diff --git a/Demos/AllBulletDemos/CMakeLists.txt b/Demos/AllBulletDemos/CMakeLists.txt deleted file mode 100644 index 5fb0dce1c..000000000 --- a/Demos/AllBulletDemos/CMakeLists.txt +++ /dev/null @@ -1,87 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/Extras -${BULLET_PHYSICS_SOURCE_DIR}/Extras/GIMPACTUtils -${BULLET_PHYSICS_SOURCE_DIR}/Extras/HACD -${BULLET_PHYSICS_SOURCE_DIR}/Extras/ConvexDecomposition -${BULLET_PHYSICS_SOURCE_DIR}/Extras/LibXML -${BULLET_PHYSICS_SOURCE_DIR}/Extras/LibXML/include -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter -${VECTOR_MATH_INCLUDE} -) - -LINK_LIBRARIES( -GLUI GIMPACTUtils HACD ConvexDecomposition OpenGLSupport BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -SET(AllBulletDemos_SRCS - Main.cpp - DemoEntries.cpp - ../CcdPhysicsDemo/CcdPhysicsDemo.cpp - ../BasicDemo/BasicDemo.cpp - ../BspDemo/BspDemo.cpp - ../BspDemo/BspConverter.cpp - ../BspDemo/BspLoader.cpp - ../DynamicControlDemo/MotorDemo.cpp - ../ConcaveDemo/ConcavePhysicsDemo.cpp - ../ConcaveRaycastDemo/ConcaveRaycastDemo.cpp - ../ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp - ../ConvexDecompositionDemo/ConvexDecompositionDemo.cpp - ../SliderConstraintDemo/SliderConstraintDemo.cpp - ../RagdollDemo/RagdollDemo.cpp - ../GimpactTestDemo/GimpactTestDemo.cpp - ../Raytracer/Raytracer.cpp - ../GjkConvexCastDemo/LinearConvexCastDemo.cpp - ../ForkLiftDemo/ForkLiftDemo.cpp - ../SoftDemo/SoftDemo.cpp - ../ConstraintDemo/ConstraintDemo.cpp - ../Benchmarks/BenchmarkDemo.cpp - ../Box2dDemo/Box2dDemo.cpp - -) - -IF (WIN32) - ADD_EXECUTABLE(AppAllBulletDemos - ${AllBulletDemos_SRCS} - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppAllBulletDemos - ${AllBulletDemos_SRCS} - ) -ENDIF() - - - - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - ADD_CUSTOM_COMMAND( - TARGET AppAllBulletDemos - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SerializeDemo/testFile.bullet ${CMAKE_CURRENT_BINARY_DIR}/testFile.bullet - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/file.obj ${CMAKE_CURRENT_BINARY_DIR} - ) -ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppAllBulletDemos PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppAllBulletDemos PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppAllBulletDemos PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/AllBulletDemos/DemoEntries.cpp b/Demos/AllBulletDemos/DemoEntries.cpp deleted file mode 100644 index eb35f02c0..000000000 --- a/Demos/AllBulletDemos/DemoEntries.cpp +++ /dev/null @@ -1,178 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "DemoEntries.h" - -#include "../CcdPhysicsDemo/CcdPhysicsDemo.h" -#include "../BspDemo/BspDemo.h" -#include "../BasicDemo/BasicDemo.h" -#include "../ConcaveDemo/ConcaveDemo.h" -#include "../ConcaveRaycastDemo/ConcaveRaycastDemo.h" -#include "../ConcaveConvexcastDemo/ConcaveConvexcastDemo.h" -#include "../ConvexDecompositionDemo/ConvexDecompositionDemo.h" -#include "../DynamicControlDemo/MotorDemo.h" -#include "../SliderConstraintDemo/SliderConstraintDemo.h" -#include "../RagdollDemo/RagdollDemo.h" -#include "../GimpactTestDemo/GimpactTestDemo.h" -#include "../Raytracer/Raytracer.h" -#include "../GjkConvexCastDemo/LinearConvexCastDemo.h" -#include "../ForkLiftDemo/ForkLiftDemo.h" -#include "../ConstraintDemo/ConstraintDemo.h" -//#include "../Benchmarks/BenchmarkDemo.h" -#include "../SoftDemo/SoftDemo.h" -//#include "../Box2dDemo/Box2dDemo.h" - -#include "GLDebugFont.h" - -#include "GlutStuff.h"//OpenGL stuff - - -extern int gNumAlignedAllocs; -extern int gNumAlignedFree; -extern int gTotalBytesAlignedAllocs; - -class btEmptyDebugDemo : public GlutDemoApplication -{ -public: - btEmptyDebugDemo() - { - - } - - virtual void clientMoveAndDisplay() - { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float xOffset = 10.f; - float yStart = 20.f; - float yIncr = 20.f; - char buf[124]; - - - glColor3f(0, 0, 0); - - setOrthographicProjection(); - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"gNumAlignedAllocs= %d",gNumAlignedAllocs); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"gNumAlignedFree= %d",gNumAlignedFree); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"# alloc-free = %d",gNumAlignedAllocs-gNumAlignedFree); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; -#ifdef BT_DEBUG_MEMORY_ALLOCATIONS - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"gTotalBytesAlignedAllocs = %d",gTotalBytesAlignedAllocs); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; -#endif //BT_DEBUG_MEMORY_ALLOCATIONS - - glFlush(); - glutSwapBuffers(); - - } - - virtual void initPhysics() {} - - static DemoApplication* Create() - { - btEmptyDebugDemo* demo = new btEmptyDebugDemo(); - demo->myinit(); - return demo; - } - -}; - - -btDemoEntry g_demoEntries[] = -{ -// {"Box2dDemo",Box2dDemo::Create}, - {"ForkLift Demo",ForkLiftDemo::Create}, - {"Dynamic Control Demo",MotorDemo::Create}, - {"ConstraintDemo",ConstraintDemo::Create}, - - {"Ragdoll Demo",RagdollDemo::Create}, - {"Basic Demo", BasicDemo::Create}, - {"CcdPhysicsDemo", CcdPhysicsDemo::Create}, - {"Convex Decomposition",ConvexDecompositionDemo::Create}, - {"Concave Moving", GimpactConcaveDemo::Create}, - - {"ConcaveDemo",ConcaveDemo::Create}, - {"Concave Convexcast Demo",ConcaveConvexcastDemo::Create}, - {"SoftBody Cluster Collide1",SoftDemo19::Create}, - - {"SoftBody Ropes Attach",SoftDemo4::Create}, - - {"SoftBody Cloth Attach",SoftDemo5::Create}, - - {"SoftBody Cloth",SoftDemo0::Create}, - -// {"SoftBody Volume",SoftDemo2::Create}, - {"SoftBody Pressure",SoftDemo1::Create}, - {"SoftBody Cluster Car",SoftDemo24::Create}, - {"SoftBody Cluster Robot",SoftDemo25::Create}, - // {"SoftBody Ropes",SoftDemo3::Create}, - {"SoftBody Sticks",SoftDemo6::Create}, - {"SoftBody Collide",SoftDemo7::Create}, - {"SoftBody Collide2",SoftDemo8::Create}, -// {"SoftBody Collide3",SoftDemo9::Create}, -// {"SoftBody Impact",SoftDemo10::Create}, - {"SoftBody Aero",SoftDemo11::Create}, - {"SoftBody Friction",SoftDemo12::Create}, -// {"SoftBody Torus",SoftDemo13::Create}, -// {"SoftBody Torus Match",SoftDemo14::Create}, -// {"SoftBody Bunny",SoftDemo15::Create}, -// {"SoftBody Bunny Match",SoftDemo16::Create}, - {"SoftBody Init Cutting",SoftDemo17::Create}, -// {"SoftBody Cluster Deform",SoftDemo18::Create}, - -// {"SoftBody Cluster Collide2",SoftDemo20::Create}, -// {"SoftBody Cluster Socket",SoftDemo21::Create}, - {"SoftBody Cluster Hinge",SoftDemo22::Create}, - {"SoftBody Cluster Combine",SoftDemo23::Create}, -// {"SoftBody Cluster Stack Soft",SoftDemo26::Create}, - {"SoftBody Cluster Stack Mixed",SoftDemo27::Create}, - - {"SoftBody TetGen Tetrahedral Cube",SoftDemo28::Create}, - {"SoftBody TetGen Tetrahedral Bunny",SoftDemo29::Create}, - - -// {"SliderConstraint",SliderConstraintDemo::Create}, - -// {"ConcaveRaycastDemo",ConcaveRaycastDemo::Create}, - //{"BspDemo", BspDemo::Create}, -// {"Raytracer Test",Raytracer::Create}, -// {"GjkConvexCast",LinearConvexCastDemo::Create}, -// {"Benchmark 3000 FALL",BenchmarkDemo1::Create}, -// {"Benchmark 1000 STACK",BenchmarkDemo2::Create}, -// {"Benchmark 136 RAGDOLLS",BenchmarkDemo3::Create}, -// {"Benchmark 1000 CONVEX",BenchmarkDemo4::Create}, -// {"Benchmark Mesh-Prim",BenchmarkDemo5::Create}, -// {"Benchmark Mesh-Convex",BenchmarkDemo6::Create}, -// {"Benchmark Raycast",BenchmarkDemo7::Create}, - - {"MemoryLeak Checker",btEmptyDebugDemo::Create}, - {0, 0} -}; - - diff --git a/Demos/AllBulletDemos/DemoEntries.h b/Demos/AllBulletDemos/DemoEntries.h deleted file mode 100644 index 41fd8571a..000000000 --- a/Demos/AllBulletDemos/DemoEntries.h +++ /dev/null @@ -1,34 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef BT_DEMO_ENTRIES_H -#define BT_DEMO_ENTRIES_H - - -class DemoApplication; - -typedef DemoApplication* DemoCreateFcn(); - -struct btDemoEntry -{ - const char *name; - DemoCreateFcn *createFcn; -}; - -extern btDemoEntry g_demoEntries[]; - - - -#endif //BT_DEMO_ENTRIES_H diff --git a/Demos/AllBulletDemos/Main.cpp b/Demos/AllBulletDemos/Main.cpp deleted file mode 100644 index c59e18d3b..000000000 --- a/Demos/AllBulletDemos/Main.cpp +++ /dev/null @@ -1,574 +0,0 @@ -/* -* Copyright (c) 2006-2007 Erin Catto http://www.gphysics.com -* -* This software is provided 'as-is', without any express or implied -* warranty. In no event will the authors be held liable for any damages -* arising from the use of this software. -* Permission is granted to anyone to use this software for any purpose, -* including commercial applications, and to alter it and redistribute it -* freely, subject to the following restrictions: -* 1. The origin of this software must not be misrepresented; you must not -* claim that you wrote the original software. If you use this software -* in a product, an acknowledgment in the product documentation would be -* appreciated but is not required. -* 2. Altered source versions must be plainly marked as such, and must not be -* misrepresented as being the original software. -* 3. This notice may not be removed or altered from any source distribution. -*/ - -#include - -#include "glui/GL/glui.h" -#include "LinearMath/btScalar.h" -#include "LinearMath/btMinMax.h" -#include "BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.h" -#include "DemoApplication.h" -#include "DemoEntries.h" -#include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h" -#include "BulletSoftBody/btSoftRigidDynamicsWorld.h" -#include "BulletSoftBody/btSoftBodyHelpers.h" - -#include "GLDebugDrawer.h" -static GLDebugDrawer dDebugDraw2; - -#include "LinearMath/btQuickprof.h" - - - -namespace -{ - int testIndex=1; - int testSelection=0; - btDemoEntry* entry; - DemoApplication* demo; - int iterationCount; - int width; - int height; - int framePeriod;//todo: test if this value should be 0 - int mainWindow; - GLUI *glui; - //float hz; - float viewZoom=20.f; - float viewX; - float viewY; - int tx, ty, tw, th; - int gDrawAabb; - int gWireFrame; - int gDrawNormals; - int gHelpText; - int gDebugConstraints; - int gDebugContacts; - int gDrawTextures=1; - int gDrawShadows=0; - int gDrawClusters=0; - int gDebugNoDeactivation; - int gUseWarmstarting; - int gRandomizeConstraints; - int gUseSplitImpulse; - float gErp; - float gSlop; - float gErp2; - float gWarmStartingParameter; -} - - - -void setDefaultSettings() -{ - viewX = 0.0f; - viewY = 0.0f; - framePeriod = 6;//16;//16;//todo: test if this value should be 0 - - width = 1280; - height = 768;//480; - iterationCount = 10; - gDrawAabb=0; - gDrawNormals=0; - gWireFrame=0; - gDebugContacts=0; - //enable constraint debug visualization for first demo, only if user hasn't overridden the setting - if (testSelection>1) - { - gDebugConstraints=0; - } else - { - gDebugConstraints=1; - } - gHelpText = 0; - gDrawTextures=1; - gDrawShadows=0; - gDrawClusters=0; - - gDebugNoDeactivation = 0; - gUseSplitImpulse = 1; - gUseWarmstarting = 1; - gRandomizeConstraints = 0; - gErp = 0.2f; - gSlop=0.0f; - gErp2 = 0.81f; - gWarmStartingParameter = 0.85f; - -} - -void setDefaultSettingsAndSync() -{ - setDefaultSettings(); - glui->sync_live(); -} - - -void TogglePause() -{ - if (demo) - demo->toggleIdle(); -} - -void ResetScene() -{ - if (demo) - demo->clientResetScene(); -} - -void NextScene() -{ - testSelection++; - if (testSelection>1) - { - gDebugConstraints=0; - } else - { - gDebugConstraints=1; - } - - if(testSelection>28) - testSelection=0; - if (glui) - glui->sync_live(); -} - - -void SingleSimulationStep() -{ - if (demo) - demo->clientMoveAndDisplay(); -} - - -void Resize(int w, int h) -{ - width = w; - height = h; - - GLUI_Master.get_viewport_area( &tx, &ty, &tw, &th ); - glViewport( tx, ty, tw, th ); - - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - if (demo) - demo->reshape(tw, th); -} - -DemoApplication* CreatDemo(btDemoEntry* entry) -{ - DemoApplication* demo = entry->createFcn(); - btAssert(demo); - if (demo->getDynamicsWorld()) - { - demo->getDynamicsWorld()->setDebugDrawer(&dDebugDraw2); - gDrawTextures = demo->getTexturing(); - gDrawShadows = demo->getShadows(); - if (glui) - glui->sync_live(); - } - -#ifndef BT_NO_PROFILE - CProfileManager::Reset(); -#endif //BT_NO_PROFILE - - return demo; - -} - -/*b2Vec2 ConvertScreenToWorld(int x, int y) -{ - b2Vec2 p; - - float ratio = float(tw) / float(th); - float u = x / float(tw); - float v = (th - y) / float(th); - p.x = viewZoom * (viewX - ratio) * (1.0f - u) + viewZoom * (ratio + viewX) * u; - p.y = viewZoom * (viewY - 0.1f) * (1.0f - v) + viewZoom * (viewY + 1.9f) * v; - return p; -} -*/ - -// This is used to control the frame rate (60Hz). -void Timer(int) -{ - glutSetWindow(mainWindow); - glutPostRedisplay(); - glutTimerFunc(framePeriod, Timer, 0); -} - -void SimulationLoop() -{ - Resize(width, height); - - - - if (gDrawAabb) - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawAabb); - } else - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawAabb)); - } - if (gWireFrame) - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawWireframe); - } else - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawWireframe)); - } - if (gDrawNormals) - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawNormals); - } else - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawNormals)); - } - if (gHelpText) - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_NoHelpText)); - } else - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_NoHelpText); - } - if (gDebugConstraints) - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits); - } else - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits)); - } - if (gDebugContacts) - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawContactPoints); - } else - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawContactPoints)); - } - - demo->setTexturing(0!=gDrawTextures); - demo->setShadows(0!=gDrawShadows); - demo->setDrawClusters(0!=gDrawClusters); - - if (gDebugNoDeactivation) - { - demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_NoDeactivation); - } else - { - demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_NoDeactivation)); - } - - - - - if (demo->getDynamicsWorld() && demo->getDynamicsWorld()->getWorldType() == BT_DISCRETE_DYNAMICS_WORLD) - { - btDiscreteDynamicsWorld* discreteWorld = (btDiscreteDynamicsWorld*) demo->getDynamicsWorld(); - discreteWorld->getSolverInfo().m_numIterations = iterationCount; - discreteWorld->getSolverInfo().m_erp = gErp; - discreteWorld->getSolverInfo().m_erp2 = gErp2; - - discreteWorld->getSolverInfo().m_linearSlop = gSlop; - - discreteWorld->getSolverInfo().m_warmstartingFactor = gWarmStartingParameter; - discreteWorld->getSolverInfo().m_splitImpulse = gUseSplitImpulse; - - // btSequentialImpulseConstraintSolver* solver = ((btSequentialImpulseConstraintSolver*) discreteWorld->getConstraintSolver()); - - if (gUseWarmstarting) - { - discreteWorld->getSolverInfo().m_solverMode |= SOLVER_USE_WARMSTARTING; - } else - { - discreteWorld->getSolverInfo().m_solverMode &= (~SOLVER_USE_WARMSTARTING); - } - if (gRandomizeConstraints) - { - discreteWorld->getSolverInfo().m_solverMode |= SOLVER_RANDMIZE_ORDER; - } else - { - discreteWorld->getSolverInfo().m_solverMode &= (~SOLVER_RANDMIZE_ORDER); - } - } - - if (!demo->isIdle()) - { - demo->clientMoveAndDisplay(); - - - } - else - { - demo->displayCallback(); - } - - if (demo->getDynamicsWorld() && demo->getDynamicsWorld()->getWorldType()==BT_SOFT_RIGID_DYNAMICS_WORLD) - { - btSoftRigidDynamicsWorld* softWorld = (btSoftRigidDynamicsWorld*)demo->getDynamicsWorld(); - for ( int i=0;igetSoftBodyArray().size();i++) - { - btSoftBody* psb=(btSoftBody*)softWorld->getSoftBodyArray()[i]; - if (softWorld->getDebugDrawer() && !(softWorld->getDebugDrawer()->getDebugMode() & (btIDebugDraw::DBG_DrawWireframe))) - { - btSoftBodyHelpers::DrawFrame(psb,softWorld->getDebugDrawer()); - btSoftBodyHelpers::Draw(psb,softWorld->getDebugDrawer(),softWorld->getDrawFlags()); - } - } - } - - if (testSelection != testIndex) - { - if (testSelection>1) - { - gDebugConstraints=0; - } else - { - gDebugConstraints=1; - } - - testIndex = testSelection; - delete demo; - entry = g_demoEntries + testIndex; - demo = CreatDemo(entry); - viewZoom = 20.0f; - viewX = 0.0f; - viewY = 0.0f; - Resize(width, height); - } -} - -void RestartScene() -{ - delete demo; - entry = g_demoEntries + testIndex; - demo = CreatDemo(entry); - viewZoom = 20.0f; - viewX = 0.0f; - viewY = 0.0f; - Resize(width, height); -} - -void Keyboard(unsigned char key, int x, int y) -{ - - - - - switch (key) - { - case 27: - exit(0); - break; - - // Press 'r' to reset. - case 'r': - delete demo; - demo = CreatDemo(entry); - Resize(width,height); - break; - - default: - if (demo) - { - demo->keyboardCallback(key,x,y); - } - } -} - -void KeyboardSpecialUp(int key, int x, int y) -{ - if (demo) - { - demo->specialKeyboardUp(key,x,y); - } - -} - - -void GlutIdleFunc() -{ - int current_window, new_window=-1; - current_window = glutGetWindow(); - if (GLUI_Master.gluis.first_child() != NULL ) - { - new_window = ((GLUI_Main*)GLUI_Master.gluis.first_child())->getMainWindowId(); - } - if ( (new_window > 0) && (new_window != current_window )) - { - //--- Window is changed only if its not already the current window --- - glutSetWindow( new_window ); - } - - if (demo) - demo->moveAndDisplay(); - - glutSetWindow( current_window ); -} - -void KeyboardSpecial(int key, int x, int y) -{ - - if (demo) - { - demo->specialKeyboard(key,x,y); - } - -} - - -void Mouse(int button, int state, int x, int y) -{ - if (demo) - demo->mouseFunc(button,state,x,y); -} - -void MouseMotion(int x, int y) -{ - demo->mouseMotionFunc(x,y); -} - -#ifdef BT_USE_FREEGLUT -#include "GL/freeglut_ext.h" -#endif - -int main(int argc, char** argv) -{ - -//#define CHECK_FPU_EXCEPTIONS 1 -#ifdef CHECK_FPU_EXCEPTIONS - - int cw = _control87(0, 0); - - // Set the exception masks off, turn exceptions on - cw &= ~(EM_ZERODIVIDE | EM_INVALID); - - printf("control87 = %#x\n", cw); - - // Set the control word - _control87(cw, MCW_EM); -#endif //CHECK_FPU_EXCEPTIONS - - - setDefaultSettings(); - - int bulletVersion = btGetVersion(); - printf("Bullet version %d\n",bulletVersion); - - glutInit(&argc, argv); - glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE |GLUT_DEPTH | GLUT_STENCIL); - glutInitWindowSize(width, height); - mainWindow = glutCreateWindow("http://bulletphysics.com"); -#ifdef BT_USE_FREEGLUT - glutSetOption (GLUT_ACTION_ON_WINDOW_CLOSE, GLUT_ACTION_GLUTMAINLOOP_RETURNS); -#endif - entry = g_demoEntries + testIndex; - demo = CreatDemo(entry); - - glutDisplayFunc(SimulationLoop); - GLUI_Master.set_glutReshapeFunc(Resize); - GLUI_Master.set_glutKeyboardFunc(Keyboard); - GLUI_Master.set_glutSpecialFunc(KeyboardSpecial); - GLUI_Master.set_glutIdleFunc(GlutIdleFunc); - GLUI_Master.set_glutSpecialUpFunc(KeyboardSpecialUp); - GLUI_Master.set_glutMouseFunc(Mouse); - glutMotionFunc(MouseMotion); - - - glui = GLUI_Master.create_glui_subwindow( mainWindow, - GLUI_SUBWINDOW_RIGHT ); - - - - glui->add_statictext("Tests"); - GLUI_Listbox* testList = - glui->add_listbox("", &testSelection); - glui->add_button("Next Scene", 0,(GLUI_Update_CB)NextScene); - - glui->add_separator(); - - GLUI_Spinner* iterationSpinner = - glui->add_spinner("Iterations", GLUI_SPINNER_INT, &iterationCount); - iterationSpinner->set_int_limits(1, 250); - -/* GLUI_Spinner* hertzSpinner = - glui->add_spinner("Hertz", GLUI_SPINNER_FLOAT, &hz); - hertzSpinner->set_float_limits(5.0f, 200.0f); -*/ - - - glui->add_checkbox("DisableDeactivation", &gDebugNoDeactivation); - glui->add_checkbox("Split Impulse", &gUseSplitImpulse); - GLUI_Spinner* spinner = 0; - - spinner = glui->add_spinner("ERP", GLUI_SPINNER_FLOAT, &gErp); -// spinner->set_float_limits(0.f,1.f); -// spinner = glui->add_spinner("ERP2", GLUI_SPINNER_FLOAT, &gErp2); - spinner->set_float_limits(0.f,1.f); - spinner = glui->add_spinner("Slop", GLUI_SPINNER_FLOAT, &gSlop); - spinner->set_float_limits(0.f,1.f); -// spinner = glui->add_spinner("WSP", GLUI_SPINNER_FLOAT,&gWarmStartingParameter); -// spinner->set_float_limits (0.f,1.0); - glui->add_checkbox("Warmstarting", &gUseWarmstarting); - glui->add_checkbox("Randomize Constraints", &gRandomizeConstraints); - - - glui->add_button("Reset Defaults", 0,(GLUI_Update_CB)setDefaultSettingsAndSync); - glui->add_separator(); - - GLUI_Panel* drawPanel = glui->add_panel("Debug Draw"); - - - glui->add_checkbox_to_panel(drawPanel, "Help", &gHelpText); - glui->add_checkbox_to_panel(drawPanel, "AABBs", &gDrawAabb); - glui->add_checkbox_to_panel(drawPanel, "Wireframe", &gWireFrame); - glui->add_checkbox_to_panel(drawPanel, "Normals", &gDrawNormals); - glui->add_checkbox_to_panel(drawPanel, "Contacts", &gDebugContacts); - glui->add_checkbox_to_panel(drawPanel, "Constraints", &gDebugConstraints); - - glui->add_checkbox_to_panel(drawPanel, "Textures", &gDrawTextures); - glui->add_checkbox_to_panel(drawPanel, "Shadows", &gDrawShadows); - glui->add_checkbox_to_panel(drawPanel, "Clusters", &gDrawClusters); - - int testCount = 0; - btDemoEntry* e = g_demoEntries; - while (e->createFcn) - { - testList->add_item(testCount, e->name); - ++testCount; - ++e; - } - - glui->add_separator(); - - glui->add_button("Toggle Pause", 0,(GLUI_Update_CB)TogglePause); - - glui->add_button("Single Step", 0,(GLUI_Update_CB)SingleSimulationStep); - glui->add_button("Reset Scene", 0,(GLUI_Update_CB)ResetScene); - glui->add_button("Restart Scene", 0,(GLUI_Update_CB)RestartScene); - - glui->add_separator(); - -// glui->add_button("Exit", 0,(GLUI_Update_CB)exit); - - glui->set_main_gfx_window( mainWindow ); - - // Use a timer to control the frame rate. - glutTimerFunc(framePeriod, Timer, 0); - - glutMainLoop(); - - return 0; -} diff --git a/Demos/AllBulletDemos/Makefile.am b/Demos/AllBulletDemos/Makefile.am deleted file mode 100644 index aab8b9854..000000000 --- a/Demos/AllBulletDemos/Makefile.am +++ /dev/null @@ -1,34 +0,0 @@ -noinst_PROGRAMS=AllBulletDemo - -AllBulletDemo_SOURCES=\ - ../SoftDemo/SoftDemo.cpp \ - ../ConstraintDemo/ConstraintDemo.cpp \ - ../ForkLiftDemo/ForkLiftDemo.cpp \ - ../RagdollDemo/RagdollDemo.cpp \ - ../BasicDemo/BasicDemo.cpp \ - ../CcdPhysicsDemo/CcdPhysicsDemo.cpp \ - ../SliderConstraintDemo/SliderConstraintDemo.cpp \ - ../ConcaveRaycastDemo/ConcaveRaycastDemo.cpp \ - ../Raytracer/Raytracer.cpp \ - ../BspDemo/BspDemo.cpp \ - ../BspDemo/BspLoader.cpp \ - ../BspDemo/BspConverter.cpp \ - ../ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp \ - ../ConvexDecompositionDemo/ConvexDecompositionDemo.cpp \ - ../GimpactTestDemo/GimpactTestDemo.cpp \ - ../GjkConvexCastDemo/LinearConvexCastDemo.cpp \ - ../ConcaveDemo/ConcavePhysicsDemo.cpp \ - ../DynamicControlDemo/MotorDemo.cpp \ - DemoEntries.cpp \ - DemoEntries.h\ - Main.cpp -AllBulletDemo_CXXFLAGS=\ - -I@top_builddir@/src \ - -I@top_builddir@/Extras/GIMPACTUtils \ - -I@top_builddir@/Extras/ConvexDecomposition \ - -I@top_builddir@/Extras/HACD \ - -I@top_builddir@/Extras \ - -I@top_builddir@/Demos/OpenGL \ - -I@top_builddir@/Demos/SoftDemo \ - $(CXXFLAGS) -AllBulletDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -L../../Extras -lgimpactutils -lconvexdecomposition -lHACD -lBulletSoftBody -lBulletDynamics -lBulletCollision -lLinearMath -lglui @opengl_LIBS@ diff --git a/Demos/BasicDemo/BasicDemo.cpp b/Demos/BasicDemo/BasicDemo.cpp deleted file mode 100644 index 5cdfb0f16..000000000 --- a/Demos/BasicDemo/BasicDemo.cpp +++ /dev/null @@ -1,147 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -///create 125 (5x5x5) dynamic object -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - -///scaling of the objects (0.1 = 20 centimeter boxes ) -#define SCALING 1. -#define START_POS_X -5 -#define START_POS_Y -5 -#define START_POS_Z -3 - -#include "BasicDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" - -#include //printf debugging -#include "GLDebugDrawer.h" -#include "LinearMath/btAabbUtil2.h" - -static GLDebugDrawer gDebugDraw; - -///The MyOverlapCallback is used to show how to collect object that overlap with a given bounding box defined by aabbMin and aabbMax. -///See m_physicsSetup.m_dynamicsWorld->getBroadphase()->aabbTest. -struct MyOverlapCallback : public btBroadphaseAabbCallback -{ - btVector3 m_queryAabbMin; - btVector3 m_queryAabbMax; - - int m_numOverlap; - MyOverlapCallback(const btVector3& aabbMin, const btVector3& aabbMax ) : m_queryAabbMin(aabbMin),m_queryAabbMax(aabbMax),m_numOverlap(0) {} - virtual bool process(const btBroadphaseProxy* proxy) - { - btVector3 proxyAabbMin,proxyAabbMax; - btCollisionObject* colObj0 = (btCollisionObject*)proxy->m_clientObject; - colObj0->getCollisionShape()->getAabb(colObj0->getWorldTransform(),proxyAabbMin,proxyAabbMax); - if (TestAabbAgainstAabb2(proxyAabbMin,proxyAabbMax,m_queryAabbMin,m_queryAabbMax)) - { - m_numOverlap++; - } - return true; - } -}; - -void BasicDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - m_physicsSetup.stepSimulation(ms/1000000.f); - m_physicsSetup.m_dynamicsWorld->debugDrawWorld(); - - /* - ///step the simulation - if (m_physicsSetup.m_dynamicsWorld) - { - m_physicsSetup.m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_physicsSetup.m_dynamicsWorld->debugDrawWorld(); - - btVector3 aabbMin(1,1,1); - btVector3 aabbMax(2,2,2); - - MyOverlapCallback aabbOverlap(aabbMin,aabbMax); - m_physicsSetup.m_dynamicsWorld->getBroadphase()->aabbTest(aabbMin,aabbMax,aabbOverlap); - - //if (aabbOverlap.m_numOverlap) - // printf("#aabb overlap = %d\n", aabbOverlap.m_numOverlap); - } - */ - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void BasicDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_physicsSetup.m_dynamicsWorld) - m_physicsSetup.m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - - - - -void BasicDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(SCALING*50.)); - GraphicsPhysicsBridge gfxBridge; - m_physicsSetup.initPhysics(gfxBridge); - - m_dynamicsWorld = m_physicsSetup.m_dynamicsWorld; - m_dynamicsWorld->setDebugDrawer(&gDebugDraw); - -} -void BasicDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void BasicDemo::exitPhysics() -{ - m_physicsSetup.exitPhysics(); -} - - - - diff --git a/Demos/BasicDemo/BasicDemo.h b/Demos/BasicDemo/BasicDemo.h deleted file mode 100644 index ae6bf7149..000000000 --- a/Demos/BasicDemo/BasicDemo.h +++ /dev/null @@ -1,67 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef BASIC_DEMO_H -#define BASIC_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -#include "LinearMath/btAlignedObjectArray.h" -#include "BasicDemoPhysicsSetup.h" - - -///BasicDemo is good starting point for learning the code base and porting. - -class BasicDemo : public PlatformDemoApplication -{ - - BasicDemoPhysicsSetup m_physicsSetup; - - public: - - BasicDemo() - { - } - virtual ~BasicDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - virtual void clientResetScene(); - - static DemoApplication* Create() - { - BasicDemo* demo = new BasicDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //BASIC_DEMO_H - diff --git a/Demos/BasicDemo/BasicDemoPhysicsSetup.cpp b/Demos/BasicDemo/BasicDemoPhysicsSetup.cpp deleted file mode 100644 index 6956f0fc0..000000000 --- a/Demos/BasicDemo/BasicDemoPhysicsSetup.cpp +++ /dev/null @@ -1,91 +0,0 @@ - - -#include "BasicDemoPhysicsSetup.h" -#include "btBulletDynamicsCommon.h" -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Z 5 - -void BasicDemoPhysicsSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - if (m_dynamicsWorld->getDebugDrawer()) - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawWireframe+btIDebugDraw::DBG_DrawContactPoints); - - ///create a few basic rigid bodies - btBoxShape* groundShape = createBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); - gfxBridge.createCollisionShapeGraphicsObject(groundShape); - - //groundShape->initializePolyhedralFeatures(); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - - { - btScalar mass(0.); - btRigidBody* body = createRigidBody(mass,groundTransform,groundShape, btVector4(0,0,1,1)); - gfxBridge.createRigidBodyGraphicsObject(body, btVector3(0, 1, 0)); - } - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btBoxShape* colShape = createBoxShape(btVector3(1,1,1)); - gfxBridge.createCollisionShapeGraphicsObject(colShape); - - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - - for (int k=0;k //printf debugging -#include "Taru.mdl" -#include "landscape.mdl" -#include "BulletCollision/BroadphaseCollision/btDbvtBroadphase.h" -#ifdef USE_PARALLEL_DISPATCHER_BENCHMARK -#include "BulletMultiThreaded/SpuGatheringCollisionDispatcher.h" -#include "BulletMultiThreaded/SequentialThreadSupport.h" -#include "BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" -#endif - -#include "BulletCollision/CollisionDispatch/btSimulationIslandManager.h" - - -#ifdef USE_PARALLEL_DISPATCHER_BENCHMARK -#ifdef _WIN32 -#include "BulletMultiThreaded/Win32ThreadSupport.h" -#elif defined (USE_PTHREADS) -#include "BulletMultiThreaded/PosixThreadSupport.h" -#endif -#include "BulletMultiThreaded/SpuGatheringCollisionDispatcher.h" -#include "BulletMultiThreaded/btParallelConstraintSolver.h" - - - - -btThreadSupportInterface* createSolverThreadSupport(int maxNumThreads) -{ -//#define SEQUENTIAL -#ifdef SEQUENTIAL - SequentialThreadSupport::SequentialThreadConstructionInfo tci("solverThreads",SolverThreadFunc,SolverlsMemoryFunc); - SequentialThreadSupport* threadSupport = new SequentialThreadSupport(tci); - threadSupport->startSPU(); -#else - -#ifdef _WIN32 - Win32ThreadSupport::Win32ThreadConstructionInfo threadConstructionInfo("solverThreads",SolverThreadFunc,SolverlsMemoryFunc,maxNumThreads); - Win32ThreadSupport* threadSupport = new Win32ThreadSupport(threadConstructionInfo); - threadSupport->startSPU(); -#elif defined (USE_PTHREADS) - PosixThreadSupport::ThreadConstructionInfo solverConstructionInfo("solver", SolverThreadFunc, - SolverlsMemoryFunc, maxNumThreads); - - PosixThreadSupport* threadSupport = new PosixThreadSupport(solverConstructionInfo); - -#else - SequentialThreadSupport::SequentialThreadConstructionInfo tci("solverThreads",SolverThreadFunc,SolverlsMemoryFunc); - SequentialThreadSupport* threadSupport = new SequentialThreadSupport(tci); - threadSupport->startSPU(); -#endif - -#endif - - return threadSupport; -} -#endif - -class btRaycastBar2 -{ -public: - btVector3 source[NUMRAYS]; - btVector3 dest[NUMRAYS]; - btVector3 direction[NUMRAYS]; - btVector3 hit[NUMRAYS]; - btVector3 normal[NUMRAYS]; - - int frame_counter; - int ms; - int sum_ms; - int sum_ms_samples; - int min_ms; - int max_ms; - -#ifdef USE_BT_CLOCK - btClock frame_timer; -#endif //USE_BT_CLOCK - - btScalar dx; - btScalar min_x; - btScalar max_x; - btScalar max_y; - btScalar sign; - - btRaycastBar2 () - { - ms = 0; - max_ms = 0; - min_ms = 9999; - sum_ms_samples = 0; - sum_ms = 0; - } - - - - btRaycastBar2 (btScalar ray_length, btScalar z,btScalar max_y) - { - frame_counter = 0; - ms = 0; - max_ms = 0; - min_ms = 9999; - sum_ms_samples = 0; - sum_ms = 0; - dx = 10.0; - min_x = 0; - max_x = 0; - this->max_y = max_y; - sign = 1.0; - btScalar dalpha = 2*SIMD_2_PI/NUMRAYS; - for (int i = 0; i < NUMRAYS; i++) - { - btScalar alpha = dalpha * i; - // rotate around by alpha degrees y - btQuaternion q(btVector3(0.0, 1.0, 0.0), alpha); - direction[i] = btVector3(1.0, 0.0, 0.0); - direction[i] = quatRotate(q , direction[i]); - direction[i] = direction[i] * ray_length; - - - source[i] = btVector3(min_x, max_y, z); - dest[i] = source[i] + direction[i]; - dest[i][1]=-1000; - normal[i] = btVector3(1.0, 0.0, 0.0); - } - } - - void move (btScalar dt) - { - if (dt > btScalar(1.0/60.0)) - dt = btScalar(1.0/60.0); - for (int i = 0; i < NUMRAYS; i++) - { - source[i][0] += dx * dt * sign; - dest[i][0] += dx * dt * sign; - } - if (source[0][0] < min_x) - sign = 1.0; - else if (source[0][0] > max_x) - sign = -1.0; - } - - void cast (btCollisionWorld* cw) - { -#ifdef USE_BT_CLOCK - frame_timer.reset (); -#endif //USE_BT_CLOCK - -#ifdef BATCH_RAYCASTER - if (!gBatchRaycaster) - return; - - gBatchRaycaster->clearRays (); - for (int i = 0; i < NUMRAYS; i++) - { - gBatchRaycaster->addRay (source[i], dest[i]); - } - gBatchRaycaster->performBatchRaycast (); - for (int i = 0; i < gBatchRaycaster->getNumRays (); i++) - { - const SpuRaycastTaskWorkUnitOut& out = (*gBatchRaycaster)[i]; - hit[i].setInterpolate3(source[i],dest[i],out.hitFraction); - normal[i] = out.hitNormal; - normal[i].normalize (); - } -#else - for (int i = 0; i < NUMRAYS; i++) - { - btCollisionWorld::ClosestRayResultCallback cb(source[i], dest[i]); - - cw->rayTest (source[i], dest[i], cb); - if (cb.hasHit ()) - { - hit[i] = cb.m_hitPointWorld; - normal[i] = cb.m_hitNormalWorld; - normal[i].normalize (); - } else { - hit[i] = dest[i]; - normal[i] = btVector3(1.0, 0.0, 0.0); - } - - } -#ifdef USE_BT_CLOCK - ms += frame_timer.getTimeMilliseconds (); -#endif //USE_BT_CLOCK - frame_counter++; - if (frame_counter > 50) - { - min_ms = ms < min_ms ? ms : min_ms; - max_ms = ms > max_ms ? ms : max_ms; - sum_ms += ms; - sum_ms_samples++; - btScalar mean_ms = (btScalar)sum_ms/(btScalar)sum_ms_samples; - printf("%d rays in %d ms %d %d %f\n", NUMRAYS * frame_counter, ms, min_ms, max_ms, mean_ms); - ms = 0; - frame_counter = 0; - } -#endif - } - - void draw () - { -#ifdef USE_GRAPHICAL_BENCHMARK - glDisable (GL_LIGHTING); - glColor3f (0.0, 1.0, 0.0); - glBegin (GL_LINES); - int i; - - for (i = 0; i < NUMRAYS; i++) - { - glVertex3f (source[i][0], source[i][1], source[i][2]); - glVertex3f (hit[i][0], hit[i][1], hit[i][2]); - } - glEnd (); - glColor3f (1.0, 1.0, 1.0); - glBegin (GL_LINES); - for (i = 0; i < NUMRAYS; i++) - { - glVertex3f (hit[i][0], hit[i][1], hit[i][2]); - glVertex3f (hit[i][0] + normal[i][0], hit[i][1] + normal[i][1], hit[i][2] + normal[i][2]); - } - glEnd (); - glColor3f (0.0, 1.0, 1.0); - glBegin (GL_POINTS); - for ( i = 0; i < NUMRAYS; i++) - { - glVertex3f (hit[i][0], hit[i][1], hit[i][2]); - } - glEnd (); - glEnable (GL_LIGHTING); -#endif //USE_GRAPHICAL_BENCHMARK - - } -}; - - -static btRaycastBar2 raycastBar; - - -void BenchmarkDemo::clientMoveAndDisplay() -{ -#ifdef USE_GRAPHICAL_BENCHMARK - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); -#endif //USE_GRAPHICAL_BENCHMARK - - //simple dynamics world doesn't handle fixed-time-stepping - //float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(btScalar(1./60.)); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - if (m_benchmark==7) - { - castRays(); - - raycastBar.draw(); - - } - - renderme(); - -#ifdef USE_GRAPHICAL_BENCHMARK - glFlush(); - - swapBuffers(); -#endif //USE_GRAPHICAL_BENCHMARK - -} - - - -void BenchmarkDemo::displayCallback(void) -{ - -#ifdef USE_GRAPHICAL_BENCHMARK - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -#endif //USE_GRAPHICAL_BENCHMARK -} - - - - -void BenchmarkDemo::initPhysics() -{ - - setCameraDistance(btScalar(100.)); - - ///collision configuration contains default setup for memory, collision setup - btDefaultCollisionConstructionInfo cci; - cci.m_defaultMaxPersistentManifoldPoolSize = 32768; - m_collisionConfiguration = new btDefaultCollisionConfiguration(cci); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_dispatcher->setDispatcherFlags(btCollisionDispatcher::CD_DISABLE_CONTACTPOOL_DYNAMIC_ALLOCATION); - -#if USE_PARALLEL_DISPATCHER_BENCHMARK - - int maxNumOutstandingTasks = 4; -#ifdef _WIN32 - Win32ThreadSupport* threadSupportCollision = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo( "collision",processCollisionTask, createCollisionLocalStoreMemory,maxNumOutstandingTasks)); -#elif defined (USE_PTHREADS) - PosixThreadSupport::ThreadConstructionInfo collisionConstructionInfo( "collision",processCollisionTask, createCollisionLocalStoreMemory,maxNumOutstandingTasks); - PosixThreadSupport* threadSupportCollision = new PosixThreadSupport(collisionConstructionInfo); -#endif - //SequentialThreadSupport::SequentialThreadConstructionInfo sci("spuCD", processCollisionTask, createCollisionLocalStoreMemory); - //SequentialThreadSupport* seq = new SequentialThreadSupport(sci); - m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupportCollision,1,m_collisionConfiguration); -#endif - - - ///the maximum size of the collision world. Make sure objects stay within these boundaries - ///Don't make the world AABB size too large, it will harm simulation quality and performance - btVector3 worldAabbMin(-1000,-1000,-1000); - btVector3 worldAabbMax(1000,1000,1000); - - btHashedOverlappingPairCache* pairCache = new btHashedOverlappingPairCache(); - m_overlappingPairCache = new btAxisSweep3(worldAabbMin,worldAabbMax,3500,pairCache); -// m_overlappingPairCache = new btSimpleBroadphase(); -// m_overlappingPairCache = new btDbvtBroadphase(); - - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) -#ifdef USE_PARALLEL_DISPATCHER_BENCHMARK - - btThreadSupportInterface* thread = createSolverThreadSupport(4); - btConstraintSolver* sol = new btParallelConstraintSolver(thread); -#else - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; -#endif //USE_PARALLEL_DISPATCHER_BENCHMARK - - - m_solver = sol; - - btDiscreteDynamicsWorld* dynamicsWorld; - m_dynamicsWorld = dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_solver,m_collisionConfiguration); - -#ifdef USE_PARALLEL_DISPATCHER_BENCHMARK - dynamicsWorld->getSimulationIslandManager()->setSplitIslands(false); -#endif //USE_PARALLEL_DISPATCHER_BENCHMARK - - ///the following 3 lines increase the performance dramatically, with a little bit of loss of quality - m_dynamicsWorld->getSolverInfo().m_solverMode |=SOLVER_ENABLE_FRICTION_DIRECTION_CACHING; //don't recalculate friction values each frame - dynamicsWorld->getSolverInfo().m_numIterations = 5; //few solver iterations - //m_defaultContactProcessingThreshold = 0.f;//used when creating bodies: body->setContactProcessingThreshold(...); - - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - if (m_benchmark<5) - { - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(250.),btScalar(50.),btScalar(250.))); - // btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),0); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - } - - switch (m_benchmark) - { - case 1: - { - createTest1(); - break; - } - case 2: - { - createTest2(); - break; - } - case 3: - { - createTest3(); - break; - } - case 4: - { - createTest4(); - break; - } - case 5: - { - createTest5(); - break; - } - case 6: - { - createTest6(); - break; - } - case 7: - { - createTest7(); - break; - } - - - default: - { - } - } - - - clientResetScene(); -} - - -void BenchmarkDemo::createTest1() -{ - // 3000 - int size = 8; - const float cubeSize = 1.0f; - float spacing = cubeSize; - btVector3 pos(0.0f, cubeSize * 2,0.f); - float offset = -size * (cubeSize * 2.0f + spacing) * 0.5f; - - btBoxShape* blockShape = new btBoxShape(btVector3(cubeSize-COLLISION_RADIUS,cubeSize-COLLISION_RADIUS,cubeSize-COLLISION_RADIUS)); - btVector3 localInertia(0,0,0); - float mass = 2.f; - blockShape->calculateLocalInertia(mass,localInertia); - - btTransform trans; - trans.setIdentity(); - - for(int k=0;k<47;k++) { - for(int j=0;jcalculateLocalInertia(mass,localInertia); - -// btScalar diffX = boxSize[0] * 1.0f; - btScalar diffY = boxSize[1] * 1.0f; - btScalar diffZ = boxSize[2] * 1.0f; - - btScalar offset = -stackSize * (diffZ * 2.0f) * 0.5f; - btVector3 pos(0.0f, diffY, 0.0f); - - btTransform trans; - trans.setIdentity(); - - while(stackSize) { - for(int i=0;icalculateLocalInertia(mass,localInertia); - - - btScalar diffX = boxSize[0]*1.02f; - btScalar diffY = boxSize[1]*1.02f; - btScalar diffZ = boxSize[2]*1.02f; - - btScalar offsetX = -stackSize * (diffX * 2.0f + space) * 0.5f; - btScalar offsetZ = -stackSize * (diffZ * 2.0f + space) * 0.5f; - while(stackSize) { - for(int j=0;jlocalCreateRigidBody(mass,trans,blockShape); - - - } - } - offsetX += diffX; - offsetZ += diffZ; - pos[1] += (diffY * 2.0f + space); - stackSize--; - } - -} - - const btVector3 rotate( const btQuaternion& quat, const btVector3 & vec ) -{ - float tmpX, tmpY, tmpZ, tmpW; - tmpX = ( ( ( quat.getW() * vec.getX() ) + ( quat.getY() * vec.getZ() ) ) - ( quat.getZ() * vec.getY() ) ); - tmpY = ( ( ( quat.getW() * vec.getY() ) + ( quat.getZ() * vec.getX() ) ) - ( quat.getX() * vec.getZ() ) ); - tmpZ = ( ( ( quat.getW() * vec.getZ() ) + ( quat.getX() * vec.getY() ) ) - ( quat.getY() * vec.getX() ) ); - tmpW = ( ( ( quat.getX() * vec.getX() ) + ( quat.getY() * vec.getY() ) ) + ( quat.getZ() * vec.getZ() ) ); - return btVector3( - ( ( ( ( tmpW * quat.getX() ) + ( tmpX * quat.getW() ) ) - ( tmpY * quat.getZ() ) ) + ( tmpZ * quat.getY() ) ), - ( ( ( ( tmpW * quat.getY() ) + ( tmpY * quat.getW() ) ) - ( tmpZ * quat.getX() ) ) + ( tmpX * quat.getZ() ) ), - ( ( ( ( tmpW * quat.getZ() ) + ( tmpZ * quat.getW() ) ) - ( tmpX * quat.getY() ) ) + ( tmpY * quat.getX() ) ) - ); -} - -void BenchmarkDemo::createTowerCircle(const btVector3& offsetPosition,int stackSize,int rotSize,const btVector3& boxSize) -{ - - btBoxShape* blockShape = new btBoxShape(btVector3(boxSize[0]-COLLISION_RADIUS,boxSize[1]-COLLISION_RADIUS,boxSize[2]-COLLISION_RADIUS)); - - btTransform trans; - trans.setIdentity(); - - float mass = 1.f; - btVector3 localInertia(0,0,0); - blockShape->calculateLocalInertia(mass,localInertia); - - - float radius = 1.3f * rotSize * boxSize[0] / SIMD_PI; - - // create active boxes - btQuaternion rotY(0,1,0,0); - float posY = boxSize[1]; - - for(int i=0;icalculateLocalInertia(mass,localInertia); - - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,shape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - m_ownerWorld->addRigidBody(body); - - return body; - } - -public: - RagDoll (btDynamicsWorld* ownerWorld, const btVector3& positionOffset,btScalar scale) - : m_ownerWorld (ownerWorld) - { - // Setup the geometry - m_shapes[BODYPART_PELVIS] = new btCapsuleShape(btScalar(0.15)*scale, btScalar(0.20)*scale); - m_shapes[BODYPART_SPINE] = new btCapsuleShape(btScalar(0.15)*scale, btScalar(0.28)*scale); - m_shapes[BODYPART_HEAD] = new btCapsuleShape(btScalar(0.10)*scale, btScalar(0.05)*scale); - m_shapes[BODYPART_LEFT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07)*scale, btScalar(0.45)*scale); - m_shapes[BODYPART_LEFT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05)*scale, btScalar(0.37)*scale); - m_shapes[BODYPART_RIGHT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07)*scale, btScalar(0.45)*scale); - m_shapes[BODYPART_RIGHT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05)*scale, btScalar(0.37)*scale); - m_shapes[BODYPART_LEFT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05)*scale, btScalar(0.33)*scale); - m_shapes[BODYPART_LEFT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04)*scale, btScalar(0.25)*scale); - m_shapes[BODYPART_RIGHT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05)*scale, btScalar(0.33)*scale); - m_shapes[BODYPART_RIGHT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04)*scale, btScalar(0.25)*scale); - - // Setup all the rigid bodies - btTransform offset; offset.setIdentity(); - offset.setOrigin(positionOffset); - - btTransform transform; - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.), btScalar(1.), btScalar(0.))); - m_bodies[BODYPART_PELVIS] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_PELVIS]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.), btScalar(1.2), btScalar(0.))); - m_bodies[BODYPART_SPINE] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_SPINE]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.), btScalar(1.6), btScalar(0.))); - m_bodies[BODYPART_HEAD] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_HEAD]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(-0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_LEFT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(-0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_LEFT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_RIGHT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_RIGHT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(-0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,M_PI_2); - m_bodies[BODYPART_LEFT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(-0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,M_PI_2); - m_bodies[BODYPART_LEFT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_ARM]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-M_PI_2); - m_bodies[BODYPART_RIGHT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(scale*btVector3(btScalar(0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-M_PI_2); - m_bodies[BODYPART_RIGHT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_ARM]); - - // Setup some damping on the m_bodies - for (int i = 0; i < BODYPART_COUNT; ++i) - { - m_bodies[i]->setDamping(btScalar(0.05), btScalar(0.85)); - m_bodies[i]->setDeactivationTime(btScalar(0.8)); - m_bodies[i]->setSleepingThresholds(btScalar(1.6), btScalar(2.5)); - } - - // Now setup the constraints - btHingeConstraint* hingeC; - btConeTwistConstraint* coneC; - - btTransform localA, localB; - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.15), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_SPINE], localA, localB); - hingeC->setLimit(btScalar(-M_PI_4), btScalar(M_PI_2)); - m_joints[JOINT_PELVIS_SPINE] = hingeC; - m_ownerWorld->addConstraint(m_joints[JOINT_PELVIS_SPINE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI_2); localA.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.30), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_HEAD], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, M_PI_2); - m_joints[JOINT_SPINE_HEAD] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_SPINE_HEAD], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,-M_PI_4*5); localA.setOrigin(scale*btVector3(btScalar(-0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,-M_PI_4*5); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_LEFT_UPPER_LEG], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, 0); - m_joints[JOINT_LEFT_HIP] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_LEG], *m_bodies[BODYPART_LEFT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_LEFT_KNEE] = hingeC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI_4); localA.setOrigin(scale*btVector3(btScalar(0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_4); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_RIGHT_UPPER_LEG], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, 0); - m_joints[JOINT_RIGHT_HIP] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_LEG], *m_bodies[BODYPART_RIGHT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_RIGHT_KNEE] = hingeC; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI); localA.setOrigin(scale*btVector3(btScalar(-0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_LEFT_UPPER_ARM], localA, localB); - coneC->setLimit(M_PI_2, M_PI_2, 0); - m_joints[JOINT_LEFT_SHOULDER] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_ARM], *m_bodies[BODYPART_LEFT_LOWER_ARM], localA, localB); - hingeC->setLimit(btScalar(-M_PI_2), btScalar(0)); - m_joints[JOINT_LEFT_ELBOW] = hingeC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_ELBOW], true); - - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,0); localA.setOrigin(scale*btVector3(btScalar(0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_RIGHT_UPPER_ARM], localA, localB); - coneC->setLimit(M_PI_2, M_PI_2, 0); - m_joints[JOINT_RIGHT_SHOULDER] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(scale*btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(scale*btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_ARM], *m_bodies[BODYPART_RIGHT_LOWER_ARM], localA, localB); - hingeC->setLimit(btScalar(-M_PI_2), btScalar(0)); - m_joints[JOINT_RIGHT_ELBOW] = hingeC; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_ELBOW], true); - } - - virtual ~RagDoll () - { - int i; - - // Remove all constraints - for ( i = 0; i < JOINT_COUNT; ++i) - { - m_ownerWorld->removeConstraint(m_joints[i]); - delete m_joints[i]; m_joints[i] = 0; - } - - // Remove all bodies and shapes - for ( i = 0; i < BODYPART_COUNT; ++i) - { - m_ownerWorld->removeRigidBody(m_bodies[i]); - - delete m_bodies[i]->getMotionState(); - - delete m_bodies[i]; m_bodies[i] = 0; - delete m_shapes[i]; m_shapes[i] = 0; - } - } -}; - -void BenchmarkDemo::createTest3() -{ - setCameraDistance(btScalar(50.)); - - int size = 16; - - float sizeX = 1.f; - float sizeY = 1.f; - - //int rc=0; - - btScalar scale(3.5); - btVector3 pos(0.0f, sizeY, 0.0f); - while(size) { - float offset = -size * (sizeX * 6.0f) * 0.5f; - for(int i=0;isetLocalScaling(btVector3(scaling,scaling,scaling)); - - for (int i=0;iaddPoint(vtx*btScalar(1./scaling)); - } - - //this will enable polyhedral contact clipping, better quality, slightly slower - //convexHullShape->initializePolyhedralFeatures(); - - btTransform trans; - trans.setIdentity(); - - float mass = 1.f; - btVector3 localInertia(0,0,0); - convexHullShape->calculateLocalInertia(mass,localInertia); - - for(int k=0;k<15;k++) { - for(int j=0;jaddIndexedMesh(part,PHY_SHORT); - - bool useQuantizedAabbCompression = true; - btBvhTriangleMeshShape* trimeshShape = new btBvhTriangleMeshShape(meshInterface,useQuantizedAabbCompression); - btVector3 localInertia(0,0,0); - trans.setOrigin(btVector3(0,-25,0)); - - btRigidBody* body = localCreateRigidBody(0,trans,trimeshShape); - body->setFriction (btScalar(0.9)); - - } - -} - - -void BenchmarkDemo::createTest5() -{ - setCameraDistance(btScalar(250.)); - btVector3 boxSize(1.5f,1.5f,1.5f); - float boxMass = 1.0f; - float sphereRadius = 1.5f; - float sphereMass = 1.0f; - float capsuleHalf = 2.0f; - float capsuleRadius = 1.0f; - float capsuleMass = 1.0f; - - { - int size = 10; - int height = 10; - - const float cubeSize = boxSize[0]; - float spacing = 2.0f; - btVector3 pos(0.0f, 20.0f, 0.0f); - float offset = -size * (cubeSize * 2.0f + spacing) * 0.5f; - - int numBodies = 0; - - for(int k=0;kaddPoint(vtx); - } - - btTransform trans; - trans.setIdentity(); - - float mass = 1.f; - btVector3 localInertia(0,0,0); - convexHullShape->calculateLocalInertia(mass,localInertia); - - - { - int size = 10; - int height = 10; - - const float cubeSize = boxSize[0]; - float spacing = 2.0f; - btVector3 pos(0.0f, 20.0f, 0.0f); - float offset = -size * (cubeSize * 2.0f + spacing) * 0.5f; - - - for(int k=0;kgetNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - } - - //delete collision shapes - for (int j=0;jgetShapeType() != INVALID_SHAPE_PROXYTYPE)); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - - btRigidBody* body = new btRigidBody(mass,0,shape,localInertia); - body->setWorldTransform(startTransform); - body->setContactProcessingThreshold(m_defaultContactProcessingThreshold); - m_dynamicsWorld->addRigidBody(body); - - return body; -} -#endif //USE_GRAPHICAL_BENCHMARK - diff --git a/Demos/Benchmarks/BenchmarkDemo.h b/Demos/Benchmarks/BenchmarkDemo.h deleted file mode 100644 index 9e0582c56..000000000 --- a/Demos/Benchmarks/BenchmarkDemo.h +++ /dev/null @@ -1,269 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef BENCHMARK_DEMO_H -#define BENCHMARK_DEMO_H - - -#include "LinearMath/btAlignedObjectArray.h" -#include "LinearMath/btTransform.h" - -class btDynamicsWorld; - -#define NUMRAYS 500 - -class btRigidBody; -class btBroadphaseInterface; -class btCollisionShape; -class btOverlappingPairCache; -class btCollisionDispatcher; -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; -class btDefaultCollisionConfiguration; - - -#ifndef USE_GRAPHICAL_BENCHMARK -///empty placeholder -class DemoApplication -{ -protected: - - btDynamicsWorld* m_dynamicsWorld; - btScalar m_defaultContactProcessingThreshold; - -public: - DemoApplication() - :m_defaultContactProcessingThreshold(BT_LARGE_FLOAT) - { - } - virtual void myinit() {} - virtual btDynamicsWorld* getDynamicsWorld() - { - return m_dynamicsWorld; - } - - btScalar getDeltaTimeMicroseconds() - { - return 1.f; - } - - void renderme() {} - void setCameraDistance(btScalar dist){} - void clientResetScene(){} - btRigidBody* localCreateRigidBody(float mass, const btTransform& startTransform,btCollisionShape* shape); - -}; -///BenchmarkDemo is provides several performance tests -#define PlatformDemoApplication DemoApplication -#else //USE_GRAPHICAL_BENCHMARK - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -#endif //USE_GRAPHICAL_BENCHMARK - - -class BenchmarkDemo : public PlatformDemoApplication -{ - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btAlignedObjectArray m_ragdolls; - - btBroadphaseInterface* m_overlappingPairCache; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - int m_benchmark; - - void createTest1(); - void createTest2(); - void createTest3(); - void createTest4(); - void createTest5(); - void createTest6(); - void createTest7(); - - void createWall(const btVector3& offsetPosition,int stackSize,const btVector3& boxSize); - void createPyramid(const btVector3& offsetPosition,int stackSize,const btVector3& boxSize); - void createTowerCircle(const btVector3& offsetPosition,int stackSize,int rotSize,const btVector3& boxSize); - void createLargeMeshBody(); - - - class SpuBatchRaycaster* m_batchRaycaster; - class btThreadSupportInterface* m_batchRaycasterThreadSupport; - - void castRays(); - void initRays(); - - public: - - BenchmarkDemo(int benchmark) - :m_benchmark(benchmark), - m_overlappingPairCache(0), - m_dispatcher(0), - m_solver(0), - m_collisionConfiguration(0) - { - } - virtual ~BenchmarkDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - - - -}; - -class BenchmarkDemo1 : public BenchmarkDemo -{ -public: - BenchmarkDemo1() - :BenchmarkDemo(1) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo1* demo = new BenchmarkDemo1; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -class BenchmarkDemo2 : public BenchmarkDemo -{ -public: - BenchmarkDemo2() - :BenchmarkDemo(2) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo2* demo = new BenchmarkDemo2; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -class BenchmarkDemo3 : public BenchmarkDemo -{ -public: - BenchmarkDemo3() - :BenchmarkDemo(3) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo3* demo = new BenchmarkDemo3; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -class BenchmarkDemo4 : public BenchmarkDemo -{ -public: - BenchmarkDemo4() - :BenchmarkDemo(4) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo4* demo = new BenchmarkDemo4; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - - -class BenchmarkDemo5 : public BenchmarkDemo -{ -public: - BenchmarkDemo5() - :BenchmarkDemo(5) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo5* demo = new BenchmarkDemo5; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - - -class BenchmarkDemo6 : public BenchmarkDemo -{ -public: - BenchmarkDemo6() - :BenchmarkDemo(6) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo6* demo = new BenchmarkDemo6; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -class BenchmarkDemo7 : public BenchmarkDemo -{ -public: - BenchmarkDemo7() - :BenchmarkDemo(7) - { - } - - static DemoApplication* Create() - { - BenchmarkDemo7* demo = new BenchmarkDemo7; - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -#endif //BENCHMARK_DEMO_H - diff --git a/Demos/Benchmarks/CMakeLists.txt b/Demos/Benchmarks/CMakeLists.txt deleted file mode 100644 index dae23300c..000000000 --- a/Demos/Benchmarks/CMakeLists.txt +++ /dev/null @@ -1,93 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# You shouldn't have to modify anything below this line -######################################################## - -IF (USE_GRAPHICAL_BENCHMARK) -IF (USE_GLUT) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${GLUT_INCLUDE_DIR} - ) - - IF (USE_MULTITHREADED_BENCHMARK) - INCLUDE_DIRECTORIES( ${VECTOR_MATH_INCLUDE} ) - LINK_LIBRARIES( OpenGLSupport BulletMultiThreaded BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}) - ELSE() - LINK_LIBRARIES( OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}) - ENDIF(USE_MULTITHREADED_BENCHMARK) - - IF (WIN32) - ADD_EXECUTABLE(AppBenchmarks - main.cpp - BenchmarkDemo.cpp - BenchmarkDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppBenchmarks - main.cpp - BenchmarkDemo.cpp - BenchmarkDemo.h - ) - ENDIF () - IF (WIN32) - IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBenchmarks PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBenchmarks PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBenchmarks PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") - ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - - ENDIF(WIN32) -ELSE (USE_GLUT) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ) - - IF (USE_MULTITHREADED_BENCHMARK) - INCLUDE_DIRECTORIES( ${VECTOR_MATH_INCLUDE} ) - LINK_LIBRARIES( - OpenGLSupport BulletMultiThreaded BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - ELSE() - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ENDIF() - - ADD_EXECUTABLE(AppBenchmarks - WIN32 - ../OpenGL/Win32AppMain.cpp - BenchmarkDemo.cpp - BenchmarkDemo.h - Win32BenchmarkDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ENDIF (USE_GLUT) -ELSE (USE_GRAPHICAL_BENCHMARK) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ) - - IF (USE_MULTITHREADED_BENCHMARK) - LINK_LIBRARIES( BulletMultiThreaded BulletDynamics BulletCollision LinearMath ) - ELSE() - LINK_LIBRARIES( BulletDynamics BulletCollision LinearMath ) - ENDIF() - - - ADD_EXECUTABLE(AppBenchmarks - main.cpp - BenchmarkDemo.cpp - ) -ENDIF (USE_GRAPHICAL_BENCHMARK) \ No newline at end of file diff --git a/Demos/Benchmarks/Taru.mdl b/Demos/Benchmarks/Taru.mdl deleted file mode 100644 index 73f708c82..000000000 --- a/Demos/Benchmarks/Taru.mdl +++ /dev/null @@ -1,49 +0,0 @@ -#define TaruVtxCount 43 -#define TaruIdxCount 132 - -static float TaruVtx[] = { -1.08664f,-1.99237f,0.0f, -0.768369f,-1.99237f,-0.768369f, -1.28852f,1.34412e-007f,-1.28852f, -1.82224f,1.90735e-007f,0.0f, -0.0f,-1.99237f,-1.08664f, -0.0f,0.0f,-1.82224f, -0.0f,-1.99237f,-1.08664f, --0.768369f,-1.99237f,-0.768369f, --1.28852f,1.34412e-007f,-1.28852f, -0.0f,0.0f,-1.82224f, --1.08664f,-1.99237f,1.82086e-007f, --1.82224f,1.90735e-007f,1.59305e-007f, --0.768369f,-1.99237f,0.76837f, --1.28852f,2.47058e-007f,1.28852f, -1.42495e-007f,-1.99237f,1.08664f, -2.38958e-007f,2.70388e-007f,1.82224f, -0.768369f,-1.99237f,0.768369f, -1.28852f,2.47058e-007f,1.28852f, -0.768369f,1.99237f,-0.768369f, -1.08664f,1.99237f,0.0f, -0.0f,1.99237f,-1.08664f, --0.768369f,1.99237f,-0.768369f, -0.0f,1.99237f,-1.08664f, --1.08664f,1.99237f,0.0f, --0.768369f,1.99237f,0.768369f, -1.42495e-007f,1.99237f,1.08664f, -0.768369f,1.99237f,0.768369f, -1.42495e-007f,-1.99237f,1.08664f, --0.768369f,-1.99237f,0.76837f, --1.08664f,-1.99237f,1.82086e-007f, --0.768369f,-1.99237f,-0.768369f, -0.0f,-1.99237f,-1.08664f, -0.768369f,-1.99237f,-0.768369f, -1.08664f,-1.99237f,0.0f, -0.768369f,-1.99237f,0.768369f, -0.768369f,1.99237f,-0.768369f, -0.0f,1.99237f,-1.08664f, --0.768369f,1.99237f,-0.768369f, --1.08664f,1.99237f,0.0f, --0.768369f,1.99237f,0.768369f, -1.42495e-007f,1.99237f,1.08664f, -0.768369f,1.99237f,0.768369f, -1.08664f,1.99237f,0.0f, -}; - diff --git a/Demos/Benchmarks/Win32BenchmarkDemo.cpp b/Demos/Benchmarks/Win32BenchmarkDemo.cpp deleted file mode 100644 index 486f308a9..000000000 --- a/Demos/Benchmarks/Win32BenchmarkDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BenchmarkDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new BenchmarkDemo(1); -} - -#endif diff --git a/Demos/Benchmarks/landscape.mdl b/Demos/Benchmarks/landscape.mdl deleted file mode 100644 index 6b879b23e..000000000 --- a/Demos/Benchmarks/landscape.mdl +++ /dev/null @@ -1,84369 +0,0 @@ -#define Landscape02VtxCount 1980 -#define Landscape02IdxCount 11310 -#include "LinearMath/btScalar.h" - -btScalar Landscape02Vtx[] = { --250.0f,2.99192f,113.281f, --250.0f,2.18397f,117.188f, --246.094f,1.62262f,113.281f, --246.094f,1.51628f,117.188f, --242.188f,0.847411f,113.281f, --242.188f,0.628327f,117.188f, --238.281f,-0.697436f,113.281f, --238.281f,-0.567933f,117.188f, --234.375f,-2.65115f,113.281f, --234.375f,-2.01568f,117.188f, --230.469f,-3.82201f,113.281f, --230.469f,-3.41089f,117.188f, --226.563f,-3.99138f,113.281f, --226.563f,-3.82758f,117.188f, --222.656f,-5.51066f,113.281f, --222.656f,-5.01586f,117.188f, --218.75f,-5.62904f,113.281f, --218.75f,-4.74822f,117.188f, --214.844f,-4.90514f,113.281f, --214.844f,-3.30853f,117.188f, --210.938f,-2.9572f,113.281f, --210.938f,-2.32499f,117.188f, --207.031f,-2.44242f,113.281f, --207.031f,-1.71509f,117.188f, --203.125f,-1.5086f,113.281f, --203.125f,-1.19203f,117.188f, --199.219f,-0.130838f,113.281f, --199.219f,0.219498f,117.188f, --195.313f,0.985417f,113.281f, --195.313f,1.66304f,117.188f, --191.406f,3.20064f,113.281f, --191.406f,4.35105f,117.188f, --187.5f,4.6779f,113.281f, --187.5f,6.33228f,117.188f, --183.594f,6.16902f,113.281f, --183.594f,8.00972f,117.188f, --179.688f,8.18835f,113.281f, --179.688f,9.71486f,117.188f, --175.781f,9.35082f,113.281f, --175.781f,10.7727f,117.188f, --171.875f,9.50665f,113.281f, --171.875f,11.358f,117.188f, --167.969f,12.1301f,113.281f, --167.969f,12.5239f,117.188f, --164.063f,14.8728f,113.281f, --164.063f,14.6278f,117.188f, --160.156f,16.3761f,113.281f, --160.156f,17.2069f,117.188f, --156.25f,18.5367f,113.281f, --156.25f,19.9779f,117.188f, --152.344f,22.4636f,113.281f, --152.344f,23.4607f,117.188f, --148.438f,26.1459f,113.281f, --148.438f,26.6108f,117.188f, --144.531f,28.6071f,113.281f, --144.531f,28.4635f,117.188f, --140.625f,30.2795f,113.281f, --140.625f,29.7705f,117.188f, --136.719f,32.2229f,113.281f, --136.719f,31.0684f,117.188f, --132.813f,32.8919f,113.281f, --132.813f,31.8395f,117.188f, --128.906f,33.5143f,113.281f, --128.906f,32.1658f,117.188f, --125.0f,34.6963f,113.281f, --125.0f,34.7478f,117.188f, --121.094f,37.3995f,113.281f, --121.094f,36.0624f,117.188f, --117.188f,38.0464f,113.281f, --117.188f,37.2702f,117.188f, --113.281f,37.8506f,113.281f, --113.281f,37.3474f,117.188f, --109.375f,37.8984f,113.281f, --109.375f,37.242f,117.188f, --105.469f,36.0464f,113.281f, --105.469f,36.1544f,117.188f, --101.563f,34.1136f,113.281f, --101.563f,33.403f,117.188f, --97.6563f,32.0925f,113.281f, --97.6563f,31.294f,117.188f, --93.75f,29.8306f,113.281f, --93.75f,29.4961f,117.188f, --89.8438f,30.1499f,113.281f, --89.8438f,29.0556f,117.188f, --85.9375f,28.8377f,113.281f, --85.9375f,28.2757f,117.188f, --82.0313f,26.9726f,113.281f, --82.0313f,26.6322f,117.188f, --78.125f,25.4597f,113.281f, --78.125f,24.8286f,117.188f, --74.2188f,23.3572f,113.281f, --74.2188f,22.7019f,117.188f, --70.3125f,21.1615f,113.281f, --70.3125f,20.4725f,117.188f, --66.4063f,18.1212f,113.281f, --66.4063f,17.984f,117.188f, --62.5f,16.3411f,113.281f, --62.5f,16.3033f,117.188f, --58.5938f,15.075f,113.281f, --58.5938f,14.2087f,117.188f, --54.6875f,14.2482f,113.281f, --54.6875f,12.8086f,117.188f, --50.7813f,13.7945f,113.281f, --50.7813f,12.5463f,117.188f, --46.875f,12.7086f,113.281f, --46.875f,12.1781f,117.188f, --42.9688f,10.5756f,113.281f, --42.9688f,11.1391f,117.188f, --39.0625f,9.99343f,113.281f, --39.0625f,10.4623f,117.188f, --35.1563f,11.0936f,113.281f, --35.1563f,11.0528f,117.188f, --31.25f,11.9553f,113.281f, --31.25f,11.454f,117.188f, --27.3438f,11.5734f,113.281f, --27.3438f,10.5577f,117.188f, --23.4375f,11.0397f,113.281f, --23.4375f,10.6328f,117.188f, --19.5313f,12.5166f,113.281f, --19.5313f,12.5569f,117.188f, --15.625f,13.856f,113.281f, --15.625f,13.5389f,117.188f, --11.7188f,14.525f,113.281f, --11.7188f,14.3792f,117.188f, --7.8125f,14.7554f,113.281f, --7.8125f,15.4809f,117.188f, --3.90625f,15.9168f,113.281f, --3.90625f,16.1008f,117.188f, -0.0f,17.0728f,113.281f, -0.0f,17.3675f,117.188f, -3.90625f,18.3498f,113.281f, -3.90625f,18.919f,117.188f, --250.0f,4.66213f,109.375f, --246.094f,2.25542f,109.375f, --242.188f,0.972654f,109.375f, --238.281f,-1.95429f,109.375f, --234.375f,-2.74128f,109.375f, --230.469f,-3.62525f,109.375f, --226.563f,-4.55305f,109.375f, --222.656f,-6.4124f,109.375f, --218.75f,-6.73329f,109.375f, --214.844f,-5.91703f,109.375f, --210.938f,-4.73996f,109.375f, --207.031f,-3.31105f,109.375f, --203.125f,-2.06764f,109.375f, --199.219f,-0.969242f,109.375f, --195.313f,0.268778f,109.375f, --191.406f,1.94799f,109.375f, --187.5f,2.80754f,109.375f, --183.594f,4.22131f,109.375f, --179.688f,5.20723f,109.375f, --175.781f,7.47197f,109.375f, --171.875f,9.45267f,109.375f, --167.969f,12.6425f,109.375f, --164.063f,14.9382f,109.375f, --160.156f,16.7967f,109.375f, --156.25f,19.5153f,109.375f, --152.344f,21.4005f,109.375f, --148.438f,25.1259f,109.375f, --144.531f,28.4102f,109.375f, --140.625f,30.7572f,109.375f, --136.719f,33.0194f,109.375f, --132.813f,33.072f,109.375f, --128.906f,33.1358f,109.375f, --125.0f,35.0549f,109.375f, --121.094f,36.4427f,109.375f, --117.188f,38.3265f,109.375f, --113.281f,38.5339f,109.375f, --109.375f,37.0126f,109.375f, --105.469f,34.9063f,109.375f, --101.563f,32.9886f,109.375f, --97.6563f,30.8964f,109.375f, --93.75f,30.5048f,109.375f, --89.8438f,30.4943f,109.375f, --85.9375f,28.8782f,109.375f, --82.0313f,28.1966f,109.375f, --78.125f,25.9164f,109.375f, --74.2188f,23.3428f,109.375f, --70.3125f,20.9839f,109.375f, --66.4063f,18.3885f,109.375f, --62.5f,16.9034f,109.375f, --58.5938f,15.2602f,109.375f, --54.6875f,14.3223f,109.375f, --50.7813f,13.3767f,109.375f, --46.875f,12.5798f,109.375f, --42.9688f,11.3276f,109.375f, --39.0625f,11.0169f,109.375f, --35.1563f,11.7482f,109.375f, --31.25f,12.5037f,109.375f, --27.3438f,12.3832f,109.375f, --23.4375f,12.3097f,109.375f, --19.5313f,12.6165f,109.375f, --15.625f,13.7744f,109.375f, --11.7188f,14.363f,109.375f, --7.8125f,14.828f,109.375f, --3.90625f,15.599f,109.375f, -0.0f,16.3885f,109.375f, -3.90625f,18.0017f,109.375f, --250.0f,5.23892f,105.469f, --246.094f,2.90481f,105.469f, --242.188f,0.264647f,105.469f, --238.281f,-0.288927f,105.469f, --234.375f,-0.910295f,105.469f, --230.469f,-2.20742f,105.469f, --226.563f,-3.6968f,105.469f, --222.656f,-5.2145f,105.469f, --218.75f,-6.07198f,105.469f, --214.844f,-5.42535f,105.469f, --210.938f,-4.82182f,105.469f, --207.031f,-3.22017f,105.469f, --203.125f,-2.28037f,105.469f, --199.219f,-1.51966f,105.469f, --195.313f,-0.0464115f,105.469f, --191.406f,1.73523f,105.469f, --187.5f,2.72489f,105.469f, --183.594f,4.39996f,105.469f, --179.688f,5.48007f,105.469f, --175.781f,7.27769f,105.469f, --171.875f,10.1115f,105.469f, --167.969f,13.0557f,105.469f, --164.063f,15.7105f,105.469f, --160.156f,17.8448f,105.469f, --156.25f,19.8398f,105.469f, --152.344f,21.6672f,105.469f, --148.438f,24.1475f,105.469f, --144.531f,28.4217f,105.469f, --140.625f,31.6921f,105.469f, --136.719f,34.3814f,105.469f, --132.813f,34.9011f,105.469f, --128.906f,33.8056f,105.469f, --125.0f,34.3226f,105.469f, --121.094f,35.6061f,105.469f, --117.188f,37.9636f,105.469f, --113.281f,38.6673f,105.469f, --109.375f,36.8831f,105.469f, --105.469f,34.5846f,105.469f, --101.563f,32.2221f,105.469f, --97.6563f,30.3826f,105.469f, --93.75f,30.4243f,105.469f, --89.8438f,30.7761f,105.469f, --85.9375f,29.8335f,105.469f, --82.0313f,28.0208f,105.469f, --78.125f,25.7215f,105.469f, --74.2188f,22.9019f,105.469f, --70.3125f,20.9096f,105.469f, --66.4063f,18.2558f,105.469f, --62.5f,16.689f,105.469f, --58.5938f,15.8032f,105.469f, --54.6875f,14.8311f,105.469f, --50.7813f,13.7628f,105.469f, --46.875f,13.0048f,105.469f, --42.9688f,11.9222f,105.469f, --39.0625f,12.021f,105.469f, --35.1563f,12.2727f,105.469f, --31.25f,12.6336f,105.469f, --27.3438f,12.6865f,105.469f, --23.4375f,12.3758f,105.469f, --19.5313f,13.0149f,105.469f, --15.625f,14.0448f,105.469f, --11.7188f,14.6064f,105.469f, --7.8125f,15.1105f,105.469f, --3.90625f,15.8367f,105.469f, -0.0f,16.822f,105.469f, -3.90625f,17.9608f,105.469f, --250.0f,4.27755f,101.563f, --246.094f,2.84639f,101.563f, --242.188f,2.00001f,101.563f, --238.281f,1.59426f,101.563f, --234.375f,0.494548f,101.563f, --230.469f,-1.78619f,101.563f, --226.563f,-2.8668f,101.563f, --222.656f,-5.00406f,101.563f, --218.75f,-6.01721f,101.563f, --214.844f,-5.29731f,101.563f, --210.938f,-4.08939f,101.563f, --207.031f,-3.76734f,101.563f, --203.125f,-2.53974f,101.563f, --199.219f,-1.06933f,101.563f, --195.313f,-0.447271f,101.563f, --191.406f,1.52362f,101.563f, --187.5f,3.40783f,101.563f, --183.594f,4.48418f,101.563f, --179.688f,6.791f,101.563f, --175.781f,8.68642f,101.563f, --171.875f,11.1511f,101.563f, --167.969f,14.4536f,101.563f, --164.063f,17.5923f,101.563f, --160.156f,19.4108f,101.563f, --156.25f,20.7669f,101.563f, --152.344f,22.2683f,101.563f, --148.438f,24.0251f,101.563f, --144.531f,27.7431f,101.563f, --140.625f,31.4827f,101.563f, --136.719f,34.3945f,101.563f, --132.813f,35.3451f,101.563f, --128.906f,34.9912f,101.563f, --125.0f,34.2253f,101.563f, --121.094f,35.1765f,101.563f, --117.188f,37.3095f,101.563f, --113.281f,37.7256f,101.563f, --109.375f,36.2331f,101.563f, --105.469f,34.435f,101.563f, --101.563f,32.1021f,101.563f, --97.6563f,31.0728f,101.563f, --93.75f,30.7462f,101.563f, --89.8438f,30.8125f,101.563f, --85.9375f,29.6802f,101.563f, --82.0313f,27.3023f,101.563f, --78.125f,25.1113f,101.563f, --74.2188f,22.6475f,101.563f, --70.3125f,20.1315f,101.563f, --66.4063f,18.0132f,101.563f, --62.5f,17.1414f,101.563f, --58.5938f,16.7884f,101.563f, --54.6875f,15.7107f,101.563f, --50.7813f,14.6855f,101.563f, --46.875f,13.3626f,101.563f, --42.9688f,11.6073f,101.563f, --39.0625f,11.3359f,101.563f, --35.1563f,12.4227f,101.563f, --31.25f,13.068f,101.563f, --27.3438f,12.4485f,101.563f, --23.4375f,11.8491f,101.563f, --19.5313f,13.6925f,101.563f, --15.625f,14.7114f,101.563f, --11.7188f,14.963f,101.563f, --7.8125f,15.0631f,101.563f, --3.90625f,16.1214f,101.563f, -0.0f,17.0818f,101.563f, -3.90625f,17.7074f,101.563f, --250.0f,4.24758f,97.6563f, --246.094f,3.92716f,97.6563f, --242.188f,3.12473f,97.6563f, --238.281f,2.07357f,97.6563f, --234.375f,0.407895f,97.6563f, --230.469f,-0.904646f,97.6563f, --226.563f,-2.62182f,97.6563f, --222.656f,-3.89204f,97.6563f, --218.75f,-5.61944f,97.6563f, --214.844f,-4.00077f,97.6563f, --210.938f,-2.40041f,97.6563f, --207.031f,-2.40061f,97.6563f, --203.125f,-1.96286f,97.6563f, --199.219f,-1.48062f,97.6563f, --195.313f,-0.101653f,97.6563f, --191.406f,1.73583f,97.6563f, --187.5f,3.67572f,97.6563f, --183.594f,5.12213f,97.6563f, --179.688f,7.63637f,97.6563f, --175.781f,10.1724f,97.6563f, --171.875f,12.2812f,97.6563f, --167.969f,15.2851f,97.6563f, --164.063f,18.2233f,97.6563f, --160.156f,20.4971f,97.6563f, --156.25f,21.878f,97.6563f, --152.344f,23.2306f,97.6563f, --148.438f,24.2686f,97.6563f, --144.531f,28.1874f,97.6563f, --140.625f,31.2597f,97.6563f, --136.719f,33.3133f,97.6563f, --132.813f,35.319f,97.6563f, --128.906f,35.1009f,97.6563f, --125.0f,34.8265f,97.6563f, --121.094f,34.2935f,97.6563f, --117.188f,36.4908f,97.6563f, --113.281f,37.1964f,97.6563f, --109.375f,36.1354f,97.6563f, --105.469f,34.3852f,97.6563f, --101.563f,30.8829f,97.6563f, --97.6563f,30.1091f,97.6563f, --93.75f,30.9329f,97.6563f, --89.8438f,30.8751f,97.6563f, --85.9375f,29.018f,97.6563f, --82.0313f,27.3105f,97.6563f, --78.125f,25.0087f,97.6563f, --74.2188f,21.6466f,97.6563f, --70.3125f,18.5043f,97.6563f, --66.4063f,18.66f,97.6563f, --62.5f,18.1592f,97.6563f, --58.5938f,17.521f,97.6563f, --54.6875f,16.3389f,97.6563f, --50.7813f,14.8664f,97.6563f, --46.875f,13.5991f,97.6563f, --42.9688f,11.873f,97.6563f, --39.0625f,11.498f,97.6563f, --35.1563f,11.5171f,97.6563f, --31.25f,12.5588f,97.6563f, --27.3438f,12.2172f,97.6563f, --23.4375f,11.2491f,97.6563f, --19.5313f,13.2373f,97.6563f, --15.625f,13.5683f,97.6563f, --11.7188f,14.0875f,97.6563f, --7.8125f,14.6591f,97.6563f, --3.90625f,15.1275f,97.6563f, -0.0f,15.8243f,97.6563f, -3.90625f,18.0176f,97.6563f, --250.0f,4.93619f,93.75f, --246.094f,3.50077f,93.75f, --242.188f,2.88532f,93.75f, --238.281f,2.19691f,93.75f, --234.375f,1.45343f,93.75f, --230.469f,-0.151238f,93.75f, --226.563f,-1.0856f,93.75f, --222.656f,-2.29205f,93.75f, --218.75f,-3.83678f,93.75f, --214.844f,-2.73856f,93.75f, --210.938f,-2.19574f,93.75f, --207.031f,-0.222008f,93.75f, --203.125f,-0.117961f,93.75f, --199.219f,-0.17607f,93.75f, --195.313f,1.32212f,93.75f, --191.406f,2.64292f,93.75f, --187.5f,3.72678f,93.75f, --183.594f,5.78729f,93.75f, --179.688f,9.09616f,93.75f, --175.781f,11.4833f,93.75f, --171.875f,13.1923f,93.75f, --167.969f,15.68f,93.75f, --164.063f,17.9844f,93.75f, --160.156f,20.7688f,93.75f, --156.25f,23.4925f,93.75f, --152.344f,25.2252f,93.75f, --148.438f,25.9373f,93.75f, --144.531f,28.1941f,93.75f, --140.625f,31.9896f,93.75f, --136.719f,33.5688f,93.75f, --132.813f,34.7177f,93.75f, --128.906f,35.1459f,93.75f, --125.0f,34.9785f,93.75f, --121.094f,34.3971f,93.75f, --117.188f,35.2455f,93.75f, --113.281f,36.0209f,93.75f, --109.375f,35.244f,93.75f, --105.469f,33.4542f,93.75f, --101.563f,30.3707f,93.75f, --97.6563f,30.709f,93.75f, --93.75f,31.2489f,93.75f, --89.8438f,30.5476f,93.75f, --85.9375f,28.5982f,93.75f, --82.0313f,26.6838f,93.75f, --78.125f,24.1646f,93.75f, --74.2188f,21.261f,93.75f, --70.3125f,19.8206f,93.75f, --66.4063f,19.4952f,93.75f, --62.5f,18.3276f,93.75f, --58.5938f,18.1028f,93.75f, --54.6875f,17.0878f,93.75f, --50.7813f,15.0144f,93.75f, --46.875f,13.5565f,93.75f, --42.9688f,11.0211f,93.75f, --39.0625f,11.1986f,93.75f, --35.1563f,10.4097f,93.75f, --31.25f,11.2207f,93.75f, --27.3438f,11.4539f,93.75f, --23.4375f,11.4014f,93.75f, --19.5313f,12.2344f,93.75f, --15.625f,13.5348f,93.75f, --11.7188f,14.2772f,93.75f, --7.8125f,14.0447f,93.75f, --3.90625f,14.1587f,93.75f, -0.0f,15.3266f,93.75f, -3.90625f,17.1671f,93.75f, --250.0f,5.40499f,89.8438f, --246.094f,3.9236f,89.8438f, --242.188f,2.78029f,89.8438f, --238.281f,2.337f,89.8438f, --234.375f,1.45614f,89.8438f, --230.469f,0.487402f,89.8438f, --226.563f,0.814658f,89.8438f, --222.656f,-0.244101f,89.8438f, --218.75f,-2.09422f,89.8438f, --214.844f,-1.48441f,89.8438f, --210.938f,-0.695794f,89.8438f, --207.031f,0.742314f,89.8438f, --203.125f,1.30594f,89.8438f, --199.219f,1.49011f,89.8438f, --195.313f,2.5687f,89.8438f, --191.406f,3.72318f,89.8438f, --187.5f,4.658f,89.8438f, --183.594f,7.20615f,89.8438f, --179.688f,9.85211f,89.8438f, --175.781f,12.8482f,89.8438f, --171.875f,14.6361f,89.8438f, --167.969f,16.6036f,89.8438f, --164.063f,19.7308f,89.8438f, --160.156f,22.7068f,89.8438f, --156.25f,24.421f,89.8438f, --152.344f,25.8961f,89.8438f, --148.438f,27.1249f,89.8438f, --144.531f,29.0138f,89.8438f, --140.625f,31.6384f,89.8438f, --136.719f,33.9142f,89.8438f, --132.813f,34.3317f,89.8438f, --128.906f,36.0856f,89.8438f, --125.0f,35.5134f,89.8438f, --121.094f,34.7035f,89.8438f, --117.188f,33.6847f,89.8438f, --113.281f,34.2624f,89.8438f, --109.375f,34.2147f,89.8438f, --105.469f,32.2925f,89.8438f, --101.563f,30.4889f,89.8438f, --97.6563f,30.8562f,89.8438f, --93.75f,31.4717f,89.8438f, --89.8438f,30.2623f,89.8438f, --85.9375f,28.4623f,89.8438f, --82.0313f,26.6117f,89.8438f, --78.125f,24.1755f,89.8438f, --74.2188f,22.4752f,89.8438f, --70.3125f,20.3246f,89.8438f, --66.4063f,19.488f,89.8438f, --62.5f,18.6447f,89.8438f, --58.5938f,17.8933f,89.8438f, --54.6875f,16.177f,89.8438f, --50.7813f,15.2537f,89.8438f, --46.875f,13.5232f,89.8438f, --42.9688f,11.842f,89.8438f, --39.0625f,10.223f,89.8438f, --35.1563f,9.54441f,89.8438f, --31.25f,9.73488f,89.8438f, --27.3438f,10.7057f,89.8438f, --23.4375f,11.9185f,89.8438f, --19.5313f,13.2106f,89.8438f, --15.625f,13.0807f,89.8438f, --11.7188f,12.8112f,89.8438f, --7.8125f,12.7972f,89.8438f, --3.90625f,14.1049f,89.8438f, -0.0f,14.9674f,89.8438f, -3.90625f,15.6427f,89.8438f, --250.0f,6.21462f,85.9375f, --246.094f,4.66025f,85.9375f, --242.188f,3.36279f,85.9375f, --238.281f,1.97426f,85.9375f, --234.375f,0.590897f,85.9375f, --230.469f,2.01222f,85.9375f, --226.563f,2.15192f,85.9375f, --222.656f,0.78006f,85.9375f, --218.75f,-0.424968f,85.9375f, --214.844f,-0.512869f,85.9375f, --210.938f,0.00319427f,85.9375f, --207.031f,1.05715f,85.9375f, --203.125f,2.11926f,85.9375f, --199.219f,2.48862f,85.9375f, --195.313f,3.89944f,85.9375f, --191.406f,5.71899f,85.9375f, --187.5f,6.41674f,85.9375f, --183.594f,7.94295f,85.9375f, --179.688f,10.9562f,85.9375f, --175.781f,13.1951f,85.9375f, --171.875f,15.7827f,85.9375f, --167.969f,17.6951f,85.9375f, --164.063f,20.2261f,85.9375f, --160.156f,22.5211f,85.9375f, --156.25f,24.8103f,85.9375f, --152.344f,26.6666f,85.9375f, --148.438f,27.7052f,85.9375f, --144.531f,29.2234f,85.9375f, --140.625f,31.4629f,85.9375f, --136.719f,34.0955f,85.9375f, --132.813f,34.7124f,85.9375f, --128.906f,36.1712f,85.9375f, --125.0f,36.4743f,85.9375f, --121.094f,35.3967f,85.9375f, --117.188f,34.3505f,85.9375f, --113.281f,33.5175f,85.9375f, --109.375f,32.9976f,85.9375f, --105.469f,31.7882f,85.9375f, --101.563f,31.1746f,85.9375f, --97.6563f,31.0271f,85.9375f, --93.75f,31.5303f,85.9375f, --89.8438f,30.8744f,85.9375f, --85.9375f,28.1434f,85.9375f, --82.0313f,25.9196f,85.9375f, --78.125f,24.4044f,85.9375f, --74.2188f,21.9984f,85.9375f, --70.3125f,20.0411f,85.9375f, --66.4063f,19.9449f,85.9375f, --62.5f,18.3893f,85.9375f, --58.5938f,16.9846f,85.9375f, --54.6875f,15.6155f,85.9375f, --50.7813f,14.6152f,85.9375f, --46.875f,12.7358f,85.9375f, --42.9688f,12.1599f,85.9375f, --39.0625f,10.1045f,85.9375f, --35.1563f,9.61416f,85.9375f, --31.25f,10.0784f,85.9375f, --27.3438f,10.2188f,85.9375f, --23.4375f,11.574f,85.9375f, --19.5313f,11.8712f,85.9375f, --15.625f,11.9109f,85.9375f, --11.7188f,11.509f,85.9375f, --7.8125f,13.9979f,85.9375f, --3.90625f,14.8453f,85.9375f, -0.0f,14.7941f,85.9375f, -3.90625f,15.5916f,85.9375f, --250.0f,6.94324f,82.0313f, --246.094f,4.77131f,82.0313f, --242.188f,3.62143f,82.0313f, --238.281f,2.50324f,82.0313f, --234.375f,1.40345f,82.0313f, --230.469f,2.05881f,82.0313f, --226.563f,2.41769f,82.0313f, --222.656f,1.23736f,82.0313f, --218.75f,1.59545f,82.0313f, --214.844f,1.25313f,82.0313f, --210.938f,1.53594f,82.0313f, --207.031f,2.33073f,82.0313f, --203.125f,2.59696f,82.0313f, --199.219f,4.25487f,82.0313f, --195.313f,5.86136f,82.0313f, --191.406f,7.54631f,82.0313f, --187.5f,8.7315f,82.0313f, --183.594f,9.65737f,82.0313f, --179.688f,11.5328f,82.0313f, --175.781f,14.3069f,82.0313f, --171.875f,16.2889f,82.0313f, --167.969f,17.6379f,82.0313f, --164.063f,20.4422f,82.0313f, --160.156f,22.9557f,82.0313f, --156.25f,25.0731f,82.0313f, --152.344f,27.3881f,82.0313f, --148.438f,28.7955f,82.0313f, --144.531f,30.2575f,82.0313f, --140.625f,32.5888f,82.0313f, --136.719f,33.9884f,82.0313f, --132.813f,34.4838f,82.0313f, --128.906f,35.7672f,82.0313f, --125.0f,36.1002f,82.0313f, --121.094f,35.9318f,82.0313f, --117.188f,34.9715f,82.0313f, --113.281f,33.3187f,82.0313f, --109.375f,31.9477f,82.0313f, --105.469f,31.4437f,82.0313f, --101.563f,31.2817f,82.0313f, --97.6563f,32.08f,82.0313f, --93.75f,31.4037f,82.0313f, --89.8438f,30.2769f,82.0313f, --85.9375f,28.1374f,82.0313f, --82.0313f,25.4814f,82.0313f, --78.125f,24.1831f,82.0313f, --74.2188f,22.6148f,82.0313f, --70.3125f,19.2585f,82.0313f, --66.4063f,18.6785f,82.0313f, --62.5f,17.7889f,82.0313f, --58.5938f,16.5855f,82.0313f, --54.6875f,14.6918f,82.0313f, --50.7813f,12.9532f,82.0313f, --46.875f,12.1502f,82.0313f, --42.9688f,11.3533f,82.0313f, --39.0625f,9.8302f,82.0313f, --35.1563f,9.95311f,82.0313f, --31.25f,10.7631f,82.0313f, --27.3438f,10.2187f,82.0313f, --23.4375f,10.1072f,82.0313f, --19.5313f,11.299f,82.0313f, --15.625f,11.5563f,82.0313f, --11.7188f,13.9188f,82.0313f, --7.8125f,15.247f,82.0313f, --3.90625f,15.6866f,82.0313f, -0.0f,15.9694f,82.0313f, -3.90625f,16.9644f,82.0313f, --250.0f,6.39735f,78.125f, --246.094f,5.09353f,78.125f, --242.188f,4.53503f,78.125f, --238.281f,3.72522f,78.125f, --234.375f,3.02648f,78.125f, --230.469f,3.02057f,78.125f, --226.563f,3.8807f,78.125f, --222.656f,4.47382f,78.125f, --218.75f,3.84005f,78.125f, --214.844f,2.7347f,78.125f, --210.938f,4.55018f,78.125f, --207.031f,5.04579f,78.125f, --203.125f,4.45937f,78.125f, --199.219f,5.32656f,78.125f, --195.313f,7.13791f,78.125f, --191.406f,8.89822f,78.125f, --187.5f,10.3911f,78.125f, --183.594f,11.3679f,78.125f, --179.688f,13.4068f,78.125f, --175.781f,16.3393f,78.125f, --171.875f,17.801f,78.125f, --167.969f,19.0455f,78.125f, --164.063f,21.4178f,78.125f, --160.156f,23.555f,78.125f, --156.25f,25.3953f,78.125f, --152.344f,26.9657f,78.125f, --148.438f,28.8194f,78.125f, --144.531f,31.456f,78.125f, --140.625f,33.3499f,78.125f, --136.719f,34.2296f,78.125f, --132.813f,34.5964f,78.125f, --128.906f,35.7399f,78.125f, --125.0f,35.4576f,78.125f, --121.094f,35.7986f,78.125f, --117.188f,34.4641f,78.125f, --113.281f,33.925f,78.125f, --109.375f,32.0574f,78.125f, --105.469f,31.6743f,78.125f, --101.563f,31.65f,78.125f, --97.6563f,31.9461f,78.125f, --93.75f,31.2261f,78.125f, --89.8438f,30.4701f,78.125f, --85.9375f,27.7569f,78.125f, --82.0313f,25.4553f,78.125f, --78.125f,23.3917f,78.125f, --74.2188f,21.6944f,78.125f, --70.3125f,18.6818f,78.125f, --66.4063f,17.4066f,78.125f, --62.5f,17.1317f,78.125f, --58.5938f,16.5093f,78.125f, --54.6875f,14.9512f,78.125f, --50.7813f,13.228f,78.125f, --46.875f,11.4638f,78.125f, --42.9688f,10.3877f,78.125f, --39.0625f,9.7131f,78.125f, --35.1563f,10.0477f,78.125f, --31.25f,10.325f,78.125f, --27.3438f,10.317f,78.125f, --23.4375f,10.9076f,78.125f, --19.5313f,11.7808f,78.125f, --15.625f,14.1905f,78.125f, --11.7188f,15.6035f,78.125f, --7.8125f,16.0979f,78.125f, --3.90625f,16.6425f,78.125f, -0.0f,17.2837f,78.125f, -3.90625f,18.8244f,78.125f, --250.0f,6.03592f,74.2188f, --246.094f,5.17606f,74.2188f, --242.188f,3.7036f,74.2188f, --238.281f,3.69f,74.2188f, --234.375f,4.60611f,74.2188f, --230.469f,4.52682f,74.2188f, --226.563f,5.59937f,74.2188f, --222.656f,6.25837f,74.2188f, --218.75f,5.11517f,74.2188f, --214.844f,4.67242f,74.2188f, --210.938f,5.76173f,74.2188f, --207.031f,6.80461f,74.2188f, --203.125f,6.95083f,74.2188f, --199.219f,7.35893f,74.2188f, --195.313f,8.63949f,74.2188f, --191.406f,10.4144f,74.2188f, --187.5f,11.8105f,74.2188f, --183.594f,13.4583f,74.2188f, --179.688f,15.5665f,74.2188f, --175.781f,18.2568f,74.2188f, --171.875f,19.1732f,74.2188f, --167.969f,21.3098f,74.2188f, --164.063f,23.6359f,74.2188f, --160.156f,25.3154f,74.2188f, --156.25f,27.6289f,74.2188f, --152.344f,28.8953f,74.2188f, --148.438f,30.5098f,74.2188f, --144.531f,32.3942f,74.2188f, --140.625f,33.3325f,74.2188f, --136.719f,33.8009f,74.2188f, --132.813f,35.0803f,74.2188f, --128.906f,34.737f,74.2188f, --125.0f,34.3656f,74.2188f, --121.094f,34.2107f,74.2188f, --117.188f,33.1645f,74.2188f, --113.281f,32.0615f,74.2188f, --109.375f,32.0827f,74.2188f, --105.469f,32.4658f,74.2188f, --101.563f,31.6315f,74.2188f, --97.6563f,30.9698f,74.2188f, --93.75f,30.6464f,74.2188f, --89.8438f,29.9645f,74.2188f, --85.9375f,27.4393f,74.2188f, --82.0313f,25.2807f,74.2188f, --78.125f,23.57f,74.2188f, --74.2188f,20.653f,74.2188f, --70.3125f,18.1395f,74.2188f, --66.4063f,17.6585f,74.2188f, --62.5f,17.2798f,74.2188f, --58.5938f,16.6041f,74.2188f, --54.6875f,14.6913f,74.2188f, --50.7813f,13.1416f,74.2188f, --46.875f,10.9374f,74.2188f, --42.9688f,9.39485f,74.2188f, --39.0625f,9.21956f,74.2188f, --35.1563f,9.74875f,74.2188f, --31.25f,10.3932f,74.2188f, --27.3438f,10.7996f,74.2188f, --23.4375f,11.5538f,74.2188f, --19.5313f,13.5418f,74.2188f, --15.625f,15.6336f,74.2188f, --11.7188f,16.3846f,74.2188f, --7.8125f,17.738f,74.2188f, --3.90625f,17.98f,74.2188f, -0.0f,19.1669f,74.2188f, -3.90625f,20.6829f,74.2188f, --250.0f,5.45149f,70.3125f, --246.094f,4.83779f,70.3125f, --242.188f,3.60093f,70.3125f, --238.281f,3.26469f,70.3125f, --234.375f,4.06145f,70.3125f, --230.469f,5.31565f,70.3125f, --226.563f,6.65809f,70.3125f, --222.656f,6.70538f,70.3125f, --218.75f,6.93258f,70.3125f, --214.844f,6.84841f,70.3125f, --210.938f,6.9662f,70.3125f, --207.031f,7.74003f,70.3125f, --203.125f,8.68749f,70.3125f, --199.219f,9.06225f,70.3125f, --195.313f,10.0803f,70.3125f, --191.406f,12.202f,70.3125f, --187.5f,14.063f,70.3125f, --183.594f,15.732f,70.3125f, --179.688f,18.3972f,70.3125f, --175.781f,19.5054f,70.3125f, --171.875f,20.8927f,70.3125f, --167.969f,23.3843f,70.3125f, --164.063f,25.5894f,70.3125f, --160.156f,27.0506f,70.3125f, --156.25f,28.6483f,70.3125f, --152.344f,31.3986f,70.3125f, --148.438f,32.5255f,70.3125f, --144.531f,33.0315f,70.3125f, --140.625f,33.0927f,70.3125f, --136.719f,33.7595f,70.3125f, --132.813f,34.1872f,70.3125f, --128.906f,33.4924f,70.3125f, --125.0f,34.1817f,70.3125f, --121.094f,33.4642f,70.3125f, --117.188f,32.3231f,70.3125f, --113.281f,32.1235f,70.3125f, --109.375f,32.674f,70.3125f, --105.469f,32.7558f,70.3125f, --101.563f,32.4896f,70.3125f, --97.6563f,30.7945f,70.3125f, --93.75f,30.1182f,70.3125f, --89.8438f,28.6969f,70.3125f, --85.9375f,26.606f,70.3125f, --82.0313f,24.8053f,70.3125f, --78.125f,23.3599f,70.3125f, --74.2188f,20.5363f,70.3125f, --70.3125f,18.2858f,70.3125f, --66.4063f,17.647f,70.3125f, --62.5f,17.3761f,70.3125f, --58.5938f,16.3124f,70.3125f, --54.6875f,14.016f,70.3125f, --50.7813f,11.6317f,70.3125f, --46.875f,9.68832f,70.3125f, --42.9688f,8.63692f,70.3125f, --39.0625f,8.52412f,70.3125f, --35.1563f,10.3549f,70.3125f, --31.25f,11.1185f,70.3125f, --27.3438f,12.8223f,70.3125f, --23.4375f,14.2548f,70.3125f, --19.5313f,15.4066f,70.3125f, --15.625f,16.875f,70.3125f, --11.7188f,17.7202f,70.3125f, --7.8125f,18.6716f,70.3125f, --3.90625f,19.72f,70.3125f, -0.0f,21.3086f,70.3125f, -3.90625f,22.948f,70.3125f, --250.0f,4.53118f,66.4063f, --246.094f,3.73568f,66.4063f, --242.188f,3.80679f,66.4063f, --238.281f,4.42509f,66.4063f, --234.375f,5.0317f,66.4063f, --230.469f,6.63484f,66.4063f, --226.563f,7.65599f,66.4063f, --222.656f,8.55305f,66.4063f, --218.75f,8.71866f,66.4063f, --214.844f,7.68897f,66.4063f, --210.938f,8.59141f,66.4063f, --207.031f,9.73811f,66.4063f, --203.125f,10.1348f,66.4063f, --199.219f,10.1075f,66.4063f, --195.313f,11.1394f,66.4063f, --191.406f,13.5829f,66.4063f, --187.5f,15.4951f,66.4063f, --183.594f,17.5574f,66.4063f, --179.688f,19.9291f,66.4063f, --175.781f,21.0567f,66.4063f, --171.875f,22.5003f,66.4063f, --167.969f,25.5993f,66.4063f, --164.063f,27.0097f,66.4063f, --160.156f,27.9166f,66.4063f, --156.25f,29.8989f,66.4063f, --152.344f,32.1785f,66.4063f, --148.438f,34.0669f,66.4063f, --144.531f,34.5129f,66.4063f, --140.625f,34.1795f,66.4063f, --136.719f,33.3311f,66.4063f, --132.813f,32.969f,66.4063f, --128.906f,32.9477f,66.4063f, --125.0f,33.5186f,66.4063f, --121.094f,32.9715f,66.4063f, --117.188f,32.4898f,66.4063f, --113.281f,33.0858f,66.4063f, --109.375f,32.6501f,66.4063f, --105.469f,32.847f,66.4063f, --101.563f,32.8074f,66.4063f, --97.6563f,31.5661f,66.4063f, --93.75f,29.4807f,66.4063f, --89.8438f,28.6706f,66.4063f, --85.9375f,26.408f,66.4063f, --82.0313f,24.3989f,66.4063f, --78.125f,22.4069f,66.4063f, --74.2188f,20.2026f,66.4063f, --70.3125f,18.5513f,66.4063f, --66.4063f,17.0548f,66.4063f, --62.5f,17.0623f,66.4063f, --58.5938f,15.9909f,66.4063f, --54.6875f,13.3885f,66.4063f, --50.7813f,11.8657f,66.4063f, --46.875f,9.02652f,66.4063f, --42.9688f,8.99046f,66.4063f, --39.0625f,10.0543f,66.4063f, --35.1563f,11.7078f,66.4063f, --31.25f,12.4956f,66.4063f, --27.3438f,14.0575f,66.4063f, --23.4375f,15.2147f,66.4063f, --19.5313f,16.7089f,66.4063f, --15.625f,17.8009f,66.4063f, --11.7188f,19.0086f,66.4063f, --7.8125f,20.9864f,66.4063f, --3.90625f,22.6943f,66.4063f, -0.0f,23.9641f,66.4063f, -3.90625f,25.5564f,66.4063f, --250.0f,4.6779f,62.5f, --246.094f,4.41735f,62.5f, --242.188f,3.93647f,62.5f, --238.281f,4.50648f,62.5f, --234.375f,5.52163f,62.5f, --230.469f,7.10395f,62.5f, --226.563f,8.10257f,62.5f, --222.656f,8.36726f,62.5f, --218.75f,8.58321f,62.5f, --214.844f,8.56809f,62.5f, --210.938f,9.95321f,62.5f, --207.031f,10.4904f,62.5f, --203.125f,10.812f,62.5f, --199.219f,11.5942f,62.5f, --195.313f,13.0371f,62.5f, --191.406f,14.6432f,62.5f, --187.5f,16.7375f,62.5f, --183.594f,18.4129f,62.5f, --179.688f,20.9534f,62.5f, --175.781f,23.1161f,62.5f, --171.875f,25.0267f,62.5f, --167.969f,26.7355f,62.5f, --164.063f,27.6983f,62.5f, --160.156f,29.1111f,62.5f, --156.25f,31.1905f,62.5f, --152.344f,32.9766f,62.5f, --148.438f,33.4703f,62.5f, --144.531f,33.714f,62.5f, --140.625f,33.649f,62.5f, --136.719f,33.0246f,62.5f, --132.813f,32.7386f,62.5f, --128.906f,32.6069f,62.5f, --125.0f,32.6579f,62.5f, --121.094f,31.5955f,62.5f, --117.188f,31.8589f,62.5f, --113.281f,32.7188f,62.5f, --109.375f,32.889f,62.5f, --105.469f,32.7317f,62.5f, --101.563f,32.4229f,62.5f, --97.6563f,31.2118f,62.5f, --93.75f,30.6824f,62.5f, --89.8438f,28.584f,62.5f, --85.9375f,26.1183f,62.5f, --82.0313f,23.8148f,62.5f, --78.125f,22.0333f,62.5f, --74.2188f,20.178f,62.5f, --70.3125f,18.704f,62.5f, --66.4063f,16.8036f,62.5f, --62.5f,15.7173f,62.5f, --58.5938f,13.9284f,62.5f, --54.6875f,13.0731f,62.5f, --50.7813f,11.8974f,62.5f, --46.875f,9.91347f,62.5f, --42.9688f,10.1439f,62.5f, --39.0625f,11.304f,62.5f, --35.1563f,12.5111f,62.5f, --31.25f,14.112f,62.5f, --27.3438f,15.3325f,62.5f, --23.4375f,16.6214f,62.5f, --19.5313f,17.8469f,62.5f, --15.625f,19.2987f,62.5f, --11.7188f,20.9518f,62.5f, --7.8125f,23.4289f,62.5f, --3.90625f,24.9379f,62.5f, -0.0f,26.156f,62.5f, -3.90625f,27.1929f,62.5f, --250.0f,4.23938f,58.5938f, --246.094f,4.819f,58.5938f, --242.188f,4.63067f,58.5938f, --238.281f,5.29023f,58.5938f, --234.375f,6.48193f,58.5938f, --230.469f,6.85856f,58.5938f, --226.563f,8.4748f,58.5938f, --222.656f,8.76416f,58.5938f, --218.75f,9.24425f,58.5938f, --214.844f,9.67654f,58.5938f, --210.938f,10.8063f,58.5938f, --207.031f,12.3237f,58.5938f, --203.125f,12.7409f,58.5938f, --199.219f,12.7587f,58.5938f, --195.313f,14.3653f,58.5938f, --191.406f,16.1467f,58.5938f, --187.5f,17.0489f,58.5938f, --183.594f,19.2091f,58.5938f, --179.688f,21.7856f,58.5938f, --175.781f,24.7829f,58.5938f, --171.875f,26.2396f,58.5938f, --167.969f,27.2756f,58.5938f, --164.063f,28.2919f,58.5938f, --160.156f,30.5945f,58.5938f, --156.25f,32.2617f,58.5938f, --152.344f,32.9049f,58.5938f, --148.438f,32.8002f,58.5938f, --144.531f,32.4751f,58.5938f, --140.625f,32.4049f,58.5938f, --136.719f,33.5631f,58.5938f, --132.813f,33.3828f,58.5938f, --128.906f,33.1064f,58.5938f, --125.0f,32.3054f,58.5938f, --121.094f,32.5047f,58.5938f, --117.188f,32.3246f,58.5938f, --113.281f,32.4393f,58.5938f, --109.375f,32.553f,58.5938f, --105.469f,32.9281f,58.5938f, --101.563f,31.8539f,58.5938f, --97.6563f,30.9253f,58.5938f, --93.75f,30.4328f,58.5938f, --89.8438f,28.3295f,58.5938f, --85.9375f,25.5393f,58.5938f, --82.0313f,23.0691f,58.5938f, --78.125f,21.505f,58.5938f, --74.2188f,21.0748f,58.5938f, --70.3125f,19.1186f,58.5938f, --66.4063f,16.7814f,58.5938f, --62.5f,15.2179f,58.5938f, --58.5938f,14.1291f,58.5938f, --54.6875f,13.2351f,58.5938f, --50.7813f,11.896f,58.5938f, --46.875f,11.0911f,58.5938f, --42.9688f,12.7485f,58.5938f, --39.0625f,13.7045f,58.5938f, --35.1563f,14.6128f,58.5938f, --31.25f,15.546f,58.5938f, --27.3438f,16.7828f,58.5938f, --23.4375f,18.7578f,58.5938f, --19.5313f,19.7951f,58.5938f, --15.625f,21.8594f,58.5938f, --11.7188f,22.7269f,58.5938f, --7.8125f,24.983f,58.5938f, --3.90625f,26.43f,58.5938f, -0.0f,27.4466f,58.5938f, -3.90625f,28.3495f,58.5938f, --250.0f,3.62748f,54.6875f, --246.094f,3.83329f,54.6875f, --242.188f,4.44022f,54.6875f, --238.281f,5.27514f,54.6875f, --234.375f,7.43995f,54.6875f, --230.469f,7.59176f,54.6875f, --226.563f,8.28985f,54.6875f, --222.656f,9.62184f,54.6875f, --218.75f,10.6613f,54.6875f, --214.844f,11.0914f,54.6875f, --210.938f,12.2186f,54.6875f, --207.031f,13.1985f,54.6875f, --203.125f,13.9982f,54.6875f, --199.219f,14.3187f,54.6875f, --195.313f,14.8791f,54.6875f, --191.406f,16.5829f,54.6875f, --187.5f,18.231f,54.6875f, --183.594f,20.0621f,54.6875f, --179.688f,22.8941f,54.6875f, --175.781f,25.0841f,54.6875f, --171.875f,26.5655f,54.6875f, --167.969f,27.3542f,54.6875f, --164.063f,29.2247f,54.6875f, --160.156f,30.91f,54.6875f, --156.25f,33.3376f,54.6875f, --152.344f,32.8808f,54.6875f, --148.438f,32.5783f,54.6875f, --144.531f,32.6138f,54.6875f, --140.625f,32.9002f,54.6875f, --136.719f,34.2312f,54.6875f, --132.813f,33.8335f,54.6875f, --128.906f,32.8545f,54.6875f, --125.0f,33.6683f,54.6875f, --121.094f,32.9953f,54.6875f, --117.188f,32.5096f,54.6875f, --113.281f,32.4307f,54.6875f, --109.375f,31.8214f,54.6875f, --105.469f,31.851f,54.6875f, --101.563f,31.6383f,54.6875f, --97.6563f,30.4359f,54.6875f, --93.75f,28.9306f,54.6875f, --89.8438f,26.5955f,54.6875f, --85.9375f,24.7234f,54.6875f, --82.0313f,23.0595f,54.6875f, --78.125f,21.3558f,54.6875f, --74.2188f,20.3788f,54.6875f, --70.3125f,19.3201f,54.6875f, --66.4063f,16.9597f,54.6875f, --62.5f,14.6652f,54.6875f, --58.5938f,14.4899f,54.6875f, --54.6875f,13.3432f,54.6875f, --50.7813f,12.3286f,54.6875f, --46.875f,12.6498f,54.6875f, --42.9688f,14.2651f,54.6875f, --39.0625f,15.6887f,54.6875f, --35.1563f,16.2038f,54.6875f, --31.25f,17.2337f,54.6875f, --27.3438f,18.7628f,54.6875f, --23.4375f,20.2472f,54.6875f, --19.5313f,21.6809f,54.6875f, --15.625f,24.084f,54.6875f, --11.7188f,25.1582f,54.6875f, --7.8125f,26.7f,54.6875f, --3.90625f,27.5421f,54.6875f, -0.0f,28.3244f,54.6875f, -3.90625f,29.2057f,54.6875f, --250.0f,3.74657f,50.7813f, --246.094f,3.89172f,50.7813f, --242.188f,4.12295f,50.7813f, --238.281f,5.16915f,50.7813f, --234.375f,6.30394f,50.7813f, --230.469f,7.21975f,50.7813f, --226.563f,8.61249f,50.7813f, --222.656f,10.1295f,50.7813f, --218.75f,12.2813f,50.7813f, --214.844f,12.3309f,50.7813f, --210.938f,13.3907f,50.7813f, --207.031f,14.1528f,50.7813f, --203.125f,14.0334f,50.7813f, --199.219f,14.814f,50.7813f, --195.313f,16.69f,50.7813f, --191.406f,17.639f,50.7813f, --187.5f,19.261f,50.7813f, --183.594f,20.748f,50.7813f, --179.688f,23.3343f,50.7813f, --175.781f,25.4837f,50.7813f, --171.875f,26.8456f,50.7813f, --167.969f,27.7788f,50.7813f, --164.063f,30.0174f,50.7813f, --160.156f,31.0689f,50.7813f, --156.25f,32.5898f,50.7813f, --152.344f,32.5672f,50.7813f, --148.438f,32.4654f,50.7813f, --144.531f,33.702f,50.7813f, --140.625f,34.7593f,50.7813f, --136.719f,33.9086f,50.7813f, --132.813f,33.681f,50.7813f, --128.906f,33.6369f,50.7813f, --125.0f,34.0371f,50.7813f, --121.094f,34.0479f,50.7813f, --117.188f,34.513f,50.7813f, --113.281f,33.7072f,50.7813f, --109.375f,32.2763f,50.7813f, --105.469f,32.0608f,50.7813f, --101.563f,31.0833f,50.7813f, --97.6563f,29.9168f,50.7813f, --93.75f,28.7604f,50.7813f, --89.8438f,26.9563f,50.7813f, --85.9375f,24.7908f,50.7813f, --82.0313f,23.7925f,50.7813f, --78.125f,21.7037f,50.7813f, --74.2188f,19.5308f,50.7813f, --70.3125f,19.3367f,50.7813f, --66.4063f,17.8482f,50.7813f, --62.5f,14.2491f,50.7813f, --58.5938f,14.7414f,50.7813f, --54.6875f,14.0395f,50.7813f, --50.7813f,12.9738f,50.7813f, --46.875f,13.9471f,50.7813f, --42.9688f,15.8319f,50.7813f, --39.0625f,16.6566f,50.7813f, --35.1563f,17.1252f,50.7813f, --31.25f,18.6998f,50.7813f, --27.3438f,20.877f,50.7813f, --23.4375f,22.0249f,50.7813f, --19.5313f,22.9369f,50.7813f, --15.625f,25.686f,50.7813f, --11.7188f,26.1758f,50.7813f, --7.8125f,28.3828f,50.7813f, --3.90625f,28.7973f,50.7813f, -0.0f,29.7276f,50.7813f, -3.90625f,30.4306f,50.7813f, --250.0f,3.69244f,46.875f, --246.094f,3.88583f,46.875f, --242.188f,3.98468f,46.875f, --238.281f,5.01772f,46.875f, --234.375f,7.23791f,46.875f, --230.469f,7.78117f,46.875f, --226.563f,8.55298f,46.875f, --222.656f,10.2684f,46.875f, --218.75f,11.1917f,46.875f, --214.844f,12.411f,46.875f, --210.938f,13.7214f,46.875f, --207.031f,14.4662f,46.875f, --203.125f,15.536f,46.875f, --199.219f,15.6035f,46.875f, --195.313f,16.8456f,46.875f, --191.406f,18.4656f,46.875f, --187.5f,19.415f,46.875f, --183.594f,20.8504f,46.875f, --179.688f,23.9388f,46.875f, --175.781f,26.2956f,46.875f, --171.875f,27.6728f,46.875f, --167.969f,28.2497f,46.875f, --164.063f,29.6503f,46.875f, --160.156f,31.9344f,46.875f, --156.25f,33.4163f,46.875f, --152.344f,33.428f,46.875f, --148.438f,33.3157f,46.875f, --144.531f,33.6261f,46.875f, --140.625f,35.1888f,46.875f, --136.719f,34.8434f,46.875f, --132.813f,34.1219f,46.875f, --128.906f,34.4564f,46.875f, --125.0f,34.9729f,46.875f, --121.094f,34.8811f,46.875f, --117.188f,35.185f,46.875f, --113.281f,34.138f,46.875f, --109.375f,32.7077f,46.875f, --105.469f,32.2219f,46.875f, --101.563f,31.2475f,46.875f, --97.6563f,29.9637f,46.875f, --93.75f,28.1214f,46.875f, --89.8438f,27.0889f,46.875f, --85.9375f,25.092f,46.875f, --82.0313f,23.3983f,46.875f, --78.125f,22.275f,46.875f, --74.2188f,19.8598f,46.875f, --70.3125f,18.8797f,46.875f, --66.4063f,17.2468f,46.875f, --62.5f,15.4985f,46.875f, --58.5938f,14.5357f,46.875f, --54.6875f,14.6964f,46.875f, --50.7813f,13.3496f,46.875f, --46.875f,15.6354f,46.875f, --42.9688f,16.7177f,46.875f, --39.0625f,17.4527f,46.875f, --35.1563f,18.2826f,46.875f, --31.25f,20.3293f,46.875f, --27.3438f,22.684f,46.875f, --23.4375f,23.538f,46.875f, --19.5313f,24.3046f,46.875f, --15.625f,26.1113f,46.875f, --11.7188f,27.4881f,46.875f, --7.8125f,29.3572f,46.875f, --3.90625f,29.786f,46.875f, -0.0f,30.3637f,46.875f, -3.90625f,30.8772f,46.875f, --250.0f,4.08083f,42.9688f, --246.094f,4.09778f,42.9688f, --242.188f,3.87631f,42.9688f, --238.281f,5.12214f,42.9688f, --234.375f,6.70993f,42.9688f, --230.469f,7.75806f,42.9688f, --226.563f,8.13676f,42.9688f, --222.656f,8.85151f,42.9688f, --218.75f,10.9378f,42.9688f, --214.844f,12.4043f,42.9688f, --210.938f,13.4636f,42.9688f, --207.031f,14.7352f,42.9688f, --203.125f,15.605f,42.9688f, --199.219f,15.7497f,42.9688f, --195.313f,17.184f,42.9688f, --191.406f,19.3679f,42.9688f, --187.5f,21.1701f,42.9688f, --183.594f,22.7204f,42.9688f, --179.688f,24.8128f,42.9688f, --175.781f,26.7707f,42.9688f, --171.875f,27.7521f,42.9688f, --167.969f,28.8689f,42.9688f, --164.063f,31.1205f,42.9688f, --160.156f,33.289f,42.9688f, --156.25f,34.2815f,42.9688f, --152.344f,33.9797f,42.9688f, --148.438f,34.2527f,42.9688f, --144.531f,34.1886f,42.9688f, --140.625f,34.868f,42.9688f, --136.719f,35.6569f,42.9688f, --132.813f,35.4999f,42.9688f, --128.906f,35.4373f,42.9688f, --125.0f,36.373f,42.9688f, --121.094f,35.4304f,42.9688f, --117.188f,34.3543f,42.9688f, --113.281f,35.0651f,42.9688f, --109.375f,33.5051f,42.9688f, --105.469f,32.471f,42.9688f, --101.563f,31.2764f,42.9688f, --97.6563f,29.7633f,42.9688f, --93.75f,27.9107f,42.9688f, --89.8438f,26.5273f,42.9688f, --85.9375f,25.2444f,42.9688f, --82.0313f,23.6093f,42.9688f, --78.125f,21.9684f,42.9688f, --74.2188f,19.4992f,42.9688f, --70.3125f,17.8231f,42.9688f, --66.4063f,17.4082f,42.9688f, --62.5f,17.0938f,42.9688f, --58.5938f,15.3348f,42.9688f, --54.6875f,14.7964f,42.9688f, --50.7813f,14.9948f,42.9688f, --46.875f,17.1807f,42.9688f, --42.9688f,18.118f,42.9688f, --39.0625f,19.0809f,42.9688f, --35.1563f,19.6971f,42.9688f, --31.25f,21.652f,42.9688f, --27.3438f,23.4343f,42.9688f, --23.4375f,24.5708f,42.9688f, --19.5313f,25.2003f,42.9688f, --15.625f,26.8391f,42.9688f, --11.7188f,28.9343f,42.9688f, --7.8125f,29.9079f,42.9688f, --3.90625f,31.268f,42.9688f, -0.0f,31.3916f,42.9688f, -3.90625f,31.8945f,42.9688f, --250.0f,4.27976f,39.0625f, --246.094f,4.20341f,39.0625f, --242.188f,3.80298f,39.0625f, --238.281f,4.79243f,39.0625f, --234.375f,5.51846f,39.0625f, --230.469f,6.91597f,39.0625f, --226.563f,8.25726f,39.0625f, --222.656f,8.85037f,39.0625f, --218.75f,9.57429f,39.0625f, --214.844f,11.3899f,39.0625f, --210.938f,12.5806f,39.0625f, --207.031f,14.2509f,39.0625f, --203.125f,14.7828f,39.0625f, --199.219f,15.9801f,39.0625f, --195.313f,17.4225f,39.0625f, --191.406f,19.6018f,39.0625f, --187.5f,22.1095f,39.0625f, --183.594f,23.8333f,39.0625f, --179.688f,25.0671f,39.0625f, --175.781f,27.1067f,39.0625f, --171.875f,28.5f,39.0625f, --167.969f,29.9625f,39.0625f, --164.063f,32.3895f,39.0625f, --160.156f,33.8224f,39.0625f, --156.25f,34.3349f,39.0625f, --152.344f,34.4661f,39.0625f, --148.438f,34.7236f,39.0625f, --144.531f,34.1129f,39.0625f, --140.625f,34.9033f,39.0625f, --136.719f,35.6229f,39.0625f, --132.813f,35.7143f,39.0625f, --128.906f,36.7151f,39.0625f, --125.0f,36.9574f,39.0625f, --121.094f,36.0729f,39.0625f, --117.188f,35.2171f,39.0625f, --113.281f,34.9343f,39.0625f, --109.375f,34.5707f,39.0625f, --105.469f,33.5046f,39.0625f, --101.563f,31.353f,39.0625f, --97.6563f,30.0283f,39.0625f, --93.75f,28.6272f,39.0625f, --89.8438f,26.4389f,39.0625f, --85.9375f,24.8159f,39.0625f, --82.0313f,23.0295f,39.0625f, --78.125f,21.1082f,39.0625f, --74.2188f,19.1239f,39.0625f, --70.3125f,18.0914f,39.0625f, --66.4063f,17.3227f,39.0625f, --62.5f,17.1022f,39.0625f, --58.5938f,16.4298f,39.0625f, --54.6875f,15.6704f,39.0625f, --50.7813f,16.5664f,39.0625f, --46.875f,18.478f,39.0625f, --42.9688f,19.4144f,39.0625f, --39.0625f,19.9351f,39.0625f, --35.1563f,20.3447f,39.0625f, --31.25f,22.4348f,39.0625f, --27.3438f,24.5713f,39.0625f, --23.4375f,25.5465f,39.0625f, --19.5313f,26.485f,39.0625f, --15.625f,28.292f,39.0625f, --11.7188f,30.0016f,39.0625f, --7.8125f,32.2532f,39.0625f, --3.90625f,33.6327f,39.0625f, -0.0f,33.835f,39.0625f, -3.90625f,34.9171f,39.0625f, --250.0f,3.91889f,35.1563f, --246.094f,3.38127f,35.1563f, --242.188f,3.26935f,35.1563f, --238.281f,4.06778f,35.1563f, --234.375f,4.87411f,35.1563f, --230.469f,6.48873f,35.1563f, --226.563f,7.17326f,35.1563f, --222.656f,8.21235f,35.1563f, --218.75f,8.21965f,35.1563f, --214.844f,10.417f,35.1563f, --210.938f,11.9497f,35.1563f, --207.031f,13.4145f,35.1563f, --203.125f,14.0876f,35.1563f, --199.219f,15.5077f,35.1563f, --195.313f,16.9011f,35.1563f, --191.406f,20.4395f,35.1563f, --187.5f,23.001f,35.1563f, --183.594f,24.0199f,35.1563f, --179.688f,25.7082f,35.1563f, --175.781f,27.3018f,35.1563f, --171.875f,28.9584f,35.1563f, --167.969f,31.1478f,35.1563f, --164.063f,32.8635f,35.1563f, --160.156f,33.5517f,35.1563f, --156.25f,34.5761f,35.1563f, --152.344f,34.5761f,35.1563f, --148.438f,34.2002f,35.1563f, --144.531f,34.7177f,35.1563f, --140.625f,35.5653f,35.1563f, --136.719f,35.7993f,35.1563f, --132.813f,37.1127f,35.1563f, --128.906f,37.2477f,35.1563f, --125.0f,36.8734f,35.1563f, --121.094f,35.4154f,35.1563f, --117.188f,34.8545f,35.1563f, --113.281f,35.4317f,35.1563f, --109.375f,34.9205f,35.1563f, --105.469f,33.5115f,35.1563f, --101.563f,32.2368f,35.1563f, --97.6563f,30.3601f,35.1563f, --93.75f,29.2913f,35.1563f, --89.8438f,27.4791f,35.1563f, --85.9375f,24.811f,35.1563f, --82.0313f,23.4984f,35.1563f, --78.125f,21.456f,35.1563f, --74.2188f,19.8992f,35.1563f, --70.3125f,17.7354f,35.1563f, --66.4063f,17.3066f,35.1563f, --62.5f,17.1745f,35.1563f, --58.5938f,16.5285f,35.1563f, --54.6875f,17.2826f,35.1563f, --50.7813f,18.6936f,35.1563f, --46.875f,19.4228f,35.1563f, --42.9688f,20.2022f,35.1563f, --39.0625f,21.4261f,35.1563f, --35.1563f,21.5779f,35.1563f, --31.25f,24.0097f,35.1563f, --27.3438f,25.4481f,35.1563f, --23.4375f,26.0036f,35.1563f, --19.5313f,27.4346f,35.1563f, --15.625f,30.2459f,35.1563f, --11.7188f,32.81f,35.1563f, --7.8125f,34.7924f,35.1563f, --3.90625f,35.8907f,35.1563f, -0.0f,36.9755f,35.1563f, -3.90625f,38.5427f,35.1563f, --250.0f,2.28536f,31.25f, --246.094f,1.63842f,31.25f, --242.188f,2.40273f,31.25f, --238.281f,3.19518f,31.25f, --234.375f,3.99394f,31.25f, --230.469f,4.99674f,31.25f, --226.563f,5.63235f,31.25f, --222.656f,6.86331f,31.25f, --218.75f,7.37515f,31.25f, --214.844f,9.34737f,31.25f, --210.938f,11.7034f,31.25f, --207.031f,13.4309f,31.25f, --203.125f,14.4474f,31.25f, --199.219f,15.8817f,31.25f, --195.313f,17.87f,31.25f, --191.406f,20.9938f,31.25f, --187.5f,23.5333f,31.25f, --183.594f,24.4107f,31.25f, --179.688f,26.0811f,31.25f, --175.781f,27.9797f,31.25f, --171.875f,29.4813f,31.25f, --167.969f,31.7071f,31.25f, --164.063f,33.0836f,31.25f, --160.156f,33.5998f,31.25f, --156.25f,33.5304f,31.25f, --152.344f,33.9929f,31.25f, --148.438f,35.4297f,31.25f, --144.531f,36.4531f,31.25f, --140.625f,35.9197f,31.25f, --136.719f,36.6849f,31.25f, --132.813f,37.8161f,31.25f, --128.906f,37.6166f,31.25f, --125.0f,36.9426f,31.25f, --121.094f,35.6388f,31.25f, --117.188f,35.0026f,31.25f, --113.281f,35.386f,31.25f, --109.375f,34.6287f,31.25f, --105.469f,33.8962f,31.25f, --101.563f,32.1844f,31.25f, --97.6563f,30.7868f,31.25f, --93.75f,29.267f,31.25f, --89.8438f,27.2585f,31.25f, --85.9375f,25.4236f,31.25f, --82.0313f,23.0281f,31.25f, --78.125f,21.4593f,31.25f, --74.2188f,19.4556f,31.25f, --70.3125f,18.0982f,31.25f, --66.4063f,17.1214f,31.25f, --62.5f,17.1751f,31.25f, --58.5938f,17.1429f,31.25f, --54.6875f,18.4434f,31.25f, --50.7813f,19.9422f,31.25f, --46.875f,21.2124f,31.25f, --42.9688f,21.2106f,31.25f, --39.0625f,22.1346f,31.25f, --35.1563f,23.3082f,31.25f, --31.25f,24.7044f,31.25f, --27.3438f,26.2688f,31.25f, --23.4375f,27.5692f,31.25f, --19.5313f,30.4099f,31.25f, --15.625f,33.0453f,31.25f, --11.7188f,34.9857f,31.25f, --7.8125f,37.0727f,31.25f, --3.90625f,39.2219f,31.25f, -0.0f,40.3658f,31.25f, -3.90625f,41.4381f,31.25f, --250.0f,0.4773f,27.3438f, --246.094f,0.631847f,27.3438f, --242.188f,1.21449f,27.3438f, --238.281f,1.52728f,27.3438f, --234.375f,2.73146f,27.3438f, --230.469f,3.65375f,27.3438f, --226.563f,5.03467f,27.3438f, --222.656f,6.27065f,27.3438f, --218.75f,7.56964f,27.3438f, --214.844f,9.63719f,27.3438f, --210.938f,11.4022f,27.3438f, --207.031f,12.7085f,27.3438f, --203.125f,14.3808f,27.3438f, --199.219f,15.9121f,27.3438f, --195.313f,17.8953f,27.3438f, --191.406f,20.8456f,27.3438f, --187.5f,22.7705f,27.3438f, --183.594f,24.5794f,27.3437f, --179.688f,27.055f,27.3438f, --175.781f,29.3548f,27.3437f, --171.875f,30.4534f,27.3438f, --167.969f,32.4366f,27.3437f, --164.063f,34.4967f,27.3438f, --160.156f,34.9614f,27.3437f, --156.25f,34.9405f,27.3438f, --152.344f,35.7165f,27.3437f, --148.438f,37.0387f,27.3438f, --144.531f,38.0934f,27.3437f, --140.625f,37.3872f,27.3438f, --136.719f,36.4336f,27.3437f, --132.813f,37.0365f,27.3438f, --128.906f,37.2591f,27.3437f, --125.0f,36.5502f,27.3438f, --121.094f,35.4814f,27.3437f, --117.188f,35.3267f,27.3438f, --113.281f,34.3757f,27.3437f, --109.375f,34.2455f,27.3438f, --105.469f,33.6851f,27.3437f, --101.563f,32.3527f,27.3438f, --97.6563f,30.111f,27.3437f, --93.75f,28.4912f,27.3438f, --89.8438f,27.0398f,27.3437f, --85.9375f,24.9699f,27.3438f, --82.0313f,22.9703f,27.3437f, --78.125f,21.7502f,27.3438f, --74.2188f,18.8537f,27.3438f, --70.3125f,18.2353f,27.3438f, --66.4063f,18.3708f,27.3438f, --62.5f,18.6738f,27.3438f, --58.5938f,18.5559f,27.3438f, --54.6875f,19.1603f,27.3438f, --50.7813f,20.8349f,27.3438f, --46.875f,21.6092f,27.3438f, --42.9688f,21.9317f,27.3437f, --39.0625f,23.0486f,27.3438f, --35.1563f,24.8675f,27.3437f, --31.25f,25.6906f,27.3438f, --27.3438f,27.9695f,27.3437f, --23.4375f,30.3105f,27.3438f, --19.5313f,33.9897f,27.3437f, --15.625f,35.6988f,27.3438f, --11.7188f,37.9213f,27.3437f, --7.8125f,40.1355f,27.3438f, --3.90625f,41.6062f,27.3437f, -0.0f,42.273f,27.3438f, -3.90625f,42.7334f,27.3437f, --250.0f,0.178144f,23.4375f, --246.094f,1.07943f,23.4375f, --242.188f,1.52473f,23.4375f, --238.281f,2.58652f,23.4375f, --234.375f,3.51451f,23.4375f, --230.469f,4.23103f,23.4375f, --226.563f,5.80506f,23.4375f, --222.656f,7.26086f,23.4375f, --218.75f,8.85201f,23.4375f, --214.844f,10.9029f,23.4375f, --210.938f,12.7138f,23.4375f, --207.031f,14.9249f,23.4375f, --203.125f,15.6506f,23.4375f, --199.219f,16.529f,23.4375f, --195.313f,17.1535f,23.4375f, --191.406f,20.5632f,23.4375f, --187.5f,23.1009f,23.4375f, --183.594f,24.7859f,23.4375f, --179.688f,26.8635f,23.4375f, --175.781f,28.5723f,23.4375f, --171.875f,30.2918f,23.4375f, --167.969f,32.7768f,23.4375f, --164.063f,34.6199f,23.4375f, --160.156f,35.6902f,23.4375f, --156.25f,37.1166f,23.4375f, --152.344f,37.0816f,23.4375f, --148.438f,37.9995f,23.4375f, --144.531f,38.687f,23.4375f, --140.625f,37.9261f,23.4375f, --136.719f,36.7476f,23.4375f, --132.813f,37.1839f,23.4375f, --128.906f,36.8682f,23.4375f, --125.0f,36.2555f,23.4375f, --121.094f,34.8461f,23.4375f, --117.188f,34.5757f,23.4375f, --113.281f,33.8965f,23.4375f, --109.375f,33.4987f,23.4375f, --105.469f,33.02f,23.4375f, --101.563f,31.4543f,23.4375f, --97.6563f,29.5899f,23.4375f, --93.75f,27.8808f,23.4375f, --89.8438f,26.4886f,23.4375f, --85.9375f,24.5413f,23.4375f, --82.0313f,22.6097f,23.4375f, --78.125f,21.38f,23.4375f, --74.2188f,19.2574f,23.4375f, --70.3125f,19.6862f,23.4375f, --66.4063f,19.3283f,23.4375f, --62.5f,20.3608f,23.4375f, --58.5938f,20.9969f,23.4375f, --54.6875f,20.5645f,23.4375f, --50.7813f,21.6338f,23.4375f, --46.875f,22.0705f,23.4375f, --42.9688f,23.2924f,23.4375f, --39.0625f,24.8627f,23.4375f, --35.1563f,25.9292f,23.4375f, --31.25f,27.2133f,23.4375f, --27.3438f,29.7296f,23.4375f, --23.4375f,32.8149f,23.4375f, --19.5313f,35.5321f,23.4375f, --15.625f,38.2144f,23.4375f, --11.7188f,40.2421f,23.4375f, --7.8125f,41.7479f,23.4375f, --3.90625f,43.372f,23.4375f, -0.0f,43.7526f,23.4375f, -3.90625f,44.6783f,23.4375f, --250.0f,0.138221f,19.5313f, --246.094f,1.4004f,19.5313f, --242.188f,3.26515f,19.5313f, --238.281f,3.65276f,19.5313f, --234.375f,4.90602f,19.5313f, --230.469f,6.03349f,19.5313f, --226.563f,7.99773f,19.5313f, --222.656f,9.41728f,19.5313f, --218.75f,10.0435f,19.5313f, --214.844f,12.1613f,19.5313f, --210.938f,13.6999f,19.5313f, --207.031f,15.7603f,19.5313f, --203.125f,16.1549f,19.5313f, --199.219f,17.1021f,19.5313f, --195.313f,18.1867f,19.5313f, --191.406f,20.6836f,19.5313f, --187.5f,23.0865f,19.5312f, --183.594f,24.3015f,19.5313f, --179.688f,26.6623f,19.5312f, --175.781f,28.232f,19.5313f, --171.875f,30.6454f,19.5312f, --167.969f,32.8674f,19.5313f, --164.063f,35.0881f,19.5312f, --160.156f,37.2715f,19.5313f, --156.25f,38.6025f,19.5312f, --152.344f,38.2781f,19.5313f, --148.438f,38.4813f,19.5312f, --144.531f,38.3281f,19.5313f, --140.625f,38.1441f,19.5312f, --136.719f,37.6066f,19.5312f, --132.813f,37.2097f,19.5312f, --128.906f,36.5694f,19.5312f, --125.0f,36.2416f,19.5312f, --121.094f,34.5305f,19.5312f, --117.188f,33.3684f,19.5312f, --113.281f,32.7805f,19.5312f, --109.375f,31.8563f,19.5312f, --105.469f,31.3398f,19.5312f, --101.563f,29.7387f,19.5312f, --97.6563f,28.7121f,19.5312f, --93.75f,27.8904f,19.5312f, --89.8438f,26.0256f,19.5312f, --85.9375f,24.5469f,19.5312f, --82.0313f,23.3531f,19.5312f, --78.125f,21.4621f,19.5313f, --74.2188f,20.3507f,19.5313f, --70.3125f,20.1879f,19.5313f, --66.4063f,20.9838f,19.5313f, --62.5f,22.229f,19.5312f, --58.5938f,22.355f,19.5312f, --54.6875f,22.7659f,19.5312f, --50.7813f,22.9258f,19.5312f, --46.875f,23.554f,19.5312f, --42.9688f,24.3861f,19.5312f, --39.0625f,25.5112f,19.5312f, --35.1563f,26.8691f,19.5312f, --31.25f,28.968f,19.5312f, --27.3438f,31.0124f,19.5312f, --23.4375f,34.8357f,19.5312f, --19.5313f,37.2362f,19.5312f, --15.625f,39.5924f,19.5312f, --11.7188f,41.5691f,19.5312f, --7.8125f,43.2441f,19.5312f, --3.90625f,45.1168f,19.5312f, -0.0f,45.7555f,19.5312f, -3.90625f,46.9055f,19.5312f, --250.0f,0.462936f,15.625f, --246.094f,2.15489f,15.625f, --242.188f,3.69232f,15.625f, --238.281f,4.89361f,15.625f, --234.375f,6.95706f,15.625f, --230.469f,8.37916f,15.625f, --226.563f,9.21515f,15.625f, --222.656f,10.0624f,15.625f, --218.75f,11.6477f,15.625f, --214.844f,13.257f,15.625f, --210.938f,14.8699f,15.625f, --207.031f,15.9852f,15.625f, --203.125f,17.025f,15.625f, --199.219f,17.8511f,15.625f, --195.313f,20.3581f,15.625f, --191.406f,22.0829f,15.625f, --187.5f,24.4216f,15.625f, --183.594f,25.5625f,15.625f, --179.688f,27.0961f,15.625f, --175.781f,30.0958f,15.625f, --171.875f,31.7977f,15.625f, --167.969f,34.7043f,15.625f, --164.063f,37.1655f,15.625f, --160.156f,37.6823f,15.625f, --156.25f,37.6204f,15.625f, --152.344f,37.8037f,15.625f, --148.438f,37.8555f,15.625f, --144.531f,37.9638f,15.625f, --140.625f,37.4821f,15.625f, --136.719f,37.0202f,15.625f, --132.813f,36.4604f,15.625f, --128.906f,36.1575f,15.625f, --125.0f,35.4218f,15.625f, --121.094f,33.5202f,15.625f, --117.188f,32.116f,15.625f, --113.281f,30.9352f,15.625f, --109.375f,29.8297f,15.625f, --105.469f,29.9146f,15.625f, --101.563f,28.7245f,15.625f, --97.6563f,27.7205f,15.625f, --93.75f,27.4217f,15.625f, --89.8438f,25.8557f,15.625f, --85.9375f,24.0609f,15.625f, --82.0313f,22.7869f,15.625f, --78.125f,20.4923f,15.625f, --74.2188f,21.0025f,15.625f, --70.3125f,21.2985f,15.625f, --66.4063f,22.5717f,15.625f, --62.5f,23.0569f,15.625f, --58.5938f,23.2123f,15.625f, --54.6875f,24.1861f,15.625f, --50.7813f,24.5626f,15.625f, --46.875f,25.1259f,15.625f, --42.9688f,25.9995f,15.625f, --39.0625f,26.8682f,15.625f, --35.1563f,27.8593f,15.625f, --31.25f,29.8924f,15.625f, --27.3438f,32.8894f,15.625f, --23.4375f,36.2901f,15.625f, --19.5313f,38.2475f,15.625f, --15.625f,40.593f,15.625f, --11.7188f,42.2973f,15.625f, --7.8125f,45.3308f,15.625f, --3.90625f,47.345f,15.625f, -0.0f,48.9808f,15.625f, -3.90625f,49.2295f,15.625f, --250.0f,1.16646f,11.7188f, --246.094f,2.99331f,11.7188f, --242.188f,4.37829f,11.7188f, --238.281f,5.21593f,11.7188f, --234.375f,6.84374f,11.7188f, --230.469f,8.34616f,11.7188f, --226.563f,9.2826f,11.7188f, --222.656f,9.90104f,11.7188f, --218.75f,10.9211f,11.7187f, --214.844f,13.6881f,11.7187f, --210.938f,15.7745f,11.7187f, --207.031f,16.2325f,11.7187f, --203.125f,17.2525f,11.7187f, --199.219f,19.1108f,11.7187f, --195.313f,21.4743f,11.7187f, --191.406f,24.021f,11.7187f, --187.5f,25.8676f,11.7187f, --183.594f,27.021f,11.7187f, --179.688f,28.254f,11.7187f, --175.781f,31.6036f,11.7187f, --171.875f,32.629f,11.7187f, --167.969f,34.9526f,11.7187f, --164.063f,36.8236f,11.7187f, --160.156f,37.152f,11.7187f, --156.25f,37.6659f,11.7187f, --152.344f,37.4102f,11.7187f, --148.438f,37.0806f,11.7187f, --144.531f,37.6299f,11.7187f, --140.625f,36.7269f,11.7187f, --136.719f,36.4841f,11.7187f, --132.813f,35.2557f,11.7187f, --128.906f,34.7066f,11.7187f, --125.0f,34.0947f,11.7187f, --121.094f,32.7343f,11.7187f, --117.188f,31.5605f,11.7187f, --113.281f,30.7492f,11.7187f, --109.375f,30.1608f,11.7187f, --105.469f,29.9144f,11.7187f, --101.563f,28.5532f,11.7187f, --97.6563f,26.2051f,11.7187f, --93.75f,26.0432f,11.7187f, --89.8438f,25.1831f,11.7187f, --85.9375f,23.7935f,11.7187f, --82.0313f,22.6952f,11.7187f, --78.125f,21.9812f,11.7187f, --74.2188f,22.3423f,11.7187f, --70.3125f,22.4959f,11.7187f, --66.4063f,22.9438f,11.7187f, --62.5f,23.6591f,11.7187f, --58.5938f,24.1634f,11.7187f, --54.6875f,24.8781f,11.7187f, --50.7813f,25.3471f,11.7187f, --46.875f,25.7599f,11.7187f, --42.9688f,26.61f,11.7187f, --39.0625f,27.5033f,11.7187f, --35.1563f,29.2751f,11.7187f, --31.25f,31.9147f,11.7187f, --27.3438f,34.1964f,11.7187f, --23.4375f,36.7734f,11.7187f, --19.5313f,39.2441f,11.7187f, --15.625f,41.3269f,11.7187f, --11.7188f,44.2682f,11.7187f, --7.8125f,47.2458f,11.7187f, --3.90625f,49.2199f,11.7187f, -0.0f,50.2546f,11.7187f, -3.90625f,51.1233f,11.7187f, --250.0f,1.52698f,7.8125f, --246.094f,2.97227f,7.8125f, --242.188f,3.77319f,7.8125f, --238.281f,4.81095f,7.8125f, --234.375f,5.94458f,7.8125f, --230.469f,7.45352f,7.8125f, --226.563f,8.9683f,7.8125f, --222.656f,9.37348f,7.8125f, --218.75f,10.3818f,7.8125f, --214.844f,13.0632f,7.8125f, --210.938f,15.5836f,7.8125f, --207.031f,17.1532f,7.8125f, --203.125f,19.3065f,7.8125f, --199.219f,21.746f,7.8125f, --195.313f,23.0026f,7.8125f, --191.406f,25.1876f,7.8125f, --187.5f,27.4911f,7.8125f, --183.594f,28.651f,7.8125f, --179.688f,28.9685f,7.8125f, --175.781f,31.1275f,7.8125f, --171.875f,32.457f,7.8125f, --167.969f,34.4336f,7.8125f, --164.063f,35.9124f,7.8125f, --160.156f,36.5078f,7.8125f, --156.25f,36.9999f,7.8125f, --152.344f,36.9517f,7.8125f, --148.438f,37.9713f,7.8125f, --144.531f,37.929f,7.8125f, --140.625f,37.5334f,7.8125f, --136.719f,36.2798f,7.8125f, --132.813f,35.1904f,7.8125f, --128.906f,33.7356f,7.8125f, --125.0f,34.0968f,7.8125f, --121.094f,33.5838f,7.8125f, --117.188f,32.9371f,7.8125f, --113.281f,32.0353f,7.8125f, --109.375f,31.4623f,7.8125f, --105.469f,30.5184f,7.8125f, --101.563f,28.7396f,7.8125f, --97.6563f,27.2715f,7.8125f, --93.75f,26.1242f,7.8125f, --89.8438f,24.5691f,7.8125f, --85.9375f,23.931f,7.8125f, --82.0313f,23.7643f,7.8125f, --78.125f,22.4588f,7.8125f, --74.2188f,22.5395f,7.8125f, --70.3125f,22.9322f,7.8125f, --66.4063f,23.4361f,7.8125f, --62.5f,24.2733f,7.8125f, --58.5938f,24.1873f,7.8125f, --54.6875f,24.2666f,7.8125f, --50.7813f,25.2522f,7.8125f, --46.875f,26.3494f,7.8125f, --42.9688f,26.8365f,7.8125f, --39.0625f,27.5515f,7.8125f, --35.1563f,30.4441f,7.8125f, --31.25f,33.5547f,7.8125f, --27.3438f,36.1409f,7.8125f, --23.4375f,38.1103f,7.8125f, --19.5313f,39.8171f,7.8125f, --15.625f,42.1146f,7.8125f, --11.7188f,45.3603f,7.8125f, --7.8125f,47.6602f,7.8125f, --3.90625f,49.963f,7.8125f, -0.0f,51.8119f,7.8125f, -3.90625f,52.2527f,7.8125f, --250.0f,0.139875f,3.90625f, --246.094f,1.72995f,3.90625f, --242.188f,2.60122f,3.90625f, --238.281f,4.01346f,3.90625f, --234.375f,5.13654f,3.90625f, --230.469f,6.69665f,3.90625f, --226.563f,8.43203f,3.90625f, --222.656f,9.83442f,3.90625f, --218.75f,11.3645f,3.90625f, --214.844f,14.222f,3.90625f, --210.938f,16.1758f,3.90625f, --207.031f,18.9127f,3.90625f, --203.125f,21.2478f,3.90625f, --199.219f,23.0589f,3.90625f, --195.313f,24.6025f,3.90625f, --191.406f,25.8143f,3.90625f, --187.5f,27.5696f,3.90625f, --183.594f,29.2176f,3.90625f, --179.688f,29.6835f,3.90625f, --175.781f,30.7416f,3.90625f, --171.875f,31.4405f,3.90625f, --167.969f,33.0831f,3.90625f, --164.063f,34.6225f,3.90625f, --160.156f,35.4992f,3.90625f, --156.25f,37.4126f,3.90625f, --152.344f,38.453f,3.90625f, --148.438f,38.9974f,3.90625f, --144.531f,38.7871f,3.90625f, --140.625f,37.6021f,3.90625f, --136.719f,36.1797f,3.90625f, --132.813f,34.9906f,3.90625f, --128.906f,34.1304f,3.90625f, --125.0f,34.3517f,3.90625f, --121.094f,33.6612f,3.90625f, --117.188f,32.7047f,3.90625f, --113.281f,32.3958f,3.90625f, --109.375f,31.0818f,3.90625f, --105.469f,30.9536f,3.90625f, --101.563f,29.8205f,3.90625f, --97.6563f,28.4796f,3.90625f, --93.75f,27.6494f,3.90625f, --89.8438f,25.5721f,3.90625f, --85.9375f,24.227f,3.90625f, --82.0313f,23.2611f,3.90625f, --78.125f,22.4589f,3.90625f, --74.2188f,23.2261f,3.90625f, --70.3125f,23.5025f,3.90625f, --66.4063f,23.6913f,3.90625f, --62.5f,24.6785f,3.90625f, --58.5938f,25.4946f,3.90625f, --54.6875f,25.9722f,3.90625f, --50.7813f,26.1977f,3.90625f, --46.875f,26.8539f,3.90625f, --42.9688f,27.7268f,3.90625f, --39.0625f,29.2046f,3.90625f, --35.1563f,31.79f,3.90625f, --31.25f,34.2658f,3.90625f, --27.3438f,35.9914f,3.90625f, --23.4375f,38.3776f,3.90625f, --19.5313f,39.8852f,3.90625f, --15.625f,43.1455f,3.90625f, --11.7188f,45.5059f,3.90625f, --7.8125f,47.4257f,3.90625f, --3.90625f,49.9032f,3.90625f, -0.0f,52.0322f,3.90625f, -3.90625f,52.6186f,3.90625f, -}; - -btScalar Landscape02Nml[] = { -0.376889f,0.897995f,0.227068f, -0.251083f,0.961355f,0.112931f, -0.256071f,0.961946f,0.0953332f, -0.188246f,0.981544f,0.0336933f, -0.321782f,0.946812f,0.00191405f, -0.277829f,0.960055f,0.0332431f, -0.366908f,0.922321f,-0.121252f, -0.346681f,0.936118f,-0.0591191f, -0.34598f,0.936023f,-0.0644918f, -0.326882f,0.934733f,-0.139364f, -0.195537f,0.979014f,-0.0574119f, -0.208421f,0.974173f,-0.0868766f, -0.220158f,0.96963f,-0.106528f, -0.21764f,0.974169f,-0.0602246f, -0.194781f,0.966032f,-0.169831f, -0.137923f,0.97923f,-0.148611f, --0.0890295f,0.968844f,-0.231118f, --0.164208f,0.952108f,-0.257926f, --0.299547f,0.905883f,-0.299413f, --0.331781f,0.892916f,-0.304338f, --0.275234f,0.921181f,-0.275086f, --0.190055f,0.968186f,-0.162776f, --0.191147f,0.964101f,-0.184313f, --0.167051f,0.973656f,-0.155201f, --0.260549f,0.956867f,-0.128527f, --0.236175f,0.968373f,-0.080466f, --0.305083f,0.942279f,-0.137969f, --0.32302f,0.940678f,-0.103844f, --0.376654f,0.91108f,-0.167524f, --0.43665f,0.882087f,-0.176802f, --0.404697f,0.87224f,-0.274621f, --0.461396f,0.842558f,-0.277868f, --0.340534f,0.861872f,-0.375783f, --0.381498f,0.847049f,-0.370091f, --0.349262f,0.83292f,-0.429255f, --0.383821f,0.842401f,-0.378209f, --0.350717f,0.827302f,-0.438826f, --0.312636f,0.886963f,-0.339934f, --0.202637f,0.921293f,-0.331899f, --0.164853f,0.917655f,-0.361571f, --0.320762f,0.929092f,-0.184116f, --0.291289f,0.89543f,-0.336684f, --0.523923f,0.850919f,-0.0379686f, --0.415222f,0.907809f,-0.0589323f, --0.464751f,0.884928f,0.030152f, --0.464228f,0.885715f,0.00114487f, --0.460666f,0.887573f,-0.00119475f, --0.527574f,0.824073f,-0.206324f, --0.569463f,0.819886f,-0.0591577f, --0.624043f,0.739025f,-0.253797f, --0.677912f,0.708815f,-0.19498f, --0.654991f,0.737431f,-0.164874f, --0.612102f,0.778841f,-0.136883f, --0.555251f,0.829082f,-0.0657209f, --0.466796f,0.884362f,-0.00238444f, --0.393172f,0.917844f,0.0545768f, --0.415266f,0.902781f,0.111985f, --0.346174f,0.92512f,0.155936f, --0.270143f,0.942251f,0.197955f, --0.242693f,0.931939f,0.269424f, --0.146828f,0.979561f,0.137484f, --0.151815f,0.949716f,0.273847f, --0.23746f,0.962635f,0.130183f, --0.242269f,0.936807f,0.252385f, --0.439066f,0.897439f,0.0427119f, --0.506925f,0.859633f,0.0637107f, --0.369534f,0.927612f,0.0545955f, --0.266432f,0.921234f,0.283447f, --0.0849634f,0.983229f,0.161377f, --0.142422f,0.97399f,0.176238f, -0.059987f,0.992193f,0.109333f, --0.00609097f,0.990503f,0.137353f, -0.218751f,0.975042f,-0.0379662f, -0.195675f,0.973574f,0.117747f, -0.412438f,0.903178f,-0.119012f, -0.389829f,0.920771f,0.01463f, -0.471887f,0.878868f,-0.0700914f, -0.512637f,0.843878f,0.158344f, -0.438398f,0.898776f,-0.0028899f, -0.463505f,0.872879f,0.152466f, -0.213581f,0.96879f,0.125817f, -0.217949f,0.966902f,0.132661f, -0.150053f,0.978231f,0.143348f, -0.183142f,0.954792f,0.234161f, -0.324547f,0.937949f,0.122152f, -0.305949f,0.944044f,0.123194f, -0.404781f,0.90011f,0.161105f, -0.386685f,0.917163f,0.0963685f, -0.43511f,0.894378f,0.103764f, -0.444378f,0.884165f,0.144156f, -0.485066f,0.871945f,0.0665013f, -0.480511f,0.864609f,0.146835f, -0.542329f,0.83784f,0.0624783f, -0.538258f,0.834152f,0.120286f, -0.497652f,0.86488f,0.0657686f, -0.471897f,0.881288f,0.0253797f, -0.368509f,0.927548f,0.0620863f, -0.391828f,0.918428f,0.0544149f, -0.284879f,0.953389f,0.0994662f, -0.359932f,0.902669f,0.235877f, -0.19297f,0.969614f,0.150374f, -0.198191f,0.923716f,0.327825f, -0.174784f,0.978101f,0.113003f, -0.121688f,0.95783f,0.260297f, -0.3291f,0.939598f,0.094074f, -0.241925f,0.967997f,0.066744f, -0.275982f,0.959352f,0.0589789f, -0.207349f,0.969048f,-0.133986f, --0.048418f,0.997403f,0.0533214f, --0.0214229f,0.995947f,-0.0873486f, --0.224808f,0.97209f,0.0671032f, --0.154526f,0.98721f,0.0392114f, --0.0539424f,0.990401f,0.127262f, -0.0294265f,0.986864f,0.158851f, -0.115045f,0.967726f,0.224212f, -0.135755f,0.967813f,0.211917f, --0.0987201f,0.976534f,0.191406f, --0.208734f,0.974954f,0.0767793f, --0.346094f,0.938088f,0.0144628f, --0.364883f,0.930977f,0.0119327f, --0.234075f,0.972082f,0.0162811f, --0.216489f,0.973875f,0.0685516f, --0.126585f,0.991898f,0.0107448f, --0.188432f,0.981937f,-0.0171439f, --0.186728f,0.980312f,-0.0641921f, --0.243763f,0.959118f,-0.14378f, --0.256453f,0.962392f,-0.0896326f, --0.227009f,0.972481f,-0.0524148f, --0.308642f,0.945388f,-0.104794f, --0.322884f,0.94242f,-0.0871231f, --0.32494f,0.940988f,-0.0946312f, --0.365791f,0.920972f,-0.134189f, -0.507209f,0.830952f,0.228598f, -0.427157f,0.893788f,0.136676f, -0.390358f,0.920644f,0.00595094f, -0.357f,0.931227f,0.0732586f, -0.253669f,0.95455f,0.156478f, -0.247974f,0.954291f,0.166849f, -0.303694f,0.950352f,0.0678299f, -0.260247f,0.965246f,0.0238949f, --0.0615746f,0.996768f,-0.0515863f, --0.225111f,0.970921f,-0.0814727f, --0.33579f,0.924057f,-0.18266f, --0.286567f,0.949099f,-0.13073f, --0.266283f,0.957101f,-0.114241f, --0.297972f,0.942451f,-0.151651f, --0.345158f,0.930403f,-0.123358f, --0.323606f,0.933615f,-0.153759f, --0.295216f,0.935234f,-0.195409f, --0.294262f,0.935546f,-0.195355f, --0.367877f,0.896699f,-0.246165f, --0.460611f,0.856308f,-0.233612f, --0.493615f,0.869663f,0.00556421f, --0.56572f,0.819247f,0.0937815f, --0.482796f,0.868728f,0.110547f, --0.473443f,0.870107f,0.136985f, --0.486628f,0.863931f,0.12968f, --0.584612f,0.809918f,-0.0475519f, --0.673803f,0.720247f,-0.165027f, --0.584438f,0.811258f,-0.0171189f, --0.49626f,0.855798f,0.146063f, --0.266763f,0.927018f,0.26358f, --0.000318467f,0.974136f,0.225963f, --0.2098f,0.977621f,0.015525f, --0.363964f,0.929076f,-0.0659462f, --0.427799f,0.890708f,-0.153708f, --0.226888f,0.973494f,-0.0288381f, -0.176474f,0.981f,0.080593f, -0.382766f,0.920418f,-0.0794987f, -0.4558f,0.874041f,-0.16822f, -0.44168f,0.87342f,-0.205075f, -0.269141f,0.944688f,-0.187422f, -0.0983269f,0.994746f,0.0285051f, -0.164874f,0.980231f,0.10938f, -0.300398f,0.949423f,0.0914149f, -0.370498f,0.925363f,0.0802133f, -0.51325f,0.857062f,0.0449297f, -0.515688f,0.85628f,-0.0291725f, -0.532902f,0.845818f,-0.0246416f, -0.470584f,0.882352f,0.00224652f, -0.358364f,0.932053f,0.0534101f, -0.299916f,0.948938f,0.0978121f, -0.234125f,0.96956f,0.0716857f, -0.201429f,0.97943f,0.0119968f, -0.257021f,0.965839f,0.0330825f, -0.205585f,0.966488f,0.153741f, --0.0291083f,0.972977f,0.22906f, --0.183781f,0.97216f,0.145362f, --0.0880966f,0.991634f,0.0943445f, -0.0404056f,0.991359f,0.124796f, --0.0259416f,0.986408f,0.162256f, --0.213262f,0.97241f,0.0945471f, --0.221976f,0.974645f,0.0281856f, --0.137418f,0.990413f,0.014064f, --0.147111f,0.988464f,0.0360112f, --0.213681f,0.97687f,0.00813376f, --0.286716f,0.957516f,-0.0309366f, --0.362687f,0.929548f,-0.0663186f, -0.471826f,0.881687f,0.00273101f, -0.493844f,0.862721f,0.108764f, -0.305852f,0.940961f,0.145073f, -0.225186f,0.91763f,0.327484f, -0.255894f,0.905552f,0.33837f, -0.302798f,0.922674f,0.238719f, -0.353759f,0.914443f,0.196594f, -0.301669f,0.941039f,0.153105f, -0.00675732f,0.993813f,0.110864f, --0.180673f,0.978312f,0.101302f, --0.247784f,0.966857f,0.0615767f, --0.309703f,0.949482f,-0.0506691f, --0.243038f,0.969623f,-0.0276337f, --0.257234f,0.966017f,-0.0253295f, --0.381367f,0.920413f,-0.0860151f, --0.354157f,0.93479f,-0.027217f, --0.299485f,0.952671f,0.0522246f, --0.356888f,0.9323f,0.0587106f, --0.335176f,0.924244f,0.182839f, --0.500593f,0.855036f,0.135351f, --0.576428f,0.801243f,0.160441f, --0.583679f,0.788168f,0.195218f, --0.491918f,0.829821f,0.263465f, --0.431671f,0.862042f,0.2656f, --0.443518f,0.883408f,0.151265f, --0.464317f,0.881859f,0.0820666f, --0.652068f,0.753609f,-0.0829502f, --0.681939f,0.728217f,-0.068254f, --0.591161f,0.804152f,0.0621953f, --0.352647f,0.921747f,0.161318f, -0.0545396f,0.95959f,0.276065f, -0.0694942f,0.971972f,0.224591f, --0.253858f,0.964902f,-0.0672354f, --0.408551f,0.900688f,-0.147807f, --0.327666f,0.933936f,-0.142825f, -0.129878f,0.985787f,-0.106564f, -0.442239f,0.89421f,-0.0693695f, -0.506959f,0.860716f,-0.0464834f, -0.440087f,0.895465f,-0.0668225f, -0.226441f,0.974021f,0.00265329f, --0.0272959f,0.999596f,0.00787303f, -0.0903893f,0.995643f,0.0228958f, -0.359925f,0.931179f,0.0579615f, -0.431266f,0.899788f,-0.0662666f, -0.53735f,0.839722f,-0.0782406f, -0.525898f,0.846474f,-0.0831443f, -0.503404f,0.859213f,-0.0913118f, -0.450901f,0.892319f,-0.0213084f, -0.278054f,0.959353f,0.048252f, -0.254295f,0.953824f,0.159853f, -0.246692f,0.953779f,0.171608f, -0.237766f,0.960301f,0.145908f, -0.249319f,0.965473f,0.0755121f, -0.140552f,0.989905f,0.0182753f, --0.0589195f,0.996842f,0.0532477f, --0.101426f,0.988847f,0.109061f, --0.043669f,0.99706f,0.0629708f, -0.0474685f,0.998853f,-0.0063145f, --0.0867729f,0.996136f,-0.0135299f, --0.196161f,0.972844f,0.12286f, --0.192413f,0.974994f,0.111196f, --0.123107f,0.990318f,0.0641543f, --0.164426f,0.985628f,0.0387435f, --0.213922f,0.974633f,0.0657922f, --0.241049f,0.968373f,0.0644173f, --0.307154f,0.951627f,-0.00792363f, -0.280771f,0.958227f,-0.0544817f, -0.299035f,0.949091f,0.0990176f, -0.225174f,0.937279f,0.266091f, -0.201765f,0.945847f,0.254291f, -0.341377f,0.920786f,0.18872f, -0.3743f,0.913661f,0.158502f, -0.359138f,0.923211f,0.136755f, -0.36518f,0.919296f,0.146759f, -0.0046348f,0.996002f,0.0892048f, --0.241229f,0.954179f,0.177061f, --0.158349f,0.951157f,0.265002f, --0.207545f,0.971279f,0.116375f, --0.289845f,0.957072f,0.00156201f, --0.257416f,0.96626f,0.00885102f, --0.326801f,0.944936f,0.0172234f, --0.439204f,0.898379f,-0.00377194f, --0.336537f,0.936282f,0.100589f, --0.407285f,0.907139f,0.105914f, --0.44858f,0.865076f,0.224543f, --0.454994f,0.838311f,0.300358f, --0.578424f,0.785375f,0.220483f, --0.613986f,0.761879f,0.206302f, --0.509143f,0.819763f,0.262226f, --0.364105f,0.879908f,0.30527f, --0.344494f,0.905138f,0.249097f, --0.369295f,0.913195f,0.172323f, --0.574832f,0.817482f,0.0359178f, --0.689125f,0.724332f,-0.0212343f, --0.619919f,0.781232f,-0.0733212f, --0.441345f,0.892835f,-0.0897783f, --0.0649595f,0.996915f,0.0440505f, -0.146397f,0.977716f,0.150467f, --0.0177868f,0.998167f,0.0578468f, --0.37006f,0.91802f,-0.14246f, --0.30849f,0.937533f,-0.160828f, -0.107382f,0.980696f,-0.163415f, -0.392635f,0.914926f,-0.093533f, -0.501877f,0.862749f,-0.0615151f, -0.381618f,0.912204f,-0.14917f, -0.160415f,0.986769f,-0.0235493f, -0.0253729f,0.99703f,0.0727145f, -0.144484f,0.989507f,0.000443305f, -0.379228f,0.922372f,-0.073601f, -0.493599f,0.867009f,-0.0682314f, -0.529895f,0.842151f,-0.099967f, -0.549367f,0.821638f,-0.152008f, -0.439412f,0.876451f,-0.196851f, -0.349224f,0.935858f,0.0470259f, -0.182079f,0.971589f,0.151205f, -0.194383f,0.962201f,0.190749f, -0.266182f,0.94835f,0.172569f, -0.284034f,0.949535f,0.133071f, -0.347472f,0.93345f,0.089069f, -0.226103f,0.974059f,0.00925465f, --0.0773561f,0.993257f,-0.0863519f, --0.200366f,0.974099f,-0.104811f, --0.00292133f,0.99995f,-0.00953497f, -0.144264f,0.988303f,-0.0494442f, --0.155865f,0.979469f,-0.127857f, --0.286146f,0.957784f,-0.0277406f, --0.165259f,0.985103f,-0.0475661f, --0.069504f,0.996782f,-0.0399387f, --0.139315f,0.988254f,-0.0628056f, --0.230813f,0.967463f,-0.103639f, --0.24543f,0.966984f,-0.0686046f, --0.189537f,0.981091f,0.0391957f, -0.151487f,0.988375f,0.0128779f, -0.16936f,0.984329f,0.0491336f, -0.218781f,0.968894f,0.115672f, -0.279098f,0.952669f,0.120523f, -0.344688f,0.931221f,0.118397f, -0.359727f,0.914297f,0.186165f, -0.326371f,0.918389f,0.223703f, -0.361839f,0.886899f,0.287197f, --0.000924981f,0.965442f,0.260617f, --0.321168f,0.914653f,0.24548f, --0.23578f,0.933549f,0.269988f, --0.0519805f,0.910912f,0.409313f, --0.120702f,0.947306f,0.296721f, --0.257649f,0.956241f,0.138637f, --0.340179f,0.924947f,0.169564f, --0.415425f,0.90289f,0.110507f, --0.41038f,0.91038f,0.0528755f, --0.447459f,0.881081f,0.153222f, --0.521314f,0.820871f,0.233245f, --0.470597f,0.83806f,0.27603f, --0.530303f,0.820989f,0.211554f, --0.59428f,0.795918f,0.11552f, --0.564828f,0.823165f,0.0580397f, --0.435129f,0.882511f,0.17843f, --0.320859f,0.891866f,0.318787f, --0.272192f,0.902535f,0.33368f, --0.476067f,0.856837f,0.197967f, --0.671403f,0.739101f,0.0543033f, --0.548598f,0.834125f,0.0572312f, --0.459373f,0.883769f,-0.0890421f, --0.194341f,0.977153f,-0.0860449f, -0.0638196f,0.997784f,0.0188364f, -0.119241f,0.989813f,0.0777976f, --0.189205f,0.978439f,-0.0828203f, --0.328042f,0.913868f,-0.239234f, -0.0439005f,0.976566f,-0.210694f, -0.345392f,0.929362f,-0.130351f, -0.531991f,0.841029f,-0.0982628f, -0.385958f,0.912021f,-0.13876f, -0.00996624f,0.998173f,-0.059598f, --0.0397997f,0.999182f,0.00710574f, -0.22423f,0.974041f,-0.0310806f, -0.399529f,0.909843f,-0.112084f, -0.472825f,0.876316f,-0.0922302f, -0.567959f,0.818431f,-0.0871407f, -0.591097f,0.802347f,-0.0827227f, -0.294969f,0.954774f,-0.0374031f, -0.136562f,0.986139f,0.0942395f, -0.140836f,0.978895f,0.148089f, -0.208743f,0.962024f,0.175889f, -0.331657f,0.931412f,0.149918f, -0.32318f,0.945148f,0.0474422f, -0.378499f,0.925602f,0.000447487f, -0.240237f,0.969087f,-0.0561752f, -0.0676245f,0.996927f,-0.0395359f, --0.154966f,0.962822f,-0.221268f, --0.087338f,0.971663f,-0.219642f, -0.144581f,0.983839f,-0.105631f, --0.0884322f,0.993076f,-0.0773351f, --0.293638f,0.94457f,-0.146848f, --0.135408f,0.983934f,-0.116358f, --0.103543f,0.987494f,-0.11889f, --0.104597f,0.98248f,-0.15425f, --0.176622f,0.962045f,-0.208023f, --0.325467f,0.923065f,-0.204992f, --0.403927f,0.903415f,-0.143824f, -0.344389f,0.929213f,0.134014f, -0.233815f,0.972165f,0.0150206f, -0.162621f,0.985815f,-0.0415186f, -0.195602f,0.980526f,0.0175561f, -0.28987f,0.950331f,0.113346f, -0.255987f,0.942074f,0.216718f, -0.263495f,0.890351f,0.371275f, -0.315069f,0.864416f,0.391812f, -0.0646003f,0.916859f,0.39395f, --0.213657f,0.9234f,0.318877f, --0.307635f,0.926495f,0.216719f, --0.201977f,0.923807f,0.325246f, --0.0210673f,0.916391f,0.399731f, --0.17042f,0.919713f,0.353674f, --0.316748f,0.899919f,0.299695f, --0.294061f,0.92391f,0.244781f, --0.396636f,0.905857f,0.14867f, --0.523471f,0.83043f,0.190696f, --0.568887f,0.791598f,0.223024f, --0.446362f,0.844948f,0.294659f, --0.453253f,0.853996f,0.255447f, --0.541011f,0.824142f,0.167623f, --0.550736f,0.81694f,0.171169f, --0.53915f,0.819657f,0.193597f, --0.444412f,0.862352f,0.242584f, --0.285315f,0.907749f,0.30755f, --0.329395f,0.886574f,0.324786f, --0.610599f,0.78547f,0.101022f, --0.543486f,0.838015f,0.0485148f, --0.319704f,0.945394f,0.0634074f, --0.262212f,0.963421f,-0.055354f, -0.000253525f,0.995852f,0.0909893f, -0.105619f,0.991464f,0.0764441f, -0.0245363f,0.999682f,-0.00586488f, --0.22917f,0.926966f,-0.29701f, --0.0159754f,0.943632f,-0.33061f, -0.309925f,0.920539f,-0.237812f, -0.48714f,0.850311f,-0.199165f, -0.288684f,0.955866f,-0.0546085f, --0.0787222f,0.994967f,0.0619939f, -0.0273777f,0.99772f,0.0616831f, -0.291481f,0.955243f,-0.0505022f, -0.438727f,0.89664f,-0.0596253f, -0.485213f,0.871546f,-0.0705428f, -0.5406f,0.839608f,-0.0530067f, -0.49511f,0.866937f,0.0573254f, -0.280189f,0.947413f,0.154605f, -0.158816f,0.979113f,0.126949f, -0.168625f,0.983554f,0.0647105f, -0.187616f,0.98216f,0.0127302f, -0.334023f,0.942557f,0.00379923f, -0.401318f,0.914355f,0.0538517f, -0.424638f,0.905172f,0.0185914f, -0.289448f,0.956081f,-0.0461475f, -0.0899479f,0.980871f,-0.172633f, --0.00560791f,0.970967f,-0.23915f, --0.153691f,0.938842f,-0.308149f, --0.0450622f,0.984719f,-0.168219f, --0.0818032f,0.994271f,0.0687937f, --0.254478f,0.967062f,-0.0056871f, --0.190127f,0.974114f,-0.122284f, --0.0615121f,0.986397f,-0.152435f, --0.0478084f,0.984317f,-0.169808f, --0.157882f,0.979732f,-0.123284f, --0.307356f,0.93941f,-0.151791f, --0.432596f,0.869844f,-0.237133f, -0.35469f,0.923204f,0.147951f, -0.317903f,0.938384f,0.135547f, -0.209784f,0.976723f,0.0447562f, -0.188401f,0.980806f,-0.0502544f, -0.153267f,0.987748f,-0.0293859f, -0.102074f,0.966336f,0.236167f, -0.128463f,0.933972f,0.333456f, -0.308207f,0.882627f,0.354934f, -0.141883f,0.91146f,0.386148f, --0.174863f,0.945456f,0.274837f, --0.248524f,0.937312f,0.244299f, --0.268339f,0.945888f,0.182456f, --0.0843285f,0.960488f,0.265238f, --0.151825f,0.934815f,0.321045f, --0.286064f,0.900967f,0.326231f, --0.240679f,0.904695f,0.351568f, --0.362345f,0.88785f,0.2836f, --0.538142f,0.813225f,0.221511f, --0.57294f,0.797677f,0.188284f, --0.51091f,0.838129f,0.191079f, --0.412611f,0.865658f,0.283528f, --0.528395f,0.821979f,0.212483f, --0.579097f,0.792111f,0.192891f, --0.502268f,0.843036f,0.192398f, --0.402738f,0.896524f,0.184518f, --0.323371f,0.930281f,0.173231f, --0.341027f,0.92193f,0.183699f, --0.49586f,0.861123f,0.112209f, --0.562176f,0.82675f,-0.0210484f, --0.29935f,0.952705f,0.0523715f, --0.273263f,0.96182f,0.0151701f, --0.127856f,0.984802f,0.117552f, -0.16681f,0.967622f,0.189425f, -0.219885f,0.966852f,0.1298f, -0.0444925f,0.994595f,-0.093817f, --0.0559771f,0.948894f,-0.31059f, -0.229668f,0.93439f,-0.272337f, -0.391338f,0.907289f,-0.153889f, -0.215699f,0.975228f,0.0490428f, --0.1202f,0.992098f,0.0359644f, -0.0568932f,0.997098f,0.0505773f, -0.369571f,0.928802f,0.0272646f, -0.435039f,0.898005f,-0.0657877f, -0.45866f,0.886154f,-0.0660444f, -0.484136f,0.874975f,0.00559808f, -0.464546f,0.884206f,0.0487577f, -0.311084f,0.947795f,0.0700806f, -0.215922f,0.975139f,0.0498078f, -0.229266f,0.973122f,-0.0216826f, -0.269391f,0.956816f,-0.109228f, -0.297276f,0.941247f,-0.160256f, -0.352506f,0.931874f,-0.0857318f, -0.363875f,0.92958f,-0.0589632f, -0.421372f,0.901903f,0.094954f, -0.220959f,0.972251f,-0.0768509f, -0.0552433f,0.994093f,-0.0934223f, --0.134577f,0.980922f,-0.140288f, --0.247593f,0.953903f,-0.169607f, --0.238891f,0.96987f,-0.0477791f, --0.130123f,0.990325f,-0.0482061f, -0.00814361f,0.986901f,-0.161119f, --0.0740374f,0.970051f,-0.231345f, --0.135238f,0.990526f,-0.0238593f, --0.204897f,0.978574f,0.0202582f, --0.205889f,0.977122f,-0.0533174f, --0.236999f,0.963982f,-0.120711f, -0.399314f,0.905653f,0.142621f, -0.334882f,0.936094f,0.107618f, -0.310789f,0.943606f,0.114093f, -0.298988f,0.952609f,0.0560503f, -0.00373107f,0.999894f,-0.0140921f, --0.127729f,0.983543f,0.12778f, -0.134365f,0.969696f,0.204046f, -0.250753f,0.938877f,0.235867f, -0.172971f,0.901933f,0.395725f, --0.0661635f,0.938085f,0.340027f, --0.190026f,0.944561f,0.267758f, --0.246469f,0.952194f,0.180498f, --0.199636f,0.962622f,0.183041f, --0.204824f,0.924659f,0.321019f, --0.345906f,0.869848f,0.351729f, --0.272906f,0.86539f,0.420265f, --0.23738f,0.86577f,0.44056f, --0.476597f,0.838274f,0.264863f, --0.549692f,0.815624f,0.180542f, --0.521659f,0.837826f,0.160993f, --0.461012f,0.874551f,0.150426f, --0.498406f,0.858536f,0.120447f, --0.538861f,0.837113f,0.0941878f, --0.51696f,0.855065f,0.0401927f, --0.464195f,0.882878f,0.0710582f, --0.339798f,0.923706f,0.176929f, --0.307071f,0.929998f,0.202016f, --0.435636f,0.887155f,0.152245f, --0.50925f,0.856289f,0.0862179f, --0.352613f,0.935762f,-0.00363908f, --0.24432f,0.969666f,0.0074465f, --0.223693f,0.974193f,-0.0301471f, -0.0924619f,0.993171f,0.071143f, -0.248444f,0.955155f,0.161104f, -0.25541f,0.957577f,0.133462f, -0.152224f,0.983188f,-0.100846f, -0.175485f,0.954332f,-0.241774f, -0.229817f,0.96697f,-0.110245f, -0.104087f,0.990176f,0.0933667f, --0.0251916f,0.99085f,0.132593f, -0.0299952f,0.999356f,-0.0197015f, -0.374506f,0.927216f,-0.00387803f, -0.523769f,0.851516f,-0.0242066f, -0.412003f,0.903869f,-0.115217f, -0.44751f,0.89427f,-0.00401492f, -0.502351f,0.864643f,-0.0060566f, -0.261187f,0.953407f,-0.150988f, -0.201827f,0.974066f,-0.102283f, -0.328474f,0.941424f,-0.0763319f, -0.327281f,0.932573f,-0.152297f, -0.312159f,0.927432f,-0.205977f, -0.304739f,0.922289f,-0.237734f, -0.291399f,0.941708f,-0.168142f, -0.325323f,0.94222f,-0.0799213f, -0.270502f,0.962573f,-0.0167793f, --0.00135827f,0.998382f,0.0568385f, --0.0464612f,0.993882f,0.100202f, --0.163616f,0.983349f,-0.0790802f, --0.219372f,0.956704f,-0.191292f, --0.0798083f,0.976764f,-0.198904f, --0.0362508f,0.993161f,-0.11098f, --0.194493f,0.976824f,0.0893684f, --0.303508f,0.929002f,0.211751f, --0.120982f,0.967912f,0.220249f, --0.126864f,0.979558f,0.156117f, --0.190168f,0.969475f,0.154773f, -0.442277f,0.894635f,0.0633978f, -0.351901f,0.932017f,0.0866602f, -0.271089f,0.951246f,0.147111f, -0.263373f,0.940704f,0.2138f, -0.0780789f,0.961317f,0.264145f, --0.165165f,0.972713f,0.162944f, -0.054241f,0.96435f,0.259011f, -0.119009f,0.928226f,0.352467f, -0.062551f,0.905107f,0.420558f, --0.0376962f,0.903166f,0.427633f, --0.119235f,0.864868f,0.487634f, --0.107099f,0.89512f,0.43277f, --0.228241f,0.933808f,0.275515f, --0.34367f,0.891778f,0.294319f, --0.360994f,0.863066f,0.353271f, --0.329935f,0.870805f,0.364474f, --0.225803f,0.873787f,0.430708f, --0.324138f,0.85889f,0.396537f, --0.511071f,0.812187f,0.281352f, --0.475013f,0.824987f,0.306202f, --0.392033f,0.887928f,0.240612f, --0.45534f,0.876633f,0.155499f, --0.547025f,0.829694f,0.111226f, --0.496064f,0.862275f,0.101992f, --0.479515f,0.87606f,0.0508306f, --0.424535f,0.90465f,0.0371277f, --0.362147f,0.919497f,0.152886f, --0.412742f,0.878092f,0.24207f, --0.402299f,0.893898f,0.197745f, --0.26297f,0.963672f,0.0467231f, --0.219075f,0.975598f,-0.0146319f, --0.186267f,0.980099f,-0.0686323f, --0.0357984f,0.992879f,-0.113625f, -0.180598f,0.983509f,0.00973344f, -0.28459f,0.957748f,0.0415635f, -0.350884f,0.934731f,0.0561944f, -0.201029f,0.975728f,-0.0868401f, -0.10163f,0.994331f,-0.0312587f, --0.0498772f,0.998294f,0.0303674f, -0.0144565f,0.996475f,0.082632f, -0.17671f,0.984206f,0.0105968f, -0.384098f,0.921983f,-0.049144f, -0.526508f,0.848767f,-0.048829f, -0.451141f,0.890087f,-0.0649363f, -0.349978f,0.927792f,-0.129298f, -0.525028f,0.849511f,-0.051734f, -0.403316f,0.902994f,-0.148114f, -0.146493f,0.950082f,-0.275472f, -0.257494f,0.953663f,-0.155639f, -0.363336f,0.930153f,-0.0529431f, -0.407301f,0.911128f,-0.0628641f, -0.309341f,0.935596f,-0.170201f, -0.234661f,0.952473f,-0.194238f, -0.248922f,0.950735f,-0.18477f, -0.176271f,0.982701f,-0.0568089f, --0.0817466f,0.996475f,0.0188703f, --0.0390696f,0.99855f,0.0370285f, -0.0392849f,0.997614f,0.0567754f, --0.165147f,0.985538f,-0.0379532f, --0.216905f,0.97598f,0.020392f, --0.25871f,0.942954f,0.209538f, --0.318314f,0.87576f,0.362933f, --0.238112f,0.92993f,0.280235f, --0.11178f,0.963059f,0.244995f, --0.156033f,0.939968f,0.303502f, --0.219558f,0.904757f,0.364977f, -0.29059f,0.953077f,-0.0848643f, -0.282679f,0.959209f,-0.00326087f, -0.165956f,0.986031f,0.0141778f, -0.145774f,0.971701f,0.185869f, -0.0971539f,0.92606f,0.364656f, --0.126893f,0.938591f,0.320851f, --0.158756f,0.918948f,0.361014f, -0.0576791f,0.877286f,0.47649f, -0.151465f,0.884095f,0.442079f, --0.0842052f,0.912347f,0.400665f, --0.236928f,0.870703f,0.430978f, --0.0173538f,0.858153f,0.513101f, --0.0453547f,0.868839f,0.493013f, --0.308698f,0.88215f,0.355692f, --0.391959f,0.868398f,0.303732f, --0.360504f,0.877037f,0.317558f, --0.289644f,0.88703f,0.359561f, --0.323579f,0.85156f,0.412484f, --0.483914f,0.781191f,0.39442f, --0.428744f,0.813324f,0.393297f, --0.337017f,0.871068f,0.357294f, --0.382215f,0.837599f,0.390306f, --0.472752f,0.816976f,0.330237f, --0.454132f,0.848356f,0.272131f, --0.386129f,0.879637f,0.277745f, --0.408175f,0.895196f,0.178931f, --0.461039f,0.873474f,0.15648f, --0.444429f,0.876284f,0.186035f, --0.324725f,0.941951f,0.085336f, --0.200261f,0.979518f,0.0209972f, --0.146655f,0.98862f,0.0335086f, --0.105669f,0.986512f,-0.125016f, --0.0113758f,0.977088f,-0.21253f, -0.125756f,0.969156f,-0.211948f, -0.231535f,0.947003f,-0.222657f, -0.267937f,0.954488f,-0.131005f, -0.231299f,0.971277f,0.055871f, -0.0809071f,0.991774f,0.0991925f, -0.000207679f,0.999953f,0.00973996f, -0.0247831f,0.993578f,-0.110402f, -0.181304f,0.979201f,-0.0910725f, -0.390907f,0.919373f,-0.0441033f, -0.523664f,0.849877f,-0.0590321f, -0.487061f,0.873094f,-0.0218679f, -0.442794f,0.892691f,-0.0838822f, -0.486459f,0.850567f,-0.199735f, -0.449595f,0.886474f,-0.10967f, -0.172841f,0.979158f,-0.106661f, -0.134151f,0.987388f,-0.084069f, -0.292984f,0.955775f,-0.0255695f, -0.391346f,0.920229f,-0.00512785f, -0.418943f,0.907957f,0.00999318f, -0.324262f,0.936698f,-0.1321f, -0.190686f,0.957473f,-0.216527f, -0.0619887f,0.993289f,-0.097645f, --0.0829846f,0.99633f,-0.0209901f, --0.0646754f,0.997763f,-0.0169202f, --0.0614217f,0.996217f,0.0614677f, --0.189778f,0.963623f,0.188191f, --0.363861f,0.896503f,0.25276f, --0.348308f,0.859996f,0.372945f, --0.264506f,0.906439f,0.329249f, --0.140762f,0.939057f,0.31362f, --0.154941f,0.944783f,0.288752f, --0.237481f,0.904164f,0.355093f, --0.314839f,0.867723f,0.38462f, -0.199283f,0.97456f,-0.102566f, -0.290362f,0.956152f,-0.0382605f, -0.163603f,0.98144f,-0.10005f, --0.0845537f,0.992536f,-0.0878854f, --0.0995819f,0.988025f,0.117859f, --0.128698f,0.94862f,0.289062f, --0.181988f,0.934999f,0.304396f, -0.0121717f,0.953274f,0.301863f, -0.15771f,0.909532f,0.384551f, --0.030083f,0.904525f,0.425359f, --0.262213f,0.918561f,0.295788f, --0.150427f,0.932893f,0.327234f, --0.0433771f,0.888915f,0.456013f, --0.194904f,0.882492f,0.428042f, --0.359771f,0.865678f,0.348089f, --0.358104f,0.856009f,0.37284f, --0.334766f,0.853069f,0.400257f, --0.382047f,0.809514f,0.445788f, --0.440041f,0.772384f,0.458024f, --0.392897f,0.847233f,0.357532f, --0.352962f,0.862399f,0.362885f, --0.432462f,0.797784f,0.42014f, --0.40741f,0.807767f,0.426063f, --0.417686f,0.831448f,0.366378f, --0.406533f,0.835025f,0.370761f, --0.302917f,0.831265f,0.466089f, --0.354465f,0.85583f,0.376708f, --0.320875f,0.930472f,0.17681f, --0.210666f,0.977556f,0.00208309f, --0.202152f,0.976764f,-0.0711849f, --0.0734606f,0.993473f,-0.0872598f, -0.0104554f,0.979699f,-0.2002f, -0.0812548f,0.981491f,-0.173417f, -0.133484f,0.953074f,-0.271721f, -0.239226f,0.941558f,-0.23715f, -0.0986638f,0.979162f,-0.177504f, -0.0167662f,0.999807f,0.0102821f, -0.0608252f,0.989728f,0.129377f, -0.193478f,0.976369f,0.0962839f, -0.105893f,0.986391f,-0.125774f, -0.159018f,0.972139f,-0.17222f, -0.348199f,0.916375f,-0.197521f, -0.506641f,0.853561f,-0.121441f, -0.438954f,0.895697f,-0.0710352f, -0.508211f,0.861156f,-0.0114456f, -0.538629f,0.837641f,-0.0907543f, -0.350973f,0.934296f,-0.0625226f, -0.130826f,0.991364f,0.00901604f, -0.142249f,0.989581f,0.0222434f, -0.314713f,0.948656f,-0.0317428f, -0.413134f,0.902882f,-0.118849f, -0.421178f,0.889709f,-0.176143f, -0.40304f,0.897538f,-0.178843f, -0.190553f,0.961133f,-0.199782f, --0.0704956f,0.989551f,-0.125772f, --0.145721f,0.988685f,0.035603f, --0.158165f,0.979549f,0.124366f, --0.141884f,0.945197f,0.294061f, --0.282634f,0.89813f,0.336869f, --0.398539f,0.847577f,0.350398f, --0.326007f,0.891199f,0.31541f, --0.257935f,0.930645f,0.259558f, --0.189362f,0.933131f,0.305628f, --0.181998f,0.908713f,0.375656f, --0.284451f,0.857477f,0.428743f, --0.324962f,0.834267f,0.445419f, -0.162722f,0.967013f,-0.19598f, -0.196801f,0.96943f,-0.146541f, -0.171798f,0.98444f,0.0369126f, --0.0614366f,0.993745f,0.0932502f, --0.263807f,0.962515f,0.063023f, --0.262644f,0.943232f,0.203304f, --0.183229f,0.945939f,0.267632f, --0.0512022f,0.955564f,0.290302f, -0.0500709f,0.932925f,0.356571f, --0.017607f,0.930336f,0.366286f, --0.141345f,0.917863f,0.370876f, --0.196664f,0.921785f,0.334121f, --0.123639f,0.931227f,0.342826f, --0.166673f,0.929929f,0.327799f, --0.365314f,0.882118f,0.297345f, --0.422119f,0.842584f,0.334465f, --0.378137f,0.838603f,0.392119f, --0.433991f,0.800503f,0.413336f, --0.373446f,0.819157f,0.435339f, --0.321191f,0.877582f,0.35593f, --0.410179f,0.839146f,0.357194f, --0.450466f,0.792998f,0.410164f, --0.383405f,0.853385f,0.353178f, --0.361072f,0.88078f,0.306355f, --0.471517f,0.844691f,0.253315f, --0.399349f,0.852332f,0.337713f, --0.193735f,0.889811f,0.413163f, --0.0964184f,0.953204f,0.28654f, --0.0731968f,0.993583f,0.0862245f, --0.107213f,0.990087f,-0.0907379f, --0.0139207f,0.976637f,-0.214443f, --0.00517032f,0.976967f,-0.213328f, -0.032564f,0.990278f,-0.135238f, -0.193406f,0.974103f,-0.117123f, -0.137302f,0.989014f,-0.0547632f, -0.0149454f,0.997504f,0.06901f, --0.0673257f,0.995987f,0.0589639f, -0.00671915f,0.997834f,0.0654375f, -0.236496f,0.961793f,0.137925f, -0.296243f,0.953456f,0.0562338f, -0.227931f,0.966806f,-0.11547f, -0.392626f,0.909868f,-0.134105f, -0.455312f,0.880641f,-0.131003f, -0.402519f,0.906647f,-0.126375f, -0.459051f,0.879656f,-0.124406f, -0.531911f,0.846049f,-0.0356662f, -0.366681f,0.930218f,0.0155094f, -0.101768f,0.992829f,-0.0627213f, -0.169781f,0.984995f,-0.0309622f, -0.383193f,0.921183f,-0.0677109f, -0.483652f,0.86784f,-0.113728f, -0.481548f,0.864447f,-0.144373f, -0.322376f,0.925659f,-0.198063f, -0.121084f,0.992307f,-0.0257868f, --0.189201f,0.97803f,0.0875253f, --0.272481f,0.941614f,0.197779f, --0.28107f,0.929157f,0.240138f, --0.316277f,0.890261f,0.327726f, --0.284096f,0.875896f,0.389994f, --0.304764f,0.879665f,0.365114f, --0.295018f,0.913863f,0.278959f, --0.233864f,0.913909f,0.331779f, --0.25276f,0.886942f,0.386584f, --0.254968f,0.846261f,0.467797f, --0.324913f,0.811645f,0.485452f, --0.330966f,0.801562f,0.497956f, -0.166281f,0.984047f,-0.0632562f, -0.102172f,0.992786f,-0.0627485f, --0.0446214f,0.999004f,-0.000325965f, --0.137659f,0.980871f,0.13763f, --0.270041f,0.94552f,0.18185f, --0.300503f,0.932348f,0.201063f, --0.224552f,0.960314f,0.165452f, --0.109331f,0.978965f,0.17226f, -0.0684226f,0.972288f,0.223551f, --0.0281009f,0.965962f,0.257154f, --0.203983f,0.927334f,0.313757f, --0.170837f,0.935943f,0.307937f, --0.0844776f,0.951083f,0.29716f, --0.140439f,0.935294f,0.32481f, --0.360713f,0.879742f,0.309743f, --0.466354f,0.845167f,0.261162f, --0.425659f,0.859392f,0.283303f, --0.470194f,0.836884f,0.280256f, --0.410878f,0.856359f,0.312777f, --0.293557f,0.864483f,0.408036f, --0.429097f,0.81157f,0.396523f, --0.438172f,0.837036f,0.327683f, --0.303084f,0.911643f,0.277574f, --0.346895f,0.902405f,0.255594f, --0.444307f,0.857916f,0.258015f, --0.440123f,0.885255f,0.150386f, --0.246442f,0.965625f,0.0826743f, --0.0242341f,0.995753f,0.0888192f, -0.128537f,0.987977f,0.085905f, -0.10291f,0.993755f,-0.0431449f, -0.0280177f,0.986869f,-0.159076f, --0.0318503f,0.988236f,-0.149584f, -0.00777626f,0.97932f,-0.202168f, -0.111085f,0.970769f,-0.212762f, --0.00220326f,0.997417f,-0.0718009f, --0.0152092f,0.997571f,0.0679693f, -0.0100591f,0.998816f,0.0476033f, --0.00783919f,0.999851f,-0.0153546f, -0.1632f,0.986482f,-0.0148045f, -0.356551f,0.93118f,0.0760001f, -0.33409f,0.940767f,0.0578066f, -0.378555f,0.924836f,-0.0370621f, -0.481573f,0.874509f,-0.0576253f, -0.443664f,0.890369f,-0.102011f, -0.449245f,0.88434f,-0.126968f, -0.449063f,0.892098f,-0.05003f, -0.400085f,0.916232f,0.0212355f, -0.189459f,0.975149f,-0.114846f, -0.154225f,0.96178f,-0.226258f, -0.36559f,0.902984f,-0.225751f, -0.443305f,0.891814f,-0.0902669f, -0.481296f,0.876165f,0.0262584f, -0.274557f,0.96003f,0.0544047f, --0.0951468f,0.983236f,0.155547f, --0.272231f,0.920302f,0.280953f, --0.309095f,0.909629f,0.277553f, --0.260629f,0.904898f,0.336501f, --0.319906f,0.899874f,0.296456f, --0.309019f,0.910231f,0.275658f, --0.301457f,0.909911f,0.284931f, --0.289244f,0.908198f,0.302514f, --0.349317f,0.867088f,0.355157f, --0.355035f,0.811266f,0.46454f, --0.291879f,0.804435f,0.517388f, --0.292737f,0.815956f,0.498519f, --0.341117f,0.83204f,0.437434f, -0.012939f,0.999781f,0.0164623f, -0.101117f,0.986501f,0.12881f, --0.0315137f,0.991787f,0.123953f, --0.202813f,0.972667f,0.113078f, --0.267039f,0.954882f,0.129964f, --0.329248f,0.943109f,0.0462825f, --0.158801f,0.981787f,0.104294f, --0.0896983f,0.994441f,0.0551561f, --0.03797f,0.996172f,0.0787436f, --0.124773f,0.970658f,0.205561f, --0.242396f,0.92942f,0.278248f, --0.1236f,0.936757f,0.327428f, --0.115597f,0.950099f,0.289742f, --0.242269f,0.924532f,0.294187f, --0.335063f,0.873272f,0.353736f, --0.402827f,0.872268f,0.27727f, --0.433494f,0.882428f,0.182769f, --0.472347f,0.860126f,0.192541f, --0.516304f,0.829671f,0.212311f, --0.401557f,0.840095f,0.364681f, --0.365647f,0.853697f,0.370816f, --0.342203f,0.911984f,0.226234f, --0.319568f,0.928553f,0.188855f, --0.368607f,0.886665f,0.279203f, --0.401013f,0.885839f,0.233406f, --0.263462f,0.961384f,0.0795548f, --0.119336f,0.983737f,-0.134243f, --0.028348f,0.969034f,-0.245295f, -0.0404463f,0.983879f,-0.174201f, -0.11875f,0.992593f,0.0256534f, -0.0602272f,0.997166f,0.0450923f, -0.0340291f,0.999414f,-0.00366965f, -0.0708792f,0.992684f,-0.097743f, -0.0958935f,0.99395f,-0.0535485f, --0.0943801f,0.993296f,-0.0667466f, --0.119267f,0.988594f,-0.0919588f, -0.000759128f,0.999891f,-0.0147216f, -0.0724665f,0.997368f,-0.00256206f, -0.170906f,0.979948f,-0.10244f, -0.214916f,0.97339f,-0.079521f, -0.347938f,0.935698f,0.0583811f, -0.479062f,0.877734f,-0.00909944f, -0.517939f,0.850313f,-0.0933121f, -0.446396f,0.884197f,-0.137574f, -0.389313f,0.918353f,-0.0711587f, -0.410982f,0.908412f,0.0766878f, -0.41147f,0.910096f,0.0491837f, -0.356411f,0.933637f,-0.0359751f, -0.291892f,0.941315f,-0.169483f, -0.292525f,0.936947f,-0.191205f, -0.303478f,0.950202f,-0.0708325f, -0.350076f,0.936333f,0.0269695f, -0.186651f,0.94527f,0.26763f, --0.145022f,0.9031f,0.404201f, --0.257588f,0.88179f,0.395088f, --0.316433f,0.892435f,0.321607f, --0.301856f,0.895088f,0.328177f, --0.311714f,0.888624f,0.336427f, --0.275146f,0.879635f,0.387991f, --0.320358f,0.874704f,0.363681f, --0.312957f,0.856468f,0.410514f, --0.417707f,0.826376f,0.377656f, --0.402058f,0.821773f,0.403779f, --0.299174f,0.86271f,0.407708f, --0.252864f,0.886408f,0.387737f, --0.266831f,0.899401f,0.346235f, --0.121912f,0.980245f,-0.155747f, --0.0467045f,0.996241f,-0.0729522f, --0.0560423f,0.996609f,0.0602479f, --0.253613f,0.959854f,0.119832f, --0.17852f,0.958289f,0.223189f, --0.25091f,0.965294f,0.0724672f, --0.244405f,0.968888f,0.0390022f, --0.111828f,0.978686f,0.172245f, --0.104286f,0.963728f,0.245667f, --0.172657f,0.941673f,0.288863f, --0.302965f,0.917419f,0.257981f, --0.21274f,0.929075f,0.302592f, --0.0577232f,0.923128f,0.380136f, --0.183983f,0.930078f,0.31797f, --0.384056f,0.900387f,0.204463f, --0.327378f,0.913703f,0.240771f, --0.374063f,0.905896f,0.198566f, --0.504219f,0.846296f,0.17189f, --0.555467f,0.810974f,0.183786f, --0.456478f,0.86757f,0.197356f, --0.300554f,0.935674f,0.184881f, --0.295051f,0.948068f,0.118792f, --0.362387f,0.917821f,0.162113f, --0.440667f,0.875232f,0.199453f, --0.248631f,0.939944f,0.233854f, --0.0966352f,0.995188f,0.0161918f, -0.0243217f,0.996259f,-0.0829196f, -0.0213875f,0.994057f,-0.106741f, --0.13683f,0.98707f,-0.0834831f, --0.0593385f,0.994125f,0.0905282f, -0.0836318f,0.990077f,0.112932f, -0.079675f,0.993049f,0.0866394f, -0.0726138f,0.990126f,0.119908f, -0.0468689f,0.990824f,0.126776f, -0.00048966f,0.99587f,0.0907856f, --0.0299455f,0.998898f,-0.0361395f, --0.0528047f,0.988171f,-0.143981f, -0.0771474f,0.992034f,-0.0995875f, -0.233f,0.968973f,-0.0824758f, -0.215078f,0.967265f,-0.134683f, -0.299646f,0.93128f,-0.207193f, -0.500666f,0.844143f,-0.191721f, -0.5316f,0.838001f,-0.123112f, -0.45137f,0.888237f,-0.0854371f, -0.26295f,0.958984f,-0.105862f, -0.297072f,0.954855f,-0.000735176f, -0.467586f,0.880091f,0.0824758f, -0.451683f,0.892137f,0.00862833f, -0.280097f,0.955995f,-0.0872873f, -0.27353f,0.961001f,0.0407195f, -0.263182f,0.963734f,0.044184f, -0.22357f,0.970136f,0.0940863f, --0.055048f,0.955137f,0.291002f, --0.267739f,0.863744f,0.426921f, --0.199104f,0.857693f,0.474046f, --0.21681f,0.879018f,0.424642f, --0.270209f,0.885026f,0.379098f, --0.341336f,0.865644f,0.366267f, --0.32372f,0.861174f,0.391898f, --0.34092f,0.838889f,0.42431f, --0.295898f,0.818794f,0.491956f, --0.331f,0.829823f,0.449258f, --0.389842f,0.853312f,0.34624f, --0.281201f,0.9123f,0.297716f, --0.234572f,0.935622f,0.263795f, --0.225355f,0.942001f,0.248696f, --0.0486057f,0.996635f,-0.0660014f, --0.101682f,0.988174f,-0.114771f, --0.162649f,0.983215f,-0.0826606f, --0.318288f,0.946728f,-0.048975f, --0.258454f,0.965864f,-0.0175802f, --0.136613f,0.987862f,0.0739351f, --0.281595f,0.958211f,0.0503573f, --0.28706f,0.943479f,0.165663f, --0.148179f,0.930819f,0.334095f, --0.182832f,0.931383f,0.314798f, --0.242578f,0.923022f,0.298642f, --0.204404f,0.955935f,0.21073f, --0.142784f,0.976536f,0.161212f, --0.136962f,0.950722f,0.278153f, --0.274249f,0.920019f,0.279915f, --0.389723f,0.904453f,0.173436f, --0.370261f,0.901011f,0.226022f, --0.50377f,0.847021f,0.169619f, --0.52553f,0.835875f,0.158529f, --0.435894f,0.894864f,0.0959897f, --0.279872f,0.956869f,0.07793f, --0.331658f,0.940229f,0.0772765f, --0.372127f,0.91403f,0.161461f, --0.456876f,0.888328f,0.0462339f, --0.204408f,0.978272f,0.0346564f, -0.0554954f,0.998458f,-0.00157713f, --0.0102256f,0.999947f,0.00149442f, --0.0507499f,0.985345f,0.162848f, --0.124313f,0.970082f,0.208536f, --0.111836f,0.992788f,0.0431796f, -0.135986f,0.987999f,0.0732526f, -0.00980425f,0.997155f,0.0747439f, -0.00734776f,0.982792f,0.184568f, -0.0872171f,0.965097f,0.246944f, -0.0795152f,0.966423f,0.244345f, -0.106439f,0.984803f,0.137237f, -0.0584187f,0.998092f,-0.0199996f, -0.0370568f,0.991888f,-0.121591f, -0.199554f,0.972297f,-0.121727f, -0.308311f,0.945569f,-0.104131f, -0.399439f,0.904394f,-0.150064f, -0.468199f,0.870932f,-0.149223f, -0.412212f,0.907025f,-0.0859413f, -0.425915f,0.903304f,0.0513667f, -0.351639f,0.936099f,-0.00832492f, -0.20857f,0.966693f,-0.148333f, -0.395551f,0.918183f,0.0219088f, -0.538432f,0.838724f,0.0814483f, -0.24402f,0.966591f,-0.0784634f, -0.178953f,0.981938f,0.0614245f, -0.258979f,0.960241f,0.104243f, -0.0759782f,0.986383f,0.145865f, --0.19655f,0.929601f,0.311786f, --0.328358f,0.883678f,0.333607f, --0.21216f,0.920721f,0.327507f, --0.208125f,0.923292f,0.322823f, --0.300181f,0.87973f,0.368737f, --0.312111f,0.847974f,0.428401f, --0.324858f,0.873038f,0.363693f, --0.410275f,0.846963f,0.338124f, --0.346514f,0.853308f,0.389607f, --0.303825f,0.86928f,0.389926f, --0.270707f,0.881074f,0.387848f, --0.213937f,0.928705f,0.302885f, --0.20202f,0.939889f,0.275312f, --0.214102f,0.943299f,0.253667f, --0.0402111f,0.999126f,0.011392f, --0.0458289f,0.99894f,0.00442323f, --0.170695f,0.984267f,-0.0456311f, --0.29333f,0.955986f,-0.00691228f, --0.274679f,0.961535f,-0.00118788f, --0.240876f,0.970372f,-0.0188751f, --0.335158f,0.942005f,0.0172014f, --0.387782f,0.921031f,0.0364391f, --0.254694f,0.964339f,0.0719752f, --0.156383f,0.970864f,0.181569f, --0.223749f,0.957301f,0.183063f, --0.122594f,0.972034f,0.200303f, --0.0910709f,0.976799f,0.193828f, --0.28429f,0.950625f,0.124466f, --0.315477f,0.924742f,0.212902f, --0.305454f,0.925312f,0.224713f, --0.365063f,0.920836f,0.137077f, --0.474911f,0.873286f,0.108772f, --0.523018f,0.843362f,0.123259f, --0.405348f,0.903149f,0.141474f, --0.272593f,0.953587f,0.127925f, --0.342778f,0.935924f,0.0809316f, --0.402631f,0.912044f,0.0778773f, --0.324862f,0.935409f,0.139553f, --0.213356f,0.97623f,0.0381383f, -0.0301299f,0.998064f,0.0544045f, --0.104927f,0.992798f,0.0578138f, --0.261101f,0.959724f,0.103713f, --0.0217785f,0.964552f,0.262994f, -0.0803134f,0.988499f,0.128142f, -0.028164f,0.998669f,0.043203f, --0.0183001f,0.984341f,0.175323f, --0.0612635f,0.982917f,0.173556f, --0.0331225f,0.977326f,0.209135f, -0.0728156f,0.957515f,0.279039f, -0.245559f,0.942697f,0.225881f, -0.183786f,0.974714f,0.127102f, -0.141547f,0.988409f,0.0548866f, -0.245636f,0.968932f,-0.0288843f, -0.304552f,0.94926f,-0.0784495f, -0.340339f,0.936344f,-0.0861948f, -0.460805f,0.886321f,0.0457651f, -0.380493f,0.924294f,0.030084f, -0.352595f,0.93478f,0.0431689f, -0.472573f,0.87479f,0.106851f, -0.264087f,0.962772f,-0.057695f, -0.234368f,0.968348f,-0.0858683f, -0.503248f,0.863251f,0.0392276f, -0.302957f,0.950423f,0.0700943f, -0.0199528f,0.999731f,0.0118377f, -0.239816f,0.960125f,0.143695f, --0.0259597f,0.9852f,0.16943f, --0.288371f,0.907451f,0.305574f, --0.301113f,0.913287f,0.274296f, --0.184882f,0.952263f,0.242927f, --0.251998f,0.931999f,0.260528f, --0.398011f,0.856633f,0.32828f, --0.335641f,0.851294f,0.403292f, --0.239383f,0.893387f,0.380205f, --0.388171f,0.875539f,0.287671f, --0.364652f,0.897686f,0.247364f, --0.31107f,0.908317f,0.279636f, --0.277708f,0.915298f,0.291733f, --0.164862f,0.947448f,0.274159f, --0.18884f,0.953184f,0.236178f, --0.183001f,0.960107f,0.211435f, --0.0382166f,0.998778f,0.0313295f, --0.025601f,0.999566f,0.0145695f, --0.151993f,0.98817f,-0.0204673f, --0.361566f,0.932093f,-0.021731f, --0.304279f,0.951825f,0.0379804f, --0.164708f,0.984119f,0.0661845f, --0.289794f,0.954555f,-0.0695987f, --0.339732f,0.933497f,-0.114741f, --0.304944f,0.945342f,-0.115492f, --0.266385f,0.963249f,-0.0345067f, --0.261205f,0.96511f,0.0183122f, --0.220073f,0.973176f,0.06706f, --0.108437f,0.981443f,0.158152f, --0.188668f,0.971426f,0.143996f, --0.373149f,0.923277f,0.0912126f, --0.308957f,0.927563f,0.210174f, --0.302984f,0.922237f,0.240167f, --0.457665f,0.867903f,0.193102f, --0.548023f,0.825328f,0.136032f, --0.407198f,0.903776f,0.131829f, --0.253292f,0.959077f,0.126545f, --0.271541f,0.948088f,0.165511f, --0.43428f,0.889355f,0.142997f, --0.382973f,0.89965f,0.20967f, --0.169509f,0.965022f,0.199998f, -0.00160887f,0.982078f,0.188467f, --0.0137168f,0.977172f,0.212005f, --0.230009f,0.971053f,0.0644371f, --0.165502f,0.985539f,0.036359f, -0.129892f,0.967237f,0.218131f, -0.0422409f,0.973374f,0.225299f, --0.105762f,0.968925f,0.223604f, --0.0226547f,0.965849f,0.258115f, -0.0138374f,0.990856f,0.134211f, -0.0309349f,0.998739f,0.0395399f, -0.294589f,0.940971f,0.166706f, -0.248856f,0.959421f,0.132596f, -0.181153f,0.982002f,0.053445f, -0.283788f,0.958737f,0.0169453f, -0.366617f,0.930251f,-0.0149969f, -0.332578f,0.93839f,-0.0938972f, -0.358957f,0.931691f,-0.0557027f, -0.429022f,0.901938f,0.0494683f, -0.332897f,0.942781f,-0.0185381f, -0.429131f,0.903242f,-0.000810457f, -0.405301f,0.91403f,-0.0167607f, -0.256936f,0.958211f,-0.12576f, -0.354456f,0.935063f,-0.00433271f, -0.385431f,0.888673f,0.248403f, -0.0742527f,0.992531f,0.0967874f, -0.121836f,0.985927f,0.11447f, --0.100545f,0.965192f,0.241444f, --0.337975f,0.881899f,0.328674f, --0.242866f,0.922974f,0.298555f, --0.185171f,0.940279f,0.285633f, --0.313033f,0.906226f,0.28419f, --0.448562f,0.843983f,0.294082f, --0.356046f,0.888609f,0.289144f, --0.196811f,0.931399f,0.306206f, --0.298585f,0.916744f,0.265384f, --0.410663f,0.894937f,0.17448f, --0.325435f,0.90586f,0.271126f, --0.301755f,0.928362f,0.216998f, --0.109278f,0.952007f,0.285903f, --0.14523f,0.965578f,0.215795f, --0.139372f,0.971047f,0.194018f, -0.00163448f,0.997617f,0.0689798f, -0.026224f,0.998835f,0.04051f, --0.128032f,0.991559f,-0.0204567f, --0.309968f,0.948873f,-0.0596736f, --0.340105f,0.924291f,-0.173245f, --0.190965f,0.977348f,-0.0912302f, --0.146645f,0.988782f,-0.028384f, --0.31072f,0.935549f,-0.167929f, --0.380234f,0.90209f,-0.204096f, --0.300275f,0.945729f,-0.124224f, --0.302914f,0.945705f,-0.117837f, --0.237161f,0.970049f,-0.0525309f, --0.165718f,0.984724f,-0.0534418f, --0.190643f,0.98063f,0.0449474f, --0.411915f,0.909141f,0.0615588f, --0.453396f,0.88136f,0.1328f, --0.362905f,0.886473f,0.287169f, --0.380477f,0.872742f,0.305874f, --0.476636f,0.866585f,0.147809f, --0.366115f,0.923073f,0.117878f, --0.278065f,0.952821f,0.121709f, --0.370509f,0.910147f,0.18535f, --0.442894f,0.857435f,0.26201f, --0.347292f,0.915122f,0.204794f, --0.111317f,0.983727f,0.141034f, --0.00583658f,0.989977f,0.14111f, -0.00293304f,0.989031f,0.147679f, --0.0932614f,0.992658f,0.0770272f, --0.209442f,0.977765f,-0.0104574f, --0.0521744f,0.996134f,0.0706788f, -0.0111918f,0.977173f,0.21215f, --0.0985288f,0.958328f,0.268141f, -0.0097532f,0.972945f,0.23083f, -0.214151f,0.960047f,0.180136f, -0.0316331f,0.999392f,0.014672f, -0.114623f,0.990459f,0.0765015f, -0.302992f,0.926463f,0.223298f, -0.283203f,0.948444f,0.142303f, -0.315435f,0.948621f,0.0248881f, -0.37741f,0.92565f,0.0270755f, -0.401819f,0.915069f,0.0345122f, -0.321768f,0.943567f,-0.0784028f, -0.371664f,0.926589f,-0.0574381f, -0.394659f,0.917373f,-0.0516908f, -0.434962f,0.894125f,-0.106531f, -0.447382f,0.892016f,-0.0644733f, -0.241542f,0.966428f,-0.0876093f, -0.127706f,0.991493f,-0.0251536f, -0.250404f,0.953051f,0.170269f, -0.250954f,0.937023f,0.242919f, --0.000559693f,0.986358f,0.164614f, --0.211006f,0.922632f,0.32284f, --0.34675f,0.881023f,0.321811f, --0.216454f,0.925604f,0.310492f, --0.177379f,0.942447f,0.283426f, --0.307121f,0.917748f,0.251824f, --0.427987f,0.86998f,0.244872f, --0.348579f,0.908707f,0.229659f, --0.214211f,0.945769f,0.244201f, --0.272299f,0.924949f,0.265184f, --0.413173f,0.878684f,0.239168f, --0.359354f,0.883418f,0.300728f, --0.292273f,0.892332f,0.343978f, --0.146355f,0.897543f,0.415929f, --0.0984727f,0.903088f,0.418013f, --0.114958f,0.888054f,0.445134f, -0.0486539f,0.997583f,-0.0496084f, -0.0486095f,0.995772f,-0.0779487f, --0.0727955f,0.994312f,-0.0777426f, --0.222675f,0.967501f,-0.119823f, --0.286744f,0.93984f,-0.185682f, --0.296641f,0.937378f,-0.182555f, --0.219022f,0.967026f,-0.12996f, --0.147314f,0.984117f,-0.0990538f, --0.3428f,0.902622f,-0.26031f, --0.347893f,0.908635f,-0.230983f, --0.327008f,0.925901f,-0.189136f, --0.254527f,0.952486f,-0.167289f, --0.228332f,0.958887f,-0.168522f, --0.287734f,0.955666f,-0.0625468f, --0.451431f,0.892304f,0.00185963f, --0.510909f,0.851571f,0.11747f, --0.434919f,0.884052f,0.171166f, --0.355658f,0.920763f,0.16032f, --0.392075f,0.91242f,0.117331f, --0.40418f,0.912194f,0.0673793f, --0.347001f,0.925636f,0.15096f, --0.406528f,0.883834f,0.231457f, --0.406378f,0.897555f,0.171031f, --0.271349f,0.960134f,0.0671726f, --0.0926357f,0.994526f,0.0483373f, --0.0156467f,0.998994f,0.0420269f, -0.00801384f,0.999533f,0.0295044f, --0.0412004f,0.995482f,0.0855485f, --0.171347f,0.982792f,0.068987f, --0.142796f,0.988044f,0.0581328f, --0.101871f,0.981247f,0.163632f, --0.103189f,0.979569f,0.172615f, -0.0761964f,0.994828f,0.0671726f, -0.210538f,0.977574f,0.00485915f, -0.123577f,0.988892f,0.0825912f, -0.0553491f,0.995759f,0.0734865f, -0.223203f,0.966768f,0.124662f, -0.344575f,0.927512f,0.144881f, -0.388873f,0.91351f,0.119485f, -0.324349f,0.942843f,0.0764535f, -0.411999f,0.8978f,0.155603f, -0.440079f,0.892774f,0.0963553f, -0.378616f,0.925121f,-0.0283174f, -0.428515f,0.90345f,-0.0123871f, -0.429626f,0.902172f,-0.0388249f, -0.396609f,0.917987f,-0.000717735f, -0.233551f,0.972137f,-0.020091f, -0.111169f,0.993801f,0.000982701f, -0.115357f,0.993291f,0.00809163f, -0.164275f,0.973308f,0.160266f, --0.0349159f,0.947849f,0.316803f, --0.267423f,0.890391f,0.368361f, --0.327503f,0.90805f,0.261125f, --0.196107f,0.942247f,0.271499f, --0.118776f,0.949723f,0.289686f, --0.296931f,0.925681f,0.234405f, --0.445051f,0.862967f,0.239201f, --0.335704f,0.917243f,0.2144f, --0.25181f,0.948438f,0.1925f, --0.329983f,0.903347f,0.274f, --0.391867f,0.838521f,0.378579f, --0.417038f,0.817641f,0.396917f, --0.341558f,0.812981f,0.471594f, --0.188106f,0.834488f,0.517925f, --0.137025f,0.804598f,0.577794f, --0.18711f,0.76127f,0.620852f, -0.138194f,0.960364f,-0.242082f, -0.0401358f,0.96162f,-0.271434f, --0.076195f,0.979732f,-0.185256f, --0.203103f,0.960439f,-0.190543f, --0.267864f,0.941416f,-0.2049f, --0.261748f,0.936741f,-0.232388f, --0.231434f,0.930091f,-0.285254f, --0.126583f,0.962607f,-0.239509f, --0.258776f,0.934905f,-0.242872f, --0.430322f,0.876496f,-0.215819f, --0.353956f,0.929119f,-0.107016f, --0.27861f,0.956787f,-0.0832819f, --0.250796f,0.967007f,-0.0447179f, --0.348257f,0.937394f,-0.0030026f, --0.497787f,0.866258f,0.0424905f, --0.584411f,0.803193f,0.115522f, --0.394257f,0.905213f,0.158588f, --0.343138f,0.935038f,0.0892179f, --0.380878f,0.917442f,0.115034f, --0.389256f,0.914513f,0.11021f, --0.431967f,0.895633f,0.10605f, --0.414636f,0.893675f,0.171528f, --0.300214f,0.948969f,0.0965901f, --0.20281f,0.978452f,-0.0387339f, --0.123855f,0.987388f,-0.098611f, --0.0140563f,0.999899f,0.0019046f, --0.052066f,0.991601f,0.118388f, --0.0936165f,0.973604f,0.208163f, --0.149626f,0.978491f,0.142013f, --0.198198f,0.970011f,0.140699f, --0.130637f,0.968649f,0.211313f, -0.013631f,0.991214f,0.131563f, -0.20118f,0.979295f,0.0225449f, -0.231889f,0.971935f,-0.0396138f, -0.0131145f,0.999014f,-0.0424166f, -0.0264969f,0.999403f,0.0221517f, -0.210411f,0.977103f,0.0315571f, -0.327081f,0.943965f,0.0441437f, -0.381166f,0.920813f,0.0825546f, -0.346088f,0.933621f,0.0925967f, -0.356105f,0.932513f,0.0600724f, -0.479238f,0.87232f,0.0968908f, -0.446186f,0.89276f,0.062428f, -0.391504f,0.920172f,-0.00287489f, -0.426134f,0.9041f,0.0318405f, -0.417296f,0.907685f,0.0444148f, -0.286592f,0.957965f,0.012947f, -0.07628f,0.996621f,-0.030475f, -0.0820652f,0.99629f,0.0259114f, --0.0280556f,0.994071f,0.105053f, --0.213977f,0.933546f,0.287585f, --0.245374f,0.890565f,0.382995f, --0.189692f,0.923736f,0.332759f, --0.238316f,0.94737f,0.213765f, --0.176209f,0.945132f,0.275092f, --0.265622f,0.907592f,0.32515f, --0.420635f,0.873046f,0.246691f, --0.275407f,0.930254f,0.242441f, --0.273955f,0.921146f,0.276474f, --0.415501f,0.828882f,0.374585f, --0.488833f,0.76092f,0.426664f, --0.43149f,0.76785f,0.473522f, --0.33634f,0.787599f,0.516297f, --0.228347f,0.790629f,0.568123f, --0.231089f,0.763668f,0.602835f, --0.28515f,0.752352f,0.593849f, -0.109283f,0.926796f,-0.359314f, --0.0105223f,0.944186f,-0.329244f, --0.147017f,0.945286f,-0.29124f, --0.202823f,0.935685f,-0.288714f, --0.214861f,0.941374f,-0.260095f, --0.2356f,0.926477f,-0.293483f, --0.224333f,0.941495f,-0.251519f, --0.230404f,0.948768f,-0.216226f, --0.277442f,0.956386f,-0.0913908f, --0.472179f,0.876647f,-0.0923929f, --0.428177f,0.898465f,-0.0970806f, --0.3387f,0.938243f,-0.0705803f, --0.291725f,0.956079f,0.0284457f, --0.399526f,0.915525f,0.0468393f, --0.527082f,0.845186f,0.0885769f, --0.577694f,0.815576f,0.0332458f, --0.408723f,0.912647f,0.00457497f, --0.331162f,0.938989f,0.0929031f, --0.4185f,0.893481f,0.162938f, --0.372755f,0.902119f,0.217335f, --0.419905f,0.891761f,0.168648f, --0.426162f,0.889671f,0.163929f, --0.238048f,0.949403f,0.20486f, --0.0631417f,0.981494f,0.180781f, --0.0934621f,0.991987f,0.0850084f, --0.209815f,0.971464f,0.110612f, --0.239382f,0.928806f,0.282871f, --0.0385152f,0.924665f,0.378829f, --0.0229585f,0.976683f,0.213458f, --0.204415f,0.977814f,0.0457583f, --0.131276f,0.991302f,0.00937849f, -0.100844f,0.99484f,0.0110965f, -0.227419f,0.973508f,-0.0237273f, -0.22975f,0.97307f,0.0187244f, -0.0718328f,0.997222f,0.0197173f, -0.0214849f,0.994143f,-0.105917f, -0.174121f,0.982096f,-0.0718949f, -0.303053f,0.952921f,0.010044f, -0.38012f,0.924935f,0.00218727f, -0.364895f,0.929903f,-0.0461611f, -0.383009f,0.921386f,-0.0659776f, -0.441676f,0.895702f,-0.0513817f, -0.484548f,0.87476f,0.00284626f, -0.413676f,0.910113f,-0.0237944f, -0.449057f,0.893501f,-0.00212143f, -0.360983f,0.928147f,-0.090746f, -0.274993f,0.958661f,0.0731286f, -0.0881261f,0.984394f,0.15232f, -0.00584658f,0.984704f,0.174138f, --0.113749f,0.971528f,0.207834f, --0.320112f,0.923512f,0.211313f, --0.308899f,0.921582f,0.23509f, --0.147069f,0.956187f,0.253135f, --0.14137f,0.959806f,0.242461f, --0.277438f,0.935166f,0.220209f, --0.254545f,0.906523f,0.336782f, --0.385464f,0.89189f,0.236535f, --0.346902f,0.887297f,0.303913f, --0.404152f,0.809818f,0.425271f, --0.45263f,0.705418f,0.545446f, --0.436346f,0.733679f,0.520882f, --0.40606f,0.758487f,0.509719f, --0.399991f,0.76519f,0.504471f, --0.29927f,0.789873f,0.535292f, --0.216265f,0.823324f,0.524754f, --0.25441f,0.854784f,0.452349f, --0.0876585f,0.974972f,-0.204317f, --0.064531f,0.993199f,-0.096908f, --0.142906f,0.98657f,-0.0790982f, --0.190225f,0.979959f,-0.0591132f, --0.245075f,0.966633f,-0.0745641f, --0.286525f,0.954682f,-0.0805399f, --0.302328f,0.953201f,0.00253574f, --0.315251f,0.947498f,0.0535207f, --0.363913f,0.92013f,0.144666f, --0.433014f,0.884677f,0.172759f, --0.39903f,0.904384f,0.151207f, --0.340877f,0.927749f,0.15194f, --0.34367f,0.933336f,0.103799f, --0.371228f,0.927804f,0.0370044f, --0.540653f,0.838686f,-0.0655789f, --0.541683f,0.840171f,-0.0263209f, --0.443789f,0.895468f,-0.0344719f, --0.446175f,0.894923f,0.00646964f, --0.489716f,0.870366f,0.0513954f, --0.393228f,0.91623f,0.0767741f, --0.386844f,0.914535f,0.118231f, --0.456614f,0.881467f,0.1205f, --0.291641f,0.939064f,0.181947f, --0.0983466f,0.949337f,0.298474f, --0.0663966f,0.917799f,0.391455f, --0.225097f,0.912905f,0.340494f, --0.270333f,0.917625f,0.291349f, --0.0378823f,0.963845f,0.263756f, -0.203246f,0.94956f,0.238803f, --0.00658121f,0.998329f,0.057403f, --0.104339f,0.991332f,-0.0798442f, -0.0714998f,0.99184f,-0.105548f, -0.229254f,0.968801f,-0.0941692f, -0.162963f,0.980447f,-0.110304f, -0.144794f,0.987619f,-0.0603599f, -0.1028f,0.982727f,-0.153883f, -0.103742f,0.981824f,-0.158931f, -0.242509f,0.962807f,-0.119129f, -0.409757f,0.908112f,-0.0862081f, -0.420763f,0.899369f,-0.118717f, -0.356993f,0.920491f,-0.158908f, -0.417923f,0.902816f,-0.101306f, -0.45294f,0.886743f,-0.0923743f, -0.388277f,0.919595f,-0.0598771f, -0.442705f,0.896663f,-0.00260706f, -0.330753f,0.943188f,0.0316099f, -0.0976556f,0.983098f,0.154858f, --0.0408134f,0.964902f,0.259421f, --0.0353778f,0.920067f,0.39016f, --0.0336634f,0.909873f,0.413518f, --0.27131f,0.928078f,0.255075f, --0.276299f,0.942343f,0.188808f, --0.178846f,0.97249f,0.149254f, --0.173925f,0.95192f,0.252185f, --0.312455f,0.905292f,0.287781f, --0.299358f,0.905887f,0.299588f, --0.361522f,0.88183f,0.302783f, --0.474485f,0.805519f,0.35497f, --0.514467f,0.728892f,0.451708f, --0.495653f,0.729457f,0.471404f, --0.395267f,0.75904f,0.517322f, --0.414244f,0.765988f,0.491594f, --0.375453f,0.800102f,0.467837f, --0.23686f,0.857078f,0.457509f, --0.153599f,0.897001f,0.414483f, --0.139778f,0.900978f,0.410733f, --0.246424f,0.968956f,-0.0200009f, --0.187575f,0.975459f,0.115309f, --0.169324f,0.958565f,0.229092f, --0.227196f,0.942917f,0.243495f, --0.216356f,0.935609f,0.278972f, --0.279085f,0.916546f,0.286453f, --0.337088f,0.885038f,0.32106f, --0.317388f,0.891504f,0.323242f, --0.400555f,0.875243f,0.271117f, --0.420396f,0.865286f,0.273034f, --0.438864f,0.863369f,0.248983f, --0.296161f,0.903481f,0.309855f, --0.22181f,0.945018f,0.240296f, --0.217483f,0.959525f,0.178924f, --0.432196f,0.899705f,0.0611361f, --0.592514f,0.805005f,-0.029893f, --0.445437f,0.89528f,0.00770123f, --0.444106f,0.895735f,-0.0207082f, --0.441178f,0.89658f,-0.0387967f, --0.433316f,0.896401f,-0.0932815f, --0.448061f,0.893999f,-0.00273746f, --0.479681f,0.876222f,0.046264f, --0.38049f,0.918735f,0.105607f, --0.274091f,0.928692f,0.249812f, --0.115693f,0.919238f,0.37632f, --0.109076f,0.943601f,0.312601f, --0.183297f,0.969532f,0.162513f, --0.0200265f,0.998099f,0.0582807f, -0.217564f,0.969248f,0.114995f, -0.107422f,0.986137f,0.126469f, --0.0101958f,0.999802f,0.0170616f, -0.0917708f,0.993871f,-0.0616322f, -0.259886f,0.964354f,-0.049807f, -0.22181f,0.965636f,-0.135454f, -0.11068f,0.965795f,-0.234499f, -0.156396f,0.962982f,-0.219561f, -0.0996902f,0.954613f,-0.28067f, -0.240821f,0.930419f,-0.276271f, -0.362585f,0.892287f,-0.268992f, -0.39828f,0.905306f,-0.147629f, -0.377219f,0.92249f,-0.0819651f, -0.379471f,0.918832f,-0.108391f, -0.428571f,0.902988f,-0.0306522f, -0.390587f,0.920304f,0.0219829f, -0.365451f,0.930816f,-0.00527733f, -0.226127f,0.963781f,0.141399f, --0.014879f,0.969939f,0.242893f, --0.0990439f,0.938525f,0.330697f, --0.160986f,0.911469f,0.37856f, --0.0311141f,0.900531f,0.433676f, --0.0818559f,0.904519f,0.418503f, --0.202897f,0.939947f,0.274469f, --0.199596f,0.951915f,0.232421f, --0.290928f,0.922977f,0.251942f, --0.30301f,0.91121f,0.279072f, --0.315746f,0.908229f,0.274635f, --0.386173f,0.858884f,0.336435f, --0.56045f,0.768828f,0.307894f, --0.529456f,0.742805f,0.409776f, --0.545227f,0.770059f,0.331265f, --0.460487f,0.804404f,0.375346f, --0.384041f,0.835484f,0.393038f, --0.366328f,0.856374f,0.363907f, --0.227066f,0.886912f,0.40228f, --0.162423f,0.896635f,0.411903f, --0.18398f,0.877261f,0.443356f, --0.33059f,0.941987f,0.0580528f, --0.349053f,0.930827f,0.108275f, --0.250298f,0.937413f,0.242089f, --0.231173f,0.921233f,0.312871f, --0.267366f,0.883285f,0.385127f, --0.300638f,0.858727f,0.414975f, --0.348846f,0.869854f,0.348799f, --0.262698f,0.902187f,0.342122f, --0.319043f,0.887638f,0.33213f, --0.407631f,0.874264f,0.263628f, --0.391131f,0.891388f,0.229006f, --0.306387f,0.939971f,0.150271f, --0.172289f,0.969062f,0.176734f, --0.280735f,0.939942f,0.194158f, --0.35822f,0.876748f,0.320922f, --0.540223f,0.822439f,0.178196f, --0.415201f,0.897062f,0.151285f, --0.398489f,0.913332f,0.0838552f, --0.47388f,0.879024f,0.052479f, --0.430994f,0.889287f,0.153011f, --0.501585f,0.850518f,0.158213f, --0.493115f,0.843586f,0.212601f, --0.437044f,0.869936f,0.228482f, --0.335665f,0.928238f,0.160321f, --0.135997f,0.987913f,0.0743886f, -0.0115105f,0.995614f,0.0928467f, --0.0367985f,0.999249f,0.0121783f, -0.0254956f,0.996874f,-0.0747791f, -0.107382f,0.991622f,-0.0717932f, -0.144184f,0.989518f,0.00810907f, -0.0943487f,0.994079f,-0.0539027f, -0.124876f,0.987862f,-0.0923827f, -0.25534f,0.960035f,-0.114602f, -0.339105f,0.927956f,-0.154613f, -0.200588f,0.937015f,-0.285951f, -0.184172f,0.917658f,-0.352115f, -0.137125f,0.909076f,-0.393417f, -0.231522f,0.90798f,-0.349242f, -0.299652f,0.902049f,-0.310671f, -0.23061f,0.944613f,-0.233507f, -0.336481f,0.938772f,-0.0740748f, -0.38792f,0.918977f,-0.070704f, -0.337723f,0.938393f,-0.073227f, -0.392706f,0.919584f,-0.012147f, -0.294051f,0.954956f,-0.0399037f, -0.173344f,0.964432f,0.199555f, --0.108669f,0.967119f,0.22994f, --0.18728f,0.925976f,0.327863f, --0.156223f,0.937505f,0.310931f, --0.0961609f,0.948752f,0.301037f, --0.051031f,0.914222f,0.401987f, --0.116652f,0.921592f,0.370216f, --0.16747f,0.919727f,0.355044f, --0.233888f,0.917713f,0.321092f, --0.296558f,0.924646f,0.23892f, --0.384099f,0.898594f,0.212122f, --0.451252f,0.843433f,0.291535f, --0.561019f,0.766309f,0.313095f, --0.56702f,0.761029f,0.315156f, --0.502958f,0.815049f,0.287624f, --0.46769f,0.845823f,0.256612f, --0.438846f,0.860082f,0.260142f, --0.380472f,0.841841f,0.382812f, --0.286801f,0.84573f,0.449984f, --0.166497f,0.837941f,0.519744f, --0.237954f,0.844014f,0.480644f, --0.400938f,0.907575f,0.124721f, --0.36178f,0.91645f,0.170983f, --0.326178f,0.936068f,0.131852f, --0.348093f,0.925471f,0.149445f, --0.380521f,0.903785f,0.195901f, --0.261965f,0.932138f,0.249988f, --0.229009f,0.957451f,0.175621f, --0.296226f,0.953377f,0.0576446f, --0.385007f,0.916429f,0.109216f, --0.396898f,0.895963f,0.199304f, --0.30002f,0.927264f,0.223985f, --0.290512f,0.953204f,0.083697f, --0.240862f,0.959505f,0.146069f, --0.368638f,0.900621f,0.230189f, --0.437205f,0.833732f,0.337256f, --0.435531f,0.825298f,0.359438f, --0.382764f,0.869714f,0.311593f, --0.302351f,0.902083f,0.307944f, --0.504704f,0.84016f,0.198507f, --0.44412f,0.839306f,0.313565f, --0.494888f,0.841296f,0.217503f, --0.530329f,0.827106f,0.186138f, --0.314084f,0.933199f,0.174614f, --0.124034f,0.990967f,0.050983f, --0.0452003f,0.995178f,-0.0870557f, --0.00182424f,0.990385f,-0.138326f, --0.0388611f,0.986686f,-0.157927f, -0.0684221f,0.991564f,-0.11009f, -0.102533f,0.981475f,-0.161848f, -0.149983f,0.975213f,-0.162681f, -0.108711f,0.963953f,-0.24285f, -0.134579f,0.963238f,-0.232511f, -0.280754f,0.932346f,-0.227832f, -0.370391f,0.907723f,-0.197103f, -0.290987f,0.936165f,-0.197286f, -0.244643f,0.947659f,-0.205165f, -0.12819f,0.972148f,-0.196204f, -0.159014f,0.967422f,-0.197002f, -0.312607f,0.930748f,-0.189697f, -0.153027f,0.941997f,-0.298704f, -0.218578f,0.950985f,-0.218748f, -0.390534f,0.915543f,-0.0962525f, -0.350134f,0.933592f,-0.0762398f, -0.369694f,0.928637f,-0.030973f, -0.182224f,0.981373f,0.0608345f, --0.0452136f,0.980467f,0.191416f, --0.152401f,0.95767f,0.244216f, --0.205784f,0.951891f,0.22706f, --0.112228f,0.971017f,0.211022f, --0.130106f,0.967854f,0.215247f, --0.151633f,0.958079f,0.243087f, --0.104162f,0.953804f,0.281796f, --0.17561f,0.947845f,0.265989f, --0.209606f,0.941523f,0.263816f, --0.251275f,0.930745f,0.265659f, --0.361f,0.884718f,0.294879f, --0.50281f,0.813876f,0.291185f, --0.583247f,0.763934f,0.276094f, --0.556622f,0.802134f,0.216224f, --0.473532f,0.851987f,0.223352f, --0.473757f,0.85285f,0.219548f, --0.491496f,0.823107f,0.284477f, --0.477559f,0.793154f,0.377946f, --0.368868f,0.830921f,0.416542f, --0.202419f,0.861608f,0.465466f, --0.095407f,0.855544f,0.508864f, --0.40239f,0.909528f,0.104118f, --0.357524f,0.930915f,0.0746555f, --0.280797f,0.959558f,0.0200349f, --0.296463f,0.954936f,-0.0143765f, --0.381172f,0.918388f,-0.106166f, --0.308734f,0.946435f,-0.094572f, --0.184864f,0.981918f,-0.0407667f, --0.211096f,0.97426f,-0.0790985f, --0.431269f,0.892976f,-0.128847f, --0.508723f,0.860224f,-0.0348507f, --0.315588f,0.942693f,0.108326f, --0.229963f,0.954167f,0.191527f, --0.338476f,0.90391f,0.261495f, --0.399866f,0.843393f,0.358882f, --0.508212f,0.817205f,0.271838f, --0.45663f,0.829465f,0.321678f, --0.343829f,0.869846f,0.353765f, --0.25214f,0.908629f,0.332893f, --0.465924f,0.864347f,0.189262f, --0.451321f,0.885092f,0.11367f, --0.398038f,0.913426f,0.0849568f, --0.473433f,0.880353f,-0.0289816f, --0.282123f,0.951018f,-0.126376f, --0.111297f,0.983512f,-0.142537f, --0.0203568f,0.995748f,-0.089847f, -0.0177076f,0.998505f,-0.0517153f, --0.0210973f,0.999746f,0.00787929f, -0.0422415f,0.999104f,-0.00245387f, -0.162083f,0.986673f,-0.0143034f, -0.184873f,0.978111f,-0.0954998f, -0.225836f,0.960454f,-0.162869f, -0.105652f,0.960265f,-0.25832f, -0.22096f,0.965567f,-0.137321f, -0.306187f,0.951906f,0.0111556f, -0.252563f,0.963728f,0.0862585f, -0.185211f,0.975091f,0.122044f, -0.141716f,0.976503f,0.162355f, -0.200688f,0.976886f,0.0736112f, -0.398894f,0.916482f,0.0307355f, -0.27456f,0.96012f,-0.0527967f, -0.152825f,0.971043f,-0.183632f, -0.271211f,0.950001f,-0.154736f, -0.286301f,0.958137f,0.00244849f, -0.246502f,0.96458f,0.0939299f, -0.102065f,0.977178f,0.186298f, --0.0761105f,0.976837f,0.19999f, --0.0810786f,0.974651f,0.208524f, --0.174214f,0.975155f,0.136831f, --0.127689f,0.983595f,0.127422f, --0.123239f,0.988203f,0.0909257f, --0.173027f,0.984333f,0.033919f, --0.13019f,0.985916f,0.104975f, --0.151236f,0.977557f,0.146665f, --0.212082f,0.972216f,0.0990861f, --0.346196f,0.93167f,0.110181f, --0.461867f,0.845088f,0.269268f, --0.491314f,0.790968f,0.364663f, --0.499721f,0.798886f,0.334753f, --0.533877f,0.823302f,0.192741f, --0.489959f,0.855912f,0.165393f, --0.540105f,0.823669f,0.172786f, --0.55174f,0.789596f,0.268553f, --0.518837f,0.818462f,0.246838f, --0.35793f,0.879679f,0.31313f, --0.226645f,0.914368f,0.335505f, --0.174062f,0.93173f,0.31872f, --0.352372f,0.928926f,-0.113715f, --0.283164f,0.949292f,-0.13661f, --0.253833f,0.949289f,-0.185523f, --0.258433f,0.953837f,-0.152994f, --0.329686f,0.925665f,-0.185613f, --0.360482f,0.913899f,-0.186657f, --0.246398f,0.964945f,-0.0903879f, --0.197613f,0.98019f,0.013309f, --0.409684f,0.910684f,0.0530475f, --0.545574f,0.83677f,0.0465257f, --0.477964f,0.876264f,0.060934f, --0.386247f,0.882258f,0.269135f, --0.437443f,0.816448f,0.376904f, --0.381546f,0.830459f,0.405906f, --0.378931f,0.857772f,0.347329f, --0.484349f,0.854204f,0.189053f, --0.391934f,0.899277f,0.194136f, --0.180618f,0.947297f,0.264585f, --0.285059f,0.943094f,0.171219f, --0.41449f,0.905591f,-0.0900102f, --0.367364f,0.916679f,-0.157298f, --0.4046f,0.892318f,-0.200168f, --0.265207f,0.933534f,-0.241204f, --0.171437f,0.970625f,-0.168809f, --0.091648f,0.995789f,0.00231266f, --0.0988725f,0.989781f,0.102747f, --0.0749525f,0.978356f,0.192877f, -0.0618361f,0.988236f,0.139875f, -0.222758f,0.971067f,0.0860673f, -0.260459f,0.965435f,-0.00983276f, -0.296216f,0.954928f,-0.0191894f, -0.108089f,0.992937f,-0.0489145f, -0.0559635f,0.998425f,-0.00391097f, -0.182072f,0.980129f,0.0787236f, -0.189029f,0.972269f,0.137697f, -0.20292f,0.962368f,0.180751f, -0.162611f,0.977583f,0.133749f, -0.283117f,0.944546f,0.166365f, -0.362781f,0.917623f,0.162352f, -0.322808f,0.912852f,0.249991f, -0.306817f,0.930382f,0.200629f, -0.265368f,0.963264f,0.0412725f, -0.150516f,0.988588f,0.00624705f, -0.192187f,0.980013f,0.0513622f, -0.111093f,0.98864f,0.101236f, --0.0652663f,0.990994f,0.116922f, --0.0960853f,0.989279f,0.109972f, --0.171018f,0.980514f,0.0966674f, --0.118023f,0.981194f,0.152737f, --0.0297124f,0.980668f,0.19341f, --0.130364f,0.983461f,0.125733f, --0.228583f,0.970632f,0.0749913f, --0.187681f,0.973906f,0.127608f, --0.18184f,0.968481f,0.170233f, --0.382626f,0.904754f,0.187128f, --0.565004f,0.795638f,0.218473f, --0.54964f,0.808473f,0.210397f, --0.494188f,0.848001f,0.191501f, --0.42417f,0.88632f,0.185785f, --0.490729f,0.864039f,0.112346f, --0.547278f,0.819965f,0.167765f, --0.555649f,0.823683f,0.113141f, --0.525063f,0.850181f,0.0387426f, --0.465555f,0.881687f,0.0767294f, --0.25104f,0.948586f,0.19278f, --0.134177f,0.968986f,0.207515f, --0.358148f,0.879839f,-0.31243f, --0.281248f,0.911984f,-0.298639f, --0.261128f,0.923339f,-0.281526f, --0.281121f,0.935581f,-0.213678f, --0.316696f,0.928992f,-0.191515f, --0.378661f,0.908066f,-0.178974f, --0.357733f,0.923356f,-0.139433f, --0.295419f,0.953886f,0.0531873f, --0.456379f,0.869265f,0.18999f, --0.492836f,0.836159f,0.240731f, --0.533039f,0.832034f,0.153586f, --0.471339f,0.822176f,0.319166f, --0.417097f,0.817012f,0.398149f, --0.397475f,0.860419f,0.318894f, --0.295585f,0.889222f,0.349162f, --0.397825f,0.896297f,0.195927f, --0.426121f,0.903442f,0.0470364f, --0.225108f,0.967792f,0.11272f, --0.180332f,0.969123f,0.168172f, --0.283694f,0.958436f,-0.0303046f, --0.31011f,0.929142f,-0.201316f, --0.379988f,0.880118f,-0.284609f, --0.280631f,0.91033f,-0.304213f, --0.299273f,0.919298f,-0.255591f, --0.271669f,0.962178f,0.0202533f, --0.127278f,0.946024f,0.298058f, --0.0668081f,0.957542f,0.280447f, -0.156177f,0.962373f,0.222366f, -0.269377f,0.960799f,0.0655824f, -0.307217f,0.951527f,-0.0146071f, -0.247019f,0.968029f,-0.0436127f, -0.117286f,0.99106f,0.0635867f, -0.0498813f,0.996011f,0.0739844f, -0.194956f,0.980335f,0.0305971f, -0.139483f,0.989424f,-0.0398183f, -0.235447f,0.970519f,0.0515568f, -0.132445f,0.989845f,-0.05162f, -0.206421f,0.976844f,0.0562743f, -0.330371f,0.919083f,0.214804f, -0.266375f,0.922982f,0.277756f, -0.331232f,0.885792f,0.325049f, -0.36267f,0.895106f,0.259337f, -0.240431f,0.963714f,0.115964f, -0.171746f,0.982113f,-0.0771883f, -0.0351621f,0.99889f,-0.0313443f, --0.0882653f,0.987488f,0.130674f, --0.0658856f,0.986287f,0.151318f, --0.167193f,0.982329f,0.0841182f, --0.21476f,0.97234f,0.0918338f, --0.104496f,0.958461f,0.265392f, --0.0605561f,0.923444f,0.378926f, --0.152497f,0.949101f,0.275594f, --0.216118f,0.964594f,0.151167f, --0.26219f,0.945639f,0.192413f, --0.408309f,0.854572f,0.320922f, --0.530012f,0.797788f,0.28744f, --0.48417f,0.855541f,0.183383f, --0.504616f,0.863257f,0.012294f, --0.421367f,0.905956f,0.0411587f, --0.517653f,0.855189f,0.0262018f, --0.533316f,0.826853f,0.178574f, --0.514944f,0.854185f,0.0721125f, --0.506113f,0.861889f,-0.0315744f, --0.499639f,0.865958f,-0.0218358f, --0.302149f,0.952465f,0.038937f, --0.129933f,0.988738f,0.0742583f, -}; - -btScalar Landscape02Tex[] = { -0.0f,0.273438f, -0.0f,0.265625f, -0.0078125f,0.273438f, -0.0078125f,0.265625f, -0.015625f,0.273438f, -0.015625f,0.265625f, -0.0234375f,0.273438f, -0.0234375f,0.265625f, -0.03125f,0.273438f, -0.03125f,0.265625f, -0.0390625f,0.273438f, -0.0390625f,0.265625f, -0.046875f,0.273438f, -0.046875f,0.265625f, -0.0546875f,0.273438f, -0.0546875f,0.265625f, -0.0625f,0.273438f, -0.0625f,0.265625f, -0.0703125f,0.273438f, -0.0703125f,0.265625f, -0.078125f,0.273438f, -0.078125f,0.265625f, -0.0859375f,0.273438f, -0.0859375f,0.265625f, -0.09375f,0.273438f, -0.09375f,0.265625f, -0.101563f,0.273438f, -0.101563f,0.265625f, -0.109375f,0.273438f, -0.109375f,0.265625f, -0.117188f,0.273438f, -0.117188f,0.265625f, -0.125f,0.273438f, -0.125f,0.265625f, -0.132813f,0.273438f, -0.132813f,0.265625f, -0.140625f,0.273438f, -0.140625f,0.265625f, -0.148438f,0.273438f, -0.148438f,0.265625f, -0.15625f,0.273438f, -0.15625f,0.265625f, -0.164063f,0.273438f, -0.164063f,0.265625f, -0.171875f,0.273438f, -0.171875f,0.265625f, -0.179688f,0.273438f, -0.179688f,0.265625f, -0.1875f,0.273438f, -0.1875f,0.265625f, -0.195313f,0.273438f, -0.195313f,0.265625f, -0.203125f,0.273438f, -0.203125f,0.265625f, -0.210938f,0.273438f, -0.210938f,0.265625f, -0.21875f,0.273438f, -0.21875f,0.265625f, -0.226563f,0.273438f, -0.226563f,0.265625f, -0.234375f,0.273438f, -0.234375f,0.265625f, -0.242188f,0.273438f, -0.242188f,0.265625f, -0.25f,0.273438f, -0.25f,0.265625f, -0.257813f,0.273438f, -0.257813f,0.265625f, -0.265625f,0.273438f, -0.265625f,0.265625f, -0.273438f,0.273438f, -0.273438f,0.265625f, -0.28125f,0.273438f, -0.28125f,0.265625f, -0.289063f,0.273438f, -0.289063f,0.265625f, -0.296875f,0.273438f, -0.296875f,0.265625f, -0.304688f,0.273438f, -0.304688f,0.265625f, -0.3125f,0.273438f, -0.3125f,0.265625f, -0.320313f,0.273438f, -0.320313f,0.265625f, -0.328125f,0.273438f, -0.328125f,0.265625f, -0.335938f,0.273438f, -0.335938f,0.265625f, -0.34375f,0.273438f, -0.34375f,0.265625f, -0.351563f,0.273438f, -0.351563f,0.265625f, -0.359375f,0.273438f, -0.359375f,0.265625f, -0.367188f,0.273438f, -0.367188f,0.265625f, -0.375f,0.273438f, -0.375f,0.265625f, -0.382813f,0.273438f, -0.382813f,0.265625f, -0.390625f,0.273438f, -0.390625f,0.265625f, -0.398438f,0.273438f, -0.398438f,0.265625f, -0.40625f,0.273438f, -0.40625f,0.265625f, -0.414063f,0.273438f, -0.414063f,0.265625f, -0.421875f,0.273438f, -0.421875f,0.265625f, -0.429688f,0.273438f, -0.429688f,0.265625f, -0.4375f,0.273438f, -0.4375f,0.265625f, -0.445313f,0.273438f, -0.445313f,0.265625f, -0.453125f,0.273438f, -0.453125f,0.265625f, -0.460938f,0.273438f, -0.460938f,0.265625f, -0.46875f,0.273438f, -0.46875f,0.265625f, -0.476563f,0.273438f, -0.476563f,0.265625f, -0.484375f,0.273438f, -0.484375f,0.265625f, -0.492188f,0.273438f, -0.492188f,0.265625f, -0.5f,0.273438f, -0.5f,0.265625f, -0.507813f,0.273438f, -0.507813f,0.265625f, -0.0f,0.28125f, -0.0078125f,0.28125f, -0.015625f,0.28125f, -0.0234375f,0.28125f, -0.03125f,0.28125f, -0.0390625f,0.28125f, -0.046875f,0.28125f, -0.0546875f,0.28125f, -0.0625f,0.28125f, -0.0703125f,0.28125f, -0.078125f,0.28125f, -0.0859375f,0.28125f, -0.09375f,0.28125f, -0.101563f,0.28125f, -0.109375f,0.28125f, -0.117188f,0.28125f, -0.125f,0.28125f, -0.132813f,0.28125f, -0.140625f,0.28125f, -0.148438f,0.28125f, -0.15625f,0.28125f, -0.164063f,0.28125f, -0.171875f,0.28125f, -0.179688f,0.28125f, -0.1875f,0.28125f, -0.195313f,0.28125f, -0.203125f,0.28125f, -0.210938f,0.28125f, -0.21875f,0.28125f, -0.226563f,0.28125f, -0.234375f,0.28125f, -0.242188f,0.28125f, -0.25f,0.28125f, -0.257813f,0.28125f, -0.265625f,0.28125f, -0.273438f,0.28125f, -0.28125f,0.28125f, -0.289063f,0.28125f, -0.296875f,0.28125f, -0.304688f,0.28125f, -0.3125f,0.28125f, -0.320313f,0.28125f, -0.328125f,0.28125f, -0.335938f,0.28125f, -0.34375f,0.28125f, -0.351563f,0.28125f, -0.359375f,0.28125f, -0.367188f,0.28125f, -0.375f,0.28125f, -0.382813f,0.28125f, -0.390625f,0.28125f, -0.398438f,0.28125f, -0.40625f,0.28125f, -0.414063f,0.28125f, -0.421875f,0.28125f, -0.429688f,0.28125f, -0.4375f,0.28125f, -0.445313f,0.28125f, -0.453125f,0.28125f, -0.460938f,0.28125f, -0.46875f,0.28125f, -0.476563f,0.28125f, -0.484375f,0.28125f, -0.492188f,0.28125f, -0.5f,0.28125f, -0.507813f,0.28125f, -0.0f,0.289063f, -0.0078125f,0.289063f, -0.015625f,0.289063f, -0.0234375f,0.289063f, -0.03125f,0.289063f, -0.0390625f,0.289063f, -0.046875f,0.289063f, -0.0546875f,0.289063f, -0.0625f,0.289063f, -0.0703125f,0.289063f, -0.078125f,0.289063f, -0.0859375f,0.289063f, -0.09375f,0.289063f, -0.101563f,0.289063f, -0.109375f,0.289063f, -0.117188f,0.289063f, -0.125f,0.289063f, -0.132813f,0.289063f, -0.140625f,0.289063f, -0.148438f,0.289063f, -0.15625f,0.289063f, -0.164063f,0.289063f, -0.171875f,0.289063f, -0.179688f,0.289063f, -0.1875f,0.289063f, -0.195313f,0.289063f, -0.203125f,0.289063f, -0.210938f,0.289063f, -0.21875f,0.289063f, -0.226563f,0.289063f, -0.234375f,0.289063f, -0.242188f,0.289063f, -0.25f,0.289063f, -0.257813f,0.289063f, -0.265625f,0.289063f, -0.273438f,0.289063f, -0.28125f,0.289063f, -0.289063f,0.289063f, -0.296875f,0.289063f, -0.304688f,0.289063f, -0.3125f,0.289063f, -0.320313f,0.289063f, -0.328125f,0.289063f, -0.335938f,0.289063f, -0.34375f,0.289063f, -0.351563f,0.289063f, -0.359375f,0.289063f, -0.367188f,0.289063f, -0.375f,0.289063f, -0.382813f,0.289063f, -0.390625f,0.289063f, -0.398438f,0.289063f, -0.40625f,0.289063f, -0.414063f,0.289063f, -0.421875f,0.289063f, -0.429688f,0.289063f, -0.4375f,0.289063f, -0.445313f,0.289063f, -0.453125f,0.289063f, -0.460938f,0.289063f, -0.46875f,0.289063f, -0.476563f,0.289063f, -0.484375f,0.289063f, -0.492188f,0.289063f, -0.5f,0.289063f, -0.507813f,0.289063f, -0.0f,0.296875f, -0.0078125f,0.296875f, -0.015625f,0.296875f, -0.0234375f,0.296875f, -0.03125f,0.296875f, -0.0390625f,0.296875f, -0.046875f,0.296875f, -0.0546875f,0.296875f, -0.0625f,0.296875f, -0.0703125f,0.296875f, -0.078125f,0.296875f, -0.0859375f,0.296875f, -0.09375f,0.296875f, -0.101563f,0.296875f, -0.109375f,0.296875f, -0.117188f,0.296875f, -0.125f,0.296875f, -0.132813f,0.296875f, -0.140625f,0.296875f, -0.148438f,0.296875f, -0.15625f,0.296875f, -0.164063f,0.296875f, -0.171875f,0.296875f, -0.179688f,0.296875f, -0.1875f,0.296875f, -0.195313f,0.296875f, -0.203125f,0.296875f, -0.210938f,0.296875f, -0.21875f,0.296875f, -0.226563f,0.296875f, -0.234375f,0.296875f, -0.242188f,0.296875f, -0.25f,0.296875f, -0.257813f,0.296875f, -0.265625f,0.296875f, -0.273438f,0.296875f, -0.28125f,0.296875f, -0.289063f,0.296875f, -0.296875f,0.296875f, -0.304688f,0.296875f, -0.3125f,0.296875f, -0.320313f,0.296875f, -0.328125f,0.296875f, -0.335938f,0.296875f, -0.34375f,0.296875f, -0.351563f,0.296875f, -0.359375f,0.296875f, -0.367188f,0.296875f, -0.375f,0.296875f, -0.382813f,0.296875f, -0.390625f,0.296875f, -0.398438f,0.296875f, -0.40625f,0.296875f, -0.414063f,0.296875f, -0.421875f,0.296875f, -0.429688f,0.296875f, -0.4375f,0.296875f, -0.445313f,0.296875f, -0.453125f,0.296875f, -0.460938f,0.296875f, -0.46875f,0.296875f, -0.476563f,0.296875f, -0.484375f,0.296875f, -0.492188f,0.296875f, -0.5f,0.296875f, -0.507813f,0.296875f, -0.0f,0.304688f, -0.0078125f,0.304688f, -0.015625f,0.304688f, -0.0234375f,0.304688f, -0.03125f,0.304688f, -0.0390625f,0.304688f, -0.046875f,0.304688f, -0.0546875f,0.304688f, -0.0625f,0.304688f, -0.0703125f,0.304688f, -0.078125f,0.304688f, -0.0859375f,0.304688f, -0.09375f,0.304688f, -0.101563f,0.304688f, -0.109375f,0.304688f, -0.117188f,0.304688f, -0.125f,0.304688f, -0.132813f,0.304688f, -0.140625f,0.304688f, -0.148438f,0.304688f, -0.15625f,0.304688f, -0.164063f,0.304688f, -0.171875f,0.304688f, -0.179688f,0.304688f, -0.1875f,0.304688f, -0.195313f,0.304688f, -0.203125f,0.304688f, -0.210938f,0.304688f, -0.21875f,0.304688f, -0.226563f,0.304688f, -0.234375f,0.304688f, -0.242188f,0.304688f, -0.25f,0.304688f, -0.257813f,0.304688f, -0.265625f,0.304688f, -0.273438f,0.304688f, -0.28125f,0.304688f, -0.289063f,0.304688f, -0.296875f,0.304688f, -0.304688f,0.304688f, -0.3125f,0.304688f, -0.320313f,0.304688f, -0.328125f,0.304688f, -0.335938f,0.304688f, -0.34375f,0.304688f, -0.351563f,0.304688f, -0.359375f,0.304688f, -0.367188f,0.304688f, -0.375f,0.304688f, -0.382813f,0.304688f, -0.390625f,0.304688f, -0.398438f,0.304688f, -0.40625f,0.304688f, -0.414063f,0.304688f, -0.421875f,0.304688f, -0.429688f,0.304688f, -0.4375f,0.304688f, -0.445313f,0.304688f, -0.453125f,0.304688f, -0.460938f,0.304688f, -0.46875f,0.304688f, -0.476563f,0.304688f, -0.484375f,0.304688f, -0.492188f,0.304688f, -0.5f,0.304688f, -0.507813f,0.304688f, -0.0f,0.3125f, -0.0078125f,0.3125f, -0.015625f,0.3125f, -0.0234375f,0.3125f, -0.03125f,0.3125f, -0.0390625f,0.3125f, -0.046875f,0.3125f, -0.0546875f,0.3125f, -0.0625f,0.3125f, -0.0703125f,0.3125f, -0.078125f,0.3125f, -0.0859375f,0.3125f, -0.09375f,0.3125f, -0.101563f,0.3125f, -0.109375f,0.3125f, -0.117188f,0.3125f, -0.125f,0.3125f, -0.132813f,0.3125f, -0.140625f,0.3125f, -0.148438f,0.3125f, -0.15625f,0.3125f, -0.164063f,0.3125f, -0.171875f,0.3125f, -0.179688f,0.3125f, -0.1875f,0.3125f, -0.195313f,0.3125f, -0.203125f,0.3125f, -0.210938f,0.3125f, -0.21875f,0.3125f, -0.226563f,0.3125f, -0.234375f,0.3125f, -0.242188f,0.3125f, -0.25f,0.3125f, -0.257813f,0.3125f, -0.265625f,0.3125f, -0.273438f,0.3125f, -0.28125f,0.3125f, -0.289063f,0.3125f, -0.296875f,0.3125f, -0.304688f,0.3125f, -0.3125f,0.3125f, -0.320313f,0.3125f, -0.328125f,0.3125f, -0.335938f,0.3125f, -0.34375f,0.3125f, -0.351563f,0.3125f, -0.359375f,0.3125f, -0.367188f,0.3125f, -0.375f,0.3125f, -0.382813f,0.3125f, -0.390625f,0.3125f, -0.398438f,0.3125f, -0.40625f,0.3125f, -0.414063f,0.3125f, -0.421875f,0.3125f, -0.429688f,0.3125f, -0.4375f,0.3125f, -0.445313f,0.3125f, -0.453125f,0.3125f, -0.460938f,0.3125f, -0.46875f,0.3125f, -0.476563f,0.3125f, -0.484375f,0.3125f, -0.492188f,0.3125f, -0.5f,0.3125f, -0.507813f,0.3125f, -0.0f,0.320313f, -0.0078125f,0.320313f, -0.015625f,0.320313f, -0.0234375f,0.320313f, -0.03125f,0.320313f, -0.0390625f,0.320313f, -0.046875f,0.320313f, -0.0546875f,0.320313f, -0.0625f,0.320313f, -0.0703125f,0.320313f, -0.078125f,0.320313f, -0.0859375f,0.320313f, -0.09375f,0.320313f, -0.101563f,0.320313f, -0.109375f,0.320313f, -0.117188f,0.320313f, -0.125f,0.320313f, -0.132813f,0.320313f, -0.140625f,0.320313f, -0.148438f,0.320313f, -0.15625f,0.320313f, -0.164063f,0.320313f, -0.171875f,0.320313f, -0.179688f,0.320313f, -0.1875f,0.320313f, -0.195313f,0.320313f, -0.203125f,0.320313f, -0.210938f,0.320313f, -0.21875f,0.320313f, -0.226563f,0.320313f, -0.234375f,0.320313f, -0.242188f,0.320313f, -0.25f,0.320313f, -0.257813f,0.320313f, -0.265625f,0.320313f, -0.273438f,0.320313f, -0.28125f,0.320313f, -0.289063f,0.320313f, -0.296875f,0.320313f, -0.304688f,0.320313f, -0.3125f,0.320313f, -0.320313f,0.320313f, -0.328125f,0.320313f, -0.335938f,0.320313f, -0.34375f,0.320313f, -0.351563f,0.320313f, -0.359375f,0.320313f, -0.367188f,0.320313f, -0.375f,0.320313f, -0.382813f,0.320313f, -0.390625f,0.320313f, -0.398438f,0.320313f, -0.40625f,0.320313f, -0.414063f,0.320313f, -0.421875f,0.320313f, -0.429688f,0.320313f, -0.4375f,0.320313f, -0.445313f,0.320313f, -0.453125f,0.320313f, -0.460938f,0.320313f, -0.46875f,0.320313f, -0.476563f,0.320313f, -0.484375f,0.320313f, -0.492188f,0.320313f, -0.5f,0.320313f, -0.507813f,0.320313f, -0.0f,0.328125f, -0.0078125f,0.328125f, -0.015625f,0.328125f, -0.0234375f,0.328125f, -0.03125f,0.328125f, -0.0390625f,0.328125f, -0.046875f,0.328125f, -0.0546875f,0.328125f, -0.0625f,0.328125f, -0.0703125f,0.328125f, -0.078125f,0.328125f, -0.0859375f,0.328125f, -0.09375f,0.328125f, -0.101563f,0.328125f, -0.109375f,0.328125f, -0.117188f,0.328125f, -0.125f,0.328125f, -0.132813f,0.328125f, -0.140625f,0.328125f, -0.148438f,0.328125f, -0.15625f,0.328125f, -0.164063f,0.328125f, -0.171875f,0.328125f, -0.179688f,0.328125f, -0.1875f,0.328125f, -0.195313f,0.328125f, -0.203125f,0.328125f, -0.210938f,0.328125f, -0.21875f,0.328125f, -0.226563f,0.328125f, -0.234375f,0.328125f, -0.242188f,0.328125f, -0.25f,0.328125f, -0.257813f,0.328125f, -0.265625f,0.328125f, -0.273438f,0.328125f, -0.28125f,0.328125f, -0.289063f,0.328125f, -0.296875f,0.328125f, -0.304688f,0.328125f, -0.3125f,0.328125f, -0.320313f,0.328125f, -0.328125f,0.328125f, -0.335938f,0.328125f, -0.34375f,0.328125f, -0.351563f,0.328125f, -0.359375f,0.328125f, -0.367188f,0.328125f, -0.375f,0.328125f, -0.382813f,0.328125f, -0.390625f,0.328125f, -0.398438f,0.328125f, -0.40625f,0.328125f, -0.414063f,0.328125f, -0.421875f,0.328125f, -0.429688f,0.328125f, -0.4375f,0.328125f, -0.445313f,0.328125f, -0.453125f,0.328125f, -0.460938f,0.328125f, -0.46875f,0.328125f, -0.476563f,0.328125f, -0.484375f,0.328125f, -0.492188f,0.328125f, -0.5f,0.328125f, -0.507813f,0.328125f, -0.0f,0.335938f, -0.0078125f,0.335938f, -0.015625f,0.335938f, -0.0234375f,0.335938f, -0.03125f,0.335938f, -0.0390625f,0.335938f, -0.046875f,0.335938f, -0.0546875f,0.335938f, -0.0625f,0.335938f, -0.0703125f,0.335938f, -0.078125f,0.335938f, -0.0859375f,0.335938f, -0.09375f,0.335938f, -0.101563f,0.335938f, -0.109375f,0.335938f, -0.117188f,0.335938f, -0.125f,0.335938f, -0.132813f,0.335938f, -0.140625f,0.335938f, -0.148438f,0.335938f, -0.15625f,0.335938f, -0.164063f,0.335938f, -0.171875f,0.335938f, -0.179688f,0.335938f, -0.1875f,0.335938f, -0.195313f,0.335938f, -0.203125f,0.335938f, -0.210938f,0.335938f, -0.21875f,0.335938f, -0.226563f,0.335938f, -0.234375f,0.335938f, -0.242188f,0.335938f, -0.25f,0.335938f, -0.257813f,0.335938f, -0.265625f,0.335938f, -0.273438f,0.335938f, -0.28125f,0.335938f, -0.289063f,0.335938f, -0.296875f,0.335938f, -0.304688f,0.335938f, -0.3125f,0.335938f, -0.320313f,0.335938f, -0.328125f,0.335938f, -0.335938f,0.335938f, -0.34375f,0.335938f, -0.351563f,0.335938f, -0.359375f,0.335938f, -0.367188f,0.335938f, -0.375f,0.335938f, -0.382813f,0.335938f, -0.390625f,0.335938f, -0.398438f,0.335938f, -0.40625f,0.335938f, -0.414063f,0.335938f, -0.421875f,0.335938f, -0.429688f,0.335938f, -0.4375f,0.335938f, -0.445313f,0.335938f, -0.453125f,0.335938f, -0.460938f,0.335938f, -0.46875f,0.335938f, -0.476563f,0.335938f, -0.484375f,0.335938f, -0.492188f,0.335938f, -0.5f,0.335938f, -0.507813f,0.335938f, -0.0f,0.34375f, -0.0078125f,0.34375f, -0.015625f,0.34375f, -0.0234375f,0.34375f, -0.03125f,0.34375f, -0.0390625f,0.34375f, -0.046875f,0.34375f, -0.0546875f,0.34375f, -0.0625f,0.34375f, -0.0703125f,0.34375f, -0.078125f,0.34375f, -0.0859375f,0.34375f, -0.09375f,0.34375f, -0.101563f,0.34375f, -0.109375f,0.34375f, -0.117188f,0.34375f, -0.125f,0.34375f, -0.132813f,0.34375f, -0.140625f,0.34375f, -0.148438f,0.34375f, -0.15625f,0.34375f, -0.164063f,0.34375f, -0.171875f,0.34375f, -0.179688f,0.34375f, -0.1875f,0.34375f, -0.195313f,0.34375f, -0.203125f,0.34375f, -0.210938f,0.34375f, -0.21875f,0.34375f, -0.226563f,0.34375f, -0.234375f,0.34375f, -0.242188f,0.34375f, -0.25f,0.34375f, -0.257813f,0.34375f, -0.265625f,0.34375f, -0.273438f,0.34375f, -0.28125f,0.34375f, -0.289063f,0.34375f, -0.296875f,0.34375f, -0.304688f,0.34375f, -0.3125f,0.34375f, -0.320313f,0.34375f, -0.328125f,0.34375f, -0.335938f,0.34375f, -0.34375f,0.34375f, -0.351563f,0.34375f, -0.359375f,0.34375f, -0.367188f,0.34375f, -0.375f,0.34375f, -0.382813f,0.34375f, -0.390625f,0.34375f, -0.398438f,0.34375f, -0.40625f,0.34375f, -0.414063f,0.34375f, -0.421875f,0.34375f, -0.429688f,0.34375f, -0.4375f,0.34375f, -0.445313f,0.34375f, -0.453125f,0.34375f, -0.460938f,0.34375f, -0.46875f,0.34375f, -0.476563f,0.34375f, -0.484375f,0.34375f, -0.492188f,0.34375f, -0.5f,0.34375f, -0.507813f,0.34375f, -0.0f,0.351563f, -0.0078125f,0.351563f, -0.015625f,0.351563f, -0.0234375f,0.351563f, -0.03125f,0.351563f, -0.0390625f,0.351563f, -0.046875f,0.351563f, -0.0546875f,0.351563f, -0.0625f,0.351563f, -0.0703125f,0.351563f, -0.078125f,0.351563f, -0.0859375f,0.351563f, -0.09375f,0.351563f, -0.101563f,0.351563f, -0.109375f,0.351563f, -0.117188f,0.351563f, -0.125f,0.351563f, -0.132813f,0.351563f, -0.140625f,0.351563f, -0.148438f,0.351563f, -0.15625f,0.351563f, -0.164063f,0.351563f, -0.171875f,0.351563f, -0.179688f,0.351563f, -0.1875f,0.351563f, -0.195313f,0.351563f, -0.203125f,0.351563f, -0.210938f,0.351563f, -0.21875f,0.351563f, -0.226563f,0.351563f, -0.234375f,0.351563f, -0.242188f,0.351563f, -0.25f,0.351563f, -0.257813f,0.351563f, -0.265625f,0.351563f, -0.273438f,0.351563f, -0.28125f,0.351563f, -0.289063f,0.351563f, -0.296875f,0.351563f, -0.304688f,0.351563f, -0.3125f,0.351563f, -0.320313f,0.351563f, -0.328125f,0.351563f, -0.335938f,0.351563f, -0.34375f,0.351563f, -0.351563f,0.351563f, -0.359375f,0.351563f, -0.367188f,0.351563f, -0.375f,0.351563f, -0.382813f,0.351563f, -0.390625f,0.351563f, -0.398438f,0.351563f, -0.40625f,0.351563f, -0.414063f,0.351563f, -0.421875f,0.351563f, -0.429688f,0.351563f, -0.4375f,0.351563f, -0.445313f,0.351563f, -0.453125f,0.351563f, -0.460938f,0.351563f, -0.46875f,0.351563f, -0.476563f,0.351563f, -0.484375f,0.351563f, -0.492188f,0.351563f, -0.5f,0.351563f, -0.507813f,0.351563f, -0.0f,0.359375f, -0.0078125f,0.359375f, -0.015625f,0.359375f, -0.0234375f,0.359375f, -0.03125f,0.359375f, -0.0390625f,0.359375f, -0.046875f,0.359375f, -0.0546875f,0.359375f, -0.0625f,0.359375f, -0.0703125f,0.359375f, -0.078125f,0.359375f, -0.0859375f,0.359375f, -0.09375f,0.359375f, -0.101563f,0.359375f, -0.109375f,0.359375f, -0.117188f,0.359375f, -0.125f,0.359375f, -0.132813f,0.359375f, -0.140625f,0.359375f, -0.148438f,0.359375f, -0.15625f,0.359375f, -0.164063f,0.359375f, -0.171875f,0.359375f, -0.179688f,0.359375f, -0.1875f,0.359375f, -0.195313f,0.359375f, -0.203125f,0.359375f, -0.210938f,0.359375f, -0.21875f,0.359375f, -0.226563f,0.359375f, -0.234375f,0.359375f, -0.242188f,0.359375f, -0.25f,0.359375f, -0.257813f,0.359375f, -0.265625f,0.359375f, -0.273438f,0.359375f, -0.28125f,0.359375f, -0.289063f,0.359375f, -0.296875f,0.359375f, -0.304688f,0.359375f, -0.3125f,0.359375f, -0.320313f,0.359375f, -0.328125f,0.359375f, -0.335938f,0.359375f, -0.34375f,0.359375f, -0.351563f,0.359375f, -0.359375f,0.359375f, -0.367188f,0.359375f, -0.375f,0.359375f, -0.382813f,0.359375f, -0.390625f,0.359375f, -0.398438f,0.359375f, -0.40625f,0.359375f, -0.414063f,0.359375f, -0.421875f,0.359375f, -0.429688f,0.359375f, -0.4375f,0.359375f, -0.445313f,0.359375f, -0.453125f,0.359375f, -0.460938f,0.359375f, -0.46875f,0.359375f, -0.476563f,0.359375f, -0.484375f,0.359375f, -0.492188f,0.359375f, -0.5f,0.359375f, -0.507813f,0.359375f, -0.0f,0.367188f, -0.0078125f,0.367188f, -0.015625f,0.367188f, -0.0234375f,0.367188f, -0.03125f,0.367188f, -0.0390625f,0.367188f, -0.046875f,0.367188f, -0.0546875f,0.367188f, -0.0625f,0.367188f, -0.0703125f,0.367188f, -0.078125f,0.367188f, -0.0859375f,0.367188f, -0.09375f,0.367188f, -0.101563f,0.367188f, -0.109375f,0.367188f, -0.117188f,0.367188f, -0.125f,0.367188f, -0.132813f,0.367188f, -0.140625f,0.367188f, -0.148438f,0.367188f, -0.15625f,0.367188f, -0.164063f,0.367188f, -0.171875f,0.367188f, -0.179688f,0.367188f, -0.1875f,0.367188f, -0.195313f,0.367188f, -0.203125f,0.367188f, -0.210938f,0.367188f, -0.21875f,0.367188f, -0.226563f,0.367188f, -0.234375f,0.367188f, -0.242188f,0.367188f, -0.25f,0.367188f, -0.257813f,0.367188f, -0.265625f,0.367188f, -0.273438f,0.367188f, -0.28125f,0.367188f, -0.289063f,0.367188f, -0.296875f,0.367188f, -0.304688f,0.367188f, -0.3125f,0.367188f, -0.320313f,0.367188f, -0.328125f,0.367188f, -0.335938f,0.367188f, -0.34375f,0.367188f, -0.351563f,0.367188f, -0.359375f,0.367188f, -0.367188f,0.367188f, -0.375f,0.367188f, -0.382813f,0.367188f, -0.390625f,0.367188f, -0.398438f,0.367188f, -0.40625f,0.367188f, -0.414063f,0.367188f, -0.421875f,0.367188f, -0.429688f,0.367188f, -0.4375f,0.367188f, -0.445313f,0.367188f, -0.453125f,0.367188f, -0.460938f,0.367188f, -0.46875f,0.367188f, -0.476563f,0.367188f, -0.484375f,0.367188f, -0.492188f,0.367188f, -0.5f,0.367188f, -0.507813f,0.367188f, -0.0f,0.375f, -0.0078125f,0.375f, -0.015625f,0.375f, -0.0234375f,0.375f, -0.03125f,0.375f, -0.0390625f,0.375f, -0.046875f,0.375f, -0.0546875f,0.375f, -0.0625f,0.375f, -0.0703125f,0.375f, -0.078125f,0.375f, -0.0859375f,0.375f, -0.09375f,0.375f, -0.101563f,0.375f, -0.109375f,0.375f, -0.117188f,0.375f, -0.125f,0.375f, -0.132813f,0.375f, -0.140625f,0.375f, -0.148438f,0.375f, -0.15625f,0.375f, -0.164063f,0.375f, -0.171875f,0.375f, -0.179688f,0.375f, -0.1875f,0.375f, -0.195313f,0.375f, -0.203125f,0.375f, -0.210938f,0.375f, -0.21875f,0.375f, -0.226563f,0.375f, -0.234375f,0.375f, -0.242188f,0.375f, -0.25f,0.375f, -0.257813f,0.375f, -0.265625f,0.375f, -0.273438f,0.375f, -0.28125f,0.375f, -0.289063f,0.375f, -0.296875f,0.375f, -0.304688f,0.375f, -0.3125f,0.375f, -0.320313f,0.375f, -0.328125f,0.375f, -0.335938f,0.375f, -0.34375f,0.375f, -0.351563f,0.375f, -0.359375f,0.375f, -0.367188f,0.375f, -0.375f,0.375f, -0.382813f,0.375f, -0.390625f,0.375f, -0.398438f,0.375f, -0.40625f,0.375f, -0.414063f,0.375f, -0.421875f,0.375f, -0.429688f,0.375f, -0.4375f,0.375f, -0.445313f,0.375f, -0.453125f,0.375f, -0.460938f,0.375f, -0.46875f,0.375f, -0.476563f,0.375f, -0.484375f,0.375f, -0.492188f,0.375f, -0.5f,0.375f, -0.507813f,0.375f, -0.0f,0.382813f, -0.0078125f,0.382813f, -0.015625f,0.382813f, -0.0234375f,0.382813f, -0.03125f,0.382813f, -0.0390625f,0.382813f, -0.046875f,0.382813f, -0.0546875f,0.382813f, -0.0625f,0.382813f, -0.0703125f,0.382813f, -0.078125f,0.382813f, -0.0859375f,0.382813f, -0.09375f,0.382813f, -0.101563f,0.382813f, -0.109375f,0.382813f, -0.117188f,0.382813f, -0.125f,0.382813f, -0.132813f,0.382813f, -0.140625f,0.382813f, -0.148438f,0.382813f, -0.15625f,0.382813f, -0.164063f,0.382813f, -0.171875f,0.382813f, -0.179688f,0.382813f, -0.1875f,0.382813f, -0.195313f,0.382813f, -0.203125f,0.382813f, -0.210938f,0.382813f, -0.21875f,0.382813f, -0.226563f,0.382813f, -0.234375f,0.382813f, -0.242188f,0.382813f, -0.25f,0.382813f, -0.257813f,0.382813f, -0.265625f,0.382813f, -0.273438f,0.382813f, -0.28125f,0.382813f, -0.289063f,0.382813f, -0.296875f,0.382813f, -0.304688f,0.382813f, -0.3125f,0.382813f, -0.320313f,0.382813f, -0.328125f,0.382813f, -0.335938f,0.382813f, -0.34375f,0.382813f, -0.351563f,0.382813f, -0.359375f,0.382813f, -0.367188f,0.382813f, -0.375f,0.382813f, -0.382813f,0.382813f, -0.390625f,0.382813f, -0.398438f,0.382813f, -0.40625f,0.382813f, -0.414063f,0.382813f, -0.421875f,0.382813f, -0.429688f,0.382813f, -0.4375f,0.382813f, -0.445313f,0.382813f, -0.453125f,0.382813f, -0.460938f,0.382813f, -0.46875f,0.382813f, -0.476563f,0.382813f, -0.484375f,0.382813f, -0.492188f,0.382813f, -0.5f,0.382813f, -0.507813f,0.382813f, -0.0f,0.390625f, -0.0078125f,0.390625f, -0.015625f,0.390625f, -0.0234375f,0.390625f, -0.03125f,0.390625f, -0.0390625f,0.390625f, -0.046875f,0.390625f, -0.0546875f,0.390625f, -0.0625f,0.390625f, -0.0703125f,0.390625f, -0.078125f,0.390625f, -0.0859375f,0.390625f, -0.09375f,0.390625f, -0.101563f,0.390625f, -0.109375f,0.390625f, -0.117188f,0.390625f, -0.125f,0.390625f, -0.132813f,0.390625f, -0.140625f,0.390625f, -0.148438f,0.390625f, -0.15625f,0.390625f, -0.164063f,0.390625f, -0.171875f,0.390625f, -0.179688f,0.390625f, -0.1875f,0.390625f, -0.195313f,0.390625f, -0.203125f,0.390625f, -0.210938f,0.390625f, -0.21875f,0.390625f, -0.226563f,0.390625f, -0.234375f,0.390625f, -0.242188f,0.390625f, -0.25f,0.390625f, -0.257813f,0.390625f, -0.265625f,0.390625f, -0.273438f,0.390625f, -0.28125f,0.390625f, -0.289063f,0.390625f, -0.296875f,0.390625f, -0.304688f,0.390625f, -0.3125f,0.390625f, -0.320313f,0.390625f, -0.328125f,0.390625f, -0.335938f,0.390625f, -0.34375f,0.390625f, -0.351563f,0.390625f, -0.359375f,0.390625f, -0.367188f,0.390625f, -0.375f,0.390625f, -0.382813f,0.390625f, -0.390625f,0.390625f, -0.398438f,0.390625f, -0.40625f,0.390625f, -0.414063f,0.390625f, -0.421875f,0.390625f, -0.429688f,0.390625f, -0.4375f,0.390625f, -0.445313f,0.390625f, -0.453125f,0.390625f, -0.460938f,0.390625f, -0.46875f,0.390625f, -0.476563f,0.390625f, -0.484375f,0.390625f, -0.492188f,0.390625f, -0.5f,0.390625f, -0.507813f,0.390625f, -0.0f,0.398438f, -0.0078125f,0.398438f, -0.015625f,0.398438f, -0.0234375f,0.398438f, -0.03125f,0.398438f, -0.0390625f,0.398438f, -0.046875f,0.398438f, -0.0546875f,0.398438f, -0.0625f,0.398438f, -0.0703125f,0.398438f, -0.078125f,0.398438f, -0.0859375f,0.398438f, -0.09375f,0.398438f, -0.101563f,0.398438f, -0.109375f,0.398438f, -0.117188f,0.398438f, -0.125f,0.398438f, -0.132813f,0.398438f, -0.140625f,0.398438f, -0.148438f,0.398438f, -0.15625f,0.398438f, -0.164063f,0.398438f, -0.171875f,0.398438f, -0.179688f,0.398438f, -0.1875f,0.398438f, -0.195313f,0.398438f, -0.203125f,0.398438f, -0.210938f,0.398438f, -0.21875f,0.398438f, -0.226563f,0.398438f, -0.234375f,0.398438f, -0.242188f,0.398438f, -0.25f,0.398438f, -0.257813f,0.398438f, -0.265625f,0.398438f, -0.273438f,0.398438f, -0.28125f,0.398438f, -0.289063f,0.398438f, -0.296875f,0.398438f, -0.304688f,0.398438f, -0.3125f,0.398438f, -0.320313f,0.398438f, -0.328125f,0.398438f, -0.335938f,0.398438f, -0.34375f,0.398438f, -0.351563f,0.398438f, -0.359375f,0.398438f, -0.367188f,0.398438f, -0.375f,0.398438f, -0.382813f,0.398438f, -0.390625f,0.398438f, -0.398438f,0.398438f, -0.40625f,0.398438f, -0.414063f,0.398438f, -0.421875f,0.398438f, -0.429688f,0.398438f, -0.4375f,0.398438f, -0.445313f,0.398438f, -0.453125f,0.398438f, -0.460938f,0.398438f, -0.46875f,0.398438f, -0.476563f,0.398438f, -0.484375f,0.398438f, -0.492188f,0.398438f, -0.5f,0.398438f, -0.507813f,0.398438f, -0.0f,0.40625f, -0.0078125f,0.40625f, -0.015625f,0.40625f, -0.0234375f,0.40625f, -0.03125f,0.40625f, -0.0390625f,0.40625f, -0.046875f,0.40625f, -0.0546875f,0.40625f, -0.0625f,0.40625f, -0.0703125f,0.40625f, -0.078125f,0.40625f, -0.0859375f,0.40625f, -0.09375f,0.40625f, -0.101563f,0.40625f, -0.109375f,0.40625f, -0.117188f,0.40625f, -0.125f,0.40625f, -0.132813f,0.40625f, -0.140625f,0.40625f, -0.148438f,0.40625f, -0.15625f,0.40625f, -0.164063f,0.40625f, -0.171875f,0.40625f, -0.179688f,0.40625f, -0.1875f,0.40625f, -0.195313f,0.40625f, -0.203125f,0.40625f, -0.210938f,0.40625f, -0.21875f,0.40625f, -0.226563f,0.40625f, -0.234375f,0.40625f, -0.242188f,0.40625f, -0.25f,0.40625f, -0.257813f,0.40625f, -0.265625f,0.40625f, -0.273438f,0.40625f, -0.28125f,0.40625f, -0.289063f,0.40625f, -0.296875f,0.40625f, -0.304688f,0.40625f, -0.3125f,0.40625f, -0.320313f,0.40625f, -0.328125f,0.40625f, -0.335938f,0.40625f, -0.34375f,0.40625f, -0.351563f,0.40625f, -0.359375f,0.40625f, -0.367188f,0.40625f, -0.375f,0.40625f, -0.382813f,0.40625f, -0.390625f,0.40625f, -0.398438f,0.40625f, -0.40625f,0.40625f, -0.414063f,0.40625f, -0.421875f,0.40625f, -0.429688f,0.40625f, -0.4375f,0.40625f, -0.445313f,0.40625f, -0.453125f,0.40625f, -0.460938f,0.40625f, -0.46875f,0.40625f, -0.476563f,0.40625f, -0.484375f,0.40625f, -0.492188f,0.40625f, -0.5f,0.40625f, -0.507813f,0.40625f, -0.0f,0.414063f, -0.0078125f,0.414063f, -0.015625f,0.414063f, -0.0234375f,0.414063f, -0.03125f,0.414063f, -0.0390625f,0.414063f, -0.046875f,0.414063f, -0.0546875f,0.414063f, -0.0625f,0.414063f, -0.0703125f,0.414063f, -0.078125f,0.414063f, -0.0859375f,0.414063f, -0.09375f,0.414063f, -0.101563f,0.414063f, -0.109375f,0.414063f, -0.117188f,0.414063f, -0.125f,0.414063f, -0.132813f,0.414063f, -0.140625f,0.414063f, -0.148438f,0.414063f, -0.15625f,0.414063f, -0.164063f,0.414063f, -0.171875f,0.414063f, -0.179688f,0.414063f, -0.1875f,0.414063f, -0.195313f,0.414063f, -0.203125f,0.414063f, -0.210938f,0.414063f, -0.21875f,0.414063f, -0.226563f,0.414063f, -0.234375f,0.414063f, -0.242188f,0.414063f, -0.25f,0.414063f, -0.257813f,0.414063f, -0.265625f,0.414063f, -0.273438f,0.414063f, -0.28125f,0.414063f, -0.289063f,0.414063f, -0.296875f,0.414063f, -0.304688f,0.414063f, -0.3125f,0.414063f, -0.320313f,0.414063f, -0.328125f,0.414063f, -0.335938f,0.414063f, -0.34375f,0.414063f, -0.351563f,0.414063f, -0.359375f,0.414063f, -0.367188f,0.414063f, -0.375f,0.414063f, -0.382813f,0.414063f, -0.390625f,0.414063f, -0.398438f,0.414063f, -0.40625f,0.414063f, -0.414063f,0.414063f, -0.421875f,0.414063f, -0.429688f,0.414063f, -0.4375f,0.414063f, -0.445313f,0.414063f, -0.453125f,0.414063f, -0.460938f,0.414063f, -0.46875f,0.414063f, -0.476563f,0.414063f, -0.484375f,0.414063f, -0.492188f,0.414063f, -0.5f,0.414063f, -0.507813f,0.414063f, -0.0f,0.421875f, -0.0078125f,0.421875f, -0.015625f,0.421875f, -0.0234375f,0.421875f, -0.03125f,0.421875f, -0.0390625f,0.421875f, -0.046875f,0.421875f, -0.0546875f,0.421875f, -0.0625f,0.421875f, -0.0703125f,0.421875f, -0.078125f,0.421875f, -0.0859375f,0.421875f, -0.09375f,0.421875f, -0.101563f,0.421875f, -0.109375f,0.421875f, -0.117188f,0.421875f, -0.125f,0.421875f, -0.132813f,0.421875f, -0.140625f,0.421875f, -0.148438f,0.421875f, -0.15625f,0.421875f, -0.164063f,0.421875f, -0.171875f,0.421875f, -0.179688f,0.421875f, -0.1875f,0.421875f, -0.195313f,0.421875f, -0.203125f,0.421875f, -0.210938f,0.421875f, -0.21875f,0.421875f, -0.226563f,0.421875f, -0.234375f,0.421875f, -0.242188f,0.421875f, -0.25f,0.421875f, -0.257813f,0.421875f, -0.265625f,0.421875f, -0.273438f,0.421875f, -0.28125f,0.421875f, -0.289063f,0.421875f, -0.296875f,0.421875f, -0.304688f,0.421875f, -0.3125f,0.421875f, -0.320313f,0.421875f, -0.328125f,0.421875f, -0.335938f,0.421875f, -0.34375f,0.421875f, -0.351563f,0.421875f, -0.359375f,0.421875f, -0.367188f,0.421875f, -0.375f,0.421875f, -0.382813f,0.421875f, -0.390625f,0.421875f, -0.398438f,0.421875f, -0.40625f,0.421875f, -0.414063f,0.421875f, -0.421875f,0.421875f, -0.429688f,0.421875f, -0.4375f,0.421875f, -0.445313f,0.421875f, -0.453125f,0.421875f, -0.460938f,0.421875f, -0.46875f,0.421875f, -0.476563f,0.421875f, -0.484375f,0.421875f, -0.492188f,0.421875f, -0.5f,0.421875f, -0.507813f,0.421875f, -0.0f,0.429688f, -0.0078125f,0.429688f, -0.015625f,0.429688f, -0.0234375f,0.429688f, -0.03125f,0.429688f, -0.0390625f,0.429688f, -0.046875f,0.429688f, -0.0546875f,0.429688f, -0.0625f,0.429688f, -0.0703125f,0.429688f, -0.078125f,0.429688f, -0.0859375f,0.429688f, -0.09375f,0.429688f, -0.101563f,0.429688f, -0.109375f,0.429688f, -0.117188f,0.429688f, -0.125f,0.429688f, -0.132813f,0.429688f, -0.140625f,0.429688f, -0.148438f,0.429688f, -0.15625f,0.429688f, -0.164063f,0.429688f, -0.171875f,0.429688f, -0.179688f,0.429688f, -0.1875f,0.429688f, -0.195313f,0.429688f, -0.203125f,0.429688f, -0.210938f,0.429688f, -0.21875f,0.429688f, -0.226563f,0.429688f, -0.234375f,0.429688f, -0.242188f,0.429688f, -0.25f,0.429688f, -0.257813f,0.429688f, -0.265625f,0.429688f, -0.273438f,0.429688f, -0.28125f,0.429688f, -0.289063f,0.429688f, -0.296875f,0.429688f, -0.304688f,0.429688f, -0.3125f,0.429688f, -0.320313f,0.429688f, -0.328125f,0.429688f, -0.335938f,0.429688f, -0.34375f,0.429688f, -0.351563f,0.429688f, -0.359375f,0.429688f, -0.367188f,0.429688f, -0.375f,0.429688f, -0.382813f,0.429688f, -0.390625f,0.429688f, -0.398438f,0.429688f, -0.40625f,0.429688f, -0.414063f,0.429688f, -0.421875f,0.429688f, -0.429688f,0.429688f, -0.4375f,0.429688f, -0.445313f,0.429688f, -0.453125f,0.429688f, -0.460938f,0.429688f, -0.46875f,0.429688f, -0.476563f,0.429688f, -0.484375f,0.429688f, -0.492188f,0.429688f, -0.5f,0.429688f, -0.507813f,0.429688f, -0.0f,0.4375f, -0.0078125f,0.4375f, -0.015625f,0.4375f, -0.0234375f,0.4375f, -0.03125f,0.4375f, -0.0390625f,0.4375f, -0.046875f,0.4375f, -0.0546875f,0.4375f, -0.0625f,0.4375f, -0.0703125f,0.4375f, -0.078125f,0.4375f, -0.0859375f,0.4375f, -0.09375f,0.4375f, -0.101563f,0.4375f, -0.109375f,0.4375f, -0.117188f,0.4375f, -0.125f,0.4375f, -0.132813f,0.4375f, -0.140625f,0.4375f, -0.148438f,0.4375f, -0.15625f,0.4375f, -0.164063f,0.4375f, -0.171875f,0.4375f, -0.179688f,0.4375f, -0.1875f,0.4375f, -0.195313f,0.4375f, -0.203125f,0.4375f, -0.210938f,0.4375f, -0.21875f,0.4375f, -0.226563f,0.4375f, -0.234375f,0.4375f, -0.242188f,0.4375f, -0.25f,0.4375f, -0.257813f,0.4375f, -0.265625f,0.4375f, -0.273438f,0.4375f, -0.28125f,0.4375f, -0.289063f,0.4375f, -0.296875f,0.4375f, -0.304688f,0.4375f, -0.3125f,0.4375f, -0.320313f,0.4375f, -0.328125f,0.4375f, -0.335938f,0.4375f, -0.34375f,0.4375f, -0.351563f,0.4375f, -0.359375f,0.4375f, -0.367188f,0.4375f, -0.375f,0.4375f, -0.382813f,0.4375f, -0.390625f,0.4375f, -0.398438f,0.4375f, -0.40625f,0.4375f, -0.414063f,0.4375f, -0.421875f,0.4375f, -0.429688f,0.4375f, -0.4375f,0.4375f, -0.445313f,0.4375f, -0.453125f,0.4375f, -0.460938f,0.4375f, -0.46875f,0.4375f, -0.476563f,0.4375f, -0.484375f,0.4375f, -0.492188f,0.4375f, -0.5f,0.4375f, -0.507813f,0.4375f, -0.0f,0.445313f, -0.0078125f,0.445313f, -0.015625f,0.445313f, -0.0234375f,0.445313f, -0.03125f,0.445313f, -0.0390625f,0.445313f, -0.046875f,0.445313f, -0.0546875f,0.445313f, -0.0625f,0.445313f, -0.0703125f,0.445313f, -0.078125f,0.445313f, -0.0859375f,0.445313f, -0.09375f,0.445313f, -0.101563f,0.445313f, -0.109375f,0.445313f, -0.117188f,0.445313f, -0.125f,0.445313f, -0.132813f,0.445313f, -0.140625f,0.445313f, -0.148438f,0.445313f, -0.15625f,0.445313f, -0.164063f,0.445313f, -0.171875f,0.445313f, -0.179688f,0.445313f, -0.1875f,0.445313f, -0.195313f,0.445313f, -0.203125f,0.445313f, -0.210938f,0.445313f, -0.21875f,0.445313f, -0.226563f,0.445313f, -0.234375f,0.445313f, -0.242188f,0.445313f, -0.25f,0.445313f, -0.257813f,0.445313f, -0.265625f,0.445313f, -0.273438f,0.445313f, -0.28125f,0.445313f, -0.289063f,0.445313f, -0.296875f,0.445313f, -0.304688f,0.445313f, -0.3125f,0.445313f, -0.320313f,0.445313f, -0.328125f,0.445313f, -0.335938f,0.445313f, -0.34375f,0.445313f, -0.351563f,0.445313f, -0.359375f,0.445313f, -0.367188f,0.445313f, -0.375f,0.445313f, -0.382813f,0.445313f, -0.390625f,0.445313f, -0.398438f,0.445313f, -0.40625f,0.445313f, -0.414063f,0.445313f, -0.421875f,0.445313f, -0.429688f,0.445313f, -0.4375f,0.445313f, -0.445313f,0.445313f, -0.453125f,0.445313f, -0.460938f,0.445313f, -0.46875f,0.445313f, -0.476563f,0.445313f, -0.484375f,0.445313f, -0.492188f,0.445313f, -0.5f,0.445313f, -0.507813f,0.445313f, -0.0f,0.453125f, -0.0078125f,0.453125f, -0.015625f,0.453125f, -0.0234375f,0.453125f, -0.03125f,0.453125f, -0.0390625f,0.453125f, -0.046875f,0.453125f, -0.0546875f,0.453125f, -0.0625f,0.453125f, -0.0703125f,0.453125f, -0.078125f,0.453125f, -0.0859375f,0.453125f, -0.09375f,0.453125f, -0.101563f,0.453125f, -0.109375f,0.453125f, -0.117188f,0.453125f, -0.125f,0.453125f, -0.132813f,0.453125f, -0.140625f,0.453125f, -0.148438f,0.453125f, -0.15625f,0.453125f, -0.164063f,0.453125f, -0.171875f,0.453125f, -0.179688f,0.453125f, -0.1875f,0.453125f, -0.195313f,0.453125f, -0.203125f,0.453125f, -0.210938f,0.453125f, -0.21875f,0.453125f, -0.226563f,0.453125f, -0.234375f,0.453125f, -0.242188f,0.453125f, -0.25f,0.453125f, -0.257813f,0.453125f, -0.265625f,0.453125f, -0.273438f,0.453125f, -0.28125f,0.453125f, -0.289063f,0.453125f, -0.296875f,0.453125f, -0.304688f,0.453125f, -0.3125f,0.453125f, -0.320313f,0.453125f, -0.328125f,0.453125f, -0.335938f,0.453125f, -0.34375f,0.453125f, -0.351563f,0.453125f, -0.359375f,0.453125f, -0.367188f,0.453125f, -0.375f,0.453125f, -0.382813f,0.453125f, -0.390625f,0.453125f, -0.398438f,0.453125f, -0.40625f,0.453125f, -0.414063f,0.453125f, -0.421875f,0.453125f, -0.429688f,0.453125f, -0.4375f,0.453125f, -0.445313f,0.453125f, -0.453125f,0.453125f, -0.460938f,0.453125f, -0.46875f,0.453125f, -0.476563f,0.453125f, -0.484375f,0.453125f, -0.492188f,0.453125f, -0.5f,0.453125f, -0.507813f,0.453125f, -0.0f,0.460938f, -0.0078125f,0.460938f, -0.015625f,0.460938f, -0.0234375f,0.460938f, -0.03125f,0.460938f, -0.0390625f,0.460938f, -0.046875f,0.460938f, -0.0546875f,0.460938f, -0.0625f,0.460938f, -0.0703125f,0.460938f, -0.078125f,0.460938f, -0.0859375f,0.460938f, -0.09375f,0.460938f, -0.101563f,0.460938f, -0.109375f,0.460938f, -0.117188f,0.460938f, -0.125f,0.460938f, -0.132813f,0.460938f, -0.140625f,0.460938f, -0.148438f,0.460938f, -0.15625f,0.460938f, -0.164063f,0.460938f, -0.171875f,0.460938f, -0.179688f,0.460938f, -0.1875f,0.460938f, -0.195313f,0.460938f, -0.203125f,0.460938f, -0.210938f,0.460938f, -0.21875f,0.460938f, -0.226563f,0.460938f, -0.234375f,0.460938f, -0.242188f,0.460938f, -0.25f,0.460938f, -0.257813f,0.460938f, -0.265625f,0.460938f, -0.273438f,0.460938f, -0.28125f,0.460938f, -0.289063f,0.460938f, -0.296875f,0.460938f, -0.304688f,0.460938f, -0.3125f,0.460938f, -0.320313f,0.460938f, -0.328125f,0.460938f, -0.335938f,0.460938f, -0.34375f,0.460938f, -0.351563f,0.460938f, -0.359375f,0.460938f, -0.367188f,0.460938f, -0.375f,0.460938f, -0.382813f,0.460938f, -0.390625f,0.460938f, -0.398438f,0.460938f, -0.40625f,0.460938f, -0.414063f,0.460938f, -0.421875f,0.460938f, -0.429688f,0.460938f, -0.4375f,0.460938f, -0.445313f,0.460938f, -0.453125f,0.460938f, -0.460938f,0.460938f, -0.46875f,0.460938f, -0.476563f,0.460938f, -0.484375f,0.460938f, -0.492188f,0.460938f, -0.5f,0.460938f, -0.507813f,0.460938f, -0.0f,0.46875f, -0.0078125f,0.46875f, -0.015625f,0.46875f, -0.0234375f,0.46875f, -0.03125f,0.46875f, -0.0390625f,0.46875f, -0.046875f,0.46875f, -0.0546875f,0.46875f, -0.0625f,0.46875f, -0.0703125f,0.46875f, -0.078125f,0.46875f, -0.0859375f,0.46875f, -0.09375f,0.46875f, -0.101563f,0.46875f, -0.109375f,0.46875f, -0.117188f,0.46875f, -0.125f,0.46875f, -0.132813f,0.46875f, -0.140625f,0.46875f, -0.148438f,0.46875f, -0.15625f,0.46875f, -0.164063f,0.46875f, -0.171875f,0.46875f, -0.179688f,0.46875f, -0.1875f,0.46875f, -0.195313f,0.46875f, -0.203125f,0.46875f, -0.210938f,0.46875f, -0.21875f,0.46875f, -0.226563f,0.46875f, -0.234375f,0.46875f, -0.242188f,0.46875f, -0.25f,0.46875f, -0.257813f,0.46875f, -0.265625f,0.46875f, -0.273438f,0.46875f, -0.28125f,0.46875f, -0.289063f,0.46875f, -0.296875f,0.46875f, -0.304688f,0.46875f, -0.3125f,0.46875f, -0.320313f,0.46875f, -0.328125f,0.46875f, -0.335938f,0.46875f, -0.34375f,0.46875f, -0.351563f,0.46875f, -0.359375f,0.46875f, -0.367188f,0.46875f, -0.375f,0.46875f, -0.382813f,0.46875f, -0.390625f,0.46875f, -0.398438f,0.46875f, -0.40625f,0.46875f, -0.414063f,0.46875f, -0.421875f,0.46875f, -0.429688f,0.46875f, -0.4375f,0.46875f, -0.445313f,0.46875f, -0.453125f,0.46875f, -0.460938f,0.46875f, -0.46875f,0.46875f, -0.476563f,0.46875f, -0.484375f,0.46875f, -0.492188f,0.46875f, -0.5f,0.46875f, -0.507813f,0.46875f, -0.0f,0.476563f, -0.0078125f,0.476563f, -0.015625f,0.476563f, -0.0234375f,0.476563f, -0.03125f,0.476563f, -0.0390625f,0.476563f, -0.046875f,0.476563f, -0.0546875f,0.476563f, -0.0625f,0.476563f, -0.0703125f,0.476563f, -0.078125f,0.476563f, -0.0859375f,0.476563f, -0.09375f,0.476563f, -0.101563f,0.476563f, -0.109375f,0.476563f, -0.117188f,0.476563f, -0.125f,0.476563f, -0.132813f,0.476563f, -0.140625f,0.476563f, -0.148438f,0.476563f, -0.15625f,0.476563f, -0.164063f,0.476563f, -0.171875f,0.476563f, -0.179688f,0.476563f, -0.1875f,0.476563f, -0.195313f,0.476563f, -0.203125f,0.476563f, -0.210938f,0.476563f, -0.21875f,0.476563f, -0.226563f,0.476563f, -0.234375f,0.476563f, -0.242188f,0.476563f, -0.25f,0.476563f, -0.257813f,0.476563f, -0.265625f,0.476563f, -0.273438f,0.476563f, -0.28125f,0.476563f, -0.289063f,0.476563f, -0.296875f,0.476563f, -0.304688f,0.476563f, -0.3125f,0.476563f, -0.320313f,0.476563f, -0.328125f,0.476563f, -0.335938f,0.476563f, -0.34375f,0.476563f, -0.351563f,0.476563f, -0.359375f,0.476563f, -0.367188f,0.476563f, -0.375f,0.476563f, -0.382813f,0.476563f, -0.390625f,0.476563f, -0.398438f,0.476563f, -0.40625f,0.476563f, -0.414063f,0.476563f, -0.421875f,0.476563f, -0.429688f,0.476563f, -0.4375f,0.476563f, -0.445313f,0.476563f, -0.453125f,0.476563f, -0.460938f,0.476563f, -0.46875f,0.476563f, -0.476563f,0.476563f, -0.484375f,0.476563f, -0.492188f,0.476563f, -0.5f,0.476563f, -0.507813f,0.476563f, -0.0f,0.484375f, -0.0078125f,0.484375f, -0.015625f,0.484375f, -0.0234375f,0.484375f, -0.03125f,0.484375f, -0.0390625f,0.484375f, -0.046875f,0.484375f, -0.0546875f,0.484375f, -0.0625f,0.484375f, -0.0703125f,0.484375f, -0.078125f,0.484375f, -0.0859375f,0.484375f, -0.09375f,0.484375f, -0.101563f,0.484375f, -0.109375f,0.484375f, -0.117188f,0.484375f, -0.125f,0.484375f, -0.132813f,0.484375f, -0.140625f,0.484375f, -0.148438f,0.484375f, -0.15625f,0.484375f, -0.164063f,0.484375f, -0.171875f,0.484375f, -0.179688f,0.484375f, -0.1875f,0.484375f, -0.195313f,0.484375f, -0.203125f,0.484375f, -0.210938f,0.484375f, -0.21875f,0.484375f, -0.226563f,0.484375f, -0.234375f,0.484375f, -0.242188f,0.484375f, -0.25f,0.484375f, -0.257813f,0.484375f, -0.265625f,0.484375f, -0.273438f,0.484375f, -0.28125f,0.484375f, -0.289063f,0.484375f, -0.296875f,0.484375f, -0.304688f,0.484375f, -0.3125f,0.484375f, -0.320313f,0.484375f, -0.328125f,0.484375f, -0.335938f,0.484375f, -0.34375f,0.484375f, -0.351563f,0.484375f, -0.359375f,0.484375f, -0.367188f,0.484375f, -0.375f,0.484375f, -0.382813f,0.484375f, -0.390625f,0.484375f, -0.398438f,0.484375f, -0.40625f,0.484375f, -0.414063f,0.484375f, -0.421875f,0.484375f, -0.429688f,0.484375f, -0.4375f,0.484375f, -0.445313f,0.484375f, -0.453125f,0.484375f, -0.460938f,0.484375f, -0.46875f,0.484375f, -0.476563f,0.484375f, -0.484375f,0.484375f, -0.492188f,0.484375f, -0.5f,0.484375f, -0.507813f,0.484375f, -0.0f,0.492188f, -0.0078125f,0.492188f, -0.015625f,0.492188f, -0.0234375f,0.492188f, -0.03125f,0.492188f, -0.0390625f,0.492188f, -0.046875f,0.492188f, -0.0546875f,0.492188f, -0.0625f,0.492188f, -0.0703125f,0.492188f, -0.078125f,0.492188f, -0.0859375f,0.492188f, -0.09375f,0.492188f, -0.101563f,0.492188f, -0.109375f,0.492188f, -0.117188f,0.492188f, -0.125f,0.492188f, -0.132813f,0.492188f, -0.140625f,0.492188f, -0.148438f,0.492188f, -0.15625f,0.492188f, -0.164063f,0.492188f, -0.171875f,0.492188f, -0.179688f,0.492188f, -0.1875f,0.492188f, -0.195313f,0.492188f, -0.203125f,0.492188f, -0.210938f,0.492188f, -0.21875f,0.492188f, -0.226563f,0.492188f, -0.234375f,0.492188f, -0.242188f,0.492188f, -0.25f,0.492188f, -0.257813f,0.492188f, -0.265625f,0.492188f, -0.273438f,0.492188f, -0.28125f,0.492188f, -0.289063f,0.492188f, -0.296875f,0.492188f, -0.304688f,0.492188f, -0.3125f,0.492188f, -0.320313f,0.492188f, -0.328125f,0.492188f, -0.335938f,0.492188f, -0.34375f,0.492188f, -0.351563f,0.492188f, -0.359375f,0.492188f, -0.367188f,0.492188f, -0.375f,0.492188f, -0.382813f,0.492188f, -0.390625f,0.492188f, -0.398438f,0.492188f, -0.40625f,0.492188f, -0.414063f,0.492188f, -0.421875f,0.492188f, -0.429688f,0.492188f, -0.4375f,0.492188f, -0.445313f,0.492188f, -0.453125f,0.492188f, -0.460938f,0.492188f, -0.46875f,0.492188f, -0.476563f,0.492188f, -0.484375f,0.492188f, -0.492188f,0.492188f, -0.5f,0.492188f, -0.507813f,0.492188f, -}; - -unsigned short Landscape02Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -126,127,128, -129,128,127, -128,129,130, -131,130,129, -132,0,133, -2,133,0, -133,2,134, -4,134,2, -134,4,135, -6,135,4, -135,6,136, -8,136,6, -136,8,137, -10,137,8, -137,10,138, -12,138,10, -138,12,139, -14,139,12, -139,14,140, -16,140,14, -140,16,141, -18,141,16, -141,18,142, -20,142,18, -142,20,143, -22,143,20, -143,22,144, -24,144,22, -144,24,145, -26,145,24, -145,26,146, -28,146,26, -146,28,147, -30,147,28, -147,30,148, -32,148,30, -148,32,149, -34,149,32, -149,34,150, -36,150,34, -150,36,151, -38,151,36, -151,38,152, -40,152,38, -152,40,153, -42,153,40, -153,42,154, -44,154,42, -154,44,155, -46,155,44, -155,46,156, -48,156,46, -156,48,157, -50,157,48, -157,50,158, -52,158,50, -158,52,159, -54,159,52, -159,54,160, -56,160,54, -160,56,161, -58,161,56, -161,58,162, -60,162,58, -162,60,163, -62,163,60, -163,62,164, -64,164,62, -164,64,165, -66,165,64, -165,66,166, -68,166,66, -166,68,167, -70,167,68, -167,70,168, -72,168,70, -168,72,169, -74,169,72, -169,74,170, -76,170,74, -170,76,171, -78,171,76, -171,78,172, -80,172,78, -172,80,173, -82,173,80, -173,82,174, -84,174,82, -174,84,175, -86,175,84, -175,86,176, -88,176,86, -176,88,177, -90,177,88, -177,90,178, -92,178,90, -178,92,179, -94,179,92, -179,94,180, -96,180,94, -180,96,181, -98,181,96, -181,98,182, -100,182,98, -182,100,183, -102,183,100, -183,102,184, -104,184,102, -184,104,185, -106,185,104, -185,106,186, -108,186,106, -186,108,187, -110,187,108, -187,110,188, -112,188,110, -188,112,189, -114,189,112, -189,114,190, -116,190,114, -190,116,191, -118,191,116, -191,118,192, -120,192,118, -192,120,193, -122,193,120, -193,122,194, -124,194,122, -194,124,195, -126,195,124, -195,126,196, -128,196,126, -196,128,197, -130,197,128, -198,132,199, -133,199,132, -199,133,200, -134,200,133, -200,134,201, -135,201,134, -201,135,202, -136,202,135, -202,136,203, -137,203,136, -203,137,204, -138,204,137, -204,138,205, -139,205,138, -205,139,206, -140,206,139, -206,140,207, -141,207,140, -207,141,208, -142,208,141, -208,142,209, -143,209,142, -209,143,210, -144,210,143, -210,144,211, -145,211,144, -211,145,212, -146,212,145, -212,146,213, -147,213,146, -213,147,214, -148,214,147, -214,148,215, -149,215,148, -215,149,216, -150,216,149, -216,150,217, -151,217,150, -217,151,218, -152,218,151, -218,152,219, -153,219,152, -219,153,220, -154,220,153, -220,154,221, -155,221,154, -221,155,222, -156,222,155, -222,156,223, -157,223,156, -223,157,224, -158,224,157, -224,158,225, -159,225,158, -225,159,226, -160,226,159, -226,160,227, -161,227,160, -227,161,228, -162,228,161, -228,162,229, -163,229,162, -229,163,230, -164,230,163, -230,164,231, -165,231,164, -231,165,232, -166,232,165, -232,166,233, -167,233,166, -233,167,234, -168,234,167, -234,168,235, -169,235,168, -235,169,236, -170,236,169, -236,170,237, -171,237,170, -237,171,238, -172,238,171, -238,172,239, -173,239,172, -239,173,240, -174,240,173, -240,174,241, -175,241,174, -241,175,242, -176,242,175, -242,176,243, -177,243,176, -243,177,244, -178,244,177, -244,178,245, -179,245,178, -245,179,246, -180,246,179, -246,180,247, -181,247,180, -247,181,248, -182,248,181, -248,182,249, -183,249,182, -249,183,250, -184,250,183, -250,184,251, -185,251,184, -251,185,252, -186,252,185, -252,186,253, -187,253,186, -253,187,254, -188,254,187, -254,188,255, -189,255,188, -255,189,256, -190,256,189, -256,190,257, -191,257,190, -257,191,258, -192,258,191, -258,192,259, -193,259,192, -259,193,260, -194,260,193, -260,194,261, -195,261,194, -261,195,262, -196,262,195, -262,196,263, -197,263,196, -264,198,265, -199,265,198, -265,199,266, -200,266,199, -266,200,267, -201,267,200, -267,201,268, -202,268,201, -268,202,269, -203,269,202, -269,203,270, -204,270,203, -270,204,271, -205,271,204, -271,205,272, -206,272,205, -272,206,273, -207,273,206, -273,207,274, -208,274,207, -274,208,275, -209,275,208, -275,209,276, -210,276,209, -276,210,277, -211,277,210, -277,211,278, -212,278,211, -278,212,279, -213,279,212, -279,213,280, -214,280,213, -280,214,281, -215,281,214, -281,215,282, -216,282,215, -282,216,283, -217,283,216, -283,217,284, -218,284,217, -284,218,285, -219,285,218, -285,219,286, -220,286,219, -286,220,287, -221,287,220, -287,221,288, -222,288,221, -288,222,289, -223,289,222, -289,223,290, -224,290,223, -290,224,291, -225,291,224, -291,225,292, -226,292,225, -292,226,293, -227,293,226, -293,227,294, -228,294,227, -294,228,295, -229,295,228, -295,229,296, -230,296,229, -296,230,297, -231,297,230, -297,231,298, -232,298,231, -298,232,299, -233,299,232, -299,233,300, -234,300,233, -300,234,301, -235,301,234, -301,235,302, -236,302,235, -302,236,303, -237,303,236, -303,237,304, -238,304,237, -304,238,305, -239,305,238, -305,239,306, -240,306,239, -306,240,307, -241,307,240, -307,241,308, -242,308,241, -308,242,309, -243,309,242, -309,243,310, -244,310,243, -310,244,311, -245,311,244, -311,245,312, -246,312,245, -312,246,313, -247,313,246, -313,247,314, -248,314,247, -314,248,315, -249,315,248, -315,249,316, -250,316,249, -316,250,317, -251,317,250, -317,251,318, -252,318,251, -318,252,319, -253,319,252, -319,253,320, -254,320,253, -320,254,321, -255,321,254, -321,255,322, -256,322,255, -322,256,323, -257,323,256, -323,257,324, -258,324,257, -324,258,325, -259,325,258, -325,259,326, -260,326,259, -326,260,327, -261,327,260, -327,261,328, -262,328,261, -328,262,329, -263,329,262, -330,264,331, -265,331,264, -331,265,332, -266,332,265, -332,266,333, -267,333,266, -333,267,334, -268,334,267, -334,268,335, -269,335,268, -335,269,336, -270,336,269, -336,270,337, -271,337,270, -337,271,338, -272,338,271, -338,272,339, -273,339,272, -339,273,340, -274,340,273, -340,274,341, -275,341,274, -341,275,342, -276,342,275, -342,276,343, -277,343,276, -343,277,344, -278,344,277, -344,278,345, -279,345,278, -345,279,346, -280,346,279, -346,280,347, -281,347,280, -347,281,348, -282,348,281, -348,282,349, -283,349,282, -349,283,350, -284,350,283, -350,284,351, -285,351,284, -351,285,352, -286,352,285, -352,286,353, -287,353,286, -353,287,354, -288,354,287, -354,288,355, -289,355,288, -355,289,356, -290,356,289, -356,290,357, -291,357,290, -357,291,358, -292,358,291, -358,292,359, -293,359,292, -359,293,360, -294,360,293, -360,294,361, -295,361,294, -361,295,362, -296,362,295, -362,296,363, -297,363,296, -363,297,364, -298,364,297, -364,298,365, -299,365,298, -365,299,366, -300,366,299, -366,300,367, -301,367,300, -367,301,368, -302,368,301, -368,302,369, -303,369,302, -369,303,370, -304,370,303, -370,304,371, -305,371,304, -371,305,372, -306,372,305, -372,306,373, -307,373,306, -373,307,374, -308,374,307, -374,308,375, -309,375,308, -375,309,376, -310,376,309, -376,310,377, -311,377,310, -377,311,378, -312,378,311, -378,312,379, -313,379,312, -379,313,380, -314,380,313, -380,314,381, -315,381,314, -381,315,382, -316,382,315, -382,316,383, -317,383,316, -383,317,384, -318,384,317, -384,318,385, -319,385,318, -385,319,386, -320,386,319, -386,320,387, -321,387,320, -387,321,388, -322,388,321, -388,322,389, -323,389,322, -389,323,390, -324,390,323, -390,324,391, -325,391,324, -391,325,392, -326,392,325, -392,326,393, -327,393,326, -393,327,394, -328,394,327, -394,328,395, -329,395,328, -396,330,397, -331,397,330, -397,331,398, -332,398,331, -398,332,399, -333,399,332, -399,333,400, -334,400,333, -400,334,401, -335,401,334, -401,335,402, -336,402,335, -402,336,403, -337,403,336, -403,337,404, -338,404,337, -404,338,405, -339,405,338, -405,339,406, -340,406,339, -406,340,407, -341,407,340, -407,341,408, -342,408,341, -408,342,409, -343,409,342, -409,343,410, -344,410,343, -410,344,411, -345,411,344, -411,345,412, -346,412,345, -412,346,413, -347,413,346, -413,347,414, -348,414,347, -414,348,415, -349,415,348, -415,349,416, -350,416,349, -416,350,417, -351,417,350, -417,351,418, -352,418,351, -418,352,419, -353,419,352, -419,353,420, -354,420,353, -420,354,421, -355,421,354, -421,355,422, -356,422,355, -422,356,423, -357,423,356, -423,357,424, -358,424,357, -424,358,425, -359,425,358, -425,359,426, -360,426,359, -426,360,427, -361,427,360, -427,361,428, -362,428,361, -428,362,429, -363,429,362, -429,363,430, -364,430,363, -430,364,431, -365,431,364, -431,365,432, -366,432,365, -432,366,433, -367,433,366, -433,367,434, -368,434,367, -434,368,435, -369,435,368, -435,369,436, -370,436,369, -436,370,437, -371,437,370, -437,371,438, -372,438,371, -438,372,439, -373,439,372, -439,373,440, -374,440,373, -440,374,441, -375,441,374, -441,375,442, -376,442,375, -442,376,443, -377,443,376, -443,377,444, -378,444,377, -444,378,445, -379,445,378, -445,379,446, -380,446,379, -446,380,447, -381,447,380, -447,381,448, -382,448,381, -448,382,449, -383,449,382, -449,383,450, -384,450,383, -450,384,451, -385,451,384, -451,385,452, -386,452,385, -452,386,453, -387,453,386, -453,387,454, -388,454,387, -454,388,455, -389,455,388, -455,389,456, -390,456,389, -456,390,457, -391,457,390, -457,391,458, -392,458,391, -458,392,459, -393,459,392, -459,393,460, -394,460,393, -460,394,461, -395,461,394, -462,396,463, -397,463,396, -463,397,464, -398,464,397, -464,398,465, -399,465,398, -465,399,466, -400,466,399, -466,400,467, -401,467,400, -467,401,468, -402,468,401, -468,402,469, -403,469,402, -469,403,470, -404,470,403, -470,404,471, -405,471,404, -471,405,472, -406,472,405, -472,406,473, -407,473,406, -473,407,474, -408,474,407, -474,408,475, -409,475,408, -475,409,476, -410,476,409, -476,410,477, -411,477,410, -477,411,478, -412,478,411, -478,412,479, -413,479,412, -479,413,480, -414,480,413, -480,414,481, -415,481,414, -481,415,482, -416,482,415, -482,416,483, -417,483,416, -483,417,484, -418,484,417, -484,418,485, -419,485,418, -485,419,486, -420,486,419, -486,420,487, -421,487,420, -487,421,488, -422,488,421, -488,422,489, -423,489,422, -489,423,490, -424,490,423, -490,424,491, -425,491,424, -491,425,492, -426,492,425, -492,426,493, -427,493,426, -493,427,494, -428,494,427, -494,428,495, -429,495,428, -495,429,496, -430,496,429, -496,430,497, -431,497,430, -497,431,498, -432,498,431, -498,432,499, -433,499,432, -499,433,500, -434,500,433, -500,434,501, -435,501,434, -501,435,502, -436,502,435, -502,436,503, -437,503,436, -503,437,504, -438,504,437, -504,438,505, -439,505,438, -505,439,506, -440,506,439, -506,440,507, -441,507,440, -507,441,508, -442,508,441, -508,442,509, -443,509,442, -509,443,510, -444,510,443, -510,444,511, -445,511,444, -511,445,512, -446,512,445, -512,446,513, -447,513,446, -513,447,514, -448,514,447, -514,448,515, -449,515,448, -515,449,516, -450,516,449, -516,450,517, -451,517,450, -517,451,518, -452,518,451, -518,452,519, -453,519,452, -519,453,520, -454,520,453, -520,454,521, -455,521,454, -521,455,522, -456,522,455, -522,456,523, -457,523,456, -523,457,524, -458,524,457, -524,458,525, -459,525,458, -525,459,526, -460,526,459, -526,460,527, -461,527,460, -528,462,529, -463,529,462, -529,463,530, -464,530,463, -530,464,531, -465,531,464, -531,465,532, -466,532,465, -532,466,533, -467,533,466, -533,467,534, -468,534,467, -534,468,535, -469,535,468, -535,469,536, -470,536,469, -536,470,537, -471,537,470, -537,471,538, -472,538,471, -538,472,539, -473,539,472, -539,473,540, -474,540,473, -540,474,541, -475,541,474, -541,475,542, -476,542,475, -542,476,543, -477,543,476, -543,477,544, -478,544,477, -544,478,545, -479,545,478, -545,479,546, -480,546,479, -546,480,547, -481,547,480, -547,481,548, -482,548,481, -548,482,549, -483,549,482, -549,483,550, -484,550,483, -550,484,551, -485,551,484, -551,485,552, -486,552,485, -552,486,553, -487,553,486, -553,487,554, -488,554,487, -554,488,555, -489,555,488, -555,489,556, -490,556,489, -556,490,557, -491,557,490, -557,491,558, -492,558,491, -558,492,559, -493,559,492, -559,493,560, -494,560,493, -560,494,561, -495,561,494, -561,495,562, -496,562,495, -562,496,563, -497,563,496, -563,497,564, -498,564,497, -564,498,565, -499,565,498, -565,499,566, -500,566,499, -566,500,567, -501,567,500, -567,501,568, -502,568,501, -568,502,569, -503,569,502, -569,503,570, -504,570,503, -570,504,571, -505,571,504, -571,505,572, -506,572,505, -572,506,573, -507,573,506, -573,507,574, -508,574,507, -574,508,575, -509,575,508, -575,509,576, -510,576,509, -576,510,577, -511,577,510, -577,511,578, -512,578,511, -578,512,579, -513,579,512, -579,513,580, -514,580,513, -580,514,581, -515,581,514, -581,515,582, -516,582,515, -582,516,583, -517,583,516, -583,517,584, -518,584,517, -584,518,585, -519,585,518, -585,519,586, -520,586,519, -586,520,587, -521,587,520, -587,521,588, -522,588,521, -588,522,589, -523,589,522, -589,523,590, -524,590,523, -590,524,591, -525,591,524, -591,525,592, -526,592,525, -592,526,593, -527,593,526, -594,528,595, -529,595,528, -595,529,596, -530,596,529, -596,530,597, -531,597,530, -597,531,598, -532,598,531, -598,532,599, -533,599,532, -599,533,600, -534,600,533, -600,534,601, -535,601,534, -601,535,602, -536,602,535, -602,536,603, -537,603,536, -603,537,604, -538,604,537, -604,538,605, -539,605,538, -605,539,606, -540,606,539, -606,540,607, -541,607,540, -607,541,608, -542,608,541, -608,542,609, -543,609,542, -609,543,610, -544,610,543, -610,544,611, -545,611,544, -611,545,612, -546,612,545, -612,546,613, -547,613,546, -613,547,614, -548,614,547, -614,548,615, -549,615,548, -615,549,616, -550,616,549, -616,550,617, -551,617,550, -617,551,618, -552,618,551, -618,552,619, -553,619,552, -619,553,620, -554,620,553, -620,554,621, -555,621,554, -621,555,622, -556,622,555, -622,556,623, -557,623,556, -623,557,624, -558,624,557, -624,558,625, -559,625,558, -625,559,626, -560,626,559, -626,560,627, -561,627,560, -627,561,628, -562,628,561, -628,562,629, -563,629,562, -629,563,630, -564,630,563, -630,564,631, -565,631,564, -631,565,632, -566,632,565, -632,566,633, -567,633,566, -633,567,634, -568,634,567, -634,568,635, -569,635,568, -635,569,636, -570,636,569, -636,570,637, -571,637,570, -637,571,638, -572,638,571, -638,572,639, -573,639,572, -639,573,640, -574,640,573, -640,574,641, -575,641,574, -641,575,642, -576,642,575, -642,576,643, -577,643,576, -643,577,644, -578,644,577, -644,578,645, -579,645,578, -645,579,646, -580,646,579, -646,580,647, -581,647,580, -647,581,648, -582,648,581, -648,582,649, -583,649,582, -649,583,650, -584,650,583, -650,584,651, -585,651,584, -651,585,652, -586,652,585, -652,586,653, -587,653,586, -653,587,654, -588,654,587, -654,588,655, -589,655,588, -655,589,656, -590,656,589, -656,590,657, -591,657,590, -657,591,658, -592,658,591, -658,592,659, -593,659,592, -660,594,661, -595,661,594, -661,595,662, -596,662,595, -662,596,663, -597,663,596, -663,597,664, -598,664,597, -664,598,665, -599,665,598, -665,599,666, -600,666,599, -666,600,667, -601,667,600, -667,601,668, -602,668,601, -668,602,669, -603,669,602, -669,603,670, -604,670,603, -670,604,671, -605,671,604, -671,605,672, -606,672,605, -672,606,673, -607,673,606, -673,607,674, -608,674,607, -674,608,675, -609,675,608, -675,609,676, -610,676,609, -676,610,677, -611,677,610, -677,611,678, -612,678,611, -678,612,679, -613,679,612, -679,613,680, -614,680,613, -680,614,681, -615,681,614, -681,615,682, -616,682,615, -682,616,683, -617,683,616, -683,617,684, -618,684,617, -684,618,685, -619,685,618, -685,619,686, -620,686,619, -686,620,687, -621,687,620, -687,621,688, -622,688,621, -688,622,689, -623,689,622, -689,623,690, -624,690,623, -690,624,691, -625,691,624, -691,625,692, -626,692,625, -692,626,693, -627,693,626, -693,627,694, -628,694,627, -694,628,695, -629,695,628, -695,629,696, -630,696,629, -696,630,697, -631,697,630, -697,631,698, -632,698,631, -698,632,699, -633,699,632, -699,633,700, -634,700,633, -700,634,701, -635,701,634, -701,635,702, -636,702,635, -702,636,703, -637,703,636, -703,637,704, -638,704,637, -704,638,705, -639,705,638, -705,639,706, -640,706,639, -706,640,707, -641,707,640, -707,641,708, -642,708,641, -708,642,709, -643,709,642, -709,643,710, -644,710,643, -710,644,711, -645,711,644, -711,645,712, -646,712,645, -712,646,713, -647,713,646, -713,647,714, -648,714,647, -714,648,715, -649,715,648, -715,649,716, -650,716,649, -716,650,717, -651,717,650, -717,651,718, -652,718,651, -718,652,719, -653,719,652, -719,653,720, -654,720,653, -720,654,721, -655,721,654, -721,655,722, -656,722,655, -722,656,723, -657,723,656, -723,657,724, -658,724,657, -724,658,725, -659,725,658, -726,660,727, -661,727,660, -727,661,728, -662,728,661, -728,662,729, -663,729,662, -729,663,730, -664,730,663, -730,664,731, -665,731,664, -731,665,732, -666,732,665, -732,666,733, -667,733,666, -733,667,734, -668,734,667, -734,668,735, -669,735,668, -735,669,736, -670,736,669, -736,670,737, -671,737,670, -737,671,738, -672,738,671, -738,672,739, -673,739,672, -739,673,740, -674,740,673, -740,674,741, -675,741,674, -741,675,742, -676,742,675, -742,676,743, -677,743,676, -743,677,744, -678,744,677, -744,678,745, -679,745,678, -745,679,746, -680,746,679, -746,680,747, -681,747,680, -747,681,748, -682,748,681, -748,682,749, -683,749,682, -749,683,750, -684,750,683, -750,684,751, -685,751,684, -751,685,752, -686,752,685, -752,686,753, -687,753,686, -753,687,754, -688,754,687, -754,688,755, -689,755,688, -755,689,756, -690,756,689, -756,690,757, -691,757,690, -757,691,758, -692,758,691, -758,692,759, -693,759,692, -759,693,760, -694,760,693, -760,694,761, -695,761,694, -761,695,762, -696,762,695, -762,696,763, -697,763,696, -763,697,764, -698,764,697, -764,698,765, -699,765,698, -765,699,766, -700,766,699, -766,700,767, -701,767,700, -767,701,768, -702,768,701, -768,702,769, -703,769,702, -769,703,770, -704,770,703, -770,704,771, -705,771,704, -771,705,772, -706,772,705, -772,706,773, -707,773,706, -773,707,774, -708,774,707, -774,708,775, -709,775,708, -775,709,776, -710,776,709, -776,710,777, -711,777,710, -777,711,778, -712,778,711, -778,712,779, -713,779,712, -779,713,780, -714,780,713, -780,714,781, -715,781,714, -781,715,782, -716,782,715, -782,716,783, -717,783,716, -783,717,784, -718,784,717, -784,718,785, -719,785,718, -785,719,786, -720,786,719, -786,720,787, -721,787,720, -787,721,788, -722,788,721, -788,722,789, -723,789,722, -789,723,790, -724,790,723, -790,724,791, -725,791,724, -792,726,793, -727,793,726, -793,727,794, -728,794,727, -794,728,795, -729,795,728, -795,729,796, -730,796,729, -796,730,797, -731,797,730, -797,731,798, -732,798,731, -798,732,799, -733,799,732, -799,733,800, -734,800,733, -800,734,801, -735,801,734, -801,735,802, -736,802,735, -802,736,803, -737,803,736, -803,737,804, -738,804,737, -804,738,805, -739,805,738, -805,739,806, -740,806,739, -806,740,807, -741,807,740, -807,741,808, -742,808,741, -808,742,809, -743,809,742, -809,743,810, -744,810,743, -810,744,811, -745,811,744, -811,745,812, -746,812,745, -812,746,813, -747,813,746, -813,747,814, -748,814,747, -814,748,815, -749,815,748, -815,749,816, -750,816,749, -816,750,817, -751,817,750, -817,751,818, -752,818,751, -818,752,819, -753,819,752, -819,753,820, -754,820,753, -820,754,821, -755,821,754, -821,755,822, -756,822,755, -822,756,823, -757,823,756, -823,757,824, -758,824,757, -824,758,825, -759,825,758, -825,759,826, -760,826,759, -826,760,827, -761,827,760, -827,761,828, -762,828,761, -828,762,829, -763,829,762, -829,763,830, -764,830,763, -830,764,831, -765,831,764, -831,765,832, -766,832,765, -832,766,833, -767,833,766, -833,767,834, -768,834,767, -834,768,835, -769,835,768, -835,769,836, -770,836,769, -836,770,837, -771,837,770, -837,771,838, -772,838,771, -838,772,839, -773,839,772, -839,773,840, -774,840,773, -840,774,841, -775,841,774, -841,775,842, -776,842,775, -842,776,843, -777,843,776, -843,777,844, -778,844,777, -844,778,845, -779,845,778, -845,779,846, -780,846,779, -846,780,847, -781,847,780, -847,781,848, -782,848,781, -848,782,849, -783,849,782, -849,783,850, -784,850,783, -850,784,851, -785,851,784, -851,785,852, -786,852,785, -852,786,853, -787,853,786, -853,787,854, -788,854,787, -854,788,855, -789,855,788, -855,789,856, -790,856,789, -856,790,857, -791,857,790, -858,792,859, -793,859,792, -859,793,860, -794,860,793, -860,794,861, -795,861,794, -861,795,862, -796,862,795, -862,796,863, -797,863,796, -863,797,864, -798,864,797, -864,798,865, -799,865,798, -865,799,866, -800,866,799, -866,800,867, -801,867,800, -867,801,868, -802,868,801, -868,802,869, -803,869,802, -869,803,870, -804,870,803, -870,804,871, -805,871,804, -871,805,872, -806,872,805, -872,806,873, -807,873,806, -873,807,874, -808,874,807, -874,808,875, -809,875,808, -875,809,876, -810,876,809, -876,810,877, -811,877,810, -877,811,878, -812,878,811, -878,812,879, -813,879,812, -879,813,880, -814,880,813, -880,814,881, -815,881,814, -881,815,882, -816,882,815, -882,816,883, -817,883,816, -883,817,884, -818,884,817, -884,818,885, -819,885,818, -885,819,886, -820,886,819, -886,820,887, -821,887,820, -887,821,888, -822,888,821, -888,822,889, -823,889,822, -889,823,890, -824,890,823, -890,824,891, -825,891,824, -891,825,892, -826,892,825, -892,826,893, -827,893,826, -893,827,894, -828,894,827, -894,828,895, -829,895,828, -895,829,896, -830,896,829, -896,830,897, -831,897,830, -897,831,898, -832,898,831, -898,832,899, -833,899,832, -899,833,900, -834,900,833, -900,834,901, -835,901,834, -901,835,902, -836,902,835, -902,836,903, -837,903,836, -903,837,904, -838,904,837, -904,838,905, -839,905,838, -905,839,906, -840,906,839, -906,840,907, -841,907,840, -907,841,908, -842,908,841, -908,842,909, -843,909,842, -909,843,910, -844,910,843, -910,844,911, -845,911,844, -911,845,912, -846,912,845, -912,846,913, -847,913,846, -913,847,914, -848,914,847, -914,848,915, -849,915,848, -915,849,916, -850,916,849, -916,850,917, -851,917,850, -917,851,918, -852,918,851, -918,852,919, -853,919,852, -919,853,920, -854,920,853, -920,854,921, -855,921,854, -921,855,922, -856,922,855, -922,856,923, -857,923,856, -924,858,925, -859,925,858, -925,859,926, -860,926,859, -926,860,927, -861,927,860, -927,861,928, -862,928,861, -928,862,929, -863,929,862, -929,863,930, -864,930,863, -930,864,931, -865,931,864, -931,865,932, -866,932,865, -932,866,933, -867,933,866, -933,867,934, -868,934,867, -934,868,935, -869,935,868, -935,869,936, -870,936,869, -936,870,937, -871,937,870, -937,871,938, -872,938,871, -938,872,939, -873,939,872, -939,873,940, -874,940,873, -940,874,941, -875,941,874, -941,875,942, -876,942,875, -942,876,943, -877,943,876, -943,877,944, -878,944,877, -944,878,945, -879,945,878, -945,879,946, -880,946,879, -946,880,947, -881,947,880, -947,881,948, -882,948,881, -948,882,949, -883,949,882, -949,883,950, -884,950,883, -950,884,951, -885,951,884, -951,885,952, -886,952,885, -952,886,953, -887,953,886, -953,887,954, -888,954,887, -954,888,955, -889,955,888, -955,889,956, -890,956,889, -956,890,957, -891,957,890, -957,891,958, -892,958,891, -958,892,959, -893,959,892, -959,893,960, -894,960,893, -960,894,961, -895,961,894, -961,895,962, -896,962,895, -962,896,963, -897,963,896, -963,897,964, -898,964,897, -964,898,965, -899,965,898, -965,899,966, -900,966,899, -966,900,967, -901,967,900, -967,901,968, -902,968,901, -968,902,969, -903,969,902, -969,903,970, -904,970,903, -970,904,971, -905,971,904, -971,905,972, -906,972,905, -972,906,973, -907,973,906, -973,907,974, -908,974,907, -974,908,975, -909,975,908, -975,909,976, -910,976,909, -976,910,977, -911,977,910, -977,911,978, -912,978,911, -978,912,979, -913,979,912, -979,913,980, -914,980,913, -980,914,981, -915,981,914, -981,915,982, -916,982,915, -982,916,983, -917,983,916, -983,917,984, -918,984,917, -984,918,985, -919,985,918, -985,919,986, -920,986,919, -986,920,987, -921,987,920, -987,921,988, -922,988,921, -988,922,989, -923,989,922, -990,924,991, -925,991,924, -991,925,992, -926,992,925, -992,926,993, -927,993,926, -993,927,994, -928,994,927, -994,928,995, -929,995,928, -995,929,996, -930,996,929, -996,930,997, -931,997,930, -997,931,998, -932,998,931, -998,932,999, -933,999,932, -999,933,1000, -934,1000,933, -1000,934,1001, -935,1001,934, -1001,935,1002, -936,1002,935, -1002,936,1003, -937,1003,936, -1003,937,1004, -938,1004,937, -1004,938,1005, -939,1005,938, -1005,939,1006, -940,1006,939, -1006,940,1007, -941,1007,940, -1007,941,1008, -942,1008,941, -1008,942,1009, -943,1009,942, -1009,943,1010, -944,1010,943, -1010,944,1011, -945,1011,944, -1011,945,1012, -946,1012,945, -1012,946,1013, -947,1013,946, -1013,947,1014, -948,1014,947, -1014,948,1015, -949,1015,948, -1015,949,1016, -950,1016,949, -1016,950,1017, -951,1017,950, -1017,951,1018, -952,1018,951, -1018,952,1019, -953,1019,952, -1019,953,1020, -954,1020,953, -1020,954,1021, -955,1021,954, -1021,955,1022, -956,1022,955, -1022,956,1023, -957,1023,956, -1023,957,1024, -958,1024,957, -1024,958,1025, -959,1025,958, -1025,959,1026, -960,1026,959, -1026,960,1027, -961,1027,960, -1027,961,1028, -962,1028,961, -1028,962,1029, -963,1029,962, -1029,963,1030, -964,1030,963, -1030,964,1031, -965,1031,964, -1031,965,1032, -966,1032,965, -1032,966,1033, -967,1033,966, -1033,967,1034, -968,1034,967, -1034,968,1035, -969,1035,968, -1035,969,1036, -970,1036,969, -1036,970,1037, -971,1037,970, -1037,971,1038, -972,1038,971, -1038,972,1039, -973,1039,972, -1039,973,1040, -974,1040,973, -1040,974,1041, -975,1041,974, -1041,975,1042, -976,1042,975, -1042,976,1043, -977,1043,976, -1043,977,1044, -978,1044,977, -1044,978,1045, -979,1045,978, -1045,979,1046, -980,1046,979, -1046,980,1047, -981,1047,980, -1047,981,1048, -982,1048,981, -1048,982,1049, -983,1049,982, -1049,983,1050, -984,1050,983, -1050,984,1051, -985,1051,984, -1051,985,1052, -986,1052,985, -1052,986,1053, -987,1053,986, -1053,987,1054, -988,1054,987, -1054,988,1055, -989,1055,988, -1056,990,1057, -991,1057,990, -1057,991,1058, -992,1058,991, -1058,992,1059, -993,1059,992, -1059,993,1060, -994,1060,993, -1060,994,1061, -995,1061,994, -1061,995,1062, -996,1062,995, -1062,996,1063, -997,1063,996, -1063,997,1064, -998,1064,997, -1064,998,1065, -999,1065,998, -1065,999,1066, -1000,1066,999, -1066,1000,1067, -1001,1067,1000, -1067,1001,1068, -1002,1068,1001, -1068,1002,1069, -1003,1069,1002, -1069,1003,1070, -1004,1070,1003, -1070,1004,1071, -1005,1071,1004, -1071,1005,1072, -1006,1072,1005, -1072,1006,1073, -1007,1073,1006, -1073,1007,1074, -1008,1074,1007, -1074,1008,1075, -1009,1075,1008, -1075,1009,1076, -1010,1076,1009, -1076,1010,1077, -1011,1077,1010, -1077,1011,1078, -1012,1078,1011, -1078,1012,1079, -1013,1079,1012, -1079,1013,1080, -1014,1080,1013, -1080,1014,1081, -1015,1081,1014, -1081,1015,1082, -1016,1082,1015, -1082,1016,1083, -1017,1083,1016, -1083,1017,1084, -1018,1084,1017, -1084,1018,1085, -1019,1085,1018, -1085,1019,1086, -1020,1086,1019, -1086,1020,1087, -1021,1087,1020, -1087,1021,1088, -1022,1088,1021, -1088,1022,1089, -1023,1089,1022, -1089,1023,1090, -1024,1090,1023, -1090,1024,1091, -1025,1091,1024, -1091,1025,1092, -1026,1092,1025, -1092,1026,1093, -1027,1093,1026, -1093,1027,1094, -1028,1094,1027, -1094,1028,1095, -1029,1095,1028, -1095,1029,1096, -1030,1096,1029, -1096,1030,1097, -1031,1097,1030, -1097,1031,1098, -1032,1098,1031, -1098,1032,1099, -1033,1099,1032, -1099,1033,1100, -1034,1100,1033, -1100,1034,1101, -1035,1101,1034, -1101,1035,1102, -1036,1102,1035, -1102,1036,1103, -1037,1103,1036, -1103,1037,1104, -1038,1104,1037, -1104,1038,1105, -1039,1105,1038, -1105,1039,1106, -1040,1106,1039, -1106,1040,1107, -1041,1107,1040, -1107,1041,1108, -1042,1108,1041, -1108,1042,1109, -1043,1109,1042, -1109,1043,1110, -1044,1110,1043, -1110,1044,1111, -1045,1111,1044, -1111,1045,1112, -1046,1112,1045, -1112,1046,1113, -1047,1113,1046, -1113,1047,1114, -1048,1114,1047, -1114,1048,1115, -1049,1115,1048, -1115,1049,1116, -1050,1116,1049, -1116,1050,1117, -1051,1117,1050, -1117,1051,1118, -1052,1118,1051, -1118,1052,1119, -1053,1119,1052, -1119,1053,1120, -1054,1120,1053, -1120,1054,1121, -1055,1121,1054, -1122,1056,1123, -1057,1123,1056, -1123,1057,1124, -1058,1124,1057, -1124,1058,1125, -1059,1125,1058, -1125,1059,1126, -1060,1126,1059, -1126,1060,1127, -1061,1127,1060, -1127,1061,1128, -1062,1128,1061, -1128,1062,1129, -1063,1129,1062, -1129,1063,1130, -1064,1130,1063, -1130,1064,1131, -1065,1131,1064, -1131,1065,1132, -1066,1132,1065, -1132,1066,1133, -1067,1133,1066, -1133,1067,1134, -1068,1134,1067, -1134,1068,1135, -1069,1135,1068, -1135,1069,1136, -1070,1136,1069, -1136,1070,1137, -1071,1137,1070, -1137,1071,1138, -1072,1138,1071, -1138,1072,1139, -1073,1139,1072, -1139,1073,1140, -1074,1140,1073, -1140,1074,1141, -1075,1141,1074, -1141,1075,1142, -1076,1142,1075, -1142,1076,1143, -1077,1143,1076, -1143,1077,1144, -1078,1144,1077, -1144,1078,1145, -1079,1145,1078, -1145,1079,1146, -1080,1146,1079, -1146,1080,1147, -1081,1147,1080, -1147,1081,1148, -1082,1148,1081, -1148,1082,1149, -1083,1149,1082, -1149,1083,1150, -1084,1150,1083, -1150,1084,1151, -1085,1151,1084, -1151,1085,1152, -1086,1152,1085, -1152,1086,1153, -1087,1153,1086, -1153,1087,1154, -1088,1154,1087, -1154,1088,1155, -1089,1155,1088, -1155,1089,1156, -1090,1156,1089, -1156,1090,1157, -1091,1157,1090, -1157,1091,1158, -1092,1158,1091, -1158,1092,1159, -1093,1159,1092, -1159,1093,1160, -1094,1160,1093, -1160,1094,1161, -1095,1161,1094, -1161,1095,1162, -1096,1162,1095, -1162,1096,1163, -1097,1163,1096, -1163,1097,1164, -1098,1164,1097, -1164,1098,1165, -1099,1165,1098, -1165,1099,1166, -1100,1166,1099, -1166,1100,1167, -1101,1167,1100, -1167,1101,1168, -1102,1168,1101, -1168,1102,1169, -1103,1169,1102, -1169,1103,1170, -1104,1170,1103, -1170,1104,1171, -1105,1171,1104, -1171,1105,1172, -1106,1172,1105, -1172,1106,1173, -1107,1173,1106, -1173,1107,1174, -1108,1174,1107, -1174,1108,1175, -1109,1175,1108, -1175,1109,1176, -1110,1176,1109, -1176,1110,1177, -1111,1177,1110, -1177,1111,1178, -1112,1178,1111, -1178,1112,1179, -1113,1179,1112, -1179,1113,1180, -1114,1180,1113, -1180,1114,1181, -1115,1181,1114, -1181,1115,1182, -1116,1182,1115, -1182,1116,1183, -1117,1183,1116, -1183,1117,1184, -1118,1184,1117, -1184,1118,1185, -1119,1185,1118, -1185,1119,1186, -1120,1186,1119, -1186,1120,1187, -1121,1187,1120, -1188,1122,1189, -1123,1189,1122, -1189,1123,1190, -1124,1190,1123, -1190,1124,1191, -1125,1191,1124, -1191,1125,1192, -1126,1192,1125, -1192,1126,1193, -1127,1193,1126, -1193,1127,1194, -1128,1194,1127, -1194,1128,1195, -1129,1195,1128, -1195,1129,1196, -1130,1196,1129, -1196,1130,1197, -1131,1197,1130, -1197,1131,1198, -1132,1198,1131, -1198,1132,1199, -1133,1199,1132, -1199,1133,1200, -1134,1200,1133, -1200,1134,1201, -1135,1201,1134, -1201,1135,1202, -1136,1202,1135, -1202,1136,1203, -1137,1203,1136, -1203,1137,1204, -1138,1204,1137, -1204,1138,1205, -1139,1205,1138, -1205,1139,1206, -1140,1206,1139, -1206,1140,1207, -1141,1207,1140, -1207,1141,1208, -1142,1208,1141, -1208,1142,1209, -1143,1209,1142, -1209,1143,1210, -1144,1210,1143, -1210,1144,1211, -1145,1211,1144, -1211,1145,1212, -1146,1212,1145, -1212,1146,1213, -1147,1213,1146, -1213,1147,1214, -1148,1214,1147, -1214,1148,1215, -1149,1215,1148, -1215,1149,1216, -1150,1216,1149, -1216,1150,1217, -1151,1217,1150, -1217,1151,1218, -1152,1218,1151, -1218,1152,1219, -1153,1219,1152, -1219,1153,1220, -1154,1220,1153, -1220,1154,1221, -1155,1221,1154, -1221,1155,1222, -1156,1222,1155, -1222,1156,1223, -1157,1223,1156, -1223,1157,1224, -1158,1224,1157, -1224,1158,1225, -1159,1225,1158, -1225,1159,1226, -1160,1226,1159, -1226,1160,1227, -1161,1227,1160, -1227,1161,1228, -1162,1228,1161, -1228,1162,1229, -1163,1229,1162, -1229,1163,1230, -1164,1230,1163, -1230,1164,1231, -1165,1231,1164, -1231,1165,1232, -1166,1232,1165, -1232,1166,1233, -1167,1233,1166, -1233,1167,1234, -1168,1234,1167, -1234,1168,1235, -1169,1235,1168, -1235,1169,1236, -1170,1236,1169, -1236,1170,1237, -1171,1237,1170, -1237,1171,1238, -1172,1238,1171, -1238,1172,1239, -1173,1239,1172, -1239,1173,1240, -1174,1240,1173, -1240,1174,1241, -1175,1241,1174, -1241,1175,1242, -1176,1242,1175, -1242,1176,1243, -1177,1243,1176, -1243,1177,1244, -1178,1244,1177, -1244,1178,1245, -1179,1245,1178, -1245,1179,1246, -1180,1246,1179, -1246,1180,1247, -1181,1247,1180, -1247,1181,1248, -1182,1248,1181, -1248,1182,1249, -1183,1249,1182, -1249,1183,1250, -1184,1250,1183, -1250,1184,1251, -1185,1251,1184, -1251,1185,1252, -1186,1252,1185, -1252,1186,1253, -1187,1253,1186, -1254,1188,1255, -1189,1255,1188, -1255,1189,1256, -1190,1256,1189, -1256,1190,1257, -1191,1257,1190, -1257,1191,1258, -1192,1258,1191, -1258,1192,1259, -1193,1259,1192, -1259,1193,1260, -1194,1260,1193, -1260,1194,1261, -1195,1261,1194, -1261,1195,1262, -1196,1262,1195, -1262,1196,1263, -1197,1263,1196, -1263,1197,1264, -1198,1264,1197, -1264,1198,1265, -1199,1265,1198, -1265,1199,1266, -1200,1266,1199, -1266,1200,1267, -1201,1267,1200, -1267,1201,1268, -1202,1268,1201, -1268,1202,1269, -1203,1269,1202, -1269,1203,1270, -1204,1270,1203, -1270,1204,1271, -1205,1271,1204, -1271,1205,1272, -1206,1272,1205, -1272,1206,1273, -1207,1273,1206, -1273,1207,1274, -1208,1274,1207, -1274,1208,1275, -1209,1275,1208, -1275,1209,1276, -1210,1276,1209, -1276,1210,1277, -1211,1277,1210, -1277,1211,1278, -1212,1278,1211, -1278,1212,1279, -1213,1279,1212, -1279,1213,1280, -1214,1280,1213, -1280,1214,1281, -1215,1281,1214, -1281,1215,1282, -1216,1282,1215, -1282,1216,1283, -1217,1283,1216, -1283,1217,1284, -1218,1284,1217, -1284,1218,1285, -1219,1285,1218, -1285,1219,1286, -1220,1286,1219, -1286,1220,1287, -1221,1287,1220, -1287,1221,1288, -1222,1288,1221, -1288,1222,1289, -1223,1289,1222, -1289,1223,1290, -1224,1290,1223, -1290,1224,1291, -1225,1291,1224, -1291,1225,1292, -1226,1292,1225, -1292,1226,1293, -1227,1293,1226, -1293,1227,1294, -1228,1294,1227, -1294,1228,1295, -1229,1295,1228, -1295,1229,1296, -1230,1296,1229, -1296,1230,1297, -1231,1297,1230, -1297,1231,1298, -1232,1298,1231, -1298,1232,1299, -1233,1299,1232, -1299,1233,1300, -1234,1300,1233, -1300,1234,1301, -1235,1301,1234, -1301,1235,1302, -1236,1302,1235, -1302,1236,1303, -1237,1303,1236, -1303,1237,1304, -1238,1304,1237, -1304,1238,1305, -1239,1305,1238, -1305,1239,1306, -1240,1306,1239, -1306,1240,1307, -1241,1307,1240, -1307,1241,1308, -1242,1308,1241, -1308,1242,1309, -1243,1309,1242, -1309,1243,1310, -1244,1310,1243, -1310,1244,1311, -1245,1311,1244, -1311,1245,1312, -1246,1312,1245, -1312,1246,1313, -1247,1313,1246, -1313,1247,1314, -1248,1314,1247, -1314,1248,1315, -1249,1315,1248, -1315,1249,1316, -1250,1316,1249, -1316,1250,1317, -1251,1317,1250, -1317,1251,1318, -1252,1318,1251, -1318,1252,1319, -1253,1319,1252, -1320,1254,1321, -1255,1321,1254, -1321,1255,1322, -1256,1322,1255, -1322,1256,1323, -1257,1323,1256, -1323,1257,1324, -1258,1324,1257, -1324,1258,1325, -1259,1325,1258, -1325,1259,1326, -1260,1326,1259, -1326,1260,1327, -1261,1327,1260, -1327,1261,1328, -1262,1328,1261, -1328,1262,1329, -1263,1329,1262, -1329,1263,1330, -1264,1330,1263, -1330,1264,1331, -1265,1331,1264, -1331,1265,1332, -1266,1332,1265, -1332,1266,1333, -1267,1333,1266, -1333,1267,1334, -1268,1334,1267, -1334,1268,1335, -1269,1335,1268, -1335,1269,1336, -1270,1336,1269, -1336,1270,1337, -1271,1337,1270, -1337,1271,1338, -1272,1338,1271, -1338,1272,1339, -1273,1339,1272, -1339,1273,1340, -1274,1340,1273, -1340,1274,1341, -1275,1341,1274, -1341,1275,1342, -1276,1342,1275, -1342,1276,1343, -1277,1343,1276, -1343,1277,1344, -1278,1344,1277, -1344,1278,1345, -1279,1345,1278, -1345,1279,1346, -1280,1346,1279, -1346,1280,1347, -1281,1347,1280, -1347,1281,1348, -1282,1348,1281, -1348,1282,1349, -1283,1349,1282, -1349,1283,1350, -1284,1350,1283, -1350,1284,1351, -1285,1351,1284, -1351,1285,1352, -1286,1352,1285, -1352,1286,1353, -1287,1353,1286, -1353,1287,1354, -1288,1354,1287, -1354,1288,1355, -1289,1355,1288, -1355,1289,1356, -1290,1356,1289, -1356,1290,1357, -1291,1357,1290, -1357,1291,1358, -1292,1358,1291, -1358,1292,1359, -1293,1359,1292, -1359,1293,1360, -1294,1360,1293, -1360,1294,1361, -1295,1361,1294, -1361,1295,1362, -1296,1362,1295, -1362,1296,1363, -1297,1363,1296, -1363,1297,1364, -1298,1364,1297, -1364,1298,1365, -1299,1365,1298, -1365,1299,1366, -1300,1366,1299, -1366,1300,1367, -1301,1367,1300, -1367,1301,1368, -1302,1368,1301, -1368,1302,1369, -1303,1369,1302, -1369,1303,1370, -1304,1370,1303, -1370,1304,1371, -1305,1371,1304, -1371,1305,1372, -1306,1372,1305, -1372,1306,1373, -1307,1373,1306, -1373,1307,1374, -1308,1374,1307, -1374,1308,1375, -1309,1375,1308, -1375,1309,1376, -1310,1376,1309, -1376,1310,1377, -1311,1377,1310, -1377,1311,1378, -1312,1378,1311, -1378,1312,1379, -1313,1379,1312, -1379,1313,1380, -1314,1380,1313, -1380,1314,1381, -1315,1381,1314, -1381,1315,1382, -1316,1382,1315, -1382,1316,1383, -1317,1383,1316, -1383,1317,1384, -1318,1384,1317, -1384,1318,1385, -1319,1385,1318, -1386,1320,1387, -1321,1387,1320, -1387,1321,1388, -1322,1388,1321, -1388,1322,1389, -1323,1389,1322, -1389,1323,1390, -1324,1390,1323, -1390,1324,1391, -1325,1391,1324, -1391,1325,1392, -1326,1392,1325, -1392,1326,1393, -1327,1393,1326, -1393,1327,1394, -1328,1394,1327, -1394,1328,1395, -1329,1395,1328, -1395,1329,1396, -1330,1396,1329, -1396,1330,1397, -1331,1397,1330, -1397,1331,1398, -1332,1398,1331, -1398,1332,1399, -1333,1399,1332, -1399,1333,1400, -1334,1400,1333, -1400,1334,1401, -1335,1401,1334, -1401,1335,1402, -1336,1402,1335, -1402,1336,1403, -1337,1403,1336, -1403,1337,1404, -1338,1404,1337, -1404,1338,1405, -1339,1405,1338, -1405,1339,1406, -1340,1406,1339, -1406,1340,1407, -1341,1407,1340, -1407,1341,1408, -1342,1408,1341, -1408,1342,1409, -1343,1409,1342, -1409,1343,1410, -1344,1410,1343, -1410,1344,1411, -1345,1411,1344, -1411,1345,1412, -1346,1412,1345, -1412,1346,1413, -1347,1413,1346, -1413,1347,1414, -1348,1414,1347, -1414,1348,1415, -1349,1415,1348, -1415,1349,1416, -1350,1416,1349, -1416,1350,1417, -1351,1417,1350, -1417,1351,1418, -1352,1418,1351, -1418,1352,1419, -1353,1419,1352, -1419,1353,1420, -1354,1420,1353, -1420,1354,1421, -1355,1421,1354, -1421,1355,1422, -1356,1422,1355, -1422,1356,1423, -1357,1423,1356, -1423,1357,1424, -1358,1424,1357, -1424,1358,1425, -1359,1425,1358, -1425,1359,1426, -1360,1426,1359, -1426,1360,1427, -1361,1427,1360, -1427,1361,1428, -1362,1428,1361, -1428,1362,1429, -1363,1429,1362, -1429,1363,1430, -1364,1430,1363, -1430,1364,1431, -1365,1431,1364, -1431,1365,1432, -1366,1432,1365, -1432,1366,1433, -1367,1433,1366, -1433,1367,1434, -1368,1434,1367, -1434,1368,1435, -1369,1435,1368, -1435,1369,1436, -1370,1436,1369, -1436,1370,1437, -1371,1437,1370, -1437,1371,1438, -1372,1438,1371, -1438,1372,1439, -1373,1439,1372, -1439,1373,1440, -1374,1440,1373, -1440,1374,1441, -1375,1441,1374, -1441,1375,1442, -1376,1442,1375, -1442,1376,1443, -1377,1443,1376, -1443,1377,1444, -1378,1444,1377, -1444,1378,1445, -1379,1445,1378, -1445,1379,1446, -1380,1446,1379, -1446,1380,1447, -1381,1447,1380, -1447,1381,1448, -1382,1448,1381, -1448,1382,1449, -1383,1449,1382, -1449,1383,1450, -1384,1450,1383, -1450,1384,1451, -1385,1451,1384, -1452,1386,1453, -1387,1453,1386, -1453,1387,1454, -1388,1454,1387, -1454,1388,1455, -1389,1455,1388, -1455,1389,1456, -1390,1456,1389, -1456,1390,1457, -1391,1457,1390, -1457,1391,1458, -1392,1458,1391, -1458,1392,1459, -1393,1459,1392, -1459,1393,1460, -1394,1460,1393, -1460,1394,1461, -1395,1461,1394, -1461,1395,1462, -1396,1462,1395, -1462,1396,1463, -1397,1463,1396, -1463,1397,1464, -1398,1464,1397, -1464,1398,1465, -1399,1465,1398, -1465,1399,1466, -1400,1466,1399, -1466,1400,1467, -1401,1467,1400, -1467,1401,1468, -1402,1468,1401, -1468,1402,1469, -1403,1469,1402, -1469,1403,1470, -1404,1470,1403, -1470,1404,1471, -1405,1471,1404, -1471,1405,1472, -1406,1472,1405, -1472,1406,1473, -1407,1473,1406, -1473,1407,1474, -1408,1474,1407, -1474,1408,1475, -1409,1475,1408, -1475,1409,1476, -1410,1476,1409, -1476,1410,1477, -1411,1477,1410, -1477,1411,1478, -1412,1478,1411, -1478,1412,1479, -1413,1479,1412, -1479,1413,1480, -1414,1480,1413, -1480,1414,1481, -1415,1481,1414, -1481,1415,1482, -1416,1482,1415, -1482,1416,1483, -1417,1483,1416, -1483,1417,1484, -1418,1484,1417, -1484,1418,1485, -1419,1485,1418, -1485,1419,1486, -1420,1486,1419, -1486,1420,1487, -1421,1487,1420, -1487,1421,1488, -1422,1488,1421, -1488,1422,1489, -1423,1489,1422, -1489,1423,1490, -1424,1490,1423, -1490,1424,1491, -1425,1491,1424, -1491,1425,1492, -1426,1492,1425, -1492,1426,1493, -1427,1493,1426, -1493,1427,1494, -1428,1494,1427, -1494,1428,1495, -1429,1495,1428, -1495,1429,1496, -1430,1496,1429, -1496,1430,1497, -1431,1497,1430, -1497,1431,1498, -1432,1498,1431, -1498,1432,1499, -1433,1499,1432, -1499,1433,1500, -1434,1500,1433, -1500,1434,1501, -1435,1501,1434, -1501,1435,1502, -1436,1502,1435, -1502,1436,1503, -1437,1503,1436, -1503,1437,1504, -1438,1504,1437, -1504,1438,1505, -1439,1505,1438, -1505,1439,1506, -1440,1506,1439, -1506,1440,1507, -1441,1507,1440, -1507,1441,1508, -1442,1508,1441, -1508,1442,1509, -1443,1509,1442, -1509,1443,1510, -1444,1510,1443, -1510,1444,1511, -1445,1511,1444, -1511,1445,1512, -1446,1512,1445, -1512,1446,1513, -1447,1513,1446, -1513,1447,1514, -1448,1514,1447, -1514,1448,1515, -1449,1515,1448, -1515,1449,1516, -1450,1516,1449, -1516,1450,1517, -1451,1517,1450, -1518,1452,1519, -1453,1519,1452, -1519,1453,1520, -1454,1520,1453, -1520,1454,1521, -1455,1521,1454, -1521,1455,1522, -1456,1522,1455, -1522,1456,1523, -1457,1523,1456, -1523,1457,1524, -1458,1524,1457, -1524,1458,1525, -1459,1525,1458, -1525,1459,1526, -1460,1526,1459, -1526,1460,1527, -1461,1527,1460, -1527,1461,1528, -1462,1528,1461, -1528,1462,1529, -1463,1529,1462, -1529,1463,1530, -1464,1530,1463, -1530,1464,1531, -1465,1531,1464, -1531,1465,1532, -1466,1532,1465, -1532,1466,1533, -1467,1533,1466, -1533,1467,1534, -1468,1534,1467, -1534,1468,1535, -1469,1535,1468, -1535,1469,1536, -1470,1536,1469, -1536,1470,1537, -1471,1537,1470, -1537,1471,1538, -1472,1538,1471, -1538,1472,1539, -1473,1539,1472, -1539,1473,1540, -1474,1540,1473, -1540,1474,1541, -1475,1541,1474, -1541,1475,1542, -1476,1542,1475, -1542,1476,1543, -1477,1543,1476, -1543,1477,1544, -1478,1544,1477, -1544,1478,1545, -1479,1545,1478, -1545,1479,1546, -1480,1546,1479, -1546,1480,1547, -1481,1547,1480, -1547,1481,1548, -1482,1548,1481, -1548,1482,1549, -1483,1549,1482, -1549,1483,1550, -1484,1550,1483, -1550,1484,1551, -1485,1551,1484, -1551,1485,1552, -1486,1552,1485, -1552,1486,1553, -1487,1553,1486, -1553,1487,1554, -1488,1554,1487, -1554,1488,1555, -1489,1555,1488, -1555,1489,1556, -1490,1556,1489, -1556,1490,1557, -1491,1557,1490, -1557,1491,1558, -1492,1558,1491, -1558,1492,1559, -1493,1559,1492, -1559,1493,1560, -1494,1560,1493, -1560,1494,1561, -1495,1561,1494, -1561,1495,1562, -1496,1562,1495, -1562,1496,1563, -1497,1563,1496, -1563,1497,1564, -1498,1564,1497, -1564,1498,1565, -1499,1565,1498, -1565,1499,1566, -1500,1566,1499, -1566,1500,1567, -1501,1567,1500, -1567,1501,1568, -1502,1568,1501, -1568,1502,1569, -1503,1569,1502, -1569,1503,1570, -1504,1570,1503, -1570,1504,1571, -1505,1571,1504, -1571,1505,1572, -1506,1572,1505, -1572,1506,1573, -1507,1573,1506, -1573,1507,1574, -1508,1574,1507, -1574,1508,1575, -1509,1575,1508, -1575,1509,1576, -1510,1576,1509, -1576,1510,1577, -1511,1577,1510, -1577,1511,1578, -1512,1578,1511, -1578,1512,1579, -1513,1579,1512, -1579,1513,1580, -1514,1580,1513, -1580,1514,1581, -1515,1581,1514, -1581,1515,1582, -1516,1582,1515, -1582,1516,1583, -1517,1583,1516, -1584,1518,1585, -1519,1585,1518, -1585,1519,1586, -1520,1586,1519, -1586,1520,1587, -1521,1587,1520, -1587,1521,1588, -1522,1588,1521, -1588,1522,1589, -1523,1589,1522, -1589,1523,1590, -1524,1590,1523, -1590,1524,1591, -1525,1591,1524, -1591,1525,1592, -1526,1592,1525, -1592,1526,1593, -1527,1593,1526, -1593,1527,1594, -1528,1594,1527, -1594,1528,1595, -1529,1595,1528, -1595,1529,1596, -1530,1596,1529, -1596,1530,1597, -1531,1597,1530, -1597,1531,1598, -1532,1598,1531, -1598,1532,1599, -1533,1599,1532, -1599,1533,1600, -1534,1600,1533, -1600,1534,1601, -1535,1601,1534, -1601,1535,1602, -1536,1602,1535, -1602,1536,1603, -1537,1603,1536, -1603,1537,1604, -1538,1604,1537, -1604,1538,1605, -1539,1605,1538, -1605,1539,1606, -1540,1606,1539, -1606,1540,1607, -1541,1607,1540, -1607,1541,1608, -1542,1608,1541, -1608,1542,1609, -1543,1609,1542, -1609,1543,1610, -1544,1610,1543, -1610,1544,1611, -1545,1611,1544, -1611,1545,1612, -1546,1612,1545, -1612,1546,1613, -1547,1613,1546, -1613,1547,1614, -1548,1614,1547, -1614,1548,1615, -1549,1615,1548, -1615,1549,1616, -1550,1616,1549, -1616,1550,1617, -1551,1617,1550, -1617,1551,1618, -1552,1618,1551, -1618,1552,1619, -1553,1619,1552, -1619,1553,1620, -1554,1620,1553, -1620,1554,1621, -1555,1621,1554, -1621,1555,1622, -1556,1622,1555, -1622,1556,1623, -1557,1623,1556, -1623,1557,1624, -1558,1624,1557, -1624,1558,1625, -1559,1625,1558, -1625,1559,1626, -1560,1626,1559, -1626,1560,1627, -1561,1627,1560, -1627,1561,1628, -1562,1628,1561, -1628,1562,1629, -1563,1629,1562, -1629,1563,1630, -1564,1630,1563, -1630,1564,1631, -1565,1631,1564, -1631,1565,1632, -1566,1632,1565, -1632,1566,1633, -1567,1633,1566, -1633,1567,1634, -1568,1634,1567, -1634,1568,1635, -1569,1635,1568, -1635,1569,1636, -1570,1636,1569, -1636,1570,1637, -1571,1637,1570, -1637,1571,1638, -1572,1638,1571, -1638,1572,1639, -1573,1639,1572, -1639,1573,1640, -1574,1640,1573, -1640,1574,1641, -1575,1641,1574, -1641,1575,1642, -1576,1642,1575, -1642,1576,1643, -1577,1643,1576, -1643,1577,1644, -1578,1644,1577, -1644,1578,1645, -1579,1645,1578, -1645,1579,1646, -1580,1646,1579, -1646,1580,1647, -1581,1647,1580, -1647,1581,1648, -1582,1648,1581, -1648,1582,1649, -1583,1649,1582, -1650,1584,1651, -1585,1651,1584, -1651,1585,1652, -1586,1652,1585, -1652,1586,1653, -1587,1653,1586, -1653,1587,1654, -1588,1654,1587, -1654,1588,1655, -1589,1655,1588, -1655,1589,1656, -1590,1656,1589, -1656,1590,1657, -1591,1657,1590, -1657,1591,1658, -1592,1658,1591, -1658,1592,1659, -1593,1659,1592, -1659,1593,1660, -1594,1660,1593, -1660,1594,1661, -1595,1661,1594, -1661,1595,1662, -1596,1662,1595, -1662,1596,1663, -1597,1663,1596, -1663,1597,1664, -1598,1664,1597, -1664,1598,1665, -1599,1665,1598, -1665,1599,1666, -1600,1666,1599, -1666,1600,1667, -1601,1667,1600, -1667,1601,1668, -1602,1668,1601, -1668,1602,1669, -1603,1669,1602, -1669,1603,1670, -1604,1670,1603, -1670,1604,1671, -1605,1671,1604, -1671,1605,1672, -1606,1672,1605, -1672,1606,1673, -1607,1673,1606, -1673,1607,1674, -1608,1674,1607, -1674,1608,1675, -1609,1675,1608, -1675,1609,1676, -1610,1676,1609, -1676,1610,1677, -1611,1677,1610, -1677,1611,1678, -1612,1678,1611, -1678,1612,1679, -1613,1679,1612, -1679,1613,1680, -1614,1680,1613, -1680,1614,1681, -1615,1681,1614, -1681,1615,1682, -1616,1682,1615, -1682,1616,1683, -1617,1683,1616, -1683,1617,1684, -1618,1684,1617, -1684,1618,1685, -1619,1685,1618, -1685,1619,1686, -1620,1686,1619, -1686,1620,1687, -1621,1687,1620, -1687,1621,1688, -1622,1688,1621, -1688,1622,1689, -1623,1689,1622, -1689,1623,1690, -1624,1690,1623, -1690,1624,1691, -1625,1691,1624, -1691,1625,1692, -1626,1692,1625, -1692,1626,1693, -1627,1693,1626, -1693,1627,1694, -1628,1694,1627, -1694,1628,1695, -1629,1695,1628, -1695,1629,1696, -1630,1696,1629, -1696,1630,1697, -1631,1697,1630, -1697,1631,1698, -1632,1698,1631, -1698,1632,1699, -1633,1699,1632, -1699,1633,1700, -1634,1700,1633, -1700,1634,1701, -1635,1701,1634, -1701,1635,1702, -1636,1702,1635, -1702,1636,1703, -1637,1703,1636, -1703,1637,1704, -1638,1704,1637, -1704,1638,1705, -1639,1705,1638, -1705,1639,1706, -1640,1706,1639, -1706,1640,1707, -1641,1707,1640, -1707,1641,1708, -1642,1708,1641, -1708,1642,1709, -1643,1709,1642, -1709,1643,1710, -1644,1710,1643, -1710,1644,1711, -1645,1711,1644, -1711,1645,1712, -1646,1712,1645, -1712,1646,1713, -1647,1713,1646, -1713,1647,1714, -1648,1714,1647, -1714,1648,1715, -1649,1715,1648, -1716,1650,1717, -1651,1717,1650, -1717,1651,1718, -1652,1718,1651, -1718,1652,1719, -1653,1719,1652, -1719,1653,1720, -1654,1720,1653, -1720,1654,1721, -1655,1721,1654, -1721,1655,1722, -1656,1722,1655, -1722,1656,1723, -1657,1723,1656, -1723,1657,1724, -1658,1724,1657, -1724,1658,1725, -1659,1725,1658, -1725,1659,1726, -1660,1726,1659, -1726,1660,1727, -1661,1727,1660, -1727,1661,1728, -1662,1728,1661, -1728,1662,1729, -1663,1729,1662, -1729,1663,1730, -1664,1730,1663, -1730,1664,1731, -1665,1731,1664, -1731,1665,1732, -1666,1732,1665, -1732,1666,1733, -1667,1733,1666, -1733,1667,1734, -1668,1734,1667, -1734,1668,1735, -1669,1735,1668, -1735,1669,1736, -1670,1736,1669, -1736,1670,1737, -1671,1737,1670, -1737,1671,1738, -1672,1738,1671, -1738,1672,1739, -1673,1739,1672, -1739,1673,1740, -1674,1740,1673, -1740,1674,1741, -1675,1741,1674, -1741,1675,1742, -1676,1742,1675, -1742,1676,1743, -1677,1743,1676, -1743,1677,1744, -1678,1744,1677, -1744,1678,1745, -1679,1745,1678, -1745,1679,1746, -1680,1746,1679, -1746,1680,1747, -1681,1747,1680, -1747,1681,1748, -1682,1748,1681, -1748,1682,1749, -1683,1749,1682, -1749,1683,1750, -1684,1750,1683, -1750,1684,1751, -1685,1751,1684, -1751,1685,1752, -1686,1752,1685, -1752,1686,1753, -1687,1753,1686, -1753,1687,1754, -1688,1754,1687, -1754,1688,1755, -1689,1755,1688, -1755,1689,1756, -1690,1756,1689, -1756,1690,1757, -1691,1757,1690, -1757,1691,1758, -1692,1758,1691, -1758,1692,1759, -1693,1759,1692, -1759,1693,1760, -1694,1760,1693, -1760,1694,1761, -1695,1761,1694, -1761,1695,1762, -1696,1762,1695, -1762,1696,1763, -1697,1763,1696, -1763,1697,1764, -1698,1764,1697, -1764,1698,1765, -1699,1765,1698, -1765,1699,1766, -1700,1766,1699, -1766,1700,1767, -1701,1767,1700, -1767,1701,1768, -1702,1768,1701, -1768,1702,1769, -1703,1769,1702, -1769,1703,1770, -1704,1770,1703, -1770,1704,1771, -1705,1771,1704, -1771,1705,1772, -1706,1772,1705, -1772,1706,1773, -1707,1773,1706, -1773,1707,1774, -1708,1774,1707, -1774,1708,1775, -1709,1775,1708, -1775,1709,1776, -1710,1776,1709, -1776,1710,1777, -1711,1777,1710, -1777,1711,1778, -1712,1778,1711, -1778,1712,1779, -1713,1779,1712, -1779,1713,1780, -1714,1780,1713, -1780,1714,1781, -1715,1781,1714, -1782,1716,1783, -1717,1783,1716, -1783,1717,1784, -1718,1784,1717, -1784,1718,1785, -1719,1785,1718, -1785,1719,1786, -1720,1786,1719, -1786,1720,1787, -1721,1787,1720, -1787,1721,1788, -1722,1788,1721, -1788,1722,1789, -1723,1789,1722, -1789,1723,1790, -1724,1790,1723, -1790,1724,1791, -1725,1791,1724, -1791,1725,1792, -1726,1792,1725, -1792,1726,1793, -1727,1793,1726, -1793,1727,1794, -1728,1794,1727, -1794,1728,1795, -1729,1795,1728, -1795,1729,1796, -1730,1796,1729, -1796,1730,1797, -1731,1797,1730, -1797,1731,1798, -1732,1798,1731, -1798,1732,1799, -1733,1799,1732, -1799,1733,1800, -1734,1800,1733, -1800,1734,1801, -1735,1801,1734, -1801,1735,1802, -1736,1802,1735, -1802,1736,1803, -1737,1803,1736, -1803,1737,1804, -1738,1804,1737, -1804,1738,1805, -1739,1805,1738, -1805,1739,1806, -1740,1806,1739, -1806,1740,1807, -1741,1807,1740, -1807,1741,1808, -1742,1808,1741, -1808,1742,1809, -1743,1809,1742, -1809,1743,1810, -1744,1810,1743, -1810,1744,1811, -1745,1811,1744, -1811,1745,1812, -1746,1812,1745, -1812,1746,1813, -1747,1813,1746, -1813,1747,1814, -1748,1814,1747, -1814,1748,1815, -1749,1815,1748, -1815,1749,1816, -1750,1816,1749, -1816,1750,1817, -1751,1817,1750, -1817,1751,1818, -1752,1818,1751, -1818,1752,1819, -1753,1819,1752, -1819,1753,1820, -1754,1820,1753, -1820,1754,1821, -1755,1821,1754, -1821,1755,1822, -1756,1822,1755, -1822,1756,1823, -1757,1823,1756, -1823,1757,1824, -1758,1824,1757, -1824,1758,1825, -1759,1825,1758, -1825,1759,1826, -1760,1826,1759, -1826,1760,1827, -1761,1827,1760, -1827,1761,1828, -1762,1828,1761, -1828,1762,1829, -1763,1829,1762, -1829,1763,1830, -1764,1830,1763, -1830,1764,1831, -1765,1831,1764, -1831,1765,1832, -1766,1832,1765, -1832,1766,1833, -1767,1833,1766, -1833,1767,1834, -1768,1834,1767, -1834,1768,1835, -1769,1835,1768, -1835,1769,1836, -1770,1836,1769, -1836,1770,1837, -1771,1837,1770, -1837,1771,1838, -1772,1838,1771, -1838,1772,1839, -1773,1839,1772, -1839,1773,1840, -1774,1840,1773, -1840,1774,1841, -1775,1841,1774, -1841,1775,1842, -1776,1842,1775, -1842,1776,1843, -1777,1843,1776, -1843,1777,1844, -1778,1844,1777, -1844,1778,1845, -1779,1845,1778, -1845,1779,1846, -1780,1846,1779, -1846,1780,1847, -1781,1847,1780, -1848,1782,1849, -1783,1849,1782, -1849,1783,1850, -1784,1850,1783, -1850,1784,1851, -1785,1851,1784, -1851,1785,1852, -1786,1852,1785, -1852,1786,1853, -1787,1853,1786, -1853,1787,1854, -1788,1854,1787, -1854,1788,1855, -1789,1855,1788, -1855,1789,1856, -1790,1856,1789, -1856,1790,1857, -1791,1857,1790, -1857,1791,1858, -1792,1858,1791, -1858,1792,1859, -1793,1859,1792, -1859,1793,1860, -1794,1860,1793, -1860,1794,1861, -1795,1861,1794, -1861,1795,1862, -1796,1862,1795, -1862,1796,1863, -1797,1863,1796, -1863,1797,1864, -1798,1864,1797, -1864,1798,1865, -1799,1865,1798, -1865,1799,1866, -1800,1866,1799, -1866,1800,1867, -1801,1867,1800, -1867,1801,1868, -1802,1868,1801, -1868,1802,1869, -1803,1869,1802, -1869,1803,1870, -1804,1870,1803, -1870,1804,1871, -1805,1871,1804, -1871,1805,1872, -1806,1872,1805, -1872,1806,1873, -1807,1873,1806, -1873,1807,1874, -1808,1874,1807, -1874,1808,1875, -1809,1875,1808, -1875,1809,1876, -1810,1876,1809, -1876,1810,1877, -1811,1877,1810, -1877,1811,1878, -1812,1878,1811, -1878,1812,1879, -1813,1879,1812, -1879,1813,1880, -1814,1880,1813, -1880,1814,1881, -1815,1881,1814, -1881,1815,1882, -1816,1882,1815, -1882,1816,1883, -1817,1883,1816, -1883,1817,1884, -1818,1884,1817, -1884,1818,1885, -1819,1885,1818, -1885,1819,1886, -1820,1886,1819, -1886,1820,1887, -1821,1887,1820, -1887,1821,1888, -1822,1888,1821, -1888,1822,1889, -1823,1889,1822, -1889,1823,1890, -1824,1890,1823, -1890,1824,1891, -1825,1891,1824, -1891,1825,1892, -1826,1892,1825, -1892,1826,1893, -1827,1893,1826, -1893,1827,1894, -1828,1894,1827, -1894,1828,1895, -1829,1895,1828, -1895,1829,1896, -1830,1896,1829, -1896,1830,1897, -1831,1897,1830, -1897,1831,1898, -1832,1898,1831, -1898,1832,1899, -1833,1899,1832, -1899,1833,1900, -1834,1900,1833, -1900,1834,1901, -1835,1901,1834, -1901,1835,1902, -1836,1902,1835, -1902,1836,1903, -1837,1903,1836, -1903,1837,1904, -1838,1904,1837, -1904,1838,1905, -1839,1905,1838, -1905,1839,1906, -1840,1906,1839, -1906,1840,1907, -1841,1907,1840, -1907,1841,1908, -1842,1908,1841, -1908,1842,1909, -1843,1909,1842, -1909,1843,1910, -1844,1910,1843, -1910,1844,1911, -1845,1911,1844, -1911,1845,1912, -1846,1912,1845, -1912,1846,1913, -1847,1913,1846, -1914,1848,1915, -1849,1915,1848, -1915,1849,1916, -1850,1916,1849, -1916,1850,1917, -1851,1917,1850, -1917,1851,1918, -1852,1918,1851, -1918,1852,1919, -1853,1919,1852, -1919,1853,1920, -1854,1920,1853, -1920,1854,1921, -1855,1921,1854, -1921,1855,1922, -1856,1922,1855, -1922,1856,1923, -1857,1923,1856, -1923,1857,1924, -1858,1924,1857, -1924,1858,1925, -1859,1925,1858, -1925,1859,1926, -1860,1926,1859, -1926,1860,1927, -1861,1927,1860, -1927,1861,1928, -1862,1928,1861, -1928,1862,1929, -1863,1929,1862, -1929,1863,1930, -1864,1930,1863, -1930,1864,1931, -1865,1931,1864, -1931,1865,1932, -1866,1932,1865, -1932,1866,1933, -1867,1933,1866, -1933,1867,1934, -1868,1934,1867, -1934,1868,1935, -1869,1935,1868, -1935,1869,1936, -1870,1936,1869, -1936,1870,1937, -1871,1937,1870, -1937,1871,1938, -1872,1938,1871, -1938,1872,1939, -1873,1939,1872, -1939,1873,1940, -1874,1940,1873, -1940,1874,1941, -1875,1941,1874, -1941,1875,1942, -1876,1942,1875, -1942,1876,1943, -1877,1943,1876, -1943,1877,1944, -1878,1944,1877, -1944,1878,1945, -1879,1945,1878, -1945,1879,1946, -1880,1946,1879, -1946,1880,1947, -1881,1947,1880, -1947,1881,1948, -1882,1948,1881, -1948,1882,1949, -1883,1949,1882, -1949,1883,1950, -1884,1950,1883, -1950,1884,1951, -1885,1951,1884, -1951,1885,1952, -1886,1952,1885, -1952,1886,1953, -1887,1953,1886, -1953,1887,1954, -1888,1954,1887, -1954,1888,1955, -1889,1955,1888, -1955,1889,1956, -1890,1956,1889, -1956,1890,1957, -1891,1957,1890, -1957,1891,1958, -1892,1958,1891, -1958,1892,1959, -1893,1959,1892, -1959,1893,1960, -1894,1960,1893, -1960,1894,1961, -1895,1961,1894, -1961,1895,1962, -1896,1962,1895, -1962,1896,1963, -1897,1963,1896, -1963,1897,1964, -1898,1964,1897, -1964,1898,1965, -1899,1965,1898, -1965,1899,1966, -1900,1966,1899, -1966,1900,1967, -1901,1967,1900, -1967,1901,1968, -1902,1968,1901, -1968,1902,1969, -1903,1969,1902, -1969,1903,1970, -1904,1970,1903, -1970,1904,1971, -1905,1971,1904, -1971,1905,1972, -1906,1972,1905, -1972,1906,1973, -1907,1973,1906, -1973,1907,1974, -1908,1974,1907, -1974,1908,1975, -1909,1975,1908, -1975,1909,1976, -1910,1976,1909, -1976,1910,1977, -1911,1977,1910, -1977,1911,1978, -1912,1978,1911, -1978,1912,1979, -1913,1979,1912, -}; - -#define Landscape03VtxCount 2048 -#define Landscape03IdxCount 11718 - -btScalar Landscape03Vtx[] = { -3.90625f,50.3865f,-2.20246e-006f, -3.90625f,52.6186f,3.90625f, -7.8125f,50.3905f,-2.20264e-006f, -7.8125f,51.8648f,3.90625f, -11.7188f,49.8171f,-2.17758e-006f, -11.7188f,51.1949f,3.90625f, -15.625f,50.595f,-2.21158e-006f, -15.625f,50.2102f,3.90625f, -19.5313f,50.405f,-2.20327e-006f, -19.5313f,50.6058f,3.90625f, -23.4375f,50.9679f,-2.22788e-006f, -23.4375f,50.7008f,3.90625f, -27.3438f,52.4635f,-2.29325e-006f, -27.3438f,51.2163f,3.90625f, -31.25f,53.1505f,-2.32328e-006f, -31.25f,51.4263f,3.90625f, -35.1563f,53.061f,-2.31937e-006f, -35.1563f,52.1968f,3.90625f, -39.0625f,53.6772f,-2.34631e-006f, -39.0625f,53.9783f,3.90625f, -42.9688f,54.3062f,-2.3738e-006f, -42.9688f,53.8927f,3.90625f, -46.875f,54.6795f,-2.39012e-006f, -46.875f,53.3266f,3.90625f, -50.7813f,55.3188f,-2.41806e-006f, -50.7813f,53.5901f,3.90625f, -54.6875f,56.913f,-2.48775e-006f, -54.6875f,55.5679f,3.90625f, -58.5938f,57.4575f,-2.51155e-006f, -58.5938f,55.1819f,3.90625f, -62.5f,56.5398f,-2.47143e-006f, -62.5f,53.6891f,3.90625f, -66.4063f,55.8786f,-2.44253e-006f, -66.4063f,53.0541f,3.90625f, -70.3125f,53.6497f,-2.3451e-006f, -70.3125f,51.6665f,3.90625f, -74.2188f,51.6447f,-2.25746e-006f, -74.2188f,51.4469f,3.90625f, -78.125f,51.8145f,-2.26488e-006f, -78.125f,51.9591f,3.90625f, -82.0313f,51.335f,-2.24392e-006f, -82.0313f,51.0418f,3.90625f, -85.9375f,50.1836f,-2.1936e-006f, -85.9375f,49.7513f,3.90625f, -89.8438f,49.0536f,-2.1442e-006f, -89.8438f,48.7329f,3.90625f, -93.75f,47.3968f,-2.07178e-006f, -93.75f,46.8713f,3.90625f, -97.6563f,45.8014f,-2.00204e-006f, -97.6563f,46.3905f,3.90625f, -101.563f,45.2347f,-1.97727e-006f, -101.563f,45.4241f,3.90625f, -105.469f,44.6501f,-1.95172e-006f, -105.469f,45.6811f,3.90625f, -109.375f,44.3569f,-1.9389e-006f, -109.375f,45.3238f,3.90625f, -113.281f,44.1147f,-1.92831e-006f, -113.281f,43.6112f,3.90625f, -117.188f,43.4037f,-1.89723e-006f, -117.188f,42.1291f,3.90625f, -121.094f,41.1606f,-1.79919e-006f, -121.094f,40.4747f,3.90625f, -125.0f,40.195f,-1.75698e-006f, -125.0f,39.3351f,3.90625f, -128.906f,39.5659f,-1.72948e-006f, -128.906f,38.0742f,3.90625f, -132.813f,38.2592f,-1.67236e-006f, -132.813f,36.7758f,3.90625f, -136.719f,36.4337f,-1.59257e-006f, -136.719f,34.9213f,3.90625f, -140.625f,34.1507f,-1.49277e-006f, -140.625f,32.3643f,3.90625f, -144.531f,31.5531f,-1.37923e-006f, -144.531f,31.7157f,3.90625f, -148.438f,29.9056f,-1.30722e-006f, -148.438f,30.6005f,3.90625f, -152.344f,30.5219f,-1.33416e-006f, -152.344f,31.6034f,3.90625f, -156.25f,31.1254f,-1.36053e-006f, -156.25f,32.6503f,3.90625f, -160.156f,31.8976f,-1.39429e-006f, -160.156f,33.3131f,3.90625f, -164.063f,31.5364f,-1.3785e-006f, -164.063f,32.5745f,3.90625f, -167.969f,30.5585f,-1.33575e-006f, -167.969f,31.5017f,3.90625f, -171.875f,30.0528f,-1.31365e-006f, -171.875f,30.6842f,3.90625f, -175.781f,29.2833f,-1.28002e-006f, -175.781f,29.8734f,3.90625f, -179.688f,28.3316f,-1.23841e-006f, -179.688f,28.6537f,3.90625f, -183.594f,27.0177f,-1.18098e-006f, -183.594f,27.2073f,3.90625f, -187.5f,24.7626f,-1.08241e-006f, -187.5f,25.4367f,3.90625f, -191.406f,22.7371f,-9.9387e-007f, -191.406f,24.1609f,3.90625f, -195.313f,21.6497f,-9.46338e-007f, -195.313f,23.9724f,3.90625f, -199.219f,21.3313f,-9.32422e-007f, -199.219f,23.7702f,3.90625f, -203.125f,20.9148f,-9.14215e-007f, -203.125f,22.4031f,3.90625f, -207.031f,19.4875f,-8.51826e-007f, -207.031f,22.1587f,3.90625f, -210.938f,19.0037f,-8.30679e-007f, -210.938f,21.6154f,3.90625f, -214.844f,18.408f,-8.0464e-007f, -214.844f,21.8202f,3.90625f, -218.75f,18.7855f,-8.2114e-007f, -218.75f,21.017f,3.90625f, -222.656f,18.1497f,-7.9335e-007f, -222.656f,19.3736f,3.90625f, -226.563f,17.6889f,-7.73205e-007f, -226.563f,18.2127f,3.90625f, -230.469f,16.8429f,-7.36228e-007f, -230.469f,17.2263f,3.90625f, -234.375f,16.3712f,-7.15609e-007f, -234.375f,16.2938f,3.90625f, -238.281f,14.3259f,-6.26204e-007f, -238.281f,14.4518f,3.90625f, -242.188f,12.4394f,-5.43742e-007f, -242.188f,13.6398f,3.90625f, -246.094f,12.3876f,-5.41479e-007f, -246.094f,13.2404f,3.90625f, -250.0f,11.9236f,-5.21196e-007f, -250.0f,12.7102f,3.90625f, -3.90625f,48.8559f,-3.90625f, -7.8125f,49.3575f,-3.90625f, -11.7188f,49.963f,-3.90625f, -15.625f,50.1126f,-3.90625f, -19.5313f,51.6247f,-3.90625f, -23.4375f,52.1716f,-3.90625f, -27.3438f,52.8679f,-3.90625f, -31.25f,53.978f,-3.90625f, -35.1563f,53.8948f,-3.90625f, -39.0625f,54.8492f,-3.90625f, -42.9688f,56.1714f,-3.90625f, -46.875f,56.4915f,-3.90625f, -50.7813f,56.5729f,-3.90625f, -54.6875f,57.9767f,-3.90625f, -58.5938f,58.6125f,-3.90625f, -62.5f,58.0023f,-3.90625f, -66.4063f,57.5742f,-3.90625f, -70.3125f,55.4949f,-3.90625f, -74.2188f,53.7219f,-3.90625f, -78.125f,53.233f,-3.90625f, -82.0313f,52.5499f,-3.90625f, -85.9375f,51.1842f,-3.90625f, -89.8438f,49.6534f,-3.90625f, -93.75f,47.6829f,-3.90625f, -97.6563f,45.813f,-3.90625f, -101.563f,44.7099f,-3.90625f, -105.469f,45.0932f,-3.90625f, -109.375f,44.8326f,-3.90625f, -113.281f,44.5197f,-3.90625f, -117.188f,43.7399f,-3.90625f, -121.094f,42.3088f,-3.90625f, -125.0f,40.4224f,-3.90625f, -128.906f,39.437f,-3.90625f, -132.813f,39.825f,-3.90625f, -136.719f,38.2979f,-3.90625f, -140.625f,35.2095f,-3.90625f, -144.531f,32.0692f,-3.90625f, -148.438f,31.1765f,-3.90625f, -152.344f,32.2065f,-3.90625f, -156.25f,31.4774f,-3.90625f, -160.156f,31.7166f,-3.90625f, -164.063f,31.7667f,-3.90625f, -167.969f,31.1742f,-3.90625f, -171.875f,29.6515f,-3.90625f, -175.781f,28.7845f,-3.90625f, -179.688f,28.3154f,-3.90625f, -183.594f,26.6187f,-3.90625f, -187.5f,24.7363f,-3.90625f, -191.406f,22.9162f,-3.90625f, -195.313f,21.5211f,-3.90625f, -199.219f,19.7693f,-3.90625f, -203.125f,18.9792f,-3.90625f, -207.031f,18.8399f,-3.90625f, -210.938f,18.8797f,-3.90625f, -214.844f,18.8123f,-3.90625f, -218.75f,18.5136f,-3.90625f, -222.656f,18.5607f,-3.90625f, -226.563f,17.5053f,-3.90625f, -230.469f,17.4838f,-3.90625f, -234.375f,16.6728f,-3.90625f, -238.281f,14.8594f,-3.90625f, -242.188f,12.9613f,-3.90625f, -246.094f,12.8624f,-3.90625f, -250.0f,11.5894f,-3.90625f, -3.90625f,48.7225f,-7.8125f, -7.8125f,49.1281f,-7.8125f, -11.7188f,50.0005f,-7.8125f, -15.625f,50.5896f,-7.8125f, -19.5313f,51.5499f,-7.8125f, -23.4375f,52.9511f,-7.8125f, -27.3438f,53.117f,-7.8125f, -31.25f,54.0682f,-7.8125f, -35.1563f,55.2353f,-7.8125f, -39.0625f,57.2741f,-7.8125f, -42.9688f,57.4338f,-7.8125f, -46.875f,57.766f,-7.8125f, -50.7813f,57.2724f,-7.8125f, -54.6875f,58.0147f,-7.8125f, -58.5938f,58.764f,-7.8125f, -62.5f,58.6375f,-7.8125f, -66.4063f,57.2699f,-7.8125f, -70.3125f,55.9883f,-7.8125f, -74.2188f,54.8767f,-7.8125f, -78.125f,54.5266f,-7.8125f, -82.0313f,53.7148f,-7.8125f, -85.9375f,52.3735f,-7.8125f, -89.8438f,50.9637f,-7.8125f, -93.75f,48.4983f,-7.8125f, -97.6563f,45.9034f,-7.8125f, -101.563f,45.0863f,-7.8125f, -105.469f,44.2432f,-7.8125f, -109.375f,43.9561f,-7.8125f, -113.281f,43.3015f,-7.8125f, -117.188f,43.254f,-7.8125f, -121.094f,42.7388f,-7.8125f, -125.0f,41.1851f,-7.8125f, -128.906f,39.7522f,-7.8125f, -132.813f,39.8116f,-7.8125f, -136.719f,38.7148f,-7.8125f, -140.625f,36.0845f,-7.8125f, -144.531f,34.0308f,-7.8125f, -148.438f,33.0368f,-7.8125f, -152.344f,32.5867f,-7.8125f, -156.25f,32.8758f,-7.8125f, -160.156f,32.65f,-7.8125f, -164.063f,32.6826f,-7.8125f, -167.969f,31.5243f,-7.8125f, -171.875f,30.4061f,-7.8125f, -175.781f,29.2721f,-7.8125f, -179.688f,28.0417f,-7.8125f, -183.594f,26.2041f,-7.8125f, -187.5f,24.2168f,-7.8125f, -191.406f,22.7847f,-7.8125f, -195.313f,20.5069f,-7.8125f, -199.219f,18.6189f,-7.8125f, -203.125f,17.5296f,-7.8125f, -207.031f,18.0846f,-7.8125f, -210.938f,18.4802f,-7.8125f, -214.844f,18.5436f,-7.8125f, -218.75f,18.3296f,-7.8125f, -222.656f,17.9158f,-7.8125f, -226.563f,17.0318f,-7.8125f, -230.469f,16.2818f,-7.8125f, -234.375f,15.4949f,-7.8125f, -238.281f,13.4891f,-7.8125f, -242.188f,13.3349f,-7.8125f, -246.094f,12.2716f,-7.8125f, -250.0f,10.9901f,-7.8125f, -3.90625f,49.6298f,-11.7188f, -7.8125f,50.0683f,-11.7188f, -11.7188f,50.6295f,-11.7188f, -15.625f,51.0495f,-11.7188f, -19.5313f,52.4884f,-11.7188f, -23.4375f,53.3147f,-11.7188f, -27.3438f,54.4311f,-11.7188f, -31.25f,55.2874f,-11.7188f, -35.1563f,56.5549f,-11.7188f, -39.0625f,57.9376f,-11.7188f, -42.9688f,58.2302f,-11.7188f, -46.875f,59.1419f,-11.7188f, -50.7813f,58.8724f,-11.7188f, -54.6875f,58.5393f,-11.7188f, -58.5938f,58.6416f,-11.7188f, -62.5f,58.1973f,-11.7188f, -66.4063f,57.9168f,-11.7188f, -70.3125f,56.4347f,-11.7188f, -74.2188f,55.7911f,-11.7188f, -78.125f,55.946f,-11.7188f, -82.0313f,54.9033f,-11.7188f, -85.9375f,53.0954f,-11.7188f, -89.8438f,51.7428f,-11.7188f, -93.75f,49.2198f,-11.7188f, -97.6563f,46.1127f,-11.7188f, -101.563f,43.9953f,-11.7188f, -105.469f,43.5777f,-11.7188f, -109.375f,43.3284f,-11.7188f, -113.281f,43.5152f,-11.7188f, -117.188f,43.6687f,-11.7188f, -121.094f,42.5477f,-11.7188f, -125.0f,41.4079f,-11.7188f, -128.906f,39.4512f,-11.7188f, -132.813f,39.5183f,-11.7188f, -136.719f,37.8068f,-11.7188f, -140.625f,36.5652f,-11.7188f, -144.531f,34.8202f,-11.7188f, -148.438f,34.0166f,-11.7188f, -152.344f,33.5311f,-11.7188f, -156.25f,34.1672f,-11.7188f, -160.156f,33.8602f,-11.7188f, -164.063f,33.8717f,-11.7188f, -167.969f,33.1703f,-11.7188f, -171.875f,31.0241f,-11.7188f, -175.781f,30.2798f,-11.7188f, -179.688f,28.3241f,-11.7188f, -183.594f,26.4432f,-11.7188f, -187.5f,24.9758f,-11.7188f, -191.406f,22.2834f,-11.7188f, -195.313f,19.3875f,-11.7188f, -199.219f,18.4079f,-11.7188f, -203.125f,16.6498f,-11.7188f, -207.031f,16.1235f,-11.7188f, -210.938f,16.9462f,-11.7188f, -214.844f,17.2638f,-11.7188f, -218.75f,17.0386f,-11.7188f, -222.656f,16.7666f,-11.7188f, -226.563f,15.3591f,-11.7188f, -230.469f,14.4048f,-11.7188f, -234.375f,13.3079f,-11.7188f, -238.281f,13.0895f,-11.7188f, -242.188f,12.8462f,-11.7188f, -246.094f,12.6287f,-11.7188f, -250.0f,11.4682f,-11.7188f, -3.90625f,50.6915f,-15.625f, -7.8125f,51.2382f,-15.625f, -11.7188f,52.3659f,-15.625f, -15.625f,52.3873f,-15.625f, -19.5313f,53.1083f,-15.625f, -23.4375f,54.652f,-15.625f, -27.3438f,56.0359f,-15.625f, -31.25f,56.4398f,-15.625f, -35.1563f,57.3156f,-15.625f, -39.0625f,58.2355f,-15.625f, -42.9688f,59.4547f,-15.625f, -46.875f,59.9176f,-15.625f, -50.7813f,60.0789f,-15.625f, -54.6875f,59.004f,-15.625f, -58.5938f,59.3361f,-15.625f, -62.5f,59.2681f,-15.625f, -66.4063f,58.5571f,-15.625f, -70.3125f,57.1801f,-15.625f, -74.2188f,56.2048f,-15.625f, -78.125f,56.9427f,-15.625f, -82.0313f,55.401f,-15.625f, -85.9375f,53.0457f,-15.625f, -89.8438f,51.6378f,-15.625f, -93.75f,49.1297f,-15.625f, -97.6563f,46.6267f,-15.625f, -101.563f,44.7255f,-15.625f, -105.469f,43.3819f,-15.625f, -109.375f,42.8703f,-15.625f, -113.281f,42.7636f,-15.625f, -117.188f,42.1897f,-15.625f, -121.094f,41.9269f,-15.625f, -125.0f,41.5365f,-15.625f, -128.906f,39.5408f,-15.625f, -132.813f,38.9178f,-15.625f, -136.719f,38.1447f,-15.625f, -140.625f,36.5145f,-15.625f, -144.531f,34.8696f,-15.625f, -148.438f,34.8203f,-15.625f, -152.344f,34.409f,-15.625f, -156.25f,35.1394f,-15.625f, -160.156f,35.619f,-15.625f, -164.063f,34.7784f,-15.625f, -167.969f,33.6548f,-15.625f, -171.875f,32.1822f,-15.625f, -175.781f,31.1666f,-15.625f, -179.688f,28.9574f,-15.625f, -183.594f,27.3989f,-15.625f, -187.5f,24.7201f,-15.625f, -191.406f,21.7859f,-15.625f, -195.313f,19.2508f,-15.625f, -199.219f,18.0209f,-15.625f, -203.125f,16.8441f,-15.625f, -207.031f,15.8846f,-15.625f, -210.938f,15.6902f,-15.625f, -214.844f,15.3143f,-15.625f, -218.75f,15.3862f,-15.625f, -222.656f,14.2743f,-15.625f, -226.563f,13.5791f,-15.625f, -230.469f,13.4953f,-15.625f, -234.375f,13.3484f,-15.625f, -238.281f,13.2722f,-15.625f, -242.188f,13.4455f,-15.625f, -246.094f,13.0725f,-15.625f, -250.0f,11.5558f,-15.625f, -3.90625f,52.1028f,-19.5313f, -7.8125f,52.877f,-19.5313f, -11.7188f,54.5397f,-19.5313f, -15.625f,54.8941f,-19.5313f, -19.5313f,54.9009f,-19.5313f, -23.4375f,56.1681f,-19.5313f, -27.3438f,56.5579f,-19.5313f, -31.25f,57.7962f,-19.5313f, -35.1563f,58.728f,-19.5313f, -39.0625f,59.4794f,-19.5313f, -42.9688f,60.2636f,-19.5313f, -46.875f,61.2139f,-19.5313f, -50.7813f,60.4636f,-19.5313f, -54.6875f,59.681f,-19.5313f, -58.5938f,60.2068f,-19.5313f, -62.5f,59.1055f,-19.5313f, -66.4063f,57.6126f,-19.5313f, -70.3125f,56.6416f,-19.5313f, -74.2188f,56.4864f,-19.5313f, -78.125f,56.1784f,-19.5313f, -82.0313f,54.8451f,-19.5313f, -85.9375f,53.4094f,-19.5313f, -89.8438f,51.7161f,-19.5313f, -93.75f,48.9933f,-19.5313f, -97.6563f,47.5116f,-19.5313f, -101.563f,45.7701f,-19.5313f, -105.469f,44.0377f,-19.5313f, -109.375f,43.0918f,-19.5313f, -113.281f,42.3992f,-19.5313f, -117.188f,42.0928f,-19.5313f, -121.094f,42.0543f,-19.5313f, -125.0f,41.793f,-19.5313f, -128.906f,39.3232f,-19.5313f, -132.813f,39.1149f,-19.5313f, -136.719f,38.2381f,-19.5313f, -140.625f,36.1019f,-19.5313f, -144.531f,36.4503f,-19.5313f, -148.438f,35.6809f,-19.5313f, -152.344f,35.8022f,-19.5313f, -156.25f,36.4955f,-19.5313f, -160.156f,36.3187f,-19.5313f, -164.063f,35.0268f,-19.5313f, -167.969f,34.0134f,-19.5313f, -171.875f,33.6455f,-19.5313f, -175.781f,31.5932f,-19.5313f, -179.688f,30.0326f,-19.5313f, -183.594f,28.3453f,-19.5313f, -187.5f,25.3719f,-19.5313f, -191.406f,22.0833f,-19.5313f, -195.313f,18.7475f,-19.5313f, -199.219f,17.5517f,-19.5313f, -203.125f,16.1528f,-19.5313f, -207.031f,15.6144f,-19.5313f, -210.938f,14.9281f,-19.5313f, -214.844f,14.5711f,-19.5313f, -218.75f,13.8446f,-19.5313f, -222.656f,13.6892f,-19.5313f, -226.563f,13.1595f,-19.5313f, -230.469f,13.2872f,-19.5313f, -234.375f,13.6153f,-19.5313f, -238.281f,12.8725f,-19.5313f, -242.188f,12.7128f,-19.5313f, -246.094f,13.0658f,-19.5313f, -250.0f,11.5414f,-19.5313f, -3.90625f,54.332f,-23.4375f, -7.8125f,55.636f,-23.4375f, -11.7188f,56.3899f,-23.4375f, -15.625f,56.3763f,-23.4375f, -19.5313f,56.9523f,-23.4375f, -23.4375f,57.5593f,-23.4375f, -27.3438f,57.8056f,-23.4375f, -31.25f,58.5489f,-23.4375f, -35.1563f,59.2321f,-23.4375f, -39.0625f,60.5971f,-23.4375f, -42.9688f,60.1728f,-23.4375f, -46.875f,60.9341f,-23.4375f, -50.7813f,59.5118f,-23.4375f, -54.6875f,59.7552f,-23.4375f, -58.5938f,59.9126f,-23.4375f, -62.5f,58.501f,-23.4375f, -66.4063f,57.8539f,-23.4375f, -70.3125f,56.8693f,-23.4375f, -74.2188f,56.0687f,-23.4375f, -78.125f,55.4392f,-23.4375f, -82.0313f,53.7167f,-23.4375f, -85.9375f,52.1078f,-23.4375f, -89.8438f,50.8869f,-23.4375f, -93.75f,49.9812f,-23.4375f, -97.6563f,47.9233f,-23.4375f, -101.563f,46.1166f,-23.4375f, -105.469f,44.4826f,-23.4375f, -109.375f,42.8924f,-23.4375f, -113.281f,41.9991f,-23.4375f, -117.188f,41.1759f,-23.4375f, -121.094f,41.1189f,-23.4375f, -125.0f,39.9128f,-23.4375f, -128.906f,39.8641f,-23.4375f, -132.813f,39.8777f,-23.4375f, -136.719f,38.3567f,-23.4375f, -140.625f,37.4926f,-23.4375f, -144.531f,37.0275f,-23.4375f, -148.438f,36.7211f,-23.4375f, -152.344f,36.9355f,-23.4375f, -156.25f,37.7455f,-23.4375f, -160.156f,37.3585f,-23.4375f, -164.063f,36.1837f,-23.4375f, -167.969f,34.768f,-23.4375f, -171.875f,33.2179f,-23.4375f, -175.781f,31.6883f,-23.4375f, -179.688f,30.1136f,-23.4375f, -183.594f,28.1155f,-23.4375f, -187.5f,25.4881f,-23.4375f, -191.406f,22.8498f,-23.4375f, -195.313f,19.4425f,-23.4375f, -199.219f,17.1253f,-23.4375f, -203.125f,14.8354f,-23.4375f, -207.031f,14.1771f,-23.4375f, -210.938f,13.9227f,-23.4375f, -214.844f,13.3404f,-23.4375f, -218.75f,13.0525f,-23.4375f, -222.656f,13.0744f,-23.4375f, -226.563f,13.0432f,-23.4375f, -230.469f,13.3341f,-23.4375f, -234.375f,13.6022f,-23.4375f, -238.281f,13.3878f,-23.4375f, -242.188f,12.5812f,-23.4375f, -246.094f,11.8699f,-23.4375f, -250.0f,11.3395f,-23.4375f, -3.90625f,57.5273f,-27.3438f, -7.8125f,57.8217f,-27.3438f, -11.7188f,57.5626f,-27.3438f, -15.625f,57.7794f,-27.3438f, -19.5313f,58.7949f,-27.3438f, -23.4375f,59.3547f,-27.3438f, -27.3438f,59.2359f,-27.3438f, -31.25f,58.8772f,-27.3438f, -35.1563f,58.7149f,-27.3438f, -39.0625f,59.7221f,-27.3438f, -42.9688f,60.0457f,-27.3438f, -46.875f,59.6559f,-27.3438f, -50.7813f,59.9346f,-27.3438f, -54.6875f,60.4095f,-27.3438f, -58.5938f,59.3107f,-27.3438f, -62.5f,57.9086f,-27.3438f, -66.4063f,57.3034f,-27.3438f, -70.3125f,55.5758f,-27.3438f, -74.2188f,54.7167f,-27.3438f, -78.125f,54.405f,-27.3438f, -82.0313f,53.0644f,-27.3438f, -85.9375f,50.9689f,-27.3438f, -89.8438f,49.5959f,-27.3438f, -93.75f,49.2817f,-27.3438f, -97.6563f,48.9188f,-27.3438f, -101.563f,47.0066f,-27.3438f, -105.469f,44.4266f,-27.3438f, -109.375f,42.4539f,-27.3438f, -113.281f,41.5486f,-27.3438f, -117.188f,41.4419f,-27.3438f, -121.094f,41.2039f,-27.3438f, -125.0f,40.188f,-27.3438f, -128.906f,40.4744f,-27.3438f, -132.813f,40.1187f,-27.3438f, -136.719f,38.8055f,-27.3438f, -140.625f,38.024f,-27.3438f, -144.531f,37.5255f,-27.3438f, -148.438f,36.8676f,-27.3438f, -152.344f,37.8967f,-27.3438f, -156.25f,38.4708f,-27.3438f, -160.156f,37.8284f,-27.3438f, -164.063f,36.6094f,-27.3438f, -167.969f,34.4523f,-27.3438f, -171.875f,32.2936f,-27.3438f, -175.781f,31.7467f,-27.3438f, -179.688f,29.9455f,-27.3438f, -183.594f,27.7546f,-27.3438f, -187.5f,25.1902f,-27.3438f, -191.406f,22.537f,-27.3438f, -195.313f,19.5657f,-27.3438f, -199.219f,17.4406f,-27.3438f, -203.125f,15.5459f,-27.3438f, -207.031f,14.92f,-27.3438f, -210.938f,13.472f,-27.3438f, -214.844f,12.9933f,-27.3438f, -218.75f,13.2849f,-27.3438f, -222.656f,12.3375f,-27.3438f, -226.563f,12.0553f,-27.3438f, -230.469f,12.4756f,-27.3438f, -234.375f,12.0857f,-27.3438f, -238.281f,12.1988f,-27.3438f, -242.188f,11.9091f,-27.3438f, -246.094f,10.7301f,-27.3438f, -250.0f,10.1068f,-27.3438f, -3.90625f,59.4204f,-31.25f, -7.8125f,59.5424f,-31.25f, -11.7188f,58.7785f,-31.25f, -15.625f,59.7851f,-31.25f, -19.5313f,60.4897f,-31.25f, -23.4375f,60.6095f,-31.25f, -27.3438f,60.3384f,-31.25f, -31.25f,59.5445f,-31.25f, -35.1563f,58.6838f,-31.25f, -39.0625f,58.847f,-31.25f, -42.9688f,59.3885f,-31.25f, -46.875f,59.447f,-31.25f, -50.7813f,59.5998f,-31.25f, -54.6875f,58.9947f,-31.25f, -58.5938f,58.7482f,-31.25f, -62.5f,56.5947f,-31.25f, -66.4063f,56.2941f,-31.25f, -70.3125f,54.6423f,-31.25f, -74.2188f,53.7392f,-31.25f, -78.125f,53.2955f,-31.25f, -82.0313f,52.8233f,-31.25f, -85.9375f,52.1194f,-31.25f, -89.8438f,51.3335f,-31.25f, -93.75f,49.9201f,-31.25f, -97.6563f,49.1642f,-31.25f, -101.563f,47.4466f,-31.25f, -105.469f,44.6086f,-31.25f, -109.375f,42.885f,-31.25f, -113.281f,42.947f,-31.25f, -117.188f,42.2436f,-31.25f, -121.094f,41.6479f,-31.25f, -125.0f,41.6151f,-31.25f, -128.906f,41.2079f,-31.25f, -132.813f,40.7975f,-31.25f, -136.719f,39.8341f,-31.25f, -140.625f,38.7649f,-31.25f, -144.531f,37.7387f,-31.25f, -148.438f,37.2112f,-31.25f, -152.344f,38.3278f,-31.25f, -156.25f,38.7659f,-31.25f, -160.156f,37.5608f,-31.25f, -164.063f,35.9966f,-31.25f, -167.969f,33.737f,-31.25f, -171.875f,32.0109f,-31.25f, -175.781f,31.1169f,-31.25f, -179.688f,30.0211f,-31.25f, -183.594f,27.5633f,-31.25f, -187.5f,25.0292f,-31.25f, -191.406f,22.8265f,-31.25f, -195.313f,19.8972f,-31.25f, -199.219f,17.6714f,-31.25f, -203.125f,16.2679f,-31.25f, -207.031f,15.0546f,-31.25f, -210.938f,14.037f,-31.25f, -214.844f,12.5501f,-31.25f, -218.75f,12.1528f,-31.25f, -222.656f,12.0576f,-31.25f, -226.563f,11.2847f,-31.25f, -230.469f,11.5946f,-31.25f, -234.375f,10.9216f,-31.25f, -238.281f,10.9182f,-31.25f, -242.188f,11.2826f,-31.25f, -246.094f,11.5781f,-31.25f, -250.0f,11.536f,-31.25f, -3.90625f,60.2212f,-35.1563f, -7.8125f,59.3731f,-35.1563f, -11.7188f,58.5327f,-35.1563f, -15.625f,59.5785f,-35.1563f, -19.5313f,60.1491f,-35.1563f, -23.4375f,60.5297f,-35.1563f, -27.3438f,60.5336f,-35.1563f, -31.25f,60.162f,-35.1563f, -35.1563f,58.5927f,-35.1563f, -39.0625f,57.9369f,-35.1563f, -42.9688f,58.4405f,-35.1563f, -46.875f,58.7374f,-35.1563f, -50.7813f,57.6198f,-35.1563f, -54.6875f,57.3277f,-35.1563f, -58.5938f,56.6423f,-35.1563f, -62.5f,56.2444f,-35.1563f, -66.4063f,56.132f,-35.1563f, -70.3125f,54.6673f,-35.1563f, -74.2188f,53.2924f,-35.1563f, -78.125f,53.2569f,-35.1563f, -82.0313f,52.0828f,-35.1563f, -85.9375f,51.9661f,-35.1563f, -89.8438f,50.9045f,-35.1563f, -93.75f,49.4997f,-35.1563f, -97.6563f,48.0748f,-35.1563f, -101.563f,46.3182f,-35.1563f, -105.469f,44.0878f,-35.1563f, -109.375f,42.863f,-35.1563f, -113.281f,42.8044f,-35.1563f, -117.188f,42.9648f,-35.1563f, -121.094f,42.3221f,-35.1563f, -125.0f,41.6576f,-35.1563f, -128.906f,41.1606f,-35.1563f, -132.813f,39.59f,-35.1563f, -136.719f,38.5602f,-35.1563f, -140.625f,37.9389f,-35.1563f, -144.531f,37.2602f,-35.1563f, -148.438f,37.3784f,-35.1563f, -152.344f,37.8906f,-35.1563f, -156.25f,37.8221f,-35.1563f, -160.156f,36.3088f,-35.1563f, -164.063f,35.1881f,-35.1563f, -167.969f,33.2601f,-35.1563f, -171.875f,31.8157f,-35.1563f, -175.781f,31.3416f,-35.1563f, -179.688f,30.0265f,-35.1563f, -183.594f,27.3943f,-35.1563f, -187.5f,24.641f,-35.1563f, -191.406f,22.2525f,-35.1563f, -195.313f,20.2011f,-35.1563f, -199.219f,18.7104f,-35.1563f, -203.125f,17.3459f,-35.1563f, -207.031f,15.2838f,-35.1563f, -210.938f,13.6157f,-35.1563f, -214.844f,13.3893f,-35.1563f, -218.75f,12.9319f,-35.1563f, -222.656f,11.5191f,-35.1563f, -226.563f,10.4878f,-35.1563f, -230.469f,9.83031f,-35.1563f, -234.375f,9.91945f,-35.1563f, -238.281f,10.9647f,-35.1563f, -242.188f,11.5866f,-35.1563f, -246.094f,11.8313f,-35.1563f, -250.0f,11.9419f,-35.1563f, -3.90625f,59.9094f,-39.0625f, -7.8125f,58.6207f,-39.0625f, -11.7188f,57.735f,-39.0625f, -15.625f,58.9909f,-39.0625f, -19.5313f,60.0678f,-39.0625f, -23.4375f,60.5419f,-39.0625f, -27.3438f,60.4672f,-39.0625f, -31.25f,59.5824f,-39.0625f, -35.1563f,58.4068f,-39.0625f, -39.0625f,57.5098f,-39.0625f, -42.9688f,57.6631f,-39.0625f, -46.875f,57.8211f,-39.0625f, -50.7813f,57.1897f,-39.0625f, -54.6875f,55.6789f,-39.0625f, -58.5938f,55.3212f,-39.0625f, -62.5f,55.2941f,-39.0625f, -66.4063f,55.8101f,-39.0625f, -70.3125f,54.309f,-39.0625f, -74.2188f,53.6313f,-39.0625f, -78.125f,52.7246f,-39.0625f, -82.0313f,51.5473f,-39.0625f, -85.9375f,51.5315f,-39.0625f, -89.8438f,50.6121f,-39.0625f, -93.75f,50.3734f,-39.0625f, -97.6563f,48.8877f,-39.0625f, -101.563f,47.0081f,-39.0625f, -105.469f,44.4827f,-39.0625f, -109.375f,43.5851f,-39.0625f, -113.281f,43.2668f,-39.0625f, -117.188f,43.4016f,-39.0625f, -121.094f,41.962f,-39.0625f, -125.0f,41.4641f,-39.0625f, -128.906f,40.2221f,-39.0625f, -132.813f,38.9234f,-39.0625f, -136.719f,37.7062f,-39.0625f, -140.625f,37.6455f,-39.0625f, -144.531f,37.8691f,-39.0625f, -148.438f,37.4139f,-39.0625f, -152.344f,37.204f,-39.0625f, -156.25f,36.7774f,-39.0625f, -160.156f,35.8962f,-39.0625f, -164.063f,34.5247f,-39.0625f, -167.969f,32.7322f,-39.0625f, -171.875f,32.1044f,-39.0625f, -175.781f,31.321f,-39.0625f, -179.688f,29.7775f,-39.0625f, -183.594f,26.7381f,-39.0625f, -187.5f,24.0216f,-39.0625f, -191.406f,22.277f,-39.0625f, -195.313f,21.2497f,-39.0625f, -199.219f,19.9529f,-39.0625f, -203.125f,18.3349f,-39.0625f, -207.031f,16.7961f,-39.0625f, -210.938f,15.071f,-39.0625f, -214.844f,13.5616f,-39.0625f, -218.75f,13.1679f,-39.0625f, -222.656f,11.2729f,-39.0625f, -226.563f,10.5025f,-39.0625f, -230.469f,9.72086f,-39.0625f, -234.375f,9.90489f,-39.0625f, -238.281f,10.7231f,-39.0625f, -242.188f,11.2573f,-39.0625f, -246.094f,12.0761f,-39.0625f, -250.0f,11.902f,-39.0625f, -3.90625f,59.5207f,-42.9688f, -7.8125f,58.2483f,-42.9688f, -11.7188f,58.069f,-42.9688f, -15.625f,59.4248f,-42.9688f, -19.5313f,60.5261f,-42.9688f, -23.4375f,60.668f,-42.9688f, -27.3438f,60.0252f,-42.9688f, -31.25f,58.0523f,-42.9688f, -35.1563f,56.7426f,-42.9688f, -39.0625f,57.2045f,-42.9688f, -42.9688f,57.166f,-42.9688f, -46.875f,56.9465f,-42.9688f, -50.7813f,55.7381f,-42.9688f, -54.6875f,55.2924f,-42.9688f, -58.5938f,54.6074f,-42.9688f, -62.5f,54.1882f,-42.9688f, -66.4063f,53.672f,-42.9688f, -70.3125f,53.3122f,-42.9688f, -74.2188f,53.0852f,-42.9688f, -78.125f,52.6173f,-42.9688f, -82.0313f,51.616f,-42.9688f, -85.9375f,50.148f,-42.9688f, -89.8438f,49.4823f,-42.9688f, -93.75f,50.0221f,-42.9688f, -97.6563f,48.9931f,-42.9688f, -101.563f,47.1045f,-42.9688f, -105.469f,44.442f,-42.9688f, -109.375f,44.5071f,-42.9688f, -113.281f,44.1005f,-42.9688f, -117.188f,42.8414f,-42.9688f, -121.094f,42.5419f,-42.9688f, -125.0f,41.5451f,-42.9688f, -128.906f,39.4272f,-42.9688f, -132.813f,39.8815f,-42.9688f, -136.719f,39.1366f,-42.9688f, -140.625f,38.7457f,-42.9688f, -144.531f,38.4257f,-42.9688f, -148.438f,37.9899f,-42.9688f, -152.344f,37.1716f,-42.9688f, -156.25f,36.0431f,-42.9688f, -160.156f,35.0784f,-42.9688f, -164.063f,33.3564f,-42.9688f, -167.969f,32.1522f,-42.9688f, -171.875f,30.9698f,-42.9688f, -175.781f,29.7186f,-42.9688f, -179.688f,28.0509f,-42.9688f, -183.594f,25.8254f,-42.9688f, -187.5f,24.8502f,-42.9688f, -191.406f,22.9031f,-42.9688f, -195.313f,20.8135f,-42.9688f, -199.219f,19.6651f,-42.9688f, -203.125f,18.4753f,-42.9688f, -207.031f,17.2259f,-42.9688f, -210.938f,15.6171f,-42.9688f, -214.844f,13.2953f,-42.9688f, -218.75f,13.1679f,-42.9688f, -222.656f,10.7772f,-42.9688f, -226.563f,9.62294f,-42.9688f, -230.469f,9.27609f,-42.9688f, -234.375f,9.47241f,-42.9688f, -238.281f,10.2411f,-42.9688f, -242.188f,11.3745f,-42.9688f, -246.094f,10.981f,-42.9688f, -250.0f,9.93179f,-42.9688f, -3.90625f,58.9086f,-46.875f, -7.8125f,58.895f,-46.875f, -11.7188f,59.1807f,-46.875f, -15.625f,60.2442f,-46.875f, -19.5313f,60.6114f,-46.875f, -23.4375f,59.9439f,-46.875f, -27.3438f,58.704f,-46.875f, -31.25f,58.3729f,-46.875f, -35.1563f,57.0256f,-46.875f, -39.0625f,57.069f,-46.875f, -42.9688f,57.0536f,-46.875f, -46.875f,55.7912f,-46.875f, -50.7813f,54.8674f,-46.875f, -54.6875f,53.8265f,-46.875f, -58.5938f,53.563f,-46.875f, -62.5f,52.5979f,-46.875f, -66.4063f,52.3986f,-46.875f, -70.3125f,52.1891f,-46.875f, -74.2188f,52.2468f,-46.875f, -78.125f,52.3398f,-46.875f, -82.0313f,50.9875f,-46.875f, -85.9375f,49.4072f,-46.875f, -89.8438f,48.3295f,-46.875f, -93.75f,48.9009f,-46.875f, -97.6563f,47.6633f,-46.875f, -101.563f,44.4101f,-46.875f, -105.469f,44.0249f,-46.875f, -109.375f,43.7395f,-46.875f, -113.281f,44.0967f,-46.875f, -117.188f,43.3593f,-46.875f, -121.094f,42.11f,-46.875f, -125.0f,40.8903f,-46.875f, -128.906f,40.3861f,-46.875f, -132.813f,40.075f,-46.875f, -136.719f,39.6347f,-46.875f, -140.625f,38.7369f,-46.875f, -144.531f,37.9042f,-46.875f, -148.438f,36.8546f,-46.875f, -152.344f,36.4012f,-46.875f, -156.25f,35.3977f,-46.875f, -160.156f,34.0947f,-46.875f, -164.063f,32.2545f,-46.875f, -167.969f,30.0086f,-46.875f, -171.875f,29.202f,-46.875f, -175.781f,28.0362f,-46.875f, -179.688f,26.7114f,-46.875f, -183.594f,25.9577f,-46.875f, -187.5f,25.3242f,-46.875f, -191.406f,23.8586f,-46.875f, -195.313f,20.6056f,-46.875f, -199.219f,19.3835f,-46.875f, -203.125f,17.4503f,-46.875f, -207.031f,16.5736f,-46.875f, -210.938f,14.945f,-46.875f, -214.844f,12.5914f,-46.875f, -218.75f,11.835f,-46.875f, -222.656f,10.1636f,-46.875f, -226.563f,9.71281f,-46.875f, -230.469f,9.27988f,-46.875f, -234.375f,8.50394f,-46.875f, -238.281f,9.20978f,-46.875f, -242.188f,9.21707f,-46.875f, -246.094f,9.40089f,-46.875f, -250.0f,8.55411f,-46.875f, -3.90625f,59.8509f,-50.7813f, -7.8125f,59.6141f,-50.7813f, -11.7188f,59.7453f,-50.7813f, -15.625f,60.4259f,-50.7813f, -19.5313f,59.4314f,-50.7813f, -23.4375f,59.033f,-50.7813f, -27.3438f,57.561f,-50.7813f, -31.25f,57.9511f,-50.7813f, -35.1563f,57.0088f,-50.7813f, -39.0625f,56.2469f,-50.7813f, -42.9688f,55.8604f,-50.7813f, -46.875f,55.2326f,-50.7813f, -50.7813f,54.8965f,-50.7813f, -54.6875f,53.1713f,-50.7813f, -58.5938f,52.6122f,-50.7813f, -62.5f,50.9097f,-50.7813f, -66.4063f,50.8144f,-50.7813f, -70.3125f,50.2702f,-50.7813f, -74.2188f,51.4962f,-50.7813f, -78.125f,50.7879f,-50.7813f, -82.0313f,49.5502f,-50.7813f, -85.9375f,48.3386f,-50.7813f, -89.8438f,48.0143f,-50.7813f, -93.75f,46.7527f,-50.7813f, -97.6563f,45.5374f,-50.7813f, -101.563f,44.3542f,-50.7813f, -105.469f,44.8366f,-50.7813f, -109.375f,45.0192f,-50.7813f, -113.281f,44.4763f,-50.7813f, -117.188f,43.4751f,-50.7813f, -121.094f,42.029f,-50.7813f, -125.0f,40.9708f,-50.7813f, -128.906f,40.3658f,-50.7813f, -132.813f,40.0768f,-50.7813f, -136.719f,40.0333f,-50.7813f, -140.625f,38.2667f,-50.7813f, -144.531f,36.5326f,-50.7813f, -148.438f,35.8183f,-50.7813f, -152.344f,35.3934f,-50.7813f, -156.25f,34.9787f,-50.7813f, -160.156f,33.4969f,-50.7813f, -164.063f,31.7517f,-50.7813f, -167.969f,29.499f,-50.7813f, -171.875f,27.1729f,-50.7813f, -175.781f,25.4931f,-50.7813f, -179.688f,25.2745f,-50.7813f, -183.594f,25.2315f,-50.7813f, -187.5f,24.531f,-50.7813f, -191.406f,23.4387f,-50.7813f, -195.313f,21.3665f,-50.7813f, -199.219f,19.2834f,-50.7813f, -203.125f,17.7694f,-50.7813f, -207.031f,16.0247f,-50.7813f, -210.938f,13.9451f,-50.7813f, -214.844f,12.3369f,-50.7813f, -218.75f,10.9033f,-50.7813f, -222.656f,10.0734f,-50.7813f, -226.563f,9.08212f,-50.7813f, -230.469f,9.04527f,-50.7813f, -234.375f,8.83458f,-50.7813f, -238.281f,9.03578f,-50.7813f, -242.188f,9.06782f,-50.7813f, -246.094f,9.03068f,-50.7813f, -250.0f,9.66685f,-50.7813f, -3.90625f,60.3928f,-54.6875f, -7.8125f,60.9235f,-54.6875f, -11.7188f,60.8946f,-54.6875f, -15.625f,60.5131f,-54.6875f, -19.5313f,58.455f,-54.6875f, -23.4375f,57.9712f,-54.6875f, -27.3438f,57.0716f,-54.6875f, -31.25f,56.9372f,-54.6875f, -35.1563f,57.5607f,-54.6875f, -39.0625f,56.6778f,-54.6875f, -42.9688f,56.24f,-54.6875f, -46.875f,55.0661f,-54.6875f, -50.7813f,54.3546f,-54.6875f, -54.6875f,52.1641f,-54.6875f, -58.5938f,51.2643f,-54.6875f, -62.5f,49.4484f,-54.6875f, -66.4063f,48.4401f,-54.6875f, -70.3125f,48.0181f,-54.6875f, -74.2188f,48.8036f,-54.6875f, -78.125f,48.2106f,-54.6875f, -82.0313f,47.8181f,-54.6875f, -85.9375f,47.3982f,-54.6875f, -89.8438f,46.4776f,-54.6875f, -93.75f,45.3848f,-54.6875f, -97.6563f,44.5336f,-54.6875f, -101.563f,45.1445f,-54.6875f, -105.469f,45.5775f,-54.6875f, -109.375f,45.4274f,-54.6875f, -113.281f,44.4184f,-54.6875f, -117.188f,43.6208f,-54.6875f, -121.094f,43.0133f,-54.6875f, -125.0f,41.2193f,-54.6875f, -128.906f,40.0465f,-54.6875f, -132.813f,40.3451f,-54.6875f, -136.719f,39.4272f,-54.6875f, -140.625f,37.2935f,-54.6875f, -144.531f,35.9597f,-54.6875f, -148.438f,34.766f,-54.6875f, -152.344f,33.3503f,-54.6875f, -156.25f,33.6732f,-54.6875f, -160.156f,32.5764f,-54.6875f, -164.063f,30.6942f,-54.6875f, -167.969f,28.8727f,-54.6875f, -171.875f,26.8203f,-54.6875f, -175.781f,24.7162f,-54.6875f, -179.688f,23.5533f,-54.6875f, -183.594f,23.5154f,-54.6875f, -187.5f,23.3554f,-54.6875f, -191.406f,22.7735f,-54.6875f, -195.313f,22.2741f,-54.6875f, -199.219f,20.9717f,-54.6875f, -203.125f,18.5469f,-54.6875f, -207.031f,16.0531f,-54.6875f, -210.938f,13.6058f,-54.6875f, -214.844f,11.0674f,-54.6875f, -218.75f,9.89862f,-54.6875f, -222.656f,9.6172f,-54.6875f, -226.563f,8.63026f,-54.6875f, -230.469f,8.95799f,-54.6875f, -234.375f,8.84522f,-54.6875f, -238.281f,8.9176f,-54.6875f, -242.188f,9.19248f,-54.6875f, -246.094f,9.16691f,-54.6875f, -250.0f,9.42022f,-54.6875f, -3.90625f,61.5747f,-58.5938f, -7.8125f,61.244f,-58.5938f, -11.7188f,60.3982f,-58.5938f, -15.625f,59.4267f,-58.5938f, -19.5313f,58.5294f,-58.5938f, -23.4375f,56.6412f,-58.5938f, -27.3438f,56.0648f,-58.5938f, -31.25f,56.4883f,-58.5938f, -35.1563f,56.5562f,-58.5938f, -39.0625f,56.745f,-58.5938f, -42.9688f,55.6505f,-58.5938f, -46.875f,54.6622f,-58.5938f, -50.7813f,53.7206f,-58.5938f, -54.6875f,51.9309f,-58.5938f, -58.5938f,50.4214f,-58.5938f, -62.5f,48.4353f,-58.5938f, -66.4063f,47.1373f,-58.5938f, -70.3125f,46.0037f,-58.5938f, -74.2188f,45.9795f,-58.5938f, -78.125f,45.2396f,-58.5938f, -82.0313f,45.264f,-58.5938f, -85.9375f,45.2603f,-58.5938f, -89.8438f,45.3076f,-58.5938f, -93.75f,44.8744f,-58.5938f, -97.6563f,44.3646f,-58.5938f, -101.563f,45.1043f,-58.5938f, -105.469f,45.6336f,-58.5938f, -109.375f,44.6129f,-58.5938f, -113.281f,44.3333f,-58.5938f, -117.188f,44.3267f,-58.5938f, -121.094f,42.9064f,-58.5938f, -125.0f,40.63f,-58.5938f, -128.906f,41.2828f,-58.5938f, -132.813f,40.2801f,-58.5938f, -136.719f,39.4089f,-58.5938f, -140.625f,37.0919f,-58.5938f, -144.531f,34.889f,-58.5938f, -148.438f,32.5161f,-58.5938f, -152.344f,31.9597f,-58.5938f, -156.25f,31.5986f,-58.5938f, -160.156f,31.1966f,-58.5938f, -164.063f,30.4149f,-58.5938f, -167.969f,29.0304f,-58.5938f, -171.875f,27.2929f,-58.5938f, -175.781f,26.0835f,-58.5938f, -179.688f,24.7373f,-58.5938f, -183.594f,23.6409f,-58.5938f, -187.5f,23.3059f,-58.5938f, -191.406f,22.8781f,-58.5938f, -195.313f,22.319f,-58.5938f, -199.219f,21.2986f,-58.5938f, -203.125f,19.8613f,-58.5938f, -207.031f,16.8941f,-58.5938f, -210.938f,13.7519f,-58.5938f, -214.844f,11.895f,-58.5938f, -218.75f,9.64673f,-58.5938f, -222.656f,9.27102f,-58.5938f, -226.563f,9.40316f,-58.5938f, -230.469f,8.90628f,-58.5938f, -234.375f,8.63691f,-58.5938f, -238.281f,9.10736f,-58.5938f, -242.188f,9.6506f,-58.5938f, -246.094f,9.20945f,-58.5938f, -250.0f,10.1973f,-58.5938f, -3.90625f,62.1111f,-62.5f, -7.8125f,60.6401f,-62.5f, -11.7188f,59.5734f,-62.5f, -15.625f,59.219f,-62.5f, -19.5313f,57.489f,-62.5f, -23.4375f,55.7813f,-62.5f, -27.3438f,55.9775f,-62.5f, -31.25f,55.9857f,-62.5f, -35.1563f,55.7053f,-62.5f, -39.0625f,55.9712f,-62.5f, -42.9688f,54.6904f,-62.5f, -46.875f,53.8065f,-62.5f, -50.7813f,52.4182f,-62.5f, -54.6875f,50.8531f,-62.5f, -58.5938f,49.1994f,-62.5f, -62.5f,47.7017f,-62.5f, -66.4063f,45.469f,-62.5f, -70.3125f,44.3384f,-62.5f, -74.2188f,43.2272f,-62.5f, -78.125f,43.8591f,-62.5f, -82.0313f,44.3452f,-62.5f, -85.9375f,44.3048f,-62.5f, -89.8438f,44.2242f,-62.5f, -93.75f,44.0587f,-62.5f, -97.6563f,43.7317f,-62.5f, -101.563f,44.5392f,-62.5f, -105.469f,44.5257f,-62.5f, -109.375f,43.5595f,-62.5f, -113.281f,44.5114f,-62.5f, -117.188f,43.2895f,-62.5f, -121.094f,41.6188f,-62.5f, -125.0f,39.9989f,-62.5f, -128.906f,40.9613f,-62.5f, -132.813f,39.8454f,-62.5f, -136.719f,38.9499f,-62.5f, -140.625f,36.7405f,-62.5f, -144.531f,34.8983f,-62.5f, -148.438f,33.5172f,-62.5f, -152.344f,31.5497f,-62.5f, -156.25f,31.3001f,-62.5f, -160.156f,30.8035f,-62.5f, -164.063f,30.3361f,-62.5f, -167.969f,29.7129f,-62.5f, -171.875f,28.9356f,-62.5f, -175.781f,27.3605f,-62.5f, -179.688f,26.5354f,-62.5f, -183.594f,25.1923f,-62.5f, -187.5f,23.8745f,-62.5f, -191.406f,22.6444f,-62.5f, -195.313f,22.0412f,-62.5f, -199.219f,20.9675f,-62.5f, -203.125f,18.5243f,-62.5f, -207.031f,15.5154f,-62.5f, -210.938f,13.2419f,-62.5f, -214.844f,11.0082f,-62.5f, -218.75f,9.92645f,-62.5f, -222.656f,9.66787f,-62.5f, -226.563f,10.141f,-62.5f, -230.469f,9.5559f,-62.5f, -234.375f,8.93799f,-62.5f, -238.281f,9.36179f,-62.5f, -242.188f,9.32325f,-62.5f, -246.094f,9.89448f,-62.5f, -250.0f,11.3062f,-62.5f, -3.90625f,60.8569f,-66.4063f, -7.8125f,59.3087f,-66.4063f, -11.7188f,58.6192f,-66.4063f, -15.625f,57.567f,-66.4063f, -19.5313f,54.6351f,-66.4063f, -23.4375f,53.6183f,-66.4063f, -27.3438f,54.0844f,-66.4063f, -31.25f,54.4962f,-66.4063f, -35.1563f,53.9539f,-66.4063f, -39.0625f,53.4324f,-66.4063f, -42.9688f,52.6655f,-66.4063f, -46.875f,51.9681f,-66.4063f, -50.7813f,51.1623f,-66.4063f, -54.6875f,50.0114f,-66.4063f, -58.5938f,47.9598f,-66.4063f, -62.5f,46.2999f,-66.4063f, -66.4063f,44.4466f,-66.4063f, -70.3125f,42.2001f,-66.4063f, -74.2188f,41.2192f,-66.4063f, -78.125f,41.7209f,-66.4063f, -82.0313f,42.7363f,-66.4063f, -85.9375f,42.9552f,-66.4063f, -89.8438f,43.0346f,-66.4063f, -93.75f,43.4604f,-66.4063f, -97.6563f,42.6437f,-66.4063f, -101.563f,42.6894f,-66.4063f, -105.469f,43.1054f,-66.4063f, -109.375f,42.7138f,-66.4063f, -113.281f,42.4744f,-66.4063f, -117.188f,42.2299f,-66.4063f, -121.094f,41.2421f,-66.4063f, -125.0f,40.3737f,-66.4063f, -128.906f,40.1758f,-66.4063f, -132.813f,39.5421f,-66.4063f, -136.719f,39.0437f,-66.4063f, -140.625f,37.1531f,-66.4063f, -144.531f,34.9841f,-66.4063f, -148.438f,33.2713f,-66.4063f, -152.344f,32.4185f,-66.4063f, -156.25f,31.779f,-66.4063f, -160.156f,30.7377f,-66.4063f, -164.063f,30.5524f,-66.4063f, -167.969f,29.5693f,-66.4063f, -171.875f,28.9756f,-66.4063f, -175.781f,27.4499f,-66.4063f, -179.688f,26.7907f,-66.4063f, -183.594f,25.5886f,-66.4063f, -187.5f,24.2807f,-66.4063f, -191.406f,22.1754f,-66.4063f, -195.313f,20.7766f,-66.4063f, -199.219f,19.914f,-66.4063f, -203.125f,17.149f,-66.4063f, -207.031f,14.0043f,-66.4063f, -210.938f,11.404f,-66.4063f, -214.844f,10.0012f,-66.4063f, -218.75f,8.65109f,-66.4063f, -222.656f,9.38897f,-66.4063f, -226.563f,9.4612f,-66.4063f, -230.469f,8.86613f,-66.4063f, -234.375f,8.68429f,-66.4063f, -238.281f,9.75985f,-66.4063f, -242.188f,10.3807f,-66.4063f, -246.094f,10.966f,-66.4063f, -250.0f,11.4354f,-66.4063f, -3.90625f,59.1482f,-70.3125f, -7.8125f,57.7892f,-70.3125f, -11.7188f,55.5839f,-70.3125f, -15.625f,54.3451f,-70.3125f, -19.5313f,52.0576f,-70.3125f, -23.4375f,50.5935f,-70.3125f, -27.3438f,50.8648f,-70.3125f, -31.25f,51.3182f,-70.3125f, -35.1563f,51.6726f,-70.3125f, -39.0625f,51.1264f,-70.3125f, -42.9688f,51.6239f,-70.3125f, -46.875f,49.728f,-70.3125f, -50.7813f,48.7924f,-70.3125f, -54.6875f,47.3884f,-70.3125f, -58.5938f,46.4477f,-70.3125f, -62.5f,45.2447f,-70.3125f, -66.4063f,42.8677f,-70.3125f, -70.3125f,40.9023f,-70.3125f, -74.2188f,39.5284f,-70.3125f, -78.125f,39.6524f,-70.3125f, -82.0313f,40.5173f,-70.3125f, -85.9375f,41.0204f,-70.3125f, -89.8438f,41.9366f,-70.3125f, -93.75f,42.1341f,-70.3125f, -97.6563f,41.4699f,-70.3125f, -101.563f,40.6754f,-70.3125f, -105.469f,41.2206f,-70.3125f, -109.375f,40.9668f,-70.3125f, -113.281f,41.1079f,-70.3125f, -117.188f,40.7056f,-70.3125f, -121.094f,39.8305f,-70.3125f, -125.0f,40.959f,-70.3125f, -128.906f,41.7481f,-70.3125f, -132.813f,41.1255f,-70.3125f, -136.719f,39.8634f,-70.3125f, -140.625f,37.8454f,-70.3125f, -144.531f,35.3914f,-70.3125f, -148.438f,33.8462f,-70.3125f, -152.344f,33.0994f,-70.3125f, -156.25f,32.4757f,-70.3125f, -160.156f,31.4779f,-70.3125f, -164.063f,29.4211f,-70.3125f, -167.969f,28.0779f,-70.3125f, -171.875f,27.802f,-70.3125f, -175.781f,26.7406f,-70.3125f, -179.688f,25.4777f,-70.3125f, -183.594f,24.7569f,-70.3125f, -187.5f,22.9331f,-70.3125f, -191.406f,21.2419f,-70.3125f, -195.313f,19.5082f,-70.3125f, -199.219f,17.6022f,-70.3125f, -203.125f,15.316f,-70.3125f, -207.031f,12.7546f,-70.3125f, -210.938f,10.3646f,-70.3125f, -214.844f,8.2502f,-70.3125f, -218.75f,8.14317f,-70.3125f, -222.656f,8.65089f,-70.3125f, -226.563f,8.60005f,-70.3125f, -230.469f,8.58165f,-70.3125f, -234.375f,9.40162f,-70.3125f, -238.281f,9.96281f,-70.3125f, -242.188f,9.81934f,-70.3125f, -246.094f,10.3078f,-70.3125f, -250.0f,10.4404f,-70.3125f, -3.90625f,56.5167f,-74.2188f, -7.8125f,55.7237f,-74.2188f, -11.7188f,53.4039f,-74.2188f, -15.625f,51.0313f,-74.2188f, -19.5313f,49.1141f,-74.2188f, -23.4375f,47.8398f,-74.2188f, -27.3438f,47.778f,-74.2188f, -31.25f,48.3917f,-74.2188f, -35.1563f,48.2503f,-74.2188f, -39.0625f,49.1497f,-74.2188f, -42.9688f,48.8224f,-74.2188f, -46.875f,47.4358f,-74.2188f, -50.7813f,47.051f,-74.2188f, -54.6875f,45.4218f,-74.2188f, -58.5938f,44.3385f,-74.2188f, -62.5f,42.9758f,-74.2188f, -66.4063f,41.4743f,-74.2188f, -70.3125f,39.4251f,-74.2188f, -74.2188f,37.5972f,-74.2188f, -78.125f,37.8246f,-74.2188f, -82.0313f,38.9578f,-74.2188f, -85.9375f,40.148f,-74.2188f, -89.8438f,41.1035f,-74.2188f, -93.75f,40.631f,-74.2188f, -97.6563f,40.0863f,-74.2188f, -101.563f,40.3273f,-74.2188f, -105.469f,40.0413f,-74.2188f, -109.375f,40.0514f,-74.2188f, -113.281f,39.4849f,-74.2188f, -117.188f,39.5903f,-74.2188f, -121.094f,40.1543f,-74.2188f, -125.0f,40.3424f,-74.2188f, -128.906f,41.779f,-74.2188f, -132.813f,41.4976f,-74.2188f, -136.719f,41.1475f,-74.2188f, -140.625f,38.8105f,-74.2188f, -144.531f,35.834f,-74.2188f, -148.438f,34.6385f,-74.2188f, -152.344f,33.7088f,-74.2188f, -156.25f,32.7137f,-74.2188f, -160.156f,30.7745f,-74.2188f, -164.063f,28.172f,-74.2188f, -167.969f,27.1433f,-74.2188f, -171.875f,26.7248f,-74.2188f, -175.781f,25.7807f,-74.2188f, -179.688f,24.8758f,-74.2188f, -183.594f,23.4994f,-74.2188f, -187.5f,23.3209f,-74.2188f, -191.406f,22.3523f,-74.2188f, -195.313f,20.3275f,-74.2188f, -199.219f,17.2927f,-74.2188f, -203.125f,15.0486f,-74.2188f, -207.031f,12.2721f,-74.2188f, -210.938f,9.60109f,-74.2188f, -214.844f,7.36411f,-74.2188f, -218.75f,7.27514f,-74.2188f, -222.656f,8.35951f,-74.2188f, -226.563f,8.18334f,-74.2188f, -230.469f,8.98708f,-74.2188f, -234.375f,8.98011f,-74.2188f, -238.281f,9.03329f,-74.2188f, -242.188f,8.88664f,-74.2188f, -246.094f,8.62938f,-74.2188f, -250.0f,9.6823f,-74.2188f, -3.90625f,54.4402f,-78.125f, -7.8125f,53.0525f,-78.125f, -11.7188f,51.2204f,-78.125f, -15.625f,48.7251f,-78.125f, -19.5313f,45.9841f,-78.125f, -23.4375f,45.0227f,-78.125f, -27.3438f,45.3099f,-78.125f, -31.25f,45.9225f,-78.125f, -35.1563f,46.8025f,-78.125f, -39.0625f,46.8434f,-78.125f, -42.9688f,46.0024f,-78.125f, -46.875f,45.6669f,-78.125f, -50.7813f,45.4624f,-78.125f, -54.6875f,43.4573f,-78.125f, -58.5938f,42.1273f,-78.125f, -62.5f,41.0088f,-78.125f, -66.4063f,38.8967f,-78.125f, -70.3125f,38.002f,-78.125f, -74.2188f,36.5282f,-78.125f, -78.125f,37.0499f,-78.125f, -82.0313f,37.3419f,-78.125f, -85.9375f,38.6056f,-78.125f, -89.8438f,39.7527f,-78.125f, -93.75f,40.3513f,-78.125f, -97.6563f,40.6919f,-78.125f, -101.563f,40.7736f,-78.125f, -105.469f,40.3007f,-78.125f, -109.375f,39.3023f,-78.125f, -113.281f,39.1369f,-78.125f, -117.188f,39.884f,-78.125f, -121.094f,40.5674f,-78.125f, -125.0f,40.8192f,-78.125f, -128.906f,41.893f,-78.125f, -132.813f,42.3647f,-78.125f, -136.719f,41.2455f,-78.125f, -140.625f,38.7064f,-78.125f, -144.531f,36.9679f,-78.125f, -148.438f,36.03f,-78.125f, -152.344f,33.9946f,-78.125f, -156.25f,32.2274f,-78.125f, -160.156f,30.474f,-78.125f, -164.063f,28.4739f,-78.125f, -167.969f,27.222f,-78.125f, -171.875f,26.6935f,-78.125f, -175.781f,25.0624f,-78.125f, -179.688f,24.162f,-78.125f, -183.594f,24.0176f,-78.125f, -187.5f,24.0379f,-78.125f, -191.406f,22.4301f,-78.125f, -195.313f,19.7078f,-78.125f, -199.219f,17.0911f,-78.125f, -203.125f,14.784f,-78.125f, -207.031f,11.8835f,-78.125f, -210.938f,9.34715f,-78.125f, -214.844f,7.23075f,-78.125f, -218.75f,7.91637f,-78.125f, -222.656f,8.69702f,-78.125f, -226.563f,8.56112f,-78.125f, -230.469f,9.86446f,-78.125f, -234.375f,9.26431f,-78.125f, -238.281f,8.47473f,-78.125f, -242.188f,7.8386f,-78.125f, -246.094f,7.82236f,-78.125f, -250.0f,8.68625f,-78.125f, -3.90625f,51.949f,-82.0313f, -7.8125f,50.1159f,-82.0313f, -11.7188f,48.9067f,-82.0313f, -15.625f,46.6417f,-82.0313f, -19.5313f,44.5725f,-82.0313f, -23.4375f,43.435f,-82.0313f, -27.3438f,43.6749f,-82.0313f, -31.25f,44.8399f,-82.0313f, -35.1563f,45.0253f,-82.0313f, -39.0625f,44.7335f,-82.0313f, -42.9688f,44.4485f,-82.0313f, -46.875f,44.8284f,-82.0313f, -50.7813f,43.5547f,-82.0313f, -54.6875f,41.2266f,-82.0313f, -58.5938f,40.4716f,-82.0313f, -62.5f,38.4361f,-82.0313f, -66.4063f,36.3554f,-82.0313f, -70.3125f,35.5722f,-82.0313f, -74.2188f,35.0069f,-82.0313f, -78.125f,35.8289f,-82.0313f, -82.0313f,37.0933f,-82.0313f, -85.9375f,38.1008f,-82.0313f, -89.8438f,38.9582f,-82.0313f, -93.75f,40.0751f,-82.0313f, -97.6563f,40.3989f,-82.0313f, -101.563f,40.2487f,-82.0313f, -105.469f,39.9234f,-82.0313f, -109.375f,40.0277f,-82.0313f, -113.281f,40.6647f,-82.0313f, -117.188f,40.69f,-82.0313f, -121.094f,40.7857f,-82.0313f, -125.0f,41.5688f,-82.0313f, -128.906f,41.836f,-82.0313f, -132.813f,41.6054f,-82.0313f, -136.719f,39.6237f,-82.0313f, -140.625f,38.6765f,-82.0313f, -144.531f,36.9959f,-82.0313f, -148.438f,35.8215f,-82.0313f, -152.344f,34.799f,-82.0313f, -156.25f,33.2398f,-82.0313f, -160.156f,30.7864f,-82.0313f, -164.063f,28.6776f,-82.0313f, -167.969f,26.6558f,-82.0313f, -171.875f,25.8282f,-82.0313f, -175.781f,24.7932f,-82.0313f, -179.688f,22.3283f,-82.0313f, -183.594f,23.1666f,-82.0313f, -187.5f,23.1721f,-82.0313f, -191.406f,21.3358f,-82.0313f, -195.313f,18.8226f,-82.0313f, -199.219f,16.5471f,-82.0313f, -203.125f,14.4667f,-82.0313f, -207.031f,11.1533f,-82.0313f, -210.938f,8.28389f,-82.0313f, -214.844f,8.02411f,-82.0313f, -218.75f,8.03784f,-82.0313f, -222.656f,8.27638f,-82.0313f, -226.563f,8.14824f,-82.0313f, -230.469f,8.45286f,-82.0313f, -234.375f,8.21959f,-82.0313f, -238.281f,8.25224f,-82.0313f, -242.188f,7.67129f,-82.0313f, -246.094f,8.04143f,-82.0313f, -250.0f,8.6199f,-82.0313f, -3.90625f,50.007f,-85.9375f, -7.8125f,48.4593f,-85.9375f, -11.7188f,46.0233f,-85.9375f, -15.625f,44.0556f,-85.9375f, -19.5313f,42.3324f,-85.9375f, -23.4375f,41.8982f,-85.9375f, -27.3438f,42.3931f,-85.9375f, -31.25f,43.1153f,-85.9375f, -35.1563f,43.1285f,-85.9375f, -39.0625f,43.422f,-85.9375f, -42.9688f,43.5417f,-85.9375f, -46.875f,42.2294f,-85.9375f, -50.7813f,40.9068f,-85.9375f, -54.6875f,39.4177f,-85.9375f, -58.5938f,37.2575f,-85.9375f, -62.5f,35.2254f,-85.9375f, -66.4063f,33.8821f,-85.9375f, -70.3125f,33.1531f,-85.9375f, -74.2188f,34.2747f,-85.9375f, -78.125f,35.599f,-85.9375f, -82.0313f,37.007f,-85.9375f, -85.9375f,37.5018f,-85.9375f, -89.8438f,38.1376f,-85.9375f, -93.75f,38.9449f,-85.9375f, -97.6563f,38.9221f,-85.9375f, -101.563f,38.8555f,-85.9375f, -105.469f,39.5572f,-85.9375f, -109.375f,40.1231f,-85.9375f, -113.281f,40.7416f,-85.9375f, -117.188f,40.3888f,-85.9375f, -121.094f,40.6715f,-85.9375f, -125.0f,40.7246f,-85.9375f, -128.906f,40.6124f,-85.9375f, -132.813f,39.685f,-85.9375f, -136.719f,39.2043f,-85.9375f, -140.625f,38.1816f,-85.9375f, -144.531f,36.598f,-85.9375f, -148.438f,36.2907f,-85.9375f, -152.344f,34.8832f,-85.9375f, -156.25f,33.4024f,-85.9375f, -160.156f,31.2463f,-85.9375f, -164.063f,29.1669f,-85.9375f, -167.969f,26.7298f,-85.9375f, -171.875f,24.3407f,-85.9375f, -175.781f,23.4854f,-85.9375f, -179.688f,21.3474f,-85.9375f, -183.594f,21.2953f,-85.9375f, -187.5f,21.7398f,-85.9375f, -191.406f,20.4218f,-85.9375f, -195.313f,17.9433f,-85.9375f, -199.219f,15.3133f,-85.9375f, -203.125f,13.0586f,-85.9375f, -207.031f,9.24996f,-85.9375f, -210.938f,7.18408f,-85.9375f, -214.844f,7.59758f,-85.9375f, -218.75f,8.04641f,-85.9375f, -222.656f,8.01634f,-85.9375f, -226.563f,7.95015f,-85.9375f, -230.469f,7.86343f,-85.9375f, -234.375f,6.21751f,-85.9375f, -238.281f,7.40112f,-85.9375f, -242.188f,7.60481f,-85.9375f, -246.094f,6.77129f,-85.9375f, -250.0f,7.87753f,-85.9375f, -3.90625f,47.6596f,-89.8438f, -7.8125f,45.9136f,-89.8438f, -11.7188f,44.0495f,-89.8438f, -15.625f,42.5127f,-89.8438f, -19.5313f,41.5996f,-89.8438f, -23.4375f,41.2638f,-89.8438f, -27.3438f,41.2672f,-89.8438f, -31.25f,41.5402f,-89.8438f, -35.1563f,42.558f,-89.8438f, -39.0625f,42.49f,-89.8438f, -42.9688f,42.2839f,-89.8438f, -46.875f,40.9401f,-89.8438f, -50.7813f,38.7346f,-89.8438f, -54.6875f,36.624f,-89.8438f, -58.5938f,35.1978f,-89.8438f, -62.5f,34.9272f,-89.8438f, -66.4063f,32.893f,-89.8438f, -70.3125f,32.4101f,-89.8438f, -74.2188f,33.9814f,-89.8438f, -78.125f,35.8825f,-89.8438f, -82.0313f,37.1245f,-89.8438f, -85.9375f,37.3954f,-89.8438f, -89.8438f,38.0118f,-89.8438f, -93.75f,37.5426f,-89.8438f, -97.6563f,38.0776f,-89.8438f, -101.563f,37.9785f,-89.8438f, -105.469f,38.6389f,-89.8438f, -109.375f,39.284f,-89.8438f, -113.281f,40.0027f,-89.8438f, -117.188f,41.2412f,-89.8438f, -121.094f,41.2301f,-89.8438f, -125.0f,40.7611f,-89.8438f, -128.906f,39.7426f,-89.8438f, -132.813f,39.1387f,-89.8438f, -136.719f,38.499f,-89.8438f, -140.625f,37.714f,-89.8438f, -144.531f,36.6379f,-89.8438f, -148.438f,36.1196f,-89.8438f, -152.344f,35.7001f,-89.8438f, -156.25f,33.9038f,-89.8438f, -160.156f,32.0706f,-89.8438f, -164.063f,29.746f,-89.8438f, -167.969f,26.4482f,-89.8438f, -171.875f,23.8046f,-89.8438f, -175.781f,21.9675f,-89.8438f, -179.688f,20.7011f,-89.8438f, -183.594f,20.6699f,-89.8438f, -187.5f,20.1508f,-89.8438f, -191.406f,17.8245f,-89.8438f, -195.313f,16.2785f,-89.8438f, -199.219f,13.4596f,-89.8438f, -203.125f,9.54647f,-89.8438f, -207.031f,6.02727f,-89.8438f, -210.938f,5.88903f,-89.8438f, -214.844f,6.47568f,-89.8438f, -218.75f,6.20004f,-89.8438f, -222.656f,6.0849f,-89.8438f, -226.563f,6.84648f,-89.8438f, -230.469f,6.3424f,-89.8438f, -234.375f,5.81853f,-89.8438f, -238.281f,5.89205f,-89.8438f, -242.188f,6.84078f,-89.8438f, -246.094f,6.32426f,-89.8438f, -250.0f,6.29368f,-89.8438f, -3.90625f,45.4182f,-93.75f, -7.8125f,44.5664f,-93.75f, -11.7188f,44.0207f,-93.75f, -15.625f,42.2553f,-93.75f, -19.5313f,40.8951f,-93.75f, -23.4375f,40.7665f,-93.75f, -27.3438f,40.5756f,-93.75f, -31.25f,41.2988f,-93.75f, -35.1563f,40.6862f,-93.75f, -39.0625f,40.6007f,-93.75f, -42.9688f,39.5329f,-93.75f, -46.875f,38.2364f,-93.75f, -50.7813f,36.1442f,-93.75f, -54.6875f,34.7353f,-93.75f, -58.5938f,34.4214f,-93.75f, -62.5f,33.9528f,-93.75f, -66.4063f,32.4931f,-93.75f, -70.3125f,32.5145f,-93.75f, -74.2188f,33.393f,-93.75f, -78.125f,34.9658f,-93.75f, -82.0313f,36.3611f,-93.75f, -85.9375f,37.568f,-93.75f, -89.8438f,37.012f,-93.75f, -93.75f,37.6392f,-93.75f, -97.6563f,38.4371f,-93.75f, -101.563f,38.3719f,-93.75f, -105.469f,39.1179f,-93.75f, -109.375f,38.5168f,-93.75f, -113.281f,40.0403f,-93.75f, -117.188f,40.2277f,-93.75f, -121.094f,40.8985f,-93.75f, -125.0f,40.189f,-93.75f, -128.906f,39.9435f,-93.75f, -132.813f,39.6824f,-93.75f, -136.719f,38.844f,-93.75f, -140.625f,37.4579f,-93.75f, -144.531f,36.8375f,-93.75f, -148.438f,36.2601f,-93.75f, -152.344f,35.6484f,-93.75f, -156.25f,34.179f,-93.75f, -160.156f,32.0651f,-93.75f, -164.063f,28.6431f,-93.75f, -167.969f,25.1239f,-93.75f, -171.875f,22.4459f,-93.75f, -175.781f,19.5301f,-93.75f, -179.688f,18.4371f,-93.75f, -183.594f,18.6076f,-93.75f, -187.5f,17.488f,-93.75f, -191.406f,15.1604f,-93.75f, -195.313f,13.0197f,-93.75f, -199.219f,9.4702f,-93.75f, -203.125f,5.597f,-93.75f, -207.031f,3.59409f,-93.75f, -210.938f,4.28966f,-93.75f, -214.844f,4.21811f,-93.75f, -218.75f,4.11546f,-93.75f, -222.656f,5.40815f,-93.75f, -226.563f,5.56249f,-93.75f, -230.469f,5.35075f,-93.75f, -234.375f,5.24306f,-93.75f, -238.281f,4.85548f,-93.75f, -242.188f,5.02825f,-93.75f, -246.094f,5.32318f,-93.75f, -250.0f,5.59512f,-93.75f, -3.90625f,44.9637f,-97.6563f, -7.8125f,44.7813f,-97.6563f, -11.7188f,43.457f,-97.6563f, -15.625f,42.5329f,-97.6563f, -19.5313f,40.506f,-97.6563f, -23.4375f,39.8146f,-97.6563f, -27.3438f,40.2245f,-97.6563f, -31.25f,39.497f,-97.6563f, -35.1563f,38.8152f,-97.6563f, -39.0625f,38.3406f,-97.6563f, -42.9688f,37.57f,-97.6563f, -46.875f,36.3128f,-97.6563f, -50.7813f,34.2277f,-97.6563f, -54.6875f,33.3395f,-97.6563f, -58.5938f,32.972f,-97.6563f, -62.5f,32.6315f,-97.6563f, -66.4063f,32.4796f,-97.6563f, -70.3125f,31.6472f,-97.6563f, -74.2188f,32.2256f,-97.6563f, -78.125f,33.8073f,-97.6563f, -82.0313f,35.7591f,-97.6563f, -85.9375f,36.5001f,-97.6563f, -89.8438f,36.9113f,-97.6563f, -93.75f,37.6902f,-97.6563f, -97.6563f,37.9643f,-97.6563f, -101.563f,38.9556f,-97.6563f, -105.469f,39.6823f,-97.6563f, -109.375f,38.9917f,-97.6563f, -113.281f,40.0872f,-97.6563f, -117.188f,40.44f,-97.6563f, -121.094f,39.6877f,-97.6563f, -125.0f,39.0011f,-97.6563f, -128.906f,39.8735f,-97.6563f, -132.813f,39.5503f,-97.6563f, -136.719f,37.743f,-97.6563f, -140.625f,36.4691f,-97.6563f, -144.531f,36.1765f,-97.6563f, -148.438f,35.9476f,-97.6563f, -152.344f,35.1141f,-97.6563f, -156.25f,33.2516f,-97.6563f, -160.156f,30.654f,-97.6563f, -164.063f,27.2318f,-97.6563f, -167.969f,23.3975f,-97.6563f, -171.875f,20.6722f,-97.6563f, -175.781f,18.394f,-97.6563f, -179.688f,17.6475f,-97.6563f, -183.594f,16.1037f,-97.6563f, -187.5f,14.761f,-97.6563f, -191.406f,12.2456f,-97.6563f, -195.313f,9.43327f,-97.6563f, -199.219f,6.9118f,-97.6563f, -203.125f,4.26334f,-97.6563f, -207.031f,3.47413f,-97.6563f, -210.938f,3.74872f,-97.6563f, -214.844f,3.7631f,-97.6563f, -218.75f,3.80513f,-97.6563f, -222.656f,4.23443f,-97.6563f, -226.563f,3.71016f,-97.6563f, -230.469f,3.772f,-97.6563f, -234.375f,3.80374f,-97.6563f, -238.281f,3.70762f,-97.6563f, -242.188f,4.23931f,-97.6563f, -246.094f,4.40519f,-97.6563f, -250.0f,4.5119f,-97.6563f, -3.90625f,44.5311f,-101.563f, -7.8125f,44.4181f,-101.563f, -11.7188f,43.4864f,-101.563f, -15.625f,42.259f,-101.563f, -19.5313f,41.0558f,-101.563f, -23.4375f,39.9996f,-101.563f, -27.3438f,39.3917f,-101.563f, -31.25f,39.5691f,-101.563f, -35.1563f,37.0889f,-101.563f, -39.0625f,36.4296f,-101.563f, -42.9688f,36.543f,-101.563f, -46.875f,35.4365f,-101.563f, -50.7813f,33.3641f,-101.563f, -54.6875f,32.0629f,-101.563f, -58.5938f,32.175f,-101.563f, -62.5f,32.775f,-101.563f, -66.4063f,31.6335f,-101.563f, -70.3125f,32.1001f,-101.563f, -74.2188f,32.5906f,-101.563f, -78.125f,33.1502f,-101.563f, -82.0313f,35.1972f,-101.563f, -85.9375f,36.0132f,-101.563f, -89.8438f,37.3442f,-101.563f, -93.75f,37.6109f,-101.563f, -97.6563f,38.1601f,-101.563f, -101.563f,39.77f,-101.563f, -105.469f,39.6862f,-101.563f, -109.375f,39.4829f,-101.563f, -113.281f,40.1383f,-101.563f, -117.188f,40.8908f,-101.563f, -121.094f,39.3517f,-101.563f, -125.0f,38.9321f,-101.563f, -128.906f,39.2537f,-101.563f, -132.813f,38.4876f,-101.563f, -136.719f,36.6755f,-101.563f, -140.625f,35.2803f,-101.563f, -144.531f,35.8754f,-101.563f, -148.438f,36.2761f,-101.563f, -152.344f,34.7815f,-101.563f, -156.25f,32.2662f,-101.563f, -160.156f,29.8191f,-101.563f, -164.063f,25.8929f,-101.563f, -167.969f,22.552f,-101.563f, -171.875f,20.3186f,-101.563f, -175.781f,17.2917f,-101.563f, -179.688f,16.8305f,-101.563f, -183.594f,14.7168f,-101.563f, -187.5f,12.0609f,-101.563f, -191.406f,9.91022f,-101.563f, -195.313f,7.22029f,-101.563f, -199.219f,5.48379f,-101.563f, -203.125f,3.03759f,-101.563f, -207.031f,3.02148f,-101.563f, -210.938f,2.88667f,-101.563f, -214.844f,3.08795f,-101.563f, -218.75f,3.43814f,-101.563f, -222.656f,3.58591f,-101.563f, -226.563f,3.17855f,-101.563f, -230.469f,2.48711f,-101.563f, -234.375f,2.66471f,-101.563f, -238.281f,2.06432f,-101.563f, -242.188f,2.49704f,-101.563f, -246.094f,3.05219f,-101.563f, -250.0f,3.69155f,-101.563f, -3.90625f,44.8466f,-105.469f, -7.8125f,44.3102f,-105.469f, -11.7188f,43.8936f,-105.469f, -15.625f,43.2285f,-105.469f, -19.5313f,42.7384f,-105.469f, -23.4375f,41.2954f,-105.469f, -27.3438f,39.4813f,-105.469f, -31.25f,38.4483f,-105.469f, -35.1563f,35.8264f,-105.469f, -39.0625f,35.0991f,-105.469f, -42.9688f,35.1929f,-105.469f, -46.875f,34.3044f,-105.469f, -50.7813f,31.4169f,-105.469f, -54.6875f,30.8206f,-105.469f, -58.5938f,31.2902f,-105.469f, -62.5f,32.2869f,-105.469f, -66.4063f,32.5121f,-105.469f, -70.3125f,32.772f,-105.469f, -74.2188f,32.5422f,-105.469f, -78.125f,34.0506f,-105.469f, -82.0313f,35.4894f,-105.469f, -85.9375f,36.753f,-105.469f, -89.8438f,37.6901f,-105.469f, -93.75f,37.848f,-105.469f, -97.6563f,38.9724f,-105.469f, -101.563f,40.0724f,-105.469f, -105.469f,39.7381f,-105.469f, -109.375f,39.3905f,-105.469f, -113.281f,39.8577f,-105.469f, -117.188f,40.4957f,-105.469f, -121.094f,39.554f,-105.469f, -125.0f,39.0384f,-105.469f, -128.906f,38.2112f,-105.469f, -132.813f,36.7141f,-105.469f, -136.719f,34.736f,-105.469f, -140.625f,34.2236f,-105.469f, -144.531f,35.4181f,-105.469f, -148.438f,35.4456f,-105.469f, -152.344f,33.4389f,-105.469f, -156.25f,29.9708f,-105.469f, -160.156f,27.2392f,-105.469f, -164.063f,24.3409f,-105.469f, -167.969f,22.4438f,-105.469f, -171.875f,19.5326f,-105.469f, -175.781f,16.9951f,-105.469f, -179.688f,14.77f,-105.469f, -183.594f,13.1816f,-105.469f, -187.5f,10.3711f,-105.469f, -191.406f,7.10511f,-105.469f, -195.313f,5.43711f,-105.469f, -199.219f,3.35463f,-105.469f, -203.125f,2.41276f,-105.469f, -207.031f,2.35357f,-105.469f, -210.938f,2.28627f,-105.469f, -214.844f,1.61561f,-105.469f, -218.75f,2.61087f,-105.469f, -222.656f,2.34638f,-105.469f, -226.563f,1.47074f,-105.469f, -230.469f,0.63025f,-105.469f, -234.375f,0.847991f,-105.469f, -238.281f,1.35199f,-105.469f, -242.188f,2.21032f,-105.469f, -246.094f,3.01323f,-105.469f, -250.0f,3.12713f,-105.469f, -3.90625f,45.3987f,-109.375f, -7.8125f,44.6273f,-109.375f, -11.7188f,44.5674f,-109.375f, -15.625f,44.2998f,-109.375f, -19.5313f,43.5383f,-109.375f, -23.4375f,42.0306f,-109.375f, -27.3438f,40.7068f,-109.375f, -31.25f,39.6497f,-109.375f, -35.1563f,36.2161f,-109.375f, -39.0625f,34.8769f,-109.375f, -42.9688f,35.1989f,-109.375f, -46.875f,33.9714f,-109.375f, -50.7813f,30.9979f,-109.375f, -54.6875f,31.9366f,-109.375f, -58.5938f,31.5755f,-109.375f, -62.5f,31.572f,-109.375f, -66.4063f,33.0668f,-109.375f, -70.3125f,33.6444f,-109.375f, -74.2188f,32.5467f,-109.375f, -78.125f,34.2686f,-109.375f, -82.0313f,36.0633f,-109.375f, -85.9375f,37.5569f,-109.375f, -89.8438f,38.5599f,-109.375f, -93.75f,38.6708f,-109.375f, -97.6563f,39.2558f,-109.375f, -101.563f,39.9111f,-109.375f, -105.469f,39.9236f,-109.375f, -109.375f,39.5666f,-109.375f, -113.281f,40.1532f,-109.375f, -117.188f,40.8773f,-109.375f, -121.094f,40.133f,-109.375f, -125.0f,38.348f,-109.375f, -128.906f,36.9174f,-109.375f, -132.813f,34.8975f,-109.375f, -136.719f,32.9097f,-109.375f, -140.625f,32.6666f,-109.375f, -144.531f,33.1207f,-109.375f, -148.438f,32.6024f,-109.375f, -152.344f,31.1149f,-109.375f, -156.25f,27.7885f,-109.375f, -160.156f,24.9665f,-109.375f, -164.063f,22.789f,-109.375f, -167.969f,20.4907f,-109.375f, -171.875f,18.2402f,-109.375f, -175.781f,15.9409f,-109.375f, -179.688f,12.7122f,-109.375f, -183.594f,10.9582f,-109.375f, -187.5f,7.47226f,-109.375f, -191.406f,4.87747f,-109.375f, -195.313f,2.78589f,-109.375f, -199.219f,1.53429f,-109.375f, -203.125f,1.61775f,-109.375f, -207.031f,1.772f,-109.375f, -210.938f,1.15444f,-109.375f, -214.844f,0.342505f,-109.375f, -218.75f,0.510183f,-109.375f, -222.656f,0.254977f,-109.375f, -226.563f,-0.22727f,-109.375f, -230.469f,-0.840625f,-109.375f, -234.375f,-0.282154f,-109.375f, -238.281f,0.424945f,-109.375f, -242.188f,1.73577f,-109.375f, -246.094f,1.80217f,-109.375f, -250.0f,1.60105f,-109.375f, -3.90625f,47.4869f,-113.281f, -7.8125f,46.3185f,-113.281f, -11.7188f,46.4911f,-113.281f, -15.625f,45.2506f,-113.281f, -19.5313f,43.7939f,-113.281f, -23.4375f,42.6062f,-113.281f, -27.3438f,41.6674f,-113.281f, -31.25f,39.5196f,-113.281f, -35.1563f,36.6784f,-113.281f, -39.0625f,35.8546f,-113.281f, -42.9688f,35.2647f,-113.281f, -46.875f,33.0882f,-113.281f, -50.7813f,31.1331f,-113.281f, -54.6875f,31.9095f,-113.281f, -58.5938f,31.5715f,-113.281f, -62.5f,32.3642f,-113.281f, -66.4063f,33.2578f,-113.281f, -70.3125f,33.1847f,-113.281f, -74.2188f,33.6624f,-113.281f, -78.125f,35.6582f,-113.281f, -82.0313f,36.7989f,-113.281f, -85.9375f,37.9951f,-113.281f, -89.8438f,38.7063f,-113.281f, -93.75f,39.9727f,-113.281f, -97.6563f,39.641f,-113.281f, -101.563f,40.1318f,-113.281f, -105.469f,40.117f,-113.281f, -109.375f,40.0678f,-113.281f, -113.281f,40.1534f,-113.281f, -117.188f,40.7841f,-113.281f, -121.094f,39.3312f,-113.281f, -125.0f,38.1823f,-113.281f, -128.906f,37.0921f,-113.281f, -132.813f,34.9687f,-113.281f, -136.719f,32.6631f,-113.281f, -140.625f,30.9601f,-113.281f, -144.531f,31.0644f,-113.281f, -148.438f,29.6495f,-113.281f, -152.344f,27.5095f,-113.281f, -156.25f,24.9361f,-113.281f, -160.156f,22.6206f,-113.281f, -164.063f,20.1136f,-113.281f, -167.969f,17.9862f,-113.281f, -171.875f,16.1252f,-113.281f, -175.781f,14.2991f,-113.281f, -179.688f,11.4262f,-113.281f, -183.594f,8.55749f,-113.281f, -187.5f,6.02067f,-113.281f, -191.406f,3.1883f,-113.281f, -195.313f,1.54808f,-113.281f, -199.219f,0.0223479f,-113.281f, -203.125f,-0.0807506f,-113.281f, -207.031f,-0.420855f,-113.281f, -210.938f,-0.531322f,-113.281f, -214.844f,-1.34393f,-113.281f, -218.75f,-2.28346f,-113.281f, -222.656f,-2.245f,-113.281f, -226.563f,-2.22932f,-113.281f, -230.469f,-1.47268f,-113.281f, -234.375f,-0.543695f,-113.281f, -238.281f,-0.391948f,-113.281f, -242.188f,-0.270077f,-113.281f, -246.094f,-0.650629f,-113.281f, -250.0f,0.111517f,-113.281f, -3.90625f,48.3887f,-117.188f, -7.8125f,48.004f,-117.188f, -11.7188f,46.8723f,-117.188f, -15.625f,45.5005f,-117.188f, -19.5313f,43.3644f,-117.188f, -23.4375f,42.3352f,-117.188f, -27.3438f,41.1562f,-117.188f, -31.25f,39.1736f,-117.188f, -35.1563f,38.0627f,-117.188f, -39.0625f,36.4728f,-117.188f, -42.9688f,34.8001f,-117.188f, -46.875f,32.5103f,-117.188f, -50.7813f,31.6328f,-117.188f, -54.6875f,31.6106f,-117.188f, -58.5938f,32.3004f,-117.188f, -62.5f,32.696f,-117.188f, -66.4063f,33.3795f,-117.188f, -70.3125f,33.9696f,-117.188f, -74.2188f,34.9211f,-117.188f, -78.125f,36.7686f,-117.188f, -82.0313f,37.7676f,-117.188f, -85.9375f,37.8174f,-117.188f, -89.8438f,38.2878f,-117.188f, -93.75f,39.6151f,-117.188f, -97.6563f,39.7422f,-117.188f, -101.563f,40.9611f,-117.188f, -105.469f,40.8932f,-117.188f, -109.375f,40.6603f,-117.188f, -113.281f,40.2935f,-117.188f, -117.188f,39.8681f,-117.188f, -121.094f,39.0965f,-117.188f, -125.0f,37.1333f,-117.188f, -128.906f,35.5222f,-117.188f, -132.813f,33.9068f,-117.188f, -136.719f,32.2618f,-117.188f, -140.625f,29.8657f,-117.188f, -144.531f,28.1704f,-117.188f, -148.438f,27.1495f,-117.188f, -152.344f,24.5217f,-117.188f, -156.25f,22.0419f,-117.188f, -160.156f,19.9238f,-117.188f, -164.063f,17.6875f,-117.188f, -167.969f,15.5636f,-117.188f, -171.875f,13.5497f,-117.188f, -175.781f,11.2761f,-117.188f, -179.688f,8.95864f,-117.188f, -183.594f,7.04623f,-117.188f, -187.5f,4.83635f,-117.188f, -191.406f,2.76046f,-117.188f, -195.313f,0.190119f,-117.188f, -199.219f,-0.558379f,-117.188f, -203.125f,-1.03303f,-117.188f, -207.031f,-2.17563f,-117.188f, -210.938f,-1.91155f,-117.188f, -214.844f,-3.00018f,-117.188f, -218.75f,-4.26691f,-117.188f, -222.656f,-5.15855f,-117.188f, -226.563f,-3.46348f,-117.188f, -230.469f,-2.16077f,-117.188f, -234.375f,-1.47785f,-117.188f, -238.281f,-1.78424f,-117.188f, -242.188f,-1.00317f,-117.188f, -246.094f,-1.97981f,-117.188f, -250.0f,-2.29372f,-117.188f, -}; - -btScalar Landscape03Nml[] = { --0.0301669f,0.913898f,-0.404822f, -0.0925944f,0.901922f,-0.421856f, -0.0550338f,0.955133f,-0.291019f, -0.163554f,0.924847f,-0.343379f, --0.00160556f,0.985516f,-0.169577f, -0.0975687f,0.967908f,-0.23159f, --0.0718641f,0.997324f,-0.0134097f, -0.108884f,0.992259f,0.0597208f, --0.0649193f,0.987727f,0.142057f, --0.0923076f,0.995503f,-0.0212622f, --0.212176f,0.966905f,0.141687f, --0.135924f,0.982555f,0.126925f, --0.248136f,0.950917f,0.184892f, --0.114969f,0.937595f,0.328173f, --0.0596382f,0.954355f,0.292661f, --0.0673134f,0.931098f,0.358506f, --0.100514f,0.963905f,0.246544f, --0.237357f,0.960335f,0.146353f, --0.210275f,0.964506f,0.159726f, --0.243879f,0.969407f,-0.027797f, --0.0995316f,0.963559f,0.248291f, -0.0232774f,0.986211f,0.163848f, --0.0780955f,0.939808f,0.33266f, -0.0143543f,0.937354f,0.348083f, --0.242603f,0.911487f,0.332166f, --0.217791f,0.899583f,0.378572f, --0.259297f,0.919695f,0.294833f, --0.235372f,0.900382f,0.365939f, -0.0548314f,0.924698f,0.376733f, -0.17577f,0.83537f,0.520828f, -0.183628f,0.8685f,0.460423f, -0.206319f,0.791195f,0.57571f, -0.291585f,0.831097f,0.473557f, -0.258977f,0.806104f,0.532097f, -0.406441f,0.807616f,0.427274f, -0.279416f,0.89888f,0.337552f, -0.161449f,0.944511f,0.286064f, --0.0153595f,0.999467f,0.0288015f, -0.0344442f,0.986316f,0.16123f, -0.0228147f,0.999694f,-0.00950936f, -0.221267f,0.961345f,0.163882f, -0.262982f,0.961437f,0.0804904f, -0.292545f,0.943495f,0.155677f, -0.287728f,0.952627f,0.0985627f, -0.338791f,0.935036f,0.104535f, -0.332042f,0.939101f,0.0885263f, -0.395865f,0.914692f,0.0814219f, -0.342439f,0.937891f,0.0556409f, -0.24643f,0.967531f,-0.0561722f, -0.155524f,0.980084f,-0.12348f, -0.12756f,0.989194f,-0.0722747f, -0.141529f,0.984734f,-0.10133f, -0.0842668f,0.99539f,-0.0458028f, -0.00840046f,0.967846f,-0.251403f, -0.0723924f,0.995277f,-0.0646756f, -0.161395f,0.974624f,-0.155111f, -0.168526f,0.983485f,0.0660013f, -0.32936f,0.929371f,0.166709f, -0.334018f,0.924548f,0.18342f, -0.39263f,0.883836f,0.254313f, -0.373683f,0.906029f,0.198675f, -0.318503f,0.931732f,0.174444f, -0.214891f,0.969497f,0.117891f, -0.248914f,0.936934f,0.245348f, -0.199074f,0.96113f,0.19131f, -0.293417f,0.893252f,0.340597f, -0.339667f,0.873015f,0.349959f, -0.354613f,0.873548f,0.333412f, -0.457963f,0.824157f,0.333219f, -0.455319f,0.825254f,0.334127f, -0.52695f,0.805593f,0.270821f, -0.439193f,0.858556f,0.264557f, -0.401282f,0.908751f,0.114652f, -0.249111f,0.965853f,-0.0712114f, -0.0897089f,0.991664f,0.0924929f, -0.0376765f,0.979393f,-0.19842f, --0.126991f,0.990951f,0.0434627f, --0.217753f,0.933113f,-0.286154f, --0.167574f,0.97576f,-0.140749f, --0.203937f,0.914317f,-0.349907f, --0.0608955f,0.980207f,-0.188379f, --0.0120075f,0.947447f,-0.319686f, -0.167601f,0.980952f,-0.0982003f, -0.212052f,0.945824f,-0.245868f, -0.218606f,0.972968f,-0.0744646f, -0.212851f,0.953898f,-0.211596f, -0.171647f,0.974969f,-0.141323f, -0.199197f,0.967793f,-0.153938f, -0.200412f,0.972091f,-0.121957f, -0.23265f,0.963849f,-0.129883f, -0.296235f,0.953212f,-0.060261f, -0.314311f,0.946698f,-0.0705058f, -0.404868f,0.912189f,-0.0631982f, -0.403087f,0.912504f,-0.0696997f, -0.463227f,0.884095f,-0.0616207f, -0.39479f,0.897802f,-0.195171f, -0.35121f,0.926619f,-0.13427f, -0.220773f,0.898508f,-0.379398f, -0.189824f,0.93595f,-0.296589f, -0.0483901f,0.855509f,-0.515522f, -0.0904515f,0.884685f,-0.457329f, -0.120283f,0.865017f,-0.487112f, -0.203986f,0.900002f,-0.385209f, -0.248454f,0.881227f,-0.402131f, -0.178575f,0.929214f,-0.323532f, -0.0792679f,0.824417f,-0.560404f, -0.115378f,0.950213f,-0.289454f, -0.0725597f,0.807744f,-0.585051f, -0.0327706f,0.953791f,-0.298679f, -0.0099385f,0.78612f,-0.617994f, -0.0403637f,0.952173f,-0.302881f, -0.215114f,0.87002f,-0.443611f, -0.182967f,0.972742f,-0.142465f, -0.292542f,0.923312f,-0.248827f, -0.159782f,0.983577f,-0.0839386f, -0.255356f,0.959339f,-0.120256f, -0.180088f,0.983508f,0.0167535f, -0.210595f,0.975243f,-0.0674566f, -0.305089f,0.951559f,0.0381592f, -0.342154f,0.939613f,0.00764387f, -0.44387f,0.894627f,0.0512048f, -0.377004f,0.921573f,-0.0925792f, -0.197535f,0.978807f,-0.0540106f, -0.128094f,0.953819f,-0.271702f, -0.10228f,0.991256f,-0.0833686f, -0.111348f,0.971755f,-0.208074f, -0.120727f,0.982203f,-0.143886f, -0.131919f,0.971754f,-0.195681f, --0.118481f,0.971727f,-0.204228f, --0.131824f,0.977685f,-0.163569f, --0.0725384f,0.997366f,-0.000133281f, --0.204047f,0.978951f,0.00446862f, --0.227431f,0.966677f,0.117515f, --0.137601f,0.963906f,0.227929f, --0.242399f,0.965055f,0.0995586f, --0.153062f,0.97808f,0.141178f, --0.129415f,0.948353f,0.289617f, --0.22442f,0.902886f,0.366649f, --0.173979f,0.92147f,0.34731f, --0.0318649f,0.93595f,0.350687f, --0.176397f,0.955508f,0.236408f, --0.254551f,0.956811f,0.140418f, --0.0162894f,0.984782f,0.173032f, -0.167302f,0.961803f,0.216667f, -0.267797f,0.948626f,0.168505f, -0.412955f,0.869957f,0.269525f, -0.258065f,0.893814f,0.366742f, -0.124905f,0.932115f,0.339941f, -0.234805f,0.927845f,0.289777f, -0.325979f,0.90761f,0.264542f, -0.401458f,0.890435f,0.214374f, -0.44845f,0.886659f,0.112823f, -0.337292f,0.940965f,0.0286028f, -0.110729f,0.992952f,-0.0422648f, -0.0165495f,0.996512f,-0.0817925f, -0.0843804f,0.994583f,-0.0606957f, -0.1131f,0.990749f,-0.0749933f, -0.241223f,0.970417f,0.0100747f, -0.396578f,0.902933f,0.165644f, -0.324808f,0.936808f,0.129963f, -0.0728626f,0.997053f,0.0240034f, -0.167633f,0.975741f,0.140815f, -0.474631f,0.846984f,0.239465f, -0.567824f,0.786908f,0.24156f, -0.402496f,0.873451f,0.274008f, -0.0459982f,0.950641f,0.306865f, --0.0582337f,0.962437f,0.265188f, -0.030037f,0.970181f,0.240514f, --0.0533502f,0.992438f,0.110548f, -0.0995416f,0.988544f,0.11346f, -0.255626f,0.959556f,0.11793f, -0.26735f,0.961569f,0.0625254f, -0.18836f,0.981833f,-0.0228855f, -0.278864f,0.958778f,-0.0545789f, -0.407529f,0.909061f,-0.086769f, -0.427129f,0.902011f,-0.0627458f, -0.408272f,0.912551f,-0.0237565f, -0.36375f,0.922794f,-0.127037f, -0.266363f,0.919721f,-0.28838f, -0.0788795f,0.927162f,-0.366263f, -0.0391177f,0.978258f,-0.20367f, -0.0160429f,0.996725f,-0.0792609f, -0.0608773f,0.998141f,0.00292939f, -0.025245f,0.998361f,-0.0513526f, -0.140845f,0.988959f,-0.046063f, -0.138979f,0.986427f,-0.0874468f, -0.128983f,0.987322f,-0.0925141f, -0.303074f,0.948227f,-0.0949297f, -0.392011f,0.918105f,-0.0584085f, -0.26566f,0.960779f,0.0795528f, -0.166068f,0.98603f,-0.0129125f, -0.262845f,0.962536f,-0.0666132f, --0.104783f,0.989703f,0.0975085f, --0.153604f,0.984769f,0.0814646f, --0.17021f,0.98292f,0.0699758f, --0.192965f,0.974203f,0.117018f, --0.286836f,0.952199f,0.105086f, --0.195248f,0.969752f,0.146488f, --0.150662f,0.967412f,0.203504f, --0.264752f,0.950334f,0.163619f, --0.315905f,0.913283f,0.257134f, --0.224744f,0.91965f,0.322078f, --0.108929f,0.947464f,0.300743f, -0.0128823f,0.944776f,0.327463f, --0.0190359f,0.964202f,0.264485f, --0.187346f,0.97974f,0.0707926f, --0.0647113f,0.997854f,-0.0100069f, -0.163923f,0.98566f,0.0400324f, -0.299244f,0.952147f,0.0622031f, -0.300231f,0.948028f,0.105378f, -0.182306f,0.951449f,0.248009f, -0.15023f,0.937487f,0.313924f, -0.264855f,0.926023f,0.268948f, -0.322593f,0.919374f,0.225135f, -0.43093f,0.873406f,0.22685f, -0.536094f,0.828094f,0.163899f, -0.40435f,0.914491f,0.0144028f, -0.203744f,0.975451f,-0.0835749f, -0.102706f,0.983162f,-0.151145f, -0.0912494f,0.98262f,-0.161654f, -0.0714052f,0.991795f,-0.106042f, -0.113839f,0.992199f,-0.0508211f, -0.266818f,0.963676f,0.0116937f, -0.379059f,0.920849f,0.091386f, -0.155245f,0.98775f,0.0158058f, -0.135484f,0.989724f,-0.0457313f, -0.394833f,0.917954f,-0.0383045f, -0.510875f,0.847518f,0.143943f, -0.369724f,0.884704f,0.283906f, -0.16927f,0.926331f,0.336538f, --0.0368298f,0.974452f,0.221557f, -0.0247064f,0.955492f,0.293981f, -0.0101397f,0.960739f,0.27727f, -0.120365f,0.954563f,0.272621f, -0.285189f,0.933274f,0.218327f, -0.27356f,0.947401f,0.16612f, -0.298803f,0.939862f,0.165455f, -0.344494f,0.938521f,0.0223999f, -0.423232f,0.90602f,-0.00171397f, -0.428479f,0.903517f,-0.00795118f, -0.445837f,0.889867f,-0.0967762f, -0.420806f,0.885752f,-0.195872f, -0.361482f,0.916002f,-0.173987f, -0.0888846f,0.94798f,-0.305668f, --0.104291f,0.938663f,-0.328687f, --0.0525896f,0.969771f,-0.238281f, -0.0233793f,0.980465f,-0.1953f, -0.0772242f,0.980658f,-0.179852f, -0.158397f,0.962723f,-0.219259f, -0.207852f,0.94171f,-0.264536f, -0.167471f,0.922973f,-0.346518f, -0.273321f,0.900673f,-0.337764f, -0.244245f,0.947327f,-0.207161f, -0.179974f,0.982676f,-0.0442354f, -0.256056f,0.966655f,0.00369743f, -0.311224f,0.950239f,-0.0136096f, --0.114346f,0.96184f,0.248574f, --0.136601f,0.952445f,0.272377f, --0.118024f,0.9521f,0.282091f, --0.208962f,0.956737f,0.20246f, --0.278994f,0.940284f,0.195009f, --0.257672f,0.939434f,0.225986f, --0.195307f,0.931658f,0.306381f, --0.244185f,0.930201f,0.274044f, --0.297894f,0.926606f,0.229479f, --0.247712f,0.954952f,0.163421f, --0.130651f,0.964187f,0.230812f, --0.0752954f,0.962878f,0.259223f, -0.102408f,0.945859f,0.308f, --0.0116154f,0.986031f,0.166158f, -0.0110135f,0.994405f,0.105056f, -0.0951503f,0.992756f,0.0733669f, -0.243797f,0.961487f,0.12691f, -0.260872f,0.955085f,0.140567f, -0.0581113f,0.983556f,0.170998f, -0.136043f,0.955475f,0.261839f, -0.341254f,0.920705f,0.189336f, -0.362462f,0.927476f,0.0917096f, -0.434756f,0.897441f,0.0747436f, -0.56712f,0.819757f,0.0798336f, -0.532941f,0.840799f,0.0950342f, -0.285812f,0.957415f,-0.0408404f, -0.105292f,0.985973f,-0.129498f, -0.0183827f,0.988838f,-0.147857f, -0.00614806f,0.993133f,-0.116825f, -0.099955f,0.989102f,-0.108098f, -0.238003f,0.969438f,-0.0595305f, -0.37769f,0.925502f,0.0282058f, -0.22782f,0.973089f,-0.0345812f, -0.169707f,0.981804f,-0.085208f, -0.345833f,0.936168f,-0.0631539f, -0.390375f,0.920563f,0.0130624f, -0.292594f,0.949139f,0.116291f, -0.162356f,0.962761f,0.216174f, --0.0222207f,0.972687f,0.231055f, --0.0543181f,0.955402f,0.290271f, -0.0573363f,0.941579f,0.331875f, -0.0971816f,0.964596f,0.245172f, -0.31345f,0.917083f,0.246388f, -0.307384f,0.923753f,0.228463f, -0.331585f,0.921188f,0.203628f, -0.40966f,0.902178f,0.135106f, -0.421265f,0.901117f,0.102585f, -0.477285f,0.878068f,0.0345826f, -0.547818f,0.833857f,-0.0676607f, -0.41388f,0.899953f,-0.13707f, -0.336726f,0.938017f,-0.0820957f, -0.267129f,0.960427f,-0.0788775f, --0.0301028f,0.966021f,-0.256704f, --0.102361f,0.925067f,-0.36575f, --0.0109209f,0.925593f,-0.378364f, -0.0802595f,0.925005f,-0.371381f, -0.178475f,0.901809f,-0.393558f, -0.234643f,0.9031f,-0.359657f, -0.21073f,0.932522f,-0.29325f, -0.145492f,0.962309f,-0.22977f, -0.0986234f,0.992893f,-0.0666048f, -0.0609779f,0.998071f,0.0116837f, -0.208222f,0.976086f,0.0624398f, -0.291247f,0.954621f,0.0622453f, --0.144182f,0.940028f,0.309126f, --0.205006f,0.91833f,0.33859f, --0.12423f,0.88968f,0.43936f, --0.080186f,0.900963f,0.426423f, --0.276852f,0.915664f,0.291398f, --0.294009f,0.912157f,0.285532f, --0.229314f,0.935643f,0.268306f, --0.167187f,0.934278f,0.314918f, --0.22242f,0.937858f,0.266367f, --0.260643f,0.947201f,0.186748f, --0.191964f,0.952786f,0.235261f, --0.0626162f,0.968356f,0.24159f, -0.113658f,0.975135f,0.190246f, -0.0609991f,0.983083f,0.172707f, -0.00661942f,0.987494f,0.157516f, -0.132957f,0.988179f,0.0763221f, -0.229975f,0.973129f,-0.011475f, -0.267568f,0.962445f,0.0458956f, -0.0512446f,0.996521f,0.0657221f, -0.10251f,0.994623f,0.0147167f, -0.405413f,0.913613f,0.0308412f, -0.422693f,0.905322f,0.0415123f, -0.446493f,0.894763f,-0.00665318f, -0.517619f,0.855611f,0.00103599f, -0.493254f,0.857934f,0.143698f, -0.391227f,0.901201f,0.186488f, -0.212519f,0.97466f,0.0698119f, -0.0889638f,0.99521f,-0.0405254f, -0.0684633f,0.989971f,-0.123576f, -0.0764325f,0.983592f,-0.163418f, -0.104882f,0.990961f,-0.0836475f, -0.31755f,0.948184f,0.0104726f, -0.297752f,0.954642f,-0.00148102f, -0.157954f,0.986909f,-0.0325777f, -0.331713f,0.943333f,0.00940707f, -0.320973f,0.946975f,0.014661f, -0.220471f,0.961455f,0.164306f, -0.0647366f,0.977455f,0.200976f, --0.0349474f,0.961311f,0.273238f, --0.125874f,0.956852f,0.261896f, -0.0785055f,0.963364f,0.256449f, -0.211427f,0.962249f,0.171395f, -0.267083f,0.952021f,0.149409f, -0.340455f,0.905998f,0.251512f, -0.343062f,0.921876f,0.180149f, -0.420249f,0.886024f,0.195835f, -0.477229f,0.85754f,0.192034f, -0.564804f,0.822942f,0.0613434f, -0.583206f,0.811559f,-0.0352364f, -0.433319f,0.897576f,-0.0811897f, -0.291913f,0.950865f,-0.103166f, -0.268144f,0.961121f,-0.065914f, -0.14681f,0.986926f,-0.0665068f, -0.0393351f,0.975019f,-0.218612f, -0.042722f,0.945279f,-0.323454f, -0.104892f,0.926937f,-0.360257f, -0.188153f,0.928382f,-0.320477f, -0.104479f,0.956869f,-0.271082f, -0.039684f,0.98773f,-0.151046f, -0.0798596f,0.996734f,-0.0120106f, -0.0027229f,0.999081f,-0.0427778f, -0.0156228f,0.999853f,-0.00700924f, -0.224664f,0.97266f,0.058815f, -0.342188f,0.939164f,0.029646f, --0.199093f,0.881081f,0.429019f, --0.240385f,0.861587f,0.447083f, --0.200309f,0.881599f,0.427386f, --0.0492643f,0.888913f,0.455419f, --0.146605f,0.886582f,0.438724f, --0.194932f,0.91844f,0.344193f, --0.212452f,0.949737f,0.229922f, --0.231229f,0.946978f,0.223083f, --0.22018f,0.943947f,0.245937f, --0.155384f,0.954263f,0.255419f, --0.222552f,0.970336f,0.0944332f, -0.0103498f,0.996133f,0.0872447f, -0.133012f,0.991064f,-0.00997971f, -0.0530236f,0.995787f,0.0748093f, -0.0840279f,0.994917f,0.0554967f, -0.25995f,0.964887f,-0.0376792f, -0.277109f,0.958722f,-0.0637373f, -0.172083f,0.982525f,-0.0709421f, -0.0951551f,0.994032f,-0.0533466f, -0.177084f,0.970483f,-0.163718f, -0.336303f,0.91861f,-0.207499f, -0.381503f,0.916211f,-0.122527f, -0.437128f,0.898759f,-0.0339342f, -0.471093f,0.8784f,0.0805223f, -0.407138f,0.905658f,0.118413f, -0.402844f,0.901612f,0.157519f, -0.327464f,0.936685f,0.124046f, -0.19809f,0.980129f,0.0103207f, -0.123868f,0.987803f,-0.0943524f, -0.0527864f,0.989238f,-0.136459f, -0.072462f,0.988213f,-0.134849f, -0.248671f,0.959688f,-0.131005f, -0.280617f,0.958078f,0.0577984f, -0.169552f,0.981657f,0.0871871f, -0.315169f,0.946806f,0.0650122f, -0.205308f,0.973708f,0.0986977f, -0.0950386f,0.972165f,0.214158f, -0.053629f,0.964124f,0.259978f, --0.0859535f,0.951705f,0.294738f, --0.0564482f,0.948883f,0.31054f, -0.154105f,0.958817f,0.238582f, -0.276457f,0.946116f,0.168629f, -0.211552f,0.972531f,0.0971047f, -0.294402f,0.951062f,0.0938527f, -0.390766f,0.916003f,0.0907783f, -0.406836f,0.907458f,0.104904f, -0.487803f,0.868421f,0.0888414f, -0.60401f,0.790886f,0.0983406f, -0.637938f,0.762279f,0.109387f, -0.4874f,0.873178f,0.00117935f, -0.336067f,0.93258f,-0.131735f, -0.229766f,0.943375f,-0.239272f, -0.152224f,0.966237f,-0.207882f, -0.121199f,0.969969f,-0.210883f, -0.121425f,0.965511f,-0.230314f, -0.0800447f,0.963578f,-0.255166f, -0.0996944f,0.981315f,-0.164563f, -0.0506382f,0.996401f,-0.0679735f, --0.049503f,0.998346f,-0.0292297f, -0.050214f,0.998168f,0.0337586f, -0.113307f,0.993459f,0.014176f, --0.000723347f,0.991208f,-0.132313f, -0.134265f,0.980729f,-0.141929f, -0.363008f,0.931437f,-0.0254801f, --0.23486f,0.827656f,0.509732f, --0.18483f,0.851106f,0.491383f, --0.113579f,0.917253f,0.381767f, --0.0885467f,0.926234f,0.366401f, --0.119506f,0.895756f,0.428181f, --0.107176f,0.917761f,0.382398f, --0.0925542f,0.950614f,0.296253f, --0.166069f,0.978511f,0.12222f, --0.250375f,0.968134f,-0.00545859f, --0.116612f,0.99254f,0.0355817f, --0.0441586f,0.99869f,-0.0258397f, -0.0237183f,0.990591f,-0.134786f, -0.114156f,0.992737f,-0.0379611f, -0.0216237f,0.999568f,0.0199155f, -0.13918f,0.98521f,-0.0999564f, -0.240654f,0.960885f,-0.137059f, -0.249305f,0.964708f,-0.0847689f, -0.222546f,0.966381f,-0.128771f, -0.148234f,0.971026f,-0.187443f, -0.258813f,0.946284f,-0.193812f, -0.386195f,0.898799f,-0.207397f, -0.325896f,0.902531f,-0.281478f, -0.250321f,0.93543f,-0.249621f, -0.351402f,0.936022f,0.01949f, -0.42413f,0.889134f,0.171914f, -0.422963f,0.898638f,0.116411f, -0.393976f,0.918547f,0.0324739f, -0.283361f,0.957155f,-0.0596804f, -0.186222f,0.979389f,-0.0782236f, -0.100294f,0.99243f,-0.0708823f, -0.151138f,0.983442f,-0.0999959f, -0.115742f,0.982035f,-0.149033f, -0.0920961f,0.993962f,0.0596489f, -0.180728f,0.97583f,0.122852f, -0.267575f,0.959234f,0.0909572f, -0.204025f,0.959594f,0.193785f, -0.0830398f,0.98516f,0.150214f, -0.000808908f,0.987078f,0.160239f, --0.115905f,0.961815f,0.247948f, --0.0397732f,0.972025f,0.231484f, -0.185186f,0.964166f,0.189976f, -0.333936f,0.928543f,0.162155f, -0.358439f,0.932281f,0.0487095f, -0.30639f,0.946624f,-0.100142f, -0.389119f,0.921183f,-0.00273847f, -0.418957f,0.907889f,-0.0145855f, -0.498018f,0.86538f,-0.05563f, -0.565975f,0.823958f,-0.0276542f, -0.61235f,0.789736f,0.0366549f, -0.580326f,0.809292f,0.0909313f, -0.472624f,0.880866f,0.0264734f, -0.31167f,0.948991f,-0.0477351f, -0.149242f,0.981946f,-0.116226f, -0.114121f,0.974963f,-0.190851f, -0.0836789f,0.981905f,-0.169884f, -0.0779767f,0.990421f,-0.113957f, -0.0144442f,0.982901f,-0.183565f, --0.021091f,0.988398f,-0.150415f, --0.0454971f,0.990828f,-0.127242f, --0.0180398f,0.984723f,-0.173189f, -0.129331f,0.988095f,-0.0833159f, -0.183553f,0.978578f,-0.0932403f, -0.123107f,0.958699f,-0.256402f, -0.189949f,0.953063f,-0.235775f, --0.0544616f,0.84489f,0.53216f, --0.0113297f,0.890886f,0.454085f, --0.0462225f,0.938549f,0.342038f, --0.128436f,0.915911f,0.380277f, --0.159132f,0.90887f,0.385529f, --0.0486608f,0.932565f,0.357708f, -0.0612592f,0.9505f,0.304627f, -0.0533898f,0.988914f,0.138559f, --0.104607f,0.992177f,-0.0681298f, --0.180998f,0.963403f,-0.197725f, -0.0184775f,0.993878f,-0.108929f, --0.0166014f,0.988229f,-0.152078f, --0.0077365f,0.996975f,-0.0773314f, -0.0579939f,0.995726f,-0.071872f, -0.284878f,0.950639f,-0.123003f, -0.233331f,0.946766f,-0.221789f, -0.274724f,0.943287f,-0.186374f, -0.284827f,0.926731f,-0.245036f, -0.143673f,0.947988f,-0.284037f, -0.183874f,0.951741f,-0.245725f, -0.373811f,0.924384f,-0.0760214f, -0.370847f,0.928183f,0.0307872f, -0.230777f,0.972874f,0.0160428f, -0.116854f,0.992434f,-0.0376857f, -0.311514f,0.945104f,0.0986779f, -0.493623f,0.85792f,0.14251f, -0.47336f,0.879733f,0.0447334f, -0.299829f,0.953139f,0.0403417f, -0.142324f,0.985386f,0.0935816f, -0.0780161f,0.991843f,0.100799f, -0.120483f,0.987279f,0.10375f, -0.113666f,0.977351f,0.178507f, -0.020827f,0.987302f,0.157484f, -0.18308f,0.973453f,0.137371f, -0.268344f,0.949436f,0.162981f, -0.178652f,0.97403f,0.139099f, -0.140521f,0.985536f,0.0947243f, --0.0588959f,0.995353f,0.0761881f, --0.17043f,0.974748f,0.144293f, -0.0194468f,0.992819f,0.118038f, -0.23167f,0.972512f,0.0234243f, -0.390625f,0.920274f,-0.0225152f, -0.45457f,0.886543f,-0.086066f, -0.307368f,0.941264f,-0.13981f, -0.289942f,0.953608f,-0.0810322f, -0.455218f,0.890309f,-0.0112281f, -0.513837f,0.856124f,-0.0549855f, -0.546925f,0.836241f,-0.0396788f, -0.583367f,0.812208f,-0.00110721f, -0.552934f,0.832422f,0.0365798f, -0.448406f,0.891004f,0.0710176f, -0.325547f,0.934833f,0.141795f, -0.239603f,0.963586f,0.118709f, -0.230453f,0.97295f,0.0160981f, -0.0486317f,0.9909f,-0.125509f, -0.0743177f,0.991871f,-0.103291f, -0.139517f,0.9837f,-0.11344f, --0.0210587f,0.976395f,-0.214963f, -0.00854959f,0.97326f,-0.229548f, -0.0184659f,0.95097f,-0.308733f, -0.0120962f,0.95636f,-0.291939f, -0.153044f,0.979201f,-0.1332f, -0.190748f,0.981634f,-0.00308124f, -0.151842f,0.988041f,0.0268087f, -0.0319983f,0.964154f,0.263409f, -0.0761375f,0.979983f,0.183946f, --0.0471561f,0.98918f,0.13892f, --0.184804f,0.965808f,0.181831f, --0.118202f,0.977652f,0.173852f, --0.00263192f,0.986244f,0.165277f, -0.113935f,0.977488f,0.177586f, -0.213178f,0.965311f,0.150764f, -0.0917926f,0.995582f,-0.0197448f, --0.112968f,0.973922f,-0.196759f, --0.0750323f,0.977001f,-0.199598f, -0.0257774f,0.985322f,-0.168747f, -0.042721f,0.964979f,-0.258825f, -0.0821835f,0.934135f,-0.34733f, -0.254423f,0.923351f,-0.287563f, -0.255965f,0.951062f,-0.173101f, -0.240055f,0.959513f,-0.147338f, -0.319995f,0.939284f,-0.123892f, -0.15271f,0.974885f,-0.162111f, -0.132954f,0.978157f,-0.159787f, -0.156062f,0.978958f,-0.131476f, -0.237325f,0.969005f,0.0685979f, -0.280555f,0.951122f,0.129056f, -0.254605f,0.966124f,0.0421956f, -0.282663f,0.955227f,-0.087427f, -0.484968f,0.871846f,-0.0684877f, -0.483506f,0.87515f,-0.0182894f, -0.210764f,0.97671f,0.0402119f, -0.0804806f,0.985666f,0.148275f, -0.143859f,0.967897f,0.206108f, -0.0874346f,0.987357f,0.132215f, -0.0878227f,0.985433f,0.145635f, -0.118466f,0.990277f,0.0729134f, -0.170426f,0.983396f,-0.0623508f, -0.249461f,0.967984f,-0.0278496f, -0.240586f,0.970589f,0.00866192f, -0.158755f,0.987312f,0.00339798f, --0.0496588f,0.997869f,0.0423253f, --0.174436f,0.984473f,-0.0196346f, -0.0953847f,0.991998f,-0.0827112f, -0.301757f,0.941321f,-0.151184f, -0.416386f,0.897492f,-0.145363f, -0.439988f,0.889223f,-0.125274f, -0.313047f,0.948071f,-0.0562344f, -0.243151f,0.96888f,-0.0463665f, -0.428373f,0.903467f,-0.0156432f, -0.536849f,0.842847f,-0.0374461f, -0.521753f,0.850621f,-0.0649361f, -0.537565f,0.842885f,-0.02384f, -0.530522f,0.843125f,0.087673f, -0.408082f,0.90082f,0.148295f, -0.350282f,0.920762f,0.171756f, -0.275878f,0.960222f,0.0431791f, -0.279727f,0.959242f,0.0400889f, -0.199403f,0.977085f,0.0744484f, -0.0837631f,0.994427f,-0.0640234f, -0.142714f,0.98022f,-0.137117f, -0.0724844f,0.974795f,-0.211f, -0.0199047f,0.956284f,-0.29176f, -0.0419923f,0.973015f,-0.226887f, --0.0571486f,0.988577f,-0.139464f, --0.0620153f,0.996095f,-0.0628396f, -0.00941635f,0.995205f,0.097359f, -0.0452536f,0.980521f,0.191132f, -0.238692f,0.970551f,0.032497f, -0.18188f,0.979621f,-0.0852148f, --0.0338772f,0.991689f,-0.124115f, --0.215207f,0.972977f,-0.0836781f, --0.127875f,0.990711f,-0.0462653f, --0.0382254f,0.999079f,-0.0194842f, -0.0717625f,0.997386f,-0.00848587f, -0.235337f,0.971913f,0.00129577f, -0.258073f,0.965901f,-0.0208375f, -0.00563659f,0.988134f,-0.153488f, --0.0963466f,0.971245f,-0.217715f, -0.0933449f,0.976181f,-0.19585f, -0.172697f,0.943118f,-0.284084f, -0.114064f,0.91464f,-0.387844f, -0.105309f,0.920749f,-0.375675f, -0.0952503f,0.976152f,-0.195075f, -0.198665f,0.977736f,-0.0675672f, -0.327274f,0.944589f,-0.0253815f, -0.185125f,0.982311f,-0.0281882f, -0.161734f,0.983206f,-0.0845435f, -0.135269f,0.981463f,-0.135765f, -0.160555f,0.98307f,-0.0882893f, -0.258909f,0.96483f,-0.0454967f, -0.342126f,0.938267f,0.0510447f, -0.36458f,0.930989f,-0.0184394f, -0.461971f,0.885156f,-0.0555142f, -0.401049f,0.915892f,-0.0173601f, -0.179695f,0.981649f,0.0638365f, --0.0160491f,0.998918f,0.0436388f, -0.112643f,0.989219f,0.093583f, -0.158223f,0.986353f,0.0455405f, -0.150051f,0.988439f,-0.0217303f, -0.238384f,0.964999f,-0.10932f, -0.283357f,0.938433f,-0.197616f, -0.1814f,0.953903f,-0.239086f, -0.147672f,0.981223f,-0.124073f, -0.0988803f,0.99502f,-0.0125399f, --0.0367309f,0.999167f,-0.0177995f, --0.0641669f,0.988893f,-0.134067f, -0.155868f,0.964972f,-0.211032f, -0.311449f,0.929937f,-0.195488f, -0.363438f,0.913854f,-0.181064f, -0.379108f,0.919625f,-0.102794f, -0.251516f,0.967833f,-0.00624272f, -0.239964f,0.970767f,0.0053561f, -0.444229f,0.895407f,-0.0301255f, -0.561208f,0.823627f,-0.0817525f, -0.529532f,0.843694f,-0.0881851f, -0.463417f,0.885698f,-0.0280076f, -0.42264f,0.895689f,0.138263f, -0.360725f,0.902736f,0.234403f, -0.374064f,0.893088f,0.249939f, -0.398158f,0.891769f,0.214982f, -0.241834f,0.965676f,0.0947983f, -0.124224f,0.988267f,0.0888664f, -0.239364f,0.964398f,0.112437f, -0.252174f,0.966402f,-0.0497516f, -0.205848f,0.974166f,-0.0928869f, -0.0402048f,0.980488f,-0.192421f, --0.109787f,0.981783f,-0.155076f, --0.172809f,0.983136f,-0.0598348f, --0.119927f,0.992756f,0.00723519f, --0.0378691f,0.997707f,0.0560999f, --0.018583f,0.999146f,0.0369096f, -0.311296f,0.946614f,-0.0837655f, -0.23235f,0.967065f,-0.103921f, --0.0472012f,0.997512f,-0.0523709f, --0.280913f,0.95942f,-0.0245033f, --0.168558f,0.985462f,0.0212842f, --0.0297654f,0.999551f,-0.00345095f, -0.14783f,0.984722f,-0.0920209f, -0.234818f,0.942556f,-0.23759f, -0.226f,0.954601f,-0.194065f, -0.0915505f,0.991576f,-0.0916283f, --0.0384295f,0.986109f,-0.161594f, -0.0699749f,0.969463f,-0.235043f, -0.242042f,0.947128f,-0.210628f, -0.200696f,0.954776f,-0.21937f, -0.0684629f,0.960296f,-0.270452f, --0.0178037f,0.955193f,-0.295449f, -0.106419f,0.956511f,-0.271592f, -0.250177f,0.956337f,-0.151101f, -0.206468f,0.977841f,-0.0346042f, -0.226301f,0.972897f,-0.047521f, -0.19172f,0.975927f,-0.103973f, -0.110286f,0.969903f,-0.217085f, -0.124805f,0.979571f,-0.157684f, -0.230362f,0.972377f,0.0376307f, -0.390327f,0.9143f,0.108165f, -0.486088f,0.869528f,0.0874049f, -0.355552f,0.931184f,0.0804947f, -0.162837f,0.968115f,0.190362f, -0.0587916f,0.990094f,0.127507f, -0.122084f,0.99234f,0.0189101f, -0.227899f,0.973107f,0.0335246f, -0.245712f,0.968327f,-0.0443735f, -0.235392f,0.962107f,-0.137626f, -0.299512f,0.953154f,0.0423112f, -0.158421f,0.985528f,0.0603087f, -0.0139537f,0.99778f,0.0651181f, -0.05695f,0.991196f,0.119526f, -0.0853993f,0.993434f,0.0761332f, -0.0800124f,0.992698f,-0.0902652f, -0.152744f,0.965412f,-0.211303f, -0.298303f,0.938225f,-0.175354f, -0.346617f,0.918158f,-0.191946f, -0.306791f,0.939305f,-0.153575f, -0.213668f,0.966817f,-0.140039f, -0.269123f,0.94608f,-0.180294f, -0.462084f,0.866259f,-0.189928f, -0.547323f,0.828917f,-0.11547f, -0.492713f,0.870051f,0.0156307f, -0.377637f,0.925543f,0.0275792f, -0.309374f,0.94993f,0.0438272f, -0.339128f,0.933648f,0.115296f, -0.355844f,0.92275f,0.148012f, -0.387104f,0.898496f,0.207015f, -0.394935f,0.895155f,0.206698f, -0.187014f,0.981688f,0.0362499f, -0.286474f,0.957988f,0.0138101f, -0.315633f,0.944806f,-0.0878444f, -0.189054f,0.976628f,-0.102261f, -0.071001f,0.995263f,-0.066411f, --0.121993f,0.990638f,-0.0612738f, --0.195423f,0.978588f,-0.0646113f, --0.134933f,0.988908f,-0.0620808f, --0.0362027f,0.9885f,-0.146822f, -0.0247852f,0.975168f,-0.220074f, -0.236634f,0.970435f,-0.0475491f, -0.163622f,0.985347f,0.0481553f, --0.110204f,0.98299f,0.146921f, --0.274076f,0.953125f,0.128197f, --0.127913f,0.990913f,0.0415925f, -0.0693505f,0.994264f,-0.081428f, -0.246728f,0.957329f,-0.15049f, -0.356012f,0.927656f,-0.112735f, -0.108926f,0.979602f,-0.168863f, --0.0117435f,0.995074f,-0.0984399f, -0.0591802f,0.992813f,-0.104017f, -0.152983f,0.961405f,-0.228683f, -0.199436f,0.939216f,-0.279462f, -0.158919f,0.956661f,-0.244017f, -0.142246f,0.964436f,-0.222776f, -0.0928224f,0.948092f,-0.304146f, -0.072096f,0.927878f,-0.365849f, -0.0949024f,0.954182f,-0.28378f, -0.0839904f,0.981792f,-0.17038f, -0.207123f,0.975655f,-0.0720922f, -0.306863f,0.948734f,-0.075756f, -0.227677f,0.946857f,-0.22721f, -0.0209281f,0.957849f,-0.28651f, -0.0889558f,0.973432f,-0.210993f, -0.377519f,0.908654f,-0.178401f, -0.444767f,0.867771f,-0.22171f, -0.296477f,0.952876f,-0.0642486f, -0.049587f,0.998699f,0.0118749f, -0.185088f,0.975344f,0.120192f, -0.179316f,0.983776f,0.00553586f, -0.203508f,0.978758f,-0.0248474f, -0.30632f,0.951877f,-0.00993344f, -0.182507f,0.983075f,0.0159703f, -0.0804506f,0.991985f,0.0974322f, -0.170994f,0.963788f,0.204629f, -0.0962731f,0.986887f,0.12956f, -0.097797f,0.995201f,0.00337759f, -0.147003f,0.987459f,-0.0575677f, -0.218112f,0.972969f,-0.0758899f, -0.244949f,0.956598f,-0.157862f, -0.315584f,0.924587f,-0.213415f, -0.352441f,0.893692f,-0.277668f, -0.28482f,0.905458f,-0.31468f, -0.265138f,0.910445f,-0.317477f, -0.308383f,0.884493f,-0.350102f, -0.390084f,0.870652f,-0.299665f, -0.373263f,0.922794f,-0.0955261f, -0.378781f,0.918384f,0.114439f, -0.476669f,0.866105f,0.150494f, -0.353048f,0.93424f,-0.0505168f, -0.309942f,0.946077f,-0.0942048f, -0.298518f,0.948219f,-0.108479f, -0.350416f,0.935917f,-0.0356219f, -0.447907f,0.893892f,-0.0183155f, -0.280155f,0.95286f,-0.116492f, -0.270748f,0.951225f,-0.147871f, -0.374052f,0.922269f,-0.0974917f, -0.176754f,0.980223f,-0.0889943f, -0.0634799f,0.992926f,-0.100339f, --0.11806f,0.977045f,-0.177329f, --0.199746f,0.955239f,-0.218219f, --0.0812223f,0.969857f,-0.229739f, -0.130179f,0.951543f,-0.278602f, -0.200559f,0.919086f,-0.339202f, -0.0174361f,0.999489f,0.0268061f, -0.0105554f,0.991703f,0.128113f, --0.141198f,0.973013f,0.182506f, --0.142313f,0.985833f,0.0887713f, -0.00597934f,0.99465f,-0.103131f, -0.213448f,0.959986f,-0.181295f, -0.150446f,0.953754f,-0.260228f, -0.244008f,0.968351f,-0.0525036f, -0.184758f,0.982743f,0.00893989f, --0.00567918f,0.992902f,-0.118797f, -0.138037f,0.98016f,-0.142241f, -0.21929f,0.962205f,-0.16147f, -0.269703f,0.95408f,-0.13035f, -0.150911f,0.956731f,-0.24878f, -0.180021f,0.944452f,-0.27496f, -0.119147f,0.92214f,-0.368051f, -0.0669033f,0.930661f,-0.359714f, --0.0113587f,0.942765f,-0.333265f, -0.0142182f,0.972628f,-0.231934f, -0.163413f,0.959027f,-0.231437f, -0.324001f,0.919871f,-0.221046f, -0.291919f,0.93701f,-0.19182f, -0.107512f,0.968299f,-0.225473f, -0.0749887f,0.923898f,-0.375218f, -0.415609f,0.849812f,-0.324172f, -0.314994f,0.92041f,-0.231569f, -0.136459f,0.990645f,0.000905767f, -0.00734966f,0.998995f,0.0442195f, -0.0805668f,0.996634f,0.0151596f, -0.266119f,0.962333f,0.0556322f, -0.269187f,0.962624f,-0.0298845f, -0.209195f,0.975524f,-0.0677535f, -0.153299f,0.985902f,0.0670637f, -0.0587395f,0.996349f,0.0619523f, -0.20348f,0.97612f,0.0760684f, -0.225978f,0.971688f,-0.0689656f, -0.204562f,0.957442f,-0.203617f, -0.164418f,0.955123f,-0.246386f, -0.1725f,0.961839f,-0.212392f, -0.288653f,0.947463f,-0.137816f, -0.355829f,0.918236f,-0.173863f, -0.453757f,0.873536f,-0.176182f, -0.355645f,0.881401f,-0.310884f, -0.238917f,0.864251f,-0.442706f, -0.251593f,0.863453f,-0.437206f, -0.231383f,0.92049f,-0.314896f, -0.219172f,0.968344f,-0.119471f, -0.254773f,0.966196f,-0.0394394f, -0.482542f,0.873342f,0.0665443f, -0.470019f,0.880685f,0.0589576f, -0.359563f,0.932576f,-0.0318683f, -0.336062f,0.937393f,-0.0914179f, -0.320744f,0.932455f,-0.166285f, -0.428106f,0.887361f,-0.171217f, -0.372336f,0.918652f,-0.132074f, -0.247289f,0.941171f,-0.230314f, -0.287477f,0.950239f,-0.120008f, -0.121799f,0.989487f,-0.0779795f, -0.132326f,0.991166f,-0.00888466f, --0.00459516f,0.997934f,-0.0640824f, --0.0924696f,0.984613f,-0.148277f, --0.0479758f,0.968834f,-0.243019f, -0.052427f,0.976364f,-0.209677f, -0.223214f,0.97397f,-0.0394671f, -0.0112214f,0.972418f,0.232975f, -0.0106355f,0.967748f,0.251694f, --0.0743183f,0.979789f,0.185717f, -0.0581795f,0.9982f,0.01459f, -0.133434f,0.964693f,-0.227076f, -0.215981f,0.948544f,-0.231554f, -0.137408f,0.968029f,-0.209856f, -0.0442022f,0.987042f,-0.154256f, -0.228305f,0.972284f,0.0504f, -0.121617f,0.992241f,-0.0258404f, -0.134527f,0.985242f,-0.105833f, -0.151618f,0.980953f,-0.121423f, -0.275183f,0.956894f,-0.092891f, -0.263324f,0.945384f,-0.192117f, -0.25647f,0.929449f,-0.26523f, -0.21073f,0.904026f,-0.371926f, -0.0728135f,0.89169f,-0.446751f, --0.0691284f,0.877831f,-0.473955f, --0.019884f,0.913569f,-0.406197f, -0.178205f,0.891525f,-0.416444f, -0.263993f,0.900279f,-0.34613f, -0.210305f,0.939702f,-0.269689f, -0.208408f,0.948624f,-0.238074f, -0.229275f,0.910156f,-0.345036f, -0.227512f,0.924458f,-0.305966f, -0.142229f,0.989234f,0.0344507f, --0.0464441f,0.986357f,0.157934f, -0.073391f,0.981122f,0.178921f, -0.158555f,0.984472f,0.0753311f, -0.265489f,0.961878f,0.0656237f, -0.318063f,0.94383f,0.0895592f, -0.229589f,0.973115f,0.0183382f, -0.0918017f,0.995548f,-0.0213497f, -0.0710209f,0.997458f,0.00582691f, -0.234172f,0.971044f,-0.0473045f, -0.373198f,0.918081f,-0.133603f, -0.27855f,0.93462f,-0.221124f, -0.174681f,0.94082f,-0.290421f, -0.0816739f,0.936818f,-0.34015f, -0.233666f,0.948403f,-0.214319f, -0.373882f,0.91082f,-0.174984f, -0.44036f,0.88198f,-0.16791f, -0.496092f,0.86017f,-0.118324f, -0.420226f,0.875748f,-0.237645f, -0.228936f,0.896528f,-0.379243f, -0.0594423f,0.913794f,-0.401806f, -0.0971839f,0.949435f,-0.298544f, -0.201575f,0.953775f,-0.222894f, -0.339139f,0.935667f,-0.0975326f, -0.471026f,0.864094f,0.177416f, -0.409402f,0.896788f,0.167814f, -0.414181f,0.90532f,0.0940739f, -0.426161f,0.903473f,-0.0460849f, -0.431652f,0.886771f,-0.165266f, -0.36903f,0.909898f,-0.189479f, -0.237762f,0.950577f,-0.199683f, -0.250405f,0.963718f,-0.0924377f, -0.100123f,0.989034f,-0.108572f, -0.0410755f,0.997876f,-0.0505615f, -0.0233843f,0.999496f,0.0214792f, --0.0536722f,0.998467f,-0.0135057f, -0.00107433f,0.999993f,-0.00356525f, --0.0705196f,0.996911f,-0.0345704f, --0.0688919f,0.997514f,0.0148223f, --0.0812179f,0.983535f,0.161436f, --0.0138011f,0.988231f,0.152344f, -0.0655184f,0.995642f,0.0663652f, -0.220598f,0.973784f,-0.0554998f, -0.309629f,0.942731f,-0.124049f, -0.155774f,0.947975f,-0.27763f, -0.127196f,0.974249f,-0.186174f, --0.058769f,0.981296f,-0.183314f, -0.0497615f,0.99612f,-0.0725919f, -0.182926f,0.98205f,0.0460018f, -0.19209f,0.981195f,-0.0189005f, -0.224403f,0.972569f,-0.0612647f, -0.315645f,0.941316f,-0.119552f, -0.360736f,0.920207f,-0.151949f, -0.310465f,0.916626f,-0.251809f, -0.327403f,0.899549f,-0.28917f, -0.161725f,0.896729f,-0.411973f, --0.0141039f,0.865769f,-0.500245f, --0.0292484f,0.82172f,-0.56914f, -0.0961328f,0.815723f,-0.570398f, -0.101793f,0.868026f,-0.485972f, -0.156302f,0.922247f,-0.353597f, -0.205267f,0.935719f,-0.286871f, -0.229076f,0.948515f,-0.218729f, -0.0347356f,0.987904f,-0.151126f, --0.079026f,0.996018f,0.0412683f, --0.00943989f,0.997185f,0.0743796f, -0.111542f,0.993598f,-0.0179121f, -0.186771f,0.982172f,0.0213291f, -0.207496f,0.975443f,0.0738717f, -0.321818f,0.944637f,0.0639911f, -0.281397f,0.958917f,0.0359716f, -0.126766f,0.988281f,0.0850327f, -0.0940702f,0.995531f,0.0082479f, -0.338235f,0.93955f,-0.0533163f, -0.410978f,0.899199f,-0.150126f, -0.338008f,0.912085f,-0.232059f, -0.265939f,0.902685f,-0.338284f, -0.120839f,0.912428f,-0.39099f, -0.0943411f,0.91428f,-0.393944f, -0.326367f,0.911608f,-0.24991f, -0.410002f,0.90171f,-0.137175f, -0.446036f,0.89335f,-0.054576f, -0.453415f,0.890674f,0.0333893f, -0.369882f,0.926554f,0.0684487f, -0.15305f,0.985829f,-0.0686756f, -0.0307343f,0.980172f,-0.195752f, -0.104404f,0.981192f,-0.162361f, -0.153412f,0.984343f,-0.086793f, -0.259868f,0.962798f,0.0740869f, -0.405239f,0.886729f,0.222469f, -0.507863f,0.829218f,0.233395f, -0.530784f,0.842353f,0.0933228f, -0.515092f,0.857118f,0.0053912f, -0.421652f,0.904509f,-0.0638277f, -0.186762f,0.968676f,-0.16367f, -0.141357f,0.986443f,-0.0833539f, -0.10637f,0.994244f,0.0127965f, --0.010764f,0.999348f,-0.0344492f, --0.00443345f,0.999867f,-0.0156939f, --0.0569297f,0.998142f,0.0217125f, --0.0108274f,0.998516f,0.0533776f, --0.0518054f,0.997615f,0.0456197f, --0.08879f,0.991878f,0.0910736f, -0.15627f,0.9777f,0.14029f, -0.127078f,0.991794f,-0.0140045f, -0.182153f,0.975854f,-0.12054f, -0.236919f,0.957374f,-0.165238f, -0.354425f,0.924081f,-0.143031f, -0.22947f,0.95204f,-0.202395f, -0.0414456f,0.986576f,-0.157956f, --0.0334694f,0.988237f,-0.149222f, --0.0516418f,0.976013f,-0.2115f, -0.149794f,0.980531f,-0.126967f, -0.232135f,0.958309f,-0.166606f, -0.253821f,0.951991f,-0.171138f, -0.306434f,0.927336f,-0.214818f, -0.397399f,0.902704f,-0.164923f, -0.371523f,0.904625f,-0.208864f, -0.394746f,0.892045f,-0.220071f, -0.272791f,0.90211f,-0.334339f, -0.143123f,0.890975f,-0.430905f, -0.0302622f,0.843122f,-0.53687f, -0.0628652f,0.888185f,-0.455165f, -0.00848379f,0.914478f,-0.404546f, -0.009201f,0.926788f,-0.375473f, -0.0671766f,0.952807f,-0.296052f, -0.132209f,0.974746f,-0.179973f, --0.0203291f,0.99362f,-0.110936f, --0.138553f,0.985569f,-0.0972441f, -0.0605753f,0.989699f,-0.129717f, -0.0968295f,0.980926f,-0.168548f, -0.0979519f,0.993956f,-0.0495753f, -0.201443f,0.976928f,-0.0709446f, -0.381986f,0.916436f,-0.119294f, -0.157625f,0.97891f,-0.12996f, -0.10065f,0.993729f,0.0486956f, -0.194299f,0.980695f,-0.0220253f, -0.364962f,0.929379f,-0.0552881f, -0.487949f,0.871552f,-0.0479875f, -0.462417f,0.883871f,-0.0702998f, -0.341292f,0.927621f,-0.151788f, -0.13195f,0.962323f,-0.237746f, -0.0784249f,0.961522f,-0.263298f, -0.155522f,0.961843f,-0.225101f, -0.275269f,0.959916f,-0.0528088f, -0.354301f,0.927858f,0.116403f, -0.359914f,0.906647f,0.22012f, -0.307706f,0.904557f,0.295117f, -0.281691f,0.897787f,0.338569f, -0.169122f,0.964903f,0.200898f, -0.116857f,0.992098f,0.045666f, -0.131422f,0.991068f,-0.0226175f, -0.19688f,0.980005f,-0.0287978f, -0.332698f,0.942383f,-0.0350149f, -0.49437f,0.868541f,-0.0351363f, -0.591151f,0.806162f,-0.0253575f, -0.528595f,0.848271f,-0.0319893f, -0.452945f,0.891538f,3.96151e-005f, -0.269718f,0.962267f,0.0359679f, -0.0172075f,0.99965f,0.0201157f, -0.0836306f,0.98488f,0.151715f, -0.0817519f,0.992549f,0.0903531f, --0.0289252f,0.999464f,0.015311f, --0.0977995f,0.99488f,0.0254794f, --0.0368101f,0.998502f,0.0404932f, --0.0917396f,0.988968f,0.116306f, --0.19824f,0.961924f,0.188156f, -0.355147f,0.931267f,-0.0813196f, -0.261709f,0.946669f,-0.187953f, -0.187089f,0.954576f,-0.23191f, -0.281523f,0.925027f,-0.255086f, -0.340665f,0.862289f,-0.374707f, -0.168991f,0.920317f,-0.352786f, --0.0114217f,0.969014f,-0.246743f, -0.0275027f,0.971061f,-0.237244f, -0.0127748f,0.945787f,-0.324537f, -0.106685f,0.927276f,-0.358857f, -0.242554f,0.910981f,-0.333589f, -0.254201f,0.919334f,-0.300346f, -0.319051f,0.907348f,-0.273727f, -0.384836f,0.892504f,-0.235241f, -0.359386f,0.889916f,-0.280877f, -0.418755f,0.87516f,-0.242361f, -0.378513f,0.873068f,-0.307377f, -0.247447f,0.872868f,-0.420561f, -0.0334574f,0.868028f,-0.495387f, --0.104393f,0.897693f,-0.428077f, --0.0466408f,0.949283f,-0.310944f, -0.00907853f,0.960916f,-0.276691f, -0.00868667f,0.966036f,-0.258261f, -0.0845957f,0.976098f,-0.200192f, --0.0296926f,0.969375f,-0.243785f, --0.104852f,0.955765f,-0.274807f, -0.0855702f,0.957819f,-0.274336f, -0.0411396f,0.961225f,-0.272681f, -0.0481708f,0.973933f,-0.221661f, -0.28909f,0.93695f,-0.196346f, -0.356766f,0.919532f,-0.164859f, -0.126757f,0.9882f,-0.0859897f, -0.0144124f,0.990867f,-0.134068f, -0.233251f,0.969449f,-0.075909f, -0.354937f,0.93426f,-0.034317f, -0.469402f,0.882971f,-0.00493066f, -0.398385f,0.917184f,-0.00790304f, -0.386606f,0.918227f,0.0859925f, -0.228789f,0.970147f,0.0804364f, -0.115903f,0.993259f,0.0019484f, -0.110471f,0.992802f,-0.0462595f, -0.159257f,0.98723f,-0.00373461f, -0.193831f,0.979844f,0.0483161f, -0.304703f,0.938233f,0.163935f, -0.27363f,0.944953f,0.179417f, -0.268196f,0.936861f,0.224416f, -0.306571f,0.922686f,0.233806f, -0.304362f,0.944561f,0.123164f, -0.226364f,0.97021f,-0.0863264f, -0.198019f,0.963611f,-0.179562f, -0.39862f,0.902547f,-0.162819f, -0.534677f,0.804719f,-0.257967f, -0.537872f,0.788638f,-0.297899f, -0.486148f,0.837034f,-0.251066f, -0.374822f,0.901369f,-0.216893f, -0.171725f,0.976903f,-0.127168f, --0.0108013f,0.999941f,-0.00151679f, -0.0247265f,0.999687f,-0.00377037f, -0.135958f,0.990654f,0.0109791f, --0.00717425f,0.999252f,0.0379956f, --0.0710711f,0.991911f,0.105175f, --0.0859239f,0.990395f,0.108328f, --0.18335f,0.97033f,0.157612f, --0.315275f,0.941315f,0.120535f, -0.340669f,0.883831f,-0.320605f, -0.289176f,0.886429f,-0.361416f, -0.20883f,0.874721f,-0.437325f, -0.364068f,0.812937f,-0.454519f, -0.367133f,0.769647f,-0.522357f, -0.0748495f,0.818621f,-0.569436f, --0.0872921f,0.835085f,-0.543151f, -0.00846427f,0.872897f,-0.48783f, -0.114223f,0.886407f,-0.448593f, -0.0920189f,0.872463f,-0.479939f, -0.2125f,0.893929f,-0.394633f, -0.175058f,0.869572f,-0.461735f, -0.23988f,0.874417f,-0.421725f, -0.3397f,0.869601f,-0.358326f, -0.392151f,0.874231f,-0.286248f, -0.401032f,0.871377f,-0.282622f, -0.447169f,0.847971f,-0.28458f, -0.337548f,0.868339f,-0.363386f, -0.0674983f,0.896564f,-0.437742f, --0.167145f,0.867884f,-0.467804f, --0.130341f,0.888597f,-0.43978f, --0.0513088f,0.927515f,-0.370248f, --0.0499693f,0.955154f,-0.291861f, -0.0619562f,0.966501f,-0.249073f, -0.104114f,0.952328f,-0.28676f, --0.0782617f,0.904542f,-0.419141f, -0.00654125f,0.918336f,-0.395747f, -0.0825819f,0.944757f,-0.317199f, -0.028702f,0.9283f,-0.370722f, -0.170752f,0.927761f,-0.331819f, -0.188742f,0.965638f,-0.178664f, -0.126613f,0.983535f,0.12895f, -0.0677004f,0.989289f,0.129321f, -0.179931f,0.977134f,0.113286f, -0.301628f,0.94869f,0.0949132f, -0.473083f,0.874439f,0.107469f, -0.430087f,0.900068f,0.0700241f, -0.294529f,0.954232f,0.0519033f, -0.218538f,0.963065f,0.157309f, -0.194139f,0.967934f,0.159416f, -0.193754f,0.980213f,0.0405318f, -0.162395f,0.97825f,-0.129057f, -0.175319f,0.968352f,-0.177646f, -0.248014f,0.960103f,-0.129196f, -0.28568f,0.95369f,-0.0941428f, -0.21993f,0.968315f,-0.118312f, -0.322085f,0.944206f,-0.068818f, -0.382868f,0.918715f,-0.0968289f, -0.390317f,0.908769f,-0.147618f, -0.269935f,0.914207f,-0.30226f, -0.374262f,0.856519f,-0.355391f, -0.561588f,0.771614f,-0.298716f, -0.563679f,0.781086f,-0.268646f, -0.435393f,0.841674f,-0.319402f, -0.305805f,0.901875f,-0.305133f, -0.0714141f,0.973517f,-0.217175f, --0.0655193f,0.984454f,-0.162963f, -0.0352485f,0.985949f,-0.163286f, -0.0657594f,0.9937f,-0.0907542f, --0.080707f,0.996331f,0.0284757f, --0.168129f,0.985261f,0.0315202f, --0.129479f,0.990858f,0.0378905f, --0.12231f,0.991737f,0.0387141f, --0.178343f,0.98279f,-0.0481504f, -0.273318f,0.858026f,-0.434843f, -0.385091f,0.836836f,-0.389114f, -0.340339f,0.786413f,-0.515483f, -0.318221f,0.733035f,-0.601161f, -0.367621f,0.755443f,-0.542366f, -0.119455f,0.799665f,-0.588444f, --0.0802011f,0.78091f,-0.619473f, --0.0688818f,0.778398f,-0.623981f, -0.0140135f,0.818686f,-0.574071f, -0.0274992f,0.866697f,-0.498077f, -0.177071f,0.88196f,-0.436797f, -0.265217f,0.852958f,-0.449581f, -0.257768f,0.854407f,-0.45116f, -0.248846f,0.837431f,-0.486605f, -0.267639f,0.861569f,-0.431356f, -0.378672f,0.856274f,-0.351288f, -0.453357f,0.836299f,-0.308337f, -0.386424f,0.863215f,-0.324865f, -0.128686f,0.904609f,-0.406352f, --0.130252f,0.895612f,-0.425338f, --0.18148f,0.896143f,-0.40496f, --0.161324f,0.928509f,-0.334435f, --0.0897102f,0.95467f,-0.283825f, -0.0454642f,0.942898f,-0.329963f, -0.150896f,0.947175f,-0.283f, -0.0358472f,0.960013f,-0.277651f, --0.0385071f,0.932002f,-0.360402f, -0.0386813f,0.938718f,-0.342507f, -0.0283698f,0.934985f,-0.353551f, -0.108122f,0.956069f,-0.272473f, -0.00374271f,0.987226f,-0.159284f, --0.196358f,0.979545f,-0.0439957f, --0.00408304f,0.984849f,0.173364f, -0.19648f,0.945984f,0.257896f, -0.360526f,0.896905f,0.256092f, -0.497904f,0.850304f,0.170515f, -0.432778f,0.894142f,0.114953f, -0.285493f,0.945844f,0.154508f, -0.185631f,0.971794f,0.145459f, -0.230083f,0.969236f,0.0874248f, -0.368311f,0.929659f,-0.00905859f, -0.334163f,0.916764f,-0.218814f, -0.186339f,0.940464f,-0.284262f, -0.166871f,0.945707f,-0.278912f, -0.282007f,0.937612f,-0.20336f, -0.24104f,0.942322f,-0.232226f, -0.269154f,0.937876f,-0.218962f, -0.376707f,0.923358f,-0.0741695f, -0.419282f,0.907855f,0.00132882f, -0.443207f,0.893334f,-0.0743096f, -0.437794f,0.862232f,-0.254741f, -0.526311f,0.818963f,-0.228685f, -0.539618f,0.818293f,-0.198015f, -0.495179f,0.844909f,-0.202303f, -0.231134f,0.928947f,-0.289195f, --0.0315579f,0.980647f,-0.193222f, --0.0610949f,0.990009f,-0.12708f, --0.0213691f,0.991115f,-0.131279f, --0.0564833f,0.997988f,-0.0288065f, --0.126885f,0.991868f,-0.0099403f, --0.0683923f,0.994887f,-0.0743097f, --0.0443491f,0.981445f,-0.186542f, --0.106156f,0.962217f,-0.250737f, --0.0540242f,0.978674f,-0.198191f, -0.194886f,0.824241f,-0.531645f, -0.320074f,0.809438f,-0.492303f, -0.464438f,0.773143f,-0.431911f, -0.405677f,0.746051f,-0.528047f, -0.305674f,0.751501f,-0.584645f, -0.130892f,0.809782f,-0.571944f, --0.0644176f,0.819769f,-0.56906f, --0.0714323f,0.833301f,-0.548185f, --0.0643631f,0.853923f,-0.516404f, --0.0107306f,0.851684f,-0.523946f, -0.13746f,0.827954f,-0.543688f, -0.198685f,0.868523f,-0.454084f, -0.246871f,0.881894f,-0.401644f, -0.296117f,0.852853f,-0.430066f, -0.256816f,0.850031f,-0.459883f, -0.314177f,0.830121f,-0.460643f, -0.37334f,0.830673f,-0.413038f, -0.413553f,0.857071f,-0.30725f, -0.158679f,0.931259f,-0.327989f, --0.130088f,0.933779f,-0.333368f, --0.259668f,0.892475f,-0.368866f, --0.237565f,0.924215f,-0.298981f, --0.0871208f,0.968004f,-0.235327f, -0.0797031f,0.982117f,-0.17057f, -0.0461708f,0.99392f,-0.0999594f, -0.0445161f,0.998669f,-0.0260401f, -0.0420509f,0.9919f,-0.119856f, -0.0652827f,0.976809f,-0.203917f, -0.0163117f,0.980129f,-0.197692f, --0.0727832f,0.991022f,-0.112154f, --0.0519999f,0.997388f,0.0501216f, --0.215497f,0.976498f,0.00360735f, --0.144793f,0.989191f,0.023161f, -0.11495f,0.986032f,0.120527f, -0.332155f,0.934954f,0.124633f, -0.520936f,0.843883f,0.128405f, -0.426058f,0.883139f,0.196317f, -0.297882f,0.930389f,0.213643f, -0.255462f,0.962333f,0.0930293f, -0.330201f,0.94382f,-0.0130553f, -0.464814f,0.88236f,-0.0734001f, -0.396624f,0.912293f,-0.10203f, -0.190826f,0.974675f,-0.116592f, -0.186045f,0.970537f,-0.153119f, -0.228366f,0.951236f,-0.207361f, -0.252282f,0.958154f,-0.135261f, -0.163352f,0.984522f,-0.0635096f, -0.214627f,0.974395f,0.066997f, -0.385854f,0.917468f,0.096793f, -0.519216f,0.853803f,0.0378886f, -0.535665f,0.843867f,-0.0308472f, -0.541689f,0.838373f,-0.060851f, -0.563197f,0.822059f,-0.0838289f, -0.51966f,0.848391f,-0.100928f, -0.236369f,0.967062f,-0.0944536f, --0.111969f,0.993037f,-0.0366171f, --0.0968965f,0.995233f,-0.011032f, --0.0970566f,0.995182f,0.013894f, --0.0559363f,0.991458f,0.117821f, --0.00538008f,0.999824f,-0.0179674f, -0.0108998f,0.982438f,-0.186268f, -0.0427996f,0.970253f,-0.238279f, --0.10823f,0.95386f,-0.280066f, --0.196538f,0.942983f,-0.26862f, -0.307908f,0.814842f,-0.491147f, -0.299308f,0.78907f,-0.536455f, -0.435133f,0.777699f,-0.453699f, -0.495126f,0.764316f,-0.413124f, -0.362871f,0.81835f,-0.445676f, -0.0803271f,0.871076f,-0.484534f, --0.110099f,0.885293f,-0.451812f, --0.149245f,0.895891f,-0.418456f, --0.0670569f,0.907151f,-0.415428f, -0.0527044f,0.88691f,-0.458926f, -0.100471f,0.888224f,-0.448291f, -0.121208f,0.922825f,-0.365653f, -0.249787f,0.879883f,-0.404243f, -0.334334f,0.839973f,-0.427396f, -0.283757f,0.852792f,-0.438437f, -0.337422f,0.812854f,-0.474778f, -0.291967f,0.807546f,-0.512469f, -0.269633f,0.862064f,-0.429119f, -0.108203f,0.943068f,-0.314506f, --0.121343f,0.966872f,-0.224575f, --0.202731f,0.95836f,-0.201115f, --0.275106f,0.928104f,-0.25088f, --0.220959f,0.943196f,-0.248108f, --0.0845259f,0.990859f,-0.105139f, --0.0183112f,0.999824f,0.00404228f, -0.0398541f,0.999205f,-0.000234289f, -0.144105f,0.989245f,0.0250549f, -0.0887732f,0.994681f,0.052239f, --0.0385311f,0.993554f,0.106613f, --0.141743f,0.984863f,0.099766f, --0.130913f,0.987043f,0.0927824f, --0.138468f,0.982136f,0.12742f, --0.181593f,0.983362f,-0.00473479f, -0.124018f,0.991703f,-0.0338209f, -0.350394f,0.929846f,-0.112294f, -0.471172f,0.881999f,-0.00866642f, -0.362692f,0.927143f,0.0941279f, -0.321547f,0.934446f,0.153031f, -0.39706f,0.903274f,0.162601f, -0.408629f,0.910814f,0.0586596f, -0.440544f,0.897708f,-0.00641084f, -0.417743f,0.90832f,0.0210971f, -0.223429f,0.972702f,-0.0626924f, -0.239878f,0.966667f,-0.0895152f, -0.326998f,0.934073f,-0.143454f, -0.0984577f,0.955256f,-0.278913f, -0.055814f,0.995135f,-0.081185f, -0.198837f,0.979583f,-0.0296926f, -0.452343f,0.887429f,-0.0886289f, -0.538988f,0.831253f,-0.136052f, -0.534759f,0.840783f,-0.084361f, -0.557911f,0.827063f,-0.0685738f, -0.570718f,0.812258f,-0.120488f, -0.469437f,0.877038f,-0.102147f, -0.179725f,0.982175f,0.0550563f, --0.143773f,0.988083f,0.054972f, --0.0900032f,0.995941f,-0.00107895f, --0.112639f,0.992937f,-0.0372634f, --0.0770822f,0.995012f,-0.0633234f, -0.131283f,0.990073f,-0.0501953f, -0.151552f,0.985928f,-0.0705498f, -0.0547644f,0.990744f,-0.124209f, --0.0889999f,0.992043f,-0.0890439f, --0.225525f,0.966809f,-0.120075f, -0.367815f,0.812209f,-0.4528f, -0.333749f,0.806687f,-0.487716f, -0.350467f,0.776679f,-0.523395f, -0.428661f,0.776887f,-0.461189f, -0.344028f,0.851962f,-0.394722f, -0.0917588f,0.929121f,-0.35821f, --0.151193f,0.922445f,-0.355297f, --0.135334f,0.926245f,-0.351788f, --0.0236046f,0.919658f,-0.39201f, -0.0475929f,0.924342f,-0.378586f, -0.0534474f,0.931533f,-0.359707f, -0.122967f,0.908442f,-0.399514f, -0.333531f,0.836829f,-0.434137f, -0.345062f,0.821786f,-0.45343f, -0.298405f,0.81077f,-0.503594f, -0.369796f,0.765054f,-0.527202f, -0.289381f,0.806079f,-0.516232f, -0.106326f,0.866117f,-0.488402f, --0.0247184f,0.959589f,-0.280318f, --0.247885f,0.952117f,-0.178958f, --0.233969f,0.968302f,-0.0874651f, --0.230973f,0.963517f,-0.135224f, --0.23946f,0.950685f,-0.197121f, --0.148981f,0.968772f,-0.198205f, --0.0244446f,0.976892f,-0.212332f, -0.0214143f,0.979888f,-0.198397f, -0.0179015f,0.996249f,-0.084666f, --0.0584671f,0.995927f,0.0686411f, --0.0472317f,0.986168f,0.158874f, --0.0434315f,0.994906f,0.0909663f, --0.106857f,0.994237f,0.00858694f, --0.103595f,0.993848f,-0.0391609f, --0.0110181f,0.988269f,-0.152323f, -0.194953f,0.947451f,-0.253632f, -0.318956f,0.92262f,-0.216885f, -0.355303f,0.928796f,-0.105349f, -0.319482f,0.947371f,-0.0204796f, -0.274811f,0.961125f,0.0267891f, -0.33758f,0.938163f,0.0767414f, -0.445225f,0.885597f,0.132261f, -0.483843f,0.868855f,0.104815f, -0.473616f,0.877987f,0.069475f, -0.358094f,0.929841f,-0.0846442f, -0.209896f,0.940516f,-0.267156f, -0.398687f,0.89746f,-0.188715f, -0.164362f,0.933368f,-0.319075f, --0.0806345f,0.937721f,-0.337901f, -0.19678f,0.945117f,-0.26083f, -0.467829f,0.857531f,-0.213953f, -0.522616f,0.828828f,-0.199792f, -0.48751f,0.848849f,-0.204424f, -0.559553f,0.806974f,-0.18893f, -0.585339f,0.775984f,-0.235006f, -0.309037f,0.923705f,-0.22642f, -0.0763335f,0.997082f,0.00115348f, --0.0450053f,0.998556f,0.0293498f, --0.0333568f,0.997154f,-0.0676115f, --0.00964185f,0.995848f,-0.0905243f, -0.000956175f,0.96601f,-0.258503f, -0.00169255f,0.940578f,-0.339574f, -0.0710047f,0.988076f,-0.136617f, -0.0666563f,0.995318f,-0.0699874f, --0.123764f,0.98454f,-0.123946f, --0.163961f,0.983022f,-0.0823738f, -0.335205f,0.824436f,-0.456008f, -0.40434f,0.809075f,-0.426506f, -0.410475f,0.791681f,-0.452494f, -0.374361f,0.829194f,-0.41508f, -0.245781f,0.909811f,-0.33442f, -0.0263815f,0.954919f,-0.295693f, --0.125325f,0.941665f,-0.312348f, --0.129375f,0.929134f,-0.346369f, --0.0304152f,0.953686f,-0.299263f, --0.0235504f,0.953092f,-0.301762f, -0.153775f,0.94901f,-0.275197f, -0.274986f,0.871191f,-0.406705f, -0.301999f,0.805469f,-0.509919f, -0.376419f,0.798039f,-0.470576f, -0.361388f,0.809968f,-0.461899f, -0.38255f,0.848875f,-0.364783f, -0.240129f,0.889938f,-0.387747f, --0.0576931f,0.937865f,-0.342172f, --0.263371f,0.95113f,-0.161204f, --0.310954f,0.950327f,-0.0136276f, --0.223147f,0.974756f,-0.00746382f, --0.15809f,0.984734f,-0.0728478f, --0.146587f,0.977645f,-0.150739f, --0.120405f,0.952352f,-0.280228f, -0.00186508f,0.961595f,-0.274467f, --0.0732237f,0.95724f,-0.279876f, --0.12777f,0.973556f,-0.189377f, --0.137722f,0.985013f,-0.103834f, --0.0840689f,0.995964f,-0.0314252f, -0.00572333f,0.997438f,0.0713008f, --0.0203309f,0.999218f,0.033924f, -0.0131655f,0.994107f,-0.107599f, -0.106442f,0.965608f,-0.237214f, -0.156613f,0.948157f,-0.276534f, -0.221784f,0.959186f,-0.175425f, -0.297839f,0.94933f,-0.100322f, -0.237415f,0.96993f,-0.0535752f, -0.206724f,0.977649f,0.0383141f, -0.342833f,0.933108f,0.108513f, -0.413098f,0.906827f,0.0837554f, -0.485601f,0.86482f,0.127586f, -0.517433f,0.850444f,0.0949105f, -0.521609f,0.853001f,-0.0177076f, -0.35462f,0.907818f,-0.223854f, -0.320255f,0.896065f,-0.307417f, -0.254422f,0.945666f,-0.202447f, --0.0420832f,0.95285f,-0.300511f, -0.132146f,0.911038f,-0.390572f, -0.397135f,0.84337f,-0.361954f, -0.530962f,0.805014f,-0.264634f, -0.518015f,0.788476f,-0.331612f, -0.536794f,0.726368f,-0.429234f, -0.499189f,0.748129f,-0.437165f, -0.193048f,0.933972f,-0.300713f, --0.0642143f,0.969885f,-0.234947f, --0.0349143f,0.97216f,-0.231701f, --0.020308f,0.973327f,-0.22852f, -0.0335645f,0.983758f,-0.176336f, -0.162495f,0.963807f,-0.211356f, -0.0549435f,0.960153f,-0.274021f, --0.150243f,0.943756f,-0.294538f, -0.093877f,0.988384f,-0.119518f, --0.0288967f,0.977445f,-0.209205f, --0.228292f,0.925763f,-0.301406f, -0.329933f,0.832357f,-0.445339f, -0.354113f,0.855807f,-0.377092f, -0.402588f,0.885182f,-0.233185f, -0.310305f,0.922327f,-0.23027f, -0.169674f,0.966179f,-0.194188f, -0.0510686f,0.987038f,-0.152145f, --0.0638218f,0.978386f,-0.196689f, --0.116946f,0.960297f,-0.253286f, --0.0788814f,0.945056f,-0.317249f, -0.0429532f,0.937478f,-0.345383f, -0.160798f,0.890341f,-0.425953f, -0.370061f,0.833359f,-0.410569f, -0.405144f,0.796477f,-0.448867f, -0.330775f,0.831238f,-0.446802f, -0.214187f,0.914592f,-0.342995f, -0.302956f,0.933789f,-0.190409f, -0.260411f,0.956162f,-0.13394f, --0.0987797f,0.989363f,-0.106786f, --0.381946f,0.915584f,-0.125788f, --0.356892f,0.930397f,-0.0835967f, --0.219462f,0.974624f,-0.0441002f, --0.0826206f,0.996346f,-0.0216629f, --0.0522166f,0.993096f,-0.10504f, --0.0544454f,0.992373f,-0.110596f, --0.0392289f,0.996233f,-0.0773398f, --0.0738534f,0.995703f,-0.0558676f, --0.126249f,0.987782f,-0.0913672f, --0.191576f,0.965578f,-0.17595f, --0.204819f,0.971278f,-0.121116f, --0.121301f,0.991656f,-0.0436452f, -0.0591737f,0.997785f,0.0303762f, -0.146031f,0.988908f,-0.0271181f, -0.164489f,0.985353f,-0.0449734f, -0.1732f,0.984753f,-0.0162076f, -0.192999f,0.97944f,-0.0587201f, -0.224284f,0.970976f,-0.0830781f, -0.215597f,0.976395f,0.0130766f, -0.11857f,0.99294f,-0.00337615f, -0.283009f,0.956652f,0.0687283f, -0.418445f,0.903636f,0.0913547f, -0.498249f,0.865176f,0.0567366f, -0.572218f,0.818628f,-0.0491444f, -0.584595f,0.798602f,-0.143119f, -0.499999f,0.838004f,-0.218521f, -0.312173f,0.860973f,-0.401589f, -0.169015f,0.918853f,-0.356571f, -0.0805256f,0.94115f,-0.328258f, -0.268694f,0.864193f,-0.42541f, -0.373719f,0.773399f,-0.512044f, -0.442856f,0.749728f,-0.491717f, -0.564815f,0.671761f,-0.479293f, -0.549235f,0.627986f,-0.551338f, -0.305274f,0.788247f,-0.534298f, -0.0146963f,0.910216f,-0.413874f, --0.0347141f,0.920746f,-0.388614f, --0.0142092f,0.918584f,-0.394971f, --0.0593092f,0.944757f,-0.32236f, --0.0129026f,0.951456f,-0.307515f, -0.101136f,0.954598f,-0.280203f, -0.103786f,0.979836f,-0.170731f, --0.130724f,0.946294f,-0.2957f, --0.0475497f,0.951312f,-0.30454f, -0.068843f,0.980898f,-0.181933f, --0.0601749f,0.975587f,-0.21121f, -0.164088f,0.946673f,-0.277283f, -0.219167f,0.958752f,-0.180996f, -0.292116f,0.952214f,-0.0892046f, -0.382294f,0.923975f,-0.0110254f, -0.185963f,0.972429f,-0.140709f, -0.0282036f,0.98507f,-0.16983f, --0.0260978f,0.984942f,-0.170904f, -0.00347731f,0.966818f,-0.255444f, -0.046523f,0.915606f,-0.399376f, -0.121249f,0.881024f,-0.457269f, -0.234655f,0.843553f,-0.483069f, -0.349259f,0.806387f,-0.47724f, -0.352024f,0.817545f,-0.455741f, -0.21f,0.895765f,-0.391796f, -0.123731f,0.946466f,-0.298149f, -0.189246f,0.953263f,-0.235533f, -0.21574f,0.971887f,-0.0943018f, --0.0878709f,0.988681f,-0.12161f, --0.31365f,0.930831f,-0.187554f, --0.370884f,0.90378f,-0.213602f, --0.292833f,0.938489f,-0.182993f, --0.076513f,0.991298f,-0.107116f, --0.0492348f,0.994225f,-0.0953508f, --0.128831f,0.991129f,-0.0326479f, --0.117178f,0.99304f,0.0118732f, --0.0834857f,0.989043f,0.12175f, --0.0124631f,0.991817f,0.127061f, --0.133134f,0.991073f,-0.00703918f, --0.190067f,0.981738f,-0.00811131f, --0.0950662f,0.989352f,-0.110206f, -0.0262188f,0.977376f,-0.209877f, -0.0774906f,0.981033f,-0.177679f, -0.0911686f,0.995787f,-0.00982619f, -0.177517f,0.984043f,0.0121696f, -0.260966f,0.962001f,-0.0803208f, -0.219093f,0.96759f,-0.12557f, -0.15488f,0.986019f,-0.06147f, -0.155325f,0.987507f,-0.0265508f, -0.257438f,0.9633f,-0.0760109f, -0.429699f,0.898131f,-0.0933795f, -0.553938f,0.821258f,-0.136702f, -0.635333f,0.740056f,-0.220611f, -0.590775f,0.752696f,-0.290577f, -0.544721f,0.782975f,-0.300381f, -0.386007f,0.854199f,-0.348343f, -0.159868f,0.903698f,-0.397205f, -0.111475f,0.854344f,-0.507613f, -0.32886f,0.783243f,-0.527619f, -0.428722f,0.729381f,-0.533105f, -0.463071f,0.680849f,-0.567459f, -0.578683f,0.643078f,-0.501575f, -0.498776f,0.750313f,-0.433881f, -0.172367f,0.935224f,-0.309265f, --0.0549105f,0.957697f,-0.282492f, --0.000989137f,0.955961f,-0.293491f, --0.105185f,0.947134f,-0.303107f, --0.108598f,0.951252f,-0.288662f, --0.0192021f,0.937992f,-0.346125f, -0.0434621f,0.947915f,-0.315545f, -0.0658084f,0.965866f,-0.250542f, -0.00168367f,0.969468f,-0.245211f, --0.0752902f,0.953259f,-0.292624f, --0.0406571f,0.962797f,-0.267151f, --0.0486067f,0.969651f,-0.239615f, -0.0419974f,0.993223f,-0.108371f, -0.194169f,0.980548f,-0.0286949f, -0.261981f,0.963651f,-0.0523696f, -0.349136f,0.937066f,-0.00343362f, -0.31121f,0.950026f,0.0244779f, -0.0510089f,0.992585f,-0.110335f, -0.0314098f,0.989653f,-0.140003f, -0.185979f,0.958236f,-0.217244f, -0.136104f,0.898638f,-0.417044f, -0.108771f,0.892335f,-0.438072f, -0.238757f,0.906785f,-0.34747f, -0.373646f,0.87379f,-0.311256f, -0.340425f,0.883999f,-0.320402f, -0.14853f,0.93597f,-0.319217f, -0.0564088f,0.968057f,-0.244304f, -0.0971116f,0.979187f,-0.17822f, -0.12449f,0.986246f,-0.108724f, -0.00791995f,0.999591f,-0.0274806f, --0.236925f,0.964883f,-0.113439f, --0.404549f,0.891486f,-0.203944f, --0.302952f,0.940514f,-0.153798f, --0.187243f,0.970939f,-0.149055f, --0.103813f,0.994585f,-0.00480558f, --0.136945f,0.990579f,0.00047278f, --0.192386f,0.981319f,0.000301484f, --0.157118f,0.980577f,0.117404f, --0.0205849f,0.995936f,0.0876826f, --0.0389376f,0.992928f,0.112147f, --0.205589f,0.977918f,0.0375515f, -0.0799477f,0.995293f,0.0547661f, -0.128711f,0.981689f,-0.140426f, --0.00377139f,0.985264f,-0.170999f, --0.0186288f,0.990563f,-0.135788f, -0.247861f,0.95847f,-0.141069f, -0.335397f,0.913398f,-0.230679f, -0.164127f,0.956335f,-0.241837f, -0.0560549f,0.992155f,-0.111746f, -0.165621f,0.985752f,-0.0293729f, -0.329655f,0.93718f,-0.114108f, -0.47188f,0.859421f,-0.196784f, -0.593068f,0.774119f,-0.22138f, -0.65363f,0.716422f,-0.24394f, -0.606788f,0.760352f,-0.231675f, -0.536399f,0.810894f,-0.23394f, -0.343135f,0.901586f,-0.263439f, -0.295862f,0.930397f,-0.216396f, -0.307346f,0.85762f,-0.412342f, -0.36437f,0.770675f,-0.522776f, -0.48977f,0.726784f,-0.481571f, -0.467664f,0.727396f,-0.50218f, -0.516451f,0.759976f,-0.394608f, -0.369408f,0.883578f,-0.287798f, -0.11272f,0.986131f,-0.121821f, --0.0556185f,0.985996f,-0.157218f, --0.0141506f,0.99059f,-0.13613f, --0.0462718f,0.993931f,-0.099801f, --0.0190733f,0.9801f,-0.197584f, -0.0617351f,0.955747f,-0.287639f, --0.00791345f,0.937814f,-0.347049f, -0.0263533f,0.943249f,-0.331038f, --0.0408223f,0.937006f,-0.34692f, --0.0840519f,0.9495f,-0.302299f, --0.0536227f,0.964498f,-0.25859f, --0.0366453f,0.973297f,-0.226607f, -0.0559372f,0.997556f,-0.0418806f, -0.117658f,0.99199f,-0.0459629f, -0.260816f,0.963552f,0.059517f, -0.265721f,0.95723f,0.114473f, -0.305022f,0.92568f,0.223781f, -0.229311f,0.961539f,0.151192f, -0.0614828f,0.993074f,-0.10012f, -0.279787f,0.947394f,-0.15545f, -0.307005f,0.902601f,-0.301762f, -0.0599313f,0.924785f,-0.375741f, -0.138459f,0.941623f,-0.306881f, -0.380474f,0.890209f,-0.250536f, -0.362157f,0.883362f,-0.297512f, -0.118666f,0.951617f,-0.283449f, --0.0864913f,0.973386f,-0.212226f, -0.0535968f,0.99807f,-0.0313783f, -0.0571748f,0.998014f,0.026449f, --0.0576417f,0.995225f,0.0787756f, --0.164671f,0.983729f,0.0718444f, --0.317398f,0.947117f,0.0472105f, --0.350813f,0.936189f,-0.0219157f, --0.249283f,0.968275f,0.0173648f, --0.166219f,0.983818f,0.0668861f, --0.137263f,0.989074f,0.0537794f, --0.237615f,0.966132f,0.100634f, --0.156805f,0.98112f,0.113207f, -0.0155394f,0.999476f,0.0283817f, --0.0358194f,0.998926f,0.0293752f, --0.187269f,0.982125f,-0.01898f, -0.0856923f,0.996255f,0.0114998f, -0.21812f,0.975918f,0.00295422f, -0.0575266f,0.997525f,-0.0404377f, -0.0557844f,0.976324f,-0.208997f, -0.282723f,0.906166f,-0.314533f, -0.34017f,0.885713f,-0.315906f, -0.0703654f,0.964786f,-0.253451f, --0.0857039f,0.987005f,-0.135924f, -0.161068f,0.982423f,-0.0943491f, -0.439921f,0.879468f,-0.181673f, -0.499341f,0.805071f,-0.320185f, -0.581376f,0.752639f,-0.309089f, -0.634744f,0.735927f,-0.235609f, -0.590228f,0.797974f,-0.121932f, -0.552123f,0.824777f,-0.122079f, -0.403254f,0.893687f,-0.196749f, -0.282279f,0.904426f,-0.319896f, -0.487441f,0.821419f,-0.296095f, -0.471414f,0.771013f,-0.428146f, -0.452383f,0.750947f,-0.48107f, -0.453351f,0.789814f,-0.413117f, -0.426317f,0.829282f,-0.361311f, -0.274227f,0.935292f,-0.223671f, -0.0409647f,0.985686f,-0.16354f, -0.00611451f,0.980211f,-0.19786f, --0.0818346f,0.965065f,-0.248905f, --0.0402149f,0.984168f,-0.172615f, -0.0358772f,0.970818f,-0.237119f, -0.140843f,0.951316f,-0.274156f, -0.0386407f,0.935491f,-0.351232f, -0.02521f,0.945244f,-0.325388f, --0.00704123f,0.966541f,-0.256414f, --0.132543f,0.963814f,-0.231288f, --0.120001f,0.972985f,-0.197233f, --0.125856f,0.970406f,-0.20609f, -0.150068f,0.984139f,0.0946078f, -0.0962514f,0.994035f,0.0512922f, -0.139768f,0.98134f,0.132051f, -0.167943f,0.959948f,0.224265f, -0.248876f,0.931236f,0.266197f, -0.347088f,0.901338f,0.259075f, -0.298327f,0.935934f,0.187161f, -0.410224f,0.911771f,0.0197232f, -0.382392f,0.916875f,-0.11453f, -0.0687189f,0.981224f,-0.180215f, -0.109108f,0.978331f,-0.175964f, -0.423091f,0.889035f,-0.17496f, -0.308023f,0.9305f,-0.198221f, -0.0610242f,0.996399f,-0.0588678f, --0.139679f,0.983461f,-0.1153f, --0.178862f,0.976278f,-0.122024f, --0.0279755f,0.98865f,0.147609f, -0.0175582f,0.984678f,0.173494f, --0.182965f,0.982824f,0.0240987f, --0.334982f,0.934918f,0.117109f, --0.346361f,0.929574f,0.126201f, --0.256073f,0.950373f,0.176686f, --0.14622f,0.975847f,0.162306f, --0.145894f,0.982033f,0.119692f, --0.243091f,0.96438f,0.104295f, --0.119399f,0.991881f,0.0437603f, -0.0792305f,0.996134f,0.0379462f, --0.0234512f,0.999544f,0.0190445f, --0.148416f,0.988869f,0.0105176f, -0.0279419f,0.999576f,0.00824062f, -0.239276f,0.970159f,0.0392311f, -0.182184f,0.979477f,-0.086222f, -0.251919f,0.933495f,-0.255194f, -0.359782f,0.855042f,-0.373444f, -0.260041f,0.87469f,-0.409017f, --0.0332083f,0.931159f,-0.363099f, --0.108678f,0.933514f,-0.341673f, -0.191287f,0.909011f,-0.370282f, -0.516055f,0.783319f,-0.346553f, -0.557568f,0.726461f,-0.401711f, -0.511814f,0.738467f,-0.438991f, -0.509794f,0.789775f,-0.341125f, -0.522098f,0.819729f,-0.235496f, -0.54438f,0.815602f,-0.196071f, -0.540927f,0.823066f,-0.173089f, -0.36892f,0.838043f,-0.401972f, -0.461826f,0.790802f,-0.401684f, -0.549439f,0.728653f,-0.408878f, -0.455853f,0.753497f,-0.473751f, -0.389397f,0.799772f,-0.456875f, -0.293181f,0.868874f,-0.398878f, -0.155589f,0.965139f,-0.210473f, -0.031565f,0.984349f,-0.173382f, -0.0970165f,0.970686f,-0.219901f, --0.0352366f,0.943342f,-0.329946f, --0.0636858f,0.931929f,-0.357006f, -0.111555f,0.924517f,-0.364451f, -0.180963f,0.908751f,-0.376064f, -0.0582409f,0.924666f,-0.376299f, --0.091325f,0.934476f,-0.344113f, --0.148498f,0.963415f,-0.223113f, --0.170646f,0.976481f,-0.131776f, --0.0961794f,0.980781f,-0.169761f, --0.06221f,0.973089f,-0.221874f, -0.206636f,0.934831f,0.288777f, -0.0869406f,0.963592f,0.252847f, -0.0799701f,0.959241f,0.271038f, -0.160525f,0.963414f,0.21463f, -0.255681f,0.955661f,0.146082f, -0.323027f,0.93103f,0.169812f, -0.330118f,0.920313f,0.209873f, -0.447578f,0.884885f,0.12904f, -0.467368f,0.874534f,0.129448f, -0.130174f,0.988207f,0.0806387f, -0.145402f,0.989036f,-0.0258009f, -0.425216f,0.898822f,-0.106345f, -0.205136f,0.977985f,-0.0382811f, --0.0258123f,0.995757f,0.0883314f, --0.00518813f,0.996132f,0.0877124f, --0.192412f,0.980974f,0.0258233f, --0.196114f,0.979963f,0.0348015f, -0.0217983f,0.995754f,0.0894399f, --0.10216f,0.980256f,0.169296f, --0.384424f,0.908881f,0.161723f, --0.367551f,0.91996f,0.136309f, --0.285788f,0.948719f,0.135118f, --0.171256f,0.972185f,0.159771f, --0.0605854f,0.969905f,0.235826f, --0.167372f,0.981266f,0.0954134f, --0.0977838f,0.994994f,0.0206294f, -0.0451608f,0.997867f,0.0471292f, --0.0136124f,0.997411f,0.0706177f, --0.158818f,0.986831f,0.0306748f, -0.0267005f,0.99957f,0.0121357f, -0.289361f,0.957076f,-0.0166175f, -0.336393f,0.939976f,-0.0573177f, -0.390118f,0.913466f,-0.115702f, -0.445853f,0.875576f,-0.185959f, -0.293335f,0.914816f,-0.277609f, --0.00739937f,0.915657f,-0.401893f, -0.00533725f,0.872492f,-0.488599f, -0.197734f,0.788261f,-0.582705f, -0.43334f,0.722538f,-0.53866f, -0.548408f,0.706281f,-0.447678f, -0.484095f,0.751007f,-0.449045f, -0.458828f,0.77804f,-0.429103f, -0.441245f,0.787203f,-0.430829f, -0.474553f,0.805707f,-0.354451f, -0.550933f,0.789486f,-0.270526f, -0.502032f,0.792798f,-0.345594f, -0.478273f,0.764634f,-0.43196f, -0.556872f,0.730832f,-0.394687f, -0.471855f,0.788619f,-0.394251f, -0.354943f,0.841801f,-0.406677f, -0.154029f,0.899791f,-0.40823f, -0.0155123f,0.938951f,-0.343701f, -0.0497714f,0.948037f,-0.314243f, -0.154285f,0.935402f,-0.31815f, -0.101927f,0.920411f,-0.377432f, --0.0203862f,0.864666f,-0.501933f, -0.070179f,0.866621f,-0.494007f, -0.100294f,0.910674f,-0.400766f, -0.000402101f,0.968295f,-0.249809f, --0.128961f,0.971456f,-0.199105f, --0.199723f,0.946207f,-0.254564f, --0.134113f,0.940975f,-0.310772f, --0.0316747f,0.927512f,-0.372449f, -0.0302907f,0.938917f,-0.342807f, -0.218976f,0.899032f,0.379198f, -0.139079f,0.919337f,0.368072f, -0.135024f,0.957047f,0.256573f, -0.313512f,0.936875f,0.154838f, -0.29644f,0.95504f,0.00476296f, -0.279277f,0.959996f,0.0202722f, -0.3625f,0.931007f,0.0426625f, -0.472022f,0.881367f,0.0196857f, -0.429567f,0.887347f,0.167594f, -0.224991f,0.963227f,0.146879f, -0.296133f,0.954919f,-0.0208476f, -0.415966f,0.902166f,-0.114319f, -0.183129f,0.982743f,0.0260829f, --0.0925135f,0.995706f,-0.00325499f, --0.0437431f,0.995986f,0.0780946f, --0.179713f,0.977607f,0.109486f, --0.141385f,0.986823f,0.0786845f, --0.085949f,0.993479f,0.0749198f, --0.233157f,0.944593f,0.231044f, --0.345216f,0.897121f,0.275681f, --0.266518f,0.944857f,0.190296f, --0.236509f,0.971079f,0.032684f, --0.255527f,0.96653f,-0.0229239f, --0.0941044f,0.991025f,0.0949427f, --0.0715158f,0.990946f,0.113625f, --0.0636481f,0.988651f,0.136079f, -0.0130078f,0.992968f,0.11767f, -0.0194535f,0.99321f,0.114698f, --0.0733749f,0.997304f,0.000320173f, -0.0745089f,0.991949f,-0.102398f, -0.316045f,0.940065f,-0.128038f, -0.302503f,0.936628f,-0.176692f, -0.365578f,0.917629f,-0.155918f, -0.474055f,0.875706f,-0.091714f, -0.462666f,0.882661f,-0.0827679f, -0.197672f,0.918824f,-0.341598f, -0.1211f,0.851979f,-0.509379f, -0.340562f,0.776445f,-0.530237f, -0.411588f,0.704014f,-0.578756f, -0.454493f,0.713166f,-0.533695f, -0.463114f,0.742631f,-0.483761f, -0.44079f,0.754688f,-0.485953f, -0.400302f,0.772025f,-0.493696f, -0.38659f,0.783016f,-0.487272f, -0.457033f,0.766931f,-0.450487f, -0.547084f,0.759757f,-0.351382f, -0.508566f,0.782012f,-0.360303f, -0.54699f,0.792915f,-0.268492f, -0.489855f,0.837224f,-0.243102f, -0.350988f,0.891534f,-0.286312f, -0.195385f,0.947495f,-0.253137f, -0.0709694f,0.939176f,-0.336023f, -0.0288377f,0.903143f,-0.42837f, -0.128806f,0.91498f,-0.382389f, -0.209123f,0.895775f,-0.392243f, -0.0981301f,0.852621f,-0.513233f, --0.0414306f,0.841347f,-0.538906f, --0.0951984f,0.922571f,-0.373899f, --0.157973f,0.963972f,-0.214014f, --0.107909f,0.978829f,-0.173926f, --0.0713291f,0.969594f,-0.234092f, -0.0141898f,0.950434f,-0.310602f, --0.0202439f,0.895649f,-0.4443f, --0.114151f,0.867225f,-0.484655f, -0.0955354f,0.969912f,0.223927f, -0.218114f,0.913651f,0.343028f, -0.223104f,0.958808f,0.175816f, -0.39761f,0.915149f,0.0663907f, -0.332649f,0.940641f,-0.0673772f, -0.280455f,0.956871f,-0.0757854f, -0.359446f,0.926985f,-0.107225f, -0.369482f,0.924827f,-0.0904272f, -0.410746f,0.887001f,0.210991f, -0.335823f,0.922126f,0.192112f, -0.395669f,0.917218f,-0.0464346f, -0.353697f,0.926083f,-0.131407f, -0.179534f,0.981887f,0.0605388f, --0.13479f,0.99057f,-0.0245515f, --0.0725996f,0.990136f,0.119831f, --0.160567f,0.981095f,0.108036f, --0.173547f,0.983858f,0.0436428f, --0.151709f,0.976244f,0.154697f, --0.302597f,0.914896f,0.267208f, --0.328732f,0.906446f,0.265123f, --0.132663f,0.960039f,0.246424f, --0.138673f,0.989957f,0.0274833f, --0.234284f,0.968151f,-0.0882923f, --0.176173f,0.979923f,-0.0933525f, --0.138089f,0.990412f,-0.00402308f, --0.0957719f,0.981754f,0.164279f, -0.0343111f,0.979592f,0.198047f, -0.0638942f,0.984862f,0.161133f, -0.0719687f,0.995312f,0.0646062f, -0.0847007f,0.982914f,-0.163422f, -0.363247f,0.926697f,-0.0963506f, -0.36667f,0.908341f,-0.201173f, -0.337169f,0.882657f,-0.327465f, -0.394509f,0.879929f,-0.264742f, -0.48646f,0.864989f,-0.123088f, -0.417344f,0.883151f,-0.21417f, -0.20086f,0.830272f,-0.519907f, -0.38892f,0.767179f,-0.510077f, -0.449414f,0.718324f,-0.531072f, -0.423477f,0.726204f,-0.541567f, -0.422958f,0.74196f,-0.520194f, -0.433204f,0.760712f,-0.483374f, -0.409051f,0.775415f,-0.481049f, -0.416047f,0.762178f,-0.495973f, -0.412818f,0.728929f,-0.546117f, -0.422596f,0.756339f,-0.499363f, -0.473538f,0.806572f,-0.353841f, -0.474731f,0.838081f,-0.268794f, -0.539079f,0.832631f,-0.126962f, -0.311124f,0.910644f,-0.271898f, -0.195648f,0.962321f,-0.18884f, -0.177086f,0.961235f,-0.211349f, -0.0559264f,0.927874f,-0.368677f, -0.121016f,0.928529f,-0.350982f, -0.256538f,0.895264f,-0.364269f, -0.222607f,0.876269f,-0.427317f, --0.106542f,0.82471f,-0.55543f, --0.245122f,0.890501f,-0.383305f, --0.209725f,0.956698f,-0.201855f, --0.0624605f,0.97406f,-0.2175f, --0.0812465f,0.947824f,-0.308266f, -0.0649824f,0.972455f,-0.223851f, -0.119957f,0.950206f,-0.287609f, --0.0414767f,0.905483f,-0.422351f, -}; - -btScalar Landscape03Tex[] = { -0.507813f,0.5f, -0.507813f,0.492188f, -0.515625f,0.5f, -0.515625f,0.492188f, -0.523438f,0.5f, -0.523438f,0.492188f, -0.53125f,0.5f, -0.53125f,0.492188f, -0.539063f,0.5f, -0.539063f,0.492188f, -0.546875f,0.5f, -0.546875f,0.492188f, -0.554688f,0.5f, -0.554688f,0.492188f, -0.5625f,0.5f, -0.5625f,0.492188f, -0.570313f,0.5f, -0.570313f,0.492188f, -0.578125f,0.5f, -0.578125f,0.492188f, -0.585938f,0.5f, -0.585938f,0.492188f, -0.59375f,0.5f, -0.59375f,0.492188f, -0.601563f,0.5f, -0.601563f,0.492188f, -0.609375f,0.5f, -0.609375f,0.492188f, -0.617188f,0.5f, -0.617188f,0.492188f, -0.625f,0.5f, -0.625f,0.492188f, -0.632813f,0.5f, -0.632813f,0.492188f, -0.640625f,0.5f, -0.640625f,0.492188f, -0.648438f,0.5f, -0.648438f,0.492188f, -0.65625f,0.5f, -0.65625f,0.492188f, -0.664063f,0.5f, -0.664063f,0.492188f, -0.671875f,0.5f, -0.671875f,0.492188f, -0.679688f,0.5f, -0.679688f,0.492188f, -0.6875f,0.5f, -0.6875f,0.492188f, -0.695313f,0.5f, -0.695313f,0.492188f, -0.703125f,0.5f, -0.703125f,0.492188f, -0.710938f,0.5f, -0.710938f,0.492188f, -0.71875f,0.5f, -0.71875f,0.492188f, -0.726563f,0.5f, -0.726563f,0.492188f, -0.734375f,0.5f, -0.734375f,0.492188f, -0.742188f,0.5f, -0.742188f,0.492188f, -0.75f,0.5f, -0.75f,0.492188f, -0.757813f,0.5f, -0.757813f,0.492188f, -0.765625f,0.5f, -0.765625f,0.492188f, -0.773438f,0.5f, -0.773438f,0.492188f, -0.78125f,0.5f, -0.78125f,0.492188f, -0.789063f,0.5f, -0.789063f,0.492188f, -0.796875f,0.5f, -0.796875f,0.492188f, -0.804688f,0.5f, -0.804688f,0.492188f, -0.8125f,0.5f, -0.8125f,0.492188f, -0.820313f,0.5f, -0.820313f,0.492188f, -0.828125f,0.5f, -0.828125f,0.492188f, -0.835938f,0.5f, -0.835938f,0.492188f, -0.84375f,0.5f, -0.84375f,0.492188f, -0.851563f,0.5f, -0.851563f,0.492188f, -0.859375f,0.5f, -0.859375f,0.492188f, -0.867188f,0.5f, -0.867188f,0.492188f, -0.875f,0.5f, -0.875f,0.492188f, -0.882813f,0.5f, -0.882813f,0.492188f, -0.890625f,0.5f, -0.890625f,0.492188f, -0.898438f,0.5f, -0.898438f,0.492188f, -0.90625f,0.5f, -0.90625f,0.492188f, -0.914063f,0.5f, -0.914063f,0.492188f, -0.921875f,0.5f, -0.921875f,0.492188f, -0.929688f,0.5f, -0.929688f,0.492188f, -0.9375f,0.5f, -0.9375f,0.492188f, -0.945313f,0.5f, -0.945313f,0.492188f, -0.953125f,0.5f, -0.953125f,0.492188f, -0.960938f,0.5f, -0.960938f,0.492188f, -0.96875f,0.5f, -0.96875f,0.492188f, -0.976563f,0.5f, -0.976563f,0.492188f, -0.984375f,0.5f, -0.984375f,0.492188f, -0.992188f,0.5f, -0.992188f,0.492188f, -1.0f,0.5f, -1.0f,0.492188f, -0.507813f,0.507813f, -0.515625f,0.507813f, -0.523438f,0.507813f, -0.53125f,0.507813f, -0.539063f,0.507813f, -0.546875f,0.507813f, -0.554688f,0.507813f, -0.5625f,0.507813f, -0.570313f,0.507813f, -0.578125f,0.507813f, -0.585938f,0.507813f, -0.59375f,0.507813f, -0.601563f,0.507813f, -0.609375f,0.507813f, -0.617188f,0.507813f, -0.625f,0.507813f, -0.632813f,0.507813f, -0.640625f,0.507813f, -0.648438f,0.507813f, -0.65625f,0.507813f, -0.664063f,0.507813f, -0.671875f,0.507813f, -0.679688f,0.507813f, -0.6875f,0.507813f, -0.695313f,0.507813f, -0.703125f,0.507813f, -0.710938f,0.507813f, -0.71875f,0.507813f, -0.726563f,0.507813f, -0.734375f,0.507813f, -0.742188f,0.507813f, -0.75f,0.507813f, -0.757813f,0.507813f, -0.765625f,0.507813f, -0.773438f,0.507813f, -0.78125f,0.507813f, -0.789063f,0.507813f, -0.796875f,0.507813f, -0.804688f,0.507813f, -0.8125f,0.507813f, -0.820313f,0.507813f, -0.828125f,0.507813f, -0.835938f,0.507813f, -0.84375f,0.507813f, -0.851563f,0.507813f, -0.859375f,0.507813f, -0.867188f,0.507813f, -0.875f,0.507813f, -0.882813f,0.507813f, -0.890625f,0.507813f, -0.898438f,0.507813f, -0.90625f,0.507813f, -0.914063f,0.507813f, -0.921875f,0.507813f, -0.929688f,0.507813f, -0.9375f,0.507813f, -0.945313f,0.507813f, -0.953125f,0.507813f, -0.960938f,0.507813f, -0.96875f,0.507813f, -0.976563f,0.507813f, -0.984375f,0.507813f, -0.992188f,0.507813f, -1.0f,0.507813f, -0.507813f,0.515625f, -0.515625f,0.515625f, -0.523438f,0.515625f, -0.53125f,0.515625f, -0.539063f,0.515625f, -0.546875f,0.515625f, -0.554688f,0.515625f, -0.5625f,0.515625f, -0.570313f,0.515625f, -0.578125f,0.515625f, -0.585938f,0.515625f, -0.59375f,0.515625f, -0.601563f,0.515625f, -0.609375f,0.515625f, -0.617188f,0.515625f, -0.625f,0.515625f, -0.632813f,0.515625f, -0.640625f,0.515625f, -0.648438f,0.515625f, -0.65625f,0.515625f, -0.664063f,0.515625f, -0.671875f,0.515625f, -0.679688f,0.515625f, -0.6875f,0.515625f, -0.695313f,0.515625f, -0.703125f,0.515625f, -0.710938f,0.515625f, -0.71875f,0.515625f, -0.726563f,0.515625f, -0.734375f,0.515625f, -0.742188f,0.515625f, -0.75f,0.515625f, -0.757813f,0.515625f, -0.765625f,0.515625f, -0.773438f,0.515625f, -0.78125f,0.515625f, -0.789063f,0.515625f, -0.796875f,0.515625f, -0.804688f,0.515625f, -0.8125f,0.515625f, -0.820313f,0.515625f, -0.828125f,0.515625f, -0.835938f,0.515625f, -0.84375f,0.515625f, -0.851563f,0.515625f, -0.859375f,0.515625f, -0.867188f,0.515625f, -0.875f,0.515625f, -0.882813f,0.515625f, -0.890625f,0.515625f, -0.898438f,0.515625f, -0.90625f,0.515625f, -0.914063f,0.515625f, -0.921875f,0.515625f, -0.929688f,0.515625f, -0.9375f,0.515625f, -0.945313f,0.515625f, -0.953125f,0.515625f, -0.960938f,0.515625f, -0.96875f,0.515625f, -0.976563f,0.515625f, -0.984375f,0.515625f, -0.992188f,0.515625f, -1.0f,0.515625f, -0.507813f,0.523438f, -0.515625f,0.523438f, -0.523438f,0.523438f, -0.53125f,0.523438f, -0.539063f,0.523438f, -0.546875f,0.523438f, -0.554688f,0.523438f, -0.5625f,0.523438f, -0.570313f,0.523438f, -0.578125f,0.523438f, -0.585938f,0.523438f, -0.59375f,0.523438f, -0.601563f,0.523438f, -0.609375f,0.523438f, -0.617188f,0.523438f, -0.625f,0.523438f, -0.632813f,0.523438f, -0.640625f,0.523438f, -0.648438f,0.523438f, -0.65625f,0.523438f, -0.664063f,0.523438f, -0.671875f,0.523438f, -0.679688f,0.523438f, -0.6875f,0.523438f, -0.695313f,0.523438f, -0.703125f,0.523438f, -0.710938f,0.523438f, -0.71875f,0.523438f, -0.726563f,0.523438f, -0.734375f,0.523438f, -0.742188f,0.523438f, -0.75f,0.523438f, -0.757813f,0.523438f, -0.765625f,0.523438f, -0.773438f,0.523438f, -0.78125f,0.523438f, -0.789063f,0.523438f, -0.796875f,0.523438f, -0.804688f,0.523438f, -0.8125f,0.523438f, -0.820313f,0.523438f, -0.828125f,0.523438f, -0.835938f,0.523438f, -0.84375f,0.523438f, -0.851563f,0.523438f, -0.859375f,0.523438f, -0.867188f,0.523438f, -0.875f,0.523438f, -0.882813f,0.523438f, -0.890625f,0.523438f, -0.898438f,0.523438f, -0.90625f,0.523438f, -0.914063f,0.523438f, -0.921875f,0.523438f, -0.929688f,0.523438f, -0.9375f,0.523438f, -0.945313f,0.523438f, -0.953125f,0.523438f, -0.960938f,0.523438f, -0.96875f,0.523438f, -0.976563f,0.523438f, -0.984375f,0.523438f, -0.992188f,0.523438f, -1.0f,0.523438f, -0.507813f,0.53125f, -0.515625f,0.53125f, -0.523438f,0.53125f, -0.53125f,0.53125f, -0.539063f,0.53125f, -0.546875f,0.53125f, -0.554688f,0.53125f, -0.5625f,0.53125f, -0.570313f,0.53125f, -0.578125f,0.53125f, -0.585938f,0.53125f, -0.59375f,0.53125f, -0.601563f,0.53125f, -0.609375f,0.53125f, -0.617188f,0.53125f, -0.625f,0.53125f, -0.632813f,0.53125f, -0.640625f,0.53125f, -0.648438f,0.53125f, -0.65625f,0.53125f, -0.664063f,0.53125f, -0.671875f,0.53125f, -0.679688f,0.53125f, -0.6875f,0.53125f, -0.695313f,0.53125f, -0.703125f,0.53125f, -0.710938f,0.53125f, -0.71875f,0.53125f, -0.726563f,0.53125f, -0.734375f,0.53125f, -0.742188f,0.53125f, -0.75f,0.53125f, -0.757813f,0.53125f, -0.765625f,0.53125f, -0.773438f,0.53125f, -0.78125f,0.53125f, -0.789063f,0.53125f, -0.796875f,0.53125f, -0.804688f,0.53125f, -0.8125f,0.53125f, -0.820313f,0.53125f, -0.828125f,0.53125f, -0.835938f,0.53125f, -0.84375f,0.53125f, -0.851563f,0.53125f, -0.859375f,0.53125f, -0.867188f,0.53125f, -0.875f,0.53125f, -0.882813f,0.53125f, -0.890625f,0.53125f, -0.898438f,0.53125f, -0.90625f,0.53125f, -0.914063f,0.53125f, -0.921875f,0.53125f, -0.929688f,0.53125f, -0.9375f,0.53125f, -0.945313f,0.53125f, -0.953125f,0.53125f, -0.960938f,0.53125f, -0.96875f,0.53125f, -0.976563f,0.53125f, -0.984375f,0.53125f, -0.992188f,0.53125f, -1.0f,0.53125f, -0.507813f,0.539063f, -0.515625f,0.539063f, -0.523438f,0.539063f, -0.53125f,0.539063f, -0.539063f,0.539063f, -0.546875f,0.539063f, -0.554688f,0.539063f, -0.5625f,0.539063f, -0.570313f,0.539063f, -0.578125f,0.539063f, -0.585938f,0.539063f, -0.59375f,0.539063f, -0.601563f,0.539063f, -0.609375f,0.539063f, -0.617188f,0.539063f, -0.625f,0.539063f, -0.632813f,0.539063f, -0.640625f,0.539063f, -0.648438f,0.539063f, -0.65625f,0.539063f, -0.664063f,0.539063f, -0.671875f,0.539063f, -0.679688f,0.539063f, -0.6875f,0.539063f, -0.695313f,0.539063f, -0.703125f,0.539063f, -0.710938f,0.539063f, -0.71875f,0.539063f, -0.726563f,0.539063f, -0.734375f,0.539063f, -0.742188f,0.539063f, -0.75f,0.539063f, -0.757813f,0.539063f, -0.765625f,0.539063f, -0.773438f,0.539063f, -0.78125f,0.539063f, -0.789063f,0.539063f, -0.796875f,0.539063f, -0.804688f,0.539063f, -0.8125f,0.539063f, -0.820313f,0.539063f, -0.828125f,0.539063f, -0.835938f,0.539063f, -0.84375f,0.539063f, -0.851563f,0.539063f, -0.859375f,0.539063f, -0.867188f,0.539063f, -0.875f,0.539063f, -0.882813f,0.539063f, -0.890625f,0.539063f, -0.898438f,0.539063f, -0.90625f,0.539063f, -0.914063f,0.539063f, -0.921875f,0.539063f, -0.929688f,0.539063f, -0.9375f,0.539063f, -0.945313f,0.539063f, -0.953125f,0.539063f, -0.960938f,0.539063f, -0.96875f,0.539063f, -0.976563f,0.539063f, -0.984375f,0.539063f, -0.992188f,0.539063f, -1.0f,0.539063f, -0.507813f,0.546875f, -0.515625f,0.546875f, -0.523438f,0.546875f, -0.53125f,0.546875f, -0.539063f,0.546875f, -0.546875f,0.546875f, -0.554688f,0.546875f, -0.5625f,0.546875f, -0.570313f,0.546875f, -0.578125f,0.546875f, -0.585938f,0.546875f, -0.59375f,0.546875f, -0.601563f,0.546875f, -0.609375f,0.546875f, -0.617188f,0.546875f, -0.625f,0.546875f, -0.632813f,0.546875f, -0.640625f,0.546875f, -0.648438f,0.546875f, -0.65625f,0.546875f, -0.664063f,0.546875f, -0.671875f,0.546875f, -0.679688f,0.546875f, -0.6875f,0.546875f, -0.695313f,0.546875f, -0.703125f,0.546875f, -0.710938f,0.546875f, -0.71875f,0.546875f, -0.726563f,0.546875f, -0.734375f,0.546875f, -0.742188f,0.546875f, -0.75f,0.546875f, -0.757813f,0.546875f, -0.765625f,0.546875f, -0.773438f,0.546875f, -0.78125f,0.546875f, -0.789063f,0.546875f, -0.796875f,0.546875f, -0.804688f,0.546875f, -0.8125f,0.546875f, -0.820313f,0.546875f, -0.828125f,0.546875f, -0.835938f,0.546875f, -0.84375f,0.546875f, -0.851563f,0.546875f, -0.859375f,0.546875f, -0.867188f,0.546875f, -0.875f,0.546875f, -0.882813f,0.546875f, -0.890625f,0.546875f, -0.898438f,0.546875f, -0.90625f,0.546875f, -0.914063f,0.546875f, -0.921875f,0.546875f, -0.929688f,0.546875f, -0.9375f,0.546875f, -0.945313f,0.546875f, -0.953125f,0.546875f, -0.960938f,0.546875f, -0.96875f,0.546875f, -0.976563f,0.546875f, -0.984375f,0.546875f, -0.992188f,0.546875f, -1.0f,0.546875f, -0.507813f,0.554688f, -0.515625f,0.554688f, -0.523438f,0.554688f, -0.53125f,0.554688f, -0.539063f,0.554688f, -0.546875f,0.554688f, -0.554688f,0.554688f, -0.5625f,0.554688f, -0.570313f,0.554688f, -0.578125f,0.554688f, -0.585938f,0.554688f, -0.59375f,0.554688f, -0.601563f,0.554688f, -0.609375f,0.554688f, -0.617188f,0.554688f, -0.625f,0.554688f, -0.632813f,0.554688f, -0.640625f,0.554688f, -0.648438f,0.554688f, -0.65625f,0.554688f, -0.664063f,0.554688f, -0.671875f,0.554688f, -0.679688f,0.554688f, -0.6875f,0.554688f, -0.695313f,0.554688f, -0.703125f,0.554688f, -0.710938f,0.554688f, -0.71875f,0.554688f, -0.726563f,0.554688f, -0.734375f,0.554688f, -0.742188f,0.554688f, -0.75f,0.554688f, -0.757813f,0.554688f, -0.765625f,0.554688f, -0.773438f,0.554688f, -0.78125f,0.554688f, -0.789063f,0.554688f, -0.796875f,0.554688f, -0.804688f,0.554688f, -0.8125f,0.554688f, -0.820313f,0.554688f, -0.828125f,0.554688f, -0.835938f,0.554688f, -0.84375f,0.554688f, -0.851563f,0.554688f, -0.859375f,0.554688f, -0.867188f,0.554688f, -0.875f,0.554688f, -0.882813f,0.554688f, -0.890625f,0.554688f, -0.898438f,0.554688f, -0.90625f,0.554688f, -0.914063f,0.554688f, -0.921875f,0.554688f, -0.929688f,0.554688f, -0.9375f,0.554688f, -0.945313f,0.554688f, -0.953125f,0.554688f, -0.960938f,0.554688f, -0.96875f,0.554688f, -0.976563f,0.554688f, -0.984375f,0.554688f, -0.992188f,0.554688f, -1.0f,0.554688f, -0.507813f,0.5625f, -0.515625f,0.5625f, -0.523438f,0.5625f, -0.53125f,0.5625f, -0.539063f,0.5625f, -0.546875f,0.5625f, -0.554688f,0.5625f, -0.5625f,0.5625f, -0.570313f,0.5625f, -0.578125f,0.5625f, -0.585938f,0.5625f, -0.59375f,0.5625f, -0.601563f,0.5625f, -0.609375f,0.5625f, -0.617188f,0.5625f, -0.625f,0.5625f, -0.632813f,0.5625f, -0.640625f,0.5625f, -0.648438f,0.5625f, -0.65625f,0.5625f, -0.664063f,0.5625f, -0.671875f,0.5625f, -0.679688f,0.5625f, -0.6875f,0.5625f, -0.695313f,0.5625f, -0.703125f,0.5625f, -0.710938f,0.5625f, -0.71875f,0.5625f, -0.726563f,0.5625f, -0.734375f,0.5625f, -0.742188f,0.5625f, -0.75f,0.5625f, -0.757813f,0.5625f, -0.765625f,0.5625f, -0.773438f,0.5625f, -0.78125f,0.5625f, -0.789063f,0.5625f, -0.796875f,0.5625f, -0.804688f,0.5625f, -0.8125f,0.5625f, -0.820313f,0.5625f, -0.828125f,0.5625f, -0.835938f,0.5625f, -0.84375f,0.5625f, -0.851563f,0.5625f, -0.859375f,0.5625f, -0.867188f,0.5625f, -0.875f,0.5625f, -0.882813f,0.5625f, -0.890625f,0.5625f, -0.898438f,0.5625f, -0.90625f,0.5625f, -0.914063f,0.5625f, -0.921875f,0.5625f, -0.929688f,0.5625f, -0.9375f,0.5625f, -0.945313f,0.5625f, -0.953125f,0.5625f, -0.960938f,0.5625f, -0.96875f,0.5625f, -0.976563f,0.5625f, -0.984375f,0.5625f, -0.992188f,0.5625f, -1.0f,0.5625f, -0.507813f,0.570313f, -0.515625f,0.570313f, -0.523438f,0.570313f, -0.53125f,0.570313f, -0.539063f,0.570313f, -0.546875f,0.570313f, -0.554688f,0.570313f, -0.5625f,0.570313f, -0.570313f,0.570313f, -0.578125f,0.570313f, -0.585938f,0.570313f, -0.59375f,0.570313f, -0.601563f,0.570313f, -0.609375f,0.570313f, -0.617188f,0.570313f, -0.625f,0.570313f, -0.632813f,0.570313f, -0.640625f,0.570313f, -0.648438f,0.570313f, -0.65625f,0.570313f, -0.664063f,0.570313f, -0.671875f,0.570313f, -0.679688f,0.570313f, -0.6875f,0.570313f, -0.695313f,0.570313f, -0.703125f,0.570313f, -0.710938f,0.570313f, -0.71875f,0.570313f, -0.726563f,0.570313f, -0.734375f,0.570313f, -0.742188f,0.570313f, -0.75f,0.570313f, -0.757813f,0.570313f, -0.765625f,0.570313f, -0.773438f,0.570313f, -0.78125f,0.570313f, -0.789063f,0.570313f, -0.796875f,0.570313f, -0.804688f,0.570313f, -0.8125f,0.570313f, -0.820313f,0.570313f, -0.828125f,0.570313f, -0.835938f,0.570313f, -0.84375f,0.570313f, -0.851563f,0.570313f, -0.859375f,0.570313f, -0.867188f,0.570313f, -0.875f,0.570313f, -0.882813f,0.570313f, -0.890625f,0.570313f, -0.898438f,0.570313f, -0.90625f,0.570313f, -0.914063f,0.570313f, -0.921875f,0.570313f, -0.929688f,0.570313f, -0.9375f,0.570313f, -0.945313f,0.570313f, -0.953125f,0.570313f, -0.960938f,0.570313f, -0.96875f,0.570313f, -0.976563f,0.570313f, -0.984375f,0.570313f, -0.992188f,0.570313f, -1.0f,0.570313f, -0.507813f,0.578125f, -0.515625f,0.578125f, -0.523438f,0.578125f, -0.53125f,0.578125f, -0.539063f,0.578125f, -0.546875f,0.578125f, -0.554688f,0.578125f, -0.5625f,0.578125f, -0.570313f,0.578125f, -0.578125f,0.578125f, -0.585938f,0.578125f, -0.59375f,0.578125f, -0.601563f,0.578125f, -0.609375f,0.578125f, -0.617188f,0.578125f, -0.625f,0.578125f, -0.632813f,0.578125f, -0.640625f,0.578125f, -0.648438f,0.578125f, -0.65625f,0.578125f, -0.664063f,0.578125f, -0.671875f,0.578125f, -0.679688f,0.578125f, -0.6875f,0.578125f, -0.695313f,0.578125f, -0.703125f,0.578125f, -0.710938f,0.578125f, -0.71875f,0.578125f, -0.726563f,0.578125f, -0.734375f,0.578125f, -0.742188f,0.578125f, -0.75f,0.578125f, -0.757813f,0.578125f, -0.765625f,0.578125f, -0.773438f,0.578125f, -0.78125f,0.578125f, -0.789063f,0.578125f, -0.796875f,0.578125f, -0.804688f,0.578125f, -0.8125f,0.578125f, -0.820313f,0.578125f, -0.828125f,0.578125f, -0.835938f,0.578125f, -0.84375f,0.578125f, -0.851563f,0.578125f, -0.859375f,0.578125f, -0.867188f,0.578125f, -0.875f,0.578125f, -0.882813f,0.578125f, -0.890625f,0.578125f, -0.898438f,0.578125f, -0.90625f,0.578125f, -0.914063f,0.578125f, -0.921875f,0.578125f, -0.929688f,0.578125f, -0.9375f,0.578125f, -0.945313f,0.578125f, -0.953125f,0.578125f, -0.960938f,0.578125f, -0.96875f,0.578125f, -0.976563f,0.578125f, -0.984375f,0.578125f, -0.992188f,0.578125f, -1.0f,0.578125f, -0.507813f,0.585938f, -0.515625f,0.585938f, -0.523438f,0.585938f, -0.53125f,0.585938f, -0.539063f,0.585938f, -0.546875f,0.585938f, -0.554688f,0.585938f, -0.5625f,0.585938f, -0.570313f,0.585938f, -0.578125f,0.585938f, -0.585938f,0.585938f, -0.59375f,0.585938f, -0.601563f,0.585938f, -0.609375f,0.585938f, -0.617188f,0.585938f, -0.625f,0.585938f, -0.632813f,0.585938f, -0.640625f,0.585938f, -0.648438f,0.585938f, -0.65625f,0.585938f, -0.664063f,0.585938f, -0.671875f,0.585938f, -0.679688f,0.585938f, -0.6875f,0.585938f, -0.695313f,0.585938f, -0.703125f,0.585938f, -0.710938f,0.585938f, -0.71875f,0.585938f, -0.726563f,0.585938f, -0.734375f,0.585938f, -0.742188f,0.585938f, -0.75f,0.585938f, -0.757813f,0.585938f, -0.765625f,0.585938f, -0.773438f,0.585938f, -0.78125f,0.585938f, -0.789063f,0.585938f, -0.796875f,0.585938f, -0.804688f,0.585938f, -0.8125f,0.585938f, -0.820313f,0.585938f, -0.828125f,0.585938f, -0.835938f,0.585938f, -0.84375f,0.585938f, -0.851563f,0.585938f, -0.859375f,0.585938f, -0.867188f,0.585938f, -0.875f,0.585938f, -0.882813f,0.585938f, -0.890625f,0.585938f, -0.898438f,0.585938f, -0.90625f,0.585938f, -0.914063f,0.585938f, -0.921875f,0.585938f, -0.929688f,0.585938f, -0.9375f,0.585938f, -0.945313f,0.585938f, -0.953125f,0.585938f, -0.960938f,0.585938f, -0.96875f,0.585938f, -0.976563f,0.585938f, -0.984375f,0.585938f, -0.992188f,0.585938f, -1.0f,0.585938f, -0.507813f,0.59375f, -0.515625f,0.59375f, -0.523438f,0.59375f, -0.53125f,0.59375f, -0.539063f,0.59375f, -0.546875f,0.59375f, -0.554688f,0.59375f, -0.5625f,0.59375f, -0.570313f,0.59375f, -0.578125f,0.59375f, -0.585938f,0.59375f, -0.59375f,0.59375f, -0.601563f,0.59375f, -0.609375f,0.59375f, -0.617188f,0.59375f, -0.625f,0.59375f, -0.632813f,0.59375f, -0.640625f,0.59375f, -0.648438f,0.59375f, -0.65625f,0.59375f, -0.664063f,0.59375f, -0.671875f,0.59375f, -0.679688f,0.59375f, -0.6875f,0.59375f, -0.695313f,0.59375f, -0.703125f,0.59375f, -0.710938f,0.59375f, -0.71875f,0.59375f, -0.726563f,0.59375f, -0.734375f,0.59375f, -0.742188f,0.59375f, -0.75f,0.59375f, -0.757813f,0.59375f, -0.765625f,0.59375f, -0.773438f,0.59375f, -0.78125f,0.59375f, -0.789063f,0.59375f, -0.796875f,0.59375f, -0.804688f,0.59375f, -0.8125f,0.59375f, -0.820313f,0.59375f, -0.828125f,0.59375f, -0.835938f,0.59375f, -0.84375f,0.59375f, -0.851563f,0.59375f, -0.859375f,0.59375f, -0.867188f,0.59375f, -0.875f,0.59375f, -0.882813f,0.59375f, -0.890625f,0.59375f, -0.898438f,0.59375f, -0.90625f,0.59375f, -0.914063f,0.59375f, -0.921875f,0.59375f, -0.929688f,0.59375f, -0.9375f,0.59375f, -0.945313f,0.59375f, -0.953125f,0.59375f, -0.960938f,0.59375f, -0.96875f,0.59375f, -0.976563f,0.59375f, -0.984375f,0.59375f, -0.992188f,0.59375f, -1.0f,0.59375f, -0.507813f,0.601563f, -0.515625f,0.601563f, -0.523438f,0.601563f, -0.53125f,0.601563f, -0.539063f,0.601563f, -0.546875f,0.601563f, -0.554688f,0.601563f, -0.5625f,0.601563f, -0.570313f,0.601563f, -0.578125f,0.601563f, -0.585938f,0.601563f, -0.59375f,0.601563f, -0.601563f,0.601563f, -0.609375f,0.601563f, -0.617188f,0.601563f, -0.625f,0.601563f, -0.632813f,0.601563f, -0.640625f,0.601563f, -0.648438f,0.601563f, -0.65625f,0.601563f, -0.664063f,0.601563f, -0.671875f,0.601563f, -0.679688f,0.601563f, -0.6875f,0.601563f, -0.695313f,0.601563f, -0.703125f,0.601563f, -0.710938f,0.601563f, -0.71875f,0.601563f, -0.726563f,0.601563f, -0.734375f,0.601563f, -0.742188f,0.601563f, -0.75f,0.601563f, -0.757813f,0.601563f, -0.765625f,0.601563f, -0.773438f,0.601563f, -0.78125f,0.601563f, -0.789063f,0.601563f, -0.796875f,0.601563f, -0.804688f,0.601563f, -0.8125f,0.601563f, -0.820313f,0.601563f, -0.828125f,0.601563f, -0.835938f,0.601563f, -0.84375f,0.601563f, -0.851563f,0.601563f, -0.859375f,0.601563f, -0.867188f,0.601563f, -0.875f,0.601563f, -0.882813f,0.601563f, -0.890625f,0.601563f, -0.898438f,0.601563f, -0.90625f,0.601563f, -0.914063f,0.601563f, -0.921875f,0.601563f, -0.929688f,0.601563f, -0.9375f,0.601563f, -0.945313f,0.601563f, -0.953125f,0.601563f, -0.960938f,0.601563f, -0.96875f,0.601563f, -0.976563f,0.601563f, -0.984375f,0.601563f, -0.992188f,0.601563f, -1.0f,0.601563f, -0.507813f,0.609375f, -0.515625f,0.609375f, -0.523438f,0.609375f, -0.53125f,0.609375f, -0.539063f,0.609375f, -0.546875f,0.609375f, -0.554688f,0.609375f, -0.5625f,0.609375f, -0.570313f,0.609375f, -0.578125f,0.609375f, -0.585938f,0.609375f, -0.59375f,0.609375f, -0.601563f,0.609375f, -0.609375f,0.609375f, -0.617188f,0.609375f, -0.625f,0.609375f, -0.632813f,0.609375f, -0.640625f,0.609375f, -0.648438f,0.609375f, -0.65625f,0.609375f, -0.664063f,0.609375f, -0.671875f,0.609375f, -0.679688f,0.609375f, -0.6875f,0.609375f, -0.695313f,0.609375f, -0.703125f,0.609375f, -0.710938f,0.609375f, -0.71875f,0.609375f, -0.726563f,0.609375f, -0.734375f,0.609375f, -0.742188f,0.609375f, -0.75f,0.609375f, -0.757813f,0.609375f, -0.765625f,0.609375f, -0.773438f,0.609375f, -0.78125f,0.609375f, -0.789063f,0.609375f, -0.796875f,0.609375f, -0.804688f,0.609375f, -0.8125f,0.609375f, -0.820313f,0.609375f, -0.828125f,0.609375f, -0.835938f,0.609375f, -0.84375f,0.609375f, -0.851563f,0.609375f, -0.859375f,0.609375f, -0.867188f,0.609375f, -0.875f,0.609375f, -0.882813f,0.609375f, -0.890625f,0.609375f, -0.898438f,0.609375f, -0.90625f,0.609375f, -0.914063f,0.609375f, -0.921875f,0.609375f, -0.929688f,0.609375f, -0.9375f,0.609375f, -0.945313f,0.609375f, -0.953125f,0.609375f, -0.960938f,0.609375f, -0.96875f,0.609375f, -0.976563f,0.609375f, -0.984375f,0.609375f, -0.992188f,0.609375f, -1.0f,0.609375f, -0.507813f,0.617188f, -0.515625f,0.617188f, -0.523438f,0.617188f, -0.53125f,0.617188f, -0.539063f,0.617188f, -0.546875f,0.617188f, -0.554688f,0.617188f, -0.5625f,0.617188f, -0.570313f,0.617188f, -0.578125f,0.617188f, -0.585938f,0.617188f, -0.59375f,0.617188f, -0.601563f,0.617188f, -0.609375f,0.617188f, -0.617188f,0.617188f, -0.625f,0.617188f, -0.632813f,0.617188f, -0.640625f,0.617188f, -0.648438f,0.617188f, -0.65625f,0.617188f, -0.664063f,0.617188f, -0.671875f,0.617188f, -0.679688f,0.617188f, -0.6875f,0.617188f, -0.695313f,0.617188f, -0.703125f,0.617188f, -0.710938f,0.617188f, -0.71875f,0.617188f, -0.726563f,0.617188f, -0.734375f,0.617188f, -0.742188f,0.617188f, -0.75f,0.617188f, -0.757813f,0.617188f, -0.765625f,0.617188f, -0.773438f,0.617188f, -0.78125f,0.617188f, -0.789063f,0.617188f, -0.796875f,0.617188f, -0.804688f,0.617188f, -0.8125f,0.617188f, -0.820313f,0.617188f, -0.828125f,0.617188f, -0.835938f,0.617188f, -0.84375f,0.617188f, -0.851563f,0.617188f, -0.859375f,0.617188f, -0.867188f,0.617188f, -0.875f,0.617188f, -0.882813f,0.617188f, -0.890625f,0.617188f, -0.898438f,0.617188f, -0.90625f,0.617188f, -0.914063f,0.617188f, -0.921875f,0.617188f, -0.929688f,0.617188f, -0.9375f,0.617188f, -0.945313f,0.617188f, -0.953125f,0.617188f, -0.960938f,0.617188f, -0.96875f,0.617188f, -0.976563f,0.617188f, -0.984375f,0.617188f, -0.992188f,0.617188f, -1.0f,0.617188f, -0.507813f,0.625f, -0.515625f,0.625f, -0.523438f,0.625f, -0.53125f,0.625f, -0.539063f,0.625f, -0.546875f,0.625f, -0.554688f,0.625f, -0.5625f,0.625f, -0.570313f,0.625f, -0.578125f,0.625f, -0.585938f,0.625f, -0.59375f,0.625f, -0.601563f,0.625f, -0.609375f,0.625f, -0.617188f,0.625f, -0.625f,0.625f, -0.632813f,0.625f, -0.640625f,0.625f, -0.648438f,0.625f, -0.65625f,0.625f, -0.664063f,0.625f, -0.671875f,0.625f, -0.679688f,0.625f, -0.6875f,0.625f, -0.695313f,0.625f, -0.703125f,0.625f, -0.710938f,0.625f, -0.71875f,0.625f, -0.726563f,0.625f, -0.734375f,0.625f, -0.742188f,0.625f, -0.75f,0.625f, -0.757813f,0.625f, -0.765625f,0.625f, -0.773438f,0.625f, -0.78125f,0.625f, -0.789063f,0.625f, -0.796875f,0.625f, -0.804688f,0.625f, -0.8125f,0.625f, -0.820313f,0.625f, -0.828125f,0.625f, -0.835938f,0.625f, -0.84375f,0.625f, -0.851563f,0.625f, -0.859375f,0.625f, -0.867188f,0.625f, -0.875f,0.625f, -0.882813f,0.625f, -0.890625f,0.625f, -0.898438f,0.625f, -0.90625f,0.625f, -0.914063f,0.625f, -0.921875f,0.625f, -0.929688f,0.625f, -0.9375f,0.625f, -0.945313f,0.625f, -0.953125f,0.625f, -0.960938f,0.625f, -0.96875f,0.625f, -0.976563f,0.625f, -0.984375f,0.625f, -0.992188f,0.625f, -1.0f,0.625f, -0.507813f,0.632813f, -0.515625f,0.632813f, -0.523438f,0.632813f, -0.53125f,0.632813f, -0.539063f,0.632813f, -0.546875f,0.632813f, -0.554688f,0.632813f, -0.5625f,0.632813f, -0.570313f,0.632813f, -0.578125f,0.632813f, -0.585938f,0.632813f, -0.59375f,0.632813f, -0.601563f,0.632813f, -0.609375f,0.632813f, -0.617188f,0.632813f, -0.625f,0.632813f, -0.632813f,0.632813f, -0.640625f,0.632813f, -0.648438f,0.632813f, -0.65625f,0.632813f, -0.664063f,0.632813f, -0.671875f,0.632813f, -0.679688f,0.632813f, -0.6875f,0.632813f, -0.695313f,0.632813f, -0.703125f,0.632813f, -0.710938f,0.632813f, -0.71875f,0.632813f, -0.726563f,0.632813f, -0.734375f,0.632813f, -0.742188f,0.632813f, -0.75f,0.632813f, -0.757813f,0.632813f, -0.765625f,0.632813f, -0.773438f,0.632813f, -0.78125f,0.632813f, -0.789063f,0.632813f, -0.796875f,0.632813f, -0.804688f,0.632813f, -0.8125f,0.632813f, -0.820313f,0.632813f, -0.828125f,0.632813f, -0.835938f,0.632813f, -0.84375f,0.632813f, -0.851563f,0.632813f, -0.859375f,0.632813f, -0.867188f,0.632813f, -0.875f,0.632813f, -0.882813f,0.632813f, -0.890625f,0.632813f, -0.898438f,0.632813f, -0.90625f,0.632813f, -0.914063f,0.632813f, -0.921875f,0.632813f, -0.929688f,0.632813f, -0.9375f,0.632813f, -0.945313f,0.632813f, -0.953125f,0.632813f, -0.960938f,0.632813f, -0.96875f,0.632813f, -0.976563f,0.632813f, -0.984375f,0.632813f, -0.992188f,0.632813f, -1.0f,0.632813f, -0.507813f,0.640625f, -0.515625f,0.640625f, -0.523438f,0.640625f, -0.53125f,0.640625f, -0.539063f,0.640625f, -0.546875f,0.640625f, -0.554688f,0.640625f, -0.5625f,0.640625f, -0.570313f,0.640625f, -0.578125f,0.640625f, -0.585938f,0.640625f, -0.59375f,0.640625f, -0.601563f,0.640625f, -0.609375f,0.640625f, -0.617188f,0.640625f, -0.625f,0.640625f, -0.632813f,0.640625f, -0.640625f,0.640625f, -0.648438f,0.640625f, -0.65625f,0.640625f, -0.664063f,0.640625f, -0.671875f,0.640625f, -0.679688f,0.640625f, -0.6875f,0.640625f, -0.695313f,0.640625f, -0.703125f,0.640625f, -0.710938f,0.640625f, -0.71875f,0.640625f, -0.726563f,0.640625f, -0.734375f,0.640625f, -0.742188f,0.640625f, -0.75f,0.640625f, -0.757813f,0.640625f, -0.765625f,0.640625f, -0.773438f,0.640625f, -0.78125f,0.640625f, -0.789063f,0.640625f, -0.796875f,0.640625f, -0.804688f,0.640625f, -0.8125f,0.640625f, -0.820313f,0.640625f, -0.828125f,0.640625f, -0.835938f,0.640625f, -0.84375f,0.640625f, -0.851563f,0.640625f, -0.859375f,0.640625f, -0.867188f,0.640625f, -0.875f,0.640625f, -0.882813f,0.640625f, -0.890625f,0.640625f, -0.898438f,0.640625f, -0.90625f,0.640625f, -0.914063f,0.640625f, -0.921875f,0.640625f, -0.929688f,0.640625f, -0.9375f,0.640625f, -0.945313f,0.640625f, -0.953125f,0.640625f, -0.960938f,0.640625f, -0.96875f,0.640625f, -0.976563f,0.640625f, -0.984375f,0.640625f, -0.992188f,0.640625f, -1.0f,0.640625f, -0.507813f,0.648438f, -0.515625f,0.648438f, -0.523438f,0.648438f, -0.53125f,0.648438f, -0.539063f,0.648438f, -0.546875f,0.648438f, -0.554688f,0.648438f, -0.5625f,0.648438f, -0.570313f,0.648438f, -0.578125f,0.648438f, -0.585938f,0.648438f, -0.59375f,0.648438f, -0.601563f,0.648438f, -0.609375f,0.648438f, -0.617188f,0.648438f, -0.625f,0.648438f, -0.632813f,0.648438f, -0.640625f,0.648438f, -0.648438f,0.648438f, -0.65625f,0.648438f, -0.664063f,0.648438f, -0.671875f,0.648438f, -0.679688f,0.648438f, -0.6875f,0.648438f, -0.695313f,0.648438f, -0.703125f,0.648438f, -0.710938f,0.648438f, -0.71875f,0.648438f, -0.726563f,0.648438f, -0.734375f,0.648438f, -0.742188f,0.648438f, -0.75f,0.648438f, -0.757813f,0.648438f, -0.765625f,0.648438f, -0.773438f,0.648438f, -0.78125f,0.648438f, -0.789063f,0.648438f, -0.796875f,0.648438f, -0.804688f,0.648438f, -0.8125f,0.648438f, -0.820313f,0.648438f, -0.828125f,0.648438f, -0.835938f,0.648438f, -0.84375f,0.648438f, -0.851563f,0.648438f, -0.859375f,0.648438f, -0.867188f,0.648438f, -0.875f,0.648438f, -0.882813f,0.648438f, -0.890625f,0.648438f, -0.898438f,0.648438f, -0.90625f,0.648438f, -0.914063f,0.648438f, -0.921875f,0.648438f, -0.929688f,0.648438f, -0.9375f,0.648438f, -0.945313f,0.648438f, -0.953125f,0.648438f, -0.960938f,0.648438f, -0.96875f,0.648438f, -0.976563f,0.648438f, -0.984375f,0.648438f, -0.992188f,0.648438f, -1.0f,0.648438f, -0.507813f,0.65625f, -0.515625f,0.65625f, -0.523438f,0.65625f, -0.53125f,0.65625f, -0.539063f,0.65625f, -0.546875f,0.65625f, -0.554688f,0.65625f, -0.5625f,0.65625f, -0.570313f,0.65625f, -0.578125f,0.65625f, -0.585938f,0.65625f, -0.59375f,0.65625f, -0.601563f,0.65625f, -0.609375f,0.65625f, -0.617188f,0.65625f, -0.625f,0.65625f, -0.632813f,0.65625f, -0.640625f,0.65625f, -0.648438f,0.65625f, -0.65625f,0.65625f, -0.664063f,0.65625f, -0.671875f,0.65625f, -0.679688f,0.65625f, -0.6875f,0.65625f, -0.695313f,0.65625f, -0.703125f,0.65625f, -0.710938f,0.65625f, -0.71875f,0.65625f, -0.726563f,0.65625f, -0.734375f,0.65625f, -0.742188f,0.65625f, -0.75f,0.65625f, -0.757813f,0.65625f, -0.765625f,0.65625f, -0.773438f,0.65625f, -0.78125f,0.65625f, -0.789063f,0.65625f, -0.796875f,0.65625f, -0.804688f,0.65625f, -0.8125f,0.65625f, -0.820313f,0.65625f, -0.828125f,0.65625f, -0.835938f,0.65625f, -0.84375f,0.65625f, -0.851563f,0.65625f, -0.859375f,0.65625f, -0.867188f,0.65625f, -0.875f,0.65625f, -0.882813f,0.65625f, -0.890625f,0.65625f, -0.898438f,0.65625f, -0.90625f,0.65625f, -0.914063f,0.65625f, -0.921875f,0.65625f, -0.929688f,0.65625f, -0.9375f,0.65625f, -0.945313f,0.65625f, -0.953125f,0.65625f, -0.960938f,0.65625f, -0.96875f,0.65625f, -0.976563f,0.65625f, -0.984375f,0.65625f, -0.992188f,0.65625f, -1.0f,0.65625f, -0.507813f,0.664063f, -0.515625f,0.664063f, -0.523438f,0.664063f, -0.53125f,0.664063f, -0.539063f,0.664063f, -0.546875f,0.664063f, -0.554688f,0.664063f, -0.5625f,0.664063f, -0.570313f,0.664063f, -0.578125f,0.664063f, -0.585938f,0.664063f, -0.59375f,0.664063f, -0.601563f,0.664063f, -0.609375f,0.664063f, -0.617188f,0.664063f, -0.625f,0.664063f, -0.632813f,0.664063f, -0.640625f,0.664063f, -0.648438f,0.664063f, -0.65625f,0.664063f, -0.664063f,0.664063f, -0.671875f,0.664063f, -0.679688f,0.664063f, -0.6875f,0.664063f, -0.695313f,0.664063f, -0.703125f,0.664063f, -0.710938f,0.664063f, -0.71875f,0.664063f, -0.726563f,0.664063f, -0.734375f,0.664063f, -0.742188f,0.664063f, -0.75f,0.664063f, -0.757813f,0.664063f, -0.765625f,0.664063f, -0.773438f,0.664063f, -0.78125f,0.664063f, -0.789063f,0.664063f, -0.796875f,0.664063f, -0.804688f,0.664063f, -0.8125f,0.664063f, -0.820313f,0.664063f, -0.828125f,0.664063f, -0.835938f,0.664063f, -0.84375f,0.664063f, -0.851563f,0.664063f, -0.859375f,0.664063f, -0.867188f,0.664063f, -0.875f,0.664063f, -0.882813f,0.664063f, -0.890625f,0.664063f, -0.898438f,0.664063f, -0.90625f,0.664063f, -0.914063f,0.664063f, -0.921875f,0.664063f, -0.929688f,0.664063f, -0.9375f,0.664063f, -0.945313f,0.664063f, -0.953125f,0.664063f, -0.960938f,0.664063f, -0.96875f,0.664063f, -0.976563f,0.664063f, -0.984375f,0.664063f, -0.992188f,0.664063f, -1.0f,0.664063f, -0.507813f,0.671875f, -0.515625f,0.671875f, -0.523438f,0.671875f, -0.53125f,0.671875f, -0.539063f,0.671875f, -0.546875f,0.671875f, -0.554688f,0.671875f, -0.5625f,0.671875f, -0.570313f,0.671875f, -0.578125f,0.671875f, -0.585938f,0.671875f, -0.59375f,0.671875f, -0.601563f,0.671875f, -0.609375f,0.671875f, -0.617188f,0.671875f, -0.625f,0.671875f, -0.632813f,0.671875f, -0.640625f,0.671875f, -0.648438f,0.671875f, -0.65625f,0.671875f, -0.664063f,0.671875f, -0.671875f,0.671875f, -0.679688f,0.671875f, -0.6875f,0.671875f, -0.695313f,0.671875f, -0.703125f,0.671875f, -0.710938f,0.671875f, -0.71875f,0.671875f, -0.726563f,0.671875f, -0.734375f,0.671875f, -0.742188f,0.671875f, -0.75f,0.671875f, -0.757813f,0.671875f, -0.765625f,0.671875f, -0.773438f,0.671875f, -0.78125f,0.671875f, -0.789063f,0.671875f, -0.796875f,0.671875f, -0.804688f,0.671875f, -0.8125f,0.671875f, -0.820313f,0.671875f, -0.828125f,0.671875f, -0.835938f,0.671875f, -0.84375f,0.671875f, -0.851563f,0.671875f, -0.859375f,0.671875f, -0.867188f,0.671875f, -0.875f,0.671875f, -0.882813f,0.671875f, -0.890625f,0.671875f, -0.898438f,0.671875f, -0.90625f,0.671875f, -0.914063f,0.671875f, -0.921875f,0.671875f, -0.929688f,0.671875f, -0.9375f,0.671875f, -0.945313f,0.671875f, -0.953125f,0.671875f, -0.960938f,0.671875f, -0.96875f,0.671875f, -0.976563f,0.671875f, -0.984375f,0.671875f, -0.992188f,0.671875f, -1.0f,0.671875f, -0.507813f,0.679688f, -0.515625f,0.679688f, -0.523438f,0.679688f, -0.53125f,0.679688f, -0.539063f,0.679688f, -0.546875f,0.679688f, -0.554688f,0.679688f, -0.5625f,0.679688f, -0.570313f,0.679688f, -0.578125f,0.679688f, -0.585938f,0.679688f, -0.59375f,0.679688f, -0.601563f,0.679688f, -0.609375f,0.679688f, -0.617188f,0.679688f, -0.625f,0.679688f, -0.632813f,0.679688f, -0.640625f,0.679688f, -0.648438f,0.679688f, -0.65625f,0.679688f, -0.664063f,0.679688f, -0.671875f,0.679688f, -0.679688f,0.679688f, -0.6875f,0.679688f, -0.695313f,0.679688f, -0.703125f,0.679688f, -0.710938f,0.679688f, -0.71875f,0.679688f, -0.726563f,0.679688f, -0.734375f,0.679688f, -0.742188f,0.679688f, -0.75f,0.679688f, -0.757813f,0.679688f, -0.765625f,0.679688f, -0.773438f,0.679688f, -0.78125f,0.679688f, -0.789063f,0.679688f, -0.796875f,0.679688f, -0.804688f,0.679688f, -0.8125f,0.679688f, -0.820313f,0.679688f, -0.828125f,0.679688f, -0.835938f,0.679688f, -0.84375f,0.679688f, -0.851563f,0.679688f, -0.859375f,0.679688f, -0.867188f,0.679688f, -0.875f,0.679688f, -0.882813f,0.679688f, -0.890625f,0.679688f, -0.898438f,0.679688f, -0.90625f,0.679688f, -0.914063f,0.679688f, -0.921875f,0.679688f, -0.929688f,0.679688f, -0.9375f,0.679688f, -0.945313f,0.679688f, -0.953125f,0.679688f, -0.960938f,0.679688f, -0.96875f,0.679688f, -0.976563f,0.679688f, -0.984375f,0.679688f, -0.992188f,0.679688f, -1.0f,0.679688f, -0.507813f,0.6875f, -0.515625f,0.6875f, -0.523438f,0.6875f, -0.53125f,0.6875f, -0.539063f,0.6875f, -0.546875f,0.6875f, -0.554688f,0.6875f, -0.5625f,0.6875f, -0.570313f,0.6875f, -0.578125f,0.6875f, -0.585938f,0.6875f, -0.59375f,0.6875f, -0.601563f,0.6875f, -0.609375f,0.6875f, -0.617188f,0.6875f, -0.625f,0.6875f, -0.632813f,0.6875f, -0.640625f,0.6875f, -0.648438f,0.6875f, -0.65625f,0.6875f, -0.664063f,0.6875f, -0.671875f,0.6875f, -0.679688f,0.6875f, -0.6875f,0.6875f, -0.695313f,0.6875f, -0.703125f,0.6875f, -0.710938f,0.6875f, -0.71875f,0.6875f, -0.726563f,0.6875f, -0.734375f,0.6875f, -0.742188f,0.6875f, -0.75f,0.6875f, -0.757813f,0.6875f, -0.765625f,0.6875f, -0.773438f,0.6875f, -0.78125f,0.6875f, -0.789063f,0.6875f, -0.796875f,0.6875f, -0.804688f,0.6875f, -0.8125f,0.6875f, -0.820313f,0.6875f, -0.828125f,0.6875f, -0.835938f,0.6875f, -0.84375f,0.6875f, -0.851563f,0.6875f, -0.859375f,0.6875f, -0.867188f,0.6875f, -0.875f,0.6875f, -0.882813f,0.6875f, -0.890625f,0.6875f, -0.898438f,0.6875f, -0.90625f,0.6875f, -0.914063f,0.6875f, -0.921875f,0.6875f, -0.929688f,0.6875f, -0.9375f,0.6875f, -0.945313f,0.6875f, -0.953125f,0.6875f, -0.960938f,0.6875f, -0.96875f,0.6875f, -0.976563f,0.6875f, -0.984375f,0.6875f, -0.992188f,0.6875f, -1.0f,0.6875f, -0.507813f,0.695313f, -0.515625f,0.695313f, -0.523438f,0.695313f, -0.53125f,0.695313f, -0.539063f,0.695313f, -0.546875f,0.695313f, -0.554688f,0.695313f, -0.5625f,0.695313f, -0.570313f,0.695313f, -0.578125f,0.695313f, -0.585938f,0.695313f, -0.59375f,0.695313f, -0.601563f,0.695313f, -0.609375f,0.695313f, -0.617188f,0.695313f, -0.625f,0.695313f, -0.632813f,0.695313f, -0.640625f,0.695313f, -0.648438f,0.695313f, -0.65625f,0.695313f, -0.664063f,0.695313f, -0.671875f,0.695313f, -0.679688f,0.695313f, -0.6875f,0.695313f, -0.695313f,0.695313f, -0.703125f,0.695313f, -0.710938f,0.695313f, -0.71875f,0.695313f, -0.726563f,0.695313f, -0.734375f,0.695313f, -0.742188f,0.695313f, -0.75f,0.695313f, -0.757813f,0.695313f, -0.765625f,0.695313f, -0.773438f,0.695313f, -0.78125f,0.695313f, -0.789063f,0.695313f, -0.796875f,0.695313f, -0.804688f,0.695313f, -0.8125f,0.695313f, -0.820313f,0.695313f, -0.828125f,0.695313f, -0.835938f,0.695313f, -0.84375f,0.695313f, -0.851563f,0.695313f, -0.859375f,0.695313f, -0.867188f,0.695313f, -0.875f,0.695313f, -0.882813f,0.695313f, -0.890625f,0.695313f, -0.898438f,0.695313f, -0.90625f,0.695313f, -0.914063f,0.695313f, -0.921875f,0.695313f, -0.929688f,0.695313f, -0.9375f,0.695313f, -0.945313f,0.695313f, -0.953125f,0.695313f, -0.960938f,0.695313f, -0.96875f,0.695313f, -0.976563f,0.695313f, -0.984375f,0.695313f, -0.992188f,0.695313f, -1.0f,0.695313f, -0.507813f,0.703125f, -0.515625f,0.703125f, -0.523438f,0.703125f, -0.53125f,0.703125f, -0.539063f,0.703125f, -0.546875f,0.703125f, -0.554688f,0.703125f, -0.5625f,0.703125f, -0.570313f,0.703125f, -0.578125f,0.703125f, -0.585938f,0.703125f, -0.59375f,0.703125f, -0.601563f,0.703125f, -0.609375f,0.703125f, -0.617188f,0.703125f, -0.625f,0.703125f, -0.632813f,0.703125f, -0.640625f,0.703125f, -0.648438f,0.703125f, -0.65625f,0.703125f, -0.664063f,0.703125f, -0.671875f,0.703125f, -0.679688f,0.703125f, -0.6875f,0.703125f, -0.695313f,0.703125f, -0.703125f,0.703125f, -0.710938f,0.703125f, -0.71875f,0.703125f, -0.726563f,0.703125f, -0.734375f,0.703125f, -0.742188f,0.703125f, -0.75f,0.703125f, -0.757813f,0.703125f, -0.765625f,0.703125f, -0.773438f,0.703125f, -0.78125f,0.703125f, -0.789063f,0.703125f, -0.796875f,0.703125f, -0.804688f,0.703125f, -0.8125f,0.703125f, -0.820313f,0.703125f, -0.828125f,0.703125f, -0.835938f,0.703125f, -0.84375f,0.703125f, -0.851563f,0.703125f, -0.859375f,0.703125f, -0.867188f,0.703125f, -0.875f,0.703125f, -0.882813f,0.703125f, -0.890625f,0.703125f, -0.898438f,0.703125f, -0.90625f,0.703125f, -0.914063f,0.703125f, -0.921875f,0.703125f, -0.929688f,0.703125f, -0.9375f,0.703125f, -0.945313f,0.703125f, -0.953125f,0.703125f, -0.960938f,0.703125f, -0.96875f,0.703125f, -0.976563f,0.703125f, -0.984375f,0.703125f, -0.992188f,0.703125f, -1.0f,0.703125f, -0.507813f,0.710938f, -0.515625f,0.710938f, -0.523438f,0.710938f, -0.53125f,0.710938f, -0.539063f,0.710938f, -0.546875f,0.710938f, -0.554688f,0.710938f, -0.5625f,0.710938f, -0.570313f,0.710938f, -0.578125f,0.710938f, -0.585938f,0.710938f, -0.59375f,0.710938f, -0.601563f,0.710938f, -0.609375f,0.710938f, -0.617188f,0.710938f, -0.625f,0.710938f, -0.632813f,0.710938f, -0.640625f,0.710938f, -0.648438f,0.710938f, -0.65625f,0.710938f, -0.664063f,0.710938f, -0.671875f,0.710938f, -0.679688f,0.710938f, -0.6875f,0.710938f, -0.695313f,0.710938f, -0.703125f,0.710938f, -0.710938f,0.710938f, -0.71875f,0.710938f, -0.726563f,0.710938f, -0.734375f,0.710938f, -0.742188f,0.710938f, -0.75f,0.710938f, -0.757813f,0.710938f, -0.765625f,0.710938f, -0.773438f,0.710938f, -0.78125f,0.710938f, -0.789063f,0.710938f, -0.796875f,0.710938f, -0.804688f,0.710938f, -0.8125f,0.710938f, -0.820313f,0.710938f, -0.828125f,0.710938f, -0.835938f,0.710938f, -0.84375f,0.710938f, -0.851563f,0.710938f, -0.859375f,0.710938f, -0.867188f,0.710938f, -0.875f,0.710938f, -0.882813f,0.710938f, -0.890625f,0.710938f, -0.898438f,0.710938f, -0.90625f,0.710938f, -0.914063f,0.710938f, -0.921875f,0.710938f, -0.929688f,0.710938f, -0.9375f,0.710938f, -0.945313f,0.710938f, -0.953125f,0.710938f, -0.960938f,0.710938f, -0.96875f,0.710938f, -0.976563f,0.710938f, -0.984375f,0.710938f, -0.992188f,0.710938f, -1.0f,0.710938f, -0.507813f,0.71875f, -0.515625f,0.71875f, -0.523438f,0.71875f, -0.53125f,0.71875f, -0.539063f,0.71875f, -0.546875f,0.71875f, -0.554688f,0.71875f, -0.5625f,0.71875f, -0.570313f,0.71875f, -0.578125f,0.71875f, -0.585938f,0.71875f, -0.59375f,0.71875f, -0.601563f,0.71875f, -0.609375f,0.71875f, -0.617188f,0.71875f, -0.625f,0.71875f, -0.632813f,0.71875f, -0.640625f,0.71875f, -0.648438f,0.71875f, -0.65625f,0.71875f, -0.664063f,0.71875f, -0.671875f,0.71875f, -0.679688f,0.71875f, -0.6875f,0.71875f, -0.695313f,0.71875f, -0.703125f,0.71875f, -0.710938f,0.71875f, -0.71875f,0.71875f, -0.726563f,0.71875f, -0.734375f,0.71875f, -0.742188f,0.71875f, -0.75f,0.71875f, -0.757813f,0.71875f, -0.765625f,0.71875f, -0.773438f,0.71875f, -0.78125f,0.71875f, -0.789063f,0.71875f, -0.796875f,0.71875f, -0.804688f,0.71875f, -0.8125f,0.71875f, -0.820313f,0.71875f, -0.828125f,0.71875f, -0.835938f,0.71875f, -0.84375f,0.71875f, -0.851563f,0.71875f, -0.859375f,0.71875f, -0.867188f,0.71875f, -0.875f,0.71875f, -0.882813f,0.71875f, -0.890625f,0.71875f, -0.898438f,0.71875f, -0.90625f,0.71875f, -0.914063f,0.71875f, -0.921875f,0.71875f, -0.929688f,0.71875f, -0.9375f,0.71875f, -0.945313f,0.71875f, -0.953125f,0.71875f, -0.960938f,0.71875f, -0.96875f,0.71875f, -0.976563f,0.71875f, -0.984375f,0.71875f, -0.992188f,0.71875f, -1.0f,0.71875f, -0.507813f,0.726563f, -0.515625f,0.726563f, -0.523438f,0.726563f, -0.53125f,0.726563f, -0.539063f,0.726563f, -0.546875f,0.726563f, -0.554688f,0.726563f, -0.5625f,0.726563f, -0.570313f,0.726563f, -0.578125f,0.726563f, -0.585938f,0.726563f, -0.59375f,0.726563f, -0.601563f,0.726563f, -0.609375f,0.726563f, -0.617188f,0.726563f, -0.625f,0.726563f, -0.632813f,0.726563f, -0.640625f,0.726563f, -0.648438f,0.726563f, -0.65625f,0.726563f, -0.664063f,0.726563f, -0.671875f,0.726563f, -0.679688f,0.726563f, -0.6875f,0.726563f, -0.695313f,0.726563f, -0.703125f,0.726563f, -0.710938f,0.726563f, -0.71875f,0.726563f, -0.726563f,0.726563f, -0.734375f,0.726563f, -0.742188f,0.726563f, -0.75f,0.726563f, -0.757813f,0.726563f, -0.765625f,0.726563f, -0.773438f,0.726563f, -0.78125f,0.726563f, -0.789063f,0.726563f, -0.796875f,0.726563f, -0.804688f,0.726563f, -0.8125f,0.726563f, -0.820313f,0.726563f, -0.828125f,0.726563f, -0.835938f,0.726563f, -0.84375f,0.726563f, -0.851563f,0.726563f, -0.859375f,0.726563f, -0.867188f,0.726563f, -0.875f,0.726563f, -0.882813f,0.726563f, -0.890625f,0.726563f, -0.898438f,0.726563f, -0.90625f,0.726563f, -0.914063f,0.726563f, -0.921875f,0.726563f, -0.929688f,0.726563f, -0.9375f,0.726563f, -0.945313f,0.726563f, -0.953125f,0.726563f, -0.960938f,0.726563f, -0.96875f,0.726563f, -0.976563f,0.726563f, -0.984375f,0.726563f, -0.992188f,0.726563f, -1.0f,0.726563f, -0.507813f,0.734375f, -0.515625f,0.734375f, -0.523438f,0.734375f, -0.53125f,0.734375f, -0.539063f,0.734375f, -0.546875f,0.734375f, -0.554688f,0.734375f, -0.5625f,0.734375f, -0.570313f,0.734375f, -0.578125f,0.734375f, -0.585938f,0.734375f, -0.59375f,0.734375f, -0.601563f,0.734375f, -0.609375f,0.734375f, -0.617188f,0.734375f, -0.625f,0.734375f, -0.632813f,0.734375f, -0.640625f,0.734375f, -0.648438f,0.734375f, -0.65625f,0.734375f, -0.664063f,0.734375f, -0.671875f,0.734375f, -0.679688f,0.734375f, -0.6875f,0.734375f, -0.695313f,0.734375f, -0.703125f,0.734375f, -0.710938f,0.734375f, -0.71875f,0.734375f, -0.726563f,0.734375f, -0.734375f,0.734375f, -0.742188f,0.734375f, -0.75f,0.734375f, -0.757813f,0.734375f, -0.765625f,0.734375f, -0.773438f,0.734375f, -0.78125f,0.734375f, -0.789063f,0.734375f, -0.796875f,0.734375f, -0.804688f,0.734375f, -0.8125f,0.734375f, -0.820313f,0.734375f, -0.828125f,0.734375f, -0.835938f,0.734375f, -0.84375f,0.734375f, -0.851563f,0.734375f, -0.859375f,0.734375f, -0.867188f,0.734375f, -0.875f,0.734375f, -0.882813f,0.734375f, -0.890625f,0.734375f, -0.898438f,0.734375f, -0.90625f,0.734375f, -0.914063f,0.734375f, -0.921875f,0.734375f, -0.929688f,0.734375f, -0.9375f,0.734375f, -0.945313f,0.734375f, -0.953125f,0.734375f, -0.960938f,0.734375f, -0.96875f,0.734375f, -0.976563f,0.734375f, -0.984375f,0.734375f, -0.992188f,0.734375f, -1.0f,0.734375f, -}; - -unsigned short Landscape03Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -128,0,129, -2,129,0, -129,2,130, -4,130,2, -130,4,131, -6,131,4, -131,6,132, -8,132,6, -132,8,133, -10,133,8, -133,10,134, -12,134,10, -134,12,135, -14,135,12, -135,14,136, -16,136,14, -136,16,137, -18,137,16, -137,18,138, -20,138,18, -138,20,139, -22,139,20, -139,22,140, -24,140,22, -140,24,141, -26,141,24, -141,26,142, -28,142,26, -142,28,143, -30,143,28, -143,30,144, -32,144,30, -144,32,145, -34,145,32, -145,34,146, -36,146,34, -146,36,147, -38,147,36, -147,38,148, -40,148,38, -148,40,149, -42,149,40, -149,42,150, -44,150,42, -150,44,151, -46,151,44, -151,46,152, -48,152,46, -152,48,153, -50,153,48, -153,50,154, -52,154,50, -154,52,155, -54,155,52, -155,54,156, -56,156,54, -156,56,157, -58,157,56, -157,58,158, -60,158,58, -158,60,159, -62,159,60, -159,62,160, -64,160,62, -160,64,161, -66,161,64, -161,66,162, -68,162,66, -162,68,163, -70,163,68, -163,70,164, -72,164,70, -164,72,165, -74,165,72, -165,74,166, -76,166,74, -166,76,167, -78,167,76, -167,78,168, -80,168,78, -168,80,169, -82,169,80, -169,82,170, -84,170,82, -170,84,171, -86,171,84, -171,86,172, -88,172,86, -172,88,173, -90,173,88, -173,90,174, -92,174,90, -174,92,175, -94,175,92, -175,94,176, -96,176,94, -176,96,177, -98,177,96, -177,98,178, -100,178,98, -178,100,179, -102,179,100, -179,102,180, -104,180,102, -180,104,181, -106,181,104, -181,106,182, -108,182,106, -182,108,183, -110,183,108, -183,110,184, -112,184,110, -184,112,185, -114,185,112, -185,114,186, -116,186,114, -186,116,187, -118,187,116, -187,118,188, -120,188,118, -188,120,189, -122,189,120, -189,122,190, -124,190,122, -190,124,191, -126,191,124, -192,128,193, -129,193,128, -193,129,194, -130,194,129, -194,130,195, -131,195,130, -195,131,196, -132,196,131, -196,132,197, -133,197,132, -197,133,198, -134,198,133, -198,134,199, -135,199,134, -199,135,200, -136,200,135, -200,136,201, -137,201,136, -201,137,202, -138,202,137, -202,138,203, -139,203,138, -203,139,204, -140,204,139, -204,140,205, -141,205,140, -205,141,206, -142,206,141, -206,142,207, -143,207,142, -207,143,208, -144,208,143, -208,144,209, -145,209,144, -209,145,210, -146,210,145, -210,146,211, -147,211,146, -211,147,212, -148,212,147, -212,148,213, -149,213,148, -213,149,214, -150,214,149, -214,150,215, -151,215,150, -215,151,216, -152,216,151, -216,152,217, -153,217,152, -217,153,218, -154,218,153, -218,154,219, -155,219,154, -219,155,220, -156,220,155, -220,156,221, -157,221,156, -221,157,222, -158,222,157, -222,158,223, -159,223,158, -223,159,224, -160,224,159, -224,160,225, -161,225,160, -225,161,226, -162,226,161, -226,162,227, -163,227,162, -227,163,228, -164,228,163, -228,164,229, -165,229,164, -229,165,230, -166,230,165, -230,166,231, -167,231,166, -231,167,232, -168,232,167, -232,168,233, -169,233,168, -233,169,234, -170,234,169, -234,170,235, -171,235,170, -235,171,236, -172,236,171, -236,172,237, -173,237,172, -237,173,238, -174,238,173, -238,174,239, -175,239,174, -239,175,240, -176,240,175, -240,176,241, -177,241,176, -241,177,242, -178,242,177, -242,178,243, -179,243,178, -243,179,244, -180,244,179, -244,180,245, -181,245,180, -245,181,246, -182,246,181, -246,182,247, -183,247,182, -247,183,248, -184,248,183, -248,184,249, -185,249,184, -249,185,250, -186,250,185, -250,186,251, -187,251,186, -251,187,252, -188,252,187, -252,188,253, -189,253,188, -253,189,254, -190,254,189, -254,190,255, -191,255,190, -256,192,257, -193,257,192, -257,193,258, -194,258,193, -258,194,259, -195,259,194, -259,195,260, -196,260,195, -260,196,261, -197,261,196, -261,197,262, -198,262,197, -262,198,263, -199,263,198, -263,199,264, -200,264,199, -264,200,265, -201,265,200, -265,201,266, -202,266,201, -266,202,267, -203,267,202, -267,203,268, -204,268,203, -268,204,269, -205,269,204, -269,205,270, -206,270,205, -270,206,271, -207,271,206, -271,207,272, -208,272,207, -272,208,273, -209,273,208, -273,209,274, -210,274,209, -274,210,275, -211,275,210, -275,211,276, -212,276,211, -276,212,277, -213,277,212, -277,213,278, -214,278,213, -278,214,279, -215,279,214, -279,215,280, -216,280,215, -280,216,281, -217,281,216, -281,217,282, -218,282,217, -282,218,283, -219,283,218, -283,219,284, -220,284,219, -284,220,285, -221,285,220, -285,221,286, -222,286,221, -286,222,287, -223,287,222, -287,223,288, -224,288,223, -288,224,289, -225,289,224, -289,225,290, -226,290,225, -290,226,291, -227,291,226, -291,227,292, -228,292,227, -292,228,293, -229,293,228, -293,229,294, -230,294,229, -294,230,295, -231,295,230, -295,231,296, -232,296,231, -296,232,297, -233,297,232, -297,233,298, -234,298,233, -298,234,299, -235,299,234, -299,235,300, -236,300,235, -300,236,301, -237,301,236, -301,237,302, -238,302,237, -302,238,303, -239,303,238, -303,239,304, -240,304,239, -304,240,305, -241,305,240, -305,241,306, -242,306,241, -306,242,307, -243,307,242, -307,243,308, -244,308,243, -308,244,309, -245,309,244, -309,245,310, -246,310,245, -310,246,311, -247,311,246, -311,247,312, -248,312,247, -312,248,313, -249,313,248, -313,249,314, -250,314,249, -314,250,315, -251,315,250, -315,251,316, -252,316,251, -316,252,317, -253,317,252, -317,253,318, -254,318,253, -318,254,319, -255,319,254, -320,256,321, -257,321,256, -321,257,322, -258,322,257, -322,258,323, -259,323,258, -323,259,324, -260,324,259, -324,260,325, -261,325,260, -325,261,326, -262,326,261, -326,262,327, -263,327,262, -327,263,328, -264,328,263, -328,264,329, -265,329,264, -329,265,330, -266,330,265, -330,266,331, -267,331,266, -331,267,332, -268,332,267, -332,268,333, -269,333,268, -333,269,334, -270,334,269, -334,270,335, -271,335,270, -335,271,336, -272,336,271, -336,272,337, -273,337,272, -337,273,338, -274,338,273, -338,274,339, -275,339,274, -339,275,340, -276,340,275, -340,276,341, -277,341,276, -341,277,342, -278,342,277, -342,278,343, -279,343,278, -343,279,344, -280,344,279, -344,280,345, -281,345,280, -345,281,346, -282,346,281, -346,282,347, -283,347,282, -347,283,348, -284,348,283, -348,284,349, -285,349,284, -349,285,350, -286,350,285, -350,286,351, -287,351,286, -351,287,352, -288,352,287, -352,288,353, -289,353,288, -353,289,354, -290,354,289, -354,290,355, -291,355,290, -355,291,356, -292,356,291, -356,292,357, -293,357,292, -357,293,358, -294,358,293, -358,294,359, -295,359,294, -359,295,360, -296,360,295, -360,296,361, -297,361,296, -361,297,362, -298,362,297, -362,298,363, -299,363,298, -363,299,364, -300,364,299, -364,300,365, -301,365,300, -365,301,366, -302,366,301, -366,302,367, -303,367,302, -367,303,368, -304,368,303, -368,304,369, -305,369,304, -369,305,370, -306,370,305, -370,306,371, -307,371,306, -371,307,372, -308,372,307, -372,308,373, -309,373,308, -373,309,374, -310,374,309, -374,310,375, -311,375,310, -375,311,376, -312,376,311, -376,312,377, -313,377,312, -377,313,378, -314,378,313, -378,314,379, -315,379,314, -379,315,380, -316,380,315, -380,316,381, -317,381,316, -381,317,382, -318,382,317, -382,318,383, -319,383,318, -384,320,385, -321,385,320, -385,321,386, -322,386,321, -386,322,387, -323,387,322, -387,323,388, -324,388,323, -388,324,389, -325,389,324, -389,325,390, -326,390,325, -390,326,391, -327,391,326, -391,327,392, -328,392,327, -392,328,393, -329,393,328, -393,329,394, -330,394,329, -394,330,395, -331,395,330, -395,331,396, -332,396,331, -396,332,397, -333,397,332, -397,333,398, -334,398,333, -398,334,399, -335,399,334, -399,335,400, -336,400,335, -400,336,401, -337,401,336, -401,337,402, -338,402,337, -402,338,403, -339,403,338, -403,339,404, -340,404,339, -404,340,405, -341,405,340, -405,341,406, -342,406,341, -406,342,407, -343,407,342, -407,343,408, -344,408,343, -408,344,409, -345,409,344, -409,345,410, -346,410,345, -410,346,411, -347,411,346, -411,347,412, -348,412,347, -412,348,413, -349,413,348, -413,349,414, -350,414,349, -414,350,415, -351,415,350, -415,351,416, -352,416,351, -416,352,417, -353,417,352, -417,353,418, -354,418,353, -418,354,419, -355,419,354, -419,355,420, -356,420,355, -420,356,421, -357,421,356, -421,357,422, -358,422,357, -422,358,423, -359,423,358, -423,359,424, -360,424,359, -424,360,425, -361,425,360, -425,361,426, -362,426,361, -426,362,427, -363,427,362, -427,363,428, -364,428,363, -428,364,429, -365,429,364, -429,365,430, -366,430,365, -430,366,431, -367,431,366, -431,367,432, -368,432,367, -432,368,433, -369,433,368, -433,369,434, -370,434,369, -434,370,435, -371,435,370, -435,371,436, -372,436,371, -436,372,437, -373,437,372, -437,373,438, -374,438,373, -438,374,439, -375,439,374, -439,375,440, -376,440,375, -440,376,441, -377,441,376, -441,377,442, -378,442,377, -442,378,443, -379,443,378, -443,379,444, -380,444,379, -444,380,445, -381,445,380, -445,381,446, -382,446,381, -446,382,447, -383,447,382, -448,384,449, -385,449,384, -449,385,450, -386,450,385, -450,386,451, -387,451,386, -451,387,452, -388,452,387, -452,388,453, -389,453,388, -453,389,454, -390,454,389, -454,390,455, -391,455,390, -455,391,456, -392,456,391, -456,392,457, -393,457,392, -457,393,458, -394,458,393, -458,394,459, -395,459,394, -459,395,460, -396,460,395, -460,396,461, -397,461,396, -461,397,462, -398,462,397, -462,398,463, -399,463,398, -463,399,464, -400,464,399, -464,400,465, -401,465,400, -465,401,466, -402,466,401, -466,402,467, -403,467,402, -467,403,468, -404,468,403, -468,404,469, -405,469,404, -469,405,470, -406,470,405, -470,406,471, -407,471,406, -471,407,472, -408,472,407, -472,408,473, -409,473,408, -473,409,474, -410,474,409, -474,410,475, -411,475,410, -475,411,476, -412,476,411, -476,412,477, -413,477,412, -477,413,478, -414,478,413, -478,414,479, -415,479,414, -479,415,480, -416,480,415, -480,416,481, -417,481,416, -481,417,482, -418,482,417, -482,418,483, -419,483,418, -483,419,484, -420,484,419, -484,420,485, -421,485,420, -485,421,486, -422,486,421, -486,422,487, -423,487,422, -487,423,488, -424,488,423, -488,424,489, -425,489,424, -489,425,490, -426,490,425, -490,426,491, -427,491,426, -491,427,492, -428,492,427, -492,428,493, -429,493,428, -493,429,494, -430,494,429, -494,430,495, -431,495,430, -495,431,496, -432,496,431, -496,432,497, -433,497,432, -497,433,498, -434,498,433, -498,434,499, -435,499,434, -499,435,500, -436,500,435, -500,436,501, -437,501,436, -501,437,502, -438,502,437, -502,438,503, -439,503,438, -503,439,504, -440,504,439, -504,440,505, -441,505,440, -505,441,506, -442,506,441, -506,442,507, -443,507,442, -507,443,508, -444,508,443, -508,444,509, -445,509,444, -509,445,510, -446,510,445, -510,446,511, -447,511,446, -512,448,513, -449,513,448, -513,449,514, -450,514,449, -514,450,515, -451,515,450, -515,451,516, -452,516,451, -516,452,517, -453,517,452, -517,453,518, -454,518,453, -518,454,519, -455,519,454, -519,455,520, -456,520,455, -520,456,521, -457,521,456, -521,457,522, -458,522,457, -522,458,523, -459,523,458, -523,459,524, -460,524,459, -524,460,525, -461,525,460, -525,461,526, -462,526,461, -526,462,527, -463,527,462, -527,463,528, -464,528,463, -528,464,529, -465,529,464, -529,465,530, -466,530,465, -530,466,531, -467,531,466, -531,467,532, -468,532,467, -532,468,533, -469,533,468, -533,469,534, -470,534,469, -534,470,535, -471,535,470, -535,471,536, -472,536,471, -536,472,537, -473,537,472, -537,473,538, -474,538,473, -538,474,539, -475,539,474, -539,475,540, -476,540,475, -540,476,541, -477,541,476, -541,477,542, -478,542,477, -542,478,543, -479,543,478, -543,479,544, -480,544,479, -544,480,545, -481,545,480, -545,481,546, -482,546,481, -546,482,547, -483,547,482, -547,483,548, -484,548,483, -548,484,549, -485,549,484, -549,485,550, -486,550,485, -550,486,551, -487,551,486, -551,487,552, -488,552,487, -552,488,553, -489,553,488, -553,489,554, -490,554,489, -554,490,555, -491,555,490, -555,491,556, -492,556,491, -556,492,557, -493,557,492, -557,493,558, -494,558,493, -558,494,559, -495,559,494, -559,495,560, -496,560,495, -560,496,561, -497,561,496, -561,497,562, -498,562,497, -562,498,563, -499,563,498, -563,499,564, -500,564,499, -564,500,565, -501,565,500, -565,501,566, -502,566,501, -566,502,567, -503,567,502, -567,503,568, -504,568,503, -568,504,569, -505,569,504, -569,505,570, -506,570,505, -570,506,571, -507,571,506, -571,507,572, -508,572,507, -572,508,573, -509,573,508, -573,509,574, -510,574,509, -574,510,575, -511,575,510, -576,512,577, -513,577,512, -577,513,578, -514,578,513, -578,514,579, -515,579,514, -579,515,580, -516,580,515, -580,516,581, -517,581,516, -581,517,582, -518,582,517, -582,518,583, -519,583,518, -583,519,584, -520,584,519, -584,520,585, -521,585,520, -585,521,586, -522,586,521, -586,522,587, -523,587,522, -587,523,588, -524,588,523, -588,524,589, -525,589,524, -589,525,590, -526,590,525, -590,526,591, -527,591,526, -591,527,592, -528,592,527, -592,528,593, -529,593,528, -593,529,594, -530,594,529, -594,530,595, -531,595,530, -595,531,596, -532,596,531, -596,532,597, -533,597,532, -597,533,598, -534,598,533, -598,534,599, -535,599,534, -599,535,600, -536,600,535, -600,536,601, -537,601,536, -601,537,602, -538,602,537, -602,538,603, -539,603,538, -603,539,604, -540,604,539, -604,540,605, -541,605,540, -605,541,606, -542,606,541, -606,542,607, -543,607,542, -607,543,608, -544,608,543, -608,544,609, -545,609,544, -609,545,610, -546,610,545, -610,546,611, -547,611,546, -611,547,612, -548,612,547, -612,548,613, -549,613,548, -613,549,614, -550,614,549, -614,550,615, -551,615,550, -615,551,616, -552,616,551, -616,552,617, -553,617,552, -617,553,618, -554,618,553, -618,554,619, -555,619,554, -619,555,620, -556,620,555, -620,556,621, -557,621,556, -621,557,622, -558,622,557, -622,558,623, -559,623,558, -623,559,624, -560,624,559, -624,560,625, -561,625,560, -625,561,626, -562,626,561, -626,562,627, -563,627,562, -627,563,628, -564,628,563, -628,564,629, -565,629,564, -629,565,630, -566,630,565, -630,566,631, -567,631,566, -631,567,632, -568,632,567, -632,568,633, -569,633,568, -633,569,634, -570,634,569, -634,570,635, -571,635,570, -635,571,636, -572,636,571, -636,572,637, -573,637,572, -637,573,638, -574,638,573, -638,574,639, -575,639,574, -640,576,641, -577,641,576, -641,577,642, -578,642,577, -642,578,643, -579,643,578, -643,579,644, -580,644,579, -644,580,645, -581,645,580, -645,581,646, -582,646,581, -646,582,647, -583,647,582, -647,583,648, -584,648,583, -648,584,649, -585,649,584, -649,585,650, -586,650,585, -650,586,651, -587,651,586, -651,587,652, -588,652,587, -652,588,653, -589,653,588, -653,589,654, -590,654,589, -654,590,655, -591,655,590, -655,591,656, -592,656,591, -656,592,657, -593,657,592, -657,593,658, -594,658,593, -658,594,659, -595,659,594, -659,595,660, -596,660,595, -660,596,661, -597,661,596, -661,597,662, -598,662,597, -662,598,663, -599,663,598, -663,599,664, -600,664,599, -664,600,665, -601,665,600, -665,601,666, -602,666,601, -666,602,667, -603,667,602, -667,603,668, -604,668,603, -668,604,669, -605,669,604, -669,605,670, -606,670,605, -670,606,671, -607,671,606, -671,607,672, -608,672,607, -672,608,673, -609,673,608, -673,609,674, -610,674,609, -674,610,675, -611,675,610, -675,611,676, -612,676,611, -676,612,677, -613,677,612, -677,613,678, -614,678,613, -678,614,679, -615,679,614, -679,615,680, -616,680,615, -680,616,681, -617,681,616, -681,617,682, -618,682,617, -682,618,683, -619,683,618, -683,619,684, -620,684,619, -684,620,685, -621,685,620, -685,621,686, -622,686,621, -686,622,687, -623,687,622, -687,623,688, -624,688,623, -688,624,689, -625,689,624, -689,625,690, -626,690,625, -690,626,691, -627,691,626, -691,627,692, -628,692,627, -692,628,693, -629,693,628, -693,629,694, -630,694,629, -694,630,695, -631,695,630, -695,631,696, -632,696,631, -696,632,697, -633,697,632, -697,633,698, -634,698,633, -698,634,699, -635,699,634, -699,635,700, -636,700,635, -700,636,701, -637,701,636, -701,637,702, -638,702,637, -702,638,703, -639,703,638, -704,640,705, -641,705,640, -705,641,706, -642,706,641, -706,642,707, -643,707,642, -707,643,708, -644,708,643, -708,644,709, -645,709,644, -709,645,710, -646,710,645, -710,646,711, -647,711,646, -711,647,712, -648,712,647, -712,648,713, -649,713,648, -713,649,714, -650,714,649, -714,650,715, -651,715,650, -715,651,716, -652,716,651, -716,652,717, -653,717,652, -717,653,718, -654,718,653, -718,654,719, -655,719,654, -719,655,720, -656,720,655, -720,656,721, -657,721,656, -721,657,722, -658,722,657, -722,658,723, -659,723,658, -723,659,724, -660,724,659, -724,660,725, -661,725,660, -725,661,726, -662,726,661, -726,662,727, -663,727,662, -727,663,728, -664,728,663, -728,664,729, -665,729,664, -729,665,730, -666,730,665, -730,666,731, -667,731,666, -731,667,732, -668,732,667, -732,668,733, -669,733,668, -733,669,734, -670,734,669, -734,670,735, -671,735,670, -735,671,736, -672,736,671, -736,672,737, -673,737,672, -737,673,738, -674,738,673, -738,674,739, -675,739,674, -739,675,740, -676,740,675, -740,676,741, -677,741,676, -741,677,742, -678,742,677, -742,678,743, -679,743,678, -743,679,744, -680,744,679, -744,680,745, -681,745,680, -745,681,746, -682,746,681, -746,682,747, -683,747,682, -747,683,748, -684,748,683, -748,684,749, -685,749,684, -749,685,750, -686,750,685, -750,686,751, -687,751,686, -751,687,752, -688,752,687, -752,688,753, -689,753,688, -753,689,754, -690,754,689, -754,690,755, -691,755,690, -755,691,756, -692,756,691, -756,692,757, -693,757,692, -757,693,758, -694,758,693, -758,694,759, -695,759,694, -759,695,760, -696,760,695, -760,696,761, -697,761,696, -761,697,762, -698,762,697, -762,698,763, -699,763,698, -763,699,764, -700,764,699, -764,700,765, -701,765,700, -765,701,766, -702,766,701, -766,702,767, -703,767,702, -768,704,769, -705,769,704, -769,705,770, -706,770,705, -770,706,771, -707,771,706, -771,707,772, -708,772,707, -772,708,773, -709,773,708, -773,709,774, -710,774,709, -774,710,775, -711,775,710, -775,711,776, -712,776,711, -776,712,777, -713,777,712, -777,713,778, -714,778,713, -778,714,779, -715,779,714, -779,715,780, -716,780,715, -780,716,781, -717,781,716, -781,717,782, -718,782,717, -782,718,783, -719,783,718, -783,719,784, -720,784,719, -784,720,785, -721,785,720, -785,721,786, -722,786,721, -786,722,787, -723,787,722, -787,723,788, -724,788,723, -788,724,789, -725,789,724, -789,725,790, -726,790,725, -790,726,791, -727,791,726, -791,727,792, -728,792,727, -792,728,793, -729,793,728, -793,729,794, -730,794,729, -794,730,795, -731,795,730, -795,731,796, -732,796,731, -796,732,797, -733,797,732, -797,733,798, -734,798,733, -798,734,799, -735,799,734, -799,735,800, -736,800,735, -800,736,801, -737,801,736, -801,737,802, -738,802,737, -802,738,803, -739,803,738, -803,739,804, -740,804,739, -804,740,805, -741,805,740, -805,741,806, -742,806,741, -806,742,807, -743,807,742, -807,743,808, -744,808,743, -808,744,809, -745,809,744, -809,745,810, -746,810,745, -810,746,811, -747,811,746, -811,747,812, -748,812,747, -812,748,813, -749,813,748, -813,749,814, -750,814,749, -814,750,815, -751,815,750, -815,751,816, -752,816,751, -816,752,817, -753,817,752, -817,753,818, -754,818,753, -818,754,819, -755,819,754, -819,755,820, -756,820,755, -820,756,821, -757,821,756, -821,757,822, -758,822,757, -822,758,823, -759,823,758, -823,759,824, -760,824,759, -824,760,825, -761,825,760, -825,761,826, -762,826,761, -826,762,827, -763,827,762, -827,763,828, -764,828,763, -828,764,829, -765,829,764, -829,765,830, -766,830,765, -830,766,831, -767,831,766, -832,768,833, -769,833,768, -833,769,834, -770,834,769, -834,770,835, -771,835,770, -835,771,836, -772,836,771, -836,772,837, -773,837,772, -837,773,838, -774,838,773, -838,774,839, -775,839,774, -839,775,840, -776,840,775, -840,776,841, -777,841,776, -841,777,842, -778,842,777, -842,778,843, -779,843,778, -843,779,844, -780,844,779, -844,780,845, -781,845,780, -845,781,846, -782,846,781, -846,782,847, -783,847,782, -847,783,848, -784,848,783, -848,784,849, -785,849,784, -849,785,850, -786,850,785, -850,786,851, -787,851,786, -851,787,852, -788,852,787, -852,788,853, -789,853,788, -853,789,854, -790,854,789, -854,790,855, -791,855,790, -855,791,856, -792,856,791, -856,792,857, -793,857,792, -857,793,858, -794,858,793, -858,794,859, -795,859,794, -859,795,860, -796,860,795, -860,796,861, -797,861,796, -861,797,862, -798,862,797, -862,798,863, -799,863,798, -863,799,864, -800,864,799, -864,800,865, -801,865,800, -865,801,866, -802,866,801, -866,802,867, -803,867,802, -867,803,868, -804,868,803, -868,804,869, -805,869,804, -869,805,870, -806,870,805, -870,806,871, -807,871,806, -871,807,872, -808,872,807, -872,808,873, -809,873,808, -873,809,874, -810,874,809, -874,810,875, -811,875,810, -875,811,876, -812,876,811, -876,812,877, -813,877,812, -877,813,878, -814,878,813, -878,814,879, -815,879,814, -879,815,880, -816,880,815, -880,816,881, -817,881,816, -881,817,882, -818,882,817, -882,818,883, -819,883,818, -883,819,884, -820,884,819, -884,820,885, -821,885,820, -885,821,886, -822,886,821, -886,822,887, -823,887,822, -887,823,888, -824,888,823, -888,824,889, -825,889,824, -889,825,890, -826,890,825, -890,826,891, -827,891,826, -891,827,892, -828,892,827, -892,828,893, -829,893,828, -893,829,894, -830,894,829, -894,830,895, -831,895,830, -896,832,897, -833,897,832, -897,833,898, -834,898,833, -898,834,899, -835,899,834, -899,835,900, -836,900,835, -900,836,901, -837,901,836, -901,837,902, -838,902,837, -902,838,903, -839,903,838, -903,839,904, -840,904,839, -904,840,905, -841,905,840, -905,841,906, -842,906,841, -906,842,907, -843,907,842, -907,843,908, -844,908,843, -908,844,909, -845,909,844, -909,845,910, -846,910,845, -910,846,911, -847,911,846, -911,847,912, -848,912,847, -912,848,913, -849,913,848, -913,849,914, -850,914,849, -914,850,915, -851,915,850, -915,851,916, -852,916,851, -916,852,917, -853,917,852, -917,853,918, -854,918,853, -918,854,919, -855,919,854, -919,855,920, -856,920,855, -920,856,921, -857,921,856, -921,857,922, -858,922,857, -922,858,923, -859,923,858, -923,859,924, -860,924,859, -924,860,925, -861,925,860, -925,861,926, -862,926,861, -926,862,927, -863,927,862, -927,863,928, -864,928,863, -928,864,929, -865,929,864, -929,865,930, -866,930,865, -930,866,931, -867,931,866, -931,867,932, -868,932,867, -932,868,933, -869,933,868, -933,869,934, -870,934,869, -934,870,935, -871,935,870, -935,871,936, -872,936,871, -936,872,937, -873,937,872, -937,873,938, -874,938,873, -938,874,939, -875,939,874, -939,875,940, -876,940,875, -940,876,941, -877,941,876, -941,877,942, -878,942,877, -942,878,943, -879,943,878, -943,879,944, -880,944,879, -944,880,945, -881,945,880, -945,881,946, -882,946,881, -946,882,947, -883,947,882, -947,883,948, -884,948,883, -948,884,949, -885,949,884, -949,885,950, -886,950,885, -950,886,951, -887,951,886, -951,887,952, -888,952,887, -952,888,953, -889,953,888, -953,889,954, -890,954,889, -954,890,955, -891,955,890, -955,891,956, -892,956,891, -956,892,957, -893,957,892, -957,893,958, -894,958,893, -958,894,959, -895,959,894, -960,896,961, -897,961,896, -961,897,962, -898,962,897, -962,898,963, -899,963,898, -963,899,964, -900,964,899, -964,900,965, -901,965,900, -965,901,966, -902,966,901, -966,902,967, -903,967,902, -967,903,968, -904,968,903, -968,904,969, -905,969,904, -969,905,970, -906,970,905, -970,906,971, -907,971,906, -971,907,972, -908,972,907, -972,908,973, -909,973,908, -973,909,974, -910,974,909, -974,910,975, -911,975,910, -975,911,976, -912,976,911, -976,912,977, -913,977,912, -977,913,978, -914,978,913, -978,914,979, -915,979,914, -979,915,980, -916,980,915, -980,916,981, -917,981,916, -981,917,982, -918,982,917, -982,918,983, -919,983,918, -983,919,984, -920,984,919, -984,920,985, -921,985,920, -985,921,986, -922,986,921, -986,922,987, -923,987,922, -987,923,988, -924,988,923, -988,924,989, -925,989,924, -989,925,990, -926,990,925, -990,926,991, -927,991,926, -991,927,992, -928,992,927, -992,928,993, -929,993,928, -993,929,994, -930,994,929, -994,930,995, -931,995,930, -995,931,996, -932,996,931, -996,932,997, -933,997,932, -997,933,998, -934,998,933, -998,934,999, -935,999,934, -999,935,1000, -936,1000,935, -1000,936,1001, -937,1001,936, -1001,937,1002, -938,1002,937, -1002,938,1003, -939,1003,938, -1003,939,1004, -940,1004,939, -1004,940,1005, -941,1005,940, -1005,941,1006, -942,1006,941, -1006,942,1007, -943,1007,942, -1007,943,1008, -944,1008,943, -1008,944,1009, -945,1009,944, -1009,945,1010, -946,1010,945, -1010,946,1011, -947,1011,946, -1011,947,1012, -948,1012,947, -1012,948,1013, -949,1013,948, -1013,949,1014, -950,1014,949, -1014,950,1015, -951,1015,950, -1015,951,1016, -952,1016,951, -1016,952,1017, -953,1017,952, -1017,953,1018, -954,1018,953, -1018,954,1019, -955,1019,954, -1019,955,1020, -956,1020,955, -1020,956,1021, -957,1021,956, -1021,957,1022, -958,1022,957, -1022,958,1023, -959,1023,958, -1024,960,1025, -961,1025,960, -1025,961,1026, -962,1026,961, -1026,962,1027, -963,1027,962, -1027,963,1028, -964,1028,963, -1028,964,1029, -965,1029,964, -1029,965,1030, -966,1030,965, -1030,966,1031, -967,1031,966, -1031,967,1032, -968,1032,967, -1032,968,1033, -969,1033,968, -1033,969,1034, -970,1034,969, -1034,970,1035, -971,1035,970, -1035,971,1036, -972,1036,971, -1036,972,1037, -973,1037,972, -1037,973,1038, -974,1038,973, -1038,974,1039, -975,1039,974, -1039,975,1040, -976,1040,975, -1040,976,1041, -977,1041,976, -1041,977,1042, -978,1042,977, -1042,978,1043, -979,1043,978, -1043,979,1044, -980,1044,979, -1044,980,1045, -981,1045,980, -1045,981,1046, -982,1046,981, -1046,982,1047, -983,1047,982, -1047,983,1048, -984,1048,983, -1048,984,1049, -985,1049,984, -1049,985,1050, -986,1050,985, -1050,986,1051, -987,1051,986, -1051,987,1052, -988,1052,987, -1052,988,1053, -989,1053,988, -1053,989,1054, -990,1054,989, -1054,990,1055, -991,1055,990, -1055,991,1056, -992,1056,991, -1056,992,1057, -993,1057,992, -1057,993,1058, -994,1058,993, -1058,994,1059, -995,1059,994, -1059,995,1060, -996,1060,995, -1060,996,1061, -997,1061,996, -1061,997,1062, -998,1062,997, -1062,998,1063, -999,1063,998, -1063,999,1064, -1000,1064,999, -1064,1000,1065, -1001,1065,1000, -1065,1001,1066, -1002,1066,1001, -1066,1002,1067, -1003,1067,1002, -1067,1003,1068, -1004,1068,1003, -1068,1004,1069, -1005,1069,1004, -1069,1005,1070, -1006,1070,1005, -1070,1006,1071, -1007,1071,1006, -1071,1007,1072, -1008,1072,1007, -1072,1008,1073, -1009,1073,1008, -1073,1009,1074, -1010,1074,1009, -1074,1010,1075, -1011,1075,1010, -1075,1011,1076, -1012,1076,1011, -1076,1012,1077, -1013,1077,1012, -1077,1013,1078, -1014,1078,1013, -1078,1014,1079, -1015,1079,1014, -1079,1015,1080, -1016,1080,1015, -1080,1016,1081, -1017,1081,1016, -1081,1017,1082, -1018,1082,1017, -1082,1018,1083, -1019,1083,1018, -1083,1019,1084, -1020,1084,1019, -1084,1020,1085, -1021,1085,1020, -1085,1021,1086, -1022,1086,1021, -1086,1022,1087, -1023,1087,1022, -1088,1024,1089, -1025,1089,1024, -1089,1025,1090, -1026,1090,1025, -1090,1026,1091, -1027,1091,1026, -1091,1027,1092, -1028,1092,1027, -1092,1028,1093, -1029,1093,1028, -1093,1029,1094, -1030,1094,1029, -1094,1030,1095, -1031,1095,1030, -1095,1031,1096, -1032,1096,1031, -1096,1032,1097, -1033,1097,1032, -1097,1033,1098, -1034,1098,1033, -1098,1034,1099, -1035,1099,1034, -1099,1035,1100, -1036,1100,1035, -1100,1036,1101, -1037,1101,1036, -1101,1037,1102, -1038,1102,1037, -1102,1038,1103, -1039,1103,1038, -1103,1039,1104, -1040,1104,1039, -1104,1040,1105, -1041,1105,1040, -1105,1041,1106, -1042,1106,1041, -1106,1042,1107, -1043,1107,1042, -1107,1043,1108, -1044,1108,1043, -1108,1044,1109, -1045,1109,1044, -1109,1045,1110, -1046,1110,1045, -1110,1046,1111, -1047,1111,1046, -1111,1047,1112, -1048,1112,1047, -1112,1048,1113, -1049,1113,1048, -1113,1049,1114, -1050,1114,1049, -1114,1050,1115, -1051,1115,1050, -1115,1051,1116, -1052,1116,1051, -1116,1052,1117, -1053,1117,1052, -1117,1053,1118, -1054,1118,1053, -1118,1054,1119, -1055,1119,1054, -1119,1055,1120, -1056,1120,1055, -1120,1056,1121, -1057,1121,1056, -1121,1057,1122, -1058,1122,1057, -1122,1058,1123, -1059,1123,1058, -1123,1059,1124, -1060,1124,1059, -1124,1060,1125, -1061,1125,1060, -1125,1061,1126, -1062,1126,1061, -1126,1062,1127, -1063,1127,1062, -1127,1063,1128, -1064,1128,1063, -1128,1064,1129, -1065,1129,1064, -1129,1065,1130, -1066,1130,1065, -1130,1066,1131, -1067,1131,1066, -1131,1067,1132, -1068,1132,1067, -1132,1068,1133, -1069,1133,1068, -1133,1069,1134, -1070,1134,1069, -1134,1070,1135, -1071,1135,1070, -1135,1071,1136, -1072,1136,1071, -1136,1072,1137, -1073,1137,1072, -1137,1073,1138, -1074,1138,1073, -1138,1074,1139, -1075,1139,1074, -1139,1075,1140, -1076,1140,1075, -1140,1076,1141, -1077,1141,1076, -1141,1077,1142, -1078,1142,1077, -1142,1078,1143, -1079,1143,1078, -1143,1079,1144, -1080,1144,1079, -1144,1080,1145, -1081,1145,1080, -1145,1081,1146, -1082,1146,1081, -1146,1082,1147, -1083,1147,1082, -1147,1083,1148, -1084,1148,1083, -1148,1084,1149, -1085,1149,1084, -1149,1085,1150, -1086,1150,1085, -1150,1086,1151, -1087,1151,1086, -1152,1088,1153, -1089,1153,1088, -1153,1089,1154, -1090,1154,1089, -1154,1090,1155, -1091,1155,1090, -1155,1091,1156, -1092,1156,1091, -1156,1092,1157, -1093,1157,1092, -1157,1093,1158, -1094,1158,1093, -1158,1094,1159, -1095,1159,1094, -1159,1095,1160, -1096,1160,1095, -1160,1096,1161, -1097,1161,1096, -1161,1097,1162, -1098,1162,1097, -1162,1098,1163, -1099,1163,1098, -1163,1099,1164, -1100,1164,1099, -1164,1100,1165, -1101,1165,1100, -1165,1101,1166, -1102,1166,1101, -1166,1102,1167, -1103,1167,1102, -1167,1103,1168, -1104,1168,1103, -1168,1104,1169, -1105,1169,1104, -1169,1105,1170, -1106,1170,1105, -1170,1106,1171, -1107,1171,1106, -1171,1107,1172, -1108,1172,1107, -1172,1108,1173, -1109,1173,1108, -1173,1109,1174, -1110,1174,1109, -1174,1110,1175, -1111,1175,1110, -1175,1111,1176, -1112,1176,1111, -1176,1112,1177, -1113,1177,1112, -1177,1113,1178, -1114,1178,1113, -1178,1114,1179, -1115,1179,1114, -1179,1115,1180, -1116,1180,1115, -1180,1116,1181, -1117,1181,1116, -1181,1117,1182, -1118,1182,1117, -1182,1118,1183, -1119,1183,1118, -1183,1119,1184, -1120,1184,1119, -1184,1120,1185, -1121,1185,1120, -1185,1121,1186, -1122,1186,1121, -1186,1122,1187, -1123,1187,1122, -1187,1123,1188, -1124,1188,1123, -1188,1124,1189, -1125,1189,1124, -1189,1125,1190, -1126,1190,1125, -1190,1126,1191, -1127,1191,1126, -1191,1127,1192, -1128,1192,1127, -1192,1128,1193, -1129,1193,1128, -1193,1129,1194, -1130,1194,1129, -1194,1130,1195, -1131,1195,1130, -1195,1131,1196, -1132,1196,1131, -1196,1132,1197, -1133,1197,1132, -1197,1133,1198, -1134,1198,1133, -1198,1134,1199, -1135,1199,1134, -1199,1135,1200, -1136,1200,1135, -1200,1136,1201, -1137,1201,1136, -1201,1137,1202, -1138,1202,1137, -1202,1138,1203, -1139,1203,1138, -1203,1139,1204, -1140,1204,1139, -1204,1140,1205, -1141,1205,1140, -1205,1141,1206, -1142,1206,1141, -1206,1142,1207, -1143,1207,1142, -1207,1143,1208, -1144,1208,1143, -1208,1144,1209, -1145,1209,1144, -1209,1145,1210, -1146,1210,1145, -1210,1146,1211, -1147,1211,1146, -1211,1147,1212, -1148,1212,1147, -1212,1148,1213, -1149,1213,1148, -1213,1149,1214, -1150,1214,1149, -1214,1150,1215, -1151,1215,1150, -1216,1152,1217, -1153,1217,1152, -1217,1153,1218, -1154,1218,1153, -1218,1154,1219, -1155,1219,1154, -1219,1155,1220, -1156,1220,1155, -1220,1156,1221, -1157,1221,1156, -1221,1157,1222, -1158,1222,1157, -1222,1158,1223, -1159,1223,1158, -1223,1159,1224, -1160,1224,1159, -1224,1160,1225, -1161,1225,1160, -1225,1161,1226, -1162,1226,1161, -1226,1162,1227, -1163,1227,1162, -1227,1163,1228, -1164,1228,1163, -1228,1164,1229, -1165,1229,1164, -1229,1165,1230, -1166,1230,1165, -1230,1166,1231, -1167,1231,1166, -1231,1167,1232, -1168,1232,1167, -1232,1168,1233, -1169,1233,1168, -1233,1169,1234, -1170,1234,1169, -1234,1170,1235, -1171,1235,1170, -1235,1171,1236, -1172,1236,1171, -1236,1172,1237, -1173,1237,1172, -1237,1173,1238, -1174,1238,1173, -1238,1174,1239, -1175,1239,1174, -1239,1175,1240, -1176,1240,1175, -1240,1176,1241, -1177,1241,1176, -1241,1177,1242, -1178,1242,1177, -1242,1178,1243, -1179,1243,1178, -1243,1179,1244, -1180,1244,1179, -1244,1180,1245, -1181,1245,1180, -1245,1181,1246, -1182,1246,1181, -1246,1182,1247, -1183,1247,1182, -1247,1183,1248, -1184,1248,1183, -1248,1184,1249, -1185,1249,1184, -1249,1185,1250, -1186,1250,1185, -1250,1186,1251, -1187,1251,1186, -1251,1187,1252, -1188,1252,1187, -1252,1188,1253, -1189,1253,1188, -1253,1189,1254, -1190,1254,1189, -1254,1190,1255, -1191,1255,1190, -1255,1191,1256, -1192,1256,1191, -1256,1192,1257, -1193,1257,1192, -1257,1193,1258, -1194,1258,1193, -1258,1194,1259, -1195,1259,1194, -1259,1195,1260, -1196,1260,1195, -1260,1196,1261, -1197,1261,1196, -1261,1197,1262, -1198,1262,1197, -1262,1198,1263, -1199,1263,1198, -1263,1199,1264, -1200,1264,1199, -1264,1200,1265, -1201,1265,1200, -1265,1201,1266, -1202,1266,1201, -1266,1202,1267, -1203,1267,1202, -1267,1203,1268, -1204,1268,1203, -1268,1204,1269, -1205,1269,1204, -1269,1205,1270, -1206,1270,1205, -1270,1206,1271, -1207,1271,1206, -1271,1207,1272, -1208,1272,1207, -1272,1208,1273, -1209,1273,1208, -1273,1209,1274, -1210,1274,1209, -1274,1210,1275, -1211,1275,1210, -1275,1211,1276, -1212,1276,1211, -1276,1212,1277, -1213,1277,1212, -1277,1213,1278, -1214,1278,1213, -1278,1214,1279, -1215,1279,1214, -1280,1216,1281, -1217,1281,1216, -1281,1217,1282, -1218,1282,1217, -1282,1218,1283, -1219,1283,1218, -1283,1219,1284, -1220,1284,1219, -1284,1220,1285, -1221,1285,1220, -1285,1221,1286, -1222,1286,1221, -1286,1222,1287, -1223,1287,1222, -1287,1223,1288, -1224,1288,1223, -1288,1224,1289, -1225,1289,1224, -1289,1225,1290, -1226,1290,1225, -1290,1226,1291, -1227,1291,1226, -1291,1227,1292, -1228,1292,1227, -1292,1228,1293, -1229,1293,1228, -1293,1229,1294, -1230,1294,1229, -1294,1230,1295, -1231,1295,1230, -1295,1231,1296, -1232,1296,1231, -1296,1232,1297, -1233,1297,1232, -1297,1233,1298, -1234,1298,1233, -1298,1234,1299, -1235,1299,1234, -1299,1235,1300, -1236,1300,1235, -1300,1236,1301, -1237,1301,1236, -1301,1237,1302, -1238,1302,1237, -1302,1238,1303, -1239,1303,1238, -1303,1239,1304, -1240,1304,1239, -1304,1240,1305, -1241,1305,1240, -1305,1241,1306, -1242,1306,1241, -1306,1242,1307, -1243,1307,1242, -1307,1243,1308, -1244,1308,1243, -1308,1244,1309, -1245,1309,1244, -1309,1245,1310, -1246,1310,1245, -1310,1246,1311, -1247,1311,1246, -1311,1247,1312, -1248,1312,1247, -1312,1248,1313, -1249,1313,1248, -1313,1249,1314, -1250,1314,1249, -1314,1250,1315, -1251,1315,1250, -1315,1251,1316, -1252,1316,1251, -1316,1252,1317, -1253,1317,1252, -1317,1253,1318, -1254,1318,1253, -1318,1254,1319, -1255,1319,1254, -1319,1255,1320, -1256,1320,1255, -1320,1256,1321, -1257,1321,1256, -1321,1257,1322, -1258,1322,1257, -1322,1258,1323, -1259,1323,1258, -1323,1259,1324, -1260,1324,1259, -1324,1260,1325, -1261,1325,1260, -1325,1261,1326, -1262,1326,1261, -1326,1262,1327, -1263,1327,1262, -1327,1263,1328, -1264,1328,1263, -1328,1264,1329, -1265,1329,1264, -1329,1265,1330, -1266,1330,1265, -1330,1266,1331, -1267,1331,1266, -1331,1267,1332, -1268,1332,1267, -1332,1268,1333, -1269,1333,1268, -1333,1269,1334, -1270,1334,1269, -1334,1270,1335, -1271,1335,1270, -1335,1271,1336, -1272,1336,1271, -1336,1272,1337, -1273,1337,1272, -1337,1273,1338, -1274,1338,1273, -1338,1274,1339, -1275,1339,1274, -1339,1275,1340, -1276,1340,1275, -1340,1276,1341, -1277,1341,1276, -1341,1277,1342, -1278,1342,1277, -1342,1278,1343, -1279,1343,1278, -1344,1280,1345, -1281,1345,1280, -1345,1281,1346, -1282,1346,1281, -1346,1282,1347, -1283,1347,1282, -1347,1283,1348, -1284,1348,1283, -1348,1284,1349, -1285,1349,1284, -1349,1285,1350, -1286,1350,1285, -1350,1286,1351, -1287,1351,1286, -1351,1287,1352, -1288,1352,1287, -1352,1288,1353, -1289,1353,1288, -1353,1289,1354, -1290,1354,1289, -1354,1290,1355, -1291,1355,1290, -1355,1291,1356, -1292,1356,1291, -1356,1292,1357, -1293,1357,1292, -1357,1293,1358, -1294,1358,1293, -1358,1294,1359, -1295,1359,1294, -1359,1295,1360, -1296,1360,1295, -1360,1296,1361, -1297,1361,1296, -1361,1297,1362, -1298,1362,1297, -1362,1298,1363, -1299,1363,1298, -1363,1299,1364, -1300,1364,1299, -1364,1300,1365, -1301,1365,1300, -1365,1301,1366, -1302,1366,1301, -1366,1302,1367, -1303,1367,1302, -1367,1303,1368, -1304,1368,1303, -1368,1304,1369, -1305,1369,1304, -1369,1305,1370, -1306,1370,1305, -1370,1306,1371, -1307,1371,1306, -1371,1307,1372, -1308,1372,1307, -1372,1308,1373, -1309,1373,1308, -1373,1309,1374, -1310,1374,1309, -1374,1310,1375, -1311,1375,1310, -1375,1311,1376, -1312,1376,1311, -1376,1312,1377, -1313,1377,1312, -1377,1313,1378, -1314,1378,1313, -1378,1314,1379, -1315,1379,1314, -1379,1315,1380, -1316,1380,1315, -1380,1316,1381, -1317,1381,1316, -1381,1317,1382, -1318,1382,1317, -1382,1318,1383, -1319,1383,1318, -1383,1319,1384, -1320,1384,1319, -1384,1320,1385, -1321,1385,1320, -1385,1321,1386, -1322,1386,1321, -1386,1322,1387, -1323,1387,1322, -1387,1323,1388, -1324,1388,1323, -1388,1324,1389, -1325,1389,1324, -1389,1325,1390, -1326,1390,1325, -1390,1326,1391, -1327,1391,1326, -1391,1327,1392, -1328,1392,1327, -1392,1328,1393, -1329,1393,1328, -1393,1329,1394, -1330,1394,1329, -1394,1330,1395, -1331,1395,1330, -1395,1331,1396, -1332,1396,1331, -1396,1332,1397, -1333,1397,1332, -1397,1333,1398, -1334,1398,1333, -1398,1334,1399, -1335,1399,1334, -1399,1335,1400, -1336,1400,1335, -1400,1336,1401, -1337,1401,1336, -1401,1337,1402, -1338,1402,1337, -1402,1338,1403, -1339,1403,1338, -1403,1339,1404, -1340,1404,1339, -1404,1340,1405, -1341,1405,1340, -1405,1341,1406, -1342,1406,1341, -1406,1342,1407, -1343,1407,1342, -1408,1344,1409, -1345,1409,1344, -1409,1345,1410, -1346,1410,1345, -1410,1346,1411, -1347,1411,1346, -1411,1347,1412, -1348,1412,1347, -1412,1348,1413, -1349,1413,1348, -1413,1349,1414, -1350,1414,1349, -1414,1350,1415, -1351,1415,1350, -1415,1351,1416, -1352,1416,1351, -1416,1352,1417, -1353,1417,1352, -1417,1353,1418, -1354,1418,1353, -1418,1354,1419, -1355,1419,1354, -1419,1355,1420, -1356,1420,1355, -1420,1356,1421, -1357,1421,1356, -1421,1357,1422, -1358,1422,1357, -1422,1358,1423, -1359,1423,1358, -1423,1359,1424, -1360,1424,1359, -1424,1360,1425, -1361,1425,1360, -1425,1361,1426, -1362,1426,1361, -1426,1362,1427, -1363,1427,1362, -1427,1363,1428, -1364,1428,1363, -1428,1364,1429, -1365,1429,1364, -1429,1365,1430, -1366,1430,1365, -1430,1366,1431, -1367,1431,1366, -1431,1367,1432, -1368,1432,1367, -1432,1368,1433, -1369,1433,1368, -1433,1369,1434, -1370,1434,1369, -1434,1370,1435, -1371,1435,1370, -1435,1371,1436, -1372,1436,1371, -1436,1372,1437, -1373,1437,1372, -1437,1373,1438, -1374,1438,1373, -1438,1374,1439, -1375,1439,1374, -1439,1375,1440, -1376,1440,1375, -1440,1376,1441, -1377,1441,1376, -1441,1377,1442, -1378,1442,1377, -1442,1378,1443, -1379,1443,1378, -1443,1379,1444, -1380,1444,1379, -1444,1380,1445, -1381,1445,1380, -1445,1381,1446, -1382,1446,1381, -1446,1382,1447, -1383,1447,1382, -1447,1383,1448, -1384,1448,1383, -1448,1384,1449, -1385,1449,1384, -1449,1385,1450, -1386,1450,1385, -1450,1386,1451, -1387,1451,1386, -1451,1387,1452, -1388,1452,1387, -1452,1388,1453, -1389,1453,1388, -1453,1389,1454, -1390,1454,1389, -1454,1390,1455, -1391,1455,1390, -1455,1391,1456, -1392,1456,1391, -1456,1392,1457, -1393,1457,1392, -1457,1393,1458, -1394,1458,1393, -1458,1394,1459, -1395,1459,1394, -1459,1395,1460, -1396,1460,1395, -1460,1396,1461, -1397,1461,1396, -1461,1397,1462, -1398,1462,1397, -1462,1398,1463, -1399,1463,1398, -1463,1399,1464, -1400,1464,1399, -1464,1400,1465, -1401,1465,1400, -1465,1401,1466, -1402,1466,1401, -1466,1402,1467, -1403,1467,1402, -1467,1403,1468, -1404,1468,1403, -1468,1404,1469, -1405,1469,1404, -1469,1405,1470, -1406,1470,1405, -1470,1406,1471, -1407,1471,1406, -1472,1408,1473, -1409,1473,1408, -1473,1409,1474, -1410,1474,1409, -1474,1410,1475, -1411,1475,1410, -1475,1411,1476, -1412,1476,1411, -1476,1412,1477, -1413,1477,1412, -1477,1413,1478, -1414,1478,1413, -1478,1414,1479, -1415,1479,1414, -1479,1415,1480, -1416,1480,1415, -1480,1416,1481, -1417,1481,1416, -1481,1417,1482, -1418,1482,1417, -1482,1418,1483, -1419,1483,1418, -1483,1419,1484, -1420,1484,1419, -1484,1420,1485, -1421,1485,1420, -1485,1421,1486, -1422,1486,1421, -1486,1422,1487, -1423,1487,1422, -1487,1423,1488, -1424,1488,1423, -1488,1424,1489, -1425,1489,1424, -1489,1425,1490, -1426,1490,1425, -1490,1426,1491, -1427,1491,1426, -1491,1427,1492, -1428,1492,1427, -1492,1428,1493, -1429,1493,1428, -1493,1429,1494, -1430,1494,1429, -1494,1430,1495, -1431,1495,1430, -1495,1431,1496, -1432,1496,1431, -1496,1432,1497, -1433,1497,1432, -1497,1433,1498, -1434,1498,1433, -1498,1434,1499, -1435,1499,1434, -1499,1435,1500, -1436,1500,1435, -1500,1436,1501, -1437,1501,1436, -1501,1437,1502, -1438,1502,1437, -1502,1438,1503, -1439,1503,1438, -1503,1439,1504, -1440,1504,1439, -1504,1440,1505, -1441,1505,1440, -1505,1441,1506, -1442,1506,1441, -1506,1442,1507, -1443,1507,1442, -1507,1443,1508, -1444,1508,1443, -1508,1444,1509, -1445,1509,1444, -1509,1445,1510, -1446,1510,1445, -1510,1446,1511, -1447,1511,1446, -1511,1447,1512, -1448,1512,1447, -1512,1448,1513, -1449,1513,1448, -1513,1449,1514, -1450,1514,1449, -1514,1450,1515, -1451,1515,1450, -1515,1451,1516, -1452,1516,1451, -1516,1452,1517, -1453,1517,1452, -1517,1453,1518, -1454,1518,1453, -1518,1454,1519, -1455,1519,1454, -1519,1455,1520, -1456,1520,1455, -1520,1456,1521, -1457,1521,1456, -1521,1457,1522, -1458,1522,1457, -1522,1458,1523, -1459,1523,1458, -1523,1459,1524, -1460,1524,1459, -1524,1460,1525, -1461,1525,1460, -1525,1461,1526, -1462,1526,1461, -1526,1462,1527, -1463,1527,1462, -1527,1463,1528, -1464,1528,1463, -1528,1464,1529, -1465,1529,1464, -1529,1465,1530, -1466,1530,1465, -1530,1466,1531, -1467,1531,1466, -1531,1467,1532, -1468,1532,1467, -1532,1468,1533, -1469,1533,1468, -1533,1469,1534, -1470,1534,1469, -1534,1470,1535, -1471,1535,1470, -1536,1472,1537, -1473,1537,1472, -1537,1473,1538, -1474,1538,1473, -1538,1474,1539, -1475,1539,1474, -1539,1475,1540, -1476,1540,1475, -1540,1476,1541, -1477,1541,1476, -1541,1477,1542, -1478,1542,1477, -1542,1478,1543, -1479,1543,1478, -1543,1479,1544, -1480,1544,1479, -1544,1480,1545, -1481,1545,1480, -1545,1481,1546, -1482,1546,1481, -1546,1482,1547, -1483,1547,1482, -1547,1483,1548, -1484,1548,1483, -1548,1484,1549, -1485,1549,1484, -1549,1485,1550, -1486,1550,1485, -1550,1486,1551, -1487,1551,1486, -1551,1487,1552, -1488,1552,1487, -1552,1488,1553, -1489,1553,1488, -1553,1489,1554, -1490,1554,1489, -1554,1490,1555, -1491,1555,1490, -1555,1491,1556, -1492,1556,1491, -1556,1492,1557, -1493,1557,1492, -1557,1493,1558, -1494,1558,1493, -1558,1494,1559, -1495,1559,1494, -1559,1495,1560, -1496,1560,1495, -1560,1496,1561, -1497,1561,1496, -1561,1497,1562, -1498,1562,1497, -1562,1498,1563, -1499,1563,1498, -1563,1499,1564, -1500,1564,1499, -1564,1500,1565, -1501,1565,1500, -1565,1501,1566, -1502,1566,1501, -1566,1502,1567, -1503,1567,1502, -1567,1503,1568, -1504,1568,1503, -1568,1504,1569, -1505,1569,1504, -1569,1505,1570, -1506,1570,1505, -1570,1506,1571, -1507,1571,1506, -1571,1507,1572, -1508,1572,1507, -1572,1508,1573, -1509,1573,1508, -1573,1509,1574, -1510,1574,1509, -1574,1510,1575, -1511,1575,1510, -1575,1511,1576, -1512,1576,1511, -1576,1512,1577, -1513,1577,1512, -1577,1513,1578, -1514,1578,1513, -1578,1514,1579, -1515,1579,1514, -1579,1515,1580, -1516,1580,1515, -1580,1516,1581, -1517,1581,1516, -1581,1517,1582, -1518,1582,1517, -1582,1518,1583, -1519,1583,1518, -1583,1519,1584, -1520,1584,1519, -1584,1520,1585, -1521,1585,1520, -1585,1521,1586, -1522,1586,1521, -1586,1522,1587, -1523,1587,1522, -1587,1523,1588, -1524,1588,1523, -1588,1524,1589, -1525,1589,1524, -1589,1525,1590, -1526,1590,1525, -1590,1526,1591, -1527,1591,1526, -1591,1527,1592, -1528,1592,1527, -1592,1528,1593, -1529,1593,1528, -1593,1529,1594, -1530,1594,1529, -1594,1530,1595, -1531,1595,1530, -1595,1531,1596, -1532,1596,1531, -1596,1532,1597, -1533,1597,1532, -1597,1533,1598, -1534,1598,1533, -1598,1534,1599, -1535,1599,1534, -1600,1536,1601, -1537,1601,1536, -1601,1537,1602, -1538,1602,1537, -1602,1538,1603, -1539,1603,1538, -1603,1539,1604, -1540,1604,1539, -1604,1540,1605, -1541,1605,1540, -1605,1541,1606, -1542,1606,1541, -1606,1542,1607, -1543,1607,1542, -1607,1543,1608, -1544,1608,1543, -1608,1544,1609, -1545,1609,1544, -1609,1545,1610, -1546,1610,1545, -1610,1546,1611, -1547,1611,1546, -1611,1547,1612, -1548,1612,1547, -1612,1548,1613, -1549,1613,1548, -1613,1549,1614, -1550,1614,1549, -1614,1550,1615, -1551,1615,1550, -1615,1551,1616, -1552,1616,1551, -1616,1552,1617, -1553,1617,1552, -1617,1553,1618, -1554,1618,1553, -1618,1554,1619, -1555,1619,1554, -1619,1555,1620, -1556,1620,1555, -1620,1556,1621, -1557,1621,1556, -1621,1557,1622, -1558,1622,1557, -1622,1558,1623, -1559,1623,1558, -1623,1559,1624, -1560,1624,1559, -1624,1560,1625, -1561,1625,1560, -1625,1561,1626, -1562,1626,1561, -1626,1562,1627, -1563,1627,1562, -1627,1563,1628, -1564,1628,1563, -1628,1564,1629, -1565,1629,1564, -1629,1565,1630, -1566,1630,1565, -1630,1566,1631, -1567,1631,1566, -1631,1567,1632, -1568,1632,1567, -1632,1568,1633, -1569,1633,1568, -1633,1569,1634, -1570,1634,1569, -1634,1570,1635, -1571,1635,1570, -1635,1571,1636, -1572,1636,1571, -1636,1572,1637, -1573,1637,1572, -1637,1573,1638, -1574,1638,1573, -1638,1574,1639, -1575,1639,1574, -1639,1575,1640, -1576,1640,1575, -1640,1576,1641, -1577,1641,1576, -1641,1577,1642, -1578,1642,1577, -1642,1578,1643, -1579,1643,1578, -1643,1579,1644, -1580,1644,1579, -1644,1580,1645, -1581,1645,1580, -1645,1581,1646, -1582,1646,1581, -1646,1582,1647, -1583,1647,1582, -1647,1583,1648, -1584,1648,1583, -1648,1584,1649, -1585,1649,1584, -1649,1585,1650, -1586,1650,1585, -1650,1586,1651, -1587,1651,1586, -1651,1587,1652, -1588,1652,1587, -1652,1588,1653, -1589,1653,1588, -1653,1589,1654, -1590,1654,1589, -1654,1590,1655, -1591,1655,1590, -1655,1591,1656, -1592,1656,1591, -1656,1592,1657, -1593,1657,1592, -1657,1593,1658, -1594,1658,1593, -1658,1594,1659, -1595,1659,1594, -1659,1595,1660, -1596,1660,1595, -1660,1596,1661, -1597,1661,1596, -1661,1597,1662, -1598,1662,1597, -1662,1598,1663, -1599,1663,1598, -1664,1600,1665, -1601,1665,1600, -1665,1601,1666, -1602,1666,1601, -1666,1602,1667, -1603,1667,1602, -1667,1603,1668, -1604,1668,1603, -1668,1604,1669, -1605,1669,1604, -1669,1605,1670, -1606,1670,1605, -1670,1606,1671, -1607,1671,1606, -1671,1607,1672, -1608,1672,1607, -1672,1608,1673, -1609,1673,1608, -1673,1609,1674, -1610,1674,1609, -1674,1610,1675, -1611,1675,1610, -1675,1611,1676, -1612,1676,1611, -1676,1612,1677, -1613,1677,1612, -1677,1613,1678, -1614,1678,1613, -1678,1614,1679, -1615,1679,1614, -1679,1615,1680, -1616,1680,1615, -1680,1616,1681, -1617,1681,1616, -1681,1617,1682, -1618,1682,1617, -1682,1618,1683, -1619,1683,1618, -1683,1619,1684, -1620,1684,1619, -1684,1620,1685, -1621,1685,1620, -1685,1621,1686, -1622,1686,1621, -1686,1622,1687, -1623,1687,1622, -1687,1623,1688, -1624,1688,1623, -1688,1624,1689, -1625,1689,1624, -1689,1625,1690, -1626,1690,1625, -1690,1626,1691, -1627,1691,1626, -1691,1627,1692, -1628,1692,1627, -1692,1628,1693, -1629,1693,1628, -1693,1629,1694, -1630,1694,1629, -1694,1630,1695, -1631,1695,1630, -1695,1631,1696, -1632,1696,1631, -1696,1632,1697, -1633,1697,1632, -1697,1633,1698, -1634,1698,1633, -1698,1634,1699, -1635,1699,1634, -1699,1635,1700, -1636,1700,1635, -1700,1636,1701, -1637,1701,1636, -1701,1637,1702, -1638,1702,1637, -1702,1638,1703, -1639,1703,1638, -1703,1639,1704, -1640,1704,1639, -1704,1640,1705, -1641,1705,1640, -1705,1641,1706, -1642,1706,1641, -1706,1642,1707, -1643,1707,1642, -1707,1643,1708, -1644,1708,1643, -1708,1644,1709, -1645,1709,1644, -1709,1645,1710, -1646,1710,1645, -1710,1646,1711, -1647,1711,1646, -1711,1647,1712, -1648,1712,1647, -1712,1648,1713, -1649,1713,1648, -1713,1649,1714, -1650,1714,1649, -1714,1650,1715, -1651,1715,1650, -1715,1651,1716, -1652,1716,1651, -1716,1652,1717, -1653,1717,1652, -1717,1653,1718, -1654,1718,1653, -1718,1654,1719, -1655,1719,1654, -1719,1655,1720, -1656,1720,1655, -1720,1656,1721, -1657,1721,1656, -1721,1657,1722, -1658,1722,1657, -1722,1658,1723, -1659,1723,1658, -1723,1659,1724, -1660,1724,1659, -1724,1660,1725, -1661,1725,1660, -1725,1661,1726, -1662,1726,1661, -1726,1662,1727, -1663,1727,1662, -1728,1664,1729, -1665,1729,1664, -1729,1665,1730, -1666,1730,1665, -1730,1666,1731, -1667,1731,1666, -1731,1667,1732, -1668,1732,1667, -1732,1668,1733, -1669,1733,1668, -1733,1669,1734, -1670,1734,1669, -1734,1670,1735, -1671,1735,1670, -1735,1671,1736, -1672,1736,1671, -1736,1672,1737, -1673,1737,1672, -1737,1673,1738, -1674,1738,1673, -1738,1674,1739, -1675,1739,1674, -1739,1675,1740, -1676,1740,1675, -1740,1676,1741, -1677,1741,1676, -1741,1677,1742, -1678,1742,1677, -1742,1678,1743, -1679,1743,1678, -1743,1679,1744, -1680,1744,1679, -1744,1680,1745, -1681,1745,1680, -1745,1681,1746, -1682,1746,1681, -1746,1682,1747, -1683,1747,1682, -1747,1683,1748, -1684,1748,1683, -1748,1684,1749, -1685,1749,1684, -1749,1685,1750, -1686,1750,1685, -1750,1686,1751, -1687,1751,1686, -1751,1687,1752, -1688,1752,1687, -1752,1688,1753, -1689,1753,1688, -1753,1689,1754, -1690,1754,1689, -1754,1690,1755, -1691,1755,1690, -1755,1691,1756, -1692,1756,1691, -1756,1692,1757, -1693,1757,1692, -1757,1693,1758, -1694,1758,1693, -1758,1694,1759, -1695,1759,1694, -1759,1695,1760, -1696,1760,1695, -1760,1696,1761, -1697,1761,1696, -1761,1697,1762, -1698,1762,1697, -1762,1698,1763, -1699,1763,1698, -1763,1699,1764, -1700,1764,1699, -1764,1700,1765, -1701,1765,1700, -1765,1701,1766, -1702,1766,1701, -1766,1702,1767, -1703,1767,1702, -1767,1703,1768, -1704,1768,1703, -1768,1704,1769, -1705,1769,1704, -1769,1705,1770, -1706,1770,1705, -1770,1706,1771, -1707,1771,1706, -1771,1707,1772, -1708,1772,1707, -1772,1708,1773, -1709,1773,1708, -1773,1709,1774, -1710,1774,1709, -1774,1710,1775, -1711,1775,1710, -1775,1711,1776, -1712,1776,1711, -1776,1712,1777, -1713,1777,1712, -1777,1713,1778, -1714,1778,1713, -1778,1714,1779, -1715,1779,1714, -1779,1715,1780, -1716,1780,1715, -1780,1716,1781, -1717,1781,1716, -1781,1717,1782, -1718,1782,1717, -1782,1718,1783, -1719,1783,1718, -1783,1719,1784, -1720,1784,1719, -1784,1720,1785, -1721,1785,1720, -1785,1721,1786, -1722,1786,1721, -1786,1722,1787, -1723,1787,1722, -1787,1723,1788, -1724,1788,1723, -1788,1724,1789, -1725,1789,1724, -1789,1725,1790, -1726,1790,1725, -1790,1726,1791, -1727,1791,1726, -1792,1728,1793, -1729,1793,1728, -1793,1729,1794, -1730,1794,1729, -1794,1730,1795, -1731,1795,1730, -1795,1731,1796, -1732,1796,1731, -1796,1732,1797, -1733,1797,1732, -1797,1733,1798, -1734,1798,1733, -1798,1734,1799, -1735,1799,1734, -1799,1735,1800, -1736,1800,1735, -1800,1736,1801, -1737,1801,1736, -1801,1737,1802, -1738,1802,1737, -1802,1738,1803, -1739,1803,1738, -1803,1739,1804, -1740,1804,1739, -1804,1740,1805, -1741,1805,1740, -1805,1741,1806, -1742,1806,1741, -1806,1742,1807, -1743,1807,1742, -1807,1743,1808, -1744,1808,1743, -1808,1744,1809, -1745,1809,1744, -1809,1745,1810, -1746,1810,1745, -1810,1746,1811, -1747,1811,1746, -1811,1747,1812, -1748,1812,1747, -1812,1748,1813, -1749,1813,1748, -1813,1749,1814, -1750,1814,1749, -1814,1750,1815, -1751,1815,1750, -1815,1751,1816, -1752,1816,1751, -1816,1752,1817, -1753,1817,1752, -1817,1753,1818, -1754,1818,1753, -1818,1754,1819, -1755,1819,1754, -1819,1755,1820, -1756,1820,1755, -1820,1756,1821, -1757,1821,1756, -1821,1757,1822, -1758,1822,1757, -1822,1758,1823, -1759,1823,1758, -1823,1759,1824, -1760,1824,1759, -1824,1760,1825, -1761,1825,1760, -1825,1761,1826, -1762,1826,1761, -1826,1762,1827, -1763,1827,1762, -1827,1763,1828, -1764,1828,1763, -1828,1764,1829, -1765,1829,1764, -1829,1765,1830, -1766,1830,1765, -1830,1766,1831, -1767,1831,1766, -1831,1767,1832, -1768,1832,1767, -1832,1768,1833, -1769,1833,1768, -1833,1769,1834, -1770,1834,1769, -1834,1770,1835, -1771,1835,1770, -1835,1771,1836, -1772,1836,1771, -1836,1772,1837, -1773,1837,1772, -1837,1773,1838, -1774,1838,1773, -1838,1774,1839, -1775,1839,1774, -1839,1775,1840, -1776,1840,1775, -1840,1776,1841, -1777,1841,1776, -1841,1777,1842, -1778,1842,1777, -1842,1778,1843, -1779,1843,1778, -1843,1779,1844, -1780,1844,1779, -1844,1780,1845, -1781,1845,1780, -1845,1781,1846, -1782,1846,1781, -1846,1782,1847, -1783,1847,1782, -1847,1783,1848, -1784,1848,1783, -1848,1784,1849, -1785,1849,1784, -1849,1785,1850, -1786,1850,1785, -1850,1786,1851, -1787,1851,1786, -1851,1787,1852, -1788,1852,1787, -1852,1788,1853, -1789,1853,1788, -1853,1789,1854, -1790,1854,1789, -1854,1790,1855, -1791,1855,1790, -1856,1792,1857, -1793,1857,1792, -1857,1793,1858, -1794,1858,1793, -1858,1794,1859, -1795,1859,1794, -1859,1795,1860, -1796,1860,1795, -1860,1796,1861, -1797,1861,1796, -1861,1797,1862, -1798,1862,1797, -1862,1798,1863, -1799,1863,1798, -1863,1799,1864, -1800,1864,1799, -1864,1800,1865, -1801,1865,1800, -1865,1801,1866, -1802,1866,1801, -1866,1802,1867, -1803,1867,1802, -1867,1803,1868, -1804,1868,1803, -1868,1804,1869, -1805,1869,1804, -1869,1805,1870, -1806,1870,1805, -1870,1806,1871, -1807,1871,1806, -1871,1807,1872, -1808,1872,1807, -1872,1808,1873, -1809,1873,1808, -1873,1809,1874, -1810,1874,1809, -1874,1810,1875, -1811,1875,1810, -1875,1811,1876, -1812,1876,1811, -1876,1812,1877, -1813,1877,1812, -1877,1813,1878, -1814,1878,1813, -1878,1814,1879, -1815,1879,1814, -1879,1815,1880, -1816,1880,1815, -1880,1816,1881, -1817,1881,1816, -1881,1817,1882, -1818,1882,1817, -1882,1818,1883, -1819,1883,1818, -1883,1819,1884, -1820,1884,1819, -1884,1820,1885, -1821,1885,1820, -1885,1821,1886, -1822,1886,1821, -1886,1822,1887, -1823,1887,1822, -1887,1823,1888, -1824,1888,1823, -1888,1824,1889, -1825,1889,1824, -1889,1825,1890, -1826,1890,1825, -1890,1826,1891, -1827,1891,1826, -1891,1827,1892, -1828,1892,1827, -1892,1828,1893, -1829,1893,1828, -1893,1829,1894, -1830,1894,1829, -1894,1830,1895, -1831,1895,1830, -1895,1831,1896, -1832,1896,1831, -1896,1832,1897, -1833,1897,1832, -1897,1833,1898, -1834,1898,1833, -1898,1834,1899, -1835,1899,1834, -1899,1835,1900, -1836,1900,1835, -1900,1836,1901, -1837,1901,1836, -1901,1837,1902, -1838,1902,1837, -1902,1838,1903, -1839,1903,1838, -1903,1839,1904, -1840,1904,1839, -1904,1840,1905, -1841,1905,1840, -1905,1841,1906, -1842,1906,1841, -1906,1842,1907, -1843,1907,1842, -1907,1843,1908, -1844,1908,1843, -1908,1844,1909, -1845,1909,1844, -1909,1845,1910, -1846,1910,1845, -1910,1846,1911, -1847,1911,1846, -1911,1847,1912, -1848,1912,1847, -1912,1848,1913, -1849,1913,1848, -1913,1849,1914, -1850,1914,1849, -1914,1850,1915, -1851,1915,1850, -1915,1851,1916, -1852,1916,1851, -1916,1852,1917, -1853,1917,1852, -1917,1853,1918, -1854,1918,1853, -1918,1854,1919, -1855,1919,1854, -1920,1856,1921, -1857,1921,1856, -1921,1857,1922, -1858,1922,1857, -1922,1858,1923, -1859,1923,1858, -1923,1859,1924, -1860,1924,1859, -1924,1860,1925, -1861,1925,1860, -1925,1861,1926, -1862,1926,1861, -1926,1862,1927, -1863,1927,1862, -1927,1863,1928, -1864,1928,1863, -1928,1864,1929, -1865,1929,1864, -1929,1865,1930, -1866,1930,1865, -1930,1866,1931, -1867,1931,1866, -1931,1867,1932, -1868,1932,1867, -1932,1868,1933, -1869,1933,1868, -1933,1869,1934, -1870,1934,1869, -1934,1870,1935, -1871,1935,1870, -1935,1871,1936, -1872,1936,1871, -1936,1872,1937, -1873,1937,1872, -1937,1873,1938, -1874,1938,1873, -1938,1874,1939, -1875,1939,1874, -1939,1875,1940, -1876,1940,1875, -1940,1876,1941, -1877,1941,1876, -1941,1877,1942, -1878,1942,1877, -1942,1878,1943, -1879,1943,1878, -1943,1879,1944, -1880,1944,1879, -1944,1880,1945, -1881,1945,1880, -1945,1881,1946, -1882,1946,1881, -1946,1882,1947, -1883,1947,1882, -1947,1883,1948, -1884,1948,1883, -1948,1884,1949, -1885,1949,1884, -1949,1885,1950, -1886,1950,1885, -1950,1886,1951, -1887,1951,1886, -1951,1887,1952, -1888,1952,1887, -1952,1888,1953, -1889,1953,1888, -1953,1889,1954, -1890,1954,1889, -1954,1890,1955, -1891,1955,1890, -1955,1891,1956, -1892,1956,1891, -1956,1892,1957, -1893,1957,1892, -1957,1893,1958, -1894,1958,1893, -1958,1894,1959, -1895,1959,1894, -1959,1895,1960, -1896,1960,1895, -1960,1896,1961, -1897,1961,1896, -1961,1897,1962, -1898,1962,1897, -1962,1898,1963, -1899,1963,1898, -1963,1899,1964, -1900,1964,1899, -1964,1900,1965, -1901,1965,1900, -1965,1901,1966, -1902,1966,1901, -1966,1902,1967, -1903,1967,1902, -1967,1903,1968, -1904,1968,1903, -1968,1904,1969, -1905,1969,1904, -1969,1905,1970, -1906,1970,1905, -1970,1906,1971, -1907,1971,1906, -1971,1907,1972, -1908,1972,1907, -1972,1908,1973, -1909,1973,1908, -1973,1909,1974, -1910,1974,1909, -1974,1910,1975, -1911,1975,1910, -1975,1911,1976, -1912,1976,1911, -1976,1912,1977, -1913,1977,1912, -1977,1913,1978, -1914,1978,1913, -1978,1914,1979, -1915,1979,1914, -1979,1915,1980, -1916,1980,1915, -1980,1916,1981, -1917,1981,1916, -1981,1917,1982, -1918,1982,1917, -1982,1918,1983, -1919,1983,1918, -1984,1920,1985, -1921,1985,1920, -1985,1921,1986, -1922,1986,1921, -1986,1922,1987, -1923,1987,1922, -1987,1923,1988, -1924,1988,1923, -1988,1924,1989, -1925,1989,1924, -1989,1925,1990, -1926,1990,1925, -1990,1926,1991, -1927,1991,1926, -1991,1927,1992, -1928,1992,1927, -1992,1928,1993, -1929,1993,1928, -1993,1929,1994, -1930,1994,1929, -1994,1930,1995, -1931,1995,1930, -1995,1931,1996, -1932,1996,1931, -1996,1932,1997, -1933,1997,1932, -1997,1933,1998, -1934,1998,1933, -1998,1934,1999, -1935,1999,1934, -1999,1935,2000, -1936,2000,1935, -2000,1936,2001, -1937,2001,1936, -2001,1937,2002, -1938,2002,1937, -2002,1938,2003, -1939,2003,1938, -2003,1939,2004, -1940,2004,1939, -2004,1940,2005, -1941,2005,1940, -2005,1941,2006, -1942,2006,1941, -2006,1942,2007, -1943,2007,1942, -2007,1943,2008, -1944,2008,1943, -2008,1944,2009, -1945,2009,1944, -2009,1945,2010, -1946,2010,1945, -2010,1946,2011, -1947,2011,1946, -2011,1947,2012, -1948,2012,1947, -2012,1948,2013, -1949,2013,1948, -2013,1949,2014, -1950,2014,1949, -2014,1950,2015, -1951,2015,1950, -2015,1951,2016, -1952,2016,1951, -2016,1952,2017, -1953,2017,1952, -2017,1953,2018, -1954,2018,1953, -2018,1954,2019, -1955,2019,1954, -2019,1955,2020, -1956,2020,1955, -2020,1956,2021, -1957,2021,1956, -2021,1957,2022, -1958,2022,1957, -2022,1958,2023, -1959,2023,1958, -2023,1959,2024, -1960,2024,1959, -2024,1960,2025, -1961,2025,1960, -2025,1961,2026, -1962,2026,1961, -2026,1962,2027, -1963,2027,1962, -2027,1963,2028, -1964,2028,1963, -2028,1964,2029, -1965,2029,1964, -2029,1965,2030, -1966,2030,1965, -2030,1966,2031, -1967,2031,1966, -2031,1967,2032, -1968,2032,1967, -2032,1968,2033, -1969,2033,1968, -2033,1969,2034, -1970,2034,1969, -2034,1970,2035, -1971,2035,1970, -2035,1971,2036, -1972,2036,1971, -2036,1972,2037, -1973,2037,1972, -2037,1973,2038, -1974,2038,1973, -2038,1974,2039, -1975,2039,1974, -2039,1975,2040, -1976,2040,1975, -2040,1976,2041, -1977,2041,1976, -2041,1977,2042, -1978,2042,1977, -2042,1978,2043, -1979,2043,1978, -2043,1979,2044, -1980,2044,1979, -2044,1980,2045, -1981,2045,1980, -2045,1981,2046, -1982,2046,1981, -2046,1982,2047, -1983,2047,1982, -}; - -#define Landscape04VtxCount 2112 -#define Landscape04IdxCount 12096 - -btScalar Landscape04Vtx[] = { -3.90625f,18.9654f,125.0f, -3.90625f,20.0876f,128.906f, -7.8125f,20.5764f,125.0f, -7.8125f,21.0764f,128.906f, -11.7188f,21.5489f,125.0f, -11.7188f,21.4076f,128.906f, -15.625f,22.4963f,125.0f, -15.625f,22.6299f,128.906f, -19.5313f,22.3264f,125.0f, -19.5313f,22.1174f,128.906f, -23.4375f,20.3987f,125.0f, -23.4375f,20.3977f,128.906f, -27.3438f,18.6622f,125.0f, -27.3438f,18.7343f,128.906f, -31.25f,17.4724f,125.0f, -31.25f,17.9144f,128.906f, -35.1563f,16.4832f,125.0f, -35.1563f,17.2941f,128.906f, -39.0625f,15.2653f,125.0f, -39.0625f,16.5386f,128.906f, -42.9688f,14.379f,125.0f, -42.9688f,15.6892f,128.906f, -46.875f,13.9872f,125.0f, -46.875f,14.6414f,128.906f, -50.7813f,14.7002f,125.0f, -50.7813f,14.3505f,128.906f, -54.6875f,15.1119f,125.0f, -54.6875f,14.1604f,128.906f, -58.5938f,14.6638f,125.0f, -58.5938f,14.517f,128.906f, -62.5f,14.668f,125.0f, -62.5f,15.1057f,128.906f, -66.4063f,14.9792f,125.0f, -66.4063f,16.0684f,128.906f, -70.3125f,15.4776f,125.0f, -70.3125f,16.6251f,128.906f, -74.2188f,15.0939f,125.0f, -74.2188f,15.9689f,128.906f, -78.125f,15.5318f,125.0f, -78.125f,16.0234f,128.906f, -82.0313f,16.0777f,125.0f, -82.0313f,16.205f,128.906f, -85.9375f,17.8753f,125.0f, -85.9375f,18.8167f,128.906f, -89.8438f,18.8786f,125.0f, -89.8438f,19.6433f,128.906f, -93.75f,19.8208f,125.0f, -93.75f,20.2916f,128.906f, -97.6563f,23.2578f,125.0f, -97.6563f,23.2308f,128.906f, -101.563f,25.3117f,125.0f, -101.563f,25.882f,128.906f, -105.469f,26.8718f,125.0f, -105.469f,27.5736f,128.906f, -109.375f,28.7414f,125.0f, -109.375f,28.9662f,128.906f, -113.281f,29.9339f,125.0f, -113.281f,30.5702f,128.906f, -117.188f,30.6849f,125.0f, -117.188f,31.8627f,128.906f, -121.094f,32.4202f,125.0f, -121.094f,32.5216f,128.906f, -125.0f,34.7495f,125.0f, -125.0f,34.1918f,128.906f, -128.906f,37.137f,125.0f, -128.906f,37.0161f,128.906f, -132.813f,38.4113f,125.0f, -132.813f,38.5084f,128.906f, -136.719f,38.1788f,125.0f, -136.719f,39.1631f,128.906f, -140.625f,38.7652f,125.0f, -140.625f,39.0529f,128.906f, -144.531f,37.9353f,125.0f, -144.531f,38.9229f,128.906f, -148.438f,38.5681f,125.0f, -148.438f,38.4312f,128.906f, -152.344f,38.6243f,125.0f, -152.344f,39.1086f,128.906f, -156.25f,39.6341f,125.0f, -156.25f,39.7022f,128.906f, -160.156f,39.762f,125.0f, -160.156f,39.3007f,128.906f, -164.063f,38.5385f,125.0f, -164.063f,38.2318f,128.906f, -167.969f,36.3551f,125.0f, -167.969f,36.7493f,128.906f, -171.875f,36.1936f,125.0f, -171.875f,35.9781f,128.906f, -175.781f,35.5636f,125.0f, -175.781f,35.7712f,128.906f, -179.688f,34.6544f,125.0f, -179.688f,35.6247f,128.906f, -183.594f,34.1597f,125.0f, -183.594f,35.4808f,128.906f, -187.5f,33.5567f,125.0f, -187.5f,35.6102f,128.906f, -191.406f,33.0138f,125.0f, -191.406f,34.0305f,128.906f, -195.313f,31.2722f,125.0f, -195.313f,32.0227f,128.906f, -199.219f,29.2529f,125.0f, -199.219f,29.7666f,128.906f, -203.125f,26.9435f,125.0f, -203.125f,27.3968f,128.906f, -207.031f,25.0844f,125.0f, -207.031f,25.1642f,128.906f, -210.938f,23.6605f,125.0f, -210.938f,24.279f,128.906f, -214.844f,22.0745f,125.0f, -214.844f,22.4357f,128.906f, -218.75f,20.3206f,125.0f, -218.75f,21.7754f,128.906f, -222.656f,20.0402f,125.0f, -222.656f,19.6381f,128.906f, -226.563f,20.1162f,125.0f, -226.563f,19.78f,128.906f, -230.469f,20.2399f,125.0f, -230.469f,20.0349f,128.906f, -234.375f,19.6142f,125.0f, -234.375f,19.1534f,128.906f, -238.281f,18.6118f,125.0f, -238.281f,17.863f,128.906f, -242.188f,17.3711f,125.0f, -242.188f,17.658f,128.906f, -246.094f,17.675f,125.0f, -246.094f,16.951f,128.906f, -250.0f,17.3999f,125.0f, -250.0f,16.2961f,128.906f, -3.90625f,18.5327f,121.094f, -7.8125f,19.7267f,121.094f, -11.7188f,20.9891f,121.094f, -15.625f,22.237f,121.094f, -19.5313f,22.3238f,121.094f, -23.4375f,20.1525f,121.094f, -27.3438f,17.9536f,121.094f, -31.25f,17.647f,121.094f, -35.1563f,16.241f,121.094f, -39.0625f,14.6821f,121.094f, -42.9688f,14.4948f,121.094f, -46.875f,15.0351f,121.094f, -50.7813f,15.3893f,121.094f, -54.6875f,15.1531f,121.094f, -58.5938f,14.9284f,121.094f, -62.5f,15.1197f,121.094f, -66.4063f,15.1561f,121.094f, -70.3125f,15.1593f,121.094f, -74.2188f,15.0707f,121.094f, -78.125f,16.0455f,121.094f, -82.0313f,16.6186f,121.094f, -85.9375f,17.4149f,121.094f, -89.8438f,18.746f,121.094f, -93.75f,18.8475f,121.094f, -97.6563f,21.6899f,121.094f, -101.563f,24.567f,121.094f, -105.469f,25.7581f,121.094f, -109.375f,27.437f,121.094f, -113.281f,29.1226f,121.094f, -117.188f,30.137f,121.094f, -121.094f,32.1062f,121.094f, -125.0f,34.674f,121.094f, -128.906f,37.1044f,121.094f, -132.813f,37.8111f,121.094f, -136.719f,37.7901f,121.094f, -140.625f,37.5727f,121.094f, -144.531f,37.1561f,121.094f, -148.438f,38.1976f,121.094f, -152.344f,38.9227f,121.094f, -156.25f,40.3124f,121.094f, -160.156f,40.6867f,121.094f, -164.063f,39.5374f,121.094f, -167.969f,38.019f,121.094f, -171.875f,36.4573f,121.094f, -175.781f,35.2509f,121.094f, -179.688f,34.6709f,121.094f, -183.594f,33.5584f,121.094f, -187.5f,33.2411f,121.094f, -191.406f,31.7588f,121.094f, -195.313f,30.3558f,121.094f, -199.219f,28.879f,121.094f, -203.125f,26.7589f,121.094f, -207.031f,25.0535f,121.094f, -210.938f,23.0477f,121.094f, -214.844f,20.6897f,121.094f, -218.75f,19.3676f,121.094f, -222.656f,19.2985f,121.094f, -226.563f,20.2312f,121.094f, -230.469f,20.317f,121.094f, -234.375f,20.2468f,121.094f, -238.281f,20.3734f,121.094f, -242.188f,18.3676f,121.094f, -246.094f,16.642f,121.094f, -250.0f,17.5995f,121.094f, -3.90625f,18.919f,117.188f, -7.8125f,19.2124f,117.188f, -11.7188f,20.7659f,117.188f, -15.625f,20.5809f,117.188f, -19.5313f,20.3134f,117.188f, -23.4375f,18.6669f,117.188f, -27.3438f,17.5145f,117.188f, -31.25f,17.0813f,117.188f, -35.1563f,15.6789f,117.188f, -39.0625f,14.7581f,117.188f, -42.9688f,14.4424f,117.188f, -46.875f,14.7991f,117.188f, -50.7813f,15.0726f,117.188f, -54.6875f,14.8056f,117.188f, -58.5938f,15.756f,117.188f, -62.5f,16.3024f,117.188f, -66.4063f,16.0449f,117.188f, -70.3125f,15.9115f,117.188f, -74.2188f,16.1633f,117.188f, -78.125f,17.3323f,117.188f, -82.0313f,17.2659f,117.188f, -85.9375f,17.987f,117.188f, -89.8438f,18.3044f,117.188f, -93.75f,18.2665f,117.188f, -97.6563f,19.5364f,117.188f, -101.563f,21.7536f,117.188f, -105.469f,23.6545f,117.188f, -109.375f,25.5212f,117.188f, -113.281f,28.1179f,117.188f, -117.188f,29.5931f,117.188f, -121.094f,31.8126f,117.188f, -125.0f,34.0227f,117.188f, -128.906f,36.3895f,117.188f, -132.813f,37.0423f,117.188f, -136.719f,36.8278f,117.188f, -140.625f,36.2349f,117.188f, -144.531f,36.8825f,117.188f, -148.438f,39.6492f,117.188f, -152.344f,41.6626f,117.188f, -156.25f,42.5091f,117.188f, -160.156f,43.0711f,117.188f, -164.063f,41.7733f,117.188f, -167.969f,40.5985f,117.188f, -171.875f,38.1852f,117.188f, -175.781f,37.023f,117.188f, -179.688f,35.8533f,117.188f, -183.594f,34.5754f,117.188f, -187.5f,33.6585f,117.188f, -191.406f,32.534f,117.188f, -195.313f,31.0632f,117.188f, -199.219f,29.0243f,117.188f, -203.125f,27.0248f,117.188f, -207.031f,25.1597f,117.188f, -210.938f,22.6282f,117.188f, -214.844f,20.6205f,117.188f, -218.75f,19.2556f,117.188f, -222.656f,18.8259f,117.188f, -226.563f,19.2235f,117.188f, -230.469f,20.4441f,117.188f, -234.375f,20.5373f,117.188f, -238.281f,20.3082f,117.188f, -242.188f,19.4397f,117.188f, -246.094f,17.9806f,117.188f, -250.0f,17.3395f,117.188f, -3.90625f,18.3498f,113.281f, -7.8125f,18.7009f,113.281f, -11.7188f,19.3704f,113.281f, -15.625f,19.5203f,113.281f, -19.5313f,18.5704f,113.281f, -23.4375f,17.6697f,113.281f, -27.3438f,16.8001f,113.281f, -31.25f,16.54f,113.281f, -35.1563f,15.8558f,113.281f, -39.0625f,15.1296f,113.281f, -42.9688f,15.8599f,113.281f, -46.875f,16.437f,113.281f, -50.7813f,16.2977f,113.281f, -54.6875f,16.7076f,113.281f, -58.5938f,16.8187f,113.281f, -62.5f,17.1513f,113.281f, -66.4063f,16.5296f,113.281f, -70.3125f,15.8782f,113.281f, -74.2188f,16.614f,113.281f, -78.125f,17.0474f,113.281f, -82.0313f,17.3371f,113.281f, -85.9375f,17.9565f,113.281f, -89.8438f,18.3918f,113.281f, -93.75f,19.0258f,113.281f, -97.6563f,19.2791f,113.281f, -101.563f,20.1533f,113.281f, -105.469f,22.2922f,113.281f, -109.375f,24.6835f,113.281f, -113.281f,25.7755f,113.281f, -117.188f,28.8805f,113.281f, -121.094f,31.2119f,113.281f, -125.0f,33.4657f,113.281f, -128.906f,35.1055f,113.281f, -132.813f,36.4197f,113.281f, -136.719f,37.3017f,113.281f, -140.625f,37.1796f,113.281f, -144.531f,38.2037f,113.281f, -148.438f,41.4383f,113.281f, -152.344f,43.9714f,113.281f, -156.25f,45.0067f,113.281f, -160.156f,45.1491f,113.281f, -164.063f,43.8042f,113.281f, -167.969f,42.5165f,113.281f, -171.875f,40.361f,113.281f, -175.781f,38.3494f,113.281f, -179.688f,37.4529f,113.281f, -183.594f,35.5766f,113.281f, -187.5f,34.2438f,113.281f, -191.406f,32.0218f,113.281f, -195.313f,30.2021f,113.281f, -199.219f,28.8256f,113.281f, -203.125f,27.2081f,113.281f, -207.031f,24.992f,113.281f, -210.938f,22.5332f,113.281f, -214.844f,19.7765f,113.281f, -218.75f,18.5573f,113.281f, -222.656f,18.1469f,113.281f, -226.563f,17.9659f,113.281f, -230.469f,19.2f,113.281f, -234.375f,20.0741f,113.281f, -238.281f,20.1159f,113.281f, -242.188f,19.0382f,113.281f, -246.094f,18.3417f,113.281f, -250.0f,18.7603f,113.281f, -3.90625f,18.0017f,109.375f, -7.8125f,18.1552f,109.375f, -11.7188f,18.2026f,109.375f, -15.625f,18.2042f,109.375f, -19.5313f,17.7806f,109.375f, -23.4375f,17.5378f,109.375f, -27.3438f,16.8627f,109.375f, -31.25f,15.9329f,109.375f, -35.1563f,15.192f,109.375f, -39.0625f,16.0796f,109.375f, -42.9688f,16.1895f,109.375f, -46.875f,15.9774f,109.375f, -50.7813f,16.9529f,109.375f, -54.6875f,17.0901f,109.375f, -58.5938f,17.3722f,109.375f, -62.5f,16.5809f,109.375f, -66.4063f,16.8111f,109.375f, -70.3125f,16.9238f,109.375f, -74.2188f,16.8422f,109.375f, -78.125f,17.0401f,109.375f, -82.0313f,16.8637f,109.375f, -85.9375f,17.4071f,109.375f, -89.8438f,17.944f,109.375f, -93.75f,18.5255f,109.375f, -97.6563f,18.2829f,109.375f, -101.563f,19.0975f,109.375f, -105.469f,20.4292f,109.375f, -109.375f,22.163f,109.375f, -113.281f,25.6773f,109.375f, -117.188f,27.8617f,109.375f, -121.094f,30.6543f,109.375f, -125.0f,33.4226f,109.375f, -128.906f,34.4263f,109.375f, -132.813f,36.8747f,109.375f, -136.719f,37.4551f,109.375f, -140.625f,37.4975f,109.375f, -144.531f,40.0751f,109.375f, -148.438f,42.7524f,109.375f, -152.344f,44.7756f,109.375f, -156.25f,46.1787f,109.375f, -160.156f,46.3753f,109.375f, -164.063f,45.2089f,109.375f, -167.969f,43.7487f,109.375f, -171.875f,41.6365f,109.375f, -175.781f,39.7459f,109.375f, -179.688f,36.9804f,109.375f, -183.594f,35.6688f,109.375f, -187.5f,35.0212f,109.375f, -191.406f,32.4383f,109.375f, -195.313f,29.6046f,109.375f, -199.219f,28.1822f,109.375f, -203.125f,26.2444f,109.375f, -207.031f,24.1442f,109.375f, -210.938f,22.1072f,109.375f, -214.844f,20.0401f,109.375f, -218.75f,18.0663f,109.375f, -222.656f,16.866f,109.375f, -226.563f,16.9372f,109.375f, -230.469f,16.9853f,109.375f, -234.375f,17.6761f,109.375f, -238.281f,18.3669f,109.375f, -242.188f,18.4156f,109.375f, -246.094f,18.2171f,109.375f, -250.0f,18.5941f,109.375f, -3.90625f,17.9608f,105.469f, -7.8125f,18.4369f,105.469f, -11.7188f,18.4406f,105.469f, -15.625f,17.8685f,105.469f, -19.5313f,17.7519f,105.469f, -23.4375f,17.5734f,105.469f, -27.3438f,16.3397f,105.469f, -31.25f,15.8618f,105.469f, -35.1563f,16.1194f,105.469f, -39.0625f,16.889f,105.469f, -42.9688f,16.2804f,105.469f, -46.875f,15.8474f,105.469f, -50.7813f,16.2892f,105.469f, -54.6875f,16.2854f,105.469f, -58.5938f,16.7368f,105.469f, -62.5f,17.4055f,105.469f, -66.4063f,16.8808f,105.469f, -70.3125f,17.3183f,105.469f, -74.2188f,17.7166f,105.469f, -78.125f,17.0657f,105.469f, -82.0313f,16.7305f,105.469f, -85.9375f,16.3929f,105.469f, -89.8438f,16.6475f,105.469f, -93.75f,17.7645f,105.469f, -97.6563f,18.4212f,105.469f, -101.563f,18.4107f,105.469f, -105.469f,19.3751f,105.469f, -109.375f,21.843f,105.469f, -113.281f,25.0143f,105.469f, -117.188f,26.9168f,105.469f, -121.094f,29.8403f,105.469f, -125.0f,32.4937f,105.469f, -128.906f,34.4076f,105.469f, -132.813f,35.2497f,105.469f, -136.719f,36.4785f,105.469f, -140.625f,37.7983f,105.469f, -144.531f,40.5712f,105.469f, -148.438f,43.3698f,105.469f, -152.344f,45.784f,105.469f, -156.25f,46.9835f,105.469f, -160.156f,47.2774f,105.469f, -164.063f,46.7695f,105.469f, -167.969f,45.0199f,105.469f, -171.875f,42.588f,105.469f, -175.781f,39.988f,105.469f, -179.688f,38.0653f,105.469f, -183.594f,37.5754f,105.469f, -187.5f,35.6316f,105.469f, -191.406f,32.4143f,105.469f, -195.313f,29.5342f,105.469f, -199.219f,27.2795f,105.469f, -203.125f,26.065f,105.469f, -207.031f,24.8633f,105.469f, -210.938f,23.0216f,105.469f, -214.844f,21.1684f,105.469f, -218.75f,18.9315f,105.469f, -222.656f,17.7013f,105.469f, -226.563f,16.9466f,105.469f, -230.469f,17.1437f,105.469f, -234.375f,17.6691f,105.469f, -238.281f,17.9243f,105.469f, -242.188f,18.0005f,105.469f, -246.094f,18.6179f,105.469f, -250.0f,19.2165f,105.469f, -3.90625f,17.7074f,101.563f, -7.8125f,18.411f,101.563f, -11.7188f,17.9916f,101.563f, -15.625f,18.5349f,101.563f, -19.5313f,18.6607f,101.563f, -23.4375f,17.406f,101.563f, -27.3438f,17.2356f,101.563f, -31.25f,17.0395f,101.563f, -35.1563f,17.9903f,101.563f, -39.0625f,18.2603f,101.563f, -42.9688f,17.9037f,101.563f, -46.875f,17.2358f,101.563f, -50.7813f,16.1089f,101.563f, -54.6875f,16.6043f,101.563f, -58.5938f,16.5656f,101.563f, -62.5f,16.8655f,101.563f, -66.4063f,17.0123f,101.563f, -70.3125f,17.4985f,101.563f, -74.2188f,18.0195f,101.563f, -78.125f,17.3417f,101.563f, -82.0313f,16.8477f,101.563f, -85.9375f,15.4602f,101.563f, -89.8438f,15.6001f,101.563f, -93.75f,16.8889f,101.563f, -97.6563f,17.2944f,101.563f, -101.563f,17.3431f,101.563f, -105.469f,18.2306f,101.563f, -109.375f,20.5556f,101.563f, -113.281f,22.5598f,101.563f, -117.188f,25.0997f,101.563f, -121.094f,28.2048f,101.563f, -125.0f,30.46f,101.563f, -128.906f,32.5729f,101.563f, -132.813f,34.5568f,101.563f, -136.719f,36.463f,101.563f, -140.625f,37.8259f,101.563f, -144.531f,40.4357f,101.563f, -148.438f,43.6544f,101.563f, -152.344f,46.204f,101.563f, -156.25f,47.3874f,101.563f, -160.156f,47.5222f,101.563f, -164.063f,46.8312f,101.563f, -167.969f,44.5065f,101.563f, -171.875f,43.7648f,101.563f, -175.781f,41.9789f,101.563f, -179.688f,40.785f,101.563f, -183.594f,38.7639f,101.563f, -187.5f,36.1589f,101.563f, -191.406f,33.4197f,101.563f, -195.313f,29.7568f,101.563f, -199.219f,27.2343f,101.563f, -203.125f,26.3845f,101.563f, -207.031f,25.3149f,101.563f, -210.938f,23.4896f,101.563f, -214.844f,22.229f,101.563f, -218.75f,20.0014f,101.563f, -222.656f,19.0955f,101.563f, -226.563f,17.971f,101.563f, -230.469f,16.9303f,101.563f, -234.375f,17.3619f,101.563f, -238.281f,17.0337f,101.563f, -242.188f,17.1424f,101.563f, -246.094f,18.334f,101.563f, -250.0f,19.2744f,101.563f, -3.90625f,18.0176f,97.6563f, -7.8125f,18.1916f,97.6563f, -11.7188f,17.72f,97.6563f, -15.625f,18.3444f,97.6563f, -19.5313f,18.7102f,97.6563f, -23.4375f,17.4143f,97.6563f, -27.3438f,18.0085f,97.6563f, -31.25f,18.4924f,97.6563f, -35.1563f,19.4324f,97.6563f, -39.0625f,19.7998f,97.6563f, -42.9688f,19.5444f,97.6563f, -46.875f,19.5513f,97.6563f, -50.7813f,17.9397f,97.6563f, -54.6875f,16.6383f,97.6563f, -58.5938f,16.0619f,97.6563f, -62.5f,16.7402f,97.6563f, -66.4063f,16.955f,97.6563f, -70.3125f,17.5912f,97.6563f, -74.2188f,17.1181f,97.6563f, -78.125f,16.9063f,97.6563f, -82.0313f,16.3988f,97.6563f, -85.9375f,15.935f,97.6563f, -89.8438f,16.0664f,97.6563f, -93.75f,16.1926f,97.6563f, -97.6563f,16.5004f,97.6563f, -101.563f,17.1185f,97.6563f, -105.469f,17.2859f,97.6563f, -109.375f,19.0026f,97.6563f, -113.281f,21.0018f,97.6563f, -117.188f,23.6336f,97.6563f, -121.094f,26.4831f,97.6563f, -125.0f,29.3075f,97.6563f, -128.906f,32.5702f,97.6563f, -132.813f,34.5711f,97.6563f, -136.719f,36.1666f,97.6563f, -140.625f,37.5909f,97.6563f, -144.531f,40.3232f,97.6563f, -148.438f,42.661f,97.6563f, -152.344f,45.5604f,97.6563f, -156.25f,47.6984f,97.6563f, -160.156f,47.4129f,97.6563f, -164.063f,47.1564f,97.6563f, -167.969f,45.3058f,97.6563f, -171.875f,44.8069f,97.6563f, -175.781f,43.6847f,97.6563f, -179.688f,41.6831f,97.6563f, -183.594f,39.4072f,97.6563f, -187.5f,36.6118f,97.6563f, -191.406f,33.396f,97.6563f, -195.313f,29.9372f,97.6563f, -199.219f,28.0616f,97.6563f, -203.125f,27.3957f,97.6563f, -207.031f,25.6934f,97.6563f, -210.938f,24.4412f,97.6563f, -214.844f,23.2356f,97.6563f, -218.75f,21.445f,97.6563f, -222.656f,19.5412f,97.6563f, -226.563f,18.4898f,97.6563f, -230.469f,17.727f,97.6563f, -234.375f,16.5139f,97.6563f, -238.281f,16.2579f,97.6563f, -242.188f,16.1539f,97.6563f, -246.094f,17.0856f,97.6563f, -250.0f,18.5151f,97.6563f, -3.90625f,17.1671f,93.75f, -7.8125f,16.817f,93.75f, -11.7188f,17.5293f,93.75f, -15.625f,18.7701f,93.75f, -19.5313f,18.3362f,93.75f, -23.4375f,19.0869f,93.75f, -27.3438f,19.7557f,93.75f, -31.25f,20.0113f,93.75f, -35.1563f,20.3441f,93.75f, -39.0625f,21.4434f,93.75f, -42.9688f,21.6008f,93.75f, -46.875f,21.5423f,93.75f, -50.7813f,20.7592f,93.75f, -54.6875f,18.9207f,93.75f, -58.5938f,17.6772f,93.75f, -62.5f,17.5409f,93.75f, -66.4063f,17.599f,93.75f, -70.3125f,18.2626f,93.75f, -74.2188f,18.4046f,93.75f, -78.125f,18.215f,93.75f, -82.0313f,18.4743f,93.75f, -85.9375f,17.6579f,93.75f, -89.8438f,17.732f,93.75f, -93.75f,18.4172f,93.75f, -97.6563f,19.0439f,93.75f, -101.563f,19.7437f,93.75f, -105.469f,19.8588f,93.75f, -109.375f,19.7414f,93.75f, -113.281f,21.4756f,93.75f, -117.188f,24.1862f,93.75f, -121.094f,26.8351f,93.75f, -125.0f,29.9621f,93.75f, -128.906f,32.8267f,93.75f, -132.813f,34.6779f,93.75f, -136.719f,36.0083f,93.75f, -140.625f,36.9812f,93.75f, -144.531f,39.6087f,93.75f, -148.438f,42.2269f,93.75f, -152.344f,44.492f,93.75f, -156.25f,47.1767f,93.75f, -160.156f,47.5667f,93.75f, -164.063f,46.9625f,93.75f, -167.969f,45.6865f,93.75f, -171.875f,45.7668f,93.75f, -175.781f,44.8303f,93.75f, -179.688f,42.5904f,93.75f, -183.594f,40.3536f,93.75f, -187.5f,37.9498f,93.75f, -191.406f,35.1415f,93.75f, -195.313f,31.5011f,93.75f, -199.219f,29.695f,93.75f, -203.125f,27.7988f,93.75f, -207.031f,26.3522f,93.75f, -210.938f,25.8544f,93.75f, -214.844f,24.7269f,93.75f, -218.75f,23.7697f,93.75f, -222.656f,20.9249f,93.75f, -226.563f,19.1368f,93.75f, -230.469f,18.5704f,93.75f, -234.375f,17.554f,93.75f, -238.281f,14.9004f,93.75f, -242.188f,16.3253f,93.75f, -246.094f,16.0037f,93.75f, -250.0f,15.9921f,93.75f, -3.90625f,15.6427f,89.8438f, -7.8125f,16.2722f,89.8438f, -11.7188f,17.6471f,89.8438f, -15.625f,18.8565f,89.8438f, -19.5313f,19.651f,89.8438f, -23.4375f,20.9243f,89.8438f, -27.3438f,20.8045f,89.8438f, -31.25f,20.2274f,89.8438f, -35.1563f,21.5768f,89.8438f, -39.0625f,22.566f,89.8438f, -42.9688f,23.4111f,89.8438f, -46.875f,23.5063f,89.8438f, -50.7813f,22.9631f,89.8438f, -54.6875f,21.5642f,89.8438f, -58.5938f,20.3649f,89.8438f, -62.5f,19.6177f,89.8438f, -66.4063f,18.6758f,89.8438f, -70.3125f,18.6837f,89.8438f, -74.2188f,19.7593f,89.8438f, -78.125f,20.4356f,89.8438f, -82.0313f,20.1806f,89.8438f, -85.9375f,19.4513f,89.8438f, -89.8438f,19.2942f,89.8438f, -93.75f,19.9864f,89.8438f, -97.6563f,20.6569f,89.8438f, -101.563f,20.8985f,89.8438f, -105.469f,20.8027f,89.8438f, -109.375f,21.5099f,89.8438f, -113.281f,22.7491f,89.8438f, -117.188f,24.1938f,89.8438f, -121.094f,27.3472f,89.8438f, -125.0f,29.9546f,89.8438f, -128.906f,32.3821f,89.8438f, -132.813f,34.2078f,89.8438f, -136.719f,35.7419f,89.8438f, -140.625f,36.6408f,89.8438f, -144.531f,39.1756f,89.8438f, -148.438f,42.1721f,89.8438f, -152.344f,43.7891f,89.8438f, -156.25f,45.9566f,89.8438f, -160.156f,47.5521f,89.8438f, -164.063f,47.0165f,89.8438f, -167.969f,46.0084f,89.8438f, -171.875f,46.0374f,89.8438f, -175.781f,45.9301f,89.8438f, -179.688f,43.5326f,89.8438f, -183.594f,40.5203f,89.8438f, -187.5f,38.133f,89.8438f, -191.406f,35.8688f,89.8438f, -195.313f,33.0648f,89.8438f, -199.219f,31.0451f,89.8438f, -203.125f,27.691f,89.8438f, -207.031f,26.7927f,89.8438f, -210.938f,26.334f,89.8438f, -214.844f,25.0669f,89.8438f, -218.75f,23.4149f,89.8438f, -222.656f,20.9786f,89.8438f, -226.563f,18.963f,89.8438f, -230.469f,18.7894f,89.8438f, -234.375f,17.2683f,89.8438f, -238.281f,14.98f,89.8438f, -242.188f,15.4163f,89.8438f, -246.094f,15.4238f,89.8438f, -250.0f,15.9208f,89.8438f, -3.90625f,15.5916f,85.9375f, -7.8125f,16.3916f,85.9375f, -11.7188f,18.2047f,85.9375f, -15.625f,19.1861f,85.9375f, -19.5313f,20.7525f,85.9375f, -23.4375f,21.6364f,85.9375f, -27.3438f,21.9262f,85.9375f, -31.25f,21.6225f,85.9375f, -35.1563f,22.4806f,85.9375f, -39.0625f,23.7973f,85.9375f, -42.9688f,24.6135f,85.9375f, -46.875f,24.8421f,85.9375f, -50.7813f,24.5451f,85.9375f, -54.6875f,23.688f,85.9375f, -58.5938f,22.221f,85.9375f, -62.5f,21.5009f,85.9375f, -66.4063f,21.2241f,85.9375f, -70.3125f,20.2058f,85.9375f, -74.2188f,20.3437f,85.9375f, -78.125f,21.8786f,85.9375f, -82.0313f,21.9425f,85.9375f, -85.9375f,20.6496f,85.9375f, -89.8438f,20.6855f,85.9375f, -93.75f,20.6495f,85.9375f, -97.6563f,21.0738f,85.9375f, -101.563f,21.7991f,85.9375f, -105.469f,22.3795f,85.9375f, -109.375f,22.4292f,85.9375f, -113.281f,23.6451f,85.9375f, -117.188f,24.8457f,85.9375f, -121.094f,26.7121f,85.9375f, -125.0f,29.2236f,85.9375f, -128.906f,31.5942f,85.9375f, -132.813f,33.8517f,85.9375f, -136.719f,35.7145f,85.9375f, -140.625f,36.6808f,85.9375f, -144.531f,38.8926f,85.9375f, -148.438f,41.6484f,85.9375f, -152.344f,44.2035f,85.9375f, -156.25f,45.1997f,85.9375f, -160.156f,46.1921f,85.9375f, -164.063f,47.2097f,85.9375f, -167.969f,47.0691f,85.9375f, -171.875f,45.5257f,85.9375f, -175.781f,44.6746f,85.9375f, -179.688f,43.6223f,85.9375f, -183.594f,40.2395f,85.9375f, -187.5f,38.445f,85.9375f, -191.406f,36.5002f,85.9375f, -195.313f,33.7977f,85.9375f, -199.219f,31.5943f,85.9375f, -203.125f,28.8305f,85.9375f, -207.031f,27.4922f,85.9375f, -210.938f,26.0386f,85.9375f, -214.844f,24.1792f,85.9375f, -218.75f,22.1567f,85.9375f, -222.656f,20.1169f,85.9375f, -226.563f,19.3603f,85.9375f, -230.469f,17.7703f,85.9375f, -234.375f,16.3147f,85.9375f, -238.281f,15.0886f,85.9375f, -242.188f,15.1332f,85.9375f, -246.094f,14.7802f,85.9375f, -250.0f,15.2259f,85.9375f, -3.90625f,16.9644f,82.0313f, -7.8125f,17.8f,82.0313f, -11.7188f,19.2943f,82.0313f, -15.625f,21.0269f,82.0313f, -19.5313f,22.3312f,82.0313f, -23.4375f,23.0871f,82.0313f, -27.3438f,23.1115f,82.0313f, -31.25f,23.5304f,82.0313f, -35.1563f,24.1493f,82.0313f, -39.0625f,25.0848f,82.0313f, -42.9688f,26.0789f,82.0313f, -46.875f,26.3399f,82.0313f, -50.7813f,25.4397f,82.0313f, -54.6875f,24.894f,82.0313f, -58.5938f,24.1026f,82.0313f, -62.5f,24.0749f,82.0313f, -66.4063f,23.5256f,82.0313f, -70.3125f,21.9612f,82.0313f, -74.2188f,21.932f,82.0313f, -78.125f,22.6241f,82.0313f, -82.0313f,22.672f,82.0313f, -85.9375f,21.4303f,82.0313f, -89.8438f,21.6964f,82.0313f, -93.75f,21.7198f,82.0313f, -97.6563f,22.4953f,82.0313f, -101.563f,23.0451f,82.0313f, -105.469f,23.0285f,82.0313f, -109.375f,23.24f,82.0313f, -113.281f,23.6861f,82.0313f, -117.188f,24.7685f,82.0313f, -121.094f,26.4466f,82.0313f, -125.0f,28.8315f,82.0313f, -128.906f,30.9624f,82.0313f, -132.813f,33.7991f,82.0313f, -136.719f,35.8079f,82.0313f, -140.625f,37.0254f,82.0313f, -144.531f,38.7479f,82.0313f, -148.438f,42.0473f,82.0313f, -152.344f,43.7879f,82.0313f, -156.25f,45.1826f,82.0313f, -160.156f,46.2454f,82.0313f, -164.063f,47.0196f,82.0313f, -167.969f,47.2872f,82.0313f, -171.875f,46.2496f,82.0313f, -175.781f,44.3338f,82.0313f, -179.688f,43.1095f,82.0313f, -183.594f,40.7857f,82.0313f, -187.5f,39.646f,82.0313f, -191.406f,37.5425f,82.0313f, -195.313f,35.2951f,82.0313f, -199.219f,33.6324f,82.0313f, -203.125f,30.8911f,82.0313f, -207.031f,27.2798f,82.0313f, -210.938f,25.4308f,82.0313f, -214.844f,23.8814f,82.0313f, -218.75f,22.4441f,82.0313f, -222.656f,20.3771f,82.0313f, -226.563f,19.2073f,82.0313f, -230.469f,19.0082f,82.0313f, -234.375f,17.769f,82.0313f, -238.281f,15.8302f,82.0313f, -242.188f,14.2967f,82.0313f, -246.094f,15.1365f,82.0313f, -250.0f,14.9159f,82.0313f, -3.90625f,18.8244f,78.125f, -7.8125f,19.5283f,78.125f, -11.7188f,20.9466f,78.125f, -15.625f,22.0951f,78.125f, -19.5313f,23.2483f,78.125f, -23.4375f,23.8238f,78.125f, -27.3438f,24.6236f,78.125f, -31.25f,24.0856f,78.125f, -35.1563f,25.6129f,78.125f, -39.0625f,26.8525f,78.125f, -42.9688f,26.9859f,78.125f, -46.875f,26.6403f,78.125f, -50.7813f,26.6419f,78.125f, -54.6875f,27.4236f,78.125f, -58.5938f,26.5989f,78.125f, -62.5f,26.137f,78.125f, -66.4063f,24.8717f,78.125f, -70.3125f,23.8694f,78.125f, -74.2188f,23.2668f,78.125f, -78.125f,23.1081f,78.125f, -82.0313f,23.3134f,78.125f, -85.9375f,23.0903f,78.125f, -89.8438f,23.2822f,78.125f, -93.75f,24.291f,78.125f, -97.6563f,24.5546f,78.125f, -101.563f,24.4216f,78.125f, -105.469f,24.6379f,78.125f, -109.375f,24.5235f,78.125f, -113.281f,24.88f,78.125f, -117.188f,25.6988f,78.125f, -121.094f,26.9155f,78.125f, -125.0f,29.7499f,78.125f, -128.906f,31.361f,78.125f, -132.813f,33.9367f,78.125f, -136.719f,35.4066f,78.125f, -140.625f,36.6153f,78.125f, -144.531f,38.6091f,78.125f, -148.438f,41.2276f,78.125f, -152.344f,43.2187f,78.125f, -156.25f,45.2494f,78.125f, -160.156f,46.5334f,78.125f, -164.063f,47.1659f,78.125f, -167.969f,47.5409f,78.125f, -171.875f,46.3778f,78.125f, -175.781f,44.8935f,78.125f, -179.688f,43.7429f,78.125f, -183.594f,42.4748f,78.125f, -187.5f,40.5234f,78.125f, -191.406f,38.2806f,78.125f, -195.313f,36.297f,78.125f, -199.219f,35.0641f,78.125f, -203.125f,32.4145f,78.125f, -207.031f,29.4539f,78.125f, -210.938f,25.7399f,78.125f, -214.844f,23.157f,78.125f, -218.75f,20.9425f,78.125f, -222.656f,19.2349f,78.125f, -226.563f,18.5576f,78.125f, -230.469f,18.8407f,78.125f, -234.375f,17.6562f,78.125f, -238.281f,15.7207f,78.125f, -242.188f,14.3385f,78.125f, -246.094f,13.9958f,78.125f, -250.0f,14.6888f,78.125f, -3.90625f,20.6829f,74.2188f, -7.8125f,22.7393f,74.2188f, -11.7188f,22.9007f,74.2188f, -15.625f,23.3717f,74.2188f, -19.5313f,23.7991f,74.2188f, -23.4375f,24.5576f,74.2188f, -27.3438f,25.3464f,74.2188f, -31.25f,25.8349f,74.2188f, -35.1563f,26.2326f,74.2188f, -39.0625f,27.8003f,74.2188f, -42.9688f,28.502f,74.2188f, -46.875f,28.7947f,74.2188f, -50.7813f,29.109f,74.2188f, -54.6875f,29.4315f,74.2188f, -58.5938f,29.1948f,74.2188f, -62.5f,28.241f,74.2188f, -66.4063f,26.6727f,74.2188f, -70.3125f,25.5496f,74.2188f, -74.2188f,24.2265f,74.2188f, -78.125f,24.8641f,74.2188f, -82.0313f,24.8692f,74.2188f, -85.9375f,23.8066f,74.2188f, -89.8438f,24.5827f,74.2188f, -93.75f,25.5885f,74.2188f, -97.6563f,25.005f,74.2188f, -101.563f,25.4768f,74.2188f, -105.469f,25.8326f,74.2188f, -109.375f,25.8587f,74.2188f, -113.281f,26.8029f,74.2188f, -117.188f,27.8764f,74.2188f, -121.094f,28.8835f,74.2188f, -125.0f,30.0077f,74.2188f, -128.906f,31.9776f,74.2188f, -132.813f,34.2008f,74.2188f, -136.719f,35.4023f,74.2188f, -140.625f,36.3754f,74.2188f, -144.531f,38.9991f,74.2188f, -148.438f,41.295f,74.2188f, -152.344f,44.1131f,74.2188f, -156.25f,46.2221f,74.2188f, -160.156f,46.7797f,74.2188f, -164.063f,47.446f,74.2188f, -167.969f,47.1396f,74.2188f, -171.875f,45.9937f,74.2188f, -175.781f,45.4284f,74.2188f, -179.688f,45.018f,74.2188f, -183.594f,43.1233f,74.2188f, -187.5f,41.2272f,74.2188f, -191.406f,37.8072f,74.2188f, -195.313f,36.5304f,74.2188f, -199.219f,35.1638f,74.2188f, -203.125f,33.1538f,74.2188f, -207.031f,30.2207f,74.2188f, -210.938f,26.1665f,74.2188f, -214.844f,22.1619f,74.2188f, -218.75f,18.452f,74.2188f, -222.656f,17.0925f,74.2188f, -226.563f,17.3468f,74.2188f, -230.469f,16.447f,74.2188f, -234.375f,15.7197f,74.2188f, -238.281f,14.7889f,74.2188f, -242.188f,13.641f,74.2188f, -246.094f,12.7728f,74.2188f, -250.0f,13.3875f,74.2188f, -3.90625f,22.948f,70.3125f, -7.8125f,24.3431f,70.3125f, -11.7188f,24.6307f,70.3125f, -15.625f,24.9963f,70.3125f, -19.5313f,25.2034f,70.3125f, -23.4375f,25.2791f,70.3125f, -27.3438f,25.8257f,70.3125f, -31.25f,27.1123f,70.3125f, -35.1563f,27.8795f,70.3125f, -39.0625f,28.8437f,70.3125f, -42.9688f,29.8883f,70.3125f, -46.875f,30.6548f,70.3125f, -50.7813f,31.0396f,70.3125f, -54.6875f,31.6324f,70.3125f, -58.5938f,31.5222f,70.3125f, -62.5f,30.4696f,70.3125f, -66.4063f,28.7208f,70.3125f, -70.3125f,26.8611f,70.3125f, -74.2188f,25.6776f,70.3125f, -78.125f,26.1193f,70.3125f, -82.0313f,25.1971f,70.3125f, -85.9375f,24.4814f,70.3125f, -89.8438f,25.1213f,70.3125f, -93.75f,26.1411f,70.3125f, -97.6563f,26.4276f,70.3125f, -101.563f,26.0728f,70.3125f, -105.469f,26.113f,70.3125f, -109.375f,27.5702f,70.3125f, -113.281f,28.6199f,70.3125f, -117.188f,30.054f,70.3125f, -121.094f,30.255f,70.3125f, -125.0f,30.9839f,70.3125f, -128.906f,32.4045f,70.3125f, -132.813f,33.9858f,70.3125f, -136.719f,35.8568f,70.3125f, -140.625f,37.5803f,70.3125f, -144.531f,40.2984f,70.3125f, -148.438f,41.9326f,70.3125f, -152.344f,44.1607f,70.3125f, -156.25f,45.6454f,70.3125f, -160.156f,47.3567f,70.3125f, -164.063f,48.1147f,70.3125f, -167.969f,47.7671f,70.3125f, -171.875f,46.1009f,70.3125f, -175.781f,45.3829f,70.3125f, -179.688f,44.3458f,70.3125f, -183.594f,42.818f,70.3125f, -187.5f,40.5253f,70.3125f, -191.406f,37.6731f,70.3125f, -195.313f,36.7234f,70.3125f, -199.219f,35.0848f,70.3125f, -203.125f,33.0857f,70.3125f, -207.031f,30.0508f,70.3125f, -210.938f,26.741f,70.3125f, -214.844f,22.7613f,70.3125f, -218.75f,18.5375f,70.3125f, -222.656f,15.6052f,70.3125f, -226.563f,14.6945f,70.3125f, -230.469f,15.0013f,70.3125f, -234.375f,13.9965f,70.3125f, -238.281f,12.4404f,70.3125f, -242.188f,12.4448f,70.3125f, -246.094f,11.7446f,70.3125f, -250.0f,11.7886f,70.3125f, -3.90625f,25.5564f,66.4063f, -7.8125f,26.1216f,66.4063f, -11.7188f,26.234f,66.4063f, -15.625f,26.4553f,66.4063f, -19.5313f,26.9827f,66.4063f, -23.4375f,27.0173f,66.4063f, -27.3438f,27.3577f,66.4063f, -31.25f,28.895f,66.4063f, -35.1563f,30.1057f,66.4063f, -39.0625f,30.249f,66.4063f, -42.9688f,31.1394f,66.4063f, -46.875f,31.7197f,66.4063f, -50.7813f,33.2905f,66.4063f, -54.6875f,33.6208f,66.4063f, -58.5938f,33.5152f,66.4063f, -62.5f,31.5128f,66.4063f, -66.4063f,30.1049f,66.4063f, -70.3125f,28.9139f,66.4063f, -74.2188f,27.093f,66.4063f, -78.125f,26.8272f,66.4063f, -82.0313f,25.8777f,66.4063f, -85.9375f,25.2597f,66.4063f, -89.8438f,25.8742f,66.4063f, -93.75f,27.4783f,66.4063f, -97.6563f,27.1897f,66.4063f, -101.563f,26.8406f,66.4063f, -105.469f,27.2889f,66.4063f, -109.375f,28.6616f,66.4063f, -113.281f,29.2852f,66.4063f, -117.188f,30.3362f,66.4063f, -121.094f,32.0648f,66.4063f, -125.0f,32.6693f,66.4063f, -128.906f,33.7239f,66.4063f, -132.813f,34.8193f,66.4063f, -136.719f,36.6878f,66.4063f, -140.625f,38.5422f,66.4063f, -144.531f,40.5193f,66.4063f, -148.438f,42.0434f,66.4063f, -152.344f,43.692f,66.4063f, -156.25f,46.2f,66.4063f, -160.156f,47.7247f,66.4063f, -164.063f,48.3486f,66.4063f, -167.969f,48.4057f,66.4063f, -171.875f,47.4141f,66.4063f, -175.781f,45.925f,66.4063f, -179.688f,44.0772f,66.4063f, -183.594f,42.0866f,66.4063f, -187.5f,40.2687f,66.4063f, -191.406f,38.0236f,66.4063f, -195.313f,36.9223f,66.4063f, -199.219f,35.6323f,66.4063f, -203.125f,33.0001f,66.4063f, -207.031f,30.1425f,66.4063f, -210.938f,26.4551f,66.4063f, -214.844f,22.4224f,66.4063f, -218.75f,18.5557f,66.4063f, -222.656f,16.1428f,66.4063f, -226.563f,14.9942f,66.4063f, -230.469f,14.9221f,66.4063f, -234.375f,13.3816f,66.4063f, -238.281f,10.9914f,66.4063f, -242.188f,10.6094f,66.4063f, -246.094f,9.77905f,66.4063f, -250.0f,9.99853f,66.4063f, -3.90625f,27.1929f,62.5f, -7.8125f,28.1411f,62.5f, -11.7188f,27.9312f,62.5f, -15.625f,27.692f,62.5f, -19.5313f,27.8511f,62.5f, -23.4375f,28.2162f,62.5f, -27.3438f,29.5518f,62.5f, -31.25f,30.2367f,62.5f, -35.1563f,31.1075f,62.5f, -39.0625f,31.6239f,62.5f, -42.9688f,32.8498f,62.5f, -46.875f,33.1521f,62.5f, -50.7813f,34.6411f,62.5f, -54.6875f,35.0063f,62.5f, -58.5938f,33.8006f,62.5f, -62.5f,33.1029f,62.5f, -66.4063f,32.1466f,62.5f, -70.3125f,30.2614f,62.5f, -74.2188f,28.2978f,62.5f, -78.125f,28.0764f,62.5f, -82.0313f,27.2473f,62.5f, -85.9375f,26.2769f,62.5f, -89.8438f,26.2922f,62.5f, -93.75f,27.1235f,62.5f, -97.6563f,27.498f,62.5f, -101.563f,27.2257f,62.5f, -105.469f,28.2897f,62.5f, -109.375f,28.8921f,62.5f, -113.281f,30.563f,62.5f, -117.188f,32.1298f,62.5f, -121.094f,32.8639f,62.5f, -125.0f,34.6537f,62.5f, -128.906f,35.4867f,62.5f, -132.813f,36.6181f,62.5f, -136.719f,37.6418f,62.5f, -140.625f,39.2228f,62.5f, -144.531f,40.5105f,62.5f, -148.438f,42.215f,62.5f, -152.344f,43.5394f,62.5f, -156.25f,45.1171f,62.5f, -160.156f,46.6711f,62.5f, -164.063f,47.4274f,62.5f, -167.969f,47.6821f,62.5f, -171.875f,48.0762f,62.5f, -175.781f,46.4607f,62.5f, -179.688f,44.7623f,62.5f, -183.594f,42.6372f,62.5f, -187.5f,40.3231f,62.5f, -191.406f,38.4371f,62.5f, -195.313f,36.1978f,62.5f, -199.219f,35.38f,62.5f, -203.125f,32.0325f,62.5f, -207.031f,29.2047f,62.5f, -210.938f,27.481f,62.5f, -214.844f,24.0627f,62.5f, -218.75f,20.6235f,62.5f, -222.656f,18.5468f,62.5f, -226.563f,17.2736f,62.5f, -230.469f,15.4125f,62.5f, -234.375f,13.6775f,62.5f, -238.281f,11.4407f,62.5f, -242.188f,9.73154f,62.5f, -246.094f,8.55197f,62.5f, -250.0f,8.43693f,62.5f, -3.90625f,28.3495f,58.5938f, -7.8125f,28.8832f,58.5938f, -11.7188f,28.5512f,58.5938f, -15.625f,28.8533f,58.5938f, -19.5313f,29.0576f,58.5938f, -23.4375f,30.3079f,58.5938f, -27.3438f,31.3861f,58.5938f, -31.25f,33.0252f,58.5938f, -35.1563f,33.4087f,58.5938f, -39.0625f,34.3736f,58.5938f, -42.9688f,34.6944f,58.5938f, -46.875f,34.1156f,58.5938f, -50.7813f,34.7246f,58.5938f, -54.6875f,35.3934f,58.5938f, -58.5938f,34.9508f,58.5938f, -62.5f,34.469f,58.5938f, -66.4063f,33.1584f,58.5938f, -70.3125f,30.5913f,58.5938f, -74.2188f,30.4147f,58.5938f, -78.125f,30.821f,58.5938f, -82.0313f,29.9244f,58.5938f, -85.9375f,28.365f,58.5938f, -89.8438f,27.8694f,58.5938f, -93.75f,27.7517f,58.5938f, -97.6563f,27.9188f,58.5938f, -101.563f,27.7605f,58.5938f, -105.469f,28.252f,58.5938f, -109.375f,29.4592f,58.5938f, -113.281f,31.2608f,58.5938f, -117.188f,33.5373f,58.5938f, -121.094f,34.4995f,58.5938f, -125.0f,35.1593f,58.5938f, -128.906f,36.6148f,58.5938f, -132.813f,37.1425f,58.5938f, -136.719f,38.2148f,58.5938f, -140.625f,38.9964f,58.5938f, -144.531f,40.3196f,58.5938f, -148.438f,42.4959f,58.5938f, -152.344f,43.37f,58.5938f, -156.25f,44.3488f,58.5938f, -160.156f,45.6441f,58.5937f, -164.063f,45.6597f,58.5937f, -167.969f,46.9631f,58.5938f, -171.875f,47.0933f,58.5938f, -175.781f,45.839f,58.5937f, -179.688f,44.0491f,58.5937f, -183.594f,41.6462f,58.5938f, -187.5f,39.9012f,58.5938f, -191.406f,37.8373f,58.5938f, -195.313f,35.0871f,58.5938f, -199.219f,34.6045f,58.5938f, -203.125f,32.4469f,58.5938f, -207.031f,30.5103f,58.5938f, -210.938f,28.7194f,58.5938f, -214.844f,26.3358f,58.5938f, -218.75f,24.3668f,58.5938f, -222.656f,22.1719f,58.5938f, -226.563f,20.1708f,58.5938f, -230.469f,18.1384f,58.5938f, -234.375f,15.6994f,58.5938f, -238.281f,12.6124f,58.5938f, -242.188f,11.2279f,58.5938f, -246.094f,10.4938f,58.5938f, -250.0f,9.45058f,58.5938f, -3.90625f,29.2057f,54.6875f, -7.8125f,29.4161f,54.6875f, -11.7188f,29.6274f,54.6875f, -15.625f,29.8747f,54.6875f, -19.5313f,31.3353f,54.6875f, -23.4375f,32.5261f,54.6875f, -27.3438f,34.3893f,54.6875f, -31.25f,34.9525f,54.6875f, -35.1563f,35.8992f,54.6875f, -39.0625f,36.2066f,54.6875f, -42.9688f,36.4212f,54.6875f, -46.875f,36.1377f,54.6875f, -50.7813f,35.4213f,54.6875f, -54.6875f,35.5045f,54.6875f, -58.5938f,36.0891f,54.6875f, -62.5f,36.0244f,54.6875f, -66.4063f,34.9086f,54.6875f, -70.3125f,32.8671f,54.6875f, -74.2188f,33.5578f,54.6875f, -78.125f,33.8468f,54.6875f, -82.0313f,32.868f,54.6875f, -85.9375f,31.2245f,54.6875f, -89.8438f,29.442f,54.6875f, -93.75f,28.9144f,54.6875f, -97.6563f,27.6797f,54.6875f, -101.563f,27.9585f,54.6875f, -105.469f,28.5492f,54.6875f, -109.375f,29.119f,54.6875f, -113.281f,30.7234f,54.6875f, -117.188f,32.402f,54.6875f, -121.094f,34.3605f,54.6875f, -125.0f,35.6614f,54.6875f, -128.906f,37.1814f,54.6875f, -132.813f,37.8509f,54.6875f, -136.719f,38.3282f,54.6875f, -140.625f,39.021f,54.6875f, -144.531f,39.8455f,54.6875f, -148.438f,41.3547f,54.6875f, -152.344f,42.0848f,54.6875f, -156.25f,42.4546f,54.6875f, -160.156f,43.3035f,54.6875f, -164.063f,44.2757f,54.6875f, -167.969f,45.0917f,54.6875f, -171.875f,44.9479f,54.6875f, -175.781f,44.386f,54.6875f, -179.688f,43.1031f,54.6875f, -183.594f,41.5243f,54.6875f, -187.5f,39.9976f,54.6875f, -191.406f,37.1931f,54.6875f, -195.313f,35.2297f,54.6875f, -199.219f,34.439f,54.6875f, -203.125f,32.7399f,54.6875f, -207.031f,31.4766f,54.6875f, -210.938f,29.9402f,54.6875f, -214.844f,28.6752f,54.6875f, -218.75f,27.0387f,54.6875f, -222.656f,24.4777f,54.6875f, -226.563f,21.7169f,54.6875f, -230.469f,20.0299f,54.6875f, -234.375f,17.3103f,54.6875f, -238.281f,14.1891f,54.6875f, -242.188f,12.1605f,54.6875f, -246.094f,10.9065f,54.6875f, -250.0f,10.6619f,54.6875f, -3.90625f,30.4306f,50.7813f, -7.8125f,30.9679f,50.7813f, -11.7188f,31.3065f,50.7813f, -15.625f,32.0527f,50.7813f, -19.5313f,33.9185f,50.7813f, -23.4375f,34.6834f,50.7813f, -27.3438f,35.8025f,50.7813f, -31.25f,36.824f,50.7813f, -35.1563f,37.9949f,50.7813f, -39.0625f,38.2428f,50.7813f, -42.9688f,37.3912f,50.7813f, -46.875f,37.2849f,50.7813f, -50.7813f,36.4441f,50.7813f, -54.6875f,36.5986f,50.7813f, -58.5938f,36.7371f,50.7813f, -62.5f,36.6154f,50.7813f, -66.4063f,35.9475f,50.7813f, -70.3125f,35.1832f,50.7813f, -74.2188f,35.7876f,50.7813f, -78.125f,35.9086f,50.7813f, -82.0313f,35.0048f,50.7813f, -85.9375f,33.7202f,50.7813f, -89.8438f,32.6473f,50.7813f, -93.75f,30.9552f,50.7813f, -97.6563f,28.7453f,50.7813f, -101.563f,29.1526f,50.7813f, -105.469f,29.9957f,50.7813f, -109.375f,30.5544f,50.7813f, -113.281f,31.6947f,50.7813f, -117.188f,32.7584f,50.7813f, -121.094f,34.2518f,50.7813f, -125.0f,36.3694f,50.7813f, -128.906f,36.9477f,50.7813f, -132.813f,37.2918f,50.7813f, -136.719f,37.8325f,50.7813f, -140.625f,38.0845f,50.7813f, -144.531f,40.0088f,50.7813f, -148.438f,40.8219f,50.7813f, -152.344f,42.4039f,50.7813f, -156.25f,42.6086f,50.7813f, -160.156f,43.5487f,50.7813f, -164.063f,43.5328f,50.7813f, -167.969f,44.212f,50.7812f, -171.875f,43.6744f,50.7813f, -175.781f,43.198f,50.7813f, -179.688f,42.957f,50.7813f, -183.594f,41.4993f,50.7813f, -187.5f,39.5101f,50.7813f, -191.406f,38.1729f,50.7813f, -195.313f,35.4881f,50.7813f, -199.219f,34.6384f,50.7813f, -203.125f,34.1873f,50.7813f, -207.031f,32.1155f,50.7813f, -210.938f,30.912f,50.7813f, -214.844f,30.3391f,50.7813f, -218.75f,28.1256f,50.7813f, -222.656f,24.902f,50.7813f, -226.563f,22.2443f,50.7813f, -230.469f,20.9172f,50.7813f, -234.375f,18.8508f,50.7813f, -238.281f,15.9912f,50.7813f, -242.188f,12.7716f,50.7813f, -246.094f,11.6189f,50.7813f, -250.0f,12.2688f,50.7813f, -3.90625f,30.8772f,46.875f, -7.8125f,32.4754f,46.875f, -11.7188f,33.6983f,46.875f, -15.625f,35.14f,46.875f, -19.5313f,37.0369f,46.875f, -23.4375f,38.369f,46.875f, -27.3438f,38.6134f,46.875f, -31.25f,38.9784f,46.875f, -35.1563f,39.9891f,46.875f, -39.0625f,40.3197f,46.875f, -42.9688f,39.9692f,46.875f, -46.875f,39.6994f,46.875f, -50.7813f,39.4183f,46.875f, -54.6875f,38.2948f,46.875f, -58.5938f,38.32f,46.875f, -62.5f,38.621f,46.875f, -66.4063f,38.2134f,46.875f, -70.3125f,36.9577f,46.875f, -74.2188f,37.2936f,46.875f, -78.125f,37.8653f,46.875f, -82.0313f,36.9058f,46.875f, -85.9375f,36.1841f,46.875f, -89.8438f,34.8143f,46.875f, -93.75f,33.0783f,46.875f, -97.6563f,30.9854f,46.875f, -101.563f,30.934f,46.875f, -105.469f,32.108f,46.875f, -109.375f,33.0462f,46.875f, -113.281f,32.9253f,46.875f, -117.188f,33.3377f,46.875f, -121.094f,34.2153f,46.875f, -125.0f,35.0739f,46.875f, -128.906f,36.8239f,46.875f, -132.813f,37.1463f,46.875f, -136.719f,37.5409f,46.875f, -140.625f,38.8265f,46.875f, -144.531f,40.7241f,46.875f, -148.438f,40.9349f,46.875f, -152.344f,42.4491f,46.875f, -156.25f,43.9695f,46.875f, -160.156f,44.2191f,46.875f, -164.063f,44.9265f,46.875f, -167.969f,43.9423f,46.875f, -171.875f,43.273f,46.875f, -175.781f,43.2543f,46.875f, -179.688f,42.5328f,46.875f, -183.594f,41.1777f,46.875f, -187.5f,39.3553f,46.875f, -191.406f,37.8242f,46.875f, -195.313f,36.4649f,46.875f, -199.219f,35.6955f,46.875f, -203.125f,35.1878f,46.875f, -207.031f,32.9438f,46.875f, -210.938f,31.3677f,46.875f, -214.844f,30.7282f,46.875f, -218.75f,28.3328f,46.875f, -222.656f,25.0599f,46.875f, -226.563f,24.1932f,46.875f, -230.469f,22.3853f,46.875f, -234.375f,19.4896f,46.875f, -238.281f,16.8753f,46.875f, -242.188f,13.9469f,46.875f, -246.094f,13.2975f,46.875f, -250.0f,13.2524f,46.875f, -3.90625f,31.8945f,42.9688f, -7.8125f,34.0117f,42.9688f, -11.7188f,36.2441f,42.9688f, -15.625f,37.3622f,42.9688f, -19.5313f,39.5877f,42.9688f, -23.4375f,41.0994f,42.9688f, -27.3438f,42.0864f,42.9688f, -31.25f,42.0849f,42.9688f, -35.1563f,42.2038f,42.9688f, -39.0625f,43.473f,42.9688f, -42.9688f,42.7754f,42.9688f, -46.875f,42.3177f,42.9688f, -50.7813f,42.209f,42.9688f, -54.6875f,41.3095f,42.9688f, -58.5938f,40.8629f,42.9688f, -62.5f,40.4776f,42.9688f, -66.4063f,40.1396f,42.9688f, -70.3125f,39.1169f,42.9688f, -74.2188f,39.1382f,42.9688f, -78.125f,39.1421f,42.9688f, -82.0313f,38.9022f,42.9688f, -85.9375f,37.5711f,42.9688f, -89.8438f,36.7924f,42.9688f, -93.75f,34.7734f,42.9688f, -97.6563f,33.167f,42.9688f, -101.563f,32.4173f,42.9688f, -105.469f,33.0466f,42.9688f, -109.375f,33.3882f,42.9688f, -113.281f,33.7538f,42.9688f, -117.188f,33.5661f,42.9688f, -121.094f,33.9051f,42.9688f, -125.0f,34.9181f,42.9688f, -128.906f,35.2925f,42.9688f, -132.813f,37.1741f,42.9688f, -136.719f,38.0993f,42.9688f, -140.625f,38.7621f,42.9688f, -144.531f,39.712f,42.9688f, -148.438f,40.7257f,42.9688f, -152.344f,42.2465f,42.9688f, -156.25f,43.5331f,42.9688f, -160.156f,44.6745f,42.9687f, -164.063f,44.564f,42.9688f, -167.969f,44.6075f,42.9688f, -171.875f,43.2227f,42.9688f, -175.781f,42.5688f,42.9688f, -179.688f,41.9742f,42.9688f, -183.594f,40.3484f,42.9688f, -187.5f,38.9109f,42.9688f, -191.406f,37.7273f,42.9688f, -195.313f,36.5287f,42.9688f, -199.219f,35.9361f,42.9688f, -203.125f,35.1638f,42.9688f, -207.031f,33.6615f,42.9688f, -210.938f,31.2785f,42.9688f, -214.844f,30.1259f,42.9688f, -218.75f,28.6143f,42.9688f, -222.656f,26.1162f,42.9688f, -226.563f,24.2882f,42.9688f, -230.469f,22.5195f,42.9688f, -234.375f,20.1462f,42.9688f, -238.281f,17.4811f,42.9688f, -242.188f,15.2736f,42.9688f, -246.094f,13.788f,42.9688f, -250.0f,13.1723f,42.9688f, -3.90625f,34.9171f,39.0625f, -7.8125f,36.7711f,39.0625f, -11.7188f,38.5677f,39.0625f, -15.625f,40.0524f,39.0625f, -19.5313f,42.2392f,39.0625f, -23.4375f,43.2332f,39.0625f, -27.3438f,44.8254f,39.0625f, -31.25f,45.1808f,39.0625f, -35.1563f,44.9684f,39.0625f, -39.0625f,45.0647f,39.0625f, -42.9688f,45.0888f,39.0625f, -46.875f,45.5266f,39.0625f, -50.7813f,45.2542f,39.0625f, -54.6875f,44.1797f,39.0625f, -58.5938f,43.2658f,39.0625f, -62.5f,42.7568f,39.0625f, -66.4063f,42.4159f,39.0625f, -70.3125f,41.3883f,39.0625f, -74.2188f,41.1975f,39.0625f, -78.125f,41.3073f,39.0625f, -82.0313f,41.0587f,39.0625f, -85.9375f,40.0611f,39.0625f, -89.8438f,38.7299f,39.0625f, -93.75f,37.2923f,39.0625f, -97.6563f,35.7971f,39.0625f, -101.563f,35.1982f,39.0625f, -105.469f,33.6408f,39.0625f, -109.375f,33.2619f,39.0625f, -113.281f,33.8387f,39.0625f, -117.188f,34.7554f,39.0625f, -121.094f,33.8569f,39.0625f, -125.0f,34.7741f,39.0625f, -128.906f,35.7319f,39.0625f, -132.813f,36.6023f,39.0625f, -136.719f,37.7084f,39.0625f, -140.625f,38.2513f,39.0625f, -144.531f,39.1992f,39.0625f, -148.438f,40.2336f,39.0625f, -152.344f,41.0883f,39.0625f, -156.25f,42.4004f,39.0625f, -160.156f,42.8753f,39.0625f, -164.063f,43.1631f,39.0625f, -167.969f,43.6378f,39.0625f, -171.875f,43.2113f,39.0625f, -175.781f,42.5474f,39.0625f, -179.688f,41.3413f,39.0625f, -183.594f,39.4383f,39.0625f, -187.5f,38.9723f,39.0625f, -191.406f,37.3549f,39.0625f, -195.313f,35.8615f,39.0625f, -199.219f,34.9243f,39.0625f, -203.125f,34.598f,39.0625f, -207.031f,33.6592f,39.0625f, -210.938f,32.2347f,39.0625f, -214.844f,30.4117f,39.0625f, -218.75f,28.4787f,39.0625f, -222.656f,26.6538f,39.0625f, -226.563f,24.4892f,39.0625f, -230.469f,22.9637f,39.0625f, -234.375f,20.6363f,39.0625f, -238.281f,18.4584f,39.0625f, -242.188f,16.293f,39.0625f, -246.094f,13.7473f,39.0625f, -250.0f,13.2449f,39.0625f, -3.90625f,38.5427f,35.1563f, -7.8125f,39.2771f,35.1563f, -11.7188f,40.4801f,35.1563f, -15.625f,42.2714f,35.1563f, -19.5313f,44.0743f,35.1562f, -23.4375f,45.9071f,35.1562f, -27.3438f,47.4425f,35.1563f, -31.25f,47.765f,35.1563f, -35.1563f,46.8453f,35.1562f, -39.0625f,47.1161f,35.1562f, -42.9688f,46.591f,35.1563f, -46.875f,47.4064f,35.1563f, -50.7813f,47.2001f,35.1562f, -54.6875f,47.2372f,35.1562f, -58.5938f,46.9666f,35.1563f, -62.5f,45.3322f,35.1563f, -66.4063f,44.4351f,35.1562f, -70.3125f,43.869f,35.1562f, -74.2188f,43.7604f,35.1563f, -78.125f,43.6414f,35.1563f, -82.0313f,43.6044f,35.1563f, -85.9375f,41.9765f,35.1563f, -89.8438f,40.597f,35.1563f, -93.75f,38.8088f,35.1563f, -97.6563f,37.4254f,35.1563f, -101.563f,36.4869f,35.1563f, -105.469f,34.7975f,35.1563f, -109.375f,32.6051f,35.1563f, -113.281f,32.3929f,35.1563f, -117.188f,33.3906f,35.1563f, -121.094f,33.728f,35.1563f, -125.0f,33.8089f,35.1563f, -128.906f,35.2443f,35.1563f, -132.813f,35.9877f,35.1563f, -136.719f,36.3747f,35.1563f, -140.625f,37.6045f,35.1563f, -144.531f,38.3698f,35.1563f, -148.438f,39.393f,35.1563f, -152.344f,40.0115f,35.1563f, -156.25f,40.8722f,35.1563f, -160.156f,40.7302f,35.1563f, -164.063f,41.6767f,35.1563f, -167.969f,42.1719f,35.1563f, -171.875f,41.924f,35.1563f, -175.781f,40.9628f,35.1563f, -179.688f,39.3209f,35.1563f, -183.594f,37.9615f,35.1563f, -187.5f,37.2902f,35.1563f, -191.406f,36.1521f,35.1563f, -195.313f,35.5697f,35.1563f, -199.219f,35.0547f,35.1563f, -203.125f,33.8422f,35.1563f, -207.031f,33.1699f,35.1563f, -210.938f,32.4197f,35.1563f, -214.844f,31.0723f,35.1563f, -218.75f,29.1069f,35.1563f, -222.656f,26.4015f,35.1563f, -226.563f,23.6862f,35.1563f, -230.469f,22.3142f,35.1563f, -234.375f,20.9225f,35.1563f, -238.281f,18.6533f,35.1563f, -242.188f,16.5438f,35.1563f, -246.094f,14.5457f,35.1563f, -250.0f,13.5112f,35.1563f, -3.90625f,41.4381f,31.25f, -7.8125f,41.4661f,31.25f, -11.7188f,42.5211f,31.25f, -15.625f,44.1517f,31.25f, -19.5313f,45.8301f,31.25f, -23.4375f,47.3213f,31.25f, -27.3438f,49.1504f,31.25f, -31.25f,49.1313f,31.25f, -35.1563f,48.4621f,31.25f, -39.0625f,48.0866f,31.25f, -42.9688f,47.5259f,31.25f, -46.875f,48.2042f,31.25f, -50.7813f,48.2678f,31.25f, -54.6875f,48.6796f,31.25f, -58.5938f,49.1508f,31.25f, -62.5f,48.5261f,31.25f, -66.4063f,47.2699f,31.25f, -70.3125f,46.3239f,31.25f, -74.2188f,45.9053f,31.25f, -78.125f,45.2948f,31.25f, -82.0313f,45.1222f,31.25f, -85.9375f,44.1773f,31.25f, -89.8438f,42.0751f,31.25f, -93.75f,39.8181f,31.25f, -97.6563f,38.1904f,31.25f, -101.563f,36.9029f,31.25f, -105.469f,35.9897f,31.25f, -109.375f,34.1082f,31.25f, -113.281f,33.9882f,31.25f, -117.188f,33.4544f,31.25f, -121.094f,32.7435f,31.25f, -125.0f,32.2982f,31.25f, -128.906f,33.2893f,31.25f, -132.813f,34.4302f,31.25f, -136.719f,35.501f,31.25f, -140.625f,36.4162f,31.25f, -144.531f,38.0795f,31.25f, -148.438f,38.4184f,31.25f, -152.344f,38.1695f,31.25f, -156.25f,39.1334f,31.25f, -160.156f,39.8018f,31.25f, -164.063f,40.4009f,31.25f, -167.969f,40.6662f,31.25f, -171.875f,40.6389f,31.25f, -175.781f,40.0005f,31.25f, -179.688f,38.1437f,31.25f, -183.594f,36.1677f,31.25f, -187.5f,35.7553f,31.25f, -191.406f,35.2539f,31.25f, -195.313f,34.5258f,31.25f, -199.219f,33.9511f,31.25f, -203.125f,33.8209f,31.25f, -207.031f,32.5194f,31.25f, -210.938f,31.6797f,31.25f, -214.844f,30.494f,31.25f, -218.75f,28.9089f,31.25f, -222.656f,27.096f,31.25f, -226.563f,23.5752f,31.25f, -230.469f,22.5423f,31.25f, -234.375f,20.8438f,31.25f, -238.281f,18.7938f,31.25f, -242.188f,16.7022f,31.25f, -246.094f,14.6115f,31.25f, -250.0f,12.7758f,31.25f, -3.90625f,42.7334f,27.3437f, -7.8125f,43.3658f,27.3438f, -11.7188f,44.93f,27.3437f, -15.625f,46.7113f,27.3438f, -19.5313f,48.1031f,27.3437f, -23.4375f,48.7173f,27.3438f, -27.3438f,49.0875f,27.3437f, -31.25f,50.1272f,27.3438f, -35.1563f,49.1784f,27.3437f, -39.0625f,50.4569f,27.3438f, -42.9688f,49.7216f,27.3437f, -46.875f,49.0563f,27.3438f, -50.7813f,48.7494f,27.3437f, -54.6875f,49.0519f,27.3438f, -58.5938f,49.8264f,27.3437f, -62.5f,49.8194f,27.3438f, -66.4063f,48.9033f,27.3437f, -70.3125f,47.5002f,27.3438f, -74.2188f,46.7308f,27.3437f, -78.125f,45.8132f,27.3438f, -82.0313f,45.4303f,27.3437f, -85.9375f,44.4837f,27.3438f, -89.8438f,42.6706f,27.3437f, -93.75f,40.5108f,27.3438f, -97.6563f,38.4748f,27.3437f, -101.563f,38.2458f,27.3438f, -105.469f,37.8191f,27.3437f, -109.375f,37.5503f,27.3438f, -113.281f,36.4883f,27.3437f, -117.188f,35.7025f,27.3438f, -121.094f,34.3569f,27.3437f, -125.0f,34.052f,27.3438f, -128.906f,34.3166f,27.3437f, -132.813f,33.9873f,27.3438f, -136.719f,33.8326f,27.3437f, -140.625f,35.5138f,27.3438f, -144.531f,35.9847f,27.3437f, -148.438f,36.3159f,27.3438f, -152.344f,38.1026f,27.3437f, -156.25f,39.0191f,27.3438f, -160.156f,39.0705f,27.3437f, -164.063f,38.9644f,27.3438f, -167.969f,38.0972f,27.3437f, -171.875f,38.277f,27.3438f, -175.781f,37.5686f,27.3437f, -179.688f,35.9897f,27.3438f, -183.594f,34.1554f,27.3437f, -187.5f,33.9646f,27.3438f, -191.406f,33.9556f,27.3437f, -195.313f,33.7374f,27.3438f, -199.219f,33.3736f,27.3437f, -203.125f,32.1967f,27.3438f, -207.031f,32.2131f,27.3437f, -210.938f,30.4757f,27.3438f, -214.844f,29.0495f,27.3437f, -218.75f,27.539f,27.3438f, -222.656f,25.7435f,27.3437f, -226.563f,23.5358f,27.3438f, -230.469f,22.5305f,27.3437f, -234.375f,20.3466f,27.3438f, -238.281f,18.5956f,27.3438f, -242.188f,16.6554f,27.3438f, -246.094f,14.7633f,27.3438f, -250.0f,12.979f,27.3438f, -3.90625f,44.6783f,23.4375f, -7.8125f,46.1279f,23.4375f, -11.7188f,47.9921f,23.4375f, -15.625f,48.593f,23.4375f, -19.5313f,49.826f,23.4375f, -23.4375f,50.0111f,23.4375f, -27.3438f,49.773f,23.4375f, -31.25f,50.6443f,23.4375f, -35.1563f,50.242f,23.4375f, -39.0625f,51.5289f,23.4375f, -42.9688f,51.3905f,23.4375f, -46.875f,50.5543f,23.4375f, -50.7813f,49.96f,23.4375f, -54.6875f,51.029f,23.4375f, -58.5938f,50.4996f,23.4375f, -62.5f,50.0508f,23.4375f, -66.4063f,49.4463f,23.4375f, -70.3125f,48.7613f,23.4375f, -74.2188f,48.0188f,23.4375f, -78.125f,48.0992f,23.4375f, -82.0313f,47.1947f,23.4375f, -85.9375f,45.1889f,23.4375f, -89.8438f,43.9247f,23.4375f, -93.75f,41.7965f,23.4375f, -97.6563f,40.363f,23.4375f, -101.563f,40.3201f,23.4375f, -105.469f,39.2422f,23.4375f, -109.375f,38.6318f,23.4375f, -113.281f,37.9263f,23.4375f, -117.188f,37.113f,23.4375f, -121.094f,35.4884f,23.4375f, -125.0f,35.8385f,23.4375f, -128.906f,35.4941f,23.4375f, -132.813f,34.1911f,23.4375f, -136.719f,33.6791f,23.4375f, -140.625f,33.4506f,23.4375f, -144.531f,35.4822f,23.4375f, -148.438f,36.0187f,23.4375f, -152.344f,38.231f,23.4375f, -156.25f,39.1197f,23.4375f, -160.156f,38.9095f,23.4375f, -164.063f,38.1737f,23.4375f, -167.969f,36.7498f,23.4375f, -171.875f,36.6113f,23.4375f, -175.781f,35.5895f,23.4375f, -179.688f,34.7415f,23.4375f, -183.594f,32.6574f,23.4375f, -187.5f,32.5837f,23.4375f, -191.406f,32.5272f,23.4375f, -195.313f,32.3611f,23.4375f, -199.219f,31.4784f,23.4375f, -203.125f,30.8078f,23.4375f, -207.031f,29.9524f,23.4375f, -210.938f,29.9998f,23.4375f, -214.844f,28.4828f,23.4375f, -218.75f,26.6709f,23.4375f, -222.656f,24.9874f,23.4375f, -226.563f,23.0213f,23.4375f, -230.469f,21.3587f,23.4375f, -234.375f,19.0527f,23.4375f, -238.281f,18.1056f,23.4375f, -242.188f,16.7916f,23.4375f, -246.094f,14.9561f,23.4375f, -250.0f,13.0063f,23.4375f, -3.90625f,46.9055f,19.5312f, -7.8125f,48.3769f,19.5312f, -11.7188f,50.0613f,19.5312f, -15.625f,50.9962f,19.5312f, -19.5313f,51.161f,19.5312f, -23.4375f,51.7721f,19.5312f, -27.3438f,51.5823f,19.5312f, -31.25f,51.5274f,19.5312f, -35.1563f,51.5913f,19.5312f, -39.0625f,52.4399f,19.5312f, -42.9688f,52.5999f,19.5312f, -46.875f,51.9309f,19.5312f, -50.7813f,51.6062f,19.5312f, -54.6875f,50.86f,19.5312f, -58.5938f,51.1496f,19.5312f, -62.5f,50.1957f,19.5312f, -66.4063f,49.8047f,19.5312f, -70.3125f,49.1838f,19.5312f, -74.2188f,48.7276f,19.5312f, -78.125f,48.4967f,19.5312f, -82.0313f,47.4515f,19.5312f, -85.9375f,46.2594f,19.5312f, -89.8438f,44.6756f,19.5312f, -93.75f,43.0377f,19.5312f, -97.6563f,41.3508f,19.5312f, -101.563f,40.8261f,19.5312f, -105.469f,40.5524f,19.5312f, -109.375f,39.7289f,19.5312f, -113.281f,38.9437f,19.5312f, -117.188f,38.3781f,19.5312f, -121.094f,36.9618f,19.5312f, -125.0f,35.9735f,19.5312f, -128.906f,35.3887f,19.5312f, -132.813f,34.5133f,19.5312f, -136.719f,34.7253f,19.5312f, -140.625f,33.9228f,19.5312f, -144.531f,34.2826f,19.5312f, -148.438f,35.5643f,19.5312f, -152.344f,37.7492f,19.5312f, -156.25f,38.7871f,19.5312f, -160.156f,38.6036f,19.5312f, -164.063f,38.2702f,19.5312f, -167.969f,35.931f,19.5312f, -171.875f,34.8252f,19.5312f, -175.781f,33.99f,19.5312f, -179.688f,33.664f,19.5312f, -183.594f,31.6973f,19.5312f, -187.5f,31.3559f,19.5312f, -191.406f,31.3589f,19.5312f, -195.313f,30.7614f,19.5312f, -199.219f,29.2596f,19.5312f, -203.125f,28.7711f,19.5312f, -207.031f,27.9455f,19.5312f, -210.938f,28.3339f,19.5312f, -214.844f,28.3863f,19.5312f, -218.75f,27.4513f,19.5312f, -222.656f,25.0652f,19.5312f, -226.563f,23.2291f,19.5312f, -230.469f,20.8477f,19.5313f, -234.375f,19.424f,19.5313f, -238.281f,17.7051f,19.5313f, -242.188f,16.5977f,19.5313f, -246.094f,14.7851f,19.5313f, -250.0f,12.8344f,19.5313f, -3.90625f,49.2295f,15.625f, -7.8125f,50.0754f,15.625f, -11.7188f,51.5873f,15.625f, -15.625f,52.0525f,15.625f, -19.5313f,51.4269f,15.625f, -23.4375f,51.8405f,15.625f, -27.3438f,52.3327f,15.625f, -31.25f,53.011f,15.625f, -35.1563f,52.7359f,15.625f, -39.0625f,53.2852f,15.625f, -42.9688f,53.6617f,15.625f, -46.875f,52.4883f,15.625f, -50.7813f,51.9362f,15.625f, -54.6875f,50.8372f,15.625f, -58.5938f,50.1782f,15.625f, -62.5f,49.0401f,15.625f, -66.4063f,49.1011f,15.625f, -70.3125f,48.7903f,15.625f, -74.2188f,48.6124f,15.625f, -78.125f,48.1259f,15.625f, -82.0313f,47.7267f,15.625f, -85.9375f,46.9214f,15.625f, -89.8438f,45.0939f,15.625f, -93.75f,43.6563f,15.625f, -97.6563f,42.5709f,15.625f, -101.563f,41.9572f,15.625f, -105.469f,40.973f,15.625f, -109.375f,40.7682f,15.625f, -113.281f,39.3641f,15.625f, -117.188f,39.2768f,15.625f, -121.094f,37.5977f,15.625f, -125.0f,36.0608f,15.625f, -128.906f,36.045f,15.625f, -132.813f,35.1379f,15.625f, -136.719f,34.9875f,15.625f, -140.625f,34.0482f,15.625f, -144.531f,33.8104f,15.625f, -148.438f,34.9994f,15.625f, -152.344f,36.2664f,15.625f, -156.25f,37.7694f,15.625f, -160.156f,37.6584f,15.625f, -164.063f,36.9226f,15.625f, -167.969f,34.7519f,15.625f, -171.875f,33.2827f,15.625f, -175.781f,32.8949f,15.625f, -179.688f,32.1339f,15.625f, -183.594f,30.407f,15.625f, -187.5f,28.996f,15.625f, -191.406f,29.3357f,15.625f, -195.313f,29.1098f,15.625f, -199.219f,27.8354f,15.625f, -203.125f,26.4739f,15.625f, -207.031f,26.1829f,15.625f, -210.938f,27.387f,15.625f, -214.844f,27.4944f,15.625f, -218.75f,26.4893f,15.625f, -222.656f,24.7764f,15.625f, -226.563f,22.9689f,15.625f, -230.469f,20.4237f,15.625f, -234.375f,18.8049f,15.625f, -238.281f,17.4547f,15.625f, -242.188f,16.2758f,15.625f, -246.094f,14.2192f,15.625f, -250.0f,11.8103f,15.625f, -3.90625f,51.1233f,11.7187f, -7.8125f,51.8127f,11.7187f, -11.7188f,52.0971f,11.7187f, -15.625f,51.8317f,11.7187f, -19.5313f,52.1213f,11.7187f, -23.4375f,51.7889f,11.7187f, -27.3438f,52.2065f,11.7187f, -31.25f,52.438f,11.7187f, -35.1563f,52.6021f,11.7187f, -39.0625f,53.2864f,11.7187f, -42.9688f,52.8882f,11.7187f, -46.875f,52.6009f,11.7187f, -50.7813f,52.8442f,11.7187f, -54.6875f,52.6512f,11.7187f, -58.5938f,51.6436f,11.7187f, -62.5f,50.4271f,11.7187f, -66.4063f,49.3264f,11.7187f, -70.3125f,48.6522f,11.7187f, -74.2188f,49.5854f,11.7187f, -78.125f,50.3492f,11.7187f, -82.0313f,49.035f,11.7187f, -85.9375f,47.6474f,11.7187f, -89.8438f,46.0472f,11.7187f, -93.75f,44.7337f,11.7187f, -97.6563f,44.3349f,11.7187f, -101.563f,43.475f,11.7187f, -105.469f,42.9461f,11.7187f, -109.375f,41.7731f,11.7187f, -113.281f,40.717f,11.7187f, -117.188f,39.399f,11.7187f, -121.094f,38.1327f,11.7187f, -125.0f,36.3286f,11.7187f, -128.906f,36.2512f,11.7187f, -132.813f,35.1997f,11.7187f, -136.719f,33.9406f,11.7187f, -140.625f,33.3109f,11.7187f, -144.531f,33.8153f,11.7187f, -148.438f,33.6823f,11.7187f, -152.344f,34.7077f,11.7187f, -156.25f,35.4472f,11.7187f, -160.156f,35.6332f,11.7187f, -164.063f,34.3651f,11.7187f, -167.969f,32.9876f,11.7187f, -171.875f,32.2858f,11.7187f, -175.781f,32.1374f,11.7187f, -179.688f,30.9575f,11.7187f, -183.594f,29.1111f,11.7187f, -187.5f,28.149f,11.7187f, -191.406f,27.4443f,11.7187f, -195.313f,27.3781f,11.7187f, -199.219f,26.4413f,11.7187f, -203.125f,24.9734f,11.7187f, -207.031f,25.0959f,11.7187f, -210.938f,26.2472f,11.7187f, -214.844f,26.1569f,11.7187f, -218.75f,24.8556f,11.7187f, -222.656f,22.8797f,11.7187f, -226.563f,21.8102f,11.7187f, -230.469f,19.294f,11.7187f, -234.375f,17.5291f,11.7187f, -238.281f,16.242f,11.7187f, -242.188f,15.2738f,11.7187f, -246.094f,13.8715f,11.7187f, -250.0f,12.3043f,11.7187f, -3.90625f,52.2527f,7.8125f, -7.8125f,52.7759f,7.8125f, -11.7188f,52.1635f,7.8125f, -15.625f,52.2016f,7.8125f, -19.5313f,51.9832f,7.8125f, -23.4375f,51.4669f,7.8125f, -27.3438f,51.0033f,7.8125f, -31.25f,50.7124f,7.8125f, -35.1563f,51.6427f,7.8125f, -39.0625f,52.5008f,7.8125f, -42.9688f,53.2834f,7.8125f, -46.875f,52.5339f,7.8125f, -50.7813f,52.627f,7.8125f, -54.6875f,52.9017f,7.8125f, -58.5938f,52.8616f,7.8125f, -62.5f,51.7566f,7.8125f, -66.4063f,51.3268f,7.8125f, -70.3125f,50.6108f,7.8125f, -74.2188f,50.9277f,7.8125f, -78.125f,51.701f,7.8125f, -82.0313f,50.5549f,7.8125f, -85.9375f,48.4345f,7.8125f, -89.8438f,47.3592f,7.8125f, -93.75f,45.7216f,7.8125f, -97.6563f,45.75f,7.8125f, -101.563f,44.4249f,7.8125f, -105.469f,44.7192f,7.8125f, -109.375f,44.4938f,7.8125f, -113.281f,43.252f,7.8125f, -117.188f,41.3735f,7.8125f, -121.094f,39.8664f,7.8125f, -125.0f,37.025f,7.8125f, -128.906f,36.5094f,7.8125f, -132.813f,35.3554f,7.8125f, -136.719f,33.9389f,7.8125f, -140.625f,32.7715f,7.8125f, -144.531f,32.8295f,7.8125f, -148.438f,32.4513f,7.8125f, -152.344f,33.4598f,7.8125f, -156.25f,34.3434f,7.8125f, -160.156f,34.8633f,7.8125f, -164.063f,33.7043f,7.8125f, -167.969f,32.5629f,7.8125f, -171.875f,31.5117f,7.8125f, -175.781f,30.9816f,7.8125f, -179.688f,30.2039f,7.8125f, -183.594f,28.5054f,7.8125f, -187.5f,26.8519f,7.8125f, -191.406f,25.6078f,7.8125f, -195.313f,26.0906f,7.8125f, -199.219f,25.313f,7.8125f, -203.125f,24.0014f,7.8125f, -207.031f,24.066f,7.8125f, -210.938f,24.4935f,7.8125f, -214.844f,24.3803f,7.8125f, -218.75f,23.0075f,7.8125f, -222.656f,21.1023f,7.8125f, -226.563f,19.0418f,7.8125f, -230.469f,17.9588f,7.8125f, -234.375f,16.5211f,7.8125f, -238.281f,15.4949f,7.8125f, -242.188f,14.0938f,7.8125f, -246.094f,13.3141f,7.8125f, -250.0f,12.9595f,7.8125f, -3.90625f,52.6186f,3.90625f, -7.8125f,51.8648f,3.90625f, -11.7188f,51.1949f,3.90625f, -15.625f,50.2102f,3.90625f, -19.5313f,50.6058f,3.90625f, -23.4375f,50.7008f,3.90625f, -27.3438f,51.2163f,3.90625f, -31.25f,51.4263f,3.90625f, -35.1563f,52.1968f,3.90625f, -39.0625f,53.9783f,3.90625f, -42.9688f,53.8927f,3.90625f, -46.875f,53.3266f,3.90625f, -50.7813f,53.5901f,3.90625f, -54.6875f,55.5679f,3.90625f, -58.5938f,55.1819f,3.90625f, -62.5f,53.6891f,3.90625f, -66.4063f,53.0541f,3.90625f, -70.3125f,51.6665f,3.90625f, -74.2188f,51.4469f,3.90625f, -78.125f,51.9591f,3.90625f, -82.0313f,51.0418f,3.90625f, -85.9375f,49.7513f,3.90625f, -89.8438f,48.7329f,3.90625f, -93.75f,46.8713f,3.90625f, -97.6563f,46.3905f,3.90625f, -101.563f,45.4241f,3.90625f, -105.469f,45.6811f,3.90625f, -109.375f,45.3238f,3.90625f, -113.281f,43.6112f,3.90625f, -117.188f,42.1291f,3.90625f, -121.094f,40.4747f,3.90625f, -125.0f,39.3351f,3.90625f, -128.906f,38.0742f,3.90625f, -132.813f,36.7758f,3.90625f, -136.719f,34.9213f,3.90625f, -140.625f,32.3643f,3.90625f, -144.531f,31.7157f,3.90625f, -148.438f,30.6005f,3.90625f, -152.344f,31.6034f,3.90625f, -156.25f,32.6503f,3.90625f, -160.156f,33.3131f,3.90625f, -164.063f,32.5745f,3.90625f, -167.969f,31.5017f,3.90625f, -171.875f,30.6842f,3.90625f, -175.781f,29.8734f,3.90625f, -179.688f,28.6537f,3.90625f, -183.594f,27.2073f,3.90625f, -187.5f,25.4367f,3.90625f, -191.406f,24.1609f,3.90625f, -195.313f,23.9724f,3.90625f, -199.219f,23.7702f,3.90625f, -203.125f,22.4031f,3.90625f, -207.031f,22.1587f,3.90625f, -210.938f,21.6154f,3.90625f, -214.844f,21.8202f,3.90625f, -218.75f,21.017f,3.90625f, -222.656f,19.3736f,3.90625f, -226.563f,18.2127f,3.90625f, -230.469f,17.2263f,3.90625f, -234.375f,16.2938f,3.90625f, -238.281f,14.4518f,3.90625f, -242.188f,13.6398f,3.90625f, -246.094f,13.2404f,3.90625f, -250.0f,12.7102f,3.90625f, -}; - -btScalar Landscape04Nml[] = { --0.350125f,0.914758f,-0.201568f, --0.310159f,0.930741f,-0.193707f, --0.297809f,0.93918f,-0.171025f, --0.203808f,0.975413f,-0.083855f, --0.227869f,0.971729f,-0.0617958f, --0.175976f,0.984209f,0.0190985f, --0.113434f,0.992992f,-0.0331636f, --0.10748f,0.994138f,-0.0117748f, -0.264437f,0.964372f,0.00769155f, -0.281666f,0.958691f,0.0397075f, -0.430486f,0.901936f,-0.0345351f, -0.401178f,0.915992f,-0.00383073f, -0.323069f,0.944057f,-0.0662002f, -0.321744f,0.945983f,-0.039967f, -0.269775f,0.962292f,-0.0348534f, -0.20193f,0.970428f,-0.132266f, -0.268889f,0.954681f,-0.127604f, -0.194635f,0.954618f,-0.225435f, -0.221506f,0.956393f,-0.190387f, -0.193103f,0.932235f,-0.306022f, -0.127904f,0.985279f,-0.113427f, -0.190082f,0.941797f,-0.277285f, --0.00897869f,0.999816f,0.0169309f, -0.104995f,0.98929f,-0.101393f, --0.0904331f,0.992726f,0.0794834f, -0.0230108f,0.991613f,0.127174f, -0.0155488f,0.993572f,0.11213f, -0.0288983f,0.981821f,0.187597f, -0.0247864f,0.996149f,0.0840949f, --0.0831472f,0.996537f,0.000391199f, --0.0501709f,0.99867f,0.0118531f, --0.153f,0.976743f,-0.15021f, --0.106591f,0.988499f,-0.107277f, --0.178503f,0.946807f,-0.267757f, --0.0254657f,0.984638f,-0.172739f, --0.00387521f,0.963955f,-0.266035f, --0.0158619f,0.994497f,-0.103554f, -0.0516719f,0.979433f,-0.195043f, --0.113536f,0.993496f,-0.00869834f, --0.0532458f,0.993386f,-0.101726f, --0.240923f,0.970479f,0.0112676f, --0.272825f,0.959264f,-0.0733371f, --0.364171f,0.921854f,-0.132533f, --0.38043f,0.901643f,-0.205699f, --0.208475f,0.967633f,-0.142215f, --0.200209f,0.964847f,-0.170257f, --0.436593f,0.880066f,-0.186734f, --0.420663f,0.90307f,-0.0866427f, --0.564169f,0.813693f,-0.140058f, --0.556718f,0.83037f,-0.0234562f, --0.419122f,0.896066f,-0.146295f, --0.466908f,0.873897f,-0.135282f, --0.39151f,0.89596f,-0.209704f, --0.388383f,0.911455f,-0.135677f, --0.356022f,0.918213f,-0.173589f, --0.334437f,0.939184f,-0.0780065f, --0.257665f,0.953587f,-0.155824f, --0.309301f,0.93272f,-0.185382f, --0.315034f,0.931862f,-0.179961f, --0.295926f,0.931298f,-0.212393f, --0.436779f,0.896592f,-0.0731173f, --0.317368f,0.948237f,0.0111289f, --0.503169f,0.863334f,0.0383931f, --0.468116f,0.877337f,0.105583f, --0.41232f,0.911034f,0.00307775f, --0.465256f,0.885053f,0.0147642f, --0.139311f,0.987488f,-0.0738976f, --0.20689f,0.974976f,-0.0813499f, --0.0453849f,0.98457f,-0.169006f, --0.109269f,0.973649f,-0.20017f, -0.0405907f,0.980595f,-0.191794f, -0.0742781f,0.990348f,-0.117022f, --0.00934593f,0.982385f,-0.186633f, -0.00811898f,0.984163f,-0.177079f, --0.0726933f,0.996391f,-0.043832f, -0.0160265f,0.999861f,-0.00453309f, --0.163053f,0.986585f,0.00801872f, --0.185529f,0.978031f,-0.0950467f, --0.137829f,0.987875f,0.0714611f, --0.0578854f,0.998186f,0.0165557f, -0.148249f,0.976119f,0.158788f, -0.193139f,0.975453f,0.10578f, -0.369772f,0.912299f,0.176006f, -0.348645f,0.936628f,0.0342667f, -0.282769f,0.952501f,0.113063f, -0.239504f,0.96906f,-0.059674f, -0.137712f,0.990197f,0.0233582f, -0.149987f,0.988306f,0.0274647f, -0.169834f,0.984573f,-0.0420991f, -0.0927723f,0.990592f,-0.100603f, -0.171676f,0.97845f,-0.114732f, -0.0567364f,0.963622f,-0.261179f, -0.117062f,0.969073f,-0.217242f, -0.0434058f,0.931949f,-0.359981f, -0.148347f,0.946865f,-0.285375f, -0.103327f,0.903437f,-0.416082f, -0.28421f,0.914779f,-0.287061f, -0.391793f,0.893555f,-0.21922f, -0.419866f,0.888994f,-0.182764f, -0.461528f,0.873246f,-0.156313f, -0.483081f,0.869853f,-0.099941f, -0.503438f,0.857022f,-0.109831f, -0.46584f,0.882166f,-0.0691099f, -0.489623f,0.868073f,-0.0819641f, -0.410796f,0.910896f,-0.0389227f, -0.393119f,0.918063f,-0.0511611f, -0.359627f,0.921042f,-0.1495f, -0.306646f,0.942147f,-0.135377f, -0.381773f,0.903228f,-0.196033f, -0.360002f,0.920948f,-0.149176f, -0.203221f,0.945872f,-0.253037f, -0.218471f,0.943498f,-0.249162f, -0.0567054f,0.995659f,-0.0738017f, -0.229305f,0.968679f,0.0952866f, --0.0263963f,0.99794f,0.0584726f, --0.0422212f,0.996107f,0.0773806f, -0.0415928f,0.997459f,0.0578396f, -0.0625406f,0.995706f,0.0682456f, -0.174866f,0.970931f,0.163448f, -0.248971f,0.959664f,0.13061f, -0.296526f,0.91909f,0.259511f, -0.244457f,0.962524f,0.117427f, -0.144028f,0.988219f,0.0517682f, -0.0516566f,0.998622f,-0.00921711f, --0.0100473f,0.999479f,-0.0306849f, -0.144821f,0.968281f,0.203614f, -0.0927686f,0.985877f,0.139429f, -0.159268f,0.950036f,0.268448f, --0.238265f,0.969366f,-0.0596594f, --0.317162f,0.937667f,-0.14209f, --0.252226f,0.956124f,-0.149026f, --0.139275f,0.959516f,-0.244809f, -0.225678f,0.948782f,-0.221092f, -0.454598f,0.876109f,-0.160545f, -0.280777f,0.950726f,-0.131467f, -0.235562f,0.968875f,-0.076101f, -0.32523f,0.943278f,-0.0667146f, -0.204883f,0.977104f,-0.0573623f, --0.016814f,0.999658f,-0.0200258f, --0.0821474f,0.994185f,0.0696248f, --0.0248008f,0.998098f,0.0564331f, -0.000698274f,0.999817f,0.0191283f, -0.0007523f,0.989994f,0.141106f, --0.0137951f,0.98192f,0.188792f, --0.00956379f,0.990301f,0.138609f, --0.0156365f,0.996604f,0.0808513f, --0.104293f,0.986463f,0.126542f, --0.156424f,0.969975f,0.186228f, --0.167617f,0.975111f,0.145129f, --0.261339f,0.965118f,0.0157997f, --0.160877f,0.9832f,-0.0862302f, --0.296054f,0.934306f,-0.198555f, --0.550185f,0.752769f,-0.361436f, --0.408582f,0.840233f,-0.356467f, --0.339245f,0.876729f,-0.340968f, --0.402741f,0.85772f,-0.319556f, --0.316164f,0.924069f,-0.214795f, --0.348907f,0.927941f,-0.131109f, --0.48502f,0.870548f,-0.0830789f, --0.53006f,0.843646f,-0.085433f, --0.352226f,0.931519f,-0.0906107f, --0.0975811f,0.982258f,-0.160146f, -0.0477418f,0.981235f,-0.186812f, -0.0219054f,0.966987f,-0.253882f, --0.115057f,0.988784f,-0.0952266f, --0.238673f,0.960258f,0.144707f, --0.213447f,0.931011f,0.296071f, --0.201955f,0.923284f,0.326742f, -0.101325f,0.921693f,0.374453f, -0.294403f,0.882174f,0.367555f, -0.373397f,0.835094f,0.403971f, -0.278351f,0.921647f,0.270347f, -0.215461f,0.962466f,0.16503f, -0.225302f,0.965479f,0.13073f, -0.175997f,0.983214f,0.0481225f, -0.220124f,0.97536f,0.0147531f, -0.32343f,0.94566f,-0.0334783f, -0.369971f,0.927728f,-0.0494253f, -0.427777f,0.903113f,-0.037328f, -0.446874f,0.894597f,9.72625e-005f, -0.445338f,0.895316f,-0.00910111f, -0.463955f,0.88101f,-0.0925573f, -0.398143f,0.905258f,-0.148289f, -0.190091f,0.969836f,-0.152589f, --0.0830374f,0.980972f,-0.175495f, --0.1343f,0.985908f,-0.0997463f, --0.00843053f,0.999434f,0.0325608f, -0.021819f,0.995847f,0.0883913f, -0.206682f,0.96009f,0.188439f, -0.388829f,0.882727f,0.263827f, -0.0707915f,0.996578f,0.0426701f, --0.161491f,0.983232f,-0.0847068f, --0.0785342f,0.996721f,-0.0194704f, --0.224473f,0.966422f,-0.125062f, --0.159666f,0.968511f,-0.191032f, -0.0318558f,0.951557f,-0.305817f, -0.187349f,0.896729f,-0.400972f, -0.324927f,0.900628f,-0.288602f, -0.217775f,0.961772f,-0.16604f, -0.20019f,0.973241f,-0.112807f, -0.277242f,0.959937f,-0.0407145f, -0.14204f,0.987332f,0.0707153f, --0.0153938f,0.984428f,0.175114f, --0.0735255f,0.984081f,0.161796f, --0.0237909f,0.990594f,0.134749f, --0.0614906f,0.985818f,0.156146f, --0.143236f,0.970943f,0.191711f, --0.0137498f,0.973243f,0.229369f, -0.0567477f,0.984597f,0.165372f, --0.0347212f,0.993259f,0.110594f, --0.143386f,0.976741f,0.159429f, --0.139502f,0.982211f,0.125705f, --0.0993842f,0.989216f,0.107588f, --0.136731f,0.987843f,0.0739654f, --0.0893069f,0.995969f,0.00840628f, --0.123862f,0.992294f,-0.00315825f, --0.391175f,0.886683f,-0.246529f, --0.44403f,0.793263f,-0.41662f, --0.399761f,0.83626f,-0.375315f, --0.422675f,0.841058f,-0.33759f, --0.445112f,0.835127f,-0.323168f, --0.410733f,0.898417f,-0.155389f, --0.485628f,0.867891f,-0.104549f, --0.491383f,0.859111f,-0.143077f, --0.358033f,0.910383f,-0.207399f, --0.0910122f,0.986127f,-0.138818f, -0.0820594f,0.995842f,-0.039567f, --0.0287013f,0.999312f,-0.0234726f, --0.346268f,0.933835f,0.0897299f, --0.471073f,0.825151f,0.311795f, --0.27505f,0.819541f,0.502693f, --0.154238f,0.84574f,0.510818f, -0.0836929f,0.869512f,0.48677f, -0.266688f,0.84547f,0.462663f, -0.365749f,0.809921f,0.458537f, -0.371864f,0.832105f,0.411483f, -0.260242f,0.895369f,0.361371f, -0.283389f,0.903576f,0.321311f, -0.269874f,0.934168f,0.233448f, -0.265321f,0.957928f,0.10945f, -0.333071f,0.942841f,0.0106961f, -0.387903f,0.9217f,0.000193271f, -0.435792f,0.899834f,0.0195967f, -0.454676f,0.88982f,0.0386129f, -0.482276f,0.876019f,-0.000723308f, -0.505259f,0.860654f,-0.0631586f, -0.398328f,0.910448f,-0.111444f, -0.21929f,0.970647f,-0.0987756f, -0.0111053f,0.988208f,-0.152714f, --0.210805f,0.943357f,-0.256201f, --0.146846f,0.978658f,-0.143755f, -0.0139602f,0.999731f,-0.0184963f, -0.133096f,0.990721f,-0.0275154f, -0.2933f,0.953875f,0.0640122f, -0.228393f,0.945969f,0.230173f, -0.0546169f,0.969859f,0.237467f, --0.0762534f,0.988779f,-0.128459f, --0.106647f,0.982213f,-0.154543f, --0.122396f,0.949634f,-0.28847f, -0.0920652f,0.954226f,-0.284566f, -0.185259f,0.946785f,-0.263206f, -0.232314f,0.960849f,-0.150996f, -0.169992f,0.979263f,-0.110207f, -0.125326f,0.980516f,-0.151267f, -0.149673f,0.98818f,-0.0331477f, -0.0238199f,0.989878f,0.139909f, --0.107594f,0.981438f,0.158754f, --0.0846643f,0.982313f,0.167013f, --0.0375415f,0.970751f,0.237134f, --0.0510768f,0.964816f,0.257917f, --0.0443365f,0.980593f,0.190977f, -0.00242513f,0.997744f,0.0670872f, -0.124335f,0.983389f,0.132238f, --0.00301992f,0.993206f,0.116332f, --0.125192f,0.990103f,0.0634287f, --0.100487f,0.994519f,-0.0288746f, --0.101663f,0.992712f,-0.0647098f, --0.139647f,0.987963f,-0.0665471f, --0.130136f,0.990189f,-0.0508981f, --0.0756901f,0.997123f,-0.00415316f, --0.171558f,0.977059f,-0.126185f, --0.351855f,0.892529f,-0.282117f, --0.447333f,0.817645f,-0.362422f, --0.423851f,0.857249f,-0.29236f, --0.448058f,0.866215f,-0.221171f, --0.531086f,0.820738f,-0.210565f, --0.511898f,0.851158f,-0.116153f, --0.425868f,0.900461f,-0.0883553f, --0.399025f,0.900598f,-0.172345f, --0.24223f,0.968919f,-0.0502012f, --0.0663613f,0.996507f,0.0506899f, --0.138021f,0.972657f,0.186782f, --0.4139f,0.851097f,0.322987f, --0.550512f,0.782849f,0.289973f, --0.380287f,0.863038f,0.332486f, --0.131533f,0.903571f,0.407748f, -0.119586f,0.9109f,0.394918f, -0.299052f,0.87558f,0.379379f, -0.370047f,0.8611f,0.348671f, -0.442832f,0.822723f,0.356408f, -0.35885f,0.890772f,0.278839f, -0.314791f,0.940053f,0.131179f, -0.339464f,0.925728f,0.166711f, -0.403599f,0.900778f,0.160334f, -0.45653f,0.889636f,-0.0113152f, -0.365242f,0.916509f,-0.163124f, -0.379822f,0.91652f,-0.125407f, -0.442125f,0.891797f,-0.096041f, -0.493888f,0.864551f,-0.0928755f, -0.541781f,0.83947f,-0.041994f, -0.441424f,0.894377f,-0.0723577f, -0.226514f,0.958331f,-0.174048f, -0.0664964f,0.969681f,-0.235153f, --0.103823f,0.949537f,-0.295973f, --0.233692f,0.889012f,-0.39376f, --0.0987171f,0.939339f,-0.328477f, -0.103986f,0.972613f,-0.207871f, -0.198802f,0.974287f,-0.106033f, -0.0601774f,0.998175f,0.00500958f, --0.0421158f,0.995212f,0.0882012f, --0.0598721f,0.997785f,-0.0289851f, --0.030607f,0.999125f,-0.0285146f, --0.00697633f,0.993471f,-0.113875f, -0.0388611f,0.980882f,-0.190686f, -0.0977483f,0.98843f,-0.115983f, -0.15403f,0.986798f,-0.0500538f, -0.193054f,0.979913f,-0.0500083f, -0.157678f,0.98694f,-0.0329733f, --0.0158549f,0.999428f,0.0298765f, --0.0525571f,0.987534f,0.14837f, -0.000720533f,0.997813f,0.0660913f, --0.102677f,0.99254f,-0.0657426f, --0.099341f,0.994285f,-0.0391091f, --0.0676495f,0.996952f,-0.0388727f, -0.0225146f,0.999293f,0.0301014f, -0.0577235f,0.997453f,0.0418936f, --0.0269869f,0.999243f,0.0280361f, -0.00446401f,0.985157f,0.171599f, --0.0141502f,0.990326f,0.138035f, --0.00518586f,0.999975f,0.00477817f, --0.0328139f,0.995381f,-0.09022f, --0.128063f,0.971338f,-0.200254f, --0.151852f,0.967914f,-0.200209f, --0.0720493f,0.989055f,-0.128759f, --0.0591129f,0.991504f,-0.115868f, --0.248059f,0.943661f,-0.219024f, --0.389946f,0.877483f,-0.279225f, --0.523332f,0.810744f,-0.262332f, --0.51839f,0.842544f,-0.146256f, --0.550368f,0.815716f,-0.178051f, --0.560732f,0.813038f,-0.156683f, --0.427123f,0.899415f,-0.0928351f, --0.366593f,0.924495f,-0.104494f, --0.322547f,0.93696f,-0.134426f, --0.128035f,0.99042f,-0.0517317f, --0.291376f,0.953688f,0.0746902f, --0.520094f,0.826135f,0.216802f, --0.516864f,0.826474f,0.22314f, --0.396988f,0.892552f,0.213897f, --0.184148f,0.954818f,0.233263f, -0.0957205f,0.95579f,0.278034f, -0.314018f,0.892294f,0.32435f, -0.401668f,0.873128f,0.276243f, -0.463054f,0.857596f,0.223851f, -0.480022f,0.855973f,0.192066f, -0.375927f,0.916106f,0.13939f, -0.288789f,0.941864f,0.171735f, -0.396643f,0.909563f,0.123974f, -0.561623f,0.825897f,0.0497286f, -0.465605f,0.881752f,-0.0756653f, -0.370044f,0.915005f,-0.160728f, -0.427822f,0.898624f,-0.0971747f, -0.465206f,0.885137f,-0.0107503f, -0.468824f,0.88183f,0.0507874f, -0.478143f,0.868746f,0.12907f, -0.351411f,0.934208f,0.0613665f, -0.140442f,0.98844f,-0.0571117f, --0.0122878f,0.991421f,-0.130131f, --0.117862f,0.972142f,-0.202603f, --0.15815f,0.947613f,-0.27752f, --0.0729629f,0.95654f,-0.282325f, -0.0272484f,0.989771f,-0.14004f, --0.0137333f,0.999563f,0.0261849f, --0.0985129f,0.993299f,0.0604412f, --0.135233f,0.990548f,-0.0229695f, --0.0373153f,0.999264f,0.00888433f, -0.0352261f,0.99933f,0.00994916f, -0.061219f,0.99588f,0.0668911f, -0.0815695f,0.99444f,0.0665983f, -0.144386f,0.989424f,0.0139045f, -0.184662f,0.980318f,0.0698361f, -0.0224217f,0.989677f,0.14155f, --0.0794321f,0.954058f,0.288901f, --0.0304562f,0.959461f,0.280192f, -0.112423f,0.968918f,0.220359f, -0.0390938f,0.993037f,0.111126f, --0.0885962f,0.9933f,-0.0741985f, --0.0453085f,0.996418f,-0.0714089f, --0.123875f,0.985221f,-0.118298f, -0.00670832f,0.999925f,0.010273f, --0.0146906f,0.998569f,0.0514303f, --0.0998092f,0.992773f,0.0666264f, -0.0466126f,0.990197f,0.131669f, -0.103009f,0.992862f,0.0601126f, -0.113553f,0.993084f,-0.0298385f, --0.0128779f,0.975704f,-0.218713f, --0.177855f,0.94662f,-0.268846f, --0.191482f,0.955424f,-0.224722f, --0.0532043f,0.987628f,-0.147512f, --0.140744f,0.970833f,-0.194099f, --0.387395f,0.889373f,-0.242778f, --0.531553f,0.818908f,-0.216427f, --0.531571f,0.799354f,-0.280115f, --0.51407f,0.81292f,-0.273666f, --0.549112f,0.793924f,-0.261078f, --0.484709f,0.822384f,-0.297895f, --0.322663f,0.926066f,-0.195678f, --0.315438f,0.927311f,-0.201479f, --0.289702f,0.947148f,-0.13778f, --0.417457f,0.908684f,-0.00477603f, --0.584599f,0.810188f,0.0428868f, --0.55194f,0.828316f,0.0962071f, --0.397599f,0.904432f,0.154656f, --0.183216f,0.971572f,0.149931f, -0.0355131f,0.990243f,0.134751f, -0.298837f,0.942288f,0.150964f, -0.413659f,0.900634f,0.133206f, -0.498073f,0.828388f,0.256313f, -0.444018f,0.853405f,0.273035f, -0.327561f,0.881897f,0.339061f, -0.313826f,0.898686f,0.306392f, -0.495157f,0.851292f,0.173556f, -0.614747f,0.78345f,0.0910662f, -0.55187f,0.833866f,0.0103585f, -0.367713f,0.926545f,-0.0793776f, -0.311567f,0.950223f,0.00108255f, -0.382947f,0.917094f,0.110859f, -0.410945f,0.895808f,0.169272f, -0.455231f,0.858878f,0.234721f, -0.373673f,0.896264f,0.238911f, -0.246571f,0.935158f,0.254328f, -0.0808975f,0.990111f,0.114608f, --0.0843211f,0.99633f,-0.0147289f, --0.0859474f,0.994869f,-0.0533687f, --0.0567528f,0.986639f,-0.152718f, --0.104487f,0.984189f,-0.143019f, --0.139027f,0.990289f,8.5057e-005f, --0.137547f,0.987918f,0.0714029f, --0.144256f,0.989201f,-0.0259182f, --0.026694f,0.998838f,-0.0401331f, --0.0313342f,0.99664f,-0.0756769f, --0.0574884f,0.99781f,0.0327011f, -0.145005f,0.983413f,0.108961f, -0.119257f,0.992151f,0.0376122f, -0.0587452f,0.978725f,0.196585f, --0.0803833f,0.947865f,0.308369f, --0.127827f,0.919581f,0.371526f, --0.00616421f,0.930831f,0.365399f, -0.107639f,0.912609f,0.394409f, -0.210572f,0.88729f,0.410336f, -0.0740329f,0.980065f,0.184368f, --0.0250926f,0.999613f,0.0120275f, --0.0610433f,0.996433f,-0.05826f, --0.0708404f,0.994984f,-0.0706271f, --0.0640037f,0.997923f,-0.00726403f, --0.0949547f,0.99548f,0.00148231f, -0.00929451f,0.997943f,-0.0634315f, -0.147986f,0.988795f,-0.0195964f, -0.19874f,0.98001f,-0.00909425f, -0.119683f,0.99247f,-0.0260466f, --0.140841f,0.984951f,-0.10018f, --0.197496f,0.959342f,-0.201637f, --0.0821482f,0.973605f,-0.212945f, --0.090387f,0.978841f,-0.18358f, --0.34459f,0.903344f,-0.255395f, --0.465169f,0.833236f,-0.29889f, --0.493353f,0.789348f,-0.365421f, --0.529455f,0.773394f,-0.348624f, --0.541108f,0.776645f,-0.322528f, --0.503238f,0.814279f,-0.289312f, --0.451111f,0.869282f,-0.202106f, --0.405307f,0.906179f,-0.120689f, --0.367499f,0.92846f,-0.0539062f, --0.448648f,0.893437f,-0.0220131f, --0.582415f,0.811815f,-0.0418214f, --0.587857f,0.805915f,-0.0701802f, --0.440963f,0.897524f,0.00144435f, --0.150082f,0.985674f,0.0769547f, -0.0512849f,0.998035f,0.0359923f, -0.331471f,0.9412f,0.0653422f, -0.327057f,0.943418f,0.0547333f, -0.325027f,0.917755f,0.228216f, -0.374201f,0.856118f,0.35642f, -0.374565f,0.858588f,0.350039f, -0.460817f,0.854058f,0.241312f, -0.556465f,0.823608f,0.109619f, -0.63153f,0.770458f,0.0869767f, -0.587056f,0.806123f,0.074369f, -0.365958f,0.924908f,0.10305f, -0.26636f,0.954918f,0.131089f, -0.330741f,0.937061f,0.111923f, -0.358992f,0.918233f,0.167249f, -0.397317f,0.888574f,0.229294f, -0.378918f,0.890078f,0.253343f, -0.252398f,0.944302f,0.211161f, -0.242388f,0.947895f,0.206744f, -0.0865865f,0.99456f,0.0579091f, --0.0181168f,0.990006f,-0.139854f, -0.0162661f,0.98021f,-0.197289f, --0.148111f,0.960303f,-0.236394f, --0.255052f,0.949006f,-0.185302f, --0.211751f,0.971559f,-0.105997f, --0.0120621f,0.994912f,-0.100021f, --0.015173f,0.98959f,-0.143115f, --0.0401151f,0.99847f,-0.0380528f, --0.0979763f,0.995187f,0.00194195f, -0.0571375f,0.998251f,0.0151643f, -0.0776787f,0.976915f,0.199006f, --0.101892f,0.95655f,0.273185f, --0.133768f,0.938598f,0.318024f, --0.177801f,0.93623f,0.303084f, --0.022321f,0.922329f,0.385761f, -0.0333931f,0.905943f,0.422081f, -0.163361f,0.862964f,0.478127f, -0.305267f,0.821497f,0.481617f, -0.18106f,0.939243f,0.291615f, --0.00700511f,0.992472f,0.122275f, --0.0966012f,0.992994f,0.068052f, --0.106034f,0.991731f,0.0722919f, --0.0353039f,0.993084f,0.11197f, -0.0541772f,0.995603f,0.0764134f, -0.08347f,0.989853f,0.114994f, -0.130868f,0.975887f,0.174696f, -0.0723356f,0.969665f,0.23349f, --0.0470347f,0.960948f,0.272703f, --0.10077f,0.971805f,0.213169f, --0.119566f,0.974584f,0.189448f, --0.0774738f,0.965859f,0.247214f, --0.198029f,0.968836f,0.1488f, --0.435505f,0.897132f,-0.0740912f, --0.502708f,0.857298f,-0.111019f, --0.564282f,0.819749f,-0.0979722f, --0.594236f,0.795147f,-0.120937f, --0.591492f,0.803058f,-0.0723546f, --0.526826f,0.849968f,-0.0029614f, --0.410127f,0.912007f,0.00617969f, --0.355675f,0.932755f,-0.0588432f, --0.457125f,0.883759f,-0.100032f, --0.544765f,0.834451f,-0.0832032f, --0.554858f,0.819866f,-0.141253f, --0.535218f,0.826621f,-0.173894f, --0.203549f,0.978635f,-0.0289948f, -0.0668755f,0.997729f,0.00799418f, -0.247034f,0.968844f,0.017759f, -0.275407f,0.949712f,0.148988f, -0.19759f,0.950103f,0.241375f, -0.374575f,0.880138f,0.291635f, -0.446827f,0.865948f,0.224675f, -0.519968f,0.833624f,0.186291f, -0.587008f,0.786117f,0.193499f, -0.636373f,0.75334f,0.165857f, -0.540728f,0.822377f,0.176944f, -0.345338f,0.910903f,0.225828f, -0.278322f,0.945193f,0.170723f, -0.30876f,0.936535f,0.166043f, -0.303863f,0.916063f,0.261719f, -0.319419f,0.895614f,0.309591f, -0.43277f,0.828092f,0.356332f, -0.333077f,0.917687f,0.216587f, -0.219655f,0.964319f,0.147787f, -0.242228f,0.95005f,0.196802f, -0.204875f,0.978767f,-0.00640881f, --0.000192716f,0.97566f,-0.219288f, --0.0681124f,0.988809f,-0.132732f, --0.241144f,0.919453f,-0.310573f, --0.290276f,0.882193f,-0.370776f, -0.0292627f,0.97223f,-0.232189f, --0.0803803f,0.976804f,-0.198478f, --0.203999f,0.977793f,-0.0480039f, --0.118856f,0.989202f,0.0857425f, --0.0783112f,0.985397f,0.151198f, --0.0878718f,0.938803f,0.333059f, --0.083435f,0.948159f,0.30665f, --0.110585f,0.962509f,0.247682f, --0.186686f,0.943514f,0.273733f, --0.149516f,0.932553f,0.32862f, --0.00475332f,0.899494f,0.436906f, -0.0862131f,0.885009f,0.457522f, -0.277459f,0.815555f,0.507825f, -0.298118f,0.799955f,0.520766f, -0.14455f,0.869997f,0.471392f, -0.0121492f,0.942115f,0.335071f, --0.0752209f,0.977077f,0.199154f, --0.128636f,0.97789f,0.164878f, --0.000660482f,0.945164f,0.326595f, -0.00550592f,0.919316f,0.393482f, -0.0803772f,0.905979f,0.415621f, -0.0810259f,0.907487f,0.412192f, --0.090779f,0.919652f,0.382099f, --0.137864f,0.897436f,0.419048f, --0.130404f,0.886486f,0.444001f, --0.0852724f,0.906321f,0.413897f, --0.0259127f,0.906615f,0.421163f, --0.225351f,0.915922f,0.332119f, --0.462548f,0.869686f,0.172323f, --0.572668f,0.816922f,0.0684804f, --0.585929f,0.806118f,0.0828267f, --0.593406f,0.803366f,0.0497268f, --0.516762f,0.856027f,-0.0132014f, --0.38427f,0.922646f,-0.0325731f, --0.287245f,0.956724f,-0.0465863f, --0.413146f,0.905396f,-0.097823f, --0.564236f,0.818421f,-0.108744f, --0.507227f,0.858315f,-0.0775611f, --0.527754f,0.82927f,-0.183811f, --0.354765f,0.918321f,-0.175582f, -0.0463007f,0.998926f,-0.00175561f, -0.214268f,0.976774f,0.00151756f, -0.165544f,0.983729f,0.0698077f, -0.096445f,0.982342f,0.16032f, -0.366991f,0.896711f,0.24744f, -0.500788f,0.845195f,0.186699f, -0.507012f,0.85355f,0.119965f, -0.542994f,0.824496f,0.159261f, -0.605757f,0.757486f,0.243463f, -0.532123f,0.786802f,0.312711f, -0.44869f,0.847812f,0.282652f, -0.34333f,0.935092f,0.0879082f, -0.24319f,0.961353f,0.129073f, -0.223708f,0.954136f,0.198946f, -0.276144f,0.94134f,0.193965f, -0.41277f,0.892522f,0.181731f, -0.485836f,0.856185f,0.175815f, -0.251109f,0.963495f,0.0928509f, -0.217377f,0.969921f,0.109544f, -0.402023f,0.911537f,0.0864706f, -0.0930878f,0.988366f,-0.120284f, --0.0926141f,0.987658f,-0.126311f, --0.0129498f,0.988134f,-0.153049f, --0.0752509f,0.973537f,-0.215783f, --0.167591f,0.970187f,-0.175075f, --0.227938f,0.971032f,-0.0717025f, --0.288377f,0.95589f,0.0557925f, --0.2706f,0.959797f,0.0746015f, --0.201821f,0.948409f,0.244517f, --0.135104f,0.944724f,0.298737f, -0.0536332f,0.953012f,0.298147f, --0.104499f,0.972769f,0.206883f, --0.26012f,0.936243f,0.236192f, --0.221301f,0.933098f,0.283468f, --0.0976008f,0.934678f,0.341835f, -0.0488135f,0.920165f,0.388475f, -0.20566f,0.878417f,0.431379f, -0.294052f,0.82595f,0.480979f, -0.211093f,0.846234f,0.489211f, -0.1526f,0.86506f,0.477897f, -0.100541f,0.907805f,0.407163f, --0.126416f,0.965258f,0.228683f, --0.211306f,0.949302f,0.232755f, --0.037039f,0.912463f,0.40748f, -0.117233f,0.908378f,0.401379f, -0.101997f,0.928038f,0.35825f, --0.0502775f,0.939056f,0.340069f, --0.158243f,0.952358f,0.260718f, --0.125329f,0.958222f,0.257106f, --0.051336f,0.956723f,0.286436f, --0.0625203f,0.954305f,0.29222f, --0.207996f,0.932703f,0.294623f, --0.319481f,0.91161f,0.258649f, --0.495077f,0.865137f,0.0802322f, --0.579132f,0.814857f,-0.0247929f, --0.549115f,0.83292f,-0.0686783f, --0.493373f,0.86244f,-0.113053f, --0.402759f,0.911225f,-0.0863345f, --0.292096f,0.955556f,-0.0399004f, --0.382523f,0.923047f,-0.0407488f, --0.572187f,0.816414f,-0.0779103f, --0.512485f,0.857517f,-0.0449819f, --0.420369f,0.906318f,-0.0433336f, --0.419207f,0.879291f,-0.22608f, --0.129012f,0.980121f,-0.150729f, -0.168538f,0.98409f,0.056222f, -0.177285f,0.97778f,0.111881f, -0.0313595f,0.998166f,-0.0517722f, -0.266622f,0.963684f,-0.0150476f, -0.566513f,0.817464f,0.103999f, -0.539244f,0.841888f,0.0209898f, -0.503392f,0.861782f,0.0626771f, -0.548011f,0.825978f,0.132075f, -0.53464f,0.817691f,0.213407f, -0.52656f,0.822061f,0.21668f, -0.418461f,0.898681f,0.131391f, -0.217077f,0.97168f,0.0933593f, -0.230073f,0.97316f,0.00512693f, -0.352039f,0.933499f,-0.0681773f, -0.427612f,0.891089f,-0.152014f, -0.47402f,0.877861f,-0.0682997f, -0.292505f,0.956178f,-0.0128375f, -0.212998f,0.971167f,-0.107084f, -0.394409f,0.913171f,-0.102761f, -0.229015f,0.973422f,0.000912976f, --0.0760893f,0.988509f,-0.130618f, --0.0515625f,0.984716f,-0.166362f, --0.0928406f,0.987408f,-0.128086f, --0.200115f,0.967117f,0.156969f, --0.29324f,0.941681f,0.165066f, --0.336305f,0.919935f,0.201539f, --0.298108f,0.921775f,0.247915f, --0.262609f,0.920325f,0.289892f, --0.146209f,0.952657f,0.266586f, --0.00778438f,0.956339f,0.292158f, --0.050022f,0.92665f,0.372583f, --0.258705f,0.916977f,0.303687f, --0.247478f,0.923305f,0.293706f, --0.126717f,0.938107f,0.322331f, -0.0303988f,0.946862f,0.320201f, -0.135735f,0.944675f,0.298606f, -0.25669f,0.889672f,0.377616f, -0.215508f,0.868916f,0.44558f, -0.117717f,0.868155f,0.482129f, -0.172493f,0.853951f,0.490931f, -0.0744588f,0.909987f,0.407897f, --0.203499f,0.942765f,0.264163f, --0.165852f,0.956441f,0.240237f, -0.150303f,0.946565f,0.285349f, -0.126121f,0.955231f,0.267632f, -0.00383767f,0.957166f,0.289515f, --0.0803601f,0.965694f,0.246937f, --0.14415f,0.963474f,0.225698f, --0.128772f,0.964294f,0.231421f, --0.0634991f,0.964707f,0.255554f, --0.15178f,0.96554f,0.211412f, --0.290877f,0.950446f,0.109737f, --0.365587f,0.928197f,0.069257f, --0.512709f,0.855901f,-0.0675528f, --0.522587f,0.843414f,-0.12472f, --0.519355f,0.843468f,-0.13723f, --0.458617f,0.886978f,-0.054221f, --0.335795f,0.941914f,0.00633015f, --0.354719f,0.934449f,0.0312872f, --0.552854f,0.83289f,-0.025441f, --0.550469f,0.834453f,-0.0259307f, --0.388185f,0.921529f,-0.00983026f, --0.282899f,0.957493f,-0.056358f, --0.256814f,0.955751f,-0.143483f, --0.0731312f,0.996697f,-0.0353254f, -0.211397f,0.967055f,0.141832f, -0.27554f,0.960583f,0.0368595f, -0.217196f,0.959783f,-0.177882f, -0.479261f,0.875236f,-0.0653524f, -0.513664f,0.856169f,0.0558883f, -0.446145f,0.882397f,0.149434f, -0.498219f,0.84712f,0.184837f, -0.503236f,0.827823f,0.247916f, -0.51285f,0.815024f,0.269666f, -0.506381f,0.824734f,0.251778f, -0.333663f,0.940706f,0.0611746f, -0.353215f,0.932965f,-0.069389f, -0.414309f,0.904024f,-0.105298f, -0.451897f,0.886486f,-0.0996557f, -0.345824f,0.933767f,-0.0921138f, -0.280994f,0.95917f,0.0321915f, -0.317081f,0.945948f,0.0681282f, -0.344866f,0.938141f,0.0309596f, -0.224406f,0.974203f,0.0238892f, --0.0108486f,0.995761f,-0.0913323f, --0.00158176f,0.998953f,-0.0457292f, --0.115676f,0.985559f,-0.123663f, --0.188171f,0.911466f,0.365816f, --0.262724f,0.896783f,0.356029f, --0.358149f,0.883197f,0.302807f, --0.323424f,0.894918f,0.307438f, --0.242922f,0.924564f,0.293548f, --0.121147f,0.94907f,0.290844f, --0.0341414f,0.951299f,0.306374f, --0.132493f,0.945016f,0.298983f, --0.194216f,0.905093f,0.378268f, --0.212944f,0.914784f,0.343257f, --0.127802f,0.956235f,0.263215f, -0.0483659f,0.968777f,0.243172f, -0.117573f,0.942608f,0.312517f, -0.164225f,0.89741f,0.409494f, -0.122313f,0.88201f,0.455081f, -0.101965f,0.875392f,0.472537f, -0.209339f,0.879095f,0.428217f, -0.174899f,0.892224f,0.416349f, --0.060088f,0.941634f,0.331231f, --0.120508f,0.975773f,0.182606f, -0.112168f,0.972734f,0.202994f, -0.117253f,0.950933f,0.286318f, --0.0544328f,0.941394f,0.332887f, --0.0790068f,0.915303f,0.394942f, --0.127609f,0.917525f,0.376648f, --0.0756868f,0.941409f,0.328666f, --0.0332439f,0.958716f,0.282415f, --0.0735168f,0.965505f,0.249792f, --0.203882f,0.964791f,0.166163f, --0.320453f,0.94269f,0.0929826f, --0.471247f,0.881185f,0.0379224f, --0.492278f,0.869051f,0.0491152f, --0.532259f,0.846256f,-0.0234739f, --0.499446f,0.866138f,-0.0189645f, --0.373407f,0.92679f,-0.0403466f, --0.352534f,0.935772f,-0.00715155f, --0.527726f,0.848793f,-0.0324855f, --0.520812f,0.852354f,-0.0474108f, --0.409147f,0.909436f,-0.0743255f, --0.294722f,0.955583f,0.000817458f, --0.222255f,0.974321f,0.0360744f, --0.14278f,0.989739f,0.00545783f, -0.112175f,0.992761f,0.0429195f, -0.349968f,0.931754f,0.0967357f, -0.338116f,0.939385f,0.056869f, -0.379594f,0.923814f,0.0497667f, -0.434257f,0.879279f,0.195674f, -0.391146f,0.89525f,0.213383f, -0.465582f,0.860371f,0.207352f, -0.429826f,0.860017f,0.274991f, -0.465148f,0.815034f,0.34548f, -0.575943f,0.73808f,0.351465f, -0.535537f,0.824709f,0.181813f, -0.414278f,0.908562f,-0.0537569f, -0.380258f,0.913027f,-0.147599f, -0.408447f,0.90132f,-0.144197f, -0.367806f,0.925659f,-0.0887431f, -0.142987f,0.986995f,-0.073455f, -0.215691f,0.972786f,0.0846483f, -0.373384f,0.916381f,0.144331f, -0.381582f,0.918997f,0.0991966f, -0.0727073f,0.993287f,-0.0899678f, --0.0658262f,0.992454f,-0.103446f, -0.0138596f,0.999564f,-0.0260736f, --0.215981f,0.852322f,0.47634f, --0.206677f,0.845053f,0.493123f, --0.272991f,0.879681f,0.389406f, --0.267376f,0.924267f,0.272471f, --0.22026f,0.956955f,0.189003f, --0.175208f,0.966589f,0.187106f, --0.043064f,0.959071f,0.279872f, --0.116589f,0.955061f,0.272519f, --0.310776f,0.922421f,0.229257f, --0.169995f,0.929299f,0.32788f, --0.0175005f,0.941141f,0.337561f, -0.0138751f,0.95035f,0.310874f, --0.0519487f,0.924056f,0.37871f, -0.0171204f,0.875115f,0.483613f, -0.148666f,0.835016f,0.529761f, -0.187668f,0.864969f,0.465412f, -0.241037f,0.89408f,0.377521f, -0.22255f,0.900707f,0.373093f, -0.0517034f,0.945752f,0.320749f, --0.0271248f,0.957046f,0.288665f, -0.0325916f,0.970401f,0.239289f, -0.0171507f,0.960836f,0.276588f, --0.143534f,0.9275f,0.345169f, --0.0983366f,0.916766f,0.38713f, --0.0476997f,0.944806f,0.32414f, --0.0337303f,0.946895f,0.319767f, --0.0100366f,0.942379f,0.334396f, --0.0544901f,0.938102f,0.342046f, --0.14598f,0.916868f,0.371541f, --0.23743f,0.904478f,0.354324f, --0.411826f,0.87795f,0.244136f, --0.481531f,0.866693f,0.130273f, --0.469337f,0.874903f,0.119446f, --0.452816f,0.890509f,0.0441746f, --0.332275f,0.942324f,-0.0402274f, --0.391441f,0.91825f,-0.0599172f, --0.492183f,0.870395f,0.0129854f, --0.540952f,0.839903f,-0.0439814f, --0.452633f,0.891182f,0.0302916f, --0.353037f,0.931758f,0.0848037f, --0.230998f,0.971043f,0.0609518f, --0.110559f,0.993184f,0.0368984f, -0.0985994f,0.994896f,-0.0214387f, -0.290703f,0.956813f,-0.000841556f, -0.306742f,0.941069f,0.142471f, -0.309512f,0.928678f,0.20435f, -0.393276f,0.890035f,0.23059f, -0.472781f,0.864565f,0.170309f, -0.455511f,0.888755f,0.0512287f, -0.387199f,0.912459f,0.13227f, -0.420125f,0.891345f,0.170293f, -0.568557f,0.791084f,0.225676f, -0.642678f,0.725845f,0.245181f, -0.61301f,0.785525f,0.0846683f, -0.519083f,0.833826f,-0.187849f, -0.390386f,0.832025f,-0.394123f, -0.254733f,0.897839f,-0.359161f, -0.0968538f,0.955535f,-0.278518f, -0.110338f,0.951183f,-0.288231f, -0.337547f,0.917961f,-0.20835f, -0.382401f,0.916771f,-0.115327f, -0.232755f,0.967238f,-0.101374f, --0.075544f,0.963631f,-0.256338f, --0.111861f,0.963998f,-0.241238f, --0.403631f,0.823611f,0.398431f, --0.211285f,0.853176f,0.476917f, --0.0996818f,0.887327f,0.450237f, --0.119017f,0.926423f,0.357178f, --0.147962f,0.959424f,0.240027f, --0.17904f,0.969453f,0.167646f, --0.182698f,0.967757f,0.173402f, --0.0875162f,0.935774f,0.341566f, --0.247354f,0.926662f,0.283043f, --0.269706f,0.932828f,0.238937f, --0.116046f,0.932011f,0.34335f, --0.054572f,0.895119f,0.442474f, --0.0702883f,0.870311f,0.487462f, --0.0238769f,0.872685f,0.4877f, -0.145141f,0.847062f,0.511292f, -0.26226f,0.839585f,0.475728f, -0.307436f,0.859155f,0.409067f, -0.272452f,0.896089f,0.35042f, -0.0602872f,0.949936f,0.306572f, --0.0269541f,0.950357f,0.309992f, -0.110161f,0.964193f,0.241239f, -0.0112822f,0.980274f,0.19732f, --0.201697f,0.957263f,0.207282f, --0.0780713f,0.964435f,0.252529f, -0.00973745f,0.973101f,0.230172f, --0.0755968f,0.981149f,0.177855f, --0.0876613f,0.97114f,0.221817f, --0.111729f,0.927016f,0.357991f, --0.221124f,0.882386f,0.41533f, --0.204491f,0.867297f,0.45385f, --0.238609f,0.89578f,0.375026f, --0.38933f,0.904206f,0.175592f, --0.447525f,0.889442f,0.0928077f, --0.421271f,0.9063f,0.0339399f, --0.295839f,0.951557f,0.0837779f, --0.40469f,0.90695f,0.116906f, --0.500893f,0.852054f,0.152018f, --0.539765f,0.838827f,0.0708671f, --0.497421f,0.864837f,0.068037f, --0.338953f,0.937284f,0.0813017f, --0.178116f,0.975677f,0.127782f, --0.0428295f,0.992057f,0.118272f, -0.176596f,0.983706f,0.0336999f, -0.217356f,0.975284f,-0.0397137f, -0.172156f,0.984981f,0.0131952f, -0.279801f,0.958586f,0.0531518f, -0.429228f,0.901897f,0.0484305f, -0.537427f,0.843269f,0.00840869f, -0.461159f,0.886671f,-0.0338697f, -0.347666f,0.937337f,0.022966f, -0.390524f,0.920568f,0.00669632f, -0.544615f,0.837115f,0.0513162f, -0.64737f,0.75903f,0.0691749f, -0.709483f,0.698136f,0.0961199f, -0.69002f,0.723355f,-0.0250988f, -0.510759f,0.819636f,-0.259464f, -0.161066f,0.87948f,-0.447854f, -0.0742832f,0.901252f,-0.426881f, -0.164688f,0.896506f,-0.411284f, -0.211827f,0.873436f,-0.43845f, -0.238498f,0.898773f,-0.367868f, -0.244991f,0.941894f,-0.229815f, -0.0339169f,0.959887f,-0.278328f, --0.150927f,0.928909f,-0.338156f, --0.262269f,0.839002f,0.47675f, --0.199453f,0.89484f,0.39935f, --0.0695117f,0.920513f,0.384478f, --0.0794509f,0.922822f,0.376943f, --0.0384813f,0.923599f,0.381424f, --0.0906334f,0.946866f,0.308593f, --0.231342f,0.940055f,0.250554f, --0.228342f,0.910605f,0.344468f, --0.168052f,0.897027f,0.408779f, --0.249241f,0.920512f,0.300892f, --0.201125f,0.932701f,0.29936f, --0.156169f,0.918655f,0.362882f, --0.101964f,0.881359f,0.461314f, --0.0479674f,0.88379f,0.465418f, -0.160937f,0.878499f,0.449821f, -0.298148f,0.878819f,0.372539f, -0.363972f,0.843945f,0.394059f, -0.330687f,0.867316f,0.372033f, -0.109951f,0.941418f,0.318814f, -0.0530775f,0.967978f,0.245361f, -0.171035f,0.972595f,0.157499f, -0.0211384f,0.985036f,0.171048f, --0.223743f,0.958122f,0.178723f, --0.143003f,0.966115f,0.214875f, -0.0335442f,0.969798f,0.24159f, -0.00108957f,0.977785f,0.209606f, --0.185748f,0.96522f,0.183978f, --0.245345f,0.928456f,0.278881f, --0.278935f,0.920412f,0.273928f, --0.227379f,0.922009f,0.313367f, --0.127558f,0.911679f,0.390603f, --0.252363f,0.916101f,0.311563f, --0.353299f,0.912723f,0.205222f, --0.418007f,0.90407f,0.089031f, --0.400603f,0.906481f,0.133452f, --0.448512f,0.870078f,0.204452f, --0.467166f,0.869433f,0.160757f, --0.442544f,0.892618f,0.0859534f, --0.465336f,0.885122f,-0.00451183f, --0.389888f,0.920791f,0.0114409f, --0.26105f,0.96208f,0.079086f, --0.0611649f,0.990413f,0.123862f, -0.218817f,0.959555f,0.177126f, -0.289447f,0.944291f,0.156638f, -0.238555f,0.970242f,0.0415028f, -0.303951f,0.946528f,-0.108164f, -0.431424f,0.894504f,-0.117199f, -0.527248f,0.845956f,-0.0797999f, -0.433918f,0.900916f,0.0081213f, -0.311993f,0.948885f,0.0477355f, -0.430547f,0.901487f,0.0441572f, -0.533619f,0.845624f,-0.013065f, -0.634808f,0.772557f,-0.013228f, -0.691864f,0.721963f,0.00965866f, -0.719067f,0.694383f,0.0278453f, -0.653183f,0.756562f,0.0310991f, -0.386363f,0.918778f,-0.0810638f, -0.0570874f,0.970389f,-0.234704f, -0.136394f,0.961794f,-0.237379f, -0.31236f,0.906525f,-0.283977f, -0.169471f,0.890916f,-0.421365f, -0.117142f,0.913195f,-0.390323f, -0.0777866f,0.931625f,-0.354998f, --0.0437682f,0.92941f,-0.366443f, --0.144429f,0.859889f,0.489623f, --0.0880742f,0.890372f,0.446633f, --0.0314378f,0.923882f,0.381384f, --0.0838814f,0.944139f,0.318693f, --0.0693885f,0.945887f,0.316991f, --0.0723769f,0.923178f,0.377496f, --0.19706f,0.892458f,0.405815f, --0.297386f,0.892332f,0.339566f, --0.156962f,0.91638f,0.368254f, --0.15276f,0.919794f,0.361447f, --0.17017f,0.922781f,0.345714f, --0.253151f,0.920843f,0.296586f, --0.189094f,0.905109f,0.380816f, -0.00126887f,0.929197f,0.369582f, -0.193396f,0.936415f,0.292787f, -0.338227f,0.878943f,0.336247f, -0.32269f,0.878938f,0.351198f, -0.355444f,0.867037f,0.34915f, -0.217316f,0.918786f,0.329554f, -0.123007f,0.956146f,0.265807f, -0.19987f,0.950731f,0.236986f, -0.0209731f,0.979076f,0.202411f, --0.247784f,0.961065f,0.122302f, --0.158935f,0.979718f,0.122036f, -0.0602949f,0.986043f,0.155188f, --0.0308065f,0.985867f,0.164674f, --0.185866f,0.954971f,0.231267f, --0.272851f,0.942767f,0.191682f, --0.226832f,0.938998f,0.258516f, --0.311155f,0.923351f,0.224958f, --0.264965f,0.917378f,0.297004f, --0.186536f,0.890461f,0.41507f, --0.257136f,0.895376f,0.363569f, --0.330368f,0.897563f,0.291955f, --0.415623f,0.888172f,0.19598f, --0.414839f,0.89462f,0.166025f, --0.429244f,0.901932f,0.0476213f, --0.370358f,0.92848f,0.0275516f, --0.456696f,0.886215f,-0.0777874f, --0.424934f,0.901633f,-0.0805556f, --0.26755f,0.960865f,-0.0718042f, --0.0958709f,0.992595f,-0.0745981f, -0.0853594f,0.996177f,0.0185983f, -0.317006f,0.925486f,0.207323f, -0.362438f,0.919121f,0.154455f, -0.423147f,0.903697f,0.0654098f, -0.439077f,0.898135f,-0.0237805f, -0.463592f,0.885685f,-0.0253961f, -0.432904f,0.900567f,0.0396714f, -0.274262f,0.960561f,-0.0458644f, -0.460874f,0.887433f,0.00757752f, -0.557878f,0.824691f,-0.0930446f, -0.608392f,0.791916f,-0.0522232f, -0.68605f,0.722282f,0.0874302f, -0.697187f,0.705867f,0.125228f, -0.597474f,0.77589f,0.202532f, -0.400677f,0.868028f,0.293233f, -0.18602f,0.951589f,0.244694f, -0.190924f,0.979879f,0.0581851f, -0.431268f,0.902043f,-0.01807f, -0.329374f,0.934061f,-0.137997f, -0.144406f,0.935772f,-0.321679f, -0.0779514f,0.92222f,-0.378727f, --0.0417532f,0.914206f,-0.403093f, --0.201619f,0.929423f,0.309066f, --0.0738258f,0.948242f,0.308847f, -0.0288118f,0.952024f,0.304665f, --0.00526808f,0.951397f,0.307922f, --0.0992485f,0.952014f,0.289515f, --0.179425f,0.914994f,0.361376f, --0.223397f,0.866943f,0.445538f, --0.185005f,0.868122f,0.460584f, --0.180405f,0.90051f,0.395646f, --0.165976f,0.891215f,0.422122f, --0.142635f,0.91411f,0.37955f, --0.196593f,0.942079f,0.271733f, --0.231892f,0.955708f,0.181242f, -0.0754625f,0.968764f,0.236224f, -0.189929f,0.95814f,0.214232f, -0.245783f,0.922809f,0.29667f, -0.350212f,0.885135f,0.30641f, -0.361791f,0.894635f,0.262174f, -0.218601f,0.892888f,0.393656f, -0.122578f,0.888731f,0.441737f, -0.221602f,0.877963f,0.42435f, -0.113111f,0.927784f,0.355561f, --0.0962286f,0.967788f,0.232652f, --0.169743f,0.984124f,0.0518298f, -0.00440837f,0.997134f,0.0755295f, --0.0780505f,0.992255f,0.096638f, --0.206915f,0.971074f,0.119173f, --0.298261f,0.946469f,0.123437f, --0.365054f,0.904843f,0.219077f, --0.255666f,0.897337f,0.35975f, --0.290965f,0.914197f,0.282104f, --0.292271f,0.916518f,0.27308f, --0.219619f,0.919339f,0.326472f, --0.256286f,0.928086f,0.270137f, --0.310598f,0.93305f,0.18151f, --0.350728f,0.934452f,0.0615507f, --0.388138f,0.92156f,0.00876308f, --0.343471f,0.93847f,0.0360903f, --0.339947f,0.939272f,-0.0469463f, --0.382902f,0.903055f,-0.19462f, --0.249239f,0.929446f,-0.272047f, --0.147764f,0.944907f,-0.29209f, --0.0668186f,0.978447f,-0.19539f, -0.17553f,0.981686f,-0.0740426f, -0.388973f,0.921211f,-0.00833323f, -0.44678f,0.894539f,-0.0136777f, -0.47739f,0.878112f,-0.0318964f, -0.465567f,0.884409f,-0.0326842f, -0.484387f,0.873859f,-0.0417148f, -0.315003f,0.932104f,-0.178762f, -0.426472f,0.898104f,-0.107381f, -0.587094f,0.80929f,-0.0192587f, -0.491946f,0.869904f,0.0354452f, -0.550379f,0.808299f,0.209131f, -0.597166f,0.706874f,0.379107f, -0.503286f,0.706664f,0.497322f, -0.349603f,0.761935f,0.545191f, -0.317931f,0.791281f,0.522298f, -0.357034f,0.859818f,0.365021f, -0.457671f,0.859336f,0.22821f, -0.436038f,0.880267f,0.187085f, -0.291237f,0.949467f,0.117016f, -0.172846f,0.983353f,0.0560389f, -0.00924155f,0.999014f,-0.043417f, --0.112379f,0.966854f,0.22927f, --0.0543436f,0.980353f,0.189616f, -0.0014105f,0.977032f,0.213089f, --0.0810261f,0.954455f,0.287143f, --0.162384f,0.905883f,0.391161f, --0.248623f,0.850337f,0.463803f, --0.272281f,0.829594f,0.48748f, --0.210534f,0.842738f,0.495447f, --0.142516f,0.845822f,0.514076f, --0.128959f,0.864859f,0.485168f, --0.000520612f,0.895905f,0.444245f, -0.00320439f,0.940529f,0.339698f, --0.169376f,0.979765f,0.106637f, --0.0517963f,0.994886f,0.0867084f, -0.124214f,0.955178f,0.268711f, -0.208945f,0.916166f,0.342027f, -0.39407f,0.858275f,0.328745f, -0.248342f,0.913565f,0.322063f, -0.031165f,0.861455f,0.506877f, -0.0654094f,0.812115f,0.57982f, -0.246891f,0.786687f,0.565834f, -0.230643f,0.834381f,0.500612f, -0.069509f,0.924157f,0.375637f, -0.0080049f,0.977951f,0.208681f, --0.0216545f,0.998818f,0.043521f, --0.0416834f,0.994806f,0.0928633f, --0.209164f,0.977378f,0.0313447f, --0.33727f,0.941399f,0.00405643f, --0.445763f,0.895148f,-0.00236945f, --0.379089f,0.924127f,0.0477591f, --0.212534f,0.958583f,0.189598f, --0.289703f,0.944216f,0.156615f, --0.225857f,0.954875f,0.19288f, --0.19812f,0.968114f,0.153308f, --0.225491f,0.970896f,0.0807165f, --0.268028f,0.963292f,-0.0151842f, --0.386115f,0.917249f,-0.0978197f, --0.332792f,0.935954f,-0.115065f, --0.223332f,0.957817f,-0.180856f, --0.272615f,0.913397f,-0.302304f, --0.182015f,0.92061f,-0.345468f, --0.156497f,0.91949f,-0.36062f, --0.125465f,0.931751f,-0.340733f, -0.1054f,0.935905f,-0.336114f, -0.348771f,0.906917f,-0.236346f, -0.444797f,0.880373f,-0.164617f, -0.451025f,0.885434f,-0.112171f, -0.467976f,0.880983f,-0.0697667f, -0.499335f,0.858868f,-0.114062f, -0.349601f,0.930335f,-0.110707f, -0.307802f,0.944888f,-0.11156f, -0.473394f,0.878106f,0.0694821f, -0.43441f,0.869457f,0.23523f, -0.41901f,0.855868f,0.303184f, -0.452664f,0.775597f,0.439937f, -0.432369f,0.72522f,0.535829f, -0.415514f,0.737038f,0.533032f, -0.381011f,0.793693f,0.474217f, -0.445314f,0.773558f,0.450892f, -0.520117f,0.767192f,0.375359f, -0.457464f,0.838846f,0.295064f, -0.276432f,0.924946f,0.260884f, -0.199394f,0.937964f,0.283664f, -0.190897f,0.927436f,0.32159f, --0.0705492f,0.959049f,0.274315f, --0.0655623f,0.961527f,0.266772f, --0.0518964f,0.943387f,0.32761f, --0.202287f,0.906319f,0.371032f, --0.245861f,0.842829f,0.478739f, --0.310342f,0.836362f,0.451869f, --0.256381f,0.850522f,0.459219f, --0.198762f,0.867072f,0.456815f, --0.12379f,0.863897f,0.48822f, --0.0469651f,0.900623f,0.432056f, --8.11553e-005f,0.943721f,0.330744f, -0.129628f,0.925055f,0.357028f, -0.0340614f,0.966037f,0.256151f, --0.0890995f,0.983963f,0.154524f, --0.0322587f,0.981394f,0.189278f, -0.138447f,0.956229f,0.257794f, -0.317932f,0.883665f,0.343592f, -0.154174f,0.859961f,0.486516f, --0.0823702f,0.837125f,0.540774f, -0.067942f,0.838652f,0.540413f, -0.256779f,0.806501f,0.532561f, -0.317316f,0.771073f,0.552047f, -0.228943f,0.837474f,0.496208f, -0.221417f,0.908583f,0.354192f, -0.0661321f,0.986936f,0.146917f, --0.101631f,0.981129f,0.164493f, --0.140334f,0.967949f,0.20828f, --0.26644f,0.954208f,0.136f, --0.376833f,0.92539f,0.0406146f, --0.423125f,0.902479f,-0.0805992f, --0.378547f,0.924929f,-0.0347556f, --0.294214f,0.950388f,0.101004f, --0.253707f,0.966868f,0.0282789f, --0.1425f,0.989661f,0.0162607f, --0.152778f,0.987285f,-0.0438961f, --0.226417f,0.971142f,-0.0749508f, --0.278106f,0.959626f,-0.0421373f, --0.315252f,0.936348f,-0.154492f, --0.13807f,0.983353f,-0.118124f, --0.169891f,0.968928f,-0.179762f, --0.200272f,0.947942f,-0.247583f, --0.182846f,0.93983f,-0.288594f, --0.0836086f,0.941177f,-0.327408f, -0.0732417f,0.918516f,-0.388542f, -0.208177f,0.929929f,-0.303139f, -0.350352f,0.926406f,-0.137933f, -0.401951f,0.914196f,-0.0517823f, -0.448456f,0.893661f,-0.0160636f, -0.515556f,0.856358f,0.0291996f, -0.347689f,0.937245f,0.0261378f, -0.255909f,0.965329f,0.0514824f, -0.382053f,0.909938f,0.161395f, -0.340926f,0.922929f,0.178808f, -0.312845f,0.910786f,0.269439f, -0.364196f,0.849776f,0.381106f, -0.45928f,0.814969f,0.353394f, -0.52951f,0.800019f,0.282116f, -0.449914f,0.855375f,0.256731f, -0.454599f,0.838858f,0.299428f, -0.555327f,0.766362f,0.322957f, -0.54417f,0.781393f,0.305455f, -0.357615f,0.911759f,0.202005f, -0.139813f,0.972952f,0.183891f, -0.109083f,0.950848f,0.289808f, --0.192892f,0.944314f,0.266579f, --0.117537f,0.919218f,0.375796f, --0.132138f,0.875254f,0.465263f, --0.253971f,0.812679f,0.524453f, --0.263136f,0.777105f,0.571723f, --0.18663f,0.797568f,0.573633f, --0.239071f,0.855961f,0.458449f, --0.228946f,0.872463f,0.431732f, --0.154745f,0.876861f,0.455159f, -0.0511929f,0.876307f,0.479025f, -0.079622f,0.902874f,0.422468f, -0.0999946f,0.903351f,0.417083f, -0.103272f,0.908778f,0.404299f, --0.0300958f,0.943633f,0.329622f, --0.0276233f,0.954592f,0.296632f, -0.0865379f,0.944508f,0.316884f, -0.19572f,0.915809f,0.350694f, -0.0629871f,0.902785f,0.425456f, --0.0973105f,0.893058f,0.439293f, -0.0850344f,0.884912f,0.45793f, -0.226219f,0.859273f,0.458775f, -0.265876f,0.822998f,0.50198f, -0.299522f,0.800365f,0.519329f, -0.365936f,0.804413f,0.467986f, -0.167843f,0.908094f,0.383659f, --0.151292f,0.923022f,0.353753f, --0.16349f,0.897488f,0.409618f, --0.164454f,0.89713f,0.410016f, --0.256833f,0.931773f,0.256583f, --0.308509f,0.944441f,0.11337f, --0.397192f,0.916896f,-0.0392391f, --0.321804f,0.945652f,-0.046751f, --0.145617f,0.989197f,-0.0168656f, --0.117605f,0.989571f,-0.083174f, --0.131213f,0.988938f,-0.0691672f, --0.264465f,0.964357f,-0.00857016f, --0.279285f,0.95849f,0.0574115f, --0.308064f,0.950873f,-0.0306128f, --0.232189f,0.97071f,0.0617333f, --0.126956f,0.977263f,0.169823f, --0.134913f,0.981643f,0.134817f, --0.0643092f,0.996192f,0.0588766f, --0.0179518f,0.989177f,-0.145623f, -0.100718f,0.978365f,-0.180716f, -0.107842f,0.981772f,-0.156502f, -0.235537f,0.96668f,-0.100264f, -0.400696f,0.915349f,-0.0397433f, -0.382123f,0.921514f,-0.0692327f, -0.451191f,0.890657f,0.0561954f, -0.368356f,0.915308f,0.162865f, -0.16123f,0.974745f,0.154523f, -0.326647f,0.914341f,0.239337f, -0.365189f,0.91282f,0.182749f, -0.230086f,0.959458f,0.162792f, -0.336546f,0.918886f,0.205876f, -0.545838f,0.824177f,0.150977f, -0.544526f,0.829407f,0.124801f, -0.442013f,0.862414f,0.24671f, -0.417167f,0.87901f,0.230894f, -0.525918f,0.823184f,0.213956f, -0.591278f,0.763502f,0.259719f, -0.412761f,0.877728f,0.243355f, -0.079495f,0.961838f,0.261818f, --0.108191f,0.959339f,0.260698f, --0.395968f,0.898347f,0.190215f, --0.315805f,0.885393f,0.341095f, --0.255081f,0.831656f,0.493236f, --0.32798f,0.786298f,0.523607f, --0.31899f,0.766541f,0.557369f, --0.160414f,0.763167f,0.625974f, --0.0711111f,0.771377f,0.632393f, --0.143173f,0.825852f,0.545409f, --0.172278f,0.854223f,0.490534f, -0.0123154f,0.838365f,0.544971f, -0.0830743f,0.830631f,0.550592f, -0.0507686f,0.835031f,0.547855f, -0.149519f,0.800804f,0.579962f, -0.0893025f,0.847618f,0.523038f, --0.0238205f,0.893087f,0.449253f, -0.0209713f,0.900623f,0.434095f, -0.182588f,0.867377f,0.462945f, -0.0933756f,0.88802f,0.450223f, --0.0988317f,0.917919f,0.384262f, -0.0323919f,0.922001f,0.38583f, -0.205498f,0.882674f,0.422678f, -0.228981f,0.875897f,0.424702f, -0.330967f,0.833446f,0.442526f, -0.386545f,0.82285f,0.416534f, -0.244254f,0.85459f,0.458275f, --0.128515f,0.915454f,0.381351f, --0.221592f,0.919582f,0.324447f, --0.103305f,0.941351f,0.321226f, --0.0534104f,0.960954f,0.271504f, --0.164863f,0.980806f,0.104112f, --0.239884f,0.970598f,-0.0198681f, --0.303213f,0.937604f,-0.170178f, --0.252015f,0.951441f,-0.176773f, --0.108694f,0.994072f,0.00232095f, --0.192935f,0.981013f,0.0197642f, --0.322908f,0.946132f,0.0237552f, --0.269028f,0.963107f,-0.00704542f, --0.230013f,0.973161f,0.00722315f, --0.357365f,0.933662f,-0.0237822f, --0.204315f,0.973479f,0.102922f, --0.115797f,0.983778f,0.137007f, -0.0200406f,0.991033f,0.132107f, -0.176509f,0.981212f,0.0778953f, -0.102914f,0.991977f,-0.0734239f, -0.103634f,0.990563f,-0.0896973f, -0.246302f,0.962545f,-0.113327f, -0.365449f,0.921945f,-0.12831f, -0.388572f,0.919102f,-0.0652967f, -0.33675f,0.940592f,-0.0434361f, -0.294334f,0.951251f,0.0921318f, -0.170376f,0.973956f,0.149605f, -0.291052f,0.946977f,0.136102f, -0.448607f,0.879963f,0.156258f, -0.275208f,0.960522f,0.0407201f, -0.320727f,0.94717f,-0.00171267f, -0.563867f,0.822582f,0.0735748f, -0.458264f,0.882692f,0.104155f, -0.35932f,0.917336f,0.171414f, -0.473577f,0.85831f,0.197555f, -0.552768f,0.818756f,0.155195f, -0.56022f,0.811568f,0.165865f, -0.410483f,0.877955f,0.246373f, -0.119318f,0.965792f,0.230239f, --0.0302464f,0.98755f,0.15437f, --0.434902f,0.821345f,0.369123f, --0.425801f,0.804682f,0.41374f, --0.330648f,0.807018f,0.489278f, --0.341863f,0.793213f,0.503928f, --0.356504f,0.786512f,0.504286f, --0.269874f,0.813284f,0.515498f, --0.0937663f,0.786137f,0.610898f, --0.0122488f,0.782782f,0.622176f, --0.145176f,0.838097f,0.525849f, --0.0659853f,0.863648f,0.499758f, -0.0911511f,0.81559f,0.571406f, -0.0567409f,0.801208f,0.59569f, -0.110855f,0.801019f,0.588286f, -0.153854f,0.799367f,0.580811f, -0.0810561f,0.837494f,0.540401f, -0.0627084f,0.873537f,0.482702f, -0.153028f,0.87118f,0.466506f, -0.121758f,0.869515f,0.478663f, --0.0139367f,0.889364f,0.456987f, -0.0116753f,0.909652f,0.415206f, -0.182976f,0.873078f,0.451946f, -0.230254f,0.874104f,0.427698f, -0.299542f,0.853577f,0.42624f, -0.365816f,0.815944f,0.447677f, -0.258135f,0.828321f,0.497243f, -0.0438733f,0.899999f,0.433678f, --0.113551f,0.976415f,0.183628f, --0.115165f,0.991964f,0.0523877f, --0.0427249f,0.989973f,0.134639f, --0.000526251f,0.987641f,0.156735f, --0.182878f,0.982656f,-0.0306907f, --0.187196f,0.982029f,-0.0240342f, --0.272847f,0.956238f,-0.105656f, --0.292658f,0.95046f,-0.104775f, --0.178909f,0.983865f,0.00116467f, --0.22078f,0.973898f,-0.0527095f, --0.269354f,0.950491f,-0.154966f, --0.262457f,0.956005f,-0.131038f, --0.333574f,0.929233f,-0.158915f, --0.27846f,0.93913f,-0.201231f, --0.105722f,0.98028f,-0.166954f, --0.03086f,0.983393f,-0.178845f, -0.166296f,0.985117f,-0.0434662f, -0.22991f,0.973119f,0.0134671f, -0.156605f,0.983722f,-0.0881293f, -0.276714f,0.94824f,-0.155787f, -0.32696f,0.929339f,-0.171541f, -0.339039f,0.938238f,-0.0690071f, -0.308789f,0.948131f,-0.0754727f, -0.23717f,0.967343f,-0.0894326f, -0.163558f,0.982662f,-0.0873214f, -0.252735f,0.966333f,-0.0482272f, -0.434287f,0.896865f,0.0838305f, -0.398093f,0.912104f,0.0979158f, -0.320154f,0.94669f,-0.0357668f, -0.45783f,0.889003f,0.00810452f, -0.504235f,0.85135f,0.144742f, -0.385352f,0.920157f,0.0693918f, -0.466232f,0.882239f,0.0654287f, -0.538345f,0.833943f,0.121343f, -0.517827f,0.838051f,0.171829f, -0.46128f,0.862173f,0.209471f, -0.229103f,0.969676f,0.085091f, -0.119821f,0.992172f,0.0351865f, --0.316654f,0.75101f,0.579409f, --0.356062f,0.779142f,0.515904f, --0.357471f,0.814286f,0.457331f, --0.357809f,0.798452f,0.484198f, --0.344344f,0.806376f,0.480818f, --0.279175f,0.813317f,0.510467f, --0.188283f,0.817533f,0.544233f, -0.0108927f,0.825394f,0.564451f, -0.000505664f,0.854739f,0.519058f, --0.0291193f,0.899152f,0.436667f, --0.043893f,0.902469f,0.428513f, --0.00142614f,0.854428f,0.519568f, -0.10644f,0.82426f,0.556117f, -0.17821f,0.772022f,0.610101f, -0.155558f,0.792656f,0.58949f, -0.103298f,0.851042f,0.514837f, -0.136998f,0.86222f,0.487656f, -0.128814f,0.846529f,0.516522f, -0.0086465f,0.861582f,0.507544f, -0.0126115f,0.865086f,0.501464f, -0.152876f,0.854998f,0.495588f, -0.261992f,0.846686f,0.463122f, -0.298132f,0.855648f,0.423065f, -0.330245f,0.846388f,0.417811f, -0.241868f,0.85891f,0.451412f, -0.243399f,0.870337f,0.428102f, -0.218863f,0.950296f,0.221442f, --0.0230145f,0.994562f,-0.101567f, --0.18143f,0.968994f,-0.167732f, --0.00536077f,0.999859f,-0.0158957f, --0.0149312f,0.999841f,-0.00972481f, --0.248945f,0.961384f,-0.11733f, --0.206226f,0.978121f,-0.0273758f, --0.251569f,0.958037f,-0.137399f, --0.215501f,0.957565f,-0.191386f, --0.183194f,0.972176f,-0.145991f, --0.242363f,0.956164f,-0.164351f, --0.223675f,0.959477f,-0.171387f, --0.263678f,0.929229f,-0.25886f, --0.190809f,0.923444f,-0.332932f, --0.125476f,0.902264f,-0.412524f, --0.0800599f,0.931052f,-0.355994f, -0.00289679f,0.952892f,-0.303297f, -0.173027f,0.965415f,-0.195025f, -0.23552f,0.951626f,-0.197328f, -0.324166f,0.90746f,-0.26727f, -0.272213f,0.920502f,-0.280314f, -0.263103f,0.942676f,-0.205278f, -0.331376f,0.931643f,-0.1491f, -0.273621f,0.957062f,-0.0957296f, -0.174678f,0.976512f,-0.126141f, -0.162465f,0.97193f,-0.170168f, -0.285207f,0.956722f,-0.0577913f, -0.392887f,0.912166f,0.116586f, -0.413213f,0.901715f,0.127138f, -0.444428f,0.894805f,0.0425078f, -0.482399f,0.875952f,0.000225918f, -0.414394f,0.908379f,-0.0559034f, -0.421361f,0.906852f,-0.00856344f, -0.501069f,0.86151f,0.0820434f, -0.492896f,0.86226f,0.116453f, -0.497628f,0.854344f,0.149874f, -0.327901f,0.939568f,0.0984569f, -0.134608f,0.990256f,0.0356963f, --0.115732f,0.781457f,0.613132f, --0.224646f,0.82464f,0.519137f, --0.330602f,0.837584f,0.434919f, --0.37055f,0.826801f,0.423193f, --0.389755f,0.836631f,0.38489f, --0.35019f,0.83732f,0.419835f, --0.192063f,0.866433f,0.460875f, -0.0577661f,0.893053f,0.446228f, -0.0715028f,0.909685f,0.409097f, -0.0355467f,0.937027f,0.347443f, --0.0473295f,0.949618f,0.309815f, --0.0714543f,0.946618f,0.31434f, -0.0109848f,0.930588f,0.365903f, -0.0306039f,0.876434f,0.480548f, -0.171338f,0.790427f,0.588106f, -0.228263f,0.773415f,0.591376f, -0.15062f,0.839076f,0.522748f, -0.0933237f,0.852392f,0.514508f, -0.0403687f,0.864191f,0.501542f, -0.0159293f,0.89067f,0.454371f, -0.162582f,0.873944f,0.458028f, -0.324998f,0.838057f,0.438219f, -0.361417f,0.861814f,0.355886f, -0.357364f,0.88789f,0.289727f, -0.288052f,0.920034f,0.265637f, -0.274707f,0.932706f,0.233657f, -0.415911f,0.867317f,0.273456f, -0.214502f,0.965967f,0.144559f, --0.0739208f,0.997262f,-0.00212715f, --0.130316f,0.972201f,-0.194533f, -0.00262571f,0.981048f,-0.193747f, --0.190851f,0.93935f,-0.284951f, --0.250649f,0.92646f,-0.280798f, --0.16238f,0.957944f,-0.236595f, --0.204897f,0.9457f,-0.252327f, --0.246487f,0.945291f,-0.213705f, --0.204741f,0.966747f,-0.153234f, --0.173965f,0.952924f,-0.248341f, --0.185492f,0.924696f,-0.332461f, --0.120486f,0.929748f,-0.347926f, --0.0981061f,0.932335f,-0.348033f, --0.143961f,0.923839f,-0.354678f, --0.0348514f,0.936175f,-0.349804f, -0.141193f,0.941481f,-0.306069f, -0.298926f,0.908144f,-0.293117f, -0.339558f,0.869399f,-0.35895f, -0.236934f,0.893673f,-0.381064f, -0.188986f,0.916304f,-0.353088f, -0.222126f,0.937284f,-0.268624f, -0.165461f,0.966952f,-0.193976f, -0.194618f,0.975642f,-0.101229f, -0.225585f,0.970105f,-0.0894815f, -0.18757f,0.970367f,-0.152331f, -0.271776f,0.9587f,-0.0838549f, -0.390134f,0.920749f,0.00399703f, -0.487191f,0.870564f,0.0690114f, -0.567845f,0.821826f,0.0464111f, -0.430596f,0.898843f,-0.0816633f, -0.345462f,0.936301f,-0.063213f, -0.439054f,0.898457f,0.0025505f, -0.485886f,0.873093f,0.040301f, -0.468523f,0.882438f,0.0422951f, -0.395695f,0.916215f,0.0630502f, -0.224264f,0.974198f,-0.0253916f, --0.04074f,0.869731f,0.491842f, --0.147521f,0.861626f,0.485632f, --0.290306f,0.828918f,0.47814f, --0.344291f,0.81826f,0.460342f, --0.325822f,0.848235f,0.417537f, --0.347006f,0.892025f,0.289618f, --0.23289f,0.9484f,0.215175f, -0.0826503f,0.953848f,0.288692f, -0.0849803f,0.942357f,0.323639f, -0.0946367f,0.912864f,0.397143f, -0.0188563f,0.944615f,0.327637f, --0.0844647f,0.976435f,0.198596f, --0.0480441f,0.982086f,0.182207f, --0.108246f,0.969423f,0.220233f, -0.0163534f,0.944153f,0.329102f, -0.218936f,0.864112f,0.453186f, -0.243602f,0.846524f,0.473344f, -0.157715f,0.898021f,0.410713f, -0.124101f,0.930824f,0.343753f, -0.0887369f,0.958556f,0.270731f, -0.13199f,0.965856f,0.222935f, -0.34996f,0.900513f,0.258077f, -0.45204f,0.856515f,0.249081f, -0.434574f,0.879659f,0.19325f, -0.307812f,0.936972f,0.165332f, -0.238408f,0.942387f,0.234669f, -0.292411f,0.883524f,0.365897f, -0.235944f,0.851222f,0.468777f, -0.0834983f,0.888208f,0.45179f, -0.120252f,0.948234f,0.293925f, -0.107426f,0.988487f,0.106553f, --0.0604958f,0.997925f,0.0220282f, --0.22861f,0.965114f,-0.127644f, --0.213845f,0.934088f,-0.285919f, --0.236679f,0.925441f,-0.295876f, --0.274282f,0.922231f,-0.272506f, --0.200442f,0.934584f,-0.293896f, --0.0905439f,0.955043f,-0.282301f, --0.107977f,0.974204f,-0.198159f, --0.176859f,0.954188f,-0.241343f, --0.109412f,0.961464f,-0.252221f, --0.0832631f,0.934053f,-0.347292f, --0.0389646f,0.894623f,-0.44512f, -0.0844722f,0.90285f,-0.421576f, -0.278944f,0.884527f,-0.373902f, -0.405411f,0.845478f,-0.347577f, -0.241979f,0.880406f,-0.407837f, -0.10107f,0.917999f,-0.383487f, -0.153454f,0.950374f,-0.270631f, -0.150056f,0.964994f,-0.215103f, -0.116981f,0.964373f,-0.237277f, -0.171185f,0.966068f,-0.19341f, -0.269303f,0.954896f,-0.1251f, -0.246577f,0.939836f,-0.236448f, -0.325998f,0.915178f,-0.237011f, -0.400262f,0.89707f,-0.18723f, -0.540095f,0.838463f,-0.0726465f, -0.4591f,0.888384f,0.000734802f, -0.350121f,0.936701f,0.00262749f, -0.415959f,0.907987f,-0.0503785f, -0.469999f,0.882626f,-0.00849165f, -0.46759f,0.883776f,0.0172864f, -0.444948f,0.895095f,0.0287648f, -0.38429f,0.923043f,-0.0176926f, --0.184131f,0.893945f,0.408605f, --0.22256f,0.84592f,0.484651f, --0.306803f,0.799127f,0.516979f, --0.327467f,0.825975f,0.458836f, --0.215523f,0.873324f,0.43687f, --0.122358f,0.93676f,0.327886f, --0.214245f,0.969738f,0.117081f, -0.00165628f,0.984816f,0.173596f, --0.0471807f,0.97232f,0.228838f, --0.042786f,0.929182f,0.367137f, -0.159108f,0.885534f,0.43648f, -0.0848362f,0.945025f,0.315803f, --0.0323525f,0.969808f,0.241716f, --0.0998895f,0.964402f,0.244849f, --0.0727123f,0.986494f,0.146772f, -0.121392f,0.97688f,0.175982f, -0.260802f,0.928486f,0.264378f, -0.24004f,0.922405f,0.302572f, -0.162896f,0.94112f,0.296239f, -0.158069f,0.936377f,0.313389f, -0.18876f,0.956613f,0.221947f, -0.312407f,0.939867f,0.138025f, -0.450948f,0.870255f,0.198248f, -0.44762f,0.863366f,0.232885f, -0.235953f,0.935784f,0.261983f, -0.128819f,0.928252f,0.348933f, -0.106701f,0.927182f,0.359094f, -0.172918f,0.882203f,0.437968f, -0.183128f,0.868984f,0.459707f, -0.240959f,0.881259f,0.406597f, -0.154256f,0.918617f,0.363797f, -0.0253035f,0.919137f,0.393124f, -0.0182377f,0.964511f,0.263413f, -0.0263571f,0.99964f,0.00499089f, --0.149002f,0.961331f,-0.231604f, --0.264821f,0.912849f,-0.310769f, --0.139498f,0.954507f,-0.263548f, --0.253683f,0.93262f,-0.25664f, --0.265231f,0.9626f,-0.0552561f, --0.114883f,0.993341f,-0.00868247f, -0.0072742f,0.99351f,-0.113513f, -0.112563f,0.957036f,-0.26723f, -0.0621414f,0.905176f,-0.420469f, -0.0722297f,0.880288f,-0.468909f, -0.230329f,0.856327f,-0.462225f, -0.381575f,0.843927f,-0.377079f, -0.221134f,0.891315f,-0.395799f, -0.0308171f,0.923698f,-0.381879f, -0.0400222f,0.939112f,-0.341272f, -0.100477f,0.950816f,-0.293006f, -0.177047f,0.942783f,-0.282515f, -0.133298f,0.926135f,-0.352852f, -0.196525f,0.937661f,-0.286653f, -0.349249f,0.920399f,-0.17576f, -0.344233f,0.909171f,-0.234334f, -0.376056f,0.891226f,-0.25357f, -0.439076f,0.869021f,-0.228069f, -0.419906f,0.900431f,-0.113589f, -0.367672f,0.919513f,-0.13897f, -0.413581f,0.894358f,-0.170514f, -0.417856f,0.905717f,-0.0712231f, -0.442627f,0.896671f,0.00788109f, -0.434719f,0.900071f,0.0298519f, -0.417993f,0.908131f,0.0240916f, --0.312333f,0.839022f,0.445522f, --0.320499f,0.80841f,0.493714f, --0.254519f,0.811123f,0.526593f, --0.204612f,0.85744f,0.472156f, --0.178862f,0.910868f,0.371925f, --0.00702334f,0.926328f,0.376653f, --0.0708828f,0.954444f,0.289847f, --0.0771525f,0.977635f,0.195648f, --0.0751036f,0.961343f,0.264914f, --0.145577f,0.95681f,0.25164f, -0.127391f,0.9356f,0.329278f, -0.155803f,0.922417f,0.353372f, --0.0158909f,0.953782f,0.300078f, --0.071615f,0.974742f,0.211541f, -0.0985463f,0.976728f,0.190504f, -0.112633f,0.991267f,0.0685771f, -0.169574f,0.979892f,0.105153f, -0.189025f,0.96308f,0.191696f, -0.0919285f,0.967342f,0.236218f, -0.12853f,0.953507f,0.272588f, -0.291986f,0.918653f,0.266123f, -0.353363f,0.907675f,0.226407f, -0.385555f,0.89484f,0.224962f, -0.404454f,0.872627f,0.273752f, -0.205311f,0.929054f,0.307743f, -0.110161f,0.942272f,0.316208f, -0.185964f,0.923078f,0.336668f, -0.152054f,0.949861f,0.273212f, -0.185461f,0.938647f,0.290768f, -0.273329f,0.907935f,0.317718f, -0.1744f,0.944567f,0.278169f, -0.0252708f,0.979111f,0.20175f, -0.168508f,0.972599f,0.160178f, -0.171022f,0.978059f,0.118964f, -0.0998107f,0.989636f,0.103241f, --0.201522f,0.966723f,-0.157591f, --0.270475f,0.936595f,-0.222784f, --0.312657f,0.944755f,-0.0984088f, --0.352005f,0.934773f,-0.0478632f, --0.0861214f,0.995901f,-0.0276381f, -0.0987576f,0.994369f,-0.0384345f, -0.271502f,0.95802f,-0.0921061f, -0.198786f,0.941001f,-0.273863f, -0.12025f,0.91375f,-0.388073f, -0.19318f,0.901312f,-0.38771f, -0.347672f,0.893681f,-0.283653f, -0.243349f,0.925421f,-0.290477f, -0.0173943f,0.947888f,-0.318129f, -0.037959f,0.944705f,-0.325718f, -0.138906f,0.919468f,-0.36781f, -0.157447f,0.882137f,-0.443897f, -0.187757f,0.895179f,-0.404229f, -0.0607904f,0.891083f,-0.44975f, -0.186006f,0.945946f,-0.265685f, -0.365887f,0.929282f,-0.0506235f, -0.41897f,0.907686f,-0.0238758f, -0.421784f,0.903427f,-0.0769231f, -0.443234f,0.894342f,-0.0608035f, -0.410975f,0.898831f,-0.152323f, -0.386797f,0.913648f,-0.125039f, -0.291947f,0.94823f,-0.125004f, -0.388472f,0.921139f,-0.0243475f, -0.43729f,0.89932f,0.000909095f, -0.438439f,0.898727f,-0.00777216f, --0.28789f,0.841477f,0.457204f, --0.335895f,0.843138f,0.419871f, --0.2812f,0.876582f,0.390553f, --0.0955224f,0.927302f,0.361922f, --0.12003f,0.968207f,0.219473f, --0.0624603f,0.972133f,0.225956f, -0.00876105f,0.944888f,0.327276f, --0.0188296f,0.951986f,0.305562f, --0.0880524f,0.955492f,0.28157f, --0.14211f,0.96142f,0.235533f, -0.0867118f,0.963277f,0.254122f, -0.135173f,0.965034f,0.224584f, -0.150393f,0.96446f,0.217252f, -0.0301773f,0.99954f,0.00289386f, -0.112215f,0.991225f,-0.0698593f, -0.139936f,0.985559f,-0.0953439f, -0.125274f,0.991296f,-0.0404889f, -0.130003f,0.991461f,0.0102436f, -0.104702f,0.992835f,0.0575904f, -0.129192f,0.991077f,0.0328109f, -0.258743f,0.962487f,0.0816753f, -0.358319f,0.917773f,0.171175f, -0.362543f,0.919373f,0.152698f, -0.379026f,0.899795f,0.216122f, -0.252574f,0.930076f,0.266767f, -0.106065f,0.974915f,0.195683f, -0.13953f,0.968709f,0.205267f, -0.207814f,0.946678f,0.246198f, -0.149976f,0.969192f,0.195383f, -0.250422f,0.937237f,0.242644f, -0.308573f,0.924236f,0.224878f, -0.137327f,0.986571f,0.0884273f, -0.176869f,0.981357f,0.0752039f, -0.106914f,0.989761f,0.0945676f, -0.0990876f,0.985862f,0.135123f, -0.0562231f,0.995571f,0.0753513f, --0.246892f,0.957072f,-0.15185f, --0.351837f,0.92065f,-0.169157f, --0.377614f,0.902561f,-0.206862f, --0.10132f,0.980362f,-0.169188f, -0.0776454f,0.98254f,-0.169077f, -0.306304f,0.93954f,-0.153108f, -0.377181f,0.900422f,-0.216738f, -0.189257f,0.917577f,-0.349621f, -0.154953f,0.928643f,-0.337063f, -0.267717f,0.911458f,-0.312367f, -0.294676f,0.908518f,-0.296244f, -0.0231864f,0.917435f,-0.39721f, -0.0626224f,0.928776f,-0.365314f, -0.222796f,0.906686f,-0.358165f, -0.23143f,0.87959f,-0.415646f, -0.13808f,0.870415f,-0.472559f, -0.025291f,0.910796f,-0.412081f, --0.0453254f,0.945277f,-0.323104f, -0.159501f,0.971914f,-0.17304f, -0.38445f,0.922508f,-0.0343154f, -0.457445f,0.889226f,-0.00452937f, -0.479545f,0.877417f,-0.0132742f, -0.420093f,0.902443f,-0.0954967f, -0.386091f,0.921349f,-0.0452663f, -0.319162f,0.945851f,-0.059174f, -0.358596f,0.930564f,-0.0738904f, -0.442653f,0.891593f,-0.0955061f, -0.442432f,0.88607f,-0.138327f, --0.180108f,0.868506f,0.461799f, --0.252344f,0.891893f,0.375298f, --0.214515f,0.951228f,0.221693f, --0.0232238f,0.989215f,0.144618f, -0.0240637f,0.992144f,0.122761f, --0.119024f,0.992873f,0.00598183f, --0.113037f,0.992656f,0.0430988f, --0.0429691f,0.994091f,0.0996822f, --0.0494378f,0.98881f,0.140751f, --0.101045f,0.990831f,0.0896877f, -0.0748729f,0.995782f,0.0530223f, -0.173588f,0.976877f,0.124814f, -0.168744f,0.967443f,0.188628f, -0.211654f,0.955224f,0.206761f, -0.198232f,0.976689f,0.0823528f, -0.160641f,0.986993f,-0.00630407f, -0.0575905f,0.994633f,-0.0859521f, -0.0365841f,0.998447f,-0.0420043f, -0.0556411f,0.989086f,0.136432f, -0.127974f,0.973486f,0.1896f, -0.188609f,0.96964f,0.155643f, -0.316079f,0.935031f,0.16066f, -0.368833f,0.913789f,0.170151f, -0.28567f,0.933317f,0.217512f, -0.224877f,0.919424f,0.322631f, -0.173372f,0.927466f,0.331284f, -0.14641f,0.951279f,0.271352f, -0.199618f,0.950197f,0.239328f, -0.194716f,0.961761f,0.192616f, -0.211001f,0.970026f,0.12053f, -0.377145f,0.915922f,0.137289f, -0.173279f,0.983115f,0.0588147f, -0.137169f,0.986854f,0.085457f, -0.167124f,0.984519f,0.0528309f, -0.114693f,0.990538f,-0.0753596f, -0.120988f,0.991416f,-0.0495523f, --0.0934722f,0.99234f,-0.0807704f, --0.28812f,0.930265f,-0.227141f, --0.319246f,0.884516f,-0.340167f, --0.147049f,0.912977f,-0.380591f, -0.113837f,0.925954f,-0.360071f, -0.286328f,0.873071f,-0.394668f, -0.386305f,0.86841f,-0.310857f, -0.201568f,0.937185f,-0.284702f, -0.165365f,0.953527f,-0.251875f, -0.277218f,0.910704f,-0.306215f, -0.350715f,0.890932f,-0.288511f, -0.130261f,0.920935f,-0.367302f, --0.00793534f,0.891743f,-0.452472f, -0.173424f,0.90309f,-0.392878f, -0.309572f,0.891597f,-0.330484f, -0.155483f,0.904383f,-0.397387f, --0.0901615f,0.931774f,-0.351664f, --0.12522f,0.950283f,-0.285102f, -0.116309f,0.952999f,-0.279758f, -0.314059f,0.900664f,-0.300285f, -0.399484f,0.884115f,-0.242388f, -0.476487f,0.865346f,-0.155359f, -0.461331f,0.87037f,-0.172132f, -0.340659f,0.915541f,-0.213858f, -0.307988f,0.934535f,-0.178292f, -0.356904f,0.924065f,-0.136833f, -0.470016f,0.879468f,-0.0749671f, -0.505067f,0.862447f,-0.0330571f, --0.15355f,0.924768f,0.348175f, --0.09321f,0.949622f,0.299215f, --0.0484808f,0.991662f,0.1194f, --0.0103305f,0.999605f,0.0261285f, -0.0401188f,0.998578f,0.0351042f, --0.00661539f,0.998628f,-0.0519471f, --0.0683745f,0.981776f,-0.177318f, --0.0856989f,0.966825f,-0.240633f, --0.0983519f,0.984458f,-0.145499f, --0.0680709f,0.995572f,-0.0648268f, -0.0777629f,0.996246f,-0.0380386f, -0.0383267f,0.998901f,-0.0269619f, -0.00333347f,0.997094f,0.0761077f, -0.139217f,0.959624f,0.244419f, -0.245721f,0.912381f,0.327386f, -0.246821f,0.907772f,0.339159f, -0.175417f,0.940931f,0.289617f, --0.027159f,0.9789f,0.202525f, --0.173424f,0.953226f,0.247557f, -0.0844967f,0.921276f,0.37962f, -0.304261f,0.89366f,0.329845f, -0.31812f,0.923926f,0.21251f, -0.353311f,0.902952f,0.244642f, -0.195957f,0.945525f,0.25997f, -0.182247f,0.923305f,0.338075f, -0.134205f,0.934918f,0.328507f, -0.176553f,0.881734f,0.437463f, -0.22427f,0.87574f,0.42753f, -0.29074f,0.869795f,0.398657f, -0.272684f,0.924539f,0.266215f, -0.39631f,0.892935f,0.213556f, -0.227086f,0.96746f,0.111597f, -0.14196f,0.988195f,0.0576051f, -0.283679f,0.958555f,0.0264133f, -0.216474f,0.969698f,-0.113251f, -0.0386649f,0.982201f,-0.183812f, --0.0151491f,0.988164f,-0.152652f, --0.145516f,0.952277f,-0.268316f, --0.219857f,0.921944f,-0.318875f, --0.140821f,0.920717f,-0.363936f, -0.13255f,0.932146f,-0.33695f, -0.285156f,0.898104f,-0.334807f, -0.270867f,0.921389f,-0.278701f, -0.136545f,0.958362f,-0.250793f, -0.156889f,0.960437f,-0.230103f, -0.337521f,0.917391f,-0.210889f, -0.340375f,0.909959f,-0.236896f, -0.226521f,0.931852f,-0.283443f, -0.0467156f,0.919678f,-0.389885f, -0.11829f,0.926104f,-0.358244f, -0.284734f,0.910765f,-0.299055f, -0.155007f,0.943096f,-0.294183f, --0.117772f,0.948884f,-0.29283f, --0.124268f,0.932168f,-0.340029f, -0.155477f,0.92011f,-0.359477f, -0.348711f,0.859859f,-0.372885f, -0.344156f,0.842199f,-0.415039f, -0.367487f,0.839547f,-0.400142f, -0.45537f,0.851179f,-0.261021f, -0.340771f,0.905445f,-0.25307f, -0.281592f,0.927438f,-0.246101f, -0.270207f,0.930215f,-0.248371f, -0.337751f,0.936799f,-0.0912801f, -0.415821f,0.905383f,0.085868f, --0.0508816f,0.992949f,0.107064f, -0.00772943f,0.999926f,0.0093874f, -0.0748585f,0.990585f,-0.114623f, -0.0155266f,0.983672f,-0.179298f, -0.0579395f,0.986738f,-0.15163f, -0.0876255f,0.991018f,-0.10102f, -0.0527296f,0.995461f,-0.0792264f, --0.086898f,0.99085f,-0.103274f, --0.226618f,0.972789f,-0.0482267f, --0.175193f,0.983195f,0.0513344f, -0.0267808f,0.994997f,0.0962477f, -0.0618698f,0.991981f,0.110211f, --0.098328f,0.984739f,0.143601f, --0.00458312f,0.952299f,0.305132f, -0.173153f,0.913691f,0.367678f, -0.186464f,0.911194f,0.367365f, -0.171431f,0.905309f,0.388622f, -0.0620384f,0.93682f,0.344266f, --0.143644f,0.960893f,0.23675f, -0.0362541f,0.97893f,0.200951f, -0.349667f,0.904284f,0.244957f, -0.338175f,0.903327f,0.26389f, -0.333852f,0.898218f,0.285914f, -0.192181f,0.948404f,0.252183f, -0.15408f,0.957234f,0.244873f, -0.108314f,0.961372f,0.253046f, -0.0186373f,0.953687f,0.300223f, -0.205839f,0.914416f,0.34853f, -0.331275f,0.886521f,0.323015f, -0.368345f,0.875165f,0.313702f, -0.405591f,0.862022f,0.303997f, -0.335644f,0.884308f,0.324566f, -0.194457f,0.953987f,0.228245f, -0.317589f,0.932139f,0.173936f, -0.34707f,0.93458f,0.0781131f, -0.1429f,0.981779f,-0.125256f, -0.0457434f,0.962864f,-0.266085f, --0.0800896f,0.929514f,-0.359987f, --0.224976f,0.908098f,-0.353191f, --0.16594f,0.929111f,-0.330481f, -0.0749763f,0.957672f,-0.277928f, -0.277052f,0.936424f,-0.215295f, -0.266206f,0.947023f,-0.17967f, -0.192217f,0.96172f,-0.195315f, -0.159333f,0.947925f,-0.275775f, -0.291985f,0.916673f,-0.272864f, -0.390644f,0.893072f,-0.223205f, -0.316013f,0.901654f,-0.295223f, -0.0938304f,0.916417f,-0.38907f, -0.0371906f,0.918056f,-0.394702f, -0.249356f,0.914822f,-0.317682f, -0.159281f,0.933374f,-0.321625f, --0.034507f,0.927426f,-0.372412f, --0.0639276f,0.876921f,-0.476365f, -0.150154f,0.87361f,-0.462881f, -0.34577f,0.845394f,-0.407127f, -0.406017f,0.841234f,-0.357037f, -0.322181f,0.876026f,-0.358855f, -0.315882f,0.91236f,-0.260417f, -0.325378f,0.928704f,-0.177873f, -0.281437f,0.937288f,-0.205633f, -0.23991f,0.955112f,-0.173792f, -0.165717f,0.980838f,-0.102443f, -0.16591f,0.98582f,-0.0251575f, -0.188672f,0.97776f,0.0915829f, -0.0994257f,0.983812f,-0.14909f, -0.199087f,0.95198f,-0.232593f, -0.0121878f,0.914874f,-0.403556f, --0.0234414f,0.930265f,-0.36614f, --0.038124f,0.972539f,-0.229595f, --0.0300917f,0.999515f,-0.00796094f, --0.092201f,0.984658f,0.148144f, --0.315366f,0.938181f,0.142688f, --0.138968f,0.942311f,0.304528f, -0.0277459f,0.977812f,0.207641f, -0.0496201f,0.98101f,0.187502f, --0.256039f,0.940975f,0.22138f, --0.0796386f,0.864833f,0.495703f, -0.172206f,0.836979f,0.519434f, -0.218401f,0.8652f,0.451365f, -0.211231f,0.888948f,0.406391f, -0.153922f,0.942863f,0.295494f, --0.0705923f,0.983817f,0.164685f, -0.0334153f,0.99603f,0.0825054f, -0.282635f,0.9535f,0.104667f, -0.322121f,0.91103f,0.257413f, -0.32296f,0.89395f,0.310726f, -0.263681f,0.921808f,0.284152f, -0.145976f,0.970498f,0.191897f, -0.110214f,0.967993f,0.225482f, -0.0100073f,0.970397f,0.241307f, -0.231259f,0.94984f,0.210532f, -0.350804f,0.929639f,0.112731f, -0.388908f,0.908557f,0.152559f, -0.325259f,0.933029f,0.153831f, -0.358244f,0.845843f,0.395235f, -0.245479f,0.88292f,0.400241f, -0.340078f,0.880829f,0.329372f, -0.448713f,0.860203f,0.242295f, -0.291253f,0.956268f,-0.0268833f, -0.174446f,0.957532f,-0.229565f, --0.0246181f,0.920367f,-0.390281f, --0.230596f,0.878986f,-0.417383f, --0.188847f,0.897269f,-0.399054f, -0.0175328f,0.926292f,-0.376398f, -0.23985f,0.925856f,-0.291997f, -0.22945f,0.938275f,-0.258829f, -0.212396f,0.953082f,-0.21569f, -0.229329f,0.940641f,-0.250204f, -0.284501f,0.899212f,-0.33238f, -0.376241f,0.875275f,-0.30387f, -0.33476f,0.887829f,-0.315744f, -0.163808f,0.925647f,-0.341094f, -0.00890663f,0.895805f,-0.444357f, -0.214972f,0.896442f,-0.38753f, -0.17587f,0.912162f,-0.370177f, -0.075136f,0.903308f,-0.422362f, --0.00910936f,0.832148f,-0.55448f, -0.080579f,0.825188f,-0.559082f, -0.296201f,0.838595f,-0.457191f, -0.316267f,0.8627f,-0.39462f, -0.301959f,0.9215f,-0.24425f, -0.239667f,0.953185f,-0.184387f, -0.359606f,0.929321f,-0.0839473f, -0.264487f,0.941897f,-0.207066f, -0.184815f,0.971569f,-0.147976f, -0.141833f,0.988976f,-0.0425335f, -0.112364f,0.992816f,-0.0411276f, -}; - -btScalar Landscape04Tex[] = { -0.507813f,0.25f, -0.507813f,0.242188f, -0.515625f,0.25f, -0.515625f,0.242188f, -0.523438f,0.25f, -0.523438f,0.242188f, -0.53125f,0.25f, -0.53125f,0.242188f, -0.539063f,0.25f, -0.539063f,0.242188f, -0.546875f,0.25f, -0.546875f,0.242188f, -0.554688f,0.25f, -0.554688f,0.242188f, -0.5625f,0.25f, -0.5625f,0.242188f, -0.570313f,0.25f, -0.570313f,0.242188f, -0.578125f,0.25f, -0.578125f,0.242188f, -0.585938f,0.25f, -0.585938f,0.242188f, -0.59375f,0.25f, -0.59375f,0.242188f, -0.601563f,0.25f, -0.601563f,0.242188f, -0.609375f,0.25f, -0.609375f,0.242188f, -0.617188f,0.25f, -0.617188f,0.242188f, -0.625f,0.25f, -0.625f,0.242188f, -0.632813f,0.25f, -0.632813f,0.242188f, -0.640625f,0.25f, -0.640625f,0.242188f, -0.648438f,0.25f, -0.648438f,0.242188f, -0.65625f,0.25f, -0.65625f,0.242188f, -0.664063f,0.25f, -0.664063f,0.242188f, -0.671875f,0.25f, -0.671875f,0.242188f, -0.679688f,0.25f, -0.679688f,0.242188f, -0.6875f,0.25f, -0.6875f,0.242188f, -0.695313f,0.25f, -0.695313f,0.242188f, -0.703125f,0.25f, -0.703125f,0.242188f, -0.710938f,0.25f, -0.710938f,0.242188f, -0.71875f,0.25f, -0.71875f,0.242188f, -0.726563f,0.25f, -0.726563f,0.242188f, -0.734375f,0.25f, -0.734375f,0.242188f, -0.742188f,0.25f, -0.742188f,0.242188f, -0.75f,0.25f, -0.75f,0.242188f, -0.757813f,0.25f, -0.757813f,0.242188f, -0.765625f,0.25f, -0.765625f,0.242188f, -0.773438f,0.25f, -0.773438f,0.242188f, -0.78125f,0.25f, -0.78125f,0.242188f, -0.789063f,0.25f, -0.789063f,0.242188f, -0.796875f,0.25f, -0.796875f,0.242188f, -0.804688f,0.25f, -0.804688f,0.242188f, -0.8125f,0.25f, -0.8125f,0.242188f, -0.820313f,0.25f, -0.820313f,0.242188f, -0.828125f,0.25f, -0.828125f,0.242188f, -0.835938f,0.25f, -0.835938f,0.242188f, -0.84375f,0.25f, -0.84375f,0.242188f, -0.851563f,0.25f, -0.851563f,0.242188f, -0.859375f,0.25f, -0.859375f,0.242188f, -0.867188f,0.25f, -0.867188f,0.242188f, -0.875f,0.25f, -0.875f,0.242188f, -0.882813f,0.25f, -0.882813f,0.242188f, -0.890625f,0.25f, -0.890625f,0.242188f, -0.898438f,0.25f, -0.898438f,0.242188f, -0.90625f,0.25f, -0.90625f,0.242188f, -0.914063f,0.25f, -0.914063f,0.242188f, -0.921875f,0.25f, -0.921875f,0.242188f, -0.929688f,0.25f, -0.929688f,0.242188f, -0.9375f,0.25f, -0.9375f,0.242188f, -0.945313f,0.25f, -0.945313f,0.242188f, -0.953125f,0.25f, -0.953125f,0.242188f, -0.960938f,0.25f, -0.960938f,0.242188f, -0.96875f,0.25f, -0.96875f,0.242188f, -0.976563f,0.25f, -0.976563f,0.242188f, -0.984375f,0.25f, -0.984375f,0.242188f, -0.992188f,0.25f, -0.992188f,0.242188f, -1.0f,0.25f, -1.0f,0.242188f, -0.507813f,0.257813f, -0.515625f,0.257813f, -0.523438f,0.257813f, -0.53125f,0.257813f, -0.539063f,0.257813f, -0.546875f,0.257813f, -0.554688f,0.257813f, -0.5625f,0.257813f, -0.570313f,0.257813f, -0.578125f,0.257813f, -0.585938f,0.257813f, -0.59375f,0.257813f, -0.601563f,0.257813f, -0.609375f,0.257813f, -0.617188f,0.257813f, -0.625f,0.257813f, -0.632813f,0.257813f, -0.640625f,0.257813f, -0.648438f,0.257813f, -0.65625f,0.257813f, -0.664063f,0.257813f, -0.671875f,0.257813f, -0.679688f,0.257813f, -0.6875f,0.257813f, -0.695313f,0.257813f, -0.703125f,0.257813f, -0.710938f,0.257813f, -0.71875f,0.257813f, -0.726563f,0.257813f, -0.734375f,0.257813f, -0.742188f,0.257813f, -0.75f,0.257813f, -0.757813f,0.257813f, -0.765625f,0.257813f, -0.773438f,0.257813f, -0.78125f,0.257813f, -0.789063f,0.257813f, -0.796875f,0.257813f, -0.804688f,0.257813f, -0.8125f,0.257813f, -0.820313f,0.257813f, -0.828125f,0.257813f, -0.835938f,0.257813f, -0.84375f,0.257813f, -0.851563f,0.257813f, -0.859375f,0.257813f, -0.867188f,0.257813f, -0.875f,0.257813f, -0.882813f,0.257813f, -0.890625f,0.257813f, -0.898438f,0.257813f, -0.90625f,0.257813f, -0.914063f,0.257813f, -0.921875f,0.257813f, -0.929688f,0.257813f, -0.9375f,0.257813f, -0.945313f,0.257813f, -0.953125f,0.257813f, -0.960938f,0.257813f, -0.96875f,0.257813f, -0.976563f,0.257813f, -0.984375f,0.257813f, -0.992188f,0.257813f, -1.0f,0.257813f, -0.507813f,0.265625f, -0.515625f,0.265625f, -0.523438f,0.265625f, -0.53125f,0.265625f, -0.539063f,0.265625f, -0.546875f,0.265625f, -0.554688f,0.265625f, -0.5625f,0.265625f, -0.570313f,0.265625f, -0.578125f,0.265625f, -0.585938f,0.265625f, -0.59375f,0.265625f, -0.601563f,0.265625f, -0.609375f,0.265625f, -0.617188f,0.265625f, -0.625f,0.265625f, -0.632813f,0.265625f, -0.640625f,0.265625f, -0.648438f,0.265625f, -0.65625f,0.265625f, -0.664063f,0.265625f, -0.671875f,0.265625f, -0.679688f,0.265625f, -0.6875f,0.265625f, -0.695313f,0.265625f, -0.703125f,0.265625f, -0.710938f,0.265625f, -0.71875f,0.265625f, -0.726563f,0.265625f, -0.734375f,0.265625f, -0.742188f,0.265625f, -0.75f,0.265625f, -0.757813f,0.265625f, -0.765625f,0.265625f, -0.773438f,0.265625f, -0.78125f,0.265625f, -0.789063f,0.265625f, -0.796875f,0.265625f, -0.804688f,0.265625f, -0.8125f,0.265625f, -0.820313f,0.265625f, -0.828125f,0.265625f, -0.835938f,0.265625f, -0.84375f,0.265625f, -0.851563f,0.265625f, -0.859375f,0.265625f, -0.867188f,0.265625f, -0.875f,0.265625f, -0.882813f,0.265625f, -0.890625f,0.265625f, -0.898438f,0.265625f, -0.90625f,0.265625f, -0.914063f,0.265625f, -0.921875f,0.265625f, -0.929688f,0.265625f, -0.9375f,0.265625f, -0.945313f,0.265625f, -0.953125f,0.265625f, -0.960938f,0.265625f, -0.96875f,0.265625f, -0.976563f,0.265625f, -0.984375f,0.265625f, -0.992188f,0.265625f, -1.0f,0.265625f, -0.507813f,0.273438f, -0.515625f,0.273438f, -0.523438f,0.273438f, -0.53125f,0.273438f, -0.539063f,0.273438f, -0.546875f,0.273438f, -0.554688f,0.273438f, -0.5625f,0.273438f, -0.570313f,0.273438f, -0.578125f,0.273438f, -0.585938f,0.273438f, -0.59375f,0.273438f, -0.601563f,0.273438f, -0.609375f,0.273438f, -0.617188f,0.273438f, -0.625f,0.273438f, -0.632813f,0.273438f, -0.640625f,0.273438f, -0.648438f,0.273438f, -0.65625f,0.273438f, -0.664063f,0.273438f, -0.671875f,0.273438f, -0.679688f,0.273438f, -0.6875f,0.273438f, -0.695313f,0.273438f, -0.703125f,0.273438f, -0.710938f,0.273438f, -0.71875f,0.273438f, -0.726563f,0.273438f, -0.734375f,0.273438f, -0.742188f,0.273438f, -0.75f,0.273438f, -0.757813f,0.273438f, -0.765625f,0.273438f, -0.773438f,0.273438f, -0.78125f,0.273438f, -0.789063f,0.273438f, -0.796875f,0.273438f, -0.804688f,0.273438f, -0.8125f,0.273438f, -0.820313f,0.273438f, -0.828125f,0.273438f, -0.835938f,0.273438f, -0.84375f,0.273438f, -0.851563f,0.273438f, -0.859375f,0.273438f, -0.867188f,0.273438f, -0.875f,0.273438f, -0.882813f,0.273438f, -0.890625f,0.273438f, -0.898438f,0.273438f, -0.90625f,0.273438f, -0.914063f,0.273438f, -0.921875f,0.273438f, -0.929688f,0.273438f, -0.9375f,0.273438f, -0.945313f,0.273438f, -0.953125f,0.273438f, -0.960938f,0.273438f, -0.96875f,0.273438f, -0.976563f,0.273438f, -0.984375f,0.273438f, -0.992188f,0.273438f, -1.0f,0.273438f, -0.507813f,0.28125f, -0.515625f,0.28125f, -0.523438f,0.28125f, -0.53125f,0.28125f, -0.539063f,0.28125f, -0.546875f,0.28125f, -0.554688f,0.28125f, -0.5625f,0.28125f, -0.570313f,0.28125f, -0.578125f,0.28125f, -0.585938f,0.28125f, -0.59375f,0.28125f, -0.601563f,0.28125f, -0.609375f,0.28125f, -0.617188f,0.28125f, -0.625f,0.28125f, -0.632813f,0.28125f, -0.640625f,0.28125f, -0.648438f,0.28125f, -0.65625f,0.28125f, -0.664063f,0.28125f, -0.671875f,0.28125f, -0.679688f,0.28125f, -0.6875f,0.28125f, -0.695313f,0.28125f, -0.703125f,0.28125f, -0.710938f,0.28125f, -0.71875f,0.28125f, -0.726563f,0.28125f, -0.734375f,0.28125f, -0.742188f,0.28125f, -0.75f,0.28125f, -0.757813f,0.28125f, -0.765625f,0.28125f, -0.773438f,0.28125f, -0.78125f,0.28125f, -0.789063f,0.28125f, -0.796875f,0.28125f, -0.804688f,0.28125f, -0.8125f,0.28125f, -0.820313f,0.28125f, -0.828125f,0.28125f, -0.835938f,0.28125f, -0.84375f,0.28125f, -0.851563f,0.28125f, -0.859375f,0.28125f, -0.867188f,0.28125f, -0.875f,0.28125f, -0.882813f,0.28125f, -0.890625f,0.28125f, -0.898438f,0.28125f, -0.90625f,0.28125f, -0.914063f,0.28125f, -0.921875f,0.28125f, -0.929688f,0.28125f, -0.9375f,0.28125f, -0.945313f,0.28125f, -0.953125f,0.28125f, -0.960938f,0.28125f, -0.96875f,0.28125f, -0.976563f,0.28125f, -0.984375f,0.28125f, -0.992188f,0.28125f, -1.0f,0.28125f, -0.507813f,0.289063f, -0.515625f,0.289063f, -0.523438f,0.289063f, -0.53125f,0.289063f, -0.539063f,0.289063f, -0.546875f,0.289063f, -0.554688f,0.289063f, -0.5625f,0.289063f, -0.570313f,0.289063f, -0.578125f,0.289063f, -0.585938f,0.289063f, -0.59375f,0.289063f, -0.601563f,0.289063f, -0.609375f,0.289063f, -0.617188f,0.289063f, -0.625f,0.289063f, -0.632813f,0.289063f, -0.640625f,0.289063f, -0.648438f,0.289063f, -0.65625f,0.289063f, -0.664063f,0.289063f, -0.671875f,0.289063f, -0.679688f,0.289063f, -0.6875f,0.289063f, -0.695313f,0.289063f, -0.703125f,0.289063f, -0.710938f,0.289063f, -0.71875f,0.289063f, -0.726563f,0.289063f, -0.734375f,0.289063f, -0.742188f,0.289063f, -0.75f,0.289063f, -0.757813f,0.289063f, -0.765625f,0.289063f, -0.773438f,0.289063f, -0.78125f,0.289063f, -0.789063f,0.289063f, -0.796875f,0.289063f, -0.804688f,0.289063f, -0.8125f,0.289063f, -0.820313f,0.289063f, -0.828125f,0.289063f, -0.835938f,0.289063f, -0.84375f,0.289063f, -0.851563f,0.289063f, -0.859375f,0.289063f, -0.867188f,0.289063f, -0.875f,0.289063f, -0.882813f,0.289063f, -0.890625f,0.289063f, -0.898438f,0.289063f, -0.90625f,0.289063f, -0.914063f,0.289063f, -0.921875f,0.289063f, -0.929688f,0.289063f, -0.9375f,0.289063f, -0.945313f,0.289063f, -0.953125f,0.289063f, -0.960938f,0.289063f, -0.96875f,0.289063f, -0.976563f,0.289063f, -0.984375f,0.289063f, -0.992188f,0.289063f, -1.0f,0.289063f, -0.507813f,0.296875f, -0.515625f,0.296875f, -0.523438f,0.296875f, -0.53125f,0.296875f, -0.539063f,0.296875f, -0.546875f,0.296875f, -0.554688f,0.296875f, -0.5625f,0.296875f, -0.570313f,0.296875f, -0.578125f,0.296875f, -0.585938f,0.296875f, -0.59375f,0.296875f, -0.601563f,0.296875f, -0.609375f,0.296875f, -0.617188f,0.296875f, -0.625f,0.296875f, -0.632813f,0.296875f, -0.640625f,0.296875f, -0.648438f,0.296875f, -0.65625f,0.296875f, -0.664063f,0.296875f, -0.671875f,0.296875f, -0.679688f,0.296875f, -0.6875f,0.296875f, -0.695313f,0.296875f, -0.703125f,0.296875f, -0.710938f,0.296875f, -0.71875f,0.296875f, -0.726563f,0.296875f, -0.734375f,0.296875f, -0.742188f,0.296875f, -0.75f,0.296875f, -0.757813f,0.296875f, -0.765625f,0.296875f, -0.773438f,0.296875f, -0.78125f,0.296875f, -0.789063f,0.296875f, -0.796875f,0.296875f, -0.804688f,0.296875f, -0.8125f,0.296875f, -0.820313f,0.296875f, -0.828125f,0.296875f, -0.835938f,0.296875f, -0.84375f,0.296875f, -0.851563f,0.296875f, -0.859375f,0.296875f, -0.867188f,0.296875f, -0.875f,0.296875f, -0.882813f,0.296875f, -0.890625f,0.296875f, -0.898438f,0.296875f, -0.90625f,0.296875f, -0.914063f,0.296875f, -0.921875f,0.296875f, -0.929688f,0.296875f, -0.9375f,0.296875f, -0.945313f,0.296875f, -0.953125f,0.296875f, -0.960938f,0.296875f, -0.96875f,0.296875f, -0.976563f,0.296875f, -0.984375f,0.296875f, -0.992188f,0.296875f, -1.0f,0.296875f, -0.507813f,0.304688f, -0.515625f,0.304688f, -0.523438f,0.304688f, -0.53125f,0.304688f, -0.539063f,0.304688f, -0.546875f,0.304688f, -0.554688f,0.304688f, -0.5625f,0.304688f, -0.570313f,0.304688f, -0.578125f,0.304688f, -0.585938f,0.304688f, -0.59375f,0.304688f, -0.601563f,0.304688f, -0.609375f,0.304688f, -0.617188f,0.304688f, -0.625f,0.304688f, -0.632813f,0.304688f, -0.640625f,0.304688f, -0.648438f,0.304688f, -0.65625f,0.304688f, -0.664063f,0.304688f, -0.671875f,0.304688f, -0.679688f,0.304688f, -0.6875f,0.304688f, -0.695313f,0.304688f, -0.703125f,0.304688f, -0.710938f,0.304688f, -0.71875f,0.304688f, -0.726563f,0.304688f, -0.734375f,0.304688f, -0.742188f,0.304688f, -0.75f,0.304688f, -0.757813f,0.304688f, -0.765625f,0.304688f, -0.773438f,0.304688f, -0.78125f,0.304688f, -0.789063f,0.304688f, -0.796875f,0.304688f, -0.804688f,0.304688f, -0.8125f,0.304688f, -0.820313f,0.304688f, -0.828125f,0.304688f, -0.835938f,0.304688f, -0.84375f,0.304688f, -0.851563f,0.304688f, -0.859375f,0.304688f, -0.867188f,0.304688f, -0.875f,0.304688f, -0.882813f,0.304688f, -0.890625f,0.304688f, -0.898438f,0.304688f, -0.90625f,0.304688f, -0.914063f,0.304688f, -0.921875f,0.304688f, -0.929688f,0.304688f, -0.9375f,0.304688f, -0.945313f,0.304688f, -0.953125f,0.304688f, -0.960938f,0.304688f, -0.96875f,0.304688f, -0.976563f,0.304688f, -0.984375f,0.304688f, -0.992188f,0.304688f, -1.0f,0.304688f, -0.507813f,0.3125f, -0.515625f,0.3125f, -0.523438f,0.3125f, -0.53125f,0.3125f, -0.539063f,0.3125f, -0.546875f,0.3125f, -0.554688f,0.3125f, -0.5625f,0.3125f, -0.570313f,0.3125f, -0.578125f,0.3125f, -0.585938f,0.3125f, -0.59375f,0.3125f, -0.601563f,0.3125f, -0.609375f,0.3125f, -0.617188f,0.3125f, -0.625f,0.3125f, -0.632813f,0.3125f, -0.640625f,0.3125f, -0.648438f,0.3125f, -0.65625f,0.3125f, -0.664063f,0.3125f, -0.671875f,0.3125f, -0.679688f,0.3125f, -0.6875f,0.3125f, -0.695313f,0.3125f, -0.703125f,0.3125f, -0.710938f,0.3125f, -0.71875f,0.3125f, -0.726563f,0.3125f, -0.734375f,0.3125f, -0.742188f,0.3125f, -0.75f,0.3125f, -0.757813f,0.3125f, -0.765625f,0.3125f, -0.773438f,0.3125f, -0.78125f,0.3125f, -0.789063f,0.3125f, -0.796875f,0.3125f, -0.804688f,0.3125f, -0.8125f,0.3125f, -0.820313f,0.3125f, -0.828125f,0.3125f, -0.835938f,0.3125f, -0.84375f,0.3125f, -0.851563f,0.3125f, -0.859375f,0.3125f, -0.867188f,0.3125f, -0.875f,0.3125f, -0.882813f,0.3125f, -0.890625f,0.3125f, -0.898438f,0.3125f, -0.90625f,0.3125f, -0.914063f,0.3125f, -0.921875f,0.3125f, -0.929688f,0.3125f, -0.9375f,0.3125f, -0.945313f,0.3125f, -0.953125f,0.3125f, -0.960938f,0.3125f, -0.96875f,0.3125f, -0.976563f,0.3125f, -0.984375f,0.3125f, -0.992188f,0.3125f, -1.0f,0.3125f, -0.507813f,0.320313f, -0.515625f,0.320313f, -0.523438f,0.320313f, -0.53125f,0.320313f, -0.539063f,0.320313f, -0.546875f,0.320313f, -0.554688f,0.320313f, -0.5625f,0.320313f, -0.570313f,0.320313f, -0.578125f,0.320313f, -0.585938f,0.320313f, -0.59375f,0.320313f, -0.601563f,0.320313f, -0.609375f,0.320313f, -0.617188f,0.320313f, -0.625f,0.320313f, -0.632813f,0.320313f, -0.640625f,0.320313f, -0.648438f,0.320313f, -0.65625f,0.320313f, -0.664063f,0.320313f, -0.671875f,0.320313f, -0.679688f,0.320313f, -0.6875f,0.320313f, -0.695313f,0.320313f, -0.703125f,0.320313f, -0.710938f,0.320313f, -0.71875f,0.320313f, -0.726563f,0.320313f, -0.734375f,0.320313f, -0.742188f,0.320313f, -0.75f,0.320313f, -0.757813f,0.320313f, -0.765625f,0.320313f, -0.773438f,0.320313f, -0.78125f,0.320313f, -0.789063f,0.320313f, -0.796875f,0.320313f, -0.804688f,0.320313f, -0.8125f,0.320313f, -0.820313f,0.320313f, -0.828125f,0.320313f, -0.835938f,0.320313f, -0.84375f,0.320313f, -0.851563f,0.320313f, -0.859375f,0.320313f, -0.867188f,0.320313f, -0.875f,0.320313f, -0.882813f,0.320313f, -0.890625f,0.320313f, -0.898438f,0.320313f, -0.90625f,0.320313f, -0.914063f,0.320313f, -0.921875f,0.320313f, -0.929688f,0.320313f, -0.9375f,0.320313f, -0.945313f,0.320313f, -0.953125f,0.320313f, -0.960938f,0.320313f, -0.96875f,0.320313f, -0.976563f,0.320313f, -0.984375f,0.320313f, -0.992188f,0.320313f, -1.0f,0.320313f, -0.507813f,0.328125f, -0.515625f,0.328125f, -0.523438f,0.328125f, -0.53125f,0.328125f, -0.539063f,0.328125f, -0.546875f,0.328125f, -0.554688f,0.328125f, -0.5625f,0.328125f, -0.570313f,0.328125f, -0.578125f,0.328125f, -0.585938f,0.328125f, -0.59375f,0.328125f, -0.601563f,0.328125f, -0.609375f,0.328125f, -0.617188f,0.328125f, -0.625f,0.328125f, -0.632813f,0.328125f, -0.640625f,0.328125f, -0.648438f,0.328125f, -0.65625f,0.328125f, -0.664063f,0.328125f, -0.671875f,0.328125f, -0.679688f,0.328125f, -0.6875f,0.328125f, -0.695313f,0.328125f, -0.703125f,0.328125f, -0.710938f,0.328125f, -0.71875f,0.328125f, -0.726563f,0.328125f, -0.734375f,0.328125f, -0.742188f,0.328125f, -0.75f,0.328125f, -0.757813f,0.328125f, -0.765625f,0.328125f, -0.773438f,0.328125f, -0.78125f,0.328125f, -0.789063f,0.328125f, -0.796875f,0.328125f, -0.804688f,0.328125f, -0.8125f,0.328125f, -0.820313f,0.328125f, -0.828125f,0.328125f, -0.835938f,0.328125f, -0.84375f,0.328125f, -0.851563f,0.328125f, -0.859375f,0.328125f, -0.867188f,0.328125f, -0.875f,0.328125f, -0.882813f,0.328125f, -0.890625f,0.328125f, -0.898438f,0.328125f, -0.90625f,0.328125f, -0.914063f,0.328125f, -0.921875f,0.328125f, -0.929688f,0.328125f, -0.9375f,0.328125f, -0.945313f,0.328125f, -0.953125f,0.328125f, -0.960938f,0.328125f, -0.96875f,0.328125f, -0.976563f,0.328125f, -0.984375f,0.328125f, -0.992188f,0.328125f, -1.0f,0.328125f, -0.507813f,0.335938f, -0.515625f,0.335938f, -0.523438f,0.335938f, -0.53125f,0.335938f, -0.539063f,0.335938f, -0.546875f,0.335938f, -0.554688f,0.335938f, -0.5625f,0.335938f, -0.570313f,0.335938f, -0.578125f,0.335938f, -0.585938f,0.335938f, -0.59375f,0.335938f, -0.601563f,0.335938f, -0.609375f,0.335938f, -0.617188f,0.335938f, -0.625f,0.335938f, -0.632813f,0.335938f, -0.640625f,0.335938f, -0.648438f,0.335938f, -0.65625f,0.335938f, -0.664063f,0.335938f, -0.671875f,0.335938f, -0.679688f,0.335938f, -0.6875f,0.335938f, -0.695313f,0.335938f, -0.703125f,0.335938f, -0.710938f,0.335938f, -0.71875f,0.335938f, -0.726563f,0.335938f, -0.734375f,0.335938f, -0.742188f,0.335938f, -0.75f,0.335938f, -0.757813f,0.335938f, -0.765625f,0.335938f, -0.773438f,0.335938f, -0.78125f,0.335938f, -0.789063f,0.335938f, -0.796875f,0.335938f, -0.804688f,0.335938f, -0.8125f,0.335938f, -0.820313f,0.335938f, -0.828125f,0.335938f, -0.835938f,0.335938f, -0.84375f,0.335938f, -0.851563f,0.335938f, -0.859375f,0.335938f, -0.867188f,0.335938f, -0.875f,0.335938f, -0.882813f,0.335938f, -0.890625f,0.335938f, -0.898438f,0.335938f, -0.90625f,0.335938f, -0.914063f,0.335938f, -0.921875f,0.335938f, -0.929688f,0.335938f, -0.9375f,0.335938f, -0.945313f,0.335938f, -0.953125f,0.335938f, -0.960938f,0.335938f, -0.96875f,0.335938f, -0.976563f,0.335938f, -0.984375f,0.335938f, -0.992188f,0.335938f, -1.0f,0.335938f, -0.507813f,0.34375f, -0.515625f,0.34375f, -0.523438f,0.34375f, -0.53125f,0.34375f, -0.539063f,0.34375f, -0.546875f,0.34375f, -0.554688f,0.34375f, -0.5625f,0.34375f, -0.570313f,0.34375f, -0.578125f,0.34375f, -0.585938f,0.34375f, -0.59375f,0.34375f, -0.601563f,0.34375f, -0.609375f,0.34375f, -0.617188f,0.34375f, -0.625f,0.34375f, -0.632813f,0.34375f, -0.640625f,0.34375f, -0.648438f,0.34375f, -0.65625f,0.34375f, -0.664063f,0.34375f, -0.671875f,0.34375f, -0.679688f,0.34375f, -0.6875f,0.34375f, -0.695313f,0.34375f, -0.703125f,0.34375f, -0.710938f,0.34375f, -0.71875f,0.34375f, -0.726563f,0.34375f, -0.734375f,0.34375f, -0.742188f,0.34375f, -0.75f,0.34375f, -0.757813f,0.34375f, -0.765625f,0.34375f, -0.773438f,0.34375f, -0.78125f,0.34375f, -0.789063f,0.34375f, -0.796875f,0.34375f, -0.804688f,0.34375f, -0.8125f,0.34375f, -0.820313f,0.34375f, -0.828125f,0.34375f, -0.835938f,0.34375f, -0.84375f,0.34375f, -0.851563f,0.34375f, -0.859375f,0.34375f, -0.867188f,0.34375f, -0.875f,0.34375f, -0.882813f,0.34375f, -0.890625f,0.34375f, -0.898438f,0.34375f, -0.90625f,0.34375f, -0.914063f,0.34375f, -0.921875f,0.34375f, -0.929688f,0.34375f, -0.9375f,0.34375f, -0.945313f,0.34375f, -0.953125f,0.34375f, -0.960938f,0.34375f, -0.96875f,0.34375f, -0.976563f,0.34375f, -0.984375f,0.34375f, -0.992188f,0.34375f, -1.0f,0.34375f, -0.507813f,0.351563f, -0.515625f,0.351563f, -0.523438f,0.351563f, -0.53125f,0.351563f, -0.539063f,0.351563f, -0.546875f,0.351563f, -0.554688f,0.351563f, -0.5625f,0.351563f, -0.570313f,0.351563f, -0.578125f,0.351563f, -0.585938f,0.351563f, -0.59375f,0.351563f, -0.601563f,0.351563f, -0.609375f,0.351563f, -0.617188f,0.351563f, -0.625f,0.351563f, -0.632813f,0.351563f, -0.640625f,0.351563f, -0.648438f,0.351563f, -0.65625f,0.351563f, -0.664063f,0.351563f, -0.671875f,0.351563f, -0.679688f,0.351563f, -0.6875f,0.351563f, -0.695313f,0.351563f, -0.703125f,0.351563f, -0.710938f,0.351563f, -0.71875f,0.351563f, -0.726563f,0.351563f, -0.734375f,0.351563f, -0.742188f,0.351563f, -0.75f,0.351563f, -0.757813f,0.351563f, -0.765625f,0.351563f, -0.773438f,0.351563f, -0.78125f,0.351563f, -0.789063f,0.351563f, -0.796875f,0.351563f, -0.804688f,0.351563f, -0.8125f,0.351563f, -0.820313f,0.351563f, -0.828125f,0.351563f, -0.835938f,0.351563f, -0.84375f,0.351563f, -0.851563f,0.351563f, -0.859375f,0.351563f, -0.867188f,0.351563f, -0.875f,0.351563f, -0.882813f,0.351563f, -0.890625f,0.351563f, -0.898438f,0.351563f, -0.90625f,0.351563f, -0.914063f,0.351563f, -0.921875f,0.351563f, -0.929688f,0.351563f, -0.9375f,0.351563f, -0.945313f,0.351563f, -0.953125f,0.351563f, -0.960938f,0.351563f, -0.96875f,0.351563f, -0.976563f,0.351563f, -0.984375f,0.351563f, -0.992188f,0.351563f, -1.0f,0.351563f, -0.507813f,0.359375f, -0.515625f,0.359375f, -0.523438f,0.359375f, -0.53125f,0.359375f, -0.539063f,0.359375f, -0.546875f,0.359375f, -0.554688f,0.359375f, -0.5625f,0.359375f, -0.570313f,0.359375f, -0.578125f,0.359375f, -0.585938f,0.359375f, -0.59375f,0.359375f, -0.601563f,0.359375f, -0.609375f,0.359375f, -0.617188f,0.359375f, -0.625f,0.359375f, -0.632813f,0.359375f, -0.640625f,0.359375f, -0.648438f,0.359375f, -0.65625f,0.359375f, -0.664063f,0.359375f, -0.671875f,0.359375f, -0.679688f,0.359375f, -0.6875f,0.359375f, -0.695313f,0.359375f, -0.703125f,0.359375f, -0.710938f,0.359375f, -0.71875f,0.359375f, -0.726563f,0.359375f, -0.734375f,0.359375f, -0.742188f,0.359375f, -0.75f,0.359375f, -0.757813f,0.359375f, -0.765625f,0.359375f, -0.773438f,0.359375f, -0.78125f,0.359375f, -0.789063f,0.359375f, -0.796875f,0.359375f, -0.804688f,0.359375f, -0.8125f,0.359375f, -0.820313f,0.359375f, -0.828125f,0.359375f, -0.835938f,0.359375f, -0.84375f,0.359375f, -0.851563f,0.359375f, -0.859375f,0.359375f, -0.867188f,0.359375f, -0.875f,0.359375f, -0.882813f,0.359375f, -0.890625f,0.359375f, -0.898438f,0.359375f, -0.90625f,0.359375f, -0.914063f,0.359375f, -0.921875f,0.359375f, -0.929688f,0.359375f, -0.9375f,0.359375f, -0.945313f,0.359375f, -0.953125f,0.359375f, -0.960938f,0.359375f, -0.96875f,0.359375f, -0.976563f,0.359375f, -0.984375f,0.359375f, -0.992188f,0.359375f, -1.0f,0.359375f, -0.507813f,0.367188f, -0.515625f,0.367188f, -0.523438f,0.367188f, -0.53125f,0.367188f, -0.539063f,0.367188f, -0.546875f,0.367188f, -0.554688f,0.367188f, -0.5625f,0.367188f, -0.570313f,0.367188f, -0.578125f,0.367188f, -0.585938f,0.367188f, -0.59375f,0.367188f, -0.601563f,0.367188f, -0.609375f,0.367188f, -0.617188f,0.367188f, -0.625f,0.367188f, -0.632813f,0.367188f, -0.640625f,0.367188f, -0.648438f,0.367188f, -0.65625f,0.367188f, -0.664063f,0.367188f, -0.671875f,0.367188f, -0.679688f,0.367188f, -0.6875f,0.367188f, -0.695313f,0.367188f, -0.703125f,0.367188f, -0.710938f,0.367188f, -0.71875f,0.367188f, -0.726563f,0.367188f, -0.734375f,0.367188f, -0.742188f,0.367188f, -0.75f,0.367188f, -0.757813f,0.367188f, -0.765625f,0.367188f, -0.773438f,0.367188f, -0.78125f,0.367188f, -0.789063f,0.367188f, -0.796875f,0.367188f, -0.804688f,0.367188f, -0.8125f,0.367188f, -0.820313f,0.367188f, -0.828125f,0.367188f, -0.835938f,0.367188f, -0.84375f,0.367188f, -0.851563f,0.367188f, -0.859375f,0.367188f, -0.867188f,0.367188f, -0.875f,0.367188f, -0.882813f,0.367188f, -0.890625f,0.367188f, -0.898438f,0.367188f, -0.90625f,0.367188f, -0.914063f,0.367188f, -0.921875f,0.367188f, -0.929688f,0.367188f, -0.9375f,0.367188f, -0.945313f,0.367188f, -0.953125f,0.367188f, -0.960938f,0.367188f, -0.96875f,0.367188f, -0.976563f,0.367188f, -0.984375f,0.367188f, -0.992188f,0.367188f, -1.0f,0.367188f, -0.507813f,0.375f, -0.515625f,0.375f, -0.523438f,0.375f, -0.53125f,0.375f, -0.539063f,0.375f, -0.546875f,0.375f, -0.554688f,0.375f, -0.5625f,0.375f, -0.570313f,0.375f, -0.578125f,0.375f, -0.585938f,0.375f, -0.59375f,0.375f, -0.601563f,0.375f, -0.609375f,0.375f, -0.617188f,0.375f, -0.625f,0.375f, -0.632813f,0.375f, -0.640625f,0.375f, -0.648438f,0.375f, -0.65625f,0.375f, -0.664063f,0.375f, -0.671875f,0.375f, -0.679688f,0.375f, -0.6875f,0.375f, -0.695313f,0.375f, -0.703125f,0.375f, -0.710938f,0.375f, -0.71875f,0.375f, -0.726563f,0.375f, -0.734375f,0.375f, -0.742188f,0.375f, -0.75f,0.375f, -0.757813f,0.375f, -0.765625f,0.375f, -0.773438f,0.375f, -0.78125f,0.375f, -0.789063f,0.375f, -0.796875f,0.375f, -0.804688f,0.375f, -0.8125f,0.375f, -0.820313f,0.375f, -0.828125f,0.375f, -0.835938f,0.375f, -0.84375f,0.375f, -0.851563f,0.375f, -0.859375f,0.375f, -0.867188f,0.375f, -0.875f,0.375f, -0.882813f,0.375f, -0.890625f,0.375f, -0.898438f,0.375f, -0.90625f,0.375f, -0.914063f,0.375f, -0.921875f,0.375f, -0.929688f,0.375f, -0.9375f,0.375f, -0.945313f,0.375f, -0.953125f,0.375f, -0.960938f,0.375f, -0.96875f,0.375f, -0.976563f,0.375f, -0.984375f,0.375f, -0.992188f,0.375f, -1.0f,0.375f, -0.507813f,0.382813f, -0.515625f,0.382813f, -0.523438f,0.382813f, -0.53125f,0.382813f, -0.539063f,0.382813f, -0.546875f,0.382813f, -0.554688f,0.382813f, -0.5625f,0.382813f, -0.570313f,0.382813f, -0.578125f,0.382813f, -0.585938f,0.382813f, -0.59375f,0.382813f, -0.601563f,0.382813f, -0.609375f,0.382813f, -0.617188f,0.382813f, -0.625f,0.382813f, -0.632813f,0.382813f, -0.640625f,0.382813f, -0.648438f,0.382813f, -0.65625f,0.382813f, -0.664063f,0.382813f, -0.671875f,0.382813f, -0.679688f,0.382813f, -0.6875f,0.382813f, -0.695313f,0.382813f, -0.703125f,0.382813f, -0.710938f,0.382813f, -0.71875f,0.382813f, -0.726563f,0.382813f, -0.734375f,0.382813f, -0.742188f,0.382813f, -0.75f,0.382813f, -0.757813f,0.382813f, -0.765625f,0.382813f, -0.773438f,0.382813f, -0.78125f,0.382813f, -0.789063f,0.382813f, -0.796875f,0.382813f, -0.804688f,0.382813f, -0.8125f,0.382813f, -0.820313f,0.382813f, -0.828125f,0.382813f, -0.835938f,0.382813f, -0.84375f,0.382813f, -0.851563f,0.382813f, -0.859375f,0.382813f, -0.867188f,0.382813f, -0.875f,0.382813f, -0.882813f,0.382813f, -0.890625f,0.382813f, -0.898438f,0.382813f, -0.90625f,0.382813f, -0.914063f,0.382813f, -0.921875f,0.382813f, -0.929688f,0.382813f, -0.9375f,0.382813f, -0.945313f,0.382813f, -0.953125f,0.382813f, -0.960938f,0.382813f, -0.96875f,0.382813f, -0.976563f,0.382813f, -0.984375f,0.382813f, -0.992188f,0.382813f, -1.0f,0.382813f, -0.507813f,0.390625f, -0.515625f,0.390625f, -0.523438f,0.390625f, -0.53125f,0.390625f, -0.539063f,0.390625f, -0.546875f,0.390625f, -0.554688f,0.390625f, -0.5625f,0.390625f, -0.570313f,0.390625f, -0.578125f,0.390625f, -0.585938f,0.390625f, -0.59375f,0.390625f, -0.601563f,0.390625f, -0.609375f,0.390625f, -0.617188f,0.390625f, -0.625f,0.390625f, -0.632813f,0.390625f, -0.640625f,0.390625f, -0.648438f,0.390625f, -0.65625f,0.390625f, -0.664063f,0.390625f, -0.671875f,0.390625f, -0.679688f,0.390625f, -0.6875f,0.390625f, -0.695313f,0.390625f, -0.703125f,0.390625f, -0.710938f,0.390625f, -0.71875f,0.390625f, -0.726563f,0.390625f, -0.734375f,0.390625f, -0.742188f,0.390625f, -0.75f,0.390625f, -0.757813f,0.390625f, -0.765625f,0.390625f, -0.773438f,0.390625f, -0.78125f,0.390625f, -0.789063f,0.390625f, -0.796875f,0.390625f, -0.804688f,0.390625f, -0.8125f,0.390625f, -0.820313f,0.390625f, -0.828125f,0.390625f, -0.835938f,0.390625f, -0.84375f,0.390625f, -0.851563f,0.390625f, -0.859375f,0.390625f, -0.867188f,0.390625f, -0.875f,0.390625f, -0.882813f,0.390625f, -0.890625f,0.390625f, -0.898438f,0.390625f, -0.90625f,0.390625f, -0.914063f,0.390625f, -0.921875f,0.390625f, -0.929688f,0.390625f, -0.9375f,0.390625f, -0.945313f,0.390625f, -0.953125f,0.390625f, -0.960938f,0.390625f, -0.96875f,0.390625f, -0.976563f,0.390625f, -0.984375f,0.390625f, -0.992188f,0.390625f, -1.0f,0.390625f, -0.507813f,0.398438f, -0.515625f,0.398438f, -0.523438f,0.398438f, -0.53125f,0.398438f, -0.539063f,0.398438f, -0.546875f,0.398438f, -0.554688f,0.398438f, -0.5625f,0.398438f, -0.570313f,0.398438f, -0.578125f,0.398438f, -0.585938f,0.398438f, -0.59375f,0.398438f, -0.601563f,0.398438f, -0.609375f,0.398438f, -0.617188f,0.398438f, -0.625f,0.398438f, -0.632813f,0.398438f, -0.640625f,0.398438f, -0.648438f,0.398438f, -0.65625f,0.398438f, -0.664063f,0.398438f, -0.671875f,0.398438f, -0.679688f,0.398438f, -0.6875f,0.398438f, -0.695313f,0.398438f, -0.703125f,0.398438f, -0.710938f,0.398438f, -0.71875f,0.398438f, -0.726563f,0.398438f, -0.734375f,0.398438f, -0.742188f,0.398438f, -0.75f,0.398438f, -0.757813f,0.398438f, -0.765625f,0.398438f, -0.773438f,0.398438f, -0.78125f,0.398438f, -0.789063f,0.398438f, -0.796875f,0.398438f, -0.804688f,0.398438f, -0.8125f,0.398438f, -0.820313f,0.398438f, -0.828125f,0.398438f, -0.835938f,0.398438f, -0.84375f,0.398438f, -0.851563f,0.398438f, -0.859375f,0.398438f, -0.867188f,0.398438f, -0.875f,0.398438f, -0.882813f,0.398438f, -0.890625f,0.398438f, -0.898438f,0.398438f, -0.90625f,0.398438f, -0.914063f,0.398438f, -0.921875f,0.398438f, -0.929688f,0.398438f, -0.9375f,0.398438f, -0.945313f,0.398438f, -0.953125f,0.398438f, -0.960938f,0.398438f, -0.96875f,0.398438f, -0.976563f,0.398438f, -0.984375f,0.398438f, -0.992188f,0.398438f, -1.0f,0.398438f, -0.507813f,0.40625f, -0.515625f,0.40625f, -0.523438f,0.40625f, -0.53125f,0.40625f, -0.539063f,0.40625f, -0.546875f,0.40625f, -0.554688f,0.40625f, -0.5625f,0.40625f, -0.570313f,0.40625f, -0.578125f,0.40625f, -0.585938f,0.40625f, -0.59375f,0.40625f, -0.601563f,0.40625f, -0.609375f,0.40625f, -0.617188f,0.40625f, -0.625f,0.40625f, -0.632813f,0.40625f, -0.640625f,0.40625f, -0.648438f,0.40625f, -0.65625f,0.40625f, -0.664063f,0.40625f, -0.671875f,0.40625f, -0.679688f,0.40625f, -0.6875f,0.40625f, -0.695313f,0.40625f, -0.703125f,0.40625f, -0.710938f,0.40625f, -0.71875f,0.40625f, -0.726563f,0.40625f, -0.734375f,0.40625f, -0.742188f,0.40625f, -0.75f,0.40625f, -0.757813f,0.40625f, -0.765625f,0.40625f, -0.773438f,0.40625f, -0.78125f,0.40625f, -0.789063f,0.40625f, -0.796875f,0.40625f, -0.804688f,0.40625f, -0.8125f,0.40625f, -0.820313f,0.40625f, -0.828125f,0.40625f, -0.835938f,0.40625f, -0.84375f,0.40625f, -0.851563f,0.40625f, -0.859375f,0.40625f, -0.867188f,0.40625f, -0.875f,0.40625f, -0.882813f,0.40625f, -0.890625f,0.40625f, -0.898438f,0.40625f, -0.90625f,0.40625f, -0.914063f,0.40625f, -0.921875f,0.40625f, -0.929688f,0.40625f, -0.9375f,0.40625f, -0.945313f,0.40625f, -0.953125f,0.40625f, -0.960938f,0.40625f, -0.96875f,0.40625f, -0.976563f,0.40625f, -0.984375f,0.40625f, -0.992188f,0.40625f, -1.0f,0.40625f, -0.507813f,0.414063f, -0.515625f,0.414063f, -0.523438f,0.414063f, -0.53125f,0.414063f, -0.539063f,0.414063f, -0.546875f,0.414063f, -0.554688f,0.414063f, -0.5625f,0.414063f, -0.570313f,0.414063f, -0.578125f,0.414063f, -0.585938f,0.414063f, -0.59375f,0.414063f, -0.601563f,0.414063f, -0.609375f,0.414063f, -0.617188f,0.414063f, -0.625f,0.414063f, -0.632813f,0.414063f, -0.640625f,0.414063f, -0.648438f,0.414063f, -0.65625f,0.414063f, -0.664063f,0.414063f, -0.671875f,0.414063f, -0.679688f,0.414063f, -0.6875f,0.414063f, -0.695313f,0.414063f, -0.703125f,0.414063f, -0.710938f,0.414063f, -0.71875f,0.414063f, -0.726563f,0.414063f, -0.734375f,0.414063f, -0.742188f,0.414063f, -0.75f,0.414063f, -0.757813f,0.414063f, -0.765625f,0.414063f, -0.773438f,0.414063f, -0.78125f,0.414063f, -0.789063f,0.414063f, -0.796875f,0.414063f, -0.804688f,0.414063f, -0.8125f,0.414063f, -0.820313f,0.414063f, -0.828125f,0.414063f, -0.835938f,0.414063f, -0.84375f,0.414063f, -0.851563f,0.414063f, -0.859375f,0.414063f, -0.867188f,0.414063f, -0.875f,0.414063f, -0.882813f,0.414063f, -0.890625f,0.414063f, -0.898438f,0.414063f, -0.90625f,0.414063f, -0.914063f,0.414063f, -0.921875f,0.414063f, -0.929688f,0.414063f, -0.9375f,0.414063f, -0.945313f,0.414063f, -0.953125f,0.414063f, -0.960938f,0.414063f, -0.96875f,0.414063f, -0.976563f,0.414063f, -0.984375f,0.414063f, -0.992188f,0.414063f, -1.0f,0.414063f, -0.507813f,0.421875f, -0.515625f,0.421875f, -0.523438f,0.421875f, -0.53125f,0.421875f, -0.539063f,0.421875f, -0.546875f,0.421875f, -0.554688f,0.421875f, -0.5625f,0.421875f, -0.570313f,0.421875f, -0.578125f,0.421875f, -0.585938f,0.421875f, -0.59375f,0.421875f, -0.601563f,0.421875f, -0.609375f,0.421875f, -0.617188f,0.421875f, -0.625f,0.421875f, -0.632813f,0.421875f, -0.640625f,0.421875f, -0.648438f,0.421875f, -0.65625f,0.421875f, -0.664063f,0.421875f, -0.671875f,0.421875f, -0.679688f,0.421875f, -0.6875f,0.421875f, -0.695313f,0.421875f, -0.703125f,0.421875f, -0.710938f,0.421875f, -0.71875f,0.421875f, -0.726563f,0.421875f, -0.734375f,0.421875f, -0.742188f,0.421875f, -0.75f,0.421875f, -0.757813f,0.421875f, -0.765625f,0.421875f, -0.773438f,0.421875f, -0.78125f,0.421875f, -0.789063f,0.421875f, -0.796875f,0.421875f, -0.804688f,0.421875f, -0.8125f,0.421875f, -0.820313f,0.421875f, -0.828125f,0.421875f, -0.835938f,0.421875f, -0.84375f,0.421875f, -0.851563f,0.421875f, -0.859375f,0.421875f, -0.867188f,0.421875f, -0.875f,0.421875f, -0.882813f,0.421875f, -0.890625f,0.421875f, -0.898438f,0.421875f, -0.90625f,0.421875f, -0.914063f,0.421875f, -0.921875f,0.421875f, -0.929688f,0.421875f, -0.9375f,0.421875f, -0.945313f,0.421875f, -0.953125f,0.421875f, -0.960938f,0.421875f, -0.96875f,0.421875f, -0.976563f,0.421875f, -0.984375f,0.421875f, -0.992188f,0.421875f, -1.0f,0.421875f, -0.507813f,0.429688f, -0.515625f,0.429688f, -0.523438f,0.429688f, -0.53125f,0.429688f, -0.539063f,0.429688f, -0.546875f,0.429688f, -0.554688f,0.429688f, -0.5625f,0.429688f, -0.570313f,0.429688f, -0.578125f,0.429688f, -0.585938f,0.429688f, -0.59375f,0.429688f, -0.601563f,0.429688f, -0.609375f,0.429688f, -0.617188f,0.429688f, -0.625f,0.429688f, -0.632813f,0.429688f, -0.640625f,0.429688f, -0.648438f,0.429688f, -0.65625f,0.429688f, -0.664063f,0.429688f, -0.671875f,0.429688f, -0.679688f,0.429688f, -0.6875f,0.429688f, -0.695313f,0.429688f, -0.703125f,0.429688f, -0.710938f,0.429688f, -0.71875f,0.429688f, -0.726563f,0.429688f, -0.734375f,0.429688f, -0.742188f,0.429688f, -0.75f,0.429688f, -0.757813f,0.429688f, -0.765625f,0.429688f, -0.773438f,0.429688f, -0.78125f,0.429688f, -0.789063f,0.429688f, -0.796875f,0.429688f, -0.804688f,0.429688f, -0.8125f,0.429688f, -0.820313f,0.429688f, -0.828125f,0.429688f, -0.835938f,0.429688f, -0.84375f,0.429688f, -0.851563f,0.429688f, -0.859375f,0.429688f, -0.867188f,0.429688f, -0.875f,0.429688f, -0.882813f,0.429688f, -0.890625f,0.429688f, -0.898438f,0.429688f, -0.90625f,0.429688f, -0.914063f,0.429688f, -0.921875f,0.429688f, -0.929688f,0.429688f, -0.9375f,0.429688f, -0.945313f,0.429688f, -0.953125f,0.429688f, -0.960938f,0.429688f, -0.96875f,0.429688f, -0.976563f,0.429688f, -0.984375f,0.429688f, -0.992188f,0.429688f, -1.0f,0.429688f, -0.507813f,0.4375f, -0.515625f,0.4375f, -0.523438f,0.4375f, -0.53125f,0.4375f, -0.539063f,0.4375f, -0.546875f,0.4375f, -0.554688f,0.4375f, -0.5625f,0.4375f, -0.570313f,0.4375f, -0.578125f,0.4375f, -0.585938f,0.4375f, -0.59375f,0.4375f, -0.601563f,0.4375f, -0.609375f,0.4375f, -0.617188f,0.4375f, -0.625f,0.4375f, -0.632813f,0.4375f, -0.640625f,0.4375f, -0.648438f,0.4375f, -0.65625f,0.4375f, -0.664063f,0.4375f, -0.671875f,0.4375f, -0.679688f,0.4375f, -0.6875f,0.4375f, -0.695313f,0.4375f, -0.703125f,0.4375f, -0.710938f,0.4375f, -0.71875f,0.4375f, -0.726563f,0.4375f, -0.734375f,0.4375f, -0.742188f,0.4375f, -0.75f,0.4375f, -0.757813f,0.4375f, -0.765625f,0.4375f, -0.773438f,0.4375f, -0.78125f,0.4375f, -0.789063f,0.4375f, -0.796875f,0.4375f, -0.804688f,0.4375f, -0.8125f,0.4375f, -0.820313f,0.4375f, -0.828125f,0.4375f, -0.835938f,0.4375f, -0.84375f,0.4375f, -0.851563f,0.4375f, -0.859375f,0.4375f, -0.867188f,0.4375f, -0.875f,0.4375f, -0.882813f,0.4375f, -0.890625f,0.4375f, -0.898438f,0.4375f, -0.90625f,0.4375f, -0.914063f,0.4375f, -0.921875f,0.4375f, -0.929688f,0.4375f, -0.9375f,0.4375f, -0.945313f,0.4375f, -0.953125f,0.4375f, -0.960938f,0.4375f, -0.96875f,0.4375f, -0.976563f,0.4375f, -0.984375f,0.4375f, -0.992188f,0.4375f, -1.0f,0.4375f, -0.507813f,0.445313f, -0.515625f,0.445313f, -0.523438f,0.445313f, -0.53125f,0.445313f, -0.539063f,0.445313f, -0.546875f,0.445313f, -0.554688f,0.445313f, -0.5625f,0.445313f, -0.570313f,0.445313f, -0.578125f,0.445313f, -0.585938f,0.445313f, -0.59375f,0.445313f, -0.601563f,0.445313f, -0.609375f,0.445313f, -0.617188f,0.445313f, -0.625f,0.445313f, -0.632813f,0.445313f, -0.640625f,0.445313f, -0.648438f,0.445313f, -0.65625f,0.445313f, -0.664063f,0.445313f, -0.671875f,0.445313f, -0.679688f,0.445313f, -0.6875f,0.445313f, -0.695313f,0.445313f, -0.703125f,0.445313f, -0.710938f,0.445313f, -0.71875f,0.445313f, -0.726563f,0.445313f, -0.734375f,0.445313f, -0.742188f,0.445313f, -0.75f,0.445313f, -0.757813f,0.445313f, -0.765625f,0.445313f, -0.773438f,0.445313f, -0.78125f,0.445313f, -0.789063f,0.445313f, -0.796875f,0.445313f, -0.804688f,0.445313f, -0.8125f,0.445313f, -0.820313f,0.445313f, -0.828125f,0.445313f, -0.835938f,0.445313f, -0.84375f,0.445313f, -0.851563f,0.445313f, -0.859375f,0.445313f, -0.867188f,0.445313f, -0.875f,0.445313f, -0.882813f,0.445313f, -0.890625f,0.445313f, -0.898438f,0.445313f, -0.90625f,0.445313f, -0.914063f,0.445313f, -0.921875f,0.445313f, -0.929688f,0.445313f, -0.9375f,0.445313f, -0.945313f,0.445313f, -0.953125f,0.445313f, -0.960938f,0.445313f, -0.96875f,0.445313f, -0.976563f,0.445313f, -0.984375f,0.445313f, -0.992188f,0.445313f, -1.0f,0.445313f, -0.507813f,0.453125f, -0.515625f,0.453125f, -0.523438f,0.453125f, -0.53125f,0.453125f, -0.539063f,0.453125f, -0.546875f,0.453125f, -0.554688f,0.453125f, -0.5625f,0.453125f, -0.570313f,0.453125f, -0.578125f,0.453125f, -0.585938f,0.453125f, -0.59375f,0.453125f, -0.601563f,0.453125f, -0.609375f,0.453125f, -0.617188f,0.453125f, -0.625f,0.453125f, -0.632813f,0.453125f, -0.640625f,0.453125f, -0.648438f,0.453125f, -0.65625f,0.453125f, -0.664063f,0.453125f, -0.671875f,0.453125f, -0.679688f,0.453125f, -0.6875f,0.453125f, -0.695313f,0.453125f, -0.703125f,0.453125f, -0.710938f,0.453125f, -0.71875f,0.453125f, -0.726563f,0.453125f, -0.734375f,0.453125f, -0.742188f,0.453125f, -0.75f,0.453125f, -0.757813f,0.453125f, -0.765625f,0.453125f, -0.773438f,0.453125f, -0.78125f,0.453125f, -0.789063f,0.453125f, -0.796875f,0.453125f, -0.804688f,0.453125f, -0.8125f,0.453125f, -0.820313f,0.453125f, -0.828125f,0.453125f, -0.835938f,0.453125f, -0.84375f,0.453125f, -0.851563f,0.453125f, -0.859375f,0.453125f, -0.867188f,0.453125f, -0.875f,0.453125f, -0.882813f,0.453125f, -0.890625f,0.453125f, -0.898438f,0.453125f, -0.90625f,0.453125f, -0.914063f,0.453125f, -0.921875f,0.453125f, -0.929688f,0.453125f, -0.9375f,0.453125f, -0.945313f,0.453125f, -0.953125f,0.453125f, -0.960938f,0.453125f, -0.96875f,0.453125f, -0.976563f,0.453125f, -0.984375f,0.453125f, -0.992188f,0.453125f, -1.0f,0.453125f, -0.507813f,0.460938f, -0.515625f,0.460938f, -0.523438f,0.460938f, -0.53125f,0.460938f, -0.539063f,0.460938f, -0.546875f,0.460938f, -0.554688f,0.460938f, -0.5625f,0.460938f, -0.570313f,0.460938f, -0.578125f,0.460938f, -0.585938f,0.460938f, -0.59375f,0.460938f, -0.601563f,0.460938f, -0.609375f,0.460938f, -0.617188f,0.460938f, -0.625f,0.460938f, -0.632813f,0.460938f, -0.640625f,0.460938f, -0.648438f,0.460938f, -0.65625f,0.460938f, -0.664063f,0.460938f, -0.671875f,0.460938f, -0.679688f,0.460938f, -0.6875f,0.460938f, -0.695313f,0.460938f, -0.703125f,0.460938f, -0.710938f,0.460938f, -0.71875f,0.460938f, -0.726563f,0.460938f, -0.734375f,0.460938f, -0.742188f,0.460938f, -0.75f,0.460938f, -0.757813f,0.460938f, -0.765625f,0.460938f, -0.773438f,0.460938f, -0.78125f,0.460938f, -0.789063f,0.460938f, -0.796875f,0.460938f, -0.804688f,0.460938f, -0.8125f,0.460938f, -0.820313f,0.460938f, -0.828125f,0.460938f, -0.835938f,0.460938f, -0.84375f,0.460938f, -0.851563f,0.460938f, -0.859375f,0.460938f, -0.867188f,0.460938f, -0.875f,0.460938f, -0.882813f,0.460938f, -0.890625f,0.460938f, -0.898438f,0.460938f, -0.90625f,0.460938f, -0.914063f,0.460938f, -0.921875f,0.460938f, -0.929688f,0.460938f, -0.9375f,0.460938f, -0.945313f,0.460938f, -0.953125f,0.460938f, -0.960938f,0.460938f, -0.96875f,0.460938f, -0.976563f,0.460938f, -0.984375f,0.460938f, -0.992188f,0.460938f, -1.0f,0.460938f, -0.507813f,0.46875f, -0.515625f,0.46875f, -0.523438f,0.46875f, -0.53125f,0.46875f, -0.539063f,0.46875f, -0.546875f,0.46875f, -0.554688f,0.46875f, -0.5625f,0.46875f, -0.570313f,0.46875f, -0.578125f,0.46875f, -0.585938f,0.46875f, -0.59375f,0.46875f, -0.601563f,0.46875f, -0.609375f,0.46875f, -0.617188f,0.46875f, -0.625f,0.46875f, -0.632813f,0.46875f, -0.640625f,0.46875f, -0.648438f,0.46875f, -0.65625f,0.46875f, -0.664063f,0.46875f, -0.671875f,0.46875f, -0.679688f,0.46875f, -0.6875f,0.46875f, -0.695313f,0.46875f, -0.703125f,0.46875f, -0.710938f,0.46875f, -0.71875f,0.46875f, -0.726563f,0.46875f, -0.734375f,0.46875f, -0.742188f,0.46875f, -0.75f,0.46875f, -0.757813f,0.46875f, -0.765625f,0.46875f, -0.773438f,0.46875f, -0.78125f,0.46875f, -0.789063f,0.46875f, -0.796875f,0.46875f, -0.804688f,0.46875f, -0.8125f,0.46875f, -0.820313f,0.46875f, -0.828125f,0.46875f, -0.835938f,0.46875f, -0.84375f,0.46875f, -0.851563f,0.46875f, -0.859375f,0.46875f, -0.867188f,0.46875f, -0.875f,0.46875f, -0.882813f,0.46875f, -0.890625f,0.46875f, -0.898438f,0.46875f, -0.90625f,0.46875f, -0.914063f,0.46875f, -0.921875f,0.46875f, -0.929688f,0.46875f, -0.9375f,0.46875f, -0.945313f,0.46875f, -0.953125f,0.46875f, -0.960938f,0.46875f, -0.96875f,0.46875f, -0.976563f,0.46875f, -0.984375f,0.46875f, -0.992188f,0.46875f, -1.0f,0.46875f, -0.507813f,0.476563f, -0.515625f,0.476563f, -0.523438f,0.476563f, -0.53125f,0.476563f, -0.539063f,0.476563f, -0.546875f,0.476563f, -0.554688f,0.476563f, -0.5625f,0.476563f, -0.570313f,0.476563f, -0.578125f,0.476563f, -0.585938f,0.476563f, -0.59375f,0.476563f, -0.601563f,0.476563f, -0.609375f,0.476563f, -0.617188f,0.476563f, -0.625f,0.476563f, -0.632813f,0.476563f, -0.640625f,0.476563f, -0.648438f,0.476563f, -0.65625f,0.476563f, -0.664063f,0.476563f, -0.671875f,0.476563f, -0.679688f,0.476563f, -0.6875f,0.476563f, -0.695313f,0.476563f, -0.703125f,0.476563f, -0.710938f,0.476563f, -0.71875f,0.476563f, -0.726563f,0.476563f, -0.734375f,0.476563f, -0.742188f,0.476563f, -0.75f,0.476563f, -0.757813f,0.476563f, -0.765625f,0.476563f, -0.773438f,0.476563f, -0.78125f,0.476563f, -0.789063f,0.476563f, -0.796875f,0.476563f, -0.804688f,0.476563f, -0.8125f,0.476563f, -0.820313f,0.476563f, -0.828125f,0.476563f, -0.835938f,0.476563f, -0.84375f,0.476563f, -0.851563f,0.476563f, -0.859375f,0.476563f, -0.867188f,0.476563f, -0.875f,0.476563f, -0.882813f,0.476563f, -0.890625f,0.476563f, -0.898438f,0.476563f, -0.90625f,0.476563f, -0.914063f,0.476563f, -0.921875f,0.476563f, -0.929688f,0.476563f, -0.9375f,0.476563f, -0.945313f,0.476563f, -0.953125f,0.476563f, -0.960938f,0.476563f, -0.96875f,0.476563f, -0.976563f,0.476563f, -0.984375f,0.476563f, -0.992188f,0.476563f, -1.0f,0.476563f, -0.507813f,0.484375f, -0.515625f,0.484375f, -0.523438f,0.484375f, -0.53125f,0.484375f, -0.539063f,0.484375f, -0.546875f,0.484375f, -0.554688f,0.484375f, -0.5625f,0.484375f, -0.570313f,0.484375f, -0.578125f,0.484375f, -0.585938f,0.484375f, -0.59375f,0.484375f, -0.601563f,0.484375f, -0.609375f,0.484375f, -0.617188f,0.484375f, -0.625f,0.484375f, -0.632813f,0.484375f, -0.640625f,0.484375f, -0.648438f,0.484375f, -0.65625f,0.484375f, -0.664063f,0.484375f, -0.671875f,0.484375f, -0.679688f,0.484375f, -0.6875f,0.484375f, -0.695313f,0.484375f, -0.703125f,0.484375f, -0.710938f,0.484375f, -0.71875f,0.484375f, -0.726563f,0.484375f, -0.734375f,0.484375f, -0.742188f,0.484375f, -0.75f,0.484375f, -0.757813f,0.484375f, -0.765625f,0.484375f, -0.773438f,0.484375f, -0.78125f,0.484375f, -0.789063f,0.484375f, -0.796875f,0.484375f, -0.804688f,0.484375f, -0.8125f,0.484375f, -0.820313f,0.484375f, -0.828125f,0.484375f, -0.835938f,0.484375f, -0.84375f,0.484375f, -0.851563f,0.484375f, -0.859375f,0.484375f, -0.867188f,0.484375f, -0.875f,0.484375f, -0.882813f,0.484375f, -0.890625f,0.484375f, -0.898438f,0.484375f, -0.90625f,0.484375f, -0.914063f,0.484375f, -0.921875f,0.484375f, -0.929688f,0.484375f, -0.9375f,0.484375f, -0.945313f,0.484375f, -0.953125f,0.484375f, -0.960938f,0.484375f, -0.96875f,0.484375f, -0.976563f,0.484375f, -0.984375f,0.484375f, -0.992188f,0.484375f, -1.0f,0.484375f, -0.507813f,0.492188f, -0.515625f,0.492188f, -0.523438f,0.492188f, -0.53125f,0.492188f, -0.539063f,0.492188f, -0.546875f,0.492188f, -0.554688f,0.492188f, -0.5625f,0.492188f, -0.570313f,0.492188f, -0.578125f,0.492188f, -0.585938f,0.492188f, -0.59375f,0.492188f, -0.601563f,0.492188f, -0.609375f,0.492188f, -0.617188f,0.492188f, -0.625f,0.492188f, -0.632813f,0.492188f, -0.640625f,0.492188f, -0.648438f,0.492188f, -0.65625f,0.492188f, -0.664063f,0.492188f, -0.671875f,0.492188f, -0.679688f,0.492188f, -0.6875f,0.492188f, -0.695313f,0.492188f, -0.703125f,0.492188f, -0.710938f,0.492188f, -0.71875f,0.492188f, -0.726563f,0.492188f, -0.734375f,0.492188f, -0.742188f,0.492188f, -0.75f,0.492188f, -0.757813f,0.492188f, -0.765625f,0.492188f, -0.773438f,0.492188f, -0.78125f,0.492188f, -0.789063f,0.492188f, -0.796875f,0.492188f, -0.804688f,0.492188f, -0.8125f,0.492188f, -0.820313f,0.492188f, -0.828125f,0.492188f, -0.835938f,0.492188f, -0.84375f,0.492188f, -0.851563f,0.492188f, -0.859375f,0.492188f, -0.867188f,0.492188f, -0.875f,0.492188f, -0.882813f,0.492188f, -0.890625f,0.492188f, -0.898438f,0.492188f, -0.90625f,0.492188f, -0.914063f,0.492188f, -0.921875f,0.492188f, -0.929688f,0.492188f, -0.9375f,0.492188f, -0.945313f,0.492188f, -0.953125f,0.492188f, -0.960938f,0.492188f, -0.96875f,0.492188f, -0.976563f,0.492188f, -0.984375f,0.492188f, -0.992188f,0.492188f, -1.0f,0.492188f, -}; - -unsigned short Landscape04Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -128,0,129, -2,129,0, -129,2,130, -4,130,2, -130,4,131, -6,131,4, -131,6,132, -8,132,6, -132,8,133, -10,133,8, -133,10,134, -12,134,10, -134,12,135, -14,135,12, -135,14,136, -16,136,14, -136,16,137, -18,137,16, -137,18,138, -20,138,18, -138,20,139, -22,139,20, -139,22,140, -24,140,22, -140,24,141, -26,141,24, -141,26,142, -28,142,26, -142,28,143, -30,143,28, -143,30,144, -32,144,30, -144,32,145, -34,145,32, -145,34,146, -36,146,34, -146,36,147, -38,147,36, -147,38,148, -40,148,38, -148,40,149, -42,149,40, -149,42,150, -44,150,42, -150,44,151, -46,151,44, -151,46,152, -48,152,46, -152,48,153, -50,153,48, -153,50,154, -52,154,50, -154,52,155, -54,155,52, -155,54,156, -56,156,54, -156,56,157, -58,157,56, -157,58,158, -60,158,58, -158,60,159, -62,159,60, -159,62,160, -64,160,62, -160,64,161, -66,161,64, -161,66,162, -68,162,66, -162,68,163, -70,163,68, -163,70,164, -72,164,70, -164,72,165, -74,165,72, -165,74,166, -76,166,74, -166,76,167, -78,167,76, -167,78,168, -80,168,78, -168,80,169, -82,169,80, -169,82,170, -84,170,82, -170,84,171, -86,171,84, -171,86,172, -88,172,86, -172,88,173, -90,173,88, -173,90,174, -92,174,90, -174,92,175, -94,175,92, -175,94,176, -96,176,94, -176,96,177, -98,177,96, -177,98,178, -100,178,98, -178,100,179, -102,179,100, -179,102,180, -104,180,102, -180,104,181, -106,181,104, -181,106,182, -108,182,106, -182,108,183, -110,183,108, -183,110,184, -112,184,110, -184,112,185, -114,185,112, -185,114,186, -116,186,114, -186,116,187, -118,187,116, -187,118,188, -120,188,118, -188,120,189, -122,189,120, -189,122,190, -124,190,122, -190,124,191, -126,191,124, -192,128,193, -129,193,128, -193,129,194, -130,194,129, -194,130,195, -131,195,130, -195,131,196, -132,196,131, -196,132,197, -133,197,132, -197,133,198, -134,198,133, -198,134,199, -135,199,134, -199,135,200, -136,200,135, -200,136,201, -137,201,136, -201,137,202, -138,202,137, -202,138,203, -139,203,138, -203,139,204, -140,204,139, -204,140,205, -141,205,140, -205,141,206, -142,206,141, -206,142,207, -143,207,142, -207,143,208, -144,208,143, -208,144,209, -145,209,144, -209,145,210, -146,210,145, -210,146,211, -147,211,146, -211,147,212, -148,212,147, -212,148,213, -149,213,148, -213,149,214, -150,214,149, -214,150,215, -151,215,150, -215,151,216, -152,216,151, -216,152,217, -153,217,152, -217,153,218, -154,218,153, -218,154,219, -155,219,154, -219,155,220, -156,220,155, -220,156,221, -157,221,156, -221,157,222, -158,222,157, -222,158,223, -159,223,158, -223,159,224, -160,224,159, -224,160,225, -161,225,160, -225,161,226, -162,226,161, -226,162,227, -163,227,162, -227,163,228, -164,228,163, -228,164,229, -165,229,164, -229,165,230, -166,230,165, -230,166,231, -167,231,166, -231,167,232, -168,232,167, -232,168,233, -169,233,168, -233,169,234, -170,234,169, -234,170,235, -171,235,170, -235,171,236, -172,236,171, -236,172,237, -173,237,172, -237,173,238, -174,238,173, -238,174,239, -175,239,174, -239,175,240, -176,240,175, -240,176,241, -177,241,176, -241,177,242, -178,242,177, -242,178,243, -179,243,178, -243,179,244, -180,244,179, -244,180,245, -181,245,180, -245,181,246, -182,246,181, -246,182,247, -183,247,182, -247,183,248, -184,248,183, -248,184,249, -185,249,184, -249,185,250, -186,250,185, -250,186,251, -187,251,186, -251,187,252, -188,252,187, -252,188,253, -189,253,188, -253,189,254, -190,254,189, -254,190,255, -191,255,190, -256,192,257, -193,257,192, -257,193,258, -194,258,193, -258,194,259, -195,259,194, -259,195,260, -196,260,195, -260,196,261, -197,261,196, -261,197,262, -198,262,197, -262,198,263, -199,263,198, -263,199,264, -200,264,199, -264,200,265, -201,265,200, -265,201,266, -202,266,201, -266,202,267, -203,267,202, -267,203,268, -204,268,203, -268,204,269, -205,269,204, -269,205,270, -206,270,205, -270,206,271, -207,271,206, -271,207,272, -208,272,207, -272,208,273, -209,273,208, -273,209,274, -210,274,209, -274,210,275, -211,275,210, -275,211,276, -212,276,211, -276,212,277, -213,277,212, -277,213,278, -214,278,213, -278,214,279, -215,279,214, -279,215,280, -216,280,215, -280,216,281, -217,281,216, -281,217,282, -218,282,217, -282,218,283, -219,283,218, -283,219,284, -220,284,219, -284,220,285, -221,285,220, -285,221,286, -222,286,221, -286,222,287, -223,287,222, -287,223,288, -224,288,223, -288,224,289, -225,289,224, -289,225,290, -226,290,225, -290,226,291, -227,291,226, -291,227,292, -228,292,227, -292,228,293, -229,293,228, -293,229,294, -230,294,229, -294,230,295, -231,295,230, -295,231,296, -232,296,231, -296,232,297, -233,297,232, -297,233,298, -234,298,233, -298,234,299, -235,299,234, -299,235,300, -236,300,235, -300,236,301, -237,301,236, -301,237,302, -238,302,237, -302,238,303, -239,303,238, -303,239,304, -240,304,239, -304,240,305, -241,305,240, -305,241,306, -242,306,241, -306,242,307, -243,307,242, -307,243,308, -244,308,243, -308,244,309, -245,309,244, -309,245,310, -246,310,245, -310,246,311, -247,311,246, -311,247,312, -248,312,247, -312,248,313, -249,313,248, -313,249,314, -250,314,249, -314,250,315, -251,315,250, -315,251,316, -252,316,251, -316,252,317, -253,317,252, -317,253,318, -254,318,253, -318,254,319, -255,319,254, -320,256,321, -257,321,256, -321,257,322, -258,322,257, -322,258,323, -259,323,258, -323,259,324, -260,324,259, -324,260,325, -261,325,260, -325,261,326, -262,326,261, -326,262,327, -263,327,262, -327,263,328, -264,328,263, -328,264,329, -265,329,264, -329,265,330, -266,330,265, -330,266,331, -267,331,266, -331,267,332, -268,332,267, -332,268,333, -269,333,268, -333,269,334, -270,334,269, -334,270,335, -271,335,270, -335,271,336, -272,336,271, -336,272,337, -273,337,272, -337,273,338, -274,338,273, -338,274,339, -275,339,274, -339,275,340, -276,340,275, -340,276,341, -277,341,276, -341,277,342, -278,342,277, -342,278,343, -279,343,278, -343,279,344, -280,344,279, -344,280,345, -281,345,280, -345,281,346, -282,346,281, -346,282,347, -283,347,282, -347,283,348, -284,348,283, -348,284,349, -285,349,284, -349,285,350, -286,350,285, -350,286,351, -287,351,286, -351,287,352, -288,352,287, -352,288,353, -289,353,288, -353,289,354, -290,354,289, -354,290,355, -291,355,290, -355,291,356, -292,356,291, -356,292,357, -293,357,292, -357,293,358, -294,358,293, -358,294,359, -295,359,294, -359,295,360, -296,360,295, -360,296,361, -297,361,296, -361,297,362, -298,362,297, -362,298,363, -299,363,298, -363,299,364, -300,364,299, -364,300,365, -301,365,300, -365,301,366, -302,366,301, -366,302,367, -303,367,302, -367,303,368, -304,368,303, -368,304,369, -305,369,304, -369,305,370, -306,370,305, -370,306,371, -307,371,306, -371,307,372, -308,372,307, -372,308,373, -309,373,308, -373,309,374, -310,374,309, -374,310,375, -311,375,310, -375,311,376, -312,376,311, -376,312,377, -313,377,312, -377,313,378, -314,378,313, -378,314,379, -315,379,314, -379,315,380, -316,380,315, -380,316,381, -317,381,316, -381,317,382, -318,382,317, -382,318,383, -319,383,318, -384,320,385, -321,385,320, -385,321,386, -322,386,321, -386,322,387, -323,387,322, -387,323,388, -324,388,323, -388,324,389, -325,389,324, -389,325,390, -326,390,325, -390,326,391, -327,391,326, -391,327,392, -328,392,327, -392,328,393, -329,393,328, -393,329,394, -330,394,329, -394,330,395, -331,395,330, -395,331,396, -332,396,331, -396,332,397, -333,397,332, -397,333,398, -334,398,333, -398,334,399, -335,399,334, -399,335,400, -336,400,335, -400,336,401, -337,401,336, -401,337,402, -338,402,337, -402,338,403, -339,403,338, -403,339,404, -340,404,339, -404,340,405, -341,405,340, -405,341,406, -342,406,341, -406,342,407, -343,407,342, -407,343,408, -344,408,343, -408,344,409, -345,409,344, -409,345,410, -346,410,345, -410,346,411, -347,411,346, -411,347,412, -348,412,347, -412,348,413, -349,413,348, -413,349,414, -350,414,349, -414,350,415, -351,415,350, -415,351,416, -352,416,351, -416,352,417, -353,417,352, -417,353,418, -354,418,353, -418,354,419, -355,419,354, -419,355,420, -356,420,355, -420,356,421, -357,421,356, -421,357,422, -358,422,357, -422,358,423, -359,423,358, -423,359,424, -360,424,359, -424,360,425, -361,425,360, -425,361,426, -362,426,361, -426,362,427, -363,427,362, -427,363,428, -364,428,363, -428,364,429, -365,429,364, -429,365,430, -366,430,365, -430,366,431, -367,431,366, -431,367,432, -368,432,367, -432,368,433, -369,433,368, -433,369,434, -370,434,369, -434,370,435, -371,435,370, -435,371,436, -372,436,371, -436,372,437, -373,437,372, -437,373,438, -374,438,373, -438,374,439, -375,439,374, -439,375,440, -376,440,375, -440,376,441, -377,441,376, -441,377,442, -378,442,377, -442,378,443, -379,443,378, -443,379,444, -380,444,379, -444,380,445, -381,445,380, -445,381,446, -382,446,381, -446,382,447, -383,447,382, -448,384,449, -385,449,384, -449,385,450, -386,450,385, -450,386,451, -387,451,386, -451,387,452, -388,452,387, -452,388,453, -389,453,388, -453,389,454, -390,454,389, -454,390,455, -391,455,390, -455,391,456, -392,456,391, -456,392,457, -393,457,392, -457,393,458, -394,458,393, -458,394,459, -395,459,394, -459,395,460, -396,460,395, -460,396,461, -397,461,396, -461,397,462, -398,462,397, -462,398,463, -399,463,398, -463,399,464, -400,464,399, -464,400,465, -401,465,400, -465,401,466, -402,466,401, -466,402,467, -403,467,402, -467,403,468, -404,468,403, -468,404,469, -405,469,404, -469,405,470, -406,470,405, -470,406,471, -407,471,406, -471,407,472, -408,472,407, -472,408,473, -409,473,408, -473,409,474, -410,474,409, -474,410,475, -411,475,410, -475,411,476, -412,476,411, -476,412,477, -413,477,412, -477,413,478, -414,478,413, -478,414,479, -415,479,414, -479,415,480, -416,480,415, -480,416,481, -417,481,416, -481,417,482, -418,482,417, -482,418,483, -419,483,418, -483,419,484, -420,484,419, -484,420,485, -421,485,420, -485,421,486, -422,486,421, -486,422,487, -423,487,422, -487,423,488, -424,488,423, -488,424,489, -425,489,424, -489,425,490, -426,490,425, -490,426,491, -427,491,426, -491,427,492, -428,492,427, -492,428,493, -429,493,428, -493,429,494, -430,494,429, -494,430,495, -431,495,430, -495,431,496, -432,496,431, -496,432,497, -433,497,432, -497,433,498, -434,498,433, -498,434,499, -435,499,434, -499,435,500, -436,500,435, -500,436,501, -437,501,436, -501,437,502, -438,502,437, -502,438,503, -439,503,438, -503,439,504, -440,504,439, -504,440,505, -441,505,440, -505,441,506, -442,506,441, -506,442,507, -443,507,442, -507,443,508, -444,508,443, -508,444,509, -445,509,444, -509,445,510, -446,510,445, -510,446,511, -447,511,446, -512,448,513, -449,513,448, -513,449,514, -450,514,449, -514,450,515, -451,515,450, -515,451,516, -452,516,451, -516,452,517, -453,517,452, -517,453,518, -454,518,453, -518,454,519, -455,519,454, -519,455,520, -456,520,455, -520,456,521, -457,521,456, -521,457,522, -458,522,457, -522,458,523, -459,523,458, -523,459,524, -460,524,459, -524,460,525, -461,525,460, -525,461,526, -462,526,461, -526,462,527, -463,527,462, -527,463,528, -464,528,463, -528,464,529, -465,529,464, -529,465,530, -466,530,465, -530,466,531, -467,531,466, -531,467,532, -468,532,467, -532,468,533, -469,533,468, -533,469,534, -470,534,469, -534,470,535, -471,535,470, -535,471,536, -472,536,471, -536,472,537, -473,537,472, -537,473,538, -474,538,473, -538,474,539, -475,539,474, -539,475,540, -476,540,475, -540,476,541, -477,541,476, -541,477,542, -478,542,477, -542,478,543, -479,543,478, -543,479,544, -480,544,479, -544,480,545, -481,545,480, -545,481,546, -482,546,481, -546,482,547, -483,547,482, -547,483,548, -484,548,483, -548,484,549, -485,549,484, -549,485,550, -486,550,485, -550,486,551, -487,551,486, -551,487,552, -488,552,487, -552,488,553, -489,553,488, -553,489,554, -490,554,489, -554,490,555, -491,555,490, -555,491,556, -492,556,491, -556,492,557, -493,557,492, -557,493,558, -494,558,493, -558,494,559, -495,559,494, -559,495,560, -496,560,495, -560,496,561, -497,561,496, -561,497,562, -498,562,497, -562,498,563, -499,563,498, -563,499,564, -500,564,499, -564,500,565, -501,565,500, -565,501,566, -502,566,501, -566,502,567, -503,567,502, -567,503,568, -504,568,503, -568,504,569, -505,569,504, -569,505,570, -506,570,505, -570,506,571, -507,571,506, -571,507,572, -508,572,507, -572,508,573, -509,573,508, -573,509,574, -510,574,509, -574,510,575, -511,575,510, -576,512,577, -513,577,512, -577,513,578, -514,578,513, -578,514,579, -515,579,514, -579,515,580, -516,580,515, -580,516,581, -517,581,516, -581,517,582, -518,582,517, -582,518,583, -519,583,518, -583,519,584, -520,584,519, -584,520,585, -521,585,520, -585,521,586, -522,586,521, -586,522,587, -523,587,522, -587,523,588, -524,588,523, -588,524,589, -525,589,524, -589,525,590, -526,590,525, -590,526,591, -527,591,526, -591,527,592, -528,592,527, -592,528,593, -529,593,528, -593,529,594, -530,594,529, -594,530,595, -531,595,530, -595,531,596, -532,596,531, -596,532,597, -533,597,532, -597,533,598, -534,598,533, -598,534,599, -535,599,534, -599,535,600, -536,600,535, -600,536,601, -537,601,536, -601,537,602, -538,602,537, -602,538,603, -539,603,538, -603,539,604, -540,604,539, -604,540,605, -541,605,540, -605,541,606, -542,606,541, -606,542,607, -543,607,542, -607,543,608, -544,608,543, -608,544,609, -545,609,544, -609,545,610, -546,610,545, -610,546,611, -547,611,546, -611,547,612, -548,612,547, -612,548,613, -549,613,548, -613,549,614, -550,614,549, -614,550,615, -551,615,550, -615,551,616, -552,616,551, -616,552,617, -553,617,552, -617,553,618, -554,618,553, -618,554,619, -555,619,554, -619,555,620, -556,620,555, -620,556,621, -557,621,556, -621,557,622, -558,622,557, -622,558,623, -559,623,558, -623,559,624, -560,624,559, -624,560,625, -561,625,560, -625,561,626, -562,626,561, -626,562,627, -563,627,562, -627,563,628, -564,628,563, -628,564,629, -565,629,564, -629,565,630, -566,630,565, -630,566,631, -567,631,566, -631,567,632, -568,632,567, -632,568,633, -569,633,568, -633,569,634, -570,634,569, -634,570,635, -571,635,570, -635,571,636, -572,636,571, -636,572,637, -573,637,572, -637,573,638, -574,638,573, -638,574,639, -575,639,574, -640,576,641, -577,641,576, -641,577,642, -578,642,577, -642,578,643, -579,643,578, -643,579,644, -580,644,579, -644,580,645, -581,645,580, -645,581,646, -582,646,581, -646,582,647, -583,647,582, -647,583,648, -584,648,583, -648,584,649, -585,649,584, -649,585,650, -586,650,585, -650,586,651, -587,651,586, -651,587,652, -588,652,587, -652,588,653, -589,653,588, -653,589,654, -590,654,589, -654,590,655, -591,655,590, -655,591,656, -592,656,591, -656,592,657, -593,657,592, -657,593,658, -594,658,593, -658,594,659, -595,659,594, -659,595,660, -596,660,595, -660,596,661, -597,661,596, -661,597,662, -598,662,597, -662,598,663, -599,663,598, -663,599,664, -600,664,599, -664,600,665, -601,665,600, -665,601,666, -602,666,601, -666,602,667, -603,667,602, -667,603,668, -604,668,603, -668,604,669, -605,669,604, -669,605,670, -606,670,605, -670,606,671, -607,671,606, -671,607,672, -608,672,607, -672,608,673, -609,673,608, -673,609,674, -610,674,609, -674,610,675, -611,675,610, -675,611,676, -612,676,611, -676,612,677, -613,677,612, -677,613,678, -614,678,613, -678,614,679, -615,679,614, -679,615,680, -616,680,615, -680,616,681, -617,681,616, -681,617,682, -618,682,617, -682,618,683, -619,683,618, -683,619,684, -620,684,619, -684,620,685, -621,685,620, -685,621,686, -622,686,621, -686,622,687, -623,687,622, -687,623,688, -624,688,623, -688,624,689, -625,689,624, -689,625,690, -626,690,625, -690,626,691, -627,691,626, -691,627,692, -628,692,627, -692,628,693, -629,693,628, -693,629,694, -630,694,629, -694,630,695, -631,695,630, -695,631,696, -632,696,631, -696,632,697, -633,697,632, -697,633,698, -634,698,633, -698,634,699, -635,699,634, -699,635,700, -636,700,635, -700,636,701, -637,701,636, -701,637,702, -638,702,637, -702,638,703, -639,703,638, -704,640,705, -641,705,640, -705,641,706, -642,706,641, -706,642,707, -643,707,642, -707,643,708, -644,708,643, -708,644,709, -645,709,644, -709,645,710, -646,710,645, -710,646,711, -647,711,646, -711,647,712, -648,712,647, -712,648,713, -649,713,648, -713,649,714, -650,714,649, -714,650,715, -651,715,650, -715,651,716, -652,716,651, -716,652,717, -653,717,652, -717,653,718, -654,718,653, -718,654,719, -655,719,654, -719,655,720, -656,720,655, -720,656,721, -657,721,656, -721,657,722, -658,722,657, -722,658,723, -659,723,658, -723,659,724, -660,724,659, -724,660,725, -661,725,660, -725,661,726, -662,726,661, -726,662,727, -663,727,662, -727,663,728, -664,728,663, -728,664,729, -665,729,664, -729,665,730, -666,730,665, -730,666,731, -667,731,666, -731,667,732, -668,732,667, -732,668,733, -669,733,668, -733,669,734, -670,734,669, -734,670,735, -671,735,670, -735,671,736, -672,736,671, -736,672,737, -673,737,672, -737,673,738, -674,738,673, -738,674,739, -675,739,674, -739,675,740, -676,740,675, -740,676,741, -677,741,676, -741,677,742, -678,742,677, -742,678,743, -679,743,678, -743,679,744, -680,744,679, -744,680,745, -681,745,680, -745,681,746, -682,746,681, -746,682,747, -683,747,682, -747,683,748, -684,748,683, -748,684,749, -685,749,684, -749,685,750, -686,750,685, -750,686,751, -687,751,686, -751,687,752, -688,752,687, -752,688,753, -689,753,688, -753,689,754, -690,754,689, -754,690,755, -691,755,690, -755,691,756, -692,756,691, -756,692,757, -693,757,692, -757,693,758, -694,758,693, -758,694,759, -695,759,694, -759,695,760, -696,760,695, -760,696,761, -697,761,696, -761,697,762, -698,762,697, -762,698,763, -699,763,698, -763,699,764, -700,764,699, -764,700,765, -701,765,700, -765,701,766, -702,766,701, -766,702,767, -703,767,702, -768,704,769, -705,769,704, -769,705,770, -706,770,705, -770,706,771, -707,771,706, -771,707,772, -708,772,707, -772,708,773, -709,773,708, -773,709,774, -710,774,709, -774,710,775, -711,775,710, -775,711,776, -712,776,711, -776,712,777, -713,777,712, -777,713,778, -714,778,713, -778,714,779, -715,779,714, -779,715,780, -716,780,715, -780,716,781, -717,781,716, -781,717,782, -718,782,717, -782,718,783, -719,783,718, -783,719,784, -720,784,719, -784,720,785, -721,785,720, -785,721,786, -722,786,721, -786,722,787, -723,787,722, -787,723,788, -724,788,723, -788,724,789, -725,789,724, -789,725,790, -726,790,725, -790,726,791, -727,791,726, -791,727,792, -728,792,727, -792,728,793, -729,793,728, -793,729,794, -730,794,729, -794,730,795, -731,795,730, -795,731,796, -732,796,731, -796,732,797, -733,797,732, -797,733,798, -734,798,733, -798,734,799, -735,799,734, -799,735,800, -736,800,735, -800,736,801, -737,801,736, -801,737,802, -738,802,737, -802,738,803, -739,803,738, -803,739,804, -740,804,739, -804,740,805, -741,805,740, -805,741,806, -742,806,741, -806,742,807, -743,807,742, -807,743,808, -744,808,743, -808,744,809, -745,809,744, -809,745,810, -746,810,745, -810,746,811, -747,811,746, -811,747,812, -748,812,747, -812,748,813, -749,813,748, -813,749,814, -750,814,749, -814,750,815, -751,815,750, -815,751,816, -752,816,751, -816,752,817, -753,817,752, -817,753,818, -754,818,753, -818,754,819, -755,819,754, -819,755,820, -756,820,755, -820,756,821, -757,821,756, -821,757,822, -758,822,757, -822,758,823, -759,823,758, -823,759,824, -760,824,759, -824,760,825, -761,825,760, -825,761,826, -762,826,761, -826,762,827, -763,827,762, -827,763,828, -764,828,763, -828,764,829, -765,829,764, -829,765,830, -766,830,765, -830,766,831, -767,831,766, -832,768,833, -769,833,768, -833,769,834, -770,834,769, -834,770,835, -771,835,770, -835,771,836, -772,836,771, -836,772,837, -773,837,772, -837,773,838, -774,838,773, -838,774,839, -775,839,774, -839,775,840, -776,840,775, -840,776,841, -777,841,776, -841,777,842, -778,842,777, -842,778,843, -779,843,778, -843,779,844, -780,844,779, -844,780,845, -781,845,780, -845,781,846, -782,846,781, -846,782,847, -783,847,782, -847,783,848, -784,848,783, -848,784,849, -785,849,784, -849,785,850, -786,850,785, -850,786,851, -787,851,786, -851,787,852, -788,852,787, -852,788,853, -789,853,788, -853,789,854, -790,854,789, -854,790,855, -791,855,790, -855,791,856, -792,856,791, -856,792,857, -793,857,792, -857,793,858, -794,858,793, -858,794,859, -795,859,794, -859,795,860, -796,860,795, -860,796,861, -797,861,796, -861,797,862, -798,862,797, -862,798,863, -799,863,798, -863,799,864, -800,864,799, -864,800,865, -801,865,800, -865,801,866, -802,866,801, -866,802,867, -803,867,802, -867,803,868, -804,868,803, -868,804,869, -805,869,804, -869,805,870, -806,870,805, -870,806,871, -807,871,806, -871,807,872, -808,872,807, -872,808,873, -809,873,808, -873,809,874, -810,874,809, -874,810,875, -811,875,810, -875,811,876, -812,876,811, -876,812,877, -813,877,812, -877,813,878, -814,878,813, -878,814,879, -815,879,814, -879,815,880, -816,880,815, -880,816,881, -817,881,816, -881,817,882, -818,882,817, -882,818,883, -819,883,818, -883,819,884, -820,884,819, -884,820,885, -821,885,820, -885,821,886, -822,886,821, -886,822,887, -823,887,822, -887,823,888, -824,888,823, -888,824,889, -825,889,824, -889,825,890, -826,890,825, -890,826,891, -827,891,826, -891,827,892, -828,892,827, -892,828,893, -829,893,828, -893,829,894, -830,894,829, -894,830,895, -831,895,830, -896,832,897, -833,897,832, -897,833,898, -834,898,833, -898,834,899, -835,899,834, -899,835,900, -836,900,835, -900,836,901, -837,901,836, -901,837,902, -838,902,837, -902,838,903, -839,903,838, -903,839,904, -840,904,839, -904,840,905, -841,905,840, -905,841,906, -842,906,841, -906,842,907, -843,907,842, -907,843,908, -844,908,843, -908,844,909, -845,909,844, -909,845,910, -846,910,845, -910,846,911, -847,911,846, -911,847,912, -848,912,847, -912,848,913, -849,913,848, -913,849,914, -850,914,849, -914,850,915, -851,915,850, -915,851,916, -852,916,851, -916,852,917, -853,917,852, -917,853,918, -854,918,853, -918,854,919, -855,919,854, -919,855,920, -856,920,855, -920,856,921, -857,921,856, -921,857,922, -858,922,857, -922,858,923, -859,923,858, -923,859,924, -860,924,859, -924,860,925, -861,925,860, -925,861,926, -862,926,861, -926,862,927, -863,927,862, -927,863,928, -864,928,863, -928,864,929, -865,929,864, -929,865,930, -866,930,865, -930,866,931, -867,931,866, -931,867,932, -868,932,867, -932,868,933, -869,933,868, -933,869,934, -870,934,869, -934,870,935, -871,935,870, -935,871,936, -872,936,871, -936,872,937, -873,937,872, -937,873,938, -874,938,873, -938,874,939, -875,939,874, -939,875,940, -876,940,875, -940,876,941, -877,941,876, -941,877,942, -878,942,877, -942,878,943, -879,943,878, -943,879,944, -880,944,879, -944,880,945, -881,945,880, -945,881,946, -882,946,881, -946,882,947, -883,947,882, -947,883,948, -884,948,883, -948,884,949, -885,949,884, -949,885,950, -886,950,885, -950,886,951, -887,951,886, -951,887,952, -888,952,887, -952,888,953, -889,953,888, -953,889,954, -890,954,889, -954,890,955, -891,955,890, -955,891,956, -892,956,891, -956,892,957, -893,957,892, -957,893,958, -894,958,893, -958,894,959, -895,959,894, -960,896,961, -897,961,896, -961,897,962, -898,962,897, -962,898,963, -899,963,898, -963,899,964, -900,964,899, -964,900,965, -901,965,900, -965,901,966, -902,966,901, -966,902,967, -903,967,902, -967,903,968, -904,968,903, -968,904,969, -905,969,904, -969,905,970, -906,970,905, -970,906,971, -907,971,906, -971,907,972, -908,972,907, -972,908,973, -909,973,908, -973,909,974, -910,974,909, -974,910,975, -911,975,910, -975,911,976, -912,976,911, -976,912,977, -913,977,912, -977,913,978, -914,978,913, -978,914,979, -915,979,914, -979,915,980, -916,980,915, -980,916,981, -917,981,916, -981,917,982, -918,982,917, -982,918,983, -919,983,918, -983,919,984, -920,984,919, -984,920,985, -921,985,920, -985,921,986, -922,986,921, -986,922,987, -923,987,922, -987,923,988, -924,988,923, -988,924,989, -925,989,924, -989,925,990, -926,990,925, -990,926,991, -927,991,926, -991,927,992, -928,992,927, -992,928,993, -929,993,928, -993,929,994, -930,994,929, -994,930,995, -931,995,930, -995,931,996, -932,996,931, -996,932,997, -933,997,932, -997,933,998, -934,998,933, -998,934,999, -935,999,934, -999,935,1000, -936,1000,935, -1000,936,1001, -937,1001,936, -1001,937,1002, -938,1002,937, -1002,938,1003, -939,1003,938, -1003,939,1004, -940,1004,939, -1004,940,1005, -941,1005,940, -1005,941,1006, -942,1006,941, -1006,942,1007, -943,1007,942, -1007,943,1008, -944,1008,943, -1008,944,1009, -945,1009,944, -1009,945,1010, -946,1010,945, -1010,946,1011, -947,1011,946, -1011,947,1012, -948,1012,947, -1012,948,1013, -949,1013,948, -1013,949,1014, -950,1014,949, -1014,950,1015, -951,1015,950, -1015,951,1016, -952,1016,951, -1016,952,1017, -953,1017,952, -1017,953,1018, -954,1018,953, -1018,954,1019, -955,1019,954, -1019,955,1020, -956,1020,955, -1020,956,1021, -957,1021,956, -1021,957,1022, -958,1022,957, -1022,958,1023, -959,1023,958, -1024,960,1025, -961,1025,960, -1025,961,1026, -962,1026,961, -1026,962,1027, -963,1027,962, -1027,963,1028, -964,1028,963, -1028,964,1029, -965,1029,964, -1029,965,1030, -966,1030,965, -1030,966,1031, -967,1031,966, -1031,967,1032, -968,1032,967, -1032,968,1033, -969,1033,968, -1033,969,1034, -970,1034,969, -1034,970,1035, -971,1035,970, -1035,971,1036, -972,1036,971, -1036,972,1037, -973,1037,972, -1037,973,1038, -974,1038,973, -1038,974,1039, -975,1039,974, -1039,975,1040, -976,1040,975, -1040,976,1041, -977,1041,976, -1041,977,1042, -978,1042,977, -1042,978,1043, -979,1043,978, -1043,979,1044, -980,1044,979, -1044,980,1045, -981,1045,980, -1045,981,1046, -982,1046,981, -1046,982,1047, -983,1047,982, -1047,983,1048, -984,1048,983, -1048,984,1049, -985,1049,984, -1049,985,1050, -986,1050,985, -1050,986,1051, -987,1051,986, -1051,987,1052, -988,1052,987, -1052,988,1053, -989,1053,988, -1053,989,1054, -990,1054,989, -1054,990,1055, -991,1055,990, -1055,991,1056, -992,1056,991, -1056,992,1057, -993,1057,992, -1057,993,1058, -994,1058,993, -1058,994,1059, -995,1059,994, -1059,995,1060, -996,1060,995, -1060,996,1061, -997,1061,996, -1061,997,1062, -998,1062,997, -1062,998,1063, -999,1063,998, -1063,999,1064, -1000,1064,999, -1064,1000,1065, -1001,1065,1000, -1065,1001,1066, -1002,1066,1001, -1066,1002,1067, -1003,1067,1002, -1067,1003,1068, -1004,1068,1003, -1068,1004,1069, -1005,1069,1004, -1069,1005,1070, -1006,1070,1005, -1070,1006,1071, -1007,1071,1006, -1071,1007,1072, -1008,1072,1007, -1072,1008,1073, -1009,1073,1008, -1073,1009,1074, -1010,1074,1009, -1074,1010,1075, -1011,1075,1010, -1075,1011,1076, -1012,1076,1011, -1076,1012,1077, -1013,1077,1012, -1077,1013,1078, -1014,1078,1013, -1078,1014,1079, -1015,1079,1014, -1079,1015,1080, -1016,1080,1015, -1080,1016,1081, -1017,1081,1016, -1081,1017,1082, -1018,1082,1017, -1082,1018,1083, -1019,1083,1018, -1083,1019,1084, -1020,1084,1019, -1084,1020,1085, -1021,1085,1020, -1085,1021,1086, -1022,1086,1021, -1086,1022,1087, -1023,1087,1022, -1088,1024,1089, -1025,1089,1024, -1089,1025,1090, -1026,1090,1025, -1090,1026,1091, -1027,1091,1026, -1091,1027,1092, -1028,1092,1027, -1092,1028,1093, -1029,1093,1028, -1093,1029,1094, -1030,1094,1029, -1094,1030,1095, -1031,1095,1030, -1095,1031,1096, -1032,1096,1031, -1096,1032,1097, -1033,1097,1032, -1097,1033,1098, -1034,1098,1033, -1098,1034,1099, -1035,1099,1034, -1099,1035,1100, -1036,1100,1035, -1100,1036,1101, -1037,1101,1036, -1101,1037,1102, -1038,1102,1037, -1102,1038,1103, -1039,1103,1038, -1103,1039,1104, -1040,1104,1039, -1104,1040,1105, -1041,1105,1040, -1105,1041,1106, -1042,1106,1041, -1106,1042,1107, -1043,1107,1042, -1107,1043,1108, -1044,1108,1043, -1108,1044,1109, -1045,1109,1044, -1109,1045,1110, -1046,1110,1045, -1110,1046,1111, -1047,1111,1046, -1111,1047,1112, -1048,1112,1047, -1112,1048,1113, -1049,1113,1048, -1113,1049,1114, -1050,1114,1049, -1114,1050,1115, -1051,1115,1050, -1115,1051,1116, -1052,1116,1051, -1116,1052,1117, -1053,1117,1052, -1117,1053,1118, -1054,1118,1053, -1118,1054,1119, -1055,1119,1054, -1119,1055,1120, -1056,1120,1055, -1120,1056,1121, -1057,1121,1056, -1121,1057,1122, -1058,1122,1057, -1122,1058,1123, -1059,1123,1058, -1123,1059,1124, -1060,1124,1059, -1124,1060,1125, -1061,1125,1060, -1125,1061,1126, -1062,1126,1061, -1126,1062,1127, -1063,1127,1062, -1127,1063,1128, -1064,1128,1063, -1128,1064,1129, -1065,1129,1064, -1129,1065,1130, -1066,1130,1065, -1130,1066,1131, -1067,1131,1066, -1131,1067,1132, -1068,1132,1067, -1132,1068,1133, -1069,1133,1068, -1133,1069,1134, -1070,1134,1069, -1134,1070,1135, -1071,1135,1070, -1135,1071,1136, -1072,1136,1071, -1136,1072,1137, -1073,1137,1072, -1137,1073,1138, -1074,1138,1073, -1138,1074,1139, -1075,1139,1074, -1139,1075,1140, -1076,1140,1075, -1140,1076,1141, -1077,1141,1076, -1141,1077,1142, -1078,1142,1077, -1142,1078,1143, -1079,1143,1078, -1143,1079,1144, -1080,1144,1079, -1144,1080,1145, -1081,1145,1080, -1145,1081,1146, -1082,1146,1081, -1146,1082,1147, -1083,1147,1082, -1147,1083,1148, -1084,1148,1083, -1148,1084,1149, -1085,1149,1084, -1149,1085,1150, -1086,1150,1085, -1150,1086,1151, -1087,1151,1086, -1152,1088,1153, -1089,1153,1088, -1153,1089,1154, -1090,1154,1089, -1154,1090,1155, -1091,1155,1090, -1155,1091,1156, -1092,1156,1091, -1156,1092,1157, -1093,1157,1092, -1157,1093,1158, -1094,1158,1093, -1158,1094,1159, -1095,1159,1094, -1159,1095,1160, -1096,1160,1095, -1160,1096,1161, -1097,1161,1096, -1161,1097,1162, -1098,1162,1097, -1162,1098,1163, -1099,1163,1098, -1163,1099,1164, -1100,1164,1099, -1164,1100,1165, -1101,1165,1100, -1165,1101,1166, -1102,1166,1101, -1166,1102,1167, -1103,1167,1102, -1167,1103,1168, -1104,1168,1103, -1168,1104,1169, -1105,1169,1104, -1169,1105,1170, -1106,1170,1105, -1170,1106,1171, -1107,1171,1106, -1171,1107,1172, -1108,1172,1107, -1172,1108,1173, -1109,1173,1108, -1173,1109,1174, -1110,1174,1109, -1174,1110,1175, -1111,1175,1110, -1175,1111,1176, -1112,1176,1111, -1176,1112,1177, -1113,1177,1112, -1177,1113,1178, -1114,1178,1113, -1178,1114,1179, -1115,1179,1114, -1179,1115,1180, -1116,1180,1115, -1180,1116,1181, -1117,1181,1116, -1181,1117,1182, -1118,1182,1117, -1182,1118,1183, -1119,1183,1118, -1183,1119,1184, -1120,1184,1119, -1184,1120,1185, -1121,1185,1120, -1185,1121,1186, -1122,1186,1121, -1186,1122,1187, -1123,1187,1122, -1187,1123,1188, -1124,1188,1123, -1188,1124,1189, -1125,1189,1124, -1189,1125,1190, -1126,1190,1125, -1190,1126,1191, -1127,1191,1126, -1191,1127,1192, -1128,1192,1127, -1192,1128,1193, -1129,1193,1128, -1193,1129,1194, -1130,1194,1129, -1194,1130,1195, -1131,1195,1130, -1195,1131,1196, -1132,1196,1131, -1196,1132,1197, -1133,1197,1132, -1197,1133,1198, -1134,1198,1133, -1198,1134,1199, -1135,1199,1134, -1199,1135,1200, -1136,1200,1135, -1200,1136,1201, -1137,1201,1136, -1201,1137,1202, -1138,1202,1137, -1202,1138,1203, -1139,1203,1138, -1203,1139,1204, -1140,1204,1139, -1204,1140,1205, -1141,1205,1140, -1205,1141,1206, -1142,1206,1141, -1206,1142,1207, -1143,1207,1142, -1207,1143,1208, -1144,1208,1143, -1208,1144,1209, -1145,1209,1144, -1209,1145,1210, -1146,1210,1145, -1210,1146,1211, -1147,1211,1146, -1211,1147,1212, -1148,1212,1147, -1212,1148,1213, -1149,1213,1148, -1213,1149,1214, -1150,1214,1149, -1214,1150,1215, -1151,1215,1150, -1216,1152,1217, -1153,1217,1152, -1217,1153,1218, -1154,1218,1153, -1218,1154,1219, -1155,1219,1154, -1219,1155,1220, -1156,1220,1155, -1220,1156,1221, -1157,1221,1156, -1221,1157,1222, -1158,1222,1157, -1222,1158,1223, -1159,1223,1158, -1223,1159,1224, -1160,1224,1159, -1224,1160,1225, -1161,1225,1160, -1225,1161,1226, -1162,1226,1161, -1226,1162,1227, -1163,1227,1162, -1227,1163,1228, -1164,1228,1163, -1228,1164,1229, -1165,1229,1164, -1229,1165,1230, -1166,1230,1165, -1230,1166,1231, -1167,1231,1166, -1231,1167,1232, -1168,1232,1167, -1232,1168,1233, -1169,1233,1168, -1233,1169,1234, -1170,1234,1169, -1234,1170,1235, -1171,1235,1170, -1235,1171,1236, -1172,1236,1171, -1236,1172,1237, -1173,1237,1172, -1237,1173,1238, -1174,1238,1173, -1238,1174,1239, -1175,1239,1174, -1239,1175,1240, -1176,1240,1175, -1240,1176,1241, -1177,1241,1176, -1241,1177,1242, -1178,1242,1177, -1242,1178,1243, -1179,1243,1178, -1243,1179,1244, -1180,1244,1179, -1244,1180,1245, -1181,1245,1180, -1245,1181,1246, -1182,1246,1181, -1246,1182,1247, -1183,1247,1182, -1247,1183,1248, -1184,1248,1183, -1248,1184,1249, -1185,1249,1184, -1249,1185,1250, -1186,1250,1185, -1250,1186,1251, -1187,1251,1186, -1251,1187,1252, -1188,1252,1187, -1252,1188,1253, -1189,1253,1188, -1253,1189,1254, -1190,1254,1189, -1254,1190,1255, -1191,1255,1190, -1255,1191,1256, -1192,1256,1191, -1256,1192,1257, -1193,1257,1192, -1257,1193,1258, -1194,1258,1193, -1258,1194,1259, -1195,1259,1194, -1259,1195,1260, -1196,1260,1195, -1260,1196,1261, -1197,1261,1196, -1261,1197,1262, -1198,1262,1197, -1262,1198,1263, -1199,1263,1198, -1263,1199,1264, -1200,1264,1199, -1264,1200,1265, -1201,1265,1200, -1265,1201,1266, -1202,1266,1201, -1266,1202,1267, -1203,1267,1202, -1267,1203,1268, -1204,1268,1203, -1268,1204,1269, -1205,1269,1204, -1269,1205,1270, -1206,1270,1205, -1270,1206,1271, -1207,1271,1206, -1271,1207,1272, -1208,1272,1207, -1272,1208,1273, -1209,1273,1208, -1273,1209,1274, -1210,1274,1209, -1274,1210,1275, -1211,1275,1210, -1275,1211,1276, -1212,1276,1211, -1276,1212,1277, -1213,1277,1212, -1277,1213,1278, -1214,1278,1213, -1278,1214,1279, -1215,1279,1214, -1280,1216,1281, -1217,1281,1216, -1281,1217,1282, -1218,1282,1217, -1282,1218,1283, -1219,1283,1218, -1283,1219,1284, -1220,1284,1219, -1284,1220,1285, -1221,1285,1220, -1285,1221,1286, -1222,1286,1221, -1286,1222,1287, -1223,1287,1222, -1287,1223,1288, -1224,1288,1223, -1288,1224,1289, -1225,1289,1224, -1289,1225,1290, -1226,1290,1225, -1290,1226,1291, -1227,1291,1226, -1291,1227,1292, -1228,1292,1227, -1292,1228,1293, -1229,1293,1228, -1293,1229,1294, -1230,1294,1229, -1294,1230,1295, -1231,1295,1230, -1295,1231,1296, -1232,1296,1231, -1296,1232,1297, -1233,1297,1232, -1297,1233,1298, -1234,1298,1233, -1298,1234,1299, -1235,1299,1234, -1299,1235,1300, -1236,1300,1235, -1300,1236,1301, -1237,1301,1236, -1301,1237,1302, -1238,1302,1237, -1302,1238,1303, -1239,1303,1238, -1303,1239,1304, -1240,1304,1239, -1304,1240,1305, -1241,1305,1240, -1305,1241,1306, -1242,1306,1241, -1306,1242,1307, -1243,1307,1242, -1307,1243,1308, -1244,1308,1243, -1308,1244,1309, -1245,1309,1244, -1309,1245,1310, -1246,1310,1245, -1310,1246,1311, -1247,1311,1246, -1311,1247,1312, -1248,1312,1247, -1312,1248,1313, -1249,1313,1248, -1313,1249,1314, -1250,1314,1249, -1314,1250,1315, -1251,1315,1250, -1315,1251,1316, -1252,1316,1251, -1316,1252,1317, -1253,1317,1252, -1317,1253,1318, -1254,1318,1253, -1318,1254,1319, -1255,1319,1254, -1319,1255,1320, -1256,1320,1255, -1320,1256,1321, -1257,1321,1256, -1321,1257,1322, -1258,1322,1257, -1322,1258,1323, -1259,1323,1258, -1323,1259,1324, -1260,1324,1259, -1324,1260,1325, -1261,1325,1260, -1325,1261,1326, -1262,1326,1261, -1326,1262,1327, -1263,1327,1262, -1327,1263,1328, -1264,1328,1263, -1328,1264,1329, -1265,1329,1264, -1329,1265,1330, -1266,1330,1265, -1330,1266,1331, -1267,1331,1266, -1331,1267,1332, -1268,1332,1267, -1332,1268,1333, -1269,1333,1268, -1333,1269,1334, -1270,1334,1269, -1334,1270,1335, -1271,1335,1270, -1335,1271,1336, -1272,1336,1271, -1336,1272,1337, -1273,1337,1272, -1337,1273,1338, -1274,1338,1273, -1338,1274,1339, -1275,1339,1274, -1339,1275,1340, -1276,1340,1275, -1340,1276,1341, -1277,1341,1276, -1341,1277,1342, -1278,1342,1277, -1342,1278,1343, -1279,1343,1278, -1344,1280,1345, -1281,1345,1280, -1345,1281,1346, -1282,1346,1281, -1346,1282,1347, -1283,1347,1282, -1347,1283,1348, -1284,1348,1283, -1348,1284,1349, -1285,1349,1284, -1349,1285,1350, -1286,1350,1285, -1350,1286,1351, -1287,1351,1286, -1351,1287,1352, -1288,1352,1287, -1352,1288,1353, -1289,1353,1288, -1353,1289,1354, -1290,1354,1289, -1354,1290,1355, -1291,1355,1290, -1355,1291,1356, -1292,1356,1291, -1356,1292,1357, -1293,1357,1292, -1357,1293,1358, -1294,1358,1293, -1358,1294,1359, -1295,1359,1294, -1359,1295,1360, -1296,1360,1295, -1360,1296,1361, -1297,1361,1296, -1361,1297,1362, -1298,1362,1297, -1362,1298,1363, -1299,1363,1298, -1363,1299,1364, -1300,1364,1299, -1364,1300,1365, -1301,1365,1300, -1365,1301,1366, -1302,1366,1301, -1366,1302,1367, -1303,1367,1302, -1367,1303,1368, -1304,1368,1303, -1368,1304,1369, -1305,1369,1304, -1369,1305,1370, -1306,1370,1305, -1370,1306,1371, -1307,1371,1306, -1371,1307,1372, -1308,1372,1307, -1372,1308,1373, -1309,1373,1308, -1373,1309,1374, -1310,1374,1309, -1374,1310,1375, -1311,1375,1310, -1375,1311,1376, -1312,1376,1311, -1376,1312,1377, -1313,1377,1312, -1377,1313,1378, -1314,1378,1313, -1378,1314,1379, -1315,1379,1314, -1379,1315,1380, -1316,1380,1315, -1380,1316,1381, -1317,1381,1316, -1381,1317,1382, -1318,1382,1317, -1382,1318,1383, -1319,1383,1318, -1383,1319,1384, -1320,1384,1319, -1384,1320,1385, -1321,1385,1320, -1385,1321,1386, -1322,1386,1321, -1386,1322,1387, -1323,1387,1322, -1387,1323,1388, -1324,1388,1323, -1388,1324,1389, -1325,1389,1324, -1389,1325,1390, -1326,1390,1325, -1390,1326,1391, -1327,1391,1326, -1391,1327,1392, -1328,1392,1327, -1392,1328,1393, -1329,1393,1328, -1393,1329,1394, -1330,1394,1329, -1394,1330,1395, -1331,1395,1330, -1395,1331,1396, -1332,1396,1331, -1396,1332,1397, -1333,1397,1332, -1397,1333,1398, -1334,1398,1333, -1398,1334,1399, -1335,1399,1334, -1399,1335,1400, -1336,1400,1335, -1400,1336,1401, -1337,1401,1336, -1401,1337,1402, -1338,1402,1337, -1402,1338,1403, -1339,1403,1338, -1403,1339,1404, -1340,1404,1339, -1404,1340,1405, -1341,1405,1340, -1405,1341,1406, -1342,1406,1341, -1406,1342,1407, -1343,1407,1342, -1408,1344,1409, -1345,1409,1344, -1409,1345,1410, -1346,1410,1345, -1410,1346,1411, -1347,1411,1346, -1411,1347,1412, -1348,1412,1347, -1412,1348,1413, -1349,1413,1348, -1413,1349,1414, -1350,1414,1349, -1414,1350,1415, -1351,1415,1350, -1415,1351,1416, -1352,1416,1351, -1416,1352,1417, -1353,1417,1352, -1417,1353,1418, -1354,1418,1353, -1418,1354,1419, -1355,1419,1354, -1419,1355,1420, -1356,1420,1355, -1420,1356,1421, -1357,1421,1356, -1421,1357,1422, -1358,1422,1357, -1422,1358,1423, -1359,1423,1358, -1423,1359,1424, -1360,1424,1359, -1424,1360,1425, -1361,1425,1360, -1425,1361,1426, -1362,1426,1361, -1426,1362,1427, -1363,1427,1362, -1427,1363,1428, -1364,1428,1363, -1428,1364,1429, -1365,1429,1364, -1429,1365,1430, -1366,1430,1365, -1430,1366,1431, -1367,1431,1366, -1431,1367,1432, -1368,1432,1367, -1432,1368,1433, -1369,1433,1368, -1433,1369,1434, -1370,1434,1369, -1434,1370,1435, -1371,1435,1370, -1435,1371,1436, -1372,1436,1371, -1436,1372,1437, -1373,1437,1372, -1437,1373,1438, -1374,1438,1373, -1438,1374,1439, -1375,1439,1374, -1439,1375,1440, -1376,1440,1375, -1440,1376,1441, -1377,1441,1376, -1441,1377,1442, -1378,1442,1377, -1442,1378,1443, -1379,1443,1378, -1443,1379,1444, -1380,1444,1379, -1444,1380,1445, -1381,1445,1380, -1445,1381,1446, -1382,1446,1381, -1446,1382,1447, -1383,1447,1382, -1447,1383,1448, -1384,1448,1383, -1448,1384,1449, -1385,1449,1384, -1449,1385,1450, -1386,1450,1385, -1450,1386,1451, -1387,1451,1386, -1451,1387,1452, -1388,1452,1387, -1452,1388,1453, -1389,1453,1388, -1453,1389,1454, -1390,1454,1389, -1454,1390,1455, -1391,1455,1390, -1455,1391,1456, -1392,1456,1391, -1456,1392,1457, -1393,1457,1392, -1457,1393,1458, -1394,1458,1393, -1458,1394,1459, -1395,1459,1394, -1459,1395,1460, -1396,1460,1395, -1460,1396,1461, -1397,1461,1396, -1461,1397,1462, -1398,1462,1397, -1462,1398,1463, -1399,1463,1398, -1463,1399,1464, -1400,1464,1399, -1464,1400,1465, -1401,1465,1400, -1465,1401,1466, -1402,1466,1401, -1466,1402,1467, -1403,1467,1402, -1467,1403,1468, -1404,1468,1403, -1468,1404,1469, -1405,1469,1404, -1469,1405,1470, -1406,1470,1405, -1470,1406,1471, -1407,1471,1406, -1472,1408,1473, -1409,1473,1408, -1473,1409,1474, -1410,1474,1409, -1474,1410,1475, -1411,1475,1410, -1475,1411,1476, -1412,1476,1411, -1476,1412,1477, -1413,1477,1412, -1477,1413,1478, -1414,1478,1413, -1478,1414,1479, -1415,1479,1414, -1479,1415,1480, -1416,1480,1415, -1480,1416,1481, -1417,1481,1416, -1481,1417,1482, -1418,1482,1417, -1482,1418,1483, -1419,1483,1418, -1483,1419,1484, -1420,1484,1419, -1484,1420,1485, -1421,1485,1420, -1485,1421,1486, -1422,1486,1421, -1486,1422,1487, -1423,1487,1422, -1487,1423,1488, -1424,1488,1423, -1488,1424,1489, -1425,1489,1424, -1489,1425,1490, -1426,1490,1425, -1490,1426,1491, -1427,1491,1426, -1491,1427,1492, -1428,1492,1427, -1492,1428,1493, -1429,1493,1428, -1493,1429,1494, -1430,1494,1429, -1494,1430,1495, -1431,1495,1430, -1495,1431,1496, -1432,1496,1431, -1496,1432,1497, -1433,1497,1432, -1497,1433,1498, -1434,1498,1433, -1498,1434,1499, -1435,1499,1434, -1499,1435,1500, -1436,1500,1435, -1500,1436,1501, -1437,1501,1436, -1501,1437,1502, -1438,1502,1437, -1502,1438,1503, -1439,1503,1438, -1503,1439,1504, -1440,1504,1439, -1504,1440,1505, -1441,1505,1440, -1505,1441,1506, -1442,1506,1441, -1506,1442,1507, -1443,1507,1442, -1507,1443,1508, -1444,1508,1443, -1508,1444,1509, -1445,1509,1444, -1509,1445,1510, -1446,1510,1445, -1510,1446,1511, -1447,1511,1446, -1511,1447,1512, -1448,1512,1447, -1512,1448,1513, -1449,1513,1448, -1513,1449,1514, -1450,1514,1449, -1514,1450,1515, -1451,1515,1450, -1515,1451,1516, -1452,1516,1451, -1516,1452,1517, -1453,1517,1452, -1517,1453,1518, -1454,1518,1453, -1518,1454,1519, -1455,1519,1454, -1519,1455,1520, -1456,1520,1455, -1520,1456,1521, -1457,1521,1456, -1521,1457,1522, -1458,1522,1457, -1522,1458,1523, -1459,1523,1458, -1523,1459,1524, -1460,1524,1459, -1524,1460,1525, -1461,1525,1460, -1525,1461,1526, -1462,1526,1461, -1526,1462,1527, -1463,1527,1462, -1527,1463,1528, -1464,1528,1463, -1528,1464,1529, -1465,1529,1464, -1529,1465,1530, -1466,1530,1465, -1530,1466,1531, -1467,1531,1466, -1531,1467,1532, -1468,1532,1467, -1532,1468,1533, -1469,1533,1468, -1533,1469,1534, -1470,1534,1469, -1534,1470,1535, -1471,1535,1470, -1536,1472,1537, -1473,1537,1472, -1537,1473,1538, -1474,1538,1473, -1538,1474,1539, -1475,1539,1474, -1539,1475,1540, -1476,1540,1475, -1540,1476,1541, -1477,1541,1476, -1541,1477,1542, -1478,1542,1477, -1542,1478,1543, -1479,1543,1478, -1543,1479,1544, -1480,1544,1479, -1544,1480,1545, -1481,1545,1480, -1545,1481,1546, -1482,1546,1481, -1546,1482,1547, -1483,1547,1482, -1547,1483,1548, -1484,1548,1483, -1548,1484,1549, -1485,1549,1484, -1549,1485,1550, -1486,1550,1485, -1550,1486,1551, -1487,1551,1486, -1551,1487,1552, -1488,1552,1487, -1552,1488,1553, -1489,1553,1488, -1553,1489,1554, -1490,1554,1489, -1554,1490,1555, -1491,1555,1490, -1555,1491,1556, -1492,1556,1491, -1556,1492,1557, -1493,1557,1492, -1557,1493,1558, -1494,1558,1493, -1558,1494,1559, -1495,1559,1494, -1559,1495,1560, -1496,1560,1495, -1560,1496,1561, -1497,1561,1496, -1561,1497,1562, -1498,1562,1497, -1562,1498,1563, -1499,1563,1498, -1563,1499,1564, -1500,1564,1499, -1564,1500,1565, -1501,1565,1500, -1565,1501,1566, -1502,1566,1501, -1566,1502,1567, -1503,1567,1502, -1567,1503,1568, -1504,1568,1503, -1568,1504,1569, -1505,1569,1504, -1569,1505,1570, -1506,1570,1505, -1570,1506,1571, -1507,1571,1506, -1571,1507,1572, -1508,1572,1507, -1572,1508,1573, -1509,1573,1508, -1573,1509,1574, -1510,1574,1509, -1574,1510,1575, -1511,1575,1510, -1575,1511,1576, -1512,1576,1511, -1576,1512,1577, -1513,1577,1512, -1577,1513,1578, -1514,1578,1513, -1578,1514,1579, -1515,1579,1514, -1579,1515,1580, -1516,1580,1515, -1580,1516,1581, -1517,1581,1516, -1581,1517,1582, -1518,1582,1517, -1582,1518,1583, -1519,1583,1518, -1583,1519,1584, -1520,1584,1519, -1584,1520,1585, -1521,1585,1520, -1585,1521,1586, -1522,1586,1521, -1586,1522,1587, -1523,1587,1522, -1587,1523,1588, -1524,1588,1523, -1588,1524,1589, -1525,1589,1524, -1589,1525,1590, -1526,1590,1525, -1590,1526,1591, -1527,1591,1526, -1591,1527,1592, -1528,1592,1527, -1592,1528,1593, -1529,1593,1528, -1593,1529,1594, -1530,1594,1529, -1594,1530,1595, -1531,1595,1530, -1595,1531,1596, -1532,1596,1531, -1596,1532,1597, -1533,1597,1532, -1597,1533,1598, -1534,1598,1533, -1598,1534,1599, -1535,1599,1534, -1600,1536,1601, -1537,1601,1536, -1601,1537,1602, -1538,1602,1537, -1602,1538,1603, -1539,1603,1538, -1603,1539,1604, -1540,1604,1539, -1604,1540,1605, -1541,1605,1540, -1605,1541,1606, -1542,1606,1541, -1606,1542,1607, -1543,1607,1542, -1607,1543,1608, -1544,1608,1543, -1608,1544,1609, -1545,1609,1544, -1609,1545,1610, -1546,1610,1545, -1610,1546,1611, -1547,1611,1546, -1611,1547,1612, -1548,1612,1547, -1612,1548,1613, -1549,1613,1548, -1613,1549,1614, -1550,1614,1549, -1614,1550,1615, -1551,1615,1550, -1615,1551,1616, -1552,1616,1551, -1616,1552,1617, -1553,1617,1552, -1617,1553,1618, -1554,1618,1553, -1618,1554,1619, -1555,1619,1554, -1619,1555,1620, -1556,1620,1555, -1620,1556,1621, -1557,1621,1556, -1621,1557,1622, -1558,1622,1557, -1622,1558,1623, -1559,1623,1558, -1623,1559,1624, -1560,1624,1559, -1624,1560,1625, -1561,1625,1560, -1625,1561,1626, -1562,1626,1561, -1626,1562,1627, -1563,1627,1562, -1627,1563,1628, -1564,1628,1563, -1628,1564,1629, -1565,1629,1564, -1629,1565,1630, -1566,1630,1565, -1630,1566,1631, -1567,1631,1566, -1631,1567,1632, -1568,1632,1567, -1632,1568,1633, -1569,1633,1568, -1633,1569,1634, -1570,1634,1569, -1634,1570,1635, -1571,1635,1570, -1635,1571,1636, -1572,1636,1571, -1636,1572,1637, -1573,1637,1572, -1637,1573,1638, -1574,1638,1573, -1638,1574,1639, -1575,1639,1574, -1639,1575,1640, -1576,1640,1575, -1640,1576,1641, -1577,1641,1576, -1641,1577,1642, -1578,1642,1577, -1642,1578,1643, -1579,1643,1578, -1643,1579,1644, -1580,1644,1579, -1644,1580,1645, -1581,1645,1580, -1645,1581,1646, -1582,1646,1581, -1646,1582,1647, -1583,1647,1582, -1647,1583,1648, -1584,1648,1583, -1648,1584,1649, -1585,1649,1584, -1649,1585,1650, -1586,1650,1585, -1650,1586,1651, -1587,1651,1586, -1651,1587,1652, -1588,1652,1587, -1652,1588,1653, -1589,1653,1588, -1653,1589,1654, -1590,1654,1589, -1654,1590,1655, -1591,1655,1590, -1655,1591,1656, -1592,1656,1591, -1656,1592,1657, -1593,1657,1592, -1657,1593,1658, -1594,1658,1593, -1658,1594,1659, -1595,1659,1594, -1659,1595,1660, -1596,1660,1595, -1660,1596,1661, -1597,1661,1596, -1661,1597,1662, -1598,1662,1597, -1662,1598,1663, -1599,1663,1598, -1664,1600,1665, -1601,1665,1600, -1665,1601,1666, -1602,1666,1601, -1666,1602,1667, -1603,1667,1602, -1667,1603,1668, -1604,1668,1603, -1668,1604,1669, -1605,1669,1604, -1669,1605,1670, -1606,1670,1605, -1670,1606,1671, -1607,1671,1606, -1671,1607,1672, -1608,1672,1607, -1672,1608,1673, -1609,1673,1608, -1673,1609,1674, -1610,1674,1609, -1674,1610,1675, -1611,1675,1610, -1675,1611,1676, -1612,1676,1611, -1676,1612,1677, -1613,1677,1612, -1677,1613,1678, -1614,1678,1613, -1678,1614,1679, -1615,1679,1614, -1679,1615,1680, -1616,1680,1615, -1680,1616,1681, -1617,1681,1616, -1681,1617,1682, -1618,1682,1617, -1682,1618,1683, -1619,1683,1618, -1683,1619,1684, -1620,1684,1619, -1684,1620,1685, -1621,1685,1620, -1685,1621,1686, -1622,1686,1621, -1686,1622,1687, -1623,1687,1622, -1687,1623,1688, -1624,1688,1623, -1688,1624,1689, -1625,1689,1624, -1689,1625,1690, -1626,1690,1625, -1690,1626,1691, -1627,1691,1626, -1691,1627,1692, -1628,1692,1627, -1692,1628,1693, -1629,1693,1628, -1693,1629,1694, -1630,1694,1629, -1694,1630,1695, -1631,1695,1630, -1695,1631,1696, -1632,1696,1631, -1696,1632,1697, -1633,1697,1632, -1697,1633,1698, -1634,1698,1633, -1698,1634,1699, -1635,1699,1634, -1699,1635,1700, -1636,1700,1635, -1700,1636,1701, -1637,1701,1636, -1701,1637,1702, -1638,1702,1637, -1702,1638,1703, -1639,1703,1638, -1703,1639,1704, -1640,1704,1639, -1704,1640,1705, -1641,1705,1640, -1705,1641,1706, -1642,1706,1641, -1706,1642,1707, -1643,1707,1642, -1707,1643,1708, -1644,1708,1643, -1708,1644,1709, -1645,1709,1644, -1709,1645,1710, -1646,1710,1645, -1710,1646,1711, -1647,1711,1646, -1711,1647,1712, -1648,1712,1647, -1712,1648,1713, -1649,1713,1648, -1713,1649,1714, -1650,1714,1649, -1714,1650,1715, -1651,1715,1650, -1715,1651,1716, -1652,1716,1651, -1716,1652,1717, -1653,1717,1652, -1717,1653,1718, -1654,1718,1653, -1718,1654,1719, -1655,1719,1654, -1719,1655,1720, -1656,1720,1655, -1720,1656,1721, -1657,1721,1656, -1721,1657,1722, -1658,1722,1657, -1722,1658,1723, -1659,1723,1658, -1723,1659,1724, -1660,1724,1659, -1724,1660,1725, -1661,1725,1660, -1725,1661,1726, -1662,1726,1661, -1726,1662,1727, -1663,1727,1662, -1728,1664,1729, -1665,1729,1664, -1729,1665,1730, -1666,1730,1665, -1730,1666,1731, -1667,1731,1666, -1731,1667,1732, -1668,1732,1667, -1732,1668,1733, -1669,1733,1668, -1733,1669,1734, -1670,1734,1669, -1734,1670,1735, -1671,1735,1670, -1735,1671,1736, -1672,1736,1671, -1736,1672,1737, -1673,1737,1672, -1737,1673,1738, -1674,1738,1673, -1738,1674,1739, -1675,1739,1674, -1739,1675,1740, -1676,1740,1675, -1740,1676,1741, -1677,1741,1676, -1741,1677,1742, -1678,1742,1677, -1742,1678,1743, -1679,1743,1678, -1743,1679,1744, -1680,1744,1679, -1744,1680,1745, -1681,1745,1680, -1745,1681,1746, -1682,1746,1681, -1746,1682,1747, -1683,1747,1682, -1747,1683,1748, -1684,1748,1683, -1748,1684,1749, -1685,1749,1684, -1749,1685,1750, -1686,1750,1685, -1750,1686,1751, -1687,1751,1686, -1751,1687,1752, -1688,1752,1687, -1752,1688,1753, -1689,1753,1688, -1753,1689,1754, -1690,1754,1689, -1754,1690,1755, -1691,1755,1690, -1755,1691,1756, -1692,1756,1691, -1756,1692,1757, -1693,1757,1692, -1757,1693,1758, -1694,1758,1693, -1758,1694,1759, -1695,1759,1694, -1759,1695,1760, -1696,1760,1695, -1760,1696,1761, -1697,1761,1696, -1761,1697,1762, -1698,1762,1697, -1762,1698,1763, -1699,1763,1698, -1763,1699,1764, -1700,1764,1699, -1764,1700,1765, -1701,1765,1700, -1765,1701,1766, -1702,1766,1701, -1766,1702,1767, -1703,1767,1702, -1767,1703,1768, -1704,1768,1703, -1768,1704,1769, -1705,1769,1704, -1769,1705,1770, -1706,1770,1705, -1770,1706,1771, -1707,1771,1706, -1771,1707,1772, -1708,1772,1707, -1772,1708,1773, -1709,1773,1708, -1773,1709,1774, -1710,1774,1709, -1774,1710,1775, -1711,1775,1710, -1775,1711,1776, -1712,1776,1711, -1776,1712,1777, -1713,1777,1712, -1777,1713,1778, -1714,1778,1713, -1778,1714,1779, -1715,1779,1714, -1779,1715,1780, -1716,1780,1715, -1780,1716,1781, -1717,1781,1716, -1781,1717,1782, -1718,1782,1717, -1782,1718,1783, -1719,1783,1718, -1783,1719,1784, -1720,1784,1719, -1784,1720,1785, -1721,1785,1720, -1785,1721,1786, -1722,1786,1721, -1786,1722,1787, -1723,1787,1722, -1787,1723,1788, -1724,1788,1723, -1788,1724,1789, -1725,1789,1724, -1789,1725,1790, -1726,1790,1725, -1790,1726,1791, -1727,1791,1726, -1792,1728,1793, -1729,1793,1728, -1793,1729,1794, -1730,1794,1729, -1794,1730,1795, -1731,1795,1730, -1795,1731,1796, -1732,1796,1731, -1796,1732,1797, -1733,1797,1732, -1797,1733,1798, -1734,1798,1733, -1798,1734,1799, -1735,1799,1734, -1799,1735,1800, -1736,1800,1735, -1800,1736,1801, -1737,1801,1736, -1801,1737,1802, -1738,1802,1737, -1802,1738,1803, -1739,1803,1738, -1803,1739,1804, -1740,1804,1739, -1804,1740,1805, -1741,1805,1740, -1805,1741,1806, -1742,1806,1741, -1806,1742,1807, -1743,1807,1742, -1807,1743,1808, -1744,1808,1743, -1808,1744,1809, -1745,1809,1744, -1809,1745,1810, -1746,1810,1745, -1810,1746,1811, -1747,1811,1746, -1811,1747,1812, -1748,1812,1747, -1812,1748,1813, -1749,1813,1748, -1813,1749,1814, -1750,1814,1749, -1814,1750,1815, -1751,1815,1750, -1815,1751,1816, -1752,1816,1751, -1816,1752,1817, -1753,1817,1752, -1817,1753,1818, -1754,1818,1753, -1818,1754,1819, -1755,1819,1754, -1819,1755,1820, -1756,1820,1755, -1820,1756,1821, -1757,1821,1756, -1821,1757,1822, -1758,1822,1757, -1822,1758,1823, -1759,1823,1758, -1823,1759,1824, -1760,1824,1759, -1824,1760,1825, -1761,1825,1760, -1825,1761,1826, -1762,1826,1761, -1826,1762,1827, -1763,1827,1762, -1827,1763,1828, -1764,1828,1763, -1828,1764,1829, -1765,1829,1764, -1829,1765,1830, -1766,1830,1765, -1830,1766,1831, -1767,1831,1766, -1831,1767,1832, -1768,1832,1767, -1832,1768,1833, -1769,1833,1768, -1833,1769,1834, -1770,1834,1769, -1834,1770,1835, -1771,1835,1770, -1835,1771,1836, -1772,1836,1771, -1836,1772,1837, -1773,1837,1772, -1837,1773,1838, -1774,1838,1773, -1838,1774,1839, -1775,1839,1774, -1839,1775,1840, -1776,1840,1775, -1840,1776,1841, -1777,1841,1776, -1841,1777,1842, -1778,1842,1777, -1842,1778,1843, -1779,1843,1778, -1843,1779,1844, -1780,1844,1779, -1844,1780,1845, -1781,1845,1780, -1845,1781,1846, -1782,1846,1781, -1846,1782,1847, -1783,1847,1782, -1847,1783,1848, -1784,1848,1783, -1848,1784,1849, -1785,1849,1784, -1849,1785,1850, -1786,1850,1785, -1850,1786,1851, -1787,1851,1786, -1851,1787,1852, -1788,1852,1787, -1852,1788,1853, -1789,1853,1788, -1853,1789,1854, -1790,1854,1789, -1854,1790,1855, -1791,1855,1790, -1856,1792,1857, -1793,1857,1792, -1857,1793,1858, -1794,1858,1793, -1858,1794,1859, -1795,1859,1794, -1859,1795,1860, -1796,1860,1795, -1860,1796,1861, -1797,1861,1796, -1861,1797,1862, -1798,1862,1797, -1862,1798,1863, -1799,1863,1798, -1863,1799,1864, -1800,1864,1799, -1864,1800,1865, -1801,1865,1800, -1865,1801,1866, -1802,1866,1801, -1866,1802,1867, -1803,1867,1802, -1867,1803,1868, -1804,1868,1803, -1868,1804,1869, -1805,1869,1804, -1869,1805,1870, -1806,1870,1805, -1870,1806,1871, -1807,1871,1806, -1871,1807,1872, -1808,1872,1807, -1872,1808,1873, -1809,1873,1808, -1873,1809,1874, -1810,1874,1809, -1874,1810,1875, -1811,1875,1810, -1875,1811,1876, -1812,1876,1811, -1876,1812,1877, -1813,1877,1812, -1877,1813,1878, -1814,1878,1813, -1878,1814,1879, -1815,1879,1814, -1879,1815,1880, -1816,1880,1815, -1880,1816,1881, -1817,1881,1816, -1881,1817,1882, -1818,1882,1817, -1882,1818,1883, -1819,1883,1818, -1883,1819,1884, -1820,1884,1819, -1884,1820,1885, -1821,1885,1820, -1885,1821,1886, -1822,1886,1821, -1886,1822,1887, -1823,1887,1822, -1887,1823,1888, -1824,1888,1823, -1888,1824,1889, -1825,1889,1824, -1889,1825,1890, -1826,1890,1825, -1890,1826,1891, -1827,1891,1826, -1891,1827,1892, -1828,1892,1827, -1892,1828,1893, -1829,1893,1828, -1893,1829,1894, -1830,1894,1829, -1894,1830,1895, -1831,1895,1830, -1895,1831,1896, -1832,1896,1831, -1896,1832,1897, -1833,1897,1832, -1897,1833,1898, -1834,1898,1833, -1898,1834,1899, -1835,1899,1834, -1899,1835,1900, -1836,1900,1835, -1900,1836,1901, -1837,1901,1836, -1901,1837,1902, -1838,1902,1837, -1902,1838,1903, -1839,1903,1838, -1903,1839,1904, -1840,1904,1839, -1904,1840,1905, -1841,1905,1840, -1905,1841,1906, -1842,1906,1841, -1906,1842,1907, -1843,1907,1842, -1907,1843,1908, -1844,1908,1843, -1908,1844,1909, -1845,1909,1844, -1909,1845,1910, -1846,1910,1845, -1910,1846,1911, -1847,1911,1846, -1911,1847,1912, -1848,1912,1847, -1912,1848,1913, -1849,1913,1848, -1913,1849,1914, -1850,1914,1849, -1914,1850,1915, -1851,1915,1850, -1915,1851,1916, -1852,1916,1851, -1916,1852,1917, -1853,1917,1852, -1917,1853,1918, -1854,1918,1853, -1918,1854,1919, -1855,1919,1854, -1920,1856,1921, -1857,1921,1856, -1921,1857,1922, -1858,1922,1857, -1922,1858,1923, -1859,1923,1858, -1923,1859,1924, -1860,1924,1859, -1924,1860,1925, -1861,1925,1860, -1925,1861,1926, -1862,1926,1861, -1926,1862,1927, -1863,1927,1862, -1927,1863,1928, -1864,1928,1863, -1928,1864,1929, -1865,1929,1864, -1929,1865,1930, -1866,1930,1865, -1930,1866,1931, -1867,1931,1866, -1931,1867,1932, -1868,1932,1867, -1932,1868,1933, -1869,1933,1868, -1933,1869,1934, -1870,1934,1869, -1934,1870,1935, -1871,1935,1870, -1935,1871,1936, -1872,1936,1871, -1936,1872,1937, -1873,1937,1872, -1937,1873,1938, -1874,1938,1873, -1938,1874,1939, -1875,1939,1874, -1939,1875,1940, -1876,1940,1875, -1940,1876,1941, -1877,1941,1876, -1941,1877,1942, -1878,1942,1877, -1942,1878,1943, -1879,1943,1878, -1943,1879,1944, -1880,1944,1879, -1944,1880,1945, -1881,1945,1880, -1945,1881,1946, -1882,1946,1881, -1946,1882,1947, -1883,1947,1882, -1947,1883,1948, -1884,1948,1883, -1948,1884,1949, -1885,1949,1884, -1949,1885,1950, -1886,1950,1885, -1950,1886,1951, -1887,1951,1886, -1951,1887,1952, -1888,1952,1887, -1952,1888,1953, -1889,1953,1888, -1953,1889,1954, -1890,1954,1889, -1954,1890,1955, -1891,1955,1890, -1955,1891,1956, -1892,1956,1891, -1956,1892,1957, -1893,1957,1892, -1957,1893,1958, -1894,1958,1893, -1958,1894,1959, -1895,1959,1894, -1959,1895,1960, -1896,1960,1895, -1960,1896,1961, -1897,1961,1896, -1961,1897,1962, -1898,1962,1897, -1962,1898,1963, -1899,1963,1898, -1963,1899,1964, -1900,1964,1899, -1964,1900,1965, -1901,1965,1900, -1965,1901,1966, -1902,1966,1901, -1966,1902,1967, -1903,1967,1902, -1967,1903,1968, -1904,1968,1903, -1968,1904,1969, -1905,1969,1904, -1969,1905,1970, -1906,1970,1905, -1970,1906,1971, -1907,1971,1906, -1971,1907,1972, -1908,1972,1907, -1972,1908,1973, -1909,1973,1908, -1973,1909,1974, -1910,1974,1909, -1974,1910,1975, -1911,1975,1910, -1975,1911,1976, -1912,1976,1911, -1976,1912,1977, -1913,1977,1912, -1977,1913,1978, -1914,1978,1913, -1978,1914,1979, -1915,1979,1914, -1979,1915,1980, -1916,1980,1915, -1980,1916,1981, -1917,1981,1916, -1981,1917,1982, -1918,1982,1917, -1982,1918,1983, -1919,1983,1918, -1984,1920,1985, -1921,1985,1920, -1985,1921,1986, -1922,1986,1921, -1986,1922,1987, -1923,1987,1922, -1987,1923,1988, -1924,1988,1923, -1988,1924,1989, -1925,1989,1924, -1989,1925,1990, -1926,1990,1925, -1990,1926,1991, -1927,1991,1926, -1991,1927,1992, -1928,1992,1927, -1992,1928,1993, -1929,1993,1928, -1993,1929,1994, -1930,1994,1929, -1994,1930,1995, -1931,1995,1930, -1995,1931,1996, -1932,1996,1931, -1996,1932,1997, -1933,1997,1932, -1997,1933,1998, -1934,1998,1933, -1998,1934,1999, -1935,1999,1934, -1999,1935,2000, -1936,2000,1935, -2000,1936,2001, -1937,2001,1936, -2001,1937,2002, -1938,2002,1937, -2002,1938,2003, -1939,2003,1938, -2003,1939,2004, -1940,2004,1939, -2004,1940,2005, -1941,2005,1940, -2005,1941,2006, -1942,2006,1941, -2006,1942,2007, -1943,2007,1942, -2007,1943,2008, -1944,2008,1943, -2008,1944,2009, -1945,2009,1944, -2009,1945,2010, -1946,2010,1945, -2010,1946,2011, -1947,2011,1946, -2011,1947,2012, -1948,2012,1947, -2012,1948,2013, -1949,2013,1948, -2013,1949,2014, -1950,2014,1949, -2014,1950,2015, -1951,2015,1950, -2015,1951,2016, -1952,2016,1951, -2016,1952,2017, -1953,2017,1952, -2017,1953,2018, -1954,2018,1953, -2018,1954,2019, -1955,2019,1954, -2019,1955,2020, -1956,2020,1955, -2020,1956,2021, -1957,2021,1956, -2021,1957,2022, -1958,2022,1957, -2022,1958,2023, -1959,2023,1958, -2023,1959,2024, -1960,2024,1959, -2024,1960,2025, -1961,2025,1960, -2025,1961,2026, -1962,2026,1961, -2026,1962,2027, -1963,2027,1962, -2027,1963,2028, -1964,2028,1963, -2028,1964,2029, -1965,2029,1964, -2029,1965,2030, -1966,2030,1965, -2030,1966,2031, -1967,2031,1966, -2031,1967,2032, -1968,2032,1967, -2032,1968,2033, -1969,2033,1968, -2033,1969,2034, -1970,2034,1969, -2034,1970,2035, -1971,2035,1970, -2035,1971,2036, -1972,2036,1971, -2036,1972,2037, -1973,2037,1972, -2037,1973,2038, -1974,2038,1973, -2038,1974,2039, -1975,2039,1974, -2039,1975,2040, -1976,2040,1975, -2040,1976,2041, -1977,2041,1976, -2041,1977,2042, -1978,2042,1977, -2042,1978,2043, -1979,2043,1978, -2043,1979,2044, -1980,2044,1979, -2044,1980,2045, -1981,2045,1980, -2045,1981,2046, -1982,2046,1981, -2046,1982,2047, -1983,2047,1982, -2048,1984,2049, -1985,2049,1984, -2049,1985,2050, -1986,2050,1985, -2050,1986,2051, -1987,2051,1986, -2051,1987,2052, -1988,2052,1987, -2052,1988,2053, -1989,2053,1988, -2053,1989,2054, -1990,2054,1989, -2054,1990,2055, -1991,2055,1990, -2055,1991,2056, -1992,2056,1991, -2056,1992,2057, -1993,2057,1992, -2057,1993,2058, -1994,2058,1993, -2058,1994,2059, -1995,2059,1994, -2059,1995,2060, -1996,2060,1995, -2060,1996,2061, -1997,2061,1996, -2061,1997,2062, -1998,2062,1997, -2062,1998,2063, -1999,2063,1998, -2063,1999,2064, -2000,2064,1999, -2064,2000,2065, -2001,2065,2000, -2065,2001,2066, -2002,2066,2001, -2066,2002,2067, -2003,2067,2002, -2067,2003,2068, -2004,2068,2003, -2068,2004,2069, -2005,2069,2004, -2069,2005,2070, -2006,2070,2005, -2070,2006,2071, -2007,2071,2006, -2071,2007,2072, -2008,2072,2007, -2072,2008,2073, -2009,2073,2008, -2073,2009,2074, -2010,2074,2009, -2074,2010,2075, -2011,2075,2010, -2075,2011,2076, -2012,2076,2011, -2076,2012,2077, -2013,2077,2012, -2077,2013,2078, -2014,2078,2013, -2078,2014,2079, -2015,2079,2014, -2079,2015,2080, -2016,2080,2015, -2080,2016,2081, -2017,2081,2016, -2081,2017,2082, -2018,2082,2017, -2082,2018,2083, -2019,2083,2018, -2083,2019,2084, -2020,2084,2019, -2084,2020,2085, -2021,2085,2020, -2085,2021,2086, -2022,2086,2021, -2086,2022,2087, -2023,2087,2022, -2087,2023,2088, -2024,2088,2023, -2088,2024,2089, -2025,2089,2024, -2089,2025,2090, -2026,2090,2025, -2090,2026,2091, -2027,2091,2026, -2091,2027,2092, -2028,2092,2027, -2092,2028,2093, -2029,2093,2028, -2093,2029,2094, -2030,2094,2029, -2094,2030,2095, -2031,2095,2030, -2095,2031,2096, -2032,2096,2031, -2096,2032,2097, -2033,2097,2032, -2097,2033,2098, -2034,2098,2033, -2098,2034,2099, -2035,2099,2034, -2099,2035,2100, -2036,2100,2035, -2100,2036,2101, -2037,2101,2036, -2101,2037,2102, -2038,2102,2037, -2102,2038,2103, -2039,2103,2038, -2103,2039,2104, -2040,2104,2039, -2104,2040,2105, -2041,2105,2040, -2105,2041,2106, -2042,2106,2041, -2106,2042,2107, -2043,2107,2042, -2107,2043,2108, -2044,2108,2043, -2108,2044,2109, -2045,2109,2044, -2109,2045,2110, -2046,2110,2045, -2110,2046,2111, -2047,2111,2046, -}; - -#define Landscape05VtxCount 2244 -#define Landscape05IdxCount 12870 - -btScalar Landscape05Vtx[] = { --250.0f,-0.990273f,0.0f, --250.0f,0.139875f,3.90625f, --246.094f,0.671004f,0.0f, --246.094f,1.72995f,3.90625f, --242.188f,1.84097f,0.0f, --242.188f,2.60122f,3.90625f, --238.281f,3.67319f,-1.6056e-007f, --238.281f,4.01346f,3.90625f, --234.375f,4.96849f,-2.1718e-007f, --234.375f,5.13654f,3.90625f, --230.469f,6.56215f,-2.86841e-007f, --230.469f,6.69665f,3.90625f, --226.563f,8.30102f,-3.62849e-007f, --226.563f,8.43203f,3.90625f, --222.656f,9.94385f,-4.3466e-007f, --222.656f,9.83442f,3.90625f, --218.75f,11.5986f,-5.06992e-007f, --218.75f,11.3645f,3.90625f, --214.844f,14.3141f,-6.2569e-007f, --214.844f,14.222f,3.90625f, --210.938f,16.5538f,-7.2359e-007f, --210.938f,16.1758f,3.90625f, --207.031f,18.852f,-8.24046e-007f, --207.031f,18.9127f,3.90625f, --203.125f,21.5344f,-9.41301e-007f, --203.125f,21.2478f,3.90625f, --199.219f,22.7337f,-9.93723e-007f, --199.219f,23.0589f,3.90625f, --195.313f,24.4712f,-1.06967e-006f, --195.313f,24.6025f,3.90625f, --191.406f,26.1169f,-1.14161e-006f, --191.406f,25.8143f,3.90625f, --187.5f,26.9988f,-1.18015e-006f, --187.5f,27.5696f,3.90625f, --183.594f,28.3854f,-1.24077e-006f, --183.594f,29.2176f,3.90625f, --179.688f,29.0457f,-1.26963e-006f, --179.688f,29.6835f,3.90625f, --175.781f,29.802f,-1.30269e-006f, --175.781f,30.7416f,3.90625f, --171.875f,30.1559f,-1.31816e-006f, --171.875f,31.4405f,3.90625f, --167.969f,32.3708f,-1.41497e-006f, --167.969f,33.0831f,3.90625f, --164.063f,34.9705f,-1.52861e-006f, --164.063f,34.6225f,3.90625f, --160.156f,36.396f,-1.59092e-006f, --160.156f,35.4992f,3.90625f, --156.25f,37.2947f,-1.6302e-006f, --156.25f,37.4126f,3.90625f, --152.344f,38.248f,-1.67187e-006f, --152.344f,38.453f,3.90625f, --148.438f,38.3176f,-1.67491e-006f, --148.438f,38.9974f,3.90625f, --144.531f,38.1589f,-1.66798e-006f, --144.531f,38.7871f,3.90625f, --140.625f,36.5895f,-1.59938e-006f, --140.625f,37.6021f,3.90625f, --136.719f,35.718f,-1.56128e-006f, --136.719f,36.1797f,3.90625f, --132.813f,33.7519f,-1.47534e-006f, --132.813f,34.9906f,3.90625f, --128.906f,33.2853f,-1.45495e-006f, --128.906f,34.1304f,3.90625f, --125.0f,33.4003f,-1.45997e-006f, --125.0f,34.3517f,3.90625f, --121.094f,33.1132f,-1.44742e-006f, --121.094f,33.6612f,3.90625f, --117.188f,32.7861f,-1.43313e-006f, --117.188f,32.7047f,3.90625f, --113.281f,33.0037f,-1.44264e-006f, --113.281f,32.3958f,3.90625f, --109.375f,32.508f,-1.42097e-006f, --109.375f,31.0818f,3.90625f, --105.469f,31.8384f,-1.3917e-006f, --105.469f,30.9536f,3.90625f, --101.563f,31.1858f,-1.36317e-006f, --101.563f,29.8205f,3.90625f, --97.6563f,29.6739f,-1.29709e-006f, --97.6563f,28.4796f,3.90625f, --93.75f,27.8258f,-1.2163e-006f, --93.75f,27.6494f,3.90625f, --89.8438f,25.9046f,-1.13232e-006f, --89.8438f,25.5721f,3.90625f, --85.9375f,23.4229f,-1.02385e-006f, --85.9375f,24.227f,3.90625f, --82.0313f,23.3671f,-1.02141e-006f, --82.0313f,23.2611f,3.90625f, --78.125f,23.0585f,-1.00792e-006f, --78.125f,22.4589f,3.90625f, --74.2188f,23.9226f,-1.04569e-006f, --74.2188f,23.2261f,3.90625f, --70.3125f,23.6449f,-1.03355e-006f, --70.3125f,23.5025f,3.90625f, --66.4063f,23.2789f,-1.01755e-006f, --66.4063f,23.6913f,3.90625f, --62.5f,24.5841f,-1.07461e-006f, --62.5f,24.6785f,3.90625f, --58.5938f,25.71f,-1.12382e-006f, --58.5938f,25.4946f,3.90625f, --54.6875f,26.9872f,-1.17965e-006f, --54.6875f,25.9722f,3.90625f, --50.7813f,27.8632f,-1.21794e-006f, --50.7813f,26.1977f,3.90625f, --46.875f,28.0326f,-1.22534e-006f, --46.875f,26.8539f,3.90625f, --42.9688f,28.0866f,-1.2277e-006f, --42.9688f,27.7268f,3.90625f, --39.0625f,30.1482f,-1.31782e-006f, --39.0625f,29.2046f,3.90625f, --35.1563f,32.4049f,-1.41646e-006f, --35.1563f,31.79f,3.90625f, --31.25f,34.4714f,-1.50679e-006f, --31.25f,34.2658f,3.90625f, --27.3438f,37.2668f,-1.62898e-006f, --27.3438f,35.9914f,3.90625f, --23.4375f,38.7934f,-1.69571e-006f, --23.4375f,38.3776f,3.90625f, --19.5313f,40.4024f,-1.76605e-006f, --19.5313f,39.8852f,3.90625f, --15.625f,42.8177f,-1.87162e-006f, --15.625f,43.1455f,3.90625f, --11.7188f,45.0198f,-1.96788e-006f, --11.7188f,45.5059f,3.90625f, --7.8125f,46.7349f,-2.04285e-006f, --7.8125f,47.4257f,3.90625f, --3.90625f,48.376f,-2.11458e-006f, --3.90625f,49.9032f,3.90625f, -0.0f,49.9016f,-2.18127e-006f, -0.0f,52.0322f,3.90625f, -3.90625f,50.3865f,-2.20246e-006f, -3.90625f,52.6186f,3.90625f, --250.0f,-0.818988f,-3.90625f, --246.094f,0.671433f,-3.90625f, --242.188f,2.83415f,-3.90625f, --238.281f,4.19978f,-3.90625f, --234.375f,5.59158f,-3.90625f, --230.469f,6.94041f,-3.90625f, --226.563f,8.34599f,-3.90625f, --222.656f,9.85416f,-3.90625f, --218.75f,10.8989f,-3.90625f, --214.844f,13.6339f,-3.90625f, --210.938f,16.5116f,-3.90625f, --207.031f,17.7111f,-3.90625f, --203.125f,20.7442f,-3.90625f, --199.219f,22.5356f,-3.90625f, --195.313f,24.3988f,-3.90625f, --191.406f,25.8062f,-3.90625f, --187.5f,26.9714f,-3.90625f, --183.594f,27.7397f,-3.90625f, --179.688f,28.8632f,-3.90625f, --175.781f,29.9688f,-3.90625f, --171.875f,32.154f,-3.90625f, --167.969f,33.3799f,-3.90625f, --164.063f,35.3882f,-3.90625f, --160.156f,35.9765f,-3.90625f, --156.25f,36.5306f,-3.90625f, --152.344f,37.3214f,-3.90625f, --148.438f,36.8126f,-3.90625f, --144.531f,36.5407f,-3.90625f, --140.625f,35.696f,-3.90625f, --136.719f,35.1152f,-3.90625f, --132.813f,34.1963f,-3.90625f, --128.906f,34.0796f,-3.90625f, --125.0f,34.2398f,-3.90625f, --121.094f,34.1503f,-3.90625f, --117.188f,33.7958f,-3.90625f, --113.281f,33.856f,-3.90625f, --109.375f,33.2705f,-3.90625f, --105.469f,32.5804f,-3.90625f, --101.563f,31.911f,-3.90625f, --97.6563f,30.3705f,-3.90625f, --93.75f,29.0627f,-3.90625f, --89.8438f,26.6822f,-3.90625f, --85.9375f,24.8309f,-3.90625f, --82.0313f,23.8581f,-3.90625f, --78.125f,23.3764f,-3.90625f, --74.2188f,23.9582f,-3.90625f, --70.3125f,24.13f,-3.90625f, --66.4063f,24.4426f,-3.90625f, --62.5f,25.5839f,-3.90625f, --58.5938f,26.6899f,-3.90625f, --54.6875f,27.9086f,-3.90625f, --50.7813f,28.5131f,-3.90625f, --46.875f,29.2612f,-3.90625f, --42.9688f,29.4581f,-3.90625f, --39.0625f,30.8972f,-3.90625f, --35.1563f,32.9085f,-3.90625f, --31.25f,34.9204f,-3.90625f, --27.3438f,37.7223f,-3.90625f, --23.4375f,38.921f,-3.90625f, --19.5313f,40.2983f,-3.90625f, --15.625f,41.7689f,-3.90625f, --11.7188f,43.8388f,-3.90625f, --7.8125f,44.7599f,-3.90625f, --3.90625f,46.53f,-3.90625f, -0.0f,48.2498f,-3.90625f, -3.90625f,48.8559f,-3.90625f, --250.0f,0.432867f,-7.8125f, --246.094f,1.93096f,-7.8125f, --242.188f,3.28774f,-7.8125f, --238.281f,4.53112f,-7.8125f, --234.375f,5.67699f,-7.8125f, --230.469f,7.34068f,-7.8125f, --226.563f,8.48553f,-7.8125f, --222.656f,10.127f,-7.8125f, --218.75f,11.3267f,-7.8125f, --214.844f,13.3914f,-7.8125f, --210.938f,15.5197f,-7.8125f, --207.031f,17.9403f,-7.8125f, --203.125f,20.5644f,-7.8125f, --199.219f,22.8796f,-7.8125f, --195.313f,23.715f,-7.8125f, --191.406f,26.1312f,-7.8125f, --187.5f,28.0754f,-7.8125f, --183.594f,29.1199f,-7.8125f, --179.688f,29.5774f,-7.8125f, --175.781f,30.2676f,-7.8125f, --171.875f,31.8275f,-7.8125f, --167.969f,33.4969f,-7.8125f, --164.063f,34.4445f,-7.8125f, --160.156f,35.3881f,-7.8125f, --156.25f,36.0267f,-7.8125f, --152.344f,36.1221f,-7.8125f, --148.438f,36.7707f,-7.8125f, --144.531f,36.3067f,-7.8125f, --140.625f,36.2295f,-7.8125f, --136.719f,35.6858f,-7.8125f, --132.813f,34.6232f,-7.8125f, --128.906f,34.1675f,-7.8125f, --125.0f,34.1756f,-7.8125f, --121.094f,33.6453f,-7.8125f, --117.188f,34.2516f,-7.8125f, --113.281f,34.228f,-7.8125f, --109.375f,34.253f,-7.8125f, --105.469f,33.1798f,-7.8125f, --101.563f,32.238f,-7.8125f, --97.6563f,31.0377f,-7.8125f, --93.75f,29.6795f,-7.8125f, --89.8438f,27.5934f,-7.8125f, --85.9375f,25.7426f,-7.8125f, --82.0313f,24.4001f,-7.8125f, --78.125f,24.4095f,-7.8125f, --74.2188f,25.1494f,-7.8125f, --70.3125f,25.0193f,-7.8125f, --66.4063f,25.3902f,-7.8125f, --62.5f,25.8612f,-7.8125f, --58.5938f,26.8169f,-7.8125f, --54.6875f,28.0698f,-7.8125f, --50.7813f,28.978f,-7.8125f, --46.875f,29.1063f,-7.8125f, --42.9688f,30.6071f,-7.8125f, --39.0625f,31.7015f,-7.8125f, --35.1563f,32.6112f,-7.8125f, --31.25f,34.6006f,-7.8125f, --27.3438f,36.3005f,-7.8125f, --23.4375f,38.4757f,-7.8125f, --19.5313f,39.7014f,-7.8125f, --15.625f,40.7762f,-7.8125f, --11.7188f,42.6458f,-7.8125f, --7.8125f,45.0307f,-7.8125f, --3.90625f,47.2861f,-7.8125f, -0.0f,48.5591f,-7.8125f, -3.90625f,48.7225f,-7.8125f, --250.0f,0.568294f,-11.7188f, --246.094f,1.83097f,-11.7188f, --242.188f,3.32037f,-11.7188f, --238.281f,4.29184f,-11.7188f, --234.375f,6.04113f,-11.7188f, --230.469f,7.01872f,-11.7188f, --226.563f,8.96731f,-11.7188f, --222.656f,10.3749f,-11.7188f, --218.75f,11.568f,-11.7188f, --214.844f,13.9092f,-11.7188f, --210.938f,15.6547f,-11.7188f, --207.031f,18.2156f,-11.7188f, --203.125f,20.0116f,-11.7188f, --199.219f,21.5443f,-11.7188f, --195.313f,23.4553f,-11.7188f, --191.406f,26.2778f,-11.7188f, --187.5f,28.0543f,-11.7188f, --183.594f,29.2657f,-11.7188f, --179.688f,29.6454f,-11.7188f, --175.781f,30.699f,-11.7188f, --171.875f,30.8229f,-11.7188f, --167.969f,32.9874f,-11.7188f, --164.063f,33.581f,-11.7188f, --160.156f,34.6365f,-11.7188f, --156.25f,35.6153f,-11.7188f, --152.344f,36.2491f,-11.7188f, --148.438f,36.2996f,-11.7188f, --144.531f,36.5456f,-11.7188f, --140.625f,36.3803f,-11.7188f, --136.719f,35.2403f,-11.7188f, --132.813f,34.0595f,-11.7188f, --128.906f,34.1384f,-11.7188f, --125.0f,33.59f,-11.7188f, --121.094f,33.7745f,-11.7188f, --117.188f,33.7284f,-11.7188f, --113.281f,33.7013f,-11.7188f, --109.375f,33.6335f,-11.7188f, --105.469f,33.2451f,-11.7188f, --101.563f,32.8691f,-11.7188f, --97.6563f,31.1343f,-11.7188f, --93.75f,29.5843f,-11.7188f, --89.8438f,27.5891f,-11.7188f, --85.9375f,25.75f,-11.7188f, --82.0313f,25.4336f,-11.7188f, --78.125f,25.6207f,-11.7188f, --74.2188f,25.1627f,-11.7188f, --70.3125f,25.542f,-11.7188f, --66.4063f,25.5384f,-11.7188f, --62.5f,25.9238f,-11.7188f, --58.5938f,26.0718f,-11.7188f, --54.6875f,27.4395f,-11.7188f, --50.7813f,28.8032f,-11.7188f, --46.875f,29.9667f,-11.7188f, --42.9688f,31.7598f,-11.7188f, --39.0625f,32.2636f,-11.7188f, --35.1563f,32.5734f,-11.7188f, --31.25f,33.543f,-11.7188f, --27.3438f,35.1143f,-11.7188f, --23.4375f,37.3147f,-11.7188f, --19.5313f,39.2413f,-11.7188f, --15.625f,41.8344f,-11.7188f, --11.7188f,43.9992f,-11.7188f, --7.8125f,46.8581f,-11.7188f, --3.90625f,48.5977f,-11.7188f, -0.0f,48.7029f,-11.7188f, -3.90625f,49.6298f,-11.7188f, --250.0f,1.50235f,-15.625f, --246.094f,1.79115f,-15.625f, --242.188f,2.52523f,-15.625f, --238.281f,4.09278f,-15.625f, --234.375f,6.21068f,-15.625f, --230.469f,7.49819f,-15.625f, --226.563f,8.56548f,-15.625f, --222.656f,9.98954f,-15.625f, --218.75f,12.3263f,-15.625f, --214.844f,14.495f,-15.625f, --210.938f,15.3551f,-15.625f, --207.031f,17.6989f,-15.625f, --203.125f,19.2847f,-15.625f, --199.219f,21.1027f,-15.625f, --195.313f,23.3408f,-15.625f, --191.406f,25.3739f,-15.625f, --187.5f,27.368f,-15.625f, --183.594f,28.3731f,-15.625f, --179.688f,29.5532f,-15.625f, --175.781f,30.0011f,-15.625f, --171.875f,31.0216f,-15.625f, --167.969f,32.5546f,-15.625f, --164.063f,32.6717f,-15.625f, --160.156f,33.8465f,-15.625f, --156.25f,35.1272f,-15.625f, --152.344f,35.5572f,-15.625f, --148.438f,36.643f,-15.625f, --144.531f,36.4283f,-15.625f, --140.625f,35.6122f,-15.625f, --136.719f,35.358f,-15.625f, --132.813f,34.1938f,-15.625f, --128.906f,34.3913f,-15.625f, --125.0f,33.2147f,-15.625f, --121.094f,32.799f,-15.625f, --117.188f,33.1385f,-15.625f, --113.281f,33.1487f,-15.625f, --109.375f,33.6564f,-15.625f, --105.469f,33.2315f,-15.625f, --101.563f,32.6066f,-15.625f, --97.6563f,30.6926f,-15.625f, --93.75f,28.534f,-15.625f, --89.8438f,27.6738f,-15.625f, --85.9375f,27.4216f,-15.625f, --82.0313f,26.0324f,-15.625f, --78.125f,25.775f,-15.625f, --74.2188f,25.909f,-15.625f, --70.3125f,25.0198f,-15.625f, --66.4063f,25.9376f,-15.625f, --62.5f,26.0382f,-15.625f, --58.5938f,25.856f,-15.625f, --54.6875f,27.3648f,-15.625f, --50.7813f,28.9059f,-15.625f, --46.875f,30.6601f,-15.625f, --42.9688f,32.6996f,-15.625f, --39.0625f,32.6909f,-15.625f, --35.1563f,33.1697f,-15.625f, --31.25f,34.6947f,-15.625f, --27.3438f,35.6982f,-15.625f, --23.4375f,38.2946f,-15.625f, --19.5313f,40.6765f,-15.625f, --15.625f,43.5894f,-15.625f, --11.7188f,46.3071f,-15.625f, --7.8125f,48.6578f,-15.625f, --3.90625f,49.0003f,-15.625f, -0.0f,50.5123f,-15.625f, -3.90625f,50.6915f,-15.625f, --250.0f,1.44302f,-19.5313f, --246.094f,1.65093f,-19.5313f, --242.188f,2.94233f,-19.5313f, --238.281f,4.72065f,-19.5313f, --234.375f,6.57861f,-19.5313f, --230.469f,7.31849f,-19.5313f, --226.563f,7.90567f,-19.5313f, --222.656f,9.84414f,-19.5313f, --218.75f,12.1574f,-19.5313f, --214.844f,13.2825f,-19.5313f, --210.938f,15.2284f,-19.5313f, --207.031f,17.2765f,-19.5313f, --203.125f,19.1565f,-19.5313f, --199.219f,20.3098f,-19.5313f, --195.313f,21.9346f,-19.5313f, --191.406f,23.8549f,-19.5313f, --187.5f,26.133f,-19.5313f, --183.594f,27.5858f,-19.5313f, --179.688f,28.557f,-19.5313f, --175.781f,28.9754f,-19.5313f, --171.875f,29.9709f,-19.5313f, --167.969f,31.2632f,-19.5313f, --164.063f,31.4957f,-19.5313f, --160.156f,33.6753f,-19.5313f, --156.25f,35.1342f,-19.5313f, --152.344f,35.0617f,-19.5313f, --148.438f,34.9467f,-19.5313f, --144.531f,35.1042f,-19.5313f, --140.625f,35.0842f,-19.5313f, --136.719f,34.7766f,-19.5313f, --132.813f,33.8305f,-19.5313f, --128.906f,33.3013f,-19.5313f, --125.0f,32.5726f,-19.5313f, --121.094f,31.5139f,-19.5313f, --117.188f,31.4576f,-19.5313f, --113.281f,31.6546f,-19.5313f, --109.375f,32.4663f,-19.5313f, --105.469f,32.6148f,-19.5313f, --101.563f,31.253f,-19.5313f, --97.6563f,29.5875f,-19.5313f, --93.75f,28.4866f,-19.5313f, --89.8438f,29.106f,-19.5313f, --85.9375f,28.7092f,-19.5313f, --82.0313f,27.4567f,-19.5313f, --78.125f,26.5225f,-19.5313f, --74.2188f,26.7534f,-19.5313f, --70.3125f,26.278f,-19.5313f, --66.4063f,25.6949f,-19.5313f, --62.5f,25.7385f,-19.5313f, --58.5938f,25.8791f,-19.5313f, --54.6875f,27.42f,-19.5313f, --50.7813f,29.0777f,-19.5313f, --46.875f,31.016f,-19.5313f, --42.9688f,32.5331f,-19.5313f, --39.0625f,33.213f,-19.5313f, --35.1563f,33.9437f,-19.5313f, --31.25f,35.6737f,-19.5313f, --27.3438f,37.8841f,-19.5313f, --23.4375f,40.5289f,-19.5313f, --19.5313f,43.6786f,-19.5313f, --15.625f,47.2945f,-19.5313f, --11.7188f,49.7082f,-19.5313f, --7.8125f,51.1285f,-19.5313f, --3.90625f,51.5532f,-19.5313f, -0.0f,52.3342f,-19.5313f, -3.90625f,52.1028f,-19.5313f, --250.0f,1.05337f,-23.4375f, --246.094f,1.28315f,-23.4375f, --242.188f,3.38102f,-23.4375f, --238.281f,4.51357f,-23.4375f, --234.375f,5.63288f,-23.4375f, --230.469f,6.49498f,-23.4375f, --226.563f,7.71248f,-23.4375f, --222.656f,8.83716f,-23.4375f, --218.75f,10.4002f,-23.4375f, --214.844f,11.8049f,-23.4375f, --210.938f,13.7948f,-23.4375f, --207.031f,16.5066f,-23.4375f, --203.125f,18.598f,-23.4375f, --199.219f,20.3069f,-23.4375f, --195.313f,21.6868f,-23.4375f, --191.406f,22.5781f,-23.4375f, --187.5f,25.0292f,-23.4375f, --183.594f,26.5386f,-23.4375f, --179.688f,27.1952f,-23.4375f, --175.781f,28.4023f,-23.4375f, --171.875f,29.0264f,-23.4375f, --167.969f,29.9302f,-23.4375f, --164.063f,31.7992f,-23.4375f, --160.156f,33.4902f,-23.4375f, --156.25f,34.4307f,-23.4375f, --152.344f,34.1463f,-23.4375f, --148.438f,33.5881f,-23.4375f, --144.531f,34.0515f,-23.4375f, --140.625f,33.7128f,-23.4375f, --136.719f,33.2076f,-23.4375f, --132.813f,32.0419f,-23.4375f, --128.906f,31.3464f,-23.4375f, --125.0f,31.3552f,-23.4375f, --121.094f,30.6713f,-23.4375f, --117.188f,30.1403f,-23.4375f, --113.281f,30.1753f,-23.4375f, --109.375f,30.6182f,-23.4375f, --105.469f,31.2785f,-23.4375f, --101.563f,30.4839f,-23.4375f, --97.6563f,28.9907f,-23.4375f, --93.75f,29.3427f,-23.4375f, --89.8438f,29.5539f,-23.4375f, --85.9375f,29.4313f,-23.4375f, --82.0313f,28.0148f,-23.4375f, --78.125f,27.3569f,-23.4375f, --74.2188f,26.8569f,-23.4375f, --70.3125f,25.6193f,-23.4375f, --66.4063f,25.8188f,-23.4375f, --62.5f,25.458f,-23.4375f, --58.5938f,26.5128f,-23.4375f, --54.6875f,27.2598f,-23.4375f, --50.7813f,28.4912f,-23.4375f, --46.875f,31.0376f,-23.4375f, --42.9688f,33.0941f,-23.4375f, --39.0625f,34.4933f,-23.4375f, --35.1563f,37.1957f,-23.4375f, --31.25f,39.4612f,-23.4375f, --27.3438f,41.4598f,-23.4375f, --23.4375f,43.5893f,-23.4375f, --19.5313f,46.8054f,-23.4375f, --15.625f,49.4177f,-23.4375f, --11.7188f,51.7957f,-23.4375f, --7.8125f,53.1306f,-23.4375f, --3.90625f,53.4872f,-23.4375f, -0.0f,53.6348f,-23.4375f, -3.90625f,54.332f,-23.4375f, --250.0f,1.05459f,-27.3438f, --246.094f,2.15725f,-27.3438f, --242.188f,3.16747f,-27.3438f, --238.281f,4.17562f,-27.3438f, --234.375f,5.17097f,-27.3438f, --230.469f,6.61997f,-27.3438f, --226.563f,7.25727f,-27.3438f, --222.656f,9.26302f,-27.3438f, --218.75f,10.7606f,-27.3438f, --214.844f,11.6966f,-27.3438f, --210.938f,13.0425f,-27.3438f, --207.031f,15.0672f,-27.3438f, --203.125f,17.5971f,-27.3438f, --199.219f,19.3182f,-27.3438f, --195.313f,20.4505f,-27.3438f, --191.406f,20.7017f,-27.3438f, --187.5f,22.8054f,-27.3438f, --183.594f,24.7406f,-27.3438f, --179.688f,25.7957f,-27.3438f, --175.781f,28.4608f,-27.3438f, --171.875f,29.5031f,-27.3438f, --167.969f,29.8812f,-27.3438f, --164.063f,31.4954f,-27.3438f, --160.156f,32.6053f,-27.3438f, --156.25f,32.9274f,-27.3438f, --152.344f,32.6481f,-27.3438f, --148.438f,32.4456f,-27.3438f, --144.531f,32.0065f,-27.3438f, --140.625f,31.7655f,-27.3438f, --136.719f,31.6836f,-27.3438f, --132.813f,30.9994f,-27.3438f, --128.906f,30.4065f,-27.3438f, --125.0f,29.7478f,-27.3438f, --121.094f,29.3871f,-27.3438f, --117.188f,28.6628f,-27.3438f, --113.281f,28.88f,-27.3438f, --109.375f,29.3757f,-27.3438f, --105.469f,29.7372f,-27.3438f, --101.563f,28.9035f,-27.3438f, --97.6563f,29.0842f,-27.3438f, --93.75f,28.969f,-27.3438f, --89.8438f,29.282f,-27.3438f, --85.9375f,29.4429f,-27.3438f, --82.0313f,29.2385f,-27.3438f, --78.125f,28.2845f,-27.3438f, --74.2188f,26.9413f,-27.3438f, --70.3125f,26.3888f,-27.3438f, --66.4063f,26.4127f,-27.3438f, --62.5f,27.4297f,-27.3438f, --58.5938f,28.0301f,-27.3438f, --54.6875f,28.3682f,-27.3438f, --50.7813f,30.4624f,-27.3438f, --46.875f,32.6469f,-27.3438f, --42.9688f,34.7681f,-27.3438f, --39.0625f,37.3677f,-27.3438f, --35.1563f,40.0943f,-27.3438f, --31.25f,42.4424f,-27.3438f, --27.3438f,44.5954f,-27.3438f, --23.4375f,48.1538f,-27.3438f, --19.5313f,50.5809f,-27.3438f, --15.625f,52.7959f,-27.3438f, --11.7188f,53.9779f,-27.3438f, --7.8125f,55.2657f,-27.3438f, --3.90625f,55.7427f,-27.3438f, -0.0f,56.6047f,-27.3438f, -3.90625f,57.5273f,-27.3438f, --250.0f,1.91243f,-31.25f, --246.094f,1.77508f,-31.25f, --242.188f,2.89721f,-31.25f, --238.281f,4.82177f,-31.25f, --234.375f,5.57483f,-31.25f, --230.469f,6.15697f,-31.25f, --226.563f,7.43219f,-31.25f, --222.656f,9.10752f,-31.25f, --218.75f,10.7345f,-31.25f, --214.844f,11.7298f,-31.25f, --210.938f,13.0008f,-31.25f, --207.031f,14.4465f,-31.25f, --203.125f,16.7635f,-31.25f, --199.219f,18.7095f,-31.25f, --195.313f,19.057f,-31.25f, --191.406f,19.522f,-31.25f, --187.5f,21.0252f,-31.25f, --183.594f,22.477f,-31.25f, --179.688f,24.9456f,-31.25f, --175.781f,27.5579f,-31.25f, --171.875f,28.9367f,-31.25f, --167.969f,29.5938f,-31.25f, --164.063f,29.9491f,-31.25f, --160.156f,31.1043f,-31.25f, --156.25f,31.898f,-31.25f, --152.344f,32.025f,-31.25f, --148.438f,32.2848f,-31.25f, --144.531f,31.4433f,-31.25f, --140.625f,29.9423f,-31.25f, --136.719f,30.2535f,-31.25f, --132.813f,30.4668f,-31.25f, --128.906f,30.1261f,-31.25f, --125.0f,29.2612f,-31.25f, --121.094f,27.5496f,-31.25f, --117.188f,27.0659f,-31.25f, --113.281f,27.3359f,-31.25f, --109.375f,27.8418f,-31.25f, --105.469f,28.9814f,-31.25f, --101.563f,28.4429f,-31.25f, --97.6563f,28.5833f,-31.25f, --93.75f,28.9986f,-31.25f, --89.8438f,30.3273f,-31.25f, --85.9375f,30.5898f,-31.25f, --82.0313f,29.8768f,-31.25f, --78.125f,28.7278f,-31.25f, --74.2188f,28.2599f,-31.25f, --70.3125f,27.5942f,-31.25f, --66.4063f,28.2721f,-31.25f, --62.5f,28.9526f,-31.25f, --58.5938f,29.4527f,-31.25f, --54.6875f,30.1605f,-31.25f, --50.7813f,32.6242f,-31.25f, --46.875f,35.2708f,-31.25f, --42.9688f,37.6696f,-31.25f, --39.0625f,40.1477f,-31.25f, --35.1563f,42.5127f,-31.25f, --31.25f,45.655f,-31.25f, --27.3438f,48.5747f,-31.25f, --23.4375f,51.2069f,-31.25f, --19.5313f,53.5599f,-31.25f, --15.625f,55.3726f,-31.25f, --11.7188f,56.4687f,-31.25f, --7.8125f,56.313f,-31.25f, --3.90625f,58.0363f,-31.25f, -0.0f,59.422f,-31.25f, -3.90625f,59.4204f,-31.25f, --250.0f,1.80637f,-35.1563f, --246.094f,1.14243f,-35.1563f, --242.188f,2.08309f,-35.1563f, --238.281f,3.66548f,-35.1563f, --234.375f,4.49251f,-35.1563f, --230.469f,5.63985f,-35.1563f, --226.563f,7.33778f,-35.1563f, --222.656f,9.15183f,-35.1563f, --218.75f,10.0463f,-35.1563f, --214.844f,11.7521f,-35.1563f, --210.938f,12.6919f,-35.1563f, --207.031f,14.0216f,-35.1563f, --203.125f,14.9825f,-35.1563f, --199.219f,16.2286f,-35.1563f, --195.313f,17.2153f,-35.1563f, --191.406f,18.0692f,-35.1563f, --187.5f,19.858f,-35.1563f, --183.594f,22.2715f,-35.1563f, --179.688f,25.6457f,-35.1563f, --175.781f,27.6627f,-35.1563f, --171.875f,28.6491f,-35.1563f, --167.969f,29.5869f,-35.1563f, --164.063f,29.5582f,-35.1563f, --160.156f,30.7619f,-35.1563f, --156.25f,31.372f,-35.1563f, --152.344f,31.4423f,-35.1563f, --148.438f,31.7578f,-35.1563f, --144.531f,31.1339f,-35.1563f, --140.625f,29.3454f,-35.1563f, --136.719f,28.0675f,-35.1563f, --132.813f,28.1828f,-35.1563f, --128.906f,28.2649f,-35.1563f, --125.0f,27.2326f,-35.1563f, --121.094f,26.2567f,-35.1563f, --117.188f,25.4914f,-35.1563f, --113.281f,25.5444f,-35.1563f, --109.375f,25.8703f,-35.1563f, --105.469f,27.9373f,-35.1563f, --101.563f,27.9306f,-35.1563f, --97.6563f,27.9282f,-35.1563f, --93.75f,28.9199f,-35.1563f, --89.8438f,30.142f,-35.1563f, --85.9375f,30.3479f,-35.1563f, --82.0313f,29.749f,-35.1563f, --78.125f,29.2656f,-35.1563f, --74.2188f,28.8561f,-35.1563f, --70.3125f,28.7144f,-35.1563f, --66.4063f,29.3204f,-35.1563f, --62.5f,29.6751f,-35.1563f, --58.5938f,31.0647f,-35.1563f, --54.6875f,32.3243f,-35.1563f, --50.7813f,34.476f,-35.1563f, --46.875f,37.0984f,-35.1563f, --42.9688f,40.1281f,-35.1563f, --39.0625f,42.4472f,-35.1563f, --35.1563f,45.6772f,-35.1563f, --31.25f,49.5655f,-35.1563f, --27.3438f,51.5783f,-35.1563f, --23.4375f,53.3f,-35.1563f, --19.5313f,55.4127f,-35.1563f, --15.625f,56.8152f,-35.1563f, --11.7188f,56.8985f,-35.1563f, --7.8125f,57.5886f,-35.1563f, --3.90625f,58.9321f,-35.1563f, -0.0f,60.2297f,-35.1563f, -3.90625f,60.2212f,-35.1563f, --250.0f,2.59935f,-39.0625f, --246.094f,1.55278f,-39.0625f, --242.188f,1.42243f,-39.0625f, --238.281f,2.78238f,-39.0625f, --234.375f,3.85918f,-39.0625f, --230.469f,5.01321f,-39.0625f, --226.563f,6.56707f,-39.0625f, --222.656f,7.99762f,-39.0625f, --218.75f,9.72642f,-39.0625f, --214.844f,11.975f,-39.0625f, --210.938f,12.8008f,-39.0625f, --207.031f,13.6902f,-39.0625f, --203.125f,14.2017f,-39.0625f, --199.219f,14.8784f,-39.0625f, --195.313f,16.6265f,-39.0625f, --191.406f,17.066f,-39.0625f, --187.5f,19.3153f,-39.0625f, --183.594f,23.4017f,-39.0625f, --179.688f,26.2073f,-39.0625f, --175.781f,27.92f,-39.0625f, --171.875f,29.0435f,-39.0625f, --167.969f,28.8537f,-39.0625f, --164.063f,29.6445f,-39.0625f, --160.156f,30.2119f,-39.0625f, --156.25f,30.4693f,-39.0625f, --152.344f,30.6063f,-39.0625f, --148.438f,30.8716f,-39.0625f, --144.531f,30.3253f,-39.0625f, --140.625f,29.3941f,-39.0625f, --136.719f,27.7606f,-39.0625f, --132.813f,26.806f,-39.0625f, --128.906f,26.6501f,-39.0625f, --125.0f,25.6992f,-39.0625f, --121.094f,24.4674f,-39.0625f, --117.188f,24.1124f,-39.0625f, --113.281f,24.9142f,-39.0625f, --109.375f,25.5696f,-39.0625f, --105.469f,25.4691f,-39.0625f, --101.563f,26.7147f,-39.0625f, --97.6563f,26.7558f,-39.0625f, --93.75f,27.9278f,-39.0625f, --89.8438f,29.0149f,-39.0625f, --85.9375f,29.3557f,-39.0625f, --82.0313f,29.6134f,-39.0625f, --78.125f,29.4742f,-39.0625f, --74.2188f,29.3377f,-39.0625f, --70.3125f,29.6082f,-39.0625f, --66.4063f,29.4634f,-39.0625f, --62.5f,31.1775f,-39.0625f, --58.5938f,32.7227f,-39.0625f, --54.6875f,34.2233f,-39.0625f, --50.7813f,36.1862f,-39.0625f, --46.875f,38.7123f,-39.0625f, --42.9688f,41.2396f,-39.0625f, --39.0625f,44.5857f,-39.0625f, --35.1563f,47.0183f,-39.0625f, --31.25f,50.9933f,-39.0625f, --27.3438f,53.2967f,-39.0625f, --23.4375f,55.2026f,-39.0625f, --19.5313f,56.3858f,-39.0625f, --15.625f,57.8615f,-39.0625f, --11.7188f,57.7515f,-39.0625f, --7.8125f,58.8071f,-39.0625f, --3.90625f,59.73f,-39.0625f, -0.0f,59.8999f,-39.0625f, -3.90625f,59.9094f,-39.0625f, --250.0f,2.73015f,-42.9688f, --246.094f,1.9296f,-42.9688f, --242.188f,2.00835f,-42.9688f, --238.281f,3.16245f,-42.9688f, --234.375f,3.35198f,-42.9688f, --230.469f,4.50732f,-42.9688f, --226.563f,6.28971f,-42.9688f, --222.656f,7.89723f,-42.9688f, --218.75f,9.28447f,-42.9688f, --214.844f,11.4302f,-42.9688f, --210.938f,12.7156f,-42.9688f, --207.031f,13.6281f,-42.9688f, --203.125f,14.5932f,-42.9688f, --199.219f,14.8129f,-42.9688f, --195.313f,15.7965f,-42.9688f, --191.406f,16.3571f,-42.9688f, --187.5f,20.257f,-42.9688f, --183.594f,23.2993f,-42.9688f, --179.688f,25.4583f,-42.9688f, --175.781f,27.2887f,-42.9688f, --171.875f,27.9862f,-42.9688f, --167.969f,28.274f,-42.9688f, --164.063f,28.9264f,-42.9688f, --160.156f,29.1855f,-42.9688f, --156.25f,29.8898f,-42.9688f, --152.344f,29.4922f,-42.9688f, --148.438f,29.257f,-42.9688f, --144.531f,28.9137f,-42.9688f, --140.625f,27.618f,-42.9688f, --136.719f,26.8539f,-42.9688f, --132.813f,26.2806f,-42.9688f, --128.906f,25.1378f,-42.9688f, --125.0f,24.508f,-42.9688f, --121.094f,23.8458f,-42.9688f, --117.188f,23.501f,-42.9688f, --113.281f,24.0593f,-42.9688f, --109.375f,24.1366f,-42.9688f, --105.469f,24.075f,-42.9688f, --101.563f,24.5025f,-42.9688f, --97.6563f,24.8457f,-42.9688f, --93.75f,26.5028f,-42.9688f, --89.8438f,26.9842f,-42.9688f, --85.9375f,28.5672f,-42.9688f, --82.0313f,28.9848f,-42.9688f, --78.125f,29.1484f,-42.9688f, --74.2188f,28.8735f,-42.9688f, --70.3125f,29.9085f,-42.9688f, --66.4063f,31.647f,-42.9688f, --62.5f,32.8553f,-42.9688f, --58.5938f,34.4488f,-42.9688f, --54.6875f,35.7724f,-42.9688f, --50.7813f,38.5181f,-42.9688f, --46.875f,40.619f,-42.9688f, --42.9688f,42.6158f,-42.9688f, --39.0625f,45.9557f,-42.9688f, --35.1563f,48.8071f,-42.9688f, --31.25f,51.5425f,-42.9688f, --27.3438f,54.1461f,-42.9688f, --23.4375f,56.6935f,-42.9688f, --19.5313f,57.353f,-42.9688f, --15.625f,58.289f,-42.9688f, --11.7188f,58.4633f,-42.9688f, --7.8125f,59.0033f,-42.9688f, --3.90625f,59.61f,-42.9688f, -0.0f,59.6115f,-42.9688f, -3.90625f,59.5207f,-42.9688f, --250.0f,2.05499f,-46.875f, --246.094f,1.44228f,-46.875f, --242.188f,1.95946f,-46.875f, --238.281f,2.50642f,-46.875f, --234.375f,3.23732f,-46.875f, --230.469f,4.46051f,-46.875f, --226.563f,6.17815f,-46.875f, --222.656f,7.58101f,-46.875f, --218.75f,9.4063f,-46.875f, --214.844f,11.394f,-46.875f, --210.938f,12.4493f,-46.875f, --207.031f,13.1281f,-46.875f, --203.125f,13.8316f,-46.875f, --199.219f,14.1574f,-46.875f, --195.313f,15.0289f,-46.875f, --191.406f,17.2095f,-46.875f, --187.5f,20.3326f,-46.875f, --183.594f,22.5046f,-46.875f, --179.688f,24.7998f,-46.875f, --175.781f,26.3728f,-46.875f, --171.875f,27.3394f,-46.875f, --167.969f,27.2989f,-46.875f, --164.063f,27.5191f,-46.875f, --160.156f,28.1581f,-46.875f, --156.25f,28.357f,-46.875f, --152.344f,27.2465f,-46.875f, --148.438f,27.6591f,-46.875f, --144.531f,26.7196f,-46.875f, --140.625f,25.3776f,-46.875f, --136.719f,25.1174f,-46.875f, --132.813f,24.6913f,-46.875f, --128.906f,23.828f,-46.875f, --125.0f,22.7885f,-46.875f, --121.094f,23.6316f,-46.875f, --117.188f,23.288f,-46.875f, --113.281f,22.8849f,-46.875f, --109.375f,22.6367f,-46.875f, --105.469f,22.2282f,-46.875f, --101.563f,22.7539f,-46.875f, --97.6563f,23.4319f,-46.875f, --93.75f,25.0494f,-46.875f, --89.8438f,25.7759f,-46.875f, --85.9375f,27.2287f,-46.875f, --82.0313f,28.1554f,-46.875f, --78.125f,28.6794f,-46.875f, --74.2188f,30.4763f,-46.875f, --70.3125f,32.23f,-46.875f, --66.4063f,33.6868f,-46.875f, --62.5f,34.7841f,-46.875f, --58.5938f,36.2585f,-46.875f, --54.6875f,38.2534f,-46.875f, --50.7813f,39.5261f,-46.875f, --46.875f,41.7676f,-46.875f, --42.9688f,44.8849f,-46.875f, --39.0625f,47.6394f,-46.875f, --35.1563f,49.5783f,-46.875f, --31.25f,52.3871f,-46.875f, --27.3438f,54.9333f,-46.875f, --23.4375f,56.6705f,-46.875f, --19.5313f,56.898f,-46.875f, --15.625f,58.678f,-46.875f, --11.7188f,59.6595f,-46.875f, --7.8125f,59.0163f,-46.875f, --3.90625f,59.3587f,-46.875f, -0.0f,58.5405f,-46.875f, -3.90625f,58.9086f,-46.875f, --250.0f,2.57742f,-50.7813f, --246.094f,2.06275f,-50.7813f, --242.188f,2.26453f,-50.7813f, --238.281f,2.43527f,-50.7813f, --234.375f,2.63858f,-50.7813f, --230.469f,4.44964f,-50.7813f, --226.563f,6.50192f,-50.7813f, --222.656f,8.11006f,-50.7813f, --218.75f,10.1023f,-50.7813f, --214.844f,11.3708f,-50.7813f, --210.938f,12.7395f,-50.7813f, --207.031f,13.6541f,-50.7813f, --203.125f,13.6317f,-50.7813f, --199.219f,13.4823f,-50.7813f, --195.313f,15.3032f,-50.7813f, --191.406f,17.5085f,-50.7813f, --187.5f,19.5731f,-50.7813f, --183.594f,22.0894f,-50.7813f, --179.688f,23.8927f,-50.7813f, --175.781f,24.9335f,-50.7813f, --171.875f,26.1125f,-50.7813f, --167.969f,25.9034f,-50.7813f, --164.063f,26.9549f,-50.7813f, --160.156f,26.7939f,-50.7813f, --156.25f,26.3447f,-50.7813f, --152.344f,25.6085f,-50.7813f, --148.438f,25.2823f,-50.7813f, --144.531f,25.4854f,-50.7813f, --140.625f,23.906f,-50.7813f, --136.719f,23.7094f,-50.7813f, --132.813f,22.9599f,-50.7813f, --128.906f,22.3089f,-50.7813f, --125.0f,22.302f,-50.7813f, --121.094f,23.3289f,-50.7813f, --117.188f,23.1804f,-50.7813f, --113.281f,22.6693f,-50.7813f, --109.375f,21.2587f,-50.7813f, --105.469f,20.4638f,-50.7813f, --101.563f,21.4819f,-50.7813f, --97.6563f,22.0137f,-50.7813f, --93.75f,23.4763f,-50.7813f, --89.8438f,25.2125f,-50.7813f, --85.9375f,26.446f,-50.7813f, --82.0313f,27.5614f,-50.7813f, --78.125f,29.5641f,-50.7813f, --74.2188f,31.1552f,-50.7813f, --70.3125f,33.5337f,-50.7813f, --66.4063f,35.653f,-50.7813f, --62.5f,36.2419f,-50.7813f, --58.5938f,37.4297f,-50.7813f, --54.6875f,39.7492f,-50.7813f, --50.7813f,41.494f,-50.7813f, --46.875f,44.5449f,-50.7813f, --42.9688f,47.2689f,-50.7813f, --39.0625f,49.6705f,-50.7813f, --35.1563f,51.8942f,-50.7813f, --31.25f,53.9483f,-50.7813f, --27.3438f,55.2444f,-50.7813f, --23.4375f,56.5482f,-50.7813f, --19.5313f,58.5545f,-50.7813f, --15.625f,59.5559f,-50.7813f, --11.7188f,58.8699f,-50.7813f, --7.8125f,59.0373f,-50.7813f, --3.90625f,59.5884f,-50.7813f, -0.0f,59.6491f,-50.7813f, -3.90625f,59.8509f,-50.7813f, --250.0f,2.04136f,-54.6875f, --246.094f,2.5492f,-54.6875f, --242.188f,2.70952f,-54.6875f, --238.281f,3.00758f,-54.6875f, --234.375f,3.54707f,-54.6875f, --230.469f,5.09851f,-54.6875f, --226.563f,7.09409f,-54.6875f, --222.656f,8.40975f,-54.6875f, --218.75f,10.0555f,-54.6875f, --214.844f,11.4962f,-54.6875f, --210.938f,12.1806f,-54.6875f, --207.031f,12.7217f,-54.6875f, --203.125f,12.6935f,-54.6875f, --199.219f,14.0259f,-54.6875f, --195.313f,16.1147f,-54.6875f, --191.406f,18.3888f,-54.6875f, --187.5f,19.3549f,-54.6875f, --183.594f,21.6563f,-54.6875f, --179.688f,22.9906f,-54.6875f, --175.781f,23.7728f,-54.6875f, --171.875f,25.2286f,-54.6875f, --167.969f,26.0764f,-54.6875f, --164.063f,26.746f,-54.6875f, --160.156f,26.3029f,-54.6875f, --156.25f,25.6172f,-54.6875f, --152.344f,24.537f,-54.6875f, --148.438f,23.8458f,-54.6875f, --144.531f,23.3726f,-54.6875f, --140.625f,22.8694f,-54.6875f, --136.719f,22.5247f,-54.6875f, --132.813f,21.436f,-54.6875f, --128.906f,21.4712f,-54.6875f, --125.0f,22.1621f,-54.6875f, --121.094f,22.4599f,-54.6875f, --117.188f,21.4148f,-54.6875f, --113.281f,20.8237f,-54.6875f, --109.375f,19.6257f,-54.6875f, --105.469f,20.1462f,-54.6875f, --101.563f,21.5895f,-54.6875f, --97.6563f,22.2376f,-54.6875f, --93.75f,23.679f,-54.6875f, --89.8438f,24.9403f,-54.6875f, --85.9375f,26.4205f,-54.6875f, --82.0313f,27.9125f,-54.6875f, --78.125f,30.0689f,-54.6875f, --74.2188f,32.7388f,-54.6875f, --70.3125f,34.3502f,-54.6875f, --66.4063f,35.6763f,-54.6875f, --62.5f,37.4625f,-54.6875f, --58.5938f,38.3448f,-54.6875f, --54.6875f,40.6027f,-54.6875f, --50.7813f,44.4532f,-54.6875f, --46.875f,47.6182f,-54.6875f, --42.9688f,49.7683f,-54.6875f, --39.0625f,52.1875f,-54.6875f, --35.1563f,54.4951f,-54.6875f, --31.25f,55.9437f,-54.6875f, --27.3438f,57.1353f,-54.6875f, --23.4375f,58.016f,-54.6875f, --19.5313f,59.6013f,-54.6875f, --15.625f,59.9872f,-54.6875f, --11.7188f,59.8299f,-54.6875f, --7.8125f,60.1035f,-54.6875f, --3.90625f,60.8558f,-54.6875f, -0.0f,60.5619f,-54.6875f, -3.90625f,60.3928f,-54.6875f, --250.0f,4.01167f,-58.5938f, --246.094f,3.0694f,-58.5938f, --242.188f,3.37661f,-58.5938f, --238.281f,3.71931f,-58.5938f, --234.375f,4.08816f,-58.5938f, --230.469f,5.56386f,-58.5938f, --226.563f,7.3314f,-58.5938f, --222.656f,8.61323f,-58.5938f, --218.75f,9.77849f,-58.5938f, --214.844f,11.9744f,-58.5938f, --210.938f,12.9366f,-58.5938f, --207.031f,13.5175f,-58.5938f, --203.125f,13.948f,-58.5938f, --199.219f,14.4053f,-58.5938f, --195.313f,16.1496f,-58.5938f, --191.406f,17.8653f,-58.5938f, --187.5f,18.9853f,-58.5938f, --183.594f,21.2985f,-58.5938f, --179.688f,23.4932f,-58.5938f, --175.781f,25.3544f,-58.5938f, --171.875f,26.1087f,-58.5938f, --167.969f,26.5864f,-58.5938f, --164.063f,25.8729f,-58.5938f, --160.156f,25.0068f,-58.5938f, --156.25f,25.2867f,-58.5938f, --152.344f,23.9482f,-58.5938f, --148.438f,23.23f,-58.5938f, --144.531f,22.6171f,-58.5938f, --140.625f,21.4991f,-58.5938f, --136.719f,21.0822f,-58.5938f, --132.813f,21.0037f,-58.5938f, --128.906f,21.8362f,-58.5938f, --125.0f,21.5985f,-58.5938f, --121.094f,20.951f,-58.5938f, --117.188f,21.2066f,-58.5938f, --113.281f,19.7479f,-58.5938f, --109.375f,18.5787f,-58.5938f, --105.469f,20.3984f,-58.5938f, --101.563f,22.257f,-58.5938f, --97.6563f,23.3411f,-58.5938f, --93.75f,24.362f,-58.5938f, --89.8438f,25.7544f,-58.5938f, --85.9375f,27.7522f,-58.5938f, --82.0313f,28.9204f,-58.5938f, --78.125f,30.8124f,-58.5938f, --74.2188f,32.9097f,-58.5938f, --70.3125f,34.8737f,-58.5938f, --66.4063f,36.0518f,-58.5938f, --62.5f,38.506f,-58.5938f, --58.5938f,41.2951f,-58.5938f, --54.6875f,43.3387f,-58.5938f, --50.7813f,46.5457f,-58.5938f, --46.875f,49.2409f,-58.5938f, --42.9688f,51.3946f,-58.5938f, --39.0625f,54.0957f,-58.5938f, --35.1563f,55.8205f,-58.5938f, --31.25f,57.094f,-58.5938f, --27.3438f,58.0636f,-58.5938f, --23.4375f,58.8159f,-58.5938f, --19.5313f,59.9761f,-58.5938f, --15.625f,60.2094f,-58.5938f, --11.7188f,60.0275f,-58.5938f, --7.8125f,61.0991f,-58.5938f, --3.90625f,61.4786f,-58.5938f, -0.0f,61.4895f,-58.5938f, -3.90625f,61.5747f,-58.5938f, --250.0f,5.54938f,-62.5f, --246.094f,4.18374f,-62.5f, --242.188f,3.90057f,-62.5f, --238.281f,4.25951f,-62.5f, --234.375f,4.82365f,-62.5f, --230.469f,6.03197f,-62.5f, --226.563f,7.69909f,-62.5f, --222.656f,8.80826f,-62.5f, --218.75f,10.8241f,-62.5f, --214.844f,13.5771f,-62.5f, --210.938f,14.456f,-62.5f, --207.031f,15.0395f,-62.5f, --203.125f,14.5505f,-62.5f, --199.219f,16.1706f,-62.5f, --195.313f,16.9508f,-62.5f, --191.406f,18.2016f,-62.5f, --187.5f,19.8694f,-62.5f, --183.594f,22.6167f,-62.5f, --179.688f,24.5727f,-62.5f, --175.781f,26.0063f,-62.5f, --171.875f,26.0399f,-62.5f, --167.969f,26.6416f,-62.5f, --164.063f,25.6476f,-62.5f, --160.156f,24.4615f,-62.5f, --156.25f,23.5295f,-62.5f, --152.344f,23.7879f,-62.5f, --148.438f,22.8826f,-62.5f, --144.531f,21.6558f,-62.5f, --140.625f,20.6405f,-62.5f, --136.719f,20.1695f,-62.5f, --132.813f,20.7715f,-62.5f, --128.906f,20.5918f,-62.5f, --125.0f,20.4476f,-62.5f, --121.094f,19.9068f,-62.5f, --117.188f,19.4838f,-62.5f, --113.281f,17.843f,-62.5f, --109.375f,18.5661f,-62.5f, --105.469f,20.1106f,-62.5f, --101.563f,21.3182f,-62.5f, --97.6563f,23.2851f,-62.5f, --93.75f,24.3601f,-62.5f, --89.8438f,26.3742f,-62.5f, --85.9375f,27.7409f,-62.5f, --82.0313f,29.533f,-62.5f, --78.125f,31.5622f,-62.5f, --74.2188f,33.2773f,-62.5f, --70.3125f,35.6025f,-62.5f, --66.4063f,38.4255f,-62.5f, --62.5f,40.916f,-62.5f, --58.5938f,43.9378f,-62.5f, --54.6875f,45.9116f,-62.5f, --50.7813f,48.3177f,-62.5f, --46.875f,50.1977f,-62.5f, --42.9688f,52.4552f,-62.5f, --39.0625f,54.6779f,-62.5f, --35.1563f,56.1564f,-62.5f, --31.25f,57.5665f,-62.5f, --27.3438f,58.7762f,-62.5f, --23.4375f,59.115f,-62.5f, --19.5313f,58.5535f,-62.5f, --15.625f,58.2117f,-62.5f, --11.7188f,59.0863f,-62.5f, --7.8125f,60.3775f,-62.5f, --3.90625f,61.0192f,-62.5f, -0.0f,61.864f,-62.5f, -3.90625f,62.1111f,-62.5f, --250.0f,6.08003f,-66.4063f, --246.094f,5.13458f,-66.4063f, --242.188f,5.0967f,-66.4063f, --238.281f,5.36926f,-66.4063f, --234.375f,5.21926f,-66.4063f, --230.469f,6.37997f,-66.4063f, --226.563f,7.85032f,-66.4063f, --222.656f,9.36117f,-66.4063f, --218.75f,11.896f,-66.4063f, --214.844f,13.9549f,-66.4063f, --210.938f,15.4673f,-66.4063f, --207.031f,15.9885f,-66.4063f, --203.125f,16.4425f,-66.4063f, --199.219f,17.4253f,-66.4063f, --195.313f,18.1385f,-66.4063f, --191.406f,18.8676f,-66.4063f, --187.5f,20.1316f,-66.4063f, --183.594f,22.8534f,-66.4063f, --179.688f,24.5364f,-66.4063f, --175.781f,25.6234f,-66.4063f, --171.875f,25.9362f,-66.4063f, --167.969f,25.7735f,-66.4063f, --164.063f,25.1524f,-66.4063f, --160.156f,24.4245f,-66.4063f, --156.25f,22.8769f,-66.4063f, --152.344f,22.8762f,-66.4063f, --148.438f,21.9008f,-66.4063f, --144.531f,20.9242f,-66.4063f, --140.625f,20.1022f,-66.4063f, --136.719f,19.5823f,-66.4063f, --132.813f,19.4415f,-66.4063f, --128.906f,18.9513f,-66.4063f, --125.0f,18.9264f,-66.4063f, --121.094f,18.6878f,-66.4063f, --117.188f,17.8998f,-66.4063f, --113.281f,17.9815f,-66.4063f, --109.375f,18.2652f,-66.4063f, --105.469f,19.533f,-66.4063f, --101.563f,21.0045f,-66.4063f, --97.6563f,22.2461f,-66.4063f, --93.75f,23.7189f,-66.4063f, --89.8438f,25.574f,-66.4063f, --85.9375f,27.55f,-66.4063f, --82.0313f,29.733f,-66.4063f, --78.125f,31.0763f,-66.4063f, --74.2188f,33.9607f,-66.4063f, --70.3125f,37.3595f,-66.4063f, --66.4063f,41.019f,-66.4063f, --62.5f,43.7286f,-66.4063f, --58.5938f,46.5077f,-66.4063f, --54.6875f,47.985f,-66.4063f, --50.7813f,49.2623f,-66.4063f, --46.875f,50.9465f,-66.4063f, --42.9688f,52.912f,-66.4063f, --39.0625f,55.0349f,-66.4063f, --35.1563f,56.428f,-66.4063f, --31.25f,57.3951f,-66.4063f, --27.3438f,58.5332f,-66.4063f, --23.4375f,58.3328f,-66.4063f, --19.5313f,56.9549f,-66.4063f, --15.625f,56.9387f,-66.4063f, --11.7188f,58.3656f,-66.4063f, --7.8125f,59.6577f,-66.4063f, --3.90625f,59.8566f,-66.4063f, -0.0f,60.693f,-66.4063f, -3.90625f,60.8569f,-66.4063f, --250.0f,6.38861f,-70.3125f, --246.094f,6.37976f,-70.3125f, --242.188f,6.52455f,-70.3125f, --238.281f,6.93657f,-70.3125f, --234.375f,6.77321f,-70.3125f, --230.469f,7.26034f,-70.3125f, --226.563f,8.99316f,-70.3125f, --222.656f,10.5015f,-70.3125f, --218.75f,11.631f,-70.3125f, --214.844f,14.0548f,-70.3125f, --210.938f,15.9163f,-70.3125f, --207.031f,16.6824f,-70.3125f, --203.125f,17.1063f,-70.3125f, --199.219f,18.066f,-70.3125f, --195.313f,18.5539f,-70.3125f, --191.406f,18.8425f,-70.3125f, --187.5f,20.7731f,-70.3125f, --183.594f,22.8929f,-70.3125f, --179.688f,24.2011f,-70.3125f, --175.781f,24.5512f,-70.3125f, --171.875f,24.651f,-70.3125f, --167.969f,23.9906f,-70.3125f, --164.063f,23.6279f,-70.3125f, --160.156f,23.6162f,-70.3125f, --156.25f,22.3196f,-70.3125f, --152.344f,22.173f,-70.3125f, --148.438f,20.6833f,-70.3125f, --144.531f,19.6848f,-70.3125f, --140.625f,18.4633f,-70.3125f, --136.719f,18.2692f,-70.3125f, --132.813f,18.0595f,-70.3125f, --128.906f,17.2062f,-70.3125f, --125.0f,17.0103f,-70.3125f, --121.094f,17.1584f,-70.3125f, --117.188f,17.5441f,-70.3125f, --113.281f,17.5669f,-70.3125f, --109.375f,17.7536f,-70.3125f, --105.469f,18.3913f,-70.3125f, --101.563f,19.7264f,-70.3125f, --97.6563f,20.8943f,-70.3125f, --93.75f,22.7517f,-70.3125f, --89.8438f,25.1479f,-70.3125f, --85.9375f,27.3953f,-70.3125f, --82.0313f,29.5127f,-70.3125f, --78.125f,31.2816f,-70.3125f, --74.2188f,34.6589f,-70.3125f, --70.3125f,38.2161f,-70.3125f, --66.4063f,42.3872f,-70.3125f, --62.5f,45.4363f,-70.3125f, --58.5938f,47.0181f,-70.3125f, --54.6875f,48.7348f,-70.3125f, --50.7813f,49.8739f,-70.3125f, --46.875f,51.2434f,-70.3125f, --42.9688f,52.9444f,-70.3125f, --39.0625f,54.8413f,-70.3125f, --35.1563f,55.8776f,-70.3125f, --31.25f,56.9088f,-70.3125f, --27.3438f,56.8827f,-70.3125f, --23.4375f,56.1649f,-70.3125f, --19.5313f,54.9828f,-70.3125f, --15.625f,56.5543f,-70.3125f, --11.7188f,58.0071f,-70.3125f, --7.8125f,58.1204f,-70.3125f, --3.90625f,58.8019f,-70.3125f, -0.0f,59.3765f,-70.3125f, -3.90625f,59.1482f,-70.3125f, --250.0f,7.29753f,-74.2188f, --246.094f,6.9318f,-74.2188f, --242.188f,7.9493f,-74.2188f, --238.281f,7.61482f,-74.2188f, --234.375f,8.38948f,-74.2188f, --230.469f,8.85034f,-74.2188f, --226.563f,10.783f,-74.2188f, --222.656f,12.203f,-74.2188f, --218.75f,12.7122f,-74.2188f, --214.844f,14.2813f,-74.2188f, --210.938f,16.1159f,-74.2188f, --207.031f,16.8501f,-74.2188f, --203.125f,17.728f,-74.2188f, --199.219f,18.6948f,-74.2188f, --195.313f,19.0254f,-74.2188f, --191.406f,18.9874f,-74.2188f, --187.5f,20.7575f,-74.2188f, --183.594f,22.4682f,-74.2188f, --179.688f,23.785f,-74.2188f, --175.781f,23.136f,-74.2188f, --171.875f,22.2872f,-74.2188f, --167.969f,21.9381f,-74.2188f, --164.063f,22.818f,-74.2188f, --160.156f,21.8019f,-74.2188f, --156.25f,21.3496f,-74.2188f, --152.344f,19.9092f,-74.2188f, --148.438f,19.5338f,-74.2188f, --144.531f,19.2227f,-74.2188f, --140.625f,17.2583f,-74.2188f, --136.719f,15.7727f,-74.2188f, --132.813f,15.2069f,-74.2188f, --128.906f,15.0929f,-74.2188f, --125.0f,15.3066f,-74.2188f, --121.094f,15.1161f,-74.2188f, --117.188f,16.1171f,-74.2188f, --113.281f,17.2851f,-74.2188f, --109.375f,16.8359f,-74.2188f, --105.469f,17.6612f,-74.2188f, --101.563f,18.1651f,-74.2188f, --97.6563f,18.9354f,-74.2188f, --93.75f,21.1152f,-74.2188f, --89.8438f,23.9267f,-74.2188f, --85.9375f,26.5361f,-74.2188f, --82.0313f,29.6007f,-74.2188f, --78.125f,31.8355f,-74.2188f, --74.2188f,34.5711f,-74.2188f, --70.3125f,37.6211f,-74.2188f, --66.4063f,41.978f,-74.2188f, --62.5f,44.757f,-74.2188f, --58.5938f,47.2561f,-74.2188f, --54.6875f,48.796f,-74.2188f, --50.7813f,50.085f,-74.2188f, --46.875f,51.427f,-74.2188f, --42.9688f,52.9103f,-74.2188f, --39.0625f,53.6345f,-74.2188f, --35.1563f,55.5589f,-74.2188f, --31.25f,56.4557f,-74.2188f, --27.3438f,55.8259f,-74.2188f, --23.4375f,55.2472f,-74.2188f, --19.5313f,54.9161f,-74.2188f, --15.625f,56.2403f,-74.2188f, --11.7188f,57.7266f,-74.2188f, --7.8125f,57.6855f,-74.2188f, --3.90625f,57.4796f,-74.2188f, -0.0f,56.3955f,-74.2188f, -3.90625f,56.5167f,-74.2188f, --250.0f,8.88618f,-78.125f, --246.094f,8.31776f,-78.125f, --242.188f,8.67289f,-78.125f, --238.281f,9.52219f,-78.125f, --234.375f,9.78196f,-78.125f, --230.469f,11.3032f,-78.125f, --226.563f,13.1558f,-78.125f, --222.656f,14.4361f,-78.125f, --218.75f,15.5721f,-78.125f, --214.844f,14.3491f,-78.125f, --210.938f,15.6393f,-78.125f, --207.031f,16.9133f,-78.125f, --203.125f,18.1402f,-78.125f, --199.219f,19.179f,-78.125f, --195.313f,18.9448f,-78.125f, --191.406f,19.5289f,-78.125f, --187.5f,20.8547f,-78.125f, --183.594f,22.7611f,-78.125f, --179.688f,22.8314f,-78.125f, --175.781f,21.815f,-78.125f, --171.875f,22.2112f,-78.125f, --167.969f,21.9322f,-78.125f, --164.063f,21.3024f,-78.125f, --160.156f,20.354f,-78.125f, --156.25f,19.8588f,-78.125f, --152.344f,17.8458f,-78.125f, --148.438f,18.0613f,-78.125f, --144.531f,17.0664f,-78.125f, --140.625f,16.2256f,-78.125f, --136.719f,14.3082f,-78.125f, --132.813f,13.3463f,-78.125f, --128.906f,14.3881f,-78.125f, --125.0f,14.6865f,-78.125f, --121.094f,14.2011f,-78.125f, --117.188f,15.4562f,-78.125f, --113.281f,16.6171f,-78.125f, --109.375f,16.2869f,-78.125f, --105.469f,15.9406f,-78.125f, --101.563f,17.5579f,-78.125f, --97.6563f,19.157f,-78.125f, --93.75f,21.0678f,-78.125f, --89.8438f,23.1633f,-78.125f, --85.9375f,25.2991f,-78.125f, --82.0313f,28.9462f,-78.125f, --78.125f,31.8594f,-78.125f, --74.2188f,35.2294f,-78.125f, --70.3125f,36.9557f,-78.125f, --66.4063f,40.692f,-78.125f, --62.5f,44.5904f,-78.125f, --58.5938f,46.9805f,-78.125f, --54.6875f,48.3073f,-78.125f, --50.7813f,49.8001f,-78.125f, --46.875f,51.4881f,-78.125f, --42.9688f,52.7488f,-78.125f, --39.0625f,53.0994f,-78.125f, --35.1563f,54.6505f,-78.125f, --31.25f,55.3393f,-78.125f, --27.3438f,55.3608f,-78.125f, --23.4375f,54.3833f,-78.125f, --19.5313f,53.9595f,-78.125f, --15.625f,55.0695f,-78.125f, --11.7188f,56.423f,-78.125f, --7.8125f,56.1568f,-78.125f, --3.90625f,56.2841f,-78.125f, -0.0f,54.7508f,-78.125f, -3.90625f,54.4402f,-78.125f, --250.0f,10.7839f,-82.0313f, --246.094f,10.1255f,-82.0313f, --242.188f,10.6621f,-82.0313f, --238.281f,11.4172f,-82.0313f, --234.375f,12.3063f,-82.0313f, --230.469f,13.4915f,-82.0313f, --226.563f,14.9113f,-82.0313f, --222.656f,16.5463f,-82.0313f, --218.75f,17.3752f,-82.0313f, --214.844f,16.6701f,-82.0313f, --210.938f,15.5847f,-82.0313f, --207.031f,16.6988f,-82.0313f, --203.125f,17.6449f,-82.0313f, --199.219f,18.4976f,-82.0313f, --195.313f,18.033f,-82.0313f, --191.406f,19.1758f,-82.0313f, --187.5f,20.7116f,-82.0313f, --183.594f,21.5492f,-82.0313f, --179.688f,20.7908f,-82.0313f, --175.781f,20.6891f,-82.0313f, --171.875f,21.6368f,-82.0313f, --167.969f,21.6862f,-82.0313f, --164.063f,20.4236f,-82.0313f, --160.156f,19.4449f,-82.0313f, --156.25f,17.8718f,-82.0313f, --152.344f,16.0984f,-82.0313f, --148.438f,16.1225f,-82.0313f, --144.531f,15.3001f,-82.0313f, --140.625f,14.0113f,-82.0313f, --136.719f,12.7128f,-82.0313f, --132.813f,13.1695f,-82.0313f, --128.906f,14.1608f,-82.0313f, --125.0f,14.006f,-82.0313f, --121.094f,13.5671f,-82.0313f, --117.188f,14.799f,-82.0313f, --113.281f,15.6819f,-82.0313f, --109.375f,15.1047f,-82.0313f, --105.469f,15.4826f,-82.0313f, --101.563f,17.2178f,-82.0313f, --97.6563f,19.1794f,-82.0313f, --93.75f,21.3021f,-82.0313f, --89.8438f,21.9981f,-82.0313f, --85.9375f,24.4031f,-82.0313f, --82.0313f,28.8062f,-82.0313f, --78.125f,31.7576f,-82.0313f, --74.2188f,34.6198f,-82.0313f, --70.3125f,37.0145f,-82.0313f, --66.4063f,39.5952f,-82.0313f, --62.5f,43.4294f,-82.0313f, --58.5938f,45.9611f,-82.0313f, --54.6875f,47.398f,-82.0313f, --50.7813f,49.5672f,-82.0313f, --46.875f,51.4863f,-82.0313f, --42.9688f,52.3277f,-82.0313f, --39.0625f,52.6736f,-82.0313f, --35.1563f,53.5554f,-82.0313f, --31.25f,54.4611f,-82.0313f, --27.3438f,53.3151f,-82.0313f, --23.4375f,52.9631f,-82.0313f, --19.5313f,52.3147f,-82.0313f, --15.625f,53.7891f,-82.0313f, --11.7188f,54.3962f,-82.0313f, --7.8125f,54.2326f,-82.0313f, --3.90625f,53.6717f,-82.0313f, -0.0f,52.8681f,-82.0313f, -3.90625f,51.949f,-82.0313f, --250.0f,12.2756f,-85.9375f, --246.094f,11.9011f,-85.9375f, --242.188f,13.4495f,-85.9375f, --238.281f,14.3858f,-85.9375f, --234.375f,14.855f,-85.9375f, --230.469f,15.3384f,-85.9375f, --226.563f,17.3357f,-85.9375f, --222.656f,18.7108f,-85.9375f, --218.75f,18.0095f,-85.9375f, --214.844f,17.4308f,-85.9375f, --210.938f,17.0565f,-85.9375f, --207.031f,16.4039f,-85.9375f, --203.125f,17.3449f,-85.9375f, --199.219f,17.5816f,-85.9375f, --195.313f,17.7511f,-85.9375f, --191.406f,18.792f,-85.9375f, --187.5f,19.7983f,-85.9375f, --183.594f,19.6069f,-85.9375f, --179.688f,19.1396f,-85.9375f, --175.781f,19.0184f,-85.9375f, --171.875f,19.7492f,-85.9375f, --167.969f,19.6428f,-85.9375f, --164.063f,18.6091f,-85.9375f, --160.156f,18.1998f,-85.9375f, --156.25f,16.6809f,-85.9375f, --152.344f,15.0269f,-85.9375f, --148.438f,13.3773f,-85.9375f, --144.531f,12.7371f,-85.9375f, --140.625f,12.2537f,-85.9375f, --136.719f,12.6536f,-85.9375f, --132.813f,12.7798f,-85.9375f, --128.906f,13.2089f,-85.9375f, --125.0f,12.8356f,-85.9375f, --121.094f,12.5484f,-85.9375f, --117.188f,13.5275f,-85.9375f, --113.281f,13.5387f,-85.9375f, --109.375f,13.6111f,-85.9375f, --105.469f,14.7023f,-85.9375f, --101.563f,16.6526f,-85.9375f, --97.6563f,17.9729f,-85.9375f, --93.75f,19.8258f,-85.9375f, --89.8438f,21.7903f,-85.9375f, --85.9375f,23.4003f,-85.9375f, --82.0313f,27.4381f,-85.9375f, --78.125f,30.1644f,-85.9375f, --74.2188f,33.7682f,-85.9375f, --70.3125f,36.1779f,-85.9375f, --66.4063f,38.1368f,-85.9375f, --62.5f,41.5768f,-85.9375f, --58.5938f,43.7832f,-85.9375f, --54.6875f,45.866f,-85.9375f, --50.7813f,48.5751f,-85.9375f, --46.875f,50.4188f,-85.9375f, --42.9688f,51.0239f,-85.9375f, --39.0625f,51.2389f,-85.9375f, --35.1563f,51.8865f,-85.9375f, --31.25f,52.9036f,-85.9375f, --27.3438f,52.5405f,-85.9375f, --23.4375f,52.3296f,-85.9375f, --19.5313f,52.5889f,-85.9375f, --15.625f,52.3033f,-85.9375f, --11.7188f,52.1239f,-85.9375f, --7.8125f,52.0608f,-85.9375f, --3.90625f,51.0213f,-85.9375f, -0.0f,50.5601f,-85.9375f, -3.90625f,50.007f,-85.9375f, --250.0f,13.6424f,-89.8438f, --246.094f,14.2919f,-89.8438f, --242.188f,15.9647f,-89.8438f, --238.281f,17.1274f,-89.8438f, --234.375f,17.9206f,-89.8438f, --230.469f,17.9917f,-89.8438f, --226.563f,19.3423f,-89.8438f, --222.656f,20.1401f,-89.8438f, --218.75f,19.295f,-89.8438f, --214.844f,18.1101f,-89.8438f, --210.938f,17.3485f,-89.8438f, --207.031f,17.1077f,-89.8438f, --203.125f,17.7413f,-89.8438f, --199.219f,17.2325f,-89.8438f, --195.313f,17.6696f,-89.8438f, --191.406f,18.8437f,-89.8438f, --187.5f,19.1808f,-89.8438f, --183.594f,18.6366f,-89.8438f, --179.688f,17.3251f,-89.8438f, --175.781f,17.5752f,-89.8438f, --171.875f,18.1005f,-89.8438f, --167.969f,18.0907f,-89.8438f, --164.063f,16.519f,-89.8438f, --160.156f,15.5225f,-89.8438f, --156.25f,14.3937f,-89.8438f, --152.344f,13.4199f,-89.8438f, --148.438f,12.8584f,-89.8438f, --144.531f,12.8604f,-89.8438f, --140.625f,12.2817f,-89.8438f, --136.719f,12.4113f,-89.8438f, --132.813f,12.9949f,-89.8438f, --128.906f,11.9716f,-89.8438f, --125.0f,11.8348f,-89.8438f, --121.094f,12.2532f,-89.8438f, --117.188f,12.5983f,-89.8438f, --113.281f,13.2095f,-89.8438f, --109.375f,13.7209f,-89.8438f, --105.469f,13.8655f,-89.8438f, --101.563f,14.8679f,-89.8438f, --97.6563f,16.1039f,-89.8438f, --93.75f,17.9997f,-89.8438f, --89.8438f,20.0247f,-89.8438f, --85.9375f,22.8012f,-89.8438f, --82.0313f,25.8255f,-89.8438f, --78.125f,29.0288f,-89.8438f, --74.2188f,31.8325f,-89.8438f, --70.3125f,34.2688f,-89.8438f, --66.4063f,37.2576f,-89.8438f, --62.5f,40.8036f,-89.8438f, --58.5938f,43.0354f,-89.8438f, --54.6875f,44.5176f,-89.8438f, --50.7813f,47.4827f,-89.8438f, --46.875f,48.9307f,-89.8438f, --42.9688f,48.82f,-89.8438f, --39.0625f,48.8887f,-89.8438f, --35.1563f,50.05f,-89.8438f, --31.25f,50.9253f,-89.8438f, --27.3438f,52.3859f,-89.8438f, --23.4375f,52.2702f,-89.8438f, --19.5313f,52.0708f,-89.8438f, --15.625f,51.2832f,-89.8438f, --11.7188f,50.0989f,-89.8438f, --7.8125f,49.6111f,-89.8438f, --3.90625f,48.7785f,-89.8438f, -0.0f,48.7183f,-89.8438f, -3.90625f,47.6596f,-89.8438f, --250.0f,15.247f,-93.75f, --246.094f,17.6018f,-93.75f, --242.188f,19.2494f,-93.75f, --238.281f,20.8362f,-93.75f, --234.375f,20.4345f,-93.75f, --230.469f,21.1572f,-93.75f, --226.563f,21.3131f,-93.75f, --222.656f,20.8797f,-93.75f, --218.75f,20.5347f,-93.75f, --214.844f,19.3559f,-93.75f, --210.938f,18.2443f,-93.75f, --207.031f,17.5994f,-93.75f, --203.125f,18.0336f,-93.75f, --199.219f,18.0561f,-93.75f, --195.313f,17.673f,-93.75f, --191.406f,18.7132f,-93.75f, --187.5f,18.4272f,-93.75f, --183.594f,18.078f,-93.75f, --179.688f,16.7984f,-93.75f, --175.781f,16.1827f,-93.75f, --171.875f,16.5937f,-93.75f, --167.969f,16.0698f,-93.75f, --164.063f,14.9813f,-93.75f, --160.156f,13.1718f,-93.75f, --156.25f,12.1738f,-93.75f, --152.344f,12.229f,-93.75f, --148.438f,12.2803f,-93.75f, --144.531f,12.526f,-93.75f, --140.625f,11.9028f,-93.75f, --136.719f,12.3491f,-93.75f, --132.813f,11.7412f,-93.75f, --128.906f,11.5455f,-93.75f, --125.0f,11.6285f,-93.75f, --121.094f,11.478f,-93.75f, --117.188f,11.536f,-93.75f, --113.281f,11.8722f,-93.75f, --109.375f,12.61f,-93.75f, --105.469f,12.6899f,-93.75f, --101.563f,13.1659f,-93.75f, --97.6563f,14.5994f,-93.75f, --93.75f,16.6015f,-93.75f, --89.8438f,19.9429f,-93.75f, --85.9375f,22.8876f,-93.75f, --82.0313f,26.3209f,-93.75f, --78.125f,28.8526f,-93.75f, --74.2188f,30.2969f,-93.75f, --70.3125f,33.1597f,-93.75f, --66.4063f,36.2648f,-93.75f, --62.5f,39.1918f,-93.75f, --58.5938f,41.4171f,-93.75f, --54.6875f,43.4299f,-93.75f, --50.7813f,45.5438f,-93.75f, --46.875f,46.6281f,-93.75f, --42.9688f,46.784f,-93.75f, --39.0625f,47.3415f,-93.75f, --35.1563f,48.5539f,-93.75f, --31.25f,50.5714f,-93.75f, --27.3438f,51.0532f,-93.75f, --23.4375f,51.7685f,-93.75f, --19.5313f,51.3638f,-93.75f, --15.625f,49.6289f,-93.75f, --11.7188f,50.0322f,-93.75f, --7.8125f,48.6289f,-93.75f, --3.90625f,46.7733f,-93.75f, -0.0f,45.5993f,-93.75f, -3.90625f,45.4182f,-93.75f, --250.0f,18.5038f,-97.6563f, --246.094f,20.1199f,-97.6563f, --242.188f,22.7365f,-97.6563f, --238.281f,24.311f,-97.6563f, --234.375f,24.2572f,-97.6563f, --230.469f,24.3322f,-97.6563f, --226.563f,24.3501f,-97.6563f, --222.656f,23.3494f,-97.6563f, --218.75f,21.7677f,-97.6563f, --214.844f,20.6573f,-97.6563f, --210.938f,18.8509f,-97.6563f, --207.031f,18.1355f,-97.6563f, --203.125f,18.5785f,-97.6563f, --199.219f,18.2049f,-97.6563f, --195.313f,17.4136f,-97.6563f, --191.406f,18.6105f,-97.6563f, --187.5f,18.0859f,-97.6563f, --183.594f,17.3286f,-97.6563f, --179.688f,16.66f,-97.6563f, --175.781f,15.1619f,-97.6563f, --171.875f,14.271f,-97.6563f, --167.969f,13.4801f,-97.6563f, --164.063f,12.6373f,-97.6563f, --160.156f,11.4464f,-97.6563f, --156.25f,11.5423f,-97.6563f, --152.344f,11.795f,-97.6563f, --148.438f,10.9108f,-97.6563f, --144.531f,11.2217f,-97.6563f, --140.625f,11.0533f,-97.6563f, --136.719f,11.5512f,-97.6563f, --132.813f,11.6628f,-97.6563f, --128.906f,10.9589f,-97.6563f, --125.0f,10.3779f,-97.6563f, --121.094f,9.96294f,-97.6563f, --117.188f,10.6728f,-97.6563f, --113.281f,11.2587f,-97.6563f, --109.375f,11.2512f,-97.6563f, --105.469f,12.1215f,-97.6563f, --101.563f,12.0908f,-97.6563f, --97.6563f,13.5835f,-97.6563f, --93.75f,16.6536f,-97.6563f, --89.8438f,19.7104f,-97.6563f, --85.9375f,22.8325f,-97.6563f, --82.0313f,26.7422f,-97.6563f, --78.125f,29.4762f,-97.6563f, --74.2188f,30.148f,-97.6563f, --70.3125f,33.5961f,-97.6563f, --66.4063f,36.1685f,-97.6563f, --62.5f,37.3648f,-97.6563f, --58.5938f,39.4445f,-97.6563f, --54.6875f,40.3698f,-97.6563f, --50.7813f,43.2595f,-97.6563f, --46.875f,43.8006f,-97.6563f, --42.9688f,44.8371f,-97.6563f, --39.0625f,46.8993f,-97.6563f, --35.1563f,48.8152f,-97.6563f, --31.25f,50.2801f,-97.6563f, --27.3438f,49.7242f,-97.6563f, --23.4375f,49.8502f,-97.6563f, --19.5313f,49.8568f,-97.6563f, --15.625f,48.3267f,-97.6563f, --11.7188f,47.8521f,-97.6563f, --7.8125f,47.3364f,-97.6563f, --3.90625f,46.156f,-97.6563f, -0.0f,44.8966f,-97.6563f, -3.90625f,44.9637f,-97.6563f, --250.0f,21.0334f,-101.563f, --246.094f,23.093f,-101.563f, --242.188f,25.4189f,-101.563f, --238.281f,27.31f,-101.563f, --234.375f,26.8223f,-101.563f, --230.469f,26.375f,-101.563f, --226.563f,26.7718f,-101.563f, --222.656f,25.3642f,-101.563f, --218.75f,23.7619f,-101.563f, --214.844f,21.4458f,-101.563f, --210.938f,19.7809f,-101.563f, --207.031f,19.054f,-101.563f, --203.125f,19.6087f,-101.563f, --199.219f,19.2503f,-101.563f, --195.313f,18.0809f,-101.563f, --191.406f,17.75f,-101.563f, --187.5f,17.1292f,-101.563f, --183.594f,16.2151f,-101.563f, --179.688f,15.8928f,-101.563f, --175.781f,14.4866f,-101.563f, --171.875f,13.9039f,-101.563f, --167.969f,12.278f,-101.563f, --164.063f,11.5804f,-101.563f, --160.156f,12.0152f,-101.563f, --156.25f,11.7113f,-101.563f, --152.344f,10.7496f,-101.563f, --148.438f,9.67121f,-101.563f, --144.531f,9.72628f,-101.563f, --140.625f,9.99849f,-101.563f, --136.719f,10.504f,-101.563f, --132.813f,11.0917f,-101.563f, --128.906f,10.4997f,-101.563f, --125.0f,9.12306f,-101.563f, --121.094f,8.34841f,-101.563f, --117.188f,8.92074f,-101.563f, --113.281f,9.44857f,-101.563f, --109.375f,10.5456f,-101.563f, --105.469f,10.7435f,-101.563f, --101.563f,11.6413f,-101.563f, --97.6563f,14.2233f,-101.563f, --93.75f,17.0641f,-101.563f, --89.8438f,20.5963f,-101.563f, --85.9375f,22.9601f,-101.563f, --82.0313f,26.0881f,-101.563f, --78.125f,28.3451f,-101.563f, --74.2188f,30.4473f,-101.563f, --70.3125f,33.7644f,-101.563f, --66.4063f,36.3074f,-101.563f, --62.5f,38.0683f,-101.563f, --58.5938f,39.1597f,-101.563f, --54.6875f,40.3396f,-101.563f, --50.7813f,41.4946f,-101.563f, --46.875f,43.0029f,-101.563f, --42.9688f,44.8434f,-101.563f, --39.0625f,47.2094f,-101.563f, --35.1563f,47.3449f,-101.563f, --31.25f,49.1989f,-101.563f, --27.3438f,48.845f,-101.563f, --23.4375f,47.635f,-101.563f, --19.5313f,47.9355f,-101.563f, --15.625f,47.1439f,-101.563f, --11.7188f,45.929f,-101.563f, --7.8125f,46.9058f,-101.563f, --3.90625f,46.1235f,-101.563f, -0.0f,45.2655f,-101.563f, -3.90625f,44.5311f,-101.563f, --250.0f,24.0006f,-105.469f, --246.094f,26.733f,-105.469f, --242.188f,28.4305f,-105.469f, --238.281f,29.0431f,-105.469f, --234.375f,28.1582f,-105.469f, --230.469f,28.0178f,-105.469f, --226.563f,27.4417f,-105.469f, --222.656f,27.0081f,-105.469f, --218.75f,24.9646f,-105.469f, --214.844f,22.8713f,-105.469f, --210.938f,21.4507f,-105.469f, --207.031f,21.2058f,-105.469f, --203.125f,20.8114f,-105.469f, --199.219f,20.7281f,-105.469f, --195.313f,19.7358f,-105.469f, --191.406f,18.4733f,-105.469f, --187.5f,17.1875f,-105.469f, --183.594f,15.4383f,-105.469f, --179.688f,14.151f,-105.469f, --175.781f,13.882f,-105.469f, --171.875f,12.9008f,-105.469f, --167.969f,11.246f,-105.469f, --164.063f,11.1287f,-105.469f, --160.156f,10.748f,-105.469f, --156.25f,11.5003f,-105.469f, --152.344f,10.3683f,-105.469f, --148.438f,9.87346f,-105.469f, --144.531f,9.6524f,-105.469f, --140.625f,8.36957f,-105.469f, --136.719f,9.12242f,-105.469f, --132.813f,9.41585f,-105.469f, --128.906f,8.97735f,-105.469f, --125.0f,7.89593f,-105.469f, --121.094f,7.20155f,-105.469f, --117.188f,6.63681f,-105.469f, --113.281f,8.27572f,-105.469f, --109.375f,8.39126f,-105.469f, --105.469f,9.69363f,-105.469f, --101.563f,12.2269f,-105.469f, --97.6563f,15.3785f,-105.469f, --93.75f,18.1643f,-105.469f, --89.8438f,20.8715f,-105.469f, --85.9375f,23.5096f,-105.469f, --82.0313f,25.2072f,-105.469f, --78.125f,27.8536f,-105.469f, --74.2188f,30.8436f,-105.469f, --70.3125f,33.8966f,-105.469f, --66.4063f,36.3107f,-105.469f, --62.5f,37.9291f,-105.469f, --58.5938f,39.7963f,-105.469f, --54.6875f,40.5554f,-105.469f, --50.7813f,42.1374f,-105.469f, --46.875f,42.7622f,-105.469f, --42.9688f,44.5703f,-105.469f, --39.0625f,46.4665f,-105.469f, --35.1563f,46.6101f,-105.469f, --31.25f,47.1188f,-105.469f, --27.3438f,48.052f,-105.469f, --23.4375f,47.7845f,-105.469f, --19.5313f,47.8159f,-105.469f, --15.625f,46.7772f,-105.469f, --11.7188f,46.0033f,-105.469f, --7.8125f,47.2861f,-105.469f, --3.90625f,46.9832f,-105.469f, -0.0f,45.6472f,-105.469f, -3.90625f,44.8466f,-105.469f, --250.0f,27.0053f,-109.375f, --246.094f,28.4873f,-109.375f, --242.188f,29.8219f,-109.375f, --238.281f,30.0561f,-109.375f, --234.375f,29.2892f,-109.375f, --230.469f,29.5933f,-109.375f, --226.563f,28.8697f,-109.375f, --222.656f,27.4881f,-109.375f, --218.75f,25.7165f,-109.375f, --214.844f,23.9985f,-109.375f, --210.938f,23.3958f,-109.375f, --207.031f,23.3567f,-109.375f, --203.125f,23.3311f,-109.375f, --199.219f,22.2114f,-109.375f, --195.313f,21.0452f,-109.375f, --191.406f,20.2153f,-109.375f, --187.5f,18.8202f,-109.375f, --183.594f,16.7998f,-109.375f, --179.688f,15.8942f,-109.375f, --175.781f,14.8638f,-109.375f, --171.875f,13.1475f,-109.375f, --167.969f,12.7375f,-109.375f, --164.063f,10.7456f,-109.375f, --160.156f,10.2908f,-109.375f, --156.25f,9.65347f,-109.375f, --152.344f,10.1273f,-109.375f, --148.438f,9.91826f,-109.375f, --144.531f,8.92229f,-109.375f, --140.625f,8.34112f,-109.375f, --136.719f,7.82043f,-109.375f, --132.813f,7.17703f,-109.375f, --128.906f,7.28288f,-109.375f, --125.0f,6.94364f,-109.375f, --121.094f,6.57742f,-109.375f, --117.188f,5.68794f,-109.375f, --113.281f,5.66654f,-109.375f, --109.375f,6.9457f,-109.375f, --105.469f,9.81036f,-109.375f, --101.563f,12.6651f,-109.375f, --97.6563f,15.2246f,-109.375f, --93.75f,18.3914f,-109.375f, --89.8438f,21.0454f,-109.375f, --85.9375f,23.3579f,-109.375f, --82.0313f,25.0292f,-109.375f, --78.125f,28.9637f,-109.375f, --74.2188f,31.9858f,-109.375f, --70.3125f,34.5815f,-109.375f, --66.4063f,37.1495f,-109.375f, --62.5f,38.5371f,-109.375f, --58.5938f,39.6993f,-109.375f, --54.6875f,41.3314f,-109.375f, --50.7813f,42.3279f,-109.375f, --46.875f,43.399f,-109.375f, --42.9688f,44.8971f,-109.375f, --39.0625f,46.4515f,-109.375f, --35.1563f,46.6684f,-109.375f, --31.25f,47.2696f,-109.375f, --27.3438f,48.2082f,-109.375f, --23.4375f,47.2707f,-109.375f, --19.5313f,47.952f,-109.375f, --15.625f,47.4088f,-109.375f, --11.7188f,47.3981f,-109.375f, --7.8125f,48.0766f,-109.375f, --3.90625f,47.4974f,-109.375f, -0.0f,46.1817f,-109.375f, -3.90625f,45.3987f,-109.375f, --250.0f,28.5243f,-113.281f, --246.094f,30.3032f,-113.281f, --242.188f,31.2443f,-113.281f, --238.281f,30.733f,-113.281f, --234.375f,31.2433f,-113.281f, --230.469f,31.5829f,-113.281f, --226.563f,30.3008f,-113.281f, --222.656f,28.2348f,-113.281f, --218.75f,25.8116f,-113.281f, --214.844f,25.3702f,-113.281f, --210.938f,24.8435f,-113.281f, --207.031f,25.7524f,-113.281f, --203.125f,26.0021f,-113.281f, --199.219f,24.9024f,-113.281f, --195.313f,23.7348f,-113.281f, --191.406f,21.9608f,-113.281f, --187.5f,20.2108f,-113.281f, --183.594f,18.963f,-113.281f, --179.688f,17.7929f,-113.281f, --175.781f,16.3625f,-113.281f, --171.875f,14.6525f,-113.281f, --167.969f,13.4453f,-113.281f, --164.063f,11.5352f,-113.281f, --160.156f,10.457f,-113.281f, --156.25f,9.86849f,-113.281f, --152.344f,9.76379f,-113.281f, --148.438f,9.40799f,-113.281f, --144.531f,8.38098f,-113.281f, --140.625f,8.03078f,-113.281f, --136.719f,7.4536f,-113.281f, --132.813f,6.32375f,-113.281f, --128.906f,5.90846f,-113.281f, --125.0f,5.44126f,-113.281f, --121.094f,5.53385f,-113.281f, --117.188f,5.35081f,-113.281f, --113.281f,6.14244f,-113.281f, --109.375f,7.72509f,-113.281f, --105.469f,9.98969f,-113.281f, --101.563f,12.8924f,-113.281f, --97.6563f,15.6605f,-113.281f, --93.75f,18.4427f,-113.281f, --89.8438f,20.4633f,-113.281f, --85.9375f,22.3484f,-113.281f, --82.0313f,25.7434f,-113.281f, --78.125f,29.5649f,-113.281f, --74.2188f,32.7377f,-113.281f, --70.3125f,34.4529f,-113.281f, --66.4063f,37.0096f,-113.281f, --62.5f,38.2565f,-113.281f, --58.5938f,39.8951f,-113.281f, --54.6875f,41.291f,-113.281f, --50.7813f,42.6018f,-113.281f, --46.875f,43.3624f,-113.281f, --42.9688f,44.3449f,-113.281f, --39.0625f,45.4446f,-113.281f, --35.1563f,46.0157f,-113.281f, --31.25f,47.6632f,-113.281f, --27.3438f,47.6934f,-113.281f, --23.4375f,46.4824f,-113.281f, --19.5313f,48.2708f,-113.281f, --15.625f,48.5036f,-113.281f, --11.7188f,47.6795f,-113.281f, --7.8125f,48.4742f,-113.281f, --3.90625f,48.509f,-113.281f, -0.0f,47.4037f,-113.281f, -3.90625f,47.4869f,-113.281f, --250.0f,30.7007f,-117.188f, --246.094f,31.6625f,-117.188f, --242.188f,31.8246f,-117.188f, --238.281f,32.4951f,-117.188f, --234.375f,33.3552f,-117.188f, --230.469f,32.7471f,-117.188f, --226.563f,30.8092f,-117.188f, --222.656f,28.3135f,-117.188f, --218.75f,27.0912f,-117.188f, --214.844f,27.0184f,-117.188f, --210.938f,27.5702f,-117.188f, --207.031f,27.9311f,-117.188f, --203.125f,28.0909f,-117.188f, --199.219f,26.6916f,-117.188f, --195.313f,25.6983f,-117.188f, --191.406f,24.0617f,-117.188f, --187.5f,22.1476f,-117.188f, --183.594f,20.964f,-117.188f, --179.688f,19.1417f,-117.188f, --175.781f,18.0941f,-117.188f, --171.875f,16.3483f,-117.188f, --167.969f,13.8969f,-117.188f, --164.063f,12.2065f,-117.188f, --160.156f,10.4346f,-117.188f, --156.25f,9.28283f,-117.188f, --152.344f,8.20933f,-117.188f, --148.438f,7.69157f,-117.188f, --144.531f,7.05251f,-117.188f, --140.625f,6.38685f,-117.188f, --136.719f,5.88862f,-117.188f, --132.813f,4.48007f,-117.188f, --128.906f,4.03049f,-117.188f, --125.0f,4.96603f,-117.188f, --121.094f,6.08105f,-117.188f, --117.188f,6.76315f,-117.188f, --113.281f,7.41087f,-117.188f, --109.375f,7.5353f,-117.188f, --105.469f,9.88018f,-117.188f, --101.563f,11.8887f,-117.188f, --97.6563f,14.4702f,-117.188f, --93.75f,17.2187f,-117.188f, --89.8438f,20.2241f,-117.188f, --85.9375f,22.2766f,-117.188f, --82.0313f,25.968f,-117.188f, --78.125f,29.2923f,-117.188f, --74.2188f,31.9825f,-117.188f, --70.3125f,34.0756f,-117.188f, --66.4063f,35.9202f,-117.188f, --62.5f,37.9131f,-117.188f, --58.5938f,39.2288f,-117.188f, --54.6875f,40.591f,-117.188f, --50.7813f,42.5191f,-117.188f, --46.875f,42.7237f,-117.188f, --42.9688f,43.8388f,-117.188f, --39.0625f,45.2151f,-117.188f, --35.1563f,45.096f,-117.188f, --31.25f,45.9904f,-117.188f, --27.3438f,45.2594f,-117.188f, --23.4375f,45.7333f,-117.188f, --19.5313f,47.4248f,-117.188f, --15.625f,48.122f,-117.188f, --11.7188f,48.0312f,-117.188f, --7.8125f,49.0431f,-117.188f, --3.90625f,49.2804f,-117.188f, -0.0f,48.803f,-117.188f, -3.90625f,48.3887f,-117.188f, --250.0f,31.7497f,-121.094f, --246.094f,31.3973f,-121.094f, --242.188f,32.0742f,-121.094f, --238.281f,33.1521f,-121.094f, --234.375f,33.6068f,-121.094f, --230.469f,31.9815f,-121.094f, --226.563f,30.2957f,-121.094f, --222.656f,28.5699f,-121.094f, --218.75f,28.3353f,-121.094f, --214.844f,28.8422f,-121.094f, --210.938f,29.4292f,-121.094f, --207.031f,29.2833f,-121.094f, --203.125f,28.4123f,-121.094f, --199.219f,27.4455f,-121.094f, --195.313f,26.9053f,-121.094f, --191.406f,24.8164f,-121.094f, --187.5f,22.4409f,-121.094f, --183.594f,21.5447f,-121.094f, --179.688f,20.6668f,-121.094f, --175.781f,18.9757f,-121.094f, --171.875f,16.8092f,-121.094f, --167.969f,14.4997f,-121.094f, --164.063f,13.0122f,-121.094f, --160.156f,11.2904f,-121.094f, --156.25f,9.63825f,-121.094f, --152.344f,8.62771f,-121.094f, --148.438f,7.36842f,-121.094f, --144.531f,6.44275f,-121.094f, --140.625f,5.50805f,-121.094f, --136.719f,6.00349f,-121.094f, --132.813f,4.67796f,-121.094f, --128.906f,3.93081f,-121.094f, --125.0f,5.39329f,-121.094f, --121.094f,6.95361f,-121.094f, --117.188f,8.00676f,-121.094f, --113.281f,7.76936f,-121.094f, --109.375f,8.598f,-121.094f, --105.469f,9.71941f,-121.094f, --101.563f,11.4789f,-121.094f, --97.6563f,13.572f,-121.094f, --93.75f,16.0296f,-121.094f, --89.8438f,18.5079f,-121.094f, --85.9375f,22.5232f,-121.094f, --82.0313f,25.7298f,-121.094f, --78.125f,29.0421f,-121.094f, --74.2188f,31.8936f,-121.094f, --70.3125f,33.6857f,-121.094f, --66.4063f,35.8951f,-121.094f, --62.5f,37.4244f,-121.094f, --58.5938f,39.1337f,-121.094f, --54.6875f,40.6842f,-121.094f, --50.7813f,41.8829f,-121.094f, --46.875f,42.9851f,-121.094f, --42.9688f,42.3613f,-121.094f, --39.0625f,44.0627f,-121.094f, --35.1563f,43.3741f,-121.094f, --31.25f,43.2393f,-121.094f, --27.3438f,44.1982f,-121.094f, --23.4375f,45.2747f,-121.094f, --19.5313f,46.6461f,-121.094f, --15.625f,47.338f,-121.094f, --11.7188f,48.1318f,-121.094f, --7.8125f,49.3601f,-121.094f, --3.90625f,49.6752f,-121.094f, -0.0f,49.3611f,-121.094f, -3.90625f,49.6769f,-121.094f, --250.0f,31.4025f,-125.0f, --246.094f,31.4165f,-125.0f, --242.188f,32.314f,-125.0f, --238.281f,32.9822f,-125.0f, --234.375f,32.6962f,-125.0f, --230.469f,31.3632f,-125.0f, --226.563f,29.4391f,-125.0f, --222.656f,29.519f,-125.0f, --218.75f,29.4481f,-125.0f, --214.844f,29.8481f,-125.0f, --210.938f,30.408f,-125.0f, --207.031f,30.291f,-125.0f, --203.125f,28.7473f,-125.0f, --199.219f,28.1816f,-125.0f, --195.313f,27.2839f,-125.0f, --191.406f,25.7018f,-125.0f, --187.5f,23.2882f,-125.0f, --183.594f,22.1614f,-125.0f, --179.688f,20.658f,-125.0f, --175.781f,18.8433f,-125.0f, --171.875f,16.364f,-125.0f, --167.969f,14.7298f,-125.0f, --164.063f,12.9859f,-125.0f, --160.156f,11.3306f,-125.0f, --156.25f,10.1916f,-125.0f, --152.344f,8.3967f,-125.0f, --148.438f,6.23292f,-125.0f, --144.531f,5.48985f,-125.0f, --140.625f,5.18276f,-125.0f, --136.719f,5.56059f,-125.0f, --132.813f,5.75157f,-125.0f, --128.906f,5.32154f,-125.0f, --125.0f,6.15672f,-125.0f, --121.094f,7.53373f,-125.0f, --117.188f,8.38676f,-125.0f, --113.281f,8.64274f,-125.0f, --109.375f,8.49941f,-125.0f, --105.469f,9.24481f,-125.0f, --101.563f,11.5178f,-125.0f, --97.6563f,13.4113f,-125.0f, --93.75f,15.4997f,-125.0f, --89.8438f,17.3502f,-125.0f, --85.9375f,20.8168f,-125.0f, --82.0313f,24.9405f,-125.0f, --78.125f,27.8681f,-125.0f, --74.2188f,30.1495f,-125.0f, --70.3125f,32.4402f,-125.0f, --66.4063f,34.2537f,-125.0f, --62.5f,36.5623f,-125.0f, --58.5938f,38.9027f,-125.0f, --54.6875f,40.1192f,-125.0f, --50.7813f,41.9393f,-125.0f, --46.875f,41.8765f,-125.0f, --42.9688f,41.6371f,-125.0f, --39.0625f,41.6432f,-125.0f, --35.1563f,41.2852f,-125.0f, --31.25f,41.5629f,-125.0f, --27.3438f,42.2956f,-125.0f, --23.4375f,43.9719f,-125.0f, --19.5313f,46.2232f,-125.0f, --15.625f,47.3104f,-125.0f, --11.7188f,47.5943f,-125.0f, --7.8125f,49.1192f,-125.0f, --3.90625f,49.6341f,-125.0f, -0.0f,50.3481f,-125.0f, -3.90625f,50.3021f,-125.0f, -}; - -btScalar Landscape05Nml[] = { --0.379368f,0.918093f,-0.114827f, --0.372144f,0.893697f,-0.250627f, --0.36483f,0.925769f,-0.0992527f, --0.303739f,0.924201f,-0.231506f, --0.333317f,0.942796f,0.0059764f, --0.301915f,0.940094f,-0.158338f, --0.363026f,0.931698f,0.0122604f, --0.316966f,0.945703f,-0.0719588f, --0.334188f,0.941548f,0.0424963f, --0.326039f,0.944563f,-0.0387196f, --0.382515f,0.923758f,0.0188291f, --0.388659f,0.920843f,-0.0315106f, --0.393577f,0.919186f,-0.013971f, --0.384968f,0.922772f,-0.0170923f, --0.36589f,0.930393f,-0.0222354f, --0.357745f,0.933231f,0.0331438f, --0.482959f,0.873942f,-0.0545559f, --0.473203f,0.879732f,0.0463645f, --0.550088f,0.834035f,-0.0423024f, --0.534007f,0.844766f,0.0347315f, --0.469703f,0.882824f,0.000376011f, --0.490919f,0.868868f,0.0637728f, --0.552202f,0.826862f,-0.106641f, --0.558464f,0.829519f,0.00395409f, --0.437742f,0.897949f,-0.0454837f, --0.437659f,0.898576f,0.0318733f, --0.370538f,0.927929f,-0.0406078f, --0.403245f,0.912789f,-0.064878f, --0.385648f,0.921933f,-0.0362754f, --0.356223f,0.934382f,-0.00604283f, --0.30076f,0.953691f,-0.00400305f, --0.305622f,0.951852f,0.0239231f, --0.284526f,0.956527f,-0.0640436f, --0.380428f,0.91278f,-0.148684f, --0.270228f,0.949845f,-0.157392f, --0.258662f,0.947281f,-0.189085f, --0.182234f,0.978377f,-0.0978241f, --0.170558f,0.969333f,-0.176927f, --0.205282f,0.978149f,-0.0329196f, --0.190223f,0.949267f,-0.250415f, --0.274135f,0.959498f,0.0649128f, --0.310884f,0.912161f,-0.267046f, --0.496348f,0.868119f,0.00275513f, --0.43081f,0.896388f,-0.104358f, --0.405094f,0.913485f,0.0380057f, --0.324068f,0.9389f,0.115955f, --0.25697f,0.965908f,0.0314342f, --0.271227f,0.948776f,0.162051f, --0.254963f,0.963309f,-0.0838379f, --0.344475f,0.938191f,-0.03368f, --0.111765f,0.981495f,-0.15549f, --0.167507f,0.982459f,-0.0819529f, --0.0010222f,0.966945f,-0.254984f, --0.0444844f,0.98477f,-0.168075f, -0.186055f,0.950323f,-0.249537f, -0.1896f,0.965697f,-0.177427f, -0.271688f,0.939248f,-0.209761f, -0.279232f,0.936599f,-0.211687f, -0.322549f,0.939459f,-0.115666f, -0.354799f,0.922502f,-0.152013f, -0.252542f,0.965579f,-0.0622893f, -0.223889f,0.935481f,-0.273404f, -0.054661f,0.998373f,-0.0162575f, -0.0861707f,0.972348f,-0.217056f, -0.0124775f,0.999913f,-0.00421609f, -0.0330599f,0.976575f,-0.212621f, -0.0918366f,0.994675f,0.046771f, -0.166973f,0.980978f,-0.0990035f, -0.0387017f,0.993028f,0.111346f, -0.125297f,0.990619f,0.054541f, -0.0541059f,0.984899f,0.164456f, -0.149711f,0.968151f,0.200673f, -0.168008f,0.956272f,0.239411f, -0.195367f,0.93223f,0.304595f, -0.147118f,0.96491f,0.217497f, -0.125818f,0.960755f,0.247225f, -0.270517f,0.934497f,0.23138f, -0.29818f,0.904256f,0.305629f, -0.363841f,0.900609f,0.237745f, -0.316827f,0.923009f,0.218347f, -0.413166f,0.893779f,0.17451f, -0.334815f,0.940911f,0.0508378f, -0.474676f,0.869519f,0.136452f, -0.456974f,0.889396f,0.0122055f, -0.272216f,0.960219f,0.0622813f, -0.228855f,0.962963f,-0.142573f, -0.0810211f,0.995842f,0.0416494f, -0.189938f,0.980101f,0.0576713f, --0.0449078f,0.994712f,0.0923629f, --0.00155869f,0.98749f,0.157671f, --0.0840704f,0.991095f,0.103263f, --0.0968834f,0.985327f,0.140515f, -0.0427121f,0.991995f,0.118832f, --0.0240058f,0.999711f,0.000939081f, --0.124569f,0.986858f,0.10293f, --0.167243f,0.982306f,-0.0842863f, --0.286295f,0.953093f,0.0982316f, --0.243406f,0.969914f,-0.00444377f, --0.280466f,0.950626f,0.132851f, --0.21091f,0.972115f,0.102516f, --0.230061f,0.951476f,0.204368f, --0.123921f,0.950092f,0.286301f, --0.126792f,0.952499f,0.276893f, --0.0764868f,0.927481f,0.365962f, --0.0452811f,0.949055f,0.31184f, --0.138647f,0.960819f,0.240008f, --0.25036f,0.943892f,0.215377f, --0.314158f,0.941939f,0.118561f, --0.458647f,0.872527f,0.168342f, --0.427047f,0.882261f,0.198106f, --0.485467f,0.864542f,0.129958f, --0.523912f,0.844181f,0.113461f, --0.532843f,0.842328f,0.081008f, --0.518838f,0.84918f,0.0984888f, --0.439028f,0.883929f,0.16101f, --0.409166f,0.878784f,0.245606f, --0.386543f,0.918859f,0.0792661f, --0.447749f,0.88853f,0.100178f, --0.431191f,0.90206f,0.0190184f, --0.467639f,0.880276f,0.0801789f, --0.518882f,0.844495f,-0.132623f, --0.570181f,0.817923f,-0.076789f, --0.420368f,0.883342f,-0.207357f, --0.464447f,0.877342f,-0.120667f, --0.386958f,0.877414f,-0.283564f, --0.442101f,0.874511f,-0.199442f, --0.380012f,0.859996f,-0.340584f, --0.442865f,0.822467f,-0.356959f, --0.24551f,0.880879f,-0.404695f, --0.263304f,0.844058f,-0.467159f, --0.116714f,0.897206f,-0.425909f, --0.129252f,0.860962f,-0.491974f, --0.352237f,0.922053f,0.160457f, --0.402553f,0.906198f,0.129446f, --0.377478f,0.915341f,0.140219f, --0.336315f,0.935519f,0.10815f, --0.335675f,0.937548f,0.0912505f, --0.330532f,0.939201f,0.0930086f, --0.361761f,0.931606f,0.035208f, --0.318172f,0.947538f,0.0306247f, --0.418525f,0.907834f,-0.0259689f, --0.56364f,0.818048f,-0.114485f, --0.461029f,0.882661f,-0.0914388f, --0.472492f,0.87835f,-0.0724725f, --0.523319f,0.846244f,-0.100037f, --0.381187f,0.924062f,-0.0283799f, --0.407557f,0.911105f,-0.0615298f, --0.340677f,0.939702f,0.0299913f, --0.237849f,0.962659f,0.129291f, --0.233755f,0.968303f,0.0880164f, --0.248597f,0.967837f,0.0386268f, --0.357032f,0.933656f,0.0285478f, --0.359392f,0.919937f,0.156695f, --0.375075f,0.918577f,0.12464f, --0.326685f,0.944457f,-0.0357437f, --0.172605f,0.980131f,-0.0977257f, --0.156177f,0.9732f,-0.168789f, --0.0732432f,0.97238f,-0.221612f, -0.0871915f,0.980367f,-0.176858f, -0.1118f,0.973873f,-0.197667f, -0.197176f,0.978426f,-0.0616824f, -0.202039f,0.979229f,-0.0170475f, -0.172249f,0.982761f,0.0671591f, -0.0103709f,0.995351f,0.095751f, -0.00657151f,0.996617f,0.0819183f, -0.0314022f,0.995508f,0.0893156f, -0.0387801f,0.982532f,0.182011f, -0.0412148f,0.983254f,0.177521f, -0.166642f,0.964252f,0.20603f, -0.177047f,0.971307f,0.1588f, -0.255603f,0.956785f,0.138671f, -0.338465f,0.927074f,0.161166f, -0.418264f,0.886168f,0.199401f, -0.454161f,0.868211f,0.199869f, -0.355471f,0.903694f,0.2387f, -0.136408f,0.975339f,0.173515f, --0.0223692f,0.983821f,0.177753f, --0.0947578f,0.983833f,0.151964f, --0.0484831f,0.985895f,0.16019f, --0.137652f,0.965784f,0.219802f, --0.273035f,0.949633f,0.153782f, --0.284296f,0.949219f,0.134753f, --0.233616f,0.961781f,0.142834f, --0.158293f,0.979011f,0.128376f, --0.142079f,0.977628f,0.155106f, --0.179667f,0.940095f,0.289726f, --0.385363f,0.907468f,0.167324f, --0.462662f,0.886082f,0.0283396f, --0.500483f,0.865637f,-0.0137244f, --0.459387f,0.885328f,-0.0718224f, --0.318003f,0.947491f,-0.0336944f, --0.336522f,0.937427f,-0.0893505f, --0.421711f,0.882359f,-0.208814f, --0.386976f,0.894588f,-0.223522f, --0.348564f,0.925302f,-0.149395f, --0.389936f,0.911457f,-0.131135f, --0.262418f,0.94867f,-0.17653f, --0.142966f,0.967048f,-0.210661f, --0.341303f,0.927435f,0.152892f, --0.342877f,0.929169f,0.138133f, --0.327958f,0.941991f,0.0713955f, --0.312837f,0.949244f,0.0326933f, --0.32505f,0.944749f,0.0423311f, --0.35038f,0.936272f,0.0250833f, --0.334661f,0.939274f,0.0759313f, --0.336592f,0.939816f,0.0587454f, --0.383743f,0.919849f,0.0813597f, --0.479391f,0.876726f,0.0391772f, --0.521184f,0.850742f,-0.0678625f, --0.496942f,0.867777f,0.00353465f, --0.521763f,0.848113f,-0.0920201f, --0.373289f,0.923494f,-0.0883984f, --0.40896f,0.910065f,-0.067337f, --0.458758f,0.888254f,0.0233657f, --0.335137f,0.935384f,0.112868f, --0.174079f,0.969266f,0.173839f, --0.174994f,0.976179f,0.128265f, --0.244694f,0.967717f,0.0603988f, --0.409093f,0.90433f,-0.121779f, --0.290803f,0.954139f,-0.0710763f, --0.266076f,0.946406f,-0.183082f, --0.19492f,0.966664f,-0.166031f, --0.107014f,0.989078f,-0.101359f, --0.0950037f,0.987234f,-0.127838f, --0.0081899f,0.996807f,-0.0794301f, -0.0655685f,0.997841f,0.0038314f, -0.121704f,0.991617f,0.0433953f, -0.204125f,0.978885f,0.010797f, -0.169834f,0.985465f,0.00398161f, -0.0639966f,0.99795f,0.000581677f, -0.0389498f,0.997722f,-0.0550831f, --0.00230315f,0.998522f,-0.0543072f, --0.0428959f,0.99833f,-0.0386874f, -8.35518e-005f,0.999804f,-0.0198162f, -0.12638f,0.991004f,0.0440296f, -0.219728f,0.969155f,0.111616f, -0.270292f,0.956521f,0.109589f, -0.325159f,0.942616f,0.0758083f, -0.394886f,0.91647f,0.0644013f, -0.455483f,0.885289f,0.0937962f, -0.346134f,0.927862f,0.13879f, -0.142703f,0.967217f,0.210065f, --0.0417806f,0.973195f,0.226154f, --0.0873343f,0.983405f,0.159022f, --0.027932f,0.984118f,0.175304f, --0.101812f,0.985941f,0.132496f, --0.174734f,0.983884f,0.037939f, --0.279511f,0.957793f,-0.0671252f, --0.277834f,0.959638f,-0.04362f, --0.153076f,0.986374f,0.0602763f, --0.221825f,0.968529f,0.112897f, --0.256381f,0.940693f,0.222182f, --0.236646f,0.958592f,0.158432f, --0.345917f,0.937587f,-0.0356594f, --0.417749f,0.894423f,-0.159665f, --0.456832f,0.853011f,-0.252341f, --0.379407f,0.905637f,-0.189399f, --0.328991f,0.940983f,-0.0794707f, --0.363362f,0.931271f,0.0264943f, --0.48653f,0.873119f,0.0308429f, --0.459174f,0.871133f,0.174033f, --0.359639f,0.91236f,0.1956f, --0.2127f,0.972657f,0.0932592f, --0.0697188f,0.989689f,0.12512f, --0.251887f,0.965064f,0.0721469f, --0.317161f,0.947815f,-0.0324826f, --0.311043f,0.947329f,-0.076288f, --0.343705f,0.938452f,-0.0342691f, --0.318958f,0.946045f,0.0571365f, --0.341405f,0.939767f,0.0167816f, --0.371963f,0.928183f,-0.0109617f, --0.353511f,0.935132f,0.0236193f, --0.398287f,0.910412f,0.111881f, --0.43162f,0.897024f,0.0951448f, --0.485116f,0.874338f,-0.0140269f, --0.473699f,0.879939f,-0.03627f, --0.417805f,0.900966f,-0.117046f, --0.424936f,0.889519f,-0.167884f, --0.467852f,0.878936f,-0.0926624f, --0.493825f,0.865439f,-0.0845782f, --0.351989f,0.932075f,-0.0856709f, --0.214961f,0.974111f,-0.0700008f, --0.163285f,0.986387f,-0.0194449f, --0.162841f,0.986548f,-0.0143588f, --0.285987f,0.956112f,-0.0637334f, --0.292441f,0.94548f,-0.143341f, --0.215932f,0.955314f,-0.201864f, --0.253415f,0.950159f,-0.181603f, --0.183417f,0.974504f,-0.129231f, --0.101906f,0.993299f,-0.0545242f, --0.042238f,0.99904f,-0.0116303f, -0.0329811f,0.99907f,-0.0277622f, -0.132201f,0.990073f,-0.0477429f, -0.267032f,0.963432f,-0.0221792f, -0.1278f,0.990718f,-0.0463084f, -0.0964891f,0.995299f,-0.00830296f, -0.0476853f,0.991211f,-0.123396f, --0.00640997f,0.993203f,-0.116222f, --0.0126443f,0.992773f,-0.119338f, --0.00631822f,0.992917f,-0.118638f, -0.0563885f,0.995667f,-0.073943f, -0.12664f,0.991687f,-0.022778f, -0.273262f,0.961705f,0.021246f, -0.388375f,0.920615f,-0.0403992f, -0.37695f,0.920931f,-0.0989673f, -0.400211f,0.914808f,0.0543818f, -0.279689f,0.947142f,0.15715f, -0.0626591f,0.985325f,0.158772f, -0.0197159f,0.983213f,0.181391f, -0.0112307f,0.995546f,0.0936022f, --0.0611233f,0.998037f,0.013638f, --0.0515369f,0.996025f,0.0726543f, --0.060221f,0.998076f,0.0147593f, --0.21333f,0.972986f,-0.0882534f, --0.330599f,0.94012f,-0.0829391f, --0.311254f,0.950309f,-0.00575056f, --0.324983f,0.931955f,0.160768f, --0.245964f,0.942146f,0.227736f, --0.125195f,0.981121f,0.147403f, --0.193437f,0.975595f,0.103908f, --0.319958f,0.946961f,0.029845f, --0.440983f,0.895915f,-0.0535662f, --0.477838f,0.878381f,-0.0108058f, --0.480471f,0.872693f,0.0869201f, --0.478968f,0.83494f,0.271043f, --0.490257f,0.796981f,0.352803f, --0.434277f,0.834185f,0.339909f, --0.265882f,0.929328f,0.256236f, --0.142385f,0.958793f,0.245852f, --0.182126f,0.963412f,0.196642f, --0.0681643f,0.992157f,0.104781f, --0.176883f,0.983918f,0.024857f, --0.305513f,0.952069f,-0.0150524f, --0.401485f,0.91552f,0.0251517f, --0.372509f,0.927256f,0.0378572f, --0.265017f,0.964159f,0.0127972f, --0.342134f,0.935688f,-0.0862078f, --0.427338f,0.901948f,-0.062226f, --0.447549f,0.894216f,0.00877894f, --0.382185f,0.923573f,-0.0307708f, --0.386509f,0.921774f,-0.0307138f, --0.457766f,0.884255f,-0.0924303f, --0.384262f,0.916404f,-0.11201f, --0.431623f,0.886784f,-0.165273f, --0.460575f,0.869789f,-0.177024f, --0.471547f,0.850265f,-0.233865f, --0.351048f,0.911491f,-0.214361f, --0.263539f,0.9431f,-0.202755f, --0.173283f,0.972074f,-0.158258f, --0.19847f,0.960809f,-0.193536f, --0.275034f,0.951707f,-0.136422f, --0.217032f,0.958372f,-0.185526f, --0.201987f,0.95666f,-0.209771f, --0.299318f,0.94727f,-0.114406f, --0.187056f,0.978613f,-0.0855959f, --0.155621f,0.97153f,-0.178637f, --0.0810385f,0.981009f,-0.176221f, -0.0905036f,0.986207f,-0.138581f, -0.115825f,0.982705f,-0.14448f, -0.19636f,0.97731f,-0.0794224f, -0.143519f,0.988245f,-0.0526749f, -0.109744f,0.989619f,-0.0927937f, -0.197571f,0.972036f,-0.12693f, -0.00332495f,0.962309f,-0.271939f, --0.0356976f,0.959351f,-0.279948f, --0.0721767f,0.96735f,-0.242948f, --0.00843005f,0.989549f,-0.143952f, -0.152572f,0.983317f,-0.0990425f, -0.281378f,0.943362f,-0.175768f, -0.428891f,0.891683f,-0.144753f, -0.290445f,0.954517f,-0.0673633f, -0.176401f,0.973557f,0.145155f, -0.232983f,0.924473f,0.301776f, -0.181127f,0.950255f,0.253393f, --0.00165339f,0.991402f,0.130837f, -0.0981935f,0.976268f,0.193027f, -0.000170743f,0.996657f,0.0816968f, --0.0970384f,0.995225f,-0.0105345f, --0.00895717f,0.999951f,-0.00426387f, --0.170944f,0.985202f,-0.0124686f, --0.362907f,0.93182f,-0.00317037f, --0.388121f,0.921046f,0.0322033f, --0.407598f,0.90852f,0.0919578f, --0.247403f,0.962759f,0.109032f, --0.0829823f,0.986114f,0.143848f, --0.240859f,0.956011f,0.167424f, --0.312142f,0.912012f,0.266086f, --0.398269f,0.862926f,0.311032f, --0.511957f,0.795091f,0.325161f, --0.506846f,0.755093f,0.415864f, --0.506747f,0.718735f,0.476054f, --0.45002f,0.736589f,0.504895f, --0.287855f,0.833759f,0.471153f, --0.237765f,0.90713f,0.34725f, --0.146865f,0.915961f,0.373425f, --0.0859218f,0.935714f,0.342136f, --0.054455f,0.996952f,-0.0558782f, --0.211499f,0.976662f,-0.0374149f, --0.331452f,0.940975f,0.0686022f, --0.397421f,0.917381f,0.0216451f, --0.316207f,0.946964f,-0.0572054f, --0.202804f,0.975284f,-0.0877067f, --0.28846f,0.951091f,-0.110532f, --0.440756f,0.882415f,-0.164552f, --0.391159f,0.897816f,-0.202288f, --0.37945f,0.884355f,-0.27191f, --0.436492f,0.880924f,-0.182888f, --0.458204f,0.880643f,-0.12049f, --0.365575f,0.927969f,-0.0723085f, --0.344164f,0.93545f,-0.0805227f, --0.392565f,0.898448f,-0.196683f, --0.458844f,0.839155f,-0.292028f, --0.406986f,0.873305f,-0.267769f, --0.264536f,0.933458f,-0.242234f, --0.197907f,0.946975f,-0.253123f, --0.162416f,0.964761f,-0.207018f, --0.261287f,0.932524f,-0.249254f, --0.237723f,0.937266f,-0.25499f, --0.255938f,0.959549f,-0.117312f, --0.378394f,0.921703f,-0.0853291f, --0.154569f,0.983106f,-0.098032f, -0.020864f,0.98441f,-0.174648f, --0.0493076f,0.945704f,-0.321268f, -0.00354211f,0.950539f,-0.310586f, -0.0705741f,0.962405f,-0.262289f, -0.155003f,0.952815f,-0.260992f, -0.190084f,0.945182f,-0.265518f, -0.109466f,0.94166f,-0.318268f, -0.219465f,0.948713f,-0.227551f, -0.131592f,0.95776f,-0.255694f, --0.023132f,0.936016f,-0.351196f, --0.102398f,0.923738f,-0.369083f, --0.11778f,0.928743f,-0.351518f, -0.14699f,0.959781f,-0.239196f, -0.329451f,0.917295f,-0.223678f, -0.290403f,0.942778f,-0.163815f, -0.10086f,0.993272f,0.056896f, -0.00690717f,0.980954f,0.194116f, -0.198478f,0.949829f,0.241726f, -0.257584f,0.935998f,0.239913f, -0.0870031f,0.976807f,0.195647f, -0.0578083f,0.994066f,0.0921449f, -0.121554f,0.989161f,0.0823711f, -0.0335983f,0.999242f,0.0196737f, --0.0544848f,0.997579f,-0.0432265f, --0.170331f,0.98419f,0.0485619f, --0.366378f,0.930108f,-0.0258115f, --0.430564f,0.901925f,-0.0338598f, --0.412156f,0.909498f,0.0542308f, --0.303685f,0.949097f,0.0836093f, --0.198153f,0.949404f,0.243656f, --0.267445f,0.871756f,0.410506f, --0.393769f,0.805932f,0.442062f, --0.427473f,0.750775f,0.50359f, --0.522691f,0.707231f,0.476044f, --0.550081f,0.670741f,0.497511f, --0.518356f,0.695815f,0.49714f, --0.372017f,0.764162f,0.526934f, --0.210863f,0.841692f,0.497082f, --0.116051f,0.87101f,0.477362f, --0.106872f,0.906726f,0.407954f, -0.0295506f,0.897687f,0.439643f, --0.11391f,0.993475f,0.00559176f, --0.238885f,0.970513f,0.0322297f, --0.352278f,0.935893f,0.00201985f, --0.29155f,0.955165f,-0.0515582f, --0.283012f,0.950207f,-0.130422f, --0.233718f,0.966509f,-0.105997f, --0.293314f,0.953293f,-0.0721f, --0.344057f,0.937935f,-0.0436188f, --0.359338f,0.921856f,-0.145114f, --0.361988f,0.90939f,-0.204876f, --0.478777f,0.840974f,-0.252063f, --0.501126f,0.832032f,-0.237897f, --0.42396f,0.887247f,-0.1818f, --0.340692f,0.929815f,-0.13919f, --0.261328f,0.946412f,-0.189766f, --0.383135f,0.863856f,-0.327048f, --0.4248f,0.838392f,-0.341533f, --0.258907f,0.912327f,-0.317216f, --0.273875f,0.922352f,-0.272505f, --0.216284f,0.973372f,-0.0759435f, --0.186061f,0.980681f,-0.0603919f, --0.327344f,0.93227f,-0.15401f, --0.354135f,0.933013f,-0.0638423f, --0.30838f,0.94174f,-0.13427f, --0.0952482f,0.963393f,-0.250602f, -0.0864929f,0.957116f,-0.276491f, -0.0265645f,0.947809f,-0.31773f, --0.00743162f,0.929747f,-0.368124f, -0.0794584f,0.926075f,-0.368877f, -0.177698f,0.921503f,-0.345334f, -0.210118f,0.923104f,-0.322071f, -0.0972314f,0.929984f,-0.354507f, -0.0931107f,0.932401f,-0.349226f, -0.163846f,0.947557f,-0.274392f, -0.04099f,0.947023f,-0.318539f, --0.0637185f,0.942657f,-0.327625f, --0.131539f,0.923216f,-0.361068f, -0.0323928f,0.932437f,-0.359877f, -0.242794f,0.937436f,-0.249528f, -0.154647f,0.984538f,-0.0822692f, --0.0290139f,0.999421f,0.0177744f, --0.0330797f,0.998482f,0.0440283f, -0.157195f,0.980432f,0.118503f, -0.251646f,0.94505f,0.208697f, -0.178529f,0.966849f,0.182568f, -0.171641f,0.982807f,0.0680498f, -0.107902f,0.993714f,0.0298233f, -0.00302695f,0.994036f,0.109006f, --0.0844358f,0.977656f,0.19251f, --0.18119f,0.958323f,0.220878f, --0.285317f,0.945377f,0.157659f, --0.419121f,0.895183f,0.151606f, --0.490039f,0.857134f,0.158693f, --0.402244f,0.878123f,0.259038f, --0.398659f,0.825161f,0.400226f, --0.427626f,0.728675f,0.534948f, --0.378859f,0.704334f,0.600316f, --0.386613f,0.684959f,0.617545f, --0.440363f,0.648556f,0.62085f, --0.484249f,0.659981f,0.574394f, --0.462576f,0.728741f,0.504936f, --0.380875f,0.811463f,0.443241f, --0.190303f,0.865049f,0.464193f, --0.0749094f,0.86956f,0.488113f, --0.11614f,0.868815f,0.481323f, --0.102623f,0.843113f,0.527854f, --0.198362f,0.979655f,0.0304707f, --0.238942f,0.970277f,0.0383318f, --0.308109f,0.951351f,-0.000213496f, --0.245044f,0.968893f,0.0346459f, --0.275786f,0.960816f,-0.0278198f, --0.256726f,0.965729f,-0.0381932f, --0.318964f,0.947473f,-0.0236049f, --0.388409f,0.921405f,0.0123096f, --0.298771f,0.953298f,0.0442638f, --0.291187f,0.956662f,0.00282226f, --0.39367f,0.915026f,-0.0880448f, --0.501897f,0.840236f,-0.20519f, --0.460271f,0.863055f,-0.208055f, --0.311786f,0.925724f,-0.214066f, --0.177876f,0.937081f,-0.300397f, --0.256831f,0.902901f,-0.344683f, --0.413909f,0.808626f,-0.418096f, --0.347694f,0.845102f,-0.406092f, --0.390269f,0.881564f,-0.265585f, --0.38258f,0.915768f,-0.122479f, --0.172737f,0.984864f,-0.0142896f, --0.221138f,0.97315f,-0.0638528f, --0.32806f,0.922266f,-0.204454f, --0.20334f,0.945769f,-0.253326f, --0.0362109f,0.959773f,-0.278433f, -0.0451082f,0.968522f,-0.244806f, -0.103574f,0.977375f,-0.184421f, -0.095607f,0.942862f,-0.319172f, -0.028855f,0.903939f,-0.426688f, -0.0781753f,0.937277f,-0.339707f, -0.163597f,0.966118f,-0.199631f, -0.165445f,0.973063f,-0.160553f, -0.145787f,0.95097f,-0.272767f, -0.130591f,0.92029f,-0.368799f, -0.0531207f,0.931628f,-0.35951f, --0.0802666f,0.935074f,-0.345244f, --0.124987f,0.942063f,-0.311281f, -0.0397165f,0.963525f,-0.264653f, -0.0790619f,0.96623f,-0.245254f, -0.0277086f,0.995754f,-0.0877838f, --0.0718135f,0.997414f,0.00271225f, --0.0601764f,0.993596f,0.0956336f, -0.0305316f,0.992338f,0.119724f, -0.184993f,0.96549f,0.183324f, -0.240982f,0.949316f,0.20181f, -0.205406f,0.960305f,0.188739f, -0.0685231f,0.967991f,0.241448f, --0.121139f,0.95072f,0.285408f, --0.150135f,0.918283f,0.366355f, --0.132611f,0.919499f,0.370048f, --0.285199f,0.893271f,0.34746f, --0.428415f,0.803512f,0.413316f, --0.445474f,0.783214f,0.433738f, --0.459983f,0.771026f,0.44038f, --0.467611f,0.730475f,0.497741f, --0.48066f,0.718458f,0.502777f, --0.417628f,0.706128f,0.571814f, --0.464585f,0.665035f,0.584713f, --0.472738f,0.646587f,0.598702f, --0.412146f,0.689264f,0.595861f, --0.326825f,0.752406f,0.5719f, --0.254151f,0.834713f,0.48853f, --0.235109f,0.888903f,0.39316f, --0.153581f,0.849492f,0.504753f, --0.150095f,0.815518f,0.558929f, --0.18873f,0.837012f,0.513607f, -0.0689174f,0.995773f,0.0607139f, --0.155258f,0.983404f,-0.0938683f, --0.345692f,0.927547f,-0.141961f, --0.289881f,0.953783f,-0.079168f, --0.192407f,0.979661f,-0.0569578f, --0.267677f,0.960104f,-0.0809323f, --0.338627f,0.940905f,-0.0054102f, --0.378143f,0.925406f,-0.0251327f, --0.331689f,0.941021f,-0.0667991f, --0.266964f,0.963694f,-0.00485284f, --0.326986f,0.944023f,-0.0435962f, --0.406544f,0.902607f,-0.141498f, --0.445264f,0.84532f,-0.295253f, --0.261882f,0.90946f,-0.322956f, --0.131634f,0.928868f,-0.346231f, --0.231876f,0.922232f,-0.30939f, --0.381112f,0.87967f,-0.284489f, --0.459513f,0.85999f,-0.22196f, --0.498013f,0.864257f,-0.0710131f, --0.440544f,0.89211f,-0.100303f, --0.247938f,0.96287f,-0.106806f, --0.10732f,0.992504f,-0.0584663f, --0.221465f,0.956592f,-0.189431f, --0.229248f,0.946541f,-0.22695f, --0.0978243f,0.972744f,-0.210239f, --0.0379465f,0.985853f,-0.163259f, -0.0806013f,0.992194f,-0.0951546f, -0.280296f,0.95443f,-0.102456f, -0.155799f,0.941292f,-0.299494f, --0.0466248f,0.90184f,-0.429548f, -0.0333539f,0.93989f,-0.339845f, -0.15766f,0.95203f,-0.262264f, -0.275219f,0.92494f,-0.262186f, -0.226492f,0.914035f,-0.336513f, -0.0375497f,0.921004f,-0.387739f, --0.0841489f,0.913809f,-0.39733f, --0.216548f,0.901013f,-0.375874f, --0.0617755f,0.971104f,-0.230524f, -0.0635289f,0.988552f,-0.136856f, --0.0898172f,0.987883f,-0.126568f, --0.195744f,0.9803f,-0.0263689f, --0.163398f,0.98375f,0.0744142f, -0.0549941f,0.99236f,0.110438f, -0.19398f,0.975972f,0.0992507f, -0.191759f,0.972804f,0.129928f, -0.149866f,0.963222f,0.223034f, --0.00306242f,0.957956f,0.286898f, --0.13576f,0.938575f,0.317249f, --0.176601f,0.936485f,0.303f, --0.158083f,0.914215f,0.373122f, --0.316693f,0.854194f,0.412381f, --0.498069f,0.774619f,0.389733f, --0.492142f,0.755365f,0.432688f, --0.453311f,0.739293f,0.49795f, --0.471661f,0.730931f,0.49323f, --0.504596f,0.695479f,0.511558f, --0.486075f,0.660592f,0.572145f, --0.455536f,0.681017f,0.573326f, --0.475459f,0.732851f,0.486691f, --0.40679f,0.784517f,0.468032f, --0.294511f,0.862991f,0.410499f, --0.137096f,0.926626f,0.350098f, --0.212171f,0.92693f,0.30949f, --0.320702f,0.890591f,0.322488f, --0.144781f,0.913051f,0.381284f, --0.0467088f,0.929255f,0.366475f, -0.190524f,0.979715f,0.0621193f, --0.0159571f,0.99888f,-0.0445494f, --0.299493f,0.937414f,-0.177647f, --0.30245f,0.926474f,-0.223986f, --0.236991f,0.948637f,-0.209579f, --0.316653f,0.935173f,-0.15869f, --0.385652f,0.9143f,-0.123807f, --0.33937f,0.934637f,-0.106213f, --0.347064f,0.934195f,-0.0826249f, --0.295744f,0.955249f,0.00583919f, --0.275005f,0.961059f,-0.0271544f, --0.269439f,0.957464f,-0.103275f, --0.282112f,0.919833f,-0.272616f, --0.294141f,0.877255f,-0.379347f, --0.188084f,0.929949f,-0.315942f, --0.305781f,0.908958f,-0.283361f, --0.494244f,0.854771f,-0.158396f, --0.556326f,0.828917f,0.0582992f, --0.534005f,0.83843f,0.108964f, --0.372194f,0.92607f,0.0621723f, --0.216902f,0.97615f,-0.00922891f, --0.129625f,0.988755f,-0.0745716f, --0.137022f,0.98954f,-0.0451077f, --0.210914f,0.969697f,-0.123297f, --0.0927848f,0.980946f,-0.170691f, --0.0487293f,0.98279f,-0.178186f, -0.0377154f,0.983594f,-0.176409f, -0.270827f,0.95519f,-0.119436f, -0.365037f,0.928517f,-0.0678507f, -0.131842f,0.951604f,-0.277612f, --0.0185121f,0.905238f,-0.424502f, -0.118166f,0.903064f,-0.412931f, -0.230045f,0.8849f,-0.405008f, -0.2101f,0.906634f,-0.365886f, -0.0544702f,0.94453f,-0.323878f, --0.0630069f,0.9598f,-0.273522f, --0.203027f,0.928033f,-0.312304f, --0.22235f,0.90002f,-0.374866f, -0.0164141f,0.973192f,-0.229407f, --0.131299f,0.967472f,-0.216237f, --0.248586f,0.95668f,-0.151553f, --0.180678f,0.971697f,-0.152182f, -0.021506f,0.991774f,-0.126182f, -0.129882f,0.991187f,-0.0260519f, -0.125479f,0.988703f,0.0819803f, -0.0585413f,0.987325f,0.14752f, --0.0186301f,0.977162f,0.211676f, --0.162972f,0.968132f,0.19016f, --0.218545f,0.935778f,0.276691f, --0.284144f,0.890895f,0.354356f, --0.345593f,0.839997f,0.418295f, --0.488331f,0.792258f,0.36587f, --0.545891f,0.770241f,0.329746f, --0.533891f,0.766492f,0.357002f, --0.51665f,0.749346f,0.414189f, --0.616561f,0.690345f,0.37852f, --0.519109f,0.719346f,0.461593f, --0.392236f,0.782177f,0.484097f, --0.398436f,0.817816f,0.415241f, --0.392025f,0.864189f,0.315428f, --0.176475f,0.937288f,0.300577f, --0.137444f,0.969881f,0.201097f, --0.206545f,0.942409f,0.263066f, --0.293185f,0.938992f,0.179823f, --0.159029f,0.985376f,0.0611911f, -0.00174953f,0.998094f,0.0616789f, -0.241821f,0.962041f,0.126492f, -0.127737f,0.984773f,0.117921f, --0.17559f,0.984255f,0.0202494f, --0.277772f,0.957333f,-0.0797282f, --0.264237f,0.953214f,-0.146839f, --0.330132f,0.935063f,-0.129113f, --0.363469f,0.924563f,-0.114338f, --0.371034f,0.917638f,-0.142388f, --0.425424f,0.897691f,-0.114736f, --0.353654f,0.934652f,-0.0368062f, --0.218582f,0.975792f,0.007136f, --0.203676f,0.978799f,-0.0216238f, --0.149661f,0.987587f,-0.0476727f, --0.278943f,0.945373f,-0.1687f, --0.239375f,0.951961f,-0.190969f, --0.360119f,0.921099f,-0.147955f, --0.584157f,0.811569f,0.0107674f, --0.61484f,0.786528f,0.0578414f, --0.504089f,0.86363f,-0.00605437f, --0.333455f,0.94143f,-0.0501755f, --0.123418f,0.989972f,-0.0687344f, --0.105519f,0.985418f,-0.133478f, --0.134701f,0.9843f,-0.114061f, --0.137014f,0.977235f,-0.161985f, --0.0439551f,0.980481f,-0.191638f, --0.0327274f,0.96544f,-0.258561f, -0.0268923f,0.955378f,-0.294159f, -0.189265f,0.941783f,-0.277892f, -0.306008f,0.930356f,-0.201982f, -0.2909f,0.948465f,-0.12566f, -0.135694f,0.963424f,-0.231086f, -0.114996f,0.92781f,-0.354886f, -0.243157f,0.920361f,-0.306286f, -0.181493f,0.943785f,-0.27628f, --0.0348676f,0.964621f,-0.261325f, --0.138397f,0.964431f,-0.225208f, --0.0584572f,0.973863f,-0.219483f, --0.160488f,0.904663f,-0.394751f, --0.113572f,0.901558f,-0.417487f, --0.155065f,0.923521f,-0.350803f, --0.242307f,0.919914f,-0.308295f, --0.206106f,0.923371f,-0.323891f, --0.0753677f,0.972428f,-0.220691f, -0.00286078f,0.993423f,-0.114469f, -0.0506503f,0.998257f,-0.0302924f, --0.0328546f,0.999299f,0.017926f, --0.060813f,0.979003f,0.194565f, --0.19049f,0.94338f,0.271567f, --0.332962f,0.885593f,0.323821f, --0.330466f,0.869145f,0.367938f, --0.383415f,0.840587f,0.382632f, --0.450848f,0.795155f,0.405542f, --0.50223f,0.7918f,0.347589f, --0.586371f,0.768822f,0.255112f, --0.550176f,0.765625f,0.333355f, --0.594581f,0.747662f,0.295761f, --0.604774f,0.771025f,0.199423f, --0.461798f,0.840354f,0.283809f, --0.323989f,0.875237f,0.359155f, --0.321766f,0.916629f,0.23719f, --0.168943f,0.967667f,0.187293f, --0.107108f,0.976625f,0.186366f, --0.222921f,0.963011f,0.151379f, --0.142187f,0.985732f,0.0900906f, --0.0555822f,0.997373f,-0.0464466f, --0.00128055f,0.995901f,-0.0904418f, -0.189226f,0.980362f,-0.0555288f, -0.085267f,0.996327f,-0.00782177f, --0.128918f,0.990746f,0.042464f, --0.188312f,0.982054f,-0.0104463f, --0.196136f,0.979449f,-0.0470074f, --0.346836f,0.935484f,-0.0676365f, --0.385817f,0.920741f,-0.0581445f, --0.364523f,0.930255f,-0.0418259f, --0.413227f,0.910109f,-0.0307546f, --0.395357f,0.915702f,-0.071985f, --0.249105f,0.966325f,-0.0645241f, --0.224404f,0.97132f,-0.0786097f, --0.136636f,0.989057f,-0.0556425f, --0.161967f,0.98357f,-0.0797312f, --0.264069f,0.956689f,-0.122532f, --0.415862f,0.909427f,-0.00117779f, --0.618635f,0.784039f,0.0507281f, --0.569525f,0.818988f,-0.0700017f, --0.458442f,0.876243f,-0.148424f, --0.301532f,0.936403f,-0.179521f, --0.125352f,0.969963f,-0.208469f, --0.0885456f,0.971015f,-0.222014f, --0.127345f,0.96169f,-0.242765f, --0.111865f,0.95953f,-0.258434f, --0.00408963f,0.957803f,-0.287396f, -0.0423217f,0.932535f,-0.358592f, -0.0695614f,0.921939f,-0.381037f, -0.190852f,0.890613f,-0.412775f, -0.209386f,0.879353f,-0.427663f, -0.178912f,0.925963f,-0.332541f, -0.21012f,0.943847f,-0.254954f, -0.194248f,0.92787f,-0.318316f, -0.12116f,0.941808f,-0.313556f, -0.143074f,0.982238f,-0.121399f, -0.00445755f,0.990826f,-0.135068f, --0.0763662f,0.964673f,-0.252139f, --0.00960064f,0.938734f,-0.34451f, --0.0448775f,0.923487f,-0.380997f, --0.121038f,0.899958f,-0.418839f, --0.214432f,0.896136f,-0.388536f, --0.236628f,0.909444f,-0.341933f, --0.245801f,0.902665f,-0.353239f, --0.210816f,0.938091f,-0.274848f, --0.0790665f,0.981118f,-0.17651f, --0.0418777f,0.998086f,-0.0455073f, --0.112513f,0.981903f,0.152339f, --0.289647f,0.921573f,0.258473f, --0.276284f,0.866929f,0.414851f, --0.316808f,0.857367f,0.405653f, --0.333206f,0.853137f,0.401412f, --0.396081f,0.828088f,0.396725f, --0.485909f,0.809843f,0.328705f, --0.463328f,0.813789f,0.350819f, --0.520203f,0.774122f,0.360725f, --0.581754f,0.763678f,0.279925f, --0.55781f,0.791203f,0.250691f, --0.576356f,0.800103f,0.166282f, --0.522214f,0.839566f,0.149738f, --0.327667f,0.934488f,0.139166f, --0.239893f,0.965369f,0.102537f, --0.178401f,0.973537f,0.142826f, --0.0446164f,0.980327f,0.192274f, --0.152707f,0.98769f,0.0338934f, --0.061376f,0.996098f,-0.0634113f, --0.00816896f,0.988579f,-0.150483f, -0.0167009f,0.992551f,-0.120678f, -0.148875f,0.988771f,-0.0129578f, -0.0273451f,0.999626f,0.000950796f, --0.109359f,0.99398f,0.00672756f, --0.162948f,0.982686f,-0.0881845f, --0.242271f,0.966262f,-0.0874275f, --0.357996f,0.933723f,0.000140943f, --0.377863f,0.925289f,0.0325572f, --0.389424f,0.920391f,0.0350616f, --0.408888f,0.910343f,0.0639282f, --0.371945f,0.928232f,0.00649489f, --0.230632f,0.97289f,0.0171594f, --0.159091f,0.987197f,-0.0114848f, --0.122759f,0.984183f,-0.127724f, --0.175251f,0.974473f,-0.14032f, --0.35571f,0.933079f,-0.0532364f, --0.501387f,0.863164f,0.0596562f, --0.575441f,0.816492f,-0.0470046f, --0.501056f,0.856673f,-0.122698f, --0.414992f,0.888139f,-0.19746f, --0.309585f,0.914677f,-0.259854f, --0.0986663f,0.965073f,-0.242693f, --0.0576728f,0.965088f,-0.255499f, --0.0928316f,0.963296f,-0.251879f, --0.0710107f,0.944633f,-0.320352f, -0.0799711f,0.918771f,-0.386606f, -0.0834923f,0.89273f,-0.442789f, -0.0521243f,0.897343f,-0.438246f, -0.251171f,0.890827f,-0.378604f, -0.176541f,0.892631f,-0.414781f, -0.102505f,0.91423f,-0.392015f, -0.148543f,0.910792f,-0.385219f, -0.204336f,0.92739f,-0.313361f, -0.00672261f,0.969577f,-0.244696f, --0.0203828f,0.994006f,-0.10741f, -0.0984818f,0.994155f,-0.0442492f, -0.0884297f,0.979853f,-0.179077f, -0.079756f,0.934869f,-0.345919f, --0.0373135f,0.916973f,-0.3972f, --0.13475f,0.922044f,-0.362873f, --0.248554f,0.90561f,-0.343645f, --0.298871f,0.900649f,-0.315447f, --0.245556f,0.942684f,-0.225941f, --0.29156f,0.92569f,-0.241018f, --0.210251f,0.966564f,-0.146796f, --0.258034f,0.965595f,0.0323199f, --0.368176f,0.902709f,0.22263f, --0.350064f,0.851117f,0.391223f, --0.273287f,0.858969f,0.432996f, --0.285306f,0.881397f,0.376483f, --0.391023f,0.856564f,0.336748f, --0.346592f,0.838969f,0.419529f, --0.422742f,0.829366f,0.365295f, --0.513303f,0.775065f,0.368504f, --0.526999f,0.742246f,0.413935f, --0.485934f,0.782442f,0.389426f, --0.494091f,0.808005f,0.32094f, --0.527377f,0.820007f,0.222402f, --0.463863f,0.878834f,0.111725f, --0.310302f,0.94881f,0.0589178f, --0.228025f,0.964645f,0.132153f, --0.25901f,0.96255f,0.080067f, --0.0424596f,0.997867f,0.0495831f, --0.00646979f,0.998786f,0.048831f, -0.0235108f,0.999153f,0.033786f, -0.0350773f,0.999112f,0.0233587f, --0.06489f,0.99782f,0.0120079f, -0.0653571f,0.99589f,0.0626978f, -0.0437681f,0.989758f,0.13588f, --0.0612591f,0.992124f,0.109253f, --0.0700659f,0.993846f,0.085792f, --0.245254f,0.968292f,0.0475526f, --0.425333f,0.903383f,0.0546907f, --0.406557f,0.90921f,0.0897132f, --0.40303f,0.911526f,0.0817765f, --0.380881f,0.92142f,0.0769048f, --0.320213f,0.947262f,0.0126033f, --0.2583f,0.964583f,-0.0534921f, --0.102892f,0.993091f,-0.0564197f, --0.0482689f,0.996133f,-0.0734163f, --0.214829f,0.976629f,0.00662477f, --0.431775f,0.896672f,0.0977224f, --0.451215f,0.886255f,0.104672f, --0.522087f,0.848838f,-0.0830587f, --0.458286f,0.880944f,-0.117949f, --0.338524f,0.917937f,-0.206865f, --0.285281f,0.916752f,-0.279607f, --0.142352f,0.962006f,-0.232982f, --0.0943041f,0.983891f,-0.151875f, --0.0753867f,0.988192f,-0.133394f, -0.0592214f,0.975378f,-0.212437f, -0.135178f,0.93923f,-0.315553f, -0.146098f,0.928461f,-0.34149f, -0.0154593f,0.901088f,-0.433361f, -0.163565f,0.906515f,-0.389201f, -0.204593f,0.933049f,-0.295907f, -0.124274f,0.938076f,-0.323371f, -0.137407f,0.92485f,-0.354642f, -0.063168f,0.960879f,-0.269671f, --0.0720239f,0.98835f,-0.134077f, --0.0757271f,0.981006f,-0.178587f, -0.0897227f,0.968994f,-0.23022f, -0.219073f,0.948381f,-0.229303f, -0.192275f,0.938149f,-0.287936f, --0.0492263f,0.973953f,-0.221343f, --0.181885f,0.971294f,-0.153316f, --0.242476f,0.960686f,-0.135229f, --0.363624f,0.917475f,-0.161301f, --0.330978f,0.935565f,-0.12317f, --0.30439f,0.949195f,-0.0798413f, --0.362853f,0.931339f,-0.0307322f, --0.401675f,0.903644f,0.148607f, --0.425736f,0.872787f,0.238731f, --0.458216f,0.866256f,0.199096f, --0.325646f,0.913769f,0.242862f, --0.214745f,0.922085f,0.321938f, --0.398463f,0.884492f,0.242694f, --0.475038f,0.830832f,0.289927f, --0.448294f,0.764081f,0.463909f, --0.497042f,0.7065f,0.503792f, --0.489906f,0.735868f,0.467431f, --0.460921f,0.76339f,0.452535f, --0.40897f,0.781052f,0.471913f, --0.371818f,0.839399f,0.396435f, --0.326758f,0.904742f,0.27326f, --0.383198f,0.91056f,0.155045f, --0.284609f,0.924825f,0.252383f, --0.0749114f,0.976737f,0.200932f, -0.00799324f,0.997093f,0.0757729f, --0.0700844f,0.990942f,0.114551f, --0.0596966f,0.983848f,0.168758f, -0.00586433f,0.977052f,0.212922f, --0.0605914f,0.978841f,0.195443f, --0.0438257f,0.995801f,0.0803703f, --0.0570689f,0.993344f,0.100052f, --0.0606116f,0.987839f,0.143177f, --0.0960986f,0.983658f,0.152253f, --0.240218f,0.956553f,0.16523f, --0.410215f,0.902731f,0.129617f, --0.38596f,0.917352f,0.0974681f, --0.348531f,0.935694f,0.0547901f, --0.396424f,0.918039f,-0.00721866f, --0.26358f,0.961512f,0.0775866f, --0.177577f,0.982975f,0.0471779f, --0.0921077f,0.995708f,0.00907831f, --0.131805f,0.991186f,0.0133294f, --0.348565f,0.935587f,0.0563885f, --0.467549f,0.880933f,0.0731775f, --0.372581f,0.926945f,0.0442312f, --0.408929f,0.911847f,-0.0362219f, --0.445009f,0.893478f,-0.0605312f, --0.306432f,0.951885f,-0.00384437f, --0.259351f,0.965029f,0.0381644f, --0.265204f,0.963994f,-0.0195798f, --0.114808f,0.993343f,0.00942441f, --0.0279481f,0.990324f,-0.135929f, -0.103339f,0.977655f,-0.18306f, -0.218767f,0.966894f,-0.131368f, -0.207579f,0.958824f,-0.193824f, -0.136905f,0.960239f,-0.243308f, -0.117272f,0.934734f,-0.335438f, -0.133403f,0.937193f,-0.322294f, -0.140113f,0.948531f,-0.284001f, -0.0924439f,0.975124f,-0.201463f, --0.0405443f,0.993271f,-0.108481f, --0.0729426f,0.987394f,-0.140474f, -0.0307633f,0.972795f,-0.229615f, -0.200951f,0.951021f,-0.2349f, -0.206873f,0.91785f,-0.338755f, -0.0409109f,0.957201f,-0.286518f, --0.211311f,0.976629f,-0.0392802f, --0.256735f,0.961768f,0.0953371f, --0.237528f,0.960421f,0.145504f, --0.329105f,0.937835f,0.110248f, --0.355083f,0.930437f,0.0905737f, --0.33751f,0.931415f,0.13621f, --0.400013f,0.905919f,0.138928f, --0.505595f,0.854442f,0.119596f, --0.452675f,0.873473f,0.179247f, --0.360085f,0.917004f,0.17159f, --0.404496f,0.910531f,0.0855373f, --0.324231f,0.903855f,0.279141f, --0.336075f,0.852068f,0.40129f, --0.562491f,0.75864f,0.328737f, --0.580482f,0.703244f,0.410473f, --0.499356f,0.747889f,0.437385f, --0.47057f,0.77436f,0.423001f, --0.457721f,0.780273f,0.426221f, --0.387043f,0.830428f,0.400733f, --0.304454f,0.882516f,0.358431f, --0.240482f,0.915056f,0.323791f, --0.289179f,0.919765f,0.265345f, --0.239541f,0.954664f,0.176742f, --0.0468358f,0.993768f,0.10115f, --0.0227943f,0.987776f,0.154204f, --0.112093f,0.964309f,0.239881f, --0.0599845f,0.969963f,0.235741f, -0.0387578f,0.968143f,0.24738f, -0.0187191f,0.971458f,0.236471f, -0.242021f,0.896343f,0.371478f, -0.0480335f,0.972296f,0.228765f, --0.0779729f,0.986176f,0.146206f, --0.0941394f,0.982277f,0.16208f, --0.22083f,0.962927f,0.154936f, --0.380194f,0.918443f,0.109152f, --0.362825f,0.928988f,0.0730715f, --0.322334f,0.943799f,0.0731113f, --0.408658f,0.905696f,0.112752f, --0.342623f,0.91378f,0.218209f, --0.178962f,0.947287f,0.265744f, --0.0963031f,0.962264f,0.254507f, --0.129686f,0.959928f,0.248434f, --0.25861f,0.932715f,0.251325f, --0.400538f,0.911394f,0.0944958f, --0.371118f,0.928542f,0.00899351f, --0.395096f,0.916517f,0.0624194f, --0.492959f,0.864551f,0.097688f, --0.425957f,0.892844f,0.146255f, --0.256791f,0.9425f,0.213898f, --0.177422f,0.976398f,0.123157f, -0.0269208f,0.996881f,0.0741829f, -0.164645f,0.980831f,-0.104223f, -0.0973784f,0.963273f,-0.250244f, -0.114359f,0.965463f,-0.234102f, -0.250084f,0.96398f,-0.0905583f, -0.183861f,0.973241f,-0.137829f, -0.203921f,0.957737f,-0.202868f, -0.170155f,0.95208f,-0.254149f, -0.0373443f,0.963666f,-0.264487f, --0.0311132f,0.98854f,-0.147717f, --0.0500681f,0.990616f,-0.127173f, -0.0774781f,0.980584f,-0.180143f, -0.0416659f,0.952342f,-0.302174f, -0.183971f,0.945491f,-0.268702f, -0.234504f,0.932825f,-0.27358f, --0.0611848f,0.988685f,-0.13696f, --0.37387f,0.925543f,-0.059925f, --0.361069f,0.932447f,-0.0130774f, --0.247932f,0.961796f,0.1161f, --0.321909f,0.940217f,0.111206f, --0.373794f,0.915694f,0.147587f, --0.370927f,0.915202f,0.157537f, --0.367344f,0.908177f,0.20068f, --0.445687f,0.879826f,0.165134f, --0.480845f,0.872838f,0.0833169f, --0.396228f,0.900984f,0.176722f, --0.39533f,0.870559f,0.292987f, --0.514705f,0.791717f,0.329034f, --0.426478f,0.754312f,0.49913f, --0.476928f,0.731476f,0.487321f, --0.555203f,0.748777f,0.362053f, --0.513793f,0.811828f,0.277402f, --0.498737f,0.823176f,0.271372f, --0.459197f,0.851815f,0.252089f, --0.364638f,0.907849f,0.207f, --0.280535f,0.937686f,0.205051f, --0.204645f,0.959273f,0.194721f, --0.188424f,0.978285f,0.0863425f, --0.16576f,0.97773f,-0.128717f, --0.0413953f,0.984504f,-0.170405f, --0.119175f,0.989154f,-0.0858603f, --0.164393f,0.986215f,0.018821f, --0.0876541f,0.994439f,0.0583851f, --0.00781607f,0.987179f,0.159428f, --0.00608226f,0.980142f,0.198203f, -0.294056f,0.919888f,0.259494f, -0.176099f,0.946212f,0.271426f, --0.0256669f,0.973237f,0.228366f, --0.0934761f,0.978631f,0.183149f, --0.211202f,0.968374f,0.132837f, --0.345036f,0.933287f,0.0996237f, --0.346043f,0.935088f,0.0765773f, --0.381385f,0.918419f,0.105127f, --0.476923f,0.857096f,0.19476f, --0.397907f,0.88874f,0.227622f, --0.175271f,0.936954f,0.30232f, --0.040477f,0.944541f,0.325889f, --0.142418f,0.942444f,0.302518f, --0.246569f,0.91514f,0.318938f, --0.255277f,0.933873f,0.25043f, --0.348488f,0.92941f,0.121466f, --0.472178f,0.874219f,0.113089f, --0.490306f,0.858256f,0.151645f, --0.38804f,0.914553f,0.114097f, --0.196584f,0.979051f,0.0530513f, --0.0793551f,0.996572f,-0.0234008f, -0.0406197f,0.994776f,-0.0936505f, -0.24653f,0.966821f,-0.0669378f, -0.269235f,0.959692f,-0.0806517f, -0.0569112f,0.963296f,-0.26234f, -0.131503f,0.973945f,-0.184764f, -0.24729f,0.957434f,-0.148892f, -0.248779f,0.951221f,-0.18245f, -0.18718f,0.966303f,-0.176696f, -0.00607471f,0.977895f,-0.20901f, --0.0210706f,0.975074f,-0.220878f, -0.00501251f,0.949574f,-0.313502f, -0.0771251f,0.945518f,-0.316304f, -0.130553f,0.948445f,-0.288805f, -0.175519f,0.929764f,-0.323623f, -0.111769f,0.971665f,-0.208266f, --0.210844f,0.971563f,-0.107753f, --0.345299f,0.9344f,-0.087551f, --0.367127f,0.918607f,-0.146212f, --0.340753f,0.929779f,-0.139279f, --0.358585f,0.929839f,-0.0825605f, --0.393886f,0.919008f,-0.0166963f, --0.401193f,0.915983f,0.00451588f, --0.406108f,0.91192f,0.0589777f, --0.45609f,0.887954f,0.0593294f, --0.481921f,0.86351f,0.148669f, --0.533578f,0.80576f,0.256994f, --0.480795f,0.753832f,0.447854f, --0.502576f,0.721353f,0.476516f, --0.457582f,0.746697f,0.482766f, --0.419108f,0.791496f,0.44484f, --0.465376f,0.834036f,0.296325f, --0.468919f,0.860429f,0.199442f, --0.486627f,0.858618f,0.161151f, --0.430227f,0.89524f,0.115972f, --0.34028f,0.937953f,0.066739f, --0.311486f,0.949765f,0.0303886f, --0.166884f,0.985403f,0.0336267f, -0.0381647f,0.996782f,-0.0704869f, -0.0486826f,0.951753f,-0.302979f, --0.0940893f,0.932244f,-0.349383f, --0.229015f,0.944857f,-0.234089f, --0.214421f,0.956596f,-0.19735f, --0.17466f,0.962579f,-0.207209f, --0.106663f,0.986513f,-0.124157f, --0.0523564f,0.993983f,-0.0962102f, -0.1751f,0.970986f,0.162867f, -0.126838f,0.957099f,0.260524f, --0.0248407f,0.948904f,0.314587f, --0.0169284f,0.94527f,0.325849f, --0.126002f,0.963121f,0.237743f, --0.322368f,0.933961f,0.154262f, --0.357267f,0.920847f,0.156206f, --0.40825f,0.900639f,0.148934f, --0.500408f,0.86145f,0.0865774f, --0.437173f,0.895731f,0.0809122f, --0.234862f,0.957423f,0.167871f, --0.122112f,0.971133f,0.204913f, --0.146988f,0.949325f,0.277805f, --0.214866f,0.947227f,0.237893f, --0.166781f,0.968529f,0.184757f, --0.279132f,0.953637f,0.112522f, --0.438908f,0.892826f,0.101101f, --0.476448f,0.878957f,0.0207741f, --0.317496f,0.946313f,-0.0607282f, --0.175675f,0.968847f,-0.174568f, -0.00443594f,0.981128f,-0.193308f, -0.0639918f,0.955901f,-0.286634f, -0.156615f,0.959233f,-0.235253f, -0.281138f,0.953388f,-0.109604f, -0.173642f,0.975105f,-0.137905f, -0.125725f,0.970112f,-0.207546f, -0.23259f,0.936622f,-0.261996f, -0.234534f,0.938208f,-0.25448f, -0.160485f,0.952598f,-0.258459f, -0.0824642f,0.968528f,-0.234849f, -0.0634583f,0.946763f,-0.315614f, -0.0567562f,0.917557f,-0.393532f, -0.0240187f,0.918352f,-0.395035f, -0.0995244f,0.946786f,-0.30609f, -0.0782245f,0.971194f,-0.225085f, -0.0104903f,0.995647f,-0.0926114f, --0.185802f,0.976721f,-0.107212f, --0.328502f,0.923412f,-0.198486f, --0.311331f,0.92975f,-0.196566f, --0.349149f,0.904891f,-0.24345f, --0.388436f,0.90322f,-0.182515f, --0.447323f,0.88531f,-0.126995f, --0.452109f,0.890067f,-0.0581177f, --0.409043f,0.912515f,0.000312055f, --0.489105f,0.872225f,-0.000401423f, --0.602394f,0.789815f,0.115381f, --0.644891f,0.727938f,0.232857f, --0.581256f,0.729671f,0.360168f, --0.503025f,0.763549f,0.404917f, --0.449741f,0.833702f,0.320428f, --0.320295f,0.891402f,0.320645f, --0.365897f,0.908793f,0.200535f, --0.418513f,0.900509f,0.118029f, --0.464312f,0.883882f,0.0562756f, --0.399182f,0.916811f,0.0105308f, --0.291715f,0.956056f,-0.0293054f, --0.237447f,0.965751f,-0.104617f, --0.100041f,0.966568f,-0.236091f, -0.160871f,0.934989f,-0.316096f, -0.093049f,0.931221f,-0.352375f, --0.15859f,0.964926f,-0.209204f, --0.273524f,0.944194f,-0.183526f, --0.190425f,0.948278f,-0.253984f, --0.130985f,0.95529f,-0.265074f, --0.109109f,0.943759f,-0.312112f, --0.0442587f,0.936376f,-0.348197f, -0.0244075f,0.991066f,0.131121f, --0.0145509f,0.975134f,0.221137f, --0.0404534f,0.947565f,0.316994f, --0.0554847f,0.953641f,0.295787f, --0.0378486f,0.926136f,0.375287f, --0.276884f,0.909741f,0.309364f, --0.35531f,0.878584f,0.319132f, --0.28855f,0.905318f,0.311668f, --0.418654f,0.900829f,0.115051f, --0.470621f,0.881923f,0.0269622f, --0.302456f,0.950707f,0.0683814f, --0.155931f,0.981097f,0.114601f, --0.172528f,0.971746f,0.161072f, --0.175279f,0.972437f,0.153763f, --0.0948884f,0.989506f,0.108971f, --0.271832f,0.96203f,0.0246161f, --0.434113f,0.899816f,0.0433328f, --0.41192f,0.910729f,-0.0299284f, --0.184465f,0.976107f,-0.114836f, --0.0519711f,0.950434f,-0.306552f, -0.0510061f,0.914254f,-0.401918f, -0.0714878f,0.915457f,-0.396015f, -0.0823148f,0.944294f,-0.318643f, -0.154376f,0.938672f,-0.308322f, -0.218285f,0.948145f,-0.231024f, -0.158935f,0.938404f,-0.306818f, -0.261223f,0.9329f,-0.247912f, -0.285998f,0.932056f,-0.222434f, -0.190198f,0.913869f,-0.358703f, -0.0636773f,0.892218f,-0.447094f, -0.10205f,0.889697f,-0.445f, -0.100031f,0.900986f,-0.422159f, -0.0104969f,0.905423f,-0.424381f, --0.0688464f,0.910262f,-0.408268f, --0.0482237f,0.974352f,-0.219802f, --0.0083558f,0.994225f,-0.106992f, --0.112134f,0.979056f,-0.169927f, --0.229912f,0.945374f,-0.231102f, --0.280533f,0.899591f,-0.334719f, --0.346884f,0.867971f,-0.355384f, --0.459064f,0.843199f,-0.279779f, --0.497889f,0.848119f,-0.181111f, --0.501207f,0.860371f,-0.0924901f, --0.458162f,0.888868f,-0.00122281f, --0.514613f,0.855463f,0.0579275f, --0.647763f,0.760835f,0.0391491f, --0.704753f,0.709026f,0.0246046f, --0.656653f,0.750377f,0.0757771f, --0.504188f,0.854115f,0.127601f, --0.41033f,0.905141f,0.111126f, --0.337511f,0.936543f,0.0947305f, --0.307169f,0.946112f,0.10256f, --0.367429f,0.928128f,0.0597776f, --0.393986f,0.91872f,-0.0269814f, --0.373766f,0.918684f,-0.127743f, --0.26114f,0.960116f,-0.0999132f, --0.103927f,0.984722f,-0.139723f, -0.0511518f,0.955672f,-0.289956f, -0.187205f,0.928701f,-0.320109f, --0.0295799f,0.970029f,-0.241182f, --0.314429f,0.940081f,-0.13184f, --0.185337f,0.978913f,-0.0859053f, --0.104364f,0.967564f,-0.230061f, --0.0895833f,0.932754f,-0.349206f, --0.054587f,0.891296f,-0.450124f, -0.0297567f,0.885691f,-0.463321f, -0.100841f,0.951386f,0.291024f, --0.0719364f,0.970866f,0.22857f, --0.0950354f,0.957535f,0.272204f, --0.063148f,0.9475f,0.313457f, --0.147905f,0.922206f,0.357295f, --0.255052f,0.862392f,0.437296f, --0.348295f,0.831026f,0.433689f, --0.228735f,0.861593f,0.453141f, --0.189137f,0.904176f,0.383004f, --0.40614f,0.912877f,0.041313f, --0.322035f,0.946605f,-0.0152552f, --0.213289f,0.976152f,0.0404333f, --0.216957f,0.96919f,0.116619f, --0.143471f,0.982181f,0.121395f, --0.0619809f,0.995307f,0.0743149f, --0.20303f,0.975599f,0.0835793f, --0.415979f,0.909172f,0.0191678f, --0.336954f,0.94062f,-0.0411873f, --0.0679584f,0.981162f,-0.180839f, -0.116786f,0.956914f,-0.265849f, -0.119526f,0.96094f,-0.249616f, --0.00488697f,0.95735f,-0.288889f, -0.0539017f,0.947486f,-0.315223f, -0.147321f,0.922615f,-0.35648f, -0.255572f,0.910786f,-0.324272f, -0.156463f,0.885962f,-0.436566f, -0.1301f,0.92297f,-0.362215f, -0.25276f,0.923086f,-0.289871f, -0.383737f,0.889757f,-0.247141f, -0.211205f,0.883014f,-0.419141f, -0.0342331f,0.879599f,-0.474482f, -0.00319575f,0.938694f,-0.344735f, -0.0177214f,0.953292f,-0.301529f, --0.111253f,0.93857f,-0.326663f, --0.240335f,0.933381f,-0.26653f, --0.0538188f,0.987001f,-0.151433f, --0.0274864f,0.979377f,-0.200162f, --0.187631f,0.946384f,-0.262966f, --0.206926f,0.955659f,-0.209519f, --0.334901f,0.924406f,-0.182523f, --0.500035f,0.842333f,-0.201099f, --0.536058f,0.812568f,-0.228857f, --0.57838f,0.789021f,-0.207176f, --0.551453f,0.831854f,-0.0625953f, --0.537806f,0.840551f,0.0651045f, --0.581123f,0.812541f,0.0455343f, --0.677773f,0.725811f,-0.117567f, --0.674512f,0.726391f,-0.131871f, --0.561194f,0.823313f,-0.0849523f, --0.426155f,0.904036f,-0.0333265f, --0.350057f,0.935877f,-0.0399208f, --0.324764f,0.94579f,-0.0029281f, --0.334572f,0.942069f,0.0238272f, --0.264187f,0.96401f,-0.0298196f, --0.331302f,0.926674f,-0.177522f, --0.297768f,0.937944f,-0.177749f, --0.0551409f,0.983889f,-0.170067f, -0.144484f,0.972505f,-0.182644f, -0.119335f,0.96645f,-0.227451f, --0.0885992f,0.982619f,-0.163126f, --0.33707f,0.92576f,-0.171324f, --0.162854f,0.966557f,-0.198108f, -0.0162126f,0.974218f,-0.225026f, -0.138436f,0.947057f,-0.289688f, -0.0835536f,0.876982f,-0.473204f, --0.010237f,0.848096f,-0.529743f, -0.136921f,0.906371f,0.399681f, -0.0140824f,0.922185f,0.386492f, --0.160268f,0.929321f,0.33268f, --0.112451f,0.900092f,0.420938f, --0.203296f,0.876433f,0.436504f, --0.322996f,0.829667f,0.455332f, --0.340765f,0.827757f,0.445755f, --0.257344f,0.84669f,0.465715f, -0.00366351f,0.865541f,0.500825f, --0.0425812f,0.956742f,0.287804f, --0.322344f,0.945159f,-0.052618f, --0.280797f,0.958795f,-0.0431994f, --0.262333f,0.964629f,-0.0259446f, --0.0891831f,0.995449f,-0.0335709f, --0.0801038f,0.992742f,-0.0896982f, --0.224206f,0.974484f,0.0105758f, --0.364477f,0.9309f,-0.0241328f, --0.198506f,0.970273f,-0.138443f, -0.0492304f,0.955815f,-0.289816f, -0.0465241f,0.961334f,-0.271428f, -0.0147498f,0.993644f,-0.111598f, -0.136409f,0.989222f,-0.0532271f, -0.148553f,0.957532f,-0.247113f, -0.203722f,0.927854f,-0.312384f, -0.268253f,0.883803f,-0.383317f, -0.18614f,0.887058f,-0.422469f, -0.10218f,0.907566f,-0.407286f, -0.200645f,0.878358f,-0.433854f, -0.320433f,0.870875f,-0.372692f, -0.278243f,0.911383f,-0.303252f, --0.0169368f,0.97379f,-0.226818f, --0.116502f,0.978925f,-0.16773f, -0.0246686f,0.985931f,-0.165321f, --0.099417f,0.977857f,-0.184152f, --0.275352f,0.945128f,-0.175824f, --0.0928967f,0.974055f,-0.206368f, -0.0664566f,0.97817f,-0.196893f, --0.180659f,0.959555f,-0.21591f, --0.356529f,0.924348f,-0.135896f, --0.392702f,0.919607f,0.0104344f, --0.427591f,0.903919f,-0.00980201f, --0.491673f,0.851131f,-0.183941f, --0.597871f,0.779934f,-0.185076f, --0.630214f,0.771159f,-0.0902474f, --0.603795f,0.796392f,-0.0345128f, --0.532942f,0.846043f,0.013577f, --0.560658f,0.826581f,-0.049261f, --0.693149f,0.692482f,-0.200033f, --0.591049f,0.792583f,-0.14991f, --0.423413f,0.894971f,-0.14053f, --0.360923f,0.922234f,-0.138633f, --0.376728f,0.924323f,-0.0608465f, --0.330964f,0.94352f,-0.0152562f, --0.205049f,0.976512f,-0.0661789f, --0.221147f,0.966952f,-0.126878f, --0.282753f,0.933366f,-0.221083f, --0.0599842f,0.959615f,-0.274846f, -0.119046f,0.947951f,-0.295324f, -0.164559f,0.948383f,-0.27109f, --0.0951076f,0.948417f,-0.302424f, --0.271887f,0.913351f,-0.303098f, --0.128933f,0.917201f,-0.376985f, -0.0280066f,0.909443f,-0.414885f, -0.150608f,0.898143f,-0.413106f, -0.212115f,0.88838f,-0.407172f, -0.0467869f,0.87371f,-0.484191f, -0.135605f,0.903203f,0.407228f, --0.01172f,0.896648f,0.44259f, --0.138887f,0.847422f,0.512432f, --0.170991f,0.843044f,0.50994f, --0.191878f,0.839246f,0.508772f, --0.300268f,0.838171f,0.455311f, --0.32966f,0.831286f,0.447535f, --0.223175f,0.877254f,0.424992f, --0.0256774f,0.953915f,0.298977f, -0.199545f,0.913698f,0.354031f, --0.0319727f,0.980881f,0.191963f, --0.258985f,0.964126f,-0.0582107f, --0.212788f,0.970943f,-0.109502f, --0.0721792f,0.982085f,-0.174064f, --0.0849627f,0.985898f,-0.144175f, --0.290021f,0.949136f,-0.122591f, --0.248272f,0.954348f,-0.166075f, --0.0507313f,0.942327f,-0.330828f, -0.0792104f,0.910775f,-0.405234f, --0.0679775f,0.927432f,-0.367762f, --0.0963141f,0.945938f,-0.309718f, -0.147422f,0.952479f,-0.266555f, -0.232988f,0.930423f,-0.282895f, -0.296671f,0.921407f,-0.250989f, -0.346023f,0.880014f,-0.325337f, -0.246011f,0.893818f,-0.374924f, -0.0779935f,0.862828f,-0.499444f, -0.218748f,0.861753f,-0.457746f, -0.236169f,0.890523f,-0.388836f, -0.122215f,0.968128f,-0.218613f, --0.119249f,0.983741f,-0.134288f, --0.0975043f,0.983669f,-0.151287f, -0.0551556f,0.975975f,-0.210786f, --0.0858442f,0.972611f,-0.216008f, --0.228301f,0.939116f,-0.256789f, --0.0600278f,0.94195f,-0.330342f, --0.00498162f,0.954835f,-0.297095f, --0.236752f,0.956732f,-0.169151f, --0.404481f,0.905728f,-0.126698f, --0.442956f,0.884106f,-0.148815f, --0.353117f,0.929811f,-0.103732f, --0.367684f,0.920274f,-0.133808f, --0.620195f,0.758926f,-0.19847f, --0.650875f,0.742352f,-0.158981f, --0.60395f,0.783223f,-0.147668f, --0.562027f,0.815077f,-0.140626f, --0.504739f,0.855197f,-0.117796f, --0.629314f,0.743816f,-0.22517f, --0.590837f,0.750634f,-0.295736f, --0.432954f,0.842346f,-0.320942f, --0.414184f,0.8722f,-0.260227f, --0.438355f,0.884876f,-0.157606f, --0.309198f,0.940747f,-0.13925f, --0.155389f,0.967122f,-0.20132f, --0.14424f,0.961525f,-0.233805f, --0.235758f,0.924f,-0.301067f, -0.0151186f,0.960375f,-0.278299f, -0.144315f,0.944571f,-0.294888f, -0.112415f,0.964242f,-0.239999f, --0.0426025f,0.977992f,-0.204249f, --0.206795f,0.910666f,-0.357663f, --0.0742651f,0.885367f,-0.458922f, -0.0946583f,0.875247f,-0.474324f, -0.121834f,0.836586f,-0.534117f, -0.198513f,0.859849f,-0.470374f, -0.17646f,0.872184f,-0.456242f, -0.0304109f,0.916616f,0.39861f, --0.119037f,0.881644f,0.456655f, --0.241587f,0.81204f,0.53125f, --0.146676f,0.796898f,0.586037f, --0.0991089f,0.808485f,0.580111f, --0.265015f,0.835696f,0.481019f, --0.330941f,0.833473f,0.442495f, --0.0736129f,0.908742f,0.410816f, -0.128357f,0.956244f,0.26291f, -0.135386f,0.977167f,0.163754f, -0.135126f,0.969499f,0.204482f, --0.0826833f,0.991706f,0.0984031f, --0.125203f,0.992066f,-0.0113628f, --0.0793175f,0.988189f,-0.131112f, --0.135148f,0.988869f,-0.0622353f, --0.236045f,0.96998f,-0.0584937f, --0.106098f,0.976702f,-0.186536f, -0.0734477f,0.937214f,-0.340932f, -0.0657813f,0.913127f,-0.402333f, --0.0656411f,0.925185f,-0.373797f, --0.0812155f,0.911514f,-0.403169f, -0.138018f,0.895606f,-0.422895f, -0.180346f,0.87052f,-0.457898f, -0.220345f,0.874256f,-0.43258f, -0.337626f,0.867122f,-0.366208f, -0.351448f,0.893332f,-0.280076f, -0.206919f,0.931373f,-0.299548f, -0.143612f,0.950749f,-0.274684f, -0.0388897f,0.972032f,-0.231606f, --0.0281782f,0.996586f,-0.077599f, --0.0348963f,0.997716f,-0.0578427f, --0.0315338f,0.968969f,-0.245163f, -0.0536322f,0.969299f,-0.239965f, --0.0592746f,0.980608f,-0.186802f, --0.146447f,0.958871f,-0.243144f, --0.0489008f,0.966653f,-0.251379f, --0.0921771f,0.973026f,-0.211482f, --0.303489f,0.921788f,-0.24125f, --0.360359f,0.892722f,-0.270533f, --0.374413f,0.86994f,-0.320965f, --0.420297f,0.839321f,-0.344805f, --0.400389f,0.890168f,-0.217463f, --0.5519f,0.817694f,-0.163655f, --0.641175f,0.723209f,-0.25664f, --0.591295f,0.757829f,-0.275801f, --0.562781f,0.775127f,-0.287152f, --0.492934f,0.830818f,-0.258375f, --0.559738f,0.799568f,-0.21768f, --0.572862f,0.78051f,-0.250266f, --0.449965f,0.836305f,-0.31325f, --0.485973f,0.815927f,-0.313197f, --0.461831f,0.850292f,-0.252418f, --0.261301f,0.911823f,-0.316702f, --0.0988633f,0.911184f,-0.399961f, --0.117544f,0.902602f,-0.414118f, --0.193385f,0.896249f,-0.399173f, --0.121448f,0.924471f,-0.361392f, -0.0924319f,0.986306f,-0.136592f, -0.0129691f,0.994218f,-0.106593f, -0.0478938f,0.996018f,-0.0752017f, -0.0322924f,0.95892f,-0.281832f, -0.0176709f,0.880909f,-0.472956f, -0.117774f,0.85642f,-0.502666f, -0.141956f,0.850649f,-0.506206f, -0.133057f,0.865588f,-0.482757f, -0.139695f,0.858438f,-0.493528f, --0.227309f,0.878161f,0.420907f, --0.208802f,0.809453f,0.548805f, --0.283627f,0.767885f,0.574377f, --0.166581f,0.77975f,0.603523f, --0.0979994f,0.806409f,0.583181f, --0.132228f,0.805326f,0.577898f, --0.219374f,0.878043f,0.425342f, --0.024745f,0.955845f,0.292828f, -0.235018f,0.923494f,0.303193f, -0.225806f,0.944421f,0.238915f, -0.125193f,0.981151f,0.147203f, --0.0300197f,0.990754f,0.132305f, --0.0418198f,0.992604f,0.113964f, -0.010498f,0.998335f,0.0567192f, --0.187859f,0.981941f,-0.0223995f, --0.164152f,0.985849f,-0.0340039f, --0.00148231f,0.989313f,-0.145799f, -0.214865f,0.96059f,-0.176353f, -0.130927f,0.950976f,-0.280185f, --0.0784848f,0.932131f,-0.353513f, --0.05291f,0.922588f,-0.382142f, -0.16861f,0.90111f,-0.399463f, -0.291627f,0.864919f,-0.408495f, -0.209787f,0.830907f,-0.515347f, -0.211969f,0.855025f,-0.473287f, -0.179371f,0.927145f,-0.328982f, -0.0938016f,0.98223f,-0.162562f, -0.0948278f,0.994302f,-0.0487031f, -0.0439203f,0.998532f,-0.0316906f, --0.0612398f,0.9958f,-0.0680553f, -0.0442323f,0.992295f,-0.115732f, -0.0938163f,0.983362f,-0.155559f, --0.00984882f,0.984434f,-0.175479f, --0.064778f,0.984002f,-0.165961f, --0.129271f,0.96358f,-0.234101f, --0.126642f,0.968315f,-0.215238f, --0.066296f,0.988071f,-0.138997f, --0.153283f,0.960153f,-0.233691f, --0.288259f,0.887225f,-0.360193f, --0.349196f,0.862768f,-0.365641f, --0.457337f,0.833523f,-0.309971f, --0.510223f,0.838902f,-0.189514f, --0.576482f,0.813491f,-0.0768136f, --0.627022f,0.773599f,-0.0915885f, --0.562811f,0.806938f,-0.179152f, --0.554556f,0.77173f,-0.31129f, --0.544029f,0.784112f,-0.298665f, --0.593089f,0.773019f,-0.225135f, --0.565758f,0.788678f,-0.240633f, --0.424914f,0.871459f,-0.244963f, --0.461935f,0.845882f,-0.266647f, --0.437432f,0.833935f,-0.336461f, --0.166572f,0.89804f,-0.407159f, --0.027465f,0.893903f,-0.447419f, --0.142495f,0.890824f,-0.431426f, --0.254187f,0.896659f,-0.36248f, --0.245781f,0.925153f,-0.289282f, --0.124728f,0.970098f,-0.208211f, -0.0496061f,0.995502f,-0.0807218f, -0.134453f,0.977049f,-0.165221f, -0.178593f,0.948688f,-0.260952f, -0.203783f,0.948389f,-0.242962f, -0.169172f,0.89845f,-0.405178f, -0.129822f,0.855112f,-0.501925f, -0.114157f,0.849198f,-0.515587f, -0.207913f,0.855521f,-0.47419f, --0.447508f,0.787815f,0.423184f, --0.372189f,0.752087f,0.543911f, --0.298757f,0.721076f,0.625135f, --0.109779f,0.732409f,0.671956f, --0.05023f,0.773443f,0.631872f, --0.0721375f,0.784971f,0.615319f, -0.0161123f,0.834678f,0.550503f, -0.0881584f,0.925537f,0.368252f, -0.194291f,0.939133f,0.283338f, -0.290284f,0.915951f,0.277072f, -0.206501f,0.959193f,0.193147f, -0.0129994f,0.989588f,0.143339f, --0.0515539f,0.993638f,0.100126f, -0.0752528f,0.992857f,0.0925807f, --0.11243f,0.993659f,-0.00132253f, --0.0900456f,0.995381f,-0.0332891f, -0.0735618f,0.988585f,-0.131483f, -0.187914f,0.97058f,-0.150539f, -0.259537f,0.959521f,-0.109363f, -0.039582f,0.950958f,-0.306778f, -0.0151247f,0.899216f,-0.437243f, -0.157602f,0.861329f,-0.482984f, -0.313265f,0.852495f,-0.41847f, -0.26241f,0.877515f,-0.401384f, -0.106606f,0.940488f,-0.322671f, -0.0451106f,0.964729f,-0.259351f, --0.0198008f,0.966294f,-0.256677f, -0.0415355f,0.979836f,-0.195439f, -0.019077f,0.98811f,-0.15256f, -0.00843283f,0.995377f,-0.095676f, -0.0813095f,0.98616f,-0.14449f, -0.0601215f,0.98288f,-0.174159f, -0.0231889f,0.98066f,-0.194342f, --0.0257967f,0.969536f,-0.243588f, --0.0655874f,0.972755f,-0.222364f, --0.116074f,0.960607f,-0.252509f, --0.11539f,0.952331f,-0.282402f, --0.0547002f,0.971779f,-0.229464f, --0.238443f,0.921749f,-0.305817f, --0.409013f,0.87493f,-0.259242f, --0.537403f,0.830349f,-0.147369f, --0.604026f,0.794872f,-0.0577237f, --0.636334f,0.771366f,0.00856593f, --0.598176f,0.796287f,0.0900769f, --0.445184f,0.894265f,0.0458439f, --0.510078f,0.851049f,-0.124644f, --0.584904f,0.80616f,-0.0894032f, --0.566358f,0.809139f,-0.156631f, --0.526778f,0.78194f,-0.333278f, --0.411595f,0.815587f,-0.406703f, --0.430581f,0.806825f,-0.404517f, --0.346574f,0.828739f,-0.439406f, --0.163187f,0.84355f,-0.511658f, --0.120565f,0.900123f,-0.41862f, --0.22033f,0.94784f,-0.230335f, --0.354954f,0.922144f,-0.15381f, --0.229701f,0.962171f,-0.146509f, --0.156358f,0.938689f,-0.30727f, --0.0202846f,0.954287f,-0.298202f, -0.237025f,0.938874f,-0.24967f, -0.153523f,0.923965f,-0.350312f, -0.146234f,0.948682f,-0.280389f, -0.334575f,0.915861f,-0.221942f, -0.32488f,0.905199f,-0.273985f, -0.124349f,0.918374f,-0.375668f, -0.0853809f,0.932635f,-0.350575f, --0.326098f,0.745953f,0.580702f, --0.408924f,0.742079f,0.53113f, --0.380928f,0.732802f,0.563822f, --0.135265f,0.771831f,0.621274f, -0.0172939f,0.791015f,0.611552f, --0.0321407f,0.821651f,0.569084f, -0.110827f,0.821493f,0.559345f, -0.260047f,0.831043f,0.491674f, -0.30077f,0.882298f,0.362061f, -0.33436f,0.910333f,0.243922f, -0.27591f,0.939307f,0.203903f, -0.0278945f,0.981912f,0.18727f, --0.00885636f,0.980185f,0.197887f, -0.145141f,0.978135f,0.148949f, --0.0144219f,0.999761f,0.0164012f, --0.0725846f,0.989236f,-0.127057f, -0.156537f,0.975005f,-0.157677f, -0.153594f,0.966224f,-0.206929f, -0.277291f,0.95249f,-0.125986f, -0.254121f,0.951784f,-0.171844f, -0.192884f,0.934802f,-0.298229f, -0.176671f,0.893747f,-0.412315f, -0.195208f,0.917965f,-0.345303f, -0.157451f,0.974963f,-0.157023f, -0.0279983f,0.991052f,-0.13051f, -0.088609f,0.976865f,-0.194637f, -0.0507072f,0.953301f,-0.297735f, --0.0277167f,0.944799f,-0.326477f, --0.027462f,0.967827f,-0.250115f, --0.0885824f,0.972427f,-0.215728f, -0.0938124f,0.990405f,-0.101477f, -0.168783f,0.975825f,-0.138845f, -0.111665f,0.949064f,-0.294633f, --0.0373777f,0.928827f,-0.368623f, --0.132876f,0.934016f,-0.3316f, --0.0938993f,0.959978f,-0.263865f, --0.105226f,0.962669f,-0.249392f, --0.104341f,0.966883f,-0.232916f, --0.220802f,0.965347f,-0.13911f, --0.478375f,0.876928f,-0.0464122f, --0.604444f,0.796064f,0.0305022f, --0.611643f,0.789038f,0.0575453f, --0.651561f,0.758511f,-0.0113831f, --0.622019f,0.781788f,-0.0435906f, --0.406862f,0.913403f,-0.012587f, --0.447294f,0.893518f,0.0394196f, --0.595605f,0.801728f,0.049859f, --0.453119f,0.890822f,0.0334497f, --0.397535f,0.913376f,-0.0878049f, --0.358743f,0.901381f,-0.242521f, --0.368468f,0.876571f,-0.309604f, --0.3524f,0.834147f,-0.42428f, --0.221095f,0.907887f,-0.356171f, --0.336012f,0.912731f,-0.232418f, --0.365521f,0.924164f,-0.110978f, --0.381997f,0.913352f,-0.140951f, --0.128103f,0.980976f,-0.145863f, -0.0620369f,0.958271f,-0.279048f, --0.0393717f,0.894694f,-0.44494f, -0.166576f,0.906235f,-0.388576f, -0.257306f,0.912784f,-0.317204f, -0.0500832f,0.912737f,-0.405466f, -0.219062f,0.950498f,-0.220374f, -0.303476f,0.949102f,-0.0843104f, -0.167756f,0.983709f,-0.0646101f, --0.00137806f,0.991718f,-0.128423f, --0.411803f,0.737245f,0.535619f, --0.383529f,0.716567f,0.582612f, --0.385829f,0.756694f,0.527779f, --0.125894f,0.866623f,0.482821f, -0.0864817f,0.885592f,0.456341f, -0.0185611f,0.909875f,0.414467f, -0.0890012f,0.92755f,0.362947f, -0.3312f,0.85507f,0.39895f, -0.411118f,0.842585f,0.347898f, -0.395768f,0.87253f,0.286458f, -0.265631f,0.912624f,0.310738f, -0.0432866f,0.942781f,0.330591f, --0.0291247f,0.959608f,0.279829f, -0.17674f,0.935093f,0.307187f, -0.194038f,0.946511f,0.25781f, -0.0938941f,0.995535f,0.00965941f, -0.2133f,0.967919f,-0.132802f, -0.174202f,0.951285f,-0.254382f, -0.185706f,0.942688f,-0.277223f, -0.254853f,0.951817f,-0.170569f, -0.272452f,0.946195f,-0.174599f, -0.236374f,0.944357f,-0.228728f, -0.0622104f,0.974295f,-0.216517f, -0.00421412f,0.994674f,-0.102989f, -0.150974f,0.988535f,0.00252771f, -0.198367f,0.972494f,-0.122094f, -0.128147f,0.983415f,-0.128347f, -0.00128047f,0.972843f,-0.231463f, --0.0877992f,0.94046f,-0.328368f, --0.123322f,0.945018f,-0.302876f, -0.0120775f,0.960206f,-0.279033f, -0.230563f,0.945381f,-0.230424f, -0.231597f,0.934072f,-0.271795f, -0.0492688f,0.934225f,-0.353265f, --0.160672f,0.892999f,-0.4204f, --0.160391f,0.913064f,-0.374951f, --0.146451f,0.932705f,-0.329565f, --0.203905f,0.952995f,-0.224107f, --0.374034f,0.927408f,-0.00361175f, --0.538909f,0.826945f,0.160435f, --0.614792f,0.776175f,0.139939f, --0.589081f,0.79961f,0.116649f, --0.558852f,0.827241f,0.0579274f, --0.582196f,0.802416f,-0.131063f, --0.51435f,0.846005f,-0.140428f, --0.52517f,0.850476f,0.0297862f, --0.596917f,0.80173f,0.0303285f, --0.476386f,0.879145f,0.0126877f, --0.346071f,0.935165f,0.0755073f, --0.29506f,0.953573f,0.0603189f, --0.290873f,0.956376f,0.0271545f, --0.342792f,0.934849f,-0.0924672f, --0.36131f,0.919889f,-0.152511f, --0.440677f,0.895263f,-0.0656364f, --0.27224f,0.960453f,-0.0584458f, --0.239345f,0.939791f,-0.243941f, --0.184322f,0.924268f,-0.334296f, -0.170265f,0.967851f,-0.185131f, -0.0831722f,0.975078f,-0.205681f, -0.0764752f,0.962386f,-0.2607f, -0.25092f,0.948574f,-0.192995f, --0.000511184f,0.983325f,-0.181855f, -0.00805518f,0.99922f,-0.0386666f, -0.231558f,0.969957f,0.0745867f, -0.213284f,0.97378f,0.0791335f, -0.134707f,0.990255f,0.0353415f, --0.461887f,0.727903f,0.506772f, --0.409704f,0.769768f,0.48949f, --0.245031f,0.85373f,0.459461f, --0.000652498f,0.933053f,0.359739f, -0.0977619f,0.940993f,0.323999f, -0.0976539f,0.925223f,0.366641f, -0.122528f,0.958779f,0.256377f, -0.300256f,0.92807f,0.220301f, -0.434057f,0.868364f,0.239872f, -0.373936f,0.875783f,0.305249f, -0.188752f,0.892291f,0.41011f, -0.0749298f,0.875078f,0.478146f, -0.0539526f,0.905587f,0.420716f, -0.139771f,0.930537f,0.338475f, -0.252071f,0.902374f,0.349544f, -0.271241f,0.91149f,0.309214f, -0.343876f,0.91657f,0.204082f, -0.324141f,0.940857f,0.098591f, -0.18373f,0.982977f,-0.000581414f, -0.215424f,0.976468f,-0.0101277f, -0.272942f,0.961141f,-0.0413737f, -0.263192f,0.964688f,-0.010384f, -0.0834313f,0.988492f,-0.126183f, --0.0244777f,0.972824f,-0.230248f, -0.037395f,0.972598f,-0.229465f, -0.188221f,0.98005f,-0.0638298f, -0.133895f,0.99093f,-0.0113778f, -0.15553f,0.985289f,-0.0708293f, -0.062154f,0.97927f,-0.19279f, --0.0906565f,0.929896f,-0.356476f, --0.00537849f,0.905315f,-0.424706f, -0.162604f,0.918237f,-0.361109f, -0.211297f,0.942163f,-0.260159f, -0.166674f,0.959094f,-0.22882f, --0.0900843f,0.919646f,-0.382278f, --0.185542f,0.891522f,-0.413234f, --0.236454f,0.911319f,-0.337026f, --0.404129f,0.904849f,-0.133894f, --0.540771f,0.839361f,0.0551279f, --0.598434f,0.794978f,0.0994372f, --0.56944f,0.810652f,0.136315f, --0.572323f,0.818089f,0.0563579f, --0.472334f,0.880613f,0.0376913f, --0.539685f,0.840552f,-0.0470301f, --0.574258f,0.816988f,0.0525225f, --0.582793f,0.802613f,0.127141f, --0.577964f,0.810669f,0.0936681f, --0.453297f,0.886551f,0.0924669f, --0.392456f,0.918879f,0.0405067f, --0.316387f,0.94595f,0.0712573f, --0.278453f,0.953269f,0.117224f, --0.268053f,0.957793f,0.103824f, --0.307148f,0.94927f,0.0674248f, --0.42059f,0.907249f,-0.00173726f, --0.259446f,0.962613f,-0.0778756f, --0.0851837f,0.992966f,-0.082236f, --0.215247f,0.960313f,-0.177393f, --0.0219544f,0.989556f,-0.14247f, -0.0391647f,0.99769f,-0.0555004f, -0.102045f,0.994433f,0.0262785f, -0.194292f,0.978837f,0.0642512f, --0.0292693f,0.988875f,0.145839f, --0.101853f,0.986247f,0.130166f, -0.212882f,0.964861f,0.15403f, -0.245798f,0.960888f,0.127587f, -0.195444f,0.974318f,0.111832f, --0.321858f,0.809731f,0.490656f, --0.324834f,0.8531f,0.408293f, --0.169338f,0.931652f,0.321478f, -0.0137661f,0.965459f,0.260189f, -0.0568655f,0.931751f,0.358619f, -0.0773718f,0.91837f,0.388084f, -0.261047f,0.911575f,0.317625f, -0.360487f,0.919759f,0.155217f, -0.377368f,0.917164f,0.128078f, -0.276887f,0.917903f,0.284232f, -0.0739314f,0.913495f,0.400076f, -0.00592871f,0.863726f,0.503926f, -0.12818f,0.830694f,0.541773f, -0.218813f,0.849726f,0.479673f, -0.242686f,0.877276f,0.414115f, -0.274843f,0.886896f,0.371318f, -0.349234f,0.864992f,0.360313f, -0.316807f,0.866747f,0.385206f, -0.243026f,0.8884f,0.389467f, -0.293176f,0.904042f,0.311057f, -0.24905f,0.947495f,0.200568f, -0.307601f,0.926121f,0.21836f, -0.250581f,0.964737f,0.0805682f, -0.134636f,0.99035f,-0.0328548f, -0.000251354f,0.985828f,-0.167762f, -0.0218107f,0.990992f,-0.132131f, -0.159951f,0.984761f,-0.068279f, -0.165852f,0.977778f,-0.128229f, -0.162621f,0.98447f,-0.06613f, -0.121502f,0.975682f,-0.182435f, -0.0565286f,0.935574f,-0.348576f, -0.0461029f,0.9227f,-0.382752f, -0.0939341f,0.947555f,-0.305477f, -0.144515f,0.970016f,-0.195409f, -0.0775217f,0.989125f,-0.124991f, --0.200827f,0.965332f,-0.16674f, --0.401609f,0.907839f,-0.120577f, --0.559375f,0.828885f,-0.00699655f, --0.565805f,0.821746f,0.0678162f, --0.593147f,0.804311f,0.0354918f, --0.576294f,0.817225f,0.00543077f, --0.525544f,0.848999f,-0.0548173f, --0.499547f,0.863338f,-0.0714126f, --0.553806f,0.830814f,0.0551944f, --0.639015f,0.755184f,0.146141f, --0.555848f,0.812796f,0.174341f, --0.558245f,0.826947f,0.0672363f, --0.433561f,0.898303f,0.0712505f, --0.328723f,0.942541f,0.0596481f, --0.348698f,0.936876f,0.0259581f, --0.301092f,0.95068f,0.0745005f, --0.263015f,0.962594f,0.0650869f, --0.284818f,0.957539f,0.0446894f, --0.359379f,0.932627f,-0.032449f, --0.231945f,0.967322f,-0.102417f, --0.134462f,0.989922f,-0.0444264f, --0.162306f,0.986023f,0.0376183f, -0.00794699f,0.998548f,-0.0532871f, --0.0239448f,0.993657f,-0.109874f, --0.0216422f,0.99782f,0.0623378f, -0.109723f,0.978713f,0.173443f, --0.0637399f,0.980084f,0.188075f, --0.0488189f,0.981371f,0.185814f, -0.215314f,0.95546f,0.201833f, -0.226954f,0.944659f,0.236876f, -0.18874f,0.93582f,0.297688f, --0.35388f,0.863488f,0.359384f, --0.279389f,0.900607f,0.332938f, --0.0980507f,0.952584f,0.288043f, --0.0324622f,0.946395f,0.321377f, --0.0380375f,0.913004f,0.406173f, -0.128955f,0.929408f,0.345792f, -0.375928f,0.898621f,0.226181f, -0.446257f,0.883274f,0.143813f, -0.289683f,0.938589f,0.187442f, -0.125289f,0.928145f,0.350499f, --0.0288389f,0.895239f,0.444652f, --0.103894f,0.871209f,0.479793f, -0.105997f,0.859294f,0.500378f, -0.239743f,0.842088f,0.483127f, -0.302444f,0.818919f,0.48775f, -0.351983f,0.830309f,0.432082f, -0.318807f,0.868172f,0.380315f, -0.306771f,0.857612f,0.412787f, -0.273726f,0.881543f,0.384651f, -0.337032f,0.866043f,0.369295f, -0.363605f,0.874829f,0.320103f, -0.334634f,0.927168f,0.168463f, -0.372292f,0.916204f,0.148217f, -0.206342f,0.978274f,0.0200943f, -0.119354f,0.989819f,-0.077546f, -0.042858f,0.974765f,-0.21908f, -0.15227f,0.956258f,-0.24977f, -0.17642f,0.955622f,-0.235928f, -0.119264f,0.963567f,-0.239406f, -0.210452f,0.949288f,-0.233584f, -0.171674f,0.93622f,-0.306626f, -0.0511268f,0.942128f,-0.331333f, -0.00960037f,0.978635f,-0.205381f, --0.00181509f,0.99884f,-0.048118f, --0.0483779f,0.993619f,0.101885f, --0.221067f,0.964285f,0.145887f, --0.435375f,0.898142f,0.0615596f, --0.544434f,0.838804f,-0.00062539f, --0.579913f,0.810216f,-0.0851529f, --0.5726f,0.815766f,-0.0815813f, --0.546649f,0.832873f,-0.0865884f, --0.465735f,0.88205f,-0.071268f, --0.55864f,0.824018f,-0.0944285f, --0.642115f,0.765228f,0.0459774f, --0.656804f,0.753752f,0.0216163f, --0.520592f,0.853762f,0.00863503f, --0.481258f,0.875004f,-0.0525228f, --0.443379f,0.889071f,-0.113874f, --0.339817f,0.937077f,-0.0800719f, --0.346478f,0.935462f,-0.0697409f, --0.350474f,0.934462f,-0.0628307f, --0.228751f,0.97348f,-0.00313391f, --0.230759f,0.970493f,-0.0699589f, --0.279469f,0.954379f,-0.105155f, --0.198889f,0.96686f,-0.16008f, --0.230529f,0.946681f,-0.225058f, --0.14204f,0.970201f,-0.196301f, -0.0687794f,0.962113f,-0.263834f, --0.0677159f,0.979986f,-0.187196f, --0.220027f,0.972288f,-0.0790245f, -0.07326f,0.993712f,0.0846721f, --0.0289367f,0.993146f,0.113239f, --0.106822f,0.986395f,0.124957f, -0.128381f,0.967004f,0.22005f, -0.141757f,0.945235f,0.293998f, -0.0274083f,0.95189f,0.30521f, --0.150915f,0.940582f,0.304189f, --0.174369f,0.970549f,0.166222f, --0.140821f,0.979995f,0.140639f, --0.141606f,0.959082f,0.245171f, -0.011894f,0.972798f,0.23135f, -0.262326f,0.961504f,0.0818187f, -0.456393f,0.889018f,0.036791f, -0.382632f,0.920315f,0.0813253f, -0.174752f,0.942069f,0.286301f, --0.045852f,0.917014f,0.396211f, --0.0633233f,0.882412f,0.466197f, --0.0422981f,0.919143f,0.391647f, -0.126089f,0.949054f,0.288786f, -0.256733f,0.912921f,0.317275f, -0.315104f,0.887032f,0.337468f, -0.409846f,0.864148f,0.292018f, -0.343944f,0.901166f,0.263823f, -0.312798f,0.897029f,0.312244f, -0.323227f,0.888441f,0.325879f, -0.342446f,0.89904f,0.272869f, -0.451059f,0.860524f,0.236736f, -0.423682f,0.891569f,0.159992f, -0.404089f,0.899665f,0.165275f, -0.34072f,0.934631f,0.101855f, -0.255675f,0.966712f,-0.00994645f, -0.192495f,0.972523f,-0.130939f, -0.146493f,0.95759f,-0.248115f, -0.177747f,0.950895f,-0.253387f, -0.10258f,0.958737f,-0.265144f, -0.233714f,0.956929f,-0.172236f, -0.223818f,0.95591f,-0.190111f, --0.0753718f,0.974181f,-0.212814f, --0.223858f,0.97386f,-0.0385406f, --0.201603f,0.967155f,0.154817f, --0.110966f,0.95618f,0.270934f, --0.121146f,0.966863f,0.224722f, --0.291476f,0.94891f,0.120877f, --0.477923f,0.877529f,-0.0391374f, --0.509066f,0.849204f,-0.140369f, --0.547573f,0.807834f,-0.218101f, --0.563212f,0.785973f,-0.255028f, --0.550783f,0.817799f,-0.166865f, --0.567941f,0.823056f,0.00472398f, --0.662541f,0.748994f,-0.00687841f, --0.61971f,0.78387f,-0.03883f, --0.523314f,0.847679f,-0.0870804f, --0.447797f,0.889814f,-0.0877948f, --0.443749f,0.888577f,-0.116264f, --0.376466f,0.920201f,-0.107257f, --0.337652f,0.938208f,-0.0758775f, --0.365552f,0.926461f,-0.0896778f, --0.259904f,0.962681f,-0.0754604f, --0.126151f,0.988548f,-0.0828222f, --0.30144f,0.926166f,-0.226606f, --0.124801f,0.973148f,-0.193411f, --0.0842547f,0.941418f,-0.326548f, --0.0799027f,0.902475f,-0.423267f, --0.00736616f,0.932864f,-0.360152f, --0.199402f,0.957181f,-0.209865f, --0.285967f,0.938676f,-0.192641f, --0.0884894f,0.987166f,-0.132941f, --0.0982017f,0.994337f,0.0406204f, --0.151395f,0.982648f,0.107153f, -0.0310104f,0.988838f,0.14573f, -0.106405f,0.964191f,0.242925f, -0.070474f,0.952157f,0.297374f, -0.0656706f,0.9919f,0.108725f, --0.0894851f,0.995828f,0.0178395f, --0.190523f,0.981135f,0.0327999f, --0.155304f,0.987556f,0.0247798f, -0.115224f,0.991572f,-0.0592235f, -0.36579f,0.920032f,-0.140496f, -0.356271f,0.926984f,-0.117348f, -0.248335f,0.959842f,0.130508f, -0.000801886f,0.966476f,0.256755f, --0.114974f,0.940419f,0.319989f, --0.0524682f,0.940494f,0.335734f, -0.129742f,0.951002f,0.280646f, -0.183656f,0.974747f,0.127042f, -0.210533f,0.964529f,0.159247f, -0.299776f,0.935816f,0.185429f, -0.476652f,0.857927f,0.191739f, -0.365421f,0.920615f,0.137608f, -0.247354f,0.961561f,0.119232f, -0.333488f,0.932256f,0.140299f, -0.428629f,0.898219f,0.0973634f, -0.470887f,0.881687f,0.0298847f, -0.443595f,0.892268f,0.0841461f, -0.38152f,0.920309f,0.0864469f, -0.381462f,0.916941f,0.117074f, -0.327497f,0.93955f,0.099957f, -0.304803f,0.952409f,-0.00357992f, -0.239937f,0.959204f,-0.149528f, -0.202117f,0.965308f,-0.165315f, -0.0495866f,0.988011f,-0.146203f, -0.0854477f,0.995976f,-0.027023f, -0.244078f,0.956317f,0.160886f, --0.0753613f,0.986424f,0.145905f, --0.339089f,0.932874f,0.12151f, --0.294837f,0.942606f,0.15673f, --0.104304f,0.973462f,0.203698f, --0.0723227f,0.985619f,0.152724f, --0.210009f,0.973927f,0.0858055f, --0.391811f,0.919671f,-0.0262484f, --0.442429f,0.895892f,-0.0404195f, --0.501975f,0.857758f,-0.11078f, --0.516547f,0.834688f,-0.190982f, --0.606461f,0.747704f,-0.270451f, --0.650373f,0.745527f,-0.145618f, --0.638901f,0.762805f,-0.0996673f, --0.598555f,0.785548f,-0.156994f, --0.501024f,0.846694f,-0.179123f, --0.446137f,0.875545f,-0.185426f, --0.431282f,0.886668f,-0.16678f, --0.409115f,0.903871f,-0.125073f, --0.364534f,0.929271f,-0.0597475f, --0.342967f,0.93838f,-0.0426101f, --0.26831f,0.95962f,-0.0844963f, --0.0393852f,0.992201f,-0.118264f, --0.116204f,0.958118f,-0.261737f, --0.10396f,0.911216f,-0.398596f, -0.0690263f,0.90803f,-0.41318f, --0.107766f,0.879323f,-0.463872f, --0.204112f,0.904181f,-0.375227f, --0.300499f,0.93243f,-0.200683f, --0.27347f,0.953749f,-0.124807f, --0.169754f,0.978593f,-0.116359f, --0.231778f,0.970053f,-0.072634f, --0.190395f,0.98166f,0.00964305f, --0.0305984f,0.996687f,0.0753532f, -0.015862f,0.984083f,0.177002f, --0.0353434f,0.980638f,0.192612f, --0.00358253f,0.996067f,-0.0885361f, --0.091201f,0.995656f,-0.0187243f, --0.182622f,0.982071f,0.0467509f, --0.0739202f,0.997106f,-0.017751f, -0.154438f,0.971547f,-0.179571f, -0.395535f,0.904532f,-0.159291f, -0.194508f,0.960754f,-0.197781f, -0.113269f,0.98581f,0.123894f, --0.030891f,0.963944f,0.264306f, --0.124571f,0.959262f,0.253572f, --0.0553429f,0.968125f,0.244277f, -0.192328f,0.950681f,0.243343f, -0.217769f,0.968216f,0.123025f, -0.205296f,0.966103f,0.156522f, -0.276023f,0.954237f,0.11508f, -0.467224f,0.868183f,0.167212f, -0.402263f,0.894308f,0.195955f, -0.299601f,0.940084f,0.162733f, -0.355906f,0.933872f,0.0348486f, -0.474044f,0.880198f,-0.0230946f, -0.444725f,0.891474f,-0.0865651f, -0.431452f,0.901988f,0.0163334f, -0.385491f,0.922676f,0.00810292f, -0.339313f,0.940655f,0.00595024f, -0.37483f,0.92173f,0.099581f, -0.41171f,0.911266f,-0.00949356f, -0.281208f,0.933096f,-0.224175f, -0.138066f,0.959634f,-0.245031f, -0.0299217f,0.992057f,-0.122182f, --0.0797424f,0.99128f,-0.104905f, -0.124146f,0.977522f,0.170405f, --0.0302976f,0.947743f,0.317594f, --0.301142f,0.928457f,0.21744f, --0.278579f,0.94845f,0.151119f, --0.150217f,0.982764f,0.107745f, -0.0163995f,0.982022f,0.188052f, --0.137431f,0.989816f,0.0370977f, --0.36652f,0.926186f,-0.0885568f, --0.445397f,0.895157f,-0.0177851f, --0.463397f,0.885777f,-0.0257252f, --0.466469f,0.878885f,-0.099842f, --0.557948f,0.804805f,-0.202443f, --0.681509f,0.679149f,-0.272587f, --0.629296f,0.753928f,-0.188625f, --0.5596f,0.798482f,-0.221976f, --0.503025f,0.800303f,-0.326313f, --0.422254f,0.855253f,-0.300408f, --0.454716f,0.829192f,-0.325075f, --0.46025f,0.856807f,-0.232488f, --0.37729f,0.921922f,-0.0878209f, --0.375084f,0.920087f,-0.112928f, --0.173161f,0.984659f,-0.0214944f, --0.0348229f,0.978528f,-0.20315f, -0.0523603f,0.977312f,-0.205229f, --0.0533357f,0.893335f,-0.446215f, -0.0246713f,0.873256f,-0.486637f, --0.0923807f,0.905308f,-0.414587f, --0.269958f,0.871402f,-0.409612f, --0.388686f,0.862358f,-0.324442f, --0.340148f,0.928537f,-0.148722f, --0.147166f,0.988619f,-0.0312327f, --0.248059f,0.963625f,-0.099463f, --0.232297f,0.969578f,-0.0771772f, --0.142695f,0.989498f,-0.02308f, --0.0198137f,0.98287f,0.18323f, --0.0333475f,0.978727f,0.202438f, -}; - -btScalar Landscape05Tex[] = { -0.0f,0.5f, -0.0f,0.492188f, -0.0078125f,0.5f, -0.0078125f,0.492188f, -0.015625f,0.5f, -0.015625f,0.492188f, -0.0234375f,0.5f, -0.0234375f,0.492188f, -0.03125f,0.5f, -0.03125f,0.492188f, -0.0390625f,0.5f, -0.0390625f,0.492188f, -0.046875f,0.5f, -0.046875f,0.492188f, -0.0546875f,0.5f, -0.0546875f,0.492188f, -0.0625f,0.5f, -0.0625f,0.492188f, -0.0703125f,0.5f, -0.0703125f,0.492188f, -0.078125f,0.5f, -0.078125f,0.492188f, -0.0859375f,0.5f, -0.0859375f,0.492188f, -0.09375f,0.5f, -0.09375f,0.492188f, -0.101563f,0.5f, -0.101563f,0.492188f, -0.109375f,0.5f, -0.109375f,0.492188f, -0.117188f,0.5f, -0.117188f,0.492188f, -0.125f,0.5f, -0.125f,0.492188f, -0.132813f,0.5f, -0.132813f,0.492188f, -0.140625f,0.5f, -0.140625f,0.492188f, -0.148438f,0.5f, -0.148438f,0.492188f, -0.15625f,0.5f, -0.15625f,0.492188f, -0.164063f,0.5f, -0.164063f,0.492188f, -0.171875f,0.5f, -0.171875f,0.492188f, -0.179688f,0.5f, -0.179688f,0.492188f, -0.1875f,0.5f, -0.1875f,0.492188f, -0.195313f,0.5f, -0.195313f,0.492188f, -0.203125f,0.5f, -0.203125f,0.492188f, -0.210938f,0.5f, -0.210938f,0.492188f, -0.21875f,0.5f, -0.21875f,0.492188f, -0.226563f,0.5f, -0.226563f,0.492188f, -0.234375f,0.5f, -0.234375f,0.492188f, -0.242188f,0.5f, -0.242188f,0.492188f, -0.25f,0.5f, -0.25f,0.492188f, -0.257813f,0.5f, -0.257813f,0.492188f, -0.265625f,0.5f, -0.265625f,0.492188f, -0.273438f,0.5f, -0.273438f,0.492188f, -0.28125f,0.5f, -0.28125f,0.492188f, -0.289063f,0.5f, -0.289063f,0.492188f, -0.296875f,0.5f, -0.296875f,0.492188f, -0.304688f,0.5f, -0.304688f,0.492188f, -0.3125f,0.5f, -0.3125f,0.492188f, -0.320313f,0.5f, -0.320313f,0.492188f, -0.328125f,0.5f, -0.328125f,0.492188f, -0.335938f,0.5f, -0.335938f,0.492188f, -0.34375f,0.5f, -0.34375f,0.492188f, -0.351563f,0.5f, -0.351563f,0.492188f, -0.359375f,0.5f, -0.359375f,0.492188f, -0.367188f,0.5f, -0.367188f,0.492188f, -0.375f,0.5f, -0.375f,0.492188f, -0.382813f,0.5f, -0.382813f,0.492188f, -0.390625f,0.5f, -0.390625f,0.492188f, -0.398438f,0.5f, -0.398438f,0.492188f, -0.40625f,0.5f, -0.40625f,0.492188f, -0.414063f,0.5f, -0.414063f,0.492188f, -0.421875f,0.5f, -0.421875f,0.492188f, -0.429688f,0.5f, -0.429688f,0.492188f, -0.4375f,0.5f, -0.4375f,0.492188f, -0.445313f,0.5f, -0.445313f,0.492188f, -0.453125f,0.5f, -0.453125f,0.492188f, -0.460938f,0.5f, -0.460938f,0.492188f, -0.46875f,0.5f, -0.46875f,0.492188f, -0.476563f,0.5f, -0.476563f,0.492188f, -0.484375f,0.5f, -0.484375f,0.492188f, -0.492188f,0.5f, -0.492188f,0.492188f, -0.5f,0.5f, -0.5f,0.492188f, -0.507813f,0.5f, -0.507813f,0.492188f, -0.0f,0.507813f, -0.0078125f,0.507813f, -0.015625f,0.507813f, -0.0234375f,0.507813f, -0.03125f,0.507813f, -0.0390625f,0.507813f, -0.046875f,0.507813f, -0.0546875f,0.507813f, -0.0625f,0.507813f, -0.0703125f,0.507813f, -0.078125f,0.507813f, -0.0859375f,0.507813f, -0.09375f,0.507813f, -0.101563f,0.507813f, -0.109375f,0.507813f, -0.117188f,0.507813f, -0.125f,0.507813f, -0.132813f,0.507813f, -0.140625f,0.507813f, -0.148438f,0.507813f, -0.15625f,0.507813f, -0.164063f,0.507813f, -0.171875f,0.507813f, -0.179688f,0.507813f, -0.1875f,0.507813f, -0.195313f,0.507813f, -0.203125f,0.507813f, -0.210938f,0.507813f, -0.21875f,0.507813f, -0.226563f,0.507813f, -0.234375f,0.507813f, -0.242188f,0.507813f, -0.25f,0.507813f, -0.257813f,0.507813f, -0.265625f,0.507813f, -0.273438f,0.507813f, -0.28125f,0.507813f, -0.289063f,0.507813f, -0.296875f,0.507813f, -0.304688f,0.507813f, -0.3125f,0.507813f, -0.320313f,0.507813f, -0.328125f,0.507813f, -0.335938f,0.507813f, -0.34375f,0.507813f, -0.351563f,0.507813f, -0.359375f,0.507813f, -0.367188f,0.507813f, -0.375f,0.507813f, -0.382813f,0.507813f, -0.390625f,0.507813f, -0.398438f,0.507813f, -0.40625f,0.507813f, -0.414063f,0.507813f, -0.421875f,0.507813f, -0.429688f,0.507813f, -0.4375f,0.507813f, -0.445313f,0.507813f, -0.453125f,0.507813f, -0.460938f,0.507813f, -0.46875f,0.507813f, -0.476563f,0.507813f, -0.484375f,0.507813f, -0.492188f,0.507813f, -0.5f,0.507813f, -0.507813f,0.507813f, -0.0f,0.515625f, -0.0078125f,0.515625f, -0.015625f,0.515625f, -0.0234375f,0.515625f, -0.03125f,0.515625f, -0.0390625f,0.515625f, -0.046875f,0.515625f, -0.0546875f,0.515625f, -0.0625f,0.515625f, -0.0703125f,0.515625f, -0.078125f,0.515625f, -0.0859375f,0.515625f, -0.09375f,0.515625f, -0.101563f,0.515625f, -0.109375f,0.515625f, -0.117188f,0.515625f, -0.125f,0.515625f, -0.132813f,0.515625f, -0.140625f,0.515625f, -0.148438f,0.515625f, -0.15625f,0.515625f, -0.164063f,0.515625f, -0.171875f,0.515625f, -0.179688f,0.515625f, -0.1875f,0.515625f, -0.195313f,0.515625f, -0.203125f,0.515625f, -0.210938f,0.515625f, -0.21875f,0.515625f, -0.226563f,0.515625f, -0.234375f,0.515625f, -0.242188f,0.515625f, -0.25f,0.515625f, -0.257813f,0.515625f, -0.265625f,0.515625f, -0.273438f,0.515625f, -0.28125f,0.515625f, -0.289063f,0.515625f, -0.296875f,0.515625f, -0.304688f,0.515625f, -0.3125f,0.515625f, -0.320313f,0.515625f, -0.328125f,0.515625f, -0.335938f,0.515625f, -0.34375f,0.515625f, -0.351563f,0.515625f, -0.359375f,0.515625f, -0.367188f,0.515625f, -0.375f,0.515625f, -0.382813f,0.515625f, -0.390625f,0.515625f, -0.398438f,0.515625f, -0.40625f,0.515625f, -0.414063f,0.515625f, -0.421875f,0.515625f, -0.429688f,0.515625f, -0.4375f,0.515625f, -0.445313f,0.515625f, -0.453125f,0.515625f, -0.460938f,0.515625f, -0.46875f,0.515625f, -0.476563f,0.515625f, -0.484375f,0.515625f, -0.492188f,0.515625f, -0.5f,0.515625f, -0.507813f,0.515625f, -0.0f,0.523438f, -0.0078125f,0.523438f, -0.015625f,0.523438f, -0.0234375f,0.523438f, -0.03125f,0.523438f, -0.0390625f,0.523438f, -0.046875f,0.523438f, -0.0546875f,0.523438f, -0.0625f,0.523438f, -0.0703125f,0.523438f, -0.078125f,0.523438f, -0.0859375f,0.523438f, -0.09375f,0.523438f, -0.101563f,0.523438f, -0.109375f,0.523438f, -0.117188f,0.523438f, -0.125f,0.523438f, -0.132813f,0.523438f, -0.140625f,0.523438f, -0.148438f,0.523438f, -0.15625f,0.523438f, -0.164063f,0.523438f, -0.171875f,0.523438f, -0.179688f,0.523438f, -0.1875f,0.523438f, -0.195313f,0.523438f, -0.203125f,0.523438f, -0.210938f,0.523438f, -0.21875f,0.523438f, -0.226563f,0.523438f, -0.234375f,0.523438f, -0.242188f,0.523438f, -0.25f,0.523438f, -0.257813f,0.523438f, -0.265625f,0.523438f, -0.273438f,0.523438f, -0.28125f,0.523438f, -0.289063f,0.523438f, -0.296875f,0.523438f, -0.304688f,0.523438f, -0.3125f,0.523438f, -0.320313f,0.523438f, -0.328125f,0.523438f, -0.335938f,0.523438f, -0.34375f,0.523438f, -0.351563f,0.523438f, -0.359375f,0.523438f, -0.367188f,0.523438f, -0.375f,0.523438f, -0.382813f,0.523438f, -0.390625f,0.523438f, -0.398438f,0.523438f, -0.40625f,0.523438f, -0.414063f,0.523438f, -0.421875f,0.523438f, -0.429688f,0.523438f, -0.4375f,0.523438f, -0.445313f,0.523438f, -0.453125f,0.523438f, -0.460938f,0.523438f, -0.46875f,0.523438f, -0.476563f,0.523438f, -0.484375f,0.523438f, -0.492188f,0.523438f, -0.5f,0.523438f, -0.507813f,0.523438f, -0.0f,0.53125f, -0.0078125f,0.53125f, -0.015625f,0.53125f, -0.0234375f,0.53125f, -0.03125f,0.53125f, -0.0390625f,0.53125f, -0.046875f,0.53125f, -0.0546875f,0.53125f, -0.0625f,0.53125f, -0.0703125f,0.53125f, -0.078125f,0.53125f, -0.0859375f,0.53125f, -0.09375f,0.53125f, -0.101563f,0.53125f, -0.109375f,0.53125f, -0.117188f,0.53125f, -0.125f,0.53125f, -0.132813f,0.53125f, -0.140625f,0.53125f, -0.148438f,0.53125f, -0.15625f,0.53125f, -0.164063f,0.53125f, -0.171875f,0.53125f, -0.179688f,0.53125f, -0.1875f,0.53125f, -0.195313f,0.53125f, -0.203125f,0.53125f, -0.210938f,0.53125f, -0.21875f,0.53125f, -0.226563f,0.53125f, -0.234375f,0.53125f, -0.242188f,0.53125f, -0.25f,0.53125f, -0.257813f,0.53125f, -0.265625f,0.53125f, -0.273438f,0.53125f, -0.28125f,0.53125f, -0.289063f,0.53125f, -0.296875f,0.53125f, -0.304688f,0.53125f, -0.3125f,0.53125f, -0.320313f,0.53125f, -0.328125f,0.53125f, -0.335938f,0.53125f, -0.34375f,0.53125f, -0.351563f,0.53125f, -0.359375f,0.53125f, -0.367188f,0.53125f, -0.375f,0.53125f, -0.382813f,0.53125f, -0.390625f,0.53125f, -0.398438f,0.53125f, -0.40625f,0.53125f, -0.414063f,0.53125f, -0.421875f,0.53125f, -0.429688f,0.53125f, -0.4375f,0.53125f, -0.445313f,0.53125f, -0.453125f,0.53125f, -0.460938f,0.53125f, -0.46875f,0.53125f, -0.476563f,0.53125f, -0.484375f,0.53125f, -0.492188f,0.53125f, -0.5f,0.53125f, -0.507813f,0.53125f, -0.0f,0.539063f, -0.0078125f,0.539063f, -0.015625f,0.539063f, -0.0234375f,0.539063f, -0.03125f,0.539063f, -0.0390625f,0.539063f, -0.046875f,0.539063f, -0.0546875f,0.539063f, -0.0625f,0.539063f, -0.0703125f,0.539063f, -0.078125f,0.539063f, -0.0859375f,0.539063f, -0.09375f,0.539063f, -0.101563f,0.539063f, -0.109375f,0.539063f, -0.117188f,0.539063f, -0.125f,0.539063f, -0.132813f,0.539063f, -0.140625f,0.539063f, -0.148438f,0.539063f, -0.15625f,0.539063f, -0.164063f,0.539063f, -0.171875f,0.539063f, -0.179688f,0.539063f, -0.1875f,0.539063f, -0.195313f,0.539063f, -0.203125f,0.539063f, -0.210938f,0.539063f, -0.21875f,0.539063f, -0.226563f,0.539063f, -0.234375f,0.539063f, -0.242188f,0.539063f, -0.25f,0.539063f, -0.257813f,0.539063f, -0.265625f,0.539063f, -0.273438f,0.539063f, -0.28125f,0.539063f, -0.289063f,0.539063f, -0.296875f,0.539063f, -0.304688f,0.539063f, -0.3125f,0.539063f, -0.320313f,0.539063f, -0.328125f,0.539063f, -0.335938f,0.539063f, -0.34375f,0.539063f, -0.351563f,0.539063f, -0.359375f,0.539063f, -0.367188f,0.539063f, -0.375f,0.539063f, -0.382813f,0.539063f, -0.390625f,0.539063f, -0.398438f,0.539063f, -0.40625f,0.539063f, -0.414063f,0.539063f, -0.421875f,0.539063f, -0.429688f,0.539063f, -0.4375f,0.539063f, -0.445313f,0.539063f, -0.453125f,0.539063f, -0.460938f,0.539063f, -0.46875f,0.539063f, -0.476563f,0.539063f, -0.484375f,0.539063f, -0.492188f,0.539063f, -0.5f,0.539063f, -0.507813f,0.539063f, -0.0f,0.546875f, -0.0078125f,0.546875f, -0.015625f,0.546875f, -0.0234375f,0.546875f, -0.03125f,0.546875f, -0.0390625f,0.546875f, -0.046875f,0.546875f, -0.0546875f,0.546875f, -0.0625f,0.546875f, -0.0703125f,0.546875f, -0.078125f,0.546875f, -0.0859375f,0.546875f, -0.09375f,0.546875f, -0.101563f,0.546875f, -0.109375f,0.546875f, -0.117188f,0.546875f, -0.125f,0.546875f, -0.132813f,0.546875f, -0.140625f,0.546875f, -0.148438f,0.546875f, -0.15625f,0.546875f, -0.164063f,0.546875f, -0.171875f,0.546875f, -0.179688f,0.546875f, -0.1875f,0.546875f, -0.195313f,0.546875f, -0.203125f,0.546875f, -0.210938f,0.546875f, -0.21875f,0.546875f, -0.226563f,0.546875f, -0.234375f,0.546875f, -0.242188f,0.546875f, -0.25f,0.546875f, -0.257813f,0.546875f, -0.265625f,0.546875f, -0.273438f,0.546875f, -0.28125f,0.546875f, -0.289063f,0.546875f, -0.296875f,0.546875f, -0.304688f,0.546875f, -0.3125f,0.546875f, -0.320313f,0.546875f, -0.328125f,0.546875f, -0.335938f,0.546875f, -0.34375f,0.546875f, -0.351563f,0.546875f, -0.359375f,0.546875f, -0.367188f,0.546875f, -0.375f,0.546875f, -0.382813f,0.546875f, -0.390625f,0.546875f, -0.398438f,0.546875f, -0.40625f,0.546875f, -0.414063f,0.546875f, -0.421875f,0.546875f, -0.429688f,0.546875f, -0.4375f,0.546875f, -0.445313f,0.546875f, -0.453125f,0.546875f, -0.460938f,0.546875f, -0.46875f,0.546875f, -0.476563f,0.546875f, -0.484375f,0.546875f, -0.492188f,0.546875f, -0.5f,0.546875f, -0.507813f,0.546875f, -0.0f,0.554688f, -0.0078125f,0.554688f, -0.015625f,0.554688f, -0.0234375f,0.554688f, -0.03125f,0.554688f, -0.0390625f,0.554688f, -0.046875f,0.554688f, -0.0546875f,0.554688f, -0.0625f,0.554688f, -0.0703125f,0.554688f, -0.078125f,0.554688f, -0.0859375f,0.554688f, -0.09375f,0.554688f, -0.101563f,0.554688f, -0.109375f,0.554688f, -0.117188f,0.554688f, -0.125f,0.554688f, -0.132813f,0.554688f, -0.140625f,0.554688f, -0.148438f,0.554688f, -0.15625f,0.554688f, -0.164063f,0.554688f, -0.171875f,0.554688f, -0.179688f,0.554688f, -0.1875f,0.554688f, -0.195313f,0.554688f, -0.203125f,0.554688f, -0.210938f,0.554688f, -0.21875f,0.554688f, -0.226563f,0.554688f, -0.234375f,0.554688f, -0.242188f,0.554688f, -0.25f,0.554688f, -0.257813f,0.554688f, -0.265625f,0.554688f, -0.273438f,0.554688f, -0.28125f,0.554688f, -0.289063f,0.554688f, -0.296875f,0.554688f, -0.304688f,0.554688f, -0.3125f,0.554688f, -0.320313f,0.554688f, -0.328125f,0.554688f, -0.335938f,0.554688f, -0.34375f,0.554688f, -0.351563f,0.554688f, -0.359375f,0.554688f, -0.367188f,0.554688f, -0.375f,0.554688f, -0.382813f,0.554688f, -0.390625f,0.554688f, -0.398438f,0.554688f, -0.40625f,0.554688f, -0.414063f,0.554688f, -0.421875f,0.554688f, -0.429688f,0.554688f, -0.4375f,0.554688f, -0.445313f,0.554688f, -0.453125f,0.554688f, -0.460938f,0.554688f, -0.46875f,0.554688f, -0.476563f,0.554688f, -0.484375f,0.554688f, -0.492188f,0.554688f, -0.5f,0.554688f, -0.507813f,0.554688f, -0.0f,0.5625f, -0.0078125f,0.5625f, -0.015625f,0.5625f, -0.0234375f,0.5625f, -0.03125f,0.5625f, -0.0390625f,0.5625f, -0.046875f,0.5625f, -0.0546875f,0.5625f, -0.0625f,0.5625f, -0.0703125f,0.5625f, -0.078125f,0.5625f, -0.0859375f,0.5625f, -0.09375f,0.5625f, -0.101563f,0.5625f, -0.109375f,0.5625f, -0.117188f,0.5625f, -0.125f,0.5625f, -0.132813f,0.5625f, -0.140625f,0.5625f, -0.148438f,0.5625f, -0.15625f,0.5625f, -0.164063f,0.5625f, -0.171875f,0.5625f, -0.179688f,0.5625f, -0.1875f,0.5625f, -0.195313f,0.5625f, -0.203125f,0.5625f, -0.210938f,0.5625f, -0.21875f,0.5625f, -0.226563f,0.5625f, -0.234375f,0.5625f, -0.242188f,0.5625f, -0.25f,0.5625f, -0.257813f,0.5625f, -0.265625f,0.5625f, -0.273438f,0.5625f, -0.28125f,0.5625f, -0.289063f,0.5625f, -0.296875f,0.5625f, -0.304688f,0.5625f, -0.3125f,0.5625f, -0.320313f,0.5625f, -0.328125f,0.5625f, -0.335938f,0.5625f, -0.34375f,0.5625f, -0.351563f,0.5625f, -0.359375f,0.5625f, -0.367188f,0.5625f, -0.375f,0.5625f, -0.382813f,0.5625f, -0.390625f,0.5625f, -0.398438f,0.5625f, -0.40625f,0.5625f, -0.414063f,0.5625f, -0.421875f,0.5625f, -0.429688f,0.5625f, -0.4375f,0.5625f, -0.445313f,0.5625f, -0.453125f,0.5625f, -0.460938f,0.5625f, -0.46875f,0.5625f, -0.476563f,0.5625f, -0.484375f,0.5625f, -0.492188f,0.5625f, -0.5f,0.5625f, -0.507813f,0.5625f, -0.0f,0.570313f, -0.0078125f,0.570313f, -0.015625f,0.570313f, -0.0234375f,0.570313f, -0.03125f,0.570313f, -0.0390625f,0.570313f, -0.046875f,0.570313f, -0.0546875f,0.570313f, -0.0625f,0.570313f, -0.0703125f,0.570313f, -0.078125f,0.570313f, -0.0859375f,0.570313f, -0.09375f,0.570313f, -0.101563f,0.570313f, -0.109375f,0.570313f, -0.117188f,0.570313f, -0.125f,0.570313f, -0.132813f,0.570313f, -0.140625f,0.570313f, -0.148438f,0.570313f, -0.15625f,0.570313f, -0.164063f,0.570313f, -0.171875f,0.570313f, -0.179688f,0.570313f, -0.1875f,0.570313f, -0.195313f,0.570313f, -0.203125f,0.570313f, -0.210938f,0.570313f, -0.21875f,0.570313f, -0.226563f,0.570313f, -0.234375f,0.570313f, -0.242188f,0.570313f, -0.25f,0.570313f, -0.257813f,0.570313f, -0.265625f,0.570313f, -0.273438f,0.570313f, -0.28125f,0.570313f, -0.289063f,0.570313f, -0.296875f,0.570313f, -0.304688f,0.570313f, -0.3125f,0.570313f, -0.320313f,0.570313f, -0.328125f,0.570313f, -0.335938f,0.570313f, -0.34375f,0.570313f, -0.351563f,0.570313f, -0.359375f,0.570313f, -0.367188f,0.570313f, -0.375f,0.570313f, -0.382813f,0.570313f, -0.390625f,0.570313f, -0.398438f,0.570313f, -0.40625f,0.570313f, -0.414063f,0.570313f, -0.421875f,0.570313f, -0.429688f,0.570313f, -0.4375f,0.570313f, -0.445313f,0.570313f, -0.453125f,0.570313f, -0.460938f,0.570313f, -0.46875f,0.570313f, -0.476563f,0.570313f, -0.484375f,0.570313f, -0.492188f,0.570313f, -0.5f,0.570313f, -0.507813f,0.570313f, -0.0f,0.578125f, -0.0078125f,0.578125f, -0.015625f,0.578125f, -0.0234375f,0.578125f, -0.03125f,0.578125f, -0.0390625f,0.578125f, -0.046875f,0.578125f, -0.0546875f,0.578125f, -0.0625f,0.578125f, -0.0703125f,0.578125f, -0.078125f,0.578125f, -0.0859375f,0.578125f, -0.09375f,0.578125f, -0.101563f,0.578125f, -0.109375f,0.578125f, -0.117188f,0.578125f, -0.125f,0.578125f, -0.132813f,0.578125f, -0.140625f,0.578125f, -0.148438f,0.578125f, -0.15625f,0.578125f, -0.164063f,0.578125f, -0.171875f,0.578125f, -0.179688f,0.578125f, -0.1875f,0.578125f, -0.195313f,0.578125f, -0.203125f,0.578125f, -0.210938f,0.578125f, -0.21875f,0.578125f, -0.226563f,0.578125f, -0.234375f,0.578125f, -0.242188f,0.578125f, -0.25f,0.578125f, -0.257813f,0.578125f, -0.265625f,0.578125f, -0.273438f,0.578125f, -0.28125f,0.578125f, -0.289063f,0.578125f, -0.296875f,0.578125f, -0.304688f,0.578125f, -0.3125f,0.578125f, -0.320313f,0.578125f, -0.328125f,0.578125f, -0.335938f,0.578125f, -0.34375f,0.578125f, -0.351563f,0.578125f, -0.359375f,0.578125f, -0.367188f,0.578125f, -0.375f,0.578125f, -0.382813f,0.578125f, -0.390625f,0.578125f, -0.398438f,0.578125f, -0.40625f,0.578125f, -0.414063f,0.578125f, -0.421875f,0.578125f, -0.429688f,0.578125f, -0.4375f,0.578125f, -0.445313f,0.578125f, -0.453125f,0.578125f, -0.460938f,0.578125f, -0.46875f,0.578125f, -0.476563f,0.578125f, -0.484375f,0.578125f, -0.492188f,0.578125f, -0.5f,0.578125f, -0.507813f,0.578125f, -0.0f,0.585938f, -0.0078125f,0.585938f, -0.015625f,0.585938f, -0.0234375f,0.585938f, -0.03125f,0.585938f, -0.0390625f,0.585938f, -0.046875f,0.585938f, -0.0546875f,0.585938f, -0.0625f,0.585938f, -0.0703125f,0.585938f, -0.078125f,0.585938f, -0.0859375f,0.585938f, -0.09375f,0.585938f, -0.101563f,0.585938f, -0.109375f,0.585938f, -0.117188f,0.585938f, -0.125f,0.585938f, -0.132813f,0.585938f, -0.140625f,0.585938f, -0.148438f,0.585938f, -0.15625f,0.585938f, -0.164063f,0.585938f, -0.171875f,0.585938f, -0.179688f,0.585938f, -0.1875f,0.585938f, -0.195313f,0.585938f, -0.203125f,0.585938f, -0.210938f,0.585938f, -0.21875f,0.585938f, -0.226563f,0.585938f, -0.234375f,0.585938f, -0.242188f,0.585938f, -0.25f,0.585938f, -0.257813f,0.585938f, -0.265625f,0.585938f, -0.273438f,0.585938f, -0.28125f,0.585938f, -0.289063f,0.585938f, -0.296875f,0.585938f, -0.304688f,0.585938f, -0.3125f,0.585938f, -0.320313f,0.585938f, -0.328125f,0.585938f, -0.335938f,0.585938f, -0.34375f,0.585938f, -0.351563f,0.585938f, -0.359375f,0.585938f, -0.367188f,0.585938f, -0.375f,0.585938f, -0.382813f,0.585938f, -0.390625f,0.585938f, -0.398438f,0.585938f, -0.40625f,0.585938f, -0.414063f,0.585938f, -0.421875f,0.585938f, -0.429688f,0.585938f, -0.4375f,0.585938f, -0.445313f,0.585938f, -0.453125f,0.585938f, -0.460938f,0.585938f, -0.46875f,0.585938f, -0.476563f,0.585938f, -0.484375f,0.585938f, -0.492188f,0.585938f, -0.5f,0.585938f, -0.507813f,0.585938f, -0.0f,0.59375f, -0.0078125f,0.59375f, -0.015625f,0.59375f, -0.0234375f,0.59375f, -0.03125f,0.59375f, -0.0390625f,0.59375f, -0.046875f,0.59375f, -0.0546875f,0.59375f, -0.0625f,0.59375f, -0.0703125f,0.59375f, -0.078125f,0.59375f, -0.0859375f,0.59375f, -0.09375f,0.59375f, -0.101563f,0.59375f, -0.109375f,0.59375f, -0.117188f,0.59375f, -0.125f,0.59375f, -0.132813f,0.59375f, -0.140625f,0.59375f, -0.148438f,0.59375f, -0.15625f,0.59375f, -0.164063f,0.59375f, -0.171875f,0.59375f, -0.179688f,0.59375f, -0.1875f,0.59375f, -0.195313f,0.59375f, -0.203125f,0.59375f, -0.210938f,0.59375f, -0.21875f,0.59375f, -0.226563f,0.59375f, -0.234375f,0.59375f, -0.242188f,0.59375f, -0.25f,0.59375f, -0.257813f,0.59375f, -0.265625f,0.59375f, -0.273438f,0.59375f, -0.28125f,0.59375f, -0.289063f,0.59375f, -0.296875f,0.59375f, -0.304688f,0.59375f, -0.3125f,0.59375f, -0.320313f,0.59375f, -0.328125f,0.59375f, -0.335938f,0.59375f, -0.34375f,0.59375f, -0.351563f,0.59375f, -0.359375f,0.59375f, -0.367188f,0.59375f, -0.375f,0.59375f, -0.382813f,0.59375f, -0.390625f,0.59375f, -0.398438f,0.59375f, -0.40625f,0.59375f, -0.414063f,0.59375f, -0.421875f,0.59375f, -0.429688f,0.59375f, -0.4375f,0.59375f, -0.445313f,0.59375f, -0.453125f,0.59375f, -0.460938f,0.59375f, -0.46875f,0.59375f, -0.476563f,0.59375f, -0.484375f,0.59375f, -0.492188f,0.59375f, -0.5f,0.59375f, -0.507813f,0.59375f, -0.0f,0.601563f, -0.0078125f,0.601563f, -0.015625f,0.601563f, -0.0234375f,0.601563f, -0.03125f,0.601563f, -0.0390625f,0.601563f, -0.046875f,0.601563f, -0.0546875f,0.601563f, -0.0625f,0.601563f, -0.0703125f,0.601563f, -0.078125f,0.601563f, -0.0859375f,0.601563f, -0.09375f,0.601563f, -0.101563f,0.601563f, -0.109375f,0.601563f, -0.117188f,0.601563f, -0.125f,0.601563f, -0.132813f,0.601563f, -0.140625f,0.601563f, -0.148438f,0.601563f, -0.15625f,0.601563f, -0.164063f,0.601563f, -0.171875f,0.601563f, -0.179688f,0.601563f, -0.1875f,0.601563f, -0.195313f,0.601563f, -0.203125f,0.601563f, -0.210938f,0.601563f, -0.21875f,0.601563f, -0.226563f,0.601563f, -0.234375f,0.601563f, -0.242188f,0.601563f, -0.25f,0.601563f, -0.257813f,0.601563f, -0.265625f,0.601563f, -0.273438f,0.601563f, -0.28125f,0.601563f, -0.289063f,0.601563f, -0.296875f,0.601563f, -0.304688f,0.601563f, -0.3125f,0.601563f, -0.320313f,0.601563f, -0.328125f,0.601563f, -0.335938f,0.601563f, -0.34375f,0.601563f, -0.351563f,0.601563f, -0.359375f,0.601563f, -0.367188f,0.601563f, -0.375f,0.601563f, -0.382813f,0.601563f, -0.390625f,0.601563f, -0.398438f,0.601563f, -0.40625f,0.601563f, -0.414063f,0.601563f, -0.421875f,0.601563f, -0.429688f,0.601563f, -0.4375f,0.601563f, -0.445313f,0.601563f, -0.453125f,0.601563f, -0.460938f,0.601563f, -0.46875f,0.601563f, -0.476563f,0.601563f, -0.484375f,0.601563f, -0.492188f,0.601563f, -0.5f,0.601563f, -0.507813f,0.601563f, -0.0f,0.609375f, -0.0078125f,0.609375f, -0.015625f,0.609375f, -0.0234375f,0.609375f, -0.03125f,0.609375f, -0.0390625f,0.609375f, -0.046875f,0.609375f, -0.0546875f,0.609375f, -0.0625f,0.609375f, -0.0703125f,0.609375f, -0.078125f,0.609375f, -0.0859375f,0.609375f, -0.09375f,0.609375f, -0.101563f,0.609375f, -0.109375f,0.609375f, -0.117188f,0.609375f, -0.125f,0.609375f, -0.132813f,0.609375f, -0.140625f,0.609375f, -0.148438f,0.609375f, -0.15625f,0.609375f, -0.164063f,0.609375f, -0.171875f,0.609375f, -0.179688f,0.609375f, -0.1875f,0.609375f, -0.195313f,0.609375f, -0.203125f,0.609375f, -0.210938f,0.609375f, -0.21875f,0.609375f, -0.226563f,0.609375f, -0.234375f,0.609375f, -0.242188f,0.609375f, -0.25f,0.609375f, -0.257813f,0.609375f, -0.265625f,0.609375f, -0.273438f,0.609375f, -0.28125f,0.609375f, -0.289063f,0.609375f, -0.296875f,0.609375f, -0.304688f,0.609375f, -0.3125f,0.609375f, -0.320313f,0.609375f, -0.328125f,0.609375f, -0.335938f,0.609375f, -0.34375f,0.609375f, -0.351563f,0.609375f, -0.359375f,0.609375f, -0.367188f,0.609375f, -0.375f,0.609375f, -0.382813f,0.609375f, -0.390625f,0.609375f, -0.398438f,0.609375f, -0.40625f,0.609375f, -0.414063f,0.609375f, -0.421875f,0.609375f, -0.429688f,0.609375f, -0.4375f,0.609375f, -0.445313f,0.609375f, -0.453125f,0.609375f, -0.460938f,0.609375f, -0.46875f,0.609375f, -0.476563f,0.609375f, -0.484375f,0.609375f, -0.492188f,0.609375f, -0.5f,0.609375f, -0.507813f,0.609375f, -0.0f,0.617188f, -0.0078125f,0.617188f, -0.015625f,0.617188f, -0.0234375f,0.617188f, -0.03125f,0.617188f, -0.0390625f,0.617188f, -0.046875f,0.617188f, -0.0546875f,0.617188f, -0.0625f,0.617188f, -0.0703125f,0.617188f, -0.078125f,0.617188f, -0.0859375f,0.617188f, -0.09375f,0.617188f, -0.101563f,0.617188f, -0.109375f,0.617188f, -0.117188f,0.617188f, -0.125f,0.617188f, -0.132813f,0.617188f, -0.140625f,0.617188f, -0.148438f,0.617188f, -0.15625f,0.617188f, -0.164063f,0.617188f, -0.171875f,0.617188f, -0.179688f,0.617188f, -0.1875f,0.617188f, -0.195313f,0.617188f, -0.203125f,0.617188f, -0.210938f,0.617188f, -0.21875f,0.617188f, -0.226563f,0.617188f, -0.234375f,0.617188f, -0.242188f,0.617188f, -0.25f,0.617188f, -0.257813f,0.617188f, -0.265625f,0.617188f, -0.273438f,0.617188f, -0.28125f,0.617188f, -0.289063f,0.617188f, -0.296875f,0.617188f, -0.304688f,0.617188f, -0.3125f,0.617188f, -0.320313f,0.617188f, -0.328125f,0.617188f, -0.335938f,0.617188f, -0.34375f,0.617188f, -0.351563f,0.617188f, -0.359375f,0.617188f, -0.367188f,0.617188f, -0.375f,0.617188f, -0.382813f,0.617188f, -0.390625f,0.617188f, -0.398438f,0.617188f, -0.40625f,0.617188f, -0.414063f,0.617188f, -0.421875f,0.617188f, -0.429688f,0.617188f, -0.4375f,0.617188f, -0.445313f,0.617188f, -0.453125f,0.617188f, -0.460938f,0.617188f, -0.46875f,0.617188f, -0.476563f,0.617188f, -0.484375f,0.617188f, -0.492188f,0.617188f, -0.5f,0.617188f, -0.507813f,0.617188f, -0.0f,0.625f, -0.0078125f,0.625f, -0.015625f,0.625f, -0.0234375f,0.625f, -0.03125f,0.625f, -0.0390625f,0.625f, -0.046875f,0.625f, -0.0546875f,0.625f, -0.0625f,0.625f, -0.0703125f,0.625f, -0.078125f,0.625f, -0.0859375f,0.625f, -0.09375f,0.625f, -0.101563f,0.625f, -0.109375f,0.625f, -0.117188f,0.625f, -0.125f,0.625f, -0.132813f,0.625f, -0.140625f,0.625f, -0.148438f,0.625f, -0.15625f,0.625f, -0.164063f,0.625f, -0.171875f,0.625f, -0.179688f,0.625f, -0.1875f,0.625f, -0.195313f,0.625f, -0.203125f,0.625f, -0.210938f,0.625f, -0.21875f,0.625f, -0.226563f,0.625f, -0.234375f,0.625f, -0.242188f,0.625f, -0.25f,0.625f, -0.257813f,0.625f, -0.265625f,0.625f, -0.273438f,0.625f, -0.28125f,0.625f, -0.289063f,0.625f, -0.296875f,0.625f, -0.304688f,0.625f, -0.3125f,0.625f, -0.320313f,0.625f, -0.328125f,0.625f, -0.335938f,0.625f, -0.34375f,0.625f, -0.351563f,0.625f, -0.359375f,0.625f, -0.367188f,0.625f, -0.375f,0.625f, -0.382813f,0.625f, -0.390625f,0.625f, -0.398438f,0.625f, -0.40625f,0.625f, -0.414063f,0.625f, -0.421875f,0.625f, -0.429688f,0.625f, -0.4375f,0.625f, -0.445313f,0.625f, -0.453125f,0.625f, -0.460938f,0.625f, -0.46875f,0.625f, -0.476563f,0.625f, -0.484375f,0.625f, -0.492188f,0.625f, -0.5f,0.625f, -0.507813f,0.625f, -0.0f,0.632813f, -0.0078125f,0.632813f, -0.015625f,0.632813f, -0.0234375f,0.632813f, -0.03125f,0.632813f, -0.0390625f,0.632813f, -0.046875f,0.632813f, -0.0546875f,0.632813f, -0.0625f,0.632813f, -0.0703125f,0.632813f, -0.078125f,0.632813f, -0.0859375f,0.632813f, -0.09375f,0.632813f, -0.101563f,0.632813f, -0.109375f,0.632813f, -0.117188f,0.632813f, -0.125f,0.632813f, -0.132813f,0.632813f, -0.140625f,0.632813f, -0.148438f,0.632813f, -0.15625f,0.632813f, -0.164063f,0.632813f, -0.171875f,0.632813f, -0.179688f,0.632813f, -0.1875f,0.632813f, -0.195313f,0.632813f, -0.203125f,0.632813f, -0.210938f,0.632813f, -0.21875f,0.632813f, -0.226563f,0.632813f, -0.234375f,0.632813f, -0.242188f,0.632813f, -0.25f,0.632813f, -0.257813f,0.632813f, -0.265625f,0.632813f, -0.273438f,0.632813f, -0.28125f,0.632813f, -0.289063f,0.632813f, -0.296875f,0.632813f, -0.304688f,0.632813f, -0.3125f,0.632813f, -0.320313f,0.632813f, -0.328125f,0.632813f, -0.335938f,0.632813f, -0.34375f,0.632813f, -0.351563f,0.632813f, -0.359375f,0.632813f, -0.367188f,0.632813f, -0.375f,0.632813f, -0.382813f,0.632813f, -0.390625f,0.632813f, -0.398438f,0.632813f, -0.40625f,0.632813f, -0.414063f,0.632813f, -0.421875f,0.632813f, -0.429688f,0.632813f, -0.4375f,0.632813f, -0.445313f,0.632813f, -0.453125f,0.632813f, -0.460938f,0.632813f, -0.46875f,0.632813f, -0.476563f,0.632813f, -0.484375f,0.632813f, -0.492188f,0.632813f, -0.5f,0.632813f, -0.507813f,0.632813f, -0.0f,0.640625f, -0.0078125f,0.640625f, -0.015625f,0.640625f, -0.0234375f,0.640625f, -0.03125f,0.640625f, -0.0390625f,0.640625f, -0.046875f,0.640625f, -0.0546875f,0.640625f, -0.0625f,0.640625f, -0.0703125f,0.640625f, -0.078125f,0.640625f, -0.0859375f,0.640625f, -0.09375f,0.640625f, -0.101563f,0.640625f, -0.109375f,0.640625f, -0.117188f,0.640625f, -0.125f,0.640625f, -0.132813f,0.640625f, -0.140625f,0.640625f, -0.148438f,0.640625f, -0.15625f,0.640625f, -0.164063f,0.640625f, -0.171875f,0.640625f, -0.179688f,0.640625f, -0.1875f,0.640625f, -0.195313f,0.640625f, -0.203125f,0.640625f, -0.210938f,0.640625f, -0.21875f,0.640625f, -0.226563f,0.640625f, -0.234375f,0.640625f, -0.242188f,0.640625f, -0.25f,0.640625f, -0.257813f,0.640625f, -0.265625f,0.640625f, -0.273438f,0.640625f, -0.28125f,0.640625f, -0.289063f,0.640625f, -0.296875f,0.640625f, -0.304688f,0.640625f, -0.3125f,0.640625f, -0.320313f,0.640625f, -0.328125f,0.640625f, -0.335938f,0.640625f, -0.34375f,0.640625f, -0.351563f,0.640625f, -0.359375f,0.640625f, -0.367188f,0.640625f, -0.375f,0.640625f, -0.382813f,0.640625f, -0.390625f,0.640625f, -0.398438f,0.640625f, -0.40625f,0.640625f, -0.414063f,0.640625f, -0.421875f,0.640625f, -0.429688f,0.640625f, -0.4375f,0.640625f, -0.445313f,0.640625f, -0.453125f,0.640625f, -0.460938f,0.640625f, -0.46875f,0.640625f, -0.476563f,0.640625f, -0.484375f,0.640625f, -0.492188f,0.640625f, -0.5f,0.640625f, -0.507813f,0.640625f, -0.0f,0.648438f, -0.0078125f,0.648438f, -0.015625f,0.648438f, -0.0234375f,0.648438f, -0.03125f,0.648438f, -0.0390625f,0.648438f, -0.046875f,0.648438f, -0.0546875f,0.648438f, -0.0625f,0.648438f, -0.0703125f,0.648438f, -0.078125f,0.648438f, -0.0859375f,0.648438f, -0.09375f,0.648438f, -0.101563f,0.648438f, -0.109375f,0.648438f, -0.117188f,0.648438f, -0.125f,0.648438f, -0.132813f,0.648438f, -0.140625f,0.648438f, -0.148438f,0.648438f, -0.15625f,0.648438f, -0.164063f,0.648438f, -0.171875f,0.648438f, -0.179688f,0.648438f, -0.1875f,0.648438f, -0.195313f,0.648438f, -0.203125f,0.648438f, -0.210938f,0.648438f, -0.21875f,0.648438f, -0.226563f,0.648438f, -0.234375f,0.648438f, -0.242188f,0.648438f, -0.25f,0.648438f, -0.257813f,0.648438f, -0.265625f,0.648438f, -0.273438f,0.648438f, -0.28125f,0.648438f, -0.289063f,0.648438f, -0.296875f,0.648438f, -0.304688f,0.648438f, -0.3125f,0.648438f, -0.320313f,0.648438f, -0.328125f,0.648438f, -0.335938f,0.648438f, -0.34375f,0.648438f, -0.351563f,0.648438f, -0.359375f,0.648438f, -0.367188f,0.648438f, -0.375f,0.648438f, -0.382813f,0.648438f, -0.390625f,0.648438f, -0.398438f,0.648438f, -0.40625f,0.648438f, -0.414063f,0.648438f, -0.421875f,0.648438f, -0.429688f,0.648438f, -0.4375f,0.648438f, -0.445313f,0.648438f, -0.453125f,0.648438f, -0.460938f,0.648438f, -0.46875f,0.648438f, -0.476563f,0.648438f, -0.484375f,0.648438f, -0.492188f,0.648438f, -0.5f,0.648438f, -0.507813f,0.648438f, -0.0f,0.65625f, -0.0078125f,0.65625f, -0.015625f,0.65625f, -0.0234375f,0.65625f, -0.03125f,0.65625f, -0.0390625f,0.65625f, -0.046875f,0.65625f, -0.0546875f,0.65625f, -0.0625f,0.65625f, -0.0703125f,0.65625f, -0.078125f,0.65625f, -0.0859375f,0.65625f, -0.09375f,0.65625f, -0.101563f,0.65625f, -0.109375f,0.65625f, -0.117188f,0.65625f, -0.125f,0.65625f, -0.132813f,0.65625f, -0.140625f,0.65625f, -0.148438f,0.65625f, -0.15625f,0.65625f, -0.164063f,0.65625f, -0.171875f,0.65625f, -0.179688f,0.65625f, -0.1875f,0.65625f, -0.195313f,0.65625f, -0.203125f,0.65625f, -0.210938f,0.65625f, -0.21875f,0.65625f, -0.226563f,0.65625f, -0.234375f,0.65625f, -0.242188f,0.65625f, -0.25f,0.65625f, -0.257813f,0.65625f, -0.265625f,0.65625f, -0.273438f,0.65625f, -0.28125f,0.65625f, -0.289063f,0.65625f, -0.296875f,0.65625f, -0.304688f,0.65625f, -0.3125f,0.65625f, -0.320313f,0.65625f, -0.328125f,0.65625f, -0.335938f,0.65625f, -0.34375f,0.65625f, -0.351563f,0.65625f, -0.359375f,0.65625f, -0.367188f,0.65625f, -0.375f,0.65625f, -0.382813f,0.65625f, -0.390625f,0.65625f, -0.398438f,0.65625f, -0.40625f,0.65625f, -0.414063f,0.65625f, -0.421875f,0.65625f, -0.429688f,0.65625f, -0.4375f,0.65625f, -0.445313f,0.65625f, -0.453125f,0.65625f, -0.460938f,0.65625f, -0.46875f,0.65625f, -0.476563f,0.65625f, -0.484375f,0.65625f, -0.492188f,0.65625f, -0.5f,0.65625f, -0.507813f,0.65625f, -0.0f,0.664063f, -0.0078125f,0.664063f, -0.015625f,0.664063f, -0.0234375f,0.664063f, -0.03125f,0.664063f, -0.0390625f,0.664063f, -0.046875f,0.664063f, -0.0546875f,0.664063f, -0.0625f,0.664063f, -0.0703125f,0.664063f, -0.078125f,0.664063f, -0.0859375f,0.664063f, -0.09375f,0.664063f, -0.101563f,0.664063f, -0.109375f,0.664063f, -0.117188f,0.664063f, -0.125f,0.664063f, -0.132813f,0.664063f, -0.140625f,0.664063f, -0.148438f,0.664063f, -0.15625f,0.664063f, -0.164063f,0.664063f, -0.171875f,0.664063f, -0.179688f,0.664063f, -0.1875f,0.664063f, -0.195313f,0.664063f, -0.203125f,0.664063f, -0.210938f,0.664063f, -0.21875f,0.664063f, -0.226563f,0.664063f, -0.234375f,0.664063f, -0.242188f,0.664063f, -0.25f,0.664063f, -0.257813f,0.664063f, -0.265625f,0.664063f, -0.273438f,0.664063f, -0.28125f,0.664063f, -0.289063f,0.664063f, -0.296875f,0.664063f, -0.304688f,0.664063f, -0.3125f,0.664063f, -0.320313f,0.664063f, -0.328125f,0.664063f, -0.335938f,0.664063f, -0.34375f,0.664063f, -0.351563f,0.664063f, -0.359375f,0.664063f, -0.367188f,0.664063f, -0.375f,0.664063f, -0.382813f,0.664063f, -0.390625f,0.664063f, -0.398438f,0.664063f, -0.40625f,0.664063f, -0.414063f,0.664063f, -0.421875f,0.664063f, -0.429688f,0.664063f, -0.4375f,0.664063f, -0.445313f,0.664063f, -0.453125f,0.664063f, -0.460938f,0.664063f, -0.46875f,0.664063f, -0.476563f,0.664063f, -0.484375f,0.664063f, -0.492188f,0.664063f, -0.5f,0.664063f, -0.507813f,0.664063f, -0.0f,0.671875f, -0.0078125f,0.671875f, -0.015625f,0.671875f, -0.0234375f,0.671875f, -0.03125f,0.671875f, -0.0390625f,0.671875f, -0.046875f,0.671875f, -0.0546875f,0.671875f, -0.0625f,0.671875f, -0.0703125f,0.671875f, -0.078125f,0.671875f, -0.0859375f,0.671875f, -0.09375f,0.671875f, -0.101563f,0.671875f, -0.109375f,0.671875f, -0.117188f,0.671875f, -0.125f,0.671875f, -0.132813f,0.671875f, -0.140625f,0.671875f, -0.148438f,0.671875f, -0.15625f,0.671875f, -0.164063f,0.671875f, -0.171875f,0.671875f, -0.179688f,0.671875f, -0.1875f,0.671875f, -0.195313f,0.671875f, -0.203125f,0.671875f, -0.210938f,0.671875f, -0.21875f,0.671875f, -0.226563f,0.671875f, -0.234375f,0.671875f, -0.242188f,0.671875f, -0.25f,0.671875f, -0.257813f,0.671875f, -0.265625f,0.671875f, -0.273438f,0.671875f, -0.28125f,0.671875f, -0.289063f,0.671875f, -0.296875f,0.671875f, -0.304688f,0.671875f, -0.3125f,0.671875f, -0.320313f,0.671875f, -0.328125f,0.671875f, -0.335938f,0.671875f, -0.34375f,0.671875f, -0.351563f,0.671875f, -0.359375f,0.671875f, -0.367188f,0.671875f, -0.375f,0.671875f, -0.382813f,0.671875f, -0.390625f,0.671875f, -0.398438f,0.671875f, -0.40625f,0.671875f, -0.414063f,0.671875f, -0.421875f,0.671875f, -0.429688f,0.671875f, -0.4375f,0.671875f, -0.445313f,0.671875f, -0.453125f,0.671875f, -0.460938f,0.671875f, -0.46875f,0.671875f, -0.476563f,0.671875f, -0.484375f,0.671875f, -0.492188f,0.671875f, -0.5f,0.671875f, -0.507813f,0.671875f, -0.0f,0.679688f, -0.0078125f,0.679688f, -0.015625f,0.679688f, -0.0234375f,0.679688f, -0.03125f,0.679688f, -0.0390625f,0.679688f, -0.046875f,0.679688f, -0.0546875f,0.679688f, -0.0625f,0.679688f, -0.0703125f,0.679688f, -0.078125f,0.679688f, -0.0859375f,0.679688f, -0.09375f,0.679688f, -0.101563f,0.679688f, -0.109375f,0.679688f, -0.117188f,0.679688f, -0.125f,0.679688f, -0.132813f,0.679688f, -0.140625f,0.679688f, -0.148438f,0.679688f, -0.15625f,0.679688f, -0.164063f,0.679688f, -0.171875f,0.679688f, -0.179688f,0.679688f, -0.1875f,0.679688f, -0.195313f,0.679688f, -0.203125f,0.679688f, -0.210938f,0.679688f, -0.21875f,0.679688f, -0.226563f,0.679688f, -0.234375f,0.679688f, -0.242188f,0.679688f, -0.25f,0.679688f, -0.257813f,0.679688f, -0.265625f,0.679688f, -0.273438f,0.679688f, -0.28125f,0.679688f, -0.289063f,0.679688f, -0.296875f,0.679688f, -0.304688f,0.679688f, -0.3125f,0.679688f, -0.320313f,0.679688f, -0.328125f,0.679688f, -0.335938f,0.679688f, -0.34375f,0.679688f, -0.351563f,0.679688f, -0.359375f,0.679688f, -0.367188f,0.679688f, -0.375f,0.679688f, -0.382813f,0.679688f, -0.390625f,0.679688f, -0.398438f,0.679688f, -0.40625f,0.679688f, -0.414063f,0.679688f, -0.421875f,0.679688f, -0.429688f,0.679688f, -0.4375f,0.679688f, -0.445313f,0.679688f, -0.453125f,0.679688f, -0.460938f,0.679688f, -0.46875f,0.679688f, -0.476563f,0.679688f, -0.484375f,0.679688f, -0.492188f,0.679688f, -0.5f,0.679688f, -0.507813f,0.679688f, -0.0f,0.6875f, -0.0078125f,0.6875f, -0.015625f,0.6875f, -0.0234375f,0.6875f, -0.03125f,0.6875f, -0.0390625f,0.6875f, -0.046875f,0.6875f, -0.0546875f,0.6875f, -0.0625f,0.6875f, -0.0703125f,0.6875f, -0.078125f,0.6875f, -0.0859375f,0.6875f, -0.09375f,0.6875f, -0.101563f,0.6875f, -0.109375f,0.6875f, -0.117188f,0.6875f, -0.125f,0.6875f, -0.132813f,0.6875f, -0.140625f,0.6875f, -0.148438f,0.6875f, -0.15625f,0.6875f, -0.164063f,0.6875f, -0.171875f,0.6875f, -0.179688f,0.6875f, -0.1875f,0.6875f, -0.195313f,0.6875f, -0.203125f,0.6875f, -0.210938f,0.6875f, -0.21875f,0.6875f, -0.226563f,0.6875f, -0.234375f,0.6875f, -0.242188f,0.6875f, -0.25f,0.6875f, -0.257813f,0.6875f, -0.265625f,0.6875f, -0.273438f,0.6875f, -0.28125f,0.6875f, -0.289063f,0.6875f, -0.296875f,0.6875f, -0.304688f,0.6875f, -0.3125f,0.6875f, -0.320313f,0.6875f, -0.328125f,0.6875f, -0.335938f,0.6875f, -0.34375f,0.6875f, -0.351563f,0.6875f, -0.359375f,0.6875f, -0.367188f,0.6875f, -0.375f,0.6875f, -0.382813f,0.6875f, -0.390625f,0.6875f, -0.398438f,0.6875f, -0.40625f,0.6875f, -0.414063f,0.6875f, -0.421875f,0.6875f, -0.429688f,0.6875f, -0.4375f,0.6875f, -0.445313f,0.6875f, -0.453125f,0.6875f, -0.460938f,0.6875f, -0.46875f,0.6875f, -0.476563f,0.6875f, -0.484375f,0.6875f, -0.492188f,0.6875f, -0.5f,0.6875f, -0.507813f,0.6875f, -0.0f,0.695313f, -0.0078125f,0.695313f, -0.015625f,0.695313f, -0.0234375f,0.695313f, -0.03125f,0.695313f, -0.0390625f,0.695313f, -0.046875f,0.695313f, -0.0546875f,0.695313f, -0.0625f,0.695313f, -0.0703125f,0.695313f, -0.078125f,0.695313f, -0.0859375f,0.695313f, -0.09375f,0.695313f, -0.101563f,0.695313f, -0.109375f,0.695313f, -0.117188f,0.695313f, -0.125f,0.695313f, -0.132813f,0.695313f, -0.140625f,0.695313f, -0.148438f,0.695313f, -0.15625f,0.695313f, -0.164063f,0.695313f, -0.171875f,0.695313f, -0.179688f,0.695313f, -0.1875f,0.695313f, -0.195313f,0.695313f, -0.203125f,0.695313f, -0.210938f,0.695313f, -0.21875f,0.695313f, -0.226563f,0.695313f, -0.234375f,0.695313f, -0.242188f,0.695313f, -0.25f,0.695313f, -0.257813f,0.695313f, -0.265625f,0.695313f, -0.273438f,0.695313f, -0.28125f,0.695313f, -0.289063f,0.695313f, -0.296875f,0.695313f, -0.304688f,0.695313f, -0.3125f,0.695313f, -0.320313f,0.695313f, -0.328125f,0.695313f, -0.335938f,0.695313f, -0.34375f,0.695313f, -0.351563f,0.695313f, -0.359375f,0.695313f, -0.367188f,0.695313f, -0.375f,0.695313f, -0.382813f,0.695313f, -0.390625f,0.695313f, -0.398438f,0.695313f, -0.40625f,0.695313f, -0.414063f,0.695313f, -0.421875f,0.695313f, -0.429688f,0.695313f, -0.4375f,0.695313f, -0.445313f,0.695313f, -0.453125f,0.695313f, -0.460938f,0.695313f, -0.46875f,0.695313f, -0.476563f,0.695313f, -0.484375f,0.695313f, -0.492188f,0.695313f, -0.5f,0.695313f, -0.507813f,0.695313f, -0.0f,0.703125f, -0.0078125f,0.703125f, -0.015625f,0.703125f, -0.0234375f,0.703125f, -0.03125f,0.703125f, -0.0390625f,0.703125f, -0.046875f,0.703125f, -0.0546875f,0.703125f, -0.0625f,0.703125f, -0.0703125f,0.703125f, -0.078125f,0.703125f, -0.0859375f,0.703125f, -0.09375f,0.703125f, -0.101563f,0.703125f, -0.109375f,0.703125f, -0.117188f,0.703125f, -0.125f,0.703125f, -0.132813f,0.703125f, -0.140625f,0.703125f, -0.148438f,0.703125f, -0.15625f,0.703125f, -0.164063f,0.703125f, -0.171875f,0.703125f, -0.179688f,0.703125f, -0.1875f,0.703125f, -0.195313f,0.703125f, -0.203125f,0.703125f, -0.210938f,0.703125f, -0.21875f,0.703125f, -0.226563f,0.703125f, -0.234375f,0.703125f, -0.242188f,0.703125f, -0.25f,0.703125f, -0.257813f,0.703125f, -0.265625f,0.703125f, -0.273438f,0.703125f, -0.28125f,0.703125f, -0.289063f,0.703125f, -0.296875f,0.703125f, -0.304688f,0.703125f, -0.3125f,0.703125f, -0.320313f,0.703125f, -0.328125f,0.703125f, -0.335938f,0.703125f, -0.34375f,0.703125f, -0.351563f,0.703125f, -0.359375f,0.703125f, -0.367188f,0.703125f, -0.375f,0.703125f, -0.382813f,0.703125f, -0.390625f,0.703125f, -0.398438f,0.703125f, -0.40625f,0.703125f, -0.414063f,0.703125f, -0.421875f,0.703125f, -0.429688f,0.703125f, -0.4375f,0.703125f, -0.445313f,0.703125f, -0.453125f,0.703125f, -0.460938f,0.703125f, -0.46875f,0.703125f, -0.476563f,0.703125f, -0.484375f,0.703125f, -0.492188f,0.703125f, -0.5f,0.703125f, -0.507813f,0.703125f, -0.0f,0.710938f, -0.0078125f,0.710938f, -0.015625f,0.710938f, -0.0234375f,0.710938f, -0.03125f,0.710938f, -0.0390625f,0.710938f, -0.046875f,0.710938f, -0.0546875f,0.710938f, -0.0625f,0.710938f, -0.0703125f,0.710938f, -0.078125f,0.710938f, -0.0859375f,0.710938f, -0.09375f,0.710938f, -0.101563f,0.710938f, -0.109375f,0.710938f, -0.117188f,0.710938f, -0.125f,0.710938f, -0.132813f,0.710938f, -0.140625f,0.710938f, -0.148438f,0.710938f, -0.15625f,0.710938f, -0.164063f,0.710938f, -0.171875f,0.710938f, -0.179688f,0.710938f, -0.1875f,0.710938f, -0.195313f,0.710938f, -0.203125f,0.710938f, -0.210938f,0.710938f, -0.21875f,0.710938f, -0.226563f,0.710938f, -0.234375f,0.710938f, -0.242188f,0.710938f, -0.25f,0.710938f, -0.257813f,0.710938f, -0.265625f,0.710938f, -0.273438f,0.710938f, -0.28125f,0.710938f, -0.289063f,0.710938f, -0.296875f,0.710938f, -0.304688f,0.710938f, -0.3125f,0.710938f, -0.320313f,0.710938f, -0.328125f,0.710938f, -0.335938f,0.710938f, -0.34375f,0.710938f, -0.351563f,0.710938f, -0.359375f,0.710938f, -0.367188f,0.710938f, -0.375f,0.710938f, -0.382813f,0.710938f, -0.390625f,0.710938f, -0.398438f,0.710938f, -0.40625f,0.710938f, -0.414063f,0.710938f, -0.421875f,0.710938f, -0.429688f,0.710938f, -0.4375f,0.710938f, -0.445313f,0.710938f, -0.453125f,0.710938f, -0.460938f,0.710938f, -0.46875f,0.710938f, -0.476563f,0.710938f, -0.484375f,0.710938f, -0.492188f,0.710938f, -0.5f,0.710938f, -0.507813f,0.710938f, -0.0f,0.71875f, -0.0078125f,0.71875f, -0.015625f,0.71875f, -0.0234375f,0.71875f, -0.03125f,0.71875f, -0.0390625f,0.71875f, -0.046875f,0.71875f, -0.0546875f,0.71875f, -0.0625f,0.71875f, -0.0703125f,0.71875f, -0.078125f,0.71875f, -0.0859375f,0.71875f, -0.09375f,0.71875f, -0.101563f,0.71875f, -0.109375f,0.71875f, -0.117188f,0.71875f, -0.125f,0.71875f, -0.132813f,0.71875f, -0.140625f,0.71875f, -0.148438f,0.71875f, -0.15625f,0.71875f, -0.164063f,0.71875f, -0.171875f,0.71875f, -0.179688f,0.71875f, -0.1875f,0.71875f, -0.195313f,0.71875f, -0.203125f,0.71875f, -0.210938f,0.71875f, -0.21875f,0.71875f, -0.226563f,0.71875f, -0.234375f,0.71875f, -0.242188f,0.71875f, -0.25f,0.71875f, -0.257813f,0.71875f, -0.265625f,0.71875f, -0.273438f,0.71875f, -0.28125f,0.71875f, -0.289063f,0.71875f, -0.296875f,0.71875f, -0.304688f,0.71875f, -0.3125f,0.71875f, -0.320313f,0.71875f, -0.328125f,0.71875f, -0.335938f,0.71875f, -0.34375f,0.71875f, -0.351563f,0.71875f, -0.359375f,0.71875f, -0.367188f,0.71875f, -0.375f,0.71875f, -0.382813f,0.71875f, -0.390625f,0.71875f, -0.398438f,0.71875f, -0.40625f,0.71875f, -0.414063f,0.71875f, -0.421875f,0.71875f, -0.429688f,0.71875f, -0.4375f,0.71875f, -0.445313f,0.71875f, -0.453125f,0.71875f, -0.460938f,0.71875f, -0.46875f,0.71875f, -0.476563f,0.71875f, -0.484375f,0.71875f, -0.492188f,0.71875f, -0.5f,0.71875f, -0.507813f,0.71875f, -0.0f,0.726563f, -0.0078125f,0.726563f, -0.015625f,0.726563f, -0.0234375f,0.726563f, -0.03125f,0.726563f, -0.0390625f,0.726563f, -0.046875f,0.726563f, -0.0546875f,0.726563f, -0.0625f,0.726563f, -0.0703125f,0.726563f, -0.078125f,0.726563f, -0.0859375f,0.726563f, -0.09375f,0.726563f, -0.101563f,0.726563f, -0.109375f,0.726563f, -0.117188f,0.726563f, -0.125f,0.726563f, -0.132813f,0.726563f, -0.140625f,0.726563f, -0.148438f,0.726563f, -0.15625f,0.726563f, -0.164063f,0.726563f, -0.171875f,0.726563f, -0.179688f,0.726563f, -0.1875f,0.726563f, -0.195313f,0.726563f, -0.203125f,0.726563f, -0.210938f,0.726563f, -0.21875f,0.726563f, -0.226563f,0.726563f, -0.234375f,0.726563f, -0.242188f,0.726563f, -0.25f,0.726563f, -0.257813f,0.726563f, -0.265625f,0.726563f, -0.273438f,0.726563f, -0.28125f,0.726563f, -0.289063f,0.726563f, -0.296875f,0.726563f, -0.304688f,0.726563f, -0.3125f,0.726563f, -0.320313f,0.726563f, -0.328125f,0.726563f, -0.335938f,0.726563f, -0.34375f,0.726563f, -0.351563f,0.726563f, -0.359375f,0.726563f, -0.367188f,0.726563f, -0.375f,0.726563f, -0.382813f,0.726563f, -0.390625f,0.726563f, -0.398438f,0.726563f, -0.40625f,0.726563f, -0.414063f,0.726563f, -0.421875f,0.726563f, -0.429688f,0.726563f, -0.4375f,0.726563f, -0.445313f,0.726563f, -0.453125f,0.726563f, -0.460938f,0.726563f, -0.46875f,0.726563f, -0.476563f,0.726563f, -0.484375f,0.726563f, -0.492188f,0.726563f, -0.5f,0.726563f, -0.507813f,0.726563f, -0.0f,0.734375f, -0.0078125f,0.734375f, -0.015625f,0.734375f, -0.0234375f,0.734375f, -0.03125f,0.734375f, -0.0390625f,0.734375f, -0.046875f,0.734375f, -0.0546875f,0.734375f, -0.0625f,0.734375f, -0.0703125f,0.734375f, -0.078125f,0.734375f, -0.0859375f,0.734375f, -0.09375f,0.734375f, -0.101563f,0.734375f, -0.109375f,0.734375f, -0.117188f,0.734375f, -0.125f,0.734375f, -0.132813f,0.734375f, -0.140625f,0.734375f, -0.148438f,0.734375f, -0.15625f,0.734375f, -0.164063f,0.734375f, -0.171875f,0.734375f, -0.179688f,0.734375f, -0.1875f,0.734375f, -0.195313f,0.734375f, -0.203125f,0.734375f, -0.210938f,0.734375f, -0.21875f,0.734375f, -0.226563f,0.734375f, -0.234375f,0.734375f, -0.242188f,0.734375f, -0.25f,0.734375f, -0.257813f,0.734375f, -0.265625f,0.734375f, -0.273438f,0.734375f, -0.28125f,0.734375f, -0.289063f,0.734375f, -0.296875f,0.734375f, -0.304688f,0.734375f, -0.3125f,0.734375f, -0.320313f,0.734375f, -0.328125f,0.734375f, -0.335938f,0.734375f, -0.34375f,0.734375f, -0.351563f,0.734375f, -0.359375f,0.734375f, -0.367188f,0.734375f, -0.375f,0.734375f, -0.382813f,0.734375f, -0.390625f,0.734375f, -0.398438f,0.734375f, -0.40625f,0.734375f, -0.414063f,0.734375f, -0.421875f,0.734375f, -0.429688f,0.734375f, -0.4375f,0.734375f, -0.445313f,0.734375f, -0.453125f,0.734375f, -0.460938f,0.734375f, -0.46875f,0.734375f, -0.476563f,0.734375f, -0.484375f,0.734375f, -0.492188f,0.734375f, -0.5f,0.734375f, -0.507813f,0.734375f, -0.0f,0.742188f, -0.0078125f,0.742188f, -0.015625f,0.742188f, -0.0234375f,0.742188f, -0.03125f,0.742188f, -0.0390625f,0.742188f, -0.046875f,0.742188f, -0.0546875f,0.742188f, -0.0625f,0.742188f, -0.0703125f,0.742188f, -0.078125f,0.742188f, -0.0859375f,0.742188f, -0.09375f,0.742188f, -0.101563f,0.742188f, -0.109375f,0.742188f, -0.117188f,0.742188f, -0.125f,0.742188f, -0.132813f,0.742188f, -0.140625f,0.742188f, -0.148438f,0.742188f, -0.15625f,0.742188f, -0.164063f,0.742188f, -0.171875f,0.742188f, -0.179688f,0.742188f, -0.1875f,0.742188f, -0.195313f,0.742188f, -0.203125f,0.742188f, -0.210938f,0.742188f, -0.21875f,0.742188f, -0.226563f,0.742188f, -0.234375f,0.742188f, -0.242188f,0.742188f, -0.25f,0.742188f, -0.257813f,0.742188f, -0.265625f,0.742188f, -0.273438f,0.742188f, -0.28125f,0.742188f, -0.289063f,0.742188f, -0.296875f,0.742188f, -0.304688f,0.742188f, -0.3125f,0.742188f, -0.320313f,0.742188f, -0.328125f,0.742188f, -0.335938f,0.742188f, -0.34375f,0.742188f, -0.351563f,0.742188f, -0.359375f,0.742188f, -0.367188f,0.742188f, -0.375f,0.742188f, -0.382813f,0.742188f, -0.390625f,0.742188f, -0.398438f,0.742188f, -0.40625f,0.742188f, -0.414063f,0.742188f, -0.421875f,0.742188f, -0.429688f,0.742188f, -0.4375f,0.742188f, -0.445313f,0.742188f, -0.453125f,0.742188f, -0.460938f,0.742188f, -0.46875f,0.742188f, -0.476563f,0.742188f, -0.484375f,0.742188f, -0.492188f,0.742188f, -0.5f,0.742188f, -0.507813f,0.742188f, -0.0f,0.75f, -0.0078125f,0.75f, -0.015625f,0.75f, -0.0234375f,0.75f, -0.03125f,0.75f, -0.0390625f,0.75f, -0.046875f,0.75f, -0.0546875f,0.75f, -0.0625f,0.75f, -0.0703125f,0.75f, -0.078125f,0.75f, -0.0859375f,0.75f, -0.09375f,0.75f, -0.101563f,0.75f, -0.109375f,0.75f, -0.117188f,0.75f, -0.125f,0.75f, -0.132813f,0.75f, -0.140625f,0.75f, -0.148438f,0.75f, -0.15625f,0.75f, -0.164063f,0.75f, -0.171875f,0.75f, -0.179688f,0.75f, -0.1875f,0.75f, -0.195313f,0.75f, -0.203125f,0.75f, -0.210938f,0.75f, -0.21875f,0.75f, -0.226563f,0.75f, -0.234375f,0.75f, -0.242188f,0.75f, -0.25f,0.75f, -0.257813f,0.75f, -0.265625f,0.75f, -0.273438f,0.75f, -0.28125f,0.75f, -0.289063f,0.75f, -0.296875f,0.75f, -0.304688f,0.75f, -0.3125f,0.75f, -0.320313f,0.75f, -0.328125f,0.75f, -0.335938f,0.75f, -0.34375f,0.75f, -0.351563f,0.75f, -0.359375f,0.75f, -0.367188f,0.75f, -0.375f,0.75f, -0.382813f,0.75f, -0.390625f,0.75f, -0.398438f,0.75f, -0.40625f,0.75f, -0.414063f,0.75f, -0.421875f,0.75f, -0.429688f,0.75f, -0.4375f,0.75f, -0.445313f,0.75f, -0.453125f,0.75f, -0.460938f,0.75f, -0.46875f,0.75f, -0.476563f,0.75f, -0.484375f,0.75f, -0.492188f,0.75f, -0.5f,0.75f, -0.507813f,0.75f, -}; - -unsigned short Landscape05Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -126,127,128, -129,128,127, -128,129,130, -131,130,129, -132,0,133, -2,133,0, -133,2,134, -4,134,2, -134,4,135, -6,135,4, -135,6,136, -8,136,6, -136,8,137, -10,137,8, -137,10,138, -12,138,10, -138,12,139, -14,139,12, -139,14,140, -16,140,14, -140,16,141, -18,141,16, -141,18,142, -20,142,18, -142,20,143, -22,143,20, -143,22,144, -24,144,22, -144,24,145, -26,145,24, -145,26,146, -28,146,26, -146,28,147, -30,147,28, -147,30,148, -32,148,30, -148,32,149, -34,149,32, -149,34,150, -36,150,34, -150,36,151, -38,151,36, -151,38,152, -40,152,38, -152,40,153, -42,153,40, -153,42,154, -44,154,42, -154,44,155, -46,155,44, -155,46,156, -48,156,46, -156,48,157, -50,157,48, -157,50,158, -52,158,50, -158,52,159, -54,159,52, -159,54,160, -56,160,54, -160,56,161, -58,161,56, -161,58,162, -60,162,58, -162,60,163, -62,163,60, -163,62,164, -64,164,62, -164,64,165, -66,165,64, -165,66,166, -68,166,66, -166,68,167, -70,167,68, -167,70,168, -72,168,70, -168,72,169, -74,169,72, -169,74,170, -76,170,74, -170,76,171, -78,171,76, -171,78,172, -80,172,78, -172,80,173, -82,173,80, -173,82,174, -84,174,82, -174,84,175, -86,175,84, -175,86,176, -88,176,86, -176,88,177, -90,177,88, -177,90,178, -92,178,90, -178,92,179, -94,179,92, -179,94,180, -96,180,94, -180,96,181, -98,181,96, -181,98,182, -100,182,98, -182,100,183, -102,183,100, -183,102,184, -104,184,102, -184,104,185, -106,185,104, -185,106,186, -108,186,106, -186,108,187, -110,187,108, -187,110,188, -112,188,110, -188,112,189, -114,189,112, -189,114,190, -116,190,114, -190,116,191, -118,191,116, -191,118,192, -120,192,118, -192,120,193, -122,193,120, -193,122,194, -124,194,122, -194,124,195, -126,195,124, -195,126,196, -128,196,126, -196,128,197, -130,197,128, -198,132,199, -133,199,132, -199,133,200, -134,200,133, -200,134,201, -135,201,134, -201,135,202, -136,202,135, -202,136,203, -137,203,136, -203,137,204, -138,204,137, -204,138,205, -139,205,138, -205,139,206, -140,206,139, -206,140,207, -141,207,140, -207,141,208, -142,208,141, -208,142,209, -143,209,142, -209,143,210, -144,210,143, -210,144,211, -145,211,144, -211,145,212, -146,212,145, -212,146,213, -147,213,146, -213,147,214, -148,214,147, -214,148,215, -149,215,148, -215,149,216, -150,216,149, -216,150,217, -151,217,150, -217,151,218, -152,218,151, -218,152,219, -153,219,152, -219,153,220, -154,220,153, -220,154,221, -155,221,154, -221,155,222, -156,222,155, -222,156,223, -157,223,156, -223,157,224, -158,224,157, -224,158,225, -159,225,158, -225,159,226, -160,226,159, -226,160,227, -161,227,160, -227,161,228, -162,228,161, -228,162,229, -163,229,162, -229,163,230, -164,230,163, -230,164,231, -165,231,164, -231,165,232, -166,232,165, -232,166,233, -167,233,166, -233,167,234, -168,234,167, -234,168,235, -169,235,168, -235,169,236, -170,236,169, -236,170,237, -171,237,170, -237,171,238, -172,238,171, -238,172,239, -173,239,172, -239,173,240, -174,240,173, -240,174,241, -175,241,174, -241,175,242, -176,242,175, -242,176,243, -177,243,176, -243,177,244, -178,244,177, -244,178,245, -179,245,178, -245,179,246, -180,246,179, -246,180,247, -181,247,180, -247,181,248, -182,248,181, -248,182,249, -183,249,182, -249,183,250, -184,250,183, -250,184,251, -185,251,184, -251,185,252, -186,252,185, -252,186,253, -187,253,186, -253,187,254, -188,254,187, -254,188,255, -189,255,188, -255,189,256, -190,256,189, -256,190,257, -191,257,190, -257,191,258, -192,258,191, -258,192,259, -193,259,192, -259,193,260, -194,260,193, -260,194,261, -195,261,194, -261,195,262, -196,262,195, -262,196,263, -197,263,196, -264,198,265, -199,265,198, -265,199,266, -200,266,199, -266,200,267, -201,267,200, -267,201,268, -202,268,201, -268,202,269, -203,269,202, -269,203,270, -204,270,203, -270,204,271, -205,271,204, -271,205,272, -206,272,205, -272,206,273, -207,273,206, -273,207,274, -208,274,207, -274,208,275, -209,275,208, -275,209,276, -210,276,209, -276,210,277, -211,277,210, -277,211,278, -212,278,211, -278,212,279, -213,279,212, -279,213,280, -214,280,213, -280,214,281, -215,281,214, -281,215,282, -216,282,215, -282,216,283, -217,283,216, -283,217,284, -218,284,217, -284,218,285, -219,285,218, -285,219,286, -220,286,219, -286,220,287, -221,287,220, -287,221,288, -222,288,221, -288,222,289, -223,289,222, -289,223,290, -224,290,223, -290,224,291, -225,291,224, -291,225,292, -226,292,225, -292,226,293, -227,293,226, -293,227,294, -228,294,227, -294,228,295, -229,295,228, -295,229,296, -230,296,229, -296,230,297, -231,297,230, -297,231,298, -232,298,231, -298,232,299, -233,299,232, -299,233,300, -234,300,233, -300,234,301, -235,301,234, -301,235,302, -236,302,235, -302,236,303, -237,303,236, -303,237,304, -238,304,237, -304,238,305, -239,305,238, -305,239,306, -240,306,239, -306,240,307, -241,307,240, -307,241,308, -242,308,241, -308,242,309, -243,309,242, -309,243,310, -244,310,243, -310,244,311, -245,311,244, -311,245,312, -246,312,245, -312,246,313, -247,313,246, -313,247,314, -248,314,247, -314,248,315, -249,315,248, -315,249,316, -250,316,249, -316,250,317, -251,317,250, -317,251,318, -252,318,251, -318,252,319, -253,319,252, -319,253,320, -254,320,253, -320,254,321, -255,321,254, -321,255,322, -256,322,255, -322,256,323, -257,323,256, -323,257,324, -258,324,257, -324,258,325, -259,325,258, -325,259,326, -260,326,259, -326,260,327, -261,327,260, -327,261,328, -262,328,261, -328,262,329, -263,329,262, -330,264,331, -265,331,264, -331,265,332, -266,332,265, -332,266,333, -267,333,266, -333,267,334, -268,334,267, -334,268,335, -269,335,268, -335,269,336, -270,336,269, -336,270,337, -271,337,270, -337,271,338, -272,338,271, -338,272,339, -273,339,272, -339,273,340, -274,340,273, -340,274,341, -275,341,274, -341,275,342, -276,342,275, -342,276,343, -277,343,276, -343,277,344, -278,344,277, -344,278,345, -279,345,278, -345,279,346, -280,346,279, -346,280,347, -281,347,280, -347,281,348, -282,348,281, -348,282,349, -283,349,282, -349,283,350, -284,350,283, -350,284,351, -285,351,284, -351,285,352, -286,352,285, -352,286,353, -287,353,286, -353,287,354, -288,354,287, -354,288,355, -289,355,288, -355,289,356, -290,356,289, -356,290,357, -291,357,290, -357,291,358, -292,358,291, -358,292,359, -293,359,292, -359,293,360, -294,360,293, -360,294,361, -295,361,294, -361,295,362, -296,362,295, -362,296,363, -297,363,296, -363,297,364, -298,364,297, -364,298,365, -299,365,298, -365,299,366, -300,366,299, -366,300,367, -301,367,300, -367,301,368, -302,368,301, -368,302,369, -303,369,302, -369,303,370, -304,370,303, -370,304,371, -305,371,304, -371,305,372, -306,372,305, -372,306,373, -307,373,306, -373,307,374, -308,374,307, -374,308,375, -309,375,308, -375,309,376, -310,376,309, -376,310,377, -311,377,310, -377,311,378, -312,378,311, -378,312,379, -313,379,312, -379,313,380, -314,380,313, -380,314,381, -315,381,314, -381,315,382, -316,382,315, -382,316,383, -317,383,316, -383,317,384, -318,384,317, -384,318,385, -319,385,318, -385,319,386, -320,386,319, -386,320,387, -321,387,320, -387,321,388, -322,388,321, -388,322,389, -323,389,322, -389,323,390, -324,390,323, -390,324,391, -325,391,324, -391,325,392, -326,392,325, -392,326,393, -327,393,326, -393,327,394, -328,394,327, -394,328,395, -329,395,328, -396,330,397, -331,397,330, -397,331,398, -332,398,331, -398,332,399, -333,399,332, -399,333,400, -334,400,333, -400,334,401, -335,401,334, -401,335,402, -336,402,335, -402,336,403, -337,403,336, -403,337,404, -338,404,337, -404,338,405, -339,405,338, -405,339,406, -340,406,339, -406,340,407, -341,407,340, -407,341,408, -342,408,341, -408,342,409, -343,409,342, -409,343,410, -344,410,343, -410,344,411, -345,411,344, -411,345,412, -346,412,345, -412,346,413, -347,413,346, -413,347,414, -348,414,347, -414,348,415, -349,415,348, -415,349,416, -350,416,349, -416,350,417, -351,417,350, -417,351,418, -352,418,351, -418,352,419, -353,419,352, -419,353,420, -354,420,353, -420,354,421, -355,421,354, -421,355,422, -356,422,355, -422,356,423, -357,423,356, -423,357,424, -358,424,357, -424,358,425, -359,425,358, -425,359,426, -360,426,359, -426,360,427, -361,427,360, -427,361,428, -362,428,361, -428,362,429, -363,429,362, -429,363,430, -364,430,363, -430,364,431, -365,431,364, -431,365,432, -366,432,365, -432,366,433, -367,433,366, -433,367,434, -368,434,367, -434,368,435, -369,435,368, -435,369,436, -370,436,369, -436,370,437, -371,437,370, -437,371,438, -372,438,371, -438,372,439, -373,439,372, -439,373,440, -374,440,373, -440,374,441, -375,441,374, -441,375,442, -376,442,375, -442,376,443, -377,443,376, -443,377,444, -378,444,377, -444,378,445, -379,445,378, -445,379,446, -380,446,379, -446,380,447, -381,447,380, -447,381,448, -382,448,381, -448,382,449, -383,449,382, -449,383,450, -384,450,383, -450,384,451, -385,451,384, -451,385,452, -386,452,385, -452,386,453, -387,453,386, -453,387,454, -388,454,387, -454,388,455, -389,455,388, -455,389,456, -390,456,389, -456,390,457, -391,457,390, -457,391,458, -392,458,391, -458,392,459, -393,459,392, -459,393,460, -394,460,393, -460,394,461, -395,461,394, -462,396,463, -397,463,396, -463,397,464, -398,464,397, -464,398,465, -399,465,398, -465,399,466, -400,466,399, -466,400,467, -401,467,400, -467,401,468, -402,468,401, -468,402,469, -403,469,402, -469,403,470, -404,470,403, -470,404,471, -405,471,404, -471,405,472, -406,472,405, -472,406,473, -407,473,406, -473,407,474, -408,474,407, -474,408,475, -409,475,408, -475,409,476, -410,476,409, -476,410,477, -411,477,410, -477,411,478, -412,478,411, -478,412,479, -413,479,412, -479,413,480, -414,480,413, -480,414,481, -415,481,414, -481,415,482, -416,482,415, -482,416,483, -417,483,416, -483,417,484, -418,484,417, -484,418,485, -419,485,418, -485,419,486, -420,486,419, -486,420,487, -421,487,420, -487,421,488, -422,488,421, -488,422,489, -423,489,422, -489,423,490, -424,490,423, -490,424,491, -425,491,424, -491,425,492, -426,492,425, -492,426,493, -427,493,426, -493,427,494, -428,494,427, -494,428,495, -429,495,428, -495,429,496, -430,496,429, -496,430,497, -431,497,430, -497,431,498, -432,498,431, -498,432,499, -433,499,432, -499,433,500, -434,500,433, -500,434,501, -435,501,434, -501,435,502, -436,502,435, -502,436,503, -437,503,436, -503,437,504, -438,504,437, -504,438,505, -439,505,438, -505,439,506, -440,506,439, -506,440,507, -441,507,440, -507,441,508, -442,508,441, -508,442,509, -443,509,442, -509,443,510, -444,510,443, -510,444,511, -445,511,444, -511,445,512, -446,512,445, -512,446,513, -447,513,446, -513,447,514, -448,514,447, -514,448,515, -449,515,448, -515,449,516, -450,516,449, -516,450,517, -451,517,450, -517,451,518, -452,518,451, -518,452,519, -453,519,452, -519,453,520, -454,520,453, -520,454,521, -455,521,454, -521,455,522, -456,522,455, -522,456,523, -457,523,456, -523,457,524, -458,524,457, -524,458,525, -459,525,458, -525,459,526, -460,526,459, -526,460,527, -461,527,460, -528,462,529, -463,529,462, -529,463,530, -464,530,463, -530,464,531, -465,531,464, -531,465,532, -466,532,465, -532,466,533, -467,533,466, -533,467,534, -468,534,467, -534,468,535, -469,535,468, -535,469,536, -470,536,469, -536,470,537, -471,537,470, -537,471,538, -472,538,471, -538,472,539, -473,539,472, -539,473,540, -474,540,473, -540,474,541, -475,541,474, -541,475,542, -476,542,475, -542,476,543, -477,543,476, -543,477,544, -478,544,477, -544,478,545, -479,545,478, -545,479,546, -480,546,479, -546,480,547, -481,547,480, -547,481,548, -482,548,481, -548,482,549, -483,549,482, -549,483,550, -484,550,483, -550,484,551, -485,551,484, -551,485,552, -486,552,485, -552,486,553, -487,553,486, -553,487,554, -488,554,487, -554,488,555, -489,555,488, -555,489,556, -490,556,489, -556,490,557, -491,557,490, -557,491,558, -492,558,491, -558,492,559, -493,559,492, -559,493,560, -494,560,493, -560,494,561, -495,561,494, -561,495,562, -496,562,495, -562,496,563, -497,563,496, -563,497,564, -498,564,497, -564,498,565, -499,565,498, -565,499,566, -500,566,499, -566,500,567, -501,567,500, -567,501,568, -502,568,501, -568,502,569, -503,569,502, -569,503,570, -504,570,503, -570,504,571, -505,571,504, -571,505,572, -506,572,505, -572,506,573, -507,573,506, -573,507,574, -508,574,507, -574,508,575, -509,575,508, -575,509,576, -510,576,509, -576,510,577, -511,577,510, -577,511,578, -512,578,511, -578,512,579, -513,579,512, -579,513,580, -514,580,513, -580,514,581, -515,581,514, -581,515,582, -516,582,515, -582,516,583, -517,583,516, -583,517,584, -518,584,517, -584,518,585, -519,585,518, -585,519,586, -520,586,519, -586,520,587, -521,587,520, -587,521,588, -522,588,521, -588,522,589, -523,589,522, -589,523,590, -524,590,523, -590,524,591, -525,591,524, -591,525,592, -526,592,525, -592,526,593, -527,593,526, -594,528,595, -529,595,528, -595,529,596, -530,596,529, -596,530,597, -531,597,530, -597,531,598, -532,598,531, -598,532,599, -533,599,532, -599,533,600, -534,600,533, -600,534,601, -535,601,534, -601,535,602, -536,602,535, -602,536,603, -537,603,536, -603,537,604, -538,604,537, -604,538,605, -539,605,538, -605,539,606, -540,606,539, -606,540,607, -541,607,540, -607,541,608, -542,608,541, -608,542,609, -543,609,542, -609,543,610, -544,610,543, -610,544,611, -545,611,544, -611,545,612, -546,612,545, -612,546,613, -547,613,546, -613,547,614, -548,614,547, -614,548,615, -549,615,548, -615,549,616, -550,616,549, -616,550,617, -551,617,550, -617,551,618, -552,618,551, -618,552,619, -553,619,552, -619,553,620, -554,620,553, -620,554,621, -555,621,554, -621,555,622, -556,622,555, -622,556,623, -557,623,556, -623,557,624, -558,624,557, -624,558,625, -559,625,558, -625,559,626, -560,626,559, -626,560,627, -561,627,560, -627,561,628, -562,628,561, -628,562,629, -563,629,562, -629,563,630, -564,630,563, -630,564,631, -565,631,564, -631,565,632, -566,632,565, -632,566,633, -567,633,566, -633,567,634, -568,634,567, -634,568,635, -569,635,568, -635,569,636, -570,636,569, -636,570,637, -571,637,570, -637,571,638, -572,638,571, -638,572,639, -573,639,572, -639,573,640, -574,640,573, -640,574,641, -575,641,574, -641,575,642, -576,642,575, -642,576,643, -577,643,576, -643,577,644, -578,644,577, -644,578,645, -579,645,578, -645,579,646, -580,646,579, -646,580,647, -581,647,580, -647,581,648, -582,648,581, -648,582,649, -583,649,582, -649,583,650, -584,650,583, -650,584,651, -585,651,584, -651,585,652, -586,652,585, -652,586,653, -587,653,586, -653,587,654, -588,654,587, -654,588,655, -589,655,588, -655,589,656, -590,656,589, -656,590,657, -591,657,590, -657,591,658, -592,658,591, -658,592,659, -593,659,592, -660,594,661, -595,661,594, -661,595,662, -596,662,595, -662,596,663, -597,663,596, -663,597,664, -598,664,597, -664,598,665, -599,665,598, -665,599,666, -600,666,599, -666,600,667, -601,667,600, -667,601,668, -602,668,601, -668,602,669, -603,669,602, -669,603,670, -604,670,603, -670,604,671, -605,671,604, -671,605,672, -606,672,605, -672,606,673, -607,673,606, -673,607,674, -608,674,607, -674,608,675, -609,675,608, -675,609,676, -610,676,609, -676,610,677, -611,677,610, -677,611,678, -612,678,611, -678,612,679, -613,679,612, -679,613,680, -614,680,613, -680,614,681, -615,681,614, -681,615,682, -616,682,615, -682,616,683, -617,683,616, -683,617,684, -618,684,617, -684,618,685, -619,685,618, -685,619,686, -620,686,619, -686,620,687, -621,687,620, -687,621,688, -622,688,621, -688,622,689, -623,689,622, -689,623,690, -624,690,623, -690,624,691, -625,691,624, -691,625,692, -626,692,625, -692,626,693, -627,693,626, -693,627,694, -628,694,627, -694,628,695, -629,695,628, -695,629,696, -630,696,629, -696,630,697, -631,697,630, -697,631,698, -632,698,631, -698,632,699, -633,699,632, -699,633,700, -634,700,633, -700,634,701, -635,701,634, -701,635,702, -636,702,635, -702,636,703, -637,703,636, -703,637,704, -638,704,637, -704,638,705, -639,705,638, -705,639,706, -640,706,639, -706,640,707, -641,707,640, -707,641,708, -642,708,641, -708,642,709, -643,709,642, -709,643,710, -644,710,643, -710,644,711, -645,711,644, -711,645,712, -646,712,645, -712,646,713, -647,713,646, -713,647,714, -648,714,647, -714,648,715, -649,715,648, -715,649,716, -650,716,649, -716,650,717, -651,717,650, -717,651,718, -652,718,651, -718,652,719, -653,719,652, -719,653,720, -654,720,653, -720,654,721, -655,721,654, -721,655,722, -656,722,655, -722,656,723, -657,723,656, -723,657,724, -658,724,657, -724,658,725, -659,725,658, -726,660,727, -661,727,660, -727,661,728, -662,728,661, -728,662,729, -663,729,662, -729,663,730, -664,730,663, -730,664,731, -665,731,664, -731,665,732, -666,732,665, -732,666,733, -667,733,666, -733,667,734, -668,734,667, -734,668,735, -669,735,668, -735,669,736, -670,736,669, -736,670,737, -671,737,670, -737,671,738, -672,738,671, -738,672,739, -673,739,672, -739,673,740, -674,740,673, -740,674,741, -675,741,674, -741,675,742, -676,742,675, -742,676,743, -677,743,676, -743,677,744, -678,744,677, -744,678,745, -679,745,678, -745,679,746, -680,746,679, -746,680,747, -681,747,680, -747,681,748, -682,748,681, -748,682,749, -683,749,682, -749,683,750, -684,750,683, -750,684,751, -685,751,684, -751,685,752, -686,752,685, -752,686,753, -687,753,686, -753,687,754, -688,754,687, -754,688,755, -689,755,688, -755,689,756, -690,756,689, -756,690,757, -691,757,690, -757,691,758, -692,758,691, -758,692,759, -693,759,692, -759,693,760, -694,760,693, -760,694,761, -695,761,694, -761,695,762, -696,762,695, -762,696,763, -697,763,696, -763,697,764, -698,764,697, -764,698,765, -699,765,698, -765,699,766, -700,766,699, -766,700,767, -701,767,700, -767,701,768, -702,768,701, -768,702,769, -703,769,702, -769,703,770, -704,770,703, -770,704,771, -705,771,704, -771,705,772, -706,772,705, -772,706,773, -707,773,706, -773,707,774, -708,774,707, -774,708,775, -709,775,708, -775,709,776, -710,776,709, -776,710,777, -711,777,710, -777,711,778, -712,778,711, -778,712,779, -713,779,712, -779,713,780, -714,780,713, -780,714,781, -715,781,714, -781,715,782, -716,782,715, -782,716,783, -717,783,716, -783,717,784, -718,784,717, -784,718,785, -719,785,718, -785,719,786, -720,786,719, -786,720,787, -721,787,720, -787,721,788, -722,788,721, -788,722,789, -723,789,722, -789,723,790, -724,790,723, -790,724,791, -725,791,724, -792,726,793, -727,793,726, -793,727,794, -728,794,727, -794,728,795, -729,795,728, -795,729,796, -730,796,729, -796,730,797, -731,797,730, -797,731,798, -732,798,731, -798,732,799, -733,799,732, -799,733,800, -734,800,733, -800,734,801, -735,801,734, -801,735,802, -736,802,735, -802,736,803, -737,803,736, -803,737,804, -738,804,737, -804,738,805, -739,805,738, -805,739,806, -740,806,739, -806,740,807, -741,807,740, -807,741,808, -742,808,741, -808,742,809, -743,809,742, -809,743,810, -744,810,743, -810,744,811, -745,811,744, -811,745,812, -746,812,745, -812,746,813, -747,813,746, -813,747,814, -748,814,747, -814,748,815, -749,815,748, -815,749,816, -750,816,749, -816,750,817, -751,817,750, -817,751,818, -752,818,751, -818,752,819, -753,819,752, -819,753,820, -754,820,753, -820,754,821, -755,821,754, -821,755,822, -756,822,755, -822,756,823, -757,823,756, -823,757,824, -758,824,757, -824,758,825, -759,825,758, -825,759,826, -760,826,759, -826,760,827, -761,827,760, -827,761,828, -762,828,761, -828,762,829, -763,829,762, -829,763,830, -764,830,763, -830,764,831, -765,831,764, -831,765,832, -766,832,765, -832,766,833, -767,833,766, -833,767,834, -768,834,767, -834,768,835, -769,835,768, -835,769,836, -770,836,769, -836,770,837, -771,837,770, -837,771,838, -772,838,771, -838,772,839, -773,839,772, -839,773,840, -774,840,773, -840,774,841, -775,841,774, -841,775,842, -776,842,775, -842,776,843, -777,843,776, -843,777,844, -778,844,777, -844,778,845, -779,845,778, -845,779,846, -780,846,779, -846,780,847, -781,847,780, -847,781,848, -782,848,781, -848,782,849, -783,849,782, -849,783,850, -784,850,783, -850,784,851, -785,851,784, -851,785,852, -786,852,785, -852,786,853, -787,853,786, -853,787,854, -788,854,787, -854,788,855, -789,855,788, -855,789,856, -790,856,789, -856,790,857, -791,857,790, -858,792,859, -793,859,792, -859,793,860, -794,860,793, -860,794,861, -795,861,794, -861,795,862, -796,862,795, -862,796,863, -797,863,796, -863,797,864, -798,864,797, -864,798,865, -799,865,798, -865,799,866, -800,866,799, -866,800,867, -801,867,800, -867,801,868, -802,868,801, -868,802,869, -803,869,802, -869,803,870, -804,870,803, -870,804,871, -805,871,804, -871,805,872, -806,872,805, -872,806,873, -807,873,806, -873,807,874, -808,874,807, -874,808,875, -809,875,808, -875,809,876, -810,876,809, -876,810,877, -811,877,810, -877,811,878, -812,878,811, -878,812,879, -813,879,812, -879,813,880, -814,880,813, -880,814,881, -815,881,814, -881,815,882, -816,882,815, -882,816,883, -817,883,816, -883,817,884, -818,884,817, -884,818,885, -819,885,818, -885,819,886, -820,886,819, -886,820,887, -821,887,820, -887,821,888, -822,888,821, -888,822,889, -823,889,822, -889,823,890, -824,890,823, -890,824,891, -825,891,824, -891,825,892, -826,892,825, -892,826,893, -827,893,826, -893,827,894, -828,894,827, -894,828,895, -829,895,828, -895,829,896, -830,896,829, -896,830,897, -831,897,830, -897,831,898, -832,898,831, -898,832,899, -833,899,832, -899,833,900, -834,900,833, -900,834,901, -835,901,834, -901,835,902, -836,902,835, -902,836,903, -837,903,836, -903,837,904, -838,904,837, -904,838,905, -839,905,838, -905,839,906, -840,906,839, -906,840,907, -841,907,840, -907,841,908, -842,908,841, -908,842,909, -843,909,842, -909,843,910, -844,910,843, -910,844,911, -845,911,844, -911,845,912, -846,912,845, -912,846,913, -847,913,846, -913,847,914, -848,914,847, -914,848,915, -849,915,848, -915,849,916, -850,916,849, -916,850,917, -851,917,850, -917,851,918, -852,918,851, -918,852,919, -853,919,852, -919,853,920, -854,920,853, -920,854,921, -855,921,854, -921,855,922, -856,922,855, -922,856,923, -857,923,856, -924,858,925, -859,925,858, -925,859,926, -860,926,859, -926,860,927, -861,927,860, -927,861,928, -862,928,861, -928,862,929, -863,929,862, -929,863,930, -864,930,863, -930,864,931, -865,931,864, -931,865,932, -866,932,865, -932,866,933, -867,933,866, -933,867,934, -868,934,867, -934,868,935, -869,935,868, -935,869,936, -870,936,869, -936,870,937, -871,937,870, -937,871,938, -872,938,871, -938,872,939, -873,939,872, -939,873,940, -874,940,873, -940,874,941, -875,941,874, -941,875,942, -876,942,875, -942,876,943, -877,943,876, -943,877,944, -878,944,877, -944,878,945, -879,945,878, -945,879,946, -880,946,879, -946,880,947, -881,947,880, -947,881,948, -882,948,881, -948,882,949, -883,949,882, -949,883,950, -884,950,883, -950,884,951, -885,951,884, -951,885,952, -886,952,885, -952,886,953, -887,953,886, -953,887,954, -888,954,887, -954,888,955, -889,955,888, -955,889,956, -890,956,889, -956,890,957, -891,957,890, -957,891,958, -892,958,891, -958,892,959, -893,959,892, -959,893,960, -894,960,893, -960,894,961, -895,961,894, -961,895,962, -896,962,895, -962,896,963, -897,963,896, -963,897,964, -898,964,897, -964,898,965, -899,965,898, -965,899,966, -900,966,899, -966,900,967, -901,967,900, -967,901,968, -902,968,901, -968,902,969, -903,969,902, -969,903,970, -904,970,903, -970,904,971, -905,971,904, -971,905,972, -906,972,905, -972,906,973, -907,973,906, -973,907,974, -908,974,907, -974,908,975, -909,975,908, -975,909,976, -910,976,909, -976,910,977, -911,977,910, -977,911,978, -912,978,911, -978,912,979, -913,979,912, -979,913,980, -914,980,913, -980,914,981, -915,981,914, -981,915,982, -916,982,915, -982,916,983, -917,983,916, -983,917,984, -918,984,917, -984,918,985, -919,985,918, -985,919,986, -920,986,919, -986,920,987, -921,987,920, -987,921,988, -922,988,921, -988,922,989, -923,989,922, -990,924,991, -925,991,924, -991,925,992, -926,992,925, -992,926,993, -927,993,926, -993,927,994, -928,994,927, -994,928,995, -929,995,928, -995,929,996, -930,996,929, -996,930,997, -931,997,930, -997,931,998, -932,998,931, -998,932,999, -933,999,932, -999,933,1000, -934,1000,933, -1000,934,1001, -935,1001,934, -1001,935,1002, -936,1002,935, -1002,936,1003, -937,1003,936, -1003,937,1004, -938,1004,937, -1004,938,1005, -939,1005,938, -1005,939,1006, -940,1006,939, -1006,940,1007, -941,1007,940, -1007,941,1008, -942,1008,941, -1008,942,1009, -943,1009,942, -1009,943,1010, -944,1010,943, -1010,944,1011, -945,1011,944, -1011,945,1012, -946,1012,945, -1012,946,1013, -947,1013,946, -1013,947,1014, -948,1014,947, -1014,948,1015, -949,1015,948, -1015,949,1016, -950,1016,949, -1016,950,1017, -951,1017,950, -1017,951,1018, -952,1018,951, -1018,952,1019, -953,1019,952, -1019,953,1020, -954,1020,953, -1020,954,1021, -955,1021,954, -1021,955,1022, -956,1022,955, -1022,956,1023, -957,1023,956, -1023,957,1024, -958,1024,957, -1024,958,1025, -959,1025,958, -1025,959,1026, -960,1026,959, -1026,960,1027, -961,1027,960, -1027,961,1028, -962,1028,961, -1028,962,1029, -963,1029,962, -1029,963,1030, -964,1030,963, -1030,964,1031, -965,1031,964, -1031,965,1032, -966,1032,965, -1032,966,1033, -967,1033,966, -1033,967,1034, -968,1034,967, -1034,968,1035, -969,1035,968, -1035,969,1036, -970,1036,969, -1036,970,1037, -971,1037,970, -1037,971,1038, -972,1038,971, -1038,972,1039, -973,1039,972, -1039,973,1040, -974,1040,973, -1040,974,1041, -975,1041,974, -1041,975,1042, -976,1042,975, -1042,976,1043, -977,1043,976, -1043,977,1044, -978,1044,977, -1044,978,1045, -979,1045,978, -1045,979,1046, -980,1046,979, -1046,980,1047, -981,1047,980, -1047,981,1048, -982,1048,981, -1048,982,1049, -983,1049,982, -1049,983,1050, -984,1050,983, -1050,984,1051, -985,1051,984, -1051,985,1052, -986,1052,985, -1052,986,1053, -987,1053,986, -1053,987,1054, -988,1054,987, -1054,988,1055, -989,1055,988, -1056,990,1057, -991,1057,990, -1057,991,1058, -992,1058,991, -1058,992,1059, -993,1059,992, -1059,993,1060, -994,1060,993, -1060,994,1061, -995,1061,994, -1061,995,1062, -996,1062,995, -1062,996,1063, -997,1063,996, -1063,997,1064, -998,1064,997, -1064,998,1065, -999,1065,998, -1065,999,1066, -1000,1066,999, -1066,1000,1067, -1001,1067,1000, -1067,1001,1068, -1002,1068,1001, -1068,1002,1069, -1003,1069,1002, -1069,1003,1070, -1004,1070,1003, -1070,1004,1071, -1005,1071,1004, -1071,1005,1072, -1006,1072,1005, -1072,1006,1073, -1007,1073,1006, -1073,1007,1074, -1008,1074,1007, -1074,1008,1075, -1009,1075,1008, -1075,1009,1076, -1010,1076,1009, -1076,1010,1077, -1011,1077,1010, -1077,1011,1078, -1012,1078,1011, -1078,1012,1079, -1013,1079,1012, -1079,1013,1080, -1014,1080,1013, -1080,1014,1081, -1015,1081,1014, -1081,1015,1082, -1016,1082,1015, -1082,1016,1083, -1017,1083,1016, -1083,1017,1084, -1018,1084,1017, -1084,1018,1085, -1019,1085,1018, -1085,1019,1086, -1020,1086,1019, -1086,1020,1087, -1021,1087,1020, -1087,1021,1088, -1022,1088,1021, -1088,1022,1089, -1023,1089,1022, -1089,1023,1090, -1024,1090,1023, -1090,1024,1091, -1025,1091,1024, -1091,1025,1092, -1026,1092,1025, -1092,1026,1093, -1027,1093,1026, -1093,1027,1094, -1028,1094,1027, -1094,1028,1095, -1029,1095,1028, -1095,1029,1096, -1030,1096,1029, -1096,1030,1097, -1031,1097,1030, -1097,1031,1098, -1032,1098,1031, -1098,1032,1099, -1033,1099,1032, -1099,1033,1100, -1034,1100,1033, -1100,1034,1101, -1035,1101,1034, -1101,1035,1102, -1036,1102,1035, -1102,1036,1103, -1037,1103,1036, -1103,1037,1104, -1038,1104,1037, -1104,1038,1105, -1039,1105,1038, -1105,1039,1106, -1040,1106,1039, -1106,1040,1107, -1041,1107,1040, -1107,1041,1108, -1042,1108,1041, -1108,1042,1109, -1043,1109,1042, -1109,1043,1110, -1044,1110,1043, -1110,1044,1111, -1045,1111,1044, -1111,1045,1112, -1046,1112,1045, -1112,1046,1113, -1047,1113,1046, -1113,1047,1114, -1048,1114,1047, -1114,1048,1115, -1049,1115,1048, -1115,1049,1116, -1050,1116,1049, -1116,1050,1117, -1051,1117,1050, -1117,1051,1118, -1052,1118,1051, -1118,1052,1119, -1053,1119,1052, -1119,1053,1120, -1054,1120,1053, -1120,1054,1121, -1055,1121,1054, -1122,1056,1123, -1057,1123,1056, -1123,1057,1124, -1058,1124,1057, -1124,1058,1125, -1059,1125,1058, -1125,1059,1126, -1060,1126,1059, -1126,1060,1127, -1061,1127,1060, -1127,1061,1128, -1062,1128,1061, -1128,1062,1129, -1063,1129,1062, -1129,1063,1130, -1064,1130,1063, -1130,1064,1131, -1065,1131,1064, -1131,1065,1132, -1066,1132,1065, -1132,1066,1133, -1067,1133,1066, -1133,1067,1134, -1068,1134,1067, -1134,1068,1135, -1069,1135,1068, -1135,1069,1136, -1070,1136,1069, -1136,1070,1137, -1071,1137,1070, -1137,1071,1138, -1072,1138,1071, -1138,1072,1139, -1073,1139,1072, -1139,1073,1140, -1074,1140,1073, -1140,1074,1141, -1075,1141,1074, -1141,1075,1142, -1076,1142,1075, -1142,1076,1143, -1077,1143,1076, -1143,1077,1144, -1078,1144,1077, -1144,1078,1145, -1079,1145,1078, -1145,1079,1146, -1080,1146,1079, -1146,1080,1147, -1081,1147,1080, -1147,1081,1148, -1082,1148,1081, -1148,1082,1149, -1083,1149,1082, -1149,1083,1150, -1084,1150,1083, -1150,1084,1151, -1085,1151,1084, -1151,1085,1152, -1086,1152,1085, -1152,1086,1153, -1087,1153,1086, -1153,1087,1154, -1088,1154,1087, -1154,1088,1155, -1089,1155,1088, -1155,1089,1156, -1090,1156,1089, -1156,1090,1157, -1091,1157,1090, -1157,1091,1158, -1092,1158,1091, -1158,1092,1159, -1093,1159,1092, -1159,1093,1160, -1094,1160,1093, -1160,1094,1161, -1095,1161,1094, -1161,1095,1162, -1096,1162,1095, -1162,1096,1163, -1097,1163,1096, -1163,1097,1164, -1098,1164,1097, -1164,1098,1165, -1099,1165,1098, -1165,1099,1166, -1100,1166,1099, -1166,1100,1167, -1101,1167,1100, -1167,1101,1168, -1102,1168,1101, -1168,1102,1169, -1103,1169,1102, -1169,1103,1170, -1104,1170,1103, -1170,1104,1171, -1105,1171,1104, -1171,1105,1172, -1106,1172,1105, -1172,1106,1173, -1107,1173,1106, -1173,1107,1174, -1108,1174,1107, -1174,1108,1175, -1109,1175,1108, -1175,1109,1176, -1110,1176,1109, -1176,1110,1177, -1111,1177,1110, -1177,1111,1178, -1112,1178,1111, -1178,1112,1179, -1113,1179,1112, -1179,1113,1180, -1114,1180,1113, -1180,1114,1181, -1115,1181,1114, -1181,1115,1182, -1116,1182,1115, -1182,1116,1183, -1117,1183,1116, -1183,1117,1184, -1118,1184,1117, -1184,1118,1185, -1119,1185,1118, -1185,1119,1186, -1120,1186,1119, -1186,1120,1187, -1121,1187,1120, -1188,1122,1189, -1123,1189,1122, -1189,1123,1190, -1124,1190,1123, -1190,1124,1191, -1125,1191,1124, -1191,1125,1192, -1126,1192,1125, -1192,1126,1193, -1127,1193,1126, -1193,1127,1194, -1128,1194,1127, -1194,1128,1195, -1129,1195,1128, -1195,1129,1196, -1130,1196,1129, -1196,1130,1197, -1131,1197,1130, -1197,1131,1198, -1132,1198,1131, -1198,1132,1199, -1133,1199,1132, -1199,1133,1200, -1134,1200,1133, -1200,1134,1201, -1135,1201,1134, -1201,1135,1202, -1136,1202,1135, -1202,1136,1203, -1137,1203,1136, -1203,1137,1204, -1138,1204,1137, -1204,1138,1205, -1139,1205,1138, -1205,1139,1206, -1140,1206,1139, -1206,1140,1207, -1141,1207,1140, -1207,1141,1208, -1142,1208,1141, -1208,1142,1209, -1143,1209,1142, -1209,1143,1210, -1144,1210,1143, -1210,1144,1211, -1145,1211,1144, -1211,1145,1212, -1146,1212,1145, -1212,1146,1213, -1147,1213,1146, -1213,1147,1214, -1148,1214,1147, -1214,1148,1215, -1149,1215,1148, -1215,1149,1216, -1150,1216,1149, -1216,1150,1217, -1151,1217,1150, -1217,1151,1218, -1152,1218,1151, -1218,1152,1219, -1153,1219,1152, -1219,1153,1220, -1154,1220,1153, -1220,1154,1221, -1155,1221,1154, -1221,1155,1222, -1156,1222,1155, -1222,1156,1223, -1157,1223,1156, -1223,1157,1224, -1158,1224,1157, -1224,1158,1225, -1159,1225,1158, -1225,1159,1226, -1160,1226,1159, -1226,1160,1227, -1161,1227,1160, -1227,1161,1228, -1162,1228,1161, -1228,1162,1229, -1163,1229,1162, -1229,1163,1230, -1164,1230,1163, -1230,1164,1231, -1165,1231,1164, -1231,1165,1232, -1166,1232,1165, -1232,1166,1233, -1167,1233,1166, -1233,1167,1234, -1168,1234,1167, -1234,1168,1235, -1169,1235,1168, -1235,1169,1236, -1170,1236,1169, -1236,1170,1237, -1171,1237,1170, -1237,1171,1238, -1172,1238,1171, -1238,1172,1239, -1173,1239,1172, -1239,1173,1240, -1174,1240,1173, -1240,1174,1241, -1175,1241,1174, -1241,1175,1242, -1176,1242,1175, -1242,1176,1243, -1177,1243,1176, -1243,1177,1244, -1178,1244,1177, -1244,1178,1245, -1179,1245,1178, -1245,1179,1246, -1180,1246,1179, -1246,1180,1247, -1181,1247,1180, -1247,1181,1248, -1182,1248,1181, -1248,1182,1249, -1183,1249,1182, -1249,1183,1250, -1184,1250,1183, -1250,1184,1251, -1185,1251,1184, -1251,1185,1252, -1186,1252,1185, -1252,1186,1253, -1187,1253,1186, -1254,1188,1255, -1189,1255,1188, -1255,1189,1256, -1190,1256,1189, -1256,1190,1257, -1191,1257,1190, -1257,1191,1258, -1192,1258,1191, -1258,1192,1259, -1193,1259,1192, -1259,1193,1260, -1194,1260,1193, -1260,1194,1261, -1195,1261,1194, -1261,1195,1262, -1196,1262,1195, -1262,1196,1263, -1197,1263,1196, -1263,1197,1264, -1198,1264,1197, -1264,1198,1265, -1199,1265,1198, -1265,1199,1266, -1200,1266,1199, -1266,1200,1267, -1201,1267,1200, -1267,1201,1268, -1202,1268,1201, -1268,1202,1269, -1203,1269,1202, -1269,1203,1270, -1204,1270,1203, -1270,1204,1271, -1205,1271,1204, -1271,1205,1272, -1206,1272,1205, -1272,1206,1273, -1207,1273,1206, -1273,1207,1274, -1208,1274,1207, -1274,1208,1275, -1209,1275,1208, -1275,1209,1276, -1210,1276,1209, -1276,1210,1277, -1211,1277,1210, -1277,1211,1278, -1212,1278,1211, -1278,1212,1279, -1213,1279,1212, -1279,1213,1280, -1214,1280,1213, -1280,1214,1281, -1215,1281,1214, -1281,1215,1282, -1216,1282,1215, -1282,1216,1283, -1217,1283,1216, -1283,1217,1284, -1218,1284,1217, -1284,1218,1285, -1219,1285,1218, -1285,1219,1286, -1220,1286,1219, -1286,1220,1287, -1221,1287,1220, -1287,1221,1288, -1222,1288,1221, -1288,1222,1289, -1223,1289,1222, -1289,1223,1290, -1224,1290,1223, -1290,1224,1291, -1225,1291,1224, -1291,1225,1292, -1226,1292,1225, -1292,1226,1293, -1227,1293,1226, -1293,1227,1294, -1228,1294,1227, -1294,1228,1295, -1229,1295,1228, -1295,1229,1296, -1230,1296,1229, -1296,1230,1297, -1231,1297,1230, -1297,1231,1298, -1232,1298,1231, -1298,1232,1299, -1233,1299,1232, -1299,1233,1300, -1234,1300,1233, -1300,1234,1301, -1235,1301,1234, -1301,1235,1302, -1236,1302,1235, -1302,1236,1303, -1237,1303,1236, -1303,1237,1304, -1238,1304,1237, -1304,1238,1305, -1239,1305,1238, -1305,1239,1306, -1240,1306,1239, -1306,1240,1307, -1241,1307,1240, -1307,1241,1308, -1242,1308,1241, -1308,1242,1309, -1243,1309,1242, -1309,1243,1310, -1244,1310,1243, -1310,1244,1311, -1245,1311,1244, -1311,1245,1312, -1246,1312,1245, -1312,1246,1313, -1247,1313,1246, -1313,1247,1314, -1248,1314,1247, -1314,1248,1315, -1249,1315,1248, -1315,1249,1316, -1250,1316,1249, -1316,1250,1317, -1251,1317,1250, -1317,1251,1318, -1252,1318,1251, -1318,1252,1319, -1253,1319,1252, -1320,1254,1321, -1255,1321,1254, -1321,1255,1322, -1256,1322,1255, -1322,1256,1323, -1257,1323,1256, -1323,1257,1324, -1258,1324,1257, -1324,1258,1325, -1259,1325,1258, -1325,1259,1326, -1260,1326,1259, -1326,1260,1327, -1261,1327,1260, -1327,1261,1328, -1262,1328,1261, -1328,1262,1329, -1263,1329,1262, -1329,1263,1330, -1264,1330,1263, -1330,1264,1331, -1265,1331,1264, -1331,1265,1332, -1266,1332,1265, -1332,1266,1333, -1267,1333,1266, -1333,1267,1334, -1268,1334,1267, -1334,1268,1335, -1269,1335,1268, -1335,1269,1336, -1270,1336,1269, -1336,1270,1337, -1271,1337,1270, -1337,1271,1338, -1272,1338,1271, -1338,1272,1339, -1273,1339,1272, -1339,1273,1340, -1274,1340,1273, -1340,1274,1341, -1275,1341,1274, -1341,1275,1342, -1276,1342,1275, -1342,1276,1343, -1277,1343,1276, -1343,1277,1344, -1278,1344,1277, -1344,1278,1345, -1279,1345,1278, -1345,1279,1346, -1280,1346,1279, -1346,1280,1347, -1281,1347,1280, -1347,1281,1348, -1282,1348,1281, -1348,1282,1349, -1283,1349,1282, -1349,1283,1350, -1284,1350,1283, -1350,1284,1351, -1285,1351,1284, -1351,1285,1352, -1286,1352,1285, -1352,1286,1353, -1287,1353,1286, -1353,1287,1354, -1288,1354,1287, -1354,1288,1355, -1289,1355,1288, -1355,1289,1356, -1290,1356,1289, -1356,1290,1357, -1291,1357,1290, -1357,1291,1358, -1292,1358,1291, -1358,1292,1359, -1293,1359,1292, -1359,1293,1360, -1294,1360,1293, -1360,1294,1361, -1295,1361,1294, -1361,1295,1362, -1296,1362,1295, -1362,1296,1363, -1297,1363,1296, -1363,1297,1364, -1298,1364,1297, -1364,1298,1365, -1299,1365,1298, -1365,1299,1366, -1300,1366,1299, -1366,1300,1367, -1301,1367,1300, -1367,1301,1368, -1302,1368,1301, -1368,1302,1369, -1303,1369,1302, -1369,1303,1370, -1304,1370,1303, -1370,1304,1371, -1305,1371,1304, -1371,1305,1372, -1306,1372,1305, -1372,1306,1373, -1307,1373,1306, -1373,1307,1374, -1308,1374,1307, -1374,1308,1375, -1309,1375,1308, -1375,1309,1376, -1310,1376,1309, -1376,1310,1377, -1311,1377,1310, -1377,1311,1378, -1312,1378,1311, -1378,1312,1379, -1313,1379,1312, -1379,1313,1380, -1314,1380,1313, -1380,1314,1381, -1315,1381,1314, -1381,1315,1382, -1316,1382,1315, -1382,1316,1383, -1317,1383,1316, -1383,1317,1384, -1318,1384,1317, -1384,1318,1385, -1319,1385,1318, -1386,1320,1387, -1321,1387,1320, -1387,1321,1388, -1322,1388,1321, -1388,1322,1389, -1323,1389,1322, -1389,1323,1390, -1324,1390,1323, -1390,1324,1391, -1325,1391,1324, -1391,1325,1392, -1326,1392,1325, -1392,1326,1393, -1327,1393,1326, -1393,1327,1394, -1328,1394,1327, -1394,1328,1395, -1329,1395,1328, -1395,1329,1396, -1330,1396,1329, -1396,1330,1397, -1331,1397,1330, -1397,1331,1398, -1332,1398,1331, -1398,1332,1399, -1333,1399,1332, -1399,1333,1400, -1334,1400,1333, -1400,1334,1401, -1335,1401,1334, -1401,1335,1402, -1336,1402,1335, -1402,1336,1403, -1337,1403,1336, -1403,1337,1404, -1338,1404,1337, -1404,1338,1405, -1339,1405,1338, -1405,1339,1406, -1340,1406,1339, -1406,1340,1407, -1341,1407,1340, -1407,1341,1408, -1342,1408,1341, -1408,1342,1409, -1343,1409,1342, -1409,1343,1410, -1344,1410,1343, -1410,1344,1411, -1345,1411,1344, -1411,1345,1412, -1346,1412,1345, -1412,1346,1413, -1347,1413,1346, -1413,1347,1414, -1348,1414,1347, -1414,1348,1415, -1349,1415,1348, -1415,1349,1416, -1350,1416,1349, -1416,1350,1417, -1351,1417,1350, -1417,1351,1418, -1352,1418,1351, -1418,1352,1419, -1353,1419,1352, -1419,1353,1420, -1354,1420,1353, -1420,1354,1421, -1355,1421,1354, -1421,1355,1422, -1356,1422,1355, -1422,1356,1423, -1357,1423,1356, -1423,1357,1424, -1358,1424,1357, -1424,1358,1425, -1359,1425,1358, -1425,1359,1426, -1360,1426,1359, -1426,1360,1427, -1361,1427,1360, -1427,1361,1428, -1362,1428,1361, -1428,1362,1429, -1363,1429,1362, -1429,1363,1430, -1364,1430,1363, -1430,1364,1431, -1365,1431,1364, -1431,1365,1432, -1366,1432,1365, -1432,1366,1433, -1367,1433,1366, -1433,1367,1434, -1368,1434,1367, -1434,1368,1435, -1369,1435,1368, -1435,1369,1436, -1370,1436,1369, -1436,1370,1437, -1371,1437,1370, -1437,1371,1438, -1372,1438,1371, -1438,1372,1439, -1373,1439,1372, -1439,1373,1440, -1374,1440,1373, -1440,1374,1441, -1375,1441,1374, -1441,1375,1442, -1376,1442,1375, -1442,1376,1443, -1377,1443,1376, -1443,1377,1444, -1378,1444,1377, -1444,1378,1445, -1379,1445,1378, -1445,1379,1446, -1380,1446,1379, -1446,1380,1447, -1381,1447,1380, -1447,1381,1448, -1382,1448,1381, -1448,1382,1449, -1383,1449,1382, -1449,1383,1450, -1384,1450,1383, -1450,1384,1451, -1385,1451,1384, -1452,1386,1453, -1387,1453,1386, -1453,1387,1454, -1388,1454,1387, -1454,1388,1455, -1389,1455,1388, -1455,1389,1456, -1390,1456,1389, -1456,1390,1457, -1391,1457,1390, -1457,1391,1458, -1392,1458,1391, -1458,1392,1459, -1393,1459,1392, -1459,1393,1460, -1394,1460,1393, -1460,1394,1461, -1395,1461,1394, -1461,1395,1462, -1396,1462,1395, -1462,1396,1463, -1397,1463,1396, -1463,1397,1464, -1398,1464,1397, -1464,1398,1465, -1399,1465,1398, -1465,1399,1466, -1400,1466,1399, -1466,1400,1467, -1401,1467,1400, -1467,1401,1468, -1402,1468,1401, -1468,1402,1469, -1403,1469,1402, -1469,1403,1470, -1404,1470,1403, -1470,1404,1471, -1405,1471,1404, -1471,1405,1472, -1406,1472,1405, -1472,1406,1473, -1407,1473,1406, -1473,1407,1474, -1408,1474,1407, -1474,1408,1475, -1409,1475,1408, -1475,1409,1476, -1410,1476,1409, -1476,1410,1477, -1411,1477,1410, -1477,1411,1478, -1412,1478,1411, -1478,1412,1479, -1413,1479,1412, -1479,1413,1480, -1414,1480,1413, -1480,1414,1481, -1415,1481,1414, -1481,1415,1482, -1416,1482,1415, -1482,1416,1483, -1417,1483,1416, -1483,1417,1484, -1418,1484,1417, -1484,1418,1485, -1419,1485,1418, -1485,1419,1486, -1420,1486,1419, -1486,1420,1487, -1421,1487,1420, -1487,1421,1488, -1422,1488,1421, -1488,1422,1489, -1423,1489,1422, -1489,1423,1490, -1424,1490,1423, -1490,1424,1491, -1425,1491,1424, -1491,1425,1492, -1426,1492,1425, -1492,1426,1493, -1427,1493,1426, -1493,1427,1494, -1428,1494,1427, -1494,1428,1495, -1429,1495,1428, -1495,1429,1496, -1430,1496,1429, -1496,1430,1497, -1431,1497,1430, -1497,1431,1498, -1432,1498,1431, -1498,1432,1499, -1433,1499,1432, -1499,1433,1500, -1434,1500,1433, -1500,1434,1501, -1435,1501,1434, -1501,1435,1502, -1436,1502,1435, -1502,1436,1503, -1437,1503,1436, -1503,1437,1504, -1438,1504,1437, -1504,1438,1505, -1439,1505,1438, -1505,1439,1506, -1440,1506,1439, -1506,1440,1507, -1441,1507,1440, -1507,1441,1508, -1442,1508,1441, -1508,1442,1509, -1443,1509,1442, -1509,1443,1510, -1444,1510,1443, -1510,1444,1511, -1445,1511,1444, -1511,1445,1512, -1446,1512,1445, -1512,1446,1513, -1447,1513,1446, -1513,1447,1514, -1448,1514,1447, -1514,1448,1515, -1449,1515,1448, -1515,1449,1516, -1450,1516,1449, -1516,1450,1517, -1451,1517,1450, -1518,1452,1519, -1453,1519,1452, -1519,1453,1520, -1454,1520,1453, -1520,1454,1521, -1455,1521,1454, -1521,1455,1522, -1456,1522,1455, -1522,1456,1523, -1457,1523,1456, -1523,1457,1524, -1458,1524,1457, -1524,1458,1525, -1459,1525,1458, -1525,1459,1526, -1460,1526,1459, -1526,1460,1527, -1461,1527,1460, -1527,1461,1528, -1462,1528,1461, -1528,1462,1529, -1463,1529,1462, -1529,1463,1530, -1464,1530,1463, -1530,1464,1531, -1465,1531,1464, -1531,1465,1532, -1466,1532,1465, -1532,1466,1533, -1467,1533,1466, -1533,1467,1534, -1468,1534,1467, -1534,1468,1535, -1469,1535,1468, -1535,1469,1536, -1470,1536,1469, -1536,1470,1537, -1471,1537,1470, -1537,1471,1538, -1472,1538,1471, -1538,1472,1539, -1473,1539,1472, -1539,1473,1540, -1474,1540,1473, -1540,1474,1541, -1475,1541,1474, -1541,1475,1542, -1476,1542,1475, -1542,1476,1543, -1477,1543,1476, -1543,1477,1544, -1478,1544,1477, -1544,1478,1545, -1479,1545,1478, -1545,1479,1546, -1480,1546,1479, -1546,1480,1547, -1481,1547,1480, -1547,1481,1548, -1482,1548,1481, -1548,1482,1549, -1483,1549,1482, -1549,1483,1550, -1484,1550,1483, -1550,1484,1551, -1485,1551,1484, -1551,1485,1552, -1486,1552,1485, -1552,1486,1553, -1487,1553,1486, -1553,1487,1554, -1488,1554,1487, -1554,1488,1555, -1489,1555,1488, -1555,1489,1556, -1490,1556,1489, -1556,1490,1557, -1491,1557,1490, -1557,1491,1558, -1492,1558,1491, -1558,1492,1559, -1493,1559,1492, -1559,1493,1560, -1494,1560,1493, -1560,1494,1561, -1495,1561,1494, -1561,1495,1562, -1496,1562,1495, -1562,1496,1563, -1497,1563,1496, -1563,1497,1564, -1498,1564,1497, -1564,1498,1565, -1499,1565,1498, -1565,1499,1566, -1500,1566,1499, -1566,1500,1567, -1501,1567,1500, -1567,1501,1568, -1502,1568,1501, -1568,1502,1569, -1503,1569,1502, -1569,1503,1570, -1504,1570,1503, -1570,1504,1571, -1505,1571,1504, -1571,1505,1572, -1506,1572,1505, -1572,1506,1573, -1507,1573,1506, -1573,1507,1574, -1508,1574,1507, -1574,1508,1575, -1509,1575,1508, -1575,1509,1576, -1510,1576,1509, -1576,1510,1577, -1511,1577,1510, -1577,1511,1578, -1512,1578,1511, -1578,1512,1579, -1513,1579,1512, -1579,1513,1580, -1514,1580,1513, -1580,1514,1581, -1515,1581,1514, -1581,1515,1582, -1516,1582,1515, -1582,1516,1583, -1517,1583,1516, -1584,1518,1585, -1519,1585,1518, -1585,1519,1586, -1520,1586,1519, -1586,1520,1587, -1521,1587,1520, -1587,1521,1588, -1522,1588,1521, -1588,1522,1589, -1523,1589,1522, -1589,1523,1590, -1524,1590,1523, -1590,1524,1591, -1525,1591,1524, -1591,1525,1592, -1526,1592,1525, -1592,1526,1593, -1527,1593,1526, -1593,1527,1594, -1528,1594,1527, -1594,1528,1595, -1529,1595,1528, -1595,1529,1596, -1530,1596,1529, -1596,1530,1597, -1531,1597,1530, -1597,1531,1598, -1532,1598,1531, -1598,1532,1599, -1533,1599,1532, -1599,1533,1600, -1534,1600,1533, -1600,1534,1601, -1535,1601,1534, -1601,1535,1602, -1536,1602,1535, -1602,1536,1603, -1537,1603,1536, -1603,1537,1604, -1538,1604,1537, -1604,1538,1605, -1539,1605,1538, -1605,1539,1606, -1540,1606,1539, -1606,1540,1607, -1541,1607,1540, -1607,1541,1608, -1542,1608,1541, -1608,1542,1609, -1543,1609,1542, -1609,1543,1610, -1544,1610,1543, -1610,1544,1611, -1545,1611,1544, -1611,1545,1612, -1546,1612,1545, -1612,1546,1613, -1547,1613,1546, -1613,1547,1614, -1548,1614,1547, -1614,1548,1615, -1549,1615,1548, -1615,1549,1616, -1550,1616,1549, -1616,1550,1617, -1551,1617,1550, -1617,1551,1618, -1552,1618,1551, -1618,1552,1619, -1553,1619,1552, -1619,1553,1620, -1554,1620,1553, -1620,1554,1621, -1555,1621,1554, -1621,1555,1622, -1556,1622,1555, -1622,1556,1623, -1557,1623,1556, -1623,1557,1624, -1558,1624,1557, -1624,1558,1625, -1559,1625,1558, -1625,1559,1626, -1560,1626,1559, -1626,1560,1627, -1561,1627,1560, -1627,1561,1628, -1562,1628,1561, -1628,1562,1629, -1563,1629,1562, -1629,1563,1630, -1564,1630,1563, -1630,1564,1631, -1565,1631,1564, -1631,1565,1632, -1566,1632,1565, -1632,1566,1633, -1567,1633,1566, -1633,1567,1634, -1568,1634,1567, -1634,1568,1635, -1569,1635,1568, -1635,1569,1636, -1570,1636,1569, -1636,1570,1637, -1571,1637,1570, -1637,1571,1638, -1572,1638,1571, -1638,1572,1639, -1573,1639,1572, -1639,1573,1640, -1574,1640,1573, -1640,1574,1641, -1575,1641,1574, -1641,1575,1642, -1576,1642,1575, -1642,1576,1643, -1577,1643,1576, -1643,1577,1644, -1578,1644,1577, -1644,1578,1645, -1579,1645,1578, -1645,1579,1646, -1580,1646,1579, -1646,1580,1647, -1581,1647,1580, -1647,1581,1648, -1582,1648,1581, -1648,1582,1649, -1583,1649,1582, -1650,1584,1651, -1585,1651,1584, -1651,1585,1652, -1586,1652,1585, -1652,1586,1653, -1587,1653,1586, -1653,1587,1654, -1588,1654,1587, -1654,1588,1655, -1589,1655,1588, -1655,1589,1656, -1590,1656,1589, -1656,1590,1657, -1591,1657,1590, -1657,1591,1658, -1592,1658,1591, -1658,1592,1659, -1593,1659,1592, -1659,1593,1660, -1594,1660,1593, -1660,1594,1661, -1595,1661,1594, -1661,1595,1662, -1596,1662,1595, -1662,1596,1663, -1597,1663,1596, -1663,1597,1664, -1598,1664,1597, -1664,1598,1665, -1599,1665,1598, -1665,1599,1666, -1600,1666,1599, -1666,1600,1667, -1601,1667,1600, -1667,1601,1668, -1602,1668,1601, -1668,1602,1669, -1603,1669,1602, -1669,1603,1670, -1604,1670,1603, -1670,1604,1671, -1605,1671,1604, -1671,1605,1672, -1606,1672,1605, -1672,1606,1673, -1607,1673,1606, -1673,1607,1674, -1608,1674,1607, -1674,1608,1675, -1609,1675,1608, -1675,1609,1676, -1610,1676,1609, -1676,1610,1677, -1611,1677,1610, -1677,1611,1678, -1612,1678,1611, -1678,1612,1679, -1613,1679,1612, -1679,1613,1680, -1614,1680,1613, -1680,1614,1681, -1615,1681,1614, -1681,1615,1682, -1616,1682,1615, -1682,1616,1683, -1617,1683,1616, -1683,1617,1684, -1618,1684,1617, -1684,1618,1685, -1619,1685,1618, -1685,1619,1686, -1620,1686,1619, -1686,1620,1687, -1621,1687,1620, -1687,1621,1688, -1622,1688,1621, -1688,1622,1689, -1623,1689,1622, -1689,1623,1690, -1624,1690,1623, -1690,1624,1691, -1625,1691,1624, -1691,1625,1692, -1626,1692,1625, -1692,1626,1693, -1627,1693,1626, -1693,1627,1694, -1628,1694,1627, -1694,1628,1695, -1629,1695,1628, -1695,1629,1696, -1630,1696,1629, -1696,1630,1697, -1631,1697,1630, -1697,1631,1698, -1632,1698,1631, -1698,1632,1699, -1633,1699,1632, -1699,1633,1700, -1634,1700,1633, -1700,1634,1701, -1635,1701,1634, -1701,1635,1702, -1636,1702,1635, -1702,1636,1703, -1637,1703,1636, -1703,1637,1704, -1638,1704,1637, -1704,1638,1705, -1639,1705,1638, -1705,1639,1706, -1640,1706,1639, -1706,1640,1707, -1641,1707,1640, -1707,1641,1708, -1642,1708,1641, -1708,1642,1709, -1643,1709,1642, -1709,1643,1710, -1644,1710,1643, -1710,1644,1711, -1645,1711,1644, -1711,1645,1712, -1646,1712,1645, -1712,1646,1713, -1647,1713,1646, -1713,1647,1714, -1648,1714,1647, -1714,1648,1715, -1649,1715,1648, -1716,1650,1717, -1651,1717,1650, -1717,1651,1718, -1652,1718,1651, -1718,1652,1719, -1653,1719,1652, -1719,1653,1720, -1654,1720,1653, -1720,1654,1721, -1655,1721,1654, -1721,1655,1722, -1656,1722,1655, -1722,1656,1723, -1657,1723,1656, -1723,1657,1724, -1658,1724,1657, -1724,1658,1725, -1659,1725,1658, -1725,1659,1726, -1660,1726,1659, -1726,1660,1727, -1661,1727,1660, -1727,1661,1728, -1662,1728,1661, -1728,1662,1729, -1663,1729,1662, -1729,1663,1730, -1664,1730,1663, -1730,1664,1731, -1665,1731,1664, -1731,1665,1732, -1666,1732,1665, -1732,1666,1733, -1667,1733,1666, -1733,1667,1734, -1668,1734,1667, -1734,1668,1735, -1669,1735,1668, -1735,1669,1736, -1670,1736,1669, -1736,1670,1737, -1671,1737,1670, -1737,1671,1738, -1672,1738,1671, -1738,1672,1739, -1673,1739,1672, -1739,1673,1740, -1674,1740,1673, -1740,1674,1741, -1675,1741,1674, -1741,1675,1742, -1676,1742,1675, -1742,1676,1743, -1677,1743,1676, -1743,1677,1744, -1678,1744,1677, -1744,1678,1745, -1679,1745,1678, -1745,1679,1746, -1680,1746,1679, -1746,1680,1747, -1681,1747,1680, -1747,1681,1748, -1682,1748,1681, -1748,1682,1749, -1683,1749,1682, -1749,1683,1750, -1684,1750,1683, -1750,1684,1751, -1685,1751,1684, -1751,1685,1752, -1686,1752,1685, -1752,1686,1753, -1687,1753,1686, -1753,1687,1754, -1688,1754,1687, -1754,1688,1755, -1689,1755,1688, -1755,1689,1756, -1690,1756,1689, -1756,1690,1757, -1691,1757,1690, -1757,1691,1758, -1692,1758,1691, -1758,1692,1759, -1693,1759,1692, -1759,1693,1760, -1694,1760,1693, -1760,1694,1761, -1695,1761,1694, -1761,1695,1762, -1696,1762,1695, -1762,1696,1763, -1697,1763,1696, -1763,1697,1764, -1698,1764,1697, -1764,1698,1765, -1699,1765,1698, -1765,1699,1766, -1700,1766,1699, -1766,1700,1767, -1701,1767,1700, -1767,1701,1768, -1702,1768,1701, -1768,1702,1769, -1703,1769,1702, -1769,1703,1770, -1704,1770,1703, -1770,1704,1771, -1705,1771,1704, -1771,1705,1772, -1706,1772,1705, -1772,1706,1773, -1707,1773,1706, -1773,1707,1774, -1708,1774,1707, -1774,1708,1775, -1709,1775,1708, -1775,1709,1776, -1710,1776,1709, -1776,1710,1777, -1711,1777,1710, -1777,1711,1778, -1712,1778,1711, -1778,1712,1779, -1713,1779,1712, -1779,1713,1780, -1714,1780,1713, -1780,1714,1781, -1715,1781,1714, -1782,1716,1783, -1717,1783,1716, -1783,1717,1784, -1718,1784,1717, -1784,1718,1785, -1719,1785,1718, -1785,1719,1786, -1720,1786,1719, -1786,1720,1787, -1721,1787,1720, -1787,1721,1788, -1722,1788,1721, -1788,1722,1789, -1723,1789,1722, -1789,1723,1790, -1724,1790,1723, -1790,1724,1791, -1725,1791,1724, -1791,1725,1792, -1726,1792,1725, -1792,1726,1793, -1727,1793,1726, -1793,1727,1794, -1728,1794,1727, -1794,1728,1795, -1729,1795,1728, -1795,1729,1796, -1730,1796,1729, -1796,1730,1797, -1731,1797,1730, -1797,1731,1798, -1732,1798,1731, -1798,1732,1799, -1733,1799,1732, -1799,1733,1800, -1734,1800,1733, -1800,1734,1801, -1735,1801,1734, -1801,1735,1802, -1736,1802,1735, -1802,1736,1803, -1737,1803,1736, -1803,1737,1804, -1738,1804,1737, -1804,1738,1805, -1739,1805,1738, -1805,1739,1806, -1740,1806,1739, -1806,1740,1807, -1741,1807,1740, -1807,1741,1808, -1742,1808,1741, -1808,1742,1809, -1743,1809,1742, -1809,1743,1810, -1744,1810,1743, -1810,1744,1811, -1745,1811,1744, -1811,1745,1812, -1746,1812,1745, -1812,1746,1813, -1747,1813,1746, -1813,1747,1814, -1748,1814,1747, -1814,1748,1815, -1749,1815,1748, -1815,1749,1816, -1750,1816,1749, -1816,1750,1817, -1751,1817,1750, -1817,1751,1818, -1752,1818,1751, -1818,1752,1819, -1753,1819,1752, -1819,1753,1820, -1754,1820,1753, -1820,1754,1821, -1755,1821,1754, -1821,1755,1822, -1756,1822,1755, -1822,1756,1823, -1757,1823,1756, -1823,1757,1824, -1758,1824,1757, -1824,1758,1825, -1759,1825,1758, -1825,1759,1826, -1760,1826,1759, -1826,1760,1827, -1761,1827,1760, -1827,1761,1828, -1762,1828,1761, -1828,1762,1829, -1763,1829,1762, -1829,1763,1830, -1764,1830,1763, -1830,1764,1831, -1765,1831,1764, -1831,1765,1832, -1766,1832,1765, -1832,1766,1833, -1767,1833,1766, -1833,1767,1834, -1768,1834,1767, -1834,1768,1835, -1769,1835,1768, -1835,1769,1836, -1770,1836,1769, -1836,1770,1837, -1771,1837,1770, -1837,1771,1838, -1772,1838,1771, -1838,1772,1839, -1773,1839,1772, -1839,1773,1840, -1774,1840,1773, -1840,1774,1841, -1775,1841,1774, -1841,1775,1842, -1776,1842,1775, -1842,1776,1843, -1777,1843,1776, -1843,1777,1844, -1778,1844,1777, -1844,1778,1845, -1779,1845,1778, -1845,1779,1846, -1780,1846,1779, -1846,1780,1847, -1781,1847,1780, -1848,1782,1849, -1783,1849,1782, -1849,1783,1850, -1784,1850,1783, -1850,1784,1851, -1785,1851,1784, -1851,1785,1852, -1786,1852,1785, -1852,1786,1853, -1787,1853,1786, -1853,1787,1854, -1788,1854,1787, -1854,1788,1855, -1789,1855,1788, -1855,1789,1856, -1790,1856,1789, -1856,1790,1857, -1791,1857,1790, -1857,1791,1858, -1792,1858,1791, -1858,1792,1859, -1793,1859,1792, -1859,1793,1860, -1794,1860,1793, -1860,1794,1861, -1795,1861,1794, -1861,1795,1862, -1796,1862,1795, -1862,1796,1863, -1797,1863,1796, -1863,1797,1864, -1798,1864,1797, -1864,1798,1865, -1799,1865,1798, -1865,1799,1866, -1800,1866,1799, -1866,1800,1867, -1801,1867,1800, -1867,1801,1868, -1802,1868,1801, -1868,1802,1869, -1803,1869,1802, -1869,1803,1870, -1804,1870,1803, -1870,1804,1871, -1805,1871,1804, -1871,1805,1872, -1806,1872,1805, -1872,1806,1873, -1807,1873,1806, -1873,1807,1874, -1808,1874,1807, -1874,1808,1875, -1809,1875,1808, -1875,1809,1876, -1810,1876,1809, -1876,1810,1877, -1811,1877,1810, -1877,1811,1878, -1812,1878,1811, -1878,1812,1879, -1813,1879,1812, -1879,1813,1880, -1814,1880,1813, -1880,1814,1881, -1815,1881,1814, -1881,1815,1882, -1816,1882,1815, -1882,1816,1883, -1817,1883,1816, -1883,1817,1884, -1818,1884,1817, -1884,1818,1885, -1819,1885,1818, -1885,1819,1886, -1820,1886,1819, -1886,1820,1887, -1821,1887,1820, -1887,1821,1888, -1822,1888,1821, -1888,1822,1889, -1823,1889,1822, -1889,1823,1890, -1824,1890,1823, -1890,1824,1891, -1825,1891,1824, -1891,1825,1892, -1826,1892,1825, -1892,1826,1893, -1827,1893,1826, -1893,1827,1894, -1828,1894,1827, -1894,1828,1895, -1829,1895,1828, -1895,1829,1896, -1830,1896,1829, -1896,1830,1897, -1831,1897,1830, -1897,1831,1898, -1832,1898,1831, -1898,1832,1899, -1833,1899,1832, -1899,1833,1900, -1834,1900,1833, -1900,1834,1901, -1835,1901,1834, -1901,1835,1902, -1836,1902,1835, -1902,1836,1903, -1837,1903,1836, -1903,1837,1904, -1838,1904,1837, -1904,1838,1905, -1839,1905,1838, -1905,1839,1906, -1840,1906,1839, -1906,1840,1907, -1841,1907,1840, -1907,1841,1908, -1842,1908,1841, -1908,1842,1909, -1843,1909,1842, -1909,1843,1910, -1844,1910,1843, -1910,1844,1911, -1845,1911,1844, -1911,1845,1912, -1846,1912,1845, -1912,1846,1913, -1847,1913,1846, -1914,1848,1915, -1849,1915,1848, -1915,1849,1916, -1850,1916,1849, -1916,1850,1917, -1851,1917,1850, -1917,1851,1918, -1852,1918,1851, -1918,1852,1919, -1853,1919,1852, -1919,1853,1920, -1854,1920,1853, -1920,1854,1921, -1855,1921,1854, -1921,1855,1922, -1856,1922,1855, -1922,1856,1923, -1857,1923,1856, -1923,1857,1924, -1858,1924,1857, -1924,1858,1925, -1859,1925,1858, -1925,1859,1926, -1860,1926,1859, -1926,1860,1927, -1861,1927,1860, -1927,1861,1928, -1862,1928,1861, -1928,1862,1929, -1863,1929,1862, -1929,1863,1930, -1864,1930,1863, -1930,1864,1931, -1865,1931,1864, -1931,1865,1932, -1866,1932,1865, -1932,1866,1933, -1867,1933,1866, -1933,1867,1934, -1868,1934,1867, -1934,1868,1935, -1869,1935,1868, -1935,1869,1936, -1870,1936,1869, -1936,1870,1937, -1871,1937,1870, -1937,1871,1938, -1872,1938,1871, -1938,1872,1939, -1873,1939,1872, -1939,1873,1940, -1874,1940,1873, -1940,1874,1941, -1875,1941,1874, -1941,1875,1942, -1876,1942,1875, -1942,1876,1943, -1877,1943,1876, -1943,1877,1944, -1878,1944,1877, -1944,1878,1945, -1879,1945,1878, -1945,1879,1946, -1880,1946,1879, -1946,1880,1947, -1881,1947,1880, -1947,1881,1948, -1882,1948,1881, -1948,1882,1949, -1883,1949,1882, -1949,1883,1950, -1884,1950,1883, -1950,1884,1951, -1885,1951,1884, -1951,1885,1952, -1886,1952,1885, -1952,1886,1953, -1887,1953,1886, -1953,1887,1954, -1888,1954,1887, -1954,1888,1955, -1889,1955,1888, -1955,1889,1956, -1890,1956,1889, -1956,1890,1957, -1891,1957,1890, -1957,1891,1958, -1892,1958,1891, -1958,1892,1959, -1893,1959,1892, -1959,1893,1960, -1894,1960,1893, -1960,1894,1961, -1895,1961,1894, -1961,1895,1962, -1896,1962,1895, -1962,1896,1963, -1897,1963,1896, -1963,1897,1964, -1898,1964,1897, -1964,1898,1965, -1899,1965,1898, -1965,1899,1966, -1900,1966,1899, -1966,1900,1967, -1901,1967,1900, -1967,1901,1968, -1902,1968,1901, -1968,1902,1969, -1903,1969,1902, -1969,1903,1970, -1904,1970,1903, -1970,1904,1971, -1905,1971,1904, -1971,1905,1972, -1906,1972,1905, -1972,1906,1973, -1907,1973,1906, -1973,1907,1974, -1908,1974,1907, -1974,1908,1975, -1909,1975,1908, -1975,1909,1976, -1910,1976,1909, -1976,1910,1977, -1911,1977,1910, -1977,1911,1978, -1912,1978,1911, -1978,1912,1979, -1913,1979,1912, -1980,1914,1981, -1915,1981,1914, -1981,1915,1982, -1916,1982,1915, -1982,1916,1983, -1917,1983,1916, -1983,1917,1984, -1918,1984,1917, -1984,1918,1985, -1919,1985,1918, -1985,1919,1986, -1920,1986,1919, -1986,1920,1987, -1921,1987,1920, -1987,1921,1988, -1922,1988,1921, -1988,1922,1989, -1923,1989,1922, -1989,1923,1990, -1924,1990,1923, -1990,1924,1991, -1925,1991,1924, -1991,1925,1992, -1926,1992,1925, -1992,1926,1993, -1927,1993,1926, -1993,1927,1994, -1928,1994,1927, -1994,1928,1995, -1929,1995,1928, -1995,1929,1996, -1930,1996,1929, -1996,1930,1997, -1931,1997,1930, -1997,1931,1998, -1932,1998,1931, -1998,1932,1999, -1933,1999,1932, -1999,1933,2000, -1934,2000,1933, -2000,1934,2001, -1935,2001,1934, -2001,1935,2002, -1936,2002,1935, -2002,1936,2003, -1937,2003,1936, -2003,1937,2004, -1938,2004,1937, -2004,1938,2005, -1939,2005,1938, -2005,1939,2006, -1940,2006,1939, -2006,1940,2007, -1941,2007,1940, -2007,1941,2008, -1942,2008,1941, -2008,1942,2009, -1943,2009,1942, -2009,1943,2010, -1944,2010,1943, -2010,1944,2011, -1945,2011,1944, -2011,1945,2012, -1946,2012,1945, -2012,1946,2013, -1947,2013,1946, -2013,1947,2014, -1948,2014,1947, -2014,1948,2015, -1949,2015,1948, -2015,1949,2016, -1950,2016,1949, -2016,1950,2017, -1951,2017,1950, -2017,1951,2018, -1952,2018,1951, -2018,1952,2019, -1953,2019,1952, -2019,1953,2020, -1954,2020,1953, -2020,1954,2021, -1955,2021,1954, -2021,1955,2022, -1956,2022,1955, -2022,1956,2023, -1957,2023,1956, -2023,1957,2024, -1958,2024,1957, -2024,1958,2025, -1959,2025,1958, -2025,1959,2026, -1960,2026,1959, -2026,1960,2027, -1961,2027,1960, -2027,1961,2028, -1962,2028,1961, -2028,1962,2029, -1963,2029,1962, -2029,1963,2030, -1964,2030,1963, -2030,1964,2031, -1965,2031,1964, -2031,1965,2032, -1966,2032,1965, -2032,1966,2033, -1967,2033,1966, -2033,1967,2034, -1968,2034,1967, -2034,1968,2035, -1969,2035,1968, -2035,1969,2036, -1970,2036,1969, -2036,1970,2037, -1971,2037,1970, -2037,1971,2038, -1972,2038,1971, -2038,1972,2039, -1973,2039,1972, -2039,1973,2040, -1974,2040,1973, -2040,1974,2041, -1975,2041,1974, -2041,1975,2042, -1976,2042,1975, -2042,1976,2043, -1977,2043,1976, -2043,1977,2044, -1978,2044,1977, -2044,1978,2045, -1979,2045,1978, -2046,1980,2047, -1981,2047,1980, -2047,1981,2048, -1982,2048,1981, -2048,1982,2049, -1983,2049,1982, -2049,1983,2050, -1984,2050,1983, -2050,1984,2051, -1985,2051,1984, -2051,1985,2052, -1986,2052,1985, -2052,1986,2053, -1987,2053,1986, -2053,1987,2054, -1988,2054,1987, -2054,1988,2055, -1989,2055,1988, -2055,1989,2056, -1990,2056,1989, -2056,1990,2057, -1991,2057,1990, -2057,1991,2058, -1992,2058,1991, -2058,1992,2059, -1993,2059,1992, -2059,1993,2060, -1994,2060,1993, -2060,1994,2061, -1995,2061,1994, -2061,1995,2062, -1996,2062,1995, -2062,1996,2063, -1997,2063,1996, -2063,1997,2064, -1998,2064,1997, -2064,1998,2065, -1999,2065,1998, -2065,1999,2066, -2000,2066,1999, -2066,2000,2067, -2001,2067,2000, -2067,2001,2068, -2002,2068,2001, -2068,2002,2069, -2003,2069,2002, -2069,2003,2070, -2004,2070,2003, -2070,2004,2071, -2005,2071,2004, -2071,2005,2072, -2006,2072,2005, -2072,2006,2073, -2007,2073,2006, -2073,2007,2074, -2008,2074,2007, -2074,2008,2075, -2009,2075,2008, -2075,2009,2076, -2010,2076,2009, -2076,2010,2077, -2011,2077,2010, -2077,2011,2078, -2012,2078,2011, -2078,2012,2079, -2013,2079,2012, -2079,2013,2080, -2014,2080,2013, -2080,2014,2081, -2015,2081,2014, -2081,2015,2082, -2016,2082,2015, -2082,2016,2083, -2017,2083,2016, -2083,2017,2084, -2018,2084,2017, -2084,2018,2085, -2019,2085,2018, -2085,2019,2086, -2020,2086,2019, -2086,2020,2087, -2021,2087,2020, -2087,2021,2088, -2022,2088,2021, -2088,2022,2089, -2023,2089,2022, -2089,2023,2090, -2024,2090,2023, -2090,2024,2091, -2025,2091,2024, -2091,2025,2092, -2026,2092,2025, -2092,2026,2093, -2027,2093,2026, -2093,2027,2094, -2028,2094,2027, -2094,2028,2095, -2029,2095,2028, -2095,2029,2096, -2030,2096,2029, -2096,2030,2097, -2031,2097,2030, -2097,2031,2098, -2032,2098,2031, -2098,2032,2099, -2033,2099,2032, -2099,2033,2100, -2034,2100,2033, -2100,2034,2101, -2035,2101,2034, -2101,2035,2102, -2036,2102,2035, -2102,2036,2103, -2037,2103,2036, -2103,2037,2104, -2038,2104,2037, -2104,2038,2105, -2039,2105,2038, -2105,2039,2106, -2040,2106,2039, -2106,2040,2107, -2041,2107,2040, -2107,2041,2108, -2042,2108,2041, -2108,2042,2109, -2043,2109,2042, -2109,2043,2110, -2044,2110,2043, -2110,2044,2111, -2045,2111,2044, -2112,2046,2113, -2047,2113,2046, -2113,2047,2114, -2048,2114,2047, -2114,2048,2115, -2049,2115,2048, -2115,2049,2116, -2050,2116,2049, -2116,2050,2117, -2051,2117,2050, -2117,2051,2118, -2052,2118,2051, -2118,2052,2119, -2053,2119,2052, -2119,2053,2120, -2054,2120,2053, -2120,2054,2121, -2055,2121,2054, -2121,2055,2122, -2056,2122,2055, -2122,2056,2123, -2057,2123,2056, -2123,2057,2124, -2058,2124,2057, -2124,2058,2125, -2059,2125,2058, -2125,2059,2126, -2060,2126,2059, -2126,2060,2127, -2061,2127,2060, -2127,2061,2128, -2062,2128,2061, -2128,2062,2129, -2063,2129,2062, -2129,2063,2130, -2064,2130,2063, -2130,2064,2131, -2065,2131,2064, -2131,2065,2132, -2066,2132,2065, -2132,2066,2133, -2067,2133,2066, -2133,2067,2134, -2068,2134,2067, -2134,2068,2135, -2069,2135,2068, -2135,2069,2136, -2070,2136,2069, -2136,2070,2137, -2071,2137,2070, -2137,2071,2138, -2072,2138,2071, -2138,2072,2139, -2073,2139,2072, -2139,2073,2140, -2074,2140,2073, -2140,2074,2141, -2075,2141,2074, -2141,2075,2142, -2076,2142,2075, -2142,2076,2143, -2077,2143,2076, -2143,2077,2144, -2078,2144,2077, -2144,2078,2145, -2079,2145,2078, -2145,2079,2146, -2080,2146,2079, -2146,2080,2147, -2081,2147,2080, -2147,2081,2148, -2082,2148,2081, -2148,2082,2149, -2083,2149,2082, -2149,2083,2150, -2084,2150,2083, -2150,2084,2151, -2085,2151,2084, -2151,2085,2152, -2086,2152,2085, -2152,2086,2153, -2087,2153,2086, -2153,2087,2154, -2088,2154,2087, -2154,2088,2155, -2089,2155,2088, -2155,2089,2156, -2090,2156,2089, -2156,2090,2157, -2091,2157,2090, -2157,2091,2158, -2092,2158,2091, -2158,2092,2159, -2093,2159,2092, -2159,2093,2160, -2094,2160,2093, -2160,2094,2161, -2095,2161,2094, -2161,2095,2162, -2096,2162,2095, -2162,2096,2163, -2097,2163,2096, -2163,2097,2164, -2098,2164,2097, -2164,2098,2165, -2099,2165,2098, -2165,2099,2166, -2100,2166,2099, -2166,2100,2167, -2101,2167,2100, -2167,2101,2168, -2102,2168,2101, -2168,2102,2169, -2103,2169,2102, -2169,2103,2170, -2104,2170,2103, -2170,2104,2171, -2105,2171,2104, -2171,2105,2172, -2106,2172,2105, -2172,2106,2173, -2107,2173,2106, -2173,2107,2174, -2108,2174,2107, -2174,2108,2175, -2109,2175,2108, -2175,2109,2176, -2110,2176,2109, -2176,2110,2177, -2111,2177,2110, -2178,2112,2179, -2113,2179,2112, -2179,2113,2180, -2114,2180,2113, -2180,2114,2181, -2115,2181,2114, -2181,2115,2182, -2116,2182,2115, -2182,2116,2183, -2117,2183,2116, -2183,2117,2184, -2118,2184,2117, -2184,2118,2185, -2119,2185,2118, -2185,2119,2186, -2120,2186,2119, -2186,2120,2187, -2121,2187,2120, -2187,2121,2188, -2122,2188,2121, -2188,2122,2189, -2123,2189,2122, -2189,2123,2190, -2124,2190,2123, -2190,2124,2191, -2125,2191,2124, -2191,2125,2192, -2126,2192,2125, -2192,2126,2193, -2127,2193,2126, -2193,2127,2194, -2128,2194,2127, -2194,2128,2195, -2129,2195,2128, -2195,2129,2196, -2130,2196,2129, -2196,2130,2197, -2131,2197,2130, -2197,2131,2198, -2132,2198,2131, -2198,2132,2199, -2133,2199,2132, -2199,2133,2200, -2134,2200,2133, -2200,2134,2201, -2135,2201,2134, -2201,2135,2202, -2136,2202,2135, -2202,2136,2203, -2137,2203,2136, -2203,2137,2204, -2138,2204,2137, -2204,2138,2205, -2139,2205,2138, -2205,2139,2206, -2140,2206,2139, -2206,2140,2207, -2141,2207,2140, -2207,2141,2208, -2142,2208,2141, -2208,2142,2209, -2143,2209,2142, -2209,2143,2210, -2144,2210,2143, -2210,2144,2211, -2145,2211,2144, -2211,2145,2212, -2146,2212,2145, -2212,2146,2213, -2147,2213,2146, -2213,2147,2214, -2148,2214,2147, -2214,2148,2215, -2149,2215,2148, -2215,2149,2216, -2150,2216,2149, -2216,2150,2217, -2151,2217,2150, -2217,2151,2218, -2152,2218,2151, -2218,2152,2219, -2153,2219,2152, -2219,2153,2220, -2154,2220,2153, -2220,2154,2221, -2155,2221,2154, -2221,2155,2222, -2156,2222,2155, -2222,2156,2223, -2157,2223,2156, -2223,2157,2224, -2158,2224,2157, -2224,2158,2225, -2159,2225,2158, -2225,2159,2226, -2160,2226,2159, -2226,2160,2227, -2161,2227,2160, -2227,2161,2228, -2162,2228,2161, -2228,2162,2229, -2163,2229,2162, -2229,2163,2230, -2164,2230,2163, -2230,2164,2231, -2165,2231,2164, -2231,2165,2232, -2166,2232,2165, -2232,2166,2233, -2167,2233,2166, -2233,2167,2234, -2168,2234,2167, -2234,2168,2235, -2169,2235,2168, -2235,2169,2236, -2170,2236,2169, -2236,2170,2237, -2171,2237,2170, -2237,2171,2238, -2172,2238,2171, -2238,2172,2239, -2173,2239,2172, -2239,2173,2240, -2174,2240,2173, -2240,2174,2241, -2175,2241,2174, -2241,2175,2242, -2176,2242,2175, -2242,2176,2243, -2177,2243,2176, -}; - -#define Landscape06VtxCount 2310 -#define Landscape06IdxCount 13260 - -btScalar Landscape06Vtx[] = { --250.0f,5.63631f,246.094f, --250.0f,8.1152f,250.0f, --246.094f,7.06461f,246.094f, --246.094f,9.72778f,250.0f, --242.188f,9.8471f,246.094f, --242.188f,11.659f,250.0f, --238.281f,12.8404f,246.094f, --238.281f,12.5619f,250.0f, --234.375f,13.9879f,246.094f, --234.375f,12.9518f,250.0f, --230.469f,15.7239f,246.094f, --230.469f,15.1373f,250.0f, --226.563f,17.5095f,246.094f, --226.563f,17.0421f,250.0f, --222.656f,18.4322f,246.094f, --222.656f,17.9919f,250.0f, --218.75f,19.0755f,246.094f, --218.75f,18.7918f,250.0f, --214.844f,19.9271f,246.094f, --214.844f,19.5719f,250.0f, --210.938f,19.7244f,246.094f, --210.938f,20.0866f,250.0f, --207.031f,18.9716f,246.094f, --207.031f,19.7869f,250.0f, --203.125f,19.1922f,246.094f, --203.125f,20.0264f,250.0f, --199.219f,17.8506f,246.094f, --199.219f,19.3207f,250.0f, --195.313f,15.238f,246.094f, --195.313f,18.0244f,250.0f, --191.406f,14.6904f,246.094f, --191.406f,16.2939f,250.0f, --187.5f,12.9803f,246.094f, --187.5f,14.9619f,250.0f, --183.594f,11.6545f,246.094f, --183.594f,12.6676f,250.0f, --179.688f,12.4631f,246.094f, --179.688f,13.6712f,250.0f, --175.781f,13.1206f,246.094f, --175.781f,14.5417f,250.0f, --171.875f,13.3105f,246.094f, --171.875f,15.8974f,250.0f, --167.969f,13.4543f,246.094f, --167.969f,15.9641f,250.0f, --164.063f,13.4505f,246.094f, --164.063f,15.4826f,250.0f, --160.156f,14.6873f,246.094f, --160.156f,15.1093f,250.0f, --156.25f,14.1623f,246.094f, --156.25f,14.8119f,250.0f, --152.344f,14.0111f,246.094f, --152.344f,14.4017f,250.0f, --148.438f,13.2014f,246.094f, --148.438f,14.2916f,250.0f, --144.531f,12.8662f,246.094f, --144.531f,13.5685f,250.0f, --140.625f,13.1721f,246.094f, --140.625f,14.2972f,250.0f, --136.719f,12.9479f,246.094f, --136.719f,15.0727f,250.0f, --132.813f,13.4221f,246.094f, --132.813f,14.5344f,250.0f, --128.906f,14.0862f,246.094f, --128.906f,15.7145f,250.0f, --125.0f,13.481f,246.094f, --125.0f,15.4608f,250.0f, --121.094f,12.6228f,246.094f, --121.094f,15.1857f,250.0f, --117.188f,12.0584f,246.094f, --117.188f,15.444f,250.0f, --113.281f,12.7173f,246.094f, --113.281f,15.8882f,250.0f, --109.375f,12.3498f,246.094f, --109.375f,15.2023f,250.0f, --105.469f,13.0125f,246.094f, --105.469f,15.1747f,250.0f, --101.563f,13.7023f,246.094f, --101.563f,14.7499f,250.0f, --97.6563f,14.0674f,246.094f, --97.6563f,15.0991f,250.0f, --93.75f,13.8437f,246.094f, --93.75f,14.6676f,250.0f, --89.8438f,14.6327f,246.094f, --89.8438f,14.1527f,250.0f, --85.9375f,13.2966f,246.094f, --85.9375f,14.0388f,250.0f, --82.0313f,12.8094f,246.094f, --82.0313f,13.7786f,250.0f, --78.125f,11.8006f,246.094f, --78.125f,13.0685f,250.0f, --74.2188f,11.6837f,246.094f, --74.2188f,12.8361f,250.0f, --70.3125f,11.0326f,246.094f, --70.3125f,12.3629f,250.0f, --66.4063f,11.893f,246.094f, --66.4063f,11.1909f,250.0f, --62.5f,10.6469f,246.094f, --62.5f,9.92966f,250.0f, --58.5938f,8.55287f,246.094f, --58.5938f,8.8871f,250.0f, --54.6875f,7.1029f,246.094f, --54.6875f,7.4963f,250.0f, --50.7813f,6.9758f,246.094f, --50.7813f,6.23897f,250.0f, --46.875f,7.98262f,246.094f, --46.875f,6.88918f,250.0f, --42.9688f,9.11554f,246.094f, --42.9688f,7.29319f,250.0f, --39.0625f,8.74373f,246.094f, --39.0625f,6.89167f,250.0f, --35.1563f,7.46275f,246.094f, --35.1563f,6.659f,250.0f, --31.25f,7.67626f,246.094f, --31.25f,6.75404f,250.0f, --27.3438f,7.00511f,246.094f, --27.3438f,6.15573f,250.0f, --23.4375f,5.63813f,246.094f, --23.4375f,5.72737f,250.0f, --19.5313f,5.11885f,246.094f, --19.5313f,4.00822f,250.0f, --15.625f,3.60038f,246.094f, --15.625f,3.50471f,250.0f, --11.7188f,3.05357f,246.094f, --11.7188f,3.0992f,250.0f, --7.8125f,2.48195f,246.094f, --7.8125f,2.46052f,250.0f, --3.90625f,1.69136f,246.094f, --3.90625f,2.5505f,250.0f, -0.0f,1.14548f,246.094f, -0.0f,2.18079f,250.0f, -3.90625f,0.45291f,246.094f, -3.90625f,1.52302f,250.0f, --250.0f,5.2159f,242.188f, --246.094f,7.35218f,242.188f, --242.188f,10.2284f,242.188f, --238.281f,12.7552f,242.188f, --234.375f,14.3317f,242.188f, --230.469f,16.3594f,242.188f, --226.563f,17.8216f,242.188f, --222.656f,18.5321f,242.188f, --218.75f,18.7578f,242.188f, --214.844f,19.504f,242.188f, --210.938f,18.9422f,242.188f, --207.031f,17.9771f,242.188f, --203.125f,17.2798f,242.188f, --199.219f,15.2252f,242.188f, --195.313f,13.8769f,242.188f, --191.406f,12.8727f,242.188f, --187.5f,11.7858f,242.188f, --183.594f,12.4886f,242.188f, --179.688f,12.9814f,242.188f, --175.781f,13.5265f,242.188f, --171.875f,13.8082f,242.188f, --167.969f,13.8407f,242.188f, --164.063f,13.5872f,242.188f, --160.156f,13.8287f,242.188f, --156.25f,13.5778f,242.188f, --152.344f,13.0026f,242.188f, --148.438f,12.6259f,242.188f, --144.531f,12.4666f,242.188f, --140.625f,12.634f,242.188f, --136.719f,12.1746f,242.188f, --132.813f,11.7885f,242.188f, --128.906f,11.4539f,242.188f, --125.0f,11.0084f,242.188f, --121.094f,10.1521f,242.188f, --117.188f,10.6008f,242.188f, --113.281f,10.2088f,242.188f, --109.375f,11.0344f,242.188f, --105.469f,11.1441f,242.188f, --101.563f,12.3959f,242.188f, --97.6563f,13.3587f,242.188f, --93.75f,14.2415f,242.188f, --89.8438f,13.9809f,242.188f, --85.9375f,13.3276f,242.188f, --82.0313f,11.9639f,242.188f, --78.125f,11.5863f,242.188f, --74.2188f,11.7327f,242.188f, --70.3125f,11.5527f,242.188f, --66.4063f,12.3699f,242.188f, --62.5f,11.1959f,242.188f, --58.5938f,9.59967f,242.188f, --54.6875f,8.38887f,242.188f, --50.7813f,7.42613f,242.188f, --46.875f,8.34697f,242.188f, --42.9688f,9.7013f,242.188f, --39.0625f,9.10668f,242.188f, --35.1563f,8.24657f,242.188f, --31.25f,8.06656f,242.188f, --27.3438f,6.98555f,242.188f, --23.4375f,6.88836f,242.188f, --19.5313f,5.88079f,242.188f, --15.625f,4.43148f,242.188f, --11.7188f,3.65843f,242.188f, --7.8125f,2.85687f,242.188f, --3.90625f,1.8332f,242.188f, -0.0f,2.03971f,242.188f, -3.90625f,2.21488f,242.188f, --250.0f,5.44463f,238.281f, --246.094f,7.90885f,238.281f, --242.188f,10.3908f,238.281f, --238.281f,12.875f,238.281f, --234.375f,14.8255f,238.281f, --230.469f,16.5404f,238.281f, --226.563f,17.8109f,238.281f, --222.656f,19.0205f,238.281f, --218.75f,18.7565f,238.281f, --214.844f,18.9852f,238.281f, --210.938f,18.3753f,238.281f, --207.031f,16.6829f,238.281f, --203.125f,15.8099f,238.281f, --199.219f,13.2915f,238.281f, --195.313f,13.447f,238.281f, --191.406f,13.5971f,238.281f, --187.5f,12.1473f,238.281f, --183.594f,13.3531f,238.281f, --179.688f,14.4732f,238.281f, --175.781f,15.0267f,238.281f, --171.875f,14.7852f,238.281f, --167.969f,15.5706f,238.281f, --164.063f,14.267f,238.281f, --160.156f,14.0772f,238.281f, --156.25f,12.4965f,238.281f, --152.344f,12.1473f,238.281f, --148.438f,11.8693f,238.281f, --144.531f,11.2795f,238.281f, --140.625f,10.8173f,238.281f, --136.719f,10.792f,238.281f, --132.813f,10.8481f,238.281f, --128.906f,9.95928f,238.281f, --125.0f,10.0976f,238.281f, --121.094f,8.74444f,238.281f, --117.188f,9.1761f,238.281f, --113.281f,10.2354f,238.281f, --109.375f,10.7023f,238.281f, --105.469f,11.6386f,238.281f, --101.563f,12.7789f,238.281f, --97.6563f,13.956f,238.281f, --93.75f,14.1101f,238.281f, --89.8438f,13.2653f,238.281f, --85.9375f,12.1604f,238.281f, --82.0313f,11.6914f,238.281f, --78.125f,11.3706f,238.281f, --74.2188f,12.1449f,238.281f, --70.3125f,12.4512f,238.281f, --66.4063f,12.6436f,238.281f, --62.5f,11.6692f,238.281f, --58.5938f,10.8304f,238.281f, --54.6875f,8.88158f,238.281f, --50.7813f,7.94904f,238.281f, --46.875f,8.47525f,238.281f, --42.9688f,9.08763f,238.281f, --39.0625f,9.21095f,238.281f, --35.1563f,9.12926f,238.281f, --31.25f,8.5517f,238.281f, --27.3438f,7.86146f,238.281f, --23.4375f,7.33662f,238.281f, --19.5313f,6.37551f,238.281f, --15.625f,5.59324f,238.281f, --11.7188f,4.81831f,238.281f, --7.8125f,4.35695f,238.281f, --3.90625f,3.64159f,238.281f, -0.0f,3.70314f,238.281f, -3.90625f,3.04396f,238.281f, --250.0f,5.92848f,234.375f, --246.094f,8.10446f,234.375f, --242.188f,10.3516f,234.375f, --238.281f,12.4984f,234.375f, --234.375f,15.0991f,234.375f, --230.469f,16.0002f,234.375f, --226.563f,17.2585f,234.375f, --222.656f,18.1852f,234.375f, --218.75f,18.7811f,234.375f, --214.844f,18.4638f,234.375f, --210.938f,18.3171f,234.375f, --207.031f,16.1085f,234.375f, --203.125f,15.1926f,234.375f, --199.219f,14.1792f,234.375f, --195.313f,13.5589f,234.375f, --191.406f,13.9362f,234.375f, --187.5f,13.303f,234.375f, --183.594f,13.6602f,234.375f, --179.688f,15.1086f,234.375f, --175.781f,15.5943f,234.375f, --171.875f,15.3663f,234.375f, --167.969f,14.9609f,234.375f, --164.063f,14.4285f,234.375f, --160.156f,14.1532f,234.375f, --156.25f,13.0139f,234.375f, --152.344f,11.6503f,234.375f, --148.438f,11.6112f,234.375f, --144.531f,11.1097f,234.375f, --140.625f,10.8763f,234.375f, --136.719f,10.2321f,234.375f, --132.813f,9.71321f,234.375f, --128.906f,9.04388f,234.375f, --125.0f,9.53542f,234.375f, --121.094f,8.10006f,234.375f, --117.188f,9.16948f,234.375f, --113.281f,9.67824f,234.375f, --109.375f,10.2679f,234.375f, --105.469f,10.9669f,234.375f, --101.563f,12.2942f,234.375f, --97.6563f,13.2952f,234.375f, --93.75f,13.0932f,234.375f, --89.8438f,12.4514f,234.375f, --85.9375f,12.2395f,234.375f, --82.0313f,11.7622f,234.375f, --78.125f,11.9666f,234.375f, --74.2188f,12.2346f,234.375f, --70.3125f,13.1648f,234.375f, --66.4063f,13.506f,234.375f, --62.5f,13.1773f,234.375f, --58.5938f,11.9168f,234.375f, --54.6875f,10.0208f,234.375f, --50.7813f,9.08267f,234.375f, --46.875f,8.4406f,234.375f, --42.9688f,9.27515f,234.375f, --39.0625f,10.2228f,234.375f, --35.1563f,9.77624f,234.375f, --31.25f,9.17943f,234.375f, --27.3438f,8.83272f,234.375f, --23.4375f,8.00355f,234.375f, --19.5313f,7.37167f,234.375f, --15.625f,6.87424f,234.375f, --11.7188f,6.23994f,234.375f, --7.8125f,5.50641f,234.375f, --3.90625f,5.06839f,234.375f, -0.0f,5.06846f,234.375f, -3.90625f,5.19166f,234.375f, --250.0f,4.98265f,230.469f, --246.094f,7.878f,230.469f, --242.188f,10.9188f,230.469f, --238.281f,12.8549f,230.469f, --234.375f,14.5578f,230.469f, --230.469f,16.067f,230.469f, --226.563f,17.9938f,230.469f, --222.656f,18.3449f,230.469f, --218.75f,18.4423f,230.469f, --214.844f,18.9411f,230.469f, --210.938f,17.3131f,230.469f, --207.031f,15.3292f,230.469f, --203.125f,15.5278f,230.469f, --199.219f,14.9451f,230.469f, --195.313f,13.8026f,230.469f, --191.406f,13.1586f,230.469f, --187.5f,13.4388f,230.469f, --183.594f,14.2213f,230.469f, --179.688f,14.907f,230.469f, --175.781f,15.2295f,230.469f, --171.875f,14.8701f,230.469f, --167.969f,14.1393f,230.469f, --164.063f,13.7829f,230.469f, --160.156f,13.0614f,230.469f, --156.25f,12.3416f,230.469f, --152.344f,11.5366f,230.469f, --148.438f,11.5201f,230.469f, --144.531f,11.0918f,230.469f, --140.625f,11.139f,230.469f, --136.719f,10.0387f,230.469f, --132.813f,8.59099f,230.469f, --128.906f,7.71771f,230.469f, --125.0f,7.44273f,230.469f, --121.094f,8.17087f,230.469f, --117.188f,8.34002f,230.469f, --113.281f,9.22169f,230.469f, --109.375f,10.2195f,230.469f, --105.469f,11.523f,230.469f, --101.563f,12.7411f,230.469f, --97.6563f,12.7429f,230.469f, --93.75f,12.3959f,230.469f, --89.8438f,11.7559f,230.469f, --85.9375f,10.3669f,230.469f, --82.0313f,10.0825f,230.469f, --78.125f,11.4451f,230.469f, --74.2188f,12.235f,230.469f, --70.3125f,13.6016f,230.469f, --66.4063f,14.377f,230.469f, --62.5f,13.967f,230.469f, --58.5938f,12.862f,230.469f, --54.6875f,11.4719f,230.469f, --50.7813f,9.99381f,230.469f, --46.875f,8.68857f,230.469f, --42.9688f,9.43448f,230.469f, --39.0625f,10.4708f,230.469f, --35.1563f,11.0521f,230.469f, --31.25f,10.5864f,230.469f, --27.3438f,10.8331f,230.469f, --23.4375f,9.96112f,230.469f, --19.5313f,8.61029f,230.469f, --15.625f,7.42407f,230.469f, --11.7188f,6.43202f,230.469f, --7.8125f,6.36726f,230.469f, --3.90625f,6.52581f,230.469f, -0.0f,6.18686f,230.469f, -3.90625f,5.885f,230.469f, --250.0f,4.92227f,226.563f, --246.094f,8.66811f,226.563f, --242.188f,11.7599f,226.563f, --238.281f,13.6581f,226.563f, --234.375f,15.6409f,226.563f, --230.469f,16.7907f,226.563f, --226.563f,17.4606f,226.563f, --222.656f,18.4841f,226.563f, --218.75f,18.4506f,226.563f, --214.844f,17.5936f,226.563f, --210.938f,16.5941f,226.563f, --207.031f,14.8805f,226.563f, --203.125f,15.3743f,226.563f, --199.219f,15.4493f,226.563f, --195.313f,14.5184f,226.563f, --191.406f,12.9285f,226.563f, --187.5f,13.3898f,226.563f, --183.594f,14.0358f,226.563f, --179.688f,15.2884f,226.563f, --175.781f,14.972f,226.563f, --171.875f,14.2355f,226.563f, --167.969f,13.6786f,226.563f, --164.063f,13.0771f,226.563f, --160.156f,12.7879f,226.563f, --156.25f,12.4767f,226.563f, --152.344f,11.5156f,226.563f, --148.438f,11.1725f,226.563f, --144.531f,10.8869f,226.563f, --140.625f,9.77232f,226.563f, --136.719f,8.75728f,226.563f, --132.813f,6.77705f,226.563f, --128.906f,6.35083f,226.563f, --125.0f,6.59888f,226.563f, --121.094f,7.81295f,226.563f, --117.188f,8.10078f,226.563f, --113.281f,9.07634f,226.563f, --109.375f,10.2289f,226.563f, --105.469f,11.5342f,226.563f, --101.563f,12.9142f,226.563f, --97.6563f,12.8729f,226.563f, --93.75f,12.8149f,226.563f, --89.8438f,10.9671f,226.563f, --85.9375f,10.0649f,226.563f, --82.0313f,9.28012f,226.563f, --78.125f,10.1324f,226.563f, --74.2188f,11.8638f,226.563f, --70.3125f,12.6141f,226.563f, --66.4063f,13.6851f,226.563f, --62.5f,13.9389f,226.563f, --58.5938f,13.5413f,226.563f, --54.6875f,12.4869f,226.563f, --50.7813f,11.2774f,226.563f, --46.875f,10.6009f,226.563f, --42.9688f,11.4839f,226.563f, --39.0625f,12.5408f,226.563f, --35.1563f,12.8694f,226.563f, --31.25f,12.5253f,226.563f, --27.3438f,12.1887f,226.563f, --23.4375f,11.5356f,226.563f, --19.5313f,9.53151f,226.563f, --15.625f,8.29811f,226.563f, --11.7188f,7.38375f,226.563f, --7.8125f,7.57607f,226.563f, --3.90625f,7.41156f,226.563f, -0.0f,6.9836f,226.563f, -3.90625f,6.89682f,226.563f, --250.0f,4.66781f,222.656f, --246.094f,7.89882f,222.656f, --242.188f,10.8629f,222.656f, --238.281f,14.1235f,222.656f, --234.375f,15.6001f,222.656f, --230.469f,17.0347f,222.656f, --226.563f,17.4872f,222.656f, --222.656f,17.6157f,222.656f, --218.75f,16.8213f,222.656f, --214.844f,16.4076f,222.656f, --210.938f,15.0745f,222.656f, --207.031f,14.2914f,222.656f, --203.125f,14.6094f,222.656f, --199.219f,14.4637f,222.656f, --195.313f,14.0807f,222.656f, --191.406f,12.4559f,222.656f, --187.5f,13.0367f,222.656f, --183.594f,13.975f,222.656f, --179.688f,14.802f,222.656f, --175.781f,14.6145f,222.656f, --171.875f,13.4733f,222.656f, --167.969f,13.3385f,222.656f, --164.063f,13.721f,222.656f, --160.156f,12.5775f,222.656f, --156.25f,11.962f,222.656f, --152.344f,11.2422f,222.656f, --148.438f,10.827f,222.656f, --144.531f,10.2848f,222.656f, --140.625f,8.45922f,222.656f, --136.719f,7.72182f,222.656f, --132.813f,6.23545f,222.656f, --128.906f,5.69752f,222.656f, --125.0f,6.29925f,222.656f, --121.094f,7.1991f,222.656f, --117.188f,7.56788f,222.656f, --113.281f,8.87895f,222.656f, --109.375f,9.92302f,222.656f, --105.469f,10.2628f,222.656f, --101.563f,11.427f,222.656f, --97.6563f,12.2929f,222.656f, --93.75f,11.6083f,222.656f, --89.8438f,11.594f,222.656f, --85.9375f,10.1683f,222.656f, --82.0313f,10.4152f,222.656f, --78.125f,10.765f,222.656f, --74.2188f,11.5311f,222.656f, --70.3125f,12.8761f,222.656f, --66.4063f,14.8794f,222.656f, --62.5f,15.7341f,222.656f, --58.5938f,15.0851f,222.656f, --54.6875f,14.4719f,222.656f, --50.7813f,13.6899f,222.656f, --46.875f,13.0842f,222.656f, --42.9688f,13.1059f,222.656f, --39.0625f,13.9942f,222.656f, --35.1563f,13.8877f,222.656f, --31.25f,14.1293f,222.656f, --27.3438f,13.6276f,222.656f, --23.4375f,12.2206f,222.656f, --19.5313f,10.8481f,222.656f, --15.625f,9.71168f,222.656f, --11.7188f,8.51834f,222.656f, --7.8125f,9.04274f,222.656f, --3.90625f,8.46981f,222.656f, -0.0f,8.26045f,222.656f, -3.90625f,6.81349f,222.656f, --250.0f,5.16984f,218.75f, --246.094f,6.64731f,218.75f, --242.188f,9.50207f,218.75f, --238.281f,12.5115f,218.75f, --234.375f,15.8009f,218.75f, --230.469f,17.6139f,218.75f, --226.563f,18.128f,218.75f, --222.656f,17.3111f,218.75f, --218.75f,16.3962f,218.75f, --214.844f,16.0245f,218.75f, --210.938f,14.5344f,218.75f, --207.031f,13.4459f,218.75f, --203.125f,13.3987f,218.75f, --199.219f,13.5444f,218.75f, --195.313f,12.1973f,218.75f, --191.406f,11.8337f,218.75f, --187.5f,13.3027f,218.75f, --183.594f,13.2862f,218.75f, --179.688f,14.577f,218.75f, --175.781f,14.4312f,218.75f, --171.875f,13.3065f,218.75f, --167.969f,14.2726f,218.75f, --164.063f,14.5522f,218.75f, --160.156f,13.8269f,218.75f, --156.25f,12.4234f,218.75f, --152.344f,10.5035f,218.75f, --148.438f,9.65297f,218.75f, --144.531f,8.3692f,218.75f, --140.625f,7.39811f,218.75f, --136.719f,6.29024f,218.75f, --132.813f,5.37103f,218.75f, --128.906f,5.29069f,218.75f, --125.0f,5.59696f,218.75f, --121.094f,6.15404f,218.75f, --117.188f,7.15855f,218.75f, --113.281f,8.08243f,218.75f, --109.375f,8.97937f,218.75f, --105.469f,9.67177f,218.75f, --101.563f,10.7738f,218.75f, --97.6563f,11.4256f,218.75f, --93.75f,11.6906f,218.75f, --89.8438f,11.4527f,218.75f, --85.9375f,11.5445f,218.75f, --82.0313f,11.9384f,218.75f, --78.125f,12.452f,218.75f, --74.2188f,13.3202f,218.75f, --70.3125f,14.2351f,218.75f, --66.4063f,15.021f,218.75f, --62.5f,16.1053f,218.75f, --58.5938f,16.0633f,218.75f, --54.6875f,15.6154f,218.75f, --50.7813f,15.3347f,218.75f, --46.875f,14.8984f,218.75f, --42.9688f,14.1541f,218.75f, --39.0625f,14.8343f,218.75f, --35.1563f,14.8393f,218.75f, --31.25f,14.865f,218.75f, --27.3438f,13.9913f,218.75f, --23.4375f,13.7749f,218.75f, --19.5313f,12.6247f,218.75f, --15.625f,11.3466f,218.75f, --11.7188f,10.5048f,218.75f, --7.8125f,9.94742f,218.75f, --3.90625f,8.79577f,218.75f, -0.0f,8.31646f,218.75f, -3.90625f,8.02546f,218.75f, --250.0f,4.42455f,214.844f, --246.094f,6.15686f,214.844f, --242.188f,8.4919f,214.844f, --238.281f,12.2627f,214.844f, --234.375f,15.9215f,214.844f, --230.469f,17.6896f,214.844f, --226.563f,18.1835f,214.844f, --222.656f,17.9341f,214.844f, --218.75f,16.9803f,214.844f, --214.844f,15.6617f,214.844f, --210.938f,14.3989f,214.844f, --207.031f,12.7777f,214.844f, --203.125f,12.7635f,214.844f, --199.219f,12.8533f,214.844f, --195.313f,12.1672f,214.844f, --191.406f,12.2357f,214.844f, --187.5f,12.5806f,214.844f, --183.594f,12.5597f,214.844f, --179.688f,13.6296f,214.844f, --175.781f,13.8382f,214.844f, --171.875f,14.4001f,214.844f, --167.969f,14.3002f,214.844f, --164.063f,14.3353f,214.844f, --160.156f,14.0346f,214.844f, --156.25f,12.9823f,214.844f, --152.344f,10.8141f,214.844f, --148.438f,9.57028f,214.844f, --144.531f,8.18427f,214.844f, --140.625f,6.89938f,214.844f, --136.719f,5.79227f,214.844f, --132.813f,4.60172f,214.844f, --128.906f,4.59969f,214.844f, --125.0f,5.20294f,214.844f, --121.094f,6.17542f,214.844f, --117.188f,7.13347f,214.844f, --113.281f,8.1045f,214.844f, --109.375f,8.73005f,214.844f, --105.469f,9.96489f,214.844f, --101.563f,11.1039f,214.844f, --97.6563f,11.6791f,214.844f, --93.75f,11.9246f,214.844f, --89.8438f,12.0071f,214.844f, --85.9375f,12.8099f,214.844f, --82.0313f,13.3672f,214.844f, --78.125f,13.5811f,214.844f, --74.2188f,14.7559f,214.844f, --70.3125f,15.4274f,214.844f, --66.4063f,15.487f,214.844f, --62.5f,16.3346f,214.844f, --58.5938f,16.424f,214.844f, --54.6875f,17.1014f,214.844f, --50.7813f,17.634f,214.844f, --46.875f,16.5132f,214.844f, --42.9688f,15.1728f,214.844f, --39.0625f,15.4699f,214.844f, --35.1563f,16.154f,214.844f, --31.25f,15.8527f,214.844f, --27.3438f,15.4057f,214.844f, --23.4375f,14.6476f,214.844f, --19.5313f,13.1705f,214.844f, --15.625f,11.9754f,214.844f, --11.7188f,11.7453f,214.844f, --7.8125f,10.8384f,214.844f, --3.90625f,10.1259f,214.844f, -0.0f,9.49925f,214.844f, -3.90625f,9.25513f,214.844f, --250.0f,3.60269f,210.938f, --246.094f,5.37638f,210.938f, --242.188f,7.66914f,210.938f, --238.281f,11.9863f,210.938f, --234.375f,14.9525f,210.938f, --230.469f,16.5034f,210.938f, --226.563f,17.8663f,210.938f, --222.656f,17.1002f,210.938f, --218.75f,16.0413f,210.938f, --214.844f,14.8516f,210.938f, --210.938f,13.8904f,210.938f, --207.031f,11.9929f,210.938f, --203.125f,11.8171f,210.938f, --199.219f,11.6849f,210.938f, --195.313f,11.056f,210.938f, --191.406f,11.6318f,210.938f, --187.5f,11.9333f,210.938f, --183.594f,12.599f,210.938f, --179.688f,14.0437f,210.938f, --175.781f,14.7937f,210.938f, --171.875f,14.8844f,210.938f, --167.969f,14.3312f,210.938f, --164.063f,13.2879f,210.938f, --160.156f,12.3423f,210.938f, --156.25f,11.4768f,210.938f, --152.344f,9.94481f,210.938f, --148.438f,7.76655f,210.938f, --144.531f,6.59218f,210.938f, --140.625f,6.49848f,210.938f, --136.719f,5.2458f,210.938f, --132.813f,4.27164f,210.938f, --128.906f,4.68484f,210.938f, --125.0f,5.2746f,210.938f, --121.094f,6.12822f,210.938f, --117.188f,8.02215f,210.938f, --113.281f,8.95036f,210.938f, --109.375f,9.92538f,210.938f, --105.469f,10.4058f,210.938f, --101.563f,11.2862f,210.938f, --97.6563f,11.7274f,210.938f, --93.75f,12.3175f,210.938f, --89.8438f,12.6423f,210.938f, --85.9375f,13.2212f,210.938f, --82.0313f,13.9379f,210.938f, --78.125f,15.3332f,210.938f, --74.2188f,16.2893f,210.938f, --70.3125f,16.1032f,210.938f, --66.4063f,16.7786f,210.938f, --62.5f,16.8038f,210.938f, --58.5938f,16.1537f,210.938f, --54.6875f,17.4306f,210.938f, --50.7813f,17.313f,210.938f, --46.875f,16.2568f,210.938f, --42.9688f,16.0266f,210.938f, --39.0625f,16.9569f,210.938f, --35.1563f,18.0733f,210.938f, --31.25f,17.4779f,210.938f, --27.3438f,17.2939f,210.938f, --23.4375f,16.1477f,210.938f, --19.5313f,15.409f,210.938f, --15.625f,14.0019f,210.938f, --11.7188f,13.3531f,210.938f, --7.8125f,12.4823f,210.938f, --3.90625f,11.7842f,210.938f, -0.0f,11.0776f,210.938f, -3.90625f,10.5728f,210.938f, --250.0f,3.49901f,207.031f, --246.094f,4.00092f,207.031f, --242.188f,7.06194f,207.031f, --238.281f,10.1502f,207.031f, --234.375f,13.0262f,207.031f, --230.469f,15.541f,207.031f, --226.563f,16.4029f,207.031f, --222.656f,16.0741f,207.031f, --218.75f,15.3706f,207.031f, --214.844f,14.3529f,207.031f, --210.938f,13.1351f,207.031f, --207.031f,11.2939f,207.031f, --203.125f,11.4337f,207.031f, --199.219f,11.43f,207.031f, --195.313f,10.6048f,207.031f, --191.406f,10.859f,207.031f, --187.5f,11.8447f,207.031f, --183.594f,12.8305f,207.031f, --179.688f,14.9116f,207.031f, --175.781f,15.0225f,207.031f, --171.875f,14.847f,207.031f, --167.969f,13.7464f,207.031f, --164.063f,12.6716f,207.031f, --160.156f,10.4028f,207.031f, --156.25f,9.61156f,207.031f, --152.344f,9.08545f,207.031f, --148.438f,6.96088f,207.031f, --144.531f,6.6794f,207.031f, --140.625f,6.08012f,207.031f, --136.719f,5.02964f,207.031f, --132.813f,4.93996f,207.031f, --128.906f,4.955f,207.031f, --125.0f,5.23446f,207.031f, --121.094f,7.14164f,207.031f, --117.188f,9.21655f,207.031f, --113.281f,10.8802f,207.031f, --109.375f,11.0518f,207.031f, --105.469f,11.5707f,207.031f, --101.563f,12.2834f,207.031f, --97.6563f,12.7498f,207.031f, --93.75f,12.6608f,207.031f, --89.8438f,12.3649f,207.031f, --85.9375f,13.1678f,207.031f, --82.0313f,13.541f,207.031f, --78.125f,14.3448f,207.031f, --74.2188f,15.6006f,207.031f, --70.3125f,17.0141f,207.031f, --66.4063f,17.4107f,207.031f, --62.5f,18.0045f,207.031f, --58.5938f,17.6582f,207.031f, --54.6875f,17.0297f,207.031f, --50.7813f,16.6619f,207.031f, --46.875f,17.1267f,207.031f, --42.9688f,18.0618f,207.031f, --39.0625f,18.7698f,207.031f, --35.1563f,19.3034f,207.031f, --31.25f,19.1566f,207.031f, --27.3438f,19.1107f,207.031f, --23.4375f,17.3298f,207.031f, --19.5313f,15.7204f,207.031f, --15.625f,14.7827f,207.031f, --11.7188f,14.2027f,207.031f, --7.8125f,13.5758f,207.031f, --3.90625f,13.1935f,207.031f, -0.0f,11.8526f,207.031f, -3.90625f,10.4539f,207.031f, --250.0f,3.85941f,203.125f, --246.094f,3.80391f,203.125f, --242.188f,6.8342f,203.125f, --238.281f,10.0313f,203.125f, --234.375f,12.9894f,203.125f, --230.469f,15.1588f,203.125f, --226.563f,15.6234f,203.125f, --222.656f,15.112f,203.125f, --218.75f,14.5577f,203.125f, --214.844f,14.0703f,203.125f, --210.938f,13.3523f,203.125f, --207.031f,12.1264f,203.125f, --203.125f,11.037f,203.125f, --199.219f,10.3379f,203.125f, --195.313f,11.3f,203.125f, --191.406f,10.6845f,203.125f, --187.5f,11.7023f,203.125f, --183.594f,13.2057f,203.125f, --179.688f,13.976f,203.125f, --175.781f,14.994f,203.125f, --171.875f,14.6465f,203.125f, --167.969f,13.4879f,203.125f, --164.063f,12.0617f,203.125f, --160.156f,10.6454f,203.125f, --156.25f,10.2693f,203.125f, --152.344f,8.33279f,203.125f, --148.438f,7.60557f,203.125f, --144.531f,6.19774f,203.125f, --140.625f,5.7751f,203.125f, --136.719f,5.28903f,203.125f, --132.813f,5.10696f,203.125f, --128.906f,5.61944f,203.125f, --125.0f,7.32929f,203.125f, --121.094f,9.09158f,203.125f, --117.188f,10.6952f,203.125f, --113.281f,11.555f,203.125f, --109.375f,12.5837f,203.125f, --105.469f,13.4444f,203.125f, --101.563f,14.3191f,203.125f, --97.6563f,14.5546f,203.125f, --93.75f,13.9216f,203.125f, --89.8438f,13.07f,203.125f, --85.9375f,13.0497f,203.125f, --82.0313f,13.8884f,203.125f, --78.125f,14.2048f,203.125f, --74.2188f,16.2809f,203.125f, --70.3125f,17.1518f,203.125f, --66.4063f,18.4883f,203.125f, --62.5f,19.2231f,203.125f, --58.5938f,19.0199f,203.125f, --54.6875f,18.4606f,203.125f, --50.7813f,17.3076f,203.125f, --46.875f,17.0012f,203.125f, --42.9688f,18.4311f,203.125f, --39.0625f,19.9758f,203.125f, --35.1563f,20.1252f,203.125f, --31.25f,20.126f,203.125f, --27.3438f,18.9276f,203.125f, --23.4375f,18.3938f,203.125f, --19.5313f,16.6811f,203.125f, --15.625f,15.7398f,203.125f, --11.7188f,14.6978f,203.125f, --7.8125f,14.7567f,203.125f, --3.90625f,14.377f,203.125f, -0.0f,13.0029f,203.125f, -3.90625f,11.4706f,203.125f, --250.0f,4.68355f,199.219f, --246.094f,4.65569f,199.219f, --242.188f,6.34925f,199.219f, --238.281f,9.03665f,199.219f, --234.375f,11.4587f,199.219f, --230.469f,13.9932f,199.219f, --226.563f,14.8268f,199.219f, --222.656f,14.0552f,199.219f, --218.75f,14.4455f,199.219f, --214.844f,14.3053f,199.219f, --210.938f,12.5781f,199.219f, --207.031f,11.5778f,199.219f, --203.125f,9.91652f,199.219f, --199.219f,9.20832f,199.219f, --195.313f,10.1078f,199.219f, --191.406f,10.5638f,199.219f, --187.5f,11.6649f,199.219f, --183.594f,13.3758f,199.219f, --179.688f,15.2035f,199.219f, --175.781f,14.6909f,199.219f, --171.875f,14.0312f,199.219f, --167.969f,12.6808f,199.219f, --164.063f,12.649f,199.219f, --160.156f,11.6333f,199.219f, --156.25f,10.8896f,199.219f, --152.344f,8.72848f,199.219f, --148.438f,7.55753f,199.219f, --144.531f,6.70035f,199.219f, --140.625f,5.28209f,199.219f, --136.719f,5.47347f,199.219f, --132.813f,7.25678f,199.219f, --128.906f,9.06223f,199.219f, --125.0f,9.91604f,199.219f, --121.094f,10.882f,199.219f, --117.188f,11.8314f,199.219f, --113.281f,12.9729f,199.219f, --109.375f,14.1144f,199.219f, --105.469f,15.0374f,199.219f, --101.563f,15.4321f,199.219f, --97.6563f,15.9823f,199.219f, --93.75f,15.4663f,199.219f, --89.8438f,14.4094f,199.219f, --85.9375f,14.1599f,199.219f, --82.0313f,14.4239f,199.219f, --78.125f,14.7717f,199.219f, --74.2188f,15.3979f,199.219f, --70.3125f,16.4014f,199.219f, --66.4063f,17.9486f,199.219f, --62.5f,19.3767f,199.219f, --58.5938f,19.7322f,199.219f, --54.6875f,19.0648f,199.219f, --50.7813f,18.2481f,199.219f, --46.875f,17.1507f,199.219f, --42.9688f,18.6306f,199.219f, --39.0625f,19.2486f,199.219f, --35.1563f,20.3158f,199.219f, --31.25f,19.6441f,199.219f, --27.3438f,18.7294f,199.219f, --23.4375f,17.9051f,199.219f, --19.5313f,17.278f,199.219f, --15.625f,16.1912f,199.219f, --11.7188f,15.3685f,199.219f, --7.8125f,14.8376f,199.219f, --3.90625f,13.8988f,199.219f, -0.0f,12.5645f,199.219f, -3.90625f,12.1184f,199.219f, --250.0f,5.71048f,195.313f, --246.094f,4.68298f,195.313f, --242.188f,5.30012f,195.313f, --238.281f,7.72299f,195.313f, --234.375f,10.9797f,195.313f, --230.469f,12.6343f,195.313f, --226.563f,13.8962f,195.313f, --222.656f,13.2189f,195.313f, --218.75f,14.0254f,195.313f, --214.844f,14.5903f,195.313f, --210.938f,12.6794f,195.313f, --207.031f,9.8479f,195.313f, --203.125f,8.05763f,195.313f, --199.219f,7.68254f,195.313f, --195.313f,9.0324f,195.313f, --191.406f,10.7973f,195.313f, --187.5f,12.1516f,195.313f, --183.594f,13.1888f,195.313f, --179.688f,14.2559f,195.313f, --175.781f,14.0455f,195.313f, --171.875f,13.2785f,195.313f, --167.969f,12.7724f,195.313f, --164.063f,12.56f,195.313f, --160.156f,11.4647f,195.313f, --156.25f,10.6463f,195.313f, --152.344f,9.36927f,195.313f, --148.438f,7.87862f,195.313f, --144.531f,6.78168f,195.313f, --140.625f,5.32688f,195.313f, --136.719f,6.62928f,195.313f, --132.813f,8.97871f,195.313f, --128.906f,10.3174f,195.313f, --125.0f,11.2136f,195.313f, --121.094f,12.2822f,195.313f, --117.188f,13.7351f,195.313f, --113.281f,14.0196f,195.313f, --109.375f,15.5457f,195.313f, --105.469f,16.1402f,195.313f, --101.563f,16.6719f,195.313f, --97.6563f,16.2658f,195.313f, --93.75f,16.5379f,195.313f, --89.8438f,15.1289f,195.313f, --85.9375f,14.7687f,195.313f, --82.0313f,15.4638f,195.313f, --78.125f,15.3391f,195.313f, --74.2188f,14.8602f,195.313f, --70.3125f,16.2701f,195.313f, --66.4063f,17.9511f,195.313f, --62.5f,19.108f,195.313f, --58.5938f,19.5253f,195.313f, --54.6875f,19.1648f,195.313f, --50.7813f,18.0624f,195.313f, --46.875f,17.2201f,195.313f, --42.9688f,19.4165f,195.313f, --39.0625f,20.3781f,195.313f, --35.1563f,19.796f,195.313f, --31.25f,18.9841f,195.313f, --27.3438f,18.3143f,195.313f, --23.4375f,18.1973f,195.313f, --19.5313f,17.5121f,195.313f, --15.625f,16.5969f,195.313f, --11.7188f,15.3539f,195.313f, --7.8125f,14.4654f,195.313f, --3.90625f,13.8161f,195.313f, -0.0f,12.4727f,195.313f, -3.90625f,13.8013f,195.313f, --250.0f,6.07831f,191.406f, --246.094f,5.46721f,191.406f, --242.188f,4.48351f,191.406f, --238.281f,6.74031f,191.406f, --234.375f,9.75661f,191.406f, --230.469f,11.5382f,191.406f, --226.563f,12.9559f,191.406f, --222.656f,12.6196f,191.406f, --218.75f,12.4516f,191.406f, --214.844f,13.5738f,191.406f, --210.938f,12.2334f,191.406f, --207.031f,9.36284f,191.406f, --203.125f,7.56119f,191.406f, --199.219f,8.2975f,191.406f, --195.313f,10.0432f,191.406f, --191.406f,11.528f,191.406f, --187.5f,12.9338f,191.406f, --183.594f,13.9397f,191.406f, --179.688f,14.1423f,191.406f, --175.781f,13.7637f,191.406f, --171.875f,12.7983f,191.406f, --167.969f,12.6132f,191.406f, --164.063f,12.07f,191.406f, --160.156f,11.7037f,191.406f, --156.25f,10.3692f,191.406f, --152.344f,9.29784f,191.406f, --148.438f,7.91508f,191.406f, --144.531f,6.85636f,191.406f, --140.625f,8.06021f,191.406f, --136.719f,8.86078f,191.406f, --132.813f,11.0565f,191.406f, --128.906f,12.4031f,191.406f, --125.0f,13.4308f,191.406f, --121.094f,13.8732f,191.406f, --117.188f,15.0555f,191.406f, --113.281f,16.0219f,191.406f, --109.375f,16.8646f,191.406f, --105.469f,16.9156f,191.406f, --101.563f,16.9811f,191.406f, --97.6563f,17.1773f,191.406f, --93.75f,16.9233f,191.406f, --89.8438f,15.3563f,191.406f, --85.9375f,14.4936f,191.406f, --82.0313f,15.6108f,191.406f, --78.125f,15.9615f,191.406f, --74.2188f,14.6365f,191.406f, --70.3125f,15.5344f,191.406f, --66.4063f,17.4295f,191.406f, --62.5f,18.2646f,191.406f, --58.5938f,19.0205f,191.406f, --54.6875f,19.0503f,191.406f, --50.7813f,17.6912f,191.406f, --46.875f,17.6816f,191.406f, --42.9688f,18.8066f,191.406f, --39.0625f,19.8444f,191.406f, --35.1563f,18.7929f,191.406f, --31.25f,18.6865f,191.406f, --27.3438f,19.0671f,191.406f, --23.4375f,18.6708f,191.406f, --19.5313f,17.7215f,191.406f, --15.625f,16.4711f,191.406f, --11.7188f,15.4735f,191.406f, --7.8125f,14.6316f,191.406f, --3.90625f,13.8779f,191.406f, -0.0f,13.7777f,191.406f, -3.90625f,14.3936f,191.406f, --250.0f,6.25219f,187.5f, --246.094f,5.98752f,187.5f, --242.188f,5.50108f,187.5f, --238.281f,5.52049f,187.5f, --234.375f,7.87236f,187.5f, --230.469f,10.0244f,187.5f, --226.563f,10.9579f,187.5f, --222.656f,11.4176f,187.5f, --218.75f,11.1583f,187.5f, --214.844f,12.0797f,187.5f, --210.938f,10.8226f,187.5f, --207.031f,8.91363f,187.5f, --203.125f,7.71952f,187.5f, --199.219f,8.97116f,187.5f, --195.313f,10.8813f,187.5f, --191.406f,12.5874f,187.5f, --187.5f,13.3418f,187.5f, --183.594f,13.6407f,187.5f, --179.688f,13.8787f,187.5f, --175.781f,13.7918f,187.5f, --171.875f,12.965f,187.5f, --167.969f,12.2732f,187.5f, --164.063f,11.6063f,187.5f, --160.156f,10.9159f,187.5f, --156.25f,10.2447f,187.5f, --152.344f,9.32757f,187.5f, --148.438f,9.17721f,187.5f, --144.531f,9.53961f,187.5f, --140.625f,10.4339f,187.5f, --136.719f,11.8144f,187.5f, --132.813f,13.3081f,187.5f, --128.906f,13.571f,187.5f, --125.0f,13.9242f,187.5f, --121.094f,15.4069f,187.5f, --117.188f,16.9689f,187.5f, --113.281f,17.987f,187.5f, --109.375f,18.7838f,187.5f, --105.469f,18.7737f,187.5f, --101.563f,18.6666f,187.5f, --97.6563f,18.4809f,187.5f, --93.75f,18.3562f,187.5f, --89.8438f,16.3715f,187.5f, --85.9375f,14.5483f,187.5f, --82.0313f,14.9648f,187.5f, --78.125f,16.1061f,187.5f, --74.2188f,14.4715f,187.5f, --70.3125f,14.8322f,187.5f, --66.4063f,16.3093f,187.5f, --62.5f,17.3305f,187.5f, --58.5938f,18.3312f,187.5f, --54.6875f,18.2865f,187.5f, --50.7813f,17.4373f,187.5f, --46.875f,17.9803f,187.5f, --42.9688f,18.679f,187.5f, --39.0625f,19.2363f,187.5f, --35.1563f,19.9926f,187.5f, --31.25f,19.8827f,187.5f, --27.3438f,19.283f,187.5f, --23.4375f,19.0081f,187.5f, --19.5313f,17.5129f,187.5f, --15.625f,16.6754f,187.5f, --11.7188f,15.6685f,187.5f, --7.8125f,14.6133f,187.5f, --3.90625f,13.9468f,187.5f, -0.0f,14.2206f,187.5f, -3.90625f,14.1738f,187.5f, --250.0f,7.10023f,183.594f, --246.094f,6.39376f,183.594f, --242.188f,5.78017f,183.594f, --238.281f,5.07235f,183.594f, --234.375f,5.98564f,183.594f, --230.469f,7.6542f,183.594f, --226.563f,8.75539f,183.594f, --222.656f,9.90845f,183.594f, --218.75f,10.2067f,183.594f, --214.844f,10.2019f,183.594f, --210.938f,9.2327f,183.594f, --207.031f,7.67088f,183.594f, --203.125f,8.15546f,183.594f, --199.219f,9.42269f,183.594f, --195.313f,10.8046f,183.594f, --191.406f,13.3042f,183.594f, --187.5f,13.9971f,183.594f, --183.594f,13.621f,183.594f, --179.688f,13.5612f,183.594f, --175.781f,13.5357f,183.594f, --171.875f,12.8778f,183.594f, --167.969f,12.0385f,183.594f, --164.063f,11.4391f,183.594f, --160.156f,10.4255f,183.594f, --156.25f,10.5692f,183.594f, --152.344f,10.5452f,183.594f, --148.438f,11.506f,183.594f, --144.531f,12.1591f,183.594f, --140.625f,12.6212f,183.594f, --136.719f,13.5025f,183.594f, --132.813f,14.3363f,183.594f, --128.906f,14.5206f,183.594f, --125.0f,15.4902f,183.594f, --121.094f,17.4029f,183.594f, --117.188f,17.9537f,183.594f, --113.281f,18.5532f,183.594f, --109.375f,19.2939f,183.594f, --105.469f,19.2503f,183.594f, --101.563f,19.8772f,183.594f, --97.6563f,19.6753f,183.594f, --93.75f,18.6744f,183.594f, --89.8438f,17.7905f,183.594f, --85.9375f,16.1613f,183.594f, --82.0313f,15.7839f,183.594f, --78.125f,15.657f,183.594f, --74.2188f,14.4171f,183.594f, --70.3125f,14.6083f,183.594f, --66.4063f,15.5594f,183.594f, --62.5f,16.1338f,183.594f, --58.5938f,17.1134f,183.594f, --54.6875f,16.8192f,183.594f, --50.7813f,17.6885f,183.594f, --46.875f,18.5331f,183.594f, --42.9688f,19.7359f,183.594f, --39.0625f,20.7966f,183.594f, --35.1563f,20.414f,183.594f, --31.25f,20.1587f,183.594f, --27.3438f,19.9385f,183.594f, --23.4375f,18.4694f,183.594f, --19.5313f,16.9742f,183.594f, --15.625f,16.0698f,183.594f, --11.7188f,15.4466f,183.594f, --7.8125f,15.0614f,183.594f, --3.90625f,15.2165f,183.594f, -0.0f,14.2632f,183.594f, -3.90625f,13.9878f,183.594f, --250.0f,8.16978f,179.688f, --246.094f,7.02044f,179.688f, --242.188f,6.49336f,179.688f, --238.281f,6.17674f,179.688f, --234.375f,4.65977f,179.688f, --230.469f,5.28977f,179.688f, --226.563f,7.10711f,179.688f, --222.656f,8.03062f,179.688f, --218.75f,9.32719f,179.688f, --214.844f,9.22926f,179.688f, --210.938f,8.64588f,179.688f, --207.031f,7.76534f,179.688f, --203.125f,8.37552f,179.688f, --199.219f,8.61402f,179.688f, --195.313f,10.7567f,179.688f, --191.406f,12.1961f,179.688f, --187.5f,13.5076f,179.688f, --183.594f,13.5739f,179.688f, --179.688f,13.6032f,179.688f, --175.781f,13.5388f,179.688f, --171.875f,13.0425f,179.688f, --167.969f,13.5885f,179.688f, --164.063f,13.2666f,179.688f, --160.156f,11.7827f,179.688f, --156.25f,12.3517f,179.688f, --152.344f,13.1307f,179.688f, --148.438f,13.6688f,179.688f, --144.531f,13.758f,179.688f, --140.625f,14.023f,179.688f, --136.719f,15.1514f,179.688f, --132.813f,16.004f,179.688f, --128.906f,16.8991f,179.688f, --125.0f,17.3616f,179.688f, --121.094f,18.6059f,179.688f, --117.188f,19.3263f,179.688f, --113.281f,19.1956f,179.688f, --109.375f,19.7991f,179.688f, --105.469f,20.6907f,179.688f, --101.563f,21.7059f,179.688f, --97.6563f,21.5595f,179.688f, --93.75f,20.4072f,179.688f, --89.8438f,19.1786f,179.688f, --85.9375f,18.2895f,179.688f, --82.0313f,17.1568f,179.688f, --78.125f,15.2991f,179.688f, --74.2188f,14.0951f,179.688f, --70.3125f,14.2935f,179.688f, --66.4063f,15.0579f,179.688f, --62.5f,15.3497f,179.688f, --58.5938f,15.4148f,179.688f, --54.6875f,17.2528f,179.688f, --50.7813f,18.38f,179.688f, --46.875f,19.343f,179.688f, --42.9688f,20.2151f,179.688f, --39.0625f,21.1482f,179.688f, --35.1563f,20.8113f,179.688f, --31.25f,19.3685f,179.688f, --27.3438f,18.4966f,179.688f, --23.4375f,17.1162f,179.688f, --19.5313f,16.1739f,179.688f, --15.625f,15.1081f,179.688f, --11.7188f,15.5766f,179.688f, --7.8125f,16.3649f,179.688f, --3.90625f,16.3198f,179.688f, -0.0f,15.6844f,179.688f, -3.90625f,14.6785f,179.688f, --250.0f,9.32456f,175.781f, --246.094f,8.37571f,175.781f, --242.188f,7.57502f,175.781f, --238.281f,7.01497f,175.781f, --234.375f,5.67261f,175.781f, --230.469f,4.32895f,175.781f, --226.563f,5.20027f,175.781f, --222.656f,6.31061f,175.781f, --218.75f,7.56464f,175.781f, --214.844f,8.35874f,175.781f, --210.938f,8.24556f,175.781f, --207.031f,7.58905f,175.781f, --203.125f,8.23662f,175.781f, --199.219f,8.64236f,175.781f, --195.313f,10.4842f,175.781f, --191.406f,11.8296f,175.781f, --187.5f,13.5307f,175.781f, --183.594f,14.3422f,175.781f, --179.688f,14.0725f,175.781f, --175.781f,14.6f,175.781f, --171.875f,13.9877f,175.781f, --167.969f,13.7556f,175.781f, --164.063f,13.4564f,175.781f, --160.156f,13.6823f,175.781f, --156.25f,14.2643f,175.781f, --152.344f,14.5034f,175.781f, --148.438f,14.905f,175.781f, --144.531f,15.0207f,175.781f, --140.625f,15.2745f,175.781f, --136.719f,16.7553f,175.781f, --132.813f,17.9777f,175.781f, --128.906f,18.5468f,175.781f, --125.0f,19.2067f,175.781f, --121.094f,19.2384f,175.781f, --117.188f,19.4993f,175.781f, --113.281f,20.2276f,175.781f, --109.375f,21.3946f,175.781f, --105.469f,22.0598f,175.781f, --101.563f,23.2713f,175.781f, --97.6563f,22.6691f,175.781f, --93.75f,21.3119f,175.781f, --89.8438f,20.6083f,175.781f, --85.9375f,19.4937f,175.781f, --82.0313f,18.1998f,175.781f, --78.125f,15.7716f,175.781f, --74.2188f,14.2438f,175.781f, --70.3125f,14.4105f,175.781f, --66.4063f,15.1879f,175.781f, --62.5f,15.7946f,175.781f, --58.5938f,16.2302f,175.781f, --54.6875f,17.1058f,175.781f, --50.7813f,18.9688f,175.781f, --46.875f,19.3102f,175.781f, --42.9688f,19.3902f,175.781f, --39.0625f,19.6545f,175.781f, --35.1563f,19.2909f,175.781f, --31.25f,18.5385f,175.781f, --27.3438f,16.4388f,175.781f, --23.4375f,15.5576f,175.781f, --19.5313f,15.7726f,175.781f, --15.625f,16.3756f,175.781f, --11.7188f,16.9626f,175.781f, --7.8125f,17.219f,175.781f, --3.90625f,17.063f,175.781f, -0.0f,16.3609f,175.781f, -3.90625f,15.2963f,175.781f, --250.0f,10.0329f,171.875f, --246.094f,8.57258f,171.875f, --242.188f,7.81755f,171.875f, --238.281f,6.9951f,171.875f, --234.375f,5.59199f,171.875f, --230.469f,4.81205f,171.875f, --226.563f,4.7432f,171.875f, --222.656f,5.42683f,171.875f, --218.75f,6.16332f,171.875f, --214.844f,6.63573f,171.875f, --210.938f,6.97578f,171.875f, --207.031f,7.49804f,171.875f, --203.125f,8.51155f,171.875f, --199.219f,7.94356f,171.875f, --195.313f,9.50881f,171.875f, --191.406f,10.9726f,171.875f, --187.5f,13.1622f,171.875f, --183.594f,13.8249f,171.875f, --179.688f,15.1925f,171.875f, --175.781f,14.9284f,171.875f, --171.875f,13.915f,171.875f, --167.969f,14.2258f,171.875f, --164.063f,13.435f,171.875f, --160.156f,13.9359f,171.875f, --156.25f,14.8963f,171.875f, --152.344f,15.2933f,171.875f, --148.438f,15.0124f,171.875f, --144.531f,15.0787f,171.875f, --140.625f,15.1958f,171.875f, --136.719f,17.151f,171.875f, --132.813f,18.8799f,171.875f, --128.906f,19.5273f,171.875f, --125.0f,19.6894f,171.875f, --121.094f,19.6466f,171.875f, --117.188f,20.5941f,171.875f, --113.281f,21.5237f,171.875f, --109.375f,22.5435f,171.875f, --105.469f,23.0706f,171.875f, --101.563f,23.614f,171.875f, --97.6563f,22.4198f,171.875f, --93.75f,21.9598f,171.875f, --89.8438f,22.3051f,171.875f, --85.9375f,21.7459f,171.875f, --82.0313f,20.1308f,171.875f, --78.125f,17.6018f,171.875f, --74.2188f,15.106f,171.875f, --70.3125f,16.0838f,171.875f, --66.4063f,16.4153f,171.875f, --62.5f,16.9093f,171.875f, --58.5938f,16.7439f,171.875f, --54.6875f,16.4659f,171.875f, --50.7813f,18.0893f,171.875f, --46.875f,18.8298f,171.875f, --42.9688f,18.459f,171.875f, --39.0625f,18.0953f,171.875f, --35.1563f,18.2461f,171.875f, --31.25f,17.0625f,171.875f, --27.3438f,15.3181f,171.875f, --23.4375f,15.1837f,171.875f, --19.5313f,17.2025f,171.875f, --15.625f,18.3144f,171.875f, --11.7188f,18.4161f,171.875f, --7.8125f,18.3279f,171.875f, --3.90625f,17.5657f,171.875f, -0.0f,16.2057f,171.875f, -3.90625f,16.0791f,171.875f, --250.0f,9.46368f,167.969f, --246.094f,8.91851f,167.969f, --242.188f,7.83383f,167.969f, --238.281f,7.4147f,167.969f, --234.375f,6.33692f,167.969f, --230.469f,5.44334f,167.969f, --226.563f,4.39369f,167.969f, --222.656f,3.44146f,167.969f, --218.75f,4.44651f,167.969f, --214.844f,5.36701f,167.969f, --210.938f,6.2915f,167.969f, --207.031f,6.3588f,167.969f, --203.125f,7.36203f,167.969f, --199.219f,7.7957f,167.969f, --195.313f,9.3926f,167.969f, --191.406f,11.2699f,167.969f, --187.5f,12.3727f,167.969f, --183.594f,14.7022f,167.969f, --179.688f,15.4324f,167.969f, --175.781f,15.226f,167.969f, --171.875f,13.6658f,167.969f, --167.969f,14.0361f,167.969f, --164.063f,13.5871f,167.969f, --160.156f,14.725f,167.969f, --156.25f,15.5452f,167.969f, --152.344f,16.3685f,167.969f, --148.438f,17.0213f,167.969f, --144.531f,16.2228f,167.969f, --140.625f,15.1123f,167.969f, --136.719f,16.9339f,167.969f, --132.813f,18.4025f,167.969f, --128.906f,19.9945f,167.969f, --125.0f,20.4069f,167.969f, --121.094f,21.447f,167.969f, --117.188f,22.384f,167.969f, --113.281f,22.4822f,167.969f, --109.375f,22.9018f,167.969f, --105.469f,23.4936f,167.969f, --101.563f,23.0085f,167.969f, --97.6563f,22.8398f,167.969f, --93.75f,23.2939f,167.969f, --89.8438f,23.3336f,167.969f, --85.9375f,22.6883f,167.969f, --82.0313f,21.8752f,167.969f, --78.125f,18.7456f,167.969f, --74.2188f,16.5685f,167.969f, --70.3125f,17.179f,167.969f, --66.4063f,18.1074f,167.969f, --62.5f,18.9865f,167.969f, --58.5938f,17.4851f,167.969f, --54.6875f,17.2795f,167.969f, --50.7813f,16.9142f,167.969f, --46.875f,17.1532f,167.969f, --42.9688f,17.796f,167.969f, --39.0625f,17.6868f,167.969f, --35.1563f,16.7998f,167.969f, --31.25f,16.0556f,167.969f, --27.3438f,14.7864f,167.969f, --23.4375f,16.8386f,167.969f, --19.5313f,17.9676f,167.969f, --15.625f,18.4144f,167.969f, --11.7188f,18.9248f,167.969f, --7.8125f,18.4614f,167.969f, --3.90625f,17.2197f,167.969f, -0.0f,16.7097f,167.969f, -3.90625f,17.1455f,167.969f, --250.0f,9.27861f,164.063f, --246.094f,8.67875f,164.063f, --242.188f,8.39269f,164.063f, --238.281f,7.54041f,164.063f, --234.375f,6.37361f,164.063f, --230.469f,5.0066f,164.063f, --226.563f,3.63142f,164.063f, --222.656f,2.77898f,164.063f, --218.75f,2.89032f,164.063f, --214.844f,4.01591f,164.063f, --210.938f,4.52151f,164.063f, --207.031f,4.85596f,164.063f, --203.125f,6.21759f,164.063f, --199.219f,8.25574f,164.063f, --195.313f,10.3856f,164.063f, --191.406f,11.6593f,164.063f, --187.5f,12.5334f,164.063f, --183.594f,14.1044f,164.063f, --179.688f,14.8149f,164.063f, --175.781f,14.9916f,164.063f, --171.875f,14.6218f,164.063f, --167.969f,14.5374f,164.063f, --164.063f,13.7748f,164.063f, --160.156f,15.1069f,164.063f, --156.25f,16.5225f,164.063f, --152.344f,17.8264f,164.063f, --148.438f,18.5076f,164.063f, --144.531f,17.6099f,164.063f, --140.625f,16.4656f,164.063f, --136.719f,16.7761f,164.063f, --132.813f,19.1652f,164.063f, --128.906f,20.565f,164.063f, --125.0f,21.7781f,164.063f, --121.094f,22.7613f,164.063f, --117.188f,23.5743f,164.063f, --113.281f,23.3567f,164.063f, --109.375f,24.4075f,164.063f, --105.469f,24.4502f,164.063f, --101.563f,24.044f,164.063f, --97.6563f,24.669f,164.063f, --93.75f,24.7946f,164.063f, --89.8438f,23.9722f,164.063f, --85.9375f,23.2481f,164.063f, --82.0313f,22.4202f,164.063f, --78.125f,19.4816f,164.063f, --74.2188f,18.3571f,164.063f, --70.3125f,19.3195f,164.063f, --66.4063f,19.6276f,164.063f, --62.5f,19.775f,164.063f, --58.5938f,18.4049f,164.063f, --54.6875f,17.6998f,164.063f, --50.7813f,16.7989f,164.063f, --46.875f,16.5351f,164.063f, --42.9688f,16.0836f,164.063f, --39.0625f,16.4446f,164.063f, --35.1563f,15.0322f,164.063f, --31.25f,14.1679f,164.063f, --27.3438f,16.0461f,164.063f, --23.4375f,16.985f,164.063f, --19.5313f,17.3286f,164.063f, --15.625f,18.477f,164.063f, --11.7188f,17.8736f,164.063f, --7.8125f,17.8059f,164.063f, --3.90625f,17.2079f,164.063f, -0.0f,16.7726f,164.063f, -3.90625f,16.4621f,164.063f, --250.0f,8.56359f,160.156f, --246.094f,8.04536f,160.156f, --242.188f,7.71795f,160.156f, --238.281f,7.20369f,160.156f, --234.375f,5.51432f,160.156f, --230.469f,5.00541f,160.156f, --226.563f,4.36899f,160.156f, --222.656f,3.03865f,160.156f, --218.75f,2.92915f,160.156f, --214.844f,2.63693f,160.156f, --210.938f,2.69254f,160.156f, --207.031f,3.5578f,160.156f, --203.125f,5.61634f,160.156f, --199.219f,7.61065f,160.156f, --195.313f,9.64763f,160.156f, --191.406f,11.2848f,160.156f, --187.5f,12.7624f,160.156f, --183.594f,13.2875f,160.156f, --179.688f,15.2776f,160.156f, --175.781f,15.3268f,160.156f, --171.875f,15.211f,160.156f, --167.969f,14.343f,160.156f, --164.063f,14.8683f,160.156f, --160.156f,16.1659f,160.156f, --156.25f,16.4538f,160.156f, --152.344f,18.5601f,160.156f, --148.438f,19.2615f,160.156f, --144.531f,18.8155f,160.156f, --140.625f,17.4377f,160.156f, --136.719f,17.6478f,160.156f, --132.813f,19.7168f,160.156f, --128.906f,21.4745f,160.156f, --125.0f,23.0596f,160.156f, --121.094f,24.6069f,160.156f, --117.188f,25.9676f,160.156f, --113.281f,26.2865f,160.156f, --109.375f,27.1441f,160.156f, --105.469f,27.0334f,160.156f, --101.563f,26.0567f,160.156f, --97.6563f,26.2584f,160.156f, --93.75f,26.2751f,160.156f, --89.8438f,25.6929f,160.156f, --85.9375f,24.0275f,160.156f, --82.0313f,22.2346f,160.156f, --78.125f,20.4728f,160.156f, --74.2188f,19.6229f,160.156f, --70.3125f,20.0997f,160.156f, --66.4063f,21.118f,160.156f, --62.5f,20.4515f,160.156f, --58.5938f,19.4599f,160.156f, --54.6875f,18.2081f,160.156f, --50.7813f,16.8263f,160.156f, --46.875f,16.3719f,160.156f, --42.9688f,15.1416f,160.156f, --39.0625f,14.5969f,160.156f, --35.1563f,14.7039f,160.156f, --31.25f,14.8314f,160.156f, --27.3438f,16.4129f,160.156f, --23.4375f,16.144f,160.156f, --19.5313f,17.5764f,160.156f, --15.625f,17.9247f,160.156f, --11.7188f,17.0582f,160.156f, --7.8125f,17.1554f,160.156f, --3.90625f,16.8369f,160.156f, -0.0f,16.4316f,160.156f, -3.90625f,16.628f,160.156f, --250.0f,7.51933f,156.25f, --246.094f,7.63381f,156.25f, --242.188f,7.57378f,156.25f, --238.281f,6.94606f,156.25f, --234.375f,4.79198f,156.25f, --230.469f,4.43262f,156.25f, --226.563f,4.13314f,156.25f, --222.656f,2.75517f,156.25f, --218.75f,2.67631f,156.25f, --214.844f,3.321f,156.25f, --210.938f,3.33063f,156.25f, --207.031f,3.60719f,156.25f, --203.125f,4.44636f,156.25f, --199.219f,6.02108f,156.25f, --195.313f,8.25702f,156.25f, --191.406f,10.5762f,156.25f, --187.5f,11.4514f,156.25f, --183.594f,12.7361f,156.25f, --179.688f,15.4206f,156.25f, --175.781f,16.1997f,156.25f, --171.875f,14.8996f,156.25f, --167.969f,14.1118f,156.25f, --164.063f,16.0576f,156.25f, --160.156f,17.6078f,156.25f, --156.25f,17.7518f,156.25f, --152.344f,18.4278f,156.25f, --148.438f,19.5827f,156.25f, --144.531f,19.2756f,156.25f, --140.625f,18.2888f,156.25f, --136.719f,18.7157f,156.25f, --132.813f,20.4669f,156.25f, --128.906f,22.5748f,156.25f, --125.0f,24.648f,156.25f, --121.094f,27.1223f,156.25f, --117.188f,28.0709f,156.25f, --113.281f,28.4982f,156.25f, --109.375f,29.0927f,156.25f, --105.469f,29.2755f,156.25f, --101.563f,28.9208f,156.25f, --97.6563f,28.3829f,156.25f, --93.75f,26.8508f,156.25f, --89.8438f,25.9621f,156.25f, --85.9375f,24.2707f,156.25f, --82.0313f,22.6235f,156.25f, --78.125f,21.9368f,156.25f, --74.2188f,21.0831f,156.25f, --70.3125f,21.368f,156.25f, --66.4063f,21.3333f,156.25f, --62.5f,20.5296f,156.25f, --58.5938f,19.98f,156.25f, --54.6875f,18.5818f,156.25f, --50.7813f,17.2025f,156.25f, --46.875f,16.1859f,156.25f, --42.9688f,14.4559f,156.25f, --39.0625f,13.7597f,156.25f, --35.1563f,14.6354f,156.25f, --31.25f,15.6213f,156.25f, --27.3438f,15.683f,156.25f, --23.4375f,16.5331f,156.25f, --19.5313f,16.8272f,156.25f, --15.625f,16.551f,156.25f, --11.7188f,16.34f,156.25f, --7.8125f,16.4067f,156.25f, --3.90625f,15.8725f,156.25f, -0.0f,16.3451f,156.25f, -3.90625f,16.9346f,156.25f, --250.0f,6.48899f,152.344f, --246.094f,6.4047f,152.344f, --242.188f,6.57203f,152.344f, --238.281f,5.4628f,152.344f, --234.375f,4.20753f,152.344f, --230.469f,2.81156f,152.344f, --226.563f,1.88132f,152.344f, --222.656f,1.57153f,152.344f, --218.75f,2.48106f,152.344f, --214.844f,2.88884f,152.344f, --210.938f,2.63578f,152.344f, --207.031f,2.9717f,152.344f, --203.125f,3.6084f,152.344f, --199.219f,3.99032f,152.344f, --195.313f,7.36858f,152.344f, --191.406f,9.54951f,152.344f, --187.5f,10.6254f,152.344f, --183.594f,12.3317f,152.344f, --179.688f,14.015f,152.344f, --175.781f,14.8857f,152.344f, --171.875f,14.9944f,152.344f, --167.969f,14.7547f,152.344f, --164.063f,16.7748f,152.344f, --160.156f,18.5461f,152.344f, --156.25f,19.5932f,152.344f, --152.344f,19.1033f,152.344f, --148.438f,19.012f,152.344f, --144.531f,19.4428f,152.344f, --140.625f,19.3453f,152.344f, --136.719f,20.6611f,152.344f, --132.813f,22.2914f,152.344f, --128.906f,24.3802f,152.344f, --125.0f,26.4048f,152.344f, --121.094f,28.3525f,152.344f, --117.188f,30.0561f,152.344f, --113.281f,30.1155f,152.344f, --109.375f,30.9005f,152.344f, --105.469f,30.8767f,152.344f, --101.563f,30.9056f,152.344f, --97.6563f,30.3635f,152.344f, --93.75f,28.3996f,152.344f, --89.8438f,25.8081f,152.344f, --85.9375f,24.3731f,152.344f, --82.0313f,22.7783f,152.344f, --78.125f,22.5973f,152.344f, --74.2188f,21.8359f,152.344f, --70.3125f,21.4903f,152.344f, --66.4063f,21.0461f,152.344f, --62.5f,19.9934f,152.344f, --58.5938f,19.4729f,152.344f, --54.6875f,18.1265f,152.344f, --50.7813f,16.4684f,152.344f, --46.875f,15.0104f,152.344f, --42.9688f,13.8642f,152.344f, --39.0625f,14.8875f,152.344f, --35.1563f,15.117f,152.344f, --31.25f,15.0707f,152.344f, --27.3438f,15.3829f,152.344f, --23.4375f,15.5218f,152.344f, --19.5313f,15.215f,152.344f, --15.625f,15.2099f,152.344f, --11.7188f,15.5383f,152.344f, --7.8125f,15.6462f,152.344f, --3.90625f,15.3096f,152.344f, -0.0f,16.3854f,152.344f, -3.90625f,17.6952f,152.344f, --250.0f,5.17712f,148.438f, --246.094f,4.67214f,148.438f, --242.188f,4.31659f,148.438f, --238.281f,3.2191f,148.438f, --234.375f,2.13365f,148.438f, --230.469f,1.19555f,148.438f, --226.563f,0.110638f,148.438f, --222.656f,0.945025f,148.438f, --218.75f,1.43378f,148.438f, --214.844f,2.06915f,148.438f, --210.938f,2.27715f,148.438f, --207.031f,2.23051f,148.438f, --203.125f,2.64045f,148.438f, --199.219f,2.99575f,148.438f, --195.313f,5.40402f,148.438f, --191.406f,8.03643f,148.438f, --187.5f,10.0212f,148.438f, --183.594f,12.2205f,148.438f, --179.688f,14.1884f,148.438f, --175.781f,14.5505f,148.438f, --171.875f,15.188f,148.438f, --167.969f,15.2222f,148.438f, --164.063f,17.4791f,148.438f, --160.156f,19.6158f,148.438f, --156.25f,20.2107f,148.438f, --152.344f,20.552f,148.438f, --148.438f,20.2463f,148.438f, --144.531f,20.4526f,148.438f, --140.625f,20.9426f,148.438f, --136.719f,22.6331f,148.438f, --132.813f,25.1345f,148.438f, --128.906f,27.0299f,148.438f, --125.0f,29.381f,148.438f, --121.094f,31.0494f,148.438f, --117.188f,31.7246f,148.438f, --113.281f,31.9331f,148.438f, --109.375f,31.9517f,148.438f, --105.469f,32.217f,148.438f, --101.563f,31.9001f,148.438f, --97.6563f,30.471f,148.438f, --93.75f,28.6143f,148.438f, --89.8438f,26.5696f,148.438f, --85.9375f,24.7785f,148.438f, --82.0313f,23.3248f,148.438f, --78.125f,22.2737f,148.438f, --74.2188f,22.0395f,148.438f, --70.3125f,21.4879f,148.438f, --66.4063f,20.5539f,148.438f, --62.5f,19.3981f,148.438f, --58.5938f,18.0902f,148.438f, --54.6875f,16.6154f,148.438f, --50.7813f,15.8338f,148.438f, --46.875f,14.0809f,148.438f, --42.9688f,12.8188f,148.438f, --39.0625f,14.0819f,148.438f, --35.1563f,14.3673f,148.438f, --31.25f,14.2973f,148.438f, --27.3438f,15.1616f,148.438f, --23.4375f,13.9458f,148.438f, --19.5313f,14.9412f,148.438f, --15.625f,15.4488f,148.438f, --11.7188f,15.3397f,148.438f, --7.8125f,15.0356f,148.438f, --3.90625f,15.6431f,148.438f, -0.0f,16.6218f,148.438f, -3.90625f,18.4109f,148.438f, --250.0f,5.38918f,144.531f, --246.094f,4.29322f,144.531f, --242.188f,2.99843f,144.531f, --238.281f,2.80561f,144.531f, --234.375f,1.65282f,144.531f, --230.469f,-0.268879f,144.531f, --226.563f,-0.474469f,144.531f, --222.656f,-0.0607398f,144.531f, --218.75f,0.859532f,144.531f, --214.844f,1.28455f,144.531f, --210.938f,1.69755f,144.531f, --207.031f,2.1277f,144.531f, --203.125f,2.92014f,144.531f, --199.219f,3.85473f,144.531f, --195.313f,4.38999f,144.531f, --191.406f,6.72101f,144.531f, --187.5f,9.24433f,144.531f, --183.594f,11.6027f,144.531f, --179.688f,13.2042f,144.531f, --175.781f,14.6647f,144.531f, --171.875f,14.7252f,144.531f, --167.969f,16.1425f,144.531f, --164.063f,18.1823f,144.531f, --160.156f,19.9802f,144.531f, --156.25f,22.2009f,144.531f, --152.344f,21.9313f,144.531f, --148.438f,22.3421f,144.531f, --144.531f,21.6393f,144.531f, --140.625f,23.0621f,144.531f, --136.719f,24.695f,144.531f, --132.813f,26.6159f,144.531f, --128.906f,29.9912f,144.531f, --125.0f,31.6471f,144.531f, --121.094f,32.4919f,144.531f, --117.188f,32.9775f,144.531f, --113.281f,33.1587f,144.531f, --109.375f,33.0247f,144.531f, --105.469f,32.4654f,144.531f, --101.563f,31.5009f,144.531f, --97.6563f,30.2211f,144.531f, --93.75f,28.3655f,144.531f, --89.8438f,26.6696f,144.531f, --85.9375f,25.6101f,144.531f, --82.0313f,23.5563f,144.531f, --78.125f,21.8779f,144.531f, --74.2188f,21.4789f,144.531f, --70.3125f,21.2134f,144.531f, --66.4063f,20.0494f,144.531f, --62.5f,19.4674f,144.531f, --58.5938f,17.3288f,144.531f, --54.6875f,16.7337f,144.531f, --50.7813f,15.9259f,144.531f, --46.875f,14.3007f,144.531f, --42.9688f,13.3631f,144.531f, --39.0625f,12.7904f,144.531f, --35.1563f,13.6627f,144.531f, --31.25f,13.6872f,144.531f, --27.3438f,14.0818f,144.531f, --23.4375f,13.953f,144.531f, --19.5313f,14.0386f,144.531f, --15.625f,14.1249f,144.531f, --11.7188f,14.1069f,144.531f, --7.8125f,14.4968f,144.531f, --3.90625f,15.4283f,144.531f, -0.0f,16.5593f,144.531f, -3.90625f,17.8758f,144.531f, --250.0f,5.32443f,140.625f, --246.094f,4.53202f,140.625f, --242.188f,2.85351f,140.625f, --238.281f,1.48443f,140.625f, --234.375f,0.193579f,140.625f, --230.469f,-0.0240196f,140.625f, --226.563f,-0.195521f,140.625f, --222.656f,-0.525286f,140.625f, --218.75f,0.255241f,140.625f, --214.844f,0.505993f,140.625f, --210.938f,1.2501f,140.625f, --207.031f,2.77282f,140.625f, --203.125f,3.23678f,140.625f, --199.219f,3.81665f,140.625f, --195.313f,4.45749f,140.625f, --191.406f,6.57237f,140.625f, --187.5f,8.78049f,140.625f, --183.594f,10.653f,140.625f, --179.688f,12.1762f,140.625f, --175.781f,13.836f,140.625f, --171.875f,14.4421f,140.625f, --167.969f,16.2272f,140.625f, --164.063f,17.8194f,140.625f, --160.156f,20.3268f,140.625f, --156.25f,21.6942f,140.625f, --152.344f,21.8506f,140.625f, --148.438f,22.857f,140.625f, --144.531f,23.0189f,140.625f, --140.625f,24.7041f,140.625f, --136.719f,26.468f,140.625f, --132.813f,28.6459f,140.625f, --128.906f,30.9708f,140.625f, --125.0f,33.2917f,140.625f, --121.094f,34.9879f,140.625f, --117.188f,34.5936f,140.625f, --113.281f,34.2431f,140.625f, --109.375f,33.7219f,140.625f, --105.469f,32.9679f,140.625f, --101.563f,31.3296f,140.625f, --97.6563f,30.0001f,140.625f, --93.75f,28.0182f,140.625f, --89.8438f,26.2542f,140.625f, --85.9375f,24.9632f,140.625f, --82.0313f,23.5598f,140.625f, --78.125f,21.3613f,140.625f, --74.2188f,20.8425f,140.625f, --70.3125f,20.6976f,140.625f, --66.4063f,19.4459f,140.625f, --62.5f,17.9969f,140.625f, --58.5938f,17.2754f,140.625f, --54.6875f,16.763f,140.625f, --50.7813f,15.8668f,140.625f, --46.875f,15.2278f,140.625f, --42.9688f,14.0988f,140.625f, --39.0625f,13.4132f,140.625f, --35.1563f,12.9004f,140.625f, --31.25f,12.6267f,140.625f, --27.3438f,12.7032f,140.625f, --23.4375f,12.0508f,140.625f, --19.5313f,12.8332f,140.625f, --15.625f,12.2269f,140.625f, --11.7188f,12.2256f,140.625f, --7.8125f,13.9086f,140.625f, --3.90625f,15.559f,140.625f, -0.0f,16.8086f,140.625f, -3.90625f,18.5798f,140.625f, --250.0f,4.69677f,136.719f, --246.094f,3.45683f,136.719f, --242.188f,1.81964f,136.719f, --238.281f,1.13059f,136.719f, --234.375f,0.535221f,136.719f, --230.469f,0.868904f,136.719f, --226.563f,0.574251f,136.719f, --222.656f,0.279368f,136.719f, --218.75f,-1.1876f,136.719f, --214.844f,-0.688708f,136.719f, --210.938f,0.470686f,136.719f, --207.031f,2.00488f,136.719f, --203.125f,3.42644f,136.719f, --199.219f,4.20503f,136.719f, --195.313f,5.23588f,136.719f, --191.406f,6.02424f,136.719f, --187.5f,7.96541f,136.719f, --183.594f,10.5299f,136.719f, --179.688f,12.0941f,136.719f, --175.781f,13.5058f,136.719f, --171.875f,14.8816f,136.719f, --167.969f,16.551f,136.719f, --164.063f,17.712f,136.719f, --160.156f,19.6536f,136.719f, --156.25f,21.4322f,136.719f, --152.344f,22.672f,136.719f, --148.438f,23.3463f,136.719f, --144.531f,24.5334f,136.719f, --140.625f,26.061f,136.719f, --136.719f,27.7423f,136.719f, --132.813f,30.1692f,136.719f, --128.906f,33.3739f,136.719f, --125.0f,34.9742f,136.719f, --121.094f,35.9387f,136.719f, --117.188f,36.0925f,136.719f, --113.281f,35.6549f,136.719f, --109.375f,34.5646f,136.719f, --105.469f,34.6062f,136.719f, --101.563f,32.8375f,136.719f, --97.6563f,30.2678f,136.719f, --93.75f,27.2213f,136.719f, --89.8438f,26.1126f,136.719f, --85.9375f,24.9965f,136.719f, --82.0313f,22.5841f,136.719f, --78.125f,21.7213f,136.719f, --74.2188f,21.534f,136.719f, --70.3125f,20.5652f,136.719f, --66.4063f,19.032f,136.719f, --62.5f,17.4252f,136.719f, --58.5938f,16.7783f,136.719f, --54.6875f,15.9619f,136.719f, --50.7813f,14.8707f,136.719f, --46.875f,14.3143f,136.719f, --42.9688f,13.8793f,136.719f, --39.0625f,12.6352f,136.719f, --35.1563f,12.0433f,136.719f, --31.25f,11.8551f,136.719f, --27.3438f,12.0193f,136.719f, --23.4375f,11.2795f,136.719f, --19.5313f,11.6002f,136.719f, --15.625f,10.9143f,136.719f, --11.7188f,12.1473f,136.719f, --7.8125f,14.3093f,136.719f, --3.90625f,16.245f,136.719f, -0.0f,17.3141f,136.719f, -3.90625f,19.7224f,136.719f, --250.0f,3.94613f,132.813f, --246.094f,2.33247f,132.813f, --242.188f,1.96569f,132.813f, --238.281f,1.1741f,132.813f, --234.375f,0.606142f,132.813f, --230.469f,0.00901447f,132.813f, --226.563f,0.143339f,132.813f, --222.656f,-0.356031f,132.813f, --218.75f,-1.55439f,132.813f, --214.844f,-1.22801f,132.813f, --210.938f,-0.390443f,132.813f, --207.031f,1.15349f,132.813f, --203.125f,2.6275f,132.813f, --199.219f,3.55895f,132.813f, --195.313f,4.99281f,132.813f, --191.406f,4.99673f,132.813f, --187.5f,6.96468f,132.813f, --183.594f,10.0691f,132.813f, --179.688f,12.3783f,132.813f, --175.781f,13.2459f,132.813f, --171.875f,14.3637f,132.813f, --167.969f,16.3222f,132.813f, --164.063f,17.6984f,132.813f, --160.156f,19.3295f,132.813f, --156.25f,20.9768f,132.813f, --152.344f,23.1452f,132.813f, --148.438f,23.885f,132.813f, --144.531f,24.7169f,132.813f, --140.625f,27.1655f,132.813f, --136.719f,29.0232f,132.813f, --132.813f,30.2573f,132.813f, --128.906f,33.5563f,132.813f, --125.0f,35.1858f,132.813f, --121.094f,36.4332f,132.813f, --117.188f,36.6359f,132.813f, --113.281f,36.0253f,132.813f, --109.375f,34.7127f,132.813f, --105.469f,34.6833f,132.813f, --101.563f,33.7208f,132.813f, --97.6563f,30.9809f,132.813f, --93.75f,27.9091f,132.813f, --89.8438f,25.709f,132.813f, --85.9375f,24.452f,132.813f, --82.0313f,22.4897f,132.813f, --78.125f,22.0485f,132.813f, --74.2188f,22.1517f,132.813f, --70.3125f,20.4874f,132.813f, --66.4063f,19.0482f,132.813f, --62.5f,17.1019f,132.813f, --58.5938f,16.7815f,132.813f, --54.6875f,15.1253f,132.813f, --50.7813f,14.5074f,132.813f, --46.875f,12.7631f,132.813f, --42.9688f,12.6595f,132.813f, --39.0625f,11.9406f,132.813f, --35.1563f,11.7459f,132.813f, --31.25f,10.8406f,132.813f, --27.3438f,11.0393f,132.813f, --23.4375f,10.4798f,132.813f, --19.5313f,10.8165f,132.813f, --15.625f,12.4368f,132.813f, --11.7188f,13.2405f,132.813f, --7.8125f,14.9282f,132.813f, --3.90625f,16.4449f,132.813f, -0.0f,17.8238f,132.813f, -3.90625f,19.9574f,132.813f, --250.0f,2.5744f,128.906f, --246.094f,2.12474f,128.906f, --242.188f,0.674823f,128.906f, --238.281f,-0.305135f,128.906f, --234.375f,-0.948647f,128.906f, --230.469f,-0.982836f,128.906f, --226.563f,-1.17369f,128.906f, --222.656f,-1.48697f,128.906f, --218.75f,-2.23137f,128.906f, --214.844f,-2.13825f,128.906f, --210.938f,-1.06826f,128.906f, --207.031f,0.0666403f,128.906f, --203.125f,1.15717f,128.906f, --199.219f,3.14762f,128.906f, --195.313f,4.08858f,128.906f, --191.406f,5.07728f,128.906f, --187.5f,8.06699f,128.906f, --183.594f,10.7473f,128.906f, --179.688f,12.0801f,128.906f, --175.781f,13.1617f,128.906f, --171.875f,14.5283f,128.906f, --167.969f,15.8148f,128.906f, --164.063f,16.9067f,128.906f, --160.156f,18.6293f,128.906f, --156.25f,20.8869f,128.906f, --152.344f,22.6168f,128.906f, --148.438f,23.9359f,128.906f, --144.531f,26.521f,128.906f, --140.625f,27.4381f,128.906f, --136.719f,29.5698f,128.906f, --132.813f,30.681f,128.906f, --128.906f,33.28f,128.906f, --125.0f,35.3433f,128.906f, --121.094f,36.3509f,128.906f, --117.188f,36.2098f,128.906f, --113.281f,35.157f,128.906f, --109.375f,35.3884f,128.906f, --105.469f,35.7158f,128.906f, --101.563f,34.3449f,128.906f, --97.6563f,32.5198f,128.906f, --93.75f,29.0611f,128.906f, --89.8438f,25.9945f,128.906f, --85.9375f,24.2624f,128.906f, --82.0313f,23.0248f,128.906f, --78.125f,21.6012f,128.906f, --74.2188f,21.0399f,128.906f, --70.3125f,20.1719f,128.906f, --66.4063f,18.6862f,128.906f, --62.5f,17.3287f,128.906f, --58.5938f,16.0916f,128.906f, --54.6875f,14.1153f,128.906f, --50.7813f,12.6292f,128.906f, --46.875f,12.0431f,128.906f, --42.9688f,11.4785f,128.906f, --39.0625f,11.911f,128.906f, --35.1563f,11.6609f,128.906f, --31.25f,10.4332f,128.906f, --27.3438f,9.68026f,128.906f, --23.4375f,9.84506f,128.906f, --19.5313f,11.6097f,128.906f, --15.625f,13.2944f,128.906f, --11.7188f,14.0518f,128.906f, --7.8125f,15.2998f,128.906f, --3.90625f,16.8731f,128.906f, -0.0f,18.0594f,128.906f, -3.90625f,20.0876f,128.906f, --250.0f,2.47782f,125.0f, --246.094f,1.27263f,125.0f, --242.188f,-0.535855f,125.0f, --238.281f,-1.33089f,125.0f, --234.375f,-1.63273f,125.0f, --230.469f,-2.30607f,125.0f, --226.563f,-2.13647f,125.0f, --222.656f,-2.95807f,125.0f, --218.75f,-2.92133f,125.0f, --214.844f,-3.33811f,125.0f, --210.938f,-2.29807f,125.0f, --207.031f,-0.860766f,125.0f, --203.125f,0.507027f,125.0f, --199.219f,1.54044f,125.0f, --195.313f,3.32139f,125.0f, --191.406f,5.76593f,125.0f, --187.5f,8.17548f,125.0f, --183.594f,10.5223f,125.0f, --179.688f,11.4741f,125.0f, --175.781f,12.3545f,125.0f, --171.875f,13.5542f,125.0f, --167.969f,14.4358f,125.0f, --164.063f,16.6197f,125.0f, --160.156f,18.7561f,125.0f, --156.25f,21.2618f,125.0f, --152.344f,22.9541f,125.0f, --148.438f,24.7574f,125.0f, --144.531f,26.8375f,125.0f, --140.625f,28.3307f,125.0f, --136.719f,29.2598f,125.0f, --132.813f,31.2334f,125.0f, --128.906f,32.9236f,125.0f, --125.0f,34.4853f,125.0f, --121.094f,35.1589f,125.0f, --117.188f,34.4655f,125.0f, --113.281f,35.7692f,125.0f, --109.375f,35.9985f,125.0f, --105.469f,35.7974f,125.0f, --101.563f,34.6099f,125.0f, --97.6563f,32.4066f,125.0f, --93.75f,28.8398f,125.0f, --89.8438f,26.014f,125.0f, --85.9375f,25.0319f,125.0f, --82.0313f,23.7685f,125.0f, --78.125f,22.4099f,125.0f, --74.2188f,20.9166f,125.0f, --70.3125f,19.1502f,125.0f, --66.4063f,17.8355f,125.0f, --62.5f,16.5146f,125.0f, --58.5938f,14.9189f,125.0f, --54.6875f,13.2423f,125.0f, --50.7813f,12.2568f,125.0f, --46.875f,11.4853f,125.0f, --42.9688f,10.7795f,125.0f, --39.0625f,10.3251f,125.0f, --35.1563f,10.4077f,125.0f, --31.25f,9.96202f,125.0f, --27.3438f,9.77658f,125.0f, --23.4375f,10.6703f,125.0f, --19.5313f,12.2058f,125.0f, --15.625f,13.8385f,125.0f, --11.7188f,15.1556f,125.0f, --7.8125f,15.7626f,125.0f, --3.90625f,16.911f,125.0f, -0.0f,18.0803f,125.0f, -3.90625f,18.9654f,125.0f, --250.0f,1.97449f,121.094f, --246.094f,1.28169f,121.094f, --242.188f,0.0699786f,121.094f, --238.281f,-1.31551f,121.094f, --234.375f,-2.33115f,121.094f, --230.469f,-3.19445f,121.094f, --226.563f,-3.91693f,121.094f, --222.656f,-4.0298f,121.094f, --218.75f,-4.334f,121.094f, --214.844f,-3.5405f,121.094f, --210.938f,-2.70043f,121.094f, --207.031f,-2.86125f,121.094f, --203.125f,-1.24727f,121.094f, --199.219f,0.20797f,121.094f, --195.313f,2.52573f,121.094f, --191.406f,4.8544f,121.094f, --187.5f,7.37504f,121.094f, --183.594f,9.40828f,121.094f, --179.688f,11.0747f,121.094f, --175.781f,11.9892f,121.094f, --171.875f,12.3358f,121.094f, --167.969f,13.2084f,121.094f, --164.063f,15.8626f,121.094f, --160.156f,18.1098f,121.094f, --156.25f,20.2905f,121.094f, --152.344f,22.8183f,121.094f, --148.438f,25.3439f,121.094f, --144.531f,26.7908f,121.094f, --140.625f,29.0959f,121.094f, --136.719f,29.9478f,121.094f, --132.813f,30.8054f,121.094f, --128.906f,31.9545f,121.094f, --125.0f,33.8025f,121.094f, --121.094f,35.2826f,121.094f, --117.188f,36.2373f,121.094f, --113.281f,36.7861f,121.094f, --109.375f,36.509f,121.094f, --105.469f,35.7461f,121.094f, --101.563f,33.7802f,121.094f, --97.6563f,30.788f,121.094f, --93.75f,28.1422f,121.094f, --89.8438f,26.6316f,121.094f, --85.9375f,26.0349f,121.094f, --82.0313f,24.8022f,121.094f, --78.125f,23.5217f,121.094f, --74.2188f,21.74f,121.094f, --70.3125f,20.0101f,121.094f, --66.4063f,17.8705f,121.094f, --62.5f,15.6785f,121.094f, --58.5938f,13.74f,121.094f, --54.6875f,12.3387f,121.094f, --50.7813f,11.9457f,121.094f, --46.875f,12.0102f,121.094f, --42.9688f,11.0065f,121.094f, --39.0625f,9.84571f,121.094f, --35.1563f,10.0894f,121.094f, --31.25f,10.5366f,121.094f, --27.3438f,9.94957f,121.094f, --23.4375f,11.0038f,121.094f, --19.5313f,12.8084f,121.094f, --15.625f,13.8969f,121.094f, --11.7188f,14.9146f,121.094f, --7.8125f,15.4187f,121.094f, --3.90625f,16.094f,121.094f, -0.0f,17.0612f,121.094f, -3.90625f,18.5327f,121.094f, --250.0f,2.18397f,117.188f, --246.094f,1.51628f,117.188f, --242.188f,0.628327f,117.188f, --238.281f,-0.567933f,117.188f, --234.375f,-2.01568f,117.188f, --230.469f,-3.41089f,117.188f, --226.563f,-3.82758f,117.188f, --222.656f,-5.01586f,117.188f, --218.75f,-4.74822f,117.188f, --214.844f,-3.30853f,117.188f, --210.938f,-2.32499f,117.188f, --207.031f,-1.71509f,117.188f, --203.125f,-1.19203f,117.188f, --199.219f,0.219498f,117.188f, --195.313f,1.66304f,117.188f, --191.406f,4.35105f,117.188f, --187.5f,6.33228f,117.188f, --183.594f,8.00972f,117.188f, --179.688f,9.71486f,117.188f, --175.781f,10.7727f,117.188f, --171.875f,11.358f,117.188f, --167.969f,12.5239f,117.188f, --164.063f,14.6278f,117.188f, --160.156f,17.2069f,117.188f, --156.25f,19.9779f,117.188f, --152.344f,23.4607f,117.188f, --148.438f,26.6108f,117.188f, --144.531f,28.4635f,117.188f, --140.625f,29.7705f,117.188f, --136.719f,31.0684f,117.188f, --132.813f,31.8395f,117.188f, --128.906f,32.1658f,117.188f, --125.0f,34.7478f,117.188f, --121.094f,36.0624f,117.188f, --117.188f,37.2702f,117.188f, --113.281f,37.3474f,117.188f, --109.375f,37.242f,117.188f, --105.469f,36.1544f,117.188f, --101.563f,33.403f,117.188f, --97.6563f,31.294f,117.188f, --93.75f,29.4961f,117.188f, --89.8438f,29.0556f,117.188f, --85.9375f,28.2757f,117.188f, --82.0313f,26.6322f,117.188f, --78.125f,24.8286f,117.188f, --74.2188f,22.7019f,117.188f, --70.3125f,20.4725f,117.188f, --66.4063f,17.984f,117.188f, --62.5f,16.3033f,117.188f, --58.5938f,14.2087f,117.188f, --54.6875f,12.8086f,117.188f, --50.7813f,12.5463f,117.188f, --46.875f,12.1781f,117.188f, --42.9688f,11.1391f,117.188f, --39.0625f,10.4623f,117.188f, --35.1563f,11.0528f,117.188f, --31.25f,11.454f,117.188f, --27.3438f,10.5577f,117.188f, --23.4375f,10.6328f,117.188f, --19.5313f,12.5569f,117.188f, --15.625f,13.5389f,117.188f, --11.7188f,14.3792f,117.188f, --7.8125f,15.4809f,117.188f, --3.90625f,16.1008f,117.188f, -0.0f,17.3675f,117.188f, -3.90625f,18.919f,117.188f, -}; - -btScalar Landscape06Nml[] = { --0.373915f,0.891474f,-0.255855f, --0.31015f,0.793525f,-0.52357f, --0.450332f,0.86393f,-0.225447f, --0.404472f,0.777981f,-0.480778f, --0.557629f,0.811458f,-0.174885f, --0.428564f,0.86234f,-0.269633f, --0.414608f,0.909847f,-0.0166634f, --0.208047f,0.971233f,0.115854f, --0.328757f,0.932331f,0.150588f, --0.263029f,0.937991f,0.225808f, --0.409412f,0.900937f,0.143853f, --0.455309f,0.881347f,0.126178f, --0.31951f,0.943247f,0.0905511f, --0.33825f,0.934582f,0.1102f, --0.183669f,0.981438f,0.0551769f, --0.208308f,0.97293f,0.100072f, --0.189578f,0.981862f,-0.00282566f, --0.201983f,0.97649f,0.0752952f, --0.0672914f,0.99749f,-0.0220572f, --0.118523f,0.991949f,0.0446084f, -0.102757f,0.986595f,-0.126773f, -0.00122687f,0.992675f,-0.120808f, -0.0798054f,0.967751f,-0.238933f, -0.00875196f,0.978629f,-0.205448f, -0.141554f,0.932155f,-0.333242f, -0.0918343f,0.965319f,-0.244387f, -0.372959f,0.842559f,-0.388582f, -0.280191f,0.875069f,-0.394647f, -0.314921f,0.849656f,-0.422977f, -0.258676f,0.813335f,-0.521127f, -0.266443f,0.876708f,-0.400489f, -0.358307f,0.856764f,-0.370907f, -0.280512f,0.913716f,-0.293999f, -0.337561f,0.857178f,-0.388971f, -0.0927666f,0.994197f,-0.0544758f, -0.155544f,0.953116f,-0.259567f, --0.18671f,0.979157f,-0.0799463f, --0.20939f,0.930283f,-0.301212f, --0.117108f,0.986639f,-0.113269f, --0.190516f,0.897405f,-0.397956f, --0.0703231f,0.977433f,-0.199199f, --0.142735f,0.82748f,-0.54305f, --0.00706444f,0.969596f,-0.244609f, -0.0216131f,0.85384f,-0.520087f, --0.100606f,0.961424f,-0.256011f, -0.00977565f,0.925054f,-0.379709f, --0.0412166f,0.978641f,-0.201403f, -0.099113f,0.987693f,-0.12099f, -0.0911178f,0.982669f,-0.16143f, -0.0730708f,0.986329f,-0.147703f, -0.114859f,0.978874f,-0.169152f, -0.109302f,0.983788f,-0.142175f, -0.116167f,0.976713f,-0.180378f, -0.0784892f,0.966143f,-0.24578f, -0.0196949f,0.987682f,-0.155232f, -0.0258077f,0.978923f,-0.202593f, --0.0161862f,0.979217f,-0.202168f, --0.120896f,0.935381f,-0.332336f, --0.0291128f,0.941335f,-0.336215f, --0.0776893f,0.901631f,-0.425472f, --0.0768763f,0.919716f,-0.384983f, --0.0462705f,0.951989f,-0.302615f, --0.0260847f,0.891121f,-0.453016f, --0.0818404f,0.911776f,-0.40245f, -0.152271f,0.86407f,-0.479789f, -0.0880729f,0.874485f,-0.476991f, -0.11644f,0.855496f,-0.504548f, -0.0395982f,0.813262f,-0.580548f, -0.00631598f,0.857568f,-0.514332f, --0.0780909f,0.759651f,-0.645626f, --0.0538158f,0.822232f,-0.566603f, -0.0102932f,0.785194f,-0.619165f, --0.00905015f,0.879608f,-0.475613f, -0.0439442f,0.825793f,-0.562259f, --0.15058f,0.877556f,-0.455216f, --0.0080088f,0.902753f,-0.430085f, --0.112334f,0.946952f,-0.301104f, -0.00843129f,0.966084f,-0.258092f, --0.0520095f,0.981628f,-0.183579f, --0.0023169f,0.970009f,-0.243057f, --0.0302799f,0.995335f,-0.0916051f, -0.0376961f,0.991328f,-0.125888f, -0.0852061f,0.995425f,-0.0432221f, -0.156966f,0.986644f,0.0435404f, -0.21491f,0.973384f,-0.079613f, -0.060548f,0.977921f,-0.200013f, -0.158822f,0.967125f,-0.198606f, -0.134591f,0.957423f,-0.255396f, -0.121293f,0.978974f,-0.164008f, -0.108432f,0.947609f,-0.300465f, -0.0857608f,0.988377f,-0.125519f, -0.0956294f,0.951748f,-0.291599f, --0.0286686f,0.995404f,-0.0913747f, -0.0793846f,0.975448f,-0.205424f, -0.106071f,0.990697f,0.085251f, -0.292453f,0.941038f,0.170056f, -0.371746f,0.914213f,0.161306f, -0.341006f,0.933768f,0.108596f, -0.372402f,0.920827f,0.115737f, -0.298439f,0.950662f,-0.0847083f, -0.211549f,0.974139f,0.0793788f, -0.255698f,0.96634f,-0.0283838f, --0.0706076f,0.991212f,0.111867f, -0.0490836f,0.977096f,0.207063f, --0.256838f,0.950876f,0.172827f, --0.168627f,0.937168f,0.30542f, --0.0642391f,0.963856f,0.258562f, --0.00196823f,0.905532f,0.424274f, -0.182795f,0.945782f,0.268481f, -0.13515f,0.919671f,0.368699f, -0.107184f,0.970151f,0.217528f, -0.00985613f,0.977921f,0.208742f, -0.0734564f,0.98632f,0.147572f, -0.067487f,0.972043f,0.224896f, -0.20672f,0.968081f,0.141727f, -0.186648f,0.970679f,0.151478f, -0.213561f,0.965286f,0.150383f, -0.189498f,0.980689f,0.0483704f, -0.277013f,0.94213f,0.188824f, -0.316429f,0.927757f,0.197839f, -0.225121f,0.964838f,0.135677f, -0.124434f,0.992109f,0.0153398f, -0.14416f,0.987262f,0.0673169f, -0.128154f,0.991727f,-0.0073791f, -0.1809f,0.982671f,0.0404037f, -0.125271f,0.99083f,-0.0506329f, -0.117639f,0.992303f,-0.0386759f, -0.0449726f,0.973305f,-0.225068f, -0.124809f,0.992058f,0.0156083f, -0.127135f,0.958258f,-0.256082f, -0.171896f,0.982167f,0.0761593f, -0.160304f,0.951991f,-0.260798f, --0.494953f,0.868907f,-0.00477061f, --0.512017f,0.856533f,0.0647248f, --0.564588f,0.823588f,0.0542513f, --0.480746f,0.876502f,0.0250513f, --0.397786f,0.91419f,0.0776024f, --0.3922f,0.916181f,0.0824136f, --0.288362f,0.955571f,0.0610852f, --0.109541f,0.991807f,0.0657195f, --0.119597f,0.99188f,-0.0432477f, --0.0246849f,0.992746f,-0.117673f, -0.197846f,0.964215f,-0.176481f, -0.198977f,0.940868f,-0.274182f, -0.288209f,0.884317f,-0.367314f, -0.309487f,0.847917f,-0.430411f, -0.274335f,0.939851f,-0.20352f, -0.256503f,0.958634f,-0.123399f, -0.0454718f,0.993939f,-0.100084f, --0.104233f,0.980418f,0.167081f, --0.137204f,0.957647f,0.253153f, --0.0909923f,0.97094f,0.221352f, --0.0588081f,0.977218f,0.203928f, -0.0555628f,0.971956f,0.228506f, -0.00693538f,0.995197f,0.0976442f, -0.0112691f,0.996103f,-0.0874744f, -0.104487f,0.972486f,-0.208215f, -0.102504f,0.971128f,-0.215412f, -0.0933319f,0.976682f,-0.193342f, -0.023135f,0.974909f,-0.221399f, -0.0195254f,0.964185f,-0.264511f, -0.0843961f,0.966003f,-0.244368f, -0.0791804f,0.94997f,-0.30214f, -0.048562f,0.904645f,-0.423391f, -0.168302f,0.901104f,-0.399607f, -0.0460994f,0.899241f,-0.435018f, --0.0201301f,0.942734f,-0.332937f, --0.0651933f,0.964794f,-0.254799f, --0.107417f,0.971064f,-0.213298f, --0.17484f,0.97454f,-0.140369f, --0.26177f,0.957564f,-0.120611f, --0.18964f,0.980348f,-0.0543506f, --0.0244255f,0.999511f,-0.0195208f, -0.0943164f,0.983888f,-0.151887f, -0.241216f,0.961222f,-0.133665f, -0.186016f,0.976207f,-0.111437f, -0.0288865f,0.998091f,-0.0545842f, --0.00269516f,0.997826f,0.0658428f, --0.0454406f,0.988515f,0.144131f, -0.0349744f,0.994103f,0.102646f, -0.310638f,0.939659f,0.143339f, -0.362637f,0.904005f,0.226428f, -0.268459f,0.940968f,0.206177f, --0.0101438f,0.990408f,0.137803f, --0.259956f,0.964753f,0.0409231f, --0.105214f,0.99436f,0.0133734f, -0.151003f,0.984401f,0.0902917f, -0.153972f,0.971331f,0.181133f, -0.131893f,0.982033f,0.134962f, -0.145326f,0.983866f,0.104346f, -0.172165f,0.970545f,0.16853f, -0.260168f,0.947172f,0.18756f, -0.265906f,0.934787f,0.235514f, -0.175251f,0.956563f,0.232968f, -0.205308f,0.948623f,0.240753f, -0.093567f,0.968565f,0.230493f, -0.000708259f,0.964766f,0.263107f, -0.00657781f,0.964909f,0.262504f, --0.520396f,0.851586f,0.063156f, --0.521936f,0.850242f,0.0683468f, --0.537166f,0.843365f,0.0137284f, --0.507784f,0.86143f,-0.00972442f, --0.393238f,0.917684f,0.0567504f, --0.362634f,0.931285f,-0.0347048f, --0.298916f,0.951591f,-0.0715749f, --0.125797f,0.991634f,-0.0289454f, -0.00629701f,0.999979f,0.00117199f, -0.0170902f,0.994718f,-0.101214f, -0.290594f,0.952688f,-0.0891078f, -0.285259f,0.936469f,-0.20409f, -0.342737f,0.918097f,-0.199071f, -0.262981f,0.956466f,-0.126547f, --0.000199178f,0.996828f,-0.0795833f, -0.16652f,0.978742f,0.119733f, -0.0382843f,0.984413f,0.171653f, --0.277981f,0.950703f,0.137441f, --0.18354f,0.954113f,0.236605f, --0.0382213f,0.967232f,0.251001f, --0.0471282f,0.983482f,0.174763f, -0.05509f,0.990469f,0.126237f, -0.154415f,0.97865f,0.135647f, -0.187824f,0.979878f,0.0675348f, -0.226039f,0.971999f,-0.0642243f, -0.0780765f,0.982532f,-0.168921f, -0.109774f,0.985685f,-0.127961f, -0.112009f,0.982676f,-0.147653f, -0.0632751f,0.975786f,-0.209375f, -0.0264674f,0.962968f,-0.268312f, -0.10845f,0.959018f,-0.261771f, -0.0643921f,0.961817f,-0.266009f, -0.166593f,0.964859f,-0.203209f, -0.0747121f,0.973608f,-0.215653f, --0.165051f,0.968419f,-0.186874f, --0.148108f,0.983106f,-0.10755f, --0.179372f,0.979451f,-0.0922022f, --0.237948f,0.970437f,-0.0404116f, --0.2824f,0.959184f,-0.014723f, --0.146028f,0.988959f,-0.0252228f, -0.05616f,0.991975f,-0.113275f, -0.196359f,0.969761f,-0.144935f, -0.181455f,0.976082f,-0.119739f, -0.110973f,0.993178f,-0.035804f, --0.0390828f,0.998775f,0.0303582f, --0.136356f,0.988616f,0.0636122f, --0.0521843f,0.980102f,0.191512f, -0.0572854f,0.981374f,0.183367f, -0.238568f,0.946616f,0.216801f, -0.340107f,0.907515f,0.246464f, -0.312043f,0.926088f,0.212108f, -0.0846085f,0.98223f,0.167527f, --0.163231f,0.986101f,0.0309937f, --0.143013f,0.98971f,-0.00457425f, -0.0291614f,0.993948f,0.105909f, -0.107232f,0.980268f,0.16606f, -0.13514f,0.977368f,0.162754f, -0.171582f,0.963454f,0.205708f, -0.160805f,0.97344f,0.162963f, -0.206565f,0.959827f,0.189905f, -0.203733f,0.939018f,0.277016f, -0.156541f,0.940477f,0.30166f, -0.14264f,0.938158f,0.315457f, -0.0877292f,0.924317f,0.371405f, -0.0427952f,0.921735f,0.385453f, -0.102307f,0.915297f,0.389569f, --0.518725f,0.854828f,-0.0138881f, --0.516652f,0.85588f,0.023226f, --0.490153f,0.869598f,0.0595683f, --0.505693f,0.862598f,-0.0140982f, --0.393758f,0.918824f,-0.0267811f, --0.308114f,0.951253f,-0.0135724f, --0.25353f,0.967309f,0.00592796f, --0.183935f,0.978787f,-0.0902442f, --0.0335384f,0.998587f,-0.0412272f, -0.0888831f,0.995408f,-0.0355216f, -0.275528f,0.951614f,-0.136073f, -0.317879f,0.941106f,-0.115209f, -0.22556f,0.974028f,-0.0197739f, -0.262726f,0.954534f,0.140851f, -0.0383338f,0.998565f,0.0373963f, -0.0108706f,0.999386f,-0.0333096f, -0.0472758f,0.987524f,0.150202f, --0.22401f,0.968166f,0.111686f, --0.221122f,0.974472f,0.0388438f, --0.0303833f,0.999266f,0.0233175f, -0.0911048f,0.995841f,0.000284795f, -0.0750561f,0.987717f,-0.137044f, -0.140099f,0.985231f,-0.098447f, -0.159287f,0.981153f,-0.10939f, -0.301657f,0.953265f,-0.0169985f, -0.140836f,0.988971f,-0.0458453f, -0.074059f,0.996008f,-0.0498236f, -0.0873182f,0.996023f,-0.0176849f, -0.132872f,0.990946f,0.019257f, -0.15553f,0.982355f,-0.103875f, -0.133638f,0.955183f,-0.264135f, -0.0505536f,0.951293f,-0.304114f, -0.0663471f,0.962897f,-0.261588f, -0.0679148f,0.992885f,-0.0978063f, --0.186921f,0.976146f,-0.110452f, --0.16844f,0.980926f,-0.0970201f, --0.17716f,0.9831f,-0.0461376f, --0.252028f,0.967676f,-0.00920485f, --0.25063f,0.967236f,-0.0404965f, --0.0995772f,0.983353f,-0.151991f, -0.0940064f,0.974734f,-0.202626f, -0.146102f,0.962693f,-0.227766f, -0.10874f,0.966405f,-0.232891f, --0.0013416f,0.987029f,-0.160533f, --0.0603915f,0.998129f,0.00954783f, --0.17946f,0.98293f,0.040526f, --0.153066f,0.978461f,0.138509f, -0.00546813f,0.977756f,0.209673f, -0.202775f,0.944505f,0.258443f, -0.334531f,0.904949f,0.262976f, -0.339399f,0.898505f,0.278385f, -0.212792f,0.950144f,0.227917f, --0.0583572f,0.996371f,0.0619671f, --0.218128f,0.975136f,0.0391184f, --0.0703437f,0.983861f,0.16453f, -0.113041f,0.961301f,0.25124f, -0.0979771f,0.959037f,0.265798f, -0.151767f,0.929082f,0.337302f, -0.185905f,0.937423f,0.294409f, -0.169611f,0.955662f,0.240713f, -0.159864f,0.96582f,0.204047f, -0.151538f,0.965571f,0.211446f, -0.11661f,0.954852f,0.273241f, -0.0708035f,0.941966f,0.328158f, --0.00402057f,0.956357f,0.292174f, -0.0123647f,0.956622f,0.291069f, --0.626234f,0.777268f,-0.0607036f, --0.590408f,0.806122f,0.0398278f, --0.512253f,0.84829f,0.134171f, --0.429387f,0.891471f,0.144588f, --0.394702f,0.915407f,0.0789917f, --0.352114f,0.935018f,0.0419128f, --0.269358f,0.962596f,0.0292454f, --0.0709514f,0.996127f,0.0519312f, --0.0485279f,0.996417f,-0.069268f, -0.139101f,0.983953f,-0.111751f, -0.369972f,0.916386f,-0.152833f, -0.200502f,0.96864f,-0.146752f, -0.063154f,0.997971f,0.00814434f, -0.218613f,0.964332f,0.149236f, -0.233367f,0.966768f,0.104401f, -0.00832713f,0.995958f,-0.0894382f, --0.101235f,0.994608f,-0.0224841f, --0.188929f,0.980627f,0.051742f, --0.131276f,0.990999f,0.026226f, -0.0111642f,0.996226f,-0.0860703f, -0.127344f,0.982944f,-0.132683f, -0.133649f,0.978353f,-0.157998f, -0.127047f,0.978674f,-0.161419f, -0.154013f,0.97768f,-0.142902f, -0.207952f,0.974577f,-0.0833996f, -0.130584f,0.99044f,-0.0444555f, -0.0527996f,0.997244f,-0.0521173f, -0.0873033f,0.993919f,-0.0671111f, -0.134372f,0.9813f,-0.137819f, -0.302979f,0.937443f,-0.171475f, -0.235087f,0.922651f,-0.305694f, -0.116878f,0.945593f,-0.303632f, --0.0892912f,0.947762f,-0.306226f, --0.0487728f,0.993685f,-0.101049f, --0.161853f,0.9816f,-0.101314f, --0.226351f,0.97061f,-0.0817454f, --0.270044f,0.962691f,-0.0173905f, --0.294262f,0.954053f,0.0565031f, --0.151555f,0.985239f,0.0795882f, -0.00297078f,0.999916f,-0.0126498f, -0.158118f,0.985077f,-0.067991f, -0.232676f,0.957923f,-0.168067f, -0.184787f,0.953241f,-0.239135f, --0.102652f,0.943763f,-0.314284f, --0.249925f,0.941897f,-0.224429f, --0.230538f,0.969668f,-0.0812203f, --0.256878f,0.964046f,-0.0680376f, --0.0528332f,0.99816f,0.0297627f, -0.16253f,0.979605f,0.118148f, -0.292443f,0.935246f,0.199479f, -0.337448f,0.899957f,0.276054f, -0.288581f,0.911989f,0.291541f, -0.0381605f,0.961598f,0.271797f, --0.217082f,0.942133f,0.25546f, --0.187341f,0.947099f,0.26059f, -0.0122725f,0.939216f,0.343107f, -0.0450967f,0.927047f,0.372224f, -0.0805118f,0.921403f,0.380178f, -0.269621f,0.884781f,0.380089f, -0.278457f,0.920235f,0.275007f, -0.240432f,0.950543f,0.19662f, -0.110916f,0.980787f,0.160482f, -0.0190768f,0.974013f,0.225685f, -0.0421661f,0.96323f,0.26535f, -0.0623149f,0.965243f,0.253816f, -0.0484827f,0.970002f,0.238214f, --0.675447f,0.735679f,-0.050474f, --0.639324f,0.768795f,-0.0148056f, --0.556082f,0.830482f,0.0327513f, --0.42972f,0.893254f,0.132053f, --0.365389f,0.922739f,0.122653f, --0.226979f,0.966229f,0.121993f, --0.221717f,0.973751f,-0.051483f, --0.0779728f,0.987923f,-0.133899f, -0.0930073f,0.979917f,-0.176386f, -0.192144f,0.942491f,-0.27348f, -0.309496f,0.916222f,-0.254459f, -0.155051f,0.977443f,-0.143405f, --0.0554135f,0.989739f,-0.131708f, -0.110672f,0.991805f,-0.0638304f, -0.310319f,0.950296f,0.0252996f, -0.103349f,0.993006f,-0.0570824f, --0.143599f,0.988502f,-0.0473533f, --0.226116f,0.973312f,-0.0391734f, --0.100068f,0.994649f,-0.0257001f, -0.124656f,0.989757f,-0.0695779f, -0.137305f,0.97907f,-0.150231f, -0.12072f,0.989818f,-0.075415f, -0.132256f,0.990827f,-0.0277589f, -0.0994133f,0.991446f,-0.0845708f, -0.16457f,0.984921f,-0.0533595f, -0.161357f,0.986289f,-0.034624f, -0.0776395f,0.993281f,-0.0858198f, -0.196429f,0.972629f,-0.124127f, -0.213597f,0.93634f,-0.278645f, -0.333587f,0.906552f,-0.258619f, -0.264447f,0.928271f,-0.261499f, -0.0224352f,0.968338f,-0.248633f, --0.153007f,0.973949f,-0.167368f, --0.171971f,0.976037f,-0.133332f, --0.164739f,0.982172f,-0.0905542f, --0.256427f,0.965345f,-0.0485236f, --0.266685f,0.961164f,-0.0710119f, --0.315314f,0.936338f,-0.154429f, --0.180509f,0.974939f,-0.130043f, -0.0306802f,0.996715f,-0.0749509f, -0.181216f,0.981966f,-0.0538862f, -0.308423f,0.951239f,-0.0044789f, -0.193412f,0.981099f,-0.00609358f, --0.00883535f,0.999181f,0.039479f, --0.293629f,0.95203f,-0.0861418f, --0.288511f,0.952707f,-0.0954526f, --0.270635f,0.961763f,-0.0420598f, --0.176015f,0.982039f,0.0679556f, -0.0472003f,0.981703f,0.184478f, -0.185293f,0.947852f,0.259313f, -0.26012f,0.901797f,0.345109f, -0.219376f,0.887657f,0.404894f, -0.015248f,0.892187f,0.451408f, --0.212632f,0.887876f,0.407999f, --0.145904f,0.908525f,0.391529f, --0.0226457f,0.932703f,0.359933f, -0.0874951f,0.910834f,0.403393f, -0.125007f,0.935932f,0.329249f, -0.288568f,0.918223f,0.271284f, -0.34457f,0.896771f,0.277619f, -0.261558f,0.928634f,0.263108f, -0.0802026f,0.961218f,0.26387f, -0.0163948f,0.952196f,0.305047f, -0.0566148f,0.964684f,0.257253f, -0.102872f,0.970943f,0.216073f, -0.0353576f,0.994079f,0.102749f, --0.569322f,0.820332f,-0.0541097f, --0.616679f,0.764093f,-0.18939f, --0.605157f,0.764062f,-0.223597f, --0.50856f,0.856476f,-0.0884048f, --0.372491f,0.927008f,0.0436669f, --0.225048f,0.969626f,0.0958063f, --0.0508165f,0.996801f,0.0616925f, -0.0586358f,0.990558f,-0.123919f, -0.126111f,0.966195f,-0.224862f, -0.229194f,0.950926f,-0.207869f, -0.252375f,0.936474f,-0.243564f, -0.0944308f,0.971404f,-0.217846f, --0.0355117f,0.972557f,-0.229939f, -0.0856503f,0.962722f,-0.256575f, -0.220711f,0.941477f,-0.254769f, -0.0934053f,0.989629f,-0.109133f, --0.156897f,0.986627f,-0.0441527f, --0.224564f,0.970579f,-0.0868729f, --0.0948813f,0.992594f,-0.0758608f, -0.168753f,0.983045f,-0.0717275f, -0.110894f,0.991432f,-0.0690319f, --0.0147158f,0.998265f,0.0570193f, -0.10964f,0.979883f,0.16676f, -0.213201f,0.96906f,0.124368f, -0.195873f,0.980015f,-0.0346975f, -0.162476f,0.975738f,-0.146751f, -0.136902f,0.9692f,-0.204718f, -0.244929f,0.933568f,-0.26165f, -0.288988f,0.918188f,-0.270954f, -0.254175f,0.924529f,-0.283974f, -0.243695f,0.954587f,-0.171397f, --0.00175415f,0.99017f,-0.13986f, --0.165264f,0.975245f,-0.146916f, --0.185767f,0.967008f,-0.174319f, --0.191354f,0.972667f,-0.131541f, --0.271241f,0.952999f,-0.134987f, --0.1847f,0.972855f,-0.139424f, --0.209304f,0.957842f,-0.1968f, --0.243194f,0.936f,-0.254482f, --0.0210884f,0.983365f,-0.18041f, -0.0761402f,0.989042f,-0.126486f, -0.185372f,0.981538f,0.047127f, -0.117606f,0.973445f,0.196404f, --0.0453061f,0.954332f,0.295292f, --0.152267f,0.943756f,0.293495f, --0.272105f,0.944288f,0.185149f, --0.341417f,0.929337f,0.140592f, --0.316477f,0.938022f,0.141266f, --0.0291064f,0.965694f,0.258045f, -0.139271f,0.938861f,0.31487f, -0.16066f,0.916793f,0.36562f, -0.163005f,0.879828f,0.446466f, -0.088987f,0.884248f,0.458461f, --0.126118f,0.932849f,0.337472f, --0.101381f,0.953175f,0.284919f, --0.0233764f,0.967738f,0.250872f, -0.0600962f,0.965273f,0.254236f, -0.184472f,0.94915f,0.255117f, -0.293565f,0.911429f,0.288301f, -0.309916f,0.89217f,0.328611f, -0.260108f,0.896879f,0.357704f, -0.0945809f,0.935133f,0.341439f, -0.0335311f,0.964748f,0.261032f, -0.0942492f,0.979731f,0.176762f, -0.167685f,0.967918f,0.187127f, -0.258869f,0.942682f,0.210564f, --0.367443f,0.929937f,-0.0142236f, --0.499723f,0.853143f,-0.149749f, --0.60287f,0.768676f,-0.213739f, --0.628893f,0.759885f,-0.164524f, --0.498958f,0.866588f,-0.00814533f, --0.266358f,0.961387f,0.0691948f, -0.0209306f,0.994406f,0.103533f, -0.18825f,0.979809f,0.0673512f, -0.186929f,0.982347f,-0.00722501f, -0.221871f,0.971137f,-0.0875532f, -0.321849f,0.94224f,-0.0927163f, -0.129468f,0.975377f,-0.178544f, --0.0214597f,0.975387f,-0.219454f, -0.135606f,0.972282f,-0.19047f, -0.166947f,0.968719f,-0.18361f, --0.0604962f,0.993281f,-0.0986602f, --0.147333f,0.985679f,-0.0820398f, --0.177745f,0.972235f,-0.152201f, --0.13389f,0.979994f,-0.147259f, -0.107621f,0.993068f,-0.0472599f, -0.0496354f,0.9956f,0.0794756f, --0.114638f,0.990271f,0.0788811f, -0.0386746f,0.994961f,0.0924988f, -0.257639f,0.951075f,0.170521f, -0.371556f,0.918219f,0.137186f, -0.306734f,0.951256f,-0.0320228f, -0.251981f,0.957147f,-0.142743f, -0.259956f,0.937158f,-0.232721f, -0.273432f,0.938847f,-0.209289f, -0.242378f,0.942977f,-0.228139f, -0.135357f,0.967026f,-0.21573f, --0.0237633f,0.989278f,-0.144096f, --0.131198f,0.984621f,-0.11536f, --0.202181f,0.972555f,-0.115152f, --0.221308f,0.9725f,-0.0725642f, --0.229514f,0.969023f,-0.0912046f, --0.218972f,0.967608f,-0.125639f, --0.212632f,0.976006f,-0.0469096f, --0.218674f,0.974967f,-0.0402565f, --0.122558f,0.989962f,-0.0703905f, -0.0166378f,0.999654f,0.0203946f, --0.0104674f,0.996634f,0.0813074f, --0.0169459f,0.959611f,0.28082f, --0.0960206f,0.935549f,0.339894f, --0.167668f,0.926307f,0.337405f, --0.198261f,0.909687f,0.364915f, --0.193335f,0.935754f,0.294935f, --0.259424f,0.960196f,0.103554f, --0.126539f,0.989254f,0.073239f, -0.0445245f,0.981975f,0.183692f, -0.070195f,0.9396f,0.334999f, -0.116045f,0.901991f,0.415867f, -0.160437f,0.912696f,0.375828f, --0.00552585f,0.963507f,0.267627f, --0.111729f,0.971129f,0.210774f, -0.00935468f,0.964114f,0.265323f, -0.084172f,0.968508f,0.234323f, -0.13752f,0.967988f,0.209968f, -0.208575f,0.947382f,0.242826f, -0.289545f,0.920265f,0.263203f, -0.228797f,0.929214f,0.290195f, -0.185013f,0.916649f,0.354295f, -0.160823f,0.950358f,0.266374f, -0.183734f,0.959776f,0.212302f, -0.0865279f,0.982909f,0.162492f, -0.143782f,0.963199f,0.227098f, --0.40108f,0.898526f,-0.178287f, --0.447805f,0.881163f,-0.15173f, --0.619629f,0.769135f,-0.156501f, --0.663764f,0.743697f,-0.0795752f, --0.534645f,0.83883f,-0.102567f, --0.293541f,0.950588f,-0.101077f, --0.0154638f,0.998684f,-0.048892f, -0.170364f,0.984269f,-0.0468065f, -0.272586f,0.961403f,-0.0374194f, -0.276742f,0.955139f,-0.105472f, -0.3572f,0.929651f,-0.0903144f, -0.185848f,0.967712f,-0.170277f, --0.00167559f,0.978573f,-0.205892f, -0.0698456f,0.971595f,-0.226108f, -0.0821889f,0.985623f,-0.147624f, --0.0376538f,0.998466f,-0.0405822f, --0.0983702f,0.988409f,-0.115634f, --0.140633f,0.987279f,-0.0741791f, --0.185061f,0.981813f,-0.0423742f, --0.0718387f,0.997236f,0.0189748f, -0.00846681f,0.991398f,0.130611f, -0.00870324f,0.999937f,0.00714861f, -0.043927f,0.984772f,-0.168207f, -0.173423f,0.967972f,-0.181535f, -0.363952f,0.925731f,-0.10277f, -0.415083f,0.906279f,-0.0797799f, -0.295656f,0.934439f,-0.198525f, -0.285411f,0.94244f,-0.174208f, -0.286359f,0.952372f,-0.104818f, -0.274f,0.954057f,-0.121243f, -0.125082f,0.985323f,-0.116157f, --0.0728358f,0.994219f,-0.0788892f, --0.183935f,0.981488f,-0.0533801f, --0.254614f,0.966975f,0.0114848f, --0.238556f,0.965368f,0.105624f, --0.207746f,0.971319f,0.115674f, --0.215469f,0.971204f,0.101667f, --0.267107f,0.96138f,0.0663435f, --0.207576f,0.97646f,0.0586408f, --0.117358f,0.991748f,0.0516096f, --0.0500459f,0.994852f,0.0881198f, --0.093813f,0.986665f,0.133006f, --0.152698f,0.969858f,0.18989f, --0.1251f,0.953778f,0.273236f, --0.165614f,0.925222f,0.341373f, --0.185498f,0.929562f,0.3186f, --0.115032f,0.960173f,0.254626f, --0.110794f,0.97049f,0.214181f, --0.10146f,0.992209f,0.072301f, --0.111958f,0.99337f,0.026117f, --0.0975457f,0.980844f,0.168611f, -0.086247f,0.976994f,0.195051f, -0.241113f,0.947591f,0.20961f, -0.0868755f,0.959222f,0.268972f, --0.141994f,0.949853f,0.278599f, --0.0178282f,0.934163f,0.356401f, -0.0726972f,0.940594f,0.331659f, -0.165529f,0.917627f,0.361333f, -0.223743f,0.920886f,0.319231f, -0.302189f,0.900958f,0.311378f, -0.181249f,0.939198f,0.291642f, -0.15269f,0.934294f,0.32215f, -0.181639f,0.932767f,0.311371f, -0.174351f,0.925291f,0.336805f, -0.107261f,0.938861f,0.327163f, -0.0621733f,0.949825f,0.306542f, --0.336425f,0.924181f,-0.180852f, --0.467727f,0.856958f,-0.216458f, --0.602238f,0.781026f,-0.165251f, --0.647361f,0.734151f,-0.204809f, --0.50962f,0.821617f,-0.255407f, --0.329682f,0.908003f,-0.258533f, --0.0514578f,0.97257f,-0.226846f, -0.197411f,0.959315f,-0.201849f, -0.264136f,0.946231f,-0.186758f, -0.271989f,0.947232f,-0.169627f, -0.342182f,0.926412f,-0.157076f, -0.226068f,0.960114f,-0.164544f, -0.0298714f,0.986995f,-0.157954f, -0.0947848f,0.979734f,-0.176458f, -0.0184686f,0.978597f,-0.204958f, --0.115417f,0.979217f,-0.166771f, --0.133289f,0.987752f,-0.0811202f, --0.254272f,0.966705f,0.0287551f, --0.238007f,0.962858f,0.127508f, --0.0805244f,0.989118f,0.123135f, -0.0609568f,0.996652f,0.0544921f, -0.185345f,0.981121f,-0.0552078f, -0.246025f,0.947034f,-0.206392f, -0.188933f,0.898455f,-0.396338f, -0.253355f,0.896162f,-0.364288f, -0.431339f,0.877591f,-0.209237f, -0.33179f,0.90994f,-0.248847f, -0.173449f,0.964884f,-0.197267f, -0.195848f,0.971573f,-0.133f, -0.242458f,0.968164f,-0.0622215f, -0.0872514f,0.995924f,0.0228468f, --0.104392f,0.994289f,0.0221861f, --0.212909f,0.976423f,0.0355982f, --0.329497f,0.936369f,0.121017f, --0.322708f,0.91595f,0.238528f, --0.206447f,0.929806f,0.304697f, --0.167225f,0.947523f,0.272462f, --0.184928f,0.959175f,0.213976f, --0.173343f,0.972643f,0.154651f, --0.113658f,0.986612f,0.116951f, --0.0855668f,0.994338f,0.0630098f, --0.114452f,0.992427f,0.0446133f, --0.159653f,0.986324f,0.0409453f, --0.238644f,0.971105f,-0.00174015f, --0.263001f,0.962569f,0.0655076f, --0.150786f,0.97653f,0.153794f, --0.0789227f,0.973225f,0.21588f, --0.0862836f,0.967962f,0.235807f, -0.0429765f,0.969236f,0.242351f, --0.0440941f,0.992467f,0.114305f, --0.115348f,0.992717f,-0.0347649f, -0.0790257f,0.995351f,-0.0550642f, -0.126473f,0.98592f,0.109395f, --0.0409487f,0.953557f,0.298417f, --0.206016f,0.913735f,0.350208f, --0.0633912f,0.92675f,0.370293f, -0.0785739f,0.913264f,0.399719f, -0.177609f,0.899902f,0.398285f, -0.238034f,0.923241f,0.301604f, -0.255943f,0.926508f,0.27582f, -0.232022f,0.914012f,0.332787f, -0.162081f,0.936068f,0.312259f, -0.177513f,0.926269f,0.332437f, -0.185532f,0.921601f,0.340924f, -0.173632f,0.950356f,0.258214f, -0.111166f,0.980225f,0.163712f, --0.0923042f,0.995727f,-0.00270435f, --0.408896f,0.902709f,-0.133863f, --0.602302f,0.79183f,-0.10118f, --0.624884f,0.765307f,-0.154352f, --0.552184f,0.809036f,-0.201379f, --0.343811f,0.917937f,-0.197956f, --0.0748905f,0.960991f,-0.266248f, -0.134998f,0.958099f,-0.252631f, -0.206547f,0.962195f,-0.177534f, -0.264489f,0.960553f,-0.0859237f, -0.340814f,0.939333f,-0.0387315f, -0.235136f,0.971602f,-0.0264814f, -0.0144037f,0.991275f,-0.131023f, -0.053242f,0.991683f,-0.117173f, -0.0920982f,0.995717f,0.00816044f, --0.164789f,0.980567f,-0.106454f, --0.239234f,0.97035f,-0.0344802f, --0.316227f,0.948287f,0.0274269f, --0.260328f,0.965493f,0.00728909f, --0.00635978f,0.999169f,0.0402508f, -0.152101f,0.988094f,-0.023159f, -0.261272f,0.960304f,-0.0977355f, -0.363311f,0.923635f,-0.122082f, -0.303719f,0.94151f,-0.145994f, -0.209258f,0.960639f,-0.182713f, -0.299827f,0.935978f,-0.184526f, -0.310225f,0.948937f,-0.0572597f, -0.134013f,0.988326f,-0.0724722f, -0.173294f,0.983169f,-0.0578515f, -0.150596f,0.988589f,-0.00352276f, -0.0218728f,0.99535f,0.093809f, --0.090936f,0.980927f,0.171796f, --0.253868f,0.938693f,0.233251f, --0.400767f,0.870372f,0.286074f, --0.392418f,0.877786f,0.274773f, --0.219224f,0.925755f,0.308089f, --0.114269f,0.92983f,0.349798f, --0.147993f,0.921652f,0.358685f, --0.138523f,0.925121f,0.353501f, --0.0290531f,0.945854f,0.32329f, -0.0440242f,0.978167f,0.203106f, --0.0576599f,0.997178f,0.0480716f, --0.156038f,0.987653f,-0.0139414f, --0.143901f,0.989541f,-0.0100722f, --0.293059f,0.951458f,-0.0940478f, --0.298958f,0.953936f,-0.0251005f, --0.203233f,0.972711f,0.111937f, --0.134891f,0.965356f,0.223367f, --0.0182075f,0.958686f,0.283884f, -0.123188f,0.934113f,0.33505f, -0.0872404f,0.983488f,0.15856f, -0.00440122f,0.999845f,-0.0170726f, --0.143813f,0.987727f,0.0609306f, --0.192356f,0.942318f,0.273927f, --0.141157f,0.926207f,0.349593f, --0.0674076f,0.959831f,0.272363f, -0.0730938f,0.959591f,0.27174f, -0.173541f,0.961002f,0.215311f, -0.369237f,0.888798f,0.271483f, -0.277281f,0.944196f,0.177789f, -0.215184f,0.95909f,0.183961f, -0.13088f,0.973624f,0.186887f, -0.130607f,0.953976f,0.269946f, -0.212637f,0.930888f,0.297042f, -0.306976f,0.920481f,0.241829f, -0.280289f,0.947029f,0.156763f, -0.0123331f,0.988431f,0.151171f, --0.297868f,0.952288f,0.0664969f, --0.612229f,0.786332f,-0.0828155f, --0.600387f,0.789438f,-0.127758f, --0.542733f,0.826042f,-0.151972f, --0.320126f,0.93364f,-0.160733f, -0.000589343f,0.981171f,-0.193142f, -0.0980808f,0.971507f,-0.215763f, -0.124748f,0.986178f,-0.109047f, -0.199191f,0.978521f,-0.0531043f, -0.247764f,0.965734f,-0.0772702f, -0.318214f,0.948019f,-0.000766246f, -0.183917f,0.97162f,-0.148756f, --0.0488566f,0.965709f,-0.25499f, --0.0165518f,0.99654f,-0.0814512f, --0.0793375f,0.996823f,-0.00696945f, --0.310737f,0.950344f,-0.0169863f, --0.292329f,0.952706f,0.0830406f, --0.217409f,0.975529f,0.0328f, --0.044323f,0.995765f,-0.0805443f, -0.185778f,0.977354f,-0.101323f, -0.271832f,0.958328f,-0.0878372f, -0.32088f,0.946924f,0.019279f, -0.252443f,0.960909f,0.113697f, -0.290552f,0.947257f,0.135217f, -0.289238f,0.957058f,-0.0195476f, -0.286171f,0.957114f,0.0451517f, -0.220997f,0.975269f,0.00320969f, -0.0994052f,0.991378f,-0.0853655f, -0.0429034f,0.994069f,0.099932f, --0.0709962f,0.952332f,0.296687f, --0.214284f,0.897012f,0.38659f, --0.318505f,0.838002f,0.443066f, --0.352211f,0.849573f,0.392649f, --0.30013f,0.898851f,0.319356f, --0.250783f,0.928599f,0.273517f, --0.200191f,0.919896f,0.337217f, --0.179596f,0.907951f,0.378643f, --0.135043f,0.919145f,0.370049f, -0.0368434f,0.920312f,0.389447f, -0.16581f,0.924682f,0.34274f, -0.0946402f,0.961136f,0.259346f, --0.111217f,0.985094f,0.131228f, --0.13188f,0.98641f,0.0979915f, --0.254562f,0.966634f,0.028585f, --0.324299f,0.94515f,-0.0390035f, --0.293729f,0.954471f,-0.0520494f, --0.247862f,0.966889f,0.0607495f, --0.0794894f,0.980131f,0.181727f, -0.101373f,0.964007f,0.245794f, -0.197084f,0.947574f,0.251517f, -0.177833f,0.964662f,0.194431f, --0.161149f,0.986485f,0.0296539f, --0.316387f,0.94824f,0.02721f, --0.207789f,0.976057f,0.0643106f, --0.00905536f,0.99298f,0.117933f, -0.141544f,0.987983f,0.062088f, -0.189336f,0.98168f,-0.0213574f, -0.273454f,0.960225f,0.0564811f, -0.315806f,0.930776f,0.184181f, -0.235283f,0.955417f,0.17838f, -0.124851f,0.982004f,0.141708f, -0.0792257f,0.989953f,0.117114f, -0.210835f,0.9739f,0.0840678f, -0.31429f,0.942479f,0.113817f, -0.350241f,0.914076f,0.20444f, -0.0694749f,0.983151f,0.169077f, --0.169784f,0.982476f,0.076909f, --0.507716f,0.850133f,-0.139637f, --0.564212f,0.800379f,-0.202629f, --0.514428f,0.829332f,-0.218112f, --0.369417f,0.885582f,-0.28156f, -0.00180169f,0.974596f,-0.223965f, -0.0258344f,0.976386f,-0.214484f, --0.024f,0.996868f,-0.0753534f, -0.239975f,0.969587f,0.0481022f, -0.34797f,0.931588f,-0.105173f, -0.316295f,0.909782f,-0.268803f, -0.250422f,0.912989f,-0.322087f, --0.0369252f,0.950156f,-0.30958f, --0.207502f,0.950188f,-0.232562f, --0.167975f,0.985706f,-0.0129903f, --0.315712f,0.948273f,0.0332206f, --0.386969f,0.921609f,-0.0298463f, --0.12805f,0.991662f,0.0144567f, -0.102711f,0.991948f,-0.0740863f, -0.21217f,0.967879f,-0.134884f, -0.167738f,0.98185f,-0.0885116f, -0.176293f,0.984226f,0.0148055f, -0.233609f,0.968608f,0.0850021f, -0.30166f,0.950058f,0.0799509f, -0.387591f,0.914349f,0.117215f, -0.244561f,0.968825f,0.0395933f, -0.294792f,0.954101f,0.0528114f, -0.0843374f,0.996399f,0.00873819f, --0.221704f,0.963341f,0.151067f, --0.335663f,0.86809f,0.365719f, --0.262618f,0.850841f,0.455085f, --0.222709f,0.867235f,0.445313f, --0.24917f,0.884312f,0.39485f, --0.238336f,0.907466f,0.345978f, --0.270997f,0.917236f,0.291956f, --0.229194f,0.914337f,0.333853f, --0.15897f,0.933059f,0.322692f, --0.100911f,0.956766f,0.272794f, --0.0211523f,0.974532f,0.223248f, -0.201297f,0.933635f,0.29632f, -0.155914f,0.954519f,0.254134f, --0.0218294f,0.971898f,0.234389f, --0.079809f,0.976613f,0.199646f, --0.0874479f,0.990326f,0.10774f, --0.258167f,0.959037f,-0.116608f, --0.306401f,0.945943f,-0.106352f, --0.341562f,0.936596f,-0.0782577f, --0.199458f,0.979359f,-0.0327519f, -0.0464294f,0.997405f,0.0550308f, -0.191208f,0.978076f,0.0825056f, -0.238583f,0.96711f,0.0881811f, --0.0888379f,0.993271f,0.0743033f, --0.264236f,0.955782f,0.129075f, --0.188913f,0.981529f,0.0302016f, --0.0145673f,0.997134f,-0.0742444f, -0.169633f,0.978852f,-0.114338f, -0.20381f,0.976959f,-0.0633407f, -0.175314f,0.984354f,-0.0176521f, -0.240514f,0.967819f,0.0740208f, -0.244396f,0.964775f,0.0973589f, -0.18832f,0.980026f,0.0639107f, -0.156937f,0.987568f,-0.00896143f, -0.262584f,0.963481f,-0.0524761f, -0.165405f,0.986171f,-0.0103631f, -0.180443f,0.960877f,0.210132f, -0.22428f,0.955199f,0.193116f, -0.0674282f,0.994387f,0.0815297f, --0.367623f,0.911009f,-0.186858f, --0.569756f,0.78903f,-0.229805f, --0.492917f,0.847419f,-0.197265f, --0.366141f,0.895981f,-0.251313f, --0.0646011f,0.969824f,-0.235091f, -0.018291f,0.976889f,-0.212961f, --0.170757f,0.95698f,-0.234588f, -0.158661f,0.98264f,-0.0961541f, -0.509439f,0.859861f,-0.0333235f, -0.45757f,0.865797f,-0.202548f, -0.211042f,0.949174f,-0.233516f, --0.116125f,0.987892f,-0.102876f, --0.347298f,0.937329f,-0.028262f, --0.3353f,0.938887f,0.0778782f, --0.281604f,0.948411f,0.145656f, --0.254278f,0.964997f,0.0642133f, --0.124948f,0.985399f,-0.115656f, -0.137997f,0.981596f,-0.132006f, -0.145883f,0.979226f,-0.140833f, -0.128056f,0.990732f,-0.0452937f, -0.135002f,0.989818f,-0.0451192f, -0.250583f,0.968082f,-0.00493589f, -0.249752f,0.966686f,-0.056052f, -0.354812f,0.933896f,0.0441336f, -0.303438f,0.951308f,0.0542095f, -0.224177f,0.96836f,0.10965f, -0.0241424f,0.959753f,0.279804f, --0.360787f,0.871516f,0.332105f, --0.379082f,0.837086f,0.394442f, --0.267154f,0.880877f,0.390749f, --0.209592f,0.899886f,0.382462f, --0.280017f,0.899934f,0.33423f, --0.205094f,0.90311f,0.377265f, --0.215487f,0.908768f,0.35736f, --0.222303f,0.927919f,0.299247f, --0.133955f,0.964793f,0.226343f, --0.0310722f,0.978213f,0.205265f, -0.00222901f,0.986522f,0.163613f, -0.163026f,0.975343f,0.148754f, -0.222032f,0.968535f,0.112436f, --0.0591592f,0.996482f,0.0593585f, --0.0736093f,0.986012f,0.149538f, -0.0883465f,0.986402f,0.138585f, --0.129755f,0.988677f,-0.0753772f, --0.360418f,0.926521f,-0.10797f, --0.325602f,0.942448f,-0.0759939f, --0.212184f,0.970083f,-0.117968f, --0.0173686f,0.99664f,-0.0800487f, -0.199307f,0.979749f,-0.0191744f, -0.207601f,0.977585f,-0.0350739f, --0.111673f,0.993337f,0.0284751f, --0.348081f,0.937445f,0.00599776f, --0.0214784f,0.998661f,0.0470579f, -0.101424f,0.987937f,-0.11702f, -0.14864f,0.985437f,-0.0825872f, -0.115279f,0.993006f,0.0255073f, -0.132171f,0.98902f,0.0661133f, -0.208651f,0.976857f,0.0470664f, -0.263292f,0.96404f,0.0361305f, -0.248825f,0.968171f,0.0270552f, -0.185161f,0.982538f,-0.018271f, -0.217415f,0.97571f,0.0268649f, -0.0197241f,0.992022f,0.124516f, --0.222642f,0.960275f,0.168234f, -0.132211f,0.987109f,0.0902005f, -0.194249f,0.96722f,0.163561f, --0.121192f,0.992517f,0.0149198f, --0.530811f,0.812343f,-0.241533f, --0.504434f,0.808747f,-0.302447f, --0.34313f,0.885425f,-0.313504f, --0.137778f,0.93664f,-0.322061f, -0.0757018f,0.968813f,-0.235947f, --0.132891f,0.938587f,-0.318425f, -0.0404124f,0.947798f,-0.316301f, -0.44786f,0.871235f,-0.200923f, -0.490699f,0.867082f,-0.0859319f, -0.104719f,0.99418f,-0.0252995f, --0.266739f,0.955461f,0.126271f, --0.36926f,0.905342f,0.209771f, --0.330235f,0.922316f,0.200695f, --0.269586f,0.955277f,0.121531f, --0.151874f,0.986716f,0.0576671f, --0.0142621f,0.999832f,-0.0115305f, -0.159425f,0.986955f,-0.0224599f, -0.153623f,0.986882f,-0.0496328f, -0.106278f,0.991325f,-0.0773283f, -0.114508f,0.986134f,-0.120113f, -0.21169f,0.974687f,-0.0719165f, -0.274634f,0.961096f,-0.0295159f, -0.269382f,0.962666f,0.0266079f, -0.255851f,0.94689f,0.19478f, --0.00861224f,0.958716f,0.284234f, --0.164949f,0.853283f,0.494671f, --0.299895f,0.797641f,0.523289f, --0.348319f,0.830543f,0.434595f, --0.252787f,0.902204f,0.349467f, --0.200686f,0.920719f,0.334665f, --0.211731f,0.897332f,0.387253f, --0.253565f,0.89104f,0.376502f, --0.186105f,0.884245f,0.42834f, --0.119153f,0.910802f,0.395274f, --0.0259565f,0.945107f,0.325728f, --0.0365208f,0.969055f,0.244127f, -0.0217438f,0.965814f,0.258322f, -0.21499f,0.950394f,0.224789f, -0.314831f,0.941255f,0.12215f, --0.024099f,0.99913f,-0.0340298f, --0.193558f,0.979871f,-0.0488714f, -0.141024f,0.987427f,0.0714227f, -0.042141f,0.998281f,-0.0407328f, --0.330902f,0.928766f,-0.167024f, --0.316891f,0.928564f,-0.193256f, --0.212611f,0.956496f,-0.199781f, --0.0848317f,0.98296f,-0.163073f, -0.159095f,0.98144f,-0.107074f, -0.142493f,0.988352f,-0.0534431f, --0.0993206f,0.99343f,0.0568515f, --0.282995f,0.956355f,-0.0727984f, --0.0511781f,0.994657f,-0.0896605f, -0.128118f,0.991123f,0.0355009f, -0.0178584f,0.998165f,0.057865f, -0.0308308f,0.995199f,0.0928875f, -0.176093f,0.979878f,0.0939732f, -0.250441f,0.967914f,0.0205173f, -0.266597f,0.963616f,0.0192599f, -0.242746f,0.969766f,0.0250589f, -0.198829f,0.979834f,0.0197961f, -0.092758f,0.995177f,0.031931f, --0.00514037f,0.987257f,0.15905f, --0.197401f,0.976423f,0.0873538f, -0.0947848f,0.990346f,0.101148f, -0.11003f,0.98867f,0.102099f, -0.0979659f,0.987432f,0.124019f, --0.288467f,0.943192f,-0.16485f, --0.465875f,0.798355f,-0.381562f, --0.320527f,0.848593f,-0.420894f, --0.189264f,0.880141f,-0.435352f, --0.0157309f,0.942454f,-0.333965f, --0.0523924f,0.9528f,-0.299042f, -0.0243535f,0.924362f,-0.38074f, -0.347438f,0.877508f,-0.330555f, -0.339023f,0.92439f,-0.174834f, -0.0111821f,0.998297f,0.0572478f, --0.344224f,0.932997f,0.105009f, --0.433099f,0.895278f,0.104414f, --0.282796f,0.937116f,0.204547f, --0.130039f,0.982692f,0.131936f, --0.0814764f,0.996291f,-0.027691f, --0.0200688f,0.997106f,-0.0733289f, -0.118984f,0.992345f,-0.0330638f, -0.199561f,0.979885f,0.00110984f, -0.153394f,0.986654f,-0.0546216f, -0.176634f,0.980572f,-0.0853107f, -0.13548f,0.982889f,-0.124795f, -0.191838f,0.980855f,0.0334985f, -0.104996f,0.978045f,0.180009f, -0.00782433f,0.923816f,0.382758f, --0.0895214f,0.848914f,0.520894f, --0.239967f,0.84054f,0.485703f, --0.280756f,0.842357f,0.460011f, --0.207606f,0.901917f,0.378742f, --0.122486f,0.94404f,0.306245f, --0.244402f,0.93107f,0.270881f, --0.292773f,0.891472f,0.345777f, --0.276286f,0.909624f,0.310243f, --0.213016f,0.932947f,0.290231f, --0.0942691f,0.953854f,0.28509f, --0.0105057f,0.953135f,0.302364f, -0.0307865f,0.936068f,0.35047f, -0.0538732f,0.955717f,0.289315f, -0.209391f,0.949668f,0.232994f, -0.403861f,0.868428f,0.287628f, -0.149382f,0.968969f,0.196936f, --0.176548f,0.984269f,0.00674917f, -0.0687777f,0.996274f,-0.0520396f, -0.147821f,0.988716f,-0.0242998f, --0.223164f,0.968308f,-0.112148f, --0.295488f,0.928787f,-0.2237f, --0.23574f,0.935973f,-0.261496f, --0.100501f,0.963432f,-0.248392f, -0.0576299f,0.973773f,-0.220102f, -0.0436147f,0.999029f,-0.00621142f, --0.153496f,0.982634f,0.104254f, --0.184805f,0.972589f,0.141133f, --0.14696f,0.984535f,0.0953571f, --0.0211774f,0.989717f,0.141466f, -0.0758245f,0.9782f,0.193326f, -0.117048f,0.987762f,0.103083f, -0.217731f,0.97559f,-0.0285914f, -0.270726f,0.959521f,-0.0776314f, -0.230415f,0.971747f,-0.0511441f, -0.234903f,0.971865f,0.0172727f, -0.182122f,0.97948f,0.0863184f, -0.0884364f,0.988499f,0.122674f, --0.00977715f,0.999042f,0.0426606f, --0.0304096f,0.999492f,-0.00954367f, -0.200711f,0.957383f,0.207686f, -0.148405f,0.978101f,0.145929f, -0.14921f,0.978785f,0.140417f, -0.0273685f,0.999287f,0.0260052f, --0.3017f,0.88706f,-0.349431f, --0.32483f,0.824834f,-0.462746f, --0.238736f,0.866733f,-0.437926f, --0.174101f,0.907603f,-0.382029f, --0.0165261f,0.968715f,-0.247625f, -0.078914f,0.949167f,-0.30472f, -0.287731f,0.926482f,-0.242571f, -0.12793f,0.981688f,-0.141147f, --0.134026f,0.990975f,-0.00233563f, --0.342476f,0.939327f,-0.0193419f, --0.427311f,0.903697f,-0.027138f, --0.353742f,0.934457f,-0.0407041f, --0.055135f,0.997815f,0.0363915f, -0.0312575f,0.999385f,0.0158812f, -0.00264454f,0.999634f,-0.0269175f, -0.0835808f,0.996075f,-0.0291308f, -0.150499f,0.987413f,0.0486412f, -0.165157f,0.971811f,0.168246f, -0.215634f,0.960222f,0.177413f, -0.0835282f,0.988765f,0.123967f, --0.00975779f,0.968408f,0.249181f, --0.06977f,0.918125f,0.3901f, --0.139283f,0.878718f,0.456569f, --0.11373f,0.882765f,0.455842f, --0.169944f,0.889011f,0.42518f, --0.209287f,0.894084f,0.395996f, --0.156853f,0.920873f,0.356917f, --0.124966f,0.921391f,0.367997f, --0.29021f,0.888579f,0.355255f, --0.269725f,0.894676f,0.356094f, --0.146199f,0.945073f,0.292342f, --0.175209f,0.971632f,0.15885f, --0.117718f,0.980316f,0.158504f, --0.0825429f,0.966227f,0.244116f, --0.0312586f,0.938703f,0.343308f, -0.145253f,0.922109f,0.358632f, -0.209296f,0.943478f,0.256992f, -0.299421f,0.901575f,0.312265f, -0.248395f,0.88619f,0.39111f, -0.0914055f,0.966416f,0.240179f, -0.127765f,0.989974f,-0.0602251f, -0.140331f,0.988333f,-0.0592086f, --0.14269f,0.987394f,-0.0685058f, --0.196659f,0.96924f,-0.147981f, --0.173702f,0.951221f,-0.254961f, --0.143754f,0.948468f,-0.282389f, --0.0849965f,0.99069f,-0.106347f, --0.164159f,0.984178f,0.0666661f, --0.232036f,0.961292f,0.148586f, --0.256871f,0.951713f,0.168109f, --0.0692891f,0.973705f,0.217018f, -0.083167f,0.991239f,0.102607f, -0.0755656f,0.994003f,-0.07904f, -0.210733f,0.972404f,-0.100116f, -0.30249f,0.937213f,-0.173582f, -0.293071f,0.941554f,-0.166086f, -0.154342f,0.975072f,-0.159414f, -0.102764f,0.994605f,0.0141294f, -0.056079f,0.980415f,0.188792f, -0.109909f,0.955557f,0.273554f, -0.133139f,0.972499f,0.191102f, -0.0554464f,0.995429f,0.0777578f, -0.259868f,0.925249f,0.276374f, -0.196037f,0.949951f,0.243232f, -0.114869f,0.970528f,0.21185f, -0.223665f,0.947755f,0.227452f, -0.0930818f,0.995219f,-0.0295687f, --0.269847f,0.892223f,-0.362106f, --0.284642f,0.866853f,-0.409321f, --0.255009f,0.880625f,-0.399336f, --0.131932f,0.93993f,-0.314842f, -0.0677192f,0.974824f,-0.212442f, -0.187299f,0.973952f,-0.127815f, -0.0529524f,0.998138f,-0.0302806f, --0.109006f,0.993972f,0.0117426f, --0.296161f,0.95278f,-0.067077f, --0.391399f,0.918205f,-0.0608803f, --0.369652f,0.920023f,-0.130056f, --0.175066f,0.983052f,-0.0544101f, -0.0114037f,0.997649f,0.0675687f, --0.0112147f,0.996664f,0.0808418f, -0.0734363f,0.988721f,0.130533f, -0.0224625f,0.993745f,0.109391f, -0.0118323f,0.985875f,0.167063f, -0.164185f,0.947186f,0.275466f, -0.0854603f,0.916044f,0.391867f, --0.130673f,0.906994f,0.400358f, --0.128332f,0.898319f,0.420183f, --0.0833752f,0.911617f,0.402496f, --0.0573327f,0.932174f,0.357442f, --0.17852f,0.926686f,0.330734f, --0.230606f,0.897072f,0.376939f, --0.191094f,0.893503f,0.406369f, --0.142227f,0.886795f,0.439733f, --0.17679f,0.896492f,0.40626f, --0.238548f,0.945234f,0.222772f, --0.0952672f,0.973092f,0.209801f, --0.096256f,0.964628f,0.245412f, --0.179685f,0.951666f,0.249087f, --0.204503f,0.928081f,0.311197f, --0.0772696f,0.924068f,0.374336f, -0.158946f,0.926358f,0.341463f, -0.256333f,0.910209f,0.325291f, -0.24298f,0.91134f,0.332296f, -0.258464f,0.899993f,0.351011f, -0.335956f,0.897826f,0.28468f, -0.32299f,0.94494f,0.0525965f, -0.125001f,0.99187f,-0.0238687f, --0.121525f,0.992278f,-0.0248174f, --0.149564f,0.988264f,-0.0310731f, --0.0664528f,0.99755f,-0.021853f, --0.216702f,0.971886f,-0.0920818f, --0.313688f,0.949511f,-0.0053432f, --0.230579f,0.964148f,0.131349f, --0.200205f,0.977444f,0.06724f, --0.214561f,0.975215f,-0.0540219f, --0.0751922f,0.988525f,-0.131015f, -0.196994f,0.973692f,-0.114533f, -0.277294f,0.941009f,-0.193932f, -0.227557f,0.901482f,-0.368168f, -0.240964f,0.919471f,-0.31066f, -0.212207f,0.970864f,-0.111317f, -0.0629816f,0.997092f,0.0428958f, --0.106678f,0.985091f,0.134967f, --0.0538645f,0.972292f,0.227481f, -0.0800601f,0.969345f,0.232295f, -0.209708f,0.947853f,0.239995f, -0.200719f,0.957631f,0.206531f, -0.262538f,0.945755f,0.191366f, -0.219609f,0.958448f,0.182068f, -0.16942f,0.971857f,0.163679f, -0.226298f,0.968297f,0.105781f, -0.311569f,0.942438f,0.12139f, -0.0252626f,0.999298f,-0.0276703f, --0.250271f,0.93337f,-0.257262f, --0.253906f,0.911858f,-0.322563f, --0.227242f,0.899531f,-0.373102f, --0.0651757f,0.944171f,-0.322945f, -0.0757455f,0.97969f,-0.185662f, --0.00346825f,0.999555f,-0.0296364f, --0.101674f,0.994706f,-0.0148914f, --0.257112f,0.961591f,-0.0961018f, --0.383381f,0.91395f,-0.133094f, --0.376104f,0.917884f,-0.12663f, --0.286338f,0.956389f,-0.0577212f, --0.0969792f,0.993405f,0.061176f, --0.0181638f,0.982944f,0.183006f, -0.0407231f,0.989025f,0.142023f, -0.0858284f,0.987795f,0.129982f, -0.0586048f,0.994197f,0.0902062f, -0.00131743f,0.999561f,0.0296072f, --0.0615813f,0.973472f,0.220363f, --0.103673f,0.946783f,0.304719f, --0.0728984f,0.963065f,0.259214f, --0.0671535f,0.98356f,0.16763f, --0.0415144f,0.986558f,0.158053f, --0.226194f,0.961315f,0.157196f, --0.322442f,0.916637f,0.236235f, --0.20303f,0.923357f,0.32587f, --0.141662f,0.940817f,0.307889f, --0.0764267f,0.960304f,0.268283f, --0.0942789f,0.977491f,0.188741f, --0.142883f,0.973984f,0.175899f, --0.198273f,0.947542f,0.250702f, --0.198314f,0.931193f,0.305861f, --0.212116f,0.938506f,0.272421f, --0.0469422f,0.977819f,0.204126f, -0.196637f,0.969918f,0.1435f, -0.210661f,0.950426f,0.228718f, -0.210629f,0.90739f,0.363701f, -0.274296f,0.882172f,0.382799f, -0.402024f,0.855402f,0.326595f, -0.442462f,0.866019f,0.232889f, -0.128104f,0.97894f,0.158954f, --0.10509f,0.973708f,0.202109f, --0.168744f,0.972176f,0.162479f, --0.102712f,0.980722f,0.166234f, --0.117365f,0.985855f,0.119644f, --0.348177f,0.934585f,-0.0729569f, --0.249993f,0.967414f,-0.040164f, --0.059218f,0.996444f,-0.0599467f, --0.0488698f,0.975685f,-0.21366f, --0.0228314f,0.943327f,-0.331077f, -0.144917f,0.936565f,-0.319132f, -0.332603f,0.901794f,-0.275938f, -0.285592f,0.906866f,-0.309889f, -0.0349917f,0.981145f,-0.190079f, --0.0795345f,0.991829f,0.0997459f, --0.0793233f,0.9451f,0.317009f, --0.0879959f,0.940679f,0.327688f, --0.00912821f,0.970457f,0.241099f, -0.124716f,0.982357f,0.13936f, -0.187981f,0.977561f,0.0950669f, -0.255482f,0.951122f,0.173483f, -0.297001f,0.952441f,0.0681659f, -0.265042f,0.961574f,0.0716068f, -0.186715f,0.981446f,0.0436002f, -0.255349f,0.964505f,0.0672885f, -0.267248f,0.96042f,0.078566f, -0.154901f,0.983709f,0.0912232f, --0.0558054f,0.990723f,-0.123913f, --0.190326f,0.930089f,-0.314182f, --0.171804f,0.925365f,-0.337911f, --0.124574f,0.93618f,-0.328706f, --0.0782933f,0.960403f,-0.267387f, --0.15298f,0.970001f,-0.188931f, --0.0717491f,0.993745f,-0.0855706f, --0.147047f,0.986451f,-0.0727437f, --0.378361f,0.919377f,-0.107652f, --0.386168f,0.917464f,-0.0955771f, --0.364818f,0.925918f,-0.097894f, --0.234461f,0.971639f,0.0307667f, --0.0876095f,0.988677f,0.121826f, -0.151616f,0.984538f,0.0877402f, -0.0730881f,0.996968f,-0.0267174f, -0.0661066f,0.997404f,0.0285557f, -0.00089126f,0.998637f,0.052186f, --0.169004f,0.978667f,0.116824f, --0.169994f,0.972188f,0.161096f, --0.0375438f,0.966292f,0.254695f, -0.0282607f,0.96926f,0.244409f, -0.0134123f,0.993493f,0.113096f, --0.245106f,0.969303f,-0.0193377f, --0.4073f,0.913294f,0.000911808f, --0.297873f,0.952205f,0.0676567f, --0.106293f,0.976869f,0.185552f, --0.0629676f,0.97793f,0.199217f, --0.110366f,0.958688f,0.262177f, --0.181956f,0.936769f,0.298926f, --0.212233f,0.945122f,0.248398f, --0.195256f,0.962306f,0.189318f, --0.105775f,0.982974f,0.150248f, -0.0268617f,0.999457f,0.0191026f, -0.158413f,0.985011f,0.068261f, -0.0517671f,0.977028f,0.206729f, -0.0576574f,0.95413f,0.293788f, -0.234396f,0.901434f,0.363971f, -0.437391f,0.816127f,0.377659f, -0.504071f,0.803908f,0.315666f, -0.133347f,0.946928f,0.292483f, --0.151412f,0.933905f,0.323877f, --0.120106f,0.92207f,0.367915f, --0.00325057f,0.939171f,0.343435f, -0.0348166f,0.983178f,0.179299f, --0.135523f,0.990774f,0.00106677f, --0.269937f,0.929173f,-0.252528f, --0.0598233f,0.968739f,-0.240761f, -0.0705133f,0.981516f,-0.177915f, -0.0411605f,0.966746f,-0.252403f, -0.126252f,0.944488f,-0.30332f, -0.315542f,0.911296f,-0.264523f, -0.160596f,0.976989f,-0.140362f, --0.167382f,0.98071f,0.100946f, --0.298691f,0.934743f,0.192454f, --0.145935f,0.9608f,0.235724f, --0.00307512f,0.970287f,0.241936f, -0.110563f,0.982642f,0.148964f, -0.216043f,0.97432f,0.0634533f, -0.143964f,0.986263f,0.0809867f, -0.0914437f,0.980957f,0.17135f, -0.140934f,0.985084f,-0.0987321f, -0.206841f,0.978337f,0.00859891f, -0.190086f,0.979435f,0.0676362f, -0.201515f,0.978077f,0.0525072f, -0.267937f,0.960786f,0.0714189f, -0.246755f,0.968907f,0.0182169f, -0.214715f,0.971106f,-0.104168f, --0.0180649f,0.956568f,-0.290949f, --0.219959f,0.899081f,-0.378512f, --0.191729f,0.921961f,-0.336494f, --0.106738f,0.947718f,-0.300729f, --0.152636f,0.943663f,-0.293602f, --0.224106f,0.947646f,-0.227472f, --0.228203f,0.973419f,0.019469f, --0.388401f,0.917519f,0.0854554f, --0.336148f,0.939599f,0.0644837f, --0.402605f,0.913568f,-0.0574625f, --0.305232f,0.952235f,-0.00907982f, --0.096739f,0.995183f,-0.0159156f, -0.180076f,0.982792f,0.0411394f, -0.136148f,0.986894f,0.0866302f, -0.0219341f,0.999371f,0.0278606f, --0.0791566f,0.996134f,0.0381004f, --0.239326f,0.960376f,0.142833f, --0.218166f,0.951783f,0.215666f, --0.166214f,0.94168f,0.292596f, -0.0428911f,0.92465f,0.378394f, -0.200943f,0.923885f,0.325667f, --0.0783125f,0.985711f,0.149132f, --0.415101f,0.909654f,-0.0148509f, --0.366356f,0.929766f,0.0363078f, --0.239727f,0.962799f,0.124698f, --0.166496f,0.955565f,0.243259f, --0.200219f,0.921854f,0.331809f, --0.112297f,0.932828f,0.342375f, --0.106223f,0.957221f,0.269154f, --0.127872f,0.96503f,0.228835f, --0.0138049f,0.984551f,0.174552f, -0.0256733f,0.993774f,0.108417f, -0.00728748f,0.973829f,0.227164f, --0.00741294f,0.956693f,0.291004f, -0.0683597f,0.974464f,0.213887f, -0.177941f,0.966015f,0.187489f, -0.424978f,0.876377f,0.226619f, -0.505816f,0.827485f,0.243758f, -0.166361f,0.911198f,0.376885f, --0.17476f,0.913668f,0.366973f, --0.176728f,0.923512f,0.340431f, -0.0722139f,0.943797f,0.322541f, -0.177366f,0.957288f,0.228344f, -0.0913959f,0.986484f,0.136004f, --0.0297265f,0.993047f,-0.113903f, --0.0869422f,0.951911f,-0.293781f, --0.0450316f,0.952406f,-0.301489f, -0.143119f,0.964298f,-0.222813f, -0.165675f,0.921893f,-0.350237f, -0.164354f,0.949667f,-0.266682f, --0.039757f,0.998354f,0.0413462f, --0.291683f,0.947651f,0.12992f, --0.239728f,0.968947f,0.0605947f, --0.107127f,0.994229f,0.00574708f, --0.00468879f,0.997776f,-0.0664969f, -0.179786f,0.983119f,-0.033983f, -0.200209f,0.979349f,-0.0281487f, -0.0601426f,0.997956f,0.0216006f, --0.0759803f,0.997037f,0.0120005f, -0.14599f,0.98347f,-0.107112f, -0.111543f,0.987674f,-0.109808f, -0.157618f,0.987042f,-0.0300797f, -0.250909f,0.967637f,-0.026879f, -0.281043f,0.956928f,-0.0728269f, -0.296885f,0.954758f,-0.0172396f, -0.276747f,0.960894f,-0.00969537f, -0.102049f,0.992961f,-0.0601211f, --0.130111f,0.972079f,-0.195279f, --0.17254f,0.923261f,-0.343248f, --0.125309f,0.912244f,-0.390012f, --0.211743f,0.924189f,-0.317868f, --0.376287f,0.901788f,-0.212569f, --0.427638f,0.901509f,-0.0663888f, --0.389415f,0.920624f,0.0283935f, --0.297925f,0.953877f,0.0368632f, --0.273734f,0.961504f,0.0240644f, --0.334113f,0.936286f,-0.108341f, --0.109536f,0.993721f,-0.0228029f, -0.0288145f,0.999546f,0.00876748f, -0.119784f,0.984043f,0.131571f, -0.0511538f,0.994284f,0.0937163f, --0.0752276f,0.983313f,0.165639f, --0.293078f,0.946365f,0.136011f, --0.332793f,0.935954f,0.115063f, --0.225106f,0.941939f,0.249154f, -0.0114661f,0.958888f,0.283552f, -0.24485f,0.921506f,0.301455f, -0.100987f,0.953885f,0.282675f, --0.340266f,0.932035f,0.124616f, --0.415762f,0.898895f,0.138312f, --0.325966f,0.925955f,0.190664f, --0.250966f,0.918836f,0.304559f, --0.221816f,0.898675f,0.378392f, --0.0852583f,0.899614f,0.428282f, --0.0998073f,0.904564f,0.41449f, --0.102816f,0.885513f,0.453096f, -0.0414724f,0.91382f,0.403996f, --0.0128006f,0.939036f,0.343581f, --0.0641104f,0.924175f,0.376551f, -0.0655361f,0.926269f,0.37112f, -0.187467f,0.942186f,0.277743f, -0.21985f,0.965692f,0.138218f, -0.3812f,0.921864f,0.0696633f, -0.433954f,0.878909f,0.197998f, -0.0643484f,0.944154f,0.32316f, --0.162002f,0.923385f,0.348016f, --0.0466746f,0.93461f,0.352597f, -0.113297f,0.96975f,0.216212f, -0.268791f,0.938715f,0.215791f, -0.199257f,0.972974f,0.116695f, -0.13591f,0.990721f,-0.000598755f, -0.098836f,0.989317f,-0.107165f, -0.00840194f,0.94937f,-0.314049f, -0.0977197f,0.93606f,-0.337997f, -0.228369f,0.952655f,-0.20074f, --0.102319f,0.98537f,-0.136295f, --0.210478f,0.975126f,0.0694824f, --0.226245f,0.97389f,-0.0187694f, --0.184535f,0.981701f,-0.0470082f, --0.0356904f,0.995184f,-0.0912977f, -0.0448449f,0.980059f,-0.193583f, -0.0871766f,0.981936f,-0.167935f, -0.149691f,0.986438f,-0.0673319f, -0.081336f,0.996451f,-0.021693f, -0.0320348f,0.999323f,-0.0181162f, -0.0913657f,0.979354f,-0.180329f, -0.100696f,0.986931f,-0.125808f, -0.108832f,0.988438f,-0.105573f, -0.287509f,0.953f,-0.0955498f, -0.243655f,0.954139f,-0.173927f, -0.160509f,0.983073f,-0.0883436f, -0.264497f,0.963724f,0.0357424f, -0.162998f,0.986545f,0.0127154f, -0.0143391f,0.999851f,0.00965394f, --0.0125406f,0.999093f,-0.0406807f, --0.106874f,0.984584f,-0.138462f, --0.285824f,0.938351f,-0.194429f, --0.419998f,0.877928f,-0.22988f, --0.451562f,0.860313f,-0.236545f, --0.434075f,0.875052f,-0.214154f, --0.338822f,0.927615f,-0.157258f, --0.245036f,0.962096f,-0.119701f, --0.344114f,0.932339f,-0.111035f, --0.226404f,0.972006f,0.0628119f, -0.0419787f,0.991974f,0.119273f, -0.128473f,0.991295f,0.0288037f, --0.0257017f,0.999564f,0.0145347f, --0.185301f,0.952066f,0.243378f, --0.184541f,0.936895f,0.29694f, --0.273419f,0.950852f,0.145334f, --0.319783f,0.945196f,0.0659039f, --0.035432f,0.98966f,0.138987f, -0.220222f,0.955124f,0.19809f, -0.125192f,0.96286f,0.239224f, --0.256002f,0.939458f,0.227776f, --0.448892f,0.878586f,0.163043f, --0.385115f,0.893165f,0.232256f, --0.361248f,0.871706f,0.331103f, --0.291851f,0.846516f,0.445235f, --0.17348f,0.85884f,0.481973f, --0.107775f,0.841326f,0.529675f, --0.0921307f,0.850827f,0.517306f, -0.0950699f,0.836893f,0.539048f, -0.0822562f,0.850572f,0.519385f, -0.00749303f,0.916802f,0.399272f, -0.0761143f,0.966912f,0.243491f, -0.269493f,0.937399f,0.220582f, -0.37073f,0.916186f,0.152194f, -0.358083f,0.929944f,0.083549f, -0.335187f,0.907961f,0.251509f, -0.0578141f,0.947361f,0.314904f, --0.166707f,0.957873f,0.233855f, --0.0184246f,0.983369f,0.180682f, -0.167068f,0.976917f,0.13312f, -0.286534f,0.942354f,0.172822f, -0.301062f,0.945554f,0.123648f, -0.228175f,0.972518f,0.0463188f, -0.216797f,0.97484f,-0.0518194f, -0.199106f,0.962895f,-0.18218f, -0.00394531f,0.962307f,-0.271937f, --0.0105699f,0.99745f,-0.0705888f, --0.131705f,0.985651f,0.105578f, --0.19725f,0.980353f,0.00065076f, --0.141436f,0.988723f,-0.0492296f, --0.163841f,0.979948f,-0.113394f, -0.0189882f,0.981225f,-0.191928f, -0.0882705f,0.978772f,-0.18497f, -0.0393937f,0.981447f,-0.187645f, -0.0729287f,0.986122f,-0.149146f, -0.0148824f,0.998969f,-0.0428982f, --0.0177962f,0.999449f,0.0279995f, --0.0162323f,0.963189f,-0.268333f, -0.00641467f,0.976357f,-0.216067f, -0.107749f,0.98057f,-0.16393f, -0.293413f,0.939289f,-0.177892f, -0.308304f,0.934826f,-0.17621f, -0.101903f,0.952869f,-0.285755f, -0.182917f,0.946528f,-0.265755f, -0.146405f,0.977668f,-0.15077f, --0.0629734f,0.995858f,-0.0655825f, --0.0448201f,0.998977f,-0.00597126f, --0.0400505f,0.999191f,-0.00375744f, --0.153158f,0.98627f,-0.0617534f, --0.285484f,0.92871f,-0.236637f, --0.448842f,0.826713f,-0.339243f, --0.479202f,0.840256f,-0.253646f, --0.347296f,0.912974f,-0.214157f, --0.288381f,0.931416f,-0.222037f, --0.393139f,0.905395f,-0.160316f, --0.362299f,0.919254f,-0.153982f, -0.042344f,0.998556f,-0.0330675f, -0.205011f,0.978411f,0.0261187f, --0.127573f,0.99058f,0.0497635f, --0.371574f,0.908811f,0.189723f, --0.216831f,0.928294f,0.302084f, --0.0703165f,0.93644f,0.343708f, --0.232099f,0.969924f,0.0733245f, --0.112472f,0.99344f,-0.0206566f, -0.137846f,0.985164f,0.102232f, -0.0558694f,0.966778f,0.249437f, --0.236804f,0.911959f,0.335045f, --0.429918f,0.856338f,0.286105f, --0.441526f,0.844766f,0.302366f, --0.455345f,0.82665f,0.330622f, --0.361376f,0.843549f,0.397281f, --0.152799f,0.875871f,0.457714f, --0.118894f,0.891156f,0.437842f, --0.0896442f,0.897342f,0.432135f, -0.0157836f,0.897193f,0.441356f, -0.112602f,0.854856f,0.5065f, -0.219938f,0.859901f,0.460648f, -0.288065f,0.92641f,0.242451f, -0.293811f,0.955367f,0.0308066f, -0.390529f,0.919592f,0.0428713f, -0.271277f,0.959279f,0.0786938f, -0.217133f,0.949907f,0.22479f, -0.0884504f,0.963513f,0.252624f, --0.0236259f,0.986232f,0.163669f, -0.0800779f,0.996646f,0.0168362f, -0.165418f,0.984838f,-0.0522657f, -0.249596f,0.968284f,-0.0113122f, -0.338274f,0.940962f,-0.0126639f, -0.305431f,0.950632f,-0.0548703f, -0.294152f,0.946987f,-0.12919f, -0.225417f,0.970184f,-0.0890507f, --0.00713906f,0.99978f,0.0197001f, --0.176932f,0.984214f,-0.00420403f, --0.111846f,0.993652f,0.0120569f, --0.1391f,0.984895f,-0.103119f, --0.088794f,0.987668f,-0.128949f, --0.0465185f,0.96883f,-0.243321f, -0.0250763f,0.955082f,-0.295277f, -0.0363238f,0.977208f,-0.209152f, -0.0515148f,0.981849f,-0.182534f, --0.0181f,0.986039f,-0.165529f, --0.1292f,0.991547f,-0.0118974f, --0.123925f,0.986172f,0.110035f, -0.0445182f,0.949745f,-0.309843f, --0.00147152f,0.93224f,-0.361838f, -0.114309f,0.919114f,-0.377045f, -0.249456f,0.882365f,-0.399004f, -0.318339f,0.895336f,-0.311503f, -0.245085f,0.904168f,-0.349877f, -0.0939131f,0.907167f,-0.410156f, --0.0302879f,0.963667f,-0.265383f, --0.13844f,0.974516f,-0.176503f, --0.0411687f,0.989896f,-0.135687f, --0.00628724f,0.990542f,-0.137063f, --0.112489f,0.976976f,-0.181283f, --0.1315f,0.967086f,-0.217836f, --0.376506f,0.872387f,-0.311743f, --0.531305f,0.793042f,-0.297992f, --0.39351f,0.883689f,-0.253462f, --0.336847f,0.927504f,-0.162083f, --0.393317f,0.917094f,-0.0651222f, --0.321501f,0.93797f,-0.129808f, --0.135804f,0.972419f,-0.189625f, -0.0526632f,0.998612f,0.00112608f, --0.194024f,0.972777f,0.126724f, --0.436845f,0.883669f,0.168215f, --0.311688f,0.924669f,0.218719f, --0.0696464f,0.953993f,0.291628f, -0.0409792f,0.956788f,0.287884f, --0.0764775f,0.990645f,0.113025f, --0.0364568f,0.989186f,0.142066f, --0.121833f,0.946798f,0.297877f, --0.315082f,0.850341f,0.421476f, --0.377714f,0.797842f,0.469873f, --0.420842f,0.786479f,0.452043f, --0.397492f,0.78965f,0.467389f, --0.380055f,0.83336f,0.401334f, --0.183142f,0.896787f,0.402781f, --0.0888282f,0.916137f,0.3909f, --0.0940934f,0.935116f,0.34162f, -0.00386799f,0.937503f,0.347956f, -0.10018f,0.944394f,0.313183f, -0.280679f,0.93056f,0.235113f, -0.465087f,0.85876f,0.215002f, -0.41466f,0.904302f,0.101461f, -0.364139f,0.929581f,0.0572809f, -0.242065f,0.968602f,0.0566915f, -0.117842f,0.992149f,0.0418746f, -0.148716f,0.982681f,0.110551f, -0.0959266f,0.995185f,0.0201233f, -0.176327f,0.980433f,-0.0875236f, -0.210189f,0.965141f,-0.155959f, -0.226725f,0.946611f,-0.229181f, -0.330781f,0.920607f,-0.207526f, -0.365923f,0.916599f,-0.161081f, -0.298516f,0.923753f,-0.239936f, -0.0221976f,0.976238f,-0.215559f, --0.104515f,0.994469f,-0.0104162f, --0.0427336f,0.998984f,-0.0143091f, --0.0839971f,0.989572f,-0.117013f, --0.00725244f,0.993108f,-0.116977f, --0.0399839f,0.966361f,-0.254064f, -0.00504893f,0.980798f,-0.194961f, --0.018473f,0.987693f,-0.155309f, --0.0253738f,0.987423f,-0.15605f, -0.000452807f,0.989468f,-0.144748f, --0.0811148f,0.995994f,-0.0376225f, --0.286969f,0.957515f,0.0285449f, --0.27524f,0.951495f,0.137481f, -0.163018f,0.971572f,-0.171676f, -0.122581f,0.955248f,-0.269212f, -0.130974f,0.917919f,-0.374527f, -0.258812f,0.917892f,-0.300816f, -0.268244f,0.908354f,-0.320839f, -0.223034f,0.911459f,-0.345686f, -0.0389184f,0.957275f,-0.28655f, --0.140597f,0.964524f,-0.223439f, --0.145862f,0.970122f,-0.193875f, --0.104111f,0.974098f,-0.200733f, --0.0208986f,0.992723f,-0.118595f, --0.0701237f,0.994147f,-0.08218f, --0.122604f,0.99062f,-0.0603304f, --0.259222f,0.963912f,-0.0606481f, --0.533518f,0.797325f,-0.282189f, --0.48726f,0.821939f,-0.294948f, --0.445665f,0.877532f,-0.176975f, --0.446224f,0.888631f,-0.105925f, --0.296073f,0.952805f,-0.0671049f, --0.124475f,0.991773f,-0.0298685f, --0.112069f,0.99368f,-0.00632266f, --0.24484f,0.957295f,0.15375f, --0.472578f,0.869701f,0.142444f, --0.348902f,0.914252f,0.205937f, --0.110311f,0.945787f,0.30548f, --0.00134709f,0.941519f,0.336957f, -0.0293716f,0.928574f,0.369983f, --0.116225f,0.946895f,0.299803f, --0.223618f,0.889099f,0.399372f, --0.413824f,0.817577f,0.400396f, --0.452277f,0.775981f,0.439658f, --0.398113f,0.749968f,0.528257f, --0.374899f,0.784234f,0.494397f, --0.25264f,0.860337f,0.442712f, --0.127446f,0.920564f,0.369215f, --0.018556f,0.935495f,0.352851f, --0.0323754f,0.965116f,0.259814f, -0.0357851f,0.98547f,0.166039f, -0.195904f,0.976812f,0.0863732f, -0.361612f,0.932271f,0.0103395f, -0.440593f,0.897705f,0.00204446f, -0.433278f,0.895277f,0.103679f, -0.385805f,0.912456f,0.136304f, -0.326244f,0.9426f,0.0712044f, -0.139247f,0.987833f,-0.0692571f, -0.107504f,0.992792f,-0.0529845f, -0.186477f,0.981836f,-0.0349818f, -0.2261f,0.969793f,-0.0915407f, -0.319918f,0.94368f,-0.0843796f, -0.284455f,0.935881f,-0.207877f, -0.26738f,0.950319f,-0.159379f, -0.326413f,0.941309f,-0.085975f, -0.340028f,0.93811f,-0.0657985f, -0.0548427f,0.991972f,-0.113944f, --0.195067f,0.950504f,-0.241849f, --0.0282147f,0.982936f,-0.181769f, --0.0838232f,0.97875f,-0.187144f, -0.0287357f,0.988886f,-0.145871f, -0.0192345f,0.984318f,-0.175351f, --0.131262f,0.971109f,-0.199292f, --0.0357158f,0.988874f,-0.144408f, -0.0171216f,0.989641f,-0.142542f, --0.0610371f,0.990627f,-0.122202f, --0.174272f,0.984646f,-0.0100664f, --0.321779f,0.946758f,0.0104107f, --0.391721f,0.920071f,-0.0049163f, -0.251962f,0.967049f,0.0364793f, -0.286588f,0.95799f,-0.0110494f, -0.190653f,0.96361f,-0.187371f, -0.192921f,0.95146f,-0.239803f, -0.313234f,0.932132f,-0.181696f, -0.220402f,0.968379f,-0.116899f, -0.0241557f,0.995754f,-0.0888337f, --0.173138f,0.969731f,-0.172177f, --0.148056f,0.974915f,-0.166191f, --0.121802f,0.976444f,-0.178104f, --0.134617f,0.985638f,-0.10196f, --0.12881f,0.990748f,0.0427476f, --0.193234f,0.979772f,0.0520324f, --0.169584f,0.981577f,0.0880205f, --0.37404f,0.925821f,-0.0543154f, --0.520547f,0.83989f,-0.153672f, --0.499517f,0.851003f,-0.162103f, --0.4353f,0.881523f,-0.182841f, --0.371568f,0.902946f,-0.21593f, --0.165948f,0.980792f,-0.10251f, --0.208618f,0.975931f,-0.0635357f, --0.355123f,0.932394f,0.0673039f, --0.461506f,0.884901f,0.0629418f, --0.443442f,0.893747f,0.0676439f, --0.18907f,0.971969f,0.139742f, --0.0546977f,0.978989f,0.19644f, -0.0244551f,0.950588f,0.309492f, --0.115369f,0.932748f,0.341572f, --0.31704f,0.862788f,0.393805f, --0.382907f,0.826411f,0.412829f, --0.514077f,0.784716f,0.346333f, --0.482563f,0.790781f,0.37656f, --0.301253f,0.838125f,0.454745f, --0.149029f,0.885064f,0.440966f, --0.0699981f,0.93986f,0.33431f, -0.00541731f,0.96209f,0.272677f, -0.0875381f,0.972016f,0.217994f, -0.185287f,0.977612f,0.0997159f, -0.257792f,0.964794f,-0.0521163f, -0.377486f,0.923846f,-0.0633437f, -0.414459f,0.907288f,-0.071082f, -0.347034f,0.936287f,-0.0541691f, -0.366281f,0.930406f,0.0134975f, -0.42839f,0.903092f,0.0301138f, -0.236883f,0.966501f,-0.0988031f, -0.0750179f,0.986987f,-0.142226f, -0.187793f,0.976018f,-0.110108f, -0.233114f,0.960011f,-0.155038f, -0.295131f,0.944107f,-0.146833f, -0.293935f,0.952937f,-0.0742579f, -0.206131f,0.978459f,-0.0112805f, -0.26541f,0.963541f,0.0338617f, -0.315062f,0.940538f,0.126983f, -0.200639f,0.96888f,0.144968f, --0.0482349f,0.996749f,-0.0645292f, --0.0829471f,0.973987f,-0.210875f, --0.0395681f,0.974449f,-0.221097f, --0.0327152f,0.953444f,-0.299791f, -0.0198675f,0.970814f,-0.23901f, --0.0300308f,0.967142f,-0.252456f, --0.0212823f,0.929856f,-0.367308f, --0.0806959f,0.938686f,-0.335198f, --0.165388f,0.976093f,-0.141032f, --0.248602f,0.968455f,-0.0171025f, --0.306518f,0.951371f,0.0306604f, --0.345042f,0.93733f,0.04856f, -0.223548f,0.968386f,-0.110699f, -0.301936f,0.947319f,-0.106873f, -0.333496f,0.936283f,-0.110248f, -0.267715f,0.952143f,-0.147486f, -0.160925f,0.980864f,-0.109589f, -0.106924f,0.990465f,0.086874f, -0.0634847f,0.989163f,0.132389f, --0.00868593f,0.99995f,-0.00503069f, --0.137697f,0.961899f,-0.236198f, --0.140914f,0.964191f,-0.224676f, --0.263955f,0.951239f,-0.159597f, --0.23775f,0.971227f,-0.0138849f, --0.148246f,0.985689f,0.0802536f, --0.176705f,0.981995f,0.0667941f, --0.283636f,0.956796f,0.0639697f, --0.481368f,0.872896f,-0.0796102f, --0.48359f,0.86775f,-0.114673f, --0.410361f,0.90546f,-0.10838f, --0.368916f,0.919839f,-0.133408f, --0.290849f,0.948818f,-0.123086f, --0.265473f,0.964116f,-0.001833f, --0.375668f,0.926391f,0.025952f, --0.457607f,0.88747f,-0.0547004f, --0.428989f,0.902388f,-0.0407983f, --0.246051f,0.968578f,-0.0362744f, --0.121016f,0.990282f,0.0685327f, --0.158606f,0.977484f,0.139173f, --0.181659f,0.932387f,0.312498f, --0.374645f,0.868516f,0.324533f, --0.427131f,0.84162f,0.330508f, --0.473189f,0.797198f,0.374923f, --0.486417f,0.800363f,0.350452f, --0.401778f,0.85438f,0.329557f, --0.142919f,0.913903f,0.379941f, -0.0660554f,0.918312f,0.390308f, -0.107243f,0.947465f,0.301346f, -0.120927f,0.966132f,0.227959f, -0.280478f,0.92581f,0.253394f, -0.365712f,0.921405f,0.131406f, -0.413772f,0.910147f,-0.0206163f, -0.410674f,0.90493f,-0.111572f, -0.355567f,0.932765f,-0.0593443f, -0.345425f,0.933621f,-0.0950402f, -0.397628f,0.912297f,-0.0980078f, -0.290063f,0.956994f,0.00506036f, -0.106586f,0.994174f,-0.016042f, -0.184529f,0.978373f,-0.093465f, -0.32595f,0.937225f,-0.12396f, -0.234333f,0.947332f,-0.218287f, -0.205568f,0.971289f,-0.119751f, -0.183661f,0.977533f,-0.103434f, -0.18646f,0.974485f,-0.124944f, -0.228632f,0.97345f,-0.0111031f, -0.2372f,0.970015f,0.0529807f, -0.150741f,0.988413f,-0.0177775f, -0.0529111f,0.986113f,-0.15742f, -0.0129012f,0.976239f,-0.216311f, -0.0638914f,0.966774f,-0.247521f, --0.013106f,0.949224f,-0.314329f, -0.00301657f,0.947335f,-0.320229f, -0.0158116f,0.945699f,-0.32466f, --0.206362f,0.955554f,-0.21055f, --0.363868f,0.929813f,-0.0551994f, --0.322459f,0.943841f,0.0720059f, --0.369143f,0.923823f,0.101411f, --0.383217f,0.903675f,0.191093f, -0.316947f,0.930379f,-0.184227f, -0.292606f,0.932053f,-0.213681f, -0.281637f,0.95325f,-0.109518f, -0.181192f,0.981727f,-0.0581435f, -0.0846872f,0.996407f,0.000962506f, --0.00109762f,0.999999f,0.000234158f, -0.0777708f,0.996176f,0.0398008f, -0.205791f,0.978243f,0.0262708f, -0.0568816f,0.985436f,-0.160253f, --0.183235f,0.956309f,-0.227811f, --0.306851f,0.928821f,-0.207686f, --0.348537f,0.918038f,-0.189017f, --0.243342f,0.965099f,-0.0967916f, --0.232072f,0.972378f,-0.0249578f, --0.190489f,0.981246f,0.0294989f, --0.361119f,0.921084f,-0.145596f, --0.509056f,0.842731f,-0.175118f, --0.463553f,0.883903f,-0.0619248f, --0.339892f,0.940435f,0.00741701f, --0.334839f,0.939566f,-0.0714062f, --0.350156f,0.936419f,-0.0225887f, --0.347741f,0.937357f,0.020947f, --0.370099f,0.928938f,-0.0100614f, --0.438593f,0.892875f,-0.102033f, --0.372504f,0.925425f,-0.0694955f, --0.205666f,0.969919f,0.130228f, --0.228734f,0.96522f,0.126612f, --0.319826f,0.92691f,0.196338f, --0.371568f,0.883063f,0.286595f, --0.42486f,0.867995f,0.257059f, --0.575514f,0.802019f,0.159839f, --0.477155f,0.843037f,0.248216f, --0.322215f,0.91617f,0.238347f, --0.15776f,0.967147f,0.199344f, -0.0563134f,0.972277f,0.226949f, -0.189774f,0.959109f,0.209989f, -0.114773f,0.983426f,0.140357f, -0.195319f,0.960799f,0.196765f, -0.466014f,0.846607f,0.257076f, -0.551779f,0.823036f,0.13473f, -0.451922f,0.891695f,-0.0254353f, -0.295217f,0.951228f,-0.0895088f, -0.39575f,0.916754f,-0.0542532f, -0.335629f,0.937827f,-0.0885088f, -0.163272f,0.984979f,0.0561951f, -0.175225f,0.975709f,0.131485f, -0.276736f,0.960943f,0.00255915f, -0.374077f,0.92611f,-0.0488528f, -0.257806f,0.961501f,-0.0951409f, -0.210674f,0.973483f,-0.0891523f, -0.210996f,0.9611f,-0.178234f, -0.230566f,0.953272f,-0.195223f, -0.113631f,0.949966f,-0.290949f, -0.210906f,0.960561f,-0.181223f, -0.197018f,0.968285f,-0.153646f, -0.117662f,0.979392f,-0.164157f, -0.00452083f,0.974487f,-0.224398f, -0.0685234f,0.976453f,-0.20456f, -0.0486196f,0.979817f,-0.193895f, --0.041249f,0.985341f,-0.165533f, --0.0536621f,0.998462f,0.0138937f, --0.34438f,0.936413f,0.0673216f, --0.441342f,0.892502f,0.0930463f, --0.35428f,0.929013f,0.106864f, --0.394607f,0.91136f,0.117083f, --0.495153f,0.861045f,0.115868f, -0.317163f,0.930357f,-0.183965f, -0.258032f,0.948579f,-0.183348f, -0.18786f,0.965135f,-0.182274f, -0.168177f,0.970722f,-0.171508f, -0.130487f,0.977884f,-0.163448f, -0.0391868f,0.976408f,-0.212349f, -0.0535243f,0.973465f,-0.222489f, -0.187797f,0.962281f,-0.196843f, -0.12136f,0.981658f,-0.147035f, --0.157459f,0.973185f,-0.167681f, --0.281843f,0.941023f,-0.18719f, --0.339259f,0.910185f,-0.237625f, --0.312535f,0.920718f,-0.233666f, --0.266508f,0.952365f,-0.148237f, --0.190534f,0.974186f,-0.121073f, --0.276015f,0.959165f,-0.0617859f, --0.523368f,0.852103f,0.00254573f, --0.538f,0.84284f,-0.0133122f, --0.352764f,0.935613f,-0.0136594f, --0.269435f,0.962844f,-0.0183539f, --0.350798f,0.93502f,-0.0517468f, --0.373067f,0.922044f,-0.103225f, --0.354323f,0.929911f,-0.0985928f, --0.409705f,0.907488f,-0.0927797f, --0.42852f,0.900791f,-0.070324f, --0.329659f,0.944032f,-0.0113329f, --0.243515f,0.962301f,0.121152f, --0.341781f,0.918017f,0.201073f, --0.462572f,0.875527f,0.139571f, --0.350168f,0.914262f,0.203733f, --0.49611f,0.864935f,0.0759072f, --0.527565f,0.849514f,0.000485091f, --0.337106f,0.940759f,0.0364912f, --0.159402f,0.986691f,0.0321325f, -0.0661572f,0.997809f,-0.000201698f, -0.185343f,0.982618f,-0.0104608f, -0.145499f,0.981994f,0.120491f, -0.134704f,0.982549f,0.128264f, -0.406275f,0.89759f,0.17109f, -0.586902f,0.779785f,0.217901f, -0.565709f,0.807524f,0.166967f, -0.384632f,0.92307f,-3.36604e-005f, -0.35623f,0.932256f,-0.0632309f, -0.323525f,0.94617f,0.00968274f, -0.0775419f,0.995759f,-0.0495083f, -0.170196f,0.984289f,-0.0470022f, -0.351353f,0.935822f,-0.0280704f, -0.38341f,0.923157f,-0.0278874f, -0.285688f,0.957776f,-0.0323514f, -0.254076f,0.961785f,-0.102057f, -0.271137f,0.936424f,-0.222698f, -0.261266f,0.933845f,-0.24428f, -0.199017f,0.946563f,-0.253793f, -0.0763778f,0.960008f,-0.269355f, -0.131471f,0.985485f,-0.107402f, -0.160318f,0.984539f,-0.0705758f, -0.0961684f,0.977977f,-0.185235f, -0.0245162f,0.963631f,-0.26611f, --0.0125968f,0.989853f,-0.141538f, --0.234149f,0.972198f,0.00219358f, --0.224015f,0.949544f,0.219506f, --0.294091f,0.928539f,0.226551f, --0.388903f,0.912184f,0.129128f, --0.352208f,0.9324f,0.0811158f, --0.3962f,0.915032f,0.0757807f, --0.491066f,0.869445f,0.0540404f, -0.157697f,0.961233f,-0.226193f, -0.272083f,0.946677f,-0.172551f, -0.25297f,0.931319f,-0.262015f, -0.179666f,0.941632f,-0.284691f, -0.0998509f,0.952676f,-0.287122f, -0.0337305f,0.95661f,-0.289412f, -0.0669213f,0.956372f,-0.284383f, -0.111493f,0.948222f,-0.297395f, -0.109434f,0.973643f,-0.200107f, --0.146896f,0.95648f,-0.252126f, --0.266533f,0.937028f,-0.225695f, --0.287184f,0.932451f,-0.219226f, --0.333493f,0.906758f,-0.258015f, --0.32756f,0.915563f,-0.233343f, --0.294553f,0.94475f,-0.143827f, --0.391872f,0.91893f,0.0447686f, --0.558682f,0.823628f,0.0975275f, --0.441987f,0.895769f,0.0473795f, --0.31507f,0.944961f,-0.0882052f, --0.286026f,0.950757f,-0.119373f, --0.300544f,0.946699f,-0.115905f, --0.336723f,0.926445f,-0.168278f, --0.353572f,0.929204f,-0.107543f, --0.453641f,0.88906f,-0.0615028f, --0.438343f,0.898681f,0.0151213f, --0.388424f,0.921475f,0.00321393f, --0.409039f,0.909757f,0.0709235f, --0.363684f,0.905932f,0.216843f, --0.363969f,0.919331f,0.149522f, --0.393196f,0.918247f,0.0470974f, --0.399628f,0.911703f,0.0953624f, --0.51262f,0.855967f,-0.0673815f, --0.335242f,0.936382f,-0.103929f, --0.0973696f,0.981557f,-0.164516f, -0.067792f,0.980923f,-0.182192f, -0.0872383f,0.996018f,-0.0183907f, --0.00523703f,0.995218f,0.0975357f, -0.128581f,0.983098f,0.130327f, -0.373617f,0.921384f,0.107058f, -0.560261f,0.820373f,0.114439f, -0.627317f,0.771722f,0.104494f, -0.477878f,0.875076f,0.0766505f, -0.339671f,0.937101f,0.080413f, -0.338185f,0.931593f,0.133286f, -0.241006f,0.969638f,0.0414564f, -0.184566f,0.96984f,-0.159206f, -0.299844f,0.937156f,-0.178416f, -0.33645f,0.93097f,-0.14176f, -0.33978f,0.935566f,-0.0962638f, -0.338458f,0.922961f,-0.183273f, -0.376116f,0.905613f,-0.195964f, -0.229101f,0.942068f,-0.244989f, -0.179681f,0.964126f,-0.195387f, -0.0309568f,0.968834f,-0.245768f, -0.00573259f,0.975463f,-0.220088f, -0.156849f,0.977783f,-0.139061f, -0.21782f,0.972525f,-0.0821593f, -0.0218621f,0.99451f,-0.102332f, --0.198564f,0.980065f,-0.00663249f, --0.36267f,0.923836f,0.122463f, --0.30382f,0.935102f,0.182419f, --0.225949f,0.949998f,0.215522f, --0.338005f,0.935768f,0.100459f, --0.329518f,0.942604f,0.0540005f, --0.353044f,0.9356f,0.00366832f, --0.46383f,0.880375f,-0.0990046f, -0.265153f,0.963251f,-0.0429098f, -0.322279f,0.944597f,-0.0622248f, -0.315505f,0.945542f,-0.0800488f, -0.163962f,0.974749f,-0.151597f, -0.137337f,0.972433f,-0.188448f, -0.0704319f,0.957822f,-0.278599f, -0.0704671f,0.945462f,-0.318019f, -0.0908986f,0.948607f,-0.303121f, -0.035224f,0.968727f,-0.245614f, --0.0832465f,0.983302f,-0.161824f, --0.246429f,0.938519f,-0.241773f, --0.316726f,0.889326f,-0.329823f, --0.284897f,0.918994f,-0.272549f, --0.362325f,0.886545f,-0.287677f, --0.440048f,0.874713f,-0.203063f, --0.497142f,0.865956f,-0.0544999f, --0.523445f,0.849121f,-0.0707108f, --0.401725f,0.907593f,-0.122034f, --0.239401f,0.964528f,-0.111235f, --0.233733f,0.958501f,-0.163231f, --0.252964f,0.932836f,-0.256566f, --0.367645f,0.889692f,-0.270713f, --0.454692f,0.878935f,-0.143978f, --0.492544f,0.866924f,-0.0764391f, --0.481959f,0.875013f,-0.0454739f, --0.427088f,0.903155f,0.0436767f, --0.414523f,0.900313f,0.132691f, --0.445145f,0.893064f,0.0654368f, --0.272596f,0.94477f,0.181937f, --0.346295f,0.936658f,0.0524542f, --0.387211f,0.921676f,-0.0241059f, --0.412405f,0.90305f,-0.120098f, --0.307707f,0.940243f,-0.145806f, --0.0608418f,0.995582f,-0.0715164f, --0.0645131f,0.997917f,-0.000435129f, --0.102008f,0.988043f,0.115607f, -0.0143588f,0.992143f,0.12428f, -0.177967f,0.984035f,-0.00139713f, -0.41001f,0.908001f,-0.0861781f, -0.552955f,0.819416f,-0.150989f, -0.604866f,0.793986f,-0.061019f, -0.412532f,0.907382f,0.080473f, -0.292095f,0.937176f,0.190737f, -0.30791f,0.927063f,0.213882f, -0.344775f,0.913992f,0.21389f, -0.356481f,0.927786f,0.110156f, -0.364153f,0.931072f,-0.0223179f, -0.345291f,0.930006f,-0.125944f, -0.351321f,0.913987f,-0.20298f, -0.3587f,0.898336f,-0.253627f, -0.30452f,0.930923f,-0.201617f, -0.2074f,0.975489f,-0.0735288f, -0.18932f,0.981882f,-0.00809888f, -0.163933f,0.983471f,-0.0768774f, -0.0155138f,0.975385f,-0.219964f, -0.0271837f,0.983796f,-0.177221f, -0.116676f,0.992898f,-0.0232359f, --0.0753728f,0.996934f,0.0209924f, --0.279745f,0.951672f,0.12674f, --0.364174f,0.921867f,0.132433f, --0.344523f,0.936581f,0.0641857f, --0.216332f,0.972578f,0.0853902f, --0.223892f,0.974436f,0.0186366f, --0.28965f,0.953049f,-0.0883156f, --0.269918f,0.95756f,-0.101108f, --0.286201f,0.950564f,-0.120491f, -0.172976f,0.984286f,-0.0355076f, -0.24194f,0.969981f,0.0245291f, -0.324379f,0.937283f,0.127591f, -0.286811f,0.953171f,0.0959428f, -0.228455f,0.972614f,-0.0427886f, -0.182359f,0.97568f,-0.121631f, -0.113036f,0.971479f,-0.208452f, -0.0547152f,0.964701f,-0.257601f, --0.089806f,0.977237f,-0.192205f, --0.171631f,0.984685f,-0.0306458f, --0.116586f,0.992809f,0.0271681f, --0.181607f,0.981068f,-0.0672723f, --0.351307f,0.914748f,-0.199546f, --0.388005f,0.90325f,-0.183278f, --0.498044f,0.847159f,-0.185132f, --0.510366f,0.84434f,-0.163145f, --0.479522f,0.851128f,-0.213636f, --0.42037f,0.86671f,-0.268518f, --0.285469f,0.932257f,-0.22227f, --0.161107f,0.969121f,-0.186679f, --0.183754f,0.955302f,-0.231585f, --0.370817f,0.89935f,-0.231654f, --0.514998f,0.83014f,-0.213645f, --0.498206f,0.85286f,-0.156273f, --0.539513f,0.835182f,-0.106757f, --0.535773f,0.843208f,0.0441435f, --0.434698f,0.878206f,0.19948f, --0.415775f,0.89222f,0.176277f, --0.35414f,0.920981f,0.162413f, --0.208366f,0.953013f,0.219884f, --0.257177f,0.962661f,0.0845243f, --0.386488f,0.920792f,-0.0526133f, --0.381213f,0.924327f,0.0172227f, --0.280093f,0.955497f,0.0925905f, --0.1219f,0.953555f,0.275451f, --0.0595691f,0.973079f,0.222641f, -0.124431f,0.978938f,0.161854f, -0.328706f,0.943592f,0.0398269f, -0.495224f,0.863825f,-0.0925162f, -0.549494f,0.832161f,-0.0745945f, -0.445758f,0.890738f,0.0887957f, -0.286029f,0.911685f,0.294987f, -0.236342f,0.90766f,0.346837f, -0.306156f,0.900003f,0.310262f, -0.362522f,0.893707f,0.264322f, -0.407318f,0.891604f,0.197826f, -0.447705f,0.883296f,0.139101f, -0.451832f,0.890524f,0.0530504f, -0.450032f,0.892977f,-0.00796524f, -0.380264f,0.922022f,-0.0726326f, -0.220431f,0.973877f,-0.0545382f, -0.073814f,0.997262f,0.00436123f, -0.143916f,0.987825f,0.059083f, -0.242994f,0.967605f,0.068523f, -0.0793826f,0.995647f,0.0488496f, --0.0810126f,0.994023f,0.0731786f, -0.0550609f,0.987118f,0.150223f, --0.0403249f,0.995863f,0.0814341f, --0.341404f,0.939899f,-0.00574405f, --0.333197f,0.942331f,0.0315063f, --0.270492f,0.962353f,-0.0266656f, --0.217149f,0.973729f,-0.0685481f, --0.150518f,0.988024f,-0.0339529f, --0.227799f,0.970772f,-0.0755549f, --0.30247f,0.950166f,-0.0754703f, --0.319718f,0.946617f,-0.0411916f, -0.16825f,0.98433f,0.0527868f, -0.196178f,0.978898f,0.0572086f, -0.274186f,0.954613f,0.116347f, -0.32563f,0.930709f,0.166568f, -0.315871f,0.943308f,0.101959f, -0.191037f,0.981318f,-0.0227958f, -0.218135f,0.975914f,0.0029357f, -0.0466483f,0.982299f,-0.18142f, --0.170175f,0.975305f,-0.140788f, --0.258133f,0.965917f,0.0192531f, --0.189679f,0.978131f,0.0853348f, --0.0936377f,0.967266f,0.235858f, --0.301926f,0.950003f,0.0795937f, --0.345647f,0.93835f,0.00528925f, --0.494118f,0.858314f,-0.138363f, --0.492927f,0.860507f,-0.128646f, --0.443878f,0.87267f,-0.203517f, --0.398442f,0.869961f,-0.290537f, --0.31747f,0.894846f,-0.313789f, --0.189431f,0.934926f,-0.300049f, --0.194231f,0.947861f,-0.252654f, --0.355627f,0.917296f,-0.179159f, --0.521351f,0.821848f,-0.229692f, --0.537173f,0.817848f,-0.206322f, --0.595314f,0.798098f,-0.0929575f, --0.612312f,0.785394f,0.0907203f, --0.484809f,0.839064f,0.246843f, --0.327417f,0.875762f,0.354737f, --0.358949f,0.909479f,0.20977f, --0.221142f,0.943893f,0.245282f, --0.137619f,0.956208f,0.258316f, --0.37682f,0.920718f,0.101416f, --0.393482f,0.900899f,0.183174f, --0.309483f,0.930699f,0.194988f, --0.137506f,0.96116f,0.2393f, --0.0256175f,0.984881f,0.171327f, -0.155024f,0.972933f,0.171372f, -0.40312f,0.907825f,0.115531f, -0.491485f,0.869632f,-0.0467184f, -0.488586f,0.869843f,0.0682392f, -0.313615f,0.910806f,0.268473f, -0.190736f,0.863506f,0.466881f, -0.238952f,0.837112f,0.492083f, -0.344695f,0.840122f,0.418784f, -0.396648f,0.860615f,0.319393f, -0.456384f,0.85928f,0.230981f, -0.487857f,0.863295f,0.129295f, -0.451906f,0.891012f,0.043332f, -0.456211f,0.882737f,0.112455f, -0.397431f,0.910062f,0.117622f, -0.204941f,0.971778f,0.116821f, -0.0877111f,0.985798f,0.143208f, -0.14813f,0.986469f,0.0702648f, -0.212033f,0.976625f,0.035296f, -0.0413914f,0.99116f,0.126047f, --0.10186f,0.970634f,0.217932f, -0.0558102f,0.971334f,0.231076f, -0.0834757f,0.981533f,0.172117f, --0.293392f,0.955612f,-0.0269471f, --0.339064f,0.938377f,-0.0669636f, --0.232942f,0.969004f,-0.0822698f, --0.249298f,0.960887f,-0.120613f, --0.178309f,0.98375f,-0.0210319f, --0.23671f,0.971566f,0.00516088f, --0.322203f,0.944986f,0.0564443f, --0.359276f,0.929551f,0.0827968f, -}; - -btScalar Landscape06Tex[] = { -0.0f,0.0078125f, -0.0f,0.0f, -0.0078125f,0.0078125f, -0.0078125f,0.0f, -0.015625f,0.0078125f, -0.015625f,0.0f, -0.0234375f,0.0078125f, -0.0234375f,0.0f, -0.03125f,0.0078125f, -0.03125f,0.0f, -0.0390625f,0.0078125f, -0.0390625f,0.0f, -0.046875f,0.0078125f, -0.046875f,0.0f, -0.0546875f,0.0078125f, -0.0546875f,0.0f, -0.0625f,0.0078125f, -0.0625f,0.0f, -0.0703125f,0.0078125f, -0.0703125f,0.0f, -0.078125f,0.0078125f, -0.078125f,0.0f, -0.0859375f,0.0078125f, -0.0859375f,0.0f, -0.09375f,0.0078125f, -0.09375f,0.0f, -0.101563f,0.0078125f, -0.101563f,0.0f, -0.109375f,0.0078125f, -0.109375f,0.0f, -0.117188f,0.0078125f, -0.117188f,0.0f, -0.125f,0.0078125f, -0.125f,0.0f, -0.132813f,0.0078125f, -0.132813f,0.0f, -0.140625f,0.0078125f, -0.140625f,0.0f, -0.148438f,0.0078125f, -0.148438f,0.0f, -0.15625f,0.0078125f, -0.15625f,0.0f, -0.164063f,0.0078125f, -0.164063f,0.0f, -0.171875f,0.0078125f, -0.171875f,0.0f, -0.179688f,0.0078125f, -0.179688f,0.0f, -0.1875f,0.0078125f, -0.1875f,0.0f, -0.195313f,0.0078125f, -0.195313f,0.0f, -0.203125f,0.0078125f, -0.203125f,0.0f, -0.210938f,0.0078125f, -0.210938f,0.0f, -0.21875f,0.0078125f, -0.21875f,0.0f, -0.226563f,0.0078125f, -0.226563f,0.0f, -0.234375f,0.0078125f, -0.234375f,0.0f, -0.242188f,0.0078125f, -0.242188f,0.0f, -0.25f,0.0078125f, -0.25f,0.0f, -0.257813f,0.0078125f, -0.257813f,0.0f, -0.265625f,0.0078125f, -0.265625f,0.0f, -0.273438f,0.0078125f, -0.273438f,0.0f, -0.28125f,0.0078125f, -0.28125f,0.0f, -0.289063f,0.0078125f, -0.289063f,0.0f, -0.296875f,0.0078125f, -0.296875f,0.0f, -0.304688f,0.0078125f, -0.304688f,0.0f, -0.3125f,0.0078125f, -0.3125f,0.0f, -0.320313f,0.0078125f, -0.320313f,0.0f, -0.328125f,0.0078125f, -0.328125f,0.0f, -0.335938f,0.0078125f, -0.335938f,0.0f, -0.34375f,0.0078125f, -0.34375f,0.0f, -0.351563f,0.0078125f, -0.351563f,0.0f, -0.359375f,0.0078125f, -0.359375f,0.0f, -0.367188f,0.0078125f, -0.367188f,0.0f, -0.375f,0.0078125f, -0.375f,0.0f, -0.382813f,0.0078125f, -0.382813f,0.0f, -0.390625f,0.0078125f, -0.390625f,0.0f, -0.398438f,0.0078125f, -0.398438f,0.0f, -0.40625f,0.0078125f, -0.40625f,0.0f, -0.414063f,0.0078125f, -0.414063f,0.0f, -0.421875f,0.0078125f, -0.421875f,0.0f, -0.429688f,0.0078125f, -0.429688f,0.0f, -0.4375f,0.0078125f, -0.4375f,0.0f, -0.445313f,0.0078125f, -0.445313f,0.0f, -0.453125f,0.0078125f, -0.453125f,0.0f, -0.460938f,0.0078125f, -0.460938f,0.0f, -0.46875f,0.0078125f, -0.46875f,0.0f, -0.476563f,0.0078125f, -0.476563f,0.0f, -0.484375f,0.0078125f, -0.484375f,0.0f, -0.492188f,0.0078125f, -0.492188f,0.0f, -0.5f,0.0078125f, -0.5f,0.0f, -0.507813f,0.0078125f, -0.507813f,0.0f, -0.0f,0.015625f, -0.0078125f,0.015625f, -0.015625f,0.015625f, -0.0234375f,0.015625f, -0.03125f,0.015625f, -0.0390625f,0.015625f, -0.046875f,0.015625f, -0.0546875f,0.015625f, -0.0625f,0.015625f, -0.0703125f,0.015625f, -0.078125f,0.015625f, -0.0859375f,0.015625f, -0.09375f,0.015625f, -0.101563f,0.015625f, -0.109375f,0.015625f, -0.117188f,0.015625f, -0.125f,0.015625f, -0.132813f,0.015625f, -0.140625f,0.015625f, -0.148438f,0.015625f, -0.15625f,0.015625f, -0.164063f,0.015625f, -0.171875f,0.015625f, -0.179688f,0.015625f, -0.1875f,0.015625f, -0.195313f,0.015625f, -0.203125f,0.015625f, -0.210938f,0.015625f, -0.21875f,0.015625f, -0.226563f,0.015625f, -0.234375f,0.015625f, -0.242188f,0.015625f, -0.25f,0.015625f, -0.257813f,0.015625f, -0.265625f,0.015625f, -0.273438f,0.015625f, -0.28125f,0.015625f, -0.289063f,0.015625f, -0.296875f,0.015625f, -0.304688f,0.015625f, -0.3125f,0.015625f, -0.320313f,0.015625f, -0.328125f,0.015625f, -0.335938f,0.015625f, -0.34375f,0.015625f, -0.351563f,0.015625f, -0.359375f,0.015625f, -0.367188f,0.015625f, -0.375f,0.015625f, -0.382813f,0.015625f, -0.390625f,0.015625f, -0.398438f,0.015625f, -0.40625f,0.015625f, -0.414063f,0.015625f, -0.421875f,0.015625f, -0.429688f,0.015625f, -0.4375f,0.015625f, -0.445313f,0.015625f, -0.453125f,0.015625f, -0.460938f,0.015625f, -0.46875f,0.015625f, -0.476563f,0.015625f, -0.484375f,0.015625f, -0.492188f,0.015625f, -0.5f,0.015625f, -0.507813f,0.015625f, -0.0f,0.0234375f, -0.0078125f,0.0234375f, -0.015625f,0.0234375f, -0.0234375f,0.0234375f, -0.03125f,0.0234375f, -0.0390625f,0.0234375f, -0.046875f,0.0234375f, -0.0546875f,0.0234375f, -0.0625f,0.0234375f, -0.0703125f,0.0234375f, -0.078125f,0.0234375f, -0.0859375f,0.0234375f, -0.09375f,0.0234375f, -0.101563f,0.0234375f, -0.109375f,0.0234375f, -0.117188f,0.0234375f, -0.125f,0.0234375f, -0.132813f,0.0234375f, -0.140625f,0.0234375f, -0.148438f,0.0234375f, -0.15625f,0.0234375f, -0.164063f,0.0234375f, -0.171875f,0.0234375f, -0.179688f,0.0234375f, -0.1875f,0.0234375f, -0.195313f,0.0234375f, -0.203125f,0.0234375f, -0.210938f,0.0234375f, -0.21875f,0.0234375f, -0.226563f,0.0234375f, -0.234375f,0.0234375f, -0.242188f,0.0234375f, -0.25f,0.0234375f, -0.257813f,0.0234375f, -0.265625f,0.0234375f, -0.273438f,0.0234375f, -0.28125f,0.0234375f, -0.289063f,0.0234375f, -0.296875f,0.0234375f, -0.304688f,0.0234375f, -0.3125f,0.0234375f, -0.320313f,0.0234375f, -0.328125f,0.0234375f, -0.335938f,0.0234375f, -0.34375f,0.0234375f, -0.351563f,0.0234375f, -0.359375f,0.0234375f, -0.367188f,0.0234375f, -0.375f,0.0234375f, -0.382813f,0.0234375f, -0.390625f,0.0234375f, -0.398438f,0.0234375f, -0.40625f,0.0234375f, -0.414063f,0.0234375f, -0.421875f,0.0234375f, -0.429688f,0.0234375f, -0.4375f,0.0234375f, -0.445313f,0.0234375f, -0.453125f,0.0234375f, -0.460938f,0.0234375f, -0.46875f,0.0234375f, -0.476563f,0.0234375f, -0.484375f,0.0234375f, -0.492188f,0.0234375f, -0.5f,0.0234375f, -0.507813f,0.0234375f, -0.0f,0.03125f, -0.0078125f,0.03125f, -0.015625f,0.03125f, -0.0234375f,0.03125f, -0.03125f,0.03125f, -0.0390625f,0.03125f, -0.046875f,0.03125f, -0.0546875f,0.03125f, -0.0625f,0.03125f, -0.0703125f,0.03125f, -0.078125f,0.03125f, -0.0859375f,0.03125f, -0.09375f,0.03125f, -0.101563f,0.03125f, -0.109375f,0.03125f, -0.117188f,0.03125f, -0.125f,0.03125f, -0.132813f,0.03125f, -0.140625f,0.03125f, -0.148438f,0.03125f, -0.15625f,0.03125f, -0.164063f,0.03125f, -0.171875f,0.03125f, -0.179688f,0.03125f, -0.1875f,0.03125f, -0.195313f,0.03125f, -0.203125f,0.03125f, -0.210938f,0.03125f, -0.21875f,0.03125f, -0.226563f,0.03125f, -0.234375f,0.03125f, -0.242188f,0.03125f, -0.25f,0.03125f, -0.257813f,0.03125f, -0.265625f,0.03125f, -0.273438f,0.03125f, -0.28125f,0.03125f, -0.289063f,0.03125f, -0.296875f,0.03125f, -0.304688f,0.03125f, -0.3125f,0.03125f, -0.320313f,0.03125f, -0.328125f,0.03125f, -0.335938f,0.03125f, -0.34375f,0.03125f, -0.351563f,0.03125f, -0.359375f,0.03125f, -0.367188f,0.03125f, -0.375f,0.03125f, -0.382813f,0.03125f, -0.390625f,0.03125f, -0.398438f,0.03125f, -0.40625f,0.03125f, -0.414063f,0.03125f, -0.421875f,0.03125f, -0.429688f,0.03125f, -0.4375f,0.03125f, -0.445313f,0.03125f, -0.453125f,0.03125f, -0.460938f,0.03125f, -0.46875f,0.03125f, -0.476563f,0.03125f, -0.484375f,0.03125f, -0.492188f,0.03125f, -0.5f,0.03125f, -0.507813f,0.03125f, -0.0f,0.0390625f, -0.0078125f,0.0390625f, -0.015625f,0.0390625f, -0.0234375f,0.0390625f, -0.03125f,0.0390625f, -0.0390625f,0.0390625f, -0.046875f,0.0390625f, -0.0546875f,0.0390625f, -0.0625f,0.0390625f, -0.0703125f,0.0390625f, -0.078125f,0.0390625f, -0.0859375f,0.0390625f, -0.09375f,0.0390625f, -0.101563f,0.0390625f, -0.109375f,0.0390625f, -0.117188f,0.0390625f, -0.125f,0.0390625f, -0.132813f,0.0390625f, -0.140625f,0.0390625f, -0.148438f,0.0390625f, -0.15625f,0.0390625f, -0.164063f,0.0390625f, -0.171875f,0.0390625f, -0.179688f,0.0390625f, -0.1875f,0.0390625f, -0.195313f,0.0390625f, -0.203125f,0.0390625f, -0.210938f,0.0390625f, -0.21875f,0.0390625f, -0.226563f,0.0390625f, -0.234375f,0.0390625f, -0.242188f,0.0390625f, -0.25f,0.0390625f, -0.257813f,0.0390625f, -0.265625f,0.0390625f, -0.273438f,0.0390625f, -0.28125f,0.0390625f, -0.289063f,0.0390625f, -0.296875f,0.0390625f, -0.304688f,0.0390625f, -0.3125f,0.0390625f, -0.320313f,0.0390625f, -0.328125f,0.0390625f, -0.335938f,0.0390625f, -0.34375f,0.0390625f, -0.351563f,0.0390625f, -0.359375f,0.0390625f, -0.367188f,0.0390625f, -0.375f,0.0390625f, -0.382813f,0.0390625f, -0.390625f,0.0390625f, -0.398438f,0.0390625f, -0.40625f,0.0390625f, -0.414063f,0.0390625f, -0.421875f,0.0390625f, -0.429688f,0.0390625f, -0.4375f,0.0390625f, -0.445313f,0.0390625f, -0.453125f,0.0390625f, -0.460938f,0.0390625f, -0.46875f,0.0390625f, -0.476563f,0.0390625f, -0.484375f,0.0390625f, -0.492188f,0.0390625f, -0.5f,0.0390625f, -0.507813f,0.0390625f, -0.0f,0.046875f, -0.0078125f,0.046875f, -0.015625f,0.046875f, -0.0234375f,0.046875f, -0.03125f,0.046875f, -0.0390625f,0.046875f, -0.046875f,0.046875f, -0.0546875f,0.046875f, -0.0625f,0.046875f, -0.0703125f,0.046875f, -0.078125f,0.046875f, -0.0859375f,0.046875f, -0.09375f,0.046875f, -0.101563f,0.046875f, -0.109375f,0.046875f, -0.117188f,0.046875f, -0.125f,0.046875f, -0.132813f,0.046875f, -0.140625f,0.046875f, -0.148438f,0.046875f, -0.15625f,0.046875f, -0.164063f,0.046875f, -0.171875f,0.046875f, -0.179688f,0.046875f, -0.1875f,0.046875f, -0.195313f,0.046875f, -0.203125f,0.046875f, -0.210938f,0.046875f, -0.21875f,0.046875f, -0.226563f,0.046875f, -0.234375f,0.046875f, -0.242188f,0.046875f, -0.25f,0.046875f, -0.257813f,0.046875f, -0.265625f,0.046875f, -0.273438f,0.046875f, -0.28125f,0.046875f, -0.289063f,0.046875f, -0.296875f,0.046875f, -0.304688f,0.046875f, -0.3125f,0.046875f, -0.320313f,0.046875f, -0.328125f,0.046875f, -0.335938f,0.046875f, -0.34375f,0.046875f, -0.351563f,0.046875f, -0.359375f,0.046875f, -0.367188f,0.046875f, -0.375f,0.046875f, -0.382813f,0.046875f, -0.390625f,0.046875f, -0.398438f,0.046875f, -0.40625f,0.046875f, -0.414063f,0.046875f, -0.421875f,0.046875f, -0.429688f,0.046875f, -0.4375f,0.046875f, -0.445313f,0.046875f, -0.453125f,0.046875f, -0.460938f,0.046875f, -0.46875f,0.046875f, -0.476563f,0.046875f, -0.484375f,0.046875f, -0.492188f,0.046875f, -0.5f,0.046875f, -0.507813f,0.046875f, -0.0f,0.0546875f, -0.0078125f,0.0546875f, -0.015625f,0.0546875f, -0.0234375f,0.0546875f, -0.03125f,0.0546875f, -0.0390625f,0.0546875f, -0.046875f,0.0546875f, -0.0546875f,0.0546875f, -0.0625f,0.0546875f, -0.0703125f,0.0546875f, -0.078125f,0.0546875f, -0.0859375f,0.0546875f, -0.09375f,0.0546875f, -0.101563f,0.0546875f, -0.109375f,0.0546875f, -0.117188f,0.0546875f, -0.125f,0.0546875f, -0.132813f,0.0546875f, -0.140625f,0.0546875f, -0.148438f,0.0546875f, -0.15625f,0.0546875f, -0.164063f,0.0546875f, -0.171875f,0.0546875f, -0.179688f,0.0546875f, -0.1875f,0.0546875f, -0.195313f,0.0546875f, -0.203125f,0.0546875f, -0.210938f,0.0546875f, -0.21875f,0.0546875f, -0.226563f,0.0546875f, -0.234375f,0.0546875f, -0.242188f,0.0546875f, -0.25f,0.0546875f, -0.257813f,0.0546875f, -0.265625f,0.0546875f, -0.273438f,0.0546875f, -0.28125f,0.0546875f, -0.289063f,0.0546875f, -0.296875f,0.0546875f, -0.304688f,0.0546875f, -0.3125f,0.0546875f, -0.320313f,0.0546875f, -0.328125f,0.0546875f, -0.335938f,0.0546875f, -0.34375f,0.0546875f, -0.351563f,0.0546875f, -0.359375f,0.0546875f, -0.367188f,0.0546875f, -0.375f,0.0546875f, -0.382813f,0.0546875f, -0.390625f,0.0546875f, -0.398438f,0.0546875f, -0.40625f,0.0546875f, -0.414063f,0.0546875f, -0.421875f,0.0546875f, -0.429688f,0.0546875f, -0.4375f,0.0546875f, -0.445313f,0.0546875f, -0.453125f,0.0546875f, -0.460938f,0.0546875f, -0.46875f,0.0546875f, -0.476563f,0.0546875f, -0.484375f,0.0546875f, -0.492188f,0.0546875f, -0.5f,0.0546875f, -0.507813f,0.0546875f, -0.0f,0.0625f, -0.0078125f,0.0625f, -0.015625f,0.0625f, -0.0234375f,0.0625f, -0.03125f,0.0625f, -0.0390625f,0.0625f, -0.046875f,0.0625f, -0.0546875f,0.0625f, -0.0625f,0.0625f, -0.0703125f,0.0625f, -0.078125f,0.0625f, -0.0859375f,0.0625f, -0.09375f,0.0625f, -0.101563f,0.0625f, -0.109375f,0.0625f, -0.117188f,0.0625f, -0.125f,0.0625f, -0.132813f,0.0625f, -0.140625f,0.0625f, -0.148438f,0.0625f, -0.15625f,0.0625f, -0.164063f,0.0625f, -0.171875f,0.0625f, -0.179688f,0.0625f, -0.1875f,0.0625f, -0.195313f,0.0625f, -0.203125f,0.0625f, -0.210938f,0.0625f, -0.21875f,0.0625f, -0.226563f,0.0625f, -0.234375f,0.0625f, -0.242188f,0.0625f, -0.25f,0.0625f, -0.257813f,0.0625f, -0.265625f,0.0625f, -0.273438f,0.0625f, -0.28125f,0.0625f, -0.289063f,0.0625f, -0.296875f,0.0625f, -0.304688f,0.0625f, -0.3125f,0.0625f, -0.320313f,0.0625f, -0.328125f,0.0625f, -0.335938f,0.0625f, -0.34375f,0.0625f, -0.351563f,0.0625f, -0.359375f,0.0625f, -0.367188f,0.0625f, -0.375f,0.0625f, -0.382813f,0.0625f, -0.390625f,0.0625f, -0.398438f,0.0625f, -0.40625f,0.0625f, -0.414063f,0.0625f, -0.421875f,0.0625f, -0.429688f,0.0625f, -0.4375f,0.0625f, -0.445313f,0.0625f, -0.453125f,0.0625f, -0.460938f,0.0625f, -0.46875f,0.0625f, -0.476563f,0.0625f, -0.484375f,0.0625f, -0.492188f,0.0625f, -0.5f,0.0625f, -0.507813f,0.0625f, -0.0f,0.0703125f, -0.0078125f,0.0703125f, -0.015625f,0.0703125f, -0.0234375f,0.0703125f, -0.03125f,0.0703125f, -0.0390625f,0.0703125f, -0.046875f,0.0703125f, -0.0546875f,0.0703125f, -0.0625f,0.0703125f, -0.0703125f,0.0703125f, -0.078125f,0.0703125f, -0.0859375f,0.0703125f, -0.09375f,0.0703125f, -0.101563f,0.0703125f, -0.109375f,0.0703125f, -0.117188f,0.0703125f, -0.125f,0.0703125f, -0.132813f,0.0703125f, -0.140625f,0.0703125f, -0.148438f,0.0703125f, -0.15625f,0.0703125f, -0.164063f,0.0703125f, -0.171875f,0.0703125f, -0.179688f,0.0703125f, -0.1875f,0.0703125f, -0.195313f,0.0703125f, -0.203125f,0.0703125f, -0.210938f,0.0703125f, -0.21875f,0.0703125f, -0.226563f,0.0703125f, -0.234375f,0.0703125f, -0.242188f,0.0703125f, -0.25f,0.0703125f, -0.257813f,0.0703125f, -0.265625f,0.0703125f, -0.273438f,0.0703125f, -0.28125f,0.0703125f, -0.289063f,0.0703125f, -0.296875f,0.0703125f, -0.304688f,0.0703125f, -0.3125f,0.0703125f, -0.320313f,0.0703125f, -0.328125f,0.0703125f, -0.335938f,0.0703125f, -0.34375f,0.0703125f, -0.351563f,0.0703125f, -0.359375f,0.0703125f, -0.367188f,0.0703125f, -0.375f,0.0703125f, -0.382813f,0.0703125f, -0.390625f,0.0703125f, -0.398438f,0.0703125f, -0.40625f,0.0703125f, -0.414063f,0.0703125f, -0.421875f,0.0703125f, -0.429688f,0.0703125f, -0.4375f,0.0703125f, -0.445313f,0.0703125f, -0.453125f,0.0703125f, -0.460938f,0.0703125f, -0.46875f,0.0703125f, -0.476563f,0.0703125f, -0.484375f,0.0703125f, -0.492188f,0.0703125f, -0.5f,0.0703125f, -0.507813f,0.0703125f, -0.0f,0.078125f, -0.0078125f,0.078125f, -0.015625f,0.078125f, -0.0234375f,0.078125f, -0.03125f,0.078125f, -0.0390625f,0.078125f, -0.046875f,0.078125f, -0.0546875f,0.078125f, -0.0625f,0.078125f, -0.0703125f,0.078125f, -0.078125f,0.078125f, -0.0859375f,0.078125f, -0.09375f,0.078125f, -0.101563f,0.078125f, -0.109375f,0.078125f, -0.117188f,0.078125f, -0.125f,0.078125f, -0.132813f,0.078125f, -0.140625f,0.078125f, -0.148438f,0.078125f, -0.15625f,0.078125f, -0.164063f,0.078125f, -0.171875f,0.078125f, -0.179688f,0.078125f, -0.1875f,0.078125f, -0.195313f,0.078125f, -0.203125f,0.078125f, -0.210938f,0.078125f, -0.21875f,0.078125f, -0.226563f,0.078125f, -0.234375f,0.078125f, -0.242188f,0.078125f, -0.25f,0.078125f, -0.257813f,0.078125f, -0.265625f,0.078125f, -0.273438f,0.078125f, -0.28125f,0.078125f, -0.289063f,0.078125f, -0.296875f,0.078125f, -0.304688f,0.078125f, -0.3125f,0.078125f, -0.320313f,0.078125f, -0.328125f,0.078125f, -0.335938f,0.078125f, -0.34375f,0.078125f, -0.351563f,0.078125f, -0.359375f,0.078125f, -0.367188f,0.078125f, -0.375f,0.078125f, -0.382813f,0.078125f, -0.390625f,0.078125f, -0.398438f,0.078125f, -0.40625f,0.078125f, -0.414063f,0.078125f, -0.421875f,0.078125f, -0.429688f,0.078125f, -0.4375f,0.078125f, -0.445313f,0.078125f, -0.453125f,0.078125f, -0.460938f,0.078125f, -0.46875f,0.078125f, -0.476563f,0.078125f, -0.484375f,0.078125f, -0.492188f,0.078125f, -0.5f,0.078125f, -0.507813f,0.078125f, -0.0f,0.0859375f, -0.0078125f,0.0859375f, -0.015625f,0.0859375f, -0.0234375f,0.0859375f, -0.03125f,0.0859375f, -0.0390625f,0.0859375f, -0.046875f,0.0859375f, -0.0546875f,0.0859375f, -0.0625f,0.0859375f, -0.0703125f,0.0859375f, -0.078125f,0.0859375f, -0.0859375f,0.0859375f, -0.09375f,0.0859375f, -0.101563f,0.0859375f, -0.109375f,0.0859375f, -0.117188f,0.0859375f, -0.125f,0.0859375f, -0.132813f,0.0859375f, -0.140625f,0.0859375f, -0.148438f,0.0859375f, -0.15625f,0.0859375f, -0.164063f,0.0859375f, -0.171875f,0.0859375f, -0.179688f,0.0859375f, -0.1875f,0.0859375f, -0.195313f,0.0859375f, -0.203125f,0.0859375f, -0.210938f,0.0859375f, -0.21875f,0.0859375f, -0.226563f,0.0859375f, -0.234375f,0.0859375f, -0.242188f,0.0859375f, -0.25f,0.0859375f, -0.257813f,0.0859375f, -0.265625f,0.0859375f, -0.273438f,0.0859375f, -0.28125f,0.0859375f, -0.289063f,0.0859375f, -0.296875f,0.0859375f, -0.304688f,0.0859375f, -0.3125f,0.0859375f, -0.320313f,0.0859375f, -0.328125f,0.0859375f, -0.335938f,0.0859375f, -0.34375f,0.0859375f, -0.351563f,0.0859375f, -0.359375f,0.0859375f, -0.367188f,0.0859375f, -0.375f,0.0859375f, -0.382813f,0.0859375f, -0.390625f,0.0859375f, -0.398438f,0.0859375f, -0.40625f,0.0859375f, -0.414063f,0.0859375f, -0.421875f,0.0859375f, -0.429688f,0.0859375f, -0.4375f,0.0859375f, -0.445313f,0.0859375f, -0.453125f,0.0859375f, -0.460938f,0.0859375f, -0.46875f,0.0859375f, -0.476563f,0.0859375f, -0.484375f,0.0859375f, -0.492188f,0.0859375f, -0.5f,0.0859375f, -0.507813f,0.0859375f, -0.0f,0.09375f, -0.0078125f,0.09375f, -0.015625f,0.09375f, -0.0234375f,0.09375f, -0.03125f,0.09375f, -0.0390625f,0.09375f, -0.046875f,0.09375f, -0.0546875f,0.09375f, -0.0625f,0.09375f, -0.0703125f,0.09375f, -0.078125f,0.09375f, -0.0859375f,0.09375f, -0.09375f,0.09375f, -0.101563f,0.09375f, -0.109375f,0.09375f, -0.117188f,0.09375f, -0.125f,0.09375f, -0.132813f,0.09375f, -0.140625f,0.09375f, -0.148438f,0.09375f, -0.15625f,0.09375f, -0.164063f,0.09375f, -0.171875f,0.09375f, -0.179688f,0.09375f, -0.1875f,0.09375f, -0.195313f,0.09375f, -0.203125f,0.09375f, -0.210938f,0.09375f, -0.21875f,0.09375f, -0.226563f,0.09375f, -0.234375f,0.09375f, -0.242188f,0.09375f, -0.25f,0.09375f, -0.257813f,0.09375f, -0.265625f,0.09375f, -0.273438f,0.09375f, -0.28125f,0.09375f, -0.289063f,0.09375f, -0.296875f,0.09375f, -0.304688f,0.09375f, -0.3125f,0.09375f, -0.320313f,0.09375f, -0.328125f,0.09375f, -0.335938f,0.09375f, -0.34375f,0.09375f, -0.351563f,0.09375f, -0.359375f,0.09375f, -0.367188f,0.09375f, -0.375f,0.09375f, -0.382813f,0.09375f, -0.390625f,0.09375f, -0.398438f,0.09375f, -0.40625f,0.09375f, -0.414063f,0.09375f, -0.421875f,0.09375f, -0.429688f,0.09375f, -0.4375f,0.09375f, -0.445313f,0.09375f, -0.453125f,0.09375f, -0.460938f,0.09375f, -0.46875f,0.09375f, -0.476563f,0.09375f, -0.484375f,0.09375f, -0.492188f,0.09375f, -0.5f,0.09375f, -0.507813f,0.09375f, -0.0f,0.101563f, -0.0078125f,0.101563f, -0.015625f,0.101563f, -0.0234375f,0.101563f, -0.03125f,0.101563f, -0.0390625f,0.101563f, -0.046875f,0.101563f, -0.0546875f,0.101563f, -0.0625f,0.101563f, -0.0703125f,0.101563f, -0.078125f,0.101563f, -0.0859375f,0.101563f, -0.09375f,0.101563f, -0.101563f,0.101563f, -0.109375f,0.101563f, -0.117188f,0.101563f, -0.125f,0.101563f, -0.132813f,0.101563f, -0.140625f,0.101563f, -0.148438f,0.101563f, -0.15625f,0.101563f, -0.164063f,0.101563f, -0.171875f,0.101563f, -0.179688f,0.101563f, -0.1875f,0.101563f, -0.195313f,0.101563f, -0.203125f,0.101563f, -0.210938f,0.101563f, -0.21875f,0.101563f, -0.226563f,0.101563f, -0.234375f,0.101563f, -0.242188f,0.101563f, -0.25f,0.101563f, -0.257813f,0.101563f, -0.265625f,0.101563f, -0.273438f,0.101563f, -0.28125f,0.101563f, -0.289063f,0.101563f, -0.296875f,0.101563f, -0.304688f,0.101563f, -0.3125f,0.101563f, -0.320313f,0.101563f, -0.328125f,0.101563f, -0.335938f,0.101563f, -0.34375f,0.101563f, -0.351563f,0.101563f, -0.359375f,0.101563f, -0.367188f,0.101563f, -0.375f,0.101563f, -0.382813f,0.101563f, -0.390625f,0.101563f, -0.398438f,0.101563f, -0.40625f,0.101563f, -0.414063f,0.101563f, -0.421875f,0.101563f, -0.429688f,0.101563f, -0.4375f,0.101563f, -0.445313f,0.101563f, -0.453125f,0.101563f, -0.460938f,0.101563f, -0.46875f,0.101563f, -0.476563f,0.101563f, -0.484375f,0.101563f, -0.492188f,0.101563f, -0.5f,0.101563f, -0.507813f,0.101563f, -0.0f,0.109375f, -0.0078125f,0.109375f, -0.015625f,0.109375f, -0.0234375f,0.109375f, -0.03125f,0.109375f, -0.0390625f,0.109375f, -0.046875f,0.109375f, -0.0546875f,0.109375f, -0.0625f,0.109375f, -0.0703125f,0.109375f, -0.078125f,0.109375f, -0.0859375f,0.109375f, -0.09375f,0.109375f, -0.101563f,0.109375f, -0.109375f,0.109375f, -0.117188f,0.109375f, -0.125f,0.109375f, -0.132813f,0.109375f, -0.140625f,0.109375f, -0.148438f,0.109375f, -0.15625f,0.109375f, -0.164063f,0.109375f, -0.171875f,0.109375f, -0.179688f,0.109375f, -0.1875f,0.109375f, -0.195313f,0.109375f, -0.203125f,0.109375f, -0.210938f,0.109375f, -0.21875f,0.109375f, -0.226563f,0.109375f, -0.234375f,0.109375f, -0.242188f,0.109375f, -0.25f,0.109375f, -0.257813f,0.109375f, -0.265625f,0.109375f, -0.273438f,0.109375f, -0.28125f,0.109375f, -0.289063f,0.109375f, -0.296875f,0.109375f, -0.304688f,0.109375f, -0.3125f,0.109375f, -0.320313f,0.109375f, -0.328125f,0.109375f, -0.335938f,0.109375f, -0.34375f,0.109375f, -0.351563f,0.109375f, -0.359375f,0.109375f, -0.367188f,0.109375f, -0.375f,0.109375f, -0.382813f,0.109375f, -0.390625f,0.109375f, -0.398438f,0.109375f, -0.40625f,0.109375f, -0.414063f,0.109375f, -0.421875f,0.109375f, -0.429688f,0.109375f, -0.4375f,0.109375f, -0.445313f,0.109375f, -0.453125f,0.109375f, -0.460938f,0.109375f, -0.46875f,0.109375f, -0.476563f,0.109375f, -0.484375f,0.109375f, -0.492188f,0.109375f, -0.5f,0.109375f, -0.507813f,0.109375f, -0.0f,0.117188f, -0.0078125f,0.117188f, -0.015625f,0.117188f, -0.0234375f,0.117188f, -0.03125f,0.117188f, -0.0390625f,0.117188f, -0.046875f,0.117188f, -0.0546875f,0.117188f, -0.0625f,0.117188f, -0.0703125f,0.117188f, -0.078125f,0.117188f, -0.0859375f,0.117188f, -0.09375f,0.117188f, -0.101563f,0.117188f, -0.109375f,0.117188f, -0.117188f,0.117188f, -0.125f,0.117188f, -0.132813f,0.117188f, -0.140625f,0.117188f, -0.148438f,0.117188f, -0.15625f,0.117188f, -0.164063f,0.117188f, -0.171875f,0.117188f, -0.179688f,0.117188f, -0.1875f,0.117188f, -0.195313f,0.117188f, -0.203125f,0.117188f, -0.210938f,0.117188f, -0.21875f,0.117188f, -0.226563f,0.117188f, -0.234375f,0.117188f, -0.242188f,0.117188f, -0.25f,0.117188f, -0.257813f,0.117188f, -0.265625f,0.117188f, -0.273438f,0.117188f, -0.28125f,0.117188f, -0.289063f,0.117188f, -0.296875f,0.117188f, -0.304688f,0.117188f, -0.3125f,0.117188f, -0.320313f,0.117188f, -0.328125f,0.117188f, -0.335938f,0.117188f, -0.34375f,0.117188f, -0.351563f,0.117188f, -0.359375f,0.117188f, -0.367188f,0.117188f, -0.375f,0.117188f, -0.382813f,0.117188f, -0.390625f,0.117188f, -0.398438f,0.117188f, -0.40625f,0.117188f, -0.414063f,0.117188f, -0.421875f,0.117188f, -0.429688f,0.117188f, -0.4375f,0.117188f, -0.445313f,0.117188f, -0.453125f,0.117188f, -0.460938f,0.117188f, -0.46875f,0.117188f, -0.476563f,0.117188f, -0.484375f,0.117188f, -0.492188f,0.117188f, -0.5f,0.117188f, -0.507813f,0.117188f, -0.0f,0.125f, -0.0078125f,0.125f, -0.015625f,0.125f, -0.0234375f,0.125f, -0.03125f,0.125f, -0.0390625f,0.125f, -0.046875f,0.125f, -0.0546875f,0.125f, -0.0625f,0.125f, -0.0703125f,0.125f, -0.078125f,0.125f, -0.0859375f,0.125f, -0.09375f,0.125f, -0.101563f,0.125f, -0.109375f,0.125f, -0.117188f,0.125f, -0.125f,0.125f, -0.132813f,0.125f, -0.140625f,0.125f, -0.148438f,0.125f, -0.15625f,0.125f, -0.164063f,0.125f, -0.171875f,0.125f, -0.179688f,0.125f, -0.1875f,0.125f, -0.195313f,0.125f, -0.203125f,0.125f, -0.210938f,0.125f, -0.21875f,0.125f, -0.226563f,0.125f, -0.234375f,0.125f, -0.242188f,0.125f, -0.25f,0.125f, -0.257813f,0.125f, -0.265625f,0.125f, -0.273438f,0.125f, -0.28125f,0.125f, -0.289063f,0.125f, -0.296875f,0.125f, -0.304688f,0.125f, -0.3125f,0.125f, -0.320313f,0.125f, -0.328125f,0.125f, -0.335938f,0.125f, -0.34375f,0.125f, -0.351563f,0.125f, -0.359375f,0.125f, -0.367188f,0.125f, -0.375f,0.125f, -0.382813f,0.125f, -0.390625f,0.125f, -0.398438f,0.125f, -0.40625f,0.125f, -0.414063f,0.125f, -0.421875f,0.125f, -0.429688f,0.125f, -0.4375f,0.125f, -0.445313f,0.125f, -0.453125f,0.125f, -0.460938f,0.125f, -0.46875f,0.125f, -0.476563f,0.125f, -0.484375f,0.125f, -0.492188f,0.125f, -0.5f,0.125f, -0.507813f,0.125f, -0.0f,0.132813f, -0.0078125f,0.132813f, -0.015625f,0.132813f, -0.0234375f,0.132813f, -0.03125f,0.132813f, -0.0390625f,0.132813f, -0.046875f,0.132813f, -0.0546875f,0.132813f, -0.0625f,0.132813f, -0.0703125f,0.132813f, -0.078125f,0.132813f, -0.0859375f,0.132813f, -0.09375f,0.132813f, -0.101563f,0.132813f, -0.109375f,0.132813f, -0.117188f,0.132813f, -0.125f,0.132813f, -0.132813f,0.132813f, -0.140625f,0.132813f, -0.148438f,0.132813f, -0.15625f,0.132813f, -0.164063f,0.132813f, -0.171875f,0.132813f, -0.179688f,0.132813f, -0.1875f,0.132813f, -0.195313f,0.132813f, -0.203125f,0.132813f, -0.210938f,0.132813f, -0.21875f,0.132813f, -0.226563f,0.132813f, -0.234375f,0.132813f, -0.242188f,0.132813f, -0.25f,0.132813f, -0.257813f,0.132813f, -0.265625f,0.132813f, -0.273438f,0.132813f, -0.28125f,0.132813f, -0.289063f,0.132813f, -0.296875f,0.132813f, -0.304688f,0.132813f, -0.3125f,0.132813f, -0.320313f,0.132813f, -0.328125f,0.132813f, -0.335938f,0.132813f, -0.34375f,0.132813f, -0.351563f,0.132813f, -0.359375f,0.132813f, -0.367188f,0.132813f, -0.375f,0.132813f, -0.382813f,0.132813f, -0.390625f,0.132813f, -0.398438f,0.132813f, -0.40625f,0.132813f, -0.414063f,0.132813f, -0.421875f,0.132813f, -0.429688f,0.132813f, -0.4375f,0.132813f, -0.445313f,0.132813f, -0.453125f,0.132813f, -0.460938f,0.132813f, -0.46875f,0.132813f, -0.476563f,0.132813f, -0.484375f,0.132813f, -0.492188f,0.132813f, -0.5f,0.132813f, -0.507813f,0.132813f, -0.0f,0.140625f, -0.0078125f,0.140625f, -0.015625f,0.140625f, -0.0234375f,0.140625f, -0.03125f,0.140625f, -0.0390625f,0.140625f, -0.046875f,0.140625f, -0.0546875f,0.140625f, -0.0625f,0.140625f, -0.0703125f,0.140625f, -0.078125f,0.140625f, -0.0859375f,0.140625f, -0.09375f,0.140625f, -0.101563f,0.140625f, -0.109375f,0.140625f, -0.117188f,0.140625f, -0.125f,0.140625f, -0.132813f,0.140625f, -0.140625f,0.140625f, -0.148438f,0.140625f, -0.15625f,0.140625f, -0.164063f,0.140625f, -0.171875f,0.140625f, -0.179688f,0.140625f, -0.1875f,0.140625f, -0.195313f,0.140625f, -0.203125f,0.140625f, -0.210938f,0.140625f, -0.21875f,0.140625f, -0.226563f,0.140625f, -0.234375f,0.140625f, -0.242188f,0.140625f, -0.25f,0.140625f, -0.257813f,0.140625f, -0.265625f,0.140625f, -0.273438f,0.140625f, -0.28125f,0.140625f, -0.289063f,0.140625f, -0.296875f,0.140625f, -0.304688f,0.140625f, -0.3125f,0.140625f, -0.320313f,0.140625f, -0.328125f,0.140625f, -0.335938f,0.140625f, -0.34375f,0.140625f, -0.351563f,0.140625f, -0.359375f,0.140625f, -0.367188f,0.140625f, -0.375f,0.140625f, -0.382813f,0.140625f, -0.390625f,0.140625f, -0.398438f,0.140625f, -0.40625f,0.140625f, -0.414063f,0.140625f, -0.421875f,0.140625f, -0.429688f,0.140625f, -0.4375f,0.140625f, -0.445313f,0.140625f, -0.453125f,0.140625f, -0.460938f,0.140625f, -0.46875f,0.140625f, -0.476563f,0.140625f, -0.484375f,0.140625f, -0.492188f,0.140625f, -0.5f,0.140625f, -0.507813f,0.140625f, -0.0f,0.148438f, -0.0078125f,0.148438f, -0.015625f,0.148438f, -0.0234375f,0.148438f, -0.03125f,0.148438f, -0.0390625f,0.148438f, -0.046875f,0.148438f, -0.0546875f,0.148438f, -0.0625f,0.148438f, -0.0703125f,0.148438f, -0.078125f,0.148438f, -0.0859375f,0.148438f, -0.09375f,0.148438f, -0.101563f,0.148438f, -0.109375f,0.148438f, -0.117188f,0.148438f, -0.125f,0.148438f, -0.132813f,0.148438f, -0.140625f,0.148438f, -0.148438f,0.148438f, -0.15625f,0.148438f, -0.164063f,0.148438f, -0.171875f,0.148438f, -0.179688f,0.148438f, -0.1875f,0.148438f, -0.195313f,0.148438f, -0.203125f,0.148438f, -0.210938f,0.148438f, -0.21875f,0.148438f, -0.226563f,0.148438f, -0.234375f,0.148438f, -0.242188f,0.148438f, -0.25f,0.148438f, -0.257813f,0.148438f, -0.265625f,0.148438f, -0.273438f,0.148438f, -0.28125f,0.148438f, -0.289063f,0.148438f, -0.296875f,0.148438f, -0.304688f,0.148438f, -0.3125f,0.148438f, -0.320313f,0.148438f, -0.328125f,0.148438f, -0.335938f,0.148438f, -0.34375f,0.148438f, -0.351563f,0.148438f, -0.359375f,0.148438f, -0.367188f,0.148438f, -0.375f,0.148438f, -0.382813f,0.148438f, -0.390625f,0.148438f, -0.398438f,0.148438f, -0.40625f,0.148438f, -0.414063f,0.148438f, -0.421875f,0.148438f, -0.429688f,0.148438f, -0.4375f,0.148438f, -0.445313f,0.148438f, -0.453125f,0.148438f, -0.460938f,0.148438f, -0.46875f,0.148438f, -0.476563f,0.148438f, -0.484375f,0.148438f, -0.492188f,0.148438f, -0.5f,0.148438f, -0.507813f,0.148438f, -0.0f,0.15625f, -0.0078125f,0.15625f, -0.015625f,0.15625f, -0.0234375f,0.15625f, -0.03125f,0.15625f, -0.0390625f,0.15625f, -0.046875f,0.15625f, -0.0546875f,0.15625f, -0.0625f,0.15625f, -0.0703125f,0.15625f, -0.078125f,0.15625f, -0.0859375f,0.15625f, -0.09375f,0.15625f, -0.101563f,0.15625f, -0.109375f,0.15625f, -0.117188f,0.15625f, -0.125f,0.15625f, -0.132813f,0.15625f, -0.140625f,0.15625f, -0.148438f,0.15625f, -0.15625f,0.15625f, -0.164063f,0.15625f, -0.171875f,0.15625f, -0.179688f,0.15625f, -0.1875f,0.15625f, -0.195313f,0.15625f, -0.203125f,0.15625f, -0.210938f,0.15625f, -0.21875f,0.15625f, -0.226563f,0.15625f, -0.234375f,0.15625f, -0.242188f,0.15625f, -0.25f,0.15625f, -0.257813f,0.15625f, -0.265625f,0.15625f, -0.273438f,0.15625f, -0.28125f,0.15625f, -0.289063f,0.15625f, -0.296875f,0.15625f, -0.304688f,0.15625f, -0.3125f,0.15625f, -0.320313f,0.15625f, -0.328125f,0.15625f, -0.335938f,0.15625f, -0.34375f,0.15625f, -0.351563f,0.15625f, -0.359375f,0.15625f, -0.367188f,0.15625f, -0.375f,0.15625f, -0.382813f,0.15625f, -0.390625f,0.15625f, -0.398438f,0.15625f, -0.40625f,0.15625f, -0.414063f,0.15625f, -0.421875f,0.15625f, -0.429688f,0.15625f, -0.4375f,0.15625f, -0.445313f,0.15625f, -0.453125f,0.15625f, -0.460938f,0.15625f, -0.46875f,0.15625f, -0.476563f,0.15625f, -0.484375f,0.15625f, -0.492188f,0.15625f, -0.5f,0.15625f, -0.507813f,0.15625f, -0.0f,0.164063f, -0.0078125f,0.164063f, -0.015625f,0.164063f, -0.0234375f,0.164063f, -0.03125f,0.164063f, -0.0390625f,0.164063f, -0.046875f,0.164063f, -0.0546875f,0.164063f, -0.0625f,0.164063f, -0.0703125f,0.164063f, -0.078125f,0.164063f, -0.0859375f,0.164063f, -0.09375f,0.164063f, -0.101563f,0.164063f, -0.109375f,0.164063f, -0.117188f,0.164063f, -0.125f,0.164063f, -0.132813f,0.164063f, -0.140625f,0.164063f, -0.148438f,0.164063f, -0.15625f,0.164063f, -0.164063f,0.164063f, -0.171875f,0.164063f, -0.179688f,0.164063f, -0.1875f,0.164063f, -0.195313f,0.164063f, -0.203125f,0.164063f, -0.210938f,0.164063f, -0.21875f,0.164063f, -0.226563f,0.164063f, -0.234375f,0.164063f, -0.242188f,0.164063f, -0.25f,0.164063f, -0.257813f,0.164063f, -0.265625f,0.164063f, -0.273438f,0.164063f, -0.28125f,0.164063f, -0.289063f,0.164063f, -0.296875f,0.164063f, -0.304688f,0.164063f, -0.3125f,0.164063f, -0.320313f,0.164063f, -0.328125f,0.164063f, -0.335938f,0.164063f, -0.34375f,0.164063f, -0.351563f,0.164063f, -0.359375f,0.164063f, -0.367188f,0.164063f, -0.375f,0.164063f, -0.382813f,0.164063f, -0.390625f,0.164063f, -0.398438f,0.164063f, -0.40625f,0.164063f, -0.414063f,0.164063f, -0.421875f,0.164063f, -0.429688f,0.164063f, -0.4375f,0.164063f, -0.445313f,0.164063f, -0.453125f,0.164063f, -0.460938f,0.164063f, -0.46875f,0.164063f, -0.476563f,0.164063f, -0.484375f,0.164063f, -0.492188f,0.164063f, -0.5f,0.164063f, -0.507813f,0.164063f, -0.0f,0.171875f, -0.0078125f,0.171875f, -0.015625f,0.171875f, -0.0234375f,0.171875f, -0.03125f,0.171875f, -0.0390625f,0.171875f, -0.046875f,0.171875f, -0.0546875f,0.171875f, -0.0625f,0.171875f, -0.0703125f,0.171875f, -0.078125f,0.171875f, -0.0859375f,0.171875f, -0.09375f,0.171875f, -0.101563f,0.171875f, -0.109375f,0.171875f, -0.117188f,0.171875f, -0.125f,0.171875f, -0.132813f,0.171875f, -0.140625f,0.171875f, -0.148438f,0.171875f, -0.15625f,0.171875f, -0.164063f,0.171875f, -0.171875f,0.171875f, -0.179688f,0.171875f, -0.1875f,0.171875f, -0.195313f,0.171875f, -0.203125f,0.171875f, -0.210938f,0.171875f, -0.21875f,0.171875f, -0.226563f,0.171875f, -0.234375f,0.171875f, -0.242188f,0.171875f, -0.25f,0.171875f, -0.257813f,0.171875f, -0.265625f,0.171875f, -0.273438f,0.171875f, -0.28125f,0.171875f, -0.289063f,0.171875f, -0.296875f,0.171875f, -0.304688f,0.171875f, -0.3125f,0.171875f, -0.320313f,0.171875f, -0.328125f,0.171875f, -0.335938f,0.171875f, -0.34375f,0.171875f, -0.351563f,0.171875f, -0.359375f,0.171875f, -0.367188f,0.171875f, -0.375f,0.171875f, -0.382813f,0.171875f, -0.390625f,0.171875f, -0.398438f,0.171875f, -0.40625f,0.171875f, -0.414063f,0.171875f, -0.421875f,0.171875f, -0.429688f,0.171875f, -0.4375f,0.171875f, -0.445313f,0.171875f, -0.453125f,0.171875f, -0.460938f,0.171875f, -0.46875f,0.171875f, -0.476563f,0.171875f, -0.484375f,0.171875f, -0.492188f,0.171875f, -0.5f,0.171875f, -0.507813f,0.171875f, -0.0f,0.179688f, -0.0078125f,0.179688f, -0.015625f,0.179688f, -0.0234375f,0.179688f, -0.03125f,0.179688f, -0.0390625f,0.179688f, -0.046875f,0.179688f, -0.0546875f,0.179688f, -0.0625f,0.179688f, -0.0703125f,0.179688f, -0.078125f,0.179688f, -0.0859375f,0.179688f, -0.09375f,0.179688f, -0.101563f,0.179688f, -0.109375f,0.179688f, -0.117188f,0.179688f, -0.125f,0.179688f, -0.132813f,0.179688f, -0.140625f,0.179688f, -0.148438f,0.179688f, -0.15625f,0.179688f, -0.164063f,0.179688f, -0.171875f,0.179688f, -0.179688f,0.179688f, -0.1875f,0.179688f, -0.195313f,0.179688f, -0.203125f,0.179688f, -0.210938f,0.179688f, -0.21875f,0.179688f, -0.226563f,0.179688f, -0.234375f,0.179688f, -0.242188f,0.179688f, -0.25f,0.179688f, -0.257813f,0.179688f, -0.265625f,0.179688f, -0.273438f,0.179688f, -0.28125f,0.179688f, -0.289063f,0.179688f, -0.296875f,0.179688f, -0.304688f,0.179688f, -0.3125f,0.179688f, -0.320313f,0.179688f, -0.328125f,0.179688f, -0.335938f,0.179688f, -0.34375f,0.179688f, -0.351563f,0.179688f, -0.359375f,0.179688f, -0.367188f,0.179688f, -0.375f,0.179688f, -0.382813f,0.179688f, -0.390625f,0.179688f, -0.398438f,0.179688f, -0.40625f,0.179688f, -0.414063f,0.179688f, -0.421875f,0.179688f, -0.429688f,0.179688f, -0.4375f,0.179688f, -0.445313f,0.179688f, -0.453125f,0.179688f, -0.460938f,0.179688f, -0.46875f,0.179688f, -0.476563f,0.179688f, -0.484375f,0.179688f, -0.492188f,0.179688f, -0.5f,0.179688f, -0.507813f,0.179688f, -0.0f,0.1875f, -0.0078125f,0.1875f, -0.015625f,0.1875f, -0.0234375f,0.1875f, -0.03125f,0.1875f, -0.0390625f,0.1875f, -0.046875f,0.1875f, -0.0546875f,0.1875f, -0.0625f,0.1875f, -0.0703125f,0.1875f, -0.078125f,0.1875f, -0.0859375f,0.1875f, -0.09375f,0.1875f, -0.101563f,0.1875f, -0.109375f,0.1875f, -0.117188f,0.1875f, -0.125f,0.1875f, -0.132813f,0.1875f, -0.140625f,0.1875f, -0.148438f,0.1875f, -0.15625f,0.1875f, -0.164063f,0.1875f, -0.171875f,0.1875f, -0.179688f,0.1875f, -0.1875f,0.1875f, -0.195313f,0.1875f, -0.203125f,0.1875f, -0.210938f,0.1875f, -0.21875f,0.1875f, -0.226563f,0.1875f, -0.234375f,0.1875f, -0.242188f,0.1875f, -0.25f,0.1875f, -0.257813f,0.1875f, -0.265625f,0.1875f, -0.273438f,0.1875f, -0.28125f,0.1875f, -0.289063f,0.1875f, -0.296875f,0.1875f, -0.304688f,0.1875f, -0.3125f,0.1875f, -0.320313f,0.1875f, -0.328125f,0.1875f, -0.335938f,0.1875f, -0.34375f,0.1875f, -0.351563f,0.1875f, -0.359375f,0.1875f, -0.367188f,0.1875f, -0.375f,0.1875f, -0.382813f,0.1875f, -0.390625f,0.1875f, -0.398438f,0.1875f, -0.40625f,0.1875f, -0.414063f,0.1875f, -0.421875f,0.1875f, -0.429688f,0.1875f, -0.4375f,0.1875f, -0.445313f,0.1875f, -0.453125f,0.1875f, -0.460938f,0.1875f, -0.46875f,0.1875f, -0.476563f,0.1875f, -0.484375f,0.1875f, -0.492188f,0.1875f, -0.5f,0.1875f, -0.507813f,0.1875f, -0.0f,0.195313f, -0.0078125f,0.195313f, -0.015625f,0.195313f, -0.0234375f,0.195313f, -0.03125f,0.195313f, -0.0390625f,0.195313f, -0.046875f,0.195313f, -0.0546875f,0.195313f, -0.0625f,0.195313f, -0.0703125f,0.195313f, -0.078125f,0.195313f, -0.0859375f,0.195313f, -0.09375f,0.195313f, -0.101563f,0.195313f, -0.109375f,0.195313f, -0.117188f,0.195313f, -0.125f,0.195313f, -0.132813f,0.195313f, -0.140625f,0.195313f, -0.148438f,0.195313f, -0.15625f,0.195313f, -0.164063f,0.195313f, -0.171875f,0.195313f, -0.179688f,0.195313f, -0.1875f,0.195313f, -0.195313f,0.195313f, -0.203125f,0.195313f, -0.210938f,0.195313f, -0.21875f,0.195313f, -0.226563f,0.195313f, -0.234375f,0.195313f, -0.242188f,0.195313f, -0.25f,0.195313f, -0.257813f,0.195313f, -0.265625f,0.195313f, -0.273438f,0.195313f, -0.28125f,0.195313f, -0.289063f,0.195313f, -0.296875f,0.195313f, -0.304688f,0.195313f, -0.3125f,0.195313f, -0.320313f,0.195313f, -0.328125f,0.195313f, -0.335938f,0.195313f, -0.34375f,0.195313f, -0.351563f,0.195313f, -0.359375f,0.195313f, -0.367188f,0.195313f, -0.375f,0.195313f, -0.382813f,0.195313f, -0.390625f,0.195313f, -0.398438f,0.195313f, -0.40625f,0.195313f, -0.414063f,0.195313f, -0.421875f,0.195313f, -0.429688f,0.195313f, -0.4375f,0.195313f, -0.445313f,0.195313f, -0.453125f,0.195313f, -0.460938f,0.195313f, -0.46875f,0.195313f, -0.476563f,0.195313f, -0.484375f,0.195313f, -0.492188f,0.195313f, -0.5f,0.195313f, -0.507813f,0.195313f, -0.0f,0.203125f, -0.0078125f,0.203125f, -0.015625f,0.203125f, -0.0234375f,0.203125f, -0.03125f,0.203125f, -0.0390625f,0.203125f, -0.046875f,0.203125f, -0.0546875f,0.203125f, -0.0625f,0.203125f, -0.0703125f,0.203125f, -0.078125f,0.203125f, -0.0859375f,0.203125f, -0.09375f,0.203125f, -0.101563f,0.203125f, -0.109375f,0.203125f, -0.117188f,0.203125f, -0.125f,0.203125f, -0.132813f,0.203125f, -0.140625f,0.203125f, -0.148438f,0.203125f, -0.15625f,0.203125f, -0.164063f,0.203125f, -0.171875f,0.203125f, -0.179688f,0.203125f, -0.1875f,0.203125f, -0.195313f,0.203125f, -0.203125f,0.203125f, -0.210938f,0.203125f, -0.21875f,0.203125f, -0.226563f,0.203125f, -0.234375f,0.203125f, -0.242188f,0.203125f, -0.25f,0.203125f, -0.257813f,0.203125f, -0.265625f,0.203125f, -0.273438f,0.203125f, -0.28125f,0.203125f, -0.289063f,0.203125f, -0.296875f,0.203125f, -0.304688f,0.203125f, -0.3125f,0.203125f, -0.320313f,0.203125f, -0.328125f,0.203125f, -0.335938f,0.203125f, -0.34375f,0.203125f, -0.351563f,0.203125f, -0.359375f,0.203125f, -0.367188f,0.203125f, -0.375f,0.203125f, -0.382813f,0.203125f, -0.390625f,0.203125f, -0.398438f,0.203125f, -0.40625f,0.203125f, -0.414063f,0.203125f, -0.421875f,0.203125f, -0.429688f,0.203125f, -0.4375f,0.203125f, -0.445313f,0.203125f, -0.453125f,0.203125f, -0.460938f,0.203125f, -0.46875f,0.203125f, -0.476563f,0.203125f, -0.484375f,0.203125f, -0.492188f,0.203125f, -0.5f,0.203125f, -0.507813f,0.203125f, -0.0f,0.210938f, -0.0078125f,0.210938f, -0.015625f,0.210938f, -0.0234375f,0.210938f, -0.03125f,0.210938f, -0.0390625f,0.210938f, -0.046875f,0.210938f, -0.0546875f,0.210938f, -0.0625f,0.210938f, -0.0703125f,0.210938f, -0.078125f,0.210938f, -0.0859375f,0.210938f, -0.09375f,0.210938f, -0.101563f,0.210938f, -0.109375f,0.210938f, -0.117188f,0.210938f, -0.125f,0.210938f, -0.132813f,0.210938f, -0.140625f,0.210938f, -0.148438f,0.210938f, -0.15625f,0.210938f, -0.164063f,0.210938f, -0.171875f,0.210938f, -0.179688f,0.210938f, -0.1875f,0.210938f, -0.195313f,0.210938f, -0.203125f,0.210938f, -0.210938f,0.210938f, -0.21875f,0.210938f, -0.226563f,0.210938f, -0.234375f,0.210938f, -0.242188f,0.210938f, -0.25f,0.210938f, -0.257813f,0.210938f, -0.265625f,0.210938f, -0.273438f,0.210938f, -0.28125f,0.210938f, -0.289063f,0.210938f, -0.296875f,0.210938f, -0.304688f,0.210938f, -0.3125f,0.210938f, -0.320313f,0.210938f, -0.328125f,0.210938f, -0.335938f,0.210938f, -0.34375f,0.210938f, -0.351563f,0.210938f, -0.359375f,0.210938f, -0.367188f,0.210938f, -0.375f,0.210938f, -0.382813f,0.210938f, -0.390625f,0.210938f, -0.398438f,0.210938f, -0.40625f,0.210938f, -0.414063f,0.210938f, -0.421875f,0.210938f, -0.429688f,0.210938f, -0.4375f,0.210938f, -0.445313f,0.210938f, -0.453125f,0.210938f, -0.460938f,0.210938f, -0.46875f,0.210938f, -0.476563f,0.210938f, -0.484375f,0.210938f, -0.492188f,0.210938f, -0.5f,0.210938f, -0.507813f,0.210938f, -0.0f,0.21875f, -0.0078125f,0.21875f, -0.015625f,0.21875f, -0.0234375f,0.21875f, -0.03125f,0.21875f, -0.0390625f,0.21875f, -0.046875f,0.21875f, -0.0546875f,0.21875f, -0.0625f,0.21875f, -0.0703125f,0.21875f, -0.078125f,0.21875f, -0.0859375f,0.21875f, -0.09375f,0.21875f, -0.101563f,0.21875f, -0.109375f,0.21875f, -0.117188f,0.21875f, -0.125f,0.21875f, -0.132813f,0.21875f, -0.140625f,0.21875f, -0.148438f,0.21875f, -0.15625f,0.21875f, -0.164063f,0.21875f, -0.171875f,0.21875f, -0.179688f,0.21875f, -0.1875f,0.21875f, -0.195313f,0.21875f, -0.203125f,0.21875f, -0.210938f,0.21875f, -0.21875f,0.21875f, -0.226563f,0.21875f, -0.234375f,0.21875f, -0.242188f,0.21875f, -0.25f,0.21875f, -0.257813f,0.21875f, -0.265625f,0.21875f, -0.273438f,0.21875f, -0.28125f,0.21875f, -0.289063f,0.21875f, -0.296875f,0.21875f, -0.304688f,0.21875f, -0.3125f,0.21875f, -0.320313f,0.21875f, -0.328125f,0.21875f, -0.335938f,0.21875f, -0.34375f,0.21875f, -0.351563f,0.21875f, -0.359375f,0.21875f, -0.367188f,0.21875f, -0.375f,0.21875f, -0.382813f,0.21875f, -0.390625f,0.21875f, -0.398438f,0.21875f, -0.40625f,0.21875f, -0.414063f,0.21875f, -0.421875f,0.21875f, -0.429688f,0.21875f, -0.4375f,0.21875f, -0.445313f,0.21875f, -0.453125f,0.21875f, -0.460938f,0.21875f, -0.46875f,0.21875f, -0.476563f,0.21875f, -0.484375f,0.21875f, -0.492188f,0.21875f, -0.5f,0.21875f, -0.507813f,0.21875f, -0.0f,0.226563f, -0.0078125f,0.226563f, -0.015625f,0.226563f, -0.0234375f,0.226563f, -0.03125f,0.226563f, -0.0390625f,0.226563f, -0.046875f,0.226563f, -0.0546875f,0.226563f, -0.0625f,0.226563f, -0.0703125f,0.226563f, -0.078125f,0.226563f, -0.0859375f,0.226563f, -0.09375f,0.226563f, -0.101563f,0.226563f, -0.109375f,0.226563f, -0.117188f,0.226563f, -0.125f,0.226563f, -0.132813f,0.226563f, -0.140625f,0.226563f, -0.148438f,0.226563f, -0.15625f,0.226563f, -0.164063f,0.226563f, -0.171875f,0.226563f, -0.179688f,0.226563f, -0.1875f,0.226563f, -0.195313f,0.226563f, -0.203125f,0.226563f, -0.210938f,0.226563f, -0.21875f,0.226563f, -0.226563f,0.226563f, -0.234375f,0.226563f, -0.242188f,0.226563f, -0.25f,0.226563f, -0.257813f,0.226563f, -0.265625f,0.226563f, -0.273438f,0.226563f, -0.28125f,0.226563f, -0.289063f,0.226563f, -0.296875f,0.226563f, -0.304688f,0.226563f, -0.3125f,0.226563f, -0.320313f,0.226563f, -0.328125f,0.226563f, -0.335938f,0.226563f, -0.34375f,0.226563f, -0.351563f,0.226563f, -0.359375f,0.226563f, -0.367188f,0.226563f, -0.375f,0.226563f, -0.382813f,0.226563f, -0.390625f,0.226563f, -0.398438f,0.226563f, -0.40625f,0.226563f, -0.414063f,0.226563f, -0.421875f,0.226563f, -0.429688f,0.226563f, -0.4375f,0.226563f, -0.445313f,0.226563f, -0.453125f,0.226563f, -0.460938f,0.226563f, -0.46875f,0.226563f, -0.476563f,0.226563f, -0.484375f,0.226563f, -0.492188f,0.226563f, -0.5f,0.226563f, -0.507813f,0.226563f, -0.0f,0.234375f, -0.0078125f,0.234375f, -0.015625f,0.234375f, -0.0234375f,0.234375f, -0.03125f,0.234375f, -0.0390625f,0.234375f, -0.046875f,0.234375f, -0.0546875f,0.234375f, -0.0625f,0.234375f, -0.0703125f,0.234375f, -0.078125f,0.234375f, -0.0859375f,0.234375f, -0.09375f,0.234375f, -0.101563f,0.234375f, -0.109375f,0.234375f, -0.117188f,0.234375f, -0.125f,0.234375f, -0.132813f,0.234375f, -0.140625f,0.234375f, -0.148438f,0.234375f, -0.15625f,0.234375f, -0.164063f,0.234375f, -0.171875f,0.234375f, -0.179688f,0.234375f, -0.1875f,0.234375f, -0.195313f,0.234375f, -0.203125f,0.234375f, -0.210938f,0.234375f, -0.21875f,0.234375f, -0.226563f,0.234375f, -0.234375f,0.234375f, -0.242188f,0.234375f, -0.25f,0.234375f, -0.257813f,0.234375f, -0.265625f,0.234375f, -0.273438f,0.234375f, -0.28125f,0.234375f, -0.289063f,0.234375f, -0.296875f,0.234375f, -0.304688f,0.234375f, -0.3125f,0.234375f, -0.320313f,0.234375f, -0.328125f,0.234375f, -0.335938f,0.234375f, -0.34375f,0.234375f, -0.351563f,0.234375f, -0.359375f,0.234375f, -0.367188f,0.234375f, -0.375f,0.234375f, -0.382813f,0.234375f, -0.390625f,0.234375f, -0.398438f,0.234375f, -0.40625f,0.234375f, -0.414063f,0.234375f, -0.421875f,0.234375f, -0.429688f,0.234375f, -0.4375f,0.234375f, -0.445313f,0.234375f, -0.453125f,0.234375f, -0.460938f,0.234375f, -0.46875f,0.234375f, -0.476563f,0.234375f, -0.484375f,0.234375f, -0.492188f,0.234375f, -0.5f,0.234375f, -0.507813f,0.234375f, -0.0f,0.242188f, -0.0078125f,0.242188f, -0.015625f,0.242188f, -0.0234375f,0.242188f, -0.03125f,0.242188f, -0.0390625f,0.242188f, -0.046875f,0.242188f, -0.0546875f,0.242188f, -0.0625f,0.242188f, -0.0703125f,0.242188f, -0.078125f,0.242188f, -0.0859375f,0.242188f, -0.09375f,0.242188f, -0.101563f,0.242188f, -0.109375f,0.242188f, -0.117188f,0.242188f, -0.125f,0.242188f, -0.132813f,0.242188f, -0.140625f,0.242188f, -0.148438f,0.242188f, -0.15625f,0.242188f, -0.164063f,0.242188f, -0.171875f,0.242188f, -0.179688f,0.242188f, -0.1875f,0.242188f, -0.195313f,0.242188f, -0.203125f,0.242188f, -0.210938f,0.242188f, -0.21875f,0.242188f, -0.226563f,0.242188f, -0.234375f,0.242188f, -0.242188f,0.242188f, -0.25f,0.242188f, -0.257813f,0.242188f, -0.265625f,0.242188f, -0.273438f,0.242188f, -0.28125f,0.242188f, -0.289063f,0.242188f, -0.296875f,0.242188f, -0.304688f,0.242188f, -0.3125f,0.242188f, -0.320313f,0.242188f, -0.328125f,0.242188f, -0.335938f,0.242188f, -0.34375f,0.242188f, -0.351563f,0.242188f, -0.359375f,0.242188f, -0.367188f,0.242188f, -0.375f,0.242188f, -0.382813f,0.242188f, -0.390625f,0.242188f, -0.398438f,0.242188f, -0.40625f,0.242188f, -0.414063f,0.242188f, -0.421875f,0.242188f, -0.429688f,0.242188f, -0.4375f,0.242188f, -0.445313f,0.242188f, -0.453125f,0.242188f, -0.460938f,0.242188f, -0.46875f,0.242188f, -0.476563f,0.242188f, -0.484375f,0.242188f, -0.492188f,0.242188f, -0.5f,0.242188f, -0.507813f,0.242188f, -0.0f,0.25f, -0.0078125f,0.25f, -0.015625f,0.25f, -0.0234375f,0.25f, -0.03125f,0.25f, -0.0390625f,0.25f, -0.046875f,0.25f, -0.0546875f,0.25f, -0.0625f,0.25f, -0.0703125f,0.25f, -0.078125f,0.25f, -0.0859375f,0.25f, -0.09375f,0.25f, -0.101563f,0.25f, -0.109375f,0.25f, -0.117188f,0.25f, -0.125f,0.25f, -0.132813f,0.25f, -0.140625f,0.25f, -0.148438f,0.25f, -0.15625f,0.25f, -0.164063f,0.25f, -0.171875f,0.25f, -0.179688f,0.25f, -0.1875f,0.25f, -0.195313f,0.25f, -0.203125f,0.25f, -0.210938f,0.25f, -0.21875f,0.25f, -0.226563f,0.25f, -0.234375f,0.25f, -0.242188f,0.25f, -0.25f,0.25f, -0.257813f,0.25f, -0.265625f,0.25f, -0.273438f,0.25f, -0.28125f,0.25f, -0.289063f,0.25f, -0.296875f,0.25f, -0.304688f,0.25f, -0.3125f,0.25f, -0.320313f,0.25f, -0.328125f,0.25f, -0.335938f,0.25f, -0.34375f,0.25f, -0.351563f,0.25f, -0.359375f,0.25f, -0.367188f,0.25f, -0.375f,0.25f, -0.382813f,0.25f, -0.390625f,0.25f, -0.398438f,0.25f, -0.40625f,0.25f, -0.414063f,0.25f, -0.421875f,0.25f, -0.429688f,0.25f, -0.4375f,0.25f, -0.445313f,0.25f, -0.453125f,0.25f, -0.460938f,0.25f, -0.46875f,0.25f, -0.476563f,0.25f, -0.484375f,0.25f, -0.492188f,0.25f, -0.5f,0.25f, -0.507813f,0.25f, -0.0f,0.257813f, -0.0078125f,0.257813f, -0.015625f,0.257813f, -0.0234375f,0.257813f, -0.03125f,0.257813f, -0.0390625f,0.257813f, -0.046875f,0.257813f, -0.0546875f,0.257813f, -0.0625f,0.257813f, -0.0703125f,0.257813f, -0.078125f,0.257813f, -0.0859375f,0.257813f, -0.09375f,0.257813f, -0.101563f,0.257813f, -0.109375f,0.257813f, -0.117188f,0.257813f, -0.125f,0.257813f, -0.132813f,0.257813f, -0.140625f,0.257813f, -0.148438f,0.257813f, -0.15625f,0.257813f, -0.164063f,0.257813f, -0.171875f,0.257813f, -0.179688f,0.257813f, -0.1875f,0.257813f, -0.195313f,0.257813f, -0.203125f,0.257813f, -0.210938f,0.257813f, -0.21875f,0.257813f, -0.226563f,0.257813f, -0.234375f,0.257813f, -0.242188f,0.257813f, -0.25f,0.257813f, -0.257813f,0.257813f, -0.265625f,0.257813f, -0.273438f,0.257813f, -0.28125f,0.257813f, -0.289063f,0.257813f, -0.296875f,0.257813f, -0.304688f,0.257813f, -0.3125f,0.257813f, -0.320313f,0.257813f, -0.328125f,0.257813f, -0.335938f,0.257813f, -0.34375f,0.257813f, -0.351563f,0.257813f, -0.359375f,0.257813f, -0.367188f,0.257813f, -0.375f,0.257813f, -0.382813f,0.257813f, -0.390625f,0.257813f, -0.398438f,0.257813f, -0.40625f,0.257813f, -0.414063f,0.257813f, -0.421875f,0.257813f, -0.429688f,0.257813f, -0.4375f,0.257813f, -0.445313f,0.257813f, -0.453125f,0.257813f, -0.460938f,0.257813f, -0.46875f,0.257813f, -0.476563f,0.257813f, -0.484375f,0.257813f, -0.492188f,0.257813f, -0.5f,0.257813f, -0.507813f,0.257813f, -0.0f,0.265625f, -0.0078125f,0.265625f, -0.015625f,0.265625f, -0.0234375f,0.265625f, -0.03125f,0.265625f, -0.0390625f,0.265625f, -0.046875f,0.265625f, -0.0546875f,0.265625f, -0.0625f,0.265625f, -0.0703125f,0.265625f, -0.078125f,0.265625f, -0.0859375f,0.265625f, -0.09375f,0.265625f, -0.101563f,0.265625f, -0.109375f,0.265625f, -0.117188f,0.265625f, -0.125f,0.265625f, -0.132813f,0.265625f, -0.140625f,0.265625f, -0.148438f,0.265625f, -0.15625f,0.265625f, -0.164063f,0.265625f, -0.171875f,0.265625f, -0.179688f,0.265625f, -0.1875f,0.265625f, -0.195313f,0.265625f, -0.203125f,0.265625f, -0.210938f,0.265625f, -0.21875f,0.265625f, -0.226563f,0.265625f, -0.234375f,0.265625f, -0.242188f,0.265625f, -0.25f,0.265625f, -0.257813f,0.265625f, -0.265625f,0.265625f, -0.273438f,0.265625f, -0.28125f,0.265625f, -0.289063f,0.265625f, -0.296875f,0.265625f, -0.304688f,0.265625f, -0.3125f,0.265625f, -0.320313f,0.265625f, -0.328125f,0.265625f, -0.335938f,0.265625f, -0.34375f,0.265625f, -0.351563f,0.265625f, -0.359375f,0.265625f, -0.367188f,0.265625f, -0.375f,0.265625f, -0.382813f,0.265625f, -0.390625f,0.265625f, -0.398438f,0.265625f, -0.40625f,0.265625f, -0.414063f,0.265625f, -0.421875f,0.265625f, -0.429688f,0.265625f, -0.4375f,0.265625f, -0.445313f,0.265625f, -0.453125f,0.265625f, -0.460938f,0.265625f, -0.46875f,0.265625f, -0.476563f,0.265625f, -0.484375f,0.265625f, -0.492188f,0.265625f, -0.5f,0.265625f, -0.507813f,0.265625f, -}; - -unsigned short Landscape06Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -126,127,128, -129,128,127, -128,129,130, -131,130,129, -132,0,133, -2,133,0, -133,2,134, -4,134,2, -134,4,135, -6,135,4, -135,6,136, -8,136,6, -136,8,137, -10,137,8, -137,10,138, -12,138,10, -138,12,139, -14,139,12, -139,14,140, -16,140,14, -140,16,141, -18,141,16, -141,18,142, -20,142,18, -142,20,143, -22,143,20, -143,22,144, -24,144,22, -144,24,145, -26,145,24, -145,26,146, -28,146,26, -146,28,147, -30,147,28, -147,30,148, -32,148,30, -148,32,149, -34,149,32, -149,34,150, -36,150,34, -150,36,151, -38,151,36, -151,38,152, -40,152,38, -152,40,153, -42,153,40, -153,42,154, -44,154,42, -154,44,155, -46,155,44, -155,46,156, -48,156,46, -156,48,157, -50,157,48, -157,50,158, -52,158,50, -158,52,159, -54,159,52, -159,54,160, -56,160,54, -160,56,161, -58,161,56, -161,58,162, -60,162,58, -162,60,163, -62,163,60, -163,62,164, -64,164,62, -164,64,165, -66,165,64, -165,66,166, -68,166,66, -166,68,167, -70,167,68, -167,70,168, -72,168,70, -168,72,169, -74,169,72, -169,74,170, -76,170,74, -170,76,171, -78,171,76, -171,78,172, -80,172,78, -172,80,173, -82,173,80, -173,82,174, -84,174,82, -174,84,175, -86,175,84, -175,86,176, -88,176,86, -176,88,177, -90,177,88, -177,90,178, -92,178,90, -178,92,179, -94,179,92, -179,94,180, -96,180,94, -180,96,181, -98,181,96, -181,98,182, -100,182,98, -182,100,183, -102,183,100, -183,102,184, -104,184,102, -184,104,185, -106,185,104, -185,106,186, -108,186,106, -186,108,187, -110,187,108, -187,110,188, -112,188,110, -188,112,189, -114,189,112, -189,114,190, -116,190,114, -190,116,191, -118,191,116, -191,118,192, -120,192,118, -192,120,193, -122,193,120, -193,122,194, -124,194,122, -194,124,195, -126,195,124, -195,126,196, -128,196,126, -196,128,197, -130,197,128, -198,132,199, -133,199,132, -199,133,200, -134,200,133, -200,134,201, -135,201,134, -201,135,202, -136,202,135, -202,136,203, -137,203,136, -203,137,204, -138,204,137, -204,138,205, -139,205,138, -205,139,206, -140,206,139, -206,140,207, -141,207,140, -207,141,208, -142,208,141, -208,142,209, -143,209,142, -209,143,210, -144,210,143, -210,144,211, -145,211,144, -211,145,212, -146,212,145, -212,146,213, -147,213,146, -213,147,214, -148,214,147, -214,148,215, -149,215,148, -215,149,216, -150,216,149, -216,150,217, -151,217,150, -217,151,218, -152,218,151, -218,152,219, -153,219,152, -219,153,220, -154,220,153, -220,154,221, -155,221,154, -221,155,222, -156,222,155, -222,156,223, -157,223,156, -223,157,224, -158,224,157, -224,158,225, -159,225,158, -225,159,226, -160,226,159, -226,160,227, -161,227,160, -227,161,228, -162,228,161, -228,162,229, -163,229,162, -229,163,230, -164,230,163, -230,164,231, -165,231,164, -231,165,232, -166,232,165, -232,166,233, -167,233,166, -233,167,234, -168,234,167, -234,168,235, -169,235,168, -235,169,236, -170,236,169, -236,170,237, -171,237,170, -237,171,238, -172,238,171, -238,172,239, -173,239,172, -239,173,240, -174,240,173, -240,174,241, -175,241,174, -241,175,242, -176,242,175, -242,176,243, -177,243,176, -243,177,244, -178,244,177, -244,178,245, -179,245,178, -245,179,246, -180,246,179, -246,180,247, -181,247,180, -247,181,248, -182,248,181, -248,182,249, -183,249,182, -249,183,250, -184,250,183, -250,184,251, -185,251,184, -251,185,252, -186,252,185, -252,186,253, -187,253,186, -253,187,254, -188,254,187, -254,188,255, -189,255,188, -255,189,256, -190,256,189, -256,190,257, -191,257,190, -257,191,258, -192,258,191, -258,192,259, -193,259,192, -259,193,260, -194,260,193, -260,194,261, -195,261,194, -261,195,262, -196,262,195, -262,196,263, -197,263,196, -264,198,265, -199,265,198, -265,199,266, -200,266,199, -266,200,267, -201,267,200, -267,201,268, -202,268,201, -268,202,269, -203,269,202, -269,203,270, -204,270,203, -270,204,271, -205,271,204, -271,205,272, -206,272,205, -272,206,273, -207,273,206, -273,207,274, -208,274,207, -274,208,275, -209,275,208, -275,209,276, -210,276,209, -276,210,277, -211,277,210, -277,211,278, -212,278,211, -278,212,279, -213,279,212, -279,213,280, -214,280,213, -280,214,281, -215,281,214, -281,215,282, -216,282,215, -282,216,283, -217,283,216, -283,217,284, -218,284,217, -284,218,285, -219,285,218, -285,219,286, -220,286,219, -286,220,287, -221,287,220, -287,221,288, -222,288,221, -288,222,289, -223,289,222, -289,223,290, -224,290,223, -290,224,291, -225,291,224, -291,225,292, -226,292,225, -292,226,293, -227,293,226, -293,227,294, -228,294,227, -294,228,295, -229,295,228, -295,229,296, -230,296,229, -296,230,297, -231,297,230, -297,231,298, -232,298,231, -298,232,299, -233,299,232, -299,233,300, -234,300,233, -300,234,301, -235,301,234, -301,235,302, -236,302,235, -302,236,303, -237,303,236, -303,237,304, -238,304,237, -304,238,305, -239,305,238, -305,239,306, -240,306,239, -306,240,307, -241,307,240, -307,241,308, -242,308,241, -308,242,309, -243,309,242, -309,243,310, -244,310,243, -310,244,311, -245,311,244, -311,245,312, -246,312,245, -312,246,313, -247,313,246, -313,247,314, -248,314,247, -314,248,315, -249,315,248, -315,249,316, -250,316,249, -316,250,317, -251,317,250, -317,251,318, -252,318,251, -318,252,319, -253,319,252, -319,253,320, -254,320,253, -320,254,321, -255,321,254, -321,255,322, -256,322,255, -322,256,323, -257,323,256, -323,257,324, -258,324,257, -324,258,325, -259,325,258, -325,259,326, -260,326,259, -326,260,327, -261,327,260, -327,261,328, -262,328,261, -328,262,329, -263,329,262, -330,264,331, -265,331,264, -331,265,332, -266,332,265, -332,266,333, -267,333,266, -333,267,334, -268,334,267, -334,268,335, -269,335,268, -335,269,336, -270,336,269, -336,270,337, -271,337,270, -337,271,338, -272,338,271, -338,272,339, -273,339,272, -339,273,340, -274,340,273, -340,274,341, -275,341,274, -341,275,342, -276,342,275, -342,276,343, -277,343,276, -343,277,344, -278,344,277, -344,278,345, -279,345,278, -345,279,346, -280,346,279, -346,280,347, -281,347,280, -347,281,348, -282,348,281, -348,282,349, -283,349,282, -349,283,350, -284,350,283, -350,284,351, -285,351,284, -351,285,352, -286,352,285, -352,286,353, -287,353,286, -353,287,354, -288,354,287, -354,288,355, -289,355,288, -355,289,356, -290,356,289, -356,290,357, -291,357,290, -357,291,358, -292,358,291, -358,292,359, -293,359,292, -359,293,360, -294,360,293, -360,294,361, -295,361,294, -361,295,362, -296,362,295, -362,296,363, -297,363,296, -363,297,364, -298,364,297, -364,298,365, -299,365,298, -365,299,366, -300,366,299, -366,300,367, -301,367,300, -367,301,368, -302,368,301, -368,302,369, -303,369,302, -369,303,370, -304,370,303, -370,304,371, -305,371,304, -371,305,372, -306,372,305, -372,306,373, -307,373,306, -373,307,374, -308,374,307, -374,308,375, -309,375,308, -375,309,376, -310,376,309, -376,310,377, -311,377,310, -377,311,378, -312,378,311, -378,312,379, -313,379,312, -379,313,380, -314,380,313, -380,314,381, -315,381,314, -381,315,382, -316,382,315, -382,316,383, -317,383,316, -383,317,384, -318,384,317, -384,318,385, -319,385,318, -385,319,386, -320,386,319, -386,320,387, -321,387,320, -387,321,388, -322,388,321, -388,322,389, -323,389,322, -389,323,390, -324,390,323, -390,324,391, -325,391,324, -391,325,392, -326,392,325, -392,326,393, -327,393,326, -393,327,394, -328,394,327, -394,328,395, -329,395,328, -396,330,397, -331,397,330, -397,331,398, -332,398,331, -398,332,399, -333,399,332, -399,333,400, -334,400,333, -400,334,401, -335,401,334, -401,335,402, -336,402,335, -402,336,403, -337,403,336, -403,337,404, -338,404,337, -404,338,405, -339,405,338, -405,339,406, -340,406,339, -406,340,407, -341,407,340, -407,341,408, -342,408,341, -408,342,409, -343,409,342, -409,343,410, -344,410,343, -410,344,411, -345,411,344, -411,345,412, -346,412,345, -412,346,413, -347,413,346, -413,347,414, -348,414,347, -414,348,415, -349,415,348, -415,349,416, -350,416,349, -416,350,417, -351,417,350, -417,351,418, -352,418,351, -418,352,419, -353,419,352, -419,353,420, -354,420,353, -420,354,421, -355,421,354, -421,355,422, -356,422,355, -422,356,423, -357,423,356, -423,357,424, -358,424,357, -424,358,425, -359,425,358, -425,359,426, -360,426,359, -426,360,427, -361,427,360, -427,361,428, -362,428,361, -428,362,429, -363,429,362, -429,363,430, -364,430,363, -430,364,431, -365,431,364, -431,365,432, -366,432,365, -432,366,433, -367,433,366, -433,367,434, -368,434,367, -434,368,435, -369,435,368, -435,369,436, -370,436,369, -436,370,437, -371,437,370, -437,371,438, -372,438,371, -438,372,439, -373,439,372, -439,373,440, -374,440,373, -440,374,441, -375,441,374, -441,375,442, -376,442,375, -442,376,443, -377,443,376, -443,377,444, -378,444,377, -444,378,445, -379,445,378, -445,379,446, -380,446,379, -446,380,447, -381,447,380, -447,381,448, -382,448,381, -448,382,449, -383,449,382, -449,383,450, -384,450,383, -450,384,451, -385,451,384, -451,385,452, -386,452,385, -452,386,453, -387,453,386, -453,387,454, -388,454,387, -454,388,455, -389,455,388, -455,389,456, -390,456,389, -456,390,457, -391,457,390, -457,391,458, -392,458,391, -458,392,459, -393,459,392, -459,393,460, -394,460,393, -460,394,461, -395,461,394, -462,396,463, -397,463,396, -463,397,464, -398,464,397, -464,398,465, -399,465,398, -465,399,466, -400,466,399, -466,400,467, -401,467,400, -467,401,468, -402,468,401, -468,402,469, -403,469,402, -469,403,470, -404,470,403, -470,404,471, -405,471,404, -471,405,472, -406,472,405, -472,406,473, -407,473,406, -473,407,474, -408,474,407, -474,408,475, -409,475,408, -475,409,476, -410,476,409, -476,410,477, -411,477,410, -477,411,478, -412,478,411, -478,412,479, -413,479,412, -479,413,480, -414,480,413, -480,414,481, -415,481,414, -481,415,482, -416,482,415, -482,416,483, -417,483,416, -483,417,484, -418,484,417, -484,418,485, -419,485,418, -485,419,486, -420,486,419, -486,420,487, -421,487,420, -487,421,488, -422,488,421, -488,422,489, -423,489,422, -489,423,490, -424,490,423, -490,424,491, -425,491,424, -491,425,492, -426,492,425, -492,426,493, -427,493,426, -493,427,494, -428,494,427, -494,428,495, -429,495,428, -495,429,496, -430,496,429, -496,430,497, -431,497,430, -497,431,498, -432,498,431, -498,432,499, -433,499,432, -499,433,500, -434,500,433, -500,434,501, -435,501,434, -501,435,502, -436,502,435, -502,436,503, -437,503,436, -503,437,504, -438,504,437, -504,438,505, -439,505,438, -505,439,506, -440,506,439, -506,440,507, -441,507,440, -507,441,508, -442,508,441, -508,442,509, -443,509,442, -509,443,510, -444,510,443, -510,444,511, -445,511,444, -511,445,512, -446,512,445, -512,446,513, -447,513,446, -513,447,514, -448,514,447, -514,448,515, -449,515,448, -515,449,516, -450,516,449, -516,450,517, -451,517,450, -517,451,518, -452,518,451, -518,452,519, -453,519,452, -519,453,520, -454,520,453, -520,454,521, -455,521,454, -521,455,522, -456,522,455, -522,456,523, -457,523,456, -523,457,524, -458,524,457, -524,458,525, -459,525,458, -525,459,526, -460,526,459, -526,460,527, -461,527,460, -528,462,529, -463,529,462, -529,463,530, -464,530,463, -530,464,531, -465,531,464, -531,465,532, -466,532,465, -532,466,533, -467,533,466, -533,467,534, -468,534,467, -534,468,535, -469,535,468, -535,469,536, -470,536,469, -536,470,537, -471,537,470, -537,471,538, -472,538,471, -538,472,539, -473,539,472, -539,473,540, -474,540,473, -540,474,541, -475,541,474, -541,475,542, -476,542,475, -542,476,543, -477,543,476, -543,477,544, -478,544,477, -544,478,545, -479,545,478, -545,479,546, -480,546,479, -546,480,547, -481,547,480, -547,481,548, -482,548,481, -548,482,549, -483,549,482, -549,483,550, -484,550,483, -550,484,551, -485,551,484, -551,485,552, -486,552,485, -552,486,553, -487,553,486, -553,487,554, -488,554,487, -554,488,555, -489,555,488, -555,489,556, -490,556,489, -556,490,557, -491,557,490, -557,491,558, -492,558,491, -558,492,559, -493,559,492, -559,493,560, -494,560,493, -560,494,561, -495,561,494, -561,495,562, -496,562,495, -562,496,563, -497,563,496, -563,497,564, -498,564,497, -564,498,565, -499,565,498, -565,499,566, -500,566,499, -566,500,567, -501,567,500, -567,501,568, -502,568,501, -568,502,569, -503,569,502, -569,503,570, -504,570,503, -570,504,571, -505,571,504, -571,505,572, -506,572,505, -572,506,573, -507,573,506, -573,507,574, -508,574,507, -574,508,575, -509,575,508, -575,509,576, -510,576,509, -576,510,577, -511,577,510, -577,511,578, -512,578,511, -578,512,579, -513,579,512, -579,513,580, -514,580,513, -580,514,581, -515,581,514, -581,515,582, -516,582,515, -582,516,583, -517,583,516, -583,517,584, -518,584,517, -584,518,585, -519,585,518, -585,519,586, -520,586,519, -586,520,587, -521,587,520, -587,521,588, -522,588,521, -588,522,589, -523,589,522, -589,523,590, -524,590,523, -590,524,591, -525,591,524, -591,525,592, -526,592,525, -592,526,593, -527,593,526, -594,528,595, -529,595,528, -595,529,596, -530,596,529, -596,530,597, -531,597,530, -597,531,598, -532,598,531, -598,532,599, -533,599,532, -599,533,600, -534,600,533, -600,534,601, -535,601,534, -601,535,602, -536,602,535, -602,536,603, -537,603,536, -603,537,604, -538,604,537, -604,538,605, -539,605,538, -605,539,606, -540,606,539, -606,540,607, -541,607,540, -607,541,608, -542,608,541, -608,542,609, -543,609,542, -609,543,610, -544,610,543, -610,544,611, -545,611,544, -611,545,612, -546,612,545, -612,546,613, -547,613,546, -613,547,614, -548,614,547, -614,548,615, -549,615,548, -615,549,616, -550,616,549, -616,550,617, -551,617,550, -617,551,618, -552,618,551, -618,552,619, -553,619,552, -619,553,620, -554,620,553, -620,554,621, -555,621,554, -621,555,622, -556,622,555, -622,556,623, -557,623,556, -623,557,624, -558,624,557, -624,558,625, -559,625,558, -625,559,626, -560,626,559, -626,560,627, -561,627,560, -627,561,628, -562,628,561, -628,562,629, -563,629,562, -629,563,630, -564,630,563, -630,564,631, -565,631,564, -631,565,632, -566,632,565, -632,566,633, -567,633,566, -633,567,634, -568,634,567, -634,568,635, -569,635,568, -635,569,636, -570,636,569, -636,570,637, -571,637,570, -637,571,638, -572,638,571, -638,572,639, -573,639,572, -639,573,640, -574,640,573, -640,574,641, -575,641,574, -641,575,642, -576,642,575, -642,576,643, -577,643,576, -643,577,644, -578,644,577, -644,578,645, -579,645,578, -645,579,646, -580,646,579, -646,580,647, -581,647,580, -647,581,648, -582,648,581, -648,582,649, -583,649,582, -649,583,650, -584,650,583, -650,584,651, -585,651,584, -651,585,652, -586,652,585, -652,586,653, -587,653,586, -653,587,654, -588,654,587, -654,588,655, -589,655,588, -655,589,656, -590,656,589, -656,590,657, -591,657,590, -657,591,658, -592,658,591, -658,592,659, -593,659,592, -660,594,661, -595,661,594, -661,595,662, -596,662,595, -662,596,663, -597,663,596, -663,597,664, -598,664,597, -664,598,665, -599,665,598, -665,599,666, -600,666,599, -666,600,667, -601,667,600, -667,601,668, -602,668,601, -668,602,669, -603,669,602, -669,603,670, -604,670,603, -670,604,671, -605,671,604, -671,605,672, -606,672,605, -672,606,673, -607,673,606, -673,607,674, -608,674,607, -674,608,675, -609,675,608, -675,609,676, -610,676,609, -676,610,677, -611,677,610, -677,611,678, -612,678,611, -678,612,679, -613,679,612, -679,613,680, -614,680,613, -680,614,681, -615,681,614, -681,615,682, -616,682,615, -682,616,683, -617,683,616, -683,617,684, -618,684,617, -684,618,685, -619,685,618, -685,619,686, -620,686,619, -686,620,687, -621,687,620, -687,621,688, -622,688,621, -688,622,689, -623,689,622, -689,623,690, -624,690,623, -690,624,691, -625,691,624, -691,625,692, -626,692,625, -692,626,693, -627,693,626, -693,627,694, -628,694,627, -694,628,695, -629,695,628, -695,629,696, -630,696,629, -696,630,697, -631,697,630, -697,631,698, -632,698,631, -698,632,699, -633,699,632, -699,633,700, -634,700,633, -700,634,701, -635,701,634, -701,635,702, -636,702,635, -702,636,703, -637,703,636, -703,637,704, -638,704,637, -704,638,705, -639,705,638, -705,639,706, -640,706,639, -706,640,707, -641,707,640, -707,641,708, -642,708,641, -708,642,709, -643,709,642, -709,643,710, -644,710,643, -710,644,711, -645,711,644, -711,645,712, -646,712,645, -712,646,713, -647,713,646, -713,647,714, -648,714,647, -714,648,715, -649,715,648, -715,649,716, -650,716,649, -716,650,717, -651,717,650, -717,651,718, -652,718,651, -718,652,719, -653,719,652, -719,653,720, -654,720,653, -720,654,721, -655,721,654, -721,655,722, -656,722,655, -722,656,723, -657,723,656, -723,657,724, -658,724,657, -724,658,725, -659,725,658, -726,660,727, -661,727,660, -727,661,728, -662,728,661, -728,662,729, -663,729,662, -729,663,730, -664,730,663, -730,664,731, -665,731,664, -731,665,732, -666,732,665, -732,666,733, -667,733,666, -733,667,734, -668,734,667, -734,668,735, -669,735,668, -735,669,736, -670,736,669, -736,670,737, -671,737,670, -737,671,738, -672,738,671, -738,672,739, -673,739,672, -739,673,740, -674,740,673, -740,674,741, -675,741,674, -741,675,742, -676,742,675, -742,676,743, -677,743,676, -743,677,744, -678,744,677, -744,678,745, -679,745,678, -745,679,746, -680,746,679, -746,680,747, -681,747,680, -747,681,748, -682,748,681, -748,682,749, -683,749,682, -749,683,750, -684,750,683, -750,684,751, -685,751,684, -751,685,752, -686,752,685, -752,686,753, -687,753,686, -753,687,754, -688,754,687, -754,688,755, -689,755,688, -755,689,756, -690,756,689, -756,690,757, -691,757,690, -757,691,758, -692,758,691, -758,692,759, -693,759,692, -759,693,760, -694,760,693, -760,694,761, -695,761,694, -761,695,762, -696,762,695, -762,696,763, -697,763,696, -763,697,764, -698,764,697, -764,698,765, -699,765,698, -765,699,766, -700,766,699, -766,700,767, -701,767,700, -767,701,768, -702,768,701, -768,702,769, -703,769,702, -769,703,770, -704,770,703, -770,704,771, -705,771,704, -771,705,772, -706,772,705, -772,706,773, -707,773,706, -773,707,774, -708,774,707, -774,708,775, -709,775,708, -775,709,776, -710,776,709, -776,710,777, -711,777,710, -777,711,778, -712,778,711, -778,712,779, -713,779,712, -779,713,780, -714,780,713, -780,714,781, -715,781,714, -781,715,782, -716,782,715, -782,716,783, -717,783,716, -783,717,784, -718,784,717, -784,718,785, -719,785,718, -785,719,786, -720,786,719, -786,720,787, -721,787,720, -787,721,788, -722,788,721, -788,722,789, -723,789,722, -789,723,790, -724,790,723, -790,724,791, -725,791,724, -792,726,793, -727,793,726, -793,727,794, -728,794,727, -794,728,795, -729,795,728, -795,729,796, -730,796,729, -796,730,797, -731,797,730, -797,731,798, -732,798,731, -798,732,799, -733,799,732, -799,733,800, -734,800,733, -800,734,801, -735,801,734, -801,735,802, -736,802,735, -802,736,803, -737,803,736, -803,737,804, -738,804,737, -804,738,805, -739,805,738, -805,739,806, -740,806,739, -806,740,807, -741,807,740, -807,741,808, -742,808,741, -808,742,809, -743,809,742, -809,743,810, -744,810,743, -810,744,811, -745,811,744, -811,745,812, -746,812,745, -812,746,813, -747,813,746, -813,747,814, -748,814,747, -814,748,815, -749,815,748, -815,749,816, -750,816,749, -816,750,817, -751,817,750, -817,751,818, -752,818,751, -818,752,819, -753,819,752, -819,753,820, -754,820,753, -820,754,821, -755,821,754, -821,755,822, -756,822,755, -822,756,823, -757,823,756, -823,757,824, -758,824,757, -824,758,825, -759,825,758, -825,759,826, -760,826,759, -826,760,827, -761,827,760, -827,761,828, -762,828,761, -828,762,829, -763,829,762, -829,763,830, -764,830,763, -830,764,831, -765,831,764, -831,765,832, -766,832,765, -832,766,833, -767,833,766, -833,767,834, -768,834,767, -834,768,835, -769,835,768, -835,769,836, -770,836,769, -836,770,837, -771,837,770, -837,771,838, -772,838,771, -838,772,839, -773,839,772, -839,773,840, -774,840,773, -840,774,841, -775,841,774, -841,775,842, -776,842,775, -842,776,843, -777,843,776, -843,777,844, -778,844,777, -844,778,845, -779,845,778, -845,779,846, -780,846,779, -846,780,847, -781,847,780, -847,781,848, -782,848,781, -848,782,849, -783,849,782, -849,783,850, -784,850,783, -850,784,851, -785,851,784, -851,785,852, -786,852,785, -852,786,853, -787,853,786, -853,787,854, -788,854,787, -854,788,855, -789,855,788, -855,789,856, -790,856,789, -856,790,857, -791,857,790, -858,792,859, -793,859,792, -859,793,860, -794,860,793, -860,794,861, -795,861,794, -861,795,862, -796,862,795, -862,796,863, -797,863,796, -863,797,864, -798,864,797, -864,798,865, -799,865,798, -865,799,866, -800,866,799, -866,800,867, -801,867,800, -867,801,868, -802,868,801, -868,802,869, -803,869,802, -869,803,870, -804,870,803, -870,804,871, -805,871,804, -871,805,872, -806,872,805, -872,806,873, -807,873,806, -873,807,874, -808,874,807, -874,808,875, -809,875,808, -875,809,876, -810,876,809, -876,810,877, -811,877,810, -877,811,878, -812,878,811, -878,812,879, -813,879,812, -879,813,880, -814,880,813, -880,814,881, -815,881,814, -881,815,882, -816,882,815, -882,816,883, -817,883,816, -883,817,884, -818,884,817, -884,818,885, -819,885,818, -885,819,886, -820,886,819, -886,820,887, -821,887,820, -887,821,888, -822,888,821, -888,822,889, -823,889,822, -889,823,890, -824,890,823, -890,824,891, -825,891,824, -891,825,892, -826,892,825, -892,826,893, -827,893,826, -893,827,894, -828,894,827, -894,828,895, -829,895,828, -895,829,896, -830,896,829, -896,830,897, -831,897,830, -897,831,898, -832,898,831, -898,832,899, -833,899,832, -899,833,900, -834,900,833, -900,834,901, -835,901,834, -901,835,902, -836,902,835, -902,836,903, -837,903,836, -903,837,904, -838,904,837, -904,838,905, -839,905,838, -905,839,906, -840,906,839, -906,840,907, -841,907,840, -907,841,908, -842,908,841, -908,842,909, -843,909,842, -909,843,910, -844,910,843, -910,844,911, -845,911,844, -911,845,912, -846,912,845, -912,846,913, -847,913,846, -913,847,914, -848,914,847, -914,848,915, -849,915,848, -915,849,916, -850,916,849, -916,850,917, -851,917,850, -917,851,918, -852,918,851, -918,852,919, -853,919,852, -919,853,920, -854,920,853, -920,854,921, -855,921,854, -921,855,922, -856,922,855, -922,856,923, -857,923,856, -924,858,925, -859,925,858, -925,859,926, -860,926,859, -926,860,927, -861,927,860, -927,861,928, -862,928,861, -928,862,929, -863,929,862, -929,863,930, -864,930,863, -930,864,931, -865,931,864, -931,865,932, -866,932,865, -932,866,933, -867,933,866, -933,867,934, -868,934,867, -934,868,935, -869,935,868, -935,869,936, -870,936,869, -936,870,937, -871,937,870, -937,871,938, -872,938,871, -938,872,939, -873,939,872, -939,873,940, -874,940,873, -940,874,941, -875,941,874, -941,875,942, -876,942,875, -942,876,943, -877,943,876, -943,877,944, -878,944,877, -944,878,945, -879,945,878, -945,879,946, -880,946,879, -946,880,947, -881,947,880, -947,881,948, -882,948,881, -948,882,949, -883,949,882, -949,883,950, -884,950,883, -950,884,951, -885,951,884, -951,885,952, -886,952,885, -952,886,953, -887,953,886, -953,887,954, -888,954,887, -954,888,955, -889,955,888, -955,889,956, -890,956,889, -956,890,957, -891,957,890, -957,891,958, -892,958,891, -958,892,959, -893,959,892, -959,893,960, -894,960,893, -960,894,961, -895,961,894, -961,895,962, -896,962,895, -962,896,963, -897,963,896, -963,897,964, -898,964,897, -964,898,965, -899,965,898, -965,899,966, -900,966,899, -966,900,967, -901,967,900, -967,901,968, -902,968,901, -968,902,969, -903,969,902, -969,903,970, -904,970,903, -970,904,971, -905,971,904, -971,905,972, -906,972,905, -972,906,973, -907,973,906, -973,907,974, -908,974,907, -974,908,975, -909,975,908, -975,909,976, -910,976,909, -976,910,977, -911,977,910, -977,911,978, -912,978,911, -978,912,979, -913,979,912, -979,913,980, -914,980,913, -980,914,981, -915,981,914, -981,915,982, -916,982,915, -982,916,983, -917,983,916, -983,917,984, -918,984,917, -984,918,985, -919,985,918, -985,919,986, -920,986,919, -986,920,987, -921,987,920, -987,921,988, -922,988,921, -988,922,989, -923,989,922, -990,924,991, -925,991,924, -991,925,992, -926,992,925, -992,926,993, -927,993,926, -993,927,994, -928,994,927, -994,928,995, -929,995,928, -995,929,996, -930,996,929, -996,930,997, -931,997,930, -997,931,998, -932,998,931, -998,932,999, -933,999,932, -999,933,1000, -934,1000,933, -1000,934,1001, -935,1001,934, -1001,935,1002, -936,1002,935, -1002,936,1003, -937,1003,936, -1003,937,1004, -938,1004,937, -1004,938,1005, -939,1005,938, -1005,939,1006, -940,1006,939, -1006,940,1007, -941,1007,940, -1007,941,1008, -942,1008,941, -1008,942,1009, -943,1009,942, -1009,943,1010, -944,1010,943, -1010,944,1011, -945,1011,944, -1011,945,1012, -946,1012,945, -1012,946,1013, -947,1013,946, -1013,947,1014, -948,1014,947, -1014,948,1015, -949,1015,948, -1015,949,1016, -950,1016,949, -1016,950,1017, -951,1017,950, -1017,951,1018, -952,1018,951, -1018,952,1019, -953,1019,952, -1019,953,1020, -954,1020,953, -1020,954,1021, -955,1021,954, -1021,955,1022, -956,1022,955, -1022,956,1023, -957,1023,956, -1023,957,1024, -958,1024,957, -1024,958,1025, -959,1025,958, -1025,959,1026, -960,1026,959, -1026,960,1027, -961,1027,960, -1027,961,1028, -962,1028,961, -1028,962,1029, -963,1029,962, -1029,963,1030, -964,1030,963, -1030,964,1031, -965,1031,964, -1031,965,1032, -966,1032,965, -1032,966,1033, -967,1033,966, -1033,967,1034, -968,1034,967, -1034,968,1035, -969,1035,968, -1035,969,1036, -970,1036,969, -1036,970,1037, -971,1037,970, -1037,971,1038, -972,1038,971, -1038,972,1039, -973,1039,972, -1039,973,1040, -974,1040,973, -1040,974,1041, -975,1041,974, -1041,975,1042, -976,1042,975, -1042,976,1043, -977,1043,976, -1043,977,1044, -978,1044,977, -1044,978,1045, -979,1045,978, -1045,979,1046, -980,1046,979, -1046,980,1047, -981,1047,980, -1047,981,1048, -982,1048,981, -1048,982,1049, -983,1049,982, -1049,983,1050, -984,1050,983, -1050,984,1051, -985,1051,984, -1051,985,1052, -986,1052,985, -1052,986,1053, -987,1053,986, -1053,987,1054, -988,1054,987, -1054,988,1055, -989,1055,988, -1056,990,1057, -991,1057,990, -1057,991,1058, -992,1058,991, -1058,992,1059, -993,1059,992, -1059,993,1060, -994,1060,993, -1060,994,1061, -995,1061,994, -1061,995,1062, -996,1062,995, -1062,996,1063, -997,1063,996, -1063,997,1064, -998,1064,997, -1064,998,1065, -999,1065,998, -1065,999,1066, -1000,1066,999, -1066,1000,1067, -1001,1067,1000, -1067,1001,1068, -1002,1068,1001, -1068,1002,1069, -1003,1069,1002, -1069,1003,1070, -1004,1070,1003, -1070,1004,1071, -1005,1071,1004, -1071,1005,1072, -1006,1072,1005, -1072,1006,1073, -1007,1073,1006, -1073,1007,1074, -1008,1074,1007, -1074,1008,1075, -1009,1075,1008, -1075,1009,1076, -1010,1076,1009, -1076,1010,1077, -1011,1077,1010, -1077,1011,1078, -1012,1078,1011, -1078,1012,1079, -1013,1079,1012, -1079,1013,1080, -1014,1080,1013, -1080,1014,1081, -1015,1081,1014, -1081,1015,1082, -1016,1082,1015, -1082,1016,1083, -1017,1083,1016, -1083,1017,1084, -1018,1084,1017, -1084,1018,1085, -1019,1085,1018, -1085,1019,1086, -1020,1086,1019, -1086,1020,1087, -1021,1087,1020, -1087,1021,1088, -1022,1088,1021, -1088,1022,1089, -1023,1089,1022, -1089,1023,1090, -1024,1090,1023, -1090,1024,1091, -1025,1091,1024, -1091,1025,1092, -1026,1092,1025, -1092,1026,1093, -1027,1093,1026, -1093,1027,1094, -1028,1094,1027, -1094,1028,1095, -1029,1095,1028, -1095,1029,1096, -1030,1096,1029, -1096,1030,1097, -1031,1097,1030, -1097,1031,1098, -1032,1098,1031, -1098,1032,1099, -1033,1099,1032, -1099,1033,1100, -1034,1100,1033, -1100,1034,1101, -1035,1101,1034, -1101,1035,1102, -1036,1102,1035, -1102,1036,1103, -1037,1103,1036, -1103,1037,1104, -1038,1104,1037, -1104,1038,1105, -1039,1105,1038, -1105,1039,1106, -1040,1106,1039, -1106,1040,1107, -1041,1107,1040, -1107,1041,1108, -1042,1108,1041, -1108,1042,1109, -1043,1109,1042, -1109,1043,1110, -1044,1110,1043, -1110,1044,1111, -1045,1111,1044, -1111,1045,1112, -1046,1112,1045, -1112,1046,1113, -1047,1113,1046, -1113,1047,1114, -1048,1114,1047, -1114,1048,1115, -1049,1115,1048, -1115,1049,1116, -1050,1116,1049, -1116,1050,1117, -1051,1117,1050, -1117,1051,1118, -1052,1118,1051, -1118,1052,1119, -1053,1119,1052, -1119,1053,1120, -1054,1120,1053, -1120,1054,1121, -1055,1121,1054, -1122,1056,1123, -1057,1123,1056, -1123,1057,1124, -1058,1124,1057, -1124,1058,1125, -1059,1125,1058, -1125,1059,1126, -1060,1126,1059, -1126,1060,1127, -1061,1127,1060, -1127,1061,1128, -1062,1128,1061, -1128,1062,1129, -1063,1129,1062, -1129,1063,1130, -1064,1130,1063, -1130,1064,1131, -1065,1131,1064, -1131,1065,1132, -1066,1132,1065, -1132,1066,1133, -1067,1133,1066, -1133,1067,1134, -1068,1134,1067, -1134,1068,1135, -1069,1135,1068, -1135,1069,1136, -1070,1136,1069, -1136,1070,1137, -1071,1137,1070, -1137,1071,1138, -1072,1138,1071, -1138,1072,1139, -1073,1139,1072, -1139,1073,1140, -1074,1140,1073, -1140,1074,1141, -1075,1141,1074, -1141,1075,1142, -1076,1142,1075, -1142,1076,1143, -1077,1143,1076, -1143,1077,1144, -1078,1144,1077, -1144,1078,1145, -1079,1145,1078, -1145,1079,1146, -1080,1146,1079, -1146,1080,1147, -1081,1147,1080, -1147,1081,1148, -1082,1148,1081, -1148,1082,1149, -1083,1149,1082, -1149,1083,1150, -1084,1150,1083, -1150,1084,1151, -1085,1151,1084, -1151,1085,1152, -1086,1152,1085, -1152,1086,1153, -1087,1153,1086, -1153,1087,1154, -1088,1154,1087, -1154,1088,1155, -1089,1155,1088, -1155,1089,1156, -1090,1156,1089, -1156,1090,1157, -1091,1157,1090, -1157,1091,1158, -1092,1158,1091, -1158,1092,1159, -1093,1159,1092, -1159,1093,1160, -1094,1160,1093, -1160,1094,1161, -1095,1161,1094, -1161,1095,1162, -1096,1162,1095, -1162,1096,1163, -1097,1163,1096, -1163,1097,1164, -1098,1164,1097, -1164,1098,1165, -1099,1165,1098, -1165,1099,1166, -1100,1166,1099, -1166,1100,1167, -1101,1167,1100, -1167,1101,1168, -1102,1168,1101, -1168,1102,1169, -1103,1169,1102, -1169,1103,1170, -1104,1170,1103, -1170,1104,1171, -1105,1171,1104, -1171,1105,1172, -1106,1172,1105, -1172,1106,1173, -1107,1173,1106, -1173,1107,1174, -1108,1174,1107, -1174,1108,1175, -1109,1175,1108, -1175,1109,1176, -1110,1176,1109, -1176,1110,1177, -1111,1177,1110, -1177,1111,1178, -1112,1178,1111, -1178,1112,1179, -1113,1179,1112, -1179,1113,1180, -1114,1180,1113, -1180,1114,1181, -1115,1181,1114, -1181,1115,1182, -1116,1182,1115, -1182,1116,1183, -1117,1183,1116, -1183,1117,1184, -1118,1184,1117, -1184,1118,1185, -1119,1185,1118, -1185,1119,1186, -1120,1186,1119, -1186,1120,1187, -1121,1187,1120, -1188,1122,1189, -1123,1189,1122, -1189,1123,1190, -1124,1190,1123, -1190,1124,1191, -1125,1191,1124, -1191,1125,1192, -1126,1192,1125, -1192,1126,1193, -1127,1193,1126, -1193,1127,1194, -1128,1194,1127, -1194,1128,1195, -1129,1195,1128, -1195,1129,1196, -1130,1196,1129, -1196,1130,1197, -1131,1197,1130, -1197,1131,1198, -1132,1198,1131, -1198,1132,1199, -1133,1199,1132, -1199,1133,1200, -1134,1200,1133, -1200,1134,1201, -1135,1201,1134, -1201,1135,1202, -1136,1202,1135, -1202,1136,1203, -1137,1203,1136, -1203,1137,1204, -1138,1204,1137, -1204,1138,1205, -1139,1205,1138, -1205,1139,1206, -1140,1206,1139, -1206,1140,1207, -1141,1207,1140, -1207,1141,1208, -1142,1208,1141, -1208,1142,1209, -1143,1209,1142, -1209,1143,1210, -1144,1210,1143, -1210,1144,1211, -1145,1211,1144, -1211,1145,1212, -1146,1212,1145, -1212,1146,1213, -1147,1213,1146, -1213,1147,1214, -1148,1214,1147, -1214,1148,1215, -1149,1215,1148, -1215,1149,1216, -1150,1216,1149, -1216,1150,1217, -1151,1217,1150, -1217,1151,1218, -1152,1218,1151, -1218,1152,1219, -1153,1219,1152, -1219,1153,1220, -1154,1220,1153, -1220,1154,1221, -1155,1221,1154, -1221,1155,1222, -1156,1222,1155, -1222,1156,1223, -1157,1223,1156, -1223,1157,1224, -1158,1224,1157, -1224,1158,1225, -1159,1225,1158, -1225,1159,1226, -1160,1226,1159, -1226,1160,1227, -1161,1227,1160, -1227,1161,1228, -1162,1228,1161, -1228,1162,1229, -1163,1229,1162, -1229,1163,1230, -1164,1230,1163, -1230,1164,1231, -1165,1231,1164, -1231,1165,1232, -1166,1232,1165, -1232,1166,1233, -1167,1233,1166, -1233,1167,1234, -1168,1234,1167, -1234,1168,1235, -1169,1235,1168, -1235,1169,1236, -1170,1236,1169, -1236,1170,1237, -1171,1237,1170, -1237,1171,1238, -1172,1238,1171, -1238,1172,1239, -1173,1239,1172, -1239,1173,1240, -1174,1240,1173, -1240,1174,1241, -1175,1241,1174, -1241,1175,1242, -1176,1242,1175, -1242,1176,1243, -1177,1243,1176, -1243,1177,1244, -1178,1244,1177, -1244,1178,1245, -1179,1245,1178, -1245,1179,1246, -1180,1246,1179, -1246,1180,1247, -1181,1247,1180, -1247,1181,1248, -1182,1248,1181, -1248,1182,1249, -1183,1249,1182, -1249,1183,1250, -1184,1250,1183, -1250,1184,1251, -1185,1251,1184, -1251,1185,1252, -1186,1252,1185, -1252,1186,1253, -1187,1253,1186, -1254,1188,1255, -1189,1255,1188, -1255,1189,1256, -1190,1256,1189, -1256,1190,1257, -1191,1257,1190, -1257,1191,1258, -1192,1258,1191, -1258,1192,1259, -1193,1259,1192, -1259,1193,1260, -1194,1260,1193, -1260,1194,1261, -1195,1261,1194, -1261,1195,1262, -1196,1262,1195, -1262,1196,1263, -1197,1263,1196, -1263,1197,1264, -1198,1264,1197, -1264,1198,1265, -1199,1265,1198, -1265,1199,1266, -1200,1266,1199, -1266,1200,1267, -1201,1267,1200, -1267,1201,1268, -1202,1268,1201, -1268,1202,1269, -1203,1269,1202, -1269,1203,1270, -1204,1270,1203, -1270,1204,1271, -1205,1271,1204, -1271,1205,1272, -1206,1272,1205, -1272,1206,1273, -1207,1273,1206, -1273,1207,1274, -1208,1274,1207, -1274,1208,1275, -1209,1275,1208, -1275,1209,1276, -1210,1276,1209, -1276,1210,1277, -1211,1277,1210, -1277,1211,1278, -1212,1278,1211, -1278,1212,1279, -1213,1279,1212, -1279,1213,1280, -1214,1280,1213, -1280,1214,1281, -1215,1281,1214, -1281,1215,1282, -1216,1282,1215, -1282,1216,1283, -1217,1283,1216, -1283,1217,1284, -1218,1284,1217, -1284,1218,1285, -1219,1285,1218, -1285,1219,1286, -1220,1286,1219, -1286,1220,1287, -1221,1287,1220, -1287,1221,1288, -1222,1288,1221, -1288,1222,1289, -1223,1289,1222, -1289,1223,1290, -1224,1290,1223, -1290,1224,1291, -1225,1291,1224, -1291,1225,1292, -1226,1292,1225, -1292,1226,1293, -1227,1293,1226, -1293,1227,1294, -1228,1294,1227, -1294,1228,1295, -1229,1295,1228, -1295,1229,1296, -1230,1296,1229, -1296,1230,1297, -1231,1297,1230, -1297,1231,1298, -1232,1298,1231, -1298,1232,1299, -1233,1299,1232, -1299,1233,1300, -1234,1300,1233, -1300,1234,1301, -1235,1301,1234, -1301,1235,1302, -1236,1302,1235, -1302,1236,1303, -1237,1303,1236, -1303,1237,1304, -1238,1304,1237, -1304,1238,1305, -1239,1305,1238, -1305,1239,1306, -1240,1306,1239, -1306,1240,1307, -1241,1307,1240, -1307,1241,1308, -1242,1308,1241, -1308,1242,1309, -1243,1309,1242, -1309,1243,1310, -1244,1310,1243, -1310,1244,1311, -1245,1311,1244, -1311,1245,1312, -1246,1312,1245, -1312,1246,1313, -1247,1313,1246, -1313,1247,1314, -1248,1314,1247, -1314,1248,1315, -1249,1315,1248, -1315,1249,1316, -1250,1316,1249, -1316,1250,1317, -1251,1317,1250, -1317,1251,1318, -1252,1318,1251, -1318,1252,1319, -1253,1319,1252, -1320,1254,1321, -1255,1321,1254, -1321,1255,1322, -1256,1322,1255, -1322,1256,1323, -1257,1323,1256, -1323,1257,1324, -1258,1324,1257, -1324,1258,1325, -1259,1325,1258, -1325,1259,1326, -1260,1326,1259, -1326,1260,1327, -1261,1327,1260, -1327,1261,1328, -1262,1328,1261, -1328,1262,1329, -1263,1329,1262, -1329,1263,1330, -1264,1330,1263, -1330,1264,1331, -1265,1331,1264, -1331,1265,1332, -1266,1332,1265, -1332,1266,1333, -1267,1333,1266, -1333,1267,1334, -1268,1334,1267, -1334,1268,1335, -1269,1335,1268, -1335,1269,1336, -1270,1336,1269, -1336,1270,1337, -1271,1337,1270, -1337,1271,1338, -1272,1338,1271, -1338,1272,1339, -1273,1339,1272, -1339,1273,1340, -1274,1340,1273, -1340,1274,1341, -1275,1341,1274, -1341,1275,1342, -1276,1342,1275, -1342,1276,1343, -1277,1343,1276, -1343,1277,1344, -1278,1344,1277, -1344,1278,1345, -1279,1345,1278, -1345,1279,1346, -1280,1346,1279, -1346,1280,1347, -1281,1347,1280, -1347,1281,1348, -1282,1348,1281, -1348,1282,1349, -1283,1349,1282, -1349,1283,1350, -1284,1350,1283, -1350,1284,1351, -1285,1351,1284, -1351,1285,1352, -1286,1352,1285, -1352,1286,1353, -1287,1353,1286, -1353,1287,1354, -1288,1354,1287, -1354,1288,1355, -1289,1355,1288, -1355,1289,1356, -1290,1356,1289, -1356,1290,1357, -1291,1357,1290, -1357,1291,1358, -1292,1358,1291, -1358,1292,1359, -1293,1359,1292, -1359,1293,1360, -1294,1360,1293, -1360,1294,1361, -1295,1361,1294, -1361,1295,1362, -1296,1362,1295, -1362,1296,1363, -1297,1363,1296, -1363,1297,1364, -1298,1364,1297, -1364,1298,1365, -1299,1365,1298, -1365,1299,1366, -1300,1366,1299, -1366,1300,1367, -1301,1367,1300, -1367,1301,1368, -1302,1368,1301, -1368,1302,1369, -1303,1369,1302, -1369,1303,1370, -1304,1370,1303, -1370,1304,1371, -1305,1371,1304, -1371,1305,1372, -1306,1372,1305, -1372,1306,1373, -1307,1373,1306, -1373,1307,1374, -1308,1374,1307, -1374,1308,1375, -1309,1375,1308, -1375,1309,1376, -1310,1376,1309, -1376,1310,1377, -1311,1377,1310, -1377,1311,1378, -1312,1378,1311, -1378,1312,1379, -1313,1379,1312, -1379,1313,1380, -1314,1380,1313, -1380,1314,1381, -1315,1381,1314, -1381,1315,1382, -1316,1382,1315, -1382,1316,1383, -1317,1383,1316, -1383,1317,1384, -1318,1384,1317, -1384,1318,1385, -1319,1385,1318, -1386,1320,1387, -1321,1387,1320, -1387,1321,1388, -1322,1388,1321, -1388,1322,1389, -1323,1389,1322, -1389,1323,1390, -1324,1390,1323, -1390,1324,1391, -1325,1391,1324, -1391,1325,1392, -1326,1392,1325, -1392,1326,1393, -1327,1393,1326, -1393,1327,1394, -1328,1394,1327, -1394,1328,1395, -1329,1395,1328, -1395,1329,1396, -1330,1396,1329, -1396,1330,1397, -1331,1397,1330, -1397,1331,1398, -1332,1398,1331, -1398,1332,1399, -1333,1399,1332, -1399,1333,1400, -1334,1400,1333, -1400,1334,1401, -1335,1401,1334, -1401,1335,1402, -1336,1402,1335, -1402,1336,1403, -1337,1403,1336, -1403,1337,1404, -1338,1404,1337, -1404,1338,1405, -1339,1405,1338, -1405,1339,1406, -1340,1406,1339, -1406,1340,1407, -1341,1407,1340, -1407,1341,1408, -1342,1408,1341, -1408,1342,1409, -1343,1409,1342, -1409,1343,1410, -1344,1410,1343, -1410,1344,1411, -1345,1411,1344, -1411,1345,1412, -1346,1412,1345, -1412,1346,1413, -1347,1413,1346, -1413,1347,1414, -1348,1414,1347, -1414,1348,1415, -1349,1415,1348, -1415,1349,1416, -1350,1416,1349, -1416,1350,1417, -1351,1417,1350, -1417,1351,1418, -1352,1418,1351, -1418,1352,1419, -1353,1419,1352, -1419,1353,1420, -1354,1420,1353, -1420,1354,1421, -1355,1421,1354, -1421,1355,1422, -1356,1422,1355, -1422,1356,1423, -1357,1423,1356, -1423,1357,1424, -1358,1424,1357, -1424,1358,1425, -1359,1425,1358, -1425,1359,1426, -1360,1426,1359, -1426,1360,1427, -1361,1427,1360, -1427,1361,1428, -1362,1428,1361, -1428,1362,1429, -1363,1429,1362, -1429,1363,1430, -1364,1430,1363, -1430,1364,1431, -1365,1431,1364, -1431,1365,1432, -1366,1432,1365, -1432,1366,1433, -1367,1433,1366, -1433,1367,1434, -1368,1434,1367, -1434,1368,1435, -1369,1435,1368, -1435,1369,1436, -1370,1436,1369, -1436,1370,1437, -1371,1437,1370, -1437,1371,1438, -1372,1438,1371, -1438,1372,1439, -1373,1439,1372, -1439,1373,1440, -1374,1440,1373, -1440,1374,1441, -1375,1441,1374, -1441,1375,1442, -1376,1442,1375, -1442,1376,1443, -1377,1443,1376, -1443,1377,1444, -1378,1444,1377, -1444,1378,1445, -1379,1445,1378, -1445,1379,1446, -1380,1446,1379, -1446,1380,1447, -1381,1447,1380, -1447,1381,1448, -1382,1448,1381, -1448,1382,1449, -1383,1449,1382, -1449,1383,1450, -1384,1450,1383, -1450,1384,1451, -1385,1451,1384, -1452,1386,1453, -1387,1453,1386, -1453,1387,1454, -1388,1454,1387, -1454,1388,1455, -1389,1455,1388, -1455,1389,1456, -1390,1456,1389, -1456,1390,1457, -1391,1457,1390, -1457,1391,1458, -1392,1458,1391, -1458,1392,1459, -1393,1459,1392, -1459,1393,1460, -1394,1460,1393, -1460,1394,1461, -1395,1461,1394, -1461,1395,1462, -1396,1462,1395, -1462,1396,1463, -1397,1463,1396, -1463,1397,1464, -1398,1464,1397, -1464,1398,1465, -1399,1465,1398, -1465,1399,1466, -1400,1466,1399, -1466,1400,1467, -1401,1467,1400, -1467,1401,1468, -1402,1468,1401, -1468,1402,1469, -1403,1469,1402, -1469,1403,1470, -1404,1470,1403, -1470,1404,1471, -1405,1471,1404, -1471,1405,1472, -1406,1472,1405, -1472,1406,1473, -1407,1473,1406, -1473,1407,1474, -1408,1474,1407, -1474,1408,1475, -1409,1475,1408, -1475,1409,1476, -1410,1476,1409, -1476,1410,1477, -1411,1477,1410, -1477,1411,1478, -1412,1478,1411, -1478,1412,1479, -1413,1479,1412, -1479,1413,1480, -1414,1480,1413, -1480,1414,1481, -1415,1481,1414, -1481,1415,1482, -1416,1482,1415, -1482,1416,1483, -1417,1483,1416, -1483,1417,1484, -1418,1484,1417, -1484,1418,1485, -1419,1485,1418, -1485,1419,1486, -1420,1486,1419, -1486,1420,1487, -1421,1487,1420, -1487,1421,1488, -1422,1488,1421, -1488,1422,1489, -1423,1489,1422, -1489,1423,1490, -1424,1490,1423, -1490,1424,1491, -1425,1491,1424, -1491,1425,1492, -1426,1492,1425, -1492,1426,1493, -1427,1493,1426, -1493,1427,1494, -1428,1494,1427, -1494,1428,1495, -1429,1495,1428, -1495,1429,1496, -1430,1496,1429, -1496,1430,1497, -1431,1497,1430, -1497,1431,1498, -1432,1498,1431, -1498,1432,1499, -1433,1499,1432, -1499,1433,1500, -1434,1500,1433, -1500,1434,1501, -1435,1501,1434, -1501,1435,1502, -1436,1502,1435, -1502,1436,1503, -1437,1503,1436, -1503,1437,1504, -1438,1504,1437, -1504,1438,1505, -1439,1505,1438, -1505,1439,1506, -1440,1506,1439, -1506,1440,1507, -1441,1507,1440, -1507,1441,1508, -1442,1508,1441, -1508,1442,1509, -1443,1509,1442, -1509,1443,1510, -1444,1510,1443, -1510,1444,1511, -1445,1511,1444, -1511,1445,1512, -1446,1512,1445, -1512,1446,1513, -1447,1513,1446, -1513,1447,1514, -1448,1514,1447, -1514,1448,1515, -1449,1515,1448, -1515,1449,1516, -1450,1516,1449, -1516,1450,1517, -1451,1517,1450, -1518,1452,1519, -1453,1519,1452, -1519,1453,1520, -1454,1520,1453, -1520,1454,1521, -1455,1521,1454, -1521,1455,1522, -1456,1522,1455, -1522,1456,1523, -1457,1523,1456, -1523,1457,1524, -1458,1524,1457, -1524,1458,1525, -1459,1525,1458, -1525,1459,1526, -1460,1526,1459, -1526,1460,1527, -1461,1527,1460, -1527,1461,1528, -1462,1528,1461, -1528,1462,1529, -1463,1529,1462, -1529,1463,1530, -1464,1530,1463, -1530,1464,1531, -1465,1531,1464, -1531,1465,1532, -1466,1532,1465, -1532,1466,1533, -1467,1533,1466, -1533,1467,1534, -1468,1534,1467, -1534,1468,1535, -1469,1535,1468, -1535,1469,1536, -1470,1536,1469, -1536,1470,1537, -1471,1537,1470, -1537,1471,1538, -1472,1538,1471, -1538,1472,1539, -1473,1539,1472, -1539,1473,1540, -1474,1540,1473, -1540,1474,1541, -1475,1541,1474, -1541,1475,1542, -1476,1542,1475, -1542,1476,1543, -1477,1543,1476, -1543,1477,1544, -1478,1544,1477, -1544,1478,1545, -1479,1545,1478, -1545,1479,1546, -1480,1546,1479, -1546,1480,1547, -1481,1547,1480, -1547,1481,1548, -1482,1548,1481, -1548,1482,1549, -1483,1549,1482, -1549,1483,1550, -1484,1550,1483, -1550,1484,1551, -1485,1551,1484, -1551,1485,1552, -1486,1552,1485, -1552,1486,1553, -1487,1553,1486, -1553,1487,1554, -1488,1554,1487, -1554,1488,1555, -1489,1555,1488, -1555,1489,1556, -1490,1556,1489, -1556,1490,1557, -1491,1557,1490, -1557,1491,1558, -1492,1558,1491, -1558,1492,1559, -1493,1559,1492, -1559,1493,1560, -1494,1560,1493, -1560,1494,1561, -1495,1561,1494, -1561,1495,1562, -1496,1562,1495, -1562,1496,1563, -1497,1563,1496, -1563,1497,1564, -1498,1564,1497, -1564,1498,1565, -1499,1565,1498, -1565,1499,1566, -1500,1566,1499, -1566,1500,1567, -1501,1567,1500, -1567,1501,1568, -1502,1568,1501, -1568,1502,1569, -1503,1569,1502, -1569,1503,1570, -1504,1570,1503, -1570,1504,1571, -1505,1571,1504, -1571,1505,1572, -1506,1572,1505, -1572,1506,1573, -1507,1573,1506, -1573,1507,1574, -1508,1574,1507, -1574,1508,1575, -1509,1575,1508, -1575,1509,1576, -1510,1576,1509, -1576,1510,1577, -1511,1577,1510, -1577,1511,1578, -1512,1578,1511, -1578,1512,1579, -1513,1579,1512, -1579,1513,1580, -1514,1580,1513, -1580,1514,1581, -1515,1581,1514, -1581,1515,1582, -1516,1582,1515, -1582,1516,1583, -1517,1583,1516, -1584,1518,1585, -1519,1585,1518, -1585,1519,1586, -1520,1586,1519, -1586,1520,1587, -1521,1587,1520, -1587,1521,1588, -1522,1588,1521, -1588,1522,1589, -1523,1589,1522, -1589,1523,1590, -1524,1590,1523, -1590,1524,1591, -1525,1591,1524, -1591,1525,1592, -1526,1592,1525, -1592,1526,1593, -1527,1593,1526, -1593,1527,1594, -1528,1594,1527, -1594,1528,1595, -1529,1595,1528, -1595,1529,1596, -1530,1596,1529, -1596,1530,1597, -1531,1597,1530, -1597,1531,1598, -1532,1598,1531, -1598,1532,1599, -1533,1599,1532, -1599,1533,1600, -1534,1600,1533, -1600,1534,1601, -1535,1601,1534, -1601,1535,1602, -1536,1602,1535, -1602,1536,1603, -1537,1603,1536, -1603,1537,1604, -1538,1604,1537, -1604,1538,1605, -1539,1605,1538, -1605,1539,1606, -1540,1606,1539, -1606,1540,1607, -1541,1607,1540, -1607,1541,1608, -1542,1608,1541, -1608,1542,1609, -1543,1609,1542, -1609,1543,1610, -1544,1610,1543, -1610,1544,1611, -1545,1611,1544, -1611,1545,1612, -1546,1612,1545, -1612,1546,1613, -1547,1613,1546, -1613,1547,1614, -1548,1614,1547, -1614,1548,1615, -1549,1615,1548, -1615,1549,1616, -1550,1616,1549, -1616,1550,1617, -1551,1617,1550, -1617,1551,1618, -1552,1618,1551, -1618,1552,1619, -1553,1619,1552, -1619,1553,1620, -1554,1620,1553, -1620,1554,1621, -1555,1621,1554, -1621,1555,1622, -1556,1622,1555, -1622,1556,1623, -1557,1623,1556, -1623,1557,1624, -1558,1624,1557, -1624,1558,1625, -1559,1625,1558, -1625,1559,1626, -1560,1626,1559, -1626,1560,1627, -1561,1627,1560, -1627,1561,1628, -1562,1628,1561, -1628,1562,1629, -1563,1629,1562, -1629,1563,1630, -1564,1630,1563, -1630,1564,1631, -1565,1631,1564, -1631,1565,1632, -1566,1632,1565, -1632,1566,1633, -1567,1633,1566, -1633,1567,1634, -1568,1634,1567, -1634,1568,1635, -1569,1635,1568, -1635,1569,1636, -1570,1636,1569, -1636,1570,1637, -1571,1637,1570, -1637,1571,1638, -1572,1638,1571, -1638,1572,1639, -1573,1639,1572, -1639,1573,1640, -1574,1640,1573, -1640,1574,1641, -1575,1641,1574, -1641,1575,1642, -1576,1642,1575, -1642,1576,1643, -1577,1643,1576, -1643,1577,1644, -1578,1644,1577, -1644,1578,1645, -1579,1645,1578, -1645,1579,1646, -1580,1646,1579, -1646,1580,1647, -1581,1647,1580, -1647,1581,1648, -1582,1648,1581, -1648,1582,1649, -1583,1649,1582, -1650,1584,1651, -1585,1651,1584, -1651,1585,1652, -1586,1652,1585, -1652,1586,1653, -1587,1653,1586, -1653,1587,1654, -1588,1654,1587, -1654,1588,1655, -1589,1655,1588, -1655,1589,1656, -1590,1656,1589, -1656,1590,1657, -1591,1657,1590, -1657,1591,1658, -1592,1658,1591, -1658,1592,1659, -1593,1659,1592, -1659,1593,1660, -1594,1660,1593, -1660,1594,1661, -1595,1661,1594, -1661,1595,1662, -1596,1662,1595, -1662,1596,1663, -1597,1663,1596, -1663,1597,1664, -1598,1664,1597, -1664,1598,1665, -1599,1665,1598, -1665,1599,1666, -1600,1666,1599, -1666,1600,1667, -1601,1667,1600, -1667,1601,1668, -1602,1668,1601, -1668,1602,1669, -1603,1669,1602, -1669,1603,1670, -1604,1670,1603, -1670,1604,1671, -1605,1671,1604, -1671,1605,1672, -1606,1672,1605, -1672,1606,1673, -1607,1673,1606, -1673,1607,1674, -1608,1674,1607, -1674,1608,1675, -1609,1675,1608, -1675,1609,1676, -1610,1676,1609, -1676,1610,1677, -1611,1677,1610, -1677,1611,1678, -1612,1678,1611, -1678,1612,1679, -1613,1679,1612, -1679,1613,1680, -1614,1680,1613, -1680,1614,1681, -1615,1681,1614, -1681,1615,1682, -1616,1682,1615, -1682,1616,1683, -1617,1683,1616, -1683,1617,1684, -1618,1684,1617, -1684,1618,1685, -1619,1685,1618, -1685,1619,1686, -1620,1686,1619, -1686,1620,1687, -1621,1687,1620, -1687,1621,1688, -1622,1688,1621, -1688,1622,1689, -1623,1689,1622, -1689,1623,1690, -1624,1690,1623, -1690,1624,1691, -1625,1691,1624, -1691,1625,1692, -1626,1692,1625, -1692,1626,1693, -1627,1693,1626, -1693,1627,1694, -1628,1694,1627, -1694,1628,1695, -1629,1695,1628, -1695,1629,1696, -1630,1696,1629, -1696,1630,1697, -1631,1697,1630, -1697,1631,1698, -1632,1698,1631, -1698,1632,1699, -1633,1699,1632, -1699,1633,1700, -1634,1700,1633, -1700,1634,1701, -1635,1701,1634, -1701,1635,1702, -1636,1702,1635, -1702,1636,1703, -1637,1703,1636, -1703,1637,1704, -1638,1704,1637, -1704,1638,1705, -1639,1705,1638, -1705,1639,1706, -1640,1706,1639, -1706,1640,1707, -1641,1707,1640, -1707,1641,1708, -1642,1708,1641, -1708,1642,1709, -1643,1709,1642, -1709,1643,1710, -1644,1710,1643, -1710,1644,1711, -1645,1711,1644, -1711,1645,1712, -1646,1712,1645, -1712,1646,1713, -1647,1713,1646, -1713,1647,1714, -1648,1714,1647, -1714,1648,1715, -1649,1715,1648, -1716,1650,1717, -1651,1717,1650, -1717,1651,1718, -1652,1718,1651, -1718,1652,1719, -1653,1719,1652, -1719,1653,1720, -1654,1720,1653, -1720,1654,1721, -1655,1721,1654, -1721,1655,1722, -1656,1722,1655, -1722,1656,1723, -1657,1723,1656, -1723,1657,1724, -1658,1724,1657, -1724,1658,1725, -1659,1725,1658, -1725,1659,1726, -1660,1726,1659, -1726,1660,1727, -1661,1727,1660, -1727,1661,1728, -1662,1728,1661, -1728,1662,1729, -1663,1729,1662, -1729,1663,1730, -1664,1730,1663, -1730,1664,1731, -1665,1731,1664, -1731,1665,1732, -1666,1732,1665, -1732,1666,1733, -1667,1733,1666, -1733,1667,1734, -1668,1734,1667, -1734,1668,1735, -1669,1735,1668, -1735,1669,1736, -1670,1736,1669, -1736,1670,1737, -1671,1737,1670, -1737,1671,1738, -1672,1738,1671, -1738,1672,1739, -1673,1739,1672, -1739,1673,1740, -1674,1740,1673, -1740,1674,1741, -1675,1741,1674, -1741,1675,1742, -1676,1742,1675, -1742,1676,1743, -1677,1743,1676, -1743,1677,1744, -1678,1744,1677, -1744,1678,1745, -1679,1745,1678, -1745,1679,1746, -1680,1746,1679, -1746,1680,1747, -1681,1747,1680, -1747,1681,1748, -1682,1748,1681, -1748,1682,1749, -1683,1749,1682, -1749,1683,1750, -1684,1750,1683, -1750,1684,1751, -1685,1751,1684, -1751,1685,1752, -1686,1752,1685, -1752,1686,1753, -1687,1753,1686, -1753,1687,1754, -1688,1754,1687, -1754,1688,1755, -1689,1755,1688, -1755,1689,1756, -1690,1756,1689, -1756,1690,1757, -1691,1757,1690, -1757,1691,1758, -1692,1758,1691, -1758,1692,1759, -1693,1759,1692, -1759,1693,1760, -1694,1760,1693, -1760,1694,1761, -1695,1761,1694, -1761,1695,1762, -1696,1762,1695, -1762,1696,1763, -1697,1763,1696, -1763,1697,1764, -1698,1764,1697, -1764,1698,1765, -1699,1765,1698, -1765,1699,1766, -1700,1766,1699, -1766,1700,1767, -1701,1767,1700, -1767,1701,1768, -1702,1768,1701, -1768,1702,1769, -1703,1769,1702, -1769,1703,1770, -1704,1770,1703, -1770,1704,1771, -1705,1771,1704, -1771,1705,1772, -1706,1772,1705, -1772,1706,1773, -1707,1773,1706, -1773,1707,1774, -1708,1774,1707, -1774,1708,1775, -1709,1775,1708, -1775,1709,1776, -1710,1776,1709, -1776,1710,1777, -1711,1777,1710, -1777,1711,1778, -1712,1778,1711, -1778,1712,1779, -1713,1779,1712, -1779,1713,1780, -1714,1780,1713, -1780,1714,1781, -1715,1781,1714, -1782,1716,1783, -1717,1783,1716, -1783,1717,1784, -1718,1784,1717, -1784,1718,1785, -1719,1785,1718, -1785,1719,1786, -1720,1786,1719, -1786,1720,1787, -1721,1787,1720, -1787,1721,1788, -1722,1788,1721, -1788,1722,1789, -1723,1789,1722, -1789,1723,1790, -1724,1790,1723, -1790,1724,1791, -1725,1791,1724, -1791,1725,1792, -1726,1792,1725, -1792,1726,1793, -1727,1793,1726, -1793,1727,1794, -1728,1794,1727, -1794,1728,1795, -1729,1795,1728, -1795,1729,1796, -1730,1796,1729, -1796,1730,1797, -1731,1797,1730, -1797,1731,1798, -1732,1798,1731, -1798,1732,1799, -1733,1799,1732, -1799,1733,1800, -1734,1800,1733, -1800,1734,1801, -1735,1801,1734, -1801,1735,1802, -1736,1802,1735, -1802,1736,1803, -1737,1803,1736, -1803,1737,1804, -1738,1804,1737, -1804,1738,1805, -1739,1805,1738, -1805,1739,1806, -1740,1806,1739, -1806,1740,1807, -1741,1807,1740, -1807,1741,1808, -1742,1808,1741, -1808,1742,1809, -1743,1809,1742, -1809,1743,1810, -1744,1810,1743, -1810,1744,1811, -1745,1811,1744, -1811,1745,1812, -1746,1812,1745, -1812,1746,1813, -1747,1813,1746, -1813,1747,1814, -1748,1814,1747, -1814,1748,1815, -1749,1815,1748, -1815,1749,1816, -1750,1816,1749, -1816,1750,1817, -1751,1817,1750, -1817,1751,1818, -1752,1818,1751, -1818,1752,1819, -1753,1819,1752, -1819,1753,1820, -1754,1820,1753, -1820,1754,1821, -1755,1821,1754, -1821,1755,1822, -1756,1822,1755, -1822,1756,1823, -1757,1823,1756, -1823,1757,1824, -1758,1824,1757, -1824,1758,1825, -1759,1825,1758, -1825,1759,1826, -1760,1826,1759, -1826,1760,1827, -1761,1827,1760, -1827,1761,1828, -1762,1828,1761, -1828,1762,1829, -1763,1829,1762, -1829,1763,1830, -1764,1830,1763, -1830,1764,1831, -1765,1831,1764, -1831,1765,1832, -1766,1832,1765, -1832,1766,1833, -1767,1833,1766, -1833,1767,1834, -1768,1834,1767, -1834,1768,1835, -1769,1835,1768, -1835,1769,1836, -1770,1836,1769, -1836,1770,1837, -1771,1837,1770, -1837,1771,1838, -1772,1838,1771, -1838,1772,1839, -1773,1839,1772, -1839,1773,1840, -1774,1840,1773, -1840,1774,1841, -1775,1841,1774, -1841,1775,1842, -1776,1842,1775, -1842,1776,1843, -1777,1843,1776, -1843,1777,1844, -1778,1844,1777, -1844,1778,1845, -1779,1845,1778, -1845,1779,1846, -1780,1846,1779, -1846,1780,1847, -1781,1847,1780, -1848,1782,1849, -1783,1849,1782, -1849,1783,1850, -1784,1850,1783, -1850,1784,1851, -1785,1851,1784, -1851,1785,1852, -1786,1852,1785, -1852,1786,1853, -1787,1853,1786, -1853,1787,1854, -1788,1854,1787, -1854,1788,1855, -1789,1855,1788, -1855,1789,1856, -1790,1856,1789, -1856,1790,1857, -1791,1857,1790, -1857,1791,1858, -1792,1858,1791, -1858,1792,1859, -1793,1859,1792, -1859,1793,1860, -1794,1860,1793, -1860,1794,1861, -1795,1861,1794, -1861,1795,1862, -1796,1862,1795, -1862,1796,1863, -1797,1863,1796, -1863,1797,1864, -1798,1864,1797, -1864,1798,1865, -1799,1865,1798, -1865,1799,1866, -1800,1866,1799, -1866,1800,1867, -1801,1867,1800, -1867,1801,1868, -1802,1868,1801, -1868,1802,1869, -1803,1869,1802, -1869,1803,1870, -1804,1870,1803, -1870,1804,1871, -1805,1871,1804, -1871,1805,1872, -1806,1872,1805, -1872,1806,1873, -1807,1873,1806, -1873,1807,1874, -1808,1874,1807, -1874,1808,1875, -1809,1875,1808, -1875,1809,1876, -1810,1876,1809, -1876,1810,1877, -1811,1877,1810, -1877,1811,1878, -1812,1878,1811, -1878,1812,1879, -1813,1879,1812, -1879,1813,1880, -1814,1880,1813, -1880,1814,1881, -1815,1881,1814, -1881,1815,1882, -1816,1882,1815, -1882,1816,1883, -1817,1883,1816, -1883,1817,1884, -1818,1884,1817, -1884,1818,1885, -1819,1885,1818, -1885,1819,1886, -1820,1886,1819, -1886,1820,1887, -1821,1887,1820, -1887,1821,1888, -1822,1888,1821, -1888,1822,1889, -1823,1889,1822, -1889,1823,1890, -1824,1890,1823, -1890,1824,1891, -1825,1891,1824, -1891,1825,1892, -1826,1892,1825, -1892,1826,1893, -1827,1893,1826, -1893,1827,1894, -1828,1894,1827, -1894,1828,1895, -1829,1895,1828, -1895,1829,1896, -1830,1896,1829, -1896,1830,1897, -1831,1897,1830, -1897,1831,1898, -1832,1898,1831, -1898,1832,1899, -1833,1899,1832, -1899,1833,1900, -1834,1900,1833, -1900,1834,1901, -1835,1901,1834, -1901,1835,1902, -1836,1902,1835, -1902,1836,1903, -1837,1903,1836, -1903,1837,1904, -1838,1904,1837, -1904,1838,1905, -1839,1905,1838, -1905,1839,1906, -1840,1906,1839, -1906,1840,1907, -1841,1907,1840, -1907,1841,1908, -1842,1908,1841, -1908,1842,1909, -1843,1909,1842, -1909,1843,1910, -1844,1910,1843, -1910,1844,1911, -1845,1911,1844, -1911,1845,1912, -1846,1912,1845, -1912,1846,1913, -1847,1913,1846, -1914,1848,1915, -1849,1915,1848, -1915,1849,1916, -1850,1916,1849, -1916,1850,1917, -1851,1917,1850, -1917,1851,1918, -1852,1918,1851, -1918,1852,1919, -1853,1919,1852, -1919,1853,1920, -1854,1920,1853, -1920,1854,1921, -1855,1921,1854, -1921,1855,1922, -1856,1922,1855, -1922,1856,1923, -1857,1923,1856, -1923,1857,1924, -1858,1924,1857, -1924,1858,1925, -1859,1925,1858, -1925,1859,1926, -1860,1926,1859, -1926,1860,1927, -1861,1927,1860, -1927,1861,1928, -1862,1928,1861, -1928,1862,1929, -1863,1929,1862, -1929,1863,1930, -1864,1930,1863, -1930,1864,1931, -1865,1931,1864, -1931,1865,1932, -1866,1932,1865, -1932,1866,1933, -1867,1933,1866, -1933,1867,1934, -1868,1934,1867, -1934,1868,1935, -1869,1935,1868, -1935,1869,1936, -1870,1936,1869, -1936,1870,1937, -1871,1937,1870, -1937,1871,1938, -1872,1938,1871, -1938,1872,1939, -1873,1939,1872, -1939,1873,1940, -1874,1940,1873, -1940,1874,1941, -1875,1941,1874, -1941,1875,1942, -1876,1942,1875, -1942,1876,1943, -1877,1943,1876, -1943,1877,1944, -1878,1944,1877, -1944,1878,1945, -1879,1945,1878, -1945,1879,1946, -1880,1946,1879, -1946,1880,1947, -1881,1947,1880, -1947,1881,1948, -1882,1948,1881, -1948,1882,1949, -1883,1949,1882, -1949,1883,1950, -1884,1950,1883, -1950,1884,1951, -1885,1951,1884, -1951,1885,1952, -1886,1952,1885, -1952,1886,1953, -1887,1953,1886, -1953,1887,1954, -1888,1954,1887, -1954,1888,1955, -1889,1955,1888, -1955,1889,1956, -1890,1956,1889, -1956,1890,1957, -1891,1957,1890, -1957,1891,1958, -1892,1958,1891, -1958,1892,1959, -1893,1959,1892, -1959,1893,1960, -1894,1960,1893, -1960,1894,1961, -1895,1961,1894, -1961,1895,1962, -1896,1962,1895, -1962,1896,1963, -1897,1963,1896, -1963,1897,1964, -1898,1964,1897, -1964,1898,1965, -1899,1965,1898, -1965,1899,1966, -1900,1966,1899, -1966,1900,1967, -1901,1967,1900, -1967,1901,1968, -1902,1968,1901, -1968,1902,1969, -1903,1969,1902, -1969,1903,1970, -1904,1970,1903, -1970,1904,1971, -1905,1971,1904, -1971,1905,1972, -1906,1972,1905, -1972,1906,1973, -1907,1973,1906, -1973,1907,1974, -1908,1974,1907, -1974,1908,1975, -1909,1975,1908, -1975,1909,1976, -1910,1976,1909, -1976,1910,1977, -1911,1977,1910, -1977,1911,1978, -1912,1978,1911, -1978,1912,1979, -1913,1979,1912, -1980,1914,1981, -1915,1981,1914, -1981,1915,1982, -1916,1982,1915, -1982,1916,1983, -1917,1983,1916, -1983,1917,1984, -1918,1984,1917, -1984,1918,1985, -1919,1985,1918, -1985,1919,1986, -1920,1986,1919, -1986,1920,1987, -1921,1987,1920, -1987,1921,1988, -1922,1988,1921, -1988,1922,1989, -1923,1989,1922, -1989,1923,1990, -1924,1990,1923, -1990,1924,1991, -1925,1991,1924, -1991,1925,1992, -1926,1992,1925, -1992,1926,1993, -1927,1993,1926, -1993,1927,1994, -1928,1994,1927, -1994,1928,1995, -1929,1995,1928, -1995,1929,1996, -1930,1996,1929, -1996,1930,1997, -1931,1997,1930, -1997,1931,1998, -1932,1998,1931, -1998,1932,1999, -1933,1999,1932, -1999,1933,2000, -1934,2000,1933, -2000,1934,2001, -1935,2001,1934, -2001,1935,2002, -1936,2002,1935, -2002,1936,2003, -1937,2003,1936, -2003,1937,2004, -1938,2004,1937, -2004,1938,2005, -1939,2005,1938, -2005,1939,2006, -1940,2006,1939, -2006,1940,2007, -1941,2007,1940, -2007,1941,2008, -1942,2008,1941, -2008,1942,2009, -1943,2009,1942, -2009,1943,2010, -1944,2010,1943, -2010,1944,2011, -1945,2011,1944, -2011,1945,2012, -1946,2012,1945, -2012,1946,2013, -1947,2013,1946, -2013,1947,2014, -1948,2014,1947, -2014,1948,2015, -1949,2015,1948, -2015,1949,2016, -1950,2016,1949, -2016,1950,2017, -1951,2017,1950, -2017,1951,2018, -1952,2018,1951, -2018,1952,2019, -1953,2019,1952, -2019,1953,2020, -1954,2020,1953, -2020,1954,2021, -1955,2021,1954, -2021,1955,2022, -1956,2022,1955, -2022,1956,2023, -1957,2023,1956, -2023,1957,2024, -1958,2024,1957, -2024,1958,2025, -1959,2025,1958, -2025,1959,2026, -1960,2026,1959, -2026,1960,2027, -1961,2027,1960, -2027,1961,2028, -1962,2028,1961, -2028,1962,2029, -1963,2029,1962, -2029,1963,2030, -1964,2030,1963, -2030,1964,2031, -1965,2031,1964, -2031,1965,2032, -1966,2032,1965, -2032,1966,2033, -1967,2033,1966, -2033,1967,2034, -1968,2034,1967, -2034,1968,2035, -1969,2035,1968, -2035,1969,2036, -1970,2036,1969, -2036,1970,2037, -1971,2037,1970, -2037,1971,2038, -1972,2038,1971, -2038,1972,2039, -1973,2039,1972, -2039,1973,2040, -1974,2040,1973, -2040,1974,2041, -1975,2041,1974, -2041,1975,2042, -1976,2042,1975, -2042,1976,2043, -1977,2043,1976, -2043,1977,2044, -1978,2044,1977, -2044,1978,2045, -1979,2045,1978, -2046,1980,2047, -1981,2047,1980, -2047,1981,2048, -1982,2048,1981, -2048,1982,2049, -1983,2049,1982, -2049,1983,2050, -1984,2050,1983, -2050,1984,2051, -1985,2051,1984, -2051,1985,2052, -1986,2052,1985, -2052,1986,2053, -1987,2053,1986, -2053,1987,2054, -1988,2054,1987, -2054,1988,2055, -1989,2055,1988, -2055,1989,2056, -1990,2056,1989, -2056,1990,2057, -1991,2057,1990, -2057,1991,2058, -1992,2058,1991, -2058,1992,2059, -1993,2059,1992, -2059,1993,2060, -1994,2060,1993, -2060,1994,2061, -1995,2061,1994, -2061,1995,2062, -1996,2062,1995, -2062,1996,2063, -1997,2063,1996, -2063,1997,2064, -1998,2064,1997, -2064,1998,2065, -1999,2065,1998, -2065,1999,2066, -2000,2066,1999, -2066,2000,2067, -2001,2067,2000, -2067,2001,2068, -2002,2068,2001, -2068,2002,2069, -2003,2069,2002, -2069,2003,2070, -2004,2070,2003, -2070,2004,2071, -2005,2071,2004, -2071,2005,2072, -2006,2072,2005, -2072,2006,2073, -2007,2073,2006, -2073,2007,2074, -2008,2074,2007, -2074,2008,2075, -2009,2075,2008, -2075,2009,2076, -2010,2076,2009, -2076,2010,2077, -2011,2077,2010, -2077,2011,2078, -2012,2078,2011, -2078,2012,2079, -2013,2079,2012, -2079,2013,2080, -2014,2080,2013, -2080,2014,2081, -2015,2081,2014, -2081,2015,2082, -2016,2082,2015, -2082,2016,2083, -2017,2083,2016, -2083,2017,2084, -2018,2084,2017, -2084,2018,2085, -2019,2085,2018, -2085,2019,2086, -2020,2086,2019, -2086,2020,2087, -2021,2087,2020, -2087,2021,2088, -2022,2088,2021, -2088,2022,2089, -2023,2089,2022, -2089,2023,2090, -2024,2090,2023, -2090,2024,2091, -2025,2091,2024, -2091,2025,2092, -2026,2092,2025, -2092,2026,2093, -2027,2093,2026, -2093,2027,2094, -2028,2094,2027, -2094,2028,2095, -2029,2095,2028, -2095,2029,2096, -2030,2096,2029, -2096,2030,2097, -2031,2097,2030, -2097,2031,2098, -2032,2098,2031, -2098,2032,2099, -2033,2099,2032, -2099,2033,2100, -2034,2100,2033, -2100,2034,2101, -2035,2101,2034, -2101,2035,2102, -2036,2102,2035, -2102,2036,2103, -2037,2103,2036, -2103,2037,2104, -2038,2104,2037, -2104,2038,2105, -2039,2105,2038, -2105,2039,2106, -2040,2106,2039, -2106,2040,2107, -2041,2107,2040, -2107,2041,2108, -2042,2108,2041, -2108,2042,2109, -2043,2109,2042, -2109,2043,2110, -2044,2110,2043, -2110,2044,2111, -2045,2111,2044, -2112,2046,2113, -2047,2113,2046, -2113,2047,2114, -2048,2114,2047, -2114,2048,2115, -2049,2115,2048, -2115,2049,2116, -2050,2116,2049, -2116,2050,2117, -2051,2117,2050, -2117,2051,2118, -2052,2118,2051, -2118,2052,2119, -2053,2119,2052, -2119,2053,2120, -2054,2120,2053, -2120,2054,2121, -2055,2121,2054, -2121,2055,2122, -2056,2122,2055, -2122,2056,2123, -2057,2123,2056, -2123,2057,2124, -2058,2124,2057, -2124,2058,2125, -2059,2125,2058, -2125,2059,2126, -2060,2126,2059, -2126,2060,2127, -2061,2127,2060, -2127,2061,2128, -2062,2128,2061, -2128,2062,2129, -2063,2129,2062, -2129,2063,2130, -2064,2130,2063, -2130,2064,2131, -2065,2131,2064, -2131,2065,2132, -2066,2132,2065, -2132,2066,2133, -2067,2133,2066, -2133,2067,2134, -2068,2134,2067, -2134,2068,2135, -2069,2135,2068, -2135,2069,2136, -2070,2136,2069, -2136,2070,2137, -2071,2137,2070, -2137,2071,2138, -2072,2138,2071, -2138,2072,2139, -2073,2139,2072, -2139,2073,2140, -2074,2140,2073, -2140,2074,2141, -2075,2141,2074, -2141,2075,2142, -2076,2142,2075, -2142,2076,2143, -2077,2143,2076, -2143,2077,2144, -2078,2144,2077, -2144,2078,2145, -2079,2145,2078, -2145,2079,2146, -2080,2146,2079, -2146,2080,2147, -2081,2147,2080, -2147,2081,2148, -2082,2148,2081, -2148,2082,2149, -2083,2149,2082, -2149,2083,2150, -2084,2150,2083, -2150,2084,2151, -2085,2151,2084, -2151,2085,2152, -2086,2152,2085, -2152,2086,2153, -2087,2153,2086, -2153,2087,2154, -2088,2154,2087, -2154,2088,2155, -2089,2155,2088, -2155,2089,2156, -2090,2156,2089, -2156,2090,2157, -2091,2157,2090, -2157,2091,2158, -2092,2158,2091, -2158,2092,2159, -2093,2159,2092, -2159,2093,2160, -2094,2160,2093, -2160,2094,2161, -2095,2161,2094, -2161,2095,2162, -2096,2162,2095, -2162,2096,2163, -2097,2163,2096, -2163,2097,2164, -2098,2164,2097, -2164,2098,2165, -2099,2165,2098, -2165,2099,2166, -2100,2166,2099, -2166,2100,2167, -2101,2167,2100, -2167,2101,2168, -2102,2168,2101, -2168,2102,2169, -2103,2169,2102, -2169,2103,2170, -2104,2170,2103, -2170,2104,2171, -2105,2171,2104, -2171,2105,2172, -2106,2172,2105, -2172,2106,2173, -2107,2173,2106, -2173,2107,2174, -2108,2174,2107, -2174,2108,2175, -2109,2175,2108, -2175,2109,2176, -2110,2176,2109, -2176,2110,2177, -2111,2177,2110, -2178,2112,2179, -2113,2179,2112, -2179,2113,2180, -2114,2180,2113, -2180,2114,2181, -2115,2181,2114, -2181,2115,2182, -2116,2182,2115, -2182,2116,2183, -2117,2183,2116, -2183,2117,2184, -2118,2184,2117, -2184,2118,2185, -2119,2185,2118, -2185,2119,2186, -2120,2186,2119, -2186,2120,2187, -2121,2187,2120, -2187,2121,2188, -2122,2188,2121, -2188,2122,2189, -2123,2189,2122, -2189,2123,2190, -2124,2190,2123, -2190,2124,2191, -2125,2191,2124, -2191,2125,2192, -2126,2192,2125, -2192,2126,2193, -2127,2193,2126, -2193,2127,2194, -2128,2194,2127, -2194,2128,2195, -2129,2195,2128, -2195,2129,2196, -2130,2196,2129, -2196,2130,2197, -2131,2197,2130, -2197,2131,2198, -2132,2198,2131, -2198,2132,2199, -2133,2199,2132, -2199,2133,2200, -2134,2200,2133, -2200,2134,2201, -2135,2201,2134, -2201,2135,2202, -2136,2202,2135, -2202,2136,2203, -2137,2203,2136, -2203,2137,2204, -2138,2204,2137, -2204,2138,2205, -2139,2205,2138, -2205,2139,2206, -2140,2206,2139, -2206,2140,2207, -2141,2207,2140, -2207,2141,2208, -2142,2208,2141, -2208,2142,2209, -2143,2209,2142, -2209,2143,2210, -2144,2210,2143, -2210,2144,2211, -2145,2211,2144, -2211,2145,2212, -2146,2212,2145, -2212,2146,2213, -2147,2213,2146, -2213,2147,2214, -2148,2214,2147, -2214,2148,2215, -2149,2215,2148, -2215,2149,2216, -2150,2216,2149, -2216,2150,2217, -2151,2217,2150, -2217,2151,2218, -2152,2218,2151, -2218,2152,2219, -2153,2219,2152, -2219,2153,2220, -2154,2220,2153, -2220,2154,2221, -2155,2221,2154, -2221,2155,2222, -2156,2222,2155, -2222,2156,2223, -2157,2223,2156, -2223,2157,2224, -2158,2224,2157, -2224,2158,2225, -2159,2225,2158, -2225,2159,2226, -2160,2226,2159, -2226,2160,2227, -2161,2227,2160, -2227,2161,2228, -2162,2228,2161, -2228,2162,2229, -2163,2229,2162, -2229,2163,2230, -2164,2230,2163, -2230,2164,2231, -2165,2231,2164, -2231,2165,2232, -2166,2232,2165, -2232,2166,2233, -2167,2233,2166, -2233,2167,2234, -2168,2234,2167, -2234,2168,2235, -2169,2235,2168, -2235,2169,2236, -2170,2236,2169, -2236,2170,2237, -2171,2237,2170, -2237,2171,2238, -2172,2238,2171, -2238,2172,2239, -2173,2239,2172, -2239,2173,2240, -2174,2240,2173, -2240,2174,2241, -2175,2241,2174, -2241,2175,2242, -2176,2242,2175, -2242,2176,2243, -2177,2243,2176, -2244,2178,2245, -2179,2245,2178, -2245,2179,2246, -2180,2246,2179, -2246,2180,2247, -2181,2247,2180, -2247,2181,2248, -2182,2248,2181, -2248,2182,2249, -2183,2249,2182, -2249,2183,2250, -2184,2250,2183, -2250,2184,2251, -2185,2251,2184, -2251,2185,2252, -2186,2252,2185, -2252,2186,2253, -2187,2253,2186, -2253,2187,2254, -2188,2254,2187, -2254,2188,2255, -2189,2255,2188, -2255,2189,2256, -2190,2256,2189, -2256,2190,2257, -2191,2257,2190, -2257,2191,2258, -2192,2258,2191, -2258,2192,2259, -2193,2259,2192, -2259,2193,2260, -2194,2260,2193, -2260,2194,2261, -2195,2261,2194, -2261,2195,2262, -2196,2262,2195, -2262,2196,2263, -2197,2263,2196, -2263,2197,2264, -2198,2264,2197, -2264,2198,2265, -2199,2265,2198, -2265,2199,2266, -2200,2266,2199, -2266,2200,2267, -2201,2267,2200, -2267,2201,2268, -2202,2268,2201, -2268,2202,2269, -2203,2269,2202, -2269,2203,2270, -2204,2270,2203, -2270,2204,2271, -2205,2271,2204, -2271,2205,2272, -2206,2272,2205, -2272,2206,2273, -2207,2273,2206, -2273,2207,2274, -2208,2274,2207, -2274,2208,2275, -2209,2275,2208, -2275,2209,2276, -2210,2276,2209, -2276,2210,2277, -2211,2277,2210, -2277,2211,2278, -2212,2278,2211, -2278,2212,2279, -2213,2279,2212, -2279,2213,2280, -2214,2280,2213, -2280,2214,2281, -2215,2281,2214, -2281,2215,2282, -2216,2282,2215, -2282,2216,2283, -2217,2283,2216, -2283,2217,2284, -2218,2284,2217, -2284,2218,2285, -2219,2285,2218, -2285,2219,2286, -2220,2286,2219, -2286,2220,2287, -2221,2287,2220, -2287,2221,2288, -2222,2288,2221, -2288,2222,2289, -2223,2289,2222, -2289,2223,2290, -2224,2290,2223, -2290,2224,2291, -2225,2291,2224, -2291,2225,2292, -2226,2292,2225, -2292,2226,2293, -2227,2293,2226, -2293,2227,2294, -2228,2294,2227, -2294,2228,2295, -2229,2295,2228, -2295,2229,2296, -2230,2296,2229, -2296,2230,2297, -2231,2297,2230, -2297,2231,2298, -2232,2298,2231, -2298,2232,2299, -2233,2299,2232, -2299,2233,2300, -2234,2300,2233, -2300,2234,2301, -2235,2301,2234, -2301,2235,2302, -2236,2302,2235, -2302,2236,2303, -2237,2303,2236, -2303,2237,2304, -2238,2304,2237, -2304,2238,2305, -2239,2305,2238, -2305,2239,2306, -2240,2306,2239, -2306,2240,2307, -2241,2307,2240, -2307,2241,2308, -2242,2308,2241, -2308,2242,2309, -2243,2309,2242, -}; - -#define Landscape07VtxCount 2240 -#define Landscape07IdxCount 12852 - -btScalar Landscape07Vtx[] = { -3.90625f,49.6769f,-121.094f, -3.90625f,48.3887f,-117.188f, -7.8125f,48.8687f,-121.094f, -7.8125f,48.004f,-117.188f, -11.7188f,47.3453f,-121.094f, -11.7188f,46.8723f,-117.188f, -15.625f,44.9132f,-121.094f, -15.625f,45.5005f,-117.188f, -19.5313f,43.1526f,-121.094f, -19.5313f,43.3644f,-117.188f, -23.4375f,41.3946f,-121.094f, -23.4375f,42.3352f,-117.188f, -27.3438f,40.1349f,-121.094f, -27.3438f,41.1562f,-117.188f, -31.25f,39.2733f,-121.094f, -31.25f,39.1736f,-117.188f, -35.1563f,38.3718f,-121.094f, -35.1563f,38.0627f,-117.188f, -39.0625f,37.16f,-121.094f, -39.0625f,36.4728f,-117.188f, -42.9688f,35.2678f,-121.094f, -42.9688f,34.8001f,-117.188f, -46.875f,32.8529f,-121.094f, -46.875f,32.5103f,-117.188f, -50.7813f,32.0924f,-121.094f, -50.7813f,31.6328f,-117.188f, -54.6875f,33.2013f,-121.094f, -54.6875f,31.6106f,-117.188f, -58.5938f,34.1499f,-121.094f, -58.5938f,32.3004f,-117.188f, -62.5f,33.7675f,-121.094f, -62.5f,32.696f,-117.188f, -66.4063f,34.4892f,-121.094f, -66.4063f,33.3795f,-117.188f, -70.3125f,34.7441f,-121.094f, -70.3125f,33.9696f,-117.188f, -74.2188f,35.4435f,-121.094f, -74.2188f,34.9211f,-117.188f, -78.125f,36.6876f,-121.094f, -78.125f,36.7686f,-117.188f, -82.0313f,37.8831f,-121.094f, -82.0313f,37.7676f,-117.188f, -85.9375f,37.8533f,-121.094f, -85.9375f,37.8174f,-117.188f, -89.8438f,38.2467f,-121.094f, -89.8438f,38.2878f,-117.188f, -93.75f,39.5884f,-121.094f, -93.75f,39.6151f,-117.188f, -97.6563f,39.7164f,-121.094f, -97.6563f,39.7422f,-117.188f, -101.563f,40.296f,-121.094f, -101.563f,40.9611f,-117.188f, -105.469f,40.7222f,-121.094f, -105.469f,40.8932f,-117.188f, -109.375f,40.1304f,-121.094f, -109.375f,40.6603f,-117.188f, -113.281f,39.4566f,-121.094f, -113.281f,40.2935f,-117.188f, -117.188f,39.003f,-121.094f, -117.188f,39.8681f,-117.188f, -121.094f,38.091f,-121.094f, -121.094f,39.0965f,-117.188f, -125.0f,37.216f,-121.094f, -125.0f,37.1333f,-117.188f, -128.906f,35.4631f,-121.094f, -128.906f,35.5222f,-117.188f, -132.813f,33.4698f,-121.094f, -132.813f,33.9068f,-117.188f, -136.719f,31.5516f,-121.094f, -136.719f,32.2618f,-117.188f, -140.625f,28.6676f,-121.094f, -140.625f,29.8657f,-117.188f, -144.531f,26.5656f,-121.094f, -144.531f,28.1704f,-117.188f, -148.438f,24.1962f,-121.094f, -148.438f,27.1495f,-117.188f, -152.344f,22.2193f,-121.094f, -152.344f,24.5217f,-117.188f, -156.25f,20.1818f,-121.094f, -156.25f,22.0419f,-117.188f, -160.156f,17.6116f,-121.094f, -160.156f,19.9238f,-117.188f, -164.063f,15.5398f,-121.094f, -164.063f,17.6875f,-117.188f, -167.969f,13.7972f,-121.094f, -167.969f,15.5636f,-117.188f, -171.875f,11.7291f,-121.094f, -171.875f,13.5497f,-117.188f, -175.781f,9.31738f,-121.094f, -175.781f,11.2761f,-117.188f, -179.688f,6.60425f,-121.094f, -179.688f,8.95864f,-117.188f, -183.594f,4.50127f,-121.094f, -183.594f,7.04623f,-117.188f, -187.5f,2.77579f,-121.094f, -187.5f,4.83635f,-117.188f, -191.406f,1.39292f,-121.094f, -191.406f,2.76046f,-117.188f, -195.313f,-1.41093f,-121.094f, -195.313f,0.190119f,-117.188f, -199.219f,-2.1383f,-121.094f, -199.219f,-0.558379f,-117.188f, -203.125f,-2.43203f,-121.094f, -203.125f,-1.03303f,-117.188f, -207.031f,-3.74398f,-121.094f, -207.031f,-2.17563f,-117.188f, -210.938f,-4.31531f,-121.094f, -210.938f,-1.91155f,-117.188f, -214.844f,-5.42965f,-121.094f, -214.844f,-3.00018f,-117.188f, -218.75f,-6.70056f,-121.094f, -218.75f,-4.26691f,-117.188f, -222.656f,-6.19564f,-121.094f, -222.656f,-5.15855f,-117.188f, -226.563f,-4.68254f,-121.094f, -226.563f,-3.46348f,-117.188f, -230.469f,-3.31858f,-121.094f, -230.469f,-2.16077f,-117.188f, -234.375f,-3.88428f,-121.094f, -234.375f,-1.47785f,-117.188f, -238.281f,-3.80321f,-121.094f, -238.281f,-1.78424f,-117.188f, -242.188f,-3.43571f,-121.094f, -242.188f,-1.00317f,-117.188f, -246.094f,-3.77556f,-121.094f, -246.094f,-1.97981f,-117.188f, -250.0f,-3.83169f,-121.094f, -250.0f,-2.29372f,-117.188f, -3.90625f,50.3021f,-125.0f, -7.8125f,50.0186f,-125.0f, -11.7188f,47.8026f,-125.0f, -15.625f,45.4122f,-125.0f, -19.5313f,42.7204f,-125.0f, -23.4375f,42.1093f,-125.0f, -27.3438f,41.0672f,-125.0f, -31.25f,40.3016f,-125.0f, -35.1563f,38.401f,-125.0f, -39.0625f,36.5811f,-125.0f, -42.9688f,35.0771f,-125.0f, -46.875f,32.9255f,-125.0f, -50.7813f,31.2736f,-125.0f, -54.6875f,33.4622f,-125.0f, -58.5938f,34.314f,-125.0f, -62.5f,34.4185f,-125.0f, -66.4063f,34.621f,-125.0f, -70.3125f,34.9532f,-125.0f, -74.2188f,35.7305f,-125.0f, -78.125f,37.4446f,-125.0f, -82.0313f,37.6824f,-125.0f, -85.9375f,37.9835f,-125.0f, -89.8438f,38.5713f,-125.0f, -93.75f,39.56f,-125.0f, -97.6563f,40.0645f,-125.0f, -101.563f,39.9237f,-125.0f, -105.469f,39.8912f,-125.0f, -109.375f,39.9678f,-125.0f, -113.281f,39.7665f,-125.0f, -117.188f,38.758f,-125.0f, -121.094f,37.6738f,-125.0f, -125.0f,36.834f,-125.0f, -128.906f,34.7637f,-125.0f, -132.813f,31.9691f,-125.0f, -136.719f,30.7311f,-125.0f, -140.625f,27.9768f,-125.0f, -144.531f,25.22f,-125.0f, -148.438f,22.2616f,-125.0f, -152.344f,20.6399f,-125.0f, -156.25f,18.9363f,-125.0f, -160.156f,16.8778f,-125.0f, -164.063f,14.7425f,-125.0f, -167.969f,12.4299f,-125.0f, -171.875f,10.1017f,-125.0f, -175.781f,7.82169f,-125.0f, -179.688f,5.46502f,-125.0f, -183.594f,2.71076f,-125.0f, -187.5f,1.07736f,-125.0f, -191.406f,-0.592638f,-125.0f, -195.313f,-2.99173f,-125.0f, -199.219f,-4.30517f,-125.0f, -203.125f,-4.79591f,-125.0f, -207.031f,-6.32671f,-125.0f, -210.938f,-6.6914f,-125.0f, -214.844f,-8.34188f,-125.0f, -218.75f,-8.94371f,-125.0f, -222.656f,-7.16417f,-125.0f, -226.563f,-5.53904f,-125.0f, -230.469f,-5.10207f,-125.0f, -234.375f,-5.77507f,-125.0f, -238.281f,-5.5948f,-125.0f, -242.188f,-5.81224f,-125.0f, -246.094f,-5.48291f,-125.0f, -250.0f,-5.3221f,-125.0f, -3.90625f,50.4716f,-128.906f, -7.8125f,50.3922f,-128.906f, -11.7188f,48.0997f,-128.906f, -15.625f,44.9895f,-128.906f, -19.5313f,43.3038f,-128.906f, -23.4375f,42.8795f,-128.906f, -27.3438f,42.0905f,-128.906f, -31.25f,40.0566f,-128.906f, -35.1563f,37.7024f,-128.906f, -39.0625f,35.7533f,-128.906f, -42.9688f,32.9949f,-128.906f, -46.875f,31.7476f,-128.906f, -50.7813f,30.9413f,-128.906f, -54.6875f,31.9364f,-128.906f, -58.5938f,33.2028f,-128.906f, -62.5f,34.0103f,-128.906f, -66.4063f,34.3126f,-128.906f, -70.3125f,34.6096f,-128.906f, -74.2188f,35.8861f,-128.906f, -78.125f,36.5754f,-128.906f, -82.0313f,36.9009f,-128.906f, -85.9375f,37.369f,-128.906f, -89.8438f,38.2734f,-128.906f, -93.75f,38.7518f,-128.906f, -97.6563f,39.7576f,-128.906f, -101.563f,39.3413f,-128.906f, -105.469f,40.4224f,-128.906f, -109.375f,40.506f,-128.906f, -113.281f,39.7509f,-128.906f, -117.188f,38.6208f,-128.906f, -121.094f,37.1513f,-128.906f, -125.0f,36.003f,-128.906f, -128.906f,34.1307f,-128.906f, -132.813f,31.5523f,-128.906f, -136.719f,29.2003f,-128.906f, -140.625f,26.3718f,-128.906f, -144.531f,24.0851f,-128.906f, -148.438f,21.0492f,-128.906f, -152.344f,18.9709f,-128.906f, -156.25f,16.5536f,-128.906f, -160.156f,14.5588f,-128.906f, -164.063f,12.8386f,-128.906f, -167.969f,11.3092f,-128.906f, -171.875f,9.19396f,-128.906f, -175.781f,6.84617f,-128.906f, -179.688f,3.80062f,-128.906f, -183.594f,0.734751f,-128.906f, -187.5f,0.121523f,-128.906f, -191.406f,-1.9203f,-128.906f, -195.313f,-5.35291f,-128.906f, -199.219f,-7.06575f,-128.906f, -203.125f,-8.27325f,-128.906f, -207.031f,-8.82541f,-128.906f, -210.938f,-9.36185f,-128.906f, -214.844f,-10.8597f,-128.906f, -218.75f,-10.695f,-128.906f, -222.656f,-8.91012f,-128.906f, -226.563f,-8.24825f,-128.906f, -230.469f,-7.79624f,-128.906f, -234.375f,-6.74578f,-128.906f, -238.281f,-7.41285f,-128.906f, -242.188f,-7.01421f,-128.906f, -246.094f,-6.91669f,-128.906f, -250.0f,-6.09876f,-128.906f, -3.90625f,49.1054f,-132.813f, -7.8125f,48.771f,-132.813f, -11.7188f,46.9765f,-132.813f, -15.625f,44.4736f,-132.813f, -19.5313f,43.2026f,-132.813f, -23.4375f,42.2898f,-132.813f, -27.3438f,41.7492f,-132.813f, -31.25f,39.5792f,-132.813f, -35.1563f,36.5653f,-132.813f, -39.0625f,33.5612f,-132.813f, -42.9688f,31.9604f,-132.813f, -46.875f,30.953f,-132.813f, -50.7813f,30.5912f,-132.813f, -54.6875f,31.76f,-132.813f, -58.5938f,33.0843f,-132.813f, -62.5f,33.4323f,-132.813f, -66.4063f,33.9264f,-132.813f, -70.3125f,33.9268f,-132.813f, -74.2188f,33.8122f,-132.813f, -78.125f,34.9456f,-132.813f, -82.0313f,35.6308f,-132.813f, -85.9375f,35.8317f,-132.813f, -89.8438f,36.8255f,-132.813f, -93.75f,37.5781f,-132.813f, -97.6563f,39.0469f,-132.813f, -101.563f,38.905f,-132.813f, -105.469f,39.3656f,-132.813f, -109.375f,39.9706f,-132.813f, -113.281f,38.8077f,-132.813f, -117.188f,37.8378f,-132.813f, -121.094f,36.8368f,-132.813f, -125.0f,35.8474f,-132.813f, -128.906f,33.8502f,-132.813f, -132.813f,31.6251f,-132.813f, -136.719f,28.2781f,-132.813f, -140.625f,24.9841f,-132.813f, -144.531f,22.2281f,-132.813f, -148.438f,19.2974f,-132.813f, -152.344f,17.1516f,-132.813f, -156.25f,14.7654f,-132.813f, -160.156f,13.1833f,-132.813f, -164.063f,11.0184f,-132.813f, -167.969f,9.1589f,-132.813f, -171.875f,6.82631f,-132.813f, -175.781f,4.30633f,-132.813f, -179.688f,2.04751f,-132.813f, -183.594f,-0.74554f,-132.813f, -187.5f,-1.24688f,-132.813f, -191.406f,-3.70884f,-132.813f, -195.313f,-7.20423f,-132.813f, -199.219f,-9.63057f,-132.813f, -203.125f,-10.6411f,-132.813f, -207.031f,-11.1561f,-132.813f, -210.938f,-11.9998f,-132.813f, -214.844f,-13.1369f,-132.813f, -218.75f,-12.4543f,-132.813f, -222.656f,-11.5031f,-132.813f, -226.563f,-11.4632f,-132.813f, -230.469f,-10.5609f,-132.813f, -234.375f,-9.96017f,-132.813f, -238.281f,-9.64047f,-132.813f, -242.188f,-8.79112f,-132.813f, -246.094f,-8.33514f,-132.813f, -250.0f,-6.32649f,-132.813f, -3.90625f,47.9f,-136.719f, -7.8125f,47.0423f,-136.719f, -11.7188f,46.1087f,-136.719f, -15.625f,42.8209f,-136.719f, -19.5313f,41.8846f,-136.719f, -23.4375f,41.4071f,-136.719f, -27.3438f,39.6798f,-136.719f, -31.25f,38.1881f,-136.719f, -35.1563f,35.3952f,-136.719f, -39.0625f,31.8297f,-136.719f, -42.9688f,31.014f,-136.719f, -46.875f,29.29f,-136.719f, -50.7813f,29.4455f,-136.719f, -54.6875f,30.368f,-136.719f, -58.5938f,31.6261f,-136.719f, -62.5f,31.8803f,-136.719f, -66.4063f,32.8102f,-136.719f, -70.3125f,33.4331f,-136.719f, -74.2188f,33.19f,-136.719f, -78.125f,33.74f,-136.719f, -82.0313f,35.1047f,-136.719f, -85.9375f,36.2436f,-136.719f, -89.8438f,36.4928f,-136.719f, -93.75f,36.192f,-136.719f, -97.6563f,37.547f,-136.719f, -101.563f,38.0632f,-136.719f, -105.469f,38.6551f,-136.719f, -109.375f,38.4484f,-136.719f, -113.281f,37.8421f,-136.719f, -117.188f,37.5588f,-136.719f, -121.094f,37.278f,-136.719f, -125.0f,35.3541f,-136.719f, -128.906f,33.0939f,-136.719f, -132.813f,30.522f,-136.719f, -136.719f,27.5957f,-136.719f, -140.625f,24.4595f,-136.719f, -144.531f,21.0335f,-136.719f, -148.438f,18.0163f,-136.719f, -152.344f,15.3659f,-136.719f, -156.25f,13.4036f,-136.719f, -160.156f,11.6819f,-136.719f, -164.063f,9.68686f,-136.719f, -167.969f,7.56782f,-136.719f, -171.875f,4.49435f,-136.719f, -175.781f,1.55284f,-136.719f, -179.688f,0.275057f,-136.719f, -183.594f,-2.20168f,-136.719f, -187.5f,-3.16842f,-136.719f, -191.406f,-5.74212f,-136.719f, -195.313f,-8.33918f,-136.719f, -199.219f,-11.9926f,-136.719f, -203.125f,-13.7382f,-136.719f, -207.031f,-14.2163f,-136.719f, -210.938f,-14.76f,-136.719f, -214.844f,-14.7917f,-136.719f, -218.75f,-15.4594f,-136.719f, -222.656f,-14.7722f,-136.719f, -226.563f,-14.7687f,-136.719f, -230.469f,-13.0502f,-136.719f, -234.375f,-12.7522f,-136.719f, -238.281f,-12.1277f,-136.719f, -242.188f,-11.9805f,-136.719f, -246.094f,-9.26664f,-136.719f, -250.0f,-6.42671f,-136.719f, -3.90625f,47.2681f,-140.625f, -7.8125f,46.3513f,-140.625f, -11.7188f,45.1181f,-140.625f, -15.625f,42.9593f,-140.625f, -19.5313f,40.04f,-140.625f, -23.4375f,38.1657f,-140.625f, -27.3438f,37.2537f,-140.625f, -31.25f,35.6767f,-140.625f, -35.1563f,33.3413f,-140.625f, -39.0625f,30.7556f,-140.625f, -42.9688f,29.0258f,-140.625f, -46.875f,27.8122f,-140.625f, -50.7813f,27.4512f,-140.625f, -54.6875f,28.1912f,-140.625f, -58.5938f,29.8142f,-140.625f, -62.5f,30.1394f,-140.625f, -66.4063f,30.7105f,-140.625f, -70.3125f,31.9295f,-140.625f, -74.2188f,32.6689f,-140.625f, -78.125f,32.9232f,-140.625f, -82.0313f,35.5221f,-140.625f, -85.9375f,36.1785f,-140.625f, -89.8438f,35.864f,-140.625f, -93.75f,35.2473f,-140.625f, -97.6563f,35.6334f,-140.625f, -101.563f,36.5759f,-140.625f, -105.469f,37.2506f,-140.625f, -109.375f,36.7249f,-140.625f, -113.281f,36.4287f,-140.625f, -117.188f,36.6819f,-140.625f, -121.094f,36.4294f,-140.625f, -125.0f,35.2358f,-140.625f, -128.906f,32.9869f,-140.625f, -132.813f,30.156f,-140.625f, -136.719f,27.0471f,-140.625f, -140.625f,23.8554f,-140.625f, -144.531f,20.3993f,-140.625f, -148.438f,16.6224f,-140.625f, -152.344f,13.058f,-140.625f, -156.25f,11.1345f,-140.625f, -160.156f,9.35133f,-140.625f, -164.063f,7.36194f,-140.625f, -167.969f,5.31819f,-140.625f, -171.875f,2.78652f,-140.625f, -175.781f,0.868982f,-140.625f, -179.688f,-1.31465f,-140.625f, -183.594f,-3.64199f,-140.625f, -187.5f,-5.38333f,-140.625f, -191.406f,-8.08251f,-140.625f, -195.313f,-10.9184f,-140.625f, -199.219f,-14.2737f,-140.625f, -203.125f,-16.1495f,-140.625f, -207.031f,-16.9134f,-140.625f, -210.938f,-16.9575f,-140.625f, -214.844f,-17.6023f,-140.625f, -218.75f,-17.6633f,-140.625f, -222.656f,-17.159f,-140.625f, -226.563f,-16.2062f,-140.625f, -230.469f,-15.7685f,-140.625f, -234.375f,-15.0547f,-140.625f, -238.281f,-14.7858f,-140.625f, -242.188f,-12.8534f,-140.625f, -246.094f,-9.20599f,-140.625f, -250.0f,-5.60644f,-140.625f, -3.90625f,45.2398f,-144.531f, -7.8125f,45.0428f,-144.531f, -11.7188f,44.1179f,-144.531f, -15.625f,42.444f,-144.531f, -19.5313f,39.732f,-144.531f, -23.4375f,37.0479f,-144.531f, -27.3438f,34.3624f,-144.531f, -31.25f,33.2513f,-144.531f, -35.1563f,31.1146f,-144.531f, -39.0625f,29.2726f,-144.531f, -42.9688f,27.3159f,-144.531f, -46.875f,27.1241f,-144.531f, -50.7813f,26.6524f,-144.531f, -54.6875f,26.3337f,-144.531f, -58.5938f,27.8201f,-144.531f, -62.5f,27.8456f,-144.531f, -66.4063f,27.8306f,-144.531f, -70.3125f,29.8911f,-144.531f, -74.2188f,31.0667f,-144.531f, -78.125f,32.5778f,-144.531f, -82.0313f,34.5337f,-144.531f, -85.9375f,35.1457f,-144.531f, -89.8438f,34.7649f,-144.531f, -93.75f,34.0929f,-144.531f, -97.6563f,34.2934f,-144.531f, -101.563f,34.8046f,-144.531f, -105.469f,36.2496f,-144.531f, -109.375f,35.8351f,-144.531f, -113.281f,35.8228f,-144.531f, -117.188f,35.7495f,-144.531f, -121.094f,34.832f,-144.531f, -125.0f,34.3351f,-144.531f, -128.906f,32.4744f,-144.531f, -132.813f,29.6967f,-144.531f, -136.719f,26.263f,-144.531f, -140.625f,23.3556f,-144.531f, -144.531f,19.3517f,-144.531f, -148.438f,14.458f,-144.531f, -152.344f,11.2423f,-144.531f, -156.25f,9.75514f,-144.531f, -160.156f,7.96146f,-144.531f, -164.063f,5.67024f,-144.531f, -167.969f,4.08006f,-144.531f, -171.875f,1.71102f,-144.531f, -175.781f,-0.915369f,-144.531f, -179.688f,-2.66343f,-144.531f, -183.594f,-5.5816f,-144.531f, -187.5f,-7.79353f,-144.531f, -191.406f,-10.1772f,-144.531f, -195.313f,-13.5463f,-144.531f, -199.219f,-16.0692f,-144.531f, -203.125f,-17.2505f,-144.531f, -207.031f,-18.7241f,-144.531f, -210.938f,-18.7295f,-144.531f, -214.844f,-19.3f,-144.531f, -218.75f,-20.3181f,-144.531f, -222.656f,-19.4871f,-144.531f, -226.563f,-18.5465f,-144.531f, -230.469f,-17.525f,-144.531f, -234.375f,-16.5076f,-144.531f, -238.281f,-15.0993f,-144.531f, -242.188f,-13.0716f,-144.531f, -246.094f,-9.99063f,-144.531f, -250.0f,-5.64288f,-144.531f, -3.90625f,43.4167f,-148.438f, -7.8125f,43.0193f,-148.438f, -11.7188f,42.6242f,-148.438f, -15.625f,40.8831f,-148.438f, -19.5313f,38.6824f,-148.438f, -23.4375f,36.0177f,-148.438f, -27.3438f,32.9654f,-148.438f, -31.25f,31.3995f,-148.438f, -35.1563f,29.5101f,-148.438f, -39.0625f,27.4588f,-148.438f, -42.9688f,25.129f,-148.438f, -46.875f,25.4533f,-148.438f, -50.7813f,25.7106f,-148.438f, -54.6875f,25.737f,-148.438f, -58.5938f,26.1608f,-148.438f, -62.5f,27.2373f,-148.438f, -66.4063f,27.3635f,-148.438f, -70.3125f,27.7787f,-148.438f, -74.2188f,29.0906f,-148.438f, -78.125f,31.3992f,-148.438f, -82.0313f,32.9373f,-148.438f, -85.9375f,33.743f,-148.438f, -89.8438f,34.4265f,-148.438f, -93.75f,33.525f,-148.438f, -97.6563f,33.8231f,-148.438f, -101.563f,34.6826f,-148.438f, -105.469f,35.0275f,-148.438f, -109.375f,34.4667f,-148.438f, -113.281f,34.7266f,-148.438f, -117.188f,34.0788f,-148.438f, -121.094f,33.2521f,-148.438f, -125.0f,32.1914f,-148.438f, -128.906f,30.7782f,-148.438f, -132.813f,28.8615f,-148.438f, -136.719f,25.3691f,-148.438f, -140.625f,21.5786f,-148.438f, -144.531f,17.2969f,-148.438f, -148.438f,13.1925f,-148.438f, -152.344f,10.0632f,-148.438f, -156.25f,8.32421f,-148.438f, -160.156f,6.57856f,-148.438f, -164.063f,4.18522f,-148.438f, -167.969f,2.25091f,-148.438f, -171.875f,0.445952f,-148.438f, -175.781f,-1.73703f,-148.438f, -179.688f,-3.44886f,-148.438f, -183.594f,-6.77108f,-148.438f, -187.5f,-9.26031f,-148.438f, -191.406f,-12.38f,-148.438f, -195.313f,-14.6453f,-148.438f, -199.219f,-15.8435f,-148.438f, -203.125f,-17.3242f,-148.438f, -207.031f,-19.3932f,-148.438f, -210.938f,-19.7735f,-148.438f, -214.844f,-20.1293f,-148.438f, -218.75f,-20.5777f,-148.438f, -222.656f,-20.7145f,-148.438f, -226.563f,-20.64f,-148.438f, -230.469f,-19.6971f,-148.438f, -234.375f,-17.5016f,-148.438f, -238.281f,-14.644f,-148.438f, -242.188f,-12.3094f,-148.438f, -246.094f,-10.1634f,-148.438f, -250.0f,-6.79503f,-148.438f, -3.90625f,42.7212f,-152.344f, -7.8125f,41.7463f,-152.344f, -11.7188f,40.5249f,-152.344f, -15.625f,39.5225f,-152.344f, -19.5313f,36.6967f,-152.344f, -23.4375f,34.0075f,-152.344f, -27.3438f,31.2054f,-152.344f, -31.25f,28.8502f,-152.344f, -35.1563f,27.2625f,-152.344f, -39.0625f,24.9496f,-152.344f, -42.9688f,23.5897f,-152.344f, -46.875f,23.4709f,-152.344f, -50.7813f,24.179f,-152.344f, -54.6875f,25.021f,-152.344f, -58.5938f,25.6664f,-152.344f, -62.5f,25.7063f,-152.344f, -66.4063f,26.6928f,-152.344f, -70.3125f,26.8261f,-152.344f, -74.2188f,28.2549f,-152.344f, -78.125f,30.3373f,-152.344f, -82.0313f,31.6194f,-152.344f, -85.9375f,32.9189f,-152.344f, -89.8438f,32.7162f,-152.344f, -93.75f,33.0001f,-152.344f, -97.6563f,34.4407f,-152.344f, -101.563f,35.0813f,-152.344f, -105.469f,34.4143f,-152.344f, -109.375f,33.5195f,-152.344f, -113.281f,32.927f,-152.344f, -117.188f,32.6509f,-152.344f, -121.094f,32.6775f,-152.344f, -125.0f,30.887f,-152.344f, -128.906f,28.4296f,-152.344f, -132.813f,26.5539f,-152.344f, -136.719f,24.0803f,-152.344f, -140.625f,20.196f,-152.344f, -144.531f,16.4293f,-152.344f, -148.438f,12.8243f,-152.344f, -152.344f,9.76479f,-152.344f, -156.25f,7.14206f,-152.344f, -160.156f,4.74684f,-152.344f, -164.063f,2.30008f,-152.344f, -167.969f,1.49801f,-152.344f, -171.875f,-0.62719f,-152.344f, -175.781f,-1.99004f,-152.344f, -179.688f,-4.80775f,-152.344f, -183.594f,-8.00986f,-152.344f, -187.5f,-11.4771f,-152.344f, -191.406f,-12.8743f,-152.344f, -195.313f,-13.8733f,-152.344f, -199.219f,-15.0749f,-152.344f, -203.125f,-16.9234f,-152.344f, -207.031f,-18.3258f,-152.344f, -210.938f,-19.6583f,-152.344f, -214.844f,-20.9396f,-152.344f, -218.75f,-21.8071f,-152.344f, -222.656f,-21.4908f,-152.344f, -226.563f,-21.4698f,-152.344f, -230.469f,-19.3773f,-152.344f, -234.375f,-17.0448f,-152.344f, -238.281f,-14.0123f,-152.344f, -242.188f,-11.2372f,-152.344f, -246.094f,-9.11286f,-152.344f, -250.0f,-6.76792f,-152.344f, -3.90625f,41.7368f,-156.25f, -7.8125f,40.8494f,-156.25f, -11.7188f,39.2286f,-156.25f, -15.625f,37.4784f,-156.25f, -19.5313f,36.0345f,-156.25f, -23.4375f,33.9716f,-156.25f, -27.3438f,31.3041f,-156.25f, -31.25f,28.9777f,-156.25f, -35.1563f,26.0934f,-156.25f, -39.0625f,23.7421f,-156.25f, -42.9688f,22.4401f,-156.25f, -46.875f,22.1238f,-156.25f, -50.7813f,22.6669f,-156.25f, -54.6875f,23.7702f,-156.25f, -58.5938f,24.63f,-156.25f, -62.5f,25.2145f,-156.25f, -66.4063f,26.6101f,-156.25f, -70.3125f,27.3664f,-156.25f, -74.2188f,28.121f,-156.25f, -78.125f,29.5305f,-156.25f, -82.0313f,30.4367f,-156.25f, -85.9375f,30.627f,-156.25f, -89.8438f,30.4079f,-156.25f, -93.75f,32.2186f,-156.25f, -97.6563f,33.2916f,-156.25f, -101.563f,33.8066f,-156.25f, -105.469f,32.5269f,-156.25f, -109.375f,32.0751f,-156.25f, -113.281f,31.0298f,-156.25f, -117.188f,30.9869f,-156.25f, -121.094f,30.9826f,-156.25f, -125.0f,29.0676f,-156.25f, -128.906f,26.8988f,-156.25f, -132.813f,24.0771f,-156.25f, -136.719f,21.8087f,-156.25f, -140.625f,18.8179f,-156.25f, -144.531f,14.2483f,-156.25f, -148.438f,10.9236f,-156.25f, -152.344f,9.05948f,-156.25f, -156.25f,6.86087f,-156.25f, -160.156f,3.50699f,-156.25f, -164.063f,1.14903f,-156.25f, -167.969f,-0.639847f,-156.25f, -171.875f,-2.73828f,-156.25f, -175.781f,-4.02372f,-156.25f, -179.688f,-6.15141f,-156.25f, -183.594f,-8.81231f,-156.25f, -187.5f,-10.3417f,-156.25f, -191.406f,-11.1895f,-156.25f, -195.313f,-13.1464f,-156.25f, -199.219f,-14.5401f,-156.25f, -203.125f,-15.9427f,-156.25f, -207.031f,-17.492f,-156.25f, -210.938f,-19.0599f,-156.25f, -214.844f,-21.1101f,-156.25f, -218.75f,-21.3872f,-156.25f, -222.656f,-21.1481f,-156.25f, -226.563f,-20.2836f,-156.25f, -230.469f,-18.1679f,-156.25f, -234.375f,-15.72f,-156.25f, -238.281f,-13.4579f,-156.25f, -242.188f,-10.1453f,-156.25f, -246.094f,-8.09411f,-156.25f, -250.0f,-5.46467f,-156.25f, -3.90625f,40.4755f,-160.156f, -7.8125f,39.299f,-160.156f, -11.7188f,37.3972f,-160.156f, -15.625f,36.1894f,-160.156f, -19.5313f,34.3138f,-160.156f, -23.4375f,32.893f,-160.156f, -27.3438f,30.4515f,-160.156f, -31.25f,28.5808f,-160.156f, -35.1563f,25.8839f,-160.156f, -39.0625f,23.8505f,-160.156f, -42.9688f,22.3057f,-160.156f, -46.875f,21.4418f,-160.156f, -50.7813f,21.9709f,-160.156f, -54.6875f,23.0083f,-160.156f, -58.5938f,24.899f,-160.156f, -62.5f,25.213f,-160.156f, -66.4063f,26.1428f,-160.156f, -70.3125f,27.2675f,-160.156f, -74.2188f,28.0843f,-160.156f, -78.125f,28.9474f,-160.156f, -82.0313f,29.5078f,-160.156f, -85.9375f,29.7468f,-160.156f, -89.8438f,30.8621f,-160.156f, -93.75f,31.5001f,-160.156f, -97.6563f,32.1184f,-160.156f, -101.563f,31.2692f,-160.156f, -105.469f,30.4985f,-160.156f, -109.375f,29.4368f,-160.156f, -113.281f,30.6889f,-160.156f, -117.188f,29.6238f,-160.156f, -121.094f,28.6487f,-160.156f, -125.0f,26.3174f,-160.156f, -128.906f,24.6125f,-160.156f, -132.813f,22.1993f,-160.156f, -136.719f,19.3934f,-160.156f, -140.625f,16.5457f,-160.156f, -144.531f,13.4024f,-160.156f, -148.438f,9.69887f,-160.156f, -152.344f,8.13305f,-160.156f, -156.25f,6.48921f,-160.156f, -160.156f,2.56153f,-160.156f, -164.063f,0.0733139f,-160.156f, -167.969f,-1.11414f,-160.156f, -171.875f,-3.04708f,-160.156f, -175.781f,-6.18654f,-160.156f, -179.688f,-7.4188f,-160.156f, -183.594f,-9.1718f,-160.156f, -187.5f,-9.78027f,-160.156f, -191.406f,-10.5496f,-160.156f, -195.313f,-12.7259f,-160.156f, -199.219f,-13.9068f,-160.156f, -203.125f,-15.4772f,-160.156f, -207.031f,-17.6287f,-160.156f, -210.938f,-19.2502f,-160.156f, -214.844f,-19.5824f,-160.156f, -218.75f,-19.3114f,-160.156f, -222.656f,-19.5266f,-160.156f, -226.563f,-17.8446f,-160.156f, -230.469f,-16.3027f,-160.156f, -234.375f,-14.5015f,-160.156f, -238.281f,-11.9891f,-160.156f, -242.188f,-9.40017f,-160.156f, -246.094f,-6.63794f,-160.156f, -250.0f,-3.71573f,-160.156f, -3.90625f,38.8633f,-164.063f, -7.8125f,37.4382f,-164.063f, -11.7188f,35.7214f,-164.063f, -15.625f,34.0614f,-164.063f, -19.5313f,33.0957f,-164.063f, -23.4375f,32.0369f,-164.063f, -27.3438f,29.7096f,-164.063f, -31.25f,27.3216f,-164.063f, -35.1563f,25.2446f,-164.063f, -39.0625f,23.6071f,-164.063f, -42.9688f,22.2443f,-164.063f, -46.875f,21.2807f,-164.063f, -50.7813f,21.0358f,-164.063f, -54.6875f,22.8177f,-164.063f, -58.5938f,24.4434f,-164.063f, -62.5f,25.1375f,-164.063f, -66.4063f,25.3266f,-164.063f, -70.3125f,26.6102f,-164.063f, -74.2188f,27.6569f,-164.063f, -78.125f,27.8248f,-164.063f, -82.0313f,28.0421f,-164.063f, -85.9375f,29.1719f,-164.063f, -89.8438f,29.9529f,-164.063f, -93.75f,30.947f,-164.063f, -97.6563f,30.6189f,-164.063f, -101.563f,29.7913f,-164.063f, -105.469f,27.6858f,-164.063f, -109.375f,27.3234f,-164.063f, -113.281f,27.8148f,-164.063f, -117.188f,27.3571f,-164.063f, -121.094f,26.1572f,-164.063f, -125.0f,23.8557f,-164.063f, -128.906f,21.6383f,-164.063f, -132.813f,19.0681f,-164.063f, -136.719f,16.7352f,-164.063f, -140.625f,14.4004f,-164.063f, -144.531f,11.082f,-164.063f, -148.438f,8.38754f,-164.063f, -152.344f,7.0054f,-164.063f, -156.25f,4.95122f,-164.063f, -160.156f,2.47298f,-164.063f, -164.063f,0.777691f,-164.063f, -167.969f,-1.44055f,-164.063f, -171.875f,-3.57218f,-164.063f, -175.781f,-6.3396f,-164.063f, -179.688f,-7.49937f,-164.063f, -183.594f,-9.17485f,-164.063f, -187.5f,-9.92705f,-164.063f, -191.406f,-11.0737f,-164.063f, -195.313f,-12.8264f,-164.063f, -199.219f,-14.9306f,-164.063f, -203.125f,-15.9553f,-164.063f, -207.031f,-17.0898f,-164.063f, -210.938f,-18.5283f,-164.063f, -214.844f,-18.545f,-164.063f, -218.75f,-18.553f,-164.063f, -222.656f,-17.5725f,-164.063f, -226.563f,-15.6444f,-164.063f, -230.469f,-14.565f,-164.063f, -234.375f,-12.5578f,-164.063f, -238.281f,-10.6498f,-164.063f, -242.188f,-8.28284f,-164.063f, -246.094f,-5.87682f,-164.063f, -250.0f,-2.5339f,-164.063f, -3.90625f,37.2199f,-167.969f, -7.8125f,36.6782f,-167.969f, -11.7188f,36.2393f,-167.969f, -15.625f,33.4745f,-167.969f, -19.5313f,32.0928f,-167.969f, -23.4375f,30.5662f,-167.969f, -27.3438f,28.5968f,-167.969f, -31.25f,26.4298f,-167.969f, -35.1563f,23.9469f,-167.969f, -39.0625f,22.5415f,-167.969f, -42.9688f,21.8267f,-167.969f, -46.875f,21.2097f,-167.969f, -50.7813f,21.0841f,-167.969f, -54.6875f,21.7877f,-167.969f, -58.5938f,22.9351f,-167.969f, -62.5f,24.0641f,-167.969f, -66.4063f,24.42f,-167.969f, -70.3125f,24.8355f,-167.969f, -74.2188f,25.2701f,-167.969f, -78.125f,26.0252f,-167.969f, -82.0313f,26.8612f,-167.969f, -85.9375f,27.4256f,-167.969f, -89.8438f,28.994f,-167.969f, -93.75f,29.1766f,-167.969f, -97.6563f,27.8964f,-167.969f, -101.563f,26.6384f,-167.969f, -105.469f,24.9844f,-167.969f, -109.375f,25.0669f,-167.969f, -113.281f,24.572f,-167.969f, -117.188f,23.7817f,-167.969f, -121.094f,22.2089f,-167.969f, -125.0f,19.7633f,-167.969f, -128.906f,17.7618f,-167.969f, -132.813f,15.7339f,-167.969f, -136.719f,13.4975f,-167.969f, -140.625f,11.7364f,-167.969f, -144.531f,9.85351f,-167.969f, -148.438f,8.05282f,-167.969f, -152.344f,6.97463f,-167.969f, -156.25f,5.11511f,-167.969f, -160.156f,3.12954f,-167.969f, -164.063f,1.56555f,-167.969f, -167.969f,-1.77415f,-167.969f, -171.875f,-4.16322f,-167.969f, -175.781f,-5.85214f,-167.969f, -179.688f,-7.97892f,-167.969f, -183.594f,-9.87953f,-167.969f, -187.5f,-10.2762f,-167.969f, -191.406f,-11.5319f,-167.969f, -195.313f,-13.3612f,-167.969f, -199.219f,-15.3709f,-167.969f, -203.125f,-16.5674f,-167.969f, -207.031f,-17.6903f,-167.969f, -210.938f,-17.6736f,-167.969f, -214.844f,-16.8207f,-167.969f, -218.75f,-17.0254f,-167.969f, -222.656f,-16.3676f,-167.969f, -226.563f,-14.2816f,-167.969f, -230.469f,-13.3488f,-167.969f, -234.375f,-12.0136f,-167.969f, -238.281f,-9.90116f,-167.969f, -242.188f,-7.92295f,-167.969f, -246.094f,-5.41594f,-167.969f, -250.0f,-1.87299f,-167.969f, -3.90625f,35.3898f,-171.875f, -7.8125f,35.2527f,-171.875f, -11.7188f,34.3178f,-171.875f, -15.625f,33.0736f,-171.875f, -19.5313f,31.4013f,-171.875f, -23.4375f,28.9174f,-171.875f, -27.3438f,26.607f,-171.875f, -31.25f,24.7766f,-171.875f, -35.1563f,23.21f,-171.875f, -39.0625f,21.903f,-171.875f, -42.9688f,20.775f,-171.875f, -46.875f,20.114f,-171.875f, -50.7813f,19.6974f,-171.875f, -54.6875f,20.6726f,-171.875f, -58.5938f,22.241f,-171.875f, -62.5f,22.075f,-171.875f, -66.4063f,22.6771f,-171.875f, -70.3125f,22.4456f,-171.875f, -74.2188f,22.8643f,-171.875f, -78.125f,24.7268f,-171.875f, -82.0313f,25.7019f,-171.875f, -85.9375f,26.1196f,-171.875f, -89.8438f,25.6156f,-171.875f, -93.75f,24.7881f,-171.875f, -97.6563f,24.0074f,-171.875f, -101.563f,23.4739f,-171.875f, -105.469f,23.362f,-171.875f, -109.375f,22.2604f,-171.875f, -113.281f,21.2772f,-171.875f, -117.188f,19.7815f,-171.875f, -121.094f,17.9686f,-171.875f, -125.0f,16.3211f,-171.875f, -128.906f,14.2631f,-171.875f, -132.813f,12.4914f,-171.875f, -136.719f,10.3941f,-171.875f, -140.625f,8.91613f,-171.875f, -144.531f,9.17409f,-171.875f, -148.438f,7.34154f,-171.875f, -152.344f,6.13056f,-171.875f, -156.25f,4.58272f,-171.875f, -160.156f,2.77083f,-171.875f, -164.063f,1.11181f,-171.875f, -167.969f,-2.00034f,-171.875f, -171.875f,-3.64525f,-171.875f, -175.781f,-5.12602f,-171.875f, -179.688f,-8.3325f,-171.875f, -183.594f,-10.0807f,-171.875f, -187.5f,-10.8974f,-171.875f, -191.406f,-11.9623f,-171.875f, -195.313f,-14.5041f,-171.875f, -199.219f,-15.8629f,-171.875f, -203.125f,-17.2342f,-171.875f, -207.031f,-18.2786f,-171.875f, -210.938f,-16.9405f,-171.875f, -214.844f,-16.1592f,-171.875f, -218.75f,-15.9928f,-171.875f, -222.656f,-14.9179f,-171.875f, -226.563f,-13.6308f,-171.875f, -230.469f,-12.822f,-171.875f, -234.375f,-11.0168f,-171.875f, -238.281f,-8.54191f,-171.875f, -242.188f,-6.16464f,-171.875f, -246.094f,-4.35579f,-171.875f, -250.0f,-1.83408f,-171.875f, -3.90625f,34.823f,-175.781f, -7.8125f,33.9621f,-175.781f, -11.7188f,33.7226f,-175.781f, -15.625f,31.9821f,-175.781f, -19.5313f,29.6933f,-175.781f, -23.4375f,27.247f,-175.781f, -27.3438f,25.1394f,-175.781f, -31.25f,23.3125f,-175.781f, -35.1563f,21.288f,-175.781f, -39.0625f,21.2432f,-175.781f, -42.9688f,19.7041f,-175.781f, -46.875f,19.3043f,-175.781f, -50.7813f,18.5669f,-175.781f, -54.6875f,19.5408f,-175.781f, -58.5938f,20.3028f,-175.781f, -62.5f,20.573f,-175.781f, -66.4063f,20.7874f,-175.781f, -70.3125f,21.4507f,-175.781f, -74.2188f,22.9166f,-175.781f, -78.125f,23.6886f,-175.781f, -82.0313f,24.4139f,-175.781f, -85.9375f,25.1097f,-175.781f, -89.8438f,24.1395f,-175.781f, -93.75f,23.5282f,-175.781f, -97.6563f,22.7881f,-175.781f, -101.563f,21.2087f,-175.781f, -105.469f,20.6461f,-175.781f, -109.375f,19.7212f,-175.781f, -113.281f,17.9239f,-175.781f, -117.188f,16.9142f,-175.781f, -121.094f,16.1581f,-175.781f, -125.0f,15.1171f,-175.781f, -128.906f,13.1305f,-175.781f, -132.813f,10.3035f,-175.781f, -136.719f,7.95438f,-175.781f, -140.625f,7.49768f,-175.781f, -144.531f,7.76486f,-175.781f, -148.438f,6.84318f,-175.781f, -152.344f,6.0204f,-175.781f, -156.25f,4.83875f,-175.781f, -160.156f,2.59906f,-175.781f, -164.063f,1.35973f,-175.781f, -167.969f,-1.40345f,-175.781f, -171.875f,-3.6985f,-175.781f, -175.781f,-5.60686f,-175.781f, -179.688f,-8.15914f,-175.781f, -183.594f,-9.0389f,-175.781f, -187.5f,-11.2771f,-175.781f, -191.406f,-13.1363f,-175.781f, -195.313f,-14.845f,-175.781f, -199.219f,-15.885f,-175.781f, -203.125f,-17.6421f,-175.781f, -207.031f,-18.1972f,-175.781f, -210.938f,-16.4052f,-175.781f, -214.844f,-16.4522f,-175.781f, -218.75f,-15.8261f,-175.781f, -222.656f,-13.6816f,-175.781f, -226.563f,-12.8394f,-175.781f, -230.469f,-11.638f,-175.781f, -234.375f,-8.87545f,-175.781f, -238.281f,-6.82071f,-175.781f, -242.188f,-3.82988f,-175.781f, -246.094f,-2.34543f,-175.781f, -250.0f,-0.72787f,-175.781f, -3.90625f,32.9461f,-179.688f, -7.8125f,32.0951f,-179.688f, -11.7188f,31.1161f,-179.688f, -15.625f,29.4f,-179.688f, -19.5313f,27.5196f,-179.688f, -23.4375f,26.3351f,-179.688f, -27.3438f,24.0706f,-179.688f, -31.25f,21.9677f,-179.688f, -35.1563f,20.1582f,-179.688f, -39.0625f,19.3604f,-179.688f, -42.9688f,18.5912f,-179.688f, -46.875f,18.0845f,-179.688f, -50.7813f,18.0311f,-179.688f, -54.6875f,17.5412f,-179.688f, -58.5938f,17.724f,-179.688f, -62.5f,18.1752f,-179.688f, -66.4063f,18.8435f,-179.688f, -70.3125f,20.8887f,-179.688f, -74.2188f,21.9179f,-179.688f, -78.125f,22.3044f,-179.688f, -82.0313f,22.1491f,-179.688f, -85.9375f,23.261f,-179.688f, -89.8438f,22.4285f,-179.688f, -93.75f,21.5354f,-179.688f, -97.6563f,19.6399f,-179.688f, -101.563f,18.1312f,-179.688f, -105.469f,17.0655f,-179.688f, -109.375f,16.1471f,-179.688f, -113.281f,15.8256f,-179.688f, -117.188f,14.9609f,-179.688f, -121.094f,15.4508f,-179.688f, -125.0f,14.9122f,-179.688f, -128.906f,12.3324f,-179.688f, -132.813f,9.95184f,-179.688f, -136.719f,7.31755f,-179.688f, -140.625f,6.91109f,-179.688f, -144.531f,7.29489f,-179.688f, -148.438f,6.73968f,-179.688f, -152.344f,6.0555f,-179.688f, -156.25f,5.42266f,-179.688f, -160.156f,3.84651f,-179.688f, -164.063f,2.44552f,-179.688f, -167.969f,-0.187962f,-179.688f, -171.875f,-3.00626f,-179.688f, -175.781f,-5.38527f,-179.688f, -179.688f,-6.48806f,-179.688f, -183.594f,-9.24275f,-179.688f, -187.5f,-11.5122f,-179.688f, -191.406f,-12.6735f,-179.688f, -195.313f,-14.1843f,-179.688f, -199.219f,-15.4787f,-179.688f, -203.125f,-16.6061f,-179.688f, -207.031f,-17.1175f,-179.688f, -210.938f,-16.022f,-179.688f, -214.844f,-15.9349f,-179.688f, -218.75f,-14.6169f,-179.688f, -222.656f,-13.0146f,-179.688f, -226.563f,-12.2f,-179.688f, -230.469f,-9.81169f,-179.688f, -234.375f,-6.72224f,-179.688f, -238.281f,-4.11664f,-179.688f, -242.188f,-2.18066f,-179.688f, -246.094f,-0.510192f,-179.688f, -250.0f,1.48603f,-179.688f, -3.90625f,30.0027f,-183.594f, -7.8125f,29.6114f,-183.594f, -11.7188f,28.342f,-183.594f, -15.625f,26.9383f,-183.594f, -19.5313f,26.0219f,-183.594f, -23.4375f,25.017f,-183.594f, -27.3438f,22.7851f,-183.594f, -31.25f,20.6488f,-183.594f, -35.1563f,18.7107f,-183.594f, -39.0625f,17.0893f,-183.594f, -42.9688f,17.4316f,-183.594f, -46.875f,17.3211f,-183.594f, -50.7813f,16.5318f,-183.594f, -54.6875f,16.2012f,-183.594f, -58.5938f,17.0855f,-183.594f, -62.5f,17.2472f,-183.594f, -66.4063f,18.0123f,-183.594f, -70.3125f,18.684f,-183.594f, -74.2188f,19.625f,-183.594f, -78.125f,19.9442f,-183.594f, -82.0313f,19.9236f,-183.594f, -85.9375f,19.2286f,-183.594f, -89.8438f,19.5358f,-183.594f, -93.75f,18.429f,-183.594f, -97.6563f,16.1318f,-183.594f, -101.563f,14.371f,-183.594f, -105.469f,13.894f,-183.594f, -109.375f,13.5457f,-183.594f, -113.281f,13.7348f,-183.594f, -117.188f,14.0078f,-183.594f, -121.094f,14.2652f,-183.594f, -125.0f,13.5964f,-183.594f, -128.906f,11.3529f,-183.594f, -132.813f,8.43645f,-183.594f, -136.719f,6.95213f,-183.594f, -140.625f,7.16061f,-183.594f, -144.531f,6.71961f,-183.594f, -148.438f,5.35597f,-183.594f, -152.344f,5.22708f,-183.594f, -156.25f,5.07045f,-183.594f, -160.156f,3.44698f,-183.594f, -164.063f,2.33212f,-183.594f, -167.969f,0.462143f,-183.594f, -171.875f,-2.31458f,-183.594f, -175.781f,-4.89712f,-183.594f, -179.688f,-6.66797f,-183.594f, -183.594f,-9.25909f,-183.594f, -187.5f,-9.93472f,-183.594f, -191.406f,-12.0357f,-183.594f, -195.313f,-13.4286f,-183.594f, -199.219f,-14.4671f,-183.594f, -203.125f,-15.0102f,-183.594f, -207.031f,-14.8104f,-183.594f, -210.938f,-13.4733f,-183.594f, -214.844f,-14.0715f,-183.594f, -218.75f,-14.2416f,-183.594f, -222.656f,-12.2774f,-183.594f, -226.563f,-11.1048f,-183.594f, -230.469f,-8.72548f,-183.594f, -234.375f,-5.50563f,-183.594f, -238.281f,-2.81853f,-183.594f, -242.188f,-0.555239f,-183.594f, -246.094f,1.07177f,-183.594f, -250.0f,3.1022f,-183.594f, -3.90625f,27.6405f,-187.5f, -7.8125f,27.1266f,-187.5f, -11.7188f,26.0941f,-187.5f, -15.625f,25.1443f,-187.5f, -19.5313f,24.6236f,-187.5f, -23.4375f,23.7274f,-187.5f, -27.3438f,22.5792f,-187.5f, -31.25f,19.7482f,-187.5f, -35.1563f,17.6829f,-187.5f, -39.0625f,16.5577f,-187.5f, -42.9688f,15.8636f,-187.5f, -46.875f,16.0968f,-187.5f, -50.7813f,15.5614f,-187.5f, -54.6875f,15.4655f,-187.5f, -58.5938f,16.304f,-187.5f, -62.5f,16.7706f,-187.5f, -66.4063f,16.3947f,-187.5f, -70.3125f,16.6761f,-187.5f, -74.2188f,16.7627f,-187.5f, -78.125f,17.2579f,-187.5f, -82.0313f,16.7208f,-187.5f, -85.9375f,16.5278f,-187.5f, -89.8438f,16.2251f,-187.5f, -93.75f,15.0741f,-187.5f, -97.6563f,14.2628f,-187.5f, -101.563f,12.432f,-187.5f, -105.469f,10.8877f,-187.5f, -109.375f,11.903f,-187.5f, -113.281f,12.5606f,-187.5f, -117.188f,13.2652f,-187.5f, -121.094f,13.6914f,-187.5f, -125.0f,12.7849f,-187.5f, -128.906f,10.4802f,-187.5f, -132.813f,8.75276f,-187.5f, -136.719f,6.90392f,-187.5f, -140.625f,6.91636f,-187.5f, -144.531f,6.78271f,-187.5f, -148.438f,5.25436f,-187.5f, -152.344f,4.14458f,-187.5f, -156.25f,3.58445f,-187.5f, -160.156f,3.67538f,-187.5f, -164.063f,1.88171f,-187.5f, -167.969f,1.16358f,-187.5f, -171.875f,-0.909335f,-187.5f, -175.781f,-4.00056f,-187.5f, -179.688f,-6.532f,-187.5f, -183.594f,-8.29174f,-187.5f, -187.5f,-9.0196f,-187.5f, -191.406f,-10.1189f,-187.5f, -195.313f,-11.1349f,-187.5f, -199.219f,-12.4853f,-187.5f, -203.125f,-12.7324f,-187.5f, -207.031f,-12.949f,-187.5f, -210.938f,-11.8708f,-187.5f, -214.844f,-12.2515f,-187.5f, -218.75f,-12.8455f,-187.5f, -222.656f,-10.7923f,-187.5f, -226.563f,-8.82819f,-187.5f, -230.469f,-7.36721f,-187.5f, -234.375f,-5.23714f,-187.5f, -238.281f,-2.63334f,-187.5f, -242.188f,0.485313f,-187.5f, -246.094f,2.78278f,-187.5f, -250.0f,3.96313f,-187.5f, -3.90625f,25.3652f,-191.406f, -7.8125f,24.7195f,-191.406f, -11.7188f,25.004f,-191.406f, -15.625f,24.1773f,-191.406f, -19.5313f,22.7395f,-191.406f, -23.4375f,21.4739f,-191.406f, -27.3438f,21.0405f,-191.406f, -31.25f,18.3321f,-191.406f, -35.1563f,16.9491f,-191.406f, -39.0625f,15.1898f,-191.406f, -42.9688f,14.5842f,-191.406f, -46.875f,14.234f,-191.406f, -50.7813f,14.0689f,-191.406f, -54.6875f,15.4103f,-191.406f, -58.5938f,15.0749f,-191.406f, -62.5f,14.6893f,-191.406f, -66.4063f,14.8987f,-191.406f, -70.3125f,14.4416f,-191.406f, -74.2188f,14.3436f,-191.406f, -78.125f,13.5844f,-191.406f, -82.0313f,13.3989f,-191.406f, -85.9375f,14.3892f,-191.406f, -89.8438f,13.3595f,-191.406f, -93.75f,13.3004f,-191.406f, -97.6563f,11.8557f,-191.406f, -101.563f,9.50387f,-191.406f, -105.469f,9.09049f,-191.406f, -109.375f,10.2607f,-191.406f, -113.281f,11.3275f,-191.406f, -117.188f,11.8898f,-191.406f, -121.094f,11.9585f,-191.406f, -125.0f,11.0034f,-191.406f, -128.906f,10.0704f,-191.406f, -132.813f,8.84472f,-191.406f, -136.719f,7.56972f,-191.406f, -140.625f,6.66467f,-191.406f, -144.531f,5.57509f,-191.406f, -148.438f,4.43943f,-191.406f, -152.344f,3.51469f,-191.406f, -156.25f,2.91572f,-191.406f, -160.156f,3.43161f,-191.406f, -164.063f,1.97664f,-191.406f, -167.969f,1.37279f,-191.406f, -171.875f,-0.545961f,-191.406f, -175.781f,-3.78517f,-191.406f, -179.688f,-6.09483f,-191.406f, -183.594f,-6.45627f,-191.406f, -187.5f,-7.27376f,-191.406f, -191.406f,-8.99215f,-191.406f, -195.313f,-9.89915f,-191.406f, -199.219f,-10.9608f,-191.406f, -203.125f,-10.8387f,-191.406f, -207.031f,-10.5261f,-191.406f, -210.938f,-10.1365f,-191.406f, -214.844f,-10.631f,-191.406f, -218.75f,-10.8413f,-191.406f, -222.656f,-9.03823f,-191.406f, -226.563f,-7.39571f,-191.406f, -230.469f,-4.8409f,-191.406f, -234.375f,-3.47756f,-191.406f, -238.281f,-1.63291f,-191.406f, -242.188f,1.44814f,-191.406f, -246.094f,2.93141f,-191.406f, -250.0f,4.03991f,-191.406f, -3.90625f,23.0993f,-195.313f, -7.8125f,23.2309f,-195.313f, -11.7188f,23.4293f,-195.313f, -15.625f,22.4425f,-195.313f, -19.5313f,21.4905f,-195.313f, -23.4375f,19.6567f,-195.313f, -27.3438f,18.1324f,-195.313f, -31.25f,17.3872f,-195.313f, -35.1563f,16.265f,-195.313f, -39.0625f,13.8338f,-195.313f, -42.9688f,12.7629f,-195.313f, -46.875f,13.1006f,-195.313f, -50.7813f,13.3481f,-195.313f, -54.6875f,13.8039f,-195.313f, -58.5938f,13.0621f,-195.313f, -62.5f,12.4363f,-195.313f, -66.4063f,12.748f,-195.313f, -70.3125f,12.2979f,-195.313f, -74.2188f,11.3997f,-195.313f, -78.125f,12.1637f,-195.313f, -82.0313f,12.2143f,-195.313f, -85.9375f,12.0963f,-195.313f, -89.8438f,11.3468f,-195.313f, -93.75f,11.1939f,-195.313f, -97.6563f,9.31577f,-195.313f, -101.563f,9.0203f,-195.313f, -105.469f,8.39154f,-195.313f, -109.375f,8.72501f,-195.313f, -113.281f,9.3763f,-195.313f, -117.188f,9.56963f,-195.313f, -121.094f,9.54203f,-195.313f, -125.0f,9.30859f,-195.313f, -128.906f,9.02325f,-195.313f, -132.813f,8.54457f,-195.313f, -136.719f,7.91487f,-195.313f, -140.625f,5.8935f,-195.313f, -144.531f,4.77605f,-195.313f, -148.438f,3.03324f,-195.313f, -152.344f,2.63999f,-195.313f, -156.25f,1.85254f,-195.313f, -160.156f,2.58504f,-195.313f, -164.063f,1.86646f,-195.313f, -167.969f,0.472293f,-195.313f, -171.875f,-0.819486f,-195.313f, -175.781f,-3.28005f,-195.313f, -179.688f,-4.07223f,-195.313f, -183.594f,-5.23099f,-195.313f, -187.5f,-5.93446f,-195.313f, -191.406f,-7.40083f,-195.313f, -195.313f,-9.52595f,-195.313f, -199.219f,-9.06593f,-195.313f, -203.125f,-8.64632f,-195.313f, -207.031f,-8.71126f,-195.313f, -210.938f,-7.66946f,-195.313f, -214.844f,-8.22025f,-195.313f, -218.75f,-8.77434f,-195.313f, -222.656f,-7.8003f,-195.313f, -226.563f,-5.29317f,-195.313f, -230.469f,-3.13421f,-195.313f, -234.375f,-1.47978f,-195.313f, -238.281f,0.0436352f,-195.313f, -242.188f,1.56763f,-195.313f, -246.094f,3.2707f,-195.313f, -250.0f,5.38332f,-195.313f, -3.90625f,21.5827f,-199.219f, -7.8125f,21.5884f,-199.219f, -11.7188f,22.0551f,-199.219f, -15.625f,21.1895f,-199.219f, -19.5313f,19.9629f,-199.219f, -23.4375f,18.1891f,-199.219f, -27.3438f,17.3914f,-199.219f, -31.25f,15.7832f,-199.219f, -35.1563f,13.9537f,-199.219f, -39.0625f,11.7784f,-199.219f, -42.9688f,12.6473f,-199.219f, -46.875f,12.1685f,-199.219f, -50.7813f,12.2586f,-199.219f, -54.6875f,12.032f,-199.219f, -58.5938f,12.5025f,-199.219f, -62.5f,12.2207f,-199.219f, -66.4063f,10.4332f,-199.219f, -70.3125f,10.2093f,-199.219f, -74.2188f,9.56536f,-199.219f, -78.125f,10.5041f,-199.219f, -82.0313f,10.9136f,-199.219f, -85.9375f,10.6303f,-199.219f, -89.8438f,11.148f,-199.219f, -93.75f,10.2169f,-199.219f, -97.6563f,8.56966f,-199.219f, -101.563f,8.81808f,-199.219f, -105.469f,7.92638f,-199.219f, -109.375f,7.988f,-199.219f, -113.281f,8.07342f,-199.219f, -117.188f,8.41463f,-199.219f, -121.094f,8.44317f,-199.219f, -125.0f,8.93315f,-199.219f, -128.906f,8.02242f,-199.219f, -132.813f,7.78977f,-199.219f, -136.719f,7.24422f,-199.219f, -140.625f,6.65469f,-199.219f, -144.531f,5.63698f,-199.219f, -148.438f,3.71906f,-199.219f, -152.344f,1.94989f,-199.219f, -156.25f,1.5781f,-199.219f, -160.156f,2.54367f,-199.219f, -164.063f,2.24455f,-199.219f, -167.969f,0.172967f,-199.219f, -171.875f,-1.24076f,-199.219f, -175.781f,-2.09517f,-199.219f, -179.688f,-2.60068f,-199.219f, -183.594f,-3.35838f,-199.219f, -187.5f,-5.02796f,-199.219f, -191.406f,-6.75939f,-199.219f, -195.313f,-7.86176f,-199.219f, -199.219f,-7.60703f,-199.219f, -203.125f,-7.1176f,-199.219f, -207.031f,-7.21926f,-199.219f, -210.938f,-6.354f,-199.219f, -214.844f,-6.26146f,-199.219f, -218.75f,-7.39202f,-199.219f, -222.656f,-6.10132f,-199.219f, -226.563f,-4.15677f,-199.219f, -230.469f,-1.72339f,-199.219f, -234.375f,0.220408f,-199.219f, -238.281f,1.71501f,-199.219f, -242.188f,2.32136f,-199.219f, -246.094f,3.9302f,-199.219f, -250.0f,6.99831f,-199.219f, -3.90625f,20.3179f,-203.125f, -7.8125f,19.0038f,-203.125f, -11.7188f,19.8795f,-203.125f, -15.625f,18.863f,-203.125f, -19.5313f,17.2513f,-203.125f, -23.4375f,16.7786f,-203.125f, -27.3438f,16.4605f,-203.125f, -31.25f,14.0944f,-203.125f, -35.1563f,12.6715f,-203.125f, -39.0625f,12.2869f,-203.125f, -42.9688f,12.0256f,-203.125f, -46.875f,11.4308f,-203.125f, -50.7813f,11.5543f,-203.125f, -54.6875f,10.8247f,-203.125f, -58.5938f,12.5385f,-203.125f, -62.5f,12.1754f,-203.125f, -66.4063f,10.0857f,-203.125f, -70.3125f,8.73654f,-203.125f, -74.2188f,8.35323f,-203.125f, -78.125f,8.75049f,-203.125f, -82.0313f,9.69714f,-203.125f, -85.9375f,9.93848f,-203.125f, -89.8438f,9.99533f,-203.125f, -93.75f,9.28937f,-203.125f, -97.6563f,8.19048f,-203.125f, -101.563f,7.82659f,-203.125f, -105.469f,6.70152f,-203.125f, -109.375f,6.35245f,-203.125f, -113.281f,6.80811f,-203.125f, -117.188f,7.88474f,-203.125f, -121.094f,8.76964f,-203.125f, -125.0f,9.33913f,-203.125f, -128.906f,9.12843f,-203.125f, -132.813f,7.62144f,-203.125f, -136.719f,6.32841f,-203.125f, -140.625f,6.30299f,-203.125f, -144.531f,5.78467f,-203.125f, -148.438f,4.2404f,-203.125f, -152.344f,2.7611f,-203.125f, -156.25f,1.95904f,-203.125f, -160.156f,2.27166f,-203.125f, -164.063f,2.22405f,-203.125f, -167.969f,1.12279f,-203.125f, -171.875f,-0.169061f,-203.125f, -175.781f,-0.887647f,-203.125f, -179.688f,-0.896535f,-203.125f, -183.594f,-2.41604f,-203.125f, -187.5f,-3.63423f,-203.125f, -191.406f,-6.00826f,-203.125f, -195.313f,-5.87316f,-203.125f, -199.219f,-5.18767f,-203.125f, -203.125f,-4.23762f,-203.125f, -207.031f,-4.7338f,-203.125f, -210.938f,-4.88225f,-203.125f, -214.844f,-4.82274f,-203.125f, -218.75f,-5.06338f,-203.125f, -222.656f,-5.13737f,-203.125f, -226.563f,-2.74217f,-203.125f, -230.469f,0.0831564f,-203.125f, -234.375f,2.00986f,-203.125f, -238.281f,2.89937f,-203.125f, -242.188f,3.79442f,-203.125f, -246.094f,5.43821f,-203.125f, -250.0f,8.47222f,-203.125f, -3.90625f,18.3149f,-207.031f, -7.8125f,16.9318f,-207.031f, -11.7188f,16.7123f,-207.031f, -15.625f,16.066f,-207.031f, -19.5313f,15.8401f,-207.031f, -23.4375f,14.9793f,-207.031f, -27.3438f,13.5136f,-207.031f, -31.25f,12.316f,-207.031f, -35.1563f,12.4286f,-207.031f, -39.0625f,12.5926f,-207.031f, -42.9688f,12.419f,-207.031f, -46.875f,11.7087f,-207.031f, -50.7813f,10.9033f,-207.031f, -54.6875f,10.2175f,-207.031f, -58.5938f,10.7307f,-207.031f, -62.5f,9.9283f,-207.031f, -66.4063f,9.11458f,-207.031f, -70.3125f,6.81804f,-207.031f, -74.2188f,6.85559f,-207.031f, -78.125f,6.98146f,-207.031f, -82.0313f,8.41059f,-207.031f, -85.9375f,8.81018f,-207.031f, -89.8438f,9.25882f,-207.031f, -93.75f,8.4973f,-207.031f, -97.6563f,7.11312f,-207.031f, -101.563f,6.11367f,-207.031f, -105.469f,4.54171f,-207.031f, -109.375f,3.984f,-207.031f, -113.281f,6.23536f,-207.031f, -117.188f,7.41972f,-207.031f, -121.094f,8.40005f,-207.031f, -125.0f,9.21009f,-207.031f, -128.906f,9.10113f,-207.031f, -132.813f,8.69785f,-207.031f, -136.719f,7.08314f,-207.031f, -140.625f,6.14113f,-207.031f, -144.531f,4.85123f,-207.031f, -148.438f,4.53013f,-207.031f, -152.344f,4.73052f,-207.031f, -156.25f,3.50435f,-207.031f, -160.156f,3.02093f,-207.031f, -164.063f,2.65317f,-207.031f, -167.969f,1.91936f,-207.031f, -171.875f,1.31638f,-207.031f, -175.781f,0.631767f,-207.031f, -179.688f,-0.185018f,-207.031f, -183.594f,-1.04617f,-207.031f, -187.5f,-2.59594f,-207.031f, -191.406f,-3.62219f,-207.031f, -195.313f,-3.17366f,-207.031f, -199.219f,-3.0812f,-207.031f, -203.125f,-2.21365f,-207.031f, -207.031f,-3.02851f,-207.031f, -210.938f,-4.12823f,-207.031f, -214.844f,-3.42208f,-207.031f, -218.75f,-3.83284f,-207.031f, -222.656f,-3.83483f,-207.031f, -226.563f,-1.81388f,-207.031f, -230.469f,1.06182f,-207.031f, -234.375f,3.0063f,-207.031f, -238.281f,3.97581f,-207.031f, -242.188f,5.25584f,-207.031f, -246.094f,6.1092f,-207.031f, -250.0f,9.89458f,-207.031f, -3.90625f,16.2147f,-210.938f, -7.8125f,15.8155f,-210.938f, -11.7188f,14.9704f,-210.938f, -15.625f,14.6853f,-210.938f, -19.5313f,14.3326f,-210.938f, -23.4375f,14.0488f,-210.938f, -27.3438f,12.2057f,-210.938f, -31.25f,12.7526f,-210.938f, -35.1563f,13.1468f,-210.938f, -39.0625f,12.959f,-210.938f, -42.9688f,12.3931f,-210.938f, -46.875f,11.9578f,-210.938f, -50.7813f,10.5381f,-210.938f, -54.6875f,9.28222f,-210.938f, -58.5938f,9.20117f,-210.938f, -62.5f,8.74359f,-210.938f, -66.4063f,7.58308f,-210.938f, -70.3125f,5.98903f,-210.938f, -74.2188f,5.92315f,-210.938f, -78.125f,6.30208f,-210.938f, -82.0313f,7.35787f,-210.938f, -85.9375f,7.64729f,-210.938f, -89.8438f,7.89394f,-210.938f, -93.75f,7.64523f,-210.938f, -97.6563f,5.66526f,-210.938f, -101.563f,4.1348f,-210.938f, -105.469f,2.65548f,-210.938f, -109.375f,4.20615f,-210.938f, -113.281f,5.82801f,-210.938f, -117.188f,6.92681f,-210.938f, -121.094f,8.52107f,-210.938f, -125.0f,9.29929f,-210.938f, -128.906f,10.1454f,-210.938f, -132.813f,9.39782f,-210.938f, -136.719f,8.72704f,-210.938f, -140.625f,7.91058f,-210.938f, -144.531f,5.32835f,-210.938f, -148.438f,5.30143f,-210.938f, -152.344f,4.98294f,-210.938f, -156.25f,5.27331f,-210.938f, -160.156f,4.054f,-210.938f, -164.063f,4.25352f,-210.938f, -167.969f,3.60791f,-210.938f, -171.875f,2.94898f,-210.938f, -175.781f,1.97064f,-210.938f, -179.688f,1.21275f,-210.938f, -183.594f,-0.419751f,-210.938f, -187.5f,-1.77221f,-210.938f, -191.406f,-1.94763f,-210.938f, -195.313f,-1.32172f,-210.938f, -199.219f,-1.74453f,-210.938f, -203.125f,-0.694964f,-210.938f, -207.031f,-1.77277f,-210.938f, -210.938f,-2.39571f,-210.938f, -214.844f,-2.61021f,-210.938f, -218.75f,-3.16f,-210.938f, -222.656f,-2.46606f,-210.938f, -226.563f,-0.862086f,-210.938f, -230.469f,1.4487f,-210.938f, -234.375f,3.44239f,-210.938f, -238.281f,5.41949f,-210.938f, -242.188f,6.28416f,-210.938f, -246.094f,7.24993f,-210.938f, -250.0f,10.7227f,-210.938f, -3.90625f,14.284f,-214.844f, -7.8125f,14.031f,-214.844f, -11.7188f,12.8153f,-214.844f, -15.625f,12.2914f,-214.844f, -19.5313f,12.0657f,-214.844f, -23.4375f,12.4452f,-214.844f, -27.3438f,12.703f,-214.844f, -31.25f,12.3401f,-214.844f, -35.1563f,13.2219f,-214.844f, -39.0625f,12.9074f,-214.844f, -42.9688f,12.5934f,-214.844f, -46.875f,11.4717f,-214.844f, -50.7813f,10.548f,-214.844f, -54.6875f,9.43614f,-214.844f, -58.5938f,10.0982f,-214.844f, -62.5f,9.36536f,-214.844f, -66.4063f,8.07196f,-214.844f, -70.3125f,6.4483f,-214.844f, -74.2188f,5.80499f,-214.844f, -78.125f,5.60605f,-214.844f, -82.0313f,6.64906f,-214.844f, -85.9375f,7.64402f,-214.844f, -89.8438f,8.31151f,-214.844f, -93.75f,7.97344f,-214.844f, -97.6563f,5.39549f,-214.844f, -101.563f,3.66809f,-214.844f, -105.469f,3.2001f,-214.844f, -109.375f,5.91373f,-214.844f, -113.281f,7.40339f,-214.844f, -117.188f,8.30807f,-214.844f, -121.094f,9.75774f,-214.844f, -125.0f,10.2383f,-214.844f, -128.906f,10.3408f,-214.844f, -132.813f,10.6262f,-214.844f, -136.719f,10.8818f,-214.844f, -140.625f,9.09087f,-214.844f, -144.531f,6.48291f,-214.844f, -148.438f,5.02116f,-214.844f, -152.344f,5.97543f,-214.844f, -156.25f,6.33053f,-214.844f, -160.156f,5.91049f,-214.844f, -164.063f,5.03025f,-214.844f, -167.969f,5.01201f,-214.844f, -171.875f,4.36222f,-214.844f, -175.781f,3.69208f,-214.844f, -179.688f,2.96539f,-214.844f, -183.594f,1.43789f,-214.844f, -187.5f,-0.374301f,-214.844f, -191.406f,-0.955695f,-214.844f, -195.313f,-0.123769f,-214.844f, -199.219f,-0.113436f,-214.844f, -203.125f,-0.0171993f,-214.844f, -207.031f,-1.0984f,-214.844f, -210.938f,-1.10949f,-214.844f, -214.844f,-1.92471f,-214.844f, -218.75f,-2.26183f,-214.844f, -222.656f,-1.32064f,-214.844f, -226.563f,0.209158f,-214.844f, -230.469f,2.41199f,-214.844f, -234.375f,4.66871f,-214.844f, -238.281f,6.29773f,-214.844f, -242.188f,7.20184f,-214.844f, -246.094f,8.08018f,-214.844f, -250.0f,10.3057f,-214.844f, -3.90625f,13.272f,-218.75f, -7.8125f,12.8218f,-218.75f, -11.7188f,11.8102f,-218.75f, -15.625f,11.7105f,-218.75f, -19.5313f,11.5191f,-218.75f, -23.4375f,12.1253f,-218.75f, -27.3438f,12.0266f,-218.75f, -31.25f,12.3549f,-218.75f, -35.1563f,12.3822f,-218.75f, -39.0625f,12.268f,-218.75f, -42.9688f,12.5022f,-218.75f, -46.875f,11.2878f,-218.75f, -50.7813f,10.1823f,-218.75f, -54.6875f,10.4244f,-218.75f, -58.5938f,10.0047f,-218.75f, -62.5f,9.96061f,-218.75f, -66.4063f,8.64873f,-218.75f, -70.3125f,6.45636f,-218.75f, -74.2188f,5.30254f,-218.75f, -78.125f,5.2915f,-218.75f, -82.0313f,7.2575f,-218.75f, -85.9375f,8.1568f,-218.75f, -89.8438f,8.97514f,-218.75f, -93.75f,7.72908f,-218.75f, -97.6563f,5.41501f,-218.75f, -101.563f,4.24025f,-218.75f, -105.469f,5.39134f,-218.75f, -109.375f,7.69518f,-218.75f, -113.281f,8.87616f,-218.75f, -117.188f,9.44758f,-218.75f, -121.094f,9.21473f,-218.75f, -125.0f,10.1366f,-218.75f, -128.906f,11.6088f,-218.75f, -132.813f,12.0083f,-218.75f, -136.719f,12.3184f,-218.75f, -140.625f,10.8438f,-218.75f, -144.531f,7.65837f,-218.75f, -148.438f,6.07316f,-218.75f, -152.344f,6.4613f,-218.75f, -156.25f,7.01972f,-218.75f, -160.156f,7.25454f,-218.75f, -164.063f,6.31416f,-218.75f, -167.969f,6.48096f,-218.75f, -171.875f,5.89274f,-218.75f, -175.781f,5.71289f,-218.75f, -179.688f,4.3046f,-218.75f, -183.594f,2.49719f,-218.75f, -187.5f,1.16956f,-218.75f, -191.406f,1.21673f,-218.75f, -195.313f,1.19652f,-218.75f, -199.219f,1.27819f,-218.75f, -203.125f,1.06325f,-218.75f, -207.031f,0.133118f,-218.75f, -210.938f,-0.283675f,-218.75f, -214.844f,-0.471323f,-218.75f, -218.75f,-0.941533f,-218.75f, -222.656f,-0.953851f,-218.75f, -226.563f,0.751216f,-218.75f, -230.469f,2.54245f,-218.75f, -234.375f,5.17863f,-218.75f, -238.281f,7.22669f,-218.75f, -242.188f,8.44723f,-218.75f, -246.094f,8.59229f,-218.75f, -250.0f,10.4333f,-218.75f, -3.90625f,13.0199f,-222.656f, -7.8125f,13.1789f,-222.656f, -11.7188f,12.4614f,-222.656f, -15.625f,10.8521f,-222.656f, -19.5313f,11.2552f,-222.656f, -23.4375f,12.1618f,-222.656f, -27.3438f,12.6207f,-222.656f, -31.25f,12.7195f,-222.656f, -35.1563f,12.6379f,-222.656f, -39.0625f,12.5247f,-222.656f, -42.9688f,11.5493f,-222.656f, -46.875f,11.1218f,-222.656f, -50.7813f,11.1036f,-222.656f, -54.6875f,11.2909f,-222.656f, -58.5938f,9.99718f,-222.656f, -62.5f,9.07075f,-222.656f, -66.4063f,7.85904f,-222.656f, -70.3125f,6.00034f,-222.656f, -74.2188f,6.20222f,-222.656f, -78.125f,6.90091f,-222.656f, -82.0313f,8.15724f,-222.656f, -85.9375f,8.92624f,-222.656f, -89.8438f,9.54135f,-222.656f, -93.75f,8.05473f,-222.656f, -97.6563f,5.80654f,-222.656f, -101.563f,5.02178f,-222.656f, -105.469f,7.15584f,-222.656f, -109.375f,8.94755f,-222.656f, -113.281f,9.86631f,-222.656f, -117.188f,10.6421f,-222.656f, -121.094f,10.7891f,-222.656f, -125.0f,11.0716f,-222.656f, -128.906f,12.6376f,-222.656f, -132.813f,12.4373f,-222.656f, -136.719f,12.1143f,-222.656f, -140.625f,11.4028f,-222.656f, -144.531f,8.95242f,-222.656f, -148.438f,6.83012f,-222.656f, -152.344f,7.65217f,-222.656f, -156.25f,8.26579f,-222.656f, -160.156f,7.9665f,-222.656f, -164.063f,7.5217f,-222.656f, -167.969f,7.17758f,-222.656f, -171.875f,5.9966f,-222.656f, -175.781f,5.77514f,-222.656f, -179.688f,4.77675f,-222.656f, -183.594f,3.39545f,-222.656f, -187.5f,2.95911f,-222.656f, -191.406f,1.85368f,-222.656f, -195.313f,1.31365f,-222.656f, -199.219f,1.12622f,-222.656f, -203.125f,1.47676f,-222.656f, -207.031f,1.89446f,-222.656f, -210.938f,0.63056f,-222.656f, -214.844f,0.297565f,-222.656f, -218.75f,-0.0109998f,-222.656f, -222.656f,-0.225082f,-222.656f, -226.563f,0.63258f,-222.656f, -230.469f,2.89831f,-222.656f, -234.375f,5.64839f,-222.656f, -238.281f,7.22414f,-222.656f, -242.188f,7.89951f,-222.656f, -246.094f,8.80151f,-222.656f, -250.0f,10.9602f,-222.656f, -3.90625f,11.9733f,-226.563f, -7.8125f,12.8862f,-226.563f, -11.7188f,12.1283f,-226.563f, -15.625f,10.7234f,-226.563f, -19.5313f,11.6866f,-226.563f, -23.4375f,12.6552f,-226.563f, -27.3438f,12.7353f,-226.563f, -31.25f,11.7992f,-226.563f, -35.1563f,11.2006f,-226.563f, -39.0625f,10.9699f,-226.563f, -42.9688f,10.7653f,-226.563f, -46.875f,10.9947f,-226.563f, -50.7813f,11.2791f,-226.563f, -54.6875f,11.0716f,-226.563f, -58.5938f,10.7092f,-226.563f, -62.5f,9.16355f,-226.563f, -66.4063f,7.59431f,-226.563f, -70.3125f,6.68502f,-226.563f, -74.2188f,6.98133f,-226.563f, -78.125f,7.72239f,-226.563f, -82.0313f,9.00293f,-226.563f, -85.9375f,9.47866f,-226.563f, -89.8438f,8.94458f,-226.563f, -93.75f,7.79648f,-226.563f, -97.6563f,6.07787f,-226.563f, -101.563f,6.60546f,-226.563f, -105.469f,8.5652f,-226.563f, -109.375f,10.2869f,-226.563f, -113.281f,11.4751f,-226.563f, -117.188f,11.6224f,-226.563f, -121.094f,12.0803f,-226.563f, -125.0f,12.5335f,-226.563f, -128.906f,13.5918f,-226.563f, -132.813f,12.9198f,-226.563f, -136.719f,11.521f,-226.563f, -140.625f,10.6418f,-226.563f, -144.531f,8.8393f,-226.563f, -148.438f,8.79941f,-226.563f, -152.344f,9.4929f,-226.563f, -156.25f,9.96206f,-226.563f, -160.156f,8.75524f,-226.563f, -164.063f,7.64157f,-226.563f, -167.969f,7.1963f,-226.563f, -171.875f,6.83929f,-226.563f, -175.781f,6.10665f,-226.563f, -179.688f,4.70473f,-226.563f, -183.594f,4.54758f,-226.563f, -187.5f,3.58616f,-226.563f, -191.406f,2.97998f,-226.563f, -195.313f,1.49179f,-226.563f, -199.219f,1.85834f,-226.563f, -203.125f,1.49089f,-226.563f, -207.031f,1.39949f,-226.563f, -210.938f,0.863002f,-226.563f, -214.844f,1.15546f,-226.563f, -218.75f,0.609373f,-226.563f, -222.656f,1.04332f,-226.563f, -226.563f,1.58038f,-226.563f, -230.469f,4.11549f,-226.563f, -234.375f,5.64696f,-226.563f, -238.281f,6.61687f,-226.563f, -242.188f,7.3113f,-226.563f, -246.094f,8.56955f,-226.563f, -250.0f,10.7891f,-226.563f, -3.90625f,10.4619f,-230.469f, -7.8125f,11.4179f,-230.469f, -11.7188f,10.7841f,-230.469f, -15.625f,10.597f,-230.469f, -19.5313f,10.9999f,-230.469f, -23.4375f,11.5972f,-230.469f, -27.3438f,11.4553f,-230.469f, -31.25f,10.1015f,-230.469f, -35.1563f,10.412f,-230.469f, -39.0625f,9.72694f,-230.469f, -42.9688f,9.71973f,-230.469f, -46.875f,10.7767f,-230.469f, -50.7813f,10.8775f,-230.469f, -54.6875f,10.3186f,-230.469f, -58.5938f,10.4188f,-230.469f, -62.5f,8.94879f,-230.469f, -66.4063f,7.92103f,-230.469f, -70.3125f,8.48295f,-230.469f, -74.2188f,8.74782f,-230.469f, -78.125f,8.87976f,-230.469f, -82.0313f,9.68632f,-230.469f, -85.9375f,9.54993f,-230.469f, -89.8438f,9.04624f,-230.469f, -93.75f,8.49407f,-230.469f, -97.6563f,7.90008f,-230.469f, -101.563f,9.20657f,-230.469f, -105.469f,10.5114f,-230.469f, -109.375f,11.5284f,-230.469f, -113.281f,12.0378f,-230.469f, -117.188f,12.9398f,-230.469f, -121.094f,13.1489f,-230.469f, -125.0f,13.8974f,-230.469f, -128.906f,14.5048f,-230.469f, -132.813f,13.1823f,-230.469f, -136.719f,11.6226f,-230.469f, -140.625f,11.1108f,-230.469f, -144.531f,10.0418f,-230.469f, -148.438f,10.2026f,-230.469f, -152.344f,10.9585f,-230.469f, -156.25f,11.0258f,-230.469f, -160.156f,9.88552f,-230.469f, -164.063f,8.92538f,-230.469f, -167.969f,7.90306f,-230.469f, -171.875f,7.23733f,-230.469f, -175.781f,6.09503f,-230.469f, -179.688f,5.15065f,-230.469f, -183.594f,4.73006f,-230.469f, -187.5f,4.05091f,-230.469f, -191.406f,3.01834f,-230.469f, -195.313f,1.83317f,-230.469f, -199.219f,2.77945f,-230.469f, -203.125f,3.05633f,-230.469f, -207.031f,2.07007f,-230.469f, -210.938f,2.01993f,-230.469f, -214.844f,2.13491f,-230.469f, -218.75f,1.65812f,-230.469f, -222.656f,1.8404f,-230.469f, -226.563f,2.78297f,-230.469f, -230.469f,3.94561f,-230.469f, -234.375f,5.83019f,-230.469f, -238.281f,6.9093f,-230.469f, -242.188f,7.96229f,-230.469f, -246.094f,7.63052f,-230.469f, -250.0f,10.2449f,-230.469f, -3.90625f,8.85224f,-234.375f, -7.8125f,9.40139f,-234.375f, -11.7188f,9.62814f,-234.375f, -15.625f,9.97075f,-234.375f, -19.5313f,9.96073f,-234.375f, -23.4375f,9.70541f,-234.375f, -27.3438f,10.0435f,-234.375f, -31.25f,9.85879f,-234.375f, -35.1563f,9.52681f,-234.375f, -39.0625f,8.75341f,-234.375f, -42.9688f,8.99686f,-234.375f, -46.875f,9.56309f,-234.375f, -50.7813f,9.54486f,-234.375f, -54.6875f,10.0225f,-234.375f, -58.5938f,9.56394f,-234.375f, -62.5f,9.18474f,-234.375f, -66.4063f,9.29208f,-234.375f, -70.3125f,10.4881f,-234.375f, -74.2188f,10.8865f,-234.375f, -78.125f,11.0201f,-234.375f, -82.0313f,11.7722f,-234.375f, -85.9375f,11.1624f,-234.375f, -89.8438f,10.602f,-234.375f, -93.75f,9.93284f,-234.375f, -97.6563f,10.2532f,-234.375f, -101.563f,11.0848f,-234.375f, -105.469f,12.6576f,-234.375f, -109.375f,13.4783f,-234.375f, -113.281f,14.7992f,-234.375f, -117.188f,15.3803f,-234.375f, -121.094f,15.9985f,-234.375f, -125.0f,14.9035f,-234.375f, -128.906f,14.2715f,-234.375f, -132.813f,14.0098f,-234.375f, -136.719f,13.1141f,-234.375f, -140.625f,12.5809f,-234.375f, -144.531f,11.8546f,-234.375f, -148.438f,11.5219f,-234.375f, -152.344f,11.8842f,-234.375f, -156.25f,11.6581f,-234.375f, -160.156f,10.8307f,-234.375f, -164.063f,10.2712f,-234.375f, -167.969f,8.58443f,-234.375f, -171.875f,7.00592f,-234.375f, -175.781f,5.65553f,-234.375f, -179.688f,5.07429f,-234.375f, -183.594f,4.41004f,-234.375f, -187.5f,3.95516f,-234.375f, -191.406f,3.42243f,-234.375f, -195.313f,2.54334f,-234.375f, -199.219f,3.95931f,-234.375f, -203.125f,3.9139f,-234.375f, -207.031f,2.90644f,-234.375f, -210.938f,3.11525f,-234.375f, -214.844f,3.33135f,-234.375f, -218.75f,2.64229f,-234.375f, -222.656f,2.64397f,-234.375f, -226.563f,3.186f,-234.375f, -230.469f,4.46201f,-234.375f, -234.375f,5.92783f,-234.375f, -238.281f,6.79968f,-234.375f, -242.188f,8.7067f,-234.375f, -246.094f,8.47322f,-234.375f, -250.0f,10.3839f,-234.375f, -3.90625f,7.99527f,-238.281f, -7.8125f,8.62199f,-238.281f, -11.7188f,9.06695f,-238.281f, -15.625f,9.12589f,-238.281f, -19.5313f,8.97926f,-238.281f, -23.4375f,9.75152f,-238.281f, -27.3438f,9.58038f,-238.281f, -31.25f,9.30169f,-238.281f, -35.1563f,8.63599f,-238.281f, -39.0625f,8.72973f,-238.281f, -42.9688f,8.49513f,-238.281f, -46.875f,8.78362f,-238.281f, -50.7813f,8.75045f,-238.281f, -54.6875f,8.96186f,-238.281f, -58.5938f,10.0611f,-238.281f, -62.5f,11.1275f,-238.281f, -66.4063f,10.8209f,-238.281f, -70.3125f,12.0108f,-238.281f, -74.2188f,13.2126f,-238.281f, -78.125f,14.1323f,-238.281f, -82.0313f,14.3575f,-238.281f, -85.9375f,13.2781f,-238.281f, -89.8438f,12.8024f,-238.281f, -93.75f,12.0484f,-238.281f, -97.6563f,12.7657f,-238.281f, -101.563f,14.0307f,-238.281f, -105.469f,15.9567f,-238.281f, -109.375f,17.7803f,-238.281f, -113.281f,19.0777f,-238.281f, -117.188f,18.7555f,-238.281f, -121.094f,18.8129f,-238.281f, -125.0f,17.4807f,-238.281f, -128.906f,16.4022f,-238.281f, -132.813f,16.01f,-238.281f, -136.719f,15.1852f,-238.281f, -140.625f,13.9301f,-238.281f, -144.531f,12.8841f,-238.281f, -148.438f,11.7108f,-238.281f, -152.344f,11.414f,-238.281f, -156.25f,11.056f,-238.281f, -160.156f,10.8688f,-238.281f, -164.063f,10.5672f,-238.281f, -167.969f,10.0938f,-238.281f, -171.875f,7.73603f,-238.281f, -175.781f,5.94931f,-238.281f, -179.688f,5.51512f,-238.281f, -183.594f,5.27449f,-238.281f, -187.5f,4.94763f,-238.281f, -191.406f,4.13161f,-238.281f, -195.313f,3.59426f,-238.281f, -199.219f,4.03163f,-238.281f, -203.125f,4.38188f,-238.281f, -207.031f,3.09959f,-238.281f, -210.938f,3.1766f,-238.281f, -214.844f,3.05715f,-238.281f, -218.75f,3.20329f,-238.281f, -222.656f,2.53565f,-238.281f, -226.563f,3.1275f,-238.281f, -230.469f,4.54736f,-238.281f, -234.375f,5.9361f,-238.281f, -238.281f,6.99977f,-238.281f, -242.188f,8.20813f,-238.281f, -246.094f,9.56614f,-238.281f, -250.0f,11.4751f,-238.281f, -3.90625f,6.40337f,-242.188f, -7.8125f,7.88741f,-242.188f, -11.7188f,8.60661f,-242.188f, -15.625f,8.56923f,-242.188f, -19.5313f,8.60588f,-242.188f, -23.4375f,8.63232f,-242.188f, -27.3438f,8.3446f,-242.188f, -31.25f,7.50857f,-242.188f, -35.1563f,7.64026f,-242.188f, -39.0625f,7.75851f,-242.188f, -42.9688f,7.56672f,-242.188f, -46.875f,7.98994f,-242.188f, -50.7813f,9.62391f,-242.188f, -54.6875f,9.28711f,-242.188f, -58.5938f,10.3792f,-242.188f, -62.5f,11.2793f,-242.188f, -66.4063f,12.3048f,-242.188f, -70.3125f,13.5272f,-242.188f, -74.2188f,14.5101f,-242.188f, -78.125f,15.2091f,-242.188f, -82.0313f,15.9007f,-242.188f, -85.9375f,15.4601f,-242.188f, -89.8438f,14.5171f,-242.188f, -93.75f,14.2266f,-242.188f, -97.6563f,13.9558f,-242.188f, -101.563f,15.8234f,-242.188f, -105.469f,18.6741f,-242.188f, -109.375f,20.7296f,-242.188f, -113.281f,21.5353f,-242.188f, -117.188f,20.9821f,-242.188f, -121.094f,20.2232f,-242.188f, -125.0f,18.5423f,-242.188f, -128.906f,17.8591f,-242.188f, -132.813f,17.6716f,-242.188f, -136.719f,16.8982f,-242.188f, -140.625f,14.8574f,-242.188f, -144.531f,13.0736f,-242.188f, -148.438f,12.4847f,-242.188f, -152.344f,11.8101f,-242.188f, -156.25f,11.7863f,-242.188f, -160.156f,11.4288f,-242.188f, -164.063f,10.8653f,-242.188f, -167.969f,9.75951f,-242.188f, -171.875f,8.13212f,-242.188f, -175.781f,6.91851f,-242.188f, -179.688f,5.93418f,-242.188f, -183.594f,5.79732f,-242.188f, -187.5f,5.8082f,-242.188f, -191.406f,4.85116f,-242.188f, -195.313f,4.2744f,-242.188f, -199.219f,4.23009f,-242.188f, -203.125f,3.99841f,-242.188f, -207.031f,3.48205f,-242.188f, -210.938f,3.71102f,-242.188f, -214.844f,3.52803f,-242.188f, -218.75f,3.41263f,-242.188f, -222.656f,2.40768f,-242.188f, -226.563f,3.40111f,-242.188f, -230.469f,4.51594f,-242.188f, -234.375f,5.96131f,-242.188f, -238.281f,7.68646f,-242.188f, -242.188f,8.54536f,-242.188f, -246.094f,9.49379f,-242.188f, -250.0f,12.0532f,-242.188f, -3.90625f,6.09425f,-246.094f, -7.8125f,7.62532f,-246.094f, -11.7188f,8.33141f,-246.094f, -15.625f,8.6172f,-246.094f, -19.5313f,8.7607f,-246.094f, -23.4375f,7.89699f,-246.094f, -27.3438f,7.77868f,-246.094f, -31.25f,7.41037f,-246.094f, -35.1563f,6.57203f,-246.094f, -39.0625f,6.31554f,-246.094f, -42.9688f,7.72481f,-246.094f, -46.875f,8.88325f,-246.094f, -50.7813f,10.0433f,-246.094f, -54.6875f,10.7945f,-246.094f, -58.5938f,11.7506f,-246.094f, -62.5f,13.1397f,-246.094f, -66.4063f,13.1294f,-246.094f, -70.3125f,14.8885f,-246.094f, -74.2188f,15.5444f,-246.094f, -78.125f,16.4867f,-246.094f, -82.0313f,17.0601f,-246.094f, -85.9375f,17.2351f,-246.094f, -89.8438f,16.4292f,-246.094f, -93.75f,16.32f,-246.094f, -97.6563f,17.0323f,-246.094f, -101.563f,17.5524f,-246.094f, -105.469f,20.0544f,-246.094f, -109.375f,21.7596f,-246.094f, -113.281f,22.3401f,-246.094f, -117.188f,22.7891f,-246.094f, -121.094f,21.705f,-246.094f, -125.0f,20.4875f,-246.094f, -128.906f,19.3013f,-246.094f, -132.813f,18.5254f,-246.094f, -136.719f,17.4179f,-246.094f, -140.625f,14.7663f,-246.094f, -144.531f,13.8915f,-246.094f, -148.438f,12.0594f,-246.094f, -152.344f,11.8343f,-246.094f, -156.25f,12.3176f,-246.094f, -160.156f,12.7287f,-246.094f, -164.063f,10.9779f,-246.094f, -167.969f,10.1928f,-246.094f, -171.875f,8.20833f,-246.094f, -175.781f,7.71383f,-246.094f, -179.688f,7.59678f,-246.094f, -183.594f,6.98083f,-246.094f, -187.5f,6.81055f,-246.094f, -191.406f,6.13881f,-246.094f, -195.313f,4.42472f,-246.094f, -199.219f,3.97044f,-246.094f, -203.125f,4.06157f,-246.094f, -207.031f,3.73524f,-246.094f, -210.938f,4.45121f,-246.094f, -214.844f,3.42347f,-246.094f, -218.75f,2.70444f,-246.094f, -222.656f,3.88027f,-246.094f, -226.563f,4.53456f,-246.094f, -230.469f,5.69259f,-246.094f, -234.375f,6.23366f,-246.094f, -238.281f,7.38965f,-246.094f, -242.188f,8.96481f,-246.094f, -246.094f,10.9805f,-246.094f, -250.0f,13.0168f,-246.094f, -3.90625f,6.31953f,-250.0f, -7.8125f,6.89279f,-250.0f, -11.7188f,8.63362f,-250.0f, -15.625f,9.28278f,-250.0f, -19.5313f,9.05374f,-250.0f, -23.4375f,8.51295f,-250.0f, -27.3438f,8.2676f,-250.0f, -31.25f,7.86717f,-250.0f, -35.1563f,6.56073f,-250.0f, -39.0625f,6.77605f,-250.0f, -42.9688f,8.67577f,-250.0f, -46.875f,10.2384f,-250.0f, -50.7813f,11.5086f,-250.0f, -54.6875f,12.7259f,-250.0f, -58.5938f,14.4625f,-250.0f, -62.5f,15.7352f,-250.0f, -66.4063f,15.1953f,-250.0f, -70.3125f,16.1585f,-250.0f, -74.2188f,17.1058f,-250.0f, -78.125f,17.3014f,-250.0f, -82.0313f,18.6932f,-250.0f, -85.9375f,18.6138f,-250.0f, -89.8438f,18.0431f,-250.0f, -93.75f,18.293f,-250.0f, -97.6563f,18.5338f,-250.0f, -101.563f,18.8033f,-250.0f, -105.469f,22.2037f,-250.0f, -109.375f,24.04f,-250.0f, -113.281f,24.711f,-250.0f, -117.188f,24.2801f,-250.0f, -121.094f,23.1052f,-250.0f, -125.0f,21.9886f,-250.0f, -128.906f,21.2657f,-250.0f, -132.813f,19.5364f,-250.0f, -136.719f,18.5278f,-250.0f, -140.625f,15.9806f,-250.0f, -144.531f,14.8577f,-250.0f, -148.438f,13.3645f,-250.0f, -152.344f,12.8082f,-250.0f, -156.25f,13.3689f,-250.0f, -160.156f,12.7449f,-250.0f, -164.063f,11.1108f,-250.0f, -167.969f,9.59991f,-250.0f, -171.875f,8.88472f,-250.0f, -175.781f,8.39035f,-250.0f, -179.688f,7.9163f,-250.0f, -183.594f,7.4118f,-250.0f, -187.5f,6.98082f,-250.0f, -191.406f,7.20793f,-250.0f, -195.313f,6.19875f,-250.0f, -199.219f,4.05745f,-250.0f, -203.125f,4.65884f,-250.0f, -207.031f,3.75824f,-250.0f, -210.938f,4.17504f,-250.0f, -214.844f,4.37516f,-250.0f, -218.75f,4.69345f,-250.0f, -222.656f,5.87678f,-250.0f, -226.563f,6.28295f,-250.0f, -230.469f,7.2125f,-250.0f, -234.375f,7.55925f,-250.0f, -238.281f,7.93922f,-250.0f, -242.188f,9.87332f,-250.0f, -246.094f,11.5957f,-250.0f, -250.0f,13.3418f,-250.0f, -}; - -btScalar Landscape07Nml[] = { -0.163295f,0.951018f,0.262487f, -0.144468f,0.954269f,0.261724f, -0.284339f,0.929979f,0.233003f, -0.211332f,0.959058f,0.188537f, -0.433374f,0.893306f,0.11913f, -0.363648f,0.930033f,0.052906f, -0.467682f,0.883824f,-0.0113249f, -0.383618f,0.915858f,-0.118494f, -0.389479f,0.919494f,-0.0532637f, -0.409514f,0.907723f,-0.0913076f, -0.332107f,0.943241f,-0.00112667f, -0.268223f,0.935541f,-0.229827f, -0.254548f,0.967046f,-0.0051751f, -0.306606f,0.933957f,-0.183623f, -0.282468f,0.956486f,0.073117f, -0.352033f,0.935268f,0.0366899f, -0.28404f,0.958651f,0.0175868f, -0.303901f,0.947745f,0.0970751f, -0.36555f,0.930735f,0.0102418f, -0.393208f,0.907605f,0.147107f, -0.468517f,0.882377f,0.0436299f, -0.45621f,0.884295f,0.0994741f, -0.387946f,0.921329f,0.0254982f, -0.35572f,0.93034f,0.0890492f, --0.0727074f,0.997226f,-0.0159048f, -0.0416391f,0.981376f,0.187527f, --0.216733f,0.958137f,0.187084f, --0.0894435f,0.917028f,0.388664f, --0.0768893f,0.966885f,0.243356f, --0.0850782f,0.918088f,0.387139f, --0.0500426f,0.973558f,0.222893f, --0.133165f,0.955198f,0.264319f, --0.123001f,0.980349f,0.154228f, --0.136539f,0.958129f,0.251685f, --0.132627f,0.981796f,0.135965f, --0.174651f,0.968606f,0.176918f, --0.259357f,0.958248f,0.120395f, --0.298496f,0.949786f,0.0938444f, --0.287382f,0.955091f,0.0721996f, --0.350088f,0.936687f,-0.00747904f, --0.148232f,0.988935f,-0.00587251f, --0.126386f,0.991686f,0.0242043f, --0.0549856f,0.99804f,0.0298927f, --0.061356f,0.998107f,0.00430538f, --0.205447f,0.97828f,0.0275574f, --0.222811f,0.974816f,-0.00939735f, --0.192208f,0.981343f,0.00477232f, --0.179009f,0.983825f,-0.00666687f, --0.0670729f,0.997581f,0.0182672f, --0.127994f,0.990724f,-0.0456448f, --0.132352f,0.983294f,-0.124961f, --0.16906f,0.976471f,-0.133875f, -0.0163433f,0.992538f,-0.120836f, -0.061026f,0.995929f,-0.0663405f, -0.133906f,0.98909f,-0.0613958f, -0.0943148f,0.983776f,-0.152607f, -0.150352f,0.985874f,-0.0738065f, -0.100217f,0.972528f,-0.210109f, -0.174622f,0.974275f,-0.142462f, -0.154561f,0.962801f,-0.221644f, -0.214773f,0.96191f,-0.169122f, -0.258606f,0.948184f,-0.184582f, -0.352689f,0.932616f,-0.0764078f, -0.422646f,0.906225f,0.0112396f, -0.443105f,0.890896f,-0.0998108f, -0.401063f,0.915401f,-0.0344995f, -0.415945f,0.889086f,-0.19109f, -0.396075f,0.910803f,-0.116459f, -0.504361f,0.849207f,-0.15642f, -0.465554f,0.866637f,-0.179442f, -0.527872f,0.824305f,-0.204628f, -0.465951f,0.840148f,-0.277561f, -0.474007f,0.822715f,-0.31378f, -0.361245f,0.837173f,-0.410663f, -0.405138f,0.793126f,-0.454769f, -0.304965f,0.772294f,-0.557277f, -0.421648f,0.811214f,-0.405148f, -0.482203f,0.762506f,-0.431353f, -0.478963f,0.817038f,-0.321005f, -0.485062f,0.781955f,-0.391486f, -0.478205f,0.82345f,-0.305368f, -0.426707f,0.781297f,-0.455518f, -0.428677f,0.841565f,-0.32864f, -0.430024f,0.798188f,-0.421871f, -0.423016f,0.835924f,-0.349699f, -0.437416f,0.818455f,-0.372557f, -0.461522f,0.813116f,-0.354739f, -0.446182f,0.808887f,-0.382915f, -0.507869f,0.791896f,-0.339072f, -0.474665f,0.780232f,-0.407346f, -0.494125f,0.792543f,-0.357373f, -0.430265f,0.769469f,-0.472006f, -0.389469f,0.809375f,-0.439574f, -0.38782f,0.781711f,-0.488389f, -0.349938f,0.837293f,-0.4201f, -0.417236f,0.816738f,-0.398564f, -0.440298f,0.822173f,-0.360789f, -0.490994f,0.819158f,-0.296487f, -0.379279f,0.852728f,-0.359169f, -0.3675f,0.860963f,-0.351692f, -0.122152f,0.892865f,-0.433442f, -0.135293f,0.922235f,-0.362185f, -0.188083f,0.883941f,-0.428104f, -0.194653f,0.9204f,-0.339078f, -0.200053f,0.870677f,-0.449332f, -0.149584f,0.899445f,-0.410639f, -0.170948f,0.845446f,-0.505962f, -0.0834541f,0.848059f,-0.523289f, -0.233208f,0.811352f,-0.536024f, -0.246347f,0.822898f,-0.512008f, -0.0429626f,0.875995f,-0.480403f, -0.171623f,0.870482f,-0.461311f, --0.202408f,0.938053f,-0.281226f, --0.0831604f,0.960463f,-0.265698f, --0.312635f,0.912112f,-0.265162f, --0.344362f,0.89728f,-0.276231f, --0.0852182f,0.932714f,-0.350403f, --0.156991f,0.922287f,-0.353185f, -0.0213728f,0.893503f,-0.448548f, --0.0577934f,0.860578f,-0.506029f, --0.0250381f,0.886654f,-0.461755f, --0.0319956f,0.87749f,-0.478526f, --0.0302913f,0.865602f,-0.499816f, --0.00892741f,0.865625f,-0.500613f, -0.0556557f,0.906734f,-0.418015f, -0.137632f,0.905698f,-0.400959f, -0.0276894f,0.926625f,-0.374965f, -0.074566f,0.927887f,-0.365329f, -0.0588963f,0.991806f,0.113367f, -0.300045f,0.940314f,0.160571f, -0.505162f,0.858812f,0.0851652f, -0.523651f,0.851407f,0.0299276f, -0.336751f,0.940492f,0.0455315f, -0.231254f,0.960478f,0.15493f, -0.265257f,0.945144f,0.190637f, -0.327138f,0.941822f,0.0771526f, -0.406507f,0.912216f,-0.0511354f, -0.398687f,0.900126f,-0.17556f, -0.399875f,0.884983f,-0.238547f, -0.421808f,0.899838f,-0.11122f, --0.041369f,0.987502f,-0.152078f, --0.327111f,0.932019f,-0.156008f, --0.143307f,0.985559f,-0.0902006f, --0.0270205f,0.999466f,0.0183744f, --0.0836031f,0.996473f,-0.00727851f, --0.153499f,0.988141f,-0.00380883f, --0.269657f,0.962702f,0.0221269f, --0.220011f,0.975241f,-0.0223422f, --0.104184f,0.990611f,-0.0885198f, --0.112376f,0.99176f,-0.0615135f, --0.176142f,0.984186f,-0.0187604f, --0.211815f,0.974306f,-0.076572f, --0.0254097f,0.999559f,-0.0153608f, --0.0364109f,0.99734f,-0.0631393f, --0.0203648f,0.999538f,-0.0225481f, -0.0549873f,0.998448f,0.00884961f, -0.169599f,0.985346f,0.0181241f, -0.253148f,0.96653f,-0.0416731f, -0.241207f,0.963047f,-0.119834f, -0.334221f,0.932038f,-0.140004f, -0.510774f,0.849501f,-0.132124f, -0.446103f,0.866333f,-0.224633f, -0.443332f,0.853241f,-0.274658f, -0.556199f,0.799442f,-0.227011f, -0.56349f,0.790862f,-0.238781f, -0.469847f,0.819465f,-0.32821f, -0.384148f,0.843359f,-0.375735f, -0.405196f,0.828658f,-0.386189f, -0.451519f,0.832227f,-0.321758f, -0.460293f,0.845627f,-0.27027f, -0.479361f,0.841341f,-0.249716f, -0.486527f,0.832565f,-0.264815f, -0.505678f,0.817374f,-0.276024f, -0.532701f,0.792427f,-0.297134f, -0.419998f,0.832504f,-0.361301f, -0.381252f,0.872209f,-0.306428f, -0.441269f,0.820876f,-0.362552f, -0.40003f,0.811169f,-0.426593f, -0.192925f,0.829083f,-0.524786f, -0.183969f,0.805942f,-0.562684f, -0.196671f,0.822252f,-0.534063f, -0.210296f,0.820946f,-0.530871f, -0.203797f,0.82129f,-0.532869f, --0.110131f,0.879911f,-0.462199f, --0.313522f,0.874849f,-0.369247f, --0.225349f,0.894153f,-0.386922f, --0.0425073f,0.90311f,-0.4273f, -0.0811921f,0.929959f,-0.358587f, --0.0097083f,0.913772f,-0.406111f, --0.0203212f,0.916094f,-0.400448f, --0.0594319f,0.92652f,-0.371521f, --0.0269889f,0.956838f,-0.289365f, -0.0349749f,0.98646f,-0.160231f, -0.256968f,0.956769f,-0.13624f, -0.548943f,0.832681f,-0.0728256f, -0.489119f,0.868806f,-0.0770563f, -0.299363f,0.954014f,0.0154449f, -0.150669f,0.988307f,0.0233966f, -0.338483f,0.938561f,0.0673226f, -0.470525f,0.880363f,-0.0597344f, -0.482272f,0.850276f,-0.210818f, -0.467725f,0.834993f,-0.289861f, -0.394888f,0.866151f,-0.306343f, -0.253937f,0.935832f,-0.244407f, --0.00400266f,0.994244f,-0.107062f, --0.309146f,0.937501f,-0.15975f, --0.226806f,0.957844f,-0.176334f, --0.122632f,0.982531f,-0.139981f, --0.0635605f,0.992861f,-0.10093f, --0.151586f,0.973622f,-0.170534f, --0.231525f,0.948656f,-0.215516f, --0.166237f,0.951792f,-0.257795f, --0.0869197f,0.960928f,-0.262798f, --0.164573f,0.950876f,-0.262203f, --0.167249f,0.963013f,-0.211268f, --0.211402f,0.954271f,-0.211366f, --0.0642089f,0.988782f,-0.134861f, --0.0696806f,0.987799f,-0.139279f, --0.124243f,0.98904f,-0.0797755f, -0.0962393f,0.995288f,-0.0118021f, -0.210783f,0.972894f,-0.0951158f, -0.297355f,0.950074f,-0.0945467f, -0.301001f,0.949737f,-0.0860135f, -0.352321f,0.929179f,-0.111785f, -0.488103f,0.867307f,-0.0976422f, -0.556803f,0.828121f,-0.0646904f, -0.522997f,0.817722f,-0.240427f, -0.526158f,0.791225f,-0.311642f, -0.539548f,0.783883f,-0.30727f, -0.519736f,0.798926f,-0.302643f, -0.456854f,0.816569f,-0.352845f, -0.429557f,0.807438f,-0.404381f, -0.403588f,0.823842f,-0.397997f, -0.363835f,0.833866f,-0.415079f, -0.411515f,0.83345f,-0.368804f, -0.472303f,0.812756f,-0.341113f, -0.520866f,0.78709f,-0.330436f, -0.571303f,0.758641f,-0.313172f, -0.364947f,0.85616f,-0.365791f, -0.334117f,0.892356f,-0.303424f, -0.531373f,0.790182f,-0.305376f, -0.490437f,0.768139f,-0.411624f, -0.28549f,0.798709f,-0.529679f, -0.166173f,0.802828f,-0.572585f, -0.142862f,0.826392f,-0.544671f, -0.199443f,0.816751f,-0.541424f, -0.128075f,0.851947f,-0.507724f, --0.168704f,0.879688f,-0.444621f, --0.244755f,0.842741f,-0.479461f, --0.150804f,0.809643f,-0.567218f, --0.142654f,0.804501f,-0.576565f, --0.00468689f,0.885234f,-0.465123f, --0.00403137f,0.903548f,-0.428468f, --0.0506207f,0.931001f,-0.361489f, --0.153442f,0.941817f,-0.299058f, --0.162811f,0.972443f,-0.166875f, -0.109587f,0.934225f,-0.339431f, -0.212963f,0.908729f,-0.358967f, -0.490721f,0.837065f,-0.2419f, -0.423339f,0.87185f,-0.246298f, -0.265687f,0.948953f,-0.169996f, -0.19754f,0.959782f,-0.199488f, -0.295591f,0.918793f,-0.261622f, -0.531499f,0.826018f,-0.187622f, -0.59212f,0.773761f,-0.225139f, -0.430882f,0.823206f,-0.369692f, -0.346812f,0.896722f,-0.274977f, -0.157001f,0.944818f,-0.287523f, --0.0770972f,0.974843f,-0.209133f, --0.291803f,0.93708f,-0.191656f, --0.196019f,0.961744f,-0.191378f, --0.131765f,0.96396f,-0.231124f, --0.0745388f,0.982069f,-0.173159f, -0.00914064f,0.98959f,-0.143621f, --0.138284f,0.94748f,-0.288373f, --0.221669f,0.91917f,-0.325561f, --0.129149f,0.970549f,-0.203358f, --0.130482f,0.980721f,-0.145466f, --0.176902f,0.951987f,-0.249854f, --0.247465f,0.916992f,-0.31287f, --0.158128f,0.953184f,-0.25775f, --0.0356987f,0.985511f,-0.165812f, --0.125849f,0.96636f,-0.224301f, -0.0681695f,0.96619f,-0.248655f, -0.227225f,0.953018f,-0.200315f, -0.225952f,0.967572f,-0.112919f, -0.287704f,0.957355f,-0.0264129f, -0.36102f,0.928385f,-0.0881278f, -0.475672f,0.87145f,-0.119627f, -0.569214f,0.81507f,-0.107964f, -0.623663f,0.769908f,-0.13523f, -0.603105f,0.773542f,-0.19467f, -0.556766f,0.776509f,-0.295034f, -0.523993f,0.789717f,-0.319025f, -0.458736f,0.810878f,-0.36337f, -0.42608f,0.838013f,-0.340867f, -0.413816f,0.852215f,-0.320134f, -0.428047f,0.839676f,-0.334247f, -0.440545f,0.806668f,-0.393963f, -0.471664f,0.754066f,-0.457075f, -0.438131f,0.75533f,-0.487358f, -0.513035f,0.778713f,-0.361111f, -0.362236f,0.865985f,-0.344753f, -0.319311f,0.872794f,-0.36915f, -0.546544f,0.761872f,-0.347621f, -0.587841f,0.74763f,-0.309017f, -0.346001f,0.792234f,-0.502642f, -0.160837f,0.807416f,-0.567637f, -0.137348f,0.82025f,-0.555271f, -0.177955f,0.827144f,-0.533071f, -0.0951091f,0.870125f,-0.483567f, --0.154432f,0.835911f,-0.526691f, --0.124368f,0.808763f,-0.574834f, --0.126819f,0.782715f,-0.609323f, --0.137751f,0.811099f,-0.568456f, --0.111652f,0.799108f,-0.590729f, --0.083265f,0.829705f,-0.551957f, --0.187386f,0.858237f,-0.477825f, --0.293723f,0.918982f,-0.263055f, --0.393626f,0.913021f,-0.107009f, -0.212209f,0.950224f,-0.228125f, -0.209499f,0.936607f,-0.280851f, -0.442676f,0.872148f,-0.208317f, -0.471617f,0.857429f,-0.205893f, -0.203873f,0.890799f,-0.406094f, -0.238352f,0.874506f,-0.422408f, -0.316589f,0.834877f,-0.45028f, -0.439788f,0.802413f,-0.403384f, -0.591147f,0.75018f,-0.29627f, -0.446858f,0.837414f,-0.314732f, -0.297014f,0.892204f,-0.340228f, -0.174626f,0.914769f,-0.364286f, --0.105816f,0.915255f,-0.388731f, --0.264967f,0.884964f,-0.382925f, --0.17731f,0.909999f,-0.374785f, --0.129483f,0.910653f,-0.39236f, --0.183919f,0.912509f,-0.365379f, --0.0547605f,0.971103f,-0.232295f, --0.0329197f,0.988161f,-0.149845f, --0.283679f,0.94023f,-0.188398f, --0.271484f,0.961222f,-0.0484715f, --0.126156f,0.992006f,-0.00297784f, --0.0077445f,0.99412f,-0.10801f, --0.122479f,0.952558f,-0.278626f, --0.22816f,0.898995f,-0.373834f, --0.116624f,0.94701f,-0.299285f, --0.0338322f,0.962019f,-0.270876f, -0.0643125f,0.93366f,-0.352339f, -0.108033f,0.951056f,-0.28952f, -0.0914872f,0.981979f,-0.165373f, -0.260441f,0.963994f,-0.0537291f, -0.448443f,0.892711f,-0.0443492f, -0.523825f,0.846692f,-0.0933822f, -0.566469f,0.810587f,-0.148532f, -0.615421f,0.777098f,-0.131818f, -0.641634f,0.7586f,-0.11328f, -0.626845f,0.758026f,-0.180172f, -0.575952f,0.768546f,-0.278596f, -0.455289f,0.793648f,-0.403527f, -0.401888f,0.827012f,-0.393113f, -0.390072f,0.829628f,-0.399451f, -0.432707f,0.817098f,-0.380939f, -0.498394f,0.785084f,-0.367759f, -0.54453f,0.759415f,-0.356056f, -0.443321f,0.820621f,-0.360621f, -0.413861f,0.828476f,-0.377289f, -0.394054f,0.852433f,-0.343626f, -0.354186f,0.831754f,-0.427477f, -0.501406f,0.754246f,-0.423916f, -0.58911f,0.726277f,-0.354219f, -0.489087f,0.757568f,-0.432301f, -0.219144f,0.803913f,-0.552901f, -0.0950257f,0.808184f,-0.581213f, -0.0824554f,0.830823f,-0.550395f, -0.0933748f,0.860985f,-0.499987f, --0.0248456f,0.850125f,-0.525994f, --0.102917f,0.824622f,-0.556243f, --0.137975f,0.843048f,-0.519839f, --0.191841f,0.811585f,-0.551839f, --0.0960986f,0.833755f,-0.543707f, --0.122745f,0.850064f,-0.512177f, --0.326981f,0.870361f,-0.368177f, --0.538824f,0.830097f,-0.143558f, --0.554748f,0.831168f,0.0375988f, -0.183636f,0.945911f,-0.267453f, -0.248003f,0.941284f,-0.229083f, -0.367193f,0.90606f,-0.210295f, -0.559963f,0.826078f,-0.0635307f, -0.486301f,0.848236f,-0.209779f, -0.313552f,0.830527f,-0.460336f, -0.26103f,0.794184f,-0.548758f, -0.384376f,0.78311f,-0.488869f, -0.479781f,0.77201f,-0.416905f, -0.481011f,0.825397f,-0.295547f, -0.281884f,0.886831f,-0.366158f, -0.202383f,0.940438f,-0.273162f, --0.0238314f,0.938511f,-0.344426f, --0.257973f,0.859678f,-0.440913f, --0.194719f,0.873936f,-0.445332f, --0.0838372f,0.877697f,-0.471825f, --0.223876f,0.839024f,-0.495901f, --0.216019f,0.888182f,-0.405548f, --0.127765f,0.960438f,-0.247457f, --0.306436f,0.940762f,-0.145138f, --0.327317f,0.939981f,-0.096429f, --0.0557083f,0.990847f,-0.122959f, -0.0995056f,0.975129f,-0.198043f, -0.0247654f,0.966343f,-0.256062f, --0.1694f,0.916546f,-0.362281f, --0.197841f,0.908709f,-0.367568f, --0.0185126f,0.95561f,-0.294052f, -0.0824185f,0.951583f,-0.296138f, -0.0241627f,0.96387f,-0.265277f, -0.0355962f,0.964767f,-0.260688f, -0.155357f,0.948871f,-0.274788f, -0.403654f,0.905713f,-0.129414f, -0.540931f,0.838513f,-0.0654957f, -0.603296f,0.79305f,-0.0842943f, -0.615316f,0.778563f,-0.123395f, -0.650635f,0.750663f,-0.114799f, -0.681129f,0.712532f,-0.16841f, -0.640077f,0.706799f,-0.301225f, -0.501905f,0.776085f,-0.381816f, -0.395956f,0.833034f,-0.386359f, -0.40448f,0.824611f,-0.39549f, -0.410354f,0.816219f,-0.406689f, -0.470853f,0.807605f,-0.355065f, -0.489936f,0.812779f,-0.315203f, -0.459069f,0.843316f,-0.279417f, -0.469145f,0.829489f,-0.303069f, -0.440235f,0.819159f,-0.367657f, -0.420347f,0.792019f,-0.442734f, -0.528602f,0.735131f,-0.424456f, -0.540602f,0.708419f,-0.453752f, -0.493287f,0.777492f,-0.390095f, -0.304413f,0.86604f,-0.396619f, -0.0820709f,0.870144f,-0.485916f, -0.0884612f,0.883073f,-0.460823f, -0.0898563f,0.860973f,-0.500651f, --0.0421635f,0.844727f,-0.533535f, --0.161922f,0.847271f,-0.505878f, --0.14449f,0.888235f,-0.436074f, --0.171293f,0.877903f,-0.447153f, --0.137238f,0.90321f,-0.406666f, --0.254069f,0.918554f,-0.302831f, --0.505168f,0.843216f,-0.183829f, --0.675277f,0.734237f,-0.069976f, --0.653992f,0.755215f,0.0440947f, -0.0555085f,0.890635f,-0.451319f, -0.137334f,0.909799f,-0.39167f, -0.308301f,0.903589f,-0.297451f, -0.471952f,0.852104f,-0.226231f, -0.566013f,0.811602f,-0.144679f, -0.544915f,0.811135f,-0.212433f, -0.36963f,0.829124f,-0.419437f, -0.344038f,0.821377f,-0.454948f, -0.421617f,0.811326f,-0.404955f, -0.42674f,0.823996f,-0.372724f, -0.214619f,0.881696f,-0.42018f, -0.0910032f,0.951585f,-0.293606f, -0.0846967f,0.975495f,-0.203065f, --0.12731f,0.949549f,-0.286616f, --0.203708f,0.900619f,-0.383912f, --0.0136138f,0.94578f,-0.324521f, --0.1774f,0.907831f,-0.379963f, --0.319591f,0.828051f,-0.460644f, --0.309551f,0.868477f,-0.387202f, --0.350068f,0.908991f,-0.226245f, --0.314996f,0.908797f,-0.273615f, --0.0601423f,0.962735f,-0.263674f, -0.136393f,0.973573f,-0.183175f, -0.0532739f,0.976623f,-0.208255f, --0.105007f,0.973025f,-0.205419f, --0.20872f,0.948662f,-0.237649f, --0.0905915f,0.950284f,-0.297915f, -0.0475864f,0.961005f,-0.272405f, -0.0362517f,0.97079f,-0.237174f, -0.105725f,0.948531f,-0.298516f, -0.162566f,0.915122f,-0.368949f, -0.273546f,0.895769f,-0.350385f, -0.484941f,0.844255f,-0.228179f, -0.616479f,0.776457f,-0.130645f, -0.628311f,0.758456f,-0.173119f, -0.646758f,0.730427f,-0.2195f, -0.713832f,0.657703f,-0.240564f, -0.670883f,0.685042f,-0.283959f, -0.484582f,0.813502f,-0.32155f, -0.374759f,0.869215f,-0.322522f, -0.442437f,0.844514f,-0.301738f, -0.417442f,0.841211f,-0.343666f, -0.423405f,0.844004f,-0.329219f, -0.51768f,0.821209f,-0.240049f, -0.452859f,0.851327f,-0.264878f, -0.509187f,0.825405f,-0.243796f, -0.514747f,0.798114f,-0.313129f, -0.470791f,0.788824f,-0.395111f, -0.531455f,0.747848f,-0.397843f, -0.533283f,0.783064f,-0.32003f, -0.426956f,0.884256f,-0.18921f, -0.350467f,0.920762f,-0.171379f, -0.166727f,0.944055f,-0.284537f, -0.0641204f,0.940994f,-0.332292f, -0.176576f,0.941646f,-0.286573f, -0.033479f,0.945913f,-0.322688f, --0.166217f,0.885456f,-0.433982f, --0.211415f,0.849321f,-0.483692f, --0.245686f,0.873508f,-0.420264f, --0.318583f,0.913339f,-0.253606f, --0.37482f,0.927017f,-0.0122188f, --0.519112f,0.853899f,0.0371293f, --0.674751f,0.732141f,-0.0931649f, --0.717847f,0.685588f,-0.121095f, -0.129526f,0.933398f,-0.33465f, -0.109756f,0.909727f,-0.400439f, -0.235187f,0.88528f,-0.401206f, -0.43527f,0.839228f,-0.32594f, -0.509145f,0.799028f,-0.319883f, -0.559944f,0.774395f,-0.294577f, -0.481154f,0.808934f,-0.337812f, -0.346903f,0.826321f,-0.443681f, -0.419785f,0.810323f,-0.408849f, -0.424579f,0.803602f,-0.417081f, -0.213763f,0.882039f,-0.419896f, --0.065439f,0.903315f,-0.423958f, --0.0365788f,0.953894f,-0.297908f, --0.052968f,0.984136f,-0.169324f, --0.178873f,0.950393f,-0.254476f, --0.13588f,0.955299f,-0.262566f, --0.0549577f,0.986053f,-0.157096f, --0.250853f,0.921347f,-0.296972f, --0.383387f,0.86801f,-0.31555f, --0.39517f,0.874494f,-0.281248f, --0.297344f,0.903399f,-0.308961f, --0.146671f,0.942034f,-0.301762f, -0.0292749f,0.969498f,-0.243343f, -0.0315554f,0.994938f,-0.0954108f, --0.135353f,0.99076f,0.00864549f, --0.109362f,0.993969f,-0.00807889f, -0.00178341f,0.978683f,-0.205368f, -0.0583577f,0.951175f,-0.303086f, -0.0448944f,0.938747f,-0.341671f, -0.135893f,0.935013f,-0.327543f, -0.248098f,0.92828f,-0.277025f, -0.287291f,0.872499f,-0.395234f, -0.360517f,0.825037f,-0.435134f, -0.531263f,0.786524f,-0.314864f, -0.667801f,0.716872f,-0.200342f, -0.67932f,0.687853f,-0.2557f, -0.702261f,0.671608f,-0.236161f, -0.672702f,0.722764f,-0.15838f, -0.529805f,0.828764f,-0.180158f, -0.396956f,0.86756f,-0.29961f, -0.439447f,0.830334f,-0.342683f, -0.431898f,0.838796f,-0.33149f, -0.414335f,0.865026f,-0.282941f, -0.433505f,0.865399f,-0.251314f, -0.473777f,0.866492f,-0.157252f, -0.513796f,0.828002f,-0.224559f, -0.584841f,0.771201f,-0.251417f, -0.518412f,0.788719f,-0.330412f, -0.507007f,0.831445f,-0.227253f, -0.414775f,0.908203f,-0.0559478f, -0.370241f,0.92627f,0.07033f, -0.386742f,0.919823f,0.0659988f, -0.294152f,0.955333f,0.0285335f, -0.1108f,0.9849f,-0.133022f, -0.118551f,0.967697f,-0.222506f, -0.0772752f,0.978981f,-0.188747f, --0.0200413f,0.97522f,-0.220327f, --0.18076f,0.942791f,-0.280125f, --0.356914f,0.914544f,-0.190318f, --0.511643f,0.854464f,-0.0900754f, --0.529301f,0.843485f,0.0915077f, --0.481356f,0.855106f,0.192586f, --0.566596f,0.818312f,0.0966086f, --0.682392f,0.727753f,-0.0686784f, -0.232504f,0.952167f,-0.198291f, -0.256414f,0.932781f,-0.253323f, -0.252094f,0.888895f,-0.38251f, -0.391259f,0.847753f,-0.358095f, -0.537533f,0.80784f,-0.241771f, -0.561137f,0.803605f,-0.198354f, -0.542606f,0.822395f,-0.171013f, -0.447025f,0.853524f,-0.267703f, -0.421457f,0.829331f,-0.366857f, -0.381949f,0.841011f,-0.383165f, -0.196905f,0.918187f,-0.343745f, --0.0750719f,0.92165f,-0.380691f, --0.176435f,0.915143f,-0.362469f, --0.162121f,0.952528f,-0.257698f, --0.094717f,0.979068f,-0.180149f, --0.167752f,0.965606f,-0.198655f, --0.133367f,0.985758f,-0.102438f, --0.176519f,0.982527f,-0.0590077f, --0.382392f,0.914243f,-0.133925f, --0.379354f,0.898635f,-0.220329f, --0.2745f,0.907747f,-0.317246f, --0.107475f,0.924008f,-0.366959f, --0.0783766f,0.915897f,-0.393688f, --0.161723f,0.964079f,-0.210708f, --0.213776f,0.971922f,-0.0983248f, -0.0126393f,0.993361f,-0.114343f, -0.146279f,0.956353f,-0.252963f, -0.181548f,0.939791f,-0.289541f, -0.0719106f,0.91394f,-0.399427f, -0.0405362f,0.92481f,-0.378262f, -0.227996f,0.9289f,-0.291825f, -0.430007f,0.847434f,-0.311368f, -0.444003f,0.803436f,-0.396676f, -0.425815f,0.77314f,-0.470039f, -0.591393f,0.731624f,-0.339089f, -0.68448f,0.684033f,-0.252165f, -0.663878f,0.696032f,-0.273504f, -0.62681f,0.752096f,-0.203619f, -0.578478f,0.810023f,-0.0960529f, -0.535256f,0.829774f,-0.158038f, -0.488949f,0.817442f,-0.304496f, -0.370902f,0.857519f,-0.356501f, -0.349699f,0.870975f,-0.345126f, -0.374514f,0.863134f,-0.338731f, -0.45144f,0.856074f,-0.251673f, -0.565254f,0.789722f,-0.238384f, -0.610208f,0.775791f,-0.160605f, -0.460354f,0.88479f,-0.0722568f, -0.360414f,0.930663f,0.0629891f, -0.310809f,0.940565f,0.136874f, -0.344153f,0.923997f,0.166701f, -0.371378f,0.913473f,0.166271f, -0.349168f,0.916329f,0.196019f, -0.310264f,0.946182f,0.0920588f, -0.219218f,0.972739f,-0.075642f, -0.0579784f,0.994476f,-0.087501f, --0.0556996f,0.997544f,-0.0424565f, --0.239345f,0.970003f,0.0425244f, --0.461388f,0.876311f,0.138566f, --0.538726f,0.825514f,0.168229f, --0.597717f,0.791468f,0.127721f, --0.507215f,0.833365f,0.219627f, --0.488959f,0.84151f,0.229738f, --0.545304f,0.815937f,0.192066f, -0.227692f,0.931856f,-0.282489f, -0.297935f,0.90904f,-0.291343f, -0.353719f,0.876832f,-0.325652f, -0.346915f,0.865884f,-0.36041f, -0.409305f,0.867351f,-0.283145f, -0.519851f,0.844165f,-0.130922f, -0.531147f,0.844051f,-0.0738934f, -0.549452f,0.835136f,-0.0255055f, -0.519598f,0.847001f,-0.112281f, -0.416821f,0.899711f,-0.12954f, -0.213877f,0.961324f,-0.173531f, --0.0327967f,0.969436f,-0.243141f, --0.200151f,0.944585f,-0.26019f, --0.261086f,0.940261f,-0.218503f, --0.16617f,0.980036f,-0.109163f, --0.211362f,0.973049f,-0.0922088f, --0.262019f,0.96267f,-0.0679153f, --0.172722f,0.984229f,0.0382049f, --0.269464f,0.962867f,-0.0166155f, --0.289017f,0.944015f,-0.159073f, --0.146887f,0.958128f,-0.245795f, --0.0700562f,0.951312f,-0.300164f, --0.140619f,0.963564f,-0.227533f, --0.278995f,0.930049f,-0.239105f, --0.16269f,0.936868f,-0.309531f, -0.070144f,0.909561f,-0.409607f, -0.193776f,0.876857f,-0.43997f, -0.127038f,0.902686f,-0.411121f, -0.150617f,0.947884f,-0.280767f, -0.0386496f,0.919015f,-0.392324f, -0.208973f,0.868713f,-0.449075f, -0.403894f,0.796876f,-0.449287f, -0.495348f,0.781817f,-0.378673f, -0.489779f,0.764879f,-0.418421f, -0.499102f,0.742417f,-0.446893f, -0.648968f,0.690613f,-0.319208f, -0.677239f,0.687846f,-0.26118f, -0.512369f,0.799495f,-0.313506f, -0.465181f,0.863456f,-0.195064f, -0.589095f,0.803266f,-0.0879238f, -0.56026f,0.801619f,-0.208601f, -0.442292f,0.866151f,-0.232723f, -0.407485f,0.876049f,-0.257867f, -0.41887f,0.854839f,-0.306264f, -0.344336f,0.834896f,-0.429397f, -0.497957f,0.824163f,-0.269804f, -0.448098f,0.886678f,-0.114058f, -0.337837f,0.929162f,0.150081f, -0.341034f,0.908641f,0.240972f, -0.356163f,0.918925f,0.169481f, -0.332963f,0.932465f,0.140159f, -0.378366f,0.915215f,0.13864f, -0.366597f,0.926522f,0.0846395f, -0.364364f,0.925578f,0.102688f, -0.226565f,0.954799f,0.192424f, -0.0359845f,0.964557f,0.261408f, --0.155471f,0.954274f,0.255321f, --0.290268f,0.886689f,0.359898f, --0.467017f,0.828082f,0.31012f, --0.499403f,0.82291f,0.270953f, --0.565258f,0.797609f,0.210482f, --0.553063f,0.809532f,0.196925f, --0.499446f,0.823964f,0.267652f, --0.522286f,0.796771f,0.30393f, -0.282895f,0.896955f,-0.339766f, -0.328074f,0.870604f,-0.366628f, -0.343521f,0.854938f,-0.388683f, -0.333693f,0.867418f,-0.369101f, -0.350459f,0.883644f,-0.310405f, -0.440013f,0.868347f,-0.228826f, -0.488334f,0.85139f,-0.191483f, -0.49066f,0.852892f,-0.178404f, -0.509846f,0.855822f,-0.0873222f, -0.418823f,0.907869f,-0.0190138f, -0.288806f,0.957176f,-0.0201137f, -0.0497186f,0.992214f,-0.114191f, --0.215841f,0.960205f,-0.177253f, --0.338759f,0.933444f,-0.118004f, --0.242696f,0.969321f,-0.0389388f, --0.141909f,0.989578f,-0.0244358f, --0.270493f,0.952883f,-0.137288f, --0.235245f,0.967095f,-0.0968818f, --0.186427f,0.979041f,-0.0819931f, --0.181825f,0.962183f,-0.20284f, --0.135402f,0.958028f,-0.252681f, --0.153581f,0.96935f,-0.191767f, --0.186528f,0.978878f,-0.0837011f, --0.164286f,0.974581f,-0.152324f, -0.0119477f,0.951315f,-0.307988f, -0.181241f,0.876938f,-0.44512f, -0.193514f,0.837326f,-0.51131f, --0.00806995f,0.853668f,-0.520756f, -0.0461085f,0.918292f,-0.393209f, -0.210027f,0.898011f,-0.386606f, -0.313179f,0.820953f,-0.477447f, -0.395672f,0.762863f,-0.511355f, -0.407119f,0.752829f,-0.517206f, -0.491283f,0.735772f,-0.466133f, -0.508563f,0.731088f,-0.454835f, -0.557969f,0.720001f,-0.412637f, -0.635268f,0.712821f,-0.297187f, -0.514275f,0.818992f,-0.254505f, -0.384017f,0.888427f,-0.251454f, -0.535431f,0.823023f,-0.189597f, -0.597396f,0.79853f,-0.0739445f, -0.435766f,0.897283f,-0.0706489f, -0.387025f,0.91478f,-0.115713f, -0.532369f,0.842082f,-0.0864959f, -0.42055f,0.882636f,-0.209979f, -0.370951f,0.912219f,-0.173928f, -0.309089f,0.948381f,-0.0709704f, -0.21321f,0.976943f,0.0111471f, -0.331446f,0.943237f,0.0211533f, -0.410945f,0.911483f,0.0179772f, -0.321726f,0.946051f,-0.0384626f, -0.397145f,0.917286f,0.0293659f, -0.411757f,0.908804f,0.0673213f, -0.22276f,0.971882f,0.0763077f, -0.069501f,0.964908f,0.253224f, --0.028986f,0.93542f,0.352349f, --0.1774f,0.888082f,0.424074f, --0.313309f,0.830284f,0.460941f, --0.375142f,0.83463f,0.403313f, --0.455516f,0.824707f,0.335207f, --0.516585f,0.80896f,0.280577f, --0.560057f,0.80406f,0.199559f, --0.56953f,0.792393f,0.218515f, --0.567769f,0.776958f,0.271984f, -0.281384f,0.90217f,-0.326974f, -0.32181f,0.911348f,-0.256676f, -0.424167f,0.891125f,-0.16118f, -0.302129f,0.903121f,-0.305108f, -0.274213f,0.914554f,-0.297318f, -0.377666f,0.887315f,-0.264651f, -0.50458f,0.840574f,-0.197063f, -0.48044f,0.846134f,-0.230726f, -0.426379f,0.87586f,-0.225987f, -0.348305f,0.925694f,-0.147563f, -0.27972f,0.958581f,-0.053649f, -0.144728f,0.989215f,-0.0225097f, --0.168728f,0.979072f,-0.113791f, --0.360157f,0.915919f,-0.177143f, --0.292774f,0.933287f,-0.207987f, --0.10309f,0.983541f,-0.148387f, --0.174215f,0.960869f,-0.215359f, --0.250891f,0.918965f,-0.304233f, --0.150246f,0.940005f,-0.306294f, --0.0860686f,0.946791f,-0.310127f, --0.15131f,0.934427f,-0.322415f, --0.22276f,0.935306f,-0.27492f, --0.201088f,0.949203f,-0.242028f, --0.0437143f,0.949864f,-0.309592f, -0.109977f,0.887847f,-0.446802f, -0.297781f,0.833674f,-0.465096f, -0.214775f,0.818536f,-0.532795f, -0.0269455f,0.850361f,-0.52551f, --0.017632f,0.796129f,-0.60487f, -0.185146f,0.781388f,-0.595948f, -0.323386f,0.740218f,-0.589491f, -0.406653f,0.707179f,-0.578387f, -0.409551f,0.698057f,-0.587354f, -0.432954f,0.696782f,-0.57188f, -0.429959f,0.722053f,-0.54201f, -0.513634f,0.737641f,-0.438254f, -0.557438f,0.766448f,-0.319093f, -0.451237f,0.872287f,-0.188415f, -0.398866f,0.907449f,-0.132071f, -0.479702f,0.868398f,-0.125579f, -0.492136f,0.869715f,0.0373829f, -0.490052f,0.864036f,0.115287f, -0.467195f,0.882543f,-0.0533554f, -0.500676f,0.860686f,-0.092427f, -0.467521f,0.883982f,0.000254135f, -0.346172f,0.935182f,-0.0748316f, -0.285844f,0.955101f,-0.0779434f, -0.233788f,0.970423f,-0.0601792f, -0.33578f,0.93567f,-0.108509f, -0.44843f,0.890103f,-0.0814045f, -0.344049f,0.926181f,-0.154332f, -0.278254f,0.949058f,-0.147866f, -0.299653f,0.954043f,0.00333978f, -0.154533f,0.964067f,0.21609f, -0.0182142f,0.948347f,0.316711f, --0.116946f,0.954294f,0.275039f, --0.30019f,0.894483f,0.33134f, --0.320232f,0.867471f,0.380717f, --0.340655f,0.881399f,0.327246f, --0.432069f,0.860755f,0.269105f, --0.470649f,0.851696f,0.23044f, --0.520568f,0.837827f,0.164485f, --0.594362f,0.792684f,0.135598f, --0.629645f,0.760492f,0.15874f, -0.105475f,0.917668f,-0.383094f, -0.157333f,0.940076f,-0.302494f, -0.34936f,0.922619f,-0.163471f, -0.441147f,0.892415f,-0.0947875f, -0.353266f,0.911437f,-0.210916f, -0.379048f,0.861228f,-0.33854f, -0.442622f,0.833751f,-0.330068f, -0.481137f,0.838111f,-0.257053f, -0.418048f,0.882249f,-0.216499f, -0.270753f,0.936711f,-0.221958f, -0.184979f,0.961951f,-0.201082f, -0.112903f,0.979904f,-0.164442f, --0.0774318f,0.983977f,-0.160602f, --0.269214f,0.939575f,-0.211477f, --0.244405f,0.926884f,-0.284872f, --0.16522f,0.91825f,-0.359887f, --0.0697709f,0.937892f,-0.339838f, --0.121807f,0.888033f,-0.443351f, --0.178259f,0.862094f,-0.474361f, --0.173573f,0.911189f,-0.373641f, --0.145335f,0.940854f,-0.30606f, --0.196672f,0.897435f,-0.394881f, --0.142648f,0.86312f,-0.484434f, -0.079713f,0.828378f,-0.554469f, -0.216417f,0.76965f,-0.600668f, -0.249468f,0.776353f,-0.578828f, -0.204058f,0.841867f,-0.499621f, -0.0644049f,0.826788f,-0.558814f, -0.116412f,0.767322f,-0.630607f, -0.208898f,0.705315f,-0.677416f, -0.323537f,0.664792f,-0.673332f, -0.378749f,0.668133f,-0.640428f, -0.350681f,0.681998f,-0.641795f, -0.388988f,0.701053f,-0.597673f, -0.366172f,0.724838f,-0.583548f, -0.331191f,0.791609f,-0.513486f, -0.441902f,0.864123f,-0.240861f, -0.365381f,0.918735f,-0.149742f, -0.346761f,0.932102f,-0.104611f, -0.441617f,0.896164f,-0.0431763f, -0.429069f,0.903098f,0.0177174f, -0.509493f,0.859732f,0.035759f, -0.550737f,0.834518f,-0.0163997f, -0.446836f,0.894607f,0.00385291f, -0.489488f,0.868437f,0.0788584f, -0.430014f,0.900385f,-0.0662903f, -0.277285f,0.953602f,-0.117285f, -0.208284f,0.969937f,-0.12586f, -0.377184f,0.918436f,-0.119197f, -0.417651f,0.892053f,-0.172653f, -0.381197f,0.917074f,-0.116891f, -0.274507f,0.95009f,-0.148238f, -0.0946799f,0.989623f,-0.108088f, --0.059654f,0.986641f,0.151597f, --0.0667871f,0.959734f,0.272857f, --0.0714815f,0.942101f,0.327622f, --0.300084f,0.906469f,0.297092f, --0.336918f,0.914203f,0.225209f, --0.288002f,0.930996f,0.224278f, --0.416386f,0.886687f,0.201018f, --0.454428f,0.859405f,0.234346f, --0.478891f,0.849426f,0.221671f, --0.583336f,0.801078f,0.13414f, --0.664795f,0.744846f,0.0570272f, -0.0774054f,0.9409f,-0.329722f, -0.120466f,0.940242f,-0.318486f, -0.258377f,0.92069f,-0.292526f, -0.391172f,0.892344f,-0.225179f, -0.441921f,0.861239f,-0.250944f, -0.474164f,0.819484f,-0.321892f, -0.430001f,0.828794f,-0.358051f, -0.388327f,0.849227f,-0.357794f, -0.321794f,0.900086f,-0.293759f, -0.306798f,0.936469f,-0.170002f, -0.197413f,0.950888f,-0.238412f, -0.140677f,0.959941f,-0.242328f, --0.0738732f,0.952166f,-0.296516f, --0.264161f,0.917561f,-0.297155f, --0.156821f,0.939785f,-0.303665f, --0.074827f,0.921443f,-0.381239f, --0.0597443f,0.912887f,-0.403816f, --0.0722702f,0.937805f,-0.339556f, --0.223343f,0.933173f,-0.281613f, --0.284993f,0.906137f,-0.31256f, --0.17102f,0.941557f,-0.290212f, -0.0188228f,0.955829f,-0.29332f, -0.0949729f,0.880183f,-0.465036f, -0.154174f,0.836833f,-0.525301f, -0.175395f,0.823625f,-0.539331f, -0.0906162f,0.806123f,-0.584769f, -0.167569f,0.848038f,-0.502744f, -0.206981f,0.812951f,-0.544306f, -0.220466f,0.75453f,-0.618126f, -0.281661f,0.74367f,-0.606318f, -0.323085f,0.773947f,-0.544631f, -0.389827f,0.796004f,-0.463047f, -0.409468f,0.784217f,-0.466197f, -0.383754f,0.755374f,-0.531172f, -0.333252f,0.782449f,-0.526039f, -0.13472f,0.877229f,-0.460782f, -0.220453f,0.931705f,-0.288664f, -0.346271f,0.928921f,-0.131156f, -0.317872f,0.942854f,-0.0999207f, -0.41364f,0.908959f,-0.0519229f, -0.398453f,0.915561f,-0.0546188f, -0.505703f,0.862625f,-0.0119489f, -0.526627f,0.849939f,0.0163649f, -0.402553f,0.915142f,0.0215902f, -0.486926f,0.872826f,0.0328415f, -0.480317f,0.876602f,0.0293992f, -0.350224f,0.935385f,0.0489656f, -0.241613f,0.961192f,-0.13317f, -0.388714f,0.905381f,-0.170843f, -0.410083f,0.900693f,-0.14347f, -0.356005f,0.930194f,-0.0894385f, -0.273996f,0.955273f,-0.111267f, --0.044831f,0.997624f,-0.0523075f, --0.196423f,0.976135f,0.0926162f, --0.135564f,0.988784f,0.0626771f, --0.172489f,0.970476f,0.168594f, --0.254529f,0.9218f,0.292405f, --0.284378f,0.936305f,0.206065f, --0.327372f,0.917976f,0.223935f, --0.435353f,0.844597f,0.311647f, --0.503149f,0.802852f,0.319796f, --0.41775f,0.811758f,0.408086f, --0.454925f,0.830308f,0.321918f, --0.572823f,0.802298f,0.167904f, -0.20617f,0.937765f,-0.279448f, -0.12824f,0.920264f,-0.369687f, -0.239724f,0.89965f,-0.364914f, -0.406692f,0.839091f,-0.361286f, -0.450018f,0.81612f,-0.362535f, -0.486709f,0.828644f,-0.276522f, -0.440087f,0.85086f,-0.286985f, -0.416932f,0.85696f,-0.302962f, -0.239451f,0.901982f,-0.359293f, -0.202502f,0.927776f,-0.313409f, -0.221835f,0.941111f,-0.255147f, -0.127859f,0.963075f,-0.236935f, -0.0102396f,0.970361f,-0.241441f, --0.185811f,0.907396f,-0.376969f, --0.143f,0.87175f,-0.468618f, --0.054802f,0.895065f,-0.442557f, --0.153942f,0.908075f,-0.389489f, --0.214862f,0.949277f,-0.22958f, --0.226443f,0.961303f,-0.156909f, --0.189142f,0.939849f,-0.284446f, --0.183498f,0.904381f,-0.385258f, -0.0372666f,0.939229f,-0.341264f, -0.17942f,0.912891f,-0.366659f, -0.186987f,0.89504f,-0.404894f, -0.249987f,0.855827f,-0.452843f, -0.209164f,0.815071f,-0.540287f, -0.137636f,0.780743f,-0.609506f, -0.248264f,0.780183f,-0.574177f, -0.268876f,0.805155f,-0.528613f, -0.166884f,0.854291f,-0.492277f, -0.223895f,0.925944f,-0.304136f, -0.382591f,0.903499f,-0.193167f, -0.505015f,0.839819f,-0.199159f, -0.522375f,0.816711f,-0.245169f, -0.295143f,0.898426f,-0.32515f, -0.045309f,0.962545f,-0.26731f, -0.0698554f,0.972543f,-0.221991f, -0.23803f,0.966556f,-0.0954522f, -0.24345f,0.969904f,-0.00421011f, -0.387893f,0.915554f,0.106303f, -0.388608f,0.912695f,0.126382f, -0.452964f,0.880246f,0.141388f, -0.553021f,0.816379f,0.166411f, -0.46714f,0.881043f,0.0744546f, -0.450683f,0.892414f,0.0219511f, -0.444978f,0.886482f,0.127064f, -0.382178f,0.921652f,0.0670691f, -0.411319f,0.911388f,-0.0137033f, -0.389838f,0.919191f,-0.0558004f, -0.35617f,0.934375f,0.0092699f, -0.326889f,0.943423f,0.0556465f, -0.261297f,0.961477f,0.0853544f, --0.107365f,0.988428f,0.107158f, --0.198313f,0.974378f,0.106114f, --0.119767f,0.989964f,0.0750203f, --0.291683f,0.947022f,0.134427f, --0.31644f,0.92799f,0.196723f, --0.289311f,0.932636f,0.215615f, --0.411791f,0.85345f,0.319455f, --0.469106f,0.777331f,0.419161f, --0.481552f,0.76826f,0.421765f, --0.441444f,0.803246f,0.399904f, --0.347505f,0.834501f,0.427607f, --0.388172f,0.828163f,0.404313f, -0.166663f,0.855647f,-0.489991f, -0.206118f,0.852788f,-0.479863f, -0.253643f,0.809648f,-0.529278f, -0.34663f,0.798296f,-0.492515f, -0.334799f,0.852879f,-0.400633f, -0.411503f,0.867459f,-0.279608f, -0.469719f,0.846111f,-0.251912f, -0.425418f,0.857617f,-0.288986f, -0.321984f,0.890401f,-0.321733f, -0.13105f,0.897315f,-0.421487f, -0.163065f,0.944711f,-0.284482f, -0.0880681f,0.960841f,-0.262734f, -0.0835185f,0.96106f,-0.263417f, --0.0250069f,0.943064f,-0.33167f, --0.080502f,0.931121f,-0.355714f, --0.129429f,0.916002f,-0.379721f, --0.246145f,0.898013f,-0.36467f, --0.295885f,0.891242f,-0.343715f, --0.176282f,0.915144f,-0.362541f, --0.0418985f,0.91018f,-0.412089f, --0.0774111f,0.852502f,-0.51696f, --0.0321668f,0.826692f,-0.561735f, -0.194406f,0.844754f,-0.498595f, -0.282885f,0.80862f,-0.515859f, -0.302949f,0.736294f,-0.605056f, -0.233445f,0.738314f,-0.632768f, -0.172128f,0.759349f,-0.627504f, -0.112225f,0.79134f,-0.600988f, -0.137255f,0.870359f,-0.472902f, -0.0541041f,0.935131f,-0.350147f, -0.048453f,0.960354f,-0.274541f, -0.350102f,0.918679f,-0.182913f, -0.524752f,0.830609f,-0.186344f, -0.518158f,0.835225f,-0.184147f, -0.313736f,0.944893f,-0.0935296f, -0.0308812f,0.997052f,-0.070238f, -0.048477f,0.985949f,-0.159858f, -0.14972f,0.972865f,-0.1764f, -0.155626f,0.983809f,-0.0888849f, -0.284416f,0.958659f,0.0089454f, -0.3659f,0.926807f,0.0845335f, -0.421454f,0.897257f,0.131556f, -0.563402f,0.804293f,0.188919f, -0.539736f,0.827553f,0.154408f, -0.404327f,0.91158f,0.0744378f, -0.452914f,0.883943f,0.116249f, -0.458215f,0.8862f,0.0684684f, -0.412404f,0.90336f,0.117745f, -0.337667f,0.93426f,0.114626f, -0.331072f,0.928113f,0.170285f, -0.265924f,0.943818f,0.196193f, -0.193837f,0.929607f,0.313462f, --0.0688814f,0.919176f,0.387776f, --0.142537f,0.930406f,0.33768f, --0.12463f,0.963373f,0.237444f, --0.336333f,0.924835f,0.17765f, --0.311125f,0.930755f,0.192081f, --0.359893f,0.911001f,0.201382f, --0.532454f,0.800855f,0.274086f, --0.552598f,0.767696f,0.324466f, --0.457025f,0.795874f,0.39713f, --0.406778f,0.834647f,0.371344f, --0.39211f,0.844207f,0.365466f, --0.407171f,0.83024f,0.380675f, -0.088004f,0.820624f,-0.564651f, -0.180508f,0.82686f,-0.532654f, -0.264125f,0.820464f,-0.507027f, -0.247967f,0.854234f,-0.456943f, -0.24322f,0.902001f,-0.356704f, -0.342999f,0.897422f,-0.277462f, -0.495739f,0.849894f,-0.178668f, -0.449958f,0.858561f,-0.245787f, -0.384562f,0.884942f,-0.262659f, -0.158931f,0.931299f,-0.327755f, --0.00482349f,0.936712f,-0.350067f, -0.115045f,0.961792f,-0.248435f, -0.108639f,0.956333f,-0.271339f, --0.0605962f,0.963938f,-0.259135f, --0.116693f,0.974935f,-0.189434f, --0.0876965f,0.975552f,-0.201512f, --0.158272f,0.938607f,-0.30654f, --0.195709f,0.870225f,-0.452113f, --0.139804f,0.831767f,-0.537233f, --0.0224753f,0.834621f,-0.550366f, -0.0691358f,0.82738f,-0.557371f, -0.021368f,0.778901f,-0.626782f, -0.103745f,0.763834f,-0.637021f, -0.295282f,0.754578f,-0.586021f, -0.391718f,0.767187f,-0.507919f, -0.243831f,0.78308f,-0.57213f, -0.0624167f,0.795727f,-0.60243f, -0.0157622f,0.882125f,-0.470752f, --0.0549233f,0.922741f,-0.381487f, --0.0376875f,0.97f,-0.240167f, -0.0506221f,0.974297f,-0.219507f, -0.328414f,0.911788f,-0.246548f, -0.524714f,0.832523f,-0.177709f, -0.470173f,0.873047f,-0.12933f, -0.188699f,0.978079f,-0.0880599f, -0.0393835f,0.999181f,-0.00932192f, -0.202516f,0.978334f,-0.0430044f, -0.188361f,0.964087f,-0.187232f, -0.0636833f,0.962187f,-0.264841f, -0.180234f,0.965248f,-0.18924f, -0.346543f,0.937198f,-0.0395955f, -0.331037f,0.942573f,-0.0443968f, -0.504726f,0.851052f,0.144785f, -0.565376f,0.80039f,0.199312f, -0.492317f,0.859822f,0.135391f, -0.448961f,0.892857f,0.0352157f, -0.367625f,0.92412f,0.104186f, -0.329385f,0.906428f,0.264373f, -0.348699f,0.881448f,0.318526f, -0.290794f,0.899496f,0.326107f, -0.185082f,0.919339f,0.347219f, -0.0676347f,0.907778f,0.413962f, --0.145808f,0.884054f,0.444059f, --0.0815232f,0.884669f,0.459037f, -0.0810938f,0.898461f,0.431499f, --0.248842f,0.934053f,0.256168f, --0.367995f,0.892045f,0.262364f, --0.356163f,0.871443f,0.337246f, --0.546503f,0.805165f,0.230312f, --0.590616f,0.793807f,0.145063f, --0.541291f,0.82267f,0.173836f, --0.431572f,0.851071f,0.299038f, --0.381298f,0.858781f,0.342208f, --0.443875f,0.85724f,0.260987f, -0.118157f,0.850415f,-0.512673f, -0.134653f,0.857894f,-0.49587f, -0.229214f,0.896945f,-0.378087f, -0.208074f,0.910502f,-0.35734f, -0.182505f,0.899208f,-0.397639f, -0.219865f,0.895989f,-0.385828f, -0.451196f,0.865461f,-0.217713f, -0.490084f,0.844039f,-0.217752f, -0.378309f,0.899823f,-0.217259f, -0.231483f,0.942802f,-0.239876f, -0.0439163f,0.94313f,-0.329511f, -0.0365981f,0.93055f,-0.364332f, -0.0406622f,0.963235f,-0.265566f, --0.0474005f,0.988537f,-0.143342f, --0.135564f,0.953464f,-0.269312f, --0.0159099f,0.95648f,-0.291363f, -6.71815e-006f,0.933398f,-0.358843f, --0.0477574f,0.880875f,-0.470933f, --0.0515582f,0.822668f,-0.56618f, -0.00280332f,0.78244f,-0.62272f, -0.0365076f,0.790824f,-0.610954f, -0.0809221f,0.832084f,-0.548715f, -0.112086f,0.801748f,-0.587057f, -0.219407f,0.814817f,-0.536594f, -0.31647f,0.811557f,-0.491143f, -0.326532f,0.816359f,-0.476376f, -0.0311646f,0.874097f,-0.484751f, --0.166146f,0.898216f,-0.406943f, --0.145486f,0.939877f,-0.308975f, --0.113562f,0.952885f,-0.281273f, -0.0633693f,0.957888f,-0.280063f, -0.322061f,0.911056f,-0.257398f, -0.438519f,0.889327f,-0.12961f, -0.430695f,0.901938f,0.0317863f, -0.232727f,0.970972f,0.0552405f, -0.0388751f,0.995464f,-0.0868351f, -0.197289f,0.970749f,-0.136837f, -0.308804f,0.945817f,-0.100347f, -0.177873f,0.966831f,-0.183299f, -0.0327621f,0.970738f,-0.237896f, -0.244781f,0.968393f,-0.0479323f, -0.27827f,0.960269f,-0.0211936f, -0.355239f,0.931705f,0.0757045f, -0.555707f,0.816071f,0.158801f, -0.563884f,0.814994f,0.133487f, -0.420142f,0.89843f,0.127685f, -0.31027f,0.90429f,0.293243f, -0.233723f,0.926208f,0.295826f, -0.272016f,0.906457f,0.323021f, -0.267428f,0.881549f,0.389042f, -0.161017f,0.891985f,0.422417f, -0.0459966f,0.878435f,0.475642f, --0.0917474f,0.877231f,0.47122f, --0.0819927f,0.91503f,0.394964f, -0.108269f,0.907964f,0.40482f, --0.16221f,0.904236f,0.395026f, --0.422279f,0.840786f,0.338761f, --0.374364f,0.835182f,0.402893f, --0.384829f,0.826017f,0.411828f, --0.512379f,0.829197f,0.223383f, --0.585197f,0.801652f,0.122056f, --0.526709f,0.831787f,0.175237f, --0.374079f,0.907515f,0.191003f, --0.329797f,0.931547f,0.153144f, -0.105779f,0.878895f,-0.465138f, -0.0405535f,0.897741f,-0.438654f, -0.106545f,0.927041f,-0.359504f, -0.255352f,0.917446f,-0.305103f, -0.298997f,0.88918f,-0.346352f, -0.205215f,0.859845f,-0.467497f, -0.304244f,0.842016f,-0.445471f, -0.435228f,0.863678f,-0.254238f, -0.39753f,0.896082f,-0.197502f, -0.268558f,0.910516f,-0.314385f, -0.0970216f,0.931439f,-0.350727f, -0.0336528f,0.944013f,-0.328188f, --0.0988412f,0.948055f,-0.302362f, --0.0597673f,0.966409f,-0.249964f, -0.0558923f,0.934228f,-0.352269f, --0.00489276f,0.88655f,-0.462606f, -0.0451038f,0.899627f,-0.434323f, -0.0627933f,0.870215f,-0.488654f, -0.0536848f,0.846805f,-0.529187f, -0.0729181f,0.867797f,-0.491539f, --0.0450251f,0.86132f,-0.506063f, -0.0321391f,0.857039f,-0.514249f, -0.105366f,0.853869f,-0.509711f, -0.20021f,0.860626f,-0.468229f, -0.336826f,0.823703f,-0.456137f, -0.291163f,0.890761f,-0.348954f, --0.0337704f,0.937324f,-0.34682f, --0.238938f,0.893089f,-0.381184f, --0.1654f,0.905926f,-0.389797f, --0.0746684f,0.904792f,-0.419256f, -0.0731105f,0.895556f,-0.438901f, -0.199233f,0.902713f,-0.381334f, -0.277877f,0.941082f,-0.192742f, -0.300522f,0.95354f,-0.0211427f, -0.316945f,0.945681f,0.0723468f, -0.218722f,0.970853f,-0.0980014f, -0.256356f,0.93882f,-0.229999f, -0.242436f,0.93442f,-0.26093f, -0.1983f,0.960329f,-0.196077f, -0.00223103f,0.977894f,-0.209089f, -0.104164f,0.98625f,-0.128296f, -0.285507f,0.957716f,-0.0355725f, -0.283907f,0.956269f,-0.0703361f, -0.529334f,0.848145f,0.0213636f, -0.533064f,0.836918f,0.124145f, -0.319483f,0.916151f,0.242069f, -0.17728f,0.930248f,0.321263f, -0.27524f,0.891192f,0.360581f, -0.317681f,0.901882f,0.292724f, -0.194688f,0.951543f,0.23804f, -0.108971f,0.911619f,0.396329f, --0.0300123f,0.895185f,0.444683f, --0.0818392f,0.875146f,0.476887f, --0.0034355f,0.872809f,0.48805f, -0.0854438f,0.889906f,0.448069f, --0.143928f,0.891079f,0.430422f, --0.400827f,0.846578f,0.350204f, --0.436121f,0.820693f,0.369135f, --0.389169f,0.817738f,0.42409f, --0.354493f,0.838309f,0.414212f, --0.495629f,0.825913f,0.268736f, --0.491187f,0.862049f,0.124928f, --0.360891f,0.926358f,0.107794f, --0.272797f,0.945677f,0.17685f, --0.0230447f,0.8982f,-0.438983f, --0.0253824f,0.922509f,-0.38514f, -0.0868314f,0.93389f,-0.346856f, -0.228815f,0.908408f,-0.349913f, -0.325232f,0.887343f,-0.326875f, -0.342601f,0.877959f,-0.334385f, -0.256841f,0.884237f,-0.390073f, -0.281416f,0.889548f,-0.359874f, -0.383834f,0.865745f,-0.321181f, -0.3194f,0.893039f,-0.316962f, -0.102059f,0.965529f,-0.239452f, --0.0466698f,0.958891f,-0.279912f, --0.0536344f,0.964707f,-0.257804f, --0.0261637f,0.940106f,-0.339875f, -0.144391f,0.948897f,-0.280616f, -0.0981473f,0.936323f,-0.337144f, -0.012852f,0.869861f,-0.493129f, -0.144402f,0.872896f,-0.466049f, --0.00636809f,0.871363f,-0.490597f, --0.0613187f,0.915967f,-0.396541f, -0.0199429f,0.949099f,-0.314346f, -0.0355652f,0.92816f,-0.370479f, -0.140076f,0.947915f,-0.286071f, -0.222188f,0.910114f,-0.349749f, -0.215543f,0.917499f,-0.33427f, -0.183013f,0.971215f,-0.152469f, -0.0390344f,0.988083f,-0.14889f, --0.127226f,0.955382f,-0.266569f, --0.116102f,0.92344f,-0.365757f, --0.0309649f,0.920225f,-0.390164f, -0.00625843f,0.924708f,-0.380627f, -0.101949f,0.952725f,-0.286221f, -0.10526f,0.958946f,-0.263332f, -0.1589f,0.975537f,-0.151918f, -0.291601f,0.956292f,-0.0217678f, -0.33385f,0.942155f,0.0297851f, -0.349208f,0.937042f,0.00260008f, -0.278057f,0.953965f,-0.112407f, -0.149531f,0.968881f,-0.197256f, --0.00612536f,0.988275f,-0.152563f, --0.00797921f,0.994274f,-0.106558f, -0.301027f,0.953574f,-0.00894642f, -0.304582f,0.944145f,-0.125778f, -0.403446f,0.913254f,-0.0565483f, -0.37426f,0.908704f,0.184893f, -0.255667f,0.895707f,0.363791f, -0.219787f,0.909558f,0.352701f, -0.267099f,0.929513f,0.254289f, -0.378434f,0.885367f,0.270025f, -0.147409f,0.95291f,0.265015f, --0.0634097f,0.932842f,0.354663f, --0.0326192f,0.907501f,0.418782f, --0.118713f,0.911859f,0.392963f, --0.0609125f,0.902157f,0.427087f, -0.138333f,0.871993f,0.469567f, --0.0649916f,0.904886f,0.420664f, --0.383734f,0.861279f,0.333085f, --0.474942f,0.817835f,0.324924f, --0.422908f,0.836367f,0.348768f, --0.339416f,0.853379f,0.395651f, --0.324702f,0.875389f,0.358137f, --0.41353f,0.899847f,0.138815f, --0.448451f,0.884614f,0.12787f, --0.414049f,0.866279f,0.279505f, -0.070634f,0.912028f,-0.404001f, --0.0676482f,0.885638f,-0.459422f, -0.0565435f,0.906984f,-0.417353f, -0.246119f,0.879096f,-0.408185f, -0.292529f,0.859337f,-0.419485f, -0.280896f,0.904751f,-0.320192f, -0.320721f,0.917291f,-0.23604f, -0.350916f,0.874365f,-0.335178f, -0.376904f,0.866371f,-0.327636f, -0.17512f,0.962866f,-0.205478f, -0.0176642f,0.987314f,-0.157793f, -0.0227212f,0.982851f,-0.182998f, -0.0272561f,0.971904f,-0.233795f, --0.0877209f,0.950392f,-0.298429f, -0.0166276f,0.994097f,-0.107211f, -0.266845f,0.962366f,-0.0514236f, -0.216132f,0.934464f,-0.282956f, -0.0993362f,0.906446f,-0.410472f, --0.0104212f,0.924877f,-0.380123f, --0.166185f,0.907878f,-0.384889f, --0.0197905f,0.953108f,-0.301983f, --0.0183125f,0.962192f,-0.271757f, -0.0845408f,0.976284f,-0.199307f, -0.269635f,0.943751f,-0.191394f, -0.189274f,0.968047f,-0.164501f, -0.102539f,0.979864f,-0.171327f, -0.106979f,0.970988f,-0.213865f, --0.0373949f,0.962501f,-0.268688f, --0.0919497f,0.957563f,-0.273163f, --0.0692205f,0.979823f,-0.187497f, --0.0661107f,0.993399f,-0.093741f, -0.0537161f,0.998551f,0.00311785f, -0.163558f,0.98647f,-0.0111964f, -0.128373f,0.980868f,-0.146347f, -0.126964f,0.974881f,-0.182993f, -0.228868f,0.973261f,0.0195364f, -0.336464f,0.933228f,0.126005f, -0.409696f,0.899435f,0.152205f, -0.227221f,0.973118f,0.0375761f, --0.0400449f,0.999001f,-0.0198394f, --0.0832424f,0.995769f,-0.0389306f, -0.262425f,0.963268f,0.0569854f, -0.380638f,0.919787f,0.0954299f, -0.267185f,0.959941f,0.0844166f, -0.200067f,0.945675f,0.256267f, -0.180437f,0.922348f,0.341639f, -0.274022f,0.906356f,0.321607f, -0.375587f,0.88639f,0.270641f, -0.289567f,0.933145f,0.213051f, -0.118001f,0.9078f,0.402461f, --0.100351f,0.886215f,0.452275f, --0.0321373f,0.879207f,0.475355f, --0.064732f,0.903306f,0.424085f, --0.117284f,0.933968f,0.337563f, -0.107835f,0.909874f,0.400625f, --0.00684675f,0.915037f,0.403311f, --0.3665f,0.879987f,0.302161f, --0.484488f,0.825175f,0.290444f, --0.455029f,0.825809f,0.33315f, --0.355514f,0.861697f,0.362061f, --0.249905f,0.90704f,0.338859f, --0.283441f,0.915216f,0.286426f, --0.489082f,0.840765f,0.232193f, --0.566036f,0.779585f,0.26805f, -0.300059f,0.882066f,-0.363212f, -0.0511478f,0.860745f,-0.506461f, -0.0202137f,0.82997f,-0.557442f, -0.244641f,0.828925f,-0.503024f, -0.229733f,0.86489f,-0.446306f, -0.151553f,0.888421f,-0.433289f, -0.276054f,0.875076f,-0.397538f, -0.35746f,0.874812f,-0.326997f, -0.20869f,0.962246f,-0.174729f, -0.135202f,0.98952f,0.050694f, -0.0768682f,0.997036f,0.00329808f, -0.0854955f,0.992826f,-0.08359f, -0.0751533f,0.982531f,-0.170249f, --0.0858423f,0.966447f,-0.242097f, --0.101218f,0.962967f,-0.2499f, -0.245897f,0.943422f,-0.222463f, -0.411229f,0.896277f,-0.166064f, -0.160383f,0.921177f,-0.354556f, -0.0135902f,0.93936f,-0.342662f, --0.185366f,0.907574f,-0.37676f, --0.130182f,0.940725f,-0.313191f, --0.0326676f,0.972591f,-0.230215f, -0.0675199f,0.972602f,-0.222457f, -0.233107f,0.94649f,-0.2232f, -0.212831f,0.95378f,-0.212148f, -0.167019f,0.9356f,-0.311059f, -0.16946f,0.90555f,-0.388925f, --0.0763448f,0.914067f,-0.398312f, --0.178349f,0.9565f,-0.230865f, --0.221816f,0.964561f,-0.142896f, --0.163528f,0.986246f,-0.0240246f, --0.0459992f,0.998297f,0.0358721f, -0.192503f,0.971257f,0.140008f, -0.306262f,0.942491f,0.133843f, -0.166989f,0.985549f,-0.0284312f, -0.110164f,0.988175f,-0.106645f, -0.230491f,0.969982f,-0.0775155f, -0.320779f,0.937031f,0.138109f, -0.2844f,0.912116f,0.295231f, -0.0676957f,0.97278f,0.221621f, --0.0445371f,0.996486f,0.0709375f, -0.140086f,0.988598f,0.0552233f, -0.294951f,0.934183f,0.200765f, -0.239076f,0.923996f,0.298453f, -0.115077f,0.947116f,0.299546f, -0.169084f,0.942486f,0.288323f, -0.304609f,0.90997f,0.281369f, -0.369662f,0.880322f,0.297294f, -0.206677f,0.906857f,0.36728f, --0.0427609f,0.882729f,0.467933f, --0.167345f,0.859324f,0.483279f, --0.0302574f,0.860894f,0.507884f, -0.0910322f,0.886636f,0.453421f, --0.0366606f,0.947171f,0.318627f, -0.025939f,0.94095f,0.337552f, -0.0591946f,0.91956f,0.388466f, --0.284221f,0.911546f,0.297158f, --0.532586f,0.813173f,0.234739f, --0.487487f,0.825499f,0.284445f, --0.31853f,0.893358f,0.316938f, --0.238637f,0.92505f,0.295524f, --0.265409f,0.911937f,0.312937f, --0.505062f,0.827653f,0.244749f, --0.589625f,0.757122f,0.281262f, -0.260545f,0.875981f,-0.405923f, -0.198469f,0.90372f,-0.379342f, -0.0608985f,0.867502f,-0.493691f, -0.108599f,0.877043f,-0.467977f, -0.149016f,0.918586f,-0.366053f, -0.269933f,0.909568f,-0.315946f, -0.225091f,0.894351f,-0.386613f, -0.14483f,0.975181f,-0.16747f, -0.0237141f,0.999718f,0.00125985f, -0.0312597f,0.997955f,0.0557504f, -0.105656f,0.993029f,0.0522575f, -0.205288f,0.977382f,0.0508146f, -0.175007f,0.977751f,-0.115656f, -0.0411408f,0.976103f,-0.213378f, --0.0123853f,0.935985f,-0.351821f, -0.185506f,0.902134f,-0.38954f, -0.361594f,0.882471f,-0.300824f, -0.229178f,0.926898f,-0.297216f, --0.016076f,0.953923f,-0.299621f, --0.176229f,0.940869f,-0.289326f, --0.197595f,0.933757f,-0.298419f, --0.0925101f,0.952321f,-0.290735f, -0.0363018f,0.966473f,-0.254189f, -0.27059f,0.939141f,-0.211649f, -0.283887f,0.910685f,-0.300101f, -0.267987f,0.87929f,-0.39374f, -0.167837f,0.906306f,-0.387866f, --0.162045f,0.958045f,-0.236411f, --0.34242f,0.923851f,-0.171018f, --0.280408f,0.954479f,-0.101693f, --0.219474f,0.974995f,-0.0348799f, --0.111179f,0.993643f,0.0176973f, -0.0791225f,0.990452f,0.112896f, -0.243665f,0.947394f,0.207537f, -0.282223f,0.914505f,0.289882f, -0.280685f,0.943977f,0.173563f, -0.165641f,0.985889f,-0.0242044f, -0.0702016f,0.994363f,0.0794649f, -0.118053f,0.960325f,0.252664f, -0.204772f,0.904931f,0.373051f, -0.0632983f,0.962848f,0.262521f, -0.122554f,0.958346f,0.257978f, -0.174517f,0.943136f,0.28291f, -0.181765f,0.923678f,0.337315f, -0.176745f,0.924152f,0.338681f, -0.201711f,0.945597f,0.255262f, -0.29766f,0.929054f,0.219676f, -0.268359f,0.928086f,0.258147f, -0.100906f,0.896734f,0.430912f, --0.0388415f,0.876619f,0.479615f, --0.130193f,0.899332f,0.417434f, -0.000668505f,0.914851f,0.403791f, -0.198601f,0.908384f,0.367961f, -0.0382447f,0.953766f,0.298106f, --0.0134843f,0.968824f,0.247384f, -0.0247843f,0.964757f,0.261972f, --0.214942f,0.928034f,0.304224f, --0.51491f,0.834181f,0.197508f, --0.514132f,0.845f,0.147116f, --0.364403f,0.910649f,0.194754f, --0.252308f,0.925047f,0.283953f, --0.245043f,0.926077f,0.286941f, --0.475784f,0.852889f,0.214964f, --0.66621f,0.724577f,0.176499f, -0.0831836f,0.888999f,-0.45029f, -0.181271f,0.909397f,-0.374349f, -0.118635f,0.893305f,-0.433511f, -0.0803087f,0.896743f,-0.435204f, -0.0532614f,0.909245f,-0.41284f, -0.209897f,0.941844f,-0.262435f, -0.164344f,0.979747f,-0.114402f, --0.0796744f,0.996148f,-0.0366233f, --0.0133458f,0.996096f,0.0872637f, -0.0764545f,0.99532f,0.0590999f, -0.136206f,0.990597f,0.0128964f, -0.22076f,0.975032f,-0.0240476f, -0.302428f,0.952936f,-0.021205f, -0.123508f,0.990766f,-0.0559322f, -0.0598433f,0.996046f,-0.06566f, -0.217088f,0.972764f,-0.0812636f, -0.324106f,0.93941f,-0.111642f, -0.231973f,0.969426f,-0.0800149f, --0.0239272f,0.988929f,-0.146448f, --0.168479f,0.969286f,-0.179165f, --0.198758f,0.9628f,-0.183064f, --0.0847832f,0.988177f,-0.12774f, --0.00304443f,0.993662f,-0.112364f, -0.297886f,0.949812f,-0.0955022f, -0.392699f,0.900627f,-0.186169f, -0.309254f,0.921444f,-0.235165f, --0.0368216f,0.992281f,-0.118418f, --0.30784f,0.939111f,0.152661f, --0.339391f,0.929078f,0.147065f, --0.31987f,0.942094f,0.100706f, --0.261939f,0.955297f,0.137099f, --0.18149f,0.977639f,0.106224f, --0.0176854f,0.987381f,0.157371f, -0.134774f,0.952305f,0.273773f, -0.227558f,0.898637f,0.375058f, -0.367312f,0.872839f,0.3213f, -0.289472f,0.940027f,0.180432f, -0.0121921f,0.995617f,0.0927227f, --0.0151053f,0.984704f,0.173582f, -0.12465f,0.941586f,0.312855f, -0.123765f,0.936041f,0.329407f, -0.0496474f,0.956015f,0.289087f, -0.155803f,0.919433f,0.361065f, -0.180039f,0.912678f,0.366885f, -0.192318f,0.910529f,0.365993f, -0.269572f,0.892548f,0.361509f, -0.331198f,0.898525f,0.288029f, -0.198758f,0.948186f,0.247866f, --0.0345441f,0.951973f,0.304226f, --0.0327497f,0.929484f,0.367404f, --0.0643392f,0.937143f,0.342962f, -0.00774044f,0.965859f,0.258952f, -0.179174f,0.948429f,0.261495f, -0.132443f,0.935778f,0.32677f, -0.0607758f,0.973146f,0.222018f, --0.0289622f,0.977742f,0.2078f, --0.247283f,0.928769f,0.276114f, --0.440694f,0.866976f,0.232681f, --0.493254f,0.853754f,0.166745f, --0.437376f,0.881741f,0.176734f, --0.303558f,0.920161f,0.247297f, --0.230002f,0.942128f,0.243914f, --0.435382f,0.879414f,0.192544f, --0.672886f,0.738322f,0.045878f, -0.0719528f,0.93004f,-0.360345f, -0.170321f,0.920666f,-0.351232f, -0.181011f,0.922477f,-0.340985f, -0.0828362f,0.939404f,-0.332654f, --0.0227994f,0.947238f,-0.31972f, --0.0485785f,0.963562f,-0.263036f, -0.0586424f,0.995988f,-0.0676002f, --0.0660447f,0.996659f,-0.0480482f, --0.0602898f,0.992772f,-0.103773f, -0.058767f,0.996066f,-0.0663303f, -0.189158f,0.981943f,0.00282556f, -0.237805f,0.968932f,-0.0679702f, -0.226076f,0.973949f,-0.0176966f, -0.0903031f,0.990597f,0.102775f, -0.00876316f,0.995102f,0.0984623f, -0.239141f,0.958139f,0.157419f, -0.358816f,0.926379f,0.11434f, -0.290281f,0.955997f,0.0425008f, -0.0827916f,0.995067f,-0.054651f, --0.14974f,0.985436f,-0.0805802f, --0.250148f,0.9681f,-0.0144092f, --0.190918f,0.980525f,0.0460446f, -0.000678111f,0.99542f,0.0955933f, -0.316233f,0.948486f,0.019255f, -0.451155f,0.892443f,0.00187563f, -0.20864f,0.975493f,0.0698802f, --0.187263f,0.946264f,0.263661f, --0.412354f,0.843904f,0.343207f, --0.267988f,0.899756f,0.344414f, --0.237384f,0.936767f,0.25713f, --0.24929f,0.96341f,0.0984657f, --0.12508f,0.979898f,0.155419f, --0.075281f,0.975532f,0.206567f, --0.0362475f,0.956877f,0.288223f, -0.179598f,0.903623f,0.388856f, -0.452503f,0.830262f,0.325433f, -0.44384f,0.859576f,0.253251f, -0.0283124f,0.992393f,0.119807f, --0.131018f,0.979645f,0.152082f, --0.0108162f,0.971878f,0.235238f, -0.177243f,0.920605f,0.347953f, -0.0690998f,0.954542f,0.289956f, -0.0964158f,0.939858f,0.327675f, -0.141817f,0.921257f,0.362178f, -0.189018f,0.897606f,0.398216f, -0.266469f,0.899974f,0.345024f, -0.359545f,0.871551f,0.333357f, -0.237931f,0.897592f,0.371104f, --0.0217966f,0.934365f,0.355651f, --0.0978092f,0.948287f,0.30197f, -0.00875447f,0.940305f,0.340221f, -0.0870369f,0.963741f,0.252246f, -0.143744f,0.964801f,0.220218f, -0.0987042f,0.960888f,0.25875f, -0.124661f,0.953903f,0.273f, --0.0397023f,0.970451f,0.238011f, --0.294392f,0.938787f,0.17892f, --0.415783f,0.892445f,0.175119f, --0.502145f,0.854833f,0.130809f, --0.438287f,0.876552f,0.198899f, --0.315043f,0.920499f,0.231147f, --0.194294f,0.951114f,0.240065f, --0.351808f,0.923717f,0.151587f, --0.54821f,0.835857f,0.0284484f, -0.0750917f,0.989867f,-0.120519f, -0.16891f,0.981624f,-0.0887941f, -0.190217f,0.976992f,-0.0964579f, -0.031324f,0.983953f,-0.175657f, --0.0605958f,0.993695f,-0.0943344f, --0.0750681f,0.99685f,-0.025582f, --0.0331924f,0.999431f,-0.00606515f, --0.0198899f,0.99954f,0.0228873f, --0.0160511f,0.998799f,-0.0462827f, -0.0298246f,0.995221f,-0.092978f, -0.113995f,0.985706f,-0.124048f, -0.249662f,0.968309f,-0.00683024f, -0.100872f,0.992347f,0.0712218f, -0.0920036f,0.982533f,0.161755f, -0.0527146f,0.998589f,-0.00636128f, -0.182827f,0.9816f,-0.0550969f, -0.393766f,0.919069f,-0.0161334f, -0.337394f,0.941358f,0.00313128f, -0.105574f,0.990777f,0.0849468f, --0.199161f,0.971911f,0.125398f, --0.309481f,0.93868f,0.151989f, --0.20903f,0.965522f,0.15516f, -0.0624223f,0.987754f,0.142987f, -0.384312f,0.922399f,0.0385395f, -0.395292f,0.916973f,0.0539f, --0.00445825f,0.983693f,0.179798f, --0.32103f,0.866957f,0.381215f, --0.378167f,0.863609f,0.33342f, --0.220175f,0.926633f,0.304752f, --0.0614943f,0.950074f,0.305906f, --0.12116f,0.98024f,0.156364f, --0.278268f,0.956461f,0.0880323f, --0.168756f,0.960122f,0.222908f, --0.0650574f,0.977781f,0.199281f, -0.11325f,0.979757f,0.165078f, -0.469769f,0.846474f,0.250598f, -0.492575f,0.830428f,0.260305f, -0.123756f,0.962501f,0.241404f, --0.13585f,0.964887f,0.224807f, --0.0763658f,0.97309f,0.217403f, -0.0878568f,0.965257f,0.246088f, -0.105594f,0.951417f,0.289233f, -0.0757959f,0.967864f,0.239781f, -0.0993833f,0.975608f,0.195732f, -0.186309f,0.954458f,0.23302f, -0.338273f,0.909543f,0.241458f, -0.326788f,0.907649f,0.263405f, -0.193788f,0.920444f,0.339454f, -0.0304147f,0.954662f,0.296135f, --0.0232537f,0.980981f,0.192706f, -0.000389577f,0.986091f,0.166207f, -0.0882095f,0.967853f,0.235542f, -0.188357f,0.927906f,0.321731f, -0.0670292f,0.972109f,0.224745f, -0.0943312f,0.961869f,0.256728f, -0.0613113f,0.959756f,0.274061f, --0.207348f,0.967924f,0.141881f, --0.415608f,0.907723f,0.0575284f, --0.500123f,0.863342f,0.0672098f, --0.492039f,0.866172f,0.0874256f, --0.354073f,0.931677f,0.0813054f, --0.181316f,0.978479f,0.0985071f, --0.266622f,0.956284f,0.120138f, --0.442863f,0.891447f,0.0958846f, --0.0871303f,0.98944f,-0.115829f, -0.0906659f,0.9958f,-0.0127409f, -0.283182f,0.958456f,0.0342056f, -0.0813038f,0.994836f,-0.0607581f, --0.14732f,0.989082f,0.00362058f, --0.15085f,0.987502f,0.0456442f, --0.0204288f,0.99901f,0.039516f, -0.00607957f,0.996993f,-0.0772516f, -0.0245166f,0.989435f,-0.142892f, -0.112542f,0.984768f,-0.132539f, -0.117701f,0.980135f,-0.159633f, -0.0712861f,0.996099f,-0.0520052f, -0.0255235f,0.995475f,0.0915291f, -0.102558f,0.988742f,0.10895f, -0.263691f,0.960156f,0.0925667f, -0.248163f,0.965214f,-0.0823197f, -0.340591f,0.934756f,-0.101139f, -0.19652f,0.980248f,0.0222232f, --0.0707824f,0.98306f,0.169067f, --0.214629f,0.938414f,0.270766f, --0.253216f,0.94197f,0.220395f, --0.140751f,0.981088f,0.132876f, -0.0855474f,0.99626f,0.0121329f, -0.407822f,0.912623f,0.0283097f, -0.314806f,0.941456f,0.120654f, --0.127318f,0.956166f,0.263699f, --0.403379f,0.856412f,0.322248f, --0.326125f,0.89105f,0.315709f, --0.192548f,0.934549f,0.29924f, --0.115959f,0.956033f,0.26936f, --0.0455884f,0.940005f,0.3381f, --0.221624f,0.931041f,0.289905f, --0.142796f,0.963558f,0.226198f, -0.0818112f,0.991531f,0.100865f, -0.115133f,0.989689f,-0.0852087f, -0.362891f,0.931224f,-0.0336289f, -0.464909f,0.869676f,0.1659f, -0.12135f,0.938462f,0.323362f, --0.154102f,0.92745f,0.340718f, --0.00840056f,0.94535f,0.325948f, -0.0978542f,0.97811f,0.183647f, -0.11792f,0.982347f,0.145222f, -0.146369f,0.980631f,0.130149f, -0.169334f,0.978423f,0.118383f, -0.164013f,0.985699f,0.0386944f, -0.265906f,0.961228f,0.0730397f, -0.245913f,0.944548f,0.217615f, -0.193695f,0.94265f,0.271832f, -0.193351f,0.95598f,0.22072f, -0.0582845f,0.995708f,0.0718875f, --0.00685416f,0.998237f,0.0589609f, --0.0637908f,0.997757f,0.0202719f, -0.11477f,0.985697f,0.123411f, -0.150647f,0.970382f,0.188848f, -0.0830539f,0.976206f,0.200309f, -0.0503424f,0.976583f,0.20917f, --0.0756986f,0.967299f,0.242081f, --0.38538f,0.913963f,0.127097f, --0.499709f,0.856093f,0.131896f, --0.457912f,0.888414f,0.0322019f, --0.285439f,0.956482f,-0.0605596f, --0.224005f,0.968049f,-0.112706f, --0.33892f,0.940492f,-0.0246551f, --0.468811f,0.882994f,0.0231736f, --0.219323f,0.927554f,-0.302556f, -0.0032435f,0.972826f,-0.231515f, -0.227016f,0.959392f,-0.167423f, -0.0751831f,0.995555f,-0.0567285f, --0.21163f,0.975526f,-0.0596754f, --0.120787f,0.989714f,-0.0766664f, -0.103292f,0.984862f,-0.139202f, -0.130327f,0.957045f,-0.258998f, -0.100597f,0.957666f,-0.269734f, -0.0434385f,0.943793f,-0.327671f, --0.00659457f,0.974177f,-0.225689f, --0.0387678f,0.996731f,-0.0708824f, -0.0108947f,0.998722f,-0.049343f, -0.045379f,0.994354f,-0.0959194f, -0.256328f,0.966322f,0.0227405f, -0.338426f,0.940797f,0.0191927f, -0.245639f,0.967185f,0.0649251f, -0.104201f,0.958601f,0.265004f, --0.106481f,0.952706f,0.284628f, --0.229215f,0.947098f,0.224647f, --0.194403f,0.966329f,0.168569f, --0.00252669f,0.996043f,0.0888332f, -0.156392f,0.987666f,-0.00755935f, -0.321695f,0.943636f,0.0778705f, -0.130492f,0.960095f,0.247363f, --0.218806f,0.887212f,0.406175f, --0.387978f,0.851763f,0.352097f, --0.317465f,0.905687f,0.280974f, --0.175202f,0.945708f,0.273753f, --0.0852507f,0.952748f,0.291554f, --0.110501f,0.951599f,0.28679f, --0.162568f,0.933525f,0.319534f, --0.0379096f,0.973407f,0.225923f, -0.243134f,0.964593f,0.102203f, -0.236277f,0.971524f,-0.017745f, -0.298887f,0.954255f,-0.00800205f, -0.225509f,0.966982f,0.118704f, --0.0160588f,0.939828f,0.341271f, --0.127862f,0.916925f,0.378021f, -0.078893f,0.93958f,0.333116f, -0.244086f,0.933689f,0.262004f, -0.186692f,0.967385f,0.17121f, -0.108188f,0.990525f,0.0845894f, -0.174941f,0.977766f,0.115627f, -0.231991f,0.970242f,0.0693606f, -0.186114f,0.981267f,0.0497696f, -0.166608f,0.977012f,0.133002f, -0.191728f,0.971565f,0.138929f, -0.25765f,0.957218f,0.131718f, -0.087274f,0.989729f,0.113225f, --0.00280678f,0.977756f,0.209725f, -0.0607703f,0.980671f,0.185986f, -0.0485237f,0.997381f,0.053629f, -0.0587736f,0.987863f,0.14378f, -0.0482407f,0.976088f,0.211956f, -0.0134663f,0.978159f,0.20742f, --0.112292f,0.962623f,0.246469f, --0.319272f,0.919627f,0.228803f, --0.453582f,0.883075f,0.120176f, --0.338159f,0.939324f,0.0576029f, --0.23768f,0.971299f,-0.0092623f, --0.191895f,0.980604f,-0.0399f, --0.401044f,0.906011f,-0.135303f, --0.489506f,0.868205f,-0.081269f, --0.196977f,0.901169f,-0.386128f, --0.0562291f,0.922285f,-0.382399f, -0.0867548f,0.952728f,-0.291176f, -0.0232316f,0.988917f,-0.146644f, --0.11605f,0.968007f,-0.222475f, --0.0789033f,0.942785f,-0.323929f, -0.139529f,0.948189f,-0.285427f, -0.132434f,0.962288f,-0.23762f, -0.0765905f,0.96807f,-0.238692f, -0.0641003f,0.96574f,-0.251472f, --0.105766f,0.965216f,-0.239106f, --0.110895f,0.972771f,-0.203515f, -0.0206339f,0.984024f,-0.176838f, -0.0647147f,0.988173f,-0.139018f, -0.148599f,0.980872f,-0.125734f, -0.271512f,0.961735f,0.0367049f, -0.0561912f,0.976773f,0.206777f, --0.0583132f,0.913697f,0.402191f, --0.0462589f,0.893353f,0.446968f, --0.125152f,0.910112f,0.39501f, --0.0803843f,0.940756f,0.329418f, -0.0619859f,0.973174f,0.221562f, -0.135828f,0.971328f,0.195124f, -0.132962f,0.954202f,0.267992f, --0.0325488f,0.903596f,0.427147f, --0.270164f,0.841605f,0.467668f, --0.262238f,0.850223f,0.456456f, --0.212116f,0.889937f,0.403757f, --0.177521f,0.909486f,0.375929f, --0.116828f,0.901627f,0.416436f, --0.0747169f,0.915103f,0.396238f, --0.119776f,0.962629f,0.242896f, -0.0380452f,0.99097f,0.128572f, -0.304108f,0.937317f,0.17016f, -0.240764f,0.951762f,0.190215f, -0.194326f,0.952804f,0.233243f, -0.142453f,0.936947f,0.31912f, --0.0935081f,0.945618f,0.31155f, --0.0887705f,0.956167f,0.27904f, -0.107828f,0.967058f,0.230592f, -0.241042f,0.935322f,0.258984f, -0.259409f,0.922717f,0.285133f, -0.218487f,0.962504f,0.160778f, -0.220571f,0.975062f,0.0245473f, -0.235132f,0.971421f,-0.0324531f, -0.193322f,0.980828f,0.0245576f, -0.123827f,0.992302f,-0.00201728f, -0.206505f,0.97706f,0.0520531f, -0.250594f,0.965023f,0.0770254f, -0.0246334f,0.99033f,0.136524f, --0.123437f,0.964871f,0.231923f, -0.10276f,0.956911f,0.271591f, -0.090829f,0.970486f,0.223397f, -0.00393218f,0.964068f,0.265627f, -0.045739f,0.962581f,0.267105f, -0.0438394f,0.968724f,0.244235f, --0.1348f,0.971521f,0.194876f, --0.247965f,0.950768f,0.185883f, --0.385563f,0.920067f,0.0694089f, --0.33646f,0.941527f,0.0179056f, --0.284408f,0.957673f,0.0444463f, --0.0809611f,0.98246f,0.167982f, --0.272195f,0.961849f,0.0275091f, --0.538305f,0.840251f,-0.0648443f, --0.138085f,0.947265f,-0.289173f, --0.112292f,0.943405f,-0.312055f, --0.0366032f,0.968339f,-0.246942f, --0.0207584f,0.978499f,-0.205204f, --0.0114432f,0.978269f,-0.207024f, --0.017206f,0.978017f,-0.207814f, --0.00196221f,0.968739f,-0.248075f, -0.111459f,0.982805f,-0.147209f, -0.0917515f,0.980196f,-0.175495f, -0.0783409f,0.987595f,-0.136083f, --0.0849004f,0.981698f,-0.170473f, --0.0826208f,0.969176f,-0.232103f, --0.0513296f,0.962825f,-0.265205f, --0.0169212f,0.988046f,-0.153227f, -0.0442536f,0.99886f,0.017891f, -0.0803284f,0.974024f,0.211719f, --0.118041f,0.942704f,0.312052f, --0.187621f,0.893485f,0.408023f, --0.0735772f,0.857937f,0.508459f, --0.0838693f,0.837024f,0.5407f, --0.00356882f,0.863268f,0.504733f, -0.117551f,0.889838f,0.440874f, -0.141271f,0.893306f,0.426669f, -0.0270129f,0.906148f,0.422097f, --0.109486f,0.851548f,0.512717f, --0.266831f,0.814637f,0.514944f, --0.253628f,0.788787f,0.559899f, --0.216685f,0.776961f,0.591083f, --0.15137f,0.760068f,0.631968f, --0.119157f,0.801398f,0.586143f, -0.0626697f,0.817134f,0.573031f, -0.150716f,0.886392f,0.437714f, -0.0719955f,0.965525f,0.250157f, -0.170594f,0.93758f,0.303054f, -0.205981f,0.906978f,0.367374f, -0.159242f,0.93166f,0.326575f, -0.163686f,0.939188f,0.301881f, -0.00255834f,0.983457f,0.181126f, --0.0246414f,0.997684f,0.063397f, -0.103068f,0.994148f,0.0323463f, -0.175261f,0.977189f,0.119941f, -0.238397f,0.946614f,0.216998f, -0.376211f,0.893689f,0.244508f, -0.336321f,0.93903f,0.0714918f, -0.22632f,0.974025f,-0.00733613f, -0.155366f,0.98668f,0.0481989f, -0.129371f,0.988467f,0.0787169f, -0.140766f,0.985457f,0.095182f, -0.181141f,0.974304f,0.133867f, --0.0259321f,0.983166f,0.180868f, --0.16382f,0.974748f,0.151756f, -0.12842f,0.977623f,0.166619f, -0.102805f,0.986615f,0.12658f, --0.0352231f,0.991461f,0.125559f, -0.0344472f,0.990276f,0.134782f, -0.100258f,0.97877f,0.178768f, --0.0763414f,0.992566f,0.0947915f, --0.24142f,0.968616f,0.059149f, --0.325267f,0.943242f,0.06705f, --0.302069f,0.9528f,0.0304413f, --0.317187f,0.948361f,-0.0017587f, --0.219267f,0.973832f,0.059775f, --0.187608f,0.954493f,0.231832f, --0.46452f,0.867868f,0.176143f, --0.203418f,0.948131f,-0.244273f, --0.139664f,0.973265f,-0.182342f, --0.0536959f,0.988785f,-0.139361f, --0.00355604f,0.986781f,-0.162022f, --0.0572809f,0.980561f,-0.187669f, --0.0374007f,0.985205f,-0.167247f, -0.0555765f,0.976159f,-0.209822f, -0.0908927f,0.962348f,-0.256173f, -0.0600715f,0.972748f,-0.223946f, -0.0442581f,0.987652f,-0.150282f, --0.0260568f,0.986636f,-0.160841f, --0.0937884f,0.986183f,-0.136552f, --0.00585357f,0.999959f,-0.00691373f, --0.168872f,0.982349f,-0.0804476f, --0.215485f,0.975309f,0.0483622f, --0.0961691f,0.964354f,0.246521f, --0.114487f,0.922048f,0.369757f, --0.269656f,0.899414f,0.344007f, --0.21772f,0.897789f,0.382849f, --0.126818f,0.886934f,0.444145f, -0.0624514f,0.872607f,0.484415f, -0.170504f,0.863439f,0.474764f, -0.127681f,0.882519f,0.452612f, -0.0249418f,0.887332f,0.460457f, --0.228952f,0.87943f,0.417354f, --0.336679f,0.801754f,0.493799f, --0.354676f,0.742594f,0.568119f, --0.265358f,0.728648f,0.631393f, --0.0874663f,0.774696f,0.626255f, -0.0313715f,0.816845f,0.576004f, -0.138491f,0.877406f,0.459325f, -0.251487f,0.873743f,0.416325f, -0.149012f,0.891076f,0.428695f, -0.134082f,0.895567f,0.424244f, -0.259356f,0.879751f,0.398462f, -0.273738f,0.923515f,0.268677f, -0.242075f,0.954352f,0.174962f, -0.166067f,0.977105f,0.132992f, -0.0519593f,0.998404f,0.022142f, -0.0706628f,0.997395f,0.0145074f, -0.0910476f,0.994722f,0.0473141f, -0.126598f,0.990827f,0.0472679f, -0.33108f,0.937289f,0.108974f, -0.427456f,0.888646f,0.166103f, -0.265492f,0.95292f,0.14648f, -0.0868945f,0.990384f,0.10765f, -0.0739344f,0.98242f,0.171417f, -0.14882f,0.964095f,0.219937f, -0.160065f,0.969614f,0.185009f, -0.0379065f,0.980794f,0.191328f, --0.111879f,0.992654f,0.0460448f, -0.101571f,0.994616f,0.0205655f, -0.134276f,0.987226f,0.0857599f, -0.00322228f,0.996946f,0.0780295f, --0.00585508f,0.99961f,0.0273218f, -0.102527f,0.992913f,0.0601057f, --0.0243337f,0.999696f,0.00385478f, --0.236106f,0.971591f,0.0163038f, --0.335881f,0.941896f,0.00400261f, --0.319925f,0.947097f,0.0255887f, --0.262465f,0.960477f,0.0927118f, --0.320184f,0.947305f,-0.00973767f, --0.358146f,0.929034f,0.0928862f, --0.431591f,0.882961f,0.184686f, --0.350194f,0.913588f,-0.20669f, --0.241714f,0.958821f,-0.149118f, --0.0874799f,0.991928f,-0.0917931f, --0.00637736f,0.998289f,-0.0581162f, -0.0261719f,0.997729f,-0.0620574f, -0.00430678f,0.979141f,-0.203135f, -0.121705f,0.971178f,-0.20494f, -0.10219f,0.965909f,-0.237861f, -0.00407698f,0.957171f,-0.289495f, --0.0386862f,0.968014f,-0.247897f, --0.0509849f,0.995926f,-0.0743816f, --0.228245f,0.973592f,-0.00474817f, --0.140696f,0.979081f,0.146984f, --0.104046f,0.966867f,0.233113f, --0.254332f,0.94315f,0.213969f, --0.211685f,0.953746f,0.213442f, --0.245201f,0.93619f,0.251844f, --0.247199f,0.912647f,0.325527f, --0.213426f,0.932543f,0.291228f, --0.170741f,0.942588f,0.28701f, --0.0363946f,0.943193f,0.330245f, -0.169433f,0.88607f,0.431478f, -0.12169f,0.89261f,0.434096f, -0.0508642f,0.869951f,0.490509f, --0.175065f,0.875657f,0.450086f, --0.464211f,0.815419f,0.345833f, --0.467728f,0.796275f,0.383635f, --0.295863f,0.865688f,0.403795f, --0.0706376f,0.91172f,0.404693f, -0.151265f,0.880258f,0.449738f, -0.239887f,0.896678f,0.372052f, -0.270966f,0.902061f,0.335952f, -0.133682f,0.938928f,0.317085f, -0.132181f,0.949509f,0.284538f, -0.337234f,0.911457f,0.235624f, -0.391568f,0.908725f,0.144547f, -0.297707f,0.949115f,0.10272f, -0.163642f,0.985787f,0.038011f, -0.0603665f,0.994817f,0.0818182f, -0.0342529f,0.984393f,0.172617f, -0.146f,0.969394f,0.197379f, -0.189586f,0.979398f,0.0695505f, -0.32179f,0.946595f,0.0202369f, -0.339913f,0.938655f,0.0581868f, -0.255631f,0.940824f,0.222493f, -0.130905f,0.959362f,0.249975f, -0.0245005f,0.97884f,0.203155f, -0.116898f,0.96642f,0.228839f, -0.217161f,0.952887f,0.211771f, -0.0905814f,0.991503f,0.0933592f, -0.00963547f,0.999795f,0.0178162f, -0.0707892f,0.997359f,-0.0162393f, -0.0454623f,0.996335f,0.0724521f, -0.025845f,0.99119f,0.129903f, -0.0553395f,0.998031f,0.0295398f, -0.0632528f,0.997901f,0.0138837f, --0.000723073f,0.987186f,0.159572f, --0.246121f,0.956173f,0.158611f, --0.292993f,0.948379f,0.121377f, --0.358856f,0.933219f,0.0180357f, --0.312153f,0.948631f,0.0515794f, --0.263061f,0.955548f,0.133141f, --0.387996f,0.907685f,0.159898f, --0.516559f,0.845117f,0.137638f, --0.310178f,0.948377f,-0.0661154f, --0.300026f,0.949757f,-0.0891454f, --0.137668f,0.990363f,0.0151269f, --0.0326899f,0.997118f,0.0684562f, -0.0835016f,0.994462f,0.0638203f, -0.0992766f,0.995028f,0.00796582f, -0.068628f,0.997514f,-0.0159775f, -0.181484f,0.983266f,0.0158879f, -0.0929905f,0.991619f,-0.0896955f, --0.159863f,0.9831f,-0.0892104f, --0.274969f,0.956779f,0.094689f, --0.2578f,0.933703f,0.248472f, --0.255563f,0.934109f,0.249254f, --0.183445f,0.905456f,0.382751f, --0.258353f,0.860148f,0.439771f, --0.12588f,0.873686f,0.469923f, --0.210169f,0.916013f,0.341684f, --0.272883f,0.91339f,0.302083f, --0.180317f,0.937251f,0.298406f, --0.199625f,0.942232f,0.268977f, --0.0859427f,0.9396f,0.33131f, -0.0831524f,0.928739f,0.361288f, -0.0997333f,0.904186f,0.415333f, --0.0517762f,0.893569f,0.445931f, --0.109718f,0.87826f,0.465426f, --0.369685f,0.848108f,0.379534f, --0.446603f,0.811841f,0.376112f, --0.267849f,0.883969f,0.383218f, --0.10672f,0.930725f,0.349801f, -0.10205f,0.92892f,0.355941f, -0.253281f,0.903219f,0.346475f, -0.270898f,0.880967f,0.387957f, -0.236849f,0.896348f,0.374784f, -0.206634f,0.946539f,0.247723f, -0.405577f,0.89206f,0.199342f, -0.379351f,0.915673f,0.1328f, -0.334598f,0.922412f,0.192872f, -0.211991f,0.969195f,0.125385f, --0.0201216f,0.993487f,0.112152f, --0.0648495f,0.986484f,0.150479f, -0.170924f,0.975936f,0.135405f, -0.29249f,0.9553f,0.0430209f, -0.300918f,0.953641f,0.00421578f, -0.280252f,0.954656f,0.100457f, -0.110799f,0.982326f,0.150862f, -0.111953f,0.970209f,0.214852f, -0.0917898f,0.974074f,0.206772f, -0.0706157f,0.981239f,0.179398f, -0.263217f,0.920389f,0.289137f, -0.266708f,0.942871f,0.199653f, -0.0169344f,0.99983f,0.00724636f, -0.0586405f,0.99674f,0.0554216f, --0.0335948f,0.99924f,0.0197934f, -0.0130139f,0.996641f,0.0808552f, -0.158081f,0.974057f,0.161934f, --0.0718701f,0.984912f,0.157428f, --0.146615f,0.930223f,0.336437f, --0.215441f,0.915614f,0.339465f, --0.194576f,0.929319f,0.313857f, --0.21244f,0.956751f,0.198736f, --0.353032f,0.933914f,0.0563254f, --0.387138f,0.913346f,0.126188f, --0.421226f,0.884098f,0.202334f, --0.478159f,0.863227f,0.161871f, --0.144962f,0.987796f,0.0569687f, --0.329752f,0.937067f,-0.114758f, --0.228627f,0.973393f,0.0153452f, --0.0297707f,0.988896f,0.1456f, -0.0737235f,0.992418f,0.0983429f, -0.119683f,0.983634f,0.134687f, -0.0735029f,0.988539f,0.131863f, -0.205816f,0.971725f,0.115713f, -0.105316f,0.994111f,0.0255379f, --0.224655f,0.970814f,0.0839657f, --0.371877f,0.9075f,0.195325f, --0.304303f,0.906448f,0.292833f, --0.280483f,0.900657f,0.331883f, --0.306628f,0.862929f,0.401664f, --0.272078f,0.807801f,0.522907f, --0.0728986f,0.827771f,0.55631f, --0.0766844f,0.868115f,0.490404f, --0.262952f,0.903979f,0.337163f, --0.116268f,0.92805f,0.353844f, --0.236581f,0.941122f,0.241494f, --0.103825f,0.933685f,0.342713f, -0.0620174f,0.936003f,0.346485f, -0.0525461f,0.928042f,0.368751f, --0.037371f,0.900626f,0.432986f, --0.0859425f,0.920181f,0.381944f, --0.402084f,0.867474f,0.292945f, --0.458834f,0.792013f,0.402725f, --0.247545f,0.839465f,0.483756f, --0.0206347f,0.857039f,0.514838f, -0.131938f,0.906082f,0.402004f, -0.260907f,0.906936f,0.330749f, -0.222736f,0.912076f,0.344246f, -0.286017f,0.867948f,0.406029f, -0.265664f,0.918021f,0.29438f, -0.386646f,0.888781f,0.246116f, -0.416594f,0.869611f,0.265003f, -0.291338f,0.924889f,0.244341f, -0.264598f,0.920497f,0.287528f, --0.0209737f,0.965015f,0.261353f, -0.011928f,0.966786f,0.255307f, -0.209759f,0.975171f,0.0710066f, -0.379568f,0.924828f,0.0249204f, -0.227757f,0.968062f,-0.104795f, -0.230276f,0.968937f,0.0901831f, -0.121279f,0.97806f,0.169381f, -0.101139f,0.989453f,0.103701f, -0.125341f,0.986876f,0.101809f, -0.00931107f,0.998148f,0.0601183f, -0.147262f,0.96746f,0.205755f, -0.372526f,0.861294f,0.34554f, -0.0770606f,0.989688f,0.120749f, -0.0673416f,0.990666f,0.11852f, -0.0242126f,0.998823f,0.0420167f, --0.0975945f,0.993903f,-0.0513095f, -0.0117629f,0.986762f,0.16175f, --0.119035f,0.908985f,0.399472f, --0.171696f,0.877378f,0.448027f, --0.168225f,0.894295f,0.414653f, --0.158105f,0.915758f,0.369311f, --0.0984338f,0.938718f,0.330333f, --0.319812f,0.930617f,0.177966f, --0.398204f,0.897351f,0.190248f, --0.414882f,0.896338f,0.156369f, --0.434877f,0.894265f,0.105701f, -}; - -btScalar Landscape07Tex[] = { -0.507813f,0.742188f, -0.507813f,0.734375f, -0.515625f,0.742188f, -0.515625f,0.734375f, -0.523438f,0.742188f, -0.523438f,0.734375f, -0.53125f,0.742188f, -0.53125f,0.734375f, -0.539063f,0.742188f, -0.539063f,0.734375f, -0.546875f,0.742188f, -0.546875f,0.734375f, -0.554688f,0.742188f, -0.554688f,0.734375f, -0.5625f,0.742188f, -0.5625f,0.734375f, -0.570313f,0.742188f, -0.570313f,0.734375f, -0.578125f,0.742188f, -0.578125f,0.734375f, -0.585938f,0.742188f, -0.585938f,0.734375f, -0.59375f,0.742188f, -0.59375f,0.734375f, -0.601563f,0.742188f, -0.601563f,0.734375f, -0.609375f,0.742188f, -0.609375f,0.734375f, -0.617188f,0.742188f, -0.617188f,0.734375f, -0.625f,0.742188f, -0.625f,0.734375f, -0.632813f,0.742188f, -0.632813f,0.734375f, -0.640625f,0.742188f, -0.640625f,0.734375f, -0.648438f,0.742188f, -0.648438f,0.734375f, -0.65625f,0.742188f, -0.65625f,0.734375f, -0.664063f,0.742188f, -0.664063f,0.734375f, -0.671875f,0.742188f, -0.671875f,0.734375f, -0.679688f,0.742188f, -0.679688f,0.734375f, -0.6875f,0.742188f, -0.6875f,0.734375f, -0.695313f,0.742188f, -0.695313f,0.734375f, -0.703125f,0.742188f, -0.703125f,0.734375f, -0.710938f,0.742188f, -0.710938f,0.734375f, -0.71875f,0.742188f, -0.71875f,0.734375f, -0.726563f,0.742188f, -0.726563f,0.734375f, -0.734375f,0.742188f, -0.734375f,0.734375f, -0.742188f,0.742188f, -0.742188f,0.734375f, -0.75f,0.742188f, -0.75f,0.734375f, -0.757813f,0.742188f, -0.757813f,0.734375f, -0.765625f,0.742188f, -0.765625f,0.734375f, -0.773438f,0.742188f, -0.773438f,0.734375f, -0.78125f,0.742188f, -0.78125f,0.734375f, -0.789063f,0.742188f, -0.789063f,0.734375f, -0.796875f,0.742188f, -0.796875f,0.734375f, -0.804688f,0.742188f, -0.804688f,0.734375f, -0.8125f,0.742188f, -0.8125f,0.734375f, -0.820313f,0.742188f, -0.820313f,0.734375f, -0.828125f,0.742188f, -0.828125f,0.734375f, -0.835938f,0.742188f, -0.835938f,0.734375f, -0.84375f,0.742188f, -0.84375f,0.734375f, -0.851563f,0.742188f, -0.851563f,0.734375f, -0.859375f,0.742188f, -0.859375f,0.734375f, -0.867188f,0.742188f, -0.867188f,0.734375f, -0.875f,0.742188f, -0.875f,0.734375f, -0.882813f,0.742188f, -0.882813f,0.734375f, -0.890625f,0.742188f, -0.890625f,0.734375f, -0.898438f,0.742188f, -0.898438f,0.734375f, -0.90625f,0.742188f, -0.90625f,0.734375f, -0.914063f,0.742188f, -0.914063f,0.734375f, -0.921875f,0.742188f, -0.921875f,0.734375f, -0.929688f,0.742188f, -0.929688f,0.734375f, -0.9375f,0.742188f, -0.9375f,0.734375f, -0.945313f,0.742188f, -0.945313f,0.734375f, -0.953125f,0.742188f, -0.953125f,0.734375f, -0.960938f,0.742188f, -0.960938f,0.734375f, -0.96875f,0.742188f, -0.96875f,0.734375f, -0.976563f,0.742188f, -0.976563f,0.734375f, -0.984375f,0.742188f, -0.984375f,0.734375f, -0.992188f,0.742188f, -0.992188f,0.734375f, -1.0f,0.742188f, -1.0f,0.734375f, -0.507813f,0.75f, -0.515625f,0.75f, -0.523438f,0.75f, -0.53125f,0.75f, -0.539063f,0.75f, -0.546875f,0.75f, -0.554688f,0.75f, -0.5625f,0.75f, -0.570313f,0.75f, -0.578125f,0.75f, -0.585938f,0.75f, -0.59375f,0.75f, -0.601563f,0.75f, -0.609375f,0.75f, -0.617188f,0.75f, -0.625f,0.75f, -0.632813f,0.75f, -0.640625f,0.75f, -0.648438f,0.75f, -0.65625f,0.75f, -0.664063f,0.75f, -0.671875f,0.75f, -0.679688f,0.75f, -0.6875f,0.75f, -0.695313f,0.75f, -0.703125f,0.75f, -0.710938f,0.75f, -0.71875f,0.75f, -0.726563f,0.75f, -0.734375f,0.75f, -0.742188f,0.75f, -0.75f,0.75f, -0.757813f,0.75f, -0.765625f,0.75f, -0.773438f,0.75f, -0.78125f,0.75f, -0.789063f,0.75f, -0.796875f,0.75f, -0.804688f,0.75f, -0.8125f,0.75f, -0.820313f,0.75f, -0.828125f,0.75f, -0.835938f,0.75f, -0.84375f,0.75f, -0.851563f,0.75f, -0.859375f,0.75f, -0.867188f,0.75f, -0.875f,0.75f, -0.882813f,0.75f, -0.890625f,0.75f, -0.898438f,0.75f, -0.90625f,0.75f, -0.914063f,0.75f, -0.921875f,0.75f, -0.929688f,0.75f, -0.9375f,0.75f, -0.945313f,0.75f, -0.953125f,0.75f, -0.960938f,0.75f, -0.96875f,0.75f, -0.976563f,0.75f, -0.984375f,0.75f, -0.992188f,0.75f, -1.0f,0.75f, -0.507813f,0.757813f, -0.515625f,0.757813f, -0.523438f,0.757813f, -0.53125f,0.757813f, -0.539063f,0.757813f, -0.546875f,0.757813f, -0.554688f,0.757813f, -0.5625f,0.757813f, -0.570313f,0.757813f, -0.578125f,0.757813f, -0.585938f,0.757813f, -0.59375f,0.757813f, -0.601563f,0.757813f, -0.609375f,0.757813f, -0.617188f,0.757813f, -0.625f,0.757813f, -0.632813f,0.757813f, -0.640625f,0.757813f, -0.648438f,0.757813f, -0.65625f,0.757813f, -0.664063f,0.757813f, -0.671875f,0.757813f, -0.679688f,0.757813f, -0.6875f,0.757813f, -0.695313f,0.757813f, -0.703125f,0.757813f, -0.710938f,0.757813f, -0.71875f,0.757813f, -0.726563f,0.757813f, -0.734375f,0.757813f, -0.742188f,0.757813f, -0.75f,0.757813f, -0.757813f,0.757813f, -0.765625f,0.757813f, -0.773438f,0.757813f, -0.78125f,0.757813f, -0.789063f,0.757813f, -0.796875f,0.757813f, -0.804688f,0.757813f, -0.8125f,0.757813f, -0.820313f,0.757813f, -0.828125f,0.757813f, -0.835938f,0.757813f, -0.84375f,0.757813f, -0.851563f,0.757813f, -0.859375f,0.757813f, -0.867188f,0.757813f, -0.875f,0.757813f, -0.882813f,0.757813f, -0.890625f,0.757813f, -0.898438f,0.757813f, -0.90625f,0.757813f, -0.914063f,0.757813f, -0.921875f,0.757813f, -0.929688f,0.757813f, -0.9375f,0.757813f, -0.945313f,0.757813f, -0.953125f,0.757813f, -0.960938f,0.757813f, -0.96875f,0.757813f, -0.976563f,0.757813f, -0.984375f,0.757813f, -0.992188f,0.757813f, -1.0f,0.757813f, -0.507813f,0.765625f, -0.515625f,0.765625f, -0.523438f,0.765625f, -0.53125f,0.765625f, -0.539063f,0.765625f, -0.546875f,0.765625f, -0.554688f,0.765625f, -0.5625f,0.765625f, -0.570313f,0.765625f, -0.578125f,0.765625f, -0.585938f,0.765625f, -0.59375f,0.765625f, -0.601563f,0.765625f, -0.609375f,0.765625f, -0.617188f,0.765625f, -0.625f,0.765625f, -0.632813f,0.765625f, -0.640625f,0.765625f, -0.648438f,0.765625f, -0.65625f,0.765625f, -0.664063f,0.765625f, -0.671875f,0.765625f, -0.679688f,0.765625f, -0.6875f,0.765625f, -0.695313f,0.765625f, -0.703125f,0.765625f, -0.710938f,0.765625f, -0.71875f,0.765625f, -0.726563f,0.765625f, -0.734375f,0.765625f, -0.742188f,0.765625f, -0.75f,0.765625f, -0.757813f,0.765625f, -0.765625f,0.765625f, -0.773438f,0.765625f, -0.78125f,0.765625f, -0.789063f,0.765625f, -0.796875f,0.765625f, -0.804688f,0.765625f, -0.8125f,0.765625f, -0.820313f,0.765625f, -0.828125f,0.765625f, -0.835938f,0.765625f, -0.84375f,0.765625f, -0.851563f,0.765625f, -0.859375f,0.765625f, -0.867188f,0.765625f, -0.875f,0.765625f, -0.882813f,0.765625f, -0.890625f,0.765625f, -0.898438f,0.765625f, -0.90625f,0.765625f, -0.914063f,0.765625f, -0.921875f,0.765625f, -0.929688f,0.765625f, -0.9375f,0.765625f, -0.945313f,0.765625f, -0.953125f,0.765625f, -0.960938f,0.765625f, -0.96875f,0.765625f, -0.976563f,0.765625f, -0.984375f,0.765625f, -0.992188f,0.765625f, -1.0f,0.765625f, -0.507813f,0.773438f, -0.515625f,0.773438f, -0.523438f,0.773438f, -0.53125f,0.773438f, -0.539063f,0.773438f, -0.546875f,0.773438f, -0.554688f,0.773438f, -0.5625f,0.773438f, -0.570313f,0.773438f, -0.578125f,0.773438f, -0.585938f,0.773438f, -0.59375f,0.773438f, -0.601563f,0.773438f, -0.609375f,0.773438f, -0.617188f,0.773438f, -0.625f,0.773438f, -0.632813f,0.773438f, -0.640625f,0.773438f, -0.648438f,0.773438f, -0.65625f,0.773438f, -0.664063f,0.773438f, -0.671875f,0.773438f, -0.679688f,0.773438f, -0.6875f,0.773438f, -0.695313f,0.773438f, -0.703125f,0.773438f, -0.710938f,0.773438f, -0.71875f,0.773438f, -0.726563f,0.773438f, -0.734375f,0.773438f, -0.742188f,0.773438f, -0.75f,0.773438f, -0.757813f,0.773438f, -0.765625f,0.773438f, -0.773438f,0.773438f, -0.78125f,0.773438f, -0.789063f,0.773438f, -0.796875f,0.773438f, -0.804688f,0.773438f, -0.8125f,0.773438f, -0.820313f,0.773438f, -0.828125f,0.773438f, -0.835938f,0.773438f, -0.84375f,0.773438f, -0.851563f,0.773438f, -0.859375f,0.773438f, -0.867188f,0.773438f, -0.875f,0.773438f, -0.882813f,0.773438f, -0.890625f,0.773438f, -0.898438f,0.773438f, -0.90625f,0.773438f, -0.914063f,0.773438f, -0.921875f,0.773438f, -0.929688f,0.773438f, -0.9375f,0.773438f, -0.945313f,0.773438f, -0.953125f,0.773438f, -0.960938f,0.773438f, -0.96875f,0.773438f, -0.976563f,0.773438f, -0.984375f,0.773438f, -0.992188f,0.773438f, -1.0f,0.773438f, -0.507813f,0.78125f, -0.515625f,0.78125f, -0.523438f,0.78125f, -0.53125f,0.78125f, -0.539063f,0.78125f, -0.546875f,0.78125f, -0.554688f,0.78125f, -0.5625f,0.78125f, -0.570313f,0.78125f, -0.578125f,0.78125f, -0.585938f,0.78125f, -0.59375f,0.78125f, -0.601563f,0.78125f, -0.609375f,0.78125f, -0.617188f,0.78125f, -0.625f,0.78125f, -0.632813f,0.78125f, -0.640625f,0.78125f, -0.648438f,0.78125f, -0.65625f,0.78125f, -0.664063f,0.78125f, -0.671875f,0.78125f, -0.679688f,0.78125f, -0.6875f,0.78125f, -0.695313f,0.78125f, -0.703125f,0.78125f, -0.710938f,0.78125f, -0.71875f,0.78125f, -0.726563f,0.78125f, -0.734375f,0.78125f, -0.742188f,0.78125f, -0.75f,0.78125f, -0.757813f,0.78125f, -0.765625f,0.78125f, -0.773438f,0.78125f, -0.78125f,0.78125f, -0.789063f,0.78125f, -0.796875f,0.78125f, -0.804688f,0.78125f, -0.8125f,0.78125f, -0.820313f,0.78125f, -0.828125f,0.78125f, -0.835938f,0.78125f, -0.84375f,0.78125f, -0.851563f,0.78125f, -0.859375f,0.78125f, -0.867188f,0.78125f, -0.875f,0.78125f, -0.882813f,0.78125f, -0.890625f,0.78125f, -0.898438f,0.78125f, -0.90625f,0.78125f, -0.914063f,0.78125f, -0.921875f,0.78125f, -0.929688f,0.78125f, -0.9375f,0.78125f, -0.945313f,0.78125f, -0.953125f,0.78125f, -0.960938f,0.78125f, -0.96875f,0.78125f, -0.976563f,0.78125f, -0.984375f,0.78125f, -0.992188f,0.78125f, -1.0f,0.78125f, -0.507813f,0.789063f, -0.515625f,0.789063f, -0.523438f,0.789063f, -0.53125f,0.789063f, -0.539063f,0.789063f, -0.546875f,0.789063f, -0.554688f,0.789063f, -0.5625f,0.789063f, -0.570313f,0.789063f, -0.578125f,0.789063f, -0.585938f,0.789063f, -0.59375f,0.789063f, -0.601563f,0.789063f, -0.609375f,0.789063f, -0.617188f,0.789063f, -0.625f,0.789063f, -0.632813f,0.789063f, -0.640625f,0.789063f, -0.648438f,0.789063f, -0.65625f,0.789063f, -0.664063f,0.789063f, -0.671875f,0.789063f, -0.679688f,0.789063f, -0.6875f,0.789063f, -0.695313f,0.789063f, -0.703125f,0.789063f, -0.710938f,0.789063f, -0.71875f,0.789063f, -0.726563f,0.789063f, -0.734375f,0.789063f, -0.742188f,0.789063f, -0.75f,0.789063f, -0.757813f,0.789063f, -0.765625f,0.789063f, -0.773438f,0.789063f, -0.78125f,0.789063f, -0.789063f,0.789063f, -0.796875f,0.789063f, -0.804688f,0.789063f, -0.8125f,0.789063f, -0.820313f,0.789063f, -0.828125f,0.789063f, -0.835938f,0.789063f, -0.84375f,0.789063f, -0.851563f,0.789063f, -0.859375f,0.789063f, -0.867188f,0.789063f, -0.875f,0.789063f, -0.882813f,0.789063f, -0.890625f,0.789063f, -0.898438f,0.789063f, -0.90625f,0.789063f, -0.914063f,0.789063f, -0.921875f,0.789063f, -0.929688f,0.789063f, -0.9375f,0.789063f, -0.945313f,0.789063f, -0.953125f,0.789063f, -0.960938f,0.789063f, -0.96875f,0.789063f, -0.976563f,0.789063f, -0.984375f,0.789063f, -0.992188f,0.789063f, -1.0f,0.789063f, -0.507813f,0.796875f, -0.515625f,0.796875f, -0.523438f,0.796875f, -0.53125f,0.796875f, -0.539063f,0.796875f, -0.546875f,0.796875f, -0.554688f,0.796875f, -0.5625f,0.796875f, -0.570313f,0.796875f, -0.578125f,0.796875f, -0.585938f,0.796875f, -0.59375f,0.796875f, -0.601563f,0.796875f, -0.609375f,0.796875f, -0.617188f,0.796875f, -0.625f,0.796875f, -0.632813f,0.796875f, -0.640625f,0.796875f, -0.648438f,0.796875f, -0.65625f,0.796875f, -0.664063f,0.796875f, -0.671875f,0.796875f, -0.679688f,0.796875f, -0.6875f,0.796875f, -0.695313f,0.796875f, -0.703125f,0.796875f, -0.710938f,0.796875f, -0.71875f,0.796875f, -0.726563f,0.796875f, -0.734375f,0.796875f, -0.742188f,0.796875f, -0.75f,0.796875f, -0.757813f,0.796875f, -0.765625f,0.796875f, -0.773438f,0.796875f, -0.78125f,0.796875f, -0.789063f,0.796875f, -0.796875f,0.796875f, -0.804688f,0.796875f, -0.8125f,0.796875f, -0.820313f,0.796875f, -0.828125f,0.796875f, -0.835938f,0.796875f, -0.84375f,0.796875f, -0.851563f,0.796875f, -0.859375f,0.796875f, -0.867188f,0.796875f, -0.875f,0.796875f, -0.882813f,0.796875f, -0.890625f,0.796875f, -0.898438f,0.796875f, -0.90625f,0.796875f, -0.914063f,0.796875f, -0.921875f,0.796875f, -0.929688f,0.796875f, -0.9375f,0.796875f, -0.945313f,0.796875f, -0.953125f,0.796875f, -0.960938f,0.796875f, -0.96875f,0.796875f, -0.976563f,0.796875f, -0.984375f,0.796875f, -0.992188f,0.796875f, -1.0f,0.796875f, -0.507813f,0.804688f, -0.515625f,0.804688f, -0.523438f,0.804688f, -0.53125f,0.804688f, -0.539063f,0.804688f, -0.546875f,0.804688f, -0.554688f,0.804688f, -0.5625f,0.804688f, -0.570313f,0.804688f, -0.578125f,0.804688f, -0.585938f,0.804688f, -0.59375f,0.804688f, -0.601563f,0.804688f, -0.609375f,0.804688f, -0.617188f,0.804688f, -0.625f,0.804688f, -0.632813f,0.804688f, -0.640625f,0.804688f, -0.648438f,0.804688f, -0.65625f,0.804688f, -0.664063f,0.804688f, -0.671875f,0.804688f, -0.679688f,0.804688f, -0.6875f,0.804688f, -0.695313f,0.804688f, -0.703125f,0.804688f, -0.710938f,0.804688f, -0.71875f,0.804688f, -0.726563f,0.804688f, -0.734375f,0.804688f, -0.742188f,0.804688f, -0.75f,0.804688f, -0.757813f,0.804688f, -0.765625f,0.804688f, -0.773438f,0.804688f, -0.78125f,0.804688f, -0.789063f,0.804688f, -0.796875f,0.804688f, -0.804688f,0.804688f, -0.8125f,0.804688f, -0.820313f,0.804688f, -0.828125f,0.804688f, -0.835938f,0.804688f, -0.84375f,0.804688f, -0.851563f,0.804688f, -0.859375f,0.804688f, -0.867188f,0.804688f, -0.875f,0.804688f, -0.882813f,0.804688f, -0.890625f,0.804688f, -0.898438f,0.804688f, -0.90625f,0.804688f, -0.914063f,0.804688f, -0.921875f,0.804688f, -0.929688f,0.804688f, -0.9375f,0.804688f, -0.945313f,0.804688f, -0.953125f,0.804688f, -0.960938f,0.804688f, -0.96875f,0.804688f, -0.976563f,0.804688f, -0.984375f,0.804688f, -0.992188f,0.804688f, -1.0f,0.804688f, -0.507813f,0.8125f, -0.515625f,0.8125f, -0.523438f,0.8125f, -0.53125f,0.8125f, -0.539063f,0.8125f, -0.546875f,0.8125f, -0.554688f,0.8125f, -0.5625f,0.8125f, -0.570313f,0.8125f, -0.578125f,0.8125f, -0.585938f,0.8125f, -0.59375f,0.8125f, -0.601563f,0.8125f, -0.609375f,0.8125f, -0.617188f,0.8125f, -0.625f,0.8125f, -0.632813f,0.8125f, -0.640625f,0.8125f, -0.648438f,0.8125f, -0.65625f,0.8125f, -0.664063f,0.8125f, -0.671875f,0.8125f, -0.679688f,0.8125f, -0.6875f,0.8125f, -0.695313f,0.8125f, -0.703125f,0.8125f, -0.710938f,0.8125f, -0.71875f,0.8125f, -0.726563f,0.8125f, -0.734375f,0.8125f, -0.742188f,0.8125f, -0.75f,0.8125f, -0.757813f,0.8125f, -0.765625f,0.8125f, -0.773438f,0.8125f, -0.78125f,0.8125f, -0.789063f,0.8125f, -0.796875f,0.8125f, -0.804688f,0.8125f, -0.8125f,0.8125f, -0.820313f,0.8125f, -0.828125f,0.8125f, -0.835938f,0.8125f, -0.84375f,0.8125f, -0.851563f,0.8125f, -0.859375f,0.8125f, -0.867188f,0.8125f, -0.875f,0.8125f, -0.882813f,0.8125f, -0.890625f,0.8125f, -0.898438f,0.8125f, -0.90625f,0.8125f, -0.914063f,0.8125f, -0.921875f,0.8125f, -0.929688f,0.8125f, -0.9375f,0.8125f, -0.945313f,0.8125f, -0.953125f,0.8125f, -0.960938f,0.8125f, -0.96875f,0.8125f, -0.976563f,0.8125f, -0.984375f,0.8125f, -0.992188f,0.8125f, -1.0f,0.8125f, -0.507813f,0.820313f, -0.515625f,0.820313f, -0.523438f,0.820313f, -0.53125f,0.820313f, -0.539063f,0.820313f, -0.546875f,0.820313f, -0.554688f,0.820313f, -0.5625f,0.820313f, -0.570313f,0.820313f, -0.578125f,0.820313f, -0.585938f,0.820313f, -0.59375f,0.820313f, -0.601563f,0.820313f, -0.609375f,0.820313f, -0.617188f,0.820313f, -0.625f,0.820313f, -0.632813f,0.820313f, -0.640625f,0.820313f, -0.648438f,0.820313f, -0.65625f,0.820313f, -0.664063f,0.820313f, -0.671875f,0.820313f, -0.679688f,0.820313f, -0.6875f,0.820313f, -0.695313f,0.820313f, -0.703125f,0.820313f, -0.710938f,0.820313f, -0.71875f,0.820313f, -0.726563f,0.820313f, -0.734375f,0.820313f, -0.742188f,0.820313f, -0.75f,0.820313f, -0.757813f,0.820313f, -0.765625f,0.820313f, -0.773438f,0.820313f, -0.78125f,0.820313f, -0.789063f,0.820313f, -0.796875f,0.820313f, -0.804688f,0.820313f, -0.8125f,0.820313f, -0.820313f,0.820313f, -0.828125f,0.820313f, -0.835938f,0.820313f, -0.84375f,0.820313f, -0.851563f,0.820313f, -0.859375f,0.820313f, -0.867188f,0.820313f, -0.875f,0.820313f, -0.882813f,0.820313f, -0.890625f,0.820313f, -0.898438f,0.820313f, -0.90625f,0.820313f, -0.914063f,0.820313f, -0.921875f,0.820313f, -0.929688f,0.820313f, -0.9375f,0.820313f, -0.945313f,0.820313f, -0.953125f,0.820313f, -0.960938f,0.820313f, -0.96875f,0.820313f, -0.976563f,0.820313f, -0.984375f,0.820313f, -0.992188f,0.820313f, -1.0f,0.820313f, -0.507813f,0.828125f, -0.515625f,0.828125f, -0.523438f,0.828125f, -0.53125f,0.828125f, -0.539063f,0.828125f, -0.546875f,0.828125f, -0.554688f,0.828125f, -0.5625f,0.828125f, -0.570313f,0.828125f, -0.578125f,0.828125f, -0.585938f,0.828125f, -0.59375f,0.828125f, -0.601563f,0.828125f, -0.609375f,0.828125f, -0.617188f,0.828125f, -0.625f,0.828125f, -0.632813f,0.828125f, -0.640625f,0.828125f, -0.648438f,0.828125f, -0.65625f,0.828125f, -0.664063f,0.828125f, -0.671875f,0.828125f, -0.679688f,0.828125f, -0.6875f,0.828125f, -0.695313f,0.828125f, -0.703125f,0.828125f, -0.710938f,0.828125f, -0.71875f,0.828125f, -0.726563f,0.828125f, -0.734375f,0.828125f, -0.742188f,0.828125f, -0.75f,0.828125f, -0.757813f,0.828125f, -0.765625f,0.828125f, -0.773438f,0.828125f, -0.78125f,0.828125f, -0.789063f,0.828125f, -0.796875f,0.828125f, -0.804688f,0.828125f, -0.8125f,0.828125f, -0.820313f,0.828125f, -0.828125f,0.828125f, -0.835938f,0.828125f, -0.84375f,0.828125f, -0.851563f,0.828125f, -0.859375f,0.828125f, -0.867188f,0.828125f, -0.875f,0.828125f, -0.882813f,0.828125f, -0.890625f,0.828125f, -0.898438f,0.828125f, -0.90625f,0.828125f, -0.914063f,0.828125f, -0.921875f,0.828125f, -0.929688f,0.828125f, -0.9375f,0.828125f, -0.945313f,0.828125f, -0.953125f,0.828125f, -0.960938f,0.828125f, -0.96875f,0.828125f, -0.976563f,0.828125f, -0.984375f,0.828125f, -0.992188f,0.828125f, -1.0f,0.828125f, -0.507813f,0.835938f, -0.515625f,0.835938f, -0.523438f,0.835938f, -0.53125f,0.835938f, -0.539063f,0.835938f, -0.546875f,0.835938f, -0.554688f,0.835938f, -0.5625f,0.835938f, -0.570313f,0.835938f, -0.578125f,0.835938f, -0.585938f,0.835938f, -0.59375f,0.835938f, -0.601563f,0.835938f, -0.609375f,0.835938f, -0.617188f,0.835938f, -0.625f,0.835938f, -0.632813f,0.835938f, -0.640625f,0.835938f, -0.648438f,0.835938f, -0.65625f,0.835938f, -0.664063f,0.835938f, -0.671875f,0.835938f, -0.679688f,0.835938f, -0.6875f,0.835938f, -0.695313f,0.835938f, -0.703125f,0.835938f, -0.710938f,0.835938f, -0.71875f,0.835938f, -0.726563f,0.835938f, -0.734375f,0.835938f, -0.742188f,0.835938f, -0.75f,0.835938f, -0.757813f,0.835938f, -0.765625f,0.835938f, -0.773438f,0.835938f, -0.78125f,0.835938f, -0.789063f,0.835938f, -0.796875f,0.835938f, -0.804688f,0.835938f, -0.8125f,0.835938f, -0.820313f,0.835938f, -0.828125f,0.835938f, -0.835938f,0.835938f, -0.84375f,0.835938f, -0.851563f,0.835938f, -0.859375f,0.835938f, -0.867188f,0.835938f, -0.875f,0.835938f, -0.882813f,0.835938f, -0.890625f,0.835938f, -0.898438f,0.835938f, -0.90625f,0.835938f, -0.914063f,0.835938f, -0.921875f,0.835938f, -0.929688f,0.835938f, -0.9375f,0.835938f, -0.945313f,0.835938f, -0.953125f,0.835938f, -0.960938f,0.835938f, -0.96875f,0.835938f, -0.976563f,0.835938f, -0.984375f,0.835938f, -0.992188f,0.835938f, -1.0f,0.835938f, -0.507813f,0.84375f, -0.515625f,0.84375f, -0.523438f,0.84375f, -0.53125f,0.84375f, -0.539063f,0.84375f, -0.546875f,0.84375f, -0.554688f,0.84375f, -0.5625f,0.84375f, -0.570313f,0.84375f, -0.578125f,0.84375f, -0.585938f,0.84375f, -0.59375f,0.84375f, -0.601563f,0.84375f, -0.609375f,0.84375f, -0.617188f,0.84375f, -0.625f,0.84375f, -0.632813f,0.84375f, -0.640625f,0.84375f, -0.648438f,0.84375f, -0.65625f,0.84375f, -0.664063f,0.84375f, -0.671875f,0.84375f, -0.679688f,0.84375f, -0.6875f,0.84375f, -0.695313f,0.84375f, -0.703125f,0.84375f, -0.710938f,0.84375f, -0.71875f,0.84375f, -0.726563f,0.84375f, -0.734375f,0.84375f, -0.742188f,0.84375f, -0.75f,0.84375f, -0.757813f,0.84375f, -0.765625f,0.84375f, -0.773438f,0.84375f, -0.78125f,0.84375f, -0.789063f,0.84375f, -0.796875f,0.84375f, -0.804688f,0.84375f, -0.8125f,0.84375f, -0.820313f,0.84375f, -0.828125f,0.84375f, -0.835938f,0.84375f, -0.84375f,0.84375f, -0.851563f,0.84375f, -0.859375f,0.84375f, -0.867188f,0.84375f, -0.875f,0.84375f, -0.882813f,0.84375f, -0.890625f,0.84375f, -0.898438f,0.84375f, -0.90625f,0.84375f, -0.914063f,0.84375f, -0.921875f,0.84375f, -0.929688f,0.84375f, -0.9375f,0.84375f, -0.945313f,0.84375f, -0.953125f,0.84375f, -0.960938f,0.84375f, -0.96875f,0.84375f, -0.976563f,0.84375f, -0.984375f,0.84375f, -0.992188f,0.84375f, -1.0f,0.84375f, -0.507813f,0.851563f, -0.515625f,0.851563f, -0.523438f,0.851563f, -0.53125f,0.851563f, -0.539063f,0.851563f, -0.546875f,0.851563f, -0.554688f,0.851563f, -0.5625f,0.851563f, -0.570313f,0.851563f, -0.578125f,0.851563f, -0.585938f,0.851563f, -0.59375f,0.851563f, -0.601563f,0.851563f, -0.609375f,0.851563f, -0.617188f,0.851563f, -0.625f,0.851563f, -0.632813f,0.851563f, -0.640625f,0.851563f, -0.648438f,0.851563f, -0.65625f,0.851563f, -0.664063f,0.851563f, -0.671875f,0.851563f, -0.679688f,0.851563f, -0.6875f,0.851563f, -0.695313f,0.851563f, -0.703125f,0.851563f, -0.710938f,0.851563f, -0.71875f,0.851563f, -0.726563f,0.851563f, -0.734375f,0.851563f, -0.742188f,0.851563f, -0.75f,0.851563f, -0.757813f,0.851563f, -0.765625f,0.851563f, -0.773438f,0.851563f, -0.78125f,0.851563f, -0.789063f,0.851563f, -0.796875f,0.851563f, -0.804688f,0.851563f, -0.8125f,0.851563f, -0.820313f,0.851563f, -0.828125f,0.851563f, -0.835938f,0.851563f, -0.84375f,0.851563f, -0.851563f,0.851563f, -0.859375f,0.851563f, -0.867188f,0.851563f, -0.875f,0.851563f, -0.882813f,0.851563f, -0.890625f,0.851563f, -0.898438f,0.851563f, -0.90625f,0.851563f, -0.914063f,0.851563f, -0.921875f,0.851563f, -0.929688f,0.851563f, -0.9375f,0.851563f, -0.945313f,0.851563f, -0.953125f,0.851563f, -0.960938f,0.851563f, -0.96875f,0.851563f, -0.976563f,0.851563f, -0.984375f,0.851563f, -0.992188f,0.851563f, -1.0f,0.851563f, -0.507813f,0.859375f, -0.515625f,0.859375f, -0.523438f,0.859375f, -0.53125f,0.859375f, -0.539063f,0.859375f, -0.546875f,0.859375f, -0.554688f,0.859375f, -0.5625f,0.859375f, -0.570313f,0.859375f, -0.578125f,0.859375f, -0.585938f,0.859375f, -0.59375f,0.859375f, -0.601563f,0.859375f, -0.609375f,0.859375f, -0.617188f,0.859375f, -0.625f,0.859375f, -0.632813f,0.859375f, -0.640625f,0.859375f, -0.648438f,0.859375f, -0.65625f,0.859375f, -0.664063f,0.859375f, -0.671875f,0.859375f, -0.679688f,0.859375f, -0.6875f,0.859375f, -0.695313f,0.859375f, -0.703125f,0.859375f, -0.710938f,0.859375f, -0.71875f,0.859375f, -0.726563f,0.859375f, -0.734375f,0.859375f, -0.742188f,0.859375f, -0.75f,0.859375f, -0.757813f,0.859375f, -0.765625f,0.859375f, -0.773438f,0.859375f, -0.78125f,0.859375f, -0.789063f,0.859375f, -0.796875f,0.859375f, -0.804688f,0.859375f, -0.8125f,0.859375f, -0.820313f,0.859375f, -0.828125f,0.859375f, -0.835938f,0.859375f, -0.84375f,0.859375f, -0.851563f,0.859375f, -0.859375f,0.859375f, -0.867188f,0.859375f, -0.875f,0.859375f, -0.882813f,0.859375f, -0.890625f,0.859375f, -0.898438f,0.859375f, -0.90625f,0.859375f, -0.914063f,0.859375f, -0.921875f,0.859375f, -0.929688f,0.859375f, -0.9375f,0.859375f, -0.945313f,0.859375f, -0.953125f,0.859375f, -0.960938f,0.859375f, -0.96875f,0.859375f, -0.976563f,0.859375f, -0.984375f,0.859375f, -0.992188f,0.859375f, -1.0f,0.859375f, -0.507813f,0.867188f, -0.515625f,0.867188f, -0.523438f,0.867188f, -0.53125f,0.867188f, -0.539063f,0.867188f, -0.546875f,0.867188f, -0.554688f,0.867188f, -0.5625f,0.867188f, -0.570313f,0.867188f, -0.578125f,0.867188f, -0.585938f,0.867188f, -0.59375f,0.867188f, -0.601563f,0.867188f, -0.609375f,0.867188f, -0.617188f,0.867188f, -0.625f,0.867188f, -0.632813f,0.867188f, -0.640625f,0.867188f, -0.648438f,0.867188f, -0.65625f,0.867188f, -0.664063f,0.867188f, -0.671875f,0.867188f, -0.679688f,0.867188f, -0.6875f,0.867188f, -0.695313f,0.867188f, -0.703125f,0.867188f, -0.710938f,0.867188f, -0.71875f,0.867188f, -0.726563f,0.867188f, -0.734375f,0.867188f, -0.742188f,0.867188f, -0.75f,0.867188f, -0.757813f,0.867188f, -0.765625f,0.867188f, -0.773438f,0.867188f, -0.78125f,0.867188f, -0.789063f,0.867188f, -0.796875f,0.867188f, -0.804688f,0.867188f, -0.8125f,0.867188f, -0.820313f,0.867188f, -0.828125f,0.867188f, -0.835938f,0.867188f, -0.84375f,0.867188f, -0.851563f,0.867188f, -0.859375f,0.867188f, -0.867188f,0.867188f, -0.875f,0.867188f, -0.882813f,0.867188f, -0.890625f,0.867188f, -0.898438f,0.867188f, -0.90625f,0.867188f, -0.914063f,0.867188f, -0.921875f,0.867188f, -0.929688f,0.867188f, -0.9375f,0.867188f, -0.945313f,0.867188f, -0.953125f,0.867188f, -0.960938f,0.867188f, -0.96875f,0.867188f, -0.976563f,0.867188f, -0.984375f,0.867188f, -0.992188f,0.867188f, -1.0f,0.867188f, -0.507813f,0.875f, -0.515625f,0.875f, -0.523438f,0.875f, -0.53125f,0.875f, -0.539063f,0.875f, -0.546875f,0.875f, -0.554688f,0.875f, -0.5625f,0.875f, -0.570313f,0.875f, -0.578125f,0.875f, -0.585938f,0.875f, -0.59375f,0.875f, -0.601563f,0.875f, -0.609375f,0.875f, -0.617188f,0.875f, -0.625f,0.875f, -0.632813f,0.875f, -0.640625f,0.875f, -0.648438f,0.875f, -0.65625f,0.875f, -0.664063f,0.875f, -0.671875f,0.875f, -0.679688f,0.875f, -0.6875f,0.875f, -0.695313f,0.875f, -0.703125f,0.875f, -0.710938f,0.875f, -0.71875f,0.875f, -0.726563f,0.875f, -0.734375f,0.875f, -0.742188f,0.875f, -0.75f,0.875f, -0.757813f,0.875f, -0.765625f,0.875f, -0.773438f,0.875f, -0.78125f,0.875f, -0.789063f,0.875f, -0.796875f,0.875f, -0.804688f,0.875f, -0.8125f,0.875f, -0.820313f,0.875f, -0.828125f,0.875f, -0.835938f,0.875f, -0.84375f,0.875f, -0.851563f,0.875f, -0.859375f,0.875f, -0.867188f,0.875f, -0.875f,0.875f, -0.882813f,0.875f, -0.890625f,0.875f, -0.898438f,0.875f, -0.90625f,0.875f, -0.914063f,0.875f, -0.921875f,0.875f, -0.929688f,0.875f, -0.9375f,0.875f, -0.945313f,0.875f, -0.953125f,0.875f, -0.960938f,0.875f, -0.96875f,0.875f, -0.976563f,0.875f, -0.984375f,0.875f, -0.992188f,0.875f, -1.0f,0.875f, -0.507813f,0.882813f, -0.515625f,0.882813f, -0.523438f,0.882813f, -0.53125f,0.882813f, -0.539063f,0.882813f, -0.546875f,0.882813f, -0.554688f,0.882813f, -0.5625f,0.882813f, -0.570313f,0.882813f, -0.578125f,0.882813f, -0.585938f,0.882813f, -0.59375f,0.882813f, -0.601563f,0.882813f, -0.609375f,0.882813f, -0.617188f,0.882813f, -0.625f,0.882813f, -0.632813f,0.882813f, -0.640625f,0.882813f, -0.648438f,0.882813f, -0.65625f,0.882813f, -0.664063f,0.882813f, -0.671875f,0.882813f, -0.679688f,0.882813f, -0.6875f,0.882813f, -0.695313f,0.882813f, -0.703125f,0.882813f, -0.710938f,0.882813f, -0.71875f,0.882813f, -0.726563f,0.882813f, -0.734375f,0.882813f, -0.742188f,0.882813f, -0.75f,0.882813f, -0.757813f,0.882813f, -0.765625f,0.882813f, -0.773438f,0.882813f, -0.78125f,0.882813f, -0.789063f,0.882813f, -0.796875f,0.882813f, -0.804688f,0.882813f, -0.8125f,0.882813f, -0.820313f,0.882813f, -0.828125f,0.882813f, -0.835938f,0.882813f, -0.84375f,0.882813f, -0.851563f,0.882813f, -0.859375f,0.882813f, -0.867188f,0.882813f, -0.875f,0.882813f, -0.882813f,0.882813f, -0.890625f,0.882813f, -0.898438f,0.882813f, -0.90625f,0.882813f, -0.914063f,0.882813f, -0.921875f,0.882813f, -0.929688f,0.882813f, -0.9375f,0.882813f, -0.945313f,0.882813f, -0.953125f,0.882813f, -0.960938f,0.882813f, -0.96875f,0.882813f, -0.976563f,0.882813f, -0.984375f,0.882813f, -0.992188f,0.882813f, -1.0f,0.882813f, -0.507813f,0.890625f, -0.515625f,0.890625f, -0.523438f,0.890625f, -0.53125f,0.890625f, -0.539063f,0.890625f, -0.546875f,0.890625f, -0.554688f,0.890625f, -0.5625f,0.890625f, -0.570313f,0.890625f, -0.578125f,0.890625f, -0.585938f,0.890625f, -0.59375f,0.890625f, -0.601563f,0.890625f, -0.609375f,0.890625f, -0.617188f,0.890625f, -0.625f,0.890625f, -0.632813f,0.890625f, -0.640625f,0.890625f, -0.648438f,0.890625f, -0.65625f,0.890625f, -0.664063f,0.890625f, -0.671875f,0.890625f, -0.679688f,0.890625f, -0.6875f,0.890625f, -0.695313f,0.890625f, -0.703125f,0.890625f, -0.710938f,0.890625f, -0.71875f,0.890625f, -0.726563f,0.890625f, -0.734375f,0.890625f, -0.742188f,0.890625f, -0.75f,0.890625f, -0.757813f,0.890625f, -0.765625f,0.890625f, -0.773438f,0.890625f, -0.78125f,0.890625f, -0.789063f,0.890625f, -0.796875f,0.890625f, -0.804688f,0.890625f, -0.8125f,0.890625f, -0.820313f,0.890625f, -0.828125f,0.890625f, -0.835938f,0.890625f, -0.84375f,0.890625f, -0.851563f,0.890625f, -0.859375f,0.890625f, -0.867188f,0.890625f, -0.875f,0.890625f, -0.882813f,0.890625f, -0.890625f,0.890625f, -0.898438f,0.890625f, -0.90625f,0.890625f, -0.914063f,0.890625f, -0.921875f,0.890625f, -0.929688f,0.890625f, -0.9375f,0.890625f, -0.945313f,0.890625f, -0.953125f,0.890625f, -0.960938f,0.890625f, -0.96875f,0.890625f, -0.976563f,0.890625f, -0.984375f,0.890625f, -0.992188f,0.890625f, -1.0f,0.890625f, -0.507813f,0.898438f, -0.515625f,0.898438f, -0.523438f,0.898438f, -0.53125f,0.898438f, -0.539063f,0.898438f, -0.546875f,0.898438f, -0.554688f,0.898438f, -0.5625f,0.898438f, -0.570313f,0.898438f, -0.578125f,0.898438f, -0.585938f,0.898438f, -0.59375f,0.898438f, -0.601563f,0.898438f, -0.609375f,0.898438f, -0.617188f,0.898438f, -0.625f,0.898438f, -0.632813f,0.898438f, -0.640625f,0.898438f, -0.648438f,0.898438f, -0.65625f,0.898438f, -0.664063f,0.898438f, -0.671875f,0.898438f, -0.679688f,0.898438f, -0.6875f,0.898438f, -0.695313f,0.898438f, -0.703125f,0.898438f, -0.710938f,0.898438f, -0.71875f,0.898438f, -0.726563f,0.898438f, -0.734375f,0.898438f, -0.742188f,0.898438f, -0.75f,0.898438f, -0.757813f,0.898438f, -0.765625f,0.898438f, -0.773438f,0.898438f, -0.78125f,0.898438f, -0.789063f,0.898438f, -0.796875f,0.898438f, -0.804688f,0.898438f, -0.8125f,0.898438f, -0.820313f,0.898438f, -0.828125f,0.898438f, -0.835938f,0.898438f, -0.84375f,0.898438f, -0.851563f,0.898438f, -0.859375f,0.898438f, -0.867188f,0.898438f, -0.875f,0.898438f, -0.882813f,0.898438f, -0.890625f,0.898438f, -0.898438f,0.898438f, -0.90625f,0.898438f, -0.914063f,0.898438f, -0.921875f,0.898438f, -0.929688f,0.898438f, -0.9375f,0.898438f, -0.945313f,0.898438f, -0.953125f,0.898438f, -0.960938f,0.898438f, -0.96875f,0.898438f, -0.976563f,0.898438f, -0.984375f,0.898438f, -0.992188f,0.898438f, -1.0f,0.898438f, -0.507813f,0.90625f, -0.515625f,0.90625f, -0.523438f,0.90625f, -0.53125f,0.90625f, -0.539063f,0.90625f, -0.546875f,0.90625f, -0.554688f,0.90625f, -0.5625f,0.90625f, -0.570313f,0.90625f, -0.578125f,0.90625f, -0.585938f,0.90625f, -0.59375f,0.90625f, -0.601563f,0.90625f, -0.609375f,0.90625f, -0.617188f,0.90625f, -0.625f,0.90625f, -0.632813f,0.90625f, -0.640625f,0.90625f, -0.648438f,0.90625f, -0.65625f,0.90625f, -0.664063f,0.90625f, -0.671875f,0.90625f, -0.679688f,0.90625f, -0.6875f,0.90625f, -0.695313f,0.90625f, -0.703125f,0.90625f, -0.710938f,0.90625f, -0.71875f,0.90625f, -0.726563f,0.90625f, -0.734375f,0.90625f, -0.742188f,0.90625f, -0.75f,0.90625f, -0.757813f,0.90625f, -0.765625f,0.90625f, -0.773438f,0.90625f, -0.78125f,0.90625f, -0.789063f,0.90625f, -0.796875f,0.90625f, -0.804688f,0.90625f, -0.8125f,0.90625f, -0.820313f,0.90625f, -0.828125f,0.90625f, -0.835938f,0.90625f, -0.84375f,0.90625f, -0.851563f,0.90625f, -0.859375f,0.90625f, -0.867188f,0.90625f, -0.875f,0.90625f, -0.882813f,0.90625f, -0.890625f,0.90625f, -0.898438f,0.90625f, -0.90625f,0.90625f, -0.914063f,0.90625f, -0.921875f,0.90625f, -0.929688f,0.90625f, -0.9375f,0.90625f, -0.945313f,0.90625f, -0.953125f,0.90625f, -0.960938f,0.90625f, -0.96875f,0.90625f, -0.976563f,0.90625f, -0.984375f,0.90625f, -0.992188f,0.90625f, -1.0f,0.90625f, -0.507813f,0.914063f, -0.515625f,0.914063f, -0.523438f,0.914063f, -0.53125f,0.914063f, -0.539063f,0.914063f, -0.546875f,0.914063f, -0.554688f,0.914063f, -0.5625f,0.914063f, -0.570313f,0.914063f, -0.578125f,0.914063f, -0.585938f,0.914063f, -0.59375f,0.914063f, -0.601563f,0.914063f, -0.609375f,0.914063f, -0.617188f,0.914063f, -0.625f,0.914063f, -0.632813f,0.914063f, -0.640625f,0.914063f, -0.648438f,0.914063f, -0.65625f,0.914063f, -0.664063f,0.914063f, -0.671875f,0.914063f, -0.679688f,0.914063f, -0.6875f,0.914063f, -0.695313f,0.914063f, -0.703125f,0.914063f, -0.710938f,0.914063f, -0.71875f,0.914063f, -0.726563f,0.914063f, -0.734375f,0.914063f, -0.742188f,0.914063f, -0.75f,0.914063f, -0.757813f,0.914063f, -0.765625f,0.914063f, -0.773438f,0.914063f, -0.78125f,0.914063f, -0.789063f,0.914063f, -0.796875f,0.914063f, -0.804688f,0.914063f, -0.8125f,0.914063f, -0.820313f,0.914063f, -0.828125f,0.914063f, -0.835938f,0.914063f, -0.84375f,0.914063f, -0.851563f,0.914063f, -0.859375f,0.914063f, -0.867188f,0.914063f, -0.875f,0.914063f, -0.882813f,0.914063f, -0.890625f,0.914063f, -0.898438f,0.914063f, -0.90625f,0.914063f, -0.914063f,0.914063f, -0.921875f,0.914063f, -0.929688f,0.914063f, -0.9375f,0.914063f, -0.945313f,0.914063f, -0.953125f,0.914063f, -0.960938f,0.914063f, -0.96875f,0.914063f, -0.976563f,0.914063f, -0.984375f,0.914063f, -0.992188f,0.914063f, -1.0f,0.914063f, -0.507813f,0.921875f, -0.515625f,0.921875f, -0.523438f,0.921875f, -0.53125f,0.921875f, -0.539063f,0.921875f, -0.546875f,0.921875f, -0.554688f,0.921875f, -0.5625f,0.921875f, -0.570313f,0.921875f, -0.578125f,0.921875f, -0.585938f,0.921875f, -0.59375f,0.921875f, -0.601563f,0.921875f, -0.609375f,0.921875f, -0.617188f,0.921875f, -0.625f,0.921875f, -0.632813f,0.921875f, -0.640625f,0.921875f, -0.648438f,0.921875f, -0.65625f,0.921875f, -0.664063f,0.921875f, -0.671875f,0.921875f, -0.679688f,0.921875f, -0.6875f,0.921875f, -0.695313f,0.921875f, -0.703125f,0.921875f, -0.710938f,0.921875f, -0.71875f,0.921875f, -0.726563f,0.921875f, -0.734375f,0.921875f, -0.742188f,0.921875f, -0.75f,0.921875f, -0.757813f,0.921875f, -0.765625f,0.921875f, -0.773438f,0.921875f, -0.78125f,0.921875f, -0.789063f,0.921875f, -0.796875f,0.921875f, -0.804688f,0.921875f, -0.8125f,0.921875f, -0.820313f,0.921875f, -0.828125f,0.921875f, -0.835938f,0.921875f, -0.84375f,0.921875f, -0.851563f,0.921875f, -0.859375f,0.921875f, -0.867188f,0.921875f, -0.875f,0.921875f, -0.882813f,0.921875f, -0.890625f,0.921875f, -0.898438f,0.921875f, -0.90625f,0.921875f, -0.914063f,0.921875f, -0.921875f,0.921875f, -0.929688f,0.921875f, -0.9375f,0.921875f, -0.945313f,0.921875f, -0.953125f,0.921875f, -0.960938f,0.921875f, -0.96875f,0.921875f, -0.976563f,0.921875f, -0.984375f,0.921875f, -0.992188f,0.921875f, -1.0f,0.921875f, -0.507813f,0.929688f, -0.515625f,0.929688f, -0.523438f,0.929688f, -0.53125f,0.929688f, -0.539063f,0.929688f, -0.546875f,0.929688f, -0.554688f,0.929688f, -0.5625f,0.929688f, -0.570313f,0.929688f, -0.578125f,0.929688f, -0.585938f,0.929688f, -0.59375f,0.929688f, -0.601563f,0.929688f, -0.609375f,0.929688f, -0.617188f,0.929688f, -0.625f,0.929688f, -0.632813f,0.929688f, -0.640625f,0.929688f, -0.648438f,0.929688f, -0.65625f,0.929688f, -0.664063f,0.929688f, -0.671875f,0.929688f, -0.679688f,0.929688f, -0.6875f,0.929688f, -0.695313f,0.929688f, -0.703125f,0.929688f, -0.710938f,0.929688f, -0.71875f,0.929688f, -0.726563f,0.929688f, -0.734375f,0.929688f, -0.742188f,0.929688f, -0.75f,0.929688f, -0.757813f,0.929688f, -0.765625f,0.929688f, -0.773438f,0.929688f, -0.78125f,0.929688f, -0.789063f,0.929688f, -0.796875f,0.929688f, -0.804688f,0.929688f, -0.8125f,0.929688f, -0.820313f,0.929688f, -0.828125f,0.929688f, -0.835938f,0.929688f, -0.84375f,0.929688f, -0.851563f,0.929688f, -0.859375f,0.929688f, -0.867188f,0.929688f, -0.875f,0.929688f, -0.882813f,0.929688f, -0.890625f,0.929688f, -0.898438f,0.929688f, -0.90625f,0.929688f, -0.914063f,0.929688f, -0.921875f,0.929688f, -0.929688f,0.929688f, -0.9375f,0.929688f, -0.945313f,0.929688f, -0.953125f,0.929688f, -0.960938f,0.929688f, -0.96875f,0.929688f, -0.976563f,0.929688f, -0.984375f,0.929688f, -0.992188f,0.929688f, -1.0f,0.929688f, -0.507813f,0.9375f, -0.515625f,0.9375f, -0.523438f,0.9375f, -0.53125f,0.9375f, -0.539063f,0.9375f, -0.546875f,0.9375f, -0.554688f,0.9375f, -0.5625f,0.9375f, -0.570313f,0.9375f, -0.578125f,0.9375f, -0.585938f,0.9375f, -0.59375f,0.9375f, -0.601563f,0.9375f, -0.609375f,0.9375f, -0.617188f,0.9375f, -0.625f,0.9375f, -0.632813f,0.9375f, -0.640625f,0.9375f, -0.648438f,0.9375f, -0.65625f,0.9375f, -0.664063f,0.9375f, -0.671875f,0.9375f, -0.679688f,0.9375f, -0.6875f,0.9375f, -0.695313f,0.9375f, -0.703125f,0.9375f, -0.710938f,0.9375f, -0.71875f,0.9375f, -0.726563f,0.9375f, -0.734375f,0.9375f, -0.742188f,0.9375f, -0.75f,0.9375f, -0.757813f,0.9375f, -0.765625f,0.9375f, -0.773438f,0.9375f, -0.78125f,0.9375f, -0.789063f,0.9375f, -0.796875f,0.9375f, -0.804688f,0.9375f, -0.8125f,0.9375f, -0.820313f,0.9375f, -0.828125f,0.9375f, -0.835938f,0.9375f, -0.84375f,0.9375f, -0.851563f,0.9375f, -0.859375f,0.9375f, -0.867188f,0.9375f, -0.875f,0.9375f, -0.882813f,0.9375f, -0.890625f,0.9375f, -0.898438f,0.9375f, -0.90625f,0.9375f, -0.914063f,0.9375f, -0.921875f,0.9375f, -0.929688f,0.9375f, -0.9375f,0.9375f, -0.945313f,0.9375f, -0.953125f,0.9375f, -0.960938f,0.9375f, -0.96875f,0.9375f, -0.976563f,0.9375f, -0.984375f,0.9375f, -0.992188f,0.9375f, -1.0f,0.9375f, -0.507813f,0.945313f, -0.515625f,0.945313f, -0.523438f,0.945313f, -0.53125f,0.945313f, -0.539063f,0.945313f, -0.546875f,0.945313f, -0.554688f,0.945313f, -0.5625f,0.945313f, -0.570313f,0.945313f, -0.578125f,0.945313f, -0.585938f,0.945313f, -0.59375f,0.945313f, -0.601563f,0.945313f, -0.609375f,0.945313f, -0.617188f,0.945313f, -0.625f,0.945313f, -0.632813f,0.945313f, -0.640625f,0.945313f, -0.648438f,0.945313f, -0.65625f,0.945313f, -0.664063f,0.945313f, -0.671875f,0.945313f, -0.679688f,0.945313f, -0.6875f,0.945313f, -0.695313f,0.945313f, -0.703125f,0.945313f, -0.710938f,0.945313f, -0.71875f,0.945313f, -0.726563f,0.945313f, -0.734375f,0.945313f, -0.742188f,0.945313f, -0.75f,0.945313f, -0.757813f,0.945313f, -0.765625f,0.945313f, -0.773438f,0.945313f, -0.78125f,0.945313f, -0.789063f,0.945313f, -0.796875f,0.945313f, -0.804688f,0.945313f, -0.8125f,0.945313f, -0.820313f,0.945313f, -0.828125f,0.945313f, -0.835938f,0.945313f, -0.84375f,0.945313f, -0.851563f,0.945313f, -0.859375f,0.945313f, -0.867188f,0.945313f, -0.875f,0.945313f, -0.882813f,0.945313f, -0.890625f,0.945313f, -0.898438f,0.945313f, -0.90625f,0.945313f, -0.914063f,0.945313f, -0.921875f,0.945313f, -0.929688f,0.945313f, -0.9375f,0.945313f, -0.945313f,0.945313f, -0.953125f,0.945313f, -0.960938f,0.945313f, -0.96875f,0.945313f, -0.976563f,0.945313f, -0.984375f,0.945313f, -0.992188f,0.945313f, -1.0f,0.945313f, -0.507813f,0.953125f, -0.515625f,0.953125f, -0.523438f,0.953125f, -0.53125f,0.953125f, -0.539063f,0.953125f, -0.546875f,0.953125f, -0.554688f,0.953125f, -0.5625f,0.953125f, -0.570313f,0.953125f, -0.578125f,0.953125f, -0.585938f,0.953125f, -0.59375f,0.953125f, -0.601563f,0.953125f, -0.609375f,0.953125f, -0.617188f,0.953125f, -0.625f,0.953125f, -0.632813f,0.953125f, -0.640625f,0.953125f, -0.648438f,0.953125f, -0.65625f,0.953125f, -0.664063f,0.953125f, -0.671875f,0.953125f, -0.679688f,0.953125f, -0.6875f,0.953125f, -0.695313f,0.953125f, -0.703125f,0.953125f, -0.710938f,0.953125f, -0.71875f,0.953125f, -0.726563f,0.953125f, -0.734375f,0.953125f, -0.742188f,0.953125f, -0.75f,0.953125f, -0.757813f,0.953125f, -0.765625f,0.953125f, -0.773438f,0.953125f, -0.78125f,0.953125f, -0.789063f,0.953125f, -0.796875f,0.953125f, -0.804688f,0.953125f, -0.8125f,0.953125f, -0.820313f,0.953125f, -0.828125f,0.953125f, -0.835938f,0.953125f, -0.84375f,0.953125f, -0.851563f,0.953125f, -0.859375f,0.953125f, -0.867188f,0.953125f, -0.875f,0.953125f, -0.882813f,0.953125f, -0.890625f,0.953125f, -0.898438f,0.953125f, -0.90625f,0.953125f, -0.914063f,0.953125f, -0.921875f,0.953125f, -0.929688f,0.953125f, -0.9375f,0.953125f, -0.945313f,0.953125f, -0.953125f,0.953125f, -0.960938f,0.953125f, -0.96875f,0.953125f, -0.976563f,0.953125f, -0.984375f,0.953125f, -0.992188f,0.953125f, -1.0f,0.953125f, -0.507813f,0.960938f, -0.515625f,0.960938f, -0.523438f,0.960938f, -0.53125f,0.960938f, -0.539063f,0.960938f, -0.546875f,0.960938f, -0.554688f,0.960938f, -0.5625f,0.960938f, -0.570313f,0.960938f, -0.578125f,0.960938f, -0.585938f,0.960938f, -0.59375f,0.960938f, -0.601563f,0.960938f, -0.609375f,0.960938f, -0.617188f,0.960938f, -0.625f,0.960938f, -0.632813f,0.960938f, -0.640625f,0.960938f, -0.648438f,0.960938f, -0.65625f,0.960938f, -0.664063f,0.960938f, -0.671875f,0.960938f, -0.679688f,0.960938f, -0.6875f,0.960938f, -0.695313f,0.960938f, -0.703125f,0.960938f, -0.710938f,0.960938f, -0.71875f,0.960938f, -0.726563f,0.960938f, -0.734375f,0.960938f, -0.742188f,0.960938f, -0.75f,0.960938f, -0.757813f,0.960938f, -0.765625f,0.960938f, -0.773438f,0.960938f, -0.78125f,0.960938f, -0.789063f,0.960938f, -0.796875f,0.960938f, -0.804688f,0.960938f, -0.8125f,0.960938f, -0.820313f,0.960938f, -0.828125f,0.960938f, -0.835938f,0.960938f, -0.84375f,0.960938f, -0.851563f,0.960938f, -0.859375f,0.960938f, -0.867188f,0.960938f, -0.875f,0.960938f, -0.882813f,0.960938f, -0.890625f,0.960938f, -0.898438f,0.960938f, -0.90625f,0.960938f, -0.914063f,0.960938f, -0.921875f,0.960938f, -0.929688f,0.960938f, -0.9375f,0.960938f, -0.945313f,0.960938f, -0.953125f,0.960938f, -0.960938f,0.960938f, -0.96875f,0.960938f, -0.976563f,0.960938f, -0.984375f,0.960938f, -0.992188f,0.960938f, -1.0f,0.960938f, -0.507813f,0.96875f, -0.515625f,0.96875f, -0.523438f,0.96875f, -0.53125f,0.96875f, -0.539063f,0.96875f, -0.546875f,0.96875f, -0.554688f,0.96875f, -0.5625f,0.96875f, -0.570313f,0.96875f, -0.578125f,0.96875f, -0.585938f,0.96875f, -0.59375f,0.96875f, -0.601563f,0.96875f, -0.609375f,0.96875f, -0.617188f,0.96875f, -0.625f,0.96875f, -0.632813f,0.96875f, -0.640625f,0.96875f, -0.648438f,0.96875f, -0.65625f,0.96875f, -0.664063f,0.96875f, -0.671875f,0.96875f, -0.679688f,0.96875f, -0.6875f,0.96875f, -0.695313f,0.96875f, -0.703125f,0.96875f, -0.710938f,0.96875f, -0.71875f,0.96875f, -0.726563f,0.96875f, -0.734375f,0.96875f, -0.742188f,0.96875f, -0.75f,0.96875f, -0.757813f,0.96875f, -0.765625f,0.96875f, -0.773438f,0.96875f, -0.78125f,0.96875f, -0.789063f,0.96875f, -0.796875f,0.96875f, -0.804688f,0.96875f, -0.8125f,0.96875f, -0.820313f,0.96875f, -0.828125f,0.96875f, -0.835938f,0.96875f, -0.84375f,0.96875f, -0.851563f,0.96875f, -0.859375f,0.96875f, -0.867188f,0.96875f, -0.875f,0.96875f, -0.882813f,0.96875f, -0.890625f,0.96875f, -0.898438f,0.96875f, -0.90625f,0.96875f, -0.914063f,0.96875f, -0.921875f,0.96875f, -0.929688f,0.96875f, -0.9375f,0.96875f, -0.945313f,0.96875f, -0.953125f,0.96875f, -0.960938f,0.96875f, -0.96875f,0.96875f, -0.976563f,0.96875f, -0.984375f,0.96875f, -0.992188f,0.96875f, -1.0f,0.96875f, -0.507813f,0.976563f, -0.515625f,0.976563f, -0.523438f,0.976563f, -0.53125f,0.976563f, -0.539063f,0.976563f, -0.546875f,0.976563f, -0.554688f,0.976563f, -0.5625f,0.976563f, -0.570313f,0.976563f, -0.578125f,0.976563f, -0.585938f,0.976563f, -0.59375f,0.976563f, -0.601563f,0.976563f, -0.609375f,0.976563f, -0.617188f,0.976563f, -0.625f,0.976563f, -0.632813f,0.976563f, -0.640625f,0.976563f, -0.648438f,0.976563f, -0.65625f,0.976563f, -0.664063f,0.976563f, -0.671875f,0.976563f, -0.679688f,0.976563f, -0.6875f,0.976563f, -0.695313f,0.976563f, -0.703125f,0.976563f, -0.710938f,0.976563f, -0.71875f,0.976563f, -0.726563f,0.976563f, -0.734375f,0.976563f, -0.742188f,0.976563f, -0.75f,0.976563f, -0.757813f,0.976563f, -0.765625f,0.976563f, -0.773438f,0.976563f, -0.78125f,0.976563f, -0.789063f,0.976563f, -0.796875f,0.976563f, -0.804688f,0.976563f, -0.8125f,0.976563f, -0.820313f,0.976563f, -0.828125f,0.976563f, -0.835938f,0.976563f, -0.84375f,0.976563f, -0.851563f,0.976563f, -0.859375f,0.976563f, -0.867188f,0.976563f, -0.875f,0.976563f, -0.882813f,0.976563f, -0.890625f,0.976563f, -0.898438f,0.976563f, -0.90625f,0.976563f, -0.914063f,0.976563f, -0.921875f,0.976563f, -0.929688f,0.976563f, -0.9375f,0.976563f, -0.945313f,0.976563f, -0.953125f,0.976563f, -0.960938f,0.976563f, -0.96875f,0.976563f, -0.976563f,0.976563f, -0.984375f,0.976563f, -0.992188f,0.976563f, -1.0f,0.976563f, -0.507813f,0.984375f, -0.515625f,0.984375f, -0.523438f,0.984375f, -0.53125f,0.984375f, -0.539063f,0.984375f, -0.546875f,0.984375f, -0.554688f,0.984375f, -0.5625f,0.984375f, -0.570313f,0.984375f, -0.578125f,0.984375f, -0.585938f,0.984375f, -0.59375f,0.984375f, -0.601563f,0.984375f, -0.609375f,0.984375f, -0.617188f,0.984375f, -0.625f,0.984375f, -0.632813f,0.984375f, -0.640625f,0.984375f, -0.648438f,0.984375f, -0.65625f,0.984375f, -0.664063f,0.984375f, -0.671875f,0.984375f, -0.679688f,0.984375f, -0.6875f,0.984375f, -0.695313f,0.984375f, -0.703125f,0.984375f, -0.710938f,0.984375f, -0.71875f,0.984375f, -0.726563f,0.984375f, -0.734375f,0.984375f, -0.742188f,0.984375f, -0.75f,0.984375f, -0.757813f,0.984375f, -0.765625f,0.984375f, -0.773438f,0.984375f, -0.78125f,0.984375f, -0.789063f,0.984375f, -0.796875f,0.984375f, -0.804688f,0.984375f, -0.8125f,0.984375f, -0.820313f,0.984375f, -0.828125f,0.984375f, -0.835938f,0.984375f, -0.84375f,0.984375f, -0.851563f,0.984375f, -0.859375f,0.984375f, -0.867188f,0.984375f, -0.875f,0.984375f, -0.882813f,0.984375f, -0.890625f,0.984375f, -0.898438f,0.984375f, -0.90625f,0.984375f, -0.914063f,0.984375f, -0.921875f,0.984375f, -0.929688f,0.984375f, -0.9375f,0.984375f, -0.945313f,0.984375f, -0.953125f,0.984375f, -0.960938f,0.984375f, -0.96875f,0.984375f, -0.976563f,0.984375f, -0.984375f,0.984375f, -0.992188f,0.984375f, -1.0f,0.984375f, -0.507813f,0.992188f, -0.515625f,0.992188f, -0.523438f,0.992188f, -0.53125f,0.992188f, -0.539063f,0.992188f, -0.546875f,0.992188f, -0.554688f,0.992188f, -0.5625f,0.992188f, -0.570313f,0.992188f, -0.578125f,0.992188f, -0.585938f,0.992188f, -0.59375f,0.992188f, -0.601563f,0.992188f, -0.609375f,0.992188f, -0.617188f,0.992188f, -0.625f,0.992188f, -0.632813f,0.992188f, -0.640625f,0.992188f, -0.648438f,0.992188f, -0.65625f,0.992188f, -0.664063f,0.992188f, -0.671875f,0.992188f, -0.679688f,0.992188f, -0.6875f,0.992188f, -0.695313f,0.992188f, -0.703125f,0.992188f, -0.710938f,0.992188f, -0.71875f,0.992188f, -0.726563f,0.992188f, -0.734375f,0.992188f, -0.742188f,0.992188f, -0.75f,0.992188f, -0.757813f,0.992188f, -0.765625f,0.992188f, -0.773438f,0.992188f, -0.78125f,0.992188f, -0.789063f,0.992188f, -0.796875f,0.992188f, -0.804688f,0.992188f, -0.8125f,0.992188f, -0.820313f,0.992188f, -0.828125f,0.992188f, -0.835938f,0.992188f, -0.84375f,0.992188f, -0.851563f,0.992188f, -0.859375f,0.992188f, -0.867188f,0.992188f, -0.875f,0.992188f, -0.882813f,0.992188f, -0.890625f,0.992188f, -0.898438f,0.992188f, -0.90625f,0.992188f, -0.914063f,0.992188f, -0.921875f,0.992188f, -0.929688f,0.992188f, -0.9375f,0.992188f, -0.945313f,0.992188f, -0.953125f,0.992188f, -0.960938f,0.992188f, -0.96875f,0.992188f, -0.976563f,0.992188f, -0.984375f,0.992188f, -0.992188f,0.992188f, -1.0f,0.992188f, -0.507813f,1.0f, -0.515625f,1.0f, -0.523438f,1.0f, -0.53125f,1.0f, -0.539063f,1.0f, -0.546875f,1.0f, -0.554688f,1.0f, -0.5625f,1.0f, -0.570313f,1.0f, -0.578125f,1.0f, -0.585938f,1.0f, -0.59375f,1.0f, -0.601563f,1.0f, -0.609375f,1.0f, -0.617188f,1.0f, -0.625f,1.0f, -0.632813f,1.0f, -0.640625f,1.0f, -0.648438f,1.0f, -0.65625f,1.0f, -0.664063f,1.0f, -0.671875f,1.0f, -0.679688f,1.0f, -0.6875f,1.0f, -0.695313f,1.0f, -0.703125f,1.0f, -0.710938f,1.0f, -0.71875f,1.0f, -0.726563f,1.0f, -0.734375f,1.0f, -0.742188f,1.0f, -0.75f,1.0f, -0.757813f,1.0f, -0.765625f,1.0f, -0.773438f,1.0f, -0.78125f,1.0f, -0.789063f,1.0f, -0.796875f,1.0f, -0.804688f,1.0f, -0.8125f,1.0f, -0.820313f,1.0f, -0.828125f,1.0f, -0.835938f,1.0f, -0.84375f,1.0f, -0.851563f,1.0f, -0.859375f,1.0f, -0.867188f,1.0f, -0.875f,1.0f, -0.882813f,1.0f, -0.890625f,1.0f, -0.898438f,1.0f, -0.90625f,1.0f, -0.914063f,1.0f, -0.921875f,1.0f, -0.929688f,1.0f, -0.9375f,1.0f, -0.945313f,1.0f, -0.953125f,1.0f, -0.960938f,1.0f, -0.96875f,1.0f, -0.976563f,1.0f, -0.984375f,1.0f, -0.992188f,1.0f, -1.0f,1.0f, -}; - -unsigned short Landscape07Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -128,0,129, -2,129,0, -129,2,130, -4,130,2, -130,4,131, -6,131,4, -131,6,132, -8,132,6, -132,8,133, -10,133,8, -133,10,134, -12,134,10, -134,12,135, -14,135,12, -135,14,136, -16,136,14, -136,16,137, -18,137,16, -137,18,138, -20,138,18, -138,20,139, -22,139,20, -139,22,140, -24,140,22, -140,24,141, -26,141,24, -141,26,142, -28,142,26, -142,28,143, -30,143,28, -143,30,144, -32,144,30, -144,32,145, -34,145,32, -145,34,146, -36,146,34, -146,36,147, -38,147,36, -147,38,148, -40,148,38, -148,40,149, -42,149,40, -149,42,150, -44,150,42, -150,44,151, -46,151,44, -151,46,152, -48,152,46, -152,48,153, -50,153,48, -153,50,154, -52,154,50, -154,52,155, -54,155,52, -155,54,156, -56,156,54, -156,56,157, -58,157,56, -157,58,158, -60,158,58, -158,60,159, -62,159,60, -159,62,160, -64,160,62, -160,64,161, -66,161,64, -161,66,162, -68,162,66, -162,68,163, -70,163,68, -163,70,164, -72,164,70, -164,72,165, -74,165,72, -165,74,166, -76,166,74, -166,76,167, -78,167,76, -167,78,168, -80,168,78, -168,80,169, -82,169,80, -169,82,170, -84,170,82, -170,84,171, -86,171,84, -171,86,172, -88,172,86, -172,88,173, -90,173,88, -173,90,174, -92,174,90, -174,92,175, -94,175,92, -175,94,176, -96,176,94, -176,96,177, -98,177,96, -177,98,178, -100,178,98, -178,100,179, -102,179,100, -179,102,180, -104,180,102, -180,104,181, -106,181,104, -181,106,182, -108,182,106, -182,108,183, -110,183,108, -183,110,184, -112,184,110, -184,112,185, -114,185,112, -185,114,186, -116,186,114, -186,116,187, -118,187,116, -187,118,188, -120,188,118, -188,120,189, -122,189,120, -189,122,190, -124,190,122, -190,124,191, -126,191,124, -192,128,193, -129,193,128, -193,129,194, -130,194,129, -194,130,195, -131,195,130, -195,131,196, -132,196,131, -196,132,197, -133,197,132, -197,133,198, -134,198,133, -198,134,199, -135,199,134, -199,135,200, -136,200,135, -200,136,201, -137,201,136, -201,137,202, -138,202,137, -202,138,203, -139,203,138, -203,139,204, -140,204,139, -204,140,205, -141,205,140, -205,141,206, -142,206,141, -206,142,207, -143,207,142, -207,143,208, -144,208,143, -208,144,209, -145,209,144, -209,145,210, -146,210,145, -210,146,211, -147,211,146, -211,147,212, -148,212,147, -212,148,213, -149,213,148, -213,149,214, -150,214,149, -214,150,215, -151,215,150, -215,151,216, -152,216,151, -216,152,217, -153,217,152, -217,153,218, -154,218,153, -218,154,219, -155,219,154, -219,155,220, -156,220,155, -220,156,221, -157,221,156, -221,157,222, -158,222,157, -222,158,223, -159,223,158, -223,159,224, -160,224,159, -224,160,225, -161,225,160, -225,161,226, -162,226,161, -226,162,227, -163,227,162, -227,163,228, -164,228,163, -228,164,229, -165,229,164, -229,165,230, -166,230,165, -230,166,231, -167,231,166, -231,167,232, -168,232,167, -232,168,233, -169,233,168, -233,169,234, -170,234,169, -234,170,235, -171,235,170, -235,171,236, -172,236,171, -236,172,237, -173,237,172, -237,173,238, -174,238,173, -238,174,239, -175,239,174, -239,175,240, -176,240,175, -240,176,241, -177,241,176, -241,177,242, -178,242,177, -242,178,243, -179,243,178, -243,179,244, -180,244,179, -244,180,245, -181,245,180, -245,181,246, -182,246,181, -246,182,247, -183,247,182, -247,183,248, -184,248,183, -248,184,249, -185,249,184, -249,185,250, -186,250,185, -250,186,251, -187,251,186, -251,187,252, -188,252,187, -252,188,253, -189,253,188, -253,189,254, -190,254,189, -254,190,255, -191,255,190, -256,192,257, -193,257,192, -257,193,258, -194,258,193, -258,194,259, -195,259,194, -259,195,260, -196,260,195, -260,196,261, -197,261,196, -261,197,262, -198,262,197, -262,198,263, -199,263,198, -263,199,264, -200,264,199, -264,200,265, -201,265,200, -265,201,266, -202,266,201, -266,202,267, -203,267,202, -267,203,268, -204,268,203, -268,204,269, -205,269,204, -269,205,270, -206,270,205, -270,206,271, -207,271,206, -271,207,272, -208,272,207, -272,208,273, -209,273,208, -273,209,274, -210,274,209, -274,210,275, -211,275,210, -275,211,276, -212,276,211, -276,212,277, -213,277,212, -277,213,278, -214,278,213, -278,214,279, -215,279,214, -279,215,280, -216,280,215, -280,216,281, -217,281,216, -281,217,282, -218,282,217, -282,218,283, -219,283,218, -283,219,284, -220,284,219, -284,220,285, -221,285,220, -285,221,286, -222,286,221, -286,222,287, -223,287,222, -287,223,288, -224,288,223, -288,224,289, -225,289,224, -289,225,290, -226,290,225, -290,226,291, -227,291,226, -291,227,292, -228,292,227, -292,228,293, -229,293,228, -293,229,294, -230,294,229, -294,230,295, -231,295,230, -295,231,296, -232,296,231, -296,232,297, -233,297,232, -297,233,298, -234,298,233, -298,234,299, -235,299,234, -299,235,300, -236,300,235, -300,236,301, -237,301,236, -301,237,302, -238,302,237, -302,238,303, -239,303,238, -303,239,304, -240,304,239, -304,240,305, -241,305,240, -305,241,306, -242,306,241, -306,242,307, -243,307,242, -307,243,308, -244,308,243, -308,244,309, -245,309,244, -309,245,310, -246,310,245, -310,246,311, -247,311,246, -311,247,312, -248,312,247, -312,248,313, -249,313,248, -313,249,314, -250,314,249, -314,250,315, -251,315,250, -315,251,316, -252,316,251, -316,252,317, -253,317,252, -317,253,318, -254,318,253, -318,254,319, -255,319,254, -320,256,321, -257,321,256, -321,257,322, -258,322,257, -322,258,323, -259,323,258, -323,259,324, -260,324,259, -324,260,325, -261,325,260, -325,261,326, -262,326,261, -326,262,327, -263,327,262, -327,263,328, -264,328,263, -328,264,329, -265,329,264, -329,265,330, -266,330,265, -330,266,331, -267,331,266, -331,267,332, -268,332,267, -332,268,333, -269,333,268, -333,269,334, -270,334,269, -334,270,335, -271,335,270, -335,271,336, -272,336,271, -336,272,337, -273,337,272, -337,273,338, -274,338,273, -338,274,339, -275,339,274, -339,275,340, -276,340,275, -340,276,341, -277,341,276, -341,277,342, -278,342,277, -342,278,343, -279,343,278, -343,279,344, -280,344,279, -344,280,345, -281,345,280, -345,281,346, -282,346,281, -346,282,347, -283,347,282, -347,283,348, -284,348,283, -348,284,349, -285,349,284, -349,285,350, -286,350,285, -350,286,351, -287,351,286, -351,287,352, -288,352,287, -352,288,353, -289,353,288, -353,289,354, -290,354,289, -354,290,355, -291,355,290, -355,291,356, -292,356,291, -356,292,357, -293,357,292, -357,293,358, -294,358,293, -358,294,359, -295,359,294, -359,295,360, -296,360,295, -360,296,361, -297,361,296, -361,297,362, -298,362,297, -362,298,363, -299,363,298, -363,299,364, -300,364,299, -364,300,365, -301,365,300, -365,301,366, -302,366,301, -366,302,367, -303,367,302, -367,303,368, -304,368,303, -368,304,369, -305,369,304, -369,305,370, -306,370,305, -370,306,371, -307,371,306, -371,307,372, -308,372,307, -372,308,373, -309,373,308, -373,309,374, -310,374,309, -374,310,375, -311,375,310, -375,311,376, -312,376,311, -376,312,377, -313,377,312, -377,313,378, -314,378,313, -378,314,379, -315,379,314, -379,315,380, -316,380,315, -380,316,381, -317,381,316, -381,317,382, -318,382,317, -382,318,383, -319,383,318, -384,320,385, -321,385,320, -385,321,386, -322,386,321, -386,322,387, -323,387,322, -387,323,388, -324,388,323, -388,324,389, -325,389,324, -389,325,390, -326,390,325, -390,326,391, -327,391,326, -391,327,392, -328,392,327, -392,328,393, -329,393,328, -393,329,394, -330,394,329, -394,330,395, -331,395,330, -395,331,396, -332,396,331, -396,332,397, -333,397,332, -397,333,398, -334,398,333, -398,334,399, -335,399,334, -399,335,400, -336,400,335, -400,336,401, -337,401,336, -401,337,402, -338,402,337, -402,338,403, -339,403,338, -403,339,404, -340,404,339, -404,340,405, -341,405,340, -405,341,406, -342,406,341, -406,342,407, -343,407,342, -407,343,408, -344,408,343, -408,344,409, -345,409,344, -409,345,410, -346,410,345, -410,346,411, -347,411,346, -411,347,412, -348,412,347, -412,348,413, -349,413,348, -413,349,414, -350,414,349, -414,350,415, -351,415,350, -415,351,416, -352,416,351, -416,352,417, -353,417,352, -417,353,418, -354,418,353, -418,354,419, -355,419,354, -419,355,420, -356,420,355, -420,356,421, -357,421,356, -421,357,422, -358,422,357, -422,358,423, -359,423,358, -423,359,424, -360,424,359, -424,360,425, -361,425,360, -425,361,426, -362,426,361, -426,362,427, -363,427,362, -427,363,428, -364,428,363, -428,364,429, -365,429,364, -429,365,430, -366,430,365, -430,366,431, -367,431,366, -431,367,432, -368,432,367, -432,368,433, -369,433,368, -433,369,434, -370,434,369, -434,370,435, -371,435,370, -435,371,436, -372,436,371, -436,372,437, -373,437,372, -437,373,438, -374,438,373, -438,374,439, -375,439,374, -439,375,440, -376,440,375, -440,376,441, -377,441,376, -441,377,442, -378,442,377, -442,378,443, -379,443,378, -443,379,444, -380,444,379, -444,380,445, -381,445,380, -445,381,446, -382,446,381, -446,382,447, -383,447,382, -448,384,449, -385,449,384, -449,385,450, -386,450,385, -450,386,451, -387,451,386, -451,387,452, -388,452,387, -452,388,453, -389,453,388, -453,389,454, -390,454,389, -454,390,455, -391,455,390, -455,391,456, -392,456,391, -456,392,457, -393,457,392, -457,393,458, -394,458,393, -458,394,459, -395,459,394, -459,395,460, -396,460,395, -460,396,461, -397,461,396, -461,397,462, -398,462,397, -462,398,463, -399,463,398, -463,399,464, -400,464,399, -464,400,465, -401,465,400, -465,401,466, -402,466,401, -466,402,467, -403,467,402, -467,403,468, -404,468,403, -468,404,469, -405,469,404, -469,405,470, -406,470,405, -470,406,471, -407,471,406, -471,407,472, -408,472,407, -472,408,473, -409,473,408, -473,409,474, -410,474,409, -474,410,475, -411,475,410, -475,411,476, -412,476,411, -476,412,477, -413,477,412, -477,413,478, -414,478,413, -478,414,479, -415,479,414, -479,415,480, -416,480,415, -480,416,481, -417,481,416, -481,417,482, -418,482,417, -482,418,483, -419,483,418, -483,419,484, -420,484,419, -484,420,485, -421,485,420, -485,421,486, -422,486,421, -486,422,487, -423,487,422, -487,423,488, -424,488,423, -488,424,489, -425,489,424, -489,425,490, -426,490,425, -490,426,491, -427,491,426, -491,427,492, -428,492,427, -492,428,493, -429,493,428, -493,429,494, -430,494,429, -494,430,495, -431,495,430, -495,431,496, -432,496,431, -496,432,497, -433,497,432, -497,433,498, -434,498,433, -498,434,499, -435,499,434, -499,435,500, -436,500,435, -500,436,501, -437,501,436, -501,437,502, -438,502,437, -502,438,503, -439,503,438, -503,439,504, -440,504,439, -504,440,505, -441,505,440, -505,441,506, -442,506,441, -506,442,507, -443,507,442, -507,443,508, -444,508,443, -508,444,509, -445,509,444, -509,445,510, -446,510,445, -510,446,511, -447,511,446, -512,448,513, -449,513,448, -513,449,514, -450,514,449, -514,450,515, -451,515,450, -515,451,516, -452,516,451, -516,452,517, -453,517,452, -517,453,518, -454,518,453, -518,454,519, -455,519,454, -519,455,520, -456,520,455, -520,456,521, -457,521,456, -521,457,522, -458,522,457, -522,458,523, -459,523,458, -523,459,524, -460,524,459, -524,460,525, -461,525,460, -525,461,526, -462,526,461, -526,462,527, -463,527,462, -527,463,528, -464,528,463, -528,464,529, -465,529,464, -529,465,530, -466,530,465, -530,466,531, -467,531,466, -531,467,532, -468,532,467, -532,468,533, -469,533,468, -533,469,534, -470,534,469, -534,470,535, -471,535,470, -535,471,536, -472,536,471, -536,472,537, -473,537,472, -537,473,538, -474,538,473, -538,474,539, -475,539,474, -539,475,540, -476,540,475, -540,476,541, -477,541,476, -541,477,542, -478,542,477, -542,478,543, -479,543,478, -543,479,544, -480,544,479, -544,480,545, -481,545,480, -545,481,546, -482,546,481, -546,482,547, -483,547,482, -547,483,548, -484,548,483, -548,484,549, -485,549,484, -549,485,550, -486,550,485, -550,486,551, -487,551,486, -551,487,552, -488,552,487, -552,488,553, -489,553,488, -553,489,554, -490,554,489, -554,490,555, -491,555,490, -555,491,556, -492,556,491, -556,492,557, -493,557,492, -557,493,558, -494,558,493, -558,494,559, -495,559,494, -559,495,560, -496,560,495, -560,496,561, -497,561,496, -561,497,562, -498,562,497, -562,498,563, -499,563,498, -563,499,564, -500,564,499, -564,500,565, -501,565,500, -565,501,566, -502,566,501, -566,502,567, -503,567,502, -567,503,568, -504,568,503, -568,504,569, -505,569,504, -569,505,570, -506,570,505, -570,506,571, -507,571,506, -571,507,572, -508,572,507, -572,508,573, -509,573,508, -573,509,574, -510,574,509, -574,510,575, -511,575,510, -576,512,577, -513,577,512, -577,513,578, -514,578,513, -578,514,579, -515,579,514, -579,515,580, -516,580,515, -580,516,581, -517,581,516, -581,517,582, -518,582,517, -582,518,583, -519,583,518, -583,519,584, -520,584,519, -584,520,585, -521,585,520, -585,521,586, -522,586,521, -586,522,587, -523,587,522, -587,523,588, -524,588,523, -588,524,589, -525,589,524, -589,525,590, -526,590,525, -590,526,591, -527,591,526, -591,527,592, -528,592,527, -592,528,593, -529,593,528, -593,529,594, -530,594,529, -594,530,595, -531,595,530, -595,531,596, -532,596,531, -596,532,597, -533,597,532, -597,533,598, -534,598,533, -598,534,599, -535,599,534, -599,535,600, -536,600,535, -600,536,601, -537,601,536, -601,537,602, -538,602,537, -602,538,603, -539,603,538, -603,539,604, -540,604,539, -604,540,605, -541,605,540, -605,541,606, -542,606,541, -606,542,607, -543,607,542, -607,543,608, -544,608,543, -608,544,609, -545,609,544, -609,545,610, -546,610,545, -610,546,611, -547,611,546, -611,547,612, -548,612,547, -612,548,613, -549,613,548, -613,549,614, -550,614,549, -614,550,615, -551,615,550, -615,551,616, -552,616,551, -616,552,617, -553,617,552, -617,553,618, -554,618,553, -618,554,619, -555,619,554, -619,555,620, -556,620,555, -620,556,621, -557,621,556, -621,557,622, -558,622,557, -622,558,623, -559,623,558, -623,559,624, -560,624,559, -624,560,625, -561,625,560, -625,561,626, -562,626,561, -626,562,627, -563,627,562, -627,563,628, -564,628,563, -628,564,629, -565,629,564, -629,565,630, -566,630,565, -630,566,631, -567,631,566, -631,567,632, -568,632,567, -632,568,633, -569,633,568, -633,569,634, -570,634,569, -634,570,635, -571,635,570, -635,571,636, -572,636,571, -636,572,637, -573,637,572, -637,573,638, -574,638,573, -638,574,639, -575,639,574, -640,576,641, -577,641,576, -641,577,642, -578,642,577, -642,578,643, -579,643,578, -643,579,644, -580,644,579, -644,580,645, -581,645,580, -645,581,646, -582,646,581, -646,582,647, -583,647,582, -647,583,648, -584,648,583, -648,584,649, -585,649,584, -649,585,650, -586,650,585, -650,586,651, -587,651,586, -651,587,652, -588,652,587, -652,588,653, -589,653,588, -653,589,654, -590,654,589, -654,590,655, -591,655,590, -655,591,656, -592,656,591, -656,592,657, -593,657,592, -657,593,658, -594,658,593, -658,594,659, -595,659,594, -659,595,660, -596,660,595, -660,596,661, -597,661,596, -661,597,662, -598,662,597, -662,598,663, -599,663,598, -663,599,664, -600,664,599, -664,600,665, -601,665,600, -665,601,666, -602,666,601, -666,602,667, -603,667,602, -667,603,668, -604,668,603, -668,604,669, -605,669,604, -669,605,670, -606,670,605, -670,606,671, -607,671,606, -671,607,672, -608,672,607, -672,608,673, -609,673,608, -673,609,674, -610,674,609, -674,610,675, -611,675,610, -675,611,676, -612,676,611, -676,612,677, -613,677,612, -677,613,678, -614,678,613, -678,614,679, -615,679,614, -679,615,680, -616,680,615, -680,616,681, -617,681,616, -681,617,682, -618,682,617, -682,618,683, -619,683,618, -683,619,684, -620,684,619, -684,620,685, -621,685,620, -685,621,686, -622,686,621, -686,622,687, -623,687,622, -687,623,688, -624,688,623, -688,624,689, -625,689,624, -689,625,690, -626,690,625, -690,626,691, -627,691,626, -691,627,692, -628,692,627, -692,628,693, -629,693,628, -693,629,694, -630,694,629, -694,630,695, -631,695,630, -695,631,696, -632,696,631, -696,632,697, -633,697,632, -697,633,698, -634,698,633, -698,634,699, -635,699,634, -699,635,700, -636,700,635, -700,636,701, -637,701,636, -701,637,702, -638,702,637, -702,638,703, -639,703,638, -704,640,705, -641,705,640, -705,641,706, -642,706,641, -706,642,707, -643,707,642, -707,643,708, -644,708,643, -708,644,709, -645,709,644, -709,645,710, -646,710,645, -710,646,711, -647,711,646, -711,647,712, -648,712,647, -712,648,713, -649,713,648, -713,649,714, -650,714,649, -714,650,715, -651,715,650, -715,651,716, -652,716,651, -716,652,717, -653,717,652, -717,653,718, -654,718,653, -718,654,719, -655,719,654, -719,655,720, -656,720,655, -720,656,721, -657,721,656, -721,657,722, -658,722,657, -722,658,723, -659,723,658, -723,659,724, -660,724,659, -724,660,725, -661,725,660, -725,661,726, -662,726,661, -726,662,727, -663,727,662, -727,663,728, -664,728,663, -728,664,729, -665,729,664, -729,665,730, -666,730,665, -730,666,731, -667,731,666, -731,667,732, -668,732,667, -732,668,733, -669,733,668, -733,669,734, -670,734,669, -734,670,735, -671,735,670, -735,671,736, -672,736,671, -736,672,737, -673,737,672, -737,673,738, -674,738,673, -738,674,739, -675,739,674, -739,675,740, -676,740,675, -740,676,741, -677,741,676, -741,677,742, -678,742,677, -742,678,743, -679,743,678, -743,679,744, -680,744,679, -744,680,745, -681,745,680, -745,681,746, -682,746,681, -746,682,747, -683,747,682, -747,683,748, -684,748,683, -748,684,749, -685,749,684, -749,685,750, -686,750,685, -750,686,751, -687,751,686, -751,687,752, -688,752,687, -752,688,753, -689,753,688, -753,689,754, -690,754,689, -754,690,755, -691,755,690, -755,691,756, -692,756,691, -756,692,757, -693,757,692, -757,693,758, -694,758,693, -758,694,759, -695,759,694, -759,695,760, -696,760,695, -760,696,761, -697,761,696, -761,697,762, -698,762,697, -762,698,763, -699,763,698, -763,699,764, -700,764,699, -764,700,765, -701,765,700, -765,701,766, -702,766,701, -766,702,767, -703,767,702, -768,704,769, -705,769,704, -769,705,770, -706,770,705, -770,706,771, -707,771,706, -771,707,772, -708,772,707, -772,708,773, -709,773,708, -773,709,774, -710,774,709, -774,710,775, -711,775,710, -775,711,776, -712,776,711, -776,712,777, -713,777,712, -777,713,778, -714,778,713, -778,714,779, -715,779,714, -779,715,780, -716,780,715, -780,716,781, -717,781,716, -781,717,782, -718,782,717, -782,718,783, -719,783,718, -783,719,784, -720,784,719, -784,720,785, -721,785,720, -785,721,786, -722,786,721, -786,722,787, -723,787,722, -787,723,788, -724,788,723, -788,724,789, -725,789,724, -789,725,790, -726,790,725, -790,726,791, -727,791,726, -791,727,792, -728,792,727, -792,728,793, -729,793,728, -793,729,794, -730,794,729, -794,730,795, -731,795,730, -795,731,796, -732,796,731, -796,732,797, -733,797,732, -797,733,798, -734,798,733, -798,734,799, -735,799,734, -799,735,800, -736,800,735, -800,736,801, -737,801,736, -801,737,802, -738,802,737, -802,738,803, -739,803,738, -803,739,804, -740,804,739, -804,740,805, -741,805,740, -805,741,806, -742,806,741, -806,742,807, -743,807,742, -807,743,808, -744,808,743, -808,744,809, -745,809,744, -809,745,810, -746,810,745, -810,746,811, -747,811,746, -811,747,812, -748,812,747, -812,748,813, -749,813,748, -813,749,814, -750,814,749, -814,750,815, -751,815,750, -815,751,816, -752,816,751, -816,752,817, -753,817,752, -817,753,818, -754,818,753, -818,754,819, -755,819,754, -819,755,820, -756,820,755, -820,756,821, -757,821,756, -821,757,822, -758,822,757, -822,758,823, -759,823,758, -823,759,824, -760,824,759, -824,760,825, -761,825,760, -825,761,826, -762,826,761, -826,762,827, -763,827,762, -827,763,828, -764,828,763, -828,764,829, -765,829,764, -829,765,830, -766,830,765, -830,766,831, -767,831,766, -832,768,833, -769,833,768, -833,769,834, -770,834,769, -834,770,835, -771,835,770, -835,771,836, -772,836,771, -836,772,837, -773,837,772, -837,773,838, -774,838,773, -838,774,839, -775,839,774, -839,775,840, -776,840,775, -840,776,841, -777,841,776, -841,777,842, -778,842,777, -842,778,843, -779,843,778, -843,779,844, -780,844,779, -844,780,845, -781,845,780, -845,781,846, -782,846,781, -846,782,847, -783,847,782, -847,783,848, -784,848,783, -848,784,849, -785,849,784, -849,785,850, -786,850,785, -850,786,851, -787,851,786, -851,787,852, -788,852,787, -852,788,853, -789,853,788, -853,789,854, -790,854,789, -854,790,855, -791,855,790, -855,791,856, -792,856,791, -856,792,857, -793,857,792, -857,793,858, -794,858,793, -858,794,859, -795,859,794, -859,795,860, -796,860,795, -860,796,861, -797,861,796, -861,797,862, -798,862,797, -862,798,863, -799,863,798, -863,799,864, -800,864,799, -864,800,865, -801,865,800, -865,801,866, -802,866,801, -866,802,867, -803,867,802, -867,803,868, -804,868,803, -868,804,869, -805,869,804, -869,805,870, -806,870,805, -870,806,871, -807,871,806, -871,807,872, -808,872,807, -872,808,873, -809,873,808, -873,809,874, -810,874,809, -874,810,875, -811,875,810, -875,811,876, -812,876,811, -876,812,877, -813,877,812, -877,813,878, -814,878,813, -878,814,879, -815,879,814, -879,815,880, -816,880,815, -880,816,881, -817,881,816, -881,817,882, -818,882,817, -882,818,883, -819,883,818, -883,819,884, -820,884,819, -884,820,885, -821,885,820, -885,821,886, -822,886,821, -886,822,887, -823,887,822, -887,823,888, -824,888,823, -888,824,889, -825,889,824, -889,825,890, -826,890,825, -890,826,891, -827,891,826, -891,827,892, -828,892,827, -892,828,893, -829,893,828, -893,829,894, -830,894,829, -894,830,895, -831,895,830, -896,832,897, -833,897,832, -897,833,898, -834,898,833, -898,834,899, -835,899,834, -899,835,900, -836,900,835, -900,836,901, -837,901,836, -901,837,902, -838,902,837, -902,838,903, -839,903,838, -903,839,904, -840,904,839, -904,840,905, -841,905,840, -905,841,906, -842,906,841, -906,842,907, -843,907,842, -907,843,908, -844,908,843, -908,844,909, -845,909,844, -909,845,910, -846,910,845, -910,846,911, -847,911,846, -911,847,912, -848,912,847, -912,848,913, -849,913,848, -913,849,914, -850,914,849, -914,850,915, -851,915,850, -915,851,916, -852,916,851, -916,852,917, -853,917,852, -917,853,918, -854,918,853, -918,854,919, -855,919,854, -919,855,920, -856,920,855, -920,856,921, -857,921,856, -921,857,922, -858,922,857, -922,858,923, -859,923,858, -923,859,924, -860,924,859, -924,860,925, -861,925,860, -925,861,926, -862,926,861, -926,862,927, -863,927,862, -927,863,928, -864,928,863, -928,864,929, -865,929,864, -929,865,930, -866,930,865, -930,866,931, -867,931,866, -931,867,932, -868,932,867, -932,868,933, -869,933,868, -933,869,934, -870,934,869, -934,870,935, -871,935,870, -935,871,936, -872,936,871, -936,872,937, -873,937,872, -937,873,938, -874,938,873, -938,874,939, -875,939,874, -939,875,940, -876,940,875, -940,876,941, -877,941,876, -941,877,942, -878,942,877, -942,878,943, -879,943,878, -943,879,944, -880,944,879, -944,880,945, -881,945,880, -945,881,946, -882,946,881, -946,882,947, -883,947,882, -947,883,948, -884,948,883, -948,884,949, -885,949,884, -949,885,950, -886,950,885, -950,886,951, -887,951,886, -951,887,952, -888,952,887, -952,888,953, -889,953,888, -953,889,954, -890,954,889, -954,890,955, -891,955,890, -955,891,956, -892,956,891, -956,892,957, -893,957,892, -957,893,958, -894,958,893, -958,894,959, -895,959,894, -960,896,961, -897,961,896, -961,897,962, -898,962,897, -962,898,963, -899,963,898, -963,899,964, -900,964,899, -964,900,965, -901,965,900, -965,901,966, -902,966,901, -966,902,967, -903,967,902, -967,903,968, -904,968,903, -968,904,969, -905,969,904, -969,905,970, -906,970,905, -970,906,971, -907,971,906, -971,907,972, -908,972,907, -972,908,973, -909,973,908, -973,909,974, -910,974,909, -974,910,975, -911,975,910, -975,911,976, -912,976,911, -976,912,977, -913,977,912, -977,913,978, -914,978,913, -978,914,979, -915,979,914, -979,915,980, -916,980,915, -980,916,981, -917,981,916, -981,917,982, -918,982,917, -982,918,983, -919,983,918, -983,919,984, -920,984,919, -984,920,985, -921,985,920, -985,921,986, -922,986,921, -986,922,987, -923,987,922, -987,923,988, -924,988,923, -988,924,989, -925,989,924, -989,925,990, -926,990,925, -990,926,991, -927,991,926, -991,927,992, -928,992,927, -992,928,993, -929,993,928, -993,929,994, -930,994,929, -994,930,995, -931,995,930, -995,931,996, -932,996,931, -996,932,997, -933,997,932, -997,933,998, -934,998,933, -998,934,999, -935,999,934, -999,935,1000, -936,1000,935, -1000,936,1001, -937,1001,936, -1001,937,1002, -938,1002,937, -1002,938,1003, -939,1003,938, -1003,939,1004, -940,1004,939, -1004,940,1005, -941,1005,940, -1005,941,1006, -942,1006,941, -1006,942,1007, -943,1007,942, -1007,943,1008, -944,1008,943, -1008,944,1009, -945,1009,944, -1009,945,1010, -946,1010,945, -1010,946,1011, -947,1011,946, -1011,947,1012, -948,1012,947, -1012,948,1013, -949,1013,948, -1013,949,1014, -950,1014,949, -1014,950,1015, -951,1015,950, -1015,951,1016, -952,1016,951, -1016,952,1017, -953,1017,952, -1017,953,1018, -954,1018,953, -1018,954,1019, -955,1019,954, -1019,955,1020, -956,1020,955, -1020,956,1021, -957,1021,956, -1021,957,1022, -958,1022,957, -1022,958,1023, -959,1023,958, -1024,960,1025, -961,1025,960, -1025,961,1026, -962,1026,961, -1026,962,1027, -963,1027,962, -1027,963,1028, -964,1028,963, -1028,964,1029, -965,1029,964, -1029,965,1030, -966,1030,965, -1030,966,1031, -967,1031,966, -1031,967,1032, -968,1032,967, -1032,968,1033, -969,1033,968, -1033,969,1034, -970,1034,969, -1034,970,1035, -971,1035,970, -1035,971,1036, -972,1036,971, -1036,972,1037, -973,1037,972, -1037,973,1038, -974,1038,973, -1038,974,1039, -975,1039,974, -1039,975,1040, -976,1040,975, -1040,976,1041, -977,1041,976, -1041,977,1042, -978,1042,977, -1042,978,1043, -979,1043,978, -1043,979,1044, -980,1044,979, -1044,980,1045, -981,1045,980, -1045,981,1046, -982,1046,981, -1046,982,1047, -983,1047,982, -1047,983,1048, -984,1048,983, -1048,984,1049, -985,1049,984, -1049,985,1050, -986,1050,985, -1050,986,1051, -987,1051,986, -1051,987,1052, -988,1052,987, -1052,988,1053, -989,1053,988, -1053,989,1054, -990,1054,989, -1054,990,1055, -991,1055,990, -1055,991,1056, -992,1056,991, -1056,992,1057, -993,1057,992, -1057,993,1058, -994,1058,993, -1058,994,1059, -995,1059,994, -1059,995,1060, -996,1060,995, -1060,996,1061, -997,1061,996, -1061,997,1062, -998,1062,997, -1062,998,1063, -999,1063,998, -1063,999,1064, -1000,1064,999, -1064,1000,1065, -1001,1065,1000, -1065,1001,1066, -1002,1066,1001, -1066,1002,1067, -1003,1067,1002, -1067,1003,1068, -1004,1068,1003, -1068,1004,1069, -1005,1069,1004, -1069,1005,1070, -1006,1070,1005, -1070,1006,1071, -1007,1071,1006, -1071,1007,1072, -1008,1072,1007, -1072,1008,1073, -1009,1073,1008, -1073,1009,1074, -1010,1074,1009, -1074,1010,1075, -1011,1075,1010, -1075,1011,1076, -1012,1076,1011, -1076,1012,1077, -1013,1077,1012, -1077,1013,1078, -1014,1078,1013, -1078,1014,1079, -1015,1079,1014, -1079,1015,1080, -1016,1080,1015, -1080,1016,1081, -1017,1081,1016, -1081,1017,1082, -1018,1082,1017, -1082,1018,1083, -1019,1083,1018, -1083,1019,1084, -1020,1084,1019, -1084,1020,1085, -1021,1085,1020, -1085,1021,1086, -1022,1086,1021, -1086,1022,1087, -1023,1087,1022, -1088,1024,1089, -1025,1089,1024, -1089,1025,1090, -1026,1090,1025, -1090,1026,1091, -1027,1091,1026, -1091,1027,1092, -1028,1092,1027, -1092,1028,1093, -1029,1093,1028, -1093,1029,1094, -1030,1094,1029, -1094,1030,1095, -1031,1095,1030, -1095,1031,1096, -1032,1096,1031, -1096,1032,1097, -1033,1097,1032, -1097,1033,1098, -1034,1098,1033, -1098,1034,1099, -1035,1099,1034, -1099,1035,1100, -1036,1100,1035, -1100,1036,1101, -1037,1101,1036, -1101,1037,1102, -1038,1102,1037, -1102,1038,1103, -1039,1103,1038, -1103,1039,1104, -1040,1104,1039, -1104,1040,1105, -1041,1105,1040, -1105,1041,1106, -1042,1106,1041, -1106,1042,1107, -1043,1107,1042, -1107,1043,1108, -1044,1108,1043, -1108,1044,1109, -1045,1109,1044, -1109,1045,1110, -1046,1110,1045, -1110,1046,1111, -1047,1111,1046, -1111,1047,1112, -1048,1112,1047, -1112,1048,1113, -1049,1113,1048, -1113,1049,1114, -1050,1114,1049, -1114,1050,1115, -1051,1115,1050, -1115,1051,1116, -1052,1116,1051, -1116,1052,1117, -1053,1117,1052, -1117,1053,1118, -1054,1118,1053, -1118,1054,1119, -1055,1119,1054, -1119,1055,1120, -1056,1120,1055, -1120,1056,1121, -1057,1121,1056, -1121,1057,1122, -1058,1122,1057, -1122,1058,1123, -1059,1123,1058, -1123,1059,1124, -1060,1124,1059, -1124,1060,1125, -1061,1125,1060, -1125,1061,1126, -1062,1126,1061, -1126,1062,1127, -1063,1127,1062, -1127,1063,1128, -1064,1128,1063, -1128,1064,1129, -1065,1129,1064, -1129,1065,1130, -1066,1130,1065, -1130,1066,1131, -1067,1131,1066, -1131,1067,1132, -1068,1132,1067, -1132,1068,1133, -1069,1133,1068, -1133,1069,1134, -1070,1134,1069, -1134,1070,1135, -1071,1135,1070, -1135,1071,1136, -1072,1136,1071, -1136,1072,1137, -1073,1137,1072, -1137,1073,1138, -1074,1138,1073, -1138,1074,1139, -1075,1139,1074, -1139,1075,1140, -1076,1140,1075, -1140,1076,1141, -1077,1141,1076, -1141,1077,1142, -1078,1142,1077, -1142,1078,1143, -1079,1143,1078, -1143,1079,1144, -1080,1144,1079, -1144,1080,1145, -1081,1145,1080, -1145,1081,1146, -1082,1146,1081, -1146,1082,1147, -1083,1147,1082, -1147,1083,1148, -1084,1148,1083, -1148,1084,1149, -1085,1149,1084, -1149,1085,1150, -1086,1150,1085, -1150,1086,1151, -1087,1151,1086, -1152,1088,1153, -1089,1153,1088, -1153,1089,1154, -1090,1154,1089, -1154,1090,1155, -1091,1155,1090, -1155,1091,1156, -1092,1156,1091, -1156,1092,1157, -1093,1157,1092, -1157,1093,1158, -1094,1158,1093, -1158,1094,1159, -1095,1159,1094, -1159,1095,1160, -1096,1160,1095, -1160,1096,1161, -1097,1161,1096, -1161,1097,1162, -1098,1162,1097, -1162,1098,1163, -1099,1163,1098, -1163,1099,1164, -1100,1164,1099, -1164,1100,1165, -1101,1165,1100, -1165,1101,1166, -1102,1166,1101, -1166,1102,1167, -1103,1167,1102, -1167,1103,1168, -1104,1168,1103, -1168,1104,1169, -1105,1169,1104, -1169,1105,1170, -1106,1170,1105, -1170,1106,1171, -1107,1171,1106, -1171,1107,1172, -1108,1172,1107, -1172,1108,1173, -1109,1173,1108, -1173,1109,1174, -1110,1174,1109, -1174,1110,1175, -1111,1175,1110, -1175,1111,1176, -1112,1176,1111, -1176,1112,1177, -1113,1177,1112, -1177,1113,1178, -1114,1178,1113, -1178,1114,1179, -1115,1179,1114, -1179,1115,1180, -1116,1180,1115, -1180,1116,1181, -1117,1181,1116, -1181,1117,1182, -1118,1182,1117, -1182,1118,1183, -1119,1183,1118, -1183,1119,1184, -1120,1184,1119, -1184,1120,1185, -1121,1185,1120, -1185,1121,1186, -1122,1186,1121, -1186,1122,1187, -1123,1187,1122, -1187,1123,1188, -1124,1188,1123, -1188,1124,1189, -1125,1189,1124, -1189,1125,1190, -1126,1190,1125, -1190,1126,1191, -1127,1191,1126, -1191,1127,1192, -1128,1192,1127, -1192,1128,1193, -1129,1193,1128, -1193,1129,1194, -1130,1194,1129, -1194,1130,1195, -1131,1195,1130, -1195,1131,1196, -1132,1196,1131, -1196,1132,1197, -1133,1197,1132, -1197,1133,1198, -1134,1198,1133, -1198,1134,1199, -1135,1199,1134, -1199,1135,1200, -1136,1200,1135, -1200,1136,1201, -1137,1201,1136, -1201,1137,1202, -1138,1202,1137, -1202,1138,1203, -1139,1203,1138, -1203,1139,1204, -1140,1204,1139, -1204,1140,1205, -1141,1205,1140, -1205,1141,1206, -1142,1206,1141, -1206,1142,1207, -1143,1207,1142, -1207,1143,1208, -1144,1208,1143, -1208,1144,1209, -1145,1209,1144, -1209,1145,1210, -1146,1210,1145, -1210,1146,1211, -1147,1211,1146, -1211,1147,1212, -1148,1212,1147, -1212,1148,1213, -1149,1213,1148, -1213,1149,1214, -1150,1214,1149, -1214,1150,1215, -1151,1215,1150, -1216,1152,1217, -1153,1217,1152, -1217,1153,1218, -1154,1218,1153, -1218,1154,1219, -1155,1219,1154, -1219,1155,1220, -1156,1220,1155, -1220,1156,1221, -1157,1221,1156, -1221,1157,1222, -1158,1222,1157, -1222,1158,1223, -1159,1223,1158, -1223,1159,1224, -1160,1224,1159, -1224,1160,1225, -1161,1225,1160, -1225,1161,1226, -1162,1226,1161, -1226,1162,1227, -1163,1227,1162, -1227,1163,1228, -1164,1228,1163, -1228,1164,1229, -1165,1229,1164, -1229,1165,1230, -1166,1230,1165, -1230,1166,1231, -1167,1231,1166, -1231,1167,1232, -1168,1232,1167, -1232,1168,1233, -1169,1233,1168, -1233,1169,1234, -1170,1234,1169, -1234,1170,1235, -1171,1235,1170, -1235,1171,1236, -1172,1236,1171, -1236,1172,1237, -1173,1237,1172, -1237,1173,1238, -1174,1238,1173, -1238,1174,1239, -1175,1239,1174, -1239,1175,1240, -1176,1240,1175, -1240,1176,1241, -1177,1241,1176, -1241,1177,1242, -1178,1242,1177, -1242,1178,1243, -1179,1243,1178, -1243,1179,1244, -1180,1244,1179, -1244,1180,1245, -1181,1245,1180, -1245,1181,1246, -1182,1246,1181, -1246,1182,1247, -1183,1247,1182, -1247,1183,1248, -1184,1248,1183, -1248,1184,1249, -1185,1249,1184, -1249,1185,1250, -1186,1250,1185, -1250,1186,1251, -1187,1251,1186, -1251,1187,1252, -1188,1252,1187, -1252,1188,1253, -1189,1253,1188, -1253,1189,1254, -1190,1254,1189, -1254,1190,1255, -1191,1255,1190, -1255,1191,1256, -1192,1256,1191, -1256,1192,1257, -1193,1257,1192, -1257,1193,1258, -1194,1258,1193, -1258,1194,1259, -1195,1259,1194, -1259,1195,1260, -1196,1260,1195, -1260,1196,1261, -1197,1261,1196, -1261,1197,1262, -1198,1262,1197, -1262,1198,1263, -1199,1263,1198, -1263,1199,1264, -1200,1264,1199, -1264,1200,1265, -1201,1265,1200, -1265,1201,1266, -1202,1266,1201, -1266,1202,1267, -1203,1267,1202, -1267,1203,1268, -1204,1268,1203, -1268,1204,1269, -1205,1269,1204, -1269,1205,1270, -1206,1270,1205, -1270,1206,1271, -1207,1271,1206, -1271,1207,1272, -1208,1272,1207, -1272,1208,1273, -1209,1273,1208, -1273,1209,1274, -1210,1274,1209, -1274,1210,1275, -1211,1275,1210, -1275,1211,1276, -1212,1276,1211, -1276,1212,1277, -1213,1277,1212, -1277,1213,1278, -1214,1278,1213, -1278,1214,1279, -1215,1279,1214, -1280,1216,1281, -1217,1281,1216, -1281,1217,1282, -1218,1282,1217, -1282,1218,1283, -1219,1283,1218, -1283,1219,1284, -1220,1284,1219, -1284,1220,1285, -1221,1285,1220, -1285,1221,1286, -1222,1286,1221, -1286,1222,1287, -1223,1287,1222, -1287,1223,1288, -1224,1288,1223, -1288,1224,1289, -1225,1289,1224, -1289,1225,1290, -1226,1290,1225, -1290,1226,1291, -1227,1291,1226, -1291,1227,1292, -1228,1292,1227, -1292,1228,1293, -1229,1293,1228, -1293,1229,1294, -1230,1294,1229, -1294,1230,1295, -1231,1295,1230, -1295,1231,1296, -1232,1296,1231, -1296,1232,1297, -1233,1297,1232, -1297,1233,1298, -1234,1298,1233, -1298,1234,1299, -1235,1299,1234, -1299,1235,1300, -1236,1300,1235, -1300,1236,1301, -1237,1301,1236, -1301,1237,1302, -1238,1302,1237, -1302,1238,1303, -1239,1303,1238, -1303,1239,1304, -1240,1304,1239, -1304,1240,1305, -1241,1305,1240, -1305,1241,1306, -1242,1306,1241, -1306,1242,1307, -1243,1307,1242, -1307,1243,1308, -1244,1308,1243, -1308,1244,1309, -1245,1309,1244, -1309,1245,1310, -1246,1310,1245, -1310,1246,1311, -1247,1311,1246, -1311,1247,1312, -1248,1312,1247, -1312,1248,1313, -1249,1313,1248, -1313,1249,1314, -1250,1314,1249, -1314,1250,1315, -1251,1315,1250, -1315,1251,1316, -1252,1316,1251, -1316,1252,1317, -1253,1317,1252, -1317,1253,1318, -1254,1318,1253, -1318,1254,1319, -1255,1319,1254, -1319,1255,1320, -1256,1320,1255, -1320,1256,1321, -1257,1321,1256, -1321,1257,1322, -1258,1322,1257, -1322,1258,1323, -1259,1323,1258, -1323,1259,1324, -1260,1324,1259, -1324,1260,1325, -1261,1325,1260, -1325,1261,1326, -1262,1326,1261, -1326,1262,1327, -1263,1327,1262, -1327,1263,1328, -1264,1328,1263, -1328,1264,1329, -1265,1329,1264, -1329,1265,1330, -1266,1330,1265, -1330,1266,1331, -1267,1331,1266, -1331,1267,1332, -1268,1332,1267, -1332,1268,1333, -1269,1333,1268, -1333,1269,1334, -1270,1334,1269, -1334,1270,1335, -1271,1335,1270, -1335,1271,1336, -1272,1336,1271, -1336,1272,1337, -1273,1337,1272, -1337,1273,1338, -1274,1338,1273, -1338,1274,1339, -1275,1339,1274, -1339,1275,1340, -1276,1340,1275, -1340,1276,1341, -1277,1341,1276, -1341,1277,1342, -1278,1342,1277, -1342,1278,1343, -1279,1343,1278, -1344,1280,1345, -1281,1345,1280, -1345,1281,1346, -1282,1346,1281, -1346,1282,1347, -1283,1347,1282, -1347,1283,1348, -1284,1348,1283, -1348,1284,1349, -1285,1349,1284, -1349,1285,1350, -1286,1350,1285, -1350,1286,1351, -1287,1351,1286, -1351,1287,1352, -1288,1352,1287, -1352,1288,1353, -1289,1353,1288, -1353,1289,1354, -1290,1354,1289, -1354,1290,1355, -1291,1355,1290, -1355,1291,1356, -1292,1356,1291, -1356,1292,1357, -1293,1357,1292, -1357,1293,1358, -1294,1358,1293, -1358,1294,1359, -1295,1359,1294, -1359,1295,1360, -1296,1360,1295, -1360,1296,1361, -1297,1361,1296, -1361,1297,1362, -1298,1362,1297, -1362,1298,1363, -1299,1363,1298, -1363,1299,1364, -1300,1364,1299, -1364,1300,1365, -1301,1365,1300, -1365,1301,1366, -1302,1366,1301, -1366,1302,1367, -1303,1367,1302, -1367,1303,1368, -1304,1368,1303, -1368,1304,1369, -1305,1369,1304, -1369,1305,1370, -1306,1370,1305, -1370,1306,1371, -1307,1371,1306, -1371,1307,1372, -1308,1372,1307, -1372,1308,1373, -1309,1373,1308, -1373,1309,1374, -1310,1374,1309, -1374,1310,1375, -1311,1375,1310, -1375,1311,1376, -1312,1376,1311, -1376,1312,1377, -1313,1377,1312, -1377,1313,1378, -1314,1378,1313, -1378,1314,1379, -1315,1379,1314, -1379,1315,1380, -1316,1380,1315, -1380,1316,1381, -1317,1381,1316, -1381,1317,1382, -1318,1382,1317, -1382,1318,1383, -1319,1383,1318, -1383,1319,1384, -1320,1384,1319, -1384,1320,1385, -1321,1385,1320, -1385,1321,1386, -1322,1386,1321, -1386,1322,1387, -1323,1387,1322, -1387,1323,1388, -1324,1388,1323, -1388,1324,1389, -1325,1389,1324, -1389,1325,1390, -1326,1390,1325, -1390,1326,1391, -1327,1391,1326, -1391,1327,1392, -1328,1392,1327, -1392,1328,1393, -1329,1393,1328, -1393,1329,1394, -1330,1394,1329, -1394,1330,1395, -1331,1395,1330, -1395,1331,1396, -1332,1396,1331, -1396,1332,1397, -1333,1397,1332, -1397,1333,1398, -1334,1398,1333, -1398,1334,1399, -1335,1399,1334, -1399,1335,1400, -1336,1400,1335, -1400,1336,1401, -1337,1401,1336, -1401,1337,1402, -1338,1402,1337, -1402,1338,1403, -1339,1403,1338, -1403,1339,1404, -1340,1404,1339, -1404,1340,1405, -1341,1405,1340, -1405,1341,1406, -1342,1406,1341, -1406,1342,1407, -1343,1407,1342, -1408,1344,1409, -1345,1409,1344, -1409,1345,1410, -1346,1410,1345, -1410,1346,1411, -1347,1411,1346, -1411,1347,1412, -1348,1412,1347, -1412,1348,1413, -1349,1413,1348, -1413,1349,1414, -1350,1414,1349, -1414,1350,1415, -1351,1415,1350, -1415,1351,1416, -1352,1416,1351, -1416,1352,1417, -1353,1417,1352, -1417,1353,1418, -1354,1418,1353, -1418,1354,1419, -1355,1419,1354, -1419,1355,1420, -1356,1420,1355, -1420,1356,1421, -1357,1421,1356, -1421,1357,1422, -1358,1422,1357, -1422,1358,1423, -1359,1423,1358, -1423,1359,1424, -1360,1424,1359, -1424,1360,1425, -1361,1425,1360, -1425,1361,1426, -1362,1426,1361, -1426,1362,1427, -1363,1427,1362, -1427,1363,1428, -1364,1428,1363, -1428,1364,1429, -1365,1429,1364, -1429,1365,1430, -1366,1430,1365, -1430,1366,1431, -1367,1431,1366, -1431,1367,1432, -1368,1432,1367, -1432,1368,1433, -1369,1433,1368, -1433,1369,1434, -1370,1434,1369, -1434,1370,1435, -1371,1435,1370, -1435,1371,1436, -1372,1436,1371, -1436,1372,1437, -1373,1437,1372, -1437,1373,1438, -1374,1438,1373, -1438,1374,1439, -1375,1439,1374, -1439,1375,1440, -1376,1440,1375, -1440,1376,1441, -1377,1441,1376, -1441,1377,1442, -1378,1442,1377, -1442,1378,1443, -1379,1443,1378, -1443,1379,1444, -1380,1444,1379, -1444,1380,1445, -1381,1445,1380, -1445,1381,1446, -1382,1446,1381, -1446,1382,1447, -1383,1447,1382, -1447,1383,1448, -1384,1448,1383, -1448,1384,1449, -1385,1449,1384, -1449,1385,1450, -1386,1450,1385, -1450,1386,1451, -1387,1451,1386, -1451,1387,1452, -1388,1452,1387, -1452,1388,1453, -1389,1453,1388, -1453,1389,1454, -1390,1454,1389, -1454,1390,1455, -1391,1455,1390, -1455,1391,1456, -1392,1456,1391, -1456,1392,1457, -1393,1457,1392, -1457,1393,1458, -1394,1458,1393, -1458,1394,1459, -1395,1459,1394, -1459,1395,1460, -1396,1460,1395, -1460,1396,1461, -1397,1461,1396, -1461,1397,1462, -1398,1462,1397, -1462,1398,1463, -1399,1463,1398, -1463,1399,1464, -1400,1464,1399, -1464,1400,1465, -1401,1465,1400, -1465,1401,1466, -1402,1466,1401, -1466,1402,1467, -1403,1467,1402, -1467,1403,1468, -1404,1468,1403, -1468,1404,1469, -1405,1469,1404, -1469,1405,1470, -1406,1470,1405, -1470,1406,1471, -1407,1471,1406, -1472,1408,1473, -1409,1473,1408, -1473,1409,1474, -1410,1474,1409, -1474,1410,1475, -1411,1475,1410, -1475,1411,1476, -1412,1476,1411, -1476,1412,1477, -1413,1477,1412, -1477,1413,1478, -1414,1478,1413, -1478,1414,1479, -1415,1479,1414, -1479,1415,1480, -1416,1480,1415, -1480,1416,1481, -1417,1481,1416, -1481,1417,1482, -1418,1482,1417, -1482,1418,1483, -1419,1483,1418, -1483,1419,1484, -1420,1484,1419, -1484,1420,1485, -1421,1485,1420, -1485,1421,1486, -1422,1486,1421, -1486,1422,1487, -1423,1487,1422, -1487,1423,1488, -1424,1488,1423, -1488,1424,1489, -1425,1489,1424, -1489,1425,1490, -1426,1490,1425, -1490,1426,1491, -1427,1491,1426, -1491,1427,1492, -1428,1492,1427, -1492,1428,1493, -1429,1493,1428, -1493,1429,1494, -1430,1494,1429, -1494,1430,1495, -1431,1495,1430, -1495,1431,1496, -1432,1496,1431, -1496,1432,1497, -1433,1497,1432, -1497,1433,1498, -1434,1498,1433, -1498,1434,1499, -1435,1499,1434, -1499,1435,1500, -1436,1500,1435, -1500,1436,1501, -1437,1501,1436, -1501,1437,1502, -1438,1502,1437, -1502,1438,1503, -1439,1503,1438, -1503,1439,1504, -1440,1504,1439, -1504,1440,1505, -1441,1505,1440, -1505,1441,1506, -1442,1506,1441, -1506,1442,1507, -1443,1507,1442, -1507,1443,1508, -1444,1508,1443, -1508,1444,1509, -1445,1509,1444, -1509,1445,1510, -1446,1510,1445, -1510,1446,1511, -1447,1511,1446, -1511,1447,1512, -1448,1512,1447, -1512,1448,1513, -1449,1513,1448, -1513,1449,1514, -1450,1514,1449, -1514,1450,1515, -1451,1515,1450, -1515,1451,1516, -1452,1516,1451, -1516,1452,1517, -1453,1517,1452, -1517,1453,1518, -1454,1518,1453, -1518,1454,1519, -1455,1519,1454, -1519,1455,1520, -1456,1520,1455, -1520,1456,1521, -1457,1521,1456, -1521,1457,1522, -1458,1522,1457, -1522,1458,1523, -1459,1523,1458, -1523,1459,1524, -1460,1524,1459, -1524,1460,1525, -1461,1525,1460, -1525,1461,1526, -1462,1526,1461, -1526,1462,1527, -1463,1527,1462, -1527,1463,1528, -1464,1528,1463, -1528,1464,1529, -1465,1529,1464, -1529,1465,1530, -1466,1530,1465, -1530,1466,1531, -1467,1531,1466, -1531,1467,1532, -1468,1532,1467, -1532,1468,1533, -1469,1533,1468, -1533,1469,1534, -1470,1534,1469, -1534,1470,1535, -1471,1535,1470, -1536,1472,1537, -1473,1537,1472, -1537,1473,1538, -1474,1538,1473, -1538,1474,1539, -1475,1539,1474, -1539,1475,1540, -1476,1540,1475, -1540,1476,1541, -1477,1541,1476, -1541,1477,1542, -1478,1542,1477, -1542,1478,1543, -1479,1543,1478, -1543,1479,1544, -1480,1544,1479, -1544,1480,1545, -1481,1545,1480, -1545,1481,1546, -1482,1546,1481, -1546,1482,1547, -1483,1547,1482, -1547,1483,1548, -1484,1548,1483, -1548,1484,1549, -1485,1549,1484, -1549,1485,1550, -1486,1550,1485, -1550,1486,1551, -1487,1551,1486, -1551,1487,1552, -1488,1552,1487, -1552,1488,1553, -1489,1553,1488, -1553,1489,1554, -1490,1554,1489, -1554,1490,1555, -1491,1555,1490, -1555,1491,1556, -1492,1556,1491, -1556,1492,1557, -1493,1557,1492, -1557,1493,1558, -1494,1558,1493, -1558,1494,1559, -1495,1559,1494, -1559,1495,1560, -1496,1560,1495, -1560,1496,1561, -1497,1561,1496, -1561,1497,1562, -1498,1562,1497, -1562,1498,1563, -1499,1563,1498, -1563,1499,1564, -1500,1564,1499, -1564,1500,1565, -1501,1565,1500, -1565,1501,1566, -1502,1566,1501, -1566,1502,1567, -1503,1567,1502, -1567,1503,1568, -1504,1568,1503, -1568,1504,1569, -1505,1569,1504, -1569,1505,1570, -1506,1570,1505, -1570,1506,1571, -1507,1571,1506, -1571,1507,1572, -1508,1572,1507, -1572,1508,1573, -1509,1573,1508, -1573,1509,1574, -1510,1574,1509, -1574,1510,1575, -1511,1575,1510, -1575,1511,1576, -1512,1576,1511, -1576,1512,1577, -1513,1577,1512, -1577,1513,1578, -1514,1578,1513, -1578,1514,1579, -1515,1579,1514, -1579,1515,1580, -1516,1580,1515, -1580,1516,1581, -1517,1581,1516, -1581,1517,1582, -1518,1582,1517, -1582,1518,1583, -1519,1583,1518, -1583,1519,1584, -1520,1584,1519, -1584,1520,1585, -1521,1585,1520, -1585,1521,1586, -1522,1586,1521, -1586,1522,1587, -1523,1587,1522, -1587,1523,1588, -1524,1588,1523, -1588,1524,1589, -1525,1589,1524, -1589,1525,1590, -1526,1590,1525, -1590,1526,1591, -1527,1591,1526, -1591,1527,1592, -1528,1592,1527, -1592,1528,1593, -1529,1593,1528, -1593,1529,1594, -1530,1594,1529, -1594,1530,1595, -1531,1595,1530, -1595,1531,1596, -1532,1596,1531, -1596,1532,1597, -1533,1597,1532, -1597,1533,1598, -1534,1598,1533, -1598,1534,1599, -1535,1599,1534, -1600,1536,1601, -1537,1601,1536, -1601,1537,1602, -1538,1602,1537, -1602,1538,1603, -1539,1603,1538, -1603,1539,1604, -1540,1604,1539, -1604,1540,1605, -1541,1605,1540, -1605,1541,1606, -1542,1606,1541, -1606,1542,1607, -1543,1607,1542, -1607,1543,1608, -1544,1608,1543, -1608,1544,1609, -1545,1609,1544, -1609,1545,1610, -1546,1610,1545, -1610,1546,1611, -1547,1611,1546, -1611,1547,1612, -1548,1612,1547, -1612,1548,1613, -1549,1613,1548, -1613,1549,1614, -1550,1614,1549, -1614,1550,1615, -1551,1615,1550, -1615,1551,1616, -1552,1616,1551, -1616,1552,1617, -1553,1617,1552, -1617,1553,1618, -1554,1618,1553, -1618,1554,1619, -1555,1619,1554, -1619,1555,1620, -1556,1620,1555, -1620,1556,1621, -1557,1621,1556, -1621,1557,1622, -1558,1622,1557, -1622,1558,1623, -1559,1623,1558, -1623,1559,1624, -1560,1624,1559, -1624,1560,1625, -1561,1625,1560, -1625,1561,1626, -1562,1626,1561, -1626,1562,1627, -1563,1627,1562, -1627,1563,1628, -1564,1628,1563, -1628,1564,1629, -1565,1629,1564, -1629,1565,1630, -1566,1630,1565, -1630,1566,1631, -1567,1631,1566, -1631,1567,1632, -1568,1632,1567, -1632,1568,1633, -1569,1633,1568, -1633,1569,1634, -1570,1634,1569, -1634,1570,1635, -1571,1635,1570, -1635,1571,1636, -1572,1636,1571, -1636,1572,1637, -1573,1637,1572, -1637,1573,1638, -1574,1638,1573, -1638,1574,1639, -1575,1639,1574, -1639,1575,1640, -1576,1640,1575, -1640,1576,1641, -1577,1641,1576, -1641,1577,1642, -1578,1642,1577, -1642,1578,1643, -1579,1643,1578, -1643,1579,1644, -1580,1644,1579, -1644,1580,1645, -1581,1645,1580, -1645,1581,1646, -1582,1646,1581, -1646,1582,1647, -1583,1647,1582, -1647,1583,1648, -1584,1648,1583, -1648,1584,1649, -1585,1649,1584, -1649,1585,1650, -1586,1650,1585, -1650,1586,1651, -1587,1651,1586, -1651,1587,1652, -1588,1652,1587, -1652,1588,1653, -1589,1653,1588, -1653,1589,1654, -1590,1654,1589, -1654,1590,1655, -1591,1655,1590, -1655,1591,1656, -1592,1656,1591, -1656,1592,1657, -1593,1657,1592, -1657,1593,1658, -1594,1658,1593, -1658,1594,1659, -1595,1659,1594, -1659,1595,1660, -1596,1660,1595, -1660,1596,1661, -1597,1661,1596, -1661,1597,1662, -1598,1662,1597, -1662,1598,1663, -1599,1663,1598, -1664,1600,1665, -1601,1665,1600, -1665,1601,1666, -1602,1666,1601, -1666,1602,1667, -1603,1667,1602, -1667,1603,1668, -1604,1668,1603, -1668,1604,1669, -1605,1669,1604, -1669,1605,1670, -1606,1670,1605, -1670,1606,1671, -1607,1671,1606, -1671,1607,1672, -1608,1672,1607, -1672,1608,1673, -1609,1673,1608, -1673,1609,1674, -1610,1674,1609, -1674,1610,1675, -1611,1675,1610, -1675,1611,1676, -1612,1676,1611, -1676,1612,1677, -1613,1677,1612, -1677,1613,1678, -1614,1678,1613, -1678,1614,1679, -1615,1679,1614, -1679,1615,1680, -1616,1680,1615, -1680,1616,1681, -1617,1681,1616, -1681,1617,1682, -1618,1682,1617, -1682,1618,1683, -1619,1683,1618, -1683,1619,1684, -1620,1684,1619, -1684,1620,1685, -1621,1685,1620, -1685,1621,1686, -1622,1686,1621, -1686,1622,1687, -1623,1687,1622, -1687,1623,1688, -1624,1688,1623, -1688,1624,1689, -1625,1689,1624, -1689,1625,1690, -1626,1690,1625, -1690,1626,1691, -1627,1691,1626, -1691,1627,1692, -1628,1692,1627, -1692,1628,1693, -1629,1693,1628, -1693,1629,1694, -1630,1694,1629, -1694,1630,1695, -1631,1695,1630, -1695,1631,1696, -1632,1696,1631, -1696,1632,1697, -1633,1697,1632, -1697,1633,1698, -1634,1698,1633, -1698,1634,1699, -1635,1699,1634, -1699,1635,1700, -1636,1700,1635, -1700,1636,1701, -1637,1701,1636, -1701,1637,1702, -1638,1702,1637, -1702,1638,1703, -1639,1703,1638, -1703,1639,1704, -1640,1704,1639, -1704,1640,1705, -1641,1705,1640, -1705,1641,1706, -1642,1706,1641, -1706,1642,1707, -1643,1707,1642, -1707,1643,1708, -1644,1708,1643, -1708,1644,1709, -1645,1709,1644, -1709,1645,1710, -1646,1710,1645, -1710,1646,1711, -1647,1711,1646, -1711,1647,1712, -1648,1712,1647, -1712,1648,1713, -1649,1713,1648, -1713,1649,1714, -1650,1714,1649, -1714,1650,1715, -1651,1715,1650, -1715,1651,1716, -1652,1716,1651, -1716,1652,1717, -1653,1717,1652, -1717,1653,1718, -1654,1718,1653, -1718,1654,1719, -1655,1719,1654, -1719,1655,1720, -1656,1720,1655, -1720,1656,1721, -1657,1721,1656, -1721,1657,1722, -1658,1722,1657, -1722,1658,1723, -1659,1723,1658, -1723,1659,1724, -1660,1724,1659, -1724,1660,1725, -1661,1725,1660, -1725,1661,1726, -1662,1726,1661, -1726,1662,1727, -1663,1727,1662, -1728,1664,1729, -1665,1729,1664, -1729,1665,1730, -1666,1730,1665, -1730,1666,1731, -1667,1731,1666, -1731,1667,1732, -1668,1732,1667, -1732,1668,1733, -1669,1733,1668, -1733,1669,1734, -1670,1734,1669, -1734,1670,1735, -1671,1735,1670, -1735,1671,1736, -1672,1736,1671, -1736,1672,1737, -1673,1737,1672, -1737,1673,1738, -1674,1738,1673, -1738,1674,1739, -1675,1739,1674, -1739,1675,1740, -1676,1740,1675, -1740,1676,1741, -1677,1741,1676, -1741,1677,1742, -1678,1742,1677, -1742,1678,1743, -1679,1743,1678, -1743,1679,1744, -1680,1744,1679, -1744,1680,1745, -1681,1745,1680, -1745,1681,1746, -1682,1746,1681, -1746,1682,1747, -1683,1747,1682, -1747,1683,1748, -1684,1748,1683, -1748,1684,1749, -1685,1749,1684, -1749,1685,1750, -1686,1750,1685, -1750,1686,1751, -1687,1751,1686, -1751,1687,1752, -1688,1752,1687, -1752,1688,1753, -1689,1753,1688, -1753,1689,1754, -1690,1754,1689, -1754,1690,1755, -1691,1755,1690, -1755,1691,1756, -1692,1756,1691, -1756,1692,1757, -1693,1757,1692, -1757,1693,1758, -1694,1758,1693, -1758,1694,1759, -1695,1759,1694, -1759,1695,1760, -1696,1760,1695, -1760,1696,1761, -1697,1761,1696, -1761,1697,1762, -1698,1762,1697, -1762,1698,1763, -1699,1763,1698, -1763,1699,1764, -1700,1764,1699, -1764,1700,1765, -1701,1765,1700, -1765,1701,1766, -1702,1766,1701, -1766,1702,1767, -1703,1767,1702, -1767,1703,1768, -1704,1768,1703, -1768,1704,1769, -1705,1769,1704, -1769,1705,1770, -1706,1770,1705, -1770,1706,1771, -1707,1771,1706, -1771,1707,1772, -1708,1772,1707, -1772,1708,1773, -1709,1773,1708, -1773,1709,1774, -1710,1774,1709, -1774,1710,1775, -1711,1775,1710, -1775,1711,1776, -1712,1776,1711, -1776,1712,1777, -1713,1777,1712, -1777,1713,1778, -1714,1778,1713, -1778,1714,1779, -1715,1779,1714, -1779,1715,1780, -1716,1780,1715, -1780,1716,1781, -1717,1781,1716, -1781,1717,1782, -1718,1782,1717, -1782,1718,1783, -1719,1783,1718, -1783,1719,1784, -1720,1784,1719, -1784,1720,1785, -1721,1785,1720, -1785,1721,1786, -1722,1786,1721, -1786,1722,1787, -1723,1787,1722, -1787,1723,1788, -1724,1788,1723, -1788,1724,1789, -1725,1789,1724, -1789,1725,1790, -1726,1790,1725, -1790,1726,1791, -1727,1791,1726, -1792,1728,1793, -1729,1793,1728, -1793,1729,1794, -1730,1794,1729, -1794,1730,1795, -1731,1795,1730, -1795,1731,1796, -1732,1796,1731, -1796,1732,1797, -1733,1797,1732, -1797,1733,1798, -1734,1798,1733, -1798,1734,1799, -1735,1799,1734, -1799,1735,1800, -1736,1800,1735, -1800,1736,1801, -1737,1801,1736, -1801,1737,1802, -1738,1802,1737, -1802,1738,1803, -1739,1803,1738, -1803,1739,1804, -1740,1804,1739, -1804,1740,1805, -1741,1805,1740, -1805,1741,1806, -1742,1806,1741, -1806,1742,1807, -1743,1807,1742, -1807,1743,1808, -1744,1808,1743, -1808,1744,1809, -1745,1809,1744, -1809,1745,1810, -1746,1810,1745, -1810,1746,1811, -1747,1811,1746, -1811,1747,1812, -1748,1812,1747, -1812,1748,1813, -1749,1813,1748, -1813,1749,1814, -1750,1814,1749, -1814,1750,1815, -1751,1815,1750, -1815,1751,1816, -1752,1816,1751, -1816,1752,1817, -1753,1817,1752, -1817,1753,1818, -1754,1818,1753, -1818,1754,1819, -1755,1819,1754, -1819,1755,1820, -1756,1820,1755, -1820,1756,1821, -1757,1821,1756, -1821,1757,1822, -1758,1822,1757, -1822,1758,1823, -1759,1823,1758, -1823,1759,1824, -1760,1824,1759, -1824,1760,1825, -1761,1825,1760, -1825,1761,1826, -1762,1826,1761, -1826,1762,1827, -1763,1827,1762, -1827,1763,1828, -1764,1828,1763, -1828,1764,1829, -1765,1829,1764, -1829,1765,1830, -1766,1830,1765, -1830,1766,1831, -1767,1831,1766, -1831,1767,1832, -1768,1832,1767, -1832,1768,1833, -1769,1833,1768, -1833,1769,1834, -1770,1834,1769, -1834,1770,1835, -1771,1835,1770, -1835,1771,1836, -1772,1836,1771, -1836,1772,1837, -1773,1837,1772, -1837,1773,1838, -1774,1838,1773, -1838,1774,1839, -1775,1839,1774, -1839,1775,1840, -1776,1840,1775, -1840,1776,1841, -1777,1841,1776, -1841,1777,1842, -1778,1842,1777, -1842,1778,1843, -1779,1843,1778, -1843,1779,1844, -1780,1844,1779, -1844,1780,1845, -1781,1845,1780, -1845,1781,1846, -1782,1846,1781, -1846,1782,1847, -1783,1847,1782, -1847,1783,1848, -1784,1848,1783, -1848,1784,1849, -1785,1849,1784, -1849,1785,1850, -1786,1850,1785, -1850,1786,1851, -1787,1851,1786, -1851,1787,1852, -1788,1852,1787, -1852,1788,1853, -1789,1853,1788, -1853,1789,1854, -1790,1854,1789, -1854,1790,1855, -1791,1855,1790, -1856,1792,1857, -1793,1857,1792, -1857,1793,1858, -1794,1858,1793, -1858,1794,1859, -1795,1859,1794, -1859,1795,1860, -1796,1860,1795, -1860,1796,1861, -1797,1861,1796, -1861,1797,1862, -1798,1862,1797, -1862,1798,1863, -1799,1863,1798, -1863,1799,1864, -1800,1864,1799, -1864,1800,1865, -1801,1865,1800, -1865,1801,1866, -1802,1866,1801, -1866,1802,1867, -1803,1867,1802, -1867,1803,1868, -1804,1868,1803, -1868,1804,1869, -1805,1869,1804, -1869,1805,1870, -1806,1870,1805, -1870,1806,1871, -1807,1871,1806, -1871,1807,1872, -1808,1872,1807, -1872,1808,1873, -1809,1873,1808, -1873,1809,1874, -1810,1874,1809, -1874,1810,1875, -1811,1875,1810, -1875,1811,1876, -1812,1876,1811, -1876,1812,1877, -1813,1877,1812, -1877,1813,1878, -1814,1878,1813, -1878,1814,1879, -1815,1879,1814, -1879,1815,1880, -1816,1880,1815, -1880,1816,1881, -1817,1881,1816, -1881,1817,1882, -1818,1882,1817, -1882,1818,1883, -1819,1883,1818, -1883,1819,1884, -1820,1884,1819, -1884,1820,1885, -1821,1885,1820, -1885,1821,1886, -1822,1886,1821, -1886,1822,1887, -1823,1887,1822, -1887,1823,1888, -1824,1888,1823, -1888,1824,1889, -1825,1889,1824, -1889,1825,1890, -1826,1890,1825, -1890,1826,1891, -1827,1891,1826, -1891,1827,1892, -1828,1892,1827, -1892,1828,1893, -1829,1893,1828, -1893,1829,1894, -1830,1894,1829, -1894,1830,1895, -1831,1895,1830, -1895,1831,1896, -1832,1896,1831, -1896,1832,1897, -1833,1897,1832, -1897,1833,1898, -1834,1898,1833, -1898,1834,1899, -1835,1899,1834, -1899,1835,1900, -1836,1900,1835, -1900,1836,1901, -1837,1901,1836, -1901,1837,1902, -1838,1902,1837, -1902,1838,1903, -1839,1903,1838, -1903,1839,1904, -1840,1904,1839, -1904,1840,1905, -1841,1905,1840, -1905,1841,1906, -1842,1906,1841, -1906,1842,1907, -1843,1907,1842, -1907,1843,1908, -1844,1908,1843, -1908,1844,1909, -1845,1909,1844, -1909,1845,1910, -1846,1910,1845, -1910,1846,1911, -1847,1911,1846, -1911,1847,1912, -1848,1912,1847, -1912,1848,1913, -1849,1913,1848, -1913,1849,1914, -1850,1914,1849, -1914,1850,1915, -1851,1915,1850, -1915,1851,1916, -1852,1916,1851, -1916,1852,1917, -1853,1917,1852, -1917,1853,1918, -1854,1918,1853, -1918,1854,1919, -1855,1919,1854, -1920,1856,1921, -1857,1921,1856, -1921,1857,1922, -1858,1922,1857, -1922,1858,1923, -1859,1923,1858, -1923,1859,1924, -1860,1924,1859, -1924,1860,1925, -1861,1925,1860, -1925,1861,1926, -1862,1926,1861, -1926,1862,1927, -1863,1927,1862, -1927,1863,1928, -1864,1928,1863, -1928,1864,1929, -1865,1929,1864, -1929,1865,1930, -1866,1930,1865, -1930,1866,1931, -1867,1931,1866, -1931,1867,1932, -1868,1932,1867, -1932,1868,1933, -1869,1933,1868, -1933,1869,1934, -1870,1934,1869, -1934,1870,1935, -1871,1935,1870, -1935,1871,1936, -1872,1936,1871, -1936,1872,1937, -1873,1937,1872, -1937,1873,1938, -1874,1938,1873, -1938,1874,1939, -1875,1939,1874, -1939,1875,1940, -1876,1940,1875, -1940,1876,1941, -1877,1941,1876, -1941,1877,1942, -1878,1942,1877, -1942,1878,1943, -1879,1943,1878, -1943,1879,1944, -1880,1944,1879, -1944,1880,1945, -1881,1945,1880, -1945,1881,1946, -1882,1946,1881, -1946,1882,1947, -1883,1947,1882, -1947,1883,1948, -1884,1948,1883, -1948,1884,1949, -1885,1949,1884, -1949,1885,1950, -1886,1950,1885, -1950,1886,1951, -1887,1951,1886, -1951,1887,1952, -1888,1952,1887, -1952,1888,1953, -1889,1953,1888, -1953,1889,1954, -1890,1954,1889, -1954,1890,1955, -1891,1955,1890, -1955,1891,1956, -1892,1956,1891, -1956,1892,1957, -1893,1957,1892, -1957,1893,1958, -1894,1958,1893, -1958,1894,1959, -1895,1959,1894, -1959,1895,1960, -1896,1960,1895, -1960,1896,1961, -1897,1961,1896, -1961,1897,1962, -1898,1962,1897, -1962,1898,1963, -1899,1963,1898, -1963,1899,1964, -1900,1964,1899, -1964,1900,1965, -1901,1965,1900, -1965,1901,1966, -1902,1966,1901, -1966,1902,1967, -1903,1967,1902, -1967,1903,1968, -1904,1968,1903, -1968,1904,1969, -1905,1969,1904, -1969,1905,1970, -1906,1970,1905, -1970,1906,1971, -1907,1971,1906, -1971,1907,1972, -1908,1972,1907, -1972,1908,1973, -1909,1973,1908, -1973,1909,1974, -1910,1974,1909, -1974,1910,1975, -1911,1975,1910, -1975,1911,1976, -1912,1976,1911, -1976,1912,1977, -1913,1977,1912, -1977,1913,1978, -1914,1978,1913, -1978,1914,1979, -1915,1979,1914, -1979,1915,1980, -1916,1980,1915, -1980,1916,1981, -1917,1981,1916, -1981,1917,1982, -1918,1982,1917, -1982,1918,1983, -1919,1983,1918, -1984,1920,1985, -1921,1985,1920, -1985,1921,1986, -1922,1986,1921, -1986,1922,1987, -1923,1987,1922, -1987,1923,1988, -1924,1988,1923, -1988,1924,1989, -1925,1989,1924, -1989,1925,1990, -1926,1990,1925, -1990,1926,1991, -1927,1991,1926, -1991,1927,1992, -1928,1992,1927, -1992,1928,1993, -1929,1993,1928, -1993,1929,1994, -1930,1994,1929, -1994,1930,1995, -1931,1995,1930, -1995,1931,1996, -1932,1996,1931, -1996,1932,1997, -1933,1997,1932, -1997,1933,1998, -1934,1998,1933, -1998,1934,1999, -1935,1999,1934, -1999,1935,2000, -1936,2000,1935, -2000,1936,2001, -1937,2001,1936, -2001,1937,2002, -1938,2002,1937, -2002,1938,2003, -1939,2003,1938, -2003,1939,2004, -1940,2004,1939, -2004,1940,2005, -1941,2005,1940, -2005,1941,2006, -1942,2006,1941, -2006,1942,2007, -1943,2007,1942, -2007,1943,2008, -1944,2008,1943, -2008,1944,2009, -1945,2009,1944, -2009,1945,2010, -1946,2010,1945, -2010,1946,2011, -1947,2011,1946, -2011,1947,2012, -1948,2012,1947, -2012,1948,2013, -1949,2013,1948, -2013,1949,2014, -1950,2014,1949, -2014,1950,2015, -1951,2015,1950, -2015,1951,2016, -1952,2016,1951, -2016,1952,2017, -1953,2017,1952, -2017,1953,2018, -1954,2018,1953, -2018,1954,2019, -1955,2019,1954, -2019,1955,2020, -1956,2020,1955, -2020,1956,2021, -1957,2021,1956, -2021,1957,2022, -1958,2022,1957, -2022,1958,2023, -1959,2023,1958, -2023,1959,2024, -1960,2024,1959, -2024,1960,2025, -1961,2025,1960, -2025,1961,2026, -1962,2026,1961, -2026,1962,2027, -1963,2027,1962, -2027,1963,2028, -1964,2028,1963, -2028,1964,2029, -1965,2029,1964, -2029,1965,2030, -1966,2030,1965, -2030,1966,2031, -1967,2031,1966, -2031,1967,2032, -1968,2032,1967, -2032,1968,2033, -1969,2033,1968, -2033,1969,2034, -1970,2034,1969, -2034,1970,2035, -1971,2035,1970, -2035,1971,2036, -1972,2036,1971, -2036,1972,2037, -1973,2037,1972, -2037,1973,2038, -1974,2038,1973, -2038,1974,2039, -1975,2039,1974, -2039,1975,2040, -1976,2040,1975, -2040,1976,2041, -1977,2041,1976, -2041,1977,2042, -1978,2042,1977, -2042,1978,2043, -1979,2043,1978, -2043,1979,2044, -1980,2044,1979, -2044,1980,2045, -1981,2045,1980, -2045,1981,2046, -1982,2046,1981, -2046,1982,2047, -1983,2047,1982, -2048,1984,2049, -1985,2049,1984, -2049,1985,2050, -1986,2050,1985, -2050,1986,2051, -1987,2051,1986, -2051,1987,2052, -1988,2052,1987, -2052,1988,2053, -1989,2053,1988, -2053,1989,2054, -1990,2054,1989, -2054,1990,2055, -1991,2055,1990, -2055,1991,2056, -1992,2056,1991, -2056,1992,2057, -1993,2057,1992, -2057,1993,2058, -1994,2058,1993, -2058,1994,2059, -1995,2059,1994, -2059,1995,2060, -1996,2060,1995, -2060,1996,2061, -1997,2061,1996, -2061,1997,2062, -1998,2062,1997, -2062,1998,2063, -1999,2063,1998, -2063,1999,2064, -2000,2064,1999, -2064,2000,2065, -2001,2065,2000, -2065,2001,2066, -2002,2066,2001, -2066,2002,2067, -2003,2067,2002, -2067,2003,2068, -2004,2068,2003, -2068,2004,2069, -2005,2069,2004, -2069,2005,2070, -2006,2070,2005, -2070,2006,2071, -2007,2071,2006, -2071,2007,2072, -2008,2072,2007, -2072,2008,2073, -2009,2073,2008, -2073,2009,2074, -2010,2074,2009, -2074,2010,2075, -2011,2075,2010, -2075,2011,2076, -2012,2076,2011, -2076,2012,2077, -2013,2077,2012, -2077,2013,2078, -2014,2078,2013, -2078,2014,2079, -2015,2079,2014, -2079,2015,2080, -2016,2080,2015, -2080,2016,2081, -2017,2081,2016, -2081,2017,2082, -2018,2082,2017, -2082,2018,2083, -2019,2083,2018, -2083,2019,2084, -2020,2084,2019, -2084,2020,2085, -2021,2085,2020, -2085,2021,2086, -2022,2086,2021, -2086,2022,2087, -2023,2087,2022, -2087,2023,2088, -2024,2088,2023, -2088,2024,2089, -2025,2089,2024, -2089,2025,2090, -2026,2090,2025, -2090,2026,2091, -2027,2091,2026, -2091,2027,2092, -2028,2092,2027, -2092,2028,2093, -2029,2093,2028, -2093,2029,2094, -2030,2094,2029, -2094,2030,2095, -2031,2095,2030, -2095,2031,2096, -2032,2096,2031, -2096,2032,2097, -2033,2097,2032, -2097,2033,2098, -2034,2098,2033, -2098,2034,2099, -2035,2099,2034, -2099,2035,2100, -2036,2100,2035, -2100,2036,2101, -2037,2101,2036, -2101,2037,2102, -2038,2102,2037, -2102,2038,2103, -2039,2103,2038, -2103,2039,2104, -2040,2104,2039, -2104,2040,2105, -2041,2105,2040, -2105,2041,2106, -2042,2106,2041, -2106,2042,2107, -2043,2107,2042, -2107,2043,2108, -2044,2108,2043, -2108,2044,2109, -2045,2109,2044, -2109,2045,2110, -2046,2110,2045, -2110,2046,2111, -2047,2111,2046, -2112,2048,2113, -2049,2113,2048, -2113,2049,2114, -2050,2114,2049, -2114,2050,2115, -2051,2115,2050, -2115,2051,2116, -2052,2116,2051, -2116,2052,2117, -2053,2117,2052, -2117,2053,2118, -2054,2118,2053, -2118,2054,2119, -2055,2119,2054, -2119,2055,2120, -2056,2120,2055, -2120,2056,2121, -2057,2121,2056, -2121,2057,2122, -2058,2122,2057, -2122,2058,2123, -2059,2123,2058, -2123,2059,2124, -2060,2124,2059, -2124,2060,2125, -2061,2125,2060, -2125,2061,2126, -2062,2126,2061, -2126,2062,2127, -2063,2127,2062, -2127,2063,2128, -2064,2128,2063, -2128,2064,2129, -2065,2129,2064, -2129,2065,2130, -2066,2130,2065, -2130,2066,2131, -2067,2131,2066, -2131,2067,2132, -2068,2132,2067, -2132,2068,2133, -2069,2133,2068, -2133,2069,2134, -2070,2134,2069, -2134,2070,2135, -2071,2135,2070, -2135,2071,2136, -2072,2136,2071, -2136,2072,2137, -2073,2137,2072, -2137,2073,2138, -2074,2138,2073, -2138,2074,2139, -2075,2139,2074, -2139,2075,2140, -2076,2140,2075, -2140,2076,2141, -2077,2141,2076, -2141,2077,2142, -2078,2142,2077, -2142,2078,2143, -2079,2143,2078, -2143,2079,2144, -2080,2144,2079, -2144,2080,2145, -2081,2145,2080, -2145,2081,2146, -2082,2146,2081, -2146,2082,2147, -2083,2147,2082, -2147,2083,2148, -2084,2148,2083, -2148,2084,2149, -2085,2149,2084, -2149,2085,2150, -2086,2150,2085, -2150,2086,2151, -2087,2151,2086, -2151,2087,2152, -2088,2152,2087, -2152,2088,2153, -2089,2153,2088, -2153,2089,2154, -2090,2154,2089, -2154,2090,2155, -2091,2155,2090, -2155,2091,2156, -2092,2156,2091, -2156,2092,2157, -2093,2157,2092, -2157,2093,2158, -2094,2158,2093, -2158,2094,2159, -2095,2159,2094, -2159,2095,2160, -2096,2160,2095, -2160,2096,2161, -2097,2161,2096, -2161,2097,2162, -2098,2162,2097, -2162,2098,2163, -2099,2163,2098, -2163,2099,2164, -2100,2164,2099, -2164,2100,2165, -2101,2165,2100, -2165,2101,2166, -2102,2166,2101, -2166,2102,2167, -2103,2167,2102, -2167,2103,2168, -2104,2168,2103, -2168,2104,2169, -2105,2169,2104, -2169,2105,2170, -2106,2170,2105, -2170,2106,2171, -2107,2171,2106, -2171,2107,2172, -2108,2172,2107, -2172,2108,2173, -2109,2173,2108, -2173,2109,2174, -2110,2174,2109, -2174,2110,2175, -2111,2175,2110, -2176,2112,2177, -2113,2177,2112, -2177,2113,2178, -2114,2178,2113, -2178,2114,2179, -2115,2179,2114, -2179,2115,2180, -2116,2180,2115, -2180,2116,2181, -2117,2181,2116, -2181,2117,2182, -2118,2182,2117, -2182,2118,2183, -2119,2183,2118, -2183,2119,2184, -2120,2184,2119, -2184,2120,2185, -2121,2185,2120, -2185,2121,2186, -2122,2186,2121, -2186,2122,2187, -2123,2187,2122, -2187,2123,2188, -2124,2188,2123, -2188,2124,2189, -2125,2189,2124, -2189,2125,2190, -2126,2190,2125, -2190,2126,2191, -2127,2191,2126, -2191,2127,2192, -2128,2192,2127, -2192,2128,2193, -2129,2193,2128, -2193,2129,2194, -2130,2194,2129, -2194,2130,2195, -2131,2195,2130, -2195,2131,2196, -2132,2196,2131, -2196,2132,2197, -2133,2197,2132, -2197,2133,2198, -2134,2198,2133, -2198,2134,2199, -2135,2199,2134, -2199,2135,2200, -2136,2200,2135, -2200,2136,2201, -2137,2201,2136, -2201,2137,2202, -2138,2202,2137, -2202,2138,2203, -2139,2203,2138, -2203,2139,2204, -2140,2204,2139, -2204,2140,2205, -2141,2205,2140, -2205,2141,2206, -2142,2206,2141, -2206,2142,2207, -2143,2207,2142, -2207,2143,2208, -2144,2208,2143, -2208,2144,2209, -2145,2209,2144, -2209,2145,2210, -2146,2210,2145, -2210,2146,2211, -2147,2211,2146, -2211,2147,2212, -2148,2212,2147, -2212,2148,2213, -2149,2213,2148, -2213,2149,2214, -2150,2214,2149, -2214,2150,2215, -2151,2215,2150, -2215,2151,2216, -2152,2216,2151, -2216,2152,2217, -2153,2217,2152, -2217,2153,2218, -2154,2218,2153, -2218,2154,2219, -2155,2219,2154, -2219,2155,2220, -2156,2220,2155, -2220,2156,2221, -2157,2221,2156, -2221,2157,2222, -2158,2222,2157, -2222,2158,2223, -2159,2223,2158, -2223,2159,2224, -2160,2224,2159, -2224,2160,2225, -2161,2225,2160, -2225,2161,2226, -2162,2226,2161, -2226,2162,2227, -2163,2227,2162, -2227,2163,2228, -2164,2228,2163, -2228,2164,2229, -2165,2229,2164, -2229,2165,2230, -2166,2230,2165, -2230,2166,2231, -2167,2231,2166, -2231,2167,2232, -2168,2232,2167, -2232,2168,2233, -2169,2233,2168, -2233,2169,2234, -2170,2234,2169, -2234,2170,2235, -2171,2235,2170, -2235,2171,2236, -2172,2236,2171, -2236,2172,2237, -2173,2237,2172, -2237,2173,2238, -2174,2238,2173, -2238,2174,2239, -2175,2239,2174, -}; - -#define Landscape08VtxCount 2178 -#define Landscape08IdxCount 12480 - -btScalar Landscape08Vtx[] = { --250.0f,30.98f,-128.906f, --250.0f,31.4025f,-125.0f, --246.094f,31.7629f,-128.906f, --246.094f,31.4165f,-125.0f, --242.188f,32.5689f,-128.906f, --242.188f,32.314f,-125.0f, --238.281f,32.9125f,-128.906f, --238.281f,32.9822f,-125.0f, --234.375f,32.5915f,-128.906f, --234.375f,32.6962f,-125.0f, --230.469f,31.2708f,-128.906f, --230.469f,31.3632f,-125.0f, --226.563f,30.5212f,-128.906f, --226.563f,29.4391f,-125.0f, --222.656f,30.2031f,-128.906f, --222.656f,29.519f,-125.0f, --218.75f,30.4582f,-128.906f, --218.75f,29.4481f,-125.0f, --214.844f,30.6941f,-128.906f, --214.844f,29.8481f,-125.0f, --210.938f,30.5035f,-128.906f, --210.938f,30.408f,-125.0f, --207.031f,30.2726f,-128.906f, --207.031f,30.291f,-125.0f, --203.125f,29.38f,-128.906f, --203.125f,28.7473f,-125.0f, --199.219f,28.6973f,-128.906f, --199.219f,28.1816f,-125.0f, --195.313f,27.9768f,-128.906f, --195.313f,27.2839f,-125.0f, --191.406f,26.1169f,-128.906f, --191.406f,25.7018f,-125.0f, --187.5f,23.8648f,-128.906f, --187.5f,23.2882f,-125.0f, --183.594f,21.95f,-128.906f, --183.594f,22.1614f,-125.0f, --179.688f,19.6798f,-128.906f, --179.688f,20.658f,-125.0f, --175.781f,17.3507f,-128.906f, --175.781f,18.8433f,-125.0f, --171.875f,15.7914f,-128.906f, --171.875f,16.364f,-125.0f, --167.969f,14.3745f,-128.906f, --167.969f,14.7298f,-125.0f, --164.063f,12.4911f,-128.906f, --164.063f,12.9859f,-125.0f, --160.156f,11.0533f,-128.906f, --160.156f,11.3306f,-125.0f, --156.25f,9.15062f,-128.906f, --156.25f,10.1916f,-125.0f, --152.344f,6.68059f,-128.906f, --152.344f,8.3967f,-125.0f, --148.438f,5.57112f,-128.906f, --148.438f,6.23292f,-125.0f, --144.531f,5.2271f,-128.906f, --144.531f,5.48985f,-125.0f, --140.625f,5.87576f,-128.906f, --140.625f,5.18276f,-125.0f, --136.719f,6.85614f,-128.906f, --136.719f,5.56059f,-125.0f, --132.813f,6.86087f,-128.906f, --132.813f,5.75157f,-125.0f, --128.906f,7.10341f,-128.906f, --128.906f,5.32154f,-125.0f, --125.0f,7.54727f,-128.906f, --125.0f,6.15672f,-125.0f, --121.094f,8.02225f,-128.906f, --121.094f,7.53373f,-125.0f, --117.188f,8.70065f,-128.906f, --117.188f,8.38676f,-125.0f, --113.281f,9.39689f,-128.906f, --113.281f,8.64274f,-125.0f, --109.375f,8.80449f,-128.906f, --109.375f,8.49941f,-125.0f, --105.469f,9.43366f,-128.906f, --105.469f,9.24481f,-125.0f, --101.563f,10.868f,-128.906f, --101.563f,11.5178f,-125.0f, --97.6563f,12.8404f,-128.906f, --97.6563f,13.4113f,-125.0f, --93.75f,14.8214f,-128.906f, --93.75f,15.4997f,-125.0f, --89.8438f,16.618f,-128.906f, --89.8438f,17.3502f,-125.0f, --85.9375f,20.2496f,-128.906f, --85.9375f,20.8168f,-125.0f, --82.0313f,23.697f,-128.906f, --82.0313f,24.9405f,-125.0f, --78.125f,26.4451f,-128.906f, --78.125f,27.8681f,-125.0f, --74.2188f,28.7901f,-128.906f, --74.2188f,30.1495f,-125.0f, --70.3125f,31.4052f,-128.906f, --70.3125f,32.4402f,-125.0f, --66.4063f,33.3106f,-128.906f, --66.4063f,34.2537f,-125.0f, --62.5f,35.8538f,-128.906f, --62.5f,36.5623f,-125.0f, --58.5938f,37.9798f,-128.906f, --58.5938f,38.9027f,-125.0f, --54.6875f,39.4006f,-128.906f, --54.6875f,40.1192f,-125.0f, --50.7813f,40.6584f,-128.906f, --50.7813f,41.9393f,-125.0f, --46.875f,40.8896f,-128.906f, --46.875f,41.8765f,-125.0f, --42.9688f,39.9544f,-128.906f, --42.9688f,41.6371f,-125.0f, --39.0625f,40.0893f,-128.906f, --39.0625f,41.6432f,-125.0f, --35.1563f,39.3183f,-128.906f, --35.1563f,41.2852f,-125.0f, --31.25f,39.8575f,-128.906f, --31.25f,41.5629f,-125.0f, --27.3438f,41.5378f,-128.906f, --27.3438f,42.2956f,-125.0f, --23.4375f,44.0561f,-128.906f, --23.4375f,43.9719f,-125.0f, --19.5313f,45.4298f,-128.906f, --19.5313f,46.2232f,-125.0f, --15.625f,47.4474f,-128.906f, --15.625f,47.3104f,-125.0f, --11.7188f,48.0018f,-128.906f, --11.7188f,47.5943f,-125.0f, --7.8125f,48.0717f,-128.906f, --7.8125f,49.1192f,-125.0f, --3.90625f,48.7253f,-128.906f, --3.90625f,49.6341f,-125.0f, -0.0f,49.8f,-128.906f, -0.0f,50.3481f,-125.0f, -3.90625f,50.4716f,-128.906f, -3.90625f,50.3021f,-125.0f, --250.0f,31.1145f,-132.813f, --246.094f,31.857f,-132.813f, --242.188f,32.7446f,-132.813f, --238.281f,33.1734f,-132.813f, --234.375f,32.1952f,-132.813f, --230.469f,31.8959f,-132.813f, --226.563f,32.1326f,-132.813f, --222.656f,32.1631f,-132.813f, --218.75f,31.3795f,-132.813f, --214.844f,30.9888f,-132.813f, --210.938f,30.5577f,-132.813f, --207.031f,30.1392f,-132.813f, --203.125f,29.8482f,-132.813f, --199.219f,28.5903f,-132.813f, --195.313f,27.4671f,-132.813f, --191.406f,25.5032f,-132.813f, --187.5f,23.2799f,-132.813f, --183.594f,21.2846f,-132.813f, --179.688f,19.3954f,-132.813f, --175.781f,18.1112f,-132.813f, --171.875f,16.3831f,-132.813f, --167.969f,14.5038f,-132.813f, --164.063f,12.8109f,-132.813f, --160.156f,10.386f,-132.813f, --156.25f,7.93486f,-132.813f, --152.344f,7.25449f,-132.813f, --148.438f,6.19974f,-132.813f, --144.531f,5.89578f,-132.813f, --140.625f,6.61884f,-132.813f, --136.719f,7.53382f,-132.813f, --132.813f,8.21024f,-132.813f, --128.906f,8.74115f,-132.813f, --125.0f,8.97047f,-132.813f, --121.094f,9.41307f,-132.813f, --117.188f,10.0468f,-132.813f, --113.281f,9.47404f,-132.813f, --109.375f,9.418f,-132.813f, --105.469f,10.3176f,-132.813f, --101.563f,11.3001f,-132.813f, --97.6563f,12.5318f,-132.813f, --93.75f,14.6986f,-132.813f, --89.8438f,16.6495f,-132.813f, --85.9375f,19.1906f,-132.813f, --82.0313f,23.4349f,-132.813f, --78.125f,26.1629f,-132.813f, --74.2188f,28.739f,-132.813f, --70.3125f,31.1271f,-132.813f, --66.4063f,32.2452f,-132.813f, --62.5f,34.0303f,-132.813f, --58.5938f,36.1234f,-132.813f, --54.6875f,38.3054f,-132.813f, --50.7813f,38.7936f,-132.813f, --46.875f,39.1319f,-132.813f, --42.9688f,39.1462f,-132.813f, --39.0625f,38.4732f,-132.813f, --35.1563f,38.3061f,-132.813f, --31.25f,39.4999f,-132.813f, --27.3438f,41.8953f,-132.813f, --23.4375f,43.2645f,-132.813f, --19.5313f,44.7736f,-132.813f, --15.625f,46.2491f,-132.813f, --11.7188f,47.4527f,-132.813f, --7.8125f,47.1407f,-132.813f, --3.90625f,48.0628f,-132.813f, -0.0f,48.5651f,-132.813f, -3.90625f,49.1054f,-132.813f, --250.0f,30.7461f,-136.719f, --246.094f,30.8483f,-136.719f, --242.188f,32.188f,-136.719f, --238.281f,33.149f,-136.719f, --234.375f,32.3165f,-136.719f, --230.469f,32.613f,-136.719f, --226.563f,33.3246f,-136.719f, --222.656f,32.6429f,-136.719f, --218.75f,31.8882f,-136.719f, --214.844f,31.5125f,-136.719f, --210.938f,30.2065f,-136.719f, --207.031f,30.0024f,-136.719f, --203.125f,29.5699f,-136.719f, --199.219f,28.1245f,-136.719f, --195.313f,26.764f,-136.719f, --191.406f,24.8025f,-136.719f, --187.5f,22.7863f,-136.719f, --183.594f,21.0979f,-136.719f, --179.688f,19.5742f,-136.719f, --175.781f,17.9263f,-136.719f, --171.875f,16.0908f,-136.719f, --167.969f,14.6542f,-136.719f, --164.063f,12.4534f,-136.719f, --160.156f,9.93763f,-136.719f, --156.25f,7.87486f,-136.719f, --152.344f,7.06627f,-136.719f, --148.438f,6.22453f,-136.719f, --144.531f,6.39864f,-136.719f, --140.625f,7.02103f,-136.719f, --136.719f,7.85488f,-136.719f, --132.813f,9.33235f,-136.719f, --128.906f,10.546f,-136.719f, --125.0f,10.1958f,-136.719f, --121.094f,9.85385f,-136.719f, --117.188f,10.2437f,-136.719f, --113.281f,9.95341f,-136.719f, --109.375f,9.05387f,-136.719f, --105.469f,10.3384f,-136.719f, --101.563f,11.2859f,-136.719f, --97.6563f,12.3544f,-136.719f, --93.75f,14.0582f,-136.719f, --89.8438f,15.9772f,-136.719f, --85.9375f,18.8673f,-136.719f, --82.0313f,22.2278f,-136.719f, --78.125f,25.0468f,-136.719f, --74.2188f,27.6452f,-136.719f, --70.3125f,29.155f,-136.719f, --66.4063f,30.7457f,-136.719f, --62.5f,32.6722f,-136.719f, --58.5938f,34.5222f,-136.719f, --54.6875f,36.3904f,-136.719f, --50.7813f,36.1946f,-136.719f, --46.875f,36.5194f,-136.719f, --42.9688f,36.2715f,-136.719f, --39.0625f,36.4185f,-136.719f, --35.1563f,37.1668f,-136.719f, --31.25f,38.3933f,-136.719f, --27.3438f,40.8416f,-136.719f, --23.4375f,42.7243f,-136.719f, --19.5313f,43.7567f,-136.719f, --15.625f,44.7705f,-136.719f, --11.7188f,45.3267f,-136.719f, --7.8125f,46.433f,-136.719f, --3.90625f,47.3134f,-136.719f, -0.0f,48.4146f,-136.719f, -3.90625f,47.9f,-136.719f, --250.0f,29.1575f,-140.625f, --246.094f,30.5173f,-140.625f, --242.188f,31.576f,-140.625f, --238.281f,31.6992f,-140.625f, --234.375f,32.9063f,-140.625f, --230.469f,33.2752f,-140.625f, --226.563f,32.8003f,-140.625f, --222.656f,33.133f,-140.625f, --218.75f,32.0543f,-140.625f, --214.844f,31.2672f,-140.625f, --210.938f,30.2378f,-140.625f, --207.031f,29.601f,-140.625f, --203.125f,28.4643f,-140.625f, --199.219f,26.8711f,-140.625f, --195.313f,24.936f,-140.625f, --191.406f,22.9115f,-140.625f, --187.5f,21.8507f,-140.625f, --183.594f,20.4435f,-140.625f, --179.688f,18.4455f,-140.625f, --175.781f,17.1667f,-140.625f, --171.875f,15.2077f,-140.625f, --167.969f,13.4799f,-140.625f, --164.063f,11.7723f,-140.625f, --160.156f,9.26955f,-140.625f, --156.25f,7.56528f,-140.625f, --152.344f,6.4244f,-140.625f, --148.438f,6.60539f,-140.625f, --144.531f,6.44163f,-140.625f, --140.625f,6.55017f,-140.625f, --136.719f,7.62805f,-140.625f, --132.813f,9.20726f,-140.625f, --128.906f,10.5063f,-140.625f, --125.0f,10.6867f,-140.625f, --121.094f,9.3702f,-140.625f, --117.188f,9.53484f,-140.625f, --113.281f,8.855f,-140.625f, --109.375f,9.3082f,-140.625f, --105.469f,9.67718f,-140.625f, --101.563f,10.5233f,-140.625f, --97.6563f,11.8026f,-140.625f, --93.75f,13.1675f,-140.625f, --89.8438f,15.253f,-140.625f, --85.9375f,18.1074f,-140.625f, --82.0313f,20.8004f,-140.625f, --78.125f,23.7651f,-140.625f, --74.2188f,25.7067f,-140.625f, --70.3125f,27.5126f,-140.625f, --66.4063f,29.8191f,-140.625f, --62.5f,31.7367f,-140.625f, --58.5938f,32.8891f,-140.625f, --54.6875f,34.0989f,-140.625f, --50.7813f,34.6645f,-140.625f, --46.875f,34.0325f,-140.625f, --42.9688f,33.7773f,-140.625f, --39.0625f,34.1723f,-140.625f, --35.1563f,36.0861f,-140.625f, --31.25f,38.8562f,-140.625f, --27.3438f,40.5684f,-140.625f, --23.4375f,42.6832f,-140.625f, --19.5313f,43.505f,-140.625f, --15.625f,43.7197f,-140.625f, --11.7188f,43.8656f,-140.625f, --7.8125f,45.6272f,-140.625f, --3.90625f,46.7713f,-140.625f, -0.0f,47.1255f,-140.625f, -3.90625f,47.2681f,-140.625f, --250.0f,28.3388f,-144.531f, --246.094f,29.5689f,-144.531f, --242.188f,30.0422f,-144.531f, --238.281f,30.6319f,-144.531f, --234.375f,32.5914f,-144.531f, --230.469f,33.306f,-144.531f, --226.563f,32.9265f,-144.531f, --222.656f,32.5363f,-144.531f, --218.75f,31.8845f,-144.531f, --214.844f,31.7429f,-144.531f, --210.938f,29.6521f,-144.531f, --207.031f,28.3301f,-144.531f, --203.125f,26.8166f,-144.531f, --199.219f,25.0756f,-144.531f, --195.313f,23.0988f,-144.531f, --191.406f,21.2037f,-144.531f, --187.5f,20.271f,-144.531f, --183.594f,18.4189f,-144.531f, --179.688f,16.2352f,-144.531f, --175.781f,14.734f,-144.531f, --171.875f,13.9522f,-144.531f, --167.969f,12.543f,-144.531f, --164.063f,10.6335f,-144.531f, --160.156f,8.53885f,-144.531f, --156.25f,7.32299f,-144.531f, --152.344f,6.69849f,-144.531f, --148.438f,5.37792f,-144.531f, --144.531f,5.52557f,-144.531f, --140.625f,5.94721f,-144.531f, --136.719f,7.15949f,-144.531f, --132.813f,8.5533f,-144.531f, --128.906f,9.68048f,-144.531f, --125.0f,9.80421f,-144.531f, --121.094f,9.67052f,-144.531f, --117.188f,9.82889f,-144.531f, --113.281f,9.40895f,-144.531f, --109.375f,9.53728f,-144.531f, --105.469f,9.89567f,-144.531f, --101.563f,10.4472f,-144.531f, --97.6563f,11.3813f,-144.531f, --93.75f,13.6687f,-144.531f, --89.8438f,15.6897f,-144.531f, --85.9375f,17.6694f,-144.531f, --82.0313f,20.0542f,-144.531f, --78.125f,22.2881f,-144.531f, --74.2188f,24.021f,-144.531f, --70.3125f,26.6221f,-144.531f, --66.4063f,28.7647f,-144.531f, --62.5f,31.0025f,-144.531f, --58.5938f,31.9212f,-144.531f, --54.6875f,32.1124f,-144.531f, --50.7813f,33.4656f,-144.531f, --46.875f,33.5412f,-144.531f, --42.9688f,33.5562f,-144.531f, --39.0625f,34.3563f,-144.531f, --35.1563f,36.2482f,-144.531f, --31.25f,37.99f,-144.531f, --27.3438f,40.3527f,-144.531f, --23.4375f,42.4204f,-144.531f, --19.5313f,44.0f,-144.531f, --15.625f,44.183f,-144.531f, --11.7188f,44.0185f,-144.531f, --7.8125f,45.08f,-144.531f, --3.90625f,45.5784f,-144.531f, -0.0f,44.8122f,-144.531f, -3.90625f,45.2398f,-144.531f, --250.0f,27.5165f,-148.438f, --246.094f,28.4707f,-148.438f, --242.188f,28.8693f,-148.438f, --238.281f,29.8936f,-148.438f, --234.375f,30.9982f,-148.438f, --230.469f,31.9158f,-148.438f, --226.563f,33.0887f,-148.438f, --222.656f,32.141f,-148.438f, --218.75f,31.0388f,-148.438f, --214.844f,30.5599f,-148.438f, --210.938f,29.1269f,-148.438f, --207.031f,26.6179f,-148.438f, --203.125f,25.2859f,-148.438f, --199.219f,23.1182f,-148.438f, --195.313f,21.139f,-148.438f, --191.406f,19.7044f,-148.438f, --187.5f,18.4387f,-148.438f, --183.594f,17.6363f,-148.438f, --179.688f,15.8724f,-148.438f, --175.781f,14.454f,-148.438f, --171.875f,13.2052f,-148.438f, --167.969f,11.7702f,-148.438f, --164.063f,10.4965f,-148.438f, --160.156f,8.29165f,-148.438f, --156.25f,7.24803f,-148.438f, --152.344f,6.79621f,-148.438f, --148.438f,5.48372f,-148.438f, --144.531f,4.11362f,-148.438f, --140.625f,4.6586f,-148.438f, --136.719f,6.20081f,-148.438f, --132.813f,7.67687f,-148.438f, --128.906f,9.0742f,-148.438f, --125.0f,8.8028f,-148.438f, --121.094f,9.309f,-148.438f, --117.188f,9.26616f,-148.438f, --113.281f,9.88711f,-148.438f, --109.375f,9.19023f,-148.438f, --105.469f,9.46828f,-148.438f, --101.563f,10.1584f,-148.438f, --97.6563f,11.2649f,-148.438f, --93.75f,13.476f,-148.438f, --89.8438f,15.8318f,-148.438f, --85.9375f,17.6136f,-148.438f, --82.0313f,18.7495f,-148.438f, --78.125f,20.5385f,-148.438f, --74.2188f,23.5666f,-148.438f, --70.3125f,26.2836f,-148.438f, --66.4063f,28.729f,-148.438f, --62.5f,30.3854f,-148.438f, --58.5938f,30.9909f,-148.438f, --54.6875f,31.4288f,-148.438f, --50.7813f,31.916f,-148.438f, --46.875f,32.4745f,-148.438f, --42.9688f,32.0881f,-148.438f, --39.0625f,34.0231f,-148.438f, --35.1563f,35.6432f,-148.438f, --31.25f,37.6278f,-148.438f, --27.3438f,39.652f,-148.438f, --23.4375f,42.3336f,-148.438f, --19.5313f,43.3336f,-148.438f, --15.625f,43.9329f,-148.438f, --11.7188f,43.8742f,-148.438f, --7.8125f,44.336f,-148.438f, --3.90625f,44.2738f,-148.438f, -0.0f,42.6429f,-148.438f, -3.90625f,43.4167f,-148.438f, --250.0f,27.7654f,-152.344f, --246.094f,28.2588f,-152.344f, --242.188f,28.0365f,-152.344f, --238.281f,29.4531f,-152.344f, --234.375f,31.8507f,-152.344f, --230.469f,31.9987f,-152.344f, --226.563f,32.2635f,-152.344f, --222.656f,32.4573f,-152.344f, --218.75f,30.3791f,-152.344f, --214.844f,29.1133f,-152.344f, --210.938f,27.6466f,-152.344f, --207.031f,25.5524f,-152.344f, --203.125f,23.857f,-152.344f, --199.219f,21.724f,-152.344f, --195.313f,19.9592f,-152.344f, --191.406f,18.6648f,-152.344f, --187.5f,17.3913f,-152.344f, --183.594f,17.3113f,-152.344f, --179.688f,15.8776f,-152.344f, --175.781f,13.7968f,-152.344f, --171.875f,11.9961f,-152.344f, --167.969f,10.9315f,-152.344f, --164.063f,9.24337f,-152.344f, --160.156f,7.95749f,-152.344f, --156.25f,6.95525f,-152.344f, --152.344f,6.523f,-152.344f, --148.438f,5.62313f,-152.344f, --144.531f,4.31939f,-152.344f, --140.625f,3.1203f,-152.344f, --136.719f,4.98713f,-152.344f, --132.813f,6.64544f,-152.344f, --128.906f,7.48658f,-152.344f, --125.0f,8.08424f,-152.344f, --121.094f,8.96562f,-152.344f, --117.188f,9.10159f,-152.344f, --113.281f,9.38004f,-152.344f, --109.375f,8.97581f,-152.344f, --105.469f,8.78511f,-152.344f, --101.563f,9.76846f,-152.344f, --97.6563f,10.4299f,-152.344f, --93.75f,13.6059f,-152.344f, --89.8438f,16.3193f,-152.344f, --85.9375f,17.6959f,-152.344f, --82.0313f,18.5545f,-152.344f, --78.125f,20.1179f,-152.344f, --74.2188f,22.929f,-152.344f, --70.3125f,25.8413f,-152.344f, --66.4063f,28.4214f,-152.344f, --62.5f,30.0187f,-152.344f, --58.5938f,30.4285f,-152.344f, --54.6875f,30.9236f,-152.344f, --50.7813f,31.3519f,-152.344f, --46.875f,31.0939f,-152.344f, --42.9688f,30.2517f,-152.344f, --39.0625f,32.8953f,-152.344f, --35.1563f,34.6998f,-152.344f, --31.25f,36.8107f,-152.344f, --27.3438f,38.8491f,-152.344f, --23.4375f,41.3749f,-152.344f, --19.5313f,42.0838f,-152.344f, --15.625f,42.3106f,-152.344f, --11.7188f,43.9654f,-152.344f, --7.8125f,44.3642f,-152.344f, --3.90625f,43.1787f,-152.344f, -0.0f,41.875f,-152.344f, -3.90625f,42.7212f,-152.344f, --250.0f,27.3076f,-156.25f, --246.094f,27.8739f,-156.25f, --242.188f,27.7337f,-156.25f, --238.281f,28.4499f,-156.25f, --234.375f,30.5068f,-156.25f, --230.469f,31.1326f,-156.25f, --226.563f,32.3149f,-156.25f, --222.656f,31.2724f,-156.25f, --218.75f,29.5487f,-156.25f, --214.844f,26.8408f,-156.25f, --210.938f,25.2503f,-156.25f, --207.031f,24.2811f,-156.25f, --203.125f,23.8635f,-156.25f, --199.219f,22.2573f,-156.25f, --195.313f,20.6368f,-156.25f, --191.406f,19.4922f,-156.25f, --187.5f,18.0281f,-156.25f, --183.594f,15.4098f,-156.25f, --179.688f,13.9176f,-156.25f, --175.781f,11.8192f,-156.25f, --171.875f,9.31112f,-156.25f, --167.969f,8.81167f,-156.25f, --164.063f,8.04908f,-156.25f, --160.156f,6.4764f,-156.25f, --156.25f,5.83656f,-156.25f, --152.344f,5.70173f,-156.25f, --148.438f,6.05686f,-156.25f, --144.531f,3.98364f,-156.25f, --140.625f,2.80636f,-156.25f, --136.719f,3.53326f,-156.25f, --132.813f,4.97177f,-156.25f, --128.906f,6.71319f,-156.25f, --125.0f,8.26478f,-156.25f, --121.094f,9.00909f,-156.25f, --117.188f,8.8849f,-156.25f, --113.281f,9.50654f,-156.25f, --109.375f,9.16878f,-156.25f, --105.469f,8.84796f,-156.25f, --101.563f,9.78015f,-156.25f, --97.6563f,11.1536f,-156.25f, --93.75f,13.416f,-156.25f, --89.8438f,15.8674f,-156.25f, --85.9375f,17.2814f,-156.25f, --82.0313f,18.1958f,-156.25f, --78.125f,19.5037f,-156.25f, --74.2188f,22.0147f,-156.25f, --70.3125f,24.3288f,-156.25f, --66.4063f,26.5193f,-156.25f, --62.5f,27.9571f,-156.25f, --58.5938f,28.8524f,-156.25f, --54.6875f,30.6249f,-156.25f, --50.7813f,30.9824f,-156.25f, --46.875f,31.0372f,-156.25f, --42.9688f,30.2189f,-156.25f, --39.0625f,32.0632f,-156.25f, --35.1563f,34.0061f,-156.25f, --31.25f,35.3975f,-156.25f, --27.3438f,37.8006f,-156.25f, --23.4375f,40.1384f,-156.25f, --19.5313f,40.5455f,-156.25f, --15.625f,41.6044f,-156.25f, --11.7188f,43.1078f,-156.25f, --7.8125f,43.5927f,-156.25f, --3.90625f,43.0245f,-156.25f, -0.0f,41.3824f,-156.25f, -3.90625f,41.7368f,-156.25f, --250.0f,27.1128f,-160.156f, --246.094f,26.9845f,-160.156f, --242.188f,26.7433f,-160.156f, --238.281f,27.3777f,-160.156f, --234.375f,29.1743f,-160.156f, --230.469f,31.0712f,-160.156f, --226.563f,31.3707f,-160.156f, --222.656f,30.2327f,-160.156f, --218.75f,27.897f,-160.156f, --214.844f,26.4218f,-160.156f, --210.938f,24.0007f,-160.156f, --207.031f,23.6445f,-160.156f, --203.125f,23.6467f,-160.156f, --199.219f,22.8576f,-160.156f, --195.313f,20.6778f,-160.156f, --191.406f,19.3331f,-160.156f, --187.5f,17.8893f,-160.156f, --183.594f,14.3376f,-160.156f, --179.688f,11.9084f,-160.156f, --175.781f,9.60285f,-160.156f, --171.875f,7.78231f,-160.156f, --167.969f,8.15369f,-160.156f, --164.063f,7.46984f,-160.156f, --160.156f,6.48522f,-160.156f, --156.25f,5.27847f,-160.156f, --152.344f,4.69473f,-160.156f, --148.438f,5.14018f,-160.156f, --144.531f,3.26777f,-160.156f, --140.625f,3.33507f,-160.156f, --136.719f,2.47156f,-160.156f, --132.813f,4.15824f,-160.156f, --128.906f,6.45432f,-160.156f, --125.0f,7.99373f,-160.156f, --121.094f,8.38925f,-160.156f, --117.188f,8.59802f,-160.156f, --113.281f,9.4891f,-160.156f, --109.375f,9.20323f,-160.156f, --105.469f,8.27038f,-160.156f, --101.563f,9.71848f,-160.156f, --97.6563f,11.8577f,-160.156f, --93.75f,14.596f,-160.156f, --89.8438f,16.1058f,-160.156f, --85.9375f,17.6531f,-160.156f, --82.0313f,18.2123f,-160.156f, --78.125f,18.7175f,-160.156f, --74.2188f,20.7283f,-160.156f, --70.3125f,23.5217f,-160.156f, --66.4063f,26.4239f,-160.156f, --62.5f,27.757f,-160.156f, --58.5938f,28.1862f,-160.156f, --54.6875f,28.9075f,-160.156f, --50.7813f,29.5287f,-160.156f, --46.875f,29.3972f,-160.156f, --42.9688f,29.568f,-160.156f, --39.0625f,30.605f,-160.156f, --35.1563f,33.0369f,-160.156f, --31.25f,34.749f,-160.156f, --27.3438f,37.4864f,-160.156f, --23.4375f,39.2291f,-160.156f, --19.5313f,39.6275f,-160.156f, --15.625f,39.865f,-160.156f, --11.7188f,41.1833f,-160.156f, --7.8125f,41.7789f,-160.156f, --3.90625f,41.6972f,-160.156f, -0.0f,40.379f,-160.156f, -3.90625f,40.4755f,-160.156f, --250.0f,26.3982f,-164.063f, --246.094f,26.3606f,-164.063f, --242.188f,26.6508f,-164.063f, --238.281f,27.2228f,-164.063f, --234.375f,29.1682f,-164.063f, --230.469f,30.116f,-164.063f, --226.563f,30.3591f,-164.063f, --222.656f,28.8713f,-164.063f, --218.75f,26.8459f,-164.063f, --214.844f,24.9771f,-164.063f, --210.938f,24.4581f,-164.063f, --207.031f,23.6584f,-164.063f, --203.125f,22.7316f,-164.063f, --199.219f,21.1836f,-164.063f, --195.313f,19.6131f,-164.063f, --191.406f,18.5182f,-164.063f, --187.5f,16.824f,-164.063f, --183.594f,13.8772f,-164.063f, --179.688f,10.3923f,-164.063f, --175.781f,7.50643f,-164.063f, --171.875f,6.58466f,-164.063f, --167.969f,6.81413f,-164.063f, --164.063f,6.88249f,-164.063f, --160.156f,6.78655f,-164.063f, --156.25f,5.18348f,-164.063f, --152.344f,4.44173f,-164.063f, --148.438f,4.56392f,-164.063f, --144.531f,3.00722f,-164.063f, --140.625f,2.88808f,-164.063f, --136.719f,2.58477f,-164.063f, --132.813f,3.20911f,-164.063f, --128.906f,5.33043f,-164.063f, --125.0f,6.73698f,-164.063f, --121.094f,7.71971f,-164.063f, --117.188f,8.44689f,-164.063f, --113.281f,9.05366f,-164.063f, --109.375f,8.81111f,-164.063f, --105.469f,7.75706f,-164.063f, --101.563f,11.1131f,-164.063f, --97.6563f,12.8283f,-164.063f, --93.75f,14.7771f,-164.063f, --89.8438f,16.181f,-164.063f, --85.9375f,17.4228f,-164.063f, --82.0313f,18.5185f,-164.063f, --78.125f,19.3122f,-164.063f, --74.2188f,20.1572f,-164.063f, --70.3125f,22.741f,-164.063f, --66.4063f,24.5911f,-164.063f, --62.5f,26.3846f,-164.063f, --58.5938f,26.7315f,-164.063f, --54.6875f,27.0842f,-164.063f, --50.7813f,28.7654f,-164.063f, --46.875f,28.7233f,-164.063f, --42.9688f,29.2872f,-164.063f, --39.0625f,29.4838f,-164.063f, --35.1563f,32.7848f,-164.063f, --31.25f,34.771f,-164.063f, --27.3438f,36.568f,-164.063f, --23.4375f,37.5518f,-164.063f, --19.5313f,38.4106f,-164.063f, --15.625f,39.2979f,-164.063f, --11.7188f,39.3573f,-164.063f, --7.8125f,40.0034f,-164.063f, --3.90625f,39.5971f,-164.063f, -0.0f,38.8676f,-164.063f, -3.90625f,38.8633f,-164.063f, --250.0f,25.2893f,-167.969f, --246.094f,25.108f,-167.969f, --242.188f,25.5028f,-167.969f, --238.281f,26.6095f,-167.969f, --234.375f,28.3221f,-167.969f, --230.469f,28.5453f,-167.969f, --226.563f,28.2595f,-167.969f, --222.656f,26.8423f,-167.969f, --218.75f,25.0092f,-167.969f, --214.844f,24.2925f,-167.969f, --210.938f,23.8404f,-167.969f, --207.031f,22.7515f,-167.969f, --203.125f,22.5332f,-167.969f, --199.219f,20.3284f,-167.969f, --195.313f,18.8238f,-167.969f, --191.406f,17.0096f,-167.969f, --187.5f,14.7741f,-167.969f, --183.594f,12.4233f,-167.969f, --179.688f,9.35872f,-167.969f, --175.781f,6.39156f,-167.969f, --171.875f,4.97533f,-167.969f, --167.969f,4.85484f,-167.969f, --164.063f,5.54727f,-167.969f, --160.156f,5.08595f,-167.969f, --156.25f,3.82379f,-167.969f, --152.344f,3.95751f,-167.969f, --148.438f,4.60866f,-167.969f, --144.531f,3.48771f,-167.969f, --140.625f,3.26748f,-167.969f, --136.719f,1.87672f,-167.969f, --132.813f,2.70232f,-167.969f, --128.906f,4.51339f,-167.969f, --125.0f,6.0309f,-167.969f, --121.094f,7.41076f,-167.969f, --117.188f,7.44121f,-167.969f, --113.281f,7.50774f,-167.969f, --109.375f,6.89121f,-167.969f, --105.469f,8.13035f,-167.969f, --101.563f,11.7503f,-167.969f, --97.6563f,14.1358f,-167.969f, --93.75f,15.4553f,-167.969f, --89.8438f,16.6233f,-167.969f, --85.9375f,16.9002f,-167.969f, --82.0313f,18.4951f,-167.969f, --78.125f,19.0947f,-167.969f, --74.2188f,20.0506f,-167.969f, --70.3125f,20.9426f,-167.969f, --66.4063f,22.9738f,-167.969f, --62.5f,24.6229f,-167.969f, --58.5938f,26.446f,-167.969f, --54.6875f,26.6448f,-167.969f, --50.7813f,26.7349f,-167.969f, --46.875f,28.1266f,-167.969f, --42.9688f,29.6034f,-167.969f, --39.0625f,30.3572f,-167.969f, --35.1563f,31.5467f,-167.969f, --31.25f,33.6878f,-167.969f, --27.3438f,35.587f,-167.969f, --23.4375f,36.0939f,-167.969f, --19.5313f,37.5008f,-167.969f, --15.625f,38.2137f,-167.969f, --11.7188f,38.0843f,-167.969f, --7.8125f,38.5726f,-167.969f, --3.90625f,38.3565f,-167.969f, -0.0f,37.8848f,-167.969f, -3.90625f,37.2199f,-167.969f, --250.0f,24.1398f,-171.875f, --246.094f,23.8227f,-171.875f, --242.188f,24.7818f,-171.875f, --238.281f,26.1053f,-171.875f, --234.375f,26.9542f,-171.875f, --230.469f,26.4956f,-171.875f, --226.563f,25.4866f,-171.875f, --222.656f,24.7397f,-171.875f, --218.75f,23.4337f,-171.875f, --214.844f,23.2342f,-171.875f, --210.938f,22.1055f,-171.875f, --207.031f,20.7279f,-171.875f, --203.125f,20.7273f,-171.875f, --199.219f,19.1302f,-171.875f, --195.313f,16.3679f,-171.875f, --191.406f,14.4548f,-171.875f, --187.5f,12.5085f,-171.875f, --183.594f,10.0081f,-171.875f, --179.688f,7.8572f,-171.875f, --175.781f,4.38151f,-171.875f, --171.875f,3.2342f,-171.875f, --167.969f,3.37553f,-171.875f, --164.063f,3.90509f,-171.875f, --160.156f,3.26335f,-171.875f, --156.25f,2.88438f,-171.875f, --152.344f,4.22045f,-171.875f, --148.438f,3.83297f,-171.875f, --144.531f,2.98648f,-171.875f, --140.625f,2.83916f,-171.875f, --136.719f,1.97368f,-171.875f, --132.813f,1.85909f,-171.875f, --128.906f,3.2051f,-171.875f, --125.0f,5.12684f,-171.875f, --121.094f,5.86909f,-171.875f, --117.188f,6.45429f,-171.875f, --113.281f,6.28889f,-171.875f, --109.375f,7.53536f,-171.875f, --105.469f,9.44844f,-171.875f, --101.563f,11.4162f,-171.875f, --97.6563f,13.7412f,-171.875f, --93.75f,14.8315f,-171.875f, --89.8438f,15.4968f,-171.875f, --85.9375f,16.3468f,-171.875f, --82.0313f,18.2605f,-171.875f, --78.125f,18.0829f,-171.875f, --74.2188f,18.1489f,-171.875f, --70.3125f,20.6678f,-171.875f, --66.4063f,23.1234f,-171.875f, --62.5f,24.4247f,-171.875f, --58.5938f,26.5223f,-171.875f, --54.6875f,26.4286f,-171.875f, --50.7813f,26.7163f,-171.875f, --46.875f,28.0436f,-171.875f, --42.9688f,29.6821f,-171.875f, --39.0625f,30.721f,-171.875f, --35.1563f,31.1869f,-171.875f, --31.25f,32.2507f,-171.875f, --27.3438f,33.3898f,-171.875f, --23.4375f,33.9008f,-171.875f, --19.5313f,34.8028f,-171.875f, --15.625f,35.7178f,-171.875f, --11.7188f,35.7796f,-171.875f, --7.8125f,35.6384f,-171.875f, --3.90625f,35.5122f,-171.875f, -0.0f,35.5973f,-171.875f, -3.90625f,35.3898f,-171.875f, --250.0f,23.4472f,-175.781f, --246.094f,24.0295f,-175.781f, --242.188f,25.0451f,-175.781f, --238.281f,25.8985f,-175.781f, --234.375f,26.561f,-175.781f, --230.469f,25.8342f,-175.781f, --226.563f,24.8466f,-175.781f, --222.656f,24.9204f,-175.781f, --218.75f,23.1933f,-175.781f, --214.844f,22.3916f,-175.781f, --210.938f,20.9595f,-175.781f, --207.031f,19.4013f,-175.781f, --203.125f,18.3359f,-175.781f, --199.219f,16.2135f,-175.781f, --195.313f,14.3022f,-175.781f, --191.406f,12.4792f,-175.781f, --187.5f,10.1621f,-175.781f, --183.594f,7.8368f,-175.781f, --179.688f,5.59407f,-175.781f, --175.781f,3.47332f,-175.781f, --171.875f,2.4167f,-175.781f, --167.969f,2.13794f,-175.781f, --164.063f,2.36632f,-175.781f, --160.156f,2.44955f,-175.781f, --156.25f,2.40042f,-175.781f, --152.344f,3.0142f,-175.781f, --148.438f,2.58304f,-175.781f, --144.531f,3.06221f,-175.781f, --140.625f,2.8937f,-175.781f, --136.719f,2.59115f,-175.781f, --132.813f,2.27806f,-175.781f, --128.906f,3.67695f,-175.781f, --125.0f,5.23254f,-175.781f, --121.094f,6.12339f,-175.781f, --117.188f,6.24689f,-175.781f, --113.281f,6.79282f,-175.781f, --109.375f,7.83542f,-175.781f, --105.469f,9.33972f,-175.781f, --101.563f,11.2701f,-175.781f, --97.6563f,13.0689f,-175.781f, --93.75f,13.927f,-175.781f, --89.8438f,14.9788f,-175.781f, --85.9375f,15.6647f,-175.781f, --82.0313f,16.3833f,-175.781f, --78.125f,16.1061f,-175.781f, --74.2188f,17.7393f,-175.781f, --70.3125f,19.8808f,-175.781f, --66.4063f,22.2751f,-175.781f, --62.5f,23.8491f,-175.781f, --58.5938f,25.3344f,-175.781f, --54.6875f,26.6818f,-175.781f, --50.7813f,27.9151f,-175.781f, --46.875f,28.5054f,-175.781f, --42.9688f,29.7057f,-175.781f, --39.0625f,30.623f,-175.781f, --35.1563f,31.5341f,-175.781f, --31.25f,31.663f,-175.781f, --27.3438f,31.1886f,-175.781f, --23.4375f,31.5377f,-175.781f, --19.5313f,31.9508f,-175.781f, --15.625f,32.9549f,-175.781f, --11.7188f,33.7731f,-175.781f, --7.8125f,33.8023f,-175.781f, --3.90625f,34.5283f,-175.781f, -0.0f,34.7929f,-175.781f, -3.90625f,34.823f,-175.781f, --250.0f,22.2698f,-179.688f, --246.094f,23.7669f,-179.688f, --242.188f,24.59f,-179.688f, --238.281f,26.1637f,-179.688f, --234.375f,25.5266f,-179.688f, --230.469f,24.4911f,-179.688f, --226.563f,24.894f,-179.688f, --222.656f,23.7469f,-179.688f, --218.75f,22.9663f,-179.688f, --214.844f,20.6574f,-179.688f, --210.938f,19.2502f,-179.688f, --207.031f,17.3967f,-179.688f, --203.125f,15.9684f,-179.688f, --199.219f,13.2948f,-179.688f, --195.313f,11.9318f,-179.688f, --191.406f,9.64213f,-179.688f, --187.5f,7.9435f,-179.688f, --183.594f,6.1917f,-179.688f, --179.688f,4.0394f,-179.688f, --175.781f,1.9267f,-179.688f, --171.875f,1.73477f,-179.688f, --167.969f,0.994442f,-179.688f, --164.063f,0.99617f,-179.688f, --160.156f,1.00048f,-179.688f, --156.25f,1.54446f,-179.688f, --152.344f,0.849521f,-179.688f, --148.438f,1.3046f,-179.688f, --144.531f,1.38519f,-179.688f, --140.625f,0.916628f,-179.688f, --136.719f,1.39685f,-179.688f, --132.813f,2.17945f,-179.688f, --128.906f,4.01973f,-179.688f, --125.0f,5.72989f,-179.688f, --121.094f,7.24268f,-179.688f, --117.188f,7.06199f,-179.688f, --113.281f,7.91292f,-179.688f, --109.375f,7.8138f,-179.688f, --105.469f,10.102f,-179.688f, --101.563f,11.8106f,-179.688f, --97.6563f,12.9642f,-179.688f, --93.75f,13.5879f,-179.688f, --89.8438f,13.4552f,-179.688f, --85.9375f,14.1844f,-179.688f, --82.0313f,14.3802f,-179.688f, --78.125f,15.3847f,-179.688f, --74.2188f,17.2288f,-179.688f, --70.3125f,18.9285f,-179.688f, --66.4063f,20.0035f,-179.688f, --62.5f,22.2672f,-179.688f, --58.5938f,25.1262f,-179.688f, --54.6875f,27.2745f,-179.688f, --50.7813f,28.2648f,-179.688f, --46.875f,29.3825f,-179.688f, --42.9688f,30.2137f,-179.688f, --39.0625f,31.3826f,-179.688f, --35.1563f,31.25f,-179.688f, --31.25f,31.0392f,-179.688f, --27.3438f,30.3369f,-179.688f, --23.4375f,30.5503f,-179.688f, --19.5313f,30.9715f,-179.688f, --15.625f,31.8287f,-179.688f, --11.7188f,32.1393f,-179.688f, --7.8125f,32.0725f,-179.688f, --3.90625f,32.6574f,-179.688f, -0.0f,32.8889f,-179.688f, -3.90625f,32.9461f,-179.688f, --250.0f,22.3874f,-183.594f, --246.094f,22.8072f,-183.594f, --242.188f,23.1353f,-183.594f, --238.281f,24.0949f,-183.594f, --234.375f,24.0026f,-183.594f, --230.469f,23.458f,-183.594f, --226.563f,23.872f,-183.594f, --222.656f,22.969f,-183.594f, --218.75f,21.8375f,-183.594f, --214.844f,19.9316f,-183.594f, --210.938f,16.812f,-183.594f, --207.031f,15.1789f,-183.594f, --203.125f,13.7876f,-183.594f, --199.219f,11.6818f,-183.594f, --195.313f,9.75291f,-183.594f, --191.406f,7.08878f,-183.594f, --187.5f,6.43001f,-183.594f, --183.594f,5.15238f,-183.594f, --179.688f,3.77653f,-183.594f, --175.781f,3.01737f,-183.594f, --171.875f,1.46355f,-183.594f, --167.969f,0.767798f,-183.594f, --164.063f,1.98474f,-183.594f, --160.156f,1.09473f,-183.594f, --156.25f,1.29857f,-183.594f, --152.344f,-0.203491f,-183.594f, --148.438f,-0.506199f,-183.594f, --144.531f,-0.678603f,-183.594f, --140.625f,0.165814f,-183.594f, --136.719f,1.44759f,-183.594f, --132.813f,1.43337f,-183.594f, --128.906f,3.23614f,-183.594f, --125.0f,4.8541f,-183.594f, --121.094f,6.64038f,-183.594f, --117.188f,7.96432f,-183.594f, --113.281f,8.52594f,-183.594f, --109.375f,7.78399f,-183.594f, --105.469f,9.45422f,-183.594f, --101.563f,11.3198f,-183.594f, --97.6563f,12.2369f,-183.594f, --93.75f,12.7733f,-183.594f, --89.8438f,12.9184f,-183.594f, --85.9375f,12.958f,-183.594f, --82.0313f,13.3326f,-183.594f, --78.125f,14.3984f,-183.594f, --74.2188f,16.2737f,-183.594f, --70.3125f,17.9981f,-183.594f, --66.4063f,19.5314f,-183.594f, --62.5f,21.4039f,-183.594f, --58.5938f,24.8945f,-183.594f, --54.6875f,26.9904f,-183.594f, --50.7813f,28.6222f,-183.594f, --46.875f,30.2128f,-183.594f, --42.9688f,30.5142f,-183.594f, --39.0625f,30.7026f,-183.594f, --35.1563f,30.6413f,-183.594f, --31.25f,29.7659f,-183.594f, --27.3438f,30.2613f,-183.594f, --23.4375f,31.0694f,-183.594f, --19.5313f,31.0437f,-183.594f, --15.625f,30.9824f,-183.594f, --11.7188f,30.4648f,-183.594f, --7.8125f,30.0916f,-183.594f, --3.90625f,30.0801f,-183.594f, -0.0f,29.9992f,-183.594f, -3.90625f,30.0027f,-183.594f, --250.0f,22.2829f,-187.5f, --246.094f,23.1567f,-187.5f, --242.188f,23.2229f,-187.5f, --238.281f,23.6644f,-187.5f, --234.375f,23.5148f,-187.5f, --230.469f,22.8756f,-187.5f, --226.563f,22.2471f,-187.5f, --222.656f,21.4292f,-187.5f, --218.75f,20.4108f,-187.5f, --214.844f,18.2601f,-187.5f, --210.938f,16.3575f,-187.5f, --207.031f,13.0762f,-187.5f, --203.125f,11.5916f,-187.5f, --199.219f,9.81885f,-187.5f, --195.313f,8.57193f,-187.5f, --191.406f,5.93865f,-187.5f, --187.5f,5.15801f,-187.5f, --183.594f,3.89597f,-187.5f, --179.688f,4.52236f,-187.5f, --175.781f,4.21162f,-187.5f, --171.875f,2.62521f,-187.5f, --167.969f,1.85733f,-187.5f, --164.063f,2.14119f,-187.5f, --160.156f,2.60992f,-187.5f, --156.25f,1.99742f,-187.5f, --152.344f,0.836315f,-187.5f, --148.438f,-0.122141f,-187.5f, --144.531f,-1.21041f,-187.5f, --140.625f,0.620409f,-187.5f, --136.719f,2.20372f,-187.5f, --132.813f,2.55457f,-187.5f, --128.906f,3.09944f,-187.5f, --125.0f,4.76219f,-187.5f, --121.094f,6.5939f,-187.5f, --117.188f,7.40657f,-187.5f, --113.281f,8.17096f,-187.5f, --109.375f,8.8965f,-187.5f, --105.469f,9.54116f,-187.5f, --101.563f,10.8183f,-187.5f, --97.6563f,12.2345f,-187.5f, --93.75f,11.945f,-187.5f, --89.8438f,12.3063f,-187.5f, --85.9375f,12.7736f,-187.5f, --82.0313f,13.2581f,-187.5f, --78.125f,14.2241f,-187.5f, --74.2188f,15.1957f,-187.5f, --70.3125f,17.7241f,-187.5f, --66.4063f,21.0931f,-187.5f, --62.5f,23.7741f,-187.5f, --58.5938f,24.8775f,-187.5f, --54.6875f,26.5924f,-187.5f, --50.7813f,28.0699f,-187.5f, --46.875f,30.1552f,-187.5f, --42.9688f,30.8508f,-187.5f, --39.0625f,30.7935f,-187.5f, --35.1563f,30.3224f,-187.5f, --31.25f,28.8455f,-187.5f, --27.3438f,30.2059f,-187.5f, --23.4375f,31.5456f,-187.5f, --19.5313f,31.0657f,-187.5f, --15.625f,30.5686f,-187.5f, --11.7188f,29.9754f,-187.5f, --7.8125f,28.7754f,-187.5f, --3.90625f,28.2457f,-187.5f, -0.0f,27.4045f,-187.5f, -3.90625f,27.6405f,-187.5f, --250.0f,21.5096f,-191.406f, --246.094f,22.1931f,-191.406f, --242.188f,22.416f,-191.406f, --238.281f,22.619f,-191.406f, --234.375f,22.9242f,-191.406f, --230.469f,22.6042f,-191.406f, --226.563f,21.5344f,-191.406f, --222.656f,20.226f,-191.406f, --218.75f,19.6198f,-191.406f, --214.844f,18.0849f,-191.406f, --210.938f,15.9896f,-191.406f, --207.031f,12.7402f,-191.406f, --203.125f,9.98899f,-191.406f, --199.219f,7.38602f,-191.406f, --195.313f,6.23078f,-191.406f, --191.406f,4.8714f,-191.406f, --187.5f,4.87792f,-191.406f, --183.594f,4.53381f,-191.406f, --179.688f,5.23517f,-191.406f, --175.781f,4.22349f,-191.406f, --171.875f,3.46214f,-191.406f, --167.969f,3.62202f,-191.406f, --164.063f,3.07142f,-191.406f, --160.156f,3.69893f,-191.406f, --156.25f,4.20827f,-191.406f, --152.344f,2.23654f,-191.406f, --148.438f,0.582121f,-191.406f, --144.531f,0.44941f,-191.406f, --140.625f,2.42446f,-191.406f, --136.719f,3.54807f,-191.406f, --132.813f,3.58143f,-191.406f, --128.906f,4.42162f,-191.406f, --125.0f,5.24153f,-191.406f, --121.094f,6.55792f,-191.406f, --117.188f,6.93471f,-191.406f, --113.281f,7.73309f,-191.406f, --109.375f,8.04468f,-191.406f, --105.469f,9.15528f,-191.406f, --101.563f,10.9583f,-191.406f, --97.6563f,12.1897f,-191.406f, --93.75f,11.6481f,-191.406f, --89.8438f,11.6514f,-191.406f, --85.9375f,12.4326f,-191.406f, --82.0313f,13.3808f,-191.406f, --78.125f,14.386f,-191.406f, --74.2188f,16.182f,-191.406f, --70.3125f,18.9931f,-191.406f, --66.4063f,22.8308f,-191.406f, --62.5f,25.3868f,-191.406f, --58.5938f,26.1484f,-191.406f, --54.6875f,25.6258f,-191.406f, --50.7813f,26.9464f,-191.406f, --46.875f,29.0075f,-191.406f, --42.9688f,29.8523f,-191.406f, --39.0625f,30.1236f,-191.406f, --35.1563f,29.7557f,-191.406f, --31.25f,28.4913f,-191.406f, --27.3438f,29.5389f,-191.406f, --23.4375f,30.4685f,-191.406f, --19.5313f,30.3743f,-191.406f, --15.625f,30.3762f,-191.406f, --11.7188f,29.0099f,-191.406f, --7.8125f,28.1952f,-191.406f, --3.90625f,26.135f,-191.406f, -0.0f,25.2418f,-191.406f, -3.90625f,25.3652f,-191.406f, --250.0f,20.78f,-195.313f, --246.094f,20.8279f,-195.313f, --242.188f,21.2199f,-195.313f, --238.281f,22.0652f,-195.313f, --234.375f,22.2095f,-195.313f, --230.469f,22.1372f,-195.313f, --226.563f,21.0165f,-195.313f, --222.656f,19.4174f,-195.313f, --218.75f,17.7927f,-195.313f, --214.844f,16.6172f,-195.313f, --210.938f,14.7065f,-195.313f, --207.031f,11.8095f,-195.313f, --203.125f,9.63824f,-195.313f, --199.219f,6.4991f,-195.313f, --195.313f,6.23707f,-195.313f, --191.406f,6.60374f,-195.313f, --187.5f,6.22557f,-195.313f, --183.594f,5.47951f,-195.313f, --179.688f,5.16851f,-195.313f, --175.781f,4.83538f,-195.313f, --171.875f,4.16992f,-195.313f, --167.969f,5.40533f,-195.313f, --164.063f,5.01562f,-195.313f, --160.156f,4.58978f,-195.313f, --156.25f,4.73252f,-195.313f, --152.344f,3.14586f,-195.313f, --148.438f,1.16894f,-195.313f, --144.531f,2.4916f,-195.313f, --140.625f,3.98933f,-195.313f, --136.719f,5.16861f,-195.313f, --132.813f,5.68931f,-195.313f, --128.906f,5.45815f,-195.313f, --125.0f,5.15506f,-195.313f, --121.094f,6.46153f,-195.313f, --117.188f,7.36577f,-195.313f, --113.281f,8.13491f,-195.313f, --109.375f,7.50896f,-195.313f, --105.469f,8.93662f,-195.313f, --101.563f,10.6513f,-195.313f, --97.6563f,10.6255f,-195.313f, --93.75f,10.5332f,-195.313f, --89.8438f,11.5758f,-195.313f, --85.9375f,11.568f,-195.313f, --82.0313f,14.2419f,-195.313f, --78.125f,16.1272f,-195.313f, --74.2188f,17.0994f,-195.313f, --70.3125f,20.4651f,-195.313f, --66.4063f,23.534f,-195.313f, --62.5f,25.1181f,-195.313f, --58.5938f,25.9427f,-195.313f, --54.6875f,25.5166f,-195.313f, --50.7813f,25.1027f,-195.313f, --46.875f,27.2281f,-195.313f, --42.9688f,28.7319f,-195.313f, --39.0625f,28.8984f,-195.313f, --35.1563f,28.3307f,-195.313f, --31.25f,27.4754f,-195.313f, --27.3438f,27.8763f,-195.313f, --23.4375f,28.1023f,-195.313f, --19.5313f,28.9815f,-195.313f, --15.625f,28.5849f,-195.313f, --11.7188f,27.2687f,-195.313f, --7.8125f,26.8112f,-195.313f, --3.90625f,25.3636f,-195.313f, -0.0f,23.2134f,-195.313f, -3.90625f,23.0993f,-195.313f, --250.0f,20.2026f,-199.219f, --246.094f,19.5895f,-199.219f, --242.188f,20.3489f,-199.219f, --238.281f,21.0293f,-199.219f, --234.375f,21.5343f,-199.219f, --230.469f,20.6859f,-199.219f, --226.563f,19.9279f,-199.219f, --222.656f,18.7217f,-199.219f, --218.75f,17.4818f,-199.219f, --214.844f,15.0438f,-199.219f, --210.938f,13.4082f,-199.219f, --207.031f,10.7188f,-199.219f, --203.125f,8.32176f,-199.219f, --199.219f,7.30407f,-199.219f, --195.313f,7.02569f,-199.219f, --191.406f,7.38826f,-199.219f, --187.5f,6.94954f,-199.219f, --183.594f,6.62067f,-199.219f, --179.688f,6.55308f,-199.219f, --175.781f,6.3403f,-199.219f, --171.875f,5.0001f,-199.219f, --167.969f,6.51564f,-199.219f, --164.063f,6.69774f,-199.219f, --160.156f,5.67189f,-199.219f, --156.25f,4.8973f,-199.219f, --152.344f,3.43798f,-199.219f, --148.438f,2.08531f,-199.219f, --144.531f,3.86643f,-199.219f, --140.625f,6.0862f,-199.219f, --136.719f,6.99995f,-199.219f, --132.813f,8.32808f,-199.219f, --128.906f,8.55809f,-199.219f, --125.0f,8.26904f,-199.219f, --121.094f,8.63733f,-199.219f, --117.188f,9.11106f,-199.219f, --113.281f,9.73154f,-199.219f, --109.375f,9.14108f,-199.219f, --105.469f,9.3525f,-199.219f, --101.563f,9.56281f,-199.219f, --97.6563f,9.74866f,-199.219f, --93.75f,10.9852f,-199.219f, --89.8438f,12.3926f,-199.219f, --85.9375f,13.6407f,-199.219f, --82.0313f,15.9886f,-199.219f, --78.125f,17.7913f,-199.219f, --74.2188f,18.8352f,-199.219f, --70.3125f,20.2718f,-199.219f, --66.4063f,23.501f,-199.219f, --62.5f,24.6073f,-199.219f, --58.5938f,25.3028f,-199.219f, --54.6875f,25.2244f,-199.219f, --50.7813f,23.9922f,-199.219f, --46.875f,24.6425f,-199.219f, --42.9688f,26.6199f,-199.219f, --39.0625f,27.5474f,-199.219f, --35.1563f,27.4672f,-199.219f, --31.25f,27.2906f,-199.219f, --27.3438f,26.489f,-199.219f, --23.4375f,26.3554f,-199.219f, --19.5313f,26.1787f,-199.219f, --15.625f,26.2538f,-199.219f, --11.7188f,25.7694f,-199.219f, --7.8125f,25.2691f,-199.219f, --3.90625f,23.3867f,-199.219f, -0.0f,22.5717f,-199.219f, -3.90625f,21.5827f,-199.219f, --250.0f,19.3526f,-203.125f, --246.094f,19.2964f,-203.125f, --242.188f,19.226f,-203.125f, --238.281f,19.4274f,-203.125f, --234.375f,19.4317f,-203.125f, --230.469f,19.3079f,-203.125f, --226.563f,18.212f,-203.125f, --222.656f,17.8371f,-203.125f, --218.75f,16.8642f,-203.125f, --214.844f,14.8539f,-203.125f, --210.938f,12.425f,-203.125f, --207.031f,10.0369f,-203.125f, --203.125f,9.00151f,-203.125f, --199.219f,8.61334f,-203.125f, --195.313f,8.09586f,-203.125f, --191.406f,8.18143f,-203.125f, --187.5f,7.75345f,-203.125f, --183.594f,7.72772f,-203.125f, --179.688f,7.71649f,-203.125f, --175.781f,7.72935f,-203.125f, --171.875f,6.70116f,-203.125f, --167.969f,6.58828f,-203.125f, --164.063f,6.47975f,-203.125f, --160.156f,5.96451f,-203.125f, --156.25f,5.85253f,-203.125f, --152.344f,5.14982f,-203.125f, --148.438f,4.60646f,-203.125f, --144.531f,6.3659f,-203.125f, --140.625f,7.66587f,-203.125f, --136.719f,8.68095f,-203.125f, --132.813f,9.86922f,-203.125f, --128.906f,9.93481f,-203.125f, --125.0f,10.9585f,-203.125f, --121.094f,10.9271f,-203.125f, --117.188f,11.4348f,-203.125f, --113.281f,11.0548f,-203.125f, --109.375f,11.2501f,-203.125f, --105.469f,11.7673f,-203.125f, --101.563f,10.8899f,-203.125f, --97.6563f,11.3791f,-203.125f, --93.75f,12.168f,-203.125f, --89.8438f,12.7667f,-203.125f, --85.9375f,15.2415f,-203.125f, --82.0313f,17.9783f,-203.125f, --78.125f,19.6193f,-203.125f, --74.2188f,19.6343f,-203.125f, --70.3125f,19.7814f,-203.125f, --66.4063f,21.45f,-203.125f, --62.5f,24.1224f,-203.125f, --58.5938f,24.9145f,-203.125f, --54.6875f,24.2614f,-203.125f, --50.7813f,24.025f,-203.125f, --46.875f,23.1092f,-203.125f, --42.9688f,24.0294f,-203.125f, --39.0625f,25.4744f,-203.125f, --35.1563f,25.9477f,-203.125f, --31.25f,25.5895f,-203.125f, --27.3438f,25.0752f,-203.125f, --23.4375f,24.6537f,-203.125f, --19.5313f,25.0025f,-203.125f, --15.625f,25.211f,-203.125f, --11.7188f,24.2103f,-203.125f, --7.8125f,23.1363f,-203.125f, --3.90625f,21.4314f,-203.125f, -0.0f,20.8784f,-203.125f, -3.90625f,20.3179f,-203.125f, --250.0f,18.4857f,-207.031f, --246.094f,18.9103f,-207.031f, --242.188f,17.7666f,-207.031f, --238.281f,18.3803f,-207.031f, --234.375f,17.7746f,-207.031f, --230.469f,18.1956f,-207.031f, --226.563f,17.4596f,-207.031f, --222.656f,16.5346f,-207.031f, --218.75f,15.3933f,-207.031f, --214.844f,14.0342f,-207.031f, --210.938f,11.5492f,-207.031f, --207.031f,10.8526f,-207.031f, --203.125f,10.5164f,-207.031f, --199.219f,10.4957f,-207.031f, --195.313f,9.57889f,-207.031f, --191.406f,9.42031f,-207.031f, --187.5f,9.08544f,-207.031f, --183.594f,8.10082f,-207.031f, --179.688f,8.5632f,-207.031f, --175.781f,8.74392f,-207.031f, --171.875f,8.56175f,-207.031f, --167.969f,7.13665f,-207.031f, --164.063f,6.99003f,-207.031f, --160.156f,7.1192f,-207.031f, --156.25f,6.173f,-207.031f, --152.344f,6.44193f,-207.031f, --148.438f,7.15583f,-207.031f, --144.531f,7.74526f,-207.031f, --140.625f,9.38846f,-207.031f, --136.719f,10.1943f,-207.031f, --132.813f,10.5195f,-207.031f, --128.906f,11.4457f,-207.031f, --125.0f,12.4233f,-207.031f, --121.094f,12.8633f,-207.031f, --117.188f,13.4045f,-207.031f, --113.281f,12.9134f,-207.031f, --109.375f,12.9203f,-207.031f, --105.469f,13.2173f,-207.031f, --101.563f,12.9065f,-207.031f, --97.6563f,12.9327f,-207.031f, --93.75f,13.5926f,-207.031f, --89.8438f,14.5472f,-207.031f, --85.9375f,16.41f,-207.031f, --82.0313f,19.1484f,-207.031f, --78.125f,20.5688f,-207.031f, --74.2188f,20.1464f,-207.031f, --70.3125f,19.9352f,-207.031f, --66.4063f,20.4543f,-207.031f, --62.5f,22.0083f,-207.031f, --58.5938f,23.2866f,-207.031f, --54.6875f,23.3242f,-207.031f, --50.7813f,23.0127f,-207.031f, --46.875f,23.4455f,-207.031f, --42.9688f,23.4808f,-207.031f, --39.0625f,24.4622f,-207.031f, --35.1563f,25.1122f,-207.031f, --31.25f,25.3818f,-207.031f, --27.3438f,24.0051f,-207.031f, --23.4375f,22.3971f,-207.031f, --19.5313f,23.4811f,-207.031f, --15.625f,23.8447f,-207.031f, --11.7188f,22.3912f,-207.031f, --7.8125f,21.7286f,-207.031f, --3.90625f,20.1632f,-207.031f, -0.0f,18.6587f,-207.031f, -3.90625f,18.3149f,-207.031f, --250.0f,17.6517f,-210.938f, --246.094f,17.8132f,-210.938f, --242.188f,17.4894f,-210.938f, --238.281f,16.7087f,-210.938f, --234.375f,15.9111f,-210.938f, --230.469f,16.6733f,-210.938f, --226.563f,16.6911f,-210.938f, --222.656f,14.6177f,-210.938f, --218.75f,13.6959f,-210.938f, --214.844f,12.227f,-210.938f, --210.938f,11.5376f,-210.938f, --207.031f,11.7259f,-210.938f, --203.125f,11.4804f,-210.938f, --199.219f,11.8728f,-210.938f, --195.313f,11.7357f,-210.938f, --191.406f,10.6319f,-210.938f, --187.5f,10.7016f,-210.938f, --183.594f,9.53811f,-210.938f, --179.688f,9.65149f,-210.938f, --175.781f,9.45993f,-210.938f, --171.875f,9.4427f,-210.938f, --167.969f,8.02525f,-210.938f, --164.063f,6.71089f,-210.938f, --160.156f,7.22567f,-210.938f, --156.25f,7.52391f,-210.938f, --152.344f,8.46765f,-210.938f, --148.438f,8.60801f,-210.938f, --144.531f,9.89046f,-210.938f, --140.625f,10.9163f,-210.938f, --136.719f,11.445f,-210.938f, --132.813f,12.6949f,-210.938f, --128.906f,13.3645f,-210.938f, --125.0f,14.5389f,-210.938f, --121.094f,14.7689f,-210.938f, --117.188f,15.8285f,-210.938f, --113.281f,15.5058f,-210.938f, --109.375f,14.3542f,-210.938f, --105.469f,14.9928f,-210.938f, --101.563f,14.9601f,-210.938f, --97.6563f,15.1602f,-210.938f, --93.75f,15.1589f,-210.938f, --89.8438f,16.5401f,-210.938f, --85.9375f,18.2407f,-210.938f, --82.0313f,19.8006f,-210.938f, --78.125f,20.9223f,-210.938f, --74.2188f,20.5615f,-210.938f, --70.3125f,21.0505f,-210.938f, --66.4063f,21.024f,-210.938f, --62.5f,21.7216f,-210.938f, --58.5938f,22.8737f,-210.938f, --54.6875f,23.631f,-210.938f, --50.7813f,23.6265f,-210.938f, --46.875f,23.5636f,-210.938f, --42.9688f,24.1299f,-210.938f, --39.0625f,24.6395f,-210.938f, --35.1563f,25.3237f,-210.938f, --31.25f,24.7459f,-210.938f, --27.3438f,22.2327f,-210.938f, --23.4375f,21.6309f,-210.938f, --19.5313f,22.3059f,-210.938f, --15.625f,22.1894f,-210.938f, --11.7188f,21.2088f,-210.938f, --7.8125f,20.3383f,-210.938f, --3.90625f,18.4799f,-210.938f, -0.0f,17.18f,-210.938f, -3.90625f,16.2147f,-210.938f, --250.0f,17.6547f,-214.844f, --246.094f,17.1845f,-214.844f, --242.188f,17.6913f,-214.844f, --238.281f,16.8842f,-214.844f, --234.375f,14.7169f,-214.844f, --230.469f,15.4287f,-214.844f, --226.563f,14.5659f,-214.844f, --222.656f,13.1756f,-214.844f, --218.75f,12.021f,-214.844f, --214.844f,11.9663f,-214.844f, --210.938f,12.535f,-214.844f, --207.031f,12.5802f,-214.844f, --203.125f,12.7437f,-214.844f, --199.219f,12.9859f,-214.844f, --195.313f,12.7714f,-214.844f, --191.406f,11.9783f,-214.844f, --187.5f,11.9282f,-214.844f, --183.594f,10.7633f,-214.844f, --179.688f,10.3463f,-214.844f, --175.781f,10.1867f,-214.844f, --171.875f,10.378f,-214.844f, --167.969f,8.81572f,-214.844f, --164.063f,7.29133f,-214.844f, --160.156f,8.45242f,-214.844f, --156.25f,9.77224f,-214.844f, --152.344f,10.4567f,-214.844f, --148.438f,11.0484f,-214.844f, --144.531f,12.1985f,-214.844f, --140.625f,13.766f,-214.844f, --136.719f,14.9123f,-214.844f, --132.813f,15.4577f,-214.844f, --128.906f,16.3401f,-214.844f, --125.0f,16.5963f,-214.844f, --121.094f,16.9605f,-214.844f, --117.188f,16.548f,-214.844f, --113.281f,16.701f,-214.844f, --109.375f,16.6987f,-214.844f, --105.469f,16.1393f,-214.844f, --101.563f,15.4379f,-214.844f, --97.6563f,15.9931f,-214.844f, --93.75f,16.7962f,-214.844f, --89.8438f,18.5464f,-214.844f, --85.9375f,20.2834f,-214.844f, --82.0313f,20.8463f,-214.844f, --78.125f,21.263f,-214.844f, --74.2188f,22.137f,-214.844f, --70.3125f,22.1614f,-214.844f, --66.4063f,21.7706f,-214.844f, --62.5f,23.0496f,-214.844f, --58.5938f,23.0762f,-214.844f, --54.6875f,24.2163f,-214.844f, --50.7813f,23.9415f,-214.844f, --46.875f,23.115f,-214.844f, --42.9688f,24.4371f,-214.844f, --39.0625f,25.7433f,-214.844f, --35.1563f,24.6385f,-214.844f, --31.25f,23.2822f,-214.844f, --27.3438f,21.8583f,-214.844f, --23.4375f,21.2352f,-214.844f, --19.5313f,21.3084f,-214.844f, --15.625f,20.7264f,-214.844f, --11.7188f,19.67f,-214.844f, --7.8125f,18.8192f,-214.844f, --3.90625f,16.6504f,-214.844f, -0.0f,14.8779f,-214.844f, -3.90625f,14.284f,-214.844f, --250.0f,17.1549f,-218.75f, --246.094f,16.6295f,-218.75f, --242.188f,17.7459f,-218.75f, --238.281f,17.3894f,-218.75f, --234.375f,15.2738f,-218.75f, --230.469f,13.3984f,-218.75f, --226.563f,12.8639f,-218.75f, --222.656f,12.3225f,-218.75f, --218.75f,12.1914f,-218.75f, --214.844f,12.4104f,-218.75f, --210.938f,12.9278f,-218.75f, --207.031f,13.387f,-218.75f, --203.125f,13.4342f,-218.75f, --199.219f,12.7445f,-218.75f, --195.313f,12.543f,-218.75f, --191.406f,12.1437f,-218.75f, --187.5f,12.3491f,-218.75f, --183.594f,11.2334f,-218.75f, --179.688f,11.4016f,-218.75f, --175.781f,11.2455f,-218.75f, --171.875f,10.3681f,-218.75f, --167.969f,9.23056f,-218.75f, --164.063f,8.35869f,-218.75f, --160.156f,10.3612f,-218.75f, --156.25f,11.8429f,-218.75f, --152.344f,13.2154f,-218.75f, --148.438f,13.6238f,-218.75f, --144.531f,14.8343f,-218.75f, --140.625f,15.5549f,-218.75f, --136.719f,16.9496f,-218.75f, --132.813f,17.9187f,-218.75f, --128.906f,17.7467f,-218.75f, --125.0f,17.8229f,-218.75f, --121.094f,17.4408f,-218.75f, --117.188f,17.3929f,-218.75f, --113.281f,17.9861f,-218.75f, --109.375f,18.0206f,-218.75f, --105.469f,17.6787f,-218.75f, --101.563f,17.3769f,-218.75f, --97.6563f,17.5683f,-218.75f, --93.75f,18.0067f,-218.75f, --89.8438f,18.9639f,-218.75f, --85.9375f,20.8377f,-218.75f, --82.0313f,22.207f,-218.75f, --78.125f,23.1239f,-218.75f, --74.2188f,22.384f,-218.75f, --70.3125f,22.2939f,-218.75f, --66.4063f,21.8208f,-218.75f, --62.5f,22.9458f,-218.75f, --58.5938f,24.2547f,-218.75f, --54.6875f,24.5855f,-218.75f, --50.7813f,23.9529f,-218.75f, --46.875f,22.9226f,-218.75f, --42.9688f,25.1015f,-218.75f, --39.0625f,25.1591f,-218.75f, --35.1563f,23.6146f,-218.75f, --31.25f,21.7924f,-218.75f, --27.3438f,20.3147f,-218.75f, --23.4375f,19.9227f,-218.75f, --19.5313f,20.3267f,-218.75f, --15.625f,19.1903f,-218.75f, --11.7188f,17.3132f,-218.75f, --7.8125f,16.5145f,-218.75f, --3.90625f,15.5991f,-218.75f, -0.0f,13.7865f,-218.75f, -3.90625f,13.272f,-218.75f, --250.0f,16.7536f,-222.656f, --246.094f,16.7692f,-222.656f, --242.188f,17.6216f,-222.656f, --238.281f,17.7524f,-222.656f, --234.375f,15.7102f,-222.656f, --230.469f,13.9934f,-222.656f, --226.563f,13.1311f,-222.656f, --222.656f,13.6218f,-222.656f, --218.75f,13.8812f,-222.656f, --214.844f,13.6928f,-222.656f, --210.938f,13.2498f,-222.656f, --207.031f,13.9199f,-222.656f, --203.125f,14.8224f,-222.656f, --199.219f,14.7821f,-222.656f, --195.313f,14.4118f,-222.656f, --191.406f,13.2421f,-222.656f, --187.5f,13.1953f,-222.656f, --183.594f,11.9441f,-222.656f, --179.688f,11.8006f,-222.656f, --175.781f,11.2509f,-222.656f, --171.875f,9.7863f,-222.656f, --167.969f,8.85086f,-222.656f, --164.063f,10.6896f,-222.656f, --160.156f,12.9132f,-222.656f, --156.25f,13.602f,-222.656f, --152.344f,15.3711f,-222.656f, --148.438f,16.1768f,-222.656f, --144.531f,16.9203f,-222.656f, --140.625f,17.0404f,-222.656f, --136.719f,18.4968f,-222.656f, --132.813f,18.8222f,-222.656f, --128.906f,19.2736f,-222.656f, --125.0f,19.1956f,-222.656f, --121.094f,18.5998f,-222.656f, --117.188f,18.5054f,-222.656f, --113.281f,19.68f,-222.656f, --109.375f,19.5038f,-222.656f, --105.469f,19.4749f,-222.656f, --101.563f,18.7504f,-222.656f, --97.6563f,18.6121f,-222.656f, --93.75f,19.1119f,-222.656f, --89.8438f,20.5347f,-222.656f, --85.9375f,21.4412f,-222.656f, --82.0313f,22.187f,-222.656f, --78.125f,22.9384f,-222.656f, --74.2188f,22.5226f,-222.656f, --70.3125f,22.7323f,-222.656f, --66.4063f,23.4931f,-222.656f, --62.5f,24.6895f,-222.656f, --58.5938f,24.9745f,-222.656f, --54.6875f,24.801f,-222.656f, --50.7813f,23.2235f,-222.656f, --46.875f,22.4973f,-222.656f, --42.9688f,23.9826f,-222.656f, --39.0625f,23.4458f,-222.656f, --35.1563f,22.66f,-222.656f, --31.25f,20.8011f,-222.656f, --27.3438f,18.877f,-222.656f, --23.4375f,17.9999f,-222.656f, --19.5313f,18.2206f,-222.656f, --15.625f,17.8501f,-222.656f, --11.7188f,16.2125f,-222.656f, --7.8125f,15.4897f,-222.656f, --3.90625f,14.2048f,-222.656f, -0.0f,13.1443f,-222.656f, -3.90625f,13.0199f,-222.656f, --250.0f,15.9959f,-226.563f, --246.094f,16.3902f,-226.563f, --242.188f,17.2433f,-226.563f, --238.281f,16.8903f,-226.563f, --234.375f,16.2616f,-226.563f, --230.469f,16.3335f,-226.563f, --226.563f,15.3662f,-226.563f, --222.656f,14.6429f,-226.563f, --218.75f,15.2987f,-226.563f, --214.844f,15.1249f,-226.563f, --210.938f,14.6321f,-226.563f, --207.031f,15.402f,-226.563f, --203.125f,15.5803f,-226.563f, --199.219f,15.8024f,-226.563f, --195.313f,14.9564f,-226.563f, --191.406f,14.7272f,-226.563f, --187.5f,14.0749f,-226.563f, --183.594f,12.2838f,-226.563f, --179.688f,12.0268f,-226.563f, --175.781f,10.904f,-226.563f, --171.875f,10.0049f,-226.563f, --167.969f,9.85558f,-226.563f, --164.063f,11.873f,-226.563f, --160.156f,14.0684f,-226.563f, --156.25f,15.4765f,-226.563f, --152.344f,16.7458f,-226.563f, --148.438f,17.9359f,-226.563f, --144.531f,18.4507f,-226.563f, --140.625f,18.3457f,-226.563f, --136.719f,20.0059f,-226.563f, --132.813f,20.3125f,-226.563f, --128.906f,19.751f,-226.563f, --125.0f,19.8084f,-226.563f, --121.094f,19.9091f,-226.563f, --117.188f,20.3401f,-226.563f, --113.281f,20.8121f,-226.563f, --109.375f,20.5705f,-226.563f, --105.469f,20.9909f,-226.563f, --101.563f,20.4171f,-226.563f, --97.6563f,19.834f,-226.563f, --93.75f,19.9289f,-226.563f, --89.8438f,20.4305f,-226.563f, --85.9375f,21.4097f,-226.563f, --82.0313f,21.9666f,-226.563f, --78.125f,22.5232f,-226.563f, --74.2188f,22.2049f,-226.563f, --70.3125f,22.7045f,-226.563f, --66.4063f,23.7933f,-226.563f, --62.5f,24.5938f,-226.563f, --58.5938f,24.6161f,-226.563f, --54.6875f,23.6008f,-226.563f, --50.7813f,21.9411f,-226.563f, --46.875f,21.6164f,-226.563f, --42.9688f,22.5551f,-226.563f, --39.0625f,22.5032f,-226.563f, --35.1563f,21.5165f,-226.563f, --31.25f,19.8362f,-226.563f, --27.3438f,17.5967f,-226.563f, --23.4375f,15.6932f,-226.563f, --19.5313f,15.7774f,-226.563f, --15.625f,15.6405f,-226.563f, --11.7188f,14.7549f,-226.563f, --7.8125f,14.3205f,-226.563f, --3.90625f,13.2947f,-226.563f, -0.0f,11.9266f,-226.563f, -3.90625f,11.9733f,-226.563f, --250.0f,15.2423f,-230.469f, --246.094f,16.2143f,-230.469f, --242.188f,17.2462f,-230.469f, --238.281f,17.7941f,-230.469f, --234.375f,18.4029f,-230.469f, --230.469f,18.5726f,-230.469f, --226.563f,17.4729f,-230.469f, --222.656f,15.9467f,-230.469f, --218.75f,15.5021f,-230.469f, --214.844f,15.7096f,-230.469f, --210.938f,15.6276f,-230.469f, --207.031f,15.7025f,-230.469f, --203.125f,14.8851f,-230.469f, --199.219f,14.87f,-230.469f, --195.313f,14.3971f,-230.469f, --191.406f,14.5771f,-230.469f, --187.5f,13.8163f,-230.469f, --183.594f,12.7605f,-230.469f, --179.688f,12.587f,-230.469f, --175.781f,11.0727f,-230.469f, --171.875f,10.0166f,-230.469f, --167.969f,12.5787f,-230.469f, --164.063f,13.3613f,-230.469f, --160.156f,14.7537f,-230.469f, --156.25f,15.9879f,-230.469f, --152.344f,17.6792f,-230.469f, --148.438f,18.5224f,-230.469f, --144.531f,18.5026f,-230.469f, --140.625f,19.4852f,-230.469f, --136.719f,20.3222f,-230.469f, --132.813f,20.2809f,-230.469f, --128.906f,21.0408f,-230.469f, --125.0f,20.4729f,-230.469f, --121.094f,20.8829f,-230.469f, --117.188f,21.532f,-230.469f, --113.281f,21.3373f,-230.469f, --109.375f,22.0014f,-230.469f, --105.469f,22.1484f,-230.469f, --101.563f,21.7053f,-230.469f, --97.6563f,20.5255f,-230.469f, --93.75f,19.6269f,-230.469f, --89.8438f,20.0012f,-230.469f, --85.9375f,21.0697f,-230.469f, --82.0313f,21.8192f,-230.469f, --78.125f,22.7525f,-230.469f, --74.2188f,22.3932f,-230.469f, --70.3125f,22.0383f,-230.469f, --66.4063f,22.5989f,-230.469f, --62.5f,23.0428f,-230.469f, --58.5938f,22.4512f,-230.469f, --54.6875f,21.5848f,-230.469f, --50.7813f,20.085f,-230.469f, --46.875f,19.9106f,-230.469f, --42.9688f,20.5256f,-230.469f, --39.0625f,20.2072f,-230.469f, --35.1563f,18.9414f,-230.469f, --31.25f,17.9342f,-230.469f, --27.3438f,15.3472f,-230.469f, --23.4375f,13.2173f,-230.469f, --19.5313f,13.1448f,-230.469f, --15.625f,13.7506f,-230.469f, --11.7188f,12.7439f,-230.469f, --7.8125f,12.5338f,-230.469f, --3.90625f,12.0435f,-230.469f, -0.0f,11.0483f,-230.469f, -3.90625f,10.4619f,-230.469f, --250.0f,15.6879f,-234.375f, --246.094f,17.6667f,-234.375f, --242.188f,18.8427f,-234.375f, --238.281f,19.6527f,-234.375f, --234.375f,19.7979f,-234.375f, --230.469f,19.8698f,-234.375f, --226.563f,19.1736f,-234.375f, --222.656f,16.9995f,-234.375f, --218.75f,15.4573f,-234.375f, --214.844f,15.6294f,-234.375f, --210.938f,15.4315f,-234.375f, --207.031f,15.1239f,-234.375f, --203.125f,14.669f,-234.375f, --199.219f,14.4586f,-234.375f, --195.313f,14.1329f,-234.375f, --191.406f,14.0558f,-234.375f, --187.5f,13.3746f,-234.375f, --183.594f,13.2348f,-234.375f, --179.688f,13.3354f,-234.375f, --175.781f,12.1532f,-234.375f, --171.875f,11.4785f,-234.375f, --167.969f,12.7174f,-234.375f, --164.063f,14.0617f,-234.375f, --160.156f,15.3367f,-234.375f, --156.25f,16.6196f,-234.375f, --152.344f,17.6677f,-234.375f, --148.438f,18.475f,-234.375f, --144.531f,19.8205f,-234.375f, --140.625f,19.6973f,-234.375f, --136.719f,20.5952f,-234.375f, --132.813f,20.3507f,-234.375f, --128.906f,20.8729f,-234.375f, --125.0f,21.9377f,-234.375f, --121.094f,21.8916f,-234.375f, --117.188f,21.9614f,-234.375f, --113.281f,22.1752f,-234.375f, --109.375f,22.2881f,-234.375f, --105.469f,23.1063f,-234.375f, --101.563f,23.4826f,-234.375f, --97.6563f,22.5968f,-234.375f, --93.75f,21.3142f,-234.375f, --89.8438f,19.9609f,-234.375f, --85.9375f,21.4353f,-234.375f, --82.0313f,21.9716f,-234.375f, --78.125f,22.6918f,-234.375f, --74.2188f,21.9561f,-234.375f, --70.3125f,21.3085f,-234.375f, --66.4063f,21.4104f,-234.375f, --62.5f,21.4904f,-234.375f, --58.5938f,20.2467f,-234.375f, --54.6875f,19.1535f,-234.375f, --50.7813f,17.9598f,-234.375f, --46.875f,18.0449f,-234.375f, --42.9688f,18.3612f,-234.375f, --39.0625f,17.5008f,-234.375f, --35.1563f,16.7819f,-234.375f, --31.25f,15.4328f,-234.375f, --27.3438f,13.9747f,-234.375f, --23.4375f,12.1868f,-234.375f, --19.5313f,12.0847f,-234.375f, --15.625f,11.926f,-234.375f, --11.7188f,11.3058f,-234.375f, --7.8125f,11.0187f,-234.375f, --3.90625f,10.1275f,-234.375f, -0.0f,9.73133f,-234.375f, -3.90625f,8.85224f,-234.375f, --250.0f,16.6463f,-238.281f, --246.094f,18.8582f,-238.281f, --242.188f,19.6269f,-238.281f, --238.281f,20.3222f,-238.281f, --234.375f,20.8316f,-238.281f, --230.469f,20.6072f,-238.281f, --226.563f,19.2331f,-238.281f, --222.656f,18.0021f,-238.281f, --218.75f,16.4891f,-238.281f, --214.844f,15.7845f,-238.281f, --210.938f,15.4622f,-238.281f, --207.031f,14.3459f,-238.281f, --203.125f,14.6544f,-238.281f, --199.219f,13.7779f,-238.281f, --195.313f,13.4199f,-238.281f, --191.406f,13.2089f,-238.281f, --187.5f,12.5036f,-238.281f, --183.594f,12.6398f,-238.281f, --179.688f,13.015f,-238.281f, --175.781f,12.659f,-238.281f, --171.875f,13.2801f,-238.281f, --167.969f,13.9547f,-238.281f, --164.063f,14.8792f,-238.281f, --160.156f,16.4144f,-238.281f, --156.25f,17.1062f,-238.281f, --152.344f,17.9028f,-238.281f, --148.438f,19.1823f,-238.281f, --144.531f,20.6903f,-238.281f, --140.625f,19.9053f,-238.281f, --136.719f,20.8795f,-238.281f, --132.813f,21.7034f,-238.281f, --128.906f,21.8373f,-238.281f, --125.0f,22.5134f,-238.281f, --121.094f,22.7918f,-238.281f, --117.188f,23.1126f,-238.281f, --113.281f,23.0308f,-238.281f, --109.375f,23.7212f,-238.281f, --105.469f,24.6127f,-238.281f, --101.563f,24.5942f,-238.281f, --97.6563f,24.0315f,-238.281f, --93.75f,23.2191f,-238.281f, --89.8438f,21.3372f,-238.281f, --85.9375f,20.6395f,-238.281f, --82.0313f,22.2808f,-238.281f, --78.125f,22.2977f,-238.281f, --74.2188f,21.5802f,-238.281f, --70.3125f,20.5131f,-238.281f, --66.4063f,20.0882f,-238.281f, --62.5f,19.9865f,-238.281f, --58.5938f,19.1423f,-238.281f, --54.6875f,16.917f,-238.281f, --50.7813f,16.0256f,-238.281f, --46.875f,15.4122f,-238.281f, --42.9688f,15.0531f,-238.281f, --39.0625f,15.8819f,-238.281f, --35.1563f,14.3724f,-238.281f, --31.25f,12.993f,-238.281f, --27.3438f,11.8948f,-238.281f, --23.4375f,10.1339f,-238.281f, --19.5313f,10.4205f,-238.281f, --15.625f,10.7339f,-238.281f, --11.7188f,9.86852f,-238.281f, --7.8125f,8.89818f,-238.281f, --3.90625f,8.20848f,-238.281f, -0.0f,7.89095f,-238.281f, -3.90625f,7.99527f,-238.281f, --250.0f,16.461f,-242.188f, --246.094f,18.8623f,-242.188f, --242.188f,19.6097f,-242.188f, --238.281f,20.8167f,-242.188f, --234.375f,21.0667f,-242.188f, --230.469f,20.3337f,-242.188f, --226.563f,18.9993f,-242.188f, --222.656f,17.8141f,-242.188f, --218.75f,17.3651f,-242.188f, --214.844f,16.1703f,-242.188f, --210.938f,15.3612f,-242.188f, --207.031f,14.5062f,-242.188f, --203.125f,14.0333f,-242.188f, --199.219f,13.0731f,-242.188f, --195.313f,13.0716f,-242.188f, --191.406f,12.2773f,-242.188f, --187.5f,12.1599f,-242.188f, --183.594f,12.0841f,-242.188f, --179.688f,11.1979f,-242.188f, --175.781f,11.7767f,-242.188f, --171.875f,13.5192f,-242.188f, --167.969f,13.6117f,-242.188f, --164.063f,14.5377f,-242.188f, --160.156f,16.1128f,-242.188f, --156.25f,17.0591f,-242.188f, --152.344f,18.0547f,-242.188f, --148.438f,19.9927f,-242.188f, --144.531f,20.5592f,-242.188f, --140.625f,20.5602f,-242.188f, --136.719f,20.6585f,-242.188f, --132.813f,22.6924f,-242.188f, --128.906f,23.4786f,-242.188f, --125.0f,23.9921f,-242.188f, --121.094f,24.3221f,-242.188f, --117.188f,24.7845f,-242.188f, --113.281f,24.0995f,-242.188f, --109.375f,25.5836f,-242.188f, --105.469f,25.1932f,-242.188f, --101.563f,25.0022f,-242.188f, --97.6563f,24.569f,-242.188f, --93.75f,24.5749f,-242.188f, --89.8438f,22.6678f,-242.188f, --85.9375f,20.6652f,-242.188f, --82.0313f,21.1719f,-242.188f, --78.125f,21.9102f,-242.188f, --74.2188f,20.9512f,-242.188f, --70.3125f,19.1099f,-242.188f, --66.4063f,18.2366f,-242.188f, --62.5f,16.9751f,-242.188f, --58.5938f,16.938f,-242.188f, --54.6875f,16.3692f,-242.188f, --50.7813f,14.5702f,-242.188f, --46.875f,13.5527f,-242.188f, --42.9688f,13.0169f,-242.188f, --39.0625f,11.9599f,-242.188f, --35.1563f,11.4675f,-242.188f, --31.25f,10.1264f,-242.188f, --27.3438f,9.05124f,-242.188f, --23.4375f,8.17722f,-242.188f, --19.5313f,8.42066f,-242.188f, --15.625f,8.13199f,-242.188f, --11.7188f,7.70744f,-242.188f, --7.8125f,7.06448f,-242.188f, --3.90625f,6.2428f,-242.188f, -0.0f,6.35893f,-242.188f, -3.90625f,6.40337f,-242.188f, --250.0f,16.6546f,-246.094f, --246.094f,17.6689f,-246.094f, --242.188f,18.7575f,-246.094f, --238.281f,20.3967f,-246.094f, --234.375f,20.3065f,-246.094f, --230.469f,20.2082f,-246.094f, --226.563f,19.5383f,-246.094f, --222.656f,17.7409f,-246.094f, --218.75f,16.6708f,-246.094f, --214.844f,15.9584f,-246.094f, --210.938f,14.8412f,-246.094f, --207.031f,14.5591f,-246.094f, --203.125f,13.9049f,-246.094f, --199.219f,12.4723f,-246.094f, --195.313f,11.7361f,-246.094f, --191.406f,11.5463f,-246.094f, --187.5f,10.9687f,-246.094f, --183.594f,10.6795f,-246.094f, --179.688f,10.6856f,-246.094f, --175.781f,10.6342f,-246.094f, --171.875f,12.061f,-246.094f, --167.969f,12.3131f,-246.094f, --164.063f,13.8453f,-246.094f, --160.156f,15.3522f,-246.094f, --156.25f,16.575f,-246.094f, --152.344f,17.953f,-246.094f, --148.438f,18.9271f,-246.094f, --144.531f,19.6463f,-246.094f, --140.625f,20.0348f,-246.094f, --136.719f,20.8966f,-246.094f, --132.813f,22.7081f,-246.094f, --128.906f,24.2289f,-246.094f, --125.0f,24.3296f,-246.094f, --121.094f,25.513f,-246.094f, --117.188f,26.0616f,-246.094f, --113.281f,25.9026f,-246.094f, --109.375f,25.3793f,-246.094f, --105.469f,26.0086f,-246.094f, --101.563f,25.9668f,-246.094f, --97.6563f,25.4377f,-246.094f, --93.75f,24.6398f,-246.094f, --89.8438f,22.6277f,-246.094f, --85.9375f,20.9377f,-246.094f, --82.0313f,20.5815f,-246.094f, --78.125f,20.2521f,-246.094f, --74.2188f,19.1439f,-246.094f, --70.3125f,17.8492f,-246.094f, --66.4063f,16.6347f,-246.094f, --62.5f,15.9154f,-246.094f, --58.5938f,14.2098f,-246.094f, --54.6875f,13.5957f,-246.094f, --50.7813f,12.5676f,-246.094f, --46.875f,11.2422f,-246.094f, --42.9688f,10.426f,-246.094f, --39.0625f,10.1665f,-246.094f, --35.1563f,9.19605f,-246.094f, --31.25f,7.36042f,-246.094f, --27.3438f,5.74959f,-246.094f, --23.4375f,5.41512f,-246.094f, --19.5313f,6.03312f,-246.094f, --15.625f,5.93285f,-246.094f, --11.7188f,5.3331f,-246.094f, --7.8125f,5.48059f,-246.094f, --3.90625f,4.92566f,-246.094f, -0.0f,5.05645f,-246.094f, -3.90625f,6.09425f,-246.094f, --250.0f,17.2418f,-250.0f, --246.094f,17.9679f,-250.0f, --242.188f,19.359f,-250.0f, --238.281f,19.3277f,-250.0f, --234.375f,20.1575f,-250.0f, --230.469f,19.8999f,-250.0f, --226.563f,18.9681f,-250.0f, --222.656f,17.7696f,-250.0f, --218.75f,15.6199f,-250.0f, --214.844f,14.6555f,-250.0f, --210.938f,13.0514f,-250.0f, --207.031f,13.6029f,-250.0f, --203.125f,13.1455f,-250.0f, --199.219f,12.0056f,-250.0f, --195.313f,11.1773f,-250.0f, --191.406f,10.7263f,-250.0f, --187.5f,10.2543f,-250.0f, --183.594f,9.76389f,-250.0f, --179.688f,9.00623f,-250.0f, --175.781f,9.47424f,-250.0f, --171.875f,10.8011f,-250.0f, --167.969f,12.4395f,-250.0f, --164.063f,13.7736f,-250.0f, --160.156f,14.0938f,-250.0f, --156.25f,15.8447f,-250.0f, --152.344f,17.1975f,-250.0f, --148.438f,17.963f,-250.0f, --144.531f,19.3662f,-250.0f, --140.625f,20.309f,-250.0f, --136.719f,21.9063f,-250.0f, --132.813f,22.8363f,-250.0f, --128.906f,24.0073f,-250.0f, --125.0f,25.2989f,-250.0f, --121.094f,26.2944f,-250.0f, --117.188f,27.4482f,-250.0f, --113.281f,27.4823f,-250.0f, --109.375f,27.2835f,-250.0f, --105.469f,27.4754f,-250.0f, --101.563f,27.7731f,-250.0f, --97.6563f,26.6981f,-250.0f, --93.75f,24.4699f,-250.0f, --89.8438f,22.81f,-250.0f, --85.9375f,21.6739f,-250.0f, --82.0313f,19.8713f,-250.0f, --78.125f,18.5848f,-250.0f, --74.2188f,17.7134f,-250.0f, --70.3125f,15.5276f,-250.0f, --66.4063f,14.6805f,-250.0f, --62.5f,14.0332f,-250.0f, --58.5938f,12.1429f,-250.0f, --54.6875f,10.3027f,-250.0f, --50.7813f,9.68001f,-250.0f, --46.875f,8.12561f,-250.0f, --42.9688f,8.26581f,-250.0f, --39.0625f,7.98056f,-250.0f, --35.1563f,7.43215f,-250.0f, --31.25f,6.33038f,-250.0f, --27.3438f,4.62549f,-250.0f, --23.4375f,3.83616f,-250.0f, --19.5313f,4.24597f,-250.0f, --15.625f,3.79997f,-250.0f, --11.7188f,3.74461f,-250.0f, --7.8125f,3.79853f,-250.0f, --3.90625f,3.95418f,-250.0f, -0.0f,5.70623f,-250.0f, -3.90625f,6.31953f,-250.0f, -}; - -btScalar Landscape08Nml[] = { --0.193879f,0.980285f,-0.0381128f, --0.101407f,0.994799f,-0.00961843f, --0.17812f,0.983422f,0.0339701f, --0.107869f,0.990758f,0.0822321f, --0.150224f,0.986838f,0.0598614f, --0.176421f,0.983338f,0.0438458f, -0.00771709f,0.999873f,0.0139132f, --0.0458501f,0.998747f,-0.0200731f, -0.170866f,0.984802f,-0.0311488f, -0.198428f,0.979783f,-0.0255296f, -0.223966f,0.969797f,0.0966125f, -0.319719f,0.946459f,0.0446654f, -0.155788f,0.942148f,0.296794f, -0.226142f,0.945324f,0.234996f, -0.0234229f,0.954977f,0.295752f, --0.0213542f,0.981077f,0.192434f, --0.0320299f,0.976907f,0.211248f, --0.0305686f,0.97015f,0.240572f, --0.00290395f,0.990031f,0.14082f, --0.0740282f,0.98339f,0.165723f, -0.0359831f,0.998663f,0.0371117f, --0.048977f,0.998654f,0.0171003f, -0.119085f,0.992879f,0.00312204f, -0.163687f,0.985928f,0.0339365f, -0.233927f,0.967265f,0.0983717f, -0.258555f,0.954734f,0.147076f, -0.185228f,0.98177f,0.0426319f, -0.171781f,0.975163f,0.139813f, -0.312497f,0.949826f,0.0132586f, -0.315278f,0.937034f,0.150223f, -0.455936f,0.889912f,-0.0133666f, -0.444363f,0.88993f,0.102789f, -0.477095f,0.878821f,-0.00729384f, -0.442265f,0.892911f,0.0843273f, -0.441901f,0.89445f,-0.0684218f, -0.356563f,0.929766f,-0.091634f, -0.46452f,0.88048f,-0.0947459f, -0.399286f,0.883106f,-0.246362f, -0.430625f,0.899506f,-0.073831f, -0.418125f,0.862027f,-0.286498f, -0.390492f,0.919986f,-0.0337736f, -0.451928f,0.884249f,-0.117748f, -0.389473f,0.920638f,-0.0271218f, -0.401911f,0.911214f,-0.0903147f, -0.411594f,0.910246f,-0.0451926f, -0.385985f,0.916603f,-0.104187f, -0.406515f,0.904587f,-0.128329f, -0.375686f,0.920382f,-0.108425f, -0.421893f,0.886378f,-0.190632f, -0.362475f,0.891842f,-0.270609f, -0.382406f,0.917607f,-0.108459f, -0.380095f,0.864773f,-0.32817f, -0.206545f,0.977978f,-0.0299668f, -0.319336f,0.938074f,-0.134321f, --0.0276167f,0.998803f,0.0403598f, -0.0724517f,0.997355f,-0.00577643f, --0.170399f,0.974366f,0.146884f, --0.0444923f,0.976538f,0.210699f, --0.123713f,0.961736f,0.244457f, --0.0585476f,0.950932f,0.303809f, --0.0436638f,0.948824f,0.312774f, --0.0108452f,0.950133f,0.311655f, --0.0562151f,0.924389f,0.377285f, --0.024656f,0.918307f,0.3951f, --0.11936f,0.930674f,0.345831f, --0.21058f,0.936144f,0.281584f, --0.166672f,0.952976f,0.253095f, --0.262868f,0.958623f,0.109278f, --0.138859f,0.97532f,0.171667f, --0.166823f,0.980233f,0.106364f, --0.016911f,0.994026f,0.107828f, -0.014088f,0.986713f,0.161858f, --0.0269312f,0.989998f,0.138489f, --0.0681193f,0.995186f,0.0704648f, --0.241507f,0.962694f,0.122045f, --0.306148f,0.951983f,0.00131283f, --0.400562f,0.916076f,-0.0188573f, --0.46755f,0.872686f,-0.140772f, --0.451983f,0.886731f,-0.0970551f, --0.445163f,0.885181f,-0.135217f, --0.440559f,0.893764f,-0.0842181f, --0.44058f,0.883958f,-0.156548f, --0.530573f,0.842324f,-0.094771f, --0.559377f,0.815929f,-0.14614f, --0.675146f,0.724837f,-0.137074f, --0.671227f,0.729467f,-0.131655f, --0.627673f,0.767191f,-0.132076f, --0.630683f,0.736819f,-0.243592f, --0.548071f,0.819689f,-0.166518f, --0.526895f,0.799727f,-0.287781f, --0.521779f,0.83885f,-0.155167f, --0.501504f,0.822365f,-0.268719f, --0.465479f,0.867433f,-0.175756f, --0.453816f,0.862676f,-0.223251f, --0.458424f,0.854844f,-0.243083f, --0.470698f,0.860374f,-0.195446f, --0.485669f,0.830839f,-0.27172f, --0.494445f,0.85319f,-0.166102f, --0.418394f,0.865747f,-0.274642f, --0.405345f,0.892443f,-0.198093f, --0.287108f,0.926134f,-0.244631f, --0.325256f,0.923685f,-0.202519f, --0.192384f,0.91848f,-0.345518f, --0.208186f,0.935081f,-0.28685f, -0.0681073f,0.948251f,-0.310131f, -0.077158f,0.955715f,-0.283998f, -0.102278f,0.947499f,-0.302962f, -0.02043f,0.921087f,-0.388821f, -0.0627177f,0.929646f,-0.363077f, -0.0629047f,0.918578f,-0.390202f, --0.00415691f,0.947597f,-0.31944f, --0.00512929f,0.899538f,-0.436812f, --0.271944f,0.935195f,-0.226842f, --0.177509f,0.92231f,-0.343271f, --0.413186f,0.904845f,-0.102632f, --0.338265f,0.931446f,-0.13411f, --0.418276f,0.90315f,-0.0967731f, --0.404177f,0.914278f,-0.0271442f, --0.400569f,0.902696f,-0.157112f, --0.429625f,0.894308f,-0.125039f, --0.29004f,0.948484f,-0.127491f, --0.188203f,0.980777f,0.0515283f, --0.0585039f,0.997556f,-0.0381961f, --0.133431f,0.99094f,0.0152943f, --0.143343f,0.971126f,-0.1907f, --0.24516f,0.938627f,-0.242644f, --0.188833f,0.958258f,-0.214673f, --0.174705f,0.963776f,-0.201528f, --0.196517f,0.95296f,-0.230756f, --0.128653f,0.987396f,-0.0921772f, --0.120365f,0.975049f,-0.186527f, -0.0117596f,0.998991f,0.0433545f, --0.146882f,0.98666f,-0.0701983f, --0.218442f,0.971087f,-0.0962923f, --0.179096f,0.983284f,-0.0328244f, -0.0658277f,0.997324f,0.0318063f, -0.120963f,0.992647f,0.00454206f, -0.0263542f,0.988052f,0.151849f, -0.0179305f,0.957276f,0.288619f, -0.0987151f,0.955923f,0.276526f, -0.113577f,0.970939f,0.210662f, -0.111989f,0.989066f,0.0959572f, -0.0937332f,0.995324f,-0.0233266f, -0.0889156f,0.995493f,-0.0329669f, -0.214527f,0.976717f,-0.0013568f, -0.281036f,0.957864f,-0.0592866f, -0.349427f,0.927689f,-0.131507f, -0.460507f,0.876585f,-0.139754f, -0.465208f,0.877856f,-0.1138f, -0.432422f,0.897621f,-0.0853653f, -0.392928f,0.918987f,-0.032723f, -0.389134f,0.920603f,0.0326418f, -0.40247f,0.914003f,0.0511488f, -0.41651f,0.90858f,0.031652f, -0.468908f,0.883168f,-0.0118055f, -0.497957f,0.862594f,-0.0892785f, -0.342146f,0.929254f,-0.139366f, -0.262957f,0.964807f,-0.00115352f, -0.156573f,0.98302f,0.095691f, --0.0479214f,0.988417f,0.143995f, --0.198695f,0.970386f,0.13737f, --0.222539f,0.963461f,0.14906f, --0.145574f,0.943362f,0.298121f, --0.065459f,0.922659f,0.380021f, --0.0644219f,0.950539f,0.303852f, --0.126762f,0.967843f,0.217283f, --0.017815f,0.980142f,0.197496f, -0.0660407f,0.994277f,0.0839804f, --0.101583f,0.994471f,0.0266049f, --0.224345f,0.969139f,0.102176f, --0.280297f,0.958092f,0.0591033f, --0.402555f,0.91416f,-0.047541f, --0.458467f,0.883974f,-0.0916445f, --0.50134f,0.862765f,-0.0655406f, --0.644808f,0.754744f,-0.12077f, --0.636358f,0.756299f,-0.151855f, --0.556238f,0.818404f,-0.144268f, --0.504016f,0.849904f,-0.153725f, --0.404172f,0.887071f,-0.223046f, --0.360363f,0.894242f,-0.265463f, --0.432057f,0.840836f,-0.326069f, --0.4393f,0.818603f,-0.370006f, --0.249988f,0.890718f,-0.379642f, --0.114697f,0.874572f,-0.471135f, --0.0301956f,0.870113f,-0.491927f, -0.0871874f,0.907337f,-0.411263f, -0.0509325f,0.923392f,-0.380464f, --0.106299f,0.953821f,-0.280938f, --0.389809f,0.901657f,-0.187255f, --0.420279f,0.904001f,-0.0784108f, --0.360569f,0.922439f,-0.138186f, --0.332116f,0.91853f,-0.214478f, --0.305854f,0.899541f,-0.311896f, --0.11957f,0.95083f,-0.285701f, --0.0843961f,0.977455f,-0.193542f, --0.186555f,0.968589f,-0.164414f, --0.1142f,0.975963f,-0.185618f, --0.138309f,0.943055f,-0.30252f, --0.101226f,0.981339f,-0.163482f, --0.184633f,0.97099f,-0.151951f, --0.239394f,0.95355f,-0.182845f, --0.0575173f,0.989733f,-0.130847f, -0.0688205f,0.993792f,0.0874178f, --0.0714424f,0.990397f,0.118361f, --0.0225247f,0.994972f,0.0975878f, -0.167362f,0.976776f,0.133786f, -0.156506f,0.98511f,0.0711603f, -0.198564f,0.979194f,0.0418473f, -0.173408f,0.984455f,-0.0278778f, -0.108869f,0.989375f,-0.0963545f, -0.224679f,0.96015f,-0.166226f, -0.339104f,0.91731f,-0.208688f, -0.367935f,0.88797f,-0.275922f, -0.418707f,0.869398f,-0.262357f, -0.420889f,0.892687f,-0.161129f, -0.397172f,0.910077f,-0.118378f, -0.374326f,0.920598f,-0.11126f, -0.397932f,0.911721f,-0.102056f, -0.386888f,0.911258f,-0.141166f, -0.41482f,0.902273f,-0.117593f, -0.501715f,0.859192f,-0.100356f, -0.491949f,0.863362f,-0.112214f, -0.357466f,0.931719f,-0.0641779f, -0.171333f,0.982821f,-0.068616f, -0.100623f,0.994346f,0.0339287f, --0.0698557f,0.996834f,0.0379692f, --0.194026f,0.980994f,0.00220452f, --0.288205f,0.957419f,0.0169548f, --0.304635f,0.947239f,0.0996808f, --0.10216f,0.973655f,0.20386f, -0.100532f,0.974742f,0.199427f, --0.0238908f,0.99964f,0.0121747f, --0.00850096f,0.997624f,-0.0683673f, -0.116859f,0.992157f,-0.044359f, --0.0433286f,0.998946f,-0.0151181f, --0.258294f,0.961617f,-0.0926162f, --0.256378f,0.96262f,-0.0873673f, --0.327211f,0.940376f,-0.0928767f, --0.431734f,0.888327f,-0.15646f, --0.514253f,0.844258f,-0.150905f, --0.599748f,0.789083f,-0.132858f, --0.620824f,0.749219f,-0.230756f, --0.533018f,0.803035f,-0.266508f, --0.441513f,0.840682f,-0.313561f, --0.38701f,0.854241f,-0.347124f, --0.380219f,0.879441f,-0.286385f, --0.39628f,0.874175f,-0.280679f, --0.390488f,0.846052f,-0.362926f, --0.205032f,0.876667f,-0.435221f, --0.00372872f,0.883142f,-0.46909f, --0.0083869f,0.837348f,-0.546606f, --0.00127167f,0.831923f,-0.55489f, --0.11424f,0.875282f,-0.469926f, --0.256213f,0.933918f,-0.249305f, --0.393049f,0.915109f,-0.0899313f, --0.484342f,0.863396f,-0.141282f, --0.32612f,0.940905f,-0.0913441f, --0.240051f,0.956808f,-0.163992f, --0.189326f,0.934609f,-0.301099f, --0.228613f,0.900757f,-0.369288f, --0.206601f,0.953154f,-0.220936f, --0.220523f,0.958575f,-0.180285f, --0.0691943f,0.98249f,-0.172992f, -0.0652464f,0.984331f,-0.163816f, --0.308082f,0.909128f,-0.280306f, --0.234588f,0.948864f,-0.211249f, --0.164432f,0.95809f,-0.234578f, --0.206026f,0.945244f,-0.253116f, --0.143287f,0.989535f,-0.0170174f, -0.0124441f,0.996035f,0.0880878f, -0.00356068f,0.999352f,-0.0358152f, -0.110457f,0.993318f,-0.0334531f, -0.202646f,0.978802f,0.0296789f, -0.245502f,0.969355f,0.00893075f, -0.235742f,0.966989f,-0.096741f, -0.211469f,0.957228f,-0.197474f, -0.297424f,0.906479f,-0.299724f, -0.384843f,0.8614f,-0.331489f, -0.405425f,0.833969f,-0.374335f, -0.330388f,0.8594f,-0.390224f, -0.318232f,0.891429f,-0.32262f, -0.388106f,0.870631f,-0.302284f, -0.354731f,0.863719f,-0.357989f, -0.344798f,0.878386f,-0.330988f, -0.405293f,0.884611f,-0.230654f, -0.388923f,0.889959f,-0.23814f, -0.464087f,0.861962f,-0.20407f, -0.454884f,0.878774f,-0.144348f, -0.334448f,0.940492f,-0.0601651f, -0.155367f,0.984248f,-0.0843604f, -0.0216917f,0.991768f,-0.126198f, --0.0136477f,0.995915f,-0.089255f, --0.167328f,0.979282f,-0.114052f, --0.307453f,0.946588f,-0.0971837f, --0.335506f,0.9366f,-0.101072f, --0.175739f,0.978185f,-0.110768f, -0.119064f,0.992411f,-0.0307238f, -0.11077f,0.993829f,0.00590121f, -0.0501349f,0.998052f,-0.0371321f, -0.0267572f,0.997581f,-0.0641572f, --0.0614311f,0.997945f,0.0181992f, --0.171984f,0.984492f,-0.0345973f, --0.25243f,0.961435f,-0.109187f, --0.338599f,0.935923f,-0.0969507f, --0.406007f,0.913202f,-0.0349361f, --0.506218f,0.860674f,-0.0546185f, --0.568342f,0.8123f,-0.130983f, --0.570141f,0.791669f,-0.219544f, --0.495272f,0.816181f,-0.297581f, --0.441753f,0.829099f,-0.342707f, --0.433015f,0.854206f,-0.287802f, --0.452692f,0.8617f,-0.229223f, --0.349843f,0.914647f,-0.202562f, --0.26556f,0.912134f,-0.312233f, --0.238012f,0.870367f,-0.431058f, -0.0104117f,0.943359f,-0.331612f, -0.0744935f,0.949145f,-0.305899f, --0.0305186f,0.956187f,-0.291161f, --0.253914f,0.939488f,-0.229978f, --0.449831f,0.878563f,-0.160557f, --0.46937f,0.880955f,-0.0600792f, --0.456075f,0.88917f,-0.0370459f, --0.35963f,0.932902f,-0.0189682f, --0.136797f,0.989932f,0.0363352f, --0.0613131f,0.996495f,-0.0569106f, --0.21207f,0.964351f,-0.158282f, --0.303853f,0.931291f,-0.200924f, --0.14101f,0.957182f,-0.252823f, --0.0888984f,0.919027f,-0.384041f, -0.0067746f,0.936029f,-0.351857f, --0.277531f,0.936633f,-0.213766f, --0.206375f,0.947006f,-0.246148f, --0.159145f,0.94264f,-0.293433f, --0.254895f,0.932893f,-0.254437f, --0.289527f,0.928279f,-0.233391f, --0.0765713f,0.988951f,-0.126934f, -0.118605f,0.992812f,0.0160497f, -0.122094f,0.985714f,-0.116021f, -0.123131f,0.980876f,-0.150734f, -0.257926f,0.962137f,-0.0881221f, -0.397575f,0.90803f,-0.131971f, -0.301628f,0.898949f,-0.317666f, -0.360055f,0.863992f,-0.351962f, -0.391486f,0.830925f,-0.39535f, -0.399022f,0.829333f,-0.391136f, -0.323505f,0.871183f,-0.369302f, -0.290418f,0.885393f,-0.362955f, -0.422788f,0.860776f,-0.283398f, -0.400499f,0.876008f,-0.26872f, -0.272367f,0.912425f,-0.305444f, -0.289824f,0.919053f,-0.267101f, -0.375469f,0.907173f,-0.189898f, -0.450189f,0.881784f,-0.140667f, -0.386895f,0.914552f,-0.117932f, -0.236065f,0.970562f,-0.0477698f, -0.25497f,0.966484f,0.0299776f, -0.147152f,0.978905f,-0.141747f, --0.0638684f,0.954892f,-0.290005f, --0.198781f,0.952653f,-0.230082f, --0.310279f,0.934977f,-0.171888f, --0.315284f,0.933842f,-0.168923f, --0.14676f,0.971582f,-0.185715f, --0.0201641f,0.976785f,-0.213271f, -0.0408109f,0.997823f,-0.0518006f, --0.000100141f,1.0f,-0.000656924f, -0.0713875f,0.992775f,0.096444f, --0.0699693f,0.997522f,-0.0073179f, --0.120441f,0.992484f,-0.0216487f, --0.200799f,0.979135f,-0.0312183f, --0.379156f,0.923729f,-0.0544518f, --0.468756f,0.883079f,0.0209709f, --0.451556f,0.890079f,0.0621062f, --0.476504f,0.87674f,-0.0653536f, --0.492274f,0.840855f,-0.22501f, --0.481358f,0.828756f,-0.285409f, --0.474733f,0.852404f,-0.219173f, --0.502016f,0.852123f,-0.147874f, --0.474734f,0.870513f,-0.12975f, --0.344408f,0.92173f,-0.178317f, --0.150823f,0.963991f,-0.21903f, --0.180013f,0.935609f,-0.303696f, --0.154788f,0.929555f,-0.334617f, -0.0226749f,0.973389f,-0.228036f, --0.128469f,0.975007f,-0.181264f, --0.302747f,0.952293f,-0.0385077f, --0.427741f,0.902872f,-0.0431169f, --0.47673f,0.871329f,-0.116249f, --0.489254f,0.866227f,-0.101399f, --0.407231f,0.911582f,-0.0564075f, --0.202058f,0.978968f,-0.0281862f, --0.00674228f,0.999486f,0.0313481f, --0.103136f,0.994637f,-0.00773474f, --0.196734f,0.967877f,-0.156554f, -0.0323675f,0.951182f,-0.306928f, -0.00132526f,0.886111f,-0.463472f, --0.0819618f,0.88666f,-0.4551f, --0.207835f,0.973361f,-0.0968142f, --0.157163f,0.972283f,-0.173105f, --0.187284f,0.955049f,-0.229797f, --0.285445f,0.950862f,-0.119931f, --0.25293f,0.964263f,-0.078892f, --0.219599f,0.957265f,-0.188204f, --0.0108412f,0.995374f,-0.0954668f, -0.265678f,0.963807f,-0.0221529f, -0.203794f,0.959343f,-0.195266f, -0.214345f,0.928921f,-0.301932f, -0.439386f,0.868442f,-0.22967f, -0.401404f,0.868685f,-0.290278f, -0.386804f,0.861005f,-0.330232f, -0.428054f,0.836263f,-0.342686f, -0.371108f,0.864198f,-0.339765f, -0.321515f,0.897421f,-0.302098f, -0.213518f,0.927633f,-0.306443f, -0.325579f,0.933219f,-0.151988f, -0.403183f,0.912352f,-0.0711129f, -0.337076f,0.932606f,-0.128942f, -0.295377f,0.932293f,-0.208765f, -0.330751f,0.922115f,-0.200767f, -0.392168f,0.906602f,-0.155808f, -0.373592f,0.925323f,-0.0648487f, -0.191498f,0.98018f,-0.0507507f, -0.210624f,0.977447f,-0.015309f, -0.322948f,0.945895f,0.0314047f, -0.111956f,0.981203f,-0.157186f, --0.247376f,0.91284f,-0.32485f, --0.344293f,0.903462f,-0.255381f, --0.317143f,0.916625f,-0.243348f, --0.146502f,0.958945f,-0.242819f, --0.0529375f,0.980235f,-0.19062f, --0.0439655f,0.993569f,-0.104344f, --0.0681441f,0.993007f,-0.0964036f, -0.0333119f,0.999062f,-0.0276811f, -0.0418264f,0.997289f,-0.0605344f, --0.133447f,0.982771f,-0.127878f, --0.204776f,0.9734f,-0.102754f, --0.405337f,0.909688f,-0.0903804f, --0.513852f,0.857872f,0.00340788f, --0.448907f,0.892038f,0.0524446f, --0.345596f,0.938383f,0.000245611f, --0.371875f,0.917654f,-0.14007f, --0.507047f,0.834221f,-0.216744f, --0.563482f,0.814021f,-0.140919f, --0.549501f,0.831415f,-0.0824446f, --0.452205f,0.89061f,-0.0482179f, --0.283377f,0.952701f,-0.109812f, --0.141817f,0.97445f,-0.174169f, --0.1066f,0.981505f,-0.159008f, --0.128743f,0.958435f,-0.254611f, -0.00656601f,0.946015f,-0.324056f, --0.2018f,0.913066f,-0.354384f, --0.37997f,0.904414f,-0.19406f, --0.423353f,0.890783f,-0.165163f, --0.446411f,0.883929f,-0.139235f, --0.512365f,0.844229f,-0.157352f, --0.38243f,0.91272f,-0.143839f, --0.20154f,0.953013f,-0.226157f, --0.104673f,0.977037f,-0.185586f, --0.0458745f,0.998873f,-0.0121567f, --0.0345945f,0.993617f,-0.107371f, -0.172752f,0.948616f,-0.265111f, -0.0733608f,0.946968f,-0.312842f, --0.16546f,0.93251f,-0.321012f, --0.129843f,0.991294f,-0.0218587f, --0.0514732f,0.996939f,-0.0588533f, --0.139666f,0.979954f,-0.142066f, --0.409538f,0.893138f,-0.185964f, --0.25948f,0.963277f,-0.0690542f, --0.106228f,0.993322f,-0.0450175f, --0.047863f,0.993002f,-0.107966f, -0.238746f,0.962198f,-0.131057f, -0.395076f,0.900486f,-0.181771f, -0.285693f,0.874669f,-0.391577f, -0.358513f,0.848133f,-0.39005f, -0.400938f,0.884343f,-0.239137f, -0.415724f,0.899223f,-0.136277f, -0.438653f,0.894164f,-0.0897495f, -0.361082f,0.930821f,-0.0565009f, -0.321158f,0.946416f,-0.0339725f, -0.242073f,0.961641f,-0.129024f, -0.199607f,0.93926f,-0.279192f, -0.404284f,0.887623f,-0.220636f, -0.424881f,0.860893f,-0.279892f, -0.291182f,0.870529f,-0.396727f, -0.302468f,0.897545f,-0.320822f, -0.33835f,0.898885f,-0.278433f, -0.289098f,0.929341f,-0.229667f, -0.170367f,0.971163f,-0.166783f, -0.129237f,0.986609f,-0.0995005f, -0.305057f,0.951694f,0.0349234f, -0.306439f,0.951736f,-0.0171507f, --0.0808802f,0.976235f,-0.201056f, --0.37625f,0.871862f,-0.313516f, --0.307717f,0.906797f,-0.28815f, --0.221648f,0.946026f,-0.236446f, --0.153972f,0.983161f,-0.0984244f, --0.108206f,0.992418f,-0.0582996f, --0.0581427f,0.997361f,-0.0434687f, -0.00296039f,0.999365f,-0.0355116f, -0.0891034f,0.995894f,-0.0160169f, --0.110645f,0.991801f,-0.0639364f, --0.218461f,0.975223f,-0.0348525f, --0.395365f,0.918398f,-0.0152307f, --0.576836f,0.816159f,-0.0338453f, --0.444941f,0.895556f,-0.00249309f, --0.286239f,0.957764f,-0.0274641f, --0.294715f,0.953259f,-0.0666355f, --0.477956f,0.87064f,-0.116377f, --0.574643f,0.800737f,-0.169131f, --0.54804f,0.808388f,-0.214852f, --0.442187f,0.863382f,-0.242986f, --0.246722f,0.934143f,-0.257887f, --0.157124f,0.964153f,-0.213827f, --0.112706f,0.987993f,-0.10568f, --0.0332674f,0.993709f,-0.106936f, -0.112688f,0.981964f,-0.151814f, --0.167f,0.962022f,-0.215928f, --0.466198f,0.854366f,-0.229606f, --0.414399f,0.885329f,-0.210869f, --0.461383f,0.855213f,-0.236084f, --0.488245f,0.847976f,-0.206287f, --0.351309f,0.900136f,-0.257559f, --0.14601f,0.942734f,-0.29989f, --0.222931f,0.937875f,-0.265879f, --0.195469f,0.970505f,-0.141106f, -0.07525f,0.994532f,-0.0724173f, -0.279727f,0.951429f,-0.128592f, -0.077712f,0.980159f,-0.182341f, --0.20264f,0.956685f,-0.209022f, --0.0986596f,0.987061f,-0.126403f, --0.0477559f,0.985147f,-0.164941f, --0.0669351f,0.983547f,-0.167793f, --0.331517f,0.915331f,-0.228616f, --0.350669f,0.900109f,-0.258526f, --0.179805f,0.971282f,-0.155824f, -0.0156578f,0.989915f,-0.140797f, -0.301547f,0.9226f,-0.240579f, -0.457383f,0.852861f,-0.25185f, -0.449776f,0.84917f,-0.276789f, -0.26609f,0.885033f,-0.381984f, -0.182331f,0.952085f,-0.245538f, -0.260541f,0.964562f,-0.0416928f, -0.408684f,0.907067f,0.101033f, -0.342263f,0.936545f,0.0757594f, -0.318298f,0.944991f,0.0753604f, -0.467785f,0.882822f,0.0424513f, -0.409568f,0.864687f,-0.290809f, -0.379738f,0.82358f,-0.421325f, -0.451329f,0.792384f,-0.410402f, -0.275091f,0.868881f,-0.411547f, -0.161796f,0.92881f,-0.333367f, -0.286521f,0.932696f,-0.219053f, -0.272475f,0.944744f,-0.182252f, -0.119383f,0.965719f,-0.230508f, --0.0212448f,0.971989f,-0.234063f, -0.226311f,0.969491f,-0.094178f, -0.326176f,0.942844f,-0.068215f, -0.104404f,0.994209f,-0.0254499f, --0.295807f,0.921372f,-0.252133f, --0.383855f,0.886842f,-0.257228f, --0.359597f,0.921141f,-0.148961f, --0.240318f,0.969399f,-0.0501282f, --0.0922578f,0.994071f,-0.0575481f, --0.0797027f,0.995693f,-0.047355f, --0.026569f,0.999636f,0.00472767f, -0.105393f,0.994402f,0.00758912f, --0.0968377f,0.99427f,-0.0452707f, --0.304918f,0.952227f,0.0169656f, --0.404524f,0.901318f,0.154875f, --0.513873f,0.850873f,0.109318f, --0.450348f,0.892744f,-0.0139455f, --0.274075f,0.961559f,-0.0169546f, --0.246789f,0.966677f,-0.068048f, --0.421796f,0.89143f,-0.165651f, --0.530762f,0.820949f,-0.210556f, --0.518596f,0.828643f,-0.210734f, --0.419929f,0.882924f,-0.210013f, --0.267086f,0.925885f,-0.26721f, --0.260528f,0.916111f,-0.304739f, --0.212437f,0.941505f,-0.261606f, --0.048105f,0.973033f,-0.225594f, -0.0765563f,0.979806f,-0.184712f, --0.093108f,0.98921f,-0.113109f, --0.45825f,0.862094f,-0.216335f, --0.388948f,0.902314f,-0.185873f, --0.448149f,0.871913f,-0.197307f, --0.488741f,0.854988f,-0.173574f, --0.313337f,0.916762f,-0.247724f, --0.157546f,0.938004f,-0.308753f, --0.267357f,0.911027f,-0.313926f, --0.236818f,0.920159f,-0.311809f, -0.000164176f,0.954985f,-0.296656f, -0.271822f,0.944232f,-0.185848f, -0.151331f,0.970946f,-0.185371f, --0.118147f,0.962507f,-0.244174f, -0.026977f,0.993643f,-0.109301f, -0.00824696f,0.988318f,-0.152184f, --0.049843f,0.98983f,-0.133236f, --0.292853f,0.946012f,-0.138915f, --0.402779f,0.899681f,-0.168355f, --0.216565f,0.962959f,-0.160656f, -0.0811851f,0.971223f,-0.223909f, -0.376654f,0.888442f,-0.262304f, -0.412611f,0.862287f,-0.293621f, -0.420494f,0.885689f,-0.196825f, -0.303261f,0.948914f,-0.0871512f, -0.0927021f,0.987654f,-0.12628f, -0.131263f,0.975894f,-0.174359f, -0.34789f,0.928255f,-0.131586f, -0.388684f,0.916314f,-0.0964015f, -0.334363f,0.935247f,-0.116251f, -0.500896f,0.857152f,-0.119971f, -0.598542f,0.784881f,-0.160341f, -0.47847f,0.803478f,-0.354245f, -0.40143f,0.813052f,-0.421663f, -0.177917f,0.923323f,-0.340324f, -0.0444056f,0.967329f,-0.249605f, -0.182957f,0.975679f,-0.12074f, -0.298547f,0.954355f,0.00877178f, -0.20958f,0.975318f,-0.0695111f, -0.014388f,0.988042f,-0.153512f, -0.159715f,0.970499f,-0.180618f, -0.22067f,0.966546f,-0.130745f, -0.121564f,0.992499f,-0.0129668f, --0.106928f,0.989668f,-0.0955226f, --0.432009f,0.877086f,-0.209972f, --0.412195f,0.894243f,-0.174429f, --0.247992f,0.954923f,-0.163162f, --0.103668f,0.985418f,-0.134925f, --0.118626f,0.990103f,-0.0749928f, --0.0679366f,0.995617f,-0.0642786f, -0.157737f,0.986207f,-0.0501565f, --0.132086f,0.989105f,-0.064997f, --0.385668f,0.914108f,0.125169f, --0.489653f,0.859555f,0.146305f, --0.451033f,0.881762f,0.138074f, --0.379544f,0.923663f,0.0528468f, --0.267976f,0.962936f,0.0307148f, --0.154653f,0.986101f,0.0607174f, --0.285519f,0.958009f,-0.0264139f, --0.517333f,0.83498f,-0.187551f, --0.544673f,0.81339f,-0.204273f, --0.443255f,0.872475f,-0.205697f, --0.212541f,0.959106f,-0.18693f, --0.144834f,0.956217f,-0.254307f, --0.219765f,0.912031f,-0.346271f, --0.054698f,0.959311f,-0.277002f, --0.0226538f,0.964658f,-0.262528f, --0.09277f,0.980401f,-0.173803f, --0.427129f,0.87184f,-0.2397f, --0.458168f,0.877303f,-0.142906f, --0.456008f,0.884075f,-0.102317f, --0.457836f,0.873049f,-0.167843f, --0.276231f,0.922652f,-0.269091f, --0.0986428f,0.965162f,-0.242345f, --0.166497f,0.944239f,-0.284061f, --0.221568f,0.881867f,-0.416194f, --0.047486f,0.902488f,-0.428089f, -0.159799f,0.906084f,-0.391761f, -0.154437f,0.936571f,-0.314616f, --0.0388024f,0.943344f,-0.329539f, -0.0179311f,0.971802f,-0.235116f, --0.0317957f,0.972144f,-0.232219f, --0.108238f,0.982139f,-0.153906f, --0.294778f,0.950488f,-0.098378f, --0.31352f,0.940894f,-0.128155f, --0.158161f,0.944104f,-0.289226f, -0.136392f,0.925587f,-0.353108f, -0.369725f,0.858345f,-0.355736f, -0.408427f,0.863142f,-0.296941f, -0.264495f,0.934318f,-0.238939f, -0.231394f,0.968992f,-0.0866717f, -0.180537f,0.980662f,-0.0755592f, -0.289728f,0.94884f,-0.125539f, -0.338081f,0.901985f,-0.268559f, -0.344111f,0.905129f,-0.249658f, -0.337921f,0.897299f,-0.284014f, -0.46242f,0.831252f,-0.308526f, -0.625979f,0.756355f,-0.18994f, -0.59942f,0.766009f,-0.232218f, -0.396651f,0.850096f,-0.346416f, -0.113051f,0.922761f,-0.368417f, --0.0568672f,0.928859f,-0.366041f, -0.0370994f,0.962262f,-0.269583f, -0.21844f,0.959083f,-0.180121f, -0.248457f,0.958661f,-0.138705f, -0.0562715f,0.995806f,-0.072134f, -0.151796f,0.987439f,-0.0438309f, -0.213126f,0.976907f,0.0151789f, -0.0825188f,0.995896f,-0.0371849f, --0.0293603f,0.995761f,-0.0871655f, --0.339382f,0.929166f,-0.146528f, --0.407976f,0.887929f,-0.212458f, --0.300706f,0.928797f,-0.216592f, --0.171876f,0.971688f,-0.162117f, --0.133134f,0.975354f,-0.175954f, --0.0436112f,0.969589f,-0.240823f, -0.0955252f,0.97277f,-0.211171f, --0.222971f,0.974797f,-0.00733171f, --0.502187f,0.842082f,0.19674f, --0.406382f,0.878535f,0.251057f, --0.403841f,0.907763f,0.113486f, --0.295941f,0.954472f,0.0374491f, --0.309098f,0.948653f,-0.0672074f, --0.212726f,0.977025f,0.0130525f, --0.199979f,0.978912f,0.0417118f, --0.374584f,0.922961f,-0.0884893f, --0.481248f,0.836641f,-0.261597f, --0.419239f,0.839768f,-0.345005f, --0.269419f,0.905569f,-0.327654f, --0.084614f,0.973021f,-0.214643f, --0.193736f,0.935164f,-0.296537f, --0.190273f,0.932167f,-0.307995f, --0.0917672f,0.986648f,-0.134552f, --0.101923f,0.994749f,0.009248f, --0.329353f,0.943234f,-0.0428565f, --0.527408f,0.832391f,-0.170191f, --0.427451f,0.895563f,-0.123505f, --0.337252f,0.917187f,-0.212202f, --0.254472f,0.911026f,-0.324462f, --0.191138f,0.941948f,-0.276043f, --0.0895186f,0.969134f,-0.229708f, --0.115141f,0.935532f,-0.33395f, --0.0316994f,0.925937f,-0.376346f, -0.117945f,0.920189f,-0.373285f, -0.121803f,0.934924f,-0.333287f, --0.0046923f,0.925271f,-0.379279f, -0.0524128f,0.95708f,-0.285046f, --0.0476851f,0.956392f,-0.288167f, --0.185718f,0.956668f,-0.224263f, --0.292875f,0.939689f,-0.176661f, --0.212138f,0.937073f,-0.277295f, -0.00215598f,0.9095f,-0.415698f, -0.155074f,0.855231f,-0.494501f, -0.3372f,0.836708f,-0.431528f, -0.272726f,0.886233f,-0.374449f, -0.193484f,0.944931f,-0.263949f, -0.192169f,0.938969f,-0.285322f, -0.141281f,0.932743f,-0.331708f, -0.278032f,0.931044f,-0.236339f, -0.426985f,0.871432f,-0.241434f, -0.368362f,0.861689f,-0.349f, -0.400587f,0.825418f,-0.397762f, -0.451323f,0.785144f,-0.424095f, -0.523643f,0.765884f,-0.373121f, -0.603289f,0.753586f,-0.261056f, -0.44978f,0.832328f,-0.323928f, -0.156509f,0.915232f,-0.371289f, --0.0704135f,0.915939f,-0.395092f, --0.00319557f,0.926331f,-0.376696f, -0.166676f,0.911893f,-0.37506f, -0.102989f,0.962696f,-0.250219f, --0.0387958f,0.995347f,-0.0881961f, -0.0653507f,0.992864f,-0.0997527f, -0.179449f,0.98367f,-0.0138117f, -0.177828f,0.983985f,0.012264f, -0.0645076f,0.995168f,-0.0740203f, --0.292502f,0.938695f,-0.182468f, --0.400433f,0.889464f,-0.220243f, --0.318802f,0.923541f,-0.213161f, --0.169897f,0.961934f,-0.214052f, --0.0267051f,0.972116f,-0.232975f, --0.00536052f,0.964395f,-0.264412f, --0.100769f,0.988596f,-0.111905f, --0.404303f,0.910751f,0.0840968f, --0.594207f,0.803932f,0.0247338f, --0.396136f,0.914658f,0.0804795f, --0.304433f,0.952514f,0.00620435f, --0.201276f,0.977901f,-0.0565476f, --0.264949f,0.959844f,-0.0922019f, --0.227773f,0.971084f,-0.0715179f, --0.172114f,0.969698f,-0.173387f, --0.26936f,0.945102f,-0.185006f, --0.392685f,0.904465f,-0.166556f, --0.407044f,0.896103f,-0.176958f, --0.40747f,0.889993f,-0.204647f, --0.189782f,0.978511f,-0.0806113f, --0.0480587f,0.996223f,-0.0723184f, --0.217275f,0.958525f,-0.184451f, --0.306094f,0.944116f,-0.122276f, --0.254593f,0.966558f,0.0308049f, --0.20196f,0.972664f,0.114613f, --0.409794f,0.899925f,-0.14901f, --0.415034f,0.857771f,-0.303274f, --0.263165f,0.89665f,-0.356039f, --0.215387f,0.884962f,-0.412857f, --0.225079f,0.887943f,-0.401119f, --0.0773061f,0.916142f,-0.393328f, --0.0308036f,0.905486f,-0.423257f, --0.0371917f,0.883129f,-0.467653f, -0.0716369f,0.893813f,-0.442681f, -0.12997f,0.919319f,-0.371429f, -0.119867f,0.921216f,-0.370126f, -0.0228827f,0.984493f,-0.173923f, --0.0834452f,0.988816f,-0.123614f, --0.247718f,0.964917f,-0.0870125f, --0.254118f,0.961997f,-0.0999321f, --0.0671834f,0.977202f,-0.201403f, -0.157483f,0.940773f,-0.300243f, -0.164503f,0.92764f,-0.335294f, -0.27582f,0.929794f,-0.243733f, -0.209142f,0.946949f,-0.244024f, -0.183638f,0.949161f,-0.255677f, -0.277174f,0.906106f,-0.319605f, -0.178788f,0.896597f,-0.405153f, -0.185529f,0.860132f,-0.475134f, -0.438868f,0.800307f,-0.408538f, -0.441024f,0.788796f,-0.428135f, -0.397261f,0.791714f,-0.464083f, -0.440809f,0.77176f,-0.458338f, -0.455755f,0.768172f,-0.449666f, -0.535299f,0.762932f,-0.362477f, -0.450448f,0.842352f,-0.295872f, -0.136515f,0.937333f,-0.320579f, --0.0637901f,0.937145f,-0.343061f, --0.0112309f,0.935306f,-0.353662f, -0.108413f,0.948157f,-0.298738f, --0.0660356f,0.972239f,-0.224477f, --0.07256f,0.985988f,-0.150208f, -0.0814078f,0.980504f,-0.178842f, -0.133209f,0.989139f,-0.0621265f, -0.112681f,0.993117f,-0.0319677f, -0.144875f,0.987157f,0.0673239f, --0.178705f,0.983714f,-0.0192655f, --0.383305f,0.919432f,-0.0878717f, --0.311703f,0.944518f,-0.103569f, --0.170547f,0.974222f,-0.147663f, --0.0584686f,0.987712f,-0.144938f, --0.130239f,0.988008f,-0.0829397f, --0.30957f,0.949755f,0.0461837f, --0.426068f,0.896859f,0.118784f, --0.505712f,0.862298f,-0.0263905f, --0.384432f,0.913927f,-0.130189f, --0.233817f,0.957708f,-0.167708f, --0.196686f,0.961804f,-0.190386f, --0.272431f,0.94059f,-0.202662f, --0.180772f,0.950727f,-0.251872f, --0.0565853f,0.956064f,-0.287647f, --0.288561f,0.926858f,-0.240141f, --0.491099f,0.856076f,-0.161104f, --0.419638f,0.904096f,-0.0807095f, --0.388583f,0.916169f,-0.0981701f, --0.261262f,0.961028f,-0.0903754f, --0.0632456f,0.997064f,0.0431658f, --0.169715f,0.97859f,0.116442f, --0.344027f,0.938297f,0.0352825f, --0.314669f,0.949192f,0.00417096f, --0.192981f,0.980434f,0.0388389f, --0.184602f,0.98279f,-0.00683269f, --0.246496f,0.934378f,-0.25725f, --0.19921f,0.861846f,-0.466409f, --0.140436f,0.848535f,-0.510163f, --0.20288f,0.807079f,-0.554493f, --0.11519f,0.832336f,-0.542169f, -0.00924053f,0.875455f,-0.483211f, --0.00888073f,0.876341f,-0.48161f, -0.00107193f,0.907613f,-0.419807f, -0.021101f,0.930448f,-0.365817f, -0.0745313f,0.948396f,-0.308205f, --0.200438f,0.964136f,-0.17397f, --0.166231f,0.985214f,-0.0414839f, --0.252324f,0.967639f,-0.00281073f, --0.16447f,0.986195f,-0.0192238f, -0.0101706f,0.983613f,-0.180006f, -0.16229f,0.966979f,-0.196502f, -0.152128f,0.981833f,-0.113406f, -0.194455f,0.973444f,-0.120809f, -0.334057f,0.938492f,-0.0874058f, -0.243016f,0.928299f,-0.281434f, -0.337071f,0.885295f,-0.320369f, -0.298461f,0.876938f,-0.376698f, -0.311828f,0.819683f,-0.480502f, -0.369257f,0.755567f,-0.54108f, -0.401798f,0.784012f,-0.473163f, -0.404891f,0.784738f,-0.469309f, -0.444437f,0.782155f,-0.436702f, -0.466084f,0.794919f,-0.388419f, -0.447341f,0.805216f,-0.389247f, -0.362297f,0.887389f,-0.285098f, -0.179937f,0.962799f,-0.201595f, -0.000795301f,0.958246f,-0.285946f, --0.0439986f,0.938528f,-0.342389f, -0.000314903f,0.959745f,-0.280871f, --0.0200826f,0.975564f,-0.218794f, --0.0669112f,0.936012f,-0.345551f, -0.0051897f,0.948012f,-0.318192f, -0.0134178f,0.970832f,-0.239387f, -0.036317f,0.978504f,-0.203005f, -0.0625457f,0.996542f,-0.0547064f, --0.151505f,0.986626f,0.0601296f, --0.354535f,0.929709f,0.0997293f, --0.323458f,0.940866f,0.100727f, --0.112965f,0.981029f,0.157548f, --0.108156f,0.989168f,0.0992381f, --0.141093f,0.979303f,0.145114f, --0.335564f,0.940028f,0.061184f, --0.404784f,0.910739f,0.081883f, --0.415621f,0.909054f,0.0296628f, --0.326024f,0.941449f,-0.0859172f, --0.204455f,0.961807f,-0.182004f, --0.198427f,0.946732f,-0.253624f, --0.160629f,0.949f,-0.27129f, --0.122223f,0.918206f,-0.376775f, --0.161284f,0.939678f,-0.301651f, --0.374966f,0.911783f,-0.167489f, --0.467696f,0.856498f,-0.218336f, --0.443475f,0.843003f,-0.304427f, --0.385194f,0.898165f,-0.211955f, --0.377418f,0.917998f,-0.121804f, --0.264639f,0.962925f,0.0523651f, --0.211739f,0.961017f,0.177801f, --0.229995f,0.957255f,0.175401f, --0.280377f,0.956102f,0.0851875f, --0.20016f,0.97825f,0.0544282f, --0.10573f,0.994257f,-0.0165441f, -0.0203896f,0.991211f,-0.130708f, --0.0236073f,0.94884f,-0.314873f, --0.0941765f,0.92043f,-0.379394f, --0.167941f,0.897458f,-0.407879f, --0.187085f,0.877031f,-0.442511f, --0.0729267f,0.89358f,-0.44294f, --0.0781669f,0.903365f,-0.421688f, --0.0898224f,0.927661f,-0.362461f, --0.0306254f,0.944826f,-0.326139f, -0.00767666f,0.952077f,-0.305762f, --0.288656f,0.939633f,-0.183761f, --0.235623f,0.952993f,-0.190489f, --0.273085f,0.931861f,-0.238874f, --0.0949222f,0.974332f,-0.204123f, -0.149266f,0.955245f,-0.255397f, -0.0666117f,0.957576f,-0.280376f, -0.127398f,0.979355f,-0.156952f, -0.209457f,0.954497f,-0.21228f, -0.367092f,0.913409f,-0.175864f, -0.415953f,0.865553f,-0.278928f, -0.34245f,0.832959f,-0.434635f, -0.340781f,0.830404f,-0.440793f, -0.395293f,0.802521f,-0.446882f, -0.405952f,0.792834f,-0.454552f, -0.385024f,0.788348f,-0.479858f, -0.365166f,0.783008f,-0.503539f, -0.371074f,0.838688f,-0.39863f, -0.42233f,0.859897f,-0.286732f, -0.440629f,0.882917f,-0.162183f, -0.299827f,0.949298f,-0.0945333f, -0.141695f,0.979344f,-0.144247f, -0.039666f,0.992248f,-0.117771f, -0.021245f,0.997585f,-0.0661304f, --0.0594041f,0.983411f,-0.17139f, -0.0611812f,0.981318f,-0.182404f, -0.0186916f,0.932529f,-0.360611f, --0.0300853f,0.91754f,-0.396504f, --0.00135599f,0.922081f,-0.386995f, --0.0351954f,0.956784f,-0.28866f, --0.108108f,0.976189f,-0.188065f, --0.279221f,0.950183f,-0.13852f, --0.398641f,0.914814f,-0.0648175f, --0.383626f,0.922668f,-0.0389249f, --0.188191f,0.977628f,0.0939533f, --0.083441f,0.973103f,0.21473f, --0.0631642f,0.980575f,0.185698f, --0.269017f,0.963031f,0.0141438f, --0.4376f,0.89917f,-0.000301879f, --0.339736f,0.940513f,0.00384959f, --0.235638f,0.967987f,-0.0864624f, --0.0773761f,0.988655f,-0.128744f, --0.0852549f,0.968269f,-0.234917f, --0.114948f,0.939941f,-0.3214f, --0.156571f,0.928217f,-0.337488f, --0.29563f,0.924155f,-0.241951f, --0.401682f,0.899225f,-0.173337f, --0.351799f,0.915761f,-0.193956f, --0.391021f,0.882077f,-0.262761f, --0.525453f,0.810665f,-0.258305f, --0.504092f,0.859496f,-0.0846014f, --0.362403f,0.931317f,0.0362275f, --0.27912f,0.954258f,0.107159f, --0.207619f,0.961802f,0.178414f, --0.228638f,0.970139f,0.0809669f, --0.12077f,0.992669f,0.00484841f, -0.0304882f,0.99448f,-0.100401f, -0.0674392f,0.979801f,-0.18826f, -0.0351304f,0.9953f,-0.090241f, --0.0704736f,0.995263f,-0.0669708f, --0.129706f,0.981562f,-0.1404f, --0.122442f,0.956888f,-0.263387f, --0.0356665f,0.922731f,-0.38379f, --0.0454106f,0.896226f,-0.441267f, --0.0870705f,0.865568f,-0.493164f, --0.0312927f,0.854755f,-0.518087f, --0.0110302f,0.85359f,-0.520829f, --0.135251f,0.990349f,0.0302781f, --0.120846f,0.991438f,-0.049458f, --0.156404f,0.974115f,-0.163209f, --0.121903f,0.951948f,-0.280952f, -0.0966131f,0.959924f,-0.263082f, -0.0624341f,0.96714f,-0.24646f, -0.0557469f,0.94749f,-0.31489f, -0.245712f,0.928812f,-0.27737f, -0.339947f,0.895451f,-0.28741f, -0.505833f,0.828917f,-0.238808f, -0.492153f,0.815708f,-0.303985f, -0.325713f,0.824266f,-0.463138f, -0.357884f,0.8174f,-0.451416f, -0.423911f,0.828952f,-0.364879f, -0.465983f,0.818349f,-0.3364f, -0.340136f,0.856815f,-0.387524f, -0.250037f,0.902839f,-0.349804f, -0.270063f,0.93551f,-0.227788f, -0.268197f,0.961943f,0.0523086f, -0.314452f,0.921737f,0.226982f, -0.230483f,0.962611f,0.142328f, --0.0337231f,0.996519f,0.0762456f, --0.0478467f,0.987694f,0.1489f, -0.0777224f,0.977564f,0.195776f, -0.137813f,0.987309f,0.0789204f, -0.213773f,0.976881f,-0.00209812f, -0.0678985f,0.982243f,-0.174896f, --0.118448f,0.956882f,-0.26523f, --0.229961f,0.9707f,-0.0697049f, --0.144208f,0.98561f,0.0881926f, --0.198479f,0.979386f,0.0375393f, --0.401292f,0.909987f,-0.104347f, --0.400254f,0.91005f,-0.107726f, --0.346067f,0.932825f,-0.100374f, --0.193125f,0.981161f,0.00517742f, --0.0334943f,0.995589f,0.0876359f, --0.09901f,0.987334f,0.12397f, --0.411919f,0.909058f,-0.0627387f, --0.33988f,0.934279f,-0.107727f, --0.163445f,0.980417f,-0.109859f, --0.094399f,0.976137f,-0.195566f, --0.0281723f,0.98965f,-0.140708f, --0.0765865f,0.985816f,-0.149338f, --0.168645f,0.974838f,-0.145776f, --0.316363f,0.934327f,-0.164156f, --0.429172f,0.879196f,-0.206943f, --0.428946f,0.898522f,-0.0930795f, --0.397223f,0.909843f,0.12f, --0.511164f,0.850782f,0.12199f, --0.553545f,0.831305f,-0.0501975f, --0.425265f,0.901367f,-0.0817687f, --0.377377f,0.925701f,-0.0257517f, --0.226427f,0.969468f,0.0941363f, --0.0709665f,0.993431f,0.0897693f, --0.0343935f,0.997803f,-0.0566276f, -0.136725f,0.981098f,-0.136942f, --0.000388307f,0.974615f,-0.223888f, --0.143125f,0.988947f,-0.0387096f, --0.0654844f,0.993475f,0.0933713f, -0.0107967f,0.999865f,0.0124207f, -0.0463655f,0.990074f,-0.132676f, -0.111072f,0.958636f,-0.262069f, -0.052211f,0.918497f,-0.391967f, -0.014765f,0.869476f,-0.493754f, --0.00446669f,0.826302f,-0.56321f, --0.00312167f,0.829643f,-0.558286f, --0.205328f,0.971118f,-0.121531f, --0.107279f,0.990692f,-0.0837913f, --0.0655817f,0.993795f,-0.089834f, --0.0669083f,0.985851f,-0.15369f, -0.0877486f,0.98832f,-0.124596f, -0.169572f,0.978484f,-0.117533f, -0.160152f,0.950603f,-0.265903f, -0.208233f,0.926f,-0.314903f, -0.349792f,0.904675f,-0.243329f, -0.449891f,0.870303f,-0.200426f, -0.566229f,0.816333f,-0.113956f, -0.48817f,0.833849f,-0.257655f, -0.363235f,0.831342f,-0.420631f, -0.324206f,0.826771f,-0.459718f, -0.3997f,0.840833f,-0.365021f, -0.353025f,0.906211f,-0.232714f, -0.219616f,0.962891f,-0.156874f, -0.0720827f,0.994934f,-0.0700696f, -0.045678f,0.994046f,0.0989266f, -0.213575f,0.964796f,0.153475f, -0.24905f,0.930442f,0.268798f, -0.0777133f,0.945053f,0.317546f, --0.128028f,0.977296f,0.168824f, -0.0217263f,0.951068f,0.308215f, -0.207313f,0.918764f,0.335998f, -0.282654f,0.924456f,0.255906f, -0.201157f,0.96204f,0.184429f, --0.110233f,0.981395f,0.157205f, --0.355659f,0.909169f,0.216606f, --0.21295f,0.947904f,0.236917f, --0.107393f,0.959263f,0.261306f, --0.278087f,0.947596f,0.157257f, --0.393558f,0.918794f,0.0304824f, --0.302068f,0.952957f,-0.0250724f, --0.213276f,0.970666f,-0.110997f, --0.166999f,0.978773f,-0.118807f, --0.142246f,0.989828f,0.00258048f, --0.283745f,0.958854f,0.0093455f, --0.336957f,0.941016f,-0.0308147f, --0.113565f,0.9931f,-0.02925f, --0.0231129f,0.991621f,-0.127093f, --0.107284f,0.981887f,-0.156166f, --0.121783f,0.990389f,-0.0655664f, --0.179469f,0.983757f,0.00373427f, --0.267261f,0.963295f,0.0251965f, --0.419417f,0.907445f,0.0251735f, --0.582729f,0.80835f,0.0836507f, --0.554692f,0.78035f,0.288741f, --0.368624f,0.840437f,0.397218f, --0.336016f,0.929619f,0.151335f, --0.379048f,0.912637f,-0.153022f, --0.410461f,0.89244f,-0.187275f, --0.310698f,0.938768f,-0.148932f, --0.0772428f,0.993562f,-0.0828798f, -0.0559112f,0.996518f,-0.0618564f, -0.218481f,0.971621f,-0.090653f, -0.0070055f,0.988587f,-0.150488f, --0.287385f,0.949521f,-0.125778f, --0.0963797f,0.992515f,-0.0749989f, -0.0940601f,0.994076f,-0.0544632f, -0.147534f,0.985277f,-0.0863886f, -0.20617f,0.964455f,-0.165287f, -0.228919f,0.941159f,-0.248628f, -0.142687f,0.889558f,-0.433967f, -0.0525074f,0.86193f,-0.5043f, --0.0400559f,0.852931f,-0.520485f, --0.12929f,0.965503f,-0.226025f, --0.12119f,0.954637f,-0.271994f, --0.0677494f,0.970158f,-0.232815f, --0.0658176f,0.978188f,-0.197017f, -0.00868199f,0.985201f,-0.171183f, -0.183883f,0.977449f,-0.103828f, -0.283397f,0.948052f,-0.144513f, -0.244002f,0.935244f,-0.256481f, -0.251457f,0.918413f,-0.305429f, -0.421894f,0.885288f,-0.195626f, -0.539016f,0.82675f,-0.161076f, -0.595125f,0.795068f,-0.117014f, -0.542945f,0.81823f,-0.188971f, -0.36087f,0.878337f,-0.313523f, -0.249934f,0.94591f,-0.206849f, -0.203095f,0.978645f,0.0317209f, -0.0808087f,0.992314f,0.0937131f, -0.015528f,0.990219f,0.138653f, -0.01799f,0.994881f,0.09944f, -0.195411f,0.975412f,0.101915f, -0.0694818f,0.977162f,0.200816f, -0.0667035f,0.917371f,0.392404f, --0.00815505f,0.942331f,0.334582f, --0.124548f,0.965608f,0.228228f, -0.172601f,0.943034f,0.284421f, -0.392995f,0.877789f,0.273937f, -0.148864f,0.962548f,0.226586f, --0.160978f,0.90924f,0.383887f, --0.338041f,0.865118f,0.370538f, --0.158685f,0.913484f,0.374654f, --0.085827f,0.934088f,0.346573f, --0.160284f,0.956319f,0.244467f, --0.286424f,0.955431f,0.0715057f, --0.239888f,0.970684f,0.0150701f, --0.160609f,0.986985f,0.00807186f, --0.109896f,0.993313f,-0.0353894f, --0.197211f,0.969041f,-0.148551f, --0.329877f,0.939761f,-0.0896172f, --0.308832f,0.948199f,-0.0744408f, --0.098416f,0.980296f,-0.171271f, -0.0274733f,0.990192f,-0.136989f, --0.0841565f,0.99088f,-0.105235f, --0.256459f,0.960709f,-0.106143f, --0.249667f,0.95978f,0.128406f, --0.305999f,0.931391f,0.197168f, --0.484241f,0.852569f,0.196565f, --0.610379f,0.753144f,0.245383f, --0.585787f,0.783089f,0.208867f, --0.367515f,0.91758f,0.151588f, --0.0411995f,0.989239f,0.140389f, --0.109078f,0.987353f,-0.115051f, --0.380949f,0.866858f,-0.321615f, --0.342318f,0.88779f,-0.307647f, --0.12792f,0.955198f,-0.266896f, -0.0278952f,0.967981f,-0.249469f, -0.188442f,0.9544f,-0.231539f, -0.052008f,0.978364f,-0.200246f, --0.225418f,0.931417f,-0.285742f, --0.134566f,0.926089f,-0.352493f, -0.0345745f,0.959769f,-0.278653f, -0.174695f,0.953806f,-0.24441f, -0.227273f,0.930386f,-0.287627f, -0.325716f,0.918321f,-0.224934f, -0.329407f,0.888239f,-0.32019f, -0.0905336f,0.875389f,-0.474867f, --0.0331275f,0.86706f,-0.497102f, -0.0288126f,0.978255f,-0.205394f, --0.0838329f,0.954569f,-0.285956f, --0.140323f,0.954698f,-0.262415f, --0.112432f,0.972197f,-0.205408f, -0.0092799f,0.981035f,-0.193608f, -0.142017f,0.962963f,-0.229203f, -0.310781f,0.933484f,-0.17895f, -0.359578f,0.919553f,-0.158514f, -0.334745f,0.907674f,-0.253129f, -0.345814f,0.873436f,-0.342815f, -0.500723f,0.821828f,-0.271799f, -0.538977f,0.812424f,-0.22242f, -0.523422f,0.839245f,-0.147303f, -0.340441f,0.940266f,0.000412888f, -0.0152874f,0.997305f,0.0717554f, -0.0533145f,0.966764f,0.250049f, -0.112464f,0.954457f,0.276338f, -0.109039f,0.955163f,0.275271f, -0.0445431f,0.979533f,0.196291f, -0.165433f,0.962373f,0.21557f, --0.0715535f,0.977821f,0.196841f, --0.0891149f,0.939351f,0.331178f, -0.117094f,0.910023f,0.397676f, -0.030807f,0.968216f,0.248212f, -0.157233f,0.982334f,0.101481f, -0.403254f,0.903723f,0.143774f, -0.0482774f,0.97679f,0.208689f, --0.297552f,0.88274f,0.363639f, --0.30014f,0.861944f,0.408619f, --0.211374f,0.886111f,0.412466f, --0.03076f,0.854928f,0.517834f, -0.0282722f,0.878122f,0.477601f, --0.13332f,0.93673f,0.32367f, --0.256519f,0.940042f,0.224764f, --0.183801f,0.953616f,0.238397f, --0.0194462f,0.968434f,0.24851f, --0.0907191f,0.988269f,0.122863f, --0.322189f,0.946234f,-0.028899f, --0.20601f,0.965456f,-0.159543f, --0.0654489f,0.973414f,-0.219504f, --0.113732f,0.990052f,-0.0828341f, --0.135223f,0.986029f,0.0972711f, --0.295266f,0.944373f,0.144834f, --0.450404f,0.860579f,0.237781f, --0.30004f,0.881766f,0.363958f, --0.429075f,0.860577f,0.274411f, --0.624789f,0.771784f,0.118272f, --0.497638f,0.864372f,0.0722275f, --0.313601f,0.946808f,-0.0721819f, --0.057809f,0.993544f,-0.0976184f, -0.13458f,0.987765f,-0.078798f, --0.184662f,0.92514f,-0.331688f, --0.385787f,0.812528f,-0.436996f, --0.187957f,0.911737f,-0.36525f, -0.0316981f,0.954599f,-0.296202f, -0.147926f,0.956328f,-0.252101f, -0.104858f,0.974711f,-0.197342f, --0.0836115f,0.931387f,-0.354298f, --0.111379f,0.87594f,-0.469386f, --0.0328315f,0.880204f,-0.473458f, -0.162025f,0.887756f,-0.430856f, -0.205253f,0.903446f,-0.376373f, -0.237481f,0.902569f,-0.359125f, -0.385116f,0.876359f,-0.289276f, -0.249914f,0.920198f,-0.301294f, -0.0143883f,0.906805f,-0.421304f, -0.1198f,0.98226f,-0.14427f, --0.009516f,0.980934f,-0.194106f, --0.149357f,0.951394f,-0.269335f, --0.133007f,0.936454f,-0.324597f, -0.034566f,0.948692f,-0.314306f, -0.178184f,0.929444f,-0.323086f, -0.219637f,0.922638f,-0.317015f, -0.296463f,0.935411f,-0.192652f, -0.416664f,0.902617f,-0.108048f, -0.442812f,0.876638f,-0.188209f, -0.465688f,0.849444f,-0.248152f, -0.511879f,0.84424f,-0.158868f, -0.360617f,0.931627f,-0.0450278f, -0.228988f,0.955033f,0.188354f, --0.00280316f,0.974776f,0.223168f, -0.00899431f,0.980078f,0.198407f, -0.0845579f,0.975657f,0.202347f, -0.0600237f,0.962271f,0.265389f, -0.0344627f,0.950379f,0.309181f, -0.173636f,0.921696f,0.346881f, --0.00190385f,0.960894f,0.276909f, --0.186383f,0.97431f,0.126416f, -0.101162f,0.98048f,0.168596f, -0.181976f,0.961147f,0.207559f, -0.220019f,0.957024f,0.188939f, -0.310192f,0.917199f,0.250053f, --0.02225f,0.932984f,0.359229f, --0.395015f,0.837639f,0.377259f, --0.325443f,0.861588f,0.389554f, --0.255559f,0.880464f,0.39934f, --0.151471f,0.886274f,0.437693f, --0.0211154f,0.863177f,0.50446f, -0.00094362f,0.808505f,0.588488f, --0.114242f,0.850647f,0.513176f, --0.11027f,0.888828f,0.444776f, --0.0310984f,0.926772f,0.374335f, -0.036991f,0.899416f,0.435525f, --0.0593828f,0.941327f,0.33223f, --0.108182f,0.990534f,0.0844942f, --0.153469f,0.985899f,0.066708f, --0.257292f,0.956946f,0.134368f, --0.339432f,0.926138f,0.164482f, --0.361227f,0.853531f,0.3755f, --0.433268f,0.811828f,0.391425f, --0.292152f,0.883075f,0.367186f, --0.254971f,0.931997f,0.257627f, --0.51111f,0.857028f,-0.0653379f, --0.482419f,0.859823f,-0.167263f, --0.240122f,0.964988f,-0.105544f, --0.0637549f,0.987476f,-0.144314f, -0.14266f,0.980144f,-0.137714f, -0.096896f,0.982614f,-0.158371f, --0.287298f,0.856944f,-0.42791f, --0.299829f,0.819408f,-0.488542f, --0.0881013f,0.911449f,-0.40187f, -0.0509938f,0.949808f,-0.308649f, -0.13334f,0.962273f,-0.237174f, -0.0865622f,0.946427f,-0.311099f, -0.0118172f,0.924665f,-0.380599f, --0.0178448f,0.910652f,-0.412789f, -0.073892f,0.906856f,-0.414913f, -0.15114f,0.90612f,-0.395099f, -0.255577f,0.878518f,-0.403593f, -0.278013f,0.865146f,-0.417411f, -0.239832f,0.923443f,-0.299555f, -0.188412f,0.940744f,-0.281961f, --0.0158305f,0.982567f,-0.185231f, -0.0666038f,0.988337f,-0.136945f, --0.0538402f,0.959334f,-0.277092f, --0.0212127f,0.945816f,-0.324009f, --0.0150833f,0.913689f,-0.406133f, -0.15601f,0.93774f,-0.310331f, -0.182702f,0.936618f,-0.298942f, -0.189924f,0.93758f,-0.29133f, -0.333869f,0.91329f,-0.233307f, -0.499532f,0.857573f,-0.122619f, -0.46551f,0.873216f,-0.144201f, -0.373694f,0.926999f,0.0320189f, -0.203779f,0.950539f,0.234414f, -0.13831f,0.928366f,0.344974f, -0.0515931f,0.949665f,0.30899f, -0.0310079f,0.96445f,0.262439f, -0.0853119f,0.968829f,0.232577f, --0.00103764f,0.981733f,0.190261f, --0.00365072f,0.967667f,0.252206f, -0.10066f,0.945677f,0.309134f, -0.178572f,0.914026f,0.364237f, --0.0213985f,0.991455f,0.128684f, -0.0498313f,0.996519f,0.0668339f, -0.120586f,0.983203f,0.137006f, -0.0910496f,0.981472f,0.16859f, -0.13401f,0.919805f,0.368783f, --0.0801133f,0.861028f,0.502208f, --0.337717f,0.841946f,0.420801f, --0.27627f,0.878916f,0.388821f, --0.2301f,0.91025f,0.344237f, --0.177792f,0.940411f,0.289857f, --0.131507f,0.928729f,0.346652f, --0.0961971f,0.892019f,0.441642f, --0.0639687f,0.872394f,0.4846f, --0.0102449f,0.879124f,0.476482f, --0.00257342f,0.917704f,0.397258f, --0.0554909f,0.910659f,0.409416f, -0.0291401f,0.896118f,0.442858f, -0.0220451f,0.91331f,0.406668f, --0.138595f,0.921526f,0.362741f, --0.186305f,0.924786f,0.331755f, --0.347011f,0.903153f,0.25278f, --0.513046f,0.817508f,0.261656f, --0.445268f,0.835978f,0.320745f, --0.177443f,0.933005f,0.313074f, --0.0397144f,0.982015f,0.184579f, --0.223543f,0.974128f,-0.0332155f, --0.4666f,0.831165f,-0.302406f, --0.335541f,0.890675f,-0.306773f, --0.0318096f,0.973987f,-0.224358f, -0.0953506f,0.970682f,-0.220646f, -0.134482f,0.984534f,-0.112281f, --0.0162953f,0.992479f,-0.121323f, --0.284204f,0.902721f,-0.322992f, --0.211997f,0.906314f,-0.365585f, --0.016875f,0.958349f,-0.285101f, -0.129044f,0.959618f,-0.24996f, -0.151996f,0.928771f,-0.338057f, --0.0199776f,0.904327f,-0.426372f, --0.0559071f,0.940256f,-0.335846f, -0.108952f,0.945546f,-0.306712f, -0.215589f,0.905767f,-0.364838f, -0.293281f,0.878158f,-0.377921f, -0.279356f,0.877367f,-0.390112f, -0.127912f,0.886694f,-0.444312f, -0.153161f,0.902051f,-0.403541f, --0.0890667f,0.969622f,-0.227816f, -0.0791521f,0.98141f,-0.174841f, -0.0791423f,0.971591f,-0.22304f, -0.0168825f,0.939671f,-0.341662f, --0.00465273f,0.922224f,-0.386629f, -0.0341103f,0.949158f,-0.312946f, -0.243022f,0.94331f,-0.226069f, -0.218985f,0.910646f,-0.350386f, -0.282576f,0.88974f,-0.358487f, -0.398347f,0.877162f,-0.268155f, -0.330147f,0.941044f,-0.073754f, -0.178397f,0.970659f,0.16123f, -0.0525065f,0.954596f,0.293241f, -0.0945297f,0.914894f,0.392472f, -0.13661f,0.905749f,0.401193f, -0.0406243f,0.947359f,0.317587f, -0.163762f,0.925717f,0.340926f, -0.040504f,0.970394f,0.238108f, --0.0543453f,0.975142f,0.214812f, -2.68223e-005f,0.976435f,0.215812f, -0.209407f,0.932778f,0.293383f, -0.184464f,0.966229f,0.179928f, --0.0113387f,0.999016f,0.0428878f, -0.079177f,0.981677f,0.173323f, -0.0362262f,0.968187f,0.24759f, --0.0723427f,0.93572f,0.345245f, --0.135834f,0.890086f,0.435082f, --0.264248f,0.873681f,0.408479f, --0.262216f,0.89706f,0.355706f, --0.164052f,0.919196f,0.358002f, --0.167176f,0.924403f,0.342829f, --0.200682f,0.904947f,0.375229f, --0.158624f,0.899685f,0.406701f, --0.112022f,0.891533f,0.438886f, --0.00921475f,0.869473f,0.493894f, -0.0802624f,0.881225f,0.465833f, --0.0504548f,0.922517f,0.382645f, --0.0121989f,0.918687f,0.394797f, -0.0440736f,0.891185f,0.451494f, --0.0756766f,0.900734f,0.427728f, --0.202037f,0.909488f,0.363335f, --0.295423f,0.866009f,0.403428f, --0.471319f,0.827048f,0.30635f, --0.443758f,0.874939f,0.193806f, --0.125026f,0.977756f,0.168412f, -0.0442668f,0.987172f,0.153403f, --0.0338798f,0.987768f,0.152205f, --0.259589f,0.965039f,-0.0362462f, --0.35784f,0.903258f,-0.236805f, --0.167942f,0.956248f,-0.239554f, -0.0460995f,0.994911f,-0.0895878f, --0.00166787f,0.99811f,-0.0614342f, --0.0336402f,0.998923f,0.0319432f, --0.139942f,0.989786f,0.0271849f, --0.21913f,0.971861f,-0.0864193f, --0.083914f,0.990307f,-0.110685f, -0.180721f,0.971397f,-0.154041f, -0.29639f,0.913592f,-0.278393f, -0.0452233f,0.94418f,-0.326312f, --0.13463f,0.924181f,-0.357441f, -0.11753f,0.929423f,-0.349798f, -0.238754f,0.909243f,-0.340989f, -0.272577f,0.899491f,-0.341494f, -0.343945f,0.879082f,-0.330025f, -0.202726f,0.889055f,-0.410468f, -0.0880936f,0.876474f,-0.473321f, --0.000386659f,0.989518f,-0.144407f, --0.0138532f,0.983228f,-0.181856f, -0.165824f,0.98552f,-0.0353913f, -0.196669f,0.963831f,-0.179867f, -0.00115533f,0.93443f,-0.356144f, --0.0579019f,0.928374f,-0.36711f, -0.234096f,0.913194f,-0.333581f, -0.311749f,0.881031f,-0.355805f, -0.243154f,0.902483f,-0.355529f, -0.214274f,0.956658f,-0.197209f, -0.120355f,0.990537f,0.0659672f, -0.0219689f,0.979298f,0.201227f, --0.0108785f,0.963809f,0.266373f, --0.016985f,0.957116f,0.289205f, -0.15437f,0.922679f,0.353316f, -0.0959731f,0.93811f,0.332776f, -0.138832f,0.935317f,0.325434f, -0.133758f,0.941295f,0.309956f, --0.00148525f,0.972503f,0.232885f, -0.00817406f,0.979885f,0.199396f, -0.180862f,0.960033f,0.213602f, -0.330054f,0.924212f,0.192085f, -0.039978f,0.994865f,0.0929833f, --0.118088f,0.976595f,0.179768f, --0.100092f,0.923425f,0.370498f, --0.117559f,0.88568f,0.449166f, --0.170937f,0.879572f,0.443997f, --0.244838f,0.844603f,0.47613f, --0.196312f,0.844324f,0.498577f, --0.188529f,0.85759f,0.478535f, --0.188501f,0.839785f,0.509145f, --0.185899f,0.842964f,0.50483f, --0.154293f,0.872091f,0.464382f, --0.115474f,0.894542f,0.431811f, --0.0887035f,0.930393f,0.35567f, -0.133188f,0.884773f,0.446583f, -0.0484666f,0.90226f,0.42846f, --0.0427135f,0.946807f,0.318954f, --0.0239721f,0.952831f,0.302554f, --0.0435714f,0.926502f,0.373759f, --0.182333f,0.899048f,0.398079f, --0.323546f,0.846433f,0.422929f, --0.334412f,0.852971f,0.40076f, --0.325744f,0.921829f,0.210052f, --0.140593f,0.980752f,0.135497f, --0.000911154f,0.974293f,0.225285f, --0.0250989f,0.969759f,0.242771f, --0.116671f,0.973198f,0.198177f, --0.222025f,0.967605f,0.12019f, --0.252573f,0.967519f,-0.0106675f, --0.0639595f,0.99456f,0.0822198f, -0.0427289f,0.995551f,0.0839736f, --0.103724f,0.994603f,-0.00239601f, --0.143088f,0.981404f,0.127957f, --0.10974f,0.986771f,0.119333f, -0.0104156f,0.996494f,-0.083017f, -0.293943f,0.936018f,-0.193565f, -0.319276f,0.921897f,-0.219472f, -0.0381885f,0.98033f,-0.193638f, --0.0675527f,0.960756f,-0.269042f, -0.11652f,0.926645f,-0.357425f, -0.2292f,0.915276f,-0.331265f, -0.30797f,0.891339f,-0.33267f, -0.348546f,0.853103f,-0.38824f, -0.249601f,0.874176f,-0.416553f, -0.18778f,0.887174f,-0.421499f, -0.122671f,0.990262f,-0.0658213f, --0.0435566f,0.992887f,-0.11081f, -0.0494387f,0.998572f,0.0202637f, -0.34574f,0.93458f,0.0838063f, -0.205482f,0.970541f,-0.125808f, -0.00807532f,0.928646f,-0.370879f, -0.212354f,0.896105f,-0.389746f, -0.285287f,0.924061f,-0.254407f, -0.130923f,0.978283f,-0.160691f, --0.0198715f,0.999555f,-0.0222427f, --0.0516664f,0.987583f,0.148362f, --0.0269196f,0.97761f,0.208697f, --0.00903021f,0.979554f,0.200976f, --0.00834551f,0.993685f,0.111894f, -0.110842f,0.987362f,0.113269f, -0.106874f,0.976878f,0.185167f, -0.141547f,0.968321f,0.205716f, -0.174972f,0.958256f,0.22612f, -0.054828f,0.97071f,0.233913f, -0.0299952f,0.981566f,0.188753f, -0.154988f,0.980787f,0.118472f, -0.340268f,0.925521f,0.166219f, -0.0136729f,0.972695f,0.231683f, --0.270301f,0.899629f,0.342937f, --0.212226f,0.859098f,0.465736f, --0.140535f,0.846284f,0.513861f, --0.175101f,0.833937f,0.523345f, --0.270288f,0.821688f,0.501769f, --0.282918f,0.830124f,0.48047f, --0.174774f,0.812594f,0.556008f, --0.140913f,0.828898f,0.541361f, --0.117146f,0.878471f,0.463211f, --0.0728003f,0.920501f,0.383899f, --0.00293246f,0.948861f,0.315679f, --0.025836f,0.967046f,0.253289f, --0.00528251f,0.957042f,0.289901f, -0.088837f,0.914901f,0.393781f, -0.103014f,0.924276f,0.367561f, -0.00437406f,0.95596f,0.293464f, --0.1442f,0.952275f,0.269032f, --0.25396f,0.922416f,0.290951f, --0.3894f,0.883133f,0.261618f, --0.283615f,0.906122f,0.313857f, --0.158058f,0.930594f,0.330171f, --0.134893f,0.961854f,0.237993f, --0.0720522f,0.980808f,0.181173f, -0.0349752f,0.985618f,0.16533f, --0.115886f,0.987377f,0.107965f, --0.182211f,0.968171f,0.171592f, --0.154769f,0.971197f,0.181169f, --0.0833304f,0.991727f,0.0976435f, -0.136344f,0.989699f,0.0436644f, --0.106946f,0.993768f,-0.0314277f, --0.261215f,0.963441f,0.0595659f, -0.0120329f,0.999596f,0.0257635f, -0.254582f,0.953185f,-0.163178f, -0.299581f,0.899014f,-0.319413f, -0.266729f,0.9307f,-0.250307f, -0.0579078f,0.977779f,-0.201483f, -0.0590491f,0.968354f,-0.242494f, -0.196887f,0.912909f,-0.357536f, -0.211047f,0.877381f,-0.430885f, -0.301745f,0.869054f,-0.39204f, -0.422629f,0.852977f,-0.306291f, -0.252055f,0.896241f,-0.364994f, -0.158615f,0.91987f,-0.35872f, -0.099088f,0.991841f,-0.0802016f, --0.0649468f,0.996188f,-0.0582405f, --0.09006f,0.995865f,-0.0119566f, -0.299186f,0.949686f,0.0926523f, -0.448961f,0.886032f,0.115674f, -0.225408f,0.968479f,-0.106019f, -0.110364f,0.983262f,-0.144965f, -0.0982296f,0.994337f,0.0405443f, -0.03386f,0.98307f,0.180072f, --0.0548904f,0.982813f,0.176255f, --0.131535f,0.986412f,0.0984329f, --0.0772354f,0.9803f,0.181787f, -0.0556449f,0.958844f,0.278429f, -0.08308f,0.969903f,0.228882f, -0.0990101f,0.980512f,0.169685f, -0.044494f,0.989611f,0.136713f, -0.124145f,0.981303f,0.14708f, -0.126925f,0.98249f,0.136391f, -0.0289993f,0.988064f,0.151292f, -0.146433f,0.982737f,0.113073f, -0.210582f,0.977005f,-0.0334257f, -0.179552f,0.980748f,0.0767724f, --0.0986728f,0.925956f,0.364513f, --0.333893f,0.835984f,0.435484f, --0.316161f,0.849609f,0.422146f, --0.184942f,0.836066f,0.516517f, --0.165011f,0.827696f,0.536368f, --0.1919f,0.849729f,0.491054f, --0.260791f,0.881445f,0.393754f, --0.244518f,0.891442f,0.3815f, --0.101674f,0.91665f,0.386543f, --0.0135975f,0.926806f,0.375295f, -0.0383624f,0.948469f,0.31454f, -0.0311937f,0.973858f,0.225008f, --0.0712105f,0.966505f,0.24657f, --0.0567001f,0.939446f,0.337973f, -0.028793f,0.937988f,0.345471f, -0.0944493f,0.922855f,0.373388f, -0.0339618f,0.928396f,0.370037f, --0.0877384f,0.940895f,0.327137f, --0.18953f,0.934542f,0.301182f, --0.32638f,0.91712f,0.22884f, --0.359606f,0.925931f,0.115484f, --0.250341f,0.958991f,0.132911f, --0.0188851f,0.981881f,0.188556f, -0.0444017f,0.992958f,0.109832f, -0.0292244f,0.992914f,0.115188f, --0.0809364f,0.975181f,0.206087f, --0.271318f,0.947628f,0.168488f, --0.147667f,0.972329f,0.181027f, -0.0428511f,0.996597f,0.0704105f, -0.186761f,0.979997f,-0.0687482f, --0.111624f,0.989428f,-0.0925828f, --0.210799f,0.973161f,-0.0923101f, -0.115063f,0.969975f,-0.214262f, -0.376036f,0.900817f,-0.217086f, -0.373114f,0.884398f,-0.280403f, -0.226074f,0.905778f,-0.358407f, -0.0100432f,0.919347f,-0.393319f, -0.0770135f,0.93428f,-0.348124f, -0.321395f,0.895396f,-0.308175f, -0.278274f,0.88968f,-0.361984f, -0.208857f,0.897848f,-0.387619f, -0.325776f,0.898072f,-0.295527f, -0.259741f,0.94586f,-0.194637f, -0.133572f,0.977992f,-0.160282f, --0.0277257f,0.992037f,-0.122857f, --0.0924217f,0.994571f,-0.0478129f, --0.116438f,0.990661f,-0.0709396f, -0.19557f,0.979919f,-0.0388625f, -0.381806f,0.908869f,0.167871f, -0.299282f,0.900933f,0.314247f, -0.0638964f,0.963274f,0.260808f, --0.0731879f,0.961388f,0.265284f, -0.00180295f,0.933351f,0.35896f, -0.0655899f,0.939022f,0.337544f, --0.0612046f,0.96894f,0.239602f, --0.166052f,0.961913f,0.217141f, --0.0893118f,0.965245f,0.245614f, -0.0820047f,0.941494f,0.326902f, -0.146932f,0.937808f,0.314527f, -0.136588f,0.939539f,0.314023f, -0.166222f,0.964584f,0.204811f, -0.17109f,0.976368f,0.132039f, -0.0961069f,0.992806f,0.0714098f, -0.21778f,0.975905f,-0.013487f, -0.251597f,0.967828f,-0.00281592f, --0.0966896f,0.992674f,0.0724564f, --0.377842f,0.87018f,0.316262f, --0.323773f,0.853386f,0.408537f, --0.278729f,0.867238f,0.412564f, --0.286188f,0.874143f,0.392391f, --0.157911f,0.873337f,0.46081f, --0.102832f,0.901917f,0.419488f, --0.202979f,0.914239f,0.350665f, --0.202531f,0.912766f,0.354739f, --0.0843061f,0.956165f,0.28043f, --0.032801f,0.972626f,0.23005f, -0.0558474f,0.961664f,0.268485f, -0.0617913f,0.944956f,0.321309f, --0.110343f,0.937288f,0.330629f, --0.100375f,0.942449f,0.318927f, -0.00551388f,0.94452f,0.328408f, -0.0918462f,0.918926f,0.383587f, -0.101653f,0.927592f,0.3595f, --0.0426308f,0.960188f,0.276083f, --0.204594f,0.956809f,0.206539f, --0.269971f,0.94929f,0.161132f, --0.226691f,0.969699f,0.0910768f, --0.201053f,0.979426f,-0.0173973f, --0.0500104f,0.996428f,-0.0680439f, -0.0272717f,0.999341f,-0.0239459f, --0.123434f,0.99095f,0.0527561f, --0.192945f,0.962627f,0.190054f, --0.168165f,0.969015f,0.180916f, --0.018086f,0.998622f,0.0492547f, -0.193647f,0.975713f,-0.102395f, -0.238523f,0.949336f,-0.204618f, --0.0631885f,0.979427f,-0.191649f, --0.143153f,0.951631f,-0.271858f, -0.148284f,0.940281f,-0.306403f, -0.321113f,0.91022f,-0.261508f, -0.430557f,0.873923f,-0.225566f, -0.33081f,0.885978f,-0.324974f, -0.0651303f,0.881392f,-0.467874f, -0.0061581f,0.870221f,-0.492623f, -0.228459f,0.886891f,-0.401535f, -0.271547f,0.915184f,-0.297827f, -0.234822f,0.937165f,-0.258033f, -0.27549f,0.92259f,-0.270061f, -0.15924f,0.956523f,-0.244348f, -0.0559303f,0.980799f,-0.186831f, --0.135424f,0.978967f,-0.152593f, --0.15029f,0.985676f,-0.0765294f, --0.0914165f,0.995631f,-0.0190383f, -0.0718608f,0.995714f,0.0582141f, -0.110439f,0.955564f,0.273313f, -0.150494f,0.878589f,0.453246f, -0.206788f,0.864483f,0.458157f, -0.00161058f,0.957582f,0.288156f, --0.0606597f,0.978401f,0.197616f, -0.0692656f,0.9636f,0.25822f, --0.0150286f,0.961837f,0.273212f, --0.0821089f,0.979895f,0.181835f, --0.0658015f,0.997594f,0.0218166f, -0.0735253f,0.997209f,0.0129617f, -0.108564f,0.993746f,0.0261473f, -0.141903f,0.981669f,0.127241f, -0.25029f,0.961471f,0.113707f, -0.225135f,0.967003f,0.119246f, -0.180078f,0.979492f,0.0903737f, -0.237995f,0.971216f,-0.00990333f, -0.0690008f,0.993039f,0.0954582f, --0.15301f,0.921345f,0.357369f, --0.436898f,0.858127f,0.2697f, --0.402318f,0.892319f,0.204714f, --0.306797f,0.913547f,0.267033f, --0.291188f,0.917032f,0.272509f, --0.177835f,0.951614f,0.250608f, --0.0915363f,0.968867f,0.230039f, --0.166531f,0.945303f,0.280483f, --0.214524f,0.956179f,0.199251f, --0.012479f,0.976094f,0.216991f, -0.0485598f,0.972045f,0.22972f, --0.0252191f,0.985709f,0.166561f, --0.0505751f,0.962642f,0.266012f, --0.0744793f,0.942362f,0.3262f, --0.0759606f,0.964725f,0.252062f, --0.0161104f,0.954528f,0.297687f, -0.0264811f,0.949176f,0.313631f, -0.160628f,0.931063f,0.327597f, -0.0783265f,0.972396f,0.219798f, --0.0844827f,0.993769f,0.0727062f, --0.216702f,0.975588f,-0.035603f, --0.195742f,0.979732f,-0.0425419f, --0.158684f,0.986912f,-0.0287187f, --0.0351752f,0.999203f,-0.0188605f, -0.0075235f,0.998877f,-0.0467686f, --0.172586f,0.978556f,-0.112436f, --0.211691f,0.968971f,-0.127601f, --0.0966389f,0.974492f,-0.202552f, -0.105494f,0.955113f,-0.276822f, -0.276059f,0.900517f,-0.335947f, -0.219894f,0.907239f,-0.358557f, --0.0517693f,0.940977f,-0.334489f, --0.112634f,0.913693f,-0.390485f, -0.139923f,0.91136f,-0.387097f, -0.277005f,0.880398f,-0.384926f, -0.432717f,0.843875f,-0.317222f, -0.433921f,0.823502f,-0.365455f, -0.17364f,0.848637f,-0.499665f, --0.015678f,0.850557f,-0.525649f, -0.122709f,0.874405f,-0.469423f, -0.164019f,0.896294f,-0.412014f, -0.166557f,0.925047f,-0.34139f, -0.280426f,0.925939f,-0.25298f, -0.167623f,0.949542f,-0.265088f, --0.00102675f,0.947405f,-0.320035f, --0.299103f,0.954018f,0.0196808f, --0.231787f,0.963234f,0.135851f, --0.196753f,0.961454f,0.192081f, --0.100151f,0.951932f,0.289472f, --0.0563981f,0.925245f,0.375154f, -0.0944709f,0.906549f,0.411394f, -0.305132f,0.862547f,0.403618f, -0.241596f,0.931691f,0.271261f, --0.00370494f,0.998524f,0.0541932f, --0.000261525f,0.998839f,0.0481646f, -0.0260826f,0.996855f,0.0748309f, -0.0599122f,0.998202f,-0.00179631f, -0.0800977f,0.992669f,-0.0905174f, -0.0495455f,0.986325f,-0.157186f, -0.0563113f,0.99071f,-0.123787f, -0.0832843f,0.991933f,-0.095561f, -0.195142f,0.979158f,-0.0563024f, -0.166634f,0.980307f,0.105976f, -0.195862f,0.965878f,0.169461f, -0.284001f,0.943304f,0.171815f, --0.127388f,0.981047f,0.146008f, --0.325222f,0.907949f,0.264311f, --0.283635f,0.916157f,0.28321f, --0.335047f,0.926228f,0.17276f, --0.335005f,0.934046f,0.123816f, --0.290471f,0.951826f,0.098256f, --0.155538f,0.980437f,0.120632f, --0.103955f,0.982905f,0.151957f, --0.195165f,0.971298f,0.135979f, --0.117017f,0.988828f,0.0923353f, --0.0942839f,0.995508f,0.00860997f, --0.0378307f,0.988218f,0.148301f, -0.011735f,0.964206f,0.264893f, --0.104568f,0.970188f,0.218634f, --0.0628876f,0.976435f,0.206445f, --0.0629747f,0.98253f,0.175127f, --0.0956593f,0.974263f,0.204109f, -0.00313264f,0.95614f,0.292895f, -0.184054f,0.913334f,0.363241f, -0.234886f,0.917194f,0.321843f, -0.0818984f,0.986888f,0.139086f, --0.195667f,0.979747f,-0.0425424f, --0.217661f,0.976006f,-0.00606019f, --0.197993f,0.980131f,-0.011927f, --0.0476541f,0.998861f,-0.00224411f, -0.0987461f,0.994341f,-0.039179f, --0.0376594f,0.985822f,-0.163515f, --0.127665f,0.950129f,-0.284528f, -0.022229f,0.926621f,-0.37534f, -0.1509f,0.867911f,-0.473243f, -0.251356f,0.84329f,-0.475061f, -0.180391f,0.877498f,-0.44436f, --0.0381311f,0.903323f,-0.427263f, --0.0302687f,0.878817f,-0.476199f, -0.151045f,0.843437f,-0.515557f, -0.243043f,0.829132f,-0.503459f, -0.361214f,0.815934f,-0.451416f, -0.469501f,0.80804f,-0.355866f, -0.232058f,0.89573f,-0.379233f, --0.0406313f,0.902008f,-0.429803f, -0.0570971f,0.896722f,-0.438895f, -0.139199f,0.907425f,-0.396488f, -0.0981956f,0.909915f,-0.403003f, -0.173099f,0.913856f,-0.367293f, -0.208242f,0.936494f,-0.28216f, -0.104323f,0.936228f,-0.335549f, --0.455877f,0.874672f,0.164697f, --0.324643f,0.906811f,0.268889f, --0.22917f,0.934048f,0.273927f, --0.11917f,0.945648f,0.302569f, --0.0303449f,0.953424f,0.300104f, -0.0953211f,0.968161f,0.231468f, -0.307551f,0.928088f,0.209914f, -0.396906f,0.882705f,0.251588f, -0.154339f,0.98019f,0.124127f, -0.00614755f,0.999958f,0.00674104f, -0.0862143f,0.995356f,-0.0428297f, -0.0605751f,0.988948f,-0.135323f, -0.116851f,0.991236f,-0.0616197f, -0.0626175f,0.989161f,-0.132815f, -0.0598334f,0.989391f,-0.132381f, -0.0870904f,0.982628f,-0.163882f, -0.0967617f,0.982554f,-0.15882f, -0.0255981f,0.999032f,-0.0357718f, -0.114826f,0.99101f,0.0686587f, -0.196799f,0.954402f,0.22447f, --0.0385546f,0.932725f,0.358521f, --0.332784f,0.924223f,0.18726f, --0.304588f,0.936692f,0.172726f, --0.293315f,0.937819f,0.185638f, --0.274742f,0.953043f,0.127381f, --0.263119f,0.962853f,0.0606766f, --0.268024f,0.959606f,0.0855591f, --0.0879001f,0.973995f,0.208824f, --0.133948f,0.986848f,0.0904876f, --0.113332f,0.988235f,0.102703f, --0.0299834f,0.985262f,0.168402f, --0.19277f,0.976736f,0.0939502f, --0.0881002f,0.973369f,0.211639f, --0.024161f,0.965814f,0.258109f, --0.0447814f,0.977625f,0.205534f, --0.0454862f,0.975256f,0.216349f, --0.133105f,0.964838f,0.22665f, --0.114579f,0.956534f,0.268169f, -0.0712671f,0.941693f,0.328841f, -0.238728f,0.884921f,0.399904f, -0.297664f,0.869038f,0.395183f, --0.00961778f,0.988677f,0.149748f, --0.265709f,0.963666f,-0.0273077f, --0.143358f,0.988736f,0.0430136f, --0.00534208f,0.998711f,-0.0504723f, -0.174549f,0.979244f,-0.103024f, -0.0753759f,0.97722f,-0.198391f, --0.0309169f,0.954209f,-0.297538f, -0.114484f,0.932628f,-0.342197f, -0.277629f,0.881086f,-0.382896f, -0.233881f,0.840787f,-0.488238f, -0.145974f,0.866169f,-0.477957f, --0.0214889f,0.855591f,-0.517207f, -0.015747f,0.850281f,-0.526094f, -0.181736f,0.859322f,-0.478056f, -0.233268f,0.832868f,-0.501913f, -0.278912f,0.819449f,-0.500711f, -0.37496f,0.838284f,-0.395834f, -0.211098f,0.909912f,-0.357069f, -0.0173895f,0.949305f,-0.313875f, -0.0778513f,0.935569f,-0.344455f, -0.13573f,0.919161f,-0.369756f, -0.128317f,0.903382f,-0.40919f, -0.134873f,0.894846f,-0.425512f, -0.140765f,0.922098f,-0.360446f, -0.195779f,0.941368f,-0.274766f, --0.498792f,0.861228f,0.0974355f, --0.334273f,0.933116f,0.132498f, --0.209899f,0.97009f,0.121936f, --0.146122f,0.979163f,0.141027f, --0.00844043f,0.991347f,0.130997f, -0.183871f,0.98064f,0.0673491f, -0.295623f,0.955305f,0.000649681f, -0.325261f,0.940591f,0.0974362f, -0.279972f,0.936209f,0.212435f, -0.117319f,0.989809f,0.0807136f, -0.167452f,0.985876f,0.00303625f, -0.0997326f,0.991951f,-0.0780129f, -0.0970545f,0.989541f,-0.106723f, -0.122983f,0.982138f,-0.14241f, -0.0889416f,0.984545f,-0.150867f, -0.0922265f,0.975522f,-0.199627f, -0.0767647f,0.98447f,-0.15788f, --0.0166949f,0.981051f,-0.193027f, --0.0192651f,0.97159f,-0.235885f, --0.0430007f,0.99834f,-0.038322f, --0.1057f,0.976121f,0.189775f, --0.21501f,0.968939f,0.122177f, --0.312622f,0.947332f,0.0695023f, --0.268759f,0.958656f,0.0935212f, --0.210053f,0.974561f,0.0781578f, --0.280996f,0.956877f,0.0736733f, --0.29425f,0.945004f,0.142776f, --0.103752f,0.988352f,0.111339f, --0.0179991f,0.994529f,0.102897f, --0.257355f,0.965403f,0.0420096f, --0.105403f,0.956057f,0.273578f, --0.10459f,0.942017f,0.318851f, --0.129983f,0.956026f,0.262903f, --0.0671262f,0.95499f,0.288944f, --0.00387184f,0.948915f,0.315508f, --0.104327f,0.957897f,0.267486f, --0.136557f,0.931775f,0.336375f, --0.0981417f,0.964639f,0.24462f, -0.0564237f,0.977306f,0.204178f, -0.151449f,0.955346f,0.253725f, -0.313069f,0.882901f,0.349962f, -0.317375f,0.903515f,0.287983f, --0.14146f,0.988238f,-0.0580959f, --0.183704f,0.977531f,-0.10337f, -0.0729777f,0.993775f,-0.0841813f, -0.241185f,0.959561f,-0.145165f, -0.180872f,0.946861f,-0.26597f, -0.0759246f,0.918564f,-0.387911f, -0.0834031f,0.881426f,-0.4649f, -0.312989f,0.886301f,-0.341334f, -0.345782f,0.8869f,-0.306339f, -0.190174f,0.893803f,-0.40614f, -0.0967003f,0.870562f,-0.482463f, --0.011292f,0.813313f,-0.581716f, -0.104307f,0.818569f,-0.564858f, -0.278742f,0.804599f,-0.524332f, -0.252871f,0.80123f,-0.542298f, -0.288393f,0.816691f,-0.499846f, -0.158986f,0.877853f,-0.451771f, --0.0422089f,0.892803f,-0.448466f, -0.0676213f,0.902423f,-0.425511f, -0.196008f,0.897779f,-0.394428f, -0.174291f,0.88488f,-0.431984f, -0.107973f,0.893114f,-0.43668f, -0.0286973f,0.916566f,-0.398853f, -0.0334026f,0.935074f,-0.352875f, --0.456752f,0.886621f,-0.0726759f, --0.35821f,0.92461f,-0.129546f, --0.255187f,0.962466f,-0.0924034f, --0.153659f,0.987984f,-0.0166497f, -0.0326193f,0.998752f,-0.0378261f, -0.219848f,0.975435f,-0.0138776f, -0.325192f,0.945498f,0.0168406f, -0.223054f,0.973348f,-0.0532875f, -0.221049f,0.975263f,0.000679153f, -0.242907f,0.969656f,0.0276409f, -0.175892f,0.983375f,-0.0451076f, -0.180873f,0.98342f,0.0130764f, -0.169259f,0.981997f,-0.0838673f, -0.138819f,0.973225f,-0.183198f, -0.0923263f,0.975478f,-0.199795f, -0.109785f,0.97291f,-0.203452f, -0.048887f,0.975403f,-0.214938f, -0.0862303f,0.974446f,-0.207409f, -0.0239822f,0.965181f,-0.260482f, --0.234299f,0.93066f,-0.281028f, --0.183154f,0.968628f,-0.167974f, --0.163946f,0.9725f,-0.165423f, --0.29935f,0.945623f,-0.127226f, --0.309491f,0.943295f,-0.120043f, --0.244588f,0.967669f,-0.0615978f, --0.316375f,0.948228f,-0.0277512f, --0.278706f,0.959538f,-0.0401272f, --0.112855f,0.98959f,-0.0893067f, --0.0120823f,0.999804f,0.015665f, --0.269265f,0.962743f,0.0249422f, --0.319779f,0.940968f,0.110998f, --0.127925f,0.957822f,0.257316f, --0.134411f,0.958853f,0.250069f, --0.0963489f,0.939739f,0.328035f, -0.013379f,0.931979f,0.362265f, --0.059723f,0.950577f,0.304692f, --0.140375f,0.96932f,0.201776f, -0.0285405f,0.975242f,0.219289f, -0.0759984f,0.981739f,0.174395f, -0.082912f,0.985645f,0.14707f, -0.244118f,0.959921f,0.137686f, -0.433469f,0.888297f,0.151764f, -0.159753f,0.986026f,0.0472448f, --0.155828f,0.965805f,-0.207217f, -0.0529598f,0.961817f,-0.268522f, -0.302231f,0.91749f,-0.258588f, -0.300969f,0.905771f,-0.298324f, -0.219954f,0.902269f,-0.370851f, -0.168125f,0.874674f,-0.45462f, -0.0852064f,0.832228f,-0.547846f, -0.293285f,0.876411f,-0.381953f, -0.299707f,0.878674f,-0.371628f, -0.169625f,0.87124f,-0.460618f, -0.152784f,0.862886f,-0.481751f, -0.140952f,0.826781f,-0.544578f, -0.216806f,0.796193f,-0.564865f, -0.252088f,0.778347f,-0.575003f, -0.184028f,0.779276f,-0.599052f, -0.07662f,0.847353f,-0.525474f, --0.000576164f,0.875581f,-0.483072f, -0.0676453f,0.855821f,-0.51283f, -0.10935f,0.864233f,-0.491064f, -0.170357f,0.902391f,-0.395814f, -0.0783522f,0.922085f,-0.378973f, --0.0376769f,0.945309f,-0.323992f, --0.0145087f,0.973617f,-0.227725f, --0.23379f,0.969091f,0.0787691f, --0.308611f,0.949667f,-0.0537712f, --0.26795f,0.959457f,-0.087437f, --0.196118f,0.96672f,-0.16429f, -0.0184009f,0.993828f,-0.109391f, -0.124962f,0.988681f,-0.0830367f, -0.297057f,0.954812f,-0.00955538f, -0.355506f,0.934478f,-0.0191401f, -0.206845f,0.957298f,-0.201981f, -0.24827f,0.946264f,-0.207234f, -0.137685f,0.959548f,-0.245584f, -0.129837f,0.983718f,-0.124261f, -0.240211f,0.966075f,-0.0948542f, -0.253383f,0.959847f,-0.120381f, -0.101386f,0.970431f,-0.219056f, -0.110568f,0.971775f,-0.208395f, -0.09998f,0.968593f,-0.227667f, -0.051279f,0.9528f,-0.299236f, -0.0182953f,0.960636f,-0.277207f, --0.177379f,0.948528f,-0.262356f, --0.248744f,0.930203f,-0.269905f, --0.201336f,0.9681f,-0.14915f, --0.308378f,0.940105f,-0.145279f, --0.337871f,0.915739f,-0.217407f, --0.303349f,0.940151f,-0.155226f, --0.267648f,0.955794f,-0.121746f, --0.256838f,0.946595f,-0.194914f, --0.151848f,0.978969f,-0.136244f, --0.166527f,0.98578f,-0.0225025f, --0.271416f,0.956933f,0.103014f, --0.388293f,0.921445f,0.0129329f, --0.211649f,0.973838f,0.0827345f, --0.164151f,0.971899f,0.168719f, --0.20343f,0.950968f,0.232971f, --0.0501604f,0.944198f,0.325535f, -0.0851988f,0.916779f,0.390203f, --0.0675238f,0.966737f,0.246698f, --0.050967f,0.964665f,0.258503f, -0.0897532f,0.945965f,0.311599f, -0.203817f,0.954291f,0.218604f, -0.298323f,0.9542f,0.0224806f, -0.409994f,0.911395f,0.0355409f, -0.297451f,0.952362f,0.0673044f, -0.087158f,0.982486f,-0.164695f, -0.130693f,0.926163f,-0.353753f, -0.287973f,0.877932f,-0.3825f, -0.285473f,0.870692f,-0.400501f, -0.210236f,0.894171f,-0.395297f, -0.291478f,0.889926f,-0.350816f, -0.238796f,0.833f,-0.499086f, -0.156519f,0.786723f,-0.597134f, -0.265294f,0.807831f,-0.526334f, -0.196683f,0.821511f,-0.535197f, -0.111545f,0.852981f,-0.509883f, -0.148451f,0.876975f,-0.457031f, -0.27925f,0.865803f,-0.415216f, -0.364812f,0.845771f,-0.389337f, -0.213362f,0.862896f,-0.458135f, --0.014091f,0.870788f,-0.491456f, --0.0389733f,0.872117f,-0.487742f, -0.0697073f,0.876793f,-0.475789f, -0.0500075f,0.893805f,-0.445659f, -0.0507492f,0.920605f,-0.387184f, -0.00717016f,0.971083f,-0.238636f, --0.12982f,0.987525f,-0.0891113f, --0.196671f,0.977747f,-0.0730188f, --0.180786f,0.972597f,0.146192f, --0.276836f,0.956623f,0.0907445f, --0.145247f,0.980389f,0.133193f, --0.201228f,0.967008f,-0.156214f, --0.0137179f,0.995281f,-0.0960578f, -0.139707f,0.987867f,-0.0678349f, -0.246306f,0.96116f,-0.124516f, -0.421865f,0.906227f,-0.0279788f, -0.299255f,0.934152f,-0.194439f, -0.288356f,0.912569f,-0.289945f, -0.0853497f,0.915952f,-0.392106f, -0.039019f,0.957394f,-0.286136f, -0.208597f,0.95771f,-0.198188f, -0.25753f,0.95731f,-0.131287f, -0.153643f,0.978938f,-0.134439f, -0.0994252f,0.976974f,-0.188775f, -0.12654f,0.974603f,-0.184759f, -0.142684f,0.966335f,-0.214099f, --0.00843645f,0.93512f,-0.354231f, --0.17704f,0.933769f,-0.311017f, --0.343277f,0.895674f,-0.282717f, --0.276715f,0.959562f,-0.0516624f, --0.215753f,0.976427f,-0.00633257f, --0.305134f,0.926522f,-0.220112f, --0.33388f,0.920497f,-0.203001f, --0.259644f,0.948413f,-0.181927f, --0.268974f,0.938104f,-0.218205f, --0.245938f,0.962991f,-0.110289f, --0.275564f,0.96071f,0.0331654f, --0.258271f,0.944524f,0.202903f, --0.309053f,0.947461f,0.0824847f, --0.320335f,0.94673f,-0.0329778f, --0.208609f,0.963472f,0.167941f, --0.270763f,0.941796f,0.199269f, --0.104692f,0.947993f,0.30058f, -0.0304241f,0.930802f,0.364255f, -0.0189457f,0.906511f,0.421757f, --0.0823065f,0.924037f,0.373337f, -0.102263f,0.911082f,0.39934f, -0.325851f,0.888801f,0.322263f, -0.371159f,0.927767f,0.0385981f, -0.355076f,0.934525f,0.0241533f, -0.375158f,0.916478f,0.139015f, -0.286108f,0.953917f,-0.0904664f, -0.199009f,0.919897f,-0.337913f, -0.358636f,0.872243f,-0.332523f, -0.268543f,0.846175f,-0.460296f, -0.182977f,0.871041f,-0.455858f, -0.289295f,0.860781f,-0.418765f, -0.382576f,0.820168f,-0.425393f, -0.183794f,0.780369f,-0.597699f, -0.239111f,0.770893f,-0.590381f, -0.11759f,0.781853f,-0.612273f, -0.0625615f,0.849006f,-0.524666f, -0.09237f,0.869569f,-0.485096f, -0.210947f,0.881757f,-0.421908f, -0.36331f,0.890409f,-0.274185f, -0.280816f,0.923638f,-0.260836f, -0.0186632f,0.936387f,-0.350473f, --0.00764646f,0.914133f,-0.405343f, -0.0383964f,0.885647f,-0.462769f, -0.0296537f,0.913944f,-0.404755f, --0.02984f,0.920171f,-0.390377f, --0.172982f,0.943792f,-0.281663f, --0.19032f,0.979403f,0.0674393f, --0.205961f,0.972526f,0.108505f, -}; - -btScalar Landscape08Tex[] = { -0.0f,0.757813f, -0.0f,0.75f, -0.0078125f,0.757813f, -0.0078125f,0.75f, -0.015625f,0.757813f, -0.015625f,0.75f, -0.0234375f,0.757813f, -0.0234375f,0.75f, -0.03125f,0.757813f, -0.03125f,0.75f, -0.0390625f,0.757813f, -0.0390625f,0.75f, -0.046875f,0.757813f, -0.046875f,0.75f, -0.0546875f,0.757813f, -0.0546875f,0.75f, -0.0625f,0.757813f, -0.0625f,0.75f, -0.0703125f,0.757813f, -0.0703125f,0.75f, -0.078125f,0.757813f, -0.078125f,0.75f, -0.0859375f,0.757813f, -0.0859375f,0.75f, -0.09375f,0.757813f, -0.09375f,0.75f, -0.101563f,0.757813f, -0.101563f,0.75f, -0.109375f,0.757813f, -0.109375f,0.75f, -0.117188f,0.757813f, -0.117188f,0.75f, -0.125f,0.757813f, -0.125f,0.75f, -0.132813f,0.757813f, -0.132813f,0.75f, -0.140625f,0.757813f, -0.140625f,0.75f, -0.148438f,0.757813f, -0.148438f,0.75f, -0.15625f,0.757813f, -0.15625f,0.75f, -0.164063f,0.757813f, -0.164063f,0.75f, -0.171875f,0.757813f, -0.171875f,0.75f, -0.179688f,0.757813f, -0.179688f,0.75f, -0.1875f,0.757813f, -0.1875f,0.75f, -0.195313f,0.757813f, -0.195313f,0.75f, -0.203125f,0.757813f, -0.203125f,0.75f, -0.210938f,0.757813f, -0.210938f,0.75f, -0.21875f,0.757813f, -0.21875f,0.75f, -0.226563f,0.757813f, -0.226563f,0.75f, -0.234375f,0.757813f, -0.234375f,0.75f, -0.242188f,0.757813f, -0.242188f,0.75f, -0.25f,0.757813f, -0.25f,0.75f, -0.257813f,0.757813f, -0.257813f,0.75f, -0.265625f,0.757813f, -0.265625f,0.75f, -0.273438f,0.757813f, -0.273438f,0.75f, -0.28125f,0.757813f, -0.28125f,0.75f, -0.289063f,0.757813f, -0.289063f,0.75f, -0.296875f,0.757813f, -0.296875f,0.75f, -0.304688f,0.757813f, -0.304688f,0.75f, -0.3125f,0.757813f, -0.3125f,0.75f, -0.320313f,0.757813f, -0.320313f,0.75f, -0.328125f,0.757813f, -0.328125f,0.75f, -0.335938f,0.757813f, -0.335938f,0.75f, -0.34375f,0.757813f, -0.34375f,0.75f, -0.351563f,0.757813f, -0.351563f,0.75f, -0.359375f,0.757813f, -0.359375f,0.75f, -0.367188f,0.757813f, -0.367188f,0.75f, -0.375f,0.757813f, -0.375f,0.75f, -0.382813f,0.757813f, -0.382813f,0.75f, -0.390625f,0.757813f, -0.390625f,0.75f, -0.398438f,0.757813f, -0.398438f,0.75f, -0.40625f,0.757813f, -0.40625f,0.75f, -0.414063f,0.757813f, -0.414063f,0.75f, -0.421875f,0.757813f, -0.421875f,0.75f, -0.429688f,0.757813f, -0.429688f,0.75f, -0.4375f,0.757813f, -0.4375f,0.75f, -0.445313f,0.757813f, -0.445313f,0.75f, -0.453125f,0.757813f, -0.453125f,0.75f, -0.460938f,0.757813f, -0.460938f,0.75f, -0.46875f,0.757813f, -0.46875f,0.75f, -0.476563f,0.757813f, -0.476563f,0.75f, -0.484375f,0.757813f, -0.484375f,0.75f, -0.492188f,0.757813f, -0.492188f,0.75f, -0.5f,0.757813f, -0.5f,0.75f, -0.507813f,0.757813f, -0.507813f,0.75f, -0.0f,0.765625f, -0.0078125f,0.765625f, -0.015625f,0.765625f, -0.0234375f,0.765625f, -0.03125f,0.765625f, -0.0390625f,0.765625f, -0.046875f,0.765625f, -0.0546875f,0.765625f, -0.0625f,0.765625f, -0.0703125f,0.765625f, -0.078125f,0.765625f, -0.0859375f,0.765625f, -0.09375f,0.765625f, -0.101563f,0.765625f, -0.109375f,0.765625f, -0.117188f,0.765625f, -0.125f,0.765625f, -0.132813f,0.765625f, -0.140625f,0.765625f, -0.148438f,0.765625f, -0.15625f,0.765625f, -0.164063f,0.765625f, -0.171875f,0.765625f, -0.179688f,0.765625f, -0.1875f,0.765625f, -0.195313f,0.765625f, -0.203125f,0.765625f, -0.210938f,0.765625f, -0.21875f,0.765625f, -0.226563f,0.765625f, -0.234375f,0.765625f, -0.242188f,0.765625f, -0.25f,0.765625f, -0.257813f,0.765625f, -0.265625f,0.765625f, -0.273438f,0.765625f, -0.28125f,0.765625f, -0.289063f,0.765625f, -0.296875f,0.765625f, -0.304688f,0.765625f, -0.3125f,0.765625f, -0.320313f,0.765625f, -0.328125f,0.765625f, -0.335938f,0.765625f, -0.34375f,0.765625f, -0.351563f,0.765625f, -0.359375f,0.765625f, -0.367188f,0.765625f, -0.375f,0.765625f, -0.382813f,0.765625f, -0.390625f,0.765625f, -0.398438f,0.765625f, -0.40625f,0.765625f, -0.414063f,0.765625f, -0.421875f,0.765625f, -0.429688f,0.765625f, -0.4375f,0.765625f, -0.445313f,0.765625f, -0.453125f,0.765625f, -0.460938f,0.765625f, -0.46875f,0.765625f, -0.476563f,0.765625f, -0.484375f,0.765625f, -0.492188f,0.765625f, -0.5f,0.765625f, -0.507813f,0.765625f, -0.0f,0.773438f, -0.0078125f,0.773438f, -0.015625f,0.773438f, -0.0234375f,0.773438f, -0.03125f,0.773438f, -0.0390625f,0.773438f, -0.046875f,0.773438f, -0.0546875f,0.773438f, -0.0625f,0.773438f, -0.0703125f,0.773438f, -0.078125f,0.773438f, -0.0859375f,0.773438f, -0.09375f,0.773438f, -0.101563f,0.773438f, -0.109375f,0.773438f, -0.117188f,0.773438f, -0.125f,0.773438f, -0.132813f,0.773438f, -0.140625f,0.773438f, -0.148438f,0.773438f, -0.15625f,0.773438f, -0.164063f,0.773438f, -0.171875f,0.773438f, -0.179688f,0.773438f, -0.1875f,0.773438f, -0.195313f,0.773438f, -0.203125f,0.773438f, -0.210938f,0.773438f, -0.21875f,0.773438f, -0.226563f,0.773438f, -0.234375f,0.773438f, -0.242188f,0.773438f, -0.25f,0.773438f, -0.257813f,0.773438f, -0.265625f,0.773438f, -0.273438f,0.773438f, -0.28125f,0.773438f, -0.289063f,0.773438f, -0.296875f,0.773438f, -0.304688f,0.773438f, -0.3125f,0.773438f, -0.320313f,0.773438f, -0.328125f,0.773438f, -0.335938f,0.773438f, -0.34375f,0.773438f, -0.351563f,0.773438f, -0.359375f,0.773438f, -0.367188f,0.773438f, -0.375f,0.773438f, -0.382813f,0.773438f, -0.390625f,0.773438f, -0.398438f,0.773438f, -0.40625f,0.773438f, -0.414063f,0.773438f, -0.421875f,0.773438f, -0.429688f,0.773438f, -0.4375f,0.773438f, -0.445313f,0.773438f, -0.453125f,0.773438f, -0.460938f,0.773438f, -0.46875f,0.773438f, -0.476563f,0.773438f, -0.484375f,0.773438f, -0.492188f,0.773438f, -0.5f,0.773438f, -0.507813f,0.773438f, -0.0f,0.78125f, -0.0078125f,0.78125f, -0.015625f,0.78125f, -0.0234375f,0.78125f, -0.03125f,0.78125f, -0.0390625f,0.78125f, -0.046875f,0.78125f, -0.0546875f,0.78125f, -0.0625f,0.78125f, -0.0703125f,0.78125f, -0.078125f,0.78125f, -0.0859375f,0.78125f, -0.09375f,0.78125f, -0.101563f,0.78125f, -0.109375f,0.78125f, -0.117188f,0.78125f, -0.125f,0.78125f, -0.132813f,0.78125f, -0.140625f,0.78125f, -0.148438f,0.78125f, -0.15625f,0.78125f, -0.164063f,0.78125f, -0.171875f,0.78125f, -0.179688f,0.78125f, -0.1875f,0.78125f, -0.195313f,0.78125f, -0.203125f,0.78125f, -0.210938f,0.78125f, -0.21875f,0.78125f, -0.226563f,0.78125f, -0.234375f,0.78125f, -0.242188f,0.78125f, -0.25f,0.78125f, -0.257813f,0.78125f, -0.265625f,0.78125f, -0.273438f,0.78125f, -0.28125f,0.78125f, -0.289063f,0.78125f, -0.296875f,0.78125f, -0.304688f,0.78125f, -0.3125f,0.78125f, -0.320313f,0.78125f, -0.328125f,0.78125f, -0.335938f,0.78125f, -0.34375f,0.78125f, -0.351563f,0.78125f, -0.359375f,0.78125f, -0.367188f,0.78125f, -0.375f,0.78125f, -0.382813f,0.78125f, -0.390625f,0.78125f, -0.398438f,0.78125f, -0.40625f,0.78125f, -0.414063f,0.78125f, -0.421875f,0.78125f, -0.429688f,0.78125f, -0.4375f,0.78125f, -0.445313f,0.78125f, -0.453125f,0.78125f, -0.460938f,0.78125f, -0.46875f,0.78125f, -0.476563f,0.78125f, -0.484375f,0.78125f, -0.492188f,0.78125f, -0.5f,0.78125f, -0.507813f,0.78125f, -0.0f,0.789063f, -0.0078125f,0.789063f, -0.015625f,0.789063f, -0.0234375f,0.789063f, -0.03125f,0.789063f, -0.0390625f,0.789063f, -0.046875f,0.789063f, -0.0546875f,0.789063f, -0.0625f,0.789063f, -0.0703125f,0.789063f, -0.078125f,0.789063f, -0.0859375f,0.789063f, -0.09375f,0.789063f, -0.101563f,0.789063f, -0.109375f,0.789063f, -0.117188f,0.789063f, -0.125f,0.789063f, -0.132813f,0.789063f, -0.140625f,0.789063f, -0.148438f,0.789063f, -0.15625f,0.789063f, -0.164063f,0.789063f, -0.171875f,0.789063f, -0.179688f,0.789063f, -0.1875f,0.789063f, -0.195313f,0.789063f, -0.203125f,0.789063f, -0.210938f,0.789063f, -0.21875f,0.789063f, -0.226563f,0.789063f, -0.234375f,0.789063f, -0.242188f,0.789063f, -0.25f,0.789063f, -0.257813f,0.789063f, -0.265625f,0.789063f, -0.273438f,0.789063f, -0.28125f,0.789063f, -0.289063f,0.789063f, -0.296875f,0.789063f, -0.304688f,0.789063f, -0.3125f,0.789063f, -0.320313f,0.789063f, -0.328125f,0.789063f, -0.335938f,0.789063f, -0.34375f,0.789063f, -0.351563f,0.789063f, -0.359375f,0.789063f, -0.367188f,0.789063f, -0.375f,0.789063f, -0.382813f,0.789063f, -0.390625f,0.789063f, -0.398438f,0.789063f, -0.40625f,0.789063f, -0.414063f,0.789063f, -0.421875f,0.789063f, -0.429688f,0.789063f, -0.4375f,0.789063f, -0.445313f,0.789063f, -0.453125f,0.789063f, -0.460938f,0.789063f, -0.46875f,0.789063f, -0.476563f,0.789063f, -0.484375f,0.789063f, -0.492188f,0.789063f, -0.5f,0.789063f, -0.507813f,0.789063f, -0.0f,0.796875f, -0.0078125f,0.796875f, -0.015625f,0.796875f, -0.0234375f,0.796875f, -0.03125f,0.796875f, -0.0390625f,0.796875f, -0.046875f,0.796875f, -0.0546875f,0.796875f, -0.0625f,0.796875f, -0.0703125f,0.796875f, -0.078125f,0.796875f, -0.0859375f,0.796875f, -0.09375f,0.796875f, -0.101563f,0.796875f, -0.109375f,0.796875f, -0.117188f,0.796875f, -0.125f,0.796875f, -0.132813f,0.796875f, -0.140625f,0.796875f, -0.148438f,0.796875f, -0.15625f,0.796875f, -0.164063f,0.796875f, -0.171875f,0.796875f, -0.179688f,0.796875f, -0.1875f,0.796875f, -0.195313f,0.796875f, -0.203125f,0.796875f, -0.210938f,0.796875f, -0.21875f,0.796875f, -0.226563f,0.796875f, -0.234375f,0.796875f, -0.242188f,0.796875f, -0.25f,0.796875f, -0.257813f,0.796875f, -0.265625f,0.796875f, -0.273438f,0.796875f, -0.28125f,0.796875f, -0.289063f,0.796875f, -0.296875f,0.796875f, -0.304688f,0.796875f, -0.3125f,0.796875f, -0.320313f,0.796875f, -0.328125f,0.796875f, -0.335938f,0.796875f, -0.34375f,0.796875f, -0.351563f,0.796875f, -0.359375f,0.796875f, -0.367188f,0.796875f, -0.375f,0.796875f, -0.382813f,0.796875f, -0.390625f,0.796875f, -0.398438f,0.796875f, -0.40625f,0.796875f, -0.414063f,0.796875f, -0.421875f,0.796875f, -0.429688f,0.796875f, -0.4375f,0.796875f, -0.445313f,0.796875f, -0.453125f,0.796875f, -0.460938f,0.796875f, -0.46875f,0.796875f, -0.476563f,0.796875f, -0.484375f,0.796875f, -0.492188f,0.796875f, -0.5f,0.796875f, -0.507813f,0.796875f, -0.0f,0.804688f, -0.0078125f,0.804688f, -0.015625f,0.804688f, -0.0234375f,0.804688f, -0.03125f,0.804688f, -0.0390625f,0.804688f, -0.046875f,0.804688f, -0.0546875f,0.804688f, -0.0625f,0.804688f, -0.0703125f,0.804688f, -0.078125f,0.804688f, -0.0859375f,0.804688f, -0.09375f,0.804688f, -0.101563f,0.804688f, -0.109375f,0.804688f, -0.117188f,0.804688f, -0.125f,0.804688f, -0.132813f,0.804688f, -0.140625f,0.804688f, -0.148438f,0.804688f, -0.15625f,0.804688f, -0.164063f,0.804688f, -0.171875f,0.804688f, -0.179688f,0.804688f, -0.1875f,0.804688f, -0.195313f,0.804688f, -0.203125f,0.804688f, -0.210938f,0.804688f, -0.21875f,0.804688f, -0.226563f,0.804688f, -0.234375f,0.804688f, -0.242188f,0.804688f, -0.25f,0.804688f, -0.257813f,0.804688f, -0.265625f,0.804688f, -0.273438f,0.804688f, -0.28125f,0.804688f, -0.289063f,0.804688f, -0.296875f,0.804688f, -0.304688f,0.804688f, -0.3125f,0.804688f, -0.320313f,0.804688f, -0.328125f,0.804688f, -0.335938f,0.804688f, -0.34375f,0.804688f, -0.351563f,0.804688f, -0.359375f,0.804688f, -0.367188f,0.804688f, -0.375f,0.804688f, -0.382813f,0.804688f, -0.390625f,0.804688f, -0.398438f,0.804688f, -0.40625f,0.804688f, -0.414063f,0.804688f, -0.421875f,0.804688f, -0.429688f,0.804688f, -0.4375f,0.804688f, -0.445313f,0.804688f, -0.453125f,0.804688f, -0.460938f,0.804688f, -0.46875f,0.804688f, -0.476563f,0.804688f, -0.484375f,0.804688f, -0.492188f,0.804688f, -0.5f,0.804688f, -0.507813f,0.804688f, -0.0f,0.8125f, -0.0078125f,0.8125f, -0.015625f,0.8125f, -0.0234375f,0.8125f, -0.03125f,0.8125f, -0.0390625f,0.8125f, -0.046875f,0.8125f, -0.0546875f,0.8125f, -0.0625f,0.8125f, -0.0703125f,0.8125f, -0.078125f,0.8125f, -0.0859375f,0.8125f, -0.09375f,0.8125f, -0.101563f,0.8125f, -0.109375f,0.8125f, -0.117188f,0.8125f, -0.125f,0.8125f, -0.132813f,0.8125f, -0.140625f,0.8125f, -0.148438f,0.8125f, -0.15625f,0.8125f, -0.164063f,0.8125f, -0.171875f,0.8125f, -0.179688f,0.8125f, -0.1875f,0.8125f, -0.195313f,0.8125f, -0.203125f,0.8125f, -0.210938f,0.8125f, -0.21875f,0.8125f, -0.226563f,0.8125f, -0.234375f,0.8125f, -0.242188f,0.8125f, -0.25f,0.8125f, -0.257813f,0.8125f, -0.265625f,0.8125f, -0.273438f,0.8125f, -0.28125f,0.8125f, -0.289063f,0.8125f, -0.296875f,0.8125f, -0.304688f,0.8125f, -0.3125f,0.8125f, -0.320313f,0.8125f, -0.328125f,0.8125f, -0.335938f,0.8125f, -0.34375f,0.8125f, -0.351563f,0.8125f, -0.359375f,0.8125f, -0.367188f,0.8125f, -0.375f,0.8125f, -0.382813f,0.8125f, -0.390625f,0.8125f, -0.398438f,0.8125f, -0.40625f,0.8125f, -0.414063f,0.8125f, -0.421875f,0.8125f, -0.429688f,0.8125f, -0.4375f,0.8125f, -0.445313f,0.8125f, -0.453125f,0.8125f, -0.460938f,0.8125f, -0.46875f,0.8125f, -0.476563f,0.8125f, -0.484375f,0.8125f, -0.492188f,0.8125f, -0.5f,0.8125f, -0.507813f,0.8125f, -0.0f,0.820313f, -0.0078125f,0.820313f, -0.015625f,0.820313f, -0.0234375f,0.820313f, -0.03125f,0.820313f, -0.0390625f,0.820313f, -0.046875f,0.820313f, -0.0546875f,0.820313f, -0.0625f,0.820313f, -0.0703125f,0.820313f, -0.078125f,0.820313f, -0.0859375f,0.820313f, -0.09375f,0.820313f, -0.101563f,0.820313f, -0.109375f,0.820313f, -0.117188f,0.820313f, -0.125f,0.820313f, -0.132813f,0.820313f, -0.140625f,0.820313f, -0.148438f,0.820313f, -0.15625f,0.820313f, -0.164063f,0.820313f, -0.171875f,0.820313f, -0.179688f,0.820313f, -0.1875f,0.820313f, -0.195313f,0.820313f, -0.203125f,0.820313f, -0.210938f,0.820313f, -0.21875f,0.820313f, -0.226563f,0.820313f, -0.234375f,0.820313f, -0.242188f,0.820313f, -0.25f,0.820313f, -0.257813f,0.820313f, -0.265625f,0.820313f, -0.273438f,0.820313f, -0.28125f,0.820313f, -0.289063f,0.820313f, -0.296875f,0.820313f, -0.304688f,0.820313f, -0.3125f,0.820313f, -0.320313f,0.820313f, -0.328125f,0.820313f, -0.335938f,0.820313f, -0.34375f,0.820313f, -0.351563f,0.820313f, -0.359375f,0.820313f, -0.367188f,0.820313f, -0.375f,0.820313f, -0.382813f,0.820313f, -0.390625f,0.820313f, -0.398438f,0.820313f, -0.40625f,0.820313f, -0.414063f,0.820313f, -0.421875f,0.820313f, -0.429688f,0.820313f, -0.4375f,0.820313f, -0.445313f,0.820313f, -0.453125f,0.820313f, -0.460938f,0.820313f, -0.46875f,0.820313f, -0.476563f,0.820313f, -0.484375f,0.820313f, -0.492188f,0.820313f, -0.5f,0.820313f, -0.507813f,0.820313f, -0.0f,0.828125f, -0.0078125f,0.828125f, -0.015625f,0.828125f, -0.0234375f,0.828125f, -0.03125f,0.828125f, -0.0390625f,0.828125f, -0.046875f,0.828125f, -0.0546875f,0.828125f, -0.0625f,0.828125f, -0.0703125f,0.828125f, -0.078125f,0.828125f, -0.0859375f,0.828125f, -0.09375f,0.828125f, -0.101563f,0.828125f, -0.109375f,0.828125f, -0.117188f,0.828125f, -0.125f,0.828125f, -0.132813f,0.828125f, -0.140625f,0.828125f, -0.148438f,0.828125f, -0.15625f,0.828125f, -0.164063f,0.828125f, -0.171875f,0.828125f, -0.179688f,0.828125f, -0.1875f,0.828125f, -0.195313f,0.828125f, -0.203125f,0.828125f, -0.210938f,0.828125f, -0.21875f,0.828125f, -0.226563f,0.828125f, -0.234375f,0.828125f, -0.242188f,0.828125f, -0.25f,0.828125f, -0.257813f,0.828125f, -0.265625f,0.828125f, -0.273438f,0.828125f, -0.28125f,0.828125f, -0.289063f,0.828125f, -0.296875f,0.828125f, -0.304688f,0.828125f, -0.3125f,0.828125f, -0.320313f,0.828125f, -0.328125f,0.828125f, -0.335938f,0.828125f, -0.34375f,0.828125f, -0.351563f,0.828125f, -0.359375f,0.828125f, -0.367188f,0.828125f, -0.375f,0.828125f, -0.382813f,0.828125f, -0.390625f,0.828125f, -0.398438f,0.828125f, -0.40625f,0.828125f, -0.414063f,0.828125f, -0.421875f,0.828125f, -0.429688f,0.828125f, -0.4375f,0.828125f, -0.445313f,0.828125f, -0.453125f,0.828125f, -0.460938f,0.828125f, -0.46875f,0.828125f, -0.476563f,0.828125f, -0.484375f,0.828125f, -0.492188f,0.828125f, -0.5f,0.828125f, -0.507813f,0.828125f, -0.0f,0.835938f, -0.0078125f,0.835938f, -0.015625f,0.835938f, -0.0234375f,0.835938f, -0.03125f,0.835938f, -0.0390625f,0.835938f, -0.046875f,0.835938f, -0.0546875f,0.835938f, -0.0625f,0.835938f, -0.0703125f,0.835938f, -0.078125f,0.835938f, -0.0859375f,0.835938f, -0.09375f,0.835938f, -0.101563f,0.835938f, -0.109375f,0.835938f, -0.117188f,0.835938f, -0.125f,0.835938f, -0.132813f,0.835938f, -0.140625f,0.835938f, -0.148438f,0.835938f, -0.15625f,0.835938f, -0.164063f,0.835938f, -0.171875f,0.835938f, -0.179688f,0.835938f, -0.1875f,0.835938f, -0.195313f,0.835938f, -0.203125f,0.835938f, -0.210938f,0.835938f, -0.21875f,0.835938f, -0.226563f,0.835938f, -0.234375f,0.835938f, -0.242188f,0.835938f, -0.25f,0.835938f, -0.257813f,0.835938f, -0.265625f,0.835938f, -0.273438f,0.835938f, -0.28125f,0.835938f, -0.289063f,0.835938f, -0.296875f,0.835938f, -0.304688f,0.835938f, -0.3125f,0.835938f, -0.320313f,0.835938f, -0.328125f,0.835938f, -0.335938f,0.835938f, -0.34375f,0.835938f, -0.351563f,0.835938f, -0.359375f,0.835938f, -0.367188f,0.835938f, -0.375f,0.835938f, -0.382813f,0.835938f, -0.390625f,0.835938f, -0.398438f,0.835938f, -0.40625f,0.835938f, -0.414063f,0.835938f, -0.421875f,0.835938f, -0.429688f,0.835938f, -0.4375f,0.835938f, -0.445313f,0.835938f, -0.453125f,0.835938f, -0.460938f,0.835938f, -0.46875f,0.835938f, -0.476563f,0.835938f, -0.484375f,0.835938f, -0.492188f,0.835938f, -0.5f,0.835938f, -0.507813f,0.835938f, -0.0f,0.84375f, -0.0078125f,0.84375f, -0.015625f,0.84375f, -0.0234375f,0.84375f, -0.03125f,0.84375f, -0.0390625f,0.84375f, -0.046875f,0.84375f, -0.0546875f,0.84375f, -0.0625f,0.84375f, -0.0703125f,0.84375f, -0.078125f,0.84375f, -0.0859375f,0.84375f, -0.09375f,0.84375f, -0.101563f,0.84375f, -0.109375f,0.84375f, -0.117188f,0.84375f, -0.125f,0.84375f, -0.132813f,0.84375f, -0.140625f,0.84375f, -0.148438f,0.84375f, -0.15625f,0.84375f, -0.164063f,0.84375f, -0.171875f,0.84375f, -0.179688f,0.84375f, -0.1875f,0.84375f, -0.195313f,0.84375f, -0.203125f,0.84375f, -0.210938f,0.84375f, -0.21875f,0.84375f, -0.226563f,0.84375f, -0.234375f,0.84375f, -0.242188f,0.84375f, -0.25f,0.84375f, -0.257813f,0.84375f, -0.265625f,0.84375f, -0.273438f,0.84375f, -0.28125f,0.84375f, -0.289063f,0.84375f, -0.296875f,0.84375f, -0.304688f,0.84375f, -0.3125f,0.84375f, -0.320313f,0.84375f, -0.328125f,0.84375f, -0.335938f,0.84375f, -0.34375f,0.84375f, -0.351563f,0.84375f, -0.359375f,0.84375f, -0.367188f,0.84375f, -0.375f,0.84375f, -0.382813f,0.84375f, -0.390625f,0.84375f, -0.398438f,0.84375f, -0.40625f,0.84375f, -0.414063f,0.84375f, -0.421875f,0.84375f, -0.429688f,0.84375f, -0.4375f,0.84375f, -0.445313f,0.84375f, -0.453125f,0.84375f, -0.460938f,0.84375f, -0.46875f,0.84375f, -0.476563f,0.84375f, -0.484375f,0.84375f, -0.492188f,0.84375f, -0.5f,0.84375f, -0.507813f,0.84375f, -0.0f,0.851563f, -0.0078125f,0.851563f, -0.015625f,0.851563f, -0.0234375f,0.851563f, -0.03125f,0.851563f, -0.0390625f,0.851563f, -0.046875f,0.851563f, -0.0546875f,0.851563f, -0.0625f,0.851563f, -0.0703125f,0.851563f, -0.078125f,0.851563f, -0.0859375f,0.851563f, -0.09375f,0.851563f, -0.101563f,0.851563f, -0.109375f,0.851563f, -0.117188f,0.851563f, -0.125f,0.851563f, -0.132813f,0.851563f, -0.140625f,0.851563f, -0.148438f,0.851563f, -0.15625f,0.851563f, -0.164063f,0.851563f, -0.171875f,0.851563f, -0.179688f,0.851563f, -0.1875f,0.851563f, -0.195313f,0.851563f, -0.203125f,0.851563f, -0.210938f,0.851563f, -0.21875f,0.851563f, -0.226563f,0.851563f, -0.234375f,0.851563f, -0.242188f,0.851563f, -0.25f,0.851563f, -0.257813f,0.851563f, -0.265625f,0.851563f, -0.273438f,0.851563f, -0.28125f,0.851563f, -0.289063f,0.851563f, -0.296875f,0.851563f, -0.304688f,0.851563f, -0.3125f,0.851563f, -0.320313f,0.851563f, -0.328125f,0.851563f, -0.335938f,0.851563f, -0.34375f,0.851563f, -0.351563f,0.851563f, -0.359375f,0.851563f, -0.367188f,0.851563f, -0.375f,0.851563f, -0.382813f,0.851563f, -0.390625f,0.851563f, -0.398438f,0.851563f, -0.40625f,0.851563f, -0.414063f,0.851563f, -0.421875f,0.851563f, -0.429688f,0.851563f, -0.4375f,0.851563f, -0.445313f,0.851563f, -0.453125f,0.851563f, -0.460938f,0.851563f, -0.46875f,0.851563f, -0.476563f,0.851563f, -0.484375f,0.851563f, -0.492188f,0.851563f, -0.5f,0.851563f, -0.507813f,0.851563f, -0.0f,0.859375f, -0.0078125f,0.859375f, -0.015625f,0.859375f, -0.0234375f,0.859375f, -0.03125f,0.859375f, -0.0390625f,0.859375f, -0.046875f,0.859375f, -0.0546875f,0.859375f, -0.0625f,0.859375f, -0.0703125f,0.859375f, -0.078125f,0.859375f, -0.0859375f,0.859375f, -0.09375f,0.859375f, -0.101563f,0.859375f, -0.109375f,0.859375f, -0.117188f,0.859375f, -0.125f,0.859375f, -0.132813f,0.859375f, -0.140625f,0.859375f, -0.148438f,0.859375f, -0.15625f,0.859375f, -0.164063f,0.859375f, -0.171875f,0.859375f, -0.179688f,0.859375f, -0.1875f,0.859375f, -0.195313f,0.859375f, -0.203125f,0.859375f, -0.210938f,0.859375f, -0.21875f,0.859375f, -0.226563f,0.859375f, -0.234375f,0.859375f, -0.242188f,0.859375f, -0.25f,0.859375f, -0.257813f,0.859375f, -0.265625f,0.859375f, -0.273438f,0.859375f, -0.28125f,0.859375f, -0.289063f,0.859375f, -0.296875f,0.859375f, -0.304688f,0.859375f, -0.3125f,0.859375f, -0.320313f,0.859375f, -0.328125f,0.859375f, -0.335938f,0.859375f, -0.34375f,0.859375f, -0.351563f,0.859375f, -0.359375f,0.859375f, -0.367188f,0.859375f, -0.375f,0.859375f, -0.382813f,0.859375f, -0.390625f,0.859375f, -0.398438f,0.859375f, -0.40625f,0.859375f, -0.414063f,0.859375f, -0.421875f,0.859375f, -0.429688f,0.859375f, -0.4375f,0.859375f, -0.445313f,0.859375f, -0.453125f,0.859375f, -0.460938f,0.859375f, -0.46875f,0.859375f, -0.476563f,0.859375f, -0.484375f,0.859375f, -0.492188f,0.859375f, -0.5f,0.859375f, -0.507813f,0.859375f, -0.0f,0.867188f, -0.0078125f,0.867188f, -0.015625f,0.867188f, -0.0234375f,0.867188f, -0.03125f,0.867188f, -0.0390625f,0.867188f, -0.046875f,0.867188f, -0.0546875f,0.867188f, -0.0625f,0.867188f, -0.0703125f,0.867188f, -0.078125f,0.867188f, -0.0859375f,0.867188f, -0.09375f,0.867188f, -0.101563f,0.867188f, -0.109375f,0.867188f, -0.117188f,0.867188f, -0.125f,0.867188f, -0.132813f,0.867188f, -0.140625f,0.867188f, -0.148438f,0.867188f, -0.15625f,0.867188f, -0.164063f,0.867188f, -0.171875f,0.867188f, -0.179688f,0.867188f, -0.1875f,0.867188f, -0.195313f,0.867188f, -0.203125f,0.867188f, -0.210938f,0.867188f, -0.21875f,0.867188f, -0.226563f,0.867188f, -0.234375f,0.867188f, -0.242188f,0.867188f, -0.25f,0.867188f, -0.257813f,0.867188f, -0.265625f,0.867188f, -0.273438f,0.867188f, -0.28125f,0.867188f, -0.289063f,0.867188f, -0.296875f,0.867188f, -0.304688f,0.867188f, -0.3125f,0.867188f, -0.320313f,0.867188f, -0.328125f,0.867188f, -0.335938f,0.867188f, -0.34375f,0.867188f, -0.351563f,0.867188f, -0.359375f,0.867188f, -0.367188f,0.867188f, -0.375f,0.867188f, -0.382813f,0.867188f, -0.390625f,0.867188f, -0.398438f,0.867188f, -0.40625f,0.867188f, -0.414063f,0.867188f, -0.421875f,0.867188f, -0.429688f,0.867188f, -0.4375f,0.867188f, -0.445313f,0.867188f, -0.453125f,0.867188f, -0.460938f,0.867188f, -0.46875f,0.867188f, -0.476563f,0.867188f, -0.484375f,0.867188f, -0.492188f,0.867188f, -0.5f,0.867188f, -0.507813f,0.867188f, -0.0f,0.875f, -0.0078125f,0.875f, -0.015625f,0.875f, -0.0234375f,0.875f, -0.03125f,0.875f, -0.0390625f,0.875f, -0.046875f,0.875f, -0.0546875f,0.875f, -0.0625f,0.875f, -0.0703125f,0.875f, -0.078125f,0.875f, -0.0859375f,0.875f, -0.09375f,0.875f, -0.101563f,0.875f, -0.109375f,0.875f, -0.117188f,0.875f, -0.125f,0.875f, -0.132813f,0.875f, -0.140625f,0.875f, -0.148438f,0.875f, -0.15625f,0.875f, -0.164063f,0.875f, -0.171875f,0.875f, -0.179688f,0.875f, -0.1875f,0.875f, -0.195313f,0.875f, -0.203125f,0.875f, -0.210938f,0.875f, -0.21875f,0.875f, -0.226563f,0.875f, -0.234375f,0.875f, -0.242188f,0.875f, -0.25f,0.875f, -0.257813f,0.875f, -0.265625f,0.875f, -0.273438f,0.875f, -0.28125f,0.875f, -0.289063f,0.875f, -0.296875f,0.875f, -0.304688f,0.875f, -0.3125f,0.875f, -0.320313f,0.875f, -0.328125f,0.875f, -0.335938f,0.875f, -0.34375f,0.875f, -0.351563f,0.875f, -0.359375f,0.875f, -0.367188f,0.875f, -0.375f,0.875f, -0.382813f,0.875f, -0.390625f,0.875f, -0.398438f,0.875f, -0.40625f,0.875f, -0.414063f,0.875f, -0.421875f,0.875f, -0.429688f,0.875f, -0.4375f,0.875f, -0.445313f,0.875f, -0.453125f,0.875f, -0.460938f,0.875f, -0.46875f,0.875f, -0.476563f,0.875f, -0.484375f,0.875f, -0.492188f,0.875f, -0.5f,0.875f, -0.507813f,0.875f, -0.0f,0.882813f, -0.0078125f,0.882813f, -0.015625f,0.882813f, -0.0234375f,0.882813f, -0.03125f,0.882813f, -0.0390625f,0.882813f, -0.046875f,0.882813f, -0.0546875f,0.882813f, -0.0625f,0.882813f, -0.0703125f,0.882813f, -0.078125f,0.882813f, -0.0859375f,0.882813f, -0.09375f,0.882813f, -0.101563f,0.882813f, -0.109375f,0.882813f, -0.117188f,0.882813f, -0.125f,0.882813f, -0.132813f,0.882813f, -0.140625f,0.882813f, -0.148438f,0.882813f, -0.15625f,0.882813f, -0.164063f,0.882813f, -0.171875f,0.882813f, -0.179688f,0.882813f, -0.1875f,0.882813f, -0.195313f,0.882813f, -0.203125f,0.882813f, -0.210938f,0.882813f, -0.21875f,0.882813f, -0.226563f,0.882813f, -0.234375f,0.882813f, -0.242188f,0.882813f, -0.25f,0.882813f, -0.257813f,0.882813f, -0.265625f,0.882813f, -0.273438f,0.882813f, -0.28125f,0.882813f, -0.289063f,0.882813f, -0.296875f,0.882813f, -0.304688f,0.882813f, -0.3125f,0.882813f, -0.320313f,0.882813f, -0.328125f,0.882813f, -0.335938f,0.882813f, -0.34375f,0.882813f, -0.351563f,0.882813f, -0.359375f,0.882813f, -0.367188f,0.882813f, -0.375f,0.882813f, -0.382813f,0.882813f, -0.390625f,0.882813f, -0.398438f,0.882813f, -0.40625f,0.882813f, -0.414063f,0.882813f, -0.421875f,0.882813f, -0.429688f,0.882813f, -0.4375f,0.882813f, -0.445313f,0.882813f, -0.453125f,0.882813f, -0.460938f,0.882813f, -0.46875f,0.882813f, -0.476563f,0.882813f, -0.484375f,0.882813f, -0.492188f,0.882813f, -0.5f,0.882813f, -0.507813f,0.882813f, -0.0f,0.890625f, -0.0078125f,0.890625f, -0.015625f,0.890625f, -0.0234375f,0.890625f, -0.03125f,0.890625f, -0.0390625f,0.890625f, -0.046875f,0.890625f, -0.0546875f,0.890625f, -0.0625f,0.890625f, -0.0703125f,0.890625f, -0.078125f,0.890625f, -0.0859375f,0.890625f, -0.09375f,0.890625f, -0.101563f,0.890625f, -0.109375f,0.890625f, -0.117188f,0.890625f, -0.125f,0.890625f, -0.132813f,0.890625f, -0.140625f,0.890625f, -0.148438f,0.890625f, -0.15625f,0.890625f, -0.164063f,0.890625f, -0.171875f,0.890625f, -0.179688f,0.890625f, -0.1875f,0.890625f, -0.195313f,0.890625f, -0.203125f,0.890625f, -0.210938f,0.890625f, -0.21875f,0.890625f, -0.226563f,0.890625f, -0.234375f,0.890625f, -0.242188f,0.890625f, -0.25f,0.890625f, -0.257813f,0.890625f, -0.265625f,0.890625f, -0.273438f,0.890625f, -0.28125f,0.890625f, -0.289063f,0.890625f, -0.296875f,0.890625f, -0.304688f,0.890625f, -0.3125f,0.890625f, -0.320313f,0.890625f, -0.328125f,0.890625f, -0.335938f,0.890625f, -0.34375f,0.890625f, -0.351563f,0.890625f, -0.359375f,0.890625f, -0.367188f,0.890625f, -0.375f,0.890625f, -0.382813f,0.890625f, -0.390625f,0.890625f, -0.398438f,0.890625f, -0.40625f,0.890625f, -0.414063f,0.890625f, -0.421875f,0.890625f, -0.429688f,0.890625f, -0.4375f,0.890625f, -0.445313f,0.890625f, -0.453125f,0.890625f, -0.460938f,0.890625f, -0.46875f,0.890625f, -0.476563f,0.890625f, -0.484375f,0.890625f, -0.492188f,0.890625f, -0.5f,0.890625f, -0.507813f,0.890625f, -0.0f,0.898438f, -0.0078125f,0.898438f, -0.015625f,0.898438f, -0.0234375f,0.898438f, -0.03125f,0.898438f, -0.0390625f,0.898438f, -0.046875f,0.898438f, -0.0546875f,0.898438f, -0.0625f,0.898438f, -0.0703125f,0.898438f, -0.078125f,0.898438f, -0.0859375f,0.898438f, -0.09375f,0.898438f, -0.101563f,0.898438f, -0.109375f,0.898438f, -0.117188f,0.898438f, -0.125f,0.898438f, -0.132813f,0.898438f, -0.140625f,0.898438f, -0.148438f,0.898438f, -0.15625f,0.898438f, -0.164063f,0.898438f, -0.171875f,0.898438f, -0.179688f,0.898438f, -0.1875f,0.898438f, -0.195313f,0.898438f, -0.203125f,0.898438f, -0.210938f,0.898438f, -0.21875f,0.898438f, -0.226563f,0.898438f, -0.234375f,0.898438f, -0.242188f,0.898438f, -0.25f,0.898438f, -0.257813f,0.898438f, -0.265625f,0.898438f, -0.273438f,0.898438f, -0.28125f,0.898438f, -0.289063f,0.898438f, -0.296875f,0.898438f, -0.304688f,0.898438f, -0.3125f,0.898438f, -0.320313f,0.898438f, -0.328125f,0.898438f, -0.335938f,0.898438f, -0.34375f,0.898438f, -0.351563f,0.898438f, -0.359375f,0.898438f, -0.367188f,0.898438f, -0.375f,0.898438f, -0.382813f,0.898438f, -0.390625f,0.898438f, -0.398438f,0.898438f, -0.40625f,0.898438f, -0.414063f,0.898438f, -0.421875f,0.898438f, -0.429688f,0.898438f, -0.4375f,0.898438f, -0.445313f,0.898438f, -0.453125f,0.898438f, -0.460938f,0.898438f, -0.46875f,0.898438f, -0.476563f,0.898438f, -0.484375f,0.898438f, -0.492188f,0.898438f, -0.5f,0.898438f, -0.507813f,0.898438f, -0.0f,0.90625f, -0.0078125f,0.90625f, -0.015625f,0.90625f, -0.0234375f,0.90625f, -0.03125f,0.90625f, -0.0390625f,0.90625f, -0.046875f,0.90625f, -0.0546875f,0.90625f, -0.0625f,0.90625f, -0.0703125f,0.90625f, -0.078125f,0.90625f, -0.0859375f,0.90625f, -0.09375f,0.90625f, -0.101563f,0.90625f, -0.109375f,0.90625f, -0.117188f,0.90625f, -0.125f,0.90625f, -0.132813f,0.90625f, -0.140625f,0.90625f, -0.148438f,0.90625f, -0.15625f,0.90625f, -0.164063f,0.90625f, -0.171875f,0.90625f, -0.179688f,0.90625f, -0.1875f,0.90625f, -0.195313f,0.90625f, -0.203125f,0.90625f, -0.210938f,0.90625f, -0.21875f,0.90625f, -0.226563f,0.90625f, -0.234375f,0.90625f, -0.242188f,0.90625f, -0.25f,0.90625f, -0.257813f,0.90625f, -0.265625f,0.90625f, -0.273438f,0.90625f, -0.28125f,0.90625f, -0.289063f,0.90625f, -0.296875f,0.90625f, -0.304688f,0.90625f, -0.3125f,0.90625f, -0.320313f,0.90625f, -0.328125f,0.90625f, -0.335938f,0.90625f, -0.34375f,0.90625f, -0.351563f,0.90625f, -0.359375f,0.90625f, -0.367188f,0.90625f, -0.375f,0.90625f, -0.382813f,0.90625f, -0.390625f,0.90625f, -0.398438f,0.90625f, -0.40625f,0.90625f, -0.414063f,0.90625f, -0.421875f,0.90625f, -0.429688f,0.90625f, -0.4375f,0.90625f, -0.445313f,0.90625f, -0.453125f,0.90625f, -0.460938f,0.90625f, -0.46875f,0.90625f, -0.476563f,0.90625f, -0.484375f,0.90625f, -0.492188f,0.90625f, -0.5f,0.90625f, -0.507813f,0.90625f, -0.0f,0.914063f, -0.0078125f,0.914063f, -0.015625f,0.914063f, -0.0234375f,0.914063f, -0.03125f,0.914063f, -0.0390625f,0.914063f, -0.046875f,0.914063f, -0.0546875f,0.914063f, -0.0625f,0.914063f, -0.0703125f,0.914063f, -0.078125f,0.914063f, -0.0859375f,0.914063f, -0.09375f,0.914063f, -0.101563f,0.914063f, -0.109375f,0.914063f, -0.117188f,0.914063f, -0.125f,0.914063f, -0.132813f,0.914063f, -0.140625f,0.914063f, -0.148438f,0.914063f, -0.15625f,0.914063f, -0.164063f,0.914063f, -0.171875f,0.914063f, -0.179688f,0.914063f, -0.1875f,0.914063f, -0.195313f,0.914063f, -0.203125f,0.914063f, -0.210938f,0.914063f, -0.21875f,0.914063f, -0.226563f,0.914063f, -0.234375f,0.914063f, -0.242188f,0.914063f, -0.25f,0.914063f, -0.257813f,0.914063f, -0.265625f,0.914063f, -0.273438f,0.914063f, -0.28125f,0.914063f, -0.289063f,0.914063f, -0.296875f,0.914063f, -0.304688f,0.914063f, -0.3125f,0.914063f, -0.320313f,0.914063f, -0.328125f,0.914063f, -0.335938f,0.914063f, -0.34375f,0.914063f, -0.351563f,0.914063f, -0.359375f,0.914063f, -0.367188f,0.914063f, -0.375f,0.914063f, -0.382813f,0.914063f, -0.390625f,0.914063f, -0.398438f,0.914063f, -0.40625f,0.914063f, -0.414063f,0.914063f, -0.421875f,0.914063f, -0.429688f,0.914063f, -0.4375f,0.914063f, -0.445313f,0.914063f, -0.453125f,0.914063f, -0.460938f,0.914063f, -0.46875f,0.914063f, -0.476563f,0.914063f, -0.484375f,0.914063f, -0.492188f,0.914063f, -0.5f,0.914063f, -0.507813f,0.914063f, -0.0f,0.921875f, -0.0078125f,0.921875f, -0.015625f,0.921875f, -0.0234375f,0.921875f, -0.03125f,0.921875f, -0.0390625f,0.921875f, -0.046875f,0.921875f, -0.0546875f,0.921875f, -0.0625f,0.921875f, -0.0703125f,0.921875f, -0.078125f,0.921875f, -0.0859375f,0.921875f, -0.09375f,0.921875f, -0.101563f,0.921875f, -0.109375f,0.921875f, -0.117188f,0.921875f, -0.125f,0.921875f, -0.132813f,0.921875f, -0.140625f,0.921875f, -0.148438f,0.921875f, -0.15625f,0.921875f, -0.164063f,0.921875f, -0.171875f,0.921875f, -0.179688f,0.921875f, -0.1875f,0.921875f, -0.195313f,0.921875f, -0.203125f,0.921875f, -0.210938f,0.921875f, -0.21875f,0.921875f, -0.226563f,0.921875f, -0.234375f,0.921875f, -0.242188f,0.921875f, -0.25f,0.921875f, -0.257813f,0.921875f, -0.265625f,0.921875f, -0.273438f,0.921875f, -0.28125f,0.921875f, -0.289063f,0.921875f, -0.296875f,0.921875f, -0.304688f,0.921875f, -0.3125f,0.921875f, -0.320313f,0.921875f, -0.328125f,0.921875f, -0.335938f,0.921875f, -0.34375f,0.921875f, -0.351563f,0.921875f, -0.359375f,0.921875f, -0.367188f,0.921875f, -0.375f,0.921875f, -0.382813f,0.921875f, -0.390625f,0.921875f, -0.398438f,0.921875f, -0.40625f,0.921875f, -0.414063f,0.921875f, -0.421875f,0.921875f, -0.429688f,0.921875f, -0.4375f,0.921875f, -0.445313f,0.921875f, -0.453125f,0.921875f, -0.460938f,0.921875f, -0.46875f,0.921875f, -0.476563f,0.921875f, -0.484375f,0.921875f, -0.492188f,0.921875f, -0.5f,0.921875f, -0.507813f,0.921875f, -0.0f,0.929688f, -0.0078125f,0.929688f, -0.015625f,0.929688f, -0.0234375f,0.929688f, -0.03125f,0.929688f, -0.0390625f,0.929688f, -0.046875f,0.929688f, -0.0546875f,0.929688f, -0.0625f,0.929688f, -0.0703125f,0.929688f, -0.078125f,0.929688f, -0.0859375f,0.929688f, -0.09375f,0.929688f, -0.101563f,0.929688f, -0.109375f,0.929688f, -0.117188f,0.929688f, -0.125f,0.929688f, -0.132813f,0.929688f, -0.140625f,0.929688f, -0.148438f,0.929688f, -0.15625f,0.929688f, -0.164063f,0.929688f, -0.171875f,0.929688f, -0.179688f,0.929688f, -0.1875f,0.929688f, -0.195313f,0.929688f, -0.203125f,0.929688f, -0.210938f,0.929688f, -0.21875f,0.929688f, -0.226563f,0.929688f, -0.234375f,0.929688f, -0.242188f,0.929688f, -0.25f,0.929688f, -0.257813f,0.929688f, -0.265625f,0.929688f, -0.273438f,0.929688f, -0.28125f,0.929688f, -0.289063f,0.929688f, -0.296875f,0.929688f, -0.304688f,0.929688f, -0.3125f,0.929688f, -0.320313f,0.929688f, -0.328125f,0.929688f, -0.335938f,0.929688f, -0.34375f,0.929688f, -0.351563f,0.929688f, -0.359375f,0.929688f, -0.367188f,0.929688f, -0.375f,0.929688f, -0.382813f,0.929688f, -0.390625f,0.929688f, -0.398438f,0.929688f, -0.40625f,0.929688f, -0.414063f,0.929688f, -0.421875f,0.929688f, -0.429688f,0.929688f, -0.4375f,0.929688f, -0.445313f,0.929688f, -0.453125f,0.929688f, -0.460938f,0.929688f, -0.46875f,0.929688f, -0.476563f,0.929688f, -0.484375f,0.929688f, -0.492188f,0.929688f, -0.5f,0.929688f, -0.507813f,0.929688f, -0.0f,0.9375f, -0.0078125f,0.9375f, -0.015625f,0.9375f, -0.0234375f,0.9375f, -0.03125f,0.9375f, -0.0390625f,0.9375f, -0.046875f,0.9375f, -0.0546875f,0.9375f, -0.0625f,0.9375f, -0.0703125f,0.9375f, -0.078125f,0.9375f, -0.0859375f,0.9375f, -0.09375f,0.9375f, -0.101563f,0.9375f, -0.109375f,0.9375f, -0.117188f,0.9375f, -0.125f,0.9375f, -0.132813f,0.9375f, -0.140625f,0.9375f, -0.148438f,0.9375f, -0.15625f,0.9375f, -0.164063f,0.9375f, -0.171875f,0.9375f, -0.179688f,0.9375f, -0.1875f,0.9375f, -0.195313f,0.9375f, -0.203125f,0.9375f, -0.210938f,0.9375f, -0.21875f,0.9375f, -0.226563f,0.9375f, -0.234375f,0.9375f, -0.242188f,0.9375f, -0.25f,0.9375f, -0.257813f,0.9375f, -0.265625f,0.9375f, -0.273438f,0.9375f, -0.28125f,0.9375f, -0.289063f,0.9375f, -0.296875f,0.9375f, -0.304688f,0.9375f, -0.3125f,0.9375f, -0.320313f,0.9375f, -0.328125f,0.9375f, -0.335938f,0.9375f, -0.34375f,0.9375f, -0.351563f,0.9375f, -0.359375f,0.9375f, -0.367188f,0.9375f, -0.375f,0.9375f, -0.382813f,0.9375f, -0.390625f,0.9375f, -0.398438f,0.9375f, -0.40625f,0.9375f, -0.414063f,0.9375f, -0.421875f,0.9375f, -0.429688f,0.9375f, -0.4375f,0.9375f, -0.445313f,0.9375f, -0.453125f,0.9375f, -0.460938f,0.9375f, -0.46875f,0.9375f, -0.476563f,0.9375f, -0.484375f,0.9375f, -0.492188f,0.9375f, -0.5f,0.9375f, -0.507813f,0.9375f, -0.0f,0.945313f, -0.0078125f,0.945313f, -0.015625f,0.945313f, -0.0234375f,0.945313f, -0.03125f,0.945313f, -0.0390625f,0.945313f, -0.046875f,0.945313f, -0.0546875f,0.945313f, -0.0625f,0.945313f, -0.0703125f,0.945313f, -0.078125f,0.945313f, -0.0859375f,0.945313f, -0.09375f,0.945313f, -0.101563f,0.945313f, -0.109375f,0.945313f, -0.117188f,0.945313f, -0.125f,0.945313f, -0.132813f,0.945313f, -0.140625f,0.945313f, -0.148438f,0.945313f, -0.15625f,0.945313f, -0.164063f,0.945313f, -0.171875f,0.945313f, -0.179688f,0.945313f, -0.1875f,0.945313f, -0.195313f,0.945313f, -0.203125f,0.945313f, -0.210938f,0.945313f, -0.21875f,0.945313f, -0.226563f,0.945313f, -0.234375f,0.945313f, -0.242188f,0.945313f, -0.25f,0.945313f, -0.257813f,0.945313f, -0.265625f,0.945313f, -0.273438f,0.945313f, -0.28125f,0.945313f, -0.289063f,0.945313f, -0.296875f,0.945313f, -0.304688f,0.945313f, -0.3125f,0.945313f, -0.320313f,0.945313f, -0.328125f,0.945313f, -0.335938f,0.945313f, -0.34375f,0.945313f, -0.351563f,0.945313f, -0.359375f,0.945313f, -0.367188f,0.945313f, -0.375f,0.945313f, -0.382813f,0.945313f, -0.390625f,0.945313f, -0.398438f,0.945313f, -0.40625f,0.945313f, -0.414063f,0.945313f, -0.421875f,0.945313f, -0.429688f,0.945313f, -0.4375f,0.945313f, -0.445313f,0.945313f, -0.453125f,0.945313f, -0.460938f,0.945313f, -0.46875f,0.945313f, -0.476563f,0.945313f, -0.484375f,0.945313f, -0.492188f,0.945313f, -0.5f,0.945313f, -0.507813f,0.945313f, -0.0f,0.953125f, -0.0078125f,0.953125f, -0.015625f,0.953125f, -0.0234375f,0.953125f, -0.03125f,0.953125f, -0.0390625f,0.953125f, -0.046875f,0.953125f, -0.0546875f,0.953125f, -0.0625f,0.953125f, -0.0703125f,0.953125f, -0.078125f,0.953125f, -0.0859375f,0.953125f, -0.09375f,0.953125f, -0.101563f,0.953125f, -0.109375f,0.953125f, -0.117188f,0.953125f, -0.125f,0.953125f, -0.132813f,0.953125f, -0.140625f,0.953125f, -0.148438f,0.953125f, -0.15625f,0.953125f, -0.164063f,0.953125f, -0.171875f,0.953125f, -0.179688f,0.953125f, -0.1875f,0.953125f, -0.195313f,0.953125f, -0.203125f,0.953125f, -0.210938f,0.953125f, -0.21875f,0.953125f, -0.226563f,0.953125f, -0.234375f,0.953125f, -0.242188f,0.953125f, -0.25f,0.953125f, -0.257813f,0.953125f, -0.265625f,0.953125f, -0.273438f,0.953125f, -0.28125f,0.953125f, -0.289063f,0.953125f, -0.296875f,0.953125f, -0.304688f,0.953125f, -0.3125f,0.953125f, -0.320313f,0.953125f, -0.328125f,0.953125f, -0.335938f,0.953125f, -0.34375f,0.953125f, -0.351563f,0.953125f, -0.359375f,0.953125f, -0.367188f,0.953125f, -0.375f,0.953125f, -0.382813f,0.953125f, -0.390625f,0.953125f, -0.398438f,0.953125f, -0.40625f,0.953125f, -0.414063f,0.953125f, -0.421875f,0.953125f, -0.429688f,0.953125f, -0.4375f,0.953125f, -0.445313f,0.953125f, -0.453125f,0.953125f, -0.460938f,0.953125f, -0.46875f,0.953125f, -0.476563f,0.953125f, -0.484375f,0.953125f, -0.492188f,0.953125f, -0.5f,0.953125f, -0.507813f,0.953125f, -0.0f,0.960938f, -0.0078125f,0.960938f, -0.015625f,0.960938f, -0.0234375f,0.960938f, -0.03125f,0.960938f, -0.0390625f,0.960938f, -0.046875f,0.960938f, -0.0546875f,0.960938f, -0.0625f,0.960938f, -0.0703125f,0.960938f, -0.078125f,0.960938f, -0.0859375f,0.960938f, -0.09375f,0.960938f, -0.101563f,0.960938f, -0.109375f,0.960938f, -0.117188f,0.960938f, -0.125f,0.960938f, -0.132813f,0.960938f, -0.140625f,0.960938f, -0.148438f,0.960938f, -0.15625f,0.960938f, -0.164063f,0.960938f, -0.171875f,0.960938f, -0.179688f,0.960938f, -0.1875f,0.960938f, -0.195313f,0.960938f, -0.203125f,0.960938f, -0.210938f,0.960938f, -0.21875f,0.960938f, -0.226563f,0.960938f, -0.234375f,0.960938f, -0.242188f,0.960938f, -0.25f,0.960938f, -0.257813f,0.960938f, -0.265625f,0.960938f, -0.273438f,0.960938f, -0.28125f,0.960938f, -0.289063f,0.960938f, -0.296875f,0.960938f, -0.304688f,0.960938f, -0.3125f,0.960938f, -0.320313f,0.960938f, -0.328125f,0.960938f, -0.335938f,0.960938f, -0.34375f,0.960938f, -0.351563f,0.960938f, -0.359375f,0.960938f, -0.367188f,0.960938f, -0.375f,0.960938f, -0.382813f,0.960938f, -0.390625f,0.960938f, -0.398438f,0.960938f, -0.40625f,0.960938f, -0.414063f,0.960938f, -0.421875f,0.960938f, -0.429688f,0.960938f, -0.4375f,0.960938f, -0.445313f,0.960938f, -0.453125f,0.960938f, -0.460938f,0.960938f, -0.46875f,0.960938f, -0.476563f,0.960938f, -0.484375f,0.960938f, -0.492188f,0.960938f, -0.5f,0.960938f, -0.507813f,0.960938f, -0.0f,0.96875f, -0.0078125f,0.96875f, -0.015625f,0.96875f, -0.0234375f,0.96875f, -0.03125f,0.96875f, -0.0390625f,0.96875f, -0.046875f,0.96875f, -0.0546875f,0.96875f, -0.0625f,0.96875f, -0.0703125f,0.96875f, -0.078125f,0.96875f, -0.0859375f,0.96875f, -0.09375f,0.96875f, -0.101563f,0.96875f, -0.109375f,0.96875f, -0.117188f,0.96875f, -0.125f,0.96875f, -0.132813f,0.96875f, -0.140625f,0.96875f, -0.148438f,0.96875f, -0.15625f,0.96875f, -0.164063f,0.96875f, -0.171875f,0.96875f, -0.179688f,0.96875f, -0.1875f,0.96875f, -0.195313f,0.96875f, -0.203125f,0.96875f, -0.210938f,0.96875f, -0.21875f,0.96875f, -0.226563f,0.96875f, -0.234375f,0.96875f, -0.242188f,0.96875f, -0.25f,0.96875f, -0.257813f,0.96875f, -0.265625f,0.96875f, -0.273438f,0.96875f, -0.28125f,0.96875f, -0.289063f,0.96875f, -0.296875f,0.96875f, -0.304688f,0.96875f, -0.3125f,0.96875f, -0.320313f,0.96875f, -0.328125f,0.96875f, -0.335938f,0.96875f, -0.34375f,0.96875f, -0.351563f,0.96875f, -0.359375f,0.96875f, -0.367188f,0.96875f, -0.375f,0.96875f, -0.382813f,0.96875f, -0.390625f,0.96875f, -0.398438f,0.96875f, -0.40625f,0.96875f, -0.414063f,0.96875f, -0.421875f,0.96875f, -0.429688f,0.96875f, -0.4375f,0.96875f, -0.445313f,0.96875f, -0.453125f,0.96875f, -0.460938f,0.96875f, -0.46875f,0.96875f, -0.476563f,0.96875f, -0.484375f,0.96875f, -0.492188f,0.96875f, -0.5f,0.96875f, -0.507813f,0.96875f, -0.0f,0.976563f, -0.0078125f,0.976563f, -0.015625f,0.976563f, -0.0234375f,0.976563f, -0.03125f,0.976563f, -0.0390625f,0.976563f, -0.046875f,0.976563f, -0.0546875f,0.976563f, -0.0625f,0.976563f, -0.0703125f,0.976563f, -0.078125f,0.976563f, -0.0859375f,0.976563f, -0.09375f,0.976563f, -0.101563f,0.976563f, -0.109375f,0.976563f, -0.117188f,0.976563f, -0.125f,0.976563f, -0.132813f,0.976563f, -0.140625f,0.976563f, -0.148438f,0.976563f, -0.15625f,0.976563f, -0.164063f,0.976563f, -0.171875f,0.976563f, -0.179688f,0.976563f, -0.1875f,0.976563f, -0.195313f,0.976563f, -0.203125f,0.976563f, -0.210938f,0.976563f, -0.21875f,0.976563f, -0.226563f,0.976563f, -0.234375f,0.976563f, -0.242188f,0.976563f, -0.25f,0.976563f, -0.257813f,0.976563f, -0.265625f,0.976563f, -0.273438f,0.976563f, -0.28125f,0.976563f, -0.289063f,0.976563f, -0.296875f,0.976563f, -0.304688f,0.976563f, -0.3125f,0.976563f, -0.320313f,0.976563f, -0.328125f,0.976563f, -0.335938f,0.976563f, -0.34375f,0.976563f, -0.351563f,0.976563f, -0.359375f,0.976563f, -0.367188f,0.976563f, -0.375f,0.976563f, -0.382813f,0.976563f, -0.390625f,0.976563f, -0.398438f,0.976563f, -0.40625f,0.976563f, -0.414063f,0.976563f, -0.421875f,0.976563f, -0.429688f,0.976563f, -0.4375f,0.976563f, -0.445313f,0.976563f, -0.453125f,0.976563f, -0.460938f,0.976563f, -0.46875f,0.976563f, -0.476563f,0.976563f, -0.484375f,0.976563f, -0.492188f,0.976563f, -0.5f,0.976563f, -0.507813f,0.976563f, -0.0f,0.984375f, -0.0078125f,0.984375f, -0.015625f,0.984375f, -0.0234375f,0.984375f, -0.03125f,0.984375f, -0.0390625f,0.984375f, -0.046875f,0.984375f, -0.0546875f,0.984375f, -0.0625f,0.984375f, -0.0703125f,0.984375f, -0.078125f,0.984375f, -0.0859375f,0.984375f, -0.09375f,0.984375f, -0.101563f,0.984375f, -0.109375f,0.984375f, -0.117188f,0.984375f, -0.125f,0.984375f, -0.132813f,0.984375f, -0.140625f,0.984375f, -0.148438f,0.984375f, -0.15625f,0.984375f, -0.164063f,0.984375f, -0.171875f,0.984375f, -0.179688f,0.984375f, -0.1875f,0.984375f, -0.195313f,0.984375f, -0.203125f,0.984375f, -0.210938f,0.984375f, -0.21875f,0.984375f, -0.226563f,0.984375f, -0.234375f,0.984375f, -0.242188f,0.984375f, -0.25f,0.984375f, -0.257813f,0.984375f, -0.265625f,0.984375f, -0.273438f,0.984375f, -0.28125f,0.984375f, -0.289063f,0.984375f, -0.296875f,0.984375f, -0.304688f,0.984375f, -0.3125f,0.984375f, -0.320313f,0.984375f, -0.328125f,0.984375f, -0.335938f,0.984375f, -0.34375f,0.984375f, -0.351563f,0.984375f, -0.359375f,0.984375f, -0.367188f,0.984375f, -0.375f,0.984375f, -0.382813f,0.984375f, -0.390625f,0.984375f, -0.398438f,0.984375f, -0.40625f,0.984375f, -0.414063f,0.984375f, -0.421875f,0.984375f, -0.429688f,0.984375f, -0.4375f,0.984375f, -0.445313f,0.984375f, -0.453125f,0.984375f, -0.460938f,0.984375f, -0.46875f,0.984375f, -0.476563f,0.984375f, -0.484375f,0.984375f, -0.492188f,0.984375f, -0.5f,0.984375f, -0.507813f,0.984375f, -0.0f,0.992188f, -0.0078125f,0.992188f, -0.015625f,0.992188f, -0.0234375f,0.992188f, -0.03125f,0.992188f, -0.0390625f,0.992188f, -0.046875f,0.992188f, -0.0546875f,0.992188f, -0.0625f,0.992188f, -0.0703125f,0.992188f, -0.078125f,0.992188f, -0.0859375f,0.992188f, -0.09375f,0.992188f, -0.101563f,0.992188f, -0.109375f,0.992188f, -0.117188f,0.992188f, -0.125f,0.992188f, -0.132813f,0.992188f, -0.140625f,0.992188f, -0.148438f,0.992188f, -0.15625f,0.992188f, -0.164063f,0.992188f, -0.171875f,0.992188f, -0.179688f,0.992188f, -0.1875f,0.992188f, -0.195313f,0.992188f, -0.203125f,0.992188f, -0.210938f,0.992188f, -0.21875f,0.992188f, -0.226563f,0.992188f, -0.234375f,0.992188f, -0.242188f,0.992188f, -0.25f,0.992188f, -0.257813f,0.992188f, -0.265625f,0.992188f, -0.273438f,0.992188f, -0.28125f,0.992188f, -0.289063f,0.992188f, -0.296875f,0.992188f, -0.304688f,0.992188f, -0.3125f,0.992188f, -0.320313f,0.992188f, -0.328125f,0.992188f, -0.335938f,0.992188f, -0.34375f,0.992188f, -0.351563f,0.992188f, -0.359375f,0.992188f, -0.367188f,0.992188f, -0.375f,0.992188f, -0.382813f,0.992188f, -0.390625f,0.992188f, -0.398438f,0.992188f, -0.40625f,0.992188f, -0.414063f,0.992188f, -0.421875f,0.992188f, -0.429688f,0.992188f, -0.4375f,0.992188f, -0.445313f,0.992188f, -0.453125f,0.992188f, -0.460938f,0.992188f, -0.46875f,0.992188f, -0.476563f,0.992188f, -0.484375f,0.992188f, -0.492188f,0.992188f, -0.5f,0.992188f, -0.507813f,0.992188f, -0.0f,1.0f, -0.0078125f,1.0f, -0.015625f,1.0f, -0.0234375f,1.0f, -0.03125f,1.0f, -0.0390625f,1.0f, -0.046875f,1.0f, -0.0546875f,1.0f, -0.0625f,1.0f, -0.0703125f,1.0f, -0.078125f,1.0f, -0.0859375f,1.0f, -0.09375f,1.0f, -0.101563f,1.0f, -0.109375f,1.0f, -0.117188f,1.0f, -0.125f,1.0f, -0.132813f,1.0f, -0.140625f,1.0f, -0.148438f,1.0f, -0.15625f,1.0f, -0.164063f,1.0f, -0.171875f,1.0f, -0.179688f,1.0f, -0.1875f,1.0f, -0.195313f,1.0f, -0.203125f,1.0f, -0.210938f,1.0f, -0.21875f,1.0f, -0.226563f,1.0f, -0.234375f,1.0f, -0.242188f,1.0f, -0.25f,1.0f, -0.257813f,1.0f, -0.265625f,1.0f, -0.273438f,1.0f, -0.28125f,1.0f, -0.289063f,1.0f, -0.296875f,1.0f, -0.304688f,1.0f, -0.3125f,1.0f, -0.320313f,1.0f, -0.328125f,1.0f, -0.335938f,1.0f, -0.34375f,1.0f, -0.351563f,1.0f, -0.359375f,1.0f, -0.367188f,1.0f, -0.375f,1.0f, -0.382813f,1.0f, -0.390625f,1.0f, -0.398438f,1.0f, -0.40625f,1.0f, -0.414063f,1.0f, -0.421875f,1.0f, -0.429688f,1.0f, -0.4375f,1.0f, -0.445313f,1.0f, -0.453125f,1.0f, -0.460938f,1.0f, -0.46875f,1.0f, -0.476563f,1.0f, -0.484375f,1.0f, -0.492188f,1.0f, -0.5f,1.0f, -0.507813f,1.0f, -}; - -unsigned short Landscape08Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -126,127,128, -129,128,127, -128,129,130, -131,130,129, -132,0,133, -2,133,0, -133,2,134, -4,134,2, -134,4,135, -6,135,4, -135,6,136, -8,136,6, -136,8,137, -10,137,8, -137,10,138, -12,138,10, -138,12,139, -14,139,12, -139,14,140, -16,140,14, -140,16,141, -18,141,16, -141,18,142, -20,142,18, -142,20,143, -22,143,20, -143,22,144, -24,144,22, -144,24,145, -26,145,24, -145,26,146, -28,146,26, -146,28,147, -30,147,28, -147,30,148, -32,148,30, -148,32,149, -34,149,32, -149,34,150, -36,150,34, -150,36,151, -38,151,36, -151,38,152, -40,152,38, -152,40,153, -42,153,40, -153,42,154, -44,154,42, -154,44,155, -46,155,44, -155,46,156, -48,156,46, -156,48,157, -50,157,48, -157,50,158, -52,158,50, -158,52,159, -54,159,52, -159,54,160, -56,160,54, -160,56,161, -58,161,56, -161,58,162, -60,162,58, -162,60,163, -62,163,60, -163,62,164, -64,164,62, -164,64,165, -66,165,64, -165,66,166, -68,166,66, -166,68,167, -70,167,68, -167,70,168, -72,168,70, -168,72,169, -74,169,72, -169,74,170, -76,170,74, -170,76,171, -78,171,76, -171,78,172, -80,172,78, -172,80,173, -82,173,80, -173,82,174, -84,174,82, -174,84,175, -86,175,84, -175,86,176, -88,176,86, -176,88,177, -90,177,88, -177,90,178, -92,178,90, -178,92,179, -94,179,92, -179,94,180, -96,180,94, -180,96,181, -98,181,96, -181,98,182, -100,182,98, -182,100,183, -102,183,100, -183,102,184, -104,184,102, -184,104,185, -106,185,104, -185,106,186, -108,186,106, -186,108,187, -110,187,108, -187,110,188, -112,188,110, -188,112,189, -114,189,112, -189,114,190, -116,190,114, -190,116,191, -118,191,116, -191,118,192, -120,192,118, -192,120,193, -122,193,120, -193,122,194, -124,194,122, -194,124,195, -126,195,124, -195,126,196, -128,196,126, -196,128,197, -130,197,128, -198,132,199, -133,199,132, -199,133,200, -134,200,133, -200,134,201, -135,201,134, -201,135,202, -136,202,135, -202,136,203, -137,203,136, -203,137,204, -138,204,137, -204,138,205, -139,205,138, -205,139,206, -140,206,139, -206,140,207, -141,207,140, -207,141,208, -142,208,141, -208,142,209, -143,209,142, -209,143,210, -144,210,143, -210,144,211, -145,211,144, -211,145,212, -146,212,145, -212,146,213, -147,213,146, -213,147,214, -148,214,147, -214,148,215, -149,215,148, -215,149,216, -150,216,149, -216,150,217, -151,217,150, -217,151,218, -152,218,151, -218,152,219, -153,219,152, -219,153,220, -154,220,153, -220,154,221, -155,221,154, -221,155,222, -156,222,155, -222,156,223, -157,223,156, -223,157,224, -158,224,157, -224,158,225, -159,225,158, -225,159,226, -160,226,159, -226,160,227, -161,227,160, -227,161,228, -162,228,161, -228,162,229, -163,229,162, -229,163,230, -164,230,163, -230,164,231, -165,231,164, -231,165,232, -166,232,165, -232,166,233, -167,233,166, -233,167,234, -168,234,167, -234,168,235, -169,235,168, -235,169,236, -170,236,169, -236,170,237, -171,237,170, -237,171,238, -172,238,171, -238,172,239, -173,239,172, -239,173,240, -174,240,173, -240,174,241, -175,241,174, -241,175,242, -176,242,175, -242,176,243, -177,243,176, -243,177,244, -178,244,177, -244,178,245, -179,245,178, -245,179,246, -180,246,179, -246,180,247, -181,247,180, -247,181,248, -182,248,181, -248,182,249, -183,249,182, -249,183,250, -184,250,183, -250,184,251, -185,251,184, -251,185,252, -186,252,185, -252,186,253, -187,253,186, -253,187,254, -188,254,187, -254,188,255, -189,255,188, -255,189,256, -190,256,189, -256,190,257, -191,257,190, -257,191,258, -192,258,191, -258,192,259, -193,259,192, -259,193,260, -194,260,193, -260,194,261, -195,261,194, -261,195,262, -196,262,195, -262,196,263, -197,263,196, -264,198,265, -199,265,198, -265,199,266, -200,266,199, -266,200,267, -201,267,200, -267,201,268, -202,268,201, -268,202,269, -203,269,202, -269,203,270, -204,270,203, -270,204,271, -205,271,204, -271,205,272, -206,272,205, -272,206,273, -207,273,206, -273,207,274, -208,274,207, -274,208,275, -209,275,208, -275,209,276, -210,276,209, -276,210,277, -211,277,210, -277,211,278, -212,278,211, -278,212,279, -213,279,212, -279,213,280, -214,280,213, -280,214,281, -215,281,214, -281,215,282, -216,282,215, -282,216,283, -217,283,216, -283,217,284, -218,284,217, -284,218,285, -219,285,218, -285,219,286, -220,286,219, -286,220,287, -221,287,220, -287,221,288, -222,288,221, -288,222,289, -223,289,222, -289,223,290, -224,290,223, -290,224,291, -225,291,224, -291,225,292, -226,292,225, -292,226,293, -227,293,226, -293,227,294, -228,294,227, -294,228,295, -229,295,228, -295,229,296, -230,296,229, -296,230,297, -231,297,230, -297,231,298, -232,298,231, -298,232,299, -233,299,232, -299,233,300, -234,300,233, -300,234,301, -235,301,234, -301,235,302, -236,302,235, -302,236,303, -237,303,236, -303,237,304, -238,304,237, -304,238,305, -239,305,238, -305,239,306, -240,306,239, -306,240,307, -241,307,240, -307,241,308, -242,308,241, -308,242,309, -243,309,242, -309,243,310, -244,310,243, -310,244,311, -245,311,244, -311,245,312, -246,312,245, -312,246,313, -247,313,246, -313,247,314, -248,314,247, -314,248,315, -249,315,248, -315,249,316, -250,316,249, -316,250,317, -251,317,250, -317,251,318, -252,318,251, -318,252,319, -253,319,252, -319,253,320, -254,320,253, -320,254,321, -255,321,254, -321,255,322, -256,322,255, -322,256,323, -257,323,256, -323,257,324, -258,324,257, -324,258,325, -259,325,258, -325,259,326, -260,326,259, -326,260,327, -261,327,260, -327,261,328, -262,328,261, -328,262,329, -263,329,262, -330,264,331, -265,331,264, -331,265,332, -266,332,265, -332,266,333, -267,333,266, -333,267,334, -268,334,267, -334,268,335, -269,335,268, -335,269,336, -270,336,269, -336,270,337, -271,337,270, -337,271,338, -272,338,271, -338,272,339, -273,339,272, -339,273,340, -274,340,273, -340,274,341, -275,341,274, -341,275,342, -276,342,275, -342,276,343, -277,343,276, -343,277,344, -278,344,277, -344,278,345, -279,345,278, -345,279,346, -280,346,279, -346,280,347, -281,347,280, -347,281,348, -282,348,281, -348,282,349, -283,349,282, -349,283,350, -284,350,283, -350,284,351, -285,351,284, -351,285,352, -286,352,285, -352,286,353, -287,353,286, -353,287,354, -288,354,287, -354,288,355, -289,355,288, -355,289,356, -290,356,289, -356,290,357, -291,357,290, -357,291,358, -292,358,291, -358,292,359, -293,359,292, -359,293,360, -294,360,293, -360,294,361, -295,361,294, -361,295,362, -296,362,295, -362,296,363, -297,363,296, -363,297,364, -298,364,297, -364,298,365, -299,365,298, -365,299,366, -300,366,299, -366,300,367, -301,367,300, -367,301,368, -302,368,301, -368,302,369, -303,369,302, -369,303,370, -304,370,303, -370,304,371, -305,371,304, -371,305,372, -306,372,305, -372,306,373, -307,373,306, -373,307,374, -308,374,307, -374,308,375, -309,375,308, -375,309,376, -310,376,309, -376,310,377, -311,377,310, -377,311,378, -312,378,311, -378,312,379, -313,379,312, -379,313,380, -314,380,313, -380,314,381, -315,381,314, -381,315,382, -316,382,315, -382,316,383, -317,383,316, -383,317,384, -318,384,317, -384,318,385, -319,385,318, -385,319,386, -320,386,319, -386,320,387, -321,387,320, -387,321,388, -322,388,321, -388,322,389, -323,389,322, -389,323,390, -324,390,323, -390,324,391, -325,391,324, -391,325,392, -326,392,325, -392,326,393, -327,393,326, -393,327,394, -328,394,327, -394,328,395, -329,395,328, -396,330,397, -331,397,330, -397,331,398, -332,398,331, -398,332,399, -333,399,332, -399,333,400, -334,400,333, -400,334,401, -335,401,334, -401,335,402, -336,402,335, -402,336,403, -337,403,336, -403,337,404, -338,404,337, -404,338,405, -339,405,338, -405,339,406, -340,406,339, -406,340,407, -341,407,340, -407,341,408, -342,408,341, -408,342,409, -343,409,342, -409,343,410, -344,410,343, -410,344,411, -345,411,344, -411,345,412, -346,412,345, -412,346,413, -347,413,346, -413,347,414, -348,414,347, -414,348,415, -349,415,348, -415,349,416, -350,416,349, -416,350,417, -351,417,350, -417,351,418, -352,418,351, -418,352,419, -353,419,352, -419,353,420, -354,420,353, -420,354,421, -355,421,354, -421,355,422, -356,422,355, -422,356,423, -357,423,356, -423,357,424, -358,424,357, -424,358,425, -359,425,358, -425,359,426, -360,426,359, -426,360,427, -361,427,360, -427,361,428, -362,428,361, -428,362,429, -363,429,362, -429,363,430, -364,430,363, -430,364,431, -365,431,364, -431,365,432, -366,432,365, -432,366,433, -367,433,366, -433,367,434, -368,434,367, -434,368,435, -369,435,368, -435,369,436, -370,436,369, -436,370,437, -371,437,370, -437,371,438, -372,438,371, -438,372,439, -373,439,372, -439,373,440, -374,440,373, -440,374,441, -375,441,374, -441,375,442, -376,442,375, -442,376,443, -377,443,376, -443,377,444, -378,444,377, -444,378,445, -379,445,378, -445,379,446, -380,446,379, -446,380,447, -381,447,380, -447,381,448, -382,448,381, -448,382,449, -383,449,382, -449,383,450, -384,450,383, -450,384,451, -385,451,384, -451,385,452, -386,452,385, -452,386,453, -387,453,386, -453,387,454, -388,454,387, -454,388,455, -389,455,388, -455,389,456, -390,456,389, -456,390,457, -391,457,390, -457,391,458, -392,458,391, -458,392,459, -393,459,392, -459,393,460, -394,460,393, -460,394,461, -395,461,394, -462,396,463, -397,463,396, -463,397,464, -398,464,397, -464,398,465, -399,465,398, -465,399,466, -400,466,399, -466,400,467, -401,467,400, -467,401,468, -402,468,401, -468,402,469, -403,469,402, -469,403,470, -404,470,403, -470,404,471, -405,471,404, -471,405,472, -406,472,405, -472,406,473, -407,473,406, -473,407,474, -408,474,407, -474,408,475, -409,475,408, -475,409,476, -410,476,409, -476,410,477, -411,477,410, -477,411,478, -412,478,411, -478,412,479, -413,479,412, -479,413,480, -414,480,413, -480,414,481, -415,481,414, -481,415,482, -416,482,415, -482,416,483, -417,483,416, -483,417,484, -418,484,417, -484,418,485, -419,485,418, -485,419,486, -420,486,419, -486,420,487, -421,487,420, -487,421,488, -422,488,421, -488,422,489, -423,489,422, -489,423,490, -424,490,423, -490,424,491, -425,491,424, -491,425,492, -426,492,425, -492,426,493, -427,493,426, -493,427,494, -428,494,427, -494,428,495, -429,495,428, -495,429,496, -430,496,429, -496,430,497, -431,497,430, -497,431,498, -432,498,431, -498,432,499, -433,499,432, -499,433,500, -434,500,433, -500,434,501, -435,501,434, -501,435,502, -436,502,435, -502,436,503, -437,503,436, -503,437,504, -438,504,437, -504,438,505, -439,505,438, -505,439,506, -440,506,439, -506,440,507, -441,507,440, -507,441,508, -442,508,441, -508,442,509, -443,509,442, -509,443,510, -444,510,443, -510,444,511, -445,511,444, -511,445,512, -446,512,445, -512,446,513, -447,513,446, -513,447,514, -448,514,447, -514,448,515, -449,515,448, -515,449,516, -450,516,449, -516,450,517, -451,517,450, -517,451,518, -452,518,451, -518,452,519, -453,519,452, -519,453,520, -454,520,453, -520,454,521, -455,521,454, -521,455,522, -456,522,455, -522,456,523, -457,523,456, -523,457,524, -458,524,457, -524,458,525, -459,525,458, -525,459,526, -460,526,459, -526,460,527, -461,527,460, -528,462,529, -463,529,462, -529,463,530, -464,530,463, -530,464,531, -465,531,464, -531,465,532, -466,532,465, -532,466,533, -467,533,466, -533,467,534, -468,534,467, -534,468,535, -469,535,468, -535,469,536, -470,536,469, -536,470,537, -471,537,470, -537,471,538, -472,538,471, -538,472,539, -473,539,472, -539,473,540, -474,540,473, -540,474,541, -475,541,474, -541,475,542, -476,542,475, -542,476,543, -477,543,476, -543,477,544, -478,544,477, -544,478,545, -479,545,478, -545,479,546, -480,546,479, -546,480,547, -481,547,480, -547,481,548, -482,548,481, -548,482,549, -483,549,482, -549,483,550, -484,550,483, -550,484,551, -485,551,484, -551,485,552, -486,552,485, -552,486,553, -487,553,486, -553,487,554, -488,554,487, -554,488,555, -489,555,488, -555,489,556, -490,556,489, -556,490,557, -491,557,490, -557,491,558, -492,558,491, -558,492,559, -493,559,492, -559,493,560, -494,560,493, -560,494,561, -495,561,494, -561,495,562, -496,562,495, -562,496,563, -497,563,496, -563,497,564, -498,564,497, -564,498,565, -499,565,498, -565,499,566, -500,566,499, -566,500,567, -501,567,500, -567,501,568, -502,568,501, -568,502,569, -503,569,502, -569,503,570, -504,570,503, -570,504,571, -505,571,504, -571,505,572, -506,572,505, -572,506,573, -507,573,506, -573,507,574, -508,574,507, -574,508,575, -509,575,508, -575,509,576, -510,576,509, -576,510,577, -511,577,510, -577,511,578, -512,578,511, -578,512,579, -513,579,512, -579,513,580, -514,580,513, -580,514,581, -515,581,514, -581,515,582, -516,582,515, -582,516,583, -517,583,516, -583,517,584, -518,584,517, -584,518,585, -519,585,518, -585,519,586, -520,586,519, -586,520,587, -521,587,520, -587,521,588, -522,588,521, -588,522,589, -523,589,522, -589,523,590, -524,590,523, -590,524,591, -525,591,524, -591,525,592, -526,592,525, -592,526,593, -527,593,526, -594,528,595, -529,595,528, -595,529,596, -530,596,529, -596,530,597, -531,597,530, -597,531,598, -532,598,531, -598,532,599, -533,599,532, -599,533,600, -534,600,533, -600,534,601, -535,601,534, -601,535,602, -536,602,535, -602,536,603, -537,603,536, -603,537,604, -538,604,537, -604,538,605, -539,605,538, -605,539,606, -540,606,539, -606,540,607, -541,607,540, -607,541,608, -542,608,541, -608,542,609, -543,609,542, -609,543,610, -544,610,543, -610,544,611, -545,611,544, -611,545,612, -546,612,545, -612,546,613, -547,613,546, -613,547,614, -548,614,547, -614,548,615, -549,615,548, -615,549,616, -550,616,549, -616,550,617, -551,617,550, -617,551,618, -552,618,551, -618,552,619, -553,619,552, -619,553,620, -554,620,553, -620,554,621, -555,621,554, -621,555,622, -556,622,555, -622,556,623, -557,623,556, -623,557,624, -558,624,557, -624,558,625, -559,625,558, -625,559,626, -560,626,559, -626,560,627, -561,627,560, -627,561,628, -562,628,561, -628,562,629, -563,629,562, -629,563,630, -564,630,563, -630,564,631, -565,631,564, -631,565,632, -566,632,565, -632,566,633, -567,633,566, -633,567,634, -568,634,567, -634,568,635, -569,635,568, -635,569,636, -570,636,569, -636,570,637, -571,637,570, -637,571,638, -572,638,571, -638,572,639, -573,639,572, -639,573,640, -574,640,573, -640,574,641, -575,641,574, -641,575,642, -576,642,575, -642,576,643, -577,643,576, -643,577,644, -578,644,577, -644,578,645, -579,645,578, -645,579,646, -580,646,579, -646,580,647, -581,647,580, -647,581,648, -582,648,581, -648,582,649, -583,649,582, -649,583,650, -584,650,583, -650,584,651, -585,651,584, -651,585,652, -586,652,585, -652,586,653, -587,653,586, -653,587,654, -588,654,587, -654,588,655, -589,655,588, -655,589,656, -590,656,589, -656,590,657, -591,657,590, -657,591,658, -592,658,591, -658,592,659, -593,659,592, -660,594,661, -595,661,594, -661,595,662, -596,662,595, -662,596,663, -597,663,596, -663,597,664, -598,664,597, -664,598,665, -599,665,598, -665,599,666, -600,666,599, -666,600,667, -601,667,600, -667,601,668, -602,668,601, -668,602,669, -603,669,602, -669,603,670, -604,670,603, -670,604,671, -605,671,604, -671,605,672, -606,672,605, -672,606,673, -607,673,606, -673,607,674, -608,674,607, -674,608,675, -609,675,608, -675,609,676, -610,676,609, -676,610,677, -611,677,610, -677,611,678, -612,678,611, -678,612,679, -613,679,612, -679,613,680, -614,680,613, -680,614,681, -615,681,614, -681,615,682, -616,682,615, -682,616,683, -617,683,616, -683,617,684, -618,684,617, -684,618,685, -619,685,618, -685,619,686, -620,686,619, -686,620,687, -621,687,620, -687,621,688, -622,688,621, -688,622,689, -623,689,622, -689,623,690, -624,690,623, -690,624,691, -625,691,624, -691,625,692, -626,692,625, -692,626,693, -627,693,626, -693,627,694, -628,694,627, -694,628,695, -629,695,628, -695,629,696, -630,696,629, -696,630,697, -631,697,630, -697,631,698, -632,698,631, -698,632,699, -633,699,632, -699,633,700, -634,700,633, -700,634,701, -635,701,634, -701,635,702, -636,702,635, -702,636,703, -637,703,636, -703,637,704, -638,704,637, -704,638,705, -639,705,638, -705,639,706, -640,706,639, -706,640,707, -641,707,640, -707,641,708, -642,708,641, -708,642,709, -643,709,642, -709,643,710, -644,710,643, -710,644,711, -645,711,644, -711,645,712, -646,712,645, -712,646,713, -647,713,646, -713,647,714, -648,714,647, -714,648,715, -649,715,648, -715,649,716, -650,716,649, -716,650,717, -651,717,650, -717,651,718, -652,718,651, -718,652,719, -653,719,652, -719,653,720, -654,720,653, -720,654,721, -655,721,654, -721,655,722, -656,722,655, -722,656,723, -657,723,656, -723,657,724, -658,724,657, -724,658,725, -659,725,658, -726,660,727, -661,727,660, -727,661,728, -662,728,661, -728,662,729, -663,729,662, -729,663,730, -664,730,663, -730,664,731, -665,731,664, -731,665,732, -666,732,665, -732,666,733, -667,733,666, -733,667,734, -668,734,667, -734,668,735, -669,735,668, -735,669,736, -670,736,669, -736,670,737, -671,737,670, -737,671,738, -672,738,671, -738,672,739, -673,739,672, -739,673,740, -674,740,673, -740,674,741, -675,741,674, -741,675,742, -676,742,675, -742,676,743, -677,743,676, -743,677,744, -678,744,677, -744,678,745, -679,745,678, -745,679,746, -680,746,679, -746,680,747, -681,747,680, -747,681,748, -682,748,681, -748,682,749, -683,749,682, -749,683,750, -684,750,683, -750,684,751, -685,751,684, -751,685,752, -686,752,685, -752,686,753, -687,753,686, -753,687,754, -688,754,687, -754,688,755, -689,755,688, -755,689,756, -690,756,689, -756,690,757, -691,757,690, -757,691,758, -692,758,691, -758,692,759, -693,759,692, -759,693,760, -694,760,693, -760,694,761, -695,761,694, -761,695,762, -696,762,695, -762,696,763, -697,763,696, -763,697,764, -698,764,697, -764,698,765, -699,765,698, -765,699,766, -700,766,699, -766,700,767, -701,767,700, -767,701,768, -702,768,701, -768,702,769, -703,769,702, -769,703,770, -704,770,703, -770,704,771, -705,771,704, -771,705,772, -706,772,705, -772,706,773, -707,773,706, -773,707,774, -708,774,707, -774,708,775, -709,775,708, -775,709,776, -710,776,709, -776,710,777, -711,777,710, -777,711,778, -712,778,711, -778,712,779, -713,779,712, -779,713,780, -714,780,713, -780,714,781, -715,781,714, -781,715,782, -716,782,715, -782,716,783, -717,783,716, -783,717,784, -718,784,717, -784,718,785, -719,785,718, -785,719,786, -720,786,719, -786,720,787, -721,787,720, -787,721,788, -722,788,721, -788,722,789, -723,789,722, -789,723,790, -724,790,723, -790,724,791, -725,791,724, -792,726,793, -727,793,726, -793,727,794, -728,794,727, -794,728,795, -729,795,728, -795,729,796, -730,796,729, -796,730,797, -731,797,730, -797,731,798, -732,798,731, -798,732,799, -733,799,732, -799,733,800, -734,800,733, -800,734,801, -735,801,734, -801,735,802, -736,802,735, -802,736,803, -737,803,736, -803,737,804, -738,804,737, -804,738,805, -739,805,738, -805,739,806, -740,806,739, -806,740,807, -741,807,740, -807,741,808, -742,808,741, -808,742,809, -743,809,742, -809,743,810, -744,810,743, -810,744,811, -745,811,744, -811,745,812, -746,812,745, -812,746,813, -747,813,746, -813,747,814, -748,814,747, -814,748,815, -749,815,748, -815,749,816, -750,816,749, -816,750,817, -751,817,750, -817,751,818, -752,818,751, -818,752,819, -753,819,752, -819,753,820, -754,820,753, -820,754,821, -755,821,754, -821,755,822, -756,822,755, -822,756,823, -757,823,756, -823,757,824, -758,824,757, -824,758,825, -759,825,758, -825,759,826, -760,826,759, -826,760,827, -761,827,760, -827,761,828, -762,828,761, -828,762,829, -763,829,762, -829,763,830, -764,830,763, -830,764,831, -765,831,764, -831,765,832, -766,832,765, -832,766,833, -767,833,766, -833,767,834, -768,834,767, -834,768,835, -769,835,768, -835,769,836, -770,836,769, -836,770,837, -771,837,770, -837,771,838, -772,838,771, -838,772,839, -773,839,772, -839,773,840, -774,840,773, -840,774,841, -775,841,774, -841,775,842, -776,842,775, -842,776,843, -777,843,776, -843,777,844, -778,844,777, -844,778,845, -779,845,778, -845,779,846, -780,846,779, -846,780,847, -781,847,780, -847,781,848, -782,848,781, -848,782,849, -783,849,782, -849,783,850, -784,850,783, -850,784,851, -785,851,784, -851,785,852, -786,852,785, -852,786,853, -787,853,786, -853,787,854, -788,854,787, -854,788,855, -789,855,788, -855,789,856, -790,856,789, -856,790,857, -791,857,790, -858,792,859, -793,859,792, -859,793,860, -794,860,793, -860,794,861, -795,861,794, -861,795,862, -796,862,795, -862,796,863, -797,863,796, -863,797,864, -798,864,797, -864,798,865, -799,865,798, -865,799,866, -800,866,799, -866,800,867, -801,867,800, -867,801,868, -802,868,801, -868,802,869, -803,869,802, -869,803,870, -804,870,803, -870,804,871, -805,871,804, -871,805,872, -806,872,805, -872,806,873, -807,873,806, -873,807,874, -808,874,807, -874,808,875, -809,875,808, -875,809,876, -810,876,809, -876,810,877, -811,877,810, -877,811,878, -812,878,811, -878,812,879, -813,879,812, -879,813,880, -814,880,813, -880,814,881, -815,881,814, -881,815,882, -816,882,815, -882,816,883, -817,883,816, -883,817,884, -818,884,817, -884,818,885, -819,885,818, -885,819,886, -820,886,819, -886,820,887, -821,887,820, -887,821,888, -822,888,821, -888,822,889, -823,889,822, -889,823,890, -824,890,823, -890,824,891, -825,891,824, -891,825,892, -826,892,825, -892,826,893, -827,893,826, -893,827,894, -828,894,827, -894,828,895, -829,895,828, -895,829,896, -830,896,829, -896,830,897, -831,897,830, -897,831,898, -832,898,831, -898,832,899, -833,899,832, -899,833,900, -834,900,833, -900,834,901, -835,901,834, -901,835,902, -836,902,835, -902,836,903, -837,903,836, -903,837,904, -838,904,837, -904,838,905, -839,905,838, -905,839,906, -840,906,839, -906,840,907, -841,907,840, -907,841,908, -842,908,841, -908,842,909, -843,909,842, -909,843,910, -844,910,843, -910,844,911, -845,911,844, -911,845,912, -846,912,845, -912,846,913, -847,913,846, -913,847,914, -848,914,847, -914,848,915, -849,915,848, -915,849,916, -850,916,849, -916,850,917, -851,917,850, -917,851,918, -852,918,851, -918,852,919, -853,919,852, -919,853,920, -854,920,853, -920,854,921, -855,921,854, -921,855,922, -856,922,855, -922,856,923, -857,923,856, -924,858,925, -859,925,858, -925,859,926, -860,926,859, -926,860,927, -861,927,860, -927,861,928, -862,928,861, -928,862,929, -863,929,862, -929,863,930, -864,930,863, -930,864,931, -865,931,864, -931,865,932, -866,932,865, -932,866,933, -867,933,866, -933,867,934, -868,934,867, -934,868,935, -869,935,868, -935,869,936, -870,936,869, -936,870,937, -871,937,870, -937,871,938, -872,938,871, -938,872,939, -873,939,872, -939,873,940, -874,940,873, -940,874,941, -875,941,874, -941,875,942, -876,942,875, -942,876,943, -877,943,876, -943,877,944, -878,944,877, -944,878,945, -879,945,878, -945,879,946, -880,946,879, -946,880,947, -881,947,880, -947,881,948, -882,948,881, -948,882,949, -883,949,882, -949,883,950, -884,950,883, -950,884,951, -885,951,884, -951,885,952, -886,952,885, -952,886,953, -887,953,886, -953,887,954, -888,954,887, -954,888,955, -889,955,888, -955,889,956, -890,956,889, -956,890,957, -891,957,890, -957,891,958, -892,958,891, -958,892,959, -893,959,892, -959,893,960, -894,960,893, -960,894,961, -895,961,894, -961,895,962, -896,962,895, -962,896,963, -897,963,896, -963,897,964, -898,964,897, -964,898,965, -899,965,898, -965,899,966, -900,966,899, -966,900,967, -901,967,900, -967,901,968, -902,968,901, -968,902,969, -903,969,902, -969,903,970, -904,970,903, -970,904,971, -905,971,904, -971,905,972, -906,972,905, -972,906,973, -907,973,906, -973,907,974, -908,974,907, -974,908,975, -909,975,908, -975,909,976, -910,976,909, -976,910,977, -911,977,910, -977,911,978, -912,978,911, -978,912,979, -913,979,912, -979,913,980, -914,980,913, -980,914,981, -915,981,914, -981,915,982, -916,982,915, -982,916,983, -917,983,916, -983,917,984, -918,984,917, -984,918,985, -919,985,918, -985,919,986, -920,986,919, -986,920,987, -921,987,920, -987,921,988, -922,988,921, -988,922,989, -923,989,922, -990,924,991, -925,991,924, -991,925,992, -926,992,925, -992,926,993, -927,993,926, -993,927,994, -928,994,927, -994,928,995, -929,995,928, -995,929,996, -930,996,929, -996,930,997, -931,997,930, -997,931,998, -932,998,931, -998,932,999, -933,999,932, -999,933,1000, -934,1000,933, -1000,934,1001, -935,1001,934, -1001,935,1002, -936,1002,935, -1002,936,1003, -937,1003,936, -1003,937,1004, -938,1004,937, -1004,938,1005, -939,1005,938, -1005,939,1006, -940,1006,939, -1006,940,1007, -941,1007,940, -1007,941,1008, -942,1008,941, -1008,942,1009, -943,1009,942, -1009,943,1010, -944,1010,943, -1010,944,1011, -945,1011,944, -1011,945,1012, -946,1012,945, -1012,946,1013, -947,1013,946, -1013,947,1014, -948,1014,947, -1014,948,1015, -949,1015,948, -1015,949,1016, -950,1016,949, -1016,950,1017, -951,1017,950, -1017,951,1018, -952,1018,951, -1018,952,1019, -953,1019,952, -1019,953,1020, -954,1020,953, -1020,954,1021, -955,1021,954, -1021,955,1022, -956,1022,955, -1022,956,1023, -957,1023,956, -1023,957,1024, -958,1024,957, -1024,958,1025, -959,1025,958, -1025,959,1026, -960,1026,959, -1026,960,1027, -961,1027,960, -1027,961,1028, -962,1028,961, -1028,962,1029, -963,1029,962, -1029,963,1030, -964,1030,963, -1030,964,1031, -965,1031,964, -1031,965,1032, -966,1032,965, -1032,966,1033, -967,1033,966, -1033,967,1034, -968,1034,967, -1034,968,1035, -969,1035,968, -1035,969,1036, -970,1036,969, -1036,970,1037, -971,1037,970, -1037,971,1038, -972,1038,971, -1038,972,1039, -973,1039,972, -1039,973,1040, -974,1040,973, -1040,974,1041, -975,1041,974, -1041,975,1042, -976,1042,975, -1042,976,1043, -977,1043,976, -1043,977,1044, -978,1044,977, -1044,978,1045, -979,1045,978, -1045,979,1046, -980,1046,979, -1046,980,1047, -981,1047,980, -1047,981,1048, -982,1048,981, -1048,982,1049, -983,1049,982, -1049,983,1050, -984,1050,983, -1050,984,1051, -985,1051,984, -1051,985,1052, -986,1052,985, -1052,986,1053, -987,1053,986, -1053,987,1054, -988,1054,987, -1054,988,1055, -989,1055,988, -1056,990,1057, -991,1057,990, -1057,991,1058, -992,1058,991, -1058,992,1059, -993,1059,992, -1059,993,1060, -994,1060,993, -1060,994,1061, -995,1061,994, -1061,995,1062, -996,1062,995, -1062,996,1063, -997,1063,996, -1063,997,1064, -998,1064,997, -1064,998,1065, -999,1065,998, -1065,999,1066, -1000,1066,999, -1066,1000,1067, -1001,1067,1000, -1067,1001,1068, -1002,1068,1001, -1068,1002,1069, -1003,1069,1002, -1069,1003,1070, -1004,1070,1003, -1070,1004,1071, -1005,1071,1004, -1071,1005,1072, -1006,1072,1005, -1072,1006,1073, -1007,1073,1006, -1073,1007,1074, -1008,1074,1007, -1074,1008,1075, -1009,1075,1008, -1075,1009,1076, -1010,1076,1009, -1076,1010,1077, -1011,1077,1010, -1077,1011,1078, -1012,1078,1011, -1078,1012,1079, -1013,1079,1012, -1079,1013,1080, -1014,1080,1013, -1080,1014,1081, -1015,1081,1014, -1081,1015,1082, -1016,1082,1015, -1082,1016,1083, -1017,1083,1016, -1083,1017,1084, -1018,1084,1017, -1084,1018,1085, -1019,1085,1018, -1085,1019,1086, -1020,1086,1019, -1086,1020,1087, -1021,1087,1020, -1087,1021,1088, -1022,1088,1021, -1088,1022,1089, -1023,1089,1022, -1089,1023,1090, -1024,1090,1023, -1090,1024,1091, -1025,1091,1024, -1091,1025,1092, -1026,1092,1025, -1092,1026,1093, -1027,1093,1026, -1093,1027,1094, -1028,1094,1027, -1094,1028,1095, -1029,1095,1028, -1095,1029,1096, -1030,1096,1029, -1096,1030,1097, -1031,1097,1030, -1097,1031,1098, -1032,1098,1031, -1098,1032,1099, -1033,1099,1032, -1099,1033,1100, -1034,1100,1033, -1100,1034,1101, -1035,1101,1034, -1101,1035,1102, -1036,1102,1035, -1102,1036,1103, -1037,1103,1036, -1103,1037,1104, -1038,1104,1037, -1104,1038,1105, -1039,1105,1038, -1105,1039,1106, -1040,1106,1039, -1106,1040,1107, -1041,1107,1040, -1107,1041,1108, -1042,1108,1041, -1108,1042,1109, -1043,1109,1042, -1109,1043,1110, -1044,1110,1043, -1110,1044,1111, -1045,1111,1044, -1111,1045,1112, -1046,1112,1045, -1112,1046,1113, -1047,1113,1046, -1113,1047,1114, -1048,1114,1047, -1114,1048,1115, -1049,1115,1048, -1115,1049,1116, -1050,1116,1049, -1116,1050,1117, -1051,1117,1050, -1117,1051,1118, -1052,1118,1051, -1118,1052,1119, -1053,1119,1052, -1119,1053,1120, -1054,1120,1053, -1120,1054,1121, -1055,1121,1054, -1122,1056,1123, -1057,1123,1056, -1123,1057,1124, -1058,1124,1057, -1124,1058,1125, -1059,1125,1058, -1125,1059,1126, -1060,1126,1059, -1126,1060,1127, -1061,1127,1060, -1127,1061,1128, -1062,1128,1061, -1128,1062,1129, -1063,1129,1062, -1129,1063,1130, -1064,1130,1063, -1130,1064,1131, -1065,1131,1064, -1131,1065,1132, -1066,1132,1065, -1132,1066,1133, -1067,1133,1066, -1133,1067,1134, -1068,1134,1067, -1134,1068,1135, -1069,1135,1068, -1135,1069,1136, -1070,1136,1069, -1136,1070,1137, -1071,1137,1070, -1137,1071,1138, -1072,1138,1071, -1138,1072,1139, -1073,1139,1072, -1139,1073,1140, -1074,1140,1073, -1140,1074,1141, -1075,1141,1074, -1141,1075,1142, -1076,1142,1075, -1142,1076,1143, -1077,1143,1076, -1143,1077,1144, -1078,1144,1077, -1144,1078,1145, -1079,1145,1078, -1145,1079,1146, -1080,1146,1079, -1146,1080,1147, -1081,1147,1080, -1147,1081,1148, -1082,1148,1081, -1148,1082,1149, -1083,1149,1082, -1149,1083,1150, -1084,1150,1083, -1150,1084,1151, -1085,1151,1084, -1151,1085,1152, -1086,1152,1085, -1152,1086,1153, -1087,1153,1086, -1153,1087,1154, -1088,1154,1087, -1154,1088,1155, -1089,1155,1088, -1155,1089,1156, -1090,1156,1089, -1156,1090,1157, -1091,1157,1090, -1157,1091,1158, -1092,1158,1091, -1158,1092,1159, -1093,1159,1092, -1159,1093,1160, -1094,1160,1093, -1160,1094,1161, -1095,1161,1094, -1161,1095,1162, -1096,1162,1095, -1162,1096,1163, -1097,1163,1096, -1163,1097,1164, -1098,1164,1097, -1164,1098,1165, -1099,1165,1098, -1165,1099,1166, -1100,1166,1099, -1166,1100,1167, -1101,1167,1100, -1167,1101,1168, -1102,1168,1101, -1168,1102,1169, -1103,1169,1102, -1169,1103,1170, -1104,1170,1103, -1170,1104,1171, -1105,1171,1104, -1171,1105,1172, -1106,1172,1105, -1172,1106,1173, -1107,1173,1106, -1173,1107,1174, -1108,1174,1107, -1174,1108,1175, -1109,1175,1108, -1175,1109,1176, -1110,1176,1109, -1176,1110,1177, -1111,1177,1110, -1177,1111,1178, -1112,1178,1111, -1178,1112,1179, -1113,1179,1112, -1179,1113,1180, -1114,1180,1113, -1180,1114,1181, -1115,1181,1114, -1181,1115,1182, -1116,1182,1115, -1182,1116,1183, -1117,1183,1116, -1183,1117,1184, -1118,1184,1117, -1184,1118,1185, -1119,1185,1118, -1185,1119,1186, -1120,1186,1119, -1186,1120,1187, -1121,1187,1120, -1188,1122,1189, -1123,1189,1122, -1189,1123,1190, -1124,1190,1123, -1190,1124,1191, -1125,1191,1124, -1191,1125,1192, -1126,1192,1125, -1192,1126,1193, -1127,1193,1126, -1193,1127,1194, -1128,1194,1127, -1194,1128,1195, -1129,1195,1128, -1195,1129,1196, -1130,1196,1129, -1196,1130,1197, -1131,1197,1130, -1197,1131,1198, -1132,1198,1131, -1198,1132,1199, -1133,1199,1132, -1199,1133,1200, -1134,1200,1133, -1200,1134,1201, -1135,1201,1134, -1201,1135,1202, -1136,1202,1135, -1202,1136,1203, -1137,1203,1136, -1203,1137,1204, -1138,1204,1137, -1204,1138,1205, -1139,1205,1138, -1205,1139,1206, -1140,1206,1139, -1206,1140,1207, -1141,1207,1140, -1207,1141,1208, -1142,1208,1141, -1208,1142,1209, -1143,1209,1142, -1209,1143,1210, -1144,1210,1143, -1210,1144,1211, -1145,1211,1144, -1211,1145,1212, -1146,1212,1145, -1212,1146,1213, -1147,1213,1146, -1213,1147,1214, -1148,1214,1147, -1214,1148,1215, -1149,1215,1148, -1215,1149,1216, -1150,1216,1149, -1216,1150,1217, -1151,1217,1150, -1217,1151,1218, -1152,1218,1151, -1218,1152,1219, -1153,1219,1152, -1219,1153,1220, -1154,1220,1153, -1220,1154,1221, -1155,1221,1154, -1221,1155,1222, -1156,1222,1155, -1222,1156,1223, -1157,1223,1156, -1223,1157,1224, -1158,1224,1157, -1224,1158,1225, -1159,1225,1158, -1225,1159,1226, -1160,1226,1159, -1226,1160,1227, -1161,1227,1160, -1227,1161,1228, -1162,1228,1161, -1228,1162,1229, -1163,1229,1162, -1229,1163,1230, -1164,1230,1163, -1230,1164,1231, -1165,1231,1164, -1231,1165,1232, -1166,1232,1165, -1232,1166,1233, -1167,1233,1166, -1233,1167,1234, -1168,1234,1167, -1234,1168,1235, -1169,1235,1168, -1235,1169,1236, -1170,1236,1169, -1236,1170,1237, -1171,1237,1170, -1237,1171,1238, -1172,1238,1171, -1238,1172,1239, -1173,1239,1172, -1239,1173,1240, -1174,1240,1173, -1240,1174,1241, -1175,1241,1174, -1241,1175,1242, -1176,1242,1175, -1242,1176,1243, -1177,1243,1176, -1243,1177,1244, -1178,1244,1177, -1244,1178,1245, -1179,1245,1178, -1245,1179,1246, -1180,1246,1179, -1246,1180,1247, -1181,1247,1180, -1247,1181,1248, -1182,1248,1181, -1248,1182,1249, -1183,1249,1182, -1249,1183,1250, -1184,1250,1183, -1250,1184,1251, -1185,1251,1184, -1251,1185,1252, -1186,1252,1185, -1252,1186,1253, -1187,1253,1186, -1254,1188,1255, -1189,1255,1188, -1255,1189,1256, -1190,1256,1189, -1256,1190,1257, -1191,1257,1190, -1257,1191,1258, -1192,1258,1191, -1258,1192,1259, -1193,1259,1192, -1259,1193,1260, -1194,1260,1193, -1260,1194,1261, -1195,1261,1194, -1261,1195,1262, -1196,1262,1195, -1262,1196,1263, -1197,1263,1196, -1263,1197,1264, -1198,1264,1197, -1264,1198,1265, -1199,1265,1198, -1265,1199,1266, -1200,1266,1199, -1266,1200,1267, -1201,1267,1200, -1267,1201,1268, -1202,1268,1201, -1268,1202,1269, -1203,1269,1202, -1269,1203,1270, -1204,1270,1203, -1270,1204,1271, -1205,1271,1204, -1271,1205,1272, -1206,1272,1205, -1272,1206,1273, -1207,1273,1206, -1273,1207,1274, -1208,1274,1207, -1274,1208,1275, -1209,1275,1208, -1275,1209,1276, -1210,1276,1209, -1276,1210,1277, -1211,1277,1210, -1277,1211,1278, -1212,1278,1211, -1278,1212,1279, -1213,1279,1212, -1279,1213,1280, -1214,1280,1213, -1280,1214,1281, -1215,1281,1214, -1281,1215,1282, -1216,1282,1215, -1282,1216,1283, -1217,1283,1216, -1283,1217,1284, -1218,1284,1217, -1284,1218,1285, -1219,1285,1218, -1285,1219,1286, -1220,1286,1219, -1286,1220,1287, -1221,1287,1220, -1287,1221,1288, -1222,1288,1221, -1288,1222,1289, -1223,1289,1222, -1289,1223,1290, -1224,1290,1223, -1290,1224,1291, -1225,1291,1224, -1291,1225,1292, -1226,1292,1225, -1292,1226,1293, -1227,1293,1226, -1293,1227,1294, -1228,1294,1227, -1294,1228,1295, -1229,1295,1228, -1295,1229,1296, -1230,1296,1229, -1296,1230,1297, -1231,1297,1230, -1297,1231,1298, -1232,1298,1231, -1298,1232,1299, -1233,1299,1232, -1299,1233,1300, -1234,1300,1233, -1300,1234,1301, -1235,1301,1234, -1301,1235,1302, -1236,1302,1235, -1302,1236,1303, -1237,1303,1236, -1303,1237,1304, -1238,1304,1237, -1304,1238,1305, -1239,1305,1238, -1305,1239,1306, -1240,1306,1239, -1306,1240,1307, -1241,1307,1240, -1307,1241,1308, -1242,1308,1241, -1308,1242,1309, -1243,1309,1242, -1309,1243,1310, -1244,1310,1243, -1310,1244,1311, -1245,1311,1244, -1311,1245,1312, -1246,1312,1245, -1312,1246,1313, -1247,1313,1246, -1313,1247,1314, -1248,1314,1247, -1314,1248,1315, -1249,1315,1248, -1315,1249,1316, -1250,1316,1249, -1316,1250,1317, -1251,1317,1250, -1317,1251,1318, -1252,1318,1251, -1318,1252,1319, -1253,1319,1252, -1320,1254,1321, -1255,1321,1254, -1321,1255,1322, -1256,1322,1255, -1322,1256,1323, -1257,1323,1256, -1323,1257,1324, -1258,1324,1257, -1324,1258,1325, -1259,1325,1258, -1325,1259,1326, -1260,1326,1259, -1326,1260,1327, -1261,1327,1260, -1327,1261,1328, -1262,1328,1261, -1328,1262,1329, -1263,1329,1262, -1329,1263,1330, -1264,1330,1263, -1330,1264,1331, -1265,1331,1264, -1331,1265,1332, -1266,1332,1265, -1332,1266,1333, -1267,1333,1266, -1333,1267,1334, -1268,1334,1267, -1334,1268,1335, -1269,1335,1268, -1335,1269,1336, -1270,1336,1269, -1336,1270,1337, -1271,1337,1270, -1337,1271,1338, -1272,1338,1271, -1338,1272,1339, -1273,1339,1272, -1339,1273,1340, -1274,1340,1273, -1340,1274,1341, -1275,1341,1274, -1341,1275,1342, -1276,1342,1275, -1342,1276,1343, -1277,1343,1276, -1343,1277,1344, -1278,1344,1277, -1344,1278,1345, -1279,1345,1278, -1345,1279,1346, -1280,1346,1279, -1346,1280,1347, -1281,1347,1280, -1347,1281,1348, -1282,1348,1281, -1348,1282,1349, -1283,1349,1282, -1349,1283,1350, -1284,1350,1283, -1350,1284,1351, -1285,1351,1284, -1351,1285,1352, -1286,1352,1285, -1352,1286,1353, -1287,1353,1286, -1353,1287,1354, -1288,1354,1287, -1354,1288,1355, -1289,1355,1288, -1355,1289,1356, -1290,1356,1289, -1356,1290,1357, -1291,1357,1290, -1357,1291,1358, -1292,1358,1291, -1358,1292,1359, -1293,1359,1292, -1359,1293,1360, -1294,1360,1293, -1360,1294,1361, -1295,1361,1294, -1361,1295,1362, -1296,1362,1295, -1362,1296,1363, -1297,1363,1296, -1363,1297,1364, -1298,1364,1297, -1364,1298,1365, -1299,1365,1298, -1365,1299,1366, -1300,1366,1299, -1366,1300,1367, -1301,1367,1300, -1367,1301,1368, -1302,1368,1301, -1368,1302,1369, -1303,1369,1302, -1369,1303,1370, -1304,1370,1303, -1370,1304,1371, -1305,1371,1304, -1371,1305,1372, -1306,1372,1305, -1372,1306,1373, -1307,1373,1306, -1373,1307,1374, -1308,1374,1307, -1374,1308,1375, -1309,1375,1308, -1375,1309,1376, -1310,1376,1309, -1376,1310,1377, -1311,1377,1310, -1377,1311,1378, -1312,1378,1311, -1378,1312,1379, -1313,1379,1312, -1379,1313,1380, -1314,1380,1313, -1380,1314,1381, -1315,1381,1314, -1381,1315,1382, -1316,1382,1315, -1382,1316,1383, -1317,1383,1316, -1383,1317,1384, -1318,1384,1317, -1384,1318,1385, -1319,1385,1318, -1386,1320,1387, -1321,1387,1320, -1387,1321,1388, -1322,1388,1321, -1388,1322,1389, -1323,1389,1322, -1389,1323,1390, -1324,1390,1323, -1390,1324,1391, -1325,1391,1324, -1391,1325,1392, -1326,1392,1325, -1392,1326,1393, -1327,1393,1326, -1393,1327,1394, -1328,1394,1327, -1394,1328,1395, -1329,1395,1328, -1395,1329,1396, -1330,1396,1329, -1396,1330,1397, -1331,1397,1330, -1397,1331,1398, -1332,1398,1331, -1398,1332,1399, -1333,1399,1332, -1399,1333,1400, -1334,1400,1333, -1400,1334,1401, -1335,1401,1334, -1401,1335,1402, -1336,1402,1335, -1402,1336,1403, -1337,1403,1336, -1403,1337,1404, -1338,1404,1337, -1404,1338,1405, -1339,1405,1338, -1405,1339,1406, -1340,1406,1339, -1406,1340,1407, -1341,1407,1340, -1407,1341,1408, -1342,1408,1341, -1408,1342,1409, -1343,1409,1342, -1409,1343,1410, -1344,1410,1343, -1410,1344,1411, -1345,1411,1344, -1411,1345,1412, -1346,1412,1345, -1412,1346,1413, -1347,1413,1346, -1413,1347,1414, -1348,1414,1347, -1414,1348,1415, -1349,1415,1348, -1415,1349,1416, -1350,1416,1349, -1416,1350,1417, -1351,1417,1350, -1417,1351,1418, -1352,1418,1351, -1418,1352,1419, -1353,1419,1352, -1419,1353,1420, -1354,1420,1353, -1420,1354,1421, -1355,1421,1354, -1421,1355,1422, -1356,1422,1355, -1422,1356,1423, -1357,1423,1356, -1423,1357,1424, -1358,1424,1357, -1424,1358,1425, -1359,1425,1358, -1425,1359,1426, -1360,1426,1359, -1426,1360,1427, -1361,1427,1360, -1427,1361,1428, -1362,1428,1361, -1428,1362,1429, -1363,1429,1362, -1429,1363,1430, -1364,1430,1363, -1430,1364,1431, -1365,1431,1364, -1431,1365,1432, -1366,1432,1365, -1432,1366,1433, -1367,1433,1366, -1433,1367,1434, -1368,1434,1367, -1434,1368,1435, -1369,1435,1368, -1435,1369,1436, -1370,1436,1369, -1436,1370,1437, -1371,1437,1370, -1437,1371,1438, -1372,1438,1371, -1438,1372,1439, -1373,1439,1372, -1439,1373,1440, -1374,1440,1373, -1440,1374,1441, -1375,1441,1374, -1441,1375,1442, -1376,1442,1375, -1442,1376,1443, -1377,1443,1376, -1443,1377,1444, -1378,1444,1377, -1444,1378,1445, -1379,1445,1378, -1445,1379,1446, -1380,1446,1379, -1446,1380,1447, -1381,1447,1380, -1447,1381,1448, -1382,1448,1381, -1448,1382,1449, -1383,1449,1382, -1449,1383,1450, -1384,1450,1383, -1450,1384,1451, -1385,1451,1384, -1452,1386,1453, -1387,1453,1386, -1453,1387,1454, -1388,1454,1387, -1454,1388,1455, -1389,1455,1388, -1455,1389,1456, -1390,1456,1389, -1456,1390,1457, -1391,1457,1390, -1457,1391,1458, -1392,1458,1391, -1458,1392,1459, -1393,1459,1392, -1459,1393,1460, -1394,1460,1393, -1460,1394,1461, -1395,1461,1394, -1461,1395,1462, -1396,1462,1395, -1462,1396,1463, -1397,1463,1396, -1463,1397,1464, -1398,1464,1397, -1464,1398,1465, -1399,1465,1398, -1465,1399,1466, -1400,1466,1399, -1466,1400,1467, -1401,1467,1400, -1467,1401,1468, -1402,1468,1401, -1468,1402,1469, -1403,1469,1402, -1469,1403,1470, -1404,1470,1403, -1470,1404,1471, -1405,1471,1404, -1471,1405,1472, -1406,1472,1405, -1472,1406,1473, -1407,1473,1406, -1473,1407,1474, -1408,1474,1407, -1474,1408,1475, -1409,1475,1408, -1475,1409,1476, -1410,1476,1409, -1476,1410,1477, -1411,1477,1410, -1477,1411,1478, -1412,1478,1411, -1478,1412,1479, -1413,1479,1412, -1479,1413,1480, -1414,1480,1413, -1480,1414,1481, -1415,1481,1414, -1481,1415,1482, -1416,1482,1415, -1482,1416,1483, -1417,1483,1416, -1483,1417,1484, -1418,1484,1417, -1484,1418,1485, -1419,1485,1418, -1485,1419,1486, -1420,1486,1419, -1486,1420,1487, -1421,1487,1420, -1487,1421,1488, -1422,1488,1421, -1488,1422,1489, -1423,1489,1422, -1489,1423,1490, -1424,1490,1423, -1490,1424,1491, -1425,1491,1424, -1491,1425,1492, -1426,1492,1425, -1492,1426,1493, -1427,1493,1426, -1493,1427,1494, -1428,1494,1427, -1494,1428,1495, -1429,1495,1428, -1495,1429,1496, -1430,1496,1429, -1496,1430,1497, -1431,1497,1430, -1497,1431,1498, -1432,1498,1431, -1498,1432,1499, -1433,1499,1432, -1499,1433,1500, -1434,1500,1433, -1500,1434,1501, -1435,1501,1434, -1501,1435,1502, -1436,1502,1435, -1502,1436,1503, -1437,1503,1436, -1503,1437,1504, -1438,1504,1437, -1504,1438,1505, -1439,1505,1438, -1505,1439,1506, -1440,1506,1439, -1506,1440,1507, -1441,1507,1440, -1507,1441,1508, -1442,1508,1441, -1508,1442,1509, -1443,1509,1442, -1509,1443,1510, -1444,1510,1443, -1510,1444,1511, -1445,1511,1444, -1511,1445,1512, -1446,1512,1445, -1512,1446,1513, -1447,1513,1446, -1513,1447,1514, -1448,1514,1447, -1514,1448,1515, -1449,1515,1448, -1515,1449,1516, -1450,1516,1449, -1516,1450,1517, -1451,1517,1450, -1518,1452,1519, -1453,1519,1452, -1519,1453,1520, -1454,1520,1453, -1520,1454,1521, -1455,1521,1454, -1521,1455,1522, -1456,1522,1455, -1522,1456,1523, -1457,1523,1456, -1523,1457,1524, -1458,1524,1457, -1524,1458,1525, -1459,1525,1458, -1525,1459,1526, -1460,1526,1459, -1526,1460,1527, -1461,1527,1460, -1527,1461,1528, -1462,1528,1461, -1528,1462,1529, -1463,1529,1462, -1529,1463,1530, -1464,1530,1463, -1530,1464,1531, -1465,1531,1464, -1531,1465,1532, -1466,1532,1465, -1532,1466,1533, -1467,1533,1466, -1533,1467,1534, -1468,1534,1467, -1534,1468,1535, -1469,1535,1468, -1535,1469,1536, -1470,1536,1469, -1536,1470,1537, -1471,1537,1470, -1537,1471,1538, -1472,1538,1471, -1538,1472,1539, -1473,1539,1472, -1539,1473,1540, -1474,1540,1473, -1540,1474,1541, -1475,1541,1474, -1541,1475,1542, -1476,1542,1475, -1542,1476,1543, -1477,1543,1476, -1543,1477,1544, -1478,1544,1477, -1544,1478,1545, -1479,1545,1478, -1545,1479,1546, -1480,1546,1479, -1546,1480,1547, -1481,1547,1480, -1547,1481,1548, -1482,1548,1481, -1548,1482,1549, -1483,1549,1482, -1549,1483,1550, -1484,1550,1483, -1550,1484,1551, -1485,1551,1484, -1551,1485,1552, -1486,1552,1485, -1552,1486,1553, -1487,1553,1486, -1553,1487,1554, -1488,1554,1487, -1554,1488,1555, -1489,1555,1488, -1555,1489,1556, -1490,1556,1489, -1556,1490,1557, -1491,1557,1490, -1557,1491,1558, -1492,1558,1491, -1558,1492,1559, -1493,1559,1492, -1559,1493,1560, -1494,1560,1493, -1560,1494,1561, -1495,1561,1494, -1561,1495,1562, -1496,1562,1495, -1562,1496,1563, -1497,1563,1496, -1563,1497,1564, -1498,1564,1497, -1564,1498,1565, -1499,1565,1498, -1565,1499,1566, -1500,1566,1499, -1566,1500,1567, -1501,1567,1500, -1567,1501,1568, -1502,1568,1501, -1568,1502,1569, -1503,1569,1502, -1569,1503,1570, -1504,1570,1503, -1570,1504,1571, -1505,1571,1504, -1571,1505,1572, -1506,1572,1505, -1572,1506,1573, -1507,1573,1506, -1573,1507,1574, -1508,1574,1507, -1574,1508,1575, -1509,1575,1508, -1575,1509,1576, -1510,1576,1509, -1576,1510,1577, -1511,1577,1510, -1577,1511,1578, -1512,1578,1511, -1578,1512,1579, -1513,1579,1512, -1579,1513,1580, -1514,1580,1513, -1580,1514,1581, -1515,1581,1514, -1581,1515,1582, -1516,1582,1515, -1582,1516,1583, -1517,1583,1516, -1584,1518,1585, -1519,1585,1518, -1585,1519,1586, -1520,1586,1519, -1586,1520,1587, -1521,1587,1520, -1587,1521,1588, -1522,1588,1521, -1588,1522,1589, -1523,1589,1522, -1589,1523,1590, -1524,1590,1523, -1590,1524,1591, -1525,1591,1524, -1591,1525,1592, -1526,1592,1525, -1592,1526,1593, -1527,1593,1526, -1593,1527,1594, -1528,1594,1527, -1594,1528,1595, -1529,1595,1528, -1595,1529,1596, -1530,1596,1529, -1596,1530,1597, -1531,1597,1530, -1597,1531,1598, -1532,1598,1531, -1598,1532,1599, -1533,1599,1532, -1599,1533,1600, -1534,1600,1533, -1600,1534,1601, -1535,1601,1534, -1601,1535,1602, -1536,1602,1535, -1602,1536,1603, -1537,1603,1536, -1603,1537,1604, -1538,1604,1537, -1604,1538,1605, -1539,1605,1538, -1605,1539,1606, -1540,1606,1539, -1606,1540,1607, -1541,1607,1540, -1607,1541,1608, -1542,1608,1541, -1608,1542,1609, -1543,1609,1542, -1609,1543,1610, -1544,1610,1543, -1610,1544,1611, -1545,1611,1544, -1611,1545,1612, -1546,1612,1545, -1612,1546,1613, -1547,1613,1546, -1613,1547,1614, -1548,1614,1547, -1614,1548,1615, -1549,1615,1548, -1615,1549,1616, -1550,1616,1549, -1616,1550,1617, -1551,1617,1550, -1617,1551,1618, -1552,1618,1551, -1618,1552,1619, -1553,1619,1552, -1619,1553,1620, -1554,1620,1553, -1620,1554,1621, -1555,1621,1554, -1621,1555,1622, -1556,1622,1555, -1622,1556,1623, -1557,1623,1556, -1623,1557,1624, -1558,1624,1557, -1624,1558,1625, -1559,1625,1558, -1625,1559,1626, -1560,1626,1559, -1626,1560,1627, -1561,1627,1560, -1627,1561,1628, -1562,1628,1561, -1628,1562,1629, -1563,1629,1562, -1629,1563,1630, -1564,1630,1563, -1630,1564,1631, -1565,1631,1564, -1631,1565,1632, -1566,1632,1565, -1632,1566,1633, -1567,1633,1566, -1633,1567,1634, -1568,1634,1567, -1634,1568,1635, -1569,1635,1568, -1635,1569,1636, -1570,1636,1569, -1636,1570,1637, -1571,1637,1570, -1637,1571,1638, -1572,1638,1571, -1638,1572,1639, -1573,1639,1572, -1639,1573,1640, -1574,1640,1573, -1640,1574,1641, -1575,1641,1574, -1641,1575,1642, -1576,1642,1575, -1642,1576,1643, -1577,1643,1576, -1643,1577,1644, -1578,1644,1577, -1644,1578,1645, -1579,1645,1578, -1645,1579,1646, -1580,1646,1579, -1646,1580,1647, -1581,1647,1580, -1647,1581,1648, -1582,1648,1581, -1648,1582,1649, -1583,1649,1582, -1650,1584,1651, -1585,1651,1584, -1651,1585,1652, -1586,1652,1585, -1652,1586,1653, -1587,1653,1586, -1653,1587,1654, -1588,1654,1587, -1654,1588,1655, -1589,1655,1588, -1655,1589,1656, -1590,1656,1589, -1656,1590,1657, -1591,1657,1590, -1657,1591,1658, -1592,1658,1591, -1658,1592,1659, -1593,1659,1592, -1659,1593,1660, -1594,1660,1593, -1660,1594,1661, -1595,1661,1594, -1661,1595,1662, -1596,1662,1595, -1662,1596,1663, -1597,1663,1596, -1663,1597,1664, -1598,1664,1597, -1664,1598,1665, -1599,1665,1598, -1665,1599,1666, -1600,1666,1599, -1666,1600,1667, -1601,1667,1600, -1667,1601,1668, -1602,1668,1601, -1668,1602,1669, -1603,1669,1602, -1669,1603,1670, -1604,1670,1603, -1670,1604,1671, -1605,1671,1604, -1671,1605,1672, -1606,1672,1605, -1672,1606,1673, -1607,1673,1606, -1673,1607,1674, -1608,1674,1607, -1674,1608,1675, -1609,1675,1608, -1675,1609,1676, -1610,1676,1609, -1676,1610,1677, -1611,1677,1610, -1677,1611,1678, -1612,1678,1611, -1678,1612,1679, -1613,1679,1612, -1679,1613,1680, -1614,1680,1613, -1680,1614,1681, -1615,1681,1614, -1681,1615,1682, -1616,1682,1615, -1682,1616,1683, -1617,1683,1616, -1683,1617,1684, -1618,1684,1617, -1684,1618,1685, -1619,1685,1618, -1685,1619,1686, -1620,1686,1619, -1686,1620,1687, -1621,1687,1620, -1687,1621,1688, -1622,1688,1621, -1688,1622,1689, -1623,1689,1622, -1689,1623,1690, -1624,1690,1623, -1690,1624,1691, -1625,1691,1624, -1691,1625,1692, -1626,1692,1625, -1692,1626,1693, -1627,1693,1626, -1693,1627,1694, -1628,1694,1627, -1694,1628,1695, -1629,1695,1628, -1695,1629,1696, -1630,1696,1629, -1696,1630,1697, -1631,1697,1630, -1697,1631,1698, -1632,1698,1631, -1698,1632,1699, -1633,1699,1632, -1699,1633,1700, -1634,1700,1633, -1700,1634,1701, -1635,1701,1634, -1701,1635,1702, -1636,1702,1635, -1702,1636,1703, -1637,1703,1636, -1703,1637,1704, -1638,1704,1637, -1704,1638,1705, -1639,1705,1638, -1705,1639,1706, -1640,1706,1639, -1706,1640,1707, -1641,1707,1640, -1707,1641,1708, -1642,1708,1641, -1708,1642,1709, -1643,1709,1642, -1709,1643,1710, -1644,1710,1643, -1710,1644,1711, -1645,1711,1644, -1711,1645,1712, -1646,1712,1645, -1712,1646,1713, -1647,1713,1646, -1713,1647,1714, -1648,1714,1647, -1714,1648,1715, -1649,1715,1648, -1716,1650,1717, -1651,1717,1650, -1717,1651,1718, -1652,1718,1651, -1718,1652,1719, -1653,1719,1652, -1719,1653,1720, -1654,1720,1653, -1720,1654,1721, -1655,1721,1654, -1721,1655,1722, -1656,1722,1655, -1722,1656,1723, -1657,1723,1656, -1723,1657,1724, -1658,1724,1657, -1724,1658,1725, -1659,1725,1658, -1725,1659,1726, -1660,1726,1659, -1726,1660,1727, -1661,1727,1660, -1727,1661,1728, -1662,1728,1661, -1728,1662,1729, -1663,1729,1662, -1729,1663,1730, -1664,1730,1663, -1730,1664,1731, -1665,1731,1664, -1731,1665,1732, -1666,1732,1665, -1732,1666,1733, -1667,1733,1666, -1733,1667,1734, -1668,1734,1667, -1734,1668,1735, -1669,1735,1668, -1735,1669,1736, -1670,1736,1669, -1736,1670,1737, -1671,1737,1670, -1737,1671,1738, -1672,1738,1671, -1738,1672,1739, -1673,1739,1672, -1739,1673,1740, -1674,1740,1673, -1740,1674,1741, -1675,1741,1674, -1741,1675,1742, -1676,1742,1675, -1742,1676,1743, -1677,1743,1676, -1743,1677,1744, -1678,1744,1677, -1744,1678,1745, -1679,1745,1678, -1745,1679,1746, -1680,1746,1679, -1746,1680,1747, -1681,1747,1680, -1747,1681,1748, -1682,1748,1681, -1748,1682,1749, -1683,1749,1682, -1749,1683,1750, -1684,1750,1683, -1750,1684,1751, -1685,1751,1684, -1751,1685,1752, -1686,1752,1685, -1752,1686,1753, -1687,1753,1686, -1753,1687,1754, -1688,1754,1687, -1754,1688,1755, -1689,1755,1688, -1755,1689,1756, -1690,1756,1689, -1756,1690,1757, -1691,1757,1690, -1757,1691,1758, -1692,1758,1691, -1758,1692,1759, -1693,1759,1692, -1759,1693,1760, -1694,1760,1693, -1760,1694,1761, -1695,1761,1694, -1761,1695,1762, -1696,1762,1695, -1762,1696,1763, -1697,1763,1696, -1763,1697,1764, -1698,1764,1697, -1764,1698,1765, -1699,1765,1698, -1765,1699,1766, -1700,1766,1699, -1766,1700,1767, -1701,1767,1700, -1767,1701,1768, -1702,1768,1701, -1768,1702,1769, -1703,1769,1702, -1769,1703,1770, -1704,1770,1703, -1770,1704,1771, -1705,1771,1704, -1771,1705,1772, -1706,1772,1705, -1772,1706,1773, -1707,1773,1706, -1773,1707,1774, -1708,1774,1707, -1774,1708,1775, -1709,1775,1708, -1775,1709,1776, -1710,1776,1709, -1776,1710,1777, -1711,1777,1710, -1777,1711,1778, -1712,1778,1711, -1778,1712,1779, -1713,1779,1712, -1779,1713,1780, -1714,1780,1713, -1780,1714,1781, -1715,1781,1714, -1782,1716,1783, -1717,1783,1716, -1783,1717,1784, -1718,1784,1717, -1784,1718,1785, -1719,1785,1718, -1785,1719,1786, -1720,1786,1719, -1786,1720,1787, -1721,1787,1720, -1787,1721,1788, -1722,1788,1721, -1788,1722,1789, -1723,1789,1722, -1789,1723,1790, -1724,1790,1723, -1790,1724,1791, -1725,1791,1724, -1791,1725,1792, -1726,1792,1725, -1792,1726,1793, -1727,1793,1726, -1793,1727,1794, -1728,1794,1727, -1794,1728,1795, -1729,1795,1728, -1795,1729,1796, -1730,1796,1729, -1796,1730,1797, -1731,1797,1730, -1797,1731,1798, -1732,1798,1731, -1798,1732,1799, -1733,1799,1732, -1799,1733,1800, -1734,1800,1733, -1800,1734,1801, -1735,1801,1734, -1801,1735,1802, -1736,1802,1735, -1802,1736,1803, -1737,1803,1736, -1803,1737,1804, -1738,1804,1737, -1804,1738,1805, -1739,1805,1738, -1805,1739,1806, -1740,1806,1739, -1806,1740,1807, -1741,1807,1740, -1807,1741,1808, -1742,1808,1741, -1808,1742,1809, -1743,1809,1742, -1809,1743,1810, -1744,1810,1743, -1810,1744,1811, -1745,1811,1744, -1811,1745,1812, -1746,1812,1745, -1812,1746,1813, -1747,1813,1746, -1813,1747,1814, -1748,1814,1747, -1814,1748,1815, -1749,1815,1748, -1815,1749,1816, -1750,1816,1749, -1816,1750,1817, -1751,1817,1750, -1817,1751,1818, -1752,1818,1751, -1818,1752,1819, -1753,1819,1752, -1819,1753,1820, -1754,1820,1753, -1820,1754,1821, -1755,1821,1754, -1821,1755,1822, -1756,1822,1755, -1822,1756,1823, -1757,1823,1756, -1823,1757,1824, -1758,1824,1757, -1824,1758,1825, -1759,1825,1758, -1825,1759,1826, -1760,1826,1759, -1826,1760,1827, -1761,1827,1760, -1827,1761,1828, -1762,1828,1761, -1828,1762,1829, -1763,1829,1762, -1829,1763,1830, -1764,1830,1763, -1830,1764,1831, -1765,1831,1764, -1831,1765,1832, -1766,1832,1765, -1832,1766,1833, -1767,1833,1766, -1833,1767,1834, -1768,1834,1767, -1834,1768,1835, -1769,1835,1768, -1835,1769,1836, -1770,1836,1769, -1836,1770,1837, -1771,1837,1770, -1837,1771,1838, -1772,1838,1771, -1838,1772,1839, -1773,1839,1772, -1839,1773,1840, -1774,1840,1773, -1840,1774,1841, -1775,1841,1774, -1841,1775,1842, -1776,1842,1775, -1842,1776,1843, -1777,1843,1776, -1843,1777,1844, -1778,1844,1777, -1844,1778,1845, -1779,1845,1778, -1845,1779,1846, -1780,1846,1779, -1846,1780,1847, -1781,1847,1780, -1848,1782,1849, -1783,1849,1782, -1849,1783,1850, -1784,1850,1783, -1850,1784,1851, -1785,1851,1784, -1851,1785,1852, -1786,1852,1785, -1852,1786,1853, -1787,1853,1786, -1853,1787,1854, -1788,1854,1787, -1854,1788,1855, -1789,1855,1788, -1855,1789,1856, -1790,1856,1789, -1856,1790,1857, -1791,1857,1790, -1857,1791,1858, -1792,1858,1791, -1858,1792,1859, -1793,1859,1792, -1859,1793,1860, -1794,1860,1793, -1860,1794,1861, -1795,1861,1794, -1861,1795,1862, -1796,1862,1795, -1862,1796,1863, -1797,1863,1796, -1863,1797,1864, -1798,1864,1797, -1864,1798,1865, -1799,1865,1798, -1865,1799,1866, -1800,1866,1799, -1866,1800,1867, -1801,1867,1800, -1867,1801,1868, -1802,1868,1801, -1868,1802,1869, -1803,1869,1802, -1869,1803,1870, -1804,1870,1803, -1870,1804,1871, -1805,1871,1804, -1871,1805,1872, -1806,1872,1805, -1872,1806,1873, -1807,1873,1806, -1873,1807,1874, -1808,1874,1807, -1874,1808,1875, -1809,1875,1808, -1875,1809,1876, -1810,1876,1809, -1876,1810,1877, -1811,1877,1810, -1877,1811,1878, -1812,1878,1811, -1878,1812,1879, -1813,1879,1812, -1879,1813,1880, -1814,1880,1813, -1880,1814,1881, -1815,1881,1814, -1881,1815,1882, -1816,1882,1815, -1882,1816,1883, -1817,1883,1816, -1883,1817,1884, -1818,1884,1817, -1884,1818,1885, -1819,1885,1818, -1885,1819,1886, -1820,1886,1819, -1886,1820,1887, -1821,1887,1820, -1887,1821,1888, -1822,1888,1821, -1888,1822,1889, -1823,1889,1822, -1889,1823,1890, -1824,1890,1823, -1890,1824,1891, -1825,1891,1824, -1891,1825,1892, -1826,1892,1825, -1892,1826,1893, -1827,1893,1826, -1893,1827,1894, -1828,1894,1827, -1894,1828,1895, -1829,1895,1828, -1895,1829,1896, -1830,1896,1829, -1896,1830,1897, -1831,1897,1830, -1897,1831,1898, -1832,1898,1831, -1898,1832,1899, -1833,1899,1832, -1899,1833,1900, -1834,1900,1833, -1900,1834,1901, -1835,1901,1834, -1901,1835,1902, -1836,1902,1835, -1902,1836,1903, -1837,1903,1836, -1903,1837,1904, -1838,1904,1837, -1904,1838,1905, -1839,1905,1838, -1905,1839,1906, -1840,1906,1839, -1906,1840,1907, -1841,1907,1840, -1907,1841,1908, -1842,1908,1841, -1908,1842,1909, -1843,1909,1842, -1909,1843,1910, -1844,1910,1843, -1910,1844,1911, -1845,1911,1844, -1911,1845,1912, -1846,1912,1845, -1912,1846,1913, -1847,1913,1846, -1914,1848,1915, -1849,1915,1848, -1915,1849,1916, -1850,1916,1849, -1916,1850,1917, -1851,1917,1850, -1917,1851,1918, -1852,1918,1851, -1918,1852,1919, -1853,1919,1852, -1919,1853,1920, -1854,1920,1853, -1920,1854,1921, -1855,1921,1854, -1921,1855,1922, -1856,1922,1855, -1922,1856,1923, -1857,1923,1856, -1923,1857,1924, -1858,1924,1857, -1924,1858,1925, -1859,1925,1858, -1925,1859,1926, -1860,1926,1859, -1926,1860,1927, -1861,1927,1860, -1927,1861,1928, -1862,1928,1861, -1928,1862,1929, -1863,1929,1862, -1929,1863,1930, -1864,1930,1863, -1930,1864,1931, -1865,1931,1864, -1931,1865,1932, -1866,1932,1865, -1932,1866,1933, -1867,1933,1866, -1933,1867,1934, -1868,1934,1867, -1934,1868,1935, -1869,1935,1868, -1935,1869,1936, -1870,1936,1869, -1936,1870,1937, -1871,1937,1870, -1937,1871,1938, -1872,1938,1871, -1938,1872,1939, -1873,1939,1872, -1939,1873,1940, -1874,1940,1873, -1940,1874,1941, -1875,1941,1874, -1941,1875,1942, -1876,1942,1875, -1942,1876,1943, -1877,1943,1876, -1943,1877,1944, -1878,1944,1877, -1944,1878,1945, -1879,1945,1878, -1945,1879,1946, -1880,1946,1879, -1946,1880,1947, -1881,1947,1880, -1947,1881,1948, -1882,1948,1881, -1948,1882,1949, -1883,1949,1882, -1949,1883,1950, -1884,1950,1883, -1950,1884,1951, -1885,1951,1884, -1951,1885,1952, -1886,1952,1885, -1952,1886,1953, -1887,1953,1886, -1953,1887,1954, -1888,1954,1887, -1954,1888,1955, -1889,1955,1888, -1955,1889,1956, -1890,1956,1889, -1956,1890,1957, -1891,1957,1890, -1957,1891,1958, -1892,1958,1891, -1958,1892,1959, -1893,1959,1892, -1959,1893,1960, -1894,1960,1893, -1960,1894,1961, -1895,1961,1894, -1961,1895,1962, -1896,1962,1895, -1962,1896,1963, -1897,1963,1896, -1963,1897,1964, -1898,1964,1897, -1964,1898,1965, -1899,1965,1898, -1965,1899,1966, -1900,1966,1899, -1966,1900,1967, -1901,1967,1900, -1967,1901,1968, -1902,1968,1901, -1968,1902,1969, -1903,1969,1902, -1969,1903,1970, -1904,1970,1903, -1970,1904,1971, -1905,1971,1904, -1971,1905,1972, -1906,1972,1905, -1972,1906,1973, -1907,1973,1906, -1973,1907,1974, -1908,1974,1907, -1974,1908,1975, -1909,1975,1908, -1975,1909,1976, -1910,1976,1909, -1976,1910,1977, -1911,1977,1910, -1977,1911,1978, -1912,1978,1911, -1978,1912,1979, -1913,1979,1912, -1980,1914,1981, -1915,1981,1914, -1981,1915,1982, -1916,1982,1915, -1982,1916,1983, -1917,1983,1916, -1983,1917,1984, -1918,1984,1917, -1984,1918,1985, -1919,1985,1918, -1985,1919,1986, -1920,1986,1919, -1986,1920,1987, -1921,1987,1920, -1987,1921,1988, -1922,1988,1921, -1988,1922,1989, -1923,1989,1922, -1989,1923,1990, -1924,1990,1923, -1990,1924,1991, -1925,1991,1924, -1991,1925,1992, -1926,1992,1925, -1992,1926,1993, -1927,1993,1926, -1993,1927,1994, -1928,1994,1927, -1994,1928,1995, -1929,1995,1928, -1995,1929,1996, -1930,1996,1929, -1996,1930,1997, -1931,1997,1930, -1997,1931,1998, -1932,1998,1931, -1998,1932,1999, -1933,1999,1932, -1999,1933,2000, -1934,2000,1933, -2000,1934,2001, -1935,2001,1934, -2001,1935,2002, -1936,2002,1935, -2002,1936,2003, -1937,2003,1936, -2003,1937,2004, -1938,2004,1937, -2004,1938,2005, -1939,2005,1938, -2005,1939,2006, -1940,2006,1939, -2006,1940,2007, -1941,2007,1940, -2007,1941,2008, -1942,2008,1941, -2008,1942,2009, -1943,2009,1942, -2009,1943,2010, -1944,2010,1943, -2010,1944,2011, -1945,2011,1944, -2011,1945,2012, -1946,2012,1945, -2012,1946,2013, -1947,2013,1946, -2013,1947,2014, -1948,2014,1947, -2014,1948,2015, -1949,2015,1948, -2015,1949,2016, -1950,2016,1949, -2016,1950,2017, -1951,2017,1950, -2017,1951,2018, -1952,2018,1951, -2018,1952,2019, -1953,2019,1952, -2019,1953,2020, -1954,2020,1953, -2020,1954,2021, -1955,2021,1954, -2021,1955,2022, -1956,2022,1955, -2022,1956,2023, -1957,2023,1956, -2023,1957,2024, -1958,2024,1957, -2024,1958,2025, -1959,2025,1958, -2025,1959,2026, -1960,2026,1959, -2026,1960,2027, -1961,2027,1960, -2027,1961,2028, -1962,2028,1961, -2028,1962,2029, -1963,2029,1962, -2029,1963,2030, -1964,2030,1963, -2030,1964,2031, -1965,2031,1964, -2031,1965,2032, -1966,2032,1965, -2032,1966,2033, -1967,2033,1966, -2033,1967,2034, -1968,2034,1967, -2034,1968,2035, -1969,2035,1968, -2035,1969,2036, -1970,2036,1969, -2036,1970,2037, -1971,2037,1970, -2037,1971,2038, -1972,2038,1971, -2038,1972,2039, -1973,2039,1972, -2039,1973,2040, -1974,2040,1973, -2040,1974,2041, -1975,2041,1974, -2041,1975,2042, -1976,2042,1975, -2042,1976,2043, -1977,2043,1976, -2043,1977,2044, -1978,2044,1977, -2044,1978,2045, -1979,2045,1978, -2046,1980,2047, -1981,2047,1980, -2047,1981,2048, -1982,2048,1981, -2048,1982,2049, -1983,2049,1982, -2049,1983,2050, -1984,2050,1983, -2050,1984,2051, -1985,2051,1984, -2051,1985,2052, -1986,2052,1985, -2052,1986,2053, -1987,2053,1986, -2053,1987,2054, -1988,2054,1987, -2054,1988,2055, -1989,2055,1988, -2055,1989,2056, -1990,2056,1989, -2056,1990,2057, -1991,2057,1990, -2057,1991,2058, -1992,2058,1991, -2058,1992,2059, -1993,2059,1992, -2059,1993,2060, -1994,2060,1993, -2060,1994,2061, -1995,2061,1994, -2061,1995,2062, -1996,2062,1995, -2062,1996,2063, -1997,2063,1996, -2063,1997,2064, -1998,2064,1997, -2064,1998,2065, -1999,2065,1998, -2065,1999,2066, -2000,2066,1999, -2066,2000,2067, -2001,2067,2000, -2067,2001,2068, -2002,2068,2001, -2068,2002,2069, -2003,2069,2002, -2069,2003,2070, -2004,2070,2003, -2070,2004,2071, -2005,2071,2004, -2071,2005,2072, -2006,2072,2005, -2072,2006,2073, -2007,2073,2006, -2073,2007,2074, -2008,2074,2007, -2074,2008,2075, -2009,2075,2008, -2075,2009,2076, -2010,2076,2009, -2076,2010,2077, -2011,2077,2010, -2077,2011,2078, -2012,2078,2011, -2078,2012,2079, -2013,2079,2012, -2079,2013,2080, -2014,2080,2013, -2080,2014,2081, -2015,2081,2014, -2081,2015,2082, -2016,2082,2015, -2082,2016,2083, -2017,2083,2016, -2083,2017,2084, -2018,2084,2017, -2084,2018,2085, -2019,2085,2018, -2085,2019,2086, -2020,2086,2019, -2086,2020,2087, -2021,2087,2020, -2087,2021,2088, -2022,2088,2021, -2088,2022,2089, -2023,2089,2022, -2089,2023,2090, -2024,2090,2023, -2090,2024,2091, -2025,2091,2024, -2091,2025,2092, -2026,2092,2025, -2092,2026,2093, -2027,2093,2026, -2093,2027,2094, -2028,2094,2027, -2094,2028,2095, -2029,2095,2028, -2095,2029,2096, -2030,2096,2029, -2096,2030,2097, -2031,2097,2030, -2097,2031,2098, -2032,2098,2031, -2098,2032,2099, -2033,2099,2032, -2099,2033,2100, -2034,2100,2033, -2100,2034,2101, -2035,2101,2034, -2101,2035,2102, -2036,2102,2035, -2102,2036,2103, -2037,2103,2036, -2103,2037,2104, -2038,2104,2037, -2104,2038,2105, -2039,2105,2038, -2105,2039,2106, -2040,2106,2039, -2106,2040,2107, -2041,2107,2040, -2107,2041,2108, -2042,2108,2041, -2108,2042,2109, -2043,2109,2042, -2109,2043,2110, -2044,2110,2043, -2110,2044,2111, -2045,2111,2044, -2112,2046,2113, -2047,2113,2046, -2113,2047,2114, -2048,2114,2047, -2114,2048,2115, -2049,2115,2048, -2115,2049,2116, -2050,2116,2049, -2116,2050,2117, -2051,2117,2050, -2117,2051,2118, -2052,2118,2051, -2118,2052,2119, -2053,2119,2052, -2119,2053,2120, -2054,2120,2053, -2120,2054,2121, -2055,2121,2054, -2121,2055,2122, -2056,2122,2055, -2122,2056,2123, -2057,2123,2056, -2123,2057,2124, -2058,2124,2057, -2124,2058,2125, -2059,2125,2058, -2125,2059,2126, -2060,2126,2059, -2126,2060,2127, -2061,2127,2060, -2127,2061,2128, -2062,2128,2061, -2128,2062,2129, -2063,2129,2062, -2129,2063,2130, -2064,2130,2063, -2130,2064,2131, -2065,2131,2064, -2131,2065,2132, -2066,2132,2065, -2132,2066,2133, -2067,2133,2066, -2133,2067,2134, -2068,2134,2067, -2134,2068,2135, -2069,2135,2068, -2135,2069,2136, -2070,2136,2069, -2136,2070,2137, -2071,2137,2070, -2137,2071,2138, -2072,2138,2071, -2138,2072,2139, -2073,2139,2072, -2139,2073,2140, -2074,2140,2073, -2140,2074,2141, -2075,2141,2074, -2141,2075,2142, -2076,2142,2075, -2142,2076,2143, -2077,2143,2076, -2143,2077,2144, -2078,2144,2077, -2144,2078,2145, -2079,2145,2078, -2145,2079,2146, -2080,2146,2079, -2146,2080,2147, -2081,2147,2080, -2147,2081,2148, -2082,2148,2081, -2148,2082,2149, -2083,2149,2082, -2149,2083,2150, -2084,2150,2083, -2150,2084,2151, -2085,2151,2084, -2151,2085,2152, -2086,2152,2085, -2152,2086,2153, -2087,2153,2086, -2153,2087,2154, -2088,2154,2087, -2154,2088,2155, -2089,2155,2088, -2155,2089,2156, -2090,2156,2089, -2156,2090,2157, -2091,2157,2090, -2157,2091,2158, -2092,2158,2091, -2158,2092,2159, -2093,2159,2092, -2159,2093,2160, -2094,2160,2093, -2160,2094,2161, -2095,2161,2094, -2161,2095,2162, -2096,2162,2095, -2162,2096,2163, -2097,2163,2096, -2163,2097,2164, -2098,2164,2097, -2164,2098,2165, -2099,2165,2098, -2165,2099,2166, -2100,2166,2099, -2166,2100,2167, -2101,2167,2100, -2167,2101,2168, -2102,2168,2101, -2168,2102,2169, -2103,2169,2102, -2169,2103,2170, -2104,2170,2103, -2170,2104,2171, -2105,2171,2104, -2171,2105,2172, -2106,2172,2105, -2172,2106,2173, -2107,2173,2106, -2173,2107,2174, -2108,2174,2107, -2174,2108,2175, -2109,2175,2108, -2175,2109,2176, -2110,2176,2109, -2176,2110,2177, -2111,2177,2110, -}; - -#define Landscape01VtxCount 2048 -#define Landscape01IdxCount 11718 - -btScalar Landscape01Vtx[] = { -3.90626f,0.452911f,246.094f, -3.90626f,1.52302f,250.0f, -7.8125f,1.18238f,246.094f, -7.81251f,1.7549f,250.0f, -11.7188f,2.12911f,246.094f, -11.7188f,2.62454f,250.0f, -15.625f,3.01456f,246.094f, -15.625f,3.22814f,250.0f, -19.5313f,3.97431f,246.094f, -19.5313f,3.63231f,250.0f, -23.4375f,4.08741f,246.094f, -23.4375f,4.24097f,250.0f, -27.3438f,5.8163f,246.094f, -27.3438f,5.93409f,250.0f, -31.25f,6.86809f,246.094f, -31.25f,7.34105f,250.0f, -35.1563f,8.25405f,246.094f, -35.1563f,8.62507f,250.0f, -39.0625f,8.38601f,246.094f, -39.0625f,8.68483f,250.0f, -42.9688f,6.94797f,246.094f, -42.9688f,7.71847f,250.0f, -46.875f,4.60698f,246.094f, -46.875f,6.12159f,250.0f, -50.7813f,3.6429f,246.094f, -50.7813f,5.13002f,250.0f, -54.6875f,4.01945f,246.094f, -54.6875f,5.50476f,250.0f, -58.5938f,4.05996f,246.094f, -58.5938f,5.31917f,250.0f, -62.5f,3.98995f,246.094f, -62.5f,5.51823f,250.0f, -66.4063f,5.44402f,246.094f, -66.4063f,6.80029f,250.0f, -70.3125f,6.03873f,246.094f, -70.3125f,7.41783f,250.0f, -74.2188f,6.37187f,246.094f, -74.2188f,8.16051f,250.0f, -78.125f,6.74414f,246.094f, -78.125f,8.72099f,250.0f, -82.0313f,7.37958f,246.094f, -82.0313f,10.1125f,250.0f, -85.9375f,8.97782f,246.094f, -85.9375f,10.4624f,250.0f, -89.8438f,11.0829f,246.094f, -89.8438f,11.6403f,250.0f, -93.75f,12.3286f,246.094f, -93.75f,13.1378f,250.0f, -97.6563f,13.5966f,246.094f, -97.6563f,14.2949f,250.0f, -101.563f,15.5602f,246.094f, -101.563f,16.9487f,250.0f, -105.469f,16.9944f,246.094f, -105.469f,18.1946f,250.0f, -109.375f,17.886f,246.094f, -109.375f,19.5101f,250.0f, -113.281f,18.9289f,246.094f, -113.281f,20.9286f,250.0f, -117.188f,18.9873f,246.094f, -117.188f,20.0636f,250.0f, -121.094f,18.4954f,246.094f, -121.094f,20.5657f,250.0f, -125.0f,20.1484f,246.094f, -125.0f,21.1466f,250.0f, -128.906f,20.5032f,246.094f, -128.906f,22.3026f,250.0f, -132.813f,21.212f,246.094f, -132.813f,22.9139f,250.0f, -136.719f,22.289f,246.094f, -136.719f,24.4671f,250.0f, -140.625f,23.2441f,246.094f, -140.625f,24.3276f,250.0f, -144.531f,22.4971f,246.094f, -144.531f,24.3128f,250.0f, -148.438f,22.6347f,246.094f, -148.438f,23.8291f,250.0f, -152.344f,23.5767f,246.094f, -152.344f,24.1369f,250.0f, -156.25f,25.193f,246.094f, -156.25f,24.9132f,250.0f, -160.156f,25.2521f,246.094f, -160.156f,24.7251f,250.0f, -164.063f,25.7424f,246.094f, -164.063f,24.1169f,250.0f, -167.969f,24.3269f,246.094f, -167.969f,24.6092f,250.0f, -171.875f,25.0479f,246.094f, -171.875f,24.967f,250.0f, -175.781f,25.0107f,246.094f, -175.781f,24.7879f,250.0f, -179.688f,23.583f,246.094f, -179.688f,22.6841f,250.0f, -183.594f,20.958f,246.094f, -183.594f,20.6584f,250.0f, -187.5f,19.7535f,246.094f, -187.5f,20.0313f,250.0f, -191.406f,20.4707f,246.094f, -191.406f,20.3896f,250.0f, -195.313f,19.7551f,246.094f, -195.313f,21.5643f,250.0f, -199.219f,19.698f,246.094f, -199.219f,21.5733f,250.0f, -203.125f,20.0732f,246.094f, -203.125f,20.38f,250.0f, -207.031f,19.8667f,246.094f, -207.031f,19.3779f,250.0f, -210.938f,19.4501f,246.094f, -210.938f,19.5994f,250.0f, -214.844f,19.2918f,246.094f, -214.844f,19.0966f,250.0f, -218.75f,18.7652f,246.094f, -218.75f,19.9256f,250.0f, -222.656f,18.8129f,246.094f, -222.656f,19.8704f,250.0f, -226.563f,18.3547f,246.094f, -226.563f,18.8671f,250.0f, -230.469f,16.9801f,246.094f, -230.469f,17.4931f,250.0f, -234.375f,15.6173f,246.094f, -234.375f,16.1699f,250.0f, -238.281f,15.549f,246.094f, -238.281f,15.3704f,250.0f, -242.188f,15.2468f,246.094f, -242.188f,15.0306f,250.0f, -246.094f,14.1325f,246.094f, -246.094f,14.2622f,250.0f, -250.0f,14.4063f,246.094f, -250.0f,14.3657f,250.0f, -3.90626f,2.21488f,242.188f, -7.81252f,2.28606f,242.188f, -11.7188f,3.88428f,242.188f, -15.625f,3.39117f,242.188f, -19.5313f,3.64824f,242.188f, -23.4375f,4.14072f,242.188f, -27.3438f,5.74104f,242.188f, -31.25f,6.66142f,242.188f, -35.1563f,7.31371f,242.188f, -39.0625f,7.68371f,242.188f, -42.9688f,6.99041f,242.188f, -46.875f,4.89778f,242.188f, -50.7813f,2.64913f,242.188f, -54.6875f,2.76175f,242.188f, -58.5938f,3.10499f,242.188f, -62.5f,4.61915f,242.188f, -66.4063f,5.36769f,242.188f, -70.3125f,5.41759f,242.188f, -74.2188f,5.42279f,242.188f, -78.125f,5.53934f,242.188f, -82.0313f,5.38421f,242.188f, -85.9375f,7.77227f,242.188f, -89.8438f,9.40622f,242.188f, -93.75f,11.2904f,242.188f, -97.6563f,12.0748f,242.188f, -101.563f,14.1058f,242.188f, -105.469f,15.1513f,242.188f, -109.375f,15.9477f,242.188f, -113.281f,16.843f,242.188f, -117.188f,17.2117f,242.188f, -121.094f,18.2641f,242.188f, -125.0f,18.8672f,242.188f, -128.906f,19.3239f,242.188f, -132.813f,20.1067f,242.188f, -136.719f,20.8307f,242.188f, -140.625f,21.3646f,242.188f, -144.531f,21.6047f,242.188f, -148.438f,22.2456f,242.188f, -152.344f,23.5103f,242.188f, -156.25f,24.8533f,242.188f, -160.156f,25.4504f,242.188f, -164.063f,25.9357f,242.188f, -167.969f,24.8535f,242.188f, -171.875f,25.3099f,242.188f, -175.781f,25.3494f,242.188f, -179.688f,24.2229f,242.188f, -183.594f,21.0829f,242.188f, -187.5f,19.574f,242.188f, -191.406f,19.9835f,242.188f, -195.313f,19.6061f,242.188f, -199.219f,18.9509f,242.188f, -203.125f,20.1818f,242.188f, -207.031f,19.2962f,242.188f, -210.938f,18.8908f,242.188f, -214.844f,18.7996f,242.188f, -218.75f,18.7982f,242.188f, -222.656f,18.3283f,242.188f, -226.563f,17.7287f,242.188f, -230.469f,15.6882f,242.188f, -234.375f,15.2468f,242.188f, -238.281f,15.2703f,242.188f, -242.188f,14.4812f,242.188f, -246.094f,14.5597f,242.188f, -250.0f,14.178f,242.188f, -3.90626f,3.04396f,238.281f, -7.81252f,3.88428f,238.281f, -11.7188f,4.51367f,238.281f, -15.625f,4.1993f,238.281f, -19.5313f,4.48585f,238.281f, -23.4375f,5.11452f,238.281f, -27.3438f,4.98441f,238.281f, -31.25f,5.77536f,238.281f, -35.1563f,5.42743f,238.281f, -39.0625f,6.4581f,238.281f, -42.9688f,5.55272f,238.281f, -46.875f,3.69555f,238.281f, -50.7813f,3.08321f,238.281f, -54.6875f,2.96664f,238.281f, -58.5938f,3.94595f,238.281f, -62.5f,4.71605f,238.281f, -66.4063f,5.07906f,238.281f, -70.3125f,5.39291f,238.281f, -74.2188f,4.29289f,238.281f, -78.125f,4.20855f,238.281f, -82.0313f,5.10829f,238.281f, -85.9375f,5.48654f,238.281f, -89.8438f,7.06082f,238.281f, -93.75f,8.6827f,238.281f, -97.6563f,9.99779f,238.281f, -101.563f,11.9757f,238.281f, -105.469f,12.9031f,238.281f, -109.375f,13.7947f,238.281f, -113.281f,13.6154f,238.281f, -117.188f,15.9897f,238.281f, -121.094f,18.0884f,238.281f, -125.0f,18.714f,238.281f, -128.906f,19.1457f,238.281f, -132.813f,20.0791f,238.281f, -136.719f,20.3929f,238.281f, -140.625f,20.8277f,238.281f, -144.531f,21.2111f,238.281f, -148.438f,22.5091f,238.281f, -152.344f,23.9188f,238.281f, -156.25f,25.0278f,238.281f, -160.156f,25.8335f,238.281f, -164.063f,25.6558f,238.281f, -167.969f,24.3663f,238.281f, -171.875f,30.6775f,238.281f, -175.781f,30.89f,238.281f, -179.688f,29.2543f,238.281f, -183.594f,26.6241f,238.281f, -187.5f,24.7124f,238.281f, -191.406f,23.7048f,238.281f, -195.313f,23.3839f,238.281f, -199.219f,23.312f,238.281f, -203.125f,17.5221f,238.281f, -207.031f,17.418f,238.281f, -210.938f,17.5259f,238.281f, -214.844f,18.2392f,238.281f, -218.75f,18.6793f,238.281f, -222.656f,18.3701f,238.281f, -226.563f,17.2487f,238.281f, -230.469f,16.4f,238.281f, -234.375f,15.4998f,238.281f, -238.281f,14.6207f,238.281f, -242.188f,14.3055f,238.281f, -246.094f,14.2255f,238.281f, -250.0f,14.1326f,238.281f, -3.90626f,5.19166f,234.375f, -7.81252f,4.93292f,234.375f, -11.7188f,4.03413f,234.375f, -15.625f,3.70957f,234.375f, -19.5313f,4.44484f,234.375f, -23.4375f,5.12277f,234.375f, -27.3438f,4.60029f,234.375f, -31.25f,4.55048f,234.375f, -35.1563f,4.78512f,234.375f, -39.0625f,4.94627f,234.375f, -42.9688f,5.03351f,234.375f, -46.875f,3.08166f,234.375f, -50.7813f,2.57752f,234.375f, -54.6875f,3.08533f,234.375f, -58.5938f,4.0254f,234.375f, -62.5f,4.57575f,234.375f, -66.4063f,4.67125f,234.375f, -70.3125f,4.5612f,234.375f, -74.2188f,4.232f,234.375f, -78.125f,4.1571f,234.375f, -82.0313f,4.20157f,234.375f, -85.9375f,4.29102f,234.375f, -89.8438f,5.54826f,234.375f, -93.75f,7.06094f,234.375f, -97.6563f,8.27366f,234.375f, -101.563f,9.83852f,234.375f, -105.469f,10.9262f,234.375f, -109.375f,11.7812f,234.375f, -113.281f,13.8453f,234.375f, -117.188f,15.5538f,234.375f, -121.094f,16.8977f,234.375f, -125.0f,18.2996f,234.375f, -128.906f,19.6512f,234.375f, -132.813f,19.411f,234.375f, -136.719f,19.3317f,234.375f, -140.625f,20.656f,234.375f, -144.531f,21.6048f,234.375f, -148.438f,22.2246f,234.375f, -152.344f,23.6649f,234.375f, -156.25f,24.8772f,234.375f, -160.156f,27.6423f,234.375f, -164.063f,29.4442f,234.375f, -167.969f,29.6691f,234.375f, -171.875f,30.0772f,234.375f, -175.781f,30.3189f,234.375f, -179.688f,28.7319f,234.375f, -183.594f,26.6952f,234.375f, -187.5f,25.3375f,234.375f, -191.406f,24.1666f,234.375f, -195.313f,22.5458f,234.375f, -199.219f,22.2182f,234.375f, -203.125f,22.2413f,234.375f, -207.031f,21.8533f,234.375f, -210.938f,17.4596f,234.375f, -214.844f,17.2677f,234.375f, -218.75f,16.9584f,234.375f, -222.656f,16.6188f,234.375f, -226.563f,17.4388f,234.375f, -230.469f,16.936f,234.375f, -234.375f,15.6181f,234.375f, -238.281f,15.8373f,234.375f, -242.188f,15.0881f,234.375f, -246.094f,14.2247f,234.375f, -250.0f,14.111f,234.375f, -3.90626f,5.885f,230.469f, -7.81251f,5.4786f,230.469f, -11.7188f,5.0584f,230.469f, -15.625f,4.10283f,230.469f, -19.5313f,4.10569f,230.469f, -23.4375f,4.42202f,230.469f, -27.3438f,4.27849f,230.469f, -31.25f,4.25612f,230.469f, -35.1563f,3.83542f,230.469f, -39.0625f,3.37515f,230.469f, -42.9688f,4.16288f,230.469f, -46.875f,2.84197f,230.469f, -50.7813f,2.83467f,230.469f, -54.6875f,3.07874f,230.469f, -58.5938f,3.37745f,230.469f, -62.5f,4.09612f,230.469f, -66.4063f,4.65777f,230.469f, -70.3125f,4.45712f,230.469f, -74.2188f,3.89296f,230.469f, -78.125f,3.87471f,230.469f, -82.0313f,4.64568f,230.469f, -85.9375f,5.82987f,230.469f, -89.8438f,6.40084f,230.469f, -93.75f,7.65914f,230.469f, -97.6563f,8.07052f,230.469f, -101.563f,9.86632f,230.469f, -105.469f,11.8636f,230.469f, -109.375f,12.9547f,230.469f, -113.281f,14.2745f,230.469f, -117.188f,15.6876f,230.469f, -121.094f,17.2089f,230.469f, -125.0f,18.1267f,230.469f, -128.906f,19.379f,230.469f, -132.813f,19.2097f,230.469f, -136.719f,18.9335f,230.469f, -140.625f,19.9763f,230.469f, -144.531f,21.5401f,230.469f, -148.438f,21.7302f,230.469f, -152.344f,23.0108f,230.469f, -156.25f,28.7387f,230.469f, -160.156f,28.4179f,230.469f, -164.063f,28.6483f,230.469f, -167.969f,29.5567f,230.469f, -171.875f,29.589f,230.469f, -175.781f,29.7943f,230.469f, -179.688f,28.0587f,230.469f, -183.594f,27.6387f,230.469f, -187.5f,26.92f,230.469f, -191.406f,25.7995f,230.469f, -195.313f,23.8573f,230.469f, -199.219f,22.1543f,230.469f, -203.125f,21.8606f,230.469f, -207.031f,21.7644f,230.469f, -210.938f,22.284f,230.469f, -214.844f,22.465f,230.469f, -218.75f,16.4018f,230.469f, -222.656f,16.1053f,230.469f, -226.563f,16.9553f,230.469f, -230.469f,16.9851f,230.469f, -234.375f,16.0967f,230.469f, -238.281f,15.9758f,230.469f, -242.188f,15.3258f,230.469f, -246.094f,15.2909f,230.469f, -250.0f,14.7208f,230.469f, -3.90626f,6.89682f,226.563f, -7.81251f,6.58742f,226.563f, -11.7188f,6.03516f,226.563f, -15.625f,4.72243f,226.563f, -19.5313f,3.6445f,226.563f, -23.4375f,4.35761f,226.563f, -27.3438f,4.11714f,226.563f, -31.25f,4.31125f,226.563f, -35.1563f,3.42415f,226.563f, -39.0625f,2.29216f,226.563f, -42.9688f,2.47915f,226.563f, -46.875f,2.26767f,226.563f, -50.7813f,1.11914f,226.563f, -54.6875f,2.43266f,226.563f, -58.5938f,3.88718f,226.563f, -62.5f,3.9963f,226.563f, -66.4063f,4.30547f,226.563f, -70.3125f,4.43739f,226.563f, -74.2188f,3.89069f,226.563f, -78.125f,4.12082f,226.563f, -82.0313f,5.53252f,226.563f, -85.9375f,6.38493f,226.563f, -89.8438f,6.79959f,226.563f, -93.75f,8.29598f,226.563f, -97.6563f,8.48723f,226.563f, -101.563f,9.93554f,226.563f, -105.469f,11.5657f,226.563f, -109.375f,13.0486f,226.563f, -113.281f,13.8621f,226.563f, -117.188f,14.9688f,226.563f, -121.094f,16.3799f,226.563f, -125.0f,17.1973f,226.563f, -128.906f,17.376f,226.563f, -132.813f,18.1073f,226.563f, -136.719f,18.6844f,226.563f, -140.625f,18.5161f,226.563f, -144.531f,20.7617f,226.563f, -148.438f,21.0578f,226.563f, -152.344f,26.44f,226.563f, -156.25f,27.1807f,226.563f, -160.156f,27.2962f,226.563f, -164.063f,28.0507f,226.563f, -167.969f,28.6572f,226.563f, -171.875f,28.3487f,226.563f, -175.781f,23.7294f,226.563f, -179.688f,23.1113f,226.563f, -183.594f,22.5708f,226.563f, -187.5f,22.6165f,226.563f, -191.406f,21.8697f,226.563f, -195.313f,19.9841f,226.563f, -199.219f,22.9835f,226.563f, -203.125f,22.0743f,226.563f, -207.031f,22.4886f,226.563f, -210.938f,22.2516f,226.563f, -214.844f,22.3739f,226.563f, -218.75f,22.7815f,226.563f, -222.656f,17.0366f,226.563f, -226.563f,16.1334f,226.563f, -230.469f,16.9265f,226.563f, -234.375f,17.1793f,226.563f, -238.281f,17.3365f,226.563f, -242.188f,16.1971f,226.563f, -246.094f,15.2775f,226.563f, -250.0f,15.1313f,226.563f, -3.90626f,6.81349f,222.656f, -7.81251f,7.23848f,222.656f, -11.7188f,6.09864f,222.656f, -15.625f,4.9545f,222.656f, -19.5313f,3.88133f,222.656f, -23.4375f,4.06964f,222.656f, -27.3438f,3.90589f,222.656f, -31.25f,4.08304f,222.656f, -35.1563f,3.26204f,222.656f, -39.0625f,1.53457f,222.656f, -42.9688f,1.90835f,222.656f, -46.875f,1.98509f,222.656f, -50.7813f,2.14652f,222.656f, -54.6875f,2.7418f,222.656f, -58.5938f,3.74695f,222.656f, -62.5f,4.00354f,222.656f, -66.4063f,4.38792f,222.656f, -70.3125f,3.93121f,222.656f, -74.2188f,3.42647f,222.656f, -78.125f,5.0562f,222.656f, -82.0313f,5.98572f,222.656f, -85.9375f,6.52919f,222.656f, -89.8438f,6.83394f,222.656f, -93.75f,7.48974f,222.656f, -97.6563f,8.19267f,222.656f, -101.563f,9.33438f,222.656f, -105.469f,11.8423f,222.656f, -109.375f,13.1158f,222.656f, -113.281f,13.8944f,222.656f, -117.188f,14.8014f,222.656f, -121.094f,15.4129f,222.656f, -125.0f,15.6942f,222.656f, -128.906f,16.2049f,222.656f, -132.813f,17.0318f,222.656f, -136.719f,18.5423f,222.656f, -140.625f,18.8685f,222.656f, -144.531f,19.4529f,222.656f, -148.438f,25.9153f,222.656f, -152.344f,25.6773f,222.656f, -156.25f,26.0432f,222.656f, -160.156f,26.3016f,222.656f, -164.063f,27.084f,222.656f, -167.969f,27.1073f,222.656f, -171.875f,22.7536f,222.656f, -175.781f,23.3785f,222.656f, -179.688f,23.0862f,222.656f, -183.594f,22.5993f,222.656f, -187.5f,22.0197f,222.656f, -191.406f,21.8352f,222.656f, -195.313f,20.0501f,222.656f, -199.219f,18.5797f,222.656f, -203.125f,18.2905f,222.656f, -207.031f,22.7876f,222.656f, -210.938f,21.9787f,222.656f, -214.844f,21.4782f,222.656f, -218.75f,21.5786f,222.656f, -222.656f,21.6231f,222.656f, -226.563f,17.8058f,222.656f, -230.469f,17.6169f,222.656f, -234.375f,18.3242f,222.656f, -238.281f,18.4847f,222.656f, -242.188f,17.3189f,222.656f, -246.094f,16.7726f,222.656f, -250.0f,16.587f,222.656f, -3.90627f,8.02546f,218.75f, -7.81251f,8.24803f,218.75f, -11.7188f,6.92174f,218.75f, -15.625f,5.86085f,218.75f, -19.5313f,4.56603f,218.75f, -23.4375f,3.6909f,218.75f, -27.3438f,4.26522f,218.75f, -31.25f,3.37783f,218.75f, -35.1563f,1.72339f,218.75f, -39.0625f,2.22205f,218.75f, -42.9688f,2.71848f,218.75f, -46.875f,3.1467f,218.75f, -50.7813f,3.05327f,218.75f, -54.6875f,3.19537f,218.75f, -58.5938f,3.68243f,218.75f, -62.5f,3.35279f,218.75f, -66.4063f,4.00402f,218.75f, -70.3125f,2.9244f,218.75f, -74.2188f,4.39027f,218.75f, -78.125f,5.55878f,218.75f, -82.0313f,6.38772f,218.75f, -85.9375f,6.34964f,218.75f, -89.8438f,6.80441f,218.75f, -93.75f,6.5829f,218.75f, -97.6563f,7.27657f,218.75f, -101.563f,9.67388f,218.75f, -105.469f,10.833f,218.75f, -109.375f,12.1666f,218.75f, -113.281f,13.2095f,218.75f, -117.188f,14.2491f,218.75f, -121.094f,14.6953f,218.75f, -125.0f,14.2707f,218.75f, -128.906f,15.9556f,218.75f, -132.813f,16.7068f,218.75f, -136.719f,17.6679f,218.75f, -140.625f,18.8257f,218.75f, -144.531f,24.2255f,218.75f, -148.438f,25.0749f,218.75f, -152.344f,25.9271f,218.75f, -156.25f,26.2032f,218.75f, -160.156f,24.5168f,218.75f, -164.063f,26.2403f,218.75f, -167.969f,26.6223f,218.75f, -171.875f,22.4271f,218.75f, -175.781f,23.7925f,218.75f, -179.688f,23.3478f,218.75f, -183.594f,22.2279f,218.75f, -187.5f,22.2148f,218.75f, -191.406f,20.7538f,218.75f, -195.313f,19.5131f,218.75f, -199.219f,19.4834f,218.75f, -203.125f,18.3756f,218.75f, -207.031f,18.1034f,218.75f, -210.938f,20.0003f,218.75f, -214.844f,22.2111f,218.75f, -218.75f,21.6123f,218.75f, -222.656f,22.5943f,218.75f, -226.563f,24.3115f,218.75f, -230.469f,19.0536f,218.75f, -234.375f,18.6613f,218.75f, -238.281f,18.7675f,218.75f, -242.188f,18.3163f,218.75f, -246.094f,16.7013f,218.75f, -250.0f,17.0786f,218.75f, -3.90627f,9.25513f,214.844f, -7.81251f,9.67426f,214.844f, -11.7188f,8.92139f,214.844f, -15.625f,6.90738f,214.844f, -19.5313f,6.12616f,214.844f, -23.4375f,4.98302f,214.844f, -27.3438f,3.63786f,214.844f, -31.25f,2.52097f,214.844f, -35.1563f,3.30816f,214.844f, -39.0625f,4.04406f,214.844f, -42.9688f,4.48446f,214.844f, -46.875f,4.40695f,214.844f, -50.7813f,3.7693f,214.844f, -54.6875f,2.85523f,214.844f, -58.5938f,2.56849f,214.844f, -62.5f,2.56561f,214.844f, -66.4063f,2.82937f,214.844f, -70.3125f,2.75221f,214.844f, -74.2188f,5.02974f,214.844f, -78.125f,5.7988f,214.844f, -82.0313f,6.03219f,214.844f, -85.9375f,6.27423f,214.844f, -89.8438f,6.1671f,214.844f, -93.75f,6.86893f,214.844f, -97.6563f,7.94747f,214.844f, -101.563f,9.13548f,214.844f, -105.469f,9.63636f,214.844f, -109.375f,10.3351f,214.844f, -113.281f,12.4028f,214.844f, -117.188f,13.0321f,214.844f, -121.094f,13.6284f,214.844f, -125.0f,14.3167f,214.844f, -128.906f,15.0573f,214.844f, -132.813f,16.2022f,214.844f, -136.719f,17.7526f,214.844f, -140.625f,23.7093f,214.844f, -144.531f,24.3603f,214.844f, -148.438f,24.9195f,214.844f, -152.344f,25.198f,214.844f, -156.25f,20.8225f,214.844f, -160.156f,24.5918f,214.844f, -164.063f,25.1404f,214.844f, -167.969f,26.0659f,214.844f, -171.875f,22.1485f,214.844f, -175.781f,27.7236f,214.844f, -179.688f,27.4914f,214.844f, -183.594f,26.6606f,214.844f, -187.5f,26.623f,214.844f, -191.406f,26.3244f,214.844f, -195.313f,24.8535f,214.844f, -199.219f,23.6373f,214.844f, -203.125f,21.1881f,214.844f, -207.031f,19.7509f,214.844f, -210.938f,22.3046f,214.844f, -214.844f,22.5297f,214.844f, -218.75f,22.9498f,214.844f, -222.656f,23.2271f,214.844f, -226.563f,24.89f,214.844f, -230.469f,23.5226f,214.844f, -234.375f,19.0463f,214.844f, -238.281f,17.96f,214.844f, -242.188f,18.8106f,214.844f, -246.094f,17.3168f,214.844f, -250.0f,16.7955f,214.844f, -3.90627f,10.5728f,210.938f, -7.81251f,9.81018f,210.938f, -11.7188f,9.69715f,210.938f, -15.625f,8.42137f,210.938f, -19.5313f,7.09174f,210.938f, -23.4375f,6.45357f,210.938f, -27.3438f,4.58257f,210.938f, -31.25f,4.31044f,210.938f, -35.1563f,4.23584f,210.938f, -39.0625f,4.77527f,210.938f, -42.9688f,5.51217f,210.938f, -46.875f,5.48962f,210.938f, -50.7813f,4.50211f,210.938f, -54.6875f,4.06287f,210.938f, -58.5938f,3.43161f,210.938f, -62.5f,3.43195f,210.938f, -66.4063f,3.64204f,210.938f, -70.3125f,5.16151f,210.938f, -74.2188f,6.72853f,210.938f, -78.125f,7.43878f,210.938f, -82.0313f,7.30716f,210.938f, -85.9375f,6.54327f,210.938f, -89.8438f,5.96003f,210.938f, -93.75f,6.45099f,210.938f, -97.6563f,8.32748f,210.938f, -101.563f,8.85186f,210.938f, -105.469f,9.64058f,210.938f, -109.375f,10.4181f,210.938f, -113.281f,11.6911f,210.938f, -117.188f,12.0508f,210.938f, -121.094f,13.1004f,210.938f, -125.0f,14.4899f,210.938f, -128.906f,15.1295f,210.938f, -132.813f,15.6195f,210.938f, -136.719f,16.9219f,210.938f, -140.625f,23.4614f,210.938f, -144.531f,24.6763f,210.938f, -148.438f,26.12f,210.938f, -152.344f,21.7533f,210.938f, -156.25f,20.7448f,210.938f, -160.156f,24.1481f,210.938f, -164.063f,26.0464f,210.938f, -167.969f,25.1633f,210.938f, -171.875f,20.8056f,210.938f, -175.781f,26.3651f,210.938f, -179.688f,25.5322f,210.938f, -183.594f,26.3828f,210.938f, -187.5f,26.3586f,210.938f, -191.406f,26.1714f,210.938f, -195.313f,25.9695f,210.938f, -199.219f,24.3505f,210.938f, -203.125f,23.872f,210.938f, -207.031f,23.0401f,210.938f, -210.938f,22.3904f,210.938f, -214.844f,22.7647f,210.938f, -218.75f,23.266f,210.938f, -222.656f,23.8563f,210.938f, -226.563f,24.6635f,210.938f, -230.469f,24.3846f,210.938f, -234.375f,18.3213f,210.938f, -238.281f,17.6531f,210.938f, -242.188f,17.8854f,210.938f, -246.094f,17.1692f,210.938f, -250.0f,16.127f,210.938f, -3.90626f,10.4539f,207.031f, -7.81251f,10.0241f,207.031f, -11.7188f,10.3861f,207.031f, -15.625f,8.84417f,207.031f, -19.5313f,8.35477f,207.031f, -23.4375f,6.48112f,207.031f, -27.3438f,6.10753f,207.031f, -31.25f,6.13796f,207.031f, -35.1563f,6.51045f,207.031f, -39.0625f,6.65278f,207.031f, -42.9688f,6.27698f,207.031f, -46.875f,5.80577f,207.031f, -50.7813f,5.90354f,207.031f, -54.6875f,5.66137f,207.031f, -58.5938f,4.67472f,207.031f, -62.5f,4.81103f,207.031f, -66.4063f,6.06764f,207.031f, -70.3125f,7.61387f,207.031f, -74.2188f,8.72682f,207.031f, -78.125f,9.33231f,207.031f, -82.0313f,8.49751f,207.031f, -85.9375f,7.85293f,207.031f, -89.8438f,7.37573f,207.031f, -93.75f,7.4561f,207.031f, -97.6563f,7.76623f,207.031f, -101.563f,8.68264f,207.031f, -105.469f,10.4373f,207.031f, -109.375f,10.4722f,207.031f, -113.281f,11.4418f,207.031f, -117.188f,12.3081f,207.031f, -121.094f,12.9224f,207.031f, -125.0f,14.3204f,207.031f, -128.906f,15.1746f,207.031f, -132.813f,14.4847f,207.031f, -136.719f,20.974f,207.031f, -140.625f,23.4669f,207.031f, -144.531f,24.9918f,207.031f, -148.438f,25.7345f,207.031f, -152.344f,21.4943f,207.031f, -156.25f,22.169f,207.031f, -160.156f,24.9739f,207.031f, -164.063f,26.4423f,207.031f, -167.969f,25.8928f,207.031f, -171.875f,20.5408f,207.031f, -175.781f,24.2294f,207.031f, -179.688f,24.4008f,207.031f, -183.594f,25.2809f,207.031f, -187.5f,25.8589f,207.031f, -191.406f,26.3716f,207.031f, -195.313f,26.0525f,207.031f, -199.219f,24.6109f,207.031f, -203.125f,24.1128f,207.031f, -207.031f,23.4731f,207.031f, -210.938f,22.6487f,207.031f, -214.844f,22.7977f,207.031f, -218.75f,18.4754f,207.031f, -222.656f,23.1848f,207.031f, -226.563f,23.1818f,207.031f, -230.469f,22.9194f,207.031f, -234.375f,19.8052f,207.031f, -238.281f,16.8602f,207.031f, -242.188f,17.1047f,207.031f, -246.094f,16.1145f,207.031f, -250.0f,15.0049f,207.031f, -3.90626f,11.4706f,203.125f, -7.81251f,11.0922f,203.125f, -11.7188f,11.454f,203.125f, -15.625f,10.399f,203.125f, -19.5313f,8.89365f,203.125f, -23.4375f,7.52605f,203.125f, -27.3438f,7.07779f,203.125f, -31.25f,7.98082f,203.125f, -35.1563f,8.78342f,203.125f, -39.0625f,8.87165f,203.125f, -42.9688f,8.39122f,203.125f, -46.875f,7.48032f,203.125f, -50.7813f,6.77944f,203.125f, -54.6875f,7.14862f,203.125f, -58.5938f,6.46173f,203.125f, -62.5f,6.73824f,203.125f, -66.4063f,7.64505f,203.125f, -70.3125f,9.22763f,203.125f, -74.2188f,9.87781f,203.125f, -78.125f,10.1574f,203.125f, -82.0313f,9.81606f,203.125f, -85.9375f,9.8669f,203.125f, -89.8438f,10.0032f,203.125f, -93.75f,9.76597f,203.125f, -97.6563f,9.2129f,203.125f, -101.563f,8.89917f,203.125f, -105.469f,9.85112f,203.125f, -109.375f,11.4827f,203.125f, -113.281f,11.8911f,203.125f, -117.188f,12.3305f,203.125f, -121.094f,13.6098f,203.125f, -125.0f,14.1477f,203.125f, -128.906f,14.7928f,203.125f, -132.813f,16.3422f,203.125f, -136.719f,22.7583f,203.125f, -140.625f,24.5881f,203.125f, -144.531f,25.3565f,203.125f, -148.438f,21.7799f,203.125f, -152.344f,24.1222f,203.125f, -156.25f,26.6774f,203.125f, -160.156f,25.7031f,203.125f, -164.063f,26.9766f,203.125f, -167.969f,25.936f,203.125f, -171.875f,19.7727f,203.125f, -175.781f,19.3015f,203.125f, -179.688f,19.2421f,203.125f, -183.594f,24.8014f,203.125f, -187.5f,25.3041f,203.125f, -191.406f,25.3226f,203.125f, -195.313f,20.0369f,203.125f, -199.219f,19.4927f,203.125f, -203.125f,23.4349f,203.125f, -207.031f,22.748f,203.125f, -210.938f,22.4583f,203.125f, -214.844f,18.8936f,203.125f, -218.75f,17.4565f,203.125f, -222.656f,18.8235f,203.125f, -226.563f,21.4749f,203.125f, -230.469f,21.7691f,203.125f, -234.375f,21.1398f,203.125f, -238.281f,15.9012f,203.125f, -242.188f,15.9735f,203.125f, -246.094f,15.2287f,203.125f, -250.0f,13.5655f,203.125f, -3.90626f,12.1184f,199.219f, -7.81251f,12.3652f,199.219f, -11.7188f,12.1177f,199.219f, -15.625f,11.107f,199.219f, -19.5313f,9.91183f,199.219f, -23.4375f,8.6581f,199.219f, -27.3438f,7.98212f,199.219f, -31.25f,9.14995f,199.219f, -35.1563f,10.2879f,199.219f, -39.0625f,10.2569f,199.219f, -42.9688f,9.58908f,199.219f, -46.875f,8.1296f,199.219f, -50.7813f,7.81944f,199.219f, -54.6875f,8.54521f,199.219f, -58.5938f,8.14627f,199.219f, -62.5f,8.60974f,199.219f, -66.4063f,9.63518f,199.219f, -70.3125f,10.5321f,199.219f, -74.2188f,10.3348f,199.219f, -78.125f,11.2806f,199.219f, -82.0313f,11.3874f,199.219f, -85.9375f,11.6949f,199.219f, -89.8438f,12.3833f,199.219f, -93.75f,12.4654f,199.219f, -97.6563f,11.369f,199.219f, -101.563f,10.2737f,199.219f, -105.469f,10.4291f,199.219f, -109.375f,11.0962f,199.219f, -113.281f,12.1388f,199.219f, -117.188f,12.5535f,199.219f, -121.094f,13.2826f,199.219f, -125.0f,15.1899f,199.219f, -128.906f,16.3486f,199.219f, -132.813f,17.6147f,199.219f, -136.719f,23.878f,199.219f, -140.625f,24.5901f,199.219f, -144.531f,26.2181f,199.219f, -148.438f,21.847f,199.219f, -152.344f,26.5018f,199.219f, -156.25f,26.2772f,199.219f, -160.156f,26.4621f,199.219f, -164.063f,26.1902f,199.219f, -167.969f,26.1086f,199.219f, -171.875f,20.7414f,199.219f, -175.781f,20.393f,199.219f, -179.688f,19.7885f,199.219f, -183.594f,20.9687f,199.219f, -187.5f,23.8625f,199.219f, -191.406f,24.0825f,199.219f, -195.313f,19.4921f,199.219f, -199.219f,20.8763f,199.219f, -203.125f,21.987f,199.219f, -207.031f,21.9212f,199.219f, -210.938f,20.0341f,199.219f, -214.844f,15.7998f,199.219f, -218.75f,15.7759f,199.219f, -222.656f,15.8963f,199.219f, -226.563f,19.8168f,199.219f, -230.469f,19.9894f,199.219f, -234.375f,19.4382f,199.219f, -238.281f,14.2335f,199.219f, -242.188f,14.9225f,199.219f, -246.094f,13.5857f,199.219f, -250.0f,11.7225f,199.219f, -3.90626f,13.8013f,195.313f, -7.81251f,13.8046f,195.313f, -11.7188f,13.1462f,195.313f, -15.625f,12.2626f,195.313f, -19.5313f,10.67f,195.313f, -23.4375f,10.0372f,195.313f, -27.3438f,9.3255f,195.313f, -31.25f,10.5057f,195.313f, -35.1563f,11.0615f,195.313f, -39.0625f,11.2421f,195.313f, -42.9688f,10.4767f,195.313f, -46.875f,9.03042f,195.313f, -50.7813f,9.47397f,195.313f, -54.6875f,9.65703f,195.313f, -58.5938f,9.6345f,195.313f, -62.5f,9.9552f,195.313f, -66.4063f,10.8427f,195.313f, -70.3125f,11.7912f,195.313f, -74.2188f,11.5822f,195.313f, -78.125f,13.07f,195.313f, -82.0313f,13.803f,195.313f, -85.9375f,12.9764f,195.313f, -89.8438f,14.639f,195.313f, -93.75f,14.6139f,195.313f, -97.6563f,13.3162f,195.313f, -101.563f,12.7402f,195.313f, -105.469f,12.8061f,195.313f, -109.375f,12.1167f,195.313f, -113.281f,12.705f,195.313f, -117.188f,12.4568f,195.313f, -121.094f,13.5698f,195.313f, -125.0f,15.1843f,195.313f, -128.906f,16.7529f,195.313f, -132.813f,19.1744f,195.313f, -136.719f,23.9261f,195.313f, -140.625f,25.9824f,195.313f, -144.531f,26.1631f,195.313f, -148.438f,21.4735f,195.313f, -152.344f,25.5313f,195.313f, -156.25f,27.0098f,195.313f, -160.156f,27.5776f,195.313f, -164.063f,27.0858f,195.313f, -167.969f,26.3007f,195.313f, -171.875f,23.4599f,195.313f, -175.781f,26.4252f,195.313f, -179.688f,21.1453f,195.313f, -183.594f,21.1021f,195.313f, -187.5f,25.1644f,195.313f, -191.406f,24.8681f,195.313f, -195.313f,24.1757f,195.313f, -199.219f,20.0013f,195.313f, -203.125f,23.6085f,195.313f, -207.031f,22.7043f,195.313f, -210.938f,17.4097f,195.313f, -214.844f,16.8216f,195.313f, -218.75f,16.2595f,195.313f, -222.656f,15.547f,195.313f, -226.563f,20.5074f,195.313f, -230.469f,20.0296f,195.313f, -234.375f,19.4594f,195.313f, -238.281f,14.3376f,195.313f, -242.188f,13.8667f,195.313f, -246.094f,12.7786f,195.313f, -250.0f,12.669f,195.313f, -3.90626f,14.3936f,191.406f, -7.81251f,14.3324f,191.406f, -11.7188f,13.5165f,191.406f, -15.625f,12.3486f,191.406f, -19.5313f,10.8996f,191.406f, -23.4375f,10.767f,191.406f, -27.3438f,12.0663f,191.406f, -31.25f,12.0032f,191.406f, -35.1563f,12.6763f,191.406f, -39.0625f,12.4746f,191.406f, -42.9688f,10.9305f,191.406f, -46.875f,11.0794f,191.406f, -50.7813f,11.2588f,191.406f, -54.6875f,11.0855f,191.406f, -58.5938f,10.1448f,191.406f, -62.5f,11.1184f,191.406f, -66.4063f,12.2266f,191.406f, -70.3125f,12.3132f,191.406f, -74.2188f,13.6918f,191.406f, -78.125f,14.4314f,191.406f, -82.0313f,14.6924f,191.406f, -85.9375f,15.6669f,191.406f, -89.8438f,16.085f,191.406f, -93.75f,16.2697f,191.406f, -97.6563f,16.3584f,191.406f, -101.563f,15.6226f,191.406f, -105.469f,14.7096f,191.406f, -109.375f,14.172f,191.406f, -113.281f,13.6538f,191.406f, -117.188f,14.6791f,191.406f, -121.094f,15.1835f,191.406f, -125.0f,16.4947f,191.406f, -128.906f,17.5173f,191.406f, -132.813f,22.4657f,191.406f, -136.719f,25.2206f,191.406f, -140.625f,26.6814f,191.406f, -144.531f,27.4657f,191.406f, -148.438f,22.8092f,191.406f, -152.344f,22.336f,191.406f, -156.25f,29.0833f,191.406f, -160.156f,29.5204f,191.406f, -164.063f,29.4008f,191.406f, -167.969f,28.5038f,191.406f, -171.875f,27.7213f,191.406f, -175.781f,27.6884f,191.406f, -179.688f,25.8434f,191.406f, -183.594f,23.3048f,191.406f, -187.5f,27.635f,191.406f, -191.406f,26.1341f,191.406f, -195.313f,26.6792f,191.406f, -199.219f,22.747f,191.406f, -203.125f,22.8472f,191.406f, -207.031f,21.8628f,191.406f, -210.938f,20.5896f,191.406f, -214.844f,20.683f,191.406f, -218.75f,15.9904f,191.406f, -222.656f,16.3766f,191.406f, -226.563f,21.611f,191.406f, -230.469f,20.8727f,191.406f, -234.375f,20.2044f,191.406f, -238.281f,15.3358f,191.406f, -242.188f,14.7065f,191.406f, -246.094f,14.4372f,191.406f, -250.0f,14.1124f,191.406f, -3.90626f,14.1738f,187.5f, -7.81252f,14.5502f,187.5f, -11.7188f,13.6083f,187.5f, -15.625f,12.2654f,187.5f, -19.5313f,11.7405f,187.5f, -23.4375f,12.3756f,187.5f, -27.3438f,14.0775f,187.5f, -31.25f,13.9675f,187.5f, -35.1563f,14.3286f,187.5f, -39.0625f,13.1055f,187.5f, -42.9688f,13.0413f,187.5f, -46.875f,13.318f,187.5f, -50.7813f,12.9383f,187.5f, -54.6875f,12.9366f,187.5f, -58.5938f,12.1308f,187.5f, -62.5f,12.8501f,187.5f, -66.4063f,13.0312f,187.5f, -70.3125f,13.1657f,187.5f, -74.2188f,14.6177f,187.5f, -78.125f,16.1865f,187.5f, -82.0313f,16.3194f,187.5f, -85.9375f,16.9023f,187.5f, -89.8438f,17.5469f,187.5f, -93.75f,18.1166f,187.5f, -97.6563f,18.7398f,187.5f, -101.563f,18.2643f,187.5f, -105.469f,17.5115f,187.5f, -109.375f,16.8559f,187.5f, -113.281f,15.8332f,187.5f, -117.188f,16.4429f,187.5f, -121.094f,17.0698f,187.5f, -125.0f,18.0389f,187.5f, -128.906f,19.8697f,187.5f, -132.813f,24.8511f,187.5f, -136.719f,26.6838f,187.5f, -140.625f,28.5323f,187.5f, -144.531f,28.756f,187.5f, -148.438f,25.5762f,187.5f, -152.344f,25.8993f,187.5f, -156.25f,29.0469f,187.5f, -160.156f,32.1254f,187.5f, -164.063f,32.1318f,187.5f, -167.969f,31.7887f,187.5f, -171.875f,30.3727f,187.5f, -175.781f,30.1222f,187.5f, -179.688f,30.3556f,187.5f, -183.594f,30.49f,187.5f, -187.5f,29.3956f,187.5f, -191.406f,30.6569f,187.5f, -195.313f,30.8632f,187.5f, -199.219f,26.1118f,187.5f, -203.125f,25.5008f,187.5f, -207.031f,24.7878f,187.5f, -210.938f,27.5453f,187.5f, -214.844f,25.5271f,187.5f, -218.75f,20.2295f,187.5f, -222.656f,17.2785f,187.5f, -226.563f,22.0337f,187.5f, -230.469f,22.1938f,187.5f, -234.375f,21.6646f,187.5f, -238.281f,16.8654f,187.5f, -242.188f,15.704f,187.5f, -246.094f,15.9973f,187.5f, -250.0f,15.209f,187.5f, -3.90626f,13.9878f,183.594f, -7.81252f,14.3413f,183.594f, -11.7188f,13.1779f,183.594f, -15.625f,12.8538f,183.594f, -19.5313f,13.9436f,183.594f, -23.4375f,14.716f,183.594f, -27.3438f,14.991f,183.594f, -31.25f,15.4235f,183.594f, -35.1563f,15.3865f,183.594f, -39.0625f,14.2459f,183.594f, -42.9688f,15.2992f,183.594f, -46.875f,16.0599f,183.594f, -50.7813f,14.8603f,183.594f, -54.6875f,14.9726f,183.594f, -58.5938f,13.6053f,183.594f, -62.5f,13.057f,183.594f, -66.4063f,13.4201f,183.594f, -70.3125f,14.0782f,183.594f, -74.2188f,15.3178f,183.594f, -78.125f,16.3995f,183.594f, -82.0313f,17.4379f,183.594f, -85.9375f,17.9502f,183.594f, -89.8438f,18.4811f,183.594f, -93.75f,19.4227f,183.594f, -97.6563f,20.1694f,183.594f, -101.563f,20.1609f,183.594f, -105.469f,19.5537f,183.594f, -109.375f,19.039f,183.594f, -113.281f,18.2247f,183.594f, -117.188f,18.6643f,183.594f, -121.094f,19.2334f,183.594f, -125.0f,20.4158f,183.594f, -128.906f,21.1136f,183.594f, -132.813f,25.6638f,183.594f, -136.719f,27.4642f,183.594f, -140.625f,29.0749f,183.594f, -144.531f,30.6966f,183.594f, -148.438f,26.933f,183.594f, -152.344f,27.9984f,183.594f, -156.25f,28.4094f,183.594f, -160.156f,33.857f,183.594f, -164.063f,34.6528f,183.594f, -167.969f,33.405f,183.594f, -171.875f,31.8412f,183.594f, -175.781f,31.8788f,183.594f, -179.688f,32.395f,183.594f, -183.594f,32.8498f,183.594f, -187.5f,28.7385f,183.594f, -191.406f,33.6253f,183.594f, -195.313f,32.9673f,183.594f, -199.219f,31.8413f,183.594f, -203.125f,26.491f,183.594f, -207.031f,29.4589f,183.594f, -210.938f,28.7843f,183.594f, -214.844f,26.577f,183.594f, -218.75f,25.0304f,183.594f, -222.656f,18.7948f,183.594f, -226.563f,23.1467f,183.594f, -230.469f,22.3329f,183.594f, -234.375f,21.6877f,183.594f, -238.281f,16.4114f,183.594f, -242.188f,16.4672f,183.594f, -246.094f,16.3324f,183.594f, -250.0f,16.0497f,183.594f, -3.90626f,14.6785f,179.688f, -7.81252f,14.4582f,179.688f, -11.7188f,13.7379f,179.688f, -15.625f,13.9816f,179.688f, -19.5313f,14.9647f,179.688f, -23.4375f,15.3633f,179.688f, -27.3438f,16.1346f,179.688f, -31.25f,16.4088f,179.688f, -35.1563f,16.195f,179.688f, -39.0625f,16.1785f,179.688f, -42.9688f,17.2534f,179.688f, -46.875f,17.329f,179.688f, -50.7813f,16.0096f,179.688f, -54.6875f,15.4766f,179.688f, -58.5938f,14.0828f,179.688f, -62.5f,12.8927f,179.688f, -66.4063f,14.1195f,179.688f, -70.3125f,14.9421f,179.688f, -74.2188f,15.9015f,179.688f, -78.125f,17.3756f,179.688f, -82.0313f,18.6339f,179.688f, -85.9375f,19.7602f,179.688f, -89.8438f,19.8522f,179.688f, -93.75f,20.5838f,179.688f, -97.6563f,21.2938f,179.688f, -101.563f,21.1808f,179.688f, -105.469f,21.4575f,179.688f, -109.375f,21.1629f,179.688f, -113.281f,20.4789f,179.688f, -117.188f,20.5729f,179.688f, -121.094f,20.3917f,179.688f, -125.0f,21.8501f,179.688f, -128.906f,22.6846f,179.688f, -132.813f,23.4145f,179.688f, -136.719f,28.3033f,179.688f, -140.625f,30.5638f,179.688f, -144.531f,32.761f,179.688f, -148.438f,29.4434f,179.688f, -152.344f,30.346f,179.688f, -156.25f,31.7037f,179.688f, -160.156f,36.287f,179.688f, -164.063f,36.7423f,179.688f, -167.969f,35.7482f,179.688f, -171.875f,30.0008f,179.688f, -175.781f,29.6748f,179.688f, -179.688f,34.5316f,179.688f, -183.594f,34.4476f,179.688f, -187.5f,34.3489f,179.688f, -191.406f,33.4208f,179.688f, -195.313f,29.5511f,179.688f, -199.219f,28.9653f,179.688f, -203.125f,28.1749f,179.688f, -207.031f,30.5574f,179.688f, -210.938f,28.6513f,179.688f, -214.844f,27.1867f,179.688f, -218.75f,20.8455f,179.688f, -222.656f,20.3256f,179.688f, -226.563f,24.3717f,179.688f, -230.469f,23.2197f,179.688f, -234.375f,21.6566f,179.688f, -238.281f,16.2487f,179.688f, -242.188f,16.7759f,179.688f, -246.094f,16.5259f,179.688f, -250.0f,15.8782f,179.688f, -3.90626f,15.2963f,175.781f, -7.81252f,15.075f,175.781f, -11.7188f,14.8069f,175.781f, -15.625f,14.4469f,175.781f, -19.5313f,15.8073f,175.781f, -23.4375f,16.5419f,175.781f, -27.3438f,16.7791f,175.781f, -31.25f,17.1945f,175.781f, -35.1563f,16.9974f,175.781f, -39.0625f,16.9655f,175.781f, -42.9688f,17.7583f,175.781f, -46.875f,18.115f,175.781f, -50.7813f,16.6524f,175.781f, -54.6875f,15.897f,175.781f, -58.5938f,15.4613f,175.781f, -62.5f,14.3684f,175.781f, -66.4063f,15.0403f,175.781f, -70.3125f,15.9604f,175.781f, -74.2188f,16.9477f,175.781f, -78.125f,18.0563f,175.781f, -82.0313f,18.8971f,175.781f, -85.9375f,20.1037f,175.781f, -89.8438f,20.3627f,175.781f, -93.75f,20.0215f,175.781f, -97.6563f,20.8917f,175.781f, -101.563f,21.8702f,175.781f, -105.469f,22.7304f,175.781f, -109.375f,22.6873f,175.781f, -113.281f,21.4896f,175.781f, -117.188f,21.3864f,175.781f, -121.094f,22.4194f,175.781f, -125.0f,23.5751f,175.781f, -128.906f,23.9616f,175.781f, -132.813f,24.6066f,175.781f, -136.719f,30.8792f,175.781f, -140.625f,31.6572f,175.781f, -144.531f,34.2264f,175.781f, -148.438f,30.9611f,175.781f, -152.344f,35.8851f,175.781f, -156.25f,38.6379f,175.781f, -160.156f,39.1098f,175.781f, -164.063f,39.046f,175.781f, -167.969f,38.0327f,175.781f, -171.875f,36.6611f,175.781f, -175.781f,36.0664f,175.781f, -179.688f,36.1227f,175.781f, -183.594f,36.0705f,175.781f, -187.5f,35.9099f,175.781f, -191.406f,30.4106f,175.781f, -195.313f,30.0475f,175.781f, -199.219f,28.9213f,175.781f, -203.125f,32.8995f,175.781f, -207.031f,31.2376f,175.781f, -210.938f,30.0194f,175.781f, -214.844f,23.402f,175.781f, -218.75f,21.7271f,175.781f, -222.656f,20.0594f,175.781f, -226.563f,25.2266f,175.781f, -230.469f,24.1549f,175.781f, -234.375f,22.0418f,175.781f, -238.281f,15.6301f,175.781f, -242.188f,15.4767f,175.781f, -246.094f,15.8876f,175.781f, -250.0f,15.1339f,175.781f, -3.90626f,16.0791f,171.875f, -7.81251f,16.012f,171.875f, -11.7188f,15.027f,171.875f, -15.625f,15.1362f,171.875f, -19.5313f,16.3622f,171.875f, -23.4375f,16.7304f,171.875f, -27.3438f,17.228f,171.875f, -31.25f,16.4882f,171.875f, -35.1563f,16.5399f,171.875f, -39.0625f,17.5505f,171.875f, -42.9688f,17.6944f,171.875f, -46.875f,17.7481f,171.875f, -50.7813f,17.4568f,171.875f, -54.6875f,16.5655f,171.875f, -58.5938f,15.4313f,171.875f, -62.5f,14.962f,171.875f, -66.4063f,15.2516f,171.875f, -70.3125f,16.3088f,171.875f, -74.2188f,17.5354f,171.875f, -78.125f,18.5759f,171.875f, -82.0313f,19.1666f,171.875f, -85.9375f,19.8244f,171.875f, -89.8438f,20.6303f,171.875f, -93.75f,20.5635f,171.875f, -97.6563f,20.5768f,171.875f, -101.563f,21.542f,171.875f, -105.469f,22.5605f,171.875f, -109.375f,23.0118f,171.875f, -113.281f,22.6086f,171.875f, -117.188f,22.8502f,171.875f, -121.094f,23.2278f,171.875f, -125.0f,24.368f,171.875f, -128.906f,25.5759f,171.875f, -132.813f,27.7217f,171.875f, -136.719f,33.4581f,171.875f, -140.625f,33.4128f,171.875f, -144.531f,34.9465f,171.875f, -148.438f,31.4923f,171.875f, -152.344f,38.6707f,171.875f, -156.25f,40.2713f,171.875f, -160.156f,40.4155f,171.875f, -164.063f,41.0232f,171.875f, -167.969f,39.781f,171.875f, -171.875f,37.8376f,171.875f, -175.781f,38.0559f,171.875f, -179.688f,32.0147f,171.875f, -183.594f,35.2298f,171.875f, -187.5f,34.7221f,171.875f, -191.406f,31.5516f,171.875f, -195.313f,28.9984f,171.875f, -199.219f,29.8767f,171.875f, -203.125f,32.6404f,171.875f, -207.031f,31.3413f,171.875f, -210.938f,28.4132f,171.875f, -214.844f,22.9909f,171.875f, -218.75f,21.3955f,171.875f, -222.656f,25.3135f,171.875f, -226.563f,25.1463f,171.875f, -230.469f,23.4716f,171.875f, -234.375f,22.494f,171.875f, -238.281f,15.9351f,171.875f, -242.188f,15.2882f,171.875f, -246.094f,14.8463f,171.875f, -250.0f,14.5269f,171.875f, -3.90626f,17.1455f,167.969f, -7.81251f,16.6981f,167.969f, -11.7188f,16.5681f,167.969f, -15.625f,16.1667f,167.969f, -19.5313f,16.3523f,167.969f, -23.4375f,16.5389f,167.969f, -27.3438f,16.8075f,167.969f, -31.25f,17.1987f,167.969f, -35.1563f,17.86f,167.969f, -39.0625f,18.5438f,167.969f, -42.9688f,18.6718f,167.969f, -46.875f,17.9387f,167.969f, -50.7813f,17.5403f,167.969f, -54.6875f,17.4895f,167.969f, -58.5938f,16.9679f,167.969f, -62.5f,16.2192f,167.969f, -66.4063f,15.5699f,167.969f, -70.3125f,17.0017f,167.969f, -74.2188f,18.0147f,167.969f, -78.125f,18.9836f,167.969f, -82.0313f,19.8197f,167.969f, -85.9375f,19.8969f,167.969f, -89.8438f,20.6411f,167.969f, -93.75f,20.9768f,167.969f, -97.6563f,21.1498f,167.969f, -101.563f,21.3269f,167.969f, -105.469f,22.1153f,167.969f, -109.375f,22.208f,167.969f, -113.281f,23.2278f,167.969f, -117.188f,24.5722f,167.969f, -121.094f,25.3921f,167.969f, -125.0f,26.2683f,167.969f, -128.906f,28.138f,167.969f, -132.813f,29.9483f,167.969f, -136.719f,34.7607f,167.969f, -140.625f,35.3745f,167.969f, -144.531f,36.1401f,167.969f, -148.438f,38.0587f,167.969f, -152.344f,40.0092f,167.969f, -156.25f,40.9205f,167.969f, -160.156f,41.4664f,167.969f, -164.063f,41.8834f,167.969f, -167.969f,40.2863f,167.969f, -171.875f,38.4111f,167.969f, -175.781f,37.4971f,167.969f, -179.688f,32.0995f,167.969f, -183.594f,36.4852f,167.969f, -187.5f,34.5523f,167.969f, -191.406f,34.4101f,167.969f, -195.313f,29.577f,167.969f, -199.219f,33.7462f,167.969f, -203.125f,33.0191f,167.969f, -207.031f,31.6651f,167.969f, -210.938f,24.6623f,167.969f, -214.844f,22.6532f,167.969f, -218.75f,21.898f,167.969f, -222.656f,26.1764f,167.969f, -226.563f,24.7619f,167.969f, -230.469f,22.6772f,167.969f, -234.375f,17.6202f,167.969f, -238.281f,16.1581f,167.969f, -242.188f,14.7308f,167.969f, -246.094f,14.294f,167.969f, -250.0f,13.1169f,167.969f, -3.90627f,16.4621f,164.063f, -7.81251f,17.581f,164.063f, -11.7188f,17.7296f,164.063f, -15.625f,17.126f,164.063f, -19.5313f,17.3484f,164.063f, -23.4375f,17.9863f,164.063f, -27.3438f,18.6623f,164.063f, -31.25f,18.7934f,164.063f, -35.1563f,18.8245f,164.063f, -39.0625f,18.9554f,164.063f, -42.9688f,19.3152f,164.063f, -46.875f,18.5996f,164.063f, -50.7813f,18.0094f,164.063f, -54.6875f,17.5702f,164.063f, -58.5938f,17.5846f,164.063f, -62.5f,17.3718f,164.063f, -66.4063f,17.7189f,164.063f, -70.3125f,17.9805f,164.063f, -74.2188f,18.2986f,164.063f, -78.125f,18.9566f,164.063f, -82.0313f,20.4142f,164.063f, -85.9375f,20.5066f,164.063f, -89.8438f,20.7654f,164.063f, -93.75f,20.9457f,164.063f, -97.6563f,21.1078f,164.063f, -101.563f,20.7505f,164.063f, -105.469f,21.4615f,164.063f, -109.375f,22.8061f,164.063f, -113.281f,24.2655f,164.063f, -117.188f,24.815f,164.063f, -121.094f,26.3141f,164.063f, -125.0f,28.393f,164.063f, -128.906f,30.0565f,164.063f, -132.813f,31.4858f,164.063f, -136.719f,31.6549f,164.063f, -140.625f,37.0597f,164.063f, -144.531f,37.7613f,164.063f, -148.438f,38.9888f,164.063f, -152.344f,39.1482f,164.063f, -156.25f,36.6367f,164.063f, -160.156f,41.2606f,164.063f, -164.063f,42.2366f,164.063f, -167.969f,40.9757f,164.063f, -171.875f,33.9016f,164.063f, -175.781f,34.1798f,164.063f, -179.688f,33.0682f,164.063f, -183.594f,35.2269f,164.063f, -187.5f,35.1129f,164.063f, -191.406f,34.7006f,164.063f, -195.313f,30.1221f,164.063f, -199.219f,34.6592f,164.063f, -203.125f,33.6195f,164.063f, -207.031f,30.0546f,164.063f, -210.938f,24.8295f,164.063f, -214.844f,23.0298f,164.063f, -218.75f,26.5636f,164.063f, -222.656f,25.7973f,164.063f, -226.563f,23.7612f,164.063f, -230.469f,22.3646f,164.063f, -234.375f,16.1956f,164.063f, -238.281f,14.863f,164.063f, -242.188f,13.95f,164.063f, -246.094f,14.1968f,164.063f, -250.0f,13.2951f,164.063f, -3.90627f,16.628f,160.156f, -7.81251f,17.4268f,160.156f, -11.7188f,18.0363f,160.156f, -15.625f,18.1287f,160.156f, -19.5313f,18.6222f,160.156f, -23.4375f,18.2801f,160.156f, -27.3438f,18.5912f,160.156f, -31.25f,18.8635f,160.156f, -35.1563f,19.2193f,160.156f, -39.0625f,18.8821f,160.156f, -42.9688f,19.0078f,160.156f, -46.875f,19.3506f,160.156f, -50.7813f,17.8504f,160.156f, -54.6875f,18.5322f,160.156f, -58.5938f,18.2223f,160.156f, -62.5f,18.032f,160.156f, -66.4063f,18.574f,160.156f, -70.3125f,18.3835f,160.156f, -74.2188f,18.0842f,160.156f, -78.125f,19.8632f,160.156f, -82.0313f,20.9487f,160.156f, -85.9375f,20.6197f,160.156f, -89.8438f,20.5117f,160.156f, -93.75f,20.4182f,160.156f, -97.6563f,19.8654f,160.156f, -101.563f,20.1971f,160.156f, -105.469f,22.0419f,160.156f, -109.375f,23.4698f,160.156f, -113.281f,24.6461f,160.156f, -117.188f,26.2207f,160.156f, -121.094f,28.1249f,160.156f, -125.0f,29.8102f,160.156f, -128.906f,31.7349f,160.156f, -132.813f,32.4376f,160.156f, -136.719f,33.2795f,160.156f, -140.625f,37.4588f,160.156f, -144.531f,38.8195f,160.156f, -148.438f,39.9622f,160.156f, -152.344f,41.6752f,160.156f, -156.25f,37.6576f,160.156f, -160.156f,41.4722f,160.156f, -164.063f,41.8372f,160.156f, -167.969f,40.7289f,160.156f, -171.875f,35.5243f,160.156f, -175.781f,34.1726f,160.156f, -179.688f,33.9628f,160.156f, -183.594f,33.3012f,160.156f, -187.5f,37.6064f,160.156f, -191.406f,36.2987f,160.156f, -195.313f,32.9836f,160.156f, -199.219f,34.2771f,160.156f, -203.125f,33.5607f,160.156f, -207.031f,26.9351f,160.156f, -210.938f,24.3584f,160.156f, -214.844f,25.5428f,160.156f, -218.75f,26.0054f,160.156f, -222.656f,24.092f,160.156f, -226.563f,22.8948f,160.156f, -230.469f,17.1899f,160.156f, -234.375f,15.0552f,160.156f, -238.281f,14.2468f,160.156f, -242.188f,13.7862f,160.156f, -246.094f,14.5132f,160.156f, -250.0f,14.3684f,160.156f, -3.90627f,16.9346f,156.25f, -7.81251f,18.2437f,156.25f, -11.7188f,18.3869f,156.25f, -15.625f,18.1055f,156.25f, -19.5313f,18.7445f,156.25f, -23.4375f,18.9235f,156.25f, -27.3438f,18.455f,156.25f, -31.25f,18.6644f,156.25f, -35.1563f,18.9448f,156.25f, -39.0625f,18.9971f,156.25f, -42.9688f,18.8628f,156.25f, -46.875f,18.6886f,156.25f, -50.7813f,18.8494f,156.25f, -54.6875f,19.4408f,156.25f, -58.5938f,18.7384f,156.25f, -62.5f,17.473f,156.25f, -66.4063f,18.5906f,156.25f, -70.3125f,18.7252f,156.25f, -74.2188f,19.5013f,156.25f, -78.125f,19.8221f,156.25f, -82.0313f,19.8648f,156.25f, -85.9375f,19.8955f,156.25f, -89.8438f,19.4401f,156.25f, -93.75f,18.7973f,156.25f, -97.6563f,18.8923f,156.25f, -101.563f,20.6151f,156.25f, -105.469f,22.9824f,156.25f, -109.375f,25.2251f,156.25f, -113.281f,26.7829f,156.25f, -117.188f,27.8131f,156.25f, -121.094f,29.6707f,156.25f, -125.0f,31.4614f,156.25f, -128.906f,32.8387f,156.25f, -132.813f,33.7834f,156.25f, -136.719f,34.3986f,156.25f, -140.625f,35.1609f,156.25f, -144.531f,40.0963f,156.25f, -148.438f,41.0412f,156.25f, -152.344f,42.0325f,156.25f, -156.25f,42.1696f,156.25f, -160.156f,41.9265f,156.25f, -164.063f,43.279f,156.25f, -167.969f,42.5995f,156.25f, -171.875f,36.6937f,156.25f, -175.781f,34.8393f,156.25f, -179.688f,34.7157f,156.25f, -183.594f,34.0579f,156.25f, -187.5f,33.7647f,156.25f, -191.406f,33.2242f,156.25f, -195.313f,32.1053f,156.25f, -199.219f,30.6563f,156.25f, -203.125f,33.623f,156.25f, -207.031f,28.0199f,156.25f, -210.938f,30.5092f,156.25f, -214.844f,29.3828f,156.25f, -218.75f,27.3486f,156.25f, -222.656f,25.8671f,156.25f, -226.563f,24.1209f,156.25f, -230.469f,17.9979f,156.25f, -234.375f,16.1304f,156.25f, -238.281f,14.8281f,156.25f, -242.188f,13.097f,156.25f, -246.094f,13.3642f,156.25f, -250.0f,13.6085f,156.25f, -3.90627f,17.6952f,152.344f, -7.81251f,19.1063f,152.344f, -11.7188f,19.6398f,152.344f, -15.625f,19.8626f,152.344f, -19.5313f,19.1453f,152.344f, -23.4375f,19.4932f,152.344f, -27.3438f,19.3908f,152.344f, -31.25f,18.6492f,152.344f, -35.1563f,18.3861f,152.344f, -39.0625f,18.198f,152.344f, -42.9688f,18.4497f,152.344f, -46.875f,17.8083f,152.344f, -50.7813f,18.5296f,152.344f, -54.6875f,19.8096f,152.344f, -58.5938f,19.3324f,152.344f, -62.5f,18.1507f,152.344f, -66.4063f,17.7998f,152.344f, -70.3125f,17.9266f,152.344f, -74.2188f,18.569f,152.344f, -78.125f,19.5043f,152.344f, -82.0313f,20.0768f,152.344f, -85.9375f,19.5187f,152.344f, -89.8438f,20.2592f,152.344f, -93.75f,19.2159f,152.344f, -97.6563f,20.1174f,152.344f, -101.563f,21.9257f,152.344f, -105.469f,23.9219f,152.344f, -109.375f,25.8476f,152.344f, -113.281f,27.9183f,152.344f, -117.188f,29.2798f,152.344f, -121.094f,30.2289f,152.344f, -125.0f,31.7495f,152.344f, -128.906f,33.1684f,152.344f, -132.813f,34.4626f,152.344f, -136.719f,35.9981f,152.344f, -140.625f,36.5168f,152.344f, -144.531f,35.9325f,152.344f, -148.438f,41.231f,152.344f, -152.344f,42.7257f,152.344f, -156.25f,43.5162f,152.344f, -160.156f,44.357f,152.344f, -164.063f,44.2347f,152.344f, -167.969f,40.2679f,152.344f, -171.875f,36.2109f,152.344f, -175.781f,36.3906f,152.344f, -179.688f,35.227f,152.344f, -183.594f,34.7006f,152.344f, -187.5f,34.7763f,152.344f, -191.406f,34.0912f,152.344f, -195.313f,32.201f,152.344f, -199.219f,30.6601f,152.344f, -203.125f,28.7526f,152.344f, -207.031f,33.0587f,152.344f, -210.938f,31.7955f,152.344f, -214.844f,29.893f,152.344f, -218.75f,27.5989f,152.344f, -222.656f,26.1347f,152.344f, -226.563f,19.6378f,152.344f, -230.469f,18.6596f,152.344f, -234.375f,17.3965f,152.344f, -238.281f,15.5807f,152.344f, -242.188f,13.4071f,152.344f, -246.094f,12.7989f,152.344f, -250.0f,12.5897f,152.344f, -3.90626f,18.4109f,148.438f, -7.81251f,18.8163f,148.438f, -11.7188f,20.7396f,148.438f, -15.625f,21.7833f,148.438f, -19.5313f,20.6586f,148.438f, -23.4375f,19.8597f,148.438f, -27.3438f,20.0951f,148.438f, -31.25f,18.7811f,148.438f, -35.1563f,18.123f,148.438f, -39.0625f,17.773f,148.438f, -42.9688f,18.0095f,148.438f, -46.875f,17.694f,148.438f, -50.7813f,17.1666f,148.438f, -54.6875f,18.3484f,148.438f, -58.5938f,18.5612f,148.438f, -62.5f,18.1324f,148.438f, -66.4063f,17.4119f,148.438f, -70.3125f,17.2873f,148.438f, -74.2188f,17.6855f,148.438f, -78.125f,18.6618f,148.438f, -82.0313f,19.6447f,148.438f, -85.9375f,19.4743f,148.438f, -89.8438f,20.2887f,148.438f, -93.75f,20.2469f,148.438f, -97.6563f,21.1802f,148.438f, -101.563f,23.2002f,148.438f, -105.469f,24.8874f,148.438f, -109.375f,26.5433f,148.438f, -113.281f,28.653f,148.438f, -117.188f,30.2347f,148.438f, -121.094f,31.6949f,148.438f, -125.0f,33.2452f,148.438f, -128.906f,34.3964f,148.438f, -132.813f,35.2835f,148.438f, -136.719f,36.7099f,148.438f, -140.625f,37.1893f,148.438f, -144.531f,36.5212f,148.438f, -148.438f,36.7413f,148.438f, -152.344f,43.9965f,148.438f, -156.25f,44.9543f,148.438f, -160.156f,44.8078f,148.438f, -164.063f,45.09f,148.438f, -167.969f,43.0871f,148.438f, -171.875f,42.2067f,148.438f, -175.781f,40.5399f,148.438f, -179.688f,35.9902f,148.438f, -183.594f,34.4093f,148.438f, -187.5f,35.1087f,148.438f, -191.406f,34.3372f,148.438f, -195.313f,35.6724f,148.438f, -199.219f,34.961f,148.438f, -203.125f,34.4106f,148.438f, -207.031f,32.0028f,148.438f, -210.938f,31.3925f,148.438f, -214.844f,29.3539f,148.438f, -218.75f,27.6213f,148.438f, -222.656f,21.6694f,148.438f, -226.563f,20.356f,148.438f, -230.469f,19.6202f,148.438f, -234.375f,17.6247f,148.438f, -238.281f,16.5152f,148.438f, -242.188f,14.901f,148.438f, -246.094f,12.7994f,148.438f, -250.0f,12.2743f,148.438f, -3.90626f,17.8758f,144.531f, -7.81251f,19.3177f,144.531f, -11.7188f,20.9214f,144.531f, -15.625f,21.8589f,144.531f, -19.5313f,21.2904f,144.531f, -23.4375f,19.9784f,144.531f, -27.3438f,19.6359f,144.531f, -31.25f,19.4398f,144.531f, -35.1563f,18.6596f,144.531f, -39.0625f,17.1967f,144.531f, -42.9688f,16.797f,144.531f, -46.875f,16.4099f,144.531f, -50.7813f,16.54f,144.531f, -54.6875f,16.811f,144.531f, -58.5938f,17.31f,144.531f, -62.5f,17.5358f,144.531f, -66.4063f,16.8495f,144.531f, -70.3125f,17.2148f,144.531f, -74.2188f,16.6285f,144.531f, -78.125f,17.7911f,144.531f, -82.0313f,18.6054f,144.531f, -85.9375f,18.787f,144.531f, -89.8438f,20.4804f,144.531f, -93.75f,21.0544f,144.531f, -97.6563f,20.9487f,144.531f, -101.563f,23.1098f,144.531f, -105.469f,25.2196f,144.531f, -109.375f,27.0389f,144.531f, -113.281f,29.4971f,144.531f, -117.188f,31.0049f,144.531f, -121.094f,33.086f,144.531f, -125.0f,34.6611f,144.531f, -128.906f,35.8626f,144.531f, -132.813f,36.8672f,144.531f, -136.719f,37.5515f,144.531f, -140.625f,37.6433f,144.531f, -144.531f,37.8923f,144.531f, -148.438f,37.1277f,144.531f, -152.344f,40.0287f,144.531f, -156.25f,44.9863f,144.531f, -160.156f,45.0845f,144.531f, -164.063f,44.7823f,144.531f, -167.969f,42.5338f,144.531f, -171.875f,41.7912f,144.531f, -175.781f,41.5762f,144.531f, -179.688f,41.3242f,144.531f, -183.594f,39.6796f,144.531f, -187.5f,39.4704f,144.531f, -191.406f,38.5401f,144.531f, -195.313f,37.3853f,144.531f, -199.219f,35.4345f,144.531f, -203.125f,34.2437f,144.531f, -207.031f,31.8218f,144.531f, -210.938f,30.6041f,144.531f, -214.844f,26.9001f,144.531f, -218.75f,22.3094f,144.531f, -222.656f,21.4446f,144.531f, -226.563f,20.6643f,144.531f, -230.469f,20.3246f,144.531f, -234.375f,18.0382f,144.531f, -238.281f,15.7854f,144.531f, -242.188f,14.3314f,144.531f, -246.094f,12.4723f,144.531f, -250.0f,12.5491f,144.531f, -3.90626f,18.5798f,140.625f, -7.81251f,19.7271f,140.625f, -11.7188f,20.8566f,140.625f, -15.625f,21.6914f,140.625f, -19.5313f,20.9288f,140.625f, -23.4375f,20.0531f,140.625f, -27.3438f,19.1655f,140.625f, -31.25f,18.7947f,140.625f, -35.1563f,18.2984f,140.625f, -39.0625f,17.3295f,140.625f, -42.9688f,16.5557f,140.625f, -46.875f,16.1679f,140.625f, -50.7813f,16.0262f,140.625f, -54.6875f,16.1659f,140.625f, -58.5938f,16.459f,140.625f, -62.5f,17.0307f,140.625f, -66.4063f,17.6303f,140.625f, -70.3125f,16.7576f,140.625f, -74.2188f,16.9614f,140.625f, -78.125f,17.3439f,140.625f, -82.0313f,17.7742f,140.625f, -85.9375f,19.0774f,140.625f, -89.8438f,20.0724f,140.625f, -93.75f,21.5734f,140.625f, -97.6563f,21.4923f,140.625f, -101.563f,24.2474f,140.625f, -105.469f,25.9666f,140.625f, -109.375f,27.8803f,140.625f, -113.281f,29.6397f,140.625f, -117.188f,32.0374f,140.625f, -121.094f,34.014f,140.625f, -125.0f,35.1589f,140.625f, -128.906f,36.2526f,140.625f, -132.813f,37.5386f,140.625f, -136.719f,38.1647f,140.625f, -140.625f,37.9014f,140.625f, -144.531f,39.0558f,140.625f, -148.438f,38.1493f,140.625f, -152.344f,39.5967f,140.625f, -156.25f,40.3409f,140.625f, -160.156f,39.4778f,140.625f, -164.063f,43.7911f,140.625f, -167.969f,42.7467f,140.625f, -171.875f,41.4394f,140.625f, -175.781f,41.222f,140.625f, -179.688f,40.9501f,140.625f, -183.594f,40.2741f,140.625f, -187.5f,40.5011f,140.625f, -191.406f,39.8634f,140.625f, -195.313f,37.8944f,140.625f, -199.219f,35.6917f,140.625f, -203.125f,33.0921f,140.625f, -207.031f,30.7497f,140.625f, -210.938f,24.355f,140.625f, -214.844f,23.6102f,140.625f, -218.75f,23.2298f,140.625f, -222.656f,21.8035f,140.625f, -226.563f,21.0813f,140.625f, -230.469f,20.4423f,140.625f, -234.375f,19.372f,140.625f, -238.281f,16.9074f,140.625f, -242.188f,15.6931f,140.625f, -246.094f,14.0046f,140.625f, -250.0f,12.7719f,140.625f, -3.90626f,19.7224f,136.719f, -7.81251f,20.3645f,136.719f, -11.7188f,20.1938f,136.719f, -15.625f,20.0122f,136.719f, -19.5313f,20.9204f,136.719f, -23.4375f,20.2208f,136.719f, -27.3438f,19.3419f,136.719f, -31.25f,18.2059f,136.719f, -35.1563f,17.6089f,136.719f, -39.0625f,17.131f,136.719f, -42.9688f,16.8349f,136.719f, -46.875f,16.3462f,136.719f, -50.7813f,15.4488f,136.719f, -54.6875f,15.7887f,136.719f, -58.5938f,16.431f,136.719f, -62.5f,16.3378f,136.719f, -66.4063f,17.4585f,136.719f, -70.3125f,17.5113f,136.719f, -74.2188f,17.6407f,136.719f, -78.125f,17.0887f,136.719f, -82.0313f,17.2555f,136.719f, -85.9375f,18.6283f,136.719f, -89.8438f,19.6874f,136.719f, -93.75f,21.0963f,136.719f, -97.6563f,21.5582f,136.719f, -101.563f,24.9129f,136.719f, -105.469f,27.5761f,136.719f, -109.375f,28.7426f,136.719f, -113.281f,31.0958f,136.719f, -117.188f,33.7564f,136.719f, -121.094f,34.6927f,136.719f, -125.0f,35.0503f,136.719f, -128.906f,36.0657f,136.719f, -132.813f,37.2001f,136.719f, -136.719f,38.5625f,136.719f, -140.625f,38.8809f,136.719f, -144.531f,39.3646f,136.719f, -148.438f,38.919f,136.719f, -152.344f,39.5251f,136.719f, -156.25f,39.5392f,136.719f, -160.156f,39.7011f,136.719f, -164.063f,38.4043f,136.719f, -167.969f,37.7232f,136.719f, -171.875f,37.8418f,136.719f, -175.781f,41.0576f,136.719f, -179.688f,40.6804f,136.719f, -183.594f,40.6431f,136.719f, -187.5f,41.2286f,136.719f, -191.406f,40.221f,136.719f, -195.313f,37.9197f,136.719f, -199.219f,30.9591f,136.719f, -203.125f,28.2027f,136.719f, -207.031f,25.2338f,136.719f, -210.938f,24.1525f,136.719f, -214.844f,23.6344f,136.719f, -218.75f,22.6246f,136.719f, -222.656f,21.3675f,136.719f, -226.563f,21.0207f,136.719f, -230.469f,20.2558f,136.719f, -234.375f,18.3661f,136.719f, -238.281f,16.7584f,136.719f, -242.188f,16.2723f,136.719f, -246.094f,14.7268f,136.719f, -250.0f,13.5973f,136.719f, -3.90626f,19.9574f,132.813f, -7.8125f,21.126f,132.813f, -11.7188f,20.9977f,132.813f, -15.625f,21.2478f,132.813f, -19.5313f,21.5981f,132.813f, -23.4375f,20.0536f,132.813f, -27.3438f,18.6025f,132.813f, -31.25f,18.166f,132.813f, -35.1563f,17.207f,132.813f, -39.0625f,17.3703f,132.813f, -42.9688f,16.3317f,132.813f, -46.875f,15.4769f,132.813f, -50.7813f,14.7771f,132.813f, -54.6875f,14.8038f,132.813f, -58.5938f,15.7291f,132.813f, -62.5f,16.2292f,132.813f, -66.4063f,17.1488f,132.813f, -70.3125f,17.5027f,132.813f, -74.2188f,16.9736f,132.813f, -78.125f,16.4014f,132.813f, -82.0313f,16.7581f,132.813f, -85.9375f,18.1894f,132.813f, -89.8438f,20.0178f,132.813f, -93.75f,20.5813f,132.813f, -97.6563f,22.5893f,132.813f, -101.563f,25.6741f,132.813f, -105.469f,28.0908f,132.813f, -109.375f,29.1124f,132.813f, -113.281f,31.4752f,132.813f, -117.188f,33.2328f,132.813f, -121.094f,34.3747f,132.813f, -125.0f,34.8849f,132.813f, -128.906f,36.3771f,132.813f, -132.813f,37.3154f,132.813f, -136.719f,38.6196f,132.813f, -140.625f,39.1474f,132.813f, -144.531f,39.5395f,132.813f, -148.438f,38.9241f,132.813f, -152.344f,39.6801f,132.813f, -156.25f,39.7675f,132.813f, -160.156f,39.4464f,132.813f, -164.063f,38.2967f,132.813f, -167.969f,37.3679f,132.813f, -171.875f,36.5147f,132.813f, -175.781f,35.9217f,132.813f, -179.688f,35.6874f,132.813f, -183.594f,36.0348f,132.813f, -187.5f,36.167f,132.813f, -191.406f,34.7462f,132.813f, -195.313f,32.5911f,132.813f, -199.219f,30.8509f,132.813f, -203.125f,27.889f,132.813f, -207.031f,25.0869f,132.813f, -210.938f,23.713f,132.813f, -214.844f,23.4714f,132.813f, -218.75f,22.2633f,132.813f, -222.656f,21.1409f,132.813f, -226.563f,20.2725f,132.813f, -230.469f,19.4678f,132.813f, -234.375f,18.4511f,132.813f, -238.281f,18.0306f,132.813f, -242.188f,17.5677f,132.813f, -246.094f,16.403f,132.813f, -250.0f,14.7316f,132.813f, -3.90626f,20.0876f,128.906f, -7.81252f,21.0764f,128.906f, -11.7188f,21.4076f,128.906f, -15.625f,22.6299f,128.906f, -19.5313f,22.1174f,128.906f, -23.4375f,20.3977f,128.906f, -27.3438f,18.7343f,128.906f, -31.25f,17.9144f,128.906f, -35.1563f,17.2941f,128.906f, -39.0625f,16.5386f,128.906f, -42.9688f,15.6892f,128.906f, -46.875f,14.6414f,128.906f, -50.7813f,14.3505f,128.906f, -54.6875f,14.1604f,128.906f, -58.5938f,14.517f,128.906f, -62.5f,15.1057f,128.906f, -66.4063f,16.0684f,128.906f, -70.3125f,16.6251f,128.906f, -74.2188f,15.9689f,128.906f, -78.125f,16.0234f,128.906f, -82.0313f,16.205f,128.906f, -85.9375f,18.8167f,128.906f, -89.8438f,19.6433f,128.906f, -93.75f,20.2916f,128.906f, -97.6563f,23.2308f,128.906f, -101.563f,25.882f,128.906f, -105.469f,27.5736f,128.906f, -109.375f,28.9662f,128.906f, -113.281f,30.5702f,128.906f, -117.188f,31.8627f,128.906f, -121.094f,32.5216f,128.906f, -125.0f,34.1918f,128.906f, -128.906f,37.0161f,128.906f, -132.813f,38.5084f,128.906f, -136.719f,39.1631f,128.906f, -140.625f,39.0529f,128.906f, -144.531f,38.9229f,128.906f, -148.438f,38.4312f,128.906f, -152.344f,39.1086f,128.906f, -156.25f,39.7022f,128.906f, -160.156f,39.3007f,128.906f, -164.063f,38.2318f,128.906f, -167.969f,36.7493f,128.906f, -171.875f,35.9781f,128.906f, -175.781f,35.7712f,128.906f, -179.688f,35.6247f,128.906f, -183.594f,35.4808f,128.906f, -187.5f,35.6102f,128.906f, -191.406f,34.0305f,128.906f, -195.313f,32.0227f,128.906f, -199.219f,29.7666f,128.906f, -203.125f,27.3968f,128.906f, -207.031f,25.1642f,128.906f, -210.938f,24.279f,128.906f, -214.844f,22.4357f,128.906f, -218.75f,21.7754f,128.906f, -222.656f,19.6381f,128.906f, -226.563f,19.78f,128.906f, -230.469f,20.0349f,128.906f, -234.375f,19.1534f,128.906f, -238.281f,17.863f,128.906f, -242.188f,17.658f,128.906f, -246.094f,16.951f,128.906f, -250.0f,16.2961f,128.906f, -}; - -btScalar Landscape01Nml[] = { --0.145347f,0.988603f,0.0392193f, --0.118578f,0.971903f,-0.203332f, --0.210348f,0.975548f,0.0637181f, --0.143154f,0.979915f,-0.138828f, --0.186466f,0.976661f,0.106602f, --0.200996f,0.973874f,-0.105691f, --0.200019f,0.979742f,-0.00987837f, --0.162567f,0.986516f,-0.0189093f, --0.128872f,0.991658f,-0.00262187f, --0.0972065f,0.993702f,0.0557464f, --0.232168f,0.972676f,8.39761e-005f, --0.280715f,0.959127f,-0.0356947f, --0.328537f,0.944066f,-0.0283446f, --0.348021f,0.936189f,-0.0493126f, --0.28502f,0.953899f,-0.0940249f, --0.329197f,0.938125f,-0.107479f, --0.186873f,0.969867f,-0.15632f, --0.168074f,0.98179f,-0.088542f, -0.138723f,0.984643f,-0.105994f, -0.139713f,0.984758f,-0.103594f, -0.415149f,0.907443f,-0.0647914f, -0.335594f,0.916204f,-0.218967f, -0.391251f,0.906316f,-0.159731f, -0.297117f,0.890775f,-0.343864f, -0.0782406f,0.948307f,-0.307558f, -0.0742546f,0.932023f,-0.354711f, --0.0593029f,0.94484f,-0.322118f, --0.035102f,0.9388f,-0.342668f, --0.0398386f,0.972105f,-0.231139f, -0.0142535f,0.946652f,-0.321942f, --0.149407f,0.982239f,-0.113505f, --0.186817f,0.918353f,-0.348895f, --0.227035f,0.95418f,-0.194923f, --0.217455f,0.921613f,-0.32147f, --0.104683f,0.961425f,-0.254368f, --0.137473f,0.92562f,-0.352602f, --0.0889131f,0.942391f,-0.322479f, --0.137942f,0.895959f,-0.422173f, --0.0994313f,0.915873f,-0.38896f, --0.177412f,0.858967f,-0.480312f, --0.28046f,0.843765f,-0.457605f, --0.23875f,0.832625f,-0.499733f, --0.35769f,0.865922f,-0.349624f, --0.239679f,0.924761f,-0.295585f, --0.367472f,0.894137f,-0.255898f, --0.306721f,0.940051f,-0.149083f, --0.29191f,0.929123f,-0.226977f, --0.3205f,0.928892f,-0.185579f, --0.367832f,0.894452f,-0.254274f, --0.393375f,0.898238f,-0.196023f, --0.386104f,0.869165f,-0.308993f, --0.416765f,0.860247f,-0.293737f, --0.257238f,0.898443f,-0.355849f, --0.273377f,0.911812f,-0.306372f, --0.228654f,0.889208f,-0.396265f, --0.28545f,0.876522f,-0.387592f, --0.142316f,0.885962f,-0.441381f, --0.101084f,0.908701f,-0.405025f, -0.035618f,0.945519f,-0.323614f, -0.103277f,0.941647f,-0.320368f, --0.120589f,0.957422f,-0.262302f, --0.186114f,0.894712f,-0.40602f, --0.202962f,0.931974f,-0.300385f, --0.162074f,0.943023f,-0.290584f, --0.152017f,0.933176f,-0.325688f, --0.202811f,0.891764f,-0.404505f, --0.195614f,0.919053f,-0.342165f, --0.221332f,0.883262f,-0.413352f, --0.230949f,0.883479f,-0.407587f, --0.202664f,0.884798f,-0.419595f, --0.013827f,0.935183f,-0.353894f, -0.0613953f,0.949306f,-0.308299f, -0.0379666f,0.956996f,-0.287605f, -0.0239474f,0.920688f,-0.389564f, --0.124568f,0.971246f,-0.20289f, --0.0173673f,0.966674f,-0.255421f, --0.280608f,0.954174f,-0.103981f, --0.188825f,0.978003f,-0.0886339f, --0.193278f,0.981044f,-0.0139968f, --0.089832f,0.992161f,0.0868734f, --0.0617809f,0.994525f,0.0842802f, -0.0316335f,0.979002f,0.20138f, -0.126601f,0.973442f,0.190743f, -0.126356f,0.954056f,0.271683f, -0.0296197f,0.996225f,0.0816031f, --0.130879f,0.990212f,-0.0484936f, --0.0775613f,0.996382f,0.0347567f, --0.0318445f,0.999049f,0.0297665f, -0.174213f,0.981835f,0.0751658f, -0.230898f,0.968544f,0.0927823f, -0.477724f,0.867555f,0.138304f, -0.489512f,0.856269f,0.164868f, -0.425011f,0.903484f,0.0555235f, -0.345126f,0.937885f,0.0355011f, -0.051136f,0.997417f,-0.0504465f, -0.0111243f,0.99878f,-0.0481145f, -0.00085351f,0.998643f,-0.0520782f, --0.0736129f,0.992491f,-0.0976874f, -0.0605446f,0.978416f,-0.197578f, --0.1248f,0.898669f,-0.420499f, --0.068151f,0.956411f,-0.28396f, -0.0502596f,0.934397f,-0.35267f, -0.0492358f,0.99416f,-0.096025f, -0.22311f,0.97441f,-0.0273246f, -0.104257f,0.993921f,-0.0353788f, -0.135731f,0.987345f,0.0820234f, -0.0508084f,0.996415f,-0.0676404f, -0.013783f,0.999772f,-0.0162859f, -0.0814861f,0.996154f,-0.0322044f, -0.0451487f,0.998313f,-0.0365194f, -0.035547f,0.992801f,-0.114375f, --0.0977551f,0.955799f,-0.277294f, -0.0588118f,0.977967f,-0.200303f, -0.0956551f,0.968682f,-0.229142f, -0.255494f,0.951171f,-0.173197f, -0.287347f,0.949686f,-0.124613f, -0.300983f,0.934694f,-0.189092f, -0.326044f,0.937015f,-0.125296f, -0.170234f,0.979103f,-0.111255f, -0.217643f,0.971688f,-0.0919459f, -0.0857423f,0.995f,-0.0512173f, -0.141055f,0.988855f,0.0476293f, -0.141065f,0.98942f,-0.0338874f, -0.161562f,0.986303f,0.0332183f, -0.113059f,0.993231f,0.0266602f, -0.073071f,0.997081f,-0.0221543f, --0.0590251f,0.997651f,-0.034775f, --0.0264959f,0.999595f,0.0103962f, --0.0628475f,0.932757f,0.354985f, --0.188464f,0.930547f,0.31395f, --0.11595f,0.95582f,0.270118f, --0.0150745f,0.981122f,0.192801f, --0.121292f,0.98854f,0.0898753f, --0.191875f,0.979293f,0.0645635f, --0.302211f,0.947932f,-0.100469f, --0.168835f,0.972187f,-0.162321f, --0.165107f,0.942083f,-0.291925f, -0.0524842f,0.966783f,-0.250151f, -0.334898f,0.925425f,-0.177288f, -0.453352f,0.888614f,-0.0695481f, -0.212879f,0.976177f,-0.0419751f, --0.0859137f,0.991174f,-0.100958f, --0.19247f,0.980365f,-0.0428897f, --0.217979f,0.975456f,0.0311624f, --0.130678f,0.991292f,-0.0162531f, -0.0105625f,0.994964f,-0.0996785f, --0.0191557f,0.967247f,-0.253114f, --0.034833f,0.962122f,-0.270385f, --0.195874f,0.937997f,-0.285996f, --0.397161f,0.831379f,-0.388681f, --0.379064f,0.825916f,-0.417342f, --0.284483f,0.874083f,-0.393762f, --0.320157f,0.86551f,-0.385217f, --0.327447f,0.85814f,-0.395442f, --0.219114f,0.871062f,-0.439592f, --0.161876f,0.861769f,-0.480781f, --0.18946f,0.845726f,-0.498852f, --0.191307f,0.924603f,-0.32941f, --0.159365f,0.982225f,-0.0991764f, --0.164558f,0.975832f,-0.143777f, --0.155521f,0.974006f,-0.164699f, --0.172244f,0.972979f,-0.153766f, --0.162541f,0.961346f,-0.222247f, --0.11171f,0.955927f,-0.271523f, --0.101714f,0.980079f,-0.170586f, --0.223397f,0.974336f,-0.0276274f, --0.300622f,0.953413f,0.0251167f, --0.254202f,0.967133f,-0.00586307f, --0.0994566f,0.994394f,0.0359007f, -0.078652f,0.996758f,-0.0169243f, --0.0552979f,0.987555f,0.147234f, --0.0666628f,0.864508f,0.498179f, -0.131082f,0.854494f,0.502651f, -0.414695f,0.764646f,0.4933f, -0.432926f,0.790826f,0.432632f, -0.126593f,0.91514f,0.382744f, --0.0157552f,0.943082f,0.332186f, -0.122694f,0.924647f,0.36052f, -0.0975822f,0.984244f,0.147447f, --0.026294f,0.960938f,-0.275512f, -0.1231f,0.958251f,-0.258072f, -0.037902f,0.976085f,-0.214059f, --0.000148888f,0.992562f,-0.121742f, -0.0716429f,0.997173f,-0.0226693f, -0.135484f,0.989193f,-0.0560393f, -0.275603f,0.956281f,-0.0978236f, -0.283097f,0.956822f,-0.0659346f, -0.109624f,0.991403f,-0.0714361f, -0.084436f,0.990816f,-0.105609f, -0.0791881f,0.990931f,-0.108558f, -0.0674956f,0.997569f,-0.0173508f, -0.0556006f,0.998429f,0.00688119f, --0.144974f,0.947519f,0.28494f, --0.110826f,0.961365f,0.251981f, --0.0669451f,0.996693f,0.0460586f, --0.00516145f,0.998802f,0.0486696f, --0.116537f,0.988089f,0.100498f, --0.0456605f,0.993379f,0.105422f, --0.110131f,0.987256f,-0.114879f, --0.0746162f,0.968429f,-0.237861f, --0.0785155f,0.952358f,-0.294703f, --0.0192369f,0.946876f,-0.321024f, -0.320056f,0.920022f,-0.226108f, -0.288692f,0.932613f,-0.216541f, -0.123147f,0.991593f,-0.0397145f, --0.113817f,0.992375f,0.0473138f, --0.192042f,0.9774f,0.0883642f, --0.156949f,0.987573f,0.00819321f, --0.0848586f,0.992344f,-0.0897344f, -0.0818673f,0.992357f,-0.0923282f, -0.113464f,0.986976f,-0.114035f, --0.0777263f,0.979155f,-0.187653f, --0.11587f,0.975173f,-0.188711f, --0.26618f,0.902421f,-0.338799f, --0.343104f,0.842974f,-0.414336f, --0.318919f,0.837107f,-0.444457f, --0.324821f,0.839352f,-0.435867f, --0.312979f,0.836318f,-0.45013f, --0.203015f,0.862499f,-0.463553f, --0.14187f,0.900483f,-0.411101f, --0.22968f,0.933243f,-0.276233f, --0.413973f,0.871187f,-0.263932f, --0.305656f,0.93798f,-0.163607f, --0.161875f,0.985861f,-0.0433003f, --0.135788f,0.990721f,0.00582442f, --0.138617f,0.984876f,-0.103942f, --0.135024f,0.980056f,-0.145806f, --0.124871f,0.989793f,-0.068687f, --0.182018f,0.982992f,-0.024403f, --0.309743f,0.950592f,-0.0208625f, --0.30492f,0.95221f,0.0178823f, --0.299424f,0.951826f,0.066125f, --0.120448f,0.944431f,0.305848f, -0.118213f,0.907792f,0.402418f, --0.261318f,0.917154f,0.300902f, --0.411401f,0.860866f,0.299431f, -0.15139f,0.91772f,0.367249f, -0.409879f,0.832051f,0.373752f, -0.446772f,0.77668f,0.44403f, -0.301572f,0.80653f,0.508491f, -0.168293f,0.89172f,0.420135f, -0.0587854f,0.961406f,0.26878f, -0.30067f,0.896979f,0.324077f, -0.282217f,0.935284f,0.213535f, -0.148185f,0.986837f,0.0647602f, --0.0572401f,0.974528f,-0.216838f, --0.0945497f,0.96665f,-0.238009f, --0.000668496f,0.9725f,-0.232902f, -0.125989f,0.980136f,-0.15317f, -0.218059f,0.975888f,-0.00959987f, -0.265461f,0.958501f,0.103951f, -0.173443f,0.98019f,0.0956349f, -0.133691f,0.987754f,0.0804258f, -0.0900836f,0.995272f,0.0363034f, -0.0177237f,0.999106f,-0.0383914f, -0.042211f,0.998744f,-0.0269875f, -0.0720539f,0.94434f,0.320982f, -0.0948772f,0.964987f,0.244537f, -0.123635f,0.987961f,0.0929884f, --0.0283728f,0.998997f,-0.0346279f, --0.152337f,0.985597f,-0.0734363f, --0.0291778f,0.996634f,-0.0766092f, -0.0594392f,0.995285f,-0.0766423f, --0.027888f,0.982723f,-0.182971f, --0.0125244f,0.971758f,-0.235647f, --0.0767296f,0.943557f,-0.322201f, -0.2299f,0.955601f,-0.184318f, -0.271645f,0.9586f,-0.0854157f, -0.0112173f,0.999015f,-0.0429278f, --0.142475f,0.989464f,-0.02574f, --0.192441f,0.979224f,-0.0639254f, --0.103523f,0.99301f,-0.0567016f, --0.00378459f,0.998834f,-0.0481324f, -0.0499927f,0.992415f,-0.112309f, -0.0737699f,0.994576f,-0.0733206f, --0.0190206f,0.999623f,-0.0197948f, --0.0783652f,0.99692f,0.00307073f, --0.152226f,0.987897f,0.0297819f, --0.333638f,0.940154f,-0.069252f, --0.307736f,0.941909f,-0.134557f, --0.334924f,0.918699f,-0.209327f, --0.35357f,0.914459f,-0.19686f, --0.243406f,0.963329f,-0.112917f, --0.31479f,0.943784f,-0.100892f, --0.368184f,0.929745f,0.00391099f, --0.386308f,0.922293f,-0.0119138f, --0.337617f,0.936762f,-0.0921568f, --0.305867f,0.947033f,-0.0978487f, --0.109063f,0.994026f,0.00418869f, -0.00976093f,0.996792f,-0.0794369f, --0.152053f,0.972765f,-0.17495f, --0.268682f,0.956747f,-0.111559f, --0.16583f,0.986099f,0.0104333f, --0.26795f,0.960138f,-0.0796053f, --0.428361f,0.903607f,0.000904858f, --0.364896f,0.884093f,0.291943f, --0.411739f,0.889329f,0.19891f, --0.213918f,0.942658f,0.256194f, --0.0353818f,0.912316f,0.407955f, --0.234679f,0.972031f,0.0090071f, -0.164799f,0.976041f,-0.142074f, -0.378329f,0.920537f,-0.0973577f, -0.389048f,0.913009f,0.122701f, -0.312785f,0.918579f,0.241617f, -0.331426f,0.913352f,0.236529f, -0.235473f,0.970893f,0.043811f, -0.0409183f,0.988429f,-0.14606f, -0.183882f,0.951979f,0.244794f, -0.256685f,0.844334f,0.470333f, -0.243297f,0.84406f,0.47788f, -0.178194f,0.957255f,0.227835f, -0.0574376f,0.965885f,-0.252523f, --0.0590426f,0.961892f,-0.266977f, -0.0063288f,0.996614f,-0.081983f, -0.221194f,0.97242f,0.0739783f, -0.131016f,0.988415f,0.0766141f, -0.0953963f,0.986256f,0.134901f, -0.160579f,0.972927f,0.166216f, -0.109946f,0.983906f,0.14086f, -0.027673f,0.996741f,0.0757784f, -0.095102f,0.971229f,0.218334f, -0.102357f,0.973251f,0.205684f, -0.193741f,0.956416f,0.218477f, -0.132416f,0.984788f,0.112512f, --0.0766537f,0.99488f,-0.0658589f, --0.0304197f,0.995587f,-0.0887742f, -0.0261631f,0.997431f,-0.0666789f, -0.0720508f,0.996334f,-0.0461268f, -0.110802f,0.979106f,-0.170512f, --0.036534f,0.946972f,-0.319234f, -0.0562543f,0.953438f,-0.296297f, -0.21433f,0.964539f,-0.154036f, --0.0463138f,0.986383f,-0.157808f, --0.114222f,0.99275f,-0.0374399f, --0.129535f,0.99146f,-0.0150624f, --0.148036f,0.985214f,-0.0862475f, --0.0412316f,0.997863f,-0.050697f, -0.0938182f,0.995513f,-0.0123356f, -0.0585542f,0.997889f,-0.0281043f, --0.11195f,0.993633f,0.0126653f, --0.208443f,0.969116f,0.131782f, --0.178284f,0.959747f,0.217024f, --0.249524f,0.951637f,0.179236f, --0.204568f,0.966799f,0.153139f, --0.277831f,0.959694f,0.042405f, --0.421523f,0.906804f,-0.00501147f, --0.349246f,0.93481f,0.0644755f, --0.271825f,0.953501f,0.130185f, --0.341243f,0.939899f,0.0119564f, --0.356048f,0.93224f,-0.0644791f, --0.286188f,0.955628f,-0.0697892f, --0.248084f,0.956522f,-0.153364f, --0.154022f,0.960443f,-0.232007f, -0.032406f,0.989794f,-0.138774f, --0.0622078f,0.991529f,-0.114016f, --0.335467f,0.915845f,-0.220659f, --0.194821f,0.973732f,-0.117857f, --0.29903f,0.953799f,-0.0291431f, --0.514277f,0.834668f,0.197101f, --0.344769f,0.927072f,0.147212f, --0.0936834f,0.993837f,0.0592615f, --0.181141f,0.974379f,-0.133321f, --0.0841805f,0.983933f,-0.157447f, -0.0661375f,0.94785f,-0.31178f, -0.143104f,0.856028f,-0.496726f, -0.226417f,0.827547f,-0.513714f, -0.178899f,0.912784f,-0.367179f, -0.234616f,0.943911f,-0.232351f, -0.346693f,0.91935f,-0.186008f, -0.307074f,0.943627f,-0.123586f, -0.214863f,0.970065f,0.113171f, -0.0234555f,0.999712f,0.00506759f, --0.0206358f,0.99868f,0.047041f, -0.0320247f,0.946177f,0.322062f, -0.23638f,0.837444f,0.492759f, -0.410368f,0.848265f,0.33473f, --0.0124285f,0.999913f,-0.00451951f, --0.13197f,0.981357f,-0.139724f, -0.0888915f,0.995883f,0.0177605f, -0.12955f,0.973581f,0.188033f, -0.100974f,0.97841f,0.18033f, -0.116628f,0.987352f,0.107396f, -0.0879041f,0.989191f,0.117361f, -0.114472f,0.980893f,0.157306f, -0.0306685f,0.986407f,0.161431f, -0.128704f,0.972047f,0.196366f, -0.21783f,0.966546f,0.135421f, -0.280184f,0.953049f,0.114866f, -0.0272615f,0.999564f,-0.0113551f, --0.0491486f,0.997279f,-0.0549472f, -0.00337261f,0.998977f,-0.0450999f, -0.0913253f,0.995457f,-0.0269266f, -0.252481f,0.964775f,-0.0739122f, -0.0897947f,0.975122f,-0.202665f, --0.0238258f,0.968534f,-0.247739f, -0.162662f,0.981573f,-0.10028f, --0.0276113f,0.997652f,-0.0626774f, --0.289082f,0.95335f,-0.0869268f, --0.160594f,0.986876f,0.0169191f, --0.0752137f,0.997117f,0.00999502f, --0.0455931f,0.997939f,-0.0451647f, -0.0616976f,0.995202f,-0.0759372f, --0.00353073f,0.999867f,-0.0159004f, --0.177748f,0.976224f,0.124065f, --0.247702f,0.959217f,0.136188f, --0.164797f,0.981869f,0.0936766f, --0.214718f,0.976098f,0.0335935f, --0.211552f,0.977318f,-0.00980662f, --0.200169f,0.979677f,0.0128577f, --0.39928f,0.916411f,-0.027687f, --0.374531f,0.927212f,0.0022105f, --0.268102f,0.963363f,0.00736207f, --0.247283f,0.968232f,-0.0371081f, --0.289483f,0.949449f,-0.121432f, --0.253482f,0.93971f,-0.229547f, --0.132892f,0.950758f,-0.279997f, --0.140676f,0.931036f,-0.336723f, --0.161496f,0.9509f,-0.264023f, --0.0403886f,0.9973f,-0.0613364f, --0.215095f,0.96767f,-0.131717f, --0.434628f,0.895597f,-0.0948964f, --0.381939f,0.886142f,0.262442f, --0.43994f,0.880276f,0.177672f, --0.252792f,0.948954f,-0.188633f, --0.0941535f,0.957693f,-0.271953f, --0.13352f,0.964535f,-0.227692f, -0.0341173f,0.927935f,-0.371176f, -0.348577f,0.799586f,-0.489036f, -0.387188f,0.819484f,-0.42253f, -0.14352f,0.883544f,-0.445815f, -0.0762879f,0.891752f,-0.446047f, -0.0742711f,0.875908f,-0.476728f, -0.300515f,0.871535f,-0.38745f, -0.0625809f,0.886656f,-0.458175f, --0.0365474f,0.9191f,-0.392325f, --0.0762363f,0.966891f,-0.243538f, -0.0117284f,0.995382f,0.0952715f, -0.0102532f,0.999347f,-0.0346391f, --0.059511f,0.989492f,-0.131776f, -0.349383f,0.904972f,0.24281f, -0.425179f,0.763732f,0.485732f, --0.0166138f,0.992406f,0.121875f, --0.122272f,0.990094f,0.0690156f, --0.015652f,0.970579f,0.240273f, -0.124649f,0.94771f,0.293785f, -0.220282f,0.938434f,0.266116f, -0.102745f,0.973801f,0.202865f, -0.0640356f,0.977435f,0.201297f, --0.0952943f,0.987515f,0.125435f, -0.114947f,0.977151f,0.178783f, -0.258472f,0.957495f,0.128042f, -0.282157f,0.951094f,0.125728f, -0.142066f,0.986542f,0.0809464f, --0.0434313f,0.998053f,-0.0447576f, -0.0347776f,0.999239f,-0.0176595f, -0.102204f,0.984881f,-0.139871f, -0.245582f,0.958619f,-0.144014f, -0.135608f,0.990697f,0.0113886f, --0.0626335f,0.997441f,0.0344788f, --0.0132478f,0.995736f,0.0912912f, --0.039638f,0.981575f,0.186922f, --0.205229f,0.973473f,0.10115f, --0.153245f,0.987696f,-0.0311751f, --0.0852914f,0.993336f,-0.0775215f, -0.0304281f,0.997751f,-0.0597208f, -0.0412582f,0.993049f,-0.110237f, --0.115798f,0.992196f,0.0462328f, --0.265664f,0.954942f,0.132323f, --0.179634f,0.978355f,0.102729f, --0.122093f,0.992469f,0.00988423f, --0.0976525f,0.994936f,-0.0237989f, --0.19391f,0.963376f,-0.185219f, --0.249328f,0.960076f,-0.126845f, --0.386054f,0.920896f,-0.0539736f, --0.40236f,0.909842f,-0.101455f, --0.264839f,0.959901f,-0.091928f, --0.215529f,0.973573f,-0.0755211f, --0.190591f,0.977631f,-0.0889496f, --0.114636f,0.971653f,-0.20676f, --0.147698f,0.942871f,-0.29863f, --0.153003f,0.970479f,-0.186443f, --0.259911f,0.94737f,-0.186912f, --0.218176f,0.967871f,-0.124997f, --0.218418f,0.965394f,0.142507f, --0.497944f,0.825767f,0.264878f, --0.394522f,0.874216f,0.283017f, --0.174161f,0.980284f,0.0933364f, --0.0291225f,0.984908f,-0.170609f, --0.149188f,0.939649f,-0.307902f, --0.109448f,0.970586f,-0.214438f, -0.391051f,0.895182f,-0.213842f, -0.237246f,0.888641f,-0.392468f, -0.104812f,0.984981f,-0.137213f, -0.1294f,0.991592f,-0.000205693f, -0.119158f,0.992497f,-0.0274125f, -0.117487f,0.990494f,-0.071548f, -0.234708f,0.962187f,-0.138234f, -0.347721f,0.937443f,-0.017023f, -0.135989f,0.962379f,-0.235229f, --0.193384f,0.875532f,-0.442772f, --0.209357f,0.905544f,-0.368998f, -0.0641865f,0.982942f,-0.172352f, -0.0534516f,0.998302f,-0.023133f, --0.0579793f,0.992675f,-0.105989f, -0.299444f,0.827258f,0.475371f, -0.320901f,0.752799f,0.574731f, --0.0625162f,0.964286f,0.257381f, --0.0931157f,0.981324f,0.168322f, -0.0981691f,0.975509f,0.19684f, -0.238911f,0.944952f,0.223577f, -0.0852945f,0.980047f,0.179533f, -0.0437708f,0.96942f,0.241474f, --0.0654565f,0.948925f,0.308637f, -0.105877f,0.941798f,0.319071f, -0.298409f,0.90697f,0.29725f, -0.267454f,0.931587f,0.246198f, -0.257873f,0.930012f,0.261877f, -0.0608152f,0.99476f,0.0821851f, -0.0682325f,0.995644f,-0.0635329f, -0.204976f,0.974836f,-0.0876375f, -0.100643f,0.994422f,0.031559f, --0.0498971f,0.971595f,0.231328f, --0.0948982f,0.951903f,0.291332f, --0.0140779f,0.962693f,0.270229f, -0.0194699f,0.983768f,0.178386f, --0.0700516f,0.997536f,0.00373294f, --0.0458738f,0.991776f,-0.119485f, --0.0457685f,0.983541f,-0.17479f, -0.031836f,0.984739f,-0.171101f, --0.0846163f,0.991107f,-0.102703f, --0.250146f,0.959975f,0.125993f, --0.240823f,0.966766f,0.0858408f, --0.110771f,0.993685f,0.0178603f, --0.0536647f,0.99805f,-0.0318645f, --0.0537905f,0.996775f,-0.0595505f, --0.0979926f,0.994498f,-0.0370296f, --0.317761f,0.946482f,-0.0565711f, --0.353331f,0.932392f,-0.0761719f, --0.315921f,0.918114f,-0.23929f, --0.304095f,0.907663f,-0.289264f, --0.232301f,0.951296f,-0.202665f, --0.181242f,0.959764f,-0.214488f, --0.0415921f,0.982269f,-0.182804f, --0.134113f,0.976644f,-0.16787f, --0.266673f,0.950383f,-0.160182f, --0.233335f,0.968889f,-0.0825141f, --0.383896f,0.923094f,0.0228394f, --0.46523f,0.826401f,0.317211f, --0.448022f,0.824389f,0.345917f, --0.335673f,0.941977f,-0.00160348f, -0.00939714f,0.9768f,-0.213948f, -0.0525806f,0.945774f,-0.320541f, --0.0139338f,0.984205f,-0.176483f, --0.233879f,0.941098f,-0.244203f, -0.35813f,0.924476f,-0.13072f, -0.148621f,0.988076f,0.040214f, --0.0873945f,0.896884f,0.433546f, -0.16715f,0.882598f,0.43941f, -0.105867f,0.92276f,0.370549f, -0.162793f,0.877156f,0.451769f, -0.26606f,0.895485f,0.356818f, -0.178343f,0.923603f,0.339339f, -0.205659f,0.876785f,0.434686f, -0.164046f,0.939287f,0.301379f, --0.304778f,0.94913f,-0.0791393f, --0.351721f,0.931897f,-0.088655f, --0.137155f,0.986834f,0.0857151f, --0.0493791f,0.984585f,0.167793f, --0.29261f,0.942092f,0.163834f, -0.175576f,0.863797f,0.472257f, -0.388427f,0.769345f,0.507181f, -0.0396361f,0.995255f,0.0888612f, -0.000897162f,0.999738f,-0.022857f, -0.263974f,0.951061f,0.160623f, -0.140984f,0.987533f,0.0700142f, --0.0604349f,0.998129f,-0.00925637f, --0.0323604f,0.969904f,0.241328f, -0.0249905f,0.978924f,0.202689f, -0.301944f,0.900385f,0.313268f, -0.302439f,0.903212f,0.304531f, -0.227241f,0.927301f,0.297445f, -0.295557f,0.903047f,0.311692f, -0.215996f,0.968849f,0.121149f, -0.0543993f,0.994951f,0.0843384f, --0.108272f,0.967731f,0.227539f, --0.144218f,0.941468f,0.304694f, --0.0465574f,0.94074f,0.335917f, -0.0834793f,0.95338f,0.289996f, -0.159412f,0.96437f,0.211135f, -0.125672f,0.984055f,0.125864f, -0.0125305f,0.999902f,-0.00630946f, --0.0213081f,0.999771f,-0.00209364f, --0.0845682f,0.99631f,0.014661f, --0.191644f,0.962461f,0.192203f, --0.326186f,0.912172f,0.248084f, --0.125723f,0.965189f,0.229357f, --0.0487346f,0.993706f,0.100859f, -0.0069351f,0.999976f,0.00057427f, --0.0853775f,0.991791f,-0.0951918f, --0.217561f,0.97582f,-0.0210368f, --0.247132f,0.964013f,0.0979986f, --0.253847f,0.965546f,-0.0573009f, --0.17269f,0.977352f,-0.122318f, --0.308873f,0.930936f,-0.19482f, --0.274273f,0.935966f,-0.220775f, --0.176582f,0.954344f,-0.240926f, --0.17678f,0.967725f,-0.179601f, --0.142126f,0.989789f,-0.0108556f, --0.241082f,0.966299f,-0.0902532f, --0.303483f,0.94088f,-0.150476f, --0.634535f,0.768468f,-0.082594f, --0.47113f,0.814002f,0.339761f, --0.289984f,0.937003f,0.194769f, -0.025067f,0.999685f,-0.000862102f, -0.289006f,0.893747f,-0.343064f, -0.00615404f,0.935866f,-0.352301f, --0.338901f,0.929111f,-0.147984f, --0.164518f,0.985591f,-0.0393034f, -0.290961f,0.935697f,-0.199533f, --0.0876053f,0.971539f,-0.220083f, --0.32548f,0.935239f,0.139248f, -0.0766933f,0.974848f,0.20926f, -0.108828f,0.917507f,0.382541f, -0.0350786f,0.924503f,0.379557f, -0.162845f,0.883516f,0.439183f, -0.280718f,0.786151f,0.550603f, -0.282161f,0.80649f,0.519575f, -0.319525f,0.746566f,0.583561f, --0.0912168f,0.872752f,0.479567f, --0.288082f,0.924626f,0.249148f, --0.142667f,0.981082f,0.130856f, --0.066753f,0.9808f,0.183236f, --0.230244f,0.961075f,0.152718f, --0.067082f,0.99457f,0.0795691f, -0.611911f,0.730537f,0.303119f, -0.451199f,0.889041f,0.077617f, -0.0130284f,0.992329f,-0.12294f, -0.0930856f,0.993052f,-0.0719959f, -0.26722f,0.962884f,0.0380388f, -0.075301f,0.995117f,-0.0638176f, -0.167918f,0.972374f,0.162147f, -0.0578882f,0.993576f,0.0972437f, -0.196869f,0.968468f,0.152684f, -0.304163f,0.924874f,0.228237f, -0.255006f,0.935584f,0.244244f, -0.260728f,0.944471f,0.199987f, -0.218361f,0.924111f,0.313587f, -0.0535174f,0.911234f,0.408398f, --0.0710624f,0.921034f,0.382946f, --0.130246f,0.949543f,0.285314f, --0.0655027f,0.977569f,0.200169f, -0.0903252f,0.974724f,0.204338f, -0.155207f,0.949154f,0.273892f, -0.153701f,0.938218f,0.310037f, -0.0621551f,0.960028f,0.272917f, --0.0534301f,0.951765f,0.30214f, --0.196733f,0.911558f,0.361052f, --0.281614f,0.838193f,0.46704f, --0.263195f,0.866235f,0.424694f, --0.0481024f,0.917426f,0.394989f, -0.0935627f,0.945047f,0.31326f, -0.130693f,0.965135f,0.226792f, -0.00742185f,0.989033f,0.14751f, --0.243053f,0.969364f,0.0354789f, --0.273599f,0.961363f,-0.0304179f, --0.215123f,0.976563f,-0.00682047f, --0.164989f,0.983922f,0.068385f, --0.241802f,0.97031f,0.00552545f, --0.241315f,0.967202f,-0.0792945f, --0.169018f,0.981272f,-0.0923975f, --0.282714f,0.953981f,-0.0999632f, --0.234963f,0.971912f,-0.0134244f, --0.109087f,0.993838f,-0.0196489f, --0.369236f,0.9273f,-0.0614783f, --0.551241f,0.800465f,0.235349f, --0.62344f,0.781571f,-0.0216512f, --0.285923f,0.957424f,0.0398505f, -0.246101f,0.967083f,0.064696f, -0.379822f,0.894837f,-0.234526f, --0.124179f,0.991035f,0.0492959f, --0.55499f,0.830986f,0.0380685f, --0.0883601f,0.986961f,0.13454f, -0.492332f,0.870217f,0.0182045f, --0.0249785f,0.975709f,-0.217643f, --0.368665f,0.864796f,-0.340902f, --0.0172444f,0.938433f,-0.345031f, --0.0663306f,0.97669f,-0.204147f, -0.00514992f,0.997132f,-0.0755029f, -0.0570337f,0.998371f,-0.00125828f, -0.249285f,0.962439f,0.107557f, -0.242481f,0.961206f,0.131476f, -0.205153f,0.940815f,0.269776f, -0.193253f,0.908579f,0.370322f, --0.0564604f,0.989265f,0.134783f, -0.0286103f,0.993761f,-0.107795f, --0.22802f,0.927614f,-0.29587f, --0.141654f,0.989087f,-0.0405023f, --0.0918591f,0.979413f,-0.179757f, -0.474817f,0.877478f,-0.067685f, -0.562064f,0.827022f,0.0108876f, -0.0667731f,0.98619f,-0.151561f, -0.0478258f,0.978171f,-0.202223f, -0.240461f,0.955483f,-0.170967f, -0.22331f,0.956303f,-0.188725f, -0.105513f,0.987685f,0.115519f, -0.0191904f,0.988704f,0.148645f, -0.138326f,0.966121f,0.217888f, -0.261136f,0.942738f,0.207491f, -0.283954f,0.937656f,0.20043f, -0.227821f,0.960294f,0.161036f, -0.0632997f,0.956465f,0.284901f, --0.0487147f,0.902832f,0.427225f, --0.0448066f,0.869805f,0.491357f, -0.0191513f,0.881775f,0.471282f, -0.0794772f,0.93047f,0.357644f, -0.0542875f,0.971817f,0.2294f, -0.0315472f,0.963796f,0.264769f, -0.140004f,0.919916f,0.36627f, -0.0838185f,0.924915f,0.370818f, --0.147814f,0.916849f,0.370861f, --0.285354f,0.864307f,0.414182f, --0.277978f,0.859855f,0.428226f, --0.199243f,0.910371f,0.362666f, -0.00801534f,0.941586f,0.336678f, -0.134574f,0.9298f,0.342582f, -0.118153f,0.909557f,0.398429f, -0.0557977f,0.896269f,0.439987f, --0.0363608f,0.927402f,0.372294f, --0.166377f,0.978738f,0.119962f, --0.285966f,0.957794f,-0.0292047f, --0.233552f,0.97096f,0.0518564f, --0.131443f,0.981568f,0.138735f, --0.225195f,0.974079f,0.0213645f, --0.190643f,0.980844f,0.0400016f, --0.234677f,0.970688f,0.051878f, --0.269033f,0.961888f,-0.0489107f, --0.0845976f,0.996159f,0.0225919f, --0.404645f,0.907558f,0.112255f, --0.609864f,0.674076f,0.416758f, --0.498816f,0.848126f,0.178504f, --0.144072f,0.987953f,-0.0565038f, -0.166758f,0.948601f,-0.268974f, -0.264567f,0.924612f,0.274038f, --0.242512f,0.859891f,0.449195f, --0.469649f,0.864648f,0.178364f, --0.10506f,0.987899f,0.114094f, -0.522959f,0.850167f,0.0610757f, -0.207342f,0.943984f,-0.256717f, --0.370985f,0.736513f,-0.565613f, --0.196204f,0.840957f,-0.504277f, --0.176697f,0.964208f,-0.197689f, --0.102305f,0.980589f,-0.167266f, -0.103476f,0.966902f,-0.233225f, -0.176136f,0.882185f,-0.436721f, -0.1356f,0.926363f,-0.351374f, -0.144454f,0.987968f,-0.0552396f, -0.173673f,0.98445f,-0.0263929f, -0.186245f,0.978364f,-0.0900963f, -0.313839f,0.899877f,-0.302865f, -0.0432774f,0.865555f,-0.498941f, --0.311487f,0.833772f,-0.45585f, --0.00804547f,0.940342f,-0.340136f, -0.304128f,0.919914f,-0.247515f, -0.693924f,0.703662f,0.152743f, -0.239861f,0.957303f,-0.161363f, -0.0838446f,0.969769f,-0.229169f, -0.258925f,0.935636f,-0.239881f, -0.257223f,0.918931f,-0.299002f, -0.0548176f,0.967903f,0.245271f, -0.0212885f,0.963347f,0.267412f, -0.0818858f,0.973102f,0.215332f, -0.303912f,0.917546f,0.25641f, -0.304793f,0.927062f,0.218307f, -0.238677f,0.941098f,0.239517f, --0.064428f,0.967965f,0.242677f, --0.187169f,0.922119f,0.338622f, --0.088608f,0.904799f,0.416518f, -0.0498324f,0.910793f,0.409846f, -0.176362f,0.913248f,0.367253f, -0.168717f,0.938419f,0.301504f, -0.00502329f,0.962305f,0.271928f, -0.0457173f,0.940418f,0.336934f, -0.0516487f,0.913931f,0.402569f, --0.133343f,0.891616f,0.432713f, --0.271457f,0.878825f,0.392399f, --0.232052f,0.920355f,0.3148f, --0.147635f,0.961854f,0.230305f, --0.0156622f,0.96416f,0.264858f, -0.0430262f,0.93984f,0.338894f, --0.0165403f,0.899263f,0.437095f, -0.0174547f,0.845985f,0.53292f, -0.0913065f,0.841589f,0.532345f, -0.0967863f,0.903784f,0.416901f, --0.0948439f,0.973273f,0.209153f, --0.30724f,0.95163f,-0.00197291f, --0.219507f,0.974242f,0.051671f, --0.123616f,0.986822f,0.104414f, --0.209302f,0.977457f,0.0277521f, --0.245642f,0.966973f,0.0679884f, --0.189013f,0.970874f,0.147233f, --0.260969f,0.955926f,0.134541f, --0.586593f,0.772947f,0.241789f, --0.622505f,0.744412f,0.241534f, --0.343069f,0.923585f,0.171158f, -0.270136f,0.949637f,0.158794f, --0.0270125f,0.976583f,-0.213437f, --0.293688f,0.905533f,0.306199f, --0.165876f,0.923469f,0.345963f, --0.101353f,0.963266f,0.248689f, --0.0607966f,0.998139f,0.00473307f, -0.571806f,0.81892f,0.04908f, -0.496821f,0.86721f,0.0334054f, --0.0103979f,0.971297f,-0.237642f, --0.296903f,0.868994f,-0.395851f, --0.405401f,0.821757f,-0.400457f, --0.0724266f,0.96927f,-0.235097f, -0.416989f,0.879556f,-0.229132f, -0.361436f,0.845922f,-0.392148f, --0.194841f,0.930819f,-0.309213f, --0.180426f,0.920987f,-0.345297f, -0.16396f,0.957989f,-0.235318f, -0.390246f,0.873397f,-0.291351f, -0.368832f,0.745912f,-0.554597f, -0.0989123f,0.900328f,-0.423823f, --0.474178f,0.712544f,-0.517143f, --0.225662f,0.862106f,-0.453707f, -0.0544551f,0.930953f,-0.361055f, -0.547706f,0.827837f,-0.121263f, -0.394416f,0.886974f,-0.240235f, -0.0920684f,0.955894f,-0.278909f, -0.287609f,0.908713f,-0.302524f, -0.34308f,0.875033f,-0.341487f, --0.0471282f,0.962572f,0.266897f, -0.0309198f,0.953932f,0.298424f, -0.131633f,0.963671f,0.232402f, -0.278528f,0.937297f,0.209515f, -0.282669f,0.933258f,0.221646f, -0.232384f,0.927485f,0.292863f, --0.0647083f,0.957687f,0.280443f, --0.249973f,0.928177f,0.275683f, --0.129841f,0.953629f,0.271538f, -0.0843284f,0.953748f,0.288536f, -0.245794f,0.935145f,0.255127f, -0.172562f,0.957759f,0.230042f, --0.0230052f,0.954645f,0.296857f, --0.041189f,0.951248f,0.305663f, -0.00483043f,0.930995f,0.364999f, --0.165245f,0.915404f,0.367054f, --0.220878f,0.904299f,0.365316f, --0.0993279f,0.939818f,0.326919f, --0.130653f,0.959943f,0.247869f, --0.122986f,0.930904f,0.343936f, --0.00592517f,0.911134f,0.412068f, --0.1345f,0.9137f,0.383488f, --0.0693903f,0.866333f,0.494623f, -0.121472f,0.852483f,0.508447f, -0.210048f,0.85163f,0.480215f, -0.0819942f,0.889969f,0.448588f, --0.0885916f,0.940837f,0.327072f, --0.228328f,0.96901f,0.0942702f, --0.142437f,0.987843f,0.0622738f, --0.157298f,0.987135f,0.0286638f, --0.320718f,0.947161f,0.00499032f, --0.336449f,0.936473f,0.0990975f, --0.304779f,0.919932f,0.246646f, --0.589969f,0.761912f,0.267259f, --0.577652f,0.799842f,0.163009f, --0.2738f,0.948238f,0.160868f, -0.240449f,0.968762f,0.0607085f, --0.0196269f,0.999224f,-0.0341484f, --0.384279f,0.908117f,0.166292f, --0.0937293f,0.985711f,0.139963f, -0.0542133f,0.980144f,0.190731f, -0.0177665f,0.999043f,0.039964f, -0.448192f,0.892243f,0.0550135f, -0.417622f,0.800327f,0.430197f, -0.199972f,0.838529f,0.506833f, --0.0526069f,0.975321f,0.214434f, --0.547935f,0.818163f,-0.174291f, --0.280437f,0.954205f,-0.10415f, -0.341739f,0.938698f,0.0453871f, -0.346269f,0.925369f,0.15424f, --0.319444f,0.944119f,0.0812127f, --0.192857f,0.977783f,0.0821343f, -0.335818f,0.935599f,-0.108997f, -0.474712f,0.785031f,-0.397964f, -0.373974f,0.907089f,-0.193218f, -0.0523306f,0.977738f,-0.203201f, --0.41385f,0.870502f,-0.266372f, --0.377073f,0.911356f,-0.165066f, -0.0445989f,0.977381f,-0.206731f, -0.525837f,0.831576f,-0.178819f, -0.378975f,0.901633f,-0.208411f, -0.088353f,0.958416f,-0.271353f, -0.309469f,0.925076f,-0.220144f, -0.420279f,0.904173f,-0.0763995f, -0.00329705f,0.962532f,0.271149f, -0.0784063f,0.967252f,0.241403f, -0.186812f,0.966508f,0.175965f, -0.294591f,0.944303f,0.146656f, -0.242144f,0.958708f,0.149151f, -0.122249f,0.946777f,0.297772f, --0.0273117f,0.906407f,0.421521f, --0.206066f,0.9181f,0.338568f, --0.0954796f,0.950658f,0.295183f, -0.102184f,0.964671f,0.242834f, -0.213961f,0.952875f,0.215059f, -0.119187f,0.935673f,0.33213f, --0.0431159f,0.926594f,0.373584f, --0.0072858f,0.954565f,0.297913f, --0.0455381f,0.966183f,0.253806f, --0.154593f,0.937454f,0.311898f, --0.199077f,0.936411f,0.288969f, --0.136466f,0.95497f,0.263457f, --0.127877f,0.920831f,0.3684f, --0.229636f,0.912787f,0.337767f, --0.0324452f,0.91205f,0.408794f, --0.100812f,0.892675f,0.439282f, --0.166782f,0.900555f,0.401477f, -0.102011f,0.876619f,0.470247f, -0.195025f,0.830402f,0.521918f, -0.0914158f,0.843587f,0.529154f, -0.0626366f,0.873316f,0.48311f, --0.00226622f,0.929744f,0.3682f, --0.0934177f,0.966149f,0.240479f, --0.109555f,0.963702f,0.243468f, --0.302241f,0.931855f,0.200739f, --0.368178f,0.918352f,0.145171f, --0.476623f,0.864028f,0.162128f, --0.569304f,0.726984f,0.383911f, --0.64096f,0.755201f,0.137264f, --0.241026f,0.942011f,0.233501f, -0.376487f,0.905115f,0.197547f, -0.13011f,0.991259f,-0.0218225f, --0.643013f,0.733979f,-0.218653f, --0.19089f,0.942227f,0.275264f, --0.00867818f,0.931663f,0.363219f, -0.146287f,0.916711f,0.371809f, -0.32054f,0.88208f,0.345239f, -0.0976689f,0.827123f,0.55347f, -0.0475977f,0.818583f,0.572413f, -0.312042f,0.775215f,0.549246f, --0.398647f,0.872033f,0.283969f, --0.297551f,0.880657f,0.368657f, -0.0684096f,0.950263f,0.303844f, -0.473417f,0.718991f,0.50885f, --0.0712795f,0.964076f,0.255885f, --0.187608f,0.981414f,0.0403824f, -0.441688f,0.892595f,0.090477f, -0.402228f,0.910874f,0.0923076f, -0.356001f,0.889285f,0.287114f, -0.109119f,0.990916f,0.0786044f, --0.366364f,0.926283f,0.0881909f, --0.361407f,0.913864f,0.185034f, -0.114451f,0.98516f,0.127909f, -0.511212f,0.854805f,0.0892759f, -0.488262f,0.865451f,0.112231f, -0.135362f,0.990178f,0.0350016f, -0.158924f,0.983832f,0.0825671f, -0.139428f,0.973099f,0.183407f, --0.0124598f,0.997106f,0.0750005f, -0.111778f,0.989445f,0.0922193f, -0.245419f,0.967744f,0.0569325f, -0.2823f,0.95863f,0.0365395f, -0.172017f,0.973333f,0.151766f, --0.129296f,0.953534f,0.27213f, --0.0899396f,0.877846f,0.470422f, --0.0963581f,0.899855f,0.425413f, --0.0212856f,0.934761f,0.354638f, -0.147549f,0.94824f,0.281195f, -0.129526f,0.93959f,0.316849f, -0.0223606f,0.903767f,0.427441f, --0.0124316f,0.909175f,0.41623f, -0.115235f,0.910193f,0.397831f, --0.0283739f,0.950232f,0.310248f, --0.203804f,0.932573f,0.297946f, --0.13899f,0.955458f,0.260347f, --0.204301f,0.958838f,0.197208f, --0.229868f,0.915186f,0.331053f, --0.132513f,0.91447f,0.38234f, --0.151493f,0.940711f,0.3035f, --0.124022f,0.907796f,0.400656f, --0.112999f,0.914934f,0.387462f, --0.039891f,0.908327f,0.416355f, -0.0930682f,0.835427f,0.541664f, -0.161351f,0.801381f,0.575981f, -0.131487f,0.83942f,0.527339f, -0.132693f,0.857332f,0.497367f, --0.0832448f,0.920852f,0.380923f, --0.145993f,0.894645f,0.422252f, --0.213236f,0.888697f,0.405893f, --0.293641f,0.888131f,0.353551f, --0.525155f,0.788991f,0.318912f, --0.588027f,0.679363f,0.438964f, --0.478637f,0.812929f,0.331743f, --0.264049f,0.917426f,0.297671f, -0.302963f,0.900818f,0.31103f, -0.420369f,0.80167f,0.424988f, --0.470879f,0.867699f,0.159284f, --0.530406f,0.817263f,0.225279f, --0.0411983f,0.860627f,0.507566f, -0.103255f,0.833118f,0.543372f, -0.186539f,0.814428f,0.549463f, -0.132619f,0.779192f,0.612594f, -0.0761138f,0.83531f,0.544485f, -0.378863f,0.611781f,0.694397f, --0.172003f,0.719417f,0.672944f, --0.295852f,0.804769f,0.514605f, -0.0593285f,0.827842f,0.557814f, -0.323809f,0.743921f,0.584575f, -0.339913f,0.758357f,0.556197f, --0.00694706f,0.946602f,0.322331f, -0.188872f,0.934445f,0.301895f, -0.251044f,0.713229f,0.654432f, -0.351195f,0.638214f,0.685087f, -0.295602f,0.899369f,0.322109f, --0.450583f,0.880167f,0.14927f, --0.375985f,0.904392f,0.201769f, -0.158376f,0.94847f,0.274448f, -0.500024f,0.831884f,0.240719f, -0.503159f,0.8293f,0.243089f, -0.0889199f,0.964326f,0.249335f, -0.108789f,0.932871f,0.34339f, -0.066105f,0.944864f,0.320722f, --0.09433f,0.994124f,-0.0530892f, -0.0903529f,0.995715f,-0.0196726f, -0.246451f,0.969124f,-0.00783612f, -0.17532f,0.977334f,0.118663f, -0.0145033f,0.945036f,0.326645f, --0.208385f,0.89773f,0.388145f, --0.186403f,0.920929f,0.342264f, --0.0196042f,0.920127f,0.391129f, -0.088861f,0.938743f,0.332966f, -0.0904885f,0.955513f,0.280725f, -0.00776342f,0.887041f,0.461625f, -0.0357997f,0.855618f,0.516368f, -0.0251977f,0.899984f,0.435195f, -0.113155f,0.898436f,0.424273f, -0.0488401f,0.928538f,0.36801f, --0.122117f,0.962671f,0.241562f, --0.0832756f,0.977563f,0.193483f, --0.182752f,0.960599f,0.209407f, --0.340533f,0.923546f,0.176353f, --0.207225f,0.949201f,0.236801f, --0.0875863f,0.939463f,0.331268f, --0.156293f,0.945917f,0.284277f, --0.15128f,0.944026f,0.293135f, --0.133917f,0.921967f,0.363377f, --0.0187779f,0.901995f,0.431337f, -0.137151f,0.859664f,0.492105f, -0.151864f,0.841546f,0.518398f, -0.169983f,0.832825f,0.526791f, -0.0329472f,0.8585f,0.511754f, --0.148058f,0.877168f,0.456787f, --0.179554f,0.872912f,0.453636f, --0.29061f,0.863835f,0.411502f, --0.582219f,0.748049f,0.318501f, --0.586418f,0.753548f,0.297117f, --0.423744f,0.867437f,0.260755f, --0.266814f,0.914007f,0.305617f, -0.297036f,0.879751f,0.371224f, -0.301464f,0.846429f,0.438951f, --0.267915f,0.8201f,0.505626f, --0.708126f,0.705156f,0.0362171f, --0.280503f,0.856013f,0.434234f, -0.0634361f,0.843315f,0.533662f, -0.203328f,0.848496f,0.488581f, -0.157757f,0.86266f,0.480552f, --0.0108627f,0.875364f,0.483343f, --0.00732908f,0.804113f,0.594431f, -0.217513f,0.756413f,0.616869f, --0.242879f,0.903897f,0.352108f, --0.0770731f,0.775477f,0.626654f, -0.238061f,0.731126f,0.639361f, -0.459013f,0.658034f,0.596908f, -0.0332364f,0.855326f,0.517022f, --0.132848f,0.766918f,0.627844f, --0.0252308f,0.840734f,0.54086f, -0.442735f,0.688282f,0.574677f, -0.624206f,0.545029f,0.559742f, --0.216833f,0.89857f,0.381516f, --0.428783f,0.890698f,0.151005f, -0.076598f,0.986116f,0.147334f, -0.479671f,0.865386f,0.144994f, -0.542246f,0.827427f,0.146065f, -0.100899f,0.969794f,0.222079f, -0.0591096f,0.972132f,0.226859f, -0.163564f,0.950136f,0.265495f, --0.0539816f,0.998166f,0.0273959f, -0.085626f,0.996323f,0.00278248f, -0.159482f,0.986364f,0.0406345f, --0.0565903f,0.982572f,0.177057f, --0.167853f,0.932231f,0.320579f, --0.135579f,0.92648f,0.351075f, --0.12175f,0.950039f,0.287407f, --0.0275f,0.960651f,0.276393f, -0.0945575f,0.956567f,0.27575f, -0.0118837f,0.934274f,0.356358f, --0.160104f,0.889888f,0.42716f, -0.0609856f,0.903744f,0.423707f, -0.121664f,0.922268f,0.366906f, -0.148425f,0.946235f,0.287418f, -0.23463f,0.944122f,0.231479f, --0.0440541f,0.996345f,0.0731815f, --0.127251f,0.98255f,0.135658f, --0.207412f,0.958865f,0.1938f, --0.296871f,0.939382f,0.171549f, --0.278192f,0.946498f,0.163558f, --0.178451f,0.945897f,0.270988f, --0.115294f,0.937073f,0.329548f, --0.175206f,0.945254f,0.275312f, --0.191323f,0.939359f,0.284604f, --0.0822793f,0.949627f,0.302389f, -0.0583847f,0.93226f,0.357046f, -0.125066f,0.884667f,0.449136f, -0.147347f,0.866347f,0.477213f, -0.0545541f,0.865292f,0.49829f, --0.098516f,0.887377f,0.450395f, --0.209769f,0.897417f,0.388122f, --0.210182f,0.881546f,0.422729f, --0.451263f,0.852365f,0.264264f, --0.650724f,0.758775f,-0.0286192f, --0.407582f,0.890583f,0.201838f, --0.388367f,0.887583f,0.247725f, -0.193188f,0.884808f,0.424019f, -0.215311f,0.880386f,0.422566f, --0.165147f,0.855262f,0.491176f, --0.520864f,0.795129f,0.310596f, --0.488998f,0.786967f,0.37625f, -0.0562235f,0.868104f,0.493187f, -0.400928f,0.84731f,0.348313f, -0.199813f,0.978725f,-0.0465961f, --0.198621f,0.97682f,0.0798329f, --0.0891351f,0.888352f,0.450429f, -0.204835f,0.834736f,0.511135f, --0.0720813f,0.941881f,0.328121f, --0.196291f,0.972713f,0.123691f, -0.179787f,0.980826f,-0.0752149f, -0.511674f,0.853811f,0.0958982f, -0.0191479f,0.909767f,0.414677f, --0.125562f,0.89333f,0.431505f, -0.22305f,0.943278f,0.245918f, -0.527748f,0.84488f,0.0875187f, -0.598212f,0.799615f,-0.0525252f, -0.0107332f,0.903361f,0.428747f, --0.300811f,0.914951f,0.269032f, -0.179787f,0.975264f,0.128593f, -0.519301f,0.854591f,0.00126655f, -0.419398f,0.906587f,-0.0469514f, -0.0522982f,0.994257f,0.0933686f, -0.0513278f,0.996267f,0.0694112f, -0.103651f,0.993237f,0.0523089f, -0.0555975f,0.984758f,0.164805f, -0.0862163f,0.988349f,0.12543f, -0.0909734f,0.981273f,0.169784f, --0.14512f,0.970727f,0.191388f, --0.180918f,0.953611f,0.240612f, --0.140102f,0.96533f,0.22025f, --0.119189f,0.970295f,0.210526f, --0.0126783f,0.974075f,0.225869f, -0.0237961f,0.97809f,0.20682f, --0.0862872f,0.95413f,0.286688f, --0.14433f,0.944949f,0.293667f, -0.132869f,0.954959f,0.265329f, -0.22733f,0.94991f,0.214458f, -0.185536f,0.968744f,0.164655f, -0.30218f,0.927213f,0.221277f, --0.010566f,0.987352f,0.158194f, --0.227641f,0.957817f,0.175404f, --0.212635f,0.950922f,0.224799f, --0.288872f,0.93765f,0.193302f, --0.303211f,0.936666f,0.175273f, --0.283958f,0.943546f,0.170553f, --0.13575f,0.960553f,0.242714f, --0.0816944f,0.973992f,0.211345f, --0.191701f,0.977982f,0.0824724f, --0.110352f,0.986199f,0.123427f, --0.0409453f,0.971384f,0.233958f, -0.0185038f,0.933683f,0.357621f, -0.13477f,0.907601f,0.397615f, -0.0792432f,0.925049f,0.371489f, --0.0350852f,0.929789f,0.366418f, --0.159548f,0.910971f,0.380363f, --0.245138f,0.905643f,0.346003f, --0.179352f,0.926492f,0.330825f, --0.589052f,0.80668f,0.0478056f, --0.578625f,0.779472f,0.240033f, --0.471687f,0.839166f,0.270762f, -0.0987404f,0.916105f,0.388589f, -0.173592f,0.831445f,0.527792f, --0.220086f,0.704489f,0.674728f, --0.395802f,0.62503f,0.672813f, --0.417304f,0.755058f,0.505712f, -0.0513487f,0.865997f,0.497406f, -0.431689f,0.734124f,0.524124f, -0.359032f,0.884637f,0.297512f, --0.308259f,0.930686f,0.196975f, --0.34698f,0.877125f,0.332049f, -0.00851592f,0.919266f,0.393545f, -0.326193f,0.840272f,0.433061f, -0.261231f,0.960149f,-0.0993615f, -0.388612f,0.889039f,-0.242053f, -0.0354931f,0.979528f,-0.198152f, -0.0485316f,0.907873f,0.416427f, --0.0781845f,0.964592f,0.251892f, -0.47974f,0.876345f,0.0432286f, -0.568817f,0.783907f,-0.248873f, -0.483889f,0.834837f,-0.262485f, --0.220496f,0.975376f,0.00471288f, --0.25449f,0.933474f,0.252706f, -0.326168f,0.921789f,0.209569f, -0.609761f,0.790958f,0.0507595f, -0.419183f,0.900774f,-0.11354f, --0.0389936f,0.992704f,-0.114095f, -0.112818f,0.992086f,-0.0551048f, -0.140261f,0.98577f,-0.0926471f, -0.0460285f,0.981507f,0.185811f, -0.0839854f,0.981486f,0.172137f, -0.0780195f,0.983837f,0.161178f, --0.135272f,0.977846f,0.159743f, --0.233239f,0.960885f,0.149328f, --0.119476f,0.978748f,0.166665f, --0.0623017f,0.991047f,0.118089f, --0.0310067f,0.999432f,0.0132292f, --0.0037253f,0.997112f,0.0758502f, --0.0758016f,0.98526f,0.153355f, --0.143296f,0.988211f,0.0539015f, -0.103486f,0.991653f,0.076914f, -0.266632f,0.947722f,0.175298f, -0.164045f,0.978994f,0.121078f, -0.196418f,0.969063f,0.149458f, -0.0648458f,0.968138f,0.241876f, --0.21695f,0.963194f,0.158716f, --0.238014f,0.956133f,0.17076f, --0.251543f,0.948014f,0.194926f, --0.241597f,0.958745f,0.149794f, --0.248822f,0.966568f,0.0619263f, --0.195635f,0.9804f,0.0233089f, -0.00681016f,0.994726f,0.102342f, --0.0728308f,0.997328f,0.00570638f, --0.223928f,0.970021f,-0.0944255f, --0.201047f,0.979434f,0.0169867f, --0.100278f,0.986057f,0.132801f, -0.129703f,0.962794f,0.237074f, -0.129196f,0.949613f,0.28556f, --0.100355f,0.959332f,0.263838f, --0.226831f,0.927446f,0.297306f, --0.211803f,0.921673f,0.325051f, --0.16781f,0.90652f,0.387378f, --0.507141f,0.76624f,0.394569f, --0.499456f,0.740703f,0.449336f, --0.375574f,0.865361f,0.331805f, -0.0665425f,0.96722f,0.245068f, --0.127974f,0.946728f,0.295513f, --0.531445f,0.627941f,0.568557f, --0.268657f,0.746051f,0.609287f, --0.123398f,0.84105f,0.526695f, -0.113268f,0.868801f,0.482033f, -0.278975f,0.860996f,0.425274f, -0.256512f,0.783766f,0.565608f, -0.24637f,0.788587f,0.563411f, --0.207735f,0.977522f,-0.036006f, -0.0390118f,0.996098f,0.0791601f, -0.408253f,0.910351f,0.0677493f, -0.466297f,0.863647f,-0.191525f, -0.226125f,0.967725f,-0.111247f, --0.24034f,0.965221f,0.102887f, --0.130757f,0.944853f,0.300258f, -0.283435f,0.943407f,0.172188f, -0.590839f,0.8059f,-0.0378747f, -0.573782f,0.756596f,-0.313587f, -0.355206f,0.926281f,0.12583f, --0.219704f,0.910923f,0.349212f, --0.277723f,0.959254f,0.051969f, -0.340807f,0.938572f,0.0541606f, -0.677372f,0.729826f,0.0923128f, -0.49544f,0.867668f,-0.0411347f, --0.024834f,0.981688f,-0.188872f, -0.050519f,0.974996f,-0.216403f, -0.180767f,0.970256f,-0.161015f, -0.0401148f,0.977494f,0.207113f, -0.106256f,0.969045f,0.222848f, -0.0969035f,0.97128f,0.217314f, --0.118574f,0.978564f,0.16838f, --0.194437f,0.978726f,0.0655019f, --0.11441f,0.993427f,0.0037257f, -0.00229181f,0.999514f,0.0311045f, -0.0309142f,0.998007f,0.0550047f, --0.113357f,0.989867f,0.085516f, --0.111292f,0.980012f,0.164894f, --0.0212066f,0.993646f,0.110539f, -0.0241257f,0.999577f,-0.0162417f, -0.157698f,0.982481f,0.0993122f, -0.222931f,0.950361f,0.21706f, -0.18078f,0.964986f,0.190052f, -0.0702985f,0.98108f,0.180387f, --0.190259f,0.977665f,0.089291f, --0.268574f,0.956136f,0.116926f, --0.267756f,0.955804f,0.121429f, --0.211446f,0.969418f,0.124579f, --0.14687f,0.983484f,0.105776f, --0.198985f,0.979945f,-0.0106117f, --0.0887412f,0.995564f,0.0312775f, -0.0104704f,0.992989f,0.117739f, --0.125001f,0.9915f,0.0360868f, --0.238906f,0.968221f,-0.0739686f, --0.167029f,0.981518f,-0.0933989f, --0.0351406f,0.998931f,-0.030045f, -0.0130186f,0.974123f,0.225643f, --0.0745329f,0.922898f,0.377762f, --0.18971f,0.916591f,0.351953f, --0.286917f,0.902381f,0.321538f, --0.328487f,0.84853f,0.414841f, --0.591704f,0.685127f,0.424839f, --0.448564f,0.796089f,0.406241f, --0.170353f,0.888356f,0.426384f, --0.00830475f,0.908708f,0.417349f, --0.140027f,0.883683f,0.446651f, --0.599598f,0.727182f,0.334197f, --0.234879f,0.924162f,0.301258f, --0.0954672f,0.951872f,0.291248f, -0.100155f,0.948228f,0.301383f, -0.352663f,0.898478f,0.261471f, -0.217902f,0.956165f,0.19562f, -0.428441f,0.89557f,0.119967f, -0.0504867f,0.972497f,-0.227379f, --0.160086f,0.98254f,-0.0948013f, -0.319131f,0.945228f,-0.0685555f, -0.64992f,0.715088f,0.257397f, -0.0361031f,0.995429f,0.0884124f, --0.2599f,0.897768f,0.355618f, --0.17567f,0.983498f,0.0432638f, -0.53944f,0.841427f,-0.0317039f, -0.60742f,0.697232f,-0.380669f, -0.609044f,0.790595f,-0.063438f, --0.195234f,0.980448f,0.0245981f, --0.224173f,0.885759f,0.406419f, -0.0964403f,0.992198f,0.0790071f, -0.380926f,0.892571f,-0.241272f, -0.532566f,0.777301f,-0.334927f, -0.58332f,0.811668f,0.0305478f, -0.122052f,0.989417f,-0.0784701f, -0.094933f,0.975516f,-0.198385f, -0.104703f,0.956209f,-0.273317f, -0.0116109f,0.989434f,0.144515f, -0.0514824f,0.974923f,0.216505f, -0.096067f,0.950842f,0.294399f, -0.00976988f,0.964716f,0.263111f, --0.0931121f,0.98126f,0.168699f, --0.0745948f,0.982842f,0.168693f, --0.083139f,0.982475f,0.166825f, --0.0763046f,0.97088f,0.22709f, --0.130809f,0.960701f,0.244832f, --0.117161f,0.974629f,0.190711f, -0.0735371f,0.976475f,0.202706f, -0.123062f,0.984428f,0.125529f, -0.0660058f,0.995943f,0.0611663f, -0.0811078f,0.98996f,0.115763f, -0.156048f,0.953727f,0.257008f, -0.12971f,0.935453f,0.32879f, --0.0928149f,0.955298f,0.280698f, --0.264252f,0.949049f,0.171686f, --0.241724f,0.966072f,0.0909662f, --0.244999f,0.96713f,0.0680795f, --0.106995f,0.982895f,0.149898f, --0.106861f,0.990227f,0.089616f, --0.133621f,0.990932f,0.0141138f, --0.0517957f,0.998024f,0.0355675f, --0.0225779f,0.998718f,0.0453005f, --0.144281f,0.986502f,-0.0774439f, --0.157036f,0.983398f,-0.0909287f, --0.161108f,0.986936f,-0.00118469f, --0.22235f,0.965394f,0.136287f, --0.250578f,0.942366f,0.221715f, --0.217658f,0.901831f,0.373264f, --0.29708f,0.848133f,0.438651f, --0.36269f,0.819581f,0.443558f, --0.534096f,0.793842f,0.290785f, --0.584404f,0.811192f,0.0209707f, --0.1404f,0.905222f,0.401075f, --0.307079f,0.89418f,0.325797f, --0.27164f,0.834087f,0.480115f, --0.322843f,0.946322f,0.0157466f, --0.301281f,0.933652f,-0.193713f, --0.127165f,0.985755f,0.11007f, -0.121812f,0.97858f,0.165962f, -0.500139f,0.864928f,0.0419482f, -0.30357f,0.892132f,-0.334582f, -0.443241f,0.85073f,-0.282481f, -0.0967978f,0.993781f,0.0550442f, --0.201565f,0.978713f,0.0386423f, -0.209591f,0.974539f,0.0796601f, -0.481917f,0.851558f,0.20641f, --0.0224044f,0.977009f,0.212016f, --0.238315f,0.88567f,0.398491f, -0.220358f,0.960844f,0.167992f, -0.601263f,0.791797f,-0.107428f, -0.618362f,0.741713f,-0.25979f, -0.284452f,0.956119f,0.0701626f, --0.201478f,0.913131f,0.3544f, --0.20526f,0.978252f,0.0298624f, -0.352634f,0.929538f,-0.107737f, -0.649062f,0.752634f,-0.110725f, -0.490387f,0.729272f,-0.477162f, -0.431974f,0.874843f,-0.219197f, -0.184608f,0.975155f,-0.122446f, -0.192786f,0.978517f,-0.0730681f, -0.240097f,0.966116f,-0.094733f, --0.255309f,0.963455f,-0.0810722f, --0.124334f,0.990531f,0.0582188f, -0.042075f,0.979967f,0.194667f, -0.0324324f,0.965776f,0.25734f, --0.0760147f,0.965606f,0.248649f, --0.138926f,0.972343f,0.187746f, --0.0932442f,0.974882f,0.202264f, --0.0380092f,0.975147f,0.218276f, --0.0242537f,0.984345f,0.174576f, --0.0724602f,0.995976f,0.0527463f, -0.0175716f,0.997526f,0.068069f, -0.191598f,0.97051f,0.146287f, -0.0888492f,0.992747f,0.0809944f, -0.0509079f,0.989914f,0.132209f, -0.0413152f,0.988953f,0.142354f, --0.00590782f,0.97647f,0.215574f, --0.0327876f,0.94937f,0.312443f, --0.0862721f,0.978712f,0.186225f, --0.179337f,0.981669f,0.0645377f, --0.255621f,0.960924f,0.106226f, --0.157413f,0.981394f,0.109943f, --0.0325878f,0.996293f,0.0796149f, --0.0627116f,0.997982f,-0.00999288f, --0.0263234f,0.995733f,-0.0884504f, -0.00359159f,0.990572f,-0.136946f, --0.0963f,0.991181f,-0.0910356f, --0.255814f,0.966717f,-0.00409974f, --0.292954f,0.950051f,0.107618f, --0.259513f,0.946888f,0.189886f, --0.274998f,0.934354f,0.226623f, --0.37248f,0.885745f,0.276974f, --0.384203f,0.849481f,0.361622f, --0.326853f,0.86434f,0.382208f, --0.213332f,0.922586f,0.321442f, --0.528611f,0.848285f,0.0313709f, --0.466119f,0.869006f,0.166018f, --0.226659f,0.921685f,0.314837f, --0.225942f,0.929604f,0.291181f, -0.262979f,0.943638f,0.200972f, --0.158823f,0.970135f,-0.183342f, --0.433654f,0.893597f,-0.115884f, -0.0458639f,0.99877f,-0.0188405f, -0.612149f,0.789064f,0.0514904f, -0.423383f,0.878106f,-0.222881f, -0.0967751f,0.930754f,-0.352606f, -0.0811144f,0.996202f,0.0316668f, --0.413686f,0.895072f,-0.166465f, -0.148131f,0.951189f,0.270735f, -0.436798f,0.864787f,0.247692f, -0.0437864f,0.959427f,0.278536f, --0.28501f,0.956226f,0.0663364f, -0.510274f,0.859616f,0.0260981f, -0.648806f,0.686419f,-0.328451f, -0.586912f,0.808674f,0.0397475f, --0.0852935f,0.966768f,0.241009f, --0.148057f,0.961052f,0.233361f, -0.164136f,0.983527f,-0.0757203f, -0.450314f,0.849987f,-0.273386f, -0.550526f,0.728504f,-0.407679f, -0.58281f,0.780161f,-0.227338f, -0.258267f,0.941325f,-0.21727f, -0.0807909f,0.98982f,-0.117172f, -0.0801488f,0.996327f,0.0301511f, -0.239863f,0.961671f,0.132871f, --0.229647f,0.969202f,0.0889415f, --0.172859f,0.981826f,0.0783421f, --0.0626565f,0.996388f,0.0573105f, --0.0572909f,0.992727f,0.105883f, --0.0279351f,0.983375f,0.179427f, --0.00285096f,0.99214f,0.125102f, --0.084025f,0.99632f,-0.0168937f, --0.0732377f,0.997041f,-0.0233556f, --0.0045065f,0.999839f,0.0173404f, -0.0203121f,0.999722f,0.0119547f, --0.0506539f,0.996487f,-0.0666886f, -0.119651f,0.992498f,0.0251293f, -0.0686084f,0.989615f,0.126312f, -0.000108814f,0.982339f,0.187109f, -0.0874025f,0.98865f,0.122196f, --0.0625717f,0.997577f,0.0304034f, --0.0486926f,0.992353f,0.113426f, -0.0140738f,0.989644f,0.142855f, --0.151919f,0.980609f,0.123804f, --0.280176f,0.959074f,0.0409668f, --0.112828f,0.992642f,-0.0439511f, -0.0530002f,0.995827f,-0.0742939f, -0.0297885f,0.985001f,-0.169959f, -0.0528437f,0.970999f,-0.233169f, --0.0380639f,0.977109f,-0.209305f, --0.249056f,0.968138f,-0.0260696f, --0.370842f,0.913812f,0.165599f, --0.310025f,0.907402f,0.283736f, --0.313659f,0.908343f,0.276641f, --0.360766f,0.88042f,0.307747f, --0.383668f,0.851108f,0.358349f, --0.392242f,0.857478f,0.332984f, --0.296931f,0.900087f,0.318865f, --0.199402f,0.936164f,0.289543f, --0.412291f,0.885214f,0.215434f, --0.62242f,0.781068f,-0.0502514f, --0.272781f,0.928261f,0.252828f, --0.317665f,0.921151f,0.224876f, -0.0813846f,0.925309f,0.370378f, -0.00278871f,0.889899f,0.45615f, --0.460626f,0.879338f,0.120782f, -0.0601251f,0.985077f,0.161272f, -0.599887f,0.787248f,0.142742f, -0.617017f,0.753279f,0.227729f, -0.13665f,0.981422f,0.134675f, -0.136502f,0.974756f,0.176687f, --0.27066f,0.954113f,-0.128105f, --0.13295f,0.980241f,-0.146465f, -0.409773f,0.909514f,-0.0697851f, -0.339811f,0.93455f,0.10557f, --0.243979f,0.943604f,-0.223798f, -0.572252f,0.820076f,0.00181093f, -0.58136f,0.813444f,0.0181706f, -0.213313f,0.927464f,0.307095f, --0.0427767f,0.853854f,0.518751f, -0.0717407f,0.97577f,0.206702f, -0.349298f,0.936925f,0.0127626f, -0.643074f,0.765767f,0.00757208f, -0.584117f,0.763349f,-0.275872f, -0.414478f,0.906497f,-0.0804466f, -0.213842f,0.975055f,-0.0594842f, --0.00469446f,0.990505f,-0.137399f, --0.0685672f,0.992236f,-0.103764f, -0.0844774f,0.996384f,-0.00904741f, --0.320391f,0.938064f,0.131853f, --0.173519f,0.96335f,0.204565f, --0.0123366f,0.973468f,0.228492f, --0.018009f,0.983892f,0.177855f, --0.10447f,0.992257f,0.0671745f, -0.0409931f,0.988078f,0.148399f, -0.0370075f,0.994865f,0.0941976f, --0.0471895f,0.997972f,-0.0427132f, --0.0371271f,0.993135f,-0.110921f, -0.0109117f,0.996203f,-0.0863686f, -0.0455917f,0.995961f,-0.0773449f, --0.0321894f,0.986545f,-0.160288f, --0.0649603f,0.996397f,0.0545189f, -0.00369488f,0.985567f,0.169244f, -0.226168f,0.962189f,0.151787f, -0.029392f,0.999567f,0.00117257f, --0.13579f,0.984206f,-0.113581f, --0.10103f,0.992288f,-0.0718192f, --0.125171f,0.991084f,0.0456533f, --0.108309f,0.993989f,0.015999f, --0.0231464f,0.995269f,-0.0943563f, -0.0270486f,0.99325f,-0.112795f, -0.141677f,0.989359f,-0.0331051f, -0.0268575f,0.994547f,-0.100767f, --0.194101f,0.980932f,0.009818f, --0.41139f,0.899763f,0.145547f, --0.482013f,0.8562f,0.185973f, --0.415606f,0.872343f,0.257468f, --0.291757f,0.884021f,0.365218f, --0.316561f,0.886381f,0.337814f, --0.406f,0.884827f,0.22857f, --0.363525f,0.905831f,0.217534f, --0.301242f,0.93366f,0.193734f, --0.208193f,0.941974f,0.263325f, --0.164184f,0.932027f,0.323063f, --0.4694f,0.88027f,-0.0691917f, --0.525104f,0.840943f,-0.130688f, --0.256903f,0.950739f,0.17348f, --0.180022f,0.968548f,0.171775f, -0.0734506f,0.860739f,0.50372f, --0.205317f,0.895889f,0.393991f, -0.0472127f,0.984089f,0.171289f, -0.492639f,0.869295f,-0.040419f, -0.615313f,0.776504f,0.135761f, -0.240143f,0.940103f,0.241946f, -0.0961855f,0.982412f,0.160044f, -0.107308f,0.976554f,0.186622f, --0.0192621f,0.988216f,-0.151846f, -0.243819f,0.934285f,-0.260122f, -0.363158f,0.92047f,-0.144401f, --0.0181857f,0.911833f,-0.410158f, -0.13216f,0.935755f,-0.326948f, -0.234069f,0.876493f,0.42068f, --0.0429998f,0.864233f,0.501251f, -0.30178f,0.838678f,0.453374f, -0.334916f,0.905993f,0.258858f, -0.486799f,0.865003f,0.121641f, -0.551114f,0.813232f,-0.186886f, -0.639118f,0.75121f,0.164956f, -0.383938f,0.890692f,0.243432f, -0.354878f,0.921145f,0.159855f, -0.162961f,0.98584f,-0.0395363f, --0.0637937f,0.974986f,-0.212914f, --0.0365262f,0.968846f,-0.244954f, --0.281965f,0.951785f,0.120834f, --0.274882f,0.955225f,0.109473f, --0.104135f,0.948711f,0.298502f, -0.0826411f,0.912269f,0.401168f, -0.0342531f,0.97031f,0.239425f, --0.0365634f,0.991589f,0.124154f, -0.134024f,0.975461f,0.174679f, -0.109589f,0.99345f,0.032348f, -0.0453955f,0.994687f,-0.0923934f, --0.0149079f,0.988982f,-0.147281f, -0.0512217f,0.992549f,-0.110554f, -0.0167819f,0.988638f,-0.149377f, --0.222271f,0.949144f,-0.222982f, --0.0921327f,0.987637f,-0.126823f, -0.189567f,0.98184f,-0.00744372f, -0.205171f,0.976356f,0.0680753f, --0.00982996f,0.993812f,-0.110639f, --0.0883427f,0.978311f,-0.18736f, --0.198236f,0.955921f,-0.216604f, --0.180283f,0.972159f,-0.149685f, -0.0029493f,0.99947f,-0.0324137f, --0.0433514f,0.998534f,-0.0324142f, -0.0405175f,0.99421f,0.0995223f, -0.00286263f,0.981263f,0.19265f, --0.296663f,0.921382f,0.251091f, --0.412123f,0.867858f,0.277446f, --0.439996f,0.871969f,0.214648f, --0.457669f,0.875232f,0.156552f, --0.384822f,0.899193f,0.208242f, --0.276213f,0.916653f,0.288882f, --0.314226f,0.91283f,0.260774f, --0.345662f,0.91535f,0.206522f, --0.311859f,0.934366f,0.17235f, --0.323293f,0.931681f,0.165688f, --0.218081f,0.943645f,0.248946f, -0.00414662f,0.967721f,0.251991f, --0.350612f,0.910773f,-0.218092f, --0.590427f,0.768592f,-0.246296f, --0.263693f,0.937904f,0.225393f, --0.149885f,0.945975f,0.287518f, --0.0723712f,0.947676f,0.310922f, -0.303995f,0.902765f,0.304306f, -0.615729f,0.768916f,0.172179f, -0.376573f,0.870472f,0.316971f, -0.258103f,0.862435f,0.435417f, -0.208037f,0.965523f,0.156476f, -0.041711f,0.997309f,0.0602974f, -0.0896451f,0.984172f,0.152868f, -0.200861f,0.950569f,0.236798f, -0.331115f,0.861074f,0.385894f, -0.343908f,0.839357f,0.420961f, --0.162885f,0.985003f,0.0568977f, --0.0608521f,0.991774f,0.112611f, -0.279417f,0.937386f,0.207929f, -0.438178f,0.898268f,0.033396f, -0.516016f,0.854846f,-0.0544561f, -0.550254f,0.781096f,-0.295143f, -0.499018f,0.830127f,-0.248738f, -0.421585f,0.905472f,0.0488414f, -0.355515f,0.918443f,0.173411f, -0.416018f,0.882036f,0.221226f, -0.346021f,0.922667f,0.170161f, -0.0862406f,0.994799f,-0.0542001f, -0.0251294f,0.989963f,-0.139071f, --0.167311f,0.982002f,0.0876306f, --0.296088f,0.953872f,0.0496014f, --0.309819f,0.944071f,0.112878f, -0.0107419f,0.974593f,0.223724f, -0.235566f,0.938548f,0.252263f, -0.0528759f,0.995406f,0.0798236f, -0.106055f,0.992977f,0.0524375f, -0.227694f,0.967451f,0.110427f, -0.15013f,0.988604f,0.0110517f, -0.0292872f,0.989448f,-0.141897f, -0.0113647f,0.978518f,-0.205848f, -0.0966514f,0.981912f,-0.162811f, --0.0834695f,0.969158f,-0.231875f, --0.173766f,0.92349f,-0.34201f, -0.0289323f,0.967596f,-0.250839f, -0.166759f,0.980973f,-0.0994165f, -0.0796755f,0.992423f,-0.0935347f, --0.0109031f,0.993494f,-0.113363f, --0.181202f,0.957527f,-0.224295f, --0.231371f,0.948894f,-0.214636f, --0.0963906f,0.978232f,-0.183771f, --0.0964169f,0.992283f,-0.0779687f, --0.114591f,0.992373f,0.045429f, --0.0476997f,0.984744f,0.167343f, --0.353531f,0.929974f,0.100818f, --0.42903f,0.892447f,0.139543f, --0.399459f,0.902474f,0.161164f, --0.44275f,0.883954f,0.150326f, --0.416721f,0.891582f,0.177271f, --0.364313f,0.907101f,0.210818f, --0.329954f,0.890729f,0.312622f, --0.308128f,0.891277f,0.33269f, --0.248313f,0.912421f,0.325314f, --0.264673f,0.92449f,0.274348f, --0.221501f,0.958108f,0.181568f, --0.00722143f,0.985032f,0.17222f, -0.0811419f,0.973825f,0.212324f, --0.519461f,0.82914f,-0.206608f, --0.561212f,0.816969f,-0.132674f, --0.10198f,0.978452f,0.179533f, --0.0294922f,0.994047f,0.104885f, -0.212965f,0.975972f,0.0461033f, -0.39072f,0.902699f,0.180202f, -0.284816f,0.877828f,0.385096f, -0.371584f,0.726424f,0.578129f, -0.415725f,0.734903f,0.535809f, -0.0647658f,0.913533f,0.401575f, -0.0316961f,0.895539f,0.443852f, --0.0215836f,0.930013f,0.366891f, -0.0389377f,0.900411f,0.433293f, -0.182398f,0.888094f,0.421923f, -0.319795f,0.864372f,0.388061f, -0.179682f,0.983355f,0.0269752f, -0.358016f,0.913314f,-0.19412f, -0.445422f,0.82688f,-0.343321f, -0.564533f,0.736553f,-0.372547f, -0.511683f,0.792162f,-0.332656f, -0.362215f,0.931906f,0.0187495f, -0.332114f,0.925718f,0.180958f, -0.376936f,0.924108f,0.0628019f, -0.34207f,0.939661f,0.00505146f, -0.432513f,0.89733f,0.0879243f, -0.250624f,0.96783f,0.022189f, -0.113333f,0.993448f,0.0146943f, --0.330108f,0.943938f,0.00323688f, --0.32108f,0.944743f,0.0660874f, --0.312445f,0.949733f,0.0196284f, --0.0425447f,0.998988f,-0.0145795f, -0.234895f,0.971633f,0.0274452f, -0.205978f,0.978297f,0.0225396f, -0.0556133f,0.99289f,-0.10525f, -0.149272f,0.988455f,-0.0259672f, -0.25486f,0.966188f,0.0390683f, -0.206371f,0.977859f,-0.0346908f, -0.0798975f,0.983688f,-0.161166f, -0.0387149f,0.980238f,-0.193996f, --0.0261652f,0.985317f,-0.168719f, --0.115457f,0.963019f,-0.243441f, --0.0914394f,0.962229f,-0.256427f, -0.0382488f,0.992063f,-0.119784f, -0.0800161f,0.996698f,-0.0137989f, -0.0187475f,0.998138f,-0.0580508f, --0.073595f,0.994051f,-0.0802936f, --0.224165f,0.957926f,-0.179241f, --0.16346f,0.967941f,-0.190711f, --0.19173f,0.978244f,-0.0792358f, --0.275576f,0.961029f,-0.0219235f, --0.0407932f,0.98802f,0.148838f, --0.278629f,0.956556f,0.085827f, --0.465684f,0.878931f,0.103047f, --0.438529f,0.89146f,0.11398f, --0.455089f,0.880964f,0.129601f, --0.457802f,0.879895f,0.127287f, --0.406331f,0.89051f,0.204664f, --0.386395f,0.891456f,0.236654f, --0.321818f,0.921226f,0.218577f, --0.271011f,0.935727f,0.22576f, --0.198383f,0.944022f,0.263564f, --0.105727f,0.975806f,0.191373f, --0.0832756f,0.987941f,0.130528f, -0.0931562f,0.956641f,0.27597f, --0.216408f,0.96162f,0.168686f, --0.648586f,0.688743f,-0.323988f, --0.276841f,0.843915f,-0.459527f, --0.060911f,0.935148f,-0.348981f, -0.243821f,0.963831f,-0.107611f, -0.35478f,0.93349f,-0.0522288f, -0.124674f,0.987025f,-0.101179f, -0.106145f,0.993646f,0.0374371f, -0.264307f,0.911176f,0.316069f, -0.180037f,0.821936f,0.540378f, -0.0976487f,0.839888f,0.533903f, -0.242869f,0.82432f,0.511381f, -0.296956f,0.900742f,0.316987f, -0.37446f,0.92343f,0.0840066f, -0.38614f,0.913414f,-0.128727f, -0.497691f,0.838063f,-0.223505f, -0.399217f,0.778523f,-0.484281f, -0.607215f,0.684189f,-0.403949f, -0.455879f,0.835157f,-0.307715f, -0.317815f,0.943806f,-0.0906903f, -0.166917f,0.983806f,0.0653043f, -0.277188f,0.953387f,0.119249f, -0.491287f,0.85011f,0.189606f, -0.3858f,0.919271f,0.0780984f, -0.390109f,0.91635f,0.0900968f, -0.247947f,0.964668f,0.0890966f, -0.0188396f,0.999506f,0.0251451f, --0.249227f,0.949063f,0.192782f, --0.24873f,0.963608f,0.0979465f, --0.225537f,0.968208f,-0.108193f, --0.0586638f,0.984304f,-0.166448f, -0.193919f,0.980395f,-0.0349386f, -0.232927f,0.972341f,0.0172453f, -0.165218f,0.985248f,-0.0445953f, -0.10666f,0.982482f,-0.152814f, -0.176402f,0.976328f,-0.125164f, -0.217875f,0.975941f,-0.00837002f, -0.138055f,0.990338f,0.0130638f, -0.0914598f,0.995289f,-0.0321788f, --0.014672f,0.992233f,-0.123523f, --0.0701479f,0.990985f,-0.114142f, --0.0940689f,0.987781f,-0.124254f, --0.152176f,0.977744f,-0.144426f, -0.043676f,0.996991f,0.0640382f, -0.0457416f,0.996307f,0.07266f, --0.0198973f,0.997072f,0.0738311f, --0.119455f,0.990174f,-0.0727032f, --0.224875f,0.962572f,-0.151282f, --0.250045f,0.966903f,-0.0507448f, --0.319974f,0.944248f,-0.0775328f, --0.16005f,0.987102f,-0.00365841f, --0.307005f,0.947659f,0.0876954f, --0.490256f,0.846833f,0.206209f, --0.400386f,0.879926f,0.255778f, --0.427515f,0.880624f,0.204282f, --0.477897f,0.856347f,0.195663f, --0.43217f,0.864768f,0.255745f, --0.342474f,0.92438f,0.16803f, --0.284468f,0.956998f,0.0568588f, --0.290121f,0.956708f,0.023234f, --0.249156f,0.966838f,0.0560771f, --0.0655515f,0.986836f,0.147842f, --0.100568f,0.984251f,0.145384f, --0.0191778f,0.985445f,0.168911f, --0.0443403f,0.97787f,0.204462f, --0.28653f,0.957033f,-0.044587f, --0.127864f,0.901634f,-0.413166f, --0.0930849f,0.861283f,-0.499526f, --0.10032f,0.791759f,-0.60254f, -0.277857f,0.863349f,-0.421218f, -0.0733471f,0.944573f,-0.320003f, -0.0656198f,0.995434f,-0.0693225f, -0.0994234f,0.993172f,-0.0610351f, -0.0758799f,0.991718f,0.103618f, -0.0755546f,0.978148f,0.193698f, -0.318521f,0.931105f,0.177731f, -0.532035f,0.846717f,0.00302226f, -0.479952f,0.801468f,-0.356785f, -0.444207f,0.753204f,-0.485143f, -0.599635f,0.661874f,-0.449845f, -0.467802f,0.782561f,-0.410805f, -0.194572f,0.899472f,-0.391269f, -0.334078f,0.938895f,-0.0828733f, -0.236858f,0.971355f,0.0191963f, -0.177255f,0.983392f,0.0389945f, -0.22691f,0.973661f,-0.0222777f, -0.408661f,0.912593f,0.013075f, -0.394434f,0.908333f,0.139114f, -0.34039f,0.913901f,0.221176f, -0.340162f,0.904445f,0.257428f, -0.21637f,0.954077f,0.207173f, --0.190356f,0.960699f,0.202044f, --0.0745122f,0.978557f,0.192026f, --0.0103556f,0.997337f,0.0721953f, --0.102208f,0.994222f,-0.0328074f, -0.0538732f,0.998534f,0.00527007f, -0.220064f,0.97523f,-0.0223306f, -0.22889f,0.972208f,-0.0492086f, -0.203387f,0.976813f,-0.0668524f, -0.112155f,0.987122f,-0.114071f, -0.137033f,0.989998f,-0.0335468f, -0.125928f,0.990544f,-0.0544465f, -0.164164f,0.983484f,-0.0762248f, -0.056178f,0.987899f,-0.14457f, --0.125491f,0.977887f,-0.167299f, --0.0763702f,0.993552f,-0.0837951f, --0.140516f,0.986451f,-0.0846751f, --0.138825f,0.988035f,-0.0671838f, -0.0272382f,0.998662f,0.0439583f, -0.051406f,0.998673f,0.00322772f, -0.0131796f,0.996364f,-0.0841692f, --0.197723f,0.973335f,-0.116299f, --0.315939f,0.94482f,-0.0865842f, --0.273936f,0.961179f,-0.0330844f, --0.278588f,0.957771f,-0.0711653f, --0.371629f,0.922753f,0.102078f, --0.589295f,0.797687f,0.128167f, --0.394808f,0.893641f,0.213383f, --0.419749f,0.89327f,0.160869f, --0.503386f,0.848953f,0.160878f, --0.392151f,0.910681f,0.129912f, --0.194389f,0.97789f,0.0771005f, --0.210697f,0.97754f,0.00473511f, --0.261758f,0.965059f,0.0120029f, --0.306606f,0.951531f,-0.0240962f, --0.191391f,0.98062f,0.0418887f, --0.0805366f,0.9875f,0.135492f, --0.0197042f,0.996843f,0.0769187f, --0.0102082f,0.996001f,0.0887568f, --0.106967f,0.993499f,0.0389638f, --0.0299932f,0.997488f,-0.0641764f, -0.166392f,0.98551f,-0.0329295f, -0.122834f,0.919366f,-0.373736f, -0.0989442f,0.860803f,-0.499228f, --0.16483f,0.786842f,-0.594736f, --0.139994f,0.854441f,-0.500331f, -0.037386f,0.884593f,-0.464864f, --0.0340706f,0.910599f,-0.411885f, -0.0643546f,0.934103f,-0.351155f, -0.330549f,0.864687f,-0.378225f, -0.61879f,0.706641f,-0.343158f, -0.664468f,0.668218f,-0.334614f, -0.535603f,0.737564f,-0.411252f, -0.392926f,0.807647f,-0.439677f, -0.299634f,0.936543f,-0.181953f, -0.20385f,0.978529f,-0.030423f, -0.255219f,0.962099f,-0.0960637f, -0.218057f,0.97044f,-0.103423f, -0.152183f,0.981776f,-0.113823f, -0.287579f,0.953452f,-0.0907011f, -0.354102f,0.933846f,-0.0504376f, -0.271766f,0.955964f,0.110796f, -0.254566f,0.942907f,0.214762f, -0.330431f,0.909031f,0.253925f, -0.276649f,0.934017f,0.226003f, --0.276078f,0.960525f,0.0342386f, --0.126608f,0.988039f,0.088024f, --0.0433883f,0.982429f,0.181523f, --0.0351658f,0.95918f,0.280603f, -0.130316f,0.978179f,0.161815f, -0.34012f,0.939563f,0.0392436f, -0.225269f,0.971719f,-0.0708295f, -0.186144f,0.981343f,-0.0481244f, -0.117145f,0.991402f,-0.0582961f, -0.122374f,0.988553f,-0.0882497f, -0.217284f,0.968092f,-0.124844f, -0.168939f,0.967628f,-0.1875f, -0.0966952f,0.983818f,-0.150838f, --0.108071f,0.971789f,-0.209635f, --0.167419f,0.956466f,-0.239047f, --0.15925f,0.972646f,-0.169115f, --0.169755f,0.972705f,-0.158205f, -0.0352685f,0.991682f,-0.123784f, -0.0984439f,0.980655f,-0.169186f, -0.0318934f,0.989724f,-0.139387f, --0.246309f,0.963763f,-0.102435f, --0.355567f,0.934631f,-0.00599911f, --0.265814f,0.963735f,-0.0236194f, --0.351588f,0.935043f,-0.0456126f, --0.494494f,0.858936f,0.133056f, --0.559402f,0.824266f,0.0874941f, --0.405326f,0.914016f,0.0169127f, --0.376559f,0.926338f,0.010028f, --0.448864f,0.890609f,-0.0730511f, --0.3487f,0.913403f,-0.210007f, --0.225518f,0.948441f,-0.222713f, --0.278172f,0.957801f,-0.0723737f, --0.296428f,0.947861f,0.117f, --0.260326f,0.954501f,0.14546f, --0.208806f,0.976306f,0.0568064f, --0.0937503f,0.995595f,-0.00141652f, -0.0211825f,0.998587f,-0.0487327f, --0.0203898f,0.998016f,-0.0595622f, --0.117256f,0.992273f,-0.0405676f, -0.0346735f,0.999272f,0.0158994f, -0.165596f,0.985653f,-0.0326431f, -0.277068f,0.959929f,-0.0420538f, -0.211278f,0.971116f,-0.110882f, -0.138826f,0.972226f,-0.188423f, -0.0186164f,0.920791f,-0.389612f, -0.00693313f,0.891348f,-0.453267f, --0.0471378f,0.869656f,-0.491403f, -0.135484f,0.84445f,-0.518217f, -0.351566f,0.784405f,-0.510988f, -0.399468f,0.772299f,-0.493943f, -0.574953f,0.790421f,-0.211338f, -0.577809f,0.813449f,-0.0666111f, -0.451377f,0.892327f,0.00336233f, -0.237932f,0.970883f,-0.0278435f, -0.170635f,0.975266f,-0.140498f, -0.305065f,0.94416f,-0.124487f, -0.219111f,0.958291f,-0.183492f, -0.160317f,0.981326f,-0.106286f, -0.222178f,0.974771f,-0.021419f, -0.23168f,0.971792f,0.0441002f, -0.140177f,0.984507f,0.105338f, -0.184383f,0.966339f,0.179422f, -0.307531f,0.911743f,0.272303f, -0.342083f,0.879118f,0.331859f, --0.245266f,0.968917f,0.0323163f, --0.176433f,0.984311f,-0.00156667f, --0.164847f,0.983548f,0.0738887f, --0.0271087f,0.959686f,0.279762f, -0.210185f,0.960158f,0.18417f, -0.386525f,0.917795f,0.0908302f, -0.288585f,0.956426f,0.04436f, -0.157424f,0.986731f,-0.0397454f, -0.194229f,0.980956f,0.000793421f, -0.143953f,0.978f,-0.150974f, -0.243865f,0.955091f,-0.168319f, -0.151307f,0.968911f,-0.195749f, -0.0861511f,0.987302f,-0.133462f, --0.0343302f,0.988258f,-0.148887f, --0.149683f,0.954065f,-0.259529f, --0.180054f,0.943807f,-0.277143f, --0.182632f,0.946912f,-0.26458f, -0.0250152f,0.97257f,-0.23126f, -0.0655433f,0.96826f,-0.241197f, -0.00940225f,0.990707f,-0.135685f, --0.313822f,0.94168f,-0.121471f, --0.325919f,0.940955f,0.0915474f, --0.245857f,0.968763f,-0.0324418f, --0.38384f,0.920444f,-0.0738245f, --0.542624f,0.834584f,0.0950211f, --0.496894f,0.865347f,0.0653522f, --0.40471f,0.910862f,-0.0808731f, --0.336326f,0.940002f,-0.0572751f, --0.384947f,0.90765f,-0.167296f, --0.26052f,0.919475f,-0.294439f, --0.278076f,0.879766f,-0.385599f, --0.415096f,0.880667f,-0.2283f, --0.411169f,0.907675f,0.0840562f, --0.22106f,0.940981f,0.256296f, --0.105371f,0.978797f,0.175653f, --0.0100537f,0.999811f,0.0166273f, -0.0459065f,0.991326f,-0.123151f, --0.0151969f,0.991011f,-0.132912f, --0.164041f,0.976761f,-0.137947f, -0.00793599f,0.998771f,-0.0489272f, -0.178958f,0.98335f,-0.031577f, -0.314466f,0.949045f,-0.0206086f, -0.240757f,0.963062f,-0.120617f, -0.126531f,0.982046f,-0.139911f, -0.0695074f,0.9956f,-0.062839f, -0.0427419f,0.998852f,-0.02164f, --0.0292495f,0.993565f,-0.109419f, -0.176081f,0.974549f,-0.138744f, -0.405406f,0.900659f,-0.156393f, -0.48202f,0.865956f,-0.133334f, -0.477566f,0.852664f,-0.211881f, -0.526274f,0.839922f,-0.132537f, -0.390331f,0.920621f,-0.0098857f, -0.349443f,0.931118f,0.104442f, -0.205374f,0.96487f,-0.163851f, -0.359411f,0.921384f,-0.147904f, -0.161592f,0.938137f,-0.306246f, -0.0124614f,0.982178f,-0.187542f, -0.143914f,0.986786f,0.0744463f, -0.270333f,0.949018f,0.162126f, -0.132f,0.991194f,0.0105184f, -0.131712f,0.991267f,0.00644011f, -0.199003f,0.974024f,0.108048f, -0.274163f,0.928953f,0.248757f, -}; - -btScalar Landscape01Tex[] = { -0.507813f,0.0078125f, -0.507813f,0.0f, -0.515625f,0.0078125f, -0.515625f,0.0f, -0.523438f,0.0078125f, -0.523438f,0.0f, -0.53125f,0.0078125f, -0.53125f,0.0f, -0.539063f,0.0078125f, -0.539063f,0.0f, -0.546875f,0.0078125f, -0.546875f,0.0f, -0.554688f,0.0078125f, -0.554688f,0.0f, -0.5625f,0.0078125f, -0.5625f,0.0f, -0.570313f,0.0078125f, -0.570313f,0.0f, -0.578125f,0.0078125f, -0.578125f,0.0f, -0.585938f,0.0078125f, -0.585938f,0.0f, -0.59375f,0.0078125f, -0.59375f,0.0f, -0.601563f,0.0078125f, -0.601563f,0.0f, -0.609375f,0.0078125f, -0.609375f,0.0f, -0.617188f,0.0078125f, -0.617188f,0.0f, -0.625f,0.0078125f, -0.625f,0.0f, -0.632813f,0.0078125f, -0.632813f,0.0f, -0.640625f,0.0078125f, -0.640625f,0.0f, -0.648438f,0.0078125f, -0.648438f,0.0f, -0.65625f,0.0078125f, -0.65625f,0.0f, -0.664063f,0.0078125f, -0.664063f,0.0f, -0.671875f,0.0078125f, -0.671875f,0.0f, -0.679688f,0.0078125f, -0.679688f,0.0f, -0.6875f,0.0078125f, -0.6875f,0.0f, -0.695313f,0.0078125f, -0.695313f,0.0f, -0.703125f,0.0078125f, -0.703125f,0.0f, -0.710938f,0.0078125f, -0.710938f,0.0f, -0.71875f,0.0078125f, -0.71875f,0.0f, -0.726563f,0.0078125f, -0.726563f,0.0f, -0.734375f,0.0078125f, -0.734375f,0.0f, -0.742188f,0.0078125f, -0.742188f,0.0f, -0.75f,0.0078125f, -0.75f,0.0f, -0.757813f,0.0078125f, -0.757813f,0.0f, -0.765625f,0.0078125f, -0.765625f,0.0f, -0.773438f,0.0078125f, -0.773438f,0.0f, -0.78125f,0.0078125f, -0.78125f,0.0f, -0.789063f,0.0078125f, -0.789063f,0.0f, -0.796875f,0.0078125f, -0.796875f,0.0f, -0.804688f,0.0078125f, -0.804688f,0.0f, -0.8125f,0.0078125f, -0.8125f,0.0f, -0.820313f,0.0078125f, -0.820313f,0.0f, -0.828125f,0.0078125f, -0.828125f,0.0f, -0.835938f,0.0078125f, -0.835938f,0.0f, -0.84375f,0.0078125f, -0.84375f,0.0f, -0.851563f,0.0078125f, -0.851563f,0.0f, -0.859375f,0.0078125f, -0.859375f,0.0f, -0.867188f,0.0078125f, -0.867188f,0.0f, -0.875f,0.0078125f, -0.875f,0.0f, -0.882813f,0.0078125f, -0.882813f,0.0f, -0.890625f,0.0078125f, -0.890625f,0.0f, -0.898438f,0.0078125f, -0.898438f,0.0f, -0.90625f,0.0078125f, -0.90625f,0.0f, -0.914063f,0.0078125f, -0.914063f,0.0f, -0.921875f,0.0078125f, -0.921875f,0.0f, -0.929688f,0.0078125f, -0.929688f,0.0f, -0.9375f,0.0078125f, -0.9375f,0.0f, -0.945313f,0.0078125f, -0.945313f,0.0f, -0.953125f,0.0078125f, -0.953125f,0.0f, -0.960938f,0.0078125f, -0.960938f,0.0f, -0.96875f,0.0078125f, -0.96875f,0.0f, -0.976563f,0.0078125f, -0.976563f,0.0f, -0.984375f,0.0078125f, -0.984375f,0.0f, -0.992188f,0.0078125f, -0.992188f,0.0f, -1.0f,0.0078125f, -1.0f,0.0f, -0.507813f,0.015625f, -0.515625f,0.015625f, -0.523438f,0.015625f, -0.53125f,0.015625f, -0.539063f,0.015625f, -0.546875f,0.015625f, -0.554688f,0.015625f, -0.5625f,0.015625f, -0.570313f,0.015625f, -0.578125f,0.015625f, -0.585938f,0.015625f, -0.59375f,0.015625f, -0.601563f,0.015625f, -0.609375f,0.015625f, -0.617188f,0.015625f, -0.625f,0.015625f, -0.632813f,0.015625f, -0.640625f,0.015625f, -0.648438f,0.015625f, -0.65625f,0.015625f, -0.664063f,0.015625f, -0.671875f,0.015625f, -0.679688f,0.015625f, -0.6875f,0.015625f, -0.695313f,0.015625f, -0.703125f,0.015625f, -0.710938f,0.015625f, -0.71875f,0.015625f, -0.726563f,0.015625f, -0.734375f,0.015625f, -0.742188f,0.015625f, -0.75f,0.015625f, -0.757813f,0.015625f, -0.765625f,0.015625f, -0.773438f,0.015625f, -0.78125f,0.015625f, -0.789063f,0.015625f, -0.796875f,0.015625f, -0.804688f,0.015625f, -0.8125f,0.015625f, -0.820313f,0.015625f, -0.828125f,0.015625f, -0.835938f,0.015625f, -0.84375f,0.015625f, -0.851563f,0.015625f, -0.859375f,0.015625f, -0.867188f,0.015625f, -0.875f,0.015625f, -0.882813f,0.015625f, -0.890625f,0.015625f, -0.898438f,0.015625f, -0.90625f,0.015625f, -0.914063f,0.015625f, -0.921875f,0.015625f, -0.929688f,0.015625f, -0.9375f,0.015625f, -0.945313f,0.015625f, -0.953125f,0.015625f, -0.960938f,0.015625f, -0.96875f,0.015625f, -0.976563f,0.015625f, -0.984375f,0.015625f, -0.992188f,0.015625f, -1.0f,0.015625f, -0.507813f,0.0234375f, -0.515625f,0.0234375f, -0.523438f,0.0234375f, -0.53125f,0.0234375f, -0.539063f,0.0234375f, -0.546875f,0.0234375f, -0.554688f,0.0234375f, -0.5625f,0.0234375f, -0.570313f,0.0234375f, -0.578125f,0.0234375f, -0.585938f,0.0234375f, -0.59375f,0.0234375f, -0.601563f,0.0234375f, -0.609375f,0.0234375f, -0.617188f,0.0234375f, -0.625f,0.0234375f, -0.632813f,0.0234375f, -0.640625f,0.0234375f, -0.648438f,0.0234375f, -0.65625f,0.0234375f, -0.664063f,0.0234375f, -0.671875f,0.0234375f, -0.679688f,0.0234375f, -0.6875f,0.0234375f, -0.695313f,0.0234375f, -0.703125f,0.0234375f, -0.710938f,0.0234375f, -0.71875f,0.0234375f, -0.726563f,0.0234375f, -0.734375f,0.0234375f, -0.742188f,0.0234375f, -0.75f,0.0234375f, -0.757813f,0.0234375f, -0.765625f,0.0234375f, -0.773438f,0.0234375f, -0.78125f,0.0234375f, -0.789063f,0.0234375f, -0.796875f,0.0234375f, -0.804688f,0.0234375f, -0.8125f,0.0234375f, -0.820313f,0.0234375f, -0.828125f,0.0234375f, -0.835938f,0.0234375f, -0.84375f,0.0234375f, -0.851563f,0.0234375f, -0.859375f,0.0234375f, -0.867188f,0.0234375f, -0.875f,0.0234375f, -0.882813f,0.0234375f, -0.890625f,0.0234375f, -0.898438f,0.0234375f, -0.90625f,0.0234375f, -0.914063f,0.0234375f, -0.921875f,0.0234375f, -0.929688f,0.0234375f, -0.9375f,0.0234375f, -0.945313f,0.0234375f, -0.953125f,0.0234375f, -0.960938f,0.0234375f, -0.96875f,0.0234375f, -0.976563f,0.0234375f, -0.984375f,0.0234375f, -0.992188f,0.0234375f, -1.0f,0.0234375f, -0.507813f,0.03125f, -0.515625f,0.03125f, -0.523438f,0.03125f, -0.53125f,0.03125f, -0.539063f,0.03125f, -0.546875f,0.03125f, -0.554688f,0.03125f, -0.5625f,0.03125f, -0.570313f,0.03125f, -0.578125f,0.03125f, -0.585938f,0.03125f, -0.59375f,0.03125f, -0.601563f,0.03125f, -0.609375f,0.03125f, -0.617188f,0.03125f, -0.625f,0.03125f, -0.632813f,0.03125f, -0.640625f,0.03125f, -0.648438f,0.03125f, -0.65625f,0.03125f, -0.664063f,0.03125f, -0.671875f,0.03125f, -0.679688f,0.03125f, -0.6875f,0.03125f, -0.695313f,0.03125f, -0.703125f,0.03125f, -0.710938f,0.03125f, -0.71875f,0.03125f, -0.726563f,0.03125f, -0.734375f,0.03125f, -0.742188f,0.03125f, -0.75f,0.03125f, -0.757813f,0.03125f, -0.765625f,0.03125f, -0.773438f,0.03125f, -0.78125f,0.03125f, -0.789063f,0.03125f, -0.796875f,0.03125f, -0.804688f,0.03125f, -0.8125f,0.03125f, -0.820313f,0.03125f, -0.828125f,0.03125f, -0.835938f,0.03125f, -0.84375f,0.03125f, -0.851563f,0.03125f, -0.859375f,0.03125f, -0.867188f,0.03125f, -0.875f,0.03125f, -0.882813f,0.03125f, -0.890625f,0.03125f, -0.898438f,0.03125f, -0.90625f,0.03125f, -0.914063f,0.03125f, -0.921875f,0.03125f, -0.929688f,0.03125f, -0.9375f,0.03125f, -0.945313f,0.03125f, -0.953125f,0.03125f, -0.960938f,0.03125f, -0.96875f,0.03125f, -0.976563f,0.03125f, -0.984375f,0.03125f, -0.992188f,0.03125f, -1.0f,0.03125f, -0.507813f,0.0390625f, -0.515625f,0.0390625f, -0.523438f,0.0390625f, -0.53125f,0.0390625f, -0.539063f,0.0390625f, -0.546875f,0.0390625f, -0.554688f,0.0390625f, -0.5625f,0.0390625f, -0.570313f,0.0390625f, -0.578125f,0.0390625f, -0.585938f,0.0390625f, -0.59375f,0.0390625f, -0.601563f,0.0390625f, -0.609375f,0.0390625f, -0.617188f,0.0390625f, -0.625f,0.0390625f, -0.632813f,0.0390625f, -0.640625f,0.0390625f, -0.648438f,0.0390625f, -0.65625f,0.0390625f, -0.664063f,0.0390625f, -0.671875f,0.0390625f, -0.679688f,0.0390625f, -0.6875f,0.0390625f, -0.695313f,0.0390625f, -0.703125f,0.0390625f, -0.710938f,0.0390625f, -0.71875f,0.0390625f, -0.726563f,0.0390625f, -0.734375f,0.0390625f, -0.742188f,0.0390625f, -0.75f,0.0390625f, -0.757813f,0.0390625f, -0.765625f,0.0390625f, -0.773438f,0.0390625f, -0.78125f,0.0390625f, -0.789063f,0.0390625f, -0.796875f,0.0390625f, -0.804688f,0.0390625f, -0.8125f,0.0390625f, -0.820313f,0.0390625f, -0.828125f,0.0390625f, -0.835938f,0.0390625f, -0.84375f,0.0390625f, -0.851563f,0.0390625f, -0.859375f,0.0390625f, -0.867188f,0.0390625f, -0.875f,0.0390625f, -0.882813f,0.0390625f, -0.890625f,0.0390625f, -0.898438f,0.0390625f, -0.90625f,0.0390625f, -0.914063f,0.0390625f, -0.921875f,0.0390625f, -0.929688f,0.0390625f, -0.9375f,0.0390625f, -0.945313f,0.0390625f, -0.953125f,0.0390625f, -0.960938f,0.0390625f, -0.96875f,0.0390625f, -0.976563f,0.0390625f, -0.984375f,0.0390625f, -0.992188f,0.0390625f, -1.0f,0.0390625f, -0.507813f,0.046875f, -0.515625f,0.046875f, -0.523438f,0.046875f, -0.53125f,0.046875f, -0.539063f,0.046875f, -0.546875f,0.046875f, -0.554688f,0.046875f, -0.5625f,0.046875f, -0.570313f,0.046875f, -0.578125f,0.046875f, -0.585938f,0.046875f, -0.59375f,0.046875f, -0.601563f,0.046875f, -0.609375f,0.046875f, -0.617188f,0.046875f, -0.625f,0.046875f, -0.632813f,0.046875f, -0.640625f,0.046875f, -0.648438f,0.046875f, -0.65625f,0.046875f, -0.664063f,0.046875f, -0.671875f,0.046875f, -0.679688f,0.046875f, -0.6875f,0.046875f, -0.695313f,0.046875f, -0.703125f,0.046875f, -0.710938f,0.046875f, -0.71875f,0.046875f, -0.726563f,0.046875f, -0.734375f,0.046875f, -0.742188f,0.046875f, -0.75f,0.046875f, -0.757813f,0.046875f, -0.765625f,0.046875f, -0.773438f,0.046875f, -0.78125f,0.046875f, -0.789063f,0.046875f, -0.796875f,0.046875f, -0.804688f,0.046875f, -0.8125f,0.046875f, -0.820313f,0.046875f, -0.828125f,0.046875f, -0.835938f,0.046875f, -0.84375f,0.046875f, -0.851563f,0.046875f, -0.859375f,0.046875f, -0.867188f,0.046875f, -0.875f,0.046875f, -0.882813f,0.046875f, -0.890625f,0.046875f, -0.898438f,0.046875f, -0.90625f,0.046875f, -0.914063f,0.046875f, -0.921875f,0.046875f, -0.929688f,0.046875f, -0.9375f,0.046875f, -0.945313f,0.046875f, -0.953125f,0.046875f, -0.960938f,0.046875f, -0.96875f,0.046875f, -0.976563f,0.046875f, -0.984375f,0.046875f, -0.992188f,0.046875f, -1.0f,0.046875f, -0.507813f,0.0546875f, -0.515625f,0.0546875f, -0.523438f,0.0546875f, -0.53125f,0.0546875f, -0.539063f,0.0546875f, -0.546875f,0.0546875f, -0.554688f,0.0546875f, -0.5625f,0.0546875f, -0.570313f,0.0546875f, -0.578125f,0.0546875f, -0.585938f,0.0546875f, -0.59375f,0.0546875f, -0.601563f,0.0546875f, -0.609375f,0.0546875f, -0.617188f,0.0546875f, -0.625f,0.0546875f, -0.632813f,0.0546875f, -0.640625f,0.0546875f, -0.648438f,0.0546875f, -0.65625f,0.0546875f, -0.664063f,0.0546875f, -0.671875f,0.0546875f, -0.679688f,0.0546875f, -0.6875f,0.0546875f, -0.695313f,0.0546875f, -0.703125f,0.0546875f, -0.710938f,0.0546875f, -0.71875f,0.0546875f, -0.726563f,0.0546875f, -0.734375f,0.0546875f, -0.742188f,0.0546875f, -0.75f,0.0546875f, -0.757813f,0.0546875f, -0.765625f,0.0546875f, -0.773438f,0.0546875f, -0.78125f,0.0546875f, -0.789063f,0.0546875f, -0.796875f,0.0546875f, -0.804688f,0.0546875f, -0.8125f,0.0546875f, -0.820313f,0.0546875f, -0.828125f,0.0546875f, -0.835938f,0.0546875f, -0.84375f,0.0546875f, -0.851563f,0.0546875f, -0.859375f,0.0546875f, -0.867188f,0.0546875f, -0.875f,0.0546875f, -0.882813f,0.0546875f, -0.890625f,0.0546875f, -0.898438f,0.0546875f, -0.90625f,0.0546875f, -0.914063f,0.0546875f, -0.921875f,0.0546875f, -0.929688f,0.0546875f, -0.9375f,0.0546875f, -0.945313f,0.0546875f, -0.953125f,0.0546875f, -0.960938f,0.0546875f, -0.96875f,0.0546875f, -0.976563f,0.0546875f, -0.984375f,0.0546875f, -0.992188f,0.0546875f, -1.0f,0.0546875f, -0.507813f,0.0625f, -0.515625f,0.0625f, -0.523438f,0.0625f, -0.53125f,0.0625f, -0.539063f,0.0625f, -0.546875f,0.0625f, -0.554688f,0.0625f, -0.5625f,0.0625f, -0.570313f,0.0625f, -0.578125f,0.0625f, -0.585938f,0.0625f, -0.59375f,0.0625f, -0.601563f,0.0625f, -0.609375f,0.0625f, -0.617188f,0.0625f, -0.625f,0.0625f, -0.632813f,0.0625f, -0.640625f,0.0625f, -0.648438f,0.0625f, -0.65625f,0.0625f, -0.664063f,0.0625f, -0.671875f,0.0625f, -0.679688f,0.0625f, -0.6875f,0.0625f, -0.695313f,0.0625f, -0.703125f,0.0625f, -0.710938f,0.0625f, -0.71875f,0.0625f, -0.726563f,0.0625f, -0.734375f,0.0625f, -0.742188f,0.0625f, -0.75f,0.0625f, -0.757813f,0.0625f, -0.765625f,0.0625f, -0.773438f,0.0625f, -0.78125f,0.0625f, -0.789063f,0.0625f, -0.796875f,0.0625f, -0.804688f,0.0625f, -0.8125f,0.0625f, -0.820313f,0.0625f, -0.828125f,0.0625f, -0.835938f,0.0625f, -0.84375f,0.0625f, -0.851563f,0.0625f, -0.859375f,0.0625f, -0.867188f,0.0625f, -0.875f,0.0625f, -0.882813f,0.0625f, -0.890625f,0.0625f, -0.898438f,0.0625f, -0.90625f,0.0625f, -0.914063f,0.0625f, -0.921875f,0.0625f, -0.929688f,0.0625f, -0.9375f,0.0625f, -0.945313f,0.0625f, -0.953125f,0.0625f, -0.960938f,0.0625f, -0.96875f,0.0625f, -0.976563f,0.0625f, -0.984375f,0.0625f, -0.992188f,0.0625f, -1.0f,0.0625f, -0.507813f,0.0703125f, -0.515625f,0.0703125f, -0.523438f,0.0703125f, -0.53125f,0.0703125f, -0.539063f,0.0703125f, -0.546875f,0.0703125f, -0.554688f,0.0703125f, -0.5625f,0.0703125f, -0.570313f,0.0703125f, -0.578125f,0.0703125f, -0.585938f,0.0703125f, -0.59375f,0.0703125f, -0.601563f,0.0703125f, -0.609375f,0.0703125f, -0.617188f,0.0703125f, -0.625f,0.0703125f, -0.632813f,0.0703125f, -0.640625f,0.0703125f, -0.648438f,0.0703125f, -0.65625f,0.0703125f, -0.664063f,0.0703125f, -0.671875f,0.0703125f, -0.679688f,0.0703125f, -0.6875f,0.0703125f, -0.695313f,0.0703125f, -0.703125f,0.0703125f, -0.710938f,0.0703125f, -0.71875f,0.0703125f, -0.726563f,0.0703125f, -0.734375f,0.0703125f, -0.742188f,0.0703125f, -0.75f,0.0703125f, -0.757813f,0.0703125f, -0.765625f,0.0703125f, -0.773438f,0.0703125f, -0.78125f,0.0703125f, -0.789063f,0.0703125f, -0.796875f,0.0703125f, -0.804688f,0.0703125f, -0.8125f,0.0703125f, -0.820313f,0.0703125f, -0.828125f,0.0703125f, -0.835938f,0.0703125f, -0.84375f,0.0703125f, -0.851563f,0.0703125f, -0.859375f,0.0703125f, -0.867188f,0.0703125f, -0.875f,0.0703125f, -0.882813f,0.0703125f, -0.890625f,0.0703125f, -0.898438f,0.0703125f, -0.90625f,0.0703125f, -0.914063f,0.0703125f, -0.921875f,0.0703125f, -0.929688f,0.0703125f, -0.9375f,0.0703125f, -0.945313f,0.0703125f, -0.953125f,0.0703125f, -0.960938f,0.0703125f, -0.96875f,0.0703125f, -0.976563f,0.0703125f, -0.984375f,0.0703125f, -0.992188f,0.0703125f, -1.0f,0.0703125f, -0.507813f,0.078125f, -0.515625f,0.078125f, -0.523438f,0.078125f, -0.53125f,0.078125f, -0.539063f,0.078125f, -0.546875f,0.078125f, -0.554688f,0.078125f, -0.5625f,0.078125f, -0.570313f,0.078125f, -0.578125f,0.078125f, -0.585938f,0.078125f, -0.59375f,0.078125f, -0.601563f,0.078125f, -0.609375f,0.078125f, -0.617188f,0.078125f, -0.625f,0.078125f, -0.632813f,0.078125f, -0.640625f,0.078125f, -0.648438f,0.078125f, -0.65625f,0.078125f, -0.664063f,0.078125f, -0.671875f,0.078125f, -0.679688f,0.078125f, -0.6875f,0.078125f, -0.695313f,0.078125f, -0.703125f,0.078125f, -0.710938f,0.078125f, -0.71875f,0.078125f, -0.726563f,0.078125f, -0.734375f,0.078125f, -0.742188f,0.078125f, -0.75f,0.078125f, -0.757813f,0.078125f, -0.765625f,0.078125f, -0.773438f,0.078125f, -0.78125f,0.078125f, -0.789063f,0.078125f, -0.796875f,0.078125f, -0.804688f,0.078125f, -0.8125f,0.078125f, -0.820313f,0.078125f, -0.828125f,0.078125f, -0.835938f,0.078125f, -0.84375f,0.078125f, -0.851563f,0.078125f, -0.859375f,0.078125f, -0.867188f,0.078125f, -0.875f,0.078125f, -0.882813f,0.078125f, -0.890625f,0.078125f, -0.898438f,0.078125f, -0.90625f,0.078125f, -0.914063f,0.078125f, -0.921875f,0.078125f, -0.929688f,0.078125f, -0.9375f,0.078125f, -0.945313f,0.078125f, -0.953125f,0.078125f, -0.960938f,0.078125f, -0.96875f,0.078125f, -0.976563f,0.078125f, -0.984375f,0.078125f, -0.992188f,0.078125f, -1.0f,0.078125f, -0.507813f,0.0859375f, -0.515625f,0.0859375f, -0.523438f,0.0859375f, -0.53125f,0.0859375f, -0.539063f,0.0859375f, -0.546875f,0.0859375f, -0.554688f,0.0859375f, -0.5625f,0.0859375f, -0.570313f,0.0859375f, -0.578125f,0.0859375f, -0.585938f,0.0859375f, -0.59375f,0.0859375f, -0.601563f,0.0859375f, -0.609375f,0.0859375f, -0.617188f,0.0859375f, -0.625f,0.0859375f, -0.632813f,0.0859375f, -0.640625f,0.0859375f, -0.648438f,0.0859375f, -0.65625f,0.0859375f, -0.664063f,0.0859375f, -0.671875f,0.0859375f, -0.679688f,0.0859375f, -0.6875f,0.0859375f, -0.695313f,0.0859375f, -0.703125f,0.0859375f, -0.710938f,0.0859375f, -0.71875f,0.0859375f, -0.726563f,0.0859375f, -0.734375f,0.0859375f, -0.742188f,0.0859375f, -0.75f,0.0859375f, -0.757813f,0.0859375f, -0.765625f,0.0859375f, -0.773438f,0.0859375f, -0.78125f,0.0859375f, -0.789063f,0.0859375f, -0.796875f,0.0859375f, -0.804688f,0.0859375f, -0.8125f,0.0859375f, -0.820313f,0.0859375f, -0.828125f,0.0859375f, -0.835938f,0.0859375f, -0.84375f,0.0859375f, -0.851563f,0.0859375f, -0.859375f,0.0859375f, -0.867188f,0.0859375f, -0.875f,0.0859375f, -0.882813f,0.0859375f, -0.890625f,0.0859375f, -0.898438f,0.0859375f, -0.90625f,0.0859375f, -0.914063f,0.0859375f, -0.921875f,0.0859375f, -0.929688f,0.0859375f, -0.9375f,0.0859375f, -0.945313f,0.0859375f, -0.953125f,0.0859375f, -0.960938f,0.0859375f, -0.96875f,0.0859375f, -0.976563f,0.0859375f, -0.984375f,0.0859375f, -0.992188f,0.0859375f, -1.0f,0.0859375f, -0.507813f,0.09375f, -0.515625f,0.09375f, -0.523438f,0.09375f, -0.53125f,0.09375f, -0.539063f,0.09375f, -0.546875f,0.09375f, -0.554688f,0.09375f, -0.5625f,0.09375f, -0.570313f,0.09375f, -0.578125f,0.09375f, -0.585938f,0.09375f, -0.59375f,0.09375f, -0.601563f,0.09375f, -0.609375f,0.09375f, -0.617188f,0.09375f, -0.625f,0.09375f, -0.632813f,0.09375f, -0.640625f,0.09375f, -0.648438f,0.09375f, -0.65625f,0.09375f, -0.664063f,0.09375f, -0.671875f,0.09375f, -0.679688f,0.09375f, -0.6875f,0.09375f, -0.695313f,0.09375f, -0.703125f,0.09375f, -0.710938f,0.09375f, -0.71875f,0.09375f, -0.726563f,0.09375f, -0.734375f,0.09375f, -0.742188f,0.09375f, -0.75f,0.09375f, -0.757813f,0.09375f, -0.765625f,0.09375f, -0.773438f,0.09375f, -0.78125f,0.09375f, -0.789063f,0.09375f, -0.796875f,0.09375f, -0.804688f,0.09375f, -0.8125f,0.09375f, -0.820313f,0.09375f, -0.828125f,0.09375f, -0.835938f,0.09375f, -0.84375f,0.09375f, -0.851563f,0.09375f, -0.859375f,0.09375f, -0.867188f,0.09375f, -0.875f,0.09375f, -0.882813f,0.09375f, -0.890625f,0.09375f, -0.898438f,0.09375f, -0.90625f,0.09375f, -0.914063f,0.09375f, -0.921875f,0.09375f, -0.929688f,0.09375f, -0.9375f,0.09375f, -0.945313f,0.09375f, -0.953125f,0.09375f, -0.960938f,0.09375f, -0.96875f,0.09375f, -0.976563f,0.09375f, -0.984375f,0.09375f, -0.992188f,0.09375f, -1.0f,0.09375f, -0.507813f,0.101563f, -0.515625f,0.101563f, -0.523438f,0.101563f, -0.53125f,0.101563f, -0.539063f,0.101563f, -0.546875f,0.101563f, -0.554688f,0.101563f, -0.5625f,0.101563f, -0.570313f,0.101563f, -0.578125f,0.101563f, -0.585938f,0.101563f, -0.59375f,0.101563f, -0.601563f,0.101563f, -0.609375f,0.101563f, -0.617188f,0.101563f, -0.625f,0.101563f, -0.632813f,0.101563f, -0.640625f,0.101563f, -0.648438f,0.101563f, -0.65625f,0.101563f, -0.664063f,0.101563f, -0.671875f,0.101563f, -0.679688f,0.101563f, -0.6875f,0.101563f, -0.695313f,0.101563f, -0.703125f,0.101563f, -0.710938f,0.101563f, -0.71875f,0.101563f, -0.726563f,0.101563f, -0.734375f,0.101563f, -0.742188f,0.101563f, -0.75f,0.101563f, -0.757813f,0.101563f, -0.765625f,0.101563f, -0.773438f,0.101563f, -0.78125f,0.101563f, -0.789063f,0.101563f, -0.796875f,0.101563f, -0.804688f,0.101563f, -0.8125f,0.101563f, -0.820313f,0.101563f, -0.828125f,0.101563f, -0.835938f,0.101563f, -0.84375f,0.101563f, -0.851563f,0.101563f, -0.859375f,0.101563f, -0.867188f,0.101563f, -0.875f,0.101563f, -0.882813f,0.101563f, -0.890625f,0.101563f, -0.898438f,0.101563f, -0.90625f,0.101563f, -0.914063f,0.101563f, -0.921875f,0.101563f, -0.929688f,0.101563f, -0.9375f,0.101563f, -0.945313f,0.101563f, -0.953125f,0.101563f, -0.960938f,0.101563f, -0.96875f,0.101563f, -0.976563f,0.101563f, -0.984375f,0.101563f, -0.992188f,0.101563f, -1.0f,0.101563f, -0.507813f,0.109375f, -0.515625f,0.109375f, -0.523438f,0.109375f, -0.53125f,0.109375f, -0.539063f,0.109375f, -0.546875f,0.109375f, -0.554688f,0.109375f, -0.5625f,0.109375f, -0.570313f,0.109375f, -0.578125f,0.109375f, -0.585938f,0.109375f, -0.59375f,0.109375f, -0.601563f,0.109375f, -0.609375f,0.109375f, -0.617188f,0.109375f, -0.625f,0.109375f, -0.632813f,0.109375f, -0.640625f,0.109375f, -0.648438f,0.109375f, -0.65625f,0.109375f, -0.664063f,0.109375f, -0.671875f,0.109375f, -0.679688f,0.109375f, -0.6875f,0.109375f, -0.695313f,0.109375f, -0.703125f,0.109375f, -0.710938f,0.109375f, -0.71875f,0.109375f, -0.726563f,0.109375f, -0.734375f,0.109375f, -0.742188f,0.109375f, -0.75f,0.109375f, -0.757813f,0.109375f, -0.765625f,0.109375f, -0.773438f,0.109375f, -0.78125f,0.109375f, -0.789063f,0.109375f, -0.796875f,0.109375f, -0.804688f,0.109375f, -0.8125f,0.109375f, -0.820313f,0.109375f, -0.828125f,0.109375f, -0.835938f,0.109375f, -0.84375f,0.109375f, -0.851563f,0.109375f, -0.859375f,0.109375f, -0.867188f,0.109375f, -0.875f,0.109375f, -0.882813f,0.109375f, -0.890625f,0.109375f, -0.898438f,0.109375f, -0.90625f,0.109375f, -0.914063f,0.109375f, -0.921875f,0.109375f, -0.929688f,0.109375f, -0.9375f,0.109375f, -0.945313f,0.109375f, -0.953125f,0.109375f, -0.960938f,0.109375f, -0.96875f,0.109375f, -0.976563f,0.109375f, -0.984375f,0.109375f, -0.992188f,0.109375f, -1.0f,0.109375f, -0.507813f,0.117188f, -0.515625f,0.117188f, -0.523438f,0.117188f, -0.53125f,0.117188f, -0.539063f,0.117188f, -0.546875f,0.117188f, -0.554688f,0.117188f, -0.5625f,0.117188f, -0.570313f,0.117188f, -0.578125f,0.117188f, -0.585938f,0.117188f, -0.59375f,0.117188f, -0.601563f,0.117188f, -0.609375f,0.117188f, -0.617188f,0.117188f, -0.625f,0.117188f, -0.632813f,0.117188f, -0.640625f,0.117188f, -0.648438f,0.117188f, -0.65625f,0.117188f, -0.664063f,0.117188f, -0.671875f,0.117188f, -0.679688f,0.117188f, -0.6875f,0.117188f, -0.695313f,0.117188f, -0.703125f,0.117188f, -0.710938f,0.117188f, -0.71875f,0.117188f, -0.726563f,0.117188f, -0.734375f,0.117188f, -0.742188f,0.117188f, -0.75f,0.117188f, -0.757813f,0.117188f, -0.765625f,0.117188f, -0.773438f,0.117188f, -0.78125f,0.117188f, -0.789063f,0.117188f, -0.796875f,0.117188f, -0.804688f,0.117188f, -0.8125f,0.117188f, -0.820313f,0.117188f, -0.828125f,0.117188f, -0.835938f,0.117188f, -0.84375f,0.117188f, -0.851563f,0.117188f, -0.859375f,0.117188f, -0.867188f,0.117188f, -0.875f,0.117188f, -0.882813f,0.117188f, -0.890625f,0.117188f, -0.898438f,0.117188f, -0.90625f,0.117188f, -0.914063f,0.117188f, -0.921875f,0.117188f, -0.929688f,0.117188f, -0.9375f,0.117188f, -0.945313f,0.117188f, -0.953125f,0.117188f, -0.960938f,0.117188f, -0.96875f,0.117188f, -0.976563f,0.117188f, -0.984375f,0.117188f, -0.992188f,0.117188f, -1.0f,0.117188f, -0.507813f,0.125f, -0.515625f,0.125f, -0.523438f,0.125f, -0.53125f,0.125f, -0.539063f,0.125f, -0.546875f,0.125f, -0.554688f,0.125f, -0.5625f,0.125f, -0.570313f,0.125f, -0.578125f,0.125f, -0.585938f,0.125f, -0.59375f,0.125f, -0.601563f,0.125f, -0.609375f,0.125f, -0.617188f,0.125f, -0.625f,0.125f, -0.632813f,0.125f, -0.640625f,0.125f, -0.648438f,0.125f, -0.65625f,0.125f, -0.664063f,0.125f, -0.671875f,0.125f, -0.679688f,0.125f, -0.6875f,0.125f, -0.695313f,0.125f, -0.703125f,0.125f, -0.710938f,0.125f, -0.71875f,0.125f, -0.726563f,0.125f, -0.734375f,0.125f, -0.742188f,0.125f, -0.75f,0.125f, -0.757813f,0.125f, -0.765625f,0.125f, -0.773438f,0.125f, -0.78125f,0.125f, -0.789063f,0.125f, -0.796875f,0.125f, -0.804688f,0.125f, -0.8125f,0.125f, -0.820313f,0.125f, -0.828125f,0.125f, -0.835938f,0.125f, -0.84375f,0.125f, -0.851563f,0.125f, -0.859375f,0.125f, -0.867188f,0.125f, -0.875f,0.125f, -0.882813f,0.125f, -0.890625f,0.125f, -0.898438f,0.125f, -0.90625f,0.125f, -0.914063f,0.125f, -0.921875f,0.125f, -0.929688f,0.125f, -0.9375f,0.125f, -0.945313f,0.125f, -0.953125f,0.125f, -0.960938f,0.125f, -0.96875f,0.125f, -0.976563f,0.125f, -0.984375f,0.125f, -0.992188f,0.125f, -1.0f,0.125f, -0.507813f,0.132813f, -0.515625f,0.132813f, -0.523438f,0.132813f, -0.53125f,0.132813f, -0.539063f,0.132813f, -0.546875f,0.132813f, -0.554688f,0.132813f, -0.5625f,0.132813f, -0.570313f,0.132813f, -0.578125f,0.132813f, -0.585938f,0.132813f, -0.59375f,0.132813f, -0.601563f,0.132813f, -0.609375f,0.132813f, -0.617188f,0.132813f, -0.625f,0.132813f, -0.632813f,0.132813f, -0.640625f,0.132813f, -0.648438f,0.132813f, -0.65625f,0.132813f, -0.664063f,0.132813f, -0.671875f,0.132813f, -0.679688f,0.132813f, -0.6875f,0.132813f, -0.695313f,0.132813f, -0.703125f,0.132813f, -0.710938f,0.132813f, -0.71875f,0.132813f, -0.726563f,0.132813f, -0.734375f,0.132813f, -0.742188f,0.132813f, -0.75f,0.132813f, -0.757813f,0.132813f, -0.765625f,0.132813f, -0.773438f,0.132813f, -0.78125f,0.132813f, -0.789063f,0.132813f, -0.796875f,0.132813f, -0.804688f,0.132813f, -0.8125f,0.132813f, -0.820313f,0.132813f, -0.828125f,0.132813f, -0.835938f,0.132813f, -0.84375f,0.132813f, -0.851563f,0.132813f, -0.859375f,0.132813f, -0.867188f,0.132813f, -0.875f,0.132813f, -0.882813f,0.132813f, -0.890625f,0.132813f, -0.898438f,0.132813f, -0.90625f,0.132813f, -0.914063f,0.132813f, -0.921875f,0.132813f, -0.929688f,0.132813f, -0.9375f,0.132813f, -0.945313f,0.132813f, -0.953125f,0.132813f, -0.960938f,0.132813f, -0.96875f,0.132813f, -0.976563f,0.132813f, -0.984375f,0.132813f, -0.992188f,0.132813f, -1.0f,0.132813f, -0.507813f,0.140625f, -0.515625f,0.140625f, -0.523438f,0.140625f, -0.53125f,0.140625f, -0.539063f,0.140625f, -0.546875f,0.140625f, -0.554688f,0.140625f, -0.5625f,0.140625f, -0.570313f,0.140625f, -0.578125f,0.140625f, -0.585938f,0.140625f, -0.59375f,0.140625f, -0.601563f,0.140625f, -0.609375f,0.140625f, -0.617188f,0.140625f, -0.625f,0.140625f, -0.632813f,0.140625f, -0.640625f,0.140625f, -0.648438f,0.140625f, -0.65625f,0.140625f, -0.664063f,0.140625f, -0.671875f,0.140625f, -0.679688f,0.140625f, -0.6875f,0.140625f, -0.695313f,0.140625f, -0.703125f,0.140625f, -0.710938f,0.140625f, -0.71875f,0.140625f, -0.726563f,0.140625f, -0.734375f,0.140625f, -0.742188f,0.140625f, -0.75f,0.140625f, -0.757813f,0.140625f, -0.765625f,0.140625f, -0.773438f,0.140625f, -0.78125f,0.140625f, -0.789063f,0.140625f, -0.796875f,0.140625f, -0.804688f,0.140625f, -0.8125f,0.140625f, -0.820313f,0.140625f, -0.828125f,0.140625f, -0.835938f,0.140625f, -0.84375f,0.140625f, -0.851563f,0.140625f, -0.859375f,0.140625f, -0.867188f,0.140625f, -0.875f,0.140625f, -0.882813f,0.140625f, -0.890625f,0.140625f, -0.898438f,0.140625f, -0.90625f,0.140625f, -0.914063f,0.140625f, -0.921875f,0.140625f, -0.929688f,0.140625f, -0.9375f,0.140625f, -0.945313f,0.140625f, -0.953125f,0.140625f, -0.960938f,0.140625f, -0.96875f,0.140625f, -0.976563f,0.140625f, -0.984375f,0.140625f, -0.992188f,0.140625f, -1.0f,0.140625f, -0.507813f,0.148438f, -0.515625f,0.148438f, -0.523438f,0.148438f, -0.53125f,0.148438f, -0.539063f,0.148438f, -0.546875f,0.148438f, -0.554688f,0.148438f, -0.5625f,0.148438f, -0.570313f,0.148438f, -0.578125f,0.148438f, -0.585938f,0.148438f, -0.59375f,0.148438f, -0.601563f,0.148438f, -0.609375f,0.148438f, -0.617188f,0.148438f, -0.625f,0.148438f, -0.632813f,0.148438f, -0.640625f,0.148438f, -0.648438f,0.148438f, -0.65625f,0.148438f, -0.664063f,0.148438f, -0.671875f,0.148438f, -0.679688f,0.148438f, -0.6875f,0.148438f, -0.695313f,0.148438f, -0.703125f,0.148438f, -0.710938f,0.148438f, -0.71875f,0.148438f, -0.726563f,0.148438f, -0.734375f,0.148438f, -0.742188f,0.148438f, -0.75f,0.148438f, -0.757813f,0.148438f, -0.765625f,0.148438f, -0.773438f,0.148438f, -0.78125f,0.148438f, -0.789063f,0.148438f, -0.796875f,0.148438f, -0.804688f,0.148438f, -0.8125f,0.148438f, -0.820313f,0.148438f, -0.828125f,0.148438f, -0.835938f,0.148438f, -0.84375f,0.148438f, -0.851563f,0.148438f, -0.859375f,0.148438f, -0.867188f,0.148438f, -0.875f,0.148438f, -0.882813f,0.148438f, -0.890625f,0.148438f, -0.898438f,0.148438f, -0.90625f,0.148438f, -0.914063f,0.148438f, -0.921875f,0.148438f, -0.929688f,0.148438f, -0.9375f,0.148438f, -0.945313f,0.148438f, -0.953125f,0.148438f, -0.960938f,0.148438f, -0.96875f,0.148438f, -0.976563f,0.148438f, -0.984375f,0.148438f, -0.992188f,0.148438f, -1.0f,0.148438f, -0.507813f,0.15625f, -0.515625f,0.15625f, -0.523438f,0.15625f, -0.53125f,0.15625f, -0.539063f,0.15625f, -0.546875f,0.15625f, -0.554688f,0.15625f, -0.5625f,0.15625f, -0.570313f,0.15625f, -0.578125f,0.15625f, -0.585938f,0.15625f, -0.59375f,0.15625f, -0.601563f,0.15625f, -0.609375f,0.15625f, -0.617188f,0.15625f, -0.625f,0.15625f, -0.632813f,0.15625f, -0.640625f,0.15625f, -0.648438f,0.15625f, -0.65625f,0.15625f, -0.664063f,0.15625f, -0.671875f,0.15625f, -0.679688f,0.15625f, -0.6875f,0.15625f, -0.695313f,0.15625f, -0.703125f,0.15625f, -0.710938f,0.15625f, -0.71875f,0.15625f, -0.726563f,0.15625f, -0.734375f,0.15625f, -0.742188f,0.15625f, -0.75f,0.15625f, -0.757813f,0.15625f, -0.765625f,0.15625f, -0.773438f,0.15625f, -0.78125f,0.15625f, -0.789063f,0.15625f, -0.796875f,0.15625f, -0.804688f,0.15625f, -0.8125f,0.15625f, -0.820313f,0.15625f, -0.828125f,0.15625f, -0.835938f,0.15625f, -0.84375f,0.15625f, -0.851563f,0.15625f, -0.859375f,0.15625f, -0.867188f,0.15625f, -0.875f,0.15625f, -0.882813f,0.15625f, -0.890625f,0.15625f, -0.898438f,0.15625f, -0.90625f,0.15625f, -0.914063f,0.15625f, -0.921875f,0.15625f, -0.929688f,0.15625f, -0.9375f,0.15625f, -0.945313f,0.15625f, -0.953125f,0.15625f, -0.960938f,0.15625f, -0.96875f,0.15625f, -0.976563f,0.15625f, -0.984375f,0.15625f, -0.992188f,0.15625f, -1.0f,0.15625f, -0.507813f,0.164063f, -0.515625f,0.164063f, -0.523438f,0.164063f, -0.53125f,0.164063f, -0.539063f,0.164063f, -0.546875f,0.164063f, -0.554688f,0.164063f, -0.5625f,0.164063f, -0.570313f,0.164063f, -0.578125f,0.164063f, -0.585938f,0.164063f, -0.59375f,0.164063f, -0.601563f,0.164063f, -0.609375f,0.164063f, -0.617188f,0.164063f, -0.625f,0.164063f, -0.632813f,0.164063f, -0.640625f,0.164063f, -0.648438f,0.164063f, -0.65625f,0.164063f, -0.664063f,0.164063f, -0.671875f,0.164063f, -0.679688f,0.164063f, -0.6875f,0.164063f, -0.695313f,0.164063f, -0.703125f,0.164063f, -0.710938f,0.164063f, -0.71875f,0.164063f, -0.726563f,0.164063f, -0.734375f,0.164063f, -0.742188f,0.164063f, -0.75f,0.164063f, -0.757813f,0.164063f, -0.765625f,0.164063f, -0.773438f,0.164063f, -0.78125f,0.164063f, -0.789063f,0.164063f, -0.796875f,0.164063f, -0.804688f,0.164063f, -0.8125f,0.164063f, -0.820313f,0.164063f, -0.828125f,0.164063f, -0.835938f,0.164063f, -0.84375f,0.164063f, -0.851563f,0.164063f, -0.859375f,0.164063f, -0.867188f,0.164063f, -0.875f,0.164063f, -0.882813f,0.164063f, -0.890625f,0.164063f, -0.898438f,0.164063f, -0.90625f,0.164063f, -0.914063f,0.164063f, -0.921875f,0.164063f, -0.929688f,0.164063f, -0.9375f,0.164063f, -0.945313f,0.164063f, -0.953125f,0.164063f, -0.960938f,0.164063f, -0.96875f,0.164063f, -0.976563f,0.164063f, -0.984375f,0.164063f, -0.992188f,0.164063f, -1.0f,0.164063f, -0.507813f,0.171875f, -0.515625f,0.171875f, -0.523438f,0.171875f, -0.53125f,0.171875f, -0.539063f,0.171875f, -0.546875f,0.171875f, -0.554688f,0.171875f, -0.5625f,0.171875f, -0.570313f,0.171875f, -0.578125f,0.171875f, -0.585938f,0.171875f, -0.59375f,0.171875f, -0.601563f,0.171875f, -0.609375f,0.171875f, -0.617188f,0.171875f, -0.625f,0.171875f, -0.632813f,0.171875f, -0.640625f,0.171875f, -0.648438f,0.171875f, -0.65625f,0.171875f, -0.664063f,0.171875f, -0.671875f,0.171875f, -0.679688f,0.171875f, -0.6875f,0.171875f, -0.695313f,0.171875f, -0.703125f,0.171875f, -0.710938f,0.171875f, -0.71875f,0.171875f, -0.726563f,0.171875f, -0.734375f,0.171875f, -0.742188f,0.171875f, -0.75f,0.171875f, -0.757813f,0.171875f, -0.765625f,0.171875f, -0.773438f,0.171875f, -0.78125f,0.171875f, -0.789063f,0.171875f, -0.796875f,0.171875f, -0.804688f,0.171875f, -0.8125f,0.171875f, -0.820313f,0.171875f, -0.828125f,0.171875f, -0.835938f,0.171875f, -0.84375f,0.171875f, -0.851563f,0.171875f, -0.859375f,0.171875f, -0.867188f,0.171875f, -0.875f,0.171875f, -0.882813f,0.171875f, -0.890625f,0.171875f, -0.898438f,0.171875f, -0.90625f,0.171875f, -0.914063f,0.171875f, -0.921875f,0.171875f, -0.929688f,0.171875f, -0.9375f,0.171875f, -0.945313f,0.171875f, -0.953125f,0.171875f, -0.960938f,0.171875f, -0.96875f,0.171875f, -0.976563f,0.171875f, -0.984375f,0.171875f, -0.992188f,0.171875f, -1.0f,0.171875f, -0.507813f,0.179688f, -0.515625f,0.179688f, -0.523438f,0.179688f, -0.53125f,0.179688f, -0.539063f,0.179688f, -0.546875f,0.179688f, -0.554688f,0.179688f, -0.5625f,0.179688f, -0.570313f,0.179688f, -0.578125f,0.179688f, -0.585938f,0.179688f, -0.59375f,0.179688f, -0.601563f,0.179688f, -0.609375f,0.179688f, -0.617188f,0.179688f, -0.625f,0.179688f, -0.632813f,0.179688f, -0.640625f,0.179688f, -0.648438f,0.179688f, -0.65625f,0.179688f, -0.664063f,0.179688f, -0.671875f,0.179688f, -0.679688f,0.179688f, -0.6875f,0.179688f, -0.695313f,0.179688f, -0.703125f,0.179688f, -0.710938f,0.179688f, -0.71875f,0.179688f, -0.726563f,0.179688f, -0.734375f,0.179688f, -0.742188f,0.179688f, -0.75f,0.179688f, -0.757813f,0.179688f, -0.765625f,0.179688f, -0.773438f,0.179688f, -0.78125f,0.179688f, -0.789063f,0.179688f, -0.796875f,0.179688f, -0.804688f,0.179688f, -0.8125f,0.179688f, -0.820313f,0.179688f, -0.828125f,0.179688f, -0.835938f,0.179688f, -0.84375f,0.179688f, -0.851563f,0.179688f, -0.859375f,0.179688f, -0.867188f,0.179688f, -0.875f,0.179688f, -0.882813f,0.179688f, -0.890625f,0.179688f, -0.898438f,0.179688f, -0.90625f,0.179688f, -0.914063f,0.179688f, -0.921875f,0.179688f, -0.929688f,0.179688f, -0.9375f,0.179688f, -0.945313f,0.179688f, -0.953125f,0.179688f, -0.960938f,0.179688f, -0.96875f,0.179688f, -0.976563f,0.179688f, -0.984375f,0.179688f, -0.992188f,0.179688f, -1.0f,0.179688f, -0.507813f,0.1875f, -0.515625f,0.1875f, -0.523438f,0.1875f, -0.53125f,0.1875f, -0.539063f,0.1875f, -0.546875f,0.1875f, -0.554688f,0.1875f, -0.5625f,0.1875f, -0.570313f,0.1875f, -0.578125f,0.1875f, -0.585938f,0.1875f, -0.59375f,0.1875f, -0.601563f,0.1875f, -0.609375f,0.1875f, -0.617188f,0.1875f, -0.625f,0.1875f, -0.632813f,0.1875f, -0.640625f,0.1875f, -0.648438f,0.1875f, -0.65625f,0.1875f, -0.664063f,0.1875f, -0.671875f,0.1875f, -0.679688f,0.1875f, -0.6875f,0.1875f, -0.695313f,0.1875f, -0.703125f,0.1875f, -0.710938f,0.1875f, -0.71875f,0.1875f, -0.726563f,0.1875f, -0.734375f,0.1875f, -0.742188f,0.1875f, -0.75f,0.1875f, -0.757813f,0.1875f, -0.765625f,0.1875f, -0.773438f,0.1875f, -0.78125f,0.1875f, -0.789063f,0.1875f, -0.796875f,0.1875f, -0.804688f,0.1875f, -0.8125f,0.1875f, -0.820313f,0.1875f, -0.828125f,0.1875f, -0.835938f,0.1875f, -0.84375f,0.1875f, -0.851563f,0.1875f, -0.859375f,0.1875f, -0.867188f,0.1875f, -0.875f,0.1875f, -0.882813f,0.1875f, -0.890625f,0.1875f, -0.898438f,0.1875f, -0.90625f,0.1875f, -0.914063f,0.1875f, -0.921875f,0.1875f, -0.929688f,0.1875f, -0.9375f,0.1875f, -0.945313f,0.1875f, -0.953125f,0.1875f, -0.960938f,0.1875f, -0.96875f,0.1875f, -0.976563f,0.1875f, -0.984375f,0.1875f, -0.992188f,0.1875f, -1.0f,0.1875f, -0.507813f,0.195313f, -0.515625f,0.195313f, -0.523438f,0.195313f, -0.53125f,0.195313f, -0.539063f,0.195313f, -0.546875f,0.195313f, -0.554688f,0.195313f, -0.5625f,0.195313f, -0.570313f,0.195313f, -0.578125f,0.195313f, -0.585938f,0.195313f, -0.59375f,0.195313f, -0.601563f,0.195313f, -0.609375f,0.195313f, -0.617188f,0.195313f, -0.625f,0.195313f, -0.632813f,0.195313f, -0.640625f,0.195313f, -0.648438f,0.195313f, -0.65625f,0.195313f, -0.664063f,0.195313f, -0.671875f,0.195313f, -0.679688f,0.195313f, -0.6875f,0.195313f, -0.695313f,0.195313f, -0.703125f,0.195313f, -0.710938f,0.195313f, -0.71875f,0.195313f, -0.726563f,0.195313f, -0.734375f,0.195313f, -0.742188f,0.195313f, -0.75f,0.195313f, -0.757813f,0.195313f, -0.765625f,0.195313f, -0.773438f,0.195313f, -0.78125f,0.195313f, -0.789063f,0.195313f, -0.796875f,0.195313f, -0.804688f,0.195313f, -0.8125f,0.195313f, -0.820313f,0.195313f, -0.828125f,0.195313f, -0.835938f,0.195313f, -0.84375f,0.195313f, -0.851563f,0.195313f, -0.859375f,0.195313f, -0.867188f,0.195313f, -0.875f,0.195313f, -0.882813f,0.195313f, -0.890625f,0.195313f, -0.898438f,0.195313f, -0.90625f,0.195313f, -0.914063f,0.195313f, -0.921875f,0.195313f, -0.929688f,0.195313f, -0.9375f,0.195313f, -0.945313f,0.195313f, -0.953125f,0.195313f, -0.960938f,0.195313f, -0.96875f,0.195313f, -0.976563f,0.195313f, -0.984375f,0.195313f, -0.992188f,0.195313f, -1.0f,0.195313f, -0.507813f,0.203125f, -0.515625f,0.203125f, -0.523438f,0.203125f, -0.53125f,0.203125f, -0.539063f,0.203125f, -0.546875f,0.203125f, -0.554688f,0.203125f, -0.5625f,0.203125f, -0.570313f,0.203125f, -0.578125f,0.203125f, -0.585938f,0.203125f, -0.59375f,0.203125f, -0.601563f,0.203125f, -0.609375f,0.203125f, -0.617188f,0.203125f, -0.625f,0.203125f, -0.632813f,0.203125f, -0.640625f,0.203125f, -0.648438f,0.203125f, -0.65625f,0.203125f, -0.664063f,0.203125f, -0.671875f,0.203125f, -0.679688f,0.203125f, -0.6875f,0.203125f, -0.695313f,0.203125f, -0.703125f,0.203125f, -0.710938f,0.203125f, -0.71875f,0.203125f, -0.726563f,0.203125f, -0.734375f,0.203125f, -0.742188f,0.203125f, -0.75f,0.203125f, -0.757813f,0.203125f, -0.765625f,0.203125f, -0.773438f,0.203125f, -0.78125f,0.203125f, -0.789063f,0.203125f, -0.796875f,0.203125f, -0.804688f,0.203125f, -0.8125f,0.203125f, -0.820313f,0.203125f, -0.828125f,0.203125f, -0.835938f,0.203125f, -0.84375f,0.203125f, -0.851563f,0.203125f, -0.859375f,0.203125f, -0.867188f,0.203125f, -0.875f,0.203125f, -0.882813f,0.203125f, -0.890625f,0.203125f, -0.898438f,0.203125f, -0.90625f,0.203125f, -0.914063f,0.203125f, -0.921875f,0.203125f, -0.929688f,0.203125f, -0.9375f,0.203125f, -0.945313f,0.203125f, -0.953125f,0.203125f, -0.960938f,0.203125f, -0.96875f,0.203125f, -0.976563f,0.203125f, -0.984375f,0.203125f, -0.992188f,0.203125f, -1.0f,0.203125f, -0.507813f,0.210938f, -0.515625f,0.210938f, -0.523438f,0.210938f, -0.53125f,0.210938f, -0.539063f,0.210938f, -0.546875f,0.210938f, -0.554688f,0.210938f, -0.5625f,0.210938f, -0.570313f,0.210938f, -0.578125f,0.210938f, -0.585938f,0.210938f, -0.59375f,0.210938f, -0.601563f,0.210938f, -0.609375f,0.210938f, -0.617188f,0.210938f, -0.625f,0.210938f, -0.632813f,0.210938f, -0.640625f,0.210938f, -0.648438f,0.210938f, -0.65625f,0.210938f, -0.664063f,0.210938f, -0.671875f,0.210938f, -0.679688f,0.210938f, -0.6875f,0.210938f, -0.695313f,0.210938f, -0.703125f,0.210938f, -0.710938f,0.210938f, -0.71875f,0.210938f, -0.726563f,0.210938f, -0.734375f,0.210938f, -0.742188f,0.210938f, -0.75f,0.210938f, -0.757813f,0.210938f, -0.765625f,0.210938f, -0.773438f,0.210938f, -0.78125f,0.210938f, -0.789063f,0.210938f, -0.796875f,0.210938f, -0.804688f,0.210938f, -0.8125f,0.210938f, -0.820313f,0.210938f, -0.828125f,0.210938f, -0.835938f,0.210938f, -0.84375f,0.210938f, -0.851563f,0.210938f, -0.859375f,0.210938f, -0.867188f,0.210938f, -0.875f,0.210938f, -0.882813f,0.210938f, -0.890625f,0.210938f, -0.898438f,0.210938f, -0.90625f,0.210938f, -0.914063f,0.210938f, -0.921875f,0.210938f, -0.929688f,0.210938f, -0.9375f,0.210938f, -0.945313f,0.210938f, -0.953125f,0.210938f, -0.960938f,0.210938f, -0.96875f,0.210938f, -0.976563f,0.210938f, -0.984375f,0.210938f, -0.992188f,0.210938f, -1.0f,0.210938f, -0.507813f,0.21875f, -0.515625f,0.21875f, -0.523438f,0.21875f, -0.53125f,0.21875f, -0.539063f,0.21875f, -0.546875f,0.21875f, -0.554688f,0.21875f, -0.5625f,0.21875f, -0.570313f,0.21875f, -0.578125f,0.21875f, -0.585938f,0.21875f, -0.59375f,0.21875f, -0.601563f,0.21875f, -0.609375f,0.21875f, -0.617188f,0.21875f, -0.625f,0.21875f, -0.632813f,0.21875f, -0.640625f,0.21875f, -0.648438f,0.21875f, -0.65625f,0.21875f, -0.664063f,0.21875f, -0.671875f,0.21875f, -0.679688f,0.21875f, -0.6875f,0.21875f, -0.695313f,0.21875f, -0.703125f,0.21875f, -0.710938f,0.21875f, -0.71875f,0.21875f, -0.726563f,0.21875f, -0.734375f,0.21875f, -0.742188f,0.21875f, -0.75f,0.21875f, -0.757813f,0.21875f, -0.765625f,0.21875f, -0.773438f,0.21875f, -0.78125f,0.21875f, -0.789063f,0.21875f, -0.796875f,0.21875f, -0.804688f,0.21875f, -0.8125f,0.21875f, -0.820313f,0.21875f, -0.828125f,0.21875f, -0.835938f,0.21875f, -0.84375f,0.21875f, -0.851563f,0.21875f, -0.859375f,0.21875f, -0.867188f,0.21875f, -0.875f,0.21875f, -0.882813f,0.21875f, -0.890625f,0.21875f, -0.898438f,0.21875f, -0.90625f,0.21875f, -0.914063f,0.21875f, -0.921875f,0.21875f, -0.929688f,0.21875f, -0.9375f,0.21875f, -0.945313f,0.21875f, -0.953125f,0.21875f, -0.960938f,0.21875f, -0.96875f,0.21875f, -0.976563f,0.21875f, -0.984375f,0.21875f, -0.992188f,0.21875f, -1.0f,0.21875f, -0.507813f,0.226563f, -0.515625f,0.226563f, -0.523438f,0.226563f, -0.53125f,0.226563f, -0.539063f,0.226563f, -0.546875f,0.226563f, -0.554688f,0.226563f, -0.5625f,0.226563f, -0.570313f,0.226563f, -0.578125f,0.226563f, -0.585938f,0.226563f, -0.59375f,0.226563f, -0.601563f,0.226563f, -0.609375f,0.226563f, -0.617188f,0.226563f, -0.625f,0.226563f, -0.632813f,0.226563f, -0.640625f,0.226563f, -0.648438f,0.226563f, -0.65625f,0.226563f, -0.664063f,0.226563f, -0.671875f,0.226563f, -0.679688f,0.226563f, -0.6875f,0.226563f, -0.695313f,0.226563f, -0.703125f,0.226563f, -0.710938f,0.226563f, -0.71875f,0.226563f, -0.726563f,0.226563f, -0.734375f,0.226563f, -0.742188f,0.226563f, -0.75f,0.226563f, -0.757813f,0.226563f, -0.765625f,0.226563f, -0.773438f,0.226563f, -0.78125f,0.226563f, -0.789063f,0.226563f, -0.796875f,0.226563f, -0.804688f,0.226563f, -0.8125f,0.226563f, -0.820313f,0.226563f, -0.828125f,0.226563f, -0.835938f,0.226563f, -0.84375f,0.226563f, -0.851563f,0.226563f, -0.859375f,0.226563f, -0.867188f,0.226563f, -0.875f,0.226563f, -0.882813f,0.226563f, -0.890625f,0.226563f, -0.898438f,0.226563f, -0.90625f,0.226563f, -0.914063f,0.226563f, -0.921875f,0.226563f, -0.929688f,0.226563f, -0.9375f,0.226563f, -0.945313f,0.226563f, -0.953125f,0.226563f, -0.960938f,0.226563f, -0.96875f,0.226563f, -0.976563f,0.226563f, -0.984375f,0.226563f, -0.992188f,0.226563f, -1.0f,0.226563f, -0.507813f,0.234375f, -0.515625f,0.234375f, -0.523438f,0.234375f, -0.53125f,0.234375f, -0.539063f,0.234375f, -0.546875f,0.234375f, -0.554688f,0.234375f, -0.5625f,0.234375f, -0.570313f,0.234375f, -0.578125f,0.234375f, -0.585938f,0.234375f, -0.59375f,0.234375f, -0.601563f,0.234375f, -0.609375f,0.234375f, -0.617188f,0.234375f, -0.625f,0.234375f, -0.632813f,0.234375f, -0.640625f,0.234375f, -0.648438f,0.234375f, -0.65625f,0.234375f, -0.664063f,0.234375f, -0.671875f,0.234375f, -0.679688f,0.234375f, -0.6875f,0.234375f, -0.695313f,0.234375f, -0.703125f,0.234375f, -0.710938f,0.234375f, -0.71875f,0.234375f, -0.726563f,0.234375f, -0.734375f,0.234375f, -0.742188f,0.234375f, -0.75f,0.234375f, -0.757813f,0.234375f, -0.765625f,0.234375f, -0.773438f,0.234375f, -0.78125f,0.234375f, -0.789063f,0.234375f, -0.796875f,0.234375f, -0.804688f,0.234375f, -0.8125f,0.234375f, -0.820313f,0.234375f, -0.828125f,0.234375f, -0.835938f,0.234375f, -0.84375f,0.234375f, -0.851563f,0.234375f, -0.859375f,0.234375f, -0.867188f,0.234375f, -0.875f,0.234375f, -0.882813f,0.234375f, -0.890625f,0.234375f, -0.898438f,0.234375f, -0.90625f,0.234375f, -0.914063f,0.234375f, -0.921875f,0.234375f, -0.929688f,0.234375f, -0.9375f,0.234375f, -0.945313f,0.234375f, -0.953125f,0.234375f, -0.960938f,0.234375f, -0.96875f,0.234375f, -0.976563f,0.234375f, -0.984375f,0.234375f, -0.992188f,0.234375f, -1.0f,0.234375f, -0.507813f,0.242188f, -0.515625f,0.242188f, -0.523438f,0.242188f, -0.53125f,0.242188f, -0.539063f,0.242188f, -0.546875f,0.242188f, -0.554688f,0.242188f, -0.5625f,0.242188f, -0.570313f,0.242188f, -0.578125f,0.242188f, -0.585938f,0.242188f, -0.59375f,0.242188f, -0.601563f,0.242188f, -0.609375f,0.242188f, -0.617188f,0.242188f, -0.625f,0.242188f, -0.632813f,0.242188f, -0.640625f,0.242188f, -0.648438f,0.242188f, -0.65625f,0.242188f, -0.664063f,0.242188f, -0.671875f,0.242188f, -0.679688f,0.242188f, -0.6875f,0.242188f, -0.695313f,0.242188f, -0.703125f,0.242188f, -0.710938f,0.242188f, -0.71875f,0.242188f, -0.726563f,0.242188f, -0.734375f,0.242188f, -0.742188f,0.242188f, -0.75f,0.242188f, -0.757813f,0.242188f, -0.765625f,0.242188f, -0.773438f,0.242188f, -0.78125f,0.242188f, -0.789063f,0.242188f, -0.796875f,0.242188f, -0.804688f,0.242188f, -0.8125f,0.242188f, -0.820313f,0.242188f, -0.828125f,0.242188f, -0.835938f,0.242188f, -0.84375f,0.242188f, -0.851563f,0.242188f, -0.859375f,0.242188f, -0.867188f,0.242188f, -0.875f,0.242188f, -0.882813f,0.242188f, -0.890625f,0.242188f, -0.898438f,0.242188f, -0.90625f,0.242188f, -0.914063f,0.242188f, -0.921875f,0.242188f, -0.929688f,0.242188f, -0.9375f,0.242188f, -0.945313f,0.242188f, -0.953125f,0.242188f, -0.960938f,0.242188f, -0.96875f,0.242188f, -0.976563f,0.242188f, -0.984375f,0.242188f, -0.992188f,0.242188f, -1.0f,0.242188f, -}; - -unsigned short Landscape01Idx[] = { -0,1,2, -3,2,1, -2,3,4, -5,4,3, -4,5,6, -7,6,5, -6,7,8, -9,8,7, -8,9,10, -11,10,9, -10,11,12, -13,12,11, -12,13,14, -15,14,13, -14,15,16, -17,16,15, -16,17,18, -19,18,17, -18,19,20, -21,20,19, -20,21,22, -23,22,21, -22,23,24, -25,24,23, -24,25,26, -27,26,25, -26,27,28, -29,28,27, -28,29,30, -31,30,29, -30,31,32, -33,32,31, -32,33,34, -35,34,33, -34,35,36, -37,36,35, -36,37,38, -39,38,37, -38,39,40, -41,40,39, -40,41,42, -43,42,41, -42,43,44, -45,44,43, -44,45,46, -47,46,45, -46,47,48, -49,48,47, -48,49,50, -51,50,49, -50,51,52, -53,52,51, -52,53,54, -55,54,53, -54,55,56, -57,56,55, -56,57,58, -59,58,57, -58,59,60, -61,60,59, -60,61,62, -63,62,61, -62,63,64, -65,64,63, -64,65,66, -67,66,65, -66,67,68, -69,68,67, -68,69,70, -71,70,69, -70,71,72, -73,72,71, -72,73,74, -75,74,73, -74,75,76, -77,76,75, -76,77,78, -79,78,77, -78,79,80, -81,80,79, -80,81,82, -83,82,81, -82,83,84, -85,84,83, -84,85,86, -87,86,85, -86,87,88, -89,88,87, -88,89,90, -91,90,89, -90,91,92, -93,92,91, -92,93,94, -95,94,93, -94,95,96, -97,96,95, -96,97,98, -99,98,97, -98,99,100, -101,100,99, -100,101,102, -103,102,101, -102,103,104, -105,104,103, -104,105,106, -107,106,105, -106,107,108, -109,108,107, -108,109,110, -111,110,109, -110,111,112, -113,112,111, -112,113,114, -115,114,113, -114,115,116, -117,116,115, -116,117,118, -119,118,117, -118,119,120, -121,120,119, -120,121,122, -123,122,121, -122,123,124, -125,124,123, -124,125,126, -127,126,125, -128,0,129, -2,129,0, -129,2,130, -4,130,2, -130,4,131, -6,131,4, -131,6,132, -8,132,6, -132,8,133, -10,133,8, -133,10,134, -12,134,10, -134,12,135, -14,135,12, -135,14,136, -16,136,14, -136,16,137, -18,137,16, -137,18,138, -20,138,18, -138,20,139, -22,139,20, -139,22,140, -24,140,22, -140,24,141, -26,141,24, -141,26,142, -28,142,26, -142,28,143, -30,143,28, -143,30,144, -32,144,30, -144,32,145, -34,145,32, -145,34,146, -36,146,34, -146,36,147, -38,147,36, -147,38,148, -40,148,38, -148,40,149, -42,149,40, -149,42,150, -44,150,42, -150,44,151, -46,151,44, -151,46,152, -48,152,46, -152,48,153, -50,153,48, -153,50,154, -52,154,50, -154,52,155, -54,155,52, -155,54,156, -56,156,54, -156,56,157, -58,157,56, -157,58,158, -60,158,58, -158,60,159, -62,159,60, -159,62,160, -64,160,62, -160,64,161, -66,161,64, -161,66,162, -68,162,66, -162,68,163, -70,163,68, -163,70,164, -72,164,70, -164,72,165, -74,165,72, -165,74,166, -76,166,74, -166,76,167, -78,167,76, -167,78,168, -80,168,78, -168,80,169, -82,169,80, -169,82,170, -84,170,82, -170,84,171, -86,171,84, -171,86,172, -88,172,86, -172,88,173, -90,173,88, -173,90,174, -92,174,90, -174,92,175, -94,175,92, -175,94,176, -96,176,94, -176,96,177, -98,177,96, -177,98,178, -100,178,98, -178,100,179, -102,179,100, -179,102,180, -104,180,102, -180,104,181, -106,181,104, -181,106,182, -108,182,106, -182,108,183, -110,183,108, -183,110,184, -112,184,110, -184,112,185, -114,185,112, -185,114,186, -116,186,114, -186,116,187, -118,187,116, -187,118,188, -120,188,118, -188,120,189, -122,189,120, -189,122,190, -124,190,122, -190,124,191, -126,191,124, -192,128,193, -129,193,128, -193,129,194, -130,194,129, -194,130,195, -131,195,130, -195,131,196, -132,196,131, -196,132,197, -133,197,132, -197,133,198, -134,198,133, -198,134,199, -135,199,134, -199,135,200, -136,200,135, -200,136,201, -137,201,136, -201,137,202, -138,202,137, -202,138,203, -139,203,138, -203,139,204, -140,204,139, -204,140,205, -141,205,140, -205,141,206, -142,206,141, -206,142,207, -143,207,142, -207,143,208, -144,208,143, -208,144,209, -145,209,144, -209,145,210, -146,210,145, -210,146,211, -147,211,146, -211,147,212, -148,212,147, -212,148,213, -149,213,148, -213,149,214, -150,214,149, -214,150,215, -151,215,150, -215,151,216, -152,216,151, -216,152,217, -153,217,152, -217,153,218, -154,218,153, -218,154,219, -155,219,154, -219,155,220, -156,220,155, -220,156,221, -157,221,156, -221,157,222, -158,222,157, -222,158,223, -159,223,158, -223,159,224, -160,224,159, -224,160,225, -161,225,160, -225,161,226, -162,226,161, -226,162,227, -163,227,162, -227,163,228, -164,228,163, -228,164,229, -165,229,164, -229,165,230, -166,230,165, -230,166,231, -167,231,166, -231,167,232, -168,232,167, -232,168,233, -169,233,168, -233,169,234, -170,234,169, -234,170,235, -171,235,170, -235,171,236, -172,236,171, -236,172,237, -173,237,172, -237,173,238, -174,238,173, -238,174,239, -175,239,174, -239,175,240, -176,240,175, -240,176,241, -177,241,176, -241,177,242, -178,242,177, -242,178,243, -179,243,178, -243,179,244, -180,244,179, -244,180,245, -181,245,180, -245,181,246, -182,246,181, -246,182,247, -183,247,182, -247,183,248, -184,248,183, -248,184,249, -185,249,184, -249,185,250, -186,250,185, -250,186,251, -187,251,186, -251,187,252, -188,252,187, -252,188,253, -189,253,188, -253,189,254, -190,254,189, -254,190,255, -191,255,190, -256,192,257, -193,257,192, -257,193,258, -194,258,193, -258,194,259, -195,259,194, -259,195,260, -196,260,195, -260,196,261, -197,261,196, -261,197,262, -198,262,197, -262,198,263, -199,263,198, -263,199,264, -200,264,199, -264,200,265, -201,265,200, -265,201,266, -202,266,201, -266,202,267, -203,267,202, -267,203,268, -204,268,203, -268,204,269, -205,269,204, -269,205,270, -206,270,205, -270,206,271, -207,271,206, -271,207,272, -208,272,207, -272,208,273, -209,273,208, -273,209,274, -210,274,209, -274,210,275, -211,275,210, -275,211,276, -212,276,211, -276,212,277, -213,277,212, -277,213,278, -214,278,213, -278,214,279, -215,279,214, -279,215,280, -216,280,215, -280,216,281, -217,281,216, -281,217,282, -218,282,217, -282,218,283, -219,283,218, -283,219,284, -220,284,219, -284,220,285, -221,285,220, -285,221,286, -222,286,221, -286,222,287, -223,287,222, -287,223,288, -224,288,223, -288,224,289, -225,289,224, -289,225,290, -226,290,225, -290,226,291, -227,291,226, -291,227,292, -228,292,227, -292,228,293, -229,293,228, -293,229,294, -230,294,229, -294,230,295, -231,295,230, -295,231,296, -232,296,231, -296,232,297, -233,297,232, -297,233,298, -234,298,233, -298,234,299, -235,299,234, -299,235,300, -236,300,235, -300,236,301, -237,301,236, -301,237,302, -238,302,237, -302,238,303, -239,303,238, -303,239,304, -240,304,239, -304,240,305, -241,305,240, -305,241,306, -242,306,241, -306,242,307, -243,307,242, -307,243,308, -244,308,243, -308,244,309, -245,309,244, -309,245,310, -246,310,245, -310,246,311, -247,311,246, -311,247,312, -248,312,247, -312,248,313, -249,313,248, -313,249,314, -250,314,249, -314,250,315, -251,315,250, -315,251,316, -252,316,251, -316,252,317, -253,317,252, -317,253,318, -254,318,253, -318,254,319, -255,319,254, -320,256,321, -257,321,256, -321,257,322, -258,322,257, -322,258,323, -259,323,258, -323,259,324, -260,324,259, -324,260,325, -261,325,260, -325,261,326, -262,326,261, -326,262,327, -263,327,262, -327,263,328, -264,328,263, -328,264,329, -265,329,264, -329,265,330, -266,330,265, -330,266,331, -267,331,266, -331,267,332, -268,332,267, -332,268,333, -269,333,268, -333,269,334, -270,334,269, -334,270,335, -271,335,270, -335,271,336, -272,336,271, -336,272,337, -273,337,272, -337,273,338, -274,338,273, -338,274,339, -275,339,274, -339,275,340, -276,340,275, -340,276,341, -277,341,276, -341,277,342, -278,342,277, -342,278,343, -279,343,278, -343,279,344, -280,344,279, -344,280,345, -281,345,280, -345,281,346, -282,346,281, -346,282,347, -283,347,282, -347,283,348, -284,348,283, -348,284,349, -285,349,284, -349,285,350, -286,350,285, -350,286,351, -287,351,286, -351,287,352, -288,352,287, -352,288,353, -289,353,288, -353,289,354, -290,354,289, -354,290,355, -291,355,290, -355,291,356, -292,356,291, -356,292,357, -293,357,292, -357,293,358, -294,358,293, -358,294,359, -295,359,294, -359,295,360, -296,360,295, -360,296,361, -297,361,296, -361,297,362, -298,362,297, -362,298,363, -299,363,298, -363,299,364, -300,364,299, -364,300,365, -301,365,300, -365,301,366, -302,366,301, -366,302,367, -303,367,302, -367,303,368, -304,368,303, -368,304,369, -305,369,304, -369,305,370, -306,370,305, -370,306,371, -307,371,306, -371,307,372, -308,372,307, -372,308,373, -309,373,308, -373,309,374, -310,374,309, -374,310,375, -311,375,310, -375,311,376, -312,376,311, -376,312,377, -313,377,312, -377,313,378, -314,378,313, -378,314,379, -315,379,314, -379,315,380, -316,380,315, -380,316,381, -317,381,316, -381,317,382, -318,382,317, -382,318,383, -319,383,318, -384,320,385, -321,385,320, -385,321,386, -322,386,321, -386,322,387, -323,387,322, -387,323,388, -324,388,323, -388,324,389, -325,389,324, -389,325,390, -326,390,325, -390,326,391, -327,391,326, -391,327,392, -328,392,327, -392,328,393, -329,393,328, -393,329,394, -330,394,329, -394,330,395, -331,395,330, -395,331,396, -332,396,331, -396,332,397, -333,397,332, -397,333,398, -334,398,333, -398,334,399, -335,399,334, -399,335,400, -336,400,335, -400,336,401, -337,401,336, -401,337,402, -338,402,337, -402,338,403, -339,403,338, -403,339,404, -340,404,339, -404,340,405, -341,405,340, -405,341,406, -342,406,341, -406,342,407, -343,407,342, -407,343,408, -344,408,343, -408,344,409, -345,409,344, -409,345,410, -346,410,345, -410,346,411, -347,411,346, -411,347,412, -348,412,347, -412,348,413, -349,413,348, -413,349,414, -350,414,349, -414,350,415, -351,415,350, -415,351,416, -352,416,351, -416,352,417, -353,417,352, -417,353,418, -354,418,353, -418,354,419, -355,419,354, -419,355,420, -356,420,355, -420,356,421, -357,421,356, -421,357,422, -358,422,357, -422,358,423, -359,423,358, -423,359,424, -360,424,359, -424,360,425, -361,425,360, -425,361,426, -362,426,361, -426,362,427, -363,427,362, -427,363,428, -364,428,363, -428,364,429, -365,429,364, -429,365,430, -366,430,365, -430,366,431, -367,431,366, -431,367,432, -368,432,367, -432,368,433, -369,433,368, -433,369,434, -370,434,369, -434,370,435, -371,435,370, -435,371,436, -372,436,371, -436,372,437, -373,437,372, -437,373,438, -374,438,373, -438,374,439, -375,439,374, -439,375,440, -376,440,375, -440,376,441, -377,441,376, -441,377,442, -378,442,377, -442,378,443, -379,443,378, -443,379,444, -380,444,379, -444,380,445, -381,445,380, -445,381,446, -382,446,381, -446,382,447, -383,447,382, -448,384,449, -385,449,384, -449,385,450, -386,450,385, -450,386,451, -387,451,386, -451,387,452, -388,452,387, -452,388,453, -389,453,388, -453,389,454, -390,454,389, -454,390,455, -391,455,390, -455,391,456, -392,456,391, -456,392,457, -393,457,392, -457,393,458, -394,458,393, -458,394,459, -395,459,394, -459,395,460, -396,460,395, -460,396,461, -397,461,396, -461,397,462, -398,462,397, -462,398,463, -399,463,398, -463,399,464, -400,464,399, -464,400,465, -401,465,400, -465,401,466, -402,466,401, -466,402,467, -403,467,402, -467,403,468, -404,468,403, -468,404,469, -405,469,404, -469,405,470, -406,470,405, -470,406,471, -407,471,406, -471,407,472, -408,472,407, -472,408,473, -409,473,408, -473,409,474, -410,474,409, -474,410,475, -411,475,410, -475,411,476, -412,476,411, -476,412,477, -413,477,412, -477,413,478, -414,478,413, -478,414,479, -415,479,414, -479,415,480, -416,480,415, -480,416,481, -417,481,416, -481,417,482, -418,482,417, -482,418,483, -419,483,418, -483,419,484, -420,484,419, -484,420,485, -421,485,420, -485,421,486, -422,486,421, -486,422,487, -423,487,422, -487,423,488, -424,488,423, -488,424,489, -425,489,424, -489,425,490, -426,490,425, -490,426,491, -427,491,426, -491,427,492, -428,492,427, -492,428,493, -429,493,428, -493,429,494, -430,494,429, -494,430,495, -431,495,430, -495,431,496, -432,496,431, -496,432,497, -433,497,432, -497,433,498, -434,498,433, -498,434,499, -435,499,434, -499,435,500, -436,500,435, -500,436,501, -437,501,436, -501,437,502, -438,502,437, -502,438,503, -439,503,438, -503,439,504, -440,504,439, -504,440,505, -441,505,440, -505,441,506, -442,506,441, -506,442,507, -443,507,442, -507,443,508, -444,508,443, -508,444,509, -445,509,444, -509,445,510, -446,510,445, -510,446,511, -447,511,446, -512,448,513, -449,513,448, -513,449,514, -450,514,449, -514,450,515, -451,515,450, -515,451,516, -452,516,451, -516,452,517, -453,517,452, -517,453,518, -454,518,453, -518,454,519, -455,519,454, -519,455,520, -456,520,455, -520,456,521, -457,521,456, -521,457,522, -458,522,457, -522,458,523, -459,523,458, -523,459,524, -460,524,459, -524,460,525, -461,525,460, -525,461,526, -462,526,461, -526,462,527, -463,527,462, -527,463,528, -464,528,463, -528,464,529, -465,529,464, -529,465,530, -466,530,465, -530,466,531, -467,531,466, -531,467,532, -468,532,467, -532,468,533, -469,533,468, -533,469,534, -470,534,469, -534,470,535, -471,535,470, -535,471,536, -472,536,471, -536,472,537, -473,537,472, -537,473,538, -474,538,473, -538,474,539, -475,539,474, -539,475,540, -476,540,475, -540,476,541, -477,541,476, -541,477,542, -478,542,477, -542,478,543, -479,543,478, -543,479,544, -480,544,479, -544,480,545, -481,545,480, -545,481,546, -482,546,481, -546,482,547, -483,547,482, -547,483,548, -484,548,483, -548,484,549, -485,549,484, -549,485,550, -486,550,485, -550,486,551, -487,551,486, -551,487,552, -488,552,487, -552,488,553, -489,553,488, -553,489,554, -490,554,489, -554,490,555, -491,555,490, -555,491,556, -492,556,491, -556,492,557, -493,557,492, -557,493,558, -494,558,493, -558,494,559, -495,559,494, -559,495,560, -496,560,495, -560,496,561, -497,561,496, -561,497,562, -498,562,497, -562,498,563, -499,563,498, -563,499,564, -500,564,499, -564,500,565, -501,565,500, -565,501,566, -502,566,501, -566,502,567, -503,567,502, -567,503,568, -504,568,503, -568,504,569, -505,569,504, -569,505,570, -506,570,505, -570,506,571, -507,571,506, -571,507,572, -508,572,507, -572,508,573, -509,573,508, -573,509,574, -510,574,509, -574,510,575, -511,575,510, -576,512,577, -513,577,512, -577,513,578, -514,578,513, -578,514,579, -515,579,514, -579,515,580, -516,580,515, -580,516,581, -517,581,516, -581,517,582, -518,582,517, -582,518,583, -519,583,518, -583,519,584, -520,584,519, -584,520,585, -521,585,520, -585,521,586, -522,586,521, -586,522,587, -523,587,522, -587,523,588, -524,588,523, -588,524,589, -525,589,524, -589,525,590, -526,590,525, -590,526,591, -527,591,526, -591,527,592, -528,592,527, -592,528,593, -529,593,528, -593,529,594, -530,594,529, -594,530,595, -531,595,530, -595,531,596, -532,596,531, -596,532,597, -533,597,532, -597,533,598, -534,598,533, -598,534,599, -535,599,534, -599,535,600, -536,600,535, -600,536,601, -537,601,536, -601,537,602, -538,602,537, -602,538,603, -539,603,538, -603,539,604, -540,604,539, -604,540,605, -541,605,540, -605,541,606, -542,606,541, -606,542,607, -543,607,542, -607,543,608, -544,608,543, -608,544,609, -545,609,544, -609,545,610, -546,610,545, -610,546,611, -547,611,546, -611,547,612, -548,612,547, -612,548,613, -549,613,548, -613,549,614, -550,614,549, -614,550,615, -551,615,550, -615,551,616, -552,616,551, -616,552,617, -553,617,552, -617,553,618, -554,618,553, -618,554,619, -555,619,554, -619,555,620, -556,620,555, -620,556,621, -557,621,556, -621,557,622, -558,622,557, -622,558,623, -559,623,558, -623,559,624, -560,624,559, -624,560,625, -561,625,560, -625,561,626, -562,626,561, -626,562,627, -563,627,562, -627,563,628, -564,628,563, -628,564,629, -565,629,564, -629,565,630, -566,630,565, -630,566,631, -567,631,566, -631,567,632, -568,632,567, -632,568,633, -569,633,568, -633,569,634, -570,634,569, -634,570,635, -571,635,570, -635,571,636, -572,636,571, -636,572,637, -573,637,572, -637,573,638, -574,638,573, -638,574,639, -575,639,574, -640,576,641, -577,641,576, -641,577,642, -578,642,577, -642,578,643, -579,643,578, -643,579,644, -580,644,579, -644,580,645, -581,645,580, -645,581,646, -582,646,581, -646,582,647, -583,647,582, -647,583,648, -584,648,583, -648,584,649, -585,649,584, -649,585,650, -586,650,585, -650,586,651, -587,651,586, -651,587,652, -588,652,587, -652,588,653, -589,653,588, -653,589,654, -590,654,589, -654,590,655, -591,655,590, -655,591,656, -592,656,591, -656,592,657, -593,657,592, -657,593,658, -594,658,593, -658,594,659, -595,659,594, -659,595,660, -596,660,595, -660,596,661, -597,661,596, -661,597,662, -598,662,597, -662,598,663, -599,663,598, -663,599,664, -600,664,599, -664,600,665, -601,665,600, -665,601,666, -602,666,601, -666,602,667, -603,667,602, -667,603,668, -604,668,603, -668,604,669, -605,669,604, -669,605,670, -606,670,605, -670,606,671, -607,671,606, -671,607,672, -608,672,607, -672,608,673, -609,673,608, -673,609,674, -610,674,609, -674,610,675, -611,675,610, -675,611,676, -612,676,611, -676,612,677, -613,677,612, -677,613,678, -614,678,613, -678,614,679, -615,679,614, -679,615,680, -616,680,615, -680,616,681, -617,681,616, -681,617,682, -618,682,617, -682,618,683, -619,683,618, -683,619,684, -620,684,619, -684,620,685, -621,685,620, -685,621,686, -622,686,621, -686,622,687, -623,687,622, -687,623,688, -624,688,623, -688,624,689, -625,689,624, -689,625,690, -626,690,625, -690,626,691, -627,691,626, -691,627,692, -628,692,627, -692,628,693, -629,693,628, -693,629,694, -630,694,629, -694,630,695, -631,695,630, -695,631,696, -632,696,631, -696,632,697, -633,697,632, -697,633,698, -634,698,633, -698,634,699, -635,699,634, -699,635,700, -636,700,635, -700,636,701, -637,701,636, -701,637,702, -638,702,637, -702,638,703, -639,703,638, -704,640,705, -641,705,640, -705,641,706, -642,706,641, -706,642,707, -643,707,642, -707,643,708, -644,708,643, -708,644,709, -645,709,644, -709,645,710, -646,710,645, -710,646,711, -647,711,646, -711,647,712, -648,712,647, -712,648,713, -649,713,648, -713,649,714, -650,714,649, -714,650,715, -651,715,650, -715,651,716, -652,716,651, -716,652,717, -653,717,652, -717,653,718, -654,718,653, -718,654,719, -655,719,654, -719,655,720, -656,720,655, -720,656,721, -657,721,656, -721,657,722, -658,722,657, -722,658,723, -659,723,658, -723,659,724, -660,724,659, -724,660,725, -661,725,660, -725,661,726, -662,726,661, -726,662,727, -663,727,662, -727,663,728, -664,728,663, -728,664,729, -665,729,664, -729,665,730, -666,730,665, -730,666,731, -667,731,666, -731,667,732, -668,732,667, -732,668,733, -669,733,668, -733,669,734, -670,734,669, -734,670,735, -671,735,670, -735,671,736, -672,736,671, -736,672,737, -673,737,672, -737,673,738, -674,738,673, -738,674,739, -675,739,674, -739,675,740, -676,740,675, -740,676,741, -677,741,676, -741,677,742, -678,742,677, -742,678,743, -679,743,678, -743,679,744, -680,744,679, -744,680,745, -681,745,680, -745,681,746, -682,746,681, -746,682,747, -683,747,682, -747,683,748, -684,748,683, -748,684,749, -685,749,684, -749,685,750, -686,750,685, -750,686,751, -687,751,686, -751,687,752, -688,752,687, -752,688,753, -689,753,688, -753,689,754, -690,754,689, -754,690,755, -691,755,690, -755,691,756, -692,756,691, -756,692,757, -693,757,692, -757,693,758, -694,758,693, -758,694,759, -695,759,694, -759,695,760, -696,760,695, -760,696,761, -697,761,696, -761,697,762, -698,762,697, -762,698,763, -699,763,698, -763,699,764, -700,764,699, -764,700,765, -701,765,700, -765,701,766, -702,766,701, -766,702,767, -703,767,702, -768,704,769, -705,769,704, -769,705,770, -706,770,705, -770,706,771, -707,771,706, -771,707,772, -708,772,707, -772,708,773, -709,773,708, -773,709,774, -710,774,709, -774,710,775, -711,775,710, -775,711,776, -712,776,711, -776,712,777, -713,777,712, -777,713,778, -714,778,713, -778,714,779, -715,779,714, -779,715,780, -716,780,715, -780,716,781, -717,781,716, -781,717,782, -718,782,717, -782,718,783, -719,783,718, -783,719,784, -720,784,719, -784,720,785, -721,785,720, -785,721,786, -722,786,721, -786,722,787, -723,787,722, -787,723,788, -724,788,723, -788,724,789, -725,789,724, -789,725,790, -726,790,725, -790,726,791, -727,791,726, -791,727,792, -728,792,727, -792,728,793, -729,793,728, -793,729,794, -730,794,729, -794,730,795, -731,795,730, -795,731,796, -732,796,731, -796,732,797, -733,797,732, -797,733,798, -734,798,733, -798,734,799, -735,799,734, -799,735,800, -736,800,735, -800,736,801, -737,801,736, -801,737,802, -738,802,737, -802,738,803, -739,803,738, -803,739,804, -740,804,739, -804,740,805, -741,805,740, -805,741,806, -742,806,741, -806,742,807, -743,807,742, -807,743,808, -744,808,743, -808,744,809, -745,809,744, -809,745,810, -746,810,745, -810,746,811, -747,811,746, -811,747,812, -748,812,747, -812,748,813, -749,813,748, -813,749,814, -750,814,749, -814,750,815, -751,815,750, -815,751,816, -752,816,751, -816,752,817, -753,817,752, -817,753,818, -754,818,753, -818,754,819, -755,819,754, -819,755,820, -756,820,755, -820,756,821, -757,821,756, -821,757,822, -758,822,757, -822,758,823, -759,823,758, -823,759,824, -760,824,759, -824,760,825, -761,825,760, -825,761,826, -762,826,761, -826,762,827, -763,827,762, -827,763,828, -764,828,763, -828,764,829, -765,829,764, -829,765,830, -766,830,765, -830,766,831, -767,831,766, -832,768,833, -769,833,768, -833,769,834, -770,834,769, -834,770,835, -771,835,770, -835,771,836, -772,836,771, -836,772,837, -773,837,772, -837,773,838, -774,838,773, -838,774,839, -775,839,774, -839,775,840, -776,840,775, -840,776,841, -777,841,776, -841,777,842, -778,842,777, -842,778,843, -779,843,778, -843,779,844, -780,844,779, -844,780,845, -781,845,780, -845,781,846, -782,846,781, -846,782,847, -783,847,782, -847,783,848, -784,848,783, -848,784,849, -785,849,784, -849,785,850, -786,850,785, -850,786,851, -787,851,786, -851,787,852, -788,852,787, -852,788,853, -789,853,788, -853,789,854, -790,854,789, -854,790,855, -791,855,790, -855,791,856, -792,856,791, -856,792,857, -793,857,792, -857,793,858, -794,858,793, -858,794,859, -795,859,794, -859,795,860, -796,860,795, -860,796,861, -797,861,796, -861,797,862, -798,862,797, -862,798,863, -799,863,798, -863,799,864, -800,864,799, -864,800,865, -801,865,800, -865,801,866, -802,866,801, -866,802,867, -803,867,802, -867,803,868, -804,868,803, -868,804,869, -805,869,804, -869,805,870, -806,870,805, -870,806,871, -807,871,806, -871,807,872, -808,872,807, -872,808,873, -809,873,808, -873,809,874, -810,874,809, -874,810,875, -811,875,810, -875,811,876, -812,876,811, -876,812,877, -813,877,812, -877,813,878, -814,878,813, -878,814,879, -815,879,814, -879,815,880, -816,880,815, -880,816,881, -817,881,816, -881,817,882, -818,882,817, -882,818,883, -819,883,818, -883,819,884, -820,884,819, -884,820,885, -821,885,820, -885,821,886, -822,886,821, -886,822,887, -823,887,822, -887,823,888, -824,888,823, -888,824,889, -825,889,824, -889,825,890, -826,890,825, -890,826,891, -827,891,826, -891,827,892, -828,892,827, -892,828,893, -829,893,828, -893,829,894, -830,894,829, -894,830,895, -831,895,830, -896,832,897, -833,897,832, -897,833,898, -834,898,833, -898,834,899, -835,899,834, -899,835,900, -836,900,835, -900,836,901, -837,901,836, -901,837,902, -838,902,837, -902,838,903, -839,903,838, -903,839,904, -840,904,839, -904,840,905, -841,905,840, -905,841,906, -842,906,841, -906,842,907, -843,907,842, -907,843,908, -844,908,843, -908,844,909, -845,909,844, -909,845,910, -846,910,845, -910,846,911, -847,911,846, -911,847,912, -848,912,847, -912,848,913, -849,913,848, -913,849,914, -850,914,849, -914,850,915, -851,915,850, -915,851,916, -852,916,851, -916,852,917, -853,917,852, -917,853,918, -854,918,853, -918,854,919, -855,919,854, -919,855,920, -856,920,855, -920,856,921, -857,921,856, -921,857,922, -858,922,857, -922,858,923, -859,923,858, -923,859,924, -860,924,859, -924,860,925, -861,925,860, -925,861,926, -862,926,861, -926,862,927, -863,927,862, -927,863,928, -864,928,863, -928,864,929, -865,929,864, -929,865,930, -866,930,865, -930,866,931, -867,931,866, -931,867,932, -868,932,867, -932,868,933, -869,933,868, -933,869,934, -870,934,869, -934,870,935, -871,935,870, -935,871,936, -872,936,871, -936,872,937, -873,937,872, -937,873,938, -874,938,873, -938,874,939, -875,939,874, -939,875,940, -876,940,875, -940,876,941, -877,941,876, -941,877,942, -878,942,877, -942,878,943, -879,943,878, -943,879,944, -880,944,879, -944,880,945, -881,945,880, -945,881,946, -882,946,881, -946,882,947, -883,947,882, -947,883,948, -884,948,883, -948,884,949, -885,949,884, -949,885,950, -886,950,885, -950,886,951, -887,951,886, -951,887,952, -888,952,887, -952,888,953, -889,953,888, -953,889,954, -890,954,889, -954,890,955, -891,955,890, -955,891,956, -892,956,891, -956,892,957, -893,957,892, -957,893,958, -894,958,893, -958,894,959, -895,959,894, -960,896,961, -897,961,896, -961,897,962, -898,962,897, -962,898,963, -899,963,898, -963,899,964, -900,964,899, -964,900,965, -901,965,900, -965,901,966, -902,966,901, -966,902,967, -903,967,902, -967,903,968, -904,968,903, -968,904,969, -905,969,904, -969,905,970, -906,970,905, -970,906,971, -907,971,906, -971,907,972, -908,972,907, -972,908,973, -909,973,908, -973,909,974, -910,974,909, -974,910,975, -911,975,910, -975,911,976, -912,976,911, -976,912,977, -913,977,912, -977,913,978, -914,978,913, -978,914,979, -915,979,914, -979,915,980, -916,980,915, -980,916,981, -917,981,916, -981,917,982, -918,982,917, -982,918,983, -919,983,918, -983,919,984, -920,984,919, -984,920,985, -921,985,920, -985,921,986, -922,986,921, -986,922,987, -923,987,922, -987,923,988, -924,988,923, -988,924,989, -925,989,924, -989,925,990, -926,990,925, -990,926,991, -927,991,926, -991,927,992, -928,992,927, -992,928,993, -929,993,928, -993,929,994, -930,994,929, -994,930,995, -931,995,930, -995,931,996, -932,996,931, -996,932,997, -933,997,932, -997,933,998, -934,998,933, -998,934,999, -935,999,934, -999,935,1000, -936,1000,935, -1000,936,1001, -937,1001,936, -1001,937,1002, -938,1002,937, -1002,938,1003, -939,1003,938, -1003,939,1004, -940,1004,939, -1004,940,1005, -941,1005,940, -1005,941,1006, -942,1006,941, -1006,942,1007, -943,1007,942, -1007,943,1008, -944,1008,943, -1008,944,1009, -945,1009,944, -1009,945,1010, -946,1010,945, -1010,946,1011, -947,1011,946, -1011,947,1012, -948,1012,947, -1012,948,1013, -949,1013,948, -1013,949,1014, -950,1014,949, -1014,950,1015, -951,1015,950, -1015,951,1016, -952,1016,951, -1016,952,1017, -953,1017,952, -1017,953,1018, -954,1018,953, -1018,954,1019, -955,1019,954, -1019,955,1020, -956,1020,955, -1020,956,1021, -957,1021,956, -1021,957,1022, -958,1022,957, -1022,958,1023, -959,1023,958, -1024,960,1025, -961,1025,960, -1025,961,1026, -962,1026,961, -1026,962,1027, -963,1027,962, -1027,963,1028, -964,1028,963, -1028,964,1029, -965,1029,964, -1029,965,1030, -966,1030,965, -1030,966,1031, -967,1031,966, -1031,967,1032, -968,1032,967, -1032,968,1033, -969,1033,968, -1033,969,1034, -970,1034,969, -1034,970,1035, -971,1035,970, -1035,971,1036, -972,1036,971, -1036,972,1037, -973,1037,972, -1037,973,1038, -974,1038,973, -1038,974,1039, -975,1039,974, -1039,975,1040, -976,1040,975, -1040,976,1041, -977,1041,976, -1041,977,1042, -978,1042,977, -1042,978,1043, -979,1043,978, -1043,979,1044, -980,1044,979, -1044,980,1045, -981,1045,980, -1045,981,1046, -982,1046,981, -1046,982,1047, -983,1047,982, -1047,983,1048, -984,1048,983, -1048,984,1049, -985,1049,984, -1049,985,1050, -986,1050,985, -1050,986,1051, -987,1051,986, -1051,987,1052, -988,1052,987, -1052,988,1053, -989,1053,988, -1053,989,1054, -990,1054,989, -1054,990,1055, -991,1055,990, -1055,991,1056, -992,1056,991, -1056,992,1057, -993,1057,992, -1057,993,1058, -994,1058,993, -1058,994,1059, -995,1059,994, -1059,995,1060, -996,1060,995, -1060,996,1061, -997,1061,996, -1061,997,1062, -998,1062,997, -1062,998,1063, -999,1063,998, -1063,999,1064, -1000,1064,999, -1064,1000,1065, -1001,1065,1000, -1065,1001,1066, -1002,1066,1001, -1066,1002,1067, -1003,1067,1002, -1067,1003,1068, -1004,1068,1003, -1068,1004,1069, -1005,1069,1004, -1069,1005,1070, -1006,1070,1005, -1070,1006,1071, -1007,1071,1006, -1071,1007,1072, -1008,1072,1007, -1072,1008,1073, -1009,1073,1008, -1073,1009,1074, -1010,1074,1009, -1074,1010,1075, -1011,1075,1010, -1075,1011,1076, -1012,1076,1011, -1076,1012,1077, -1013,1077,1012, -1077,1013,1078, -1014,1078,1013, -1078,1014,1079, -1015,1079,1014, -1079,1015,1080, -1016,1080,1015, -1080,1016,1081, -1017,1081,1016, -1081,1017,1082, -1018,1082,1017, -1082,1018,1083, -1019,1083,1018, -1083,1019,1084, -1020,1084,1019, -1084,1020,1085, -1021,1085,1020, -1085,1021,1086, -1022,1086,1021, -1086,1022,1087, -1023,1087,1022, -1088,1024,1089, -1025,1089,1024, -1089,1025,1090, -1026,1090,1025, -1090,1026,1091, -1027,1091,1026, -1091,1027,1092, -1028,1092,1027, -1092,1028,1093, -1029,1093,1028, -1093,1029,1094, -1030,1094,1029, -1094,1030,1095, -1031,1095,1030, -1095,1031,1096, -1032,1096,1031, -1096,1032,1097, -1033,1097,1032, -1097,1033,1098, -1034,1098,1033, -1098,1034,1099, -1035,1099,1034, -1099,1035,1100, -1036,1100,1035, -1100,1036,1101, -1037,1101,1036, -1101,1037,1102, -1038,1102,1037, -1102,1038,1103, -1039,1103,1038, -1103,1039,1104, -1040,1104,1039, -1104,1040,1105, -1041,1105,1040, -1105,1041,1106, -1042,1106,1041, -1106,1042,1107, -1043,1107,1042, -1107,1043,1108, -1044,1108,1043, -1108,1044,1109, -1045,1109,1044, -1109,1045,1110, -1046,1110,1045, -1110,1046,1111, -1047,1111,1046, -1111,1047,1112, -1048,1112,1047, -1112,1048,1113, -1049,1113,1048, -1113,1049,1114, -1050,1114,1049, -1114,1050,1115, -1051,1115,1050, -1115,1051,1116, -1052,1116,1051, -1116,1052,1117, -1053,1117,1052, -1117,1053,1118, -1054,1118,1053, -1118,1054,1119, -1055,1119,1054, -1119,1055,1120, -1056,1120,1055, -1120,1056,1121, -1057,1121,1056, -1121,1057,1122, -1058,1122,1057, -1122,1058,1123, -1059,1123,1058, -1123,1059,1124, -1060,1124,1059, -1124,1060,1125, -1061,1125,1060, -1125,1061,1126, -1062,1126,1061, -1126,1062,1127, -1063,1127,1062, -1127,1063,1128, -1064,1128,1063, -1128,1064,1129, -1065,1129,1064, -1129,1065,1130, -1066,1130,1065, -1130,1066,1131, -1067,1131,1066, -1131,1067,1132, -1068,1132,1067, -1132,1068,1133, -1069,1133,1068, -1133,1069,1134, -1070,1134,1069, -1134,1070,1135, -1071,1135,1070, -1135,1071,1136, -1072,1136,1071, -1136,1072,1137, -1073,1137,1072, -1137,1073,1138, -1074,1138,1073, -1138,1074,1139, -1075,1139,1074, -1139,1075,1140, -1076,1140,1075, -1140,1076,1141, -1077,1141,1076, -1141,1077,1142, -1078,1142,1077, -1142,1078,1143, -1079,1143,1078, -1143,1079,1144, -1080,1144,1079, -1144,1080,1145, -1081,1145,1080, -1145,1081,1146, -1082,1146,1081, -1146,1082,1147, -1083,1147,1082, -1147,1083,1148, -1084,1148,1083, -1148,1084,1149, -1085,1149,1084, -1149,1085,1150, -1086,1150,1085, -1150,1086,1151, -1087,1151,1086, -1152,1088,1153, -1089,1153,1088, -1153,1089,1154, -1090,1154,1089, -1154,1090,1155, -1091,1155,1090, -1155,1091,1156, -1092,1156,1091, -1156,1092,1157, -1093,1157,1092, -1157,1093,1158, -1094,1158,1093, -1158,1094,1159, -1095,1159,1094, -1159,1095,1160, -1096,1160,1095, -1160,1096,1161, -1097,1161,1096, -1161,1097,1162, -1098,1162,1097, -1162,1098,1163, -1099,1163,1098, -1163,1099,1164, -1100,1164,1099, -1164,1100,1165, -1101,1165,1100, -1165,1101,1166, -1102,1166,1101, -1166,1102,1167, -1103,1167,1102, -1167,1103,1168, -1104,1168,1103, -1168,1104,1169, -1105,1169,1104, -1169,1105,1170, -1106,1170,1105, -1170,1106,1171, -1107,1171,1106, -1171,1107,1172, -1108,1172,1107, -1172,1108,1173, -1109,1173,1108, -1173,1109,1174, -1110,1174,1109, -1174,1110,1175, -1111,1175,1110, -1175,1111,1176, -1112,1176,1111, -1176,1112,1177, -1113,1177,1112, -1177,1113,1178, -1114,1178,1113, -1178,1114,1179, -1115,1179,1114, -1179,1115,1180, -1116,1180,1115, -1180,1116,1181, -1117,1181,1116, -1181,1117,1182, -1118,1182,1117, -1182,1118,1183, -1119,1183,1118, -1183,1119,1184, -1120,1184,1119, -1184,1120,1185, -1121,1185,1120, -1185,1121,1186, -1122,1186,1121, -1186,1122,1187, -1123,1187,1122, -1187,1123,1188, -1124,1188,1123, -1188,1124,1189, -1125,1189,1124, -1189,1125,1190, -1126,1190,1125, -1190,1126,1191, -1127,1191,1126, -1191,1127,1192, -1128,1192,1127, -1192,1128,1193, -1129,1193,1128, -1193,1129,1194, -1130,1194,1129, -1194,1130,1195, -1131,1195,1130, -1195,1131,1196, -1132,1196,1131, -1196,1132,1197, -1133,1197,1132, -1197,1133,1198, -1134,1198,1133, -1198,1134,1199, -1135,1199,1134, -1199,1135,1200, -1136,1200,1135, -1200,1136,1201, -1137,1201,1136, -1201,1137,1202, -1138,1202,1137, -1202,1138,1203, -1139,1203,1138, -1203,1139,1204, -1140,1204,1139, -1204,1140,1205, -1141,1205,1140, -1205,1141,1206, -1142,1206,1141, -1206,1142,1207, -1143,1207,1142, -1207,1143,1208, -1144,1208,1143, -1208,1144,1209, -1145,1209,1144, -1209,1145,1210, -1146,1210,1145, -1210,1146,1211, -1147,1211,1146, -1211,1147,1212, -1148,1212,1147, -1212,1148,1213, -1149,1213,1148, -1213,1149,1214, -1150,1214,1149, -1214,1150,1215, -1151,1215,1150, -1216,1152,1217, -1153,1217,1152, -1217,1153,1218, -1154,1218,1153, -1218,1154,1219, -1155,1219,1154, -1219,1155,1220, -1156,1220,1155, -1220,1156,1221, -1157,1221,1156, -1221,1157,1222, -1158,1222,1157, -1222,1158,1223, -1159,1223,1158, -1223,1159,1224, -1160,1224,1159, -1224,1160,1225, -1161,1225,1160, -1225,1161,1226, -1162,1226,1161, -1226,1162,1227, -1163,1227,1162, -1227,1163,1228, -1164,1228,1163, -1228,1164,1229, -1165,1229,1164, -1229,1165,1230, -1166,1230,1165, -1230,1166,1231, -1167,1231,1166, -1231,1167,1232, -1168,1232,1167, -1232,1168,1233, -1169,1233,1168, -1233,1169,1234, -1170,1234,1169, -1234,1170,1235, -1171,1235,1170, -1235,1171,1236, -1172,1236,1171, -1236,1172,1237, -1173,1237,1172, -1237,1173,1238, -1174,1238,1173, -1238,1174,1239, -1175,1239,1174, -1239,1175,1240, -1176,1240,1175, -1240,1176,1241, -1177,1241,1176, -1241,1177,1242, -1178,1242,1177, -1242,1178,1243, -1179,1243,1178, -1243,1179,1244, -1180,1244,1179, -1244,1180,1245, -1181,1245,1180, -1245,1181,1246, -1182,1246,1181, -1246,1182,1247, -1183,1247,1182, -1247,1183,1248, -1184,1248,1183, -1248,1184,1249, -1185,1249,1184, -1249,1185,1250, -1186,1250,1185, -1250,1186,1251, -1187,1251,1186, -1251,1187,1252, -1188,1252,1187, -1252,1188,1253, -1189,1253,1188, -1253,1189,1254, -1190,1254,1189, -1254,1190,1255, -1191,1255,1190, -1255,1191,1256, -1192,1256,1191, -1256,1192,1257, -1193,1257,1192, -1257,1193,1258, -1194,1258,1193, -1258,1194,1259, -1195,1259,1194, -1259,1195,1260, -1196,1260,1195, -1260,1196,1261, -1197,1261,1196, -1261,1197,1262, -1198,1262,1197, -1262,1198,1263, -1199,1263,1198, -1263,1199,1264, -1200,1264,1199, -1264,1200,1265, -1201,1265,1200, -1265,1201,1266, -1202,1266,1201, -1266,1202,1267, -1203,1267,1202, -1267,1203,1268, -1204,1268,1203, -1268,1204,1269, -1205,1269,1204, -1269,1205,1270, -1206,1270,1205, -1270,1206,1271, -1207,1271,1206, -1271,1207,1272, -1208,1272,1207, -1272,1208,1273, -1209,1273,1208, -1273,1209,1274, -1210,1274,1209, -1274,1210,1275, -1211,1275,1210, -1275,1211,1276, -1212,1276,1211, -1276,1212,1277, -1213,1277,1212, -1277,1213,1278, -1214,1278,1213, -1278,1214,1279, -1215,1279,1214, -1280,1216,1281, -1217,1281,1216, -1281,1217,1282, -1218,1282,1217, -1282,1218,1283, -1219,1283,1218, -1283,1219,1284, -1220,1284,1219, -1284,1220,1285, -1221,1285,1220, -1285,1221,1286, -1222,1286,1221, -1286,1222,1287, -1223,1287,1222, -1287,1223,1288, -1224,1288,1223, -1288,1224,1289, -1225,1289,1224, -1289,1225,1290, -1226,1290,1225, -1290,1226,1291, -1227,1291,1226, -1291,1227,1292, -1228,1292,1227, -1292,1228,1293, -1229,1293,1228, -1293,1229,1294, -1230,1294,1229, -1294,1230,1295, -1231,1295,1230, -1295,1231,1296, -1232,1296,1231, -1296,1232,1297, -1233,1297,1232, -1297,1233,1298, -1234,1298,1233, -1298,1234,1299, -1235,1299,1234, -1299,1235,1300, -1236,1300,1235, -1300,1236,1301, -1237,1301,1236, -1301,1237,1302, -1238,1302,1237, -1302,1238,1303, -1239,1303,1238, -1303,1239,1304, -1240,1304,1239, -1304,1240,1305, -1241,1305,1240, -1305,1241,1306, -1242,1306,1241, -1306,1242,1307, -1243,1307,1242, -1307,1243,1308, -1244,1308,1243, -1308,1244,1309, -1245,1309,1244, -1309,1245,1310, -1246,1310,1245, -1310,1246,1311, -1247,1311,1246, -1311,1247,1312, -1248,1312,1247, -1312,1248,1313, -1249,1313,1248, -1313,1249,1314, -1250,1314,1249, -1314,1250,1315, -1251,1315,1250, -1315,1251,1316, -1252,1316,1251, -1316,1252,1317, -1253,1317,1252, -1317,1253,1318, -1254,1318,1253, -1318,1254,1319, -1255,1319,1254, -1319,1255,1320, -1256,1320,1255, -1320,1256,1321, -1257,1321,1256, -1321,1257,1322, -1258,1322,1257, -1322,1258,1323, -1259,1323,1258, -1323,1259,1324, -1260,1324,1259, -1324,1260,1325, -1261,1325,1260, -1325,1261,1326, -1262,1326,1261, -1326,1262,1327, -1263,1327,1262, -1327,1263,1328, -1264,1328,1263, -1328,1264,1329, -1265,1329,1264, -1329,1265,1330, -1266,1330,1265, -1330,1266,1331, -1267,1331,1266, -1331,1267,1332, -1268,1332,1267, -1332,1268,1333, -1269,1333,1268, -1333,1269,1334, -1270,1334,1269, -1334,1270,1335, -1271,1335,1270, -1335,1271,1336, -1272,1336,1271, -1336,1272,1337, -1273,1337,1272, -1337,1273,1338, -1274,1338,1273, -1338,1274,1339, -1275,1339,1274, -1339,1275,1340, -1276,1340,1275, -1340,1276,1341, -1277,1341,1276, -1341,1277,1342, -1278,1342,1277, -1342,1278,1343, -1279,1343,1278, -1344,1280,1345, -1281,1345,1280, -1345,1281,1346, -1282,1346,1281, -1346,1282,1347, -1283,1347,1282, -1347,1283,1348, -1284,1348,1283, -1348,1284,1349, -1285,1349,1284, -1349,1285,1350, -1286,1350,1285, -1350,1286,1351, -1287,1351,1286, -1351,1287,1352, -1288,1352,1287, -1352,1288,1353, -1289,1353,1288, -1353,1289,1354, -1290,1354,1289, -1354,1290,1355, -1291,1355,1290, -1355,1291,1356, -1292,1356,1291, -1356,1292,1357, -1293,1357,1292, -1357,1293,1358, -1294,1358,1293, -1358,1294,1359, -1295,1359,1294, -1359,1295,1360, -1296,1360,1295, -1360,1296,1361, -1297,1361,1296, -1361,1297,1362, -1298,1362,1297, -1362,1298,1363, -1299,1363,1298, -1363,1299,1364, -1300,1364,1299, -1364,1300,1365, -1301,1365,1300, -1365,1301,1366, -1302,1366,1301, -1366,1302,1367, -1303,1367,1302, -1367,1303,1368, -1304,1368,1303, -1368,1304,1369, -1305,1369,1304, -1369,1305,1370, -1306,1370,1305, -1370,1306,1371, -1307,1371,1306, -1371,1307,1372, -1308,1372,1307, -1372,1308,1373, -1309,1373,1308, -1373,1309,1374, -1310,1374,1309, -1374,1310,1375, -1311,1375,1310, -1375,1311,1376, -1312,1376,1311, -1376,1312,1377, -1313,1377,1312, -1377,1313,1378, -1314,1378,1313, -1378,1314,1379, -1315,1379,1314, -1379,1315,1380, -1316,1380,1315, -1380,1316,1381, -1317,1381,1316, -1381,1317,1382, -1318,1382,1317, -1382,1318,1383, -1319,1383,1318, -1383,1319,1384, -1320,1384,1319, -1384,1320,1385, -1321,1385,1320, -1385,1321,1386, -1322,1386,1321, -1386,1322,1387, -1323,1387,1322, -1387,1323,1388, -1324,1388,1323, -1388,1324,1389, -1325,1389,1324, -1389,1325,1390, -1326,1390,1325, -1390,1326,1391, -1327,1391,1326, -1391,1327,1392, -1328,1392,1327, -1392,1328,1393, -1329,1393,1328, -1393,1329,1394, -1330,1394,1329, -1394,1330,1395, -1331,1395,1330, -1395,1331,1396, -1332,1396,1331, -1396,1332,1397, -1333,1397,1332, -1397,1333,1398, -1334,1398,1333, -1398,1334,1399, -1335,1399,1334, -1399,1335,1400, -1336,1400,1335, -1400,1336,1401, -1337,1401,1336, -1401,1337,1402, -1338,1402,1337, -1402,1338,1403, -1339,1403,1338, -1403,1339,1404, -1340,1404,1339, -1404,1340,1405, -1341,1405,1340, -1405,1341,1406, -1342,1406,1341, -1406,1342,1407, -1343,1407,1342, -1408,1344,1409, -1345,1409,1344, -1409,1345,1410, -1346,1410,1345, -1410,1346,1411, -1347,1411,1346, -1411,1347,1412, -1348,1412,1347, -1412,1348,1413, -1349,1413,1348, -1413,1349,1414, -1350,1414,1349, -1414,1350,1415, -1351,1415,1350, -1415,1351,1416, -1352,1416,1351, -1416,1352,1417, -1353,1417,1352, -1417,1353,1418, -1354,1418,1353, -1418,1354,1419, -1355,1419,1354, -1419,1355,1420, -1356,1420,1355, -1420,1356,1421, -1357,1421,1356, -1421,1357,1422, -1358,1422,1357, -1422,1358,1423, -1359,1423,1358, -1423,1359,1424, -1360,1424,1359, -1424,1360,1425, -1361,1425,1360, -1425,1361,1426, -1362,1426,1361, -1426,1362,1427, -1363,1427,1362, -1427,1363,1428, -1364,1428,1363, -1428,1364,1429, -1365,1429,1364, -1429,1365,1430, -1366,1430,1365, -1430,1366,1431, -1367,1431,1366, -1431,1367,1432, -1368,1432,1367, -1432,1368,1433, -1369,1433,1368, -1433,1369,1434, -1370,1434,1369, -1434,1370,1435, -1371,1435,1370, -1435,1371,1436, -1372,1436,1371, -1436,1372,1437, -1373,1437,1372, -1437,1373,1438, -1374,1438,1373, -1438,1374,1439, -1375,1439,1374, -1439,1375,1440, -1376,1440,1375, -1440,1376,1441, -1377,1441,1376, -1441,1377,1442, -1378,1442,1377, -1442,1378,1443, -1379,1443,1378, -1443,1379,1444, -1380,1444,1379, -1444,1380,1445, -1381,1445,1380, -1445,1381,1446, -1382,1446,1381, -1446,1382,1447, -1383,1447,1382, -1447,1383,1448, -1384,1448,1383, -1448,1384,1449, -1385,1449,1384, -1449,1385,1450, -1386,1450,1385, -1450,1386,1451, -1387,1451,1386, -1451,1387,1452, -1388,1452,1387, -1452,1388,1453, -1389,1453,1388, -1453,1389,1454, -1390,1454,1389, -1454,1390,1455, -1391,1455,1390, -1455,1391,1456, -1392,1456,1391, -1456,1392,1457, -1393,1457,1392, -1457,1393,1458, -1394,1458,1393, -1458,1394,1459, -1395,1459,1394, -1459,1395,1460, -1396,1460,1395, -1460,1396,1461, -1397,1461,1396, -1461,1397,1462, -1398,1462,1397, -1462,1398,1463, -1399,1463,1398, -1463,1399,1464, -1400,1464,1399, -1464,1400,1465, -1401,1465,1400, -1465,1401,1466, -1402,1466,1401, -1466,1402,1467, -1403,1467,1402, -1467,1403,1468, -1404,1468,1403, -1468,1404,1469, -1405,1469,1404, -1469,1405,1470, -1406,1470,1405, -1470,1406,1471, -1407,1471,1406, -1472,1408,1473, -1409,1473,1408, -1473,1409,1474, -1410,1474,1409, -1474,1410,1475, -1411,1475,1410, -1475,1411,1476, -1412,1476,1411, -1476,1412,1477, -1413,1477,1412, -1477,1413,1478, -1414,1478,1413, -1478,1414,1479, -1415,1479,1414, -1479,1415,1480, -1416,1480,1415, -1480,1416,1481, -1417,1481,1416, -1481,1417,1482, -1418,1482,1417, -1482,1418,1483, -1419,1483,1418, -1483,1419,1484, -1420,1484,1419, -1484,1420,1485, -1421,1485,1420, -1485,1421,1486, -1422,1486,1421, -1486,1422,1487, -1423,1487,1422, -1487,1423,1488, -1424,1488,1423, -1488,1424,1489, -1425,1489,1424, -1489,1425,1490, -1426,1490,1425, -1490,1426,1491, -1427,1491,1426, -1491,1427,1492, -1428,1492,1427, -1492,1428,1493, -1429,1493,1428, -1493,1429,1494, -1430,1494,1429, -1494,1430,1495, -1431,1495,1430, -1495,1431,1496, -1432,1496,1431, -1496,1432,1497, -1433,1497,1432, -1497,1433,1498, -1434,1498,1433, -1498,1434,1499, -1435,1499,1434, -1499,1435,1500, -1436,1500,1435, -1500,1436,1501, -1437,1501,1436, -1501,1437,1502, -1438,1502,1437, -1502,1438,1503, -1439,1503,1438, -1503,1439,1504, -1440,1504,1439, -1504,1440,1505, -1441,1505,1440, -1505,1441,1506, -1442,1506,1441, -1506,1442,1507, -1443,1507,1442, -1507,1443,1508, -1444,1508,1443, -1508,1444,1509, -1445,1509,1444, -1509,1445,1510, -1446,1510,1445, -1510,1446,1511, -1447,1511,1446, -1511,1447,1512, -1448,1512,1447, -1512,1448,1513, -1449,1513,1448, -1513,1449,1514, -1450,1514,1449, -1514,1450,1515, -1451,1515,1450, -1515,1451,1516, -1452,1516,1451, -1516,1452,1517, -1453,1517,1452, -1517,1453,1518, -1454,1518,1453, -1518,1454,1519, -1455,1519,1454, -1519,1455,1520, -1456,1520,1455, -1520,1456,1521, -1457,1521,1456, -1521,1457,1522, -1458,1522,1457, -1522,1458,1523, -1459,1523,1458, -1523,1459,1524, -1460,1524,1459, -1524,1460,1525, -1461,1525,1460, -1525,1461,1526, -1462,1526,1461, -1526,1462,1527, -1463,1527,1462, -1527,1463,1528, -1464,1528,1463, -1528,1464,1529, -1465,1529,1464, -1529,1465,1530, -1466,1530,1465, -1530,1466,1531, -1467,1531,1466, -1531,1467,1532, -1468,1532,1467, -1532,1468,1533, -1469,1533,1468, -1533,1469,1534, -1470,1534,1469, -1534,1470,1535, -1471,1535,1470, -1536,1472,1537, -1473,1537,1472, -1537,1473,1538, -1474,1538,1473, -1538,1474,1539, -1475,1539,1474, -1539,1475,1540, -1476,1540,1475, -1540,1476,1541, -1477,1541,1476, -1541,1477,1542, -1478,1542,1477, -1542,1478,1543, -1479,1543,1478, -1543,1479,1544, -1480,1544,1479, -1544,1480,1545, -1481,1545,1480, -1545,1481,1546, -1482,1546,1481, -1546,1482,1547, -1483,1547,1482, -1547,1483,1548, -1484,1548,1483, -1548,1484,1549, -1485,1549,1484, -1549,1485,1550, -1486,1550,1485, -1550,1486,1551, -1487,1551,1486, -1551,1487,1552, -1488,1552,1487, -1552,1488,1553, -1489,1553,1488, -1553,1489,1554, -1490,1554,1489, -1554,1490,1555, -1491,1555,1490, -1555,1491,1556, -1492,1556,1491, -1556,1492,1557, -1493,1557,1492, -1557,1493,1558, -1494,1558,1493, -1558,1494,1559, -1495,1559,1494, -1559,1495,1560, -1496,1560,1495, -1560,1496,1561, -1497,1561,1496, -1561,1497,1562, -1498,1562,1497, -1562,1498,1563, -1499,1563,1498, -1563,1499,1564, -1500,1564,1499, -1564,1500,1565, -1501,1565,1500, -1565,1501,1566, -1502,1566,1501, -1566,1502,1567, -1503,1567,1502, -1567,1503,1568, -1504,1568,1503, -1568,1504,1569, -1505,1569,1504, -1569,1505,1570, -1506,1570,1505, -1570,1506,1571, -1507,1571,1506, -1571,1507,1572, -1508,1572,1507, -1572,1508,1573, -1509,1573,1508, -1573,1509,1574, -1510,1574,1509, -1574,1510,1575, -1511,1575,1510, -1575,1511,1576, -1512,1576,1511, -1576,1512,1577, -1513,1577,1512, -1577,1513,1578, -1514,1578,1513, -1578,1514,1579, -1515,1579,1514, -1579,1515,1580, -1516,1580,1515, -1580,1516,1581, -1517,1581,1516, -1581,1517,1582, -1518,1582,1517, -1582,1518,1583, -1519,1583,1518, -1583,1519,1584, -1520,1584,1519, -1584,1520,1585, -1521,1585,1520, -1585,1521,1586, -1522,1586,1521, -1586,1522,1587, -1523,1587,1522, -1587,1523,1588, -1524,1588,1523, -1588,1524,1589, -1525,1589,1524, -1589,1525,1590, -1526,1590,1525, -1590,1526,1591, -1527,1591,1526, -1591,1527,1592, -1528,1592,1527, -1592,1528,1593, -1529,1593,1528, -1593,1529,1594, -1530,1594,1529, -1594,1530,1595, -1531,1595,1530, -1595,1531,1596, -1532,1596,1531, -1596,1532,1597, -1533,1597,1532, -1597,1533,1598, -1534,1598,1533, -1598,1534,1599, -1535,1599,1534, -1600,1536,1601, -1537,1601,1536, -1601,1537,1602, -1538,1602,1537, -1602,1538,1603, -1539,1603,1538, -1603,1539,1604, -1540,1604,1539, -1604,1540,1605, -1541,1605,1540, -1605,1541,1606, -1542,1606,1541, -1606,1542,1607, -1543,1607,1542, -1607,1543,1608, -1544,1608,1543, -1608,1544,1609, -1545,1609,1544, -1609,1545,1610, -1546,1610,1545, -1610,1546,1611, -1547,1611,1546, -1611,1547,1612, -1548,1612,1547, -1612,1548,1613, -1549,1613,1548, -1613,1549,1614, -1550,1614,1549, -1614,1550,1615, -1551,1615,1550, -1615,1551,1616, -1552,1616,1551, -1616,1552,1617, -1553,1617,1552, -1617,1553,1618, -1554,1618,1553, -1618,1554,1619, -1555,1619,1554, -1619,1555,1620, -1556,1620,1555, -1620,1556,1621, -1557,1621,1556, -1621,1557,1622, -1558,1622,1557, -1622,1558,1623, -1559,1623,1558, -1623,1559,1624, -1560,1624,1559, -1624,1560,1625, -1561,1625,1560, -1625,1561,1626, -1562,1626,1561, -1626,1562,1627, -1563,1627,1562, -1627,1563,1628, -1564,1628,1563, -1628,1564,1629, -1565,1629,1564, -1629,1565,1630, -1566,1630,1565, -1630,1566,1631, -1567,1631,1566, -1631,1567,1632, -1568,1632,1567, -1632,1568,1633, -1569,1633,1568, -1633,1569,1634, -1570,1634,1569, -1634,1570,1635, -1571,1635,1570, -1635,1571,1636, -1572,1636,1571, -1636,1572,1637, -1573,1637,1572, -1637,1573,1638, -1574,1638,1573, -1638,1574,1639, -1575,1639,1574, -1639,1575,1640, -1576,1640,1575, -1640,1576,1641, -1577,1641,1576, -1641,1577,1642, -1578,1642,1577, -1642,1578,1643, -1579,1643,1578, -1643,1579,1644, -1580,1644,1579, -1644,1580,1645, -1581,1645,1580, -1645,1581,1646, -1582,1646,1581, -1646,1582,1647, -1583,1647,1582, -1647,1583,1648, -1584,1648,1583, -1648,1584,1649, -1585,1649,1584, -1649,1585,1650, -1586,1650,1585, -1650,1586,1651, -1587,1651,1586, -1651,1587,1652, -1588,1652,1587, -1652,1588,1653, -1589,1653,1588, -1653,1589,1654, -1590,1654,1589, -1654,1590,1655, -1591,1655,1590, -1655,1591,1656, -1592,1656,1591, -1656,1592,1657, -1593,1657,1592, -1657,1593,1658, -1594,1658,1593, -1658,1594,1659, -1595,1659,1594, -1659,1595,1660, -1596,1660,1595, -1660,1596,1661, -1597,1661,1596, -1661,1597,1662, -1598,1662,1597, -1662,1598,1663, -1599,1663,1598, -1664,1600,1665, -1601,1665,1600, -1665,1601,1666, -1602,1666,1601, -1666,1602,1667, -1603,1667,1602, -1667,1603,1668, -1604,1668,1603, -1668,1604,1669, -1605,1669,1604, -1669,1605,1670, -1606,1670,1605, -1670,1606,1671, -1607,1671,1606, -1671,1607,1672, -1608,1672,1607, -1672,1608,1673, -1609,1673,1608, -1673,1609,1674, -1610,1674,1609, -1674,1610,1675, -1611,1675,1610, -1675,1611,1676, -1612,1676,1611, -1676,1612,1677, -1613,1677,1612, -1677,1613,1678, -1614,1678,1613, -1678,1614,1679, -1615,1679,1614, -1679,1615,1680, -1616,1680,1615, -1680,1616,1681, -1617,1681,1616, -1681,1617,1682, -1618,1682,1617, -1682,1618,1683, -1619,1683,1618, -1683,1619,1684, -1620,1684,1619, -1684,1620,1685, -1621,1685,1620, -1685,1621,1686, -1622,1686,1621, -1686,1622,1687, -1623,1687,1622, -1687,1623,1688, -1624,1688,1623, -1688,1624,1689, -1625,1689,1624, -1689,1625,1690, -1626,1690,1625, -1690,1626,1691, -1627,1691,1626, -1691,1627,1692, -1628,1692,1627, -1692,1628,1693, -1629,1693,1628, -1693,1629,1694, -1630,1694,1629, -1694,1630,1695, -1631,1695,1630, -1695,1631,1696, -1632,1696,1631, -1696,1632,1697, -1633,1697,1632, -1697,1633,1698, -1634,1698,1633, -1698,1634,1699, -1635,1699,1634, -1699,1635,1700, -1636,1700,1635, -1700,1636,1701, -1637,1701,1636, -1701,1637,1702, -1638,1702,1637, -1702,1638,1703, -1639,1703,1638, -1703,1639,1704, -1640,1704,1639, -1704,1640,1705, -1641,1705,1640, -1705,1641,1706, -1642,1706,1641, -1706,1642,1707, -1643,1707,1642, -1707,1643,1708, -1644,1708,1643, -1708,1644,1709, -1645,1709,1644, -1709,1645,1710, -1646,1710,1645, -1710,1646,1711, -1647,1711,1646, -1711,1647,1712, -1648,1712,1647, -1712,1648,1713, -1649,1713,1648, -1713,1649,1714, -1650,1714,1649, -1714,1650,1715, -1651,1715,1650, -1715,1651,1716, -1652,1716,1651, -1716,1652,1717, -1653,1717,1652, -1717,1653,1718, -1654,1718,1653, -1718,1654,1719, -1655,1719,1654, -1719,1655,1720, -1656,1720,1655, -1720,1656,1721, -1657,1721,1656, -1721,1657,1722, -1658,1722,1657, -1722,1658,1723, -1659,1723,1658, -1723,1659,1724, -1660,1724,1659, -1724,1660,1725, -1661,1725,1660, -1725,1661,1726, -1662,1726,1661, -1726,1662,1727, -1663,1727,1662, -1728,1664,1729, -1665,1729,1664, -1729,1665,1730, -1666,1730,1665, -1730,1666,1731, -1667,1731,1666, -1731,1667,1732, -1668,1732,1667, -1732,1668,1733, -1669,1733,1668, -1733,1669,1734, -1670,1734,1669, -1734,1670,1735, -1671,1735,1670, -1735,1671,1736, -1672,1736,1671, -1736,1672,1737, -1673,1737,1672, -1737,1673,1738, -1674,1738,1673, -1738,1674,1739, -1675,1739,1674, -1739,1675,1740, -1676,1740,1675, -1740,1676,1741, -1677,1741,1676, -1741,1677,1742, -1678,1742,1677, -1742,1678,1743, -1679,1743,1678, -1743,1679,1744, -1680,1744,1679, -1744,1680,1745, -1681,1745,1680, -1745,1681,1746, -1682,1746,1681, -1746,1682,1747, -1683,1747,1682, -1747,1683,1748, -1684,1748,1683, -1748,1684,1749, -1685,1749,1684, -1749,1685,1750, -1686,1750,1685, -1750,1686,1751, -1687,1751,1686, -1751,1687,1752, -1688,1752,1687, -1752,1688,1753, -1689,1753,1688, -1753,1689,1754, -1690,1754,1689, -1754,1690,1755, -1691,1755,1690, -1755,1691,1756, -1692,1756,1691, -1756,1692,1757, -1693,1757,1692, -1757,1693,1758, -1694,1758,1693, -1758,1694,1759, -1695,1759,1694, -1759,1695,1760, -1696,1760,1695, -1760,1696,1761, -1697,1761,1696, -1761,1697,1762, -1698,1762,1697, -1762,1698,1763, -1699,1763,1698, -1763,1699,1764, -1700,1764,1699, -1764,1700,1765, -1701,1765,1700, -1765,1701,1766, -1702,1766,1701, -1766,1702,1767, -1703,1767,1702, -1767,1703,1768, -1704,1768,1703, -1768,1704,1769, -1705,1769,1704, -1769,1705,1770, -1706,1770,1705, -1770,1706,1771, -1707,1771,1706, -1771,1707,1772, -1708,1772,1707, -1772,1708,1773, -1709,1773,1708, -1773,1709,1774, -1710,1774,1709, -1774,1710,1775, -1711,1775,1710, -1775,1711,1776, -1712,1776,1711, -1776,1712,1777, -1713,1777,1712, -1777,1713,1778, -1714,1778,1713, -1778,1714,1779, -1715,1779,1714, -1779,1715,1780, -1716,1780,1715, -1780,1716,1781, -1717,1781,1716, -1781,1717,1782, -1718,1782,1717, -1782,1718,1783, -1719,1783,1718, -1783,1719,1784, -1720,1784,1719, -1784,1720,1785, -1721,1785,1720, -1785,1721,1786, -1722,1786,1721, -1786,1722,1787, -1723,1787,1722, -1787,1723,1788, -1724,1788,1723, -1788,1724,1789, -1725,1789,1724, -1789,1725,1790, -1726,1790,1725, -1790,1726,1791, -1727,1791,1726, -1792,1728,1793, -1729,1793,1728, -1793,1729,1794, -1730,1794,1729, -1794,1730,1795, -1731,1795,1730, -1795,1731,1796, -1732,1796,1731, -1796,1732,1797, -1733,1797,1732, -1797,1733,1798, -1734,1798,1733, -1798,1734,1799, -1735,1799,1734, -1799,1735,1800, -1736,1800,1735, -1800,1736,1801, -1737,1801,1736, -1801,1737,1802, -1738,1802,1737, -1802,1738,1803, -1739,1803,1738, -1803,1739,1804, -1740,1804,1739, -1804,1740,1805, -1741,1805,1740, -1805,1741,1806, -1742,1806,1741, -1806,1742,1807, -1743,1807,1742, -1807,1743,1808, -1744,1808,1743, -1808,1744,1809, -1745,1809,1744, -1809,1745,1810, -1746,1810,1745, -1810,1746,1811, -1747,1811,1746, -1811,1747,1812, -1748,1812,1747, -1812,1748,1813, -1749,1813,1748, -1813,1749,1814, -1750,1814,1749, -1814,1750,1815, -1751,1815,1750, -1815,1751,1816, -1752,1816,1751, -1816,1752,1817, -1753,1817,1752, -1817,1753,1818, -1754,1818,1753, -1818,1754,1819, -1755,1819,1754, -1819,1755,1820, -1756,1820,1755, -1820,1756,1821, -1757,1821,1756, -1821,1757,1822, -1758,1822,1757, -1822,1758,1823, -1759,1823,1758, -1823,1759,1824, -1760,1824,1759, -1824,1760,1825, -1761,1825,1760, -1825,1761,1826, -1762,1826,1761, -1826,1762,1827, -1763,1827,1762, -1827,1763,1828, -1764,1828,1763, -1828,1764,1829, -1765,1829,1764, -1829,1765,1830, -1766,1830,1765, -1830,1766,1831, -1767,1831,1766, -1831,1767,1832, -1768,1832,1767, -1832,1768,1833, -1769,1833,1768, -1833,1769,1834, -1770,1834,1769, -1834,1770,1835, -1771,1835,1770, -1835,1771,1836, -1772,1836,1771, -1836,1772,1837, -1773,1837,1772, -1837,1773,1838, -1774,1838,1773, -1838,1774,1839, -1775,1839,1774, -1839,1775,1840, -1776,1840,1775, -1840,1776,1841, -1777,1841,1776, -1841,1777,1842, -1778,1842,1777, -1842,1778,1843, -1779,1843,1778, -1843,1779,1844, -1780,1844,1779, -1844,1780,1845, -1781,1845,1780, -1845,1781,1846, -1782,1846,1781, -1846,1782,1847, -1783,1847,1782, -1847,1783,1848, -1784,1848,1783, -1848,1784,1849, -1785,1849,1784, -1849,1785,1850, -1786,1850,1785, -1850,1786,1851, -1787,1851,1786, -1851,1787,1852, -1788,1852,1787, -1852,1788,1853, -1789,1853,1788, -1853,1789,1854, -1790,1854,1789, -1854,1790,1855, -1791,1855,1790, -1856,1792,1857, -1793,1857,1792, -1857,1793,1858, -1794,1858,1793, -1858,1794,1859, -1795,1859,1794, -1859,1795,1860, -1796,1860,1795, -1860,1796,1861, -1797,1861,1796, -1861,1797,1862, -1798,1862,1797, -1862,1798,1863, -1799,1863,1798, -1863,1799,1864, -1800,1864,1799, -1864,1800,1865, -1801,1865,1800, -1865,1801,1866, -1802,1866,1801, -1866,1802,1867, -1803,1867,1802, -1867,1803,1868, -1804,1868,1803, -1868,1804,1869, -1805,1869,1804, -1869,1805,1870, -1806,1870,1805, -1870,1806,1871, -1807,1871,1806, -1871,1807,1872, -1808,1872,1807, -1872,1808,1873, -1809,1873,1808, -1873,1809,1874, -1810,1874,1809, -1874,1810,1875, -1811,1875,1810, -1875,1811,1876, -1812,1876,1811, -1876,1812,1877, -1813,1877,1812, -1877,1813,1878, -1814,1878,1813, -1878,1814,1879, -1815,1879,1814, -1879,1815,1880, -1816,1880,1815, -1880,1816,1881, -1817,1881,1816, -1881,1817,1882, -1818,1882,1817, -1882,1818,1883, -1819,1883,1818, -1883,1819,1884, -1820,1884,1819, -1884,1820,1885, -1821,1885,1820, -1885,1821,1886, -1822,1886,1821, -1886,1822,1887, -1823,1887,1822, -1887,1823,1888, -1824,1888,1823, -1888,1824,1889, -1825,1889,1824, -1889,1825,1890, -1826,1890,1825, -1890,1826,1891, -1827,1891,1826, -1891,1827,1892, -1828,1892,1827, -1892,1828,1893, -1829,1893,1828, -1893,1829,1894, -1830,1894,1829, -1894,1830,1895, -1831,1895,1830, -1895,1831,1896, -1832,1896,1831, -1896,1832,1897, -1833,1897,1832, -1897,1833,1898, -1834,1898,1833, -1898,1834,1899, -1835,1899,1834, -1899,1835,1900, -1836,1900,1835, -1900,1836,1901, -1837,1901,1836, -1901,1837,1902, -1838,1902,1837, -1902,1838,1903, -1839,1903,1838, -1903,1839,1904, -1840,1904,1839, -1904,1840,1905, -1841,1905,1840, -1905,1841,1906, -1842,1906,1841, -1906,1842,1907, -1843,1907,1842, -1907,1843,1908, -1844,1908,1843, -1908,1844,1909, -1845,1909,1844, -1909,1845,1910, -1846,1910,1845, -1910,1846,1911, -1847,1911,1846, -1911,1847,1912, -1848,1912,1847, -1912,1848,1913, -1849,1913,1848, -1913,1849,1914, -1850,1914,1849, -1914,1850,1915, -1851,1915,1850, -1915,1851,1916, -1852,1916,1851, -1916,1852,1917, -1853,1917,1852, -1917,1853,1918, -1854,1918,1853, -1918,1854,1919, -1855,1919,1854, -1920,1856,1921, -1857,1921,1856, -1921,1857,1922, -1858,1922,1857, -1922,1858,1923, -1859,1923,1858, -1923,1859,1924, -1860,1924,1859, -1924,1860,1925, -1861,1925,1860, -1925,1861,1926, -1862,1926,1861, -1926,1862,1927, -1863,1927,1862, -1927,1863,1928, -1864,1928,1863, -1928,1864,1929, -1865,1929,1864, -1929,1865,1930, -1866,1930,1865, -1930,1866,1931, -1867,1931,1866, -1931,1867,1932, -1868,1932,1867, -1932,1868,1933, -1869,1933,1868, -1933,1869,1934, -1870,1934,1869, -1934,1870,1935, -1871,1935,1870, -1935,1871,1936, -1872,1936,1871, -1936,1872,1937, -1873,1937,1872, -1937,1873,1938, -1874,1938,1873, -1938,1874,1939, -1875,1939,1874, -1939,1875,1940, -1876,1940,1875, -1940,1876,1941, -1877,1941,1876, -1941,1877,1942, -1878,1942,1877, -1942,1878,1943, -1879,1943,1878, -1943,1879,1944, -1880,1944,1879, -1944,1880,1945, -1881,1945,1880, -1945,1881,1946, -1882,1946,1881, -1946,1882,1947, -1883,1947,1882, -1947,1883,1948, -1884,1948,1883, -1948,1884,1949, -1885,1949,1884, -1949,1885,1950, -1886,1950,1885, -1950,1886,1951, -1887,1951,1886, -1951,1887,1952, -1888,1952,1887, -1952,1888,1953, -1889,1953,1888, -1953,1889,1954, -1890,1954,1889, -1954,1890,1955, -1891,1955,1890, -1955,1891,1956, -1892,1956,1891, -1956,1892,1957, -1893,1957,1892, -1957,1893,1958, -1894,1958,1893, -1958,1894,1959, -1895,1959,1894, -1959,1895,1960, -1896,1960,1895, -1960,1896,1961, -1897,1961,1896, -1961,1897,1962, -1898,1962,1897, -1962,1898,1963, -1899,1963,1898, -1963,1899,1964, -1900,1964,1899, -1964,1900,1965, -1901,1965,1900, -1965,1901,1966, -1902,1966,1901, -1966,1902,1967, -1903,1967,1902, -1967,1903,1968, -1904,1968,1903, -1968,1904,1969, -1905,1969,1904, -1969,1905,1970, -1906,1970,1905, -1970,1906,1971, -1907,1971,1906, -1971,1907,1972, -1908,1972,1907, -1972,1908,1973, -1909,1973,1908, -1973,1909,1974, -1910,1974,1909, -1974,1910,1975, -1911,1975,1910, -1975,1911,1976, -1912,1976,1911, -1976,1912,1977, -1913,1977,1912, -1977,1913,1978, -1914,1978,1913, -1978,1914,1979, -1915,1979,1914, -1979,1915,1980, -1916,1980,1915, -1980,1916,1981, -1917,1981,1916, -1981,1917,1982, -1918,1982,1917, -1982,1918,1983, -1919,1983,1918, -1984,1920,1985, -1921,1985,1920, -1985,1921,1986, -1922,1986,1921, -1986,1922,1987, -1923,1987,1922, -1987,1923,1988, -1924,1988,1923, -1988,1924,1989, -1925,1989,1924, -1989,1925,1990, -1926,1990,1925, -1990,1926,1991, -1927,1991,1926, -1991,1927,1992, -1928,1992,1927, -1992,1928,1993, -1929,1993,1928, -1993,1929,1994, -1930,1994,1929, -1994,1930,1995, -1931,1995,1930, -1995,1931,1996, -1932,1996,1931, -1996,1932,1997, -1933,1997,1932, -1997,1933,1998, -1934,1998,1933, -1998,1934,1999, -1935,1999,1934, -1999,1935,2000, -1936,2000,1935, -2000,1936,2001, -1937,2001,1936, -2001,1937,2002, -1938,2002,1937, -2002,1938,2003, -1939,2003,1938, -2003,1939,2004, -1940,2004,1939, -2004,1940,2005, -1941,2005,1940, -2005,1941,2006, -1942,2006,1941, -2006,1942,2007, -1943,2007,1942, -2007,1943,2008, -1944,2008,1943, -2008,1944,2009, -1945,2009,1944, -2009,1945,2010, -1946,2010,1945, -2010,1946,2011, -1947,2011,1946, -2011,1947,2012, -1948,2012,1947, -2012,1948,2013, -1949,2013,1948, -2013,1949,2014, -1950,2014,1949, -2014,1950,2015, -1951,2015,1950, -2015,1951,2016, -1952,2016,1951, -2016,1952,2017, -1953,2017,1952, -2017,1953,2018, -1954,2018,1953, -2018,1954,2019, -1955,2019,1954, -2019,1955,2020, -1956,2020,1955, -2020,1956,2021, -1957,2021,1956, -2021,1957,2022, -1958,2022,1957, -2022,1958,2023, -1959,2023,1958, -2023,1959,2024, -1960,2024,1959, -2024,1960,2025, -1961,2025,1960, -2025,1961,2026, -1962,2026,1961, -2026,1962,2027, -1963,2027,1962, -2027,1963,2028, -1964,2028,1963, -2028,1964,2029, -1965,2029,1964, -2029,1965,2030, -1966,2030,1965, -2030,1966,2031, -1967,2031,1966, -2031,1967,2032, -1968,2032,1967, -2032,1968,2033, -1969,2033,1968, -2033,1969,2034, -1970,2034,1969, -2034,1970,2035, -1971,2035,1970, -2035,1971,2036, -1972,2036,1971, -2036,1972,2037, -1973,2037,1972, -2037,1973,2038, -1974,2038,1973, -2038,1974,2039, -1975,2039,1974, -2039,1975,2040, -1976,2040,1975, -2040,1976,2041, -1977,2041,1976, -2041,1977,2042, -1978,2042,1977, -2042,1978,2043, -1979,2043,1978, -2043,1979,2044, -1980,2044,1979, -2044,1980,2045, -1981,2045,1980, -2045,1981,2046, -1982,2046,1981, -2046,1982,2047, -1983,2047,1982, -}; - diff --git a/Demos/Benchmarks/main.cpp b/Demos/Benchmarks/main.cpp deleted file mode 100644 index 78c05e5bd..000000000 --- a/Demos/Benchmarks/main.cpp +++ /dev/null @@ -1,89 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BenchmarkDemo.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" -#include - -#ifdef USE_GRAPHICAL_BENCHMARK - #include "GlutStuff.h" - #include "GLDebugDrawer.h" - GLDebugDrawer gDebugDrawer; -#define benchmarkDemo benchmarkDemo2 -#endif //USE_GRAPHICAL_BENCHMARK - - -#define NUM_DEMOS 7 -#define NUM_TESTS 200 - -extern bool gDisableDeactivation; - -int main(int argc,char** argv) -{ - gDisableDeactivation = true; - - BenchmarkDemo1 benchmarkDemo1; - BenchmarkDemo2 benchmarkDemo2; - BenchmarkDemo3 benchmarkDemo3; - BenchmarkDemo4 benchmarkDemo4; - BenchmarkDemo5 benchmarkDemo5; - BenchmarkDemo6 benchmarkDemo6; - BenchmarkDemo7 benchmarkDemo7; - - BenchmarkDemo* demoArray[NUM_DEMOS] = {&benchmarkDemo1,&benchmarkDemo2,&benchmarkDemo3,&benchmarkDemo4,&benchmarkDemo5,&benchmarkDemo6,&benchmarkDemo7}; - const char* demoNames[NUM_DEMOS] = {"3000 fall", "1000 stack", "136 ragdolls","1000 convex", "prim-trimesh", "convex-trimesh","raytests"}; - float totalTime[NUM_DEMOS] = {0.f,0.f,0.f,0.f,0.f,0.f,0.f}; - -#ifdef USE_GRAPHICAL_BENCHMARK - benchmarkDemo.initPhysics(); - benchmarkDemo.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - benchmarkDemo.setDebugMode(benchmarkDemo.getDebugMode() | btIDebugDraw::DBG_NoDeactivation); - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",&benchmarkDemo); - -#else //USE_GRAPHICAL_BENCHMARK - int d; - - for (d=0;dinitPhysics(); - - - for (int i=0;iclientMoveAndDisplay(); - float frameTime = CProfileManager::Get_Time_Since_Reset(); - if ((i % 25)==0) - { - printf("BenchmarkDemo: %s, Frame %d, Duration (ms): %f\n",demoNames[d],i,frameTime); - } - totalTime[d] += frameTime; - if (i==NUM_TESTS-1) - CProfileManager::dumpAll(); - - - } - demoArray[d]->exitPhysics(); - } - - for (d=0;d //printf debugging - - -void Box2dDemo::clientMoveAndDisplay() -{ - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - if (m_dialogDynamicsWorld) - m_dialogDynamicsWorld->draw(ms / 1000000.f); - - glFlush(); - - swapBuffers(); - -} - - - -void Box2dDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - if (m_dialogDynamicsWorld) - m_dialogDynamicsWorld->draw(0.f); - - glFlush(); - swapBuffers(); -} - - - -void Box2dDemo::reshape(int w, int h) -{ - if (m_dialogDynamicsWorld) - m_dialogDynamicsWorld->setScreenSize(w,h); - PlatformDemoApplication::reshape(w,h); -} - -void Box2dDemo::initPhysics() -{ - - m_dialogDynamicsWorld = new GL_DialogDynamicsWorld(); - - //m_dialogDynamicsWorld->createDialog(100,110,200,50); - //m_dialogDynamicsWorld->createDialog(100,00,100,100); - //m_dialogDynamicsWorld->createDialog(0,0,100,100); - GL_DialogWindow* settings = m_dialogDynamicsWorld->createDialog(50,0,200,120,"Settings"); - GL_ToggleControl* toggle = m_dialogDynamicsWorld->createToggle(settings,"Toggle 1"); - toggle = m_dialogDynamicsWorld->createToggle(settings,"Toggle 2"); - toggle ->m_active = true; - toggle = m_dialogDynamicsWorld->createToggle(settings,"Toggle 3"); - //GL_SliderControl* slider = m_dialogDynamicsWorld->createSlider(settings,"Slider"); - - GL_DialogWindow* dialog = m_dialogDynamicsWorld->createDialog(0,200,420,300,"Help"); - GL_TextControl* txt = new GL_TextControl; - dialog->addControl(txt); - txt->m_textLines.push_back("Mouse to move"); - txt->m_textLines.push_back("Test 2"); - txt->m_textLines.push_back("mouse to interact"); - txt->m_textLines.push_back("ALT + mouse to move camera"); - txt->m_textLines.push_back("space to reset"); - txt->m_textLines.push_back("cursor keys and z,x to navigate"); - txt->m_textLines.push_back("i to toggle simulation, s single step"); - txt->m_textLines.push_back("q to quit"); - txt->m_textLines.push_back(". to shoot box"); - txt->m_textLines.push_back("d to toggle deactivation"); - txt->m_textLines.push_back("g to toggle mesh animation (ConcaveDemo)"); - txt->m_textLines.push_back("h to toggle help text"); - txt->m_textLines.push_back("o to toggle orthogonal/perspective view"); - //txt->m_textLines.push_back("+- shooting speed = %10.2f",m_ShootBoxInitialSpeed); - - - - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(SCALING*50.)); - m_cameraTargetPosition.setValue(0,0,0);//0, ARRAY_SIZE_Y, 0); - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - btVoronoiSimplexSolver* simplex = new btVoronoiSimplexSolver(); - btMinkowskiPenetrationDepthSolver* pdSolver = new btMinkowskiPenetrationDepthSolver(); - - - btConvex2dConvex2dAlgorithm::CreateFunc* convexAlgo2d = new btConvex2dConvex2dAlgorithm::CreateFunc(simplex,pdSolver); - - m_dispatcher->registerCollisionCreateFunc(CONVEX_2D_SHAPE_PROXYTYPE,CONVEX_2D_SHAPE_PROXYTYPE,convexAlgo2d); - m_dispatcher->registerCollisionCreateFunc(BOX_2D_SHAPE_PROXYTYPE,CONVEX_2D_SHAPE_PROXYTYPE,convexAlgo2d); - m_dispatcher->registerCollisionCreateFunc(CONVEX_2D_SHAPE_PROXYTYPE,BOX_2D_SHAPE_PROXYTYPE,convexAlgo2d); - m_dispatcher->registerCollisionCreateFunc(BOX_2D_SHAPE_PROXYTYPE,BOX_2D_SHAPE_PROXYTYPE,new btBox2dBox2dCollisionAlgorithm::CreateFunc()); - - m_broadphase = new btDbvtBroadphase(); - //m_broadphase = new btSimpleBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - //m_dynamicsWorld->getSolverInfo().m_erp = 1.f; - //m_dynamicsWorld->getSolverInfo().m_numIterations = 4; - - - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(150.),btScalar(50.),btScalar(150.))); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-43,0)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btScalar u= btScalar(1*SCALING-0.04); - btVector3 points[3] = {btVector3(0,u,0),btVector3(-u,-u,0),btVector3(u,-u,0)}; - btConvexShape* childShape0 = new btBoxShape(btVector3(btScalar(SCALING*1),btScalar(SCALING*1),btScalar(0.04))); - btConvexShape* colShape= new btConvex2dShape(childShape0); - //btCollisionShape* colShape = new btBox2dShape(btVector3(SCALING*1,SCALING*1,0.04)); - btConvexShape* childShape1 = new btConvexHullShape(&points[0].getX(),3); - btConvexShape* colShape2= new btConvex2dShape(childShape1); - btConvexShape* childShape2 = new btCylinderShapeZ(btVector3(btScalar(SCALING*1),btScalar(SCALING*1),btScalar(0.04))); - btConvexShape* colShape3= new btConvex2dShape(childShape2); - - - m_collisionShapes.push_back(colShape); - m_collisionShapes.push_back(colShape2); - m_collisionShapes.push_back(colShape3); - - m_collisionShapes.push_back(childShape0); - m_collisionShapes.push_back(childShape1); - m_collisionShapes.push_back(childShape2); - - - //btUniformScalingShape* colShape = new btUniformScalingShape(convexColShape,1.f); - colShape->setMargin(btScalar(0.03)); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - -// float start_x = START_POS_X - ARRAY_SIZE_X/2; -// float start_y = START_POS_Y; -// float start_z = START_POS_Z - ARRAY_SIZE_Z/2; - - btVector3 x(-ARRAY_SIZE_X, 8.0f,-20.f); - btVector3 y; - btVector3 deltaX(SCALING*1, SCALING*2,0.f); - btVector3 deltaY(SCALING*2, 0.0f,0.f); - - for (int i = 0; i < ARRAY_SIZE_X; ++i) - { - y = x; - - for (int j = i; j < ARRAY_SIZE_Y; ++j) - { - startTransform.setOrigin(y-btVector3(-10,0,0)); - - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(0,0,0); - switch (j%3) - { -#if 1 - case 0: - rbInfo = btRigidBody::btRigidBodyConstructionInfo(mass,myMotionState,colShape,localInertia); - break; - case 1: - rbInfo = btRigidBody::btRigidBodyConstructionInfo(mass,myMotionState,colShape3,localInertia); - break; -#endif - default: - rbInfo = btRigidBody::btRigidBodyConstructionInfo(mass,myMotionState,colShape2,localInertia); - } - btRigidBody* body = new btRigidBody(rbInfo); - //body->setContactProcessingThreshold(colShape->getContactBreakingThreshold()); - body->setActivationState(ISLAND_SLEEPING); - body->setLinearFactor(btVector3(1,1,0)); - body->setAngularFactor(btVector3(0,0,1)); - - m_dynamicsWorld->addRigidBody(body); - body->setActivationState(ISLAND_SLEEPING); - - - // y += -0.8*deltaY; - y += deltaY; - } - - x += deltaX; - } - - } - - - clientResetScene(); -} - - -void Box2dDemo::exitPhysics() -{ - delete m_dialogDynamicsWorld; - m_dialogDynamicsWorld = 0; - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - if (m_dynamicsWorld) - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;jmouseFunc(button,state,x,y)) - { - DemoApplication::mouseFunc(button,state,x,y); - } -} - -void Box2dDemo::mouseMotionFunc(int x,int y) -{ - m_dialogDynamicsWorld->mouseMotionFunc(x,y); - DemoApplication::mouseMotionFunc(x,y); -} - diff --git a/Demos/Box2dDemo/Box2dDemo.h b/Demos/Box2dDemo/Box2dDemo.h deleted file mode 100644 index 02d4cc69b..000000000 --- a/Demos/Box2dDemo/Box2dDemo.h +++ /dev/null @@ -1,89 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef BOX2D_DEMO_H -#define BOX2D_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -#include "LinearMath/btAlignedObjectArray.h" - -class btBroadphaseInterface; -class btCollisionShape; -class btOverlappingPairCache; -class btCollisionDispatcher; -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; -class btDefaultCollisionConfiguration; -class GL_DialogDynamicsWorld; - -///Box2dDemo is good starting point for learning the code base and porting. -class Box2dDemo : public PlatformDemoApplication -{ - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - GL_DialogDynamicsWorld* m_dialogDynamicsWorld; - - public: - - Box2dDemo() : m_dialogDynamicsWorld(0) - { - } - virtual ~Box2dDemo() - { - exitPhysics(); - } - - virtual void reshape(int w, int h); - - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - Box2dDemo* demo = new Box2dDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - virtual void mouseFunc(int button, int state, int x, int y); - virtual void mouseMotionFunc(int x,int y); - - -}; - -#endif //BOX2D_DEMO_H - diff --git a/Demos/Box2dDemo/CMakeLists.txt b/Demos/Box2dDemo/CMakeLists.txt deleted file mode 100644 index 9c993a32c..000000000 --- a/Demos/Box2dDemo/CMakeLists.txt +++ /dev/null @@ -1,59 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -) - -IF (USE_GLUT) - INCLUDE_DIRECTORIES( ${GLUT_INCLUDE_DIR} ) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppBox2dDemo - main.cpp - Box2dDemo.cpp - Box2dDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppBox2dDemo - main.cpp - Box2dDemo.cpp - Box2dDemo.h - ) - ENDIF() -ELSE (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppBox2dDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32Box2dDemo.cpp - Box2dDemo.cpp - Box2dDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBox2dDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBox2dDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBox2dDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - diff --git a/Demos/Box2dDemo/Win32Box2dDemo.cpp b/Demos/Box2dDemo/Win32Box2dDemo.cpp deleted file mode 100644 index fb439063d..000000000 --- a/Demos/Box2dDemo/Win32Box2dDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "Box2dDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new Box2dDemo(); -} - -#endif diff --git a/Demos/Box2dDemo/main.cpp b/Demos/Box2dDemo/main.cpp deleted file mode 100644 index 1b0651c39..000000000 --- a/Demos/Box2dDemo/main.cpp +++ /dev/null @@ -1,61 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "Box2dDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - -class OurValue - { - int m_uid; - - public: - OurValue(const btVector3& initialPos) - :m_position(initialPos) - { - static int gUid=0; - m_uid=gUid; - gUid++; - } - - btVector3 m_position; - int getUid() const - { - return m_uid; - } - }; - - -int main(int argc,char** argv) -{ - GLDebugDrawer gDebugDrawer; - - Box2dDemo ccdDemo; - ccdDemo.initPhysics(); - ccdDemo.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/BspDemo/BspConverter.cpp b/Demos/BspDemo/BspConverter.cpp deleted file mode 100644 index 8d750c32a..000000000 --- a/Demos/BspDemo/BspConverter.cpp +++ /dev/null @@ -1,207 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BspConverter.h" -#include "BspLoader.h" -#include "LinearMath/btVector3.h" -#include "LinearMath/btGeometryUtil.h" -#include -#include - - -void BspConverter::convertBsp(BspLoader& bspLoader,float scaling) -{ - { - - float playstartf[3] = {0,0,100}; - - if (bspLoader.findVectorByName(&playstartf[0],"info_player_start")) - { - printf("found playerstart\n"); - } - else - { - if (bspLoader.findVectorByName(&playstartf[0],"info_player_deathmatch")) - { - printf("found deatchmatch start\n"); - } - } - - btVector3 playerStart (playstartf[0],playstartf[1],playstartf[2]); - - - playerStart[2] += 20.f; //start a bit higher - - playerStart *= scaling; - - - - //progressBegin("Loading bsp"); - - for (int i=0;i planeEquations; - - int brushid = bspLoader.m_dleafbrushes[leaf.firstLeafBrush+b]; - - BSPBrush& brush = bspLoader.m_dbrushes[brushid]; - if (brush.shaderNum!=-1) - { - if (bspLoader.m_dshaders[ brush.shaderNum ].contentFlags & BSPCONTENTS_SOLID) - { - brush.shaderNum = -1; - - for (int p=0;p vertices; - btGeometryUtil::getVerticesFromPlaneEquations(planeEquations,vertices); - - bool isEntity = false; - btVector3 entityTarget(0.f,0.f,0.f); - addConvexVerticesCollider(vertices,isEntity,entityTarget); - - } - } - } - } - } - -#define USE_ENTITIES -#ifdef USE_ENTITIES - - - { - int i; - for (i=0;i=0) && (modelnr < bspLoader.m_nummodels)) - { - const BSPModel& model = bspLoader.m_dmodels[modelnr]; - for (int n=0;n planeEquations; - bool isValidBrush = false; - - //convert brush - const BSPBrush& brush = bspLoader.m_dbrushes[model.firstBrush+n]; - { - for (int p=0;p vertices; - btGeometryUtil::getVerticesFromPlaneEquations(planeEquations,vertices); - - bool isEntity=true; - addConvexVerticesCollider(vertices,isEntity,targetLocation); - - } - } - - } - } - } - else - { - printf("unsupported trigger_push model, md3 ?\n"); - } - } - - } - } - } - } - -#endif //USE_ENTITIES - - - - //progressEnd(); - } - - } - - - - - - diff --git a/Demos/BspDemo/BspConverter.h b/Demos/BspDemo/BspConverter.h deleted file mode 100644 index aca44db27..000000000 --- a/Demos/BspDemo/BspConverter.h +++ /dev/null @@ -1,39 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef BSP_CONVERTER_H -#define BSP_CONVERTER_H - -class BspLoader; -#include "LinearMath/btVector3.h" -#include "LinearMath/btAlignedObjectArray.h" - -///BspConverter turns a loaded bsp level into convex parts (vertices) -class BspConverter -{ - public: - - void convertBsp(BspLoader& bspLoader,float scaling); - virtual ~BspConverter() - { - } - - ///this callback is called for each brush that succesfully converted into vertices - virtual void addConvexVerticesCollider(btAlignedObjectArray& vertices, bool isEntity, const btVector3& entityTargetLocation) = 0; - -}; - -#endif //BSP_CONVERTER_H - diff --git a/Demos/BspDemo/BspDemo.bsp b/Demos/BspDemo/BspDemo.bsp deleted file mode 100644 index 4ed414d75..000000000 Binary files a/Demos/BspDemo/BspDemo.bsp and /dev/null differ diff --git a/Demos/BspDemo/BspDemo.cpp b/Demos/BspDemo/BspDemo.cpp deleted file mode 100644 index 52e48eb1b..000000000 --- a/Demos/BspDemo/BspDemo.cpp +++ /dev/null @@ -1,313 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" - -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" - - -#define QUAKE_BSP_IMPORTING 1 - -#ifdef QUAKE_BSP_IMPORTING -#include "BspLoader.h" -#include "BspConverter.h" -#endif //QUAKE_BSP_IMPORTING - - -#include //printf debugging - - -#include "BspDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - - - - -#define CUBE_HALF_EXTENTS 1 -#define EXTRA_HEIGHT -20.f - - - -///BspToBulletConverter extends the BspConverter to convert to Bullet datastructures -class BspToBulletConverter : public BspConverter -{ - BspDemo* m_demoApp; - -public: - - BspToBulletConverter(BspDemo* demoApp) - :m_demoApp(demoApp) - { - } - - virtual void addConvexVerticesCollider(btAlignedObjectArray& vertices, bool isEntity, const btVector3& entityTargetLocation) - { - ///perhaps we can do something special with entities (isEntity) - ///like adding a collision Triggering (as example) - - if (vertices.size() > 0) - { - float mass = 0.f; - btTransform startTransform; - //can use a shift - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,0,-10.f)); - //this create an internal copy of the vertices - - btCollisionShape* shape = new btConvexHullShape(&(vertices[0].getX()),vertices.size()); - m_demoApp->m_collisionShapes.push_back(shape); - - //btRigidBody* body = m_demoApp->localCreateRigidBody(mass, startTransform,shape); - m_demoApp->localCreateRigidBody(mass, startTransform,shape); - } - } -}; - - - - - -//////////////////////////////////// - - - - - - - -BspDemo::~BspDemo() -{ - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;jsetGravity(-m_cameraUp * 10); - - -#ifdef QUAKE_BSP_IMPORTING - - void* memoryBuffer = 0; - - const char* filename = "BspDemo.bsp"; - - const char* prefix[]={"./","../","../../","../../../","../../../../", "BspDemo/", "Demos/BspDemo/", - "../Demos/BspDemo/","../../Demos/BspDemo/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - FILE* file=0; - - for (int i=0;istepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - glutSwapBuffers(); - -} - - - -void BspDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - glutSwapBuffers(); -} - - - - - - -//some code that de-mangles the windows filename passed in as argument -char cleaned_filename[512]; -char* getLastFileName() -{ - return cleaned_filename; -} -char* makeExeToBspFilename(const char* lpCmdLine) -{ - - - // We might get a windows-style path on the command line, this can mess up the DOM which expects - // all paths to be URI's. This block of code does some conversion to try and make the input - // compliant without breaking the ability to accept a properly formatted URI. Right now this only - // displays the first filename - const char *in = lpCmdLine; - char* out = cleaned_filename; - *out = '\0'; - // If the first character is a ", skip it (filenames with spaces in them are quoted) - if(*in == '\"') - { - in++; - } - int i; - for(i =0; i<512; i++) - { - //if we get '.' we stop as well, unless it's the first character. Then we add .bsp as extension - // If we hit a null or a quote, stop copying. This will get just the first filename. - if(i && (in[0] == '.') && (in[1] == 'e') && (in[2] == 'x') && (in[3] == 'e')) - break; - - // If we hit a null or a quote, stop copying. This will get just the first filename. - if(*in == '\0' || *in == '\"') - break; - // Copy while swapping backslashes for forward ones - if(*in == '\\') - { - *out = '/'; - } - else - { - *out = *in; - } - in++; - out++; - } - *(out++) = '.'; - *(out++) = 'b'; - *(out++) = 's'; - *(out++) = 'p'; - *(out++) = 0; - - return cleaned_filename; -} diff --git a/Demos/BspDemo/BspDemo.h b/Demos/BspDemo/BspDemo.h deleted file mode 100644 index d2f5d7a30..000000000 --- a/Demos/BspDemo/BspDemo.h +++ /dev/null @@ -1,71 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef BSP_DEMO_H -#define BSP_DEMO_H - -#include "GlutDemoApplication.h" -#include "LinearMath/btAlignedObjectArray.h" - -class btBroadphaseInterface; -class btCollisionShape; -class btOverlappingPairCache; -class btCollisionDispatcher; -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; -class btDefaultCollisionConfiguration; - - -///BspDemo shows the convex collision detection, by converting a Quake BSP file into convex objects and allowing interaction with boxes. -class BspDemo : public GlutDemoApplication -{ - public: - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - - - - virtual ~BspDemo(); - - virtual void initPhysics(); - - void initPhysics(const char* bspfilename); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - BspDemo* demo = new BspDemo; - demo->myinit(); - demo->initPhysics("BspDemo.bsp"); - return demo; - } - -}; - -#endif //BSP_DEMO_H - - diff --git a/Demos/BspDemo/BspLoader.cpp b/Demos/BspDemo/BspLoader.cpp deleted file mode 100644 index 0572463ae..000000000 --- a/Demos/BspDemo/BspLoader.cpp +++ /dev/null @@ -1,730 +0,0 @@ -/* -=========================================================================== -Copyright (C) 1999-2005 Id Software, Inc. - -This file is part of Quake III Arena source code. - -Quake III Arena source code is free software; you can redistribute it -and/or modify it under the terms of the GNU bteral Public License as -published by the Free Software Foundation; either version 2 of the License, -or (at your option) any later version. - -Quake III Arena source code 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 -GNU bteral Public License for more details. - -You should have received a copy of the GNU bteral Public License -along with Foobar; if not, write to the Free Software -Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA -=========================================================================== -*/ - - -#include "BspLoader.h" -#include -#include - -typedef struct -{ - char filename[1024]; - char *buffer,*script_p,*end_p; - int line; -} BSPScript; - -#define MAX_INCLUDES 8 -BSPScript scriptstack[MAX_INCLUDES]; -BSPScript *script; -int scriptline; - -char token[BSPMAXTOKEN]; -bool endofscript; -bool tokenready; // only true if UnGetToken was just called - -// -//loadBSPFile -// - -int extrasize = 100; - -BspLoader::BspLoader() - :m_num_entities(0) -{ - m_Endianness = getMachineEndianness(); - if (m_Endianness == BSP_BIG_ENDIAN) - { - printf("Machine is BIG_ENDIAN\n"); - } else - { - printf("Machine is Little Endian\n"); - } -} - - -bool BspLoader::loadBSPFile( void* memoryBuffer) { - - BSPHeader *header = (BSPHeader*) memoryBuffer; - - // load the file header - if (header) - { - // swap the header - swapBlock( (int *)header, sizeof(*header) ); - - int length = (header->lumps[BSPLUMP_SHADERS].filelen) / sizeof(BSPShader); - m_dshaders.resize(length+extrasize); - m_numShaders = copyLump( header, BSPLUMP_SHADERS, &m_dshaders[0], sizeof(BSPShader) ); - - length = (header->lumps[LUMP_MODELS].filelen) / sizeof(BSPModel); - m_dmodels.resize(length+extrasize); - m_nummodels = copyLump( header, LUMP_MODELS, &m_dmodels[0], sizeof(BSPModel) ); - - length = (header->lumps[BSPLUMP_PLANES].filelen) / sizeof(BSPPlane); - m_dplanes.resize(length+extrasize); - m_numplanes = copyLump( header, BSPLUMP_PLANES, &m_dplanes[0], sizeof(BSPPlane) ); - - length = (header->lumps[BSPLUMP_LEAFS].filelen) / sizeof(BSPLeaf); - m_dleafs.resize(length+extrasize); - m_numleafs = copyLump( header, BSPLUMP_LEAFS, &m_dleafs[0], sizeof(BSPLeaf) ); - - length = (header->lumps[BSPLUMP_NODES].filelen) / sizeof(BSPNode); - m_dnodes.resize(length+extrasize); - m_numnodes = copyLump( header, BSPLUMP_NODES, &m_dnodes[0], sizeof(BSPNode) ); - - length = (header->lumps[BSPLUMP_LEAFSURFACES].filelen) / sizeof(m_dleafsurfaces[0]); - m_dleafsurfaces.resize(length+extrasize); - m_numleafsurfaces = copyLump( header, BSPLUMP_LEAFSURFACES, &m_dleafsurfaces[0], sizeof(m_dleafsurfaces[0]) ); - - length = (header->lumps[BSPLUMP_LEAFBRUSHES].filelen) / sizeof(m_dleafbrushes[0]) ; - m_dleafbrushes.resize(length+extrasize); - m_numleafbrushes = copyLump( header, BSPLUMP_LEAFBRUSHES, &m_dleafbrushes[0], sizeof(m_dleafbrushes[0]) ); - - length = (header->lumps[LUMP_BRUSHES].filelen) / sizeof(BSPBrush); - m_dbrushes.resize(length+extrasize); - m_numbrushes = copyLump( header, LUMP_BRUSHES, &m_dbrushes[0], sizeof(BSPBrush) ); - - - length = (header->lumps[LUMP_BRUSHSIDES].filelen) / sizeof(BSPBrushSide); - m_dbrushsides.resize(length+extrasize); - m_numbrushsides = copyLump( header, LUMP_BRUSHSIDES, &m_dbrushsides[0], sizeof(BSPBrushSide) ); - - - length = (header->lumps[LUMP_SURFACES].filelen) / sizeof(BSPSurface); - m_drawSurfaces.resize(length+extrasize); - m_numDrawSurfaces = copyLump( header, LUMP_SURFACES, &m_drawSurfaces[0], sizeof(BSPSurface) ); - - - length = (header->lumps[LUMP_DRAWINDEXES].filelen) / sizeof(m_drawIndexes[0]); - m_drawIndexes.resize(length+extrasize); - m_numDrawIndexes = copyLump( header, LUMP_DRAWINDEXES, &m_drawIndexes[0], sizeof(m_drawIndexes[0]) ); - - length = (header->lumps[LUMP_VISIBILITY].filelen) / 1; - m_visBytes.resize(length+extrasize); - m_numVisBytes = copyLump( header, LUMP_VISIBILITY, &m_visBytes[0], 1 ); - - length = (header->lumps[LUMP_LIGHTMAPS].filelen) / 1; - m_lightBytes.resize(length+extrasize); - m_numLightBytes = copyLump( header, LUMP_LIGHTMAPS, &m_lightBytes[0], 1 ); - - length = (header->lumps[BSPLUMP_ENTITIES].filelen) / 1; - m_dentdata.resize(length+extrasize); - m_entdatasize = copyLump( header, BSPLUMP_ENTITIES, &m_dentdata[0], 1); - - length = (header->lumps[LUMP_LIGHTGRID].filelen) / 1; - m_gridData.resize(length+extrasize); - m_numGridPoints = copyLump( header, LUMP_LIGHTGRID, &m_gridData[0], 8 ); - - // swap everything - swapBSPFile(); - - return true; - - } - return false; -} - - - -const char* BspLoader::getValueForKey( const BSPEntity* ent, const char* key ) const { - - const BSPKeyValuePair* ep; - - for (ep=ent->epairs ; ep ; ep=ep->next) { - if (!strcmp(ep->key, key) ) { - return ep->value; - } - } - return ""; -} - -float BspLoader::getFloatForKey( const BSPEntity *ent, const char *key ) { - const char *k; - - k = getValueForKey( ent, key ); - return float(atof(k)); -} - -bool BspLoader::getVectorForKey( const BSPEntity *ent, const char *key, BSPVector3 vec ) { - - const char *k; - k = getValueForKey (ent, key); - if (strcmp(k, "")) - { - sscanf (k, "%f %f %f", &vec[0], &vec[1], &vec[2]); - return true; - } - return false; -} - - - - -/* -============== -parseFromMemory -============== -*/ -void BspLoader::parseFromMemory (char *buffer, int size) -{ - script = scriptstack; - script++; - if (script == &scriptstack[MAX_INCLUDES]) - { - //printf("script file exceeded MAX_INCLUDES"); - } - strcpy (script->filename, "memory buffer" ); - - script->buffer = buffer; - script->line = 1; - script->script_p = script->buffer; - script->end_p = script->buffer + size; - - endofscript = false; - tokenready = false; -} - - -bool BspLoader::isEndOfScript (bool crossline) -{ - if (!crossline) - //printf("Line %i is incomplete\n",scriptline); - - if (!strcmp (script->filename, "memory buffer")) - { - endofscript = true; - return false; - } - - //free (script->buffer); - if (script == scriptstack+1) - { - endofscript = true; - return false; - } - script--; - scriptline = script->line; - //printf ("returning to %s\n", script->filename); - return getToken (crossline); -} - -/* - -============== -getToken -============== -*/ -bool BspLoader::getToken (bool crossline) -{ - char *token_p; - - if (tokenready) // is a token allready waiting? - { - tokenready = false; - return true; - } - - if (script->script_p >= script->end_p) - return isEndOfScript (crossline); - -// -// skip space -// -skipspace: - while (*script->script_p <= 32) - { - if (script->script_p >= script->end_p) - return isEndOfScript (crossline); - if (*script->script_p++ == '\n') - { - if (!crossline) - { - //printf("Line %i is incomplete\n",scriptline); - } - scriptline = script->line++; - } - } - - if (script->script_p >= script->end_p) - return isEndOfScript (crossline); - - // ; # // comments - if (*script->script_p == ';' || *script->script_p == '#' - || ( script->script_p[0] == '/' && script->script_p[1] == '/') ) - { - if (!crossline) - { - //printf("Line %i is incomplete\n",scriptline); - } - while (*script->script_p++ != '\n') - if (script->script_p >= script->end_p) - return isEndOfScript (crossline); - scriptline = script->line++; - goto skipspace; - } - - // /* */ comments - if (script->script_p[0] == '/' && script->script_p[1] == '*') - { - if (!crossline) - { - //printf("Line %i is incomplete\n",scriptline); - } - script->script_p+=2; - while (script->script_p[0] != '*' && script->script_p[1] != '/') - { - if ( *script->script_p == '\n' ) { - scriptline = script->line++; - } - script->script_p++; - if (script->script_p >= script->end_p) - return isEndOfScript (crossline); - } - script->script_p += 2; - goto skipspace; - } - -// -// copy token -// - token_p = token; - - if (*script->script_p == '"') - { - // quoted token - script->script_p++; - while (*script->script_p != '"') - { - *token_p++ = *script->script_p++; - if (script->script_p == script->end_p) - break; - if (token_p == &token[BSPMAXTOKEN]) - { - //printf ("Token too large on line %i\n",scriptline); - } - } - script->script_p++; - } - else // regular token - while ( *script->script_p > 32 && *script->script_p != ';') - { - *token_p++ = *script->script_p++; - if (script->script_p == script->end_p) - break; - if (token_p == &token[BSPMAXTOKEN]) - { - //printf ("Token too large on line %i\n",scriptline); - } - } - - *token_p = 0; - - if (!strcmp (token, "$include")) - { - //getToken (false); - //AddScriptToStack (token); - return false;//getToken (crossline); - } - - return true; -} - -char *BspLoader::copystring(const char *s) -{ - char *b; - b = (char*) malloc( strlen(s)+1); - strcpy (b, s); - return b; -} - -void BspLoader::stripTrailing( char *e ) { - char *s; - - s = e + strlen(e)-1; - while (s >= e && *s <= 32) - { - *s = 0; - s--; - } -} -/* -================= -parseEpair -================= -*/ -BSPKeyValuePair *BspLoader::parseEpair( void ) { - BSPKeyValuePair *e; - - e = (struct BSPPair*) malloc( sizeof(BSPKeyValuePair)); - memset( e, 0, sizeof(BSPKeyValuePair) ); - - if ( strlen(token) >= BSPMAX_KEY-1 ) { - //printf ("ParseEpar: token too long"); - } - e->key = copystring( token ); - getToken( false ); - if ( strlen(token) >= BSPMAX_VALUE-1 ) { - - //printf ("ParseEpar: token too long"); - } - e->value = copystring( token ); - - // strip trailing spaces that sometimes get accidentally - // added in the editor - stripTrailing( e->key ); - stripTrailing( e->value ); - - return e; -} - - -/* -================ -parseEntity -================ -*/ -bool BspLoader::parseEntity( void ) { - BSPKeyValuePair *e; - BSPEntity *mapent; - - if ( !getToken (true) ) { - return false; - } - - if ( strcmp (token, "{") ) { - - //printf ("parseEntity: { not found"); - } - - BSPEntity bla; - bla.brushes = 0; - bla.epairs = 0; - bla.firstDrawSurf = 0; - bla.origin[0] = 0.f; - bla.origin[1] = 0.f; - bla.origin[2] = 0.f; - bla.patches = 0; - - m_entities.push_back(bla); - mapent = &m_entities[m_entities.size()-1]; - m_num_entities++; - - do { - if ( !getToken (true) ) { - //printf("parseEntity: EOF without closing brace"); - } - if ( !strcmp (token, "}") ) { - break; - } - e = (struct BSPPair*)parseEpair (); - e->next = mapent->epairs; - mapent->epairs = e; - } while (1); - - return true; -} - -/* -================ -parseEntities - -Parses the dentdata string into entities -================ -*/ -void BspLoader::parseEntities( void ) { - m_num_entities = 0; - m_entities.clear(); - - parseFromMemory( &m_dentdata[0], m_entdatasize ); - - while ( parseEntity () ) { - } -} - - - -int BspLoader::getMachineEndianness() -{ - long int i = 1; - const char *p = (const char *) &i; - if (p[0] == 1) // Lowest address contains the least significant byte - return BSP_LITTLE_ENDIAN; - else - return BSP_BIG_ENDIAN; -} - -short BspLoader::isLittleShort (short l) -{ - if (machineEndianness() == BSP_BIG_ENDIAN) - { - unsigned char b1,b2; - - b1 = l&255; - b2 = (l>>8)&255; - - return (b1<<8) + b2; - } - //little endian - return l; -} - -short BspLoader::isBigShort (short l) -{ - if (machineEndianness() == BSP_BIG_ENDIAN) - { - return l; - } - - unsigned char b1,b2; - - b1 = l&255; - b2 = (l>>8)&255; - - return (b1<<8) + b2; - - - -} - - -int BspLoader::isLittleLong (int l) -{ - if (machineEndianness() == BSP_BIG_ENDIAN) - { - unsigned char b1,b2,b3,b4; - - b1 = l&255; - b2 = (l>>8)&255; - b3 = (l>>16)&255; - b4 = (l>>24)&255; - - return ((int)b1<<24) + ((int)b2<<16) + ((int)b3<<8) + b4; - } - - //little endian - return l; - -} - -int BspLoader::isBigLong (int l) -{ - if (machineEndianness() == BSP_BIG_ENDIAN) - { - return l; - } - - - unsigned char b1,b2,b3,b4; - - b1 = l&255; - b2 = (l>>8)&255; - b3 = (l>>16)&255; - b4 = (l>>24)&255; - - return ((int)b1<<24) + ((int)b2<<16) + ((int)b3<<8) + b4; - -} - - -float BspLoader::isLittleFloat (float l) -{ - if (machineEndianness() == BSP_BIG_ENDIAN) - { - union {unsigned char b[4]; float f;} in, out; - - in.f = l; - out.b[0] = in.b[3]; - out.b[1] = in.b[2]; - out.b[2] = in.b[1]; - out.b[3] = in.b[0]; - - return out.f; - } - - //little endian - return l; -} - -float BspLoader::isBigFloat (float l) -{ - if (machineEndianness() == BSP_BIG_ENDIAN) - { - return l; - } - //little endian - union {unsigned char b[4]; float f;} in, out; - - in.f = l; - out.b[0] = in.b[3]; - out.b[1] = in.b[2]; - out.b[2] = in.b[1]; - out.b[3] = in.b[0]; - - return out.f; -} - - - - - - -// -// swapBlock -// If all values are 32 bits, this can be used to swap everything -// - -void BspLoader::swapBlock( int *block, int sizeOfBlock ) { - int i; - - sizeOfBlock >>= 2; - for ( i = 0 ; i < sizeOfBlock ; i++ ) { - block[i] = isLittleLong( block[i] ); - } -} - -// -// copyLump -// - -int BspLoader::copyLump( BSPHeader *header, int lump, void *dest, int size ) { - int length, ofs; - - length = header->lumps[lump].filelen; - ofs = header->lumps[lump].fileofs; - - //if ( length % size ) { - // printf ("loadBSPFile: odd lump size"); - //} - - memcpy( dest, (unsigned char *)header + ofs, length ); - - return length / size; -} - - - - -// -// swapBSPFile -// - -void BspLoader::swapBSPFile( void ) { - int i; - - // models - swapBlock( (int *) &m_dmodels[0], m_nummodels * sizeof( m_dmodels[0] ) ); - - // shaders (don't swap the name) - for ( i = 0 ; i < m_numShaders ; i++ ) { - m_dshaders[i].contentFlags = isLittleLong( m_dshaders[i].contentFlags ); - m_dshaders[i].surfaceFlags = isLittleLong( m_dshaders[i].surfaceFlags ); - } - - // planes - swapBlock( (int *)&m_dplanes[0], m_numplanes * sizeof( m_dplanes[0] ) ); - - // nodes - swapBlock( (int *)&m_dnodes[0], m_numnodes * sizeof( m_dnodes[0] ) ); - - // leafs - swapBlock( (int *)&m_dleafs[0], m_numleafs * sizeof( m_dleafs[0] ) ); - - // leaffaces - swapBlock( (int *)&m_dleafsurfaces[0], m_numleafsurfaces * sizeof( m_dleafsurfaces[0] ) ); - - // leafbrushes - swapBlock( (int *)&m_dleafbrushes[0], m_numleafbrushes * sizeof( m_dleafbrushes[0] ) ); - - // brushes - swapBlock( (int *)&m_dbrushes[0], m_numbrushes * sizeof( m_dbrushes[0] ) ); - - // brushsides - swapBlock( (int *)&m_dbrushsides[0], m_numbrushsides * sizeof( m_dbrushsides[0] ) ); - - // vis - ((int *)&m_visBytes)[0] = isLittleLong( ((int *)&m_visBytes)[0] ); - ((int *)&m_visBytes)[1] = isLittleLong( ((int *)&m_visBytes)[1] ); - - - // drawindexes - swapBlock( (int *)&m_drawIndexes[0], m_numDrawIndexes * sizeof( m_drawIndexes[0] ) ); - - // drawsurfs - swapBlock( (int *)&m_drawSurfaces[0], m_numDrawSurfaces * sizeof( m_drawSurfaces[0] ) ); - -} - - - - - -bool BspLoader::findVectorByName(float* outvec,const char* name) -{ - const char *cl; - BSPVector3 origin; - - bool found = false; - - parseEntities(); - - for ( int i = 1; i < m_num_entities; i++ ) { - cl = getValueForKey (&m_entities[i], "classname"); - if ( !strcmp( cl, "info_player_start" ) ) { - getVectorForKey( &m_entities[i], "origin", origin ); - found = true; - break; - } - if ( !strcmp( cl, "info_player_deathmatch" ) ) { - getVectorForKey( &m_entities[i], "origin", origin ); - found = true; - break; - } - } - - if (found) - { - outvec[0] = origin[0]; - outvec[1] = origin[1]; - outvec[2] = origin[2]; - } - return found; -} - - - -const BSPEntity * BspLoader::getEntityByValue( const char* name, const char* value) -{ - const BSPEntity* entity = NULL; - - for ( int i = 1; i < m_num_entities; i++ ) { - - const BSPEntity& ent = m_entities[i]; - - const char* cl = getValueForKey (&m_entities[i], name); - if ( !strcmp( cl, value ) ) { - entity = &ent; - break; - } - } - return entity; -} - diff --git a/Demos/BspDemo/BspLoader.h b/Demos/BspDemo/BspLoader.h deleted file mode 100644 index b7fc302d7..000000000 --- a/Demos/BspDemo/BspLoader.h +++ /dev/null @@ -1,295 +0,0 @@ -/* -=========================================================================== -Copyright (C) 1999-2005 Id Software, Inc. - -This file is part of Quake III Arena source code. - -Quake III Arena source code is free software; you can redistribute it -and/or modify it under the terms of the GNU bteral Public License as -published by the Free Software Foundation; either version 2 of the License, -or (at your option) any later version. - -Quake III Arena source code 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 -GNU bteral Public License for more details. - -You should have received a copy of the GNU bteral Public License -along with Foobar; if not, write to the Free Software -Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA -=========================================================================== -*/ - - - -#ifndef BSP_LOADER_H -#define BSP_LOADER_H - -#include "LinearMath/btAlignedObjectArray.h" - -#define BSPMAXTOKEN 1024 -#define BSPMAX_KEY 32 -#define BSPMAX_VALUE 1024 -#define BSPCONTENTS_SOLID 1 -#define BSPCONTENTS_AREAPORTAL 0x8000 -#define BSPLUMP_ENTITIES 0 -#define BSPLUMP_SHADERS 1 -#define BSPLUMP_PLANES 2 -#define BSPLUMP_NODES 3 -#define BSPLUMP_LEAFS 4 -#define BSPLUMP_LEAFSURFACES 5 -#define BSPLUMP_LEAFBRUSHES 6 -#define LUMP_MODELS 7 -#define LUMP_BRUSHES 8 -#define LUMP_BRUSHSIDES 9 -#define LUMP_DRAWVERTS 10 -#define LUMP_DRAWINDEXES 11 -#define LUMP_SURFACES 13 -#define LUMP_LIGHTMAPS 14 -#define LUMP_LIGHTGRID 15 -#define LUMP_VISIBILITY 16 -#define HEADER_LUMPS 17 -#define MAX_QPATH 64 - - - -typedef struct { - int fileofs, filelen; -} BSPLump; - -typedef float BSPVector3[3]; - -typedef struct { - int ident; - int version; - - BSPLump lumps[HEADER_LUMPS]; -} BSPHeader; - - -typedef struct { - float mins[3], maxs[3]; - int firstSurface, numSurfaces; - int firstBrush, numBrushes; -} BSPModel; - -typedef struct { - char shader[MAX_QPATH]; - int surfaceFlags; - int contentFlags; -} BSPShader; - -typedef struct { - float normal[3]; - float dist; -} BSPPlane; - -typedef struct { - int planeNum; - int children[2]; - int mins[3]; - int maxs[3]; -} BSPNode; - -typedef struct { - int cluster; - int area; - - int mins[3]; - int maxs[3]; - - int firstLeafSurface; - int numLeafSurfaces; - - int firstLeafBrush; - int numLeafBrushes; -} BSPLeaf; - -typedef struct { - int planeNum; - int shaderNum; -} BSPBrushSide; - -typedef struct { - int firstSide; - int numSides; - int shaderNum; -} BSPBrush; - - - - -typedef struct BSPPair { - struct BSPPair *next; - char *key; - char *value; -} BSPKeyValuePair; - -typedef struct { - BSPVector3 origin; - struct bspbrush_s *brushes; - struct parseMesh_s *patches; - int firstDrawSurf; - BSPKeyValuePair *epairs; -} BSPEntity; - -typedef enum { - MST_BAD, - MST_PLANAR, - MST_PATCH, - MST_TRIANGLE_SOUP, - MST_FLARE -} BSPMapSurface; - -typedef struct { - int shaderNum; - int fogNum; - int surfaceType; - - int firstVert; - int numVerts; - - int firstIndex; - int numIndexes; - - int lightmapNum; - int lightmapX, lightmapY; - int lightmapWidth, lightmapHeight; - - BSPVector3 lightmapOrigin; - BSPVector3 lightmapVecs[3]; - - int patchWidth; - int patchHeight; -} BSPSurface; - - - -///GPL code from IdSofware to parse a Quake 3 BSP file -///check that your platform define __BIG_ENDIAN__ correctly (in BspLoader.cpp) -class BspLoader -{ - int m_Endianness; - - public: - - BspLoader(); - - bool loadBSPFile( void* memoryBuffer); - - const char* getValueForKey( const BSPEntity *ent, const char *key ) const; - - bool getVectorForKey( const BSPEntity *ent, const char *key, BSPVector3 vec ); - - float getFloatForKey( const BSPEntity *ent, const char *key ); - - void parseEntities( void ); - - bool findVectorByName(float* outvec,const char* name); - - const BSPEntity * getEntityByValue( const char* name, const char* value); - - - protected: - - void parseFromMemory (char *buffer, int size); - - - - bool isEndOfScript (bool crossline); - - bool getToken (bool crossline); - - char *copystring(const char *s); - - void stripTrailing( char *e ); - - BSPKeyValuePair * parseEpair( void ); - - bool parseEntity( void ); - - short isLittleShort (short l); - int isLittleLong (int l); - float isLittleFloat (float l); - - int isBigLong (int l); - short isBigShort (short l); - float isBigFloat (float l); - - void swapBlock( int *block, int sizeOfBlock ); - - int copyLump( BSPHeader *header, int lump, void *dest, int size ); - - void swapBSPFile( void ); - - - - - public: //easier for conversion - int m_num_entities; - btAlignedObjectArray m_entities; - - int m_nummodels; - btAlignedObjectArray m_dmodels; - - int m_numShaders; - btAlignedObjectArray m_dshaders; - - int m_entdatasize; - btAlignedObjectArray m_dentdata; - - int m_numleafs; - btAlignedObjectArray m_dleafs; - - int m_numplanes; - btAlignedObjectArray m_dplanes; - - int m_numnodes; - btAlignedObjectArray m_dnodes; - - int m_numleafsurfaces; - btAlignedObjectArray m_dleafsurfaces; - - int m_numleafbrushes; - btAlignedObjectArray m_dleafbrushes; - - int m_numbrushes; - btAlignedObjectArray m_dbrushes; - - int m_numbrushsides; - btAlignedObjectArray m_dbrushsides; - - int m_numLightBytes; - btAlignedObjectArray m_lightBytes; - - int m_numGridPoints; - btAlignedObjectArray m_gridData; - - int m_numVisBytes; - btAlignedObjectArray m_visBytes; - - - int m_numDrawIndexes; - btAlignedObjectArray m_drawIndexes; - - int m_numDrawSurfaces; - btAlignedObjectArray m_drawSurfaces; - - enum - { - BSP_LITTLE_ENDIAN = 0, - BSP_BIG_ENDIAN = 1 - }; - - //returns machines big endian / little endian - // - int getMachineEndianness(); - - inline int machineEndianness() - { - return m_Endianness; - } - -}; - -#endif //BSP_LOADER_H diff --git a/Demos/BspDemo/CMakeLists.txt b/Demos/BspDemo/CMakeLists.txt deleted file mode 100644 index 4d201988f..000000000 --- a/Demos/BspDemo/CMakeLists.txt +++ /dev/null @@ -1,46 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} - -) - -LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppBspPhysicsDemo - main.cpp - BspDemo.cpp - BspLoader.cpp - BspConverter.cpp -) - - - - - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - ADD_CUSTOM_COMMAND( - TARGET AppBspPhysicsDemo - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/BspDemo/BspDemo.bsp ${CMAKE_CURRENT_BINARY_DIR} - ) -ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBspPhysicsDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBspPhysicsDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBspPhysicsDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/BspDemo/main.cpp b/Demos/BspDemo/main.cpp deleted file mode 100644 index e957fa1c0..000000000 --- a/Demos/BspDemo/main.cpp +++ /dev/null @@ -1,59 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#include "BspDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -char* makeExeToBspFilename(const char* lpCmdLine); -char* getLastFileName(); - - -int main(int argc,char** argv) -{ - - BspDemo* bspDemo = new BspDemo(); - - const char* bspfilename = "BspDemo.bsp"; - - printf("argc=%i\n",argc); - { - for (int i=0;i1) - { - bspfilename = argv[1]; - } - - GLDebugDrawer gDebugDrawer; - - // Enrico: TODO: Should change parameter type of initPhysics() to std::string or at least const char * - bspDemo->initPhysics((char*)bspfilename); - - bspDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - - - return glutmain(argc, argv,640,480,"Bullet Quake BSP Physics Viewer http://bulletphysics.org",bspDemo); -} - diff --git a/Demos/BulletDinoDemo/BulletDino.c b/Demos/BulletDinoDemo/BulletDino.c deleted file mode 100644 index 146f28d24..000000000 --- a/Demos/BulletDinoDemo/BulletDino.c +++ /dev/null @@ -1,996 +0,0 @@ - -/* This demo has been modified to use the Bullet C-API. - The C-API is minimal, and will develop based on developer feedback. - The C++ API is recommended, and compatible with the C-API. -*/ - -/* Copyright (c) Mark J. Kilgard, 1994, 1997. */ - -/* This program is freely distributable without licensing fees - and is provided without guarantee or warrantee expressed or - implied. This program is -not- in the public domain. */ - -/* Example for PC game developers to show how to *combine* texturing, - reflections, and projected shadows all in real-time with OpenGL. - Robust reflections use stenciling. Robust projected shadows - use both stenciling and polygon offset. PC game programmers - should realize that neither stenciling nor polygon offset are - supported by Direct3D, so these real-time rendering algorithms - are only really viable with OpenGL. - - The program has modes for disabling the stenciling and polygon - offset uses. It is worth running this example with these features - toggled off so you can see the sort of artifacts that result. - - Notice that the floor texturing, reflections, and shadowing - all co-exist properly. */ - -/* When you run this program: Left mouse button controls the - view. Middle mouse button controls light position (left & - right rotates light around dino; up & down moves light - position up and down). Right mouse button pops up menu. */ - -/* Check out the comments in the "redraw" routine to see how the - reflection blending and surface stenciling is done. You can - also see in "redraw" how the projected shadows are rendered, - including the use of stenciling and polygon offset. */ - -/* This program is derived from glutdino.c */ - -/* Compile: cc -o dinoshade dinoshade.c -lglut -lGLU -lGL -lXmu -lXext -lX11 -lm */ - -#include -#include -#include -#include /* for cos(), sin(), and sqrt() */ -#ifdef WIN32//for glut.h -#include -#endif - -#ifndef WIN32 -#ifndef CALLBACK -#define CALLBACK -#endif -#endif - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#include -#define GLVOIDPTR GLvoid(*)() -#else -#include -#include -#define GLVOIDPTR void(CALLBACK*)() -#endif - -/* Some files do not define M_PI... */ -#ifndef M_PI -#define M_PI 3.14159265 -#endif - - -//#include "../../include/Bullet-C-Api.h" -#include "Bullet-C-Api.h" - - - -plPhysicsSdkHandle physicsSdk=0; -plDynamicsWorldHandle dynamicsWorld=0; -plRigidBodyHandle floorRigidBody; -plRigidBodyHandle dinoRigidBody; - -/* Variable controlling various rendering modes. */ -static int stencilReflection = 1, stencilShadow = 1, offsetShadow = 1; -static int renderShadow = 1, renderDinosaur = 1, renderReflection = 1; -static int linearFiltering = 0, useMipmaps = 0, useTexture = 1; -static int reportSpeed = 0; -static int animation = 1; -static GLboolean lightSwitch = GL_TRUE; -static int directionalLight = 1; -static int forceExtension = 0; - -/* Time varying or user-controled variables. */ -static float jump = 0.0; -static float lightAngle = 0.0, lightHeight = 20; -GLfloat angle = -150; /* in degrees */ -GLfloat angle2 = 30; /* in degrees */ - -int moving, startx, starty; -int lightMoving = 0, lightStartX, lightStartY; - -enum { - MISSING, EXTENSION, ONE_DOT_ONE -}; -int polygonOffsetVersion; - -static GLdouble bodyWidth = 3.0; -/* *INDENT-OFF* */ -static GLfloat body[][2] = { {0, 3}, {1, 1}, {5, 1}, {8, 4}, {10, 4}, {11, 5}, - {11, 11.5}, {13, 12}, {13, 13}, {10, 13.5}, {13, 14}, {13, 15}, {11, 16}, - {8, 16}, {7, 15}, {7, 13}, {8, 12}, {7, 11}, {6, 6}, {4, 3}, {3, 2}, - {1, 2} }; -static GLfloat arm[][2] = { {8, 10}, {9, 9}, {10, 9}, {13, 8}, {14, 9}, {16, 9}, - {15, 9.5}, {16, 10}, {15, 10}, {15.5, 11}, {14.5, 10}, {14, 11}, {14, 10}, - {13, 9}, {11, 11}, {9, 11} }; -static GLfloat leg[][2] = { {8, 6}, {8, 4}, {9, 3}, {9, 2}, {8, 1}, {8, 0.5}, {9, 0}, - {12, 0}, {10, 1}, {10, 2}, {12, 4}, {11, 6}, {10, 7}, {9, 7} }; -static GLfloat eye[][2] = { {8.75, 15}, {9, 14.7}, {9.6, 14.7}, {10.1, 15}, - {9.6, 15.25}, {9, 15.25} }; -static GLfloat lightPosition[4]; -static GLfloat lightColor[] = {0.8, 1.0, 0.8, 1.0}; /* green-tinted */ -static GLfloat skinColor[] = {0.1, 1.0, 0.1, 1.0}, eyeColor[] = {1.0, 0.2, 0.2, 1.0}; -/* *INDENT-ON* */ - -/* Nice floor texture tiling pattern. */ -static char *circles[] = { - "....xxxx........", - "..xxxxxxxx......", - ".xxxxxxxxxx.....", - ".xxx....xxx.....", - "xxx......xxx....", - "xxx......xxx....", - "xxx......xxx....", - "xxx......xxx....", - ".xxx....xxx.....", - ".xxxxxxxxxx.....", - "..xxxxxxxx......", - "....xxxx........", - "................", - "................", - "................", - "................", -}; - -static void -makeFloorTexture(void) -{ - GLubyte floorTexture[16][16][3]; - GLubyte *loc; - int s, t; - loc=0; - - /* Setup RGB image for the texture. */ - loc = (GLubyte*) floorTexture; - for (t = 0; t < 16; t++) { - for (s = 0; s < 16; s++) { - if (circles[t][s] == 'x') { - /* Nice green. */ - loc[0] = 0x1f; - loc[1] = 0x8f; - loc[2] = 0x1f; - } else { - /* Light gray. */ - loc[0] = 0xaa; - loc[1] = 0xaa; - loc[2] = 0xaa; - } - loc += 3; - } - } - - glPixelStorei(GL_UNPACK_ALIGNMENT, 1); - - if (useMipmaps) { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, - GL_LINEAR_MIPMAP_LINEAR); - gluBuild2DMipmaps(GL_TEXTURE_2D, 3, 16, 16, - GL_RGB, GL_UNSIGNED_BYTE, floorTexture); - } else { - if (linearFiltering) { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - } else { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - } - glTexImage2D(GL_TEXTURE_2D, 0, 3, 16, 16, 0, - GL_RGB, GL_UNSIGNED_BYTE, floorTexture); - } -} - -enum { - X, Y, Z, W -}; -enum { - A, B, C, D -}; - -/* Create a matrix that will project the desired shadow. */ -void -shadowMatrix(GLfloat shadowMat[4][4], - GLfloat groundplane[4], - GLfloat lightpos[4]) -{ - GLfloat dot; - - /* Find dot product between light position vector and ground plane normal. */ - dot = groundplane[X] * lightpos[X] + - groundplane[Y] * lightpos[Y] + - groundplane[Z] * lightpos[Z] + - groundplane[W] * lightpos[W]; - - shadowMat[0][0] = dot - lightpos[X] * groundplane[X]; - shadowMat[1][0] = 0.f - lightpos[X] * groundplane[Y]; - shadowMat[2][0] = 0.f - lightpos[X] * groundplane[Z]; - shadowMat[3][0] = 0.f - lightpos[X] * groundplane[W]; - - shadowMat[X][1] = 0.f - lightpos[Y] * groundplane[X]; - shadowMat[1][1] = dot - lightpos[Y] * groundplane[Y]; - shadowMat[2][1] = 0.f - lightpos[Y] * groundplane[Z]; - shadowMat[3][1] = 0.f - lightpos[Y] * groundplane[W]; - - shadowMat[X][2] = 0.f - lightpos[Z] * groundplane[X]; - shadowMat[1][2] = 0.f - lightpos[Z] * groundplane[Y]; - shadowMat[2][2] = dot - lightpos[Z] * groundplane[Z]; - shadowMat[3][2] = 0.f - lightpos[Z] * groundplane[W]; - - shadowMat[X][3] = 0.f - lightpos[W] * groundplane[X]; - shadowMat[1][3] = 0.f - lightpos[W] * groundplane[Y]; - shadowMat[2][3] = 0.f - lightpos[W] * groundplane[Z]; - shadowMat[3][3] = dot - lightpos[W] * groundplane[W]; - -} - -/* Find the plane equation given 3 points. */ -void -findPlane(GLfloat plane[4], - GLfloat v0[3], GLfloat v1[3], GLfloat v2[3]) -{ - GLfloat vec0[3], vec1[3]; - - /* Need 2 vectors to find cross product. */ - vec0[X] = v1[X] - v0[X]; - vec0[Y] = v1[Y] - v0[Y]; - vec0[Z] = v1[Z] - v0[Z]; - - vec1[X] = v2[X] - v0[X]; - vec1[Y] = v2[Y] - v0[Y]; - vec1[Z] = v2[Z] - v0[Z]; - - /* find cross product to get A, B, and C of plane equation */ - plane[A] = vec0[Y] * vec1[Z] - vec0[Z] * vec1[Y]; - plane[B] = -(vec0[X] * vec1[Z] - vec0[Z] * vec1[X]); - plane[C] = vec0[X] * vec1[Y] - vec0[Y] * vec1[X]; - - plane[D] = -(plane[A] * v0[X] + plane[B] * v0[Y] + plane[C] * v0[Z]); -} - -void -extrudeSolidFromPolygon(GLfloat data[][2], unsigned int dataSize, - GLdouble thickness, GLuint side, GLuint edge, GLuint whole) -{ - static GLUtriangulatorObj *tobj = NULL; - GLdouble vertex[3], dx, dy, len; - int i; - int count = dataSize / (2 * sizeof(GLfloat)); - - if (tobj == NULL) { - tobj = gluNewTess(); /* create and initialize a GLU - polygon * * tesselation object */ - gluTessCallback(tobj, (GLenum)GLU_BEGIN, (GLVOIDPTR)glBegin); - gluTessCallback(tobj, (GLenum)GLU_VERTEX, (GLVOIDPTR)glVertex2fv); /* semi-tricky */ - gluTessCallback(tobj, (GLenum)GLU_END, (GLVOIDPTR)glEnd); - } - glNewList(side, GL_COMPILE); - glShadeModel(GL_SMOOTH); /* smooth minimizes seeing - tessellation */ - gluBeginPolygon(tobj); - for (i = 0; i < count; i++) { - vertex[0] = data[i][0]; - vertex[1] = data[i][1]; - vertex[2] = 0; - gluTessVertex(tobj, vertex, data[i]); - } - gluEndPolygon(tobj); - glEndList(); - glNewList(edge, GL_COMPILE); - glShadeModel(GL_FLAT); /* flat shade keeps angular hands - from being "smoothed" */ - glBegin(GL_QUAD_STRIP); - for (i = 0; i <= count; i++) { - /* mod function handles closing the edge */ - glVertex3f(data[i % count][0], data[i % count][1], 0.0); - glVertex3f(data[i % count][0], data[i % count][1], thickness); - /* Calculate a unit normal by dividing by Euclidean - distance. We * could be lazy and use - glEnable(GL_NORMALIZE) so we could pass in * arbitrary - normals for a very slight performance hit. */ - dx = data[(i + 1) % count][1] - data[i % count][1]; - dy = data[i % count][0] - data[(i + 1) % count][0]; - len = sqrt(dx * dx + dy * dy); - glNormal3f(dx / len, dy / len, 0.0); - } - glEnd(); - glEndList(); - glNewList(whole, GL_COMPILE); - glFrontFace(GL_CW); - glCallList(edge); - glNormal3f(0.0, 0.0, -1.0); /* constant normal for side */ - glCallList(side); - glPushMatrix(); - glTranslatef(0.0, 0.0, thickness); - glFrontFace(GL_CCW); - glNormal3f(0.0, 0.0, 1.0); /* opposite normal for other side */ - glCallList(side); - glPopMatrix(); - glEndList(); -} - -/* Enumerants for refering to display lists. */ -typedef enum { - RESERVED, BODY_SIDE, BODY_EDGE, BODY_WHOLE, ARM_SIDE, ARM_EDGE, ARM_WHOLE, - LEG_SIDE, LEG_EDGE, LEG_WHOLE, EYE_SIDE, EYE_EDGE, EYE_WHOLE -} displayLists; - -static void -makeDinosaur(void) -{ - extrudeSolidFromPolygon(body, sizeof(body), bodyWidth, - BODY_SIDE, BODY_EDGE, BODY_WHOLE); - extrudeSolidFromPolygon(arm, sizeof(arm), bodyWidth / 4, - ARM_SIDE, ARM_EDGE, ARM_WHOLE); - extrudeSolidFromPolygon(leg, sizeof(leg), bodyWidth / 2, - LEG_SIDE, LEG_EDGE, LEG_WHOLE); - extrudeSolidFromPolygon(eye, sizeof(eye), bodyWidth + 0.2, - EYE_SIDE, EYE_EDGE, EYE_WHOLE); -} - -static void -drawDinosaur(void) - -{ - plReal matrix[16]; - - glPushMatrix(); - /* Translate the dinosaur to be at (0,8,0). */ - - plGetOpenGLMatrix(dinoRigidBody,matrix); -// plGetPosition(dinoRigidBody,dinoWorldPos); - // glTranslatef(-8, 0, -bodyWidth / 2); - //glTranslatef(0.0, jump, 0.0); -// glTranslatef(dinoWorldPos[0],dinoWorldPos[1],dinoWorldPos[2]); - -#ifdef BT_USE_DOUBLE_PRECISION - glMultMatrixd(matrix); -#else - glMultMatrixf(matrix); -#endif -// glutSolidCube(15); - glTranslatef(-8.5, -8.5, 0); - - glMaterialfv(GL_FRONT, GL_DIFFUSE, skinColor); - glCallList(BODY_WHOLE); - glTranslatef(0.0, 0.0, bodyWidth); - glCallList(ARM_WHOLE); - glCallList(LEG_WHOLE); - glTranslatef(0.0, 0.0, -bodyWidth - bodyWidth / 4); - glCallList(ARM_WHOLE); - glTranslatef(0.0, 0.0, -bodyWidth / 4); - glCallList(LEG_WHOLE); - glTranslatef(0.0, 0.0, bodyWidth / 2 - 0.1); - glMaterialfv(GL_FRONT, GL_DIFFUSE, eyeColor); - glCallList(EYE_WHOLE); - - - glPopMatrix(); -} - -static GLfloat floorVertices[4][3] = { - { -20.0, 0.0, 20.0 }, - { 20.0, 0.0, 20.0 }, - { 20.0, 0.0, -20.0 }, - { -20.0, 0.0, -20.0 }, -}; - -/* Draw a floor (possibly textured). */ -static void -drawFloor(void) -{ - glDisable(GL_LIGHTING); - - if (useTexture) { - glEnable(GL_TEXTURE_2D); - } - - glBegin(GL_QUADS); - glTexCoord2f(0.0, 0.0); - glVertex3fv(floorVertices[0]); - glTexCoord2f(0.0, 16.0); - glVertex3fv(floorVertices[1]); - glTexCoord2f(16.0, 16.0); - glVertex3fv(floorVertices[2]); - glTexCoord2f(16.0, 0.0); - glVertex3fv(floorVertices[3]); - glEnd(); - - if (useTexture) { - glDisable(GL_TEXTURE_2D); - } - - glEnable(GL_LIGHTING); -} - -static GLfloat floorPlane[4]; -static GLfloat floorShadow[4][4]; - -static void -redraw(void) -{ - int start = 0, end = 0 ; - - if (reportSpeed) { - start = glutGet(GLUT_ELAPSED_TIME); - } - - /* Clear; default stencil clears to zero. */ - if ((stencilReflection && renderReflection) || (stencilShadow && renderShadow)) { - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); - } else { - /* Avoid clearing stencil when not using it. */ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - } - - /* Reposition the light source. */ - lightPosition[0] = 12*cos(lightAngle); - lightPosition[1] = lightHeight; - lightPosition[2] = 12*sin(lightAngle); - if (directionalLight) { - lightPosition[3] = 0.0; - } else { - lightPosition[3] = 1.0; - } - - shadowMatrix(floorShadow, floorPlane, lightPosition); - - glPushMatrix(); - /* Perform scene rotations based on user mouse input. */ - glRotatef(angle2, 1.0, 0.0, 0.0); - glRotatef(angle, 0.0, 1.0, 0.0); - - /* Tell GL new light source position. */ - glLightfv(GL_LIGHT0, GL_POSITION, lightPosition); - - if (renderReflection) { - if (stencilReflection) { - /* We can eliminate the visual "artifact" of seeing the "flipped" - dinosaur underneath the floor by using stencil. The idea is - draw the floor without color or depth update but so that - a stencil value of one is where the floor will be. Later when - rendering the dinosaur reflection, we will only update pixels - with a stencil value of 1 to make sure the reflection only - lives on the floor, not below the floor. */ - - /* Don't update color or depth. */ - glDisable(GL_DEPTH_TEST); - glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); - - /* Draw 1 into the stencil buffer. */ - glEnable(GL_STENCIL_TEST); - glStencilOp(GL_REPLACE, GL_REPLACE, GL_REPLACE); - glStencilFunc(GL_ALWAYS, 1, 0xffffffff); - - /* Now render floor; floor pixels just get their stencil set to 1. */ - drawFloor(); - - /* Re-enable update of color and depth. */ - glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); - glEnable(GL_DEPTH_TEST); - - /* Now, only render where stencil is set to 1. */ - glStencilFunc(GL_EQUAL, 1, 0xffffffff); /* draw if ==1 */ - glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP); - } - - glPushMatrix(); - - /* The critical reflection step: Reflect dinosaur through the floor - (the Y=0 plane) to make a relection. */ - glScalef(1.0, -1.0, 1.0); - - /* Reflect the light position. */ - glLightfv(GL_LIGHT0, GL_POSITION, lightPosition); - - /* To avoid our normals getting reversed and hence botched lighting - on the reflection, turn on normalize. */ - glEnable(GL_NORMALIZE); - glCullFace(GL_FRONT); - - /* Draw the reflected dinosaur. */ - drawDinosaur(); - - /* Disable noramlize again and re-enable back face culling. */ - glDisable(GL_NORMALIZE); - glCullFace(GL_BACK); - - glPopMatrix(); - - /* Switch back to the unreflected light position. */ - glLightfv(GL_LIGHT0, GL_POSITION, lightPosition); - - if (stencilReflection) { - glDisable(GL_STENCIL_TEST); - } - } - - /* Back face culling will get used to only draw either the top or the - bottom floor. This let's us get a floor with two distinct - appearances. The top floor surface is reflective and kind of red. - The bottom floor surface is not reflective and blue. */ - - /* Draw "bottom" of floor in blue. */ - glFrontFace(GL_CW); /* Switch face orientation. */ - glColor4f(0.1, 0.1, 0.7, 1.0); - drawFloor(); - glFrontFace(GL_CCW); - - if (renderShadow) { - if (stencilShadow) { - /* Draw the floor with stencil value 3. This helps us only - draw the shadow once per floor pixel (and only on the - floor pixels). */ - glEnable(GL_STENCIL_TEST); - glStencilFunc(GL_ALWAYS, 3, 0xffffffff); - glStencilOp(GL_KEEP, GL_KEEP, GL_REPLACE); - } - } - - /* Draw "top" of floor. Use blending to blend in reflection. */ - glEnable(GL_BLEND); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glColor4f(0.7, 0.0, 0.0, 0.3); - glColor4f(1.0, 1.0, 1.0, 0.3); - drawFloor(); - glDisable(GL_BLEND); - - if (renderDinosaur) { - /* Draw "actual" dinosaur, not its reflection. */ - drawDinosaur(); - } - - if (renderShadow) { - - /* Render the projected shadow. */ - - if (stencilShadow) { - - /* Now, only render where stencil is set above 2 (ie, 3 where - the top floor is). Update stencil with 2 where the shadow - gets drawn so we don't redraw (and accidently reblend) the - shadow). */ - glStencilFunc(GL_LESS, 2, 0xffffffff); /* draw if ==1 */ - glStencilOp(GL_REPLACE, GL_REPLACE, GL_REPLACE); - } - - /* To eliminate depth buffer artifacts, we use polygon offset - to raise the depth of the projected shadow slightly so - that it does not depth buffer alias with the floor. */ - if (offsetShadow) { - switch (polygonOffsetVersion) { - case EXTENSION: -#ifdef GL_VERSION_1_1 - case ONE_DOT_ONE: - glEnable(GL_POLYGON_OFFSET_FILL); - break; -#endif - case MISSING: - /* Oh well. */ - break; - } - } - - /* Render 50% black shadow color on top of whatever the - floor appareance is. */ - glEnable(GL_BLEND); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glDisable(GL_LIGHTING); /* Force the 50% black. */ - glColor4f(0.0, 0.0, 0.0, 0.5); - - glPushMatrix(); - /* Project the shadow. */ - glMultMatrixf((GLfloat *) floorShadow); - drawDinosaur(); - glPopMatrix(); - - glDisable(GL_BLEND); - glEnable(GL_LIGHTING); - - if (offsetShadow) { - switch (polygonOffsetVersion) { -#ifdef GL_VERSION_1_1 - case ONE_DOT_ONE: - glDisable(GL_POLYGON_OFFSET_FILL); - break; -#endif - case MISSING: - /* Oh well. */ - break; - } - } - if (stencilShadow) { - glDisable(GL_STENCIL_TEST); - } - } - - glPushMatrix(); - glDisable(GL_LIGHTING); - glColor3f(1.0, 1.0, 0.0); - if (directionalLight) { - /* Draw an arrowhead. */ - glDisable(GL_CULL_FACE); - glTranslatef(lightPosition[0], lightPosition[1], lightPosition[2]); - glRotatef(lightAngle * -180.0 / M_PI, 0, 1, 0); - glRotatef(atan(lightHeight/12) * 180.0 / M_PI, 0, 0, 1); - glBegin(GL_TRIANGLE_FAN); - glVertex3f(0, 0, 0); - glVertex3f(2, 1, 1); - glVertex3f(2, -1, 1); - glVertex3f(2, -1, -1); - glVertex3f(2, 1, -1); - glVertex3f(2, 1, 1); - glEnd(); - /* Draw a white line from light direction. */ - glColor3f(1.0, 1.0, 1.0); - glBegin(GL_LINES); - glVertex3f(0, 0, 0); - glVertex3f(5, 0, 0); - glEnd(); - glEnable(GL_CULL_FACE); - } else { - /* Draw a yellow ball at the light source. */ - glTranslatef(lightPosition[0], lightPosition[1], lightPosition[2]); - glutSolidSphere(1.0, 5, 5); - } - glEnable(GL_LIGHTING); - glPopMatrix(); - - glPopMatrix(); - - if (reportSpeed) { - glFinish(); - end = glutGet(GLUT_ELAPSED_TIME); - printf("Speed %.3g frames/sec (%d ms)\n", 1000.0/(end-start), end-start); - } - - glutSwapBuffers(); -} - -/* ARGSUSED2 */ -static void -mouse(int button, int state, int x, int y) -{ - if (button == GLUT_LEFT_BUTTON) { - if (state == GLUT_DOWN) { - moving = 1; - startx = x; - starty = y; - } - if (state == GLUT_UP) { - moving = 0; - } - } - if (button == GLUT_MIDDLE_BUTTON) { - if (state == GLUT_DOWN) { - lightMoving = 1; - lightStartX = x; - lightStartY = y; - } - if (state == GLUT_UP) { - lightMoving = 0; - } - } -} - -/* ARGSUSED1 */ -static void -motion(int x, int y) -{ - if (moving) { - angle = angle + (x - startx); - angle2 = angle2 + (y - starty); - startx = x; - starty = y; - glutPostRedisplay(); - } - if (0){//lightMoving) { - lightAngle += (x - lightStartX)/40.0; - lightHeight += (lightStartY - y)/20.0; - lightStartX = x; - lightStartY = y; - glutPostRedisplay(); - } -} - -/* Advance time varying state when idle callback registered. */ -static void -idle(void) -{ - static float time = 0.0; - static float prevtime = 0.0; - float dtime; - prevtime = time; - - time = glutGet(GLUT_ELAPSED_TIME) / 500.0; - dtime = time - prevtime; - - jump = 4.0 * fabs(sin(time)*0.5); - if (!lightMoving) { - lightAngle = time; - } - - if (dynamicsWorld) - plStepSimulation(dynamicsWorld,dtime); - - glutPostRedisplay(); -} - -enum { - M_NONE, M_MOTION, M_LIGHT, M_TEXTURE, M_SHADOWS, M_REFLECTION, M_DINOSAUR, - M_STENCIL_REFLECTION, M_STENCIL_SHADOW, M_OFFSET_SHADOW, - M_POSITIONAL, M_DIRECTIONAL, M_PERFORMANCE -}; - -static void -controlLights(int value) -{ - switch (value) { - case M_NONE: - return; - case M_MOTION: - animation = 1 - animation; - if (animation) { - glutIdleFunc(idle); - } else { - glutIdleFunc(NULL); - } - break; - case M_LIGHT: - lightSwitch = !lightSwitch; - if (lightSwitch) { - glEnable(GL_LIGHT0); - } else { - glDisable(GL_LIGHT0); - } - break; - case M_TEXTURE: - useTexture = !useTexture; - break; - case M_SHADOWS: - renderShadow = 1 - renderShadow; - break; - case M_REFLECTION: - renderReflection = 1 - renderReflection; - break; - case M_DINOSAUR: - renderDinosaur = 1 - renderDinosaur; - break; - case M_STENCIL_REFLECTION: - stencilReflection = 1 - stencilReflection; - break; - case M_STENCIL_SHADOW: - stencilShadow = 1 - stencilShadow; - break; - case M_OFFSET_SHADOW: - offsetShadow = 1 - offsetShadow; - break; - case M_POSITIONAL: - directionalLight = 0; - break; - case M_DIRECTIONAL: - directionalLight = 1; - break; - case M_PERFORMANCE: - reportSpeed = 1 - reportSpeed; - break; - } - glutPostRedisplay(); -} - -/* When not visible, stop animating. Restart when visible again. */ -static void -visible(int vis) -{ - if (vis == GLUT_VISIBLE) { - if (animation) - glutIdleFunc(idle); - } else { - if (!animation) - glutIdleFunc(NULL); - } -} - -/* Press any key to redraw; good when motion stopped and - performance reporting on. */ -/* ARGSUSED */ -static void -key(unsigned char c, int x, int y) -{ - if (c == 27) { - exit(0); /* IRIS GLism, Escape quits. */ - } - glutPostRedisplay(); -} - -/* Press any key to redraw; good when motion stopped and - performance reporting on. */ -/* ARGSUSED */ -static void -special(int k, int x, int y) -{ - glutPostRedisplay(); -} - -static int -supportsOneDotOne(void) -{ - const char *version; - int major, minor; - - version = (char *) glGetString(GL_VERSION); - if (sscanf(version, "%d.%d", &major, &minor) == 2) - return ((major > 1) || (major >= 1 && minor >= 1)); - return 0; /* OpenGL version string malformed! */ -} - - -int -main(int argc, char **argv) -{ - int i; - plCollisionShapeHandle floorShape; - plCollisionShapeHandle dinoShape,dinoChildShape; - plVector3 floorPos,childPos; - plVector3 dinoPos; - plQuaternion childOrn,dinoOrient; - - void* user_data=NULL; - - physicsSdk = plNewBulletSdk(); - dynamicsWorld = plCreateDynamicsWorld(physicsSdk); - - //create ground plane - - floorShape = plNewConvexHullShape(); - - for (i=0;i<4;i++) - { -// floorVertices - plAddVertex(floorShape,floorVertices[i][0],floorVertices[i][1],floorVertices[i][2]); - } - - - floorShape = plNewBoxShape(120,0,120); - - floorRigidBody = plCreateRigidBody(user_data,0.f,floorShape); - floorPos[0] = 0; - floorPos[1] = 0; - floorPos[2] = 0; - - plSetPosition(floorRigidBody,floorPos); - plAddRigidBody(dynamicsWorld,floorRigidBody); - - //create dino rigidbody - dinoChildShape = plNewBoxShape(8.5,8.5,8.5); - dinoShape = plNewCompoundShape(); - childPos[0] = 0; - childPos[1] = 0; - childPos[2] = 0; - childOrn[0] = 0; - childOrn[1] = 0; - childOrn[2] = 0; - childOrn[3] = 1; - - plAddChildShape(dinoShape,dinoChildShape,childPos,childOrn); - - dinoPos[0] = -10; dinoPos[1] = 28; dinoPos[2] = 0; - dinoRigidBody = plCreateRigidBody(0,1.0,dinoShape); - plSetPosition(dinoRigidBody,dinoPos); - plSetEuler(0,0,3.15*0.20,dinoOrient); - plSetOrientation(dinoRigidBody,dinoOrient); - - plAddRigidBody(dynamicsWorld,dinoRigidBody); - - printf("BulletDino\n"); - glutInit(&argc, argv); - - for (i=1; i=2 rgb double depth"); -#endif - - glutCreateWindow("Shadowy Leapin' Lizards"); - - if (glutGet(GLUT_WINDOW_STENCIL_SIZE) <= 1) { - printf("dinoshade: Sorry, I need at least 2 bits of stencil.\n"); - exit(1); - } - - /* Register GLUT callbacks. */ - glutDisplayFunc(redraw); - glutMouseFunc(mouse); - glutMotionFunc(motion); - glutVisibilityFunc(visible); - glutKeyboardFunc(key); - glutSpecialFunc(special); - - glutCreateMenu(controlLights); - - glutAddMenuEntry("Toggle motion", M_MOTION); - glutAddMenuEntry("-----------------------", M_NONE); - glutAddMenuEntry("Toggle light", M_LIGHT); - glutAddMenuEntry("Toggle texture", M_TEXTURE); - glutAddMenuEntry("Toggle shadows", M_SHADOWS); - glutAddMenuEntry("Toggle reflection", M_REFLECTION); - glutAddMenuEntry("Toggle dinosaur", M_DINOSAUR); - glutAddMenuEntry("-----------------------", M_NONE); - glutAddMenuEntry("Toggle reflection stenciling", M_STENCIL_REFLECTION); - glutAddMenuEntry("Toggle shadow stenciling", M_STENCIL_SHADOW); - glutAddMenuEntry("Toggle shadow offset", M_OFFSET_SHADOW); - glutAddMenuEntry("----------------------", M_NONE); - glutAddMenuEntry("Positional light", M_POSITIONAL); - glutAddMenuEntry("Directional light", M_DIRECTIONAL); - glutAddMenuEntry("-----------------------", M_NONE); - glutAddMenuEntry("Toggle performance", M_PERFORMANCE); - glutAttachMenu(GLUT_RIGHT_BUTTON); - makeDinosaur(); - -#ifdef GL_VERSION_1_1 - if (supportsOneDotOne() && !forceExtension) { - polygonOffsetVersion = ONE_DOT_ONE; - glPolygonOffset(-2.0, -1.0); - } else -#endif - { - { - polygonOffsetVersion = MISSING; - printf("\ndinoshine: Missing polygon offset.\n"); - printf(" Expect shadow depth aliasing artifacts.\n\n"); - } - } - - glEnable(GL_CULL_FACE); - glEnable(GL_DEPTH_TEST); - glEnable(GL_TEXTURE_2D); - glLineWidth(3.0); - - glMatrixMode(GL_PROJECTION); - gluPerspective( /* field of view in degree */ 40.0, - /* aspect ratio */ 1.0, - /* Z near */ 20.0, /* Z far */ 100.0); - glMatrixMode(GL_MODELVIEW); - gluLookAt(0.0, 8.0, 60.0, /* eye is at (0,0,30) */ - 0.0, 8.0, 0.0, /* center is at (0,0,0) */ - 0.0, 1.0, 0.); /* up is in postivie Y direction */ - - glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, 1); - glLightfv(GL_LIGHT0, GL_DIFFUSE, lightColor); - glLightf(GL_LIGHT0, GL_CONSTANT_ATTENUATION, 0.1); - glLightf(GL_LIGHT0, GL_LINEAR_ATTENUATION, 0.05); - glEnable(GL_LIGHT0); - glEnable(GL_LIGHTING); - - makeFloorTexture(); - - /* Setup floor plane for projected shadow calculations. */ - findPlane(floorPlane, floorVertices[1], floorVertices[2], floorVertices[3]); - - glutMainLoop(); - - plDeleteDynamicsWorld(dynamicsWorld); - plDeletePhysicsSdk(physicsSdk); - - - return 0; /* ANSI C requires main to return int. */ -} diff --git a/Demos/BulletDinoDemo/CMakeLists.txt b/Demos/BulletDinoDemo/CMakeLists.txt deleted file mode 100644 index eb43abb8f..000000000 --- a/Demos/BulletDinoDemo/CMakeLists.txt +++ /dev/null @@ -1,62 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - - -# This is the shortcut to finding GLU, GLUT and OpenGL if they are properly installed on your system -# This should be the case. -INCLUDE (${CMAKE_ROOT}/Modules/FindGLU.cmake) -INCLUDE (${CMAKE_ROOT}/Modules/FindGLUT.cmake) -INCLUDE (${CMAKE_ROOT}/Modules/FindOpenGL.cmake) - - -IF (WIN32) - # This is the Windows code for which Opengl, and Glut are not properly installed - # since I can't install them I must cheat and copy libraries around - INCLUDE_DIRECTORIES(${GLUT_ROOT}) - # LINK_DIRECTORIES(${GLUT_ROOT}\\lib) - IF (${GLUT_glut_LIBRARY} MATCHES "GLUT_glut_LIBRARY-NOTFOUND") - SET(GLUT_glut_LIBRARY ${BULLET_PHYSICS_SOURCE_DIR}/Glut/glut32.lib) - # LINK_LIBRARIES(${GLUT_ROOT}\\lib\\glut32 ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY}) - # TARGET_LINK_LIBRARIES(table ${GLUT_ROOT}\\lib\\glut32) -# -# ADD_CUSTOM_COMMAND(TARGET table POST_BUILD COMMAND copy ${GLUT_ROOT}\\lib\\glut32.dll ${GLUT_ROOT}\\bin\\vs2005\\Debug -# COMMAND copy ${GLUT_ROOT}\\lib\\glut32.dll ${GLUT_ROOT}\\bin\\vs2003\\Debug -# COMMAND copy ${GLUT_ROOT}\\lib\\glut32.dll ${GLUT_ROOT}\\bin\\vs6\\Debug) - ELSE (${GLUT_glut_LIBRARY} MATCHES "GLUT_glut_LIBRARY-NOTFOUND") -# LINK_LIBRARIES(${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY}) -# TARGET_LINK_LIBRARIES(table ${GLUT_glut_LIBRARY}) - ENDIF(${GLUT_glut_LIBRARY} MATCHES "GLUT_glut_LIBRARY-NOTFOUND") -# TARGET_LINK_LIBRARIES(table ${OPENGL_gl_LIBRARY}) -# TARGET_LINK_LIBRARIES(table ${OPENGL_glu_LIBRARY}) -ELSE (WIN32) - # This is the lines for linux. This should always work if everything is installed and working fine. -# SET(CMAKE_BUILD_TYPE Debug) -# SET(CMAKE_CXX_FLAGS_DEBUG "-g") - INCLUDE_DIRECTORIES(/usr/include /usr/local/include ${GLUT_INCLUDE_DIR}) -# TARGET_LINK_LIBRARIES(table ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY}) -# TARGET_LINK_LIBRARIES(checker ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY}) -ENDIF (WIN32) - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -) - -LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY} -) - -ADD_EXECUTABLE(BulletDino - BulletDino.c -) - diff --git a/Demos/BulletXmlImportDemo/BulletXmlImportDemo.cpp b/Demos/BulletXmlImportDemo/BulletXmlImportDemo.cpp deleted file mode 100644 index dba805a5b..000000000 --- a/Demos/BulletXmlImportDemo/BulletXmlImportDemo.cpp +++ /dev/null @@ -1,198 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2010 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - -#include "BulletXmlImportDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btSerializer.h" -#include "btBulletFile.h" -#include "btBulletWorldImporter.h" -#include "btBulletXmlWorldImporter.h" - -#include "BulletCollision/Gimpact/btGImpactCollisionAlgorithm.h" -#include //printf debugging - - - -#include "GLDebugDrawer.h" -GLDebugDrawer gDebugDrawer; - - -void BulletXmlImportDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - - - setupEmptyDynamicsWorld(); - - - m_dynamicsWorld->setDebugDrawer(&gDebugDrawer); - - - btBulletXmlWorldImporter* importer = new btBulletXmlWorldImporter(m_dynamicsWorld); - static const char* filename = "bullet_basic.xml"; - - const char* prefix[]={"./","../","../../","../../../","../../../../", "BulletXmlImportDemo/", "Demos/BulletXmlImportDemo/", - "../Demos/BulletXmlImportDemo/","../../Demos/BulletXmlImportDemo/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - bool fileFound = false; - - for (int i=0;iloadFile(relativeFileName); -// importer->loadFile("bulletser.xml"); -// importer->loadFile("bullet_constraints.xml"); - -} - -void BulletXmlImportDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - - - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void BulletXmlImportDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - -void BulletXmlImportDemo::setupEmptyDynamicsWorld() -{ - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - btGImpactCollisionAlgorithm::registerAlgorithm(m_dispatcher); - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - - //btGImpactCollisionAlgorithm::registerAlgorithm((btCollisionDispatcher*)m_dynamicsWorld->getDispatcher()); - - - -} - - - - -BulletXmlImportDemo::~BulletXmlImportDemo() -{ - exitPhysics(); -} - -void BulletXmlImportDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void BulletXmlImportDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - public: - - BulletXmlImportDemo() - { - //m_idle=true; - setCameraDistance(btScalar(30.)); - } - virtual ~BulletXmlImportDemo(); - - virtual void clientResetScene(); - - void initPhysics(); - - void setupEmptyDynamicsWorld(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - BulletXmlImportDemo* demo = new BulletXmlImportDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //SERIALIZE_DEMO_H - diff --git a/Demos/BulletXmlImportDemo/CMakeLists.txt b/Demos/BulletXmlImportDemo/CMakeLists.txt deleted file mode 100644 index 175c52964..000000000 --- a/Demos/BulletXmlImportDemo/CMakeLists.txt +++ /dev/null @@ -1,78 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletXmlWorldImporter -${GLUT_INCLUDE_DIR} -) - -ADD_DEFINITIONS(-DDESERIALIZE_SOFT_BODIES) - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletXmlWorldImporter BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppBulletXmlImportDemo - main.cpp - BulletXmlImportDemo.cpp - BulletXmlImportDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppBulletXmlImportDemo - main.cpp - BulletXmlImportDemo.cpp - BulletXmlImportDemo.h - ) - ENDIF() - -ELSE (USE_GLUT) - - LINK_LIBRARIES( - OpenGLSupport BulletXmlWorldImporter BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppBulletXmlImportDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32BulletXmlImportDemo.cpp - BulletXmlImportDemo.cpp - BulletXmlImportDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ENDIF (USE_GLUT) - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES AND NOT INTERNAL_UPDATE_SERIALIZATION_STRUCTURES) - ADD_CUSTOM_COMMAND( - TARGET AppBulletXmlImportDemo - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/BulletXmlImportDemo/bullet_basic.xml ${CMAKE_CURRENT_BINARY_DIR}/bullet_basic.xml - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/BulletXmlImportDemo/bullet_basic.xml ${CMAKE_CURRENT_BINARY_DIR}/Debug/bullet_basic.xml - ) -ENDIF () - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBulletXmlImportDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBulletXmlImportDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBulletXmlImportDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - - diff --git a/Demos/BulletXmlImportDemo/Win32BulletXmlImportDemo.cpp b/Demos/BulletXmlImportDemo/Win32BulletXmlImportDemo.cpp deleted file mode 100644 index 9e8510221..000000000 --- a/Demos/BulletXmlImportDemo/Win32BulletXmlImportDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2010 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BulletXmlImportDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new BulletXmlImportDemo(); -} - -#endif diff --git a/Demos/BulletXmlImportDemo/bullet_basic.xml b/Demos/BulletXmlImportDemo/bullet_basic.xml deleted file mode 100644 index 9205ee067..000000000 --- a/Demos/BulletXmlImportDemo/bullet_basic.xml +++ /dev/null @@ -1,668 +0,0 @@ - - - - - 0.600000 - 1.000000 - 0.300000 - 0.016667 - 0.000000 - 20.000000 - 1.000000 - 0.200000 - 0.800000 - 0.000000 - -0.040000 - 0.100000 - 0.000000 - 0.850000 - 100.000000 - 1000000015047466200000000000000.000000 - 10 - 260 - 2 - 128 - 1 - 0 0 0 0 - - - 0.000000 -10.000000 0.000000 0.000000 - - - - - 0 - 3 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - 0.000000 -50.000000 0.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - -431602080.000000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 1 - -1 - -2 - 2 - 2 - 0 - -51 -51 -51 -51 - - - - 0.000000 0.000000 0.000000 0.000000 - 0.000000 0.000000 0.000000 0.000000 - 0.000000 0.000000 0.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 5 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 14.166666 -3.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 14.166666 -3.000000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - -431602080.000000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 4 - -1 - 1 - 2 - 0 - -51 -51 -51 -51 - - - - 1.500000 0.000000 0.000000 0.000000 - 0.000000 1.500000 0.000000 0.000000 - 0.000000 0.000000 1.500000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.500000 1.500000 1.500000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 5 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 16.166668 -3.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 16.166668 -3.000000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - -431602080.000000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 4 - -1 - 1 - 2 - 0 - -51 -51 -51 -51 - - - - 1.500000 0.000000 0.000000 0.000000 - 0.000000 1.500000 0.000000 0.000000 - 0.000000 0.000000 1.500000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.500000 1.500000 1.500000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 5 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 18.166668 -3.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 18.166668 -3.000000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - -431602080.000000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 4 - -1 - 1 - 2 - 0 - -51 -51 -51 -51 - - - - 1.500000 0.000000 0.000000 0.000000 - 0.000000 1.500000 0.000000 0.000000 - 0.000000 0.000000 1.500000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.500000 1.500000 1.500000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 5 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 20.166668 -3.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 20.166668 -3.000000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - -431602080.000000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 4 - -1 - 1 - 2 - 0 - -51 -51 -51 -51 - - - - 1.500000 0.000000 0.000000 0.000000 - 0.000000 1.500000 0.000000 0.000000 - 0.000000 0.000000 1.500000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.500000 1.500000 1.500000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 5 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 22.166668 -3.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -5.000000 22.166668 -3.000000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - -431602080.000000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 4 - -1 - 1 - 2 - 0 - -51 -51 -51 -51 - - - - 1.500000 0.000000 0.000000 0.000000 - 0.000000 1.500000 0.000000 0.000000 - 0.000000 0.000000 1.500000 0.000000 - - - - 0.000000 -4.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.500000 1.500000 1.500000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 0 - -51 -51 -51 -51 - - - 1.000000 1.000000 1.000000 0.000000 - - - 49.959999 49.959999 49.959999 0.000000 - - 0.040000 - -842150451 - - - - 0 - 0 - -51 -51 -51 -51 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.960000 0.960000 0.960000 0.000000 - - 0.040000 - -842150451 - - diff --git a/Demos/BulletXmlImportDemo/bulletser.xml b/Demos/BulletXmlImportDemo/bulletser.xml deleted file mode 100644 index 82b8b8046..000000000 --- a/Demos/BulletXmlImportDemo/bulletser.xml +++ /dev/null @@ -1,24344 +0,0 @@ - - - - - 0 - 2 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - 0.000000 -7.000000 0.000000 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - 0.000000 -7.000000 0.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.000000 - 1.000000 - 0.000000 - 0.000000 - 0 - 1 - -1 - -2 - 2 - 2 - 0 - - - - 0.000000 0.000000 0.000000 0.000000 - 0.000000 0.000000 0.000000 0.000000 - 0.000000 0.000000 0.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 4 - 0 - 0 - - - - 0.264808 0.292382 0.918907 0.000000 - 0.957898 0.029880 -0.285551 0.000000 - -0.110947 0.955835 -0.272160 0.000000 - - - - -10.018404 16.045120 -1.137200 0.000000 - - - - - - 0.264808 0.292382 0.918907 0.000000 - 0.957898 0.029880 -0.285551 0.000000 - -0.110947 0.955835 -0.272160 0.000000 - - - - -10.018404 16.045120 -1.137200 0.000000 - - - - 0.000313 -3.168241 0.001859 0.000000 - - - -0.000187 0.000277 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.678407 -0.015449 -0.076281 0.000000 - -0.015449 0.658463 -0.002496 0.000000 - -0.076281 -0.002496 0.450866 0.000000 - - - - 0.000313 -3.168241 0.001859 0.000000 - - - -0.000187 0.000277 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.654481 0.427455 0.705801 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 6 - 0 - 0 - - - - 0.242979 0.250713 0.937072 0.000000 - 0.965499 0.030774 -0.258584 0.000000 - -0.093668 0.967572 -0.234586 0.000000 - - - - -11.238498 15.694831 0.166336 0.000000 - - - - - - 0.242979 0.250713 0.937072 0.000000 - 0.965499 0.030774 -0.258584 0.000000 - -0.093668 0.967572 -0.234586 0.000000 - - - - -11.238498 15.694831 0.166336 0.000000 - - - - 0.000846 -3.168296 0.002338 0.000000 - - - -0.000171 0.000315 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.860338 0.016671 -0.009542 0.000000 - 0.016671 0.925339 -0.007493 0.000000 - -0.009542 -0.007493 0.828272 0.000000 - - - - 0.000846 -3.168296 0.002338 0.000000 - - - -0.000171 0.000315 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.930261 0.825561 0.858127 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 8 - 0 - 0 - - - - 0.275672 0.264634 0.924107 0.000000 - 0.958897 -0.008466 -0.283626 0.000000 - -0.067234 0.964312 -0.256090 0.000000 - - - - -2.524789 11.367409 -1.009499 0.000000 - - - - - - 0.275672 0.264634 0.924107 0.000000 - 0.958897 -0.008466 -0.283626 0.000000 - -0.067234 0.964312 -0.256090 0.000000 - - - - -2.524789 11.367409 -1.009499 0.000000 - - - - 0.001664 -3.165827 0.000217 0.000000 - - - -0.000169 0.000337 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.894856 -0.056095 -0.064263 0.000000 - -0.056095 0.732659 0.016010 0.000000 - -0.064263 0.016010 0.680254 0.000000 - - - - 0.001664 -3.165827 0.000217 0.000000 - - - -0.000169 0.000337 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.715410 0.662478 0.929882 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 10 - 0 - 0 - - - - 0.257979 0.278814 0.925046 0.000000 - 0.962798 0.005503 -0.270166 0.000000 - -0.080417 0.960330 -0.267021 0.000000 - - - - -9.919354 17.980125 -0.555819 0.000000 - - - - - - 0.257979 0.278814 0.925046 0.000000 - 0.962798 0.005503 -0.270166 0.000000 - -0.080417 0.960330 -0.267021 0.000000 - - - - -9.919354 17.980125 -0.555819 0.000000 - - - - -0.000078 -3.168092 0.001480 0.000000 - - - -0.000177 0.000339 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.393794 0.005861 -0.002142 0.000000 - 0.005861 0.414610 -0.001863 0.000000 - -0.002142 -0.001863 0.387164 0.000000 - - - - -0.000078 -3.168092 0.001480 0.000000 - - - -0.000177 0.000339 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.416336 0.386531 0.392701 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 12 - 0 - 0 - - - - 0.248511 0.279020 0.927572 0.000000 - 0.965454 0.006127 -0.260503 0.000000 - -0.078369 0.960266 -0.267858 0.000000 - - - - -8.410973 14.244036 -0.442220 0.000000 - - - - - - 0.248511 0.279020 0.927572 0.000000 - 0.965454 0.006127 -0.260503 0.000000 - -0.078369 0.960266 -0.267858 0.000000 - - - - -8.410973 14.244036 -0.442220 0.000000 - - - - 0.001032 -3.167562 0.001671 0.000000 - - - -0.000182 0.000329 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.589460 0.021100 0.021100 0.000000 - 0.021100 0.658852 -0.006107 0.000000 - 0.021100 -0.006107 0.656448 0.000000 - - - - 0.001032 -3.167562 0.001671 0.000000 - - - -0.000182 0.000329 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.664779 0.662540 0.577441 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 14 - 0 - 0 - - - - 0.247185 0.280090 0.927604 0.000000 - 0.958474 0.069834 -0.276497 0.000000 - -0.142222 0.957430 -0.251197 0.000000 - - - - 1.130368 22.070639 -4.238024 0.000000 - - - - - - 0.247185 0.280090 0.927604 0.000000 - 0.958474 0.069834 -0.276497 0.000000 - -0.142222 0.957430 -0.251197 0.000000 - - - - 1.130368 22.070639 -4.238024 0.000000 - - - - -0.002590 -3.165485 -0.002949 0.000000 - - - -0.000169 0.000332 0.000293 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.466322 0.006449 -0.034802 0.000000 - 0.006449 0.507692 -0.013464 0.000000 - -0.034802 -0.013464 0.360131 0.000000 - - - - -0.002590 -3.165485 -0.002949 0.000000 - - - -0.000169 0.000332 0.000293 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.511353 0.348968 0.473824 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 16 - 0 - 0 - - - - 0.266485 0.246893 0.931681 0.000000 - 0.959592 0.022678 -0.280478 0.000000 - -0.090377 0.968777 -0.230873 0.000000 - - - - -9.872525 21.078518 0.099456 0.000000 - - - - - - 0.266485 0.246893 0.931681 0.000000 - 0.959592 0.022678 -0.280478 0.000000 - -0.090377 0.968777 -0.230873 0.000000 - - - - -9.872525 21.078518 0.099456 0.000000 - - - - -0.000733 -3.168016 0.000908 0.000000 - - - -0.000170 0.000350 0.000271 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.339247 -0.021719 -0.005950 0.000000 - -0.021719 0.269707 0.006570 0.000000 - -0.005950 0.006570 0.315268 0.000000 - - - - -0.000733 -3.168016 0.000908 0.000000 - - - -0.000170 0.000350 0.000271 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.263057 0.313905 0.347260 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 18 - 0 - 0 - - - - 0.276870 0.268336 0.922680 0.000000 - 0.955658 0.023338 -0.293552 0.000000 - -0.100304 0.963043 -0.249976 0.000000 - - - - -4.702626 11.224889 -1.168015 0.000000 - - - - - - 0.276870 0.268336 0.922680 0.000000 - 0.955658 0.023338 -0.293552 0.000000 - -0.100304 0.963043 -0.249976 0.000000 - - - - -4.702626 11.224889 -1.168015 0.000000 - - - - 0.001675 -3.166511 0.000977 0.000000 - - - -0.000171 0.000335 0.000309 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.197971 0.007453 0.003046 0.000000 - 0.007453 0.220187 -0.002334 0.000000 - 0.003046 -0.002334 0.208758 0.000000 - - - - 0.001675 -3.166511 0.000977 0.000000 - - - -0.000171 0.000335 0.000309 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.222592 0.209550 0.194775 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 20 - 0 - 0 - - - - 0.283593 0.280329 0.917055 0.000000 - 0.951274 0.038476 -0.305936 0.000000 - -0.121047 0.959132 -0.255759 0.000000 - - - - -10.550672 14.599033 0.296376 0.000000 - - - - - - 0.283593 0.280329 0.917055 0.000000 - 0.951274 0.038476 -0.305936 0.000000 - -0.121047 0.959132 -0.255759 0.000000 - - - - -10.550672 14.599033 0.296376 0.000000 - - - - 0.001169 -3.168065 0.002311 0.000000 - - - -0.000193 0.000324 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 1.236007 0.043334 -0.045267 0.000000 - 0.043334 1.384638 -0.024602 0.000000 - -0.045267 -0.024602 1.101292 0.000000 - - - - 0.001169 -3.168065 0.002311 0.000000 - - - -0.000193 0.000324 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.400687 1.087075 1.234175 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 22 - 0 - 0 - - - - 0.272907 0.234561 0.933007 0.000000 - 0.959242 0.007573 -0.282485 0.000000 - -0.073325 0.972072 -0.222934 0.000000 - - - - 1.922308 18.900015 -3.260913 0.000000 - - - - - - 0.272907 0.234561 0.933007 0.000000 - 0.959242 0.007573 -0.282485 0.000000 - -0.073325 0.972072 -0.222934 0.000000 - - - - 1.922308 18.900015 -3.260913 0.000000 - - - - -0.001330 -3.165045 -0.002655 0.000000 - - - -0.000171 0.000335 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.325534 -0.006948 0.015560 0.000000 - -0.006948 0.299091 0.002383 0.000000 - 0.015560 0.002383 0.386022 0.000000 - - - - -0.001330 -3.165045 -0.002655 0.000000 - - - -0.000171 0.000335 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.296932 0.389795 0.323920 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 24 - 0 - 0 - - - - 0.274333 0.300222 0.913569 0.000000 - 0.961129 -0.054803 -0.270606 0.000000 - -0.031176 0.952294 -0.303587 0.000000 - - - - 0.144925 11.882150 -3.524450 0.000000 - - - - - - 0.274333 0.300222 0.913569 0.000000 - 0.961129 -0.054803 -0.270606 0.000000 - -0.031176 0.952294 -0.303587 0.000000 - - - - 0.144925 11.882150 -3.524450 0.000000 - - - - 0.000599 -3.165483 -0.000786 0.000000 - - - -0.000173 0.000347 0.000287 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.570005 0.021714 0.010805 0.000000 - 0.021714 0.638505 -0.004648 0.000000 - 0.010805 -0.004648 0.596642 0.000000 - - - - 0.000599 -3.165483 -0.000786 0.000000 - - - -0.000173 0.000347 0.000287 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.644854 0.600315 0.559982 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 26 - 0 - 0 - - - - 0.259535 0.269832 0.927271 0.000000 - 0.960981 0.022978 -0.275656 0.000000 - -0.095688 0.962633 -0.253340 0.000000 - - - - -8.745180 13.411012 0.804027 0.000000 - - - - - - 0.259535 0.269832 0.927271 0.000000 - 0.960981 0.022978 -0.275656 0.000000 - -0.095688 0.962633 -0.253340 0.000000 - - - - -8.745180 13.411012 0.804027 0.000000 - - - - 0.001708 -3.167436 0.001931 0.000000 - - - -0.000179 0.000338 0.000311 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.549220 -0.025285 -0.045189 0.000000 - -0.025285 0.479570 0.004850 0.000000 - -0.045189 0.004850 0.398405 0.000000 - - - - 0.001708 -3.167436 0.001931 0.000000 - - - -0.000179 0.000338 0.000311 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.472259 0.385854 0.569083 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 28 - 0 - 0 - - - - 0.243210 0.295166 0.923973 0.000000 - 0.968147 -0.015434 -0.249907 0.000000 - -0.059503 0.955321 -0.289518 0.000000 - - - - -9.695178 19.994808 0.607097 0.000000 - - - - - - 0.243210 0.295166 0.923973 0.000000 - 0.968147 -0.015434 -0.249907 0.000000 - -0.059503 0.955321 -0.289518 0.000000 - - - - -9.695178 19.994808 0.607097 0.000000 - - - - -0.000250 -3.167815 0.001025 0.000000 - - - -0.000188 0.000356 0.000290 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.418109 -0.011465 0.005721 0.000000 - -0.011465 0.374105 0.002523 0.000000 - 0.005721 0.002523 0.435498 0.000000 - - - - -0.000250 -3.167815 0.001025 0.000000 - - - -0.000188 0.000356 0.000290 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.371069 0.437225 0.419418 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 30 - 0 - 0 - - - - 0.266779 0.290382 0.918971 0.000000 - 0.959454 0.009993 -0.281689 0.000000 - -0.090980 0.956859 -0.275942 0.000000 - - - - -9.310074 14.486863 -0.889529 0.000000 - - - - - - 0.266779 0.290382 0.918971 0.000000 - 0.959454 0.009993 -0.281689 0.000000 - -0.090980 0.956859 -0.275942 0.000000 - - - - -9.310074 14.486863 -0.889529 0.000000 - - - - 0.000829 -3.167903 0.001926 0.000000 - - - -0.000175 0.000334 0.000298 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.601416 0.069075 0.034001 0.000000 - 0.069075 0.816951 -0.022019 0.000000 - 0.034001 -0.022019 0.705745 0.000000 - - - - 0.000829 -3.167903 0.001926 0.000000 - - - -0.000175 0.000334 0.000298 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.838246 0.715833 0.570033 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 32 - 0 - 0 - - - - 0.275035 0.243113 0.930189 0.000000 - 0.958017 0.012202 -0.286452 0.000000 - -0.080990 0.969921 -0.229551 0.000000 - - - - -1.096564 13.172791 -2.039617 0.000000 - - - - - - 0.275035 0.243113 0.930189 0.000000 - 0.958017 0.012202 -0.286452 0.000000 - -0.080990 0.969921 -0.229551 0.000000 - - - - -1.096564 13.172791 -2.039617 0.000000 - - - - 0.000771 -3.165606 -0.000599 0.000000 - - - -0.000181 0.000348 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.534793 0.008557 -0.019153 0.000000 - 0.008557 0.567485 -0.003512 0.000000 - -0.019153 -0.003512 0.463653 0.000000 - - - - 0.000771 -3.165606 -0.000599 0.000000 - - - -0.000181 0.000348 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.570238 0.458809 0.536884 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 34 - 0 - 0 - - - - 0.272922 0.269009 0.923660 0.000000 - 0.958389 0.007495 -0.285367 0.000000 - -0.083689 0.963108 -0.255770 0.000000 - - - - -5.976898 12.528832 -0.221821 0.000000 - - - - - - 0.272922 0.269009 0.923660 0.000000 - 0.958389 0.007495 -0.285367 0.000000 - -0.083689 0.963108 -0.255770 0.000000 - - - - -5.976898 12.528832 -0.221821 0.000000 - - - - 0.001635 -3.166748 0.001185 0.000000 - - - -0.000178 0.000312 0.000312 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.316995 0.001262 -0.016360 0.000000 - 0.001262 0.326006 -0.000878 0.000000 - -0.016360 -0.000878 0.263034 0.000000 - - - - 0.001635 -3.166748 0.001185 0.000000 - - - -0.000178 0.000312 0.000312 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.326442 0.258458 0.321136 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 36 - 0 - 0 - - - - 0.263349 0.270617 0.925967 0.000000 - 0.961822 0.000445 -0.273677 0.000000 - -0.074474 0.962687 -0.260168 0.000000 - - - - -10.960040 18.021080 0.939480 0.000000 - - - - - - 0.263349 0.270617 0.925967 0.000000 - 0.961822 0.000445 -0.273677 0.000000 - -0.074474 0.962687 -0.260168 0.000000 - - - - -10.960040 18.021080 0.939480 0.000000 - - - - 0.000421 -3.168117 0.001832 0.000000 - - - -0.000176 0.000334 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.486755 -0.008641 -0.007840 0.000000 - -0.008640 0.459969 0.002428 0.000000 - -0.007840 0.002428 0.461054 0.000000 - - - - 0.000421 -3.168117 0.001832 0.000000 - - - -0.000176 0.000334 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.457415 0.458851 0.491512 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 38 - 0 - 0 - - - - 0.266744 0.253792 0.929751 0.000000 - 0.960598 0.008160 -0.277821 0.000000 - -0.078096 0.967224 -0.241616 0.000000 - - - - -11.098556 16.231737 0.987424 0.000000 - - - - - - 0.266744 0.253792 0.929751 0.000000 - 0.960598 0.008160 -0.277821 0.000000 - -0.078096 0.967224 -0.241616 0.000000 - - - - -11.098556 16.231737 0.987424 0.000000 - - - - 0.000970 -3.168130 0.002216 0.000000 - - - -0.000185 0.000342 0.000276 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.585797 -0.030939 0.003375 0.000000 - -0.030939 0.482723 0.009088 0.000000 - 0.003375 0.009088 0.596704 0.000000 - - - - 0.000970 -3.168130 0.002216 0.000000 - - - -0.000185 0.000342 0.000276 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.473392 0.597666 0.594164 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 40 - 0 - 0 - - - - 0.269143 0.210785 0.939751 0.000000 - 0.962592 -0.027180 -0.269588 0.000000 - -0.031283 0.977154 -0.210215 0.000000 - - - - 0.026031 13.865726 -2.003178 0.000000 - - - - - - 0.269143 0.210785 0.939751 0.000000 - 0.962592 -0.027180 -0.269588 0.000000 - -0.031283 0.977154 -0.210215 0.000000 - - - - 0.026031 13.865726 -2.003178 0.000000 - - - - 0.000572 -3.165297 -0.001108 0.000000 - - - -0.000180 0.000344 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.603775 -0.031062 -0.006832 0.000000 - -0.031062 0.502313 0.004648 0.000000 - -0.006832 0.004648 0.577712 0.000000 - - - - 0.000572 -3.165297 -0.001108 0.000000 - - - -0.000180 0.000344 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.493477 0.576109 0.614214 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 42 - 0 - 0 - - - - 0.283737 0.215623 0.934345 0.000000 - 0.956772 0.001251 -0.290836 0.000000 - -0.063879 0.976476 -0.205947 0.000000 - - - - 0.178605 13.075008 -1.375758 0.000000 - - - - - - 0.283737 0.215623 0.934345 0.000000 - 0.956772 0.001251 -0.290836 0.000000 - -0.063879 0.976476 -0.205947 0.000000 - - - - 0.178605 13.075008 -1.375758 0.000000 - - - - 0.001017 -3.165117 -0.001027 0.000000 - - - -0.000176 0.000351 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 2.338381 -0.177631 -0.146997 0.000000 - -0.177631 1.827779 0.039024 0.000000 - -0.146997 0.039024 1.704065 0.000000 - - - - 0.001017 -3.165117 -0.001027 0.000000 - - - -0.000176 0.000351 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.772496 1.671656 2.426074 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 44 - 0 - 0 - - - - 0.259117 0.262494 0.929492 0.000000 - 0.959188 0.042868 -0.279501 0.000000 - -0.113213 0.963981 -0.240673 0.000000 - - - - 0.062176 11.969648 -1.848458 0.000000 - - - - - - 0.259117 0.262494 0.929492 0.000000 - 0.959188 0.042868 -0.279501 0.000000 - -0.113213 0.963981 -0.240673 0.000000 - - - - 0.062176 11.969648 -1.848458 0.000000 - - - - 0.001145 -3.165230 -0.000781 0.000000 - - - -0.000170 0.000345 0.000284 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.684872 -0.006403 -0.006127 0.000000 - -0.006403 0.665760 0.001546 0.000000 - -0.006127 0.001546 0.662925 0.000000 - - - - 0.001145 -3.165230 -0.000781 0.000000 - - - -0.000170 0.000345 0.000284 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.663848 0.661325 0.688384 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 46 - 0 - 0 - - - - 0.250381 0.269174 0.929976 0.000000 - 0.966033 -0.006013 -0.258349 0.000000 - -0.063949 0.963073 -0.261536 0.000000 - - - - -1.106317 12.913932 -1.058279 0.000000 - - - - - - 0.250381 0.269174 0.929976 0.000000 - 0.966033 -0.006013 -0.258349 0.000000 - -0.063949 0.963073 -0.261536 0.000000 - - - - -1.106317 12.913932 -1.058279 0.000000 - - - - 0.001200 -3.165425 -0.000550 0.000000 - - - -0.000177 0.000359 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 1.543157 0.090421 -0.089587 0.000000 - 0.090421 1.890073 -0.021093 0.000000 - -0.089587 -0.021093 1.245511 0.000000 - - - - 0.001200 -3.165425 -0.000550 0.000000 - - - -0.000177 0.000359 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.914905 1.220603 1.543232 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 48 - 0 - 0 - - - - 0.267856 0.275219 0.923313 0.000000 - 0.959776 0.007491 -0.280667 0.000000 - -0.084162 0.961352 -0.262142 0.000000 - - - - -1.124454 23.155754 -1.647149 0.000000 - - - - - - 0.267856 0.275219 0.923313 0.000000 - 0.959776 0.007491 -0.280667 0.000000 - -0.084162 0.961352 -0.262142 0.000000 - - - - -1.124454 23.155754 -1.647149 0.000000 - - - - -0.002031 -3.165764 -0.002409 0.000000 - - - -0.000171 0.000322 0.000302 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.357407 0.019838 -0.019681 0.000000 - 0.019838 0.428544 -0.006765 0.000000 - -0.019681 -0.006765 0.294889 0.000000 - - - - -0.002031 -3.165764 -0.002409 0.000000 - - - -0.000171 0.000322 0.000302 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.434674 0.289202 0.356964 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 50 - 0 - 0 - - - - 0.304517 0.278124 0.910998 0.000000 - 0.952197 -0.064487 -0.298601 0.000000 - -0.024301 0.958378 -0.284466 0.000000 - - - - -7.906496 15.780626 -1.263670 0.000000 - - - - - - 0.304517 0.278124 0.910998 0.000000 - 0.952197 -0.064487 -0.298601 0.000000 - -0.024301 0.958378 -0.284466 0.000000 - - - - -7.906496 15.780626 -1.263670 0.000000 - - - - 0.000297 -3.167574 0.001238 0.000000 - - - -0.000196 0.000328 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.649328 0.001596 0.025461 0.000000 - 0.001596 0.651618 -0.006188 0.000000 - 0.025461 -0.006188 0.728887 0.000000 - - - - 0.000297 -3.167574 0.001238 0.000000 - - - -0.000196 0.000328 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.652287 0.736692 0.640855 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 52 - 0 - 0 - - - - 0.263972 0.247827 0.932148 0.000000 - 0.960098 0.025030 -0.278542 0.000000 - -0.092362 0.968481 -0.231331 0.000000 - - - - -8.914278 23.222511 -0.677441 0.000000 - - - - - - 0.263972 0.247827 0.932148 0.000000 - 0.960098 0.025030 -0.278542 0.000000 - -0.092362 0.968481 -0.231331 0.000000 - - - - -8.914278 23.222511 -0.677441 0.000000 - - - - -0.001617 -3.167928 0.000177 0.000000 - - - -0.000181 0.000355 0.000284 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.177730 -0.004872 0.000719 0.000000 - -0.004872 0.161264 0.001732 0.000000 - 0.000719 0.001732 0.179820 0.000000 - - - - -0.001617 -3.167928 0.000177 0.000000 - - - -0.000181 0.000355 0.000284 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.159758 0.180048 0.179007 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 54 - 0 - 0 - - - - 0.260971 0.245743 0.933544 0.000000 - 0.963806 -0.011706 -0.266349 0.000000 - -0.054526 0.969264 -0.239903 0.000000 - - - - -9.322986 15.480569 1.086315 0.000000 - - - - - - 0.260971 0.245743 0.933544 0.000000 - 0.963806 -0.011706 -0.266349 0.000000 - -0.054526 0.969264 -0.239903 0.000000 - - - - -9.322986 15.480569 1.086315 0.000000 - - - - 0.001184 -3.167588 0.001755 0.000000 - - - -0.000179 0.000337 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.858383 0.031085 -0.077081 0.000000 - 0.031085 0.980720 -0.002714 0.000000 - -0.077081 -0.002714 0.572388 0.000000 - - - - 0.001184 -3.167588 0.001755 0.000000 - - - -0.000179 0.000337 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.989290 0.552878 0.869323 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 56 - 0 - 0 - - - - 0.230733 0.267495 0.935526 0.000000 - 0.970522 0.005541 -0.240949 0.000000 - -0.069637 0.963543 -0.258332 0.000000 - - - - -9.812456 19.797951 -1.139824 0.000000 - - - - - - 0.230733 0.267495 0.935526 0.000000 - 0.970522 0.005541 -0.240949 0.000000 - -0.069637 0.963543 -0.258332 0.000000 - - - - -9.812456 19.797951 -1.139824 0.000000 - - - - -0.000819 -3.168171 0.001123 0.000000 - - - -0.000177 0.000343 0.000289 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.424625 0.016657 -0.019142 0.000000 - 0.016657 0.496117 -0.005430 0.000000 - -0.019142 -0.005430 0.361365 0.000000 - - - - -0.000819 -3.168171 0.001123 0.000000 - - - -0.000177 0.000343 0.000289 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.500467 0.356020 0.425621 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 58 - 0 - 0 - - - - 0.265756 0.244547 0.932508 0.000000 - 0.962682 -0.015986 -0.270163 0.000000 - -0.051161 0.969505 -0.239670 0.000000 - - - - -2.932368 10.656281 -1.757161 0.000000 - - - - - - 0.265756 0.244547 0.932508 0.000000 - 0.962682 -0.015986 -0.270163 0.000000 - -0.051161 0.969505 -0.239670 0.000000 - - - - -2.932368 10.656281 -1.757161 0.000000 - - - - 0.001641 -3.166028 0.000483 0.000000 - - - -0.000164 0.000315 0.000319 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.591222 0.006645 -0.014575 0.000000 - 0.006645 0.616250 -0.000304 0.000000 - -0.014575 -0.000304 0.536678 0.000000 - - - - 0.001641 -3.166028 0.000483 0.000000 - - - -0.000164 0.000315 0.000319 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.618101 0.533007 0.593043 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 60 - 0 - 0 - - - - 0.271211 0.256094 0.927826 0.000000 - 0.959765 0.000928 -0.280803 0.000000 - -0.072773 0.966651 -0.245538 0.000000 - - - - -3.117821 13.220895 -2.660358 0.000000 - - - - - - 0.271211 0.256094 0.927826 0.000000 - 0.959765 0.000928 -0.280803 0.000000 - -0.072773 0.966651 -0.245538 0.000000 - - - - -3.117821 13.220895 -2.660358 0.000000 - - - - 0.000551 -3.166315 0.000111 0.000000 - - - -0.000163 0.000370 0.000299 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.570054 -0.007811 -0.024397 0.000000 - -0.007811 0.551317 0.001999 0.000000 - -0.024397 0.001999 0.484399 0.000000 - - - - 0.000551 -3.166315 0.000111 0.000000 - - - -0.000163 0.000370 0.000299 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.548958 0.477938 0.578874 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 62 - 0 - 0 - - - - 0.281732 0.243452 0.928094 0.000000 - 0.952933 0.041925 -0.300270 0.000000 - -0.112011 0.969006 -0.220182 0.000000 - - - - 0.631069 12.861382 -2.330191 0.000000 - - - - - - 0.281732 0.243452 0.928094 0.000000 - 0.952933 0.041925 -0.300270 0.000000 - -0.112011 0.969006 -0.220182 0.000000 - - - - 0.631069 12.861382 -2.330191 0.000000 - - - - 0.000720 -3.165162 -0.001135 0.000000 - - - -0.000171 0.000345 0.000287 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.741244 -0.047747 -0.045102 0.000000 - -0.047747 0.612900 0.009426 0.000000 - -0.045102 0.009426 0.564426 0.000000 - - - - 0.000720 -3.165162 -0.001135 0.000000 - - - -0.000171 0.000345 0.000287 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.597675 0.553502 0.767391 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 64 - 0 - 0 - - - - 0.267312 0.248245 0.931085 0.000000 - 0.959302 0.022712 -0.281468 0.000000 - -0.091020 0.968431 -0.232071 0.000000 - - - - 0.543064 13.186378 -3.114460 0.000000 - - - - - - 0.267312 0.248245 0.931085 0.000000 - 0.959302 0.022712 -0.281468 0.000000 - -0.091020 0.968431 -0.232071 0.000000 - - - - 0.543064 13.186378 -3.114460 0.000000 - - - - 0.000359 -3.165322 -0.001161 0.000000 - - - -0.000175 0.000346 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.954923 -0.055351 -0.110718 0.000000 - -0.055351 0.810104 0.007337 0.000000 - -0.110718 0.007337 0.546145 0.000000 - - - - 0.000359 -3.165322 -0.001161 0.000000 - - - -0.000175 0.000346 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.793984 0.517936 0.999252 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 66 - 0 - 0 - - - - 0.271468 0.255952 0.927790 0.000000 - 0.958176 0.018848 -0.285559 0.000000 - -0.090577 0.966506 -0.240130 0.000000 - - - - -0.965391 13.097441 -3.100339 0.000000 - - - - - - 0.271468 0.255952 0.927790 0.000000 - 0.958176 0.018848 -0.285559 0.000000 - -0.090577 0.966506 -0.240130 0.000000 - - - - -0.965391 13.097441 -3.100339 0.000000 - - - - 0.000405 -3.165745 -0.000620 0.000000 - - - -0.000176 0.000338 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.391987 0.029349 -0.014953 0.000000 - 0.029349 0.491234 -0.010767 0.000000 - -0.014953 -0.010767 0.341856 0.000000 - - - - 0.000405 -3.165745 -0.000620 0.000000 - - - -0.000176 0.000338 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.500567 0.337686 0.386824 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 68 - 0 - 0 - - - - 0.251400 0.233070 0.939402 0.000000 - 0.963943 0.027199 -0.264716 0.000000 - -0.087248 0.972079 -0.217829 0.000000 - - - - -9.529333 19.458237 0.711732 0.000000 - - - - - - 0.251400 0.233070 0.939402 0.000000 - 0.963943 0.027199 -0.264716 0.000000 - -0.087248 0.972079 -0.217829 0.000000 - - - - -9.529333 19.458237 0.711732 0.000000 - - - - -0.000064 -3.167744 0.001072 0.000000 - - - -0.000185 0.000349 0.000292 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.477585 -0.007613 -0.008849 0.000000 - -0.007613 0.453581 0.001439 0.000000 - -0.008849 0.001439 0.441871 0.000000 - - - - -0.000064 -3.167744 0.001072 0.000000 - - - -0.000185 0.000349 0.000292 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.451465 0.439789 0.481782 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 70 - 0 - 0 - - - - 0.280082 0.276048 0.919430 0.000000 - 0.954961 0.017658 -0.296207 0.000000 - -0.098002 0.960982 -0.258669 0.000000 - - - - -6.334208 11.489948 -1.055669 0.000000 - - - - - - 0.280082 0.276048 0.919430 0.000000 - 0.954961 0.017658 -0.296207 0.000000 - -0.098002 0.960982 -0.258669 0.000000 - - - - -6.334208 11.489948 -1.055669 0.000000 - - - - 0.001657 -3.166995 0.001468 0.000000 - - - -0.000181 0.000326 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.318873 0.005114 0.009139 0.000000 - 0.005114 0.331497 -0.001110 0.000000 - 0.009139 -0.001110 0.348409 0.000000 - - - - 0.001657 -3.166995 0.001468 0.000000 - - - -0.000181 0.000326 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.333111 0.351013 0.314654 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 72 - 0 - 0 - - - - 0.266364 0.282788 0.921456 0.000000 - 0.960521 0.001775 -0.278201 0.000000 - -0.080307 0.959181 -0.271151 0.000000 - - - - -6.095496 12.996134 -1.462297 0.000000 - - - - - - 0.266364 0.282788 0.921456 0.000000 - 0.960521 0.001775 -0.278201 0.000000 - -0.080307 0.959181 -0.271151 0.000000 - - - - -6.095496 12.996134 -1.462297 0.000000 - - - - 0.001075 -3.167000 0.001139 0.000000 - - - -0.000152 0.000297 0.000313 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.555805 -0.039464 -0.001863 0.000000 - -0.039464 0.425993 0.011863 0.000000 - -0.001863 0.011863 0.549767 0.000000 - - - - 0.001075 -3.167000 0.001139 0.000000 - - - -0.000152 0.000297 0.000313 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.414057 0.549239 0.568268 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 74 - 0 - 0 - - - - 0.263759 0.273029 0.925141 0.000000 - 0.960030 0.018832 -0.279263 0.000000 - -0.093669 0.961822 -0.257149 0.000000 - - - - 0.555015 22.981026 -2.500042 0.000000 - - - - - - 0.263759 0.273029 0.925141 0.000000 - 0.960030 0.018832 -0.279263 0.000000 - -0.093669 0.961822 -0.257149 0.000000 - - - - 0.555015 22.981026 -2.500042 0.000000 - - - - -0.002286 -3.165403 -0.002924 0.000000 - - - -0.000175 0.000328 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.367031 -0.000089 -0.019040 0.000000 - -0.000089 0.373354 -0.001412 0.000000 - -0.019040 -0.001412 0.305384 0.000000 - - - - -0.002286 -3.165403 -0.002924 0.000000 - - - -0.000175 0.000328 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.373467 0.299951 0.372350 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 76 - 0 - 0 - - - - 0.266485 0.263046 0.927250 0.000000 - 0.960338 0.009457 -0.278677 0.000000 - -0.082074 0.964737 -0.250093 0.000000 - - - - 2.009061 15.789817 -3.737069 0.000000 - - - - - - 0.266485 0.263046 0.927250 0.000000 - 0.960338 0.009457 -0.278677 0.000000 - -0.082074 0.964737 -0.250093 0.000000 - - - - 2.009061 15.789817 -3.737069 0.000000 - - - - -0.000597 -3.165054 -0.002139 0.000000 - - - -0.000180 0.000334 0.000282 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.230768 0.000958 0.005683 0.000000 - 0.000958 0.232198 -0.000071 0.000000 - 0.005683 -0.000071 0.250097 0.000000 - - - - -0.000597 -3.165054 -0.002139 0.000000 - - - -0.000180 0.000334 0.000282 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.232470 0.251646 0.228947 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 78 - 0 - 0 - - - - 0.278133 0.300327 0.912385 0.000000 - 0.953948 0.024746 -0.298949 0.000000 - -0.112360 0.953515 -0.279614 0.000000 - - - - -1.537477 11.377494 -2.709434 0.000000 - - - - - - 0.278133 0.300327 0.912385 0.000000 - 0.953948 0.024746 -0.298949 0.000000 - -0.112360 0.953515 -0.279614 0.000000 - - - - -1.537477 11.377494 -2.709434 0.000000 - - - - 0.001066 -3.165801 -0.000131 0.000000 - - - -0.000177 0.000406 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.587764 -0.026011 -0.019809 0.000000 - -0.026011 0.515125 0.008390 0.000000 - -0.019809 0.008390 0.528749 0.000000 - - - - 0.001066 -3.165801 -0.000131 0.000000 - - - -0.000177 0.000406 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.506553 0.522728 0.602357 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 80 - 0 - 0 - - - - 0.288211 0.211865 0.933835 0.000000 - 0.955584 -0.000916 -0.294716 0.000000 - -0.061585 0.977298 -0.202719 0.000000 - - - - -11.153685 15.238323 -0.176678 0.000000 - - - - - - 0.288211 0.211865 0.933835 0.000000 - 0.955584 -0.000916 -0.294716 0.000000 - -0.061585 0.977298 -0.202719 0.000000 - - - - -11.153685 15.238323 -0.176678 0.000000 - - - - 0.000851 -3.168326 0.002377 0.000000 - - - -0.000190 0.000330 0.000314 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.718333 0.064361 0.033177 0.000000 - 0.064361 0.904328 -0.013921 0.000000 - 0.033177 -0.013921 0.863890 0.000000 - - - - 0.000851 -3.168326 0.002377 0.000000 - - - -0.000190 0.000330 0.000314 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.924637 0.871096 0.690819 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 82 - 0 - 0 - - - - 0.255828 0.249914 0.933860 0.000000 - 0.962706 0.022106 -0.269646 0.000000 - -0.088033 0.968016 -0.234938 0.000000 - - - - 2.395922 17.278748 -2.422043 0.000000 - - - - - - 0.255828 0.249914 0.933860 0.000000 - 0.962706 0.022106 -0.269646 0.000000 - -0.088033 0.968016 -0.234938 0.000000 - - - - 2.395922 17.278748 -2.422043 0.000000 - - - - -0.000575 -3.164746 -0.002537 0.000000 - - - -0.000173 0.000338 0.000284 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.401404 -0.006928 -0.030805 0.000000 - -0.006928 0.387717 -0.000638 0.000000 - -0.030805 -0.000638 0.289440 0.000000 - - - - -0.000575 -3.164746 -0.002537 0.000000 - - - -0.000173 0.000338 0.000284 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.385935 0.281473 0.411154 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 84 - 0 - 0 - - - - 0.286062 0.271376 0.918980 0.000000 - 0.954436 0.004349 -0.298383 0.000000 - -0.084971 0.962464 -0.257767 0.000000 - - - - -8.576577 15.730978 0.142786 0.000000 - - - - - - 0.286062 0.271376 0.918980 0.000000 - 0.954436 0.004349 -0.298383 0.000000 - -0.084971 0.962464 -0.257767 0.000000 - - - - -8.576577 15.730978 0.142786 0.000000 - - - - 0.000782 -3.167524 0.001452 0.000000 - - - -0.000186 0.000328 0.000303 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.918569 0.013301 -0.029362 0.000000 - 0.013301 0.967286 -0.004440 0.000000 - -0.029362 -0.004440 0.822946 0.000000 - - - - 0.000782 -3.167524 0.001452 0.000000 - - - -0.000186 0.000328 0.000303 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.971668 0.814647 0.922486 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 86 - 0 - 0 - - - - 0.293470 0.270392 0.916932 0.000000 - 0.953699 -0.016758 -0.300296 0.000000 - -0.065832 0.962605 -0.262790 0.000000 - - - - -3.529477 12.837772 -1.574597 0.000000 - - - - - - 0.293470 0.270392 0.916932 0.000000 - 0.953699 -0.016758 -0.300296 0.000000 - -0.065832 0.962605 -0.262790 0.000000 - - - - -3.529477 12.837772 -1.574597 0.000000 - - - - 0.001049 -3.166231 0.000334 0.000000 - - - -0.000192 0.000335 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.633052 -0.034856 0.018469 0.000000 - -0.034856 0.526830 0.006759 0.000000 - 0.018469 0.006759 0.695892 0.000000 - - - - 0.001049 -3.166231 0.000334 0.000000 - - - -0.000192 0.000335 0.000291 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.515637 0.700962 0.639175 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 88 - 0 - 0 - - - - 0.279608 0.266419 0.922410 0.000000 - 0.948137 0.074659 -0.308970 0.000000 - -0.151182 0.960962 -0.231726 0.000000 - - - - -0.734770 11.378308 -1.685973 0.000000 - - - - - - 0.279608 0.266419 0.922410 0.000000 - 0.948137 0.074659 -0.308970 0.000000 - -0.151182 0.960962 -0.231726 0.000000 - - - - -0.734770 11.378308 -1.685973 0.000000 - - - - 0.001410 -3.165412 -0.000409 0.000000 - - - -0.000168 0.000348 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.908387 -0.055531 -0.027766 0.000000 - -0.055531 0.754402 0.018369 0.000000 - -0.027766 0.018369 0.798944 0.000000 - - - - 0.001410 -3.165412 -0.000409 0.000000 - - - -0.000168 0.000348 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.735096 0.792673 0.933963 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 90 - 0 - 0 - - - - 0.273991 0.286075 0.918199 0.000000 - 0.956963 0.013872 -0.289880 0.000000 - -0.095665 0.958107 -0.269962 0.000000 - - - - -10.326201 16.496368 -0.103978 0.000000 - - - - - - 0.273991 0.286075 0.918199 0.000000 - 0.956963 0.013872 -0.289880 0.000000 - -0.095665 0.958107 -0.269962 0.000000 - - - - -10.326201 16.496368 -0.103978 0.000000 - - - - 0.000523 -3.168090 0.001913 0.000000 - - - -0.000193 0.000329 0.000292 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.681288 -0.003437 0.017528 0.000000 - -0.003437 0.664360 0.002119 0.000000 - 0.017528 0.002119 0.734561 0.000000 - - - - 0.000523 -3.168090 0.001913 0.000000 - - - -0.000193 0.000329 0.000292 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.663164 0.739825 0.677219 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 92 - 0 - 0 - - - - 0.253137 0.305463 0.917940 0.000000 - 0.956732 0.061679 -0.284359 0.000000 - -0.143479 0.950204 -0.276633 0.000000 - - - - -8.583277 13.501283 -1.313118 0.000000 - - - - - - 0.253137 0.305463 0.917940 0.000000 - 0.956732 0.061679 -0.284359 0.000000 - -0.143479 0.950204 -0.276633 0.000000 - - - - -8.583277 13.501283 -1.313118 0.000000 - - - - 0.000982 -3.167748 0.001865 0.000000 - - - -0.000172 0.000330 0.000312 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.594244 0.000140 -0.046838 0.000000 - 0.000140 0.619611 -0.011147 0.000000 - -0.046838 -0.011147 0.464354 0.000000 - - - - 0.000982 -3.167748 0.001865 0.000000 - - - -0.000172 0.000330 0.000312 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.621320 0.448574 0.608316 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 94 - 0 - 0 - - - - 0.261394 0.195782 0.945168 0.000000 - 0.963575 0.004427 -0.267401 0.000000 - -0.056536 0.980637 -0.187493 0.000000 - - - - -10.865542 14.610499 -0.832829 0.000000 - - - - - - 0.261394 0.195782 0.945168 0.000000 - 0.963575 0.004427 -0.267401 0.000000 - -0.056536 0.980637 -0.187493 0.000000 - - - - -10.865542 14.610499 -0.832829 0.000000 - - - - 0.000814 -3.168353 0.002402 0.000000 - - - -0.000190 0.000321 0.000281 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.537418 0.001708 -0.028606 0.000000 - 0.001708 0.549376 -0.001042 0.000000 - -0.028606 -0.001042 0.399892 0.000000 - - - - 0.000814 -3.168353 0.002402 0.000000 - - - -0.000190 0.000321 0.000281 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.549900 0.394176 0.542610 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 96 - 0 - 0 - - - - 0.262078 0.251424 0.931720 0.000000 - 0.961679 0.012545 -0.273890 0.000000 - -0.080551 0.967796 -0.238501 0.000000 - - - - -5.880309 22.535719 -1.172234 0.000000 - - - - - - 0.262078 0.251424 0.931720 0.000000 - 0.961679 0.012545 -0.273890 0.000000 - -0.080551 0.967796 -0.238501 0.000000 - - - - -5.880309 22.535719 -1.172234 0.000000 - - - - -0.001632 -3.167109 -0.000744 0.000000 - - - -0.000175 0.000332 0.000290 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.539629 -0.010172 -0.007735 0.000000 - -0.010172 0.507677 0.002664 0.000000 - -0.007735 0.002664 0.511324 0.000000 - - - - -0.001632 -3.167109 -0.000744 0.000000 - - - -0.000175 0.000332 0.000290 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.504682 0.509349 0.544599 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 98 - 0 - 0 - - - - 0.253657 0.276427 0.926955 0.000000 - 0.962288 0.025257 -0.270857 0.000000 - -0.098284 0.960703 -0.259596 0.000000 - - - - -0.765661 23.249353 -3.015953 0.000000 - - - - - - 0.253657 0.276427 0.926955 0.000000 - 0.962288 0.025257 -0.270857 0.000000 - -0.098284 0.960703 -0.259596 0.000000 - - - - -0.765661 23.249353 -3.015953 0.000000 - - - - -0.002528 -3.165864 -0.002533 0.000000 - - - -0.000165 0.000329 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.317900 0.025521 0.017053 0.000000 - 0.025521 0.400578 -0.007897 0.000000 - 0.017053 -0.007897 0.374801 0.000000 - - - - -0.002528 -3.165864 -0.002533 0.000000 - - - -0.000165 0.000329 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.408112 0.379500 0.305667 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 100 - 0 - 0 - - - - 0.275954 0.273218 0.921521 0.000000 - 0.952351 0.051862 -0.300563 0.000000 - -0.129911 0.960553 -0.245888 0.000000 - - - - -6.764637 23.863518 -1.478289 0.000000 - - - - - - 0.275954 0.273218 0.921521 0.000000 - 0.952351 0.051862 -0.300563 0.000000 - -0.129911 0.960553 -0.245888 0.000000 - - - - -6.764637 23.863518 -1.478289 0.000000 - - - - -0.002145 -3.167443 -0.000690 0.000000 - - - -0.000188 0.000352 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.275604 -0.009430 -0.017239 0.000000 - -0.009430 0.253972 0.000481 0.000000 - -0.017239 0.000481 0.218083 0.000000 - - - - -0.002145 -3.167443 -0.000690 0.000000 - - - -0.000188 0.000352 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.251174 0.213206 0.283279 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 102 - 0 - 0 - - - - 0.307184 0.279937 0.909546 0.000000 - 0.949373 -0.024065 -0.313228 0.000000 - -0.065796 0.959717 -0.273157 0.000000 - - - - -2.548520 24.746481 -2.059655 0.000000 - - - - - - 0.307184 0.279937 0.909546 0.000000 - 0.949373 -0.024065 -0.313228 0.000000 - -0.065796 0.959717 -0.273157 0.000000 - - - - -2.548520 24.746481 -2.059655 0.000000 - - - - -0.002639 -3.166269 -0.002207 0.000000 - - - -0.000177 0.000315 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.336702 -0.017753 -0.008861 0.000000 - -0.017753 0.289803 0.004726 0.000000 - -0.008861 0.004726 0.310554 0.000000 - - - - -0.002639 -3.166269 -0.002207 0.000000 - - - -0.000177 0.000315 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.283731 0.307851 0.345477 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 104 - 0 - 0 - - - - 0.270584 0.262477 0.926224 0.000000 - 0.954163 0.054695 -0.294246 0.000000 - -0.127893 0.963387 -0.235646 0.000000 - - - - -10.263887 15.183156 1.194660 0.000000 - - - - - - 0.270584 0.262477 0.926224 0.000000 - 0.954163 0.054695 -0.294246 0.000000 - -0.127893 0.963387 -0.235646 0.000000 - - - - -10.263887 15.183156 1.194660 0.000000 - - - - 0.001319 -3.167841 0.002134 0.000000 - - - -0.000192 0.000351 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 1.005904 0.086390 -0.082662 0.000000 - 0.086390 1.317417 -0.057426 0.000000 - -0.082662 -0.057426 0.746288 0.000000 - - - - 0.001319 -3.167841 0.002134 0.000000 - - - -0.000192 0.000351 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 1.349612 0.720506 0.999490 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 106 - 0 - 0 - - - - 0.273492 0.245503 0.930016 0.000000 - 0.959489 -0.001580 -0.281742 0.000000 - -0.067699 0.969394 -0.235990 0.000000 - - - - -10.835474 19.140160 0.045569 0.000000 - - - - - - 0.273492 0.245503 0.930016 0.000000 - 0.959489 -0.001580 -0.281742 0.000000 - -0.067699 0.969394 -0.235990 0.000000 - - - - -10.835474 19.140160 0.045569 0.000000 - - - - -0.000200 -3.168237 0.001590 0.000000 - - - -0.000182 0.000350 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.428329 -0.030176 0.006413 0.000000 - -0.030176 0.330002 0.007440 0.000000 - 0.006413 0.007440 0.452232 0.000000 - - - - -0.000200 -3.168237 0.001590 0.000000 - - - -0.000182 0.000350 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.320876 0.453844 0.435843 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 108 - 0 - 0 - - - - 0.276657 0.248175 0.928370 0.000000 - 0.956198 0.025056 -0.291647 0.000000 - -0.095641 0.968391 -0.230372 0.000000 - - - - 2.141578 17.485554 -3.835118 0.000000 - - - - - - 0.276657 0.248175 0.928370 0.000000 - 0.956198 0.025056 -0.291647 0.000000 - -0.095641 0.968391 -0.230372 0.000000 - - - - 2.141578 17.485554 -3.835118 0.000000 - - - - -0.001111 -3.165064 -0.002480 0.000000 - - - -0.000171 0.000339 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.328809 0.003394 -0.001809 0.000000 - 0.003394 0.340048 -0.001334 0.000000 - -0.001809 -0.001334 0.322590 0.000000 - - - - -0.001111 -3.165064 -0.002480 0.000000 - - - -0.000171 0.000339 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.341163 0.322092 0.328191 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 110 - 0 - 0 - - - - 0.277013 0.279371 0.919356 0.000000 - 0.955605 0.019887 -0.293979 0.000000 - -0.100412 0.959977 -0.261459 0.000000 - - - - 0.366417 13.577110 -3.965630 0.000000 - - - - - - 0.277013 0.279371 0.919356 0.000000 - 0.955605 0.019887 -0.293979 0.000000 - -0.100412 0.959977 -0.261459 0.000000 - - - - 0.366417 13.577110 -3.965630 0.000000 - - - - -0.000046 -3.165520 -0.001177 0.000000 - - - -0.000178 0.000332 0.000272 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.725660 -0.047109 -0.067738 0.000000 - -0.047109 0.602552 0.011369 0.000000 - -0.067738 0.011369 0.509023 0.000000 - - - - -0.000046 -3.165520 -0.001177 0.000000 - - - -0.000178 0.000332 0.000272 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.587701 0.489545 0.759988 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 112 - 0 - 0 - - - - 0.266045 0.254641 0.929719 0.000000 - 0.960020 0.017125 -0.279406 0.000000 - -0.087070 0.966884 -0.239905 0.000000 - - - - 0.419757 16.287697 -2.909253 0.000000 - - - - - - 0.266045 0.254641 0.929719 0.000000 - 0.960020 0.017125 -0.279406 0.000000 - -0.087070 0.966884 -0.239905 0.000000 - - - - 0.419757 16.287697 -2.909253 0.000000 - - - - -0.000435 -3.165362 -0.001679 0.000000 - - - -0.000182 0.000342 0.000276 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.367256 0.034700 0.025560 0.000000 - 0.034700 0.473648 -0.009263 0.000000 - 0.025560 -0.009263 0.460074 0.000000 - - - - -0.000435 -3.165362 -0.001679 0.000000 - - - -0.000182 0.000342 0.000276 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.484105 0.466641 0.350232 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 114 - 0 - 0 - - - - 0.283997 0.280445 0.916895 0.000000 - 0.954494 0.008096 -0.298119 0.000000 - -0.091029 0.959836 -0.265384 0.000000 - - - - -5.006969 24.920004 -1.445974 0.000000 - - - - - - 0.283997 0.280445 0.916895 0.000000 - 0.954494 0.008096 -0.298119 0.000000 - -0.091029 0.959836 -0.265384 0.000000 - - - - -5.006969 24.920004 -1.445974 0.000000 - - - - -0.002488 -3.166935 -0.001467 0.000000 - - - -0.000173 0.000360 0.000279 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.291709 0.005933 0.020432 0.000000 - 0.005933 0.303217 -0.001239 0.000000 - 0.020432 -0.001239 0.355850 0.000000 - - - - -0.002488 -3.166935 -0.001467 0.000000 - - - -0.000173 0.000360 0.000279 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.305101 0.361810 0.283866 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 116 - 0 - 0 - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - -4.086954 -6.994352 1.661670 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 1 - -1 - -2 - 2 - 2 - 0 - - - - 0.000000 0.000000 0.000000 0.000000 - 0.000000 0.000000 0.000000 0.000000 - 0.000000 0.000000 0.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 118 - 0 - 0 - - - - 0.282709 0.266868 0.921334 0.000000 - 0.956434 -0.005457 -0.291899 0.000000 - -0.072871 0.963718 -0.256784 0.000000 - - - - -6.690329 22.841635 -0.064674 0.000000 - - - - - - 0.282709 0.266868 0.921334 0.000000 - 0.956434 -0.005457 -0.291899 0.000000 - -0.072871 0.963718 -0.256784 0.000000 - - - - -6.690329 22.841635 -0.064674 0.000000 - - - - -0.001309 -3.167142 -0.000531 0.000000 - - - -0.000175 0.000343 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.363364 0.005830 -0.011844 0.000000 - 0.005830 0.384322 -0.001253 0.000000 - -0.011844 -0.001253 0.323746 0.000000 - - - - -0.001309 -3.167142 -0.000531 0.000000 - - - -0.000175 0.000343 0.000294 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.386140 0.320474 0.364818 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 120 - 0 - 0 - - - - 0.269730 0.272314 0.923629 0.000000 - 0.958694 0.013996 -0.284097 0.000000 - -0.090291 0.962107 -0.257291 0.000000 - - - - -2.238892 10.446442 -1.914610 0.000000 - - - - - - 0.269730 0.272314 0.923629 0.000000 - 0.958694 0.013996 -0.284097 0.000000 - -0.090291 0.962107 -0.257291 0.000000 - - - - -2.238892 10.446442 -1.914610 0.000000 - - - - 0.001609 -3.165849 0.000284 0.000000 - - - -0.000182 0.000330 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.685166 -0.028362 -0.004088 0.000000 - -0.028362 0.594566 0.009114 0.000000 - -0.004088 0.009114 0.670291 0.000000 - - - - 0.001609 -3.165849 0.000284 0.000000 - - - -0.000182 0.000330 0.000301 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.585728 0.669266 0.695029 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 122 - 0 - 0 - - - - 0.266424 0.246170 0.931890 0.000000 - 0.959362 0.025527 -0.281021 0.000000 - -0.092967 0.968890 -0.229366 0.000000 - - - - -9.230621 16.392509 -0.261454 0.000000 - - - - - - 0.266424 0.246170 0.931890 0.000000 - 0.959362 0.025527 -0.281021 0.000000 - -0.092967 0.968890 -0.229366 0.000000 - - - - -9.230621 16.392509 -0.261454 0.000000 - - - - 0.000451 -3.167827 0.001564 0.000000 - - - -0.000184 0.000284 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.638536 0.026139 0.057842 0.000000 - 0.026139 0.704992 -0.002323 0.000000 - 0.057842 -0.002323 0.854270 0.000000 - - - - 0.000451 -3.167827 0.001564 0.000000 - - - -0.000184 0.000284 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.712477 0.868905 0.616416 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 124 - 0 - 0 - - - - 0.280871 0.270439 0.920855 0.000000 - 0.957483 -0.013109 -0.288193 0.000000 - -0.065867 0.962648 -0.262622 0.000000 - - - - -4.216679 11.550082 -2.446970 0.000000 - - - - - - 0.280871 0.270439 0.920855 0.000000 - 0.957483 -0.013109 -0.288193 0.000000 - -0.065867 0.962648 -0.262622 0.000000 - - - - -4.216679 11.550082 -2.446970 0.000000 - - - - 0.001164 -3.166569 0.000757 0.000000 - - - -0.000173 0.000330 0.000290 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.687466 -0.014084 -0.050529 0.000000 - -0.014084 0.655845 0.005966 0.000000 - -0.050529 0.005966 0.522564 0.000000 - - - - 0.001164 -3.166569 0.000757 0.000000 - - - -0.000173 0.000330 0.000290 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.651303 0.508288 0.706284 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 126 - 0 - 0 - - - - 0.261877 0.272530 0.925823 0.000000 - 0.960583 0.019108 -0.277334 0.000000 - -0.093273 0.961958 -0.256784 0.000000 - - - - 1.679321 22.410299 -3.022897 0.000000 - - - - - - 0.261877 0.272530 0.925823 0.000000 - 0.960583 0.019108 -0.277334 0.000000 - -0.093273 0.961958 -0.256784 0.000000 - - - - 1.679321 22.410299 -3.022897 0.000000 - - - - -0.002298 -3.165136 -0.003193 0.000000 - - - -0.000173 0.000330 0.000298 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.463526 0.009845 -0.015818 0.000000 - 0.009845 0.502138 -0.004652 0.000000 - -0.015818 -0.004652 0.412956 0.000000 - - - - -0.002298 -3.165136 -0.003193 0.000000 - - - -0.000173 0.000330 0.000298 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.505274 0.408383 0.464964 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 128 - 0 - 0 - - - - 0.273401 0.252818 0.928081 0.000000 - 0.958752 0.006378 -0.284174 0.000000 - -0.077763 0.967493 -0.240646 0.000000 - - - - 0.670923 21.478176 -2.130810 0.000000 - - - - - - 0.273401 0.252818 0.928081 0.000000 - 0.958752 0.006378 -0.284174 0.000000 - -0.077763 0.967493 -0.240646 0.000000 - - - - 0.670923 21.478176 -2.130810 0.000000 - - - - -0.001698 -3.165273 -0.002678 0.000000 - - - -0.000166 0.000319 0.000302 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.350099 -0.005389 -0.010238 0.000000 - -0.005389 0.335750 0.001244 0.000000 - -0.010238 0.001244 0.313451 0.000000 - - - - -0.001698 -3.165273 -0.002678 0.000000 - - - -0.000166 0.000319 0.000302 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.334113 0.310784 0.354403 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 130 - 0 - 0 - - - - 0.254240 0.276170 0.926872 0.000000 - 0.962169 0.024828 -0.271320 0.000000 - -0.097943 0.960788 -0.259410 0.000000 - - - - 0.817258 20.765602 -2.848148 0.000000 - - - - - - 0.254240 0.276170 0.926872 0.000000 - 0.962169 0.024828 -0.271320 0.000000 - -0.097943 0.960788 -0.259410 0.000000 - - - - 0.817258 20.765602 -2.848148 0.000000 - - - - -0.001720 -3.165330 -0.002601 0.000000 - - - -0.000159 0.000323 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.332454 -0.014740 0.005360 0.000000 - -0.014740 0.279118 0.006063 0.000000 - 0.005360 0.006063 0.348079 0.000000 - - - - -0.001720 -3.165330 -0.002601 0.000000 - - - -0.000159 0.000323 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.274606 0.349776 0.335268 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 132 - 0 - 0 - - - - 0.291108 0.281970 0.914193 0.000000 - 0.952135 0.007754 -0.305581 0.000000 - -0.093253 0.959392 -0.266216 0.000000 - - - - -6.037422 24.456434 -0.454460 0.000000 - - - - - - 0.291108 0.281970 0.914193 0.000000 - 0.952135 0.007754 -0.305581 0.000000 - -0.093253 0.959392 -0.266216 0.000000 - - - - -6.037422 24.456434 -0.454460 0.000000 - - - - -0.001985 -3.167069 -0.001045 0.000000 - - - -0.000140 0.000332 0.000282 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.461956 -0.026666 -0.025547 0.000000 - -0.026666 0.391830 0.007695 0.000000 - -0.025547 0.007695 0.381746 0.000000 - - - - -0.001985 -3.167069 -0.001045 0.000000 - - - -0.000140 0.000332 0.000282 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.382924 0.374300 0.478309 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 134 - 0 - 0 - - - - 0.282443 0.276804 0.918480 0.000000 - 0.955446 0.004391 -0.295134 0.000000 - -0.085727 0.960916 -0.263231 0.000000 - - - - 0.750912 14.822566 -2.498849 0.000000 - - - - - - 0.282443 0.276804 0.918480 0.000000 - 0.955446 0.004391 -0.295134 0.000000 - -0.085727 0.960916 -0.263231 0.000000 - - - - 0.750912 14.822566 -2.498849 0.000000 - - - - 0.000112 -3.165181 -0.001530 0.000000 - - - -0.000175 0.000346 0.000279 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.314363 0.005554 -0.004282 0.000000 - 0.005554 0.332651 -0.001751 0.000000 - -0.004282 -0.001751 0.300829 0.000000 - - - - 0.000112 -3.165181 -0.001530 0.000000 - - - -0.000175 0.000346 0.000279 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.334450 0.299587 0.313805 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 136 - 0 - 0 - - - - 0.251660 0.268205 0.929911 0.000000 - 0.964375 0.011455 -0.264291 0.000000 - -0.081536 0.963294 -0.255767 0.000000 - - - - 2.279323 20.056404 -3.510723 0.000000 - - - - - - 0.251660 0.268205 0.929911 0.000000 - 0.964375 0.011455 -0.264291 0.000000 - -0.081536 0.963294 -0.255767 0.000000 - - - - 2.279323 20.056404 -3.510723 0.000000 - - - - -0.001768 -3.164999 -0.002980 0.000000 - - - -0.000168 0.000332 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.302863 0.000459 -0.008528 0.000000 - 0.000459 0.307219 -0.000544 0.000000 - -0.008528 -0.000544 0.274635 0.000000 - - - - -0.001768 -3.164999 -0.002980 0.000000 - - - -0.000168 0.000332 0.000300 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.307385 0.272254 0.305078 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 138 - 0 - 0 - - - - 0.242261 0.206779 0.947920 0.000000 - 0.965595 0.043814 -0.256335 0.000000 - -0.094537 0.977406 -0.189050 0.000000 - - - - -0.215132 14.671159 -1.805316 0.000000 - - - - - - 0.242261 0.206779 0.947920 0.000000 - 0.965595 0.043814 -0.256335 0.000000 - -0.094537 0.977406 -0.189050 0.000000 - - - - -0.215132 14.671159 -1.805316 0.000000 - - - - 0.000416 -3.165317 -0.001170 0.000000 - - - -0.000177 0.000348 0.000285 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.577963 0.026100 -0.006581 0.000000 - 0.026100 0.676926 -0.011105 0.000000 - -0.006581 -0.011105 0.554275 0.000000 - - - - 0.000416 -3.165317 -0.001170 0.000000 - - - -0.000177 0.000348 0.000285 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.684562 0.552385 0.572218 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 140 - 0 - 0 - - - - 0.304548 0.275685 0.911728 0.000000 - 0.951993 -0.119219 -0.281949 0.000000 - 0.030967 0.953826 -0.298758 0.000000 - - - - -3.571203 10.602681 -3.091400 0.000000 - - - - - - 0.304548 0.275685 0.911728 0.000000 - 0.951993 -0.119219 -0.281949 0.000000 - 0.030967 0.953826 -0.298758 0.000000 - - - - -3.571203 10.602681 -3.091400 0.000000 - - - - 0.001238 -3.166449 0.000694 0.000000 - - - -0.000162 0.000318 0.000318 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.692087 -0.012773 -0.075099 0.000000 - -0.012773 0.647636 0.029922 0.000000 - -0.075099 0.029922 0.463226 0.000000 - - - - 0.001238 -3.166449 0.000694 0.000000 - - - -0.000162 0.000318 0.000318 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.644523 0.437780 0.720645 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 142 - 0 - 0 - - - - 0.287046 0.259887 0.921989 0.000000 - 0.953841 0.011150 -0.300105 0.000000 - -0.088273 0.965575 -0.244690 0.000000 - - - - -2.225920 12.455692 -3.315838 0.000000 - - - - - - 0.287046 0.259887 0.921989 0.000000 - 0.953841 0.011150 -0.300105 0.000000 - -0.088273 0.965575 -0.244690 0.000000 - - - - -2.225920 12.455692 -3.315838 0.000000 - - - - 0.000524 -3.166133 -0.000055 0.000000 - - - -0.000191 0.000405 0.000272 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.923296 0.006944 -0.088225 0.000000 - 0.006944 0.970838 -0.006200 0.000000 - -0.088225 -0.006200 0.619623 0.000000 - - - - 0.000524 -3.166133 -0.000055 0.000000 - - - -0.000191 0.000405 0.000272 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.973501 0.595806 0.944450 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 144 - 0 - 0 - - - - 0.268226 0.224188 0.936907 0.000000 - 0.960055 0.018231 -0.279216 0.000000 - -0.079678 0.974375 -0.210343 0.000000 - - - - -9.112514 17.757938 0.199737 0.000000 - - - - - - 0.268226 0.224188 0.936907 0.000000 - 0.960055 0.018231 -0.279216 0.000000 - -0.079678 0.974375 -0.210343 0.000000 - - - - -9.112514 17.757938 0.199737 0.000000 - - - - 0.000255 -3.167715 0.001250 0.000000 - - - -0.000188 0.000352 0.000287 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.374337 0.023469 0.015617 0.000000 - 0.023469 0.446691 -0.005448 0.000000 - 0.015617 -0.005448 0.440627 0.000000 - - - - 0.000255 -3.167715 0.001250 0.000000 - - - -0.000188 0.000352 0.000287 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.453700 0.444118 0.363836 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 146 - 0 - 0 - - - - 0.272262 0.275121 0.922053 0.000000 - 0.958384 0.007979 -0.285370 0.000000 - -0.085868 0.961377 -0.261499 0.000000 - - - - -8.206606 11.824456 -0.271219 0.000000 - - - - - - 0.272262 0.275121 0.922053 0.000000 - 0.958384 0.007979 -0.285370 0.000000 - -0.085868 0.961377 -0.261499 0.000000 - - - - -8.206606 11.824456 -0.271219 0.000000 - - - - 0.001826 -3.167458 0.002030 0.000000 - - - -0.000174 0.000334 0.000304 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.358441 -0.029307 0.005791 0.000000 - -0.029307 0.262614 0.009343 0.000000 - 0.005791 0.009343 0.376092 0.000000 - - - - 0.001826 -3.167458 0.002030 0.000000 - - - -0.000174 0.000334 0.000304 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.253451 0.377827 0.365870 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 148 - 0 - 0 - - - - 0.266603 0.261177 0.927744 0.000000 - 0.958254 0.031346 -0.284195 0.000000 - -0.103306 0.964782 -0.241918 0.000000 - - - - -8.307735 22.773829 0.525339 0.000000 - - - - - - 0.266603 0.261177 0.927744 0.000000 - 0.958254 0.031346 -0.284195 0.000000 - -0.103306 0.964782 -0.241918 0.000000 - - - - -8.307735 22.773829 0.525339 0.000000 - - - - -0.001083 -3.167543 0.000048 0.000000 - - - -0.000168 0.000346 0.000316 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.580518 0.020111 -0.046532 0.000000 - 0.020111 0.663768 -0.013655 0.000000 - -0.046532 -0.013655 0.424085 0.000000 - - - - -0.001083 -3.167543 0.000048 0.000000 - - - -0.000168 0.000346 0.000316 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.670836 0.411045 0.586491 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 150 - 0 - 0 - - - - 0.241777 0.253009 0.936766 0.000000 - 0.966434 0.023662 -0.255825 0.000000 - -0.086892 0.967174 -0.238796 0.000000 - - - - -0.112271 22.069670 -3.606622 0.000000 - - - - - - 0.241777 0.253009 0.936766 0.000000 - 0.966434 0.023662 -0.255825 0.000000 - -0.086892 0.967174 -0.238796 0.000000 - - - - -0.112271 22.069670 -3.606622 0.000000 - - - - -0.002379 -3.165752 -0.002538 0.000000 - - - -0.000170 0.000324 0.000298 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.434495 -0.003448 -0.005632 0.000000 - -0.003448 0.423656 0.000633 0.000000 - -0.005632 0.000633 0.414102 0.000000 - - - - -0.002379 -3.165752 -0.002538 0.000000 - - - -0.000170 0.000324 0.000298 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.422736 0.412644 0.436873 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 152 - 0 - 0 - - - - 0.254328 0.271086 0.928348 0.000000 - 0.965174 -0.010306 -0.261407 0.000000 - -0.061296 0.962500 -0.264266 0.000000 - - - - -10.277276 17.783934 0.780533 0.000000 - - - - - - 0.254328 0.271086 0.928348 0.000000 - 0.965174 -0.010306 -0.261407 0.000000 - -0.061296 0.962500 -0.264266 0.000000 - - - - -10.277276 17.783934 0.780533 0.000000 - - - - 0.000444 -3.167942 0.001646 0.000000 - - - -0.000178 0.000344 0.000303 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.737092 0.038964 0.029305 0.000000 - 0.038964 0.866952 -0.010682 0.000000 - 0.029305 -0.010682 0.831291 0.000000 - - - - 0.000444 -3.167942 0.001646 0.000000 - - - -0.000178 0.000344 0.000303 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.877898 0.839660 0.717778 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 154 - 0 - 0 - - - - 0.299216 0.226625 0.926882 0.000000 - 0.950806 0.010861 -0.309595 0.000000 - -0.080229 0.973922 -0.212226 0.000000 - - - - -2.472811 23.386496 -2.742500 0.000000 - - - - - - 0.299216 0.226625 0.926882 0.000000 - 0.950806 0.010861 -0.309595 0.000000 - -0.080229 0.973922 -0.212226 0.000000 - - - - -2.472811 23.386496 -2.742500 0.000000 - - - - -0.002451 -3.166363 -0.002020 0.000000 - - - -0.000166 0.000317 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.274777 0.018970 0.005428 0.000000 - 0.018970 0.327233 -0.004729 0.000000 - 0.005428 -0.004729 0.297802 0.000000 - - - - -0.002451 -3.166363 -0.002020 0.000000 - - - -0.000166 0.000317 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.333602 0.299013 0.267198 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 156 - 0 - 0 - - - - 0.315779 0.242121 0.917421 0.000000 - 0.945339 0.002614 -0.326078 0.000000 - -0.081349 0.970243 -0.228061 0.000000 - - - - -3.610549 23.389378 -1.669634 0.000000 - - - - - - 0.315779 0.242121 0.917421 0.000000 - 0.945339 0.002614 -0.326078 0.000000 - -0.081349 0.970243 -0.228061 0.000000 - - - - -3.610549 23.389378 -1.669634 0.000000 - - - - -0.002088 -3.166511 -0.001661 0.000000 - - - -0.000172 0.000344 0.000299 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.394054 -0.004516 0.031684 0.000000 - -0.004516 0.374011 0.001523 0.000000 - 0.031684 0.001523 0.513060 0.000000 - - - - -0.002088 -3.166511 -0.001661 0.000000 - - - -0.000172 0.000344 0.000299 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.372371 0.520971 0.387783 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 158 - 0 - 0 - - - - 0.272245 0.253314 0.928286 0.000000 - 0.960007 -0.005993 -0.279912 0.000000 - -0.065343 0.967366 -0.244815 0.000000 - - - - -11.480623 17.341631 -0.277955 0.000000 - - - - - - 0.272245 0.253314 0.928286 0.000000 - 0.960007 -0.005993 -0.279912 0.000000 - -0.065343 0.967366 -0.244815 0.000000 - - - - -11.480623 17.341631 -0.277955 0.000000 - - - - 0.000203 -3.168483 0.002119 0.000000 - - - -0.000183 0.000323 0.000285 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.456758 0.005744 0.021015 0.000000 - 0.005744 0.470209 -0.001917 0.000000 - 0.021015 -0.001917 0.531361 0.000000 - - - - 0.000203 -3.168483 0.002119 0.000000 - - - -0.000183 0.000323 0.000285 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.471969 0.536875 0.449483 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 160 - 0 - 0 - - - - 0.288222 0.274237 0.917454 0.000000 - 0.954227 -0.002342 -0.299075 0.000000 - -0.079869 0.961659 -0.262359 0.000000 - - - - -8.022085 13.911036 0.167906 0.000000 - - - - - - 0.288222 0.274237 0.917454 0.000000 - 0.954227 -0.002342 -0.299075 0.000000 - -0.079869 0.961659 -0.262359 0.000000 - - - - -8.022085 13.911036 0.167906 0.000000 - - - - 0.001331 -3.167321 0.001599 0.000000 - - - -0.000180 0.000334 0.000310 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.350486 -0.013354 0.000530 0.000000 - -0.013354 0.310473 0.003706 0.000000 - 0.000530 0.003706 0.352315 0.000000 - - - - 0.001331 -3.167321 0.001599 0.000000 - - - -0.000180 0.000334 0.000310 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.306129 0.352457 0.354688 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 162 - 0 - 0 - - - - 0.258442 0.351774 0.899702 0.000000 - 0.965628 -0.067303 -0.251064 0.000000 - -0.027765 0.933662 -0.357076 0.000000 - - - - -8.393955 20.474304 -0.927764 0.000000 - - - - - - 0.258442 0.351774 0.899702 0.000000 - 0.965628 -0.067303 -0.251064 0.000000 - -0.027765 0.933662 -0.357076 0.000000 - - - - -8.393955 20.474304 -0.927764 0.000000 - - - - -0.000941 -3.167741 0.000495 0.000000 - - - -0.000181 0.000346 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.373811 0.005516 -0.002104 0.000000 - 0.005516 0.393163 -0.000204 0.000000 - -0.002104 -0.000204 0.367949 0.000000 - - - - -0.000941 -3.167741 0.000495 0.000000 - - - -0.000181 0.000346 0.000288 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.394645 0.367171 0.373107 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 164 - 0 - 0 - - - - 0.278631 0.201994 0.938916 0.000000 - 0.959357 -0.013024 -0.281895 0.000000 - -0.044712 0.979300 -0.197414 0.000000 - - - - -10.886441 20.601580 0.028054 0.000000 - - - - - - 0.278631 0.201994 0.938916 0.000000 - 0.959357 -0.013024 -0.281895 0.000000 - -0.044712 0.979300 -0.197414 0.000000 - - - - -10.886441 20.601580 0.028054 0.000000 - - - - -0.000615 -3.168304 0.001342 0.000000 - - - -0.000174 0.000343 0.000275 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.237972 0.016787 0.017304 0.000000 - 0.016787 0.287938 -0.003899 0.000000 - 0.017304 -0.003899 0.317162 0.000000 - - - - -0.000615 -3.168304 0.001342 0.000000 - - - -0.000174 0.000343 0.000275 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.292996 0.320783 0.229294 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 166 - 0 - 0 - - - - 0.260586 0.226656 0.938468 0.000000 - 0.963287 0.003997 -0.268443 0.000000 - -0.064596 0.973967 -0.217294 0.000000 - - - - 0.396177 18.553259 -2.599638 0.000000 - - - - - - 0.260586 0.226656 0.938468 0.000000 - 0.963287 0.003997 -0.268443 0.000000 - -0.064596 0.973967 -0.217294 0.000000 - - - - 0.396177 18.553259 -2.599638 0.000000 - - - - -0.000977 -3.165363 -0.002078 0.000000 - - - -0.000177 0.000331 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.359976 0.003616 0.026764 0.000000 - 0.003616 0.365703 -0.000393 0.000000 - 0.026764 -0.000393 0.468821 0.000000 - - - - -0.000977 -3.165363 -0.002078 0.000000 - - - -0.000177 0.000331 0.000283 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.366707 0.475048 0.352745 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 168 - 0 - 0 - - - - 0.303373 0.291774 0.907101 0.000000 - 0.949547 -0.013113 -0.313351 0.000000 - -0.079533 0.956398 -0.281031 0.000000 - - - - -9.927484 14.747825 0.034541 0.000000 - - - - - - 0.303373 0.291774 0.907101 0.000000 - 0.949547 -0.013113 -0.313351 0.000000 - -0.079533 0.956398 -0.281031 0.000000 - - - - -9.927484 14.747825 0.034541 0.000000 - - - - 0.001051 -3.167932 0.002079 0.000000 - - - -0.000195 0.000333 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.673907 0.080193 0.073487 0.000000 - 0.080193 0.877934 -0.024921 0.000000 - 0.073487 -0.024921 0.888422 0.000000 - - - - 0.001051 -3.167932 0.002079 0.000000 - - - -0.000195 0.000333 0.000297 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.905643 0.911182 0.623437 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 170 - 0 - 0 - - - - 0.271995 0.282809 0.919803 0.000000 - 0.960321 -0.018521 -0.278282 0.000000 - -0.061665 0.958998 -0.276625 0.000000 - - - - 1.777066 14.335148 -3.082107 0.000000 - - - - - - 0.271995 0.282809 0.919803 0.000000 - 0.960321 -0.018521 -0.278282 0.000000 - -0.061665 0.958998 -0.276625 0.000000 - - - - 1.777066 14.335148 -3.082107 0.000000 - - - - 0.000037 -3.164991 -0.001789 0.000000 - - - -0.000173 0.000342 0.000278 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.330301 0.026053 0.032641 0.000000 - 0.026053 0.406972 -0.008307 0.000000 - 0.032641 -0.008307 0.429494 0.000000 - - - - 0.000037 -3.164991 -0.001789 0.000000 - - - -0.000173 0.000342 0.000278 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.414884 0.439280 0.312602 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 172 - 0 - 0 - - - - 0.273325 0.268440 0.923706 0.000000 - 0.958168 0.008775 -0.286072 0.000000 - -0.084899 0.963256 -0.254812 0.000000 - - - - -2.715794 13.233632 -1.192465 0.000000 - - - - - - 0.273325 0.268440 0.923706 0.000000 - 0.958168 0.008775 -0.286072 0.000000 - -0.084899 0.963256 -0.254812 0.000000 - - - - -2.715794 13.233632 -1.192465 0.000000 - - - - 0.001070 -3.165934 -0.000031 0.000000 - - - -0.000167 0.000358 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.394029 0.012621 0.002867 0.000000 - 0.012621 0.433447 -0.003779 0.000000 - 0.002867 -0.003779 0.403964 0.000000 - - - - 0.001070 -3.165934 -0.000031 0.000000 - - - -0.000167 0.000358 0.000295 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.437382 0.404729 0.389330 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 0 - 174 - 0 - 0 - - - - 0.291331 0.271931 0.917159 0.000000 - 0.952633 0.004998 -0.304082 0.000000 - -0.087273 0.962304 -0.257594 0.000000 - - - - -9.943352 13.049049 -0.094216 0.000000 - - - - - - 0.291331 0.271931 0.917159 0.000000 - 0.952633 0.004998 -0.304082 0.000000 - -0.087273 0.962304 -0.257594 0.000000 - - - - -9.943352 13.049049 -0.094216 0.000000 - - - - 0.001521 -3.167956 0.002386 0.000000 - - - -0.000172 0.000324 0.000303 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - 999999984306749440.000000 - 0.000000 - 0.500000 - 0.100000 - 1.000000 - 0.000000 - 0.000000 - 0 - 0 - 84 - -1 - 1 - 2 - 1 - - - - 0.541295 -0.040699 -0.003333 0.000000 - -0.040699 0.422760 0.012051 0.000000 - -0.003333 0.012051 0.529632 0.000000 - - - - 0.001521 -3.167956 0.002386 0.000000 - - - -0.000172 0.000324 0.000303 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.000000 -10.000000 0.000000 0.000000 - - - 0.409209 0.528753 0.555725 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1.000000 - 0.000000 - 0.000000 - 0.005000 - 0.010000 - 0.010000 - 0.010000 - 0.800000 - 1.000000 - 0 - - - - 71 - 147 - 0 - 6 - -1 - -1 - 0 - 0.398739 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999825 -0.015506 0.010442 0.000000 - 0.015509 0.999880 -0.000183 0.000000 - -0.010438 0.000345 0.999945 0.000000 - - - - -1.148605 0.407813 -0.909073 0.000000 - - - - - - 0.999989 -0.004721 0.000164 0.000000 - 0.004721 0.999988 0.001398 0.000000 - -0.000171 -0.001398 0.999999 0.000000 - - - - -0.879751 0.179427 1.106070 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 81 - 95 - 0 - 6 - -1 - -1 - 0 - -0.154912 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999928 0.000549 0.011972 0.000000 - -0.000801 0.999779 0.020995 0.000000 - -0.011958 -0.021003 0.999708 0.000000 - - - - 0.130261 -0.280198 0.534541 0.000000 - - - - - - 0.999832 0.001246 -0.018271 0.000000 - -0.001189 0.999994 0.003157 0.000000 - 0.018275 -0.003135 0.999828 0.000000 - - - - 0.609493 0.303517 -0.029588 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 77 - 109 - 0 - 6 - -1 - -1 - 0 - -0.254296 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999994 -0.001953 -0.002959 0.000000 - 0.001987 0.999934 0.011345 0.000000 - 0.002937 -0.011351 0.999931 0.000000 - - - - 1.505062 -1.204177 -0.708804 0.000000 - - - - - - 0.999862 -0.012593 0.010844 0.000000 - 0.012679 0.999889 -0.007881 0.000000 - -0.010743 0.008017 0.999910 0.000000 - - - - -0.160763 -1.154789 -0.404381 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 107 - 165 - 0 - 6 - -1 - -1 - 0 - 0.195486 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999972 -0.001225 0.007369 0.000000 - 0.001210 0.999997 0.002116 0.000000 - -0.007372 -0.002107 0.999971 0.000000 - - - - 0.126838 1.149777 -0.642064 0.000000 - - - - - - 0.999714 0.022761 0.007321 0.000000 - -0.022465 0.999012 -0.038348 0.000000 - -0.008186 0.038172 0.999238 0.000000 - - - - -1.234870 1.214337 -0.139222 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 107 - 159 - 0 - 6 - -1 - -1 - 0 - 0.714112 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999972 -0.001225 0.007369 0.000000 - 0.001210 0.999997 0.002116 0.000000 - -0.007372 -0.002107 0.999971 0.000000 - - - - -0.798123 -1.531303 0.605195 0.000000 - - - - - - 0.999987 0.000688 0.005104 0.000000 - -0.000733 0.999959 0.008980 0.000000 - -0.005098 -0.008984 0.999947 0.000000 - - - - 1.078496 -1.061508 0.632784 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 75 - 127 - 0 - 6 - -1 - -1 - 0 - -0.039352 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999992 -0.002750 -0.002877 0.000000 - 0.002758 0.999993 0.002669 0.000000 - 0.002870 -0.002677 0.999992 0.000000 - - - - 0.945728 -1.136918 -0.004621 0.000000 - - - - - - 0.999985 -0.002735 -0.004700 0.000000 - 0.002745 0.999994 0.002207 0.000000 - 0.004694 -0.002220 0.999987 0.000000 - - - - 1.151271 -0.929153 -1.336886 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 99 - 103 - 0 - 6 - -1 - -1 - 0 - -0.406892 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999887 -0.009273 -0.011833 0.000000 - 0.009287 0.999956 0.001103 0.000000 - 0.011822 -0.001213 0.999929 0.000000 - - - - 1.565424 1.236504 -0.716268 0.000000 - - - - - - 0.998740 0.038313 0.032400 0.000000 - -0.038899 0.999087 0.017672 0.000000 - -0.031694 -0.018910 0.999319 0.000000 - - - - 0.776975 0.767613 1.544399 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 99 - 75 - 0 - 6 - -1 - -1 - 0 - 0.541433 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999887 -0.009273 -0.011833 0.000000 - 0.009287 0.999956 0.001103 0.000000 - 0.011822 -0.001213 0.999929 0.000000 - - - - 1.010527 -0.312474 1.047620 0.000000 - - - - - - 0.999992 -0.002750 -0.002877 0.000000 - 0.002758 0.999993 0.002669 0.000000 - 0.002870 -0.002677 0.999992 0.000000 - - - - 0.976103 -1.173144 -0.122854 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 43 - 41 - 0 - 6 - -1 - -1 - 0 - 0.000064 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999671 0.022995 0.011362 0.000000 - -0.022373 0.998392 -0.052082 0.000000 - -0.012541 0.051811 0.998578 0.000000 - - - - 0.547733 0.364076 0.024028 0.000000 - - - - - - 0.998622 0.051113 -0.011898 0.000000 - -0.051637 0.997462 -0.049015 0.000000 - 0.009363 0.049562 0.998727 0.000000 - - - - -0.181741 1.015347 0.260045 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 115 - 103 - 0 - 6 - -1 - -1 - 0 - 0.398816 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999854 0.007988 0.015077 0.000000 - -0.008209 0.999859 0.014645 0.000000 - -0.014958 -0.014767 0.999779 0.000000 - - - - -0.544667 -1.603396 1.544737 0.000000 - - - - - - 0.998740 0.038313 0.032400 0.000000 - -0.038899 0.999087 0.017672 0.000000 - -0.031694 -0.018910 0.999319 0.000000 - - - - -1.197697 -1.679137 -0.898750 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 113 - 77 - 0 - 6 - -1 - -1 - 0 - -0.366810 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999974 -0.006829 -0.002456 0.000000 - 0.006831 0.999976 0.000691 0.000000 - 0.002451 -0.000708 0.999997 0.000000 - - - - 0.245624 -1.559062 0.712341 0.000000 - - - - - - 0.999994 -0.001953 -0.002959 0.000000 - 0.001987 0.999934 0.011345 0.000000 - 0.002937 -0.011351 0.999931 0.000000 - - - - 0.223766 -1.167623 -1.090824 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 129 - 131 - 0 - 6 - -1 - -1 - 0 - 0.040231 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999985 0.004147 0.003719 0.000000 - -0.004153 0.999990 0.001576 0.000000 - -0.003712 -0.001592 0.999992 0.000000 - - - - -0.516964 0.990952 0.901215 0.000000 - - - - - - 0.999737 -0.020466 -0.010354 0.000000 - 0.020667 0.999592 0.019718 0.000000 - 0.009946 -0.019927 0.999752 0.000000 - - - - 0.024732 1.660541 0.360760 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 31 - 93 - 0 - 6 - -1 - -1 - 0 - -0.111936 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999902 0.013490 -0.003659 0.000000 - -0.013487 0.999909 0.000807 0.000000 - 0.003670 -0.000758 0.999993 0.000000 - - - - -1.181128 -0.261032 -0.365489 0.000000 - - - - - - 0.999190 -0.040157 -0.002590 0.000000 - 0.040164 0.999189 0.002843 0.000000 - 0.002473 -0.002945 0.999993 0.000000 - - - - -0.467074 -0.083943 -1.427529 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 101 - 115 - 0 - 6 - -1 - -1 - 0 - 1.536227 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999443 -0.028229 0.017782 0.000000 - 0.028344 0.999579 -0.006224 0.000000 - -0.017598 0.006724 0.999822 0.000000 - - - - 1.871074 0.120632 -0.165374 0.000000 - - - - - - 0.999854 0.007988 0.015077 0.000000 - -0.008209 0.999859 0.014645 0.000000 - -0.014958 -0.014767 0.999779 0.000000 - - - - 0.371448 -0.503327 -1.444950 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 61 - 33 - 0 - 6 - -1 - -1 - 0 - -0.585814 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999989 0.004199 -0.002231 0.000000 - -0.004190 0.999982 0.004222 0.000000 - 0.002248 -0.004212 0.999989 0.000000 - - - - 1.178923 0.330306 0.853489 0.000000 - - - - - - 0.999992 0.000088 0.004020 0.000000 - -0.000043 0.999937 -0.011226 0.000000 - -0.004020 0.011225 0.999929 0.000000 - - - - 0.722433 -0.760042 -0.903138 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 87 - 61 - 0 - 6 - -1 - -1 - 0 - -3.175179 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999592 0.022966 0.016977 0.000000 - -0.023176 0.999656 0.012290 0.000000 - -0.016688 -0.012679 0.999780 0.000000 - - - - -0.058689 -1.275792 -0.502480 0.000000 - - - - - - 0.999989 0.004199 -0.002231 0.000000 - -0.004190 0.999982 0.004222 0.000000 - 0.002248 -0.004212 0.999989 0.000000 - - - - -0.588453 -0.318871 -1.069428 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 13 - 161 - 0 - 6 - -1 - -1 - 0 - 0.304131 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999305 0.001210 -0.037243 0.000000 - -0.000641 0.999883 0.015283 0.000000 - 0.037257 -0.015249 0.999189 0.000000 - - - - -0.603564 0.251886 -0.558628 0.000000 - - - - - - 0.999941 0.010428 0.003191 0.000000 - -0.010465 0.999876 0.011748 0.000000 - -0.003068 -0.011780 0.999926 0.000000 - - - - -0.369211 -0.434017 -0.829002 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 35 - 87 - 0 - 6 - -1 - -1 - 0 - 0.573876 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 1.000000 0.000429 -0.000126 0.000000 - -0.000428 0.999991 0.004252 0.000000 - 0.000128 -0.004252 0.999991 0.000000 - - - - 0.668413 0.555253 1.563411 0.000000 - - - - - - 0.999592 0.022966 0.016977 0.000000 - -0.023176 0.999656 0.012290 0.000000 - -0.016688 -0.012679 0.999780 0.000000 - - - - -0.396940 1.203964 -0.959884 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 167 - 131 - 0 - 6 - -1 - -1 - 0 - -0.177745 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999813 0.013677 -0.013690 0.000000 - -0.013995 0.999629 -0.023374 0.000000 - 0.013366 0.023561 0.999633 0.000000 - - - - 1.101216 -1.519549 -0.208364 0.000000 - - - - - - 0.999737 -0.020466 -0.010354 0.000000 - 0.020667 0.999592 0.019718 0.000000 - 0.009946 -0.019927 0.999752 0.000000 - - - - -1.109613 -1.421741 -0.000889 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 167 - 113 - 0 - 6 - -1 - -1 - 0 - 0.177712 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999813 0.013677 -0.013690 0.000000 - -0.013995 0.999629 -0.023374 0.000000 - 0.013366 0.023561 0.999633 0.000000 - - - - -1.140611 0.683941 0.340254 0.000000 - - - - - - 0.999974 -0.006829 -0.002456 0.000000 - 0.006831 0.999976 0.000691 0.000000 - 0.002451 -0.000708 0.999997 0.000000 - - - - 0.991228 1.000827 -0.392762 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 157 - 155 - 0 - 6 - -1 - -1 - 0 - 0.147908 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999025 -0.003424 0.044024 0.000000 - 0.003940 0.999925 -0.011635 0.000000 - -0.043981 0.011797 0.998963 0.000000 - - - - -0.762092 0.160179 1.350998 0.000000 - - - - - - 0.999594 -0.007832 0.027388 0.000000 - 0.008676 0.999487 -0.030844 0.000000 - -0.027133 0.031069 0.999149 0.000000 - - - - -1.208668 0.920593 0.058037 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 31 - 5 - 0 - 6 - -1 - -1 - 0 - -0.142490 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999902 0.013490 -0.003660 0.000000 - -0.013487 0.999909 0.000807 0.000000 - 0.003670 -0.000758 0.999993 0.000000 - - - - 0.064520 -0.979395 -0.312057 0.000000 - - - - - - 0.999984 -0.005549 0.001266 0.000000 - 0.005545 0.999981 0.002810 0.000000 - -0.001282 -0.002803 0.999995 0.000000 - - - - -1.250101 -0.577753 0.715910 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 127 - 137 - 0 - 6 - -1 - -1 - 0 - -0.035165 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999985 -0.002735 -0.004700 0.000000 - 0.002745 0.999994 0.002207 0.000000 - 0.004694 -0.002220 0.999987 0.000000 - - - - -0.678187 -0.758855 1.211484 0.000000 - - - - - - 0.999816 0.005765 -0.018303 0.000000 - -0.005765 0.999983 0.000035 0.000000 - 0.018303 0.000070 0.999833 0.000000 - - - - 1.378594 -0.419746 -0.104451 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 23 - 83 - 0 - 6 - -1 - -1 - 0 - -0.176209 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999920 0.012504 0.001622 0.000000 - -0.012480 0.999819 -0.014376 0.000000 - -0.001802 0.014355 0.999895 0.000000 - - - - 0.135392 0.605935 1.521100 0.000000 - - - - - - 0.999914 -0.006125 -0.011598 0.000000 - 0.006091 0.999977 -0.003025 0.000000 - 0.011617 0.002954 0.999928 0.000000 - - - - 1.617340 -0.268658 0.832913 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 153 - 37 - 0 - 6 - -1 - -1 - 0 - -0.820308 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999873 0.004799 -0.015190 0.000000 - -0.004741 0.999981 0.003909 0.000000 - 0.015208 -0.003837 0.999877 0.000000 - - - - 0.741776 0.952270 -0.603444 0.000000 - - - - - - 0.999984 -0.005219 -0.002192 0.000000 - 0.005223 0.999985 0.001494 0.000000 - 0.002184 -0.001505 0.999996 0.000000 - - - - 0.689913 0.994789 0.126445 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 165 - 57 - 0 - 6 - -1 - -1 - 0 - 1.265434 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999700 0.023651 0.006386 0.000000 - -0.023400 0.999045 -0.036891 0.000000 - -0.007252 0.036730 0.999299 0.000000 - - - - -0.440566 -1.433525 0.316210 0.000000 - - - - - - 0.999292 -0.013129 -0.035244 0.000000 - 0.013967 0.999623 0.023642 0.000000 - 0.034920 -0.024117 0.999099 0.000000 - - - - 0.047603 -0.582398 -1.113613 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 97 - 119 - 0 - 6 - -1 - -1 - 0 - 0.982118 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999969 -0.000079 -0.007920 0.000000 - 0.000040 0.999988 -0.004880 0.000000 - 0.007920 0.004880 0.999957 0.000000 - - - - 0.040992 1.011433 -0.026501 0.000000 - - - - - - 0.999866 0.013991 0.008538 0.000000 - -0.014118 0.999788 0.014996 0.000000 - -0.008326 -0.015115 0.999851 0.000000 - - - - 0.075087 0.157909 1.074155 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 67 - 65 - 0 - 6 - -1 - -1 - 0 - 0.167513 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999968 -0.007428 0.003032 0.000000 - 0.007429 0.999972 -0.000233 0.000000 - -0.003030 0.000255 0.999995 0.000000 - - - - 1.425411 -0.011601 0.011769 0.000000 - - - - - - 0.999960 -0.008821 -0.001079 0.000000 - 0.008811 0.999920 -0.009119 0.000000 - 0.001159 0.009109 0.999958 0.000000 - - - - 0.935354 -0.372748 -1.365238 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 23 - 131 - 0 - 6 - -1 - -1 - 0 - 0.138032 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999972 0.007345 0.001594 0.000000 - -0.007310 0.999748 -0.021209 0.000000 - -0.001749 0.021197 0.999774 0.000000 - - - - 1.056650 1.701536 -0.117703 0.000000 - - - - - - 0.999719 -0.021348 -0.010282 0.000000 - 0.021503 0.999654 0.015141 0.000000 - 0.009955 -0.015358 0.999833 0.000000 - - - - -0.463922 1.587691 1.470158 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 157 - 97 - 0 - 6 - -1 - -1 - 0 - 0.372702 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998833 0.012154 0.046733 0.000000 - -0.011597 0.999859 -0.012160 0.000000 - -0.046875 0.011604 0.998833 0.000000 - - - - -1.046819 0.502274 -0.762776 0.000000 - - - - - - 0.999969 -0.000079 -0.007920 0.000000 - 0.000040 0.999988 -0.004880 0.000000 - 0.007920 0.004880 0.999957 0.000000 - - - - 0.446679 0.584710 1.177444 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 129 - 49 - 0 - 6 - -1 - -1 - 0 - -0.040112 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999988 0.003329 0.003678 0.000000 - -0.003318 0.999990 -0.003002 0.000000 - -0.003688 0.002990 0.999989 0.000000 - - - - -0.267122 0.512280 -1.373376 0.000000 - - - - - - 0.999992 -0.003974 -0.000028 0.000000 - 0.003974 0.999840 0.017462 0.000000 - -0.000041 -0.017462 0.999848 0.000000 - - - - -1.354793 0.496778 0.870278 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 157 - 49 - 0 - 6 - -1 - -1 - 0 - -0.529262 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998833 0.012154 0.046733 0.000000 - -0.011597 0.999859 -0.012160 0.000000 - -0.046875 0.011604 0.998833 0.000000 - - - - 0.004832 1.287365 0.982306 0.000000 - - - - - - 0.999992 -0.003974 -0.000028 0.000000 - 0.003974 0.999840 0.017462 0.000000 - -0.000041 -0.017462 0.999848 0.000000 - - - - -0.500239 0.615772 -1.413696 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 33 - 67 - 0 - 6 - -1 - -1 - 0 - -0.405770 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999992 0.001099 0.003746 0.000000 - -0.001058 0.999940 -0.010940 0.000000 - -0.003758 0.010936 0.999933 0.000000 - - - - 0.776240 -0.720229 -0.808953 0.000000 - - - - - - 0.999968 -0.007428 0.003032 0.000000 - 0.007429 0.999972 -0.000233 0.000000 - -0.003030 0.000255 0.999995 0.000000 - - - - 0.724390 0.274628 -1.199862 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 77 - 171 - 0 - 6 - -1 - -1 - 0 - -0.039446 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999993 0.001110 -0.003564 0.000000 - -0.001103 0.999998 0.001799 0.000000 - 0.003566 -0.001795 0.999992 0.000000 - - - - -1.571034 -0.854730 0.213210 0.000000 - - - - - - 0.999741 0.022445 -0.003802 0.000000 - -0.022323 0.999317 0.029431 0.000000 - 0.004460 -0.029339 0.999560 0.000000 - - - - -0.088246 -1.404151 0.224946 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 37 - 39 - 0 - 6 - -1 - -1 - 0 - 0.133219 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999957 0.005323 -0.007536 0.000000 - -0.005220 0.999895 0.013512 0.000000 - 0.007608 -0.013472 0.999880 0.000000 - - - - -0.943738 0.880049 0.847125 0.000000 - - - - - - 0.999985 0.002943 -0.004713 0.000000 - -0.002973 0.999975 -0.006451 0.000000 - 0.004694 0.006465 0.999968 0.000000 - - - - 0.815253 0.861530 0.512363 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 39 - 105 - 0 - 6 - -1 - -1 - 0 - 0.110181 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999985 0.002943 -0.004713 0.000000 - -0.002973 0.999975 -0.006451 0.000000 - 0.004694 0.006465 0.999968 0.000000 - - - - 0.333353 1.013113 0.551395 0.000000 - - - - - - 0.998895 -0.045145 0.013071 0.000000 - 0.045290 0.998913 -0.011021 0.000000 - -0.012559 0.011601 0.999854 0.000000 - - - - 1.094530 0.664131 -0.482392 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 93 - 175 - 0 - 6 - -1 - -1 - 0 - -0.000073 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998314 -0.057878 -0.004438 0.000000 - 0.057971 0.998010 0.024815 0.000000 - 0.002993 -0.025030 0.999682 0.000000 - - - - -0.788371 -0.323563 -1.463284 0.000000 - - - - - - 0.999823 0.004551 0.018255 0.000000 - -0.004673 0.999967 0.006651 0.000000 - -0.018224 -0.006736 0.999811 0.000000 - - - - 0.096754 -1.048344 -0.026887 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 17 - 53 - 0 - 6 - -1 - -1 - 0 - -0.983829 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999956 -0.009421 -0.000064 0.000000 - 0.009419 0.999845 -0.014858 0.000000 - 0.000204 0.014857 0.999890 0.000000 - - - - 1.164370 0.400812 -1.268687 0.000000 - - - - - - 0.999926 -0.011592 -0.003692 0.000000 - 0.011537 0.999827 -0.014605 0.000000 - 0.003861 0.014562 0.999887 0.000000 - - - - -1.217212 0.862043 -1.742996 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 93 - 71 - 0 - 6 - -1 - -1 - 0 - 0.066129 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998314 -0.057878 -0.004438 0.000000 - 0.057971 0.998010 0.024815 0.000000 - 0.002993 -0.025030 0.999682 0.000000 - - - - -1.421421 -0.579937 0.842680 0.000000 - - - - - - 0.999921 -0.008590 0.009135 0.000000 - 0.008521 0.999935 0.007569 0.000000 - -0.009199 -0.007491 0.999930 0.000000 - - - - -0.122090 -1.353865 -1.745057 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 31 - 13 - 0 - 6 - -1 - -1 - 0 - 0.127278 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999982 -0.004243 -0.004327 0.000000 - 0.004340 0.999730 0.022847 0.000000 - 0.004229 -0.022865 0.999730 0.000000 - - - - 0.841270 -0.274391 0.756510 0.000000 - - - - - - 0.999657 0.003157 -0.025989 0.000000 - -0.002843 0.999923 0.012120 0.000000 - 0.026026 -0.012042 0.999589 0.000000 - - - - 0.868942 -0.966759 -0.005924 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 161 - 73 - 0 - 6 - -1 - -1 - 0 - 0.694567 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999818 0.012503 0.014420 0.000000 - -0.012626 0.999884 0.008474 0.000000 - -0.014312 -0.008655 0.999860 0.000000 - - - - 0.701325 -1.004728 1.100832 0.000000 - - - - - - 0.999970 0.004018 -0.006552 0.000000 - -0.003931 0.999903 0.013335 0.000000 - 0.006604 -0.013308 0.999890 0.000000 - - - - 0.920021 0.022569 -1.349704 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 37 - 107 - 0 - 6 - -1 - -1 - 0 - -0.674791 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999957 0.005323 -0.007536 0.000000 - -0.005220 0.999895 0.013512 0.000000 - 0.007608 -0.013472 0.999880 0.000000 - - - - 1.079500 0.698007 -0.583321 0.000000 - - - - - - 0.999884 0.015223 0.000784 0.000000 - -0.015215 0.999837 -0.009739 0.000000 - -0.000932 0.009726 0.999952 0.000000 - - - - -0.085087 1.541600 -0.589792 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 83 - 109 - 0 - 6 - -1 - -1 - 0 - -0.177075 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999894 -0.007480 -0.012518 0.000000 - 0.007294 0.999864 -0.014825 0.000000 - 0.012627 0.014732 0.999812 0.000000 - - - - 1.514431 -0.339333 0.950581 0.000000 - - - - - - 0.999902 -0.009403 0.010338 0.000000 - 0.009582 0.999802 -0.017435 0.000000 - -0.010172 0.017532 0.999795 0.000000 - - - - 1.274038 1.088178 0.885551 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 13 - 85 - 0 - 6 - -1 - -1 - 0 - -0.022617 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999657 0.003157 -0.025989 0.000000 - -0.002843 0.999923 0.012120 0.000000 - 0.026026 -0.012042 0.999589 0.000000 - - - - 0.758274 0.681199 0.001532 0.000000 - - - - - - 0.999888 0.006632 0.013414 0.000000 - -0.006699 0.999965 0.004927 0.000000 - -0.013381 -0.005016 0.999898 0.000000 - - - - -0.561571 0.153719 0.723050 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 87 - 173 - 0 - 6 - -1 - -1 - 0 - 2.378793 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999476 0.027828 0.016561 0.000000 - -0.027985 0.999565 0.009327 0.000000 - -0.016294 -0.009786 0.999819 0.000000 - - - - 0.863280 0.062484 0.354611 0.000000 - - - - - - 0.999996 0.000418 0.002760 0.000000 - -0.000419 1.000000 0.000416 0.000000 - -0.002759 -0.000417 0.999996 0.000000 - - - - 0.287416 -0.510340 -0.172879 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 107 - 29 - 0 - 6 - -1 - -1 - 0 - -1.595709 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999884 0.015223 0.000784 0.000000 - -0.015215 0.999837 -0.009739 0.000000 - -0.000932 0.009726 0.999952 0.000000 - - - - 0.865269 -0.229341 0.735999 0.000000 - - - - - - 0.999345 0.016246 -0.032349 0.000000 - -0.014821 0.998930 0.043805 0.000000 - 0.033026 -0.043296 0.998516 0.000000 - - - - -0.230945 -1.048352 0.097483 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 161 - 27 - 0 - 6 - -1 - -1 - 0 - -0.042971 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999818 0.012503 0.014420 0.000000 - -0.012626 0.999884 0.008474 0.000000 - -0.014312 -0.008655 0.999860 0.000000 - - - - 0.355256 1.050246 -0.689039 0.000000 - - - - - - 0.999897 -0.010279 -0.009988 0.000000 - 0.010249 0.999943 -0.003062 0.000000 - 0.010019 0.002959 0.999945 0.000000 - - - - 1.076603 0.660442 0.025604 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 5 - 123 - 0 - 6 - -1 - -1 - 0 - -0.710271 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999727 -0.023384 0.000179 0.000000 - 0.023372 0.999418 0.024833 0.000000 - -0.000759 -0.024822 0.999692 0.000000 - - - - 0.476363 0.152431 0.833646 0.000000 - - - - - - 0.999976 -0.005905 -0.003552 0.000000 - 0.005839 0.999812 -0.018503 0.000000 - 0.003660 0.018482 0.999822 0.000000 - - - - 0.013903 -0.944748 0.405447 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 159 - 11 - 0 - 6 - -1 - -1 - 0 - -0.023756 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999852 0.017109 -0.001503 0.000000 - -0.017113 0.999849 -0.002862 0.000000 - 0.001454 0.002887 0.999995 0.000000 - - - - 0.969475 -1.028847 0.855172 0.000000 - - - - - - 0.999930 -0.002280 -0.011649 0.000000 - 0.002508 0.999804 0.019636 0.000000 - 0.011602 -0.019664 0.999739 0.000000 - - - - -0.060030 -1.163552 -0.458388 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 113 - 135 - 0 - 6 - -1 - -1 - 0 - -0.120716 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999988 -0.003752 -0.003019 0.000000 - 0.003725 0.999954 -0.008833 0.000000 - 0.003052 0.008821 0.999956 0.000000 - - - - -1.697575 -0.423645 -0.324618 0.000000 - - - - - - 0.999911 0.001812 0.013243 0.000000 - -0.002034 0.999856 0.016827 0.000000 - -0.013211 -0.016852 0.999771 0.000000 - - - - -0.363410 -0.901576 -0.914864 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 165 - 17 - 0 - 6 - -1 - -1 - 0 - -1.021723 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999231 0.039200 0.000453 0.000000 - -0.039129 0.997981 -0.050031 0.000000 - -0.002414 0.049974 0.998748 0.000000 - - - - 1.113746 -1.206181 0.514244 0.000000 - - - - - - 0.999956 -0.009421 -0.000064 0.000000 - 0.009419 0.999845 -0.014858 0.000000 - 0.000204 0.014857 0.999890 0.000000 - - - - 0.448129 -1.464164 -0.238204 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 35 - 161 - 0 - 6 - -1 - -1 - 0 - 0.346120 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999986 0.005243 -0.000475 0.000000 - -0.005242 0.999985 0.001281 0.000000 - 0.000482 -0.001278 0.999999 0.000000 - - - - 0.287570 0.799899 -1.552757 0.000000 - - - - - - 0.999818 0.012503 0.014420 0.000000 - -0.012626 0.999884 0.008474 0.000000 - -0.014312 -0.008655 0.999860 0.000000 - - - - -0.426237 0.974539 0.829051 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 113 - 41 - 0 - 6 - -1 - -1 - 0 - -0.025021 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999988 -0.003752 -0.003019 0.000000 - 0.003725 0.999954 -0.008833 0.000000 - 0.003052 0.008821 0.999956 0.000000 - - - - -1.775705 -0.220237 -1.017524 0.000000 - - - - - - 0.998616 0.050560 -0.014507 0.000000 - -0.051100 0.997906 -0.039648 0.000000 - 0.012472 0.040334 0.999108 0.000000 - - - - 0.691801 -0.960003 -1.132915 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 153 - 91 - 0 - 6 - -1 - -1 - 0 - 0.063031 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999672 0.015495 -0.020412 0.000000 - -0.015170 0.999757 0.015980 0.000000 - 0.020654 -0.015665 0.999664 0.000000 - - - - -0.983500 0.299771 0.718049 0.000000 - - - - - - 0.999900 -0.011554 0.008154 0.000000 - 0.011351 0.999634 0.024572 0.000000 - -0.008435 -0.024477 0.999665 0.000000 - - - - 0.189642 1.154552 0.176793 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 93 - 147 - 0 - 6 - -1 - -1 - 0 - -0.407922 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998314 -0.057878 -0.004438 0.000000 - 0.057971 0.998010 0.024815 0.000000 - 0.002993 -0.025030 0.999682 0.000000 - - - - -1.397458 -0.462519 0.122354 0.000000 - - - - - - 0.999997 0.002275 -0.001059 0.000000 - -0.002266 0.999955 0.009164 0.000000 - 0.001080 -0.009161 0.999957 0.000000 - - - - 0.172993 -1.474296 -0.434893 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 49 - 75 - 0 - 6 - -1 - -1 - 0 - -0.574933 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999999 -0.000094 -0.001220 0.000000 - 0.000109 0.999924 0.012312 0.000000 - 0.001218 -0.012312 0.999923 0.000000 - - - - 0.232985 0.893101 1.614673 0.000000 - - - - - - 0.999944 -0.010230 -0.002669 0.000000 - 0.010246 0.999929 0.006130 0.000000 - 0.002606 -0.006157 0.999978 0.000000 - - - - -0.133558 1.251653 -0.202133 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 125 - 19 - 0 - 6 - -1 - -1 - 0 - 1.652194 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999702 0.024139 0.003589 0.000000 - -0.024185 0.999619 0.013316 0.000000 - -0.003267 -0.013399 0.999905 0.000000 - - - - -1.204425 -0.262825 -0.500958 0.000000 - - - - - - 0.999923 -0.009091 0.008416 0.000000 - 0.009090 0.999959 0.000161 0.000000 - -0.008417 -0.000085 0.999965 0.000000 - - - - -0.623731 -1.391303 0.174927 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 19 - 9 - 0 - 6 - -1 - -1 - 0 - 1.308758 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999923 -0.009091 0.008416 0.000000 - 0.009090 0.999959 0.000161 0.000000 - -0.008417 -0.000085 0.999965 0.000000 - - - - 0.299810 1.438023 0.926680 0.000000 - - - - - - 0.999776 0.021146 -0.000676 0.000000 - -0.021141 0.999752 0.007014 0.000000 - 0.000824 -0.006998 0.999975 0.000000 - - - - -0.387944 0.705266 -1.009258 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 119 - 149 - 0 - 6 - -1 - -1 - 0 - 0.972415 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999769 0.020538 0.006346 0.000000 - -0.020586 0.999759 0.007559 0.000000 - -0.006190 -0.007688 0.999951 0.000000 - - - - -0.611347 0.190139 -0.383555 0.000000 - - - - - - 0.999910 -0.013206 -0.002402 0.000000 - 0.013185 0.999878 -0.008398 0.000000 - 0.002513 0.008366 0.999962 0.000000 - - - - -0.057306 0.031083 1.238600 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 79 - 143 - 0 - 6 - -1 - -1 - 0 - -0.160719 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999861 -0.016105 0.004259 0.000000 - 0.016099 0.999869 0.001505 0.000000 - -0.004283 -0.001436 0.999990 0.000000 - - - - -0.351740 -0.952579 -0.281047 0.000000 - - - - - - 0.999914 0.011723 0.005899 0.000000 - -0.011515 0.999351 -0.034132 0.000000 - -0.006295 0.034061 0.999400 0.000000 - - - - -1.261499 -0.180052 0.495457 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 141 - 59 - 0 - 6 - -1 - -1 - 0 - 0.000048 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.995579 0.093802 -0.004761 0.000000 - -0.093633 0.995210 0.028099 0.000000 - 0.007374 -0.027529 0.999594 0.000000 - - - - 0.951686 0.465828 0.364875 0.000000 - - - - - - 0.999769 0.003920 -0.021119 0.000000 - -0.004650 0.999389 -0.034648 0.000000 - 0.020970 0.034738 0.999176 0.000000 - - - - 0.747476 -0.923579 0.149383 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 95 - 21 - 0 - 6 - -1 - -1 - 0 - -0.014669 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999451 0.028966 -0.016092 0.000000 - -0.029936 0.997518 -0.063731 0.000000 - 0.014206 0.064178 0.997837 0.000000 - - - - -0.698994 0.602673 0.670300 0.000000 - - - - - - 0.999314 -0.028105 0.024099 0.000000 - 0.027876 0.999564 0.009760 0.000000 - -0.024363 -0.009082 0.999662 0.000000 - - - - -0.649031 -0.558438 0.649866 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 81 - 7 - 0 - 6 - -1 - -1 - 0 - -0.500172 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999441 0.030294 0.014130 0.000000 - -0.029616 0.998506 -0.045917 0.000000 - -0.015500 0.045473 0.998845 0.000000 - - - - -0.478968 0.925546 -0.117188 0.000000 - - - - - - 0.999725 -0.007598 -0.022193 0.000000 - 0.007220 0.999828 -0.017060 0.000000 - 0.022319 0.016895 0.999608 0.000000 - - - - -0.897503 0.576177 0.114841 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 65 - 63 - 0 - 6 - -1 - -1 - 0 - 0.010938 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999995 -0.003125 -0.001068 0.000000 - 0.003105 0.999820 -0.018705 0.000000 - 0.001127 0.018702 0.999824 0.000000 - - - - -0.981236 0.433616 0.665279 0.000000 - - - - - - 0.999617 -0.019834 0.019313 0.000000 - 0.020387 0.999376 -0.028843 0.000000 - -0.018729 0.029226 0.999397 0.000000 - - - - -0.602147 -0.357662 0.682560 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 169 - 21 - 0 - 6 - -1 - -1 - 0 - 0.016487 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999349 0.016561 0.032043 0.000000 - -0.017674 0.999239 0.034771 0.000000 - -0.031443 -0.035315 0.998881 0.000000 - - - - -0.818487 -0.229377 0.087430 0.000000 - - - - - - 0.999314 -0.028105 0.024099 0.000000 - 0.027876 0.999564 0.009760 0.000000 - -0.024363 -0.009082 0.999662 0.000000 - - - - -0.458102 -0.339242 0.667569 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 145 - 69 - 0 - 6 - -1 - -1 - 0 - 1.610953 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999934 0.009728 0.006086 0.000000 - -0.009444 0.998941 -0.045029 0.000000 - -0.006518 0.044969 0.998967 0.000000 - - - - 0.353925 1.134289 -0.751691 0.000000 - - - - - - 0.999957 -0.000818 -0.009275 0.000000 - 0.000464 0.999274 -0.038108 0.000000 - 0.009299 0.038102 0.999231 0.000000 - - - - -1.136587 0.686161 0.199615 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 111 - 113 - 0 - 6 - -1 - -1 - 0 - -0.035771 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999881 -0.010253 0.011513 0.000000 - 0.010100 0.999861 0.013299 0.000000 - -0.011648 -0.013181 0.999845 0.000000 - - - - 0.638979 -0.155035 -1.375884 0.000000 - - - - - - 0.999995 -0.000321 -0.003271 0.000000 - 0.000286 0.999942 -0.010812 0.000000 - 0.003275 0.010811 0.999936 0.000000 - - - - -1.866807 -1.210397 -0.408328 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 115 - 133 - 0 - 6 - -1 - -1 - 0 - 1.096859 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999883 0.002853 0.015028 0.000000 - -0.003137 0.999816 0.018933 0.000000 - -0.014971 -0.018977 0.999708 0.000000 - - - - 0.412565 0.015143 -1.515353 0.000000 - - - - - - 0.999718 -0.001123 0.023733 0.000000 - 0.000721 0.999856 0.016954 0.000000 - -0.023748 -0.016932 0.999575 0.000000 - - - - 1.236128 -0.644280 -0.454261 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 153 - 11 - 0 - 6 - -1 - -1 - 0 - 0.139258 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999539 0.021759 -0.021153 0.000000 - -0.021494 0.999688 0.012695 0.000000 - 0.021422 -0.012235 0.999696 0.000000 - - - - -0.664246 -1.042966 0.120270 0.000000 - - - - - - 0.999916 0.003976 -0.012336 0.000000 - -0.003774 0.999860 0.016315 0.000000 - 0.012399 -0.016267 0.999791 0.000000 - - - - -1.032116 0.131022 -0.505006 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 135 - 77 - 0 - 6 - -1 - -1 - 0 - 0.075870 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999902 0.005280 0.012980 0.000000 - -0.005472 0.999875 0.014850 0.000000 - -0.012900 -0.014920 0.999805 0.000000 - - - - 1.180767 0.484837 0.495352 0.000000 - - - - - - 0.999982 0.004582 -0.003781 0.000000 - -0.004583 0.999990 -0.000191 0.000000 - 0.003780 0.000209 0.999993 0.000000 - - - - -0.194403 1.332391 -0.684163 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 111 - 67 - 0 - 6 - -1 - -1 - 0 - 0.023904 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999881 -0.010253 0.011513 0.000000 - 0.010100 0.999861 0.013299 0.000000 - -0.011648 -0.013181 0.999845 0.000000 - - - - -0.676625 -0.597386 -0.791770 0.000000 - - - - - - 0.999994 -0.001683 0.003030 0.000000 - 0.001713 0.999950 -0.009815 0.000000 - -0.003013 0.009820 0.999947 0.000000 - - - - 0.224800 -1.058920 0.495595 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 111 - 65 - 0 - 6 - -1 - -1 - 0 - 0.047915 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999881 -0.010253 0.011513 0.000000 - 0.010100 0.999861 0.013299 0.000000 - -0.011648 -0.013181 0.999845 0.000000 - - - - 0.534215 0.354962 -1.213605 0.000000 - - - - - - 0.999995 -0.003125 -0.001068 0.000000 - 0.003105 0.999820 -0.018705 0.000000 - 0.001127 0.018702 0.999824 0.000000 - - - - 0.956890 -0.469586 -1.271772 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 101 - 133 - 0 - 6 - -1 - -1 - 0 - -1.106969 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999288 -0.033392 0.017579 0.000000 - 0.033431 0.999439 -0.001954 0.000000 - -0.017504 0.002540 0.999844 0.000000 - - - - 0.498038 1.302521 -1.614984 0.000000 - - - - - - 0.999718 -0.001123 0.023733 0.000000 - 0.000721 0.999856 0.016954 0.000000 - -0.023748 -0.016932 0.999575 0.000000 - - - - -0.148963 0.081156 -1.856099 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 41 - 33 - 0 - 6 - -1 - -1 - 0 - -0.024351 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998429 0.054042 -0.014813 0.000000 - -0.054616 0.997641 -0.041583 0.000000 - 0.012531 0.042327 0.999025 0.000000 - - - - -0.602355 0.436298 -0.680222 0.000000 - - - - - - 0.999970 0.006829 0.003744 0.000000 - -0.006751 0.999767 -0.020524 0.000000 - -0.003883 0.020498 0.999782 0.000000 - - - - 0.336238 0.709238 0.159118 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 101 - 97 - 0 - 6 - -1 - -1 - 0 - -0.394603 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999288 -0.033392 0.017579 0.000000 - 0.033431 0.999439 -0.001954 0.000000 - -0.017504 0.002540 0.999844 0.000000 - - - - -0.910687 -0.564842 1.090239 0.000000 - - - - - - 0.999930 0.006370 -0.009993 0.000000 - -0.006493 0.999903 -0.012329 0.000000 - 0.009913 0.012393 0.999874 0.000000 - - - - 0.108746 -1.031685 -0.056167 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 151 - 137 - 0 - 6 - -1 - -1 - 0 - -0.000108 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999611 -0.006978 -0.027020 0.000000 - 0.006593 0.999876 -0.014328 0.000000 - 0.027117 0.014144 0.999532 0.000000 - - - - -1.467359 -0.847947 1.149774 0.000000 - - - - - - 0.999826 0.000774 -0.018626 0.000000 - -0.000697 0.999991 0.004161 0.000000 - 0.018629 -0.004147 0.999818 0.000000 - - - - -0.116462 -1.526084 -1.554153 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 73 - 125 - 0 - 6 - -1 - -1 - 0 - -0.640455 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999968 0.005839 -0.005517 0.000000 - -0.005731 0.999796 0.019373 0.000000 - 0.005629 -0.019340 0.999797 0.000000 - - - - 0.076073 -0.909683 1.153965 0.000000 - - - - - - 0.999702 0.024139 0.003589 0.000000 - -0.024185 0.999619 0.013316 0.000000 - -0.003267 -0.013399 0.999905 0.000000 - - - - 0.861644 -0.503119 -1.258545 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 15 - 127 - 0 - 6 - -1 - -1 - 0 - 0.003999 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998236 -0.059059 -0.006014 0.000000 - 0.059061 0.998254 0.000125 0.000000 - 0.005996 -0.000480 0.999982 0.000000 - - - - -0.350008 0.268479 1.228509 0.000000 - - - - - - 0.999957 -0.007775 -0.005052 0.000000 - 0.007807 0.999950 0.006300 0.000000 - 0.005003 -0.006339 0.999967 0.000000 - - - - -0.691931 -1.031878 1.125067 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 87 - 73 - 0 - 6 - -1 - -1 - 0 - -0.410369 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999411 0.029728 0.017152 0.000000 - -0.029961 0.999460 0.013502 0.000000 - -0.016741 -0.014008 0.999762 0.000000 - - - - -0.498200 0.618621 -1.134893 0.000000 - - - - - - 0.999968 0.005839 -0.005517 0.000000 - -0.005731 0.999796 0.019373 0.000000 - 0.005629 -0.019340 0.999797 0.000000 - - - - 0.053165 1.219834 1.288397 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 25 - 111 - 0 - 6 - -1 - -1 - 0 - 0.036186 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998354 0.056381 -0.010478 0.000000 - -0.055721 0.996921 0.055171 0.000000 - 0.013556 -0.054496 0.998422 0.000000 - - - - 0.918613 -0.963300 -0.545922 0.000000 - - - - - - 0.999881 -0.010253 0.011513 0.000000 - 0.010100 0.999861 0.013299 0.000000 - -0.011648 -0.013181 0.999845 0.000000 - - - - -0.760561 -0.550512 -0.427465 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 105 - 169 - 0 - 6 - -1 - -1 - 0 - 0.246104 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999169 -0.038782 0.012527 0.000000 - 0.038961 0.999138 -0.014362 0.000000 - -0.011959 0.014838 0.999818 0.000000 - - - - 0.652899 -0.348363 0.603762 0.000000 - - - - - - 0.999349 0.016561 0.032043 0.000000 - -0.017674 0.999239 0.034771 0.000000 - -0.031443 -0.035315 0.998881 0.000000 - - - - 0.861060 0.648370 -0.158040 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 71 - 19 - 0 - 6 - -1 - -1 - 0 - -0.342478 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999911 -0.006889 0.011396 0.000000 - 0.006776 0.999928 0.009948 0.000000 - -0.011463 -0.009870 0.999886 0.000000 - - - - -0.431657 1.608635 0.186081 0.000000 - - - - - - 0.999923 -0.009091 0.008416 0.000000 - 0.009090 0.999959 0.000161 0.000000 - -0.008417 -0.000085 0.999965 0.000000 - - - - -0.646625 1.282563 -1.411759 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 135 - 65 - 0 - 6 - -1 - -1 - 0 - -0.166824 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999902 0.005280 0.012980 0.000000 - -0.005472 0.999875 0.014850 0.000000 - -0.012900 -0.014920 0.999805 0.000000 - - - - -0.560084 -0.953440 0.200688 0.000000 - - - - - - 0.999995 -0.003125 -0.001068 0.000000 - 0.003105 0.999820 -0.018705 0.000000 - 0.001127 0.018702 0.999824 0.000000 - - - - 1.015613 -0.279369 -0.249187 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 173 - 61 - 0 - 6 - -1 - -1 - 0 - 2.371180 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999992 0.002393 0.003226 0.000000 - -0.002408 0.999986 0.004625 0.000000 - -0.003215 -0.004633 0.999984 0.000000 - - - - 0.417097 -0.665503 0.015037 0.000000 - - - - - - 0.999937 0.010877 -0.002591 0.000000 - -0.010890 0.999928 -0.005063 0.000000 - 0.002535 0.005091 0.999984 0.000000 - - - - 0.424694 0.839560 0.025363 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 5 - 169 - 0 - 6 - -1 - -1 - 0 - -0.226500 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999762 -0.021698 0.002428 0.000000 - 0.021622 0.999380 0.027802 0.000000 - -0.003030 -0.027743 0.999610 0.000000 - - - - -0.752462 0.404144 -0.218184 0.000000 - - - - - - 0.999349 0.016561 0.032043 0.000000 - -0.017674 0.999239 0.034771 0.000000 - -0.031443 -0.035315 0.998881 0.000000 - - - - 0.557696 -0.728009 -0.359226 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 5 - 81 - 0 - 6 - -1 - -1 - 0 - -0.743296 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999762 -0.021698 0.002428 0.000000 - 0.021622 0.999380 0.027802 0.000000 - -0.003030 -0.027743 0.999610 0.000000 - - - - -0.306596 -0.179920 -1.347529 0.000000 - - - - - - 0.999441 0.030294 0.014130 0.000000 - -0.029616 0.998506 -0.045917 0.000000 - -0.015500 0.045473 0.998845 0.000000 - - - - 0.827304 -0.765847 -0.336876 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 91 - 123 - 0 - 6 - -1 - -1 - 0 - 1.714060 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999958 -0.005185 0.007504 0.000000 - 0.005025 0.999761 0.021277 0.000000 - -0.007613 -0.021238 0.999745 0.000000 - - - - 0.177877 1.136742 0.360921 0.000000 - - - - - - 0.999990 -0.004234 -0.001164 0.000000 - 0.004202 0.999636 -0.026654 0.000000 - 0.001276 0.026649 0.999644 0.000000 - - - - -0.032812 1.009118 -0.666950 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 13 - 93 - 0 - 6 - -1 - -1 - 0 - 0.000474 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999677 0.005076 -0.024895 0.000000 - -0.004682 0.999863 0.015851 0.000000 - 0.024972 -0.015729 0.999564 0.000000 - - - - -0.880761 -0.066487 -0.499819 0.000000 - - - - - - 0.998425 -0.056040 -0.002472 0.000000 - 0.056087 0.998042 0.027673 0.000000 - 0.000916 -0.027768 0.999614 0.000000 - - - - -0.257100 0.799081 -0.771685 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 123 - 85 - 0 - 6 - -1 - -1 - 0 - -0.834739 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999990 -0.004234 -0.001164 0.000000 - 0.004202 0.999636 -0.026654 0.000000 - 0.001276 0.026649 0.999644 0.000000 - - - - 0.533919 0.370623 0.493564 0.000000 - - - - - - 0.999851 0.008368 0.015124 0.000000 - -0.008493 0.999930 0.008240 0.000000 - -0.015054 -0.008368 0.999852 0.000000 - - - - 1.025450 -0.185496 -0.223309 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 85 - 31 - 0 - 6 - -1 - -1 - 0 - 0.137636 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999851 0.008368 0.015124 0.000000 - -0.008493 0.999930 0.008240 0.000000 - -0.015054 -0.008368 0.999852 0.000000 - - - - -0.431496 -0.772591 0.153700 0.000000 - - - - - - 0.999995 -0.002508 -0.002061 0.000000 - 0.002560 0.999667 0.025681 0.000000 - 0.001996 -0.025686 0.999668 0.000000 - - - - 0.869588 0.437810 0.198101 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 35 - 73 - 0 - 6 - -1 - -1 - 0 - -0.903984 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999975 0.007121 0.000055 0.000000 - -0.007121 0.999960 0.005419 0.000000 - -0.000017 -0.005419 0.999985 0.000000 - - - - -0.259993 -0.770097 -1.092074 0.000000 - - - - - - 0.999968 0.005839 -0.005517 0.000000 - -0.005731 0.999796 0.019373 0.000000 - 0.005629 -0.019340 0.999797 0.000000 - - - - -0.775571 0.444842 -1.179768 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 91 - 5 - 0 - 6 - -1 - -1 - 0 - -1.642532 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999958 -0.005185 0.007504 0.000000 - 0.005025 0.999761 0.021277 0.000000 - -0.007613 -0.021238 0.999745 0.000000 - - - - -0.295292 -0.989206 -0.495621 0.000000 - - - - - - 0.999762 -0.021698 0.002428 0.000000 - 0.021622 0.999380 0.027802 0.000000 - -0.003030 -0.027743 0.999610 0.000000 - - - - -0.041721 -0.095044 -1.188069 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 171 - 65 - 0 - 6 - -1 - -1 - 0 - -0.039558 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999656 0.025923 -0.004058 0.000000 - -0.025802 0.999291 0.027434 0.000000 - 0.004767 -0.027320 0.999615 0.000000 - - - - -1.044801 -0.411434 0.531493 0.000000 - - - - - - 0.999995 -0.003125 -0.001068 0.000000 - 0.003105 0.999820 -0.018705 0.000000 - 0.001127 0.018702 0.999824 0.000000 - - - - 0.398721 -0.102370 1.332800 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 27 - 55 - 0 - 6 - -1 - -1 - 0 - -0.042197 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999927 -0.007291 -0.009620 0.000000 - 0.007299 0.999973 0.000787 0.000000 - 0.009614 -0.000857 0.999953 0.000000 - - - - 0.848515 0.635854 -0.521518 0.000000 - - - - - - 0.999287 0.033006 -0.018307 0.000000 - -0.033254 0.999357 -0.013383 0.000000 - 0.017854 0.013982 0.999743 0.000000 - - - - -0.949702 0.501865 0.654394 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 139 - 47 - 0 - 6 - -1 - -1 - 0 - 0.088238 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999603 -0.012740 -0.025112 0.000000 - 0.011063 0.997769 -0.065836 0.000000 - 0.025895 0.065532 0.997514 0.000000 - - - - -0.974469 0.315338 -0.860540 0.000000 - - - - - - 0.999510 0.018154 -0.025483 0.000000 - -0.017908 0.999791 0.009873 0.000000 - 0.025657 -0.009412 0.999627 0.000000 - - - - 1.002713 -0.209325 -0.311700 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 133 - 157 - 0 - 6 - -1 - -1 - 0 - 0.003812 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999726 0.000607 0.023384 0.000000 - -0.000968 0.999880 0.015435 0.000000 - -0.023372 -0.015454 0.999607 0.000000 - - - - -0.692457 0.741643 1.716321 0.000000 - - - - - - 0.998795 0.020783 0.044467 0.000000 - -0.019886 0.999591 -0.020539 0.000000 - -0.044875 0.019630 0.998800 0.000000 - - - - -0.496974 1.280787 -1.096491 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 123 - 145 - 0 - 6 - -1 - -1 - 0 - 1.290125 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999994 -0.002886 -0.001801 0.000000 - 0.002836 0.999622 -0.027332 0.000000 - 0.001879 0.027327 0.999625 0.000000 - - - - 0.643378 0.381964 0.456922 0.000000 - - - - - - 0.999939 0.010625 -0.003000 0.000000 - -0.010740 0.999091 -0.041248 0.000000 - 0.002559 0.041278 0.999144 0.000000 - - - - -0.657001 -0.138330 0.833549 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 173 - 47 - 0 - 6 - -1 - -1 - 0 - -0.022925 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999989 0.003857 0.002800 0.000000 - -0.003870 0.999982 0.004549 0.000000 - -0.002782 -0.004560 0.999986 0.000000 - - - - -0.506900 0.861696 0.806145 0.000000 - - - - - - 0.999510 0.018154 -0.025483 0.000000 - -0.017908 0.999791 0.009873 0.000000 - 0.025657 -0.009412 0.999627 0.000000 - - - - -0.602095 0.309121 -0.757164 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 63 - 45 - 0 - 6 - -1 - -1 - 0 - -0.018773 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999652 -0.018125 0.019165 0.000000 - 0.018687 0.999389 -0.029527 0.000000 - -0.018618 0.029875 0.999380 0.000000 - - - - -1.053370 -0.135942 0.423892 0.000000 - - - - - - 0.999679 -0.025107 -0.003287 0.000000 - 0.025070 0.999628 -0.010782 0.000000 - 0.003556 0.010696 0.999936 0.000000 - - - - -0.004460 -0.411844 0.798038 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 67 - 45 - 0 - 6 - -1 - -1 - 0 - 0.018657 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999996 0.000089 0.002806 0.000000 - -0.000060 0.999947 -0.010302 0.000000 - -0.002806 0.010302 0.999943 0.000000 - - - - -1.035719 0.934667 0.515754 0.000000 - - - - - - 0.999679 -0.025107 -0.003287 0.000000 - 0.025070 0.999628 -0.010782 0.000000 - 0.003556 0.010696 0.999936 0.000000 - - - - -0.104925 -0.520005 -0.459737 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 173 - 33 - 0 - 6 - -1 - -1 - 0 - 0.000680 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999989 0.003857 0.002800 0.000000 - -0.003870 0.999982 0.004549 0.000000 - -0.002782 -0.004560 0.999986 0.000000 - - - - 1.042834 0.183749 1.036114 0.000000 - - - - - - 0.999956 0.008606 0.003609 0.000000 - -0.008528 0.999742 -0.021062 0.000000 - -0.003789 0.021030 0.999772 0.000000 - - - - 0.590740 0.581877 -0.678716 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 53 - 149 - 0 - 6 - -1 - -1 - 0 - -0.976079 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999978 -0.003666 -0.005578 0.000000 - 0.003549 0.999775 -0.020924 0.000000 - 0.005654 0.020904 0.999766 0.000000 - - - - 1.426453 1.328977 0.330063 0.000000 - - - - - - 0.999926 -0.011917 -0.002602 0.000000 - 0.011892 0.999886 -0.009354 0.000000 - 0.002714 0.009322 0.999953 0.000000 - - - - 1.803313 0.040098 -0.091152 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 155 - 99 - 0 - 6 - -1 - -1 - 0 - 0.138542 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999480 0.016230 0.027865 0.000000 - -0.015115 0.999095 -0.039754 0.000000 - -0.028485 0.039312 0.998821 0.000000 - - - - 1.653289 -0.494682 0.618810 0.000000 - - - - - - 0.999848 -0.012318 -0.012339 0.000000 - 0.012378 0.999912 0.004782 0.000000 - 0.012279 -0.004934 0.999912 0.000000 - - - - 1.310703 -0.621363 -0.984140 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 33 - 47 - 0 - 6 - -1 - -1 - 0 - -0.065432 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999956 0.008606 0.003609 0.000000 - -0.008528 0.999742 -0.021062 0.000000 - -0.003789 0.021030 0.999772 0.000000 - - - - -0.725962 0.755379 0.359052 0.000000 - - - - - - 0.999510 0.018154 -0.025483 0.000000 - -0.017908 0.999791 0.009873 0.000000 - 0.025657 -0.009412 0.999627 0.000000 - - - - -0.413559 -0.171502 0.513204 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 113 - 139 - 0 - 6 - -1 - -1 - 0 - 0.224433 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999994 0.001269 -0.003301 0.000000 - -0.001308 0.999932 -0.011618 0.000000 - 0.003286 0.011622 0.999927 0.000000 - - - - -1.508416 0.093455 -0.933949 0.000000 - - - - - - 0.999603 -0.012740 -0.025112 0.000000 - 0.011063 0.997769 -0.065836 0.000000 - 0.025895 0.065532 0.997514 0.000000 - - - - 0.330823 -0.752074 -0.564528 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 87 - 125 - 0 - 6 - -1 - -1 - 0 - 1.796692 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999392 0.030344 0.017156 0.000000 - -0.030577 0.999442 0.013467 0.000000 - -0.016738 -0.013984 0.999762 0.000000 - - - - -0.216676 -1.226292 -1.074611 0.000000 - - - - - - 0.999674 0.025470 0.001886 0.000000 - -0.025480 0.999662 0.005088 0.000000 - -0.001755 -0.005134 0.999985 0.000000 - - - - 1.171028 -0.221550 -1.044196 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 137 - 15 - 0 - 6 - -1 - -1 - 0 - 0.004222 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999817 0.002760 -0.018943 0.000000 - -0.002700 0.999991 0.003190 0.000000 - 0.018952 -0.003139 0.999815 0.000000 - - - - 0.286095 -1.551816 -1.191771 0.000000 - - - - - - 0.998349 -0.057092 -0.006238 0.000000 - 0.057088 0.998369 -0.000868 0.000000 - 0.006278 0.000511 0.999980 0.000000 - - - - -1.387041 -0.650972 0.238991 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 25 - 67 - 0 - 6 - -1 - -1 - 0 - -0.036246 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998257 0.058057 -0.010605 0.000000 - -0.057397 0.996860 0.054544 0.000000 - 0.013738 -0.053841 0.998455 0.000000 - - - - 0.854138 -1.017775 -0.823246 0.000000 - - - - - - 0.999996 0.000089 0.002806 0.000000 - -0.000060 0.999947 -0.010302 0.000000 - -0.002806 0.010302 0.999943 0.000000 - - - - 0.072217 -1.059843 0.581106 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 59 - 125 - 0 - 6 - -1 - -1 - 0 - 0.459085 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999340 0.031378 -0.018317 0.000000 - -0.031738 0.999302 -0.019702 0.000000 - 0.017686 0.020270 0.999638 0.000000 - - - - 1.010491 -0.503666 -0.328882 0.000000 - - - - - - 0.999674 0.025470 0.001886 0.000000 - -0.025480 0.999662 0.005088 0.000000 - -0.001755 -0.005134 0.999985 0.000000 - - - - 0.472327 0.521937 0.923435 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 67 - 143 - 0 - 6 - -1 - -1 - 0 - 0.414236 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999996 0.000089 0.002806 0.000000 - -0.000060 0.999947 -0.010302 0.000000 - -0.002806 0.010302 0.999943 0.000000 - - - - -0.441509 -1.028411 -0.056791 0.000000 - - - - - - 0.999816 0.008327 0.017292 0.000000 - -0.008141 0.999908 -0.010816 0.000000 - -0.017381 0.010673 0.999792 0.000000 - - - - 0.507258 -0.486087 0.869517 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 59 - 121 - 0 - 6 - -1 - -1 - 0 - -0.458958 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999340 0.031378 -0.018317 0.000000 - -0.031738 0.999302 -0.019702 0.000000 - 0.017686 0.020270 0.999638 0.000000 - - - - -0.068167 -0.817373 1.016800 0.000000 - - - - - - 0.999998 -0.000484 -0.002106 0.000000 - 0.000489 0.999997 0.002340 0.000000 - 0.002104 -0.002341 0.999995 0.000000 - - - - -0.035808 -0.840368 0.291712 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 153 - 55 - 0 - 6 - -1 - -1 - 0 - 0.604775 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999485 0.023126 -0.022233 0.000000 - -0.022914 0.999690 0.009765 0.000000 - 0.022451 -0.009250 0.999705 0.000000 - - - - -0.784411 1.066980 0.390953 0.000000 - - - - - - 0.999287 0.033006 -0.018307 0.000000 - -0.033254 0.999357 -0.013383 0.000000 - 0.017854 0.013982 0.999743 0.000000 - - - - 1.213310 0.500232 -1.009990 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 23 - 137 - 0 - 6 - -1 - -1 - 0 - 0.039629 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999869 0.016193 0.000128 0.000000 - -0.016183 0.999448 -0.029020 0.000000 - -0.000598 0.029015 0.999579 0.000000 - - - - 0.634799 -1.533541 -1.499307 0.000000 - - - - - - 0.999817 0.002760 -0.018943 0.000000 - -0.002700 0.999991 0.003190 0.000000 - 0.018952 -0.003139 0.999815 0.000000 - - - - -0.543082 -1.440917 -1.526497 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 85 - 55 - 0 - 6 - -1 - -1 - 0 - -0.996048 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999847 0.009780 0.014486 0.000000 - -0.009888 0.999924 0.007382 0.000000 - -0.014413 -0.007524 0.999868 0.000000 - - - - -0.798323 0.967909 0.349607 0.000000 - - - - - - 0.999287 0.033006 -0.018307 0.000000 - -0.033254 0.999357 -0.013383 0.000000 - 0.017854 0.013982 0.999743 0.000000 - - - - -0.299313 0.245975 1.199606 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 105 - 55 - 0 - 6 - -1 - -1 - 0 - -0.128150 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999235 -0.037225 0.012002 0.000000 - 0.037422 0.999160 -0.016677 0.000000 - -0.011371 0.017113 0.999789 0.000000 - - - - -0.691672 0.405592 0.723570 0.000000 - - - - - - 0.999287 0.033006 -0.018307 0.000000 - -0.033254 0.999357 -0.013383 0.000000 - 0.017854 0.013982 0.999743 0.000000 - - - - -1.220983 0.331820 -0.122910 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 57 - 17 - 0 - 6 - -1 - -1 - 0 - 0.020521 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999055 0.009567 -0.042389 0.000000 - -0.009401 0.999947 0.004098 0.000000 - 0.042426 -0.003696 0.999093 0.000000 - - - - 1.518001 -0.341384 -0.762734 0.000000 - - - - - - 0.999997 -0.001474 -0.001951 0.000000 - 0.001433 0.999775 -0.021174 0.000000 - 0.001982 0.021171 0.999774 0.000000 - - - - 0.384535 -1.510486 -0.131125 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 69 - 29 - 0 - 6 - -1 - -1 - 0 - 1.608307 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999826 0.000238 -0.018625 0.000000 - -0.000886 0.999395 -0.034779 0.000000 - 0.018605 0.034790 0.999221 0.000000 - - - - -0.549585 0.572513 -1.341193 0.000000 - - - - - - 0.999122 0.024040 -0.034307 0.000000 - -0.022760 0.999047 0.037239 0.000000 - 0.035169 -0.036426 0.998717 0.000000 - - - - -1.003116 0.637012 -1.126825 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 79 - 89 - 0 - 6 - -1 - -1 - 0 - 0.213800 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999720 -0.018640 0.014590 0.000000 - 0.018153 0.999296 0.032820 0.000000 - -0.015192 -0.032546 0.999355 0.000000 - - - - 0.275675 1.078840 -0.317842 0.000000 - - - - - - 0.998037 -0.056356 0.027333 0.000000 - 0.056880 0.998204 -0.018783 0.000000 - -0.026225 0.020301 0.999450 0.000000 - - - - 0.160671 -0.092306 -0.767547 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 79 - 9 - 0 - 6 - -1 - -1 - 0 - -1.311379 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999720 -0.018640 0.014590 0.000000 - 0.018153 0.999296 0.032820 0.000000 - -0.015192 -0.032546 0.999355 0.000000 - - - - -0.394871 0.722561 -0.817239 0.000000 - - - - - - 0.999737 0.022915 -0.001317 0.000000 - -0.022916 0.999737 -0.000521 0.000000 - 0.001305 0.000551 0.999999 0.000000 - - - - 0.043577 -0.613353 0.541286 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 121 - 79 - 0 - 6 - -1 - -1 - 0 - -0.480381 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999998 -0.000190 -0.002053 0.000000 - 0.000197 0.999994 0.003537 0.000000 - 0.002052 -0.003537 0.999992 0.000000 - - - - 0.067992 -0.697016 0.595567 0.000000 - - - - - - 0.999720 -0.018640 0.014590 0.000000 - 0.018153 0.999296 0.032820 0.000000 - -0.015192 -0.032546 0.999355 0.000000 - - - - -1.084769 -0.158835 0.027893 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 123 - 55 - 0 - 6 - -1 - -1 - 0 - 0.559885 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999994 -0.002760 -0.002020 0.000000 - 0.002705 0.999637 -0.026810 0.000000 - 0.002093 0.026805 0.999638 0.000000 - - - - -0.834968 0.769494 -0.279048 0.000000 - - - - - - 0.999278 0.033193 -0.018458 0.000000 - -0.033448 0.999347 -0.013654 0.000000 - 0.017993 0.014262 0.999736 0.000000 - - - - 0.174020 -0.500104 -0.136622 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 67 - 89 - 0 - 6 - -1 - -1 - 0 - -0.214666 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999996 0.000931 0.002529 0.000000 - -0.000904 0.999945 -0.010481 0.000000 - -0.002539 0.010479 0.999942 0.000000 - - - - -1.184629 0.855819 0.449632 0.000000 - - - - - - 0.998037 -0.056356 0.027333 0.000000 - 0.056880 0.998204 -0.018783 0.000000 - -0.026225 0.020301 0.999450 0.000000 - - - - 0.560713 -0.503984 0.067069 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 159 - 7 - 0 - 6 - -1 - -1 - 0 - 0.476677 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999677 0.025179 -0.003513 0.000000 - -0.025210 0.999639 -0.009304 0.000000 - 0.003277 0.009389 0.999951 0.000000 - - - - -1.031419 -0.198710 0.163638 0.000000 - - - - - - 0.999657 -0.006302 -0.025418 0.000000 - 0.005793 0.999782 -0.020059 0.000000 - 0.025539 0.019905 0.999476 0.000000 - - - - 0.547859 -0.668573 -0.407400 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 33 - 139 - 0 - 6 - -1 - -1 - 0 - -0.136029 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999950 0.009457 0.003363 0.000000 - -0.009384 0.999730 -0.021252 0.000000 - -0.003563 0.021220 0.999768 0.000000 - - - - 1.236913 -0.226451 -0.551620 0.000000 - - - - - - 0.999607 -0.011977 -0.025333 0.000000 - 0.010283 0.997768 -0.065982 0.000000 - 0.026067 0.065695 0.997499 0.000000 - - - - -0.382169 -0.654208 -0.931227 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 67 - 79 - 0 - 6 - -1 - -1 - 0 - -0.826043 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999996 0.000974 0.002457 0.000000 - -0.000947 0.999938 -0.011058 0.000000 - -0.002468 0.011055 0.999936 0.000000 - - - - -1.505095 0.542423 0.900927 0.000000 - - - - - - 0.999717 -0.018723 0.014667 0.000000 - 0.018233 0.999294 0.032850 0.000000 - -0.015272 -0.032574 0.999353 0.000000 - - - - 0.340514 0.396384 1.011295 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 163 - 97 - 0 - 6 - -1 - -1 - 0 - 0.970185 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.997605 0.062113 -0.030440 0.000000 - -0.058457 0.992320 0.109011 0.000000 - 0.036977 -0.106970 0.993574 0.000000 - - - - 1.476443 0.486329 0.913734 0.000000 - - - - - - 0.999910 0.008640 -0.010282 0.000000 - -0.008786 0.999860 -0.014238 0.000000 - 0.010158 0.014327 0.999846 0.000000 - - - - -1.182305 0.021136 -0.893970 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 159 - 37 - 0 - 6 - -1 - -1 - 0 - 0.266430 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999704 0.024114 -0.003331 0.000000 - -0.024143 0.999671 -0.008677 0.000000 - 0.003121 0.008755 0.999957 0.000000 - - - - 0.000383 0.217391 0.660933 0.000000 - - - - - - 0.999871 0.013062 -0.009312 0.000000 - -0.012995 0.999890 0.007150 0.000000 - 0.009404 -0.007028 0.999931 0.000000 - - - - -0.705906 -1.085847 0.679040 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 143 - 61 - 0 - 6 - -1 - -1 - 0 - 0.188686 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999826 0.007522 0.017041 0.000000 - -0.007393 0.999944 -0.007605 0.000000 - -0.017097 0.007477 0.999826 0.000000 - - - - 0.225340 -0.211301 -0.771730 0.000000 - - - - - - 0.999874 0.015442 -0.003740 0.000000 - -0.015468 0.999855 -0.007127 0.000000 - 0.003629 0.007183 0.999968 0.000000 - - - - -0.204876 -0.630318 0.438494 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 63 - 135 - 0 - 6 - -1 - -1 - 0 - 0.029585 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999649 -0.018581 0.018902 0.000000 - 0.019148 0.999359 -0.030263 0.000000 - -0.018327 0.030614 0.999363 0.000000 - - - - 0.560866 0.853232 0.509590 0.000000 - - - - - - 0.999897 0.007362 0.012319 0.000000 - -0.007525 0.999884 0.013219 0.000000 - -0.012221 -0.013311 0.999837 0.000000 - - - - -1.342288 0.980490 0.900231 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 57 - 11 - 0 - 6 - -1 - -1 - 0 - -0.449149 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999049 0.008960 -0.042662 0.000000 - -0.008848 0.999957 0.002812 0.000000 - 0.042685 -0.002432 0.999086 0.000000 - - - - -0.991636 0.441656 1.038285 0.000000 - - - - - - 0.999897 0.005133 -0.013414 0.000000 - -0.004951 0.999896 0.013546 0.000000 - 0.013482 -0.013479 0.999818 0.000000 - - - - 0.862090 -0.070671 0.825420 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 57 - 145 - 0 - 6 - -1 - -1 - 0 - 0.656874 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999050 0.008719 -0.042702 0.000000 - -0.008611 0.999959 0.002706 0.000000 - 0.042724 -0.002335 0.999084 0.000000 - - - - -0.840727 0.586269 1.087485 0.000000 - - - - - - 0.999958 0.008634 -0.003026 0.000000 - -0.008756 0.999047 -0.042765 0.000000 - 0.002654 0.042789 0.999081 0.000000 - - - - 1.078610 -0.895109 0.204945 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 159 - 39 - 0 - 6 - -1 - -1 - 0 - -0.014030 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999721 0.023373 -0.003271 0.000000 - -0.023400 0.999690 -0.008475 0.000000 - 0.003071 0.008550 0.999959 0.000000 - - - - -0.633000 0.660746 -0.496322 0.000000 - - - - - - 0.999930 0.009915 -0.006511 0.000000 - -0.009995 0.999874 -0.012334 0.000000 - 0.006388 0.012398 0.999903 0.000000 - - - - 0.423656 -0.657524 -0.853168 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 31 - 51 - 0 - 6 - -1 - -1 - 0 - 0.272670 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999987 -0.004228 -0.002975 0.000000 - 0.004302 0.999667 0.025433 0.000000 - 0.002867 -0.025445 0.999672 0.000000 - - - - 1.010839 -0.391663 0.631610 0.000000 - - - - - - 0.997428 0.069505 0.017479 0.000000 - -0.070065 0.996972 0.033730 0.000000 - -0.015081 -0.034868 0.999278 0.000000 - - - - -0.677447 -0.408883 -0.381499 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 11 - 145 - 0 - 6 - -1 - -1 - 0 - -0.327312 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999903 0.003826 -0.013390 0.000000 - -0.003636 0.999893 0.014160 0.000000 - 0.013442 -0.014109 0.999810 0.000000 - - - - 0.450811 1.150341 -0.303628 0.000000 - - - - - - 0.999966 0.007632 -0.003111 0.000000 - -0.007759 0.999037 -0.043180 0.000000 - 0.002778 0.043203 0.999062 0.000000 - - - - 0.508511 0.249434 -0.899110 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 93 - 95 - 0 - 6 - -1 - -1 - 0 - 0.228531 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.998301 -0.058241 -0.001840 0.000000 - 0.058269 0.997981 0.025274 0.000000 - 0.000364 -0.025339 0.999679 0.000000 - - - - -0.077853 -0.699305 -1.383325 0.000000 - - - - - - 0.999460 0.027820 -0.017473 0.000000 - -0.028941 0.997294 -0.067582 0.000000 - 0.015545 0.068051 0.997561 0.000000 - - - - -0.557222 -0.587851 1.100715 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 5 - 51 - 0 - 6 - -1 - -1 - 0 - -0.121320 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.999704 -0.024277 0.001611 0.000000 - 0.024235 0.999453 0.022485 0.000000 - -0.002156 -0.022440 0.999746 0.000000 - - - - -0.031808 -0.020050 1.339074 0.000000 - - - - - - 0.997428 0.069505 0.017479 0.000000 - -0.070065 0.996972 0.033730 0.000000 - -0.015081 -0.034868 0.999278 0.000000 - - - - -0.408879 -0.482817 -0.699488 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 51 - 13 - 0 - 6 - -1 - -1 - 0 - 0.151669 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.997418 0.069685 0.017351 0.000000 - -0.070246 0.996946 0.034118 0.000000 - -0.014920 -0.035249 0.999267 0.000000 - - - - -0.846216 0.300711 0.466160 0.000000 - - - - - - 0.999694 0.003390 -0.024494 0.000000 - -0.003026 0.999885 0.014888 0.000000 - 0.024542 -0.014810 0.999589 0.000000 - - - - 0.790366 -0.405384 0.724201 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 57 - 163 - 0 - 6 - -1 - -1 - 0 - -0.039658 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.371027 0.917910 -0.140645 0.000000 - -0.399368 0.020991 -0.916551 0.000000 - -0.838358 0.396234 0.374372 0.000000 - - - - 0.214166 0.225124 0.783153 0.000000 - - - - - - 0.337445 0.924316 -0.178245 0.000000 - -0.501924 0.016481 -0.864755 0.000000 - -0.796369 0.381273 0.469498 0.000000 - - - - -0.774225 -0.357658 -0.276467 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 109 - 113 - 0 - 6 - -1 - -1 - 0 - -0.084688 - 0.300000 - 1 - 100 - 45.000000 - 1 - - - - - 0.331731 0.937140 -0.108269 0.000000 - -0.373095 0.024918 -0.927459 0.000000 - -0.866461 0.348062 0.357908 0.000000 - - - - 0.115618 -1.142983 -0.887744 0.000000 - - - - - - 0.339873 0.933090 -0.117597 0.000000 - -0.382533 0.022927 -0.923658 0.000000 - -0.859160 0.358911 0.364730 0.000000 - - - - 1.807837 -1.587922 0.609291 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 1 - 1 - - - - 0 - 28 - 0 0 0 0 - - - 0.000000 0.000000 0.000000 0.000000 - - - 0.000000 1.000000 0.000000 0.000000 - - 0.000000 - 0 0 0 0 - - - - 0 - 31 - 0 0 0 0 - - 315 - 1 - 0.000000 - - - - - - 0.737321 -0.000198 -0.675542 0.000000 - 0.097020 0.989664 0.105602 0.000000 - 0.668539 -0.143404 0.729720 0.000000 - - - - -0.074712 -0.143958 0.022858 0.000000 - - - 316 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 317 - 0 - 42 - 0 0 0 0 - - - 0.596313 -0.309567 1.106486 0.000000 - 0.643806 -0.177254 0.154638 0.000000 - 0.831410 -0.111997 1.007067 0.000000 - 0.423118 -0.382422 1.138688 0.000000 - 0.150360 -0.364670 0.035505 0.000000 - 0.089922 -0.518111 1.205917 0.000000 - -0.065866 -0.529368 1.207362 0.000000 - -0.378625 -0.386715 -0.076780 0.000000 - -0.445276 -0.552009 1.217677 0.000000 - -0.550605 -0.527907 1.203142 0.000000 - -0.643938 -0.442624 0.842944 0.000000 - -0.891385 -0.241135 -0.171223 0.000000 - -0.871448 -0.287719 0.015864 0.000000 - -0.920838 -0.231840 -0.195754 0.000000 - -1.080077 0.054311 -0.869217 0.000000 - -1.098567 0.076301 -0.851978 0.000000 - -1.075426 0.079097 -0.896598 0.000000 - -0.747485 -0.100814 -0.991281 0.000000 - -0.531135 -0.203898 -1.081084 0.000000 - -0.237642 -0.264237 -1.169412 0.000000 - 0.099648 -0.328022 -1.275779 0.000000 - 0.282612 -0.317081 -1.315009 0.000000 - 0.437516 -0.317272 -1.348398 0.000000 - 0.626668 -0.308415 -1.242323 0.000000 - 0.725284 -0.269717 -1.155176 0.000000 - 1.036329 -0.138061 -0.892418 0.000000 - 1.058200 0.070749 0.027147 0.000000 - 1.146224 -0.027736 -0.746670 0.000000 - 1.202566 0.018216 -0.681935 0.000000 - 1.012291 0.091243 0.263587 0.000000 - 0.858097 -0.091489 0.997485 0.000000 - 1.015917 0.069825 0.561513 0.000000 - -1.057152 0.124347 -0.849862 0.000000 - -0.588774 0.532716 0.321014 0.000000 - -0.491743 0.619486 0.232160 0.000000 - -0.964025 0.211063 -0.835323 0.000000 - -0.500202 0.338036 0.751803 0.000000 - 0.029345 0.625646 0.615315 0.000000 - -0.062352 0.681505 0.446670 0.000000 - 0.924138 0.155257 -0.706661 0.000000 - 0.246133 0.002639 -1.183328 0.000000 - 0.763646 0.183583 0.840469 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 318 - 1 - 0.000000 - - - - - - 0.499110 -0.493079 0.712575 0.000000 - 0.604727 0.787168 0.121126 0.000000 - -0.620641 0.370458 0.691061 0.000000 - - - - 0.089376 0.104299 -0.078941 0.000000 - - - 319 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.831410 -0.111997 1.007067 0.000000 - - 0.040000 - 0 - - 320 - 0 - 32 - 0 0 0 0 - - - 0.410384 -0.291683 -0.422583 0.000000 - -0.146526 0.204817 -0.657320 0.000000 - 0.401662 -0.101049 -0.427067 0.000000 - -0.312712 -1.072996 -0.211322 0.000000 - -0.301037 -1.013021 -0.256365 0.000000 - -0.280210 -1.045215 -0.231604 0.000000 - -0.299865 -0.860814 -0.333081 0.000000 - -0.081437 -0.971186 -0.265043 0.000000 - -0.302923 -0.334494 -0.592421 0.000000 - 0.281833 -0.840598 -0.319615 0.000000 - 0.402071 -0.793700 -0.310932 0.000000 - -0.302138 -0.291562 -0.602830 0.000000 - 0.400089 -0.699885 -0.327678 0.000000 - -0.300214 -0.046996 -0.660726 0.000000 - -0.289753 0.302915 -0.678564 0.000000 - -0.294456 0.355784 -0.676432 0.000000 - -0.286270 0.878632 -0.562647 0.000000 - 0.159255 0.626722 -0.509626 0.000000 - -0.282738 0.971590 -0.546108 0.000000 - -0.294065 0.959934 -0.553997 0.000000 - -0.310502 0.956176 -0.546933 0.000000 - 0.331063 0.856657 -0.332182 0.000000 - 0.379740 0.492353 -0.408213 0.000000 - 0.361112 0.855564 -0.315227 0.000000 - 0.388935 0.416179 -0.423057 0.000000 - -0.253115 0.538029 0.782402 0.000000 - -0.244842 0.555385 0.803444 0.000000 - -0.242751 0.540194 0.816696 0.000000 - -0.305532 -0.994030 0.179649 0.000000 - 0.232044 -0.695319 0.519626 0.000000 - 0.121245 0.501817 0.939261 0.000000 - -0.258828 0.525195 0.777583 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 321 - 1 - 0.000000 - - - - - - 0.961986 -0.038364 0.270391 0.000000 - 0.099073 0.971660 -0.214618 0.000000 - -0.254494 0.233248 0.938524 0.000000 - - - - 0.197784 0.147631 0.070011 0.000000 - - - 322 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.402071 -0.793700 -0.310932 0.000000 - - 0.040000 - 0 - - 323 - 0 - 35 - 0 0 0 0 - - - 0.072488 0.292632 -1.317285 0.000000 - -0.022874 0.592725 0.512022 0.000000 - 0.481618 0.584783 0.315911 0.000000 - 0.119963 0.291453 -1.329191 0.000000 - -0.402954 0.282573 -1.215855 0.000000 - -0.462269 0.265744 -1.184262 0.000000 - -0.494933 0.435279 0.725359 0.000000 - -0.871796 0.129517 -0.982222 0.000000 - -1.001108 0.036240 -0.870254 0.000000 - -0.914152 0.091316 -0.445417 0.000000 - -0.948729 0.073766 -0.911174 0.000000 - -0.689950 0.298907 0.834273 0.000000 - -0.407252 0.455154 0.969429 0.000000 - -0.642434 0.290991 1.045011 0.000000 - -0.353105 0.490766 0.958187 0.000000 - 0.091857 0.637451 0.860874 0.000000 - 0.185402 0.665258 0.845027 0.000000 - 0.530930 0.643942 0.585995 0.000000 - 0.381991 0.674682 0.810246 0.000000 - 0.579489 0.635245 0.514021 0.000000 - 0.822559 0.469336 0.162319 0.000000 - 0.591319 0.171601 -1.312346 0.000000 - 0.820254 0.478071 0.160854 0.000000 - 0.602482 0.172085 -1.321233 0.000000 - 0.184474 -0.661480 -0.445488 0.000000 - 0.293513 -0.869981 0.136834 0.000000 - -0.335577 -0.647084 0.459345 0.000000 - -0.966679 0.001816 -0.820019 0.000000 - 0.500563 -0.242168 -0.901465 0.000000 - 0.418675 -0.818617 0.202325 0.000000 - 0.264394 -0.221569 0.970405 0.000000 - -0.414372 -0.167564 1.081723 0.000000 - 0.531432 -0.550742 0.538466 0.000000 - 0.631008 -0.209819 0.580920 0.000000 - 0.393338 -0.028316 0.913643 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 324 - 1 - 0.000000 - - - - - - 0.747553 0.454401 -0.484443 0.000000 - -0.169682 0.835810 0.522139 0.000000 - 0.642163 -0.308125 0.701916 0.000000 - - - - -0.065133 -0.040087 -0.017158 0.000000 - - - 325 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.481618 0.584783 0.315911 0.000000 - - 0.040000 - 0 - - 326 - 0 - 39 - 0 0 0 0 - - - -0.022812 -0.844826 -0.904981 0.000000 - -0.004545 -0.837416 -0.897980 0.000000 - 0.126167 -0.856493 -0.745248 0.000000 - 0.032309 -0.965994 -0.569593 0.000000 - -0.121244 -0.969102 -0.699102 0.000000 - 0.168920 -0.864897 -0.696896 0.000000 - 0.495179 -0.747109 -0.360836 0.000000 - 0.396296 -0.834006 -0.191573 0.000000 - 0.541746 -0.727914 -0.317078 0.000000 - 0.827435 -0.456875 -0.070349 0.000000 - 0.653225 -0.572473 0.206293 0.000000 - 0.905384 -0.380840 -0.008586 0.000000 - 1.213429 0.105673 0.171303 0.000000 - 0.861436 -0.194963 0.447960 0.000000 - 1.102831 -0.057057 0.123691 0.000000 - 0.772408 -0.266654 0.522845 0.000000 - 0.573509 -0.612860 0.779051 0.000000 - 0.530352 -0.714906 0.692592 0.000000 - 0.474164 -0.858053 0.581661 0.000000 - 0.309231 -1.024483 0.347799 0.000000 - 0.355206 -0.990911 0.456376 0.000000 - 0.238919 -1.084627 0.154403 0.000000 - -0.010663 -1.146148 -0.191940 0.000000 - -0.093528 -1.166744 -0.301615 0.000000 - -0.252390 -1.170646 -0.422473 0.000000 - -0.054475 1.345767 -0.277811 0.000000 - 0.874494 0.734852 0.003788 0.000000 - 1.164669 0.501073 0.005933 0.000000 - 0.806737 0.612274 -0.397654 0.000000 - -0.140870 1.417651 -0.279713 0.000000 - -0.077231 1.395026 0.120023 0.000000 - -0.664740 0.201212 0.952238 0.000000 - -0.712390 0.574783 -0.573177 0.000000 - -1.054371 -0.205300 0.155014 0.000000 - -0.775000 0.459809 -0.611802 0.000000 - -1.064406 -0.217065 0.140009 0.000000 - -0.435366 -0.006186 0.939490 0.000000 - -0.538975 -0.956918 -0.153960 0.000000 - 0.039522 -0.886270 0.435089 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 327 - 1 - 0.000000 - - - - - - 0.728556 -0.436749 0.527690 0.000000 - 0.683375 0.516242 -0.516229 0.000000 - -0.046954 0.736712 0.674574 0.000000 - - - - 0.234213 -0.012225 -0.237108 0.000000 - - - 328 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.126167 -0.856493 -0.745248 0.000000 - - 0.040000 - 0 - - 329 - 0 - 26 - 0 0 0 0 - - - -0.249704 -0.586694 1.038860 0.000000 - -0.212097 -0.590698 1.040961 0.000000 - -0.224462 -0.497632 1.049651 0.000000 - -0.233574 -0.592160 1.039131 0.000000 - -0.230562 -0.550755 1.035753 0.000000 - -0.227830 -0.480073 1.049466 0.000000 - 0.142967 0.483213 1.150505 0.000000 - 0.125713 0.480541 1.164587 0.000000 - 0.115695 0.489935 1.142920 0.000000 - -0.052507 0.474350 1.271099 0.000000 - -0.008301 0.248330 1.179300 0.000000 - -0.049945 0.518983 1.290845 0.000000 - -0.225766 -0.441146 1.049085 0.000000 - -0.152542 -0.338777 1.040126 0.000000 - 0.578306 0.116731 -1.072736 0.000000 - 0.712743 0.143241 -0.921227 0.000000 - 0.607236 -0.016820 -0.982974 0.000000 - 0.512924 0.063280 -1.114486 0.000000 - 0.768596 0.303741 0.170359 0.000000 - 0.297529 -0.552953 0.316760 0.000000 - 0.426291 -0.357225 -0.587797 0.000000 - -0.292565 -0.037558 -1.147663 0.000000 - -0.464113 0.186177 -0.972360 0.000000 - -0.317455 -0.033122 -1.142580 0.000000 - -0.858239 0.030396 -0.796152 0.000000 - -0.813362 0.253130 -0.739476 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 330 - 1 - 0.000000 - - - - - - 0.819801 -0.395231 0.414390 0.000000 - 0.078724 0.794551 0.602072 0.000000 - -0.567212 -0.460957 0.682488 0.000000 - - - - -0.164444 -0.053678 -0.029805 0.000000 - - - 331 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - -0.008301 0.248330 1.179300 0.000000 - - 0.040000 - 0 - - 332 - 0 - 35 - 0 0 0 0 - - - -0.838835 -0.335560 0.968081 0.000000 - -0.900231 -0.418889 0.784926 0.000000 - 0.660936 -0.319713 0.481776 0.000000 - -0.318237 -0.311157 0.837381 0.000000 - -0.943584 -0.445233 0.618130 0.000000 - 0.504457 -0.397544 -0.030751 0.000000 - -1.041692 -0.496189 0.266098 0.000000 - -1.068753 -0.469685 0.109274 0.000000 - 0.325966 -0.307600 -0.533932 0.000000 - -1.139169 -0.402216 -0.255887 0.000000 - -1.046948 0.002858 -0.890883 0.000000 - -1.176697 -0.022363 -0.853741 0.000000 - -1.188264 0.028638 -0.913991 0.000000 - -0.292307 -0.126541 -0.868619 0.000000 - -1.183270 -0.146076 -0.730737 0.000000 - -0.097789 -0.148950 -0.847233 0.000000 - -1.150027 -0.328068 -0.397508 0.000000 - 0.185765 -0.181383 -0.816098 0.000000 - 0.633829 -0.220064 -0.751005 0.000000 - 0.803826 -0.226333 -0.728650 0.000000 - 1.232373 -0.193782 -0.588524 0.000000 - 1.548316 -0.163189 -0.488908 0.000000 - 1.765561 -0.091394 -0.354719 0.000000 - 2.005334 0.005697 -0.142536 0.000000 - 1.910449 -0.043788 -0.265710 0.000000 - 1.730707 0.031243 0.208917 0.000000 - 2.067529 0.090444 0.006800 0.000000 - 2.094359 0.110454 0.059536 0.000000 - 2.085881 0.116583 0.081784 0.000000 - 0.697276 -0.276455 0.608629 0.000000 - -0.438373 0.833122 0.188403 0.000000 - -0.980885 0.371680 -0.460290 0.000000 - -0.718668 0.613059 0.369079 0.000000 - 1.969284 0.113278 -0.014365 0.000000 - 1.256720 0.390482 0.096433 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 333 - 1 - 0.000000 - - - - - - 0.919658 0.024893 -0.391930 0.000000 - 0.182755 0.856216 0.483214 0.000000 - 0.347605 -0.516019 0.782876 0.000000 - - - - 0.081378 0.250998 -0.138542 0.000000 - - - 334 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 1.765561 -0.091394 -0.354719 0.000000 - - 0.040000 - 0 - - 335 - 0 - 45 - 0 0 0 0 - - - -0.905591 1.085954 -0.329751 0.000000 - 0.772413 0.962819 -0.815490 0.000000 - -0.612763 0.904455 -0.681011 0.000000 - -1.341478 1.245149 0.216855 0.000000 - -1.370582 1.223408 0.194309 0.000000 - -1.360537 1.234686 0.261273 0.000000 - 0.569831 0.512615 1.306878 0.000000 - 0.539956 0.568212 1.285468 0.000000 - 0.547653 0.578372 1.274587 0.000000 - 0.539520 0.639112 1.197901 0.000000 - 0.385020 0.699279 1.179960 0.000000 - 0.548479 0.910185 0.852451 0.000000 - 0.034416 0.950114 0.982318 0.000000 - 0.560991 0.943540 0.759017 0.000000 - -0.368353 1.101061 0.751281 0.000000 - 0.631771 1.098259 0.306833 0.000000 - -0.592088 1.178041 0.629515 0.000000 - 0.645986 1.100642 0.244087 0.000000 - -1.243901 1.242112 0.258964 0.000000 - 0.781722 1.113668 -0.297624 0.000000 - -1.269762 1.239667 0.251355 0.000000 - 0.783409 1.112138 -0.305127 0.000000 - -1.020337 1.123779 -0.180305 0.000000 - 0.811987 1.089488 -0.392653 0.000000 - 0.856364 0.973603 -0.783216 0.000000 - 0.904851 0.996527 -0.677906 0.000000 - 0.845737 0.967444 -0.808646 0.000000 - 0.656856 0.767934 -1.147639 0.000000 - 0.598883 0.697747 -1.247072 0.000000 - -0.388254 0.757393 -0.956428 0.000000 - 0.595622 0.700043 -1.247532 0.000000 - -0.226888 0.597363 -1.133648 0.000000 - 0.111025 0.207949 -1.503598 0.000000 - 0.342077 0.257149 -1.556253 0.000000 - 0.229209 -0.055964 -1.653649 0.000000 - 0.047925 0.304673 -1.445027 0.000000 - 0.358591 0.286515 -1.545565 0.000000 - 1.008512 -0.550796 0.757363 0.000000 - 0.778659 -0.298028 1.443483 0.000000 - -0.558342 -1.254844 0.691743 0.000000 - 0.209110 -1.563367 -0.551456 0.000000 - -1.116206 -0.730147 0.369149 0.000000 - -1.016754 -1.066245 0.330725 0.000000 - -1.029452 -1.067330 0.418921 0.000000 - 0.041044 -1.496372 -1.068261 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 336 - 1 - 0.000000 - - - - - - 0.530805 0.632459 0.564129 0.000000 - -0.581363 0.756069 -0.300627 0.000000 - -0.616655 -0.168390 0.769014 0.000000 - - - - -0.042381 0.288483 0.147835 0.000000 - - - 337 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - -0.612763 0.904455 -0.681011 0.000000 - - 0.040000 - 0 - - 338 - 0 - 64 - 0 0 0 0 - - - 0.067742 0.614521 -1.807078 0.000000 - 0.058145 0.579170 -1.807656 0.000000 - 0.081315 0.611910 -1.798810 0.000000 - 0.000677 0.441834 -1.816566 0.000000 - -1.136187 0.272400 0.063542 0.000000 - 0.032415 0.844738 -1.529120 0.000000 - -0.004395 0.439362 -1.814491 0.000000 - -1.180055 -0.267324 0.064113 0.000000 - -0.123189 -0.111188 -1.691315 0.000000 - -0.129784 -0.185122 -1.653621 0.000000 - -1.070628 -0.792870 0.135631 0.000000 - -0.138130 -0.658336 -1.421795 0.000000 - 0.602283 -1.792770 0.170117 0.000000 - 0.618022 -1.786751 0.149875 0.000000 - 0.266350 -1.770968 0.215472 0.000000 - 0.438803 -1.755706 -0.060574 0.000000 - 0.138518 -1.742832 0.260242 0.000000 - 0.319667 -1.660930 -0.268029 0.000000 - -0.151241 -1.683233 0.356161 0.000000 - -0.357199 -1.594713 0.286550 0.000000 - 0.157071 -1.523885 -0.564409 0.000000 - -0.380220 -1.576996 0.280600 0.000000 - 0.041439 -1.311278 -0.828139 0.000000 - -0.799769 -1.248970 0.209001 0.000000 - -0.041727 -1.145463 -1.033553 0.000000 - -0.800745 -1.247844 0.207497 0.000000 - -0.115142 -0.796250 -1.311188 0.000000 - -0.858290 -1.174411 0.211325 0.000000 - -1.110417 -0.790874 0.251095 0.000000 - -1.126215 -0.764269 0.259586 0.000000 - -1.290206 -0.278773 0.407073 0.000000 - -1.317537 -0.193808 0.438989 0.000000 - -1.305070 0.217277 0.516601 0.000000 - -1.329803 -0.031292 0.512076 0.000000 - -1.326800 0.130272 0.554476 0.000000 - -1.279383 0.326351 0.468783 0.000000 - -1.063478 0.747482 0.385196 0.000000 - -0.943379 0.773407 0.133951 0.000000 - -1.031066 0.810479 0.375526 0.000000 - -0.710795 1.181516 0.426151 0.000000 - -0.620589 1.186641 0.268407 0.000000 - -0.679022 1.218088 0.434566 0.000000 - -0.299899 1.480570 0.615484 0.000000 - -0.199490 1.471696 0.453712 0.000000 - -0.278427 1.499645 0.622866 0.000000 - -0.275123 1.498555 0.624233 0.000000 - 0.077679 1.550048 0.549979 0.000000 - 0.425994 1.626017 0.275395 0.000000 - 0.295812 1.567526 -0.003211 0.000000 - 0.132464 1.570540 0.522198 0.000000 - 0.198198 1.525905 -0.229293 0.000000 - 0.130530 1.416040 -0.499135 0.000000 - 0.047844 1.268527 -0.861603 0.000000 - 0.039824 1.172333 -1.016727 0.000000 - 0.024553 0.884544 -1.483214 0.000000 - 1.362316 0.025138 0.458217 0.000000 - 1.391814 -0.115812 0.370119 0.000000 - 0.781498 0.533932 -0.770093 0.000000 - 0.811746 1.179605 0.228606 0.000000 - -0.165785 1.068714 1.027354 0.000000 - -0.201009 0.466143 1.402669 0.000000 - 0.187913 -0.023863 1.381222 0.000000 - -1.278330 0.117882 0.602969 0.000000 - 0.190660 -1.281242 0.747143 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 339 - 1 - 0.000000 - - - - - - 0.982456 0.020968 0.185312 0.000000 - 0.010904 0.985502 -0.169316 0.000000 - -0.186175 0.168366 0.967983 0.000000 - - - - -0.185187 0.007059 0.060775 0.000000 - - - 340 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - -1.110417 -0.790874 0.251095 0.000000 - - 0.040000 - 0 - - 341 - 0 - 24 - 0 0 0 0 - - - -0.137758 -0.545029 -0.530415 0.000000 - -0.392292 -0.494327 -0.359440 0.000000 - -0.119579 -0.473242 -0.564437 0.000000 - -0.794579 -0.212278 -0.178904 0.000000 - -0.064762 -0.283993 -0.669716 0.000000 - -0.824116 -0.429000 -0.084139 0.000000 - -0.761597 -0.064285 -0.199468 0.000000 - 0.131194 0.100433 -0.791804 0.000000 - -0.680362 0.325083 -0.242895 0.000000 - 0.171524 0.186000 -0.818187 0.000000 - 0.178711 0.181401 -0.828878 0.000000 - 0.177418 0.197450 -0.824325 0.000000 - -0.627766 0.480442 -0.214916 0.000000 - -0.306044 0.500301 -0.402022 0.000000 - -0.569314 0.697320 -0.166838 0.000000 - -0.365284 0.387573 0.563555 0.000000 - -0.067261 0.779914 0.491815 0.000000 - -0.567313 0.694537 -0.167826 0.000000 - 1.193845 0.205441 0.124108 0.000000 - -0.543830 -0.367646 0.604430 0.000000 - -0.471569 -0.492462 0.584267 0.000000 - 0.625885 -0.694403 0.275877 0.000000 - 1.192557 0.169848 0.123098 0.000000 - -0.584045 -0.475939 0.587582 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 342 - 1 - 0.000000 - - - - - - 0.930531 0.247449 -0.269964 0.000000 - -0.317436 0.912601 -0.257671 0.000000 - 0.182609 0.325467 0.927753 0.000000 - - - - -0.067546 -0.072300 -0.147572 0.000000 - - - 343 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 344 - 0 - 55 - 0 0 0 0 - - - -0.589175 -1.681216 -0.026649 0.000000 - 0.622146 -1.552234 -1.114926 0.000000 - -0.325464 -1.712240 0.440229 0.000000 - -0.588194 -1.681474 -0.024965 0.000000 - -0.778786 -1.510182 -0.429829 0.000000 - -0.157427 -1.532325 -0.734341 0.000000 - -0.582683 -1.685705 -0.023038 0.000000 - 0.528499 -1.563314 -1.076542 0.000000 - 0.609699 -1.578101 -1.073618 0.000000 - 0.626630 -1.580517 -1.075327 0.000000 - 0.621743 -1.574369 -1.079746 0.000000 - 0.833847 -1.601727 -1.075196 0.000000 - 0.796654 -1.585065 -0.934152 0.000000 - 0.720810 -1.625968 -0.526065 0.000000 - 0.669690 -1.605643 -0.278770 0.000000 - -0.051958 -1.583488 0.889158 0.000000 - 0.560422 -1.541519 0.321837 0.000000 - 0.382728 -1.018645 1.425591 0.000000 - 0.233476 -1.310434 1.250354 0.000000 - 0.421455 -1.291051 1.058200 0.000000 - 0.234953 -1.312063 1.248880 0.000000 - 0.454438 -1.354897 0.875893 0.000000 - 0.156642 -1.385360 1.168042 0.000000 - -0.088185 -1.611074 0.913546 0.000000 - -0.102445 -1.617852 0.904768 0.000000 - -0.428196 -1.742037 0.549171 0.000000 - -0.416095 -1.745433 0.577901 0.000000 - -0.436854 -1.749164 0.502167 0.000000 - 0.364414 1.087661 1.350821 0.000000 - 0.365757 1.091566 1.364830 0.000000 - 0.384857 0.998929 1.413931 0.000000 - 0.384909 1.175386 1.258777 0.000000 - 0.333517 1.154089 1.336514 0.000000 - 0.336462 1.161510 1.332712 0.000000 - 0.464479 1.428211 0.820902 0.000000 - 0.164881 1.445534 1.028258 0.000000 - 0.514364 1.563687 0.574164 0.000000 - 0.124094 1.510482 0.959129 0.000000 - 0.579591 1.674026 0.215222 0.000000 - -0.103476 1.676056 0.622100 0.000000 - 0.669837 1.809876 -0.247049 0.000000 - -0.163855 1.716569 0.537681 0.000000 - 0.701558 1.826957 -0.422140 0.000000 - -0.433089 1.746542 0.196194 0.000000 - 0.427207 1.846154 -0.674949 0.000000 - -0.501966 1.752096 0.113651 0.000000 - 0.755425 1.858850 -0.657234 0.000000 - 0.250349 1.807633 -0.688835 0.000000 - -0.796469 1.638165 -0.209584 0.000000 - -0.383333 1.669415 -0.645800 0.000000 - -0.856993 1.613633 -0.271282 0.000000 - -0.198856 1.701392 -0.737480 0.000000 - -0.973063 1.519535 -0.361555 0.000000 - -1.199485 0.325709 -0.242378 0.000000 - -1.199692 -0.609640 -0.235665 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 345 - 1 - 0.000000 - - - - - - 0.779733 -0.449930 -0.435406 0.000000 - 0.186959 0.831001 -0.523911 0.000000 - 0.597547 0.327108 0.732078 0.000000 - - - - 0.152066 -0.033652 -0.085371 0.000000 - - - 346 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 347 - 0 - 39 - 0 0 0 0 - - - -0.678987 0.950257 -0.004246 0.000000 - -0.723739 0.928023 0.002351 0.000000 - -0.842150 0.679654 0.091838 0.000000 - -0.085393 0.448462 0.301492 0.000000 - 0.016743 0.937829 0.093149 0.000000 - -0.623377 0.968589 -0.004370 0.000000 - -0.921804 0.519193 0.149229 0.000000 - -1.013530 0.185026 0.172006 0.000000 - -0.181771 -0.082624 0.345611 0.000000 - -1.070066 -0.010470 0.181675 0.000000 - -1.071637 -0.056811 0.187948 0.000000 - -0.973966 -0.353476 0.150379 0.000000 - -0.262946 -0.603359 0.221219 0.000000 - -0.915306 -0.534265 0.126836 0.000000 - -0.574565 -0.971686 -0.029474 0.000000 - -0.320969 -1.062716 -0.059432 0.000000 - -0.523576 -1.037867 -0.054490 0.000000 - -0.301452 -1.199726 -0.160903 0.000000 - 0.113226 -1.266457 -0.145075 0.000000 - -0.044699 -1.387033 -0.297808 0.000000 - 0.216271 -1.203223 -0.054173 0.000000 - 0.441939 -0.958155 0.115435 0.000000 - 0.574658 -0.818196 0.208392 0.000000 - 0.723482 -0.553548 0.273045 0.000000 - 0.844323 -0.345486 0.320493 0.000000 - 0.924811 -0.073240 0.296959 0.000000 - 1.000211 0.169726 0.272575 0.000000 - 0.855562 0.500854 0.168560 0.000000 - 1.000503 0.205573 0.265232 0.000000 - 0.742765 0.733131 0.095077 0.000000 - 0.080273 1.133654 -0.056768 0.000000 - 0.636348 0.864103 0.026069 0.000000 - 0.237313 1.144394 -0.094870 0.000000 - -0.391857 1.021474 -0.013494 0.000000 - 0.124240 0.440167 -0.461686 0.000000 - -0.017631 0.775251 -0.399957 0.000000 - 0.207261 -0.277685 -0.472078 0.000000 - -0.679019 0.895345 -0.036482 0.000000 - -0.674231 0.892256 -0.040329 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 348 - 1 - 0.000000 - - - - - - 0.864969 -0.375837 -0.332528 0.000000 - 0.442403 0.883880 0.151777 0.000000 - 0.236871 -0.278394 0.930800 0.000000 - - - - -0.008220 0.154810 -0.080662 0.000000 - - - 349 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 350 - 0 - 48 - 0 0 0 0 - - - 0.367213 0.148594 1.615108 0.000000 - 0.728751 0.302705 -0.336181 0.000000 - -0.149120 0.311165 1.617608 0.000000 - 1.139599 -0.022407 -0.200441 0.000000 - 0.242805 0.478229 -0.497682 0.000000 - -0.944674 0.274399 0.411716 0.000000 - -0.800202 0.311926 0.640390 0.000000 - -0.270680 0.486888 -0.669141 0.000000 - -0.701809 0.368814 -0.817876 0.000000 - -0.556540 0.380274 1.038423 0.000000 - -0.468864 0.372451 1.154210 0.000000 - -0.142225 0.341866 1.587671 0.000000 - -0.103506 0.335237 1.631650 0.000000 - -0.100985 0.326332 1.643176 0.000000 - 0.331774 0.164050 1.729523 0.000000 - 0.131486 0.212627 1.894735 0.000000 - 0.364427 0.157615 1.705929 0.000000 - 0.495180 0.089092 1.571802 0.000000 - 1.066541 0.009438 0.083025 0.000000 - 0.620628 0.040819 1.453516 0.000000 - 1.145972 0.005019 -0.199272 0.000000 - 1.162076 0.005911 -0.223981 0.000000 - 1.159161 -0.017216 -0.217251 0.000000 - 1.154873 -0.009767 -0.225897 0.000000 - 0.880113 0.263330 -0.518966 0.000000 - 0.839221 0.302458 -0.567503 0.000000 - 0.553457 0.424447 -0.869416 0.000000 - 0.464812 0.459904 -0.968814 0.000000 - 0.192228 0.458669 -1.202212 0.000000 - 0.268664 0.460065 -1.170504 0.000000 - 0.028714 0.459158 -1.269780 0.000000 - -0.653121 0.349698 -0.978629 0.000000 - -0.461034 0.297749 -1.448044 0.000000 - -0.505347 0.271872 -1.471375 0.000000 - -0.681393 0.361966 -0.883241 0.000000 - -0.309348 0.349792 -1.390633 0.000000 - 0.542870 -0.371357 -0.858684 0.000000 - 0.634069 -0.349370 -0.768210 0.000000 - -0.254698 -0.752137 -0.475346 0.000000 - -0.203351 -0.670420 -0.833507 0.000000 - -0.228225 -0.665934 -0.830626 0.000000 - -0.200935 -0.673472 -0.830074 0.000000 - 0.356900 -0.198761 -1.048574 0.000000 - -0.263250 -0.430430 -1.042565 0.000000 - 0.144197 -0.152625 -1.139141 0.000000 - -0.510137 0.293268 -1.467469 0.000000 - 0.143527 -0.152366 1.627247 0.000000 - -0.474328 -0.708844 0.374591 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 351 - 1 - 0.000000 - - - - - - 0.739048 -0.645267 0.193488 0.000000 - 0.641477 0.586392 -0.494623 0.000000 - 0.205704 0.489668 0.847296 0.000000 - - - - -0.124277 -0.023173 0.170248 0.000000 - - - 352 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 353 - 0 - 48 - 0 0 0 0 - - - 0.310740 0.173688 -1.427836 0.000000 - 0.301504 0.196937 -1.411331 0.000000 - 0.044736 -0.183332 -1.698743 0.000000 - -0.403801 0.247752 -1.754959 0.000000 - 0.310589 0.173968 -1.427606 0.000000 - 0.312311 0.170235 -1.432035 0.000000 - 0.786542 0.250579 1.030478 0.000000 - 0.749602 0.252288 1.032364 0.000000 - 0.530442 0.310772 1.103972 0.000000 - 1.265245 0.094259 0.915635 0.000000 - 1.070183 0.204192 0.872194 0.000000 - 1.356999 0.045825 0.885360 0.000000 - 1.167832 0.182622 0.732024 0.000000 - 1.500589 0.061683 0.469560 0.000000 - 1.378757 0.139413 0.411338 0.000000 - 1.425505 0.012925 0.867270 0.000000 - 1.507434 0.051160 0.385635 0.000000 - 1.371228 0.129659 0.234009 0.000000 - 1.541470 0.027422 0.053130 0.000000 - 1.518725 0.033428 -0.069547 0.000000 - 1.347312 0.112042 -0.164073 0.000000 - 1.416996 0.032901 -0.265866 0.000000 - 1.151233 0.116368 -0.508072 0.000000 - 1.199793 0.017302 -0.683715 0.000000 - 0.977696 0.124612 -0.798916 0.000000 - 0.878889 -0.025162 -1.047996 0.000000 - 0.704468 -0.052461 -1.244501 0.000000 - 0.101343 -0.164999 -1.680452 0.000000 - 0.080782 -0.169414 -1.695011 0.000000 - 0.004266 -0.185581 -1.727811 0.000000 - -0.488317 0.230507 -1.786013 0.000000 - -0.486126 0.220293 -1.784639 0.000000 - 0.008097 -0.184651 -1.731731 0.000000 - -0.521790 0.280427 -1.789951 0.000000 - -0.207104 0.438369 1.224314 0.000000 - -0.200260 0.385594 1.261435 0.000000 - -0.213820 0.409690 1.239112 0.000000 - -0.134194 0.399099 1.224648 0.000000 - -0.823245 0.384976 1.174485 0.000000 - -0.731372 0.440952 1.313073 0.000000 - -0.680994 0.471689 1.328272 0.000000 - -0.821139 0.443082 0.830387 0.000000 - -0.897150 0.405217 -0.333533 0.000000 - -1.006110 0.068798 0.716692 0.000000 - -0.728798 -0.621059 0.450526 0.000000 - -0.364004 -0.563509 0.880516 0.000000 - -0.660224 -0.558163 0.071638 0.000000 - 1.399200 -0.071769 0.833307 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 354 - 1 - 0.000000 - - - - - - 0.900044 0.292528 -0.323028 0.000000 - -0.268001 0.956036 0.119044 0.000000 - 0.343650 -0.020573 0.938872 0.000000 - - - - 0.089682 -0.043406 -0.115440 0.000000 - - - 355 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 356 - 0 - 34 - 0 0 0 0 - - - 1.086981 -0.108901 0.530724 0.000000 - 1.092456 -0.100113 0.524267 0.000000 - 1.204011 -0.100275 0.082502 0.000000 - 1.216415 -0.091105 0.073867 0.000000 - 1.061298 -0.141051 0.548676 0.000000 - 0.884996 -0.461846 0.373327 0.000000 - 1.021122 -0.379231 0.078440 0.000000 - 0.841265 -0.503608 0.345795 0.000000 - 0.883440 -0.501543 0.045681 0.000000 - 0.513185 -0.800225 0.165475 0.000000 - 0.606088 -0.743616 -0.030415 0.000000 - 0.451220 -0.827505 0.143265 0.000000 - 0.472942 -0.800858 -0.086505 0.000000 - 0.026950 -1.005994 0.010090 0.000000 - 0.142197 -0.938077 -0.236247 0.000000 - 0.033253 -0.943587 -0.290070 0.000000 - -0.033683 -1.012441 -0.001534 0.000000 - -0.415280 -1.050627 -0.040138 0.000000 - 0.040952 -0.944491 -0.296411 0.000000 - -0.976315 0.769998 0.196800 0.000000 - -0.958188 0.784896 0.216957 0.000000 - -0.973784 0.788619 0.162836 0.000000 - 0.316278 0.842509 -0.300423 0.000000 - -0.027504 1.087879 -0.025507 0.000000 - 0.714170 0.604680 0.163373 0.000000 - 0.861004 0.481852 -0.073676 0.000000 - 1.079172 0.195468 -0.117920 0.000000 - 0.418572 0.423209 -0.601001 0.000000 - -1.075786 0.032172 -0.174645 0.000000 - -1.148976 0.146783 -0.085874 0.000000 - -0.020288 -0.037661 -0.688980 0.000000 - -1.183380 0.015807 -0.125330 0.000000 - -1.166252 -0.560474 0.113515 0.000000 - -0.936595 0.188994 0.480457 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 357 - 1 - 0.000000 - - - - - - 0.888870 0.064878 0.453542 0.000000 - -0.268007 0.876514 0.399869 0.000000 - -0.371593 -0.476984 0.796495 0.000000 - - - - -0.143654 0.052339 -0.171384 0.000000 - - - 358 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 359 - 0 - 36 - 0 0 0 0 - - - 1.187243 0.019130 -0.351717 0.000000 - 1.282576 -0.056208 -0.104277 0.000000 - 1.180459 -0.087498 -0.459568 0.000000 - 1.034073 0.373494 -0.056431 0.000000 - 1.069783 0.376232 0.141309 0.000000 - 1.008755 0.428900 -0.012864 0.000000 - 0.720331 0.716060 0.249294 0.000000 - 0.711490 0.719803 0.246073 0.000000 - 0.703251 0.718574 0.156737 0.000000 - 0.697880 0.729064 0.156381 0.000000 - 0.935285 0.511907 0.214585 0.000000 - 1.109265 0.378253 0.181932 0.000000 - 1.129668 0.361517 0.182798 0.000000 - 1.448681 -0.018517 0.173042 0.000000 - 1.540971 -0.129544 0.176462 0.000000 - 1.333197 -0.328612 -0.231476 0.000000 - 1.583823 -0.207402 0.181146 0.000000 - 1.631535 -0.281671 0.182320 0.000000 - 1.179415 -0.152520 -0.529054 0.000000 - 1.267509 -0.346214 -0.463971 0.000000 - -1.116167 0.387351 -0.353853 0.000000 - -0.815099 0.523657 -0.649009 0.000000 - -0.774750 0.289625 -0.880800 0.000000 - -1.159987 0.198644 -0.442763 0.000000 - -0.281502 -0.042556 -1.015794 0.000000 - 0.000282 -0.493305 -0.837839 0.000000 - -1.083275 -0.564602 0.184617 0.000000 - -1.048609 -0.555738 0.299706 0.000000 - -0.920149 0.274062 0.413812 0.000000 - -0.562492 -0.467994 0.874497 0.000000 - 0.071592 -0.401081 0.820363 0.000000 - -0.438872 -0.257916 1.001974 0.000000 - -0.441326 -0.187810 0.993439 0.000000 - -0.582116 0.273338 0.815449 0.000000 - 0.126496 0.479737 0.676944 0.000000 - 0.134916 0.482792 0.672993 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 360 - 1 - 0.000000 - - - - - - 0.815991 0.396335 -0.420806 0.000000 - -0.281474 0.908245 0.309617 0.000000 - 0.504907 -0.134199 0.852678 0.000000 - - - - 0.063921 0.174658 -0.301427 0.000000 - - - 361 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 362 - 0 - 57 - 0 0 0 0 - - - 1.292580 -0.115704 0.009470 0.000000 - 0.974122 -0.285433 -1.507742 0.000000 - 0.744918 0.171449 -1.330760 0.000000 - 0.956607 0.224854 0.262013 0.000000 - 0.380450 0.526946 -1.147946 0.000000 - 0.536850 0.420917 0.541426 0.000000 - -0.083697 0.746285 -0.977165 0.000000 - 0.074319 0.453253 0.820400 0.000000 - -0.602182 0.807959 -0.835121 0.000000 - -0.385756 0.318609 1.071640 0.000000 - 1.051911 -0.280325 -1.315669 0.000000 - 1.308896 -0.121441 -0.025152 0.000000 - 0.988113 -0.308404 -1.535603 0.000000 - 1.008096 -0.319606 -1.681336 0.000000 - 0.998576 -0.279923 -1.672951 0.000000 - 0.984966 -0.209834 -1.677387 0.000000 - 0.797147 0.179019 -1.616773 0.000000 - 0.745341 0.280812 -1.603805 0.000000 - 0.467931 0.558497 -1.485869 0.000000 - 0.377633 0.646412 -1.450918 0.000000 - 0.014921 0.809628 -1.277358 0.000000 - -0.083519 0.852582 -1.233115 0.000000 - -0.531822 0.876351 -1.001438 0.000000 - -0.594738 0.878943 -0.970911 0.000000 - -0.907888 0.755625 -0.733545 0.000000 - -0.796814 0.818777 -0.855896 0.000000 - -1.045216 0.691382 -0.571286 0.000000 - -1.065892 0.672111 -0.541139 0.000000 - -0.798334 0.030069 1.270533 0.000000 - -1.307643 0.338300 -0.015336 0.000000 - -1.226961 0.522056 -0.354918 0.000000 - -1.412855 -0.218606 0.727936 0.000000 - -1.347150 -0.212395 0.832119 0.000000 - -1.405229 -0.204596 0.693008 0.000000 - -1.195771 -0.191193 1.044187 0.000000 - -1.351749 0.089292 0.317046 0.000000 - -1.013899 -0.164241 1.303339 0.000000 - -0.987963 -0.157637 1.308225 0.000000 - -0.719712 0.027371 1.393309 0.000000 - -0.674874 0.049246 1.409343 0.000000 - -0.162188 0.253703 1.490315 0.000000 - -0.002252 0.310390 1.518627 0.000000 - 0.400666 0.377104 1.526753 0.000000 - 0.684432 0.418160 1.536481 0.000000 - 0.938493 0.398201 1.504649 0.000000 - 1.276271 0.365664 1.460806 0.000000 - 1.269883 0.374821 1.464324 0.000000 - 1.365162 0.316487 1.346818 0.000000 - 1.600548 0.180653 1.057031 0.000000 - 1.674734 0.070846 0.917121 0.000000 - 1.416240 -0.074612 0.186077 0.000000 - 1.688425 0.070463 0.901666 0.000000 - 0.124827 -0.548140 0.981170 0.000000 - 1.242119 -0.075159 1.173470 0.000000 - -0.494108 -0.896256 -0.766273 0.000000 - -0.971111 0.297295 -0.690120 0.000000 - -0.451181 -0.889747 -0.862521 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 363 - 1 - 0.000000 - - - - - - 0.785128 -0.081658 0.613927 0.000000 - 0.298411 0.918494 -0.259458 0.000000 - -0.542701 0.386911 0.745503 0.000000 - - - - -0.216586 0.091476 0.004375 0.000000 - - - 364 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 365 - 0 - 38 - 0 0 0 0 - - - 1.195942 0.549982 0.304843 0.000000 - 0.239964 0.504323 -0.422600 0.000000 - 0.181247 0.895236 -0.052628 0.000000 - 0.997960 0.760891 0.381421 0.000000 - 1.430483 0.300799 0.221726 0.000000 - 1.450415 0.164075 0.160962 0.000000 - 0.230527 0.021489 -0.667568 0.000000 - 1.484562 0.228170 0.207222 0.000000 - 1.318951 -0.126407 -0.067262 0.000000 - 1.139842 -0.384197 -0.201322 0.000000 - 0.153839 -0.505966 -0.763472 0.000000 - 0.981585 -0.617242 -0.315812 0.000000 - 0.836927 -0.779382 -0.357367 0.000000 - 0.141973 -0.568063 -0.764562 0.000000 - -0.277533 -0.489293 -0.855172 0.000000 - -0.270327 -0.491854 -0.848462 0.000000 - -0.243402 -0.399464 -0.858042 0.000000 - -0.211930 0.043006 -0.787086 0.000000 - -0.208924 0.146419 -0.769906 0.000000 - -0.283485 0.543212 -0.598528 0.000000 - -0.311770 0.664885 -0.545312 0.000000 - -0.465347 0.967434 -0.312897 0.000000 - -0.541858 1.104750 -0.206451 0.000000 - -0.361260 1.218351 0.147178 0.000000 - -0.730441 1.288714 0.035284 0.000000 - -0.744688 1.304793 0.053327 0.000000 - -0.736647 1.329441 0.086846 0.000000 - 0.102133 1.085102 0.225580 0.000000 - 0.688517 0.885159 0.331115 0.000000 - 0.969431 0.790572 0.381531 0.000000 - -1.136817 -0.731172 0.523415 0.000000 - -0.079314 -0.911225 0.630027 0.000000 - -0.005421 -0.831913 0.649318 0.000000 - -1.135210 -0.732283 0.510967 0.000000 - -1.244566 0.225538 0.300180 0.000000 - -1.215663 -0.606890 0.105025 0.000000 - -0.849533 1.207208 0.111158 0.000000 - 1.103697 0.130132 0.537789 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 366 - 1 - 0.000000 - - - - - - 0.713805 0.101503 -0.692950 0.000000 - -0.511430 0.751509 -0.416742 0.000000 - 0.478457 0.651868 0.588342 0.000000 - - - - 0.268277 0.029150 -0.011397 0.000000 - - - 367 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 368 - 0 - 34 - 0 0 0 0 - - - 0.128394 1.176994 -0.441059 0.000000 - 0.098214 1.151236 -0.402748 0.000000 - 0.134951 1.183831 -0.444649 0.000000 - -0.160291 1.064528 -0.174482 0.000000 - 0.004258 0.916231 -0.635623 0.000000 - -0.213827 1.025438 -0.146394 0.000000 - -0.038984 0.739644 -0.707105 0.000000 - -0.507647 0.697976 0.088562 0.000000 - 0.059488 -1.234180 0.227541 0.000000 - 0.005222 -1.177801 0.237457 0.000000 - 0.039349 -1.173727 0.083600 0.000000 - -0.296628 -0.919909 0.339273 0.000000 - -0.001441 -1.060277 -0.280854 0.000000 - -0.409246 -0.764078 0.389441 0.000000 - 0.000238 -0.800541 -0.813677 0.000000 - 0.005604 -0.816285 -0.808160 0.000000 - -0.692650 -0.366077 0.524488 0.000000 - -0.033292 -0.720673 -0.853919 0.000000 - -0.720979 -0.289458 0.545914 0.000000 - -0.116137 -0.291324 -0.915225 0.000000 - -0.829266 0.146927 0.566317 0.000000 - -0.133623 -0.187988 -0.931137 0.000000 - -0.856830 0.060573 0.649244 0.000000 - -0.817702 0.169745 0.538756 0.000000 - -0.126025 0.237664 -0.873836 0.000000 - -0.591201 0.604809 0.162798 0.000000 - -0.121004 0.375738 -0.856283 0.000000 - 0.248754 1.122530 -0.288475 0.000000 - 0.600111 0.933161 0.211528 0.000000 - 0.665948 0.356586 0.199588 0.000000 - 0.711288 -0.647272 0.297557 0.000000 - 0.754156 -0.560644 0.225295 0.000000 - 0.553490 0.889259 0.292133 0.000000 - 0.381045 0.529562 0.614608 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 369 - 1 - 0.000000 - - - - - - 0.970878 0.012669 -0.239241 0.000000 - 0.151980 0.739376 0.655915 0.000000 - 0.185199 -0.673173 0.715919 0.000000 - - - - 0.011299 0.150707 -0.040963 0.000000 - - - 370 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 371 - 0 - 30 - 0 0 0 0 - - - 0.967211 0.201787 0.902247 0.000000 - 1.004035 0.155460 0.903515 0.000000 - 0.962719 0.206682 0.898613 0.000000 - 0.554646 0.303098 0.837760 0.000000 - 0.912140 0.170859 0.974814 0.000000 - 0.040943 0.481274 0.749247 0.000000 - 0.085009 0.392637 0.873834 0.000000 - 0.910007 0.167580 0.978980 0.000000 - 0.057614 0.180545 1.054639 0.000000 - 0.561804 -0.081028 1.237848 0.000000 - 0.090315 -0.419733 1.424731 0.000000 - 0.146924 -0.378857 1.399054 0.000000 - -0.099214 -0.260534 1.327379 0.000000 - -0.169985 -0.360238 1.393910 0.000000 - 0.490353 -0.134448 1.291185 0.000000 - 0.024850 -0.025665 1.229300 0.000000 - 0.334969 -0.035991 -1.633820 0.000000 - 0.193410 -0.037825 -1.688709 0.000000 - 0.095701 0.065032 -1.661043 0.000000 - 0.066007 0.135321 -1.619091 0.000000 - 0.433953 0.011840 -1.573868 0.000000 - 0.247106 -0.099367 -1.711073 0.000000 - -0.925452 -0.189043 0.331781 0.000000 - -0.866400 -0.209760 0.469362 0.000000 - -0.919222 -0.164535 0.333173 0.000000 - -0.662544 -0.277456 -0.209166 0.000000 - -0.639755 0.604901 -0.126571 0.000000 - 0.667175 -0.008054 -1.258123 0.000000 - 0.265088 -0.279857 -1.539216 0.000000 - 0.006318 -0.470845 -0.969060 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 372 - 1 - 0.000000 - - - - - - 0.901322 -0.432537 0.023026 0.000000 - 0.432500 0.901608 0.006806 0.000000 - -0.023705 0.003824 0.999712 0.000000 - - - - -0.032484 0.144918 -0.056613 0.000000 - - - 373 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 374 - 0 - 28 - 0 0 0 0 - - - 0.667295 0.018419 0.204851 0.000000 - -0.075664 0.334666 -0.251745 0.000000 - 0.574943 0.014786 0.461512 0.000000 - 0.534099 0.004755 -0.269947 0.000000 - 0.180997 0.120487 -0.677388 0.000000 - 0.658997 0.001131 0.035171 0.000000 - 0.442657 0.022291 -0.496467 0.000000 - 0.240653 -0.009396 -0.862078 0.000000 - 0.138159 0.149690 -0.784455 0.000000 - 0.244462 -0.008211 -0.901247 0.000000 - 0.113805 0.180245 -0.765815 0.000000 - -0.184082 0.402577 -0.496244 0.000000 - -0.241617 0.442113 -0.448967 0.000000 - -0.291341 0.391197 0.092428 0.000000 - -0.354840 0.478066 -0.350381 0.000000 - -0.273771 0.363887 0.219914 0.000000 - 0.486726 0.006920 0.714143 0.000000 - -0.263924 0.351972 0.252142 0.000000 - 0.298868 -0.039106 0.904741 0.000000 - 0.014443 -0.025382 0.986683 0.000000 - -0.199121 0.050266 0.879472 0.000000 - -0.191527 0.030245 0.934408 0.000000 - 0.189130 -0.066944 1.027128 0.000000 - -0.430003 -0.413723 -0.023263 0.000000 - -0.406044 -0.030135 -0.328967 0.000000 - 0.081573 -0.303177 -0.786088 0.000000 - 0.067714 -0.306557 -0.780664 0.000000 - -0.390512 -0.373926 0.174964 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 375 - 1 - 0.000000 - - - - - - 0.662539 0.441647 0.604970 0.000000 - -0.669354 0.711585 0.213570 0.000000 - -0.336165 -0.546438 0.767071 0.000000 - - - - 0.070972 0.054560 -0.024852 0.000000 - - - 376 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 377 - 0 - 40 - 0 0 0 0 - - - -0.088406 -0.746036 0.553685 0.000000 - -0.161188 -0.792723 0.336471 0.000000 - -0.081333 -0.789196 0.517614 0.000000 - -0.119487 -0.290303 0.789070 0.000000 - -0.321428 -0.276799 0.374327 0.000000 - -0.121194 -0.181620 0.847019 0.000000 - -0.064081 0.230345 0.954555 0.000000 - -0.324257 0.264337 0.354563 0.000000 - -0.073376 0.328319 0.919312 0.000000 - -0.060040 0.283634 0.975345 0.000000 - -0.165138 0.746752 0.367449 0.000000 - -0.169455 0.777648 0.279137 0.000000 - -0.169033 0.768359 0.339542 0.000000 - -0.165264 0.822067 0.245440 0.000000 - -0.269964 0.964468 -0.452466 0.000000 - -0.116198 1.057284 -0.156666 0.000000 - -0.361948 0.848046 -0.465335 0.000000 - -0.295038 0.961240 -0.491270 0.000000 - -0.460459 0.527335 -0.417358 0.000000 - -0.519384 0.330172 -0.392084 0.000000 - -0.516603 -0.025874 -0.367185 0.000000 - -0.513636 -0.217606 -0.357655 0.000000 - -0.399925 -0.574104 -0.360515 0.000000 - -0.344961 -0.741599 -0.365501 0.000000 - -0.059089 -1.162660 -0.437808 0.000000 - -0.029695 -1.190270 -0.414905 0.000000 - -0.062313 -1.175166 -0.421218 0.000000 - -0.064346 -1.094503 -0.195891 0.000000 - -0.122701 -1.059807 -0.398026 0.000000 - -0.073705 -0.956976 0.293718 0.000000 - -0.053468 -0.887624 0.439363 0.000000 - 0.506267 0.352525 0.271127 0.000000 - 0.607984 0.345720 0.150343 0.000000 - 0.583021 0.392246 0.137949 0.000000 - 0.616593 0.068044 0.019096 0.000000 - 0.370081 -0.239295 -0.577478 0.000000 - 0.114158 0.625388 -0.563271 0.000000 - 0.307069 0.764414 -0.144518 0.000000 - 0.303113 -0.687910 0.062508 0.000000 - 0.021761 -1.106929 -0.443784 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 378 - 1 - 0.000000 - - - - - - 0.984043 0.120661 -0.130767 0.000000 - -0.091149 0.973027 0.211920 0.000000 - 0.152811 -0.196619 0.968499 0.000000 - - - - -0.159084 0.029071 -0.041940 0.000000 - - - 379 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 380 - 0 - 30 - 0 0 0 0 - - - 1.098363 -0.101743 -0.555502 0.000000 - 1.023508 -0.112730 -0.625956 0.000000 - 0.984159 -0.123254 -0.619511 0.000000 - 1.096733 -0.142445 -0.555964 0.000000 - -0.705796 0.368336 -0.522399 0.000000 - -0.693682 0.361968 -0.555772 0.000000 - -0.737362 0.360500 -0.513959 0.000000 - -0.256369 0.152801 0.692986 0.000000 - -0.200673 0.154549 0.707612 0.000000 - -0.794949 0.293954 -0.003754 0.000000 - -0.834566 0.207963 0.233481 0.000000 - 0.141284 0.194665 0.797051 0.000000 - 0.238922 0.242341 0.687935 0.000000 - -0.786325 0.321424 -0.085329 0.000000 - 0.299714 0.249010 0.622115 0.000000 - -0.604417 0.361951 -0.527873 0.000000 - 0.618033 0.274352 0.296653 0.000000 - -0.572890 0.361962 -0.531569 0.000000 - 0.651633 0.262961 0.262412 0.000000 - 0.014152 0.245700 -0.572075 0.000000 - 0.913722 0.143007 -0.118528 0.000000 - 0.240663 0.198261 -0.590106 0.000000 - 0.831613 0.200105 0.090252 0.000000 - 0.922159 0.128211 -0.146535 0.000000 - 0.577619 0.056648 -0.600754 0.000000 - 0.344897 -0.242230 0.685577 0.000000 - 0.860845 -0.139625 0.134773 0.000000 - -0.137329 -0.319997 0.551323 0.000000 - -0.708922 -0.422151 0.018401 0.000000 - -0.624287 -0.402131 -0.412611 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 381 - 1 - 0.000000 - - - - - - 0.917718 -0.322024 0.232582 0.000000 - 0.302404 0.946021 0.116603 0.000000 - -0.257577 -0.036675 0.965562 0.000000 - - - - -0.087164 0.225096 0.037935 0.000000 - - - 382 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 383 - 0 - 62 - 0 0 0 0 - - - 0.643738 0.639166 -1.358966 0.000000 - -0.538551 0.585390 0.034366 0.000000 - -0.081856 0.664968 0.313477 0.000000 - 1.159965 0.547453 -1.224739 0.000000 - 0.367820 0.575621 0.601102 0.000000 - 0.112842 0.588945 -1.432605 0.000000 - 0.161376 0.595085 -1.432893 0.000000 - 0.114319 0.593970 -1.429238 0.000000 - -0.957605 0.344759 -0.208941 0.000000 - -0.443446 0.352496 -1.378106 0.000000 - -0.526210 0.290692 -1.358806 0.000000 - -1.298076 -0.033335 -0.392681 0.000000 - -0.912830 -0.024746 -1.283083 0.000000 - -1.040937 -0.203128 -1.233444 0.000000 - -1.526719 -0.511910 -0.498917 0.000000 - -1.050743 -0.194492 -1.233564 0.000000 - -1.477140 -0.467504 -0.620930 0.000000 - -1.551668 -0.517928 -0.490746 0.000000 - -1.908717 -0.625636 -0.137600 0.000000 - -1.924144 -0.604424 -0.108243 0.000000 - -1.857751 -0.635290 -0.192441 0.000000 - -2.014129 -0.496989 0.010643 0.000000 - -1.993541 -0.425951 0.021415 0.000000 - -1.891185 -0.195371 0.078286 0.000000 - -1.778020 0.060861 0.147519 0.000000 - -1.634565 0.238975 0.247095 0.000000 - -1.465759 0.448654 0.371032 0.000000 - -1.295986 0.561677 0.501986 0.000000 - -1.087416 0.699510 0.669986 0.000000 - -0.906622 0.740229 0.819854 0.000000 - -0.680053 0.789001 1.015072 0.000000 - -0.503831 0.754921 1.170519 0.000000 - -0.283481 0.708490 1.372540 0.000000 - -0.127464 0.602135 1.519574 0.000000 - 0.766448 0.325998 0.869089 0.000000 - 0.014062 0.522393 1.650561 0.000000 - 0.089087 0.489158 1.633807 0.000000 - 0.660329 0.143402 1.412458 0.000000 - 1.074956 -0.059541 1.091178 0.000000 - 0.855831 0.021619 1.337288 0.000000 - 1.185339 -0.256829 1.139320 0.000000 - 1.600877 -0.660624 0.559772 0.000000 - 1.448892 -0.590110 0.875169 0.000000 - 1.474034 -0.622010 0.847704 0.000000 - 1.703614 -0.690889 0.343357 0.000000 - 1.723596 -0.529470 0.206129 0.000000 - 1.402342 -0.513000 0.945075 0.000000 - 1.700277 -0.307604 -0.011190 0.000000 - 1.671593 -0.045524 -0.278285 0.000000 - 1.613359 0.070201 -0.425283 0.000000 - 1.476213 0.337802 -0.777916 0.000000 - 1.434798 0.370666 -0.837099 0.000000 - 1.209443 0.546758 -1.163756 0.000000 - 1.146926 0.592115 -1.249351 0.000000 - 1.140779 0.591296 -1.263831 0.000000 - 0.692818 0.670651 -1.444118 0.000000 - 0.977499 0.635703 -1.423367 0.000000 - 0.659686 0.674462 -1.448477 0.000000 - 0.712300 -0.723450 -0.347969 0.000000 - 0.127928 -0.282281 -1.173243 0.000000 - -1.490653 -0.448808 0.447973 0.000000 - -1.304486 -0.566463 0.371529 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 384 - 1 - 0.000000 - - - - - - 0.699535 0.535495 -0.473177 0.000000 - -0.170938 0.768329 0.616807 0.000000 - 0.693853 -0.350594 0.629009 0.000000 - - - - -0.348556 -0.075106 -0.244480 0.000000 - - - 385 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 386 - 0 - 33 - 0 0 0 0 - - - 0.169403 -0.156645 0.601578 0.000000 - 0.184314 0.338458 -0.877206 0.000000 - 0.175227 0.751586 -0.528150 0.000000 - -0.004271 0.234643 0.932228 0.000000 - 0.178385 -0.586350 0.273142 0.000000 - 0.187633 0.243141 -0.892030 0.000000 - 0.095985 -0.157018 -0.930066 0.000000 - 0.251620 0.376636 -0.902758 0.000000 - 0.261348 0.410481 -0.911562 0.000000 - 0.322578 0.867467 -0.799338 0.000000 - 0.339670 0.998540 -0.773659 0.000000 - 0.266964 1.155527 -0.630778 0.000000 - 0.116340 0.929578 -0.365721 0.000000 - 0.055824 0.803848 0.175256 0.000000 - -0.174792 0.425034 1.148190 0.000000 - 0.063565 0.167379 1.117319 0.000000 - -0.157660 0.449884 1.110537 0.000000 - 0.124609 0.083653 1.126787 0.000000 - 0.295312 -0.277935 1.042525 0.000000 - 0.376010 -0.456061 1.005735 0.000000 - 0.396181 -0.636651 0.897784 0.000000 - 0.383237 -0.669342 0.821567 0.000000 - 0.348600 -0.773511 0.590322 0.000000 - 0.116168 -0.800621 0.061528 0.000000 - 0.066272 -0.227409 -0.948002 0.000000 - 0.067770 -0.867356 -0.177804 0.000000 - 0.056397 -0.868594 -0.226364 0.000000 - -0.020424 -0.640769 -0.679579 0.000000 - 0.074932 -0.244798 -0.940421 0.000000 - -0.210965 0.266701 0.898836 0.000000 - -0.366291 -0.159608 -0.077443 0.000000 - -0.336196 -0.141493 -0.403037 0.000000 - -0.170505 -0.350167 -0.665908 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 387 - 1 - 0.000000 - - - - - - 0.875996 -0.480893 -0.037042 0.000000 - 0.370485 0.720070 -0.586720 0.000000 - 0.308822 0.500241 0.808942 0.000000 - - - - -0.271513 -0.011639 -0.019090 0.000000 - - - 388 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 389 - 0 - 78 - 0 0 0 0 - - - -1.176981 -0.258271 -1.622161 0.000000 - 1.330066 -0.324723 -1.032338 0.000000 - 1.154358 -0.768169 -0.775819 0.000000 - -1.373209 -0.590517 -1.242126 0.000000 - 0.933711 -1.095073 -0.404649 0.000000 - -1.546295 -0.784337 -0.766981 0.000000 - 0.689762 -1.273394 0.044771 0.000000 - -1.679279 -0.820762 -0.243325 0.000000 - 0.446429 -1.285685 0.528367 0.000000 - -1.759144 -0.696283 0.277508 0.000000 - 0.227560 -1.130803 0.998738 0.000000 - -0.976853 0.179833 -1.869815 0.000000 - 1.443611 0.191776 -1.149063 0.000000 - 2.167277 -0.314605 -0.511947 0.000000 - 2.224947 -0.089990 -0.559020 0.000000 - 2.022953 -0.586939 -0.381707 0.000000 - 1.930259 -0.763731 -0.292654 0.000000 - 1.724313 -0.980918 -0.090655 0.000000 - 1.615080 -1.096309 0.021433 0.000000 - 1.359210 -1.226225 0.285210 0.000000 - 1.252544 -1.279506 0.399631 0.000000 - 0.966646 -1.292793 0.706029 0.000000 - 0.878201 -1.295169 0.804856 0.000000 - 0.590045 -1.170748 1.125421 0.000000 - 0.528793 -1.141657 1.197324 0.000000 - 0.271932 -0.872836 1.496084 0.000000 - 0.054579 -0.824000 1.409815 0.000000 - 0.238617 -0.833975 1.538508 0.000000 - 0.048063 -0.434062 1.776189 0.000000 - -0.055604 -0.395396 1.721389 0.000000 - 0.036156 -0.402258 1.794921 0.000000 - -0.058246 0.092306 1.935928 0.000000 - -0.092246 0.113003 1.903032 0.000000 - -0.058692 0.111184 1.941367 0.000000 - -0.063929 0.340389 1.927455 0.000000 - -0.041821 0.369738 1.954292 0.000000 - -0.279295 0.200027 1.841074 0.000000 - -0.366734 0.150667 1.804315 0.000000 - -0.778925 -0.035460 1.546930 0.000000 - -1.139953 -0.188694 1.320897 0.000000 - -1.322223 -0.240860 1.174725 0.000000 - -1.693763 -0.461128 0.767292 0.000000 - -1.574798 -0.314065 0.972750 0.000000 - -1.698882 -0.466023 0.755505 0.000000 - -1.745684 -0.502810 0.655519 0.000000 - -1.911291 -0.626117 0.295017 0.000000 - -1.934099 -0.636703 0.251527 0.000000 - -1.972883 -0.642322 0.147820 0.000000 - -1.897133 -0.730918 -0.194835 0.000000 - -1.884693 -0.745886 -0.256665 0.000000 - -1.747371 -0.721365 -0.732779 0.000000 - -1.733942 -0.716545 -0.785148 0.000000 - -1.578747 -0.538677 -1.221750 0.000000 - -1.564548 -0.517932 -1.266807 0.000000 - -1.307955 -0.248165 -1.617642 0.000000 - -1.518837 -0.448218 -1.359869 0.000000 - -1.289879 -0.228660 -1.640567 0.000000 - -0.956118 0.155674 -1.879847 0.000000 - -0.957089 0.157185 -1.879356 0.000000 - -0.907064 0.233847 -1.889333 0.000000 - -0.632872 0.628947 -1.921805 0.000000 - -0.198236 0.654646 -1.750920 0.000000 - -0.615165 0.649589 -1.917594 0.000000 - -0.565986 0.736407 -1.898146 0.000000 - 1.453238 0.293086 -1.150534 0.000000 - 1.798943 0.252460 -0.927155 0.000000 - 2.202348 0.191011 -0.672175 0.000000 - 2.193498 0.203675 -0.680712 0.000000 - 2.200179 0.192311 -0.679179 0.000000 - 2.226665 -0.084731 -0.561765 0.000000 - 0.655804 1.017345 1.218964 0.000000 - 0.316049 1.390524 1.250108 0.000000 - 0.185969 0.807285 1.739262 0.000000 - -0.620302 1.507975 0.084228 0.000000 - 0.262739 1.545859 1.030975 0.000000 - -1.912498 -0.403370 0.139556 0.000000 - -1.696216 0.051530 0.431992 0.000000 - 1.896509 0.294417 -0.195375 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 390 - 1 - 0.000000 - - - - - - 0.832957 0.089344 0.546077 0.000000 - 0.008210 0.984775 -0.173642 0.000000 - -0.553276 0.149119 0.819542 0.000000 - - - - 0.045315 0.135490 -0.031806 0.000000 - - - 391 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 392 - 0 - 43 - 0 0 0 0 - - - 0.733411 0.178117 -0.724698 0.000000 - 1.353613 0.240968 -0.490448 0.000000 - 1.114084 0.185023 -0.687794 0.000000 - -1.101936 0.186372 -0.587406 0.000000 - 0.034246 0.158851 -0.780649 0.000000 - -1.066547 0.057555 -0.788646 0.000000 - -1.117995 0.232991 -0.453099 0.000000 - 0.426009 0.272176 -0.375788 0.000000 - 0.401750 0.175101 -0.758490 0.000000 - -1.172722 0.366221 -0.052088 0.000000 - -1.176072 0.368859 0.026658 0.000000 - 0.447756 0.281025 0.164923 0.000000 - -1.207800 0.376381 0.503996 0.000000 - -1.206012 0.373113 0.518549 0.000000 - 0.465975 0.122296 0.681914 0.000000 - -0.968235 0.279969 0.776330 0.000000 - -0.175829 0.193985 0.771070 0.000000 - -1.205360 0.380050 0.517556 0.000000 - 0.472662 0.105220 0.740920 0.000000 - 0.790756 0.114673 0.773153 0.000000 - 0.897318 0.158144 0.717278 0.000000 - 0.832601 0.120015 0.782204 0.000000 - 1.118213 0.254903 0.439043 0.000000 - 1.281921 0.320070 0.239712 0.000000 - 1.420473 0.318490 0.020189 0.000000 - 1.478972 0.317119 -0.253704 0.000000 - 1.465272 0.324246 -0.052798 0.000000 - 1.449682 0.269959 -0.414310 0.000000 - 1.466310 0.293103 -0.333297 0.000000 - -0.855011 -0.410211 0.155135 0.000000 - -0.942679 -0.227879 0.303842 0.000000 - -1.016229 -0.302941 0.121810 0.000000 - -0.999124 -0.385601 0.024875 0.000000 - -0.989106 -0.388179 -0.282946 0.000000 - 0.109668 -0.607663 0.078208 0.000000 - 0.093032 -0.607251 0.065168 0.000000 - 0.582378 -0.511801 0.027468 0.000000 - 0.960469 -0.383706 -0.059715 0.000000 - 1.062073 -0.334049 -0.011273 0.000000 - 1.061977 -0.320138 0.079176 0.000000 - 1.026306 -0.323907 0.134298 0.000000 - 0.853637 -0.140074 0.537872 0.000000 - 1.360918 0.165732 -0.323681 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 393 - 1 - 0.000000 - - - - - - 0.919434 -0.058025 0.388940 0.000000 - -0.172248 0.829703 0.530965 0.000000 - -0.353514 -0.555181 0.752863 0.000000 - - - - -0.027422 -0.159819 -0.044034 0.000000 - - - 394 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 395 - 0 - 46 - 0 0 0 0 - - - -0.075691 -0.299810 -0.396426 0.000000 - 1.479205 -0.562648 0.518706 0.000000 - -0.288447 -0.363354 0.097036 0.000000 - 0.127904 -0.073585 -0.843965 0.000000 - 1.825405 -0.360531 0.155105 0.000000 - 0.714150 -0.554509 0.646254 0.000000 - 1.468206 -0.576710 0.450146 0.000000 - 0.352594 -0.464924 0.722466 0.000000 - -0.489552 -0.258092 0.588142 0.000000 - -0.054681 -0.357127 0.815224 0.000000 - -0.649535 -0.066407 0.921865 0.000000 - -1.143344 0.102349 1.030694 0.000000 - -1.157280 0.086170 1.010287 0.000000 - -1.024335 0.056143 0.996426 0.000000 - -1.334945 -0.053972 0.825788 0.000000 - -0.835215 -0.022922 0.963053 0.000000 - -1.331719 -0.059924 0.829003 0.000000 - -1.403091 -0.164751 0.621652 0.000000 - -1.520370 -0.328768 0.289910 0.000000 - -1.534008 -0.354947 0.163192 0.000000 - -1.587397 -0.440018 -0.277077 0.000000 - -1.577992 -0.433675 -0.344123 0.000000 - -1.525492 -0.380155 -0.810224 0.000000 - -1.501609 -0.355683 -0.862727 0.000000 - -0.950132 -0.162206 -1.117666 0.000000 - -1.440892 -0.284102 -1.024570 0.000000 - 0.260150 0.170811 -1.123713 0.000000 - 0.168487 0.174692 -1.165509 0.000000 - 1.900764 -0.006410 -0.271410 0.000000 - 1.017332 0.116829 -0.764675 0.000000 - 1.903765 0.056889 -0.322719 0.000000 - 1.891536 -0.043930 -0.232878 0.000000 - 1.823830 -0.338607 0.082545 0.000000 - 1.807939 -0.399535 0.148294 0.000000 - 1.810844 -0.397085 0.153926 0.000000 - 1.455810 -0.574062 0.458510 0.000000 - 1.725918 -0.523948 0.377917 0.000000 - 1.462811 -0.572318 0.457565 0.000000 - -0.092734 0.659690 0.166770 0.000000 - -0.875569 0.488733 0.369118 0.000000 - -1.086648 0.227556 0.862928 0.000000 - -1.101646 0.154232 1.011800 0.000000 - 0.017740 0.433879 0.662739 0.000000 - 1.749252 0.142338 -0.158663 0.000000 - 0.009158 0.656018 0.085799 0.000000 - 1.484543 0.056381 0.326930 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 396 - 1 - 0.000000 - - - - - - 0.917693 0.194250 -0.346563 0.000000 - -0.051730 0.923316 0.380542 0.000000 - 0.393907 -0.331293 0.857369 0.000000 - - - - 0.000230 -0.275686 -0.191821 0.000000 - - - 397 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 398 - 0 - 34 - 0 0 0 0 - - - 0.091387 -0.662306 0.745082 0.000000 - -1.321391 0.066409 -0.130603 0.000000 - -1.230051 -0.403146 -0.384562 0.000000 - 0.256730 -0.830594 0.779423 0.000000 - -0.309824 -0.226896 0.667617 0.000000 - -0.762830 0.980845 0.383458 0.000000 - -0.721412 0.987693 0.383581 0.000000 - -0.666217 1.067370 0.392464 0.000000 - -0.821295 0.904870 0.352548 0.000000 - -0.704905 0.841005 0.419471 0.000000 - -1.125490 0.514045 0.182602 0.000000 - -0.646762 0.400093 0.531140 0.000000 - -1.137528 0.484277 0.166297 0.000000 - -0.507400 0.134041 0.587484 0.000000 - -1.304525 0.083318 -0.071113 0.000000 - -1.320742 0.031156 -0.093434 0.000000 - -1.318919 0.037512 -0.094515 0.000000 - -1.295887 -0.381590 -0.435953 0.000000 - -1.294529 -0.396933 -0.453718 0.000000 - -1.156937 -0.547626 -0.504937 0.000000 - -1.231572 -0.533423 -0.601607 0.000000 - -0.358198 -0.760135 0.132897 0.000000 - 0.446312 -0.991004 0.786639 0.000000 - 0.439998 -0.977195 0.804186 0.000000 - 0.652636 0.870619 -0.378446 0.000000 - -0.466363 1.143433 0.355625 0.000000 - 0.800511 0.289668 0.439985 0.000000 - 1.084311 0.487178 -0.200927 0.000000 - 1.073563 0.093290 -0.372396 0.000000 - 1.015846 0.024265 -0.434592 0.000000 - 0.518456 0.379177 -0.689895 0.000000 - 1.042365 -0.154547 -0.395450 0.000000 - 0.944207 -0.553462 -0.318626 0.000000 - -0.603298 -0.430267 -0.811780 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 399 - 1 - 0.000000 - - - - - - 0.771723 -0.054771 -0.633596 0.000000 - 0.316118 0.897522 0.307447 0.000000 - 0.551827 -0.437555 0.709953 0.000000 - - - - -0.195184 0.092964 0.271780 0.000000 - - - 400 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 401 - 0 - 36 - 0 0 0 0 - - - -0.110244 -0.681566 -0.169558 0.000000 - -0.130993 -0.697144 -0.138046 0.000000 - 0.421997 -0.704116 -0.225047 0.000000 - -0.135600 -0.676478 -0.175327 0.000000 - -1.030294 -0.476982 -0.303595 0.000000 - -0.972444 -0.662867 -0.114907 0.000000 - -1.133237 -0.188770 -0.592948 0.000000 - -1.156586 -0.068968 -0.669875 0.000000 - 0.104707 -0.272228 -0.375954 0.000000 - -1.040094 0.243293 -0.857217 0.000000 - -1.215713 0.179528 -0.846093 0.000000 - -0.932362 0.275778 -0.843362 0.000000 - 0.330728 0.212691 -0.455984 0.000000 - -0.328597 0.496962 -0.746030 0.000000 - 0.244300 0.691684 -0.512127 0.000000 - 0.524988 0.710213 -0.370358 0.000000 - 0.395533 0.745147 -0.448664 0.000000 - 0.445044 0.757189 -0.426155 0.000000 - 0.511927 0.698773 -0.396143 0.000000 - 0.553790 0.669927 -0.399180 0.000000 - 0.602824 0.642411 -0.393781 0.000000 - 1.259117 0.171707 -0.385501 0.000000 - 1.418568 -0.189672 -0.427255 0.000000 - 1.346673 0.106963 -0.397182 0.000000 - 1.436626 -0.127874 -0.423248 0.000000 - 1.373105 -0.263549 -0.417174 0.000000 - 1.145808 -0.658043 -0.350580 0.000000 - 1.070236 -0.736686 -0.308157 0.000000 - -0.465530 0.349308 0.879251 0.000000 - -0.559980 0.305782 0.840188 0.000000 - -0.560599 0.142914 0.873297 0.000000 - -0.590753 -0.190672 0.845287 0.000000 - 0.495052 -0.313362 0.556197 0.000000 - 0.581593 -0.108775 0.553999 0.000000 - 0.315384 0.406003 0.683372 0.000000 - 0.059321 0.551732 0.775153 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 402 - 1 - 0.000000 - - - - - - 0.929846 0.085890 -0.357783 0.000000 - 0.068264 0.915224 0.397120 0.000000 - 0.361561 -0.393684 0.845155 0.000000 - - - - 0.152447 -0.083367 0.065429 0.000000 - - - 403 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 404 - 0 - 28 - 0 0 0 0 - - - -0.965185 -0.324997 0.699940 0.000000 - -0.551598 -0.557510 0.676434 0.000000 - 0.422027 -0.613911 0.749660 0.000000 - -0.891925 -0.251457 0.720188 0.000000 - 0.059430 0.749184 0.574228 0.000000 - 0.567510 0.708667 0.612143 0.000000 - 0.533225 0.762875 0.576792 0.000000 - 0.241047 0.775975 0.560087 0.000000 - -0.238712 0.644858 0.604717 0.000000 - 0.754591 0.313665 0.769814 0.000000 - 0.753641 0.336774 0.766399 0.000000 - -0.201994 0.698003 0.590708 0.000000 - -0.466253 0.308553 0.728702 0.000000 - 0.748090 0.198976 0.812878 0.000000 - -0.544967 0.201624 0.731296 0.000000 - 0.717816 -0.223615 0.839441 0.000000 - -0.852081 -0.202198 0.735823 0.000000 - 0.712352 -0.344901 0.845087 0.000000 - 0.702196 -0.641023 0.778920 0.000000 - -0.370125 0.293194 -0.914388 0.000000 - 0.274760 -0.029110 -1.660554 0.000000 - 0.332864 -0.178322 -1.691820 0.000000 - -0.846362 -0.396682 -0.100623 0.000000 - -1.059504 -0.280834 0.135599 0.000000 - -0.763770 0.259370 -0.395873 0.000000 - -0.601143 0.481985 -0.418804 0.000000 - -0.520184 0.536041 -0.248763 0.000000 - 0.747902 -0.424688 -0.424819 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 405 - 1 - 0.000000 - - - - - - 0.897721 0.124076 -0.422733 0.000000 - -0.040159 0.978575 0.201938 0.000000 - 0.438731 -0.164308 0.883469 0.000000 - - - - 0.016324 -0.032739 0.138042 0.000000 - - - 406 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 407 - 0 - 16 - 0 0 0 0 - - - -0.175556 -0.303342 0.823609 0.000000 - 0.621782 -0.232306 0.857367 0.000000 - -0.381914 -0.074407 0.899159 0.000000 - 0.629961 0.118219 1.000258 0.000000 - -0.560798 0.117145 0.966333 0.000000 - 0.837780 -0.235573 0.875601 0.000000 - 0.567755 0.221514 1.007220 0.000000 - 0.282129 0.256646 1.002692 0.000000 - -0.687347 0.197809 0.978880 0.000000 - 0.538174 0.280398 1.017275 0.000000 - -0.761827 -0.261494 -0.251489 0.000000 - -1.036651 0.150086 0.176199 0.000000 - 0.051882 0.174715 -1.484893 0.000000 - 0.228906 -0.054630 -1.776645 0.000000 - 0.522259 0.238139 -0.222647 0.000000 - 0.710587 -0.093672 -0.808784 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 408 - 1 - 0.000000 - - - - - - 0.879846 0.191164 0.435119 0.000000 - -0.113692 0.973616 -0.197852 0.000000 - -0.461461 0.124610 0.878366 0.000000 - - - - -0.062500 -0.049358 0.038841 0.000000 - - - 409 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 410 - 0 - 59 - 0 0 0 0 - - - 1.484298 -0.339551 0.624772 0.000000 - 1.387102 -0.430738 0.631886 0.000000 - 0.821126 -0.640081 -0.088698 0.000000 - 1.545708 -0.207358 0.487775 0.000000 - 1.098601 -0.592297 0.645706 0.000000 - 0.419872 -0.885095 0.179201 0.000000 - 0.808097 -0.750585 0.665562 0.000000 - 0.328152 -0.871292 0.690973 0.000000 - -0.046435 -0.974024 0.439142 0.000000 - 0.169027 -0.909405 0.701631 0.000000 - 0.016772 -0.910111 0.706103 0.000000 - -0.311918 -0.947780 0.542429 0.000000 - -1.435894 -0.751078 -0.022004 0.000000 - -1.365506 -0.740407 0.079727 0.000000 - -1.573847 -0.593009 0.046203 0.000000 - -1.291336 -0.916124 -0.118849 0.000000 - -1.206676 -0.842429 0.134724 0.000000 - -1.226688 -0.958530 -0.162595 0.000000 - -0.998070 -1.005243 -0.090157 0.000000 - -0.682175 -0.959609 0.358084 0.000000 - -0.760742 -1.063600 -0.005244 0.000000 - -0.601837 -0.972908 0.397736 0.000000 - -0.318402 -1.072205 0.036459 0.000000 - -0.178510 -1.074680 0.046540 0.000000 - 0.261299 -0.969949 -0.052509 0.000000 - 0.339985 -0.950794 -0.073437 0.000000 - 0.682991 -0.742570 -0.306495 0.000000 - 0.744141 -0.704162 -0.353322 0.000000 - 0.934561 -0.444461 -0.659439 0.000000 - 1.118126 -0.263026 -0.338355 0.000000 - 1.018611 -0.349891 -0.654332 0.000000 - 0.933573 -0.452787 -0.648805 0.000000 - 1.192367 0.076961 -0.728471 0.000000 - 1.281889 0.209160 -0.545378 0.000000 - 1.223581 0.157752 -0.744995 0.000000 - 1.304778 0.344246 -0.574523 0.000000 - 1.235775 0.208443 -0.761164 0.000000 - 1.610330 0.594323 -0.216114 0.000000 - 1.669829 0.549261 -0.107617 0.000000 - 1.714953 0.370946 0.033990 0.000000 - 1.721212 0.514021 -0.023565 0.000000 - 1.671329 0.172510 0.163851 0.000000 - 1.616247 -0.080651 0.337373 0.000000 - -1.859060 0.461401 0.163869 0.000000 - -1.864201 0.448778 0.146188 0.000000 - -1.129940 0.796332 -0.263465 0.000000 - -1.157794 0.736437 -0.352662 0.000000 - -1.301263 0.810681 0.496864 0.000000 - -0.642749 1.126462 0.192090 0.000000 - 1.040400 0.519062 0.533907 0.000000 - 0.996190 0.669232 0.416424 0.000000 - 0.050519 1.060526 0.188626 0.000000 - -0.991297 0.659631 0.594029 0.000000 - 1.380482 0.220948 0.605431 0.000000 - 1.378598 0.214316 0.608635 0.000000 - -0.481901 0.156853 0.714236 0.000000 - 1.579948 0.505926 0.196055 0.000000 - -0.035936 0.038739 -1.119773 0.000000 - -0.082255 -0.165237 -1.064396 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 411 - 1 - 0.000000 - - - - - - 0.896168 -0.296522 0.330087 0.000000 - 0.420098 0.806472 -0.416077 0.000000 - -0.142830 0.511544 0.847303 0.000000 - - - - -0.264679 0.322185 0.215149 0.000000 - - - 412 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 413 - 0 - 51 - 0 0 0 0 - - - -0.591463 0.668254 -0.719167 0.000000 - -0.558506 0.732132 -0.433716 0.000000 - 0.596248 0.234408 -0.169544 0.000000 - -0.561464 0.631422 -0.779014 0.000000 - -0.542974 0.721974 -0.266322 0.000000 - 0.424087 0.282633 0.341183 0.000000 - -0.517753 0.694822 0.127475 0.000000 - -0.513459 0.615462 0.340406 0.000000 - 0.208684 0.169576 0.824430 0.000000 - -0.514914 0.491938 0.663822 0.000000 - -0.530883 0.308939 0.906141 0.000000 - -0.028890 -0.093642 1.232977 0.000000 - -0.550441 0.142757 1.122433 0.000000 - -0.649602 -0.421595 1.492206 0.000000 - -0.481829 -0.367185 1.474463 0.000000 - -0.620917 -0.318722 1.457819 0.000000 - -0.387189 -0.358648 1.461035 0.000000 - -0.595027 -0.163450 1.346491 0.000000 - -0.290269 -0.319652 1.453788 0.000000 - -0.221664 -0.311028 1.432029 0.000000 - 0.141312 -0.201332 1.439714 0.000000 - 0.203703 -0.215095 1.435517 0.000000 - 0.389705 -0.163496 1.436579 0.000000 - 0.704263 -0.052103 1.342492 0.000000 - 0.421663 -0.127296 1.433265 0.000000 - 1.016943 0.025193 1.244867 0.000000 - 1.132184 0.049792 1.117509 0.000000 - 1.379666 0.097286 0.852920 0.000000 - 1.398348 0.092688 0.684116 0.000000 - 1.450250 0.075201 0.300097 0.000000 - 1.323695 0.015034 -0.063951 0.000000 - 0.708298 0.029534 -0.657796 0.000000 - 1.219151 -0.041274 -0.371895 0.000000 - 0.722311 -0.236718 -1.066747 0.000000 - -0.026423 -0.484226 -1.581535 0.000000 - -0.011689 -0.496347 -1.574147 0.000000 - -0.042785 -0.416039 -1.549753 0.000000 - 0.093317 -0.451772 -1.523294 0.000000 - -0.162480 -0.107439 -1.406826 0.000000 - 0.709581 -0.235183 -1.086084 0.000000 - -0.265304 0.138521 -1.291172 0.000000 - 0.708241 -0.242780 -1.084766 0.000000 - -0.360038 0.315126 -1.133525 0.000000 - -0.292292 0.187754 -1.250043 0.000000 - -0.495089 0.558266 -0.909623 0.000000 - -0.703171 -0.137829 -0.201144 0.000000 - -0.588328 -0.521964 -0.363525 0.000000 - -0.611493 -0.540093 -0.244344 0.000000 - -0.718029 -0.488745 0.920023 0.000000 - -0.264125 -0.480870 -1.091281 0.000000 - -0.661318 -0.425477 1.490594 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 414 - 1 - 0.000000 - - - - - - 0.831239 -0.549884 -0.081660 0.000000 - 0.553267 0.832625 0.025106 0.000000 - 0.054187 -0.066049 0.996344 0.000000 - - - - -0.104222 -0.404259 -0.018270 0.000000 - - - 415 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 416 - 0 - 62 - 0 0 0 0 - - - -0.689265 -0.674771 -1.726225 0.000000 - -0.531362 -0.955883 -1.619304 0.000000 - -0.644704 -0.916288 0.172335 0.000000 - -0.736340 -0.585339 -1.685104 0.000000 - -0.475063 -1.013165 -1.584436 0.000000 - -0.246899 -1.280554 0.126552 0.000000 - -0.150243 -1.320172 -1.412766 0.000000 - -0.046270 -1.371114 -1.362762 0.000000 - 0.244429 -1.503700 0.085038 0.000000 - 0.326429 -1.542426 -1.201335 0.000000 - 0.615163 -1.562466 0.065909 0.000000 - 0.404628 -1.560089 -1.168981 0.000000 - 0.641514 -1.666511 0.827425 0.000000 - 0.722249 -1.680196 0.797925 0.000000 - 0.391300 -1.648191 0.933383 0.000000 - 0.185601 -1.561899 1.040444 0.000000 - -0.066527 -1.452741 1.178622 0.000000 - -0.209217 -1.321901 1.276772 0.000000 - -0.427611 -1.116184 1.435302 0.000000 - -0.508008 -0.964019 1.516759 0.000000 - -0.909968 -0.446502 0.217904 0.000000 - -0.656809 -0.671736 1.678276 0.000000 - -0.681539 -0.516799 1.739138 0.000000 - -1.016631 0.082816 0.258794 0.000000 - -0.698170 -0.461913 1.760667 0.000000 - -0.769185 -0.162578 1.692084 0.000000 - -0.766417 0.075676 1.602167 0.000000 - -0.954179 0.619799 0.290995 0.000000 - -0.755409 0.419029 1.478350 0.000000 - -0.662574 0.725335 1.322345 0.000000 - -0.728697 1.111798 0.311347 0.000000 - -0.585539 0.964731 1.203518 0.000000 - -0.366134 1.290425 0.981467 0.000000 - -0.362279 1.510564 0.317853 0.000000 - -0.275710 1.420187 0.894509 0.000000 - 0.083525 1.695700 0.624612 0.000000 - 0.109136 1.777009 0.309878 0.000000 - 0.143639 1.740011 0.581787 0.000000 - 0.624267 1.891312 0.298661 0.000000 - 0.639311 1.885044 0.288205 0.000000 - 0.630989 1.892463 0.296228 0.000000 - 0.736341 1.885409 0.248897 0.000000 - 0.704377 1.885903 -0.040836 0.000000 - 0.789617 1.884602 0.232103 0.000000 - 0.644171 1.884482 -0.278203 0.000000 - 0.346034 1.806480 -0.462572 0.000000 - 0.606962 1.873311 -0.427069 0.000000 - 0.163899 1.766672 -0.489967 0.000000 - -0.125433 1.597871 -0.580018 0.000000 - -0.301228 1.492394 -0.640074 0.000000 - -0.501574 1.263471 -0.757228 0.000000 - -0.655634 1.082658 -0.854252 0.000000 - -0.758254 0.839238 -0.975736 0.000000 - -0.864238 0.577991 -1.111389 0.000000 - -0.882474 0.364177 -1.215870 0.000000 - -0.906569 0.028455 -1.386091 0.000000 - -0.872405 -0.122641 -1.458208 0.000000 - -0.778947 -0.511503 -1.651251 0.000000 - 1.121062 0.680787 0.493626 0.000000 - 0.725760 0.178593 -1.258817 0.000000 - 0.954721 -0.679871 1.042161 0.000000 - 0.665940 -0.038261 -1.366480 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 417 - 1 - 0.000000 - - - - - - 0.959431 -0.281037 0.022600 0.000000 - 0.258872 0.909842 0.324304 0.000000 - -0.111704 -0.305297 0.945683 0.000000 - - - - 0.026292 0.055128 0.086320 0.000000 - - - 418 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 419 - 0 - 41 - 0 0 0 0 - - - 0.437044 -0.403504 0.139787 0.000000 - 0.821422 -0.023322 -1.233648 0.000000 - 0.656485 0.058833 0.314964 0.000000 - -0.425812 -0.770565 -1.379036 0.000000 - -0.389198 -1.013894 -0.154863 0.000000 - -0.442141 -1.041268 -0.175585 0.000000 - -0.419941 -0.778799 -1.388801 0.000000 - -0.028235 -0.684936 -1.385644 0.000000 - 0.053565 -0.641204 -1.382383 0.000000 - 0.076758 -0.773131 -0.022098 0.000000 - 0.477247 -0.405564 -1.374681 0.000000 - 0.483420 -0.400493 -1.373080 0.000000 - 0.545909 -0.333739 -1.370248 0.000000 - 0.894671 -0.044129 -1.355968 0.000000 - 0.943000 -0.001595 -1.358071 0.000000 - 1.063542 0.275787 -1.203827 0.000000 - 0.992706 0.308123 -1.057853 0.000000 - 0.970888 0.033788 -1.351943 0.000000 - 0.968419 0.320379 -0.795972 0.000000 - 0.712394 0.446485 0.464612 0.000000 - 0.770299 0.244639 1.365449 0.000000 - 0.734179 0.444739 0.737325 0.000000 - 0.718161 0.490008 1.452689 0.000000 - 0.753155 0.078427 1.308405 0.000000 - 0.712540 -0.271874 1.195628 0.000000 - 0.646707 -0.415375 1.143939 0.000000 - 0.491337 -0.744516 1.033420 0.000000 - 0.382470 -0.860708 0.988793 0.000000 - 0.128356 -1.127082 0.894682 0.000000 - -0.004274 -1.198079 0.856390 0.000000 - 0.008875 -1.196519 0.862632 0.000000 - -0.331696 -1.303735 0.604561 0.000000 - -0.445220 -1.315276 0.528673 0.000000 - -0.601373 0.783112 -1.201987 0.000000 - -0.593652 0.773850 -1.217983 0.000000 - -0.629350 0.914135 -1.093755 0.000000 - -0.586458 0.875145 -1.153129 0.000000 - 0.181047 0.693225 1.492035 0.000000 - -0.731279 1.015391 0.811173 0.000000 - -0.560520 -0.386857 1.016168 0.000000 - -0.431199 -0.350845 1.103222 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 420 - 1 - 0.000000 - - - - - - 0.911589 0.252273 0.324596 0.000000 - 0.021386 0.759406 -0.650265 0.000000 - -0.410545 0.599717 0.686872 0.000000 - - - - 0.021492 0.023872 -0.099277 0.000000 - - - 421 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 422 - 0 - 41 - 0 0 0 0 - - - -0.115949 0.838655 -0.852883 0.000000 - -0.147595 0.874069 -0.792474 0.000000 - -0.058899 0.825366 -0.848055 0.000000 - -0.285400 1.008722 -0.530031 0.000000 - 0.607405 0.624805 -0.773034 0.000000 - -0.630129 1.346149 0.129570 0.000000 - -0.658581 1.332318 0.102671 0.000000 - -0.624731 1.339519 0.115020 0.000000 - -0.636335 1.342207 0.125797 0.000000 - -0.552953 1.301923 0.320252 0.000000 - -0.763624 1.373555 0.284331 0.000000 - -0.208008 1.126492 0.422778 0.000000 - 1.416758 0.235304 -0.521626 0.000000 - -0.112834 1.052599 0.453391 0.000000 - 1.588503 -0.026475 -0.079740 0.000000 - 0.357692 0.653156 0.641259 0.000000 - 0.824782 -0.658028 1.104976 0.000000 - 1.053789 -0.524522 0.932984 0.000000 - 0.861584 -0.452757 1.037362 0.000000 - 0.826569 -0.650579 1.088462 0.000000 - 1.143695 -0.466327 0.822506 0.000000 - 0.808539 -0.221218 0.960173 0.000000 - 1.470392 -0.262638 0.417129 0.000000 - 0.726254 0.108635 0.853189 0.000000 - 1.487325 -0.248731 0.379493 0.000000 - 0.517599 0.422987 0.728869 0.000000 - 1.600622 -0.160136 0.127180 0.000000 - 1.671008 -0.079970 -0.149637 0.000000 - 1.678740 -0.077224 -0.185991 0.000000 - 1.649775 0.011928 -0.640054 0.000000 - 1.687345 -0.012559 -0.640051 0.000000 - 1.576891 0.098565 -0.653714 0.000000 - 1.291866 0.315654 -0.694267 0.000000 - 0.842738 0.546903 -0.752189 0.000000 - -1.521762 0.143826 0.535681 0.000000 - -1.548223 -0.142353 0.399494 0.000000 - -1.567568 -0.025633 0.572453 0.000000 - -1.062891 -1.074963 -0.805812 0.000000 - -0.842852 -1.151767 -0.779717 0.000000 - 0.650864 -0.728922 1.061503 0.000000 - -0.059857 -0.496149 0.923290 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 423 - 1 - 0.000000 - - - - - - 0.793384 -0.604082 -0.075010 0.000000 - 0.452510 0.667712 -0.591097 0.000000 - 0.407156 0.435024 0.803105 0.000000 - - - - -0.132915 -0.335763 -0.166737 0.000000 - - - 424 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 425 - 0 - 46 - 0 0 0 0 - - - 0.510189 1.251719 0.525931 0.000000 - 1.149163 0.864849 0.542527 0.000000 - 0.652889 1.284477 0.431469 0.000000 - 0.140270 1.133938 0.666841 0.000000 - 0.872593 0.470803 0.790631 0.000000 - -0.107205 1.059703 0.754592 0.000000 - -0.404941 0.949222 0.787403 0.000000 - 0.554114 0.041640 0.878256 0.000000 - -0.753743 0.825333 0.820325 0.000000 - -0.945197 0.743983 0.789542 0.000000 - 0.224954 -0.380561 0.796849 0.000000 - -1.294023 0.557851 0.719616 0.000000 - -1.243039 0.618046 0.742597 0.000000 - -1.350589 0.476070 0.671475 0.000000 - -0.082626 -0.754429 0.554450 0.000000 - -1.579260 0.164303 0.476114 0.000000 - -1.614739 0.113144 0.416456 0.000000 - -0.338510 -1.043367 0.174880 0.000000 - -1.809940 -0.144693 0.094281 0.000000 - -1.889803 -0.236736 -0.119534 0.000000 - -0.817356 -0.971415 -0.181583 0.000000 - -1.824378 -0.166462 0.046316 0.000000 - -0.493921 -1.197324 -0.202005 0.000000 - 0.277202 -1.788251 -0.227733 0.000000 - 0.556587 -2.032052 -0.237363 0.000000 - 0.605677 -1.960606 -0.084746 0.000000 - 0.653801 -1.846946 0.041722 0.000000 - 0.773034 -1.589290 0.322654 0.000000 - 0.841016 -1.356164 0.455151 0.000000 - 0.929921 -1.072098 0.612019 0.000000 - 1.008909 -0.692783 0.701483 0.000000 - 1.060888 -0.458753 0.753542 0.000000 - 1.132301 0.054615 0.738029 0.000000 - 1.152739 0.190496 0.732017 0.000000 - 1.179826 0.791482 0.563562 0.000000 - 1.188330 0.723513 0.578615 0.000000 - 1.175985 0.822093 0.557227 0.000000 - 1.154123 0.921970 0.511885 0.000000 - 1.000733 1.402297 0.163013 0.000000 - 1.037111 1.382060 0.156728 0.000000 - 1.016109 1.392217 0.174002 0.000000 - 0.496107 0.867261 -1.402322 0.000000 - -0.213098 0.666537 -1.067715 0.000000 - 0.510810 0.899124 -1.343082 0.000000 - 0.625133 0.113958 -1.133389 0.000000 - -1.531398 0.270051 -0.448948 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 426 - 1 - 0.000000 - - - - - - 0.935698 0.163039 -0.312871 0.000000 - -0.247472 0.935365 -0.252687 0.000000 - 0.251450 0.313865 0.915566 0.000000 - - - - 0.011121 0.035538 -0.125123 0.000000 - - - 427 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 428 - 0 - 44 - 0 0 0 0 - - - -0.901689 -0.317766 0.551212 0.000000 - -0.890235 -0.287110 0.560222 0.000000 - -0.886745 -0.258437 0.573579 0.000000 - -0.908564 -0.324079 0.539379 0.000000 - -0.960304 -0.585590 0.357839 0.000000 - -0.716724 -0.760265 0.424027 0.000000 - -0.620979 -0.751328 0.487485 0.000000 - -0.979851 -0.544250 0.369155 0.000000 - -0.690450 -0.779759 0.431297 0.000000 - -0.430308 -0.942329 0.400857 0.000000 - -0.208112 -1.078095 0.363030 0.000000 - 0.699793 -0.784189 0.750839 0.000000 - 0.684517 -0.736426 0.804459 0.000000 - -0.192890 -1.084557 0.347211 0.000000 - 0.632866 -0.538212 0.939315 0.000000 - 0.580033 -0.330287 1.080123 0.000000 - 0.566686 -0.274395 1.102134 0.000000 - 0.502693 -0.080465 1.151047 0.000000 - 0.404624 0.240495 1.231047 0.000000 - 0.385023 0.434385 1.230846 0.000000 - -0.720911 0.258191 0.677584 0.000000 - 0.225122 0.706454 1.169327 0.000000 - -0.689794 0.356419 0.696872 0.000000 - 0.361182 0.701264 1.241057 0.000000 - -0.571694 0.778361 0.651048 0.000000 - -0.542488 0.808342 0.654607 0.000000 - -0.558541 0.782327 0.660068 0.000000 - -0.180639 0.274264 -1.288936 0.000000 - 0.023425 0.583088 -1.088209 0.000000 - 0.419563 0.182869 -1.189120 0.000000 - 0.110226 0.181227 -1.266771 0.000000 - -0.239190 -0.464314 -1.028048 0.000000 - -0.143807 -0.715896 -0.855425 0.000000 - -0.245095 -0.793676 -0.741757 0.000000 - -0.287631 -0.760590 -0.749607 0.000000 - 0.892706 -0.273192 -0.808488 0.000000 - -0.245167 -0.211528 -1.165718 0.000000 - 0.882372 -0.078131 -0.921616 0.000000 - -0.316044 0.187575 -1.266209 0.000000 - -0.703312 0.339427 -0.642704 0.000000 - -0.534664 0.877169 -0.089143 0.000000 - -0.035716 0.926678 -0.563042 0.000000 - 0.559760 0.824530 0.222029 0.000000 - 0.412392 0.704825 1.173786 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 429 - 1 - 0.000000 - - - - - - 0.763743 0.510824 0.394658 0.000000 - -0.642568 0.660017 0.389209 0.000000 - -0.061663 -0.550851 0.832323 0.000000 - - - - 0.096002 -0.002419 0.008226 0.000000 - - - 430 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 431 - 0 - 29 - 0 0 0 0 - - - -0.274533 -0.226825 -0.516238 0.000000 - -0.081623 0.120424 -0.638691 0.000000 - 0.192503 -0.096106 -0.627173 0.000000 - -0.428379 -0.278867 -0.472457 0.000000 - -1.087089 0.313972 -0.108503 0.000000 - -1.047543 0.287272 -0.122238 0.000000 - -1.052484 0.262206 -0.134383 0.000000 - -0.626026 0.244980 -0.436641 0.000000 - -0.938719 -0.143448 -0.280587 0.000000 - -0.569635 0.239986 -0.460680 0.000000 - -0.836686 -0.339155 -0.309184 0.000000 - -0.804241 -0.416185 -0.320341 0.000000 - -0.225676 0.213055 -0.605018 0.000000 - -0.003975 0.194047 -0.655712 0.000000 - 0.032386 0.197646 -0.658341 0.000000 - 0.497783 -0.032116 -0.622938 0.000000 - 0.789214 0.178371 -0.631500 0.000000 - 0.904648 0.177092 -0.602933 0.000000 - 1.054275 0.032093 -0.504068 0.000000 - 0.423390 -0.047477 -0.624112 0.000000 - 0.628408 0.177443 -0.640412 0.000000 - 0.374164 -0.313891 0.608221 0.000000 - 1.079536 0.060847 -0.306485 0.000000 - 0.993461 0.200740 -0.251395 0.000000 - -0.113432 0.381134 0.908619 0.000000 - -0.124665 0.421445 0.896728 0.000000 - 0.039297 -0.478774 0.457660 0.000000 - 0.329549 -0.439057 0.537424 0.000000 - 1.097749 0.011632 -0.410750 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 432 - 1 - 0.000000 - - - - - - 0.923753 -0.006910 0.382927 0.000000 - 0.127618 0.948250 -0.290749 0.000000 - -0.361101 0.317449 0.876831 0.000000 - - - - -0.245008 0.135135 0.094641 0.000000 - - - 433 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 434 - 0 - 62 - 0 0 0 0 - - - 1.244997 0.499785 -0.331313 0.000000 - -0.501347 0.361940 -1.255064 0.000000 - -0.683510 0.612217 -0.811107 0.000000 - 1.203233 0.580091 0.202393 0.000000 - -0.887361 0.701972 -0.317728 0.000000 - 1.143924 0.491916 0.733286 0.000000 - -1.092945 0.622325 0.176774 0.000000 - 1.072872 0.243819 1.209339 0.000000 - -1.280114 0.380998 0.623938 0.000000 - 0.997039 -0.139936 1.583864 0.000000 - -1.430515 0.001590 0.979910 0.000000 - 1.265137 0.258954 -0.815580 0.000000 - -0.689871 0.368553 -1.377696 0.000000 - -0.654855 0.315489 -1.420315 0.000000 - -0.913806 0.571257 -1.058859 0.000000 - -0.968590 0.616076 -0.985973 0.000000 - -1.199257 0.683798 -0.643927 0.000000 - -1.225718 0.694474 -0.601691 0.000000 - -1.252452 0.702819 -0.544762 0.000000 - -1.406056 0.641806 -0.144820 0.000000 - -1.449352 0.623544 -0.038849 0.000000 - -1.582384 0.427743 0.342686 0.000000 - -1.614438 0.381486 0.427845 0.000000 - -1.711591 0.061727 0.750602 0.000000 - -1.712742 0.025971 0.809925 0.000000 - -1.719645 0.041123 0.789403 0.000000 - -1.477307 -0.346418 1.184450 0.000000 - -1.319186 -0.482977 1.280151 0.000000 - -1.382456 -0.464629 1.266102 0.000000 - -1.365118 -0.488970 1.279703 0.000000 - -1.071437 -0.453814 1.327359 0.000000 - -1.403973 -0.446839 1.252898 0.000000 - -0.041602 -0.307990 1.475834 0.000000 - 0.979273 -0.165256 1.622624 0.000000 - 1.192240 -0.144443 1.588237 0.000000 - 1.377288 -0.139551 1.553655 0.000000 - 1.354490 -0.140765 1.565616 0.000000 - 1.468145 0.139974 1.260744 0.000000 - 1.497556 0.203118 1.192453 0.000000 - 1.567481 0.404241 0.805546 0.000000 - 1.586844 0.449677 0.711767 0.000000 - 1.597014 0.529111 0.281703 0.000000 - 1.601778 0.545142 0.180270 0.000000 - 1.548926 0.492776 -0.266181 0.000000 - 1.541006 0.480572 -0.350710 0.000000 - 1.490358 0.402134 -0.529920 0.000000 - 1.239058 0.286509 -0.805000 0.000000 - 1.240997 0.286536 -0.803534 0.000000 - 1.235399 0.293468 -0.803785 0.000000 - 0.369627 -0.312745 -1.569647 0.000000 - 0.452403 -0.294960 -1.526613 0.000000 - 0.410107 -0.340378 -1.573770 0.000000 - -0.188591 0.007650 -1.554294 0.000000 - 0.687711 -0.062601 -1.338288 0.000000 - -0.239503 0.031346 -1.545851 0.000000 - -0.353923 0.081473 -1.527063 0.000000 - -0.583142 0.209915 -1.513041 0.000000 - 0.974903 -0.628371 -0.734242 0.000000 - 0.558943 -0.772023 -1.205394 0.000000 - -0.576044 -0.745336 -0.473335 0.000000 - -1.078675 -0.126341 -0.716136 0.000000 - -1.024586 -0.157788 -0.797457 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 435 - 1 - 0.000000 - - - - - - 0.895498 0.046515 0.442629 0.000000 - -0.086380 0.993777 0.070324 0.000000 - -0.436604 -0.101209 0.893943 0.000000 - - - - -0.145894 0.152615 -0.092442 0.000000 - - - 436 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 437 - 0 - 30 - 0 0 0 0 - - - -0.739473 0.255969 0.677363 0.000000 - 0.715281 -0.091271 0.396035 0.000000 - 0.631143 0.401185 0.188565 0.000000 - -0.741927 0.257363 0.675755 0.000000 - -0.723985 0.138033 0.729400 0.000000 - 0.282655 -0.116279 0.539983 0.000000 - 0.746199 -0.293460 0.414973 0.000000 - 1.148251 -0.214828 0.445820 0.000000 - 1.153989 -0.227810 0.426978 0.000000 - 1.119634 -0.257876 0.448146 0.000000 - 1.118267 -0.056406 0.411128 0.000000 - 1.023952 0.300729 0.261956 0.000000 - 0.990497 0.438022 0.202471 0.000000 - 0.904340 0.735834 -0.045777 0.000000 - 0.903316 0.724905 -0.048609 0.000000 - 0.894014 0.744438 -0.063001 0.000000 - 0.558748 0.691289 -0.042640 0.000000 - -0.823968 0.664606 0.317804 0.000000 - -0.137963 0.713294 0.102751 0.000000 - -0.844706 0.726164 0.222712 0.000000 - -0.814495 0.628273 0.351123 0.000000 - -0.767103 0.186294 -0.558907 0.000000 - 0.112936 0.114755 -0.794722 0.000000 - -0.148179 -0.630994 -0.491719 0.000000 - -0.525385 -0.292826 -0.484876 0.000000 - -0.012838 -1.108225 -0.032050 0.000000 - -0.258106 -0.954092 0.055703 0.000000 - -0.697469 -0.129883 0.566793 0.000000 - -0.846610 0.320962 -0.354983 0.000000 - 0.905016 0.540833 -0.322842 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 438 - 1 - 0.000000 - - - - - - 0.987847 -0.137056 -0.073301 0.000000 - 0.150935 0.958477 0.241950 0.000000 - 0.037096 -0.250074 0.967516 0.000000 - - - - -0.169946 -0.052140 -0.216687 0.000000 - - - 439 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 440 - 0 - 47 - 0 0 0 0 - - - 0.343690 -0.098558 -0.983514 0.000000 - 0.452219 -0.053161 -0.568965 0.000000 - 0.293101 -0.560761 -0.667055 0.000000 - 0.227051 -0.456681 -1.062475 0.000000 - 0.390263 0.054232 -0.952822 0.000000 - 0.389654 0.417265 -0.859206 0.000000 - 0.454380 0.463415 -0.408519 0.000000 - 0.386424 0.585311 -0.819048 0.000000 - 0.295150 0.860550 -0.736651 0.000000 - 0.277495 0.899677 -0.713187 0.000000 - 0.299356 0.938493 -0.201387 0.000000 - 0.230237 1.053273 -0.607175 0.000000 - -0.043567 1.443446 -0.333823 0.000000 - -0.071454 1.407111 0.031021 0.000000 - -0.001358 1.335622 -0.004276 0.000000 - -0.063273 1.435949 -0.334827 0.000000 - -0.001495 1.336132 -0.005377 0.000000 - 0.019212 1.330318 -0.407777 0.000000 - 0.009865 1.320453 -0.001577 0.000000 - 0.382891 0.918394 0.015025 0.000000 - 0.446224 0.849123 0.023524 0.000000 - 0.685491 0.463961 0.133382 0.000000 - 0.831242 0.228145 0.208618 0.000000 - 0.925105 -0.003941 0.316334 0.000000 - 1.084222 -0.355358 0.486050 0.000000 - 1.056752 -0.370289 0.440355 0.000000 - 0.960161 -0.443090 0.303925 0.000000 - 0.610138 -0.717885 -0.157320 0.000000 - 0.144963 -0.988678 -0.536139 0.000000 - -0.007446 -1.009787 -0.693196 0.000000 - 0.066600 -1.034842 -0.598126 0.000000 - -0.077724 -1.107469 -0.674536 0.000000 - -0.082583 -1.099341 -0.684451 0.000000 - -0.164163 -0.961677 -1.142528 0.000000 - -0.087147 -0.897222 -1.137233 0.000000 - -0.168815 -0.970178 -1.154585 0.000000 - 0.135367 -0.589001 -1.082914 0.000000 - -0.398266 -0.518853 1.145867 0.000000 - 0.066229 -0.329544 1.302787 0.000000 - -0.155122 -0.129202 1.307134 0.000000 - -0.297392 -0.142714 1.267387 0.000000 - -0.293176 0.903744 0.619213 0.000000 - -0.527971 0.316583 0.910087 0.000000 - -0.728133 -0.179420 0.617536 0.000000 - -0.467402 -0.579279 1.042774 0.000000 - -0.702989 -0.184911 -0.890960 0.000000 - -0.215236 0.989130 -0.641092 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 441 - 1 - 0.000000 - - - - - - 0.931990 0.256164 -0.256467 0.000000 - 0.005519 0.697416 0.716645 0.000000 - 0.362443 -0.669322 0.648571 0.000000 - - - - 0.033228 0.075070 -0.125018 0.000000 - - - 442 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 443 - 0 - 32 - 0 0 0 0 - - - -0.093006 1.040401 0.079177 0.000000 - -0.217994 0.926018 0.139593 0.000000 - 0.503525 0.704430 0.350234 0.000000 - 0.542765 0.810371 0.290349 0.000000 - -0.284791 0.847354 0.154635 0.000000 - 0.421552 0.390191 0.443755 0.000000 - -0.592099 0.494623 0.213419 0.000000 - 0.375378 0.194606 0.499929 0.000000 - -0.628757 0.435664 0.205129 0.000000 - 0.316157 -0.156256 0.492743 0.000000 - -0.801350 0.167800 0.164541 0.000000 - -0.786681 0.019495 0.163672 0.000000 - 0.288506 -0.347109 0.487358 0.000000 - -0.767228 -0.063437 0.149555 0.000000 - 0.260392 -0.700145 0.370509 0.000000 - -0.669773 -0.552863 0.039332 0.000000 - 0.251392 -0.867659 0.313863 0.000000 - -0.601229 -0.681875 0.004630 0.000000 - 0.259924 -1.184585 0.090450 0.000000 - -0.638189 -0.655797 0.005565 0.000000 - 0.144098 -1.243303 -0.004254 0.000000 - 0.267633 -1.316116 -0.003439 0.000000 - 0.264395 -1.314534 0.005338 0.000000 - 0.257233 -1.316364 -0.003854 0.000000 - 0.452113 -0.395618 -0.430689 0.000000 - 0.527914 -0.396326 -0.393395 0.000000 - 0.282482 -1.259545 -0.061975 0.000000 - 0.315014 -1.255707 -0.032392 0.000000 - 0.598056 0.467574 -0.123584 0.000000 - -0.134640 0.404194 -0.575192 0.000000 - -0.051194 0.606508 -0.470300 0.000000 - -0.619608 0.016244 -0.257740 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 444 - 1 - 0.000000 - - - - - - 0.918580 -0.244373 -0.310633 0.000000 - 0.133411 0.931528 -0.338316 0.000000 - 0.372039 0.269328 0.888285 0.000000 - - - - -0.019495 -0.161241 0.078680 0.000000 - - - 445 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 446 - 0 - 22 - 0 0 0 0 - - - -0.449587 0.866284 0.115949 0.000000 - -0.189065 0.938321 -0.197181 0.000000 - -0.485269 0.793924 0.127053 0.000000 - -0.742894 -0.741241 -0.353734 0.000000 - -0.300416 -0.232555 -0.703931 0.000000 - 0.359335 1.189322 -0.368605 0.000000 - 0.254940 1.173011 -0.320156 0.000000 - 0.057862 1.165141 0.001682 0.000000 - 0.445132 1.196383 -0.291751 0.000000 - 0.429883 1.196779 -0.319314 0.000000 - 0.651508 0.470893 -0.213048 0.000000 - 0.202840 -0.354012 -0.565737 0.000000 - 0.164368 0.645694 -0.524450 0.000000 - -0.221739 1.064320 0.254419 0.000000 - -0.661554 -0.003049 0.558106 0.000000 - -0.780800 -0.886053 -0.262795 0.000000 - 0.408592 -1.113863 -0.053406 0.000000 - 0.880738 -0.710016 0.472894 0.000000 - -0.351888 0.178011 0.828943 0.000000 - -0.177440 -0.169268 -0.741916 0.000000 - 0.196924 -0.382239 -0.572933 0.000000 - 0.771551 0.285865 -0.009266 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 447 - 1 - 0.000000 - - - - - - 0.986782 -0.105394 0.123100 0.000000 - 0.092483 0.990027 0.106273 0.000000 - -0.133073 -0.093483 0.986688 0.000000 - - - - -0.106155 -0.088984 0.098369 0.000000 - - - 448 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 449 - 0 - 56 - 0 0 0 0 - - - -1.143335 -0.555845 0.354111 0.000000 - 0.079167 -0.479360 -1.422292 0.000000 - -0.671304 -0.708402 0.570784 0.000000 - 0.456416 -0.637847 -1.067891 0.000000 - -0.183797 -0.693270 0.805367 0.000000 - 0.849176 -0.628642 -0.695635 0.000000 - 0.271475 -0.512025 1.034896 0.000000 - 1.219011 -0.452743 -0.341957 0.000000 - 0.650014 -0.182482 1.236930 0.000000 - 1.529768 -0.127440 -0.041429 0.000000 - -1.143672 -0.620333 0.647803 0.000000 - -0.761116 -0.753969 0.903249 0.000000 - -1.214561 -0.594536 0.602902 0.000000 - -1.444354 -0.425464 0.456138 0.000000 - -1.397221 -0.386605 0.229164 0.000000 - -0.991963 0.020974 -0.979166 0.000000 - -0.903767 0.014209 -1.085197 0.000000 - -1.089230 -0.079995 -0.709433 0.000000 - -0.459956 -0.037561 -1.638421 0.000000 - -0.330302 -0.188294 -1.605168 0.000000 - -1.281258 -0.273662 -0.187745 0.000000 - -0.313582 -0.200992 -1.599751 0.000000 - -0.110301 -0.336220 -1.549688 0.000000 - 0.147704 -0.489829 -1.483204 0.000000 - 0.176151 -0.500041 -1.480682 0.000000 - 0.245189 -0.531197 -1.456741 0.000000 - 0.573319 -0.653141 -1.214224 0.000000 - 0.617995 -0.666131 -1.184962 0.000000 - 0.974033 -0.659555 -0.859623 0.000000 - 1.023441 -0.656241 -0.818519 0.000000 - 1.323956 -0.500453 -0.478710 0.000000 - 1.363100 -0.479015 -0.438309 0.000000 - 1.513434 -0.177304 -0.045621 0.000000 - 1.546085 -0.240610 -0.164932 0.000000 - 1.511781 -0.173463 -0.038551 0.000000 - 1.503898 -0.172366 -0.020705 0.000000 - 1.088687 0.267446 1.172420 0.000000 - 1.068876 0.256359 1.170825 0.000000 - 1.290975 0.248085 0.841544 0.000000 - 1.274276 0.266317 0.896449 0.000000 - 1.019128 0.199523 1.176507 0.000000 - 0.702981 -0.151527 1.216769 0.000000 - 0.657243 -0.205183 1.227495 0.000000 - 0.653937 -0.204157 1.230953 0.000000 - 0.266300 -0.505562 1.260033 0.000000 - 0.196903 -0.555273 1.268790 0.000000 - -0.188670 -0.702499 1.276537 0.000000 - -0.292801 -0.743729 1.221533 0.000000 - -0.208657 -0.715343 1.275781 0.000000 - -0.656239 -0.752836 0.972209 0.000000 - -0.599073 0.761202 1.061983 0.000000 - -0.605883 0.747634 1.059722 0.000000 - 0.016914 0.944702 -0.761855 0.000000 - -0.329077 0.965425 -0.350787 0.000000 - 0.080546 0.819561 -1.010278 0.000000 - -0.239214 0.171157 -1.574760 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 450 - 1 - 0.000000 - - - - - - 0.783777 0.471682 0.403993 0.000000 - -0.111896 0.747116 -0.655208 0.000000 - -0.610879 0.468331 0.638351 0.000000 - - - - -0.039315 -0.008027 0.136791 0.000000 - - - 451 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 452 - 0 - 39 - 0 0 0 0 - - - -1.177451 -0.313997 0.398915 0.000000 - 1.069377 -0.273921 -0.523248 0.000000 - 1.099364 -0.308527 0.016317 0.000000 - 1.205500 -0.280144 -0.506242 0.000000 - 1.033586 -0.267031 -0.626097 0.000000 - 1.257766 -0.274035 -0.473626 0.000000 - 1.720857 -0.206347 -0.039977 0.000000 - 1.723996 -0.209033 0.023886 0.000000 - 1.721644 -0.206591 0.022695 0.000000 - 1.712949 -0.208441 -0.048878 0.000000 - 1.085854 -0.234643 0.423262 0.000000 - -0.240920 -0.030513 1.070469 0.000000 - -0.242437 -0.029997 1.067079 0.000000 - -0.038843 -0.054866 0.967434 0.000000 - -0.819129 -0.213945 0.848268 0.000000 - 0.853961 -0.213723 0.548869 0.000000 - -0.766477 -0.202092 0.884569 0.000000 - -0.843363 -0.222128 0.822072 0.000000 - -1.069507 -0.292303 0.583940 0.000000 - -1.214553 -0.330926 0.418689 0.000000 - -1.226373 -0.329786 0.409193 0.000000 - -1.343912 -0.308975 0.232126 0.000000 - -1.263346 -0.312783 -0.048927 0.000000 - -1.241174 -0.308194 -0.115690 0.000000 - -1.235872 -0.311703 -0.118241 0.000000 - 0.569251 -0.159613 -0.826739 0.000000 - -0.979217 -0.108974 -0.676434 0.000000 - 0.409288 -0.122225 -0.896048 0.000000 - -0.357106 0.016686 -0.956639 0.000000 - -0.918653 -0.045722 -0.770318 0.000000 - -0.848913 0.029849 -0.897381 0.000000 - 0.008915 0.004008 -1.005342 0.000000 - 0.371068 0.496971 -0.047765 0.000000 - -0.782643 0.367820 -0.219686 0.000000 - 0.186511 0.527309 0.401285 0.000000 - 0.590390 0.541594 0.152680 0.000000 - -1.205573 -0.059776 0.155390 0.000000 - -0.914495 0.335600 -0.278430 0.000000 - 1.711193 -0.197795 0.001132 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 453 - 1 - 0.000000 - - - - - - 0.748207 -0.095848 0.656506 0.000000 - -0.024094 0.984932 0.171257 0.000000 - -0.663028 -0.143953 0.734623 0.000000 - - - - 0.175614 -0.023224 0.070981 0.000000 - - - 454 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 455 - 0 - 42 - 0 0 0 0 - - - -0.232008 0.786908 -0.581310 0.000000 - -0.245557 0.545708 -0.061556 0.000000 - -0.071333 0.946874 0.053434 0.000000 - -0.338798 0.676917 -1.035415 0.000000 - -0.363636 0.610379 -1.240564 0.000000 - -0.316829 0.018889 -0.161453 0.000000 - -0.415561 0.524915 -1.557534 0.000000 - -0.413449 0.271415 -1.530556 0.000000 - -0.390057 0.524544 -1.522201 0.000000 - -0.414366 0.262839 -1.530434 0.000000 - -0.417505 0.269341 -1.527066 0.000000 - -0.219813 -0.506735 -0.244552 0.000000 - -0.311331 -0.285834 -1.523597 0.000000 - -0.293328 -0.322972 -1.523170 0.000000 - 0.036032 -0.979805 -0.302730 0.000000 - -0.137933 -0.662406 -1.550398 0.000000 - -0.047074 -0.872130 -0.770390 0.000000 - 0.008648 -0.988882 -0.293445 0.000000 - 0.029886 -1.460439 0.681473 0.000000 - 0.013041 -1.420257 0.675050 0.000000 - -0.251196 -1.171317 0.711211 0.000000 - -0.322382 -1.045766 0.731377 0.000000 - -0.515986 -0.697976 0.796099 0.000000 - -0.538459 -0.589712 0.816495 0.000000 - -0.620613 -0.171995 0.906790 0.000000 - -0.610528 -0.081958 0.925727 0.000000 - -0.555019 0.355300 1.032466 0.000000 - -0.517819 0.435890 1.051430 0.000000 - -0.073334 0.970407 0.120551 0.000000 - -0.325682 0.832545 1.160869 0.000000 - -0.072177 0.983728 0.155982 0.000000 - 0.048634 1.205099 0.929450 0.000000 - 0.027296 1.134353 0.698874 0.000000 - -0.253995 0.908577 1.181628 0.000000 - -0.021243 1.173851 1.271407 0.000000 - -0.123833 0.325919 -1.599604 0.000000 - 0.310910 0.181372 -1.377184 0.000000 - -0.045008 -0.417501 -1.581051 0.000000 - 0.379663 -0.826482 0.845420 0.000000 - 0.508052 -0.553732 0.878099 0.000000 - 0.490111 -0.488900 0.924566 0.000000 - 0.612158 0.347292 -0.533400 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 456 - 1 - 0.000000 - - - - - - 0.919872 -0.392053 -0.011445 0.000000 - 0.372815 0.864926 0.336023 0.000000 - -0.121840 -0.313365 0.941784 0.000000 - - - - 0.444965 -0.098839 -0.131652 0.000000 - - - 457 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 458 - 0 - 65 - 0 0 0 0 - - - -0.732271 -1.121580 0.351624 0.000000 - -0.372324 -1.036392 -0.221393 0.000000 - -0.584317 -1.130237 0.444061 0.000000 - -1.037894 -0.992018 0.175606 0.000000 - -0.851435 -0.858197 -0.399534 0.000000 - -1.173164 -0.933476 0.102031 0.000000 - -1.444036 -0.697600 -0.028888 0.000000 - -1.267234 -0.533624 -0.520711 0.000000 - -1.556901 -0.598563 -0.079202 0.000000 - -1.992917 1.151808 0.011664 0.000000 - -1.974217 1.147596 0.000232 0.000000 - -2.056253 0.896159 -0.025782 0.000000 - -2.038560 0.907586 -0.078316 0.000000 - -2.043211 0.734905 -0.063577 0.000000 - -2.030230 0.737337 -0.111616 0.000000 - -2.006030 0.360509 -0.157852 0.000000 - -2.011899 0.369378 -0.174034 0.000000 - -1.942862 0.242611 -0.196979 0.000000 - -1.962668 0.215200 -0.177119 0.000000 - -1.729480 -0.139386 -0.331237 0.000000 - -1.845919 -0.149627 -0.174334 0.000000 - -1.674456 -0.188886 -0.353500 0.000000 - -1.762142 -0.280072 -0.149744 0.000000 - -1.320810 -0.500744 -0.498887 0.000000 - -1.267538 -0.550520 -0.523433 0.000000 - -1.264001 -0.549165 -0.527152 0.000000 - -0.837638 -0.764510 -0.664692 0.000000 - -0.759284 -0.799319 -0.693009 0.000000 - -0.349934 -0.866876 -0.793777 0.000000 - -0.180283 -0.890109 -0.839294 0.000000 - 0.167501 -0.847887 -0.902350 0.000000 - 0.123204 -1.050672 -0.003704 0.000000 - 0.415769 -0.812880 -0.951672 0.000000 - 0.679806 -0.702398 -0.981596 0.000000 - 0.586596 -0.899558 0.232217 0.000000 - 0.935616 -0.591484 -1.000279 0.000000 - 0.920152 -0.604885 -1.009505 0.000000 - 1.102144 -0.465651 -0.857737 0.000000 - 0.972414 -0.597804 0.463251 0.000000 - 1.304456 -0.307790 -0.689172 0.000000 - 1.431648 -0.104474 -0.538402 0.000000 - 1.242811 -0.174962 0.666743 0.000000 - 1.554261 0.096428 -0.396554 0.000000 - 1.642559 0.873698 -0.053167 0.000000 - 1.598010 0.847851 0.082810 0.000000 - 1.632632 0.884597 -0.046668 0.000000 - 1.495575 0.793193 0.459369 0.000000 - 1.444146 0.363587 0.599831 0.000000 - 1.660255 0.581480 -0.151263 0.000000 - 1.428840 0.322255 0.612799 0.000000 - 1.613538 0.363368 -0.258438 0.000000 - 1.318561 0.034419 0.707176 0.000000 - 1.188359 -0.188509 0.775084 0.000000 - 1.165529 -0.214600 0.788541 0.000000 - 0.761895 -0.594683 0.917347 0.000000 - 0.655344 -0.686977 0.954346 0.000000 - 0.292579 -0.889905 0.989269 0.000000 - 0.355278 -0.858631 1.014562 0.000000 - 0.160515 -0.990609 0.914154 0.000000 - -0.129993 -1.095962 0.749266 0.000000 - 0.000850 -1.051586 0.844186 0.000000 - -0.277375 -1.144423 0.645158 0.000000 - 0.183605 -0.829677 0.993231 0.000000 - -1.301946 1.020850 0.427710 0.000000 - 0.568956 1.044166 -0.559733 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 459 - 1 - 0.000000 - - - - - - 0.821778 -0.130051 -0.554768 0.000000 - -0.115772 0.915190 -0.386036 0.000000 - 0.557922 0.381462 0.737027 0.000000 - - - - 0.085235 -0.220548 -0.156015 0.000000 - - - 460 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 461 - 0 - 62 - 0 0 0 0 - - - 1.142647 0.095341 1.823756 0.000000 - 1.047178 0.151866 1.849189 0.000000 - 0.061126 -0.135755 1.390421 0.000000 - 1.204931 -0.076810 1.666355 0.000000 - -0.095627 0.254574 1.557935 0.000000 - 0.975572 0.193933 1.856255 0.000000 - -1.400775 0.090275 1.414492 0.000000 - -0.692472 0.198865 1.502443 0.000000 - -1.392342 0.143955 1.424873 0.000000 - -1.414755 0.038019 1.392333 0.000000 - -1.459643 -0.162768 1.319843 0.000000 - -1.420806 -0.420513 1.211747 0.000000 - -1.414204 -0.437428 1.199382 0.000000 - 0.251981 -0.519617 1.060223 0.000000 - -1.309864 -0.822075 0.867811 0.000000 - -1.297587 -0.843003 0.835611 0.000000 - 0.441893 -0.773488 0.621586 0.000000 - -1.177648 -1.088639 0.417893 0.000000 - -1.157490 -1.103104 0.355265 0.000000 - 0.612269 -0.872440 0.117388 0.000000 - -1.036981 -1.194280 -0.094401 0.000000 - -1.009500 -1.183810 -0.189251 0.000000 - 0.746410 -0.806692 -0.403020 0.000000 - -0.901553 -1.128466 -0.619356 0.000000 - -0.870385 -1.074141 -0.736659 0.000000 - 0.831152 -0.582609 -0.888646 0.000000 - -0.784621 -0.897216 -1.105769 0.000000 - -0.755699 -0.786636 -1.225722 0.000000 - 0.858170 -0.222099 -1.291871 0.000000 - -0.697704 -0.522763 -1.505890 0.000000 - -0.677833 -0.354658 -1.603098 0.000000 - 0.824802 0.239522 -1.573140 0.000000 - -0.649404 -0.041574 -1.780221 0.000000 - -0.706784 0.695925 -1.889415 0.000000 - -0.658730 0.736592 -1.883874 0.000000 - -0.668648 0.702570 -1.892432 0.000000 - -0.100404 0.565887 -1.825600 0.000000 - -0.644519 0.499174 -1.901571 0.000000 - 0.212390 0.502190 -1.757227 0.000000 - -0.644645 0.172593 -1.829515 0.000000 - 0.788018 0.386174 -1.630899 0.000000 - 1.087587 0.339670 -1.471147 0.000000 - 1.239714 0.326819 -1.383692 0.000000 - 1.384714 0.052221 -1.121465 0.000000 - 1.327545 0.318017 -1.324946 0.000000 - 1.411868 -0.057374 -1.039913 0.000000 - 1.452614 -0.298540 -0.722123 0.000000 - 1.471876 -0.393372 -0.590052 0.000000 - 1.478366 -0.523403 -0.237484 0.000000 - 1.484768 -0.586998 -0.051838 0.000000 - 1.461820 -0.608890 0.286399 0.000000 - 1.449411 -0.619469 0.521562 0.000000 - 1.406423 -0.554605 0.804053 0.000000 - 1.369441 -0.488085 1.073717 0.000000 - 1.318295 -0.371251 1.274975 0.000000 - 1.252839 -0.206338 1.550646 0.000000 - -1.326723 0.788308 0.629516 0.000000 - -0.547117 1.095874 0.376454 0.000000 - -0.835057 0.862115 -1.273128 0.000000 - 0.986839 0.848904 1.028268 0.000000 - -1.455220 0.306201 1.219645 0.000000 - 1.021477 0.641703 1.298926 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 462 - 1 - 0.000000 - - - - - - 0.938503 0.047552 0.341982 0.000000 - 0.014153 0.984340 -0.175712 0.000000 - -0.344982 0.169746 0.923133 0.000000 - - - - 0.080155 0.054204 -0.163570 0.000000 - - - 463 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 464 - 0 - 63 - 0 0 0 0 - - - 0.277823 -0.285000 1.764780 0.000000 - 0.829025 -0.476250 0.751562 0.000000 - 0.295033 -0.003830 1.782071 0.000000 - 0.192192 -0.569704 1.688796 0.000000 - 0.591329 -0.962859 0.752211 0.000000 - 0.117148 -0.802808 1.628212 0.000000 - 0.113019 -0.825623 1.617186 0.000000 - 0.030347 -1.121243 1.315380 0.000000 - 0.226404 -1.357818 0.688461 0.000000 - -0.009718 -1.266838 1.167570 0.000000 - -0.214970 -1.608657 0.626656 0.000000 - -0.229942 -1.622457 0.566583 0.000000 - -0.223041 -1.620510 0.607648 0.000000 - -0.256950 -1.647968 0.528992 0.000000 - -0.831342 -1.893828 -0.712825 0.000000 - -0.762390 -1.854807 -0.422287 0.000000 - -0.975064 -1.883385 -0.772467 0.000000 - -0.997731 -1.878594 -0.743098 0.000000 - -0.517298 -1.938460 -0.656856 0.000000 - -0.598509 -1.837816 -0.135878 0.000000 - -0.305009 -1.904092 -0.634057 0.000000 - 0.014972 -1.849767 -0.606395 0.000000 - 0.204001 -1.755319 -0.604667 0.000000 - 0.500960 -1.604356 -0.608794 0.000000 - 0.648304 -1.463501 -0.626760 0.000000 - 0.893057 -1.226308 -0.663808 0.000000 - 0.986883 -1.057165 -0.697829 0.000000 - 1.152861 -0.752724 -0.766034 0.000000 - 1.188615 -0.574997 -0.810948 0.000000 - 0.916155 0.054318 0.686562 0.000000 - 1.254984 -0.230088 -0.905431 0.000000 - 1.235082 -0.062433 -0.955371 0.000000 - 0.844166 0.576824 0.563581 0.000000 - 1.189574 0.290349 -1.068310 0.000000 - 1.122238 0.432494 -1.117520 0.000000 - 0.620126 1.040037 0.394680 0.000000 - 0.963248 0.757672 -1.238703 0.000000 - 0.860659 0.863563 -1.282225 0.000000 - 0.266035 1.398565 0.196427 0.000000 - 0.598331 1.126325 -1.399949 0.000000 - 0.474343 1.190429 -1.434138 0.000000 - -0.183362 1.617311 -0.011739 0.000000 - 0.130542 1.360499 -1.536331 0.000000 - -0.638990 1.660686 -0.328929 0.000000 - -0.538602 1.588623 -0.754152 0.000000 - -0.768453 1.619767 -0.478412 0.000000 - -0.623658 1.661613 -0.305640 0.000000 - -0.102670 1.434913 -1.287104 0.000000 - -0.549692 1.665724 -0.189776 0.000000 - 0.105063 1.371101 -1.541985 0.000000 - -0.331040 1.667656 0.164684 0.000000 - -0.297769 1.666359 0.230229 0.000000 - -0.126105 1.558148 0.658707 0.000000 - -0.064309 1.514112 0.831334 0.000000 - 0.008968 1.351776 1.172409 0.000000 - 0.059544 1.224009 1.442449 0.000000 - 0.069169 1.081139 1.636377 0.000000 - 0.069061 1.090273 1.635370 0.000000 - 0.200902 0.807145 1.733675 0.000000 - 0.250816 0.566695 1.762658 0.000000 - 0.306579 0.269753 1.801043 0.000000 - -1.341094 0.558346 0.031408 0.000000 - -0.761021 0.562735 0.961962 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 465 - 1 - 0.000000 - - - - - - 0.941790 -0.040058 0.333808 0.000000 - 0.039058 0.999190 0.009709 0.000000 - -0.333926 0.003894 0.942591 0.000000 - - - - 0.031305 -0.016677 -0.006595 0.000000 - - - 466 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 467 - 0 - 35 - 0 0 0 0 - - - -1.201609 0.142060 -0.057478 0.000000 - 0.336939 0.338295 -0.478657 0.000000 - 0.213421 -0.036319 -0.849649 0.000000 - -1.273085 0.022821 -0.158440 0.000000 - -1.051429 0.398358 0.169487 0.000000 - -0.965094 0.476922 0.304840 0.000000 - 0.483291 0.573792 -0.013617 0.000000 - 0.182487 0.583012 0.089605 0.000000 - -0.941927 0.506761 0.348854 0.000000 - 0.499299 0.587885 0.022975 0.000000 - 0.791912 0.576340 -0.020251 0.000000 - 1.132900 0.579375 -0.083564 0.000000 - 1.168749 0.584655 -0.057860 0.000000 - 0.812455 0.406553 -0.421125 0.000000 - 0.719968 0.353829 -0.520649 0.000000 - 0.319813 0.009938 -0.839530 0.000000 - 0.295506 -0.012487 -0.859510 0.000000 - 0.168015 -0.123002 -0.909364 0.000000 - 0.206661 -0.100426 -0.907625 0.000000 - -0.429301 -0.441167 -0.832261 0.000000 - -0.459290 -0.450795 -0.816228 0.000000 - -0.445223 -0.427166 -0.834358 0.000000 - -0.969750 -0.179341 -0.431228 0.000000 - -1.305217 -0.017710 -0.185601 0.000000 - -1.298895 -0.055481 -0.197154 0.000000 - 1.125881 -0.126009 0.473700 0.000000 - 0.786736 -0.265305 0.616088 0.000000 - 0.475403 -0.424066 0.620849 0.000000 - 0.437978 -0.589021 0.297946 0.000000 - 0.801686 -0.396725 0.256333 0.000000 - 0.376039 -0.347536 0.751687 0.000000 - -0.784215 -0.019602 0.716260 0.000000 - -0.880708 -0.059803 0.547260 0.000000 - 0.430129 -0.589027 0.291514 0.000000 - -1.307274 -0.003833 -0.234572 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 468 - 1 - 0.000000 - - - - - - 0.906315 -0.079412 0.415075 0.000000 - -0.142047 0.867795 0.476187 0.000000 - -0.398016 -0.490535 0.775215 0.000000 - - - - -0.139952 -0.270917 -0.072032 0.000000 - - - 469 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 470 - 0 - 48 - 0 0 0 0 - - - -0.760568 -1.455847 -0.189445 0.000000 - -0.656653 -1.383128 -0.323220 0.000000 - -0.304131 -1.358251 -0.245512 0.000000 - -0.757263 -1.456110 -0.175972 0.000000 - -0.596520 -1.317091 -0.394496 0.000000 - 0.829258 -1.077000 -0.287166 0.000000 - 0.836435 -1.079528 -0.285402 0.000000 - -0.374871 -1.044484 -0.679372 0.000000 - 0.825387 -1.053671 -0.317215 0.000000 - -0.310772 -0.907750 -0.754972 0.000000 - 0.738012 -0.681304 -0.598446 0.000000 - -0.174367 -0.589526 -0.927940 0.000000 - 0.720674 -0.598865 -0.658412 0.000000 - -0.134992 -0.397948 -0.970856 0.000000 - 0.628182 -0.212684 -0.795733 0.000000 - -0.074920 -0.062971 -1.044347 0.000000 - 0.597036 -0.072207 -0.843132 0.000000 - -0.076471 0.151001 -1.034130 0.000000 - 0.507150 0.296408 -0.851606 0.000000 - -0.086361 0.483360 -1.017038 0.000000 - 0.466594 0.474438 -0.852889 0.000000 - -0.130696 0.682983 -0.951964 0.000000 - 0.384749 0.803563 -0.748136 0.000000 - -0.207603 0.995631 -0.848634 0.000000 - 0.342171 0.987127 -0.686585 0.000000 - -0.283855 1.150454 -0.743397 0.000000 - 0.272480 1.259997 -0.481171 0.000000 - -0.324650 1.248305 -0.686191 0.000000 - -0.237404 1.404422 -0.525568 0.000000 - 0.236017 1.415273 -0.360592 0.000000 - -0.141226 1.547767 -0.276150 0.000000 - 0.182472 1.615206 -0.063096 0.000000 - -0.039070 1.708693 0.010027 0.000000 - 0.158594 1.716681 0.092924 0.000000 - 0.133683 1.819989 0.431612 0.000000 - 0.046807 1.803313 0.381146 0.000000 - 0.149124 1.813067 0.426021 0.000000 - 0.050300 1.826158 0.439668 0.000000 - 0.059231 1.828584 0.445975 0.000000 - 0.582870 -0.138539 0.917726 0.000000 - 0.588429 -0.464624 1.012976 0.000000 - 0.668024 -0.479153 0.953664 0.000000 - -0.727033 0.170223 -0.018104 0.000000 - -0.365486 0.621320 0.863522 0.000000 - -0.143631 1.333779 0.609216 0.000000 - -0.776226 0.091212 -0.119933 0.000000 - -0.183468 -0.586849 1.201847 0.000000 - -0.348894 0.498193 0.904857 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 471 - 1 - 0.000000 - - - - - - 0.885320 -0.362470 0.291247 0.000000 - 0.419982 0.892165 -0.166302 0.000000 - -0.199561 0.269549 0.942082 0.000000 - - - - -0.051448 0.157000 0.135060 0.000000 - - - 472 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 473 - 0 - 43 - 0 0 0 0 - - - 0.069365 -1.403164 0.255719 0.000000 - 0.099274 -1.402098 0.236415 0.000000 - 0.037814 -1.419637 0.169482 0.000000 - 0.071556 -1.403279 0.252333 0.000000 - 0.262540 -1.222400 0.573208 0.000000 - 0.298547 -1.170923 0.646701 0.000000 - 0.242826 -1.113383 0.671359 0.000000 - 0.308578 -1.157994 0.665752 0.000000 - 0.531881 -0.803572 0.956404 0.000000 - 0.435664 -0.716624 0.985402 0.000000 - 0.549735 -0.779668 0.974647 0.000000 - 0.812658 -0.379591 1.114363 0.000000 - 0.658902 -0.250675 1.147712 0.000000 - 0.841195 -0.341051 1.125972 0.000000 - 1.114190 0.061045 1.109543 0.000000 - 0.890659 0.238793 1.142339 0.000000 - 1.154270 0.114673 1.104777 0.000000 - 1.413472 0.517246 0.946792 0.000000 - 1.290839 0.526497 0.968765 0.000000 - 1.384464 0.490584 0.955891 0.000000 - 1.059801 0.580019 1.026499 0.000000 - 1.322147 0.363925 1.003928 0.000000 - 0.066768 0.786023 0.960219 0.000000 - -0.930502 1.002348 0.882254 0.000000 - -1.204062 1.058915 0.844374 0.000000 - -1.158202 0.575324 0.887565 0.000000 - -1.242758 1.085025 0.851969 0.000000 - -1.127038 0.444134 0.869757 0.000000 - -1.023012 -0.058001 0.782322 0.000000 - -0.956379 -0.273495 0.687149 0.000000 - -0.853897 -0.623690 0.522881 0.000000 - -0.750136 -0.866448 0.313109 0.000000 - -0.667463 -1.065589 0.134762 0.000000 - -0.131337 -1.503188 -0.280024 0.000000 - -0.482084 -1.340001 -0.343584 0.000000 - -0.417937 -1.375910 -0.531897 0.000000 - -0.217065 -1.474183 -0.704194 0.000000 - -0.124086 -1.499123 -0.257256 0.000000 - -0.537850 -1.256602 -0.194159 0.000000 - 0.331969 -0.155722 -1.554628 0.000000 - 0.360862 0.608573 -1.804501 0.000000 - 0.787956 0.533029 -1.380197 0.000000 - -0.661318 0.865988 -0.979590 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 474 - 1 - 0.000000 - - - - - - 0.960485 0.181201 -0.211271 0.000000 - -0.127903 0.961510 0.243187 0.000000 - 0.247205 -0.206555 0.946691 0.000000 - - - - 0.073211 -0.023462 -0.040671 0.000000 - - - 475 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 476 - 0 - 46 - 0 0 0 0 - - - 0.481752 0.110122 1.382887 0.000000 - 0.566068 -0.091272 1.172183 0.000000 - 0.756601 -0.100826 1.154291 0.000000 - 0.219779 0.328488 1.513632 0.000000 - 0.022601 0.305199 1.452190 0.000000 - 0.270485 0.282767 1.494840 0.000000 - -0.765993 0.215654 1.240275 0.000000 - -0.753754 0.221656 1.222889 0.000000 - 0.304591 0.259182 1.486437 0.000000 - -0.706677 0.026426 1.053668 0.000000 - -0.661015 -0.184540 0.866895 0.000000 - -0.658490 -0.312110 0.646731 0.000000 - 0.638656 -0.362576 0.709202 0.000000 - -0.661542 -0.464133 0.378687 0.000000 - -0.694417 -0.512748 0.162113 0.000000 - 0.699834 -0.476849 0.183522 0.000000 - -0.755373 -0.589507 -0.193682 0.000000 - -0.799181 -0.579726 -0.348879 0.000000 - 0.743615 -0.422973 -0.353335 0.000000 - -0.868581 -0.578996 -0.604792 0.000000 - -0.762402 -0.557041 -0.708768 0.000000 - 0.241819 0.091323 -1.377565 0.000000 - 0.144822 0.081690 -1.405500 0.000000 - 0.195385 0.158645 -1.440702 0.000000 - 0.336888 0.015989 -1.261353 0.000000 - -0.072330 -0.116272 -1.253343 0.000000 - 0.674832 -0.239984 -0.854446 0.000000 - -0.295545 -0.310014 -1.101575 0.000000 - 0.683273 -0.244061 -0.842014 0.000000 - -0.643589 -0.499386 -0.804514 0.000000 - 0.725920 -0.262007 -0.781531 0.000000 - 0.843931 -0.321743 -0.615468 0.000000 - 0.892046 -0.401875 -0.408899 0.000000 - 0.905007 -0.418191 -0.362572 0.000000 - 0.979168 -0.448856 0.090451 0.000000 - 0.995176 -0.451749 0.171290 0.000000 - 1.040282 -0.346121 0.592222 0.000000 - 1.054061 -0.317725 0.694293 0.000000 - 0.799513 -0.128233 1.097689 0.000000 - 1.053961 -0.287258 0.766578 0.000000 - 0.668016 0.430127 -0.441199 0.000000 - 0.149137 0.661585 -1.201420 0.000000 - 0.455430 0.563474 -0.158629 0.000000 - 0.165057 0.667857 -1.195568 0.000000 - 0.756708 0.316409 -0.356091 0.000000 - -1.116300 0.308661 0.054726 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 477 - 1 - 0.000000 - - - - - - 0.995299 -0.074969 -0.061317 0.000000 - 0.082247 0.988568 0.126368 0.000000 - 0.051143 -0.130817 0.990086 0.000000 - - - - 0.009026 -0.253688 0.115282 0.000000 - - - 478 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 479 - 0 - 76 - 0 0 0 0 - - - 0.154058 -1.071807 -0.073258 0.000000 - -1.503407 -0.913743 -0.231005 0.000000 - 0.165981 -0.643423 -0.403491 0.000000 - 0.193077 -0.134755 -0.585589 0.000000 - -1.269717 0.004743 -0.724808 0.000000 - 0.232694 0.404471 -0.601799 0.000000 - -1.372918 -0.496667 -0.549954 0.000000 - 1.680033 -0.726625 -0.738037 0.000000 - 0.158481 -1.377983 0.372883 0.000000 - -1.648436 -1.205668 0.200913 0.000000 - -1.203879 0.541469 -0.738522 0.000000 - 0.280962 0.921573 -0.450557 0.000000 - 0.957009 1.451256 -0.164515 0.000000 - 0.333163 1.366023 -0.146624 0.000000 - 0.384199 1.694359 0.280340 0.000000 - 0.476951 1.686623 0.218534 0.000000 - 1.006360 1.428794 -0.203547 0.000000 - 1.006757 1.331799 -0.305686 0.000000 - 1.030944 1.104464 -0.471480 0.000000 - 1.061277 0.874359 -0.636949 0.000000 - 1.112899 0.671442 -0.711421 0.000000 - 1.204595 0.338458 -0.831286 0.000000 - 1.253418 0.207123 -0.840928 0.000000 - 1.422570 -0.222862 -0.869562 0.000000 - 1.444202 -0.268386 -0.859700 0.000000 - 1.611888 -0.598095 -0.784296 0.000000 - 1.683901 -0.740775 -0.765612 0.000000 - 1.693457 -0.751143 -0.763862 0.000000 - 1.701716 -0.781745 -0.756889 0.000000 - 1.708896 -1.139066 -0.465326 0.000000 - 1.711343 -1.173814 -0.438866 0.000000 - 1.708401 -1.171178 -0.445872 0.000000 - 1.702939 -1.481848 0.012648 0.000000 - 1.692782 -1.511080 0.076485 0.000000 - 1.510123 -1.560880 0.320515 0.000000 - 1.143568 -1.506028 0.336214 0.000000 - 1.696939 -1.496911 0.057556 0.000000 - 0.158678 -1.396424 0.365023 0.000000 - -0.177019 -1.375559 0.369776 0.000000 - -1.544274 -1.297932 0.392041 0.000000 - -1.612818 -1.232806 0.214829 0.000000 - -1.634164 -1.217414 0.163159 0.000000 - -1.641243 -1.212166 0.162848 0.000000 - -1.840775 -0.931778 -0.325488 0.000000 - -1.898149 -0.856266 -0.448237 0.000000 - -1.920678 -0.584396 -0.682887 0.000000 - -1.940839 -0.753316 -0.552959 0.000000 - -1.901427 -0.428428 -0.808104 0.000000 - -1.860161 -0.136116 -0.918734 0.000000 - -1.834071 0.081570 -0.999248 0.000000 - -1.809392 0.239870 -1.009722 0.000000 - -1.695276 0.366806 -0.966552 0.000000 - -1.600168 0.471103 -0.934531 0.000000 - -1.513831 0.553868 -0.900144 0.000000 - -1.148348 0.870389 -0.653404 0.000000 - -0.973725 1.024648 -0.591016 0.000000 - -0.898023 1.086267 -0.542169 0.000000 - -0.506180 1.439177 -0.244769 0.000000 - -0.239477 1.610882 0.010512 0.000000 - -0.399770 1.521495 -0.137532 0.000000 - -0.021091 1.732805 0.212691 0.000000 - 0.359344 1.723705 0.312107 0.000000 - 0.186608 1.808640 0.463858 0.000000 - 0.440407 1.699052 0.240052 0.000000 - -1.860851 -0.238882 -0.394427 0.000000 - -1.862012 -0.236567 -0.396398 0.000000 - -1.858142 -0.224919 -0.391540 0.000000 - -0.559822 0.457445 0.864663 0.000000 - -1.510746 -0.505040 0.478557 0.000000 - -1.480789 -0.611584 0.569311 0.000000 - -1.377970 0.638620 -0.676452 0.000000 - -1.800541 0.173125 -0.787956 0.000000 - 0.026790 1.105804 1.045175 0.000000 - 0.512564 0.474904 0.867363 0.000000 - 1.539099 0.057740 -0.267894 0.000000 - 1.245122 0.879672 -0.166033 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 480 - 1 - 0.000000 - - - - - - 0.895167 0.432078 -0.109476 0.000000 - -0.405676 0.891526 0.201515 0.000000 - 0.184671 -0.135978 0.973348 0.000000 - - - - 0.139111 -0.321140 0.290806 0.000000 - - - 481 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 482 - 0 - 64 - 0 0 0 0 - - - -0.111250 1.727903 0.890612 0.000000 - -0.292561 1.749827 0.369965 0.000000 - -0.246195 1.731091 0.934322 0.000000 - 0.242517 1.602990 0.773879 0.000000 - 0.166971 1.582117 0.137734 0.000000 - 0.379309 1.552541 0.732283 0.000000 - 0.675238 1.323227 0.641284 0.000000 - 0.558088 1.263410 -0.059093 0.000000 - 0.799544 1.224684 0.606764 0.000000 - 1.011598 0.918585 0.548869 0.000000 - 0.842424 0.824918 -0.201211 0.000000 - 1.108159 0.776542 0.526397 0.000000 - 1.220148 0.427311 0.505257 0.000000 - 0.992091 0.309631 -0.274680 0.000000 - 1.274890 0.252210 0.499065 0.000000 - 1.281320 -0.104325 0.514538 0.000000 - 0.992425 -0.231924 -0.272301 0.000000 - 1.283528 -0.296753 0.527401 0.000000 - 1.189242 -0.626325 0.575887 0.000000 - 0.843428 -0.746654 -0.194325 0.000000 - 1.133483 -0.816505 0.608538 0.000000 - 0.952159 -1.089589 0.683671 0.000000 - 0.559755 -1.184127 -0.048422 0.000000 - 0.839715 -1.256287 0.734438 0.000000 - 0.591480 -1.450260 0.828029 0.000000 - 0.169259 -1.501530 0.151085 0.000000 - 0.431108 -1.573345 0.892733 0.000000 - 0.139761 -1.673285 0.995772 0.000000 - -0.289774 -1.667857 0.384634 0.000000 - -0.022646 -1.725899 1.031465 0.000000 - -0.004533 -1.731742 1.050568 0.000000 - -0.562120 -1.683133 0.505647 0.000000 - -0.865572 -1.719988 0.213151 0.000000 - -0.713655 -1.718585 0.050529 0.000000 - -0.600462 -1.721877 -0.083767 0.000000 - -0.410173 -1.634008 -0.345103 0.000000 - -0.282591 -1.570861 -0.529451 0.000000 - -0.161533 -1.420524 -0.741644 0.000000 - -0.046126 -1.268668 -0.956119 0.000000 - 0.012060 -1.090964 -1.109082 0.000000 - 0.085894 -0.845320 -1.321931 0.000000 - 0.093624 -0.667805 -1.416299 0.000000 - 0.100846 -0.342665 -1.591221 0.000000 - 0.072343 -0.183455 -1.634364 0.000000 - -0.002308 0.189915 -1.738006 0.000000 - -0.054252 0.321680 -1.740031 0.000000 - -0.179090 0.644718 -1.751080 0.000000 - -0.179706 0.671228 -1.729701 0.000000 - -0.181039 0.817904 -1.571142 0.000000 - -0.199936 1.152866 -1.208065 0.000000 - -0.247525 1.354026 -0.863603 0.000000 - -0.293292 1.519641 -0.577558 0.000000 - -0.420223 1.695667 -0.024500 0.000000 - -0.450710 1.734382 0.099566 0.000000 - -0.593957 1.762032 0.554035 0.000000 - -0.683867 1.749734 0.806823 0.000000 - -0.623958 1.733617 1.066197 0.000000 - -0.706862 1.719299 1.014510 0.000000 - -0.715334 1.729674 0.896981 0.000000 - -0.751649 1.715869 0.974978 0.000000 - -0.650247 1.732154 1.075709 0.000000 - -1.174250 -0.572103 0.115811 0.000000 - -1.169212 -0.641891 0.059691 0.000000 - -1.107324 -0.943645 0.118092 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 483 - 1 - 0.000000 - - - - - - 1.000000 0.000000 0.000000 0.000000 - 0.000000 1.000000 0.000000 0.000000 - 0.000000 0.000000 1.000000 0.000000 - - - - 0.000000 0.000000 0.000000 0.000000 - - - 484 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 485 - 0 - 8 - 0 0 0 0 - - - -17.020262 -1.407098 13.169413 0.000000 - 17.020262 -1.407098 13.169413 0.000000 - -17.020262 1.407098 13.169413 0.000000 - 17.020262 1.407098 13.169413 0.000000 - -17.020262 1.407098 -13.169413 0.000000 - 17.020262 1.407098 -13.169413 0.000000 - -17.020262 -1.407098 -13.169413 0.000000 - 17.020262 -1.407098 -13.169413 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 486 - 1 - 0.000000 - - - - - - 0.780502 -0.501667 0.373024 0.000000 - 0.382838 0.855276 0.349196 0.000000 - -0.494218 -0.129741 0.859602 0.000000 - - - - 0.213697 0.164281 -0.102246 0.000000 - - - 487 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 488 - 0 - 50 - 0 0 0 0 - - - -1.048270 -0.003646 0.367004 0.000000 - -1.004334 0.578821 -0.385466 0.000000 - -1.399631 0.213131 -0.436926 0.000000 - -1.300280 0.056219 -0.056548 0.000000 - -0.700763 -0.090131 0.951035 0.000000 - -0.689995 -0.114464 0.967955 0.000000 - -0.678243 -0.088534 1.008855 0.000000 - -0.670743 -0.096060 1.031832 0.000000 - -0.394537 -0.142089 1.544629 0.000000 - -0.190932 0.086846 1.023797 0.000000 - -0.299137 -0.141722 1.751979 0.000000 - -0.282042 -0.137113 1.751617 0.000000 - 0.037914 -0.059728 1.622470 0.000000 - 0.347592 0.138322 1.011600 0.000000 - 0.271742 -0.007074 1.531072 0.000000 - 0.780866 0.039435 1.091981 0.000000 - 0.872910 0.034847 0.932520 0.000000 - 0.839792 0.043716 1.041657 0.000000 - 0.955329 0.040704 0.883105 0.000000 - 1.591628 -0.316762 -0.841206 0.000000 - 1.530222 -0.207937 -0.784693 0.000000 - 1.539774 -0.210945 -0.577598 0.000000 - 1.591407 -0.295206 -0.857023 0.000000 - 1.404037 0.065640 -0.635279 0.000000 - 1.491666 -0.117054 -0.212907 0.000000 - 1.277571 0.198894 -0.561575 0.000000 - 1.294731 -0.012812 0.324674 0.000000 - 1.051268 0.433426 -0.438693 0.000000 - 1.245646 0.005750 0.457789 0.000000 - 0.903060 0.515266 -0.395471 0.000000 - 0.582233 0.690192 -0.310681 0.000000 - 0.448766 0.720439 -0.296601 0.000000 - 0.043086 0.810860 -0.263746 0.000000 - -0.042700 0.806901 -0.267530 0.000000 - -0.513204 0.783766 -0.302398 0.000000 - -0.534390 0.776923 -0.305370 0.000000 - -0.744473 0.706892 -0.354967 0.000000 - -1.040455 0.630257 -0.414915 0.000000 - -1.068376 0.623358 -0.425477 0.000000 - -1.471988 0.388540 -0.573985 0.000000 - -1.486879 0.385082 -0.577024 0.000000 - -1.493587 0.344201 -0.570897 0.000000 - -1.504660 0.077443 -0.493200 0.000000 - -1.537829 0.090871 -0.516564 0.000000 - -1.385776 0.069694 -0.238754 0.000000 - 1.027518 -0.455593 -0.770992 0.000000 - -0.421382 -0.684209 0.066134 0.000000 - -0.930391 -0.516950 -0.631769 0.000000 - -1.304484 0.064361 -0.728171 0.000000 - -1.341581 -0.166663 -0.687520 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 489 - 1 - 0.000000 - - - - - - 0.810132 0.479821 0.336834 0.000000 - -0.320998 0.843836 -0.430002 0.000000 - -0.490557 0.240236 0.837640 0.000000 - - - - 0.060836 0.167956 0.071016 0.000000 - - - 490 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 491 - 0 - 29 - 0 0 0 0 - - - -0.243518 -0.458576 -0.976009 0.000000 - -0.313628 0.196007 0.457069 0.000000 - -0.174062 -0.176103 -1.324129 0.000000 - -0.222905 -0.574481 -0.700884 0.000000 - -0.221927 -0.276309 0.705720 0.000000 - -0.186586 -0.740334 -0.320933 0.000000 - 0.087762 -0.923172 0.666392 0.000000 - -0.013105 -0.742476 0.801916 0.000000 - 0.019950 -0.904871 0.465991 0.000000 - -0.020820 -0.724443 0.811285 0.000000 - -0.040739 -0.857592 0.243644 0.000000 - -0.051138 -0.650887 0.850078 0.000000 - -0.165379 -0.155788 0.981801 0.000000 - -0.177862 -0.067972 1.007458 0.000000 - -0.192252 0.414295 1.023354 0.000000 - -0.193943 0.401391 1.026099 0.000000 - -0.205604 0.470608 0.938893 0.000000 - -0.195970 0.753440 0.515222 0.000000 - -0.236340 0.663884 0.195525 0.000000 - -0.192703 0.802807 0.443602 0.000000 - -0.166072 0.866314 0.325827 0.000000 - -0.180060 0.805218 0.103235 0.000000 - -0.066101 0.313981 -1.052562 0.000000 - -0.149068 -0.090187 -1.436364 0.000000 - -0.032039 0.134172 -1.509359 0.000000 - -0.088127 0.023357 -1.495727 0.000000 - 0.206604 0.593221 0.481284 0.000000 - 0.598444 0.109619 -0.008264 0.000000 - -0.028259 0.132205 -1.463063 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 492 - 1 - 0.000000 - - - - - - 0.860363 -0.506807 0.054068 0.000000 - 0.458324 0.815709 0.352929 0.000000 - -0.222970 -0.278866 0.934087 0.000000 - - - - -0.024495 -0.107537 0.018802 0.000000 - - - 493 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 494 - 0 - 33 - 0 0 0 0 - - - 0.647772 -0.095041 0.602946 0.000000 - 0.555914 -0.342086 0.529317 0.000000 - 0.628928 -0.388792 0.502723 0.000000 - 0.657172 -0.071779 0.616564 0.000000 - 0.417475 -0.421678 0.489845 0.000000 - 0.606498 -0.639547 0.317255 0.000000 - 0.020220 -0.641997 0.381850 0.000000 - 0.590270 -0.873674 0.138884 0.000000 - -0.042105 -0.647094 0.371671 0.000000 - 0.487028 -1.069881 -0.117089 0.000000 - 0.572297 -0.995592 -0.010911 0.000000 - -0.200238 -0.658255 0.347187 0.000000 - -0.437094 -0.839413 0.093466 0.000000 - 0.381704 -1.164026 -0.248773 0.000000 - -0.565294 -0.780612 0.267912 0.000000 - -0.594369 -0.799080 0.273259 0.000000 - -0.619102 -0.798885 0.279664 0.000000 - -0.416320 -0.845085 0.118061 0.000000 - -0.301971 -0.901501 0.035876 0.000000 - 0.281033 -1.208845 -0.400076 0.000000 - -0.211275 1.123779 -0.205747 0.000000 - -0.244592 1.170771 -0.029992 0.000000 - 0.150454 1.157113 -0.205534 0.000000 - -0.256118 1.174050 -0.027927 0.000000 - 0.676304 1.017611 0.185525 0.000000 - 0.651342 1.100414 -0.223374 0.000000 - 0.231108 -0.935590 -0.578631 0.000000 - -0.816789 0.236220 -0.369256 0.000000 - 0.592372 0.096259 -0.398043 0.000000 - -0.912500 0.184577 -0.210463 0.000000 - -0.813188 0.518488 0.147904 0.000000 - -0.900642 -0.469737 0.321829 0.000000 - -0.853290 -0.134833 0.392557 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 495 - 1 - 0.000000 - - - - - - 0.962658 -0.085875 0.256738 0.000000 - 0.033146 0.978609 0.203043 0.000000 - -0.268683 -0.186951 0.944912 0.000000 - - - - 0.243952 -0.167843 -0.107657 0.000000 - - - 496 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 497 - 0 - 43 - 0 0 0 0 - - - 1.039976 -0.108249 -0.169325 0.000000 - 0.905066 -0.319821 0.050472 0.000000 - 0.794078 -0.303017 -0.216702 0.000000 - 1.039528 -0.097062 -0.191442 0.000000 - 0.853159 -0.404392 0.141926 0.000000 - 0.646718 -0.606430 0.465508 0.000000 - 0.304618 -0.532170 -0.243587 0.000000 - 0.499191 -0.740690 0.686869 0.000000 - 0.511045 -0.742476 0.680184 0.000000 - 0.278546 -0.780029 0.729074 0.000000 - -0.231940 -0.602574 -0.235285 0.000000 - -0.024052 -0.832709 0.794098 0.000000 - -0.703880 -0.522510 -0.216837 0.000000 - -0.014991 -0.837833 0.791266 0.000000 - -1.302165 0.002468 -0.784536 0.000000 - -1.314230 0.000256 -0.757004 0.000000 - -1.272623 -0.022456 -0.766681 0.000000 - -1.252216 -0.025885 -0.763960 0.000000 - -1.158700 -0.132309 -0.811803 0.000000 - -1.161573 -0.144658 -0.708667 0.000000 - -0.836069 -0.297143 -0.891389 0.000000 - -0.745842 -0.499192 -0.282004 0.000000 - -0.673481 -0.376057 -0.934647 0.000000 - -0.739967 -0.504005 -0.266646 0.000000 - -0.337627 -0.431707 -0.987744 0.000000 - -0.131165 -0.461975 -1.023902 0.000000 - 0.177349 -0.419102 -1.048308 0.000000 - 0.415054 -0.382052 -1.070911 0.000000 - 0.665611 -0.264492 -1.069008 0.000000 - 0.872487 -0.178494 -0.966309 0.000000 - 0.760375 -0.224303 -1.069039 0.000000 - 1.107037 0.010239 -0.687306 0.000000 - 1.114994 0.017549 -0.673707 0.000000 - 1.111975 0.006293 -0.685023 0.000000 - 0.056356 0.295370 1.364438 0.000000 - -0.140872 -0.026765 1.403259 0.000000 - -0.111233 -0.076802 1.412362 0.000000 - 0.013543 -0.015142 1.412095 0.000000 - 0.113506 0.473936 1.269224 0.000000 - -0.016960 0.848783 0.746618 0.000000 - -1.033109 0.285337 0.039500 0.000000 - 0.396809 0.690147 -0.776451 0.000000 - 0.494986 0.758336 -0.670775 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 498 - 1 - 0.000000 - - - - - - 0.697870 0.210095 0.684717 0.000000 - -0.214436 0.973445 -0.080131 0.000000 - -0.683370 -0.090908 0.724391 0.000000 - - - - -0.125315 -0.183984 0.084187 0.000000 - - - 499 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 500 - 0 - 34 - 0 0 0 0 - - - -1.184960 0.576836 0.275827 0.000000 - 0.337760 0.605606 0.386486 0.000000 - 0.194225 1.046593 0.106815 0.000000 - -1.195611 0.751712 0.168237 0.000000 - -1.172156 0.280085 0.452807 0.000000 - -1.146518 0.095373 0.499298 0.000000 - 0.466276 0.094776 0.512405 0.000000 - -1.104714 -0.248312 0.580897 0.000000 - -1.066889 -0.429834 0.568661 0.000000 - 0.567170 -0.435812 0.472212 0.000000 - -0.999886 -0.782050 0.540261 0.000000 - -0.943182 -1.012559 0.452262 0.000000 - -0.471797 -0.913392 0.422315 0.000000 - -0.952233 -0.949512 0.471323 0.000000 - 0.605057 -0.716851 0.374971 0.000000 - 1.632071 -0.429464 0.037709 0.000000 - 2.010179 -0.347214 -0.061042 0.000000 - 1.971534 -0.192664 0.004115 0.000000 - 1.840365 0.004848 0.056239 0.000000 - 1.652602 0.295126 0.125626 0.000000 - 1.353084 0.546963 0.139195 0.000000 - 1.131104 0.735987 0.144561 0.000000 - 0.564056 1.028715 0.072283 0.000000 - 0.456121 1.084747 0.056772 0.000000 - 0.110322 1.184487 -0.028509 0.000000 - -0.864847 0.958895 0.006729 0.000000 - -0.143829 1.214627 -0.113674 0.000000 - -1.190741 0.793487 0.136273 0.000000 - -1.072256 0.889853 0.049593 0.000000 - -0.462825 -0.498466 -0.851359 0.000000 - -0.336014 -0.213396 -0.886964 0.000000 - 1.154708 -0.375943 -0.386440 0.000000 - -0.772446 -0.638158 -0.594604 0.000000 - -0.371101 -0.013886 -0.801080 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 501 - 1 - 0.000000 - - - - - - 0.699558 -0.557454 0.447061 0.000000 - 0.404350 0.824645 0.395552 0.000000 - -0.589169 -0.095942 0.802294 0.000000 - - - - -0.025514 0.253344 -0.170900 0.000000 - - - 502 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 503 - 0 - 51 - 0 0 0 0 - - - 1.082339 -0.155548 0.781795 0.000000 - 0.564684 0.009453 1.015651 0.000000 - 0.555036 -0.363211 1.315045 0.000000 - 1.292523 -0.082644 0.565195 0.000000 - 1.286599 0.063480 0.332471 0.000000 - 0.481343 0.350320 0.603464 0.000000 - 1.353016 -0.060145 0.484241 0.000000 - 1.220246 0.219009 0.166790 0.000000 - 1.093918 0.343546 -0.082102 0.000000 - 0.329570 0.551425 0.124464 0.000000 - 0.999589 0.435832 -0.275998 0.000000 - 0.847683 0.468344 -0.540159 0.000000 - 0.124256 0.593175 -0.374444 0.000000 - 0.734184 0.489786 -0.744904 0.000000 - 0.572815 0.427637 -0.996073 0.000000 - -0.114495 0.471571 -0.844464 0.000000 - 0.449980 0.375526 -1.194066 0.000000 - 0.296360 0.227957 -1.405764 0.000000 - -0.363332 0.198571 -1.239668 0.000000 - 0.174810 0.104160 -1.579481 0.000000 - 0.044452 -0.109388 -1.731248 0.000000 - -0.597940 -0.199107 -1.521465 0.000000 - -0.064344 -0.297760 -1.863348 0.000000 - -0.592661 -0.270997 -1.571095 0.000000 - -0.089363 -0.352450 -1.893898 0.000000 - -0.595877 -0.412681 -1.661463 0.000000 - -0.601846 -0.177429 -1.530514 0.000000 - -0.606275 -0.171318 -1.524506 0.000000 - -0.622496 0.233904 -1.233457 0.000000 - -0.630721 0.324230 -1.164358 0.000000 - -0.638255 0.564286 -0.859220 0.000000 - -0.647323 0.694326 -0.688902 0.000000 - -0.648228 0.799962 -0.418142 0.000000 - -0.654473 0.903386 -0.145560 0.000000 - -0.650907 0.915699 0.074351 0.000000 - -0.651427 0.932212 0.412223 0.000000 - -0.644686 0.881362 0.587195 0.000000 - -0.638392 0.779198 0.930702 0.000000 - -0.628670 0.674913 1.072232 0.000000 - -0.616547 0.459496 1.360758 0.000000 - -0.603375 0.294222 1.470767 0.000000 - 0.530680 -0.372351 1.334433 0.000000 - -0.587985 0.003253 1.661526 0.000000 - 0.524610 -0.375012 1.339161 0.000000 - -0.420921 -0.320529 1.679014 0.000000 - -0.571005 -0.235829 1.724407 0.000000 - -0.572777 -0.296984 1.747690 0.000000 - 0.335598 -0.440747 1.436121 0.000000 - 0.224059 -0.482836 -1.299346 0.000000 - -0.562317 -0.808284 0.010329 0.000000 - -0.557747 -0.804363 0.417170 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 504 - 1 - 0.000000 - - - - - - 0.769113 0.194984 0.608643 0.000000 - 0.230726 0.803394 -0.548930 0.000000 - -0.596013 0.562619 0.572913 0.000000 - - - - -0.296284 0.293714 0.154533 0.000000 - - - 505 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 506 - 0 - 69 - 0 0 0 0 - - - 0.630671 1.490238 0.952471 0.000000 - 0.610549 1.505064 0.878866 0.000000 - 0.118578 1.682096 0.683647 0.000000 - 0.518016 1.504643 1.036335 0.000000 - 0.557648 1.570285 0.643020 0.000000 - -0.003910 1.730709 0.586645 0.000000 - 0.492715 1.552012 0.297891 0.000000 - -0.262744 1.723123 0.080301 0.000000 - -0.274061 1.780008 0.366679 0.000000 - 0.459023 1.538694 0.100418 0.000000 - 0.415150 1.396583 -0.233717 0.000000 - -0.227180 1.486225 -0.405136 0.000000 - 0.397498 1.325455 -0.394012 0.000000 - 0.382516 1.076484 -0.661660 0.000000 - -0.230697 1.113391 -0.797438 0.000000 - 0.379114 0.951554 -0.791721 0.000000 - 0.708405 -1.521566 -0.613645 0.000000 - 0.742246 -1.363709 -0.760519 0.000000 - 0.783562 -1.500659 -0.684655 0.000000 - -0.527381 -1.692602 0.862963 0.000000 - -0.523885 -1.691407 0.852578 0.000000 - -0.532458 -1.682369 0.853229 0.000000 - -0.857521 -1.638953 0.460547 0.000000 - -0.319297 -1.778731 0.476163 0.000000 - -0.743257 -1.653824 0.672590 0.000000 - -0.857755 -1.638990 0.458385 0.000000 - -0.103977 -1.773179 0.192035 0.000000 - -0.900218 -1.617804 0.385224 0.000000 - -0.861644 -1.600916 0.348748 0.000000 - -0.870638 -1.628285 0.434611 0.000000 - -0.517322 -1.609668 -0.025373 0.000000 - 0.086663 -1.766907 -0.047918 0.000000 - -0.425765 -1.571702 -0.132068 0.000000 - 0.509619 -1.624046 -0.469202 0.000000 - -0.134993 -1.430227 -0.493347 0.000000 - 0.560699 -1.607731 -0.510712 0.000000 - -0.031781 -1.282568 -0.646884 0.000000 - 0.711896 -1.273906 -0.836678 0.000000 - 0.104351 -1.073917 -0.859178 0.000000 - 0.709193 -1.261424 -0.846238 0.000000 - 0.139725 -0.853224 -0.961291 0.000000 - 0.603603 -0.821272 -1.035691 0.000000 - 0.177544 -0.575958 -1.087295 0.000000 - 0.579267 -0.710322 -1.082120 0.000000 - 0.144727 -0.366588 -1.112163 0.000000 - 0.511076 -0.338458 -1.128561 0.000000 - 0.077296 0.015209 -1.155292 0.000000 - 0.474667 -0.119138 -1.153666 0.000000 - 0.026264 0.140953 -1.135897 0.000000 - 0.438398 0.159301 -1.106829 0.000000 - -0.186987 0.641292 -1.055960 0.000000 - 0.405696 0.453683 -1.053572 0.000000 - -0.194148 0.652964 -1.051126 0.000000 - 0.392636 0.645554 -0.954872 0.000000 - -0.230721 0.706430 -1.027865 0.000000 - -0.451754 1.088528 -0.901025 0.000000 - -0.499108 1.160064 -0.876414 0.000000 - -0.753777 1.441818 -0.679385 0.000000 - -0.876841 1.568428 -0.588885 0.000000 - -0.668309 1.710359 -0.201936 0.000000 - -0.889644 1.586838 -0.585134 0.000000 - -0.583134 1.761533 -0.051919 0.000000 - -0.413492 1.787600 0.251395 0.000000 - 0.742051 -0.146358 0.706092 0.000000 - 0.802135 -0.268486 0.512915 0.000000 - 0.791094 0.055048 0.699333 0.000000 - 0.189881 -0.186233 1.107006 0.000000 - -0.161853 -1.061794 1.016209 0.000000 - 0.483701 -0.321197 0.872791 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 507 - 1 - 0.000000 - - - - - - 0.977161 -0.204508 -0.057733 0.000000 - 0.211052 0.965664 0.151492 0.000000 - 0.024769 -0.160217 0.986771 0.000000 - - - - 0.020288 0.143868 0.269107 0.000000 - - - 508 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 509 - 0 - 50 - 0 0 0 0 - - - 0.098246 0.888906 -0.461909 0.000000 - 0.628068 0.539523 1.583877 0.000000 - 1.103100 0.380538 1.378689 0.000000 - 0.420872 0.617405 -0.801526 0.000000 - -0.269227 0.360981 -2.116015 0.000000 - 0.637346 0.220506 -1.099581 0.000000 - 0.726409 -0.262929 -1.326841 0.000000 - 0.174896 -0.009716 -1.847626 0.000000 - -0.270872 0.364642 -2.121370 0.000000 - -0.366337 0.609225 -2.042734 0.000000 - -0.358747 0.606602 -2.049167 0.000000 - -0.280008 0.710842 -1.746109 0.000000 - -0.183274 0.838432 -1.400839 0.000000 - -0.124953 0.946266 -0.830807 0.000000 - -0.112774 0.973203 -0.688523 0.000000 - -0.161249 0.974688 -0.198338 0.000000 - -0.193477 0.969053 0.032989 0.000000 - -0.577930 0.503593 1.510417 0.000000 - -0.574498 0.497611 1.512572 0.000000 - -0.750501 0.562479 1.209197 0.000000 - -0.761740 0.560755 1.214207 0.000000 - -0.451309 0.516960 1.535276 0.000000 - -0.559693 0.712604 0.942880 0.000000 - 0.074091 0.591355 1.637260 0.000000 - -0.425039 0.821585 0.743187 0.000000 - 0.098345 0.589570 1.639088 0.000000 - -0.212611 0.954025 0.114220 0.000000 - 0.291646 0.570415 1.657514 0.000000 - 0.630252 0.543701 1.692436 0.000000 - 0.666725 0.537614 1.699057 0.000000 - 1.060967 0.404892 1.596751 0.000000 - 1.010035 0.417975 1.697043 0.000000 - 1.106634 0.396910 1.516780 0.000000 - 1.183286 0.349212 1.301541 0.000000 - 1.307904 0.205011 0.837074 0.000000 - 1.312982 0.155608 0.714958 0.000000 - 1.336169 -0.096904 0.177503 0.000000 - 1.283994 -0.266928 -0.103973 0.000000 - 1.219791 -0.480551 -0.439784 0.000000 - 0.947759 -0.872231 -1.012235 0.000000 - 0.969719 -0.907903 -0.953261 0.000000 - 0.976218 -0.912878 -0.963251 0.000000 - 0.872552 -0.757480 -1.143367 0.000000 - 1.046921 -0.774908 -0.797412 0.000000 - 0.727368 -0.538367 -1.394960 0.000000 - 0.374239 -0.189106 -1.689678 0.000000 - -0.639907 -1.149648 0.869428 0.000000 - -0.671292 -1.210605 0.802031 0.000000 - -1.454164 -0.216953 -0.251262 0.000000 - -0.709922 0.324521 -1.714827 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 510 - 1 - 0.000000 - - - - - - 0.795920 0.448524 0.406618 0.000000 - -0.135227 0.786394 -0.602743 0.000000 - -0.590106 0.424749 0.686559 0.000000 - - - - -0.066894 0.293589 0.139174 0.000000 - - - 511 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 512 - 0 - 45 - 0 0 0 0 - - - -1.264341 0.725895 0.109276 0.000000 - -1.258929 0.715984 0.144787 0.000000 - -1.555965 0.332206 -0.333987 0.000000 - -1.652693 0.312398 0.055866 0.000000 - -1.245621 0.742661 0.109765 0.000000 - -1.233649 0.744727 0.120237 0.000000 - -0.407910 1.226950 0.306139 0.000000 - -0.902632 0.781026 -0.257657 0.000000 - 0.119559 1.529972 0.433871 0.000000 - 0.296075 1.591529 0.466466 0.000000 - -0.482430 0.705470 -0.590458 0.000000 - 0.280661 1.607435 0.474334 0.000000 - 0.592817 1.510389 0.188076 0.000000 - 1.136956 0.384267 -0.496115 0.000000 - 1.160482 0.508223 -0.464142 0.000000 - 1.155063 0.330660 -0.523008 0.000000 - 0.950217 0.599272 -0.508421 0.000000 - 1.182972 0.808930 -0.341800 0.000000 - 0.707667 0.665473 -0.525386 0.000000 - 1.055923 1.217680 -0.096817 0.000000 - 1.166519 1.122605 -0.143504 0.000000 - 0.306888 0.767466 -0.556733 0.000000 - 0.999589 1.269964 -0.074576 0.000000 - 0.141458 0.750585 -0.569250 0.000000 - 0.670240 1.463649 0.134839 0.000000 - -0.420940 0.706319 -0.600754 0.000000 - -0.370242 0.702629 -0.606743 0.000000 - -0.493834 0.713443 -0.592536 0.000000 - -0.496683 0.709480 -0.594489 0.000000 - -0.988756 0.596034 -0.512683 0.000000 - -1.082678 0.569169 -0.500273 0.000000 - -1.461672 0.348556 -0.419498 0.000000 - -1.528307 0.321995 -0.410653 0.000000 - 0.683371 0.881755 0.664051 0.000000 - 0.511524 0.044609 0.721060 0.000000 - 0.733898 0.852955 0.620265 0.000000 - -0.153728 -1.201054 0.674258 0.000000 - 0.422486 -1.762130 0.001609 0.000000 - 0.161031 -1.356732 0.793581 0.000000 - 0.132460 -1.561977 -0.221053 0.000000 - 0.431533 -1.769562 -0.012377 0.000000 - -0.762575 -0.795223 0.450709 0.000000 - 0.098195 -1.487586 -0.383624 0.000000 - 0.666139 -1.663858 -0.458812 0.000000 - 0.848540 -1.065640 -0.561610 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 513 - 1 - 0.000000 - - - - - - 0.666992 0.337554 -0.664213 0.000000 - -0.443753 0.896095 0.009788 0.000000 - 0.598502 0.288218 0.747479 0.000000 - - - - 0.053015 -0.300733 0.024304 0.000000 - - - 514 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 515 - 0 - 62 - 0 0 0 0 - - - -0.015088 -1.485293 -1.024312 0.000000 - -0.042853 -1.490780 -0.489220 0.000000 - -0.177322 -1.535921 -1.064891 0.000000 - 0.294294 -1.267201 -0.957367 0.000000 - 0.388256 -1.184417 -0.373801 0.000000 - 0.422585 -1.174492 -0.932911 0.000000 - 0.649423 -0.868436 -0.903073 0.000000 - 0.702128 -0.756133 -0.267983 0.000000 - 0.743399 -0.738492 -0.894274 0.000000 - 0.862645 -0.384171 -0.903744 0.000000 - 0.867947 -0.247840 -0.182142 0.000000 - 0.915752 -0.220096 -0.912215 0.000000 - 0.920776 0.133103 -0.932814 0.000000 - 0.869403 0.290664 -0.124701 0.000000 - 0.921655 0.029687 -0.940914 0.000000 - 0.920184 0.319376 -0.918133 0.000000 - 0.812618 0.666570 -0.915375 0.000000 - 0.706316 0.806585 -0.101298 0.000000 - 0.756106 0.842396 -0.917975 0.000000 - 0.551578 1.137378 -0.948062 0.000000 - 0.394664 1.249331 -0.114230 0.000000 - 0.442113 1.291613 -0.968142 0.000000 - 0.168228 1.502979 -1.025925 0.000000 - -0.034985 1.575500 -0.162227 0.000000 - 0.009206 1.622809 -1.063685 0.000000 - -0.390682 1.745963 -0.619509 0.000000 - -0.540486 1.753144 -0.240575 0.000000 - -0.027034 1.648800 -1.072632 0.000000 - -0.489854 1.773580 -0.496882 0.000000 - -0.696502 1.771100 -0.245787 0.000000 - -0.724241 1.707255 0.115185 0.000000 - -0.808580 1.754511 -0.118081 0.000000 - -0.675577 1.674469 0.272076 0.000000 - -0.513013 1.497960 0.710879 0.000000 - -0.400275 1.363620 1.035044 0.000000 - -0.310121 1.201693 1.263621 0.000000 - -0.165032 0.925297 1.651043 0.000000 - -0.129452 0.822868 1.731485 0.000000 - -0.087485 0.701202 1.827628 0.000000 - 0.039275 0.445907 1.895170 0.000000 - 0.059329 0.379324 1.898303 0.000000 - 0.182944 -0.084847 1.929127 0.000000 - 0.184973 -0.135252 1.922108 0.000000 - 0.182367 -0.626562 1.867977 0.000000 - 0.175133 -0.659683 1.856525 0.000000 - 0.037855 -1.126697 1.717785 0.000000 - 0.027538 -1.146379 1.705435 0.000000 - -0.120837 -1.476971 1.248736 0.000000 - 0.004404 -1.207921 1.674783 0.000000 - -0.170809 -1.528912 1.068131 0.000000 - -0.344058 -1.681007 0.525269 0.000000 - -0.533893 -1.706445 -0.061669 0.000000 - -0.548928 -1.645298 -0.602937 0.000000 - -0.612891 -1.715115 -0.295501 0.000000 - -0.735482 -1.656263 -0.665344 0.000000 - -0.789087 -1.660130 -0.824473 0.000000 - -0.617942 -1.650838 -1.023159 0.000000 - -0.517185 -1.641532 -1.062068 0.000000 - -0.596731 -1.652480 -1.048799 0.000000 - -0.290701 -1.573756 -1.092181 0.000000 - -0.144428 -0.049661 -1.249842 0.000000 - -0.355512 -0.998288 -1.187238 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 516 - 1 - 0.000000 - - - - - - 0.727518 0.297961 -0.618010 0.000000 - 0.299931 0.672017 0.677077 0.000000 - 0.617056 -0.677947 0.399537 0.000000 - - - - -0.153050 0.197006 -0.151022 0.000000 - - - 517 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 518 - 0 - 40 - 0 0 0 0 - - - 0.484764 0.181296 -0.431911 0.000000 - -0.956799 0.246973 0.141485 0.000000 - 0.737998 0.156741 0.045559 0.000000 - -0.814631 0.227478 0.663133 0.000000 - 0.986265 -0.033143 0.487277 0.000000 - 1.314449 0.343740 -0.351688 0.000000 - 1.311504 0.261583 -0.141509 0.000000 - 1.172099 0.355423 -0.596860 0.000000 - 1.124849 0.359951 -0.681455 0.000000 - 0.996397 0.328552 -0.741791 0.000000 - 0.449784 0.130030 -0.914930 0.000000 - 0.251314 0.038193 -0.898450 0.000000 - 0.357021 0.094970 -0.945544 0.000000 - 0.169068 -0.014348 -0.981409 0.000000 - -0.413599 -0.225829 -1.164273 0.000000 - -0.825318 -0.198007 -0.994493 0.000000 - -0.835356 -0.187595 -0.947374 0.000000 - -0.335441 -0.213641 -1.138808 0.000000 - -0.863504 -0.111353 -0.817892 0.000000 - -0.958379 0.124820 -0.404117 0.000000 - -0.960602 0.134003 -0.372553 0.000000 - -0.984554 0.194179 -0.135932 0.000000 - -1.026298 0.296302 0.130189 0.000000 - -1.033667 0.294350 0.145538 0.000000 - -1.027759 0.302127 0.141241 0.000000 - -0.864019 0.268264 0.637688 0.000000 - -0.856531 0.265952 0.665408 0.000000 - -0.737556 0.171842 0.861000 0.000000 - -0.787622 0.198790 0.850319 0.000000 - -0.331099 0.059018 0.990464 0.000000 - 0.645572 -0.176680 0.921041 0.000000 - -0.107941 -0.042786 1.036322 0.000000 - 0.160125 -0.144744 1.101258 0.000000 - 1.147285 -0.213381 0.734486 0.000000 - 1.269692 0.032865 0.367315 0.000000 - 1.138742 -0.208288 0.747512 0.000000 - 1.316243 0.102002 0.249545 0.000000 - -0.828755 -0.092702 0.673475 0.000000 - -0.824820 -0.091211 0.683182 0.000000 - -0.062964 -0.207829 -1.008848 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 519 - 1 - 0.000000 - - - - - - 0.697191 0.452889 0.555713 0.000000 - -0.528603 0.848399 -0.028240 0.000000 - -0.484255 -0.274063 0.830895 0.000000 - - - - 0.159321 0.103551 0.096018 0.000000 - - - 520 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 521 - 0 - 30 - 0 0 0 0 - - - -0.143671 -0.304132 1.240610 0.000000 - -0.391904 -0.087774 -1.166004 0.000000 - 0.121734 -0.215051 -1.051097 0.000000 - -0.551143 0.031323 -1.346195 0.000000 - -0.305006 -0.026335 -1.503399 0.000000 - -0.606002 0.009318 -1.207839 0.000000 - -0.203617 -0.044507 -1.571527 0.000000 - 0.116059 -0.077849 -1.695069 0.000000 - 0.174139 -0.101576 -1.632220 0.000000 - 0.281748 -0.149504 -1.534060 0.000000 - 0.608516 -0.216632 -0.933590 0.000000 - 0.643697 -0.174654 -0.913029 0.000000 - 0.614179 -0.217285 -0.923858 0.000000 - 0.620969 -0.220862 -0.892005 0.000000 - 0.932765 -0.080453 0.334333 0.000000 - 0.790601 -0.119102 0.458098 0.000000 - 0.414857 -0.268864 0.814926 0.000000 - 0.333476 -0.277942 0.883037 0.000000 - -0.043162 -0.318891 1.199858 0.000000 - -0.150224 -0.321484 1.283096 0.000000 - -0.133291 -0.337127 1.270088 0.000000 - -0.121263 -0.332881 1.271122 0.000000 - -0.337973 -0.293819 1.189977 0.000000 - -0.642209 -0.213021 1.055077 0.000000 - -0.734097 -0.033053 -0.127078 0.000000 - -0.661911 -0.203365 1.036168 0.000000 - -0.863831 -0.075234 0.887690 0.000000 - 0.263399 0.491845 0.693106 0.000000 - -0.120624 0.267785 -0.964763 0.000000 - 0.217403 0.515874 0.663400 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 522 - 1 - 0.000000 - - - - - - 0.940066 -0.069037 -0.333930 0.000000 - 0.025310 0.990716 -0.133570 0.000000 - 0.340051 0.117113 0.933086 0.000000 - - - - -0.170465 -0.144877 -0.006843 0.000000 - - - 523 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 524 - 0 - 29 - 0 0 0 0 - - - 1.141971 -0.319053 0.250459 0.000000 - -0.429467 -0.343152 0.022254 0.000000 - -0.127644 -0.325591 -0.426649 0.000000 - 1.187009 -0.314567 0.183315 0.000000 - 0.900493 -0.331889 0.636481 0.000000 - 0.800675 -0.300756 0.722653 0.000000 - -0.727121 -0.192908 0.448709 0.000000 - 0.485023 -0.187868 1.008461 0.000000 - 0.099788 0.027701 1.208152 0.000000 - -0.869761 0.045006 0.830858 0.000000 - -0.859930 0.079537 0.849466 0.000000 - 0.281353 -0.073851 1.109129 0.000000 - -0.880816 0.000662 0.718571 0.000000 - -0.936371 -0.207721 0.298407 0.000000 - -0.953086 -0.243782 0.209851 0.000000 - -1.001377 -0.373760 -0.322605 0.000000 - -1.018208 -0.436524 -0.528351 0.000000 - -1.020391 -0.432271 -0.529372 0.000000 - -0.812913 -0.420760 -0.765924 0.000000 - -0.669621 -0.409987 -0.934816 0.000000 - -0.663858 -0.415802 -0.938647 0.000000 - 0.146934 -0.185973 -0.798530 0.000000 - 1.319125 -0.138257 -0.309786 0.000000 - 0.206638 -0.179937 -0.792019 0.000000 - 1.304934 0.073834 -0.640283 0.000000 - 1.296476 -0.168107 -0.230905 0.000000 - -0.723939 0.482305 -0.304083 0.000000 - 0.409357 0.607186 -0.248312 0.000000 - -0.835975 0.427140 -0.203366 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 525 - 1 - 0.000000 - - - - - - 0.709605 -0.648802 0.274803 0.000000 - 0.440886 0.713083 0.545098 0.000000 - -0.549618 -0.265647 0.792055 0.000000 - - - - -0.091277 0.142486 -0.005874 0.000000 - - - 526 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 527 - 0 - 50 - 0 0 0 0 - - - -0.742900 0.548696 0.562127 0.000000 - 0.211123 0.044223 0.420503 0.000000 - -0.619780 0.937982 0.490058 0.000000 - -0.792283 0.401834 0.543681 0.000000 - -0.075894 -0.410754 0.363466 0.000000 - -0.926897 0.032941 0.491525 0.000000 - -0.986365 -0.118971 0.417612 0.000000 - -0.337107 -0.830054 0.143118 0.000000 - -1.018587 -0.471856 0.260191 0.000000 - -0.984026 -0.131441 0.421104 0.000000 - -1.014383 -0.712112 0.058646 0.000000 - -0.547000 -1.172715 -0.218995 0.000000 - -1.014235 -0.933402 -0.133083 0.000000 - -1.007884 -1.032952 -0.253487 0.000000 - -0.562332 -1.176898 -0.192572 0.000000 - -0.471142 -1.242999 -0.165440 0.000000 - 0.002640 -1.581739 -0.045896 0.000000 - -0.004310 -1.576374 -0.087033 0.000000 - 0.250290 -1.584576 0.080235 0.000000 - 0.292989 -1.586159 0.109512 0.000000 - 0.371555 -1.528669 0.207931 0.000000 - 0.396673 -1.417139 0.294361 0.000000 - 0.440279 -1.241361 0.363430 0.000000 - 0.535123 -0.898257 0.495283 0.000000 - 0.615245 -0.636215 0.514520 0.000000 - 0.709175 -0.349219 0.532897 0.000000 - 0.823580 -0.030176 0.455601 0.000000 - 0.495897 0.490420 0.308610 0.000000 - 0.901757 0.175989 0.403067 0.000000 - 1.034921 0.493132 0.204249 0.000000 - 0.750583 0.884203 0.038653 0.000000 - 1.093902 0.625598 0.118315 0.000000 - 1.186575 0.790063 -0.062296 0.000000 - 0.821166 0.989093 -0.061385 0.000000 - 0.120916 1.379235 -0.018407 0.000000 - 0.162745 1.412331 -0.047343 0.000000 - -0.034824 1.286290 0.158890 0.000000 - -0.242834 1.161334 0.291487 0.000000 - -0.518770 1.002129 0.460097 0.000000 - -0.616785 0.943152 0.493147 0.000000 - 0.348761 -1.540481 0.188254 0.000000 - 0.339028 -1.559854 0.105078 0.000000 - 0.379115 -1.488374 -0.044736 0.000000 - 0.543042 -1.161242 -0.139833 0.000000 - -0.515420 1.034410 -0.306691 0.000000 - -0.492806 1.058179 -0.329897 0.000000 - -0.531057 0.344067 -0.618160 0.000000 - -0.675642 0.073386 -0.551393 0.000000 - 0.961354 -0.065827 -0.445498 0.000000 - -0.656673 0.928239 0.142077 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 528 - 1 - 0.000000 - - - - - - 0.924541 -0.032198 -0.379719 0.000000 - -0.183508 0.835671 -0.517667 0.000000 - 0.333988 0.548286 0.766704 0.000000 - - - - 0.057490 0.080270 -0.032472 0.000000 - - - 529 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 530 - 0 - 53 - 0 0 0 0 - - - -0.303040 -0.349334 1.257611 0.000000 - -0.560185 -0.698504 0.454506 0.000000 - -0.229958 -1.067541 0.673707 0.000000 - -0.129696 -0.691120 1.235242 0.000000 - -0.402293 -0.141443 1.273601 0.000000 - -0.474982 0.166974 1.242628 0.000000 - -0.741636 -0.263259 0.188128 0.000000 - -0.534490 0.442132 1.218192 0.000000 - -0.527505 0.694160 1.152012 0.000000 - -0.756507 0.195520 -0.099308 0.000000 - -0.514237 1.002175 1.075003 0.000000 - -0.450036 1.189594 0.989054 0.000000 - -0.603353 0.632849 -0.379621 0.000000 - -0.344625 1.484429 0.858461 0.000000 - -0.240788 1.609699 0.762612 0.000000 - -0.297227 1.005864 -0.625331 0.000000 - -0.090947 1.798774 0.625243 0.000000 - -0.073202 1.793410 0.572363 0.000000 - 0.121768 1.332376 -0.721725 0.000000 - 0.214115 1.644362 -0.262825 0.000000 - 0.355095 1.533163 -0.570785 0.000000 - 0.106736 1.314578 -0.732677 0.000000 - 0.077782 1.713092 0.121229 0.000000 - 0.060186 1.258475 -0.767438 0.000000 - -0.203078 0.855284 -0.982519 0.000000 - -0.264252 0.748191 -1.042202 0.000000 - -0.410108 0.321650 -1.214394 0.000000 - -0.485883 0.083803 -1.321858 0.000000 - -0.500617 0.074361 -1.315706 0.000000 - -0.561444 -0.163097 -1.212026 0.000000 - -0.629731 -0.400744 -1.110817 0.000000 - -0.620175 -0.646126 -0.989858 0.000000 - -0.606801 -0.894630 -0.872103 0.000000 - -0.517537 -1.115066 -0.751938 0.000000 - -0.419439 -1.349424 -0.629145 0.000000 - -0.262955 -1.525232 -0.520888 0.000000 - -0.086164 -1.720611 -0.405748 0.000000 - 0.103425 -1.692890 -0.034874 0.000000 - 0.216639 -1.334211 0.824257 0.000000 - 0.032398 -1.800549 -0.352133 0.000000 - 0.218452 -1.530143 0.486449 0.000000 - 0.316483 -1.369146 0.855923 0.000000 - 0.319395 -1.202126 1.075523 0.000000 - 0.389426 -1.256537 1.051428 0.000000 - 0.256970 -1.152383 1.106455 0.000000 - -0.030193 -0.816213 1.199411 0.000000 - 0.488830 -0.327370 -0.977278 0.000000 - 0.611731 1.107533 -0.566427 0.000000 - 0.973802 0.175013 0.309435 0.000000 - 0.993975 0.057333 0.357415 0.000000 - 0.559331 -0.666944 -0.808820 0.000000 - 0.922787 0.243158 0.349601 0.000000 - 0.991635 0.037713 0.365930 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 531 - 1 - 0.000000 - - - - - - 0.998862 -0.041799 0.022972 0.000000 - 0.045531 0.979103 -0.198201 0.000000 - -0.014207 0.199021 0.979892 0.000000 - - - - -0.311999 0.143146 0.171851 0.000000 - - - 532 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 533 - 0 - 50 - 0 0 0 0 - - - -1.159148 0.455282 -0.240084 0.000000 - 0.152039 0.400769 1.032666 0.000000 - 0.451766 0.552115 0.608325 0.000000 - -0.983073 0.430428 -0.751259 0.000000 - 0.775596 0.536143 0.174968 0.000000 - -0.814641 0.239719 -1.229061 0.000000 - 1.091840 0.354319 -0.224987 0.000000 - -0.670355 -0.098257 -1.626672 0.000000 - 1.369519 0.024361 -0.552345 0.000000 - -1.325635 0.311946 0.254429 0.000000 - -0.519799 -0.248415 1.499730 0.000000 - -0.525137 -0.255221 1.489452 0.000000 - -0.865977 -0.105583 1.164668 0.000000 - 0.021006 0.302729 1.147025 0.000000 - -0.223100 0.127568 1.300114 0.000000 - 0.164230 0.418113 1.061149 0.000000 - 0.178622 0.425899 1.056043 0.000000 - 0.561734 0.577574 0.813845 0.000000 - 0.628478 0.600647 0.776072 0.000000 - 0.985424 0.606346 0.551679 0.000000 - 1.098976 0.605822 0.484966 0.000000 - 1.405664 0.493567 0.292999 0.000000 - 1.544174 0.441425 0.211108 0.000000 - 1.786496 0.237510 0.059997 0.000000 - 1.920874 0.123834 -0.018970 0.000000 - 1.846856 -0.222495 -0.413771 0.000000 - 2.089611 -0.149403 -0.123790 0.000000 - 2.160202 -0.219473 -0.154037 0.000000 - 1.517400 -0.234720 -0.710097 0.000000 - -0.022092 -0.323349 -1.520360 0.000000 - -0.418302 -0.347456 -1.739985 0.000000 - -0.613561 -0.109290 -1.646987 0.000000 - -0.649733 -0.057468 -1.625553 0.000000 - -0.652820 -0.063115 -1.625019 0.000000 - -0.984147 0.251943 -1.293498 0.000000 - -1.019500 0.277812 -1.261753 0.000000 - -1.265290 0.442081 -0.874083 0.000000 - -1.313592 0.468732 -0.803732 0.000000 - -1.468477 0.490448 -0.391147 0.000000 - -1.507411 0.492998 -0.295734 0.000000 - -1.533028 0.364997 0.139525 0.000000 - -1.520591 0.466083 -0.193502 0.000000 - -1.536387 0.342106 0.217117 0.000000 - -1.419831 0.086858 0.630057 0.000000 - -1.495856 0.125695 0.568533 0.000000 - -1.323543 0.064301 0.736923 0.000000 - -0.251476 0.105858 1.318964 0.000000 - -1.443371 0.068535 0.504817 0.000000 - -0.963311 -0.528363 0.289228 0.000000 - -0.284447 -0.551269 1.360752 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 534 - 1 - 0.000000 - - - - - - 0.983455 0.178784 0.029208 0.000000 - -0.155868 0.917274 -0.366488 0.000000 - -0.092314 0.355872 0.929964 0.000000 - - - - -0.302572 -0.071095 0.018698 0.000000 - - - 535 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 536 - 0 - 51 - 0 0 0 0 - - - -1.276630 -0.347839 0.081864 0.000000 - -0.884273 -0.381309 -0.263622 0.000000 - -1.266424 -0.424532 0.375883 0.000000 - -1.209098 -0.075261 -0.466148 0.000000 - -1.141381 -0.025963 -0.580262 0.000000 - -1.202490 -0.045317 -0.523565 0.000000 - -1.158157 0.055071 -0.664326 0.000000 - -1.141982 0.112000 -0.783389 0.000000 - -0.893136 0.125658 -1.324272 0.000000 - -0.780420 0.012970 -1.412421 0.000000 - -0.766555 -0.012693 -1.431778 0.000000 - -0.670765 -0.254565 -1.327464 0.000000 - -0.574555 -0.378096 -1.242722 0.000000 - -0.368539 -0.632143 -1.071738 0.000000 - -0.249336 -0.706124 -0.983404 0.000000 - -0.541125 -0.597088 0.094703 0.000000 - 0.028967 -0.872159 -0.787495 0.000000 - 0.161801 -0.896610 -0.701087 0.000000 - -0.145451 -0.652138 0.459695 0.000000 - 0.482773 -0.951338 -0.502542 0.000000 - 0.620713 -0.925712 -0.423212 0.000000 - 0.264063 -0.540989 0.795645 0.000000 - 0.948548 -0.862132 -0.244668 0.000000 - 1.884000 0.048945 0.106722 0.000000 - 1.803628 -0.041864 0.123393 0.000000 - 1.822964 -0.062263 0.114024 0.000000 - 1.621836 -0.188562 0.235859 0.000000 - 1.737695 -0.229124 0.094476 0.000000 - 1.326778 -0.300891 0.384249 0.000000 - 1.496918 -0.488573 0.007336 0.000000 - 0.951111 -0.436081 0.576863 0.000000 - 1.380900 -0.613321 -0.038977 0.000000 - 0.782195 -0.454858 0.651666 0.000000 - 1.081636 -0.785983 -0.178411 0.000000 - 0.355294 -0.501617 0.841153 0.000000 - 0.111918 -0.517119 0.945977 0.000000 - -0.050151 -0.517774 1.021439 0.000000 - -0.777688 -0.480378 1.318155 0.000000 - -0.940595 -0.481975 1.388363 0.000000 - -1.109222 -0.517840 1.260888 0.000000 - -1.178014 -0.514759 1.156037 0.000000 - -1.170528 -0.518503 1.200749 0.000000 - -1.257939 -0.508500 0.722169 0.000000 - 1.884392 0.381726 0.036714 0.000000 - -0.195730 0.477912 -1.187114 0.000000 - -0.401393 0.546656 -1.113659 0.000000 - -0.344617 1.061243 0.404696 0.000000 - -0.274614 1.122430 0.624410 0.000000 - 1.178238 0.629746 0.253628 0.000000 - -0.365505 0.906619 0.840276 0.000000 - -0.808766 0.057044 1.215537 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 537 - 1 - 0.000000 - - - - - - 0.859792 -0.134780 0.492536 0.000000 - 0.206668 0.973859 -0.094277 0.000000 - -0.466954 0.182849 0.865171 0.000000 - - - - 0.005828 0.161011 0.074764 0.000000 - - - 538 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 539 - 0 - 23 - 0 0 0 0 - - - 0.576709 0.779019 0.201091 0.000000 - 0.622014 0.769384 0.152621 0.000000 - 0.213249 0.837096 -0.138389 0.000000 - 0.156826 0.843684 0.130754 0.000000 - 0.733182 0.755958 0.040641 0.000000 - 1.093614 0.583411 -0.257817 0.000000 - 0.860520 0.652537 -0.229249 0.000000 - 0.983991 0.627756 -0.193781 0.000000 - 0.238287 0.823146 -0.225899 0.000000 - -0.205618 0.922249 -0.222440 0.000000 - -0.594757 1.012577 -0.182463 0.000000 - -0.613356 1.012343 -0.229797 0.000000 - -0.594453 1.008775 -0.001495 0.000000 - 0.324479 -1.111246 -0.221902 0.000000 - 1.292363 -0.119134 -0.247719 0.000000 - 0.887928 -0.429701 0.254754 0.000000 - 0.621701 -0.154591 0.454370 0.000000 - -0.936082 -0.313478 0.314019 0.000000 - -0.846277 -1.075228 -0.211507 0.000000 - -1.045215 -0.123371 -0.201052 0.000000 - -1.114715 0.407163 0.099400 0.000000 - -1.114476 0.403216 0.037218 0.000000 - -0.756090 0.846390 -0.221430 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 540 - 1 - 0.000000 - - - - - - 0.825115 0.470222 0.313171 0.000000 - -0.536547 0.825794 0.173728 0.000000 - -0.176924 -0.311376 0.933672 0.000000 - - - - -0.170513 -0.184021 0.245260 0.000000 - - - 541 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 542 - 0 - 49 - 0 0 0 0 - - - 0.128328 -0.468416 -0.867718 0.000000 - -0.379797 -1.105786 0.592634 0.000000 - -0.392544 -0.332163 -0.920980 0.000000 - -0.864320 -0.923939 0.434906 0.000000 - -0.859548 -0.090803 -0.876810 0.000000 - -1.302165 -0.611998 0.374733 0.000000 - -0.858236 -0.090551 -0.877796 0.000000 - -0.852047 -0.089755 -0.881862 0.000000 - -0.453613 -0.252381 -1.169863 0.000000 - -0.363846 -0.285216 -1.237381 0.000000 - -0.019513 -0.322638 -1.413021 0.000000 - 0.179285 -0.339244 -1.517977 0.000000 - 0.447237 -0.294359 -1.605294 0.000000 - 0.657987 -0.444861 -0.759496 0.000000 - 0.726381 -0.242561 -1.700161 0.000000 - 0.705445 -0.262690 -1.702564 0.000000 - 0.957603 -0.221284 -1.345359 0.000000 - 1.144620 -0.263715 -0.606871 0.000000 - 1.148461 -0.193993 -1.085021 0.000000 - 1.459949 -0.048625 -0.432567 0.000000 - 1.606111 0.490230 0.827580 0.000000 - 1.537909 0.279210 0.804319 0.000000 - 1.613522 0.306784 0.498975 0.000000 - 1.453419 0.010846 0.803500 0.000000 - 1.623096 0.217235 0.308655 0.000000 - 1.311361 -0.210287 0.793691 0.000000 - 1.509032 -0.021187 -0.309516 0.000000 - 1.119420 -0.500964 0.786176 0.000000 - 1.504421 -0.022618 -0.332135 0.000000 - 0.980876 -0.621492 0.776329 0.000000 - 0.662619 -0.892785 0.760535 0.000000 - 0.575296 -0.931927 0.753732 0.000000 - 0.128560 -1.126910 0.729095 0.000000 - 0.121764 -1.128079 0.727219 0.000000 - 0.023452 -1.136625 0.722623 0.000000 - -0.439140 -1.213339 0.694247 0.000000 - -0.501990 -1.222288 0.695892 0.000000 - -0.957520 -1.146138 0.664692 0.000000 - -1.080796 -1.125237 0.661117 0.000000 - -1.409481 -0.917355 0.637240 0.000000 - -1.539550 -0.835592 0.631607 0.000000 - -1.694118 -0.606287 0.618593 0.000000 - -1.585614 -0.281760 0.379242 0.000000 - -1.335728 0.174582 -0.487030 0.000000 - -1.581107 -0.164099 0.232417 0.000000 - -1.501231 0.359797 -0.298854 0.000000 - -1.238057 0.118349 -0.566602 0.000000 - -0.000050 1.258564 0.716904 0.000000 - -0.667967 1.181175 -0.122934 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 543 - 1 - 0.000000 - - - - - - 0.954362 0.282772 -0.096087 0.000000 - -0.292493 0.949986 -0.109425 0.000000 - 0.060339 0.132536 0.989340 0.000000 - - - - -0.104428 0.232843 -0.144961 0.000000 - - - 544 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 545 - 0 - 68 - 0 0 0 0 - - - -0.800600 -0.565477 -0.251842 0.000000 - -0.497804 -0.311604 1.142815 0.000000 - -0.881692 -0.038647 -0.343886 0.000000 - -0.573369 0.219860 1.076226 0.000000 - -0.804488 0.475269 -0.494106 0.000000 - -0.480124 0.747226 0.999891 0.000000 - -0.576489 0.926038 -0.687837 0.000000 - -0.227134 1.218948 0.921267 0.000000 - -0.219923 1.269557 -0.906153 0.000000 - -0.931362 -0.536345 -0.440012 0.000000 - -1.000391 -0.090271 -0.521433 0.000000 - -0.917860 -0.623807 -0.427656 0.000000 - -0.750821 -1.031460 -0.441462 0.000000 - -0.569152 -1.053750 -0.226960 0.000000 - -0.709839 -1.131820 -0.448757 0.000000 - -0.476788 -1.453790 -0.545100 0.000000 - -0.209944 -1.455753 -0.271678 0.000000 - -0.396871 -1.564333 -0.582608 0.000000 - -0.135583 -1.776899 -0.736654 0.000000 - 0.241950 -1.732171 -0.381647 0.000000 - -0.087557 -1.822431 -0.760692 0.000000 - -0.000802 -1.851324 -0.747088 0.000000 - 0.375960 -1.781680 -0.402691 0.000000 - 0.097334 -1.871017 -0.729627 0.000000 - 0.871911 -1.746296 0.191247 0.000000 - 0.892561 -1.731697 0.188123 0.000000 - 0.866308 -1.735463 0.204645 0.000000 - 0.865758 -1.746578 0.216680 0.000000 - 0.640594 -1.652905 0.349421 0.000000 - 0.416553 -1.578376 0.499417 0.000000 - 0.257626 -1.456448 0.623175 0.000000 - 0.005988 -1.256439 0.827659 0.000000 - -0.056447 -1.165161 0.889142 0.000000 - -0.298530 -0.797846 1.140449 0.000000 - -0.298702 -0.799704 1.139076 0.000000 - -0.298476 -0.788586 1.145964 0.000000 - -0.515135 -0.364219 1.400352 0.000000 - -0.561970 -0.266147 1.462864 0.000000 - -0.610492 0.043227 1.588542 0.000000 - -0.622391 0.039620 1.589250 0.000000 - -0.630872 0.236986 1.481109 0.000000 - -0.538434 0.663763 1.226588 0.000000 - -0.518253 0.751762 1.176146 0.000000 - -0.244252 1.215348 0.887533 0.000000 - -0.245094 1.213004 0.889951 0.000000 - -0.246213 1.217924 0.879725 0.000000 - 0.112727 1.562429 0.658951 0.000000 - 0.724116 1.623129 -0.798852 0.000000 - 0.674761 1.601916 -0.854772 0.000000 - 0.648306 1.646106 -0.517305 0.000000 - 0.264738 1.521082 -0.915377 0.000000 - 0.466820 1.718875 0.181156 0.000000 - 0.625453 1.587894 -0.914157 0.000000 - 0.224273 1.502348 -0.915067 0.000000 - 0.144914 1.578561 0.644910 0.000000 - 0.372019 1.703300 0.560327 0.000000 - -0.100646 1.343263 -0.924061 0.000000 - -0.255709 1.270675 -0.928635 0.000000 - -0.268402 1.260711 -0.934395 0.000000 - -0.691134 0.910329 -0.961146 0.000000 - -0.778731 0.833561 -0.972642 0.000000 - -0.914832 0.500015 -0.773257 0.000000 - -0.790270 0.820386 -0.972916 0.000000 - -0.949315 0.416268 -0.720846 0.000000 - -0.992213 -0.007557 -0.550990 0.000000 - -0.023868 -0.757414 -1.147498 0.000000 - 0.323925 0.574197 1.204287 0.000000 - -0.011655 -1.171299 -1.030583 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 546 - 1 - 0.000000 - - - - - - 0.942931 0.220595 0.249439 0.000000 - -0.332396 0.668234 0.665564 0.000000 - -0.019864 -0.710494 0.703423 0.000000 - - - - 0.195386 -0.115327 -0.053679 0.000000 - - - 547 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 548 - 0 - 48 - 0 0 0 0 - - - 1.100199 -0.935313 0.052735 0.000000 - 0.773318 -1.044099 0.032065 0.000000 - 1.110535 -0.842562 -0.010848 0.000000 - 1.057109 -1.058943 0.176922 0.000000 - 0.825111 -1.184578 0.214970 0.000000 - 0.393602 -1.367210 0.176137 0.000000 - 0.511180 -1.387091 0.260046 0.000000 - 0.252987 -1.356288 0.064716 0.000000 - -0.067017 -1.278883 -0.102076 0.000000 - 0.599575 -0.662863 -0.310729 0.000000 - -0.333849 -1.217594 -0.233420 0.000000 - -0.575441 -1.129668 -0.294719 0.000000 - 0.386470 -0.205614 -0.507325 0.000000 - -0.950793 -0.997615 -0.383183 0.000000 - -1.043439 -0.897772 -0.380416 0.000000 - 0.154868 0.282876 -0.538385 0.000000 - -0.956823 -0.993963 -0.384756 0.000000 - -1.183169 -0.553576 -0.412342 0.000000 - -1.033686 -0.902456 -0.387705 0.000000 - -1.161046 -0.646447 -0.407054 0.000000 - -1.197682 -0.345615 -0.374479 0.000000 - -0.072534 0.754732 -0.400804 0.000000 - -1.230650 0.034773 -0.296725 0.000000 - -1.220221 0.167197 -0.241141 0.000000 - -1.147838 0.354508 -0.173761 0.000000 - -0.273437 1.163684 -0.108032 0.000000 - -1.016327 0.695036 -0.056522 0.000000 - -0.391015 1.394653 0.165351 0.000000 - -0.769924 1.145937 0.186503 0.000000 - 0.452779 1.559618 0.127336 0.000000 - 0.402348 1.619962 0.198454 0.000000 - 0.554856 1.466913 -0.011513 0.000000 - 0.709398 1.223087 -0.190893 0.000000 - 0.807636 1.073093 -0.297988 0.000000 - 0.926210 0.774781 -0.387753 0.000000 - 1.003720 0.587524 -0.441075 0.000000 - 1.079038 0.248380 -0.434066 0.000000 - 1.124281 0.056938 -0.427130 0.000000 - 1.146115 -0.310068 -0.310290 0.000000 - 1.157603 -0.467632 -0.257232 0.000000 - 0.156912 -1.159198 0.377441 0.000000 - -0.317935 -0.366284 0.646069 0.000000 - -0.720539 -0.132222 0.532117 0.000000 - -0.800416 -0.191312 0.423810 0.000000 - -0.966988 -0.727795 -0.109011 0.000000 - -0.933673 -0.901434 -0.218781 0.000000 - 0.503533 0.316772 0.557133 0.000000 - -0.972246 -0.947865 -0.361680 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 549 - 1 - 0.000000 - - - - - - 0.878246 0.087909 -0.470059 0.000000 - -0.371678 0.743977 -0.555297 0.000000 - 0.300897 0.662398 0.686069 0.000000 - - - - -0.037943 -0.044133 0.237014 0.000000 - - - 550 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 551 - 0 - 42 - 0 0 0 0 - - - 0.633521 0.183424 -0.990686 0.000000 - 0.639099 0.161025 -0.998118 0.000000 - 0.709876 0.147113 -0.914807 0.000000 - 0.634765 0.180284 -0.991924 0.000000 - 0.239208 0.230928 -1.300519 0.000000 - 0.157520 0.269694 -1.219436 0.000000 - 0.204177 0.232332 -1.330611 0.000000 - -0.267655 0.241119 -1.379831 0.000000 - -0.276395 0.251348 -1.350028 0.000000 - 0.088514 0.207205 -1.405644 0.000000 - -0.582645 1.104368 -0.074375 0.000000 - -0.375749 0.449126 -1.063716 0.000000 - -0.772573 1.119840 0.020651 0.000000 - -0.512470 1.089614 -0.089268 0.000000 - -0.019303 0.991417 -0.156471 0.000000 - 0.092643 0.946425 -0.142037 0.000000 - 0.491983 0.787795 -0.073661 0.000000 - 0.596472 0.717618 -0.015832 0.000000 - 0.924670 0.127022 -0.539188 0.000000 - 0.735880 0.135758 -0.890825 0.000000 - 0.900864 0.513546 0.165843 0.000000 - 0.982735 0.125886 -0.431085 0.000000 - 0.961713 0.441358 0.247254 0.000000 - 1.139882 -0.009062 -0.086209 0.000000 - 1.167057 0.195625 0.538504 0.000000 - 1.225945 -0.086232 0.099467 0.000000 - 1.181930 0.147764 0.603654 0.000000 - 1.288483 -0.254911 0.306905 0.000000 - 1.284330 -0.242676 0.265905 0.000000 - 1.320162 -0.318661 0.531800 0.000000 - 1.196044 0.106641 0.659123 0.000000 - 1.275915 -0.138934 0.792536 0.000000 - -0.611655 -1.169266 -0.022215 0.000000 - -0.740167 -0.885372 0.401419 0.000000 - -0.863277 -0.601892 0.236392 0.000000 - -0.654454 -1.057410 -0.429086 0.000000 - -0.341001 -0.000809 1.469067 0.000000 - -0.376455 0.079820 1.423622 0.000000 - -0.962245 0.849325 0.525148 0.000000 - -0.316973 -0.555834 -1.324781 0.000000 - -0.154788 -0.439990 -1.346467 0.000000 - 0.743854 -0.150717 -0.779679 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 552 - 1 - 0.000000 - - - - - - 0.938923 -0.044744 -0.341207 0.000000 - -0.093401 0.921158 -0.377815 0.000000 - 0.331211 0.386608 0.860717 0.000000 - - - - 0.329255 -0.070790 0.019341 0.000000 - - - 553 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 554 - 0 - 64 - 0 0 0 0 - - - -1.475359 -0.026420 0.712867 0.000000 - -0.030086 -0.002383 0.414181 0.000000 - -1.497253 0.498422 0.583796 0.000000 - 0.008839 -0.540087 0.369511 0.000000 - 1.541383 -0.329451 0.504200 0.000000 - 1.426667 0.197836 0.542209 0.000000 - -0.077886 0.522028 0.290464 0.000000 - -1.572028 0.515303 0.660199 0.000000 - -1.463929 0.573963 0.557707 0.000000 - -1.509556 0.549709 0.606988 0.000000 - -1.628390 0.486753 0.706604 0.000000 - -1.817869 0.269459 0.877802 0.000000 - -1.689512 0.153550 0.827519 0.000000 - -1.781889 0.360978 0.829865 0.000000 - -1.558086 0.030919 0.785391 0.000000 - -1.437254 -0.068433 0.721316 0.000000 - -0.938416 -0.529506 0.589783 0.000000 - -0.636403 -0.797703 0.420930 0.000000 - 0.035082 -1.038534 0.160775 0.000000 - -0.382694 -1.029893 0.271815 0.000000 - 0.078829 -1.431264 -0.165367 0.000000 - 0.431538 -1.450973 -0.196732 0.000000 - 0.092937 -1.440118 -0.168585 0.000000 - 0.207784 -1.564829 -0.351599 0.000000 - 0.609048 -1.364138 -0.091187 0.000000 - 0.090235 -1.441486 -0.174153 0.000000 - 0.944337 -1.115059 0.112783 0.000000 - 1.310150 -0.844848 0.325384 0.000000 - 1.381373 -0.759696 0.363572 0.000000 - 1.564254 -0.548323 0.443970 0.000000 - 1.636649 -0.330819 0.563841 0.000000 - 1.617000 -0.510172 0.489512 0.000000 - 1.645107 -0.288418 0.583054 0.000000 - 1.495955 0.172664 0.591524 0.000000 - 1.646164 -0.210930 0.597553 0.000000 - 1.483951 0.207567 0.590953 0.000000 - 1.300602 0.681857 0.434375 0.000000 - 1.291514 0.707932 0.427322 0.000000 - 1.289406 0.703637 0.431890 0.000000 - -0.129889 0.981915 0.010468 0.000000 - 1.029434 1.134522 0.139311 0.000000 - 1.206297 0.947601 0.281209 0.000000 - 0.995831 1.159123 0.120479 0.000000 - 0.378781 1.258861 -0.145532 0.000000 - -0.181016 1.332335 -0.398467 0.000000 - -0.097848 1.336717 -0.349794 0.000000 - -0.204434 1.343972 -0.392467 0.000000 - -0.331937 1.351815 -0.370735 0.000000 - -0.286854 1.373107 -0.419944 0.000000 - -0.401628 1.326348 -0.310888 0.000000 - -0.760794 1.111920 0.012653 0.000000 - -1.029853 0.953143 0.234871 0.000000 - -0.992754 0.973466 0.221430 0.000000 - -1.164574 0.836393 0.335211 0.000000 - -1.191355 0.809784 0.365655 0.000000 - -1.213196 -0.211504 -0.094926 0.000000 - -0.264951 1.273449 -0.479218 0.000000 - 0.137994 0.640049 -0.744855 0.000000 - -0.192501 -1.161880 -0.704940 0.000000 - 1.177905 0.830009 -0.010880 0.000000 - 1.341988 0.659921 0.133373 0.000000 - 1.589268 -0.045317 0.434319 0.000000 - -1.793112 0.278874 0.852973 0.000000 - -1.764328 0.345578 0.867408 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 555 - 1 - 0.000000 - - - - - - 0.764303 -0.638838 0.087907 0.000000 - 0.564996 0.729107 0.386243 0.000000 - -0.310840 -0.245539 0.918199 0.000000 - - - - -0.205517 -0.199284 -0.195520 0.000000 - - - 556 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 557 - 0 - 45 - 0 0 0 0 - - - 1.181983 0.552373 0.035903 0.000000 - 0.381589 1.116737 -0.324949 0.000000 - 0.577716 1.408105 0.087273 0.000000 - 1.007469 0.998786 0.184119 0.000000 - 1.311750 0.219075 -0.066106 0.000000 - 1.359606 -0.067451 -0.125095 0.000000 - 0.105717 0.747543 -0.609394 0.000000 - 1.440876 -0.545747 -0.215798 0.000000 - 1.428915 -0.680463 -0.224457 0.000000 - -0.222858 0.336719 -0.738162 0.000000 - 1.397413 -1.053471 -0.247961 0.000000 - 1.334148 -1.134941 -0.255838 0.000000 - 1.294799 -1.168566 -0.255982 0.000000 - -0.571915 -0.075452 -0.698639 0.000000 - 0.932676 -1.502363 -0.232912 0.000000 - 0.888163 -1.529164 -0.218552 0.000000 - -0.907232 -0.448566 -0.494738 0.000000 - 0.497225 -1.786025 -0.060401 0.000000 - 0.445347 -1.805189 -0.027610 0.000000 - -1.195955 -0.746074 -0.146501 0.000000 - -0.647333 -1.242478 -0.008816 0.000000 - 0.184587 -1.917532 0.158764 0.000000 - -1.216707 -0.768258 -0.116931 0.000000 - -1.286736 -0.717052 -0.132576 0.000000 - -1.284578 -0.707248 -0.143039 0.000000 - -1.287348 -0.683768 -0.164569 0.000000 - -1.225819 -0.299062 -0.445896 0.000000 - -1.215811 -0.218988 -0.498961 0.000000 - -1.100098 0.163264 -0.643770 0.000000 - -1.063440 0.295436 -0.689579 0.000000 - -0.911996 0.646338 -0.711544 0.000000 - -0.845378 0.809142 -0.718423 0.000000 - -0.672821 1.109395 -0.632482 0.000000 - -0.582972 1.272304 -0.583300 0.000000 - -0.400442 1.507911 -0.401684 0.000000 - -0.301612 1.640349 -0.297655 0.000000 - -0.118448 1.797526 -0.028269 0.000000 - -0.028369 1.877903 0.110938 0.000000 - 0.644074 1.574994 0.449633 0.000000 - 0.125073 1.939917 0.420675 0.000000 - 0.648169 1.575263 0.444641 0.000000 - 0.917936 1.144578 0.243090 0.000000 - -0.496499 0.088300 0.931861 0.000000 - -0.645940 -0.281239 0.978794 0.000000 - 0.193168 -1.755548 0.326007 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 558 - 1 - 0.000000 - - - - - - 0.916068 -0.218120 0.336515 0.000000 - 0.337244 0.873073 -0.352150 0.000000 - -0.216992 0.436081 0.873354 0.000000 - - - - 0.346012 0.201864 0.146039 0.000000 - - - 559 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 560 - 0 - 55 - 0 0 0 0 - - - 0.913889 0.134685 -0.523483 0.000000 - -0.506515 0.743886 -0.373394 0.000000 - 1.181734 0.554721 -0.312447 0.000000 - 0.662240 -0.341322 -0.575696 0.000000 - -0.687918 0.237751 -0.433029 0.000000 - 0.451371 -0.826773 -0.464028 0.000000 - -0.874585 -0.258080 -0.323918 0.000000 - 0.301879 -1.274240 -0.199409 0.000000 - -1.048278 -0.695167 -0.056742 0.000000 - -0.348106 1.210859 -0.150794 0.000000 - 1.145620 0.595448 -0.320108 0.000000 - 1.100821 0.958784 -0.018817 0.000000 - 1.153149 0.557632 -0.355049 0.000000 - 1.157897 0.554041 -0.350851 0.000000 - 1.162062 0.073649 -0.634579 0.000000 - 1.167859 -0.032492 -0.692725 0.000000 - 1.108688 -0.413753 -0.780108 0.000000 - 1.083847 -0.604670 -0.821778 0.000000 - 0.985027 -0.891708 -0.769560 0.000000 - 0.914658 -1.109167 -0.729371 0.000000 - 0.771840 -1.339381 -0.550784 0.000000 - 0.675349 -1.502012 -0.424619 0.000000 - 0.449979 -1.691908 -0.043583 0.000000 - 0.228378 -1.639996 0.192326 0.000000 - 0.387090 -1.747034 0.067076 0.000000 - 0.174686 -1.795873 0.490910 0.000000 - -0.465252 -1.459176 0.424322 0.000000 - 0.145996 -1.826162 0.541893 0.000000 - -1.080828 -1.107818 0.313169 0.000000 - -1.079924 -1.084336 0.317237 0.000000 - -1.080995 -1.068668 0.301512 0.000000 - -1.099026 -0.933520 0.181838 0.000000 - -1.140921 -0.693350 -0.076030 0.000000 - -1.149473 -0.662535 -0.104978 0.000000 - -1.182219 -0.264329 -0.353315 0.000000 - -1.195629 -0.151796 -0.419595 0.000000 - -1.205623 0.206747 -0.517801 0.000000 - -1.215829 0.412480 -0.571094 0.000000 - -1.209423 0.701895 -0.559394 0.000000 - -1.208196 0.974863 -0.545746 0.000000 - -1.107728 1.160235 -0.453232 0.000000 - -1.196279 1.108840 -0.505275 0.000000 - -0.821127 1.338392 -0.295535 0.000000 - -0.189169 1.563385 0.164446 0.000000 - -0.171591 1.571361 0.173793 0.000000 - 1.092618 1.031568 0.043146 0.000000 - -0.169841 1.571389 0.166810 0.000000 - 0.999487 1.270672 0.373991 0.000000 - 0.820268 1.440327 0.522429 0.000000 - 0.955702 1.386121 0.539092 0.000000 - 0.109304 1.627674 0.400454 0.000000 - 0.959417 1.402776 0.541321 0.000000 - -1.121305 0.665171 -0.147029 0.000000 - -1.076138 -0.091795 0.254991 0.000000 - -0.657830 0.721025 0.282129 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 561 - 1 - 0.000000 - - - - - - 0.767560 -0.579668 0.273564 0.000000 - 0.639597 0.720643 -0.267562 0.000000 - -0.042045 0.380340 0.923890 0.000000 - - - - 0.185066 0.047493 0.038386 0.000000 - - - 562 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 563 - 0 - 24 - 0 0 0 0 - - - 0.284491 0.907433 0.162430 0.000000 - 0.404171 0.758380 0.252137 0.000000 - 0.854629 0.002870 -0.069283 0.000000 - 0.858963 -0.013644 -0.072574 0.000000 - 0.196581 0.931783 -0.114824 0.000000 - 0.268571 0.279541 0.448452 0.000000 - 0.291838 -0.249552 0.494597 0.000000 - -0.499476 0.784866 0.089121 0.000000 - 0.042008 0.930302 -0.256645 0.000000 - -0.468686 0.825800 -0.157590 0.000000 - -0.514453 0.781575 0.085161 0.000000 - 0.835088 -0.186876 -0.198010 0.000000 - 0.637815 -0.348697 -0.459502 0.000000 - 0.655548 -0.368789 -0.442311 0.000000 - -1.039429 0.402392 -0.089813 0.000000 - -0.254721 -0.929726 -0.136291 0.000000 - -0.084560 -0.949206 -0.133243 0.000000 - 0.101412 -0.797558 0.253739 0.000000 - 0.045989 -0.725413 0.414541 0.000000 - -0.516225 -0.757414 0.173555 0.000000 - 0.619084 -0.371760 -0.450748 0.000000 - 0.587299 -0.398389 -0.445627 0.000000 - -0.379718 -0.695011 -0.248250 0.000000 - -1.075852 0.188489 -0.094027 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 564 - 1 - 0.000000 - - - - - - 0.754245 0.637955 0.155329 0.000000 - -0.602854 0.766590 -0.221147 0.000000 - -0.260156 0.073159 0.962791 0.000000 - - - - 0.079015 0.068228 0.175201 0.000000 - - - 565 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 566 - 0 - 46 - 0 0 0 0 - - - 0.531421 0.007053 0.996946 0.000000 - -0.674661 -0.701075 0.512324 0.000000 - -0.311453 -1.100321 0.557064 0.000000 - 0.562924 -0.269839 0.963250 0.000000 - 0.492873 0.406051 1.042528 0.000000 - 0.479104 0.584497 1.017352 0.000000 - -0.956403 -0.280202 0.320475 0.000000 - 0.450706 1.050606 0.949599 0.000000 - 0.448826 1.065736 0.944070 0.000000 - 0.439562 1.090179 0.908293 0.000000 - -1.129060 0.121032 0.000335 0.000000 - 0.225088 1.368225 0.605963 0.000000 - -0.045528 1.679910 -0.393805 0.000000 - 0.039605 1.765956 -0.387829 0.000000 - 0.045562 1.777409 -0.407731 0.000000 - -0.479949 1.212106 -0.370161 0.000000 - 0.061817 1.649412 0.027565 0.000000 - -1.127630 0.508076 -0.343944 0.000000 - 0.072034 1.618731 0.139976 0.000000 - -1.144489 0.485418 -0.343642 0.000000 - 0.193380 1.413929 0.519624 0.000000 - -1.172724 0.447128 -0.343919 0.000000 - -1.418739 -0.081669 -0.358808 0.000000 - -1.427247 -0.071608 -0.362429 0.000000 - -1.412618 -0.165176 -0.271665 0.000000 - -1.283637 -0.487829 -0.024399 0.000000 - -1.247448 -0.580579 0.042272 0.000000 - -1.003706 -0.880458 0.218493 0.000000 - -1.072985 -0.836997 0.167616 0.000000 - -0.917525 -0.934591 0.286731 0.000000 - -0.425413 -1.142898 0.489149 0.000000 - -0.521181 -1.119559 0.445427 0.000000 - -0.385853 -1.152491 0.507846 0.000000 - -0.167989 -1.190590 0.546561 0.000000 - 0.681391 -1.075136 0.604212 0.000000 - 0.355303 -1.255953 0.539293 0.000000 - 0.742111 -1.305396 0.438334 0.000000 - 0.654007 -0.909902 0.718498 0.000000 - 0.279442 -1.252770 0.552398 0.000000 - 0.600510 -0.558643 0.855076 0.000000 - 0.767240 0.304527 -0.771744 0.000000 - 0.906041 -1.065992 -0.865495 0.000000 - 0.863969 -1.037394 -0.980606 0.000000 - 0.494267 -0.993090 -0.890498 0.000000 - -0.233610 -0.812883 -0.708247 0.000000 - 0.658246 1.219690 -0.621077 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 567 - 1 - 0.000000 - - - - - - 0.747144 0.622311 -0.233465 0.000000 - -0.470538 0.743308 0.475486 0.000000 - 0.469436 -0.245402 0.848179 0.000000 - - - - -0.175003 0.061738 0.331545 0.000000 - - - 568 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 569 - 0 - 42 - 0 0 0 0 - - - -0.106896 0.178809 -0.868863 0.000000 - 0.386692 0.177782 -0.470750 0.000000 - 0.133414 0.087588 -0.841142 0.000000 - -0.395516 0.245881 -0.848626 0.000000 - 0.079224 0.377130 -0.072806 0.000000 - -0.835435 0.341101 -0.821188 0.000000 - -0.933051 0.343117 -0.793492 0.000000 - -0.226492 0.413946 0.372043 0.000000 - -1.463297 0.347225 -0.649309 0.000000 - -1.456282 0.350006 -0.652366 0.000000 - -0.500561 0.284558 0.820319 0.000000 - -1.582961 0.296795 -0.564010 0.000000 - -1.472136 0.342809 -0.644101 0.000000 - -1.585528 0.314371 -0.585795 0.000000 - -1.663349 0.224306 -0.191853 0.000000 - -0.550000 0.274186 0.853375 0.000000 - -0.559048 0.258219 0.853621 0.000000 - -1.663559 0.238788 -0.205812 0.000000 - -0.464724 0.318378 0.825888 0.000000 - -0.442789 0.324859 0.825422 0.000000 - 0.109575 0.530009 0.661502 0.000000 - 0.311900 0.599272 0.608346 0.000000 - 0.670110 0.647765 0.503057 0.000000 - 1.082986 0.699543 0.389115 0.000000 - 1.153816 0.690621 0.345094 0.000000 - 1.135513 0.703681 0.367638 0.000000 - 1.419652 0.532018 0.030331 0.000000 - 1.524713 -0.040828 -0.451811 0.000000 - 1.588289 0.032330 -0.415045 0.000000 - 1.595638 -0.030244 -0.453261 0.000000 - 0.786735 -0.079354 -0.704701 0.000000 - 1.590063 0.158704 -0.335582 0.000000 - 0.707735 -0.086440 -0.726252 0.000000 - 1.440071 0.483809 -0.020061 0.000000 - 0.644299 -0.097780 -0.743861 0.000000 - 0.550001 -0.080459 -0.797359 0.000000 - -0.029135 -0.688865 0.501187 0.000000 - -0.222268 -0.855866 0.191240 0.000000 - 0.077261 -0.842336 0.102765 0.000000 - 0.376073 -0.779665 0.111294 0.000000 - -0.075790 -0.387320 0.716212 0.000000 - -1.253373 -0.167542 -0.172561 0.000000 - - - - 0 - 31 - 0 0 0 0 - - 570 - 1 - 0.000000 - - - - - - 0.930797 0.238516 -0.276998 0.000000 - -0.031286 0.806984 0.589744 0.000000 - 0.364196 -0.540266 0.758600 0.000000 - - - - 0.000300 0.113718 0.053941 0.000000 - - - 571 - 4 - 0.040000 - - - - - 0 - 4 - 0 0 0 0 - - - 1.000000 1.000000 1.000000 0.000000 - - - 0.000000 0.000000 0.000000 0.000000 - - 0.040000 - 0 - - 572 - 0 - 45 - 0 0 0 0 - - - -0.239485 0.631381 -0.880147 0.000000 - -0.469398 0.275618 -0.418576 0.000000 - -0.216857 0.756212 -0.798697 0.000000 - -0.220138 0.386933 -0.978611 0.000000 - -0.228720 0.190010 -0.986072 0.000000 - -0.370678 -0.166610 -0.715236 0.000000 - -0.238359 0.060458 -0.990861 0.000000 - -0.142911 -0.576634 -0.938825 0.000000 - -0.117681 -0.586604 -0.945207 0.000000 - -0.141236 -0.582379 -0.938705 0.000000 - -0.123693 -0.620712 -0.930405 0.000000 - 0.021149 -0.884440 -0.862653 0.000000 - -0.111716 -1.228824 -0.279913 0.000000 - -0.138804 -1.307093 -0.166289 0.000000 - -0.235212 -1.214336 -0.105601 0.000000 - -0.376023 -1.011232 0.047684 0.000000 - -0.497863 -0.834056 0.187362 0.000000 - -0.553773 -0.617830 0.365070 0.000000 - -0.602779 -0.420846 0.533205 0.000000 - -0.572144 -0.213391 0.716414 0.000000 - -0.404148 0.696723 -0.084312 0.000000 - -0.539734 -0.015287 0.897962 0.000000 - -0.430025 0.163585 1.068178 0.000000 - -0.181341 1.055415 0.254782 0.000000 - -0.315075 0.342853 1.245844 0.000000 - -0.349645 0.322184 1.232351 0.000000 - -0.215438 1.046666 0.241660 0.000000 - -0.205031 1.067584 0.203107 0.000000 - -0.176364 1.097938 0.151595 0.000000 - -0.085042 1.194936 -0.481343 0.000000 - 0.013113 1.358308 -0.348913 0.000000 - 0.022136 1.370047 -0.310225 0.000000 - -0.149062 1.088434 -0.587032 0.000000 - 0.571393 -0.513192 0.629367 0.000000 - 0.674420 -0.231618 0.203329 0.000000 - 0.733457 0.190523 0.169219 0.000000 - 0.557589 -0.239996 0.872670 0.000000 - 0.634786 -0.205571 -0.088319 0.000000 - 0.723132 0.445694 -0.100759 0.000000 - 0.195901 -0.638044 -0.771981 0.000000 - 0.311710 0.010452 -0.712688 0.000000 - 0.384439 0.115093 -0.603964 0.000000 - 0.720511 0.455386 -0.105697 0.000000 - 0.547331 0.705756 -0.204312 0.000000 - -0.034983 1.378438 -0.337384 0.000000 - - diff --git a/Demos/BulletXmlImportDemo/main.cpp b/Demos/BulletXmlImportDemo/main.cpp deleted file mode 100644 index c9100183a..000000000 --- a/Demos/BulletXmlImportDemo/main.cpp +++ /dev/null @@ -1,107 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BulletXmlImportDemo.h" -#include "GlutStuff.h" - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - -#ifdef USE_AMD_OPENCL - - - -#include "btOpenCLUtils.h" - -#include - -cl_context g_cxMainContext; -cl_device_id g_cdDevice; -cl_command_queue g_cqCommandQue; - - -// Returns true if OpenCL is initialized properly, false otherwise. -bool initCL( void* glCtx, void* glDC ) -{ - const char* vendorSDK = btOpenCLUtils::getSdkVendorName(); - printf("This program was compiled using the %s OpenCL SDK\n",vendorSDK); - - int ciErrNum = 0; - -#ifdef BT_USE_CLEW - ciErrNum = clewInit( "OpenCL.dll" ); - if ( ciErrNum != CLEW_SUCCESS ) { - return false; - } -#endif - -#if defined(CL_PLATFORM_MINI_CL) - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#elif defined(CL_PLATFORM_AMD) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#elif defined(CL_PLATFORM_NVIDIA) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#else - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#endif - - g_cxMainContext = btOpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - int numDev = btOpenCLUtils::getNumDevices(g_cxMainContext); - if (!numDev) - return false; - - g_cdDevice = btOpenCLUtils::getDevice(g_cxMainContext,0); - - btOpenCLDeviceInfo clInfo; - btOpenCLUtils::getDeviceInfo(g_cdDevice,clInfo); - btOpenCLUtils::printDeviceInfo(g_cdDevice); - - // create a command-queue - g_cqCommandQue = clCreateCommandQueue(g_cxMainContext, g_cdDevice, 0, &ciErrNum); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - return true; -} - -#endif //#ifdef USE_AMD_OPENCL - - -int main(int argc,char** argv) -{ - -#ifdef USE_AMD_OPENCL - - bool initialized = initCL(0,0); - btAssert(initialized); -#endif //USE_AMD_OPENCL - - - BulletXmlImportDemo serializeDemo; - serializeDemo.initPhysics(); - - -#ifdef CHECK_MEMORY_LEAKS - serializeDemo.exitPhysics(); -#else - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.org",&serializeDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/CMakeLists.txt b/Demos/CMakeLists.txt deleted file mode 100644 index 98bcd2c22..000000000 --- a/Demos/CMakeLists.txt +++ /dev/null @@ -1,59 +0,0 @@ - -SUBDIRS( HelloWorld ) - - -IF (USE_GLUT) - IF (GLUT_FOUND) - IF(BUILD_CPU_DEMOS) - IF(BUILD_EXTRAS) - SUBDIRS( BulletXmlImportDemo ConcaveDemo ConvexDecompositionDemo SerializeDemo ) - ENDIF() - SET(SharedDemoSubdirs - OpenGL - CcdPhysicsDemo ConstraintDemo SliderConstraintDemo GenericJointDemo Raytracer - RagdollDemo ForkLiftDemo BasicDemo FeatherstoneMultiBodyDemo RollingFrictionDemo RaytestDemo VoronoiFractureDemo - GyroscopicDemo FractureDemo Box2dDemo BspDemo MovingConcaveDemo VehicleDemo - UserCollisionAlgorithm CharacterDemo SoftDemo - CollisionInterfaceDemo ConcaveConvexcastDemo SimplexDemo DynamicControlDemo - ConvexHullDistance - DoublePrecisionDemo CollisionDemo - ContinuousConvexCollision ConcaveRaycastDemo GjkConvexCastDemo - MultiMaterialDemo InternalEdgeDemo - ) - ELSE() - SET(SharedDemoSubdirs OpenGL ) - ENDIF(BUILD_CPU_DEMOS) - - - SUBDIRS( - ${SharedDemoSubdirs} - Benchmarks - ) - - - ENDIF(GLUT_FOUND) -ELSE (USE_GLUT) - IF (WIN32) - SUBDIRS( - OpenGL - BasicDemo - RaytestDemo - FractureDemo - Benchmarks - Box2dDemo - CollisionInterfaceDemo - ConcaveDemo - ConstraintDemo - RollingFrictionDemo - ConvexDecompositionDemo - InternalEdgeDemo - GyroscopicDemo - FeatherstoneMultiBodyDemo - GenericJointDemo - SerializeDemo - SoftDemo - VoronoiFractureDemo - ) - ENDIF(WIN32) -ENDIF (USE_GLUT) - diff --git a/Demos/CcdPhysicsDemo/CMakeLists.txt b/Demos/CcdPhysicsDemo/CMakeLists.txt deleted file mode 100644 index 4224de545..000000000 --- a/Demos/CcdPhysicsDemo/CMakeLists.txt +++ /dev/null @@ -1,48 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -../../btgui -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - ADD_EXECUTABLE(AppCcdPhysicsDemo - main.cpp - CcdPhysicsDemo.cpp - CcdPhysicsSetup.h - CcdPhysicsSetup.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppCcdPhysicsDemo - main.cpp - CcdPhysicsDemo.cpp - CcdPhysicsSetup.h - CcdPhysicsSetup.cpp - - ) -ENDIF() - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppCcdPhysicsDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppCcdPhysicsDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppCcdPhysicsDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/CcdPhysicsDemo/CcdPhysicsDemo.cpp b/Demos/CcdPhysicsDemo/CcdPhysicsDemo.cpp deleted file mode 100644 index afe53260e..000000000 --- a/Demos/CcdPhysicsDemo/CcdPhysicsDemo.cpp +++ /dev/null @@ -1,275 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - -#define CUBE_HALF_EXTENTS 1 - -#define EXTRA_HEIGHT 1.f - -#include "CcdPhysicsDemo.h" -#include "GlutStuff.h" -#include "GLDebugFont.h" - -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" - -#include //printf debugging -#include "GLDebugDrawer.h" - -#if 0 -extern btAlignedObjectArray debugContacts; -extern btAlignedObjectArray debugNormals; -#endif - -static GLDebugDrawer sDebugDrawer; - - -CcdPhysicsDemo::CcdPhysicsDemo() -:m_ccdMode(USE_CCD) -{ - setDebugMode(btIDebugDraw::DBG_DrawText+btIDebugDraw::DBG_NoHelpText); - setCameraDistance(btScalar(40.)); -} - - -void CcdPhysicsDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - //float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(1./60.,0);//ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - displayText(); -#if 0 - for (int i=0;igetDebugDrawer()->drawContactPoint(debugContacts[i],debugNormals[i],0,0,btVector3(1,0,0)); - } -#endif - - glFlush(); - - swapBuffers(); - -} - - -void CcdPhysicsDemo::displayText() -{ - int lineWidth=440; - int xStart = m_glutScreenWidth - lineWidth; - int yStart = 20; - - if((getDebugMode() & btIDebugDraw::DBG_DrawText)!=0) - { - setOrthographicProjection(); - glDisable(GL_LIGHTING); - glColor3f(0, 0, 0); - char buf[124]; - - glRasterPos3f(xStart, yStart, 0); - switch (m_ccdMode) - { - case USE_CCD: - { - sprintf(buf,"Predictive contacts and motion clamping"); - break; - } - case USE_NO_CCD: - { - sprintf(buf,"CCD handling disabled"); - break; - } - default: - { - sprintf(buf,"unknown CCD setting"); - }; - }; - - GLDebugDrawString(xStart,20,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"Press 'p' to change CCD mode"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"Press '.' or right mouse to shoot bullets"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"space to restart, h(elp), t(ext), w(ire)"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - resetPerspectiveProjection(); - glEnable(GL_LIGHTING); - } - -} - - - -void CcdPhysicsDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - displayText(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - { - m_dynamicsWorld->debugDrawWorld(); - } -#if 0 - for (int i=0;igetDebugDrawer()->drawContactPoint(debugContacts[i],debugNormals[i],0,0,btVector3(1,0,0)); - } -#endif - - glFlush(); - swapBuffers(); -} - - - - - -void CcdPhysicsDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - m_ShootBoxInitialSpeed = 4000.f; - - m_defaultContactProcessingThreshold = 0.f; - GraphicsPhysicsBridge bridge; - m_physicsSetup.initPhysics(bridge); - m_dynamicsWorld = m_physicsSetup.m_dynamicsWorld; - m_dynamicsWorld->getSolverInfo().m_solverMode |=SOLVER_USE_2_FRICTION_DIRECTIONS|SOLVER_RANDMIZE_ORDER; - - m_dynamicsWorld ->setDebugDrawer(&sDebugDrawer); - - //m_dynamicsWorld->getSolverInfo().m_splitImpulse=false; - - - - if (m_ccdMode==USE_CCD) - { - m_dynamicsWorld->getDispatchInfo().m_useContinuous=true; - } else - { - m_dynamicsWorld->getDispatchInfo().m_useContinuous=false; - } - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - -} - -void CcdPhysicsDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - -void CcdPhysicsDemo::keyboardCallback(unsigned char key, int x, int y) -{ - if (key=='p') - { - switch (m_ccdMode) - { - case USE_CCD: - { - m_ccdMode = USE_NO_CCD; - break; - } - case USE_NO_CCD: - default: - { - m_ccdMode = USE_CCD; - } - }; - clientResetScene(); - } else - { - DemoApplication::keyboardCallback(key,x,y); - } -} - - -void CcdPhysicsDemo::shootBox(const btVector3& destination) -{ - - if (m_dynamicsWorld) - { - float mass = 1.f; - btTransform startTransform; - startTransform.setIdentity(); - btVector3 camPos = getCameraPosition(); - startTransform.setOrigin(camPos); - - setShootBoxShape (); - - - btRigidBody* body = this->localCreateRigidBody(mass, startTransform,m_shootBoxShape); - body->setLinearFactor(btVector3(1,1,1)); - //body->setRestitution(1); - - btVector3 linVel(destination[0]-camPos[0],destination[1]-camPos[1],destination[2]-camPos[2]); - linVel.normalize(); - linVel*=m_ShootBoxInitialSpeed; - - body->getWorldTransform().setOrigin(camPos); - body->getWorldTransform().setRotation(btQuaternion(0,0,0,1)); - body->setLinearVelocity(linVel); - body->setAngularVelocity(btVector3(0,0,0)); - body->setContactProcessingThreshold(1e30); - - ///when using m_ccdMode, disable regular CCD - if (m_ccdMode==USE_CCD) - { - body->setCcdMotionThreshold(CUBE_HALF_EXTENTS); - body->setCcdSweptSphereRadius(0.4f); - } - - } -} - - - - -void CcdPhysicsDemo::exitPhysics() -{ - m_physicsSetup.exitPhysics(); - - - -} - - - - diff --git a/Demos/CcdPhysicsDemo/CcdPhysicsDemo.h b/Demos/CcdPhysicsDemo/CcdPhysicsDemo.h deleted file mode 100644 index 27e8babe9..000000000 --- a/Demos/CcdPhysicsDemo/CcdPhysicsDemo.h +++ /dev/null @@ -1,88 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef BT_CCD_PHYSICS_DEMO_H -#define BT_CCD_PHYSICS_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -#include "LinearMath/btAlignedObjectArray.h" - -class btBroadphaseInterface; -class btCollisionShape; -class btOverlappingPairCache; -class btCollisionDispatcher; -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; -class btDefaultCollisionConfiguration; - -#include "CcdPhysicsSetup.h" - -///CcdPhysicsDemo is good starting point for learning the code base and porting. - -class CcdPhysicsDemo : public PlatformDemoApplication -{ - - CcdPhysicsSetup m_physicsSetup; - - enum - { - USE_CCD=1, - USE_NO_CCD - }; - int m_ccdMode; - - - public: - - CcdPhysicsDemo(); - - virtual ~CcdPhysicsDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - void displayText(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - virtual void displayCallback(); - virtual void shootBox(const btVector3& destination); - virtual void clientResetScene(); - - - static DemoApplication* Create() - { - CcdPhysicsDemo* demo = new CcdPhysicsDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //BT_CCD_PHYSICS_DEMO_H - diff --git a/Demos/CcdPhysicsDemo/CcdPhysicsSetup.cpp b/Demos/CcdPhysicsDemo/CcdPhysicsSetup.cpp deleted file mode 100644 index bbbe0088c..000000000 --- a/Demos/CcdPhysicsDemo/CcdPhysicsSetup.cpp +++ /dev/null @@ -1,179 +0,0 @@ - -#include "CcdPhysicsSetup.h" -#include "btBulletDynamicsCommon.h" -#define CUBE_HALF_EXTENTS 1.f -#define EXTRA_HEIGHT 1.f - - -void KinematicObjectSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - createEmptyDynamicsWorld(); - { - btBoxShape* box = new btBoxShape(btVector3(btScalar(10.), btScalar(1.), btScalar(10.))); - gfxBridge.createCollisionShapeGraphicsObject(box); - btTransform startTrans; - startTrans.setIdentity(); - startTrans.setOrigin(btVector3(0, -1, 0)); - btRigidBody* body = createRigidBody(0, startTrans, box); - body->setMotionState(0); - body->setFriction(1); - body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - body->setActivationState(DISABLE_DEACTIVATION); - - gfxBridge.createRigidBodyGraphicsObject(body, btVector3(0,1,0)); - } - { - btBoxShape* box = new btBoxShape(btVector3(btScalar(1.), btScalar(1.), btScalar(1.))); - gfxBridge.createCollisionShapeGraphicsObject(box); - btTransform startTrans; - startTrans.setIdentity(); - startTrans.setOrigin(btVector3(0, 1, 0)); - btRigidBody* body = createRigidBody(1, startTrans, box); - body->setFriction(1); - body->setActivationState(DISABLE_DEACTIVATION); - gfxBridge.createRigidBodyGraphicsObject(body, btVector3(1, 1, 0)); - } -} - -void KinematicObjectSetup::stepSimulation(float deltaTime) -{ - if (m_dynamicsWorld) - { - btCollisionObject* colObj = m_dynamicsWorld->getCollisionObjectArray()[0]; - btRigidBody* body = btRigidBody::upcast(colObj); - if (body) - { - btMotionState* ms = body->getMotionState(); - - btTransform startTrans; - startTrans.setIdentity(); - static float time = 0.f; - time += 0.01f; - static float xPos = 0.f; - xPos = sinf(time)*10.f; - startTrans.setOrigin(btVector3(xPos, -1, 0)); - if (ms) - { - - ms->setWorldTransform(startTrans); - } - else - { - body->setWorldTransform(startTrans); - } - } - m_dynamicsWorld->stepSimulation(deltaTime); - } -} - -void CcdPhysicsSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - createEmptyDynamicsWorld(); - - - ///create a few basic rigid bodies - btBoxShape* box = new btBoxShape(btVector3(btScalar(110.), btScalar(1.), btScalar(110.))); - gfxBridge.createCollisionShapeGraphicsObject(box); - // box->initializePolyhedralFeatures(); - btCollisionShape* groundShape = box; - - - m_collisionShapes.push_back(groundShape); - //m_collisionShapes.push_back(new btCylinderShape (btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS))); - m_collisionShapes.push_back(new btBoxShape(btVector3(CUBE_HALF_EXTENTS, CUBE_HALF_EXTENTS, CUBE_HALF_EXTENTS))); - - btTransform groundTransform; - groundTransform.setIdentity(); - //groundTransform.setOrigin(btVector3(5,5,5)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0, 0, 0); - if (isDynamic) - groundShape->calculateLocalInertia(mass, localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass, myMotionState, groundShape, localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - gfxBridge.createRigidBodyGraphicsObject(body, btVector3(0, 1, 0)); - body->setFriction(0.5); - //body->setRollingFriction(0.3); - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btCollisionShape* colShape = new btBoxShape(btVector3(1, 1, 1)); - gfxBridge.createCollisionShapeGraphicsObject(colShape); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0, 0, 0); - if (isDynamic) - colShape->calculateLocalInertia(mass, localInertia); - - int gNumObjects = 120;//120; - int i; - for (i = 0; i3) - { - col = 11; - row2 |= 1; - } - - btVector3 pos(col * 2 * CUBE_HALF_EXTENTS + (row2 % 2)*CUBE_HALF_EXTENTS, - row * 2 * CUBE_HALF_EXTENTS + CUBE_HALF_EXTENTS + EXTRA_HEIGHT, 0); - - trans.setOrigin(pos); - - float mass = 1.f; - - btRigidBody* body = createRigidBody(mass, trans, shape); - gfxBridge.createRigidBodyGraphicsObject(body, btVector3(1, 1, 0)); - - body->setAnisotropicFriction(shape->getAnisotropicRollingFrictionDirection(), btCollisionObject::CF_ANISOTROPIC_ROLLING_FRICTION); - body->setFriction(0.5); - - //body->setRollingFriction(.3); - ///when using m_ccdMode - //if (m_ccdMode == USE_CCD) - { - body->setCcdMotionThreshold(CUBE_HALF_EXTENTS); - body->setCcdSweptSphereRadius(0.9*CUBE_HALF_EXTENTS); - } - } - } - -} diff --git a/Demos/CcdPhysicsDemo/CcdPhysicsSetup.h b/Demos/CcdPhysicsDemo/CcdPhysicsSetup.h deleted file mode 100644 index 9fb58225d..000000000 --- a/Demos/CcdPhysicsDemo/CcdPhysicsSetup.h +++ /dev/null @@ -1,23 +0,0 @@ - -#ifndef CCD_PHYSICS_SETUP_H -#define CCD_PHYSICS_SETUP_H - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -struct CcdPhysicsSetup : public CommonRigidBodySetup -{ - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - -}; - -struct KinematicObjectSetup : public CommonRigidBodySetup -{ - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void stepSimulation(float deltaTime); - -}; - - -#endif //CCD_PHYSICS_SETUP_H diff --git a/Demos/CcdPhysicsDemo/Makefile.am b/Demos/CcdPhysicsDemo/Makefile.am deleted file mode 100644 index b7c6968b5..000000000 --- a/Demos/CcdPhysicsDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=CcdPhysicsDemo - -CcdPhysicsDemo_SOURCES=CcdPhysicsDemo.cpp CcdPhysicsDemo.h main.cpp -CcdPhysicsDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -CcdPhysicsDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/CcdPhysicsDemo/main.cpp b/Demos/CcdPhysicsDemo/main.cpp deleted file mode 100644 index 3d0955a7d..000000000 --- a/Demos/CcdPhysicsDemo/main.cpp +++ /dev/null @@ -1,49 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "CcdPhysicsDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" -#ifdef __DEBUG_FPU_ISSUES -#define _GNU_SOURCE -#include -#endif - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - CcdPhysicsDemo* ccdDemo = new CcdPhysicsDemo(); - -#ifdef __DEBUG_FPU_ISSUES -// feenableexcept (FE_DIVBYZERO); -// feenableexcept (FE_INEXACT); -// feenableexcept (FE_INVALID); -// feenableexcept (FE_OVERFLOW|FE_DIVBYZERO|FE_UNDERFLOW); -// feenableexcept (FE_UNDERFLOW); -#endif - - ccdDemo->initPhysics(); - ccdDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - - glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",ccdDemo); - - delete ccdDemo; - return 0; - -} diff --git a/Demos/CellSpuDemo/BasicDemo2.cpp b/Demos/CellSpuDemo/BasicDemo2.cpp deleted file mode 100644 index 2af2b802e..000000000 --- a/Demos/CellSpuDemo/BasicDemo2.cpp +++ /dev/null @@ -1,277 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -//#define USE_GROUND_BOX 1 -#define PRINT_CONTACT_STATISTICS 1 -#define USE_PARALLEL_DISPATCHER 1 - - -//#define USE_SIMPLE_DYNAMICS_WORLD 1 - -int gNumObjects = 5; -#define HALF_EXTENTS btScalar(1.) -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/BroadphaseCollision/btMultiSapBroadphase.h" -#include "LinearMath/btIDebugDraw.h" -#include //printf debugging -btScalar deltaTime = btScalar(1./60.); -btScalar gCollisionMargin = btScalar(0.05); -#include "BasicDemo2.h" - -#ifdef USE_PARALLEL_DISPATCHER -#include "BulletMultiThreaded/SpuGatheringCollisionDispatcher.h" -#include "BulletMultiThreaded/Win32ThreadSupport.h" -#include "BulletMultiThreaded/SpuLibspe2Support.h" -#include "BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" -#endif//USE_PARALLEL_DISPATCHER - - -#include - -//////////////////////////////////// - - - - -int main(int argc,char** argv) -{ - - BasicDemo ccdDemo; - ccdDemo.initPhysics(); - - int i; - for (i=0;i<5;i++) - ccdDemo.clientMoveAndDisplay(); - ccdDemo.exitPhysics(); - - return 0; -} - - - -extern int gNumManifold; - -void BasicDemo::clientMoveAndDisplay() -{ - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = m_clock.getTimeMicroseconds(); - m_clock.reset(); - float minFPS = 1000000.f/60.f; - if (ms > minFPS) - ms = minFPS; - - if (m_dynamicsWorld) - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - - //some additional debugging info -#ifdef PRINT_CONTACT_STATISTICS - printf("num contact manifolds: %i\n",gNumManifold); - int numManifolds = m_dynamicsWorld->getDispatcher()->getNumManifolds(); - for (int i=0;igetDispatcher()->getManifoldByIndexInternal(i); - btCollisionObject* obA = static_cast(contactManifold->getBody0()); - btCollisionObject* obB = static_cast(contactManifold->getBody1()); - - int numContacts = contactManifold->getNumContacts(); - for (int j=0;jgetContactPoint(j); - btVector3 ptA = pt.getPositionWorldOnA(); - btVector3 ptB = pt.getPositionWorldOnB(); - printf("contact manifold[%d],pointA[%d]=(%f,%f,%f)\n",i,j,ptA[0],ptA[1],ptA[2]); - } - } -#endif //PRINT_CONTACT_STATISTICS - - -} - - - - - -void BasicDemo::initPhysics() -{ - - btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration(); - -#ifdef USE_PARALLEL_DISPATCHER - - int maxNumOutstandingTasks = 1;//number of maximum outstanding tasks -#ifdef USE_WIN32_THREADING - - Win32ThreadSupport* threadSupport = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo( - "collision", - processCollisionTask, - createCollisionLocalStoreMemory, - maxNumOutstandingTasks)); -#else - - spe_program_handle_t * program_handle; -#ifndef USE_CESOF - char* spuFileName = "../../../src/BulletMultiThreaded/out/spuCollision.elf"; - - program_handle = spe_image_open (spuFileName); - if (program_handle == NULL) - { - printf( "SPU OPEN IMAGE ERROR:%s\n",spuFileName); - exit(0); - } - else - { - printf( "IMAGE OPENED:%s\n",spuFileName); - } -#else - extern spe_program_handle_t spu_program; - program_handle = &spu_program; -#endif - SpuLibspe2Support* threadSupport = new SpuLibspe2Support( program_handle, maxNumOutstandingTasks); - -#endif // WIN32 - - - m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupport,maxNumOutstandingTasks,collisionConfiguration); -#else - m_dispatcher = new btCollisionDispatcher(collisionConfiguration); -#endif //USE_PARALLEL_DISPATCHER - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - -#define USE_SWEEP_AND_PRUNE 1 -#ifdef USE_SWEEP_AND_PRUNE -#define maxProxies 8192 - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax(10000,10000,10000); - m_overlappingPairCache = new btAxisSweep3(worldAabbMin,worldAabbMax,maxProxies); - //m_overlappingPairCache = new btMultiSapBroadphase(); - - -#else - m_overlappingPairCache = new btSimpleBroadphase; -#endif //USE_SWEEP_AND_PRUNE - - - - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_solver,m_collisionConfiguration); - m_dynamicsWorld->getDispatchInfo().m_enableSPU = true; - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - - ///create a few basic rigid bodies - - - //static ground -#ifdef USE_GROUND_BOX - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); -#else - btCollisionShape* groundShape = new btSphereShape(btScalar(50.)); -#endif//USE_GROUND_BOX - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - localCreateRigidBody(btScalar(0.),groundTransform,groundShape); - - //create a few dynamic sphere rigidbodies (re-using the same sphere shape) - //btCollisionShape* sphereShape = new btBoxShape(btVector3(1,1,1)); - btCollisionShape* sphereShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(sphereShape); - - int i; - for (i=0;isetMargin(gCollisionMargin); - btTransform trans; - trans.setIdentity(); - //stack them - int colsize = 2; - int row = (int)((i*HALF_EXTENTS*2)/(colsize*2*HALF_EXTENTS)); - int row2 = row; - int col = (i)%(colsize)-colsize/2; - btVector3 pos(col*2*HALF_EXTENTS + (row2%2)*HALF_EXTENTS, - row*2*HALF_EXTENTS+HALF_EXTENTS,0); - - trans.setOrigin(pos); - //btRigidBody* body = localCreateRigidBody(btScalar(1.),trans,sphereShape); - localCreateRigidBody(btScalar(1.),trans,sphereShape); - } - - //clientResetScene(); -} - -btRigidBody* BasicDemo::localCreateRigidBody(btScalar mass,const btTransform& startTrans,btCollisionShape* colShape) -{ -btVector3 inertia(0,0,0); -if (mass) - colShape->calculateLocalInertia(mass,inertia); - btRigidBody::btRigidBodyConstructionInfo rbci(mass,0,colShape,inertia); - rbci.m_startWorldTransform = startTrans; - -btRigidBody* body = new btRigidBody(rbci); - m_dynamicsWorld->addRigidBody(body); -return body; - -} -void BasicDemo::exitPhysics() -{ - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_overlappingPairCache; - - btCollisionDispatcher* m_dispatcher; - btDefaultCollisionConfiguration* m_collisionConfiguration; - btConstraintSolver* m_solver; - btDiscreteDynamicsWorld* m_dynamicsWorld; - - btCollisionAlgorithmCreateFunc* m_sphereSphereCF; - btCollisionAlgorithmCreateFunc* m_sphereBoxCF; - btCollisionAlgorithmCreateFunc* m_boxSphereCF; - - btRigidBody* localCreateRigidBody(btScalar mass,const btTransform& startTrans,btCollisionShape* colShape); - - - public: - - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - - -}; - -#endif //BASIC_DEMO_H - diff --git a/Demos/CharacterDemo/CMakeLists.txt b/Demos/CharacterDemo/CMakeLists.txt deleted file mode 100644 index 9b344f8ae..000000000 --- a/Demos/CharacterDemo/CMakeLists.txt +++ /dev/null @@ -1,59 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) -SET(CharacterDemo_SRCS - - DynamicCharacterController.cpp - DynamicCharacterController.h - CharacterDemo.cpp - CharacterDemo.h - ../BspDemo/BspConverter.cpp - ../BspDemo/BspConverter.h - ../BspDemo/BspLoader.cpp - ../BspDemo/BspLoader.h - main.cpp -) - -IF (WIN32) - ADD_EXECUTABLE(AppCharacterDemo - ${CharacterDemo_SRCS} - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppCharacterDemo - ${CharacterDemo_SRCS} - ) -ENDIF() - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - ADD_CUSTOM_COMMAND( - TARGET AppCharacterDemo - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/BspDemo/BspDemo.bsp ${CMAKE_CURRENT_BINARY_DIR} - ) -ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppCharacterDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppCharacterDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppCharacterDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/CharacterDemo/CharacterDemo.cpp b/Demos/CharacterDemo/CharacterDemo.cpp deleted file mode 100644 index 29a544a12..000000000 --- a/Demos/CharacterDemo/CharacterDemo.cpp +++ /dev/null @@ -1,526 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h" -#include "BulletCollision/CollisionDispatch/btGhostObject.h" - -#include "GLDebugDrawer.h" -#include //printf debugging - -#include "GL_ShapeDrawer.h" - -#include "GlutStuff.h" -#include "CharacterDemo.h" -#ifdef DYNAMIC_CHARACTER_CONTROLLER -#include "DynamicCharacterController.h" -#else -#include "BulletDynamics/Character/btKinematicCharacterController.h" -#endif - -const int maxProxies = 32766; -const int maxOverlap = 65535; - -static int gForward = 0; -static int gBackward = 0; -static int gLeft = 0; -static int gRight = 0; -static int gJump = 0; - - - - -CharacterDemo::CharacterDemo() -: -m_indexVertexArrays(0), -m_vertices(0), -m_cameraHeight(4.f), -m_minCameraDistance(3.f), -m_maxCameraDistance(10.f) -{ - m_character = 0; - m_cameraPosition = btVector3(30,30,30); -} - - -void CharacterDemo::initPhysics() -{ - btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50)); - m_collisionShapes.push_back(groundShape); - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - btAxisSweep3* sweepBP = new btAxisSweep3(worldMin,worldMax); - m_overlappingPairCache = sweepBP; - - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration); - m_dynamicsWorld->getDispatchInfo().m_allowedCcdPenetration=0.0001f; - -#ifdef DYNAMIC_CHARACTER_CONTROLLER - m_character = new DynamicCharacterController (); -#else - - btTransform startTransform; - startTransform.setIdentity (); - //startTransform.setOrigin (btVector3(0.0, 4.0, 0.0)); - startTransform.setOrigin (btVector3(10.210098,-1.6433364,16.453260)); - - - m_ghostObject = new btPairCachingGhostObject(); - m_ghostObject->setWorldTransform(startTransform); - sweepBP->getOverlappingPairCache()->setInternalGhostPairCallback(new btGhostPairCallback()); - btScalar characterHeight=1.75; - btScalar characterWidth =1.75; - btConvexShape* capsule = new btCapsuleShape(characterWidth,characterHeight); - m_ghostObject->setCollisionShape (capsule); - m_ghostObject->setCollisionFlags (btCollisionObject::CF_CHARACTER_OBJECT); - - btScalar stepHeight = btScalar(0.35); - m_character = new btKinematicCharacterController (m_ghostObject,capsule,stepHeight); -#endif - - //////////////// - - /// Create some basic environment from a Quake level - - //m_dynamicsWorld->setGravity(btVector3(0,0,0)); - btTransform tr; - tr.setIdentity(); - - const char* filename = "BspDemo.bsp"; - - const char* prefix[]={"./","../","../../","../../../","../../../../", "BspDemo/", "Demos/BspDemo/", - "../Demos/BspDemo/","../../Demos/BspDemo/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - FILE* file=0; - - for (int i=0;iaddCollisionObject(m_ghostObject,btBroadphaseProxy::CharacterFilter, btBroadphaseProxy::StaticFilter|btBroadphaseProxy::DefaultFilter); - - m_dynamicsWorld->addAction(m_character); - - - /////////////// - - clientResetScene(); - - setCameraDistance(56.f); - -} - - -//to be implemented by the demo -void CharacterDemo::renderme() -{ - updateCamera(); - - DemoApplication::renderme(); -} - - - -void CharacterDemo::debugDrawContacts() -{ -// printf("numPairs = %d\n",m_customPairCallback->getOverlappingPairArray().size()); - { - btManifoldArray manifoldArray; - btBroadphasePairArray& pairArray = m_ghostObject->getOverlappingPairCache()->getOverlappingPairArray(); - int numPairs = pairArray.size(); - - for (int i=0;igetOverlappingPairCache()->findPair(pair.m_pProxy0,pair.m_pProxy1); - if (!collisionPair) - continue; - - if (collisionPair->m_algorithm) - collisionPair->m_algorithm->getAllContactManifolds(manifoldArray); - - for (int j=0;jgetNumContacts();p++) - { - const btManifoldPoint&pt = manifold->getContactPoint(p); - - btVector3 color(255,255,255); - m_dynamicsWorld->getDebugDrawer()->drawContactPoint(pt.getPositionWorldOnB(),pt.m_normalWorldOnB,pt.getDistance(),pt.getLifeTime(),color); - } - } - } - } - -} - -void CharacterDemo::clientMoveAndDisplay() -{ - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - /* Character stuff &*/ - if (m_character) - { - - } - - debugDrawContacts(); - - - if (m_dynamicsWorld) - { - //during idle mode, just run 1 simulation step maximum - int maxSimSubSteps = m_idle ? 1 : 2; - if (m_idle) - dt = 1.0/420.f; - - ///set walkDirection for our character - btTransform xform; - xform = m_ghostObject->getWorldTransform (); - - btVector3 forwardDir = xform.getBasis()[2]; - // printf("forwardDir=%f,%f,%f\n",forwardDir[0],forwardDir[1],forwardDir[2]); - btVector3 upDir = xform.getBasis()[1]; - btVector3 strafeDir = xform.getBasis()[0]; - forwardDir.normalize (); - upDir.normalize (); - strafeDir.normalize (); - - btVector3 walkDirection = btVector3(0.0, 0.0, 0.0); - btScalar walkVelocity = btScalar(1.1) * 4.0; // 4 km/h -> 1.1 m/s - btScalar walkSpeed = walkVelocity * dt; - - //rotate view - if (gLeft) - { - btMatrix3x3 orn = m_ghostObject->getWorldTransform().getBasis(); - orn *= btMatrix3x3(btQuaternion(btVector3(0,1,0),0.01)); - m_ghostObject->getWorldTransform ().setBasis(orn); - } - - if (gRight) - { - btMatrix3x3 orn = m_ghostObject->getWorldTransform().getBasis(); - orn *= btMatrix3x3(btQuaternion(btVector3(0,1,0),-0.01)); - m_ghostObject->getWorldTransform ().setBasis(orn); - } - - if (gForward) - walkDirection += forwardDir; - - if (gBackward) - walkDirection -= forwardDir; - - - m_character->setWalkDirection(walkDirection*walkSpeed); - - - int numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - -//#define VERBOSE_FEEDBACK -#ifdef VERBOSE_FEEDBACK - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } -#endif //VERBOSE_FEEDBACK - - } - - - - - - - -#ifdef USE_QUICKPROF - btProfiler::beginBlock("render"); -#endif //USE_QUICKPROF - - - renderme(); - -#ifdef USE_QUICKPROF - btProfiler::endBlock("render"); -#endif - - - glFlush(); - glutSwapBuffers(); - -} - - - -void CharacterDemo::displayCallback(void) -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - debugDrawContacts(); - - glFlush(); - glutSwapBuffers(); -} - -void CharacterDemo::clientResetScene() -{ - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(m_ghostObject->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - - m_character->reset (m_dynamicsWorld); - ///WTF - m_character->warp (btVector3(10.210001,-2.0306311,16.576973)); - -} - -void CharacterDemo::specialKeyboardUp(int key, int x, int y) -{ - switch (key) - { - case GLUT_KEY_UP: - { - gForward = 0; - } - break; - case GLUT_KEY_DOWN: - { - gBackward = 0; - } - break; - case GLUT_KEY_LEFT: - { - gLeft = 0; - } - break; - case GLUT_KEY_RIGHT: - { - gRight = 0; - } - break; - default: - DemoApplication::specialKeyboardUp(key,x,y); - break; - } -} - - -void CharacterDemo::specialKeyboard(int key, int x, int y) -{ - -// printf("key = %i x=%i y=%i\n",key,x,y); - - switch (key) - { - case GLUT_KEY_UP: - { - gForward = 1; - } - break; - case GLUT_KEY_DOWN: - { - gBackward = 1; - } - break; - case GLUT_KEY_LEFT: - { - gLeft = 1; - } - break; - case GLUT_KEY_RIGHT: - { - gRight = 1; - } - break; - case GLUT_KEY_F1: - { - if (m_character && m_character->canJump()) - gJump = 1; - } - break; - default: - DemoApplication::specialKeyboard(key,x,y); - break; - } - -// glutPostRedisplay(); - - -} - -void CharacterDemo::updateCamera() -{ - -//#define DISABLE_CAMERA 1 -#ifdef DISABLE_CAMERA - DemoApplication::updateCamera(); - return; -#endif //DISABLE_CAMERA - - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - - btTransform characterWorldTrans; - - //look at the vehicle - characterWorldTrans = m_ghostObject->getWorldTransform(); - btVector3 up = characterWorldTrans.getBasis()[1]; - btVector3 backward = -characterWorldTrans.getBasis()[2]; - up.normalize (); - backward.normalize (); - - m_cameraTargetPosition = characterWorldTrans.getOrigin(); - m_cameraPosition = m_cameraTargetPosition + up * 10.0 + backward * 12.0; - - //use the convex sweep test to find a safe position for the camera (not blocked by static geometry) - btSphereShape cameraSphere(0.2f); - btTransform cameraFrom,cameraTo; - cameraFrom.setIdentity(); - cameraFrom.setOrigin(characterWorldTrans.getOrigin()); - cameraTo.setIdentity(); - cameraTo.setOrigin(m_cameraPosition); - - btCollisionWorld::ClosestConvexResultCallback cb( characterWorldTrans.getOrigin(), cameraTo.getOrigin() ); - cb.m_collisionFilterMask = btBroadphaseProxy::StaticFilter; - - m_dynamicsWorld->convexSweepTest(&cameraSphere,cameraFrom,cameraTo,cb); - if (cb.hasHit()) - { - - btScalar minFraction = cb.m_closestHitFraction;//btMax(btScalar(0.3),cb.m_closestHitFraction); - m_cameraPosition.setInterpolate3(cameraFrom.getOrigin(),cameraTo.getOrigin(),minFraction); - } - - - - - //update OpenGL camera settings - glFrustum(-1.0, 1.0, -1.0, 1.0, 1.0, 10000.0); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - - gluLookAt(m_cameraPosition[0],m_cameraPosition[1],m_cameraPosition[2], - m_cameraTargetPosition[0],m_cameraTargetPosition[1], m_cameraTargetPosition[2], - m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ()); - - - -} - - -CharacterDemo::~CharacterDemo() -{ - //cleanup in the reverse order of creation/initialization - if (m_character) - { - m_dynamicsWorld->removeCollisionObject(m_ghostObject); - } - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - class btBroadphaseInterface* m_overlappingPairCache; - - class btCollisionDispatcher* m_dispatcher; - - class btConstraintSolver* m_constraintSolver; - - class btDefaultCollisionConfiguration* m_collisionConfiguration; - - class btTriangleIndexVertexArray* m_indexVertexArrays; - - btVector3* m_vertices; - - void debugDrawContacts(); - - float m_cameraHeight; - - float m_minCameraDistance; - float m_maxCameraDistance; - - - CharacterDemo(); - - virtual ~CharacterDemo(); - - virtual void clientMoveAndDisplay(); - - virtual void clientResetScene(); - - virtual void displayCallback(); - - ///a very basic camera following the character - virtual void updateCamera(); - - virtual void specialKeyboard(int key, int x, int y); - - virtual void specialKeyboardUp(int key, int x, int y); - - void renderme(); - - void initPhysics(); - - static DemoApplication* Create() - { - CharacterDemo* demo = new CharacterDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - - - -#define QUAKE_BSP_IMPORTING 1 -#ifdef QUAKE_BSP_IMPORTING -#include "../BspDemo/BspLoader.h" -#include "../BspDemo/BspConverter.h" - - - - -class BspToBulletConverter : public BspConverter -{ - CharacterDemo* m_demoApp; - -public: - - BspToBulletConverter(CharacterDemo* demoApp) - :m_demoApp(demoApp) - { - } - - virtual void addConvexVerticesCollider(btAlignedObjectArray& vertices, bool isEntity, const btVector3& entityTargetLocation) - { - ///perhaps we can do something special with entities (isEntity) - ///like adding a collision Triggering (as example) - - if (vertices.size() > 0) - { - float mass = 0.f; - btTransform startTransform; - //can use a shift - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,-10.0f,0.0f)); - //this create an internal copy of the vertices - for (int i = 0; i < vertices.size(); i++) - { - vertices[i] *= btScalar(0.5); - float t = vertices[i].getZ() * btScalar(0.75); - vertices[i].setZ(-vertices[i].getY()); - vertices[i].setY(t); - } - - btCollisionShape* shape = new btConvexHullShape(&(vertices[0].getX()),vertices.size()); - m_demoApp->m_collisionShapes.push_back(shape); - - //btRigidBody* body = m_demoApp->localCreateRigidBody(mass, startTransform,shape); - m_demoApp->localCreateRigidBody(mass, startTransform,shape); - } - } -}; -#endif //QUAKE_BSP_IMPORTING - - -#endif //CHARACTER_DEMO_H - - diff --git a/Demos/CharacterDemo/DynamicCharacterController.cpp b/Demos/CharacterDemo/DynamicCharacterController.cpp deleted file mode 100644 index 452d86bc4..000000000 --- a/Demos/CharacterDemo/DynamicCharacterController.cpp +++ /dev/null @@ -1,204 +0,0 @@ -#include "BulletCollision/CollisionShapes/btMultiSphereShape.h" -#include "BulletDynamics/Dynamics/btRigidBody.h" -#include "BulletCollision/CollisionDispatch/btCollisionWorld.h" -#include "LinearMath/btDefaultMotionState.h" -#include "DynamicCharacterController.h" - -DynamicCharacterController::DynamicCharacterController () -{ - m_rayLambda[0] = 1.0; - m_rayLambda[1] = 1.0; - m_halfHeight = 1.0; - m_turnAngle = 0.0; - m_maxLinearVelocity = 10.0; - m_walkVelocity = 8.0; // meters/sec - m_turnVelocity = 1.0; // radians/sec - m_shape = NULL; - m_rigidBody = NULL; -} - -DynamicCharacterController::~DynamicCharacterController () -{ -} - -void DynamicCharacterController::setup (btScalar height, btScalar width, btScalar stepHeight) -{ - btVector3 spherePositions[2]; - btScalar sphereRadii[2]; - - sphereRadii[0] = width; - sphereRadii[1] = width; - spherePositions[0] = btVector3 (0.0, (height/btScalar(2.0) - width), 0.0); - spherePositions[1] = btVector3 (0.0, (-height/btScalar(2.0) + width), 0.0); - - m_halfHeight = height/btScalar(2.0); - - m_shape = new btMultiSphereShape (&spherePositions[0], &sphereRadii[0], 2); - - btTransform startTransform; - startTransform.setIdentity (); - startTransform.setOrigin (btVector3(0.0, 2.0, 0.0)); - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo cInfo(1.0, myMotionState, m_shape); - m_rigidBody = new btRigidBody(cInfo); - // kinematic vs. static doesn't work - //m_rigidBody->setCollisionFlags( m_rigidBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - m_rigidBody->setSleepingThresholds (0.0, 0.0); - m_rigidBody->setAngularFactor (0.0); - -} - -void DynamicCharacterController::destroy () -{ - if (m_shape) - { - delete m_shape; - } - - if (m_rigidBody) - { - delete m_rigidBody; - m_rigidBody = 0; - } -} - -btCollisionObject* DynamicCharacterController::getCollisionObject () -{ - return m_rigidBody; -} - -void DynamicCharacterController::preStep (const btCollisionWorld* collisionWorld) -{ - btTransform xform; - m_rigidBody->getMotionState()->getWorldTransform (xform); - btVector3 down = -xform.getBasis()[1]; - btVector3 forward = xform.getBasis()[2]; - down.normalize (); - forward.normalize(); - - m_raySource[0] = xform.getOrigin(); - m_raySource[1] = xform.getOrigin(); - - m_rayTarget[0] = m_raySource[0] + down * m_halfHeight * btScalar(1.1); - m_rayTarget[1] = m_raySource[1] + forward * m_halfHeight * btScalar(1.1); - - class ClosestNotMe : public btCollisionWorld::ClosestRayResultCallback - { - public: - ClosestNotMe (btRigidBody* me) : btCollisionWorld::ClosestRayResultCallback(btVector3(0.0, 0.0, 0.0), btVector3(0.0, 0.0, 0.0)) - { - m_me = me; - } - - virtual btScalar addSingleResult(btCollisionWorld::LocalRayResult& rayResult,bool normalInWorldSpace) - { - if (rayResult.m_collisionObject == m_me) - return 1.0; - - return ClosestRayResultCallback::addSingleResult (rayResult, normalInWorldSpace - ); - } - protected: - btRigidBody* m_me; - }; - - ClosestNotMe rayCallback(m_rigidBody); - - int i = 0; - for (i = 0; i < 2; i++) - { - rayCallback.m_closestHitFraction = 1.0; - collisionWorld->rayTest (m_raySource[i], m_rayTarget[i], rayCallback); - if (rayCallback.hasHit()) - { - m_rayLambda[i] = rayCallback.m_closestHitFraction; - } else { - m_rayLambda[i] = 1.0; - } - } -} - -void DynamicCharacterController::playerStep (const btCollisionWorld* dynaWorld,btScalar dt, - int forward, - int backward, - int left, - int right, - int jump) -{ - btTransform xform; - m_rigidBody->getMotionState()->getWorldTransform (xform); - - /* Handle turning */ - if (left) - m_turnAngle -= dt * m_turnVelocity; - if (right) - m_turnAngle += dt * m_turnVelocity; - - xform.setRotation (btQuaternion (btVector3(0.0, 1.0, 0.0), m_turnAngle)); - - btVector3 linearVelocity = m_rigidBody->getLinearVelocity(); - btScalar speed = m_rigidBody->getLinearVelocity().length(); - - btVector3 forwardDir = xform.getBasis()[2]; - forwardDir.normalize (); - btVector3 walkDirection = btVector3(0.0, 0.0, 0.0); - btScalar walkSpeed = m_walkVelocity * dt; - - if (forward) - walkDirection += forwardDir; - if (backward) - walkDirection -= forwardDir; - - - - if (!forward && !backward && onGround()) - { - /* Dampen when on the ground and not being moved by the player */ - linearVelocity *= btScalar(0.2); - m_rigidBody->setLinearVelocity (linearVelocity); - } else { - if (speed < m_maxLinearVelocity) - { - btVector3 velocity = linearVelocity + walkDirection * walkSpeed; - m_rigidBody->setLinearVelocity (velocity); - } - } - - m_rigidBody->getMotionState()->setWorldTransform (xform); - m_rigidBody->setCenterOfMassTransform (xform); -} - -bool DynamicCharacterController::canJump () const -{ - return onGround(); -} - -void DynamicCharacterController::jump () -{ - if (!canJump()) - return; - - btTransform xform; - m_rigidBody->getMotionState()->getWorldTransform (xform); - btVector3 up = xform.getBasis()[1]; - up.normalize (); - btScalar magnitude = (btScalar(1.0)/m_rigidBody->getInvMass()) * btScalar(8.0); - m_rigidBody->applyCentralImpulse (up * magnitude); -} - -bool DynamicCharacterController::onGround () const -{ - return m_rayLambda[0] < btScalar(1.0); -} - -void DynamicCharacterController::reset () -{ -} -void DynamicCharacterController::warp (const btVector3& origin) -{ -} -void DynamicCharacterController::registerPairCacheAndDispatcher (btOverlappingPairCache* pairCache, btCollisionDispatcher* dispatcher) -{ - -} - diff --git a/Demos/CharacterDemo/DynamicCharacterController.h b/Demos/CharacterDemo/DynamicCharacterController.h deleted file mode 100644 index 241aaeac1..000000000 --- a/Demos/CharacterDemo/DynamicCharacterController.h +++ /dev/null @@ -1,55 +0,0 @@ -#ifndef CHARACTER_CONTROLLER_H -#define CHARACTER_CONTROLLER_H - -#include "LinearMath/btVector3.h" - -#include "BulletDynamics/Character/btCharacterControllerInterface.h" - -class btCollisionShape; -class btRigidBody; -class btCollisionWorld; - -///DynamicCharacterController is obsolete/unsupported at the moment -class DynamicCharacterController : public btCharacterControllerInterface -{ -protected: - btScalar m_halfHeight; - btCollisionShape* m_shape; - btRigidBody* m_rigidBody; - - btVector3 m_raySource[2]; - btVector3 m_rayTarget[2]; - btScalar m_rayLambda[2]; - btVector3 m_rayNormal[2]; - - btScalar m_turnAngle; - - btScalar m_maxLinearVelocity; - btScalar m_walkVelocity; - btScalar m_turnVelocity; -public: - DynamicCharacterController (); - ~DynamicCharacterController (); - void setup (btScalar height = 2.0, btScalar width = 0.25, btScalar stepHeight = 0.25); - void destroy (); - - virtual void reset (); - virtual void warp (const btVector3& origin); - virtual void registerPairCacheAndDispatcher (btOverlappingPairCache* pairCache, btCollisionDispatcher* dispatcher); - - btCollisionObject* getCollisionObject (); - - void preStep (const btCollisionWorld* collisionWorld); - void playerStep (const btCollisionWorld* collisionWorld,btScalar dt, - int forward, - int backward, - int left, - int right, - int jump); - bool canJump () const; - void jump (); - - bool onGround () const; -}; - -#endif diff --git a/Demos/CharacterDemo/main.cpp b/Demos/CharacterDemo/main.cpp deleted file mode 100644 index 080eb8621..000000000 --- a/Demos/CharacterDemo/main.cpp +++ /dev/null @@ -1,19 +0,0 @@ - -#include "CharacterDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - CharacterDemo* characterDemo = new CharacterDemo; - - characterDemo->initPhysics(); - characterDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - return glutmain(argc, argv,640,480,"Bullet Character Demo. http://www.continuousphysics.com/Bullet/phpBB2/", characterDemo); -} - diff --git a/Demos/CollisionDemo/CMakeLists.txt b/Demos/CollisionDemo/CMakeLists.txt deleted file mode 100644 index 7f544ca30..000000000 --- a/Demos/CollisionDemo/CMakeLists.txt +++ /dev/null @@ -1,39 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - ADD_EXECUTABLE(AppCollisionDemo - CollisionDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppCollisionDemo - CollisionDemo.cpp - ) -ENDIF() - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppCollisionDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppCollisionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppCollisionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/CollisionDemo/CollisionDemo.cpp b/Demos/CollisionDemo/CollisionDemo.cpp deleted file mode 100644 index 3f4b0504f..000000000 --- a/Demos/CollisionDemo/CollisionDemo.cpp +++ /dev/null @@ -1,380 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -/// -/// Collision Demo shows a degenerate case, where the Simplex solver has to deal with near-affine dependent cases -/// See the define CATCH_DEGENERATE_TETRAHEDRON in Bullet's btVoronoiSimplexSolver.cpp -/// - - -//#define CHECK_GENSHER_TRIANGLE_CASE 1 - - -///This low-level internal demo does intentionally NOT use the btBulletCollisionCommon.h header -///It needs internal access -#include "GL_Simplex1to4.h" -#include "LinearMath/btQuaternion.h" -#include "LinearMath/btTransform.h" -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/NarrowPhaseCollision/btPointCollector.h" -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h" -#include "LinearMath/btTransformUtil.h" - -#include "CollisionDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" -#include "LinearMath/btIDebugDraw.h" -#include "../OpenGL/GLDebugDrawer.h" -GLDebugDrawer debugDrawer; - - -float yaw=0.f,pitch=0.f,roll=0.f; -const int maxNumObjects = 4; -const int numObjects = 2; - -GL_Simplex1to4 simplex; - -btPolyhedralConvexShape* shapePtr[maxNumObjects]; - -btTransform tr[numObjects]; -int screenWidth = 640; -int screenHeight = 480; - -void DrawRasterizerLine(float const* , float const*, int) -{ - -} - -int main(int argc,char** argv) -{ - CollisionDemo* colDemo = new CollisionDemo(); - -#ifdef CHECK_GENSHER_TRIANGLE_CASE - colDemo->setCameraDistance(8.f); -#else - colDemo->setCameraDistance(4.f); - -#endif // - colDemo->initPhysics(); - - - - return glutmain(argc, argv,screenWidth,screenHeight,"Collision Demo",colDemo); -} - -void CollisionDemo::initPhysics() -{ - setTexturing(false); - setShadows(false); - - //m_debugMode |= btIDebugDraw::DBG_DrawWireframe; -#ifdef CHECK_GENSHER_TRIANGLE_CASE - m_azi = 140.f; -#else - m_azi = 250.f; -#endif - m_ele = 25.f; - - m_azi = 0; - m_ele = 0; - m_cameraTargetPosition.setValue(8.12,0.39,0); - - tr[0].setIdentity(); - tr[0].setOrigin(btVector3(10,0,0)); - tr[1].setIdentity(); - tr[1].setOrigin(btVector3(0,0,0)); - - -#ifdef CHECK_GENSHER_TRIANGLE_CASE - tr[0].setIdentity(); - tr[1].setIdentity(); -#endif //CHECK_GENSHER_TRIANGLE_CASE - - btVector3 boxHalfExtentsA(1,1,1);//1.0000004768371582f,1.0000004768371582f,1.0000001192092896f); - btVector3 boxHalfExtentsB(4,4,4);//3.2836332321166992f,3.2836332321166992f,3.2836320400238037f); - -#ifndef CHECK_GENSHER_TRIANGLE_CASE - btBoxShape* boxA = new btBoxShape(boxHalfExtentsA); - btBoxShape* boxB = new btBoxShape(boxHalfExtentsB); -#endif - - - - - - -#ifdef CHECK_GENSHER_TRIANGLE_CASE - shapePtr[0] = trishapeA; - shapePtr[1] = trishapeB; -#else - shapePtr[0] = boxA; - shapePtr[1] = boxB; -#endif - -} - -void CollisionDemo::clientMoveAndDisplay() -{ - - displayCallback(); -} - - -static btVoronoiSimplexSolver sGjkSimplexSolver; -btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver; - -static btScalar gContactBreakingThreshold=.02f; -int myiter = 1; -int mystate = 2; - -int checkPerturbation = 1; -int numPerturbationIterations = 20; -void CollisionDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDisable(GL_LIGHTING); - - btVoronoiSimplexSolver sGjkSimplexSolver; - btGjkEpaPenetrationDepthSolver epaSolver; - btPointCollector gjkOutput; - btVector3 worldBoundsMin(-1000,-1000,-1000); - btVector3 worldBoundsMax(1000,1000,1000); - { - btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epaSolver); - - btGjkPairDetector::ClosestPointInput input; - input.m_transformA = tr[0]; - input.m_transformB = tr[1]; - - - convexConvex.getClosestPoints(input, gjkOutput, 0); - } - - ATTRIBUTE_ALIGNED16(btScalar) m[16]; - int i; - - //m_ele = 21.2; - //m_azi = -56.6; - - - - - for (i=0;idrawOpenGL(m,shapePtr[i],btVector3(119./255.,147./255.,60./255.),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax); - m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(0.6,0.6,0.6),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax); - } - - if (gjkOutput.m_hasResult) - { - printf("original distance: %10.4f\n", gjkOutput.m_distance); - btVector3 endPt = gjkOutput.m_pointInWorld + - gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance; - - debugDrawer.drawLine(gjkOutput.m_pointInWorld,endPt,btVector3(0,0,0)); - debugDrawer.drawSphere(gjkOutput.m_pointInWorld,0.05,btVector3(0,0,0)); - debugDrawer.drawSphere(endPt,0.05,btVector3(0,0,0)); - - bool perturbeA = false;//true; - const btScalar angleLimit = 0.125f * SIMD_PI; - btScalar perturbeAngle; - btScalar radiusA = shapePtr[0]->getAngularMotionDisc(); - btScalar radiusB = shapePtr[1]->getAngularMotionDisc(); - - if (radiusA < radiusB) - { - perturbeAngle = gContactBreakingThreshold /radiusA; - perturbeA = true; - } else - { - perturbeAngle = gContactBreakingThreshold / radiusB; - perturbeA = false; - } - if ( perturbeAngle > angleLimit ) - perturbeAngle = angleLimit; - - perturbeAngle*=5; - - btVector3 v0,v1; - btPlaneSpace1(gjkOutput.m_normalOnBInWorld,v0,v1); - - glLineWidth(5); - int i; - i=0; - if (myiter>=numPerturbationIterations) - myiter=0; - if (mystate<2) - { - i= myiter; - } - - for ( ;idrawOpenGL(m,shapePtr[0],btVector3(108./255.,131./255.,158./255),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax); - m_shapeDrawer->drawOpenGL(m,shapePtr[0],btVector3(0.3,0.3,1),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax); - - } - - if (1)//gjkOutput.m_hasResult) - { - - printf("perturbed distance: %10.4f\n", gjkOutput.m_distance); - btVector3 startPt,endPt; - btScalar depth = 0; - if (perturbeA) - { - btVector3 endPtOrg = gjkOutput.m_pointInWorld + gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance; - endPt = (tr[0]*input.m_transformA.inverse())(endPtOrg); - depth = (endPt - gjkOutput.m_pointInWorld).dot(gjkOutput.m_normalOnBInWorld); - startPt = endPt-gjkOutput.m_normalOnBInWorld*depth; - } else - { - endPt = gjkOutput.m_pointInWorld + gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance; - startPt = (tr[1]*input.m_transformB.inverse())(gjkOutput.m_pointInWorld); - depth = (endPt - startPt).dot(gjkOutput.m_normalOnBInWorld); - } - - printf("corrected distance: %10.4f\n", depth); - - - - debugDrawer.drawLine(startPt,endPt,btVector3(1,0,0)); - debugDrawer.drawSphere(startPt,0.05,btVector3(0,1,0)); - debugDrawer.drawSphere(endPt,0.05,btVector3(0,0,1)); - } - if (mystate<2) - break; - if (mystate==2 && i>myiter) - break; - } - - - } - - static int looper = 0; - if (looper++>10) - { - looper =0; - checkPerturbation++; - if (checkPerturbation>numPerturbationIterations) - checkPerturbation=0; - } - - GL_ShapeDrawer::drawCoordSystem(); - - - - if (mystate==1 || mystate==2) - { - static int count = 10; - count--; - if (count<0) - { - count=10; - myiter++; - } - } - - btQuaternion orn; - orn.setEuler(yaw,pitch,roll); - //let it rotate - //tr[0].setRotation(orn); - - pitch += 0.005f; - yaw += 0.01f; - - glFlush(); - glutSwapBuffers(); -} - - -void CollisionDemo::specialKeyboard(int key, int x, int y) -{ - switch (key) - { - case GLUT_KEY_DOWN: - case GLUT_KEY_UP: - { - break; - } - default: - DemoApplication::specialKeyboard(key,x,y); - break; - } - -} - -void CollisionDemo::specialKeyboardUp(int key, int x, int y) -{ - switch (key) - { - case GLUT_KEY_UP : - { - myiter++; - break; - } - - case GLUT_KEY_DOWN: - { - mystate++; - if (mystate>1) - myiter=0; - if (mystate>=4) - mystate = 0; - break; - } - default: - DemoApplication::specialKeyboardUp(key,x,y); - break; - } -} diff --git a/Demos/CollisionDemo/CollisionDemo.h b/Demos/CollisionDemo/CollisionDemo.h deleted file mode 100644 index 487250a97..000000000 --- a/Demos/CollisionDemo/CollisionDemo.h +++ /dev/null @@ -1,38 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef COLLISION_DEMO_H -#define COLLISION_DEMO_H - -#include "GlutDemoApplication.h" - -///CollisionDemo shows the low-level direct access to GJK -class CollisionDemo : public GlutDemoApplication -{ - public: - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void specialKeyboardUp(int key, int x, int y); - - virtual void specialKeyboard(int key, int x, int y); - -}; - -#endif //COLLISION_DEMO_H - diff --git a/Demos/CollisionInterfaceDemo/CMakeLists.txt b/Demos/CollisionInterfaceDemo/CMakeLists.txt deleted file mode 100644 index 9dd777bce..000000000 --- a/Demos/CollisionInterfaceDemo/CMakeLists.txt +++ /dev/null @@ -1,63 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -IF (USE_GLUT) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${GLUT_INCLUDE_DIR} - ) - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppCollisionInterfaceDemo - CollisionInterfaceDemo.cpp - CollisionInterfaceDemo.h - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppCollisionInterfaceDemo - CollisionInterfaceDemo.cpp - CollisionInterfaceDemo.h - main.cpp - ) - ENDIF() -ELSE (USE_GLUT) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ) - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppCollisionInterfaceDemo - WIN32 - CollisionInterfaceDemo.cpp - CollisionInterfaceDemo.h - Win32CollisionInterfaceDemo.cpp - ../OpenGL/Win32AppMain.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ENDIF (USE_GLUT) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppCollisionInterfaceDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppCollisionInterfaceDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppCollisionInterfaceDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/CollisionInterfaceDemo/CollisionInterfaceDemo.cpp b/Demos/CollisionInterfaceDemo/CollisionInterfaceDemo.cpp deleted file mode 100644 index c44d9a558..000000000 --- a/Demos/CollisionInterfaceDemo/CollisionInterfaceDemo.cpp +++ /dev/null @@ -1,292 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -/// -/// CollisionInterfaceDemo shows high level usage of the Collision Detection. -/// -#define TEST_NOT_ADDING_OBJECTS_TO_WORLD - -#include "GL_Simplex1to4.h" - -//include common Bullet Collision Detection headerfiles -#include "btBulletCollisionCommon.h" - -#include "LinearMath/btIDebugDraw.h" -#include "GL_ShapeDrawer.h" -#include "CollisionInterfaceDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" - -btScalar yaw=0.f,pitch=0.f,roll=0.f; -const int maxNumObjects = 4; -const int numObjects = 2; - -GL_Simplex1to4 simplex; - -btCollisionObject objects[maxNumObjects]; -btCollisionWorld* collisionWorld = 0; - -GLDebugDrawer debugDrawer; - - -void CollisionInterfaceDemo::initPhysics() -{ - - m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - - btMatrix3x3 basisA; - basisA.setIdentity(); - - btMatrix3x3 basisB; - basisB.setIdentity(); - - objects[0].getWorldTransform().setBasis(basisA); - objects[1].getWorldTransform().setBasis(basisB); - - btBoxShape* boxA = new btBoxShape(btVector3(1,1,1)); - boxA->setMargin(0.f); - - btBoxShape* boxB = new btBoxShape(btVector3(0.5,0.5,0.5)); - boxB->setMargin(0.f); - //ConvexHullShape hullA(points0,3); - //hullA.setLocalScaling(btVector3(3,3,3)); - //ConvexHullShape hullB(points1,4); - //hullB.setLocalScaling(btVector3(4,4,4)); - - objects[0].setCollisionShape(boxA);//&hullA; - objects[1].setCollisionShape(boxB);//&hullB; - - btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration(); - btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collisionConfiguration); - btVector3 worldAabbMin(-1000,-1000,-1000); - btVector3 worldAabbMax(1000,1000,1000); - - btAxisSweep3* broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax); - - //SimpleBroadphase is a brute force alternative, performing N^2 aabb overlap tests - //SimpleBroadphase* broadphase = new btSimpleBroadphase; - - collisionWorld = new btCollisionWorld(dispatcher,broadphase,collisionConfiguration); - collisionWorld->setDebugDrawer(&debugDrawer); - -#ifdef TEST_NOT_ADDING_OBJECTS_TO_WORLD -// collisionWorld->addCollisionObject(&objects[0]); - collisionWorld->addCollisionObject(&objects[1]); -#endif //TEST_NOT_ADDING_OBJECTS_TO_WORLD - -} - - -//to be implemented by the demo - -void CollisionInterfaceDemo::clientMoveAndDisplay() -{ - - displayCallback(); -} - - -static btVoronoiSimplexSolver sGjkSimplexSolver; -btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver; - -struct btDrawingResult : public btCollisionWorld::ContactResultCallback -{ - virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) - { - - glBegin(GL_LINES); - glColor3f(0, 0, 0); - - btVector3 ptA = cp.getPositionWorldOnA(); - btVector3 ptB = cp.getPositionWorldOnB(); - - glVertex3d(ptA.x(),ptA.y(),ptA.z()); - glVertex3d(ptB.x(),ptB.y(),ptB.z()); - glEnd(); - - return 0; - } -}; - -void CollisionInterfaceDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDisable(GL_LIGHTING); - - btScalar m[16]; - - btVector3 worldBoundsMin,worldBoundsMax; - collisionWorld->getBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax); - - - int i; - for (i=0;idrawOpenGL(m,objects[i].getCollisionShape(),btVector3(1,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - collisionWorld->getDispatchInfo().m_debugDraw = &debugDrawer; - - if (collisionWorld) - collisionWorld->performDiscreteCollisionDetection(); - - - - - -#ifndef TEST_NOT_ADDING_OBJECTS_TO_WORLD - - collisionWorld->debugDrawWorld(); - ///one way to draw all the contact points is iterating over contact manifolds in the dispatcher: - - int numManifolds = collisionWorld->getDispatcher()->getNumManifolds(); - for (i=0;igetDispatcher()->getManifoldByIndexInternal(i); - btCollisionObject* obA = static_cast(contactManifold->getBody0()); - btCollisionObject* obB = static_cast(contactManifold->getBody1()); - - int numContacts = contactManifold->getNumContacts(); - for (int j=0;jgetContactPoint(j); - - glBegin(GL_LINES); - glColor3f(0, 0, 0); - - btVector3 ptA = pt.getPositionWorldOnA(); - btVector3 ptB = pt.getPositionWorldOnB(); - - glVertex3d(ptA.x(),ptA.y(),ptA.z()); - glVertex3d(ptB.x(),ptB.y(),ptB.z()); - glEnd(); - } - - //you can un-comment out this line, and then all points are removed - //contactManifold->clearManifold(); - } -#else - - - glDisable(GL_TEXTURE_2D); - for (i=0;idebugDrawObject(objects[i].getWorldTransform(),objects[i].getCollisionShape(), btVector3(1,1,0)); - } - - btDrawingResult renderCallback; - - //collisionWorld->contactPairTest(&objects[0],&objects[1], renderCallback); - collisionWorld->contactTest(&objects[0],renderCallback); - -#if 0 - - //another way is to directly query the dispatcher for both objects. The objects don't need to be inserted into the world - - btCollisionAlgorithm* algo = collisionWorld->getDispatcher()->findAlgorithm(&objects[0],&objects[1]); - btManifoldResult contactPointResult(&objects[0],&objects[1]); - algo->processCollision(&objects[0],&objects[1],collisionWorld->getDispatchInfo(),&contactPointResult); - - btManifoldArray manifoldArray; - algo->getAllContactManifolds(manifoldArray); - - int numManifolds = manifoldArray.size(); - for (i=0;i(contactManifold->getBody0()); - // btCollisionObject* obB = static_cast(contactManifold->getBody1()); - - glDisable(GL_DEPTH_TEST); - int numContacts = contactManifold->getNumContacts(); - bool swap = obA == &objects[0]; - - for (int j=0;jgetContactPoint(j); - - glBegin(GL_LINES); - glColor3f(0, 0, 0); - - btVector3 ptA = swap ?pt.getPositionWorldOnA():pt.getPositionWorldOnB(); - btVector3 ptB = swap ? pt.getPositionWorldOnB():pt.getPositionWorldOnA(); - - glVertex3d(ptA.x(),ptA.y(),ptA.z()); - glVertex3d(ptB.x(),ptB.y(),ptB.z()); - glEnd(); - } - - //you can un-comment out this line, and then all points are removed - //contactManifold->clearManifold(); - } -#endif - - -#endif - - - - - - //GL_ShapeDrawer::drawCoordSystem(); - - -// btQuaternion qA = objects[0].getWorldTransform().getRotation(); -// btQuaternion qB = objects[1].getWorldTransform().getRotation(); - - - if (!m_idle) - { - - - btScalar timeInSeconds = getDeltaTimeMicroseconds()/1000.f; - - btQuaternion orn; - - objects[0].getWorldTransform().getBasis().getEulerYPR(yaw,pitch,roll); - pitch += 0.00005f*timeInSeconds; - yaw += 0.0001f*timeInSeconds; - objects[0].getWorldTransform().getBasis().setEulerYPR(yaw,pitch,roll); - - orn.setEuler(yaw,pitch,roll); - objects[1].getWorldTransform().setOrigin(objects[1].getWorldTransform().getOrigin()+btVector3(0,-0.00001*timeInSeconds,0)); - - //objects[0].getWorldTransform().setRotation(orn); - - - - } - - glFlush(); - swapBuffers(); -} - -void CollisionInterfaceDemo::clientResetScene() -{ - objects[0].getWorldTransform().setOrigin(btVector3(0.0f,3.f,0.f)); - - btQuaternion rotA(0.739f,-0.204f,0.587f,0.257f); - rotA.normalize(); - - objects[0].getWorldTransform().setRotation(rotA); - - objects[1].getWorldTransform().setOrigin(btVector3(0.0f,4.248f,0.f)); - -} - - diff --git a/Demos/CollisionInterfaceDemo/CollisionInterfaceDemo.h b/Demos/CollisionInterfaceDemo/CollisionInterfaceDemo.h deleted file mode 100644 index 9c0d61130..000000000 --- a/Demos/CollisionInterfaceDemo/CollisionInterfaceDemo.h +++ /dev/null @@ -1,42 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef COLLISION_INTERFACE_DEMO_H -#define COLLISION_INTERFACE_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -///CollisionInterfaceDemo shows how to use the collision detection without dynamics (btCollisionWorld/CollisionObject) -class CollisionInterfaceDemo : public PlatformDemoApplication -{ - public: - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void clientResetScene(); - -}; - -#endif //COLLISION_INTERFACE_DEMO_H - diff --git a/Demos/CollisionInterfaceDemo/Win32CollisionInterfaceDemo.cpp b/Demos/CollisionInterfaceDemo/Win32CollisionInterfaceDemo.cpp deleted file mode 100644 index c2f59060a..000000000 --- a/Demos/CollisionInterfaceDemo/Win32CollisionInterfaceDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "CollisionInterfaceDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new CollisionInterfaceDemo(); -} - -#endif diff --git a/Demos/CollisionInterfaceDemo/main.cpp b/Demos/CollisionInterfaceDemo/main.cpp deleted file mode 100644 index f8cbb77df..000000000 --- a/Demos/CollisionInterfaceDemo/main.cpp +++ /dev/null @@ -1,19 +0,0 @@ - -#include "CollisionInterfaceDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" - -int screenWidth = 640; -int screenHeight = 480; - - -int main(int argc,char** argv) -{ - CollisionInterfaceDemo* collisionInterfaceDemo = new CollisionInterfaceDemo(); - - collisionInterfaceDemo->initPhysics(); - - collisionInterfaceDemo->clientResetScene(); - - return glutmain(argc, argv,screenWidth,screenHeight,"Collision Interface Demo",collisionInterfaceDemo); -} diff --git a/Demos/ConcaveConvexcastDemo/CMakeLists.txt b/Demos/ConcaveConvexcastDemo/CMakeLists.txt deleted file mode 100644 index 356a4495e..000000000 --- a/Demos/ConcaveConvexcastDemo/CMakeLists.txt +++ /dev/null @@ -1,33 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppConcaveConvexCastDemo - ConcaveConvexcastDemo.cpp - main.cpp -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppConcaveConvexCastDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppConcaveConvexCastDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppConcaveConvexCastDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp b/Demos/ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp deleted file mode 100644 index 8faf62a42..000000000 --- a/Demos/ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp +++ /dev/null @@ -1,516 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "GLDebugDrawer.h" -#include "ConcaveConvexcastDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -#define NUM_DYNAMIC_BOXES_X 30 -#define NUM_DYNAMIC_BOXES_Y 30 - -static btVector3* gVertices=0; -static int* gIndices=0; -static btBvhTriangleMeshShape* trimeshShape =0; -static btRigidBody* staticBody = 0; -static float waveheight = 5.f; - -const float TRIANGLE_SIZE=8.f; - - -/* Scrolls back and forth over terrain */ -#define NUMRAYS_IN_BAR 100 -class btConvexcastBatch -{ -public: - btVector3 source[NUMRAYS_IN_BAR]; - btVector3 dest[NUMRAYS_IN_BAR]; - btVector3 direction[NUMRAYS_IN_BAR]; - btVector3 hit_com[NUMRAYS_IN_BAR]; - btVector3 hit_surface[NUMRAYS_IN_BAR]; - btScalar hit_fraction[NUMRAYS_IN_BAR]; - btVector3 normal[NUMRAYS_IN_BAR]; - - int frame_counter; - int ms; - int sum_ms; - int sum_ms_samples; - int min_ms; - int max_ms; - -#ifdef USE_BT_CLOCK - btClock frame_timer; -#endif //USE_BT_CLOCK - - btScalar dx; - btScalar min_x; - btScalar max_x; - btScalar min_y; - btScalar max_y; - btScalar sign; - - btVector3 boxShapeHalfExtents; - btBoxShape boxShape; - - btConvexcastBatch () : boxShape(btVector3(0.0, 0.0, 0.0)) - { - ms = 0; - max_ms = 0; - min_ms = 9999.0; - sum_ms_samples = 0; - sum_ms = 0; - } - - btConvexcastBatch (bool unused, btScalar ray_length, btScalar min_z, btScalar max_z, btScalar min_y , btScalar max_y ) : boxShape(btVector3(0.0, 0.0, 0.0)) - { - boxShapeHalfExtents = btVector3(1.0, 1.0, 1.0); - boxShape = btBoxShape(boxShapeHalfExtents); - frame_counter = 0; - ms = 0; - max_ms = 0; - min_ms = 9999.0; - sum_ms_samples = 0; - sum_ms = 0; - dx = 10.0; - min_x = -40; - max_x = 20; - this->min_y = min_y; - this->max_y = max_y; - sign = 1.0; - // btScalar dalpha = 2*SIMD_2_PI/NUMRAYS_IN_BAR; - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - btScalar z = (max_z-min_z)/NUMRAYS_IN_BAR * i + min_z; - source[i] = btVector3(min_x, max_y, z); - dest[i] = btVector3(min_x + ray_length, min_y, z); - normal[i] = btVector3(1.0, 0.0, 0.0); - } - } - - btConvexcastBatch (btScalar ray_length, btScalar z, btScalar min_y = -1000, btScalar max_y = 10) : boxShape(btVector3(0.0, 0.0, 0.0)) - { - boxShapeHalfExtents = btVector3(1.0, 1.0, 1.0); - boxShape = btBoxShape(boxShapeHalfExtents); - frame_counter = 0; - ms = 0; - max_ms = 0; - min_ms = 9999.0; - sum_ms_samples = 0; - sum_ms = 0; - dx = 10.0; - min_x = -40; - max_x = 20; - this->min_y = min_y; - this->max_y = max_y; - sign = 1.0; - btScalar dalpha = btScalar(2)*SIMD_2_PI/btScalar(NUMRAYS_IN_BAR); - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - btScalar alpha = dalpha * btScalar(i); - // rotate around by alpha degrees y - btTransform tr(btQuaternion(btVector3(0.0, 1.0, 0.0), alpha)); - direction[i] = btVector3(1.0, 0.0, 0.0); - direction[i] = tr * direction[i]; - source[i] = btVector3(min_x, max_y, z); - dest[i] = source[i] + direction[i] * ray_length; - dest[i][1] = min_y; - normal[i] = btVector3(1.0, 0.0, 0.0); - } - } - - void move (btScalar dt) - { - if (dt > (1.0/60.0)) - dt = 1.0/60.0; - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - source[i][0] += dx * dt * sign; - dest[i][0] += dx * dt * sign; - } - if (source[0][0] < min_x) - sign = 1.0; - else if (source[0][0] > max_x) - sign = -1.0; - } - - void cast (btCollisionWorld* cw) - { -#ifdef USE_BT_CLOCK - frame_timer.reset (); -#endif //USE_BT_CLOCK - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - btCollisionWorld::ClosestConvexResultCallback cb(source[i], dest[i]); - btQuaternion qFrom; - btQuaternion qTo; - qFrom.setRotation (btVector3(1.0, 0.0, 0.0), 0.0); - qTo.setRotation (btVector3(1.0, 0.0, 0.0), 0.7); - btTransform from(qFrom, source[i]); - btTransform to(qTo, dest[i]); - cw->convexSweepTest (&boxShape, from, to, cb); - if (cb.hasHit ()) - { - hit_surface[i] = cb.m_hitPointWorld; - hit_com[i].setInterpolate3(source[i], dest[i], cb.m_closestHitFraction); - hit_fraction[i] = cb.m_closestHitFraction; - normal[i] = cb.m_hitNormalWorld; - normal[i].normalize (); - } else { - hit_com[i] = dest[i]; - hit_surface[i] = dest[i]; - hit_fraction[i] = 1.0f; - normal[i] = btVector3(1.0, 0.0, 0.0); - } - - } -#ifdef USE_BT_CLOCK - ms += frame_timer.getTimeMilliseconds (); -#endif //USE_BT_CLOCK - frame_counter++; - if (frame_counter > 50) - { - min_ms = ms < min_ms ? ms : min_ms; - max_ms = ms > max_ms ? ms : max_ms; - sum_ms += ms; - sum_ms_samples++; - btScalar mean_ms = (btScalar)sum_ms/(btScalar)sum_ms_samples; - printf("%d rays in %d ms %d %d %f\n", NUMRAYS_IN_BAR * frame_counter, ms, min_ms, max_ms, mean_ms); - ms = 0; - frame_counter = 0; - } - } - - - void drawCube (const btTransform& T) - { - ATTRIBUTE_ALIGNED16(btScalar) m[16]; - T.getOpenGLMatrix (&m[0]); - glPushMatrix (); -#ifdef BT_USE_DOUBLE_PRECISION - glMultMatrixd (&m[0]); - glScaled (2.0 * boxShapeHalfExtents[0], 2.0 * boxShapeHalfExtents[1], 2.0 * boxShapeHalfExtents[2]); -#else - glMultMatrixf (&m[0]); - glScalef (2.0 * boxShapeHalfExtents[0], 2.0 * boxShapeHalfExtents[1], 2.0 * boxShapeHalfExtents[2]); -#endif //BT_USE_DOUBLE_PRECISION - glutSolidCube (1.0); - glPopMatrix (); - } - - void draw () - { - glDisable (GL_LIGHTING); - glColor3f (0.0, 1.0, 0.0); - glBegin (GL_LINES); - int i; - for (i = 0; i < NUMRAYS_IN_BAR; i++) - { - glVertex3f (source[i][0], source[i][1], source[i][2]); - glVertex3f (hit_com[i][0], hit_com[i][1], hit_com[i][2]); - } - glColor3f (1.0, 1.0, 1.0); - glBegin (GL_LINES); - btScalar normal_scale = 10.0; // easier to see if this is big - for (i = 0; i < NUMRAYS_IN_BAR; i++) - { - glVertex3f (hit_surface[i][0], hit_surface[i][1], hit_surface[i][2]); - glVertex3f (hit_surface[i][0] + normal_scale * normal[i][0], hit_surface[i][1] + normal_scale * normal[i][1], hit_surface[i][2] + normal_scale * normal[i][2]); - } - glEnd (); - glColor3f (0.0, 1.0, 1.0); - btQuaternion qFrom; - btQuaternion qTo; - qFrom.setRotation (btVector3(1.0, 0.0, 0.0), 0.0); - qTo.setRotation (btVector3(1.0, 0.0, 0.0), 0.7); - for ( i = 0; i < NUMRAYS_IN_BAR; i++) - { - btTransform from(qFrom, source[i]); - btTransform to(qTo, dest[i]); - btVector3 linVel, angVel; - btTransformUtil::calculateVelocity (from, to, 1.0, linVel, angVel); - btTransform T; - btTransformUtil::integrateTransform (from, linVel, angVel, hit_fraction[i], T); - drawCube (T); - } - glEnable (GL_LIGHTING); - } -}; - - -static btConvexcastBatch convexcastBatch; - - - - - -const int NUM_VERTS_X = 30; -const int NUM_VERTS_Y = 30; -const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - -void ConcaveConvexcastDemo::setVertexPositions(float waveheight, float offset) -{ - int i; - int j; - - for ( i=0;isetCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->setActivationState(DISABLE_DEACTIVATION); - } else - { - staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->forceActivationState(ACTIVE_TAG); - } - } - - DemoApplication::keyboardCallback(key,x,y); - -} - -void ConcaveConvexcastDemo::initPhysics() -{ - #define TRISIZE 10.f - - setCameraDistance(100.f); - - - int vertStride = sizeof(btVector3); - int indexStride = 3*sizeof(int); - - - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - - gVertices = new btVector3[totalVerts]; - gIndices = new int[totalTriangles*3]; - - int i; - - - setVertexPositions(waveheight,0.f); - - int index=0; - for ( i=0;isetCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_STATIC_OBJECT); - - //enable custom material callback - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - convexcastBatch = btConvexcastBatch (40.0, 0.0, -10.0,80.0); - //convexcastBatch = btConvexcastBatch (true, 40.0, -50.0, 50.0); -} - -void ConcaveConvexcastDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_animatedMesh) - { - static float offset=0.f; - offset+=0.01f; - - - - int i; - int j; - btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT); - btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT); - - for ( i=NUM_VERTS_X/2-3;ipartialRefitTree(aabbMin,aabbMax); - - - //clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation. - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - } - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - convexcastBatch.move (dt); - convexcastBatch.cast (m_dynamicsWorld); - renderme(); - convexcastBatch.draw (); - glFlush(); - glutSwapBuffers(); - -} - - - - -void ConcaveConvexcastDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - convexcastBatch.draw (); - glFlush(); - glutSwapBuffers(); -} - - - -void ConcaveConvexcastDemo::exitPhysics() -{ - - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btTriangleIndexVertexArray* m_indexVertexArrays; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - bool m_animatedMesh; - - public: - - ConcaveConvexcastDemo() : m_animatedMesh(true) - { - - } - void initPhysics(); - - void exitPhysics(); - - virtual ~ConcaveConvexcastDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - //to show refit works - void setVertexPositions(float waveheight, float offset); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - ConcaveConvexcastDemo* demo = new ConcaveConvexcastDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - }; -}; - -#endif //CONCAVE_CONVEXCAST_DEMO_H - diff --git a/Demos/ConcaveConvexcastDemo/main.cpp b/Demos/ConcaveConvexcastDemo/main.cpp deleted file mode 100644 index 6f405b6a7..000000000 --- a/Demos/ConcaveConvexcastDemo/main.cpp +++ /dev/null @@ -1,15 +0,0 @@ - -#include "ConcaveConvexcastDemo.h" -#include "GlutStuff.h" - - -int main(int argc,char** argv) -{ - - ConcaveConvexcastDemo* concaveConvexcastDemo = new ConcaveConvexcastDemo(); - concaveConvexcastDemo->initPhysics(); - concaveConvexcastDemo->setCameraDistance(30.f); - - return glutmain(argc, argv,640,480,"Concave Convexcast Demo",concaveConvexcastDemo); -} - diff --git a/Demos/ConcaveDemo/CMakeLists.txt b/Demos/ConcaveDemo/CMakeLists.txt deleted file mode 100644 index e065ccf57..000000000 --- a/Demos/ConcaveDemo/CMakeLists.txt +++ /dev/null @@ -1,67 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - - -# You shouldn't have to modify anything below this line -######################################################## - -IF (USE_GLUT) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader - ${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter - ${GLUT_INCLUDE_DIR} - - ) - - LINK_LIBRARIES( - OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppConcaveDemo - ConcavePhysicsDemo.cpp - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppConcaveDemo - ConcavePhysicsDemo.cpp - main.cpp - ) - ENDIF() -ELSE (USE_GLUT) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader - ${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter - ) - - LINK_LIBRARIES( - OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision BulletFileLoader LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppConcaveDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - ConcavePhysicsDemo.cpp - ConcaveDemo.h - Win32ConcaveDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppConcaveDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppConcaveDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppConcaveDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/ConcaveDemo/ConcaveDemo.h b/Demos/ConcaveDemo/ConcaveDemo.h deleted file mode 100644 index 86144c7e8..000000000 --- a/Demos/ConcaveDemo/ConcaveDemo.h +++ /dev/null @@ -1,91 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef CONCAVE_DEMO_H -#define CONCAVE_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -#include "LinearMath/btAlignedObjectArray.h" - -class btBroadphaseInterface; -class btCollisionShape; -class btOverlappingPairCache; -class btCollisionDispatcher; -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; -class btDefaultCollisionConfiguration; -class btTriangleIndexVertexArray; - -///ConcaveDemo shows usage of static concave triangle meshes -///It also shows per-triangle material (friction/restitution) through CustomMaterialCombinerCallback -class ConcaveDemo : public PlatformDemoApplication -{ - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btTriangleIndexVertexArray* m_indexVertexArrays; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - bool m_animatedMesh; - - public: - - ConcaveDemo() : m_animatedMesh(true) - { - - } - void initPhysics(); - - void exitPhysics(); - - virtual ~ConcaveDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - //to show refit works - void setVertexPositions(float waveheight, float offset); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - ConcaveDemo* demo = new ConcaveDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - }; -}; - -#endif //CONCAVE_DEMO_H - diff --git a/Demos/ConcaveDemo/ConcavePhysicsDemo.cpp b/Demos/ConcaveDemo/ConcavePhysicsDemo.cpp deleted file mode 100644 index e261662b0..000000000 --- a/Demos/ConcaveDemo/ConcavePhysicsDemo.cpp +++ /dev/null @@ -1,474 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" -#include "GLDebugDrawer.h" -#include "ConcaveDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -#define SERIALIZE_TO_DISK 1 - -#ifndef SERIALIZE_TO_DISK -#include "btBulletWorldImporter.h" -#endif //SERIALIZE_TO_DISK - -//by default, the sample only (de)serializes the BVH to disk. -//If you enable the SERIALIZE_SHAPE define then it will serialize the entire collision shape -//then the animation will not play, because it is using the deserialized vertices -//#define SERIALIZE_SHAPE - - - - -//#define USE_PARALLEL_DISPATCHER 1 -#ifdef USE_PARALLEL_DISPATCHER -#include "../../Extras/BulletMultiThreaded/SpuGatheringCollisionDispatcher.h" -#include "../../Extras/BulletMultiThreaded/Win32ThreadSupport.h" -#include "../../Extras/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" -#endif//USE_PARALLEL_DISPATCHER - - - - -static btVector3* gVertices=0; -static int* gIndices=0; -static btBvhTriangleMeshShape* trimeshShape =0; -static btRigidBody* staticBody = 0; -static float waveheight = 5.f; - -const float TRIANGLE_SIZE=8.f; - - - -///User can override this material combiner by implementing gContactAddedCallback and setting body0->m_collisionFlags |= btCollisionObject::customMaterialCallback; -inline btScalar calculateCombinedFriction(float friction0,float friction1) -{ - btScalar friction = friction0 * friction1; - - const btScalar MAX_FRICTION = 10.f; - if (friction < -MAX_FRICTION) - friction = -MAX_FRICTION; - if (friction > MAX_FRICTION) - friction = MAX_FRICTION; - return friction; - -} - -inline btScalar calculateCombinedRestitution(float restitution0,float restitution1) -{ - return restitution0 * restitution1; -} - - - -static bool CustomMaterialCombinerCallback(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) -{ - - float friction0 = colObj0Wrap->getCollisionObject()->getFriction(); - float friction1 = colObj1Wrap->getCollisionObject()->getFriction(); - float restitution0 = colObj0Wrap->getCollisionObject()->getRestitution(); - float restitution1 = colObj1Wrap->getCollisionObject()->getRestitution(); - - if (colObj0Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK) - { - friction0 = 1.0;//partId0,index0 - restitution0 = 0.f; - } - if (colObj1Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK) - { - if (index1&1) - { - friction1 = 1.0f;//partId1,index1 - } else - { - friction1 = 0.f; - } - restitution1 = 0.f; - } - - cp.m_combinedFriction = calculateCombinedFriction(friction0,friction1); - cp.m_combinedRestitution = calculateCombinedRestitution(restitution0,restitution1); - - //this return value is currently ignored, but to be on the safe side: return false if you don't calculate friction - return true; -} - -extern ContactAddedCallback gContactAddedCallback; - - const int NUM_VERTS_X = 30; - const int NUM_VERTS_Y = 30; - const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - -void ConcaveDemo::setVertexPositions(float waveheight, float offset) -{ - int i; - int j; - - for ( i=0;isetCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->setActivationState(DISABLE_DEACTIVATION); - } else - { - staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->forceActivationState(ACTIVE_TAG); - } - } - - DemoApplication::keyboardCallback(key,x,y); - -} - -void ConcaveDemo::initPhysics() -{ - - setTexturing(true); - setShadows(false);//true); - - #define TRISIZE 10.f - - gContactAddedCallback = CustomMaterialCombinerCallback; - -#define USE_TRIMESH_SHAPE 1 -#ifdef USE_TRIMESH_SHAPE - - int vertStride = sizeof(btVector3); - int indexStride = 3*sizeof(int); - - - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - - gVertices = new btVector3[totalVerts]; - gIndices = new int[totalTriangles*3]; - - int i; - - - setVertexPositions(waveheight,0.f); - - int index=0; - for ( i=0;isetSerializationFlags(BT_SERIALIZE_NO_BVH);// or BT_SERIALIZE_NO_TRIANGLEINFOMAP - serializer->startSerialization(); - //registering a name is optional, it allows you to retrieve the shape by name - //serializer->registerNameForPointer(trimeshShape,"mymesh"); -#ifdef SERIALIZE_SHAPE - trimeshShape->serializeSingleShape(serializer); -#else - trimeshShape->serializeSingleBvh(serializer); -#endif - serializer->finishSerialization(); - FILE* f2 = fopen("myShape.bullet","wb"); - fwrite(serializer->getBufferPointer(),serializer->getCurrentBufferSize(),1,f2); - fclose(f2); - -#else - btBulletWorldImporter import(0);//don't store info into the world - if (import.loadFile("myShape.bullet")) - { - int numBvh = import.getNumBvhs(); - if (numBvh) - { - btOptimizedBvh* bvh = import.getBvhByIndex(0); - btVector3 aabbMin(-1000,-1000,-1000),aabbMax(1000,1000,1000); - - trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression,aabbMin,aabbMax,false); - trimeshShape->setOptimizedBvh(bvh); - //trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression,aabbMin,aabbMax); - //trimeshShape->setOptimizedBvh(bvh); - - } - int numShape = import.getNumCollisionShapes(); - if (numShape) - { - trimeshShape = (btBvhTriangleMeshShape*)import.getCollisionShapeByIndex(0); - - //if you know the name, you can also try to get the shape by name: - const char* meshName = import.getNameForPointer(trimeshShape); - if (meshName) - trimeshShape = (btBvhTriangleMeshShape*)import.getCollisionShapeByName(meshName); - - } - } - - -#endif - - btCollisionShape* groundShape = trimeshShape; - -#else - btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50)); - m_collisionShapes.push_back(groundShape); - -#endif //USE_TRIMESH_SHAPE - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - -#ifdef USE_PARALLEL_DISPATCHER - -#ifdef USE_WIN32_THREADING - - int maxNumOutstandingTasks = 4;//number of maximum outstanding tasks - Win32ThreadSupport* threadSupport = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo( - "collision", - processCollisionTask, - createCollisionLocalStoreMemory, - maxNumOutstandingTasks)); -#else -///@todo show other platform threading -///Playstation 3 SPU (SPURS) version is available through PS3 Devnet -///Libspe2 SPU support will be available soon -///pthreads version -///you can hook it up to your custom task scheduler by deriving from btThreadSupportInterface -#endif - - m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupport,maxNumOutstandingTasks,m_collisionConfiguration); -#else - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); -#endif//USE_PARALLEL_DISPATCHER - - - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - m_broadphase = new btAxisSweep3(worldMin,worldMax); - m_solver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); -#ifdef USE_PARALLEL_DISPATCHER - m_dynamicsWorld->getDispatchInfo().m_enableSPU=true; -#endif //USE_PARALLEL_DISPATCHER - - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,-2,0)); - -#ifdef USE_BOX_SHAPE - btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1)); -#else - - btCompoundShape* colShape = new btCompoundShape; - btCollisionShape* cylinderShape = new btCylinderShapeX(btVector3(4,1,1)); - btCollisionShape* boxShape = new btBoxShape(btVector3(4,1,1)); - btTransform localTransform; - localTransform.setIdentity(); - colShape->addChildShape(localTransform,boxShape); - btQuaternion orn(SIMD_HALF_PI,0,0); - localTransform.setRotation(orn); - colShape->addChildShape(localTransform,cylinderShape); - -#endif //USE_BOX_SHAPE - - - m_collisionShapes.push_back(colShape); - - { - for (int i=0;i<10;i++) - { - startTransform.setOrigin(btVector3(2,10+i*2,1)); - localCreateRigidBody(1, startTransform,colShape); - } - } - - startTransform.setIdentity(); - staticBody = localCreateRigidBody(mass, startTransform,groundShape); - - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);//STATIC_OBJECT); - - //enable custom material callback - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - - - -} - -void ConcaveDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_animatedMesh) - { - static float offset=0.f; - offset+=dt; - - // setVertexPositions(waveheight,offset); - - int i; - int j; - btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT); - btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT); - - for ( i=NUM_VERTS_X/2-3;ipartialRefitTree(aabbMin,aabbMax); - - //clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation. - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - } - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - - renderme(); - - glFlush(); - swapBuffers(); - -} - - - - -void ConcaveDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - - glFlush(); - swapBuffers(); -} - - - -void ConcaveDemo::exitPhysics() -{ - - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;jinitPhysics(); - concaveDemo->setCameraDistance(30.f); - concaveDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - return glutmain(argc, argv,640,480,"Static Concave Mesh Demo",concaveDemo); -} - diff --git a/Demos/ConcaveRaycastDemo/CMakeLists.txt b/Demos/ConcaveRaycastDemo/CMakeLists.txt deleted file mode 100644 index e64fb3aa9..000000000 --- a/Demos/ConcaveRaycastDemo/CMakeLists.txt +++ /dev/null @@ -1,42 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - ADD_EXECUTABLE(AppConcaveRayCastDemo - ConcaveRaycastDemo.cpp - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppConcaveRayCastDemo - ConcaveRaycastDemo.cpp - main.cpp - ) -ENDIF() - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppConcaveRayCastDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppConcaveRayCastDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppConcaveRayCastDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/ConcaveRaycastDemo/ConcaveRaycastDemo.cpp b/Demos/ConcaveRaycastDemo/ConcaveRaycastDemo.cpp deleted file mode 100644 index 25242b7ae..000000000 --- a/Demos/ConcaveRaycastDemo/ConcaveRaycastDemo.cpp +++ /dev/null @@ -1,490 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" -#include "GLDebugDrawer.h" -#include "ConcaveRaycastDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -static GLDebugDrawer sDebugDraw; - -static btVector3* gVertices=0; -static int* gIndices=0; -static btBvhTriangleMeshShape* trimeshShape =0; -static btRigidBody* staticBody = 0; -static float waveheight = 5.f; - -const float TRIANGLE_SIZE=8.f; - - -/* Scrolls back and forth over terrain */ -#define NUMRAYS_IN_BAR 100 -class btRaycastBar -{ -public: - btVector3 source[NUMRAYS_IN_BAR]; - btVector3 dest[NUMRAYS_IN_BAR]; - btVector3 direction[NUMRAYS_IN_BAR]; - btVector3 hit[NUMRAYS_IN_BAR]; - btVector3 normal[NUMRAYS_IN_BAR]; - - int frame_counter; - int ms; - int sum_ms; - int sum_ms_samples; - int min_ms; - int max_ms; - -#ifdef USE_BT_CLOCK - btClock frame_timer; -#endif //USE_BT_CLOCK - - btScalar dx; - btScalar min_x; - btScalar max_x; - btScalar min_y; - btScalar max_y; - btScalar sign; - - btRaycastBar () - { - ms = 0; - max_ms = 0; - min_ms = 9999.0; - sum_ms_samples = 0; - sum_ms = 0; - } - - btRaycastBar (bool unused, btScalar ray_length, btScalar min_z, btScalar max_z, btScalar min_y = -10, btScalar max_y = 10) - { - frame_counter = 0; - ms = 0; - max_ms = 0; - min_ms = 9999.0; - sum_ms_samples = 0; - sum_ms = 0; - dx = 10.0; - min_x = -40; - max_x = 20; - this->min_y = min_y; - this->max_y = max_y; - sign = 1.0; - // btScalar dalpha = 2*SIMD_2_PI/NUMRAYS_IN_BAR; - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - btScalar z = (max_z-min_z)/btScalar(NUMRAYS_IN_BAR) * btScalar(i) + min_z; - source[i] = btVector3(min_x, max_y, z); - dest[i] = btVector3(min_x + ray_length, min_y, z); - normal[i] = btVector3(1.0, 0.0, 0.0); - } - } - - btRaycastBar (btScalar ray_length, btScalar z, btScalar min_y = -1000, btScalar max_y = 10) - { - frame_counter = 0; - ms = 0; - max_ms = 0; - min_ms = 9999.0; - sum_ms_samples = 0; - sum_ms = 0; - dx = 10.0; - min_x = -40; - max_x = 20; - this->min_y = min_y; - this->max_y = max_y; - sign = 1.0; - btScalar dalpha = 2*SIMD_2_PI/NUMRAYS_IN_BAR; - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - btScalar alpha = dalpha * i; - // rotate around by alpha degrees y - btTransform tr (btQuaternion (btVector3(0.0, 1.0, 0.0), alpha)); - direction[i] = btVector3(1.0, 0.0, 0.0); - direction[i] = tr* direction[i]; - direction[i] = direction[i] * ray_length; - source[i] = btVector3(min_x, max_y, z); - dest[i] = source[i] + direction[i]; - dest[i][1] = min_y; - normal[i] = btVector3(1.0, 0.0, 0.0); - } - } - - void move (btScalar dt) - { - if (dt > (1.0/60.0)) - dt = 1.0/60.0; - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - source[i][0] += dx * dt * sign; - dest[i][0] += dx * dt * sign; - } - if (source[0][0] < min_x) - sign = 1.0; - else if (source[0][0] > max_x) - sign = -1.0; - } - - void cast (btCollisionWorld* cw) - { -#ifdef USE_BT_CLOCK - frame_timer.reset (); -#endif //USE_BT_CLOCK - -#ifdef BATCH_RAYCASTER - if (!gBatchRaycaster) - return; - - gBatchRaycaster->clearRays (); - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - gBatchRaycaster->addRay (source[i], dest[i]); - } - gBatchRaycaster->performBatchRaycast (); - for (int i = 0; i < gBatchRaycaster->getNumRays (); i++) - { - const SpuRaycastTaskWorkUnitOut& out = (*gBatchRaycaster)[i]; - hit[i].setInterpolate3(source[i],dest[i],out.hitFraction); - normal[i] = out.hitNormal; - normal[i].normalize (); - } -#else - for (int i = 0; i < NUMRAYS_IN_BAR; i++) - { - btCollisionWorld::ClosestRayResultCallback cb(source[i], dest[i]); - - cw->rayTest (source[i], dest[i], cb); - if (cb.hasHit ()) - { - hit[i] = cb.m_hitPointWorld; - normal[i] = cb.m_hitNormalWorld; - normal[i].normalize (); - } else { - hit[i] = dest[i]; - normal[i] = btVector3(1.0, 0.0, 0.0); - } - - } -#ifdef USE_BT_CLOCK - ms += frame_timer.getTimeMilliseconds (); -#endif //USE_BT_CLOCK - frame_counter++; - if (frame_counter > 50) - { - min_ms = ms < min_ms ? ms : min_ms; - max_ms = ms > max_ms ? ms : max_ms; - sum_ms += ms; - sum_ms_samples++; - btScalar mean_ms = (btScalar)sum_ms/(btScalar)sum_ms_samples; - printf("%d rays in %d ms %d %d %f\n", NUMRAYS_IN_BAR * frame_counter, ms, min_ms, max_ms, mean_ms); - ms = 0; - frame_counter = 0; - } -#endif - } - - void draw () - { - glDisable (GL_LIGHTING); - glColor3f (0.0, 1.0, 0.0); - glBegin (GL_LINES); - int i; - - for (i = 0; i < NUMRAYS_IN_BAR; i++) - { - glVertex3f (source[i][0], source[i][1], source[i][2]); - glVertex3f (hit[i][0], hit[i][1], hit[i][2]); - } - glEnd (); - glColor3f (1.0, 1.0, 1.0); - glBegin (GL_LINES); - for (i = 0; i < NUMRAYS_IN_BAR; i++) - { - glVertex3f (hit[i][0], hit[i][1], hit[i][2]); - glVertex3f (hit[i][0] + normal[i][0], hit[i][1] + normal[i][1], hit[i][2] + normal[i][2]); - } - glEnd (); - glColor3f (0.0, 1.0, 1.0); - glBegin (GL_POINTS); - for ( i = 0; i < NUMRAYS_IN_BAR; i++) - { - glVertex3f (hit[i][0], hit[i][1], hit[i][2]); - } - glEnd (); - glEnable (GL_LIGHTING); - } -}; - - -static btRaycastBar raycastBar; - - -const int NUM_VERTS_X = 30; -const int NUM_VERTS_Y = 30; -const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - -void ConcaveRaycastDemo::setVertexPositions(float waveheight, float offset) -{ - int i; - int j; - - for ( i=0;isetCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->setActivationState(DISABLE_DEACTIVATION); - } else - { - staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->forceActivationState(ACTIVE_TAG); - } - } - - DemoApplication::keyboardCallback(key,x,y); - -} - -void ConcaveRaycastDemo::initPhysics() -{ - - #define TRISIZE 10.f - - - - int vertStride = sizeof(btVector3); - int indexStride = 3*sizeof(int); - - - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - - gVertices = new btVector3[totalVerts]; - gIndices = new int[totalTriangles*3]; - - int i; - - - setVertexPositions(waveheight,0.f); - - int index=0; - for ( i=0;igetSolverInfo().m_splitImpulse=true; - m_dynamicsWorld->setDebugDrawer(&sDebugDraw); - - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,-2,0)); - - btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1)); - m_collisionShapes.push_back(colShape); - - { - for (int i=0;i<10;i++) - { - //btCollisionShape* colShape = new btCapsuleShape(0.5,2.0);//boxShape = new btSphereShape(1.f); - startTransform.setOrigin(btVector3(2*i,10,1)); - localCreateRigidBody(1, startTransform,colShape); - } - } - - startTransform.setIdentity(); - staticBody = localCreateRigidBody(mass, startTransform,groundShape); - - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_STATIC_OBJECT); - -#ifdef BATCH_RAYCASTER -int maxNumOutstandingTasks = 4; - -#ifdef USE_WIN32_THREADING - Win32ThreadSupport::Win32ThreadConstructionInfo tci("batch raycast", - processRaycastTask, - createRaycastLocalStoreMemory, - maxNumOutstandingTasks); - m_threadSupportRaycast = new Win32ThreadSupport(tci); - printf("m_threadSupportRaycast = %p\n", m_threadSupportRaycast); -#endif - - gBatchRaycaster = new SpuBatchRaycaster (m_threadSupportRaycast, maxNumOutstandingTasks, m_dynamicsWorld->getCollisionObjectArray(), m_dynamicsWorld->getNumCollisionObjects()); -#endif - - raycastBar = btRaycastBar (4000.0, 0.0); - //raycastBar = btRaycastBar (true, 40.0, -50.0, 50.0); - - - - - -} - -void ConcaveRaycastDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_animatedMesh) - { - static float offset=0.f; - offset+=0.01f; - - setVertexPositions(waveheight,offset); - - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - - trimeshShape->refitTree(worldMin,worldMax); - - //clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation. - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - } - - m_dynamicsWorld->stepSimulation(1./60.,0); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - raycastBar.move (dt); - raycastBar.cast (m_dynamicsWorld); - renderme(); - raycastBar.draw (); - glFlush(); - glutSwapBuffers(); - -} - - - - -void ConcaveRaycastDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - raycastBar.draw (); - glFlush(); - glutSwapBuffers(); -} - - - -void ConcaveRaycastDemo::exitPhysics() -{ - - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btTriangleIndexVertexArray* m_indexVertexArrays; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - class btThreadSupportInterface* m_threadSupportRaycast; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - bool m_animatedMesh; - - public: - - ConcaveRaycastDemo() : m_animatedMesh(false) - { - - } - void initPhysics(); - - void exitPhysics(); - - virtual ~ConcaveRaycastDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - //to show refit works - void setVertexPositions(float waveheight, float offset); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - ConcaveRaycastDemo* demo = new ConcaveRaycastDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - }; -}; - -#endif //CONCAVE_RAYCAST_DEMO_H - diff --git a/Demos/ConcaveRaycastDemo/main.cpp b/Demos/ConcaveRaycastDemo/main.cpp deleted file mode 100644 index 03fe36f08..000000000 --- a/Demos/ConcaveRaycastDemo/main.cpp +++ /dev/null @@ -1,15 +0,0 @@ - -#include "ConcaveRaycastDemo.h" -#include "GlutStuff.h" - - -int main(int argc,char** argv) -{ - - ConcaveRaycastDemo* concaveRaycastDemo = new ConcaveRaycastDemo(); - concaveRaycastDemo->initPhysics(); - concaveRaycastDemo->setCameraDistance(30.f); - - return glutmain(argc, argv,640,480,"Concave Raycast Demo",concaveRaycastDemo); -} - diff --git a/Demos/ConstraintDemo/CMakeLists.txt b/Demos/ConstraintDemo/CMakeLists.txt deleted file mode 100644 index 6051a2455..000000000 --- a/Demos/ConstraintDemo/CMakeLists.txt +++ /dev/null @@ -1,52 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} - ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppConstraintDemo - ConstraintDemo.cpp - ConstraintDemo.h - main.cpp - ) -ELSE (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppConstraintDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32ConstraintDemo.cpp - ConstraintDemo.cpp - ConstraintDemo.h - ) -ENDIF (USE_GLUT) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppConstraintDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppConstraintDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppConstraintDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/ConstraintDemo/ConstraintDemo.cpp b/Demos/ConstraintDemo/ConstraintDemo.cpp deleted file mode 100644 index 765c533f6..000000000 --- a/Demos/ConstraintDemo/ConstraintDemo.cpp +++ /dev/null @@ -1,863 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" - -#include "GLDebugFont.h" -#include //printf debugging - -#include "ConstraintDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -#include "GLDebugDrawer.h" -static GLDebugDrawer gDebugDrawer; - - - -const int numObjects = 3; - -#define ENABLE_ALL_DEMOS 1 - -#define CUBE_HALF_EXTENTS 1.f - -#define SIMD_PI_2 ((SIMD_PI)*0.5f) -#define SIMD_PI_4 ((SIMD_PI)*0.25f) - - - - -btTransform sliderTransform; -btVector3 lowerSliderLimit = btVector3(-10,0,0); -btVector3 hiSliderLimit = btVector3(10,0,0); - -btRigidBody* d6body0 =0; - -btHingeConstraint* spDoorHinge = NULL; -btHingeConstraint* spHingeDynAB = NULL; -btGeneric6DofConstraint* spSlider6Dof = NULL; - -static bool s_bTestConeTwistMotor = false; - - - -void drawLimit() -{ - btVector3 from = sliderTransform*lowerSliderLimit; - btVector3 to = sliderTransform*hiSliderLimit; - btVector3 color(255,0,0); - glBegin(GL_LINES); - glColor3f(color.getX(), color.getY(), color.getZ()); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - if (d6body0) - { - from = d6body0->getWorldTransform().getOrigin(); - to = from + d6body0->getWorldTransform().getBasis() * btVector3(0,0,10); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - } - glEnd(); -} - - -void ConstraintDemo::setupEmptyDynamicsWorld() -{ - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - m_overlappingPairCache = new btDbvtBroadphase(); - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration); - -} - -void ConstraintDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} -void ConstraintDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - setCameraDistance(26.f); - m_Time = 0; - - setupEmptyDynamicsWorld(); - - m_dynamicsWorld->setDebugDrawer(&gDebugDrawer); - - - //btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(40.),btScalar(50.))); - btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),40); - - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-56,0)); - btRigidBody* groundBody; - groundBody= localCreateRigidBody(0, groundTransform, groundShape); - - - - btCollisionShape* shape = new btBoxShape(btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)); - m_collisionShapes.push_back(shape); - btTransform trans; - trans.setIdentity(); - trans.setOrigin(btVector3(0,20,0)); - - float mass = 1.f; - -#if ENABLE_ALL_DEMOS -///gear constraint demo - -#define THETA SIMD_PI/4.f -#define L_1 (2 - tan(THETA)) -#define L_2 (1 / cos(THETA)) -#define RATIO L_2 / L_1 - - btRigidBody* bodyA=0; - btRigidBody* bodyB=0; - - { - btCollisionShape* cylA = new btCylinderShape(btVector3(0.2,0.25,0.2)); - btCollisionShape* cylB = new btCylinderShape(btVector3(L_1,0.025,L_1)); - btCompoundShape* cyl0 = new btCompoundShape(); - cyl0->addChildShape(btTransform::getIdentity(),cylA); - cyl0->addChildShape(btTransform::getIdentity(),cylB); - - btScalar mass = 6.28; - btVector3 localInertia; - cyl0->calculateLocalInertia(mass,localInertia); - btRigidBody::btRigidBodyConstructionInfo ci(mass,0,cyl0,localInertia); - ci.m_startWorldTransform.setOrigin(btVector3(-8,1,-8)); - - btRigidBody* body = new btRigidBody(ci);//1,0,cyl0,localInertia); - m_dynamicsWorld->addRigidBody(body); - body->setLinearFactor(btVector3(0,0,0)); - body->setAngularFactor(btVector3(0,1,0)); - bodyA = body; - } - - { - btCollisionShape* cylA = new btCylinderShape(btVector3(0.2,0.26,0.2)); - btCollisionShape* cylB = new btCylinderShape(btVector3(L_2,0.025,L_2)); - btCompoundShape* cyl0 = new btCompoundShape(); - cyl0->addChildShape(btTransform::getIdentity(),cylA); - cyl0->addChildShape(btTransform::getIdentity(),cylB); - - btScalar mass = 6.28; - btVector3 localInertia; - cyl0->calculateLocalInertia(mass,localInertia); - btRigidBody::btRigidBodyConstructionInfo ci(mass,0,cyl0,localInertia); - ci.m_startWorldTransform.setOrigin(btVector3(-10,2,-8)); - - - btQuaternion orn(btVector3(0,0,1),-THETA); - ci.m_startWorldTransform.setRotation(orn); - - btRigidBody* body = new btRigidBody(ci);//1,0,cyl0,localInertia); - body->setLinearFactor(btVector3(0,0,0)); - btHingeConstraint* hinge = new btHingeConstraint(*body,btVector3(0,0,0),btVector3(0,1,0),true); - m_dynamicsWorld->addConstraint(hinge); - bodyB= body; - body->setAngularVelocity(btVector3(0,3,0)); - - m_dynamicsWorld->addRigidBody(body); - } - - btVector3 axisA(0,1,0); - btVector3 axisB(0,1,0); - btQuaternion orn(btVector3(0,0,1),-THETA); - btMatrix3x3 mat(orn); - axisB = mat.getRow(1); - - btGearConstraint* gear = new btGearConstraint(*bodyA,*bodyB, axisA,axisB,RATIO); - m_dynamicsWorld->addConstraint(gear,true); - - -#endif - - -#if ENABLE_ALL_DEMOS - //point to point constraint with a breaking threshold - { - trans.setIdentity(); - trans.setOrigin(btVector3(1,30,-5)); - localCreateRigidBody( mass,trans,shape); - trans.setOrigin(btVector3(0,0,-5)); - - btRigidBody* body0 = localCreateRigidBody( mass,trans,shape); - trans.setOrigin(btVector3(2*CUBE_HALF_EXTENTS,20,0)); - mass = 1.f; - // btRigidBody* body1 = 0;//localCreateRigidBody( mass,trans,shape); - btVector3 pivotInA(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,0); - btTypedConstraint* p2p = new btPoint2PointConstraint(*body0,pivotInA); - m_dynamicsWorld->addConstraint(p2p); - p2p ->setBreakingImpulseThreshold(10.2); - p2p->setDbgDrawSize(btScalar(5.f)); - } -#endif - - - -#if ENABLE_ALL_DEMOS - //point to point constraint (ball socket) - { - btRigidBody* body0 = localCreateRigidBody( mass,trans,shape); - trans.setOrigin(btVector3(2*CUBE_HALF_EXTENTS,20,0)); - - mass = 1.f; -// btRigidBody* body1 = 0;//localCreateRigidBody( mass,trans,shape); -// btRigidBody* body1 = localCreateRigidBody( 0.0,trans,0); - //body1->setActivationState(DISABLE_DEACTIVATION); - //body1->setDamping(0.3,0.3); - - btVector3 pivotInA(CUBE_HALF_EXTENTS,-CUBE_HALF_EXTENTS,-CUBE_HALF_EXTENTS); - btVector3 axisInA(0,0,1); - - // btVector3 pivotInB = body1 ? body1->getCenterOfMassTransform().inverse()(body0->getCenterOfMassTransform()(pivotInA)) : pivotInA; -// btVector3 axisInB = body1? -// (body1->getCenterOfMassTransform().getBasis().inverse()*(body1->getCenterOfMassTransform().getBasis() * axisInA)) : - body0->getCenterOfMassTransform().getBasis() * axisInA; - -#define P2P -#ifdef P2P - btTypedConstraint* p2p = new btPoint2PointConstraint(*body0,pivotInA); - //btTypedConstraint* p2p = new btPoint2PointConstraint(*body0,*body1,pivotInA,pivotInB); - //btTypedConstraint* hinge = new btHingeConstraint(*body0,*body1,pivotInA,pivotInB,axisInA,axisInB); - m_dynamicsWorld->addConstraint(p2p); - p2p->setDbgDrawSize(btScalar(5.f)); -#else - btHingeConstraint* hinge = new btHingeConstraint(*body0,pivotInA,axisInA); - - //use zero targetVelocity and a small maxMotorImpulse to simulate joint friction - //float targetVelocity = 0.f; - //float maxMotorImpulse = 0.01; - float targetVelocity = 1.f; - float maxMotorImpulse = 1.0f; - hinge->enableAngularMotor(true,targetVelocity,maxMotorImpulse); - m_dynamicsWorld->addConstraint(hinge); - hinge->setDbgDrawSize(btScalar(5.f)); -#endif //P2P - - - - - } -#endif - - -#if ENABLE_ALL_DEMOS - { - btTransform trans; - trans.setIdentity(); - btVector3 worldPos(-20,0,30); - trans.setOrigin(worldPos); - - btTransform frameInA, frameInB; - frameInA = btTransform::getIdentity(); - frameInB = btTransform::getIdentity(); - - btRigidBody* pRbA1 = localCreateRigidBody(mass, trans, shape); -// btRigidBody* pRbA1 = localCreateRigidBody(0.f, trans, shape); - pRbA1->setActivationState(DISABLE_DEACTIVATION); - - // add dynamic rigid body B1 - worldPos.setValue(-30,0,30); - trans.setOrigin(worldPos); - btRigidBody* pRbB1 = localCreateRigidBody(mass, trans, shape); -// btRigidBody* pRbB1 = localCreateRigidBody(0.f, trans, shape); - pRbB1->setActivationState(DISABLE_DEACTIVATION); - - // create slider constraint between A1 and B1 and add it to world - - btSliderConstraint* spSlider1 = new btSliderConstraint(*pRbA1, *pRbB1, frameInA, frameInB, true); -// spSlider1 = new btSliderConstraint(*pRbA1, *pRbB1, frameInA, frameInB, false); - spSlider1->setLowerLinLimit(-15.0F); - spSlider1->setUpperLinLimit(-5.0F); -// spSlider1->setLowerLinLimit(5.0F); -// spSlider1->setUpperLinLimit(15.0F); -// spSlider1->setLowerLinLimit(-10.0F); -// spSlider1->setUpperLinLimit(-10.0F); - - spSlider1->setLowerAngLimit(-SIMD_PI / 3.0F); - spSlider1->setUpperAngLimit( SIMD_PI / 3.0F); - - - m_dynamicsWorld->addConstraint(spSlider1, true); - spSlider1->setDbgDrawSize(btScalar(5.f)); - } -#endif - -#if ENABLE_ALL_DEMOS - //create a slider, using the generic D6 constraint - { - mass = 1.f; - btVector3 sliderWorldPos(0,10,0); - btVector3 sliderAxis(1,0,0); - btScalar angle=0.f;//SIMD_RADS_PER_DEG * 10.f; - btMatrix3x3 sliderOrientation(btQuaternion(sliderAxis ,angle)); - trans.setIdentity(); - trans.setOrigin(sliderWorldPos); - //trans.setBasis(sliderOrientation); - sliderTransform = trans; - - d6body0 = localCreateRigidBody( mass,trans,shape); - d6body0->setActivationState(DISABLE_DEACTIVATION); - btRigidBody* fixedBody1 = localCreateRigidBody(0,trans,0); - m_dynamicsWorld->addRigidBody(fixedBody1); - - btTransform frameInA, frameInB; - frameInA = btTransform::getIdentity(); - frameInB = btTransform::getIdentity(); - frameInA.setOrigin(btVector3(0., 5., 0.)); - frameInB.setOrigin(btVector3(0., 5., 0.)); - -// bool useLinearReferenceFrameA = false;//use fixed frame B for linear llimits - bool useLinearReferenceFrameA = true;//use fixed frame A for linear llimits - spSlider6Dof = new btGeneric6DofConstraint(*fixedBody1, *d6body0,frameInA,frameInB,useLinearReferenceFrameA); - spSlider6Dof->setLinearLowerLimit(lowerSliderLimit); - spSlider6Dof->setLinearUpperLimit(hiSliderLimit); - - //range should be small, otherwise singularities will 'explode' the constraint -// spSlider6Dof->setAngularLowerLimit(btVector3(-1.5,0,0)); -// spSlider6Dof->setAngularUpperLimit(btVector3(1.5,0,0)); -// spSlider6Dof->setAngularLowerLimit(btVector3(0,0,0)); -// spSlider6Dof->setAngularUpperLimit(btVector3(0,0,0)); - spSlider6Dof->setAngularLowerLimit(btVector3(-SIMD_PI,0,0)); - spSlider6Dof->setAngularUpperLimit(btVector3(1.5,0,0)); - - spSlider6Dof->getTranslationalLimitMotor()->m_enableMotor[0] = true; - spSlider6Dof->getTranslationalLimitMotor()->m_targetVelocity[0] = -5.0f; - spSlider6Dof->getTranslationalLimitMotor()->m_maxMotorForce[0] = 0.1f; - - - m_dynamicsWorld->addConstraint(spSlider6Dof); - spSlider6Dof->setDbgDrawSize(btScalar(5.f)); - - } -#endif -#if ENABLE_ALL_DEMOS - { // create a door using hinge constraint attached to the world - btCollisionShape* pDoorShape = new btBoxShape(btVector3(2.0f, 5.0f, 0.2f)); - m_collisionShapes.push_back(pDoorShape); - btTransform doorTrans; - doorTrans.setIdentity(); - doorTrans.setOrigin(btVector3(-5.0f, -2.0f, 0.0f)); - btRigidBody* pDoorBody = localCreateRigidBody( 1.0, doorTrans, pDoorShape); - pDoorBody->setActivationState(DISABLE_DEACTIVATION); - const btVector3 btPivotA(10.f + 2.1f, -2.0f, 0.0f ); // right next to the door slightly outside - btVector3 btAxisA( 0.0f, 1.0f, 0.0f ); // pointing upwards, aka Y-axis - - spDoorHinge = new btHingeConstraint( *pDoorBody, btPivotA, btAxisA ); - -// spDoorHinge->setLimit( 0.0f, SIMD_PI_2 ); - // test problem values -// spDoorHinge->setLimit( -SIMD_PI, SIMD_PI*0.8f); - -// spDoorHinge->setLimit( 1.f, -1.f); -// spDoorHinge->setLimit( -SIMD_PI*0.8f, SIMD_PI); -// spDoorHinge->setLimit( -SIMD_PI*0.8f, SIMD_PI, 0.9f, 0.3f, 0.0f); -// spDoorHinge->setLimit( -SIMD_PI*0.8f, SIMD_PI, 0.9f, 0.01f, 0.0f); // "sticky limits" - spDoorHinge->setLimit( -SIMD_PI * 0.25f, SIMD_PI * 0.25f ); -// spDoorHinge->setLimit( 0.0f, 0.0f ); - m_dynamicsWorld->addConstraint(spDoorHinge); - spDoorHinge->setDbgDrawSize(btScalar(5.f)); - - //doorTrans.setOrigin(btVector3(-5.0f, 2.0f, 0.0f)); - //btRigidBody* pDropBody = localCreateRigidBody( 10.0, doorTrans, shape); - } -#endif -#if ENABLE_ALL_DEMOS - { // create a generic 6DOF constraint - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(10.), btScalar(6.), btScalar(0.))); - tr.getBasis().setEulerZYX(0,0,0); -// btRigidBody* pBodyA = localCreateRigidBody( mass, tr, shape); - btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape); -// btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, 0); - pBodyA->setActivationState(DISABLE_DEACTIVATION); - - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(0.), btScalar(6.), btScalar(0.))); - tr.getBasis().setEulerZYX(0,0,0); - btRigidBody* pBodyB = localCreateRigidBody(mass, tr, shape); -// btRigidBody* pBodyB = localCreateRigidBody(0.f, tr, shape); - pBodyB->setActivationState(DISABLE_DEACTIVATION); - - btTransform frameInA, frameInB; - frameInA = btTransform::getIdentity(); - frameInA.setOrigin(btVector3(btScalar(-5.), btScalar(0.), btScalar(0.))); - frameInB = btTransform::getIdentity(); - frameInB.setOrigin(btVector3(btScalar(5.), btScalar(0.), btScalar(0.))); - - btGeneric6DofConstraint* pGen6DOF = new btGeneric6DofConstraint(*pBodyA, *pBodyB, frameInA, frameInB, true); -// btGeneric6DofConstraint* pGen6DOF = new btGeneric6DofConstraint(*pBodyA, *pBodyB, frameInA, frameInB, false); - pGen6DOF->setLinearLowerLimit(btVector3(-10., -2., -1.)); - pGen6DOF->setLinearUpperLimit(btVector3(10., 2., 1.)); -// pGen6DOF->setLinearLowerLimit(btVector3(-10., 0., 0.)); -// pGen6DOF->setLinearUpperLimit(btVector3(10., 0., 0.)); -// pGen6DOF->setLinearLowerLimit(btVector3(0., 0., 0.)); -// pGen6DOF->setLinearUpperLimit(btVector3(0., 0., 0.)); - -// pGen6DOF->getTranslationalLimitMotor()->m_enableMotor[0] = true; -// pGen6DOF->getTranslationalLimitMotor()->m_targetVelocity[0] = 5.0f; -// pGen6DOF->getTranslationalLimitMotor()->m_maxMotorForce[0] = 0.1f; - - -// pGen6DOF->setAngularLowerLimit(btVector3(0., SIMD_HALF_PI*0.9, 0.)); -// pGen6DOF->setAngularUpperLimit(btVector3(0., -SIMD_HALF_PI*0.9, 0.)); -// pGen6DOF->setAngularLowerLimit(btVector3(0., 0., -SIMD_HALF_PI)); -// pGen6DOF->setAngularUpperLimit(btVector3(0., 0., SIMD_HALF_PI)); - - pGen6DOF->setAngularLowerLimit(btVector3(-SIMD_HALF_PI * 0.5f, -0.75, -SIMD_HALF_PI * 0.8f)); - pGen6DOF->setAngularUpperLimit(btVector3(SIMD_HALF_PI * 0.5f, 0.75, SIMD_HALF_PI * 0.8f)); -// pGen6DOF->setAngularLowerLimit(btVector3(0.f, -0.75, SIMD_HALF_PI * 0.8f)); -// pGen6DOF->setAngularUpperLimit(btVector3(0.f, 0.75, -SIMD_HALF_PI * 0.8f)); -// pGen6DOF->setAngularLowerLimit(btVector3(0.f, -SIMD_HALF_PI * 0.8f, SIMD_HALF_PI * 1.98f)); -// pGen6DOF->setAngularUpperLimit(btVector3(0.f, SIMD_HALF_PI * 0.8f, -SIMD_HALF_PI * 1.98f)); - - - -// pGen6DOF->setAngularLowerLimit(btVector3(-0.75,-0.5, -0.5)); -// pGen6DOF->setAngularUpperLimit(btVector3(0.75,0.5, 0.5)); -// pGen6DOF->setAngularLowerLimit(btVector3(-0.75,0., 0.)); -// pGen6DOF->setAngularUpperLimit(btVector3(0.75,0., 0.)); -// pGen6DOF->setAngularLowerLimit(btVector3(0., -0.7,0.)); -// pGen6DOF->setAngularUpperLimit(btVector3(0., 0.7, 0.)); -// pGen6DOF->setAngularLowerLimit(btVector3(-1., 0.,0.)); -// pGen6DOF->setAngularUpperLimit(btVector3(1., 0., 0.)); - - m_dynamicsWorld->addConstraint(pGen6DOF, true); - pGen6DOF->setDbgDrawSize(btScalar(5.f)); - } -#endif -#if ENABLE_ALL_DEMOS - { // create a ConeTwist constraint - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-10.), btScalar(5.), btScalar(0.))); - tr.getBasis().setEulerZYX(0,0,0); - btRigidBody* pBodyA = localCreateRigidBody( 1.0, tr, shape); -// btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape); - pBodyA->setActivationState(DISABLE_DEACTIVATION); - - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-10.), btScalar(-5.), btScalar(0.))); - tr.getBasis().setEulerZYX(0,0,0); - btRigidBody* pBodyB = localCreateRigidBody(0.0, tr, shape); -// btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape); - - btTransform frameInA, frameInB; - frameInA = btTransform::getIdentity(); - frameInA.getBasis().setEulerZYX(0, 0, SIMD_PI_2); - frameInA.setOrigin(btVector3(btScalar(0.), btScalar(-5.), btScalar(0.))); - frameInB = btTransform::getIdentity(); - frameInB.getBasis().setEulerZYX(0,0, SIMD_PI_2); - frameInB.setOrigin(btVector3(btScalar(0.), btScalar(5.), btScalar(0.))); - - m_ctc = new btConeTwistConstraint(*pBodyA, *pBodyB, frameInA, frameInB); -// m_ctc->setLimit(btScalar(SIMD_PI_4), btScalar(SIMD_PI_4), btScalar(SIMD_PI) * 0.8f); -// m_ctc->setLimit(btScalar(SIMD_PI_4*0.6f), btScalar(SIMD_PI_4), btScalar(SIMD_PI) * 0.8f, 1.0f); // soft limit == hard limit - m_ctc->setLimit(btScalar(SIMD_PI_4*0.6f), btScalar(SIMD_PI_4), btScalar(SIMD_PI) * 0.8f, 0.5f); - m_dynamicsWorld->addConstraint(m_ctc, true); - m_ctc->setDbgDrawSize(btScalar(5.f)); - // s_bTestConeTwistMotor = true; // use only with old solver for now - s_bTestConeTwistMotor = false; - } -#endif -#if ENABLE_ALL_DEMOS - { // Hinge connected to the world, with motor (to hinge motor with new and old constraint solver) - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(0.), btScalar(0.), btScalar(0.))); - btRigidBody* pBody = localCreateRigidBody( 1.0, tr, shape); - pBody->setActivationState(DISABLE_DEACTIVATION); - const btVector3 btPivotA( 10.0f, 0.0f, 0.0f ); - btVector3 btAxisA( 0.0f, 0.0f, 1.0f ); - - btHingeConstraint* pHinge = new btHingeConstraint( *pBody, btPivotA, btAxisA ); -// pHinge->enableAngularMotor(true, -1.0, 0.165); // use for the old solver - pHinge->enableAngularMotor(true, -1.0f, 1.65f); // use for the new SIMD solver - m_dynamicsWorld->addConstraint(pHinge); - pHinge->setDbgDrawSize(btScalar(5.f)); - } -#endif - -#if ENABLE_ALL_DEMOS - { - // create a universal joint using generic 6DOF constraint - // create two rigid bodies - // static bodyA (parent) on top: - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(20.), btScalar(4.), btScalar(0.))); - btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape); - pBodyA->setActivationState(DISABLE_DEACTIVATION); - // dynamic bodyB (child) below it : - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(20.), btScalar(0.), btScalar(0.))); - btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape); - pBodyB->setActivationState(DISABLE_DEACTIVATION); - // add some (arbitrary) data to build constraint frames - btVector3 parentAxis(1.f, 0.f, 0.f); - btVector3 childAxis(0.f, 0.f, 1.f); - btVector3 anchor(20.f, 2.f, 0.f); - - btUniversalConstraint* pUniv = new btUniversalConstraint(*pBodyA, *pBodyB, anchor, parentAxis, childAxis); - pUniv->setLowerLimit(-SIMD_HALF_PI * 0.5f, -SIMD_HALF_PI * 0.5f); - pUniv->setUpperLimit(SIMD_HALF_PI * 0.5f, SIMD_HALF_PI * 0.5f); - // add constraint to world - m_dynamicsWorld->addConstraint(pUniv, true); - // draw constraint frames and limits for debugging - pUniv->setDbgDrawSize(btScalar(5.f)); - } -#endif - -#if ENABLE_ALL_DEMOS - { // create a generic 6DOF constraint with springs - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-20.), btScalar(16.), btScalar(0.))); - tr.getBasis().setEulerZYX(0,0,0); - btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape); - pBodyA->setActivationState(DISABLE_DEACTIVATION); - - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-10.), btScalar(16.), btScalar(0.))); - tr.getBasis().setEulerZYX(0,0,0); - btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape); - pBodyB->setActivationState(DISABLE_DEACTIVATION); - - btTransform frameInA, frameInB; - frameInA = btTransform::getIdentity(); - frameInA.setOrigin(btVector3(btScalar(10.), btScalar(0.), btScalar(0.))); - frameInB = btTransform::getIdentity(); - frameInB.setOrigin(btVector3(btScalar(0.), btScalar(0.), btScalar(0.))); - - btGeneric6DofSpringConstraint* pGen6DOFSpring = new btGeneric6DofSpringConstraint(*pBodyA, *pBodyB, frameInA, frameInB, true); - pGen6DOFSpring->setLinearUpperLimit(btVector3(5., 0., 0.)); - pGen6DOFSpring->setLinearLowerLimit(btVector3(-5., 0., 0.)); - - pGen6DOFSpring->setAngularLowerLimit(btVector3(0.f, 0.f, -1.5f)); - pGen6DOFSpring->setAngularUpperLimit(btVector3(0.f, 0.f, 1.5f)); - - m_dynamicsWorld->addConstraint(pGen6DOFSpring, true); - pGen6DOFSpring->setDbgDrawSize(btScalar(5.f)); - - pGen6DOFSpring->enableSpring(0, true); - pGen6DOFSpring->setStiffness(0, 39.478f); - pGen6DOFSpring->setDamping(0, 0.5f); - pGen6DOFSpring->enableSpring(5, true); - pGen6DOFSpring->setStiffness(5, 39.478f); - pGen6DOFSpring->setDamping(0, 0.3f); - pGen6DOFSpring->setEquilibriumPoint(); - } -#endif -#if ENABLE_ALL_DEMOS - { - // create a Hinge2 joint - // create two rigid bodies - // static bodyA (parent) on top: - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-20.), btScalar(4.), btScalar(0.))); - btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape); - pBodyA->setActivationState(DISABLE_DEACTIVATION); - // dynamic bodyB (child) below it : - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-20.), btScalar(0.), btScalar(0.))); - btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape); - pBodyB->setActivationState(DISABLE_DEACTIVATION); - // add some data to build constraint frames - btVector3 parentAxis(0.f, 1.f, 0.f); - btVector3 childAxis(1.f, 0.f, 0.f); - btVector3 anchor(-20.f, 0.f, 0.f); - btHinge2Constraint* pHinge2 = new btHinge2Constraint(*pBodyA, *pBodyB, anchor, parentAxis, childAxis); - pHinge2->setLowerLimit(-SIMD_HALF_PI * 0.5f); - pHinge2->setUpperLimit( SIMD_HALF_PI * 0.5f); - // add constraint to world - m_dynamicsWorld->addConstraint(pHinge2, true); - // draw constraint frames and limits for debugging - pHinge2->setDbgDrawSize(btScalar(5.f)); - } -#endif -#if ENABLE_ALL_DEMOS - { - // create a Hinge joint between two dynamic bodies - // create two rigid bodies - // static bodyA (parent) on top: - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-20.), btScalar(-2.), btScalar(0.))); - btRigidBody* pBodyA = localCreateRigidBody( 1.0f, tr, shape); - pBodyA->setActivationState(DISABLE_DEACTIVATION); - // dynamic bodyB: - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-30.), btScalar(-2.), btScalar(0.))); - btRigidBody* pBodyB = localCreateRigidBody(10.0, tr, shape); - pBodyB->setActivationState(DISABLE_DEACTIVATION); - // add some data to build constraint frames - btVector3 axisA(0.f, 1.f, 0.f); - btVector3 axisB(0.f, 1.f, 0.f); - btVector3 pivotA(-5.f, 0.f, 0.f); - btVector3 pivotB( 5.f, 0.f, 0.f); - spHingeDynAB = new btHingeConstraint(*pBodyA, *pBodyB, pivotA, pivotB, axisA, axisB); - spHingeDynAB->setLimit(-SIMD_HALF_PI * 0.5f, SIMD_HALF_PI * 0.5f); - // add constraint to world - m_dynamicsWorld->addConstraint(spHingeDynAB, true); - // draw constraint frames and limits for debugging - spHingeDynAB->setDbgDrawSize(btScalar(5.f)); - } -#endif - -#if ENABLE_ALL_DEMOS - { // 6DOF connected to the world, with motor - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(10.), btScalar(-15.), btScalar(0.))); - btRigidBody* pBody = localCreateRigidBody( 1.0, tr, shape); - pBody->setActivationState(DISABLE_DEACTIVATION); - btTransform frameB; - frameB.setIdentity(); - btGeneric6DofConstraint* pGen6Dof = new btGeneric6DofConstraint( *pBody, frameB, false ); - m_dynamicsWorld->addConstraint(pGen6Dof); - pGen6Dof->setDbgDrawSize(btScalar(5.f)); - - pGen6Dof->setAngularLowerLimit(btVector3(0,0,0)); - pGen6Dof->setAngularUpperLimit(btVector3(0,0,0)); - pGen6Dof->setLinearLowerLimit(btVector3(-10., 0, 0)); - pGen6Dof->setLinearUpperLimit(btVector3(10., 0, 0)); - - pGen6Dof->getTranslationalLimitMotor()->m_enableMotor[0] = true; - pGen6Dof->getTranslationalLimitMotor()->m_targetVelocity[0] = 5.0f; - pGen6Dof->getTranslationalLimitMotor()->m_maxMotorForce[0] = 0.1f; - } -#endif - - - -} - -void ConstraintDemo::exitPhysics() -{ - - int i; - - //removed/delete constraints - for (i=m_dynamicsWorld->getNumConstraints()-1; i>=0 ;i--) - { - btTypedConstraint* constraint = m_dynamicsWorld->getConstraint(i); - m_dynamicsWorld->removeConstraint(constraint); - delete constraint; - } - m_ctc = NULL; - - //remove the rigidbodies from the dynamics world and delete them - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - - - - //delete collision shapes - for (int j=0;jenableMotor(true); - m_ctc->setMotorTargetInConstraintSpace(q1); - } - - { - static bool once = true; - if ( m_dynamicsWorld->getDebugDrawer() && once) - { - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits); - once=false; - } - } - - - { - //during idle mode, just run 1 simulation step maximum - int maxSimSubSteps = m_idle ? 1 : 1; - if (m_idle) - dt = 1.0f/420.f; - - int numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - bool verbose = false; - if (verbose) - { - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } - } - } - renderme(); - -// drawLimit(); - - glFlush(); - swapBuffers(); -} - - - - -void ConstraintDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - -// drawLimit(); - - renderme(); - - glFlush(); - swapBuffers(); -} - - -void ConstraintDemo::keyboardCallback(unsigned char key, int x, int y) -{ - (void)x; - (void)y; - switch (key) - { - case 'O' : - { - bool offectOnOff; - if(spDoorHinge) - { - offectOnOff = spDoorHinge->getUseFrameOffset(); - offectOnOff = !offectOnOff; - spDoorHinge->setUseFrameOffset(offectOnOff); - printf("DoorHinge %s frame offset\n", offectOnOff ? "uses" : "does not use"); - } - if(spHingeDynAB) - { - offectOnOff = spHingeDynAB->getUseFrameOffset(); - offectOnOff = !offectOnOff; - spHingeDynAB->setUseFrameOffset(offectOnOff); - printf("HingeDynAB %s frame offset\n", offectOnOff ? "uses" : "does not use"); - } - if(spSlider6Dof) - { - offectOnOff = spSlider6Dof->getUseFrameOffset(); - offectOnOff = !offectOnOff; - spSlider6Dof->setUseFrameOffset(offectOnOff); - printf("Slider6Dof %s frame offset\n", offectOnOff ? "uses" : "does not use"); - } - } - break; - default : - { - DemoApplication::keyboardCallback(key, x, y); - } - break; - } -} diff --git a/Demos/ConstraintDemo/ConstraintDemo.h b/Demos/ConstraintDemo/ConstraintDemo.h deleted file mode 100644 index 5037cb91e..000000000 --- a/Demos/ConstraintDemo/ConstraintDemo.h +++ /dev/null @@ -1,75 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef CONSTRAINT_DEMO_H -#define CONSTRAINT_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -///ConstraintDemo shows how to create a constraint, like Hinge or btGenericD6constraint -class ConstraintDemo : public PlatformDemoApplication -{ - //keep track of variables to delete memory at the end - btAlignedObjectArray m_collisionShapes; - - class btBroadphaseInterface* m_overlappingPairCache; - - class btCollisionDispatcher* m_dispatcher; - - class btConstraintSolver* m_constraintSolver; - - class btDefaultCollisionConfiguration* m_collisionConfiguration; - - void setupEmptyDynamicsWorld(); - - void clientResetScene(); - - - public: - - - virtual ~ConstraintDemo(); - - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - ConstraintDemo* demo = new ConstraintDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } - - virtual void keyboardCallback(unsigned char key, int x, int y); - - // for cone-twist motor driving - float m_Time; - class btConeTwistConstraint* m_ctc; - -}; - -#endif //CONSTRAINT_DEMO_H - diff --git a/Demos/ConstraintDemo/Win32ConstraintDemo.cpp b/Demos/ConstraintDemo/Win32ConstraintDemo.cpp deleted file mode 100644 index 552c263cd..000000000 --- a/Demos/ConstraintDemo/Win32ConstraintDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "ConstraintDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new ConstraintDemo(); -} - -#endif diff --git a/Demos/ConstraintDemo/main.cpp b/Demos/ConstraintDemo/main.cpp deleted file mode 100644 index 0cec5f6cb..000000000 --- a/Demos/ConstraintDemo/main.cpp +++ /dev/null @@ -1,20 +0,0 @@ -#include "ConstraintDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" - -#include "btBulletDynamicsCommon.h" - -int main(int argc,char** argv) -{ - - - - ConstraintDemo* constraintDemo = new ConstraintDemo(); - - - constraintDemo->initPhysics(); - constraintDemo->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits); - - return glutmain(argc, argv,640,480,"Constraint Demo. http://www.continuousphysics.com/Bullet/phpBB2/",constraintDemo); -} - diff --git a/Demos/ContinuousConvexCollision/CMakeLists.txt b/Demos/ContinuousConvexCollision/CMakeLists.txt deleted file mode 100644 index 6426bc382..000000000 --- a/Demos/ContinuousConvexCollision/CMakeLists.txt +++ /dev/null @@ -1,32 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppContinuousConvexCollisionDemo - ContinuousConvexCollisionDemo.cpp -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppContinuousConvexCollisionDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppContinuousConvexCollisionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppContinuousConvexCollisionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/ContinuousConvexCollision/ContinuousConvexCollision.h b/Demos/ContinuousConvexCollision/ContinuousConvexCollision.h deleted file mode 100644 index 3f08900a4..000000000 --- a/Demos/ContinuousConvexCollision/ContinuousConvexCollision.h +++ /dev/null @@ -1,36 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef CONTINUOUS_CONVEX_COLLISION_DEMO_H -#define CONTINUOUS_CONVEX_COLLISION_DEMO_H - - - -///ContinuousConvexCollisionDemo shows the working of the continuous collision detection, including linear and angular motion -#include "GlutDemoApplication.h" -class btContinuousConvexCollisionDemo : public GlutDemoApplication -{ - public: - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - -}; - -#endif //CONTINUOUS_CONVEX_COLLISION_DEMO_H - diff --git a/Demos/ContinuousConvexCollision/ContinuousConvexCollisionDemo.cpp b/Demos/ContinuousConvexCollision/ContinuousConvexCollisionDemo.cpp deleted file mode 100644 index 932484509..000000000 --- a/Demos/ContinuousConvexCollision/ContinuousConvexCollisionDemo.cpp +++ /dev/null @@ -1,287 +0,0 @@ -/* - * Copyright (c) 2005 Erwin Coumans http://continuousphysics.com/Bullet/ - * - * Permission to use, copy, modify, distribute and sell this software - * and its documentation for any purpose is hereby granted without fee, - * provided that the above copyright notice appear in all copies. - * Erwin Coumans makes no representations about the suitability - * of this software for any purpose. - * It is provided "as is" without express or implied warranty. - */ - - -/* - Continuous Convex Collision Demo demonstrates an efficient continuous collision detection algorithm. - Both linear and angular velocities are supported. Convex Objects are sampled using Supporting Vertex. - Motion using Exponential Map. - Future ideas: Comparison with Screwing Motion. - Also comparision with Algebraic CCD and Interval Arithmetic methods (Stephane Redon) -*/ - - -///This low level demo need internal access, and intentionally doesn't include the btBulletCollisionCommon.h headerfile -#include "LinearMath/btQuaternion.h" -#include "LinearMath/btTransform.h" -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/CollisionShapes/btMinkowskiSumShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h" -#include "BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h" -#include "BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h" - -#include "LinearMath/btTransformUtil.h" -#include "DebugCastResult.h" - -#include "BulletCollision/CollisionShapes/btSphereShape.h" - -#include "BulletCollision/CollisionShapes/btTetrahedronShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h" - -#include "GL_ShapeDrawer.h" -#include "ContinuousConvexCollision.h" -#include "GlutStuff.h" - - -float yaw=0.f,pitch=0.f,roll=0.f; -const int maxNumObjects = 4; -const int numObjects = 2; - -btVector3 angVels[numObjects]; -btVector3 linVels[numObjects]; - -btPolyhedralConvexShape* shapePtr[maxNumObjects]; - - -btTransform fromTrans[maxNumObjects]; -btTransform toTrans[maxNumObjects]; - - -int screenWidth = 640; -int screenHeight = 480; - - -int main(int argc,char** argv) -{ - btContinuousConvexCollisionDemo* ccdDemo = new btContinuousConvexCollisionDemo(); - - ccdDemo->setCameraDistance(40.f); - - ccdDemo->initPhysics(); - - return glutmain(argc, argv,screenWidth,screenHeight,"Continuous Convex Collision Demo",ccdDemo); -} - - -void btContinuousConvexCollisionDemo::initPhysics() -{ - fromTrans[0].setOrigin(btVector3(0,10,20)); - toTrans[0].setOrigin(btVector3(0,10,-20)); - fromTrans[1].setOrigin(btVector3(-2,7,0)); - toTrans[1].setOrigin(btVector3(-2,10,0)); - - btMatrix3x3 identBasis; - identBasis.setIdentity(); - - btMatrix3x3 basisA; - basisA.setIdentity(); - basisA.setEulerZYX(0.f,-SIMD_HALF_PI,0.f); - - fromTrans[0].setBasis(identBasis); - toTrans[0].setBasis(basisA); - - fromTrans[1].setBasis(identBasis); - toTrans[1].setBasis(identBasis); - - toTrans[1].setBasis(identBasis); - btVector3 boxHalfExtentsA(10,1,1); - btVector3 boxHalfExtentsB(1.1f,1.1f,1.1f); - btBoxShape* boxA = new btBoxShape(boxHalfExtentsA); -// btBU_Simplex1to4* boxA = new btBU_Simplex1to4(btVector3(-2,0,-2),btVector3(2,0,-2),btVector3(0,0,2),btVector3(0,2,0)); -// btBU_Simplex1to4* boxA = new btBU_Simplex1to4(btVector3(-12,0,0),btVector3(12,0,0)); - - - btBoxShape* boxB = new btBoxShape(boxHalfExtentsB); - - shapePtr[0] = boxA; - shapePtr[1] = boxB; - - shapePtr[0]->setMargin(0.01f); - shapePtr[1]->setMargin(0.01f); - - for (int i=0;idrawOpenGL(m,shapePtr[i],btVector3(1,0,1),getDebugMode(),worldBoundsMin,worldBoundsMax); - } - } - } - - - btMatrix3x3 mat; - mat.setEulerZYX(yaw,pitch,roll); - btQuaternion orn; - mat.getRotation(orn); - orn.setEuler(yaw,pitch,roll); - fromTrans[1].setRotation(orn); - toTrans[1].setRotation(orn); - - - if (m_stepping || m_singleStep) - { - m_singleStep = false; - pitch += 0.005f; -// yaw += 0.01f; - } -// btVector3 fromA(-25,11,0); -// btVector3 toA(-15,11,0); - -// btQuaternion ornFromA(0.f,0.f,0.f,1.f); -// btQuaternion ornToA(0.f,0.f,0.f,1.f); - -// btTransform rayFromWorld(ornFromA,fromA); -// btTransform rayToWorld(ornToA,toA); - - btTransform rayFromWorld = fromTrans[0]; - btTransform rayToWorld = toTrans[0]; - - - if (drawLine) - { - glBegin(GL_LINES); - glColor3f(0, 0, 1); - glVertex3d(rayFromWorld.getOrigin().x(), rayFromWorld.getOrigin().y(),rayFromWorld.getOrigin().z()); - glVertex3d(rayToWorld.getOrigin().x(),rayToWorld.getOrigin().y(),rayToWorld.getOrigin().z()); - glEnd(); - } - - //now perform a raycast on the shapes, in local (shape) space - gGjkSimplexSolver.reset(); - - //choose one of the following lines - - - for (i=0;idrawOpenGL(m,shapePtr[i],btVector3(1,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - btDebugCastResult rayResult1(fromTrans[0],shapePtr[0],linVels[0],angVels[0],m_shapeDrawer); - - - for (i=1;im_fraction,hitTrans); - - hitTrans.getOpenGLMatrix(m); - m_shapeDrawer->drawOpenGL(m,shapePtr[0],btVector3(0,1,0),getDebugMode(),worldBoundsMin,worldBoundsMax); - - btTransformUtil::integrateTransform(fromTrans[i],linVels[i],angVels[i],rayResultPtr->m_fraction,hitTrans); - - hitTrans.getOpenGLMatrix(m); - m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(0,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax); - - - } - } - - swapBuffers(); -} - - diff --git a/Demos/ConvexDecompositionDemo/CMakeLists.txt b/Demos/ConvexDecompositionDemo/CMakeLists.txt deleted file mode 100644 index 08045bd4f..000000000 --- a/Demos/ConvexDecompositionDemo/CMakeLists.txt +++ /dev/null @@ -1,69 +0,0 @@ - -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${BULLET_PHYSICS_SOURCE_DIR}/Extras/HACD -${BULLET_PHYSICS_SOURCE_DIR}/Extras/ConvexDecomposition -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter -${GLUT_INCLUDE_DIR} - -) - -IF (USE_GLUT) - - LINK_LIBRARIES( - OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision LinearMath BulletFileLoader HACD ConvexDecomposition ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppConvexDecompositionDemo - main.cpp - ConvexDecompositionDemo.cpp - ConvexDecompositionDemo.h - ) -ELSE (USE_GLUT) - -LINK_LIBRARIES( - OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision LinearMath BulletFileLoader HACD ConvexDecomposition ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppConvexDecompositionDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - ConvexDecompositionDemo.cpp - ConvexDecompositionDemo.h - Win32ConvexDecompositionDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - -ENDIF (USE_GLUT) - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - ADD_CUSTOM_COMMAND( - TARGET AppConvexDecompositionDemo - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SerializeDemo/testFile.bullet ${CMAKE_CURRENT_BINARY_DIR}/testFile.bullet - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/ConvexDecompositionDemo/file.obj ${CMAKE_CURRENT_BINARY_DIR} - ) -ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppConvexDecompositionDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppConvexDecompositionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppConvexDecompositionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/ConvexDecompositionDemo/ConvexDecompositionDemo.cpp b/Demos/ConvexDecompositionDemo/ConvexDecompositionDemo.cpp deleted file mode 100644 index 3b081eaf9..000000000 --- a/Demos/ConvexDecompositionDemo/ConvexDecompositionDemo.cpp +++ /dev/null @@ -1,778 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "hacdCircularList.h" -#include "hacdVector.h" -#include "hacdICHull.h" -#include "hacdGraph.h" -#include "hacdHACD.h" - -#include "cd_wavefront.h" -#include "ConvexBuilder.h" - -#include "btBulletDynamicsCommon.h" - -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btIDebugDraw.h" -#include "LinearMath/btGeometryUtil.h" -#include "BulletCollision/CollisionShapes/btShapeHull.h" -#include "GLDebugDrawer.h" -GLDebugDrawer gDebugDrawer; -//#define TEST_SERIALIZATION -//#define NO_OBJ_TO_BULLET - -#ifdef TEST_SERIALIZATION -#include "LinearMath/btSerializer.h" -#include "btBulletFile.h" -#include "btBulletWorldImporter.h" -#endif - -//#define USE_PARALLEL_DISPATCHER 1 -#ifdef USE_PARALLEL_DISPATCHER -#include "../../Extras/BulletMultiThreaded/SpuGatheringCollisionDispatcher.h" -#include "../../Extras/BulletMultiThreaded/Win32ThreadSupport.h" -#include "../../Extras/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" -#endif//USE_PARALLEL_DISPATCHER - -#include "BulletCollision/CollisionDispatch/btCompoundCollisionAlgorithm.h"//for the callback - -bool MyCompoundChildShapeCallback(const btCollisionShape* pShape0, const btCollisionShape* pShape1) -{ - return true; -} - -#include "GLDebugFont.h" -#include //printf debugging - - -#include "ConvexDecompositionDemo.h" -#include "GL_ShapeDrawer.h" - -#include "GlutStuff.h" - - -btVector3 centroid=btVector3(0,0,0); -btVector3 convexDecompositionObjectOffset(10,0,0); - -#define CUBE_HALF_EXTENTS 4 - - -//////////////////////////////////// - -unsigned int tcount = 0; - -//sEnableSAT creates the data structures required for performing SAT tests between convex polyhedra, as alternative to GJK -bool sEnableSAT = false; - -void ConvexDecompositionDemo::initPhysics() -{ - initPhysics("file.obj"); -} - - - - -///MyContactCallback is just an example to show how to get access to the child shape that collided -bool MyContactCallback ( - btManifoldPoint& cp, - const btCollisionObjectWrapper* colObj0Wrap, - int partId0, - int index0, - const btCollisionObjectWrapper* colObj1Wrap, - int partId1, - int index1) -{ - - if (colObj0Wrap->getCollisionObject()->getCollisionShape()->getShapeType()==COMPOUND_SHAPE_PROXYTYPE) - { - btCompoundShape* compound = (btCompoundShape*)colObj0Wrap->getCollisionObject()->getCollisionShape(); - btCollisionShape* childShape; - childShape = compound->getChildShape(index0); - } - - if (colObj1Wrap->getCollisionObject()->getCollisionShape()->getShapeType()==COMPOUND_SHAPE_PROXYTYPE) - { - btCompoundShape* compound = (btCompoundShape*)colObj1Wrap->getCollisionObject()->getCollisionShape(); - btCollisionShape* childShape; - childShape = compound->getChildShape(index1); - } - - return true; -} - - -void ConvexDecompositionDemo::setupEmptyDynamicsWorld() -{ -m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - -#ifdef USE_PARALLEL_DISPATCHER -#ifdef USE_WIN32_THREADING - - int maxNumOutstandingTasks = 4;//number of maximum outstanding tasks - Win32ThreadSupport* threadSupport = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo( - "collision", - processCollisionTask, - createCollisionLocalStoreMemory, - maxNumOutstandingTasks)); -#else -///@todo other platform threading -///Playstation 3 SPU (SPURS) version is available through PS3 Devnet -///Libspe2 SPU support will be available soon -///pthreads version -///you can hook it up to your custom task scheduler by deriving from btThreadSupportInterface -#endif - - m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupport,maxNumOutstandingTasks,m_collisionConfiguration); -#else - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); -#endif//USE_PARALLEL_DISPATCHER - - gCompoundChildShapePairCallback = MyCompoundChildShapeCallback; - - convexDecompositionObjectOffset.setValue(10,0,0); - - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax(10000,10000,10000); - - m_broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax); - //m_broadphase = new btSimpleBroadphase(); - - m_solver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - -#ifdef USE_PARALLEL_DISPATCHER - m_dynamicsWorld->getDispatchInfo().m_enableSPU = true; -#endif //USE_PARALLEL_DISPATCHER - -} - -void ConvexDecompositionDemo::initPhysics(const char* filename) -{ - - gContactAddedCallback = &MyContactCallback; - - setupEmptyDynamicsWorld(); - - getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - setTexturing(true); - setShadows(true); - - setCameraDistance(26.f); - - -#ifndef NO_OBJ_TO_BULLET - - ConvexDecomposition::WavefrontObj wo; - - tcount = 0; - const char* prefix[]={"./","../","../../","../../../","../../../../", "ConvexDecompositionDemo/", "Demos/ConvexDecompositionDemo/", - "../Demos/ConvexDecompositionDemo/","../../Demos/ConvexDecompositionDemo/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - - for (int i=0;i m_convexShapes; - btAlignedObjectArray m_convexCentroids; - - MyConvexDecomposition (FILE* outputFile,ConvexDecompositionDemo* demo) - :m_convexDemo(demo), - mBaseCount(0), - mHullCount(0), - mOutputFile(outputFile) - - { - } - - virtual void ConvexDecompResult(ConvexDecomposition::ConvexResult &result) - { - - btTriangleMesh* trimesh = new btTriangleMesh(); - m_convexDemo->m_trimeshes.push_back(trimesh); - - btVector3 localScaling(6.f,6.f,6.f); - - //export data to .obj - printf("ConvexResult. "); - if (mOutputFile) - { - fprintf(mOutputFile,"## Hull Piece %d with %d vertices and %d triangles.\r\n", mHullCount, result.mHullVcount, result.mHullTcount ); - - fprintf(mOutputFile,"usemtl Material%i\r\n",mBaseCount); - fprintf(mOutputFile,"o Object%i\r\n",mBaseCount); - - for (unsigned int i=0; i vertices; - if ( 1 ) - { - //const unsigned int *src = result.mHullIndices; - for (unsigned int i=0; iaddTriangle(vertex0,vertex1,vertex2); - - index0+=mBaseCount; - index1+=mBaseCount; - index2+=mBaseCount; - - fprintf(mOutputFile,"f %d %d %d\r\n", index0+1, index1+1, index2+1 ); - } - } - - // float mass = 1.f; - - -//this is a tools issue: due to collision margin, convex objects overlap, compensate for it here: -//#define SHRINK_OBJECT_INWARDS 1 -#ifdef SHRINK_OBJECT_INWARDS - - float collisionMargin = 0.01f; - - btAlignedObjectArray planeEquations; - btGeometryUtil::getPlaneEquationsFromVertices(vertices,planeEquations); - - btAlignedObjectArray shiftedPlaneEquations; - for (int p=0;p shiftedVertices; - btGeometryUtil::getVerticesFromPlaneEquations(shiftedPlaneEquations,shiftedVertices); - - - btConvexHullShape* convexShape = new btConvexHullShape(&(shiftedVertices[0].getX()),shiftedVertices.size()); - -#else //SHRINK_OBJECT_INWARDS - - btConvexHullShape* convexShape = new btConvexHullShape(&(vertices[0].getX()),vertices.size()); -#endif - if (sEnableSAT) - convexShape->initializePolyhedralFeatures(); - convexShape->setMargin(0.01f); - m_convexShapes.push_back(convexShape); - m_convexCentroids.push_back(centroid); - m_convexDemo->m_collisionShapes.push_back(convexShape); - mBaseCount+=result.mHullVcount; // advance the 'base index' counter. - - - } - } - - int mBaseCount; - int mHullCount; - FILE* mOutputFile; - - }; - - if (tcount) - { - btTriangleMesh* trimesh = new btTriangleMesh(); - m_trimeshes.push_back(trimesh); - - btVector3 localScaling(6.f,6.f,6.f); - - int i; - for ( i=0;iaddTriangle(vertex0,vertex1,vertex2); - } - - - btConvexShape* tmpConvexShape = new btConvexTriangleMeshShape(trimesh); - - printf("old numTriangles= %d\n",wo.mTriCount); - printf("old numIndices = %d\n",wo.mTriCount*3); - printf("old numVertices = %d\n",wo.mVertexCount); - - printf("reducing vertices by creating a convex hull\n"); - - //create a hull approximation - btShapeHull* hull = new btShapeHull(tmpConvexShape); - btScalar margin = tmpConvexShape->getMargin(); - hull->buildHull(margin); - tmpConvexShape->setUserPointer(hull); - - - printf("new numTriangles = %d\n", hull->numTriangles ()); - printf("new numIndices = %d\n", hull->numIndices ()); - printf("new numVertices = %d\n", hull->numVertices ()); - - btConvexHullShape* convexShape = new btConvexHullShape(); - bool updateLocalAabb = false; - - for (i=0;inumVertices();i++) - { - convexShape->addPoint(hull->getVertexPointer()[i],updateLocalAabb); - } - convexShape->recalcLocalAabb(); - - if (sEnableSAT) - convexShape->initializePolyhedralFeatures(); - delete tmpConvexShape; - delete hull; - - - - m_collisionShapes.push_back(convexShape); - - float mass = 1.f; - - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,2,14)); - - localCreateRigidBody(mass, startTransform,convexShape); - - bool useQuantization = true; - btCollisionShape* concaveShape = new btBvhTriangleMeshShape(trimesh,useQuantization); - startTransform.setOrigin(convexDecompositionObjectOffset); - localCreateRigidBody(0.f,startTransform,concaveShape); - - m_collisionShapes.push_back (concaveShape); - - } - - - if (tcount) - { - //----------------------------------- - // Bullet Convex Decomposition - //----------------------------------- - - char outputFileName[512]; - strcpy(outputFileName,filename); - char *dot = strstr(outputFileName,"."); - if ( dot ) - *dot = 0; - strcat(outputFileName,"_convex.obj"); - FILE* outputFile = fopen(outputFileName,"wb"); - - unsigned int depth = 5; - float cpercent = 5; - float ppercent = 15; - unsigned int maxv = 16; - float skinWidth = 0.0; - - printf("WavefrontObj num triangles read %i\n",tcount); - ConvexDecomposition::DecompDesc desc; - desc.mVcount = wo.mVertexCount; - desc.mVertices = wo.mVertices; - desc.mTcount = wo.mTriCount; - desc.mIndices = (unsigned int *)wo.mIndices; - desc.mDepth = depth; - desc.mCpercent = cpercent; - desc.mPpercent = ppercent; - desc.mMaxVertices = maxv; - desc.mSkinWidth = skinWidth; - - MyConvexDecomposition convexDecomposition(outputFile,this); - desc.mCallback = &convexDecomposition; - - - //----------------------------------------------- - // HACD - //----------------------------------------------- - - std::vector< HACD::Vec3 > points; - std::vector< HACD::Vec3 > triangles; - - for(int i=0; i vertex(wo.mVertices[index], wo.mVertices[index+1],wo.mVertices[index+2]); - points.push_back(vertex); - } - - for(int i=0;i triangle(wo.mIndices[index], wo.mIndices[index+1], wo.mIndices[index+2]); - triangles.push_back(triangle); - } - - - HACD::HACD myHACD; - myHACD.SetPoints(&points[0]); - myHACD.SetNPoints(points.size()); - myHACD.SetTriangles(&triangles[0]); - myHACD.SetNTriangles(triangles.size()); - myHACD.SetCompacityWeight(0.1); - myHACD.SetVolumeWeight(0.0); - - // HACD parameters - // Recommended parameters: 2 100 0 0 0 0 - size_t nClusters = 2; - double concavity = 100; - bool invert = false; - bool addExtraDistPoints = false; - bool addNeighboursDistPoints = false; - bool addFacesPoints = false; - - myHACD.SetNClusters(nClusters); // minimum number of clusters - myHACD.SetNVerticesPerCH(100); // max of 100 vertices per convex-hull - myHACD.SetConcavity(concavity); // maximum concavity - myHACD.SetAddExtraDistPoints(addExtraDistPoints); - myHACD.SetAddNeighboursDistPoints(addNeighboursDistPoints); - myHACD.SetAddFacesPoints(addFacesPoints); - - myHACD.Compute(); - nClusters = myHACD.GetNClusters(); - - myHACD.Save("output.wrl", false); - - - //convexDecomposition.performConvexDecomposition(desc); - -// ConvexBuilder cb(desc.mCallback); -// cb.process(desc); - //now create some bodies - - if (1) - { - btCompoundShape* compound = new btCompoundShape(); - m_collisionShapes.push_back (compound); - - btTransform trans; - trans.setIdentity(); - - for (int c=0;c * pointsCH = new HACD::Vec3[nPoints]; - HACD::Vec3 * trianglesCH = new HACD::Vec3[nTriangles]; - myHACD.GetCH(c, pointsCH, trianglesCH); - - // points - for(size_t v = 0; v < nPoints; v++) - { - vertices[3*v] = pointsCH[v].X(); - vertices[3*v+1] = pointsCH[v].Y(); - vertices[3*v+2] = pointsCH[v].Z(); - } - // triangles - for(size_t f = 0; f < nTriangles; f++) - { - triangles[3*f] = trianglesCH[f].X(); - triangles[3*f+1] = trianglesCH[f].Y(); - triangles[3*f+2] = trianglesCH[f].Z(); - } - - delete [] pointsCH; - delete [] trianglesCH; - - ConvexResult r(nPoints, vertices, nTriangles, triangles); - convexDecomposition.ConvexDecompResult(r); - } - - for (int i=0;iaddChildShape(trans,convexShape); - - btRigidBody* body; - body = localCreateRigidBody( 1.0, trans,convexShape); - } -/* for (int i=0;iaddChildShape(trans,convexShape); - - btRigidBody* body; - body = localCreateRigidBody( 1.0, trans,convexShape); - }*/ - -#if 1 - btScalar mass=10.f; - trans.setOrigin(-convexDecompositionObjectOffset); - btRigidBody* body = localCreateRigidBody( mass, trans,compound); - body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - convexDecompositionObjectOffset.setZ(6); - trans.setOrigin(-convexDecompositionObjectOffset); - body = localCreateRigidBody( mass, trans,compound); - body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - convexDecompositionObjectOffset.setZ(-6); - trans.setOrigin(-convexDecompositionObjectOffset); - body = localCreateRigidBody( mass, trans,compound); - body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); -#endif - } - - - if (outputFile) - fclose(outputFile); - - - } - - - -#ifdef TEST_SERIALIZATION - //test serializing this - - int maxSerializeBufferSize = 1024*1024*5; - - btDefaultSerializer* serializer = new btDefaultSerializer(maxSerializeBufferSize); - m_dynamicsWorld->serialize(serializer); - - FILE* f2 = fopen("testFile.bullet","wb"); - fwrite(serializer->getBufferPointer(),serializer->getCurrentBufferSize(),1,f2); - fclose(f2); - - exitPhysics(); - - //now try again from the loaded file - setupEmptyDynamicsWorld(); -#endif //TEST_SERIALIZATION - -#endif //NO_OBJ_TO_BULLET - -#ifdef TEST_SERIALIZATION - - btBulletWorldImporter* fileLoader = new btBulletWorldImporter(m_dynamicsWorld); - //fileLoader->setVerboseMode(true); - - fileLoader->loadFile("testFile.bullet"); - //fileLoader->loadFile("testFile64Double.bullet"); - //fileLoader->loadFile("testFile64Single.bullet"); - //fileLoader->loadFile("testFile32Single.bullet"); - - - - -#endif //TEST_SERIALIZATION - -} - -void ConvexDecompositionDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - swapBuffers(); - -} - - - -void ConvexDecompositionDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - - glFlush(); - swapBuffers(); -} - - - - -void ConvexDecompositionDemo::exitPhysics() -{ - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (i=0;i m_collisionShapes; - - btAlignedObjectArray m_trimeshes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - - virtual void initPhysics(); - - void initPhysics(const char* filename); - - void exitPhysics(); - - virtual void clientResetScene(); - - virtual ~ConvexDecompositionDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - ConvexDecompositionDemo* demo = new ConvexDecompositionDemo(); - demo->myinit(); - demo->initPhysics("file.obj"); - return demo; - } - - -}; - -#endif //CONVEX_DECOMPOSITION_DEMO_H - - diff --git a/Demos/ConvexDecompositionDemo/Win32ConvexDecompositionDemo.cpp b/Demos/ConvexDecompositionDemo/Win32ConvexDecompositionDemo.cpp deleted file mode 100644 index d04e1d378..000000000 --- a/Demos/ConvexDecompositionDemo/Win32ConvexDecompositionDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2010 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "ConvexDecompositionDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new ConvexDecompositionDemo(); -} - -#endif diff --git a/Demos/ConvexDecompositionDemo/file.obj b/Demos/ConvexDecompositionDemo/file.obj deleted file mode 100644 index 15047b022..000000000 --- a/Demos/ConvexDecompositionDemo/file.obj +++ /dev/null @@ -1,3578 +0,0 @@ -v 0.000118 -0.390977 -0.478607 -v 0.017389 -0.390977 -0.478271 -v 0.029547 -0.390983 -0.429828 -v 0.000118 -0.390983 -0.429848 -v 0.017389 -0.390977 -0.478271 -v 0.017389 -0.342855 -0.474044 -v 0.029547 -0.317820 -0.429577 -v 0.029547 -0.390983 -0.429828 -v 0.017389 -0.342855 -0.474044 -v 0.000118 -0.331762 -0.473074 -v 0.000118 -0.306727 -0.429520 -v 0.029547 -0.317820 -0.429577 -v -0.017152 -0.342855 -0.474044 -v -0.029311 -0.317820 -0.429577 -v -0.017152 -0.342855 -0.474044 -v -0.017152 -0.390977 -0.478271 -v -0.029311 -0.390983 -0.429828 -v -0.029311 -0.317820 -0.429577 -v -0.017152 -0.390977 -0.478271 -v -0.029311 -0.390983 -0.429828 -v 0.017389 -0.391071 -0.377731 -v 0.000118 -0.391100 -0.378066 -v 0.017389 -0.336012 -0.378305 -v 0.017389 -0.391071 -0.377731 -v 0.029547 -0.317820 -0.429577 -v 0.000118 -0.306727 -0.429520 -v 0.000118 -0.324876 -0.378305 -v 0.017389 -0.336012 -0.378305 -v 0.000118 -0.306727 -0.429520 -v -0.029311 -0.317820 -0.429577 -v -0.017152 -0.336012 -0.378305 -v 0.000118 -0.324876 -0.378305 -v -0.017152 -0.391071 -0.377731 -v -0.017152 -0.336012 -0.378305 -v -0.017152 -0.391071 -0.377731 -v 0.017389 -0.355018 -0.311310 -v 0.000118 -0.358745 -0.310312 -v 0.017389 -0.313071 -0.327714 -v 0.017389 -0.355018 -0.311310 -v 0.000118 -0.302315 -0.330597 -v 0.017389 -0.313071 -0.327714 -v -0.017152 -0.313071 -0.327714 -v 0.000118 -0.302315 -0.330597 -v -0.017152 -0.355018 -0.311310 -v -0.017152 -0.313071 -0.327714 -v -0.017152 -0.355018 -0.311310 -v 0.027414 -0.282077 -0.242925 -v 0.000118 -0.286749 -0.239005 -v 0.027414 -0.244765 -0.265699 -v 0.027414 -0.282077 -0.242925 -v 0.000118 -0.231283 -0.277012 -v 0.027414 -0.244765 -0.265699 -v -0.027178 -0.244765 -0.265699 -v 0.000118 -0.231283 -0.277012 -v -0.027178 -0.282077 -0.242925 -v -0.027178 -0.244765 -0.265699 -v -0.027178 -0.282077 -0.242925 -v 0.035601 -0.254040 -0.188841 -v 0.000118 -0.261848 -0.187464 -v 0.035601 -0.172486 -0.190596 -v 0.035601 -0.254040 -0.188841 -v 0.000118 -0.149955 -0.194569 -v 0.035601 -0.172486 -0.190596 -v -0.035364 -0.172486 -0.190596 -v 0.000118 -0.149955 -0.194569 -v -0.035364 -0.254040 -0.188841 -v -0.035364 -0.172486 -0.190596 -v -0.035364 -0.254040 -0.188841 -v 0.000118 -0.360973 -0.484897 -v 0.017389 -0.390977 -0.478271 -v 0.000118 -0.390977 -0.478607 -v 0.017389 -0.342855 -0.474044 -v 0.000118 -0.331762 -0.473074 -v -0.017152 -0.342855 -0.474044 -v -0.017152 -0.390977 -0.478271 -v 0.035601 -0.232880 -0.098411 -v 0.000118 -0.240808 -0.098411 -v 0.035601 -0.144967 -0.098411 -v 0.035601 -0.232880 -0.098411 -v 0.000118 -0.122088 -0.098411 -v 0.035601 -0.144967 -0.098411 -v -0.035364 -0.144967 -0.098411 -v 0.000118 -0.122088 -0.098411 -v -0.035364 -0.232880 -0.098411 -v -0.035364 -0.144967 -0.098411 -v -0.035364 -0.232880 -0.098411 -v 0.478607 -0.390977 0.000118 -v 0.478271 -0.390977 0.017389 -v 0.429828 -0.390983 0.029547 -v 0.429848 -0.390983 0.000118 -v 0.478271 -0.390977 0.017389 -v 0.474044 -0.342855 0.017389 -v 0.429577 -0.317820 0.029547 -v 0.429828 -0.390983 0.029547 -v 0.474044 -0.342855 0.017389 -v 0.473074 -0.331762 0.000118 -v 0.429520 -0.306727 0.000118 -v 0.429577 -0.317820 0.029547 -v 0.474044 -0.342855 -0.017152 -v 0.429577 -0.317820 -0.029311 -v 0.474044 -0.342855 -0.017152 -v 0.478271 -0.390977 -0.017152 -v 0.429828 -0.390983 -0.029311 -v 0.429577 -0.317820 -0.029311 -v 0.478271 -0.390977 -0.017152 -v 0.429828 -0.390983 -0.029311 -v 0.377731 -0.391071 0.017389 -v 0.378066 -0.391100 0.000118 -v 0.378305 -0.336012 0.017389 -v 0.377731 -0.391071 0.017389 -v 0.429577 -0.317820 0.029547 -v 0.429520 -0.306727 0.000118 -v 0.378305 -0.324876 0.000118 -v 0.378305 -0.336012 0.017389 -v 0.429520 -0.306727 0.000118 -v 0.429577 -0.317820 -0.029311 -v 0.378305 -0.336012 -0.017152 -v 0.378305 -0.324876 0.000118 -v 0.377731 -0.391071 -0.017152 -v 0.378305 -0.336012 -0.017152 -v 0.377731 -0.391071 -0.017152 -v 0.311310 -0.355018 0.017389 -v 0.310312 -0.358745 0.000118 -v 0.327714 -0.313071 0.017389 -v 0.311310 -0.355018 0.017389 -v 0.330597 -0.302315 0.000118 -v 0.327714 -0.313071 0.017389 -v 0.327714 -0.313071 -0.017152 -v 0.330597 -0.302315 0.000118 -v 0.311310 -0.355018 -0.017152 -v 0.327714 -0.313071 -0.017152 -v 0.311310 -0.355018 -0.017152 -v 0.242925 -0.282077 0.027414 -v 0.239005 -0.286749 0.000118 -v 0.265699 -0.244765 0.027414 -v 0.242925 -0.282077 0.027414 -v 0.277012 -0.231283 0.000118 -v 0.265699 -0.244765 0.027414 -v 0.265699 -0.244765 -0.027178 -v 0.277012 -0.231283 0.000118 -v 0.242925 -0.282077 -0.027178 -v 0.265699 -0.244765 -0.027178 -v 0.242925 -0.282077 -0.027178 -v 0.188841 -0.254040 0.035601 -v 0.187464 -0.261848 0.000118 -v 0.190596 -0.172486 0.035601 -v 0.188841 -0.254040 0.035601 -v 0.194569 -0.149955 0.000118 -v 0.190596 -0.172486 0.035601 -v 0.190596 -0.172486 -0.035364 -v 0.194569 -0.149955 0.000118 -v 0.188841 -0.254040 -0.035364 -v 0.190596 -0.172486 -0.035364 -v 0.188841 -0.254040 -0.035364 -v 0.484897 -0.360973 0.000118 -v 0.478271 -0.390977 0.017389 -v 0.478607 -0.390977 0.000118 -v 0.474044 -0.342855 0.017389 -v 0.473074 -0.331762 0.000118 -v 0.474044 -0.342855 -0.017152 -v 0.478271 -0.390977 -0.017152 -v 0.098411 -0.232880 0.035601 -v 0.098411 -0.240808 0.000118 -v 0.098411 -0.144967 0.035601 -v 0.098411 -0.232880 0.035601 -v 0.098411 -0.122088 0.000118 -v 0.098411 -0.144967 0.035601 -v 0.098411 -0.144967 -0.035364 -v 0.098411 -0.122088 0.000118 -v 0.098411 -0.232880 -0.035364 -v 0.098411 -0.144967 -0.035364 -v 0.098411 -0.232880 -0.035364 -v -0.000118 -0.390977 0.478607 -v -0.017389 -0.390977 0.478271 -v -0.029547 -0.390983 0.429828 -v -0.000118 -0.390983 0.429848 -v -0.017389 -0.390977 0.478271 -v -0.017389 -0.342855 0.474044 -v -0.029547 -0.317820 0.429577 -v -0.029547 -0.390983 0.429828 -v -0.017389 -0.342855 0.474044 -v -0.000118 -0.331762 0.473074 -v -0.000118 -0.306727 0.429520 -v -0.029547 -0.317820 0.429577 -v 0.017152 -0.342855 0.474044 -v 0.029310 -0.317820 0.429577 -v 0.017152 -0.342855 0.474044 -v 0.017152 -0.390977 0.478271 -v 0.029310 -0.390983 0.429828 -v 0.029310 -0.317820 0.429577 -v 0.017152 -0.390977 0.478271 -v 0.029310 -0.390983 0.429828 -v -0.017389 -0.391071 0.377731 -v -0.000118 -0.391100 0.378066 -v -0.017389 -0.336012 0.378305 -v -0.017389 -0.391071 0.377731 -v -0.029547 -0.317820 0.429577 -v -0.000118 -0.306727 0.429520 -v -0.000118 -0.324876 0.378305 -v -0.017389 -0.336012 0.378305 -v -0.000118 -0.306727 0.429520 -v 0.029310 -0.317820 0.429577 -v 0.017152 -0.336012 0.378305 -v -0.000118 -0.324876 0.378305 -v 0.017152 -0.391071 0.377731 -v 0.017152 -0.336012 0.378305 -v 0.017152 -0.391071 0.377731 -v -0.017389 -0.355018 0.311310 -v -0.000118 -0.358745 0.310312 -v -0.017389 -0.313071 0.327714 -v -0.017389 -0.355018 0.311310 -v -0.000118 -0.302315 0.330597 -v -0.017389 -0.313071 0.327714 -v 0.017152 -0.313071 0.327714 -v -0.000118 -0.302315 0.330597 -v 0.017152 -0.355018 0.311310 -v 0.017152 -0.313071 0.327714 -v 0.017152 -0.355018 0.311310 -v -0.027414 -0.282077 0.242925 -v -0.000118 -0.286749 0.239005 -v -0.027414 -0.244765 0.265699 -v -0.027414 -0.282077 0.242925 -v -0.000118 -0.231283 0.277012 -v -0.027414 -0.244765 0.265699 -v 0.027178 -0.244765 0.265699 -v -0.000118 -0.231283 0.277012 -v 0.027178 -0.282077 0.242925 -v 0.027178 -0.244765 0.265699 -v 0.027178 -0.282077 0.242925 -v -0.035601 -0.254040 0.188841 -v -0.000118 -0.261848 0.187464 -v -0.035601 -0.172486 0.190596 -v -0.035601 -0.254040 0.188841 -v -0.000118 -0.149955 0.194569 -v -0.035601 -0.172486 0.190596 -v 0.035364 -0.172486 0.190596 -v -0.000118 -0.149955 0.194569 -v 0.035364 -0.254040 0.188841 -v 0.035364 -0.172486 0.190596 -v 0.035364 -0.254040 0.188841 -v -0.000118 -0.360973 0.484897 -v -0.017389 -0.390977 0.478271 -v -0.000118 -0.390977 0.478607 -v -0.017389 -0.342855 0.474044 -v -0.000118 -0.331762 0.473074 -v 0.017152 -0.342855 0.474044 -v 0.017152 -0.390977 0.478271 -v -0.035601 -0.232880 0.098411 -v -0.000118 -0.240808 0.098411 -v -0.035601 -0.144967 0.098411 -v -0.035601 -0.232880 0.098411 -v -0.000118 -0.122088 0.098411 -v -0.035601 -0.144967 0.098411 -v 0.035364 -0.144967 0.098411 -v -0.000118 -0.122088 0.098411 -v 0.035364 -0.232880 0.098411 -v 0.035364 -0.144967 0.098411 -v 0.035364 -0.232880 0.098411 -v -0.478607 -0.390977 -0.000118 -v -0.478271 -0.390977 -0.017389 -v -0.429828 -0.390983 -0.029547 -v -0.429848 -0.390983 -0.000118 -v -0.478271 -0.390977 -0.017389 -v -0.474044 -0.342855 -0.017389 -v -0.429577 -0.317820 -0.029547 -v -0.429828 -0.390983 -0.029547 -v -0.474044 -0.342855 -0.017389 -v -0.473074 -0.331762 -0.000118 -v -0.429520 -0.306727 -0.000118 -v -0.429577 -0.317820 -0.029547 -v -0.474044 -0.342855 0.017152 -v -0.429577 -0.317820 0.029310 -v -0.474044 -0.342855 0.017152 -v -0.478271 -0.390977 0.017152 -v -0.429828 -0.390983 0.029310 -v -0.429577 -0.317820 0.029310 -v -0.478271 -0.390977 0.017152 -v -0.429828 -0.390983 0.029310 -v -0.377731 -0.391071 -0.017389 -v -0.378066 -0.391100 -0.000118 -v -0.378305 -0.336012 -0.017389 -v -0.377731 -0.391071 -0.017389 -v -0.429577 -0.317820 -0.029547 -v -0.429520 -0.306727 -0.000118 -v -0.378305 -0.324876 -0.000118 -v -0.378305 -0.336012 -0.017389 -v -0.429520 -0.306727 -0.000118 -v -0.429577 -0.317820 0.029310 -v -0.378305 -0.336012 0.017152 -v -0.378305 -0.324876 -0.000118 -v -0.377731 -0.391071 0.017152 -v -0.378305 -0.336012 0.017152 -v -0.377731 -0.391071 0.017152 -v -0.311310 -0.355018 -0.017389 -v -0.310312 -0.358745 -0.000118 -v -0.327714 -0.313071 -0.017389 -v -0.311310 -0.355018 -0.017389 -v -0.330597 -0.302315 -0.000118 -v -0.327714 -0.313071 -0.017389 -v -0.327714 -0.313071 0.017152 -v -0.330597 -0.302315 -0.000118 -v -0.311310 -0.355018 0.017152 -v -0.327714 -0.313071 0.017152 -v -0.311310 -0.355018 0.017152 -v -0.242925 -0.282077 -0.027414 -v -0.239005 -0.286749 -0.000118 -v -0.265699 -0.244765 -0.027414 -v -0.242925 -0.282077 -0.027414 -v -0.277012 -0.231283 -0.000118 -v -0.265699 -0.244765 -0.027414 -v -0.265699 -0.244765 0.027178 -v -0.277012 -0.231283 -0.000118 -v -0.242925 -0.282077 0.027178 -v -0.265699 -0.244765 0.027178 -v -0.242925 -0.282077 0.027178 -v -0.188841 -0.254040 -0.035601 -v -0.187464 -0.261848 -0.000118 -v -0.190596 -0.172486 -0.035601 -v -0.188841 -0.254040 -0.035601 -v -0.194569 -0.149955 -0.000118 -v -0.190596 -0.172486 -0.035601 -v -0.190596 -0.172486 0.035364 -v -0.194569 -0.149955 -0.000118 -v -0.188841 -0.254040 0.035364 -v -0.190596 -0.172486 0.035364 -v -0.188841 -0.254040 0.035364 -v -0.484897 -0.360973 -0.000118 -v -0.478271 -0.390977 -0.017389 -v -0.478607 -0.390977 -0.000118 -v -0.474044 -0.342855 -0.017389 -v -0.473074 -0.331762 -0.000118 -v -0.474044 -0.342855 0.017152 -v -0.478271 -0.390977 0.017152 -v -0.098411 -0.232880 -0.035601 -v -0.098411 -0.240808 -0.000118 -v -0.098411 -0.144967 -0.035601 -v -0.098411 -0.232880 -0.035601 -v -0.098411 -0.122088 -0.000118 -v -0.098411 -0.144967 -0.035601 -v -0.098411 -0.144967 0.035364 -v -0.098411 -0.122088 -0.000118 -v -0.098411 -0.232880 0.035364 -v -0.098411 -0.144967 0.035364 -v -0.098411 -0.232880 0.035364 -v 0.000000 -0.094464 0.000000 -v 0.043796 -0.094464 0.105844 -v 0.105811 -0.094464 0.043875 -v -0.043875 -0.094464 0.105811 -v -0.105844 -0.094464 0.043796 -v -0.105811 -0.094464 -0.043875 -v -0.043796 -0.094464 -0.105844 -v 0.043875 -0.094464 -0.105811 -v 0.105844 -0.094464 -0.043796 -v 0.043796 -0.255563 0.105844 -v 0.105811 -0.255563 0.043875 -v 0.105811 -0.094464 0.043875 -v 0.043796 -0.094464 0.105844 -v -0.043875 -0.255563 0.105811 -v 0.043796 -0.255563 0.105844 -v 0.043796 -0.094464 0.105844 -v -0.043875 -0.094464 0.105811 -v -0.105844 -0.255563 0.043796 -v -0.043875 -0.255563 0.105811 -v -0.043875 -0.094464 0.105811 -v -0.105844 -0.094464 0.043796 -v -0.105811 -0.255563 -0.043875 -v -0.105844 -0.255563 0.043796 -v -0.105844 -0.094464 0.043796 -v -0.105811 -0.094464 -0.043875 -v -0.043796 -0.255563 -0.105844 -v -0.105811 -0.255563 -0.043875 -v -0.105811 -0.094464 -0.043875 -v -0.043796 -0.094464 -0.105844 -v 0.043875 -0.255563 -0.105811 -v -0.043796 -0.255563 -0.105844 -v -0.043796 -0.094464 -0.105844 -v 0.043875 -0.094464 -0.105811 -v 0.105844 -0.255563 -0.043796 -v 0.043875 -0.255563 -0.105811 -v 0.043875 -0.094464 -0.105811 -v 0.105844 -0.094464 -0.043796 -v 0.105811 -0.255563 0.043875 -v 0.105844 -0.255563 -0.043796 -v 0.105844 -0.094464 -0.043796 -v 0.105811 -0.094464 0.043875 -v 0.000000 -0.255563 0.000000 -v 0.105811 -0.255563 0.043875 -v 0.043796 -0.255563 0.105844 -v -0.043875 -0.255563 0.105811 -v -0.105844 -0.255563 0.043796 -v -0.105811 -0.255563 -0.043875 -v -0.043796 -0.255563 -0.105844 -v 0.043875 -0.255563 -0.105811 -v 0.105844 -0.255563 -0.043796 -v -0.275954 0.604340 0.275954 -v -0.275954 0.604340 -0.275954 -v -0.275954 0.612392 -0.275954 -v -0.275954 0.612392 0.275954 -v -0.275954 0.604340 -0.275954 -v 0.275954 0.604340 -0.275954 -v 0.275954 0.612392 -0.275954 -v -0.275954 0.612392 -0.275954 -v 0.275954 0.604340 -0.275954 -v 0.275954 0.604340 0.275954 -v 0.275954 0.612392 0.275954 -v 0.275954 0.612392 -0.275954 -v 0.275954 0.604340 0.275954 -v -0.275954 0.604340 0.275954 -v -0.275954 0.612392 0.275954 -v 0.275954 0.612392 0.275954 -v -0.275954 0.612392 0.275954 -v -0.275954 0.612392 -0.275954 -v -0.284007 0.611587 -0.284007 -v -0.284007 0.611587 0.284007 -v -0.275954 0.612392 -0.275954 -v 0.275954 0.612392 -0.275954 -v 0.284007 0.611587 -0.284007 -v -0.284007 0.611587 -0.284007 -v 0.275954 0.612392 -0.275954 -v 0.275954 0.612392 0.275954 -v 0.284007 0.611587 0.284007 -v 0.284007 0.611587 -0.284007 -v 0.275954 0.612392 0.275954 -v -0.275954 0.612392 0.275954 -v -0.284007 0.611587 0.284007 -v 0.284007 0.611587 0.284007 -v -0.284007 0.611587 0.284007 -v -0.284007 0.611587 -0.284007 -v -0.284007 0.603535 -0.284007 -v -0.284007 0.603535 0.284007 -v -0.284007 0.611587 -0.284007 -v 0.284007 0.611587 -0.284007 -v 0.284007 0.603535 -0.284007 -v -0.284007 0.603535 -0.284007 -v 0.284007 0.611587 -0.284007 -v 0.284007 0.611587 0.284007 -v 0.284007 0.603535 0.284007 -v 0.284007 0.603535 -0.284007 -v 0.284007 0.611587 0.284007 -v -0.284007 0.611587 0.284007 -v -0.284007 0.603535 0.284007 -v 0.284007 0.603535 0.284007 -v -0.507297 0.549194 0.507297 -v 0.507297 0.549194 0.507297 -v 0.507297 0.550000 0.507297 -v -0.507297 0.550000 0.507297 -v 0.507297 0.549194 0.507297 -v 0.507297 0.549194 -0.507297 -v 0.507297 0.550000 -0.507297 -v 0.507297 0.550000 0.507297 -v 0.507297 0.549194 -0.507297 -v -0.507297 0.549194 -0.507297 -v -0.507297 0.550000 -0.507297 -v 0.507297 0.550000 -0.507297 -v -0.507297 0.549194 -0.507297 -v -0.507297 0.549194 0.507297 -v -0.507297 0.550000 0.507297 -v -0.507297 0.550000 -0.507297 -v 0.507297 0.558052 0.507297 -v -0.507297 0.558052 0.507297 -v 0.507297 0.558052 -0.507297 -v 0.507297 0.558052 0.507297 -v -0.507297 0.558052 -0.507297 -v 0.507297 0.558052 -0.507297 -v -0.507297 0.558052 0.507297 -v -0.507297 0.558052 -0.507297 -v 0.499245 0.566104 0.499245 -v -0.499245 0.566104 0.499245 -v 0.499245 0.566104 -0.499245 -v 0.499245 0.566104 0.499245 -v -0.499245 0.566104 -0.499245 -v 0.499245 0.566104 -0.499245 -v -0.499245 0.566104 0.499245 -v -0.499245 0.566104 -0.499245 -v 0.499245 0.574157 0.499245 -v -0.499245 0.574157 0.499245 -v 0.499245 0.574157 -0.499245 -v 0.499245 0.574157 0.499245 -v -0.499245 0.574157 -0.499245 -v 0.499245 0.574157 -0.499245 -v -0.499245 0.574157 0.499245 -v -0.499245 0.574157 -0.499245 -v 0.491193 0.582209 0.491193 -v -0.491193 0.582209 0.491193 -v 0.491193 0.582209 -0.491193 -v 0.491193 0.582209 0.491193 -v -0.491193 0.582209 -0.491193 -v 0.491193 0.582209 -0.491193 -v -0.491193 0.582209 0.491193 -v -0.491193 0.582209 -0.491193 -v -0.491193 0.582209 0.491193 -v 0.491193 0.582209 0.491193 -v 0.483140 0.583014 0.483140 -v -0.483140 0.583014 0.483140 -v 0.491193 0.582209 0.491193 -v 0.491193 0.582209 -0.491193 -v 0.483140 0.583014 -0.483140 -v 0.483140 0.583014 0.483140 -v 0.491193 0.582209 -0.491193 -v -0.491193 0.582209 -0.491193 -v -0.483140 0.583014 -0.483140 -v 0.483140 0.583014 -0.483140 -v -0.491193 0.582209 -0.491193 -v -0.491193 0.582209 0.491193 -v -0.483140 0.583014 0.483140 -v -0.483140 0.583014 -0.483140 -v -0.314041 0.591939 -0.314041 -v -0.314041 0.591939 0.314041 -v 0.314041 0.591939 -0.314041 -v -0.314041 0.591939 -0.314041 -v 0.314041 0.591939 0.314041 -v 0.314041 0.591939 -0.314041 -v -0.314041 0.591939 0.314041 -v 0.314041 0.591939 0.314041 -v -0.322094 0.591134 -0.322094 -v -0.322094 0.591134 0.322094 -v 0.322094 0.591134 -0.322094 -v -0.322094 0.591134 -0.322094 -v 0.322094 0.591134 0.322094 -v 0.322094 0.591134 -0.322094 -v -0.322094 0.591134 0.322094 -v 0.322094 0.591134 0.322094 -v -0.322094 0.583082 -0.322094 -v -0.322094 0.583082 0.322094 -v 0.322094 0.583082 -0.322094 -v -0.322094 0.583082 -0.322094 -v 0.322094 0.583082 0.322094 -v 0.322094 0.583082 -0.322094 -v -0.322094 0.583082 0.322094 -v 0.322094 0.583082 0.322094 -v -0.322094 0.583082 0.322094 -v -0.322094 0.583082 -0.322094 -v -0.483140 0.575029 -0.483140 -v -0.483140 0.575029 0.483140 -v -0.322094 0.583082 -0.322094 -v 0.322094 0.583082 -0.322094 -v 0.483140 0.575029 -0.483140 -v -0.483140 0.575029 -0.483140 -v 0.322094 0.583082 -0.322094 -v 0.322094 0.583082 0.322094 -v 0.483140 0.575029 0.483140 -v 0.483140 0.575029 -0.483140 -v 0.322094 0.583082 0.322094 -v -0.322094 0.583082 0.322094 -v -0.483140 0.575029 0.483140 -v 0.483140 0.575029 0.483140 -v -0.483140 0.575029 0.483140 -v -0.483140 0.575029 -0.483140 -v -0.483140 0.583014 -0.483140 -v -0.483140 0.583014 0.483140 -v -0.483140 0.575029 -0.483140 -v 0.483140 0.575029 -0.483140 -v 0.483140 0.583014 -0.483140 -v -0.483140 0.583014 -0.483140 -v 0.483140 0.575029 -0.483140 -v 0.483140 0.575029 0.483140 -v 0.483140 0.583014 0.483140 -v 0.483140 0.583014 -0.483140 -v 0.483140 0.575029 0.483140 -v -0.483140 0.575029 0.483140 -v -0.483140 0.583014 0.483140 -v 0.483140 0.583014 0.483140 -v 0.275954 0.604340 -0.275954 -v -0.275954 0.604340 -0.275954 -v -0.275954 0.604340 0.275954 -v 0.275954 0.604340 0.275954 -v 0.507297 0.549194 -0.507297 -v 0.507297 0.549194 0.507297 -v -0.507297 0.549194 0.507297 -v -0.507297 0.549194 -0.507297 -v 0.061122 0.493612 0.044408 -v 0.075551 0.493612 0.000000 -v 0.153763 0.549783 0.000000 -v 0.124397 0.549782 0.090379 -v 0.023346 0.493612 0.071853 -v 0.047515 0.549782 0.146237 -v -0.023346 0.493612 0.071853 -v -0.047515 0.549782 0.146237 -v -0.061122 0.493612 0.044408 -v -0.124396 0.549782 0.090380 -v -0.075551 0.493612 0.000000 -v -0.153763 0.549783 0.000000 -v -0.061122 0.493612 -0.044407 -v -0.124397 0.549783 -0.090379 -v -0.023346 0.493612 -0.071853 -v -0.047515 0.549783 -0.146237 -v 0.023346 0.493612 -0.071853 -v 0.047515 0.549783 -0.146237 -v 0.061122 0.493612 -0.044407 -v 0.124396 0.549783 -0.090379 -v 0.039643 0.457110 0.028802 -v 0.049002 0.457110 0.000000 -v 0.015142 0.457110 0.046603 -v -0.015142 0.457110 0.046603 -v -0.039643 0.457110 0.028802 -v -0.049002 0.457110 0.000000 -v -0.039643 0.457110 -0.028802 -v -0.015142 0.457110 -0.046603 -v 0.015142 0.457110 -0.046603 -v 0.039643 0.457110 -0.028802 -v 0.065534 -0.100432 0.047613 -v 0.081005 -0.100432 0.000000 -v 0.081005 -0.082613 0.000000 -v 0.065534 -0.082613 0.047613 -v 0.025032 -0.100432 0.077040 -v 0.065534 -0.100432 0.047613 -v 0.065534 -0.082613 0.047613 -v 0.025032 -0.082613 0.077040 -v -0.025032 -0.100432 0.077040 -v 0.025032 -0.100432 0.077040 -v 0.025032 -0.082613 0.077040 -v -0.025032 -0.082613 0.077040 -v -0.065534 -0.100432 0.047613 -v -0.025032 -0.100432 0.077040 -v -0.025032 -0.082613 0.077040 -v -0.065534 -0.082613 0.047613 -v -0.081005 -0.100432 0.000000 -v -0.065534 -0.100432 0.047613 -v -0.065534 -0.082613 0.047613 -v -0.081005 -0.082613 0.000000 -v -0.065534 -0.100432 -0.047613 -v -0.081005 -0.100432 0.000000 -v -0.081005 -0.082613 0.000000 -v -0.065534 -0.082613 -0.047613 -v -0.025032 -0.100432 -0.077040 -v -0.065534 -0.100432 -0.047613 -v -0.065534 -0.082613 -0.047613 -v -0.025032 -0.082613 -0.077040 -v 0.025032 -0.100432 -0.077040 -v -0.025032 -0.100432 -0.077040 -v -0.025032 -0.082613 -0.077040 -v 0.025032 -0.082613 -0.077040 -v 0.065534 -0.100432 -0.047613 -v 0.025032 -0.100432 -0.077040 -v 0.025032 -0.082613 -0.077040 -v 0.065534 -0.082613 -0.047613 -v 0.081005 -0.100432 0.000000 -v 0.065534 -0.100432 -0.047613 -v 0.065534 -0.082613 -0.047613 -v 0.081005 -0.082613 0.000000 -v 0.065534 -0.082613 0.047613 -v 0.081005 -0.082613 0.000000 -v 0.062269 -0.081722 0.000000 -v 0.050377 -0.081722 0.036601 -v 0.025032 -0.082613 0.077040 -v 0.065534 -0.082613 0.047613 -v 0.050377 -0.081722 0.036601 -v 0.019242 -0.081722 0.059221 -v -0.025032 -0.082613 0.077040 -v 0.025032 -0.082613 0.077040 -v 0.019242 -0.081722 0.059221 -v -0.019242 -0.081722 0.059221 -v -0.065534 -0.082613 0.047613 -v -0.025032 -0.082613 0.077040 -v -0.019242 -0.081722 0.059221 -v -0.050377 -0.081722 0.036601 -v -0.081005 -0.082613 0.000000 -v -0.065534 -0.082613 0.047613 -v -0.050377 -0.081722 0.036601 -v -0.062269 -0.081722 0.000000 -v -0.065534 -0.082613 -0.047613 -v -0.081005 -0.082613 0.000000 -v -0.062269 -0.081722 0.000000 -v -0.050377 -0.081722 -0.036601 -v -0.025032 -0.082613 -0.077040 -v -0.065534 -0.082613 -0.047613 -v -0.050377 -0.081722 -0.036601 -v -0.019242 -0.081722 -0.059221 -v 0.025032 -0.082613 -0.077040 -v -0.025032 -0.082613 -0.077040 -v -0.019242 -0.081722 -0.059221 -v 0.019242 -0.081722 -0.059221 -v 0.065534 -0.082613 -0.047613 -v 0.025032 -0.082613 -0.077040 -v 0.019242 -0.081722 -0.059221 -v 0.050377 -0.081722 -0.036601 -v 0.081005 -0.082613 0.000000 -v 0.065534 -0.082613 -0.047613 -v 0.050377 -0.081722 -0.036601 -v 0.062269 -0.081722 0.000000 -v 0.050377 -0.081722 0.036601 -v 0.062269 -0.081722 0.000000 -v 0.062269 -0.063904 0.000000 -v 0.050377 -0.063904 0.036601 -v 0.019242 -0.081722 0.059221 -v 0.050377 -0.081722 0.036601 -v 0.050377 -0.063904 0.036601 -v 0.019242 -0.063904 0.059221 -v -0.019242 -0.081722 0.059221 -v 0.019242 -0.081722 0.059221 -v 0.019242 -0.063904 0.059221 -v -0.019242 -0.063904 0.059221 -v -0.050377 -0.081722 0.036601 -v -0.019242 -0.081722 0.059221 -v -0.019242 -0.063904 0.059221 -v -0.050377 -0.063904 0.036601 -v -0.062269 -0.081722 0.000000 -v -0.050377 -0.081722 0.036601 -v -0.050377 -0.063904 0.036601 -v -0.062269 -0.063904 0.000000 -v -0.050377 -0.081722 -0.036601 -v -0.062269 -0.081722 0.000000 -v -0.062269 -0.063904 0.000000 -v -0.050377 -0.063904 -0.036601 -v -0.019242 -0.081722 -0.059221 -v -0.050377 -0.081722 -0.036601 -v -0.050377 -0.063904 -0.036601 -v -0.019242 -0.063904 -0.059221 -v 0.019242 -0.081722 -0.059221 -v -0.019242 -0.081722 -0.059221 -v -0.019242 -0.063904 -0.059221 -v 0.019242 -0.063904 -0.059221 -v 0.050377 -0.081722 -0.036601 -v 0.019242 -0.081722 -0.059221 -v 0.019242 -0.063904 -0.059221 -v 0.050377 -0.063904 -0.036601 -v 0.062269 -0.081722 0.000000 -v 0.050377 -0.081722 -0.036601 -v 0.050377 -0.063904 -0.036601 -v 0.062269 -0.063904 0.000000 -v 0.050377 -0.063904 0.036601 -v 0.062269 -0.063904 0.000000 -v 0.071637 -0.059449 0.000000 -v 0.057955 -0.059449 0.042107 -v 0.019242 -0.063904 0.059221 -v 0.050377 -0.063904 0.036601 -v 0.057955 -0.059449 0.042107 -v 0.022137 -0.059449 0.068131 -v -0.019242 -0.063904 0.059221 -v 0.019242 -0.063904 0.059221 -v 0.022137 -0.059449 0.068131 -v -0.022137 -0.059449 0.068131 -v -0.050377 -0.063904 0.036601 -v -0.019242 -0.063904 0.059221 -v -0.022137 -0.059449 0.068131 -v -0.057955 -0.059449 0.042107 -v -0.062269 -0.063904 0.000000 -v -0.050377 -0.063904 0.036601 -v -0.057955 -0.059449 0.042107 -v -0.071637 -0.059449 0.000000 -v -0.050377 -0.063904 -0.036601 -v -0.062269 -0.063904 0.000000 -v -0.071637 -0.059449 0.000000 -v -0.057955 -0.059449 -0.042107 -v -0.019242 -0.063904 -0.059221 -v -0.050377 -0.063904 -0.036601 -v -0.057955 -0.059449 -0.042107 -v -0.022137 -0.059449 -0.068131 -v 0.019242 -0.063904 -0.059221 -v -0.019242 -0.063904 -0.059221 -v -0.022137 -0.059449 -0.068131 -v 0.022137 -0.059449 -0.068131 -v 0.050377 -0.063904 -0.036601 -v 0.019242 -0.063904 -0.059221 -v 0.022137 -0.059449 -0.068131 -v 0.057955 -0.059449 -0.042107 -v 0.062269 -0.063904 0.000000 -v 0.050377 -0.063904 -0.036601 -v 0.057955 -0.059449 -0.042107 -v 0.071637 -0.059449 0.000000 -v 0.057955 -0.059449 0.042107 -v 0.071637 -0.059449 0.000000 -v 0.071637 -0.050540 0.000000 -v 0.057955 -0.050540 0.042107 -v 0.022137 -0.059449 0.068131 -v 0.057955 -0.059449 0.042107 -v 0.057955 -0.050540 0.042107 -v 0.022137 -0.050540 0.068131 -v -0.022137 -0.059449 0.068131 -v 0.022137 -0.059449 0.068131 -v 0.022137 -0.050540 0.068131 -v -0.022137 -0.050540 0.068131 -v -0.057955 -0.059449 0.042107 -v -0.022137 -0.059449 0.068131 -v -0.022137 -0.050540 0.068131 -v -0.057955 -0.050540 0.042107 -v -0.071637 -0.059449 0.000000 -v -0.057955 -0.059449 0.042107 -v -0.057955 -0.050540 0.042107 -v -0.071637 -0.050540 0.000000 -v -0.057955 -0.059449 -0.042107 -v -0.071637 -0.059449 0.000000 -v -0.071637 -0.050540 0.000000 -v -0.057955 -0.050540 -0.042107 -v -0.022137 -0.059449 -0.068131 -v -0.057955 -0.059449 -0.042107 -v -0.057955 -0.050540 -0.042107 -v -0.022137 -0.050540 -0.068131 -v 0.022137 -0.059449 -0.068131 -v -0.022137 -0.059449 -0.068131 -v -0.022137 -0.050540 -0.068131 -v 0.022137 -0.050540 -0.068131 -v 0.057955 -0.059449 -0.042107 -v 0.022137 -0.059449 -0.068131 -v 0.022137 -0.050540 -0.068131 -v 0.057955 -0.050540 -0.042107 -v 0.071637 -0.059449 0.000000 -v 0.057955 -0.059449 -0.042107 -v 0.057955 -0.050540 -0.042107 -v 0.071637 -0.050540 0.000000 -v 0.057955 -0.050540 0.042107 -v 0.071637 -0.050540 0.000000 -v 0.062269 -0.046085 0.000000 -v 0.050377 -0.046085 0.036601 -v 0.022137 -0.050540 0.068131 -v 0.057955 -0.050540 0.042107 -v 0.050377 -0.046085 0.036601 -v 0.019242 -0.046085 0.059221 -v -0.022137 -0.050540 0.068131 -v 0.022137 -0.050540 0.068131 -v 0.019242 -0.046085 0.059221 -v -0.019242 -0.046085 0.059221 -v -0.057955 -0.050540 0.042107 -v -0.022137 -0.050540 0.068131 -v -0.019242 -0.046085 0.059221 -v -0.050377 -0.046085 0.036601 -v -0.071637 -0.050540 0.000000 -v -0.057955 -0.050540 0.042107 -v -0.050377 -0.046085 0.036601 -v -0.062269 -0.046085 0.000000 -v -0.057955 -0.050540 -0.042107 -v -0.071637 -0.050540 0.000000 -v -0.062269 -0.046085 0.000000 -v -0.050377 -0.046085 -0.036601 -v -0.022137 -0.050540 -0.068131 -v -0.057955 -0.050540 -0.042107 -v -0.050377 -0.046085 -0.036601 -v -0.019242 -0.046085 -0.059221 -v 0.022137 -0.050540 -0.068131 -v -0.022137 -0.050540 -0.068131 -v -0.019242 -0.046085 -0.059221 -v 0.019242 -0.046085 -0.059221 -v 0.057955 -0.050540 -0.042107 -v 0.022137 -0.050540 -0.068131 -v 0.019242 -0.046085 -0.059221 -v 0.050377 -0.046085 -0.036601 -v 0.071637 -0.050540 0.000000 -v 0.057955 -0.050540 -0.042107 -v 0.050377 -0.046085 -0.036601 -v 0.062269 -0.046085 0.000000 -v 0.050377 -0.046085 0.036601 -v 0.062269 -0.046085 0.000000 -v 0.062269 -0.037015 0.000000 -v 0.050377 -0.037015 0.036601 -v 0.019242 -0.046085 0.059221 -v 0.050377 -0.046085 0.036601 -v 0.050377 -0.037015 0.036601 -v 0.019242 -0.037015 0.059221 -v -0.019242 -0.046085 0.059221 -v 0.019242 -0.046085 0.059221 -v 0.019242 -0.037015 0.059221 -v -0.019242 -0.037015 0.059221 -v -0.050377 -0.046085 0.036601 -v -0.019242 -0.046085 0.059221 -v -0.019242 -0.037015 0.059221 -v -0.050377 -0.037015 0.036601 -v -0.062269 -0.046085 0.000000 -v -0.050377 -0.046085 0.036601 -v -0.050377 -0.037015 0.036601 -v -0.062269 -0.037015 0.000000 -v -0.050377 -0.046085 -0.036601 -v -0.062269 -0.046085 0.000000 -v -0.062269 -0.037015 0.000000 -v -0.050377 -0.037015 -0.036601 -v -0.019242 -0.046085 -0.059221 -v -0.050377 -0.046085 -0.036601 -v -0.050377 -0.037015 -0.036601 -v -0.019242 -0.037015 -0.059221 -v 0.019242 -0.046085 -0.059221 -v -0.019242 -0.046085 -0.059221 -v -0.019242 -0.037015 -0.059221 -v 0.019242 -0.037015 -0.059221 -v 0.050377 -0.046085 -0.036601 -v 0.019242 -0.046085 -0.059221 -v 0.019242 -0.037015 -0.059221 -v 0.050377 -0.037015 -0.036601 -v 0.062269 -0.046085 0.000000 -v 0.050377 -0.046085 -0.036601 -v 0.050377 -0.037015 -0.036601 -v 0.062269 -0.037015 0.000000 -v 0.035221 0.414309 0.025590 -v 0.043536 0.414309 0.000000 -v 0.049002 0.457110 0.000000 -v 0.039643 0.457110 0.028802 -v 0.013453 0.414309 0.041405 -v 0.015142 0.457110 0.046603 -v -0.013453 0.414309 0.041405 -v -0.015142 0.457110 0.046603 -v -0.035221 0.414309 0.025590 -v -0.039643 0.457110 0.028802 -v -0.043536 0.414309 0.000000 -v -0.049002 0.457110 0.000000 -v -0.035221 0.414309 -0.025590 -v -0.039643 0.457110 -0.028802 -v -0.013453 0.414309 -0.041405 -v -0.015142 0.457110 -0.046603 -v 0.013453 0.414309 -0.041405 -v 0.015142 0.457110 -0.046603 -v 0.035221 0.414309 -0.025590 -v 0.013453 0.414309 -0.041405 -v 0.015142 0.457110 -0.046603 -v 0.039643 0.457110 -0.028802 -v 0.051175 0.223460 0.037181 -v 0.063256 0.223460 0.000000 -v 0.019547 0.223460 0.060160 -v -0.019547 0.223460 0.060160 -v -0.051175 0.223460 0.037181 -v -0.063256 0.223460 0.000000 -v -0.051175 0.223460 -0.037181 -v -0.019547 0.223460 -0.060160 -v 0.019547 0.223460 -0.060160 -v 0.051176 0.223460 -0.037181 -v 0.019547 0.223460 -0.060160 -v 0.076220 0.102045 0.055377 -v 0.094213 0.102045 0.000000 -v 0.029113 0.102045 0.089602 -v -0.029113 0.102045 0.089602 -v -0.076220 0.102045 0.055377 -v -0.094213 0.102045 0.000000 -v -0.076220 0.102045 -0.055377 -v -0.029113 0.102045 -0.089602 -v 0.029113 0.102045 -0.089602 -v 0.076220 0.102045 -0.055377 -v 0.029113 0.102045 -0.089602 -v 0.068919 -0.002139 0.050073 -v 0.085189 -0.002139 0.000000 -v 0.026325 -0.002139 0.081019 -v -0.026325 -0.002139 0.081019 -v -0.068919 -0.002139 0.050073 -v -0.085189 -0.002139 0.000000 -v -0.068919 -0.002139 -0.050073 -v -0.026325 -0.002139 -0.081019 -v 0.026325 -0.002139 -0.081019 -v 0.068919 -0.002139 -0.050073 -v 0.026325 -0.002139 -0.081019 -v 0.050377 -0.037015 0.036601 -v 0.062269 -0.037015 0.000000 -v 0.019242 -0.037015 0.059221 -v -0.019242 -0.037015 0.059221 -v -0.050377 -0.037015 0.036601 -v -0.062269 -0.037015 0.000000 -v -0.050377 -0.037015 -0.036601 -v -0.019242 -0.037015 -0.059221 -v 0.019242 -0.037015 -0.059221 -v 0.050377 -0.037015 -0.036601 -v 0.019242 -0.037015 -0.059221 -vt 0.017083 0.467481 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077277 0.475172 -vt 0.017498 0.425773 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.077301 0.425780 -vt 0.022716 0.366365 -vt 0.023914 0.320840 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077611 0.335458 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.141617 0.425888 -vt 0.141203 0.458853 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.077611 0.335458 -vt 0.077682 0.295421 -vt 0.140908 0.303558 -vt 0.140908 0.357917 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.140908 0.357917 -vt 0.140908 0.303558 -vt 0.141617 0.425888 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.223614 0.381380 -vt 0.233628 0.407934 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.187732 0.293268 -vt 0.203363 0.329596 -vt 0.203363 0.329596 -vt 0.187732 0.293268 -vt 0.223614 0.381380 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.308037 0.291333 -vt 0.324950 0.321248 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.264859 0.213261 -vt 0.279922 0.245271 -vt 0.279922 0.245271 -vt 0.264859 0.213261 -vt 0.308037 0.291333 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.377000 0.255623 -vt 0.378700 0.295995 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.367735 0.111762 -vt 0.372639 0.156040 -vt 0.372639 0.156040 -vt 0.367735 0.111762 -vt 0.377000 0.255623 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.393655 0.410963 -vt 0.467714 0.453591 -vt 0.467714 0.410963 -vt 0.348935 0.453591 -vt 0.321554 0.410963 -vt 0.348935 0.368334 -vt 0.467714 0.368334 -vt 0.486443 0.230599 -vt 0.486443 0.273314 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.486443 0.071872 -vt 0.486443 0.122067 -vt 0.486443 0.122067 -vt 0.486443 0.071872 -vt 0.486443 0.230599 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.017083 0.467481 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077277 0.475172 -vt 0.017498 0.425773 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.077301 0.425780 -vt 0.022716 0.366365 -vt 0.023914 0.320840 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077611 0.335458 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.141617 0.425888 -vt 0.141203 0.458853 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.077611 0.335458 -vt 0.077682 0.295421 -vt 0.140908 0.303558 -vt 0.140908 0.357917 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.140908 0.357917 -vt 0.140908 0.303558 -vt 0.141617 0.425888 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.223614 0.381380 -vt 0.233628 0.407934 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.187732 0.293268 -vt 0.203363 0.329596 -vt 0.203363 0.329596 -vt 0.187732 0.293268 -vt 0.223614 0.381380 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.308037 0.291333 -vt 0.324950 0.321248 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.264859 0.213261 -vt 0.279922 0.245271 -vt 0.279922 0.245271 -vt 0.264859 0.213261 -vt 0.308037 0.291333 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.377000 0.255623 -vt 0.378700 0.295995 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.367735 0.111762 -vt 0.372639 0.156040 -vt 0.372639 0.156040 -vt 0.367735 0.111762 -vt 0.377000 0.255623 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.393655 0.410963 -vt 0.467714 0.453591 -vt 0.467714 0.410963 -vt 0.348935 0.453591 -vt 0.321554 0.410963 -vt 0.348935 0.368334 -vt 0.467714 0.368334 -vt 0.486443 0.230599 -vt 0.486443 0.273314 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.486443 0.071872 -vt 0.486443 0.122067 -vt 0.486443 0.122067 -vt 0.486443 0.071872 -vt 0.486443 0.230599 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.017083 0.467481 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077277 0.475172 -vt 0.017498 0.425773 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.077301 0.425780 -vt 0.022716 0.366365 -vt 0.023914 0.320840 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077611 0.335458 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.141617 0.425888 -vt 0.141203 0.458853 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.077611 0.335458 -vt 0.077682 0.295421 -vt 0.140908 0.303558 -vt 0.140908 0.357917 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.140908 0.357917 -vt 0.140908 0.303558 -vt 0.141617 0.425888 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.223614 0.381380 -vt 0.233628 0.407934 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.187732 0.293268 -vt 0.203363 0.329596 -vt 0.203363 0.329596 -vt 0.187732 0.293268 -vt 0.223614 0.381380 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.308037 0.291333 -vt 0.324950 0.321248 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.264859 0.213261 -vt 0.279922 0.245271 -vt 0.279922 0.245271 -vt 0.264859 0.213261 -vt 0.308037 0.291333 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.377000 0.255623 -vt 0.378700 0.295995 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.367735 0.111762 -vt 0.372639 0.156040 -vt 0.372639 0.156040 -vt 0.367735 0.111762 -vt 0.377000 0.255623 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.393655 0.410963 -vt 0.467714 0.453591 -vt 0.467714 0.410963 -vt 0.348935 0.453591 -vt 0.321554 0.410963 -vt 0.348935 0.368334 -vt 0.467714 0.368334 -vt 0.486443 0.230599 -vt 0.486443 0.273314 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.486443 0.071872 -vt 0.486443 0.122067 -vt 0.486443 0.122067 -vt 0.486443 0.071872 -vt 0.486443 0.230599 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.017083 0.467481 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077277 0.475172 -vt 0.017498 0.425773 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.077301 0.425780 -vt 0.022716 0.366365 -vt 0.023914 0.320840 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.077611 0.335458 -vt 0.022716 0.366365 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.077611 0.335458 -vt 0.017498 0.425773 -vt 0.077301 0.425780 -vt 0.141617 0.425888 -vt 0.141203 0.458853 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.077611 0.335458 -vt 0.077682 0.295421 -vt 0.140908 0.303558 -vt 0.140908 0.357917 -vt 0.077682 0.295421 -vt 0.077611 0.335458 -vt 0.140908 0.357917 -vt 0.140908 0.303558 -vt 0.141617 0.425888 -vt 0.140908 0.357917 -vt 0.141617 0.425888 -vt 0.223614 0.381380 -vt 0.233628 0.407934 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.187732 0.293268 -vt 0.203363 0.329596 -vt 0.203363 0.329596 -vt 0.187732 0.293268 -vt 0.223614 0.381380 -vt 0.203363 0.329596 -vt 0.223614 0.381380 -vt 0.308037 0.291333 -vt 0.324950 0.321248 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.264859 0.213261 -vt 0.279922 0.245271 -vt 0.279922 0.245271 -vt 0.264859 0.213261 -vt 0.308037 0.291333 -vt 0.279922 0.245271 -vt 0.308037 0.291333 -vt 0.377000 0.255623 -vt 0.378700 0.295995 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.367735 0.111762 -vt 0.372639 0.156040 -vt 0.372639 0.156040 -vt 0.367735 0.111762 -vt 0.377000 0.255623 -vt 0.372639 0.156040 -vt 0.377000 0.255623 -vt 0.393655 0.410963 -vt 0.467714 0.453591 -vt 0.467714 0.410963 -vt 0.348935 0.453591 -vt 0.321554 0.410963 -vt 0.348935 0.368334 -vt 0.467714 0.368334 -vt 0.486443 0.230599 -vt 0.486443 0.273314 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.486443 0.071872 -vt 0.486443 0.122067 -vt 0.486443 0.122067 -vt 0.486443 0.071872 -vt 0.486443 0.230599 -vt 0.486443 0.122067 -vt 0.486443 0.230599 -vt 0.000000 1.000000 -vt 0.312949 0.385343 -vt 0.374010 0.385343 -vt 0.251887 0.385343 -vt 0.190825 0.385343 -vt 0.129763 0.385343 -vt 0.068702 0.385343 -vt 0.496134 0.385343 -vt 0.435072 0.385343 -vt 0.312949 0.498276 -vt 0.374010 0.498276 -vt 0.374010 0.385343 -vt 0.312949 0.385343 -vt 0.251887 0.498276 -vt 0.312949 0.498276 -vt 0.312949 0.385343 -vt 0.251887 0.385343 -vt 0.190825 0.498276 -vt 0.251887 0.498276 -vt 0.251887 0.385343 -vt 0.190825 0.385343 -vt 0.129763 0.498276 -vt 0.190825 0.498276 -vt 0.190825 0.385343 -vt 0.129763 0.385343 -vt 0.068702 0.498276 -vt 0.129763 0.498276 -vt 0.129763 0.385343 -vt 0.068702 0.385343 -vt 0.007640 0.498276 -vt 0.068702 0.498276 -vt 0.068702 0.385343 -vt 0.007640 0.385343 -vt 0.435072 0.498276 -vt 0.496134 0.498276 -vt 0.496134 0.385343 -vt 0.435072 0.385343 -vt 0.321935 0.273341 -vt 0.321962 0.201250 -vt 0.321962 0.201250 -vt 0.321935 0.273341 -vt 0.234927 0.237263 -vt 0.321935 0.273341 -vt 0.270940 0.324298 -vt 0.198849 0.324271 -vt 0.147891 0.273276 -vt 0.147918 0.201184 -vt 0.198914 0.150227 -vt 0.271005 0.150254 -vt 0.321962 0.201250 -vt 0.143227 0.361033 -vt 0.143227 0.144695 -vt 0.135916 0.138034 -vt 0.135916 0.368993 -vt 0.143227 0.144695 -vt 0.359565 0.144695 -vt 0.366875 0.138034 -vt 0.135916 0.138034 -vt 0.359565 0.144695 -vt 0.359565 0.361033 -vt 0.366875 0.368993 -vt 0.366875 0.138034 -vt 0.359565 0.361033 -vt 0.143227 0.361033 -vt 0.135916 0.368993 -vt 0.366875 0.368993 -vt 0.135916 0.368993 -vt 0.135916 0.138034 -vt 0.113352 0.114821 -vt 0.113352 0.390908 -vt 0.135916 0.138034 -vt 0.366875 0.138034 -vt 0.389439 0.114821 -vt 0.113352 0.114821 -vt 0.366875 0.138034 -vt 0.366875 0.368993 -vt 0.389439 0.390908 -vt 0.389439 0.114821 -vt 0.366875 0.368993 -vt 0.135916 0.368993 -vt 0.113352 0.390908 -vt 0.389439 0.390908 -vt 0.113352 0.390908 -vt 0.113352 0.114821 -vt 0.121903 0.123372 -vt 0.121903 0.382356 -vt 0.113352 0.114821 -vt 0.389439 0.114821 -vt 0.380888 0.123372 -vt 0.121903 0.123372 -vt 0.389439 0.114821 -vt 0.389439 0.390908 -vt 0.380888 0.382356 -vt 0.380888 0.123372 -vt 0.389439 0.390908 -vt 0.113352 0.390908 -vt 0.121903 0.382356 -vt 0.380888 0.382356 -vt 0.004820 0.499440 -vt 0.497971 0.499440 -vt 0.497971 0.499440 -vt 0.004820 0.499440 -vt 0.497971 0.499440 -vt 0.497971 0.006289 -vt 0.497971 0.006289 -vt 0.497971 0.499440 -vt 0.497971 0.006289 -vt 0.004820 0.006289 -vt 0.004820 0.006289 -vt 0.497971 0.006289 -vt 0.004820 0.006289 -vt 0.004820 0.499440 -vt 0.004820 0.499440 -vt 0.004820 0.006289 -vt 0.497971 0.499440 -vt 0.004820 0.499440 -vt 0.497971 0.006289 -vt 0.497971 0.499440 -vt 0.004820 0.006289 -vt 0.497971 0.006289 -vt 0.004820 0.499440 -vt 0.004820 0.006289 -vt 0.491654 0.493123 -vt 0.011137 0.493123 -vt 0.491654 0.012605 -vt 0.491654 0.493123 -vt 0.011137 0.012605 -vt 0.491654 0.012605 -vt 0.011137 0.493123 -vt 0.011137 0.012605 -vt 0.482370 0.483838 -vt 0.020421 0.483838 -vt 0.482370 0.021890 -vt 0.482370 0.483838 -vt 0.020421 0.021890 -vt 0.482370 0.021890 -vt 0.020421 0.483838 -vt 0.020421 0.021890 -vt 0.470567 0.472035 -vt 0.032224 0.472035 -vt 0.470567 0.033693 -vt 0.470567 0.472035 -vt 0.032224 0.033693 -vt 0.470567 0.033693 -vt 0.032224 0.472035 -vt 0.032224 0.033693 -vt 0.032224 0.472035 -vt 0.470567 0.472035 -vt 0.459013 0.460481 -vt 0.043778 0.460481 -vt 0.470567 0.472035 -vt 0.470567 0.033693 -vt 0.459013 0.045247 -vt 0.459013 0.460481 -vt 0.470567 0.033693 -vt 0.032224 0.033693 -vt 0.043778 0.045247 -vt 0.459013 0.045247 -vt 0.032224 0.033693 -vt 0.032224 0.472035 -vt 0.043778 0.460481 -vt 0.043778 0.045247 -vt 0.098754 0.100222 -vt 0.098754 0.405506 -vt 0.404037 0.100222 -vt 0.098754 0.100222 -vt 0.404037 0.405506 -vt 0.404037 0.100222 -vt 0.098754 0.405506 -vt 0.404037 0.405506 -vt 0.094840 0.096308 -vt 0.094840 0.409420 -vt 0.407951 0.096308 -vt 0.094840 0.096308 -vt 0.407951 0.409420 -vt 0.407951 0.096308 -vt 0.094840 0.409420 -vt 0.407951 0.409420 -vt 0.087012 0.088481 -vt 0.087012 0.417248 -vt 0.415779 0.088481 -vt 0.087012 0.088481 -vt 0.415779 0.417248 -vt 0.415779 0.088481 -vt 0.087012 0.417248 -vt 0.415779 0.417248 -vt 0.586243 0.413570 -vt 0.586243 0.086583 -vt 0.504496 0.004836 -vt 0.504496 0.495317 -vt 0.586243 0.086583 -vt 0.913231 0.086583 -vt 0.994978 0.004836 -vt 0.504496 0.004836 -vt 0.913231 0.086583 -vt 0.913231 0.413570 -vt 0.994978 0.495317 -vt 0.994978 0.004836 -vt 0.913231 0.413570 -vt 0.586243 0.413570 -vt 0.504496 0.495317 -vt 0.994978 0.495317 -vt 0.052083 0.452177 -vt 0.052083 0.053552 -vt 0.043778 0.045247 -vt 0.043778 0.460481 -vt 0.052083 0.053552 -vt 0.450708 0.053552 -vt 0.459013 0.045247 -vt 0.043778 0.045247 -vt 0.450708 0.053552 -vt 0.450708 0.452177 -vt 0.459013 0.460481 -vt 0.459013 0.045247 -vt 0.450708 0.452177 -vt 0.052083 0.452177 -vt 0.043778 0.460481 -vt 0.459013 0.460481 -vt 0.997798 0.502710 -vt 0.503545 0.502710 -vt 0.503545 0.996963 -vt 0.997798 0.996963 -vt 0.497971 0.006289 -vt 0.497971 0.499440 -vt 0.004820 0.499440 -vt 0.004820 0.006289 -vt 0.366183 0.254192 -vt 0.376207 0.221754 -vt 0.430543 0.221754 -vt 0.410142 0.287774 -vt 0.339940 0.274240 -vt 0.356731 0.328576 -vt 0.307501 0.274241 -vt 0.290711 0.328576 -vt 0.281258 0.254192 -vt 0.237300 0.287774 -vt 0.271234 0.221754 -vt 0.216899 0.221754 -vt 0.281258 0.189315 -vt 0.237300 0.155734 -vt 0.307501 0.169267 -vt 0.290711 0.114932 -vt 0.339940 0.169267 -vt 0.356731 0.114932 -vt 0.366183 0.189315 -vt 0.410142 0.155734 -vt 0.351262 0.242793 -vt 0.357763 0.221754 -vt 0.334240 0.255796 -vt 0.313201 0.255796 -vt 0.296180 0.242793 -vt 0.289678 0.221754 -vt 0.296180 0.200714 -vt 0.313201 0.187711 -vt 0.334240 0.187711 -vt 0.351262 0.200714 -vt 0.350121 0.494170 -vt 0.396949 0.494170 -vt 0.396949 0.469050 -vt 0.350121 0.469050 -vt 0.300793 0.494170 -vt 0.350121 0.494170 -vt 0.350121 0.469050 -vt 0.300793 0.469050 -vt 0.249801 0.494170 -vt 0.300793 0.494170 -vt 0.300793 0.469050 -vt 0.249801 0.469050 -vt 0.200473 0.494170 -vt 0.249801 0.494170 -vt 0.249801 0.469050 -vt 0.200473 0.469050 -vt 0.153645 0.494170 -vt 0.200473 0.494170 -vt 0.200473 0.469050 -vt 0.153645 0.469050 -vt 0.106818 0.494170 -vt 0.153645 0.494170 -vt 0.153645 0.469050 -vt 0.106818 0.469050 -vt 0.057489 0.494170 -vt 0.106818 0.494170 -vt 0.106818 0.469050 -vt 0.057489 0.469050 -vt 0.006498 0.494170 -vt 0.057489 0.494170 -vt 0.057489 0.469050 -vt 0.006498 0.469050 -vt 0.443776 0.494170 -vt 0.493105 0.494170 -vt 0.493105 0.469050 -vt 0.443776 0.469050 -vt 0.396949 0.494170 -vt 0.443776 0.494170 -vt 0.443776 0.469050 -vt 0.396949 0.469050 -vt 0.350121 0.469050 -vt 0.396949 0.469050 -vt 0.396949 0.467794 -vt 0.350121 0.467794 -vt 0.300793 0.469050 -vt 0.350121 0.469050 -vt 0.350121 0.467794 -vt 0.300793 0.467794 -vt 0.249801 0.469050 -vt 0.300793 0.469050 -vt 0.300793 0.467794 -vt 0.249801 0.467794 -vt 0.200473 0.469050 -vt 0.249801 0.469050 -vt 0.249801 0.467794 -vt 0.200473 0.467794 -vt 0.153645 0.469050 -vt 0.200473 0.469050 -vt 0.200473 0.467794 -vt 0.153645 0.467794 -vt 0.106818 0.469050 -vt 0.153645 0.469050 -vt 0.153645 0.467794 -vt 0.106818 0.467794 -vt 0.057489 0.469050 -vt 0.106818 0.469050 -vt 0.106818 0.467794 -vt 0.057489 0.467794 -vt 0.006498 0.469050 -vt 0.057489 0.469050 -vt 0.057489 0.467794 -vt 0.006498 0.467794 -vt 0.443776 0.469050 -vt 0.493105 0.469050 -vt 0.493105 0.467794 -vt 0.443776 0.467794 -vt 0.396949 0.469050 -vt 0.443776 0.469050 -vt 0.443776 0.467794 -vt 0.396949 0.467794 -vt 0.350121 0.467794 -vt 0.396949 0.467794 -vt 0.396949 0.442675 -vt 0.350121 0.442675 -vt 0.300793 0.467794 -vt 0.350121 0.467794 -vt 0.350121 0.442675 -vt 0.300793 0.442675 -vt 0.249801 0.467794 -vt 0.300793 0.467794 -vt 0.300793 0.442675 -vt 0.249801 0.442675 -vt 0.200473 0.467794 -vt 0.249801 0.467794 -vt 0.249801 0.442675 -vt 0.200473 0.442675 -vt 0.153645 0.467794 -vt 0.200473 0.467794 -vt 0.200473 0.442675 -vt 0.153645 0.442675 -vt 0.106818 0.467794 -vt 0.153645 0.467794 -vt 0.153645 0.442675 -vt 0.106818 0.442675 -vt 0.057489 0.467794 -vt 0.106818 0.467794 -vt 0.106818 0.442675 -vt 0.057489 0.442675 -vt 0.006498 0.467794 -vt 0.057489 0.467794 -vt 0.057489 0.442675 -vt 0.006498 0.442675 -vt 0.443776 0.467794 -vt 0.493105 0.467794 -vt 0.493105 0.442675 -vt 0.443776 0.442675 -vt 0.396949 0.467794 -vt 0.443776 0.467794 -vt 0.443776 0.442675 -vt 0.396949 0.442675 -vt 0.350121 0.442675 -vt 0.396949 0.442675 -vt 0.396949 0.436395 -vt 0.350121 0.436395 -vt 0.300793 0.442675 -vt 0.350121 0.442675 -vt 0.350121 0.436395 -vt 0.300793 0.436395 -vt 0.249801 0.442675 -vt 0.300793 0.442675 -vt 0.300793 0.436395 -vt 0.249801 0.436395 -vt 0.200473 0.442675 -vt 0.249801 0.442675 -vt 0.249801 0.436395 -vt 0.200473 0.436395 -vt 0.153645 0.442675 -vt 0.200473 0.442675 -vt 0.200473 0.436395 -vt 0.153645 0.436395 -vt 0.106818 0.442675 -vt 0.153645 0.442675 -vt 0.153645 0.436395 -vt 0.106818 0.436395 -vt 0.057489 0.442675 -vt 0.106818 0.442675 -vt 0.106818 0.436395 -vt 0.057489 0.436395 -vt 0.006498 0.442675 -vt 0.057489 0.442675 -vt 0.057489 0.436395 -vt 0.006498 0.436395 -vt 0.443776 0.442675 -vt 0.493105 0.442675 -vt 0.493105 0.436395 -vt 0.443776 0.436395 -vt 0.396949 0.442675 -vt 0.443776 0.442675 -vt 0.443776 0.436395 -vt 0.396949 0.436395 -vt 0.350121 0.436395 -vt 0.396949 0.436395 -vt 0.396949 0.423835 -vt 0.350121 0.423835 -vt 0.300793 0.436395 -vt 0.350121 0.436395 -vt 0.350121 0.423835 -vt 0.300793 0.423835 -vt 0.249801 0.436395 -vt 0.300793 0.436395 -vt 0.300793 0.423835 -vt 0.249801 0.423835 -vt 0.200473 0.436395 -vt 0.249801 0.436395 -vt 0.249801 0.423835 -vt 0.200473 0.423835 -vt 0.153645 0.436395 -vt 0.200473 0.436395 -vt 0.200473 0.423835 -vt 0.153645 0.423835 -vt 0.106818 0.436395 -vt 0.153645 0.436395 -vt 0.153645 0.423835 -vt 0.106818 0.423835 -vt 0.057489 0.436395 -vt 0.106818 0.436395 -vt 0.106818 0.423835 -vt 0.057489 0.423835 -vt 0.006498 0.436395 -vt 0.057489 0.436395 -vt 0.057489 0.423835 -vt 0.006498 0.423835 -vt 0.443776 0.436395 -vt 0.493105 0.436395 -vt 0.493105 0.423835 -vt 0.443776 0.423835 -vt 0.396949 0.436395 -vt 0.443776 0.436395 -vt 0.443776 0.423835 -vt 0.396949 0.423835 -vt 0.350121 0.423835 -vt 0.396949 0.423835 -vt 0.396949 0.417555 -vt 0.350121 0.417555 -vt 0.300793 0.423835 -vt 0.350121 0.423835 -vt 0.350121 0.417555 -vt 0.300793 0.417555 -vt 0.249801 0.423835 -vt 0.300793 0.423835 -vt 0.300793 0.417555 -vt 0.249801 0.417555 -vt 0.200473 0.423835 -vt 0.249801 0.423835 -vt 0.249801 0.417555 -vt 0.200473 0.417555 -vt 0.153645 0.423835 -vt 0.200473 0.423835 -vt 0.200473 0.417555 -vt 0.153645 0.417555 -vt 0.106818 0.423835 -vt 0.153645 0.423835 -vt 0.153645 0.417555 -vt 0.106818 0.417555 -vt 0.057489 0.423835 -vt 0.106818 0.423835 -vt 0.106818 0.417555 -vt 0.057489 0.417555 -vt 0.006498 0.423835 -vt 0.057489 0.423835 -vt 0.057489 0.417555 -vt 0.006498 0.417555 -vt 0.443776 0.423835 -vt 0.493105 0.423835 -vt 0.493105 0.417555 -vt 0.443776 0.417555 -vt 0.396949 0.423835 -vt 0.443776 0.423835 -vt 0.443776 0.417555 -vt 0.396949 0.417555 -vt 0.350121 0.417555 -vt 0.396949 0.417555 -vt 0.396949 0.404768 -vt 0.350121 0.404768 -vt 0.300793 0.417555 -vt 0.350121 0.417555 -vt 0.350121 0.404768 -vt 0.300793 0.404768 -vt 0.249801 0.417555 -vt 0.300793 0.417555 -vt 0.300793 0.404768 -vt 0.249801 0.404768 -vt 0.200473 0.417555 -vt 0.249801 0.417555 -vt 0.249801 0.404768 -vt 0.200473 0.404768 -vt 0.153645 0.417555 -vt 0.200473 0.417555 -vt 0.200473 0.404768 -vt 0.153645 0.404768 -vt 0.106818 0.417555 -vt 0.153645 0.417555 -vt 0.153645 0.404768 -vt 0.106818 0.404768 -vt 0.057489 0.417555 -vt 0.106818 0.417555 -vt 0.106818 0.404768 -vt 0.057489 0.404768 -vt 0.006498 0.417555 -vt 0.057489 0.417555 -vt 0.057489 0.404768 -vt 0.006498 0.404768 -vt 0.443776 0.417555 -vt 0.493105 0.417555 -vt 0.493105 0.404768 -vt 0.443776 0.404768 -vt 0.396949 0.417555 -vt 0.443776 0.417555 -vt 0.443776 0.404768 -vt 0.396949 0.404768 -vt 0.350998 0.547962 -vt 0.398319 0.547961 -vt 0.398319 0.498824 -vt 0.350998 0.498825 -vt 0.301150 0.547961 -vt 0.301150 0.498825 -vt 0.249620 0.547961 -vt 0.249620 0.498825 -vt 0.199772 0.547962 -vt 0.199772 0.498825 -vt 0.152451 0.547962 -vt 0.152451 0.498824 -vt 0.105130 0.547961 -vt 0.105130 0.498824 -vt 0.055282 0.547962 -vt 0.055282 0.498824 -vt 0.003753 0.547962 -vt 0.003753 0.498824 -vt 0.445640 0.547961 -vt 0.495488 0.547962 -vt 0.495488 0.498824 -vt 0.445640 0.498824 -vt 0.350998 0.737698 -vt 0.398319 0.737698 -vt 0.301150 0.737698 -vt 0.249620 0.737698 -vt 0.199772 0.737698 -vt 0.152451 0.737698 -vt 0.105130 0.737698 -vt 0.055282 0.737698 -vt 0.003753 0.737698 -vt 0.445640 0.737698 -vt 0.495488 0.737698 -vt 0.350998 0.858405 -vt 0.398319 0.858405 -vt 0.301150 0.858405 -vt 0.249620 0.858405 -vt 0.199772 0.858405 -vt 0.152451 0.858405 -vt 0.105130 0.858405 -vt 0.055282 0.858405 -vt 0.003753 0.858405 -vt 0.445640 0.858405 -vt 0.495488 0.858405 -vt 0.350998 0.961982 -vt 0.398319 0.961982 -vt 0.301150 0.961982 -vt 0.249620 0.961982 -vt 0.199772 0.961982 -vt 0.152451 0.961982 -vt 0.105130 0.961982 -vt 0.055282 0.961982 -vt 0.003753 0.961982 -vt 0.445640 0.961982 -vt 0.495488 0.961982 -vt 0.350998 0.996654 -vt 0.398319 0.996654 -vt 0.301150 0.996654 -vt 0.249620 0.996654 -vt 0.199772 0.996654 -vt 0.152451 0.996654 -vt 0.105130 0.996654 -vt 0.055282 0.996654 -vt 0.003753 0.996654 -vt 0.445640 0.996654 -vt 0.495488 0.996654 -vn 0.000001 -0.000117 -1.000000 -vn 0.000007 -0.000119 -1.000000 -vn 0.000004 -0.000642 -1.000000 -vn 0.000290 -0.001097 -0.999999 -vn 0.965539 -0.259953 0.012557 -vn 0.960748 -0.276359 0.024272 -vn 0.995038 -0.099144 0.008333 -vn 0.997311 0.073275 0.000826 -vn 0.384905 -0.746403 0.542891 -vn -0.062420 -0.728758 0.681921 -vn 0.161475 -0.510903 0.844336 -vn 0.298440 -0.528902 0.794478 -vn -0.388088 -0.822360 0.416066 -vn -0.374937 -0.503238 0.778571 -vn -0.967185 -0.253827 0.011142 -vn -0.969696 -0.243379 0.021376 -vn -0.995359 -0.095953 0.007360 -vn -0.997773 0.066697 0.000871 -vn -0.000005 -0.000117 -1.000000 -vn -0.000578 -0.001225 -0.999999 -vn -0.002059 0.162154 -0.986763 -vn 0.036715 0.227361 -0.973118 -vn 0.988150 0.153490 0.000530 -vn 0.997092 0.076202 0.000795 -vn 0.419290 0.355620 0.835302 -vn 0.335340 0.314686 0.887986 -vn 0.476829 0.120448 0.870704 -vn 0.548589 -0.115983 0.828008 -vn -0.425538 0.336785 0.839936 -vn -0.326355 0.383871 0.863791 -vn -0.479491 0.111072 0.870489 -vn -0.546378 -0.151051 0.823805 -vn -0.988094 0.153853 0.000548 -vn -0.996980 0.077652 0.000810 -vn -0.071204 0.307808 -0.948780 -vn 0.134041 0.542848 -0.829065 -vn 0.038742 0.586621 -0.808935 -vn 0.999191 -0.037450 -0.014645 -vn 0.997224 -0.066926 -0.032638 -vn 0.508477 -0.486691 0.710340 -vn 0.518399 -0.586423 0.622391 -vn -0.510691 -0.477362 0.715067 -vn -0.519541 -0.586094 0.621748 -vn -0.999321 -0.034320 -0.013421 -vn -0.997248 -0.066385 -0.032993 -vn -0.208233 0.626135 -0.751394 -vn 0.208454 0.614903 -0.760553 -vn 0.003597 0.581754 -0.813357 -vn 0.994885 -0.089661 -0.046525 -vn 0.994269 -0.101688 -0.032983 -vn 0.510524 -0.657019 0.554699 -vn 0.512927 -0.632907 0.579944 -vn -0.512007 -0.660652 0.548989 -vn -0.514396 -0.638014 0.573004 -vn -0.992961 -0.104288 -0.056137 -vn -0.993472 -0.105450 -0.043510 -vn -0.215729 0.522222 -0.825073 -vn 0.214294 0.359182 -0.908332 -vn 0.000134 0.334072 -0.942548 -vn 0.997269 -0.072312 -0.015018 -vn 0.998775 -0.049471 -0.001064 -vn 0.525393 -0.499573 0.688759 -vn 0.520961 -0.381681 0.763491 -vn -0.527026 -0.502395 0.685451 -vn -0.522284 -0.373646 0.766556 -vn -0.997005 -0.073521 -0.023992 -vn -0.999371 -0.035442 -0.000762 -vn -0.214604 0.292047 -0.932016 -vn -0.000002 -0.996240 0.086630 -vn 0.254654 -0.964745 -0.066466 -vn -0.000002 -0.978728 -0.205161 -vn 0.384905 -0.746403 0.542891 -vn -0.062420 -0.728758 0.681921 -vn -0.388088 -0.822360 0.416066 -vn -0.254657 -0.964744 -0.066466 -vn 0.215116 0.223526 -0.950664 -vn -0.074129 0.228601 -0.970694 -vn 1.000000 0.000000 -0.000000 -vn 1.000000 0.000000 -0.000000 -vn 0.532664 -0.238851 0.811923 -vn 0.525606 -0.243348 0.815181 -vn -0.532938 -0.238769 0.811767 -vn -0.526504 -0.236645 0.816574 -vn -1.000000 -0.000000 0.000000 -vn -1.000000 -0.000000 0.000000 -vn -0.212589 0.222631 -0.951442 -vn 0.000117 0.000000 -1.000000 -vn 0.000118 0.000007 -1.000000 -vn 0.000642 0.000004 -1.000000 -vn 0.001097 0.000289 -0.999999 -vn 0.259953 0.965539 0.012557 -vn 0.276358 0.960748 0.024272 -vn 0.099144 0.995038 0.008333 -vn -0.073275 0.997311 0.000826 -vn 0.746403 0.384905 0.542891 -vn 0.728758 -0.062420 0.681921 -vn 0.510903 0.161476 0.844336 -vn 0.528902 0.298440 0.794478 -vn 0.822360 -0.388088 0.416066 -vn 0.503238 -0.374936 0.778572 -vn 0.253827 -0.967185 0.011142 -vn 0.243379 -0.969696 0.021376 -vn 0.095953 -0.995359 0.007360 -vn -0.066697 -0.997773 0.000871 -vn 0.000117 -0.000006 -1.000000 -vn 0.001225 -0.000578 -0.999999 -vn -0.162154 -0.002061 -0.986763 -vn -0.227361 0.036714 -0.973118 -vn -0.153490 0.988150 0.000530 -vn -0.076202 0.997092 0.000795 -vn -0.355620 0.419290 0.835302 -vn -0.314686 0.335340 0.887986 -vn -0.120448 0.476829 0.870704 -vn 0.115983 0.548589 0.828008 -vn -0.336785 -0.425537 0.839937 -vn -0.383871 -0.326354 0.863792 -vn -0.111072 -0.479490 0.870490 -vn 0.151051 -0.546377 0.823805 -vn -0.153853 -0.988094 0.000549 -vn -0.077652 -0.996980 0.000810 -vn -0.307808 -0.071204 -0.948780 -vn -0.542849 0.134040 -0.829065 -vn -0.586621 0.038742 -0.808935 -vn 0.037450 0.999191 -0.014646 -vn 0.066926 0.997224 -0.032638 -vn 0.486691 0.508477 0.710340 -vn 0.586423 0.518399 0.622390 -vn 0.477362 -0.510691 0.715067 -vn 0.586095 -0.519541 0.621748 -vn 0.034320 -0.999321 -0.013421 -vn 0.066385 -0.997248 -0.032993 -vn -0.626135 -0.208233 -0.751394 -vn -0.614903 0.208454 -0.760553 -vn -0.581754 0.003596 -0.813357 -vn 0.089661 0.994885 -0.046525 -vn 0.101687 0.994269 -0.032983 -vn 0.657019 0.510524 0.554699 -vn 0.632907 0.512927 0.579944 -vn 0.660652 -0.512006 0.548989 -vn 0.638015 -0.514396 0.573004 -vn 0.104288 -0.992961 -0.056137 -vn 0.105450 -0.993472 -0.043510 -vn -0.522222 -0.215730 -0.825073 -vn -0.359182 0.214294 -0.908332 -vn -0.334072 0.000134 -0.942547 -vn 0.072312 0.997269 -0.015018 -vn 0.049471 0.998775 -0.001064 -vn 0.499573 0.525393 0.688759 -vn 0.381681 0.520961 0.763491 -vn 0.502395 -0.527026 0.685451 -vn 0.373646 -0.522284 0.766556 -vn 0.073521 -0.997005 -0.023992 -vn 0.035442 -0.999371 -0.000762 -vn -0.292047 -0.214604 -0.932016 -vn 0.996240 -0.000002 0.086630 -vn 0.964745 0.254654 -0.066466 -vn 0.978728 -0.000002 -0.205161 -vn 0.746403 0.384905 0.542891 -vn 0.728758 -0.062420 0.681921 -vn 0.822360 -0.388088 0.416066 -vn 0.964744 -0.254658 -0.066466 -vn -0.223526 0.215116 -0.950664 -vn -0.228601 -0.074129 -0.970694 -vn -0.000000 1.000000 -0.000000 -vn -0.000000 1.000000 -0.000000 -vn 0.238851 0.532664 0.811923 -vn 0.243348 0.525606 0.815181 -vn 0.238770 -0.532938 0.811767 -vn 0.236645 -0.526504 0.816574 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn -0.222631 -0.212589 -0.951442 -vn -0.000001 0.000116 -1.000000 -vn -0.000009 0.000119 -1.000000 -vn -0.000005 0.000642 -1.000000 -vn -0.000289 0.001096 -0.999999 -vn -0.965539 0.259953 0.012557 -vn -0.960748 0.276358 0.024272 -vn -0.995038 0.099144 0.008333 -vn -0.997311 -0.073275 0.000826 -vn -0.384905 0.746403 0.542891 -vn 0.062420 0.728758 0.681921 -vn -0.161475 0.510903 0.844336 -vn -0.298440 0.528902 0.794478 -vn 0.388088 0.822361 0.416066 -vn 0.374936 0.503239 0.778571 -vn 0.967185 0.253827 0.011142 -vn 0.969696 0.243379 0.021376 -vn 0.995359 0.095953 0.007360 -vn 0.997773 -0.066696 0.000871 -vn 0.000006 0.000116 -1.000000 -vn 0.000578 0.001225 -0.999999 -vn 0.002061 -0.162154 -0.986763 -vn -0.036715 -0.227361 -0.973118 -vn -0.988150 -0.153490 0.000530 -vn -0.997092 -0.076202 0.000795 -vn -0.419290 -0.355620 0.835302 -vn -0.335340 -0.314686 0.887986 -vn -0.476829 -0.120448 0.870704 -vn -0.548589 0.115983 0.828008 -vn 0.425538 -0.336785 0.839937 -vn 0.326355 -0.383871 0.863791 -vn 0.479490 -0.111072 0.870490 -vn 0.546377 0.151051 0.823806 -vn 0.988094 -0.153853 0.000549 -vn 0.996980 -0.077652 0.000810 -vn 0.071202 -0.307807 -0.948781 -vn -0.134041 -0.542849 -0.829065 -vn -0.038743 -0.586621 -0.808935 -vn -0.999191 0.037450 -0.014645 -vn -0.997224 0.066925 -0.032638 -vn -0.508477 0.486691 0.710340 -vn -0.518400 0.586423 0.622390 -vn 0.510690 0.477362 0.715067 -vn 0.519540 0.586095 0.621748 -vn 0.999321 0.034320 -0.013421 -vn 0.997248 0.066385 -0.032993 -vn 0.208233 -0.626135 -0.751394 -vn -0.208455 -0.614903 -0.760553 -vn -0.003597 -0.581754 -0.813357 -vn -0.994885 0.089660 -0.046525 -vn -0.994269 0.101687 -0.032983 -vn -0.510524 0.657019 0.554699 -vn -0.512927 0.632907 0.579944 -vn 0.512006 0.660652 0.548989 -vn 0.514396 0.638015 0.573004 -vn 0.992961 0.104288 -0.056137 -vn 0.993472 0.105451 -0.043510 -vn 0.215730 -0.522222 -0.825072 -vn -0.214294 -0.359182 -0.908332 -vn -0.000134 -0.334072 -0.942547 -vn -0.997269 0.072312 -0.015018 -vn -0.998775 0.049471 -0.001064 -vn -0.525393 0.499573 0.688759 -vn -0.520961 0.381681 0.763491 -vn 0.527026 0.502395 0.685451 -vn 0.522284 0.373646 0.766556 -vn 0.997005 0.073521 -0.023992 -vn 0.999371 0.035442 -0.000762 -vn 0.214604 -0.292047 -0.932016 -vn 0.000002 0.996240 0.086630 -vn -0.254654 0.964745 -0.066466 -vn 0.000002 0.978728 -0.205161 -vn -0.384905 0.746403 0.542891 -vn 0.062420 0.728758 0.681921 -vn 0.388088 0.822361 0.416066 -vn 0.254658 0.964744 -0.066466 -vn -0.215116 -0.223526 -0.950664 -vn 0.074129 -0.228601 -0.970694 -vn -1.000000 -0.000000 -0.000000 -vn -1.000000 -0.000000 -0.000000 -vn -0.532664 0.238851 0.811923 -vn -0.525606 0.243348 0.815181 -vn 0.532938 0.238770 0.811767 -vn 0.526504 0.236645 0.816574 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 0.212589 -0.222631 -0.951442 -vn -0.000117 -0.000002 -1.000000 -vn -0.000120 -0.000009 -1.000000 -vn -0.000642 -0.000005 -1.000000 -vn -0.001096 -0.000290 -0.999999 -vn -0.259953 -0.965540 0.012557 -vn -0.276358 -0.960748 0.024272 -vn -0.099144 -0.995038 0.008333 -vn 0.073275 -0.997311 0.000826 -vn -0.746403 -0.384905 0.542891 -vn -0.728758 0.062420 0.681921 -vn -0.510903 -0.161475 0.844336 -vn -0.528903 -0.298440 0.794478 -vn -0.822360 0.388088 0.416066 -vn -0.503238 0.374937 0.778571 -vn -0.253827 0.967185 0.011142 -vn -0.243379 0.969696 0.021376 -vn -0.095953 0.995359 0.007360 -vn 0.066697 0.997773 0.000871 -vn -0.000116 0.000005 -1.000000 -vn -0.001225 0.000578 -0.999999 -vn 0.162155 0.002059 -0.986763 -vn 0.227361 -0.036715 -0.973118 -vn 0.153490 -0.988150 0.000530 -vn 0.076203 -0.997092 0.000795 -vn 0.355621 -0.419290 0.835302 -vn 0.314686 -0.335340 0.887986 -vn 0.120448 -0.476829 0.870704 -vn -0.115983 -0.548589 0.828008 -vn 0.336785 0.425538 0.839937 -vn 0.383871 0.326355 0.863791 -vn 0.111072 0.479490 0.870490 -vn -0.151051 0.546377 0.823805 -vn 0.153853 0.988094 0.000548 -vn 0.077652 0.996980 0.000810 -vn 0.307808 0.071202 -0.948781 -vn 0.542849 -0.134041 -0.829065 -vn 0.586621 -0.038743 -0.808934 -vn -0.037450 -0.999191 -0.014645 -vn -0.066925 -0.997224 -0.032638 -vn -0.486691 -0.508477 0.710340 -vn -0.586423 -0.518400 0.622390 -vn -0.477362 0.510691 0.715067 -vn -0.586095 0.519541 0.621748 -vn -0.034320 0.999321 -0.013421 -vn -0.066385 0.997248 -0.032993 -vn 0.626135 0.208232 -0.751395 -vn 0.614903 -0.208454 -0.760553 -vn 0.581754 -0.003597 -0.813357 -vn -0.089660 -0.994885 -0.046525 -vn -0.101687 -0.994269 -0.032983 -vn -0.657019 -0.510525 0.554699 -vn -0.632907 -0.512927 0.579944 -vn -0.660652 0.512007 0.548988 -vn -0.638015 0.514396 0.573004 -vn -0.104288 0.992961 -0.056137 -vn -0.105451 0.993472 -0.043510 -vn 0.522222 0.215729 -0.825072 -vn 0.359182 -0.214295 -0.908331 -vn 0.334072 -0.000134 -0.942547 -vn -0.072312 -0.997269 -0.015018 -vn -0.049471 -0.998775 -0.001064 -vn -0.499573 -0.525393 0.688759 -vn -0.381681 -0.520961 0.763491 -vn -0.502395 0.527026 0.685451 -vn -0.373646 0.522284 0.766556 -vn -0.073521 0.997005 -0.023992 -vn -0.035442 0.999371 -0.000763 -vn 0.292047 0.214604 -0.932016 -vn -0.996240 0.000002 0.086630 -vn -0.964745 -0.254654 -0.066466 -vn -0.978728 0.000002 -0.205161 -vn -0.746403 -0.384905 0.542891 -vn -0.728758 0.062420 0.681921 -vn -0.822360 0.388088 0.416066 -vn -0.964744 0.254657 -0.066466 -vn 0.223526 -0.215116 -0.950664 -vn 0.228601 0.074129 -0.970694 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 -0.000000 -vn -0.238851 -0.532664 0.811923 -vn -0.243348 -0.525606 0.815181 -vn -0.238770 0.532938 0.811767 -vn -0.236645 0.526504 0.816574 -vn -0.000000 1.000000 0.000000 -vn -0.000000 1.000000 0.000000 -vn 0.222631 0.212589 -0.951442 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.706842 0.707371 0.000000 -vn 0.706842 0.707371 0.000000 -vn 0.706842 0.707371 0.000000 -vn 0.706842 0.707371 0.000000 -vn -0.000374 1.000000 0.000000 -vn -0.000374 1.000000 0.000000 -vn -0.000374 1.000000 0.000000 -vn -0.000374 1.000000 0.000000 -vn -0.707371 0.706842 0.000000 -vn -0.707371 0.706842 0.000000 -vn -0.707371 0.706842 0.000000 -vn -0.707371 0.706842 0.000000 -vn -1.000000 -0.000374 0.000000 -vn -1.000000 -0.000374 0.000000 -vn -1.000000 -0.000374 0.000000 -vn -1.000000 -0.000374 0.000000 -vn -0.706842 -0.707371 -0.000000 -vn -0.706842 -0.707371 -0.000000 -vn -0.706842 -0.707371 -0.000000 -vn -0.706842 -0.707371 0.000000 -vn 0.000374 -1.000000 -0.000000 -vn 0.000374 -1.000000 0.000000 -vn 0.000374 -1.000000 -0.000000 -vn 0.000374 -1.000000 -0.000000 -vn 0.707371 -0.706842 -0.000000 -vn 0.707371 -0.706842 -0.000000 -vn 0.707371 -0.706842 -0.000000 -vn 0.707371 -0.706842 -0.000000 -vn 1.000000 0.000374 0.000000 -vn 1.000000 0.000374 0.000000 -vn 1.000000 0.000374 0.000000 -vn 1.000000 0.000374 0.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn -0.099506 0.000000 0.995037 -vn -0.099506 0.000000 0.995037 -vn -0.099506 0.000000 0.995037 -vn -0.099506 0.000000 0.995037 -vn 0.000000 -0.099506 0.995037 -vn 0.000000 -0.099506 0.995037 -vn 0.000000 -0.099506 0.995037 -vn 0.000000 -0.099506 0.995037 -vn 0.099506 0.000000 0.995037 -vn 0.099506 0.000000 0.995037 -vn 0.099506 0.000000 0.995037 -vn 0.099506 0.000000 0.995037 -vn 0.000000 0.099506 0.995037 -vn 0.000000 0.099506 0.995037 -vn 0.000000 0.099506 0.995037 -vn 0.000000 0.099506 0.995037 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -0.929987 0.000000 0.367592 -vn -0.677867 0.000000 0.735184 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -0.929987 0.367592 -vn 0.000000 -0.677867 0.735184 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 0.929987 0.000000 0.367592 -vn 0.677867 0.000000 0.735184 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 0.929987 0.367592 -vn 0.000000 0.677867 0.735184 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn -0.000000 -1.000000 0.000000 -vn -0.000000 -1.000000 0.000000 -vn -0.000000 -1.000000 0.000000 -vn -0.000000 -1.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn 0.000000 0.967538 0.252725 -vn 0.000000 0.862856 0.505449 -vn 0.967538 0.000000 0.252725 -vn 0.862856 0.000000 0.505449 -vn -0.000000 -0.967538 0.252725 -vn -0.000000 -0.862856 0.505449 -vn -0.967538 0.000000 0.252725 -vn -0.862856 0.000000 0.505449 -vn 0.000000 0.862856 0.505449 -vn 0.000000 0.967538 0.252725 -vn 0.862856 0.000000 0.505449 -vn 0.967538 0.000000 0.252725 -vn -0.000000 -0.862856 0.505449 -vn -0.000000 -0.967538 0.252725 -vn -0.862856 0.000000 0.505449 -vn -0.967538 0.000000 0.252725 -vn 0.000000 0.967538 0.252725 -vn 0.000000 0.862856 0.505449 -vn 0.967538 0.000000 0.252724 -vn 0.862857 0.000000 0.505449 -vn -0.000000 -0.967538 0.252724 -vn -0.000000 -0.862857 0.505448 -vn -0.967538 0.000000 0.252725 -vn -0.862857 0.000000 0.505449 -vn 0.000000 0.707107 0.707107 -vn 0.000000 0.707107 0.707107 -vn 0.707108 0.000000 0.707106 -vn 0.707107 0.000000 0.707107 -vn -0.000000 -0.707108 0.707105 -vn -0.000000 -0.707108 0.707105 -vn -0.707108 0.000000 0.707106 -vn -0.707108 0.000000 0.707105 -vn 0.000000 0.099506 0.995037 -vn 0.000000 0.099506 0.995037 -vn 0.000000 0.099506 0.995037 -vn 0.000000 0.099506 0.995037 -vn 0.099506 0.000000 0.995037 -vn 0.099501 0.000000 0.995037 -vn 0.099506 0.000000 0.995037 -vn 0.099506 0.000000 0.995037 -vn -0.000000 -0.099501 0.995037 -vn -0.000000 -0.099501 0.995037 -vn -0.000000 -0.099501 0.995037 -vn -0.000000 -0.099501 0.995037 -vn -0.099501 0.000000 0.995037 -vn -0.099506 0.000000 0.995037 -vn -0.099501 0.000000 0.995037 -vn -0.099501 0.000000 0.995037 -vn -0.275482 0.000000 0.961306 -vn -0.187896 0.000000 0.982189 -vn 0.000000 -0.275482 0.961306 -vn 0.000000 -0.187896 0.982189 -vn 0.275482 0.000000 0.961306 -vn 0.187896 0.000000 0.982189 -vn 0.000000 0.275482 0.961306 -vn 0.000000 0.187896 0.982189 -vn -0.516067 0.000000 0.856548 -vn -0.903649 0.000000 0.428274 -vn 0.000000 -0.516067 0.856548 -vn 0.000000 -0.903649 0.428274 -vn 0.516067 0.000000 0.856548 -vn 0.903649 0.000000 0.428274 -vn 0.000000 0.516067 0.856548 -vn 0.000000 0.903649 0.428274 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn -0.049938 0.000000 0.998752 -vn -0.049938 0.000000 0.998752 -vn -0.049938 0.000000 0.998752 -vn -0.049938 0.000000 0.998752 -vn 0.000000 -0.049938 0.998752 -vn 0.000000 -0.049938 0.998752 -vn 0.000000 -0.049938 0.998752 -vn 0.000000 -0.049938 0.998752 -vn 0.049938 0.000000 0.998752 -vn 0.049938 0.000000 0.998752 -vn 0.049938 0.000000 0.998752 -vn 0.049938 0.000000 0.998752 -vn 0.000000 0.049938 0.998752 -vn 0.000000 0.049938 0.998752 -vn 0.000000 0.049938 0.998752 -vn 0.000000 0.049938 0.998752 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 1.000000 0.000000 0.000000 -vn 0.000000 1.000000 -0.000002 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 -0.000002 -vn 0.000000 1.000000 -0.000005 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -1.000000 0.000000 0.000000 -vn -0.000000 -1.000000 0.000002 -vn 0.000000 -1.000000 0.000005 -vn -0.000000 -1.000000 0.000002 -vn -0.000000 -1.000000 0.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.000000 0.000000 -1.000000 -vn 0.562661 0.423331 -0.710072 -vn 0.704032 0.011758 -0.710070 -vn 0.582173 0.063049 -0.810617 -vn 0.433925 0.393201 -0.810618 -vn 0.206373 0.673207 -0.710072 -vn 0.119934 0.573161 -0.810618 -vn -0.228742 0.665939 -0.710072 -vn -0.239867 0.534192 -0.810618 -vn -0.576487 0.404302 -0.710072 -vn -0.508049 0.291177 -0.810618 -vn -0.704032 -0.011763 -0.710070 -vn -0.582173 -0.063055 -0.810616 -vn -0.562662 -0.423334 -0.710070 -vn -0.433926 -0.393204 -0.810616 -vn -0.206373 -0.673209 -0.710070 -vn -0.119934 -0.573164 -0.810616 -vn 0.228743 -0.665941 -0.710070 -vn 0.239869 -0.534195 -0.810616 -vn 0.576487 -0.404306 -0.710070 -vn 0.508049 -0.291182 -0.810616 -vn 0.745732 0.553468 -0.370886 -vn 0.928631 0.009435 -0.370885 -vn 0.277988 0.886096 -0.370886 -vn -0.295936 0.880264 -0.370886 -vn -0.756825 0.538201 -0.370886 -vn -0.928631 -0.009437 -0.370885 -vn -0.745732 -0.553469 -0.370885 -vn -0.277989 -0.886096 -0.370885 -vn 0.295937 -0.880265 -0.370885 -vn 0.756824 -0.538202 -0.370885 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 -0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.951056 -0.309017 0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.047494 0.015432 0.998752 -vn 0.047493 0.015432 0.998752 -vn 0.047494 0.015432 0.998752 -vn 0.047494 0.015432 0.998752 -vn 0.029353 0.040401 0.998752 -vn 0.029353 0.040401 0.998752 -vn 0.029353 0.040401 0.998752 -vn 0.029353 0.040401 0.998752 -vn 0.000000 0.049938 0.998752 -vn 0.000000 0.049938 0.998752 -vn 0.000000 0.049938 0.998752 -vn 0.000000 0.049938 0.998752 -vn -0.029353 0.040401 0.998752 -vn -0.029353 0.040401 0.998752 -vn -0.029353 0.040401 0.998752 -vn -0.029353 0.040401 0.998752 -vn -0.047493 0.015431 0.998752 -vn -0.047494 0.015432 0.998752 -vn -0.047493 0.015431 0.998752 -vn -0.047493 0.015431 0.998752 -vn -0.047493 -0.015432 0.998752 -vn -0.047493 -0.015432 0.998752 -vn -0.047493 -0.015432 0.998752 -vn -0.047493 -0.015432 0.998752 -vn -0.029353 -0.040400 0.998752 -vn -0.029353 -0.040400 0.998752 -vn -0.029353 -0.040400 0.998752 -vn -0.029353 -0.040400 0.998752 -vn 0.000000 -0.049937 0.998752 -vn 0.000000 -0.049937 0.998752 -vn 0.000000 -0.049937 0.998752 -vn 0.000000 -0.049937 0.998752 -vn 0.029353 -0.040399 0.998752 -vn 0.029353 -0.040400 0.998752 -vn 0.029353 -0.040399 0.998752 -vn 0.029353 -0.040399 0.998752 -vn 0.047493 -0.015432 0.998752 -vn 0.047493 -0.015432 0.998752 -vn 0.047493 -0.015432 0.998752 -vn 0.047493 -0.015432 0.998752 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 -0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.951056 -0.309017 0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.425325 0.138196 -0.894427 -vn 0.425326 0.138197 -0.894427 -vn 0.425325 0.138196 -0.894427 -vn 0.425325 0.138196 -0.894427 -vn 0.262866 0.361804 -0.894427 -vn 0.262865 0.361803 -0.894427 -vn 0.262866 0.361804 -0.894427 -vn 0.262866 0.361804 -0.894427 -vn -0.000000 0.447215 -0.894427 -vn 0.000000 0.447214 -0.894427 -vn -0.000000 0.447215 -0.894427 -vn -0.000000 0.447215 -0.894427 -vn -0.262865 0.361803 -0.894427 -vn -0.262866 0.361804 -0.894427 -vn -0.262865 0.361803 -0.894427 -vn -0.262865 0.361803 -0.894427 -vn -0.425326 0.138196 -0.894427 -vn -0.425325 0.138196 -0.894427 -vn -0.425326 0.138196 -0.894427 -vn -0.425326 0.138196 -0.894427 -vn -0.425326 -0.138196 -0.894427 -vn -0.425326 -0.138196 -0.894427 -vn -0.425326 -0.138196 -0.894427 -vn -0.425326 -0.138196 -0.894427 -vn -0.262865 -0.361804 -0.894427 -vn -0.262865 -0.361804 -0.894427 -vn -0.262865 -0.361804 -0.894427 -vn -0.262865 -0.361804 -0.894427 -vn 0.000000 -0.447214 -0.894427 -vn 0.000000 -0.447214 -0.894427 -vn 0.000000 -0.447214 -0.894427 -vn 0.000000 -0.447214 -0.894427 -vn 0.262865 -0.361804 -0.894427 -vn 0.262865 -0.361804 -0.894427 -vn 0.262865 -0.361804 -0.894427 -vn 0.262865 -0.361804 -0.894427 -vn 0.425326 -0.138196 -0.894427 -vn 0.425326 -0.138196 -0.894427 -vn 0.425326 -0.138196 -0.894427 -vn 0.425326 -0.138196 -0.894427 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.587786 0.809017 -0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587786 0.809017 -0.000000 -vn 0.587786 0.809017 -0.000000 -vn -0.000000 1.000000 0.000000 -vn -0.000000 1.000000 -0.000001 -vn -0.000000 1.000000 0.000000 -vn -0.000000 1.000000 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 -0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.951056 -0.309017 0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.951056 -0.309017 -0.000000 -vn 0.425325 0.138197 0.894427 -vn 0.425326 0.138197 0.894427 -vn 0.425325 0.138197 0.894427 -vn 0.425325 0.138197 0.894427 -vn 0.262866 0.361803 0.894427 -vn 0.262866 0.361804 0.894427 -vn 0.262866 0.361803 0.894427 -vn 0.262866 0.361803 0.894427 -vn 0.000000 0.447214 0.894427 -vn -0.000000 0.447213 0.894427 -vn 0.000000 0.447214 0.894427 -vn 0.000000 0.447214 0.894427 -vn -0.262866 0.361804 0.894427 -vn -0.262865 0.361804 0.894427 -vn -0.262866 0.361804 0.894427 -vn -0.262866 0.361804 0.894427 -vn -0.425326 0.138197 0.894427 -vn -0.425326 0.138197 0.894427 -vn -0.425326 0.138197 0.894427 -vn -0.425326 0.138197 0.894427 -vn -0.425324 -0.138197 0.894428 -vn -0.425326 -0.138197 0.894427 -vn -0.425324 -0.138197 0.894428 -vn -0.425324 -0.138197 0.894428 -vn -0.262866 -0.361803 0.894427 -vn -0.262865 -0.361802 0.894428 -vn -0.262866 -0.361803 0.894427 -vn -0.262866 -0.361803 0.894427 -vn 0.000000 -0.447213 0.894427 -vn 0.000000 -0.447213 0.894427 -vn 0.000000 -0.447213 0.894427 -vn 0.000000 -0.447213 0.894427 -vn 0.262866 -0.361802 0.894427 -vn 0.262866 -0.361803 0.894427 -vn 0.262866 -0.361802 0.894427 -vn 0.262866 -0.361802 0.894427 -vn 0.425326 -0.138198 0.894427 -vn 0.425325 -0.138197 0.894427 -vn 0.425326 -0.138198 0.894427 -vn 0.425326 -0.138198 0.894427 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000001 -vn 0.951056 0.309017 0.000000 -vn 0.951056 0.309017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.587785 0.809017 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn 0.000000 1.000000 0.000000 -vn -0.587785 0.809017 0.000001 -vn -0.587785 0.809017 0.000000 -vn -0.587785 0.809017 0.000001 -vn -0.587785 0.809017 0.000001 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000001 -vn -0.951056 0.309017 0.000000 -vn -0.951056 0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 -0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.951056 -0.309017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn -0.587785 -0.809017 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.000000 -1.000000 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.587785 -0.809017 0.000000 -vn 0.951056 -0.309017 0.000001 -vn 0.951056 -0.309017 0.000000 -vn 0.951056 -0.309017 0.000001 -vn 0.951056 -0.309017 0.000001 -vn 0.808878 0.587853 -0.012040 -vn 0.999927 0.000136 -0.012040 -vn 0.928631 0.009435 -0.370885 -vn 0.745732 0.553468 -0.370886 -vn 0.308865 0.951030 -0.012040 -vn 0.277988 0.886096 -0.370886 -vn -0.309124 0.950945 -0.012040 -vn -0.295936 0.880264 -0.370886 -vn -0.809038 0.587632 -0.012040 -vn -0.756825 0.538201 -0.370886 -vn -0.999927 -0.000136 -0.012040 -vn -0.928631 -0.009437 -0.370885 -vn -0.808878 -0.587853 -0.012040 -vn -0.745732 -0.553469 -0.370885 -vn -0.308865 -0.951030 -0.012040 -vn -0.277989 -0.886096 -0.370885 -vn 0.309124 -0.950945 -0.012040 -vn 0.295937 -0.880265 -0.370885 -vn 0.809038 -0.587632 -0.012040 -vn 0.309124 -0.950945 -0.012040 -vn 0.295937 -0.880265 -0.370885 -vn 0.756824 -0.538202 -0.370885 -vn 0.797207 0.577639 0.175482 -vn 0.984482 -0.001267 0.175482 -vn 0.305427 0.935906 0.175482 -vn -0.303017 0.936689 0.175482 -vn -0.795718 0.579689 0.175482 -vn -0.984482 0.001267 0.175482 -vn -0.797207 -0.577639 0.175482 -vn -0.305426 -0.935906 0.175482 -vn 0.303017 -0.936689 0.175482 -vn 0.795718 -0.579689 0.175482 -vn 0.303017 -0.936689 0.175482 -vn 0.805510 0.586917 0.081747 -vn 0.996652 0.001359 0.081747 -vn 0.306690 0.948292 0.081747 -vn -0.309275 0.947452 0.081747 -vn -0.807107 0.584718 0.081747 -vn -0.996652 -0.001359 0.081747 -vn -0.805510 -0.586917 0.081747 -vn -0.306690 -0.948292 0.081747 -vn 0.309275 -0.947452 0.081747 -vn 0.807107 -0.584718 0.081747 -vn 0.309275 -0.947452 0.081747 -vn 0.768673 0.548289 -0.329426 -vn 0.944145 -0.008240 -0.329426 -vn 0.299593 0.895389 -0.329426 -vn -0.283921 0.900482 -0.329426 -vn -0.758987 0.561621 -0.329426 -vn -0.944145 0.008240 -0.329426 -vn -0.768673 -0.548289 -0.329426 -vn -0.299593 -0.895389 -0.329426 -vn 0.283921 -0.900482 -0.329426 -vn 0.758987 -0.561620 -0.329426 -vn 0.283921 -0.900482 -0.329426 -vn 0.726320 0.416280 -0.546965 -vn 0.832289 -0.090142 -0.546964 -vn 0.342922 0.763698 -0.546965 -vn -0.171461 0.819409 -0.546965 -vn -0.620351 0.562133 -0.546965 -vn -0.832288 0.090142 -0.546965 -vn -0.726320 -0.416280 -0.546965 -vn -0.342922 -0.763698 -0.546965 -vn 0.171461 -0.819409 -0.546965 -vn 0.620351 -0.562134 -0.546965 -vn 0.171461 -0.819409 -0.546965 -f 1/1/1 2/2/2 3/3/3 -f 3/3/3 4/4/4 1/1/1 -f 5/5/5 6/6/6 7/7/7 -f 7/7/7 8/8/8 5/5/5 -f 9/9/9 10/10/10 11/11/11 -f 11/11/11 12/12/12 9/9/9 -f 10/10/10 13/13/13 14/14/14 -f 14/14/14 11/11/11 10/10/10 -f 15/15/15 16/16/16 17/17/17 -f 17/17/17 18/18/18 15/15/15 -f 19/19/19 1/1/1 4/4/4 -f 4/4/4 20/20/20 19/19/19 -f 4/4/4 3/3/3 21/21/21 -f 21/21/21 22/22/22 4/4/4 -f 8/8/8 7/7/7 23/23/23 -f 23/23/23 24/24/24 8/8/8 -f 25/25/25 26/26/26 27/27/27 -f 27/27/27 28/28/28 25/25/25 -f 29/29/29 30/30/30 31/31/31 -f 31/31/31 32/32/32 29/29/29 -f 18/18/18 17/17/17 33/33/33 -f 33/33/33 34/34/34 18/18/18 -f 20/20/20 4/4/4 22/22/22 -f 22/22/22 35/35/35 20/20/20 -f 22/22/22 21/21/21 36/36/36 -f 36/36/36 37/37/37 22/22/22 -f 24/24/24 23/23/23 38/38/38 -f 38/38/38 39/39/39 24/24/24 -f 28/28/28 27/27/27 40/40/40 -f 40/40/40 41/41/41 28/28/28 -f 32/32/32 31/31/31 42/42/42 -f 42/42/42 43/43/43 32/32/32 -f 34/34/34 33/33/33 44/44/44 -f 44/44/44 45/45/45 34/34/34 -f 35/35/35 22/22/22 37/37/37 -f 37/37/37 46/46/46 35/35/35 -f 37/37/37 36/36/36 47/47/47 -f 47/47/47 48/48/48 37/37/37 -f 39/39/39 38/38/38 49/49/49 -f 49/49/49 50/50/50 39/39/39 -f 41/41/41 40/40/40 51/51/51 -f 51/51/51 52/52/52 41/41/41 -f 43/43/43 42/42/42 53/53/53 -f 53/53/53 54/54/54 43/43/43 -f 45/45/45 44/44/44 55/55/55 -f 55/55/55 56/56/56 45/45/45 -f 46/46/46 37/37/37 48/48/48 -f 48/48/48 57/57/57 46/46/46 -f 48/48/48 47/47/47 58/58/58 -f 58/58/58 59/59/59 48/48/48 -f 50/50/50 49/49/49 60/60/60 -f 60/60/60 61/61/61 50/50/50 -f 52/52/52 51/51/51 62/62/62 -f 62/62/62 63/63/63 52/52/52 -f 54/54/54 53/53/53 64/64/64 -f 64/64/64 65/65/65 54/54/54 -f 56/56/56 55/55/55 66/66/66 -f 66/66/66 67/67/67 56/56/56 -f 57/57/57 48/48/48 59/59/59 -f 59/59/59 68/68/68 57/57/57 -f 69/69/69 70/70/70 71/71/71 -f 69/69/69 72/72/72 70/70/70 -f 69/69/69 73/73/73 72/72/72 -f 69/69/69 74/74/74 73/73/73 -f 69/69/69 75/75/75 74/74/74 -f 69/69/69 71/71/71 75/75/75 -f 76/76/76 77/77/77 59/59/59 -f 76/76/76 59/59/59 58/58/58 -f 78/78/78 79/79/79 61/61/61 -f 78/78/78 61/61/61 60/60/60 -f 80/80/80 81/81/81 63/63/63 -f 80/80/80 63/63/63 62/62/62 -f 82/82/82 83/83/83 65/65/65 -f 82/82/82 65/65/65 64/64/64 -f 84/84/84 85/85/85 67/67/67 -f 84/84/84 67/67/67 66/66/66 -f 77/77/77 86/86/86 68/68/68 -f 77/77/77 68/68/68 59/59/59 -f 87/87/87 88/88/88 89/89/89 -f 89/89/89 90/90/90 87/87/87 -f 91/91/91 92/92/92 93/93/93 -f 93/93/93 94/94/94 91/91/91 -f 95/95/95 96/96/96 97/97/97 -f 97/97/97 98/98/98 95/95/95 -f 96/96/96 99/99/99 100/100/100 -f 100/100/100 97/97/97 96/96/96 -f 101/101/101 102/102/102 103/103/103 -f 103/103/103 104/104/104 101/101/101 -f 105/105/105 87/87/87 90/90/90 -f 90/90/90 106/106/106 105/105/105 -f 90/90/90 89/89/89 107/107/107 -f 107/107/107 108/108/108 90/90/90 -f 94/94/94 93/93/93 109/109/109 -f 109/109/109 110/110/110 94/94/94 -f 111/111/111 112/112/112 113/113/113 -f 113/113/113 114/114/114 111/111/111 -f 115/115/115 116/116/116 117/117/117 -f 117/117/117 118/118/118 115/115/115 -f 104/104/104 103/103/103 119/119/119 -f 119/119/119 120/120/120 104/104/104 -f 106/106/106 90/90/90 108/108/108 -f 108/108/108 121/121/121 106/106/106 -f 108/108/108 107/107/107 122/122/122 -f 122/122/122 123/123/123 108/108/108 -f 110/110/110 109/109/109 124/124/124 -f 124/124/124 125/125/125 110/110/110 -f 114/114/114 113/113/113 126/126/126 -f 126/126/126 127/127/127 114/114/114 -f 118/118/118 117/117/117 128/128/128 -f 128/128/128 129/129/129 118/118/118 -f 120/120/120 119/119/119 130/130/130 -f 130/130/130 131/131/131 120/120/120 -f 121/121/121 108/108/108 123/123/123 -f 123/123/123 132/132/132 121/121/121 -f 123/123/123 122/122/122 133/133/133 -f 133/133/133 134/134/134 123/123/123 -f 125/125/125 124/124/124 135/135/135 -f 135/135/135 136/136/136 125/125/125 -f 127/127/127 126/126/126 137/137/137 -f 137/137/137 138/138/138 127/127/127 -f 129/129/129 128/128/128 139/139/139 -f 139/139/139 140/140/140 129/129/129 -f 131/131/131 130/130/130 141/141/141 -f 141/141/141 142/142/142 131/131/131 -f 132/132/132 123/123/123 134/134/134 -f 134/134/134 143/143/143 132/132/132 -f 134/134/134 133/133/133 144/144/144 -f 144/144/144 145/145/145 134/134/134 -f 136/136/136 135/135/135 146/146/146 -f 146/146/146 147/147/147 136/136/136 -f 138/138/138 137/137/137 148/148/148 -f 148/148/148 149/149/149 138/138/138 -f 140/140/140 139/139/139 150/150/150 -f 150/150/150 151/151/151 140/140/140 -f 142/142/142 141/141/141 152/152/152 -f 152/152/152 153/153/153 142/142/142 -f 143/143/143 134/134/134 145/145/145 -f 145/145/145 154/154/154 143/143/143 -f 155/155/155 156/156/156 157/157/157 -f 155/155/155 158/158/158 156/156/156 -f 155/155/155 159/159/159 158/158/158 -f 155/155/155 160/160/160 159/159/159 -f 155/155/155 161/161/161 160/160/160 -f 155/155/155 157/157/157 161/161/161 -f 162/162/162 163/163/163 145/145/145 -f 162/162/162 145/145/145 144/144/144 -f 164/164/164 165/165/165 147/147/147 -f 164/164/164 147/147/147 146/146/146 -f 166/166/166 167/167/167 149/149/149 -f 166/166/166 149/149/149 148/148/148 -f 168/168/168 169/169/169 151/151/151 -f 168/168/168 151/151/151 150/150/150 -f 170/170/170 171/171/171 153/153/153 -f 170/170/170 153/153/153 152/152/152 -f 163/163/163 172/172/172 154/154/154 -f 163/163/163 154/154/154 145/145/145 -f 173/173/173 174/174/174 175/175/175 -f 175/175/175 176/176/176 173/173/173 -f 177/177/177 178/178/178 179/179/179 -f 179/179/179 180/180/180 177/177/177 -f 181/181/181 182/182/182 183/183/183 -f 183/183/183 184/184/184 181/181/181 -f 182/182/182 185/185/185 186/186/186 -f 186/186/186 183/183/183 182/182/182 -f 187/187/187 188/188/188 189/189/189 -f 189/189/189 190/190/190 187/187/187 -f 191/191/191 173/173/173 176/176/176 -f 176/176/176 192/192/192 191/191/191 -f 176/176/176 175/175/175 193/193/193 -f 193/193/193 194/194/194 176/176/176 -f 180/180/180 179/179/179 195/195/195 -f 195/195/195 196/196/196 180/180/180 -f 197/197/197 198/198/198 199/199/199 -f 199/199/199 200/200/200 197/197/197 -f 201/201/201 202/202/202 203/203/203 -f 203/203/203 204/204/204 201/201/201 -f 190/190/190 189/189/189 205/205/205 -f 205/205/205 206/206/206 190/190/190 -f 192/192/192 176/176/176 194/194/194 -f 194/194/194 207/207/207 192/192/192 -f 194/194/194 193/193/193 208/208/208 -f 208/208/208 209/209/209 194/194/194 -f 196/196/196 195/195/195 210/210/210 -f 210/210/210 211/211/211 196/196/196 -f 200/200/200 199/199/199 212/212/212 -f 212/212/212 213/213/213 200/200/200 -f 204/204/204 203/203/203 214/214/214 -f 214/214/214 215/215/215 204/204/204 -f 206/206/206 205/205/205 216/216/216 -f 216/216/216 217/217/217 206/206/206 -f 207/207/207 194/194/194 209/209/209 -f 209/209/209 218/218/218 207/207/207 -f 209/209/209 208/208/208 219/219/219 -f 219/219/219 220/220/220 209/209/209 -f 211/211/211 210/210/210 221/221/221 -f 221/221/221 222/222/222 211/211/211 -f 213/213/213 212/212/212 223/223/223 -f 223/223/223 224/224/224 213/213/213 -f 215/215/215 214/214/214 225/225/225 -f 225/225/225 226/226/226 215/215/215 -f 217/217/217 216/216/216 227/227/227 -f 227/227/227 228/228/228 217/217/217 -f 218/218/218 209/209/209 220/220/220 -f 220/220/220 229/229/229 218/218/218 -f 220/220/220 219/219/219 230/230/230 -f 230/230/230 231/231/231 220/220/220 -f 222/222/222 221/221/221 232/232/232 -f 232/232/232 233/233/233 222/222/222 -f 224/224/224 223/223/223 234/234/234 -f 234/234/234 235/235/235 224/224/224 -f 226/226/226 225/225/225 236/236/236 -f 236/236/236 237/237/237 226/226/226 -f 228/228/228 227/227/227 238/238/238 -f 238/238/238 239/239/239 228/228/228 -f 229/229/229 220/220/220 231/231/231 -f 231/231/231 240/240/240 229/229/229 -f 241/241/241 242/242/242 243/243/243 -f 241/241/241 244/244/244 242/242/242 -f 241/241/241 245/245/245 244/244/244 -f 241/241/241 246/246/246 245/245/245 -f 241/241/241 247/247/247 246/246/246 -f 241/241/241 243/243/243 247/247/247 -f 248/248/248 249/249/249 231/231/231 -f 248/248/248 231/231/231 230/230/230 -f 250/250/250 251/251/251 233/233/233 -f 250/250/250 233/233/233 232/232/232 -f 252/252/252 253/253/253 235/235/235 -f 252/252/252 235/235/235 234/234/234 -f 254/254/254 255/255/255 237/237/237 -f 254/254/254 237/237/237 236/236/236 -f 256/256/256 257/257/257 239/239/239 -f 256/256/256 239/239/239 238/238/238 -f 249/249/249 258/258/258 240/240/240 -f 249/249/249 240/240/240 231/231/231 -f 259/259/259 260/260/260 261/261/261 -f 261/261/261 262/262/262 259/259/259 -f 263/263/263 264/264/264 265/265/265 -f 265/265/265 266/266/266 263/263/263 -f 267/267/267 268/268/268 269/269/269 -f 269/269/269 270/270/270 267/267/267 -f 268/268/268 271/271/271 272/272/272 -f 272/272/272 269/269/269 268/268/268 -f 273/273/273 274/274/274 275/275/275 -f 275/275/275 276/276/276 273/273/273 -f 277/277/277 259/259/259 262/262/262 -f 262/262/262 278/278/278 277/277/277 -f 262/262/262 261/261/261 279/279/279 -f 279/279/279 280/280/280 262/262/262 -f 266/266/266 265/265/265 281/281/281 -f 281/281/281 282/282/282 266/266/266 -f 283/283/283 284/284/284 285/285/285 -f 285/285/285 286/286/286 283/283/283 -f 287/287/287 288/288/288 289/289/289 -f 289/289/289 290/290/290 287/287/287 -f 276/276/276 275/275/275 291/291/291 -f 291/291/291 292/292/292 276/276/276 -f 278/278/278 262/262/262 280/280/280 -f 280/280/280 293/293/293 278/278/278 -f 280/280/280 279/279/279 294/294/294 -f 294/294/294 295/295/295 280/280/280 -f 282/282/282 281/281/281 296/296/296 -f 296/296/296 297/297/297 282/282/282 -f 286/286/286 285/285/285 298/298/298 -f 298/298/298 299/299/299 286/286/286 -f 290/290/290 289/289/289 300/300/300 -f 300/300/300 301/301/301 290/290/290 -f 292/292/292 291/291/291 302/302/302 -f 302/302/302 303/303/303 292/292/292 -f 293/293/293 280/280/280 295/295/295 -f 295/295/295 304/304/304 293/293/293 -f 295/295/295 294/294/294 305/305/305 -f 305/305/305 306/306/306 295/295/295 -f 297/297/297 296/296/296 307/307/307 -f 307/307/307 308/308/308 297/297/297 -f 299/299/299 298/298/298 309/309/309 -f 309/309/309 310/310/310 299/299/299 -f 301/301/301 300/300/300 311/311/311 -f 311/311/311 312/312/312 301/301/301 -f 303/303/303 302/302/302 313/313/313 -f 313/313/313 314/314/314 303/303/303 -f 304/304/304 295/295/295 306/306/306 -f 306/306/306 315/315/315 304/304/304 -f 306/306/306 305/305/305 316/316/316 -f 316/316/316 317/317/317 306/306/306 -f 308/308/308 307/307/307 318/318/318 -f 318/318/318 319/319/319 308/308/308 -f 310/310/310 309/309/309 320/320/320 -f 320/320/320 321/321/321 310/310/310 -f 312/312/312 311/311/311 322/322/322 -f 322/322/322 323/323/323 312/312/312 -f 314/314/314 313/313/313 324/324/324 -f 324/324/324 325/325/325 314/314/314 -f 315/315/315 306/306/306 317/317/317 -f 317/317/317 326/326/326 315/315/315 -f 327/327/327 328/328/328 329/329/329 -f 327/327/327 330/330/330 328/328/328 -f 327/327/327 331/331/331 330/330/330 -f 327/327/327 332/332/332 331/331/331 -f 327/327/327 333/333/333 332/332/332 -f 327/327/327 329/329/329 333/333/333 -f 334/334/334 335/335/335 317/317/317 -f 334/334/334 317/317/317 316/316/316 -f 336/336/336 337/337/337 319/319/319 -f 336/336/336 319/319/319 318/318/318 -f 338/338/338 339/339/339 321/321/321 -f 338/338/338 321/321/321 320/320/320 -f 340/340/340 341/341/341 323/323/323 -f 340/340/340 323/323/323 322/322/322 -f 342/342/342 343/343/343 325/325/325 -f 342/342/342 325/325/325 324/324/324 -f 335/335/335 344/344/344 326/326/326 -f 335/335/335 326/326/326 317/317/317 -f 345/345/345 346/346/346 347/347/347 -f 345/345/345 348/348/348 346/346/346 -f 345/345/345 349/349/349 348/348/348 -f 345/345/345 350/350/350 349/349/349 -f 345/345/345 351/351/351 350/350/350 -f 345/345/345 352/352/352 351/351/351 -f 345/345/345 353/353/353 352/352/352 -f 345/345/345 347/347/347 353/353/353 -f 354/354/354 355/355/355 356/356/356 -f 354/354/354 356/356/356 357/357/357 -f 358/358/358 359/359/359 360/360/360 -f 358/358/358 360/360/360 361/361/361 -f 362/362/362 363/363/363 364/364/364 -f 362/362/362 364/364/364 365/365/365 -f 366/366/366 367/367/367 368/368/368 -f 366/366/366 368/368/368 369/369/369 -f 370/370/370 371/371/371 372/372/372 -f 370/370/370 372/372/372 373/373/373 -f 374/374/374 375/375/375 376/376/376 -f 374/374/374 376/376/376 377/377/377 -f 378/378/378 379/379/379 380/380/380 -f 378/378/378 380/380/380 381/381/381 -f 382/382/382 383/383/383 384/384/384 -f 382/382/382 384/384/384 385/385/385 -f 386/386/386 387/387/387 388/388/388 -f 386/386/386 388/388/388 389/389/389 -f 386/386/386 389/389/389 390/390/390 -f 386/386/386 390/390/390 391/391/391 -f 386/386/386 391/391/391 392/392/392 -f 386/386/386 392/392/392 393/393/393 -f 386/386/386 393/393/393 394/394/394 -f 386/386/386 394/394/394 387/387/387 -f 395/395/395 396/396/396 397/397/397 -f 397/397/397 398/398/398 395/395/395 -f 399/399/399 400/400/400 401/401/401 -f 401/401/401 402/402/402 399/399/399 -f 403/403/403 404/404/404 405/405/405 -f 405/405/405 406/406/406 403/403/403 -f 407/407/407 408/408/408 409/409/409 -f 409/409/409 410/410/410 407/407/407 -f 411/411/411 412/412/412 413/413/413 -f 413/413/413 414/414/414 411/411/411 -f 415/415/415 416/416/416 417/417/417 -f 417/417/417 418/418/418 415/415/415 -f 419/419/419 420/420/420 421/421/421 -f 421/421/421 422/422/422 419/419/419 -f 423/423/423 424/424/424 425/425/425 -f 425/425/425 426/426/426 423/423/423 -f 427/427/427 428/428/428 429/429/429 -f 429/429/429 430/430/430 427/427/427 -f 431/431/431 432/432/432 433/433/433 -f 433/433/433 434/434/434 431/431/431 -f 435/435/435 436/436/436 437/437/437 -f 437/437/437 438/438/438 435/435/435 -f 439/439/439 440/440/440 441/441/441 -f 441/441/441 442/442/442 439/439/439 -f 443/443/443 444/444/444 445/445/445 -f 445/445/445 446/446/446 443/443/443 -f 447/447/447 448/448/448 449/449/449 -f 449/449/449 450/450/450 447/447/447 -f 451/451/451 452/452/452 453/453/453 -f 453/453/453 454/454/454 451/451/451 -f 455/455/455 456/456/456 457/457/457 -f 457/457/457 458/458/458 455/455/455 -f 446/446/446 445/445/445 459/459/459 -f 459/459/459 460/460/460 446/446/446 -f 450/450/450 449/449/449 461/461/461 -f 461/461/461 462/462/462 450/450/450 -f 454/454/454 453/453/453 463/463/463 -f 463/463/463 464/464/464 454/454/454 -f 458/458/458 457/457/457 465/465/465 -f 465/465/465 466/466/466 458/458/458 -f 460/460/460 459/459/459 467/467/467 -f 467/467/467 468/468/468 460/460/460 -f 462/462/462 461/461/461 469/469/469 -f 469/469/469 470/470/470 462/462/462 -f 464/464/464 463/463/463 471/471/471 -f 471/471/471 472/472/472 464/464/464 -f 466/466/466 465/465/465 473/473/473 -f 473/473/473 474/474/474 466/466/466 -f 468/468/468 467/467/467 475/475/475 -f 475/475/475 476/476/476 468/468/468 -f 470/470/470 469/469/469 477/477/477 -f 477/477/477 478/478/478 470/470/470 -f 472/472/472 471/471/471 479/479/479 -f 479/479/479 480/480/480 472/472/472 -f 474/474/474 473/473/473 481/481/481 -f 481/481/481 482/482/482 474/474/474 -f 476/476/476 475/475/475 483/483/483 -f 483/483/483 484/484/484 476/476/476 -f 478/478/478 477/477/477 485/485/485 -f 485/485/485 486/486/486 478/478/478 -f 480/480/480 479/479/479 487/487/487 -f 487/487/487 488/488/488 480/480/480 -f 482/482/482 481/481/481 489/489/489 -f 489/489/489 490/490/490 482/482/482 -f 491/491/491 492/492/492 493/493/493 -f 493/493/493 494/494/494 491/491/491 -f 495/495/495 496/496/496 497/497/497 -f 497/497/497 498/498/498 495/495/495 -f 499/499/499 500/500/500 501/501/501 -f 501/501/501 502/502/502 499/499/499 -f 503/503/503 504/504/504 505/505/505 -f 505/505/505 506/506/506 503/503/503 -f 430/430/430 429/429/429 507/507/507 -f 507/507/507 508/508/508 430/430/430 -f 434/434/434 433/433/433 509/509/509 -f 509/509/509 510/510/510 434/434/434 -f 438/438/438 437/437/437 511/511/511 -f 511/511/511 512/512/512 438/438/438 -f 442/442/442 441/441/441 513/513/513 -f 513/513/513 514/514/514 442/442/442 -f 508/508/508 507/507/507 515/515/515 -f 515/515/515 516/516/516 508/508/508 -f 510/510/510 509/509/509 517/517/517 -f 517/517/517 518/518/518 510/510/510 -f 512/512/512 511/511/511 519/519/519 -f 519/519/519 520/520/520 512/512/512 -f 514/514/514 513/513/513 521/521/521 -f 521/521/521 522/522/522 514/514/514 -f 516/516/516 515/515/515 523/523/523 -f 523/523/523 524/524/524 516/516/516 -f 518/518/518 517/517/517 525/525/525 -f 525/525/525 526/526/526 518/518/518 -f 520/520/520 519/519/519 527/527/527 -f 527/527/527 528/528/528 520/520/520 -f 522/522/522 521/521/521 529/529/529 -f 529/529/529 530/530/530 522/522/522 -f 531/531/531 532/532/532 533/533/533 -f 533/533/533 534/534/534 531/531/531 -f 535/535/535 536/536/536 537/537/537 -f 537/537/537 538/538/538 535/535/535 -f 539/539/539 540/540/540 541/541/541 -f 541/541/541 542/542/542 539/539/539 -f 543/543/543 544/544/544 545/545/545 -f 545/545/545 546/546/546 543/543/543 -f 547/547/547 548/548/548 549/549/549 -f 549/549/549 550/550/550 547/547/547 -f 551/551/551 552/552/552 553/553/553 -f 553/553/553 554/554/554 551/551/551 -f 555/555/555 556/556/556 557/557/557 -f 557/557/557 558/558/558 555/555/555 -f 559/559/559 560/560/560 561/561/561 -f 561/561/561 562/562/562 559/559/559 -f 563/563/563 564/564/564 565/565/565 -f 565/565/565 566/566/566 563/563/563 -f 567/567/567 568/568/568 569/569/569 -f 569/569/569 570/570/570 567/567/567 -f 571/571/571 572/572/572 573/573/573 -f 573/573/573 574/574/574 571/571/571 -f 575/575/575 571/571/571 574/574/574 -f 574/574/574 576/576/576 575/575/575 -f 577/577/577 575/575/575 576/576/576 -f 576/576/576 578/578/578 577/577/577 -f 579/579/579 577/577/577 578/578/578 -f 578/578/578 580/580/580 579/579/579 -f 581/581/581 579/579/579 580/580/580 -f 580/580/580 582/582/582 581/581/581 -f 583/583/583 581/581/581 582/582/582 -f 582/582/582 584/584/584 583/583/583 -f 585/585/585 583/583/583 584/584/584 -f 584/584/584 586/586/586 585/585/585 -f 587/587/587 585/585/585 586/586/586 -f 586/586/586 588/588/588 587/587/587 -f 589/589/589 587/587/587 588/588/588 -f 588/588/588 590/590/590 589/589/589 -f 572/572/572 589/589/589 590/590/590 -f 590/590/590 573/573/573 572/572/572 -f 591/591/591 592/592/592 572/572/572 -f 572/572/572 571/571/571 591/591/591 -f 593/593/593 591/591/591 571/571/571 -f 571/571/571 575/575/575 593/593/593 -f 594/594/594 593/593/593 575/575/575 -f 575/575/575 577/577/577 594/594/594 -f 595/595/595 594/594/594 577/577/577 -f 577/577/577 579/579/579 595/595/595 -f 596/596/596 595/595/595 579/579/579 -f 579/579/579 581/581/581 596/596/596 -f 597/597/597 596/596/596 581/581/581 -f 581/581/581 583/583/583 597/597/597 -f 598/598/598 597/597/597 583/583/583 -f 583/583/583 585/585/585 598/598/598 -f 599/599/599 598/598/598 585/585/585 -f 585/585/585 587/587/587 599/599/599 -f 600/600/600 599/599/599 587/587/587 -f 587/587/587 589/589/589 600/600/600 -f 592/592/592 600/600/600 589/589/589 -f 589/589/589 572/572/572 592/592/592 -f 601/601/601 602/602/602 603/603/603 -f 603/603/603 604/604/604 601/601/601 -f 605/605/605 606/606/606 607/607/607 -f 607/607/607 608/608/608 605/605/605 -f 609/609/609 610/610/610 611/611/611 -f 611/611/611 612/612/612 609/609/609 -f 613/613/613 614/614/614 615/615/615 -f 615/615/615 616/616/616 613/613/613 -f 617/617/617 618/618/618 619/619/619 -f 619/619/619 620/620/620 617/617/617 -f 621/621/621 622/622/622 623/623/623 -f 623/623/623 624/624/624 621/621/621 -f 625/625/625 626/626/626 627/627/627 -f 627/627/627 628/628/628 625/625/625 -f 629/629/629 630/630/630 631/631/631 -f 631/631/631 632/632/632 629/629/629 -f 633/633/633 634/634/634 635/635/635 -f 635/635/635 636/636/636 633/633/633 -f 637/637/637 638/638/638 639/639/639 -f 639/639/639 640/640/640 637/637/637 -f 641/641/641 642/642/642 643/643/643 -f 643/643/643 644/644/644 641/641/641 -f 645/645/645 646/646/646 647/647/647 -f 647/647/647 648/648/648 645/645/645 -f 649/649/649 650/650/650 651/651/651 -f 651/651/651 652/652/652 649/649/649 -f 653/653/653 654/654/654 655/655/655 -f 655/655/655 656/656/656 653/653/653 -f 657/657/657 658/658/658 659/659/659 -f 659/659/659 660/660/660 657/657/657 -f 661/661/661 662/662/662 663/663/663 -f 663/663/663 664/664/664 661/661/661 -f 665/665/665 666/666/666 667/667/667 -f 667/667/667 668/668/668 665/665/665 -f 669/669/669 670/670/670 671/671/671 -f 671/671/671 672/672/672 669/669/669 -f 673/673/673 674/674/674 675/675/675 -f 675/675/675 676/676/676 673/673/673 -f 677/677/677 678/678/678 679/679/679 -f 679/679/679 680/680/680 677/677/677 -f 681/681/681 682/682/682 683/683/683 -f 683/683/683 684/684/684 681/681/681 -f 685/685/685 686/686/686 687/687/687 -f 687/687/687 688/688/688 685/685/685 -f 689/689/689 690/690/690 691/691/691 -f 691/691/691 692/692/692 689/689/689 -f 693/693/693 694/694/694 695/695/695 -f 695/695/695 696/696/696 693/693/693 -f 697/697/697 698/698/698 699/699/699 -f 699/699/699 700/700/700 697/697/697 -f 701/701/701 702/702/702 703/703/703 -f 703/703/703 704/704/704 701/701/701 -f 705/705/705 706/706/706 707/707/707 -f 707/707/707 708/708/708 705/705/705 -f 709/709/709 710/710/710 711/711/711 -f 711/711/711 712/712/712 709/709/709 -f 713/713/713 714/714/714 715/715/715 -f 715/715/715 716/716/716 713/713/713 -f 717/717/717 718/718/718 719/719/719 -f 719/719/719 720/720/720 717/717/717 -f 721/721/721 722/722/722 723/723/723 -f 723/723/723 724/724/724 721/721/721 -f 725/725/725 726/726/726 727/727/727 -f 727/727/727 728/728/728 725/725/725 -f 729/729/729 730/730/730 731/731/731 -f 731/731/731 732/732/732 729/729/729 -f 733/733/733 734/734/734 735/735/735 -f 735/735/735 736/736/736 733/733/733 -f 737/737/737 738/738/738 739/739/739 -f 739/739/739 740/740/740 737/737/737 -f 741/741/741 742/742/742 743/743/743 -f 743/743/743 744/744/744 741/741/741 -f 745/745/745 746/746/746 747/747/747 -f 747/747/747 748/748/748 745/745/745 -f 749/749/749 750/750/750 751/751/751 -f 751/751/751 752/752/752 749/749/749 -f 753/753/753 754/754/754 755/755/755 -f 755/755/755 756/756/756 753/753/753 -f 757/757/757 758/758/758 759/759/759 -f 759/759/759 760/760/760 757/757/757 -f 761/761/761 762/762/762 763/763/763 -f 763/763/763 764/764/764 761/761/761 -f 765/765/765 766/766/766 767/767/767 -f 767/767/767 768/768/768 765/765/765 -f 769/769/769 770/770/770 771/771/771 -f 771/771/771 772/772/772 769/769/769 -f 773/773/773 774/774/774 775/775/775 -f 775/775/775 776/776/776 773/773/773 -f 777/777/777 778/778/778 779/779/779 -f 779/779/779 780/780/780 777/777/777 -f 781/781/781 782/782/782 783/783/783 -f 783/783/783 784/784/784 781/781/781 -f 785/785/785 786/786/786 787/787/787 -f 787/787/787 788/788/788 785/785/785 -f 789/789/789 790/790/790 791/791/791 -f 791/791/791 792/792/792 789/789/789 -f 793/793/793 794/794/794 795/795/795 -f 795/795/795 796/796/796 793/793/793 -f 797/797/797 798/798/798 799/799/799 -f 799/799/799 800/800/800 797/797/797 -f 801/801/801 802/802/802 803/803/803 -f 803/803/803 804/804/804 801/801/801 -f 805/805/805 806/806/806 807/807/807 -f 807/807/807 808/808/808 805/805/805 -f 809/809/809 810/810/810 811/811/811 -f 811/811/811 812/812/812 809/809/809 -f 813/813/813 814/814/814 815/815/815 -f 815/815/815 816/816/816 813/813/813 -f 817/817/817 818/818/818 819/819/819 -f 819/819/819 820/820/820 817/817/817 -f 821/821/821 822/822/822 823/823/823 -f 823/823/823 824/824/824 821/821/821 -f 825/825/825 826/826/826 827/827/827 -f 827/827/827 828/828/828 825/825/825 -f 829/829/829 830/830/830 831/831/831 -f 831/831/831 832/832/832 829/829/829 -f 833/833/833 834/834/834 835/835/835 -f 835/835/835 836/836/836 833/833/833 -f 837/837/837 838/838/838 839/839/839 -f 839/839/839 840/840/840 837/837/837 -f 841/841/841 842/842/842 843/843/843 -f 843/843/843 844/844/844 841/841/841 -f 845/845/845 846/846/846 847/847/847 -f 847/847/847 848/848/848 845/845/845 -f 849/849/849 850/850/850 851/851/851 -f 851/851/851 852/852/852 849/849/849 -f 853/853/853 854/854/854 855/855/855 -f 855/855/855 856/856/856 853/853/853 -f 857/857/857 858/858/858 859/859/859 -f 859/859/859 860/860/860 857/857/857 -f 861/861/861 862/862/862 863/863/863 -f 863/863/863 864/864/864 861/861/861 -f 865/865/865 866/866/866 867/867/867 -f 867/867/867 868/868/868 865/865/865 -f 869/869/869 870/870/870 871/871/871 -f 871/871/871 872/872/872 869/869/869 -f 873/873/873 874/874/874 875/875/875 -f 875/875/875 876/876/876 873/873/873 -f 877/877/877 878/878/878 879/879/879 -f 879/879/879 880/880/880 877/877/877 -f 881/881/881 882/882/882 883/883/883 -f 881/881/881 883/883/883 884/884/884 -f 885/885/885 881/881/881 884/884/884 -f 885/885/885 884/884/884 886/886/886 -f 887/887/887 885/885/885 886/886/886 -f 887/887/887 886/886/886 888/888/888 -f 889/889/889 887/887/887 888/888/888 -f 889/889/889 888/888/888 890/890/890 -f 891/891/891 889/889/889 890/890/890 -f 891/891/891 890/890/890 892/892/892 -f 893/893/893 891/891/891 892/892/892 -f 893/893/893 892/892/892 894/894/894 -f 895/895/895 893/893/893 894/894/894 -f 895/895/895 894/894/894 896/896/896 -f 897/897/897 895/895/895 896/896/896 -f 897/897/897 896/896/896 898/898/898 -f 899/899/899 900/900/900 901/901/901 -f 899/899/899 901/901/901 902/902/902 -f 882/882/882 899/899/899 902/902/902 -f 882/882/882 902/902/902 883/883/883 -f 903/903/903 904/904/904 882/882/882 -f 903/903/903 882/882/882 881/881/881 -f 905/905/905 903/903/903 881/881/881 -f 905/905/905 881/881/881 885/885/885 -f 906/906/906 905/905/905 885/885/885 -f 906/906/906 885/885/885 887/887/887 -f 907/907/907 906/906/906 887/887/887 -f 907/907/907 887/887/887 889/889/889 -f 908/908/908 907/907/907 889/889/889 -f 908/908/908 889/889/889 891/891/891 -f 909/909/909 908/908/908 891/891/891 -f 909/909/909 891/891/891 893/893/893 -f 910/910/910 909/909/909 893/893/893 -f 910/910/910 893/893/893 895/895/895 -f 911/911/911 910/910/910 895/895/895 -f 911/911/911 895/895/895 897/897/897 -f 912/912/912 913/913/913 900/900/900 -f 912/912/912 900/900/900 899/899/899 -f 904/904/904 912/912/912 899/899/899 -f 904/904/904 899/899/899 882/882/882 -f 914/914/914 915/915/915 904/904/904 -f 914/914/914 904/904/904 903/903/903 -f 916/916/916 914/914/914 903/903/903 -f 916/916/916 903/903/903 905/905/905 -f 917/917/917 916/916/916 905/905/905 -f 917/917/917 905/905/905 906/906/906 -f 918/918/918 917/917/917 906/906/906 -f 918/918/918 906/906/906 907/907/907 -f 919/919/919 918/918/918 907/907/907 -f 919/919/919 907/907/907 908/908/908 -f 920/920/920 919/919/919 908/908/908 -f 920/920/920 908/908/908 909/909/909 -f 921/921/921 920/920/920 909/909/909 -f 921/921/921 909/909/909 910/910/910 -f 922/922/922 921/921/921 910/910/910 -f 922/922/922 910/910/910 911/911/911 -f 923/923/923 924/924/924 913/913/913 -f 923/923/923 913/913/913 912/912/912 -f 915/915/915 923/923/923 912/912/912 -f 915/915/915 912/912/912 904/904/904 -f 925/925/925 926/926/926 915/915/915 -f 925/925/925 915/915/915 914/914/914 -f 927/927/927 925/925/925 914/914/914 -f 927/927/927 914/914/914 916/916/916 -f 928/928/928 927/927/927 916/916/916 -f 928/928/928 916/916/916 917/917/917 -f 929/929/929 928/928/928 917/917/917 -f 929/929/929 917/917/917 918/918/918 -f 930/930/930 929/929/929 918/918/918 -f 930/930/930 918/918/918 919/919/919 -f 931/931/931 930/930/930 919/919/919 -f 931/931/931 919/919/919 920/920/920 -f 932/932/932 931/931/931 920/920/920 -f 932/932/932 920/920/920 921/921/921 -f 933/933/933 932/932/932 921/921/921 -f 933/933/933 921/921/921 922/922/922 -f 934/934/934 935/935/935 924/924/924 -f 934/934/934 924/924/924 923/923/923 -f 926/926/926 934/934/934 923/923/923 -f 926/926/926 923/923/923 915/915/915 -f 936/936/936 937/937/937 926/926/926 -f 936/936/936 926/926/926 925/925/925 -f 938/938/938 936/936/936 925/925/925 -f 938/938/938 925/925/925 927/927/927 -f 939/939/939 938/938/938 927/927/927 -f 939/939/939 927/927/927 928/928/928 -f 940/940/940 939/939/939 928/928/928 -f 940/940/940 928/928/928 929/929/929 -f 941/941/941 940/940/940 929/929/929 -f 941/941/941 929/929/929 930/930/930 -f 942/942/942 941/941/941 930/930/930 -f 942/942/942 930/930/930 931/931/931 -f 943/943/943 942/942/942 931/931/931 -f 943/943/943 931/931/931 932/932/932 -f 944/944/944 943/943/943 932/932/932 -f 944/944/944 932/932/932 933/933/933 -f 945/945/945 946/946/946 935/935/935 -f 945/945/945 935/935/935 934/934/934 -f 937/937/937 945/945/945 934/934/934 -f 937/937/937 934/934/934 926/926/926 diff --git a/Demos/ConvexDecompositionDemo/main.cpp b/Demos/ConvexDecompositionDemo/main.cpp deleted file mode 100644 index 9173e5be0..000000000 --- a/Demos/ConvexDecompositionDemo/main.cpp +++ /dev/null @@ -1,27 +0,0 @@ - - -#include "ConvexDecompositionDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - - - -int main(int argc,char** argv) -{ - const char* filename = "file.obj"; - - - ConvexDecompositionDemo* convexDecompDemo = new ConvexDecompositionDemo(); - - convexDecompDemo->initPhysics(filename); - - - - - glutmain(argc, argv,640,480,"Bullet Physics Demo. http://www.continuousphysics.com/Bullet/phpBB2/",convexDecompDemo); - - delete convexDecompDemo; - - return 0; -} diff --git a/Demos/ConvexDecompositionDemo/testFile32Single.bullet b/Demos/ConvexDecompositionDemo/testFile32Single.bullet deleted file mode 100644 index b94637973..000000000 Binary files a/Demos/ConvexDecompositionDemo/testFile32Single.bullet and /dev/null differ diff --git a/Demos/ConvexHullDistance/CMakeLists.txt b/Demos/ConvexHullDistance/CMakeLists.txt deleted file mode 100644 index 7e02bf696..000000000 --- a/Demos/ConvexHullDistance/CMakeLists.txt +++ /dev/null @@ -1,65 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppConvexHullDistanceDemo - - ConvexHullDistanceDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppConvexHullDistanceDemo - ConvexHullDistanceDemo.cpp - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppConvexHullDistanceDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - ConvexHullDistanceDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppConvexHullDistanceDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppConvexHullDistanceDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppConvexHullDistanceDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/ConvexHullDistance/ConvexHullDistanceDemo.cpp b/Demos/ConvexHullDistance/ConvexHullDistanceDemo.cpp deleted file mode 100644 index b0647dd80..000000000 --- a/Demos/ConvexHullDistance/ConvexHullDistanceDemo.cpp +++ /dev/null @@ -1,509 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -/// -/// Convex Hull Distance Demo shows distance calculation between two convex hulls of points. -/// GJK with the btVoronoiSimplexSolver is used. -/// - -#include "GL_Simplex1to4.h" -#include "LinearMath/btQuaternion.h" -#include "LinearMath/btTransform.h" -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/CollisionShapes/btConvexHullShape.h" -#include "BulletCollision/CollisionShapes/btCylinderShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/NarrowPhaseCollision/btPointCollector.h" -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h" -#include "LinearMath/btIDebugDraw.h" -#include "LinearMath/btConvexHullComputer.h" - - - - -#define TaruVtxCount 43 - -static btScalar TaruVtx[] = { -1.08664f,-1.99237f,0.0f, -0.768369f,-1.99237f,-0.768369f, -1.28852f,1.34412e-007f,-1.28852f, -1.82224f,1.90735e-007f,0.0f, -0.0f,-1.99237f,-1.08664f, -0.0f,0.0f,-1.82224f, -0.0f,-1.99237f,-1.08664f, --0.768369f,-1.99237f,-0.768369f, --1.28852f,1.34412e-007f,-1.28852f, -0.0f,0.0f,-1.82224f, --1.08664f,-1.99237f,1.82086e-007f, --1.82224f,1.90735e-007f,1.59305e-007f, --0.768369f,-1.99237f,0.76837f, --1.28852f,2.47058e-007f,1.28852f, -1.42495e-007f,-1.99237f,1.08664f, -2.38958e-007f,2.70388e-007f,1.82224f, -0.768369f,-1.99237f,0.768369f, -1.28852f,2.47058e-007f,1.28852f, -0.768369f,1.99237f,-0.768369f, -1.08664f,1.99237f,0.0f, -0.0f,1.99237f,-1.08664f, --0.768369f,1.99237f,-0.768369f, -0.0f,1.99237f,-1.08664f, --1.08664f,1.99237f,0.0f, --0.768369f,1.99237f,0.768369f, -1.42495e-007f,1.99237f,1.08664f, -0.768369f,1.99237f,0.768369f, -1.42495e-007f,-1.99237f,1.08664f, --0.768369f,-1.99237f,0.76837f, --1.08664f,-1.99237f,1.82086e-007f, --0.768369f,-1.99237f,-0.768369f, -0.0f,-1.99237f,-1.08664f, -0.768369f,-1.99237f,-0.768369f, -1.08664f,-1.99237f,0.0f, -0.768369f,-1.99237f,0.768369f, -0.768369f,1.99237f,-0.768369f, -0.0f,1.99237f,-1.08664f, --0.768369f,1.99237f,-0.768369f, --1.08664f,1.99237f,0.0f, --0.768369f,1.99237f,0.768369f, -1.42495e-007f,1.99237f,1.08664f, -0.768369f,1.99237f,0.768369f, -1.08664f,1.99237f,0.0f, -}; - - - - -#define USE_GJK - -#ifndef USE_GJK -#include "btBulletCollisionCommon.h" - -#endif //USE_GJK -#include "GL_ShapeDrawer.h" -#ifdef WIN32 //needed for glut.h -#include -#endif -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#include -#else -#include -#endif -#include "GlutStuff.h" - - -float yaw=0.f,pitch=0.f,roll=0.f; -const int maxNumObjects = 4; -const int numObjects = 2; - -GL_Simplex1to4 simplex; - -btConvexShape* shapePtr[maxNumObjects]; - -btTransform tr[numObjects]; -int screenWidth = 640.f; -int screenHeight = 480.f; - -void clientResetScene() -{ - tr[0].setOrigin(btVector3(0.0f,3.f,7.f)); - tr[1].setOrigin(btVector3(0.0f,9.f,2.f)); -} - -int debugMode = btIDebugDraw::DBG_DrawWireframe; -GL_ShapeDrawer shapeDrawer; -int m_glutScreenWidth=0; -int m_glutScreenHeight=0; -float m_frustumZNear = 1.f; -float m_frustumZFar = 10000.f; -bool m_ortho = false; - -int myglutmain(int argc, char **argv,int width,int height,const char* title); - - -void updateCamera() { - - - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - btScalar rele = 0; - btScalar razi = 0; - btVector3 m_cameraUp(0,1,0); - btScalar m_cameraDistance = 10.f; - btVector3 m_cameraPosition; - - - btVector3 m_cameraTargetPosition = (tr[0].getOrigin()+tr[1].getOrigin())*0.5; - - - btQuaternion rot(m_cameraUp,razi); - - - int m_forwardAxis = 2; - - btVector3 eyePos(0,0,0); - eyePos[m_forwardAxis] = -m_cameraDistance; - - btVector3 forward(eyePos[0],eyePos[1],eyePos[2]); - if (forward.length2() < SIMD_EPSILON) - { - forward.setValue(1.f,0.f,0.f); - } - btVector3 right = m_cameraUp.cross(forward); - btQuaternion roll(right,-rele); - - eyePos = btMatrix3x3(rot) * btMatrix3x3(roll) * eyePos; - - m_cameraPosition[0] = eyePos.getX(); - m_cameraPosition[1] = eyePos.getY(); - m_cameraPosition[2] = eyePos.getZ(); - m_cameraPosition += m_cameraTargetPosition; - - if (m_glutScreenWidth == 0 && m_glutScreenHeight == 0) - return; - - btScalar aspect; - btVector3 extents; - - if (m_glutScreenWidth > m_glutScreenHeight) - { - aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight; - extents.setValue(aspect * 1.0f, 1.0f,0); - } else - { - aspect = m_glutScreenHeight / (btScalar)m_glutScreenWidth; - extents.setValue(1.0f, aspect*1.f,0); - } - - - if (m_ortho) - { - // reset matrix - glLoadIdentity(); - - - extents *= m_cameraDistance; - btVector3 lower = m_cameraTargetPosition - extents; - btVector3 upper = m_cameraTargetPosition + extents; - //gluOrtho2D(lower.x, upper.x, lower.y, upper.y); - glOrtho(lower.getX(), upper.getX(), lower.getY(), upper.getY(),-1000,1000); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - //glTranslatef(100,210,0); - } else - { - if (m_glutScreenWidth > m_glutScreenHeight) - { -// glFrustum (-aspect, aspect, -1.0, 1.0, 1.0, 10000.0); - glFrustum (-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar); - } else - { -// glFrustum (-1.0, 1.0, -aspect, aspect, 1.0, 10000.0); - glFrustum (-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar); - } - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - gluLookAt(m_cameraPosition[0], m_cameraPosition[1], m_cameraPosition[2], - m_cameraTargetPosition[0], m_cameraTargetPosition[1], m_cameraTargetPosition[2], - m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ()); - } - -} - - -int main(int argc,char** argv) -{ - clientResetScene(); - - btMatrix3x3 basisA; - basisA.setIdentity(); - - btMatrix3x3 basisB; - basisB.setIdentity(); - - tr[0].setBasis(basisA); - tr[1].setBasis(basisB); - - btVector3 points0[3]={btVector3(1,0,0),btVector3(0,1,0),btVector3(0,0,1)}; - //btVector3 points1[5]={btVector3(1,0,0),btVector3(0,1,0),btVector3(0,0,1),btVector3(0,0,-1),btVector3(-1,-1,0)}; - - btConvexHullShape hullA(&points0[0].getX(),3); - btConvexHullShape hullB(TaruVtx,TaruVtxCount,3*sizeof(btScalar)); - - shapePtr[0] = &hullA; - shapePtr[1] = &hullB; - - - btTransform tr; - tr.setIdentity(); - - - return myglutmain(argc, argv,screenWidth,screenHeight,"Convex Hull Distance Demo"); -} - - -static btVoronoiSimplexSolver sGjkSimplexSolver; -btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver; - -#include - - -void clientDisplay(void) { - - - updateCamera(); - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDisable(GL_LIGHTING); - - //GL_ShapeDrawer::drawCoordSystem(); - - ATTRIBUTE_ALIGNED16(btScalar) m[16]; - int i; -#ifdef USE_GJK - btGjkEpaPenetrationDepthSolver epa; - btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epa); - - btVector3 seperatingAxis(0.00000000f,0.059727669f,0.29259586f); - convexConvex.setCachedSeperatingAxis(seperatingAxis); - - btPointCollector gjkOutput; - btGjkPairDetector::ClosestPointInput input; - input.m_transformA = tr[0]; - input.m_transformB = tr[1]; - - convexConvex.getClosestPoints(input ,gjkOutput,0); - - if (gjkOutput.m_hasResult) - { - btVector3 endPt = gjkOutput.m_pointInWorld + - gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance; - - glBegin(GL_LINES); - glColor3f(1, 0, 0); - glVertex3d(gjkOutput.m_pointInWorld.x(), gjkOutput.m_pointInWorld.y(),gjkOutput.m_pointInWorld.z()); - glVertex3d(endPt.x(),endPt.y(),endPt.z()); - glEnd(); - - } -#else //USE_GJK - - - struct MyContactResultCallback : public btCollisionWorld::ContactResultCallback - { - virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) - { - glBegin(GL_LINES); - glColor3f(1, 0, 0); - - glVertex3d(cp.m_positionWorldOnA.getX(),cp.m_positionWorldOnA.getY(),cp.m_positionWorldOnA.getZ()); - glVertex3d(cp.m_positionWorldOnB.getX(),cp.m_positionWorldOnB.getY(),cp.m_positionWorldOnB.getZ()); - glEnd(); - - return 1.f; - } - }; - - btDefaultCollisionConfiguration collisionConfiguration; - btCollisionDispatcher dispatcher(&collisionConfiguration); - btDbvtBroadphase pairCache; - btCollisionWorld world (&dispatcher,&pairCache,&collisionConfiguration); - gContactBreakingThreshold=1e10f; - - MyContactResultCallback result; - btCollisionObject obA; - obA.setCollisionShape(shapePtr[0]); - obA.setWorldTransform(tr[0]); - btCollisionObject obB; - obB.setCollisionShape(shapePtr[1]); - obB.setWorldTransform(tr[1]); - world.contactPairTest(&obA,&obB,result); - -#endif//USE_GJK - - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - - for (i=0;iisPolyhedral()) - { - if (!shapePtr[i]->getUserPointer()) - { - btConvexHullComputer* convexUtil = new btConvexHullComputer(); - shapePtr[i]->setUserPointer(convexUtil); - - btPolyhedralConvexShape* polyshape = (btPolyhedralConvexShape*) shapePtr[i]; - - btAlignedObjectArray vertices; - vertices.resize(polyshape->getNumVertices()); - for (int i=0;igetNumVertices();i++) - { - polyshape->getVertex(i,vertices[i]); - } - - bool useDoublePrecision = false; - convexUtil->compute(&vertices[0].getX(),sizeof(btVector3), polyshape->getNumVertices(),0,0); - } - - if (shapePtr[i]->getUserPointer()) - { - btConvexHullComputer* convexUtil = (btConvexHullComputer*)shapePtr[i]->getUserPointer(); - //printf("num faces = %d\n",convexUtil->faces.size()); - for (int j=0;jfaces.size();j++) - { - int face = convexUtil->faces[j]; - //printf("face=%d\n",face); - const btConvexHullComputer::Edge* firstEdge = &convexUtil->edges[face]; - const btConvexHullComputer::Edge* edge = firstEdge; - - do - { - int src = edge->getSourceVertex(); - int targ = edge->getTargetVertex(); - //printf("src=%d target = %d\n", src,targ); - - btVector3 wa = tr[i] * convexUtil->vertices[src]; - btVector3 wb = tr[i] * convexUtil->vertices[targ]; - - glBegin(GL_LINES); - glColor3f(1, 1, 1); - glVertex3f(wa.getX(),wa.getY(),wa.getZ()); - glVertex3f(wb.getX(),wb.getY(),wb.getZ()); - glEnd(); - - edge = edge->getNextEdgeOfFace(); - } while (edge!=firstEdge); - - } - } - } - } else - { - shapeDrawer.drawOpenGL(m,shapePtr[i],btVector3(1,1,1),debugMode, worldMin, worldMax); - } - - - } - - simplex.setSimplexSolver(&sGjkSimplexSolver); - btVector3 ybuf[4],pbuf[4],qbuf[4]; - int numpoints = sGjkSimplexSolver.getSimplex(pbuf,qbuf,ybuf); - simplex.reset(); - - for (i=0;iinitPhysics(); - doublePrecisionDemo->setCameraDistance(btScalar(2.0)); - - doublePrecisionDemo->clientResetScene(); - - return glutmain(argc, argv,screenWidth,screenHeight,"Double Precision Demo",doublePrecisionDemo); -} - -void DoublePrecisionDemo::initPhysics() -{ - m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - - btMatrix3x3 basisA; - basisA.setIdentity(); - - btMatrix3x3 basisB; - basisB.setIdentity(); - - objects[0].getWorldTransform().setBasis(basisA); - objects[1].getWorldTransform().setBasis(basisB); - - - btBoxShape* boxA = new btBoxShape(btVector3(0.5,0.5,0.5)); - btBoxShape* boxB = new btBoxShape(btVector3(0.5,0.5,0.5)); - - objects[0].setCollisionShape(boxA);//&hullA; - objects[1].setCollisionShape(boxB);//&hullB; - - btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration(); - btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collisionConfiguration); - btVector3 worldAabbMin(80000,80000,80000); - btVector3 worldAabbMax(120000,120000,120000); - - btAxisSweep3* broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax); - - collisionWorld = new btCollisionWorld(dispatcher,broadphase,collisionConfiguration); - - collisionWorld->addCollisionObject(&objects[0]); - collisionWorld->addCollisionObject(&objects[1]); - -} - - -//to be implemented by the demo - -void DoublePrecisionDemo::clientMoveAndDisplay() -{ - - displayCallback(); -} - - -static btVoronoiSimplexSolver sGjkSimplexSolver; -btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver; - -void DoublePrecisionDemo::displayCallback(void) -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDisable(GL_LIGHTING); - - collisionWorld->getDispatchInfo().m_debugDraw = &debugDrawer; - - if (collisionWorld) - collisionWorld->performDiscreteCollisionDetection(); - - int i; - - btVector3 worldBoundsMin,worldBoundsMax; - collisionWorld->getBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax); - - - ///one way to draw all the contact points is iterating over contact manifolds / points: - int numManifolds = collisionWorld->getDispatcher()->getNumManifolds(); - for (i=0;igetDispatcher()->getManifoldByIndexInternal(i); - const btCollisionObject* obA = static_cast(contactManifold->getBody0()); - const btCollisionObject* obB = static_cast(contactManifold->getBody1()); - contactManifold->refreshContactPoints(obA->getWorldTransform(),obB->getWorldTransform()); - - int numContacts = contactManifold->getNumContacts(); - for (int j=0;jgetContactPoint(j); - - glBegin(GL_LINES); - glColor3f(1, 1, 1); - - btVector3 ptA = pt.getPositionWorldOnA() - m_cameraPosition; - btVector3 ptB = pt.getPositionWorldOnB() - m_cameraPosition; - - glVertex3d(ptA.x(),ptA.y(),ptA.z()); - glVertex3d(ptB.x(),ptB.y(),ptB.z()); - glEnd(); - } - - //you can un-comment out this line, and then all points are removed - //contactManifold->clearManifold(); - } - - btScalar m[16]; - btTransform temp; - - - btVector3 color; - //int i; - for (i=0;idrawOpenGL(m,objects[i].getCollisionShape(),color,getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - objects[1].getWorldTransform().setOrigin(objects[1].getWorldTransform().getOrigin()+btVector3(-VERY_SMALL_INCREMENT,-VERY_SMALL_INCREMENT,0)); - objects[0].getWorldTransform().setOrigin(objects[0].getWorldTransform().getOrigin()+btVector3(VERY_SMALL_INCREMENT,VERY_SMALL_INCREMENT,0)); - - float yStart = 20.f; - float yIncr = 20.f; - char buf[124]; - - glColor3f(0, 0, 0); - - setOrthographicProjection(); - - glRasterPos3f(10.0f,yStart,0); - #ifdef BT_USE_DOUBLE_PRECISION - GLDebugDrawString(10.f,yStart,"Double Precision Mode"); - #else - GLDebugDrawString(10.f,yStart,"Single Precision Mode"); - #endif - yStart += yIncr; - - glRasterPos3f(10.0f,yStart,0); - sprintf(buf,"Movement distance in x and y axis = %lf", VERY_SMALL_INCREMENT); - - GLDebugDrawString(10.f,yStart,buf); - yStart += yIncr; - - glRasterPos3f(10.0f,yStart,0); - btScalar xValue = objects[0].getWorldTransform().getOrigin().x(); - btScalar yValue = objects[0].getWorldTransform().getOrigin().y(); - btScalar zValue = objects[0].getWorldTransform().getOrigin().z(); - sprintf(buf,"Cube 0 location = ( %lf, %lf, %lf )", xValue, yValue, zValue); - GLDebugDrawString(10.f,yStart,buf); - yStart += yIncr; - - xValue = objects[1].getWorldTransform().getOrigin().x(); - yValue = objects[1].getWorldTransform().getOrigin().y(); - zValue = objects[1].getWorldTransform().getOrigin().z(); - glRasterPos3f(10.0f,yStart,0); - sprintf(buf,"Cube 1 location = ( %lf, %lf, %lf )", xValue, yValue, zValue); - GLDebugDrawString(10.f,yStart,buf); - yStart += yIncr; - - glRasterPos3f(10.0f,yStart,0); - GLDebugDrawString(10.f,yStart,"w=toggle wireframe/solid"); - - resetPerspectiveProjection(); - - glFlush(); - glutSwapBuffers(); -} - -void DoublePrecisionDemo::clientResetScene() -{ - objects[0].getWorldTransform().setOrigin(btVector3(LARGE_DISTANCE_FROM_ORIGIN,LARGE_DISTANCE_FROM_ORIGIN,LARGE_DISTANCE_FROM_ORIGIN)); - objects[1].getWorldTransform().setOrigin(btVector3(LARGE_DISTANCE_FROM_ORIGIN-VERY_SMALL_INCREMENT,LARGE_DISTANCE_FROM_ORIGIN-VERY_SMALL_INCREMENT,LARGE_DISTANCE_FROM_ORIGIN)); -} - - - -void DoublePrecisionDemo::updateCamera() -{ - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - - // look at the stationary cube - m_cameraTargetPosition = objects[0].getWorldTransform().getOrigin(); - - m_cameraPosition = m_cameraTargetPosition; - m_cameraPosition[2] = m_cameraTargetPosition[2] - m_cameraDistance; - - //update OpenGL camera settings - glFrustum(-1.0, 1.0, -1.0, 1.0, 1.0, 10000.0); - - // To not loose precision in the rendering process, we shift the object to the origin - gluLookAt(0.0, 0.0, 0.0, - m_cameraTargetPosition[0]-m_cameraPosition[0],m_cameraTargetPosition[1]-m_cameraPosition[1], m_cameraTargetPosition[2]-m_cameraPosition[2], - m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ()); - glMatrixMode(GL_MODELVIEW); -} - -void DoublePrecisionDemo::keyboardCallback(unsigned char key, int x, int y) -{ - if (key == 'w') - { - if (m_debugMode & btIDebugDraw::DBG_DrawWireframe) - { - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawWireframe); - m_debugMode |= btIDebugDraw::DBG_DrawAabb; - } - else - { - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawAabb); - m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - } - return; - } - - DemoApplication::keyboardCallback(key, x, y); -} - - diff --git a/Demos/DoublePrecisionDemo/DoublePrecisionDemo.h b/Demos/DoublePrecisionDemo/DoublePrecisionDemo.h deleted file mode 100644 index 7de07fd27..000000000 --- a/Demos/DoublePrecisionDemo/DoublePrecisionDemo.h +++ /dev/null @@ -1,41 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef COLLISION_INTERFACE_DEMO_H -#define COLLISION_INTERFACE_DEMO_H - -#include "GlutDemoApplication.h" - -///DoublePrecisionDemo shows how to use the collision detection without dynamics (btCollisionWorld/CollisionObject) -class DoublePrecisionDemo : public GlutDemoApplication -{ - public: - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void clientResetScene(); - - virtual void updateCamera(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - -}; - -#endif //COLLISION_INTERFACE_DEMO_H - - diff --git a/Demos/DynamicControlDemo/CMakeLists.txt b/Demos/DynamicControlDemo/CMakeLists.txt deleted file mode 100644 index 04521bcfd..000000000 --- a/Demos/DynamicControlDemo/CMakeLists.txt +++ /dev/null @@ -1,34 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppMotorDemo - MotorDemo.cpp - main.cpp -) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppMotorDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppMotorDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppMotorDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/DynamicControlDemo/MotorDemo.cpp b/Demos/DynamicControlDemo/MotorDemo.cpp deleted file mode 100644 index ee2184e28..000000000 --- a/Demos/DynamicControlDemo/MotorDemo.cpp +++ /dev/null @@ -1,468 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library Copyright (c) 2007 Erwin Coumans -Motor Demo - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#include "btBulletDynamicsCommon.h" -#include "GlutStuff.h" -#include "GL_ShapeDrawer.h" - -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" -#include "MotorDemo.h" - - -#ifndef M_PI -#define M_PI 3.14159265358979323846 -#endif - -#ifndef M_PI_2 -#define M_PI_2 1.57079632679489661923 -#endif - -#ifndef M_PI_4 -#define M_PI_4 0.785398163397448309616 -#endif - -#ifndef M_PI_8 -#define M_PI_8 0.5 * M_PI_4 -#endif - - -// LOCAL FUNCTIONS - -void vertex(btVector3 &v) -{ - glVertex3d(v.getX(), v.getY(), v.getZ()); -} - -void drawFrame(btTransform &tr) -{ - const float fSize = 1.f; - - glBegin(GL_LINES); - - // x - glColor3f(255.f,0,0); - btVector3 vX = tr*btVector3(fSize,0,0); - vertex(tr.getOrigin()); vertex(vX); - - // y - glColor3f(0,255.f,0); - btVector3 vY = tr*btVector3(0,fSize,0); - vertex(tr.getOrigin()); vertex(vY); - - // z - glColor3f(0,0,255.f); - btVector3 vZ = tr*btVector3(0,0,fSize); - vertex(tr.getOrigin()); vertex(vZ); - - glEnd(); -} - -// /LOCAL FUNCTIONS - - - -#define NUM_LEGS 6 -#define BODYPART_COUNT 2 * NUM_LEGS + 1 -#define JOINT_COUNT BODYPART_COUNT - 1 - -class TestRig -{ - btDynamicsWorld* m_ownerWorld; - btCollisionShape* m_shapes[BODYPART_COUNT]; - btRigidBody* m_bodies[BODYPART_COUNT]; - btTypedConstraint* m_joints[JOINT_COUNT]; - - btRigidBody* localCreateRigidBody (btScalar mass, const btTransform& startTransform, btCollisionShape* shape) - { - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,shape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - m_ownerWorld->addRigidBody(body); - - return body; - } - - -public: - TestRig (btDynamicsWorld* ownerWorld, const btVector3& positionOffset, bool bFixed) - : m_ownerWorld (ownerWorld) - { - btVector3 vUp(0, 1, 0); - - // - // Setup geometry - // - float fBodySize = 0.25f; - float fLegLength = 0.45f; - float fForeLegLength = 0.75f; - m_shapes[0] = new btCapsuleShape(btScalar(fBodySize), btScalar(0.10)); - int i; - for ( i=0; isetDamping(0.05, 0.85); - m_bodies[i]->setDeactivationTime(0.8); - //m_bodies[i]->setSleepingThresholds(1.6, 2.5); - m_bodies[i]->setSleepingThresholds(0.5f, 0.5f); - } - - - // - // Setup the constraints - // - btHingeConstraint* hingeC; - //btConeTwistConstraint* coneC; - - btTransform localA, localB, localC; - - for ( i=0; igetWorldTransform().inverse() * m_bodies[0]->getWorldTransform() * localA; - hingeC = new btHingeConstraint(*m_bodies[0], *m_bodies[1+2*i], localA, localB); - hingeC->setLimit(btScalar(-0.75 * M_PI_4), btScalar(M_PI_8)); - //hingeC->setLimit(btScalar(-0.1), btScalar(0.1)); - m_joints[2*i] = hingeC; - m_ownerWorld->addConstraint(m_joints[2*i], true); - - // knee joints - localA.setIdentity(); localB.setIdentity(); localC.setIdentity(); - localA.getBasis().setEulerZYX(0,-fAngle,0); localA.setOrigin(btVector3(btScalar(fCos*(fBodySize+fLegLength)), btScalar(0.), btScalar(fSin*(fBodySize+fLegLength)))); - localB = m_bodies[1+2*i]->getWorldTransform().inverse() * m_bodies[0]->getWorldTransform() * localA; - localC = m_bodies[2+2*i]->getWorldTransform().inverse() * m_bodies[0]->getWorldTransform() * localA; - hingeC = new btHingeConstraint(*m_bodies[1+2*i], *m_bodies[2+2*i], localB, localC); - //hingeC->setLimit(btScalar(-0.01), btScalar(0.01)); - hingeC->setLimit(btScalar(-M_PI_8), btScalar(0.2)); - m_joints[1+2*i] = hingeC; - m_ownerWorld->addConstraint(m_joints[1+2*i], true); - } - } - - virtual ~TestRig () - { - int i; - - // Remove all constraints - for ( i = 0; i < JOINT_COUNT; ++i) - { - m_ownerWorld->removeConstraint(m_joints[i]); - delete m_joints[i]; m_joints[i] = 0; - } - - // Remove all bodies and shapes - for ( i = 0; i < BODYPART_COUNT; ++i) - { - m_ownerWorld->removeRigidBody(m_bodies[i]); - - delete m_bodies[i]->getMotionState(); - - delete m_bodies[i]; m_bodies[i] = 0; - delete m_shapes[i]; m_shapes[i] = 0; - } - } - - btTypedConstraint** GetJoints() {return &m_joints[0];} - -}; - - - -void motorPreTickCallback (btDynamicsWorld *world, btScalar timeStep) -{ - MotorDemo* motorDemo = (MotorDemo*)world->getWorldUserInfo(); - - motorDemo->setMotorTargets(timeStep); - -} - - - -void MotorDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - // Setup the basic world - - m_Time = 0; - m_fCyclePeriod = 2000.f; // in milliseconds - -// m_fMuscleStrength = 0.05f; - // new SIMD solver for joints clips accumulated impulse, so the new limits for the motor - // should be (numberOfsolverIterations * oldLimits) - // currently solver uses 10 iterations, so: - m_fMuscleStrength = 0.5f; - - setCameraDistance(btScalar(5.)); - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax(10000,10000,10000); - m_broadphase = new btAxisSweep3 (worldAabbMin, worldAabbMax); - - m_solver = new btSequentialImpulseConstraintSolver; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - - m_dynamicsWorld->setInternalTickCallback(motorPreTickCallback,this,true); - - - // Setup a big ground box - { - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(200.),btScalar(10.),btScalar(200.))); - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-10,0)); - localCreateRigidBody(btScalar(0.),groundTransform,groundShape); - } - - // Spawn one ragdoll - btVector3 startOffset(1,0.5,0); - spawnTestRig(startOffset, false); - startOffset.setValue(-2,0.5,0); - spawnTestRig(startOffset, true); - - clientResetScene(); -} - - -void MotorDemo::spawnTestRig(const btVector3& startOffset, bool bFixed) -{ - TestRig* rig = new TestRig(m_dynamicsWorld, startOffset, bFixed); - m_rigs.push_back(rig); -} - -void PreStep() -{ - -} - - - - -void MotorDemo::setMotorTargets(btScalar deltaTime) -{ - - float ms = deltaTime*1000000.; - float minFPS = 1000000.f/60.f; - if (ms > minFPS) - ms = minFPS; - - m_Time += ms; - - // - // set per-frame sinusoidal position targets using angular motor (hacky?) - // - for (int r=0; r(m_rigs[r]->GetJoints()[i]); - btScalar fCurAngle = hingeC->getHingeAngle(); - - btScalar fTargetPercent = (int(m_Time / 1000) % int(m_fCyclePeriod)) / m_fCyclePeriod; - btScalar fTargetAngle = 0.5 * (1 + sin(2 * M_PI * fTargetPercent)); - btScalar fTargetLimitAngle = hingeC->getLowerLimit() + fTargetAngle * (hingeC->getUpperLimit() - hingeC->getLowerLimit()); - btScalar fAngleError = fTargetLimitAngle - fCurAngle; - btScalar fDesiredAngularVel = 1000000.f * fAngleError/ms; - hingeC->enableAngularMotor(true, fDesiredAngularVel, m_fMuscleStrength); - } - } - - -} - -void MotorDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float deltaTime = getDeltaTimeMicroseconds()/1000000.f; - - - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(deltaTime); - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - for (int i=2; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - drawFrame(body->getWorldTransform()); - } - - glFlush(); - - glutSwapBuffers(); -} - -void MotorDemo::displayCallback() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - glutSwapBuffers(); -} - -void MotorDemo::keyboardCallback(unsigned char key, int x, int y) -{ - switch (key) - { - case '+': case '=': - m_fCyclePeriod /= 1.1f; - if (m_fCyclePeriod < 1.f) - m_fCyclePeriod = 1.f; - break; - case '-': case '_': - m_fCyclePeriod *= 1.1f; - break; - case '[': - m_fMuscleStrength /= 1.1f; - break; - case ']': - m_fMuscleStrength *= 1.1f; - break; - default: - DemoApplication::keyboardCallback(key, x, y); - } -} - - - -void MotorDemo::exitPhysics() -{ - - int i; - - for (i=0;igetNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_rigs; - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - -public: - void initPhysics(); - - void exitPhysics(); - - virtual ~MotorDemo() - { - exitPhysics(); - } - - void spawnTestRig(const btVector3& startOffset, bool bFixed); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - MotorDemo* demo = new MotorDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } - - void setMotorTargets(btScalar deltaTime); - -}; - - -#endif diff --git a/Demos/DynamicControlDemo/main.cpp b/Demos/DynamicControlDemo/main.cpp deleted file mode 100644 index 188c88d5f..000000000 --- a/Demos/DynamicControlDemo/main.cpp +++ /dev/null @@ -1,28 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#include "MotorDemo.h" -#include "GlutStuff.h" - -int main(int argc,char* argv[]) -{ - MotorDemo demoApp; - - demoApp.initPhysics(); - - - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bullet.sf.net",&demoApp); -} diff --git a/Demos/EPAPenDepthDemo/PenetrationTestBullet.cpp b/Demos/EPAPenDepthDemo/PenetrationTestBullet.cpp deleted file mode 100644 index ba427db43..000000000 --- a/Demos/EPAPenDepthDemo/PenetrationTestBullet.cpp +++ /dev/null @@ -1,855 +0,0 @@ - -///contribution by Pierre Terdiman to check penetration depth solvers -///see http://www.continuousphysics.com/Bullet/phpBB2/viewtopic.php?t=638 - -#ifdef WIN32//for glut.h -#include -#endif - - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#include -#else -#include -#endif - - -#include -#include -#include - -#define VERBOSE_TEXT_ONSCREEN 1 -#ifdef VERBOSE_TEXT_ONSCREEN -#include "GLDebugFont.h" -#endif - -#include "btBulletCollisionCommon.h" - -#include "BulletCollision/NarrowPhaseCollision/btDiscreteCollisionDetectorInterface.h" -#include "BulletCollision/NarrowPhaseCollision/btSimplexSolverInterface.h" -#include "BulletCollision/NarrowPhaseCollision/btMinkowskiPenetrationDepthSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h" - - -//We can use the Bullet EPA or sampling penetration depth solver, but comparison might be useful -//#define COMPARE_WITH_SOLID35_AND_OTHER_EPA 1 -#ifdef COMPARE_WITH_SOLID35_AND_OTHER_EPA -#include "../Extras/ExtraSolid35/Solid3EpaPenetrationDepth.h" -#include "../Extras/ExtraSolid35/Solid3JohnsonSimplexSolver.h" -#include "../Extras/EPA/EpaPenetrationDepthSolver.h" -#endif //COMPARE_WITH_SOLID35_AND_OTHER_EPA - -#define USE_ORIGINAL 1 -#ifndef USE_ORIGINAL -#include "BulletCollision/NarrowPhaseCollision/btGjkEpa2.h" -#endif //USE_ORIGINAL - -static bool gRefMode = false; -static int gMethod = 0; -static int gLastUsedMethod = -1; -static int gNumGjkIterations = -1; -static int gLastDegenerateSimplex = -1; - -static const float gDisp = 0.01f; -static const float gCamSpeed = 0.1f; -static btVector3 Eye(3.0616338f, 1.1985892f, 2.5769043f); -static btVector3 Dir(-0.66853905,-0.14004262,-0.73037237); -static btVector3 N; -static int mx = 0; -static int my = 0; -static int glutScreenHeight = 512; -static int glutScreenWidth = 512; - -static void DrawLine(const btVector3& p0, const btVector3& p1, const btVector3& color, float line_width) -{ - glDisable(GL_LIGHTING); - glLineWidth(line_width); - glColor4f(color.x(), color.y(), color.z(), 1.0f); - btVector3 tmp[] = {p0, p1}; - glEnableClientState(GL_VERTEX_ARRAY); -#ifndef BT_USE_DOUBLE_PRECISION - glVertexPointer(3, GL_FLOAT, sizeof(btVector3), &tmp[0].x()); -#else - glVertexPointer(3, GL_DOUBLE, sizeof(btVector3), &tmp[0].x()); -#endif - glDrawArrays(GL_LINES, 0, 2); - glDisableClientState(GL_VERTEX_ARRAY); - glColor4f(1.0f, 1.0f, 1.0f, 1.0f); - glEnable(GL_LIGHTING); -} - -void DrawTriangle(const btVector3& p0, const btVector3& p1, const btVector3& p2, const btVector3& color) -{ -// glDisable(GL_LIGHTING); - glColor4f(color.x(), color.y(), color.z(), 1.0f); - btVector3 tmp[] = {p0, p1, p2}; - glEnableClientState(GL_VERTEX_ARRAY); -#ifndef BT_USE_DOUBLE_PRECISION - glVertexPointer(3, GL_FLOAT, sizeof(btVector3), &tmp[0].x()); -#else - glVertexPointer(3, GL_DOUBLE, sizeof(btVector3), &tmp[0].x()); -#endif - glDrawArrays(GL_TRIANGLES, 0, 3); - glDisableClientState(GL_VERTEX_ARRAY); -// glColor4f(1.0f, 1.0f, 1.0f, 1.0f); -// glEnable(GL_LIGHTING); -} - -class MyPoly -{ - public: - MyPoly() : mNbVerts(0), mIndices(NULL) {} - ~MyPoly() { delete[]mIndices; } - - short mNbVerts; - char* mIndices; - float mPlane[4]; -}; - -class MyConvex -{ - public: - MyConvex(); - ~MyConvex(); - - bool LoadFromFile(const char* filename); - void Render(bool only_wireframe, const btVector3& wire_color) const; - void Project(const btVector3& dir, float& min, float& max) const; - - int mNbVerts; - btVector3* mVerts; - int mNbPolys; - MyPoly* mPolys; - btTransform mTransform; -}; - -MyConvex::MyConvex() : - mNbVerts (0), - mVerts (NULL), - mNbPolys (0), - mPolys (NULL) -{ - mTransform.setIdentity(); -} - -MyConvex::~MyConvex() -{ - delete[]mPolys; - delete[]mVerts; -} - -bool MyConvex::LoadFromFile(const char* filename) -{ - FILE* fp = fopen(filename, "rb"); - if(!fp) return false; - - fread(&mNbVerts, sizeof(int), 1, fp); - - int i; - - mVerts = new btVector3[mNbVerts]; - for( i=0;i max) max = dp; - } - if(min>max) - { - float tmp = min; - min = max; - max = tmp; - } -} - -static btVector3 gNormal; -static btVector3 gPoint; -static float gDepth; - - struct MyResult : public btDiscreteCollisionDetectorInterface::Result - { - virtual void setShapeIdentifiersA(int partId0, int index0) - { - } - virtual void setShapeIdentifiersB(int partId1, int index1) - { - } - - virtual void addContactPoint(const btVector3& normalOnBInWorld, const btVector3& pointInWorld, btScalar depth) - { - gNormal = normalOnBInWorld; - gPoint = pointInWorld; - gDepth = depth; - } - }; - - - -static bool TestEPA(const MyConvex& hull0, const MyConvex& hull1) -{ - static btSimplexSolverInterface simplexSolver; -#ifdef COMPARE_WITH_SOLID35_AND_OTHER_EPA -// static Solid3JohnsonSimplexSolver simplexSolver2; -#endif //COMPARE_WITH_SOLID35_AND_OTHER_EPA - - simplexSolver.reset(); - - btConvexHullShape convexA((btScalar*)hull0.mVerts, hull0.mNbVerts, sizeof(btVector3)); - btConvexHullShape convexB((btScalar*)hull1.mVerts, hull1.mNbVerts, sizeof(btVector3)); - - static btGjkEpaPenetrationDepthSolver Solver0; - static btMinkowskiPenetrationDepthSolver Solver1; - -#ifdef COMPARE_WITH_SOLID35_AND_OTHER_EPA - static Solid3EpaPenetrationDepth Solver2; - static EpaPenetrationDepthSolver Solver3; -#endif - - - btConvexPenetrationDepthSolver* Solver = NULL ; - if(gMethod==0) - Solver = &Solver0; - else if(gMethod==1) - Solver = &Solver1; -#ifdef COMPARE_WITH_SOLID35_AND_OTHER_EPA - else if(gMethod==2) - Solver = &Solver2; - else - Solver = &Solver3; -#endif //COMPARE_WITH_SOLID35_AND_OTHER_EPA - - -#ifdef USE_ORIGINAL - - btGjkPairDetector GJK(&convexA, &convexB, &simplexSolver, Solver); - GJK.m_catchDegeneracies = 1; - convexA.setMargin(0.01f); - convexB.setMargin(0.01f); - - btDiscreteCollisionDetectorInterface::ClosestPointInput input; - input.m_transformA = hull0.mTransform; - input.m_transformB = hull1.mTransform; - - - MyResult output; - GJK.getClosestPoints(input, output, 0); - gLastUsedMethod = GJK.m_lastUsedMethod; - gNumGjkIterations = GJK.m_curIter; - gLastDegenerateSimplex= GJK.m_degenerateSimplex; -#else - MyResult output; - btVector3 witnesses[2]; - btVector3 normal; - btScalar depth; - - btGjkEpaSolver::sResults results; - btScalar radialMargin = 0.01f; - - btGjkEpaSolver::Collide(&convexA,hull0.mTransform, - &convexB,hull1.mTransform, - radialMargin, - results); - if (results.depth>0) - { - output.addContactPoint(results.normal,results.witnesses[1],-results.depth); - } -#endif - return true; -} - -static bool TestSepAxis(const btVector3& sep_axis, const MyConvex& hull0, const MyConvex& hull1, float& depth) -{ - float Min0,Max0; - float Min1,Max1; - hull0.Project(sep_axis, Min0, Max0); - hull1.Project(sep_axis, Min1, Max1); - - if(Max0=0.0f); - float d1 = Max1 - Min0; - btAssert(d1>=0.0f); - depth = d01e-6 || fabsf(v.y())>1e-6 || fabsf(v.z())>1e-6) return false; - return true; -} - -static bool ReferenceCode(const MyConvex& hull0, const MyConvex& hull1, float& dmin, btVector3& sep) -{ - dmin = FLT_MAX; - - int i; - - // Test normals from hull0 - for( i=0;i0.0f) sep = -sep; - - return true; -} - - - -static MyConvex gConvex0; -static MyConvex gConvex1; - -static void KeyboardCallback(unsigned char key, int x, int y) -{ - switch (key) - { - case 27: exit(0); break; - - case 'R': - case 'r': - gRefMode = !gRefMode; - break; - - case ' ': - gMethod++; -#ifdef COMPARE_WITH_SOLID35_AND_OTHER_EPA - if(gMethod==4) gMethod=0; -#else - if(gMethod==2) gMethod=0; -#endif - break; - - case '4': - gConvex0.mTransform.setOrigin(gConvex0.mTransform.getOrigin() + btVector3(-gDisp,0,0)); - break; - case '7': - gConvex0.mTransform.setRotation(gConvex0.mTransform.getRotation()*btQuaternion(btVector3(1,0,0),0.01)); - break; - case '9': - gConvex0.mTransform.setRotation(gConvex0.mTransform.getRotation()*btQuaternion(btVector3(1,0,0),-0.01)); - break; - case '1': - gConvex0.mTransform.setRotation(gConvex0.mTransform.getRotation()*btQuaternion(btVector3(0,1,0),0.01)); - break; - case '3': - gConvex0.mTransform.setRotation(gConvex0.mTransform.getRotation()*btQuaternion(btVector3(0,1,0),-0.01)); - break; - case '5': - gConvex0.mTransform.setRotation(gConvex0.mTransform.getRotation()*btQuaternion(btVector3(0,0,1),0.01)); - break; - - case '6': - gConvex0.mTransform.setOrigin(gConvex0.mTransform.getOrigin() + btVector3(gDisp,0,0)); - break; - case '8': - gConvex0.mTransform.setOrigin(gConvex0.mTransform.getOrigin() + btVector3(0,gDisp,0)); - break; - case '2': - gConvex0.mTransform.setOrigin(gConvex0.mTransform.getOrigin() + btVector3(0,-gDisp,0)); - break; - - case 101: Eye += Dir * gCamSpeed; break; - case 103: Eye -= Dir * gCamSpeed; break; - case 100: Eye -= N * gCamSpeed; break; - case 102: Eye += N * gCamSpeed; break; - } -} - -static void ArrowKeyCallback(int key, int x, int y) -{ - KeyboardCallback(key,x,y); -} - -static void MouseCallback(int button, int state, int x, int y) -{ - mx = x; - my = y; -} - -static const float NxPiF32 = 3.141592653589793f; - -float degToRad(float a) - { - return (float)0.01745329251994329547 * a; - } - -class NxQuat - { - public: - NxQuat(){} - - NxQuat(const float angle, const btVector3 & axis) - { - x = axis.x(); - y = axis.y(); - z = axis.z(); - - const float i_length = 1.0f / sqrtf( x*x + y*y + z*z ); - x = x * i_length; - y = y * i_length; - z = z * i_length; - - float Half = degToRad(angle * 0.5f); - - w = cosf(Half); - const float sin_theta_over_two = sinf(Half ); - x = x * sin_theta_over_two; - y = y * sin_theta_over_two; - z = z * sin_theta_over_two; - } - - void multiply(const NxQuat& left, const btVector3& right) - { - float a,b,c,d; - - a = - left.x*right.x() - left.y*right.y() - left.z *right.z(); - b = left.w*right.x() + left.y*right.z() - right.y()*left.z; - c = left.w*right.y() + left.z*right.x() - right.z()*left.x; - d = left.w*right.z() + left.x*right.y() - right.x()*left.y; - - w = a; - x = b; - y = c; - z = d; - } - - void rotate(btVector3 & v) const - { - NxQuat myInverse; - myInverse.x = -x; - myInverse.y = -y; - myInverse.z = -z; - myInverse.w = w; - - NxQuat left; - left.multiply(*this,v); - float vx = left.w*myInverse.x + myInverse.w*left.x + left.y*myInverse.z - myInverse.y*left.z; - float vy = left.w*myInverse.y + myInverse.w*left.y + left.z*myInverse.x - myInverse.z*left.x; - float vz = left.w*myInverse.z + myInverse.w*left.z + left.x*myInverse.y - myInverse.x*left.y; - v.setValue(vx, vy, vz); - } - - float x,y,z,w; -}; - - -static void MotionCallback(int x, int y) -{ - int dx = mx - x; - int dy = my - y; - - Dir = Dir.normalize(); - N = Dir.cross(btVector3(0,1,0)); - - NxQuat qx(NxPiF32 * dx * 20/ 180.0f, btVector3(0,1,0)); - qx.rotate(Dir); - NxQuat qy(NxPiF32 * dy * 20/ 180.0f, N); - qy.rotate(Dir); - - mx = x; - my = y; -} - -static void RenderCallback() -{ - // Clear buffers - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - // Setup camera - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - gluPerspective(60.0f, ((float)glutGet(GLUT_WINDOW_WIDTH))/((float)glutGet(GLUT_WINDOW_HEIGHT)), 1.0f, 10000.0f); - gluLookAt(Eye.x(), Eye.y(), Eye.z(), Eye.x() + Dir.x(), Eye.y() + Dir.y(), Eye.z() + Dir.z(), 0.0f, 1.0f, 0.0f); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - - glEnable(GL_LIGHTING); - - //clear previous frames result - gNormal.setValue(10,0,0); - gPoint.setValue(0,0,0); - gDepth = 999.999; - gLastUsedMethod = -1; - gNumGjkIterations = -1; - - - TestEPA(gConvex0, gConvex1); - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - - btVector3 RefSep(btScalar(0.), btScalar(0.), btScalar(0.)); - float RefDMin=0.f; - bool RefResult = false; - if(gRefMode) - RefResult = ReferenceCode(gConvex0, gConvex1, RefDMin, RefSep); - -// DrawLine(gPoint, gPoint + gNormal*20.0f, btVector3(1,0,0), 2.0f); -// printf("%f: %f %f %f\n", gDepth, gNormal.x(), gNormal.y(), gNormal.z()); - -#ifdef VERBOSE_TEXT_ONSCREEN - glColor3f(255.f, 255.f, 255.f); - - setOrthographicProjection(); - float xOffset = 10.f; - float yStart = 20.f; - float yIncr = 20.f; - char buf[124]; - - sprintf(buf,"gDepth=%f: gNormal=(%f %f %f)\n", gDepth, gNormal.x(), gNormal.y(), gNormal.z()); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - sprintf(buf,"num GJK iterations =%d\n", gNumGjkIterations); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - sprintf(buf,"gLastUsedMethod=%d\n", gLastUsedMethod); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - - - - - if (gLastUsedMethod >= 3) - { - switch ( gMethod) - { - case 0: - sprintf(buf,"Bullet GjkEpa Penetration depth solver (zlib free\n" ); - break; - case 1: - sprintf(buf,"Bullet Minkowski sampling Penetration depth solver\n" ); - break; - case 2: - sprintf(buf,"Solid35 EPA Penetration depth solver\n" ); - break; - case 3: - sprintf(buf,"EPA Penetration depth solver (Experimental/WorkInProgress, zlib free\n" ); - break; - default: - sprintf(buf,"Unknown Penetration Depth\n" ); - } - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - } else - { - sprintf(buf,"Hybrid GJK method %d\n", gLastUsedMethod); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - } - - if (gLastDegenerateSimplex) - { - sprintf(buf,"DegenerateSimplex %d\n", gLastDegenerateSimplex); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - } - - - - - resetPerspectiveProjection(); -#endif //VERBOSE_TEXT_ONSCREEN - - btVector3 color(0,0,0); - gConvex0.Render(false, color); - gConvex1.Render(false, color); - - if(gDepth<0.0f) - { - btTransform Saved = gConvex0.mTransform; - gConvex0.mTransform.setOrigin(gConvex0.mTransform.getOrigin() - btVector3(gNormal*gDepth)); - gConvex0.Render(true, btVector3(1.0f, 0.5f, 0.0f)); - gConvex0.mTransform = Saved; - } - else - { - DrawLine(gPoint, gPoint + gNormal, btVector3(0,1,0), 2.0f); - } - - if(RefResult & gRefMode) - { - btTransform Saved = gConvex0.mTransform; - gConvex0.mTransform.setOrigin(gConvex0.mTransform.getOrigin() + btVector3(RefSep*RefDMin)); - gConvex0.Render(true, btVector3(0.0f, 0.5f, 1.0f)); - gConvex0.mTransform = Saved; - } - - glutSwapBuffers(); -} - -static void ReshapeCallback(int width, int height) -{ - glViewport(0, 0, width, height); -} - -static void IdleCallback() -{ - glutPostRedisplay(); -} - -int main(int argc, char** argv) -{ - // Initialize Glut - glutInit(&argc, argv); - glutInitWindowSize(glutScreenWidth, glutScreenHeight); - glutInitDisplayMode(GLUT_RGB | GLUT_DOUBLE | GLUT_DEPTH); - int mainHandle = glutCreateWindow("TestBullet"); - glutSetWindow(mainHandle); - glutDisplayFunc(RenderCallback); - glutReshapeFunc(ReshapeCallback); - glutIdleFunc(IdleCallback); - glutKeyboardFunc(KeyboardCallback); - glutSpecialFunc(ArrowKeyCallback); - glutMouseFunc(MouseCallback); - glutMotionFunc(MotionCallback); - MotionCallback(0,0); - - // Setup default render states - glClearColor(0.3f, 0.4f, 0.5f, 1.0); - glEnable(GL_DEPTH_TEST); - glEnable(GL_COLOR_MATERIAL); - glEnable(GL_CULL_FACE); - - // Setup lighting - glEnable(GL_LIGHTING); - float AmbientColor[] = { 0.0f, 0.1f, 0.2f, 0.0f }; glLightfv(GL_LIGHT0, GL_AMBIENT, AmbientColor); - float DiffuseColor[] = { 1.0f, 1.0f, 1.0f, 0.0f }; glLightfv(GL_LIGHT0, GL_DIFFUSE, DiffuseColor); - float SpecularColor[] = { 0.0f, 0.0f, 0.0f, 0.0f }; glLightfv(GL_LIGHT0, GL_SPECULAR, SpecularColor); - float Position[] = { -10.0f, 1000.0f, -4.0f, 1.0f }; glLightfv(GL_LIGHT0, GL_POSITION, Position); - glEnable(GL_LIGHT0); - - // - bool Status = gConvex0.LoadFromFile("convex0.bin"); - if(!Status) - { - Status = gConvex0.LoadFromFile("../../convex0.bin"); - if(!Status) - { - printf("Failed to load object!\n"); - exit(0); - } - } - Status = gConvex1.LoadFromFile("convex0.bin"); - if(!Status) - { - Status = gConvex1.LoadFromFile("../../convex0.bin"); - if(!Status) - { - printf("Failed to load object!\n"); - exit(0); - } - } - -// gConvex0.mTransform.setOrigin(btVector3(1.0f, 1.0f, 0.0f)); - gConvex0.mTransform.setOrigin(btVector3(0.20000069f, 0.95000005f, 0.0f)); - - // Run - glutMainLoop(); - - return 0; -} diff --git a/Demos/FeatherstoneMultiBodyDemo/CMakeLists.txt b/Demos/FeatherstoneMultiBodyDemo/CMakeLists.txt deleted file mode 100644 index cb8c544a7..000000000 --- a/Demos/FeatherstoneMultiBodyDemo/CMakeLists.txt +++ /dev/null @@ -1,70 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppFeatherstoneMultiBodyDemo - main.cpp - FeatherstoneMultiBodyDemo.cpp - FeatherstoneMultiBodyDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppFeatherstoneMultiBodyDemo - main.cpp - FeatherstoneMultiBodyDemo.cpp - FeatherstoneMultiBodyDemo.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppFeatherstoneMultiBodyDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32FeatherstoneMultiBodyDemo.cpp - FeatherstoneMultiBodyDemo.cpp - FeatherstoneMultiBodyDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/FeatherstoneMultiBodyDemo/FeatherstoneMultiBodyDemo.cpp b/Demos/FeatherstoneMultiBodyDemo/FeatherstoneMultiBodyDemo.cpp deleted file mode 100644 index 720054914..000000000 --- a/Demos/FeatherstoneMultiBodyDemo/FeatherstoneMultiBodyDemo.cpp +++ /dev/null @@ -1,575 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2013 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///experimental support for Featherstone multi body (articulated hierarchies) - - -///create 125 (5x5x5) dynamic object -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 -float friction = 1.; - - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - - -#define START_POS_X -5 -//#define START_POS_Y 12 -#define START_POS_Y 2 -#define START_POS_Z -3 - -#include "FeatherstoneMultiBodyDemo.h" - -#include "BulletDynamics/Featherstone/btMultiBody.h" -#include "BulletDynamics/Featherstone/btMultiBodyConstraintSolver.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/Featherstone/btMultiBodyLink.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointLimitConstraint.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointMotor.h" -#include "BulletDynamics/Featherstone/btMultiBodyPoint2Point.h" - - -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" - -#include //printf debugging -#include "GLDebugDrawer.h" -#include "LinearMath/btAabbUtil2.h" - -static GLDebugDrawer gDebugDraw; -//btVector3 scaling(0.1,0.1,0.1); -float scaling = 0.4f; - - -void FeatherstoneMultiBodyDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - btVector3 aabbMin(1,1,1); - btVector3 aabbMax(2,2,2); - - - } - - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void FeatherstoneMultiBodyDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - - - - -void FeatherstoneMultiBodyDemo::initPhysics() -{ - //m_idle=true; - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(100.*scaling)); - this->m_azi = 130; - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - //Use the btMultiBodyConstraintSolver for Featherstone btMultiBody support - btMultiBodyConstraintSolver* sol = new btMultiBodyConstraintSolver; - m_solver = sol; - - //use btMultiBodyDynamicsWorld for Featherstone btMultiBody support - btMultiBodyDynamicsWorld* world = new btMultiBodyDynamicsWorld(m_dispatcher,m_broadphase,sol,m_collisionConfiguration); - m_dynamicsWorld = world; - m_dynamicsWorld->setDebugDrawer(&gDebugDraw); - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); - //groundShape->initializePolyhedralFeatures(); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,00)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - if (1) - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btBoxShape* colShape = new btBoxShape(btVector3(1,1,1)); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - float start_x = START_POS_X - ARRAY_SIZE_X/2; - float start_y = START_POS_Y; - float start_z = START_POS_Z - ARRAY_SIZE_Z/2; - - for (int k=0;kaddRigidBody(body);//,1,1+2); - } - } - } - } - - btMultiBodySettings settings; - settings.m_numLinks = 2; - settings.m_basePosition = btVector3 (60,29.5,-2)*scaling; - settings.m_isFixedBase = false; - settings.m_disableParentCollision = true;//the self-collision has conflicting/non-resolvable contact normals - - settings.m_usePrismatic = true; - settings.m_canSleep = true; - settings.m_createConstraints = true; - - //btMultiBody* createFeatherstoneMultiBody(class btMultiBodyDynamicsWorld* world, int numLinks, const btVector3& basePosition,bool isFixedBase, bool usePrismatic, bool canSleep, bool createConstraints); - - btMultiBody* mbA = createFeatherstoneMultiBody(world, settings); - - settings.m_numLinks = 10; - settings.m_basePosition = btVector3 (0,29.5,-settings.m_numLinks*4.f); - settings.m_isFixedBase = true; - settings.m_usePrismatic = false; - - btMultiBody* mbB = createFeatherstoneMultiBody(world, settings); - settings.m_basePosition = btVector3 (-20*scaling,29.5*scaling,-settings.m_numLinks*4.f*scaling); - settings.m_isFixedBase = false; - btMultiBody* mbC = createFeatherstoneMultiBody(world, settings); - - settings.m_basePosition = btVector3 (-20,9.5,-settings.m_numLinks*4.f); - settings.m_isFixedBase = true; - settings.m_usePrismatic = true; - settings.m_disableParentCollision = true; - - btMultiBody* mbPrim= createFeatherstoneMultiBody(world, settings); - - //btMultiBody* mbB = createFeatherstoneMultiBody(world, 15, btVector3 (0,29.5,-2), false,true,true); -#if 0 - if (0)//!useGroundShape && i==4) - { - //attach two multibody using a point2point constraint - - //btVector3 pivotInAworld(0,20,46); - btVector3 pivotInAworld(-0.3,29,-3.5); - - int linkA = -1; - int linkB = -1; - - btVector3 pivotInAlocal = mbA->worldPosToLocal(linkA, pivotInAworld); - btVector3 pivotInBlocal = mbB->worldPosToLocal(linkB, pivotInAworld); - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(mbA,linkA,mbB,linkB,pivotInAlocal,pivotInBlocal); - world->addMultiBodyConstraint(p2p); - } -#endif - bool testRemoveLinks = false; - if (testRemoveLinks) - { - while (mbA->getNumLinks()) - { - btCollisionObject* col = mbA->getLink(mbA->getNumLinks()-1).m_collider; - m_dynamicsWorld->removeCollisionObject(col); - delete col; - mbA->setNumLinks(mbA->getNumLinks()-1); - } - } - - if (1)//useGroundShape - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body,1,1+2);//,1,1+2); - } - - -} - -btMultiBody* FeatherstoneMultiBodyDemo::createFeatherstoneMultiBody(class btMultiBodyDynamicsWorld* world, const btMultiBodySettings& settings) -{ - - int n_links = settings.m_numLinks; - float mass = 13.5*scaling; - btVector3 inertia = btVector3 (91,344,253)*scaling*scaling; - - - bool multiDof = false; - btMultiBody * bod = new btMultiBody(n_links, mass, inertia, settings.m_isFixedBase, settings.m_canSleep,multiDof); -// bod->setHasSelfCollision(false); - - //btQuaternion orn(btVector3(0,0,1),-0.25*SIMD_HALF_PI);//0,0,0,1); - btQuaternion orn(0,0,0,1); - bod->setBasePos(settings.m_basePosition); - bod->setWorldToBaseRot(orn); - btVector3 vel(0,0,0); - bod->setBaseVel(vel); - - { - - btVector3 joint_axis_hinge(1,0,0); - btVector3 joint_axis_prismatic(0,0,1); - btQuaternion parent_to_child = orn.inverse(); - btVector3 joint_axis_child_prismatic = quatRotate(parent_to_child ,joint_axis_prismatic); - btVector3 joint_axis_child_hinge = quatRotate(parent_to_child , joint_axis_hinge); - - int this_link_num = -1; - int link_num_counter = 0; - - - - btVector3 pos = btVector3 (0,0,9.0500002)*scaling; - - btVector3 joint_axis_position = btVector3 (0,0,4.5250001)*scaling; - - for (int i=0;i0) - initial_joint_angle = -0.06f; - - const int child_link_num = link_num_counter++; - - - - if (settings.m_usePrismatic)// && i==(n_links-1)) - { - bod->setupPrismatic(child_link_num, mass, inertia, this_link_num, - parent_to_child, joint_axis_child_prismatic, quatRotate(parent_to_child , pos),btVector3(0,0,0),settings.m_disableParentCollision); - - } else - { - bod->setupRevolute(child_link_num, mass, inertia, this_link_num,parent_to_child, joint_axis_child_hinge, - joint_axis_position,quatRotate(parent_to_child , (pos - joint_axis_position)),settings.m_disableParentCollision); - } - bod->setJointPos(child_link_num, initial_joint_angle); - this_link_num = i; - - if (0)//!useGroundShape && i==4) - { - btVector3 pivotInAworld(0,20,46); - btVector3 pivotInAlocal = bod->worldPosToLocal(i, pivotInAworld); - btVector3 pivotInBworld = pivotInAworld; - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(bod,i,&btTypedConstraint::getFixedBody(),pivotInAlocal,pivotInBworld); - world->addMultiBodyConstraint(p2p); - } - //add some constraint limit - if (settings.m_usePrismatic) - { - // btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,n_links-1,2,3); - - if (settings.m_createConstraints) - { - btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,i,-1,1); - world->addMultiBodyConstraint(con); - } - - } else - { - if (settings.m_createConstraints) - { - if (1) - { - btMultiBodyJointMotor* con = new btMultiBodyJointMotor(bod,i,0,0,500000); - world->addMultiBodyConstraint(con); - } - - btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,i,-1,1); - world->addMultiBodyConstraint(con); - } - - } - } - } - - //add a collider for the base - { - - btAlignedObjectArray world_to_local; - world_to_local.resize(n_links+1); - - btAlignedObjectArray local_origin; - local_origin.resize(n_links+1); - world_to_local[0] = bod->getWorldToBaseRot(); - local_origin[0] = bod->getBasePos(); - //float halfExtents[3]={7.5,0.05,4.5}; - float halfExtents[3]={7.5,0.45,4.5}; - { - - float pos[4]={local_origin[0].x(),local_origin[0].y(),local_origin[0].z(),1}; - float quat[4]={-world_to_local[0].x(),-world_to_local[0].y(),-world_to_local[0].z(),world_to_local[0].w()}; - - - if (1) - { - btCollisionShape* box = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])*scaling); - btMultiBodyLinkCollider* col= new btMultiBodyLinkCollider(bod,-1); - col->setCollisionShape(box); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(local_origin[0]); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - world->addCollisionObject(col, 2,1+2); - col->setFriction(friction); - bod->setBaseCollider(col); - } - } - - - for (int i=0;igetNumLinks();i++) - { - const int parent = bod->getParent(i); - world_to_local[i+1] = bod->getParentToLocalRot(i) * world_to_local[parent+1]; - local_origin[i+1] = local_origin[parent+1] + (quatRotate(world_to_local[i+1].inverse() , bod->getRVector(i))); - } - - - for (int i=0;igetNumLinks();i++) - { - - btVector3 posr = local_origin[i+1]; - float pos[4]={posr.x(),posr.y(),posr.z(),1}; - - float quat[4]={-world_to_local[i+1].x(),-world_to_local[i+1].y(),-world_to_local[i+1].z(),world_to_local[i+1].w()}; - - btCollisionShape* box = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])*scaling); - btMultiBodyLinkCollider* col = new btMultiBodyLinkCollider(bod,i); - - col->setCollisionShape(box); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(posr); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - col->setFriction(friction); - world->addCollisionObject(col,2,1+2); - - bod->getLink(i).m_collider=col; - //app->drawBox(halfExtents, pos,quat); - } - - } - - - world->addMultiBody(bod); - - return bod; -} - -extern btScalar gOldPickingDist; -void FeatherstoneMultiBodyDemo::mouseMotionFunc(int x,int y) -{ - if (m_pickingMultiBodyPoint2Point) - { - //keep it at the same picking distance - - btVector3 newRayTo = getRayTo(x,y); - btVector3 rayFrom; - btVector3 oldPivotInB = m_pickingMultiBodyPoint2Point->getPivotInB(); - btVector3 newPivotB; - if (m_ortho) - { - newPivotB = oldPivotInB; - newPivotB.setX(newRayTo.getX()); - newPivotB.setY(newRayTo.getY()); - } else - { - rayFrom = m_cameraPosition; - btVector3 dir = newRayTo-rayFrom; - dir.normalize(); - dir *= gOldPickingDist; - - newPivotB = rayFrom + dir; - } - m_pickingMultiBodyPoint2Point->setPivotInB(newPivotB); - } - DemoApplication::mouseMotionFunc(x,y); -} - -void FeatherstoneMultiBodyDemo::removePickingConstraint() -{ - if (m_pickingMultiBodyPoint2Point) - { - m_pickingMultiBodyPoint2Point->getMultiBodyA()->setCanSleep(true); - - btMultiBodyDynamicsWorld* world = (btMultiBodyDynamicsWorld*) m_dynamicsWorld; - world->removeMultiBodyConstraint(m_pickingMultiBodyPoint2Point); - delete m_pickingMultiBodyPoint2Point; - m_pickingMultiBodyPoint2Point = 0; - } - - DemoApplication::removePickingConstraint(); - -} - -void FeatherstoneMultiBodyDemo::pickObject(const btVector3& pickPos, const class btCollisionObject* hitObj) -{ - btVector3 pivotInA(0,0,0); - btMultiBodyLinkCollider* multiCol = (btMultiBodyLinkCollider*)btMultiBodyLinkCollider::upcast(hitObj); - if (multiCol && multiCol->m_multiBody) - { - multiCol->m_multiBody->setCanSleep(false); - - btVector3 pivotInA = multiCol->m_multiBody->worldPosToLocal(multiCol->m_link, pickPos); - - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(multiCol->m_multiBody,multiCol->m_link,0,pivotInA,pickPos); - //if you add too much energy to the system, causing high angular velocities, simulation 'explodes' - //see also http://www.bulletphysics.org/Bullet/phpBB3/viewtopic.php?f=4&t=949 - //so we try to avoid it by clamping the maximum impulse (force) that the mouse pick can apply - //it is not satisfying, hopefully we find a better solution (higher order integrator, using joint friction using a zero-velocity target motor with limited force etc?) - - p2p->setMaxAppliedImpulse(200*scaling); - - btMultiBodyDynamicsWorld* world = (btMultiBodyDynamicsWorld*) m_dynamicsWorld; - world->addMultiBodyConstraint(p2p); - m_pickingMultiBodyPoint2Point =p2p; - } else - { - DemoApplication::pickObject(pickPos,hitObj); - } -} - - - -void FeatherstoneMultiBodyDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void FeatherstoneMultiBodyDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - virtual void mouseMotionFunc(int x,int y); - virtual void removePickingConstraint(); - virtual void pickObject(const btVector3& pickPos, const class btCollisionObject* hitObj); - class btMultiBodyPoint2Point* m_pickingMultiBodyPoint2Point; - - btMultiBody* createFeatherstoneMultiBody(class btMultiBodyDynamicsWorld* world, const btMultiBodySettings& settings); - - public: - - FeatherstoneMultiBodyDemo() - :m_pickingMultiBodyPoint2Point(0) - { - } - virtual ~FeatherstoneMultiBodyDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - virtual void clientResetScene(); - - static DemoApplication* Create() - { - FeatherstoneMultiBodyDemo* demo = new FeatherstoneMultiBodyDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //FEATHERSTONE_MULTIBODY_DEMO_H - diff --git a/Demos/FeatherstoneMultiBodyDemo/Makefile.am b/Demos/FeatherstoneMultiBodyDemo/Makefile.am deleted file mode 100644 index 00e92e685..000000000 --- a/Demos/FeatherstoneMultiBodyDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=FeatherstoneMultiBodyDemo - -FeatherstoneMultiBodyDemo_SOURCES=FeatherstoneMultiBodyDemo.cpp FeatherstoneMultiBodyDemo.h main.cpp -FeatherstoneMultiBodyDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -FeatherstoneMultiBodyDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/FeatherstoneMultiBodyDemo/Win32FeatherstoneMultiBodyDemo.cpp b/Demos/FeatherstoneMultiBodyDemo/Win32FeatherstoneMultiBodyDemo.cpp deleted file mode 100644 index 2b287c698..000000000 --- a/Demos/FeatherstoneMultiBodyDemo/Win32FeatherstoneMultiBodyDemo.cpp +++ /dev/null @@ -1,28 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2013 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///experimental support for Featherstone multi body (articulated hierarchies) - - -#include "FeatherstoneMultiBodyDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new FeatherstoneMultiBodyDemo(); -} - -#endif diff --git a/Demos/FeatherstoneMultiBodyDemo/main.cpp b/Demos/FeatherstoneMultiBodyDemo/main.cpp deleted file mode 100644 index d72c107be..000000000 --- a/Demos/FeatherstoneMultiBodyDemo/main.cpp +++ /dev/null @@ -1,42 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2013 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///experimental support for Featherstone multi body (articulated hierarchies) - - -#include "FeatherstoneMultiBodyDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - - -int main(int argc,char** argv) -{ - - FeatherstoneMultiBodyDemo demo; - demo.initPhysics(); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&demo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/ForkLiftDemo/CMakeLists.txt b/Demos/ForkLiftDemo/CMakeLists.txt deleted file mode 100644 index d4f067710..000000000 --- a/Demos/ForkLiftDemo/CMakeLists.txt +++ /dev/null @@ -1,44 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - ADD_EXECUTABLE(AppForkLiftDemo - ForkLiftDemo.cpp - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ELSE() - ADD_EXECUTABLE(AppForkLiftDemo - ForkLiftDemo.cpp - main.cpp - ) -ENDIF() - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppForkLiftDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppForkLiftDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppForkLiftDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/ForkLiftDemo/ForkLiftDemo.cpp b/Demos/ForkLiftDemo/ForkLiftDemo.cpp deleted file mode 100644 index dec0633d8..000000000 --- a/Demos/ForkLiftDemo/ForkLiftDemo.cpp +++ /dev/null @@ -1,973 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///September 2006: VehicleDemo is work in progress, this file is mostly just a placeholder -///This VehicleDemo file is very early in development, please check it later -///@todo is a basic engine model: -///A function that maps user input (throttle) into torque/force applied on the wheels -///with gears etc. -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h" -#include "GLDebugFont.h" - -#include "BulletDynamics/MLCPSolvers/btDantzigSolver.h" -#include "BulletDynamics/MLCPSolvers/btSolveProjectedGaussSeidel.h" -#include "BulletDynamics/MLCPSolvers/btMLCPSolver.h" - - -btScalar maxMotorImpulse = 1400.f; - -//the sequential impulse solver has difficulties dealing with large mass ratios (differences), between loadMass and the fork parts -btScalar loadMass = 350.f;// -//btScalar loadMass = 10.f;//this should work fine for the SI solver - - -#ifndef M_PI -#define M_PI 3.14159265358979323846 -#endif - -#ifndef M_PI_2 -#define M_PI_2 1.57079632679489661923 -#endif - -#ifndef M_PI_4 -#define M_PI_4 0.785398163397448309616 -#endif - -//#define LIFT_EPS 0.0000001f -// -// By default, Bullet Vehicle uses Y as up axis. -// You can override the up axis, for example Z-axis up. Enable this define to see how to: -//#define FORCE_ZAXIS_UP 1 -// - -#ifdef FORCE_ZAXIS_UP - int rightIndex = 0; - int upIndex = 2; - int forwardIndex = 1; - btVector3 wheelDirectionCS0(0,0,-1); - btVector3 wheelAxleCS(1,0,0); -#else - int rightIndex = 0; - int upIndex = 1; - int forwardIndex = 2; - btVector3 wheelDirectionCS0(0,-1,0); - btVector3 wheelAxleCS(-1,0,0); -#endif - -bool useMCLPSolver = true; - -#include "GLDebugDrawer.h" -#include //printf debugging - -#include "GL_ShapeDrawer.h" - -#include "GlutStuff.h" -#include "ForkLiftDemo.h" - - -const int maxProxies = 32766; -const int maxOverlap = 65535; - -///btRaycastVehicle is the interface for the constraint that implements the raycast vehicle -///notice that for higher-quality slow-moving vehicles, another approach might be better -///implementing explicit hinged-wheel constraints with cylinder collision, rather then raycasts -float gEngineForce = 0.f; - -float defaultBreakingForce = 10.f; -float gBreakingForce = 100.f; - -float maxEngineForce = 1000.f;//this should be engine/velocity dependent -float maxBreakingForce = 100.f; - -float gVehicleSteering = 0.f; -float steeringIncrement = 0.04f; -float steeringClamp = 0.3f; -float wheelRadius = 0.5f; -float wheelWidth = 0.4f; -float wheelFriction = 1000;//BT_LARGE_FLOAT; -float suspensionStiffness = 20.f; -float suspensionDamping = 2.3f; -float suspensionCompression = 4.4f; -float rollInfluence = 0.1f;//1.0f; - - -btScalar suspensionRestLength(0.6); - -#define CUBE_HALF_EXTENTS 1 - - - -//////////////////////////////////// - - - - -ForkLiftDemo::ForkLiftDemo() -: -m_carChassis(0), -m_liftBody(0), -m_forkBody(0), -m_loadBody(0), -m_indexVertexArrays(0), -m_vertices(0), -m_cameraHeight(4.f), -m_minCameraDistance(3.f), -m_maxCameraDistance(10.f) -{ - m_vehicle = 0; - m_wheelShape = 0; - m_cameraPosition = btVector3(30,30,30); - m_useDefaultCamera = false; - setTexturing(true); - setShadows(true); - -} - - -void ForkLiftDemo::exitPhysics() -{ - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - - while (body->getNumConstraintRefs()) - { - btTypedConstraint* constraint = body->getConstraintRef(0); - m_dynamicsWorld->removeConstraint(constraint); - delete constraint; - } - delete body->getMotionState(); - m_dynamicsWorld->removeRigidBody(body); - } else - { - m_dynamicsWorld->removeCollisionObject( obj ); - } - delete obj; - } - - //delete collision shapes - for (int j=0;jgetSolverInfo().m_minimumSolverBatchSize = 1;//for direct solver it is better to have a small A matrix - } else - { - m_dynamicsWorld ->getSolverInfo().m_minimumSolverBatchSize = 128;//for direct solver, it is better to solve multiple objects together, small batches have high overhead - } -#ifdef FORCE_ZAXIS_UP - m_dynamicsWorld->setGravity(btVector3(0,0,-10)); -#endif - - //m_dynamicsWorld->setGravity(btVector3(0,0,0)); -btTransform tr; -tr.setIdentity(); -tr.setOrigin(btVector3(0,-3,0)); - -//either use heightfield or triangle mesh - - - //create ground object - localCreateRigidBody(0,tr,groundShape); - -#ifdef FORCE_ZAXIS_UP -// indexRightAxis = 0; -// indexUpAxis = 2; -// indexForwardAxis = 1; - btCollisionShape* chassisShape = new btBoxShape(btVector3(1.f,2.f, 0.5f)); - btCompoundShape* compound = new btCompoundShape(); - btTransform localTrans; - localTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - localTrans.setOrigin(btVector3(0,0,1)); -#else - btCollisionShape* chassisShape = new btBoxShape(btVector3(1.f,0.5f,2.f)); - m_collisionShapes.push_back(chassisShape); - - btCompoundShape* compound = new btCompoundShape(); - m_collisionShapes.push_back(compound); - btTransform localTrans; - localTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - localTrans.setOrigin(btVector3(0,1,0)); -#endif - - compound->addChildShape(localTrans,chassisShape); - - { - btCollisionShape* suppShape = new btBoxShape(btVector3(0.5f,0.1f,0.5f)); - btTransform suppLocalTrans; - suppLocalTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - suppLocalTrans.setOrigin(btVector3(0,1.0,2.5)); - compound->addChildShape(suppLocalTrans, suppShape); - } - - tr.setOrigin(btVector3(0,0.f,0)); - - m_carChassis = localCreateRigidBody(800,tr,compound);//chassisShape); - //m_carChassis->setDamping(0.2,0.2); - - m_wheelShape = new btCylinderShapeX(btVector3(wheelWidth,wheelRadius,wheelRadius)); - - { - btCollisionShape* liftShape = new btBoxShape(btVector3(0.5f,2.0f,0.05f)); - m_collisionShapes.push_back(liftShape); - btTransform liftTrans; - m_liftStartPos = btVector3(0.0f, 2.5f, 3.05f); - liftTrans.setIdentity(); - liftTrans.setOrigin(m_liftStartPos); - m_liftBody = localCreateRigidBody(10,liftTrans, liftShape); - - btTransform localA, localB; - localA.setIdentity(); - localB.setIdentity(); - localA.getBasis().setEulerZYX(0, M_PI_2, 0); - localA.setOrigin(btVector3(0.0, 1.0, 3.05)); - localB.getBasis().setEulerZYX(0, M_PI_2, 0); - localB.setOrigin(btVector3(0.0, -1.5, -0.05)); - m_liftHinge = new btHingeConstraint(*m_carChassis,*m_liftBody, localA, localB); -// m_liftHinge->setLimit(-LIFT_EPS, LIFT_EPS); - m_liftHinge->setLimit(0.0f, 0.0f); - m_dynamicsWorld->addConstraint(m_liftHinge, true); - - btCollisionShape* forkShapeA = new btBoxShape(btVector3(1.0f,0.1f,0.1f)); - m_collisionShapes.push_back(forkShapeA); - btCompoundShape* forkCompound = new btCompoundShape(); - m_collisionShapes.push_back(forkCompound); - btTransform forkLocalTrans; - forkLocalTrans.setIdentity(); - forkCompound->addChildShape(forkLocalTrans, forkShapeA); - - btCollisionShape* forkShapeB = new btBoxShape(btVector3(0.1f,0.02f,0.6f)); - m_collisionShapes.push_back(forkShapeB); - forkLocalTrans.setIdentity(); - forkLocalTrans.setOrigin(btVector3(-0.9f, -0.08f, 0.7f)); - forkCompound->addChildShape(forkLocalTrans, forkShapeB); - - btCollisionShape* forkShapeC = new btBoxShape(btVector3(0.1f,0.02f,0.6f)); - m_collisionShapes.push_back(forkShapeC); - forkLocalTrans.setIdentity(); - forkLocalTrans.setOrigin(btVector3(0.9f, -0.08f, 0.7f)); - forkCompound->addChildShape(forkLocalTrans, forkShapeC); - - btTransform forkTrans; - m_forkStartPos = btVector3(0.0f, 0.6f, 3.2f); - forkTrans.setIdentity(); - forkTrans.setOrigin(m_forkStartPos); - m_forkBody = localCreateRigidBody(5, forkTrans, forkCompound); - - localA.setIdentity(); - localB.setIdentity(); - localA.getBasis().setEulerZYX(0, 0, M_PI_2); - localA.setOrigin(btVector3(0.0f, -1.9f, 0.05f)); - localB.getBasis().setEulerZYX(0, 0, M_PI_2); - localB.setOrigin(btVector3(0.0, 0.0, -0.1)); - m_forkSlider = new btSliderConstraint(*m_liftBody, *m_forkBody, localA, localB, true); - m_forkSlider->setLowerLinLimit(0.1f); - m_forkSlider->setUpperLinLimit(0.1f); -// m_forkSlider->setLowerAngLimit(-LIFT_EPS); -// m_forkSlider->setUpperAngLimit(LIFT_EPS); - m_forkSlider->setLowerAngLimit(0.0f); - m_forkSlider->setUpperAngLimit(0.0f); - m_dynamicsWorld->addConstraint(m_forkSlider, true); - - - btCompoundShape* loadCompound = new btCompoundShape(); - m_collisionShapes.push_back(loadCompound); - btCollisionShape* loadShapeA = new btBoxShape(btVector3(2.0f,0.5f,0.5f)); - m_collisionShapes.push_back(loadShapeA); - btTransform loadTrans; - loadTrans.setIdentity(); - loadCompound->addChildShape(loadTrans, loadShapeA); - btCollisionShape* loadShapeB = new btBoxShape(btVector3(0.1f,1.0f,1.0f)); - m_collisionShapes.push_back(loadShapeB); - loadTrans.setIdentity(); - loadTrans.setOrigin(btVector3(2.1f, 0.0f, 0.0f)); - loadCompound->addChildShape(loadTrans, loadShapeB); - btCollisionShape* loadShapeC = new btBoxShape(btVector3(0.1f,1.0f,1.0f)); - m_collisionShapes.push_back(loadShapeC); - loadTrans.setIdentity(); - loadTrans.setOrigin(btVector3(-2.1f, 0.0f, 0.0f)); - loadCompound->addChildShape(loadTrans, loadShapeC); - loadTrans.setIdentity(); - m_loadStartPos = btVector3(0.0f, 3.5f, 7.0f); - loadTrans.setOrigin(m_loadStartPos); - m_loadBody = localCreateRigidBody(loadMass, loadTrans, loadCompound); - } - - - - - - /// create vehicle - { - - m_vehicleRayCaster = new btDefaultVehicleRaycaster(m_dynamicsWorld); - m_vehicle = new btRaycastVehicle(m_tuning,m_carChassis,m_vehicleRayCaster); - - ///never deactivate the vehicle - m_carChassis->setActivationState(DISABLE_DEACTIVATION); - - m_dynamicsWorld->addVehicle(m_vehicle); - - float connectionHeight = 1.2f; - - - bool isFrontWheel=true; - - //choose coordinate system - m_vehicle->setCoordinateSystem(rightIndex,upIndex,forwardIndex); - -#ifdef FORCE_ZAXIS_UP - btVector3 connectionPointCS0(CUBE_HALF_EXTENTS-(0.3*wheelWidth),2*CUBE_HALF_EXTENTS-wheelRadius, connectionHeight); -#else - btVector3 connectionPointCS0(CUBE_HALF_EXTENTS-(0.3*wheelWidth),connectionHeight,2*CUBE_HALF_EXTENTS-wheelRadius); -#endif - - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),2*CUBE_HALF_EXTENTS-wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),connectionHeight,2*CUBE_HALF_EXTENTS-wheelRadius); -#endif - - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),-2*CUBE_HALF_EXTENTS+wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),connectionHeight,-2*CUBE_HALF_EXTENTS+wheelRadius); -#endif //FORCE_ZAXIS_UP - isFrontWheel = false; - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(CUBE_HALF_EXTENTS-(0.3*wheelWidth),-2*CUBE_HALF_EXTENTS+wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(CUBE_HALF_EXTENTS-(0.3*wheelWidth),connectionHeight,-2*CUBE_HALF_EXTENTS+wheelRadius); -#endif - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); - - for (int i=0;igetNumWheels();i++) - { - btWheelInfo& wheel = m_vehicle->getWheelInfo(i); - wheel.m_suspensionStiffness = suspensionStiffness; - wheel.m_wheelsDampingRelaxation = suspensionDamping; - wheel.m_wheelsDampingCompression = suspensionCompression; - wheel.m_frictionSlip = wheelFriction; - wheel.m_rollInfluence = rollInfluence; - } - } - - resetForklift(); - - setCameraDistance(26.f); - -} - - -//to be implemented by the demo -void ForkLiftDemo::renderme() -{ - - updateCamera(); - - ATTRIBUTE_ALIGNED16(btScalar) m[16]; - int i; - - btVector3 wheelColor(1,0,0); - - btVector3 worldBoundsMin,worldBoundsMax; - getDynamicsWorld()->getBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax); - - - - for (i=0;igetNumWheels();i++) - { - //synchronize the wheels with the (interpolated) chassis worldtransform - m_vehicle->updateWheelTransform(i,true); - //draw wheels (cylinders) - m_vehicle->getWheelInfo(i).m_worldTransform.getOpenGLMatrix(m); - m_shapeDrawer->drawOpenGL(m,m_wheelShape,wheelColor,getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - - int lineWidth=400; - int xStart = m_glutScreenWidth - lineWidth; - int yStart = 20; - - if((getDebugMode() & btIDebugDraw::DBG_NoHelpText)==0) - { - setOrthographicProjection(); - glDisable(GL_LIGHTING); - glColor3f(0, 0, 0); - char buf[124]; - - sprintf(buf,"SHIFT+Cursor Left/Right - rotate lift"); - GLDebugDrawString(xStart,20,buf); - yStart+=20; - sprintf(buf,"SHIFT+Cursor UP/Down - fork up/down"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - if (m_useDefaultCamera) - { - sprintf(buf,"F5 - camera mode (free)"); - } else - { - sprintf(buf,"F5 - camera mode (follow)"); - } - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - yStart+=20; - if (m_dynamicsWorld->getConstraintSolver()->getSolverType()==BT_MLCP_SOLVER) - { - sprintf(buf,"F6 - solver (direct MLCP)"); - } else - { - sprintf(buf,"F6 - solver (sequential impulse)"); - } - GLDebugDrawString(xStart,yStart,buf); - btDiscreteDynamicsWorld* world = (btDiscreteDynamicsWorld*) m_dynamicsWorld; - if (world->getLatencyMotionStateInterpolation()) - { - sprintf(buf,"F7 - motionstate interpolation (on)"); - } else - { - sprintf(buf,"F7 - motionstate interpolation (off)"); - } - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - sprintf(buf,"Click window for keyboard focus"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - - resetPerspectiveProjection(); - glEnable(GL_LIGHTING); - } - DemoApplication::renderme(); -} - -void ForkLiftDemo::clientMoveAndDisplay() -{ - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - { - int wheelIndex = 2; - m_vehicle->applyEngineForce(gEngineForce,wheelIndex); - m_vehicle->setBrake(gBreakingForce,wheelIndex); - wheelIndex = 3; - m_vehicle->applyEngineForce(gEngineForce,wheelIndex); - m_vehicle->setBrake(gBreakingForce,wheelIndex); - - - wheelIndex = 0; - m_vehicle->setSteeringValue(gVehicleSteering,wheelIndex); - wheelIndex = 1; - m_vehicle->setSteeringValue(gVehicleSteering,wheelIndex); - - } - - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_dynamicsWorld) - { - //during idle mode, just run 1 simulation step maximum - int maxSimSubSteps = m_idle ? 1 : 2; - if (m_idle) - dt = 1.0/420.f; - - int numSimSteps; - numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps); - - if (m_dynamicsWorld->getConstraintSolver()->getSolverType()==BT_MLCP_SOLVER) - { - btMLCPSolver* sol = (btMLCPSolver*) m_dynamicsWorld->getConstraintSolver(); - int numFallbacks = sol->getNumFallbacks(); - if (numFallbacks) - { - static int totalFailures = 0; - totalFailures+=numFallbacks; - printf("MLCP solver failed %d times, falling back to btSequentialImpulseSolver (SI)\n",totalFailures); - } - sol->setNumFallbacks(0); - } - - -//#define VERBOSE_FEEDBACK -#ifdef VERBOSE_FEEDBACK - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } -#endif //VERBOSE_FEEDBACK - - } - - - - - - - -#ifdef USE_QUICKPROF - btProfiler::beginBlock("render"); -#endif //USE_QUICKPROF - - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - -#ifdef USE_QUICKPROF - btProfiler::endBlock("render"); -#endif - - - glFlush(); - glutSwapBuffers(); - -} - - - -void ForkLiftDemo::displayCallback(void) -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - -//optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - glutSwapBuffers(); -} - - -void ForkLiftDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - -void ForkLiftDemo::resetForklift() -{ - gVehicleSteering = 0.f; - gBreakingForce = defaultBreakingForce; - gEngineForce = 0.f; - - m_carChassis->setCenterOfMassTransform(btTransform::getIdentity()); - m_carChassis->setLinearVelocity(btVector3(0,0,0)); - m_carChassis->setAngularVelocity(btVector3(0,0,0)); - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(m_carChassis->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - if (m_vehicle) - { - m_vehicle->resetSuspension(); - for (int i=0;igetNumWheels();i++) - { - //synchronize the wheels with the (interpolated) chassis worldtransform - m_vehicle->updateWheelTransform(i,true); - } - } - btTransform liftTrans; - liftTrans.setIdentity(); - liftTrans.setOrigin(m_liftStartPos); - m_liftBody->activate(); - m_liftBody->setCenterOfMassTransform(liftTrans); - m_liftBody->setLinearVelocity(btVector3(0,0,0)); - m_liftBody->setAngularVelocity(btVector3(0,0,0)); - - btTransform forkTrans; - forkTrans.setIdentity(); - forkTrans.setOrigin(m_forkStartPos); - m_forkBody->activate(); - m_forkBody->setCenterOfMassTransform(forkTrans); - m_forkBody->setLinearVelocity(btVector3(0,0,0)); - m_forkBody->setAngularVelocity(btVector3(0,0,0)); - -// m_liftHinge->setLimit(-LIFT_EPS, LIFT_EPS); - m_liftHinge->setLimit(0.0f, 0.0f); - m_liftHinge->enableAngularMotor(false, 0, 0); - - - m_forkSlider->setLowerLinLimit(0.1f); - m_forkSlider->setUpperLinLimit(0.1f); - m_forkSlider->setPoweredLinMotor(false); - - btTransform loadTrans; - loadTrans.setIdentity(); - loadTrans.setOrigin(m_loadStartPos); - m_loadBody->activate(); - m_loadBody->setCenterOfMassTransform(loadTrans); - m_loadBody->setLinearVelocity(btVector3(0,0,0)); - m_loadBody->setAngularVelocity(btVector3(0,0,0)); - -} - - - -void ForkLiftDemo::specialKeyboardUp(int key, int x, int y) -{ - switch (key) - { - case GLUT_KEY_UP : - { - lockForkSlider(); - gEngineForce = 0.f; - gBreakingForce = defaultBreakingForce; - break; - } - case GLUT_KEY_DOWN : - { - lockForkSlider(); - gEngineForce = 0.f; - gBreakingForce = defaultBreakingForce; - break; - } - case GLUT_KEY_LEFT: - case GLUT_KEY_RIGHT: - { - lockLiftHinge(); - break; - } - default: - DemoApplication::specialKeyboardUp(key,x,y); - break; - } -} - - -void ForkLiftDemo::specialKeyboard(int key, int x, int y) -{ - - if (key==GLUT_KEY_END) - return; - - // printf("key = %i x=%i y=%i\n",key,x,y); - - int state; - state=glutGetModifiers(); - if (state & GLUT_ACTIVE_SHIFT) - { - switch (key) - { - case GLUT_KEY_LEFT : - { - - m_liftHinge->setLimit(-M_PI/16.0f, M_PI/8.0f); - m_liftHinge->enableAngularMotor(true, -0.1, maxMotorImpulse); - break; - } - case GLUT_KEY_RIGHT : - { - - m_liftHinge->setLimit(-M_PI/16.0f, M_PI/8.0f); - m_liftHinge->enableAngularMotor(true, 0.1, maxMotorImpulse); - break; - } - case GLUT_KEY_UP : - { - m_forkSlider->setLowerLinLimit(0.1f); - m_forkSlider->setUpperLinLimit(3.9f); - m_forkSlider->setPoweredLinMotor(true); - m_forkSlider->setMaxLinMotorForce(maxMotorImpulse); - m_forkSlider->setTargetLinMotorVelocity(1.0); - break; - } - case GLUT_KEY_DOWN : - { - m_forkSlider->setLowerLinLimit(0.1f); - m_forkSlider->setUpperLinLimit(3.9f); - m_forkSlider->setPoweredLinMotor(true); - m_forkSlider->setMaxLinMotorForce(maxMotorImpulse); - m_forkSlider->setTargetLinMotorVelocity(-1.0); - break; - } - - default: - DemoApplication::specialKeyboard(key,x,y); - break; - } - - } else - { - switch (key) - { - case GLUT_KEY_LEFT : - { - gVehicleSteering += steeringIncrement; - if ( gVehicleSteering > steeringClamp) - gVehicleSteering = steeringClamp; - - break; - } - case GLUT_KEY_RIGHT : - { - gVehicleSteering -= steeringIncrement; - if ( gVehicleSteering < -steeringClamp) - gVehicleSteering = -steeringClamp; - - break; - } - case GLUT_KEY_UP : - { - gEngineForce = maxEngineForce; - gBreakingForce = 0.f; - break; - } - case GLUT_KEY_DOWN : - { - gEngineForce = -maxEngineForce; - gBreakingForce = 0.f; - break; - } - - case GLUT_KEY_F7: - { - btDiscreteDynamicsWorld* world = (btDiscreteDynamicsWorld*)m_dynamicsWorld; - world->setLatencyMotionStateInterpolation(!world->getLatencyMotionStateInterpolation()); - printf("world latencyMotionStateInterpolation = %d\n", world->getLatencyMotionStateInterpolation()); - break; - } - case GLUT_KEY_F6: - { - //switch solver (needs demo restart) - useMCLPSolver = !useMCLPSolver; - printf("switching to useMLCPSolver = %d\n", useMCLPSolver); - - delete m_constraintSolver; - if (useMCLPSolver) - { - btDantzigSolver* mlcp = new btDantzigSolver(); - //btSolveProjectedGaussSeidel* mlcp = new btSolveProjectedGaussSeidel; - btMLCPSolver* sol = new btMLCPSolver(mlcp); - m_constraintSolver = sol; - } else - { - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - } - - m_dynamicsWorld->setConstraintSolver(m_constraintSolver); - - - //exitPhysics(); - //initPhysics(); - break; - } - - case GLUT_KEY_F5: - m_useDefaultCamera = !m_useDefaultCamera; - break; - default: - DemoApplication::specialKeyboard(key,x,y); - break; - } - - } - // glutPostRedisplay(); - - -} - -void ForkLiftDemo::updateCamera() -{ - -//#define DISABLE_CAMERA 1 - if(m_useDefaultCamera) - { - DemoApplication::updateCamera(); - return; - } - - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - - btTransform chassisWorldTrans; - - //look at the vehicle - m_carChassis->getMotionState()->getWorldTransform(chassisWorldTrans); - m_cameraTargetPosition = chassisWorldTrans.getOrigin(); - - //interpolate the camera height -#ifdef FORCE_ZAXIS_UP - m_cameraPosition[2] = (15.0*m_cameraPosition[2] + m_cameraTargetPosition[2] + m_cameraHeight)/16.0; -#else - m_cameraPosition[1] = (15.0*m_cameraPosition[1] + m_cameraTargetPosition[1] + m_cameraHeight)/16.0; -#endif - - btVector3 camToObject = m_cameraTargetPosition - m_cameraPosition; - - //keep distance between min and max distance - float cameraDistance = camToObject.length(); - float correctionFactor = 0.f; - if (cameraDistance < m_minCameraDistance) - { - correctionFactor = 0.15*(m_minCameraDistance-cameraDistance)/cameraDistance; - } - if (cameraDistance > m_maxCameraDistance) - { - correctionFactor = 0.15*(m_maxCameraDistance-cameraDistance)/cameraDistance; - } - m_cameraPosition -= correctionFactor*camToObject; - - //update OpenGL camera settings - btScalar aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight; - glFrustum (-aspect, aspect, -1.0, 1.0, 1.0, 10000.0); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - - gluLookAt(m_cameraPosition[0],m_cameraPosition[1],m_cameraPosition[2], - m_cameraTargetPosition[0],m_cameraTargetPosition[1], m_cameraTargetPosition[2], - m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ()); - - - -} - -void ForkLiftDemo::lockLiftHinge(void) -{ - btScalar hingeAngle = m_liftHinge->getHingeAngle(); - btScalar lowLim = m_liftHinge->getLowerLimit(); - btScalar hiLim = m_liftHinge->getUpperLimit(); - m_liftHinge->enableAngularMotor(false, 0, 0); - if(hingeAngle < lowLim) - { -// m_liftHinge->setLimit(lowLim, lowLim + LIFT_EPS); - m_liftHinge->setLimit(lowLim, lowLim); - } - else if(hingeAngle > hiLim) - { -// m_liftHinge->setLimit(hiLim - LIFT_EPS, hiLim); - m_liftHinge->setLimit(hiLim, hiLim); - } - else - { -// m_liftHinge->setLimit(hingeAngle - LIFT_EPS, hingeAngle + LIFT_EPS); - m_liftHinge->setLimit(hingeAngle, hingeAngle); - } - return; -} // ForkLiftDemo::lockLiftHinge() - -void ForkLiftDemo::lockForkSlider(void) -{ - btScalar linDepth = m_forkSlider->getLinearPos(); - btScalar lowLim = m_forkSlider->getLowerLinLimit(); - btScalar hiLim = m_forkSlider->getUpperLinLimit(); - m_forkSlider->setPoweredLinMotor(false); - if(linDepth <= lowLim) - { - m_forkSlider->setLowerLinLimit(lowLim); - m_forkSlider->setUpperLinLimit(lowLim); - } - else if(linDepth > hiLim) - { - m_forkSlider->setLowerLinLimit(hiLim); - m_forkSlider->setUpperLinLimit(hiLim); - } - else - { - m_forkSlider->setLowerLinLimit(linDepth); - m_forkSlider->setUpperLinLimit(linDepth); - } - return; -} // ForkLiftDemo::lockForkSlider() diff --git a/Demos/ForkLiftDemo/ForkLiftDemo.h b/Demos/ForkLiftDemo/ForkLiftDemo.h deleted file mode 100644 index 3489f3732..000000000 --- a/Demos/ForkLiftDemo/ForkLiftDemo.h +++ /dev/null @@ -1,115 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef FORKLIFT_DEMO_H -#define FORKLIFT_DEMO_H - -class btVehicleTuning; -struct btVehicleRaycaster; -class btCollisionShape; - -#include "BulletDynamics/Vehicle/btRaycastVehicle.h" -#include "BulletDynamics/ConstraintSolver/btHingeConstraint.h" -#include "BulletDynamics/ConstraintSolver/btSliderConstraint.h" - -#include "GlutDemoApplication.h" - -///VehicleDemo shows how to setup and use the built-in raycast vehicle -class ForkLiftDemo : public GlutDemoApplication -{ - public: - - btRigidBody* m_carChassis; - -//---------------------------- - btRigidBody* m_liftBody; - btVector3 m_liftStartPos; - btHingeConstraint* m_liftHinge; - - btRigidBody* m_forkBody; - btVector3 m_forkStartPos; - btSliderConstraint* m_forkSlider; - - btRigidBody* m_loadBody; - btVector3 m_loadStartPos; - - void lockLiftHinge(void); - void lockForkSlider(void); - - bool m_useDefaultCamera; -//---------------------------- - - - btAlignedObjectArray m_collisionShapes; - - class btBroadphaseInterface* m_overlappingPairCache; - - class btCollisionDispatcher* m_dispatcher; - - class btConstraintSolver* m_constraintSolver; - - class btDefaultCollisionConfiguration* m_collisionConfiguration; - - class btTriangleIndexVertexArray* m_indexVertexArrays; - - btVector3* m_vertices; - - - btRaycastVehicle::btVehicleTuning m_tuning; - btVehicleRaycaster* m_vehicleRayCaster; - btRaycastVehicle* m_vehicle; - btCollisionShape* m_wheelShape; - - float m_cameraHeight; - - float m_minCameraDistance; - float m_maxCameraDistance; - - - ForkLiftDemo(); - - virtual ~ForkLiftDemo(); - - virtual void clientMoveAndDisplay(); - - virtual void resetForklift(); - - virtual void clientResetScene(); - - virtual void displayCallback(); - - ///a very basic camera following the vehicle - virtual void updateCamera(); - - virtual void specialKeyboard(int key, int x, int y); - - virtual void specialKeyboardUp(int key, int x, int y); - - void renderme(); - - void initPhysics(); - void exitPhysics(); - - static DemoApplication* Create() - { - ForkLiftDemo* demo = new ForkLiftDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -#endif // FORKLIFT_DEMO_H - - diff --git a/Demos/ForkLiftDemo/ForkLiftPhysicsSetup.cpp b/Demos/ForkLiftDemo/ForkLiftPhysicsSetup.cpp deleted file mode 100644 index edb556828..000000000 --- a/Demos/ForkLiftDemo/ForkLiftPhysicsSetup.cpp +++ /dev/null @@ -1,503 +0,0 @@ -#include "ForkLiftPhysicsSetup.h" -#include "BulletDynamics/MLCPSolvers/btDantzigSolver.h" -#include "BulletDynamics/MLCPSolvers/btSolveProjectedGaussSeidel.h" -#include "BulletDynamics/MLCPSolvers/btMLCPSolver.h" -#include "OpenGLWindow/CommonRenderInterface.h" - -btScalar maxMotorImpulse = 1400.f; -btScalar loadMass = 350.f;// -#ifdef FORCE_ZAXIS_UP - int rightIndex = 0; - int upIndex = 2; - int forwardIndex = 1; - btVector3 wheelDirectionCS0(0,0,-1); - btVector3 wheelAxleCS(1,0,0); -#else - int rightIndex = 0; - int upIndex = 1; - int forwardIndex = 2; - btVector3 wheelDirectionCS0(0,-1,0); - btVector3 wheelAxleCS(-1,0,0); -#endif - -float defaultBreakingForce = 10.f; -float gBreakingForce = 100.f; -float gEngineForce = 0.f; -float gVehicleSteering = 0.f; -float steeringIncrement = 0.04f; -float steeringClamp = 0.3f; -float wheelRadius = 0.5f; -float wheelWidth = 0.4f; -btScalar suspensionRestLength(0.6); -#define CUBE_HALF_EXTENTS 1 -float suspensionStiffness = 20.f; -float suspensionDamping = 2.3f; -float suspensionCompression = 4.4f; -float rollInfluence = 0.1f;//1.0f; -float wheelFriction = 1000;//BT_LARGE_FLOAT; - - -struct ForkLiftInternalData -{ - btRigidBody* m_carChassis; - -//---------------------------- - btRigidBody* m_liftBody; - btVector3 m_liftStartPos; - btHingeConstraint* m_liftHinge; - btRigidBody* m_forkBody; - btVector3 m_forkStartPos; - btSliderConstraint* m_forkSlider; - btRigidBody* m_loadBody; - btVector3 m_loadStartPos; - bool m_useDefaultCamera; - class btTriangleIndexVertexArray* m_indexVertexArrays; - btVector3* m_vertices; - btRaycastVehicle::btVehicleTuning m_tuning; - btVehicleRaycaster* m_vehicleRayCaster; - btRaycastVehicle* m_vehicle; - btCollisionShape* m_wheelShape; - float m_cameraHeight; - float m_minCameraDistance; - float m_maxCameraDistance; - btAlignedObjectArray m_collisionShapes; - class btBroadphaseInterface* m_overlappingPairCache; - class btCollisionDispatcher* m_dispatcher; - class btConstraintSolver* m_constraintSolver; - class btDefaultCollisionConfiguration* m_collisionConfiguration; - class btDiscreteDynamicsWorld* m_dynamicsWorld; - - int m_wheelInstances[4]; - - bool useMCLPSolver; - - ForkLiftInternalData() - :m_carChassis(0), - m_liftBody(0), - m_forkBody(0), - m_loadBody(0), - m_indexVertexArrays(0), - m_vertices(0), - m_cameraHeight(4.f), - m_minCameraDistance(3.f), - m_maxCameraDistance(10.f), - m_overlappingPairCache(0), - m_dispatcher(0), - m_constraintSolver(0), - m_collisionConfiguration(0), - m_dynamicsWorld(0), - useMCLPSolver(false) - { - m_vehicle = 0; - m_wheelShape = 0; - m_useDefaultCamera = false; - } -}; - -ForkLiftPhysicsSetup::ForkLiftPhysicsSetup() -{ - m_data = new ForkLiftInternalData; -} - -ForkLiftPhysicsSetup::~ForkLiftPhysicsSetup() -{ - delete m_data; -} - - -void ForkLiftPhysicsSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - - -#ifdef FORCE_ZAXIS_UP - m_cameraUp = btVector3(0,0,1); - m_forwardAxis = 1; -#endif - - btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50)); - m_data->m_collisionShapes.push_back(groundShape); - m_data->m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_data->m_dispatcher = new btCollisionDispatcher(m_data->m_collisionConfiguration); - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - m_data->m_overlappingPairCache = new btAxisSweep3(worldMin,worldMax); - if (m_data->useMCLPSolver) - { - btDantzigSolver* mlcp = new btDantzigSolver(); - //btSolveProjectedGaussSeidel* mlcp = new btSolveProjectedGaussSeidel; - btMLCPSolver* sol = new btMLCPSolver(mlcp); - m_data->m_constraintSolver = sol; - } else - { - m_data->m_constraintSolver = new btSequentialImpulseConstraintSolver(); - } - m_data->m_dynamicsWorld = new btDiscreteDynamicsWorld(m_data->m_dispatcher,m_data->m_overlappingPairCache,m_data->m_constraintSolver,m_data->m_collisionConfiguration); - if (m_data->useMCLPSolver) - { - m_data->m_dynamicsWorld ->getSolverInfo().m_minimumSolverBatchSize = 1;//for direct solver it is better to have a small A matrix - } else - { - m_data->m_dynamicsWorld ->getSolverInfo().m_minimumSolverBatchSize = 128;//for direct solver, it is better to solve multiple objects together, small batches have high overhead - } -#ifdef FORCE_ZAXIS_UP - m_dynamicsWorld->setGravity(btVector3(0,0,-10)); -#endif - - //m_dynamicsWorld->setGravity(btVector3(0,0,0)); -btTransform tr; -tr.setIdentity(); -tr.setOrigin(btVector3(0,-3,0)); - -//either use heightfield or triangle mesh - - - //create ground object - localCreateRigidBody(0,tr,groundShape); - -#ifdef FORCE_ZAXIS_UP -// indexRightAxis = 0; -// indexUpAxis = 2; -// indexForwardAxis = 1; - btCollisionShape* chassisShape = new btBoxShape(btVector3(1.f,2.f, 0.5f)); - btCompoundShape* compound = new btCompoundShape(); - btTransform localTrans; - localTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - localTrans.setOrigin(btVector3(0,0,1)); -#else - btCollisionShape* chassisShape = new btBoxShape(btVector3(1.f,0.5f,2.f)); - m_data->m_collisionShapes.push_back(chassisShape); - - btCompoundShape* compound = new btCompoundShape(); - m_data->m_collisionShapes.push_back(compound); - btTransform localTrans; - localTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - localTrans.setOrigin(btVector3(0,1,0)); -#endif - - compound->addChildShape(localTrans,chassisShape); - - { - btCollisionShape* suppShape = new btBoxShape(btVector3(0.5f,0.1f,0.5f)); - btTransform suppLocalTrans; - suppLocalTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - suppLocalTrans.setOrigin(btVector3(0,1.0,2.5)); - compound->addChildShape(suppLocalTrans, suppShape); - } - - tr.setOrigin(btVector3(0,0.f,0)); - - m_data->m_carChassis = localCreateRigidBody(800,tr,compound);//chassisShape); - //m_carChassis->setDamping(0.2,0.2); - - m_data->m_wheelShape = new btCylinderShapeX(btVector3(wheelWidth,wheelRadius,wheelRadius)); - gfxBridge.createCollisionShapeGraphicsObject(m_data->m_wheelShape); - int wheelGraphicsIndex = m_data->m_wheelShape->getUserIndex(); - - const float position[4]={0,10,10,0}; - const float quaternion[4]={0,0,0,1}; - const float color[4]={0,1,0,1}; - const float scaling[4] = {1,1,1,1}; - - for (int i=0;i<4;i++) - { - m_data->m_wheelInstances[i] = gfxBridge.registerGraphicsInstance(wheelGraphicsIndex, position, quaternion, color, scaling); - } - - - { - btCollisionShape* liftShape = new btBoxShape(btVector3(0.5f,2.0f,0.05f)); - m_data->m_collisionShapes.push_back(liftShape); - btTransform liftTrans; - m_data->m_liftStartPos = btVector3(0.0f, 2.5f, 3.05f); - liftTrans.setIdentity(); - liftTrans.setOrigin(m_data->m_liftStartPos); - m_data->m_liftBody = localCreateRigidBody(10,liftTrans, liftShape); - - btTransform localA, localB; - localA.setIdentity(); - localB.setIdentity(); - localA.getBasis().setEulerZYX(0, SIMD_HALF_PI, 0); - localA.setOrigin(btVector3(0.0, 1.0, 3.05)); - localB.getBasis().setEulerZYX(0, SIMD_HALF_PI, 0); - localB.setOrigin(btVector3(0.0, -1.5, -0.05)); - m_data->m_liftHinge = new btHingeConstraint(*m_data->m_carChassis,*m_data->m_liftBody, localA, localB); -// m_liftHinge->setLimit(-LIFT_EPS, LIFT_EPS); - m_data->m_liftHinge->setLimit(0.0f, 0.0f); - m_data->m_dynamicsWorld->addConstraint(m_data->m_liftHinge, true); - - btCollisionShape* forkShapeA = new btBoxShape(btVector3(1.0f,0.1f,0.1f)); - m_data->m_collisionShapes.push_back(forkShapeA); - btCompoundShape* forkCompound = new btCompoundShape(); - m_data->m_collisionShapes.push_back(forkCompound); - btTransform forkLocalTrans; - forkLocalTrans.setIdentity(); - forkCompound->addChildShape(forkLocalTrans, forkShapeA); - - btCollisionShape* forkShapeB = new btBoxShape(btVector3(0.1f,0.02f,0.6f)); - m_data->m_collisionShapes.push_back(forkShapeB); - forkLocalTrans.setIdentity(); - forkLocalTrans.setOrigin(btVector3(-0.9f, -0.08f, 0.7f)); - forkCompound->addChildShape(forkLocalTrans, forkShapeB); - - btCollisionShape* forkShapeC = new btBoxShape(btVector3(0.1f,0.02f,0.6f)); - m_data->m_collisionShapes.push_back(forkShapeC); - forkLocalTrans.setIdentity(); - forkLocalTrans.setOrigin(btVector3(0.9f, -0.08f, 0.7f)); - forkCompound->addChildShape(forkLocalTrans, forkShapeC); - - btTransform forkTrans; - m_data->m_forkStartPos = btVector3(0.0f, 0.6f, 3.2f); - forkTrans.setIdentity(); - forkTrans.setOrigin(m_data->m_forkStartPos); - m_data->m_forkBody = localCreateRigidBody(5, forkTrans, forkCompound); - - localA.setIdentity(); - localB.setIdentity(); - localA.getBasis().setEulerZYX(0, 0, SIMD_HALF_PI); - localA.setOrigin(btVector3(0.0f, -1.9f, 0.05f)); - localB.getBasis().setEulerZYX(0, 0, SIMD_HALF_PI); - localB.setOrigin(btVector3(0.0, 0.0, -0.1)); - m_data->m_forkSlider = new btSliderConstraint(*m_data->m_liftBody, *m_data->m_forkBody, localA, localB, true); - m_data->m_forkSlider->setLowerLinLimit(0.1f); - m_data->m_forkSlider->setUpperLinLimit(0.1f); -// m_forkSlider->setLowerAngLimit(-LIFT_EPS); -// m_forkSlider->setUpperAngLimit(LIFT_EPS); - m_data->m_forkSlider->setLowerAngLimit(0.0f); - m_data->m_forkSlider->setUpperAngLimit(0.0f); - m_data->m_dynamicsWorld->addConstraint(m_data->m_forkSlider, true); - - - btCompoundShape* loadCompound = new btCompoundShape(); - m_data->m_collisionShapes.push_back(loadCompound); - btCollisionShape* loadShapeA = new btBoxShape(btVector3(2.0f,0.5f,0.5f)); - m_data->m_collisionShapes.push_back(loadShapeA); - btTransform loadTrans; - loadTrans.setIdentity(); - loadCompound->addChildShape(loadTrans, loadShapeA); - btCollisionShape* loadShapeB = new btBoxShape(btVector3(0.1f,1.0f,1.0f)); - m_data->m_collisionShapes.push_back(loadShapeB); - loadTrans.setIdentity(); - loadTrans.setOrigin(btVector3(2.1f, 0.0f, 0.0f)); - loadCompound->addChildShape(loadTrans, loadShapeB); - btCollisionShape* loadShapeC = new btBoxShape(btVector3(0.1f,1.0f,1.0f)); - m_data->m_collisionShapes.push_back(loadShapeC); - loadTrans.setIdentity(); - loadTrans.setOrigin(btVector3(-2.1f, 0.0f, 0.0f)); - loadCompound->addChildShape(loadTrans, loadShapeC); - loadTrans.setIdentity(); - m_data->m_loadStartPos = btVector3(0.0f, 3.5f, 7.0f); - loadTrans.setOrigin(m_data->m_loadStartPos); - m_data->m_loadBody = localCreateRigidBody(loadMass, loadTrans, loadCompound); - } - - - - - - /// create vehicle - { - - m_data->m_vehicleRayCaster = new btDefaultVehicleRaycaster(m_data->m_dynamicsWorld); - m_data->m_vehicle = new btRaycastVehicle(m_data->m_tuning,m_data->m_carChassis,m_data->m_vehicleRayCaster); - - ///never deactivate the vehicle - m_data->m_carChassis->setActivationState(DISABLE_DEACTIVATION); - - m_data->m_dynamicsWorld->addVehicle(m_data->m_vehicle); - - float connectionHeight = 1.2f; - - - bool isFrontWheel=true; - - //choose coordinate system - m_data->m_vehicle->setCoordinateSystem(rightIndex,upIndex,forwardIndex); - -#ifdef FORCE_ZAXIS_UP - btVector3 connectionPointCS0(CUBE_HALF_EXTENTS-(0.3*wheelWidth),2*CUBE_HALF_EXTENTS-wheelRadius, connectionHeight); -#else - btVector3 connectionPointCS0(CUBE_HALF_EXTENTS-(0.3*wheelWidth),connectionHeight,2*CUBE_HALF_EXTENTS-wheelRadius); -#endif - - m_data->m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_data->m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),2*CUBE_HALF_EXTENTS-wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),connectionHeight,2*CUBE_HALF_EXTENTS-wheelRadius); -#endif - - m_data->m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_data->m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),-2*CUBE_HALF_EXTENTS+wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),connectionHeight,-2*CUBE_HALF_EXTENTS+wheelRadius); -#endif //FORCE_ZAXIS_UP - isFrontWheel = false; - m_data->m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_data->m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(CUBE_HALF_EXTENTS-(0.3*wheelWidth),-2*CUBE_HALF_EXTENTS+wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(CUBE_HALF_EXTENTS-(0.3*wheelWidth),connectionHeight,-2*CUBE_HALF_EXTENTS+wheelRadius); -#endif - m_data->m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_data->m_tuning,isFrontWheel); - - for (int i=0;im_vehicle->getNumWheels();i++) - { - btWheelInfo& wheel = m_data->m_vehicle->getWheelInfo(i); - wheel.m_suspensionStiffness = suspensionStiffness; - wheel.m_wheelsDampingRelaxation = suspensionDamping; - wheel.m_wheelsDampingCompression = suspensionCompression; - wheel.m_frictionSlip = wheelFriction; - wheel.m_rollInfluence = rollInfluence; - } - } - - resetForklift(); - gfxBridge.autogenerateGraphicsObjects(m_data->m_dynamicsWorld); - -// setCameraDistance(26.f); -} - -void ForkLiftPhysicsSetup::resetForklift() -{ - gVehicleSteering = 0.f; - gBreakingForce = defaultBreakingForce; - gEngineForce = 0.f; - - m_data->m_carChassis->setCenterOfMassTransform(btTransform::getIdentity()); - m_data->m_carChassis->setLinearVelocity(btVector3(0,0,0)); - m_data->m_carChassis->setAngularVelocity(btVector3(0,0,0)); - m_data->m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(m_data->m_carChassis->getBroadphaseHandle(),m_data->m_dynamicsWorld->getDispatcher()); - if (m_data->m_vehicle) - { - m_data->m_vehicle->resetSuspension(); - for (int i=0;im_vehicle->getNumWheels();i++) - { - //synchronize the wheels with the (interpolated) chassis worldtransform - m_data->m_vehicle->updateWheelTransform(i,true); - } - } - btTransform liftTrans; - liftTrans.setIdentity(); - liftTrans.setOrigin(m_data->m_liftStartPos); - m_data->m_liftBody->activate(); - m_data->m_liftBody->setCenterOfMassTransform(liftTrans); - m_data->m_liftBody->setLinearVelocity(btVector3(0,0,0)); - m_data->m_liftBody->setAngularVelocity(btVector3(0,0,0)); - - btTransform forkTrans; - forkTrans.setIdentity(); - forkTrans.setOrigin(m_data->m_forkStartPos); - m_data->m_forkBody->activate(); - m_data->m_forkBody->setCenterOfMassTransform(forkTrans); - m_data->m_forkBody->setLinearVelocity(btVector3(0,0,0)); - m_data->m_forkBody->setAngularVelocity(btVector3(0,0,0)); - -// m_liftHinge->setLimit(-LIFT_EPS, LIFT_EPS); - m_data->m_liftHinge->setLimit(0.0f, 0.0f); - m_data->m_liftHinge->enableAngularMotor(false, 0, 0); - - - m_data->m_forkSlider->setLowerLinLimit(0.1f); - m_data->m_forkSlider->setUpperLinLimit(0.1f); - m_data->m_forkSlider->setPoweredLinMotor(false); - - btTransform loadTrans; - loadTrans.setIdentity(); - loadTrans.setOrigin(m_data->m_loadStartPos); - m_data->m_loadBody->activate(); - m_data->m_loadBody->setCenterOfMassTransform(loadTrans); - m_data->m_loadBody->setLinearVelocity(btVector3(0,0,0)); - m_data->m_loadBody->setAngularVelocity(btVector3(0,0,0)); - -} - -btRigidBody* ForkLiftPhysicsSetup::localCreateRigidBody(btScalar mass, const btTransform& startTransform, btCollisionShape* shape) -{ - btAssert((!shape || shape->getShapeType() != INVALID_SHAPE_PROXYTYPE)); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - -//#define USE_MOTIONSTATE 1 -#ifdef USE_MOTIONSTATE - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo cInfo(mass,myMotionState,shape,localInertia); - - btRigidBody* body = new btRigidBody(cInfo); - body->setContactProcessingThreshold(BT_LARGE_FLOAT);//m_defaultContactProcessingThreshold); - -#else - btRigidBody* body = new btRigidBody(mass,0,shape,localInertia); - body->setWorldTransform(startTransform); -#endif// - - m_data->m_dynamicsWorld->addRigidBody(body); - return body; -} - -void ForkLiftPhysicsSetup::exitPhysics() -{ -} -void ForkLiftPhysicsSetup::stepSimulation(float deltaTime) -{ - m_data->m_dynamicsWorld->stepSimulation(deltaTime); -} -void ForkLiftPhysicsSetup::debugDraw(int debugDrawFlags) -{ -} -bool ForkLiftPhysicsSetup::pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) -{ - return false; -} -bool ForkLiftPhysicsSetup::movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) -{ - return false; -} -void ForkLiftPhysicsSetup::removePickingConstraint() -{ -} -void ForkLiftPhysicsSetup::syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge) -{ - gfxBridge.syncPhysicsToGraphics(m_data->m_dynamicsWorld); - //sync wheels - - for (int i=0;im_vehicle->getNumWheels();i++) - { - //synchronize the wheels with the (interpolated) chassis worldtransform - m_data->m_vehicle->updateWheelTransform(i,true); - - CommonRenderInterface* renderer = gfxBridge.getRenderInterface(); - if (renderer) - { - btTransform tr = m_data->m_vehicle->getWheelInfo(i).m_worldTransform; - btVector3 pos=tr.getOrigin(); - btQuaternion orn = tr.getRotation(); - renderer->writeSingleInstanceTransformToCPU(pos,orn,m_data->m_wheelInstances[i]); - } - } - -} - -void ForkLiftPhysicsSetup::renderScene(GraphicsPhysicsBridge& gfxBridge) -{ - gfxBridge.drawText3D("hi!",0,10,10,2); -} - -void ForkLiftPhysicsSetup::lockLiftHinge() -{ -} - -void ForkLiftPhysicsSetup::lockForkSlider() -{ -} diff --git a/Demos/ForkLiftDemo/ForkLiftPhysicsSetup.h b/Demos/ForkLiftDemo/ForkLiftPhysicsSetup.h deleted file mode 100644 index 89e932668..000000000 --- a/Demos/ForkLiftDemo/ForkLiftPhysicsSetup.h +++ /dev/null @@ -1,50 +0,0 @@ -#ifndef FORK_LIFT_PHYSICS_SETUP_H -#define FORK_LIFT_PHYSICS_SETUP_H - -class btRigidBody; -class btCollisionShape; -class btBroadphaseInterface; -class btConstraintSolver; -class btCollisionDispatcher; -class btDefaultCollisionConfiguration; -class btDiscreteDynamicsWorld; -class btTransform; -class btVector3; -class btBoxShape; - -#include "LinearMath/btVector3.h" -#include "LinearMath/btAlignedObjectArray.h" -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -class ForkLiftPhysicsSetup : public CommonPhysicsSetup -{ - -protected: - - struct ForkLiftInternalData* m_data; - -public: - - ForkLiftPhysicsSetup(); - virtual ~ForkLiftPhysicsSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - - virtual void exitPhysics(); - virtual void stepSimulation(float deltaTime); - virtual void debugDraw(int debugDrawFlags); - virtual bool pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld); - virtual bool movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld); - virtual void removePickingConstraint(); - virtual void syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge); - virtual void renderScene(GraphicsPhysicsBridge& gfxBridge); - - void resetForklift(); - void lockLiftHinge(); - void lockForkSlider(); - class btRigidBody* localCreateRigidBody(btScalar mass, const btTransform& startTrans, btCollisionShape* shape); - -}; - -#endif //FORK_LIFT_PHYSICS_SETUP_H diff --git a/Demos/ForkLiftDemo/Makefile.am b/Demos/ForkLiftDemo/Makefile.am deleted file mode 100644 index 588373493..000000000 --- a/Demos/ForkLiftDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=ForkLiftDemo - -ForkLiftDemo_SOURCES=ForkLiftDemo.cpp ForkLiftDemo.h main.cpp -ForkLiftDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -ForkLiftDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/ForkLiftDemo/main.cpp b/Demos/ForkLiftDemo/main.cpp deleted file mode 100644 index 42b8b0698..000000000 --- a/Demos/ForkLiftDemo/main.cpp +++ /dev/null @@ -1,18 +0,0 @@ - -#include "ForkLiftDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - ForkLiftDemo* pForkLiftDemo = new ForkLiftDemo; - - pForkLiftDemo->initPhysics(); - pForkLiftDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - return glutmain(argc, argv,1024,768,"Bullet ForkLift Demo. http://www.continuousphysics.com/Bullet/phpBB2/", pForkLiftDemo); -} - diff --git a/Demos/FractureDemo/CMakeLists.txt b/Demos/FractureDemo/CMakeLists.txt deleted file mode 100644 index 425ddc116..000000000 --- a/Demos/FractureDemo/CMakeLists.txt +++ /dev/null @@ -1,82 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppFractureDemo - main.cpp - FractureDemo.cpp - FractureDemo.h - btFractureBody.h - btFractureBody.cpp - btFractureDynamicsWorld.cpp - btFractureDynamicsWorld.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppFractureDemo - main.cpp - FractureDemo.cpp - FractureDemo.h - btFractureBody.h - btFractureBody.cpp - btFractureDynamicsWorld.cpp - btFractureDynamicsWorld.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppFractureDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32FractureDemo.cpp - FractureDemo.cpp - FractureDemo.h - btFractureBody.h - btFractureBody.cpp - btFractureDynamicsWorld.cpp - btFractureDynamicsWorld.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppFractureDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppFractureDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppFractureDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/FractureDemo/FractureDemo.cpp b/Demos/FractureDemo/FractureDemo.cpp deleted file mode 100644 index 983d4d34d..000000000 --- a/Demos/FractureDemo/FractureDemo.cpp +++ /dev/null @@ -1,362 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2011 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -///FractureDemo shows how to break objects. -///It assumes a btCompoundShaps (where the childshapes are the pre-fractured pieces) -///The btFractureBody is a class derived from btRigidBody, dealing with the collision impacts. -///Press the F key to toggle between fracture and glue mode -///This is preliminary work - - -#define CUBE_HALF_EXTENTS 1.f -#define EXTRA_HEIGHT 1.f -///scaling of the objects (0.1 = 20 centimeter boxes ) -#define SCALING 1. -#define START_POS_X -5 -#define START_POS_Y -5 -#define START_POS_Z -3 - -#include "FractureDemo.h" -#include "GlutStuff.h" -#include "GLDebugFont.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" - - -#include //printf debugging - - -int sFrameNumber = 0; - -#include "btFractureBody.h" -#include "btFractureDynamicsWorld.h" - - - - - -void FractureDemo::initPhysics() -{ - - setTexturing(true); - setShadows(true); - - setDebugMode(btIDebugDraw::DBG_DrawText|btIDebugDraw::DBG_NoHelpText); - - setCameraDistance(btScalar(SCALING*20.)); - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - //m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - - btFractureDynamicsWorld* fractureWorld = new btFractureDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld = fractureWorld; - - m_ShootBoxInitialSpeed=100; - - //m_splitImpulse removes the penetration resolution from the applied impulse, otherwise objects might fracture due to deep penetrations. - m_dynamicsWorld->getSolverInfo().m_splitImpulse = true; - - { - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(50,1,50)); - /// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),0); - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,0,0)); - localCreateRigidBody(0.f,groundTransform,groundShape); - } - - { - ///create a few basic rigid bodies - btCollisionShape* shape = new btBoxShape(btVector3(1,1,1)); - m_collisionShapes.push_back(shape); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(5,2,0)); - localCreateRigidBody(0.f,tr,shape); - } - - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btCollisionShape* colShape = new btBoxShape(btVector3(SCALING*1,SCALING*1,SCALING*1)); - //btCollisionShape* colShape = new btCapsuleShape(SCALING*0.4,SCALING*1); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - - int gNumObjects = 10; - - for (int i=0;isetLinearVelocity(btVector3(0,-10,0)); - - m_dynamicsWorld->addRigidBody(body); - - - } - - } - - - - fractureWorld->stepSimulation(1./60.,0); - fractureWorld->glueCallback(); - - - -} - -void FractureDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void FractureDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - - - renderme(); - - showMessage(); - - glFlush(); - - swapBuffers(); - -} - -void FractureDemo::showMessage() -{ - if((getDebugMode() & btIDebugDraw::DBG_DrawText)) - { - setOrthographicProjection(); - glDisable(GL_LIGHTING); - glColor3f(0, 0, 0); - char buf[124]; - - int lineWidth=380; - int xStart = m_glutScreenWidth - lineWidth; - int yStart = 20; - - btFractureDynamicsWorld* world = (btFractureDynamicsWorld*)m_dynamicsWorld; - if (world->getFractureMode()) - { - sprintf(buf,"Fracture mode"); - } else - { - sprintf(buf,"Glue mode"); - } - GLDebugDrawString(xStart,yStart,buf); - sprintf(buf,"f to toggle fracture/glue mode"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - sprintf(buf,"space to restart, mouse to pick/shoot"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - resetPerspectiveProjection(); - glEnable(GL_LIGHTING); - } - -} - - -void FractureDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - showMessage(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - -void FractureDemo::keyboardUpCallback(unsigned char key, int x, int y) -{ - if (key=='f') - { - btFractureDynamicsWorld* world = (btFractureDynamicsWorld*)m_dynamicsWorld; - world->setFractureMode(!world->getFractureMode()); - } - - PlatformDemoApplication::keyboardUpCallback(key,x,y); - -} - - -void FractureDemo::shootBox(const btVector3& destination) -{ - - if (m_dynamicsWorld) - { - btScalar mass = 1.f; - btTransform startTransform; - startTransform.setIdentity(); - btVector3 camPos = getCameraPosition(); - startTransform.setOrigin(camPos); - - setShootBoxShape (); - - btAssert((!m_shootBoxShape || m_shootBoxShape->getShapeType() != INVALID_SHAPE_PROXYTYPE)); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - m_shootBoxShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - - btFractureBody* body = new btFractureBody(mass,0,m_shootBoxShape,localInertia,&mass,1,m_dynamicsWorld); - - body->setWorldTransform(startTransform); - - m_dynamicsWorld->addRigidBody(body); - - - body->setLinearFactor(btVector3(1,1,1)); - //body->setRestitution(1); - - btVector3 linVel(destination[0]-camPos[0],destination[1]-camPos[1],destination[2]-camPos[2]); - linVel.normalize(); - linVel*=m_ShootBoxInitialSpeed; - - body->getWorldTransform().setOrigin(camPos); - body->getWorldTransform().setRotation(btQuaternion(0,0,0,1)); - body->setLinearVelocity(linVel); - body->setAngularVelocity(btVector3(0,0,0)); - body->setCcdMotionThreshold(1.); - body->setCcdSweptSphereRadius(0.2f); - - } -} - - - - - - -void FractureDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - void showMessage(); - - public: - - FractureDemo() - { - } - virtual ~FractureDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void keyboardUpCallback(unsigned char key, int x, int y); - - virtual void clientResetScene(); - - static DemoApplication* Create() - { - FractureDemo* demo = new FractureDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - void shootBox(const btVector3& destination); - -}; - -#endif //FRACTURE_DEMO_H - diff --git a/Demos/FractureDemo/Win32FractureDemo.cpp b/Demos/FractureDemo/Win32FractureDemo.cpp deleted file mode 100644 index 903986bce..000000000 --- a/Demos/FractureDemo/Win32FractureDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2011 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "FractureDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new FractureDemo(); -} - -#endif diff --git a/Demos/FractureDemo/btFractureBody.cpp b/Demos/FractureDemo/btFractureBody.cpp deleted file mode 100644 index 4ae742ffd..000000000 --- a/Demos/FractureDemo/btFractureBody.cpp +++ /dev/null @@ -1,139 +0,0 @@ - -#include "btFractureBody.h" -#include "BulletCollision/CollisionDispatch/btCollisionWorld.h" -#include "BulletCollision/CollisionShapes/btCompoundShape.h" -#include "BulletDynamics/Dynamics/btDynamicsWorld.h" - - - -void btFractureBody::recomputeConnectivity(btCollisionWorld* world) -{ - m_connections.clear(); - //@todo use the AABB tree to avoid N^2 checks - - if (getCollisionShape()->isCompound()) - { - btCompoundShape* compound = (btCompoundShape*)getCollisionShape(); - for (int i=0;igetNumChildShapes();i++) - { - for (int j=i+1;jgetNumChildShapes();j++) - { - - struct MyContactResultCallback : public btCollisionWorld::ContactResultCallback - { - bool m_connected; - btScalar m_margin; - MyContactResultCallback() :m_connected(false),m_margin(0.05) - { - } - virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) - { - if (cp.getDistance()<=m_margin) - m_connected = true; - return 1.f; - } - }; - - MyContactResultCallback result; - - btCollisionObject obA; - obA.setWorldTransform(compound->getChildTransform(i)); - obA.setCollisionShape(compound->getChildShape(i)); - btCollisionObject obB; - obB.setWorldTransform(compound->getChildTransform(j)); - obB.setCollisionShape(compound->getChildShape(j)); - world->contactPairTest(&obA,&obB,result); - if (result.m_connected) - { - btConnection tmp; - tmp.m_childIndex0 = i; - tmp.m_childIndex1 = j; - tmp.m_childShape0 = compound->getChildShape(i); - tmp.m_childShape1 = compound->getChildShape(j); - tmp.m_strength = 1.f;//?? - m_connections.push_back(tmp); - } - } - } - } - - -} - -btCompoundShape* btFractureBody::shiftTransformDistributeMass(btCompoundShape* boxCompound,btScalar mass,btTransform& shift) -{ - - btVector3 principalInertia; - - btScalar* masses = new btScalar[boxCompound->getNumChildShapes()]; - for (int j=0;jgetNumChildShapes();j++) - { - //evenly distribute mass - masses[j]=mass/boxCompound->getNumChildShapes(); - } - - return shiftTransform(boxCompound,masses,shift,principalInertia); - -} - - -btCompoundShape* btFractureBody::shiftTransform(btCompoundShape* boxCompound,btScalar* masses,btTransform& shift, btVector3& principalInertia) -{ - btTransform principal; - - boxCompound->calculatePrincipalAxisTransform(masses,principal,principalInertia); - - - ///create a new compound with world transform/center of mass properly aligned with the principal axis - - ///non-recursive compound shapes perform better - -#ifdef USE_RECURSIVE_COMPOUND - - btCompoundShape* newCompound = new btCompoundShape(); - newCompound->addChildShape(principal.inverse(),boxCompound); - newBoxCompound = newCompound; - //m_collisionShapes.push_back(newCompound); - - //btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - //btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,newCompound,principalInertia); - -#else -#ifdef CHANGE_COMPOUND_INPLACE - newBoxCompound = boxCompound; - for (int i=0;igetNumChildShapes();i++) - { - btTransform newChildTransform = principal.inverse()*boxCompound->getChildTransform(i); - ///updateChildTransform is really slow, because it re-calculates the AABB each time. todo: add option to disable this update - boxCompound->updateChildTransform(i,newChildTransform); - } - bool isDynamic = (mass != 0.f); - btVector3 localInertia(0,0,0); - if (isDynamic) - boxCompound->calculateLocalInertia(mass,localInertia); - -#else - ///creation is faster using a new compound to store the shifted children - btCompoundShape* newBoxCompound = new btCompoundShape(); - for (int i=0;igetNumChildShapes();i++) - { - btTransform newChildTransform = principal.inverse()*boxCompound->getChildTransform(i); - ///updateChildTransform is really slow, because it re-calculates the AABB each time. todo: add option to disable this update - newBoxCompound->addChildShape(newChildTransform,boxCompound->getChildShape(i)); - } - - - -#endif - -#endif//USE_RECURSIVE_COMPOUND - - shift = principal; - return newBoxCompound; -} - - - - - - diff --git a/Demos/FractureDemo/btFractureBody.h b/Demos/FractureDemo/btFractureBody.h deleted file mode 100644 index 922db3c22..000000000 --- a/Demos/FractureDemo/btFractureBody.h +++ /dev/null @@ -1,78 +0,0 @@ - -#ifndef BT_FRACTURE_BODY -#define BT_FRACTURE_BODY - -class btCollisionShape; -class btDynamicsWorld; -class btCollisionWorld; -class btCompoundShape; -class btManifoldPoint; - -#include "LinearMath/btAlignedObjectArray.h" -#include "BulletDynamics/Dynamics/btRigidBody.h" - -#define CUSTOM_FRACTURE_TYPE (btRigidBody::CO_USER_TYPE+1) - - -struct btConnection -{ - - btCollisionShape* m_childShape0; - btCollisionShape* m_childShape1; - int m_childIndex0; - int m_childIndex1; - btScalar m_strength; -}; - -class btFractureBody : public btRigidBody -{ - //connections -public: - - btDynamicsWorld* m_world; - btAlignedObjectArray m_masses; - btAlignedObjectArray m_connections; - - - - btFractureBody( const btRigidBodyConstructionInfo& constructionInfo, btDynamicsWorld* world) - :btRigidBody(constructionInfo), - m_world(world) - { - m_masses.push_back(constructionInfo.m_mass); - m_internalType=CUSTOM_FRACTURE_TYPE+CO_RIGID_BODY; - } - - - - ///btRigidBody constructor for backwards compatibility. - ///To specify friction (etc) during rigid body construction, please use the other constructor (using btRigidBodyConstructionInfo) - btFractureBody( btScalar mass, btMotionState* motionState, btCollisionShape* collisionShape, const btVector3& localInertia, btScalar* masses, int numMasses, btDynamicsWorld* world) - :btRigidBody(mass,motionState,collisionShape,localInertia), - m_world(world) - { - - for (int i=0;igetNumManifolds(); - - ///first build the islands based on axis aligned bounding box overlap - - btUnionFind unionFind; - - int index = 0; - { - - int i; - for (i=0;iisStaticOrKinematicObject()) - { - collisionObject->setIslandTag(index++); - } else - { - collisionObject->setIslandTag(-1); - } -#else - collisionObject->setIslandTag(i); - index=i+1; -#endif - } - } - - unionFind.reset(index); - - int numElem = unionFind.getNumElements(); - - for (int i=0;igetManifoldByIndexInternal(i); - if (!manifold->getNumContacts()) - continue; - - btScalar minDist = 1e30f; - for (int v=0;vgetNumContacts();v++) - { - minDist = btMin(minDist,manifold->getContactPoint(v).getDistance()); - } - if (minDist>0.) - continue; - - btCollisionObject* colObj0 = (btCollisionObject*)manifold->getBody0(); - btCollisionObject* colObj1 = (btCollisionObject*)manifold->getBody1(); - int tag0 = (colObj0)->getIslandTag(); - int tag1 = (colObj1)->getIslandTag(); - //btRigidBody* body0 = btRigidBody::upcast(colObj0); - //btRigidBody* body1 = btRigidBody::upcast(colObj1); - - - if (!colObj0->isStaticOrKinematicObject() && !colObj1->isStaticOrKinematicObject()) - { - unionFind.unite(tag0, tag1); - } - } - - - - - numElem = unionFind.getNumElements(); - - - - index=0; - for (int ai=0;aiisStaticOrKinematicObject()) - { - int tag = unionFind.find(index); - - collisionObject->setIslandTag( tag); - - //Set the correct object offset in Collision Object Array -#if STATIC_SIMULATION_ISLAND_OPTIMIZATION - unionFind.getElement(index).m_sz = ai; -#endif //STATIC_SIMULATION_ISLAND_OPTIMIZATION - - index++; - } - } - unionFind.sortIslands(); - - - - int endIslandIndex=1; - int startIslandIndex; - - btAlignedObjectArray removedObjects; - - ///iterate over all islands - for ( startIslandIndex=0;startIslandIndexgetInternalType()& CUSTOM_FRACTURE_TYPE) - { - fractureObjectIndex = i; - } - btRigidBody* otherObject = btRigidBody::upcast(colObj0); - if (!otherObject || !otherObject->getInvMass()) - continue; - numObjects++; - } - - ///Then for each island that contains at least two objects and one fracture object - if (fractureObjectIndex>=0 && numObjects>1) - { - - btFractureBody* fracObj = (btFractureBody*)getCollisionObjectArray()[fractureObjectIndex]; - - ///glueing objects means creating a new compound and removing the old objects - ///delay the removal of old objects to avoid array indexing problems - removedObjects.push_back(fracObj); - m_fractureBodies.remove(fracObj); - - btAlignedObjectArray massArray; - - btAlignedObjectArray oldImpulses; - btAlignedObjectArray oldCenterOfMassesWS; - - oldImpulses.push_back(fracObj->getLinearVelocity()/1./fracObj->getInvMass()); - oldCenterOfMassesWS.push_back(fracObj->getCenterOfMassPosition()); - - btScalar totalMass = 0.f; - - - btCompoundShape* compound = new btCompoundShape(); - if (fracObj->getCollisionShape()->isCompound()) - { - btTransform tr; - tr.setIdentity(); - btCompoundShape* oldCompound = (btCompoundShape*)fracObj->getCollisionShape(); - for (int c=0;cgetNumChildShapes();c++) - { - compound->addChildShape(oldCompound->getChildTransform(c),oldCompound->getChildShape(c)); - massArray.push_back(fracObj->m_masses[c]); - totalMass+=fracObj->m_masses[c]; - } - - } else - { - btTransform tr; - tr.setIdentity(); - compound->addChildShape(tr,fracObj->getCollisionShape()); - massArray.push_back(fracObj->m_masses[0]); - totalMass+=fracObj->m_masses[0]; - } - - for (idx=startIslandIndex;idxgetInvMass()) - continue; - - - oldImpulses.push_back(otherObject->getLinearVelocity()*(1.f/otherObject->getInvMass())); - oldCenterOfMassesWS.push_back(otherObject->getCenterOfMassPosition()); - - removedObjects.push_back(otherObject); - m_fractureBodies.remove((btFractureBody*)otherObject); - - btScalar curMass = 1.f/otherObject->getInvMass(); - - - if (otherObject->getCollisionShape()->isCompound()) - { - btTransform tr; - btCompoundShape* oldCompound = (btCompoundShape*)otherObject->getCollisionShape(); - for (int c=0;cgetNumChildShapes();c++) - { - tr = fracObj->getWorldTransform().inverseTimes(otherObject->getWorldTransform()*oldCompound->getChildTransform(c)); - compound->addChildShape(tr,oldCompound->getChildShape(c)); - massArray.push_back(curMass/(btScalar)oldCompound->getNumChildShapes()); - - } - } else - { - btTransform tr; - tr = fracObj->getWorldTransform().inverseTimes(otherObject->getWorldTransform()); - compound->addChildShape(tr,otherObject->getCollisionShape()); - massArray.push_back(curMass); - } - totalMass+=curMass; - } - - - - btTransform shift; - shift.setIdentity(); - btCompoundShape* newCompound = btFractureBody::shiftTransformDistributeMass(compound,totalMass,shift); - int numChildren = newCompound->getNumChildShapes(); - btAssert(numChildren == massArray.size()); - - btVector3 localInertia; - newCompound->calculateLocalInertia(totalMass,localInertia); - btFractureBody* newBody = new btFractureBody(totalMass,0,newCompound,localInertia, &massArray[0], numChildren,this); - newBody->recomputeConnectivity(this); - newBody->setWorldTransform(fracObj->getWorldTransform()*shift); - - //now the linear/angular velocity is still zero, apply the impulses - - for (int i=0;igetCenterOfMassPosition(); - const btVector3& imp = oldImpulses[i]; - newBody->applyImpulse(imp, rel_pos); - } - - addRigidBody(newBody); - - - } - - - } - - //remove the objects from the world at the very end, - //otherwise the island tags would not match the world collision object array indices anymore - while (removedObjects.size()) - { - btCollisionObject* otherCollider = removedObjects[removedObjects.size()-1]; - removedObjects.pop_back(); - - btRigidBody* otherObject = btRigidBody::upcast(otherCollider); - if (!otherObject || !otherObject->getInvMass()) - continue; - removeRigidBody(otherObject); - } - -} - - -struct btFracturePair -{ - btFractureBody* m_fracObj; - btAlignedObjectArray m_contactManifolds; -}; - - - -void btFractureDynamicsWorld::solveConstraints(btContactSolverInfo& solverInfo) -{ - // todo: after fracture we should run the solver again for better realism - // for example - // save all velocities and if one or more objects fracture: - // 1) revert all velocties - // 2) apply impulses for the fracture bodies at the contact locations - // 3)and run the constaint solver again - - btDiscreteDynamicsWorld::solveConstraints(solverInfo); - - fractureCallback(); -} - -btFractureBody* btFractureDynamicsWorld::addNewBody(const btTransform& oldTransform,btScalar* masses, btCompoundShape* oldCompound) -{ - int i; - - btTransform shift; - shift.setIdentity(); - btVector3 localInertia; - btCompoundShape* newCompound = btFractureBody::shiftTransform(oldCompound,masses,shift,localInertia); - btScalar totalMass = 0; - for (i=0;igetNumChildShapes();i++) - totalMass += masses[i]; - //newCompound->calculateLocalInertia(totalMass,localInertia); - - btFractureBody* newBody = new btFractureBody(totalMass,0,newCompound,localInertia, masses,newCompound->getNumChildShapes(), this); - newBody->recomputeConnectivity(this); - - newBody->setCollisionFlags(newBody->getCollisionFlags()|btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - newBody->setWorldTransform(oldTransform*shift); - addRigidBody(newBody); - return newBody; -} - -void btFractureDynamicsWorld::addRigidBody(btRigidBody* body) -{ - if (body->getInternalType() & CUSTOM_FRACTURE_TYPE) - { - btFractureBody* fbody = (btFractureBody*)body; - m_fractureBodies.push_back(fbody); - } - btDiscreteDynamicsWorld::addRigidBody(body); -} - -void btFractureDynamicsWorld::removeRigidBody(btRigidBody* body) -{ - if (body->getInternalType() & CUSTOM_FRACTURE_TYPE) - { - btFractureBody* fbody = (btFractureBody*)body; - btAlignedObjectArray tmpConstraints; - - for (int i=0;igetNumConstraintRefs();i++) - { - tmpConstraints.push_back(fbody->getConstraintRef(i)); - } - - //remove all constraints attached to this rigid body too - for (int i=0;igetCollisionShape()->isCompound()) - return; - - btCompoundShape* compound = (btCompoundShape*)fracObj->getCollisionShape(); - int numChildren = compound->getNumChildShapes(); - - if (numChildren<=1) - return; - - //compute connectivity - btUnionFind unionFind; - - btAlignedObjectArray tags; - tags.resize(numChildren); - int i, index = 0; - for ( i=0;im_connections.size();i++) - { - btConnection& connection = fracObj->m_connections[i]; - if (connection.m_strength > 0.) - { - int tag0 = tags[connection.m_childIndex0]; - int tag1 = tags[connection.m_childIndex1]; - unionFind.unite(tag0, tag1); - } - } - numElem = unionFind.getNumElements(); - - index=0; - for (int ai=0;ai removedObjects; - - int numIslands = 0; - - for ( startIslandIndex=0;startIslandIndex masses; - - int idx; - for (idx=startIslandIndex;idxgetChildShape(i); - newCompound->addChildShape(compound->getChildTransform(i),compound->getChildShape(i)); - masses.push_back(fracObj->m_masses[i]); - numShapes++; - } - if (numShapes) - { - btFractureBody* newBody = addNewBody(fracObj->getWorldTransform(),&masses[0],newCompound); - newBody->setLinearVelocity(fracObj->getLinearVelocity()); - newBody->setAngularVelocity(fracObj->getAngularVelocity()); - - numIslands++; - } - } - - - - - - removeRigidBody(fracObj);//should it also be removed from the array? - - -} - -#include - - -void btFractureDynamicsWorld::fractureCallback( ) -{ - - btAlignedObjectArray sFracturePairs; - - if (!m_fracturingMode) - { - glueCallback(); - return; - } - - int numManifolds = getDispatcher()->getNumManifolds(); - - sFracturePairs.clear(); - - - for (int i=0;igetManifoldByIndexInternal(i); - if (!manifold->getNumContacts()) - continue; - - btScalar totalImpact = 0.f; - for (int p=0;pgetNumContacts();p++) - { - totalImpact += manifold->getContactPoint(p).m_appliedImpulse; - } - - -// printf("totalImpact=%f\n",totalImpact); - - static float maxImpact = 0; - if (totalImpact>maxImpact) - maxImpact = totalImpact; - - //some threshold otherwise resting contact would break objects after a while - if (totalImpact < 40.f) - continue; - - // printf("strong impact\n"); - - - //@todo: add better logic to decide what parts to fracture - //For example use the idea from the SIGGRAPH talk about the fracture in the movie 2012: - // - //Breaking thresholds can be stored as connectivity information between child shapes in the fracture object - // - //You can calculate some "impact value" by simulating all the individual child shapes - //as rigid bodies, without constraints, running it in a separate simulation world - //(or by running the constraint solver without actually modifying the dynamics world) - //Then measure some "impact value" using the offset and applied impulse for each child shape - //weaken the connections based on this "impact value" and only break - //if this impact value exceeds the breaking threshold. - //you can propagate the weakening and breaking of connections using the connectivity information - - int f0 = m_fractureBodies.findLinearSearch((btFractureBody*)manifold->getBody0()); - int f1 = m_fractureBodies.findLinearSearch((btFractureBody*)manifold->getBody1()); - - if (f0 == f1 == m_fractureBodies.size()) - continue; - - - if (f0getBody1(); - // btRigidBody* otherOb = btRigidBody::upcast(colOb); - // if (!otherOb->getInvMass()) - // continue; - - int pi=-1; - - for (int p=0;pgetBody0(); - btRigidBody* otherOb = btRigidBody::upcast(colOb); - // if (!otherOb->getInvMass()) - // continue; - - - int pi=-1; - - for (int p=0;pgetCollisionShape()->isCompound()) - { - btTransform tr; - tr.setIdentity(); - btCompoundShape* oldCompound = (btCompoundShape*)sFracturePairs[i].m_fracObj->getCollisionShape(); - if (oldCompound->getNumChildShapes()>1) - { - bool needsBreakingCheck = false; - - - //weaken/break the connections - - //@todo: propagate along the connection graph - for (int j=0;jgetNumContacts();k++) - { - btManifoldPoint& pt = manifold->getContactPoint(k); - if (manifold->getBody0()==sFracturePairs[i].m_fracObj) - { - for (int f=0;fm_connections.size();f++) - { - btConnection& connection = sFracturePairs[i].m_fracObj->m_connections[f]; - if ( (connection.m_childIndex0 == pt.m_index0) || - (connection.m_childIndex1 == pt.m_index0) - ) - { - connection.m_strength -= pt.m_appliedImpulse; - if (connection.m_strength<0) - { - //remove or set to zero - connection.m_strength=0.f; - needsBreakingCheck = true; - } - } - } - } else - { - for (int f=0;fm_connections.size();f++) - { - btConnection& connection = sFracturePairs[i].m_fracObj->m_connections[f]; - if ( (connection.m_childIndex0 == pt.m_index1) || - (connection.m_childIndex1 == pt.m_index1) - ) - { - connection.m_strength -= pt.m_appliedImpulse; - if (connection.m_strength<0) - { - //remove or set to zero - connection.m_strength=0.f; - needsBreakingCheck = true; - } - } - } - } - } - } - - if (needsBreakingCheck) - { - breakDisconnectedParts(sFracturePairs[i].m_fracObj); - } - } - - } - - } - } - - sFracturePairs.clear(); - -} - diff --git a/Demos/FractureDemo/btFractureDynamicsWorld.h b/Demos/FractureDemo/btFractureDynamicsWorld.h deleted file mode 100644 index 255487729..000000000 --- a/Demos/FractureDemo/btFractureDynamicsWorld.h +++ /dev/null @@ -1,51 +0,0 @@ -#ifndef _BT_FRACTURE_DYNAMICS_WORLD_H -#define _BT_FRACTURE_DYNAMICS_WORLD_H - -#include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h" -#include "LinearMath/btAlignedObjectArray.h" - -class btFractureBody; -class btCompoundShape; -class btTransform; - - -///The btFractureDynamicsWorld class enabled basic glue and fracture of objects. -///If/once this implementation is stablized/tested we might merge it into btDiscreteDynamicsWorld and remove the class. -class btFractureDynamicsWorld : public btDiscreteDynamicsWorld -{ - btAlignedObjectArray m_fractureBodies; - - bool m_fracturingMode; - - btFractureBody* addNewBody(const btTransform& oldTransform,btScalar* masses, btCompoundShape* oldCompound); - - void breakDisconnectedParts( btFractureBody* fracObj); - -public: - - btFractureDynamicsWorld ( btDispatcher* dispatcher,btBroadphaseInterface* pairCache,btConstraintSolver* constraintSolver,btCollisionConfiguration* collisionConfiguration); - - virtual void addRigidBody(btRigidBody* body); - - virtual void removeRigidBody(btRigidBody* body); - - void solveConstraints(btContactSolverInfo& solverInfo); - - ///either fracture or glue (!fracture) - void setFractureMode(bool fracture) - { - m_fracturingMode = fracture; - } - - bool getFractureMode() const { return m_fracturingMode;} - - ///normally those callbacks are called internally by the 'solveConstraints' - void glueCallback(); - - ///normally those callbacks are called internally by the 'solveConstraints' - void fractureCallback(); - -}; - -#endif //_BT_FRACTURE_DYNAMICS_WORLD_H - diff --git a/Demos/FractureDemo/main.cpp b/Demos/FractureDemo/main.cpp deleted file mode 100644 index 8988b6040..000000000 --- a/Demos/FractureDemo/main.cpp +++ /dev/null @@ -1,42 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "FractureDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - -int main(int argc,char** argv) -{ - GLDebugDrawer gDebugDrawer; - - - FractureDemo ccdDemo; - ccdDemo.initPhysics(); - ccdDemo.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/GenericJointDemo/CMakeLists.txt b/Demos/GenericJointDemo/CMakeLists.txt deleted file mode 100644 index afcd423cb..000000000 --- a/Demos/GenericJointDemo/CMakeLists.txt +++ /dev/null @@ -1,68 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - -IF (USE_GLUT) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${GLUT_INCLUDE_DIR} - ) - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppGenericJointDemo - GenericJointDemo.cpp - GenericJointDemo.h - Ragdoll.cpp - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppGenericJointDemo - GenericJointDemo.cpp - GenericJointDemo.h - Ragdoll.cpp - main.cpp - ) - ENDIF() - -ELSE(USE_GLUT) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ) - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppGenericJointDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32GenericJointDemo.cpp - GenericJointDemo.cpp - GenericJointDemo.h - Ragdoll.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - - ) -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppGenericJointDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppGenericJointDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppGenericJointDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/GenericJointDemo/GenericJointDemo.cpp b/Demos/GenericJointDemo/GenericJointDemo.cpp deleted file mode 100644 index 35e24c1f7..000000000 --- a/Demos/GenericJointDemo/GenericJointDemo.cpp +++ /dev/null @@ -1,135 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Ragdoll Demo -Copyright (c) 2007 Starbreeze Studios - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -Originally Written by: Marten Svanfeldt -ReWritten by: Francisco León -*/ - - - -#include "btBulletDynamicsCommon.h" -#include "GlutStuff.h" -#include "GL_ShapeDrawer.h" - -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" -#include "GenericJointDemo.h" - - - -GLDebugDrawer debugDrawer; - - - - - - -void GenericJointDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - // Setup the basic world - - btDefaultCollisionConfiguration * collision_config = new btDefaultCollisionConfiguration(); - - btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collision_config); - - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax(10000,10000,10000); - btBroadphaseInterface* overlappingPairCache = new btAxisSweep3 (worldAabbMin, worldAabbMax); - - btConstraintSolver* constraintSolver = new btSequentialImpulseConstraintSolver; - - - m_dynamicsWorld = new btDiscreteDynamicsWorld(dispatcher,overlappingPairCache,constraintSolver,collision_config); - - m_dynamicsWorld->setGravity(btVector3(0,-30,0)); - - m_dynamicsWorld->setDebugDrawer(&debugDrawer); - - // Setup a big ground box - { - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(200.),btScalar(10.),btScalar(200.))); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-15,0)); - localCreateRigidBody(btScalar(0.),groundTransform,groundShape); - } - - // Spawn one ragdoll - spawnRagdoll(); - - clientResetScene(); -} - -void GenericJointDemo::spawnRagdoll(bool random) -{ - RagDoll* ragDoll = new RagDoll (m_dynamicsWorld, btVector3 (0,0,10),5.f); - m_ragdolls.push_back(ragDoll); -} - -void GenericJointDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - float minFPS = 1000000.f/60.f; - if (ms > minFPS) - ms = minFPS; - - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - glFlush(); - - swapBuffers(); -} - -void GenericJointDemo::displayCallback() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - swapBuffers(); -} - -void GenericJointDemo::keyboardCallback(unsigned char key, int x, int y) -{ - switch (key) - { - case 'e': - spawnRagdoll(true); - break; - default: - DemoApplication::keyboardCallback(key, x, y); - } - - -} diff --git a/Demos/GenericJointDemo/GenericJointDemo.h b/Demos/GenericJointDemo/GenericJointDemo.h deleted file mode 100644 index 68a11c052..000000000 --- a/Demos/GenericJointDemo/GenericJointDemo.h +++ /dev/null @@ -1,51 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -GenericJointDemo -Copyright (c) 2007 Starbreeze Studios - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -Written by: Marten Svanfeldt -*/ - -#ifndef GENERIGJOINTDEMO_H -#define GENERIGJOINTDEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -#include "LinearMath/btAlignedObjectArray.h" -#include "Ragdoll.h" - -class GenericJointDemo : public PlatformDemoApplication -{ - - btAlignedObjectArray m_ragdolls; - -public: - void initPhysics(); - - void spawnRagdoll(bool random = false); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void keyboardCallback(unsigned char key, int x, int y); -}; - - -#endif diff --git a/Demos/GenericJointDemo/Ragdoll.cpp b/Demos/GenericJointDemo/Ragdoll.cpp deleted file mode 100644 index 0229f5ab5..000000000 --- a/Demos/GenericJointDemo/Ragdoll.cpp +++ /dev/null @@ -1,373 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Ragdoll Demo -Copyright (c) 2007 Starbreeze Studios - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -Written by: Marten Svanfeldt -*/ - -#include "Ragdoll.h" - -//#define RIGID 1 - -RagDoll::RagDoll (btDynamicsWorld* ownerWorld, const btVector3& positionOffset, - btScalar scale_ragdoll) : m_ownerWorld (ownerWorld) -{ - - - // Setup the geometry - m_shapes[BODYPART_PELVIS] = new btCapsuleShape( - btScalar(scale_ragdoll*0.15), btScalar(scale_ragdoll*0.20)); - m_shapes[BODYPART_SPINE] = new btCapsuleShape( - btScalar(scale_ragdoll*0.15), btScalar(scale_ragdoll*0.28)); - m_shapes[BODYPART_HEAD] = new btCapsuleShape(btScalar(scale_ragdoll*0.10), btScalar(scale_ragdoll*0.05)); - m_shapes[BODYPART_LEFT_UPPER_LEG] = new btCapsuleShape(btScalar(scale_ragdoll*0.07), btScalar(scale_ragdoll*0.45)); - m_shapes[BODYPART_LEFT_LOWER_LEG] = new btCapsuleShape(btScalar(scale_ragdoll*0.05), btScalar(scale_ragdoll*0.37)); - m_shapes[BODYPART_RIGHT_UPPER_LEG] = new btCapsuleShape(btScalar(scale_ragdoll*0.07), btScalar(scale_ragdoll*0.45)); - m_shapes[BODYPART_RIGHT_LOWER_LEG] = new btCapsuleShape(btScalar(scale_ragdoll*0.05), btScalar(scale_ragdoll*0.37)); - m_shapes[BODYPART_LEFT_UPPER_ARM] = new btCapsuleShape(btScalar(scale_ragdoll*0.05), btScalar(scale_ragdoll*0.33)); - m_shapes[BODYPART_LEFT_LOWER_ARM] = new btCapsuleShape(btScalar(scale_ragdoll*0.04), btScalar(scale_ragdoll*0.25)); - m_shapes[BODYPART_RIGHT_UPPER_ARM] = new btCapsuleShape(btScalar(scale_ragdoll*0.05), btScalar(scale_ragdoll*0.33)); - m_shapes[BODYPART_RIGHT_LOWER_ARM] = new btCapsuleShape(btScalar(scale_ragdoll*0.04), btScalar(scale_ragdoll*0.25)); - - // Setup all the rigid bodies - btTransform offset; offset.setIdentity(); - offset.setOrigin(positionOffset); - - btTransform transform; - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(scale_ragdoll*1.), btScalar(0.))); - m_bodies[BODYPART_PELVIS] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_PELVIS]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(scale_ragdoll*1.2), btScalar(0.))); - m_bodies[BODYPART_SPINE] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_SPINE]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(scale_ragdoll*1.6), btScalar(0.))); - m_bodies[BODYPART_HEAD] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_HEAD]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18*scale_ragdoll), btScalar(0.65*scale_ragdoll), -btScalar(0.))); - m_bodies[BODYPART_LEFT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18*scale_ragdoll), btScalar(0.2*scale_ragdoll), btScalar(0.))); - m_bodies[BODYPART_LEFT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18*scale_ragdoll), btScalar(0.65*scale_ragdoll), btScalar(0.))); - m_bodies[BODYPART_RIGHT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18*scale_ragdoll), btScalar(0.2*scale_ragdoll), btScalar(0.))); - m_bodies[BODYPART_RIGHT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.35*scale_ragdoll), btScalar(1.45*scale_ragdoll), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); - m_bodies[BODYPART_LEFT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.7*scale_ragdoll), btScalar(1.45*scale_ragdoll), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); - m_bodies[BODYPART_LEFT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.35*scale_ragdoll), btScalar(1.45*scale_ragdoll), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-SIMD_HALF_PI); - m_bodies[BODYPART_RIGHT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.7*scale_ragdoll), btScalar(1.45*scale_ragdoll), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-SIMD_HALF_PI); - m_bodies[BODYPART_RIGHT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_ARM]); - - // Setup some damping on the m_bodies - for (int i = 0; i < BODYPART_COUNT; ++i) - { - m_bodies[i]->setDamping(0.05f, 0.85f); - m_bodies[i]->setDeactivationTime(0.8f); - m_bodies[i]->setSleepingThresholds(1.6f, 2.5f); - } - -///////////////////////////// SETTING THE CONSTRAINTS /////////////////////////////////////////////7777 - // Now setup the constraints - btGeneric6DofConstraint * joint6DOF; - btTransform localA, localB; - bool useLinearReferenceFrameA = true; -/// ******* SPINE HEAD ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.), btScalar(0.30*scale_ragdoll), btScalar(0.))); - - localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14*scale_ragdoll), btScalar(0.))); - - joint6DOF = new btGeneric6DofConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_HEAD], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_PI*0.3f,-SIMD_EPSILON,-SIMD_PI*0.3f)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.5f,SIMD_EPSILON,SIMD_PI*0.3f)); -#endif - m_joints[JOINT_SPINE_HEAD] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_SPINE_HEAD], true); - } -/// *************************** /// - - - - -/// ******* LEFT SHOULDER ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(-0.2*scale_ragdoll), btScalar(0.15*scale_ragdoll), btScalar(0.))); - - localB.getBasis().setEulerZYX(SIMD_HALF_PI,0,-SIMD_HALF_PI); - localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18*scale_ragdoll), btScalar(0.))); - - joint6DOF = new btGeneric6DofConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_LEFT_UPPER_ARM], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_PI*0.8f,-SIMD_EPSILON,-SIMD_PI*0.5f)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.8f,SIMD_EPSILON,SIMD_PI*0.5f)); -#endif - m_joints[JOINT_LEFT_SHOULDER] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_SHOULDER], true); - } -/// *************************** /// - - -/// ******* RIGHT SHOULDER ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.2*scale_ragdoll), btScalar(0.15*scale_ragdoll), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); - localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18*scale_ragdoll), btScalar(0.))); - joint6DOF = new btGeneric6DofConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_RIGHT_UPPER_ARM], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_PI*0.8f,-SIMD_EPSILON,-SIMD_PI*0.5f)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.8f,SIMD_EPSILON,SIMD_PI*0.5f)); -#endif - m_joints[JOINT_RIGHT_SHOULDER] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_SHOULDER], true); - } -/// *************************** /// - -/// ******* LEFT ELBOW ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18*scale_ragdoll), btScalar(0.))); - localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14*scale_ragdoll), btScalar(0.))); - joint6DOF = new btGeneric6DofConstraint (*m_bodies[BODYPART_LEFT_UPPER_ARM], *m_bodies[BODYPART_LEFT_LOWER_ARM], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.7f,SIMD_EPSILON,SIMD_EPSILON)); -#endif - m_joints[JOINT_LEFT_ELBOW] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_ELBOW], true); - } -/// *************************** /// - -/// ******* RIGHT ELBOW ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18*scale_ragdoll), btScalar(0.))); - localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14*scale_ragdoll), btScalar(0.))); - joint6DOF = new btGeneric6DofConstraint (*m_bodies[BODYPART_RIGHT_UPPER_ARM], *m_bodies[BODYPART_RIGHT_LOWER_ARM], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.7,SIMD_EPSILON,SIMD_EPSILON)); -#endif - - m_joints[JOINT_RIGHT_ELBOW] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_ELBOW], true); - } -/// *************************** /// - - -/// ******* PELVIS ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); - localA.setOrigin(btVector3(btScalar(0.), btScalar(0.15*scale_ragdoll), btScalar(0.))); - localB.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); - localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.15*scale_ragdoll), btScalar(0.))); - joint6DOF = new btGeneric6DofConstraint (*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_SPINE], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_PI*0.2,-SIMD_EPSILON,-SIMD_PI*0.3)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.2,SIMD_EPSILON,SIMD_PI*0.6)); -#endif - m_joints[JOINT_PELVIS_SPINE] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_PELVIS_SPINE], true); - } -/// *************************** /// - -/// ******* LEFT HIP ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(-0.18*scale_ragdoll), btScalar(-0.10*scale_ragdoll), btScalar(0.))); - - localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225*scale_ragdoll), btScalar(0.))); - - joint6DOF = new btGeneric6DofConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_LEFT_UPPER_LEG], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_HALF_PI*0.5,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_HALF_PI*0.8,SIMD_EPSILON,SIMD_HALF_PI*0.6f)); -#endif - m_joints[JOINT_LEFT_HIP] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_HIP], true); - } -/// *************************** /// - - -/// ******* RIGHT HIP ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.18*scale_ragdoll), btScalar(-0.10*scale_ragdoll), btScalar(0.))); - localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225*scale_ragdoll), btScalar(0.))); - - joint6DOF = new btGeneric6DofConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_RIGHT_UPPER_LEG], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_HALF_PI*0.5,-SIMD_EPSILON,-SIMD_HALF_PI*0.6f)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_HALF_PI*0.8,SIMD_EPSILON,SIMD_EPSILON)); -#endif - m_joints[JOINT_RIGHT_HIP] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_HIP], true); - } -/// *************************** /// - - -/// ******* LEFT KNEE ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225*scale_ragdoll), btScalar(0.))); - localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185*scale_ragdoll), btScalar(0.))); - joint6DOF = new btGeneric6DofConstraint (*m_bodies[BODYPART_LEFT_UPPER_LEG], *m_bodies[BODYPART_LEFT_LOWER_LEG], localA, localB,useLinearReferenceFrameA); -// -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.7f,SIMD_EPSILON,SIMD_EPSILON)); -#endif - m_joints[JOINT_LEFT_KNEE] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_KNEE], true); - } -/// *************************** /// - -/// ******* RIGHT KNEE ******** /// - { - localA.setIdentity(); localB.setIdentity(); - - localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225*scale_ragdoll), btScalar(0.))); - localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185*scale_ragdoll), btScalar(0.))); - joint6DOF = new btGeneric6DofConstraint (*m_bodies[BODYPART_RIGHT_UPPER_LEG], *m_bodies[BODYPART_RIGHT_LOWER_LEG], localA, localB,useLinearReferenceFrameA); - -#ifdef RIGID - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_EPSILON,SIMD_EPSILON,SIMD_EPSILON)); -#else - joint6DOF->setAngularLowerLimit(btVector3(-SIMD_EPSILON,-SIMD_EPSILON,-SIMD_EPSILON)); - joint6DOF->setAngularUpperLimit(btVector3(SIMD_PI*0.7f,SIMD_EPSILON,SIMD_EPSILON)); -#endif - m_joints[JOINT_RIGHT_KNEE] = joint6DOF; - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_KNEE], true); - } -/// *************************** /// - -} - - -RagDoll::~RagDoll() -{ - int i; - - // Remove all constraints - for (i = 0; i < JOINT_COUNT; ++i) - { - m_ownerWorld->removeConstraint(m_joints[i]); - delete m_joints[i]; m_joints[i] = 0; - } - - // Remove all bodies and shapes - for (i = 0; i < BODYPART_COUNT; ++i) - { - m_ownerWorld->removeRigidBody(m_bodies[i]); - - delete m_bodies[i]->getMotionState(); - - delete m_bodies[i]; m_bodies[i] = 0; - delete m_shapes[i]; m_shapes[i] = 0; - } -} - - -btRigidBody* RagDoll::localCreateRigidBody (btScalar mass, const btTransform& startTransform, btCollisionShape* shape) -{ - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,shape,localInertia); - rbInfo.m_additionalDamping = true; - btRigidBody* body = new btRigidBody(rbInfo); - - m_ownerWorld->addRigidBody(body); - - return body; -} diff --git a/Demos/GenericJointDemo/Ragdoll.h b/Demos/GenericJointDemo/Ragdoll.h deleted file mode 100644 index 29a9cbde1..000000000 --- a/Demos/GenericJointDemo/Ragdoll.h +++ /dev/null @@ -1,71 +0,0 @@ -#ifndef RAGDOLL_H_INCLUDED -#define RAGDOLL_H_INCLUDED - -#include "DemoApplication.h" -#include "LinearMath/btAlignedObjectArray.h" -#include "btBulletDynamicsCommon.h" - - - - -class RagDoll -{ - enum - { - BODYPART_PELVIS = 0, - BODYPART_SPINE, - BODYPART_HEAD, - - BODYPART_LEFT_UPPER_LEG, - BODYPART_LEFT_LOWER_LEG, - - BODYPART_RIGHT_UPPER_LEG, - BODYPART_RIGHT_LOWER_LEG, - - BODYPART_LEFT_UPPER_ARM, - BODYPART_LEFT_LOWER_ARM, - - BODYPART_RIGHT_UPPER_ARM, - BODYPART_RIGHT_LOWER_ARM, - - BODYPART_COUNT - }; - - enum - { - JOINT_PELVIS_SPINE = 0, - JOINT_SPINE_HEAD, - - JOINT_LEFT_HIP, - JOINT_LEFT_KNEE, - - JOINT_RIGHT_HIP, - JOINT_RIGHT_KNEE, - - JOINT_LEFT_SHOULDER, - JOINT_LEFT_ELBOW, - - JOINT_RIGHT_SHOULDER, - JOINT_RIGHT_ELBOW, - - JOINT_COUNT - }; - - btDynamicsWorld* m_ownerWorld; - btCollisionShape* m_shapes[BODYPART_COUNT]; - btRigidBody* m_bodies[BODYPART_COUNT]; - btTypedConstraint* m_joints[JOINT_COUNT]; - - btRigidBody* localCreateRigidBody (btScalar mass, const btTransform& startTransform, btCollisionShape* shape); - -public: - RagDoll (btDynamicsWorld* ownerWorld, - const btVector3& positionOffset, - btScalar scale_ragdoll = btScalar(1.0)); - - ~RagDoll (); -}; - - - -#endif // RAGDOLL_H_INCLUDED diff --git a/Demos/GenericJointDemo/Win32GenericJointDemo.cpp b/Demos/GenericJointDemo/Win32GenericJointDemo.cpp deleted file mode 100644 index 990b1fac1..000000000 --- a/Demos/GenericJointDemo/Win32GenericJointDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "GenericJointDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new GenericJointDemo(); -} - -#endif diff --git a/Demos/GenericJointDemo/main.cpp b/Demos/GenericJointDemo/main.cpp deleted file mode 100644 index 4dd56b85e..000000000 --- a/Demos/GenericJointDemo/main.cpp +++ /dev/null @@ -1,28 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2010 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "GenericJointDemo.h" - -int main(int argc,char* argv[]) -{ - GenericJointDemo demoApp; -// demoApp.configDebugDrawer(&debugDrawer); - - demoApp.initPhysics(); - demoApp.setCameraDistance(btScalar(10.)); - - return glutmain(argc, argv,640,480,"Joint 6DOF - Sequencial Impulse Solver",&demoApp); - -} diff --git a/Demos/GimpactTestDemo/BunnyMesh.h b/Demos/GimpactTestDemo/BunnyMesh.h deleted file mode 100644 index 818bd0248..000000000 --- a/Demos/GimpactTestDemo/BunnyMesh.h +++ /dev/null @@ -1,1379 +0,0 @@ -#ifndef BUNNY_MESH_H_ -#define BUNNY_MESH_H_ - - - -//***************************THE FAMOUS BUNNY TRIMESH********************************************// - -#define REAL btScalar -const int BUNNY_NUM_TRIANGLES =902; -const int BUNNY_NUM_VERTICES = 453; -const int BUNNY_NUM_INDICES = BUNNY_NUM_TRIANGLES * 3; - - -static REAL gVerticesBunny[BUNNY_NUM_VERTICES * 3] = { - REAL(-0.334392), REAL(0.133007), REAL(0.062259), - REAL(-0.350189), REAL(0.150354), REAL(-0.147769), - REAL(-0.234201), REAL(0.343811), REAL(-0.174307), - REAL(-0.200259), REAL(0.285207), REAL(0.093749), - REAL(0.003520), REAL(0.475208), REAL(-0.159365), - REAL(0.001856), REAL(0.419203), REAL(0.098582), - REAL(-0.252802), REAL(0.093666), REAL(0.237538), - REAL(-0.162901), REAL(0.237984), REAL(0.206905), - REAL(0.000865), REAL(0.318141), REAL(0.235370), - REAL(-0.414624), REAL(0.164083), REAL(-0.278254), - REAL(-0.262213), REAL(0.357334), REAL(-0.293246), - REAL(0.004628), REAL(0.482694), REAL(-0.338626), - REAL(-0.402162), REAL(0.133528), REAL(-0.443247), - REAL(-0.243781), REAL(0.324275), REAL(-0.436763), - REAL(0.005293), REAL(0.437592), REAL(-0.458332), - REAL(-0.339884), REAL(-0.041150), REAL(-0.668211), - REAL(-0.248382), REAL(0.255825), REAL(-0.627493), - REAL(0.006261), REAL(0.376103), REAL(-0.631506), - REAL(-0.216201), REAL(-0.126776), REAL(-0.886936), - REAL(-0.171075), REAL(0.011544), REAL(-0.881386), - REAL(-0.181074), REAL(0.098223), REAL(-0.814779), - REAL(-0.119891), REAL(0.218786), REAL(-0.760153), - REAL(-0.078895), REAL(0.276780), REAL(-0.739281), - REAL(0.006801), REAL(0.310959), REAL(-0.735661), - REAL(-0.168842), REAL(0.102387), REAL(-0.920381), - REAL(-0.104072), REAL(0.177278), REAL(-0.952530), - REAL(-0.129704), REAL(0.211848), REAL(-0.836678), - REAL(-0.099875), REAL(0.310931), REAL(-0.799381), - REAL(0.007237), REAL(0.361687), REAL(-0.794439), - REAL(-0.077913), REAL(0.258753), REAL(-0.921640), - REAL(0.007957), REAL(0.282241), REAL(-0.931680), - REAL(-0.252222), REAL(-0.550401), REAL(-0.557810), - REAL(-0.267633), REAL(-0.603419), REAL(-0.655209), - REAL(-0.446838), REAL(-0.118517), REAL(-0.466159), - REAL(-0.459488), REAL(-0.093017), REAL(-0.311341), - REAL(-0.370645), REAL(-0.100108), REAL(-0.159454), - REAL(-0.371984), REAL(-0.091991), REAL(-0.011044), - REAL(-0.328945), REAL(-0.098269), REAL(0.088659), - REAL(-0.282452), REAL(-0.018862), REAL(0.311501), - REAL(-0.352403), REAL(-0.131341), REAL(0.144902), - REAL(-0.364126), REAL(-0.200299), REAL(0.202388), - REAL(-0.283965), REAL(-0.231869), REAL(0.023668), - REAL(-0.298943), REAL(-0.155218), REAL(0.369716), - REAL(-0.293787), REAL(-0.121856), REAL(0.419097), - REAL(-0.290163), REAL(-0.290797), REAL(0.107824), - REAL(-0.264165), REAL(-0.272849), REAL(0.036347), - REAL(-0.228567), REAL(-0.372573), REAL(0.290309), - REAL(-0.190431), REAL(-0.286997), REAL(0.421917), - REAL(-0.191039), REAL(-0.240973), REAL(0.507118), - REAL(-0.287272), REAL(-0.276431), REAL(-0.065444), - REAL(-0.295675), REAL(-0.280818), REAL(-0.174200), - REAL(-0.399537), REAL(-0.313131), REAL(-0.376167), - REAL(-0.392666), REAL(-0.488581), REAL(-0.427494), - REAL(-0.331669), REAL(-0.570185), REAL(-0.466054), - REAL(-0.282290), REAL(-0.618140), REAL(-0.589220), - REAL(-0.374238), REAL(-0.594882), REAL(-0.323298), - REAL(-0.381071), REAL(-0.629723), REAL(-0.350777), - REAL(-0.382112), REAL(-0.624060), REAL(-0.221577), - REAL(-0.272701), REAL(-0.566522), REAL(0.259157), - REAL(-0.256702), REAL(-0.663406), REAL(0.286079), - REAL(-0.280948), REAL(-0.428359), REAL(0.055790), - REAL(-0.184974), REAL(-0.508894), REAL(0.326265), - REAL(-0.279971), REAL(-0.526918), REAL(0.395319), - REAL(-0.282599), REAL(-0.663393), REAL(0.412411), - REAL(-0.188329), REAL(-0.475093), REAL(0.417954), - REAL(-0.263384), REAL(-0.663396), REAL(0.466604), - REAL(-0.209063), REAL(-0.663393), REAL(0.509344), - REAL(-0.002044), REAL(-0.319624), REAL(0.553078), - REAL(-0.001266), REAL(-0.371260), REAL(0.413296), - REAL(-0.219753), REAL(-0.339762), REAL(-0.040921), - REAL(-0.256986), REAL(-0.282511), REAL(-0.006349), - REAL(-0.271706), REAL(-0.260881), REAL(0.001764), - REAL(-0.091191), REAL(-0.419184), REAL(-0.045912), - REAL(-0.114944), REAL(-0.429752), REAL(-0.124739), - REAL(-0.113970), REAL(-0.382987), REAL(-0.188540), - REAL(-0.243012), REAL(-0.464942), REAL(-0.242850), - REAL(-0.314815), REAL(-0.505402), REAL(-0.324768), - REAL(0.002774), REAL(-0.437526), REAL(-0.262766), - REAL(-0.072625), REAL(-0.417748), REAL(-0.221440), - REAL(-0.160112), REAL(-0.476932), REAL(-0.293450), - REAL(0.003859), REAL(-0.453425), REAL(-0.443916), - REAL(-0.120363), REAL(-0.581567), REAL(-0.438689), - REAL(-0.091499), REAL(-0.584191), REAL(-0.294511), - REAL(-0.116469), REAL(-0.599861), REAL(-0.188308), - REAL(-0.208032), REAL(-0.513640), REAL(-0.134649), - REAL(-0.235749), REAL(-0.610017), REAL(-0.040939), - REAL(-0.344916), REAL(-0.622487), REAL(-0.085380), - REAL(-0.336401), REAL(-0.531864), REAL(-0.212298), - REAL(0.001961), REAL(-0.459550), REAL(-0.135547), - REAL(-0.058296), REAL(-0.430536), REAL(-0.043440), - REAL(0.001378), REAL(-0.449511), REAL(-0.037762), - REAL(-0.130135), REAL(-0.510222), REAL(0.079144), - REAL(0.000142), REAL(-0.477549), REAL(0.157064), - REAL(-0.114284), REAL(-0.453206), REAL(0.304397), - REAL(-0.000592), REAL(-0.443558), REAL(0.285401), - REAL(-0.056215), REAL(-0.663402), REAL(0.326073), - REAL(-0.026248), REAL(-0.568010), REAL(0.273318), - REAL(-0.049261), REAL(-0.531064), REAL(0.389854), - REAL(-0.127096), REAL(-0.663398), REAL(0.479316), - REAL(-0.058384), REAL(-0.663401), REAL(0.372891), - REAL(-0.303961), REAL(0.054199), REAL(0.625921), - REAL(-0.268594), REAL(0.193403), REAL(0.502766), - REAL(-0.277159), REAL(0.126123), REAL(0.443289), - REAL(-0.287605), REAL(-0.005722), REAL(0.531844), - REAL(-0.231396), REAL(-0.121289), REAL(0.587387), - REAL(-0.253475), REAL(-0.081797), REAL(0.756541), - REAL(-0.195164), REAL(-0.137969), REAL(0.728011), - REAL(-0.167673), REAL(-0.156573), REAL(0.609388), - REAL(-0.145917), REAL(-0.169029), REAL(0.697600), - REAL(-0.077776), REAL(-0.214247), REAL(0.622586), - REAL(-0.076873), REAL(-0.214971), REAL(0.696301), - REAL(-0.002341), REAL(-0.233135), REAL(0.622859), - REAL(-0.002730), REAL(-0.213526), REAL(0.691267), - REAL(-0.003136), REAL(-0.192628), REAL(0.762731), - REAL(-0.056136), REAL(-0.201222), REAL(0.763806), - REAL(-0.114589), REAL(-0.166192), REAL(0.770723), - REAL(-0.155145), REAL(-0.129632), REAL(0.791738), - REAL(-0.183611), REAL(-0.058705), REAL(0.847012), - REAL(-0.165562), REAL(0.001980), REAL(0.833386), - REAL(-0.220084), REAL(0.019914), REAL(0.768935), - REAL(-0.255730), REAL(0.090306), REAL(0.670782), - REAL(-0.255594), REAL(0.113833), REAL(0.663389), - REAL(-0.226380), REAL(0.212655), REAL(0.617740), - REAL(-0.003367), REAL(-0.195342), REAL(0.799680), - REAL(-0.029743), REAL(-0.210508), REAL(0.827180), - REAL(-0.003818), REAL(-0.194783), REAL(0.873636), - REAL(-0.004116), REAL(-0.157907), REAL(0.931268), - REAL(-0.031280), REAL(-0.184555), REAL(0.889476), - REAL(-0.059885), REAL(-0.184448), REAL(0.841330), - REAL(-0.135333), REAL(-0.164332), REAL(0.878200), - REAL(-0.085574), REAL(-0.170948), REAL(0.925547), - REAL(-0.163833), REAL(-0.094170), REAL(0.897114), - REAL(-0.138444), REAL(-0.104250), REAL(0.945975), - REAL(-0.083497), REAL(-0.084934), REAL(0.979607), - REAL(-0.004433), REAL(-0.146642), REAL(0.985872), - REAL(-0.150715), REAL(0.032650), REAL(0.884111), - REAL(-0.135892), REAL(-0.035520), REAL(0.945455), - REAL(-0.070612), REAL(0.036849), REAL(0.975733), - REAL(-0.004458), REAL(-0.042526), REAL(1.015670), - REAL(-0.004249), REAL(0.046042), REAL(1.003240), - REAL(-0.086969), REAL(0.133224), REAL(0.947633), - REAL(-0.003873), REAL(0.161605), REAL(0.970499), - REAL(-0.125544), REAL(0.140012), REAL(0.917678), - REAL(-0.125651), REAL(0.250246), REAL(0.857602), - REAL(-0.003127), REAL(0.284070), REAL(0.878870), - REAL(-0.159174), REAL(0.125726), REAL(0.888878), - REAL(-0.183807), REAL(0.196970), REAL(0.844480), - REAL(-0.159890), REAL(0.291736), REAL(0.732480), - REAL(-0.199495), REAL(0.207230), REAL(0.779864), - REAL(-0.206182), REAL(0.164608), REAL(0.693257), - REAL(-0.186315), REAL(0.160689), REAL(0.817193), - REAL(-0.192827), REAL(0.166706), REAL(0.782271), - REAL(-0.175112), REAL(0.110008), REAL(0.860621), - REAL(-0.161022), REAL(0.057420), REAL(0.855111), - REAL(-0.172319), REAL(0.036155), REAL(0.816189), - REAL(-0.190318), REAL(0.064083), REAL(0.760605), - REAL(-0.195072), REAL(0.129179), REAL(0.731104), - REAL(-0.203126), REAL(0.410287), REAL(0.680536), - REAL(-0.216677), REAL(0.309274), REAL(0.642272), - REAL(-0.241515), REAL(0.311485), REAL(0.587832), - REAL(-0.002209), REAL(0.366663), REAL(0.749413), - REAL(-0.088230), REAL(0.396265), REAL(0.678635), - REAL(-0.170147), REAL(0.109517), REAL(0.840784), - REAL(-0.160521), REAL(0.067766), REAL(0.830650), - REAL(-0.181546), REAL(0.139805), REAL(0.812146), - REAL(-0.180495), REAL(0.148568), REAL(0.776087), - REAL(-0.180255), REAL(0.129125), REAL(0.744192), - REAL(-0.186298), REAL(0.078308), REAL(0.769352), - REAL(-0.167622), REAL(0.060539), REAL(0.806675), - REAL(-0.189876), REAL(0.102760), REAL(0.802582), - REAL(-0.108340), REAL(0.455446), REAL(0.657174), - REAL(-0.241585), REAL(0.527592), REAL(0.669296), - REAL(-0.265676), REAL(0.513366), REAL(0.634594), - REAL(-0.203073), REAL(0.478550), REAL(0.581526), - REAL(-0.266772), REAL(0.642330), REAL(0.602061), - REAL(-0.216961), REAL(0.564846), REAL(0.535435), - REAL(-0.202210), REAL(0.525495), REAL(0.475944), - REAL(-0.193888), REAL(0.467925), REAL(0.520606), - REAL(-0.265837), REAL(0.757267), REAL(0.500933), - REAL(-0.240306), REAL(0.653440), REAL(0.463215), - REAL(-0.309239), REAL(0.776868), REAL(0.304726), - REAL(-0.271009), REAL(0.683094), REAL(0.382018), - REAL(-0.312111), REAL(0.671099), REAL(0.286687), - REAL(-0.268791), REAL(0.624342), REAL(0.377231), - REAL(-0.302457), REAL(0.533996), REAL(0.360289), - REAL(-0.263656), REAL(0.529310), REAL(0.412564), - REAL(-0.282311), REAL(0.415167), REAL(0.447666), - REAL(-0.239201), REAL(0.442096), REAL(0.495604), - REAL(-0.220043), REAL(0.569026), REAL(0.445877), - REAL(-0.001263), REAL(0.395631), REAL(0.602029), - REAL(-0.057345), REAL(0.442535), REAL(0.572224), - REAL(-0.088927), REAL(0.506333), REAL(0.529106), - REAL(-0.125738), REAL(0.535076), REAL(0.612913), - REAL(-0.126251), REAL(0.577170), REAL(0.483159), - REAL(-0.149594), REAL(0.611520), REAL(0.557731), - REAL(-0.163188), REAL(0.660791), REAL(0.491080), - REAL(-0.172482), REAL(0.663387), REAL(0.415416), - REAL(-0.160464), REAL(0.591710), REAL(0.370659), - REAL(-0.156445), REAL(0.536396), REAL(0.378302), - REAL(-0.136496), REAL(0.444358), REAL(0.425226), - REAL(-0.095564), REAL(0.373768), REAL(0.473659), - REAL(-0.104146), REAL(0.315912), REAL(0.498104), - REAL(-0.000496), REAL(0.384194), REAL(0.473817), - REAL(-0.000183), REAL(0.297770), REAL(0.401486), - REAL(-0.129042), REAL(0.270145), REAL(0.434495), - REAL(0.000100), REAL(0.272963), REAL(0.349138), - REAL(-0.113060), REAL(0.236984), REAL(0.385554), - REAL(0.007260), REAL(0.016311), REAL(-0.883396), - REAL(0.007865), REAL(0.122104), REAL(-0.956137), - REAL(-0.032842), REAL(0.115282), REAL(-0.953252), - REAL(-0.089115), REAL(0.108449), REAL(-0.950317), - REAL(-0.047440), REAL(0.014729), REAL(-0.882756), - REAL(-0.104458), REAL(0.013137), REAL(-0.882070), - REAL(-0.086439), REAL(-0.584866), REAL(-0.608343), - REAL(-0.115026), REAL(-0.662605), REAL(-0.436732), - REAL(-0.071683), REAL(-0.665372), REAL(-0.606385), - REAL(-0.257884), REAL(-0.665381), REAL(-0.658052), - REAL(-0.272542), REAL(-0.665381), REAL(-0.592063), - REAL(-0.371322), REAL(-0.665382), REAL(-0.353620), - REAL(-0.372362), REAL(-0.665381), REAL(-0.224420), - REAL(-0.335166), REAL(-0.665380), REAL(-0.078623), - REAL(-0.225999), REAL(-0.665375), REAL(-0.038981), - REAL(-0.106719), REAL(-0.665374), REAL(-0.186351), - REAL(-0.081749), REAL(-0.665372), REAL(-0.292554), - REAL(0.006943), REAL(-0.091505), REAL(-0.858354), - REAL(0.006117), REAL(-0.280985), REAL(-0.769967), - REAL(0.004495), REAL(-0.502360), REAL(-0.559799), - REAL(-0.198638), REAL(-0.302135), REAL(-0.845816), - REAL(-0.237395), REAL(-0.542544), REAL(-0.587188), - REAL(-0.270001), REAL(-0.279489), REAL(-0.669861), - REAL(-0.134547), REAL(-0.119852), REAL(-0.959004), - REAL(-0.052088), REAL(-0.122463), REAL(-0.944549), - REAL(-0.124463), REAL(-0.293508), REAL(-0.899566), - REAL(-0.047616), REAL(-0.289643), REAL(-0.879292), - REAL(-0.168595), REAL(-0.529132), REAL(-0.654931), - REAL(-0.099793), REAL(-0.515719), REAL(-0.645873), - REAL(-0.186168), REAL(-0.605282), REAL(-0.724690), - REAL(-0.112970), REAL(-0.583097), REAL(-0.707469), - REAL(-0.108152), REAL(-0.665375), REAL(-0.700408), - REAL(-0.183019), REAL(-0.665378), REAL(-0.717630), - REAL(-0.349529), REAL(-0.334459), REAL(-0.511985), - REAL(-0.141182), REAL(-0.437705), REAL(-0.798194), - REAL(-0.212670), REAL(-0.448725), REAL(-0.737447), - REAL(-0.261111), REAL(-0.414945), REAL(-0.613835), - REAL(-0.077364), REAL(-0.431480), REAL(-0.778113), - REAL(0.005174), REAL(-0.425277), REAL(-0.651592), - REAL(0.089236), REAL(-0.431732), REAL(-0.777093), - REAL(0.271006), REAL(-0.415749), REAL(-0.610577), - REAL(0.223981), REAL(-0.449384), REAL(-0.734774), - REAL(0.153275), REAL(-0.438150), REAL(-0.796391), - REAL(0.358414), REAL(-0.335529), REAL(-0.507649), - REAL(0.193434), REAL(-0.665946), REAL(-0.715325), - REAL(0.118363), REAL(-0.665717), REAL(-0.699021), - REAL(0.123515), REAL(-0.583454), REAL(-0.706020), - REAL(0.196851), REAL(-0.605860), REAL(-0.722345), - REAL(0.109788), REAL(-0.516035), REAL(-0.644590), - REAL(0.178656), REAL(-0.529656), REAL(-0.652804), - REAL(0.061157), REAL(-0.289807), REAL(-0.878626), - REAL(0.138234), REAL(-0.293905), REAL(-0.897958), - REAL(0.066933), REAL(-0.122643), REAL(-0.943820), - REAL(0.149571), REAL(-0.120281), REAL(-0.957264), - REAL(0.280989), REAL(-0.280321), REAL(-0.666487), - REAL(0.246581), REAL(-0.543275), REAL(-0.584224), - REAL(0.211720), REAL(-0.302754), REAL(-0.843303), - REAL(0.086966), REAL(-0.665627), REAL(-0.291520), - REAL(0.110634), REAL(-0.665702), REAL(-0.185021), - REAL(0.228099), REAL(-0.666061), REAL(-0.036201), - REAL(0.337743), REAL(-0.666396), REAL(-0.074503), - REAL(0.376722), REAL(-0.666513), REAL(-0.219833), - REAL(0.377265), REAL(-0.666513), REAL(-0.349036), - REAL(0.281411), REAL(-0.666217), REAL(-0.588670), - REAL(0.267564), REAL(-0.666174), REAL(-0.654834), - REAL(0.080745), REAL(-0.665602), REAL(-0.605452), - REAL(0.122016), REAL(-0.662963), REAL(-0.435280), - REAL(0.095767), REAL(-0.585141), REAL(-0.607228), - REAL(0.118944), REAL(0.012799), REAL(-0.880702), - REAL(0.061944), REAL(0.014564), REAL(-0.882086), - REAL(0.104725), REAL(0.108156), REAL(-0.949130), - REAL(0.048513), REAL(0.115159), REAL(-0.952753), - REAL(0.112696), REAL(0.236643), REAL(0.386937), - REAL(0.128177), REAL(0.269757), REAL(0.436071), - REAL(0.102643), REAL(0.315600), REAL(0.499370), - REAL(0.094535), REAL(0.373481), REAL(0.474824), - REAL(0.136270), REAL(0.443946), REAL(0.426895), - REAL(0.157071), REAL(0.535923), REAL(0.380222), - REAL(0.161350), REAL(0.591224), REAL(0.372630), - REAL(0.173035), REAL(0.662865), REAL(0.417531), - REAL(0.162808), REAL(0.660299), REAL(0.493077), - REAL(0.148250), REAL(0.611070), REAL(0.559555), - REAL(0.125719), REAL(0.576790), REAL(0.484702), - REAL(0.123489), REAL(0.534699), REAL(0.614440), - REAL(0.087621), REAL(0.506066), REAL(0.530188), - REAL(0.055321), REAL(0.442365), REAL(0.572915), - REAL(0.219936), REAL(0.568361), REAL(0.448571), - REAL(0.238099), REAL(0.441375), REAL(0.498528), - REAL(0.281711), REAL(0.414315), REAL(0.451121), - REAL(0.263833), REAL(0.528513), REAL(0.415794), - REAL(0.303284), REAL(0.533081), REAL(0.363998), - REAL(0.269687), REAL(0.623528), REAL(0.380528), - REAL(0.314255), REAL(0.670153), REAL(0.290524), - REAL(0.272023), REAL(0.682273), REAL(0.385343), - REAL(0.311480), REAL(0.775931), REAL(0.308527), - REAL(0.240239), REAL(0.652714), REAL(0.466159), - REAL(0.265619), REAL(0.756464), REAL(0.504187), - REAL(0.192562), REAL(0.467341), REAL(0.522972), - REAL(0.201605), REAL(0.524885), REAL(0.478417), - REAL(0.215743), REAL(0.564193), REAL(0.538084), - REAL(0.264969), REAL(0.641527), REAL(0.605317), - REAL(0.201031), REAL(0.477940), REAL(0.584002), - REAL(0.263086), REAL(0.512567), REAL(0.637832), - REAL(0.238615), REAL(0.526867), REAL(0.672237), - REAL(0.105309), REAL(0.455123), REAL(0.658482), - REAL(0.183993), REAL(0.102195), REAL(0.804872), - REAL(0.161563), REAL(0.060042), REAL(0.808692), - REAL(0.180748), REAL(0.077754), REAL(0.771600), - REAL(0.175168), REAL(0.128588), REAL(0.746368), - REAL(0.175075), REAL(0.148030), REAL(0.778264), - REAL(0.175658), REAL(0.139265), REAL(0.814333), - REAL(0.154191), REAL(0.067291), REAL(0.832578), - REAL(0.163818), REAL(0.109013), REAL(0.842830), - REAL(0.084760), REAL(0.396004), REAL(0.679695), - REAL(0.238888), REAL(0.310760), REAL(0.590775), - REAL(0.213380), REAL(0.308625), REAL(0.644905), - REAL(0.199666), REAL(0.409678), REAL(0.683003), - REAL(0.190143), REAL(0.128597), REAL(0.733463), - REAL(0.184833), REAL(0.063516), REAL(0.762902), - REAL(0.166070), REAL(0.035644), REAL(0.818261), - REAL(0.154361), REAL(0.056943), REAL(0.857042), - REAL(0.168542), REAL(0.109489), REAL(0.862725), - REAL(0.187387), REAL(0.166131), REAL(0.784599), - REAL(0.180428), REAL(0.160135), REAL(0.819438), - REAL(0.201823), REAL(0.163991), REAL(0.695756), - REAL(0.194206), REAL(0.206635), REAL(0.782275), - REAL(0.155438), REAL(0.291260), REAL(0.734412), - REAL(0.177696), REAL(0.196424), REAL(0.846693), - REAL(0.152305), REAL(0.125256), REAL(0.890786), - REAL(0.119546), REAL(0.249876), REAL(0.859104), - REAL(0.118369), REAL(0.139643), REAL(0.919173), - REAL(0.079410), REAL(0.132973), REAL(0.948652), - REAL(0.062419), REAL(0.036648), REAL(0.976547), - REAL(0.127847), REAL(-0.035919), REAL(0.947070), - REAL(0.143624), REAL(0.032206), REAL(0.885913), - REAL(0.074888), REAL(-0.085173), REAL(0.980577), - REAL(0.130184), REAL(-0.104656), REAL(0.947620), - REAL(0.156201), REAL(-0.094653), REAL(0.899074), - REAL(0.077366), REAL(-0.171194), REAL(0.926545), - REAL(0.127722), REAL(-0.164729), REAL(0.879810), - REAL(0.052670), REAL(-0.184618), REAL(0.842019), - REAL(0.023477), REAL(-0.184638), REAL(0.889811), - REAL(0.022626), REAL(-0.210587), REAL(0.827500), - REAL(0.223089), REAL(0.211976), REAL(0.620493), - REAL(0.251444), REAL(0.113067), REAL(0.666494), - REAL(0.251419), REAL(0.089540), REAL(0.673887), - REAL(0.214360), REAL(0.019258), REAL(0.771595), - REAL(0.158999), REAL(0.001490), REAL(0.835374), - REAL(0.176696), REAL(-0.059249), REAL(0.849218), - REAL(0.148696), REAL(-0.130091), REAL(0.793599), - REAL(0.108290), REAL(-0.166528), REAL(0.772088), - REAL(0.049820), REAL(-0.201382), REAL(0.764454), - REAL(0.071341), REAL(-0.215195), REAL(0.697209), - REAL(0.073148), REAL(-0.214475), REAL(0.623510), - REAL(0.140502), REAL(-0.169461), REAL(0.699354), - REAL(0.163374), REAL(-0.157073), REAL(0.611416), - REAL(0.189466), REAL(-0.138550), REAL(0.730366), - REAL(0.247593), REAL(-0.082554), REAL(0.759610), - REAL(0.227468), REAL(-0.121982), REAL(0.590197), - REAL(0.284702), REAL(-0.006586), REAL(0.535347), - REAL(0.275741), REAL(0.125287), REAL(0.446676), - REAL(0.266650), REAL(0.192594), REAL(0.506044), - REAL(0.300086), REAL(0.053287), REAL(0.629620), - REAL(0.055450), REAL(-0.663935), REAL(0.375065), - REAL(0.122854), REAL(-0.664138), REAL(0.482323), - REAL(0.046520), REAL(-0.531571), REAL(0.391918), - REAL(0.024824), REAL(-0.568450), REAL(0.275106), - REAL(0.053855), REAL(-0.663931), REAL(0.328224), - REAL(0.112829), REAL(-0.453549), REAL(0.305788), - REAL(0.131265), REAL(-0.510617), REAL(0.080746), - REAL(0.061174), REAL(-0.430716), REAL(-0.042710), - REAL(0.341019), REAL(-0.532887), REAL(-0.208150), - REAL(0.347705), REAL(-0.623533), REAL(-0.081139), - REAL(0.238040), REAL(-0.610732), REAL(-0.038037), - REAL(0.211764), REAL(-0.514274), REAL(-0.132078), - REAL(0.120605), REAL(-0.600219), REAL(-0.186856), - REAL(0.096985), REAL(-0.584476), REAL(-0.293357), - REAL(0.127621), REAL(-0.581941), REAL(-0.437170), - REAL(0.165902), REAL(-0.477425), REAL(-0.291453), - REAL(0.077720), REAL(-0.417975), REAL(-0.220519), - REAL(0.320892), REAL(-0.506363), REAL(-0.320874), - REAL(0.248214), REAL(-0.465684), REAL(-0.239842), - REAL(0.118764), REAL(-0.383338), REAL(-0.187114), - REAL(0.118816), REAL(-0.430106), REAL(-0.123307), - REAL(0.094131), REAL(-0.419464), REAL(-0.044777), - REAL(0.274526), REAL(-0.261706), REAL(0.005110), - REAL(0.259842), REAL(-0.283292), REAL(-0.003185), - REAL(0.222861), REAL(-0.340431), REAL(-0.038210), - REAL(0.204445), REAL(-0.664380), REAL(0.513353), - REAL(0.259286), REAL(-0.664547), REAL(0.471281), - REAL(0.185402), REAL(-0.476020), REAL(0.421718), - REAL(0.279163), REAL(-0.664604), REAL(0.417328), - REAL(0.277157), REAL(-0.528122), REAL(0.400208), - REAL(0.183069), REAL(-0.509812), REAL(0.329995), - REAL(0.282599), REAL(-0.429210), REAL(0.059242), - REAL(0.254816), REAL(-0.664541), REAL(0.290687), - REAL(0.271436), REAL(-0.567707), REAL(0.263966), - REAL(0.386561), REAL(-0.625221), REAL(-0.216870), - REAL(0.387086), REAL(-0.630883), REAL(-0.346073), - REAL(0.380021), REAL(-0.596021), REAL(-0.318679), - REAL(0.291269), REAL(-0.619007), REAL(-0.585707), - REAL(0.339280), REAL(-0.571198), REAL(-0.461946), - REAL(0.400045), REAL(-0.489778), REAL(-0.422640), - REAL(0.406817), REAL(-0.314349), REAL(-0.371230), - REAL(0.300588), REAL(-0.281718), REAL(-0.170549), - REAL(0.290866), REAL(-0.277304), REAL(-0.061905), - REAL(0.187735), REAL(-0.241545), REAL(0.509437), - REAL(0.188032), REAL(-0.287569), REAL(0.424234), - REAL(0.227520), REAL(-0.373262), REAL(0.293102), - REAL(0.266526), REAL(-0.273650), REAL(0.039597), - REAL(0.291592), REAL(-0.291676), REAL(0.111386), - REAL(0.291914), REAL(-0.122741), REAL(0.422683), - REAL(0.297574), REAL(-0.156119), REAL(0.373368), - REAL(0.286603), REAL(-0.232731), REAL(0.027162), - REAL(0.364663), REAL(-0.201399), REAL(0.206850), - REAL(0.353855), REAL(-0.132408), REAL(0.149228), - REAL(0.282208), REAL(-0.019715), REAL(0.314960), - REAL(0.331187), REAL(-0.099266), REAL(0.092701), - REAL(0.375463), REAL(-0.093120), REAL(-0.006467), - REAL(0.375917), REAL(-0.101236), REAL(-0.154882), - REAL(0.466635), REAL(-0.094416), REAL(-0.305669), - REAL(0.455805), REAL(-0.119881), REAL(-0.460632), - REAL(0.277465), REAL(-0.604242), REAL(-0.651871), - REAL(0.261022), REAL(-0.551176), REAL(-0.554667), - REAL(0.093627), REAL(0.258494), REAL(-0.920589), - REAL(0.114248), REAL(0.310608), REAL(-0.798070), - REAL(0.144232), REAL(0.211434), REAL(-0.835001), - REAL(0.119916), REAL(0.176940), REAL(-0.951159), - REAL(0.184061), REAL(0.101854), REAL(-0.918220), - REAL(0.092431), REAL(0.276521), REAL(-0.738231), - REAL(0.133504), REAL(0.218403), REAL(-0.758602), - REAL(0.194987), REAL(0.097655), REAL(-0.812476), - REAL(0.185542), REAL(0.011005), REAL(-0.879202), - REAL(0.230315), REAL(-0.127450), REAL(-0.884202), - REAL(0.260471), REAL(0.255056), REAL(-0.624378), - REAL(0.351567), REAL(-0.042194), REAL(-0.663976), - REAL(0.253742), REAL(0.323524), REAL(-0.433716), - REAL(0.411612), REAL(0.132299), REAL(-0.438264), - REAL(0.270513), REAL(0.356530), REAL(-0.289984), - REAL(0.422146), REAL(0.162819), REAL(-0.273130), - REAL(0.164724), REAL(0.237490), REAL(0.208912), - REAL(0.253806), REAL(0.092900), REAL(0.240640), - REAL(0.203608), REAL(0.284597), REAL(0.096223), - REAL(0.241006), REAL(0.343093), REAL(-0.171396), - REAL(0.356076), REAL(0.149288), REAL(-0.143443), - REAL(0.337656), REAL(0.131992), REAL(0.066374) -}; - -static int gIndicesBunny[BUNNY_NUM_TRIANGLES][3] = { - {126,134,133}, - {342,138,134}, - {133,134,138}, - {126,342,134}, - {312,316,317}, - {169,163,162}, - {312,317,319}, - {312,319,318}, - {169,162,164}, - {169,168,163}, - {312,314,315}, - {169,164,165}, - {169,167,168}, - {312,315,316}, - {312,313,314}, - {169,165,166}, - {169,166,167}, - {312,318,313}, - {308,304,305}, - {308,305,306}, - {179,181,188}, - {177,173,175}, - {177,175,176}, - {302,293,300}, - {322,294,304}, - {188,176,175}, - {188,175,179}, - {158,177,187}, - {305,293,302}, - {305,302,306}, - {322,304,308}, - {188,181,183}, - {158,173,177}, - {293,298,300}, - {304,294,296}, - {304,296,305}, - {185,176,188}, - {185,188,183}, - {187,177,176}, - {187,176,185}, - {305,296,298}, - {305,298,293}, - {436,432, 28}, - {436, 28, 23}, - {434,278,431}, - { 30,208,209}, - { 30,209, 29}, - { 19, 20, 24}, - {208,207,211}, - {208,211,209}, - { 19,210,212}, - {433,434,431}, - {433,431,432}, - {433,432,436}, - {436,437,433}, - {277,275,276}, - {277,276,278}, - {209,210, 25}, - { 21, 26, 24}, - { 21, 24, 20}, - { 25, 26, 27}, - { 25, 27, 29}, - {435,439,277}, - {439,275,277}, - {432,431, 30}, - {432, 30, 28}, - {433,437,438}, - {433,438,435}, - {434,277,278}, - { 24, 25,210}, - { 24, 26, 25}, - { 29, 27, 28}, - { 29, 28, 30}, - { 19, 24,210}, - {208, 30,431}, - {208,431,278}, - {435,434,433}, - {435,277,434}, - { 25, 29,209}, - { 27, 22, 23}, - { 27, 23, 28}, - { 26, 22, 27}, - { 26, 21, 22}, - {212,210,209}, - {212,209,211}, - {207,208,278}, - {207,278,276}, - {439,435,438}, - { 12, 9, 10}, - { 12, 10, 13}, - { 2, 3, 5}, - { 2, 5, 4}, - { 16, 13, 14}, - { 16, 14, 17}, - { 22, 21, 16}, - { 13, 10, 11}, - { 13, 11, 14}, - { 1, 0, 3}, - { 1, 3, 2}, - { 15, 12, 16}, - { 19, 18, 15}, - { 19, 15, 16}, - { 19, 16, 20}, - { 9, 1, 2}, - { 9, 2, 10}, - { 3, 7, 8}, - { 3, 8, 5}, - { 16, 17, 23}, - { 16, 23, 22}, - { 21, 20, 16}, - { 10, 2, 4}, - { 10, 4, 11}, - { 0, 6, 7}, - { 0, 7, 3}, - { 12, 13, 16}, - {451,446,445}, - {451,445,450}, - {442,440,439}, - {442,439,438}, - {442,438,441}, - {421,420,422}, - {412,411,426}, - {412,426,425}, - {408,405,407}, - {413, 67, 68}, - {413, 68,414}, - {391,390,412}, - { 80,384,386}, - {404,406,378}, - {390,391,377}, - {390,377, 88}, - {400,415,375}, - {398,396,395}, - {398,395,371}, - {398,371,370}, - {112,359,358}, - {112,358,113}, - {351,352,369}, - {125,349,348}, - {345,343,342}, - {342,340,339}, - {341,335,337}, - {328,341,327}, - {331,323,333}, - {331,322,323}, - {327,318,319}, - {327,319,328}, - {315,314,324}, - {302,300,301}, - {302,301,303}, - {320,311,292}, - {285,284,289}, - {310,307,288}, - {310,288,290}, - {321,350,281}, - {321,281,282}, - {423,448,367}, - {272,273,384}, - {272,384,274}, - {264,265,382}, - {264,382,383}, - {440,442,261}, - {440,261,263}, - {252,253,254}, - {252,254,251}, - {262,256,249}, - {262,249,248}, - {228,243,242}, - {228, 31,243}, - {213,215,238}, - {213,238,237}, - { 19,212,230}, - {224,225,233}, - {224,233,231}, - {217,218, 56}, - {217, 56, 54}, - {217,216,239}, - {217,239,238}, - {217,238,215}, - {218,217,215}, - {218,215,214}, - { 6,102,206}, - {186,199,200}, - {197,182,180}, - {170,171,157}, - {201,200,189}, - {170,190,191}, - {170,191,192}, - {175,174,178}, - {175,178,179}, - {168,167,155}, - {122,149,158}, - {122,158,159}, - {135,153,154}, - {135,154,118}, - {143,140,141}, - {143,141,144}, - {132,133,136}, - {130,126,133}, - {124,125,127}, - {122,101,100}, - {122,100,121}, - {110,108,107}, - {110,107,109}, - { 98, 99, 97}, - { 98, 97, 64}, - { 98, 64, 66}, - { 87, 55, 57}, - { 83, 82, 79}, - { 83, 79, 84}, - { 78, 74, 50}, - { 49, 71, 41}, - { 49, 41, 37}, - { 49, 37, 36}, - { 58, 44, 60}, - { 60, 59, 58}, - { 51, 34, 33}, - { 39, 40, 42}, - { 39, 42, 38}, - {243,240, 33}, - {243, 33,229}, - { 39, 38, 6}, - { 44, 46, 40}, - { 55, 56, 57}, - { 64, 62, 65}, - { 64, 65, 66}, - { 41, 71, 45}, - { 75, 50, 51}, - { 81, 79, 82}, - { 77, 88, 73}, - { 93, 92, 94}, - { 68, 47, 46}, - { 96, 97, 99}, - { 96, 99, 95}, - {110,109,111}, - {111,112,110}, - {114,113,123}, - {114,123,124}, - {132,131,129}, - {133,137,136}, - {135,142,145}, - {145,152,135}, - {149,147,157}, - {157,158,149}, - {164,150,151}, - {153,163,168}, - {153,168,154}, - {185,183,182}, - {185,182,184}, - {161,189,190}, - {200,199,191}, - {200,191,190}, - {180,178,195}, - {180,195,196}, - {102,101,204}, - {102,204,206}, - { 43, 48,104}, - { 43,104,103}, - {216,217, 54}, - {216, 54, 32}, - {207,224,231}, - {230,212,211}, - {230,211,231}, - {227,232,241}, - {227,241,242}, - {235,234,241}, - {235,241,244}, - {430,248,247}, - {272,274,253}, - {272,253,252}, - {439,260,275}, - {225,224,259}, - {225,259,257}, - {269,270,407}, - {269,407,405}, - {270,269,273}, - {270,273,272}, - {273,269,268}, - {273,268,267}, - {273,267,266}, - {273,266,265}, - {273,265,264}, - {448,279,367}, - {281,350,368}, - {285,286,301}, - {290,323,310}, - {290,311,323}, - {282,281,189}, - {292,311,290}, - {292,290,291}, - {307,306,302}, - {307,302,303}, - {316,315,324}, - {316,324,329}, - {331,351,350}, - {330,334,335}, - {330,335,328}, - {341,337,338}, - {344,355,354}, - {346,345,348}, - {346,348,347}, - {364,369,352}, - {364,352,353}, - {365,363,361}, - {365,361,362}, - {376,401,402}, - {373,372,397}, - {373,397,400}, - {376, 92,377}, - {381,378,387}, - {381,387,385}, - {386, 77, 80}, - {390,389,412}, - {416,417,401}, - {403,417,415}, - {408,429,430}, - {419,423,418}, - {427,428,444}, - {427,444,446}, - {437,436,441}, - {450,445, 11}, - {450, 11, 4}, - {447,449, 5}, - {447, 5, 8}, - {441,438,437}, - {425,426,451}, - {425,451,452}, - {417,421,415}, - {408,407,429}, - {399,403,400}, - {399,400,397}, - {394,393,416}, - {389,411,412}, - {386,383,385}, - {408,387,378}, - {408,378,406}, - {377,391,376}, - { 94,375,415}, - {372,373,374}, - {372,374,370}, - {359,111,360}, - {359,112,111}, - {113,358,349}, - {113,349,123}, - {346,343,345}, - {343,340,342}, - {338,336,144}, - {338,144,141}, - {327,341,354}, - {327,354,326}, - {331,350,321}, - {331,321,322}, - {314,313,326}, - {314,326,325}, - {300,298,299}, - {300,299,301}, - {288,287,289}, - {189,292,282}, - {287,288,303}, - {284,285,297}, - {368,280,281}, - {448,447,279}, - {274,226,255}, - {267,268,404}, - {267,404,379}, - {429,262,430}, - {439,440,260}, - {257,258,249}, - {257,249,246}, - {430,262,248}, - {234,228,242}, - {234,242,241}, - {237,238,239}, - {237,239,236}, - { 15, 18,227}, - { 15,227,229}, - {222,223, 82}, - {222, 82, 83}, - {214,215,213}, - {214,213, 81}, - { 38,102, 6}, - {122,159,200}, - {122,200,201}, - {174,171,192}, - {174,192,194}, - {197,193,198}, - {190,170,161}, - {181,179,178}, - {181,178,180}, - {166,156,155}, - {163,153,152}, - {163,152,162}, - {120,156,149}, - {120,149,121}, - {152,153,135}, - {140,143,142}, - {135,131,132}, - {135,132,136}, - {130,129,128}, - {130,128,127}, - {100,105,119}, - {100,119,120}, - {106,104,107}, - {106,107,108}, - { 91, 95, 59}, - { 93, 94, 68}, - { 91, 89, 92}, - { 76, 53, 55}, - { 76, 55, 87}, - { 81, 78, 79}, - { 74, 73, 49}, - { 69, 60, 45}, - { 58, 62, 64}, - { 58, 64, 61}, - { 53, 31, 32}, - { 32, 54, 53}, - { 42, 43, 38}, - { 35, 36, 0}, - { 35, 0, 1}, - { 34, 35, 1}, - { 34, 1, 9}, - { 44, 40, 41}, - { 44, 41, 45}, - { 33,240, 51}, - { 63, 62, 58}, - { 63, 58, 59}, - { 45, 71, 70}, - { 76, 75, 51}, - { 76, 51, 52}, - { 86, 85, 84}, - { 86, 84, 87}, - { 89, 72, 73}, - { 89, 73, 88}, - { 91, 92, 96}, - { 91, 96, 95}, - { 72, 91, 60}, - { 72, 60, 69}, - {104,106,105}, - {119,105,117}, - {119,117,118}, - {124,127,128}, - {117,116,129}, - {117,129,131}, - {118,117,131}, - {135,140,142}, - {146,150,152}, - {146,152,145}, - {149,122,121}, - {166,165,151}, - {166,151,156}, - {158,172,173}, - {161,160,189}, - {199,198,193}, - {199,193,191}, - {204,201,202}, - {178,174,194}, - {200,159,186}, - {109, 48, 67}, - { 48,107,104}, - {216, 32,236}, - {216,236,239}, - {223,214, 81}, - {223, 81, 82}, - { 33, 12, 15}, - { 32,228,234}, - { 32,234,236}, - {240, 31, 52}, - {256,255,246}, - {256,246,249}, - {258,263,248}, - {258,248,249}, - {275,260,259}, - {275,259,276}, - {207,276,259}, - {270,271,429}, - {270,429,407}, - {413,418,366}, - {413,366,365}, - {368,367,279}, - {368,279,280}, - {303,301,286}, - {303,286,287}, - {283,282,292}, - {283,292,291}, - {320,292,189}, - {298,296,297}, - {298,297,299}, - {318,327,326}, - {318,326,313}, - {329,330,317}, - {336,333,320}, - {326,354,353}, - {334,332,333}, - {334,333,336}, - {342,339,139}, - {342,139,138}, - {345,342,126}, - {347,357,356}, - {369,368,351}, - {363,356,357}, - {363,357,361}, - {366,367,368}, - {366,368,369}, - {375,373,400}, - { 92, 90,377}, - {409,387,408}, - {386,385,387}, - {386,387,388}, - {412,394,391}, - {396,398,399}, - {408,406,405}, - {415,421,419}, - {415,419,414}, - {425,452,448}, - {425,448,424}, - {444,441,443}, - {448,452,449}, - {448,449,447}, - {446,444,443}, - {446,443,445}, - {250,247,261}, - {250,261,428}, - {421,422,423}, - {421,423,419}, - {427,410,250}, - {417,403,401}, - {403,402,401}, - {420,392,412}, - {420,412,425}, - {420,425,424}, - {386,411,389}, - {383,382,381}, - {383,381,385}, - {378,379,404}, - {372,371,395}, - {372,395,397}, - {371,372,370}, - {361,359,360}, - {361,360,362}, - {368,350,351}, - {349,347,348}, - {356,355,344}, - {356,344,346}, - {344,341,340}, - {344,340,343}, - {338,337,336}, - {328,335,341}, - {324,352,351}, - {324,351,331}, - {320,144,336}, - {314,325,324}, - {322,308,309}, - {310,309,307}, - {287,286,289}, - {203,280,279}, - {203,279,205}, - {297,295,283}, - {297,283,284}, - {447,205,279}, - {274,384, 80}, - {274, 80,226}, - {266,267,379}, - {266,379,380}, - {225,257,246}, - {225,246,245}, - {256,254,253}, - {256,253,255}, - {430,247,250}, - {226,235,244}, - {226,244,245}, - {232,233,244}, - {232,244,241}, - {230, 18, 19}, - { 32, 31,228}, - {219,220, 86}, - {219, 86, 57}, - {226,213,235}, - {206, 7, 6}, - {122,201,101}, - {201,204,101}, - {180,196,197}, - {170,192,171}, - {200,190,189}, - {194,193,195}, - {183,181,180}, - {183,180,182}, - {155,154,168}, - {149,156,151}, - {149,151,148}, - {155,156,120}, - {145,142,143}, - {145,143,146}, - {136,137,140}, - {133,132,130}, - {128,129,116}, - {100,120,121}, - {110,112,113}, - {110,113,114}, - { 66, 65, 63}, - { 66, 63, 99}, - { 66, 99, 98}, - { 96, 46, 61}, - { 89, 88, 90}, - { 86, 87, 57}, - { 80, 78, 81}, - { 72, 69, 49}, - { 67, 48, 47}, - { 67, 47, 68}, - { 56, 55, 53}, - { 50, 49, 36}, - { 50, 36, 35}, - { 40, 39, 41}, - {242,243,229}, - {242,229,227}, - { 6, 37, 39}, - { 42, 47, 48}, - { 42, 48, 43}, - { 61, 46, 44}, - { 45, 70, 69}, - { 69, 70, 71}, - { 69, 71, 49}, - { 74, 78, 77}, - { 83, 84, 85}, - { 73, 74, 77}, - { 93, 96, 92}, - { 68, 46, 93}, - { 95, 99, 63}, - { 95, 63, 59}, - {115,108,110}, - {115,110,114}, - {125,126,127}, - {129,130,132}, - {137,133,138}, - {137,138,139}, - {148,146,143}, - {148,143,147}, - {119,118,154}, - {161,147,143}, - {165,164,151}, - {158,157,171}, - {158,171,172}, - {159,158,187}, - {159,187,186}, - {194,192,191}, - {194,191,193}, - {189,202,201}, - {182,197,184}, - {205, 8, 7}, - { 48,109,107}, - {218,219, 57}, - {218, 57, 56}, - {207,231,211}, - {232,230,231}, - {232,231,233}, - { 53, 52, 31}, - {388,411,386}, - {409,430,250}, - {262,429,254}, - {262,254,256}, - {442,444,428}, - {273,264,383}, - {273,383,384}, - {429,271,251}, - {429,251,254}, - {413,365,362}, - { 67,413,360}, - {282,283,295}, - {285,301,299}, - {202,281,280}, - {284,283,291}, - {284,291,289}, - {320,189,160}, - {308,306,307}, - {307,309,308}, - {319,317,330}, - {319,330,328}, - {353,352,324}, - {332,331,333}, - {340,341,338}, - {354,341,344}, - {349,358,357}, - {349,357,347}, - {364,355,356}, - {364,356,363}, - {364,365,366}, - {364,366,369}, - {374,376,402}, - {375, 92,373}, - { 77,389,390}, - {382,380,381}, - {389, 77,386}, - {393,394,412}, - {393,412,392}, - {401,394,416}, - {415,400,403}, - {411,410,427}, - {411,427,426}, - {422,420,424}, - {247,248,263}, - {247,263,261}, - {445,443, 14}, - {445, 14, 11}, - {449,450, 4}, - {449, 4, 5}, - {443,441, 17}, - {443, 17, 14}, - {436, 23, 17}, - {436, 17,441}, - {424,448,422}, - {448,423,422}, - {414,419,418}, - {414,418,413}, - {406,404,405}, - {399,397,395}, - {399,395,396}, - {420,416,392}, - {388,410,411}, - {386,384,383}, - {390, 88, 77}, - {375, 94, 92}, - {415,414, 68}, - {415, 68, 94}, - {370,374,402}, - {370,402,398}, - {361,357,358}, - {361,358,359}, - {125,348,126}, - {346,344,343}, - {340,338,339}, - {337,335,334}, - {337,334,336}, - {325,353,324}, - {324,331,332}, - {324,332,329}, - {323,322,309}, - {323,309,310}, - {294,295,297}, - {294,297,296}, - {289,286,285}, - {202,280,203}, - {288,307,303}, - {282,295,321}, - { 67,360,111}, - {418,423,367}, - {418,367,366}, - {272,252,251}, - {272,251,271}, - {272,271,270}, - {255,253,274}, - {265,266,380}, - {265,380,382}, - {442,428,261}, - {440,263,258}, - {440,258,260}, - {409,250,410}, - {255,226,245}, - {255,245,246}, - { 31,240,243}, - {236,234,235}, - {236,235,237}, - {233,225,245}, - {233,245,244}, - {220,221, 85}, - {220, 85, 86}, - { 81,213,226}, - { 81,226, 80}, - { 7,206,205}, - {186,184,198}, - {186,198,199}, - {204,203,205}, - {204,205,206}, - {195,193,196}, - {171,174,172}, - {173,174,175}, - {173,172,174}, - {155,167,166}, - {160,161,143}, - {160,143,144}, - {119,154,155}, - {148,151,150}, - {148,150,146}, - {140,137,139}, - {140,139,141}, - {127,126,130}, - {114,124,128}, - {114,128,115}, - {117,105,106}, - {117,106,116}, - {104,105,100}, - {104,100,103}, - { 59, 60, 91}, - { 97, 96, 61}, - { 97, 61, 64}, - { 91, 72, 89}, - { 87, 84, 79}, - { 87, 79, 76}, - { 78, 80, 77}, - { 49, 50, 74}, - { 60, 44, 45}, - { 61, 44, 58}, - { 51, 50, 35}, - { 51, 35, 34}, - { 39, 37, 41}, - { 33, 34, 9}, - { 33, 9, 12}, - { 0, 36, 37}, - { 0, 37, 6}, - { 40, 46, 47}, - { 40, 47, 42}, - { 53, 54, 56}, - { 65, 62, 63}, - { 72, 49, 73}, - { 79, 78, 75}, - { 79, 75, 76}, - { 52, 53, 76}, - { 92, 89, 90}, - { 96, 93, 46}, - {102,103,100}, - {102,100,101}, - {116,106,108}, - {116,108,115}, - {123,125,124}, - {116,115,128}, - {118,131,135}, - {140,135,136}, - {148,147,149}, - {120,119,155}, - {164,162,152}, - {164,152,150}, - {157,147,161}, - {157,161,170}, - {186,187,185}, - {186,185,184}, - {193,197,196}, - {202,203,204}, - {194,195,178}, - {198,184,197}, - { 67,111,109}, - { 38, 43,103}, - { 38,103,102}, - {214,223,222}, - {214,222,221}, - {214,221,220}, - {214,220,219}, - {214,219,218}, - {213,237,235}, - {221,222, 83}, - {221, 83, 85}, - { 15,229, 33}, - {227, 18,230}, - {227,230,232}, - { 52, 51,240}, - { 75, 78, 50}, - {408,430,409}, - {260,258,257}, - {260,257,259}, - {224,207,259}, - {268,269,405}, - {268,405,404}, - {413,362,360}, - {447, 8,205}, - {299,297,285}, - {189,281,202}, - {290,288,289}, - {290,289,291}, - {322,321,295}, - {322,295,294}, - {333,323,311}, - {333,311,320}, - {317,316,329}, - {320,160,144}, - {353,325,326}, - {329,332,334}, - {329,334,330}, - {339,338,141}, - {339,141,139}, - {348,345,126}, - {347,356,346}, - {123,349,125}, - {364,353,354}, - {364,354,355}, - {365,364,363}, - {376,391,394}, - {376,394,401}, - { 92,376,374}, - { 92,374,373}, - {377, 90, 88}, - {380,379,378}, - {380,378,381}, - {388,387,409}, - {388,409,410}, - {416,393,392}, - {399,398,402}, - {399,402,403}, - {250,428,427}, - {421,417,416}, - {421,416,420}, - {426,427,446}, - {426,446,451}, - {444,442,441}, - {452,451,450}, - {452,450,449} -}; - - -//***************************THE END OF FAMOUS BUNNY TRIMESH********************************************// - - -#endif //BUNNY_MESH_H_ diff --git a/Demos/GimpactTestDemo/CMakeLists.txt b/Demos/GimpactTestDemo/CMakeLists.txt deleted file mode 100644 index fc7331c23..000000000 --- a/Demos/GimpactTestDemo/CMakeLists.txt +++ /dev/null @@ -1,45 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - -IF (USE_GLUT) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ) - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath GIMPACTUtils ConvexDecomposition ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppGimpactTestDemo - GimpactTestDemo.cpp - GimpactTestDemo.h - main.cpp - ) -ELSE(USE_GLUT) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ) - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath GIMPACTUtils ConvexDecomposition ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppGimpactTestDemo - WIN32 - GimpactTestDemo.cpp - GimpactTestDemo.h - ../OpenGL/Win32AppMain.cpp - Win32GimpactDemo.cpp - ) -ENDIF(USE_GLUT) diff --git a/Demos/GimpactTestDemo/GimpactTestDemo.cpp b/Demos/GimpactTestDemo/GimpactTestDemo.cpp deleted file mode 100644 index 9e5427319..000000000 --- a/Demos/GimpactTestDemo/GimpactTestDemo.cpp +++ /dev/null @@ -1,688 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "GimpactTestDemo.h" - -#define SHOW_NUM_DEEP_PENETRATIONS - -#include "LinearMath/btDefaultMotionState.h" -#include "LinearMath/btIDebugDraw.h" -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btDefaultMotionState.h" -#include "GLDebugFont.h" -/// Including GIMPACT here - - - -#include "GLDebugDrawer.h" - -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -/// Include Torus Mesh here -#include "TorusMesh.h" -#include "BunnyMesh.h" - -#ifdef SHOW_NUM_DEEP_PENETRATIONS -extern int gNumDeepPenetrationChecks; -extern int gNumSplitImpulseRecoveries; -extern int gNumGjkChecks; -#endif // - - - -//Real dts = 0.000001f; -Real dts = 1.0 / 60.0; - - -///************************************************************************************** -/// GIMPACT Test Demo made by DevO -/// -///************************************************************************************** - - - -GimpactConcaveDemo::~GimpactConcaveDemo() -{ - - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - delete m_dynamicsWorld; - - delete m_indexVertexArrays; - delete m_trimeshShape; - - delete m_indexVertexArrays2; - delete m_trimeshShape2; - - for (i=0;igetBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax); - - - int numObjects = m_dynamicsWorld->getNumCollisionObjects(); - btVector3 wireColor(1,0,0); - for (int i=0;igetCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(colObj); - - if (body && body->getMotionState()) - { - btDefaultMotionState* myMotionState = (btDefaultMotionState*)body->getMotionState(); - myMotionState->m_graphicsWorldTrans.getOpenGLMatrix(m); - } else - { - colObj->getWorldTransform().getOpenGLMatrix(m); - } - - btVector3 wireColor(1.f,1.0f,0.5f); //wants deactivation - if (i & 1) - { - wireColor = btVector3(0.f,0.0f,1.f); - } - ///color differently for active, sleeping, wantsdeactivation states - if (colObj->getActivationState() == 1) //active - { - if (i & 1) - { - wireColor += btVector3 (0.8f,0.1f,0.1f); - } else - { - wireColor += btVector3 (0.5f,0.f,0.f); - } - } - if (colObj->getActivationState() == 2) //ISLAND_SLEEPING - { - if (i & 1) - { - wireColor += btVector3 (0.5f,0.8f, 0.5f); - } else - { - wireColor += btVector3 (0.f,0.5f,0.f); - } - } - - m_shapeDrawer->drawOpenGL(m,colObj->getCollisionShape(),wireColor,getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - - float xOffset = 10.f; - float yStart = 20.f; - float yIncr = 20.f; - char buf[124]; - - glColor3f(0, 0, 0); - - setOrthographicProjection(); - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"mouse to interact"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - /* glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"space to reset"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - */ - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"cursor keys and z,x to navigate"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"i to toggle simulation, s single step"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"q to quit"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,". to shoot TRIMESH (dot)"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - // not yet hooked up again after refactoring... - -/* glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"d to toggle deactivation"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; -*/ - - /* - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"a to draw temporal AABBs"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - */ - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"h to toggle help text"); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - //bool useBulletLCP = !(getDebugMode() & btIDebugDraw::DBG_DisableBulletLCP); - - bool useCCD = ((getDebugMode() & btIDebugDraw::DBG_EnableCCD) != 0); - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"1 CCD mode (adhoc) = %i",useCCD); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"+- shooting speed = %10.2f",m_ShootBoxInitialSpeed); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - #ifdef SHOW_NUM_DEEP_PENETRATIONS - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"gNumDeepPenetrationChecks = %d",gNumDeepPenetrationChecks); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"gNumSplitImpulseRecoveries= %d",gNumSplitImpulseRecoveries); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - - - - glRasterPos3f(xOffset,yStart,0); - sprintf(buf,"gNumGjkChecks= %d",gNumGjkChecks); - GLDebugDrawString(xOffset,yStart,buf); - yStart += yIncr; - - #endif //SHOW_NUM_DEEP_PENETRATIONS - - - resetPerspectiveProjection(); - - - } - -} - -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::initGImpactCollision() -{ - /// Create Torus Shape - { - m_indexVertexArrays = new btTriangleIndexVertexArray - (NUM_TRIANGLES, - &gIndices[0][0], - 3*sizeof(int), - NUM_VERTICES, - (Real*) &gVertices[0],sizeof(Real)*3); - - -#ifdef BULLET_GIMPACT - #ifdef BULLET_GIMPACT_CONVEX_DECOMPOSITION - btGImpactConvexDecompositionShape * trimesh = new - btGImpactConvexDecompositionShape( - m_indexVertexArrays, btVector3(1.f,1.f,1.f),btScalar(0.01)); - trimesh->setMargin(0.07); - trimesh->updateBound(); - - - #else - btGImpactMeshShape * trimesh = new btGImpactMeshShape(m_indexVertexArrays); - trimesh->setLocalScaling(btVector3(1.f,1.f,1.f)); - #ifdef BULLET_TRIANGLE_COLLISION - trimesh->setMargin(0.07f); ///????? - #else - trimesh->setMargin(0.0f); - #endif - trimesh->updateBound(); - #endif - - m_trimeshShape = trimesh; - -#else - m_trimeshShape = new btGIMPACTMeshData(m_indexVertexArrays); -#endif - - } - - /// Create Bunny Shape - { - m_indexVertexArrays2 = new btTriangleIndexVertexArray - (BUNNY_NUM_TRIANGLES, - &gIndicesBunny[0][0], - 3*sizeof(int), - BUNNY_NUM_VERTICES, - (Real*) &gVerticesBunny[0],sizeof(Real)*3); -#ifdef BULLET_GIMPACT - - #ifdef BULLET_GIMPACT_CONVEX_DECOMPOSITION - btGImpactConvexDecompositionShape * trimesh2 = new - btGImpactConvexDecompositionShape( - m_indexVertexArrays2, btVector3(4.f,4.f,4.f),btScalar(0.01)); - trimesh2->setMargin(0.07); - trimesh2->updateBound(); - #else - btGImpactMeshShape * trimesh2 = new btGImpactMeshShape(m_indexVertexArrays2); - trimesh2->setLocalScaling(btVector3(4.f,4.f,4.f)); - #ifdef BULLET_TRIANGLE_COLLISION - trimesh2->setMargin(0.07f); ///????? - #else - trimesh2->setMargin(0.0f); - #endif - trimesh2->updateBound(); - #endif - - - - m_trimeshShape2 = trimesh2; -#else - m_trimeshShape2 = new btGIMPACTMeshData(m_indexVertexArrays2); - -#endif - - } - - - ///register GIMPACT algorithm - btCollisionDispatcher * dispatcher = static_cast(m_dynamicsWorld ->getDispatcher()); - -#ifdef BULLET_GIMPACT - btGImpactCollisionAlgorithm::registerAlgorithm(dispatcher); -#else - btConcaveConcaveCollisionAlgorithm::registerAlgorithm(dispatcher); -#endif - - -} - -#ifndef BULLET_GIMPACT -btCollisionShape * GimpactConcaveDemo::createTorusShape() -{ - btGIMPACTMeshShape * newtrimeshShape = new btGIMPACTMeshShape(m_trimeshShape); - newtrimeshShape->setLocalScaling(btVector3(1.f,1.f,1.f)); - return newtrimeshShape; -} -btCollisionShape * GimpactConcaveDemo::createBunnyShape() -{ - btGIMPACTMeshShape * newtrimeshShape = new btGIMPACTMeshShape(m_trimeshShape2); - newtrimeshShape->setLocalScaling(btVector3(4.f,4.f,4.f)); - return newtrimeshShape; -} -#endif -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::initPhysics() -{ - setTexturing(true); - setShadows(false); - - setCameraDistance(45.f); - - - /// Init Bullet - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - //btOverlappingPairCache* broadphase = new btSimpleBroadphase(); - //m_broadphase = new btSimpleBroadphase(); - - int maxProxies = 1024; - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax( 10000, 10000, 10000); - m_broadphase = new bt32BitAxisSweep3(worldAabbMin,worldAabbMax,maxProxies); - - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_constraintSolver,m_collisionConfiguration); - - //create trimesh model and shape - initGImpactCollision(); - - - - /// Create Scene - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - - - btCollisionShape* staticboxShape1 = new btBoxShape(btVector3(200,1,200));//floor - m_collisionShapes.push_back(staticboxShape1); - startTransform.setOrigin(btVector3(0,-10,0)); - localCreateRigidBody(mass, startTransform,staticboxShape1); - - btCollisionShape* staticboxShape2 = new btBoxShape(btVector3(1,50,200));//left wall - m_collisionShapes.push_back(staticboxShape2); - startTransform.setOrigin(btVector3(-200,15,0)); - localCreateRigidBody(mass, startTransform,staticboxShape2); - - btCollisionShape* staticboxShape3 = new btBoxShape(btVector3(1,50,200));//right wall - m_collisionShapes.push_back(staticboxShape3); - startTransform.setOrigin(btVector3(200,15,0)); - localCreateRigidBody(mass, startTransform,staticboxShape3); - - btCollisionShape* staticboxShape4 = new btBoxShape(btVector3(200,50,1));//front wall - m_collisionShapes.push_back(staticboxShape4); - startTransform.setOrigin(btVector3(0,15,200)); - localCreateRigidBody(mass, startTransform,staticboxShape4); - - btCollisionShape* staticboxShape5 = new btBoxShape(btVector3(200,50,1));//back wall - m_collisionShapes.push_back(staticboxShape5); - startTransform.setOrigin(btVector3(0,15,-200)); - localCreateRigidBody(mass, startTransform,staticboxShape5); - - - //static plane - - btVector3 normal(-0.5,0.5,0.0); - normal.normalize(); - btCollisionShape* staticplaneShape6 = new btStaticPlaneShape(normal,0.0);// A plane - m_collisionShapes.push_back(staticplaneShape6); - startTransform.setOrigin(btVector3(0,-9,0)); - - btRigidBody* staticBody2 = localCreateRigidBody(mass, startTransform,staticplaneShape6 ); - - //another static plane - - normal.setValue(0.5,0.7,0.0); - //normal.normalize(); - btCollisionShape* staticplaneShape7 = new btStaticPlaneShape(normal,0.0);// A plane - m_collisionShapes.push_back(staticplaneShape7); - startTransform.setOrigin(btVector3(0,-10,0)); - - staticBody2 = localCreateRigidBody(mass, startTransform,staticplaneShape7 ); - - /// Create Static Torus - float height = 28; - float step = 2.5; - float massT = 1.0; - - startTransform.setOrigin(btVector3(0,height,-5)); - startTransform.setRotation(btQuaternion(3.14159265*0.5,0,3.14159265*0.5)); -#ifdef BULLET_GIMPACT - kinematicTorus = localCreateRigidBody(0.0, startTransform,m_trimeshShape); - -#else - kinematicTorus = localCreateRigidBody(0.0, startTransform,createTorusShape()); - -#endif //kinematicTorus->setCollisionFlags(kinematicTorus->getCollisionFlags()|btCollisionObject::CF_STATIC_OBJECT); - //kinematicTorus->setActivationState(ISLAND_SLEEPING); - - kinematicTorus->setCollisionFlags( kinematicTorus->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - kinematicTorus->setActivationState(DISABLE_DEACTIVATION); - - /// Kinematic - kinTorusTran = btVector3(-0.1,0,0); - kinTorusRot = btQuaternion(0,3.14159265*0.01,0); - -#ifdef TEST_GIMPACT_TORUS - -#ifdef BULLET_GIMPACT - /// Create dynamic Torus - for (int i=0;i<6;i++) - { - height -= step; - startTransform.setOrigin(btVector3(0,height,-5)); - startTransform.setRotation(btQuaternion(0,0,3.14159265*0.5)); - - btRigidBody* bodyA; - bodyA= localCreateRigidBody(massT, startTransform,m_trimeshShape); - - height -= step; - startTransform.setOrigin(btVector3(0,height,-5)); - startTransform.setRotation(btQuaternion(3.14159265*0.5,0,3.14159265*0.5)); - btRigidBody* bodyB; - bodyB= localCreateRigidBody(massT, startTransform,m_trimeshShape); - - } -#else - -/// Create dynamic Torus - for (int i=0;i<6;i++) - { - height -= step; - startTransform.setOrigin(btVector3(0,height,-5)); - startTransform.setRotation(btQuaternion(0,0,3.14159265*0.5)); - - btRigidBody* bodyA = localCreateRigidBody(massT, startTransform,createTorusShape()); - - height -= step; - startTransform.setOrigin(btVector3(0,height,-5)); - startTransform.setRotation(btQuaternion(3.14159265*0.5,0,3.14159265*0.5)); - btRigidBody* bodyB = localCreateRigidBody(massT, startTransform,createTorusShape()); - - } -#endif //no BULLET_GIMPACT -#endif - - startTransform.setIdentity(); - - - /// Create Dynamic Boxes - { - for (int i=0;i<8;i++) - { - btCollisionShape* boxShape = new btBoxShape(btVector3(1,1,1)); - m_collisionShapes.push_back(boxShape); - - startTransform.setOrigin(btVector3(2*i-5,2,-3)); - localCreateRigidBody(1, startTransform,boxShape); - } - } - - - //m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - -} - -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::shootTrimesh(const btVector3& destination) -{ - - if (m_dynamicsWorld) - { - float mass = 4.f; - btTransform startTransform; - startTransform.setIdentity(); - btVector3 camPos = getCameraPosition(); - startTransform.setOrigin(camPos); -#ifdef BULLET_GIMPACT - btRigidBody* body = this->localCreateRigidBody(mass, startTransform,m_trimeshShape2); -#else - btRigidBody* body = this->localCreateRigidBody(mass, startTransform,createBunnyShape()); -#endif - btVector3 linVel(destination[0]-camPos[0],destination[1]-camPos[1],destination[2]-camPos[2]); - linVel.normalize(); - linVel*=m_ShootBoxInitialSpeed*0.25; - - body->getWorldTransform().setOrigin(camPos); - body->getWorldTransform().setRotation(btQuaternion(0,0,0,1)); - body->setLinearVelocity(linVel); - body->setAngularVelocity(btVector3(0,0,0)); - } -} - -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - -#define USE_KINEMATIC_GROUND -#ifdef USE_KINEMATIC_GROUND - //kinTorusTran = btVector3(-0.05,0,0); - //kinTorusRot = btQuaternion(0,3.14159265*0.1,0); - - //kinematic object - btCollisionObject* colObj = kinematicTorus; - //is this a rigidbody with a motionstate? then use the motionstate to update positions! - if (colObj && btRigidBody::upcast(colObj) && btRigidBody::upcast(colObj)->getMotionState()) - { - btTransform newTrans; - btRigidBody::upcast(colObj)->getMotionState()->getWorldTransform(newTrans); - - newTrans.getOrigin() += kinTorusTran; - newTrans.getBasis() = newTrans.getBasis() * btMatrix3x3(kinTorusRot); - if(newTrans.getOrigin().getX() > 6.0){ - newTrans.getOrigin().setX(6.0); - kinTorusTran = -kinTorusTran; - } - if(newTrans.getOrigin().getX() < -6.0){ - newTrans.getOrigin().setX(-6.0); - kinTorusTran = -kinTorusTran; - } - - btRigidBody::upcast(colObj)->getMotionState()->setWorldTransform(newTrans); - } else - { - /* - btTransform &newTrans = m_dynamicsWorld->getCollisionObjectArray()[0]->getWorldTransform(); - newTrans.getOrigin() += kinTorusTran; - if(newTrans.getOrigin().getX() > 0.1) kinTorusTran = -kinTorusTran; - if(newTrans.getOrigin().getX() < 0.1) kinTorusTran = -kinTorusTran; - */ - } - -#endif //USE_KINEMATIC_GROUND - - - unsigned long int time = getDeltaTimeMicroseconds()/btScalar(1000); - printf("%i time %i ms \n",m_steps_done,int(time)); - -//#ifdef BULLET_GIMPACT -// printf("%i time %.1f ms \n",m_steps_done,btGImpactCollisionAlgorithm::getAverageTreeCollisionTime()); -//#else -// printf("%i time %.1f ms \n",m_steps_done,btConcaveConcaveCollisionAlgorithm::getAverageTreeCollisionTime()); -//#endif - - //float dt = float(m_clock.getTimeMicroseconds()) * dts; //0.000001f; - float dt = btScalar(1./60.); - - - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - m_steps_done++; - - //m_dynamicsWorld->stepSimulation(dts); - - renderme(); - - glFlush(); - swapBuffers(); - -} - -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::clientResetScene() -{ - m_steps_done = 0; - DemoApplication::clientResetScene(); -} - -#define KEY_ESCAPE 0x1B - - -//------------------------------------------------------------------------------ -void GimpactConcaveDemo::keyboardCallback(unsigned char key, int x, int y) -{ - switch (key) - { - case '.': - { - shootTrimesh(getCameraTargetPosition()); - break; - } - - case '2': - { - dts += 0.000001f; - break; - } - case '3': - { - dts -= 0.000001f; if(dts<0.000001f) dts = 0.000001f; - break; - } - - default: - DemoApplication::keyboardCallback(key, x, y); - } -} - - - diff --git a/Demos/GimpactTestDemo/GimpactTestDemo.h b/Demos/GimpactTestDemo/GimpactTestDemo.h deleted file mode 100644 index 0b83e49c3..000000000 --- a/Demos/GimpactTestDemo/GimpactTestDemo.h +++ /dev/null @@ -1,145 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef TEST_CONCAVE_DEMO_H -#define TEST_CONCAVE_DEMO_H - - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -class btTriangleIndexVertexArray; -class btDefaultCollisionConfiguration; - -//#define BULLET_TRIANGLE_COLLISION 1 -#define BULLET_GIMPACT 1 -//#define BULLET_GIMPACT_CONVEX_DECOMPOSITION 1 - -#define TEST_GIMPACT_TORUS - -#ifdef BULLET_GIMPACT - -#include "BulletCollision/Gimpact/btGImpactCollisionAlgorithm.h" - #ifdef BULLET_GIMPACT_CONVEX_DECOMPOSITION - #include "../Extras/GIMPACTUtils/btGImpactConvexDecompositionShape.h" - #endif - - -#else - -#include "BulletCollision/Gimpact/btConcaveConcaveCollisionAlgorithm.h" -#include "BulletCollision/Gimpact/btGIMPACTMeshShape.h" - -#endif - - - -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; - -///GimpactConcaveDemo shows usage of static concave triangle meshes -///It also shows per-triangle material (friction/restitution) through CustomMaterialCombinerCallback -class GimpactConcaveDemo : public PlatformDemoApplication -{ - -public: - GimpactConcaveDemo() - : m_steps_done(0), - m_trimeshShape(NULL), - m_trimeshShape2(NULL), - m_indexVertexArrays(NULL), - m_indexVertexArrays2(NULL), - - - kinematicTorus(NULL), - - - m_gimpactCollisionCreateFunc(NULL), - m_collisionConfiguration(NULL), - - m_dispatcher(NULL), - - m_broadphase(NULL), - m_constraintSolver(NULL) - { - } - - virtual ~GimpactConcaveDemo(); - - - void initGImpactCollision(); - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void clientResetScene(); - - virtual void renderme(); - virtual void keyboardCallback(unsigned char key, int x, int y); - - ///Demo functions - void shootTrimesh(const btVector3& destination); - -public: ///data - unsigned int m_steps_done; - -#ifdef BULLET_GIMPACT - btCollisionShape *m_trimeshShape; - btCollisionShape *m_trimeshShape2; -#else - - btGIMPACTMeshData * m_trimeshShape; - btGIMPACTMeshData * m_trimeshShape2; - - btCollisionShape * createTorusShape(); - btCollisionShape * createBunnyShape(); - -#endif - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btTriangleIndexVertexArray *m_indexVertexArrays; - btTriangleIndexVertexArray *m_indexVertexArrays2; - - btVector3 kinTorusTran; - btQuaternion kinTorusRot; - btRigidBody *kinematicTorus; - - - btCollisionAlgorithmCreateFunc* m_gimpactCollisionCreateFunc; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - btCollisionDispatcher* m_dispatcher; - btBroadphaseInterface* m_broadphase; - btConstraintSolver* m_constraintSolver; - - static DemoApplication* Create() - { - GimpactConcaveDemo* demo = new GimpactConcaveDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -#endif //CONCAVE_DEMO_H - diff --git a/Demos/GimpactTestDemo/TorusMesh.h b/Demos/GimpactTestDemo/TorusMesh.h deleted file mode 100644 index 69190413d..000000000 --- a/Demos/GimpactTestDemo/TorusMesh.h +++ /dev/null @@ -1,921 +0,0 @@ -#ifndef TORUS_MESH_H_ -#define TORUS_MESH_H_ - - -//*************************** NOT REALLY FAMOUS TORUS ********************************************// - -#define Real btScalar -const int NUM_TRIANGLES =600; -const int NUM_VERTICES = 300; -const int NUM_INDICES = NUM_TRIANGLES * 3; - - -static Real gVertices[NUM_VERTICES * 3] = { - Real(2.5), Real(0), Real(0), - Real(2.405), Real(0.294), Real(0), - Real(2.155), Real(0.476), Real(0), - Real(1.845), Real(0.476), Real(0), - Real(1.595), Real(0.294), Real(0), - Real(1.5), Real(0 ), Real(0), - Real(1.595), Real(-0.294), Real(0), - Real(1.845), Real(-0.476), Real(0), - Real(2.155), Real(-0.476), Real(0), - Real(2.405), Real(-0.294), Real(0), - Real(2.445), Real(0 ), Real(0.52 ), - Real(2.352), Real(0.294), Real(0.5 ), - Real(2.107), Real(0.476), Real(0.448), - Real(1.805), Real(0.476), Real(0.384), - Real(1.561), Real(0.294), Real(0.332), - Real(1.467), Real(0 ), Real(0.312), - Real(1.561), Real(-0.294), Real(0.332), - Real(1.805), Real(-0.476), Real(0.384), - Real(2.107), Real(-0.476), Real(0.448), - Real(2.352), Real(-0.294), Real(0.5 ), - Real(2.284), Real(0), Real(1.017), - Real(2.197), Real(0.294), Real(0.978), - Real(1.968), Real(0.476), Real(0.876), - Real(1.686), Real(0.476), Real(0.751), - Real(1.458), Real(0.294), Real(0.649), - Real(1.37), Real(0), Real(0.61 ), - Real(1.458), Real(-0.294), Real(0.649), - Real(1.686), Real(-0.476), Real(0.751), - Real(1.968), Real(-0.476), Real(0.876), - Real(2.197), Real(-0.294), Real(0.978), - Real(2.023), Real(0), Real(1.469), - Real(1.945), Real(0.294), Real(1.413), - Real(1.743), Real(0.476), Real(1.266), - Real(1.493), Real(0.476), Real(1.085), - Real(1.291), Real(0.294), Real(0.938), - Real(1.214), Real(0), Real(0.882), - Real(1.291), Real(-0.294), Real(0.938), - Real(1.493), Real(-0.476), Real(1.085), - Real(1.743), Real(-0.476), Real(1.266), - Real(1.945), Real(-0.294), Real(1.413), - Real(1.673), Real(0), Real(1.858), - Real(1.609), Real(0.294), Real(1.787), - Real(1.442), Real(0.476), Real(1.601), - Real(1.235), Real(0.476), Real(1.371), - Real(1.068), Real(0.294), Real(1.186), - Real(1.004), Real(0), Real(1.115), - Real(1.068), Real(-0.294), Real(1.186), - Real(1.235), Real(-0.476), Real(1.371), - Real(1.442), Real(-0.476), Real(1.601), - Real(1.609), Real(-0.294), Real(1.787), - Real(1.25), Real(0), Real(2.165), - Real(1.202), Real(0.294), Real(2.082), - Real(1.077), Real(0.476), Real(1.866), - Real(0.923), Real(0.476), Real(1.598), - Real(0.798), Real(0.294), Real(1.382), - Real(0.75), Real(0), Real(1.299), - Real(0.798), Real(-0.294), Real(1.382), - Real(0.923), Real(-0.476), Real(1.598), - Real(1.077), Real(-0.476), Real(1.866), - Real(1.202), Real(-0.294), Real(2.082), - Real(0.773), Real(0), Real(2.378), - Real(0.743), Real(0.294), Real(2.287), - Real(0.666), Real(0.476), Real(2.049), - Real(0.57), Real(0.476), Real(1.755), - Real(0.493), Real(0.294), Real(1.517), - Real(0.464), Real(0), Real(1.427), - Real(0.493), Real(-0.294), Real(1.517), - Real(0.57), Real(-0.476), Real(1.755), - Real(0.666), Real(-0.476), Real(2.049), - Real(0.743), Real(-0.294), Real(2.287), - Real(0.261), Real(0), Real(2.486), - Real(0.251), Real(0.294), Real(2.391), - Real(0.225), Real(0.476), Real(2.143), - Real(0.193), Real(0.476), Real(1.835), - Real(0.167), Real(0.294), Real(1.587), - Real(0.157), Real(0), Real(1.492), - Real(0.167), Real(-0.294), Real(1.587), - Real(0.193), Real(-0.476), Real(1.835), - Real(0.225), Real(-0.476), Real(2.143), - Real(0.251), Real(-0.294), Real(2.391), - Real(-0.261), Real(0), Real(2.486), - Real(-0.251), Real(0.294), Real(2.391), - Real(-0.225), Real(0.476), Real(2.143), - Real(-0.193), Real(0.476), Real(1.835), - Real(-0.167), Real(0.294), Real(1.587), - Real(-0.157), Real(0), Real(1.492), - Real(-0.167), Real(-0.294), Real(1.587), - Real(-0.193), Real(-0.476), Real(1.835), - Real(-0.225), Real(-0.476), Real(2.143), - Real(-0.251), Real(-0.294), Real(2.391), - Real(-0.773), Real(0), Real(2.378), - Real(-0.743), Real(0.294), Real(2.287), - Real(-0.666), Real(0.476), Real(2.049), - Real(-0.57), Real(0.476), Real(1.755), - Real(-0.493), Real(0.294), Real(1.517), - Real(-0.464), Real(0), Real(1.427), - Real(-0.493), Real(-0.294), Real(1.517), - Real(-0.57), Real(-0.476), Real(1.755), - Real(-0.666), Real(-0.476), Real(2.049), - Real(-0.743), Real(-0.294), Real(2.287), - Real(-1.25 ), Real(0), Real(2.165), - Real(-1.202), Real(0.294), Real(2.082), - Real(-1.077), Real(0.476), Real(1.866), - Real(-0.923), Real(0.476), Real(1.598), - Real(-0.798), Real(0.294), Real(1.382), - Real(-0.75), Real(0), Real(1.299), - Real(-0.798), Real(-0.294), Real(1.382), - Real(-0.923), Real(-0.476), Real(1.598), - Real(-1.077), Real(-0.476), Real(1.866), - Real(-1.202), Real(-0.294), Real(2.082), - Real(-1.673), Real(0), Real(1.858), - Real(-1.609), Real(0.294), Real(1.787), - Real(-1.442), Real(0.476), Real(1.601), - Real(-1.235), Real(0.476), Real(1.371), - Real(-1.068), Real(0.294), Real(1.186), - Real(-1.004), Real(0), Real(1.115), - Real(-1.068), Real(-0.294), Real(1.186), - Real(-1.235), Real(-0.476), Real(1.371), - Real(-1.442), Real(-0.476), Real(1.601), - Real(-1.609), Real(-0.294), Real(1.787), - Real(-2.023), Real(0), Real(1.469), - Real(-1.945), Real(0.294), Real(1.413), - Real(-1.743), Real(0.476), Real(1.266), - Real(-1.493), Real(0.476), Real(1.085), - Real(-1.291), Real(0.294), Real(0.938), - Real(-1.214), Real(0), Real(0.882), - Real(-1.291), Real(-0.294), Real(0.938), - Real(-1.493), Real(-0.476), Real(1.085), - Real(-1.743), Real(-0.476), Real(1.266), - Real(-1.945), Real(-0.294), Real(1.413), - Real(-2.284), Real(0), Real(1.017), - Real(-2.197), Real(0.294), Real(0.978), - Real(-1.968), Real(0.476), Real(0.876), - Real(-1.686), Real(0.476), Real(0.751), - Real(-1.458), Real(0.294), Real(0.649), - Real(-1.37), Real(0), Real(0.61 ), - Real(-1.458), Real(-0.294), Real(0.649), - Real(-1.686), Real(-0.476), Real(0.751), - Real(-1.968), Real(-0.476), Real(0.876), - Real(-2.197), Real(-0.294), Real(0.978), - Real(-2.445), Real(0), Real(0.52), - Real(-2.352), Real(0.294), Real(0.5), - Real(-2.107), Real(0.476), Real(0.448), - Real(-1.805), Real(0.476), Real(0.384), - Real(-1.561), Real(0.294), Real(0.332), - Real(-1.467), Real(0), Real(0.312), - Real(-1.561), Real(-0.294), Real(0.332), - Real(-1.805), Real(-0.476), Real(0.384), - Real(-2.107), Real(-0.476), Real(0.448), - Real(-2.352), Real(-0.294), Real(0.5), - Real(-2.5 ), Real(0), Real(0), - Real(-2.405), Real(0.294), Real(0), - Real(-2.155), Real(0.476), Real(0), - Real(-1.845), Real(0.476), Real(0), - Real(-1.595), Real(0.294), Real(0), - Real(-1.5), Real(0), Real(0), - Real(-1.595), Real(-0.294), Real(0), - Real(-1.845), Real(-0.476), Real(0), - Real(-2.155), Real(-0.476), Real(0), - Real(-2.405), Real(-0.294), Real(0), - Real(-2.445), Real(0), Real(-0.52), - Real(-2.352), Real(0.294), Real(-0.5), - Real(-2.107), Real(0.476), Real(-0.448), - Real(-1.805), Real(0.476), Real(-0.384), - Real(-1.561), Real(0.294), Real(-0.332), - Real(-1.467), Real(0), Real(-0.312), - Real(-1.561), Real(-0.294), Real(-0.332), - Real(-1.805), Real(-0.476), Real(-0.384), - Real(-2.107), Real(-0.476), Real(-0.448), - Real(-2.352), Real(-0.294), Real(-0.5), - Real(-2.284), Real(0), Real(-1.017), - Real(-2.197), Real(0.294), Real(-0.978), - Real(-1.968), Real(0.476), Real(-0.876), - Real(-1.686), Real(0.476), Real(-0.751), - Real(-1.458), Real(0.294), Real(-0.649), - Real(-1.37), Real(0), Real(-0.61), - Real(-1.458), Real(-0.294), Real(-0.649), - Real(-1.686), Real(-0.476), Real(-0.751), - Real(-1.968), Real(-0.476), Real(-0.876), - Real(-2.197), Real(-0.294), Real(-0.978), - Real(-2.023), Real(0), Real(-1.469), - Real(-1.945), Real(0.294), Real(-1.413), - Real(-1.743), Real(0.476), Real(-1.266), - Real(-1.493), Real(0.476), Real(-1.085), - Real(-1.291), Real(0.294), Real(-0.938), - Real(-1.214), Real(0), Real(-0.882), - Real(-1.291), Real(-0.294), Real(-0.938), - Real(-1.493), Real(-0.476), Real(-1.085), - Real(-1.743), Real(-0.476), Real(-1.266), - Real(-1.945), Real(-0.294), Real(-1.413), - Real(-1.673), Real(0), Real(-1.858), - Real(-1.609), Real(0.294), Real(-1.787), - Real(-1.442), Real(0.476), Real(-1.601), - Real(-1.235), Real(0.476), Real(-1.371), - Real(-1.068), Real(0.294), Real(-1.186), - Real(-1.004), Real(0), Real(-1.115), - Real(-1.068), Real(-0.294), Real(-1.186), - Real(-1.235), Real(-0.476), Real(-1.371), - Real(-1.442), Real(-0.476), Real(-1.601), - Real(-1.609), Real(-0.294), Real(-1.787), - Real(-1.25 ), Real(0), Real(-2.165), - Real(-1.202), Real(0.294), Real(-2.082), - Real(-1.077), Real(0.476), Real(-1.866), - Real(-0.923), Real(0.476), Real(-1.598), - Real(-0.798), Real(0.294), Real(-1.382), - Real(-0.75), Real(0), Real(-1.299), - Real(-0.798), Real(-0.294), Real(-1.382), - Real(-0.923), Real(-0.476), Real(-1.598), - Real(-1.077), Real(-0.476), Real(-1.866), - Real(-1.202), Real(-0.294), Real(-2.082), - Real(-0.773), Real(0), Real(-2.378), - Real(-0.743), Real(0.294), Real(-2.287), - Real(-0.666), Real(0.476), Real(-2.049), - Real(-0.57), Real(0.476), Real(-1.755), - Real(-0.493), Real(0.294), Real(-1.517), - Real(-0.464), Real(0), Real(-1.427), - Real(-0.493), Real(-0.294), Real(-1.517), - Real(-0.57), Real(-0.476), Real(-1.755), - Real(-0.666), Real(-0.476), Real(-2.049), - Real(-0.743), Real(-0.294), Real(-2.287), - Real(-0.261), Real(0), Real(-2.486), - Real(-0.251), Real(0.294), Real(-2.391), - Real(-0.225), Real(0.476), Real(-2.143), - Real(-0.193), Real(0.476), Real(-1.835), - Real(-0.167), Real(0.294), Real(-1.587), - Real(-0.157), Real(0), Real(-1.492), - Real(-0.167), Real(-0.294), Real(-1.587), - Real(-0.193), Real(-0.476), Real(-1.835), - Real(-0.225), Real(-0.476), Real(-2.143), - Real(-0.251), Real(-0.294), Real(-2.391), - Real(0.261), Real(0), Real(-2.486), - Real(0.251), Real(0.294), Real(-2.391), - Real(0.225), Real(0.476), Real(-2.143), - Real(0.193), Real(0.476), Real(-1.835), - Real(0.167), Real(0.294), Real(-1.587), - Real(0.157), Real(0), Real(-1.492), - Real(0.167), Real(-0.294), Real(-1.587), - Real(0.193), Real(-0.476), Real(-1.835), - Real(0.225), Real(-0.476), Real(-2.143), - Real(0.251), Real(-0.294), Real(-2.391), - Real(0.773), Real(0), Real(-2.378), - Real(0.743), Real(0.294), Real(-2.287), - Real(0.666), Real(0.476), Real(-2.049), - Real(0.57), Real(0.476), Real(-1.755), - Real(0.493), Real(0.294), Real(-1.517), - Real(0.464), Real(0), Real(-1.427), - Real(0.493), Real(-0.294), Real(-1.517), - Real(0.57), Real(-0.476), Real(-1.755), - Real(0.666), Real(-0.476), Real(-2.049), - Real(0.743), Real(-0.294), Real(-2.287), - Real(1.25), Real(0), Real(-2.165), - Real(1.202), Real(0.294), Real(-2.082), - Real(1.077), Real(0.476), Real(-1.866), - Real(0.923), Real(0.476), Real(-1.598), - Real(0.798), Real(0.294), Real(-1.382), - Real(0.75), Real(0), Real(-1.299), - Real(0.798), Real(-0.294), Real(-1.382), - Real(0.923), Real(-0.476), Real(-1.598), - Real(1.077), Real(-0.476), Real(-1.866), - Real(1.202), Real(-0.294), Real(-2.082), - Real(1.673), Real(0), Real(-1.858), - Real(1.609), Real(0.294), Real(-1.787), - Real(1.442), Real(0.476), Real(-1.601), - Real(1.235), Real(0.476), Real(-1.371), - Real(1.068), Real(0.294), Real(-1.186), - Real(1.004), Real(0), Real(-1.115), - Real(1.068), Real(-0.294), Real(-1.186), - Real(1.235), Real(-0.476), Real(-1.371), - Real(1.442), Real(-0.476), Real(-1.601), - Real(1.609), Real(-0.294), Real(-1.787), - Real(2.023), Real(0), Real(-1.469), - Real(1.945), Real(0.294), Real(-1.413), - Real(1.743), Real(0.476), Real(-1.266), - Real(1.493), Real(0.476), Real(-1.085), - Real(1.291), Real(0.294), Real(-0.938), - Real(1.214), Real(0), Real(-0.882), - Real(1.291), Real(-0.294), Real(-0.938), - Real(1.493), Real(-0.476), Real(-1.085), - Real(1.743), Real(-0.476), Real(-1.266), - Real(1.945), Real(-0.294), Real(-1.413), - Real(2.284), Real(0), Real(-1.017), - Real(2.197), Real(0.294), Real(-0.978), - Real(1.968), Real(0.476), Real(-0.876), - Real(1.686), Real(0.476), Real(-0.751), - Real(1.458), Real(0.294), Real(-0.649), - Real(1.37), Real(0), Real(-0.61 ), - Real(1.458), Real(-0.294), Real(-0.649), - Real(1.686), Real(-0.476), Real(-0.751), - Real(1.968), Real(-0.476), Real(-0.876), - Real(2.197), Real(-0.294), Real(-0.978), - Real(2.445), Real(0), Real(-0.52 ), - Real(2.352), Real(0.294), Real(-0.5 ), - Real(2.107), Real(0.476), Real(-0.448), - Real(1.805), Real(0.476), Real(-0.384), - Real(1.561), Real(0.294), Real(-0.332), - Real(1.467), Real(0), Real(-0.312), - Real(1.561), Real(-0.294), Real(-0.332), - Real(1.805), Real(-0.476), Real(-0.384), - Real(2.107), Real(-0.476), Real(-0.448), - Real(2.352), Real(-0.294), Real(-0.5) -}; - - -static int gIndices[NUM_TRIANGLES][3] = { - {0, 1, 11}, - {1, 2, 12}, - {2, 3, 13}, - {3, 4, 14}, - {4, 5, 15}, - {5, 6, 16}, - {6, 7, 17}, - {7, 8, 18}, - {8, 9, 19}, - {9, 0, 10}, - {10, 11, 21}, - {11, 12, 22}, - {12, 13, 23}, - {13, 14, 24}, - {14, 15, 25}, - {15, 16, 26}, - {16, 17, 27}, - {17, 18, 28}, - {18, 19, 29}, - {19, 10, 20}, - {20, 21, 31}, - {21, 22, 32}, - {22, 23, 33}, - {23, 24, 34}, - {24, 25, 35}, - {25, 26, 36}, - {26, 27, 37}, - {27, 28, 38}, - {28, 29, 39}, - {29, 20, 30}, - {30, 31, 41}, - {31, 32, 42}, - {32, 33, 43}, - {33, 34, 44}, - {34, 35, 45}, - {35, 36, 46}, - {36, 37, 47}, - {37, 38, 48}, - {38, 39, 49}, - {39, 30, 40}, - {40, 41, 51}, - {41, 42, 52}, - {42, 43, 53}, - {43, 44, 54}, - {44, 45, 55}, - {45, 46, 56}, - {46, 47, 57}, - {47, 48, 58}, - {48, 49, 59}, - {49, 40, 50}, - {50, 51, 61}, - {51, 52, 62}, - {52, 53, 63}, - {53, 54, 64}, - {54, 55, 65}, - {55, 56, 66}, - {56, 57, 67}, - {57, 58, 68}, - {58, 59, 69}, - {59, 50, 60}, - {60, 61, 71}, - {61, 62, 72}, - {62, 63, 73}, - {63, 64, 74}, - {64, 65, 75}, - {65, 66, 76}, - {66, 67, 77}, - {67, 68, 78}, - {68, 69, 79}, - {69, 60, 70}, - {70, 71, 81}, - {71, 72, 82}, - {72, 73, 83}, - {73, 74, 84}, - {74, 75, 85}, - {75, 76, 86}, - {76, 77, 87}, - {77, 78, 88}, - {78, 79, 89}, - {79, 70, 80}, - {80, 81, 91}, - {81, 82, 92}, - {82, 83, 93}, - {83, 84, 94}, - {84, 85, 95}, - {85, 86, 96}, - {86, 87, 97}, - {87, 88, 98}, - {88, 89, 99}, - {89, 80, 90}, - {90, 91, 101}, - {91, 92, 102}, - {92, 93, 103}, - {93, 94, 104}, - {94, 95, 105}, - {95, 96, 106}, - {96, 97, 107}, - {97, 98, 108}, - {98, 99, 109}, - {99, 90, 100}, - {100, 101, 111}, - {101, 102, 112}, - {102, 103, 113}, - {103, 104, 114}, - {104, 105, 115}, - {105, 106, 116}, - {106, 107, 117}, - {107, 108, 118}, - {108, 109, 119}, - {109, 100, 110}, - {110, 111, 121}, - {111, 112, 122}, - {112, 113, 123}, - {113, 114, 124}, - {114, 115, 125}, - {115, 116, 126}, - {116, 117, 127}, - {117, 118, 128}, - {118, 119, 129}, - {119, 110, 120}, - {120, 121, 131}, - {121, 122, 132}, - {122, 123, 133}, - {123, 124, 134}, - {124, 125, 135}, - {125, 126, 136}, - {126, 127, 137}, - {127, 128, 138}, - {128, 129, 139}, - {129, 120, 130}, - {130, 131, 141}, - {131, 132, 142}, - {132, 133, 143}, - {133, 134, 144}, - {134, 135, 145}, - {135, 136, 146}, - {136, 137, 147}, - {137, 138, 148}, - {138, 139, 149}, - {139, 130, 140}, - {140, 141, 151}, - {141, 142, 152}, - {142, 143, 153}, - {143, 144, 154}, - {144, 145, 155}, - {145, 146, 156}, - {146, 147, 157}, - {147, 148, 158}, - {148, 149, 159}, - {149, 140, 150}, - {150, 151, 161}, - {151, 152, 162}, - {152, 153, 163}, - {153, 154, 164}, - {154, 155, 165}, - {155, 156, 166}, - {156, 157, 167}, - {157, 158, 168}, - {158, 159, 169}, - {159, 150, 160}, - {160, 161, 171}, - {161, 162, 172}, - {162, 163, 173}, - {163, 164, 174}, - {164, 165, 175}, - {165, 166, 176}, - {166, 167, 177}, - {167, 168, 178}, - {168, 169, 179}, - {169, 160, 170}, - {170, 171, 181}, - {171, 172, 182}, - {172, 173, 183}, - {173, 174, 184}, - {174, 175, 185}, - {175, 176, 186}, - {176, 177, 187}, - {177, 178, 188}, - {178, 179, 189}, - {179, 170, 180}, - {180, 181, 191}, - {181, 182, 192}, - {182, 183, 193}, - {183, 184, 194}, - {184, 185, 195}, - {185, 186, 196}, - {186, 187, 197}, - {187, 188, 198}, - {188, 189, 199}, - {189, 180, 190}, - {190, 191, 201}, - {191, 192, 202}, - {192, 193, 203}, - {193, 194, 204}, - {194, 195, 205}, - {195, 196, 206}, - {196, 197, 207}, - {197, 198, 208}, - {198, 199, 209}, - {199, 190, 200}, - {200, 201, 211}, - {201, 202, 212}, - {202, 203, 213}, - {203, 204, 214}, - {204, 205, 215}, - {205, 206, 216}, - {206, 207, 217}, - {207, 208, 218}, - {208, 209, 219}, - {209, 200, 210}, - {210, 211, 221}, - {211, 212, 222}, - {212, 213, 223}, - {213, 214, 224}, - {214, 215, 225}, - {215, 216, 226}, - {216, 217, 227}, - {217, 218, 228}, - {218, 219, 229}, - {219, 210, 220}, - {220, 221, 231}, - {221, 222, 232}, - {222, 223, 233}, - {223, 224, 234}, - {224, 225, 235}, - {225, 226, 236}, - {226, 227, 237}, - {227, 228, 238}, - {228, 229, 239}, - {229, 220, 230}, - {230, 231, 241}, - {231, 232, 242}, - {232, 233, 243}, - {233, 234, 244}, - {234, 235, 245}, - {235, 236, 246}, - {236, 237, 247}, - {237, 238, 248}, - {238, 239, 249}, - {239, 230, 240}, - {240, 241, 251}, - {241, 242, 252}, - {242, 243, 253}, - {243, 244, 254}, - {244, 245, 255}, - {245, 246, 256}, - {246, 247, 257}, - {247, 248, 258}, - {248, 249, 259}, - {249, 240, 250}, - {250, 251, 261}, - {251, 252, 262}, - {252, 253, 263}, - {253, 254, 264}, - {254, 255, 265}, - {255, 256, 266}, - {256, 257, 267}, - {257, 258, 268}, - {258, 259, 269}, - {259, 250, 260}, - {260, 261, 271}, - {261, 262, 272}, - {262, 263, 273}, - {263, 264, 274}, - {264, 265, 275}, - {265, 266, 276}, - {266, 267, 277}, - {267, 268, 278}, - {268, 269, 279}, - {269, 260, 270}, - {270, 271, 281}, - {271, 272, 282}, - {272, 273, 283}, - {273, 274, 284}, - {274, 275, 285}, - {275, 276, 286}, - {276, 277, 287}, - {277, 278, 288}, - {278, 279, 289}, - {279, 270, 280}, - {280, 281, 291}, - {281, 282, 292}, - {282, 283, 293}, - {283, 284, 294}, - {284, 285, 295}, - {285, 286, 296}, - {286, 287, 297}, - {287, 288, 298}, - {288, 289, 299}, - {289, 280, 290}, - {290, 291, 1}, - {291, 292, 2}, - {292, 293, 3}, - {293, 294, 4}, - {294, 295, 5}, - {295, 296, 6}, - {296, 297, 7}, - {297, 298, 8}, - {298, 299, 9}, - {299, 290, 0}, - {0, 11, 10}, - {1, 12, 11}, - {2, 13, 12}, - {3, 14, 13}, - {4, 15, 14}, - {5, 16, 15}, - {6, 17, 16}, - {7, 18, 17}, - {8, 19, 18}, - {9, 10, 19}, - {10, 21, 20}, - {11, 22, 21}, - {12, 23, 22}, - {13, 24, 23}, - {14, 25, 24}, - {15, 26, 25}, - {16, 27, 26}, - {17, 28, 27}, - {18, 29, 28}, - {19, 20, 29}, - {20, 31, 30}, - {21, 32, 31}, - {22, 33, 32}, - {23, 34, 33}, - {24, 35, 34}, - {25, 36, 35}, - {26, 37, 36}, - {27, 38, 37}, - {28, 39, 38}, - {29, 30, 39}, - {30, 41, 40}, - {31, 42, 41}, - {32, 43, 42}, - {33, 44, 43}, - {34, 45, 44}, - {35, 46, 45}, - {36, 47, 46}, - {37, 48, 47}, - {38, 49, 48}, - {39, 40, 49}, - {40, 51, 50}, - {41, 52, 51}, - {42, 53, 52}, - {43, 54, 53}, - {44, 55, 54}, - {45, 56, 55}, - {46, 57, 56}, - {47, 58, 57}, - {48, 59, 58}, - {49, 50, 59}, - {50, 61, 60}, - {51, 62, 61}, - {52, 63, 62}, - {53, 64, 63}, - {54, 65, 64}, - {55, 66, 65}, - {56, 67, 66}, - {57, 68, 67}, - {58, 69, 68}, - {59, 60, 69}, - {60, 71, 70}, - {61, 72, 71}, - {62, 73, 72}, - {63, 74, 73}, - {64, 75, 74}, - {65, 76, 75}, - {66, 77, 76}, - {67, 78, 77}, - {68, 79, 78}, - {69, 70, 79}, - {70, 81, 80}, - {71, 82, 81}, - {72, 83, 82}, - {73, 84, 83}, - {74, 85, 84}, - {75, 86, 85}, - {76, 87, 86}, - {77, 88, 87}, - {78, 89, 88}, - {79, 80, 89}, - {80, 91, 90}, - {81, 92, 91}, - {82, 93, 92}, - {83, 94, 93}, - {84, 95, 94}, - {85, 96, 95}, - {86, 97, 96}, - {87, 98, 97}, - {88, 99, 98}, - {89, 90, 99}, - {90, 101, 100}, - {91, 102, 101}, - {92, 103, 102}, - {93, 104, 103}, - {94, 105, 104}, - {95, 106, 105}, - {96, 107, 106}, - {97, 108, 107}, - {98, 109, 108}, - {99, 100, 109}, - {100, 111, 110}, - {101, 112, 111}, - {102, 113, 112}, - {103, 114, 113}, - {104, 115, 114}, - {105, 116, 115}, - {106, 117, 116}, - {107, 118, 117}, - {108, 119, 118}, - {109, 110, 119}, - {110, 121, 120}, - {111, 122, 121}, - {112, 123, 122}, - {113, 124, 123}, - {114, 125, 124}, - {115, 126, 125}, - {116, 127, 126}, - {117, 128, 127}, - {118, 129, 128}, - {119, 120, 129}, - {120, 131, 130}, - {121, 132, 131}, - {122, 133, 132}, - {123, 134, 133}, - {124, 135, 134}, - {125, 136, 135}, - {126, 137, 136}, - {127, 138, 137}, - {128, 139, 138}, - {129, 130, 139}, - {130, 141, 140}, - {131, 142, 141}, - {132, 143, 142}, - {133, 144, 143}, - {134, 145, 144}, - {135, 146, 145}, - {136, 147, 146}, - {137, 148, 147}, - {138, 149, 148}, - {139, 140, 149}, - {140, 151, 150}, - {141, 152, 151}, - {142, 153, 152}, - {143, 154, 153}, - {144, 155, 154}, - {145, 156, 155}, - {146, 157, 156}, - {147, 158, 157}, - {148, 159, 158}, - {149, 150, 159}, - {150, 161, 160}, - {151, 162, 161}, - {152, 163, 162}, - {153, 164, 163}, - {154, 165, 164}, - {155, 166, 165}, - {156, 167, 166}, - {157, 168, 167}, - {158, 169, 168}, - {159, 160, 169}, - {160, 171, 170}, - {161, 172, 171}, - {162, 173, 172}, - {163, 174, 173}, - {164, 175, 174}, - {165, 176, 175}, - {166, 177, 176}, - {167, 178, 177}, - {168, 179, 178}, - {169, 170, 179}, - {170, 181, 180}, - {171, 182, 181}, - {172, 183, 182}, - {173, 184, 183}, - {174, 185, 184}, - {175, 186, 185}, - {176, 187, 186}, - {177, 188, 187}, - {178, 189, 188}, - {179, 180, 189}, - {180, 191, 190}, - {181, 192, 191}, - {182, 193, 192}, - {183, 194, 193}, - {184, 195, 194}, - {185, 196, 195}, - {186, 197, 196}, - {187, 198, 197}, - {188, 199, 198}, - {189, 190, 199}, - {190, 201, 200}, - {191, 202, 201}, - {192, 203, 202}, - {193, 204, 203}, - {194, 205, 204}, - {195, 206, 205}, - {196, 207, 206}, - {197, 208, 207}, - {198, 209, 208}, - {199, 200, 209}, - {200, 211, 210}, - {201, 212, 211}, - {202, 213, 212}, - {203, 214, 213}, - {204, 215, 214}, - {205, 216, 215}, - {206, 217, 216}, - {207, 218, 217}, - {208, 219, 218}, - {209, 210, 219}, - {210, 221, 220}, - {211, 222, 221}, - {212, 223, 222}, - {213, 224, 223}, - {214, 225, 224}, - {215, 226, 225}, - {216, 227, 226}, - {217, 228, 227}, - {218, 229, 228}, - {219, 220, 229}, - {220, 231, 230}, - {221, 232, 231}, - {222, 233, 232}, - {223, 234, 233}, - {224, 235, 234}, - {225, 236, 235}, - {226, 237, 236}, - {227, 238, 237}, - {228, 239, 238}, - {229, 230, 239}, - {230, 241, 240}, - {231, 242, 241}, - {232, 243, 242}, - {233, 244, 243}, - {234, 245, 244}, - {235, 246, 245}, - {236, 247, 246}, - {237, 248, 247}, - {238, 249, 248}, - {239, 240, 249}, - {240, 251, 250}, - {241, 252, 251}, - {242, 253, 252}, - {243, 254, 253}, - {244, 255, 254}, - {245, 256, 255}, - {246, 257, 256}, - {247, 258, 257}, - {248, 259, 258}, - {249, 250, 259}, - {250, 261, 260}, - {251, 262, 261}, - {252, 263, 262}, - {253, 264, 263}, - {254, 265, 264}, - {255, 266, 265}, - {256, 267, 266}, - {257, 268, 267}, - {258, 269, 268}, - {259, 260, 269}, - {260, 271, 270}, - {261, 272, 271}, - {262, 273, 272}, - {263, 274, 273}, - {264, 275, 274}, - {265, 276, 275}, - {266, 277, 276}, - {267, 278, 277}, - {268, 279, 278}, - {269, 270, 279}, - {270, 281, 280}, - {271, 282, 281}, - {272, 283, 282}, - {273, 284, 283}, - {274, 285, 284}, - {275, 286, 285}, - {276, 287, 286}, - {277, 288, 287}, - {278, 289, 288}, - {279, 280, 289}, - {280, 291, 290}, - {281, 292, 291}, - {282, 293, 292}, - {283, 294, 293}, - {284, 295, 294}, - {285, 296, 295}, - {286, 297, 296}, - {287, 298, 297}, - {288, 299, 298}, - {289, 290, 299}, - {290, 1, 0}, - {291, 2, 1}, - {292, 3, 2}, - {293, 4, 3}, - {294, 5, 4}, - {295, 6, 5}, - {296, 7, 6}, - {297, 8, 7}, - {298, 9, 8}, - {299, 0, 9}, -}; - - -#endif diff --git a/Demos/GimpactTestDemo/Win32GimpactDemo.cpp b/Demos/GimpactTestDemo/Win32GimpactDemo.cpp deleted file mode 100644 index 57cc15d8a..000000000 --- a/Demos/GimpactTestDemo/Win32GimpactDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "GimpactTestDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new GimpactConcaveDemo(); -} - -#endif diff --git a/Demos/GimpactTestDemo/main.cpp b/Demos/GimpactTestDemo/main.cpp deleted file mode 100644 index 2deb72611..000000000 --- a/Demos/GimpactTestDemo/main.cpp +++ /dev/null @@ -1,13 +0,0 @@ - -#include "GimpactTestDemo.h" -#include "GlutStuff.h" - -//################################## main ##################################### -int main(int argc,char** argv) -{ - - GimpactConcaveDemo* concaveDemo = new GimpactConcaveDemo(); /// This will not be Deleted!!! - concaveDemo->initPhysics(); - - return glutmain(argc, argv,640,480,"DevO,s GIMPACT Test Demo",concaveDemo); -} diff --git a/Demos/GjkConvexCastDemo/CMakeLists.txt b/Demos/GjkConvexCastDemo/CMakeLists.txt deleted file mode 100644 index cc9037d07..000000000 --- a/Demos/GjkConvexCastDemo/CMakeLists.txt +++ /dev/null @@ -1,33 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppLinearConvexCastDemo - LinearConvexCastDemo.cpp - main.cpp -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppLinearConvexCastDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppLinearConvexCastDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppLinearConvexCastDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/GjkConvexCastDemo/LinearConvexCastDemo.cpp b/Demos/GjkConvexCastDemo/LinearConvexCastDemo.cpp deleted file mode 100644 index 29fbb091c..000000000 --- a/Demos/GjkConvexCastDemo/LinearConvexCastDemo.cpp +++ /dev/null @@ -1,188 +0,0 @@ -/* - * Copyright (c) 2005 Erwin Coumans http://continuousphysics.com/Bullet/ - * - * Permission to use, copy, modify, distribute and sell this software - * and its documentation for any purpose is hereby granted without fee, - * provided that the above copyright notice appear in all copies. - * Erwin Coumans makes no representations about the suitability - * of this software for any purpose. - * It is provided "as is" without express or implied warranty. - */ - - - -/* - LinearConvexCastDemo implements an efficient continuous collision detection algorithm. - Both linear and angular velocities are supported. Gjk or Simplex based methods. - Motion using Exponential Map. - Comparison with Screwing Motion. - Also comparision with Algebraic CCD and Interval Arithmetic methods (Stephane Redon) -*/ - - -///Low level demo, doesn't include btBulletCollisionCommon.h -#include "LinearMath/btQuaternion.h" -#include "LinearMath/btTransform.h" - -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/CollisionShapes/btConvexHullShape.h" -#include "BulletCollision/CollisionShapes/btMinkowskiSumShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h" -#include "BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h" -#include "BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h" - - - -#include "BulletCollision/CollisionShapes/btSphereShape.h" -#include "BulletCollision/CollisionShapes/btTetrahedronShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h" - - - -#include "GL_ShapeDrawer.h" -#include "LinearConvexCastDemo.h" -#include "GlutStuff.h" - -static btVoronoiSimplexSolver sVoronoiSimplexSolver; -btSimplexSolverInterface& gGjkSimplexSolver = sVoronoiSimplexSolver; - -static float yaw=0.f,pitch=0.f,roll=0.f; -static const int maxNumObjects = 4; -static const int numObjects = 2; - -static btPolyhedralConvexShape* shapePtr[maxNumObjects]; - -static btTransform tr[numObjects]; - - - -void LinearConvexCastDemo::initPhysics() -{ - - setCameraDistance(10.f); - - tr[0].setIdentity(); - tr[0].setOrigin( btVector3( 0.0f, 5.5f, 0.0f ) ); - - tr[1].setIdentity(); - tr[1].setOrigin( btVector3( 0.0f, 0.0f, 0.0f ) ); - - // Pyramide - float r = 1.0f; - float h = 2.0f; - - btConvexHullShape* shapeA = new btConvexHullShape; - shapeA->addPoint( btVector3( 0.0f, 0.75f * h, 0.0f ) ); - shapeA->addPoint( btVector3( -r, -0.25f * h, r ) ); - shapeA->addPoint( btVector3( r, -0.25f * h, r ) ); - shapeA->addPoint( btVector3( r, -0.25f * h, -r ) ); - shapeA->addPoint( btVector3( -r, -0.25f * h, -r ) ); - - - - // Triangle - btConvexHullShape* shapeB = new btConvexHullShape; - shapeB->addPoint( btVector3( 0.0f, 1.0f, 0.0f ) ); - shapeB->addPoint( btVector3( 1.0f, -1.0f, 0.0f ) ); - shapeB->addPoint( btVector3( -1.0f, -1.0f, 0.0f ) ); - - shapePtr[0] = shapeA; - shapePtr[1] = shapeB; - - shapePtr[0]->setMargin( 0.01f ); - shapePtr[1]->setMargin( 0.01f ); -} - -//to be implemented by the demo -void LinearConvexCastDemo::clientMoveAndDisplay() -{ - displayCallback(); -} - -LinearConvexCastDemo::~LinearConvexCastDemo() -{ - delete shapePtr[0]; - delete shapePtr[1]; -} - -void LinearConvexCastDemo::displayCallback(void) -{ - updateCamera(); - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDisable(GL_LIGHTING); - - GL_ShapeDrawer::drawCoordSystem(); - - - - static btScalar angle = 0.f; - angle+=getDeltaTimeMicroseconds()/1000000.0; - - tr[1].setRotation(btQuaternion(btVector3(1,0,0),angle)); - - btTransform toA, toB; - toA = tr[0]; - toA.setOrigin( btVector3( 0.0f, 0.f, 0.0f ) ); - toB = tr[1]; - toB.setOrigin( btVector3( 0.0f, 0.0f, 0.0f ) ); - - - gGjkSimplexSolver.reset(); - - - btVector3 worldBoundsMin(-1000,-1000,-1000); - btVector3 worldBoundsMax(1000,1000,1000); - - - //btGjkConvexCast convexCaster(shapePtr[ 0 ], shapePtr[ 1 ], &gGjkSimplexSolver ); - btSubsimplexConvexCast convexCaster( shapePtr[ 0 ], shapePtr[ 1 ], &gGjkSimplexSolver ); - - btConvexCast::CastResult result; - - result.m_hitPoint.setValue(0,0,0); - - convexCaster.calcTimeOfImpact( tr[ 0 ], toA, tr[ 1 ], toB, result ); - - ATTRIBUTE_ALIGNED16(btScalar) m1[16]; - ATTRIBUTE_ALIGNED16(btScalar) m2[16]; - ATTRIBUTE_ALIGNED16(btScalar) m3[16]; - - tr[ 0 ].getOpenGLMatrix( m1 ); - tr[ 1 ].getOpenGLMatrix( m2 ); - - btSphereShape sphere(0.2); - - btTransform tmp = tr[0]; - tmp.setOrigin(result.m_hitPoint); - tmp.getOpenGLMatrix(m3); - m_shapeDrawer->drawOpenGL( m3, &sphere, btVector3( 1, 0, 1 ), getDebugMode() ,worldBoundsMin,worldBoundsMax); - - - m_shapeDrawer->drawOpenGL( m1, shapePtr[ 0 ], btVector3( 1, 0, 0 ), getDebugMode() ,worldBoundsMin,worldBoundsMax); - m_shapeDrawer->drawOpenGL( m2, shapePtr[ 1 ], btVector3( 1, 0, 0 ), getDebugMode() ,worldBoundsMin,worldBoundsMax); - - btVector3 originA, originB; - originA.setInterpolate3( tr[ 0 ].getOrigin(), toA.getOrigin(), result.m_fraction ); - originB.setInterpolate3( tr[ 1 ].getOrigin(), toB.getOrigin(), result.m_fraction ); - - btTransform A = tr[ 0 ]; - A.setOrigin( originA ); - - btTransform B = tr[ 1 ]; - B.setOrigin( originB ); - - A.getOpenGLMatrix( m1 ); - B.getOpenGLMatrix( m2 ); - - m_shapeDrawer->drawOpenGL( m1, shapePtr[ 0 ], btVector3( 1, 1, 0 ), getDebugMode() ,worldBoundsMin,worldBoundsMax); - m_shapeDrawer->drawOpenGL( m2, shapePtr[ 1 ], btVector3( 1, 1, 0 ), getDebugMode() ,worldBoundsMin,worldBoundsMax); - - glFlush(); - glutSwapBuffers(); -} diff --git a/Demos/GjkConvexCastDemo/LinearConvexCastDemo.h b/Demos/GjkConvexCastDemo/LinearConvexCastDemo.h deleted file mode 100644 index 9b64d2855..000000000 --- a/Demos/GjkConvexCastDemo/LinearConvexCastDemo.h +++ /dev/null @@ -1,44 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef LINEAR_CONVEX_CAST_DEMO_H -#define LINEAR_CONVEX_CAST_DEMO_H - -#include "GlutDemoApplication.h" - -///LinearConvexCastDemo shows the working of the object sweep / pure-linear continuous collision detection query -class LinearConvexCastDemo : public GlutDemoApplication -{ - public: - - virtual ~LinearConvexCastDemo(); - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - LinearConvexCastDemo* demo = new LinearConvexCastDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } - -}; - -#endif //LINEAR_CONVEX_CAST_DEMO_H - diff --git a/Demos/GjkConvexCastDemo/main.cpp b/Demos/GjkConvexCastDemo/main.cpp deleted file mode 100644 index 3c2748a7f..000000000 --- a/Demos/GjkConvexCastDemo/main.cpp +++ /dev/null @@ -1,17 +0,0 @@ - -#include "LinearConvexCastDemo.h" -#include "GlutStuff.h" - -int screenWidth = 640; -int screenHeight = 480; - -int main(int argc,char** argv) -{ - - LinearConvexCastDemo* linearCastDemo = new LinearConvexCastDemo(); - - linearCastDemo->initPhysics(); - - - return glutmain(argc, argv,screenWidth,screenHeight,"Linear Convex Cast Demo",linearCastDemo); -} diff --git a/Demos/Glut/GL/freeglut.h b/Demos/Glut/GL/freeglut.h deleted file mode 100644 index 0e6f8c6ad..000000000 --- a/Demos/Glut/GL/freeglut.h +++ /dev/null @@ -1,22 +0,0 @@ -#ifndef __FREEGLUT_H__ -#define __FREEGLUT_H__ - -/* - * freeglut.h - * - * The freeglut library include file - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * PAWEL W. OLSZTA BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER - * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -#include "freeglut_std.h" -#include "freeglut_ext.h" - -/*** END OF FILE ***/ - -#endif /* __FREEGLUT_H__ */ diff --git a/Demos/Glut/GL/freeglut_ext.h b/Demos/Glut/GL/freeglut_ext.h deleted file mode 100644 index e547c56d8..000000000 --- a/Demos/Glut/GL/freeglut_ext.h +++ /dev/null @@ -1,239 +0,0 @@ -#ifndef __FREEGLUT_EXT_H__ -#define __FREEGLUT_EXT_H__ - -/* - * freeglut_ext.h - * - * The non-GLUT-compatible extensions to the freeglut library include file - * - * Copyright (c) 1999-2000 Pawel W. Olszta. All Rights Reserved. - * Written by Pawel W. Olszta, - * Creation date: Thu Dec 2 1999 - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * PAWEL W. OLSZTA BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER - * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -#ifdef __cplusplus - extern "C" { -#endif - -/* - * Additional GLUT Key definitions for the Special key function - */ -#define GLUT_KEY_NUM_LOCK 0x006D -#define GLUT_KEY_BEGIN 0x006E -#define GLUT_KEY_DELETE 0x006F -#define GLUT_KEY_SHIFT_L 0x0070 -#define GLUT_KEY_SHIFT_R 0x0071 -#define GLUT_KEY_CTRL_L 0x0072 -#define GLUT_KEY_CTRL_R 0x0073 -#define GLUT_KEY_ALT_L 0x0074 -#define GLUT_KEY_ALT_R 0x0075 - -/* - * GLUT API Extension macro definitions -- behaviour when the user clicks on an "x" to close a window - */ -#define GLUT_ACTION_EXIT 0 -#define GLUT_ACTION_GLUTMAINLOOP_RETURNS 1 -#define GLUT_ACTION_CONTINUE_EXECUTION 2 - -/* - * Create a new rendering context when the user opens a new window? - */ -#define GLUT_CREATE_NEW_CONTEXT 0 -#define GLUT_USE_CURRENT_CONTEXT 1 - -/* - * Direct/Indirect rendering context options (has meaning only in Unix/X11) - */ -#define GLUT_FORCE_INDIRECT_CONTEXT 0 -#define GLUT_ALLOW_DIRECT_CONTEXT 1 -#define GLUT_TRY_DIRECT_CONTEXT 2 -#define GLUT_FORCE_DIRECT_CONTEXT 3 - -/* - * GLUT API Extension macro definitions -- the glutGet parameters - */ -#define GLUT_INIT_STATE 0x007C - -#define GLUT_ACTION_ON_WINDOW_CLOSE 0x01F9 - -#define GLUT_WINDOW_BORDER_WIDTH 0x01FA -#define GLUT_WINDOW_BORDER_HEIGHT 0x01FB -#define GLUT_WINDOW_HEADER_HEIGHT 0x01FB /* Docs say it should always have been GLUT_WINDOW_BORDER_HEIGHT, keep this for backward compatibility */ - -#define GLUT_VERSION 0x01FC - -#define GLUT_RENDERING_CONTEXT 0x01FD -#define GLUT_DIRECT_RENDERING 0x01FE - -#define GLUT_FULL_SCREEN 0x01FF - -#define GLUT_SKIP_STALE_MOTION_EVENTS 0x0204 - -/* - * New tokens for glutInitDisplayMode. - * Only one GLUT_AUXn bit may be used at a time. - * Value 0x0400 is defined in OpenGLUT. - */ -#define GLUT_AUX 0x1000 - -#define GLUT_AUX1 0x1000 -#define GLUT_AUX2 0x2000 -#define GLUT_AUX3 0x4000 -#define GLUT_AUX4 0x8000 - -/* - * Context-related flags, see freeglut_state.c - */ -#define GLUT_INIT_MAJOR_VERSION 0x0200 -#define GLUT_INIT_MINOR_VERSION 0x0201 -#define GLUT_INIT_FLAGS 0x0202 -#define GLUT_INIT_PROFILE 0x0203 - -/* - * Flags for glutInitContextFlags, see freeglut_init.c - */ -#define GLUT_DEBUG 0x0001 -#define GLUT_FORWARD_COMPATIBLE 0x0002 - - -/* - * Flags for glutInitContextProfile, see freeglut_init.c - */ -#define GLUT_CORE_PROFILE 0x0001 -#define GLUT_COMPATIBILITY_PROFILE 0x0002 - -/* - * Process loop function, see freeglut_main.c - */ -FGAPI void FGAPIENTRY glutMainLoopEvent( void ); -FGAPI void FGAPIENTRY glutLeaveMainLoop( void ); -FGAPI void FGAPIENTRY glutExit ( void ); - -/* - * Window management functions, see freeglut_window.c - */ -FGAPI void FGAPIENTRY glutFullScreenToggle( void ); -FGAPI void FGAPIENTRY glutLeaveFullScreen( void ); - -/* - * Window-specific callback functions, see freeglut_callbacks.c - */ -FGAPI void FGAPIENTRY glutMouseWheelFunc( void (* callback)( int, int, int, int ) ); -FGAPI void FGAPIENTRY glutCloseFunc( void (* callback)( void ) ); -FGAPI void FGAPIENTRY glutWMCloseFunc( void (* callback)( void ) ); -/* A. Donev: Also a destruction callback for menus */ -FGAPI void FGAPIENTRY glutMenuDestroyFunc( void (* callback)( void ) ); - -/* - * State setting and retrieval functions, see freeglut_state.c - */ -FGAPI void FGAPIENTRY glutSetOption ( GLenum option_flag, int value ); -FGAPI int * FGAPIENTRY glutGetModeValues(GLenum mode, int * size); -/* A.Donev: User-data manipulation */ -FGAPI void* FGAPIENTRY glutGetWindowData( void ); -FGAPI void FGAPIENTRY glutSetWindowData(void* data); -FGAPI void* FGAPIENTRY glutGetMenuData( void ); -FGAPI void FGAPIENTRY glutSetMenuData(void* data); - -/* - * Font stuff, see freeglut_font.c - */ -FGAPI int FGAPIENTRY glutBitmapHeight( void* font ); -FGAPI GLfloat FGAPIENTRY glutStrokeHeight( void* font ); -FGAPI void FGAPIENTRY glutBitmapString( void* font, const unsigned char *string ); -FGAPI void FGAPIENTRY glutStrokeString( void* font, const unsigned char *string ); - -/* - * Geometry functions, see freeglut_geometry.c - */ -FGAPI void FGAPIENTRY glutWireRhombicDodecahedron( void ); -FGAPI void FGAPIENTRY glutSolidRhombicDodecahedron( void ); -FGAPI void FGAPIENTRY glutWireSierpinskiSponge ( int num_levels, GLdouble offset[3], GLdouble scale ); -FGAPI void FGAPIENTRY glutSolidSierpinskiSponge ( int num_levels, GLdouble offset[3], GLdouble scale ); -FGAPI void FGAPIENTRY glutWireCylinder( GLdouble radius, GLdouble height, GLint slices, GLint stacks); -FGAPI void FGAPIENTRY glutSolidCylinder( GLdouble radius, GLdouble height, GLint slices, GLint stacks); - -/* - * Extension functions, see freeglut_ext.c - */ -typedef void (*GLUTproc)(); -FGAPI GLUTproc FGAPIENTRY glutGetProcAddress( const char *procName ); - -/* - * Multi-touch/multi-pointer extensions - */ - -#define GLUT_HAS_MULTI 1 - -FGAPI void FGAPIENTRY glutMultiEntryFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutMultiButtonFunc( void (* callback)( int, int, int, int, int ) ); -FGAPI void FGAPIENTRY glutMultiMotionFunc( void (* callback)( int, int, int ) ); -FGAPI void FGAPIENTRY glutMultiPassiveFunc( void (* callback)( int, int, int ) ); - -/* - * Joystick functions, see freeglut_joystick.c - */ -/* USE OF THESE FUNCTIONS IS DEPRECATED !!!!! */ -/* If you have a serious need for these functions in your application, please either - * contact the "freeglut" developer community at freeglut-developer@lists.sourceforge.net, - * switch to the OpenGLUT library, or else port your joystick functionality over to PLIB's - * "js" library. - */ -int glutJoystickGetNumAxes( int ident ); -int glutJoystickGetNumButtons( int ident ); -int glutJoystickNotWorking( int ident ); -float glutJoystickGetDeadBand( int ident, int axis ); -void glutJoystickSetDeadBand( int ident, int axis, float db ); -float glutJoystickGetSaturation( int ident, int axis ); -void glutJoystickSetSaturation( int ident, int axis, float st ); -void glutJoystickSetMinRange( int ident, float *axes ); -void glutJoystickSetMaxRange( int ident, float *axes ); -void glutJoystickSetCenter( int ident, float *axes ); -void glutJoystickGetMinRange( int ident, float *axes ); -void glutJoystickGetMaxRange( int ident, float *axes ); -void glutJoystickGetCenter( int ident, float *axes ); - -/* - * Initialization functions, see freeglut_init.c - */ -FGAPI void FGAPIENTRY glutInitContextVersion( int majorVersion, int minorVersion ); -FGAPI void FGAPIENTRY glutInitContextFlags( int flags ); -FGAPI void FGAPIENTRY glutInitContextProfile( int profile ); - -/* to get the typedef for va_list */ -#include - -FGAPI void FGAPIENTRY glutInitErrorFunc( void (* vError)( const char *fmt, va_list ap ) ); -FGAPI void FGAPIENTRY glutInitWarningFunc( void (* vWarning)( const char *fmt, va_list ap ) ); - -/* - * GLUT API macro definitions -- the display mode definitions - */ -#define GLUT_CAPTIONLESS 0x0400 -#define GLUT_BORDERLESS 0x0800 -#define GLUT_SRGB 0x1000 - -#ifdef __cplusplus - } -#endif - -/*** END OF FILE ***/ - -#endif /* __FREEGLUT_EXT_H__ */ diff --git a/Demos/Glut/GL/freeglut_std.h b/Demos/Glut/GL/freeglut_std.h deleted file mode 100644 index 02c5c671f..000000000 --- a/Demos/Glut/GL/freeglut_std.h +++ /dev/null @@ -1,630 +0,0 @@ -#ifndef __FREEGLUT_STD_H__ -#define __FREEGLUT_STD_H__ - -/* - * freeglut_std.h - * - * The GLUT-compatible part of the freeglut library include file - * - * Copyright (c) 1999-2000 Pawel W. Olszta. All Rights Reserved. - * Written by Pawel W. Olszta, - * Creation date: Thu Dec 2 1999 - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * PAWEL W. OLSZTA BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER - * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -#ifdef __cplusplus - extern "C" { -#endif - -/* - * Under windows, we have to differentiate between static and dynamic libraries - */ -#ifdef _WIN32 -/* #pragma may not be supported by some compilers. - * Discussion by FreeGLUT developers suggests that - * Visual C++ specific code involving pragmas may - * need to move to a separate header. 24th Dec 2003 - */ - -/* Define FREEGLUT_LIB_PRAGMAS to 1 to include library - * pragmas or to 0 to exclude library pragmas. - * The default behavior depends on the compiler/platform. - */ -# ifndef FREEGLUT_LIB_PRAGMAS -# if ( defined(_MSC_VER) || defined(__WATCOMC__) ) && !defined(_WIN32_WCE) -# define FREEGLUT_LIB_PRAGMAS 0 -# else -# define FREEGLUT_LIB_PRAGMAS 0 -# endif -# endif - -# ifndef WIN32_LEAN_AND_MEAN -# define WIN32_LEAN_AND_MEAN 1 -# endif -# ifndef NOMINMAX -# define NOMINMAX -# endif -# include - -/* Windows static library */ -# ifdef FREEGLUT_STATIC - -# define FGAPI -# define FGAPIENTRY - - /* Link with Win32 static freeglut lib */ - -/* Windows shared library (DLL) */ -# else - -# define FGAPIENTRY __stdcall -# if defined(FREEGLUT_EXPORTS) -# define FGAPI __declspec(dllexport) -# else -# define FGAPI __declspec(dllimport) - - /* Link with Win32 shared freeglut lib */ - -# endif - -# endif - -/* Drag in other Windows libraries as required by FreeGLUT */ -# if FREEGLUT_LIB_PRAGMAS -# pragma comment (lib, "glu32.lib") /* link OpenGL Utility lib */ -# pragma comment (lib, "opengl32.lib") /* link Microsoft OpenGL lib */ -# pragma comment (lib, "gdi32.lib") /* link Windows GDI lib */ -# pragma comment (lib, "winmm.lib") /* link Windows MultiMedia lib */ -# pragma comment (lib, "user32.lib") /* link Windows user lib */ -# endif - -#else - -/* Non-Windows definition of FGAPI and FGAPIENTRY */ -# define FGAPI -# define FGAPIENTRY - -#endif - -/* - * The freeglut and GLUT API versions - */ -#define FREEGLUT 1 -#define GLUT_API_VERSION 4 -#define GLUT_XLIB_IMPLEMENTATION 13 -/* Deprecated: - cf. http://sourceforge.net/mailarchive/forum.php?thread_name=CABcAi1hw7cr4xtigckaGXB5X8wddLfMcbA_rZ3NAuwMrX_zmsw%40mail.gmail.com&forum_name=freeglut-developer */ -#define FREEGLUT_VERSION_2_0 1 - -/* - * Always include OpenGL and GLU headers - */ -#if __APPLE__ -# include -# include -#else -# include -# include -#endif - -/* - * GLUT API macro definitions -- the special key codes: - */ -#define GLUT_KEY_F1 0x0001 -#define GLUT_KEY_F2 0x0002 -#define GLUT_KEY_F3 0x0003 -#define GLUT_KEY_F4 0x0004 -#define GLUT_KEY_F5 0x0005 -#define GLUT_KEY_F6 0x0006 -#define GLUT_KEY_F7 0x0007 -#define GLUT_KEY_F8 0x0008 -#define GLUT_KEY_F9 0x0009 -#define GLUT_KEY_F10 0x000A -#define GLUT_KEY_F11 0x000B -#define GLUT_KEY_F12 0x000C -#define GLUT_KEY_LEFT 0x0064 -#define GLUT_KEY_UP 0x0065 -#define GLUT_KEY_RIGHT 0x0066 -#define GLUT_KEY_DOWN 0x0067 -#define GLUT_KEY_PAGE_UP 0x0068 -#define GLUT_KEY_PAGE_DOWN 0x0069 -#define GLUT_KEY_HOME 0x006A -#define GLUT_KEY_END 0x006B -#define GLUT_KEY_INSERT 0x006C - -/* - * GLUT API macro definitions -- mouse state definitions - */ -#define GLUT_LEFT_BUTTON 0x0000 -#define GLUT_MIDDLE_BUTTON 0x0001 -#define GLUT_RIGHT_BUTTON 0x0002 -#define GLUT_DOWN 0x0000 -#define GLUT_UP 0x0001 -#define GLUT_LEFT 0x0000 -#define GLUT_ENTERED 0x0001 - -/* - * GLUT API macro definitions -- the display mode definitions - */ -#define GLUT_RGB 0x0000 -#define GLUT_RGBA 0x0000 -#define GLUT_INDEX 0x0001 -#define GLUT_SINGLE 0x0000 -#define GLUT_DOUBLE 0x0002 -#define GLUT_ACCUM 0x0004 -#define GLUT_ALPHA 0x0008 -#define GLUT_DEPTH 0x0010 -#define GLUT_STENCIL 0x0020 -#define GLUT_MULTISAMPLE 0x0080 -#define GLUT_STEREO 0x0100 -#define GLUT_LUMINANCE 0x0200 - -/* - * GLUT API macro definitions -- windows and menu related definitions - */ -#define GLUT_MENU_NOT_IN_USE 0x0000 -#define GLUT_MENU_IN_USE 0x0001 -#define GLUT_NOT_VISIBLE 0x0000 -#define GLUT_VISIBLE 0x0001 -#define GLUT_HIDDEN 0x0000 -#define GLUT_FULLY_RETAINED 0x0001 -#define GLUT_PARTIALLY_RETAINED 0x0002 -#define GLUT_FULLY_COVERED 0x0003 - -/* - * GLUT API macro definitions -- fonts definitions - * - * Steve Baker suggested to make it binary compatible with GLUT: - */ -#if defined(_MSC_VER) || defined(__CYGWIN__) || defined(__MINGW32__) || defined(__WATCOMC__) -# define GLUT_STROKE_ROMAN ((void *)0x0000) -# define GLUT_STROKE_MONO_ROMAN ((void *)0x0001) -# define GLUT_BITMAP_9_BY_15 ((void *)0x0002) -# define GLUT_BITMAP_8_BY_13 ((void *)0x0003) -# define GLUT_BITMAP_TIMES_ROMAN_10 ((void *)0x0004) -# define GLUT_BITMAP_TIMES_ROMAN_24 ((void *)0x0005) -# define GLUT_BITMAP_HELVETICA_10 ((void *)0x0006) -# define GLUT_BITMAP_HELVETICA_12 ((void *)0x0007) -# define GLUT_BITMAP_HELVETICA_18 ((void *)0x0008) -#else - /* - * I don't really know if it's a good idea... But here it goes: - */ - extern void* glutStrokeRoman; - extern void* glutStrokeMonoRoman; - extern void* glutBitmap9By15; - extern void* glutBitmap8By13; - extern void* glutBitmapTimesRoman10; - extern void* glutBitmapTimesRoman24; - extern void* glutBitmapHelvetica10; - extern void* glutBitmapHelvetica12; - extern void* glutBitmapHelvetica18; - - /* - * Those pointers will be used by following definitions: - */ -# define GLUT_STROKE_ROMAN ((void *) &glutStrokeRoman) -# define GLUT_STROKE_MONO_ROMAN ((void *) &glutStrokeMonoRoman) -# define GLUT_BITMAP_9_BY_15 ((void *) &glutBitmap9By15) -# define GLUT_BITMAP_8_BY_13 ((void *) &glutBitmap8By13) -# define GLUT_BITMAP_TIMES_ROMAN_10 ((void *) &glutBitmapTimesRoman10) -# define GLUT_BITMAP_TIMES_ROMAN_24 ((void *) &glutBitmapTimesRoman24) -# define GLUT_BITMAP_HELVETICA_10 ((void *) &glutBitmapHelvetica10) -# define GLUT_BITMAP_HELVETICA_12 ((void *) &glutBitmapHelvetica12) -# define GLUT_BITMAP_HELVETICA_18 ((void *) &glutBitmapHelvetica18) -#endif - -/* - * GLUT API macro definitions -- the glutGet parameters - */ -#define GLUT_WINDOW_X 0x0064 -#define GLUT_WINDOW_Y 0x0065 -#define GLUT_WINDOW_WIDTH 0x0066 -#define GLUT_WINDOW_HEIGHT 0x0067 -#define GLUT_WINDOW_BUFFER_SIZE 0x0068 -#define GLUT_WINDOW_STENCIL_SIZE 0x0069 -#define GLUT_WINDOW_DEPTH_SIZE 0x006A -#define GLUT_WINDOW_RED_SIZE 0x006B -#define GLUT_WINDOW_GREEN_SIZE 0x006C -#define GLUT_WINDOW_BLUE_SIZE 0x006D -#define GLUT_WINDOW_ALPHA_SIZE 0x006E -#define GLUT_WINDOW_ACCUM_RED_SIZE 0x006F -#define GLUT_WINDOW_ACCUM_GREEN_SIZE 0x0070 -#define GLUT_WINDOW_ACCUM_BLUE_SIZE 0x0071 -#define GLUT_WINDOW_ACCUM_ALPHA_SIZE 0x0072 -#define GLUT_WINDOW_DOUBLEBUFFER 0x0073 -#define GLUT_WINDOW_RGBA 0x0074 -#define GLUT_WINDOW_PARENT 0x0075 -#define GLUT_WINDOW_NUM_CHILDREN 0x0076 -#define GLUT_WINDOW_COLORMAP_SIZE 0x0077 -#define GLUT_WINDOW_NUM_SAMPLES 0x0078 -#define GLUT_WINDOW_STEREO 0x0079 -#define GLUT_WINDOW_CURSOR 0x007A - -#define GLUT_SCREEN_WIDTH 0x00C8 -#define GLUT_SCREEN_HEIGHT 0x00C9 -#define GLUT_SCREEN_WIDTH_MM 0x00CA -#define GLUT_SCREEN_HEIGHT_MM 0x00CB -#define GLUT_MENU_NUM_ITEMS 0x012C -#define GLUT_DISPLAY_MODE_POSSIBLE 0x0190 -#define GLUT_INIT_WINDOW_X 0x01F4 -#define GLUT_INIT_WINDOW_Y 0x01F5 -#define GLUT_INIT_WINDOW_WIDTH 0x01F6 -#define GLUT_INIT_WINDOW_HEIGHT 0x01F7 -#define GLUT_INIT_DISPLAY_MODE 0x01F8 -#define GLUT_ELAPSED_TIME 0x02BC -#define GLUT_WINDOW_FORMAT_ID 0x007B - -/* - * GLUT API macro definitions -- the glutDeviceGet parameters - */ -#define GLUT_HAS_KEYBOARD 0x0258 -#define GLUT_HAS_MOUSE 0x0259 -#define GLUT_HAS_SPACEBALL 0x025A -#define GLUT_HAS_DIAL_AND_BUTTON_BOX 0x025B -#define GLUT_HAS_TABLET 0x025C -#define GLUT_NUM_MOUSE_BUTTONS 0x025D -#define GLUT_NUM_SPACEBALL_BUTTONS 0x025E -#define GLUT_NUM_BUTTON_BOX_BUTTONS 0x025F -#define GLUT_NUM_DIALS 0x0260 -#define GLUT_NUM_TABLET_BUTTONS 0x0261 -#define GLUT_DEVICE_IGNORE_KEY_REPEAT 0x0262 -#define GLUT_DEVICE_KEY_REPEAT 0x0263 -#define GLUT_HAS_JOYSTICK 0x0264 -#define GLUT_OWNS_JOYSTICK 0x0265 -#define GLUT_JOYSTICK_BUTTONS 0x0266 -#define GLUT_JOYSTICK_AXES 0x0267 -#define GLUT_JOYSTICK_POLL_RATE 0x0268 - -/* - * GLUT API macro definitions -- the glutLayerGet parameters - */ -#define GLUT_OVERLAY_POSSIBLE 0x0320 -#define GLUT_LAYER_IN_USE 0x0321 -#define GLUT_HAS_OVERLAY 0x0322 -#define GLUT_TRANSPARENT_INDEX 0x0323 -#define GLUT_NORMAL_DAMAGED 0x0324 -#define GLUT_OVERLAY_DAMAGED 0x0325 - -/* - * GLUT API macro definitions -- the glutVideoResizeGet parameters - */ -#define GLUT_VIDEO_RESIZE_POSSIBLE 0x0384 -#define GLUT_VIDEO_RESIZE_IN_USE 0x0385 -#define GLUT_VIDEO_RESIZE_X_DELTA 0x0386 -#define GLUT_VIDEO_RESIZE_Y_DELTA 0x0387 -#define GLUT_VIDEO_RESIZE_WIDTH_DELTA 0x0388 -#define GLUT_VIDEO_RESIZE_HEIGHT_DELTA 0x0389 -#define GLUT_VIDEO_RESIZE_X 0x038A -#define GLUT_VIDEO_RESIZE_Y 0x038B -#define GLUT_VIDEO_RESIZE_WIDTH 0x038C -#define GLUT_VIDEO_RESIZE_HEIGHT 0x038D - -/* - * GLUT API macro definitions -- the glutUseLayer parameters - */ -#define GLUT_NORMAL 0x0000 -#define GLUT_OVERLAY 0x0001 - -/* - * GLUT API macro definitions -- the glutGetModifiers parameters - */ -#define GLUT_ACTIVE_SHIFT 0x0001 -#define GLUT_ACTIVE_CTRL 0x0002 -#define GLUT_ACTIVE_ALT 0x0004 - -/* - * GLUT API macro definitions -- the glutSetCursor parameters - */ -#define GLUT_CURSOR_RIGHT_ARROW 0x0000 -#define GLUT_CURSOR_LEFT_ARROW 0x0001 -#define GLUT_CURSOR_INFO 0x0002 -#define GLUT_CURSOR_DESTROY 0x0003 -#define GLUT_CURSOR_HELP 0x0004 -#define GLUT_CURSOR_CYCLE 0x0005 -#define GLUT_CURSOR_SPRAY 0x0006 -#define GLUT_CURSOR_WAIT 0x0007 -#define GLUT_CURSOR_TEXT 0x0008 -#define GLUT_CURSOR_CROSSHAIR 0x0009 -#define GLUT_CURSOR_UP_DOWN 0x000A -#define GLUT_CURSOR_LEFT_RIGHT 0x000B -#define GLUT_CURSOR_TOP_SIDE 0x000C -#define GLUT_CURSOR_BOTTOM_SIDE 0x000D -#define GLUT_CURSOR_LEFT_SIDE 0x000E -#define GLUT_CURSOR_RIGHT_SIDE 0x000F -#define GLUT_CURSOR_TOP_LEFT_CORNER 0x0010 -#define GLUT_CURSOR_TOP_RIGHT_CORNER 0x0011 -#define GLUT_CURSOR_BOTTOM_RIGHT_CORNER 0x0012 -#define GLUT_CURSOR_BOTTOM_LEFT_CORNER 0x0013 -#define GLUT_CURSOR_INHERIT 0x0064 -#define GLUT_CURSOR_NONE 0x0065 -#define GLUT_CURSOR_FULL_CROSSHAIR 0x0066 - -/* - * GLUT API macro definitions -- RGB color component specification definitions - */ -#define GLUT_RED 0x0000 -#define GLUT_GREEN 0x0001 -#define GLUT_BLUE 0x0002 - -/* - * GLUT API macro definitions -- additional keyboard and joystick definitions - */ -#define GLUT_KEY_REPEAT_OFF 0x0000 -#define GLUT_KEY_REPEAT_ON 0x0001 -#define GLUT_KEY_REPEAT_DEFAULT 0x0002 - -#define GLUT_JOYSTICK_BUTTON_A 0x0001 -#define GLUT_JOYSTICK_BUTTON_B 0x0002 -#define GLUT_JOYSTICK_BUTTON_C 0x0004 -#define GLUT_JOYSTICK_BUTTON_D 0x0008 - -/* - * GLUT API macro definitions -- game mode definitions - */ -#define GLUT_GAME_MODE_ACTIVE 0x0000 -#define GLUT_GAME_MODE_POSSIBLE 0x0001 -#define GLUT_GAME_MODE_WIDTH 0x0002 -#define GLUT_GAME_MODE_HEIGHT 0x0003 -#define GLUT_GAME_MODE_PIXEL_DEPTH 0x0004 -#define GLUT_GAME_MODE_REFRESH_RATE 0x0005 -#define GLUT_GAME_MODE_DISPLAY_CHANGED 0x0006 - -/* - * Initialization functions, see fglut_init.c - */ -FGAPI void FGAPIENTRY glutInit( int* pargc, char** argv ); -FGAPI void FGAPIENTRY glutInitWindowPosition( int x, int y ); -FGAPI void FGAPIENTRY glutInitWindowSize( int width, int height ); -FGAPI void FGAPIENTRY glutInitDisplayMode( unsigned int displayMode ); -FGAPI void FGAPIENTRY glutInitDisplayString( const char* displayMode ); - -/* - * Process loop function, see freeglut_main.c - */ -FGAPI void FGAPIENTRY glutMainLoop( void ); - -/* - * Window management functions, see freeglut_window.c - */ -FGAPI int FGAPIENTRY glutCreateWindow( const char* title ); -FGAPI int FGAPIENTRY glutCreateSubWindow( int window, int x, int y, int width, int height ); -FGAPI void FGAPIENTRY glutDestroyWindow( int window ); -FGAPI void FGAPIENTRY glutSetWindow( int window ); -FGAPI int FGAPIENTRY glutGetWindow( void ); -FGAPI void FGAPIENTRY glutSetWindowTitle( const char* title ); -FGAPI void FGAPIENTRY glutSetIconTitle( const char* title ); -FGAPI void FGAPIENTRY glutReshapeWindow( int width, int height ); -FGAPI void FGAPIENTRY glutPositionWindow( int x, int y ); -FGAPI void FGAPIENTRY glutShowWindow( void ); -FGAPI void FGAPIENTRY glutHideWindow( void ); -FGAPI void FGAPIENTRY glutIconifyWindow( void ); -FGAPI void FGAPIENTRY glutPushWindow( void ); -FGAPI void FGAPIENTRY glutPopWindow( void ); -FGAPI void FGAPIENTRY glutFullScreen( void ); - -/* - * Display-connected functions, see freeglut_display.c - */ -FGAPI void FGAPIENTRY glutPostWindowRedisplay( int window ); -FGAPI void FGAPIENTRY glutPostRedisplay( void ); -FGAPI void FGAPIENTRY glutSwapBuffers( void ); - -/* - * Mouse cursor functions, see freeglut_cursor.c - */ -FGAPI void FGAPIENTRY glutWarpPointer( int x, int y ); -FGAPI void FGAPIENTRY glutSetCursor( int cursor ); - -/* - * Overlay stuff, see freeglut_overlay.c - */ -FGAPI void FGAPIENTRY glutEstablishOverlay( void ); -FGAPI void FGAPIENTRY glutRemoveOverlay( void ); -FGAPI void FGAPIENTRY glutUseLayer( GLenum layer ); -FGAPI void FGAPIENTRY glutPostOverlayRedisplay( void ); -FGAPI void FGAPIENTRY glutPostWindowOverlayRedisplay( int window ); -FGAPI void FGAPIENTRY glutShowOverlay( void ); -FGAPI void FGAPIENTRY glutHideOverlay( void ); - -/* - * Menu stuff, see freeglut_menu.c - */ -FGAPI int FGAPIENTRY glutCreateMenu( void (* callback)( int menu ) ); -FGAPI void FGAPIENTRY glutDestroyMenu( int menu ); -FGAPI int FGAPIENTRY glutGetMenu( void ); -FGAPI void FGAPIENTRY glutSetMenu( int menu ); -FGAPI void FGAPIENTRY glutAddMenuEntry( const char* label, int value ); -FGAPI void FGAPIENTRY glutAddSubMenu( const char* label, int subMenu ); -FGAPI void FGAPIENTRY glutChangeToMenuEntry( int item, const char* label, int value ); -FGAPI void FGAPIENTRY glutChangeToSubMenu( int item, const char* label, int value ); -FGAPI void FGAPIENTRY glutRemoveMenuItem( int item ); -FGAPI void FGAPIENTRY glutAttachMenu( int button ); -FGAPI void FGAPIENTRY glutDetachMenu( int button ); - -/* - * Global callback functions, see freeglut_callbacks.c - */ -FGAPI void FGAPIENTRY glutTimerFunc( unsigned int time, void (* callback)( int ), int value ); -FGAPI void FGAPIENTRY glutIdleFunc( void (* callback)( void ) ); - -/* - * Window-specific callback functions, see freeglut_callbacks.c - */ -FGAPI void FGAPIENTRY glutKeyboardFunc( void (* callback)( unsigned char, int, int ) ); -FGAPI void FGAPIENTRY glutSpecialFunc( void (* callback)( int, int, int ) ); -FGAPI void FGAPIENTRY glutReshapeFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutVisibilityFunc( void (* callback)( int ) ); -FGAPI void FGAPIENTRY glutDisplayFunc( void (* callback)( void ) ); -FGAPI void FGAPIENTRY glutMouseFunc( void (* callback)( int, int, int, int ) ); -FGAPI void FGAPIENTRY glutMotionFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutPassiveMotionFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutEntryFunc( void (* callback)( int ) ); - -FGAPI void FGAPIENTRY glutKeyboardUpFunc( void (* callback)( unsigned char, int, int ) ); -FGAPI void FGAPIENTRY glutSpecialUpFunc( void (* callback)( int, int, int ) ); -FGAPI void FGAPIENTRY glutJoystickFunc( void (* callback)( unsigned int, int, int, int ), int pollInterval ); -FGAPI void FGAPIENTRY glutMenuStateFunc( void (* callback)( int ) ); -FGAPI void FGAPIENTRY glutMenuStatusFunc( void (* callback)( int, int, int ) ); -FGAPI void FGAPIENTRY glutOverlayDisplayFunc( void (* callback)( void ) ); -FGAPI void FGAPIENTRY glutWindowStatusFunc( void (* callback)( int ) ); - -FGAPI void FGAPIENTRY glutSpaceballMotionFunc( void (* callback)( int, int, int ) ); -FGAPI void FGAPIENTRY glutSpaceballRotateFunc( void (* callback)( int, int, int ) ); -FGAPI void FGAPIENTRY glutSpaceballButtonFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutButtonBoxFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutDialsFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutTabletMotionFunc( void (* callback)( int, int ) ); -FGAPI void FGAPIENTRY glutTabletButtonFunc( void (* callback)( int, int, int, int ) ); - -/* - * State setting and retrieval functions, see freeglut_state.c - */ -FGAPI int FGAPIENTRY glutGet( GLenum query ); -FGAPI int FGAPIENTRY glutDeviceGet( GLenum query ); -FGAPI int FGAPIENTRY glutGetModifiers( void ); -FGAPI int FGAPIENTRY glutLayerGet( GLenum query ); - -/* - * Font stuff, see freeglut_font.c - */ -FGAPI void FGAPIENTRY glutBitmapCharacter( void* font, int character ); -FGAPI int FGAPIENTRY glutBitmapWidth( void* font, int character ); -FGAPI void FGAPIENTRY glutStrokeCharacter( void* font, int character ); -FGAPI int FGAPIENTRY glutStrokeWidth( void* font, int character ); -FGAPI int FGAPIENTRY glutBitmapLength( void* font, const unsigned char* string ); -FGAPI int FGAPIENTRY glutStrokeLength( void* font, const unsigned char* string ); - -/* - * Geometry functions, see freeglut_geometry.c - */ -FGAPI void FGAPIENTRY glutWireCube( GLdouble size ); -FGAPI void FGAPIENTRY glutSolidCube( GLdouble size ); -FGAPI void FGAPIENTRY glutWireSphere( GLdouble radius, GLint slices, GLint stacks ); -FGAPI void FGAPIENTRY glutSolidSphere( GLdouble radius, GLint slices, GLint stacks ); -FGAPI void FGAPIENTRY glutWireCone( GLdouble base, GLdouble height, GLint slices, GLint stacks ); -FGAPI void FGAPIENTRY glutSolidCone( GLdouble base, GLdouble height, GLint slices, GLint stacks ); - -FGAPI void FGAPIENTRY glutWireTorus( GLdouble innerRadius, GLdouble outerRadius, GLint sides, GLint rings ); -FGAPI void FGAPIENTRY glutSolidTorus( GLdouble innerRadius, GLdouble outerRadius, GLint sides, GLint rings ); -FGAPI void FGAPIENTRY glutWireDodecahedron( void ); -FGAPI void FGAPIENTRY glutSolidDodecahedron( void ); -FGAPI void FGAPIENTRY glutWireOctahedron( void ); -FGAPI void FGAPIENTRY glutSolidOctahedron( void ); -FGAPI void FGAPIENTRY glutWireTetrahedron( void ); -FGAPI void FGAPIENTRY glutSolidTetrahedron( void ); -FGAPI void FGAPIENTRY glutWireIcosahedron( void ); -FGAPI void FGAPIENTRY glutSolidIcosahedron( void ); - -/* - * Teapot rendering functions, found in freeglut_teapot.c - * NB: front facing polygons have clockwise winding, not counter clockwise - */ -FGAPI void FGAPIENTRY glutWireTeapot( GLdouble size ); -FGAPI void FGAPIENTRY glutSolidTeapot( GLdouble size ); - -/* - * Game mode functions, see freeglut_gamemode.c - */ -FGAPI void FGAPIENTRY glutGameModeString( const char* string ); -FGAPI int FGAPIENTRY glutEnterGameMode( void ); -FGAPI void FGAPIENTRY glutLeaveGameMode( void ); -FGAPI int FGAPIENTRY glutGameModeGet( GLenum query ); - -/* - * Video resize functions, see freeglut_videoresize.c - */ -FGAPI int FGAPIENTRY glutVideoResizeGet( GLenum query ); -FGAPI void FGAPIENTRY glutSetupVideoResizing( void ); -FGAPI void FGAPIENTRY glutStopVideoResizing( void ); -FGAPI void FGAPIENTRY glutVideoResize( int x, int y, int width, int height ); -FGAPI void FGAPIENTRY glutVideoPan( int x, int y, int width, int height ); - -/* - * Colormap functions, see freeglut_misc.c - */ -FGAPI void FGAPIENTRY glutSetColor( int color, GLfloat red, GLfloat green, GLfloat blue ); -FGAPI GLfloat FGAPIENTRY glutGetColor( int color, int component ); -FGAPI void FGAPIENTRY glutCopyColormap( int window ); - -/* - * Misc keyboard and joystick functions, see freeglut_misc.c - */ -FGAPI void FGAPIENTRY glutIgnoreKeyRepeat( int ignore ); -FGAPI void FGAPIENTRY glutSetKeyRepeat( int repeatMode ); -FGAPI void FGAPIENTRY glutForceJoystickFunc( void ); - -/* - * Misc functions, see freeglut_misc.c - */ -FGAPI int FGAPIENTRY glutExtensionSupported( const char* extension ); -FGAPI void FGAPIENTRY glutReportErrors( void ); - -/* Comment from glut.h of classic GLUT: - - Win32 has an annoying issue where there are multiple C run-time - libraries (CRTs). If the executable is linked with a different CRT - from the GLUT DLL, the GLUT DLL will not share the same CRT static - data seen by the executable. In particular, atexit callbacks registered - in the executable will not be called if GLUT calls its (different) - exit routine). GLUT is typically built with the - "/MD" option (the CRT with multithreading DLL support), but the Visual - C++ linker default is "/ML" (the single threaded CRT). - - One workaround to this issue is requiring users to always link with - the same CRT as GLUT is compiled with. That requires users supply a - non-standard option. GLUT 3.7 has its own built-in workaround where - the executable's "exit" function pointer is covertly passed to GLUT. - GLUT then calls the executable's exit function pointer to ensure that - any "atexit" calls registered by the application are called if GLUT - needs to exit. - - Note that the __glut*WithExit routines should NEVER be called directly. - To avoid the atexit workaround, #define GLUT_DISABLE_ATEXIT_HACK. */ - -/* to get the prototype for exit() */ -#include - -#if defined(_WIN32) && !defined(GLUT_DISABLE_ATEXIT_HACK) && !defined(__WATCOMC__) -FGAPI void FGAPIENTRY __glutInitWithExit(int *argcp, char **argv, void (__cdecl *exitfunc)(int)); -FGAPI int FGAPIENTRY __glutCreateWindowWithExit(const char *title, void (__cdecl *exitfunc)(int)); -FGAPI int FGAPIENTRY __glutCreateMenuWithExit(void (* func)(int), void (__cdecl *exitfunc)(int)); -#ifndef FREEGLUT_BUILDING_LIB -#if defined(__GNUC__) -#define FGUNUSED __attribute__((unused)) -#else -#define FGUNUSED -#endif -static void FGAPIENTRY FGUNUSED glutInit_ATEXIT_HACK(int *argcp, char **argv) { __glutInitWithExit(argcp, argv, exit); } -#define glutInit glutInit_ATEXIT_HACK -static int FGAPIENTRY FGUNUSED glutCreateWindow_ATEXIT_HACK(const char *title) { return __glutCreateWindowWithExit(title, exit); } -#define glutCreateWindow glutCreateWindow_ATEXIT_HACK -static int FGAPIENTRY FGUNUSED glutCreateMenu_ATEXIT_HACK(void (* func)(int)) { return __glutCreateMenuWithExit(func, exit); } -#define glutCreateMenu glutCreateMenu_ATEXIT_HACK -#endif -#endif - -#ifdef __cplusplus - } -#endif - -/*** END OF FILE ***/ - -#endif /* __FREEGLUT_STD_H__ */ - diff --git a/Demos/Glut/GL/glew.h b/Demos/Glut/GL/glew.h deleted file mode 100644 index f70103d11..000000000 --- a/Demos/Glut/GL/glew.h +++ /dev/null @@ -1,15507 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -/* - * Mesa 3-D graphics library - * Version: 7.0 - * - * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* -** Copyright (c) 2007 The Khronos Group Inc. -** -** Permission is hereby granted, free of charge, to any person obtaining a -** copy of this software and/or associated documentation files (the -** "Materials"), to deal in the Materials without restriction, including -** without limitation the rights to use, copy, modify, merge, publish, -** distribute, sublicense, and/or sell copies of the Materials, and to -** permit persons to whom the Materials are furnished to do so, subject to -** the following conditions: -** -** The above copyright notice and this permission notice shall be included -** in all copies or substantial portions of the Materials. -** -** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. -*/ - -#ifndef __glew_h__ -#define __glew_h__ -#define __GLEW_H__ - -#if defined(__gl_h_) || defined(__GL_H__) || defined(__X_GL_H) -#error gl.h included before glew.h -#endif -#if defined(__glext_h_) || defined(__GLEXT_H_) -#error glext.h included before glew.h -#endif -#if defined(__gl_ATI_h_) -#error glATI.h included before glew.h -#endif - -#define __gl_h_ -#define __GL_H__ -#define __X_GL_H -#define __glext_h_ -#define __GLEXT_H_ -#define __gl_ATI_h_ - -#if defined(_WIN32) - -/* - * GLEW does not include to avoid name space pollution. - * GL needs GLAPI and GLAPIENTRY, GLU needs APIENTRY, CALLBACK, and wchar_t - * defined properly. - */ -/* */ -#ifndef APIENTRY -#define GLEW_APIENTRY_DEFINED -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define APIENTRY __stdcall -# elif (_MSC_VER >= 800) || defined(_STDCALL_SUPPORTED) || defined(__BORLANDC__) -# define APIENTRY __stdcall -# else -# define APIENTRY -# endif -#endif -#ifndef GLAPI -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define GLAPI extern -# endif -#endif -/* */ -#ifndef CALLBACK -#define GLEW_CALLBACK_DEFINED -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define CALLBACK __attribute__ ((__stdcall__)) -# elif (defined(_M_MRX000) || defined(_M_IX86) || defined(_M_ALPHA) || defined(_M_PPC)) && !defined(MIDL_PASS) -# define CALLBACK __stdcall -# else -# define CALLBACK -# endif -#endif -/* and */ -#ifndef WINGDIAPI -#define GLEW_WINGDIAPI_DEFINED -#define WINGDIAPI __declspec(dllimport) -#endif -/* */ -#if (defined(_MSC_VER) || defined(__BORLANDC__)) && !defined(_WCHAR_T_DEFINED) -typedef unsigned short wchar_t; -# define _WCHAR_T_DEFINED -#endif -/* */ -#if !defined(_W64) -# if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && defined(_MSC_VER) && _MSC_VER >= 1300 -# define _W64 __w64 -# else -# define _W64 -# endif -#endif -#if !defined(_PTRDIFF_T_DEFINED) && !defined(_PTRDIFF_T_) && !defined(__MINGW64__) -# ifdef _WIN64 -typedef __int64 ptrdiff_t; -# else -typedef _W64 int ptrdiff_t; -# endif -# define _PTRDIFF_T_DEFINED -# define _PTRDIFF_T_ -#endif - -#ifndef GLAPI -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define GLAPI extern -# else -# define GLAPI WINGDIAPI -# endif -#endif - -#ifndef GLAPIENTRY -#define GLAPIENTRY APIENTRY -#endif - -/* - * GLEW_STATIC is defined for static library. - * GLEW_BUILD is defined for building the DLL library. - */ - -#ifdef GLEW_STATIC -# define GLEWAPI extern -#else -# ifdef GLEW_BUILD -# define GLEWAPI extern __declspec(dllexport) -# else -# define GLEWAPI extern __declspec(dllimport) -# endif -#endif - -#else /* _UNIX */ - -/* - * Needed for ptrdiff_t in turn needed by VBO. This is defined by ISO - * C. On my system, this amounts to _3 lines_ of included code, all of - * them pretty much harmless. If you know of a way of detecting 32 vs - * 64 _targets_ at compile time you are free to replace this with - * something that's portable. For now, _this_ is the portable solution. - * (mem, 2004-01-04) - */ - -#include - -/* SGI MIPSPro doesn't like stdint.h in C++ mode */ - -#if defined(__sgi) && !defined(__GNUC__) -#include -#else -#include -#endif - -#define GLEW_APIENTRY_DEFINED -#define APIENTRY - -/* - * GLEW_STATIC is defined for static library. - */ - -#ifdef GLEW_STATIC -# define GLEWAPI extern -#else -# if defined(__GNUC__) && __GNUC__>=4 -# define GLEWAPI extern __attribute__ ((visibility("default"))) -# elif defined(__SUNPRO_C) || defined(__SUNPRO_CC) -# define GLEWAPI extern __global -# else -# define GLEWAPI extern -# endif -#endif - -/* */ -#ifndef GLAPI -#define GLAPI extern -#endif -#ifndef GLAPIENTRY -#define GLAPIENTRY -#endif - -#endif /* _WIN32 */ - -#ifdef __cplusplus -extern "C" { -#endif - -/* ----------------------------- GL_VERSION_1_1 ---------------------------- */ - -#ifndef GL_VERSION_1_1 -#define GL_VERSION_1_1 1 - -typedef unsigned int GLenum; -typedef unsigned int GLbitfield; -typedef unsigned int GLuint; -typedef int GLint; -typedef int GLsizei; -typedef unsigned char GLboolean; -typedef signed char GLbyte; -typedef short GLshort; -typedef unsigned char GLubyte; -typedef unsigned short GLushort; -typedef unsigned long GLulong; -typedef float GLfloat; -typedef float GLclampf; -typedef double GLdouble; -typedef double GLclampd; -typedef void GLvoid; -#if defined(_MSC_VER) && _MSC_VER < 1400 -typedef __int64 GLint64EXT; -typedef unsigned __int64 GLuint64EXT; -#elif defined(_MSC_VER) || defined(__BORLANDC__) -typedef signed long long GLint64EXT; -typedef unsigned long long GLuint64EXT; -#else -# if defined(__MINGW32__) || defined(__CYGWIN__) -#include -# endif -typedef int64_t GLint64EXT; -typedef uint64_t GLuint64EXT; -#endif -typedef GLint64EXT GLint64; -typedef GLuint64EXT GLuint64; -typedef struct __GLsync *GLsync; - -typedef char GLchar; - -#define GL_ZERO 0 -#define GL_FALSE 0 -#define GL_LOGIC_OP 0x0BF1 -#define GL_NONE 0 -#define GL_TEXTURE_COMPONENTS 0x1003 -#define GL_NO_ERROR 0 -#define GL_POINTS 0x0000 -#define GL_CURRENT_BIT 0x00000001 -#define GL_TRUE 1 -#define GL_ONE 1 -#define GL_CLIENT_PIXEL_STORE_BIT 0x00000001 -#define GL_LINES 0x0001 -#define GL_LINE_LOOP 0x0002 -#define GL_POINT_BIT 0x00000002 -#define GL_CLIENT_VERTEX_ARRAY_BIT 0x00000002 -#define GL_LINE_STRIP 0x0003 -#define GL_LINE_BIT 0x00000004 -#define GL_TRIANGLES 0x0004 -#define GL_TRIANGLE_STRIP 0x0005 -#define GL_TRIANGLE_FAN 0x0006 -#define GL_QUADS 0x0007 -#define GL_QUAD_STRIP 0x0008 -#define GL_POLYGON_BIT 0x00000008 -#define GL_POLYGON 0x0009 -#define GL_POLYGON_STIPPLE_BIT 0x00000010 -#define GL_PIXEL_MODE_BIT 0x00000020 -#define GL_LIGHTING_BIT 0x00000040 -#define GL_FOG_BIT 0x00000080 -#define GL_DEPTH_BUFFER_BIT 0x00000100 -#define GL_ACCUM 0x0100 -#define GL_LOAD 0x0101 -#define GL_RETURN 0x0102 -#define GL_MULT 0x0103 -#define GL_ADD 0x0104 -#define GL_NEVER 0x0200 -#define GL_ACCUM_BUFFER_BIT 0x00000200 -#define GL_LESS 0x0201 -#define GL_EQUAL 0x0202 -#define GL_LEQUAL 0x0203 -#define GL_GREATER 0x0204 -#define GL_NOTEQUAL 0x0205 -#define GL_GEQUAL 0x0206 -#define GL_ALWAYS 0x0207 -#define GL_SRC_COLOR 0x0300 -#define GL_ONE_MINUS_SRC_COLOR 0x0301 -#define GL_SRC_ALPHA 0x0302 -#define GL_ONE_MINUS_SRC_ALPHA 0x0303 -#define GL_DST_ALPHA 0x0304 -#define GL_ONE_MINUS_DST_ALPHA 0x0305 -#define GL_DST_COLOR 0x0306 -#define GL_ONE_MINUS_DST_COLOR 0x0307 -#define GL_SRC_ALPHA_SATURATE 0x0308 -#define GL_STENCIL_BUFFER_BIT 0x00000400 -#define GL_FRONT_LEFT 0x0400 -#define GL_FRONT_RIGHT 0x0401 -#define GL_BACK_LEFT 0x0402 -#define GL_BACK_RIGHT 0x0403 -#define GL_FRONT 0x0404 -#define GL_BACK 0x0405 -#define GL_LEFT 0x0406 -#define GL_RIGHT 0x0407 -#define GL_FRONT_AND_BACK 0x0408 -#define GL_AUX0 0x0409 -#define GL_AUX1 0x040A -#define GL_AUX2 0x040B -#define GL_AUX3 0x040C -#define GL_INVALID_ENUM 0x0500 -#define GL_INVALID_VALUE 0x0501 -#define GL_INVALID_OPERATION 0x0502 -#define GL_STACK_OVERFLOW 0x0503 -#define GL_STACK_UNDERFLOW 0x0504 -#define GL_OUT_OF_MEMORY 0x0505 -#define GL_2D 0x0600 -#define GL_3D 0x0601 -#define GL_3D_COLOR 0x0602 -#define GL_3D_COLOR_TEXTURE 0x0603 -#define GL_4D_COLOR_TEXTURE 0x0604 -#define GL_PASS_THROUGH_TOKEN 0x0700 -#define GL_POINT_TOKEN 0x0701 -#define GL_LINE_TOKEN 0x0702 -#define GL_POLYGON_TOKEN 0x0703 -#define GL_BITMAP_TOKEN 0x0704 -#define GL_DRAW_PIXEL_TOKEN 0x0705 -#define GL_COPY_PIXEL_TOKEN 0x0706 -#define GL_LINE_RESET_TOKEN 0x0707 -#define GL_EXP 0x0800 -#define GL_VIEWPORT_BIT 0x00000800 -#define GL_EXP2 0x0801 -#define GL_CW 0x0900 -#define GL_CCW 0x0901 -#define GL_COEFF 0x0A00 -#define GL_ORDER 0x0A01 -#define GL_DOMAIN 0x0A02 -#define GL_CURRENT_COLOR 0x0B00 -#define GL_CURRENT_INDEX 0x0B01 -#define GL_CURRENT_NORMAL 0x0B02 -#define GL_CURRENT_TEXTURE_COORDS 0x0B03 -#define GL_CURRENT_RASTER_COLOR 0x0B04 -#define GL_CURRENT_RASTER_INDEX 0x0B05 -#define GL_CURRENT_RASTER_TEXTURE_COORDS 0x0B06 -#define GL_CURRENT_RASTER_POSITION 0x0B07 -#define GL_CURRENT_RASTER_POSITION_VALID 0x0B08 -#define GL_CURRENT_RASTER_DISTANCE 0x0B09 -#define GL_POINT_SMOOTH 0x0B10 -#define GL_POINT_SIZE 0x0B11 -#define GL_POINT_SIZE_RANGE 0x0B12 -#define GL_POINT_SIZE_GRANULARITY 0x0B13 -#define GL_LINE_SMOOTH 0x0B20 -#define GL_LINE_WIDTH 0x0B21 -#define GL_LINE_WIDTH_RANGE 0x0B22 -#define GL_LINE_WIDTH_GRANULARITY 0x0B23 -#define GL_LINE_STIPPLE 0x0B24 -#define GL_LINE_STIPPLE_PATTERN 0x0B25 -#define GL_LINE_STIPPLE_REPEAT 0x0B26 -#define GL_LIST_MODE 0x0B30 -#define GL_MAX_LIST_NESTING 0x0B31 -#define GL_LIST_BASE 0x0B32 -#define GL_LIST_INDEX 0x0B33 -#define GL_POLYGON_MODE 0x0B40 -#define GL_POLYGON_SMOOTH 0x0B41 -#define GL_POLYGON_STIPPLE 0x0B42 -#define GL_EDGE_FLAG 0x0B43 -#define GL_CULL_FACE 0x0B44 -#define GL_CULL_FACE_MODE 0x0B45 -#define GL_FRONT_FACE 0x0B46 -#define GL_LIGHTING 0x0B50 -#define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51 -#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52 -#define GL_LIGHT_MODEL_AMBIENT 0x0B53 -#define GL_SHADE_MODEL 0x0B54 -#define GL_COLOR_MATERIAL_FACE 0x0B55 -#define GL_COLOR_MATERIAL_PARAMETER 0x0B56 -#define GL_COLOR_MATERIAL 0x0B57 -#define GL_FOG 0x0B60 -#define GL_FOG_INDEX 0x0B61 -#define GL_FOG_DENSITY 0x0B62 -#define GL_FOG_START 0x0B63 -#define GL_FOG_END 0x0B64 -#define GL_FOG_MODE 0x0B65 -#define GL_FOG_COLOR 0x0B66 -#define GL_DEPTH_RANGE 0x0B70 -#define GL_DEPTH_TEST 0x0B71 -#define GL_DEPTH_WRITEMASK 0x0B72 -#define GL_DEPTH_CLEAR_VALUE 0x0B73 -#define GL_DEPTH_FUNC 0x0B74 -#define GL_ACCUM_CLEAR_VALUE 0x0B80 -#define GL_STENCIL_TEST 0x0B90 -#define GL_STENCIL_CLEAR_VALUE 0x0B91 -#define GL_STENCIL_FUNC 0x0B92 -#define GL_STENCIL_VALUE_MASK 0x0B93 -#define GL_STENCIL_FAIL 0x0B94 -#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95 -#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96 -#define GL_STENCIL_REF 0x0B97 -#define GL_STENCIL_WRITEMASK 0x0B98 -#define GL_MATRIX_MODE 0x0BA0 -#define GL_NORMALIZE 0x0BA1 -#define GL_VIEWPORT 0x0BA2 -#define GL_MODELVIEW_STACK_DEPTH 0x0BA3 -#define GL_PROJECTION_STACK_DEPTH 0x0BA4 -#define GL_TEXTURE_STACK_DEPTH 0x0BA5 -#define GL_MODELVIEW_MATRIX 0x0BA6 -#define GL_PROJECTION_MATRIX 0x0BA7 -#define GL_TEXTURE_MATRIX 0x0BA8 -#define GL_ATTRIB_STACK_DEPTH 0x0BB0 -#define GL_CLIENT_ATTRIB_STACK_DEPTH 0x0BB1 -#define GL_ALPHA_TEST 0x0BC0 -#define GL_ALPHA_TEST_FUNC 0x0BC1 -#define GL_ALPHA_TEST_REF 0x0BC2 -#define GL_DITHER 0x0BD0 -#define GL_BLEND_DST 0x0BE0 -#define GL_BLEND_SRC 0x0BE1 -#define GL_BLEND 0x0BE2 -#define GL_LOGIC_OP_MODE 0x0BF0 -#define GL_INDEX_LOGIC_OP 0x0BF1 -#define GL_COLOR_LOGIC_OP 0x0BF2 -#define GL_AUX_BUFFERS 0x0C00 -#define GL_DRAW_BUFFER 0x0C01 -#define GL_READ_BUFFER 0x0C02 -#define GL_SCISSOR_BOX 0x0C10 -#define GL_SCISSOR_TEST 0x0C11 -#define GL_INDEX_CLEAR_VALUE 0x0C20 -#define GL_INDEX_WRITEMASK 0x0C21 -#define GL_COLOR_CLEAR_VALUE 0x0C22 -#define GL_COLOR_WRITEMASK 0x0C23 -#define GL_INDEX_MODE 0x0C30 -#define GL_RGBA_MODE 0x0C31 -#define GL_DOUBLEBUFFER 0x0C32 -#define GL_STEREO 0x0C33 -#define GL_RENDER_MODE 0x0C40 -#define GL_PERSPECTIVE_CORRECTION_HINT 0x0C50 -#define GL_POINT_SMOOTH_HINT 0x0C51 -#define GL_LINE_SMOOTH_HINT 0x0C52 -#define GL_POLYGON_SMOOTH_HINT 0x0C53 -#define GL_FOG_HINT 0x0C54 -#define GL_TEXTURE_GEN_S 0x0C60 -#define GL_TEXTURE_GEN_T 0x0C61 -#define GL_TEXTURE_GEN_R 0x0C62 -#define GL_TEXTURE_GEN_Q 0x0C63 -#define GL_PIXEL_MAP_I_TO_I 0x0C70 -#define GL_PIXEL_MAP_S_TO_S 0x0C71 -#define GL_PIXEL_MAP_I_TO_R 0x0C72 -#define GL_PIXEL_MAP_I_TO_G 0x0C73 -#define GL_PIXEL_MAP_I_TO_B 0x0C74 -#define GL_PIXEL_MAP_I_TO_A 0x0C75 -#define GL_PIXEL_MAP_R_TO_R 0x0C76 -#define GL_PIXEL_MAP_G_TO_G 0x0C77 -#define GL_PIXEL_MAP_B_TO_B 0x0C78 -#define GL_PIXEL_MAP_A_TO_A 0x0C79 -#define GL_PIXEL_MAP_I_TO_I_SIZE 0x0CB0 -#define GL_PIXEL_MAP_S_TO_S_SIZE 0x0CB1 -#define GL_PIXEL_MAP_I_TO_R_SIZE 0x0CB2 -#define GL_PIXEL_MAP_I_TO_G_SIZE 0x0CB3 -#define GL_PIXEL_MAP_I_TO_B_SIZE 0x0CB4 -#define GL_PIXEL_MAP_I_TO_A_SIZE 0x0CB5 -#define GL_PIXEL_MAP_R_TO_R_SIZE 0x0CB6 -#define GL_PIXEL_MAP_G_TO_G_SIZE 0x0CB7 -#define GL_PIXEL_MAP_B_TO_B_SIZE 0x0CB8 -#define GL_PIXEL_MAP_A_TO_A_SIZE 0x0CB9 -#define GL_UNPACK_SWAP_BYTES 0x0CF0 -#define GL_UNPACK_LSB_FIRST 0x0CF1 -#define GL_UNPACK_ROW_LENGTH 0x0CF2 -#define GL_UNPACK_SKIP_ROWS 0x0CF3 -#define GL_UNPACK_SKIP_PIXELS 0x0CF4 -#define GL_UNPACK_ALIGNMENT 0x0CF5 -#define GL_PACK_SWAP_BYTES 0x0D00 -#define GL_PACK_LSB_FIRST 0x0D01 -#define GL_PACK_ROW_LENGTH 0x0D02 -#define GL_PACK_SKIP_ROWS 0x0D03 -#define GL_PACK_SKIP_PIXELS 0x0D04 -#define GL_PACK_ALIGNMENT 0x0D05 -#define GL_MAP_COLOR 0x0D10 -#define GL_MAP_STENCIL 0x0D11 -#define GL_INDEX_SHIFT 0x0D12 -#define GL_INDEX_OFFSET 0x0D13 -#define GL_RED_SCALE 0x0D14 -#define GL_RED_BIAS 0x0D15 -#define GL_ZOOM_X 0x0D16 -#define GL_ZOOM_Y 0x0D17 -#define GL_GREEN_SCALE 0x0D18 -#define GL_GREEN_BIAS 0x0D19 -#define GL_BLUE_SCALE 0x0D1A -#define GL_BLUE_BIAS 0x0D1B -#define GL_ALPHA_SCALE 0x0D1C -#define GL_ALPHA_BIAS 0x0D1D -#define GL_DEPTH_SCALE 0x0D1E -#define GL_DEPTH_BIAS 0x0D1F -#define GL_MAX_EVAL_ORDER 0x0D30 -#define GL_MAX_LIGHTS 0x0D31 -#define GL_MAX_CLIP_PLANES 0x0D32 -#define GL_MAX_TEXTURE_SIZE 0x0D33 -#define GL_MAX_PIXEL_MAP_TABLE 0x0D34 -#define GL_MAX_ATTRIB_STACK_DEPTH 0x0D35 -#define GL_MAX_MODELVIEW_STACK_DEPTH 0x0D36 -#define GL_MAX_NAME_STACK_DEPTH 0x0D37 -#define GL_MAX_PROJECTION_STACK_DEPTH 0x0D38 -#define GL_MAX_TEXTURE_STACK_DEPTH 0x0D39 -#define GL_MAX_VIEWPORT_DIMS 0x0D3A -#define GL_MAX_CLIENT_ATTRIB_STACK_DEPTH 0x0D3B -#define GL_SUBPIXEL_BITS 0x0D50 -#define GL_INDEX_BITS 0x0D51 -#define GL_RED_BITS 0x0D52 -#define GL_GREEN_BITS 0x0D53 -#define GL_BLUE_BITS 0x0D54 -#define GL_ALPHA_BITS 0x0D55 -#define GL_DEPTH_BITS 0x0D56 -#define GL_STENCIL_BITS 0x0D57 -#define GL_ACCUM_RED_BITS 0x0D58 -#define GL_ACCUM_GREEN_BITS 0x0D59 -#define GL_ACCUM_BLUE_BITS 0x0D5A -#define GL_ACCUM_ALPHA_BITS 0x0D5B -#define GL_NAME_STACK_DEPTH 0x0D70 -#define GL_AUTO_NORMAL 0x0D80 -#define GL_MAP1_COLOR_4 0x0D90 -#define GL_MAP1_INDEX 0x0D91 -#define GL_MAP1_NORMAL 0x0D92 -#define GL_MAP1_TEXTURE_COORD_1 0x0D93 -#define GL_MAP1_TEXTURE_COORD_2 0x0D94 -#define GL_MAP1_TEXTURE_COORD_3 0x0D95 -#define GL_MAP1_TEXTURE_COORD_4 0x0D96 -#define GL_MAP1_VERTEX_3 0x0D97 -#define GL_MAP1_VERTEX_4 0x0D98 -#define GL_MAP2_COLOR_4 0x0DB0 -#define GL_MAP2_INDEX 0x0DB1 -#define GL_MAP2_NORMAL 0x0DB2 -#define GL_MAP2_TEXTURE_COORD_1 0x0DB3 -#define GL_MAP2_TEXTURE_COORD_2 0x0DB4 -#define GL_MAP2_TEXTURE_COORD_3 0x0DB5 -#define GL_MAP2_TEXTURE_COORD_4 0x0DB6 -#define GL_MAP2_VERTEX_3 0x0DB7 -#define GL_MAP2_VERTEX_4 0x0DB8 -#define GL_MAP1_GRID_DOMAIN 0x0DD0 -#define GL_MAP1_GRID_SEGMENTS 0x0DD1 -#define GL_MAP2_GRID_DOMAIN 0x0DD2 -#define GL_MAP2_GRID_SEGMENTS 0x0DD3 -#define GL_TEXTURE_1D 0x0DE0 -#define GL_TEXTURE_2D 0x0DE1 -#define GL_FEEDBACK_BUFFER_POINTER 0x0DF0 -#define GL_FEEDBACK_BUFFER_SIZE 0x0DF1 -#define GL_FEEDBACK_BUFFER_TYPE 0x0DF2 -#define GL_SELECTION_BUFFER_POINTER 0x0DF3 -#define GL_SELECTION_BUFFER_SIZE 0x0DF4 -#define GL_TEXTURE_WIDTH 0x1000 -#define GL_TRANSFORM_BIT 0x00001000 -#define GL_TEXTURE_HEIGHT 0x1001 -#define GL_TEXTURE_INTERNAL_FORMAT 0x1003 -#define GL_TEXTURE_BORDER_COLOR 0x1004 -#define GL_TEXTURE_BORDER 0x1005 -#define GL_DONT_CARE 0x1100 -#define GL_FASTEST 0x1101 -#define GL_NICEST 0x1102 -#define GL_AMBIENT 0x1200 -#define GL_DIFFUSE 0x1201 -#define GL_SPECULAR 0x1202 -#define GL_POSITION 0x1203 -#define GL_SPOT_DIRECTION 0x1204 -#define GL_SPOT_EXPONENT 0x1205 -#define GL_SPOT_CUTOFF 0x1206 -#define GL_CONSTANT_ATTENUATION 0x1207 -#define GL_LINEAR_ATTENUATION 0x1208 -#define GL_QUADRATIC_ATTENUATION 0x1209 -#define GL_COMPILE 0x1300 -#define GL_COMPILE_AND_EXECUTE 0x1301 -#define GL_BYTE 0x1400 -#define GL_UNSIGNED_BYTE 0x1401 -#define GL_SHORT 0x1402 -#define GL_UNSIGNED_SHORT 0x1403 -#define GL_INT 0x1404 -#define GL_UNSIGNED_INT 0x1405 -#define GL_FLOAT 0x1406 -#define GL_2_BYTES 0x1407 -#define GL_3_BYTES 0x1408 -#define GL_4_BYTES 0x1409 -#define GL_DOUBLE 0x140A -#define GL_CLEAR 0x1500 -#define GL_AND 0x1501 -#define GL_AND_REVERSE 0x1502 -#define GL_COPY 0x1503 -#define GL_AND_INVERTED 0x1504 -#define GL_NOOP 0x1505 -#define GL_XOR 0x1506 -#define GL_OR 0x1507 -#define GL_NOR 0x1508 -#define GL_EQUIV 0x1509 -#define GL_INVERT 0x150A -#define GL_OR_REVERSE 0x150B -#define GL_COPY_INVERTED 0x150C -#define GL_OR_INVERTED 0x150D -#define GL_NAND 0x150E -#define GL_SET 0x150F -#define GL_EMISSION 0x1600 -#define GL_SHININESS 0x1601 -#define GL_AMBIENT_AND_DIFFUSE 0x1602 -#define GL_COLOR_INDEXES 0x1603 -#define GL_MODELVIEW 0x1700 -#define GL_PROJECTION 0x1701 -#define GL_TEXTURE 0x1702 -#define GL_COLOR 0x1800 -#define GL_DEPTH 0x1801 -#define GL_STENCIL 0x1802 -#define GL_COLOR_INDEX 0x1900 -#define GL_STENCIL_INDEX 0x1901 -#define GL_DEPTH_COMPONENT 0x1902 -#define GL_RED 0x1903 -#define GL_GREEN 0x1904 -#define GL_BLUE 0x1905 -#define GL_ALPHA 0x1906 -#define GL_RGB 0x1907 -#define GL_RGBA 0x1908 -#define GL_LUMINANCE 0x1909 -#define GL_LUMINANCE_ALPHA 0x190A -#define GL_BITMAP 0x1A00 -#define GL_POINT 0x1B00 -#define GL_LINE 0x1B01 -#define GL_FILL 0x1B02 -#define GL_RENDER 0x1C00 -#define GL_FEEDBACK 0x1C01 -#define GL_SELECT 0x1C02 -#define GL_FLAT 0x1D00 -#define GL_SMOOTH 0x1D01 -#define GL_KEEP 0x1E00 -#define GL_REPLACE 0x1E01 -#define GL_INCR 0x1E02 -#define GL_DECR 0x1E03 -#define GL_VENDOR 0x1F00 -#define GL_RENDERER 0x1F01 -#define GL_VERSION 0x1F02 -#define GL_EXTENSIONS 0x1F03 -#define GL_S 0x2000 -#define GL_ENABLE_BIT 0x00002000 -#define GL_T 0x2001 -#define GL_R 0x2002 -#define GL_Q 0x2003 -#define GL_MODULATE 0x2100 -#define GL_DECAL 0x2101 -#define GL_TEXTURE_ENV_MODE 0x2200 -#define GL_TEXTURE_ENV_COLOR 0x2201 -#define GL_TEXTURE_ENV 0x2300 -#define GL_EYE_LINEAR 0x2400 -#define GL_OBJECT_LINEAR 0x2401 -#define GL_SPHERE_MAP 0x2402 -#define GL_TEXTURE_GEN_MODE 0x2500 -#define GL_OBJECT_PLANE 0x2501 -#define GL_EYE_PLANE 0x2502 -#define GL_NEAREST 0x2600 -#define GL_LINEAR 0x2601 -#define GL_NEAREST_MIPMAP_NEAREST 0x2700 -#define GL_LINEAR_MIPMAP_NEAREST 0x2701 -#define GL_NEAREST_MIPMAP_LINEAR 0x2702 -#define GL_LINEAR_MIPMAP_LINEAR 0x2703 -#define GL_TEXTURE_MAG_FILTER 0x2800 -#define GL_TEXTURE_MIN_FILTER 0x2801 -#define GL_TEXTURE_WRAP_S 0x2802 -#define GL_TEXTURE_WRAP_T 0x2803 -#define GL_CLAMP 0x2900 -#define GL_REPEAT 0x2901 -#define GL_POLYGON_OFFSET_UNITS 0x2A00 -#define GL_POLYGON_OFFSET_POINT 0x2A01 -#define GL_POLYGON_OFFSET_LINE 0x2A02 -#define GL_R3_G3_B2 0x2A10 -#define GL_V2F 0x2A20 -#define GL_V3F 0x2A21 -#define GL_C4UB_V2F 0x2A22 -#define GL_C4UB_V3F 0x2A23 -#define GL_C3F_V3F 0x2A24 -#define GL_N3F_V3F 0x2A25 -#define GL_C4F_N3F_V3F 0x2A26 -#define GL_T2F_V3F 0x2A27 -#define GL_T4F_V4F 0x2A28 -#define GL_T2F_C4UB_V3F 0x2A29 -#define GL_T2F_C3F_V3F 0x2A2A -#define GL_T2F_N3F_V3F 0x2A2B -#define GL_T2F_C4F_N3F_V3F 0x2A2C -#define GL_T4F_C4F_N3F_V4F 0x2A2D -#define GL_CLIP_PLANE0 0x3000 -#define GL_CLIP_PLANE1 0x3001 -#define GL_CLIP_PLANE2 0x3002 -#define GL_CLIP_PLANE3 0x3003 -#define GL_CLIP_PLANE4 0x3004 -#define GL_CLIP_PLANE5 0x3005 -#define GL_LIGHT0 0x4000 -#define GL_COLOR_BUFFER_BIT 0x00004000 -#define GL_LIGHT1 0x4001 -#define GL_LIGHT2 0x4002 -#define GL_LIGHT3 0x4003 -#define GL_LIGHT4 0x4004 -#define GL_LIGHT5 0x4005 -#define GL_LIGHT6 0x4006 -#define GL_LIGHT7 0x4007 -#define GL_HINT_BIT 0x00008000 -#define GL_POLYGON_OFFSET_FILL 0x8037 -#define GL_POLYGON_OFFSET_FACTOR 0x8038 -#define GL_ALPHA4 0x803B -#define GL_ALPHA8 0x803C -#define GL_ALPHA12 0x803D -#define GL_ALPHA16 0x803E -#define GL_LUMINANCE4 0x803F -#define GL_LUMINANCE8 0x8040 -#define GL_LUMINANCE12 0x8041 -#define GL_LUMINANCE16 0x8042 -#define GL_LUMINANCE4_ALPHA4 0x8043 -#define GL_LUMINANCE6_ALPHA2 0x8044 -#define GL_LUMINANCE8_ALPHA8 0x8045 -#define GL_LUMINANCE12_ALPHA4 0x8046 -#define GL_LUMINANCE12_ALPHA12 0x8047 -#define GL_LUMINANCE16_ALPHA16 0x8048 -#define GL_INTENSITY 0x8049 -#define GL_INTENSITY4 0x804A -#define GL_INTENSITY8 0x804B -#define GL_INTENSITY12 0x804C -#define GL_INTENSITY16 0x804D -#define GL_RGB4 0x804F -#define GL_RGB5 0x8050 -#define GL_RGB8 0x8051 -#define GL_RGB10 0x8052 -#define GL_RGB12 0x8053 -#define GL_RGB16 0x8054 -#define GL_RGBA2 0x8055 -#define GL_RGBA4 0x8056 -#define GL_RGB5_A1 0x8057 -#define GL_RGBA8 0x8058 -#define GL_RGB10_A2 0x8059 -#define GL_RGBA12 0x805A -#define GL_RGBA16 0x805B -#define GL_TEXTURE_RED_SIZE 0x805C -#define GL_TEXTURE_GREEN_SIZE 0x805D -#define GL_TEXTURE_BLUE_SIZE 0x805E -#define GL_TEXTURE_ALPHA_SIZE 0x805F -#define GL_TEXTURE_LUMINANCE_SIZE 0x8060 -#define GL_TEXTURE_INTENSITY_SIZE 0x8061 -#define GL_PROXY_TEXTURE_1D 0x8063 -#define GL_PROXY_TEXTURE_2D 0x8064 -#define GL_TEXTURE_PRIORITY 0x8066 -#define GL_TEXTURE_RESIDENT 0x8067 -#define GL_TEXTURE_BINDING_1D 0x8068 -#define GL_TEXTURE_BINDING_2D 0x8069 -#define GL_VERTEX_ARRAY 0x8074 -#define GL_NORMAL_ARRAY 0x8075 -#define GL_COLOR_ARRAY 0x8076 -#define GL_INDEX_ARRAY 0x8077 -#define GL_TEXTURE_COORD_ARRAY 0x8078 -#define GL_EDGE_FLAG_ARRAY 0x8079 -#define GL_VERTEX_ARRAY_SIZE 0x807A -#define GL_VERTEX_ARRAY_TYPE 0x807B -#define GL_VERTEX_ARRAY_STRIDE 0x807C -#define GL_NORMAL_ARRAY_TYPE 0x807E -#define GL_NORMAL_ARRAY_STRIDE 0x807F -#define GL_COLOR_ARRAY_SIZE 0x8081 -#define GL_COLOR_ARRAY_TYPE 0x8082 -#define GL_COLOR_ARRAY_STRIDE 0x8083 -#define GL_INDEX_ARRAY_TYPE 0x8085 -#define GL_INDEX_ARRAY_STRIDE 0x8086 -#define GL_TEXTURE_COORD_ARRAY_SIZE 0x8088 -#define GL_TEXTURE_COORD_ARRAY_TYPE 0x8089 -#define GL_TEXTURE_COORD_ARRAY_STRIDE 0x808A -#define GL_EDGE_FLAG_ARRAY_STRIDE 0x808C -#define GL_VERTEX_ARRAY_POINTER 0x808E -#define GL_NORMAL_ARRAY_POINTER 0x808F -#define GL_COLOR_ARRAY_POINTER 0x8090 -#define GL_INDEX_ARRAY_POINTER 0x8091 -#define GL_TEXTURE_COORD_ARRAY_POINTER 0x8092 -#define GL_EDGE_FLAG_ARRAY_POINTER 0x8093 -#define GL_COLOR_INDEX1_EXT 0x80E2 -#define GL_COLOR_INDEX2_EXT 0x80E3 -#define GL_COLOR_INDEX4_EXT 0x80E4 -#define GL_COLOR_INDEX8_EXT 0x80E5 -#define GL_COLOR_INDEX12_EXT 0x80E6 -#define GL_COLOR_INDEX16_EXT 0x80E7 -#define GL_EVAL_BIT 0x00010000 -#define GL_LIST_BIT 0x00020000 -#define GL_TEXTURE_BIT 0x00040000 -#define GL_SCISSOR_BIT 0x00080000 -#define GL_ALL_ATTRIB_BITS 0x000fffff -#define GL_CLIENT_ALL_ATTRIB_BITS 0xffffffff - -GLAPI void GLAPIENTRY glAccum (GLenum op, GLfloat value); -GLAPI void GLAPIENTRY glAlphaFunc (GLenum func, GLclampf ref); -GLAPI GLboolean GLAPIENTRY glAreTexturesResident (GLsizei n, const GLuint *textures, GLboolean *residences); -GLAPI void GLAPIENTRY glArrayElement (GLint i); -GLAPI void GLAPIENTRY glBegin (GLenum mode); -GLAPI void GLAPIENTRY glBindTexture (GLenum target, GLuint texture); -GLAPI void GLAPIENTRY glBitmap (GLsizei width, GLsizei height, GLfloat xorig, GLfloat yorig, GLfloat xmove, GLfloat ymove, const GLubyte *bitmap); -GLAPI void GLAPIENTRY glBlendFunc (GLenum sfactor, GLenum dfactor); -GLAPI void GLAPIENTRY glCallList (GLuint list); -GLAPI void GLAPIENTRY glCallLists (GLsizei n, GLenum type, const GLvoid *lists); -GLAPI void GLAPIENTRY glClear (GLbitfield mask); -GLAPI void GLAPIENTRY glClearAccum (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); -GLAPI void GLAPIENTRY glClearColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -GLAPI void GLAPIENTRY glClearDepth (GLclampd depth); -GLAPI void GLAPIENTRY glClearIndex (GLfloat c); -GLAPI void GLAPIENTRY glClearStencil (GLint s); -GLAPI void GLAPIENTRY glClipPlane (GLenum plane, const GLdouble *equation); -GLAPI void GLAPIENTRY glColor3b (GLbyte red, GLbyte green, GLbyte blue); -GLAPI void GLAPIENTRY glColor3bv (const GLbyte *v); -GLAPI void GLAPIENTRY glColor3d (GLdouble red, GLdouble green, GLdouble blue); -GLAPI void GLAPIENTRY glColor3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glColor3f (GLfloat red, GLfloat green, GLfloat blue); -GLAPI void GLAPIENTRY glColor3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glColor3i (GLint red, GLint green, GLint blue); -GLAPI void GLAPIENTRY glColor3iv (const GLint *v); -GLAPI void GLAPIENTRY glColor3s (GLshort red, GLshort green, GLshort blue); -GLAPI void GLAPIENTRY glColor3sv (const GLshort *v); -GLAPI void GLAPIENTRY glColor3ub (GLubyte red, GLubyte green, GLubyte blue); -GLAPI void GLAPIENTRY glColor3ubv (const GLubyte *v); -GLAPI void GLAPIENTRY glColor3ui (GLuint red, GLuint green, GLuint blue); -GLAPI void GLAPIENTRY glColor3uiv (const GLuint *v); -GLAPI void GLAPIENTRY glColor3us (GLushort red, GLushort green, GLushort blue); -GLAPI void GLAPIENTRY glColor3usv (const GLushort *v); -GLAPI void GLAPIENTRY glColor4b (GLbyte red, GLbyte green, GLbyte blue, GLbyte alpha); -GLAPI void GLAPIENTRY glColor4bv (const GLbyte *v); -GLAPI void GLAPIENTRY glColor4d (GLdouble red, GLdouble green, GLdouble blue, GLdouble alpha); -GLAPI void GLAPIENTRY glColor4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glColor4f (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); -GLAPI void GLAPIENTRY glColor4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glColor4i (GLint red, GLint green, GLint blue, GLint alpha); -GLAPI void GLAPIENTRY glColor4iv (const GLint *v); -GLAPI void GLAPIENTRY glColor4s (GLshort red, GLshort green, GLshort blue, GLshort alpha); -GLAPI void GLAPIENTRY glColor4sv (const GLshort *v); -GLAPI void GLAPIENTRY glColor4ub (GLubyte red, GLubyte green, GLubyte blue, GLubyte alpha); -GLAPI void GLAPIENTRY glColor4ubv (const GLubyte *v); -GLAPI void GLAPIENTRY glColor4ui (GLuint red, GLuint green, GLuint blue, GLuint alpha); -GLAPI void GLAPIENTRY glColor4uiv (const GLuint *v); -GLAPI void GLAPIENTRY glColor4us (GLushort red, GLushort green, GLushort blue, GLushort alpha); -GLAPI void GLAPIENTRY glColor4usv (const GLushort *v); -GLAPI void GLAPIENTRY glColorMask (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); -GLAPI void GLAPIENTRY glColorMaterial (GLenum face, GLenum mode); -GLAPI void GLAPIENTRY glColorPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glCopyPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum type); -GLAPI void GLAPIENTRY glCopyTexImage1D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLint border); -GLAPI void GLAPIENTRY glCopyTexImage2D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -GLAPI void GLAPIENTRY glCopyTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -GLAPI void GLAPIENTRY glCopyTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -GLAPI void GLAPIENTRY glCullFace (GLenum mode); -GLAPI void GLAPIENTRY glDeleteLists (GLuint list, GLsizei range); -GLAPI void GLAPIENTRY glDeleteTextures (GLsizei n, const GLuint *textures); -GLAPI void GLAPIENTRY glDepthFunc (GLenum func); -GLAPI void GLAPIENTRY glDepthMask (GLboolean flag); -GLAPI void GLAPIENTRY glDepthRange (GLclampd zNear, GLclampd zFar); -GLAPI void GLAPIENTRY glDisable (GLenum cap); -GLAPI void GLAPIENTRY glDisableClientState (GLenum array); -GLAPI void GLAPIENTRY glDrawArrays (GLenum mode, GLint first, GLsizei count); -GLAPI void GLAPIENTRY glDrawBuffer (GLenum mode); -GLAPI void GLAPIENTRY glDrawElements (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices); -GLAPI void GLAPIENTRY glDrawPixels (GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glEdgeFlag (GLboolean flag); -GLAPI void GLAPIENTRY glEdgeFlagPointer (GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glEdgeFlagv (const GLboolean *flag); -GLAPI void GLAPIENTRY glEnable (GLenum cap); -GLAPI void GLAPIENTRY glEnableClientState (GLenum array); -GLAPI void GLAPIENTRY glEnd (void); -GLAPI void GLAPIENTRY glEndList (void); -GLAPI void GLAPIENTRY glEvalCoord1d (GLdouble u); -GLAPI void GLAPIENTRY glEvalCoord1dv (const GLdouble *u); -GLAPI void GLAPIENTRY glEvalCoord1f (GLfloat u); -GLAPI void GLAPIENTRY glEvalCoord1fv (const GLfloat *u); -GLAPI void GLAPIENTRY glEvalCoord2d (GLdouble u, GLdouble v); -GLAPI void GLAPIENTRY glEvalCoord2dv (const GLdouble *u); -GLAPI void GLAPIENTRY glEvalCoord2f (GLfloat u, GLfloat v); -GLAPI void GLAPIENTRY glEvalCoord2fv (const GLfloat *u); -GLAPI void GLAPIENTRY glEvalMesh1 (GLenum mode, GLint i1, GLint i2); -GLAPI void GLAPIENTRY glEvalMesh2 (GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2); -GLAPI void GLAPIENTRY glEvalPoint1 (GLint i); -GLAPI void GLAPIENTRY glEvalPoint2 (GLint i, GLint j); -GLAPI void GLAPIENTRY glFeedbackBuffer (GLsizei size, GLenum type, GLfloat *buffer); -GLAPI void GLAPIENTRY glFinish (void); -GLAPI void GLAPIENTRY glFlush (void); -GLAPI void GLAPIENTRY glFogf (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glFogfv (GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glFogi (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glFogiv (GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glFrontFace (GLenum mode); -GLAPI void GLAPIENTRY glFrustum (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); -GLAPI GLuint GLAPIENTRY glGenLists (GLsizei range); -GLAPI void GLAPIENTRY glGenTextures (GLsizei n, GLuint *textures); -GLAPI void GLAPIENTRY glGetBooleanv (GLenum pname, GLboolean *params); -GLAPI void GLAPIENTRY glGetClipPlane (GLenum plane, GLdouble *equation); -GLAPI void GLAPIENTRY glGetDoublev (GLenum pname, GLdouble *params); -GLAPI GLenum GLAPIENTRY glGetError (void); -GLAPI void GLAPIENTRY glGetFloatv (GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetIntegerv (GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetLightfv (GLenum light, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetLightiv (GLenum light, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetMapdv (GLenum target, GLenum query, GLdouble *v); -GLAPI void GLAPIENTRY glGetMapfv (GLenum target, GLenum query, GLfloat *v); -GLAPI void GLAPIENTRY glGetMapiv (GLenum target, GLenum query, GLint *v); -GLAPI void GLAPIENTRY glGetMaterialfv (GLenum face, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetMaterialiv (GLenum face, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetPixelMapfv (GLenum map, GLfloat *values); -GLAPI void GLAPIENTRY glGetPixelMapuiv (GLenum map, GLuint *values); -GLAPI void GLAPIENTRY glGetPixelMapusv (GLenum map, GLushort *values); -GLAPI void GLAPIENTRY glGetPointerv (GLenum pname, GLvoid* *params); -GLAPI void GLAPIENTRY glGetPolygonStipple (GLubyte *mask); -GLAPI const GLubyte * GLAPIENTRY glGetString (GLenum name); -GLAPI void GLAPIENTRY glGetTexEnvfv (GLenum target, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexEnviv (GLenum target, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetTexGendv (GLenum coord, GLenum pname, GLdouble *params); -GLAPI void GLAPIENTRY glGetTexGenfv (GLenum coord, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexGeniv (GLenum coord, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetTexImage (GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); -GLAPI void GLAPIENTRY glGetTexLevelParameterfv (GLenum target, GLint level, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexLevelParameteriv (GLenum target, GLint level, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetTexParameterfv (GLenum target, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexParameteriv (GLenum target, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glHint (GLenum target, GLenum mode); -GLAPI void GLAPIENTRY glIndexMask (GLuint mask); -GLAPI void GLAPIENTRY glIndexPointer (GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glIndexd (GLdouble c); -GLAPI void GLAPIENTRY glIndexdv (const GLdouble *c); -GLAPI void GLAPIENTRY glIndexf (GLfloat c); -GLAPI void GLAPIENTRY glIndexfv (const GLfloat *c); -GLAPI void GLAPIENTRY glIndexi (GLint c); -GLAPI void GLAPIENTRY glIndexiv (const GLint *c); -GLAPI void GLAPIENTRY glIndexs (GLshort c); -GLAPI void GLAPIENTRY glIndexsv (const GLshort *c); -GLAPI void GLAPIENTRY glIndexub (GLubyte c); -GLAPI void GLAPIENTRY glIndexubv (const GLubyte *c); -GLAPI void GLAPIENTRY glInitNames (void); -GLAPI void GLAPIENTRY glInterleavedArrays (GLenum format, GLsizei stride, const GLvoid *pointer); -GLAPI GLboolean GLAPIENTRY glIsEnabled (GLenum cap); -GLAPI GLboolean GLAPIENTRY glIsList (GLuint list); -GLAPI GLboolean GLAPIENTRY glIsTexture (GLuint texture); -GLAPI void GLAPIENTRY glLightModelf (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glLightModelfv (GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glLightModeli (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glLightModeliv (GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glLightf (GLenum light, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glLightfv (GLenum light, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glLighti (GLenum light, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glLightiv (GLenum light, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glLineStipple (GLint factor, GLushort pattern); -GLAPI void GLAPIENTRY glLineWidth (GLfloat width); -GLAPI void GLAPIENTRY glListBase (GLuint base); -GLAPI void GLAPIENTRY glLoadIdentity (void); -GLAPI void GLAPIENTRY glLoadMatrixd (const GLdouble *m); -GLAPI void GLAPIENTRY glLoadMatrixf (const GLfloat *m); -GLAPI void GLAPIENTRY glLoadName (GLuint name); -GLAPI void GLAPIENTRY glLogicOp (GLenum opcode); -GLAPI void GLAPIENTRY glMap1d (GLenum target, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); -GLAPI void GLAPIENTRY glMap1f (GLenum target, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); -GLAPI void GLAPIENTRY glMap2d (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); -GLAPI void GLAPIENTRY glMap2f (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); -GLAPI void GLAPIENTRY glMapGrid1d (GLint un, GLdouble u1, GLdouble u2); -GLAPI void GLAPIENTRY glMapGrid1f (GLint un, GLfloat u1, GLfloat u2); -GLAPI void GLAPIENTRY glMapGrid2d (GLint un, GLdouble u1, GLdouble u2, GLint vn, GLdouble v1, GLdouble v2); -GLAPI void GLAPIENTRY glMapGrid2f (GLint un, GLfloat u1, GLfloat u2, GLint vn, GLfloat v1, GLfloat v2); -GLAPI void GLAPIENTRY glMaterialf (GLenum face, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glMaterialfv (GLenum face, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glMateriali (GLenum face, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glMaterialiv (GLenum face, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glMatrixMode (GLenum mode); -GLAPI void GLAPIENTRY glMultMatrixd (const GLdouble *m); -GLAPI void GLAPIENTRY glMultMatrixf (const GLfloat *m); -GLAPI void GLAPIENTRY glNewList (GLuint list, GLenum mode); -GLAPI void GLAPIENTRY glNormal3b (GLbyte nx, GLbyte ny, GLbyte nz); -GLAPI void GLAPIENTRY glNormal3bv (const GLbyte *v); -GLAPI void GLAPIENTRY glNormal3d (GLdouble nx, GLdouble ny, GLdouble nz); -GLAPI void GLAPIENTRY glNormal3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glNormal3f (GLfloat nx, GLfloat ny, GLfloat nz); -GLAPI void GLAPIENTRY glNormal3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glNormal3i (GLint nx, GLint ny, GLint nz); -GLAPI void GLAPIENTRY glNormal3iv (const GLint *v); -GLAPI void GLAPIENTRY glNormal3s (GLshort nx, GLshort ny, GLshort nz); -GLAPI void GLAPIENTRY glNormal3sv (const GLshort *v); -GLAPI void GLAPIENTRY glNormalPointer (GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glOrtho (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); -GLAPI void GLAPIENTRY glPassThrough (GLfloat token); -GLAPI void GLAPIENTRY glPixelMapfv (GLenum map, GLsizei mapsize, const GLfloat *values); -GLAPI void GLAPIENTRY glPixelMapuiv (GLenum map, GLsizei mapsize, const GLuint *values); -GLAPI void GLAPIENTRY glPixelMapusv (GLenum map, GLsizei mapsize, const GLushort *values); -GLAPI void GLAPIENTRY glPixelStoref (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glPixelStorei (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glPixelTransferf (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glPixelTransferi (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glPixelZoom (GLfloat xfactor, GLfloat yfactor); -GLAPI void GLAPIENTRY glPointSize (GLfloat size); -GLAPI void GLAPIENTRY glPolygonMode (GLenum face, GLenum mode); -GLAPI void GLAPIENTRY glPolygonOffset (GLfloat factor, GLfloat units); -GLAPI void GLAPIENTRY glPolygonStipple (const GLubyte *mask); -GLAPI void GLAPIENTRY glPopAttrib (void); -GLAPI void GLAPIENTRY glPopClientAttrib (void); -GLAPI void GLAPIENTRY glPopMatrix (void); -GLAPI void GLAPIENTRY glPopName (void); -GLAPI void GLAPIENTRY glPrioritizeTextures (GLsizei n, const GLuint *textures, const GLclampf *priorities); -GLAPI void GLAPIENTRY glPushAttrib (GLbitfield mask); -GLAPI void GLAPIENTRY glPushClientAttrib (GLbitfield mask); -GLAPI void GLAPIENTRY glPushMatrix (void); -GLAPI void GLAPIENTRY glPushName (GLuint name); -GLAPI void GLAPIENTRY glRasterPos2d (GLdouble x, GLdouble y); -GLAPI void GLAPIENTRY glRasterPos2dv (const GLdouble *v); -GLAPI void GLAPIENTRY glRasterPos2f (GLfloat x, GLfloat y); -GLAPI void GLAPIENTRY glRasterPos2fv (const GLfloat *v); -GLAPI void GLAPIENTRY glRasterPos2i (GLint x, GLint y); -GLAPI void GLAPIENTRY glRasterPos2iv (const GLint *v); -GLAPI void GLAPIENTRY glRasterPos2s (GLshort x, GLshort y); -GLAPI void GLAPIENTRY glRasterPos2sv (const GLshort *v); -GLAPI void GLAPIENTRY glRasterPos3d (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glRasterPos3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glRasterPos3f (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glRasterPos3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glRasterPos3i (GLint x, GLint y, GLint z); -GLAPI void GLAPIENTRY glRasterPos3iv (const GLint *v); -GLAPI void GLAPIENTRY glRasterPos3s (GLshort x, GLshort y, GLshort z); -GLAPI void GLAPIENTRY glRasterPos3sv (const GLshort *v); -GLAPI void GLAPIENTRY glRasterPos4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -GLAPI void GLAPIENTRY glRasterPos4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glRasterPos4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -GLAPI void GLAPIENTRY glRasterPos4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glRasterPos4i (GLint x, GLint y, GLint z, GLint w); -GLAPI void GLAPIENTRY glRasterPos4iv (const GLint *v); -GLAPI void GLAPIENTRY glRasterPos4s (GLshort x, GLshort y, GLshort z, GLshort w); -GLAPI void GLAPIENTRY glRasterPos4sv (const GLshort *v); -GLAPI void GLAPIENTRY glReadBuffer (GLenum mode); -GLAPI void GLAPIENTRY glReadPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid *pixels); -GLAPI void GLAPIENTRY glRectd (GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2); -GLAPI void GLAPIENTRY glRectdv (const GLdouble *v1, const GLdouble *v2); -GLAPI void GLAPIENTRY glRectf (GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2); -GLAPI void GLAPIENTRY glRectfv (const GLfloat *v1, const GLfloat *v2); -GLAPI void GLAPIENTRY glRecti (GLint x1, GLint y1, GLint x2, GLint y2); -GLAPI void GLAPIENTRY glRectiv (const GLint *v1, const GLint *v2); -GLAPI void GLAPIENTRY glRects (GLshort x1, GLshort y1, GLshort x2, GLshort y2); -GLAPI void GLAPIENTRY glRectsv (const GLshort *v1, const GLshort *v2); -GLAPI GLint GLAPIENTRY glRenderMode (GLenum mode); -GLAPI void GLAPIENTRY glRotated (GLdouble angle, GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glRotatef (GLfloat angle, GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glScaled (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glScalef (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glScissor (GLint x, GLint y, GLsizei width, GLsizei height); -GLAPI void GLAPIENTRY glSelectBuffer (GLsizei size, GLuint *buffer); -GLAPI void GLAPIENTRY glShadeModel (GLenum mode); -GLAPI void GLAPIENTRY glStencilFunc (GLenum func, GLint ref, GLuint mask); -GLAPI void GLAPIENTRY glStencilMask (GLuint mask); -GLAPI void GLAPIENTRY glStencilOp (GLenum fail, GLenum zfail, GLenum zpass); -GLAPI void GLAPIENTRY glTexCoord1d (GLdouble s); -GLAPI void GLAPIENTRY glTexCoord1dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord1f (GLfloat s); -GLAPI void GLAPIENTRY glTexCoord1fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord1i (GLint s); -GLAPI void GLAPIENTRY glTexCoord1iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord1s (GLshort s); -GLAPI void GLAPIENTRY glTexCoord1sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoord2d (GLdouble s, GLdouble t); -GLAPI void GLAPIENTRY glTexCoord2dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord2f (GLfloat s, GLfloat t); -GLAPI void GLAPIENTRY glTexCoord2fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord2i (GLint s, GLint t); -GLAPI void GLAPIENTRY glTexCoord2iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord2s (GLshort s, GLshort t); -GLAPI void GLAPIENTRY glTexCoord2sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoord3d (GLdouble s, GLdouble t, GLdouble r); -GLAPI void GLAPIENTRY glTexCoord3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord3f (GLfloat s, GLfloat t, GLfloat r); -GLAPI void GLAPIENTRY glTexCoord3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord3i (GLint s, GLint t, GLint r); -GLAPI void GLAPIENTRY glTexCoord3iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord3s (GLshort s, GLshort t, GLshort r); -GLAPI void GLAPIENTRY glTexCoord3sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoord4d (GLdouble s, GLdouble t, GLdouble r, GLdouble q); -GLAPI void GLAPIENTRY glTexCoord4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord4f (GLfloat s, GLfloat t, GLfloat r, GLfloat q); -GLAPI void GLAPIENTRY glTexCoord4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord4i (GLint s, GLint t, GLint r, GLint q); -GLAPI void GLAPIENTRY glTexCoord4iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord4s (GLshort s, GLshort t, GLshort r, GLshort q); -GLAPI void GLAPIENTRY glTexCoord4sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoordPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glTexEnvf (GLenum target, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glTexEnvfv (GLenum target, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glTexEnvi (GLenum target, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glTexEnviv (GLenum target, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glTexGend (GLenum coord, GLenum pname, GLdouble param); -GLAPI void GLAPIENTRY glTexGendv (GLenum coord, GLenum pname, const GLdouble *params); -GLAPI void GLAPIENTRY glTexGenf (GLenum coord, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glTexGenfv (GLenum coord, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glTexGeni (GLenum coord, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glTexGeniv (GLenum coord, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glTexImage1D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTexImage2D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTexParameterf (GLenum target, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glTexParameterfv (GLenum target, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glTexParameteri (GLenum target, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glTexParameteriv (GLenum target, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTranslated (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glTranslatef (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glVertex2d (GLdouble x, GLdouble y); -GLAPI void GLAPIENTRY glVertex2dv (const GLdouble *v); -GLAPI void GLAPIENTRY glVertex2f (GLfloat x, GLfloat y); -GLAPI void GLAPIENTRY glVertex2fv (const GLfloat *v); -GLAPI void GLAPIENTRY glVertex2i (GLint x, GLint y); -GLAPI void GLAPIENTRY glVertex2iv (const GLint *v); -GLAPI void GLAPIENTRY glVertex2s (GLshort x, GLshort y); -GLAPI void GLAPIENTRY glVertex2sv (const GLshort *v); -GLAPI void GLAPIENTRY glVertex3d (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glVertex3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glVertex3f (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glVertex3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glVertex3i (GLint x, GLint y, GLint z); -GLAPI void GLAPIENTRY glVertex3iv (const GLint *v); -GLAPI void GLAPIENTRY glVertex3s (GLshort x, GLshort y, GLshort z); -GLAPI void GLAPIENTRY glVertex3sv (const GLshort *v); -GLAPI void GLAPIENTRY glVertex4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -GLAPI void GLAPIENTRY glVertex4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glVertex4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -GLAPI void GLAPIENTRY glVertex4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glVertex4i (GLint x, GLint y, GLint z, GLint w); -GLAPI void GLAPIENTRY glVertex4iv (const GLint *v); -GLAPI void GLAPIENTRY glVertex4s (GLshort x, GLshort y, GLshort z, GLshort w); -GLAPI void GLAPIENTRY glVertex4sv (const GLshort *v); -GLAPI void GLAPIENTRY glVertexPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glViewport (GLint x, GLint y, GLsizei width, GLsizei height); - -#define GLEW_VERSION_1_1 GLEW_GET_VAR(__GLEW_VERSION_1_1) - -#endif /* GL_VERSION_1_1 */ - -/* ---------------------------------- GLU ---------------------------------- */ - -#ifndef GLEW_NO_GLU -/* this is where we can safely include GLU */ -# if defined(__APPLE__) && defined(__MACH__) -# include -# else -# include -# endif -#endif - -/* ----------------------------- GL_VERSION_1_2 ---------------------------- */ - -#ifndef GL_VERSION_1_2 -#define GL_VERSION_1_2 1 - -#define GL_SMOOTH_POINT_SIZE_RANGE 0x0B12 -#define GL_SMOOTH_POINT_SIZE_GRANULARITY 0x0B13 -#define GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22 -#define GL_SMOOTH_LINE_WIDTH_GRANULARITY 0x0B23 -#define GL_UNSIGNED_BYTE_3_3_2 0x8032 -#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 -#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 -#define GL_UNSIGNED_INT_8_8_8_8 0x8035 -#define GL_UNSIGNED_INT_10_10_10_2 0x8036 -#define GL_RESCALE_NORMAL 0x803A -#define GL_TEXTURE_BINDING_3D 0x806A -#define GL_PACK_SKIP_IMAGES 0x806B -#define GL_PACK_IMAGE_HEIGHT 0x806C -#define GL_UNPACK_SKIP_IMAGES 0x806D -#define GL_UNPACK_IMAGE_HEIGHT 0x806E -#define GL_TEXTURE_3D 0x806F -#define GL_PROXY_TEXTURE_3D 0x8070 -#define GL_TEXTURE_DEPTH 0x8071 -#define GL_TEXTURE_WRAP_R 0x8072 -#define GL_MAX_3D_TEXTURE_SIZE 0x8073 -#define GL_BGR 0x80E0 -#define GL_BGRA 0x80E1 -#define GL_MAX_ELEMENTS_VERTICES 0x80E8 -#define GL_MAX_ELEMENTS_INDICES 0x80E9 -#define GL_CLAMP_TO_EDGE 0x812F -#define GL_TEXTURE_MIN_LOD 0x813A -#define GL_TEXTURE_MAX_LOD 0x813B -#define GL_TEXTURE_BASE_LEVEL 0x813C -#define GL_TEXTURE_MAX_LEVEL 0x813D -#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 -#define GL_SINGLE_COLOR 0x81F9 -#define GL_SEPARATE_SPECULAR_COLOR 0x81FA -#define GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 -#define GL_UNSIGNED_SHORT_5_6_5 0x8363 -#define GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 -#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 -#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 -#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 -#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 -#define GL_ALIASED_POINT_SIZE_RANGE 0x846D -#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E - -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); - -#define glCopyTexSubImage3D GLEW_GET_FUN(__glewCopyTexSubImage3D) -#define glDrawRangeElements GLEW_GET_FUN(__glewDrawRangeElements) -#define glTexImage3D GLEW_GET_FUN(__glewTexImage3D) -#define glTexSubImage3D GLEW_GET_FUN(__glewTexSubImage3D) - -#define GLEW_VERSION_1_2 GLEW_GET_VAR(__GLEW_VERSION_1_2) - -#endif /* GL_VERSION_1_2 */ - -/* ---------------------------- GL_VERSION_1_2_1 --------------------------- */ - -#ifndef GL_VERSION_1_2_1 -#define GL_VERSION_1_2_1 1 - -#define GLEW_VERSION_1_2_1 GLEW_GET_VAR(__GLEW_VERSION_1_2_1) - -#endif /* GL_VERSION_1_2_1 */ - -/* ----------------------------- GL_VERSION_1_3 ---------------------------- */ - -#ifndef GL_VERSION_1_3 -#define GL_VERSION_1_3 1 - -#define GL_MULTISAMPLE 0x809D -#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE 0x809F -#define GL_SAMPLE_COVERAGE 0x80A0 -#define GL_SAMPLE_BUFFERS 0x80A8 -#define GL_SAMPLES 0x80A9 -#define GL_SAMPLE_COVERAGE_VALUE 0x80AA -#define GL_SAMPLE_COVERAGE_INVERT 0x80AB -#define GL_CLAMP_TO_BORDER 0x812D -#define GL_TEXTURE0 0x84C0 -#define GL_TEXTURE1 0x84C1 -#define GL_TEXTURE2 0x84C2 -#define GL_TEXTURE3 0x84C3 -#define GL_TEXTURE4 0x84C4 -#define GL_TEXTURE5 0x84C5 -#define GL_TEXTURE6 0x84C6 -#define GL_TEXTURE7 0x84C7 -#define GL_TEXTURE8 0x84C8 -#define GL_TEXTURE9 0x84C9 -#define GL_TEXTURE10 0x84CA -#define GL_TEXTURE11 0x84CB -#define GL_TEXTURE12 0x84CC -#define GL_TEXTURE13 0x84CD -#define GL_TEXTURE14 0x84CE -#define GL_TEXTURE15 0x84CF -#define GL_TEXTURE16 0x84D0 -#define GL_TEXTURE17 0x84D1 -#define GL_TEXTURE18 0x84D2 -#define GL_TEXTURE19 0x84D3 -#define GL_TEXTURE20 0x84D4 -#define GL_TEXTURE21 0x84D5 -#define GL_TEXTURE22 0x84D6 -#define GL_TEXTURE23 0x84D7 -#define GL_TEXTURE24 0x84D8 -#define GL_TEXTURE25 0x84D9 -#define GL_TEXTURE26 0x84DA -#define GL_TEXTURE27 0x84DB -#define GL_TEXTURE28 0x84DC -#define GL_TEXTURE29 0x84DD -#define GL_TEXTURE30 0x84DE -#define GL_TEXTURE31 0x84DF -#define GL_ACTIVE_TEXTURE 0x84E0 -#define GL_CLIENT_ACTIVE_TEXTURE 0x84E1 -#define GL_MAX_TEXTURE_UNITS 0x84E2 -#define GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 -#define GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 -#define GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 -#define GL_TRANSPOSE_COLOR_MATRIX 0x84E6 -#define GL_SUBTRACT 0x84E7 -#define GL_COMPRESSED_ALPHA 0x84E9 -#define GL_COMPRESSED_LUMINANCE 0x84EA -#define GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB -#define GL_COMPRESSED_INTENSITY 0x84EC -#define GL_COMPRESSED_RGB 0x84ED -#define GL_COMPRESSED_RGBA 0x84EE -#define GL_TEXTURE_COMPRESSION_HINT 0x84EF -#define GL_NORMAL_MAP 0x8511 -#define GL_REFLECTION_MAP 0x8512 -#define GL_TEXTURE_CUBE_MAP 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C -#define GL_COMBINE 0x8570 -#define GL_COMBINE_RGB 0x8571 -#define GL_COMBINE_ALPHA 0x8572 -#define GL_RGB_SCALE 0x8573 -#define GL_ADD_SIGNED 0x8574 -#define GL_INTERPOLATE 0x8575 -#define GL_CONSTANT 0x8576 -#define GL_PRIMARY_COLOR 0x8577 -#define GL_PREVIOUS 0x8578 -#define GL_SOURCE0_RGB 0x8580 -#define GL_SOURCE1_RGB 0x8581 -#define GL_SOURCE2_RGB 0x8582 -#define GL_SOURCE0_ALPHA 0x8588 -#define GL_SOURCE1_ALPHA 0x8589 -#define GL_SOURCE2_ALPHA 0x858A -#define GL_OPERAND0_RGB 0x8590 -#define GL_OPERAND1_RGB 0x8591 -#define GL_OPERAND2_RGB 0x8592 -#define GL_OPERAND0_ALPHA 0x8598 -#define GL_OPERAND1_ALPHA 0x8599 -#define GL_OPERAND2_ALPHA 0x859A -#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 -#define GL_TEXTURE_COMPRESSED 0x86A1 -#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 -#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 -#define GL_DOT3_RGB 0x86AE -#define GL_DOT3_RGBA 0x86AF -#define GL_MULTISAMPLE_BIT 0x20000000 - -typedef void (GLAPIENTRY * PFNGLACTIVETEXTUREPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLCLIENTACTIVETEXTUREPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEPROC) (GLenum target, GLint lod, GLvoid *img); -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXDPROC) (const GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXFPROC) (const GLfloat m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXDPROC) (const GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXFPROC) (const GLfloat m[16]); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DPROC) (GLenum target, GLdouble s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FPROC) (GLenum target, GLfloat s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IPROC) (GLenum target, GLint s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SPROC) (GLenum target, GLshort s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DPROC) (GLenum target, GLdouble s, GLdouble t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FPROC) (GLenum target, GLfloat s, GLfloat t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IPROC) (GLenum target, GLint s, GLint t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SPROC) (GLenum target, GLshort s, GLshort t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IPROC) (GLenum target, GLint s, GLint t, GLint r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SPROC) (GLenum target, GLshort s, GLshort t, GLshort r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEPROC) (GLclampf value, GLboolean invert); - -#define glActiveTexture GLEW_GET_FUN(__glewActiveTexture) -#define glClientActiveTexture GLEW_GET_FUN(__glewClientActiveTexture) -#define glCompressedTexImage1D GLEW_GET_FUN(__glewCompressedTexImage1D) -#define glCompressedTexImage2D GLEW_GET_FUN(__glewCompressedTexImage2D) -#define glCompressedTexImage3D GLEW_GET_FUN(__glewCompressedTexImage3D) -#define glCompressedTexSubImage1D GLEW_GET_FUN(__glewCompressedTexSubImage1D) -#define glCompressedTexSubImage2D GLEW_GET_FUN(__glewCompressedTexSubImage2D) -#define glCompressedTexSubImage3D GLEW_GET_FUN(__glewCompressedTexSubImage3D) -#define glGetCompressedTexImage GLEW_GET_FUN(__glewGetCompressedTexImage) -#define glLoadTransposeMatrixd GLEW_GET_FUN(__glewLoadTransposeMatrixd) -#define glLoadTransposeMatrixf GLEW_GET_FUN(__glewLoadTransposeMatrixf) -#define glMultTransposeMatrixd GLEW_GET_FUN(__glewMultTransposeMatrixd) -#define glMultTransposeMatrixf GLEW_GET_FUN(__glewMultTransposeMatrixf) -#define glMultiTexCoord1d GLEW_GET_FUN(__glewMultiTexCoord1d) -#define glMultiTexCoord1dv GLEW_GET_FUN(__glewMultiTexCoord1dv) -#define glMultiTexCoord1f GLEW_GET_FUN(__glewMultiTexCoord1f) -#define glMultiTexCoord1fv GLEW_GET_FUN(__glewMultiTexCoord1fv) -#define glMultiTexCoord1i GLEW_GET_FUN(__glewMultiTexCoord1i) -#define glMultiTexCoord1iv GLEW_GET_FUN(__glewMultiTexCoord1iv) -#define glMultiTexCoord1s GLEW_GET_FUN(__glewMultiTexCoord1s) -#define glMultiTexCoord1sv GLEW_GET_FUN(__glewMultiTexCoord1sv) -#define glMultiTexCoord2d GLEW_GET_FUN(__glewMultiTexCoord2d) -#define glMultiTexCoord2dv GLEW_GET_FUN(__glewMultiTexCoord2dv) -#define glMultiTexCoord2f GLEW_GET_FUN(__glewMultiTexCoord2f) -#define glMultiTexCoord2fv GLEW_GET_FUN(__glewMultiTexCoord2fv) -#define glMultiTexCoord2i GLEW_GET_FUN(__glewMultiTexCoord2i) -#define glMultiTexCoord2iv GLEW_GET_FUN(__glewMultiTexCoord2iv) -#define glMultiTexCoord2s GLEW_GET_FUN(__glewMultiTexCoord2s) -#define glMultiTexCoord2sv GLEW_GET_FUN(__glewMultiTexCoord2sv) -#define glMultiTexCoord3d GLEW_GET_FUN(__glewMultiTexCoord3d) -#define glMultiTexCoord3dv GLEW_GET_FUN(__glewMultiTexCoord3dv) -#define glMultiTexCoord3f GLEW_GET_FUN(__glewMultiTexCoord3f) -#define glMultiTexCoord3fv GLEW_GET_FUN(__glewMultiTexCoord3fv) -#define glMultiTexCoord3i GLEW_GET_FUN(__glewMultiTexCoord3i) -#define glMultiTexCoord3iv GLEW_GET_FUN(__glewMultiTexCoord3iv) -#define glMultiTexCoord3s GLEW_GET_FUN(__glewMultiTexCoord3s) -#define glMultiTexCoord3sv GLEW_GET_FUN(__glewMultiTexCoord3sv) -#define glMultiTexCoord4d GLEW_GET_FUN(__glewMultiTexCoord4d) -#define glMultiTexCoord4dv GLEW_GET_FUN(__glewMultiTexCoord4dv) -#define glMultiTexCoord4f GLEW_GET_FUN(__glewMultiTexCoord4f) -#define glMultiTexCoord4fv GLEW_GET_FUN(__glewMultiTexCoord4fv) -#define glMultiTexCoord4i GLEW_GET_FUN(__glewMultiTexCoord4i) -#define glMultiTexCoord4iv GLEW_GET_FUN(__glewMultiTexCoord4iv) -#define glMultiTexCoord4s GLEW_GET_FUN(__glewMultiTexCoord4s) -#define glMultiTexCoord4sv GLEW_GET_FUN(__glewMultiTexCoord4sv) -#define glSampleCoverage GLEW_GET_FUN(__glewSampleCoverage) - -#define GLEW_VERSION_1_3 GLEW_GET_VAR(__GLEW_VERSION_1_3) - -#endif /* GL_VERSION_1_3 */ - -/* ----------------------------- GL_VERSION_1_4 ---------------------------- */ - -#ifndef GL_VERSION_1_4 -#define GL_VERSION_1_4 1 - -#define GL_BLEND_DST_RGB 0x80C8 -#define GL_BLEND_SRC_RGB 0x80C9 -#define GL_BLEND_DST_ALPHA 0x80CA -#define GL_BLEND_SRC_ALPHA 0x80CB -#define GL_POINT_SIZE_MIN 0x8126 -#define GL_POINT_SIZE_MAX 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE 0x8128 -#define GL_POINT_DISTANCE_ATTENUATION 0x8129 -#define GL_GENERATE_MIPMAP 0x8191 -#define GL_GENERATE_MIPMAP_HINT 0x8192 -#define GL_DEPTH_COMPONENT16 0x81A5 -#define GL_DEPTH_COMPONENT24 0x81A6 -#define GL_DEPTH_COMPONENT32 0x81A7 -#define GL_MIRRORED_REPEAT 0x8370 -#define GL_FOG_COORDINATE_SOURCE 0x8450 -#define GL_FOG_COORDINATE 0x8451 -#define GL_FRAGMENT_DEPTH 0x8452 -#define GL_CURRENT_FOG_COORDINATE 0x8453 -#define GL_FOG_COORDINATE_ARRAY_TYPE 0x8454 -#define GL_FOG_COORDINATE_ARRAY_STRIDE 0x8455 -#define GL_FOG_COORDINATE_ARRAY_POINTER 0x8456 -#define GL_FOG_COORDINATE_ARRAY 0x8457 -#define GL_COLOR_SUM 0x8458 -#define GL_CURRENT_SECONDARY_COLOR 0x8459 -#define GL_SECONDARY_COLOR_ARRAY_SIZE 0x845A -#define GL_SECONDARY_COLOR_ARRAY_TYPE 0x845B -#define GL_SECONDARY_COLOR_ARRAY_STRIDE 0x845C -#define GL_SECONDARY_COLOR_ARRAY_POINTER 0x845D -#define GL_SECONDARY_COLOR_ARRAY 0x845E -#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD -#define GL_TEXTURE_FILTER_CONTROL 0x8500 -#define GL_TEXTURE_LOD_BIAS 0x8501 -#define GL_INCR_WRAP 0x8507 -#define GL_DECR_WRAP 0x8508 -#define GL_TEXTURE_DEPTH_SIZE 0x884A -#define GL_DEPTH_TEXTURE_MODE 0x884B -#define GL_TEXTURE_COMPARE_MODE 0x884C -#define GL_TEXTURE_COMPARE_FUNC 0x884D -#define GL_COMPARE_R_TO_TEXTURE 0x884E - -typedef void (GLAPIENTRY * PFNGLBLENDCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); -typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTERPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDPROC) (GLdouble coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDVPROC) (const GLdouble *coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFPROC) (GLfloat coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFVPROC) (const GLfloat *coord); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSPROC) (GLenum mode, GLint *first, GLsizei *count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, GLsizei *count, GLenum type, const GLvoid **indices, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVPROC) (GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIVPROC) (GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BPROC) (GLbyte red, GLbyte green, GLbyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BVPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DPROC) (GLdouble red, GLdouble green, GLdouble blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FPROC) (GLfloat red, GLfloat green, GLfloat blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IPROC) (GLint red, GLint green, GLint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SPROC) (GLshort red, GLshort green, GLshort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBPROC) (GLubyte red, GLubyte green, GLubyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBVPROC) (const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIPROC) (GLuint red, GLuint green, GLuint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIVPROC) (const GLuint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USPROC) (GLushort red, GLushort green, GLushort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USVPROC) (const GLushort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVPROC) (const GLdouble *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVPROC) (const GLfloat *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVPROC) (const GLint *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVPROC) (const GLshort *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVPROC) (const GLdouble *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVPROC) (const GLfloat *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVPROC) (const GLint *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVPROC) (const GLshort *p); - -#define glBlendColor GLEW_GET_FUN(__glewBlendColor) -#define glBlendEquation GLEW_GET_FUN(__glewBlendEquation) -#define glBlendFuncSeparate GLEW_GET_FUN(__glewBlendFuncSeparate) -#define glFogCoordPointer GLEW_GET_FUN(__glewFogCoordPointer) -#define glFogCoordd GLEW_GET_FUN(__glewFogCoordd) -#define glFogCoorddv GLEW_GET_FUN(__glewFogCoorddv) -#define glFogCoordf GLEW_GET_FUN(__glewFogCoordf) -#define glFogCoordfv GLEW_GET_FUN(__glewFogCoordfv) -#define glMultiDrawArrays GLEW_GET_FUN(__glewMultiDrawArrays) -#define glMultiDrawElements GLEW_GET_FUN(__glewMultiDrawElements) -#define glPointParameterf GLEW_GET_FUN(__glewPointParameterf) -#define glPointParameterfv GLEW_GET_FUN(__glewPointParameterfv) -#define glPointParameteri GLEW_GET_FUN(__glewPointParameteri) -#define glPointParameteriv GLEW_GET_FUN(__glewPointParameteriv) -#define glSecondaryColor3b GLEW_GET_FUN(__glewSecondaryColor3b) -#define glSecondaryColor3bv GLEW_GET_FUN(__glewSecondaryColor3bv) -#define glSecondaryColor3d GLEW_GET_FUN(__glewSecondaryColor3d) -#define glSecondaryColor3dv GLEW_GET_FUN(__glewSecondaryColor3dv) -#define glSecondaryColor3f GLEW_GET_FUN(__glewSecondaryColor3f) -#define glSecondaryColor3fv GLEW_GET_FUN(__glewSecondaryColor3fv) -#define glSecondaryColor3i GLEW_GET_FUN(__glewSecondaryColor3i) -#define glSecondaryColor3iv GLEW_GET_FUN(__glewSecondaryColor3iv) -#define glSecondaryColor3s GLEW_GET_FUN(__glewSecondaryColor3s) -#define glSecondaryColor3sv GLEW_GET_FUN(__glewSecondaryColor3sv) -#define glSecondaryColor3ub GLEW_GET_FUN(__glewSecondaryColor3ub) -#define glSecondaryColor3ubv GLEW_GET_FUN(__glewSecondaryColor3ubv) -#define glSecondaryColor3ui GLEW_GET_FUN(__glewSecondaryColor3ui) -#define glSecondaryColor3uiv GLEW_GET_FUN(__glewSecondaryColor3uiv) -#define glSecondaryColor3us GLEW_GET_FUN(__glewSecondaryColor3us) -#define glSecondaryColor3usv GLEW_GET_FUN(__glewSecondaryColor3usv) -#define glSecondaryColorPointer GLEW_GET_FUN(__glewSecondaryColorPointer) -#define glWindowPos2d GLEW_GET_FUN(__glewWindowPos2d) -#define glWindowPos2dv GLEW_GET_FUN(__glewWindowPos2dv) -#define glWindowPos2f GLEW_GET_FUN(__glewWindowPos2f) -#define glWindowPos2fv GLEW_GET_FUN(__glewWindowPos2fv) -#define glWindowPos2i GLEW_GET_FUN(__glewWindowPos2i) -#define glWindowPos2iv GLEW_GET_FUN(__glewWindowPos2iv) -#define glWindowPos2s GLEW_GET_FUN(__glewWindowPos2s) -#define glWindowPos2sv GLEW_GET_FUN(__glewWindowPos2sv) -#define glWindowPos3d GLEW_GET_FUN(__glewWindowPos3d) -#define glWindowPos3dv GLEW_GET_FUN(__glewWindowPos3dv) -#define glWindowPos3f GLEW_GET_FUN(__glewWindowPos3f) -#define glWindowPos3fv GLEW_GET_FUN(__glewWindowPos3fv) -#define glWindowPos3i GLEW_GET_FUN(__glewWindowPos3i) -#define glWindowPos3iv GLEW_GET_FUN(__glewWindowPos3iv) -#define glWindowPos3s GLEW_GET_FUN(__glewWindowPos3s) -#define glWindowPos3sv GLEW_GET_FUN(__glewWindowPos3sv) - -#define GLEW_VERSION_1_4 GLEW_GET_VAR(__GLEW_VERSION_1_4) - -#endif /* GL_VERSION_1_4 */ - -/* ----------------------------- GL_VERSION_1_5 ---------------------------- */ - -#ifndef GL_VERSION_1_5 -#define GL_VERSION_1_5 1 - -#define GL_FOG_COORD_SRC GL_FOG_COORDINATE_SOURCE -#define GL_FOG_COORD GL_FOG_COORDINATE -#define GL_FOG_COORD_ARRAY GL_FOG_COORDINATE_ARRAY -#define GL_SRC0_RGB GL_SOURCE0_RGB -#define GL_FOG_COORD_ARRAY_POINTER GL_FOG_COORDINATE_ARRAY_POINTER -#define GL_FOG_COORD_ARRAY_TYPE GL_FOG_COORDINATE_ARRAY_TYPE -#define GL_SRC1_ALPHA GL_SOURCE1_ALPHA -#define GL_CURRENT_FOG_COORD GL_CURRENT_FOG_COORDINATE -#define GL_FOG_COORD_ARRAY_STRIDE GL_FOG_COORDINATE_ARRAY_STRIDE -#define GL_SRC0_ALPHA GL_SOURCE0_ALPHA -#define GL_SRC1_RGB GL_SOURCE1_RGB -#define GL_FOG_COORD_ARRAY_BUFFER_BINDING GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING -#define GL_SRC2_ALPHA GL_SOURCE2_ALPHA -#define GL_SRC2_RGB GL_SOURCE2_RGB -#define GL_BUFFER_SIZE 0x8764 -#define GL_BUFFER_USAGE 0x8765 -#define GL_QUERY_COUNTER_BITS 0x8864 -#define GL_CURRENT_QUERY 0x8865 -#define GL_QUERY_RESULT 0x8866 -#define GL_QUERY_RESULT_AVAILABLE 0x8867 -#define GL_ARRAY_BUFFER 0x8892 -#define GL_ELEMENT_ARRAY_BUFFER 0x8893 -#define GL_ARRAY_BUFFER_BINDING 0x8894 -#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895 -#define GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896 -#define GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897 -#define GL_COLOR_ARRAY_BUFFER_BINDING 0x8898 -#define GL_INDEX_ARRAY_BUFFER_BINDING 0x8899 -#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A -#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING 0x889B -#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING 0x889C -#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING 0x889D -#define GL_WEIGHT_ARRAY_BUFFER_BINDING 0x889E -#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F -#define GL_READ_ONLY 0x88B8 -#define GL_WRITE_ONLY 0x88B9 -#define GL_READ_WRITE 0x88BA -#define GL_BUFFER_ACCESS 0x88BB -#define GL_BUFFER_MAPPED 0x88BC -#define GL_BUFFER_MAP_POINTER 0x88BD -#define GL_STREAM_DRAW 0x88E0 -#define GL_STREAM_READ 0x88E1 -#define GL_STREAM_COPY 0x88E2 -#define GL_STATIC_DRAW 0x88E4 -#define GL_STATIC_READ 0x88E5 -#define GL_STATIC_COPY 0x88E6 -#define GL_DYNAMIC_DRAW 0x88E8 -#define GL_DYNAMIC_READ 0x88E9 -#define GL_DYNAMIC_COPY 0x88EA -#define GL_SAMPLES_PASSED 0x8914 - -typedef ptrdiff_t GLintptr; -typedef ptrdiff_t GLsizeiptr; - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERPROC) (GLenum target, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBUFFERDATAPROC) (GLenum target, GLsizeiptr size, const GLvoid* data, GLenum usage); -typedef void (GLAPIENTRY * PFNGLBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLDELETEBUFFERSPROC) (GLsizei n, const GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLDELETEQUERIESPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDQUERYPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGENBUFFERSPROC) (GLsizei n, GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLGENQUERIESPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPOINTERVPROC) (GLenum target, GLenum pname, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, GLvoid* data); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVPROC) (GLuint id, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERPROC) (GLuint buffer); -typedef GLboolean (GLAPIENTRY * PFNGLISQUERYPROC) (GLuint id); -typedef GLvoid* (GLAPIENTRY * PFNGLMAPBUFFERPROC) (GLenum target, GLenum access); -typedef GLboolean (GLAPIENTRY * PFNGLUNMAPBUFFERPROC) (GLenum target); - -#define glBeginQuery GLEW_GET_FUN(__glewBeginQuery) -#define glBindBuffer GLEW_GET_FUN(__glewBindBuffer) -#define glBufferData GLEW_GET_FUN(__glewBufferData) -#define glBufferSubData GLEW_GET_FUN(__glewBufferSubData) -#define glDeleteBuffers GLEW_GET_FUN(__glewDeleteBuffers) -#define glDeleteQueries GLEW_GET_FUN(__glewDeleteQueries) -#define glEndQuery GLEW_GET_FUN(__glewEndQuery) -#define glGenBuffers GLEW_GET_FUN(__glewGenBuffers) -#define glGenQueries GLEW_GET_FUN(__glewGenQueries) -#define glGetBufferParameteriv GLEW_GET_FUN(__glewGetBufferParameteriv) -#define glGetBufferPointerv GLEW_GET_FUN(__glewGetBufferPointerv) -#define glGetBufferSubData GLEW_GET_FUN(__glewGetBufferSubData) -#define glGetQueryObjectiv GLEW_GET_FUN(__glewGetQueryObjectiv) -#define glGetQueryObjectuiv GLEW_GET_FUN(__glewGetQueryObjectuiv) -#define glGetQueryiv GLEW_GET_FUN(__glewGetQueryiv) -#define glIsBuffer GLEW_GET_FUN(__glewIsBuffer) -#define glIsQuery GLEW_GET_FUN(__glewIsQuery) -#define glMapBuffer GLEW_GET_FUN(__glewMapBuffer) -#define glUnmapBuffer GLEW_GET_FUN(__glewUnmapBuffer) - -#define GLEW_VERSION_1_5 GLEW_GET_VAR(__GLEW_VERSION_1_5) - -#endif /* GL_VERSION_1_5 */ - -/* ----------------------------- GL_VERSION_2_0 ---------------------------- */ - -#ifndef GL_VERSION_2_0 -#define GL_VERSION_2_0 1 - -#define GL_BLEND_EQUATION_RGB GL_BLEND_EQUATION -#define GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622 -#define GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623 -#define GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624 -#define GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625 -#define GL_CURRENT_VERTEX_ATTRIB 0x8626 -#define GL_VERTEX_PROGRAM_POINT_SIZE 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 -#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 -#define GL_STENCIL_BACK_FUNC 0x8800 -#define GL_STENCIL_BACK_FAIL 0x8801 -#define GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802 -#define GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803 -#define GL_MAX_DRAW_BUFFERS 0x8824 -#define GL_DRAW_BUFFER0 0x8825 -#define GL_DRAW_BUFFER1 0x8826 -#define GL_DRAW_BUFFER2 0x8827 -#define GL_DRAW_BUFFER3 0x8828 -#define GL_DRAW_BUFFER4 0x8829 -#define GL_DRAW_BUFFER5 0x882A -#define GL_DRAW_BUFFER6 0x882B -#define GL_DRAW_BUFFER7 0x882C -#define GL_DRAW_BUFFER8 0x882D -#define GL_DRAW_BUFFER9 0x882E -#define GL_DRAW_BUFFER10 0x882F -#define GL_DRAW_BUFFER11 0x8830 -#define GL_DRAW_BUFFER12 0x8831 -#define GL_DRAW_BUFFER13 0x8832 -#define GL_DRAW_BUFFER14 0x8833 -#define GL_DRAW_BUFFER15 0x8834 -#define GL_BLEND_EQUATION_ALPHA 0x883D -#define GL_POINT_SPRITE 0x8861 -#define GL_COORD_REPLACE 0x8862 -#define GL_MAX_VERTEX_ATTRIBS 0x8869 -#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A -#define GL_MAX_TEXTURE_COORDS 0x8871 -#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 -#define GL_FRAGMENT_SHADER 0x8B30 -#define GL_VERTEX_SHADER 0x8B31 -#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49 -#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A -#define GL_MAX_VARYING_FLOATS 0x8B4B -#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C -#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D -#define GL_SHADER_TYPE 0x8B4F -#define GL_FLOAT_VEC2 0x8B50 -#define GL_FLOAT_VEC3 0x8B51 -#define GL_FLOAT_VEC4 0x8B52 -#define GL_INT_VEC2 0x8B53 -#define GL_INT_VEC3 0x8B54 -#define GL_INT_VEC4 0x8B55 -#define GL_BOOL 0x8B56 -#define GL_BOOL_VEC2 0x8B57 -#define GL_BOOL_VEC3 0x8B58 -#define GL_BOOL_VEC4 0x8B59 -#define GL_FLOAT_MAT2 0x8B5A -#define GL_FLOAT_MAT3 0x8B5B -#define GL_FLOAT_MAT4 0x8B5C -#define GL_SAMPLER_1D 0x8B5D -#define GL_SAMPLER_2D 0x8B5E -#define GL_SAMPLER_3D 0x8B5F -#define GL_SAMPLER_CUBE 0x8B60 -#define GL_SAMPLER_1D_SHADOW 0x8B61 -#define GL_SAMPLER_2D_SHADOW 0x8B62 -#define GL_DELETE_STATUS 0x8B80 -#define GL_COMPILE_STATUS 0x8B81 -#define GL_LINK_STATUS 0x8B82 -#define GL_VALIDATE_STATUS 0x8B83 -#define GL_INFO_LOG_LENGTH 0x8B84 -#define GL_ATTACHED_SHADERS 0x8B85 -#define GL_ACTIVE_UNIFORMS 0x8B86 -#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 -#define GL_SHADER_SOURCE_LENGTH 0x8B88 -#define GL_ACTIVE_ATTRIBUTES 0x8B89 -#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A -#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B -#define GL_SHADING_LANGUAGE_VERSION 0x8B8C -#define GL_CURRENT_PROGRAM 0x8B8D -#define GL_POINT_SPRITE_COORD_ORIGIN 0x8CA0 -#define GL_LOWER_LEFT 0x8CA1 -#define GL_UPPER_LEFT 0x8CA2 -#define GL_STENCIL_BACK_REF 0x8CA3 -#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4 -#define GL_STENCIL_BACK_WRITEMASK 0x8CA5 - -typedef void (GLAPIENTRY * PFNGLATTACHSHADERPROC) (GLuint program, GLuint shader); -typedef void (GLAPIENTRY * PFNGLBINDATTRIBLOCATIONPROC) (GLuint program, GLuint index, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEPROC) (GLenum, GLenum); -typedef void (GLAPIENTRY * PFNGLCOMPILESHADERPROC) (GLuint shader); -typedef GLuint (GLAPIENTRY * PFNGLCREATEPROGRAMPROC) (void); -typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROC) (GLenum type); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLDELETESHADERPROC) (GLuint shader); -typedef void (GLAPIENTRY * PFNGLDETACHSHADERPROC) (GLuint program, GLuint shader); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBARRAYPROC) (GLuint); -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSPROC) (GLsizei n, const GLenum* bufs); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBARRAYPROC) (GLuint); -typedef void (GLAPIENTRY * PFNGLGETACTIVEATTRIBPROC) (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMPROC) (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETATTACHEDSHADERSPROC) (GLuint program, GLsizei maxCount, GLsizei* count, GLuint* shaders); -typedef GLint (GLAPIENTRY * PFNGLGETATTRIBLOCATIONPROC) (GLuint program, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMINFOLOGPROC) (GLuint program, GLsizei bufSize, GLsizei* length, GLchar* infoLog); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVPROC) (GLuint program, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETSHADERINFOLOGPROC) (GLuint shader, GLsizei bufSize, GLsizei* length, GLchar* infoLog); -typedef void (GLAPIENTRY * PFNGLGETSHADERSOURCEPROC) (GLuint obj, GLsizei maxLength, GLsizei* length, GLchar* source); -typedef void (GLAPIENTRY * PFNGLGETSHADERIVPROC) (GLuint shader, GLenum pname, GLint* param); -typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMLOCATIONPROC) (GLuint program, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMFVPROC) (GLuint program, GLint location, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMIVPROC) (GLuint program, GLint location, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVPROC) (GLuint, GLenum, GLvoid**); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVPROC) (GLuint, GLenum, GLdouble*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVPROC) (GLuint, GLenum, GLfloat*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVPROC) (GLuint, GLenum, GLint*); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMPROC) (GLuint program); -typedef GLboolean (GLAPIENTRY * PFNGLISSHADERPROC) (GLuint shader); -typedef void (GLAPIENTRY * PFNGLLINKPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar** strings, const GLint* lengths); -typedef void (GLAPIENTRY * PFNGLSTENCILFUNCSEPARATEPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILMASKSEPARATEPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLSTENCILOPSEPARATEPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FPROC) (GLint location, GLfloat v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IPROC) (GLint location, GLint v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FPROC) (GLint location, GLfloat v0, GLfloat v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IPROC) (GLint location, GLint v0, GLint v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IPROC) (GLint location, GLint v0, GLint v1, GLint v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUSEPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FPROC) (GLuint index, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SPROC) (GLuint index, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SPROC) (GLuint index, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NBVPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NIVPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NSVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBVPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUIVPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUSVPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4BVPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4IVPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UIVPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4USVPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid* pointer); - -#define glAttachShader GLEW_GET_FUN(__glewAttachShader) -#define glBindAttribLocation GLEW_GET_FUN(__glewBindAttribLocation) -#define glBlendEquationSeparate GLEW_GET_FUN(__glewBlendEquationSeparate) -#define glCompileShader GLEW_GET_FUN(__glewCompileShader) -#define glCreateProgram GLEW_GET_FUN(__glewCreateProgram) -#define glCreateShader GLEW_GET_FUN(__glewCreateShader) -#define glDeleteProgram GLEW_GET_FUN(__glewDeleteProgram) -#define glDeleteShader GLEW_GET_FUN(__glewDeleteShader) -#define glDetachShader GLEW_GET_FUN(__glewDetachShader) -#define glDisableVertexAttribArray GLEW_GET_FUN(__glewDisableVertexAttribArray) -#define glDrawBuffers GLEW_GET_FUN(__glewDrawBuffers) -#define glEnableVertexAttribArray GLEW_GET_FUN(__glewEnableVertexAttribArray) -#define glGetActiveAttrib GLEW_GET_FUN(__glewGetActiveAttrib) -#define glGetActiveUniform GLEW_GET_FUN(__glewGetActiveUniform) -#define glGetAttachedShaders GLEW_GET_FUN(__glewGetAttachedShaders) -#define glGetAttribLocation GLEW_GET_FUN(__glewGetAttribLocation) -#define glGetProgramInfoLog GLEW_GET_FUN(__glewGetProgramInfoLog) -#define glGetProgramiv GLEW_GET_FUN(__glewGetProgramiv) -#define glGetShaderInfoLog GLEW_GET_FUN(__glewGetShaderInfoLog) -#define glGetShaderSource GLEW_GET_FUN(__glewGetShaderSource) -#define glGetShaderiv GLEW_GET_FUN(__glewGetShaderiv) -#define glGetUniformLocation GLEW_GET_FUN(__glewGetUniformLocation) -#define glGetUniformfv GLEW_GET_FUN(__glewGetUniformfv) -#define glGetUniformiv GLEW_GET_FUN(__glewGetUniformiv) -#define glGetVertexAttribPointerv GLEW_GET_FUN(__glewGetVertexAttribPointerv) -#define glGetVertexAttribdv GLEW_GET_FUN(__glewGetVertexAttribdv) -#define glGetVertexAttribfv GLEW_GET_FUN(__glewGetVertexAttribfv) -#define glGetVertexAttribiv GLEW_GET_FUN(__glewGetVertexAttribiv) -#define glIsProgram GLEW_GET_FUN(__glewIsProgram) -#define glIsShader GLEW_GET_FUN(__glewIsShader) -#define glLinkProgram GLEW_GET_FUN(__glewLinkProgram) -#define glShaderSource GLEW_GET_FUN(__glewShaderSource) -#define glStencilFuncSeparate GLEW_GET_FUN(__glewStencilFuncSeparate) -#define glStencilMaskSeparate GLEW_GET_FUN(__glewStencilMaskSeparate) -#define glStencilOpSeparate GLEW_GET_FUN(__glewStencilOpSeparate) -#define glUniform1f GLEW_GET_FUN(__glewUniform1f) -#define glUniform1fv GLEW_GET_FUN(__glewUniform1fv) -#define glUniform1i GLEW_GET_FUN(__glewUniform1i) -#define glUniform1iv GLEW_GET_FUN(__glewUniform1iv) -#define glUniform2f GLEW_GET_FUN(__glewUniform2f) -#define glUniform2fv GLEW_GET_FUN(__glewUniform2fv) -#define glUniform2i GLEW_GET_FUN(__glewUniform2i) -#define glUniform2iv GLEW_GET_FUN(__glewUniform2iv) -#define glUniform3f GLEW_GET_FUN(__glewUniform3f) -#define glUniform3fv GLEW_GET_FUN(__glewUniform3fv) -#define glUniform3i GLEW_GET_FUN(__glewUniform3i) -#define glUniform3iv GLEW_GET_FUN(__glewUniform3iv) -#define glUniform4f GLEW_GET_FUN(__glewUniform4f) -#define glUniform4fv GLEW_GET_FUN(__glewUniform4fv) -#define glUniform4i GLEW_GET_FUN(__glewUniform4i) -#define glUniform4iv GLEW_GET_FUN(__glewUniform4iv) -#define glUniformMatrix2fv GLEW_GET_FUN(__glewUniformMatrix2fv) -#define glUniformMatrix3fv GLEW_GET_FUN(__glewUniformMatrix3fv) -#define glUniformMatrix4fv GLEW_GET_FUN(__glewUniformMatrix4fv) -#define glUseProgram GLEW_GET_FUN(__glewUseProgram) -#define glValidateProgram GLEW_GET_FUN(__glewValidateProgram) -#define glVertexAttrib1d GLEW_GET_FUN(__glewVertexAttrib1d) -#define glVertexAttrib1dv GLEW_GET_FUN(__glewVertexAttrib1dv) -#define glVertexAttrib1f GLEW_GET_FUN(__glewVertexAttrib1f) -#define glVertexAttrib1fv GLEW_GET_FUN(__glewVertexAttrib1fv) -#define glVertexAttrib1s GLEW_GET_FUN(__glewVertexAttrib1s) -#define glVertexAttrib1sv GLEW_GET_FUN(__glewVertexAttrib1sv) -#define glVertexAttrib2d GLEW_GET_FUN(__glewVertexAttrib2d) -#define glVertexAttrib2dv GLEW_GET_FUN(__glewVertexAttrib2dv) -#define glVertexAttrib2f GLEW_GET_FUN(__glewVertexAttrib2f) -#define glVertexAttrib2fv GLEW_GET_FUN(__glewVertexAttrib2fv) -#define glVertexAttrib2s GLEW_GET_FUN(__glewVertexAttrib2s) -#define glVertexAttrib2sv GLEW_GET_FUN(__glewVertexAttrib2sv) -#define glVertexAttrib3d GLEW_GET_FUN(__glewVertexAttrib3d) -#define glVertexAttrib3dv GLEW_GET_FUN(__glewVertexAttrib3dv) -#define glVertexAttrib3f GLEW_GET_FUN(__glewVertexAttrib3f) -#define glVertexAttrib3fv GLEW_GET_FUN(__glewVertexAttrib3fv) -#define glVertexAttrib3s GLEW_GET_FUN(__glewVertexAttrib3s) -#define glVertexAttrib3sv GLEW_GET_FUN(__glewVertexAttrib3sv) -#define glVertexAttrib4Nbv GLEW_GET_FUN(__glewVertexAttrib4Nbv) -#define glVertexAttrib4Niv GLEW_GET_FUN(__glewVertexAttrib4Niv) -#define glVertexAttrib4Nsv GLEW_GET_FUN(__glewVertexAttrib4Nsv) -#define glVertexAttrib4Nub GLEW_GET_FUN(__glewVertexAttrib4Nub) -#define glVertexAttrib4Nubv GLEW_GET_FUN(__glewVertexAttrib4Nubv) -#define glVertexAttrib4Nuiv GLEW_GET_FUN(__glewVertexAttrib4Nuiv) -#define glVertexAttrib4Nusv GLEW_GET_FUN(__glewVertexAttrib4Nusv) -#define glVertexAttrib4bv GLEW_GET_FUN(__glewVertexAttrib4bv) -#define glVertexAttrib4d GLEW_GET_FUN(__glewVertexAttrib4d) -#define glVertexAttrib4dv GLEW_GET_FUN(__glewVertexAttrib4dv) -#define glVertexAttrib4f GLEW_GET_FUN(__glewVertexAttrib4f) -#define glVertexAttrib4fv GLEW_GET_FUN(__glewVertexAttrib4fv) -#define glVertexAttrib4iv GLEW_GET_FUN(__glewVertexAttrib4iv) -#define glVertexAttrib4s GLEW_GET_FUN(__glewVertexAttrib4s) -#define glVertexAttrib4sv GLEW_GET_FUN(__glewVertexAttrib4sv) -#define glVertexAttrib4ubv GLEW_GET_FUN(__glewVertexAttrib4ubv) -#define glVertexAttrib4uiv GLEW_GET_FUN(__glewVertexAttrib4uiv) -#define glVertexAttrib4usv GLEW_GET_FUN(__glewVertexAttrib4usv) -#define glVertexAttribPointer GLEW_GET_FUN(__glewVertexAttribPointer) - -#define GLEW_VERSION_2_0 GLEW_GET_VAR(__GLEW_VERSION_2_0) - -#endif /* GL_VERSION_2_0 */ - -/* ----------------------------- GL_VERSION_2_1 ---------------------------- */ - -#ifndef GL_VERSION_2_1 -#define GL_VERSION_2_1 1 - -#define GL_CURRENT_RASTER_SECONDARY_COLOR 0x845F -#define GL_PIXEL_PACK_BUFFER 0x88EB -#define GL_PIXEL_UNPACK_BUFFER 0x88EC -#define GL_PIXEL_PACK_BUFFER_BINDING 0x88ED -#define GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF -#define GL_FLOAT_MAT2x3 0x8B65 -#define GL_FLOAT_MAT2x4 0x8B66 -#define GL_FLOAT_MAT3x2 0x8B67 -#define GL_FLOAT_MAT3x4 0x8B68 -#define GL_FLOAT_MAT4x2 0x8B69 -#define GL_FLOAT_MAT4x3 0x8B6A -#define GL_SRGB 0x8C40 -#define GL_SRGB8 0x8C41 -#define GL_SRGB_ALPHA 0x8C42 -#define GL_SRGB8_ALPHA8 0x8C43 -#define GL_SLUMINANCE_ALPHA 0x8C44 -#define GL_SLUMINANCE8_ALPHA8 0x8C45 -#define GL_SLUMINANCE 0x8C46 -#define GL_SLUMINANCE8 0x8C47 -#define GL_COMPRESSED_SRGB 0x8C48 -#define GL_COMPRESSED_SRGB_ALPHA 0x8C49 -#define GL_COMPRESSED_SLUMINANCE 0x8C4A -#define GL_COMPRESSED_SLUMINANCE_ALPHA 0x8C4B - -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); - -#define glUniformMatrix2x3fv GLEW_GET_FUN(__glewUniformMatrix2x3fv) -#define glUniformMatrix2x4fv GLEW_GET_FUN(__glewUniformMatrix2x4fv) -#define glUniformMatrix3x2fv GLEW_GET_FUN(__glewUniformMatrix3x2fv) -#define glUniformMatrix3x4fv GLEW_GET_FUN(__glewUniformMatrix3x4fv) -#define glUniformMatrix4x2fv GLEW_GET_FUN(__glewUniformMatrix4x2fv) -#define glUniformMatrix4x3fv GLEW_GET_FUN(__glewUniformMatrix4x3fv) - -#define GLEW_VERSION_2_1 GLEW_GET_VAR(__GLEW_VERSION_2_1) - -#endif /* GL_VERSION_2_1 */ - -/* ----------------------------- GL_VERSION_3_0 ---------------------------- */ - -#ifndef GL_VERSION_3_0 -#define GL_VERSION_3_0 1 - -#define GL_MAX_CLIP_DISTANCES GL_MAX_CLIP_PLANES -#define GL_CLIP_DISTANCE5 GL_CLIP_PLANE5 -#define GL_CLIP_DISTANCE1 GL_CLIP_PLANE1 -#define GL_CLIP_DISTANCE3 GL_CLIP_PLANE3 -#define GL_COMPARE_REF_TO_TEXTURE GL_COMPARE_R_TO_TEXTURE_ARB -#define GL_CLIP_DISTANCE0 GL_CLIP_PLANE0 -#define GL_CLIP_DISTANCE4 GL_CLIP_PLANE4 -#define GL_CLIP_DISTANCE2 GL_CLIP_PLANE2 -#define GL_MAX_VARYING_COMPONENTS GL_MAX_VARYING_FLOATS -#define GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x0001 -#define GL_MAJOR_VERSION 0x821B -#define GL_MINOR_VERSION 0x821C -#define GL_NUM_EXTENSIONS 0x821D -#define GL_CONTEXT_FLAGS 0x821E -#define GL_DEPTH_BUFFER 0x8223 -#define GL_STENCIL_BUFFER 0x8224 -#define GL_COMPRESSED_RED 0x8225 -#define GL_COMPRESSED_RG 0x8226 -#define GL_RGBA32F 0x8814 -#define GL_RGB32F 0x8815 -#define GL_RGBA16F 0x881A -#define GL_RGB16F 0x881B -#define GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD -#define GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF -#define GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904 -#define GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905 -#define GL_CLAMP_VERTEX_COLOR 0x891A -#define GL_CLAMP_FRAGMENT_COLOR 0x891B -#define GL_CLAMP_READ_COLOR 0x891C -#define GL_FIXED_ONLY 0x891D -#define GL_TEXTURE_RED_TYPE 0x8C10 -#define GL_TEXTURE_GREEN_TYPE 0x8C11 -#define GL_TEXTURE_BLUE_TYPE 0x8C12 -#define GL_TEXTURE_ALPHA_TYPE 0x8C13 -#define GL_TEXTURE_LUMINANCE_TYPE 0x8C14 -#define GL_TEXTURE_INTENSITY_TYPE 0x8C15 -#define GL_TEXTURE_DEPTH_TYPE 0x8C16 -#define GL_UNSIGNED_NORMALIZED 0x8C17 -#define GL_TEXTURE_1D_ARRAY 0x8C18 -#define GL_PROXY_TEXTURE_1D_ARRAY 0x8C19 -#define GL_TEXTURE_2D_ARRAY 0x8C1A -#define GL_PROXY_TEXTURE_2D_ARRAY 0x8C1B -#define GL_TEXTURE_BINDING_1D_ARRAY 0x8C1C -#define GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D -#define GL_R11F_G11F_B10F 0x8C3A -#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B -#define GL_RGB9_E5 0x8C3D -#define GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E -#define GL_TEXTURE_SHARED_SIZE 0x8C3F -#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76 -#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80 -#define GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83 -#define GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84 -#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85 -#define GL_PRIMITIVES_GENERATED 0x8C87 -#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88 -#define GL_RASTERIZER_DISCARD 0x8C89 -#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B -#define GL_INTERLEAVED_ATTRIBS 0x8C8C -#define GL_SEPARATE_ATTRIBS 0x8C8D -#define GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E -#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F -#define GL_RGBA32UI 0x8D70 -#define GL_RGB32UI 0x8D71 -#define GL_RGBA16UI 0x8D76 -#define GL_RGB16UI 0x8D77 -#define GL_RGBA8UI 0x8D7C -#define GL_RGB8UI 0x8D7D -#define GL_RGBA32I 0x8D82 -#define GL_RGB32I 0x8D83 -#define GL_RGBA16I 0x8D88 -#define GL_RGB16I 0x8D89 -#define GL_RGBA8I 0x8D8E -#define GL_RGB8I 0x8D8F -#define GL_RED_INTEGER 0x8D94 -#define GL_GREEN_INTEGER 0x8D95 -#define GL_BLUE_INTEGER 0x8D96 -#define GL_ALPHA_INTEGER 0x8D97 -#define GL_RGB_INTEGER 0x8D98 -#define GL_RGBA_INTEGER 0x8D99 -#define GL_BGR_INTEGER 0x8D9A -#define GL_BGRA_INTEGER 0x8D9B -#define GL_SAMPLER_1D_ARRAY 0x8DC0 -#define GL_SAMPLER_2D_ARRAY 0x8DC1 -#define GL_SAMPLER_1D_ARRAY_SHADOW 0x8DC3 -#define GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4 -#define GL_SAMPLER_CUBE_SHADOW 0x8DC5 -#define GL_UNSIGNED_INT_VEC2 0x8DC6 -#define GL_UNSIGNED_INT_VEC3 0x8DC7 -#define GL_UNSIGNED_INT_VEC4 0x8DC8 -#define GL_INT_SAMPLER_1D 0x8DC9 -#define GL_INT_SAMPLER_2D 0x8DCA -#define GL_INT_SAMPLER_3D 0x8DCB -#define GL_INT_SAMPLER_CUBE 0x8DCC -#define GL_INT_SAMPLER_1D_ARRAY 0x8DCE -#define GL_INT_SAMPLER_2D_ARRAY 0x8DCF -#define GL_UNSIGNED_INT_SAMPLER_1D 0x8DD1 -#define GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2 -#define GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3 -#define GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4 -#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY 0x8DD6 -#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7 -#define GL_QUERY_WAIT 0x8E13 -#define GL_QUERY_NO_WAIT 0x8E14 -#define GL_QUERY_BY_REGION_WAIT 0x8E15 -#define GL_QUERY_BY_REGION_NO_WAIT 0x8E16 - -typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERPROC) (GLuint, GLenum); -typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKPROC) (GLenum); -typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONPROC) (GLuint, GLuint, const GLchar*); -typedef void (GLAPIENTRY * PFNGLCLAMPCOLORPROC) (GLenum, GLenum); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERFIPROC) (GLenum, GLint, GLfloat, GLint); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERFVPROC) (GLenum, GLint, const GLfloat*); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERIVPROC) (GLenum, GLint, const GLint*); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERUIVPROC) (GLenum, GLint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLCOLORMASKIPROC) (GLuint, GLboolean, GLboolean, GLboolean, GLboolean); -typedef void (GLAPIENTRY * PFNGLDISABLEIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLENABLEIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERPROC) (void); -typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETBOOLEANI_VPROC) (GLenum, GLuint, GLboolean*); -typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATALOCATIONPROC) (GLuint, const GLchar*); -typedef const GLubyte* (GLAPIENTRY * PFNGLGETSTRINGIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIIVPROC) (GLenum, GLenum, GLint*); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIUIVPROC) (GLenum, GLenum, GLuint*); -typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGPROC) (GLuint, GLuint, GLsizei, GLsizei *, GLsizei *, GLenum *, GLchar *); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMUIVPROC) (GLuint, GLint, GLuint*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIIVPROC) (GLuint, GLenum, GLint*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIUIVPROC) (GLuint, GLenum, GLuint*); -typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIIVPROC) (GLenum, GLenum, const GLint*); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIUIVPROC) (GLenum, GLenum, const GLuint*); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSPROC) (GLuint, GLsizei, const GLchar **, GLenum); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIPROC) (GLint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIPROC) (GLint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIPROC) (GLint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIPROC) (GLint, GLuint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IPROC) (GLuint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIPROC) (GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IPROC) (GLuint, GLint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIPROC) (GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IPROC) (GLuint, GLint, GLint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIPROC) (GLuint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4BVPROC) (GLuint, const GLbyte*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IPROC) (GLuint, GLint, GLint, GLint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4SVPROC) (GLuint, const GLshort*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UBVPROC) (GLuint, const GLubyte*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIPROC) (GLuint, GLuint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4USVPROC) (GLuint, const GLushort*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIPOINTERPROC) (GLuint, GLint, GLenum, GLsizei, const GLvoid*); - -#define glBeginConditionalRender GLEW_GET_FUN(__glewBeginConditionalRender) -#define glBeginTransformFeedback GLEW_GET_FUN(__glewBeginTransformFeedback) -#define glBindFragDataLocation GLEW_GET_FUN(__glewBindFragDataLocation) -#define glClampColor GLEW_GET_FUN(__glewClampColor) -#define glClearBufferfi GLEW_GET_FUN(__glewClearBufferfi) -#define glClearBufferfv GLEW_GET_FUN(__glewClearBufferfv) -#define glClearBufferiv GLEW_GET_FUN(__glewClearBufferiv) -#define glClearBufferuiv GLEW_GET_FUN(__glewClearBufferuiv) -#define glColorMaski GLEW_GET_FUN(__glewColorMaski) -#define glDisablei GLEW_GET_FUN(__glewDisablei) -#define glEnablei GLEW_GET_FUN(__glewEnablei) -#define glEndConditionalRender GLEW_GET_FUN(__glewEndConditionalRender) -#define glEndTransformFeedback GLEW_GET_FUN(__glewEndTransformFeedback) -#define glGetBooleani_v GLEW_GET_FUN(__glewGetBooleani_v) -#define glGetFragDataLocation GLEW_GET_FUN(__glewGetFragDataLocation) -#define glGetStringi GLEW_GET_FUN(__glewGetStringi) -#define glGetTexParameterIiv GLEW_GET_FUN(__glewGetTexParameterIiv) -#define glGetTexParameterIuiv GLEW_GET_FUN(__glewGetTexParameterIuiv) -#define glGetTransformFeedbackVarying GLEW_GET_FUN(__glewGetTransformFeedbackVarying) -#define glGetUniformuiv GLEW_GET_FUN(__glewGetUniformuiv) -#define glGetVertexAttribIiv GLEW_GET_FUN(__glewGetVertexAttribIiv) -#define glGetVertexAttribIuiv GLEW_GET_FUN(__glewGetVertexAttribIuiv) -#define glIsEnabledi GLEW_GET_FUN(__glewIsEnabledi) -#define glTexParameterIiv GLEW_GET_FUN(__glewTexParameterIiv) -#define glTexParameterIuiv GLEW_GET_FUN(__glewTexParameterIuiv) -#define glTransformFeedbackVaryings GLEW_GET_FUN(__glewTransformFeedbackVaryings) -#define glUniform1ui GLEW_GET_FUN(__glewUniform1ui) -#define glUniform1uiv GLEW_GET_FUN(__glewUniform1uiv) -#define glUniform2ui GLEW_GET_FUN(__glewUniform2ui) -#define glUniform2uiv GLEW_GET_FUN(__glewUniform2uiv) -#define glUniform3ui GLEW_GET_FUN(__glewUniform3ui) -#define glUniform3uiv GLEW_GET_FUN(__glewUniform3uiv) -#define glUniform4ui GLEW_GET_FUN(__glewUniform4ui) -#define glUniform4uiv GLEW_GET_FUN(__glewUniform4uiv) -#define glVertexAttribI1i GLEW_GET_FUN(__glewVertexAttribI1i) -#define glVertexAttribI1iv GLEW_GET_FUN(__glewVertexAttribI1iv) -#define glVertexAttribI1ui GLEW_GET_FUN(__glewVertexAttribI1ui) -#define glVertexAttribI1uiv GLEW_GET_FUN(__glewVertexAttribI1uiv) -#define glVertexAttribI2i GLEW_GET_FUN(__glewVertexAttribI2i) -#define glVertexAttribI2iv GLEW_GET_FUN(__glewVertexAttribI2iv) -#define glVertexAttribI2ui GLEW_GET_FUN(__glewVertexAttribI2ui) -#define glVertexAttribI2uiv GLEW_GET_FUN(__glewVertexAttribI2uiv) -#define glVertexAttribI3i GLEW_GET_FUN(__glewVertexAttribI3i) -#define glVertexAttribI3iv GLEW_GET_FUN(__glewVertexAttribI3iv) -#define glVertexAttribI3ui GLEW_GET_FUN(__glewVertexAttribI3ui) -#define glVertexAttribI3uiv GLEW_GET_FUN(__glewVertexAttribI3uiv) -#define glVertexAttribI4bv GLEW_GET_FUN(__glewVertexAttribI4bv) -#define glVertexAttribI4i GLEW_GET_FUN(__glewVertexAttribI4i) -#define glVertexAttribI4iv GLEW_GET_FUN(__glewVertexAttribI4iv) -#define glVertexAttribI4sv GLEW_GET_FUN(__glewVertexAttribI4sv) -#define glVertexAttribI4ubv GLEW_GET_FUN(__glewVertexAttribI4ubv) -#define glVertexAttribI4ui GLEW_GET_FUN(__glewVertexAttribI4ui) -#define glVertexAttribI4uiv GLEW_GET_FUN(__glewVertexAttribI4uiv) -#define glVertexAttribI4usv GLEW_GET_FUN(__glewVertexAttribI4usv) -#define glVertexAttribIPointer GLEW_GET_FUN(__glewVertexAttribIPointer) - -#define GLEW_VERSION_3_0 GLEW_GET_VAR(__GLEW_VERSION_3_0) - -#endif /* GL_VERSION_3_0 */ - -/* ----------------------------- GL_VERSION_3_1 ---------------------------- */ - -#ifndef GL_VERSION_3_1 -#define GL_VERSION_3_1 1 - -#define GL_TEXTURE_RECTANGLE 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE 0x84F8 -#define GL_SAMPLER_2D_RECT 0x8B63 -#define GL_SAMPLER_2D_RECT_SHADOW 0x8B64 -#define GL_TEXTURE_BUFFER 0x8C2A -#define GL_MAX_TEXTURE_BUFFER_SIZE 0x8C2B -#define GL_TEXTURE_BINDING_BUFFER 0x8C2C -#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING 0x8C2D -#define GL_TEXTURE_BUFFER_FORMAT 0x8C2E -#define GL_SAMPLER_BUFFER 0x8DC2 -#define GL_INT_SAMPLER_2D_RECT 0x8DCD -#define GL_INT_SAMPLER_BUFFER 0x8DD0 -#define GL_UNSIGNED_INT_SAMPLER_2D_RECT 0x8DD5 -#define GL_UNSIGNED_INT_SAMPLER_BUFFER 0x8DD8 -#define GL_RED_SNORM 0x8F90 -#define GL_RG_SNORM 0x8F91 -#define GL_RGB_SNORM 0x8F92 -#define GL_RGBA_SNORM 0x8F93 -#define GL_R8_SNORM 0x8F94 -#define GL_RG8_SNORM 0x8F95 -#define GL_RGB8_SNORM 0x8F96 -#define GL_RGBA8_SNORM 0x8F97 -#define GL_R16_SNORM 0x8F98 -#define GL_RG16_SNORM 0x8F99 -#define GL_RGB16_SNORM 0x8F9A -#define GL_RGBA16_SNORM 0x8F9B -#define GL_SIGNED_NORMALIZED 0x8F9C -#define GL_PRIMITIVE_RESTART 0x8F9D -#define GL_PRIMITIVE_RESTART_INDEX 0x8F9E -#define GL_BUFFER_ACCESS_FLAGS 0x911F -#define GL_BUFFER_MAP_LENGTH 0x9120 -#define GL_BUFFER_MAP_OFFSET 0x9121 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDPROC) (GLenum, GLint, GLsizei, GLsizei); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDPROC) (GLenum, GLsizei, GLenum, const GLvoid*, GLsizei); -typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTINDEXPROC) (GLuint); -typedef void (GLAPIENTRY * PFNGLTEXBUFFERPROC) (GLenum, GLenum, GLuint); - -#define glDrawArraysInstanced GLEW_GET_FUN(__glewDrawArraysInstanced) -#define glDrawElementsInstanced GLEW_GET_FUN(__glewDrawElementsInstanced) -#define glPrimitiveRestartIndex GLEW_GET_FUN(__glewPrimitiveRestartIndex) -#define glTexBuffer GLEW_GET_FUN(__glewTexBuffer) - -#define GLEW_VERSION_3_1 GLEW_GET_VAR(__GLEW_VERSION_3_1) - -#endif /* GL_VERSION_3_1 */ - -/* ----------------------------- GL_VERSION_3_2 ---------------------------- */ - -#ifndef GL_VERSION_3_2 -#define GL_VERSION_3_2 1 - -#define GL_CONTEXT_CORE_PROFILE_BIT 0x00000001 -#define GL_CONTEXT_COMPATIBILITY_PROFILE_BIT 0x00000002 -#define GL_LINES_ADJACENCY 0x000A -#define GL_LINE_STRIP_ADJACENCY 0x000B -#define GL_TRIANGLES_ADJACENCY 0x000C -#define GL_TRIANGLE_STRIP_ADJACENCY 0x000D -#define GL_PROGRAM_POINT_SIZE 0x8642 -#define GL_GEOMETRY_VERTICES_OUT 0x8916 -#define GL_GEOMETRY_INPUT_TYPE 0x8917 -#define GL_GEOMETRY_OUTPUT_TYPE 0x8918 -#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS 0x8C29 -#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED 0x8DA7 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS 0x8DA8 -#define GL_GEOMETRY_SHADER 0x8DD9 -#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS 0x8DDF -#define GL_MAX_GEOMETRY_OUTPUT_VERTICES 0x8DE0 -#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS 0x8DE1 -#define GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122 -#define GL_MAX_GEOMETRY_INPUT_COMPONENTS 0x9123 -#define GL_MAX_GEOMETRY_OUTPUT_COMPONENTS 0x9124 -#define GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125 -#define GL_CONTEXT_PROFILE_MASK 0x9126 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREPROC) (GLenum, GLenum, GLuint, GLint); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERI64VPROC) (GLenum, GLenum, GLint64 *); -typedef void (GLAPIENTRY * PFNGLGETINTEGER64I_VPROC) (GLenum, GLuint, GLint64 *); - -#define glFramebufferTexture GLEW_GET_FUN(__glewFramebufferTexture) -#define glGetBufferParameteri64v GLEW_GET_FUN(__glewGetBufferParameteri64v) -#define glGetInteger64i_v GLEW_GET_FUN(__glewGetInteger64i_v) - -#define GLEW_VERSION_3_2 GLEW_GET_VAR(__GLEW_VERSION_3_2) - -#endif /* GL_VERSION_3_2 */ - -/* ----------------------------- GL_VERSION_3_3 ---------------------------- */ - -#ifndef GL_VERSION_3_3 -#define GL_VERSION_3_3 1 - -#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE -#define GL_ANY_SAMPLES_PASSED 0x8C2F -#define GL_TEXTURE_SWIZZLE_R 0x8E42 -#define GL_TEXTURE_SWIZZLE_G 0x8E43 -#define GL_TEXTURE_SWIZZLE_B 0x8E44 -#define GL_TEXTURE_SWIZZLE_A 0x8E45 -#define GL_TEXTURE_SWIZZLE_RGBA 0x8E46 -#define GL_RGB10_A2UI 0x906F - -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBDIVISORPROC) (GLuint index, GLuint divisor); - -#define glVertexAttribDivisor GLEW_GET_FUN(__glewVertexAttribDivisor) - -#define GLEW_VERSION_3_3 GLEW_GET_VAR(__GLEW_VERSION_3_3) - -#endif /* GL_VERSION_3_3 */ - -/* ----------------------------- GL_VERSION_4_0 ---------------------------- */ - -#ifndef GL_VERSION_4_0 -#define GL_VERSION_4_0 1 - -#define GL_GEOMETRY_SHADER_INVOCATIONS 0x887F -#define GL_SAMPLE_SHADING 0x8C36 -#define GL_MIN_SAMPLE_SHADING_VALUE 0x8C37 -#define GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A -#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B -#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C -#define GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D -#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5E -#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5F -#define GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS 0x8F9F -#define GL_TEXTURE_CUBE_MAP_ARRAY 0x9009 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARRAY 0x900A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARRAY 0x900B -#define GL_SAMPLER_CUBE_MAP_ARRAY 0x900C -#define GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW 0x900D -#define GL_INT_SAMPLER_CUBE_MAP_ARRAY 0x900E -#define GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY 0x900F - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEIPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONIPROC) (GLuint buf, GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEIPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCIPROC) (GLuint buf, GLenum src, GLenum dst); -typedef void (GLAPIENTRY * PFNGLMINSAMPLESHADINGPROC) (GLclampf value); - -#define glBlendEquationSeparatei GLEW_GET_FUN(__glewBlendEquationSeparatei) -#define glBlendEquationi GLEW_GET_FUN(__glewBlendEquationi) -#define glBlendFuncSeparatei GLEW_GET_FUN(__glewBlendFuncSeparatei) -#define glBlendFunci GLEW_GET_FUN(__glewBlendFunci) -#define glMinSampleShading GLEW_GET_FUN(__glewMinSampleShading) - -#define GLEW_VERSION_4_0 GLEW_GET_VAR(__GLEW_VERSION_4_0) - -#endif /* GL_VERSION_4_0 */ - -/* ----------------------------- GL_VERSION_4_1 ---------------------------- */ - -#ifndef GL_VERSION_4_1 -#define GL_VERSION_4_1 1 - -#define GLEW_VERSION_4_1 GLEW_GET_VAR(__GLEW_VERSION_4_1) - -#endif /* GL_VERSION_4_1 */ - -/* -------------------------- GL_3DFX_multisample -------------------------- */ - -#ifndef GL_3DFX_multisample -#define GL_3DFX_multisample 1 - -#define GL_MULTISAMPLE_3DFX 0x86B2 -#define GL_SAMPLE_BUFFERS_3DFX 0x86B3 -#define GL_SAMPLES_3DFX 0x86B4 -#define GL_MULTISAMPLE_BIT_3DFX 0x20000000 - -#define GLEW_3DFX_multisample GLEW_GET_VAR(__GLEW_3DFX_multisample) - -#endif /* GL_3DFX_multisample */ - -/* ---------------------------- GL_3DFX_tbuffer ---------------------------- */ - -#ifndef GL_3DFX_tbuffer -#define GL_3DFX_tbuffer 1 - -typedef void (GLAPIENTRY * PFNGLTBUFFERMASK3DFXPROC) (GLuint mask); - -#define glTbufferMask3DFX GLEW_GET_FUN(__glewTbufferMask3DFX) - -#define GLEW_3DFX_tbuffer GLEW_GET_VAR(__GLEW_3DFX_tbuffer) - -#endif /* GL_3DFX_tbuffer */ - -/* -------------------- GL_3DFX_texture_compression_FXT1 ------------------- */ - -#ifndef GL_3DFX_texture_compression_FXT1 -#define GL_3DFX_texture_compression_FXT1 1 - -#define GL_COMPRESSED_RGB_FXT1_3DFX 0x86B0 -#define GL_COMPRESSED_RGBA_FXT1_3DFX 0x86B1 - -#define GLEW_3DFX_texture_compression_FXT1 GLEW_GET_VAR(__GLEW_3DFX_texture_compression_FXT1) - -#endif /* GL_3DFX_texture_compression_FXT1 */ - -/* ----------------------- GL_AMD_blend_minmax_factor ---------------------- */ - -#ifndef GL_AMD_blend_minmax_factor -#define GL_AMD_blend_minmax_factor 1 - -#define GL_FACTOR_MIN_AMD 0x901C -#define GL_FACTOR_MAX_AMD 0x901D - -#define GLEW_AMD_blend_minmax_factor GLEW_GET_VAR(__GLEW_AMD_blend_minmax_factor) - -#endif /* GL_AMD_blend_minmax_factor */ - -/* ----------------------- GL_AMD_conservative_depth ----------------------- */ - -#ifndef GL_AMD_conservative_depth -#define GL_AMD_conservative_depth 1 - -#define GLEW_AMD_conservative_depth GLEW_GET_VAR(__GLEW_AMD_conservative_depth) - -#endif /* GL_AMD_conservative_depth */ - -/* -------------------------- GL_AMD_debug_output -------------------------- */ - -#ifndef GL_AMD_debug_output -#define GL_AMD_debug_output 1 - -#define GL_MAX_DEBUG_MESSAGE_LENGTH_AMD 0x9143 -#define GL_MAX_DEBUG_LOGGED_MESSAGES_AMD 0x9144 -#define GL_DEBUG_LOGGED_MESSAGES_AMD 0x9145 -#define GL_DEBUG_SEVERITY_HIGH_AMD 0x9146 -#define GL_DEBUG_SEVERITY_MEDIUM_AMD 0x9147 -#define GL_DEBUG_SEVERITY_LOW_AMD 0x9148 -#define GL_DEBUG_CATEGORY_API_ERROR_AMD 0x9149 -#define GL_DEBUG_CATEGORY_WINDOW_SYSTEM_AMD 0x914A -#define GL_DEBUG_CATEGORY_DEPRECATION_AMD 0x914B -#define GL_DEBUG_CATEGORY_UNDEFINED_BEHAVIOR_AMD 0x914C -#define GL_DEBUG_CATEGORY_PERFORMANCE_AMD 0x914D -#define GL_DEBUG_CATEGORY_SHADER_COMPILER_AMD 0x914E -#define GL_DEBUG_CATEGORY_APPLICATION_AMD 0x914F -#define GL_DEBUG_CATEGORY_OTHER_AMD 0x9150 - -typedef void (APIENTRY *GLDEBUGPROCAMD)(GLuint id, GLenum category, GLenum severity, GLsizei length, const GLchar* message, GLvoid* userParam); - -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECALLBACKAMDPROC) (GLDEBUGPROCAMD callback, void* userParam); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEENABLEAMDPROC) (GLenum category, GLenum severity, GLsizei count, const GLuint* ids, GLboolean enabled); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEINSERTAMDPROC) (GLenum category, GLenum severity, GLuint id, GLsizei length, const char* buf); -typedef GLuint (GLAPIENTRY * PFNGLGETDEBUGMESSAGELOGAMDPROC) (GLuint count, GLsizei bufsize, GLenum* categories, GLuint* severities, GLuint* ids, GLsizei* lengths, char* message); - -#define glDebugMessageCallbackAMD GLEW_GET_FUN(__glewDebugMessageCallbackAMD) -#define glDebugMessageEnableAMD GLEW_GET_FUN(__glewDebugMessageEnableAMD) -#define glDebugMessageInsertAMD GLEW_GET_FUN(__glewDebugMessageInsertAMD) -#define glGetDebugMessageLogAMD GLEW_GET_FUN(__glewGetDebugMessageLogAMD) - -#define GLEW_AMD_debug_output GLEW_GET_VAR(__GLEW_AMD_debug_output) - -#endif /* GL_AMD_debug_output */ - -/* ---------------------- GL_AMD_depth_clamp_separate ---------------------- */ - -#ifndef GL_AMD_depth_clamp_separate -#define GL_AMD_depth_clamp_separate 1 - -#define GL_DEPTH_CLAMP_NEAR_AMD 0x901E -#define GL_DEPTH_CLAMP_FAR_AMD 0x901F - -#define GLEW_AMD_depth_clamp_separate GLEW_GET_VAR(__GLEW_AMD_depth_clamp_separate) - -#endif /* GL_AMD_depth_clamp_separate */ - -/* ----------------------- GL_AMD_draw_buffers_blend ----------------------- */ - -#ifndef GL_AMD_draw_buffers_blend -#define GL_AMD_draw_buffers_blend 1 - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONINDEXEDAMDPROC) (GLuint buf, GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCINDEXEDAMDPROC) (GLuint buf, GLenum src, GLenum dst); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); - -#define glBlendEquationIndexedAMD GLEW_GET_FUN(__glewBlendEquationIndexedAMD) -#define glBlendEquationSeparateIndexedAMD GLEW_GET_FUN(__glewBlendEquationSeparateIndexedAMD) -#define glBlendFuncIndexedAMD GLEW_GET_FUN(__glewBlendFuncIndexedAMD) -#define glBlendFuncSeparateIndexedAMD GLEW_GET_FUN(__glewBlendFuncSeparateIndexedAMD) - -#define GLEW_AMD_draw_buffers_blend GLEW_GET_VAR(__GLEW_AMD_draw_buffers_blend) - -#endif /* GL_AMD_draw_buffers_blend */ - -/* ------------------------- GL_AMD_name_gen_delete ------------------------ */ - -#ifndef GL_AMD_name_gen_delete -#define GL_AMD_name_gen_delete 1 - -#define GL_DATA_BUFFER_AMD 0x9151 -#define GL_PERFORMANCE_MONITOR_AMD 0x9152 -#define GL_QUERY_OBJECT_AMD 0x9153 -#define GL_VERTEX_ARRAY_OBJECT_AMD 0x9154 -#define GL_SAMPLER_OBJECT_AMD 0x9155 - -typedef void (GLAPIENTRY * PFNGLDELETENAMESAMDPROC) (GLenum identifier, GLuint num, const GLuint* names); -typedef void (GLAPIENTRY * PFNGLGENNAMESAMDPROC) (GLenum identifier, GLuint num, GLuint* names); -typedef GLboolean (GLAPIENTRY * PFNGLISNAMEAMDPROC) (GLenum identifier, GLuint name); - -#define glDeleteNamesAMD GLEW_GET_FUN(__glewDeleteNamesAMD) -#define glGenNamesAMD GLEW_GET_FUN(__glewGenNamesAMD) -#define glIsNameAMD GLEW_GET_FUN(__glewIsNameAMD) - -#define GLEW_AMD_name_gen_delete GLEW_GET_VAR(__GLEW_AMD_name_gen_delete) - -#endif /* GL_AMD_name_gen_delete */ - -/* ----------------------- GL_AMD_performance_monitor ---------------------- */ - -#ifndef GL_AMD_performance_monitor -#define GL_AMD_performance_monitor 1 - -#define GL_UNSIGNED_INT 0x1405 -#define GL_FLOAT 0x1406 -#define GL_COUNTER_TYPE_AMD 0x8BC0 -#define GL_COUNTER_RANGE_AMD 0x8BC1 -#define GL_UNSIGNED_INT64_AMD 0x8BC2 -#define GL_PERCENTAGE_AMD 0x8BC3 -#define GL_PERFMON_RESULT_AVAILABLE_AMD 0x8BC4 -#define GL_PERFMON_RESULT_SIZE_AMD 0x8BC5 -#define GL_PERFMON_RESULT_AMD 0x8BC6 - -typedef void (GLAPIENTRY * PFNGLBEGINPERFMONITORAMDPROC) (GLuint monitor); -typedef void (GLAPIENTRY * PFNGLDELETEPERFMONITORSAMDPROC) (GLsizei n, GLuint* monitors); -typedef void (GLAPIENTRY * PFNGLENDPERFMONITORAMDPROC) (GLuint monitor); -typedef void (GLAPIENTRY * PFNGLGENPERFMONITORSAMDPROC) (GLsizei n, GLuint* monitors); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERDATAAMDPROC) (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint* data, GLint *bytesWritten); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERINFOAMDPROC) (GLuint group, GLuint counter, GLenum pname, void* data); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC) (GLuint group, GLuint counter, GLsizei bufSize, GLsizei* length, char *counterString); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERSAMDPROC) (GLuint group, GLint* numCounters, GLint *maxActiveCounters, GLsizei countersSize, GLuint *counters); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORGROUPSTRINGAMDPROC) (GLuint group, GLsizei bufSize, GLsizei* length, char *groupString); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORGROUPSAMDPROC) (GLint* numGroups, GLsizei groupsSize, GLuint *groups); -typedef void (GLAPIENTRY * PFNGLSELECTPERFMONITORCOUNTERSAMDPROC) (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint* counterList); - -#define glBeginPerfMonitorAMD GLEW_GET_FUN(__glewBeginPerfMonitorAMD) -#define glDeletePerfMonitorsAMD GLEW_GET_FUN(__glewDeletePerfMonitorsAMD) -#define glEndPerfMonitorAMD GLEW_GET_FUN(__glewEndPerfMonitorAMD) -#define glGenPerfMonitorsAMD GLEW_GET_FUN(__glewGenPerfMonitorsAMD) -#define glGetPerfMonitorCounterDataAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterDataAMD) -#define glGetPerfMonitorCounterInfoAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterInfoAMD) -#define glGetPerfMonitorCounterStringAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterStringAMD) -#define glGetPerfMonitorCountersAMD GLEW_GET_FUN(__glewGetPerfMonitorCountersAMD) -#define glGetPerfMonitorGroupStringAMD GLEW_GET_FUN(__glewGetPerfMonitorGroupStringAMD) -#define glGetPerfMonitorGroupsAMD GLEW_GET_FUN(__glewGetPerfMonitorGroupsAMD) -#define glSelectPerfMonitorCountersAMD GLEW_GET_FUN(__glewSelectPerfMonitorCountersAMD) - -#define GLEW_AMD_performance_monitor GLEW_GET_VAR(__GLEW_AMD_performance_monitor) - -#endif /* GL_AMD_performance_monitor */ - -/* ------------------------ GL_AMD_sample_positions ------------------------ */ - -#ifndef GL_AMD_sample_positions -#define GL_AMD_sample_positions 1 - -#define GL_SUBSAMPLE_DISTANCE_AMD 0x883F - -typedef void (GLAPIENTRY * PFNGLSETMULTISAMPLEFVAMDPROC) (GLenum pname, GLuint index, const GLfloat* val); - -#define glSetMultisamplefvAMD GLEW_GET_FUN(__glewSetMultisamplefvAMD) - -#define GLEW_AMD_sample_positions GLEW_GET_VAR(__GLEW_AMD_sample_positions) - -#endif /* GL_AMD_sample_positions */ - -/* ------------------ GL_AMD_seamless_cubemap_per_texture ------------------ */ - -#ifndef GL_AMD_seamless_cubemap_per_texture -#define GL_AMD_seamless_cubemap_per_texture 1 - -#define GL_TEXTURE_CUBE_MAP_SEAMLESS_ARB 0x884F - -#define GLEW_AMD_seamless_cubemap_per_texture GLEW_GET_VAR(__GLEW_AMD_seamless_cubemap_per_texture) - -#endif /* GL_AMD_seamless_cubemap_per_texture */ - -/* ---------------------- GL_AMD_shader_stencil_export --------------------- */ - -#ifndef GL_AMD_shader_stencil_export -#define GL_AMD_shader_stencil_export 1 - -#define GLEW_AMD_shader_stencil_export GLEW_GET_VAR(__GLEW_AMD_shader_stencil_export) - -#endif /* GL_AMD_shader_stencil_export */ - -/* ------------------------ GL_AMD_texture_texture4 ------------------------ */ - -#ifndef GL_AMD_texture_texture4 -#define GL_AMD_texture_texture4 1 - -#define GLEW_AMD_texture_texture4 GLEW_GET_VAR(__GLEW_AMD_texture_texture4) - -#endif /* GL_AMD_texture_texture4 */ - -/* --------------- GL_AMD_transform_feedback3_lines_triangles -------------- */ - -#ifndef GL_AMD_transform_feedback3_lines_triangles -#define GL_AMD_transform_feedback3_lines_triangles 1 - -#define GLEW_AMD_transform_feedback3_lines_triangles GLEW_GET_VAR(__GLEW_AMD_transform_feedback3_lines_triangles) - -#endif /* GL_AMD_transform_feedback3_lines_triangles */ - -/* -------------------- GL_AMD_vertex_shader_tessellator ------------------- */ - -#ifndef GL_AMD_vertex_shader_tessellator -#define GL_AMD_vertex_shader_tessellator 1 - -#define GL_SAMPLER_BUFFER_AMD 0x9001 -#define GL_INT_SAMPLER_BUFFER_AMD 0x9002 -#define GL_UNSIGNED_INT_SAMPLER_BUFFER_AMD 0x9003 -#define GL_TESSELLATION_MODE_AMD 0x9004 -#define GL_TESSELLATION_FACTOR_AMD 0x9005 -#define GL_DISCRETE_AMD 0x9006 -#define GL_CONTINUOUS_AMD 0x9007 - -typedef void (GLAPIENTRY * PFNGLTESSELLATIONFACTORAMDPROC) (GLfloat factor); -typedef void (GLAPIENTRY * PFNGLTESSELLATIONMODEAMDPROC) (GLenum mode); - -#define glTessellationFactorAMD GLEW_GET_FUN(__glewTessellationFactorAMD) -#define glTessellationModeAMD GLEW_GET_FUN(__glewTessellationModeAMD) - -#define GLEW_AMD_vertex_shader_tessellator GLEW_GET_VAR(__GLEW_AMD_vertex_shader_tessellator) - -#endif /* GL_AMD_vertex_shader_tessellator */ - -/* ----------------------- GL_APPLE_aux_depth_stencil ---------------------- */ - -#ifndef GL_APPLE_aux_depth_stencil -#define GL_APPLE_aux_depth_stencil 1 - -#define GL_AUX_DEPTH_STENCIL_APPLE 0x8A14 - -#define GLEW_APPLE_aux_depth_stencil GLEW_GET_VAR(__GLEW_APPLE_aux_depth_stencil) - -#endif /* GL_APPLE_aux_depth_stencil */ - -/* ------------------------ GL_APPLE_client_storage ------------------------ */ - -#ifndef GL_APPLE_client_storage -#define GL_APPLE_client_storage 1 - -#define GL_UNPACK_CLIENT_STORAGE_APPLE 0x85B2 - -#define GLEW_APPLE_client_storage GLEW_GET_VAR(__GLEW_APPLE_client_storage) - -#endif /* GL_APPLE_client_storage */ - -/* ------------------------- GL_APPLE_element_array ------------------------ */ - -#ifndef GL_APPLE_element_array -#define GL_APPLE_element_array 1 - -#define GL_ELEMENT_ARRAY_APPLE 0x8A0C -#define GL_ELEMENT_ARRAY_TYPE_APPLE 0x8A0D -#define GL_ELEMENT_ARRAY_POINTER_APPLE 0x8A0E - -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLELEMENTPOINTERAPPLEPROC) (GLenum type, const void* pointer); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, const GLint* first, const GLsizei *count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, const GLint* first, const GLsizei *count, GLsizei primcount); - -#define glDrawElementArrayAPPLE GLEW_GET_FUN(__glewDrawElementArrayAPPLE) -#define glDrawRangeElementArrayAPPLE GLEW_GET_FUN(__glewDrawRangeElementArrayAPPLE) -#define glElementPointerAPPLE GLEW_GET_FUN(__glewElementPointerAPPLE) -#define glMultiDrawElementArrayAPPLE GLEW_GET_FUN(__glewMultiDrawElementArrayAPPLE) -#define glMultiDrawRangeElementArrayAPPLE GLEW_GET_FUN(__glewMultiDrawRangeElementArrayAPPLE) - -#define GLEW_APPLE_element_array GLEW_GET_VAR(__GLEW_APPLE_element_array) - -#endif /* GL_APPLE_element_array */ - -/* ----------------------------- GL_APPLE_fence ---------------------------- */ - -#ifndef GL_APPLE_fence -#define GL_APPLE_fence 1 - -#define GL_DRAW_PIXELS_APPLE 0x8A0A -#define GL_FENCE_APPLE 0x8A0B - -typedef void (GLAPIENTRY * PFNGLDELETEFENCESAPPLEPROC) (GLsizei n, const GLuint* fences); -typedef void (GLAPIENTRY * PFNGLFINISHFENCEAPPLEPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLFINISHOBJECTAPPLEPROC) (GLenum object, GLint name); -typedef void (GLAPIENTRY * PFNGLGENFENCESAPPLEPROC) (GLsizei n, GLuint* fences); -typedef GLboolean (GLAPIENTRY * PFNGLISFENCEAPPLEPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLSETFENCEAPPLEPROC) (GLuint fence); -typedef GLboolean (GLAPIENTRY * PFNGLTESTFENCEAPPLEPROC) (GLuint fence); -typedef GLboolean (GLAPIENTRY * PFNGLTESTOBJECTAPPLEPROC) (GLenum object, GLuint name); - -#define glDeleteFencesAPPLE GLEW_GET_FUN(__glewDeleteFencesAPPLE) -#define glFinishFenceAPPLE GLEW_GET_FUN(__glewFinishFenceAPPLE) -#define glFinishObjectAPPLE GLEW_GET_FUN(__glewFinishObjectAPPLE) -#define glGenFencesAPPLE GLEW_GET_FUN(__glewGenFencesAPPLE) -#define glIsFenceAPPLE GLEW_GET_FUN(__glewIsFenceAPPLE) -#define glSetFenceAPPLE GLEW_GET_FUN(__glewSetFenceAPPLE) -#define glTestFenceAPPLE GLEW_GET_FUN(__glewTestFenceAPPLE) -#define glTestObjectAPPLE GLEW_GET_FUN(__glewTestObjectAPPLE) - -#define GLEW_APPLE_fence GLEW_GET_VAR(__GLEW_APPLE_fence) - -#endif /* GL_APPLE_fence */ - -/* ------------------------- GL_APPLE_float_pixels ------------------------- */ - -#ifndef GL_APPLE_float_pixels -#define GL_APPLE_float_pixels 1 - -#define GL_HALF_APPLE 0x140B -#define GL_RGBA_FLOAT32_APPLE 0x8814 -#define GL_RGB_FLOAT32_APPLE 0x8815 -#define GL_ALPHA_FLOAT32_APPLE 0x8816 -#define GL_INTENSITY_FLOAT32_APPLE 0x8817 -#define GL_LUMINANCE_FLOAT32_APPLE 0x8818 -#define GL_LUMINANCE_ALPHA_FLOAT32_APPLE 0x8819 -#define GL_RGBA_FLOAT16_APPLE 0x881A -#define GL_RGB_FLOAT16_APPLE 0x881B -#define GL_ALPHA_FLOAT16_APPLE 0x881C -#define GL_INTENSITY_FLOAT16_APPLE 0x881D -#define GL_LUMINANCE_FLOAT16_APPLE 0x881E -#define GL_LUMINANCE_ALPHA_FLOAT16_APPLE 0x881F -#define GL_COLOR_FLOAT_APPLE 0x8A0F - -#define GLEW_APPLE_float_pixels GLEW_GET_VAR(__GLEW_APPLE_float_pixels) - -#endif /* GL_APPLE_float_pixels */ - -/* ---------------------- GL_APPLE_flush_buffer_range ---------------------- */ - -#ifndef GL_APPLE_flush_buffer_range -#define GL_APPLE_flush_buffer_range 1 - -#define GL_BUFFER_SERIALIZED_MODIFY_APPLE 0x8A12 -#define GL_BUFFER_FLUSHING_UNMAP_APPLE 0x8A13 - -typedef void (GLAPIENTRY * PFNGLBUFFERPARAMETERIAPPLEPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC) (GLenum target, GLintptr offset, GLsizeiptr size); - -#define glBufferParameteriAPPLE GLEW_GET_FUN(__glewBufferParameteriAPPLE) -#define glFlushMappedBufferRangeAPPLE GLEW_GET_FUN(__glewFlushMappedBufferRangeAPPLE) - -#define GLEW_APPLE_flush_buffer_range GLEW_GET_VAR(__GLEW_APPLE_flush_buffer_range) - -#endif /* GL_APPLE_flush_buffer_range */ - -/* ----------------------- GL_APPLE_object_purgeable ----------------------- */ - -#ifndef GL_APPLE_object_purgeable -#define GL_APPLE_object_purgeable 1 - -#define GL_BUFFER_OBJECT_APPLE 0x85B3 -#define GL_RELEASED_APPLE 0x8A19 -#define GL_VOLATILE_APPLE 0x8A1A -#define GL_RETAINED_APPLE 0x8A1B -#define GL_UNDEFINED_APPLE 0x8A1C -#define GL_PURGEABLE_APPLE 0x8A1D - -typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERIVAPPLEPROC) (GLenum objectType, GLuint name, GLenum pname, GLint* params); -typedef GLenum (GLAPIENTRY * PFNGLOBJECTPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); -typedef GLenum (GLAPIENTRY * PFNGLOBJECTUNPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); - -#define glGetObjectParameterivAPPLE GLEW_GET_FUN(__glewGetObjectParameterivAPPLE) -#define glObjectPurgeableAPPLE GLEW_GET_FUN(__glewObjectPurgeableAPPLE) -#define glObjectUnpurgeableAPPLE GLEW_GET_FUN(__glewObjectUnpurgeableAPPLE) - -#define GLEW_APPLE_object_purgeable GLEW_GET_VAR(__GLEW_APPLE_object_purgeable) - -#endif /* GL_APPLE_object_purgeable */ - -/* ------------------------- GL_APPLE_pixel_buffer ------------------------- */ - -#ifndef GL_APPLE_pixel_buffer -#define GL_APPLE_pixel_buffer 1 - -#define GL_MIN_PBUFFER_VIEWPORT_DIMS_APPLE 0x8A10 - -#define GLEW_APPLE_pixel_buffer GLEW_GET_VAR(__GLEW_APPLE_pixel_buffer) - -#endif /* GL_APPLE_pixel_buffer */ - -/* ---------------------------- GL_APPLE_rgb_422 --------------------------- */ - -#ifndef GL_APPLE_rgb_422 -#define GL_APPLE_rgb_422 1 - -#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA -#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB -#define GL_RGB_422_APPLE 0x8A1F - -#define GLEW_APPLE_rgb_422 GLEW_GET_VAR(__GLEW_APPLE_rgb_422) - -#endif /* GL_APPLE_rgb_422 */ - -/* --------------------------- GL_APPLE_row_bytes -------------------------- */ - -#ifndef GL_APPLE_row_bytes -#define GL_APPLE_row_bytes 1 - -#define GL_PACK_ROW_BYTES_APPLE 0x8A15 -#define GL_UNPACK_ROW_BYTES_APPLE 0x8A16 - -#define GLEW_APPLE_row_bytes GLEW_GET_VAR(__GLEW_APPLE_row_bytes) - -#endif /* GL_APPLE_row_bytes */ - -/* ------------------------ GL_APPLE_specular_vector ----------------------- */ - -#ifndef GL_APPLE_specular_vector -#define GL_APPLE_specular_vector 1 - -#define GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 - -#define GLEW_APPLE_specular_vector GLEW_GET_VAR(__GLEW_APPLE_specular_vector) - -#endif /* GL_APPLE_specular_vector */ - -/* ------------------------- GL_APPLE_texture_range ------------------------ */ - -#ifndef GL_APPLE_texture_range -#define GL_APPLE_texture_range 1 - -#define GL_TEXTURE_RANGE_LENGTH_APPLE 0x85B7 -#define GL_TEXTURE_RANGE_POINTER_APPLE 0x85B8 -#define GL_TEXTURE_STORAGE_HINT_APPLE 0x85BC -#define GL_STORAGE_PRIVATE_APPLE 0x85BD -#define GL_STORAGE_CACHED_APPLE 0x85BE -#define GL_STORAGE_SHARED_APPLE 0x85BF - -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC) (GLenum target, GLenum pname, GLvoid **params); -typedef void (GLAPIENTRY * PFNGLTEXTURERANGEAPPLEPROC) (GLenum target, GLsizei length, GLvoid *pointer); - -#define glGetTexParameterPointervAPPLE GLEW_GET_FUN(__glewGetTexParameterPointervAPPLE) -#define glTextureRangeAPPLE GLEW_GET_FUN(__glewTextureRangeAPPLE) - -#define GLEW_APPLE_texture_range GLEW_GET_VAR(__GLEW_APPLE_texture_range) - -#endif /* GL_APPLE_texture_range */ - -/* ------------------------ GL_APPLE_transform_hint ------------------------ */ - -#ifndef GL_APPLE_transform_hint -#define GL_APPLE_transform_hint 1 - -#define GL_TRANSFORM_HINT_APPLE 0x85B1 - -#define GLEW_APPLE_transform_hint GLEW_GET_VAR(__GLEW_APPLE_transform_hint) - -#endif /* GL_APPLE_transform_hint */ - -/* ---------------------- GL_APPLE_vertex_array_object --------------------- */ - -#ifndef GL_APPLE_vertex_array_object -#define GL_APPLE_vertex_array_object 1 - -#define GL_VERTEX_ARRAY_BINDING_APPLE 0x85B5 - -typedef void (GLAPIENTRY * PFNGLBINDVERTEXARRAYAPPLEPROC) (GLuint array); -typedef void (GLAPIENTRY * PFNGLDELETEVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint* arrays); -typedef void (GLAPIENTRY * PFNGLGENVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint* arrays); -typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXARRAYAPPLEPROC) (GLuint array); - -#define glBindVertexArrayAPPLE GLEW_GET_FUN(__glewBindVertexArrayAPPLE) -#define glDeleteVertexArraysAPPLE GLEW_GET_FUN(__glewDeleteVertexArraysAPPLE) -#define glGenVertexArraysAPPLE GLEW_GET_FUN(__glewGenVertexArraysAPPLE) -#define glIsVertexArrayAPPLE GLEW_GET_FUN(__glewIsVertexArrayAPPLE) - -#define GLEW_APPLE_vertex_array_object GLEW_GET_VAR(__GLEW_APPLE_vertex_array_object) - -#endif /* GL_APPLE_vertex_array_object */ - -/* ---------------------- GL_APPLE_vertex_array_range ---------------------- */ - -#ifndef GL_APPLE_vertex_array_range -#define GL_APPLE_vertex_array_range 1 - -#define GL_VERTEX_ARRAY_RANGE_APPLE 0x851D -#define GL_VERTEX_ARRAY_RANGE_LENGTH_APPLE 0x851E -#define GL_VERTEX_ARRAY_STORAGE_HINT_APPLE 0x851F -#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_APPLE 0x8520 -#define GL_VERTEX_ARRAY_RANGE_POINTER_APPLE 0x8521 -#define GL_STORAGE_CLIENT_APPLE 0x85B4 -#define GL_STORAGE_CACHED_APPLE 0x85BE -#define GL_STORAGE_SHARED_APPLE 0x85BF - -typedef void (GLAPIENTRY * PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, void* pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYPARAMETERIAPPLEPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, void* pointer); - -#define glFlushVertexArrayRangeAPPLE GLEW_GET_FUN(__glewFlushVertexArrayRangeAPPLE) -#define glVertexArrayParameteriAPPLE GLEW_GET_FUN(__glewVertexArrayParameteriAPPLE) -#define glVertexArrayRangeAPPLE GLEW_GET_FUN(__glewVertexArrayRangeAPPLE) - -#define GLEW_APPLE_vertex_array_range GLEW_GET_VAR(__GLEW_APPLE_vertex_array_range) - -#endif /* GL_APPLE_vertex_array_range */ - -/* ------------------- GL_APPLE_vertex_program_evaluators ------------------ */ - -#ifndef GL_APPLE_vertex_program_evaluators -#define GL_APPLE_vertex_program_evaluators 1 - -#define GL_VERTEX_ATTRIB_MAP1_APPLE 0x8A00 -#define GL_VERTEX_ATTRIB_MAP2_APPLE 0x8A01 -#define GL_VERTEX_ATTRIB_MAP1_SIZE_APPLE 0x8A02 -#define GL_VERTEX_ATTRIB_MAP1_COEFF_APPLE 0x8A03 -#define GL_VERTEX_ATTRIB_MAP1_ORDER_APPLE 0x8A04 -#define GL_VERTEX_ATTRIB_MAP1_DOMAIN_APPLE 0x8A05 -#define GL_VERTEX_ATTRIB_MAP2_SIZE_APPLE 0x8A06 -#define GL_VERTEX_ATTRIB_MAP2_COEFF_APPLE 0x8A07 -#define GL_VERTEX_ATTRIB_MAP2_ORDER_APPLE 0x8A08 -#define GL_VERTEX_ATTRIB_MAP2_DOMAIN_APPLE 0x8A09 - -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); -typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXATTRIBENABLEDAPPLEPROC) (GLuint index, GLenum pname); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB1DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble* points); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB1FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat* points); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB2DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble* points); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB2FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat* points); - -#define glDisableVertexAttribAPPLE GLEW_GET_FUN(__glewDisableVertexAttribAPPLE) -#define glEnableVertexAttribAPPLE GLEW_GET_FUN(__glewEnableVertexAttribAPPLE) -#define glIsVertexAttribEnabledAPPLE GLEW_GET_FUN(__glewIsVertexAttribEnabledAPPLE) -#define glMapVertexAttrib1dAPPLE GLEW_GET_FUN(__glewMapVertexAttrib1dAPPLE) -#define glMapVertexAttrib1fAPPLE GLEW_GET_FUN(__glewMapVertexAttrib1fAPPLE) -#define glMapVertexAttrib2dAPPLE GLEW_GET_FUN(__glewMapVertexAttrib2dAPPLE) -#define glMapVertexAttrib2fAPPLE GLEW_GET_FUN(__glewMapVertexAttrib2fAPPLE) - -#define GLEW_APPLE_vertex_program_evaluators GLEW_GET_VAR(__GLEW_APPLE_vertex_program_evaluators) - -#endif /* GL_APPLE_vertex_program_evaluators */ - -/* --------------------------- GL_APPLE_ycbcr_422 -------------------------- */ - -#ifndef GL_APPLE_ycbcr_422 -#define GL_APPLE_ycbcr_422 1 - -#define GL_YCBCR_422_APPLE 0x85B9 -#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA -#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB - -#define GLEW_APPLE_ycbcr_422 GLEW_GET_VAR(__GLEW_APPLE_ycbcr_422) - -#endif /* GL_APPLE_ycbcr_422 */ - -/* ------------------------ GL_ARB_ES2_compatibility ----------------------- */ - -#ifndef GL_ARB_ES2_compatibility -#define GL_ARB_ES2_compatibility 1 - -#define GL_FIXED 0x140C -#define GL_IMPLEMENTATION_COLOR_READ_TYPE 0x8B9A -#define GL_IMPLEMENTATION_COLOR_READ_FORMAT 0x8B9B -#define GL_LOW_FLOAT 0x8DF0 -#define GL_MEDIUM_FLOAT 0x8DF1 -#define GL_HIGH_FLOAT 0x8DF2 -#define GL_LOW_INT 0x8DF3 -#define GL_MEDIUM_INT 0x8DF4 -#define GL_HIGH_INT 0x8DF5 -#define GL_SHADER_BINARY_FORMATS 0x8DF8 -#define GL_NUM_SHADER_BINARY_FORMATS 0x8DF9 -#define GL_SHADER_COMPILER 0x8DFA -#define GL_MAX_VERTEX_UNIFORM_VECTORS 0x8DFB -#define GL_MAX_VARYING_VECTORS 0x8DFC -#define GL_MAX_FRAGMENT_UNIFORM_VECTORS 0x8DFD - -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHFPROC) (GLclampf d); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEFPROC) (GLclampf n, GLclampf f); -typedef void (GLAPIENTRY * PFNGLGETSHADERPRECISIONFORMATPROC) (GLenum shadertype, GLenum precisiontype, GLint* range, GLint *precision); -typedef void (GLAPIENTRY * PFNGLRELEASESHADERCOMPILERPROC) (void); -typedef void (GLAPIENTRY * PFNGLSHADERBINARYPROC) (GLsizei count, const GLuint* shaders, GLenum binaryformat, const GLvoid*binary, GLsizei length); - -#define glClearDepthf GLEW_GET_FUN(__glewClearDepthf) -#define glDepthRangef GLEW_GET_FUN(__glewDepthRangef) -#define glGetShaderPrecisionFormat GLEW_GET_FUN(__glewGetShaderPrecisionFormat) -#define glReleaseShaderCompiler GLEW_GET_FUN(__glewReleaseShaderCompiler) -#define glShaderBinary GLEW_GET_FUN(__glewShaderBinary) - -#define GLEW_ARB_ES2_compatibility GLEW_GET_VAR(__GLEW_ARB_ES2_compatibility) - -#endif /* GL_ARB_ES2_compatibility */ - -/* ----------------------- GL_ARB_blend_func_extended ---------------------- */ - -#ifndef GL_ARB_blend_func_extended -#define GL_ARB_blend_func_extended 1 - -#define GL_SRC1_COLOR 0x88F9 -#define GL_ONE_MINUS_SRC1_COLOR 0x88FA -#define GL_ONE_MINUS_SRC1_ALPHA 0x88FB -#define GL_MAX_DUAL_SOURCE_DRAW_BUFFERS 0x88FC - -typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONINDEXEDPROC) (GLuint program, GLuint colorNumber, GLuint index, const char * name); -typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATAINDEXPROC) (GLuint program, const char * name); - -#define glBindFragDataLocationIndexed GLEW_GET_FUN(__glewBindFragDataLocationIndexed) -#define glGetFragDataIndex GLEW_GET_FUN(__glewGetFragDataIndex) - -#define GLEW_ARB_blend_func_extended GLEW_GET_VAR(__GLEW_ARB_blend_func_extended) - -#endif /* GL_ARB_blend_func_extended */ - -/* ---------------------------- GL_ARB_cl_event ---------------------------- */ - -#ifndef GL_ARB_cl_event -#define GL_ARB_cl_event 1 - -#define GL_SYNC_CL_EVENT_ARB 0x8240 -#define GL_SYNC_CL_EVENT_COMPLETE_ARB 0x8241 - -typedef struct _cl_context *cl_context; -typedef struct _cl_event *cl_event; - -typedef GLsync (GLAPIENTRY * PFNGLCREATESYNCFROMCLEVENTARBPROC) (cl_context context, cl_event event, GLbitfield flags); - -#define glCreateSyncFromCLeventARB GLEW_GET_FUN(__glewCreateSyncFromCLeventARB) - -#define GLEW_ARB_cl_event GLEW_GET_VAR(__GLEW_ARB_cl_event) - -#endif /* GL_ARB_cl_event */ - -/* ----------------------- GL_ARB_color_buffer_float ----------------------- */ - -#ifndef GL_ARB_color_buffer_float -#define GL_ARB_color_buffer_float 1 - -#define GL_RGBA_FLOAT_MODE_ARB 0x8820 -#define GL_CLAMP_VERTEX_COLOR_ARB 0x891A -#define GL_CLAMP_FRAGMENT_COLOR_ARB 0x891B -#define GL_CLAMP_READ_COLOR_ARB 0x891C -#define GL_FIXED_ONLY_ARB 0x891D - -typedef void (GLAPIENTRY * PFNGLCLAMPCOLORARBPROC) (GLenum target, GLenum clamp); - -#define glClampColorARB GLEW_GET_FUN(__glewClampColorARB) - -#define GLEW_ARB_color_buffer_float GLEW_GET_VAR(__GLEW_ARB_color_buffer_float) - -#endif /* GL_ARB_color_buffer_float */ - -/* -------------------------- GL_ARB_compatibility ------------------------- */ - -#ifndef GL_ARB_compatibility -#define GL_ARB_compatibility 1 - -#define GLEW_ARB_compatibility GLEW_GET_VAR(__GLEW_ARB_compatibility) - -#endif /* GL_ARB_compatibility */ - -/* --------------------------- GL_ARB_copy_buffer -------------------------- */ - -#ifndef GL_ARB_copy_buffer -#define GL_ARB_copy_buffer 1 - -#define GL_COPY_READ_BUFFER 0x8F36 -#define GL_COPY_WRITE_BUFFER 0x8F37 - -typedef void (GLAPIENTRY * PFNGLCOPYBUFFERSUBDATAPROC) (GLenum readtarget, GLenum writetarget, GLintptr readoffset, GLintptr writeoffset, GLsizeiptr size); - -#define glCopyBufferSubData GLEW_GET_FUN(__glewCopyBufferSubData) - -#define GLEW_ARB_copy_buffer GLEW_GET_VAR(__GLEW_ARB_copy_buffer) - -#endif /* GL_ARB_copy_buffer */ - -/* -------------------------- GL_ARB_debug_output -------------------------- */ - -#ifndef GL_ARB_debug_output -#define GL_ARB_debug_output 1 - -#define GL_DEBUG_OUTPUT_SYNCHRONOUS_ARB 0x8242 -#define GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH_ARB 0x8243 -#define GL_DEBUG_CALLBACK_FUNCTION_ARB 0x8244 -#define GL_DEBUG_CALLBACK_USER_PARAM_ARB 0x8245 -#define GL_DEBUG_SOURCE_API_ARB 0x8246 -#define GL_DEBUG_SOURCE_WINDOW_SYSTEM_ARB 0x8247 -#define GL_DEBUG_SOURCE_SHADER_COMPILER_ARB 0x8248 -#define GL_DEBUG_SOURCE_THIRD_PARTY_ARB 0x8249 -#define GL_DEBUG_SOURCE_APPLICATION_ARB 0x824A -#define GL_DEBUG_SOURCE_OTHER_ARB 0x824B -#define GL_DEBUG_TYPE_ERROR_ARB 0x824C -#define GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR_ARB 0x824D -#define GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR_ARB 0x824E -#define GL_DEBUG_TYPE_PORTABILITY_ARB 0x824F -#define GL_DEBUG_TYPE_PERFORMANCE_ARB 0x8250 -#define GL_DEBUG_TYPE_OTHER_ARB 0x8251 -#define GL_MAX_DEBUG_MESSAGE_LENGTH_ARB 0x9143 -#define GL_MAX_DEBUG_LOGGED_MESSAGES_ARB 0x9144 -#define GL_DEBUG_LOGGED_MESSAGES_ARB 0x9145 -#define GL_DEBUG_SEVERITY_HIGH_ARB 0x9146 -#define GL_DEBUG_SEVERITY_MEDIUM_ARB 0x9147 -#define GL_DEBUG_SEVERITY_LOW_ARB 0x9148 - -typedef void (APIENTRY *GLDEBUGPROCARB)(GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* message, GLvoid* userParam); - -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECALLBACKARBPROC) (GLDEBUGPROCARB callback, void* userParam); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECONTROLARBPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint* ids, GLboolean enabled); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEINSERTARBPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const char* buf); -typedef GLuint (GLAPIENTRY * PFNGLGETDEBUGMESSAGELOGARBPROC) (GLuint count, GLsizei bufsize, GLenum* sources, GLenum* types, GLuint* ids, GLenum* severities, GLsizei* lengths, char* messageLog); - -#define glDebugMessageCallbackARB GLEW_GET_FUN(__glewDebugMessageCallbackARB) -#define glDebugMessageControlARB GLEW_GET_FUN(__glewDebugMessageControlARB) -#define glDebugMessageInsertARB GLEW_GET_FUN(__glewDebugMessageInsertARB) -#define glGetDebugMessageLogARB GLEW_GET_FUN(__glewGetDebugMessageLogARB) - -#define GLEW_ARB_debug_output GLEW_GET_VAR(__GLEW_ARB_debug_output) - -#endif /* GL_ARB_debug_output */ - -/* ----------------------- GL_ARB_depth_buffer_float ----------------------- */ - -#ifndef GL_ARB_depth_buffer_float -#define GL_ARB_depth_buffer_float 1 - -#define GL_DEPTH_COMPONENT32F 0x8CAC -#define GL_DEPTH32F_STENCIL8 0x8CAD -#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD - -#define GLEW_ARB_depth_buffer_float GLEW_GET_VAR(__GLEW_ARB_depth_buffer_float) - -#endif /* GL_ARB_depth_buffer_float */ - -/* --------------------------- GL_ARB_depth_clamp -------------------------- */ - -#ifndef GL_ARB_depth_clamp -#define GL_ARB_depth_clamp 1 - -#define GL_DEPTH_CLAMP 0x864F - -#define GLEW_ARB_depth_clamp GLEW_GET_VAR(__GLEW_ARB_depth_clamp) - -#endif /* GL_ARB_depth_clamp */ - -/* -------------------------- GL_ARB_depth_texture ------------------------- */ - -#ifndef GL_ARB_depth_texture -#define GL_ARB_depth_texture 1 - -#define GL_DEPTH_COMPONENT16_ARB 0x81A5 -#define GL_DEPTH_COMPONENT24_ARB 0x81A6 -#define GL_DEPTH_COMPONENT32_ARB 0x81A7 -#define GL_TEXTURE_DEPTH_SIZE_ARB 0x884A -#define GL_DEPTH_TEXTURE_MODE_ARB 0x884B - -#define GLEW_ARB_depth_texture GLEW_GET_VAR(__GLEW_ARB_depth_texture) - -#endif /* GL_ARB_depth_texture */ - -/* -------------------------- GL_ARB_draw_buffers -------------------------- */ - -#ifndef GL_ARB_draw_buffers -#define GL_ARB_draw_buffers 1 - -#define GL_MAX_DRAW_BUFFERS_ARB 0x8824 -#define GL_DRAW_BUFFER0_ARB 0x8825 -#define GL_DRAW_BUFFER1_ARB 0x8826 -#define GL_DRAW_BUFFER2_ARB 0x8827 -#define GL_DRAW_BUFFER3_ARB 0x8828 -#define GL_DRAW_BUFFER4_ARB 0x8829 -#define GL_DRAW_BUFFER5_ARB 0x882A -#define GL_DRAW_BUFFER6_ARB 0x882B -#define GL_DRAW_BUFFER7_ARB 0x882C -#define GL_DRAW_BUFFER8_ARB 0x882D -#define GL_DRAW_BUFFER9_ARB 0x882E -#define GL_DRAW_BUFFER10_ARB 0x882F -#define GL_DRAW_BUFFER11_ARB 0x8830 -#define GL_DRAW_BUFFER12_ARB 0x8831 -#define GL_DRAW_BUFFER13_ARB 0x8832 -#define GL_DRAW_BUFFER14_ARB 0x8833 -#define GL_DRAW_BUFFER15_ARB 0x8834 - -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSARBPROC) (GLsizei n, const GLenum* bufs); - -#define glDrawBuffersARB GLEW_GET_FUN(__glewDrawBuffersARB) - -#define GLEW_ARB_draw_buffers GLEW_GET_VAR(__GLEW_ARB_draw_buffers) - -#endif /* GL_ARB_draw_buffers */ - -/* ----------------------- GL_ARB_draw_buffers_blend ----------------------- */ - -#ifndef GL_ARB_draw_buffers_blend -#define GL_ARB_draw_buffers_blend 1 - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEIARBPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONIARBPROC) (GLuint buf, GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEIARBPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCIARBPROC) (GLuint buf, GLenum src, GLenum dst); - -#define glBlendEquationSeparateiARB GLEW_GET_FUN(__glewBlendEquationSeparateiARB) -#define glBlendEquationiARB GLEW_GET_FUN(__glewBlendEquationiARB) -#define glBlendFuncSeparateiARB GLEW_GET_FUN(__glewBlendFuncSeparateiARB) -#define glBlendFunciARB GLEW_GET_FUN(__glewBlendFunciARB) - -#define GLEW_ARB_draw_buffers_blend GLEW_GET_VAR(__GLEW_ARB_draw_buffers_blend) - -#endif /* GL_ARB_draw_buffers_blend */ - -/* -------------------- GL_ARB_draw_elements_base_vertex ------------------- */ - -#ifndef GL_ARB_draw_elements_base_vertex -#define GL_ARB_draw_elements_base_vertex 1 - -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, void* indices, GLint basevertex); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount, GLint basevertex); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, void* indices, GLint basevertex); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei* count, GLenum type, GLvoid**indices, GLsizei primcount, GLint *basevertex); - -#define glDrawElementsBaseVertex GLEW_GET_FUN(__glewDrawElementsBaseVertex) -#define glDrawElementsInstancedBaseVertex GLEW_GET_FUN(__glewDrawElementsInstancedBaseVertex) -#define glDrawRangeElementsBaseVertex GLEW_GET_FUN(__glewDrawRangeElementsBaseVertex) -#define glMultiDrawElementsBaseVertex GLEW_GET_FUN(__glewMultiDrawElementsBaseVertex) - -#define GLEW_ARB_draw_elements_base_vertex GLEW_GET_VAR(__GLEW_ARB_draw_elements_base_vertex) - -#endif /* GL_ARB_draw_elements_base_vertex */ - -/* -------------------------- GL_ARB_draw_indirect ------------------------- */ - -#ifndef GL_ARB_draw_indirect -#define GL_ARB_draw_indirect 1 - -#define GL_DRAW_INDIRECT_BUFFER 0x8F3F -#define GL_DRAW_INDIRECT_BUFFER_BINDING 0x8F43 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINDIRECTPROC) (GLenum mode, const void* indirect); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINDIRECTPROC) (GLenum mode, GLenum type, const void* indirect); - -#define glDrawArraysIndirect GLEW_GET_FUN(__glewDrawArraysIndirect) -#define glDrawElementsIndirect GLEW_GET_FUN(__glewDrawElementsIndirect) - -#define GLEW_ARB_draw_indirect GLEW_GET_VAR(__GLEW_ARB_draw_indirect) - -#endif /* GL_ARB_draw_indirect */ - -/* ------------------------- GL_ARB_draw_instanced ------------------------- */ - -#ifndef GL_ARB_draw_instanced -#define GL_ARB_draw_instanced 1 - -#define GLEW_ARB_draw_instanced GLEW_GET_VAR(__GLEW_ARB_draw_instanced) - -#endif /* GL_ARB_draw_instanced */ - -/* -------------------- GL_ARB_explicit_attrib_location -------------------- */ - -#ifndef GL_ARB_explicit_attrib_location -#define GL_ARB_explicit_attrib_location 1 - -#define GLEW_ARB_explicit_attrib_location GLEW_GET_VAR(__GLEW_ARB_explicit_attrib_location) - -#endif /* GL_ARB_explicit_attrib_location */ - -/* ------------------- GL_ARB_fragment_coord_conventions ------------------- */ - -#ifndef GL_ARB_fragment_coord_conventions -#define GL_ARB_fragment_coord_conventions 1 - -#define GLEW_ARB_fragment_coord_conventions GLEW_GET_VAR(__GLEW_ARB_fragment_coord_conventions) - -#endif /* GL_ARB_fragment_coord_conventions */ - -/* ------------------------ GL_ARB_fragment_program ------------------------ */ - -#ifndef GL_ARB_fragment_program -#define GL_ARB_fragment_program 1 - -#define GL_FRAGMENT_PROGRAM_ARB 0x8804 -#define GL_PROGRAM_ALU_INSTRUCTIONS_ARB 0x8805 -#define GL_PROGRAM_TEX_INSTRUCTIONS_ARB 0x8806 -#define GL_PROGRAM_TEX_INDIRECTIONS_ARB 0x8807 -#define GL_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x8808 -#define GL_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x8809 -#define GL_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x880A -#define GL_MAX_PROGRAM_ALU_INSTRUCTIONS_ARB 0x880B -#define GL_MAX_PROGRAM_TEX_INSTRUCTIONS_ARB 0x880C -#define GL_MAX_PROGRAM_TEX_INDIRECTIONS_ARB 0x880D -#define GL_MAX_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x880E -#define GL_MAX_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x880F -#define GL_MAX_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x8810 -#define GL_MAX_TEXTURE_COORDS_ARB 0x8871 -#define GL_MAX_TEXTURE_IMAGE_UNITS_ARB 0x8872 - -#define GLEW_ARB_fragment_program GLEW_GET_VAR(__GLEW_ARB_fragment_program) - -#endif /* GL_ARB_fragment_program */ - -/* --------------------- GL_ARB_fragment_program_shadow -------------------- */ - -#ifndef GL_ARB_fragment_program_shadow -#define GL_ARB_fragment_program_shadow 1 - -#define GLEW_ARB_fragment_program_shadow GLEW_GET_VAR(__GLEW_ARB_fragment_program_shadow) - -#endif /* GL_ARB_fragment_program_shadow */ - -/* ------------------------- GL_ARB_fragment_shader ------------------------ */ - -#ifndef GL_ARB_fragment_shader -#define GL_ARB_fragment_shader 1 - -#define GL_FRAGMENT_SHADER_ARB 0x8B30 -#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB 0x8B49 -#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT_ARB 0x8B8B - -#define GLEW_ARB_fragment_shader GLEW_GET_VAR(__GLEW_ARB_fragment_shader) - -#endif /* GL_ARB_fragment_shader */ - -/* ----------------------- GL_ARB_framebuffer_object ----------------------- */ - -#ifndef GL_ARB_framebuffer_object -#define GL_ARB_framebuffer_object 1 - -#define GL_INVALID_FRAMEBUFFER_OPERATION 0x0506 -#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210 -#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211 -#define GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212 -#define GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213 -#define GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214 -#define GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215 -#define GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216 -#define GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217 -#define GL_FRAMEBUFFER_DEFAULT 0x8218 -#define GL_FRAMEBUFFER_UNDEFINED 0x8219 -#define GL_DEPTH_STENCIL_ATTACHMENT 0x821A -#define GL_INDEX 0x8222 -#define GL_MAX_RENDERBUFFER_SIZE 0x84E8 -#define GL_DEPTH_STENCIL 0x84F9 -#define GL_UNSIGNED_INT_24_8 0x84FA -#define GL_DEPTH24_STENCIL8 0x88F0 -#define GL_TEXTURE_STENCIL_SIZE 0x88F1 -#define GL_UNSIGNED_NORMALIZED 0x8C17 -#define GL_SRGB 0x8C40 -#define GL_DRAW_FRAMEBUFFER_BINDING 0x8CA6 -#define GL_FRAMEBUFFER_BINDING 0x8CA6 -#define GL_RENDERBUFFER_BINDING 0x8CA7 -#define GL_READ_FRAMEBUFFER 0x8CA8 -#define GL_DRAW_FRAMEBUFFER 0x8CA9 -#define GL_READ_FRAMEBUFFER_BINDING 0x8CAA -#define GL_RENDERBUFFER_SAMPLES 0x8CAB -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE 0x8CD0 -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME 0x8CD1 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL 0x8CD2 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE 0x8CD3 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 -#define GL_FRAMEBUFFER_COMPLETE 0x8CD5 -#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6 -#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7 -#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER 0x8CDB -#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER 0x8CDC -#define GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD -#define GL_MAX_COLOR_ATTACHMENTS 0x8CDF -#define GL_COLOR_ATTACHMENT0 0x8CE0 -#define GL_COLOR_ATTACHMENT1 0x8CE1 -#define GL_COLOR_ATTACHMENT2 0x8CE2 -#define GL_COLOR_ATTACHMENT3 0x8CE3 -#define GL_COLOR_ATTACHMENT4 0x8CE4 -#define GL_COLOR_ATTACHMENT5 0x8CE5 -#define GL_COLOR_ATTACHMENT6 0x8CE6 -#define GL_COLOR_ATTACHMENT7 0x8CE7 -#define GL_COLOR_ATTACHMENT8 0x8CE8 -#define GL_COLOR_ATTACHMENT9 0x8CE9 -#define GL_COLOR_ATTACHMENT10 0x8CEA -#define GL_COLOR_ATTACHMENT11 0x8CEB -#define GL_COLOR_ATTACHMENT12 0x8CEC -#define GL_COLOR_ATTACHMENT13 0x8CED -#define GL_COLOR_ATTACHMENT14 0x8CEE -#define GL_COLOR_ATTACHMENT15 0x8CEF -#define GL_DEPTH_ATTACHMENT 0x8D00 -#define GL_STENCIL_ATTACHMENT 0x8D20 -#define GL_FRAMEBUFFER 0x8D40 -#define GL_RENDERBUFFER 0x8D41 -#define GL_RENDERBUFFER_WIDTH 0x8D42 -#define GL_RENDERBUFFER_HEIGHT 0x8D43 -#define GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44 -#define GL_STENCIL_INDEX1 0x8D46 -#define GL_STENCIL_INDEX4 0x8D47 -#define GL_STENCIL_INDEX8 0x8D48 -#define GL_STENCIL_INDEX16 0x8D49 -#define GL_RENDERBUFFER_RED_SIZE 0x8D50 -#define GL_RENDERBUFFER_GREEN_SIZE 0x8D51 -#define GL_RENDERBUFFER_BLUE_SIZE 0x8D52 -#define GL_RENDERBUFFER_ALPHA_SIZE 0x8D53 -#define GL_RENDERBUFFER_DEPTH_SIZE 0x8D54 -#define GL_RENDERBUFFER_STENCIL_SIZE 0x8D55 -#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56 -#define GL_MAX_SAMPLES 0x8D57 - -typedef void (GLAPIENTRY * PFNGLBINDFRAMEBUFFERPROC) (GLenum target, GLuint framebuffer); -typedef void (GLAPIENTRY * PFNGLBINDRENDERBUFFERPROC) (GLenum target, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFERPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); -typedef GLenum (GLAPIENTRY * PFNGLCHECKFRAMEBUFFERSTATUSPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLDELETEFRAMEBUFFERSPROC) (GLsizei n, const GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLDELETERENDERBUFFERSPROC) (GLsizei n, const GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERRENDERBUFFERPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE1DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE2DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE3DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint layer); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYERPROC) (GLenum target,GLenum attachment, GLuint texture,GLint level,GLint layer); -typedef void (GLAPIENTRY * PFNGLGENFRAMEBUFFERSPROC) (GLsizei n, GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLGENRENDERBUFFERSPROC) (GLsizei n, GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLGENERATEMIPMAPPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC) (GLenum target, GLenum attachment, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETRENDERBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISFRAMEBUFFERPROC) (GLuint framebuffer); -typedef GLboolean (GLAPIENTRY * PFNGLISRENDERBUFFERPROC) (GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glBindFramebuffer GLEW_GET_FUN(__glewBindFramebuffer) -#define glBindRenderbuffer GLEW_GET_FUN(__glewBindRenderbuffer) -#define glBlitFramebuffer GLEW_GET_FUN(__glewBlitFramebuffer) -#define glCheckFramebufferStatus GLEW_GET_FUN(__glewCheckFramebufferStatus) -#define glDeleteFramebuffers GLEW_GET_FUN(__glewDeleteFramebuffers) -#define glDeleteRenderbuffers GLEW_GET_FUN(__glewDeleteRenderbuffers) -#define glFramebufferRenderbuffer GLEW_GET_FUN(__glewFramebufferRenderbuffer) -#define glFramebufferTexture1D GLEW_GET_FUN(__glewFramebufferTexture1D) -#define glFramebufferTexture2D GLEW_GET_FUN(__glewFramebufferTexture2D) -#define glFramebufferTexture3D GLEW_GET_FUN(__glewFramebufferTexture3D) -#define glFramebufferTextureLayer GLEW_GET_FUN(__glewFramebufferTextureLayer) -#define glGenFramebuffers GLEW_GET_FUN(__glewGenFramebuffers) -#define glGenRenderbuffers GLEW_GET_FUN(__glewGenRenderbuffers) -#define glGenerateMipmap GLEW_GET_FUN(__glewGenerateMipmap) -#define glGetFramebufferAttachmentParameteriv GLEW_GET_FUN(__glewGetFramebufferAttachmentParameteriv) -#define glGetRenderbufferParameteriv GLEW_GET_FUN(__glewGetRenderbufferParameteriv) -#define glIsFramebuffer GLEW_GET_FUN(__glewIsFramebuffer) -#define glIsRenderbuffer GLEW_GET_FUN(__glewIsRenderbuffer) -#define glRenderbufferStorage GLEW_GET_FUN(__glewRenderbufferStorage) -#define glRenderbufferStorageMultisample GLEW_GET_FUN(__glewRenderbufferStorageMultisample) - -#define GLEW_ARB_framebuffer_object GLEW_GET_VAR(__GLEW_ARB_framebuffer_object) - -#endif /* GL_ARB_framebuffer_object */ - -/* ------------------------ GL_ARB_framebuffer_sRGB ------------------------ */ - -#ifndef GL_ARB_framebuffer_sRGB -#define GL_ARB_framebuffer_sRGB 1 - -#define GL_FRAMEBUFFER_SRGB 0x8DB9 - -#define GLEW_ARB_framebuffer_sRGB GLEW_GET_VAR(__GLEW_ARB_framebuffer_sRGB) - -#endif /* GL_ARB_framebuffer_sRGB */ - -/* ------------------------ GL_ARB_geometry_shader4 ------------------------ */ - -#ifndef GL_ARB_geometry_shader4 -#define GL_ARB_geometry_shader4 1 - -#define GL_LINES_ADJACENCY_ARB 0xA -#define GL_LINE_STRIP_ADJACENCY_ARB 0xB -#define GL_TRIANGLES_ADJACENCY_ARB 0xC -#define GL_TRIANGLE_STRIP_ADJACENCY_ARB 0xD -#define GL_PROGRAM_POINT_SIZE_ARB 0x8642 -#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_ARB 0x8C29 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 -#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_ARB 0x8DA7 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_ARB 0x8DA8 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_ARB 0x8DA9 -#define GL_GEOMETRY_SHADER_ARB 0x8DD9 -#define GL_GEOMETRY_VERTICES_OUT_ARB 0x8DDA -#define GL_GEOMETRY_INPUT_TYPE_ARB 0x8DDB -#define GL_GEOMETRY_OUTPUT_TYPE_ARB 0x8DDC -#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_ARB 0x8DDD -#define GL_MAX_VERTEX_VARYING_COMPONENTS_ARB 0x8DDE -#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_ARB 0x8DDF -#define GL_MAX_GEOMETRY_OUTPUT_VERTICES_ARB 0x8DE0 -#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_ARB 0x8DE1 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREFACEARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYERARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIARBPROC) (GLuint program, GLenum pname, GLint value); - -#define glFramebufferTextureARB GLEW_GET_FUN(__glewFramebufferTextureARB) -#define glFramebufferTextureFaceARB GLEW_GET_FUN(__glewFramebufferTextureFaceARB) -#define glFramebufferTextureLayerARB GLEW_GET_FUN(__glewFramebufferTextureLayerARB) -#define glProgramParameteriARB GLEW_GET_FUN(__glewProgramParameteriARB) - -#define GLEW_ARB_geometry_shader4 GLEW_GET_VAR(__GLEW_ARB_geometry_shader4) - -#endif /* GL_ARB_geometry_shader4 */ - -/* ----------------------- GL_ARB_get_program_binary ----------------------- */ - -#ifndef GL_ARB_get_program_binary -#define GL_ARB_get_program_binary 1 - -#define GL_PROGRAM_BINARY_RETRIEVABLE_HINT 0x8257 -#define GL_PROGRAM_BINARY_LENGTH 0x8741 -#define GL_NUM_PROGRAM_BINARY_FORMATS 0x87FE -#define GL_PROGRAM_BINARY_FORMATS 0x87FF - -typedef void (GLAPIENTRY * PFNGLGETPROGRAMBINARYPROC) (GLuint program, GLsizei bufSize, GLsizei* length, GLenum *binaryFormat, GLvoid*binary); -typedef void (GLAPIENTRY * PFNGLPROGRAMBINARYPROC) (GLuint program, GLenum binaryFormat, const void* binary, GLsizei length); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIPROC) (GLuint program, GLenum pname, GLint value); - -#define glGetProgramBinary GLEW_GET_FUN(__glewGetProgramBinary) -#define glProgramBinary GLEW_GET_FUN(__glewProgramBinary) -#define glProgramParameteri GLEW_GET_FUN(__glewProgramParameteri) - -#define GLEW_ARB_get_program_binary GLEW_GET_VAR(__GLEW_ARB_get_program_binary) - -#endif /* GL_ARB_get_program_binary */ - -/* --------------------------- GL_ARB_gpu_shader5 -------------------------- */ - -#ifndef GL_ARB_gpu_shader5 -#define GL_ARB_gpu_shader5 1 - -#define GL_GEOMETRY_SHADER_INVOCATIONS 0x887F -#define GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A -#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B -#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C -#define GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D -#define GL_MAX_VERTEX_STREAMS 0x8E71 - -#define GLEW_ARB_gpu_shader5 GLEW_GET_VAR(__GLEW_ARB_gpu_shader5) - -#endif /* GL_ARB_gpu_shader5 */ - -/* ------------------------- GL_ARB_gpu_shader_fp64 ------------------------ */ - -#ifndef GL_ARB_gpu_shader_fp64 -#define GL_ARB_gpu_shader_fp64 1 - -#define GL_DOUBLE_MAT2 0x8F46 -#define GL_DOUBLE_MAT3 0x8F47 -#define GL_DOUBLE_MAT4 0x8F48 -#define GL_DOUBLE_MAT2x3 0x8F49 -#define GL_DOUBLE_MAT2x4 0x8F4A -#define GL_DOUBLE_MAT3x2 0x8F4B -#define GL_DOUBLE_MAT3x4 0x8F4C -#define GL_DOUBLE_MAT4x2 0x8F4D -#define GL_DOUBLE_MAT4x3 0x8F4E -#define GL_DOUBLE_VEC2 0x8FFC -#define GL_DOUBLE_VEC3 0x8FFD -#define GL_DOUBLE_VEC4 0x8FFE - -typedef void (GLAPIENTRY * PFNGLGETUNIFORMDVPROC) (GLuint program, GLint location, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1DEXTPROC) (GLuint program, GLint location, GLdouble x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2DEXTPROC) (GLuint program, GLint location, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3DEXTPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4DEXTPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1DPROC) (GLint location, GLdouble x); -typedef void (GLAPIENTRY * PFNGLUNIFORM1DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2DPROC) (GLint location, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLUNIFORM2DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3DPROC) (GLint location, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLUNIFORM3DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4DPROC) (GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLUNIFORM4DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); - -#define glGetUniformdv GLEW_GET_FUN(__glewGetUniformdv) -#define glProgramUniform1dEXT GLEW_GET_FUN(__glewProgramUniform1dEXT) -#define glProgramUniform1dvEXT GLEW_GET_FUN(__glewProgramUniform1dvEXT) -#define glProgramUniform2dEXT GLEW_GET_FUN(__glewProgramUniform2dEXT) -#define glProgramUniform2dvEXT GLEW_GET_FUN(__glewProgramUniform2dvEXT) -#define glProgramUniform3dEXT GLEW_GET_FUN(__glewProgramUniform3dEXT) -#define glProgramUniform3dvEXT GLEW_GET_FUN(__glewProgramUniform3dvEXT) -#define glProgramUniform4dEXT GLEW_GET_FUN(__glewProgramUniform4dEXT) -#define glProgramUniform4dvEXT GLEW_GET_FUN(__glewProgramUniform4dvEXT) -#define glProgramUniformMatrix2dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2dvEXT) -#define glProgramUniformMatrix2x3dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x3dvEXT) -#define glProgramUniformMatrix2x4dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x4dvEXT) -#define glProgramUniformMatrix3dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3dvEXT) -#define glProgramUniformMatrix3x2dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x2dvEXT) -#define glProgramUniformMatrix3x4dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x4dvEXT) -#define glProgramUniformMatrix4dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4dvEXT) -#define glProgramUniformMatrix4x2dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x2dvEXT) -#define glProgramUniformMatrix4x3dvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x3dvEXT) -#define glUniform1d GLEW_GET_FUN(__glewUniform1d) -#define glUniform1dv GLEW_GET_FUN(__glewUniform1dv) -#define glUniform2d GLEW_GET_FUN(__glewUniform2d) -#define glUniform2dv GLEW_GET_FUN(__glewUniform2dv) -#define glUniform3d GLEW_GET_FUN(__glewUniform3d) -#define glUniform3dv GLEW_GET_FUN(__glewUniform3dv) -#define glUniform4d GLEW_GET_FUN(__glewUniform4d) -#define glUniform4dv GLEW_GET_FUN(__glewUniform4dv) -#define glUniformMatrix2dv GLEW_GET_FUN(__glewUniformMatrix2dv) -#define glUniformMatrix2x3dv GLEW_GET_FUN(__glewUniformMatrix2x3dv) -#define glUniformMatrix2x4dv GLEW_GET_FUN(__glewUniformMatrix2x4dv) -#define glUniformMatrix3dv GLEW_GET_FUN(__glewUniformMatrix3dv) -#define glUniformMatrix3x2dv GLEW_GET_FUN(__glewUniformMatrix3x2dv) -#define glUniformMatrix3x4dv GLEW_GET_FUN(__glewUniformMatrix3x4dv) -#define glUniformMatrix4dv GLEW_GET_FUN(__glewUniformMatrix4dv) -#define glUniformMatrix4x2dv GLEW_GET_FUN(__glewUniformMatrix4x2dv) -#define glUniformMatrix4x3dv GLEW_GET_FUN(__glewUniformMatrix4x3dv) - -#define GLEW_ARB_gpu_shader_fp64 GLEW_GET_VAR(__GLEW_ARB_gpu_shader_fp64) - -#endif /* GL_ARB_gpu_shader_fp64 */ - -/* ------------------------ GL_ARB_half_float_pixel ------------------------ */ - -#ifndef GL_ARB_half_float_pixel -#define GL_ARB_half_float_pixel 1 - -#define GL_HALF_FLOAT_ARB 0x140B - -#define GLEW_ARB_half_float_pixel GLEW_GET_VAR(__GLEW_ARB_half_float_pixel) - -#endif /* GL_ARB_half_float_pixel */ - -/* ------------------------ GL_ARB_half_float_vertex ----------------------- */ - -#ifndef GL_ARB_half_float_vertex -#define GL_ARB_half_float_vertex 1 - -#define GL_HALF_FLOAT 0x140B - -#define GLEW_ARB_half_float_vertex GLEW_GET_VAR(__GLEW_ARB_half_float_vertex) - -#endif /* GL_ARB_half_float_vertex */ - -/* ----------------------------- GL_ARB_imaging ---------------------------- */ - -#ifndef GL_ARB_imaging -#define GL_ARB_imaging 1 - -#define GL_CONSTANT_COLOR 0x8001 -#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 -#define GL_CONSTANT_ALPHA 0x8003 -#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 -#define GL_BLEND_COLOR 0x8005 -#define GL_FUNC_ADD 0x8006 -#define GL_MIN 0x8007 -#define GL_MAX 0x8008 -#define GL_BLEND_EQUATION 0x8009 -#define GL_FUNC_SUBTRACT 0x800A -#define GL_FUNC_REVERSE_SUBTRACT 0x800B -#define GL_CONVOLUTION_1D 0x8010 -#define GL_CONVOLUTION_2D 0x8011 -#define GL_SEPARABLE_2D 0x8012 -#define GL_CONVOLUTION_BORDER_MODE 0x8013 -#define GL_CONVOLUTION_FILTER_SCALE 0x8014 -#define GL_CONVOLUTION_FILTER_BIAS 0x8015 -#define GL_REDUCE 0x8016 -#define GL_CONVOLUTION_FORMAT 0x8017 -#define GL_CONVOLUTION_WIDTH 0x8018 -#define GL_CONVOLUTION_HEIGHT 0x8019 -#define GL_MAX_CONVOLUTION_WIDTH 0x801A -#define GL_MAX_CONVOLUTION_HEIGHT 0x801B -#define GL_POST_CONVOLUTION_RED_SCALE 0x801C -#define GL_POST_CONVOLUTION_GREEN_SCALE 0x801D -#define GL_POST_CONVOLUTION_BLUE_SCALE 0x801E -#define GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F -#define GL_POST_CONVOLUTION_RED_BIAS 0x8020 -#define GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 -#define GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 -#define GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 -#define GL_HISTOGRAM 0x8024 -#define GL_PROXY_HISTOGRAM 0x8025 -#define GL_HISTOGRAM_WIDTH 0x8026 -#define GL_HISTOGRAM_FORMAT 0x8027 -#define GL_HISTOGRAM_RED_SIZE 0x8028 -#define GL_HISTOGRAM_GREEN_SIZE 0x8029 -#define GL_HISTOGRAM_BLUE_SIZE 0x802A -#define GL_HISTOGRAM_ALPHA_SIZE 0x802B -#define GL_HISTOGRAM_LUMINANCE_SIZE 0x802C -#define GL_HISTOGRAM_SINK 0x802D -#define GL_MINMAX 0x802E -#define GL_MINMAX_FORMAT 0x802F -#define GL_MINMAX_SINK 0x8030 -#define GL_TABLE_TOO_LARGE 0x8031 -#define GL_COLOR_MATRIX 0x80B1 -#define GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 -#define GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 -#define GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 -#define GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 -#define GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 -#define GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 -#define GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 -#define GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 -#define GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA -#define GL_POST_COLOR_MATRIX_ALPHA_BIAS 0x80BB -#define GL_COLOR_TABLE 0x80D0 -#define GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 -#define GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 -#define GL_PROXY_COLOR_TABLE 0x80D3 -#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 -#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 -#define GL_COLOR_TABLE_SCALE 0x80D6 -#define GL_COLOR_TABLE_BIAS 0x80D7 -#define GL_COLOR_TABLE_FORMAT 0x80D8 -#define GL_COLOR_TABLE_WIDTH 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF -#define GL_IGNORE_BORDER 0x8150 -#define GL_CONSTANT_BORDER 0x8151 -#define GL_WRAP_BORDER 0x8152 -#define GL_REPLICATE_BORDER 0x8153 -#define GL_CONVOLUTION_BORDER_COLOR 0x8154 - -typedef void (GLAPIENTRY * PFNGLCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIPROC) (GLenum target, GLenum pname, GLint params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPROC) (GLenum target, GLboolean reset, GLenum format, GLenum types, GLvoid *values); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETSEPARABLEFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); -typedef void (GLAPIENTRY * PFNGLHISTOGRAMPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLMINMAXPROC) (GLenum target, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLRESETHISTOGRAMPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLRESETMINMAXPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLSEPARABLEFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); - -#define glColorSubTable GLEW_GET_FUN(__glewColorSubTable) -#define glColorTable GLEW_GET_FUN(__glewColorTable) -#define glColorTableParameterfv GLEW_GET_FUN(__glewColorTableParameterfv) -#define glColorTableParameteriv GLEW_GET_FUN(__glewColorTableParameteriv) -#define glConvolutionFilter1D GLEW_GET_FUN(__glewConvolutionFilter1D) -#define glConvolutionFilter2D GLEW_GET_FUN(__glewConvolutionFilter2D) -#define glConvolutionParameterf GLEW_GET_FUN(__glewConvolutionParameterf) -#define glConvolutionParameterfv GLEW_GET_FUN(__glewConvolutionParameterfv) -#define glConvolutionParameteri GLEW_GET_FUN(__glewConvolutionParameteri) -#define glConvolutionParameteriv GLEW_GET_FUN(__glewConvolutionParameteriv) -#define glCopyColorSubTable GLEW_GET_FUN(__glewCopyColorSubTable) -#define glCopyColorTable GLEW_GET_FUN(__glewCopyColorTable) -#define glCopyConvolutionFilter1D GLEW_GET_FUN(__glewCopyConvolutionFilter1D) -#define glCopyConvolutionFilter2D GLEW_GET_FUN(__glewCopyConvolutionFilter2D) -#define glGetColorTable GLEW_GET_FUN(__glewGetColorTable) -#define glGetColorTableParameterfv GLEW_GET_FUN(__glewGetColorTableParameterfv) -#define glGetColorTableParameteriv GLEW_GET_FUN(__glewGetColorTableParameteriv) -#define glGetConvolutionFilter GLEW_GET_FUN(__glewGetConvolutionFilter) -#define glGetConvolutionParameterfv GLEW_GET_FUN(__glewGetConvolutionParameterfv) -#define glGetConvolutionParameteriv GLEW_GET_FUN(__glewGetConvolutionParameteriv) -#define glGetHistogram GLEW_GET_FUN(__glewGetHistogram) -#define glGetHistogramParameterfv GLEW_GET_FUN(__glewGetHistogramParameterfv) -#define glGetHistogramParameteriv GLEW_GET_FUN(__glewGetHistogramParameteriv) -#define glGetMinmax GLEW_GET_FUN(__glewGetMinmax) -#define glGetMinmaxParameterfv GLEW_GET_FUN(__glewGetMinmaxParameterfv) -#define glGetMinmaxParameteriv GLEW_GET_FUN(__glewGetMinmaxParameteriv) -#define glGetSeparableFilter GLEW_GET_FUN(__glewGetSeparableFilter) -#define glHistogram GLEW_GET_FUN(__glewHistogram) -#define glMinmax GLEW_GET_FUN(__glewMinmax) -#define glResetHistogram GLEW_GET_FUN(__glewResetHistogram) -#define glResetMinmax GLEW_GET_FUN(__glewResetMinmax) -#define glSeparableFilter2D GLEW_GET_FUN(__glewSeparableFilter2D) - -#define GLEW_ARB_imaging GLEW_GET_VAR(__GLEW_ARB_imaging) - -#endif /* GL_ARB_imaging */ - -/* ------------------------ GL_ARB_instanced_arrays ------------------------ */ - -#ifndef GL_ARB_instanced_arrays -#define GL_ARB_instanced_arrays 1 - -#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ARB 0x88FE - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDARBPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDARBPROC) (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBDIVISORARBPROC) (GLuint index, GLuint divisor); - -#define glDrawArraysInstancedARB GLEW_GET_FUN(__glewDrawArraysInstancedARB) -#define glDrawElementsInstancedARB GLEW_GET_FUN(__glewDrawElementsInstancedARB) -#define glVertexAttribDivisorARB GLEW_GET_FUN(__glewVertexAttribDivisorARB) - -#define GLEW_ARB_instanced_arrays GLEW_GET_VAR(__GLEW_ARB_instanced_arrays) - -#endif /* GL_ARB_instanced_arrays */ - -/* ------------------------ GL_ARB_map_buffer_range ------------------------ */ - -#ifndef GL_ARB_map_buffer_range -#define GL_ARB_map_buffer_range 1 - -#define GL_MAP_READ_BIT 0x0001 -#define GL_MAP_WRITE_BIT 0x0002 -#define GL_MAP_INVALIDATE_RANGE_BIT 0x0004 -#define GL_MAP_INVALIDATE_BUFFER_BIT 0x0008 -#define GL_MAP_FLUSH_EXPLICIT_BIT 0x0010 -#define GL_MAP_UNSYNCHRONIZED_BIT 0x0020 - -typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); - -#define glFlushMappedBufferRange GLEW_GET_FUN(__glewFlushMappedBufferRange) -#define glMapBufferRange GLEW_GET_FUN(__glewMapBufferRange) - -#define GLEW_ARB_map_buffer_range GLEW_GET_VAR(__GLEW_ARB_map_buffer_range) - -#endif /* GL_ARB_map_buffer_range */ - -/* ------------------------- GL_ARB_matrix_palette ------------------------- */ - -#ifndef GL_ARB_matrix_palette -#define GL_ARB_matrix_palette 1 - -#define GL_MATRIX_PALETTE_ARB 0x8840 -#define GL_MAX_MATRIX_PALETTE_STACK_DEPTH_ARB 0x8841 -#define GL_MAX_PALETTE_MATRICES_ARB 0x8842 -#define GL_CURRENT_PALETTE_MATRIX_ARB 0x8843 -#define GL_MATRIX_INDEX_ARRAY_ARB 0x8844 -#define GL_CURRENT_MATRIX_INDEX_ARB 0x8845 -#define GL_MATRIX_INDEX_ARRAY_SIZE_ARB 0x8846 -#define GL_MATRIX_INDEX_ARRAY_TYPE_ARB 0x8847 -#define GL_MATRIX_INDEX_ARRAY_STRIDE_ARB 0x8848 -#define GL_MATRIX_INDEX_ARRAY_POINTER_ARB 0x8849 - -typedef void (GLAPIENTRY * PFNGLCURRENTPALETTEMATRIXARBPROC) (GLint index); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUBVARBPROC) (GLint size, GLubyte *indices); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUIVARBPROC) (GLint size, GLuint *indices); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUSVARBPROC) (GLint size, GLushort *indices); - -#define glCurrentPaletteMatrixARB GLEW_GET_FUN(__glewCurrentPaletteMatrixARB) -#define glMatrixIndexPointerARB GLEW_GET_FUN(__glewMatrixIndexPointerARB) -#define glMatrixIndexubvARB GLEW_GET_FUN(__glewMatrixIndexubvARB) -#define glMatrixIndexuivARB GLEW_GET_FUN(__glewMatrixIndexuivARB) -#define glMatrixIndexusvARB GLEW_GET_FUN(__glewMatrixIndexusvARB) - -#define GLEW_ARB_matrix_palette GLEW_GET_VAR(__GLEW_ARB_matrix_palette) - -#endif /* GL_ARB_matrix_palette */ - -/* --------------------------- GL_ARB_multisample -------------------------- */ - -#ifndef GL_ARB_multisample -#define GL_ARB_multisample 1 - -#define GL_MULTISAMPLE_ARB 0x809D -#define GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F -#define GL_SAMPLE_COVERAGE_ARB 0x80A0 -#define GL_SAMPLE_BUFFERS_ARB 0x80A8 -#define GL_SAMPLES_ARB 0x80A9 -#define GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA -#define GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB -#define GL_MULTISAMPLE_BIT_ARB 0x20000000 - -typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEARBPROC) (GLclampf value, GLboolean invert); - -#define glSampleCoverageARB GLEW_GET_FUN(__glewSampleCoverageARB) - -#define GLEW_ARB_multisample GLEW_GET_VAR(__GLEW_ARB_multisample) - -#endif /* GL_ARB_multisample */ - -/* -------------------------- GL_ARB_multitexture -------------------------- */ - -#ifndef GL_ARB_multitexture -#define GL_ARB_multitexture 1 - -#define GL_TEXTURE0_ARB 0x84C0 -#define GL_TEXTURE1_ARB 0x84C1 -#define GL_TEXTURE2_ARB 0x84C2 -#define GL_TEXTURE3_ARB 0x84C3 -#define GL_TEXTURE4_ARB 0x84C4 -#define GL_TEXTURE5_ARB 0x84C5 -#define GL_TEXTURE6_ARB 0x84C6 -#define GL_TEXTURE7_ARB 0x84C7 -#define GL_TEXTURE8_ARB 0x84C8 -#define GL_TEXTURE9_ARB 0x84C9 -#define GL_TEXTURE10_ARB 0x84CA -#define GL_TEXTURE11_ARB 0x84CB -#define GL_TEXTURE12_ARB 0x84CC -#define GL_TEXTURE13_ARB 0x84CD -#define GL_TEXTURE14_ARB 0x84CE -#define GL_TEXTURE15_ARB 0x84CF -#define GL_TEXTURE16_ARB 0x84D0 -#define GL_TEXTURE17_ARB 0x84D1 -#define GL_TEXTURE18_ARB 0x84D2 -#define GL_TEXTURE19_ARB 0x84D3 -#define GL_TEXTURE20_ARB 0x84D4 -#define GL_TEXTURE21_ARB 0x84D5 -#define GL_TEXTURE22_ARB 0x84D6 -#define GL_TEXTURE23_ARB 0x84D7 -#define GL_TEXTURE24_ARB 0x84D8 -#define GL_TEXTURE25_ARB 0x84D9 -#define GL_TEXTURE26_ARB 0x84DA -#define GL_TEXTURE27_ARB 0x84DB -#define GL_TEXTURE28_ARB 0x84DC -#define GL_TEXTURE29_ARB 0x84DD -#define GL_TEXTURE30_ARB 0x84DE -#define GL_TEXTURE31_ARB 0x84DF -#define GL_ACTIVE_TEXTURE_ARB 0x84E0 -#define GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 -#define GL_MAX_TEXTURE_UNITS_ARB 0x84E2 - -typedef void (GLAPIENTRY * PFNGLACTIVETEXTUREARBPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); - -#define glActiveTextureARB GLEW_GET_FUN(__glewActiveTextureARB) -#define glClientActiveTextureARB GLEW_GET_FUN(__glewClientActiveTextureARB) -#define glMultiTexCoord1dARB GLEW_GET_FUN(__glewMultiTexCoord1dARB) -#define glMultiTexCoord1dvARB GLEW_GET_FUN(__glewMultiTexCoord1dvARB) -#define glMultiTexCoord1fARB GLEW_GET_FUN(__glewMultiTexCoord1fARB) -#define glMultiTexCoord1fvARB GLEW_GET_FUN(__glewMultiTexCoord1fvARB) -#define glMultiTexCoord1iARB GLEW_GET_FUN(__glewMultiTexCoord1iARB) -#define glMultiTexCoord1ivARB GLEW_GET_FUN(__glewMultiTexCoord1ivARB) -#define glMultiTexCoord1sARB GLEW_GET_FUN(__glewMultiTexCoord1sARB) -#define glMultiTexCoord1svARB GLEW_GET_FUN(__glewMultiTexCoord1svARB) -#define glMultiTexCoord2dARB GLEW_GET_FUN(__glewMultiTexCoord2dARB) -#define glMultiTexCoord2dvARB GLEW_GET_FUN(__glewMultiTexCoord2dvARB) -#define glMultiTexCoord2fARB GLEW_GET_FUN(__glewMultiTexCoord2fARB) -#define glMultiTexCoord2fvARB GLEW_GET_FUN(__glewMultiTexCoord2fvARB) -#define glMultiTexCoord2iARB GLEW_GET_FUN(__glewMultiTexCoord2iARB) -#define glMultiTexCoord2ivARB GLEW_GET_FUN(__glewMultiTexCoord2ivARB) -#define glMultiTexCoord2sARB GLEW_GET_FUN(__glewMultiTexCoord2sARB) -#define glMultiTexCoord2svARB GLEW_GET_FUN(__glewMultiTexCoord2svARB) -#define glMultiTexCoord3dARB GLEW_GET_FUN(__glewMultiTexCoord3dARB) -#define glMultiTexCoord3dvARB GLEW_GET_FUN(__glewMultiTexCoord3dvARB) -#define glMultiTexCoord3fARB GLEW_GET_FUN(__glewMultiTexCoord3fARB) -#define glMultiTexCoord3fvARB GLEW_GET_FUN(__glewMultiTexCoord3fvARB) -#define glMultiTexCoord3iARB GLEW_GET_FUN(__glewMultiTexCoord3iARB) -#define glMultiTexCoord3ivARB GLEW_GET_FUN(__glewMultiTexCoord3ivARB) -#define glMultiTexCoord3sARB GLEW_GET_FUN(__glewMultiTexCoord3sARB) -#define glMultiTexCoord3svARB GLEW_GET_FUN(__glewMultiTexCoord3svARB) -#define glMultiTexCoord4dARB GLEW_GET_FUN(__glewMultiTexCoord4dARB) -#define glMultiTexCoord4dvARB GLEW_GET_FUN(__glewMultiTexCoord4dvARB) -#define glMultiTexCoord4fARB GLEW_GET_FUN(__glewMultiTexCoord4fARB) -#define glMultiTexCoord4fvARB GLEW_GET_FUN(__glewMultiTexCoord4fvARB) -#define glMultiTexCoord4iARB GLEW_GET_FUN(__glewMultiTexCoord4iARB) -#define glMultiTexCoord4ivARB GLEW_GET_FUN(__glewMultiTexCoord4ivARB) -#define glMultiTexCoord4sARB GLEW_GET_FUN(__glewMultiTexCoord4sARB) -#define glMultiTexCoord4svARB GLEW_GET_FUN(__glewMultiTexCoord4svARB) - -#define GLEW_ARB_multitexture GLEW_GET_VAR(__GLEW_ARB_multitexture) - -#endif /* GL_ARB_multitexture */ - -/* ------------------------- GL_ARB_occlusion_query ------------------------ */ - -#ifndef GL_ARB_occlusion_query -#define GL_ARB_occlusion_query 1 - -#define GL_QUERY_COUNTER_BITS_ARB 0x8864 -#define GL_CURRENT_QUERY_ARB 0x8865 -#define GL_QUERY_RESULT_ARB 0x8866 -#define GL_QUERY_RESULT_AVAILABLE_ARB 0x8867 -#define GL_SAMPLES_PASSED_ARB 0x8914 - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYARBPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEQUERIESARBPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDQUERYARBPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGENQUERIESARBPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVARBPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVARBPROC) (GLuint id, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYIVARBPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISQUERYARBPROC) (GLuint id); - -#define glBeginQueryARB GLEW_GET_FUN(__glewBeginQueryARB) -#define glDeleteQueriesARB GLEW_GET_FUN(__glewDeleteQueriesARB) -#define glEndQueryARB GLEW_GET_FUN(__glewEndQueryARB) -#define glGenQueriesARB GLEW_GET_FUN(__glewGenQueriesARB) -#define glGetQueryObjectivARB GLEW_GET_FUN(__glewGetQueryObjectivARB) -#define glGetQueryObjectuivARB GLEW_GET_FUN(__glewGetQueryObjectuivARB) -#define glGetQueryivARB GLEW_GET_FUN(__glewGetQueryivARB) -#define glIsQueryARB GLEW_GET_FUN(__glewIsQueryARB) - -#define GLEW_ARB_occlusion_query GLEW_GET_VAR(__GLEW_ARB_occlusion_query) - -#endif /* GL_ARB_occlusion_query */ - -/* ------------------------ GL_ARB_occlusion_query2 ------------------------ */ - -#ifndef GL_ARB_occlusion_query2 -#define GL_ARB_occlusion_query2 1 - -#define GL_ANY_SAMPLES_PASSED 0x8C2F - -#define GLEW_ARB_occlusion_query2 GLEW_GET_VAR(__GLEW_ARB_occlusion_query2) - -#endif /* GL_ARB_occlusion_query2 */ - -/* ----------------------- GL_ARB_pixel_buffer_object ---------------------- */ - -#ifndef GL_ARB_pixel_buffer_object -#define GL_ARB_pixel_buffer_object 1 - -#define GL_PIXEL_PACK_BUFFER_ARB 0x88EB -#define GL_PIXEL_UNPACK_BUFFER_ARB 0x88EC -#define GL_PIXEL_PACK_BUFFER_BINDING_ARB 0x88ED -#define GL_PIXEL_UNPACK_BUFFER_BINDING_ARB 0x88EF - -#define GLEW_ARB_pixel_buffer_object GLEW_GET_VAR(__GLEW_ARB_pixel_buffer_object) - -#endif /* GL_ARB_pixel_buffer_object */ - -/* ------------------------ GL_ARB_point_parameters ------------------------ */ - -#ifndef GL_ARB_point_parameters -#define GL_ARB_point_parameters 1 - -#define GL_POINT_SIZE_MIN_ARB 0x8126 -#define GL_POINT_SIZE_MAX_ARB 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE_ARB 0x8128 -#define GL_POINT_DISTANCE_ATTENUATION_ARB 0x8129 - -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFARBPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVARBPROC) (GLenum pname, const GLfloat* params); - -#define glPointParameterfARB GLEW_GET_FUN(__glewPointParameterfARB) -#define glPointParameterfvARB GLEW_GET_FUN(__glewPointParameterfvARB) - -#define GLEW_ARB_point_parameters GLEW_GET_VAR(__GLEW_ARB_point_parameters) - -#endif /* GL_ARB_point_parameters */ - -/* -------------------------- GL_ARB_point_sprite -------------------------- */ - -#ifndef GL_ARB_point_sprite -#define GL_ARB_point_sprite 1 - -#define GL_POINT_SPRITE_ARB 0x8861 -#define GL_COORD_REPLACE_ARB 0x8862 - -#define GLEW_ARB_point_sprite GLEW_GET_VAR(__GLEW_ARB_point_sprite) - -#endif /* GL_ARB_point_sprite */ - -/* ------------------------ GL_ARB_provoking_vertex ------------------------ */ - -#ifndef GL_ARB_provoking_vertex -#define GL_ARB_provoking_vertex 1 - -#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION 0x8E4C -#define GL_FIRST_VERTEX_CONVENTION 0x8E4D -#define GL_LAST_VERTEX_CONVENTION 0x8E4E -#define GL_PROVOKING_VERTEX 0x8E4F - -typedef void (GLAPIENTRY * PFNGLPROVOKINGVERTEXPROC) (GLenum mode); - -#define glProvokingVertex GLEW_GET_FUN(__glewProvokingVertex) - -#define GLEW_ARB_provoking_vertex GLEW_GET_VAR(__GLEW_ARB_provoking_vertex) - -#endif /* GL_ARB_provoking_vertex */ - -/* --------------------------- GL_ARB_robustness --------------------------- */ - -#ifndef GL_ARB_robustness -#define GL_ARB_robustness 1 - -#define GL_CONTEXT_FLAG_ROBUST_ACCESS_BIT_ARB 0x00000004 -#define GL_LOSE_CONTEXT_ON_RESET_ARB 0x8252 -#define GL_GUILTY_CONTEXT_RESET_ARB 0x8253 -#define GL_INNOCENT_CONTEXT_RESET_ARB 0x8254 -#define GL_UNKNOWN_CONTEXT_RESET_ARB 0x8255 -#define GL_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 -#define GL_NO_RESET_NOTIFICATION_ARB 0x8261 - -typedef void (GLAPIENTRY * PFNGLGETNCOLORTABLEARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void* table); -typedef void (GLAPIENTRY * PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint lod, GLsizei bufSize, void* img); -typedef void (GLAPIENTRY * PFNGLGETNCONVOLUTIONFILTERARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void* image); -typedef void (GLAPIENTRY * PFNGLGETNHISTOGRAMARBPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void* values); -typedef void (GLAPIENTRY * PFNGLGETNMAPDVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLdouble* v); -typedef void (GLAPIENTRY * PFNGLGETNMAPFVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLfloat* v); -typedef void (GLAPIENTRY * PFNGLGETNMAPIVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLint* v); -typedef void (GLAPIENTRY * PFNGLGETNMINMAXARBPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void* values); -typedef void (GLAPIENTRY * PFNGLGETNPIXELMAPFVARBPROC) (GLenum map, GLsizei bufSize, GLfloat* values); -typedef void (GLAPIENTRY * PFNGLGETNPIXELMAPUIVARBPROC) (GLenum map, GLsizei bufSize, GLuint* values); -typedef void (GLAPIENTRY * PFNGLGETNPIXELMAPUSVARBPROC) (GLenum map, GLsizei bufSize, GLushort* values); -typedef void (GLAPIENTRY * PFNGLGETNPOLYGONSTIPPLEARBPROC) (GLsizei bufSize, GLubyte* pattern); -typedef void (GLAPIENTRY * PFNGLGETNSEPARABLEFILTERARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei rowBufSize, void* row, GLsizei columnBufSize, GLvoid*column, GLvoid*span); -typedef void (GLAPIENTRY * PFNGLGETNTEXIMAGEARBPROC) (GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void* img); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMDVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMFVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMIVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMUIVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLuint* params); -typedef void (GLAPIENTRY * PFNGLREADNPIXELSARBPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, void* data); - -#define glGetnColorTableARB GLEW_GET_FUN(__glewGetnColorTableARB) -#define glGetnCompressedTexImageARB GLEW_GET_FUN(__glewGetnCompressedTexImageARB) -#define glGetnConvolutionFilterARB GLEW_GET_FUN(__glewGetnConvolutionFilterARB) -#define glGetnHistogramARB GLEW_GET_FUN(__glewGetnHistogramARB) -#define glGetnMapdvARB GLEW_GET_FUN(__glewGetnMapdvARB) -#define glGetnMapfvARB GLEW_GET_FUN(__glewGetnMapfvARB) -#define glGetnMapivARB GLEW_GET_FUN(__glewGetnMapivARB) -#define glGetnMinmaxARB GLEW_GET_FUN(__glewGetnMinmaxARB) -#define glGetnPixelMapfvARB GLEW_GET_FUN(__glewGetnPixelMapfvARB) -#define glGetnPixelMapuivARB GLEW_GET_FUN(__glewGetnPixelMapuivARB) -#define glGetnPixelMapusvARB GLEW_GET_FUN(__glewGetnPixelMapusvARB) -#define glGetnPolygonStippleARB GLEW_GET_FUN(__glewGetnPolygonStippleARB) -#define glGetnSeparableFilterARB GLEW_GET_FUN(__glewGetnSeparableFilterARB) -#define glGetnTexImageARB GLEW_GET_FUN(__glewGetnTexImageARB) -#define glGetnUniformdvARB GLEW_GET_FUN(__glewGetnUniformdvARB) -#define glGetnUniformfvARB GLEW_GET_FUN(__glewGetnUniformfvARB) -#define glGetnUniformivARB GLEW_GET_FUN(__glewGetnUniformivARB) -#define glGetnUniformuivARB GLEW_GET_FUN(__glewGetnUniformuivARB) -#define glReadnPixelsARB GLEW_GET_FUN(__glewReadnPixelsARB) - -#define GLEW_ARB_robustness GLEW_GET_VAR(__GLEW_ARB_robustness) - -#endif /* GL_ARB_robustness */ - -/* ------------------------- GL_ARB_sample_shading ------------------------- */ - -#ifndef GL_ARB_sample_shading -#define GL_ARB_sample_shading 1 - -#define GL_SAMPLE_SHADING_ARB 0x8C36 -#define GL_MIN_SAMPLE_SHADING_VALUE_ARB 0x8C37 - -typedef void (GLAPIENTRY * PFNGLMINSAMPLESHADINGARBPROC) (GLclampf value); - -#define glMinSampleShadingARB GLEW_GET_FUN(__glewMinSampleShadingARB) - -#define GLEW_ARB_sample_shading GLEW_GET_VAR(__GLEW_ARB_sample_shading) - -#endif /* GL_ARB_sample_shading */ - -/* ------------------------- GL_ARB_sampler_objects ------------------------ */ - -#ifndef GL_ARB_sampler_objects -#define GL_ARB_sampler_objects 1 - -#define GL_SAMPLER_BINDING 0x8919 - -typedef void (GLAPIENTRY * PFNGLBINDSAMPLERPROC) (GLuint unit, GLuint sampler); -typedef void (GLAPIENTRY * PFNGLDELETESAMPLERSPROC) (GLsizei count, const GLuint * samplers); -typedef void (GLAPIENTRY * PFNGLGENSAMPLERSPROC) (GLsizei count, GLuint* samplers); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISSAMPLERPROC) (GLuint sampler); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERFPROC) (GLuint sampler, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIPROC) (GLuint sampler, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, const GLint* params); - -#define glBindSampler GLEW_GET_FUN(__glewBindSampler) -#define glDeleteSamplers GLEW_GET_FUN(__glewDeleteSamplers) -#define glGenSamplers GLEW_GET_FUN(__glewGenSamplers) -#define glGetSamplerParameterIiv GLEW_GET_FUN(__glewGetSamplerParameterIiv) -#define glGetSamplerParameterIuiv GLEW_GET_FUN(__glewGetSamplerParameterIuiv) -#define glGetSamplerParameterfv GLEW_GET_FUN(__glewGetSamplerParameterfv) -#define glGetSamplerParameteriv GLEW_GET_FUN(__glewGetSamplerParameteriv) -#define glIsSampler GLEW_GET_FUN(__glewIsSampler) -#define glSamplerParameterIiv GLEW_GET_FUN(__glewSamplerParameterIiv) -#define glSamplerParameterIuiv GLEW_GET_FUN(__glewSamplerParameterIuiv) -#define glSamplerParameterf GLEW_GET_FUN(__glewSamplerParameterf) -#define glSamplerParameterfv GLEW_GET_FUN(__glewSamplerParameterfv) -#define glSamplerParameteri GLEW_GET_FUN(__glewSamplerParameteri) -#define glSamplerParameteriv GLEW_GET_FUN(__glewSamplerParameteriv) - -#define GLEW_ARB_sampler_objects GLEW_GET_VAR(__GLEW_ARB_sampler_objects) - -#endif /* GL_ARB_sampler_objects */ - -/* ------------------------ GL_ARB_seamless_cube_map ----------------------- */ - -#ifndef GL_ARB_seamless_cube_map -#define GL_ARB_seamless_cube_map 1 - -#define GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F - -#define GLEW_ARB_seamless_cube_map GLEW_GET_VAR(__GLEW_ARB_seamless_cube_map) - -#endif /* GL_ARB_seamless_cube_map */ - -/* --------------------- GL_ARB_separate_shader_objects -------------------- */ - -#ifndef GL_ARB_separate_shader_objects -#define GL_ARB_separate_shader_objects 1 - -#define GL_VERTEX_SHADER_BIT 0x00000001 -#define GL_FRAGMENT_SHADER_BIT 0x00000002 -#define GL_GEOMETRY_SHADER_BIT 0x00000004 -#define GL_TESS_CONTROL_SHADER_BIT 0x00000008 -#define GL_TESS_EVALUATION_SHADER_BIT 0x00000010 -#define GL_PROGRAM_SEPARABLE 0x8258 -#define GL_ACTIVE_PROGRAM 0x8259 -#define GL_PROGRAM_PIPELINE_BINDING 0x825A -#define GL_ALL_SHADER_BITS 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLACTIVESHADERPROGRAMPROC) (GLuint pipeline, GLuint program); -typedef void (GLAPIENTRY * PFNGLBINDPROGRAMPIPELINEPROC) (GLuint pipeline); -typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROGRAMVPROC) (GLenum type, GLsizei count, const char ** strings); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMPIPELINESPROC) (GLsizei n, const GLuint* pipelines); -typedef void (GLAPIENTRY * PFNGLGENPROGRAMPIPELINESPROC) (GLsizei n, GLuint* pipelines); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPIPELINEINFOLOGPROC) (GLuint pipeline, GLsizei bufSize, GLsizei* length, char *infoLog); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPIPELINEIVPROC) (GLuint pipeline, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMPIPELINEPROC) (GLuint pipeline); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1DPROC) (GLuint program, GLint location, GLdouble x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FPROC) (GLuint program, GLint location, GLfloat x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IPROC) (GLuint program, GLint location, GLint x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIPROC) (GLuint program, GLint location, GLuint x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2DPROC) (GLuint program, GLint location, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FPROC) (GLuint program, GLint location, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IPROC) (GLuint program, GLint location, GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIPROC) (GLuint program, GLint location, GLuint x, GLuint y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3DPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FPROC) (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IPROC) (GLuint program, GLint location, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIPROC) (GLuint program, GLint location, GLuint x, GLuint y, GLuint z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4DPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FPROC) (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IPROC) (GLuint program, GLint location, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIPROC) (GLuint program, GLint location, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUSEPROGRAMSTAGESPROC) (GLuint pipeline, GLbitfield stages, GLuint program); -typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMPIPELINEPROC) (GLuint pipeline); - -#define glActiveShaderProgram GLEW_GET_FUN(__glewActiveShaderProgram) -#define glBindProgramPipeline GLEW_GET_FUN(__glewBindProgramPipeline) -#define glCreateShaderProgramv GLEW_GET_FUN(__glewCreateShaderProgramv) -#define glDeleteProgramPipelines GLEW_GET_FUN(__glewDeleteProgramPipelines) -#define glGenProgramPipelines GLEW_GET_FUN(__glewGenProgramPipelines) -#define glGetProgramPipelineInfoLog GLEW_GET_FUN(__glewGetProgramPipelineInfoLog) -#define glGetProgramPipelineiv GLEW_GET_FUN(__glewGetProgramPipelineiv) -#define glIsProgramPipeline GLEW_GET_FUN(__glewIsProgramPipeline) -#define glProgramUniform1d GLEW_GET_FUN(__glewProgramUniform1d) -#define glProgramUniform1dv GLEW_GET_FUN(__glewProgramUniform1dv) -#define glProgramUniform1f GLEW_GET_FUN(__glewProgramUniform1f) -#define glProgramUniform1fv GLEW_GET_FUN(__glewProgramUniform1fv) -#define glProgramUniform1i GLEW_GET_FUN(__glewProgramUniform1i) -#define glProgramUniform1iv GLEW_GET_FUN(__glewProgramUniform1iv) -#define glProgramUniform1ui GLEW_GET_FUN(__glewProgramUniform1ui) -#define glProgramUniform1uiv GLEW_GET_FUN(__glewProgramUniform1uiv) -#define glProgramUniform2d GLEW_GET_FUN(__glewProgramUniform2d) -#define glProgramUniform2dv GLEW_GET_FUN(__glewProgramUniform2dv) -#define glProgramUniform2f GLEW_GET_FUN(__glewProgramUniform2f) -#define glProgramUniform2fv GLEW_GET_FUN(__glewProgramUniform2fv) -#define glProgramUniform2i GLEW_GET_FUN(__glewProgramUniform2i) -#define glProgramUniform2iv GLEW_GET_FUN(__glewProgramUniform2iv) -#define glProgramUniform2ui GLEW_GET_FUN(__glewProgramUniform2ui) -#define glProgramUniform2uiv GLEW_GET_FUN(__glewProgramUniform2uiv) -#define glProgramUniform3d GLEW_GET_FUN(__glewProgramUniform3d) -#define glProgramUniform3dv GLEW_GET_FUN(__glewProgramUniform3dv) -#define glProgramUniform3f GLEW_GET_FUN(__glewProgramUniform3f) -#define glProgramUniform3fv GLEW_GET_FUN(__glewProgramUniform3fv) -#define glProgramUniform3i GLEW_GET_FUN(__glewProgramUniform3i) -#define glProgramUniform3iv GLEW_GET_FUN(__glewProgramUniform3iv) -#define glProgramUniform3ui GLEW_GET_FUN(__glewProgramUniform3ui) -#define glProgramUniform3uiv GLEW_GET_FUN(__glewProgramUniform3uiv) -#define glProgramUniform4d GLEW_GET_FUN(__glewProgramUniform4d) -#define glProgramUniform4dv GLEW_GET_FUN(__glewProgramUniform4dv) -#define glProgramUniform4f GLEW_GET_FUN(__glewProgramUniform4f) -#define glProgramUniform4fv GLEW_GET_FUN(__glewProgramUniform4fv) -#define glProgramUniform4i GLEW_GET_FUN(__glewProgramUniform4i) -#define glProgramUniform4iv GLEW_GET_FUN(__glewProgramUniform4iv) -#define glProgramUniform4ui GLEW_GET_FUN(__glewProgramUniform4ui) -#define glProgramUniform4uiv GLEW_GET_FUN(__glewProgramUniform4uiv) -#define glProgramUniformMatrix2dv GLEW_GET_FUN(__glewProgramUniformMatrix2dv) -#define glProgramUniformMatrix2fv GLEW_GET_FUN(__glewProgramUniformMatrix2fv) -#define glProgramUniformMatrix2x3dv GLEW_GET_FUN(__glewProgramUniformMatrix2x3dv) -#define glProgramUniformMatrix2x3fv GLEW_GET_FUN(__glewProgramUniformMatrix2x3fv) -#define glProgramUniformMatrix2x4dv GLEW_GET_FUN(__glewProgramUniformMatrix2x4dv) -#define glProgramUniformMatrix2x4fv GLEW_GET_FUN(__glewProgramUniformMatrix2x4fv) -#define glProgramUniformMatrix3dv GLEW_GET_FUN(__glewProgramUniformMatrix3dv) -#define glProgramUniformMatrix3fv GLEW_GET_FUN(__glewProgramUniformMatrix3fv) -#define glProgramUniformMatrix3x2dv GLEW_GET_FUN(__glewProgramUniformMatrix3x2dv) -#define glProgramUniformMatrix3x2fv GLEW_GET_FUN(__glewProgramUniformMatrix3x2fv) -#define glProgramUniformMatrix3x4dv GLEW_GET_FUN(__glewProgramUniformMatrix3x4dv) -#define glProgramUniformMatrix3x4fv GLEW_GET_FUN(__glewProgramUniformMatrix3x4fv) -#define glProgramUniformMatrix4dv GLEW_GET_FUN(__glewProgramUniformMatrix4dv) -#define glProgramUniformMatrix4fv GLEW_GET_FUN(__glewProgramUniformMatrix4fv) -#define glProgramUniformMatrix4x2dv GLEW_GET_FUN(__glewProgramUniformMatrix4x2dv) -#define glProgramUniformMatrix4x2fv GLEW_GET_FUN(__glewProgramUniformMatrix4x2fv) -#define glProgramUniformMatrix4x3dv GLEW_GET_FUN(__glewProgramUniformMatrix4x3dv) -#define glProgramUniformMatrix4x3fv GLEW_GET_FUN(__glewProgramUniformMatrix4x3fv) -#define glUseProgramStages GLEW_GET_FUN(__glewUseProgramStages) -#define glValidateProgramPipeline GLEW_GET_FUN(__glewValidateProgramPipeline) - -#define GLEW_ARB_separate_shader_objects GLEW_GET_VAR(__GLEW_ARB_separate_shader_objects) - -#endif /* GL_ARB_separate_shader_objects */ - -/* ----------------------- GL_ARB_shader_bit_encoding ---------------------- */ - -#ifndef GL_ARB_shader_bit_encoding -#define GL_ARB_shader_bit_encoding 1 - -#define GLEW_ARB_shader_bit_encoding GLEW_GET_VAR(__GLEW_ARB_shader_bit_encoding) - -#endif /* GL_ARB_shader_bit_encoding */ - -/* ------------------------- GL_ARB_shader_objects ------------------------- */ - -#ifndef GL_ARB_shader_objects -#define GL_ARB_shader_objects 1 - -#define GL_PROGRAM_OBJECT_ARB 0x8B40 -#define GL_SHADER_OBJECT_ARB 0x8B48 -#define GL_OBJECT_TYPE_ARB 0x8B4E -#define GL_OBJECT_SUBTYPE_ARB 0x8B4F -#define GL_FLOAT_VEC2_ARB 0x8B50 -#define GL_FLOAT_VEC3_ARB 0x8B51 -#define GL_FLOAT_VEC4_ARB 0x8B52 -#define GL_INT_VEC2_ARB 0x8B53 -#define GL_INT_VEC3_ARB 0x8B54 -#define GL_INT_VEC4_ARB 0x8B55 -#define GL_BOOL_ARB 0x8B56 -#define GL_BOOL_VEC2_ARB 0x8B57 -#define GL_BOOL_VEC3_ARB 0x8B58 -#define GL_BOOL_VEC4_ARB 0x8B59 -#define GL_FLOAT_MAT2_ARB 0x8B5A -#define GL_FLOAT_MAT3_ARB 0x8B5B -#define GL_FLOAT_MAT4_ARB 0x8B5C -#define GL_SAMPLER_1D_ARB 0x8B5D -#define GL_SAMPLER_2D_ARB 0x8B5E -#define GL_SAMPLER_3D_ARB 0x8B5F -#define GL_SAMPLER_CUBE_ARB 0x8B60 -#define GL_SAMPLER_1D_SHADOW_ARB 0x8B61 -#define GL_SAMPLER_2D_SHADOW_ARB 0x8B62 -#define GL_SAMPLER_2D_RECT_ARB 0x8B63 -#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 -#define GL_OBJECT_DELETE_STATUS_ARB 0x8B80 -#define GL_OBJECT_COMPILE_STATUS_ARB 0x8B81 -#define GL_OBJECT_LINK_STATUS_ARB 0x8B82 -#define GL_OBJECT_VALIDATE_STATUS_ARB 0x8B83 -#define GL_OBJECT_INFO_LOG_LENGTH_ARB 0x8B84 -#define GL_OBJECT_ATTACHED_OBJECTS_ARB 0x8B85 -#define GL_OBJECT_ACTIVE_UNIFORMS_ARB 0x8B86 -#define GL_OBJECT_ACTIVE_UNIFORM_MAX_LENGTH_ARB 0x8B87 -#define GL_OBJECT_SHADER_SOURCE_LENGTH_ARB 0x8B88 - -typedef char GLcharARB; -typedef unsigned int GLhandleARB; - -typedef void (GLAPIENTRY * PFNGLATTACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB obj); -typedef void (GLAPIENTRY * PFNGLCOMPILESHADERARBPROC) (GLhandleARB shaderObj); -typedef GLhandleARB (GLAPIENTRY * PFNGLCREATEPROGRAMOBJECTARBPROC) (void); -typedef GLhandleARB (GLAPIENTRY * PFNGLCREATESHADEROBJECTARBPROC) (GLenum shaderType); -typedef void (GLAPIENTRY * PFNGLDELETEOBJECTARBPROC) (GLhandleARB obj); -typedef void (GLAPIENTRY * PFNGLDETACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB attachedObj); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name); -typedef void (GLAPIENTRY * PFNGLGETATTACHEDOBJECTSARBPROC) (GLhandleARB containerObj, GLsizei maxCount, GLsizei* count, GLhandleARB *obj); -typedef GLhandleARB (GLAPIENTRY * PFNGLGETHANDLEARBPROC) (GLenum pname); -typedef void (GLAPIENTRY * PFNGLGETINFOLOGARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *infoLog); -typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERFVARBPROC) (GLhandleARB obj, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERIVARBPROC) (GLhandleARB obj, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETSHADERSOURCEARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *source); -typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB* name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMFVARBPROC) (GLhandleARB programObj, GLint location, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMIVARBPROC) (GLhandleARB programObj, GLint location, GLint* params); -typedef void (GLAPIENTRY * PFNGLLINKPROGRAMARBPROC) (GLhandleARB programObj); -typedef void (GLAPIENTRY * PFNGLSHADERSOURCEARBPROC) (GLhandleARB shaderObj, GLsizei count, const GLcharARB ** string, const GLint *length); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FARBPROC) (GLint location, GLfloat v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IARBPROC) (GLint location, GLint v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FARBPROC) (GLint location, GLfloat v0, GLfloat v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IARBPROC) (GLint location, GLint v0, GLint v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUSEPROGRAMOBJECTARBPROC) (GLhandleARB programObj); -typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMARBPROC) (GLhandleARB programObj); - -#define glAttachObjectARB GLEW_GET_FUN(__glewAttachObjectARB) -#define glCompileShaderARB GLEW_GET_FUN(__glewCompileShaderARB) -#define glCreateProgramObjectARB GLEW_GET_FUN(__glewCreateProgramObjectARB) -#define glCreateShaderObjectARB GLEW_GET_FUN(__glewCreateShaderObjectARB) -#define glDeleteObjectARB GLEW_GET_FUN(__glewDeleteObjectARB) -#define glDetachObjectARB GLEW_GET_FUN(__glewDetachObjectARB) -#define glGetActiveUniformARB GLEW_GET_FUN(__glewGetActiveUniformARB) -#define glGetAttachedObjectsARB GLEW_GET_FUN(__glewGetAttachedObjectsARB) -#define glGetHandleARB GLEW_GET_FUN(__glewGetHandleARB) -#define glGetInfoLogARB GLEW_GET_FUN(__glewGetInfoLogARB) -#define glGetObjectParameterfvARB GLEW_GET_FUN(__glewGetObjectParameterfvARB) -#define glGetObjectParameterivARB GLEW_GET_FUN(__glewGetObjectParameterivARB) -#define glGetShaderSourceARB GLEW_GET_FUN(__glewGetShaderSourceARB) -#define glGetUniformLocationARB GLEW_GET_FUN(__glewGetUniformLocationARB) -#define glGetUniformfvARB GLEW_GET_FUN(__glewGetUniformfvARB) -#define glGetUniformivARB GLEW_GET_FUN(__glewGetUniformivARB) -#define glLinkProgramARB GLEW_GET_FUN(__glewLinkProgramARB) -#define glShaderSourceARB GLEW_GET_FUN(__glewShaderSourceARB) -#define glUniform1fARB GLEW_GET_FUN(__glewUniform1fARB) -#define glUniform1fvARB GLEW_GET_FUN(__glewUniform1fvARB) -#define glUniform1iARB GLEW_GET_FUN(__glewUniform1iARB) -#define glUniform1ivARB GLEW_GET_FUN(__glewUniform1ivARB) -#define glUniform2fARB GLEW_GET_FUN(__glewUniform2fARB) -#define glUniform2fvARB GLEW_GET_FUN(__glewUniform2fvARB) -#define glUniform2iARB GLEW_GET_FUN(__glewUniform2iARB) -#define glUniform2ivARB GLEW_GET_FUN(__glewUniform2ivARB) -#define glUniform3fARB GLEW_GET_FUN(__glewUniform3fARB) -#define glUniform3fvARB GLEW_GET_FUN(__glewUniform3fvARB) -#define glUniform3iARB GLEW_GET_FUN(__glewUniform3iARB) -#define glUniform3ivARB GLEW_GET_FUN(__glewUniform3ivARB) -#define glUniform4fARB GLEW_GET_FUN(__glewUniform4fARB) -#define glUniform4fvARB GLEW_GET_FUN(__glewUniform4fvARB) -#define glUniform4iARB GLEW_GET_FUN(__glewUniform4iARB) -#define glUniform4ivARB GLEW_GET_FUN(__glewUniform4ivARB) -#define glUniformMatrix2fvARB GLEW_GET_FUN(__glewUniformMatrix2fvARB) -#define glUniformMatrix3fvARB GLEW_GET_FUN(__glewUniformMatrix3fvARB) -#define glUniformMatrix4fvARB GLEW_GET_FUN(__glewUniformMatrix4fvARB) -#define glUseProgramObjectARB GLEW_GET_FUN(__glewUseProgramObjectARB) -#define glValidateProgramARB GLEW_GET_FUN(__glewValidateProgramARB) - -#define GLEW_ARB_shader_objects GLEW_GET_VAR(__GLEW_ARB_shader_objects) - -#endif /* GL_ARB_shader_objects */ - -/* ------------------------ GL_ARB_shader_precision ------------------------ */ - -#ifndef GL_ARB_shader_precision -#define GL_ARB_shader_precision 1 - -#define GLEW_ARB_shader_precision GLEW_GET_VAR(__GLEW_ARB_shader_precision) - -#endif /* GL_ARB_shader_precision */ - -/* ---------------------- GL_ARB_shader_stencil_export --------------------- */ - -#ifndef GL_ARB_shader_stencil_export -#define GL_ARB_shader_stencil_export 1 - -#define GLEW_ARB_shader_stencil_export GLEW_GET_VAR(__GLEW_ARB_shader_stencil_export) - -#endif /* GL_ARB_shader_stencil_export */ - -/* ------------------------ GL_ARB_shader_subroutine ----------------------- */ - -#ifndef GL_ARB_shader_subroutine -#define GL_ARB_shader_subroutine 1 - -#define GL_ACTIVE_SUBROUTINES 0x8DE5 -#define GL_ACTIVE_SUBROUTINE_UNIFORMS 0x8DE6 -#define GL_MAX_SUBROUTINES 0x8DE7 -#define GL_MAX_SUBROUTINE_UNIFORM_LOCATIONS 0x8DE8 -#define GL_ACTIVE_SUBROUTINE_UNIFORM_LOCATIONS 0x8E47 -#define GL_ACTIVE_SUBROUTINE_MAX_LENGTH 0x8E48 -#define GL_ACTIVE_SUBROUTINE_UNIFORM_MAX_LENGTH 0x8E49 -#define GL_NUM_COMPATIBLE_SUBROUTINES 0x8E4A -#define GL_COMPATIBLE_SUBROUTINES 0x8E4B - -typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINENAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, char *name); -typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, char *name); -typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC) (GLuint program, GLenum shadertype, GLuint index, GLenum pname, GLint* values); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTAGEIVPROC) (GLuint program, GLenum shadertype, GLenum pname, GLint* values); -typedef GLuint (GLAPIENTRY * PFNGLGETSUBROUTINEINDEXPROC) (GLuint program, GLenum shadertype, const char* name); -typedef GLint (GLAPIENTRY * PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC) (GLuint program, GLenum shadertype, const char* name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMSUBROUTINEUIVPROC) (GLenum shadertype, GLint location, GLuint* params); -typedef void (GLAPIENTRY * PFNGLUNIFORMSUBROUTINESUIVPROC) (GLenum shadertype, GLsizei count, const GLuint* indices); - -#define glGetActiveSubroutineName GLEW_GET_FUN(__glewGetActiveSubroutineName) -#define glGetActiveSubroutineUniformName GLEW_GET_FUN(__glewGetActiveSubroutineUniformName) -#define glGetActiveSubroutineUniformiv GLEW_GET_FUN(__glewGetActiveSubroutineUniformiv) -#define glGetProgramStageiv GLEW_GET_FUN(__glewGetProgramStageiv) -#define glGetSubroutineIndex GLEW_GET_FUN(__glewGetSubroutineIndex) -#define glGetSubroutineUniformLocation GLEW_GET_FUN(__glewGetSubroutineUniformLocation) -#define glGetUniformSubroutineuiv GLEW_GET_FUN(__glewGetUniformSubroutineuiv) -#define glUniformSubroutinesuiv GLEW_GET_FUN(__glewUniformSubroutinesuiv) - -#define GLEW_ARB_shader_subroutine GLEW_GET_VAR(__GLEW_ARB_shader_subroutine) - -#endif /* GL_ARB_shader_subroutine */ - -/* ----------------------- GL_ARB_shader_texture_lod ----------------------- */ - -#ifndef GL_ARB_shader_texture_lod -#define GL_ARB_shader_texture_lod 1 - -#define GLEW_ARB_shader_texture_lod GLEW_GET_VAR(__GLEW_ARB_shader_texture_lod) - -#endif /* GL_ARB_shader_texture_lod */ - -/* ---------------------- GL_ARB_shading_language_100 ---------------------- */ - -#ifndef GL_ARB_shading_language_100 -#define GL_ARB_shading_language_100 1 - -#define GL_SHADING_LANGUAGE_VERSION_ARB 0x8B8C - -#define GLEW_ARB_shading_language_100 GLEW_GET_VAR(__GLEW_ARB_shading_language_100) - -#endif /* GL_ARB_shading_language_100 */ - -/* -------------------- GL_ARB_shading_language_include -------------------- */ - -#ifndef GL_ARB_shading_language_include -#define GL_ARB_shading_language_include 1 - -#define GL_SHADER_INCLUDE_ARB 0x8DAE -#define GL_NAMED_STRING_LENGTH_ARB 0x8DE9 -#define GL_NAMED_STRING_TYPE_ARB 0x8DEA - -typedef void (GLAPIENTRY * PFNGLCOMPILESHADERINCLUDEARBPROC) (GLuint shader, GLsizei count, const char ** path, const GLint *length); -typedef void (GLAPIENTRY * PFNGLDELETENAMEDSTRINGARBPROC) (GLint namelen, const char* name); -typedef void (GLAPIENTRY * PFNGLGETNAMEDSTRINGARBPROC) (GLint namelen, const char* name, GLsizei bufSize, GLint *stringlen, char *string); -typedef void (GLAPIENTRY * PFNGLGETNAMEDSTRINGIVARBPROC) (GLint namelen, const char* name, GLenum pname, GLint *params); -typedef GLboolean (GLAPIENTRY * PFNGLISNAMEDSTRINGARBPROC) (GLint namelen, const char* name); -typedef void (GLAPIENTRY * PFNGLNAMEDSTRINGARBPROC) (GLenum type, GLint namelen, const char* name, GLint stringlen, const char *string); - -#define glCompileShaderIncludeARB GLEW_GET_FUN(__glewCompileShaderIncludeARB) -#define glDeleteNamedStringARB GLEW_GET_FUN(__glewDeleteNamedStringARB) -#define glGetNamedStringARB GLEW_GET_FUN(__glewGetNamedStringARB) -#define glGetNamedStringivARB GLEW_GET_FUN(__glewGetNamedStringivARB) -#define glIsNamedStringARB GLEW_GET_FUN(__glewIsNamedStringARB) -#define glNamedStringARB GLEW_GET_FUN(__glewNamedStringARB) - -#define GLEW_ARB_shading_language_include GLEW_GET_VAR(__GLEW_ARB_shading_language_include) - -#endif /* GL_ARB_shading_language_include */ - -/* ----------------------------- GL_ARB_shadow ----------------------------- */ - -#ifndef GL_ARB_shadow -#define GL_ARB_shadow 1 - -#define GL_TEXTURE_COMPARE_MODE_ARB 0x884C -#define GL_TEXTURE_COMPARE_FUNC_ARB 0x884D -#define GL_COMPARE_R_TO_TEXTURE_ARB 0x884E - -#define GLEW_ARB_shadow GLEW_GET_VAR(__GLEW_ARB_shadow) - -#endif /* GL_ARB_shadow */ - -/* ------------------------- GL_ARB_shadow_ambient ------------------------- */ - -#ifndef GL_ARB_shadow_ambient -#define GL_ARB_shadow_ambient 1 - -#define GL_TEXTURE_COMPARE_FAIL_VALUE_ARB 0x80BF - -#define GLEW_ARB_shadow_ambient GLEW_GET_VAR(__GLEW_ARB_shadow_ambient) - -#endif /* GL_ARB_shadow_ambient */ - -/* ------------------------------ GL_ARB_sync ------------------------------ */ - -#ifndef GL_ARB_sync -#define GL_ARB_sync 1 - -#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001 -#define GL_MAX_SERVER_WAIT_TIMEOUT 0x9111 -#define GL_OBJECT_TYPE 0x9112 -#define GL_SYNC_CONDITION 0x9113 -#define GL_SYNC_STATUS 0x9114 -#define GL_SYNC_FLAGS 0x9115 -#define GL_SYNC_FENCE 0x9116 -#define GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117 -#define GL_UNSIGNALED 0x9118 -#define GL_SIGNALED 0x9119 -#define GL_ALREADY_SIGNALED 0x911A -#define GL_TIMEOUT_EXPIRED 0x911B -#define GL_CONDITION_SATISFIED 0x911C -#define GL_WAIT_FAILED 0x911D -#define GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFF - -typedef GLenum (GLAPIENTRY * PFNGLCLIENTWAITSYNCPROC) (GLsync GLsync,GLbitfield flags,GLuint64 timeout); -typedef void (GLAPIENTRY * PFNGLDELETESYNCPROC) (GLsync GLsync); -typedef GLsync (GLAPIENTRY * PFNGLFENCESYNCPROC) (GLenum condition,GLbitfield flags); -typedef void (GLAPIENTRY * PFNGLGETINTEGER64VPROC) (GLenum pname, GLint64* params); -typedef void (GLAPIENTRY * PFNGLGETSYNCIVPROC) (GLsync GLsync,GLenum pname,GLsizei bufSize,GLsizei* length, GLint *values); -typedef GLboolean (GLAPIENTRY * PFNGLISSYNCPROC) (GLsync GLsync); -typedef void (GLAPIENTRY * PFNGLWAITSYNCPROC) (GLsync GLsync,GLbitfield flags,GLuint64 timeout); - -#define glClientWaitSync GLEW_GET_FUN(__glewClientWaitSync) -#define glDeleteSync GLEW_GET_FUN(__glewDeleteSync) -#define glFenceSync GLEW_GET_FUN(__glewFenceSync) -#define glGetInteger64v GLEW_GET_FUN(__glewGetInteger64v) -#define glGetSynciv GLEW_GET_FUN(__glewGetSynciv) -#define glIsSync GLEW_GET_FUN(__glewIsSync) -#define glWaitSync GLEW_GET_FUN(__glewWaitSync) - -#define GLEW_ARB_sync GLEW_GET_VAR(__GLEW_ARB_sync) - -#endif /* GL_ARB_sync */ - -/* ----------------------- GL_ARB_tessellation_shader ---------------------- */ - -#ifndef GL_ARB_tessellation_shader -#define GL_ARB_tessellation_shader 1 - -#define GL_PATCHES 0xE -#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_CONTROL_SHADER 0x84F0 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_EVALUATION_SHADER 0x84F1 -#define GL_MAX_TESS_CONTROL_INPUT_COMPONENTS 0x886C -#define GL_MAX_TESS_EVALUATION_INPUT_COMPONENTS 0x886D -#define GL_MAX_COMBINED_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E1E -#define GL_MAX_COMBINED_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E1F -#define GL_PATCH_VERTICES 0x8E72 -#define GL_PATCH_DEFAULT_INNER_LEVEL 0x8E73 -#define GL_PATCH_DEFAULT_OUTER_LEVEL 0x8E74 -#define GL_TESS_CONTROL_OUTPUT_VERTICES 0x8E75 -#define GL_TESS_GEN_MODE 0x8E76 -#define GL_TESS_GEN_SPACING 0x8E77 -#define GL_TESS_GEN_VERTEX_ORDER 0x8E78 -#define GL_TESS_GEN_POINT_MODE 0x8E79 -#define GL_ISOLINES 0x8E7A -#define GL_FRACTIONAL_ODD 0x8E7B -#define GL_FRACTIONAL_EVEN 0x8E7C -#define GL_MAX_PATCH_VERTICES 0x8E7D -#define GL_MAX_TESS_GEN_LEVEL 0x8E7E -#define GL_MAX_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E7F -#define GL_MAX_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E80 -#define GL_MAX_TESS_CONTROL_TEXTURE_IMAGE_UNITS 0x8E81 -#define GL_MAX_TESS_EVALUATION_TEXTURE_IMAGE_UNITS 0x8E82 -#define GL_MAX_TESS_CONTROL_OUTPUT_COMPONENTS 0x8E83 -#define GL_MAX_TESS_PATCH_COMPONENTS 0x8E84 -#define GL_MAX_TESS_CONTROL_TOTAL_OUTPUT_COMPONENTS 0x8E85 -#define GL_MAX_TESS_EVALUATION_OUTPUT_COMPONENTS 0x8E86 -#define GL_TESS_EVALUATION_SHADER 0x8E87 -#define GL_TESS_CONTROL_SHADER 0x8E88 -#define GL_MAX_TESS_CONTROL_UNIFORM_BLOCKS 0x8E89 -#define GL_MAX_TESS_EVALUATION_UNIFORM_BLOCKS 0x8E8A - -typedef void (GLAPIENTRY * PFNGLPATCHPARAMETERFVPROC) (GLenum pname, const GLfloat* values); -typedef void (GLAPIENTRY * PFNGLPATCHPARAMETERIPROC) (GLenum pname, GLint value); - -#define glPatchParameterfv GLEW_GET_FUN(__glewPatchParameterfv) -#define glPatchParameteri GLEW_GET_FUN(__glewPatchParameteri) - -#define GLEW_ARB_tessellation_shader GLEW_GET_VAR(__GLEW_ARB_tessellation_shader) - -#endif /* GL_ARB_tessellation_shader */ - -/* ---------------------- GL_ARB_texture_border_clamp ---------------------- */ - -#ifndef GL_ARB_texture_border_clamp -#define GL_ARB_texture_border_clamp 1 - -#define GL_CLAMP_TO_BORDER_ARB 0x812D - -#define GLEW_ARB_texture_border_clamp GLEW_GET_VAR(__GLEW_ARB_texture_border_clamp) - -#endif /* GL_ARB_texture_border_clamp */ - -/* ---------------------- GL_ARB_texture_buffer_object --------------------- */ - -#ifndef GL_ARB_texture_buffer_object -#define GL_ARB_texture_buffer_object 1 - -#define GL_TEXTURE_BUFFER_ARB 0x8C2A -#define GL_MAX_TEXTURE_BUFFER_SIZE_ARB 0x8C2B -#define GL_TEXTURE_BINDING_BUFFER_ARB 0x8C2C -#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING_ARB 0x8C2D -#define GL_TEXTURE_BUFFER_FORMAT_ARB 0x8C2E - -typedef void (GLAPIENTRY * PFNGLTEXBUFFERARBPROC) (GLenum target, GLenum internalformat, GLuint buffer); - -#define glTexBufferARB GLEW_GET_FUN(__glewTexBufferARB) - -#define GLEW_ARB_texture_buffer_object GLEW_GET_VAR(__GLEW_ARB_texture_buffer_object) - -#endif /* GL_ARB_texture_buffer_object */ - -/* ------------------- GL_ARB_texture_buffer_object_rgb32 ------------------ */ - -#ifndef GL_ARB_texture_buffer_object_rgb32 -#define GL_ARB_texture_buffer_object_rgb32 1 - -#define GLEW_ARB_texture_buffer_object_rgb32 GLEW_GET_VAR(__GLEW_ARB_texture_buffer_object_rgb32) - -#endif /* GL_ARB_texture_buffer_object_rgb32 */ - -/* ----------------------- GL_ARB_texture_compression ---------------------- */ - -#ifndef GL_ARB_texture_compression -#define GL_ARB_texture_compression 1 - -#define GL_COMPRESSED_ALPHA_ARB 0x84E9 -#define GL_COMPRESSED_LUMINANCE_ARB 0x84EA -#define GL_COMPRESSED_LUMINANCE_ALPHA_ARB 0x84EB -#define GL_COMPRESSED_INTENSITY_ARB 0x84EC -#define GL_COMPRESSED_RGB_ARB 0x84ED -#define GL_COMPRESSED_RGBA_ARB 0x84EE -#define GL_TEXTURE_COMPRESSION_HINT_ARB 0x84EF -#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE_ARB 0x86A0 -#define GL_TEXTURE_COMPRESSED_ARB 0x86A1 -#define GL_NUM_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A2 -#define GL_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A3 - -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint lod, void* img); - -#define glCompressedTexImage1DARB GLEW_GET_FUN(__glewCompressedTexImage1DARB) -#define glCompressedTexImage2DARB GLEW_GET_FUN(__glewCompressedTexImage2DARB) -#define glCompressedTexImage3DARB GLEW_GET_FUN(__glewCompressedTexImage3DARB) -#define glCompressedTexSubImage1DARB GLEW_GET_FUN(__glewCompressedTexSubImage1DARB) -#define glCompressedTexSubImage2DARB GLEW_GET_FUN(__glewCompressedTexSubImage2DARB) -#define glCompressedTexSubImage3DARB GLEW_GET_FUN(__glewCompressedTexSubImage3DARB) -#define glGetCompressedTexImageARB GLEW_GET_FUN(__glewGetCompressedTexImageARB) - -#define GLEW_ARB_texture_compression GLEW_GET_VAR(__GLEW_ARB_texture_compression) - -#endif /* GL_ARB_texture_compression */ - -/* -------------------- GL_ARB_texture_compression_bptc -------------------- */ - -#ifndef GL_ARB_texture_compression_bptc -#define GL_ARB_texture_compression_bptc 1 - -#define GL_COMPRESSED_RGBA_BPTC_UNORM_ARB 0x8E8C -#define GL_COMPRESSED_SRGB_ALPHA_BPTC_UNORM_ARB 0x8E8D -#define GL_COMPRESSED_RGB_BPTC_SIGNED_FLOAT_ARB 0x8E8E -#define GL_COMPRESSED_RGB_BPTC_UNSIGNED_FLOAT_ARB 0x8E8F - -#define GLEW_ARB_texture_compression_bptc GLEW_GET_VAR(__GLEW_ARB_texture_compression_bptc) - -#endif /* GL_ARB_texture_compression_bptc */ - -/* -------------------- GL_ARB_texture_compression_rgtc -------------------- */ - -#ifndef GL_ARB_texture_compression_rgtc -#define GL_ARB_texture_compression_rgtc 1 - -#define GL_COMPRESSED_RED_RGTC1 0x8DBB -#define GL_COMPRESSED_SIGNED_RED_RGTC1 0x8DBC -#define GL_COMPRESSED_RG_RGTC2 0x8DBD -#define GL_COMPRESSED_SIGNED_RG_RGTC2 0x8DBE - -#define GLEW_ARB_texture_compression_rgtc GLEW_GET_VAR(__GLEW_ARB_texture_compression_rgtc) - -#endif /* GL_ARB_texture_compression_rgtc */ - -/* ------------------------ GL_ARB_texture_cube_map ------------------------ */ - -#ifndef GL_ARB_texture_cube_map -#define GL_ARB_texture_cube_map 1 - -#define GL_NORMAL_MAP_ARB 0x8511 -#define GL_REFLECTION_MAP_ARB 0x8512 -#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARB 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_ARB 0x851C - -#define GLEW_ARB_texture_cube_map GLEW_GET_VAR(__GLEW_ARB_texture_cube_map) - -#endif /* GL_ARB_texture_cube_map */ - -/* --------------------- GL_ARB_texture_cube_map_array --------------------- */ - -#ifndef GL_ARB_texture_cube_map_array -#define GL_ARB_texture_cube_map_array 1 - -#define GL_TEXTURE_CUBE_MAP_ARRAY_ARB 0x9009 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARRAY_ARB 0x900A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARRAY_ARB 0x900B -#define GL_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900C -#define GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW_ARB 0x900D -#define GL_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900E -#define GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900F - -#define GLEW_ARB_texture_cube_map_array GLEW_GET_VAR(__GLEW_ARB_texture_cube_map_array) - -#endif /* GL_ARB_texture_cube_map_array */ - -/* ------------------------- GL_ARB_texture_env_add ------------------------ */ - -#ifndef GL_ARB_texture_env_add -#define GL_ARB_texture_env_add 1 - -#define GLEW_ARB_texture_env_add GLEW_GET_VAR(__GLEW_ARB_texture_env_add) - -#endif /* GL_ARB_texture_env_add */ - -/* ----------------------- GL_ARB_texture_env_combine ---------------------- */ - -#ifndef GL_ARB_texture_env_combine -#define GL_ARB_texture_env_combine 1 - -#define GL_SUBTRACT_ARB 0x84E7 -#define GL_COMBINE_ARB 0x8570 -#define GL_COMBINE_RGB_ARB 0x8571 -#define GL_COMBINE_ALPHA_ARB 0x8572 -#define GL_RGB_SCALE_ARB 0x8573 -#define GL_ADD_SIGNED_ARB 0x8574 -#define GL_INTERPOLATE_ARB 0x8575 -#define GL_CONSTANT_ARB 0x8576 -#define GL_PRIMARY_COLOR_ARB 0x8577 -#define GL_PREVIOUS_ARB 0x8578 -#define GL_SOURCE0_RGB_ARB 0x8580 -#define GL_SOURCE1_RGB_ARB 0x8581 -#define GL_SOURCE2_RGB_ARB 0x8582 -#define GL_SOURCE0_ALPHA_ARB 0x8588 -#define GL_SOURCE1_ALPHA_ARB 0x8589 -#define GL_SOURCE2_ALPHA_ARB 0x858A -#define GL_OPERAND0_RGB_ARB 0x8590 -#define GL_OPERAND1_RGB_ARB 0x8591 -#define GL_OPERAND2_RGB_ARB 0x8592 -#define GL_OPERAND0_ALPHA_ARB 0x8598 -#define GL_OPERAND1_ALPHA_ARB 0x8599 -#define GL_OPERAND2_ALPHA_ARB 0x859A - -#define GLEW_ARB_texture_env_combine GLEW_GET_VAR(__GLEW_ARB_texture_env_combine) - -#endif /* GL_ARB_texture_env_combine */ - -/* ---------------------- GL_ARB_texture_env_crossbar ---------------------- */ - -#ifndef GL_ARB_texture_env_crossbar -#define GL_ARB_texture_env_crossbar 1 - -#define GLEW_ARB_texture_env_crossbar GLEW_GET_VAR(__GLEW_ARB_texture_env_crossbar) - -#endif /* GL_ARB_texture_env_crossbar */ - -/* ------------------------ GL_ARB_texture_env_dot3 ------------------------ */ - -#ifndef GL_ARB_texture_env_dot3 -#define GL_ARB_texture_env_dot3 1 - -#define GL_DOT3_RGB_ARB 0x86AE -#define GL_DOT3_RGBA_ARB 0x86AF - -#define GLEW_ARB_texture_env_dot3 GLEW_GET_VAR(__GLEW_ARB_texture_env_dot3) - -#endif /* GL_ARB_texture_env_dot3 */ - -/* -------------------------- GL_ARB_texture_float ------------------------- */ - -#ifndef GL_ARB_texture_float -#define GL_ARB_texture_float 1 - -#define GL_RGBA32F_ARB 0x8814 -#define GL_RGB32F_ARB 0x8815 -#define GL_ALPHA32F_ARB 0x8816 -#define GL_INTENSITY32F_ARB 0x8817 -#define GL_LUMINANCE32F_ARB 0x8818 -#define GL_LUMINANCE_ALPHA32F_ARB 0x8819 -#define GL_RGBA16F_ARB 0x881A -#define GL_RGB16F_ARB 0x881B -#define GL_ALPHA16F_ARB 0x881C -#define GL_INTENSITY16F_ARB 0x881D -#define GL_LUMINANCE16F_ARB 0x881E -#define GL_LUMINANCE_ALPHA16F_ARB 0x881F -#define GL_TEXTURE_RED_TYPE_ARB 0x8C10 -#define GL_TEXTURE_GREEN_TYPE_ARB 0x8C11 -#define GL_TEXTURE_BLUE_TYPE_ARB 0x8C12 -#define GL_TEXTURE_ALPHA_TYPE_ARB 0x8C13 -#define GL_TEXTURE_LUMINANCE_TYPE_ARB 0x8C14 -#define GL_TEXTURE_INTENSITY_TYPE_ARB 0x8C15 -#define GL_TEXTURE_DEPTH_TYPE_ARB 0x8C16 -#define GL_UNSIGNED_NORMALIZED_ARB 0x8C17 - -#define GLEW_ARB_texture_float GLEW_GET_VAR(__GLEW_ARB_texture_float) - -#endif /* GL_ARB_texture_float */ - -/* ------------------------- GL_ARB_texture_gather ------------------------- */ - -#ifndef GL_ARB_texture_gather -#define GL_ARB_texture_gather 1 - -#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5E -#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5F -#define GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS_ARB 0x8F9F - -#define GLEW_ARB_texture_gather GLEW_GET_VAR(__GLEW_ARB_texture_gather) - -#endif /* GL_ARB_texture_gather */ - -/* --------------------- GL_ARB_texture_mirrored_repeat -------------------- */ - -#ifndef GL_ARB_texture_mirrored_repeat -#define GL_ARB_texture_mirrored_repeat 1 - -#define GL_MIRRORED_REPEAT_ARB 0x8370 - -#define GLEW_ARB_texture_mirrored_repeat GLEW_GET_VAR(__GLEW_ARB_texture_mirrored_repeat) - -#endif /* GL_ARB_texture_mirrored_repeat */ - -/* ----------------------- GL_ARB_texture_multisample ---------------------- */ - -#ifndef GL_ARB_texture_multisample -#define GL_ARB_texture_multisample 1 - -#define GL_SAMPLE_POSITION 0x8E50 -#define GL_SAMPLE_MASK 0x8E51 -#define GL_SAMPLE_MASK_VALUE 0x8E52 -#define GL_MAX_SAMPLE_MASK_WORDS 0x8E59 -#define GL_TEXTURE_2D_MULTISAMPLE 0x9100 -#define GL_PROXY_TEXTURE_2D_MULTISAMPLE 0x9101 -#define GL_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9102 -#define GL_PROXY_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9103 -#define GL_TEXTURE_BINDING_2D_MULTISAMPLE 0x9104 -#define GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY 0x9105 -#define GL_TEXTURE_SAMPLES 0x9106 -#define GL_TEXTURE_FIXED_SAMPLE_LOCATIONS 0x9107 -#define GL_SAMPLER_2D_MULTISAMPLE 0x9108 -#define GL_INT_SAMPLER_2D_MULTISAMPLE 0x9109 -#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE 0x910A -#define GL_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910B -#define GL_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910C -#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910D -#define GL_MAX_COLOR_TEXTURE_SAMPLES 0x910E -#define GL_MAX_DEPTH_TEXTURE_SAMPLES 0x910F -#define GL_MAX_INTEGER_SAMPLES 0x9110 - -typedef void (GLAPIENTRY * PFNGLGETMULTISAMPLEFVPROC) (GLenum pname, GLuint index, GLfloat* val); -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKIPROC) (GLuint index, GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE2DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); - -#define glGetMultisamplefv GLEW_GET_FUN(__glewGetMultisamplefv) -#define glSampleMaski GLEW_GET_FUN(__glewSampleMaski) -#define glTexImage2DMultisample GLEW_GET_FUN(__glewTexImage2DMultisample) -#define glTexImage3DMultisample GLEW_GET_FUN(__glewTexImage3DMultisample) - -#define GLEW_ARB_texture_multisample GLEW_GET_VAR(__GLEW_ARB_texture_multisample) - -#endif /* GL_ARB_texture_multisample */ - -/* -------------------- GL_ARB_texture_non_power_of_two -------------------- */ - -#ifndef GL_ARB_texture_non_power_of_two -#define GL_ARB_texture_non_power_of_two 1 - -#define GLEW_ARB_texture_non_power_of_two GLEW_GET_VAR(__GLEW_ARB_texture_non_power_of_two) - -#endif /* GL_ARB_texture_non_power_of_two */ - -/* ------------------------ GL_ARB_texture_query_lod ----------------------- */ - -#ifndef GL_ARB_texture_query_lod -#define GL_ARB_texture_query_lod 1 - -#define GLEW_ARB_texture_query_lod GLEW_GET_VAR(__GLEW_ARB_texture_query_lod) - -#endif /* GL_ARB_texture_query_lod */ - -/* ------------------------ GL_ARB_texture_rectangle ----------------------- */ - -#ifndef GL_ARB_texture_rectangle -#define GL_ARB_texture_rectangle 1 - -#define GL_TEXTURE_RECTANGLE_ARB 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_ARB 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_ARB 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_ARB 0x84F8 -#define GL_SAMPLER_2D_RECT_ARB 0x8B63 -#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 - -#define GLEW_ARB_texture_rectangle GLEW_GET_VAR(__GLEW_ARB_texture_rectangle) - -#endif /* GL_ARB_texture_rectangle */ - -/* --------------------------- GL_ARB_texture_rg --------------------------- */ - -#ifndef GL_ARB_texture_rg -#define GL_ARB_texture_rg 1 - -#define GL_RED 0x1903 -#define GL_COMPRESSED_RED 0x8225 -#define GL_COMPRESSED_RG 0x8226 -#define GL_RG 0x8227 -#define GL_RG_INTEGER 0x8228 -#define GL_R8 0x8229 -#define GL_R16 0x822A -#define GL_RG8 0x822B -#define GL_RG16 0x822C -#define GL_R16F 0x822D -#define GL_R32F 0x822E -#define GL_RG16F 0x822F -#define GL_RG32F 0x8230 -#define GL_R8I 0x8231 -#define GL_R8UI 0x8232 -#define GL_R16I 0x8233 -#define GL_R16UI 0x8234 -#define GL_R32I 0x8235 -#define GL_R32UI 0x8236 -#define GL_RG8I 0x8237 -#define GL_RG8UI 0x8238 -#define GL_RG16I 0x8239 -#define GL_RG16UI 0x823A -#define GL_RG32I 0x823B -#define GL_RG32UI 0x823C - -#define GLEW_ARB_texture_rg GLEW_GET_VAR(__GLEW_ARB_texture_rg) - -#endif /* GL_ARB_texture_rg */ - -/* ----------------------- GL_ARB_texture_rgb10_a2ui ----------------------- */ - -#ifndef GL_ARB_texture_rgb10_a2ui -#define GL_ARB_texture_rgb10_a2ui 1 - -#define GL_RGB10_A2UI 0x906F - -#define GLEW_ARB_texture_rgb10_a2ui GLEW_GET_VAR(__GLEW_ARB_texture_rgb10_a2ui) - -#endif /* GL_ARB_texture_rgb10_a2ui */ - -/* ------------------------- GL_ARB_texture_swizzle ------------------------ */ - -#ifndef GL_ARB_texture_swizzle -#define GL_ARB_texture_swizzle 1 - -#define GL_TEXTURE_SWIZZLE_R 0x8E42 -#define GL_TEXTURE_SWIZZLE_G 0x8E43 -#define GL_TEXTURE_SWIZZLE_B 0x8E44 -#define GL_TEXTURE_SWIZZLE_A 0x8E45 -#define GL_TEXTURE_SWIZZLE_RGBA 0x8E46 - -#define GLEW_ARB_texture_swizzle GLEW_GET_VAR(__GLEW_ARB_texture_swizzle) - -#endif /* GL_ARB_texture_swizzle */ - -/* --------------------------- GL_ARB_timer_query -------------------------- */ - -#ifndef GL_ARB_timer_query -#define GL_ARB_timer_query 1 - -#define GL_TIME_ELAPSED 0x88BF -#define GL_TIMESTAMP 0x8E28 - -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VPROC) (GLuint id, GLenum pname, GLint64* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VPROC) (GLuint id, GLenum pname, GLuint64* params); -typedef void (GLAPIENTRY * PFNGLQUERYCOUNTERPROC) (GLuint id, GLenum target); - -#define glGetQueryObjecti64v GLEW_GET_FUN(__glewGetQueryObjecti64v) -#define glGetQueryObjectui64v GLEW_GET_FUN(__glewGetQueryObjectui64v) -#define glQueryCounter GLEW_GET_FUN(__glewQueryCounter) - -#define GLEW_ARB_timer_query GLEW_GET_VAR(__GLEW_ARB_timer_query) - -#endif /* GL_ARB_timer_query */ - -/* ----------------------- GL_ARB_transform_feedback2 ---------------------- */ - -#ifndef GL_ARB_transform_feedback2 -#define GL_ARB_transform_feedback2 1 - -#define GL_TRANSFORM_FEEDBACK 0x8E22 -#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED 0x8E23 -#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE 0x8E24 -#define GL_TRANSFORM_FEEDBACK_BINDING 0x8E25 - -typedef void (GLAPIENTRY * PFNGLBINDTRANSFORMFEEDBACKPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETETRANSFORMFEEDBACKSPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKPROC) (GLenum mode, GLuint id); -typedef void (GLAPIENTRY * PFNGLGENTRANSFORMFEEDBACKSPROC) (GLsizei n, GLuint* ids); -typedef GLboolean (GLAPIENTRY * PFNGLISTRANSFORMFEEDBACKPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLPAUSETRANSFORMFEEDBACKPROC) (void); -typedef void (GLAPIENTRY * PFNGLRESUMETRANSFORMFEEDBACKPROC) (void); - -#define glBindTransformFeedback GLEW_GET_FUN(__glewBindTransformFeedback) -#define glDeleteTransformFeedbacks GLEW_GET_FUN(__glewDeleteTransformFeedbacks) -#define glDrawTransformFeedback GLEW_GET_FUN(__glewDrawTransformFeedback) -#define glGenTransformFeedbacks GLEW_GET_FUN(__glewGenTransformFeedbacks) -#define glIsTransformFeedback GLEW_GET_FUN(__glewIsTransformFeedback) -#define glPauseTransformFeedback GLEW_GET_FUN(__glewPauseTransformFeedback) -#define glResumeTransformFeedback GLEW_GET_FUN(__glewResumeTransformFeedback) - -#define GLEW_ARB_transform_feedback2 GLEW_GET_VAR(__GLEW_ARB_transform_feedback2) - -#endif /* GL_ARB_transform_feedback2 */ - -/* ----------------------- GL_ARB_transform_feedback3 ---------------------- */ - -#ifndef GL_ARB_transform_feedback3 -#define GL_ARB_transform_feedback3 1 - -#define GL_MAX_TRANSFORM_FEEDBACK_BUFFERS 0x8E70 -#define GL_MAX_VERTEX_STREAMS 0x8E71 - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYINDEXEDPROC) (GLenum target, GLuint index, GLuint id); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC) (GLenum mode, GLuint id, GLuint stream); -typedef void (GLAPIENTRY * PFNGLENDQUERYINDEXEDPROC) (GLenum target, GLuint index); -typedef void (GLAPIENTRY * PFNGLGETQUERYINDEXEDIVPROC) (GLenum target, GLuint index, GLenum pname, GLint* params); - -#define glBeginQueryIndexed GLEW_GET_FUN(__glewBeginQueryIndexed) -#define glDrawTransformFeedbackStream GLEW_GET_FUN(__glewDrawTransformFeedbackStream) -#define glEndQueryIndexed GLEW_GET_FUN(__glewEndQueryIndexed) -#define glGetQueryIndexediv GLEW_GET_FUN(__glewGetQueryIndexediv) - -#define GLEW_ARB_transform_feedback3 GLEW_GET_VAR(__GLEW_ARB_transform_feedback3) - -#endif /* GL_ARB_transform_feedback3 */ - -/* ------------------------ GL_ARB_transpose_matrix ------------------------ */ - -#ifndef GL_ARB_transpose_matrix -#define GL_ARB_transpose_matrix 1 - -#define GL_TRANSPOSE_MODELVIEW_MATRIX_ARB 0x84E3 -#define GL_TRANSPOSE_PROJECTION_MATRIX_ARB 0x84E4 -#define GL_TRANSPOSE_TEXTURE_MATRIX_ARB 0x84E5 -#define GL_TRANSPOSE_COLOR_MATRIX_ARB 0x84E6 - -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXDARBPROC) (GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXFARBPROC) (GLfloat m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXDARBPROC) (GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXFARBPROC) (GLfloat m[16]); - -#define glLoadTransposeMatrixdARB GLEW_GET_FUN(__glewLoadTransposeMatrixdARB) -#define glLoadTransposeMatrixfARB GLEW_GET_FUN(__glewLoadTransposeMatrixfARB) -#define glMultTransposeMatrixdARB GLEW_GET_FUN(__glewMultTransposeMatrixdARB) -#define glMultTransposeMatrixfARB GLEW_GET_FUN(__glewMultTransposeMatrixfARB) - -#define GLEW_ARB_transpose_matrix GLEW_GET_VAR(__GLEW_ARB_transpose_matrix) - -#endif /* GL_ARB_transpose_matrix */ - -/* ---------------------- GL_ARB_uniform_buffer_object --------------------- */ - -#ifndef GL_ARB_uniform_buffer_object -#define GL_ARB_uniform_buffer_object 1 - -#define GL_UNIFORM_BUFFER 0x8A11 -#define GL_UNIFORM_BUFFER_BINDING 0x8A28 -#define GL_UNIFORM_BUFFER_START 0x8A29 -#define GL_UNIFORM_BUFFER_SIZE 0x8A2A -#define GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B -#define GL_MAX_GEOMETRY_UNIFORM_BLOCKS 0x8A2C -#define GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D -#define GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E -#define GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F -#define GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30 -#define GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31 -#define GL_MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS 0x8A32 -#define GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33 -#define GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34 -#define GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35 -#define GL_ACTIVE_UNIFORM_BLOCKS 0x8A36 -#define GL_UNIFORM_TYPE 0x8A37 -#define GL_UNIFORM_SIZE 0x8A38 -#define GL_UNIFORM_NAME_LENGTH 0x8A39 -#define GL_UNIFORM_BLOCK_INDEX 0x8A3A -#define GL_UNIFORM_OFFSET 0x8A3B -#define GL_UNIFORM_ARRAY_STRIDE 0x8A3C -#define GL_UNIFORM_MATRIX_STRIDE 0x8A3D -#define GL_UNIFORM_IS_ROW_MAJOR 0x8A3E -#define GL_UNIFORM_BLOCK_BINDING 0x8A3F -#define GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40 -#define GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41 -#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42 -#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_GEOMETRY_SHADER 0x8A45 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46 -#define GL_INVALID_INDEX 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASEPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGEPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC) (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei* length, char* uniformBlockName); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMBLOCKIVPROC) (GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMNAMEPROC) (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei* length, char* uniformName); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMSIVPROC) (GLuint program, GLsizei uniformCount, const GLuint* uniformIndices, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETINTEGERI_VPROC) (GLenum target, GLuint index, GLint* data); -typedef GLuint (GLAPIENTRY * PFNGLGETUNIFORMBLOCKINDEXPROC) (GLuint program, const char* uniformBlockName); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMINDICESPROC) (GLuint program, GLsizei uniformCount, const char** uniformNames, GLuint* uniformIndices); -typedef void (GLAPIENTRY * PFNGLUNIFORMBLOCKBINDINGPROC) (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); - -#define glBindBufferBase GLEW_GET_FUN(__glewBindBufferBase) -#define glBindBufferRange GLEW_GET_FUN(__glewBindBufferRange) -#define glGetActiveUniformBlockName GLEW_GET_FUN(__glewGetActiveUniformBlockName) -#define glGetActiveUniformBlockiv GLEW_GET_FUN(__glewGetActiveUniformBlockiv) -#define glGetActiveUniformName GLEW_GET_FUN(__glewGetActiveUniformName) -#define glGetActiveUniformsiv GLEW_GET_FUN(__glewGetActiveUniformsiv) -#define glGetIntegeri_v GLEW_GET_FUN(__glewGetIntegeri_v) -#define glGetUniformBlockIndex GLEW_GET_FUN(__glewGetUniformBlockIndex) -#define glGetUniformIndices GLEW_GET_FUN(__glewGetUniformIndices) -#define glUniformBlockBinding GLEW_GET_FUN(__glewUniformBlockBinding) - -#define GLEW_ARB_uniform_buffer_object GLEW_GET_VAR(__GLEW_ARB_uniform_buffer_object) - -#endif /* GL_ARB_uniform_buffer_object */ - -/* ------------------------ GL_ARB_vertex_array_bgra ----------------------- */ - -#ifndef GL_ARB_vertex_array_bgra -#define GL_ARB_vertex_array_bgra 1 - -#define GL_BGRA 0x80E1 - -#define GLEW_ARB_vertex_array_bgra GLEW_GET_VAR(__GLEW_ARB_vertex_array_bgra) - -#endif /* GL_ARB_vertex_array_bgra */ - -/* ----------------------- GL_ARB_vertex_array_object ---------------------- */ - -#ifndef GL_ARB_vertex_array_object -#define GL_ARB_vertex_array_object 1 - -#define GL_VERTEX_ARRAY_BINDING 0x85B5 - -typedef void (GLAPIENTRY * PFNGLBINDVERTEXARRAYPROC) (GLuint array); -typedef void (GLAPIENTRY * PFNGLDELETEVERTEXARRAYSPROC) (GLsizei n, const GLuint* arrays); -typedef void (GLAPIENTRY * PFNGLGENVERTEXARRAYSPROC) (GLsizei n, GLuint* arrays); -typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXARRAYPROC) (GLuint array); - -#define glBindVertexArray GLEW_GET_FUN(__glewBindVertexArray) -#define glDeleteVertexArrays GLEW_GET_FUN(__glewDeleteVertexArrays) -#define glGenVertexArrays GLEW_GET_FUN(__glewGenVertexArrays) -#define glIsVertexArray GLEW_GET_FUN(__glewIsVertexArray) - -#define GLEW_ARB_vertex_array_object GLEW_GET_VAR(__GLEW_ARB_vertex_array_object) - -#endif /* GL_ARB_vertex_array_object */ - -/* ----------------------- GL_ARB_vertex_attrib_64bit ---------------------- */ - -#ifndef GL_ARB_vertex_attrib_64bit -#define GL_ARB_vertex_attrib_64bit 1 - -#define GL_DOUBLE_MAT2 0x8F46 -#define GL_DOUBLE_MAT3 0x8F47 -#define GL_DOUBLE_MAT4 0x8F48 -#define GL_DOUBLE_VEC2 0x8FFC -#define GL_DOUBLE_VEC3 0x8FFD -#define GL_DOUBLE_VEC4 0x8FFE - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLDVPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLPOINTERPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer); - -#define glGetVertexAttribLdv GLEW_GET_FUN(__glewGetVertexAttribLdv) -#define glVertexAttribL1d GLEW_GET_FUN(__glewVertexAttribL1d) -#define glVertexAttribL1dv GLEW_GET_FUN(__glewVertexAttribL1dv) -#define glVertexAttribL2d GLEW_GET_FUN(__glewVertexAttribL2d) -#define glVertexAttribL2dv GLEW_GET_FUN(__glewVertexAttribL2dv) -#define glVertexAttribL3d GLEW_GET_FUN(__glewVertexAttribL3d) -#define glVertexAttribL3dv GLEW_GET_FUN(__glewVertexAttribL3dv) -#define glVertexAttribL4d GLEW_GET_FUN(__glewVertexAttribL4d) -#define glVertexAttribL4dv GLEW_GET_FUN(__glewVertexAttribL4dv) -#define glVertexAttribLPointer GLEW_GET_FUN(__glewVertexAttribLPointer) - -#define GLEW_ARB_vertex_attrib_64bit GLEW_GET_VAR(__GLEW_ARB_vertex_attrib_64bit) - -#endif /* GL_ARB_vertex_attrib_64bit */ - -/* -------------------------- GL_ARB_vertex_blend -------------------------- */ - -#ifndef GL_ARB_vertex_blend -#define GL_ARB_vertex_blend 1 - -#define GL_MODELVIEW0_ARB 0x1700 -#define GL_MODELVIEW1_ARB 0x850A -#define GL_MAX_VERTEX_UNITS_ARB 0x86A4 -#define GL_ACTIVE_VERTEX_UNITS_ARB 0x86A5 -#define GL_WEIGHT_SUM_UNITY_ARB 0x86A6 -#define GL_VERTEX_BLEND_ARB 0x86A7 -#define GL_CURRENT_WEIGHT_ARB 0x86A8 -#define GL_WEIGHT_ARRAY_TYPE_ARB 0x86A9 -#define GL_WEIGHT_ARRAY_STRIDE_ARB 0x86AA -#define GL_WEIGHT_ARRAY_SIZE_ARB 0x86AB -#define GL_WEIGHT_ARRAY_POINTER_ARB 0x86AC -#define GL_WEIGHT_ARRAY_ARB 0x86AD -#define GL_MODELVIEW2_ARB 0x8722 -#define GL_MODELVIEW3_ARB 0x8723 -#define GL_MODELVIEW4_ARB 0x8724 -#define GL_MODELVIEW5_ARB 0x8725 -#define GL_MODELVIEW6_ARB 0x8726 -#define GL_MODELVIEW7_ARB 0x8727 -#define GL_MODELVIEW8_ARB 0x8728 -#define GL_MODELVIEW9_ARB 0x8729 -#define GL_MODELVIEW10_ARB 0x872A -#define GL_MODELVIEW11_ARB 0x872B -#define GL_MODELVIEW12_ARB 0x872C -#define GL_MODELVIEW13_ARB 0x872D -#define GL_MODELVIEW14_ARB 0x872E -#define GL_MODELVIEW15_ARB 0x872F -#define GL_MODELVIEW16_ARB 0x8730 -#define GL_MODELVIEW17_ARB 0x8731 -#define GL_MODELVIEW18_ARB 0x8732 -#define GL_MODELVIEW19_ARB 0x8733 -#define GL_MODELVIEW20_ARB 0x8734 -#define GL_MODELVIEW21_ARB 0x8735 -#define GL_MODELVIEW22_ARB 0x8736 -#define GL_MODELVIEW23_ARB 0x8737 -#define GL_MODELVIEW24_ARB 0x8738 -#define GL_MODELVIEW25_ARB 0x8739 -#define GL_MODELVIEW26_ARB 0x873A -#define GL_MODELVIEW27_ARB 0x873B -#define GL_MODELVIEW28_ARB 0x873C -#define GL_MODELVIEW29_ARB 0x873D -#define GL_MODELVIEW30_ARB 0x873E -#define GL_MODELVIEW31_ARB 0x873F - -typedef void (GLAPIENTRY * PFNGLVERTEXBLENDARBPROC) (GLint count); -typedef void (GLAPIENTRY * PFNGLWEIGHTPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLWEIGHTBVARBPROC) (GLint size, GLbyte *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTDVARBPROC) (GLint size, GLdouble *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTFVARBPROC) (GLint size, GLfloat *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTIVARBPROC) (GLint size, GLint *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTSVARBPROC) (GLint size, GLshort *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTUBVARBPROC) (GLint size, GLubyte *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTUIVARBPROC) (GLint size, GLuint *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTUSVARBPROC) (GLint size, GLushort *weights); - -#define glVertexBlendARB GLEW_GET_FUN(__glewVertexBlendARB) -#define glWeightPointerARB GLEW_GET_FUN(__glewWeightPointerARB) -#define glWeightbvARB GLEW_GET_FUN(__glewWeightbvARB) -#define glWeightdvARB GLEW_GET_FUN(__glewWeightdvARB) -#define glWeightfvARB GLEW_GET_FUN(__glewWeightfvARB) -#define glWeightivARB GLEW_GET_FUN(__glewWeightivARB) -#define glWeightsvARB GLEW_GET_FUN(__glewWeightsvARB) -#define glWeightubvARB GLEW_GET_FUN(__glewWeightubvARB) -#define glWeightuivARB GLEW_GET_FUN(__glewWeightuivARB) -#define glWeightusvARB GLEW_GET_FUN(__glewWeightusvARB) - -#define GLEW_ARB_vertex_blend GLEW_GET_VAR(__GLEW_ARB_vertex_blend) - -#endif /* GL_ARB_vertex_blend */ - -/* ---------------------- GL_ARB_vertex_buffer_object ---------------------- */ - -#ifndef GL_ARB_vertex_buffer_object -#define GL_ARB_vertex_buffer_object 1 - -#define GL_BUFFER_SIZE_ARB 0x8764 -#define GL_BUFFER_USAGE_ARB 0x8765 -#define GL_ARRAY_BUFFER_ARB 0x8892 -#define GL_ELEMENT_ARRAY_BUFFER_ARB 0x8893 -#define GL_ARRAY_BUFFER_BINDING_ARB 0x8894 -#define GL_ELEMENT_ARRAY_BUFFER_BINDING_ARB 0x8895 -#define GL_VERTEX_ARRAY_BUFFER_BINDING_ARB 0x8896 -#define GL_NORMAL_ARRAY_BUFFER_BINDING_ARB 0x8897 -#define GL_COLOR_ARRAY_BUFFER_BINDING_ARB 0x8898 -#define GL_INDEX_ARRAY_BUFFER_BINDING_ARB 0x8899 -#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING_ARB 0x889A -#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING_ARB 0x889B -#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING_ARB 0x889C -#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING_ARB 0x889D -#define GL_WEIGHT_ARRAY_BUFFER_BINDING_ARB 0x889E -#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING_ARB 0x889F -#define GL_READ_ONLY_ARB 0x88B8 -#define GL_WRITE_ONLY_ARB 0x88B9 -#define GL_READ_WRITE_ARB 0x88BA -#define GL_BUFFER_ACCESS_ARB 0x88BB -#define GL_BUFFER_MAPPED_ARB 0x88BC -#define GL_BUFFER_MAP_POINTER_ARB 0x88BD -#define GL_STREAM_DRAW_ARB 0x88E0 -#define GL_STREAM_READ_ARB 0x88E1 -#define GL_STREAM_COPY_ARB 0x88E2 -#define GL_STATIC_DRAW_ARB 0x88E4 -#define GL_STATIC_READ_ARB 0x88E5 -#define GL_STATIC_COPY_ARB 0x88E6 -#define GL_DYNAMIC_DRAW_ARB 0x88E8 -#define GL_DYNAMIC_READ_ARB 0x88E9 -#define GL_DYNAMIC_COPY_ARB 0x88EA - -typedef ptrdiff_t GLintptrARB; -typedef ptrdiff_t GLsizeiptrARB; - -typedef void (GLAPIENTRY * PFNGLBINDBUFFERARBPROC) (GLenum target, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBUFFERDATAARBPROC) (GLenum target, GLsizeiptrARB size, const GLvoid* data, GLenum usage); -typedef void (GLAPIENTRY * PFNGLBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLDELETEBUFFERSARBPROC) (GLsizei n, const GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLGENBUFFERSARBPROC) (GLsizei n, GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERIVARBPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPOINTERVARBPROC) (GLenum target, GLenum pname, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, GLvoid* data); -typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERARBPROC) (GLuint buffer); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPBUFFERARBPROC) (GLenum target, GLenum access); -typedef GLboolean (GLAPIENTRY * PFNGLUNMAPBUFFERARBPROC) (GLenum target); - -#define glBindBufferARB GLEW_GET_FUN(__glewBindBufferARB) -#define glBufferDataARB GLEW_GET_FUN(__glewBufferDataARB) -#define glBufferSubDataARB GLEW_GET_FUN(__glewBufferSubDataARB) -#define glDeleteBuffersARB GLEW_GET_FUN(__glewDeleteBuffersARB) -#define glGenBuffersARB GLEW_GET_FUN(__glewGenBuffersARB) -#define glGetBufferParameterivARB GLEW_GET_FUN(__glewGetBufferParameterivARB) -#define glGetBufferPointervARB GLEW_GET_FUN(__glewGetBufferPointervARB) -#define glGetBufferSubDataARB GLEW_GET_FUN(__glewGetBufferSubDataARB) -#define glIsBufferARB GLEW_GET_FUN(__glewIsBufferARB) -#define glMapBufferARB GLEW_GET_FUN(__glewMapBufferARB) -#define glUnmapBufferARB GLEW_GET_FUN(__glewUnmapBufferARB) - -#define GLEW_ARB_vertex_buffer_object GLEW_GET_VAR(__GLEW_ARB_vertex_buffer_object) - -#endif /* GL_ARB_vertex_buffer_object */ - -/* ------------------------- GL_ARB_vertex_program ------------------------- */ - -#ifndef GL_ARB_vertex_program -#define GL_ARB_vertex_program 1 - -#define GL_COLOR_SUM_ARB 0x8458 -#define GL_VERTEX_PROGRAM_ARB 0x8620 -#define GL_VERTEX_ATTRIB_ARRAY_ENABLED_ARB 0x8622 -#define GL_VERTEX_ATTRIB_ARRAY_SIZE_ARB 0x8623 -#define GL_VERTEX_ATTRIB_ARRAY_STRIDE_ARB 0x8624 -#define GL_VERTEX_ATTRIB_ARRAY_TYPE_ARB 0x8625 -#define GL_CURRENT_VERTEX_ATTRIB_ARB 0x8626 -#define GL_PROGRAM_LENGTH_ARB 0x8627 -#define GL_PROGRAM_STRING_ARB 0x8628 -#define GL_MAX_PROGRAM_MATRIX_STACK_DEPTH_ARB 0x862E -#define GL_MAX_PROGRAM_MATRICES_ARB 0x862F -#define GL_CURRENT_MATRIX_STACK_DEPTH_ARB 0x8640 -#define GL_CURRENT_MATRIX_ARB 0x8641 -#define GL_VERTEX_PROGRAM_POINT_SIZE_ARB 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE_ARB 0x8643 -#define GL_VERTEX_ATTRIB_ARRAY_POINTER_ARB 0x8645 -#define GL_PROGRAM_ERROR_POSITION_ARB 0x864B -#define GL_PROGRAM_BINDING_ARB 0x8677 -#define GL_MAX_VERTEX_ATTRIBS_ARB 0x8869 -#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED_ARB 0x886A -#define GL_PROGRAM_ERROR_STRING_ARB 0x8874 -#define GL_PROGRAM_FORMAT_ASCII_ARB 0x8875 -#define GL_PROGRAM_FORMAT_ARB 0x8876 -#define GL_PROGRAM_INSTRUCTIONS_ARB 0x88A0 -#define GL_MAX_PROGRAM_INSTRUCTIONS_ARB 0x88A1 -#define GL_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A2 -#define GL_MAX_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A3 -#define GL_PROGRAM_TEMPORARIES_ARB 0x88A4 -#define GL_MAX_PROGRAM_TEMPORARIES_ARB 0x88A5 -#define GL_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A6 -#define GL_MAX_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A7 -#define GL_PROGRAM_PARAMETERS_ARB 0x88A8 -#define GL_MAX_PROGRAM_PARAMETERS_ARB 0x88A9 -#define GL_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AA -#define GL_MAX_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AB -#define GL_PROGRAM_ATTRIBS_ARB 0x88AC -#define GL_MAX_PROGRAM_ATTRIBS_ARB 0x88AD -#define GL_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AE -#define GL_MAX_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AF -#define GL_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B0 -#define GL_MAX_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B1 -#define GL_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B2 -#define GL_MAX_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B3 -#define GL_MAX_PROGRAM_LOCAL_PARAMETERS_ARB 0x88B4 -#define GL_MAX_PROGRAM_ENV_PARAMETERS_ARB 0x88B5 -#define GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB 0x88B6 -#define GL_TRANSPOSE_CURRENT_MATRIX_ARB 0x88B7 -#define GL_MATRIX0_ARB 0x88C0 -#define GL_MATRIX1_ARB 0x88C1 -#define GL_MATRIX2_ARB 0x88C2 -#define GL_MATRIX3_ARB 0x88C3 -#define GL_MATRIX4_ARB 0x88C4 -#define GL_MATRIX5_ARB 0x88C5 -#define GL_MATRIX6_ARB 0x88C6 -#define GL_MATRIX7_ARB 0x88C7 -#define GL_MATRIX8_ARB 0x88C8 -#define GL_MATRIX9_ARB 0x88C9 -#define GL_MATRIX10_ARB 0x88CA -#define GL_MATRIX11_ARB 0x88CB -#define GL_MATRIX12_ARB 0x88CC -#define GL_MATRIX13_ARB 0x88CD -#define GL_MATRIX14_ARB 0x88CE -#define GL_MATRIX15_ARB 0x88CF -#define GL_MATRIX16_ARB 0x88D0 -#define GL_MATRIX17_ARB 0x88D1 -#define GL_MATRIX18_ARB 0x88D2 -#define GL_MATRIX19_ARB 0x88D3 -#define GL_MATRIX20_ARB 0x88D4 -#define GL_MATRIX21_ARB 0x88D5 -#define GL_MATRIX22_ARB 0x88D6 -#define GL_MATRIX23_ARB 0x88D7 -#define GL_MATRIX24_ARB 0x88D8 -#define GL_MATRIX25_ARB 0x88D9 -#define GL_MATRIX26_ARB 0x88DA -#define GL_MATRIX27_ARB 0x88DB -#define GL_MATRIX28_ARB 0x88DC -#define GL_MATRIX29_ARB 0x88DD -#define GL_MATRIX30_ARB 0x88DE -#define GL_MATRIX31_ARB 0x88DF - -typedef void (GLAPIENTRY * PFNGLBINDPROGRAMARBPROC) (GLenum target, GLuint program); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMSARBPROC) (GLsizei n, const GLuint* programs); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); -typedef void (GLAPIENTRY * PFNGLGENPROGRAMSARBPROC) (GLsizei n, GLuint* programs); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMENVPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMENVPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTRINGARBPROC) (GLenum target, GLenum pname, void* string); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVARBPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVARBPROC) (GLuint index, GLenum pname, GLvoid** pointer); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVARBPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVARBPROC) (GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVARBPROC) (GLuint index, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMARBPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMSTRINGARBPROC) (GLenum target, GLenum format, GLsizei len, const void* string); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DARBPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FARBPROC) (GLuint index, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SARBPROC) (GLuint index, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DARBPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FARBPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SARBPROC) (GLuint index, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NBVARBPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NIVARBPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NSVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBARBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBVARBPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUIVARBPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUSVARBPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4BVARBPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4IVARBPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVARBPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UIVARBPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4USVARBPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERARBPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void* pointer); - -#define glBindProgramARB GLEW_GET_FUN(__glewBindProgramARB) -#define glDeleteProgramsARB GLEW_GET_FUN(__glewDeleteProgramsARB) -#define glDisableVertexAttribArrayARB GLEW_GET_FUN(__glewDisableVertexAttribArrayARB) -#define glEnableVertexAttribArrayARB GLEW_GET_FUN(__glewEnableVertexAttribArrayARB) -#define glGenProgramsARB GLEW_GET_FUN(__glewGenProgramsARB) -#define glGetProgramEnvParameterdvARB GLEW_GET_FUN(__glewGetProgramEnvParameterdvARB) -#define glGetProgramEnvParameterfvARB GLEW_GET_FUN(__glewGetProgramEnvParameterfvARB) -#define glGetProgramLocalParameterdvARB GLEW_GET_FUN(__glewGetProgramLocalParameterdvARB) -#define glGetProgramLocalParameterfvARB GLEW_GET_FUN(__glewGetProgramLocalParameterfvARB) -#define glGetProgramStringARB GLEW_GET_FUN(__glewGetProgramStringARB) -#define glGetProgramivARB GLEW_GET_FUN(__glewGetProgramivARB) -#define glGetVertexAttribPointervARB GLEW_GET_FUN(__glewGetVertexAttribPointervARB) -#define glGetVertexAttribdvARB GLEW_GET_FUN(__glewGetVertexAttribdvARB) -#define glGetVertexAttribfvARB GLEW_GET_FUN(__glewGetVertexAttribfvARB) -#define glGetVertexAttribivARB GLEW_GET_FUN(__glewGetVertexAttribivARB) -#define glIsProgramARB GLEW_GET_FUN(__glewIsProgramARB) -#define glProgramEnvParameter4dARB GLEW_GET_FUN(__glewProgramEnvParameter4dARB) -#define glProgramEnvParameter4dvARB GLEW_GET_FUN(__glewProgramEnvParameter4dvARB) -#define glProgramEnvParameter4fARB GLEW_GET_FUN(__glewProgramEnvParameter4fARB) -#define glProgramEnvParameter4fvARB GLEW_GET_FUN(__glewProgramEnvParameter4fvARB) -#define glProgramLocalParameter4dARB GLEW_GET_FUN(__glewProgramLocalParameter4dARB) -#define glProgramLocalParameter4dvARB GLEW_GET_FUN(__glewProgramLocalParameter4dvARB) -#define glProgramLocalParameter4fARB GLEW_GET_FUN(__glewProgramLocalParameter4fARB) -#define glProgramLocalParameter4fvARB GLEW_GET_FUN(__glewProgramLocalParameter4fvARB) -#define glProgramStringARB GLEW_GET_FUN(__glewProgramStringARB) -#define glVertexAttrib1dARB GLEW_GET_FUN(__glewVertexAttrib1dARB) -#define glVertexAttrib1dvARB GLEW_GET_FUN(__glewVertexAttrib1dvARB) -#define glVertexAttrib1fARB GLEW_GET_FUN(__glewVertexAttrib1fARB) -#define glVertexAttrib1fvARB GLEW_GET_FUN(__glewVertexAttrib1fvARB) -#define glVertexAttrib1sARB GLEW_GET_FUN(__glewVertexAttrib1sARB) -#define glVertexAttrib1svARB GLEW_GET_FUN(__glewVertexAttrib1svARB) -#define glVertexAttrib2dARB GLEW_GET_FUN(__glewVertexAttrib2dARB) -#define glVertexAttrib2dvARB GLEW_GET_FUN(__glewVertexAttrib2dvARB) -#define glVertexAttrib2fARB GLEW_GET_FUN(__glewVertexAttrib2fARB) -#define glVertexAttrib2fvARB GLEW_GET_FUN(__glewVertexAttrib2fvARB) -#define glVertexAttrib2sARB GLEW_GET_FUN(__glewVertexAttrib2sARB) -#define glVertexAttrib2svARB GLEW_GET_FUN(__glewVertexAttrib2svARB) -#define glVertexAttrib3dARB GLEW_GET_FUN(__glewVertexAttrib3dARB) -#define glVertexAttrib3dvARB GLEW_GET_FUN(__glewVertexAttrib3dvARB) -#define glVertexAttrib3fARB GLEW_GET_FUN(__glewVertexAttrib3fARB) -#define glVertexAttrib3fvARB GLEW_GET_FUN(__glewVertexAttrib3fvARB) -#define glVertexAttrib3sARB GLEW_GET_FUN(__glewVertexAttrib3sARB) -#define glVertexAttrib3svARB GLEW_GET_FUN(__glewVertexAttrib3svARB) -#define glVertexAttrib4NbvARB GLEW_GET_FUN(__glewVertexAttrib4NbvARB) -#define glVertexAttrib4NivARB GLEW_GET_FUN(__glewVertexAttrib4NivARB) -#define glVertexAttrib4NsvARB GLEW_GET_FUN(__glewVertexAttrib4NsvARB) -#define glVertexAttrib4NubARB GLEW_GET_FUN(__glewVertexAttrib4NubARB) -#define glVertexAttrib4NubvARB GLEW_GET_FUN(__glewVertexAttrib4NubvARB) -#define glVertexAttrib4NuivARB GLEW_GET_FUN(__glewVertexAttrib4NuivARB) -#define glVertexAttrib4NusvARB GLEW_GET_FUN(__glewVertexAttrib4NusvARB) -#define glVertexAttrib4bvARB GLEW_GET_FUN(__glewVertexAttrib4bvARB) -#define glVertexAttrib4dARB GLEW_GET_FUN(__glewVertexAttrib4dARB) -#define glVertexAttrib4dvARB GLEW_GET_FUN(__glewVertexAttrib4dvARB) -#define glVertexAttrib4fARB GLEW_GET_FUN(__glewVertexAttrib4fARB) -#define glVertexAttrib4fvARB GLEW_GET_FUN(__glewVertexAttrib4fvARB) -#define glVertexAttrib4ivARB GLEW_GET_FUN(__glewVertexAttrib4ivARB) -#define glVertexAttrib4sARB GLEW_GET_FUN(__glewVertexAttrib4sARB) -#define glVertexAttrib4svARB GLEW_GET_FUN(__glewVertexAttrib4svARB) -#define glVertexAttrib4ubvARB GLEW_GET_FUN(__glewVertexAttrib4ubvARB) -#define glVertexAttrib4uivARB GLEW_GET_FUN(__glewVertexAttrib4uivARB) -#define glVertexAttrib4usvARB GLEW_GET_FUN(__glewVertexAttrib4usvARB) -#define glVertexAttribPointerARB GLEW_GET_FUN(__glewVertexAttribPointerARB) - -#define GLEW_ARB_vertex_program GLEW_GET_VAR(__GLEW_ARB_vertex_program) - -#endif /* GL_ARB_vertex_program */ - -/* -------------------------- GL_ARB_vertex_shader ------------------------- */ - -#ifndef GL_ARB_vertex_shader -#define GL_ARB_vertex_shader 1 - -#define GL_VERTEX_SHADER_ARB 0x8B31 -#define GL_MAX_VERTEX_UNIFORM_COMPONENTS_ARB 0x8B4A -#define GL_MAX_VARYING_FLOATS_ARB 0x8B4B -#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C -#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS_ARB 0x8B4D -#define GL_OBJECT_ACTIVE_ATTRIBUTES_ARB 0x8B89 -#define GL_OBJECT_ACTIVE_ATTRIBUTE_MAX_LENGTH_ARB 0x8B8A - -typedef void (GLAPIENTRY * PFNGLBINDATTRIBLOCATIONARBPROC) (GLhandleARB programObj, GLuint index, const GLcharARB* name); -typedef void (GLAPIENTRY * PFNGLGETACTIVEATTRIBARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name); -typedef GLint (GLAPIENTRY * PFNGLGETATTRIBLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB* name); - -#define glBindAttribLocationARB GLEW_GET_FUN(__glewBindAttribLocationARB) -#define glGetActiveAttribARB GLEW_GET_FUN(__glewGetActiveAttribARB) -#define glGetAttribLocationARB GLEW_GET_FUN(__glewGetAttribLocationARB) - -#define GLEW_ARB_vertex_shader GLEW_GET_VAR(__GLEW_ARB_vertex_shader) - -#endif /* GL_ARB_vertex_shader */ - -/* ------------------- GL_ARB_vertex_type_2_10_10_10_rev ------------------- */ - -#ifndef GL_ARB_vertex_type_2_10_10_10_rev -#define GL_ARB_vertex_type_2_10_10_10_rev 1 - -#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 -#define GL_INT_2_10_10_10_REV 0x8D9F - -typedef void (GLAPIENTRY * PFNGLCOLORP3UIPROC) (GLenum type, GLuint color); -typedef void (GLAPIENTRY * PFNGLCOLORP3UIVPROC) (GLenum type, const GLuint* color); -typedef void (GLAPIENTRY * PFNGLCOLORP4UIPROC) (GLenum type, GLuint color); -typedef void (GLAPIENTRY * PFNGLCOLORP4UIVPROC) (GLenum type, const GLuint* color); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP1UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP1UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP2UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP2UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP3UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP3UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP4UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP4UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLNORMALP3UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLNORMALP3UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORP3UIPROC) (GLenum type, GLuint color); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORP3UIVPROC) (GLenum type, const GLuint* color); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP1UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP1UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP2UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP2UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP3UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP3UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP4UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP4UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP1UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP1UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP2UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP2UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP3UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP3UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP4UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP4UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXP2UIPROC) (GLenum type, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXP2UIVPROC) (GLenum type, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXP3UIPROC) (GLenum type, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXP3UIVPROC) (GLenum type, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXP4UIPROC) (GLenum type, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXP4UIVPROC) (GLenum type, const GLuint* value); - -#define glColorP3ui GLEW_GET_FUN(__glewColorP3ui) -#define glColorP3uiv GLEW_GET_FUN(__glewColorP3uiv) -#define glColorP4ui GLEW_GET_FUN(__glewColorP4ui) -#define glColorP4uiv GLEW_GET_FUN(__glewColorP4uiv) -#define glMultiTexCoordP1ui GLEW_GET_FUN(__glewMultiTexCoordP1ui) -#define glMultiTexCoordP1uiv GLEW_GET_FUN(__glewMultiTexCoordP1uiv) -#define glMultiTexCoordP2ui GLEW_GET_FUN(__glewMultiTexCoordP2ui) -#define glMultiTexCoordP2uiv GLEW_GET_FUN(__glewMultiTexCoordP2uiv) -#define glMultiTexCoordP3ui GLEW_GET_FUN(__glewMultiTexCoordP3ui) -#define glMultiTexCoordP3uiv GLEW_GET_FUN(__glewMultiTexCoordP3uiv) -#define glMultiTexCoordP4ui GLEW_GET_FUN(__glewMultiTexCoordP4ui) -#define glMultiTexCoordP4uiv GLEW_GET_FUN(__glewMultiTexCoordP4uiv) -#define glNormalP3ui GLEW_GET_FUN(__glewNormalP3ui) -#define glNormalP3uiv GLEW_GET_FUN(__glewNormalP3uiv) -#define glSecondaryColorP3ui GLEW_GET_FUN(__glewSecondaryColorP3ui) -#define glSecondaryColorP3uiv GLEW_GET_FUN(__glewSecondaryColorP3uiv) -#define glTexCoordP1ui GLEW_GET_FUN(__glewTexCoordP1ui) -#define glTexCoordP1uiv GLEW_GET_FUN(__glewTexCoordP1uiv) -#define glTexCoordP2ui GLEW_GET_FUN(__glewTexCoordP2ui) -#define glTexCoordP2uiv GLEW_GET_FUN(__glewTexCoordP2uiv) -#define glTexCoordP3ui GLEW_GET_FUN(__glewTexCoordP3ui) -#define glTexCoordP3uiv GLEW_GET_FUN(__glewTexCoordP3uiv) -#define glTexCoordP4ui GLEW_GET_FUN(__glewTexCoordP4ui) -#define glTexCoordP4uiv GLEW_GET_FUN(__glewTexCoordP4uiv) -#define glVertexAttribP1ui GLEW_GET_FUN(__glewVertexAttribP1ui) -#define glVertexAttribP1uiv GLEW_GET_FUN(__glewVertexAttribP1uiv) -#define glVertexAttribP2ui GLEW_GET_FUN(__glewVertexAttribP2ui) -#define glVertexAttribP2uiv GLEW_GET_FUN(__glewVertexAttribP2uiv) -#define glVertexAttribP3ui GLEW_GET_FUN(__glewVertexAttribP3ui) -#define glVertexAttribP3uiv GLEW_GET_FUN(__glewVertexAttribP3uiv) -#define glVertexAttribP4ui GLEW_GET_FUN(__glewVertexAttribP4ui) -#define glVertexAttribP4uiv GLEW_GET_FUN(__glewVertexAttribP4uiv) -#define glVertexP2ui GLEW_GET_FUN(__glewVertexP2ui) -#define glVertexP2uiv GLEW_GET_FUN(__glewVertexP2uiv) -#define glVertexP3ui GLEW_GET_FUN(__glewVertexP3ui) -#define glVertexP3uiv GLEW_GET_FUN(__glewVertexP3uiv) -#define glVertexP4ui GLEW_GET_FUN(__glewVertexP4ui) -#define glVertexP4uiv GLEW_GET_FUN(__glewVertexP4uiv) - -#define GLEW_ARB_vertex_type_2_10_10_10_rev GLEW_GET_VAR(__GLEW_ARB_vertex_type_2_10_10_10_rev) - -#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ - -/* ------------------------- GL_ARB_viewport_array ------------------------- */ - -#ifndef GL_ARB_viewport_array -#define GL_ARB_viewport_array 1 - -#define GL_DEPTH_RANGE 0x0B70 -#define GL_VIEWPORT 0x0BA2 -#define GL_SCISSOR_BOX 0x0C10 -#define GL_SCISSOR_TEST 0x0C11 -#define GL_MAX_VIEWPORTS 0x825B -#define GL_VIEWPORT_SUBPIXEL_BITS 0x825C -#define GL_VIEWPORT_BOUNDS_RANGE 0x825D -#define GL_LAYER_PROVOKING_VERTEX 0x825E -#define GL_VIEWPORT_INDEX_PROVOKING_VERTEX 0x825F -#define GL_UNDEFINED_VERTEX 0x8260 -#define GL_FIRST_VERTEX_CONVENTION 0x8E4D -#define GL_LAST_VERTEX_CONVENTION 0x8E4E -#define GL_PROVOKING_VERTEX 0x8E4F - -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEARRAYVPROC) (GLuint first, GLsizei count, const GLclampd * v); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEINDEXEDPROC) (GLuint index, GLclampd n, GLclampd f); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEI_VPROC) (GLenum target, GLuint index, GLdouble* data); -typedef void (GLAPIENTRY * PFNGLGETFLOATI_VPROC) (GLenum target, GLuint index, GLfloat* data); -typedef void (GLAPIENTRY * PFNGLSCISSORARRAYVPROC) (GLuint first, GLsizei count, const GLint * v); -typedef void (GLAPIENTRY * PFNGLSCISSORINDEXEDPROC) (GLuint index, GLint left, GLint bottom, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLSCISSORINDEXEDVPROC) (GLuint index, const GLint * v); -typedef void (GLAPIENTRY * PFNGLVIEWPORTARRAYVPROC) (GLuint first, GLsizei count, const GLfloat * v); -typedef void (GLAPIENTRY * PFNGLVIEWPORTINDEXEDFPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat w, GLfloat h); -typedef void (GLAPIENTRY * PFNGLVIEWPORTINDEXEDFVPROC) (GLuint index, const GLfloat * v); - -#define glDepthRangeArrayv GLEW_GET_FUN(__glewDepthRangeArrayv) -#define glDepthRangeIndexed GLEW_GET_FUN(__glewDepthRangeIndexed) -#define glGetDoublei_v GLEW_GET_FUN(__glewGetDoublei_v) -#define glGetFloati_v GLEW_GET_FUN(__glewGetFloati_v) -#define glScissorArrayv GLEW_GET_FUN(__glewScissorArrayv) -#define glScissorIndexed GLEW_GET_FUN(__glewScissorIndexed) -#define glScissorIndexedv GLEW_GET_FUN(__glewScissorIndexedv) -#define glViewportArrayv GLEW_GET_FUN(__glewViewportArrayv) -#define glViewportIndexedf GLEW_GET_FUN(__glewViewportIndexedf) -#define glViewportIndexedfv GLEW_GET_FUN(__glewViewportIndexedfv) - -#define GLEW_ARB_viewport_array GLEW_GET_VAR(__GLEW_ARB_viewport_array) - -#endif /* GL_ARB_viewport_array */ - -/* --------------------------- GL_ARB_window_pos --------------------------- */ - -#ifndef GL_ARB_window_pos -#define GL_ARB_window_pos 1 - -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DARBPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVARBPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FARBPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVARBPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IARBPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVARBPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SARBPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVARBPROC) (const GLshort* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DARBPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVARBPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FARBPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVARBPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IARBPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVARBPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SARBPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVARBPROC) (const GLshort* p); - -#define glWindowPos2dARB GLEW_GET_FUN(__glewWindowPos2dARB) -#define glWindowPos2dvARB GLEW_GET_FUN(__glewWindowPos2dvARB) -#define glWindowPos2fARB GLEW_GET_FUN(__glewWindowPos2fARB) -#define glWindowPos2fvARB GLEW_GET_FUN(__glewWindowPos2fvARB) -#define glWindowPos2iARB GLEW_GET_FUN(__glewWindowPos2iARB) -#define glWindowPos2ivARB GLEW_GET_FUN(__glewWindowPos2ivARB) -#define glWindowPos2sARB GLEW_GET_FUN(__glewWindowPos2sARB) -#define glWindowPos2svARB GLEW_GET_FUN(__glewWindowPos2svARB) -#define glWindowPos3dARB GLEW_GET_FUN(__glewWindowPos3dARB) -#define glWindowPos3dvARB GLEW_GET_FUN(__glewWindowPos3dvARB) -#define glWindowPos3fARB GLEW_GET_FUN(__glewWindowPos3fARB) -#define glWindowPos3fvARB GLEW_GET_FUN(__glewWindowPos3fvARB) -#define glWindowPos3iARB GLEW_GET_FUN(__glewWindowPos3iARB) -#define glWindowPos3ivARB GLEW_GET_FUN(__glewWindowPos3ivARB) -#define glWindowPos3sARB GLEW_GET_FUN(__glewWindowPos3sARB) -#define glWindowPos3svARB GLEW_GET_FUN(__glewWindowPos3svARB) - -#define GLEW_ARB_window_pos GLEW_GET_VAR(__GLEW_ARB_window_pos) - -#endif /* GL_ARB_window_pos */ - -/* ------------------------- GL_ATIX_point_sprites ------------------------- */ - -#ifndef GL_ATIX_point_sprites -#define GL_ATIX_point_sprites 1 - -#define GL_TEXTURE_POINT_MODE_ATIX 0x60B0 -#define GL_TEXTURE_POINT_ONE_COORD_ATIX 0x60B1 -#define GL_TEXTURE_POINT_SPRITE_ATIX 0x60B2 -#define GL_POINT_SPRITE_CULL_MODE_ATIX 0x60B3 -#define GL_POINT_SPRITE_CULL_CENTER_ATIX 0x60B4 -#define GL_POINT_SPRITE_CULL_CLIP_ATIX 0x60B5 - -#define GLEW_ATIX_point_sprites GLEW_GET_VAR(__GLEW_ATIX_point_sprites) - -#endif /* GL_ATIX_point_sprites */ - -/* ---------------------- GL_ATIX_texture_env_combine3 --------------------- */ - -#ifndef GL_ATIX_texture_env_combine3 -#define GL_ATIX_texture_env_combine3 1 - -#define GL_MODULATE_ADD_ATIX 0x8744 -#define GL_MODULATE_SIGNED_ADD_ATIX 0x8745 -#define GL_MODULATE_SUBTRACT_ATIX 0x8746 - -#define GLEW_ATIX_texture_env_combine3 GLEW_GET_VAR(__GLEW_ATIX_texture_env_combine3) - -#endif /* GL_ATIX_texture_env_combine3 */ - -/* ----------------------- GL_ATIX_texture_env_route ----------------------- */ - -#ifndef GL_ATIX_texture_env_route -#define GL_ATIX_texture_env_route 1 - -#define GL_SECONDARY_COLOR_ATIX 0x8747 -#define GL_TEXTURE_OUTPUT_RGB_ATIX 0x8748 -#define GL_TEXTURE_OUTPUT_ALPHA_ATIX 0x8749 - -#define GLEW_ATIX_texture_env_route GLEW_GET_VAR(__GLEW_ATIX_texture_env_route) - -#endif /* GL_ATIX_texture_env_route */ - -/* ---------------- GL_ATIX_vertex_shader_output_point_size ---------------- */ - -#ifndef GL_ATIX_vertex_shader_output_point_size -#define GL_ATIX_vertex_shader_output_point_size 1 - -#define GL_OUTPUT_POINT_SIZE_ATIX 0x610E - -#define GLEW_ATIX_vertex_shader_output_point_size GLEW_GET_VAR(__GLEW_ATIX_vertex_shader_output_point_size) - -#endif /* GL_ATIX_vertex_shader_output_point_size */ - -/* -------------------------- GL_ATI_draw_buffers -------------------------- */ - -#ifndef GL_ATI_draw_buffers -#define GL_ATI_draw_buffers 1 - -#define GL_MAX_DRAW_BUFFERS_ATI 0x8824 -#define GL_DRAW_BUFFER0_ATI 0x8825 -#define GL_DRAW_BUFFER1_ATI 0x8826 -#define GL_DRAW_BUFFER2_ATI 0x8827 -#define GL_DRAW_BUFFER3_ATI 0x8828 -#define GL_DRAW_BUFFER4_ATI 0x8829 -#define GL_DRAW_BUFFER5_ATI 0x882A -#define GL_DRAW_BUFFER6_ATI 0x882B -#define GL_DRAW_BUFFER7_ATI 0x882C -#define GL_DRAW_BUFFER8_ATI 0x882D -#define GL_DRAW_BUFFER9_ATI 0x882E -#define GL_DRAW_BUFFER10_ATI 0x882F -#define GL_DRAW_BUFFER11_ATI 0x8830 -#define GL_DRAW_BUFFER12_ATI 0x8831 -#define GL_DRAW_BUFFER13_ATI 0x8832 -#define GL_DRAW_BUFFER14_ATI 0x8833 -#define GL_DRAW_BUFFER15_ATI 0x8834 - -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSATIPROC) (GLsizei n, const GLenum* bufs); - -#define glDrawBuffersATI GLEW_GET_FUN(__glewDrawBuffersATI) - -#define GLEW_ATI_draw_buffers GLEW_GET_VAR(__GLEW_ATI_draw_buffers) - -#endif /* GL_ATI_draw_buffers */ - -/* -------------------------- GL_ATI_element_array ------------------------- */ - -#ifndef GL_ATI_element_array -#define GL_ATI_element_array 1 - -#define GL_ELEMENT_ARRAY_ATI 0x8768 -#define GL_ELEMENT_ARRAY_TYPE_ATI 0x8769 -#define GL_ELEMENT_ARRAY_POINTER_ATI 0x876A - -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTARRAYATIPROC) (GLenum mode, GLsizei count); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTARRAYATIPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count); -typedef void (GLAPIENTRY * PFNGLELEMENTPOINTERATIPROC) (GLenum type, const void* pointer); - -#define glDrawElementArrayATI GLEW_GET_FUN(__glewDrawElementArrayATI) -#define glDrawRangeElementArrayATI GLEW_GET_FUN(__glewDrawRangeElementArrayATI) -#define glElementPointerATI GLEW_GET_FUN(__glewElementPointerATI) - -#define GLEW_ATI_element_array GLEW_GET_VAR(__GLEW_ATI_element_array) - -#endif /* GL_ATI_element_array */ - -/* ------------------------- GL_ATI_envmap_bumpmap ------------------------- */ - -#ifndef GL_ATI_envmap_bumpmap -#define GL_ATI_envmap_bumpmap 1 - -#define GL_BUMP_ROT_MATRIX_ATI 0x8775 -#define GL_BUMP_ROT_MATRIX_SIZE_ATI 0x8776 -#define GL_BUMP_NUM_TEX_UNITS_ATI 0x8777 -#define GL_BUMP_TEX_UNITS_ATI 0x8778 -#define GL_DUDV_ATI 0x8779 -#define GL_DU8DV8_ATI 0x877A -#define GL_BUMP_ENVMAP_ATI 0x877B -#define GL_BUMP_TARGET_ATI 0x877C - -typedef void (GLAPIENTRY * PFNGLGETTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); -typedef void (GLAPIENTRY * PFNGLGETTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); -typedef void (GLAPIENTRY * PFNGLTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); -typedef void (GLAPIENTRY * PFNGLTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); - -#define glGetTexBumpParameterfvATI GLEW_GET_FUN(__glewGetTexBumpParameterfvATI) -#define glGetTexBumpParameterivATI GLEW_GET_FUN(__glewGetTexBumpParameterivATI) -#define glTexBumpParameterfvATI GLEW_GET_FUN(__glewTexBumpParameterfvATI) -#define glTexBumpParameterivATI GLEW_GET_FUN(__glewTexBumpParameterivATI) - -#define GLEW_ATI_envmap_bumpmap GLEW_GET_VAR(__GLEW_ATI_envmap_bumpmap) - -#endif /* GL_ATI_envmap_bumpmap */ - -/* ------------------------- GL_ATI_fragment_shader ------------------------ */ - -#ifndef GL_ATI_fragment_shader -#define GL_ATI_fragment_shader 1 - -#define GL_RED_BIT_ATI 0x00000001 -#define GL_2X_BIT_ATI 0x00000001 -#define GL_4X_BIT_ATI 0x00000002 -#define GL_GREEN_BIT_ATI 0x00000002 -#define GL_COMP_BIT_ATI 0x00000002 -#define GL_BLUE_BIT_ATI 0x00000004 -#define GL_8X_BIT_ATI 0x00000004 -#define GL_NEGATE_BIT_ATI 0x00000004 -#define GL_BIAS_BIT_ATI 0x00000008 -#define GL_HALF_BIT_ATI 0x00000008 -#define GL_QUARTER_BIT_ATI 0x00000010 -#define GL_EIGHTH_BIT_ATI 0x00000020 -#define GL_SATURATE_BIT_ATI 0x00000040 -#define GL_FRAGMENT_SHADER_ATI 0x8920 -#define GL_REG_0_ATI 0x8921 -#define GL_REG_1_ATI 0x8922 -#define GL_REG_2_ATI 0x8923 -#define GL_REG_3_ATI 0x8924 -#define GL_REG_4_ATI 0x8925 -#define GL_REG_5_ATI 0x8926 -#define GL_CON_0_ATI 0x8941 -#define GL_CON_1_ATI 0x8942 -#define GL_CON_2_ATI 0x8943 -#define GL_CON_3_ATI 0x8944 -#define GL_CON_4_ATI 0x8945 -#define GL_CON_5_ATI 0x8946 -#define GL_CON_6_ATI 0x8947 -#define GL_CON_7_ATI 0x8948 -#define GL_MOV_ATI 0x8961 -#define GL_ADD_ATI 0x8963 -#define GL_MUL_ATI 0x8964 -#define GL_SUB_ATI 0x8965 -#define GL_DOT3_ATI 0x8966 -#define GL_DOT4_ATI 0x8967 -#define GL_MAD_ATI 0x8968 -#define GL_LERP_ATI 0x8969 -#define GL_CND_ATI 0x896A -#define GL_CND0_ATI 0x896B -#define GL_DOT2_ADD_ATI 0x896C -#define GL_SECONDARY_INTERPOLATOR_ATI 0x896D -#define GL_NUM_FRAGMENT_REGISTERS_ATI 0x896E -#define GL_NUM_FRAGMENT_CONSTANTS_ATI 0x896F -#define GL_NUM_PASSES_ATI 0x8970 -#define GL_NUM_INSTRUCTIONS_PER_PASS_ATI 0x8971 -#define GL_NUM_INSTRUCTIONS_TOTAL_ATI 0x8972 -#define GL_NUM_INPUT_INTERPOLATOR_COMPONENTS_ATI 0x8973 -#define GL_NUM_LOOPBACK_COMPONENTS_ATI 0x8974 -#define GL_COLOR_ALPHA_PAIRING_ATI 0x8975 -#define GL_SWIZZLE_STR_ATI 0x8976 -#define GL_SWIZZLE_STQ_ATI 0x8977 -#define GL_SWIZZLE_STR_DR_ATI 0x8978 -#define GL_SWIZZLE_STQ_DQ_ATI 0x8979 -#define GL_SWIZZLE_STRQ_ATI 0x897A -#define GL_SWIZZLE_STRQ_DQ_ATI 0x897B - -typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); -typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); -typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); -typedef void (GLAPIENTRY * PFNGLBEGINFRAGMENTSHADERATIPROC) (void); -typedef void (GLAPIENTRY * PFNGLBINDFRAGMENTSHADERATIPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); -typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); -typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); -typedef void (GLAPIENTRY * PFNGLDELETEFRAGMENTSHADERATIPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENDFRAGMENTSHADERATIPROC) (void); -typedef GLuint (GLAPIENTRY * PFNGLGENFRAGMENTSHADERSATIPROC) (GLuint range); -typedef void (GLAPIENTRY * PFNGLPASSTEXCOORDATIPROC) (GLuint dst, GLuint coord, GLenum swizzle); -typedef void (GLAPIENTRY * PFNGLSAMPLEMAPATIPROC) (GLuint dst, GLuint interp, GLenum swizzle); -typedef void (GLAPIENTRY * PFNGLSETFRAGMENTSHADERCONSTANTATIPROC) (GLuint dst, const GLfloat* value); - -#define glAlphaFragmentOp1ATI GLEW_GET_FUN(__glewAlphaFragmentOp1ATI) -#define glAlphaFragmentOp2ATI GLEW_GET_FUN(__glewAlphaFragmentOp2ATI) -#define glAlphaFragmentOp3ATI GLEW_GET_FUN(__glewAlphaFragmentOp3ATI) -#define glBeginFragmentShaderATI GLEW_GET_FUN(__glewBeginFragmentShaderATI) -#define glBindFragmentShaderATI GLEW_GET_FUN(__glewBindFragmentShaderATI) -#define glColorFragmentOp1ATI GLEW_GET_FUN(__glewColorFragmentOp1ATI) -#define glColorFragmentOp2ATI GLEW_GET_FUN(__glewColorFragmentOp2ATI) -#define glColorFragmentOp3ATI GLEW_GET_FUN(__glewColorFragmentOp3ATI) -#define glDeleteFragmentShaderATI GLEW_GET_FUN(__glewDeleteFragmentShaderATI) -#define glEndFragmentShaderATI GLEW_GET_FUN(__glewEndFragmentShaderATI) -#define glGenFragmentShadersATI GLEW_GET_FUN(__glewGenFragmentShadersATI) -#define glPassTexCoordATI GLEW_GET_FUN(__glewPassTexCoordATI) -#define glSampleMapATI GLEW_GET_FUN(__glewSampleMapATI) -#define glSetFragmentShaderConstantATI GLEW_GET_FUN(__glewSetFragmentShaderConstantATI) - -#define GLEW_ATI_fragment_shader GLEW_GET_VAR(__GLEW_ATI_fragment_shader) - -#endif /* GL_ATI_fragment_shader */ - -/* ------------------------ GL_ATI_map_object_buffer ----------------------- */ - -#ifndef GL_ATI_map_object_buffer -#define GL_ATI_map_object_buffer 1 - -typedef void* (GLAPIENTRY * PFNGLMAPOBJECTBUFFERATIPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLUNMAPOBJECTBUFFERATIPROC) (GLuint buffer); - -#define glMapObjectBufferATI GLEW_GET_FUN(__glewMapObjectBufferATI) -#define glUnmapObjectBufferATI GLEW_GET_FUN(__glewUnmapObjectBufferATI) - -#define GLEW_ATI_map_object_buffer GLEW_GET_VAR(__GLEW_ATI_map_object_buffer) - -#endif /* GL_ATI_map_object_buffer */ - -/* ----------------------------- GL_ATI_meminfo ---------------------------- */ - -#ifndef GL_ATI_meminfo -#define GL_ATI_meminfo 1 - -#define GL_VBO_FREE_MEMORY_ATI 0x87FB -#define GL_TEXTURE_FREE_MEMORY_ATI 0x87FC -#define GL_RENDERBUFFER_FREE_MEMORY_ATI 0x87FD - -#define GLEW_ATI_meminfo GLEW_GET_VAR(__GLEW_ATI_meminfo) - -#endif /* GL_ATI_meminfo */ - -/* -------------------------- GL_ATI_pn_triangles -------------------------- */ - -#ifndef GL_ATI_pn_triangles -#define GL_ATI_pn_triangles 1 - -#define GL_PN_TRIANGLES_ATI 0x87F0 -#define GL_MAX_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F1 -#define GL_PN_TRIANGLES_POINT_MODE_ATI 0x87F2 -#define GL_PN_TRIANGLES_NORMAL_MODE_ATI 0x87F3 -#define GL_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F4 -#define GL_PN_TRIANGLES_POINT_MODE_LINEAR_ATI 0x87F5 -#define GL_PN_TRIANGLES_POINT_MODE_CUBIC_ATI 0x87F6 -#define GL_PN_TRIANGLES_NORMAL_MODE_LINEAR_ATI 0x87F7 -#define GL_PN_TRIANGLES_NORMAL_MODE_QUADRATIC_ATI 0x87F8 - -typedef void (GLAPIENTRY * PFNGLPNTRIANGLESFATIPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPNTRIANGLESIATIPROC) (GLenum pname, GLint param); - -#define glPNTrianglesfATI GLEW_GET_FUN(__glewPNTrianglesfATI) -#define glPNTrianglesiATI GLEW_GET_FUN(__glewPNTrianglesiATI) - -#define GLEW_ATI_pn_triangles GLEW_GET_VAR(__GLEW_ATI_pn_triangles) - -#endif /* GL_ATI_pn_triangles */ - -/* ------------------------ GL_ATI_separate_stencil ------------------------ */ - -#ifndef GL_ATI_separate_stencil -#define GL_ATI_separate_stencil 1 - -#define GL_STENCIL_BACK_FUNC_ATI 0x8800 -#define GL_STENCIL_BACK_FAIL_ATI 0x8801 -#define GL_STENCIL_BACK_PASS_DEPTH_FAIL_ATI 0x8802 -#define GL_STENCIL_BACK_PASS_DEPTH_PASS_ATI 0x8803 - -typedef void (GLAPIENTRY * PFNGLSTENCILFUNCSEPARATEATIPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILOPSEPARATEATIPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); - -#define glStencilFuncSeparateATI GLEW_GET_FUN(__glewStencilFuncSeparateATI) -#define glStencilOpSeparateATI GLEW_GET_FUN(__glewStencilOpSeparateATI) - -#define GLEW_ATI_separate_stencil GLEW_GET_VAR(__GLEW_ATI_separate_stencil) - -#endif /* GL_ATI_separate_stencil */ - -/* ----------------------- GL_ATI_shader_texture_lod ----------------------- */ - -#ifndef GL_ATI_shader_texture_lod -#define GL_ATI_shader_texture_lod 1 - -#define GLEW_ATI_shader_texture_lod GLEW_GET_VAR(__GLEW_ATI_shader_texture_lod) - -#endif /* GL_ATI_shader_texture_lod */ - -/* ---------------------- GL_ATI_text_fragment_shader ---------------------- */ - -#ifndef GL_ATI_text_fragment_shader -#define GL_ATI_text_fragment_shader 1 - -#define GL_TEXT_FRAGMENT_SHADER_ATI 0x8200 - -#define GLEW_ATI_text_fragment_shader GLEW_GET_VAR(__GLEW_ATI_text_fragment_shader) - -#endif /* GL_ATI_text_fragment_shader */ - -/* --------------------- GL_ATI_texture_compression_3dc -------------------- */ - -#ifndef GL_ATI_texture_compression_3dc -#define GL_ATI_texture_compression_3dc 1 - -#define GL_COMPRESSED_LUMINANCE_ALPHA_3DC_ATI 0x8837 - -#define GLEW_ATI_texture_compression_3dc GLEW_GET_VAR(__GLEW_ATI_texture_compression_3dc) - -#endif /* GL_ATI_texture_compression_3dc */ - -/* ---------------------- GL_ATI_texture_env_combine3 ---------------------- */ - -#ifndef GL_ATI_texture_env_combine3 -#define GL_ATI_texture_env_combine3 1 - -#define GL_MODULATE_ADD_ATI 0x8744 -#define GL_MODULATE_SIGNED_ADD_ATI 0x8745 -#define GL_MODULATE_SUBTRACT_ATI 0x8746 - -#define GLEW_ATI_texture_env_combine3 GLEW_GET_VAR(__GLEW_ATI_texture_env_combine3) - -#endif /* GL_ATI_texture_env_combine3 */ - -/* -------------------------- GL_ATI_texture_float ------------------------- */ - -#ifndef GL_ATI_texture_float -#define GL_ATI_texture_float 1 - -#define GL_RGBA_FLOAT32_ATI 0x8814 -#define GL_RGB_FLOAT32_ATI 0x8815 -#define GL_ALPHA_FLOAT32_ATI 0x8816 -#define GL_INTENSITY_FLOAT32_ATI 0x8817 -#define GL_LUMINANCE_FLOAT32_ATI 0x8818 -#define GL_LUMINANCE_ALPHA_FLOAT32_ATI 0x8819 -#define GL_RGBA_FLOAT16_ATI 0x881A -#define GL_RGB_FLOAT16_ATI 0x881B -#define GL_ALPHA_FLOAT16_ATI 0x881C -#define GL_INTENSITY_FLOAT16_ATI 0x881D -#define GL_LUMINANCE_FLOAT16_ATI 0x881E -#define GL_LUMINANCE_ALPHA_FLOAT16_ATI 0x881F - -#define GLEW_ATI_texture_float GLEW_GET_VAR(__GLEW_ATI_texture_float) - -#endif /* GL_ATI_texture_float */ - -/* ----------------------- GL_ATI_texture_mirror_once ---------------------- */ - -#ifndef GL_ATI_texture_mirror_once -#define GL_ATI_texture_mirror_once 1 - -#define GL_MIRROR_CLAMP_ATI 0x8742 -#define GL_MIRROR_CLAMP_TO_EDGE_ATI 0x8743 - -#define GLEW_ATI_texture_mirror_once GLEW_GET_VAR(__GLEW_ATI_texture_mirror_once) - -#endif /* GL_ATI_texture_mirror_once */ - -/* ----------------------- GL_ATI_vertex_array_object ---------------------- */ - -#ifndef GL_ATI_vertex_array_object -#define GL_ATI_vertex_array_object 1 - -#define GL_STATIC_ATI 0x8760 -#define GL_DYNAMIC_ATI 0x8761 -#define GL_PRESERVE_ATI 0x8762 -#define GL_DISCARD_ATI 0x8763 -#define GL_OBJECT_BUFFER_SIZE_ATI 0x8764 -#define GL_OBJECT_BUFFER_USAGE_ATI 0x8765 -#define GL_ARRAY_OBJECT_BUFFER_ATI 0x8766 -#define GL_ARRAY_OBJECT_OFFSET_ATI 0x8767 - -typedef void (GLAPIENTRY * PFNGLARRAYOBJECTATIPROC) (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); -typedef void (GLAPIENTRY * PFNGLFREEOBJECTBUFFERATIPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLGETARRAYOBJECTFVATIPROC) (GLenum array, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETARRAYOBJECTIVATIPROC) (GLenum array, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETOBJECTBUFFERFVATIPROC) (GLuint buffer, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETOBJECTBUFFERIVATIPROC) (GLuint buffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVARIANTARRAYOBJECTFVATIPROC) (GLuint id, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVARIANTARRAYOBJECTIVATIPROC) (GLuint id, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISOBJECTBUFFERATIPROC) (GLuint buffer); -typedef GLuint (GLAPIENTRY * PFNGLNEWOBJECTBUFFERATIPROC) (GLsizei size, const void* pointer, GLenum usage); -typedef void (GLAPIENTRY * PFNGLUPDATEOBJECTBUFFERATIPROC) (GLuint buffer, GLuint offset, GLsizei size, const void* pointer, GLenum preserve); -typedef void (GLAPIENTRY * PFNGLVARIANTARRAYOBJECTATIPROC) (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); - -#define glArrayObjectATI GLEW_GET_FUN(__glewArrayObjectATI) -#define glFreeObjectBufferATI GLEW_GET_FUN(__glewFreeObjectBufferATI) -#define glGetArrayObjectfvATI GLEW_GET_FUN(__glewGetArrayObjectfvATI) -#define glGetArrayObjectivATI GLEW_GET_FUN(__glewGetArrayObjectivATI) -#define glGetObjectBufferfvATI GLEW_GET_FUN(__glewGetObjectBufferfvATI) -#define glGetObjectBufferivATI GLEW_GET_FUN(__glewGetObjectBufferivATI) -#define glGetVariantArrayObjectfvATI GLEW_GET_FUN(__glewGetVariantArrayObjectfvATI) -#define glGetVariantArrayObjectivATI GLEW_GET_FUN(__glewGetVariantArrayObjectivATI) -#define glIsObjectBufferATI GLEW_GET_FUN(__glewIsObjectBufferATI) -#define glNewObjectBufferATI GLEW_GET_FUN(__glewNewObjectBufferATI) -#define glUpdateObjectBufferATI GLEW_GET_FUN(__glewUpdateObjectBufferATI) -#define glVariantArrayObjectATI GLEW_GET_FUN(__glewVariantArrayObjectATI) - -#define GLEW_ATI_vertex_array_object GLEW_GET_VAR(__GLEW_ATI_vertex_array_object) - -#endif /* GL_ATI_vertex_array_object */ - -/* ------------------- GL_ATI_vertex_attrib_array_object ------------------- */ - -#ifndef GL_ATI_vertex_attrib_array_object -#define GL_ATI_vertex_attrib_array_object 1 - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC) (GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC) (GLuint index, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBARRAYOBJECTATIPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset); - -#define glGetVertexAttribArrayObjectfvATI GLEW_GET_FUN(__glewGetVertexAttribArrayObjectfvATI) -#define glGetVertexAttribArrayObjectivATI GLEW_GET_FUN(__glewGetVertexAttribArrayObjectivATI) -#define glVertexAttribArrayObjectATI GLEW_GET_FUN(__glewVertexAttribArrayObjectATI) - -#define GLEW_ATI_vertex_attrib_array_object GLEW_GET_VAR(__GLEW_ATI_vertex_attrib_array_object) - -#endif /* GL_ATI_vertex_attrib_array_object */ - -/* ------------------------- GL_ATI_vertex_streams ------------------------- */ - -#ifndef GL_ATI_vertex_streams -#define GL_ATI_vertex_streams 1 - -#define GL_MAX_VERTEX_STREAMS_ATI 0x876B -#define GL_VERTEX_SOURCE_ATI 0x876C -#define GL_VERTEX_STREAM0_ATI 0x876D -#define GL_VERTEX_STREAM1_ATI 0x876E -#define GL_VERTEX_STREAM2_ATI 0x876F -#define GL_VERTEX_STREAM3_ATI 0x8770 -#define GL_VERTEX_STREAM4_ATI 0x8771 -#define GL_VERTEX_STREAM5_ATI 0x8772 -#define GL_VERTEX_STREAM6_ATI 0x8773 -#define GL_VERTEX_STREAM7_ATI 0x8774 - -typedef void (GLAPIENTRY * PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC) (GLenum stream); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3BATIPROC) (GLenum stream, GLbyte x, GLbyte y, GLbyte z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3BVATIPROC) (GLenum stream, const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3DVATIPROC) (GLenum stream, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3FVATIPROC) (GLenum stream, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3IVATIPROC) (GLenum stream, const GLint *v); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3SVATIPROC) (GLenum stream, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXBLENDENVFATIPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLVERTEXBLENDENVIATIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2DATIPROC) (GLenum stream, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2DVATIPROC) (GLenum stream, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2FATIPROC) (GLenum stream, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2FVATIPROC) (GLenum stream, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2IATIPROC) (GLenum stream, GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2IVATIPROC) (GLenum stream, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2SATIPROC) (GLenum stream, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2SVATIPROC) (GLenum stream, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3DVATIPROC) (GLenum stream, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3FVATIPROC) (GLenum stream, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3IVATIPROC) (GLenum stream, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3SVATIPROC) (GLenum stream, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4DVATIPROC) (GLenum stream, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4FVATIPROC) (GLenum stream, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4IATIPROC) (GLenum stream, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4IVATIPROC) (GLenum stream, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4SVATIPROC) (GLenum stream, const GLshort *v); - -#define glClientActiveVertexStreamATI GLEW_GET_FUN(__glewClientActiveVertexStreamATI) -#define glNormalStream3bATI GLEW_GET_FUN(__glewNormalStream3bATI) -#define glNormalStream3bvATI GLEW_GET_FUN(__glewNormalStream3bvATI) -#define glNormalStream3dATI GLEW_GET_FUN(__glewNormalStream3dATI) -#define glNormalStream3dvATI GLEW_GET_FUN(__glewNormalStream3dvATI) -#define glNormalStream3fATI GLEW_GET_FUN(__glewNormalStream3fATI) -#define glNormalStream3fvATI GLEW_GET_FUN(__glewNormalStream3fvATI) -#define glNormalStream3iATI GLEW_GET_FUN(__glewNormalStream3iATI) -#define glNormalStream3ivATI GLEW_GET_FUN(__glewNormalStream3ivATI) -#define glNormalStream3sATI GLEW_GET_FUN(__glewNormalStream3sATI) -#define glNormalStream3svATI GLEW_GET_FUN(__glewNormalStream3svATI) -#define glVertexBlendEnvfATI GLEW_GET_FUN(__glewVertexBlendEnvfATI) -#define glVertexBlendEnviATI GLEW_GET_FUN(__glewVertexBlendEnviATI) -#define glVertexStream2dATI GLEW_GET_FUN(__glewVertexStream2dATI) -#define glVertexStream2dvATI GLEW_GET_FUN(__glewVertexStream2dvATI) -#define glVertexStream2fATI GLEW_GET_FUN(__glewVertexStream2fATI) -#define glVertexStream2fvATI GLEW_GET_FUN(__glewVertexStream2fvATI) -#define glVertexStream2iATI GLEW_GET_FUN(__glewVertexStream2iATI) -#define glVertexStream2ivATI GLEW_GET_FUN(__glewVertexStream2ivATI) -#define glVertexStream2sATI GLEW_GET_FUN(__glewVertexStream2sATI) -#define glVertexStream2svATI GLEW_GET_FUN(__glewVertexStream2svATI) -#define glVertexStream3dATI GLEW_GET_FUN(__glewVertexStream3dATI) -#define glVertexStream3dvATI GLEW_GET_FUN(__glewVertexStream3dvATI) -#define glVertexStream3fATI GLEW_GET_FUN(__glewVertexStream3fATI) -#define glVertexStream3fvATI GLEW_GET_FUN(__glewVertexStream3fvATI) -#define glVertexStream3iATI GLEW_GET_FUN(__glewVertexStream3iATI) -#define glVertexStream3ivATI GLEW_GET_FUN(__glewVertexStream3ivATI) -#define glVertexStream3sATI GLEW_GET_FUN(__glewVertexStream3sATI) -#define glVertexStream3svATI GLEW_GET_FUN(__glewVertexStream3svATI) -#define glVertexStream4dATI GLEW_GET_FUN(__glewVertexStream4dATI) -#define glVertexStream4dvATI GLEW_GET_FUN(__glewVertexStream4dvATI) -#define glVertexStream4fATI GLEW_GET_FUN(__glewVertexStream4fATI) -#define glVertexStream4fvATI GLEW_GET_FUN(__glewVertexStream4fvATI) -#define glVertexStream4iATI GLEW_GET_FUN(__glewVertexStream4iATI) -#define glVertexStream4ivATI GLEW_GET_FUN(__glewVertexStream4ivATI) -#define glVertexStream4sATI GLEW_GET_FUN(__glewVertexStream4sATI) -#define glVertexStream4svATI GLEW_GET_FUN(__glewVertexStream4svATI) - -#define GLEW_ATI_vertex_streams GLEW_GET_VAR(__GLEW_ATI_vertex_streams) - -#endif /* GL_ATI_vertex_streams */ - -/* --------------------------- GL_EXT_422_pixels --------------------------- */ - -#ifndef GL_EXT_422_pixels -#define GL_EXT_422_pixels 1 - -#define GL_422_EXT 0x80CC -#define GL_422_REV_EXT 0x80CD -#define GL_422_AVERAGE_EXT 0x80CE -#define GL_422_REV_AVERAGE_EXT 0x80CF - -#define GLEW_EXT_422_pixels GLEW_GET_VAR(__GLEW_EXT_422_pixels) - -#endif /* GL_EXT_422_pixels */ - -/* ---------------------------- GL_EXT_Cg_shader --------------------------- */ - -#ifndef GL_EXT_Cg_shader -#define GL_EXT_Cg_shader 1 - -#define GL_CG_VERTEX_SHADER_EXT 0x890E -#define GL_CG_FRAGMENT_SHADER_EXT 0x890F - -#define GLEW_EXT_Cg_shader GLEW_GET_VAR(__GLEW_EXT_Cg_shader) - -#endif /* GL_EXT_Cg_shader */ - -/* ------------------------------ GL_EXT_abgr ------------------------------ */ - -#ifndef GL_EXT_abgr -#define GL_EXT_abgr 1 - -#define GL_ABGR_EXT 0x8000 - -#define GLEW_EXT_abgr GLEW_GET_VAR(__GLEW_EXT_abgr) - -#endif /* GL_EXT_abgr */ - -/* ------------------------------ GL_EXT_bgra ------------------------------ */ - -#ifndef GL_EXT_bgra -#define GL_EXT_bgra 1 - -#define GL_BGR_EXT 0x80E0 -#define GL_BGRA_EXT 0x80E1 - -#define GLEW_EXT_bgra GLEW_GET_VAR(__GLEW_EXT_bgra) - -#endif /* GL_EXT_bgra */ - -/* ------------------------ GL_EXT_bindable_uniform ------------------------ */ - -#ifndef GL_EXT_bindable_uniform -#define GL_EXT_bindable_uniform 1 - -#define GL_MAX_VERTEX_BINDABLE_UNIFORMS_EXT 0x8DE2 -#define GL_MAX_FRAGMENT_BINDABLE_UNIFORMS_EXT 0x8DE3 -#define GL_MAX_GEOMETRY_BINDABLE_UNIFORMS_EXT 0x8DE4 -#define GL_MAX_BINDABLE_UNIFORM_SIZE_EXT 0x8DED -#define GL_UNIFORM_BUFFER_EXT 0x8DEE -#define GL_UNIFORM_BUFFER_BINDING_EXT 0x8DEF - -typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMBUFFERSIZEEXTPROC) (GLuint program, GLint location); -typedef GLintptr (GLAPIENTRY * PFNGLGETUNIFORMOFFSETEXTPROC) (GLuint program, GLint location); -typedef void (GLAPIENTRY * PFNGLUNIFORMBUFFEREXTPROC) (GLuint program, GLint location, GLuint buffer); - -#define glGetUniformBufferSizeEXT GLEW_GET_FUN(__glewGetUniformBufferSizeEXT) -#define glGetUniformOffsetEXT GLEW_GET_FUN(__glewGetUniformOffsetEXT) -#define glUniformBufferEXT GLEW_GET_FUN(__glewUniformBufferEXT) - -#define GLEW_EXT_bindable_uniform GLEW_GET_VAR(__GLEW_EXT_bindable_uniform) - -#endif /* GL_EXT_bindable_uniform */ - -/* --------------------------- GL_EXT_blend_color -------------------------- */ - -#ifndef GL_EXT_blend_color -#define GL_EXT_blend_color 1 - -#define GL_CONSTANT_COLOR_EXT 0x8001 -#define GL_ONE_MINUS_CONSTANT_COLOR_EXT 0x8002 -#define GL_CONSTANT_ALPHA_EXT 0x8003 -#define GL_ONE_MINUS_CONSTANT_ALPHA_EXT 0x8004 -#define GL_BLEND_COLOR_EXT 0x8005 - -typedef void (GLAPIENTRY * PFNGLBLENDCOLOREXTPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); - -#define glBlendColorEXT GLEW_GET_FUN(__glewBlendColorEXT) - -#define GLEW_EXT_blend_color GLEW_GET_VAR(__GLEW_EXT_blend_color) - -#endif /* GL_EXT_blend_color */ - -/* --------------------- GL_EXT_blend_equation_separate -------------------- */ - -#ifndef GL_EXT_blend_equation_separate -#define GL_EXT_blend_equation_separate 1 - -#define GL_BLEND_EQUATION_RGB_EXT 0x8009 -#define GL_BLEND_EQUATION_ALPHA_EXT 0x883D - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEEXTPROC) (GLenum modeRGB, GLenum modeAlpha); - -#define glBlendEquationSeparateEXT GLEW_GET_FUN(__glewBlendEquationSeparateEXT) - -#define GLEW_EXT_blend_equation_separate GLEW_GET_VAR(__GLEW_EXT_blend_equation_separate) - -#endif /* GL_EXT_blend_equation_separate */ - -/* ----------------------- GL_EXT_blend_func_separate ---------------------- */ - -#ifndef GL_EXT_blend_func_separate -#define GL_EXT_blend_func_separate 1 - -#define GL_BLEND_DST_RGB_EXT 0x80C8 -#define GL_BLEND_SRC_RGB_EXT 0x80C9 -#define GL_BLEND_DST_ALPHA_EXT 0x80CA -#define GL_BLEND_SRC_ALPHA_EXT 0x80CB - -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEEXTPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); - -#define glBlendFuncSeparateEXT GLEW_GET_FUN(__glewBlendFuncSeparateEXT) - -#define GLEW_EXT_blend_func_separate GLEW_GET_VAR(__GLEW_EXT_blend_func_separate) - -#endif /* GL_EXT_blend_func_separate */ - -/* ------------------------- GL_EXT_blend_logic_op ------------------------- */ - -#ifndef GL_EXT_blend_logic_op -#define GL_EXT_blend_logic_op 1 - -#define GLEW_EXT_blend_logic_op GLEW_GET_VAR(__GLEW_EXT_blend_logic_op) - -#endif /* GL_EXT_blend_logic_op */ - -/* -------------------------- GL_EXT_blend_minmax -------------------------- */ - -#ifndef GL_EXT_blend_minmax -#define GL_EXT_blend_minmax 1 - -#define GL_FUNC_ADD_EXT 0x8006 -#define GL_MIN_EXT 0x8007 -#define GL_MAX_EXT 0x8008 -#define GL_BLEND_EQUATION_EXT 0x8009 - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONEXTPROC) (GLenum mode); - -#define glBlendEquationEXT GLEW_GET_FUN(__glewBlendEquationEXT) - -#define GLEW_EXT_blend_minmax GLEW_GET_VAR(__GLEW_EXT_blend_minmax) - -#endif /* GL_EXT_blend_minmax */ - -/* ------------------------- GL_EXT_blend_subtract ------------------------- */ - -#ifndef GL_EXT_blend_subtract -#define GL_EXT_blend_subtract 1 - -#define GL_FUNC_SUBTRACT_EXT 0x800A -#define GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B - -#define GLEW_EXT_blend_subtract GLEW_GET_VAR(__GLEW_EXT_blend_subtract) - -#endif /* GL_EXT_blend_subtract */ - -/* ------------------------ GL_EXT_clip_volume_hint ------------------------ */ - -#ifndef GL_EXT_clip_volume_hint -#define GL_EXT_clip_volume_hint 1 - -#define GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 - -#define GLEW_EXT_clip_volume_hint GLEW_GET_VAR(__GLEW_EXT_clip_volume_hint) - -#endif /* GL_EXT_clip_volume_hint */ - -/* ------------------------------ GL_EXT_cmyka ----------------------------- */ - -#ifndef GL_EXT_cmyka -#define GL_EXT_cmyka 1 - -#define GL_CMYK_EXT 0x800C -#define GL_CMYKA_EXT 0x800D -#define GL_PACK_CMYK_HINT_EXT 0x800E -#define GL_UNPACK_CMYK_HINT_EXT 0x800F - -#define GLEW_EXT_cmyka GLEW_GET_VAR(__GLEW_EXT_cmyka) - -#endif /* GL_EXT_cmyka */ - -/* ------------------------- GL_EXT_color_subtable ------------------------- */ - -#ifndef GL_EXT_color_subtable -#define GL_EXT_color_subtable 1 - -typedef void (GLAPIENTRY * PFNGLCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void* data); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); - -#define glColorSubTableEXT GLEW_GET_FUN(__glewColorSubTableEXT) -#define glCopyColorSubTableEXT GLEW_GET_FUN(__glewCopyColorSubTableEXT) - -#define GLEW_EXT_color_subtable GLEW_GET_VAR(__GLEW_EXT_color_subtable) - -#endif /* GL_EXT_color_subtable */ - -/* ---------------------- GL_EXT_compiled_vertex_array --------------------- */ - -#ifndef GL_EXT_compiled_vertex_array -#define GL_EXT_compiled_vertex_array 1 - -#define GL_ARRAY_ELEMENT_LOCK_FIRST_EXT 0x81A8 -#define GL_ARRAY_ELEMENT_LOCK_COUNT_EXT 0x81A9 - -typedef void (GLAPIENTRY * PFNGLLOCKARRAYSEXTPROC) (GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLUNLOCKARRAYSEXTPROC) (void); - -#define glLockArraysEXT GLEW_GET_FUN(__glewLockArraysEXT) -#define glUnlockArraysEXT GLEW_GET_FUN(__glewUnlockArraysEXT) - -#define GLEW_EXT_compiled_vertex_array GLEW_GET_VAR(__GLEW_EXT_compiled_vertex_array) - -#endif /* GL_EXT_compiled_vertex_array */ - -/* --------------------------- GL_EXT_convolution -------------------------- */ - -#ifndef GL_EXT_convolution -#define GL_EXT_convolution 1 - -#define GL_CONVOLUTION_1D_EXT 0x8010 -#define GL_CONVOLUTION_2D_EXT 0x8011 -#define GL_SEPARABLE_2D_EXT 0x8012 -#define GL_CONVOLUTION_BORDER_MODE_EXT 0x8013 -#define GL_CONVOLUTION_FILTER_SCALE_EXT 0x8014 -#define GL_CONVOLUTION_FILTER_BIAS_EXT 0x8015 -#define GL_REDUCE_EXT 0x8016 -#define GL_CONVOLUTION_FORMAT_EXT 0x8017 -#define GL_CONVOLUTION_WIDTH_EXT 0x8018 -#define GL_CONVOLUTION_HEIGHT_EXT 0x8019 -#define GL_MAX_CONVOLUTION_WIDTH_EXT 0x801A -#define GL_MAX_CONVOLUTION_HEIGHT_EXT 0x801B -#define GL_POST_CONVOLUTION_RED_SCALE_EXT 0x801C -#define GL_POST_CONVOLUTION_GREEN_SCALE_EXT 0x801D -#define GL_POST_CONVOLUTION_BLUE_SCALE_EXT 0x801E -#define GL_POST_CONVOLUTION_ALPHA_SCALE_EXT 0x801F -#define GL_POST_CONVOLUTION_RED_BIAS_EXT 0x8020 -#define GL_POST_CONVOLUTION_GREEN_BIAS_EXT 0x8021 -#define GL_POST_CONVOLUTION_BLUE_BIAS_EXT 0x8022 -#define GL_POST_CONVOLUTION_ALPHA_BIAS_EXT 0x8023 - -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void* image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, void* image); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETSEPARABLEFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, void* row, void* column, void* span); -typedef void (GLAPIENTRY * PFNGLSEPARABLEFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* row, const void* column); - -#define glConvolutionFilter1DEXT GLEW_GET_FUN(__glewConvolutionFilter1DEXT) -#define glConvolutionFilter2DEXT GLEW_GET_FUN(__glewConvolutionFilter2DEXT) -#define glConvolutionParameterfEXT GLEW_GET_FUN(__glewConvolutionParameterfEXT) -#define glConvolutionParameterfvEXT GLEW_GET_FUN(__glewConvolutionParameterfvEXT) -#define glConvolutionParameteriEXT GLEW_GET_FUN(__glewConvolutionParameteriEXT) -#define glConvolutionParameterivEXT GLEW_GET_FUN(__glewConvolutionParameterivEXT) -#define glCopyConvolutionFilter1DEXT GLEW_GET_FUN(__glewCopyConvolutionFilter1DEXT) -#define glCopyConvolutionFilter2DEXT GLEW_GET_FUN(__glewCopyConvolutionFilter2DEXT) -#define glGetConvolutionFilterEXT GLEW_GET_FUN(__glewGetConvolutionFilterEXT) -#define glGetConvolutionParameterfvEXT GLEW_GET_FUN(__glewGetConvolutionParameterfvEXT) -#define glGetConvolutionParameterivEXT GLEW_GET_FUN(__glewGetConvolutionParameterivEXT) -#define glGetSeparableFilterEXT GLEW_GET_FUN(__glewGetSeparableFilterEXT) -#define glSeparableFilter2DEXT GLEW_GET_FUN(__glewSeparableFilter2DEXT) - -#define GLEW_EXT_convolution GLEW_GET_VAR(__GLEW_EXT_convolution) - -#endif /* GL_EXT_convolution */ - -/* ------------------------ GL_EXT_coordinate_frame ------------------------ */ - -#ifndef GL_EXT_coordinate_frame -#define GL_EXT_coordinate_frame 1 - -#define GL_TANGENT_ARRAY_EXT 0x8439 -#define GL_BINORMAL_ARRAY_EXT 0x843A -#define GL_CURRENT_TANGENT_EXT 0x843B -#define GL_CURRENT_BINORMAL_EXT 0x843C -#define GL_TANGENT_ARRAY_TYPE_EXT 0x843E -#define GL_TANGENT_ARRAY_STRIDE_EXT 0x843F -#define GL_BINORMAL_ARRAY_TYPE_EXT 0x8440 -#define GL_BINORMAL_ARRAY_STRIDE_EXT 0x8441 -#define GL_TANGENT_ARRAY_POINTER_EXT 0x8442 -#define GL_BINORMAL_ARRAY_POINTER_EXT 0x8443 -#define GL_MAP1_TANGENT_EXT 0x8444 -#define GL_MAP2_TANGENT_EXT 0x8445 -#define GL_MAP1_BINORMAL_EXT 0x8446 -#define GL_MAP2_BINORMAL_EXT 0x8447 - -typedef void (GLAPIENTRY * PFNGLBINORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, void* pointer); -typedef void (GLAPIENTRY * PFNGLTANGENTPOINTEREXTPROC) (GLenum type, GLsizei stride, void* pointer); - -#define glBinormalPointerEXT GLEW_GET_FUN(__glewBinormalPointerEXT) -#define glTangentPointerEXT GLEW_GET_FUN(__glewTangentPointerEXT) - -#define GLEW_EXT_coordinate_frame GLEW_GET_VAR(__GLEW_EXT_coordinate_frame) - -#endif /* GL_EXT_coordinate_frame */ - -/* -------------------------- GL_EXT_copy_texture -------------------------- */ - -#ifndef GL_EXT_copy_texture -#define GL_EXT_copy_texture 1 - -typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE1DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE2DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); - -#define glCopyTexImage1DEXT GLEW_GET_FUN(__glewCopyTexImage1DEXT) -#define glCopyTexImage2DEXT GLEW_GET_FUN(__glewCopyTexImage2DEXT) -#define glCopyTexSubImage1DEXT GLEW_GET_FUN(__glewCopyTexSubImage1DEXT) -#define glCopyTexSubImage2DEXT GLEW_GET_FUN(__glewCopyTexSubImage2DEXT) -#define glCopyTexSubImage3DEXT GLEW_GET_FUN(__glewCopyTexSubImage3DEXT) - -#define GLEW_EXT_copy_texture GLEW_GET_VAR(__GLEW_EXT_copy_texture) - -#endif /* GL_EXT_copy_texture */ - -/* --------------------------- GL_EXT_cull_vertex -------------------------- */ - -#ifndef GL_EXT_cull_vertex -#define GL_EXT_cull_vertex 1 - -#define GL_CULL_VERTEX_EXT 0x81AA -#define GL_CULL_VERTEX_EYE_POSITION_EXT 0x81AB -#define GL_CULL_VERTEX_OBJECT_POSITION_EXT 0x81AC - -typedef void (GLAPIENTRY * PFNGLCULLPARAMETERDVEXTPROC) (GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLCULLPARAMETERFVEXTPROC) (GLenum pname, GLfloat* params); - -#define glCullParameterdvEXT GLEW_GET_FUN(__glewCullParameterdvEXT) -#define glCullParameterfvEXT GLEW_GET_FUN(__glewCullParameterfvEXT) - -#define GLEW_EXT_cull_vertex GLEW_GET_VAR(__GLEW_EXT_cull_vertex) - -#endif /* GL_EXT_cull_vertex */ - -/* ------------------------ GL_EXT_depth_bounds_test ----------------------- */ - -#ifndef GL_EXT_depth_bounds_test -#define GL_EXT_depth_bounds_test 1 - -#define GL_DEPTH_BOUNDS_TEST_EXT 0x8890 -#define GL_DEPTH_BOUNDS_EXT 0x8891 - -typedef void (GLAPIENTRY * PFNGLDEPTHBOUNDSEXTPROC) (GLclampd zmin, GLclampd zmax); - -#define glDepthBoundsEXT GLEW_GET_FUN(__glewDepthBoundsEXT) - -#define GLEW_EXT_depth_bounds_test GLEW_GET_VAR(__GLEW_EXT_depth_bounds_test) - -#endif /* GL_EXT_depth_bounds_test */ - -/* ----------------------- GL_EXT_direct_state_access ---------------------- */ - -#ifndef GL_EXT_direct_state_access -#define GL_EXT_direct_state_access 1 - -#define GL_PROGRAM_MATRIX_EXT 0x8E2D -#define GL_TRANSPOSE_PROGRAM_MATRIX_EXT 0x8E2E -#define GL_PROGRAM_MATRIX_STACK_DEPTH_EXT 0x8E2F - -typedef void (GLAPIENTRY * PFNGLBINDMULTITEXTUREEXTPROC) (GLenum texunit, GLenum target, GLuint texture); -typedef GLenum (GLAPIENTRY * PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC) (GLuint framebuffer, GLenum target); -typedef void (GLAPIENTRY * PFNGLCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void* data); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); -typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); -typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC) (GLuint framebuffer, GLsizei n, const GLenum* bufs); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERREADBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); -typedef void (GLAPIENTRY * PFNGLGENERATEMULTITEXMIPMAPEXTPROC) (GLenum texunit, GLenum target); -typedef void (GLAPIENTRY * PFNGLGENERATETEXTUREMIPMAPEXTPROC) (GLuint texture, GLenum target); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, void* img); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, void* img); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEINDEXEDVEXTPROC) (GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEI_VEXTPROC) (GLenum pname, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETFLOATINDEXEDVEXTPROC) (GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFLOATI_VEXTPROC) (GLenum pname, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum format, GLenum type, void* pixels); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC) (GLuint buffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPOINTERVEXTPROC) (GLuint buffer, GLenum pname, void** params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, void* data); -typedef void (GLAPIENTRY * PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum pname, void* string); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMIVEXTPROC) (GLuint program, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC) (GLuint renderbuffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETPOINTERINDEXEDVEXTPROC) (GLenum target, GLuint index, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETPOINTERI_VEXTPROC) (GLenum pname, GLuint index, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, void* pixels); -typedef void (GLAPIENTRY * PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYINTEGERVEXTPROC) (GLuint vaobj, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLvoid** param); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYPOINTERVEXTPROC) (GLuint vaobj, GLenum pname, GLvoid** param); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPNAMEDBUFFEREXTPROC) (GLuint buffer, GLenum access); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length, GLbitfield access); -typedef void (GLAPIENTRY * PFNGLMATRIXFRUSTUMEXTPROC) (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADIDENTITYEXTPROC) (GLenum matrixMode); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADTRANSPOSEDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADTRANSPOSEFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTTRANSPOSEDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTTRANSPOSEFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXORTHOEXTPROC) (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f); -typedef void (GLAPIENTRY * PFNGLMATRIXPOPEXTPROC) (GLenum matrixMode); -typedef void (GLAPIENTRY * PFNGLMATRIXPUSHEXTPROC) (GLenum matrixMode); -typedef void (GLAPIENTRY * PFNGLMATRIXROTATEDEXTPROC) (GLenum matrixMode, GLdouble angle, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLMATRIXROTATEFEXTPROC) (GLenum matrixMode, GLfloat angle, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLMATRIXSCALEDEXTPROC) (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLMATRIXSCALEFEXTPROC) (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLMATRIXTRANSLATEDEXTPROC) (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLMATRIXTRANSLATEFEXTPROC) (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLMULTITEXBUFFEREXTPROC) (GLenum texunit, GLenum target, GLenum internalformat, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDPOINTEREXTPROC) (GLenum texunit, GLint size, GLenum type, GLsizei stride, const void* pointer); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENDEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble param); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENFEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENIEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat* param); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* param); -typedef void (GLAPIENTRY * PFNGLMULTITEXRENDERBUFFEREXTPROC) (GLenum texunit, GLenum target, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERDATAEXTPROC) (GLuint buffer, GLsizeiptr size, const void* data, GLenum usage); -typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, const void* data); -typedef void (GLAPIENTRY * PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC) (GLuint readBuffer, GLuint writeBuffer, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC) (GLuint framebuffer, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLenum face); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLint layer); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC) (GLuint program, GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum format, GLsizei len, const void* string); -typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC) (GLuint renderbuffer, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC) (GLuint renderbuffer, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLuint renderbuffer, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FEXTPROC) (GLuint program, GLint location, GLfloat v0); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IEXTPROC) (GLuint program, GLint location, GLint v0); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIEXTPROC) (GLuint program, GLint location, GLuint v0); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLTEXTUREBUFFEREXTPROC) (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERFEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLfloat* param); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint* param); -typedef void (GLAPIENTRY * PFNGLTEXTURERENDERBUFFEREXTPROC) (GLuint texture, GLenum target, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels); -typedef GLboolean (GLAPIENTRY * PFNGLUNMAPNAMEDBUFFEREXTPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYINDEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum texunit, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYNORMALOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); - -#define glBindMultiTextureEXT GLEW_GET_FUN(__glewBindMultiTextureEXT) -#define glCheckNamedFramebufferStatusEXT GLEW_GET_FUN(__glewCheckNamedFramebufferStatusEXT) -#define glClientAttribDefaultEXT GLEW_GET_FUN(__glewClientAttribDefaultEXT) -#define glCompressedMultiTexImage1DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage1DEXT) -#define glCompressedMultiTexImage2DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage2DEXT) -#define glCompressedMultiTexImage3DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage3DEXT) -#define glCompressedMultiTexSubImage1DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage1DEXT) -#define glCompressedMultiTexSubImage2DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage2DEXT) -#define glCompressedMultiTexSubImage3DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage3DEXT) -#define glCompressedTextureImage1DEXT GLEW_GET_FUN(__glewCompressedTextureImage1DEXT) -#define glCompressedTextureImage2DEXT GLEW_GET_FUN(__glewCompressedTextureImage2DEXT) -#define glCompressedTextureImage3DEXT GLEW_GET_FUN(__glewCompressedTextureImage3DEXT) -#define glCompressedTextureSubImage1DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage1DEXT) -#define glCompressedTextureSubImage2DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage2DEXT) -#define glCompressedTextureSubImage3DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage3DEXT) -#define glCopyMultiTexImage1DEXT GLEW_GET_FUN(__glewCopyMultiTexImage1DEXT) -#define glCopyMultiTexImage2DEXT GLEW_GET_FUN(__glewCopyMultiTexImage2DEXT) -#define glCopyMultiTexSubImage1DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage1DEXT) -#define glCopyMultiTexSubImage2DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage2DEXT) -#define glCopyMultiTexSubImage3DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage3DEXT) -#define glCopyTextureImage1DEXT GLEW_GET_FUN(__glewCopyTextureImage1DEXT) -#define glCopyTextureImage2DEXT GLEW_GET_FUN(__glewCopyTextureImage2DEXT) -#define glCopyTextureSubImage1DEXT GLEW_GET_FUN(__glewCopyTextureSubImage1DEXT) -#define glCopyTextureSubImage2DEXT GLEW_GET_FUN(__glewCopyTextureSubImage2DEXT) -#define glCopyTextureSubImage3DEXT GLEW_GET_FUN(__glewCopyTextureSubImage3DEXT) -#define glDisableClientStateIndexedEXT GLEW_GET_FUN(__glewDisableClientStateIndexedEXT) -#define glDisableClientStateiEXT GLEW_GET_FUN(__glewDisableClientStateiEXT) -#define glDisableVertexArrayAttribEXT GLEW_GET_FUN(__glewDisableVertexArrayAttribEXT) -#define glDisableVertexArrayEXT GLEW_GET_FUN(__glewDisableVertexArrayEXT) -#define glEnableClientStateIndexedEXT GLEW_GET_FUN(__glewEnableClientStateIndexedEXT) -#define glEnableClientStateiEXT GLEW_GET_FUN(__glewEnableClientStateiEXT) -#define glEnableVertexArrayAttribEXT GLEW_GET_FUN(__glewEnableVertexArrayAttribEXT) -#define glEnableVertexArrayEXT GLEW_GET_FUN(__glewEnableVertexArrayEXT) -#define glFlushMappedNamedBufferRangeEXT GLEW_GET_FUN(__glewFlushMappedNamedBufferRangeEXT) -#define glFramebufferDrawBufferEXT GLEW_GET_FUN(__glewFramebufferDrawBufferEXT) -#define glFramebufferDrawBuffersEXT GLEW_GET_FUN(__glewFramebufferDrawBuffersEXT) -#define glFramebufferReadBufferEXT GLEW_GET_FUN(__glewFramebufferReadBufferEXT) -#define glGenerateMultiTexMipmapEXT GLEW_GET_FUN(__glewGenerateMultiTexMipmapEXT) -#define glGenerateTextureMipmapEXT GLEW_GET_FUN(__glewGenerateTextureMipmapEXT) -#define glGetCompressedMultiTexImageEXT GLEW_GET_FUN(__glewGetCompressedMultiTexImageEXT) -#define glGetCompressedTextureImageEXT GLEW_GET_FUN(__glewGetCompressedTextureImageEXT) -#define glGetDoubleIndexedvEXT GLEW_GET_FUN(__glewGetDoubleIndexedvEXT) -#define glGetDoublei_vEXT GLEW_GET_FUN(__glewGetDoublei_vEXT) -#define glGetFloatIndexedvEXT GLEW_GET_FUN(__glewGetFloatIndexedvEXT) -#define glGetFloati_vEXT GLEW_GET_FUN(__glewGetFloati_vEXT) -#define glGetFramebufferParameterivEXT GLEW_GET_FUN(__glewGetFramebufferParameterivEXT) -#define glGetMultiTexEnvfvEXT GLEW_GET_FUN(__glewGetMultiTexEnvfvEXT) -#define glGetMultiTexEnvivEXT GLEW_GET_FUN(__glewGetMultiTexEnvivEXT) -#define glGetMultiTexGendvEXT GLEW_GET_FUN(__glewGetMultiTexGendvEXT) -#define glGetMultiTexGenfvEXT GLEW_GET_FUN(__glewGetMultiTexGenfvEXT) -#define glGetMultiTexGenivEXT GLEW_GET_FUN(__glewGetMultiTexGenivEXT) -#define glGetMultiTexImageEXT GLEW_GET_FUN(__glewGetMultiTexImageEXT) -#define glGetMultiTexLevelParameterfvEXT GLEW_GET_FUN(__glewGetMultiTexLevelParameterfvEXT) -#define glGetMultiTexLevelParameterivEXT GLEW_GET_FUN(__glewGetMultiTexLevelParameterivEXT) -#define glGetMultiTexParameterIivEXT GLEW_GET_FUN(__glewGetMultiTexParameterIivEXT) -#define glGetMultiTexParameterIuivEXT GLEW_GET_FUN(__glewGetMultiTexParameterIuivEXT) -#define glGetMultiTexParameterfvEXT GLEW_GET_FUN(__glewGetMultiTexParameterfvEXT) -#define glGetMultiTexParameterivEXT GLEW_GET_FUN(__glewGetMultiTexParameterivEXT) -#define glGetNamedBufferParameterivEXT GLEW_GET_FUN(__glewGetNamedBufferParameterivEXT) -#define glGetNamedBufferPointervEXT GLEW_GET_FUN(__glewGetNamedBufferPointervEXT) -#define glGetNamedBufferSubDataEXT GLEW_GET_FUN(__glewGetNamedBufferSubDataEXT) -#define glGetNamedFramebufferAttachmentParameterivEXT GLEW_GET_FUN(__glewGetNamedFramebufferAttachmentParameterivEXT) -#define glGetNamedProgramLocalParameterIivEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterIivEXT) -#define glGetNamedProgramLocalParameterIuivEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterIuivEXT) -#define glGetNamedProgramLocalParameterdvEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterdvEXT) -#define glGetNamedProgramLocalParameterfvEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterfvEXT) -#define glGetNamedProgramStringEXT GLEW_GET_FUN(__glewGetNamedProgramStringEXT) -#define glGetNamedProgramivEXT GLEW_GET_FUN(__glewGetNamedProgramivEXT) -#define glGetNamedRenderbufferParameterivEXT GLEW_GET_FUN(__glewGetNamedRenderbufferParameterivEXT) -#define glGetPointerIndexedvEXT GLEW_GET_FUN(__glewGetPointerIndexedvEXT) -#define glGetPointeri_vEXT GLEW_GET_FUN(__glewGetPointeri_vEXT) -#define glGetTextureImageEXT GLEW_GET_FUN(__glewGetTextureImageEXT) -#define glGetTextureLevelParameterfvEXT GLEW_GET_FUN(__glewGetTextureLevelParameterfvEXT) -#define glGetTextureLevelParameterivEXT GLEW_GET_FUN(__glewGetTextureLevelParameterivEXT) -#define glGetTextureParameterIivEXT GLEW_GET_FUN(__glewGetTextureParameterIivEXT) -#define glGetTextureParameterIuivEXT GLEW_GET_FUN(__glewGetTextureParameterIuivEXT) -#define glGetTextureParameterfvEXT GLEW_GET_FUN(__glewGetTextureParameterfvEXT) -#define glGetTextureParameterivEXT GLEW_GET_FUN(__glewGetTextureParameterivEXT) -#define glGetVertexArrayIntegeri_vEXT GLEW_GET_FUN(__glewGetVertexArrayIntegeri_vEXT) -#define glGetVertexArrayIntegervEXT GLEW_GET_FUN(__glewGetVertexArrayIntegervEXT) -#define glGetVertexArrayPointeri_vEXT GLEW_GET_FUN(__glewGetVertexArrayPointeri_vEXT) -#define glGetVertexArrayPointervEXT GLEW_GET_FUN(__glewGetVertexArrayPointervEXT) -#define glMapNamedBufferEXT GLEW_GET_FUN(__glewMapNamedBufferEXT) -#define glMapNamedBufferRangeEXT GLEW_GET_FUN(__glewMapNamedBufferRangeEXT) -#define glMatrixFrustumEXT GLEW_GET_FUN(__glewMatrixFrustumEXT) -#define glMatrixLoadIdentityEXT GLEW_GET_FUN(__glewMatrixLoadIdentityEXT) -#define glMatrixLoadTransposedEXT GLEW_GET_FUN(__glewMatrixLoadTransposedEXT) -#define glMatrixLoadTransposefEXT GLEW_GET_FUN(__glewMatrixLoadTransposefEXT) -#define glMatrixLoaddEXT GLEW_GET_FUN(__glewMatrixLoaddEXT) -#define glMatrixLoadfEXT GLEW_GET_FUN(__glewMatrixLoadfEXT) -#define glMatrixMultTransposedEXT GLEW_GET_FUN(__glewMatrixMultTransposedEXT) -#define glMatrixMultTransposefEXT GLEW_GET_FUN(__glewMatrixMultTransposefEXT) -#define glMatrixMultdEXT GLEW_GET_FUN(__glewMatrixMultdEXT) -#define glMatrixMultfEXT GLEW_GET_FUN(__glewMatrixMultfEXT) -#define glMatrixOrthoEXT GLEW_GET_FUN(__glewMatrixOrthoEXT) -#define glMatrixPopEXT GLEW_GET_FUN(__glewMatrixPopEXT) -#define glMatrixPushEXT GLEW_GET_FUN(__glewMatrixPushEXT) -#define glMatrixRotatedEXT GLEW_GET_FUN(__glewMatrixRotatedEXT) -#define glMatrixRotatefEXT GLEW_GET_FUN(__glewMatrixRotatefEXT) -#define glMatrixScaledEXT GLEW_GET_FUN(__glewMatrixScaledEXT) -#define glMatrixScalefEXT GLEW_GET_FUN(__glewMatrixScalefEXT) -#define glMatrixTranslatedEXT GLEW_GET_FUN(__glewMatrixTranslatedEXT) -#define glMatrixTranslatefEXT GLEW_GET_FUN(__glewMatrixTranslatefEXT) -#define glMultiTexBufferEXT GLEW_GET_FUN(__glewMultiTexBufferEXT) -#define glMultiTexCoordPointerEXT GLEW_GET_FUN(__glewMultiTexCoordPointerEXT) -#define glMultiTexEnvfEXT GLEW_GET_FUN(__glewMultiTexEnvfEXT) -#define glMultiTexEnvfvEXT GLEW_GET_FUN(__glewMultiTexEnvfvEXT) -#define glMultiTexEnviEXT GLEW_GET_FUN(__glewMultiTexEnviEXT) -#define glMultiTexEnvivEXT GLEW_GET_FUN(__glewMultiTexEnvivEXT) -#define glMultiTexGendEXT GLEW_GET_FUN(__glewMultiTexGendEXT) -#define glMultiTexGendvEXT GLEW_GET_FUN(__glewMultiTexGendvEXT) -#define glMultiTexGenfEXT GLEW_GET_FUN(__glewMultiTexGenfEXT) -#define glMultiTexGenfvEXT GLEW_GET_FUN(__glewMultiTexGenfvEXT) -#define glMultiTexGeniEXT GLEW_GET_FUN(__glewMultiTexGeniEXT) -#define glMultiTexGenivEXT GLEW_GET_FUN(__glewMultiTexGenivEXT) -#define glMultiTexImage1DEXT GLEW_GET_FUN(__glewMultiTexImage1DEXT) -#define glMultiTexImage2DEXT GLEW_GET_FUN(__glewMultiTexImage2DEXT) -#define glMultiTexImage3DEXT GLEW_GET_FUN(__glewMultiTexImage3DEXT) -#define glMultiTexParameterIivEXT GLEW_GET_FUN(__glewMultiTexParameterIivEXT) -#define glMultiTexParameterIuivEXT GLEW_GET_FUN(__glewMultiTexParameterIuivEXT) -#define glMultiTexParameterfEXT GLEW_GET_FUN(__glewMultiTexParameterfEXT) -#define glMultiTexParameterfvEXT GLEW_GET_FUN(__glewMultiTexParameterfvEXT) -#define glMultiTexParameteriEXT GLEW_GET_FUN(__glewMultiTexParameteriEXT) -#define glMultiTexParameterivEXT GLEW_GET_FUN(__glewMultiTexParameterivEXT) -#define glMultiTexRenderbufferEXT GLEW_GET_FUN(__glewMultiTexRenderbufferEXT) -#define glMultiTexSubImage1DEXT GLEW_GET_FUN(__glewMultiTexSubImage1DEXT) -#define glMultiTexSubImage2DEXT GLEW_GET_FUN(__glewMultiTexSubImage2DEXT) -#define glMultiTexSubImage3DEXT GLEW_GET_FUN(__glewMultiTexSubImage3DEXT) -#define glNamedBufferDataEXT GLEW_GET_FUN(__glewNamedBufferDataEXT) -#define glNamedBufferSubDataEXT GLEW_GET_FUN(__glewNamedBufferSubDataEXT) -#define glNamedCopyBufferSubDataEXT GLEW_GET_FUN(__glewNamedCopyBufferSubDataEXT) -#define glNamedFramebufferRenderbufferEXT GLEW_GET_FUN(__glewNamedFramebufferRenderbufferEXT) -#define glNamedFramebufferTexture1DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture1DEXT) -#define glNamedFramebufferTexture2DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture2DEXT) -#define glNamedFramebufferTexture3DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture3DEXT) -#define glNamedFramebufferTextureEXT GLEW_GET_FUN(__glewNamedFramebufferTextureEXT) -#define glNamedFramebufferTextureFaceEXT GLEW_GET_FUN(__glewNamedFramebufferTextureFaceEXT) -#define glNamedFramebufferTextureLayerEXT GLEW_GET_FUN(__glewNamedFramebufferTextureLayerEXT) -#define glNamedProgramLocalParameter4dEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4dEXT) -#define glNamedProgramLocalParameter4dvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4dvEXT) -#define glNamedProgramLocalParameter4fEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4fEXT) -#define glNamedProgramLocalParameter4fvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4fvEXT) -#define glNamedProgramLocalParameterI4iEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4iEXT) -#define glNamedProgramLocalParameterI4ivEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4ivEXT) -#define glNamedProgramLocalParameterI4uiEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4uiEXT) -#define glNamedProgramLocalParameterI4uivEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4uivEXT) -#define glNamedProgramLocalParameters4fvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameters4fvEXT) -#define glNamedProgramLocalParametersI4ivEXT GLEW_GET_FUN(__glewNamedProgramLocalParametersI4ivEXT) -#define glNamedProgramLocalParametersI4uivEXT GLEW_GET_FUN(__glewNamedProgramLocalParametersI4uivEXT) -#define glNamedProgramStringEXT GLEW_GET_FUN(__glewNamedProgramStringEXT) -#define glNamedRenderbufferStorageEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageEXT) -#define glNamedRenderbufferStorageMultisampleCoverageEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageMultisampleCoverageEXT) -#define glNamedRenderbufferStorageMultisampleEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageMultisampleEXT) -#define glProgramUniform1fEXT GLEW_GET_FUN(__glewProgramUniform1fEXT) -#define glProgramUniform1fvEXT GLEW_GET_FUN(__glewProgramUniform1fvEXT) -#define glProgramUniform1iEXT GLEW_GET_FUN(__glewProgramUniform1iEXT) -#define glProgramUniform1ivEXT GLEW_GET_FUN(__glewProgramUniform1ivEXT) -#define glProgramUniform1uiEXT GLEW_GET_FUN(__glewProgramUniform1uiEXT) -#define glProgramUniform1uivEXT GLEW_GET_FUN(__glewProgramUniform1uivEXT) -#define glProgramUniform2fEXT GLEW_GET_FUN(__glewProgramUniform2fEXT) -#define glProgramUniform2fvEXT GLEW_GET_FUN(__glewProgramUniform2fvEXT) -#define glProgramUniform2iEXT GLEW_GET_FUN(__glewProgramUniform2iEXT) -#define glProgramUniform2ivEXT GLEW_GET_FUN(__glewProgramUniform2ivEXT) -#define glProgramUniform2uiEXT GLEW_GET_FUN(__glewProgramUniform2uiEXT) -#define glProgramUniform2uivEXT GLEW_GET_FUN(__glewProgramUniform2uivEXT) -#define glProgramUniform3fEXT GLEW_GET_FUN(__glewProgramUniform3fEXT) -#define glProgramUniform3fvEXT GLEW_GET_FUN(__glewProgramUniform3fvEXT) -#define glProgramUniform3iEXT GLEW_GET_FUN(__glewProgramUniform3iEXT) -#define glProgramUniform3ivEXT GLEW_GET_FUN(__glewProgramUniform3ivEXT) -#define glProgramUniform3uiEXT GLEW_GET_FUN(__glewProgramUniform3uiEXT) -#define glProgramUniform3uivEXT GLEW_GET_FUN(__glewProgramUniform3uivEXT) -#define glProgramUniform4fEXT GLEW_GET_FUN(__glewProgramUniform4fEXT) -#define glProgramUniform4fvEXT GLEW_GET_FUN(__glewProgramUniform4fvEXT) -#define glProgramUniform4iEXT GLEW_GET_FUN(__glewProgramUniform4iEXT) -#define glProgramUniform4ivEXT GLEW_GET_FUN(__glewProgramUniform4ivEXT) -#define glProgramUniform4uiEXT GLEW_GET_FUN(__glewProgramUniform4uiEXT) -#define glProgramUniform4uivEXT GLEW_GET_FUN(__glewProgramUniform4uivEXT) -#define glProgramUniformMatrix2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2fvEXT) -#define glProgramUniformMatrix2x3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x3fvEXT) -#define glProgramUniformMatrix2x4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x4fvEXT) -#define glProgramUniformMatrix3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3fvEXT) -#define glProgramUniformMatrix3x2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x2fvEXT) -#define glProgramUniformMatrix3x4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x4fvEXT) -#define glProgramUniformMatrix4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4fvEXT) -#define glProgramUniformMatrix4x2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x2fvEXT) -#define glProgramUniformMatrix4x3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x3fvEXT) -#define glPushClientAttribDefaultEXT GLEW_GET_FUN(__glewPushClientAttribDefaultEXT) -#define glTextureBufferEXT GLEW_GET_FUN(__glewTextureBufferEXT) -#define glTextureImage1DEXT GLEW_GET_FUN(__glewTextureImage1DEXT) -#define glTextureImage2DEXT GLEW_GET_FUN(__glewTextureImage2DEXT) -#define glTextureImage3DEXT GLEW_GET_FUN(__glewTextureImage3DEXT) -#define glTextureParameterIivEXT GLEW_GET_FUN(__glewTextureParameterIivEXT) -#define glTextureParameterIuivEXT GLEW_GET_FUN(__glewTextureParameterIuivEXT) -#define glTextureParameterfEXT GLEW_GET_FUN(__glewTextureParameterfEXT) -#define glTextureParameterfvEXT GLEW_GET_FUN(__glewTextureParameterfvEXT) -#define glTextureParameteriEXT GLEW_GET_FUN(__glewTextureParameteriEXT) -#define glTextureParameterivEXT GLEW_GET_FUN(__glewTextureParameterivEXT) -#define glTextureRenderbufferEXT GLEW_GET_FUN(__glewTextureRenderbufferEXT) -#define glTextureSubImage1DEXT GLEW_GET_FUN(__glewTextureSubImage1DEXT) -#define glTextureSubImage2DEXT GLEW_GET_FUN(__glewTextureSubImage2DEXT) -#define glTextureSubImage3DEXT GLEW_GET_FUN(__glewTextureSubImage3DEXT) -#define glUnmapNamedBufferEXT GLEW_GET_FUN(__glewUnmapNamedBufferEXT) -#define glVertexArrayColorOffsetEXT GLEW_GET_FUN(__glewVertexArrayColorOffsetEXT) -#define glVertexArrayEdgeFlagOffsetEXT GLEW_GET_FUN(__glewVertexArrayEdgeFlagOffsetEXT) -#define glVertexArrayFogCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayFogCoordOffsetEXT) -#define glVertexArrayIndexOffsetEXT GLEW_GET_FUN(__glewVertexArrayIndexOffsetEXT) -#define glVertexArrayMultiTexCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayMultiTexCoordOffsetEXT) -#define glVertexArrayNormalOffsetEXT GLEW_GET_FUN(__glewVertexArrayNormalOffsetEXT) -#define glVertexArraySecondaryColorOffsetEXT GLEW_GET_FUN(__glewVertexArraySecondaryColorOffsetEXT) -#define glVertexArrayTexCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayTexCoordOffsetEXT) -#define glVertexArrayVertexAttribIOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribIOffsetEXT) -#define glVertexArrayVertexAttribOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribOffsetEXT) -#define glVertexArrayVertexOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexOffsetEXT) - -#define GLEW_EXT_direct_state_access GLEW_GET_VAR(__GLEW_EXT_direct_state_access) - -#endif /* GL_EXT_direct_state_access */ - -/* -------------------------- GL_EXT_draw_buffers2 ------------------------- */ - -#ifndef GL_EXT_draw_buffers2 -#define GL_EXT_draw_buffers2 1 - -typedef void (GLAPIENTRY * PFNGLCOLORMASKINDEXEDEXTPROC) (GLuint buf, GLboolean r, GLboolean g, GLboolean b, GLboolean a); -typedef void (GLAPIENTRY * PFNGLDISABLEINDEXEDEXTPROC) (GLenum target, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEINDEXEDEXTPROC) (GLenum target, GLuint index); -typedef void (GLAPIENTRY * PFNGLGETBOOLEANINDEXEDVEXTPROC) (GLenum value, GLuint index, GLboolean* data); -typedef void (GLAPIENTRY * PFNGLGETINTEGERINDEXEDVEXTPROC) (GLenum value, GLuint index, GLint* data); -typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDINDEXEDEXTPROC) (GLenum target, GLuint index); - -#define glColorMaskIndexedEXT GLEW_GET_FUN(__glewColorMaskIndexedEXT) -#define glDisableIndexedEXT GLEW_GET_FUN(__glewDisableIndexedEXT) -#define glEnableIndexedEXT GLEW_GET_FUN(__glewEnableIndexedEXT) -#define glGetBooleanIndexedvEXT GLEW_GET_FUN(__glewGetBooleanIndexedvEXT) -#define glGetIntegerIndexedvEXT GLEW_GET_FUN(__glewGetIntegerIndexedvEXT) -#define glIsEnabledIndexedEXT GLEW_GET_FUN(__glewIsEnabledIndexedEXT) - -#define GLEW_EXT_draw_buffers2 GLEW_GET_VAR(__GLEW_EXT_draw_buffers2) - -#endif /* GL_EXT_draw_buffers2 */ - -/* ------------------------- GL_EXT_draw_instanced ------------------------- */ - -#ifndef GL_EXT_draw_instanced -#define GL_EXT_draw_instanced 1 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDEXTPROC) (GLenum mode, GLint start, GLsizei count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDEXTPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount); - -#define glDrawArraysInstancedEXT GLEW_GET_FUN(__glewDrawArraysInstancedEXT) -#define glDrawElementsInstancedEXT GLEW_GET_FUN(__glewDrawElementsInstancedEXT) - -#define GLEW_EXT_draw_instanced GLEW_GET_VAR(__GLEW_EXT_draw_instanced) - -#endif /* GL_EXT_draw_instanced */ - -/* ----------------------- GL_EXT_draw_range_elements ---------------------- */ - -#ifndef GL_EXT_draw_range_elements -#define GL_EXT_draw_range_elements 1 - -#define GL_MAX_ELEMENTS_VERTICES_EXT 0x80E8 -#define GL_MAX_ELEMENTS_INDICES_EXT 0x80E9 - -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSEXTPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); - -#define glDrawRangeElementsEXT GLEW_GET_FUN(__glewDrawRangeElementsEXT) - -#define GLEW_EXT_draw_range_elements GLEW_GET_VAR(__GLEW_EXT_draw_range_elements) - -#endif /* GL_EXT_draw_range_elements */ - -/* ---------------------------- GL_EXT_fog_coord --------------------------- */ - -#ifndef GL_EXT_fog_coord -#define GL_EXT_fog_coord 1 - -#define GL_FOG_COORDINATE_SOURCE_EXT 0x8450 -#define GL_FOG_COORDINATE_EXT 0x8451 -#define GL_FRAGMENT_DEPTH_EXT 0x8452 -#define GL_CURRENT_FOG_COORDINATE_EXT 0x8453 -#define GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 -#define GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 -#define GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 -#define GL_FOG_COORDINATE_ARRAY_EXT 0x8457 - -typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDEXTPROC) (GLdouble coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDVEXTPROC) (const GLdouble *coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFEXTPROC) (GLfloat coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFVEXTPROC) (const GLfloat *coord); - -#define glFogCoordPointerEXT GLEW_GET_FUN(__glewFogCoordPointerEXT) -#define glFogCoorddEXT GLEW_GET_FUN(__glewFogCoorddEXT) -#define glFogCoorddvEXT GLEW_GET_FUN(__glewFogCoorddvEXT) -#define glFogCoordfEXT GLEW_GET_FUN(__glewFogCoordfEXT) -#define glFogCoordfvEXT GLEW_GET_FUN(__glewFogCoordfvEXT) - -#define GLEW_EXT_fog_coord GLEW_GET_VAR(__GLEW_EXT_fog_coord) - -#endif /* GL_EXT_fog_coord */ - -/* ------------------------ GL_EXT_fragment_lighting ----------------------- */ - -#ifndef GL_EXT_fragment_lighting -#define GL_EXT_fragment_lighting 1 - -#define GL_FRAGMENT_LIGHTING_EXT 0x8400 -#define GL_FRAGMENT_COLOR_MATERIAL_EXT 0x8401 -#define GL_FRAGMENT_COLOR_MATERIAL_FACE_EXT 0x8402 -#define GL_FRAGMENT_COLOR_MATERIAL_PARAMETER_EXT 0x8403 -#define GL_MAX_FRAGMENT_LIGHTS_EXT 0x8404 -#define GL_MAX_ACTIVE_LIGHTS_EXT 0x8405 -#define GL_CURRENT_RASTER_NORMAL_EXT 0x8406 -#define GL_LIGHT_ENV_MODE_EXT 0x8407 -#define GL_FRAGMENT_LIGHT_MODEL_LOCAL_VIEWER_EXT 0x8408 -#define GL_FRAGMENT_LIGHT_MODEL_TWO_SIDE_EXT 0x8409 -#define GL_FRAGMENT_LIGHT_MODEL_AMBIENT_EXT 0x840A -#define GL_FRAGMENT_LIGHT_MODEL_NORMAL_INTERPOLATION_EXT 0x840B -#define GL_FRAGMENT_LIGHT0_EXT 0x840C -#define GL_FRAGMENT_LIGHT7_EXT 0x8413 - -typedef void (GLAPIENTRY * PFNGLFRAGMENTCOLORMATERIALEXTPROC) (GLenum face, GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFEXTPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFVEXTPROC) (GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIEXTPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIVEXTPROC) (GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFEXTPROC) (GLenum light, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFVEXTPROC) (GLenum light, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIEXTPROC) (GLenum light, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIVEXTPROC) (GLenum light, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFEXTPROC) (GLenum face, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFVEXTPROC) (GLenum face, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIEXTPROC) (GLenum face, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIVEXTPROC) (GLenum face, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTFVEXTPROC) (GLenum light, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTIVEXTPROC) (GLenum light, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALFVEXTPROC) (GLenum face, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALIVEXTPROC) (GLenum face, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLLIGHTENVIEXTPROC) (GLenum pname, GLint param); - -#define glFragmentColorMaterialEXT GLEW_GET_FUN(__glewFragmentColorMaterialEXT) -#define glFragmentLightModelfEXT GLEW_GET_FUN(__glewFragmentLightModelfEXT) -#define glFragmentLightModelfvEXT GLEW_GET_FUN(__glewFragmentLightModelfvEXT) -#define glFragmentLightModeliEXT GLEW_GET_FUN(__glewFragmentLightModeliEXT) -#define glFragmentLightModelivEXT GLEW_GET_FUN(__glewFragmentLightModelivEXT) -#define glFragmentLightfEXT GLEW_GET_FUN(__glewFragmentLightfEXT) -#define glFragmentLightfvEXT GLEW_GET_FUN(__glewFragmentLightfvEXT) -#define glFragmentLightiEXT GLEW_GET_FUN(__glewFragmentLightiEXT) -#define glFragmentLightivEXT GLEW_GET_FUN(__glewFragmentLightivEXT) -#define glFragmentMaterialfEXT GLEW_GET_FUN(__glewFragmentMaterialfEXT) -#define glFragmentMaterialfvEXT GLEW_GET_FUN(__glewFragmentMaterialfvEXT) -#define glFragmentMaterialiEXT GLEW_GET_FUN(__glewFragmentMaterialiEXT) -#define glFragmentMaterialivEXT GLEW_GET_FUN(__glewFragmentMaterialivEXT) -#define glGetFragmentLightfvEXT GLEW_GET_FUN(__glewGetFragmentLightfvEXT) -#define glGetFragmentLightivEXT GLEW_GET_FUN(__glewGetFragmentLightivEXT) -#define glGetFragmentMaterialfvEXT GLEW_GET_FUN(__glewGetFragmentMaterialfvEXT) -#define glGetFragmentMaterialivEXT GLEW_GET_FUN(__glewGetFragmentMaterialivEXT) -#define glLightEnviEXT GLEW_GET_FUN(__glewLightEnviEXT) - -#define GLEW_EXT_fragment_lighting GLEW_GET_VAR(__GLEW_EXT_fragment_lighting) - -#endif /* GL_EXT_fragment_lighting */ - -/* ------------------------ GL_EXT_framebuffer_blit ------------------------ */ - -#ifndef GL_EXT_framebuffer_blit -#define GL_EXT_framebuffer_blit 1 - -#define GL_DRAW_FRAMEBUFFER_BINDING_EXT 0x8CA6 -#define GL_READ_FRAMEBUFFER_EXT 0x8CA8 -#define GL_DRAW_FRAMEBUFFER_EXT 0x8CA9 -#define GL_READ_FRAMEBUFFER_BINDING_EXT 0x8CAA - -typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFEREXTPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); - -#define glBlitFramebufferEXT GLEW_GET_FUN(__glewBlitFramebufferEXT) - -#define GLEW_EXT_framebuffer_blit GLEW_GET_VAR(__GLEW_EXT_framebuffer_blit) - -#endif /* GL_EXT_framebuffer_blit */ - -/* --------------------- GL_EXT_framebuffer_multisample -------------------- */ - -#ifndef GL_EXT_framebuffer_multisample -#define GL_EXT_framebuffer_multisample 1 - -#define GL_RENDERBUFFER_SAMPLES_EXT 0x8CAB -#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_EXT 0x8D56 -#define GL_MAX_SAMPLES_EXT 0x8D57 - -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glRenderbufferStorageMultisampleEXT GLEW_GET_FUN(__glewRenderbufferStorageMultisampleEXT) - -#define GLEW_EXT_framebuffer_multisample GLEW_GET_VAR(__GLEW_EXT_framebuffer_multisample) - -#endif /* GL_EXT_framebuffer_multisample */ - -/* ----------------------- GL_EXT_framebuffer_object ----------------------- */ - -#ifndef GL_EXT_framebuffer_object -#define GL_EXT_framebuffer_object 1 - -#define GL_INVALID_FRAMEBUFFER_OPERATION_EXT 0x0506 -#define GL_MAX_RENDERBUFFER_SIZE_EXT 0x84E8 -#define GL_FRAMEBUFFER_BINDING_EXT 0x8CA6 -#define GL_RENDERBUFFER_BINDING_EXT 0x8CA7 -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE_EXT 0x8CD0 -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_EXT 0x8CD1 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL_EXT 0x8CD2 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE_EXT 0x8CD3 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET_EXT 0x8CD4 -#define GL_FRAMEBUFFER_COMPLETE_EXT 0x8CD5 -#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT_EXT 0x8CD6 -#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT_EXT 0x8CD7 -#define GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS_EXT 0x8CD9 -#define GL_FRAMEBUFFER_INCOMPLETE_FORMATS_EXT 0x8CDA -#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER_EXT 0x8CDB -#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER_EXT 0x8CDC -#define GL_FRAMEBUFFER_UNSUPPORTED_EXT 0x8CDD -#define GL_MAX_COLOR_ATTACHMENTS_EXT 0x8CDF -#define GL_COLOR_ATTACHMENT0_EXT 0x8CE0 -#define GL_COLOR_ATTACHMENT1_EXT 0x8CE1 -#define GL_COLOR_ATTACHMENT2_EXT 0x8CE2 -#define GL_COLOR_ATTACHMENT3_EXT 0x8CE3 -#define GL_COLOR_ATTACHMENT4_EXT 0x8CE4 -#define GL_COLOR_ATTACHMENT5_EXT 0x8CE5 -#define GL_COLOR_ATTACHMENT6_EXT 0x8CE6 -#define GL_COLOR_ATTACHMENT7_EXT 0x8CE7 -#define GL_COLOR_ATTACHMENT8_EXT 0x8CE8 -#define GL_COLOR_ATTACHMENT9_EXT 0x8CE9 -#define GL_COLOR_ATTACHMENT10_EXT 0x8CEA -#define GL_COLOR_ATTACHMENT11_EXT 0x8CEB -#define GL_COLOR_ATTACHMENT12_EXT 0x8CEC -#define GL_COLOR_ATTACHMENT13_EXT 0x8CED -#define GL_COLOR_ATTACHMENT14_EXT 0x8CEE -#define GL_COLOR_ATTACHMENT15_EXT 0x8CEF -#define GL_DEPTH_ATTACHMENT_EXT 0x8D00 -#define GL_STENCIL_ATTACHMENT_EXT 0x8D20 -#define GL_FRAMEBUFFER_EXT 0x8D40 -#define GL_RENDERBUFFER_EXT 0x8D41 -#define GL_RENDERBUFFER_WIDTH_EXT 0x8D42 -#define GL_RENDERBUFFER_HEIGHT_EXT 0x8D43 -#define GL_RENDERBUFFER_INTERNAL_FORMAT_EXT 0x8D44 -#define GL_STENCIL_INDEX1_EXT 0x8D46 -#define GL_STENCIL_INDEX4_EXT 0x8D47 -#define GL_STENCIL_INDEX8_EXT 0x8D48 -#define GL_STENCIL_INDEX16_EXT 0x8D49 -#define GL_RENDERBUFFER_RED_SIZE_EXT 0x8D50 -#define GL_RENDERBUFFER_GREEN_SIZE_EXT 0x8D51 -#define GL_RENDERBUFFER_BLUE_SIZE_EXT 0x8D52 -#define GL_RENDERBUFFER_ALPHA_SIZE_EXT 0x8D53 -#define GL_RENDERBUFFER_DEPTH_SIZE_EXT 0x8D54 -#define GL_RENDERBUFFER_STENCIL_SIZE_EXT 0x8D55 - -typedef void (GLAPIENTRY * PFNGLBINDFRAMEBUFFEREXTPROC) (GLenum target, GLuint framebuffer); -typedef void (GLAPIENTRY * PFNGLBINDRENDERBUFFEREXTPROC) (GLenum target, GLuint renderbuffer); -typedef GLenum (GLAPIENTRY * PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLDELETEFRAMEBUFFERSEXTPROC) (GLsizei n, const GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLDELETERENDERBUFFERSEXTPROC) (GLsizei n, const GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE1DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE2DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE3DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); -typedef void (GLAPIENTRY * PFNGLGENFRAMEBUFFERSEXTPROC) (GLsizei n, GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLGENRENDERBUFFERSEXTPROC) (GLsizei n, GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLGENERATEMIPMAPEXTPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLenum target, GLenum attachment, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISFRAMEBUFFEREXTPROC) (GLuint framebuffer); -typedef GLboolean (GLAPIENTRY * PFNGLISRENDERBUFFEREXTPROC) (GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); - -#define glBindFramebufferEXT GLEW_GET_FUN(__glewBindFramebufferEXT) -#define glBindRenderbufferEXT GLEW_GET_FUN(__glewBindRenderbufferEXT) -#define glCheckFramebufferStatusEXT GLEW_GET_FUN(__glewCheckFramebufferStatusEXT) -#define glDeleteFramebuffersEXT GLEW_GET_FUN(__glewDeleteFramebuffersEXT) -#define glDeleteRenderbuffersEXT GLEW_GET_FUN(__glewDeleteRenderbuffersEXT) -#define glFramebufferRenderbufferEXT GLEW_GET_FUN(__glewFramebufferRenderbufferEXT) -#define glFramebufferTexture1DEXT GLEW_GET_FUN(__glewFramebufferTexture1DEXT) -#define glFramebufferTexture2DEXT GLEW_GET_FUN(__glewFramebufferTexture2DEXT) -#define glFramebufferTexture3DEXT GLEW_GET_FUN(__glewFramebufferTexture3DEXT) -#define glGenFramebuffersEXT GLEW_GET_FUN(__glewGenFramebuffersEXT) -#define glGenRenderbuffersEXT GLEW_GET_FUN(__glewGenRenderbuffersEXT) -#define glGenerateMipmapEXT GLEW_GET_FUN(__glewGenerateMipmapEXT) -#define glGetFramebufferAttachmentParameterivEXT GLEW_GET_FUN(__glewGetFramebufferAttachmentParameterivEXT) -#define glGetRenderbufferParameterivEXT GLEW_GET_FUN(__glewGetRenderbufferParameterivEXT) -#define glIsFramebufferEXT GLEW_GET_FUN(__glewIsFramebufferEXT) -#define glIsRenderbufferEXT GLEW_GET_FUN(__glewIsRenderbufferEXT) -#define glRenderbufferStorageEXT GLEW_GET_FUN(__glewRenderbufferStorageEXT) - -#define GLEW_EXT_framebuffer_object GLEW_GET_VAR(__GLEW_EXT_framebuffer_object) - -#endif /* GL_EXT_framebuffer_object */ - -/* ------------------------ GL_EXT_framebuffer_sRGB ------------------------ */ - -#ifndef GL_EXT_framebuffer_sRGB -#define GL_EXT_framebuffer_sRGB 1 - -#define GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 -#define GL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x8DBA - -#define GLEW_EXT_framebuffer_sRGB GLEW_GET_VAR(__GLEW_EXT_framebuffer_sRGB) - -#endif /* GL_EXT_framebuffer_sRGB */ - -/* ------------------------ GL_EXT_geometry_shader4 ------------------------ */ - -#ifndef GL_EXT_geometry_shader4 -#define GL_EXT_geometry_shader4 1 - -#define GL_LINES_ADJACENCY_EXT 0xA -#define GL_LINE_STRIP_ADJACENCY_EXT 0xB -#define GL_TRIANGLES_ADJACENCY_EXT 0xC -#define GL_TRIANGLE_STRIP_ADJACENCY_EXT 0xD -#define GL_PROGRAM_POINT_SIZE_EXT 0x8642 -#define GL_MAX_VARYING_COMPONENTS_EXT 0x8B4B -#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_EXT 0x8C29 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER_EXT 0x8CD4 -#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_EXT 0x8DA7 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_EXT 0x8DA8 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_EXT 0x8DA9 -#define GL_GEOMETRY_SHADER_EXT 0x8DD9 -#define GL_GEOMETRY_VERTICES_OUT_EXT 0x8DDA -#define GL_GEOMETRY_INPUT_TYPE_EXT 0x8DDB -#define GL_GEOMETRY_OUTPUT_TYPE_EXT 0x8DDC -#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_EXT 0x8DDD -#define GL_MAX_VERTEX_VARYING_COMPONENTS_EXT 0x8DDE -#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_EXT 0x8DDF -#define GL_MAX_GEOMETRY_OUTPUT_VERTICES_EXT 0x8DE0 -#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_EXT 0x8DE1 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIEXTPROC) (GLuint program, GLenum pname, GLint value); - -#define glFramebufferTextureEXT GLEW_GET_FUN(__glewFramebufferTextureEXT) -#define glFramebufferTextureFaceEXT GLEW_GET_FUN(__glewFramebufferTextureFaceEXT) -#define glProgramParameteriEXT GLEW_GET_FUN(__glewProgramParameteriEXT) - -#define GLEW_EXT_geometry_shader4 GLEW_GET_VAR(__GLEW_EXT_geometry_shader4) - -#endif /* GL_EXT_geometry_shader4 */ - -/* --------------------- GL_EXT_gpu_program_parameters --------------------- */ - -#ifndef GL_EXT_gpu_program_parameters -#define GL_EXT_gpu_program_parameters 1 - -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat* params); - -#define glProgramEnvParameters4fvEXT GLEW_GET_FUN(__glewProgramEnvParameters4fvEXT) -#define glProgramLocalParameters4fvEXT GLEW_GET_FUN(__glewProgramLocalParameters4fvEXT) - -#define GLEW_EXT_gpu_program_parameters GLEW_GET_VAR(__GLEW_EXT_gpu_program_parameters) - -#endif /* GL_EXT_gpu_program_parameters */ - -/* --------------------------- GL_EXT_gpu_shader4 -------------------------- */ - -#ifndef GL_EXT_gpu_shader4 -#define GL_EXT_gpu_shader4 1 - -#define GL_VERTEX_ATTRIB_ARRAY_INTEGER_EXT 0x88FD -#define GL_SAMPLER_1D_ARRAY_EXT 0x8DC0 -#define GL_SAMPLER_2D_ARRAY_EXT 0x8DC1 -#define GL_SAMPLER_BUFFER_EXT 0x8DC2 -#define GL_SAMPLER_1D_ARRAY_SHADOW_EXT 0x8DC3 -#define GL_SAMPLER_2D_ARRAY_SHADOW_EXT 0x8DC4 -#define GL_SAMPLER_CUBE_SHADOW_EXT 0x8DC5 -#define GL_UNSIGNED_INT_VEC2_EXT 0x8DC6 -#define GL_UNSIGNED_INT_VEC3_EXT 0x8DC7 -#define GL_UNSIGNED_INT_VEC4_EXT 0x8DC8 -#define GL_INT_SAMPLER_1D_EXT 0x8DC9 -#define GL_INT_SAMPLER_2D_EXT 0x8DCA -#define GL_INT_SAMPLER_3D_EXT 0x8DCB -#define GL_INT_SAMPLER_CUBE_EXT 0x8DCC -#define GL_INT_SAMPLER_2D_RECT_EXT 0x8DCD -#define GL_INT_SAMPLER_1D_ARRAY_EXT 0x8DCE -#define GL_INT_SAMPLER_2D_ARRAY_EXT 0x8DCF -#define GL_INT_SAMPLER_BUFFER_EXT 0x8DD0 -#define GL_UNSIGNED_INT_SAMPLER_1D_EXT 0x8DD1 -#define GL_UNSIGNED_INT_SAMPLER_2D_EXT 0x8DD2 -#define GL_UNSIGNED_INT_SAMPLER_3D_EXT 0x8DD3 -#define GL_UNSIGNED_INT_SAMPLER_CUBE_EXT 0x8DD4 -#define GL_UNSIGNED_INT_SAMPLER_2D_RECT_EXT 0x8DD5 -#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY_EXT 0x8DD6 -#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY_EXT 0x8DD7 -#define GL_UNSIGNED_INT_SAMPLER_BUFFER_EXT 0x8DD8 - -typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONEXTPROC) (GLuint program, GLuint color, const GLchar *name); -typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATALOCATIONEXTPROC) (GLuint program, const GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMUIVEXTPROC) (GLuint program, GLint location, GLuint *params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIIVEXTPROC) (GLuint index, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIUIVEXTPROC) (GLuint index, GLenum pname, GLuint *params); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIEXTPROC) (GLint location, GLuint v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIEXTPROC) (GLint location, GLuint v0, GLuint v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IEXTPROC) (GLuint index, GLint x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIEXTPROC) (GLuint index, GLuint x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IEXTPROC) (GLuint index, GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIEXTPROC) (GLuint index, GLuint x, GLuint y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IEXTPROC) (GLuint index, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4BVEXTPROC) (GLuint index, const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IEXTPROC) (GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4SVEXTPROC) (GLuint index, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UBVEXTPROC) (GLuint index, const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4USVEXTPROC) (GLuint index, const GLushort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); - -#define glBindFragDataLocationEXT GLEW_GET_FUN(__glewBindFragDataLocationEXT) -#define glGetFragDataLocationEXT GLEW_GET_FUN(__glewGetFragDataLocationEXT) -#define glGetUniformuivEXT GLEW_GET_FUN(__glewGetUniformuivEXT) -#define glGetVertexAttribIivEXT GLEW_GET_FUN(__glewGetVertexAttribIivEXT) -#define glGetVertexAttribIuivEXT GLEW_GET_FUN(__glewGetVertexAttribIuivEXT) -#define glUniform1uiEXT GLEW_GET_FUN(__glewUniform1uiEXT) -#define glUniform1uivEXT GLEW_GET_FUN(__glewUniform1uivEXT) -#define glUniform2uiEXT GLEW_GET_FUN(__glewUniform2uiEXT) -#define glUniform2uivEXT GLEW_GET_FUN(__glewUniform2uivEXT) -#define glUniform3uiEXT GLEW_GET_FUN(__glewUniform3uiEXT) -#define glUniform3uivEXT GLEW_GET_FUN(__glewUniform3uivEXT) -#define glUniform4uiEXT GLEW_GET_FUN(__glewUniform4uiEXT) -#define glUniform4uivEXT GLEW_GET_FUN(__glewUniform4uivEXT) -#define glVertexAttribI1iEXT GLEW_GET_FUN(__glewVertexAttribI1iEXT) -#define glVertexAttribI1ivEXT GLEW_GET_FUN(__glewVertexAttribI1ivEXT) -#define glVertexAttribI1uiEXT GLEW_GET_FUN(__glewVertexAttribI1uiEXT) -#define glVertexAttribI1uivEXT GLEW_GET_FUN(__glewVertexAttribI1uivEXT) -#define glVertexAttribI2iEXT GLEW_GET_FUN(__glewVertexAttribI2iEXT) -#define glVertexAttribI2ivEXT GLEW_GET_FUN(__glewVertexAttribI2ivEXT) -#define glVertexAttribI2uiEXT GLEW_GET_FUN(__glewVertexAttribI2uiEXT) -#define glVertexAttribI2uivEXT GLEW_GET_FUN(__glewVertexAttribI2uivEXT) -#define glVertexAttribI3iEXT GLEW_GET_FUN(__glewVertexAttribI3iEXT) -#define glVertexAttribI3ivEXT GLEW_GET_FUN(__glewVertexAttribI3ivEXT) -#define glVertexAttribI3uiEXT GLEW_GET_FUN(__glewVertexAttribI3uiEXT) -#define glVertexAttribI3uivEXT GLEW_GET_FUN(__glewVertexAttribI3uivEXT) -#define glVertexAttribI4bvEXT GLEW_GET_FUN(__glewVertexAttribI4bvEXT) -#define glVertexAttribI4iEXT GLEW_GET_FUN(__glewVertexAttribI4iEXT) -#define glVertexAttribI4ivEXT GLEW_GET_FUN(__glewVertexAttribI4ivEXT) -#define glVertexAttribI4svEXT GLEW_GET_FUN(__glewVertexAttribI4svEXT) -#define glVertexAttribI4ubvEXT GLEW_GET_FUN(__glewVertexAttribI4ubvEXT) -#define glVertexAttribI4uiEXT GLEW_GET_FUN(__glewVertexAttribI4uiEXT) -#define glVertexAttribI4uivEXT GLEW_GET_FUN(__glewVertexAttribI4uivEXT) -#define glVertexAttribI4usvEXT GLEW_GET_FUN(__glewVertexAttribI4usvEXT) -#define glVertexAttribIPointerEXT GLEW_GET_FUN(__glewVertexAttribIPointerEXT) - -#define GLEW_EXT_gpu_shader4 GLEW_GET_VAR(__GLEW_EXT_gpu_shader4) - -#endif /* GL_EXT_gpu_shader4 */ - -/* ---------------------------- GL_EXT_histogram --------------------------- */ - -#ifndef GL_EXT_histogram -#define GL_EXT_histogram 1 - -#define GL_HISTOGRAM_EXT 0x8024 -#define GL_PROXY_HISTOGRAM_EXT 0x8025 -#define GL_HISTOGRAM_WIDTH_EXT 0x8026 -#define GL_HISTOGRAM_FORMAT_EXT 0x8027 -#define GL_HISTOGRAM_RED_SIZE_EXT 0x8028 -#define GL_HISTOGRAM_GREEN_SIZE_EXT 0x8029 -#define GL_HISTOGRAM_BLUE_SIZE_EXT 0x802A -#define GL_HISTOGRAM_ALPHA_SIZE_EXT 0x802B -#define GL_HISTOGRAM_LUMINANCE_SIZE_EXT 0x802C -#define GL_HISTOGRAM_SINK_EXT 0x802D -#define GL_MINMAX_EXT 0x802E -#define GL_MINMAX_FORMAT_EXT 0x802F -#define GL_MINMAX_SINK_EXT 0x8030 - -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void* values); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void* values); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLHISTOGRAMEXTPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLMINMAXEXTPROC) (GLenum target, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLRESETHISTOGRAMEXTPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLRESETMINMAXEXTPROC) (GLenum target); - -#define glGetHistogramEXT GLEW_GET_FUN(__glewGetHistogramEXT) -#define glGetHistogramParameterfvEXT GLEW_GET_FUN(__glewGetHistogramParameterfvEXT) -#define glGetHistogramParameterivEXT GLEW_GET_FUN(__glewGetHistogramParameterivEXT) -#define glGetMinmaxEXT GLEW_GET_FUN(__glewGetMinmaxEXT) -#define glGetMinmaxParameterfvEXT GLEW_GET_FUN(__glewGetMinmaxParameterfvEXT) -#define glGetMinmaxParameterivEXT GLEW_GET_FUN(__glewGetMinmaxParameterivEXT) -#define glHistogramEXT GLEW_GET_FUN(__glewHistogramEXT) -#define glMinmaxEXT GLEW_GET_FUN(__glewMinmaxEXT) -#define glResetHistogramEXT GLEW_GET_FUN(__glewResetHistogramEXT) -#define glResetMinmaxEXT GLEW_GET_FUN(__glewResetMinmaxEXT) - -#define GLEW_EXT_histogram GLEW_GET_VAR(__GLEW_EXT_histogram) - -#endif /* GL_EXT_histogram */ - -/* ----------------------- GL_EXT_index_array_formats ---------------------- */ - -#ifndef GL_EXT_index_array_formats -#define GL_EXT_index_array_formats 1 - -#define GLEW_EXT_index_array_formats GLEW_GET_VAR(__GLEW_EXT_index_array_formats) - -#endif /* GL_EXT_index_array_formats */ - -/* --------------------------- GL_EXT_index_func --------------------------- */ - -#ifndef GL_EXT_index_func -#define GL_EXT_index_func 1 - -typedef void (GLAPIENTRY * PFNGLINDEXFUNCEXTPROC) (GLenum func, GLfloat ref); - -#define glIndexFuncEXT GLEW_GET_FUN(__glewIndexFuncEXT) - -#define GLEW_EXT_index_func GLEW_GET_VAR(__GLEW_EXT_index_func) - -#endif /* GL_EXT_index_func */ - -/* ------------------------- GL_EXT_index_material ------------------------- */ - -#ifndef GL_EXT_index_material -#define GL_EXT_index_material 1 - -typedef void (GLAPIENTRY * PFNGLINDEXMATERIALEXTPROC) (GLenum face, GLenum mode); - -#define glIndexMaterialEXT GLEW_GET_FUN(__glewIndexMaterialEXT) - -#define GLEW_EXT_index_material GLEW_GET_VAR(__GLEW_EXT_index_material) - -#endif /* GL_EXT_index_material */ - -/* -------------------------- GL_EXT_index_texture ------------------------- */ - -#ifndef GL_EXT_index_texture -#define GL_EXT_index_texture 1 - -#define GLEW_EXT_index_texture GLEW_GET_VAR(__GLEW_EXT_index_texture) - -#endif /* GL_EXT_index_texture */ - -/* -------------------------- GL_EXT_light_texture ------------------------- */ - -#ifndef GL_EXT_light_texture -#define GL_EXT_light_texture 1 - -#define GL_FRAGMENT_MATERIAL_EXT 0x8349 -#define GL_FRAGMENT_NORMAL_EXT 0x834A -#define GL_FRAGMENT_COLOR_EXT 0x834C -#define GL_ATTENUATION_EXT 0x834D -#define GL_SHADOW_ATTENUATION_EXT 0x834E -#define GL_TEXTURE_APPLICATION_MODE_EXT 0x834F -#define GL_TEXTURE_LIGHT_EXT 0x8350 -#define GL_TEXTURE_MATERIAL_FACE_EXT 0x8351 -#define GL_TEXTURE_MATERIAL_PARAMETER_EXT 0x8352 -#define GL_FRAGMENT_DEPTH_EXT 0x8452 - -typedef void (GLAPIENTRY * PFNGLAPPLYTEXTUREEXTPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLTEXTURELIGHTEXTPROC) (GLenum pname); -typedef void (GLAPIENTRY * PFNGLTEXTUREMATERIALEXTPROC) (GLenum face, GLenum mode); - -#define glApplyTextureEXT GLEW_GET_FUN(__glewApplyTextureEXT) -#define glTextureLightEXT GLEW_GET_FUN(__glewTextureLightEXT) -#define glTextureMaterialEXT GLEW_GET_FUN(__glewTextureMaterialEXT) - -#define GLEW_EXT_light_texture GLEW_GET_VAR(__GLEW_EXT_light_texture) - -#endif /* GL_EXT_light_texture */ - -/* ------------------------- GL_EXT_misc_attribute ------------------------- */ - -#ifndef GL_EXT_misc_attribute -#define GL_EXT_misc_attribute 1 - -#define GLEW_EXT_misc_attribute GLEW_GET_VAR(__GLEW_EXT_misc_attribute) - -#endif /* GL_EXT_misc_attribute */ - -/* ------------------------ GL_EXT_multi_draw_arrays ----------------------- */ - -#ifndef GL_EXT_multi_draw_arrays -#define GL_EXT_multi_draw_arrays 1 - -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, const GLint* first, const GLsizei *count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, GLsizei* count, GLenum type, const GLvoid **indices, GLsizei primcount); - -#define glMultiDrawArraysEXT GLEW_GET_FUN(__glewMultiDrawArraysEXT) -#define glMultiDrawElementsEXT GLEW_GET_FUN(__glewMultiDrawElementsEXT) - -#define GLEW_EXT_multi_draw_arrays GLEW_GET_VAR(__GLEW_EXT_multi_draw_arrays) - -#endif /* GL_EXT_multi_draw_arrays */ - -/* --------------------------- GL_EXT_multisample -------------------------- */ - -#ifndef GL_EXT_multisample -#define GL_EXT_multisample 1 - -#define GL_MULTISAMPLE_EXT 0x809D -#define GL_SAMPLE_ALPHA_TO_MASK_EXT 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_EXT 0x809F -#define GL_SAMPLE_MASK_EXT 0x80A0 -#define GL_1PASS_EXT 0x80A1 -#define GL_2PASS_0_EXT 0x80A2 -#define GL_2PASS_1_EXT 0x80A3 -#define GL_4PASS_0_EXT 0x80A4 -#define GL_4PASS_1_EXT 0x80A5 -#define GL_4PASS_2_EXT 0x80A6 -#define GL_4PASS_3_EXT 0x80A7 -#define GL_SAMPLE_BUFFERS_EXT 0x80A8 -#define GL_SAMPLES_EXT 0x80A9 -#define GL_SAMPLE_MASK_VALUE_EXT 0x80AA -#define GL_SAMPLE_MASK_INVERT_EXT 0x80AB -#define GL_SAMPLE_PATTERN_EXT 0x80AC -#define GL_MULTISAMPLE_BIT_EXT 0x20000000 - -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKEXTPROC) (GLclampf value, GLboolean invert); -typedef void (GLAPIENTRY * PFNGLSAMPLEPATTERNEXTPROC) (GLenum pattern); - -#define glSampleMaskEXT GLEW_GET_FUN(__glewSampleMaskEXT) -#define glSamplePatternEXT GLEW_GET_FUN(__glewSamplePatternEXT) - -#define GLEW_EXT_multisample GLEW_GET_VAR(__GLEW_EXT_multisample) - -#endif /* GL_EXT_multisample */ - -/* ---------------------- GL_EXT_packed_depth_stencil ---------------------- */ - -#ifndef GL_EXT_packed_depth_stencil -#define GL_EXT_packed_depth_stencil 1 - -#define GL_DEPTH_STENCIL_EXT 0x84F9 -#define GL_UNSIGNED_INT_24_8_EXT 0x84FA -#define GL_DEPTH24_STENCIL8_EXT 0x88F0 -#define GL_TEXTURE_STENCIL_SIZE_EXT 0x88F1 - -#define GLEW_EXT_packed_depth_stencil GLEW_GET_VAR(__GLEW_EXT_packed_depth_stencil) - -#endif /* GL_EXT_packed_depth_stencil */ - -/* -------------------------- GL_EXT_packed_float -------------------------- */ - -#ifndef GL_EXT_packed_float -#define GL_EXT_packed_float 1 - -#define GL_R11F_G11F_B10F_EXT 0x8C3A -#define GL_UNSIGNED_INT_10F_11F_11F_REV_EXT 0x8C3B -#define GL_RGBA_SIGNED_COMPONENTS_EXT 0x8C3C - -#define GLEW_EXT_packed_float GLEW_GET_VAR(__GLEW_EXT_packed_float) - -#endif /* GL_EXT_packed_float */ - -/* -------------------------- GL_EXT_packed_pixels ------------------------- */ - -#ifndef GL_EXT_packed_pixels -#define GL_EXT_packed_pixels 1 - -#define GL_UNSIGNED_BYTE_3_3_2_EXT 0x8032 -#define GL_UNSIGNED_SHORT_4_4_4_4_EXT 0x8033 -#define GL_UNSIGNED_SHORT_5_5_5_1_EXT 0x8034 -#define GL_UNSIGNED_INT_8_8_8_8_EXT 0x8035 -#define GL_UNSIGNED_INT_10_10_10_2_EXT 0x8036 - -#define GLEW_EXT_packed_pixels GLEW_GET_VAR(__GLEW_EXT_packed_pixels) - -#endif /* GL_EXT_packed_pixels */ - -/* ------------------------ GL_EXT_paletted_texture ------------------------ */ - -#ifndef GL_EXT_paletted_texture -#define GL_EXT_paletted_texture 1 - -#define GL_TEXTURE_1D 0x0DE0 -#define GL_TEXTURE_2D 0x0DE1 -#define GL_PROXY_TEXTURE_1D 0x8063 -#define GL_PROXY_TEXTURE_2D 0x8064 -#define GL_TEXTURE_3D_EXT 0x806F -#define GL_PROXY_TEXTURE_3D_EXT 0x8070 -#define GL_COLOR_TABLE_FORMAT_EXT 0x80D8 -#define GL_COLOR_TABLE_WIDTH_EXT 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE_EXT 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE_EXT 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE_EXT 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE_EXT 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE_EXT 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE_EXT 0x80DF -#define GL_COLOR_INDEX1_EXT 0x80E2 -#define GL_COLOR_INDEX2_EXT 0x80E3 -#define GL_COLOR_INDEX4_EXT 0x80E4 -#define GL_COLOR_INDEX8_EXT 0x80E5 -#define GL_COLOR_INDEX12_EXT 0x80E6 -#define GL_COLOR_INDEX16_EXT 0x80E7 -#define GL_TEXTURE_INDEX_SIZE_EXT 0x80ED -#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 -#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B - -typedef void (GLAPIENTRY * PFNGLCOLORTABLEEXTPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const void* data); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEEXTPROC) (GLenum target, GLenum format, GLenum type, void* data); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); - -#define glColorTableEXT GLEW_GET_FUN(__glewColorTableEXT) -#define glGetColorTableEXT GLEW_GET_FUN(__glewGetColorTableEXT) -#define glGetColorTableParameterfvEXT GLEW_GET_FUN(__glewGetColorTableParameterfvEXT) -#define glGetColorTableParameterivEXT GLEW_GET_FUN(__glewGetColorTableParameterivEXT) - -#define GLEW_EXT_paletted_texture GLEW_GET_VAR(__GLEW_EXT_paletted_texture) - -#endif /* GL_EXT_paletted_texture */ - -/* ----------------------- GL_EXT_pixel_buffer_object ---------------------- */ - -#ifndef GL_EXT_pixel_buffer_object -#define GL_EXT_pixel_buffer_object 1 - -#define GL_PIXEL_PACK_BUFFER_EXT 0x88EB -#define GL_PIXEL_UNPACK_BUFFER_EXT 0x88EC -#define GL_PIXEL_PACK_BUFFER_BINDING_EXT 0x88ED -#define GL_PIXEL_UNPACK_BUFFER_BINDING_EXT 0x88EF - -#define GLEW_EXT_pixel_buffer_object GLEW_GET_VAR(__GLEW_EXT_pixel_buffer_object) - -#endif /* GL_EXT_pixel_buffer_object */ - -/* ------------------------- GL_EXT_pixel_transform ------------------------ */ - -#ifndef GL_EXT_pixel_transform -#define GL_EXT_pixel_transform 1 - -#define GL_PIXEL_TRANSFORM_2D_EXT 0x8330 -#define GL_PIXEL_MAG_FILTER_EXT 0x8331 -#define GL_PIXEL_MIN_FILTER_EXT 0x8332 -#define GL_PIXEL_CUBIC_WEIGHT_EXT 0x8333 -#define GL_CUBIC_EXT 0x8334 -#define GL_AVERAGE_EXT 0x8335 -#define GL_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8336 -#define GL_MAX_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8337 -#define GL_PIXEL_TRANSFORM_2D_MATRIX_EXT 0x8338 - -typedef void (GLAPIENTRY * PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERFEXTPROC) (GLenum target, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERIEXTPROC) (GLenum target, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); - -#define glGetPixelTransformParameterfvEXT GLEW_GET_FUN(__glewGetPixelTransformParameterfvEXT) -#define glGetPixelTransformParameterivEXT GLEW_GET_FUN(__glewGetPixelTransformParameterivEXT) -#define glPixelTransformParameterfEXT GLEW_GET_FUN(__glewPixelTransformParameterfEXT) -#define glPixelTransformParameterfvEXT GLEW_GET_FUN(__glewPixelTransformParameterfvEXT) -#define glPixelTransformParameteriEXT GLEW_GET_FUN(__glewPixelTransformParameteriEXT) -#define glPixelTransformParameterivEXT GLEW_GET_FUN(__glewPixelTransformParameterivEXT) - -#define GLEW_EXT_pixel_transform GLEW_GET_VAR(__GLEW_EXT_pixel_transform) - -#endif /* GL_EXT_pixel_transform */ - -/* ------------------- GL_EXT_pixel_transform_color_table ------------------ */ - -#ifndef GL_EXT_pixel_transform_color_table -#define GL_EXT_pixel_transform_color_table 1 - -#define GLEW_EXT_pixel_transform_color_table GLEW_GET_VAR(__GLEW_EXT_pixel_transform_color_table) - -#endif /* GL_EXT_pixel_transform_color_table */ - -/* ------------------------ GL_EXT_point_parameters ------------------------ */ - -#ifndef GL_EXT_point_parameters -#define GL_EXT_point_parameters 1 - -#define GL_POINT_SIZE_MIN_EXT 0x8126 -#define GL_POINT_SIZE_MAX_EXT 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE_EXT 0x8128 -#define GL_DISTANCE_ATTENUATION_EXT 0x8129 - -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFEXTPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVEXTPROC) (GLenum pname, const GLfloat* params); - -#define glPointParameterfEXT GLEW_GET_FUN(__glewPointParameterfEXT) -#define glPointParameterfvEXT GLEW_GET_FUN(__glewPointParameterfvEXT) - -#define GLEW_EXT_point_parameters GLEW_GET_VAR(__GLEW_EXT_point_parameters) - -#endif /* GL_EXT_point_parameters */ - -/* ------------------------- GL_EXT_polygon_offset ------------------------- */ - -#ifndef GL_EXT_polygon_offset -#define GL_EXT_polygon_offset 1 - -#define GL_POLYGON_OFFSET_EXT 0x8037 -#define GL_POLYGON_OFFSET_FACTOR_EXT 0x8038 -#define GL_POLYGON_OFFSET_BIAS_EXT 0x8039 - -typedef void (GLAPIENTRY * PFNGLPOLYGONOFFSETEXTPROC) (GLfloat factor, GLfloat bias); - -#define glPolygonOffsetEXT GLEW_GET_FUN(__glewPolygonOffsetEXT) - -#define GLEW_EXT_polygon_offset GLEW_GET_VAR(__GLEW_EXT_polygon_offset) - -#endif /* GL_EXT_polygon_offset */ - -/* ------------------------ GL_EXT_provoking_vertex ------------------------ */ - -#ifndef GL_EXT_provoking_vertex -#define GL_EXT_provoking_vertex 1 - -#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION_EXT 0x8E4C -#define GL_FIRST_VERTEX_CONVENTION_EXT 0x8E4D -#define GL_LAST_VERTEX_CONVENTION_EXT 0x8E4E -#define GL_PROVOKING_VERTEX_EXT 0x8E4F - -typedef void (GLAPIENTRY * PFNGLPROVOKINGVERTEXEXTPROC) (GLenum mode); - -#define glProvokingVertexEXT GLEW_GET_FUN(__glewProvokingVertexEXT) - -#define GLEW_EXT_provoking_vertex GLEW_GET_VAR(__GLEW_EXT_provoking_vertex) - -#endif /* GL_EXT_provoking_vertex */ - -/* ------------------------- GL_EXT_rescale_normal ------------------------- */ - -#ifndef GL_EXT_rescale_normal -#define GL_EXT_rescale_normal 1 - -#define GL_RESCALE_NORMAL_EXT 0x803A - -#define GLEW_EXT_rescale_normal GLEW_GET_VAR(__GLEW_EXT_rescale_normal) - -#endif /* GL_EXT_rescale_normal */ - -/* -------------------------- GL_EXT_scene_marker -------------------------- */ - -#ifndef GL_EXT_scene_marker -#define GL_EXT_scene_marker 1 - -typedef void (GLAPIENTRY * PFNGLBEGINSCENEEXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLENDSCENEEXTPROC) (void); - -#define glBeginSceneEXT GLEW_GET_FUN(__glewBeginSceneEXT) -#define glEndSceneEXT GLEW_GET_FUN(__glewEndSceneEXT) - -#define GLEW_EXT_scene_marker GLEW_GET_VAR(__GLEW_EXT_scene_marker) - -#endif /* GL_EXT_scene_marker */ - -/* ------------------------- GL_EXT_secondary_color ------------------------ */ - -#ifndef GL_EXT_secondary_color -#define GL_EXT_secondary_color 1 - -#define GL_COLOR_SUM_EXT 0x8458 -#define GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 -#define GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A -#define GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B -#define GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C -#define GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D -#define GL_SECONDARY_COLOR_ARRAY_EXT 0x845E - -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BEXTPROC) (GLbyte red, GLbyte green, GLbyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BVEXTPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DEXTPROC) (GLdouble red, GLdouble green, GLdouble blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DVEXTPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FEXTPROC) (GLfloat red, GLfloat green, GLfloat blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FVEXTPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IEXTPROC) (GLint red, GLint green, GLint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IVEXTPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SEXTPROC) (GLshort red, GLshort green, GLshort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SVEXTPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBEXTPROC) (GLubyte red, GLubyte green, GLubyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBVEXTPROC) (const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIEXTPROC) (GLuint red, GLuint green, GLuint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIVEXTPROC) (const GLuint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USEXTPROC) (GLushort red, GLushort green, GLushort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USVEXTPROC) (const GLushort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); - -#define glSecondaryColor3bEXT GLEW_GET_FUN(__glewSecondaryColor3bEXT) -#define glSecondaryColor3bvEXT GLEW_GET_FUN(__glewSecondaryColor3bvEXT) -#define glSecondaryColor3dEXT GLEW_GET_FUN(__glewSecondaryColor3dEXT) -#define glSecondaryColor3dvEXT GLEW_GET_FUN(__glewSecondaryColor3dvEXT) -#define glSecondaryColor3fEXT GLEW_GET_FUN(__glewSecondaryColor3fEXT) -#define glSecondaryColor3fvEXT GLEW_GET_FUN(__glewSecondaryColor3fvEXT) -#define glSecondaryColor3iEXT GLEW_GET_FUN(__glewSecondaryColor3iEXT) -#define glSecondaryColor3ivEXT GLEW_GET_FUN(__glewSecondaryColor3ivEXT) -#define glSecondaryColor3sEXT GLEW_GET_FUN(__glewSecondaryColor3sEXT) -#define glSecondaryColor3svEXT GLEW_GET_FUN(__glewSecondaryColor3svEXT) -#define glSecondaryColor3ubEXT GLEW_GET_FUN(__glewSecondaryColor3ubEXT) -#define glSecondaryColor3ubvEXT GLEW_GET_FUN(__glewSecondaryColor3ubvEXT) -#define glSecondaryColor3uiEXT GLEW_GET_FUN(__glewSecondaryColor3uiEXT) -#define glSecondaryColor3uivEXT GLEW_GET_FUN(__glewSecondaryColor3uivEXT) -#define glSecondaryColor3usEXT GLEW_GET_FUN(__glewSecondaryColor3usEXT) -#define glSecondaryColor3usvEXT GLEW_GET_FUN(__glewSecondaryColor3usvEXT) -#define glSecondaryColorPointerEXT GLEW_GET_FUN(__glewSecondaryColorPointerEXT) - -#define GLEW_EXT_secondary_color GLEW_GET_VAR(__GLEW_EXT_secondary_color) - -#endif /* GL_EXT_secondary_color */ - -/* --------------------- GL_EXT_separate_shader_objects -------------------- */ - -#ifndef GL_EXT_separate_shader_objects -#define GL_EXT_separate_shader_objects 1 - -#define GL_ACTIVE_PROGRAM_EXT 0x8B8D - -typedef void (GLAPIENTRY * PFNGLACTIVEPROGRAMEXTPROC) (GLuint program); -typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROGRAMEXTPROC) (GLenum type, const char* string); -typedef void (GLAPIENTRY * PFNGLUSESHADERPROGRAMEXTPROC) (GLenum type, GLuint program); - -#define glActiveProgramEXT GLEW_GET_FUN(__glewActiveProgramEXT) -#define glCreateShaderProgramEXT GLEW_GET_FUN(__glewCreateShaderProgramEXT) -#define glUseShaderProgramEXT GLEW_GET_FUN(__glewUseShaderProgramEXT) - -#define GLEW_EXT_separate_shader_objects GLEW_GET_VAR(__GLEW_EXT_separate_shader_objects) - -#endif /* GL_EXT_separate_shader_objects */ - -/* --------------------- GL_EXT_separate_specular_color -------------------- */ - -#ifndef GL_EXT_separate_specular_color -#define GL_EXT_separate_specular_color 1 - -#define GL_LIGHT_MODEL_COLOR_CONTROL_EXT 0x81F8 -#define GL_SINGLE_COLOR_EXT 0x81F9 -#define GL_SEPARATE_SPECULAR_COLOR_EXT 0x81FA - -#define GLEW_EXT_separate_specular_color GLEW_GET_VAR(__GLEW_EXT_separate_specular_color) - -#endif /* GL_EXT_separate_specular_color */ - -/* --------------------- GL_EXT_shader_image_load_store -------------------- */ - -#ifndef GL_EXT_shader_image_load_store -#define GL_EXT_shader_image_load_store 1 - -#define GL_VERTEX_ATTRIB_ARRAY_BARRIER_BIT_EXT 0x00000001 -#define GL_ELEMENT_ARRAY_BARRIER_BIT_EXT 0x00000002 -#define GL_UNIFORM_BARRIER_BIT_EXT 0x00000004 -#define GL_TEXTURE_FETCH_BARRIER_BIT_EXT 0x00000008 -#define GL_SHADER_IMAGE_ACCESS_BARRIER_BIT_EXT 0x00000020 -#define GL_COMMAND_BARRIER_BIT_EXT 0x00000040 -#define GL_PIXEL_BUFFER_BARRIER_BIT_EXT 0x00000080 -#define GL_TEXTURE_UPDATE_BARRIER_BIT_EXT 0x00000100 -#define GL_BUFFER_UPDATE_BARRIER_BIT_EXT 0x00000200 -#define GL_FRAMEBUFFER_BARRIER_BIT_EXT 0x00000400 -#define GL_TRANSFORM_FEEDBACK_BARRIER_BIT_EXT 0x00000800 -#define GL_ATOMIC_COUNTER_BARRIER_BIT_EXT 0x00001000 -#define GL_MAX_IMAGE_UNITS_EXT 0x8F38 -#define GL_MAX_COMBINED_IMAGE_UNITS_AND_FRAGMENT_OUTPUTS_EXT 0x8F39 -#define GL_IMAGE_BINDING_NAME_EXT 0x8F3A -#define GL_IMAGE_BINDING_LEVEL_EXT 0x8F3B -#define GL_IMAGE_BINDING_LAYERED_EXT 0x8F3C -#define GL_IMAGE_BINDING_LAYER_EXT 0x8F3D -#define GL_IMAGE_BINDING_ACCESS_EXT 0x8F3E -#define GL_IMAGE_1D_EXT 0x904C -#define GL_IMAGE_2D_EXT 0x904D -#define GL_IMAGE_3D_EXT 0x904E -#define GL_IMAGE_2D_RECT_EXT 0x904F -#define GL_IMAGE_CUBE_EXT 0x9050 -#define GL_IMAGE_BUFFER_EXT 0x9051 -#define GL_IMAGE_1D_ARRAY_EXT 0x9052 -#define GL_IMAGE_2D_ARRAY_EXT 0x9053 -#define GL_IMAGE_CUBE_MAP_ARRAY_EXT 0x9054 -#define GL_IMAGE_2D_MULTISAMPLE_EXT 0x9055 -#define GL_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9056 -#define GL_INT_IMAGE_1D_EXT 0x9057 -#define GL_INT_IMAGE_2D_EXT 0x9058 -#define GL_INT_IMAGE_3D_EXT 0x9059 -#define GL_INT_IMAGE_2D_RECT_EXT 0x905A -#define GL_INT_IMAGE_CUBE_EXT 0x905B -#define GL_INT_IMAGE_BUFFER_EXT 0x905C -#define GL_INT_IMAGE_1D_ARRAY_EXT 0x905D -#define GL_INT_IMAGE_2D_ARRAY_EXT 0x905E -#define GL_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x905F -#define GL_INT_IMAGE_2D_MULTISAMPLE_EXT 0x9060 -#define GL_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9061 -#define GL_UNSIGNED_INT_IMAGE_1D_EXT 0x9062 -#define GL_UNSIGNED_INT_IMAGE_2D_EXT 0x9063 -#define GL_UNSIGNED_INT_IMAGE_3D_EXT 0x9064 -#define GL_UNSIGNED_INT_IMAGE_2D_RECT_EXT 0x9065 -#define GL_UNSIGNED_INT_IMAGE_CUBE_EXT 0x9066 -#define GL_UNSIGNED_INT_IMAGE_BUFFER_EXT 0x9067 -#define GL_UNSIGNED_INT_IMAGE_1D_ARRAY_EXT 0x9068 -#define GL_UNSIGNED_INT_IMAGE_2D_ARRAY_EXT 0x9069 -#define GL_UNSIGNED_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x906A -#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_EXT 0x906B -#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x906C -#define GL_MAX_IMAGE_SAMPLES_EXT 0x906D -#define GL_IMAGE_BINDING_FORMAT_EXT 0x906E -#define GL_ALL_BARRIER_BITS_EXT 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLBINDIMAGETEXTUREEXTPROC) (GLuint index, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLint format); -typedef void (GLAPIENTRY * PFNGLMEMORYBARRIEREXTPROC) (GLbitfield barriers); - -#define glBindImageTextureEXT GLEW_GET_FUN(__glewBindImageTextureEXT) -#define glMemoryBarrierEXT GLEW_GET_FUN(__glewMemoryBarrierEXT) - -#define GLEW_EXT_shader_image_load_store GLEW_GET_VAR(__GLEW_EXT_shader_image_load_store) - -#endif /* GL_EXT_shader_image_load_store */ - -/* -------------------------- GL_EXT_shadow_funcs -------------------------- */ - -#ifndef GL_EXT_shadow_funcs -#define GL_EXT_shadow_funcs 1 - -#define GLEW_EXT_shadow_funcs GLEW_GET_VAR(__GLEW_EXT_shadow_funcs) - -#endif /* GL_EXT_shadow_funcs */ - -/* --------------------- GL_EXT_shared_texture_palette --------------------- */ - -#ifndef GL_EXT_shared_texture_palette -#define GL_EXT_shared_texture_palette 1 - -#define GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB - -#define GLEW_EXT_shared_texture_palette GLEW_GET_VAR(__GLEW_EXT_shared_texture_palette) - -#endif /* GL_EXT_shared_texture_palette */ - -/* ------------------------ GL_EXT_stencil_clear_tag ----------------------- */ - -#ifndef GL_EXT_stencil_clear_tag -#define GL_EXT_stencil_clear_tag 1 - -#define GL_STENCIL_TAG_BITS_EXT 0x88F2 -#define GL_STENCIL_CLEAR_TAG_VALUE_EXT 0x88F3 - -#define GLEW_EXT_stencil_clear_tag GLEW_GET_VAR(__GLEW_EXT_stencil_clear_tag) - -#endif /* GL_EXT_stencil_clear_tag */ - -/* ------------------------ GL_EXT_stencil_two_side ------------------------ */ - -#ifndef GL_EXT_stencil_two_side -#define GL_EXT_stencil_two_side 1 - -#define GL_STENCIL_TEST_TWO_SIDE_EXT 0x8910 -#define GL_ACTIVE_STENCIL_FACE_EXT 0x8911 - -typedef void (GLAPIENTRY * PFNGLACTIVESTENCILFACEEXTPROC) (GLenum face); - -#define glActiveStencilFaceEXT GLEW_GET_FUN(__glewActiveStencilFaceEXT) - -#define GLEW_EXT_stencil_two_side GLEW_GET_VAR(__GLEW_EXT_stencil_two_side) - -#endif /* GL_EXT_stencil_two_side */ - -/* -------------------------- GL_EXT_stencil_wrap -------------------------- */ - -#ifndef GL_EXT_stencil_wrap -#define GL_EXT_stencil_wrap 1 - -#define GL_INCR_WRAP_EXT 0x8507 -#define GL_DECR_WRAP_EXT 0x8508 - -#define GLEW_EXT_stencil_wrap GLEW_GET_VAR(__GLEW_EXT_stencil_wrap) - -#endif /* GL_EXT_stencil_wrap */ - -/* --------------------------- GL_EXT_subtexture --------------------------- */ - -#ifndef GL_EXT_subtexture -#define GL_EXT_subtexture 1 - -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void* pixels); - -#define glTexSubImage1DEXT GLEW_GET_FUN(__glewTexSubImage1DEXT) -#define glTexSubImage2DEXT GLEW_GET_FUN(__glewTexSubImage2DEXT) -#define glTexSubImage3DEXT GLEW_GET_FUN(__glewTexSubImage3DEXT) - -#define GLEW_EXT_subtexture GLEW_GET_VAR(__GLEW_EXT_subtexture) - -#endif /* GL_EXT_subtexture */ - -/* ----------------------------- GL_EXT_texture ---------------------------- */ - -#ifndef GL_EXT_texture -#define GL_EXT_texture 1 - -#define GL_ALPHA4_EXT 0x803B -#define GL_ALPHA8_EXT 0x803C -#define GL_ALPHA12_EXT 0x803D -#define GL_ALPHA16_EXT 0x803E -#define GL_LUMINANCE4_EXT 0x803F -#define GL_LUMINANCE8_EXT 0x8040 -#define GL_LUMINANCE12_EXT 0x8041 -#define GL_LUMINANCE16_EXT 0x8042 -#define GL_LUMINANCE4_ALPHA4_EXT 0x8043 -#define GL_LUMINANCE6_ALPHA2_EXT 0x8044 -#define GL_LUMINANCE8_ALPHA8_EXT 0x8045 -#define GL_LUMINANCE12_ALPHA4_EXT 0x8046 -#define GL_LUMINANCE12_ALPHA12_EXT 0x8047 -#define GL_LUMINANCE16_ALPHA16_EXT 0x8048 -#define GL_INTENSITY_EXT 0x8049 -#define GL_INTENSITY4_EXT 0x804A -#define GL_INTENSITY8_EXT 0x804B -#define GL_INTENSITY12_EXT 0x804C -#define GL_INTENSITY16_EXT 0x804D -#define GL_RGB2_EXT 0x804E -#define GL_RGB4_EXT 0x804F -#define GL_RGB5_EXT 0x8050 -#define GL_RGB8_EXT 0x8051 -#define GL_RGB10_EXT 0x8052 -#define GL_RGB12_EXT 0x8053 -#define GL_RGB16_EXT 0x8054 -#define GL_RGBA2_EXT 0x8055 -#define GL_RGBA4_EXT 0x8056 -#define GL_RGB5_A1_EXT 0x8057 -#define GL_RGBA8_EXT 0x8058 -#define GL_RGB10_A2_EXT 0x8059 -#define GL_RGBA12_EXT 0x805A -#define GL_RGBA16_EXT 0x805B -#define GL_TEXTURE_RED_SIZE_EXT 0x805C -#define GL_TEXTURE_GREEN_SIZE_EXT 0x805D -#define GL_TEXTURE_BLUE_SIZE_EXT 0x805E -#define GL_TEXTURE_ALPHA_SIZE_EXT 0x805F -#define GL_TEXTURE_LUMINANCE_SIZE_EXT 0x8060 -#define GL_TEXTURE_INTENSITY_SIZE_EXT 0x8061 -#define GL_REPLACE_EXT 0x8062 -#define GL_PROXY_TEXTURE_1D_EXT 0x8063 -#define GL_PROXY_TEXTURE_2D_EXT 0x8064 - -#define GLEW_EXT_texture GLEW_GET_VAR(__GLEW_EXT_texture) - -#endif /* GL_EXT_texture */ - -/* ---------------------------- GL_EXT_texture3D --------------------------- */ - -#ifndef GL_EXT_texture3D -#define GL_EXT_texture3D 1 - -#define GL_PACK_SKIP_IMAGES_EXT 0x806B -#define GL_PACK_IMAGE_HEIGHT_EXT 0x806C -#define GL_UNPACK_SKIP_IMAGES_EXT 0x806D -#define GL_UNPACK_IMAGE_HEIGHT_EXT 0x806E -#define GL_TEXTURE_3D_EXT 0x806F -#define GL_PROXY_TEXTURE_3D_EXT 0x8070 -#define GL_TEXTURE_DEPTH_EXT 0x8071 -#define GL_TEXTURE_WRAP_R_EXT 0x8072 -#define GL_MAX_3D_TEXTURE_SIZE_EXT 0x8073 - -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void* pixels); - -#define glTexImage3DEXT GLEW_GET_FUN(__glewTexImage3DEXT) - -#define GLEW_EXT_texture3D GLEW_GET_VAR(__GLEW_EXT_texture3D) - -#endif /* GL_EXT_texture3D */ - -/* -------------------------- GL_EXT_texture_array ------------------------- */ - -#ifndef GL_EXT_texture_array -#define GL_EXT_texture_array 1 - -#define GL_COMPARE_REF_DEPTH_TO_TEXTURE_EXT 0x884E -#define GL_MAX_ARRAY_TEXTURE_LAYERS_EXT 0x88FF -#define GL_TEXTURE_1D_ARRAY_EXT 0x8C18 -#define GL_PROXY_TEXTURE_1D_ARRAY_EXT 0x8C19 -#define GL_TEXTURE_2D_ARRAY_EXT 0x8C1A -#define GL_PROXY_TEXTURE_2D_ARRAY_EXT 0x8C1B -#define GL_TEXTURE_BINDING_1D_ARRAY_EXT 0x8C1C -#define GL_TEXTURE_BINDING_2D_ARRAY_EXT 0x8C1D - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); - -#define glFramebufferTextureLayerEXT GLEW_GET_FUN(__glewFramebufferTextureLayerEXT) - -#define GLEW_EXT_texture_array GLEW_GET_VAR(__GLEW_EXT_texture_array) - -#endif /* GL_EXT_texture_array */ - -/* ---------------------- GL_EXT_texture_buffer_object --------------------- */ - -#ifndef GL_EXT_texture_buffer_object -#define GL_EXT_texture_buffer_object 1 - -#define GL_TEXTURE_BUFFER_EXT 0x8C2A -#define GL_MAX_TEXTURE_BUFFER_SIZE_EXT 0x8C2B -#define GL_TEXTURE_BINDING_BUFFER_EXT 0x8C2C -#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING_EXT 0x8C2D -#define GL_TEXTURE_BUFFER_FORMAT_EXT 0x8C2E - -typedef void (GLAPIENTRY * PFNGLTEXBUFFEREXTPROC) (GLenum target, GLenum internalformat, GLuint buffer); - -#define glTexBufferEXT GLEW_GET_FUN(__glewTexBufferEXT) - -#define GLEW_EXT_texture_buffer_object GLEW_GET_VAR(__GLEW_EXT_texture_buffer_object) - -#endif /* GL_EXT_texture_buffer_object */ - -/* -------------------- GL_EXT_texture_compression_dxt1 -------------------- */ - -#ifndef GL_EXT_texture_compression_dxt1 -#define GL_EXT_texture_compression_dxt1 1 - -#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 - -#define GLEW_EXT_texture_compression_dxt1 GLEW_GET_VAR(__GLEW_EXT_texture_compression_dxt1) - -#endif /* GL_EXT_texture_compression_dxt1 */ - -/* -------------------- GL_EXT_texture_compression_latc -------------------- */ - -#ifndef GL_EXT_texture_compression_latc -#define GL_EXT_texture_compression_latc 1 - -#define GL_COMPRESSED_LUMINANCE_LATC1_EXT 0x8C70 -#define GL_COMPRESSED_SIGNED_LUMINANCE_LATC1_EXT 0x8C71 -#define GL_COMPRESSED_LUMINANCE_ALPHA_LATC2_EXT 0x8C72 -#define GL_COMPRESSED_SIGNED_LUMINANCE_ALPHA_LATC2_EXT 0x8C73 - -#define GLEW_EXT_texture_compression_latc GLEW_GET_VAR(__GLEW_EXT_texture_compression_latc) - -#endif /* GL_EXT_texture_compression_latc */ - -/* -------------------- GL_EXT_texture_compression_rgtc -------------------- */ - -#ifndef GL_EXT_texture_compression_rgtc -#define GL_EXT_texture_compression_rgtc 1 - -#define GL_COMPRESSED_RED_RGTC1_EXT 0x8DBB -#define GL_COMPRESSED_SIGNED_RED_RGTC1_EXT 0x8DBC -#define GL_COMPRESSED_RED_GREEN_RGTC2_EXT 0x8DBD -#define GL_COMPRESSED_SIGNED_RED_GREEN_RGTC2_EXT 0x8DBE - -#define GLEW_EXT_texture_compression_rgtc GLEW_GET_VAR(__GLEW_EXT_texture_compression_rgtc) - -#endif /* GL_EXT_texture_compression_rgtc */ - -/* -------------------- GL_EXT_texture_compression_s3tc -------------------- */ - -#ifndef GL_EXT_texture_compression_s3tc -#define GL_EXT_texture_compression_s3tc 1 - -#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 -#define GL_COMPRESSED_RGBA_S3TC_DXT3_EXT 0x83F2 -#define GL_COMPRESSED_RGBA_S3TC_DXT5_EXT 0x83F3 - -#define GLEW_EXT_texture_compression_s3tc GLEW_GET_VAR(__GLEW_EXT_texture_compression_s3tc) - -#endif /* GL_EXT_texture_compression_s3tc */ - -/* ------------------------ GL_EXT_texture_cube_map ------------------------ */ - -#ifndef GL_EXT_texture_cube_map -#define GL_EXT_texture_cube_map 1 - -#define GL_NORMAL_MAP_EXT 0x8511 -#define GL_REFLECTION_MAP_EXT 0x8512 -#define GL_TEXTURE_CUBE_MAP_EXT 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C - -#define GLEW_EXT_texture_cube_map GLEW_GET_VAR(__GLEW_EXT_texture_cube_map) - -#endif /* GL_EXT_texture_cube_map */ - -/* ----------------------- GL_EXT_texture_edge_clamp ----------------------- */ - -#ifndef GL_EXT_texture_edge_clamp -#define GL_EXT_texture_edge_clamp 1 - -#define GL_CLAMP_TO_EDGE_EXT 0x812F - -#define GLEW_EXT_texture_edge_clamp GLEW_GET_VAR(__GLEW_EXT_texture_edge_clamp) - -#endif /* GL_EXT_texture_edge_clamp */ - -/* --------------------------- GL_EXT_texture_env -------------------------- */ - -#ifndef GL_EXT_texture_env -#define GL_EXT_texture_env 1 - -#define GL_TEXTURE_ENV0_EXT 0 -#define GL_ENV_BLEND_EXT 0 -#define GL_TEXTURE_ENV_SHIFT_EXT 0 -#define GL_ENV_REPLACE_EXT 0 -#define GL_ENV_ADD_EXT 0 -#define GL_ENV_SUBTRACT_EXT 0 -#define GL_TEXTURE_ENV_MODE_ALPHA_EXT 0 -#define GL_ENV_REVERSE_SUBTRACT_EXT 0 -#define GL_ENV_REVERSE_BLEND_EXT 0 -#define GL_ENV_COPY_EXT 0 -#define GL_ENV_MODULATE_EXT 0 - -#define GLEW_EXT_texture_env GLEW_GET_VAR(__GLEW_EXT_texture_env) - -#endif /* GL_EXT_texture_env */ - -/* ------------------------- GL_EXT_texture_env_add ------------------------ */ - -#ifndef GL_EXT_texture_env_add -#define GL_EXT_texture_env_add 1 - -#define GLEW_EXT_texture_env_add GLEW_GET_VAR(__GLEW_EXT_texture_env_add) - -#endif /* GL_EXT_texture_env_add */ - -/* ----------------------- GL_EXT_texture_env_combine ---------------------- */ - -#ifndef GL_EXT_texture_env_combine -#define GL_EXT_texture_env_combine 1 - -#define GL_COMBINE_EXT 0x8570 -#define GL_COMBINE_RGB_EXT 0x8571 -#define GL_COMBINE_ALPHA_EXT 0x8572 -#define GL_RGB_SCALE_EXT 0x8573 -#define GL_ADD_SIGNED_EXT 0x8574 -#define GL_INTERPOLATE_EXT 0x8575 -#define GL_CONSTANT_EXT 0x8576 -#define GL_PRIMARY_COLOR_EXT 0x8577 -#define GL_PREVIOUS_EXT 0x8578 -#define GL_SOURCE0_RGB_EXT 0x8580 -#define GL_SOURCE1_RGB_EXT 0x8581 -#define GL_SOURCE2_RGB_EXT 0x8582 -#define GL_SOURCE0_ALPHA_EXT 0x8588 -#define GL_SOURCE1_ALPHA_EXT 0x8589 -#define GL_SOURCE2_ALPHA_EXT 0x858A -#define GL_OPERAND0_RGB_EXT 0x8590 -#define GL_OPERAND1_RGB_EXT 0x8591 -#define GL_OPERAND2_RGB_EXT 0x8592 -#define GL_OPERAND0_ALPHA_EXT 0x8598 -#define GL_OPERAND1_ALPHA_EXT 0x8599 -#define GL_OPERAND2_ALPHA_EXT 0x859A - -#define GLEW_EXT_texture_env_combine GLEW_GET_VAR(__GLEW_EXT_texture_env_combine) - -#endif /* GL_EXT_texture_env_combine */ - -/* ------------------------ GL_EXT_texture_env_dot3 ------------------------ */ - -#ifndef GL_EXT_texture_env_dot3 -#define GL_EXT_texture_env_dot3 1 - -#define GL_DOT3_RGB_EXT 0x8740 -#define GL_DOT3_RGBA_EXT 0x8741 - -#define GLEW_EXT_texture_env_dot3 GLEW_GET_VAR(__GLEW_EXT_texture_env_dot3) - -#endif /* GL_EXT_texture_env_dot3 */ - -/* ------------------- GL_EXT_texture_filter_anisotropic ------------------- */ - -#ifndef GL_EXT_texture_filter_anisotropic -#define GL_EXT_texture_filter_anisotropic 1 - -#define GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE -#define GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF - -#define GLEW_EXT_texture_filter_anisotropic GLEW_GET_VAR(__GLEW_EXT_texture_filter_anisotropic) - -#endif /* GL_EXT_texture_filter_anisotropic */ - -/* ------------------------- GL_EXT_texture_integer ------------------------ */ - -#ifndef GL_EXT_texture_integer -#define GL_EXT_texture_integer 1 - -#define GL_RGBA32UI_EXT 0x8D70 -#define GL_RGB32UI_EXT 0x8D71 -#define GL_ALPHA32UI_EXT 0x8D72 -#define GL_INTENSITY32UI_EXT 0x8D73 -#define GL_LUMINANCE32UI_EXT 0x8D74 -#define GL_LUMINANCE_ALPHA32UI_EXT 0x8D75 -#define GL_RGBA16UI_EXT 0x8D76 -#define GL_RGB16UI_EXT 0x8D77 -#define GL_ALPHA16UI_EXT 0x8D78 -#define GL_INTENSITY16UI_EXT 0x8D79 -#define GL_LUMINANCE16UI_EXT 0x8D7A -#define GL_LUMINANCE_ALPHA16UI_EXT 0x8D7B -#define GL_RGBA8UI_EXT 0x8D7C -#define GL_RGB8UI_EXT 0x8D7D -#define GL_ALPHA8UI_EXT 0x8D7E -#define GL_INTENSITY8UI_EXT 0x8D7F -#define GL_LUMINANCE8UI_EXT 0x8D80 -#define GL_LUMINANCE_ALPHA8UI_EXT 0x8D81 -#define GL_RGBA32I_EXT 0x8D82 -#define GL_RGB32I_EXT 0x8D83 -#define GL_ALPHA32I_EXT 0x8D84 -#define GL_INTENSITY32I_EXT 0x8D85 -#define GL_LUMINANCE32I_EXT 0x8D86 -#define GL_LUMINANCE_ALPHA32I_EXT 0x8D87 -#define GL_RGBA16I_EXT 0x8D88 -#define GL_RGB16I_EXT 0x8D89 -#define GL_ALPHA16I_EXT 0x8D8A -#define GL_INTENSITY16I_EXT 0x8D8B -#define GL_LUMINANCE16I_EXT 0x8D8C -#define GL_LUMINANCE_ALPHA16I_EXT 0x8D8D -#define GL_RGBA8I_EXT 0x8D8E -#define GL_RGB8I_EXT 0x8D8F -#define GL_ALPHA8I_EXT 0x8D90 -#define GL_INTENSITY8I_EXT 0x8D91 -#define GL_LUMINANCE8I_EXT 0x8D92 -#define GL_LUMINANCE_ALPHA8I_EXT 0x8D93 -#define GL_RED_INTEGER_EXT 0x8D94 -#define GL_GREEN_INTEGER_EXT 0x8D95 -#define GL_BLUE_INTEGER_EXT 0x8D96 -#define GL_ALPHA_INTEGER_EXT 0x8D97 -#define GL_RGB_INTEGER_EXT 0x8D98 -#define GL_RGBA_INTEGER_EXT 0x8D99 -#define GL_BGR_INTEGER_EXT 0x8D9A -#define GL_BGRA_INTEGER_EXT 0x8D9B -#define GL_LUMINANCE_INTEGER_EXT 0x8D9C -#define GL_LUMINANCE_ALPHA_INTEGER_EXT 0x8D9D -#define GL_RGBA_INTEGER_MODE_EXT 0x8D9E - -typedef void (GLAPIENTRY * PFNGLCLEARCOLORIIEXTPROC) (GLint red, GLint green, GLint blue, GLint alpha); -typedef void (GLAPIENTRY * PFNGLCLEARCOLORIUIEXTPROC) (GLuint red, GLuint green, GLuint blue, GLuint alpha); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, GLuint *params); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, const GLuint *params); - -#define glClearColorIiEXT GLEW_GET_FUN(__glewClearColorIiEXT) -#define glClearColorIuiEXT GLEW_GET_FUN(__glewClearColorIuiEXT) -#define glGetTexParameterIivEXT GLEW_GET_FUN(__glewGetTexParameterIivEXT) -#define glGetTexParameterIuivEXT GLEW_GET_FUN(__glewGetTexParameterIuivEXT) -#define glTexParameterIivEXT GLEW_GET_FUN(__glewTexParameterIivEXT) -#define glTexParameterIuivEXT GLEW_GET_FUN(__glewTexParameterIuivEXT) - -#define GLEW_EXT_texture_integer GLEW_GET_VAR(__GLEW_EXT_texture_integer) - -#endif /* GL_EXT_texture_integer */ - -/* ------------------------ GL_EXT_texture_lod_bias ------------------------ */ - -#ifndef GL_EXT_texture_lod_bias -#define GL_EXT_texture_lod_bias 1 - -#define GL_MAX_TEXTURE_LOD_BIAS_EXT 0x84FD -#define GL_TEXTURE_FILTER_CONTROL_EXT 0x8500 -#define GL_TEXTURE_LOD_BIAS_EXT 0x8501 - -#define GLEW_EXT_texture_lod_bias GLEW_GET_VAR(__GLEW_EXT_texture_lod_bias) - -#endif /* GL_EXT_texture_lod_bias */ - -/* ---------------------- GL_EXT_texture_mirror_clamp ---------------------- */ - -#ifndef GL_EXT_texture_mirror_clamp -#define GL_EXT_texture_mirror_clamp 1 - -#define GL_MIRROR_CLAMP_EXT 0x8742 -#define GL_MIRROR_CLAMP_TO_EDGE_EXT 0x8743 -#define GL_MIRROR_CLAMP_TO_BORDER_EXT 0x8912 - -#define GLEW_EXT_texture_mirror_clamp GLEW_GET_VAR(__GLEW_EXT_texture_mirror_clamp) - -#endif /* GL_EXT_texture_mirror_clamp */ - -/* ------------------------- GL_EXT_texture_object ------------------------- */ - -#ifndef GL_EXT_texture_object -#define GL_EXT_texture_object 1 - -#define GL_TEXTURE_PRIORITY_EXT 0x8066 -#define GL_TEXTURE_RESIDENT_EXT 0x8067 -#define GL_TEXTURE_1D_BINDING_EXT 0x8068 -#define GL_TEXTURE_2D_BINDING_EXT 0x8069 -#define GL_TEXTURE_3D_BINDING_EXT 0x806A - -typedef GLboolean (GLAPIENTRY * PFNGLARETEXTURESRESIDENTEXTPROC) (GLsizei n, const GLuint* textures, GLboolean* residences); -typedef void (GLAPIENTRY * PFNGLBINDTEXTUREEXTPROC) (GLenum target, GLuint texture); -typedef void (GLAPIENTRY * PFNGLDELETETEXTURESEXTPROC) (GLsizei n, const GLuint* textures); -typedef void (GLAPIENTRY * PFNGLGENTEXTURESEXTPROC) (GLsizei n, GLuint* textures); -typedef GLboolean (GLAPIENTRY * PFNGLISTEXTUREEXTPROC) (GLuint texture); -typedef void (GLAPIENTRY * PFNGLPRIORITIZETEXTURESEXTPROC) (GLsizei n, const GLuint* textures, const GLclampf* priorities); - -#define glAreTexturesResidentEXT GLEW_GET_FUN(__glewAreTexturesResidentEXT) -#define glBindTextureEXT GLEW_GET_FUN(__glewBindTextureEXT) -#define glDeleteTexturesEXT GLEW_GET_FUN(__glewDeleteTexturesEXT) -#define glGenTexturesEXT GLEW_GET_FUN(__glewGenTexturesEXT) -#define glIsTextureEXT GLEW_GET_FUN(__glewIsTextureEXT) -#define glPrioritizeTexturesEXT GLEW_GET_FUN(__glewPrioritizeTexturesEXT) - -#define GLEW_EXT_texture_object GLEW_GET_VAR(__GLEW_EXT_texture_object) - -#endif /* GL_EXT_texture_object */ - -/* --------------------- GL_EXT_texture_perturb_normal --------------------- */ - -#ifndef GL_EXT_texture_perturb_normal -#define GL_EXT_texture_perturb_normal 1 - -#define GL_PERTURB_EXT 0x85AE -#define GL_TEXTURE_NORMAL_EXT 0x85AF - -typedef void (GLAPIENTRY * PFNGLTEXTURENORMALEXTPROC) (GLenum mode); - -#define glTextureNormalEXT GLEW_GET_FUN(__glewTextureNormalEXT) - -#define GLEW_EXT_texture_perturb_normal GLEW_GET_VAR(__GLEW_EXT_texture_perturb_normal) - -#endif /* GL_EXT_texture_perturb_normal */ - -/* ------------------------ GL_EXT_texture_rectangle ----------------------- */ - -#ifndef GL_EXT_texture_rectangle -#define GL_EXT_texture_rectangle 1 - -#define GL_TEXTURE_RECTANGLE_EXT 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_EXT 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_EXT 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_EXT 0x84F8 - -#define GLEW_EXT_texture_rectangle GLEW_GET_VAR(__GLEW_EXT_texture_rectangle) - -#endif /* GL_EXT_texture_rectangle */ - -/* -------------------------- GL_EXT_texture_sRGB -------------------------- */ - -#ifndef GL_EXT_texture_sRGB -#define GL_EXT_texture_sRGB 1 - -#define GL_SRGB_EXT 0x8C40 -#define GL_SRGB8_EXT 0x8C41 -#define GL_SRGB_ALPHA_EXT 0x8C42 -#define GL_SRGB8_ALPHA8_EXT 0x8C43 -#define GL_SLUMINANCE_ALPHA_EXT 0x8C44 -#define GL_SLUMINANCE8_ALPHA8_EXT 0x8C45 -#define GL_SLUMINANCE_EXT 0x8C46 -#define GL_SLUMINANCE8_EXT 0x8C47 -#define GL_COMPRESSED_SRGB_EXT 0x8C48 -#define GL_COMPRESSED_SRGB_ALPHA_EXT 0x8C49 -#define GL_COMPRESSED_SLUMINANCE_EXT 0x8C4A -#define GL_COMPRESSED_SLUMINANCE_ALPHA_EXT 0x8C4B -#define GL_COMPRESSED_SRGB_S3TC_DXT1_EXT 0x8C4C -#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT 0x8C4D -#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT 0x8C4E -#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT 0x8C4F - -#define GLEW_EXT_texture_sRGB GLEW_GET_VAR(__GLEW_EXT_texture_sRGB) - -#endif /* GL_EXT_texture_sRGB */ - -/* ----------------------- GL_EXT_texture_sRGB_decode ---------------------- */ - -#ifndef GL_EXT_texture_sRGB_decode -#define GL_EXT_texture_sRGB_decode 1 - -#define GL_TEXTURE_SRGB_DECODE_EXT 0x8A48 -#define GL_DECODE_EXT 0x8A49 -#define GL_SKIP_DECODE_EXT 0x8A4A - -#define GLEW_EXT_texture_sRGB_decode GLEW_GET_VAR(__GLEW_EXT_texture_sRGB_decode) - -#endif /* GL_EXT_texture_sRGB_decode */ - -/* --------------------- GL_EXT_texture_shared_exponent -------------------- */ - -#ifndef GL_EXT_texture_shared_exponent -#define GL_EXT_texture_shared_exponent 1 - -#define GL_RGB9_E5_EXT 0x8C3D -#define GL_UNSIGNED_INT_5_9_9_9_REV_EXT 0x8C3E -#define GL_TEXTURE_SHARED_SIZE_EXT 0x8C3F - -#define GLEW_EXT_texture_shared_exponent GLEW_GET_VAR(__GLEW_EXT_texture_shared_exponent) - -#endif /* GL_EXT_texture_shared_exponent */ - -/* -------------------------- GL_EXT_texture_snorm ------------------------- */ - -#ifndef GL_EXT_texture_snorm -#define GL_EXT_texture_snorm 1 - -#define GL_RED_SNORM 0x8F90 -#define GL_RG_SNORM 0x8F91 -#define GL_RGB_SNORM 0x8F92 -#define GL_RGBA_SNORM 0x8F93 -#define GL_R8_SNORM 0x8F94 -#define GL_RG8_SNORM 0x8F95 -#define GL_RGB8_SNORM 0x8F96 -#define GL_RGBA8_SNORM 0x8F97 -#define GL_R16_SNORM 0x8F98 -#define GL_RG16_SNORM 0x8F99 -#define GL_RGB16_SNORM 0x8F9A -#define GL_RGBA16_SNORM 0x8F9B -#define GL_SIGNED_NORMALIZED 0x8F9C -#define GL_ALPHA_SNORM 0x9010 -#define GL_LUMINANCE_SNORM 0x9011 -#define GL_LUMINANCE_ALPHA_SNORM 0x9012 -#define GL_INTENSITY_SNORM 0x9013 -#define GL_ALPHA8_SNORM 0x9014 -#define GL_LUMINANCE8_SNORM 0x9015 -#define GL_LUMINANCE8_ALPHA8_SNORM 0x9016 -#define GL_INTENSITY8_SNORM 0x9017 -#define GL_ALPHA16_SNORM 0x9018 -#define GL_LUMINANCE16_SNORM 0x9019 -#define GL_LUMINANCE16_ALPHA16_SNORM 0x901A -#define GL_INTENSITY16_SNORM 0x901B - -#define GLEW_EXT_texture_snorm GLEW_GET_VAR(__GLEW_EXT_texture_snorm) - -#endif /* GL_EXT_texture_snorm */ - -/* ------------------------- GL_EXT_texture_swizzle ------------------------ */ - -#ifndef GL_EXT_texture_swizzle -#define GL_EXT_texture_swizzle 1 - -#define GL_TEXTURE_SWIZZLE_R_EXT 0x8E42 -#define GL_TEXTURE_SWIZZLE_G_EXT 0x8E43 -#define GL_TEXTURE_SWIZZLE_B_EXT 0x8E44 -#define GL_TEXTURE_SWIZZLE_A_EXT 0x8E45 -#define GL_TEXTURE_SWIZZLE_RGBA_EXT 0x8E46 - -#define GLEW_EXT_texture_swizzle GLEW_GET_VAR(__GLEW_EXT_texture_swizzle) - -#endif /* GL_EXT_texture_swizzle */ - -/* --------------------------- GL_EXT_timer_query -------------------------- */ - -#ifndef GL_EXT_timer_query -#define GL_EXT_timer_query 1 - -#define GL_TIME_ELAPSED_EXT 0x88BF - -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VEXTPROC) (GLuint id, GLenum pname, GLint64EXT *params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VEXTPROC) (GLuint id, GLenum pname, GLuint64EXT *params); - -#define glGetQueryObjecti64vEXT GLEW_GET_FUN(__glewGetQueryObjecti64vEXT) -#define glGetQueryObjectui64vEXT GLEW_GET_FUN(__glewGetQueryObjectui64vEXT) - -#define GLEW_EXT_timer_query GLEW_GET_VAR(__GLEW_EXT_timer_query) - -#endif /* GL_EXT_timer_query */ - -/* ----------------------- GL_EXT_transform_feedback ----------------------- */ - -#ifndef GL_EXT_transform_feedback -#define GL_EXT_transform_feedback 1 - -#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH_EXT 0x8C76 -#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_EXT 0x8C7F -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_EXT 0x8C80 -#define GL_TRANSFORM_FEEDBACK_VARYINGS_EXT 0x8C83 -#define GL_TRANSFORM_FEEDBACK_BUFFER_START_EXT 0x8C84 -#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_EXT 0x8C85 -#define GL_PRIMITIVES_GENERATED_EXT 0x8C87 -#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_EXT 0x8C88 -#define GL_RASTERIZER_DISCARD_EXT 0x8C89 -#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_EXT 0x8C8A -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_EXT 0x8C8B -#define GL_INTERLEAVED_ATTRIBS_EXT 0x8C8C -#define GL_SEPARATE_ATTRIBS_EXT 0x8C8D -#define GL_TRANSFORM_FEEDBACK_BUFFER_EXT 0x8C8E -#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_EXT 0x8C8F - -typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKEXTPROC) (GLenum primitiveMode); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASEEXTPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBINDBUFFEROFFSETEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGEEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKEXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei* length, GLsizei *size, GLenum *type, char *name); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC) (GLuint program, GLsizei count, const char ** varyings, GLenum bufferMode); - -#define glBeginTransformFeedbackEXT GLEW_GET_FUN(__glewBeginTransformFeedbackEXT) -#define glBindBufferBaseEXT GLEW_GET_FUN(__glewBindBufferBaseEXT) -#define glBindBufferOffsetEXT GLEW_GET_FUN(__glewBindBufferOffsetEXT) -#define glBindBufferRangeEXT GLEW_GET_FUN(__glewBindBufferRangeEXT) -#define glEndTransformFeedbackEXT GLEW_GET_FUN(__glewEndTransformFeedbackEXT) -#define glGetTransformFeedbackVaryingEXT GLEW_GET_FUN(__glewGetTransformFeedbackVaryingEXT) -#define glTransformFeedbackVaryingsEXT GLEW_GET_FUN(__glewTransformFeedbackVaryingsEXT) - -#define GLEW_EXT_transform_feedback GLEW_GET_VAR(__GLEW_EXT_transform_feedback) - -#endif /* GL_EXT_transform_feedback */ - -/* -------------------------- GL_EXT_vertex_array -------------------------- */ - -#ifndef GL_EXT_vertex_array -#define GL_EXT_vertex_array 1 - -#define GL_DOUBLE_EXT 0x140A -#define GL_VERTEX_ARRAY_EXT 0x8074 -#define GL_NORMAL_ARRAY_EXT 0x8075 -#define GL_COLOR_ARRAY_EXT 0x8076 -#define GL_INDEX_ARRAY_EXT 0x8077 -#define GL_TEXTURE_COORD_ARRAY_EXT 0x8078 -#define GL_EDGE_FLAG_ARRAY_EXT 0x8079 -#define GL_VERTEX_ARRAY_SIZE_EXT 0x807A -#define GL_VERTEX_ARRAY_TYPE_EXT 0x807B -#define GL_VERTEX_ARRAY_STRIDE_EXT 0x807C -#define GL_VERTEX_ARRAY_COUNT_EXT 0x807D -#define GL_NORMAL_ARRAY_TYPE_EXT 0x807E -#define GL_NORMAL_ARRAY_STRIDE_EXT 0x807F -#define GL_NORMAL_ARRAY_COUNT_EXT 0x8080 -#define GL_COLOR_ARRAY_SIZE_EXT 0x8081 -#define GL_COLOR_ARRAY_TYPE_EXT 0x8082 -#define GL_COLOR_ARRAY_STRIDE_EXT 0x8083 -#define GL_COLOR_ARRAY_COUNT_EXT 0x8084 -#define GL_INDEX_ARRAY_TYPE_EXT 0x8085 -#define GL_INDEX_ARRAY_STRIDE_EXT 0x8086 -#define GL_INDEX_ARRAY_COUNT_EXT 0x8087 -#define GL_TEXTURE_COORD_ARRAY_SIZE_EXT 0x8088 -#define GL_TEXTURE_COORD_ARRAY_TYPE_EXT 0x8089 -#define GL_TEXTURE_COORD_ARRAY_STRIDE_EXT 0x808A -#define GL_TEXTURE_COORD_ARRAY_COUNT_EXT 0x808B -#define GL_EDGE_FLAG_ARRAY_STRIDE_EXT 0x808C -#define GL_EDGE_FLAG_ARRAY_COUNT_EXT 0x808D -#define GL_VERTEX_ARRAY_POINTER_EXT 0x808E -#define GL_NORMAL_ARRAY_POINTER_EXT 0x808F -#define GL_COLOR_ARRAY_POINTER_EXT 0x8090 -#define GL_INDEX_ARRAY_POINTER_EXT 0x8091 -#define GL_TEXTURE_COORD_ARRAY_POINTER_EXT 0x8092 -#define GL_EDGE_FLAG_ARRAY_POINTER_EXT 0x8093 - -typedef void (GLAPIENTRY * PFNGLARRAYELEMENTEXTPROC) (GLint i); -typedef void (GLAPIENTRY * PFNGLCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer); -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSEXTPROC) (GLenum mode, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTEREXTPROC) (GLsizei stride, GLsizei count, const GLboolean* pointer); -typedef void (GLAPIENTRY * PFNGLINDEXPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const void* pointer); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const void* pointer); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void* pointer); - -#define glArrayElementEXT GLEW_GET_FUN(__glewArrayElementEXT) -#define glColorPointerEXT GLEW_GET_FUN(__glewColorPointerEXT) -#define glDrawArraysEXT GLEW_GET_FUN(__glewDrawArraysEXT) -#define glEdgeFlagPointerEXT GLEW_GET_FUN(__glewEdgeFlagPointerEXT) -#define glIndexPointerEXT GLEW_GET_FUN(__glewIndexPointerEXT) -#define glNormalPointerEXT GLEW_GET_FUN(__glewNormalPointerEXT) -#define glTexCoordPointerEXT GLEW_GET_FUN(__glewTexCoordPointerEXT) -#define glVertexPointerEXT GLEW_GET_FUN(__glewVertexPointerEXT) - -#define GLEW_EXT_vertex_array GLEW_GET_VAR(__GLEW_EXT_vertex_array) - -#endif /* GL_EXT_vertex_array */ - -/* ------------------------ GL_EXT_vertex_array_bgra ----------------------- */ - -#ifndef GL_EXT_vertex_array_bgra -#define GL_EXT_vertex_array_bgra 1 - -#define GL_BGRA 0x80E1 - -#define GLEW_EXT_vertex_array_bgra GLEW_GET_VAR(__GLEW_EXT_vertex_array_bgra) - -#endif /* GL_EXT_vertex_array_bgra */ - -/* ----------------------- GL_EXT_vertex_attrib_64bit ---------------------- */ - -#ifndef GL_EXT_vertex_attrib_64bit -#define GL_EXT_vertex_attrib_64bit 1 - -#define GL_DOUBLE_MAT2_EXT 0x8F46 -#define GL_DOUBLE_MAT3_EXT 0x8F47 -#define GL_DOUBLE_MAT4_EXT 0x8F48 -#define GL_DOUBLE_MAT2x3_EXT 0x8F49 -#define GL_DOUBLE_MAT2x4_EXT 0x8F4A -#define GL_DOUBLE_MAT3x2_EXT 0x8F4B -#define GL_DOUBLE_MAT3x4_EXT 0x8F4C -#define GL_DOUBLE_MAT4x2_EXT 0x8F4D -#define GL_DOUBLE_MAT4x3_EXT 0x8F4E -#define GL_DOUBLE_VEC2_EXT 0x8FFC -#define GL_DOUBLE_VEC3_EXT 0x8FFD -#define GL_DOUBLE_VEC4_EXT 0x8FFE - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLDVEXTPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DEXTPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DEXTPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer); - -#define glGetVertexAttribLdvEXT GLEW_GET_FUN(__glewGetVertexAttribLdvEXT) -#define glVertexArrayVertexAttribLOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribLOffsetEXT) -#define glVertexAttribL1dEXT GLEW_GET_FUN(__glewVertexAttribL1dEXT) -#define glVertexAttribL1dvEXT GLEW_GET_FUN(__glewVertexAttribL1dvEXT) -#define glVertexAttribL2dEXT GLEW_GET_FUN(__glewVertexAttribL2dEXT) -#define glVertexAttribL2dvEXT GLEW_GET_FUN(__glewVertexAttribL2dvEXT) -#define glVertexAttribL3dEXT GLEW_GET_FUN(__glewVertexAttribL3dEXT) -#define glVertexAttribL3dvEXT GLEW_GET_FUN(__glewVertexAttribL3dvEXT) -#define glVertexAttribL4dEXT GLEW_GET_FUN(__glewVertexAttribL4dEXT) -#define glVertexAttribL4dvEXT GLEW_GET_FUN(__glewVertexAttribL4dvEXT) -#define glVertexAttribLPointerEXT GLEW_GET_FUN(__glewVertexAttribLPointerEXT) - -#define GLEW_EXT_vertex_attrib_64bit GLEW_GET_VAR(__GLEW_EXT_vertex_attrib_64bit) - -#endif /* GL_EXT_vertex_attrib_64bit */ - -/* -------------------------- GL_EXT_vertex_shader ------------------------- */ - -#ifndef GL_EXT_vertex_shader -#define GL_EXT_vertex_shader 1 - -#define GL_VERTEX_SHADER_EXT 0x8780 -#define GL_VERTEX_SHADER_BINDING_EXT 0x8781 -#define GL_OP_INDEX_EXT 0x8782 -#define GL_OP_NEGATE_EXT 0x8783 -#define GL_OP_DOT3_EXT 0x8784 -#define GL_OP_DOT4_EXT 0x8785 -#define GL_OP_MUL_EXT 0x8786 -#define GL_OP_ADD_EXT 0x8787 -#define GL_OP_MADD_EXT 0x8788 -#define GL_OP_FRAC_EXT 0x8789 -#define GL_OP_MAX_EXT 0x878A -#define GL_OP_MIN_EXT 0x878B -#define GL_OP_SET_GE_EXT 0x878C -#define GL_OP_SET_LT_EXT 0x878D -#define GL_OP_CLAMP_EXT 0x878E -#define GL_OP_FLOOR_EXT 0x878F -#define GL_OP_ROUND_EXT 0x8790 -#define GL_OP_EXP_BASE_2_EXT 0x8791 -#define GL_OP_LOG_BASE_2_EXT 0x8792 -#define GL_OP_POWER_EXT 0x8793 -#define GL_OP_RECIP_EXT 0x8794 -#define GL_OP_RECIP_SQRT_EXT 0x8795 -#define GL_OP_SUB_EXT 0x8796 -#define GL_OP_CROSS_PRODUCT_EXT 0x8797 -#define GL_OP_MULTIPLY_MATRIX_EXT 0x8798 -#define GL_OP_MOV_EXT 0x8799 -#define GL_OUTPUT_VERTEX_EXT 0x879A -#define GL_OUTPUT_COLOR0_EXT 0x879B -#define GL_OUTPUT_COLOR1_EXT 0x879C -#define GL_OUTPUT_TEXTURE_COORD0_EXT 0x879D -#define GL_OUTPUT_TEXTURE_COORD1_EXT 0x879E -#define GL_OUTPUT_TEXTURE_COORD2_EXT 0x879F -#define GL_OUTPUT_TEXTURE_COORD3_EXT 0x87A0 -#define GL_OUTPUT_TEXTURE_COORD4_EXT 0x87A1 -#define GL_OUTPUT_TEXTURE_COORD5_EXT 0x87A2 -#define GL_OUTPUT_TEXTURE_COORD6_EXT 0x87A3 -#define GL_OUTPUT_TEXTURE_COORD7_EXT 0x87A4 -#define GL_OUTPUT_TEXTURE_COORD8_EXT 0x87A5 -#define GL_OUTPUT_TEXTURE_COORD9_EXT 0x87A6 -#define GL_OUTPUT_TEXTURE_COORD10_EXT 0x87A7 -#define GL_OUTPUT_TEXTURE_COORD11_EXT 0x87A8 -#define GL_OUTPUT_TEXTURE_COORD12_EXT 0x87A9 -#define GL_OUTPUT_TEXTURE_COORD13_EXT 0x87AA -#define GL_OUTPUT_TEXTURE_COORD14_EXT 0x87AB -#define GL_OUTPUT_TEXTURE_COORD15_EXT 0x87AC -#define GL_OUTPUT_TEXTURE_COORD16_EXT 0x87AD -#define GL_OUTPUT_TEXTURE_COORD17_EXT 0x87AE -#define GL_OUTPUT_TEXTURE_COORD18_EXT 0x87AF -#define GL_OUTPUT_TEXTURE_COORD19_EXT 0x87B0 -#define GL_OUTPUT_TEXTURE_COORD20_EXT 0x87B1 -#define GL_OUTPUT_TEXTURE_COORD21_EXT 0x87B2 -#define GL_OUTPUT_TEXTURE_COORD22_EXT 0x87B3 -#define GL_OUTPUT_TEXTURE_COORD23_EXT 0x87B4 -#define GL_OUTPUT_TEXTURE_COORD24_EXT 0x87B5 -#define GL_OUTPUT_TEXTURE_COORD25_EXT 0x87B6 -#define GL_OUTPUT_TEXTURE_COORD26_EXT 0x87B7 -#define GL_OUTPUT_TEXTURE_COORD27_EXT 0x87B8 -#define GL_OUTPUT_TEXTURE_COORD28_EXT 0x87B9 -#define GL_OUTPUT_TEXTURE_COORD29_EXT 0x87BA -#define GL_OUTPUT_TEXTURE_COORD30_EXT 0x87BB -#define GL_OUTPUT_TEXTURE_COORD31_EXT 0x87BC -#define GL_OUTPUT_FOG_EXT 0x87BD -#define GL_SCALAR_EXT 0x87BE -#define GL_VECTOR_EXT 0x87BF -#define GL_MATRIX_EXT 0x87C0 -#define GL_VARIANT_EXT 0x87C1 -#define GL_INVARIANT_EXT 0x87C2 -#define GL_LOCAL_CONSTANT_EXT 0x87C3 -#define GL_LOCAL_EXT 0x87C4 -#define GL_MAX_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87C5 -#define GL_MAX_VERTEX_SHADER_VARIANTS_EXT 0x87C6 -#define GL_MAX_VERTEX_SHADER_INVARIANTS_EXT 0x87C7 -#define GL_MAX_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87C8 -#define GL_MAX_VERTEX_SHADER_LOCALS_EXT 0x87C9 -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CA -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_VARIANTS_EXT 0x87CB -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_EXT 0x87CC -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87CD -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCALS_EXT 0x87CE -#define GL_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CF -#define GL_VERTEX_SHADER_VARIANTS_EXT 0x87D0 -#define GL_VERTEX_SHADER_INVARIANTS_EXT 0x87D1 -#define GL_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87D2 -#define GL_VERTEX_SHADER_LOCALS_EXT 0x87D3 -#define GL_VERTEX_SHADER_OPTIMIZED_EXT 0x87D4 -#define GL_X_EXT 0x87D5 -#define GL_Y_EXT 0x87D6 -#define GL_Z_EXT 0x87D7 -#define GL_W_EXT 0x87D8 -#define GL_NEGATIVE_X_EXT 0x87D9 -#define GL_NEGATIVE_Y_EXT 0x87DA -#define GL_NEGATIVE_Z_EXT 0x87DB -#define GL_NEGATIVE_W_EXT 0x87DC -#define GL_ZERO_EXT 0x87DD -#define GL_ONE_EXT 0x87DE -#define GL_NEGATIVE_ONE_EXT 0x87DF -#define GL_NORMALIZED_RANGE_EXT 0x87E0 -#define GL_FULL_RANGE_EXT 0x87E1 -#define GL_CURRENT_VERTEX_EXT 0x87E2 -#define GL_MVP_MATRIX_EXT 0x87E3 -#define GL_VARIANT_VALUE_EXT 0x87E4 -#define GL_VARIANT_DATATYPE_EXT 0x87E5 -#define GL_VARIANT_ARRAY_STRIDE_EXT 0x87E6 -#define GL_VARIANT_ARRAY_TYPE_EXT 0x87E7 -#define GL_VARIANT_ARRAY_EXT 0x87E8 -#define GL_VARIANT_ARRAY_POINTER_EXT 0x87E9 -#define GL_INVARIANT_VALUE_EXT 0x87EA -#define GL_INVARIANT_DATATYPE_EXT 0x87EB -#define GL_LOCAL_CONSTANT_VALUE_EXT 0x87EC -#define GL_LOCAL_CONSTANT_DATATYPE_EXT 0x87ED - -typedef void (GLAPIENTRY * PFNGLBEGINVERTEXSHADEREXTPROC) (void); -typedef GLuint (GLAPIENTRY * PFNGLBINDLIGHTPARAMETEREXTPROC) (GLenum light, GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDMATERIALPARAMETEREXTPROC) (GLenum face, GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDPARAMETEREXTPROC) (GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDTEXGENPARAMETEREXTPROC) (GLenum unit, GLenum coord, GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDTEXTUREUNITPARAMETEREXTPROC) (GLenum unit, GLenum value); -typedef void (GLAPIENTRY * PFNGLBINDVERTEXSHADEREXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEVERTEXSHADEREXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENDVERTEXSHADEREXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLEXTRACTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); -typedef GLuint (GLAPIENTRY * PFNGLGENSYMBOLSEXTPROC) (GLenum dataType, GLenum storageType, GLenum range, GLuint components); -typedef GLuint (GLAPIENTRY * PFNGLGENVERTEXSHADERSEXTPROC) (GLuint range); -typedef void (GLAPIENTRY * PFNGLGETINVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); -typedef void (GLAPIENTRY * PFNGLGETINVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); -typedef void (GLAPIENTRY * PFNGLGETINVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); -typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); -typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); -typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTPOINTERVEXTPROC) (GLuint id, GLenum value, GLvoid **data); -typedef void (GLAPIENTRY * PFNGLINSERTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); -typedef GLboolean (GLAPIENTRY * PFNGLISVARIANTENABLEDEXTPROC) (GLuint id, GLenum cap); -typedef void (GLAPIENTRY * PFNGLSETINVARIANTEXTPROC) (GLuint id, GLenum type, GLvoid *addr); -typedef void (GLAPIENTRY * PFNGLSETLOCALCONSTANTEXTPROC) (GLuint id, GLenum type, GLvoid *addr); -typedef void (GLAPIENTRY * PFNGLSHADEROP1EXTPROC) (GLenum op, GLuint res, GLuint arg1); -typedef void (GLAPIENTRY * PFNGLSHADEROP2EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2); -typedef void (GLAPIENTRY * PFNGLSHADEROP3EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3); -typedef void (GLAPIENTRY * PFNGLSWIZZLEEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); -typedef void (GLAPIENTRY * PFNGLVARIANTPOINTEREXTPROC) (GLuint id, GLenum type, GLuint stride, GLvoid *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTBVEXTPROC) (GLuint id, GLbyte *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTDVEXTPROC) (GLuint id, GLdouble *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTFVEXTPROC) (GLuint id, GLfloat *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTIVEXTPROC) (GLuint id, GLint *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTSVEXTPROC) (GLuint id, GLshort *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTUBVEXTPROC) (GLuint id, GLubyte *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTUIVEXTPROC) (GLuint id, GLuint *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTUSVEXTPROC) (GLuint id, GLushort *addr); -typedef void (GLAPIENTRY * PFNGLWRITEMASKEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); - -#define glBeginVertexShaderEXT GLEW_GET_FUN(__glewBeginVertexShaderEXT) -#define glBindLightParameterEXT GLEW_GET_FUN(__glewBindLightParameterEXT) -#define glBindMaterialParameterEXT GLEW_GET_FUN(__glewBindMaterialParameterEXT) -#define glBindParameterEXT GLEW_GET_FUN(__glewBindParameterEXT) -#define glBindTexGenParameterEXT GLEW_GET_FUN(__glewBindTexGenParameterEXT) -#define glBindTextureUnitParameterEXT GLEW_GET_FUN(__glewBindTextureUnitParameterEXT) -#define glBindVertexShaderEXT GLEW_GET_FUN(__glewBindVertexShaderEXT) -#define glDeleteVertexShaderEXT GLEW_GET_FUN(__glewDeleteVertexShaderEXT) -#define glDisableVariantClientStateEXT GLEW_GET_FUN(__glewDisableVariantClientStateEXT) -#define glEnableVariantClientStateEXT GLEW_GET_FUN(__glewEnableVariantClientStateEXT) -#define glEndVertexShaderEXT GLEW_GET_FUN(__glewEndVertexShaderEXT) -#define glExtractComponentEXT GLEW_GET_FUN(__glewExtractComponentEXT) -#define glGenSymbolsEXT GLEW_GET_FUN(__glewGenSymbolsEXT) -#define glGenVertexShadersEXT GLEW_GET_FUN(__glewGenVertexShadersEXT) -#define glGetInvariantBooleanvEXT GLEW_GET_FUN(__glewGetInvariantBooleanvEXT) -#define glGetInvariantFloatvEXT GLEW_GET_FUN(__glewGetInvariantFloatvEXT) -#define glGetInvariantIntegervEXT GLEW_GET_FUN(__glewGetInvariantIntegervEXT) -#define glGetLocalConstantBooleanvEXT GLEW_GET_FUN(__glewGetLocalConstantBooleanvEXT) -#define glGetLocalConstantFloatvEXT GLEW_GET_FUN(__glewGetLocalConstantFloatvEXT) -#define glGetLocalConstantIntegervEXT GLEW_GET_FUN(__glewGetLocalConstantIntegervEXT) -#define glGetVariantBooleanvEXT GLEW_GET_FUN(__glewGetVariantBooleanvEXT) -#define glGetVariantFloatvEXT GLEW_GET_FUN(__glewGetVariantFloatvEXT) -#define glGetVariantIntegervEXT GLEW_GET_FUN(__glewGetVariantIntegervEXT) -#define glGetVariantPointervEXT GLEW_GET_FUN(__glewGetVariantPointervEXT) -#define glInsertComponentEXT GLEW_GET_FUN(__glewInsertComponentEXT) -#define glIsVariantEnabledEXT GLEW_GET_FUN(__glewIsVariantEnabledEXT) -#define glSetInvariantEXT GLEW_GET_FUN(__glewSetInvariantEXT) -#define glSetLocalConstantEXT GLEW_GET_FUN(__glewSetLocalConstantEXT) -#define glShaderOp1EXT GLEW_GET_FUN(__glewShaderOp1EXT) -#define glShaderOp2EXT GLEW_GET_FUN(__glewShaderOp2EXT) -#define glShaderOp3EXT GLEW_GET_FUN(__glewShaderOp3EXT) -#define glSwizzleEXT GLEW_GET_FUN(__glewSwizzleEXT) -#define glVariantPointerEXT GLEW_GET_FUN(__glewVariantPointerEXT) -#define glVariantbvEXT GLEW_GET_FUN(__glewVariantbvEXT) -#define glVariantdvEXT GLEW_GET_FUN(__glewVariantdvEXT) -#define glVariantfvEXT GLEW_GET_FUN(__glewVariantfvEXT) -#define glVariantivEXT GLEW_GET_FUN(__glewVariantivEXT) -#define glVariantsvEXT GLEW_GET_FUN(__glewVariantsvEXT) -#define glVariantubvEXT GLEW_GET_FUN(__glewVariantubvEXT) -#define glVariantuivEXT GLEW_GET_FUN(__glewVariantuivEXT) -#define glVariantusvEXT GLEW_GET_FUN(__glewVariantusvEXT) -#define glWriteMaskEXT GLEW_GET_FUN(__glewWriteMaskEXT) - -#define GLEW_EXT_vertex_shader GLEW_GET_VAR(__GLEW_EXT_vertex_shader) - -#endif /* GL_EXT_vertex_shader */ - -/* ------------------------ GL_EXT_vertex_weighting ------------------------ */ - -#ifndef GL_EXT_vertex_weighting -#define GL_EXT_vertex_weighting 1 - -#define GL_MODELVIEW0_STACK_DEPTH_EXT 0x0BA3 -#define GL_MODELVIEW0_MATRIX_EXT 0x0BA6 -#define GL_MODELVIEW0_EXT 0x1700 -#define GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 -#define GL_MODELVIEW1_MATRIX_EXT 0x8506 -#define GL_VERTEX_WEIGHTING_EXT 0x8509 -#define GL_MODELVIEW1_EXT 0x850A -#define GL_CURRENT_VERTEX_WEIGHT_EXT 0x850B -#define GL_VERTEX_WEIGHT_ARRAY_EXT 0x850C -#define GL_VERTEX_WEIGHT_ARRAY_SIZE_EXT 0x850D -#define GL_VERTEX_WEIGHT_ARRAY_TYPE_EXT 0x850E -#define GL_VERTEX_WEIGHT_ARRAY_STRIDE_EXT 0x850F -#define GL_VERTEX_WEIGHT_ARRAY_POINTER_EXT 0x8510 - -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, void* pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTFEXTPROC) (GLfloat weight); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTFVEXTPROC) (GLfloat* weight); - -#define glVertexWeightPointerEXT GLEW_GET_FUN(__glewVertexWeightPointerEXT) -#define glVertexWeightfEXT GLEW_GET_FUN(__glewVertexWeightfEXT) -#define glVertexWeightfvEXT GLEW_GET_FUN(__glewVertexWeightfvEXT) - -#define GLEW_EXT_vertex_weighting GLEW_GET_VAR(__GLEW_EXT_vertex_weighting) - -#endif /* GL_EXT_vertex_weighting */ - -/* ------------------------- GL_EXT_x11_sync_object ------------------------ */ - -#ifndef GL_EXT_x11_sync_object -#define GL_EXT_x11_sync_object 1 - -#define GL_SYNC_X11_FENCE_EXT 0x90E1 - -typedef GLsync (GLAPIENTRY * PFNGLIMPORTSYNCEXTPROC) (GLenum external_sync_type, GLintptr external_sync, GLbitfield flags); - -#define glImportSyncEXT GLEW_GET_FUN(__glewImportSyncEXT) - -#define GLEW_EXT_x11_sync_object GLEW_GET_VAR(__GLEW_EXT_x11_sync_object) - -#endif /* GL_EXT_x11_sync_object */ - -/* ---------------------- GL_GREMEDY_frame_terminator ---------------------- */ - -#ifndef GL_GREMEDY_frame_terminator -#define GL_GREMEDY_frame_terminator 1 - -typedef void (GLAPIENTRY * PFNGLFRAMETERMINATORGREMEDYPROC) (void); - -#define glFrameTerminatorGREMEDY GLEW_GET_FUN(__glewFrameTerminatorGREMEDY) - -#define GLEW_GREMEDY_frame_terminator GLEW_GET_VAR(__GLEW_GREMEDY_frame_terminator) - -#endif /* GL_GREMEDY_frame_terminator */ - -/* ------------------------ GL_GREMEDY_string_marker ----------------------- */ - -#ifndef GL_GREMEDY_string_marker -#define GL_GREMEDY_string_marker 1 - -typedef void (GLAPIENTRY * PFNGLSTRINGMARKERGREMEDYPROC) (GLsizei len, const void* string); - -#define glStringMarkerGREMEDY GLEW_GET_FUN(__glewStringMarkerGREMEDY) - -#define GLEW_GREMEDY_string_marker GLEW_GET_VAR(__GLEW_GREMEDY_string_marker) - -#endif /* GL_GREMEDY_string_marker */ - -/* --------------------- GL_HP_convolution_border_modes -------------------- */ - -#ifndef GL_HP_convolution_border_modes -#define GL_HP_convolution_border_modes 1 - -#define GLEW_HP_convolution_border_modes GLEW_GET_VAR(__GLEW_HP_convolution_border_modes) - -#endif /* GL_HP_convolution_border_modes */ - -/* ------------------------- GL_HP_image_transform ------------------------- */ - -#ifndef GL_HP_image_transform -#define GL_HP_image_transform 1 - -typedef void (GLAPIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERFHPPROC) (GLenum target, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERIHPPROC) (GLenum target, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint* params); - -#define glGetImageTransformParameterfvHP GLEW_GET_FUN(__glewGetImageTransformParameterfvHP) -#define glGetImageTransformParameterivHP GLEW_GET_FUN(__glewGetImageTransformParameterivHP) -#define glImageTransformParameterfHP GLEW_GET_FUN(__glewImageTransformParameterfHP) -#define glImageTransformParameterfvHP GLEW_GET_FUN(__glewImageTransformParameterfvHP) -#define glImageTransformParameteriHP GLEW_GET_FUN(__glewImageTransformParameteriHP) -#define glImageTransformParameterivHP GLEW_GET_FUN(__glewImageTransformParameterivHP) - -#define GLEW_HP_image_transform GLEW_GET_VAR(__GLEW_HP_image_transform) - -#endif /* GL_HP_image_transform */ - -/* -------------------------- GL_HP_occlusion_test ------------------------- */ - -#ifndef GL_HP_occlusion_test -#define GL_HP_occlusion_test 1 - -#define GL_OCCLUSION_TEST_HP 0x8165 -#define GL_OCCLUSION_TEST_RESULT_HP 0x8166 - -#define GLEW_HP_occlusion_test GLEW_GET_VAR(__GLEW_HP_occlusion_test) - -#endif /* GL_HP_occlusion_test */ - -/* ------------------------- GL_HP_texture_lighting ------------------------ */ - -#ifndef GL_HP_texture_lighting -#define GL_HP_texture_lighting 1 - -#define GLEW_HP_texture_lighting GLEW_GET_VAR(__GLEW_HP_texture_lighting) - -#endif /* GL_HP_texture_lighting */ - -/* --------------------------- GL_IBM_cull_vertex -------------------------- */ - -#ifndef GL_IBM_cull_vertex -#define GL_IBM_cull_vertex 1 - -#define GL_CULL_VERTEX_IBM 103050 - -#define GLEW_IBM_cull_vertex GLEW_GET_VAR(__GLEW_IBM_cull_vertex) - -#endif /* GL_IBM_cull_vertex */ - -/* ---------------------- GL_IBM_multimode_draw_arrays --------------------- */ - -#ifndef GL_IBM_multimode_draw_arrays -#define GL_IBM_multimode_draw_arrays 1 - -typedef void (GLAPIENTRY * PFNGLMULTIMODEDRAWARRAYSIBMPROC) (const GLenum* mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); -typedef void (GLAPIENTRY * PFNGLMULTIMODEDRAWELEMENTSIBMPROC) (const GLenum* mode, const GLsizei *count, GLenum type, const GLvoid * const *indices, GLsizei primcount, GLint modestride); - -#define glMultiModeDrawArraysIBM GLEW_GET_FUN(__glewMultiModeDrawArraysIBM) -#define glMultiModeDrawElementsIBM GLEW_GET_FUN(__glewMultiModeDrawElementsIBM) - -#define GLEW_IBM_multimode_draw_arrays GLEW_GET_VAR(__GLEW_IBM_multimode_draw_arrays) - -#endif /* GL_IBM_multimode_draw_arrays */ - -/* ------------------------- GL_IBM_rasterpos_clip ------------------------- */ - -#ifndef GL_IBM_rasterpos_clip -#define GL_IBM_rasterpos_clip 1 - -#define GL_RASTER_POSITION_UNCLIPPED_IBM 103010 - -#define GLEW_IBM_rasterpos_clip GLEW_GET_VAR(__GLEW_IBM_rasterpos_clip) - -#endif /* GL_IBM_rasterpos_clip */ - -/* --------------------------- GL_IBM_static_data -------------------------- */ - -#ifndef GL_IBM_static_data -#define GL_IBM_static_data 1 - -#define GL_ALL_STATIC_DATA_IBM 103060 -#define GL_STATIC_VERTEX_ARRAY_IBM 103061 - -#define GLEW_IBM_static_data GLEW_GET_VAR(__GLEW_IBM_static_data) - -#endif /* GL_IBM_static_data */ - -/* --------------------- GL_IBM_texture_mirrored_repeat -------------------- */ - -#ifndef GL_IBM_texture_mirrored_repeat -#define GL_IBM_texture_mirrored_repeat 1 - -#define GL_MIRRORED_REPEAT_IBM 0x8370 - -#define GLEW_IBM_texture_mirrored_repeat GLEW_GET_VAR(__GLEW_IBM_texture_mirrored_repeat) - -#endif /* GL_IBM_texture_mirrored_repeat */ - -/* ----------------------- GL_IBM_vertex_array_lists ----------------------- */ - -#ifndef GL_IBM_vertex_array_lists -#define GL_IBM_vertex_array_lists 1 - -#define GL_VERTEX_ARRAY_LIST_IBM 103070 -#define GL_NORMAL_ARRAY_LIST_IBM 103071 -#define GL_COLOR_ARRAY_LIST_IBM 103072 -#define GL_INDEX_ARRAY_LIST_IBM 103073 -#define GL_TEXTURE_COORD_ARRAY_LIST_IBM 103074 -#define GL_EDGE_FLAG_ARRAY_LIST_IBM 103075 -#define GL_FOG_COORDINATE_ARRAY_LIST_IBM 103076 -#define GL_SECONDARY_COLOR_ARRAY_LIST_IBM 103077 -#define GL_VERTEX_ARRAY_LIST_STRIDE_IBM 103080 -#define GL_NORMAL_ARRAY_LIST_STRIDE_IBM 103081 -#define GL_COLOR_ARRAY_LIST_STRIDE_IBM 103082 -#define GL_INDEX_ARRAY_LIST_STRIDE_IBM 103083 -#define GL_TEXTURE_COORD_ARRAY_LIST_STRIDE_IBM 103084 -#define GL_EDGE_FLAG_ARRAY_LIST_STRIDE_IBM 103085 -#define GL_FOG_COORDINATE_ARRAY_LIST_STRIDE_IBM 103086 -#define GL_SECONDARY_COLOR_ARRAY_LIST_STRIDE_IBM 103087 - -typedef void (GLAPIENTRY * PFNGLCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTERLISTIBMPROC) (GLint stride, const GLboolean ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLINDEXPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); - -#define glColorPointerListIBM GLEW_GET_FUN(__glewColorPointerListIBM) -#define glEdgeFlagPointerListIBM GLEW_GET_FUN(__glewEdgeFlagPointerListIBM) -#define glFogCoordPointerListIBM GLEW_GET_FUN(__glewFogCoordPointerListIBM) -#define glIndexPointerListIBM GLEW_GET_FUN(__glewIndexPointerListIBM) -#define glNormalPointerListIBM GLEW_GET_FUN(__glewNormalPointerListIBM) -#define glSecondaryColorPointerListIBM GLEW_GET_FUN(__glewSecondaryColorPointerListIBM) -#define glTexCoordPointerListIBM GLEW_GET_FUN(__glewTexCoordPointerListIBM) -#define glVertexPointerListIBM GLEW_GET_FUN(__glewVertexPointerListIBM) - -#define GLEW_IBM_vertex_array_lists GLEW_GET_VAR(__GLEW_IBM_vertex_array_lists) - -#endif /* GL_IBM_vertex_array_lists */ - -/* -------------------------- GL_INGR_color_clamp -------------------------- */ - -#ifndef GL_INGR_color_clamp -#define GL_INGR_color_clamp 1 - -#define GL_RED_MIN_CLAMP_INGR 0x8560 -#define GL_GREEN_MIN_CLAMP_INGR 0x8561 -#define GL_BLUE_MIN_CLAMP_INGR 0x8562 -#define GL_ALPHA_MIN_CLAMP_INGR 0x8563 -#define GL_RED_MAX_CLAMP_INGR 0x8564 -#define GL_GREEN_MAX_CLAMP_INGR 0x8565 -#define GL_BLUE_MAX_CLAMP_INGR 0x8566 -#define GL_ALPHA_MAX_CLAMP_INGR 0x8567 - -#define GLEW_INGR_color_clamp GLEW_GET_VAR(__GLEW_INGR_color_clamp) - -#endif /* GL_INGR_color_clamp */ - -/* ------------------------- GL_INGR_interlace_read ------------------------ */ - -#ifndef GL_INGR_interlace_read -#define GL_INGR_interlace_read 1 - -#define GL_INTERLACE_READ_INGR 0x8568 - -#define GLEW_INGR_interlace_read GLEW_GET_VAR(__GLEW_INGR_interlace_read) - -#endif /* GL_INGR_interlace_read */ - -/* ------------------------ GL_INTEL_parallel_arrays ----------------------- */ - -#ifndef GL_INTEL_parallel_arrays -#define GL_INTEL_parallel_arrays 1 - -#define GL_PARALLEL_ARRAYS_INTEL 0x83F4 -#define GL_VERTEX_ARRAY_PARALLEL_POINTERS_INTEL 0x83F5 -#define GL_NORMAL_ARRAY_PARALLEL_POINTERS_INTEL 0x83F6 -#define GL_COLOR_ARRAY_PARALLEL_POINTERS_INTEL 0x83F7 -#define GL_TEXTURE_COORD_ARRAY_PARALLEL_POINTERS_INTEL 0x83F8 - -typedef void (GLAPIENTRY * PFNGLCOLORPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTERVINTELPROC) (GLenum type, const void** pointer); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); - -#define glColorPointervINTEL GLEW_GET_FUN(__glewColorPointervINTEL) -#define glNormalPointervINTEL GLEW_GET_FUN(__glewNormalPointervINTEL) -#define glTexCoordPointervINTEL GLEW_GET_FUN(__glewTexCoordPointervINTEL) -#define glVertexPointervINTEL GLEW_GET_FUN(__glewVertexPointervINTEL) - -#define GLEW_INTEL_parallel_arrays GLEW_GET_VAR(__GLEW_INTEL_parallel_arrays) - -#endif /* GL_INTEL_parallel_arrays */ - -/* ------------------------ GL_INTEL_texture_scissor ----------------------- */ - -#ifndef GL_INTEL_texture_scissor -#define GL_INTEL_texture_scissor 1 - -typedef void (GLAPIENTRY * PFNGLTEXSCISSORFUNCINTELPROC) (GLenum target, GLenum lfunc, GLenum hfunc); -typedef void (GLAPIENTRY * PFNGLTEXSCISSORINTELPROC) (GLenum target, GLclampf tlow, GLclampf thigh); - -#define glTexScissorFuncINTEL GLEW_GET_FUN(__glewTexScissorFuncINTEL) -#define glTexScissorINTEL GLEW_GET_FUN(__glewTexScissorINTEL) - -#define GLEW_INTEL_texture_scissor GLEW_GET_VAR(__GLEW_INTEL_texture_scissor) - -#endif /* GL_INTEL_texture_scissor */ - -/* -------------------------- GL_KTX_buffer_region ------------------------- */ - -#ifndef GL_KTX_buffer_region -#define GL_KTX_buffer_region 1 - -#define GL_KTX_FRONT_REGION 0x0 -#define GL_KTX_BACK_REGION 0x1 -#define GL_KTX_Z_REGION 0x2 -#define GL_KTX_STENCIL_REGION 0x3 - -typedef GLuint (GLAPIENTRY * PFNGLBUFFERREGIONENABLEDEXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLDELETEBUFFERREGIONEXTPROC) (GLenum region); -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERREGIONEXTPROC) (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height, GLint xDest, GLint yDest); -typedef GLuint (GLAPIENTRY * PFNGLNEWBUFFERREGIONEXTPROC) (GLenum region); -typedef void (GLAPIENTRY * PFNGLREADBUFFERREGIONEXTPROC) (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height); - -#define glBufferRegionEnabledEXT GLEW_GET_FUN(__glewBufferRegionEnabledEXT) -#define glDeleteBufferRegionEXT GLEW_GET_FUN(__glewDeleteBufferRegionEXT) -#define glDrawBufferRegionEXT GLEW_GET_FUN(__glewDrawBufferRegionEXT) -#define glNewBufferRegionEXT GLEW_GET_FUN(__glewNewBufferRegionEXT) -#define glReadBufferRegionEXT GLEW_GET_FUN(__glewReadBufferRegionEXT) - -#define GLEW_KTX_buffer_region GLEW_GET_VAR(__GLEW_KTX_buffer_region) - -#endif /* GL_KTX_buffer_region */ - -/* ------------------------- GL_MESAX_texture_stack ------------------------ */ - -#ifndef GL_MESAX_texture_stack -#define GL_MESAX_texture_stack 1 - -#define GL_TEXTURE_1D_STACK_MESAX 0x8759 -#define GL_TEXTURE_2D_STACK_MESAX 0x875A -#define GL_PROXY_TEXTURE_1D_STACK_MESAX 0x875B -#define GL_PROXY_TEXTURE_2D_STACK_MESAX 0x875C -#define GL_TEXTURE_1D_STACK_BINDING_MESAX 0x875D -#define GL_TEXTURE_2D_STACK_BINDING_MESAX 0x875E - -#define GLEW_MESAX_texture_stack GLEW_GET_VAR(__GLEW_MESAX_texture_stack) - -#endif /* GL_MESAX_texture_stack */ - -/* -------------------------- GL_MESA_pack_invert -------------------------- */ - -#ifndef GL_MESA_pack_invert -#define GL_MESA_pack_invert 1 - -#define GL_PACK_INVERT_MESA 0x8758 - -#define GLEW_MESA_pack_invert GLEW_GET_VAR(__GLEW_MESA_pack_invert) - -#endif /* GL_MESA_pack_invert */ - -/* ------------------------- GL_MESA_resize_buffers ------------------------ */ - -#ifndef GL_MESA_resize_buffers -#define GL_MESA_resize_buffers 1 - -typedef void (GLAPIENTRY * PFNGLRESIZEBUFFERSMESAPROC) (void); - -#define glResizeBuffersMESA GLEW_GET_FUN(__glewResizeBuffersMESA) - -#define GLEW_MESA_resize_buffers GLEW_GET_VAR(__GLEW_MESA_resize_buffers) - -#endif /* GL_MESA_resize_buffers */ - -/* --------------------------- GL_MESA_window_pos -------------------------- */ - -#ifndef GL_MESA_window_pos -#define GL_MESA_window_pos 1 - -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DMESAPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVMESAPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FMESAPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVMESAPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IMESAPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVMESAPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SMESAPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVMESAPROC) (const GLshort* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DMESAPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVMESAPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FMESAPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVMESAPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IMESAPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVMESAPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SMESAPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVMESAPROC) (const GLshort* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4DMESAPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4DVMESAPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4FMESAPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4FVMESAPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4IMESAPROC) (GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4IVMESAPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4SMESAPROC) (GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4SVMESAPROC) (const GLshort* p); - -#define glWindowPos2dMESA GLEW_GET_FUN(__glewWindowPos2dMESA) -#define glWindowPos2dvMESA GLEW_GET_FUN(__glewWindowPos2dvMESA) -#define glWindowPos2fMESA GLEW_GET_FUN(__glewWindowPos2fMESA) -#define glWindowPos2fvMESA GLEW_GET_FUN(__glewWindowPos2fvMESA) -#define glWindowPos2iMESA GLEW_GET_FUN(__glewWindowPos2iMESA) -#define glWindowPos2ivMESA GLEW_GET_FUN(__glewWindowPos2ivMESA) -#define glWindowPos2sMESA GLEW_GET_FUN(__glewWindowPos2sMESA) -#define glWindowPos2svMESA GLEW_GET_FUN(__glewWindowPos2svMESA) -#define glWindowPos3dMESA GLEW_GET_FUN(__glewWindowPos3dMESA) -#define glWindowPos3dvMESA GLEW_GET_FUN(__glewWindowPos3dvMESA) -#define glWindowPos3fMESA GLEW_GET_FUN(__glewWindowPos3fMESA) -#define glWindowPos3fvMESA GLEW_GET_FUN(__glewWindowPos3fvMESA) -#define glWindowPos3iMESA GLEW_GET_FUN(__glewWindowPos3iMESA) -#define glWindowPos3ivMESA GLEW_GET_FUN(__glewWindowPos3ivMESA) -#define glWindowPos3sMESA GLEW_GET_FUN(__glewWindowPos3sMESA) -#define glWindowPos3svMESA GLEW_GET_FUN(__glewWindowPos3svMESA) -#define glWindowPos4dMESA GLEW_GET_FUN(__glewWindowPos4dMESA) -#define glWindowPos4dvMESA GLEW_GET_FUN(__glewWindowPos4dvMESA) -#define glWindowPos4fMESA GLEW_GET_FUN(__glewWindowPos4fMESA) -#define glWindowPos4fvMESA GLEW_GET_FUN(__glewWindowPos4fvMESA) -#define glWindowPos4iMESA GLEW_GET_FUN(__glewWindowPos4iMESA) -#define glWindowPos4ivMESA GLEW_GET_FUN(__glewWindowPos4ivMESA) -#define glWindowPos4sMESA GLEW_GET_FUN(__glewWindowPos4sMESA) -#define glWindowPos4svMESA GLEW_GET_FUN(__glewWindowPos4svMESA) - -#define GLEW_MESA_window_pos GLEW_GET_VAR(__GLEW_MESA_window_pos) - -#endif /* GL_MESA_window_pos */ - -/* ------------------------- GL_MESA_ycbcr_texture ------------------------- */ - -#ifndef GL_MESA_ycbcr_texture -#define GL_MESA_ycbcr_texture 1 - -#define GL_UNSIGNED_SHORT_8_8_MESA 0x85BA -#define GL_UNSIGNED_SHORT_8_8_REV_MESA 0x85BB -#define GL_YCBCR_MESA 0x8757 - -#define GLEW_MESA_ycbcr_texture GLEW_GET_VAR(__GLEW_MESA_ycbcr_texture) - -#endif /* GL_MESA_ycbcr_texture */ - -/* ------------------------- GL_NVX_gpu_memory_info ------------------------ */ - -#ifndef GL_NVX_gpu_memory_info -#define GL_NVX_gpu_memory_info 1 - -#define GL_GPU_MEMORY_INFO_DEDICATED_VIDMEM_NVX 0x9047 -#define GL_GPU_MEMORY_INFO_TOTAL_AVAILABLE_MEMORY_NVX 0x9048 -#define GL_GPU_MEMORY_INFO_CURRENT_AVAILABLE_VIDMEM_NVX 0x9049 -#define GL_GPU_MEMORY_INFO_EVICTION_COUNT_NVX 0x904A -#define GL_GPU_MEMORY_INFO_EVICTED_MEMORY_NVX 0x904B - -#define GLEW_NVX_gpu_memory_info GLEW_GET_VAR(__GLEW_NVX_gpu_memory_info) - -#endif /* GL_NVX_gpu_memory_info */ - -/* --------------------------- GL_NV_blend_square -------------------------- */ - -#ifndef GL_NV_blend_square -#define GL_NV_blend_square 1 - -#define GLEW_NV_blend_square GLEW_GET_VAR(__GLEW_NV_blend_square) - -#endif /* GL_NV_blend_square */ - -/* ------------------------ GL_NV_conditional_render ----------------------- */ - -#ifndef GL_NV_conditional_render -#define GL_NV_conditional_render 1 - -#define GL_QUERY_WAIT_NV 0x8E13 -#define GL_QUERY_NO_WAIT_NV 0x8E14 -#define GL_QUERY_BY_REGION_WAIT_NV 0x8E15 -#define GL_QUERY_BY_REGION_NO_WAIT_NV 0x8E16 - -typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERNVPROC) (GLuint id, GLenum mode); -typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERNVPROC) (void); - -#define glBeginConditionalRenderNV GLEW_GET_FUN(__glewBeginConditionalRenderNV) -#define glEndConditionalRenderNV GLEW_GET_FUN(__glewEndConditionalRenderNV) - -#define GLEW_NV_conditional_render GLEW_GET_VAR(__GLEW_NV_conditional_render) - -#endif /* GL_NV_conditional_render */ - -/* ----------------------- GL_NV_copy_depth_to_color ----------------------- */ - -#ifndef GL_NV_copy_depth_to_color -#define GL_NV_copy_depth_to_color 1 - -#define GL_DEPTH_STENCIL_TO_RGBA_NV 0x886E -#define GL_DEPTH_STENCIL_TO_BGRA_NV 0x886F - -#define GLEW_NV_copy_depth_to_color GLEW_GET_VAR(__GLEW_NV_copy_depth_to_color) - -#endif /* GL_NV_copy_depth_to_color */ - -/* ---------------------------- GL_NV_copy_image --------------------------- */ - -#ifndef GL_NV_copy_image -#define GL_NV_copy_image 1 - -typedef void (GLAPIENTRY * PFNGLCOPYIMAGESUBDATANVPROC) (GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); - -#define glCopyImageSubDataNV GLEW_GET_FUN(__glewCopyImageSubDataNV) - -#define GLEW_NV_copy_image GLEW_GET_VAR(__GLEW_NV_copy_image) - -#endif /* GL_NV_copy_image */ - -/* ------------------------ GL_NV_depth_buffer_float ----------------------- */ - -#ifndef GL_NV_depth_buffer_float -#define GL_NV_depth_buffer_float 1 - -#define GL_DEPTH_COMPONENT32F_NV 0x8DAB -#define GL_DEPTH32F_STENCIL8_NV 0x8DAC -#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV_NV 0x8DAD -#define GL_DEPTH_BUFFER_FLOAT_MODE_NV 0x8DAF - -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHDNVPROC) (GLdouble depth); -typedef void (GLAPIENTRY * PFNGLDEPTHBOUNDSDNVPROC) (GLdouble zmin, GLdouble zmax); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEDNVPROC) (GLdouble zNear, GLdouble zFar); - -#define glClearDepthdNV GLEW_GET_FUN(__glewClearDepthdNV) -#define glDepthBoundsdNV GLEW_GET_FUN(__glewDepthBoundsdNV) -#define glDepthRangedNV GLEW_GET_FUN(__glewDepthRangedNV) - -#define GLEW_NV_depth_buffer_float GLEW_GET_VAR(__GLEW_NV_depth_buffer_float) - -#endif /* GL_NV_depth_buffer_float */ - -/* --------------------------- GL_NV_depth_clamp --------------------------- */ - -#ifndef GL_NV_depth_clamp -#define GL_NV_depth_clamp 1 - -#define GL_DEPTH_CLAMP_NV 0x864F - -#define GLEW_NV_depth_clamp GLEW_GET_VAR(__GLEW_NV_depth_clamp) - -#endif /* GL_NV_depth_clamp */ - -/* ---------------------- GL_NV_depth_range_unclamped ---------------------- */ - -#ifndef GL_NV_depth_range_unclamped -#define GL_NV_depth_range_unclamped 1 - -#define GL_SAMPLE_COUNT_BITS_NV 0x8864 -#define GL_CURRENT_SAMPLE_COUNT_QUERY_NV 0x8865 -#define GL_QUERY_RESULT_NV 0x8866 -#define GL_QUERY_RESULT_AVAILABLE_NV 0x8867 -#define GL_SAMPLE_COUNT_NV 0x8914 - -#define GLEW_NV_depth_range_unclamped GLEW_GET_VAR(__GLEW_NV_depth_range_unclamped) - -#endif /* GL_NV_depth_range_unclamped */ - -/* ---------------------------- GL_NV_evaluators --------------------------- */ - -#ifndef GL_NV_evaluators -#define GL_NV_evaluators 1 - -#define GL_EVAL_2D_NV 0x86C0 -#define GL_EVAL_TRIANGULAR_2D_NV 0x86C1 -#define GL_MAP_TESSELLATION_NV 0x86C2 -#define GL_MAP_ATTRIB_U_ORDER_NV 0x86C3 -#define GL_MAP_ATTRIB_V_ORDER_NV 0x86C4 -#define GL_EVAL_FRACTIONAL_TESSELLATION_NV 0x86C5 -#define GL_EVAL_VERTEX_ATTRIB0_NV 0x86C6 -#define GL_EVAL_VERTEX_ATTRIB1_NV 0x86C7 -#define GL_EVAL_VERTEX_ATTRIB2_NV 0x86C8 -#define GL_EVAL_VERTEX_ATTRIB3_NV 0x86C9 -#define GL_EVAL_VERTEX_ATTRIB4_NV 0x86CA -#define GL_EVAL_VERTEX_ATTRIB5_NV 0x86CB -#define GL_EVAL_VERTEX_ATTRIB6_NV 0x86CC -#define GL_EVAL_VERTEX_ATTRIB7_NV 0x86CD -#define GL_EVAL_VERTEX_ATTRIB8_NV 0x86CE -#define GL_EVAL_VERTEX_ATTRIB9_NV 0x86CF -#define GL_EVAL_VERTEX_ATTRIB10_NV 0x86D0 -#define GL_EVAL_VERTEX_ATTRIB11_NV 0x86D1 -#define GL_EVAL_VERTEX_ATTRIB12_NV 0x86D2 -#define GL_EVAL_VERTEX_ATTRIB13_NV 0x86D3 -#define GL_EVAL_VERTEX_ATTRIB14_NV 0x86D4 -#define GL_EVAL_VERTEX_ATTRIB15_NV 0x86D5 -#define GL_MAX_MAP_TESSELLATION_NV 0x86D6 -#define GL_MAX_RATIONAL_EVAL_ORDER_NV 0x86D7 - -typedef void (GLAPIENTRY * PFNGLEVALMAPSNVPROC) (GLenum target, GLenum mode); -typedef void (GLAPIENTRY * PFNGLGETMAPATTRIBPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMAPATTRIBPARAMETERIVNVPROC) (GLenum target, GLuint index, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, void* points); -typedef void (GLAPIENTRY * PFNGLGETMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const void* points); -typedef void (GLAPIENTRY * PFNGLMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, const GLint* params); - -#define glEvalMapsNV GLEW_GET_FUN(__glewEvalMapsNV) -#define glGetMapAttribParameterfvNV GLEW_GET_FUN(__glewGetMapAttribParameterfvNV) -#define glGetMapAttribParameterivNV GLEW_GET_FUN(__glewGetMapAttribParameterivNV) -#define glGetMapControlPointsNV GLEW_GET_FUN(__glewGetMapControlPointsNV) -#define glGetMapParameterfvNV GLEW_GET_FUN(__glewGetMapParameterfvNV) -#define glGetMapParameterivNV GLEW_GET_FUN(__glewGetMapParameterivNV) -#define glMapControlPointsNV GLEW_GET_FUN(__glewMapControlPointsNV) -#define glMapParameterfvNV GLEW_GET_FUN(__glewMapParameterfvNV) -#define glMapParameterivNV GLEW_GET_FUN(__glewMapParameterivNV) - -#define GLEW_NV_evaluators GLEW_GET_VAR(__GLEW_NV_evaluators) - -#endif /* GL_NV_evaluators */ - -/* ----------------------- GL_NV_explicit_multisample ---------------------- */ - -#ifndef GL_NV_explicit_multisample -#define GL_NV_explicit_multisample 1 - -#define GL_SAMPLE_POSITION_NV 0x8E50 -#define GL_SAMPLE_MASK_NV 0x8E51 -#define GL_SAMPLE_MASK_VALUE_NV 0x8E52 -#define GL_TEXTURE_BINDING_RENDERBUFFER_NV 0x8E53 -#define GL_TEXTURE_RENDERBUFFER_DATA_STORE_BINDING_NV 0x8E54 -#define GL_TEXTURE_RENDERBUFFER_NV 0x8E55 -#define GL_SAMPLER_RENDERBUFFER_NV 0x8E56 -#define GL_INT_SAMPLER_RENDERBUFFER_NV 0x8E57 -#define GL_UNSIGNED_INT_SAMPLER_RENDERBUFFER_NV 0x8E58 -#define GL_MAX_SAMPLE_MASK_WORDS_NV 0x8E59 - -typedef void (GLAPIENTRY * PFNGLGETMULTISAMPLEFVNVPROC) (GLenum pname, GLuint index, GLfloat* val); -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKINDEXEDNVPROC) (GLuint index, GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLTEXRENDERBUFFERNVPROC) (GLenum target, GLuint renderbuffer); - -#define glGetMultisamplefvNV GLEW_GET_FUN(__glewGetMultisamplefvNV) -#define glSampleMaskIndexedNV GLEW_GET_FUN(__glewSampleMaskIndexedNV) -#define glTexRenderbufferNV GLEW_GET_FUN(__glewTexRenderbufferNV) - -#define GLEW_NV_explicit_multisample GLEW_GET_VAR(__GLEW_NV_explicit_multisample) - -#endif /* GL_NV_explicit_multisample */ - -/* ------------------------------ GL_NV_fence ------------------------------ */ - -#ifndef GL_NV_fence -#define GL_NV_fence 1 - -#define GL_ALL_COMPLETED_NV 0x84F2 -#define GL_FENCE_STATUS_NV 0x84F3 -#define GL_FENCE_CONDITION_NV 0x84F4 - -typedef void (GLAPIENTRY * PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint* fences); -typedef void (GLAPIENTRY * PFNGLFINISHFENCENVPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLGENFENCESNVPROC) (GLsizei n, GLuint* fences); -typedef void (GLAPIENTRY * PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISFENCENVPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); -typedef GLboolean (GLAPIENTRY * PFNGLTESTFENCENVPROC) (GLuint fence); - -#define glDeleteFencesNV GLEW_GET_FUN(__glewDeleteFencesNV) -#define glFinishFenceNV GLEW_GET_FUN(__glewFinishFenceNV) -#define glGenFencesNV GLEW_GET_FUN(__glewGenFencesNV) -#define glGetFenceivNV GLEW_GET_FUN(__glewGetFenceivNV) -#define glIsFenceNV GLEW_GET_FUN(__glewIsFenceNV) -#define glSetFenceNV GLEW_GET_FUN(__glewSetFenceNV) -#define glTestFenceNV GLEW_GET_FUN(__glewTestFenceNV) - -#define GLEW_NV_fence GLEW_GET_VAR(__GLEW_NV_fence) - -#endif /* GL_NV_fence */ - -/* --------------------------- GL_NV_float_buffer -------------------------- */ - -#ifndef GL_NV_float_buffer -#define GL_NV_float_buffer 1 - -#define GL_FLOAT_R_NV 0x8880 -#define GL_FLOAT_RG_NV 0x8881 -#define GL_FLOAT_RGB_NV 0x8882 -#define GL_FLOAT_RGBA_NV 0x8883 -#define GL_FLOAT_R16_NV 0x8884 -#define GL_FLOAT_R32_NV 0x8885 -#define GL_FLOAT_RG16_NV 0x8886 -#define GL_FLOAT_RG32_NV 0x8887 -#define GL_FLOAT_RGB16_NV 0x8888 -#define GL_FLOAT_RGB32_NV 0x8889 -#define GL_FLOAT_RGBA16_NV 0x888A -#define GL_FLOAT_RGBA32_NV 0x888B -#define GL_TEXTURE_FLOAT_COMPONENTS_NV 0x888C -#define GL_FLOAT_CLEAR_COLOR_VALUE_NV 0x888D -#define GL_FLOAT_RGBA_MODE_NV 0x888E - -#define GLEW_NV_float_buffer GLEW_GET_VAR(__GLEW_NV_float_buffer) - -#endif /* GL_NV_float_buffer */ - -/* --------------------------- GL_NV_fog_distance -------------------------- */ - -#ifndef GL_NV_fog_distance -#define GL_NV_fog_distance 1 - -#define GL_FOG_DISTANCE_MODE_NV 0x855A -#define GL_EYE_RADIAL_NV 0x855B -#define GL_EYE_PLANE_ABSOLUTE_NV 0x855C - -#define GLEW_NV_fog_distance GLEW_GET_VAR(__GLEW_NV_fog_distance) - -#endif /* GL_NV_fog_distance */ - -/* ------------------------- GL_NV_fragment_program ------------------------ */ - -#ifndef GL_NV_fragment_program -#define GL_NV_fragment_program 1 - -#define GL_MAX_FRAGMENT_PROGRAM_LOCAL_PARAMETERS_NV 0x8868 -#define GL_FRAGMENT_PROGRAM_NV 0x8870 -#define GL_MAX_TEXTURE_COORDS_NV 0x8871 -#define GL_MAX_TEXTURE_IMAGE_UNITS_NV 0x8872 -#define GL_FRAGMENT_PROGRAM_BINDING_NV 0x8873 -#define GL_PROGRAM_ERROR_STRING_NV 0x8874 - -typedef void (GLAPIENTRY * PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLdouble *params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4DNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, const GLdouble v[]); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4FNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, const GLfloat v[]); - -#define glGetProgramNamedParameterdvNV GLEW_GET_FUN(__glewGetProgramNamedParameterdvNV) -#define glGetProgramNamedParameterfvNV GLEW_GET_FUN(__glewGetProgramNamedParameterfvNV) -#define glProgramNamedParameter4dNV GLEW_GET_FUN(__glewProgramNamedParameter4dNV) -#define glProgramNamedParameter4dvNV GLEW_GET_FUN(__glewProgramNamedParameter4dvNV) -#define glProgramNamedParameter4fNV GLEW_GET_FUN(__glewProgramNamedParameter4fNV) -#define glProgramNamedParameter4fvNV GLEW_GET_FUN(__glewProgramNamedParameter4fvNV) - -#define GLEW_NV_fragment_program GLEW_GET_VAR(__GLEW_NV_fragment_program) - -#endif /* GL_NV_fragment_program */ - -/* ------------------------ GL_NV_fragment_program2 ------------------------ */ - -#ifndef GL_NV_fragment_program2 -#define GL_NV_fragment_program2 1 - -#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 -#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 -#define GL_MAX_PROGRAM_IF_DEPTH_NV 0x88F6 -#define GL_MAX_PROGRAM_LOOP_DEPTH_NV 0x88F7 -#define GL_MAX_PROGRAM_LOOP_COUNT_NV 0x88F8 - -#define GLEW_NV_fragment_program2 GLEW_GET_VAR(__GLEW_NV_fragment_program2) - -#endif /* GL_NV_fragment_program2 */ - -/* ------------------------ GL_NV_fragment_program4 ------------------------ */ - -#ifndef GL_NV_fragment_program4 -#define GL_NV_fragment_program4 1 - -#define GLEW_NV_fragment_program4 GLEW_GET_VAR(__GLEW_NV_fragment_program4) - -#endif /* GL_NV_fragment_program4 */ - -/* --------------------- GL_NV_fragment_program_option --------------------- */ - -#ifndef GL_NV_fragment_program_option -#define GL_NV_fragment_program_option 1 - -#define GLEW_NV_fragment_program_option GLEW_GET_VAR(__GLEW_NV_fragment_program_option) - -#endif /* GL_NV_fragment_program_option */ - -/* ----------------- GL_NV_framebuffer_multisample_coverage ---------------- */ - -#ifndef GL_NV_framebuffer_multisample_coverage -#define GL_NV_framebuffer_multisample_coverage 1 - -#define GL_RENDERBUFFER_COVERAGE_SAMPLES_NV 0x8CAB -#define GL_RENDERBUFFER_COLOR_SAMPLES_NV 0x8E10 -#define GL_MAX_MULTISAMPLE_COVERAGE_MODES_NV 0x8E11 -#define GL_MULTISAMPLE_COVERAGE_MODES_NV 0x8E12 - -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glRenderbufferStorageMultisampleCoverageNV GLEW_GET_FUN(__glewRenderbufferStorageMultisampleCoverageNV) - -#define GLEW_NV_framebuffer_multisample_coverage GLEW_GET_VAR(__GLEW_NV_framebuffer_multisample_coverage) - -#endif /* GL_NV_framebuffer_multisample_coverage */ - -/* ------------------------ GL_NV_geometry_program4 ------------------------ */ - -#ifndef GL_NV_geometry_program4 -#define GL_NV_geometry_program4 1 - -#define GL_GEOMETRY_PROGRAM_NV 0x8C26 -#define GL_MAX_PROGRAM_OUTPUT_VERTICES_NV 0x8C27 -#define GL_MAX_PROGRAM_TOTAL_OUTPUT_COMPONENTS_NV 0x8C28 - -typedef void (GLAPIENTRY * PFNGLPROGRAMVERTEXLIMITNVPROC) (GLenum target, GLint limit); - -#define glProgramVertexLimitNV GLEW_GET_FUN(__glewProgramVertexLimitNV) - -#define GLEW_NV_geometry_program4 GLEW_GET_VAR(__GLEW_NV_geometry_program4) - -#endif /* GL_NV_geometry_program4 */ - -/* ------------------------- GL_NV_geometry_shader4 ------------------------ */ - -#ifndef GL_NV_geometry_shader4 -#define GL_NV_geometry_shader4 1 - -#define GLEW_NV_geometry_shader4 GLEW_GET_VAR(__GLEW_NV_geometry_shader4) - -#endif /* GL_NV_geometry_shader4 */ - -/* --------------------------- GL_NV_gpu_program4 -------------------------- */ - -#ifndef GL_NV_gpu_program4 -#define GL_NV_gpu_program4 1 - -#define GL_MIN_PROGRAM_TEXEL_OFFSET_NV 0x8904 -#define GL_MAX_PROGRAM_TEXEL_OFFSET_NV 0x8905 -#define GL_PROGRAM_ATTRIB_COMPONENTS_NV 0x8906 -#define GL_PROGRAM_RESULT_COMPONENTS_NV 0x8907 -#define GL_MAX_PROGRAM_ATTRIB_COMPONENTS_NV 0x8908 -#define GL_MAX_PROGRAM_RESULT_COMPONENTS_NV 0x8909 -#define GL_MAX_PROGRAM_GENERIC_ATTRIBS_NV 0x8DA5 -#define GL_MAX_PROGRAM_GENERIC_RESULTS_NV 0x8DA6 - -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); - -#define glProgramEnvParameterI4iNV GLEW_GET_FUN(__glewProgramEnvParameterI4iNV) -#define glProgramEnvParameterI4ivNV GLEW_GET_FUN(__glewProgramEnvParameterI4ivNV) -#define glProgramEnvParameterI4uiNV GLEW_GET_FUN(__glewProgramEnvParameterI4uiNV) -#define glProgramEnvParameterI4uivNV GLEW_GET_FUN(__glewProgramEnvParameterI4uivNV) -#define glProgramEnvParametersI4ivNV GLEW_GET_FUN(__glewProgramEnvParametersI4ivNV) -#define glProgramEnvParametersI4uivNV GLEW_GET_FUN(__glewProgramEnvParametersI4uivNV) -#define glProgramLocalParameterI4iNV GLEW_GET_FUN(__glewProgramLocalParameterI4iNV) -#define glProgramLocalParameterI4ivNV GLEW_GET_FUN(__glewProgramLocalParameterI4ivNV) -#define glProgramLocalParameterI4uiNV GLEW_GET_FUN(__glewProgramLocalParameterI4uiNV) -#define glProgramLocalParameterI4uivNV GLEW_GET_FUN(__glewProgramLocalParameterI4uivNV) -#define glProgramLocalParametersI4ivNV GLEW_GET_FUN(__glewProgramLocalParametersI4ivNV) -#define glProgramLocalParametersI4uivNV GLEW_GET_FUN(__glewProgramLocalParametersI4uivNV) - -#define GLEW_NV_gpu_program4 GLEW_GET_VAR(__GLEW_NV_gpu_program4) - -#endif /* GL_NV_gpu_program4 */ - -/* --------------------------- GL_NV_gpu_program5 -------------------------- */ - -#ifndef GL_NV_gpu_program5 -#define GL_NV_gpu_program5 1 - -#define GL_MAX_GEOMETRY_PROGRAM_INVOCATIONS_NV 0x8E5A -#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5B -#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5C -#define GL_FRAGMENT_PROGRAM_INTERPOLATION_OFFSET_BITS_NV 0x8E5D -#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_NV 0x8E5E -#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_NV 0x8E5F - -#define GLEW_NV_gpu_program5 GLEW_GET_VAR(__GLEW_NV_gpu_program5) - -#endif /* GL_NV_gpu_program5 */ - -/* ------------------------- GL_NV_gpu_program_fp64 ------------------------ */ - -#ifndef GL_NV_gpu_program_fp64 -#define GL_NV_gpu_program_fp64 1 - -#define GLEW_NV_gpu_program_fp64 GLEW_GET_VAR(__GLEW_NV_gpu_program_fp64) - -#endif /* GL_NV_gpu_program_fp64 */ - -/* --------------------------- GL_NV_gpu_shader5 --------------------------- */ - -#ifndef GL_NV_gpu_shader5 -#define GL_NV_gpu_shader5 1 - -#define GL_INT64_NV 0x140E -#define GL_UNSIGNED_INT64_NV 0x140F -#define GL_INT8_NV 0x8FE0 -#define GL_INT8_VEC2_NV 0x8FE1 -#define GL_INT8_VEC3_NV 0x8FE2 -#define GL_INT8_VEC4_NV 0x8FE3 -#define GL_INT16_NV 0x8FE4 -#define GL_INT16_VEC2_NV 0x8FE5 -#define GL_INT16_VEC3_NV 0x8FE6 -#define GL_INT16_VEC4_NV 0x8FE7 -#define GL_INT64_VEC2_NV 0x8FE9 -#define GL_INT64_VEC3_NV 0x8FEA -#define GL_INT64_VEC4_NV 0x8FEB -#define GL_UNSIGNED_INT8_NV 0x8FEC -#define GL_UNSIGNED_INT8_VEC2_NV 0x8FED -#define GL_UNSIGNED_INT8_VEC3_NV 0x8FEE -#define GL_UNSIGNED_INT8_VEC4_NV 0x8FEF -#define GL_UNSIGNED_INT16_NV 0x8FF0 -#define GL_UNSIGNED_INT16_VEC2_NV 0x8FF1 -#define GL_UNSIGNED_INT16_VEC3_NV 0x8FF2 -#define GL_UNSIGNED_INT16_VEC4_NV 0x8FF3 -#define GL_UNSIGNED_INT64_VEC2_NV 0x8FF5 -#define GL_UNSIGNED_INT64_VEC3_NV 0x8FF6 -#define GL_UNSIGNED_INT64_VEC4_NV 0x8FF7 -#define GL_FLOAT16_NV 0x8FF8 -#define GL_FLOAT16_VEC2_NV 0x8FF9 -#define GL_FLOAT16_VEC3_NV 0x8FFA -#define GL_FLOAT16_VEC4_NV 0x8FFB - -typedef void (GLAPIENTRY * PFNGLGETUNIFORMI64VNVPROC) (GLuint program, GLint location, GLint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1I64NVPROC) (GLuint program, GLint location, GLint64EXT x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1I64NVPROC) (GLint location, GLint64EXT x); -typedef void (GLAPIENTRY * PFNGLUNIFORM1I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UI64NVPROC) (GLint location, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y); -typedef void (GLAPIENTRY * PFNGLUNIFORM2I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); -typedef void (GLAPIENTRY * PFNGLUNIFORM3I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); -typedef void (GLAPIENTRY * PFNGLUNIFORM4I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); - -#define glGetUniformi64vNV GLEW_GET_FUN(__glewGetUniformi64vNV) -#define glGetUniformui64vNV GLEW_GET_FUN(__glewGetUniformui64vNV) -#define glProgramUniform1i64NV GLEW_GET_FUN(__glewProgramUniform1i64NV) -#define glProgramUniform1i64vNV GLEW_GET_FUN(__glewProgramUniform1i64vNV) -#define glProgramUniform1ui64NV GLEW_GET_FUN(__glewProgramUniform1ui64NV) -#define glProgramUniform1ui64vNV GLEW_GET_FUN(__glewProgramUniform1ui64vNV) -#define glProgramUniform2i64NV GLEW_GET_FUN(__glewProgramUniform2i64NV) -#define glProgramUniform2i64vNV GLEW_GET_FUN(__glewProgramUniform2i64vNV) -#define glProgramUniform2ui64NV GLEW_GET_FUN(__glewProgramUniform2ui64NV) -#define glProgramUniform2ui64vNV GLEW_GET_FUN(__glewProgramUniform2ui64vNV) -#define glProgramUniform3i64NV GLEW_GET_FUN(__glewProgramUniform3i64NV) -#define glProgramUniform3i64vNV GLEW_GET_FUN(__glewProgramUniform3i64vNV) -#define glProgramUniform3ui64NV GLEW_GET_FUN(__glewProgramUniform3ui64NV) -#define glProgramUniform3ui64vNV GLEW_GET_FUN(__glewProgramUniform3ui64vNV) -#define glProgramUniform4i64NV GLEW_GET_FUN(__glewProgramUniform4i64NV) -#define glProgramUniform4i64vNV GLEW_GET_FUN(__glewProgramUniform4i64vNV) -#define glProgramUniform4ui64NV GLEW_GET_FUN(__glewProgramUniform4ui64NV) -#define glProgramUniform4ui64vNV GLEW_GET_FUN(__glewProgramUniform4ui64vNV) -#define glUniform1i64NV GLEW_GET_FUN(__glewUniform1i64NV) -#define glUniform1i64vNV GLEW_GET_FUN(__glewUniform1i64vNV) -#define glUniform1ui64NV GLEW_GET_FUN(__glewUniform1ui64NV) -#define glUniform1ui64vNV GLEW_GET_FUN(__glewUniform1ui64vNV) -#define glUniform2i64NV GLEW_GET_FUN(__glewUniform2i64NV) -#define glUniform2i64vNV GLEW_GET_FUN(__glewUniform2i64vNV) -#define glUniform2ui64NV GLEW_GET_FUN(__glewUniform2ui64NV) -#define glUniform2ui64vNV GLEW_GET_FUN(__glewUniform2ui64vNV) -#define glUniform3i64NV GLEW_GET_FUN(__glewUniform3i64NV) -#define glUniform3i64vNV GLEW_GET_FUN(__glewUniform3i64vNV) -#define glUniform3ui64NV GLEW_GET_FUN(__glewUniform3ui64NV) -#define glUniform3ui64vNV GLEW_GET_FUN(__glewUniform3ui64vNV) -#define glUniform4i64NV GLEW_GET_FUN(__glewUniform4i64NV) -#define glUniform4i64vNV GLEW_GET_FUN(__glewUniform4i64vNV) -#define glUniform4ui64NV GLEW_GET_FUN(__glewUniform4ui64NV) -#define glUniform4ui64vNV GLEW_GET_FUN(__glewUniform4ui64vNV) - -#define GLEW_NV_gpu_shader5 GLEW_GET_VAR(__GLEW_NV_gpu_shader5) - -#endif /* GL_NV_gpu_shader5 */ - -/* ---------------------------- GL_NV_half_float --------------------------- */ - -#ifndef GL_NV_half_float -#define GL_NV_half_float 1 - -#define GL_HALF_FLOAT_NV 0x140B - -typedef unsigned short GLhalf; - -typedef void (GLAPIENTRY * PFNGLCOLOR3HNVPROC) (GLhalf red, GLhalf green, GLhalf blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLCOLOR4HNVPROC) (GLhalf red, GLhalf green, GLhalf blue, GLhalf alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLFOGCOORDHNVPROC) (GLhalf fog); -typedef void (GLAPIENTRY * PFNGLFOGCOORDHVNVPROC) (const GLhalf* fog); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1HNVPROC) (GLenum target, GLhalf s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2HNVPROC) (GLenum target, GLhalf s, GLhalf t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3HNVPROC) (GLenum target, GLhalf s, GLhalf t, GLhalf r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4HNVPROC) (GLenum target, GLhalf s, GLhalf t, GLhalf r, GLhalf q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLNORMAL3HNVPROC) (GLhalf nx, GLhalf ny, GLhalf nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3HNVPROC) (GLhalf red, GLhalf green, GLhalf blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1HNVPROC) (GLhalf s); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2HNVPROC) (GLhalf s, GLhalf t); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3HNVPROC) (GLhalf s, GLhalf t, GLhalf r); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4HNVPROC) (GLhalf s, GLhalf t, GLhalf r, GLhalf q); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEX2HNVPROC) (GLhalf x, GLhalf y); -typedef void (GLAPIENTRY * PFNGLVERTEX2HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEX3HNVPROC) (GLhalf x, GLhalf y, GLhalf z); -typedef void (GLAPIENTRY * PFNGLVERTEX3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEX4HNVPROC) (GLhalf x, GLhalf y, GLhalf z, GLhalf w); -typedef void (GLAPIENTRY * PFNGLVERTEX4HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1HNVPROC) (GLuint index, GLhalf x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2HNVPROC) (GLuint index, GLhalf x, GLhalf y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3HNVPROC) (GLuint index, GLhalf x, GLhalf y, GLhalf z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4HNVPROC) (GLuint index, GLhalf x, GLhalf y, GLhalf z, GLhalf w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTHNVPROC) (GLhalf weight); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTHVNVPROC) (const GLhalf* weight); - -#define glColor3hNV GLEW_GET_FUN(__glewColor3hNV) -#define glColor3hvNV GLEW_GET_FUN(__glewColor3hvNV) -#define glColor4hNV GLEW_GET_FUN(__glewColor4hNV) -#define glColor4hvNV GLEW_GET_FUN(__glewColor4hvNV) -#define glFogCoordhNV GLEW_GET_FUN(__glewFogCoordhNV) -#define glFogCoordhvNV GLEW_GET_FUN(__glewFogCoordhvNV) -#define glMultiTexCoord1hNV GLEW_GET_FUN(__glewMultiTexCoord1hNV) -#define glMultiTexCoord1hvNV GLEW_GET_FUN(__glewMultiTexCoord1hvNV) -#define glMultiTexCoord2hNV GLEW_GET_FUN(__glewMultiTexCoord2hNV) -#define glMultiTexCoord2hvNV GLEW_GET_FUN(__glewMultiTexCoord2hvNV) -#define glMultiTexCoord3hNV GLEW_GET_FUN(__glewMultiTexCoord3hNV) -#define glMultiTexCoord3hvNV GLEW_GET_FUN(__glewMultiTexCoord3hvNV) -#define glMultiTexCoord4hNV GLEW_GET_FUN(__glewMultiTexCoord4hNV) -#define glMultiTexCoord4hvNV GLEW_GET_FUN(__glewMultiTexCoord4hvNV) -#define glNormal3hNV GLEW_GET_FUN(__glewNormal3hNV) -#define glNormal3hvNV GLEW_GET_FUN(__glewNormal3hvNV) -#define glSecondaryColor3hNV GLEW_GET_FUN(__glewSecondaryColor3hNV) -#define glSecondaryColor3hvNV GLEW_GET_FUN(__glewSecondaryColor3hvNV) -#define glTexCoord1hNV GLEW_GET_FUN(__glewTexCoord1hNV) -#define glTexCoord1hvNV GLEW_GET_FUN(__glewTexCoord1hvNV) -#define glTexCoord2hNV GLEW_GET_FUN(__glewTexCoord2hNV) -#define glTexCoord2hvNV GLEW_GET_FUN(__glewTexCoord2hvNV) -#define glTexCoord3hNV GLEW_GET_FUN(__glewTexCoord3hNV) -#define glTexCoord3hvNV GLEW_GET_FUN(__glewTexCoord3hvNV) -#define glTexCoord4hNV GLEW_GET_FUN(__glewTexCoord4hNV) -#define glTexCoord4hvNV GLEW_GET_FUN(__glewTexCoord4hvNV) -#define glVertex2hNV GLEW_GET_FUN(__glewVertex2hNV) -#define glVertex2hvNV GLEW_GET_FUN(__glewVertex2hvNV) -#define glVertex3hNV GLEW_GET_FUN(__glewVertex3hNV) -#define glVertex3hvNV GLEW_GET_FUN(__glewVertex3hvNV) -#define glVertex4hNV GLEW_GET_FUN(__glewVertex4hNV) -#define glVertex4hvNV GLEW_GET_FUN(__glewVertex4hvNV) -#define glVertexAttrib1hNV GLEW_GET_FUN(__glewVertexAttrib1hNV) -#define glVertexAttrib1hvNV GLEW_GET_FUN(__glewVertexAttrib1hvNV) -#define glVertexAttrib2hNV GLEW_GET_FUN(__glewVertexAttrib2hNV) -#define glVertexAttrib2hvNV GLEW_GET_FUN(__glewVertexAttrib2hvNV) -#define glVertexAttrib3hNV GLEW_GET_FUN(__glewVertexAttrib3hNV) -#define glVertexAttrib3hvNV GLEW_GET_FUN(__glewVertexAttrib3hvNV) -#define glVertexAttrib4hNV GLEW_GET_FUN(__glewVertexAttrib4hNV) -#define glVertexAttrib4hvNV GLEW_GET_FUN(__glewVertexAttrib4hvNV) -#define glVertexAttribs1hvNV GLEW_GET_FUN(__glewVertexAttribs1hvNV) -#define glVertexAttribs2hvNV GLEW_GET_FUN(__glewVertexAttribs2hvNV) -#define glVertexAttribs3hvNV GLEW_GET_FUN(__glewVertexAttribs3hvNV) -#define glVertexAttribs4hvNV GLEW_GET_FUN(__glewVertexAttribs4hvNV) -#define glVertexWeighthNV GLEW_GET_FUN(__glewVertexWeighthNV) -#define glVertexWeighthvNV GLEW_GET_FUN(__glewVertexWeighthvNV) - -#define GLEW_NV_half_float GLEW_GET_VAR(__GLEW_NV_half_float) - -#endif /* GL_NV_half_float */ - -/* ------------------------ GL_NV_light_max_exponent ----------------------- */ - -#ifndef GL_NV_light_max_exponent -#define GL_NV_light_max_exponent 1 - -#define GL_MAX_SHININESS_NV 0x8504 -#define GL_MAX_SPOT_EXPONENT_NV 0x8505 - -#define GLEW_NV_light_max_exponent GLEW_GET_VAR(__GLEW_NV_light_max_exponent) - -#endif /* GL_NV_light_max_exponent */ - -/* ----------------------- GL_NV_multisample_coverage ---------------------- */ - -#ifndef GL_NV_multisample_coverage -#define GL_NV_multisample_coverage 1 - -#define GL_COVERAGE_SAMPLES_NV 0x80A9 -#define GL_COLOR_SAMPLES_NV 0x8E20 - -#define GLEW_NV_multisample_coverage GLEW_GET_VAR(__GLEW_NV_multisample_coverage) - -#endif /* GL_NV_multisample_coverage */ - -/* --------------------- GL_NV_multisample_filter_hint --------------------- */ - -#ifndef GL_NV_multisample_filter_hint -#define GL_NV_multisample_filter_hint 1 - -#define GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 - -#define GLEW_NV_multisample_filter_hint GLEW_GET_VAR(__GLEW_NV_multisample_filter_hint) - -#endif /* GL_NV_multisample_filter_hint */ - -/* ------------------------- GL_NV_occlusion_query ------------------------- */ - -#ifndef GL_NV_occlusion_query -#define GL_NV_occlusion_query 1 - -#define GL_PIXEL_COUNTER_BITS_NV 0x8864 -#define GL_CURRENT_OCCLUSION_QUERY_ID_NV 0x8865 -#define GL_PIXEL_COUNT_NV 0x8866 -#define GL_PIXEL_COUNT_AVAILABLE_NV 0x8867 - -typedef void (GLAPIENTRY * PFNGLBEGINOCCLUSIONQUERYNVPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEOCCLUSIONQUERIESNVPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDOCCLUSIONQUERYNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLGENOCCLUSIONQUERIESNVPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETOCCLUSIONQUERYIVNVPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETOCCLUSIONQUERYUIVNVPROC) (GLuint id, GLenum pname, GLuint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISOCCLUSIONQUERYNVPROC) (GLuint id); - -#define glBeginOcclusionQueryNV GLEW_GET_FUN(__glewBeginOcclusionQueryNV) -#define glDeleteOcclusionQueriesNV GLEW_GET_FUN(__glewDeleteOcclusionQueriesNV) -#define glEndOcclusionQueryNV GLEW_GET_FUN(__glewEndOcclusionQueryNV) -#define glGenOcclusionQueriesNV GLEW_GET_FUN(__glewGenOcclusionQueriesNV) -#define glGetOcclusionQueryivNV GLEW_GET_FUN(__glewGetOcclusionQueryivNV) -#define glGetOcclusionQueryuivNV GLEW_GET_FUN(__glewGetOcclusionQueryuivNV) -#define glIsOcclusionQueryNV GLEW_GET_FUN(__glewIsOcclusionQueryNV) - -#define GLEW_NV_occlusion_query GLEW_GET_VAR(__GLEW_NV_occlusion_query) - -#endif /* GL_NV_occlusion_query */ - -/* ----------------------- GL_NV_packed_depth_stencil ---------------------- */ - -#ifndef GL_NV_packed_depth_stencil -#define GL_NV_packed_depth_stencil 1 - -#define GL_DEPTH_STENCIL_NV 0x84F9 -#define GL_UNSIGNED_INT_24_8_NV 0x84FA - -#define GLEW_NV_packed_depth_stencil GLEW_GET_VAR(__GLEW_NV_packed_depth_stencil) - -#endif /* GL_NV_packed_depth_stencil */ - -/* --------------------- GL_NV_parameter_buffer_object --------------------- */ - -#ifndef GL_NV_parameter_buffer_object -#define GL_NV_parameter_buffer_object 1 - -#define GL_MAX_PROGRAM_PARAMETER_BUFFER_BINDINGS_NV 0x8DA0 -#define GL_MAX_PROGRAM_PARAMETER_BUFFER_SIZE_NV 0x8DA1 -#define GL_VERTEX_PROGRAM_PARAMETER_BUFFER_NV 0x8DA2 -#define GL_GEOMETRY_PROGRAM_PARAMETER_BUFFER_NV 0x8DA3 -#define GL_FRAGMENT_PROGRAM_PARAMETER_BUFFER_NV 0x8DA4 - -typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLfloat *params); - -#define glProgramBufferParametersIivNV GLEW_GET_FUN(__glewProgramBufferParametersIivNV) -#define glProgramBufferParametersIuivNV GLEW_GET_FUN(__glewProgramBufferParametersIuivNV) -#define glProgramBufferParametersfvNV GLEW_GET_FUN(__glewProgramBufferParametersfvNV) - -#define GLEW_NV_parameter_buffer_object GLEW_GET_VAR(__GLEW_NV_parameter_buffer_object) - -#endif /* GL_NV_parameter_buffer_object */ - -/* --------------------- GL_NV_parameter_buffer_object2 -------------------- */ - -#ifndef GL_NV_parameter_buffer_object2 -#define GL_NV_parameter_buffer_object2 1 - -#define GLEW_NV_parameter_buffer_object2 GLEW_GET_VAR(__GLEW_NV_parameter_buffer_object2) - -#endif /* GL_NV_parameter_buffer_object2 */ - -/* ------------------------- GL_NV_pixel_data_range ------------------------ */ - -#ifndef GL_NV_pixel_data_range -#define GL_NV_pixel_data_range 1 - -#define GL_WRITE_PIXEL_DATA_RANGE_NV 0x8878 -#define GL_READ_PIXEL_DATA_RANGE_NV 0x8879 -#define GL_WRITE_PIXEL_DATA_RANGE_LENGTH_NV 0x887A -#define GL_READ_PIXEL_DATA_RANGE_LENGTH_NV 0x887B -#define GL_WRITE_PIXEL_DATA_RANGE_POINTER_NV 0x887C -#define GL_READ_PIXEL_DATA_RANGE_POINTER_NV 0x887D - -typedef void (GLAPIENTRY * PFNGLFLUSHPIXELDATARANGENVPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLPIXELDATARANGENVPROC) (GLenum target, GLsizei length, void* pointer); - -#define glFlushPixelDataRangeNV GLEW_GET_FUN(__glewFlushPixelDataRangeNV) -#define glPixelDataRangeNV GLEW_GET_FUN(__glewPixelDataRangeNV) - -#define GLEW_NV_pixel_data_range GLEW_GET_VAR(__GLEW_NV_pixel_data_range) - -#endif /* GL_NV_pixel_data_range */ - -/* --------------------------- GL_NV_point_sprite -------------------------- */ - -#ifndef GL_NV_point_sprite -#define GL_NV_point_sprite 1 - -#define GL_POINT_SPRITE_NV 0x8861 -#define GL_COORD_REPLACE_NV 0x8862 -#define GL_POINT_SPRITE_R_MODE_NV 0x8863 - -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERINVPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIVNVPROC) (GLenum pname, const GLint* params); - -#define glPointParameteriNV GLEW_GET_FUN(__glewPointParameteriNV) -#define glPointParameterivNV GLEW_GET_FUN(__glewPointParameterivNV) - -#define GLEW_NV_point_sprite GLEW_GET_VAR(__GLEW_NV_point_sprite) - -#endif /* GL_NV_point_sprite */ - -/* -------------------------- GL_NV_present_video -------------------------- */ - -#ifndef GL_NV_present_video -#define GL_NV_present_video 1 - -#define GL_FRAME_NV 0x8E26 -#define GL_FIELDS_NV 0x8E27 -#define GL_CURRENT_TIME_NV 0x8E28 -#define GL_NUM_FILL_STREAMS_NV 0x8E29 -#define GL_PRESENT_TIME_NV 0x8E2A -#define GL_PRESENT_DURATION_NV 0x8E2B - -typedef void (GLAPIENTRY * PFNGLGETVIDEOI64VNVPROC) (GLuint video_slot, GLenum pname, GLint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOIVNVPROC) (GLuint video_slot, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOUI64VNVPROC) (GLuint video_slot, GLenum pname, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOUIVNVPROC) (GLuint video_slot, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLPRESENTFRAMEDUALFILLNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLenum target1, GLuint fill1, GLenum target2, GLuint fill2, GLenum target3, GLuint fill3); -typedef void (GLAPIENTRY * PFNGLPRESENTFRAMEKEYEDNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1); - -#define glGetVideoi64vNV GLEW_GET_FUN(__glewGetVideoi64vNV) -#define glGetVideoivNV GLEW_GET_FUN(__glewGetVideoivNV) -#define glGetVideoui64vNV GLEW_GET_FUN(__glewGetVideoui64vNV) -#define glGetVideouivNV GLEW_GET_FUN(__glewGetVideouivNV) -#define glPresentFrameDualFillNV GLEW_GET_FUN(__glewPresentFrameDualFillNV) -#define glPresentFrameKeyedNV GLEW_GET_FUN(__glewPresentFrameKeyedNV) - -#define GLEW_NV_present_video GLEW_GET_VAR(__GLEW_NV_present_video) - -#endif /* GL_NV_present_video */ - -/* ------------------------ GL_NV_primitive_restart ------------------------ */ - -#ifndef GL_NV_primitive_restart -#define GL_NV_primitive_restart 1 - -#define GL_PRIMITIVE_RESTART_NV 0x8558 -#define GL_PRIMITIVE_RESTART_INDEX_NV 0x8559 - -typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTINDEXNVPROC) (GLuint index); -typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTNVPROC) (void); - -#define glPrimitiveRestartIndexNV GLEW_GET_FUN(__glewPrimitiveRestartIndexNV) -#define glPrimitiveRestartNV GLEW_GET_FUN(__glewPrimitiveRestartNV) - -#define GLEW_NV_primitive_restart GLEW_GET_VAR(__GLEW_NV_primitive_restart) - -#endif /* GL_NV_primitive_restart */ - -/* ------------------------ GL_NV_register_combiners ----------------------- */ - -#ifndef GL_NV_register_combiners -#define GL_NV_register_combiners 1 - -#define GL_REGISTER_COMBINERS_NV 0x8522 -#define GL_VARIABLE_A_NV 0x8523 -#define GL_VARIABLE_B_NV 0x8524 -#define GL_VARIABLE_C_NV 0x8525 -#define GL_VARIABLE_D_NV 0x8526 -#define GL_VARIABLE_E_NV 0x8527 -#define GL_VARIABLE_F_NV 0x8528 -#define GL_VARIABLE_G_NV 0x8529 -#define GL_CONSTANT_COLOR0_NV 0x852A -#define GL_CONSTANT_COLOR1_NV 0x852B -#define GL_PRIMARY_COLOR_NV 0x852C -#define GL_SECONDARY_COLOR_NV 0x852D -#define GL_SPARE0_NV 0x852E -#define GL_SPARE1_NV 0x852F -#define GL_DISCARD_NV 0x8530 -#define GL_E_TIMES_F_NV 0x8531 -#define GL_SPARE0_PLUS_SECONDARY_COLOR_NV 0x8532 -#define GL_UNSIGNED_IDENTITY_NV 0x8536 -#define GL_UNSIGNED_INVERT_NV 0x8537 -#define GL_EXPAND_NORMAL_NV 0x8538 -#define GL_EXPAND_NEGATE_NV 0x8539 -#define GL_HALF_BIAS_NORMAL_NV 0x853A -#define GL_HALF_BIAS_NEGATE_NV 0x853B -#define GL_SIGNED_IDENTITY_NV 0x853C -#define GL_SIGNED_NEGATE_NV 0x853D -#define GL_SCALE_BY_TWO_NV 0x853E -#define GL_SCALE_BY_FOUR_NV 0x853F -#define GL_SCALE_BY_ONE_HALF_NV 0x8540 -#define GL_BIAS_BY_NEGATIVE_ONE_HALF_NV 0x8541 -#define GL_COMBINER_INPUT_NV 0x8542 -#define GL_COMBINER_MAPPING_NV 0x8543 -#define GL_COMBINER_COMPONENT_USAGE_NV 0x8544 -#define GL_COMBINER_AB_DOT_PRODUCT_NV 0x8545 -#define GL_COMBINER_CD_DOT_PRODUCT_NV 0x8546 -#define GL_COMBINER_MUX_SUM_NV 0x8547 -#define GL_COMBINER_SCALE_NV 0x8548 -#define GL_COMBINER_BIAS_NV 0x8549 -#define GL_COMBINER_AB_OUTPUT_NV 0x854A -#define GL_COMBINER_CD_OUTPUT_NV 0x854B -#define GL_COMBINER_SUM_OUTPUT_NV 0x854C -#define GL_MAX_GENERAL_COMBINERS_NV 0x854D -#define GL_NUM_GENERAL_COMBINERS_NV 0x854E -#define GL_COLOR_SUM_CLAMP_NV 0x854F -#define GL_COMBINER0_NV 0x8550 -#define GL_COMBINER1_NV 0x8551 -#define GL_COMBINER2_NV 0x8552 -#define GL_COMBINER3_NV 0x8553 -#define GL_COMBINER4_NV 0x8554 -#define GL_COMBINER5_NV 0x8555 -#define GL_COMBINER6_NV 0x8556 -#define GL_COMBINER7_NV 0x8557 - -typedef void (GLAPIENTRY * PFNGLCOMBINERINPUTNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); -typedef void (GLAPIENTRY * PFNGLCOMBINEROUTPUTNVPROC) (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERFNVPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERFVNVPROC) (GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERINVPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERIVNVPROC) (GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLFINALCOMBINERINPUTNVPROC) (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); -typedef void (GLAPIENTRY * PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC) (GLenum variable, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC) (GLenum variable, GLenum pname, GLint* params); - -#define glCombinerInputNV GLEW_GET_FUN(__glewCombinerInputNV) -#define glCombinerOutputNV GLEW_GET_FUN(__glewCombinerOutputNV) -#define glCombinerParameterfNV GLEW_GET_FUN(__glewCombinerParameterfNV) -#define glCombinerParameterfvNV GLEW_GET_FUN(__glewCombinerParameterfvNV) -#define glCombinerParameteriNV GLEW_GET_FUN(__glewCombinerParameteriNV) -#define glCombinerParameterivNV GLEW_GET_FUN(__glewCombinerParameterivNV) -#define glFinalCombinerInputNV GLEW_GET_FUN(__glewFinalCombinerInputNV) -#define glGetCombinerInputParameterfvNV GLEW_GET_FUN(__glewGetCombinerInputParameterfvNV) -#define glGetCombinerInputParameterivNV GLEW_GET_FUN(__glewGetCombinerInputParameterivNV) -#define glGetCombinerOutputParameterfvNV GLEW_GET_FUN(__glewGetCombinerOutputParameterfvNV) -#define glGetCombinerOutputParameterivNV GLEW_GET_FUN(__glewGetCombinerOutputParameterivNV) -#define glGetFinalCombinerInputParameterfvNV GLEW_GET_FUN(__glewGetFinalCombinerInputParameterfvNV) -#define glGetFinalCombinerInputParameterivNV GLEW_GET_FUN(__glewGetFinalCombinerInputParameterivNV) - -#define GLEW_NV_register_combiners GLEW_GET_VAR(__GLEW_NV_register_combiners) - -#endif /* GL_NV_register_combiners */ - -/* ----------------------- GL_NV_register_combiners2 ----------------------- */ - -#ifndef GL_NV_register_combiners2 -#define GL_NV_register_combiners2 1 - -#define GL_PER_STAGE_CONSTANTS_NV 0x8535 - -typedef void (GLAPIENTRY * PFNGLCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, GLfloat* params); - -#define glCombinerStageParameterfvNV GLEW_GET_FUN(__glewCombinerStageParameterfvNV) -#define glGetCombinerStageParameterfvNV GLEW_GET_FUN(__glewGetCombinerStageParameterfvNV) - -#define GLEW_NV_register_combiners2 GLEW_GET_VAR(__GLEW_NV_register_combiners2) - -#endif /* GL_NV_register_combiners2 */ - -/* ------------------------ GL_NV_shader_buffer_load ----------------------- */ - -#ifndef GL_NV_shader_buffer_load -#define GL_NV_shader_buffer_load 1 - -#define GL_BUFFER_GPU_ADDRESS_NV 0x8F1D -#define GL_GPU_ADDRESS_NV 0x8F34 -#define GL_MAX_SHADER_BUFFER_ADDRESS_NV 0x8F35 - -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERUI64VNVPROC) (GLenum target, GLenum pname, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETINTEGERUI64VNVPROC) (GLenum value, GLuint64EXT* result); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC) (GLuint buffer, GLenum pname, GLuint64EXT* params); -typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERRESIDENTNVPROC) (GLenum target); -typedef GLboolean (GLAPIENTRY * PFNGLISNAMEDBUFFERRESIDENTNVPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLMAKEBUFFERNONRESIDENTNVPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLMAKEBUFFERRESIDENTNVPROC) (GLenum target, GLenum access); -typedef void (GLAPIENTRY * PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLMAKENAMEDBUFFERRESIDENTNVPROC) (GLuint buffer, GLenum access); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMUI64NVPROC) (GLuint program, GLint location, GLuint64EXT value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMUI64NVPROC) (GLint location, GLuint64EXT value); -typedef void (GLAPIENTRY * PFNGLUNIFORMUI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); - -#define glGetBufferParameterui64vNV GLEW_GET_FUN(__glewGetBufferParameterui64vNV) -#define glGetIntegerui64vNV GLEW_GET_FUN(__glewGetIntegerui64vNV) -#define glGetNamedBufferParameterui64vNV GLEW_GET_FUN(__glewGetNamedBufferParameterui64vNV) -#define glIsBufferResidentNV GLEW_GET_FUN(__glewIsBufferResidentNV) -#define glIsNamedBufferResidentNV GLEW_GET_FUN(__glewIsNamedBufferResidentNV) -#define glMakeBufferNonResidentNV GLEW_GET_FUN(__glewMakeBufferNonResidentNV) -#define glMakeBufferResidentNV GLEW_GET_FUN(__glewMakeBufferResidentNV) -#define glMakeNamedBufferNonResidentNV GLEW_GET_FUN(__glewMakeNamedBufferNonResidentNV) -#define glMakeNamedBufferResidentNV GLEW_GET_FUN(__glewMakeNamedBufferResidentNV) -#define glProgramUniformui64NV GLEW_GET_FUN(__glewProgramUniformui64NV) -#define glProgramUniformui64vNV GLEW_GET_FUN(__glewProgramUniformui64vNV) -#define glUniformui64NV GLEW_GET_FUN(__glewUniformui64NV) -#define glUniformui64vNV GLEW_GET_FUN(__glewUniformui64vNV) - -#define GLEW_NV_shader_buffer_load GLEW_GET_VAR(__GLEW_NV_shader_buffer_load) - -#endif /* GL_NV_shader_buffer_load */ - -/* ---------------------- GL_NV_tessellation_program5 ---------------------- */ - -#ifndef GL_NV_tessellation_program5 -#define GL_NV_tessellation_program5 1 - -#define GL_MAX_PROGRAM_PATCH_ATTRIBS_NV 0x86D8 -#define GL_TESS_CONTROL_PROGRAM_NV 0x891E -#define GL_TESS_EVALUATION_PROGRAM_NV 0x891F -#define GL_TESS_CONTROL_PROGRAM_PARAMETER_BUFFER_NV 0x8C74 -#define GL_TESS_EVALUATION_PROGRAM_PARAMETER_BUFFER_NV 0x8C75 - -#define GLEW_NV_tessellation_program5 GLEW_GET_VAR(__GLEW_NV_tessellation_program5) - -#endif /* GL_NV_tessellation_program5 */ - -/* -------------------------- GL_NV_texgen_emboss -------------------------- */ - -#ifndef GL_NV_texgen_emboss -#define GL_NV_texgen_emboss 1 - -#define GL_EMBOSS_LIGHT_NV 0x855D -#define GL_EMBOSS_CONSTANT_NV 0x855E -#define GL_EMBOSS_MAP_NV 0x855F - -#define GLEW_NV_texgen_emboss GLEW_GET_VAR(__GLEW_NV_texgen_emboss) - -#endif /* GL_NV_texgen_emboss */ - -/* ------------------------ GL_NV_texgen_reflection ------------------------ */ - -#ifndef GL_NV_texgen_reflection -#define GL_NV_texgen_reflection 1 - -#define GL_NORMAL_MAP_NV 0x8511 -#define GL_REFLECTION_MAP_NV 0x8512 - -#define GLEW_NV_texgen_reflection GLEW_GET_VAR(__GLEW_NV_texgen_reflection) - -#endif /* GL_NV_texgen_reflection */ - -/* ------------------------- GL_NV_texture_barrier ------------------------- */ - -#ifndef GL_NV_texture_barrier -#define GL_NV_texture_barrier 1 - -typedef void (GLAPIENTRY * PFNGLTEXTUREBARRIERNVPROC) (void); - -#define glTextureBarrierNV GLEW_GET_FUN(__glewTextureBarrierNV) - -#define GLEW_NV_texture_barrier GLEW_GET_VAR(__GLEW_NV_texture_barrier) - -#endif /* GL_NV_texture_barrier */ - -/* --------------------- GL_NV_texture_compression_vtc --------------------- */ - -#ifndef GL_NV_texture_compression_vtc -#define GL_NV_texture_compression_vtc 1 - -#define GLEW_NV_texture_compression_vtc GLEW_GET_VAR(__GLEW_NV_texture_compression_vtc) - -#endif /* GL_NV_texture_compression_vtc */ - -/* ----------------------- GL_NV_texture_env_combine4 ---------------------- */ - -#ifndef GL_NV_texture_env_combine4 -#define GL_NV_texture_env_combine4 1 - -#define GL_COMBINE4_NV 0x8503 -#define GL_SOURCE3_RGB_NV 0x8583 -#define GL_SOURCE3_ALPHA_NV 0x858B -#define GL_OPERAND3_RGB_NV 0x8593 -#define GL_OPERAND3_ALPHA_NV 0x859B - -#define GLEW_NV_texture_env_combine4 GLEW_GET_VAR(__GLEW_NV_texture_env_combine4) - -#endif /* GL_NV_texture_env_combine4 */ - -/* ---------------------- GL_NV_texture_expand_normal ---------------------- */ - -#ifndef GL_NV_texture_expand_normal -#define GL_NV_texture_expand_normal 1 - -#define GL_TEXTURE_UNSIGNED_REMAP_MODE_NV 0x888F - -#define GLEW_NV_texture_expand_normal GLEW_GET_VAR(__GLEW_NV_texture_expand_normal) - -#endif /* GL_NV_texture_expand_normal */ - -/* ----------------------- GL_NV_texture_multisample ----------------------- */ - -#ifndef GL_NV_texture_multisample -#define GL_NV_texture_multisample 1 - -#define GL_TEXTURE_COVERAGE_SAMPLES_NV 0x9045 -#define GL_TEXTURE_COLOR_SAMPLES_NV 0x9046 - -typedef void (GLAPIENTRY * PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC) (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC) (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC) (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC) (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); - -#define glTexImage2DMultisampleCoverageNV GLEW_GET_FUN(__glewTexImage2DMultisampleCoverageNV) -#define glTexImage3DMultisampleCoverageNV GLEW_GET_FUN(__glewTexImage3DMultisampleCoverageNV) -#define glTextureImage2DMultisampleCoverageNV GLEW_GET_FUN(__glewTextureImage2DMultisampleCoverageNV) -#define glTextureImage2DMultisampleNV GLEW_GET_FUN(__glewTextureImage2DMultisampleNV) -#define glTextureImage3DMultisampleCoverageNV GLEW_GET_FUN(__glewTextureImage3DMultisampleCoverageNV) -#define glTextureImage3DMultisampleNV GLEW_GET_FUN(__glewTextureImage3DMultisampleNV) - -#define GLEW_NV_texture_multisample GLEW_GET_VAR(__GLEW_NV_texture_multisample) - -#endif /* GL_NV_texture_multisample */ - -/* ------------------------ GL_NV_texture_rectangle ------------------------ */ - -#ifndef GL_NV_texture_rectangle -#define GL_NV_texture_rectangle 1 - -#define GL_TEXTURE_RECTANGLE_NV 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_NV 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_NV 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_NV 0x84F8 - -#define GLEW_NV_texture_rectangle GLEW_GET_VAR(__GLEW_NV_texture_rectangle) - -#endif /* GL_NV_texture_rectangle */ - -/* -------------------------- GL_NV_texture_shader ------------------------- */ - -#ifndef GL_NV_texture_shader -#define GL_NV_texture_shader 1 - -#define GL_OFFSET_TEXTURE_RECTANGLE_NV 0x864C -#define GL_OFFSET_TEXTURE_RECTANGLE_SCALE_NV 0x864D -#define GL_DOT_PRODUCT_TEXTURE_RECTANGLE_NV 0x864E -#define GL_RGBA_UNSIGNED_DOT_PRODUCT_MAPPING_NV 0x86D9 -#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA -#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB -#define GL_DSDT_MAG_INTENSITY_NV 0x86DC -#define GL_SHADER_CONSISTENT_NV 0x86DD -#define GL_TEXTURE_SHADER_NV 0x86DE -#define GL_SHADER_OPERATION_NV 0x86DF -#define GL_CULL_MODES_NV 0x86E0 -#define GL_OFFSET_TEXTURE_2D_MATRIX_NV 0x86E1 -#define GL_OFFSET_TEXTURE_MATRIX_NV 0x86E1 -#define GL_OFFSET_TEXTURE_2D_SCALE_NV 0x86E2 -#define GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 -#define GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 -#define GL_OFFSET_TEXTURE_2D_BIAS_NV 0x86E3 -#define GL_PREVIOUS_TEXTURE_INPUT_NV 0x86E4 -#define GL_CONST_EYE_NV 0x86E5 -#define GL_PASS_THROUGH_NV 0x86E6 -#define GL_CULL_FRAGMENT_NV 0x86E7 -#define GL_OFFSET_TEXTURE_2D_NV 0x86E8 -#define GL_DEPENDENT_AR_TEXTURE_2D_NV 0x86E9 -#define GL_DEPENDENT_GB_TEXTURE_2D_NV 0x86EA -#define GL_DOT_PRODUCT_NV 0x86EC -#define GL_DOT_PRODUCT_DEPTH_REPLACE_NV 0x86ED -#define GL_DOT_PRODUCT_TEXTURE_2D_NV 0x86EE -#define GL_DOT_PRODUCT_TEXTURE_CUBE_MAP_NV 0x86F0 -#define GL_DOT_PRODUCT_DIFFUSE_CUBE_MAP_NV 0x86F1 -#define GL_DOT_PRODUCT_REFLECT_CUBE_MAP_NV 0x86F2 -#define GL_DOT_PRODUCT_CONST_EYE_REFLECT_CUBE_MAP_NV 0x86F3 -#define GL_HILO_NV 0x86F4 -#define GL_DSDT_NV 0x86F5 -#define GL_DSDT_MAG_NV 0x86F6 -#define GL_DSDT_MAG_VIB_NV 0x86F7 -#define GL_HILO16_NV 0x86F8 -#define GL_SIGNED_HILO_NV 0x86F9 -#define GL_SIGNED_HILO16_NV 0x86FA -#define GL_SIGNED_RGBA_NV 0x86FB -#define GL_SIGNED_RGBA8_NV 0x86FC -#define GL_SIGNED_RGB_NV 0x86FE -#define GL_SIGNED_RGB8_NV 0x86FF -#define GL_SIGNED_LUMINANCE_NV 0x8701 -#define GL_SIGNED_LUMINANCE8_NV 0x8702 -#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 -#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 -#define GL_SIGNED_ALPHA_NV 0x8705 -#define GL_SIGNED_ALPHA8_NV 0x8706 -#define GL_SIGNED_INTENSITY_NV 0x8707 -#define GL_SIGNED_INTENSITY8_NV 0x8708 -#define GL_DSDT8_NV 0x8709 -#define GL_DSDT8_MAG8_NV 0x870A -#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B -#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C -#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D -#define GL_HI_SCALE_NV 0x870E -#define GL_LO_SCALE_NV 0x870F -#define GL_DS_SCALE_NV 0x8710 -#define GL_DT_SCALE_NV 0x8711 -#define GL_MAGNITUDE_SCALE_NV 0x8712 -#define GL_VIBRANCE_SCALE_NV 0x8713 -#define GL_HI_BIAS_NV 0x8714 -#define GL_LO_BIAS_NV 0x8715 -#define GL_DS_BIAS_NV 0x8716 -#define GL_DT_BIAS_NV 0x8717 -#define GL_MAGNITUDE_BIAS_NV 0x8718 -#define GL_VIBRANCE_BIAS_NV 0x8719 -#define GL_TEXTURE_BORDER_VALUES_NV 0x871A -#define GL_TEXTURE_HI_SIZE_NV 0x871B -#define GL_TEXTURE_LO_SIZE_NV 0x871C -#define GL_TEXTURE_DS_SIZE_NV 0x871D -#define GL_TEXTURE_DT_SIZE_NV 0x871E -#define GL_TEXTURE_MAG_SIZE_NV 0x871F - -#define GLEW_NV_texture_shader GLEW_GET_VAR(__GLEW_NV_texture_shader) - -#endif /* GL_NV_texture_shader */ - -/* ------------------------- GL_NV_texture_shader2 ------------------------- */ - -#ifndef GL_NV_texture_shader2 -#define GL_NV_texture_shader2 1 - -#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA -#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB -#define GL_DSDT_MAG_INTENSITY_NV 0x86DC -#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF -#define GL_HILO_NV 0x86F4 -#define GL_DSDT_NV 0x86F5 -#define GL_DSDT_MAG_NV 0x86F6 -#define GL_DSDT_MAG_VIB_NV 0x86F7 -#define GL_HILO16_NV 0x86F8 -#define GL_SIGNED_HILO_NV 0x86F9 -#define GL_SIGNED_HILO16_NV 0x86FA -#define GL_SIGNED_RGBA_NV 0x86FB -#define GL_SIGNED_RGBA8_NV 0x86FC -#define GL_SIGNED_RGB_NV 0x86FE -#define GL_SIGNED_RGB8_NV 0x86FF -#define GL_SIGNED_LUMINANCE_NV 0x8701 -#define GL_SIGNED_LUMINANCE8_NV 0x8702 -#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 -#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 -#define GL_SIGNED_ALPHA_NV 0x8705 -#define GL_SIGNED_ALPHA8_NV 0x8706 -#define GL_SIGNED_INTENSITY_NV 0x8707 -#define GL_SIGNED_INTENSITY8_NV 0x8708 -#define GL_DSDT8_NV 0x8709 -#define GL_DSDT8_MAG8_NV 0x870A -#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B -#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C -#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D - -#define GLEW_NV_texture_shader2 GLEW_GET_VAR(__GLEW_NV_texture_shader2) - -#endif /* GL_NV_texture_shader2 */ - -/* ------------------------- GL_NV_texture_shader3 ------------------------- */ - -#ifndef GL_NV_texture_shader3 -#define GL_NV_texture_shader3 1 - -#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_NV 0x8850 -#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_SCALE_NV 0x8851 -#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8852 -#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_SCALE_NV 0x8853 -#define GL_OFFSET_HILO_TEXTURE_2D_NV 0x8854 -#define GL_OFFSET_HILO_TEXTURE_RECTANGLE_NV 0x8855 -#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_2D_NV 0x8856 -#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8857 -#define GL_DEPENDENT_HILO_TEXTURE_2D_NV 0x8858 -#define GL_DEPENDENT_RGB_TEXTURE_3D_NV 0x8859 -#define GL_DEPENDENT_RGB_TEXTURE_CUBE_MAP_NV 0x885A -#define GL_DOT_PRODUCT_PASS_THROUGH_NV 0x885B -#define GL_DOT_PRODUCT_TEXTURE_1D_NV 0x885C -#define GL_DOT_PRODUCT_AFFINE_DEPTH_REPLACE_NV 0x885D -#define GL_HILO8_NV 0x885E -#define GL_SIGNED_HILO8_NV 0x885F -#define GL_FORCE_BLUE_TO_ONE_NV 0x8860 - -#define GLEW_NV_texture_shader3 GLEW_GET_VAR(__GLEW_NV_texture_shader3) - -#endif /* GL_NV_texture_shader3 */ - -/* ------------------------ GL_NV_transform_feedback ----------------------- */ - -#ifndef GL_NV_transform_feedback -#define GL_NV_transform_feedback 1 - -#define GL_BACK_PRIMARY_COLOR_NV 0x8C77 -#define GL_BACK_SECONDARY_COLOR_NV 0x8C78 -#define GL_TEXTURE_COORD_NV 0x8C79 -#define GL_CLIP_DISTANCE_NV 0x8C7A -#define GL_VERTEX_ID_NV 0x8C7B -#define GL_PRIMITIVE_ID_NV 0x8C7C -#define GL_GENERIC_ATTRIB_NV 0x8C7D -#define GL_TRANSFORM_FEEDBACK_ATTRIBS_NV 0x8C7E -#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_NV 0x8C7F -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_NV 0x8C80 -#define GL_ACTIVE_VARYINGS_NV 0x8C81 -#define GL_ACTIVE_VARYING_MAX_LENGTH_NV 0x8C82 -#define GL_TRANSFORM_FEEDBACK_VARYINGS_NV 0x8C83 -#define GL_TRANSFORM_FEEDBACK_BUFFER_START_NV 0x8C84 -#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_NV 0x8C85 -#define GL_TRANSFORM_FEEDBACK_RECORD_NV 0x8C86 -#define GL_PRIMITIVES_GENERATED_NV 0x8C87 -#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_NV 0x8C88 -#define GL_RASTERIZER_DISCARD_NV 0x8C89 -#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_NV 0x8C8A -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_NV 0x8C8B -#define GL_INTERLEAVED_ATTRIBS_NV 0x8C8C -#define GL_SEPARATE_ATTRIBS_NV 0x8C8D -#define GL_TRANSFORM_FEEDBACK_BUFFER_NV 0x8C8E -#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_NV 0x8C8F - -typedef void (GLAPIENTRY * PFNGLACTIVEVARYINGNVPROC) (GLuint program, const GLchar *name); -typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKNVPROC) (GLenum primitiveMode); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASENVPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBINDBUFFEROFFSETNVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGENVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETACTIVEVARYINGNVPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC) (GLuint program, GLuint index, GLint *location); -typedef GLint (GLAPIENTRY * PFNGLGETVARYINGLOCATIONNVPROC) (GLuint program, const GLchar *name); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC) (GLuint count, const GLint *attribs, GLenum bufferMode); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC) (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode); - -#define glActiveVaryingNV GLEW_GET_FUN(__glewActiveVaryingNV) -#define glBeginTransformFeedbackNV GLEW_GET_FUN(__glewBeginTransformFeedbackNV) -#define glBindBufferBaseNV GLEW_GET_FUN(__glewBindBufferBaseNV) -#define glBindBufferOffsetNV GLEW_GET_FUN(__glewBindBufferOffsetNV) -#define glBindBufferRangeNV GLEW_GET_FUN(__glewBindBufferRangeNV) -#define glEndTransformFeedbackNV GLEW_GET_FUN(__glewEndTransformFeedbackNV) -#define glGetActiveVaryingNV GLEW_GET_FUN(__glewGetActiveVaryingNV) -#define glGetTransformFeedbackVaryingNV GLEW_GET_FUN(__glewGetTransformFeedbackVaryingNV) -#define glGetVaryingLocationNV GLEW_GET_FUN(__glewGetVaryingLocationNV) -#define glTransformFeedbackAttribsNV GLEW_GET_FUN(__glewTransformFeedbackAttribsNV) -#define glTransformFeedbackVaryingsNV GLEW_GET_FUN(__glewTransformFeedbackVaryingsNV) - -#define GLEW_NV_transform_feedback GLEW_GET_VAR(__GLEW_NV_transform_feedback) - -#endif /* GL_NV_transform_feedback */ - -/* ----------------------- GL_NV_transform_feedback2 ----------------------- */ - -#ifndef GL_NV_transform_feedback2 -#define GL_NV_transform_feedback2 1 - -#define GL_TRANSFORM_FEEDBACK_NV 0x8E22 -#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED_NV 0x8E23 -#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE_NV 0x8E24 -#define GL_TRANSFORM_FEEDBACK_BINDING_NV 0x8E25 - -typedef void (GLAPIENTRY * PFNGLBINDTRANSFORMFEEDBACKNVPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETETRANSFORMFEEDBACKSNVPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKNVPROC) (GLenum mode, GLuint id); -typedef void (GLAPIENTRY * PFNGLGENTRANSFORMFEEDBACKSNVPROC) (GLsizei n, GLuint* ids); -typedef GLboolean (GLAPIENTRY * PFNGLISTRANSFORMFEEDBACKNVPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLPAUSETRANSFORMFEEDBACKNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLRESUMETRANSFORMFEEDBACKNVPROC) (void); - -#define glBindTransformFeedbackNV GLEW_GET_FUN(__glewBindTransformFeedbackNV) -#define glDeleteTransformFeedbacksNV GLEW_GET_FUN(__glewDeleteTransformFeedbacksNV) -#define glDrawTransformFeedbackNV GLEW_GET_FUN(__glewDrawTransformFeedbackNV) -#define glGenTransformFeedbacksNV GLEW_GET_FUN(__glewGenTransformFeedbacksNV) -#define glIsTransformFeedbackNV GLEW_GET_FUN(__glewIsTransformFeedbackNV) -#define glPauseTransformFeedbackNV GLEW_GET_FUN(__glewPauseTransformFeedbackNV) -#define glResumeTransformFeedbackNV GLEW_GET_FUN(__glewResumeTransformFeedbackNV) - -#define GLEW_NV_transform_feedback2 GLEW_GET_VAR(__GLEW_NV_transform_feedback2) - -#endif /* GL_NV_transform_feedback2 */ - -/* -------------------------- GL_NV_vdpau_interop -------------------------- */ - -#ifndef GL_NV_vdpau_interop -#define GL_NV_vdpau_interop 1 - -#define GL_SURFACE_STATE_NV 0x86EB -#define GL_SURFACE_REGISTERED_NV 0x86FD -#define GL_SURFACE_MAPPED_NV 0x8700 -#define GL_WRITE_DISCARD_NV 0x88BE - -typedef GLintptr GLvdpauSurfaceNV; - -typedef void (GLAPIENTRY * PFNGLVDPAUFININVPROC) (void); -typedef void (GLAPIENTRY * PFNGLVDPAUGETSURFACEIVNVPROC) (GLvdpauSurfaceNV surface, GLenum pname, GLsizei bufSize, GLsizei* length, GLint *values); -typedef void (GLAPIENTRY * PFNGLVDPAUINITNVPROC) (const void* vdpDevice, const GLvoid*getProcAddress); -typedef void (GLAPIENTRY * PFNGLVDPAUISSURFACENVPROC) (GLvdpauSurfaceNV surface); -typedef void (GLAPIENTRY * PFNGLVDPAUMAPSURFACESNVPROC) (GLsizei numSurfaces, const GLvdpauSurfaceNV* surfaces); -typedef GLvdpauSurfaceNV (GLAPIENTRY * PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC) (const void* vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); -typedef GLvdpauSurfaceNV (GLAPIENTRY * PFNGLVDPAUREGISTERVIDEOSURFACENVPROC) (const void* vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); -typedef void (GLAPIENTRY * PFNGLVDPAUSURFACEACCESSNVPROC) (GLvdpauSurfaceNV surface, GLenum access); -typedef void (GLAPIENTRY * PFNGLVDPAUUNMAPSURFACESNVPROC) (GLsizei numSurface, const GLvdpauSurfaceNV* surfaces); -typedef void (GLAPIENTRY * PFNGLVDPAUUNREGISTERSURFACENVPROC) (GLvdpauSurfaceNV surface); - -#define glVDPAUFiniNV GLEW_GET_FUN(__glewVDPAUFiniNV) -#define glVDPAUGetSurfaceivNV GLEW_GET_FUN(__glewVDPAUGetSurfaceivNV) -#define glVDPAUInitNV GLEW_GET_FUN(__glewVDPAUInitNV) -#define glVDPAUIsSurfaceNV GLEW_GET_FUN(__glewVDPAUIsSurfaceNV) -#define glVDPAUMapSurfacesNV GLEW_GET_FUN(__glewVDPAUMapSurfacesNV) -#define glVDPAURegisterOutputSurfaceNV GLEW_GET_FUN(__glewVDPAURegisterOutputSurfaceNV) -#define glVDPAURegisterVideoSurfaceNV GLEW_GET_FUN(__glewVDPAURegisterVideoSurfaceNV) -#define glVDPAUSurfaceAccessNV GLEW_GET_FUN(__glewVDPAUSurfaceAccessNV) -#define glVDPAUUnmapSurfacesNV GLEW_GET_FUN(__glewVDPAUUnmapSurfacesNV) -#define glVDPAUUnregisterSurfaceNV GLEW_GET_FUN(__glewVDPAUUnregisterSurfaceNV) - -#define GLEW_NV_vdpau_interop GLEW_GET_VAR(__GLEW_NV_vdpau_interop) - -#endif /* GL_NV_vdpau_interop */ - -/* ------------------------ GL_NV_vertex_array_range ----------------------- */ - -#ifndef GL_NV_vertex_array_range -#define GL_NV_vertex_array_range 1 - -#define GL_VERTEX_ARRAY_RANGE_NV 0x851D -#define GL_VERTEX_ARRAY_RANGE_LENGTH_NV 0x851E -#define GL_VERTEX_ARRAY_RANGE_VALID_NV 0x851F -#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_NV 0x8520 -#define GL_VERTEX_ARRAY_RANGE_POINTER_NV 0x8521 - -typedef void (GLAPIENTRY * PFNGLFLUSHVERTEXARRAYRANGENVPROC) (void); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYRANGENVPROC) (GLsizei length, void* pointer); - -#define glFlushVertexArrayRangeNV GLEW_GET_FUN(__glewFlushVertexArrayRangeNV) -#define glVertexArrayRangeNV GLEW_GET_FUN(__glewVertexArrayRangeNV) - -#define GLEW_NV_vertex_array_range GLEW_GET_VAR(__GLEW_NV_vertex_array_range) - -#endif /* GL_NV_vertex_array_range */ - -/* ----------------------- GL_NV_vertex_array_range2 ----------------------- */ - -#ifndef GL_NV_vertex_array_range2 -#define GL_NV_vertex_array_range2 1 - -#define GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 - -#define GLEW_NV_vertex_array_range2 GLEW_GET_VAR(__GLEW_NV_vertex_array_range2) - -#endif /* GL_NV_vertex_array_range2 */ - -/* ------------------- GL_NV_vertex_attrib_integer_64bit ------------------- */ - -#ifndef GL_NV_vertex_attrib_integer_64bit -#define GL_NV_vertex_attrib_integer_64bit 1 - -#define GL_INT64_NV 0x140E -#define GL_UNSIGNED_INT64_NV 0x140F - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLI64VNVPROC) (GLuint index, GLenum pname, GLint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLUI64VNVPROC) (GLuint index, GLenum pname, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1I64NVPROC) (GLuint index, GLint64EXT x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64NVPROC) (GLuint index, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); - -#define glGetVertexAttribLi64vNV GLEW_GET_FUN(__glewGetVertexAttribLi64vNV) -#define glGetVertexAttribLui64vNV GLEW_GET_FUN(__glewGetVertexAttribLui64vNV) -#define glVertexAttribL1i64NV GLEW_GET_FUN(__glewVertexAttribL1i64NV) -#define glVertexAttribL1i64vNV GLEW_GET_FUN(__glewVertexAttribL1i64vNV) -#define glVertexAttribL1ui64NV GLEW_GET_FUN(__glewVertexAttribL1ui64NV) -#define glVertexAttribL1ui64vNV GLEW_GET_FUN(__glewVertexAttribL1ui64vNV) -#define glVertexAttribL2i64NV GLEW_GET_FUN(__glewVertexAttribL2i64NV) -#define glVertexAttribL2i64vNV GLEW_GET_FUN(__glewVertexAttribL2i64vNV) -#define glVertexAttribL2ui64NV GLEW_GET_FUN(__glewVertexAttribL2ui64NV) -#define glVertexAttribL2ui64vNV GLEW_GET_FUN(__glewVertexAttribL2ui64vNV) -#define glVertexAttribL3i64NV GLEW_GET_FUN(__glewVertexAttribL3i64NV) -#define glVertexAttribL3i64vNV GLEW_GET_FUN(__glewVertexAttribL3i64vNV) -#define glVertexAttribL3ui64NV GLEW_GET_FUN(__glewVertexAttribL3ui64NV) -#define glVertexAttribL3ui64vNV GLEW_GET_FUN(__glewVertexAttribL3ui64vNV) -#define glVertexAttribL4i64NV GLEW_GET_FUN(__glewVertexAttribL4i64NV) -#define glVertexAttribL4i64vNV GLEW_GET_FUN(__glewVertexAttribL4i64vNV) -#define glVertexAttribL4ui64NV GLEW_GET_FUN(__glewVertexAttribL4ui64NV) -#define glVertexAttribL4ui64vNV GLEW_GET_FUN(__glewVertexAttribL4ui64vNV) -#define glVertexAttribLFormatNV GLEW_GET_FUN(__glewVertexAttribLFormatNV) - -#define GLEW_NV_vertex_attrib_integer_64bit GLEW_GET_VAR(__GLEW_NV_vertex_attrib_integer_64bit) - -#endif /* GL_NV_vertex_attrib_integer_64bit */ - -/* ------------------- GL_NV_vertex_buffer_unified_memory ------------------ */ - -#ifndef GL_NV_vertex_buffer_unified_memory -#define GL_NV_vertex_buffer_unified_memory 1 - -#define GL_VERTEX_ATTRIB_ARRAY_UNIFIED_NV 0x8F1E -#define GL_ELEMENT_ARRAY_UNIFIED_NV 0x8F1F -#define GL_VERTEX_ATTRIB_ARRAY_ADDRESS_NV 0x8F20 -#define GL_VERTEX_ARRAY_ADDRESS_NV 0x8F21 -#define GL_NORMAL_ARRAY_ADDRESS_NV 0x8F22 -#define GL_COLOR_ARRAY_ADDRESS_NV 0x8F23 -#define GL_INDEX_ARRAY_ADDRESS_NV 0x8F24 -#define GL_TEXTURE_COORD_ARRAY_ADDRESS_NV 0x8F25 -#define GL_EDGE_FLAG_ARRAY_ADDRESS_NV 0x8F26 -#define GL_SECONDARY_COLOR_ARRAY_ADDRESS_NV 0x8F27 -#define GL_FOG_COORD_ARRAY_ADDRESS_NV 0x8F28 -#define GL_ELEMENT_ARRAY_ADDRESS_NV 0x8F29 -#define GL_VERTEX_ATTRIB_ARRAY_LENGTH_NV 0x8F2A -#define GL_VERTEX_ARRAY_LENGTH_NV 0x8F2B -#define GL_NORMAL_ARRAY_LENGTH_NV 0x8F2C -#define GL_COLOR_ARRAY_LENGTH_NV 0x8F2D -#define GL_INDEX_ARRAY_LENGTH_NV 0x8F2E -#define GL_TEXTURE_COORD_ARRAY_LENGTH_NV 0x8F2F -#define GL_EDGE_FLAG_ARRAY_LENGTH_NV 0x8F30 -#define GL_SECONDARY_COLOR_ARRAY_LENGTH_NV 0x8F31 -#define GL_FOG_COORD_ARRAY_LENGTH_NV 0x8F32 -#define GL_ELEMENT_ARRAY_LENGTH_NV 0x8F33 -#define GL_DRAW_INDIRECT_UNIFIED_NV 0x8F40 -#define GL_DRAW_INDIRECT_ADDRESS_NV 0x8F41 -#define GL_DRAW_INDIRECT_LENGTH_NV 0x8F42 - -typedef void (GLAPIENTRY * PFNGLBUFFERADDRESSRANGENVPROC) (GLenum pname, GLuint index, GLuint64EXT address, GLsizeiptr length); -typedef void (GLAPIENTRY * PFNGLCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGFORMATNVPROC) (GLsizei stride); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFORMATNVPROC) (GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLGETINTEGERUI64I_VNVPROC) (GLenum value, GLuint index, GLuint64EXT result[]); -typedef void (GLAPIENTRY * PFNGLINDEXFORMATNVPROC) (GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLNORMALFORMATNVPROC) (GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLTEXCOORDFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); - -#define glBufferAddressRangeNV GLEW_GET_FUN(__glewBufferAddressRangeNV) -#define glColorFormatNV GLEW_GET_FUN(__glewColorFormatNV) -#define glEdgeFlagFormatNV GLEW_GET_FUN(__glewEdgeFlagFormatNV) -#define glFogCoordFormatNV GLEW_GET_FUN(__glewFogCoordFormatNV) -#define glGetIntegerui64i_vNV GLEW_GET_FUN(__glewGetIntegerui64i_vNV) -#define glIndexFormatNV GLEW_GET_FUN(__glewIndexFormatNV) -#define glNormalFormatNV GLEW_GET_FUN(__glewNormalFormatNV) -#define glSecondaryColorFormatNV GLEW_GET_FUN(__glewSecondaryColorFormatNV) -#define glTexCoordFormatNV GLEW_GET_FUN(__glewTexCoordFormatNV) -#define glVertexAttribFormatNV GLEW_GET_FUN(__glewVertexAttribFormatNV) -#define glVertexAttribIFormatNV GLEW_GET_FUN(__glewVertexAttribIFormatNV) -#define glVertexFormatNV GLEW_GET_FUN(__glewVertexFormatNV) - -#define GLEW_NV_vertex_buffer_unified_memory GLEW_GET_VAR(__GLEW_NV_vertex_buffer_unified_memory) - -#endif /* GL_NV_vertex_buffer_unified_memory */ - -/* -------------------------- GL_NV_vertex_program ------------------------- */ - -#ifndef GL_NV_vertex_program -#define GL_NV_vertex_program 1 - -#define GL_VERTEX_PROGRAM_NV 0x8620 -#define GL_VERTEX_STATE_PROGRAM_NV 0x8621 -#define GL_ATTRIB_ARRAY_SIZE_NV 0x8623 -#define GL_ATTRIB_ARRAY_STRIDE_NV 0x8624 -#define GL_ATTRIB_ARRAY_TYPE_NV 0x8625 -#define GL_CURRENT_ATTRIB_NV 0x8626 -#define GL_PROGRAM_LENGTH_NV 0x8627 -#define GL_PROGRAM_STRING_NV 0x8628 -#define GL_MODELVIEW_PROJECTION_NV 0x8629 -#define GL_IDENTITY_NV 0x862A -#define GL_INVERSE_NV 0x862B -#define GL_TRANSPOSE_NV 0x862C -#define GL_INVERSE_TRANSPOSE_NV 0x862D -#define GL_MAX_TRACK_MATRIX_STACK_DEPTH_NV 0x862E -#define GL_MAX_TRACK_MATRICES_NV 0x862F -#define GL_MATRIX0_NV 0x8630 -#define GL_MATRIX1_NV 0x8631 -#define GL_MATRIX2_NV 0x8632 -#define GL_MATRIX3_NV 0x8633 -#define GL_MATRIX4_NV 0x8634 -#define GL_MATRIX5_NV 0x8635 -#define GL_MATRIX6_NV 0x8636 -#define GL_MATRIX7_NV 0x8637 -#define GL_CURRENT_MATRIX_STACK_DEPTH_NV 0x8640 -#define GL_CURRENT_MATRIX_NV 0x8641 -#define GL_VERTEX_PROGRAM_POINT_SIZE_NV 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE_NV 0x8643 -#define GL_PROGRAM_PARAMETER_NV 0x8644 -#define GL_ATTRIB_ARRAY_POINTER_NV 0x8645 -#define GL_PROGRAM_TARGET_NV 0x8646 -#define GL_PROGRAM_RESIDENT_NV 0x8647 -#define GL_TRACK_MATRIX_NV 0x8648 -#define GL_TRACK_MATRIX_TRANSFORM_NV 0x8649 -#define GL_VERTEX_PROGRAM_BINDING_NV 0x864A -#define GL_PROGRAM_ERROR_POSITION_NV 0x864B -#define GL_VERTEX_ATTRIB_ARRAY0_NV 0x8650 -#define GL_VERTEX_ATTRIB_ARRAY1_NV 0x8651 -#define GL_VERTEX_ATTRIB_ARRAY2_NV 0x8652 -#define GL_VERTEX_ATTRIB_ARRAY3_NV 0x8653 -#define GL_VERTEX_ATTRIB_ARRAY4_NV 0x8654 -#define GL_VERTEX_ATTRIB_ARRAY5_NV 0x8655 -#define GL_VERTEX_ATTRIB_ARRAY6_NV 0x8656 -#define GL_VERTEX_ATTRIB_ARRAY7_NV 0x8657 -#define GL_VERTEX_ATTRIB_ARRAY8_NV 0x8658 -#define GL_VERTEX_ATTRIB_ARRAY9_NV 0x8659 -#define GL_VERTEX_ATTRIB_ARRAY10_NV 0x865A -#define GL_VERTEX_ATTRIB_ARRAY11_NV 0x865B -#define GL_VERTEX_ATTRIB_ARRAY12_NV 0x865C -#define GL_VERTEX_ATTRIB_ARRAY13_NV 0x865D -#define GL_VERTEX_ATTRIB_ARRAY14_NV 0x865E -#define GL_VERTEX_ATTRIB_ARRAY15_NV 0x865F -#define GL_MAP1_VERTEX_ATTRIB0_4_NV 0x8660 -#define GL_MAP1_VERTEX_ATTRIB1_4_NV 0x8661 -#define GL_MAP1_VERTEX_ATTRIB2_4_NV 0x8662 -#define GL_MAP1_VERTEX_ATTRIB3_4_NV 0x8663 -#define GL_MAP1_VERTEX_ATTRIB4_4_NV 0x8664 -#define GL_MAP1_VERTEX_ATTRIB5_4_NV 0x8665 -#define GL_MAP1_VERTEX_ATTRIB6_4_NV 0x8666 -#define GL_MAP1_VERTEX_ATTRIB7_4_NV 0x8667 -#define GL_MAP1_VERTEX_ATTRIB8_4_NV 0x8668 -#define GL_MAP1_VERTEX_ATTRIB9_4_NV 0x8669 -#define GL_MAP1_VERTEX_ATTRIB10_4_NV 0x866A -#define GL_MAP1_VERTEX_ATTRIB11_4_NV 0x866B -#define GL_MAP1_VERTEX_ATTRIB12_4_NV 0x866C -#define GL_MAP1_VERTEX_ATTRIB13_4_NV 0x866D -#define GL_MAP1_VERTEX_ATTRIB14_4_NV 0x866E -#define GL_MAP1_VERTEX_ATTRIB15_4_NV 0x866F -#define GL_MAP2_VERTEX_ATTRIB0_4_NV 0x8670 -#define GL_MAP2_VERTEX_ATTRIB1_4_NV 0x8671 -#define GL_MAP2_VERTEX_ATTRIB2_4_NV 0x8672 -#define GL_MAP2_VERTEX_ATTRIB3_4_NV 0x8673 -#define GL_MAP2_VERTEX_ATTRIB4_4_NV 0x8674 -#define GL_MAP2_VERTEX_ATTRIB5_4_NV 0x8675 -#define GL_MAP2_VERTEX_ATTRIB6_4_NV 0x8676 -#define GL_MAP2_VERTEX_ATTRIB7_4_NV 0x8677 -#define GL_MAP2_VERTEX_ATTRIB8_4_NV 0x8678 -#define GL_MAP2_VERTEX_ATTRIB9_4_NV 0x8679 -#define GL_MAP2_VERTEX_ATTRIB10_4_NV 0x867A -#define GL_MAP2_VERTEX_ATTRIB11_4_NV 0x867B -#define GL_MAP2_VERTEX_ATTRIB12_4_NV 0x867C -#define GL_MAP2_VERTEX_ATTRIB13_4_NV 0x867D -#define GL_MAP2_VERTEX_ATTRIB14_4_NV 0x867E -#define GL_MAP2_VERTEX_ATTRIB15_4_NV 0x867F - -typedef GLboolean (GLAPIENTRY * PFNGLAREPROGRAMSRESIDENTNVPROC) (GLsizei n, const GLuint* ids, GLboolean *residences); -typedef void (GLAPIENTRY * PFNGLBINDPROGRAMNVPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMSNVPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLEXECUTEPROGRAMNVPROC) (GLenum target, GLuint id, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGENPROGRAMSNVPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPARAMETERDVNVPROC) (GLenum target, GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTRINGNVPROC) (GLuint id, GLenum pname, GLubyte* program); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVNVPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETTRACKMATRIXIVNVPROC) (GLenum target, GLuint address, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVNVPROC) (GLuint index, GLenum pname, GLvoid** pointer); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVNVPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVNVPROC) (GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVNVPROC) (GLuint index, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMNVPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLLOADPROGRAMNVPROC) (GLenum target, GLuint id, GLsizei len, const GLubyte* program); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4DNVPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4DVNVPROC) (GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4FNVPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4FVNVPROC) (GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERS4DVNVPROC) (GLenum target, GLuint index, GLsizei num, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERS4FVNVPROC) (GLenum target, GLuint index, GLsizei num, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLREQUESTRESIDENTPROGRAMSNVPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLTRACKMATRIXNVPROC) (GLenum target, GLuint address, GLenum matrix, GLenum transform); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DNVPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FNVPROC) (GLuint index, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SNVPROC) (GLuint index, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DNVPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FNVPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SNVPROC) (GLuint index, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBNVPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVNVPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4UBVNVPROC) (GLuint index, GLsizei n, const GLubyte* v); - -#define glAreProgramsResidentNV GLEW_GET_FUN(__glewAreProgramsResidentNV) -#define glBindProgramNV GLEW_GET_FUN(__glewBindProgramNV) -#define glDeleteProgramsNV GLEW_GET_FUN(__glewDeleteProgramsNV) -#define glExecuteProgramNV GLEW_GET_FUN(__glewExecuteProgramNV) -#define glGenProgramsNV GLEW_GET_FUN(__glewGenProgramsNV) -#define glGetProgramParameterdvNV GLEW_GET_FUN(__glewGetProgramParameterdvNV) -#define glGetProgramParameterfvNV GLEW_GET_FUN(__glewGetProgramParameterfvNV) -#define glGetProgramStringNV GLEW_GET_FUN(__glewGetProgramStringNV) -#define glGetProgramivNV GLEW_GET_FUN(__glewGetProgramivNV) -#define glGetTrackMatrixivNV GLEW_GET_FUN(__glewGetTrackMatrixivNV) -#define glGetVertexAttribPointervNV GLEW_GET_FUN(__glewGetVertexAttribPointervNV) -#define glGetVertexAttribdvNV GLEW_GET_FUN(__glewGetVertexAttribdvNV) -#define glGetVertexAttribfvNV GLEW_GET_FUN(__glewGetVertexAttribfvNV) -#define glGetVertexAttribivNV GLEW_GET_FUN(__glewGetVertexAttribivNV) -#define glIsProgramNV GLEW_GET_FUN(__glewIsProgramNV) -#define glLoadProgramNV GLEW_GET_FUN(__glewLoadProgramNV) -#define glProgramParameter4dNV GLEW_GET_FUN(__glewProgramParameter4dNV) -#define glProgramParameter4dvNV GLEW_GET_FUN(__glewProgramParameter4dvNV) -#define glProgramParameter4fNV GLEW_GET_FUN(__glewProgramParameter4fNV) -#define glProgramParameter4fvNV GLEW_GET_FUN(__glewProgramParameter4fvNV) -#define glProgramParameters4dvNV GLEW_GET_FUN(__glewProgramParameters4dvNV) -#define glProgramParameters4fvNV GLEW_GET_FUN(__glewProgramParameters4fvNV) -#define glRequestResidentProgramsNV GLEW_GET_FUN(__glewRequestResidentProgramsNV) -#define glTrackMatrixNV GLEW_GET_FUN(__glewTrackMatrixNV) -#define glVertexAttrib1dNV GLEW_GET_FUN(__glewVertexAttrib1dNV) -#define glVertexAttrib1dvNV GLEW_GET_FUN(__glewVertexAttrib1dvNV) -#define glVertexAttrib1fNV GLEW_GET_FUN(__glewVertexAttrib1fNV) -#define glVertexAttrib1fvNV GLEW_GET_FUN(__glewVertexAttrib1fvNV) -#define glVertexAttrib1sNV GLEW_GET_FUN(__glewVertexAttrib1sNV) -#define glVertexAttrib1svNV GLEW_GET_FUN(__glewVertexAttrib1svNV) -#define glVertexAttrib2dNV GLEW_GET_FUN(__glewVertexAttrib2dNV) -#define glVertexAttrib2dvNV GLEW_GET_FUN(__glewVertexAttrib2dvNV) -#define glVertexAttrib2fNV GLEW_GET_FUN(__glewVertexAttrib2fNV) -#define glVertexAttrib2fvNV GLEW_GET_FUN(__glewVertexAttrib2fvNV) -#define glVertexAttrib2sNV GLEW_GET_FUN(__glewVertexAttrib2sNV) -#define glVertexAttrib2svNV GLEW_GET_FUN(__glewVertexAttrib2svNV) -#define glVertexAttrib3dNV GLEW_GET_FUN(__glewVertexAttrib3dNV) -#define glVertexAttrib3dvNV GLEW_GET_FUN(__glewVertexAttrib3dvNV) -#define glVertexAttrib3fNV GLEW_GET_FUN(__glewVertexAttrib3fNV) -#define glVertexAttrib3fvNV GLEW_GET_FUN(__glewVertexAttrib3fvNV) -#define glVertexAttrib3sNV GLEW_GET_FUN(__glewVertexAttrib3sNV) -#define glVertexAttrib3svNV GLEW_GET_FUN(__glewVertexAttrib3svNV) -#define glVertexAttrib4dNV GLEW_GET_FUN(__glewVertexAttrib4dNV) -#define glVertexAttrib4dvNV GLEW_GET_FUN(__glewVertexAttrib4dvNV) -#define glVertexAttrib4fNV GLEW_GET_FUN(__glewVertexAttrib4fNV) -#define glVertexAttrib4fvNV GLEW_GET_FUN(__glewVertexAttrib4fvNV) -#define glVertexAttrib4sNV GLEW_GET_FUN(__glewVertexAttrib4sNV) -#define glVertexAttrib4svNV GLEW_GET_FUN(__glewVertexAttrib4svNV) -#define glVertexAttrib4ubNV GLEW_GET_FUN(__glewVertexAttrib4ubNV) -#define glVertexAttrib4ubvNV GLEW_GET_FUN(__glewVertexAttrib4ubvNV) -#define glVertexAttribPointerNV GLEW_GET_FUN(__glewVertexAttribPointerNV) -#define glVertexAttribs1dvNV GLEW_GET_FUN(__glewVertexAttribs1dvNV) -#define glVertexAttribs1fvNV GLEW_GET_FUN(__glewVertexAttribs1fvNV) -#define glVertexAttribs1svNV GLEW_GET_FUN(__glewVertexAttribs1svNV) -#define glVertexAttribs2dvNV GLEW_GET_FUN(__glewVertexAttribs2dvNV) -#define glVertexAttribs2fvNV GLEW_GET_FUN(__glewVertexAttribs2fvNV) -#define glVertexAttribs2svNV GLEW_GET_FUN(__glewVertexAttribs2svNV) -#define glVertexAttribs3dvNV GLEW_GET_FUN(__glewVertexAttribs3dvNV) -#define glVertexAttribs3fvNV GLEW_GET_FUN(__glewVertexAttribs3fvNV) -#define glVertexAttribs3svNV GLEW_GET_FUN(__glewVertexAttribs3svNV) -#define glVertexAttribs4dvNV GLEW_GET_FUN(__glewVertexAttribs4dvNV) -#define glVertexAttribs4fvNV GLEW_GET_FUN(__glewVertexAttribs4fvNV) -#define glVertexAttribs4svNV GLEW_GET_FUN(__glewVertexAttribs4svNV) -#define glVertexAttribs4ubvNV GLEW_GET_FUN(__glewVertexAttribs4ubvNV) - -#define GLEW_NV_vertex_program GLEW_GET_VAR(__GLEW_NV_vertex_program) - -#endif /* GL_NV_vertex_program */ - -/* ------------------------ GL_NV_vertex_program1_1 ------------------------ */ - -#ifndef GL_NV_vertex_program1_1 -#define GL_NV_vertex_program1_1 1 - -#define GLEW_NV_vertex_program1_1 GLEW_GET_VAR(__GLEW_NV_vertex_program1_1) - -#endif /* GL_NV_vertex_program1_1 */ - -/* ------------------------- GL_NV_vertex_program2 ------------------------- */ - -#ifndef GL_NV_vertex_program2 -#define GL_NV_vertex_program2 1 - -#define GLEW_NV_vertex_program2 GLEW_GET_VAR(__GLEW_NV_vertex_program2) - -#endif /* GL_NV_vertex_program2 */ - -/* ---------------------- GL_NV_vertex_program2_option --------------------- */ - -#ifndef GL_NV_vertex_program2_option -#define GL_NV_vertex_program2_option 1 - -#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 -#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 - -#define GLEW_NV_vertex_program2_option GLEW_GET_VAR(__GLEW_NV_vertex_program2_option) - -#endif /* GL_NV_vertex_program2_option */ - -/* ------------------------- GL_NV_vertex_program3 ------------------------- */ - -#ifndef GL_NV_vertex_program3 -#define GL_NV_vertex_program3 1 - -#define MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C - -#define GLEW_NV_vertex_program3 GLEW_GET_VAR(__GLEW_NV_vertex_program3) - -#endif /* GL_NV_vertex_program3 */ - -/* ------------------------- GL_NV_vertex_program4 ------------------------- */ - -#ifndef GL_NV_vertex_program4 -#define GL_NV_vertex_program4 1 - -#define GL_VERTEX_ATTRIB_ARRAY_INTEGER_NV 0x88FD - -#define GLEW_NV_vertex_program4 GLEW_GET_VAR(__GLEW_NV_vertex_program4) - -#endif /* GL_NV_vertex_program4 */ - -/* -------------------------- GL_NV_video_capture -------------------------- */ - -#ifndef GL_NV_video_capture -#define GL_NV_video_capture 1 - -#define GL_VIDEO_BUFFER_NV 0x9020 -#define GL_VIDEO_BUFFER_BINDING_NV 0x9021 -#define GL_FIELD_UPPER_NV 0x9022 -#define GL_FIELD_LOWER_NV 0x9023 -#define GL_NUM_VIDEO_CAPTURE_STREAMS_NV 0x9024 -#define GL_NEXT_VIDEO_CAPTURE_BUFFER_STATUS_NV 0x9025 -#define GL_VIDEO_CAPTURE_TO_422_SUPPORTED_NV 0x9026 -#define GL_LAST_VIDEO_CAPTURE_STATUS_NV 0x9027 -#define GL_VIDEO_BUFFER_PITCH_NV 0x9028 -#define GL_VIDEO_COLOR_CONVERSION_MATRIX_NV 0x9029 -#define GL_VIDEO_COLOR_CONVERSION_MAX_NV 0x902A -#define GL_VIDEO_COLOR_CONVERSION_MIN_NV 0x902B -#define GL_VIDEO_COLOR_CONVERSION_OFFSET_NV 0x902C -#define GL_VIDEO_BUFFER_INTERNAL_FORMAT_NV 0x902D -#define GL_PARTIAL_SUCCESS_NV 0x902E -#define GL_SUCCESS_NV 0x902F -#define GL_FAILURE_NV 0x9030 -#define GL_YCBYCR8_422_NV 0x9031 -#define GL_YCBAYCR8A_4224_NV 0x9032 -#define GL_Z6Y10Z6CB10Z6Y10Z6CR10_422_NV 0x9033 -#define GL_Z6Y10Z6CB10Z6A10Z6Y10Z6CR10Z6A10_4224_NV 0x9034 -#define GL_Z4Y12Z4CB12Z4Y12Z4CR12_422_NV 0x9035 -#define GL_Z4Y12Z4CB12Z4A12Z4Y12Z4CR12Z4A12_4224_NV 0x9036 -#define GL_Z4Y12Z4CB12Z4CR12_444_NV 0x9037 -#define GL_VIDEO_CAPTURE_FRAME_WIDTH_NV 0x9038 -#define GL_VIDEO_CAPTURE_FRAME_HEIGHT_NV 0x9039 -#define GL_VIDEO_CAPTURE_FIELD_UPPER_HEIGHT_NV 0x903A -#define GL_VIDEO_CAPTURE_FIELD_LOWER_HEIGHT_NV 0x903B -#define GL_VIDEO_CAPTURE_SURFACE_ORIGIN_NV 0x903C - -typedef void (GLAPIENTRY * PFNGLBEGINVIDEOCAPTURENVPROC) (GLuint video_capture_slot); -typedef void (GLAPIENTRY * PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLintptrARB offset); -typedef void (GLAPIENTRY * PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC) (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLenum target, GLuint texture); -typedef void (GLAPIENTRY * PFNGLENDVIDEOCAPTURENVPROC) (GLuint video_capture_slot); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTURESTREAMDVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTURESTREAMFVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTURESTREAMIVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTUREIVNVPROC) (GLuint video_capture_slot, GLenum pname, GLint* params); -typedef GLenum (GLAPIENTRY * PFNGLVIDEOCAPTURENVPROC) (GLuint video_capture_slot, GLuint* sequence_num, GLuint64EXT *capture_time); -typedef void (GLAPIENTRY * PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLint* params); - -#define glBeginVideoCaptureNV GLEW_GET_FUN(__glewBeginVideoCaptureNV) -#define glBindVideoCaptureStreamBufferNV GLEW_GET_FUN(__glewBindVideoCaptureStreamBufferNV) -#define glBindVideoCaptureStreamTextureNV GLEW_GET_FUN(__glewBindVideoCaptureStreamTextureNV) -#define glEndVideoCaptureNV GLEW_GET_FUN(__glewEndVideoCaptureNV) -#define glGetVideoCaptureStreamdvNV GLEW_GET_FUN(__glewGetVideoCaptureStreamdvNV) -#define glGetVideoCaptureStreamfvNV GLEW_GET_FUN(__glewGetVideoCaptureStreamfvNV) -#define glGetVideoCaptureStreamivNV GLEW_GET_FUN(__glewGetVideoCaptureStreamivNV) -#define glGetVideoCaptureivNV GLEW_GET_FUN(__glewGetVideoCaptureivNV) -#define glVideoCaptureNV GLEW_GET_FUN(__glewVideoCaptureNV) -#define glVideoCaptureStreamParameterdvNV GLEW_GET_FUN(__glewVideoCaptureStreamParameterdvNV) -#define glVideoCaptureStreamParameterfvNV GLEW_GET_FUN(__glewVideoCaptureStreamParameterfvNV) -#define glVideoCaptureStreamParameterivNV GLEW_GET_FUN(__glewVideoCaptureStreamParameterivNV) - -#define GLEW_NV_video_capture GLEW_GET_VAR(__GLEW_NV_video_capture) - -#endif /* GL_NV_video_capture */ - -/* ------------------------ GL_OES_byte_coordinates ------------------------ */ - -#ifndef GL_OES_byte_coordinates -#define GL_OES_byte_coordinates 1 - -#define GL_BYTE 0x1400 - -#define GLEW_OES_byte_coordinates GLEW_GET_VAR(__GLEW_OES_byte_coordinates) - -#endif /* GL_OES_byte_coordinates */ - -/* ------------------- GL_OES_compressed_paletted_texture ------------------ */ - -#ifndef GL_OES_compressed_paletted_texture -#define GL_OES_compressed_paletted_texture 1 - -#define GL_PALETTE4_RGB8_OES 0x8B90 -#define GL_PALETTE4_RGBA8_OES 0x8B91 -#define GL_PALETTE4_R5_G6_B5_OES 0x8B92 -#define GL_PALETTE4_RGBA4_OES 0x8B93 -#define GL_PALETTE4_RGB5_A1_OES 0x8B94 -#define GL_PALETTE8_RGB8_OES 0x8B95 -#define GL_PALETTE8_RGBA8_OES 0x8B96 -#define GL_PALETTE8_R5_G6_B5_OES 0x8B97 -#define GL_PALETTE8_RGBA4_OES 0x8B98 -#define GL_PALETTE8_RGB5_A1_OES 0x8B99 - -#define GLEW_OES_compressed_paletted_texture GLEW_GET_VAR(__GLEW_OES_compressed_paletted_texture) - -#endif /* GL_OES_compressed_paletted_texture */ - -/* --------------------------- GL_OES_read_format -------------------------- */ - -#ifndef GL_OES_read_format -#define GL_OES_read_format 1 - -#define GL_IMPLEMENTATION_COLOR_READ_TYPE_OES 0x8B9A -#define GL_IMPLEMENTATION_COLOR_READ_FORMAT_OES 0x8B9B - -#define GLEW_OES_read_format GLEW_GET_VAR(__GLEW_OES_read_format) - -#endif /* GL_OES_read_format */ - -/* ------------------------ GL_OES_single_precision ------------------------ */ - -#ifndef GL_OES_single_precision -#define GL_OES_single_precision 1 - -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHFOESPROC) (GLclampd depth); -typedef void (GLAPIENTRY * PFNGLCLIPPLANEFOESPROC) (GLenum plane, const GLfloat* equation); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEFOESPROC) (GLclampf n, GLclampf f); -typedef void (GLAPIENTRY * PFNGLFRUSTUMFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); -typedef void (GLAPIENTRY * PFNGLGETCLIPPLANEFOESPROC) (GLenum plane, GLfloat* equation); -typedef void (GLAPIENTRY * PFNGLORTHOFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); - -#define glClearDepthfOES GLEW_GET_FUN(__glewClearDepthfOES) -#define glClipPlanefOES GLEW_GET_FUN(__glewClipPlanefOES) -#define glDepthRangefOES GLEW_GET_FUN(__glewDepthRangefOES) -#define glFrustumfOES GLEW_GET_FUN(__glewFrustumfOES) -#define glGetClipPlanefOES GLEW_GET_FUN(__glewGetClipPlanefOES) -#define glOrthofOES GLEW_GET_FUN(__glewOrthofOES) - -#define GLEW_OES_single_precision GLEW_GET_VAR(__GLEW_OES_single_precision) - -#endif /* GL_OES_single_precision */ - -/* ---------------------------- GL_OML_interlace --------------------------- */ - -#ifndef GL_OML_interlace -#define GL_OML_interlace 1 - -#define GL_INTERLACE_OML 0x8980 -#define GL_INTERLACE_READ_OML 0x8981 - -#define GLEW_OML_interlace GLEW_GET_VAR(__GLEW_OML_interlace) - -#endif /* GL_OML_interlace */ - -/* ---------------------------- GL_OML_resample ---------------------------- */ - -#ifndef GL_OML_resample -#define GL_OML_resample 1 - -#define GL_PACK_RESAMPLE_OML 0x8984 -#define GL_UNPACK_RESAMPLE_OML 0x8985 -#define GL_RESAMPLE_REPLICATE_OML 0x8986 -#define GL_RESAMPLE_ZERO_FILL_OML 0x8987 -#define GL_RESAMPLE_AVERAGE_OML 0x8988 -#define GL_RESAMPLE_DECIMATE_OML 0x8989 - -#define GLEW_OML_resample GLEW_GET_VAR(__GLEW_OML_resample) - -#endif /* GL_OML_resample */ - -/* ---------------------------- GL_OML_subsample --------------------------- */ - -#ifndef GL_OML_subsample -#define GL_OML_subsample 1 - -#define GL_FORMAT_SUBSAMPLE_24_24_OML 0x8982 -#define GL_FORMAT_SUBSAMPLE_244_244_OML 0x8983 - -#define GLEW_OML_subsample GLEW_GET_VAR(__GLEW_OML_subsample) - -#endif /* GL_OML_subsample */ - -/* --------------------------- GL_PGI_misc_hints --------------------------- */ - -#ifndef GL_PGI_misc_hints -#define GL_PGI_misc_hints 1 - -#define GL_PREFER_DOUBLEBUFFER_HINT_PGI 107000 -#define GL_CONSERVE_MEMORY_HINT_PGI 107005 -#define GL_RECLAIM_MEMORY_HINT_PGI 107006 -#define GL_NATIVE_GRAPHICS_HANDLE_PGI 107010 -#define GL_NATIVE_GRAPHICS_BEGIN_HINT_PGI 107011 -#define GL_NATIVE_GRAPHICS_END_HINT_PGI 107012 -#define GL_ALWAYS_FAST_HINT_PGI 107020 -#define GL_ALWAYS_SOFT_HINT_PGI 107021 -#define GL_ALLOW_DRAW_OBJ_HINT_PGI 107022 -#define GL_ALLOW_DRAW_WIN_HINT_PGI 107023 -#define GL_ALLOW_DRAW_FRG_HINT_PGI 107024 -#define GL_ALLOW_DRAW_MEM_HINT_PGI 107025 -#define GL_STRICT_DEPTHFUNC_HINT_PGI 107030 -#define GL_STRICT_LIGHTING_HINT_PGI 107031 -#define GL_STRICT_SCISSOR_HINT_PGI 107032 -#define GL_FULL_STIPPLE_HINT_PGI 107033 -#define GL_CLIP_NEAR_HINT_PGI 107040 -#define GL_CLIP_FAR_HINT_PGI 107041 -#define GL_WIDE_LINE_HINT_PGI 107042 -#define GL_BACK_NORMALS_HINT_PGI 107043 - -#define GLEW_PGI_misc_hints GLEW_GET_VAR(__GLEW_PGI_misc_hints) - -#endif /* GL_PGI_misc_hints */ - -/* -------------------------- GL_PGI_vertex_hints -------------------------- */ - -#ifndef GL_PGI_vertex_hints -#define GL_PGI_vertex_hints 1 - -#define GL_VERTEX23_BIT_PGI 0x00000004 -#define GL_VERTEX4_BIT_PGI 0x00000008 -#define GL_COLOR3_BIT_PGI 0x00010000 -#define GL_COLOR4_BIT_PGI 0x00020000 -#define GL_EDGEFLAG_BIT_PGI 0x00040000 -#define GL_INDEX_BIT_PGI 0x00080000 -#define GL_MAT_AMBIENT_BIT_PGI 0x00100000 -#define GL_VERTEX_DATA_HINT_PGI 107050 -#define GL_VERTEX_CONSISTENT_HINT_PGI 107051 -#define GL_MATERIAL_SIDE_HINT_PGI 107052 -#define GL_MAX_VERTEX_HINT_PGI 107053 -#define GL_MAT_AMBIENT_AND_DIFFUSE_BIT_PGI 0x00200000 -#define GL_MAT_DIFFUSE_BIT_PGI 0x00400000 -#define GL_MAT_EMISSION_BIT_PGI 0x00800000 -#define GL_MAT_COLOR_INDEXES_BIT_PGI 0x01000000 -#define GL_MAT_SHININESS_BIT_PGI 0x02000000 -#define GL_MAT_SPECULAR_BIT_PGI 0x04000000 -#define GL_NORMAL_BIT_PGI 0x08000000 -#define GL_TEXCOORD1_BIT_PGI 0x10000000 -#define GL_TEXCOORD2_BIT_PGI 0x20000000 -#define GL_TEXCOORD3_BIT_PGI 0x40000000 -#define GL_TEXCOORD4_BIT_PGI 0x80000000 - -#define GLEW_PGI_vertex_hints GLEW_GET_VAR(__GLEW_PGI_vertex_hints) - -#endif /* GL_PGI_vertex_hints */ - -/* ----------------------- GL_REND_screen_coordinates ---------------------- */ - -#ifndef GL_REND_screen_coordinates -#define GL_REND_screen_coordinates 1 - -#define GL_SCREEN_COORDINATES_REND 0x8490 -#define GL_INVERTED_SCREEN_W_REND 0x8491 - -#define GLEW_REND_screen_coordinates GLEW_GET_VAR(__GLEW_REND_screen_coordinates) - -#endif /* GL_REND_screen_coordinates */ - -/* ------------------------------- GL_S3_s3tc ------------------------------ */ - -#ifndef GL_S3_s3tc -#define GL_S3_s3tc 1 - -#define GL_RGB_S3TC 0x83A0 -#define GL_RGB4_S3TC 0x83A1 -#define GL_RGBA_S3TC 0x83A2 -#define GL_RGBA4_S3TC 0x83A3 -#define GL_RGBA_DXT5_S3TC 0x83A4 -#define GL_RGBA4_DXT5_S3TC 0x83A5 - -#define GLEW_S3_s3tc GLEW_GET_VAR(__GLEW_S3_s3tc) - -#endif /* GL_S3_s3tc */ - -/* -------------------------- GL_SGIS_color_range -------------------------- */ - -#ifndef GL_SGIS_color_range -#define GL_SGIS_color_range 1 - -#define GL_EXTENDED_RANGE_SGIS 0x85A5 -#define GL_MIN_RED_SGIS 0x85A6 -#define GL_MAX_RED_SGIS 0x85A7 -#define GL_MIN_GREEN_SGIS 0x85A8 -#define GL_MAX_GREEN_SGIS 0x85A9 -#define GL_MIN_BLUE_SGIS 0x85AA -#define GL_MAX_BLUE_SGIS 0x85AB -#define GL_MIN_ALPHA_SGIS 0x85AC -#define GL_MAX_ALPHA_SGIS 0x85AD - -#define GLEW_SGIS_color_range GLEW_GET_VAR(__GLEW_SGIS_color_range) - -#endif /* GL_SGIS_color_range */ - -/* ------------------------- GL_SGIS_detail_texture ------------------------ */ - -#ifndef GL_SGIS_detail_texture -#define GL_SGIS_detail_texture 1 - -typedef void (GLAPIENTRY * PFNGLDETAILTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat* points); -typedef void (GLAPIENTRY * PFNGLGETDETAILTEXFUNCSGISPROC) (GLenum target, GLfloat* points); - -#define glDetailTexFuncSGIS GLEW_GET_FUN(__glewDetailTexFuncSGIS) -#define glGetDetailTexFuncSGIS GLEW_GET_FUN(__glewGetDetailTexFuncSGIS) - -#define GLEW_SGIS_detail_texture GLEW_GET_VAR(__GLEW_SGIS_detail_texture) - -#endif /* GL_SGIS_detail_texture */ - -/* -------------------------- GL_SGIS_fog_function ------------------------- */ - -#ifndef GL_SGIS_fog_function -#define GL_SGIS_fog_function 1 - -typedef void (GLAPIENTRY * PFNGLFOGFUNCSGISPROC) (GLsizei n, const GLfloat* points); -typedef void (GLAPIENTRY * PFNGLGETFOGFUNCSGISPROC) (GLfloat* points); - -#define glFogFuncSGIS GLEW_GET_FUN(__glewFogFuncSGIS) -#define glGetFogFuncSGIS GLEW_GET_FUN(__glewGetFogFuncSGIS) - -#define GLEW_SGIS_fog_function GLEW_GET_VAR(__GLEW_SGIS_fog_function) - -#endif /* GL_SGIS_fog_function */ - -/* ------------------------ GL_SGIS_generate_mipmap ------------------------ */ - -#ifndef GL_SGIS_generate_mipmap -#define GL_SGIS_generate_mipmap 1 - -#define GL_GENERATE_MIPMAP_SGIS 0x8191 -#define GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 - -#define GLEW_SGIS_generate_mipmap GLEW_GET_VAR(__GLEW_SGIS_generate_mipmap) - -#endif /* GL_SGIS_generate_mipmap */ - -/* -------------------------- GL_SGIS_multisample -------------------------- */ - -#ifndef GL_SGIS_multisample -#define GL_SGIS_multisample 1 - -#define GL_MULTISAMPLE_SGIS 0x809D -#define GL_SAMPLE_ALPHA_TO_MASK_SGIS 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_SGIS 0x809F -#define GL_SAMPLE_MASK_SGIS 0x80A0 -#define GL_1PASS_SGIS 0x80A1 -#define GL_2PASS_0_SGIS 0x80A2 -#define GL_2PASS_1_SGIS 0x80A3 -#define GL_4PASS_0_SGIS 0x80A4 -#define GL_4PASS_1_SGIS 0x80A5 -#define GL_4PASS_2_SGIS 0x80A6 -#define GL_4PASS_3_SGIS 0x80A7 -#define GL_SAMPLE_BUFFERS_SGIS 0x80A8 -#define GL_SAMPLES_SGIS 0x80A9 -#define GL_SAMPLE_MASK_VALUE_SGIS 0x80AA -#define GL_SAMPLE_MASK_INVERT_SGIS 0x80AB -#define GL_SAMPLE_PATTERN_SGIS 0x80AC -#define GL_MULTISAMPLE_BIT_EXT 0x20000000 - -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKSGISPROC) (GLclampf value, GLboolean invert); -typedef void (GLAPIENTRY * PFNGLSAMPLEPATTERNSGISPROC) (GLenum pattern); - -#define glSampleMaskSGIS GLEW_GET_FUN(__glewSampleMaskSGIS) -#define glSamplePatternSGIS GLEW_GET_FUN(__glewSamplePatternSGIS) - -#define GLEW_SGIS_multisample GLEW_GET_VAR(__GLEW_SGIS_multisample) - -#endif /* GL_SGIS_multisample */ - -/* ------------------------- GL_SGIS_pixel_texture ------------------------- */ - -#ifndef GL_SGIS_pixel_texture -#define GL_SGIS_pixel_texture 1 - -#define GLEW_SGIS_pixel_texture GLEW_GET_VAR(__GLEW_SGIS_pixel_texture) - -#endif /* GL_SGIS_pixel_texture */ - -/* ----------------------- GL_SGIS_point_line_texgen ----------------------- */ - -#ifndef GL_SGIS_point_line_texgen -#define GL_SGIS_point_line_texgen 1 - -#define GL_EYE_DISTANCE_TO_POINT_SGIS 0x81F0 -#define GL_OBJECT_DISTANCE_TO_POINT_SGIS 0x81F1 -#define GL_EYE_DISTANCE_TO_LINE_SGIS 0x81F2 -#define GL_OBJECT_DISTANCE_TO_LINE_SGIS 0x81F3 -#define GL_EYE_POINT_SGIS 0x81F4 -#define GL_OBJECT_POINT_SGIS 0x81F5 -#define GL_EYE_LINE_SGIS 0x81F6 -#define GL_OBJECT_LINE_SGIS 0x81F7 - -#define GLEW_SGIS_point_line_texgen GLEW_GET_VAR(__GLEW_SGIS_point_line_texgen) - -#endif /* GL_SGIS_point_line_texgen */ - -/* ------------------------ GL_SGIS_sharpen_texture ------------------------ */ - -#ifndef GL_SGIS_sharpen_texture -#define GL_SGIS_sharpen_texture 1 - -typedef void (GLAPIENTRY * PFNGLGETSHARPENTEXFUNCSGISPROC) (GLenum target, GLfloat* points); -typedef void (GLAPIENTRY * PFNGLSHARPENTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat* points); - -#define glGetSharpenTexFuncSGIS GLEW_GET_FUN(__glewGetSharpenTexFuncSGIS) -#define glSharpenTexFuncSGIS GLEW_GET_FUN(__glewSharpenTexFuncSGIS) - -#define GLEW_SGIS_sharpen_texture GLEW_GET_VAR(__GLEW_SGIS_sharpen_texture) - -#endif /* GL_SGIS_sharpen_texture */ - -/* --------------------------- GL_SGIS_texture4D --------------------------- */ - -#ifndef GL_SGIS_texture4D -#define GL_SGIS_texture4D 1 - -typedef void (GLAPIENTRY * PFNGLTEXIMAGE4DSGISPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLint border, GLenum format, GLenum type, const void* pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE4DSGISPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint woffset, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLenum format, GLenum type, const void* pixels); - -#define glTexImage4DSGIS GLEW_GET_FUN(__glewTexImage4DSGIS) -#define glTexSubImage4DSGIS GLEW_GET_FUN(__glewTexSubImage4DSGIS) - -#define GLEW_SGIS_texture4D GLEW_GET_VAR(__GLEW_SGIS_texture4D) - -#endif /* GL_SGIS_texture4D */ - -/* ---------------------- GL_SGIS_texture_border_clamp --------------------- */ - -#ifndef GL_SGIS_texture_border_clamp -#define GL_SGIS_texture_border_clamp 1 - -#define GL_CLAMP_TO_BORDER_SGIS 0x812D - -#define GLEW_SGIS_texture_border_clamp GLEW_GET_VAR(__GLEW_SGIS_texture_border_clamp) - -#endif /* GL_SGIS_texture_border_clamp */ - -/* ----------------------- GL_SGIS_texture_edge_clamp ---------------------- */ - -#ifndef GL_SGIS_texture_edge_clamp -#define GL_SGIS_texture_edge_clamp 1 - -#define GL_CLAMP_TO_EDGE_SGIS 0x812F - -#define GLEW_SGIS_texture_edge_clamp GLEW_GET_VAR(__GLEW_SGIS_texture_edge_clamp) - -#endif /* GL_SGIS_texture_edge_clamp */ - -/* ------------------------ GL_SGIS_texture_filter4 ------------------------ */ - -#ifndef GL_SGIS_texture_filter4 -#define GL_SGIS_texture_filter4 1 - -typedef void (GLAPIENTRY * PFNGLGETTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLfloat* weights); -typedef void (GLAPIENTRY * PFNGLTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLsizei n, const GLfloat* weights); - -#define glGetTexFilterFuncSGIS GLEW_GET_FUN(__glewGetTexFilterFuncSGIS) -#define glTexFilterFuncSGIS GLEW_GET_FUN(__glewTexFilterFuncSGIS) - -#define GLEW_SGIS_texture_filter4 GLEW_GET_VAR(__GLEW_SGIS_texture_filter4) - -#endif /* GL_SGIS_texture_filter4 */ - -/* -------------------------- GL_SGIS_texture_lod -------------------------- */ - -#ifndef GL_SGIS_texture_lod -#define GL_SGIS_texture_lod 1 - -#define GL_TEXTURE_MIN_LOD_SGIS 0x813A -#define GL_TEXTURE_MAX_LOD_SGIS 0x813B -#define GL_TEXTURE_BASE_LEVEL_SGIS 0x813C -#define GL_TEXTURE_MAX_LEVEL_SGIS 0x813D - -#define GLEW_SGIS_texture_lod GLEW_GET_VAR(__GLEW_SGIS_texture_lod) - -#endif /* GL_SGIS_texture_lod */ - -/* ------------------------- GL_SGIS_texture_select ------------------------ */ - -#ifndef GL_SGIS_texture_select -#define GL_SGIS_texture_select 1 - -#define GLEW_SGIS_texture_select GLEW_GET_VAR(__GLEW_SGIS_texture_select) - -#endif /* GL_SGIS_texture_select */ - -/* ----------------------------- GL_SGIX_async ----------------------------- */ - -#ifndef GL_SGIX_async -#define GL_SGIX_async 1 - -#define GL_ASYNC_MARKER_SGIX 0x8329 - -typedef void (GLAPIENTRY * PFNGLASYNCMARKERSGIXPROC) (GLuint marker); -typedef void (GLAPIENTRY * PFNGLDELETEASYNCMARKERSSGIXPROC) (GLuint marker, GLsizei range); -typedef GLint (GLAPIENTRY * PFNGLFINISHASYNCSGIXPROC) (GLuint* markerp); -typedef GLuint (GLAPIENTRY * PFNGLGENASYNCMARKERSSGIXPROC) (GLsizei range); -typedef GLboolean (GLAPIENTRY * PFNGLISASYNCMARKERSGIXPROC) (GLuint marker); -typedef GLint (GLAPIENTRY * PFNGLPOLLASYNCSGIXPROC) (GLuint* markerp); - -#define glAsyncMarkerSGIX GLEW_GET_FUN(__glewAsyncMarkerSGIX) -#define glDeleteAsyncMarkersSGIX GLEW_GET_FUN(__glewDeleteAsyncMarkersSGIX) -#define glFinishAsyncSGIX GLEW_GET_FUN(__glewFinishAsyncSGIX) -#define glGenAsyncMarkersSGIX GLEW_GET_FUN(__glewGenAsyncMarkersSGIX) -#define glIsAsyncMarkerSGIX GLEW_GET_FUN(__glewIsAsyncMarkerSGIX) -#define glPollAsyncSGIX GLEW_GET_FUN(__glewPollAsyncSGIX) - -#define GLEW_SGIX_async GLEW_GET_VAR(__GLEW_SGIX_async) - -#endif /* GL_SGIX_async */ - -/* ------------------------ GL_SGIX_async_histogram ------------------------ */ - -#ifndef GL_SGIX_async_histogram -#define GL_SGIX_async_histogram 1 - -#define GL_ASYNC_HISTOGRAM_SGIX 0x832C -#define GL_MAX_ASYNC_HISTOGRAM_SGIX 0x832D - -#define GLEW_SGIX_async_histogram GLEW_GET_VAR(__GLEW_SGIX_async_histogram) - -#endif /* GL_SGIX_async_histogram */ - -/* -------------------------- GL_SGIX_async_pixel -------------------------- */ - -#ifndef GL_SGIX_async_pixel -#define GL_SGIX_async_pixel 1 - -#define GL_ASYNC_TEX_IMAGE_SGIX 0x835C -#define GL_ASYNC_DRAW_PIXELS_SGIX 0x835D -#define GL_ASYNC_READ_PIXELS_SGIX 0x835E -#define GL_MAX_ASYNC_TEX_IMAGE_SGIX 0x835F -#define GL_MAX_ASYNC_DRAW_PIXELS_SGIX 0x8360 -#define GL_MAX_ASYNC_READ_PIXELS_SGIX 0x8361 - -#define GLEW_SGIX_async_pixel GLEW_GET_VAR(__GLEW_SGIX_async_pixel) - -#endif /* GL_SGIX_async_pixel */ - -/* ----------------------- GL_SGIX_blend_alpha_minmax ---------------------- */ - -#ifndef GL_SGIX_blend_alpha_minmax -#define GL_SGIX_blend_alpha_minmax 1 - -#define GL_ALPHA_MIN_SGIX 0x8320 -#define GL_ALPHA_MAX_SGIX 0x8321 - -#define GLEW_SGIX_blend_alpha_minmax GLEW_GET_VAR(__GLEW_SGIX_blend_alpha_minmax) - -#endif /* GL_SGIX_blend_alpha_minmax */ - -/* ---------------------------- GL_SGIX_clipmap ---------------------------- */ - -#ifndef GL_SGIX_clipmap -#define GL_SGIX_clipmap 1 - -#define GLEW_SGIX_clipmap GLEW_GET_VAR(__GLEW_SGIX_clipmap) - -#endif /* GL_SGIX_clipmap */ - -/* ---------------------- GL_SGIX_convolution_accuracy --------------------- */ - -#ifndef GL_SGIX_convolution_accuracy -#define GL_SGIX_convolution_accuracy 1 - -#define GL_CONVOLUTION_HINT_SGIX 0x8316 - -#define GLEW_SGIX_convolution_accuracy GLEW_GET_VAR(__GLEW_SGIX_convolution_accuracy) - -#endif /* GL_SGIX_convolution_accuracy */ - -/* ------------------------- GL_SGIX_depth_texture ------------------------- */ - -#ifndef GL_SGIX_depth_texture -#define GL_SGIX_depth_texture 1 - -#define GL_DEPTH_COMPONENT16_SGIX 0x81A5 -#define GL_DEPTH_COMPONENT24_SGIX 0x81A6 -#define GL_DEPTH_COMPONENT32_SGIX 0x81A7 - -#define GLEW_SGIX_depth_texture GLEW_GET_VAR(__GLEW_SGIX_depth_texture) - -#endif /* GL_SGIX_depth_texture */ - -/* -------------------------- GL_SGIX_flush_raster ------------------------- */ - -#ifndef GL_SGIX_flush_raster -#define GL_SGIX_flush_raster 1 - -typedef void (GLAPIENTRY * PFNGLFLUSHRASTERSGIXPROC) (void); - -#define glFlushRasterSGIX GLEW_GET_FUN(__glewFlushRasterSGIX) - -#define GLEW_SGIX_flush_raster GLEW_GET_VAR(__GLEW_SGIX_flush_raster) - -#endif /* GL_SGIX_flush_raster */ - -/* --------------------------- GL_SGIX_fog_offset -------------------------- */ - -#ifndef GL_SGIX_fog_offset -#define GL_SGIX_fog_offset 1 - -#define GL_FOG_OFFSET_SGIX 0x8198 -#define GL_FOG_OFFSET_VALUE_SGIX 0x8199 - -#define GLEW_SGIX_fog_offset GLEW_GET_VAR(__GLEW_SGIX_fog_offset) - -#endif /* GL_SGIX_fog_offset */ - -/* -------------------------- GL_SGIX_fog_texture -------------------------- */ - -#ifndef GL_SGIX_fog_texture -#define GL_SGIX_fog_texture 1 - -#define GL_TEXTURE_FOG_SGIX 0 -#define GL_FOG_PATCHY_FACTOR_SGIX 0 -#define GL_FRAGMENT_FOG_SGIX 0 - -typedef void (GLAPIENTRY * PFNGLTEXTUREFOGSGIXPROC) (GLenum pname); - -#define glTextureFogSGIX GLEW_GET_FUN(__glewTextureFogSGIX) - -#define GLEW_SGIX_fog_texture GLEW_GET_VAR(__GLEW_SGIX_fog_texture) - -#endif /* GL_SGIX_fog_texture */ - -/* ------------------- GL_SGIX_fragment_specular_lighting ------------------ */ - -#ifndef GL_SGIX_fragment_specular_lighting -#define GL_SGIX_fragment_specular_lighting 1 - -typedef void (GLAPIENTRY * PFNGLFRAGMENTCOLORMATERIALSGIXPROC) (GLenum face, GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFSGIXPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFVSGIXPROC) (GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELISGIXPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIVSGIXPROC) (GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFSGIXPROC) (GLenum light, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTISGIXPROC) (GLenum light, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFSGIXPROC) (GLenum face, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALISGIXPROC) (GLenum face, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum value, GLfloat* data); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum value, GLint* data); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat* data); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint* data); - -#define glFragmentColorMaterialSGIX GLEW_GET_FUN(__glewFragmentColorMaterialSGIX) -#define glFragmentLightModelfSGIX GLEW_GET_FUN(__glewFragmentLightModelfSGIX) -#define glFragmentLightModelfvSGIX GLEW_GET_FUN(__glewFragmentLightModelfvSGIX) -#define glFragmentLightModeliSGIX GLEW_GET_FUN(__glewFragmentLightModeliSGIX) -#define glFragmentLightModelivSGIX GLEW_GET_FUN(__glewFragmentLightModelivSGIX) -#define glFragmentLightfSGIX GLEW_GET_FUN(__glewFragmentLightfSGIX) -#define glFragmentLightfvSGIX GLEW_GET_FUN(__glewFragmentLightfvSGIX) -#define glFragmentLightiSGIX GLEW_GET_FUN(__glewFragmentLightiSGIX) -#define glFragmentLightivSGIX GLEW_GET_FUN(__glewFragmentLightivSGIX) -#define glFragmentMaterialfSGIX GLEW_GET_FUN(__glewFragmentMaterialfSGIX) -#define glFragmentMaterialfvSGIX GLEW_GET_FUN(__glewFragmentMaterialfvSGIX) -#define glFragmentMaterialiSGIX GLEW_GET_FUN(__glewFragmentMaterialiSGIX) -#define glFragmentMaterialivSGIX GLEW_GET_FUN(__glewFragmentMaterialivSGIX) -#define glGetFragmentLightfvSGIX GLEW_GET_FUN(__glewGetFragmentLightfvSGIX) -#define glGetFragmentLightivSGIX GLEW_GET_FUN(__glewGetFragmentLightivSGIX) -#define glGetFragmentMaterialfvSGIX GLEW_GET_FUN(__glewGetFragmentMaterialfvSGIX) -#define glGetFragmentMaterialivSGIX GLEW_GET_FUN(__glewGetFragmentMaterialivSGIX) - -#define GLEW_SGIX_fragment_specular_lighting GLEW_GET_VAR(__GLEW_SGIX_fragment_specular_lighting) - -#endif /* GL_SGIX_fragment_specular_lighting */ - -/* --------------------------- GL_SGIX_framezoom --------------------------- */ - -#ifndef GL_SGIX_framezoom -#define GL_SGIX_framezoom 1 - -typedef void (GLAPIENTRY * PFNGLFRAMEZOOMSGIXPROC) (GLint factor); - -#define glFrameZoomSGIX GLEW_GET_FUN(__glewFrameZoomSGIX) - -#define GLEW_SGIX_framezoom GLEW_GET_VAR(__GLEW_SGIX_framezoom) - -#endif /* GL_SGIX_framezoom */ - -/* --------------------------- GL_SGIX_interlace --------------------------- */ - -#ifndef GL_SGIX_interlace -#define GL_SGIX_interlace 1 - -#define GL_INTERLACE_SGIX 0x8094 - -#define GLEW_SGIX_interlace GLEW_GET_VAR(__GLEW_SGIX_interlace) - -#endif /* GL_SGIX_interlace */ - -/* ------------------------- GL_SGIX_ir_instrument1 ------------------------ */ - -#ifndef GL_SGIX_ir_instrument1 -#define GL_SGIX_ir_instrument1 1 - -#define GLEW_SGIX_ir_instrument1 GLEW_GET_VAR(__GLEW_SGIX_ir_instrument1) - -#endif /* GL_SGIX_ir_instrument1 */ - -/* ------------------------- GL_SGIX_list_priority ------------------------- */ - -#ifndef GL_SGIX_list_priority -#define GL_SGIX_list_priority 1 - -#define GLEW_SGIX_list_priority GLEW_GET_VAR(__GLEW_SGIX_list_priority) - -#endif /* GL_SGIX_list_priority */ - -/* ------------------------- GL_SGIX_pixel_texture ------------------------- */ - -#ifndef GL_SGIX_pixel_texture -#define GL_SGIX_pixel_texture 1 - -typedef void (GLAPIENTRY * PFNGLPIXELTEXGENSGIXPROC) (GLenum mode); - -#define glPixelTexGenSGIX GLEW_GET_FUN(__glewPixelTexGenSGIX) - -#define GLEW_SGIX_pixel_texture GLEW_GET_VAR(__GLEW_SGIX_pixel_texture) - -#endif /* GL_SGIX_pixel_texture */ - -/* ----------------------- GL_SGIX_pixel_texture_bits ---------------------- */ - -#ifndef GL_SGIX_pixel_texture_bits -#define GL_SGIX_pixel_texture_bits 1 - -#define GLEW_SGIX_pixel_texture_bits GLEW_GET_VAR(__GLEW_SGIX_pixel_texture_bits) - -#endif /* GL_SGIX_pixel_texture_bits */ - -/* ------------------------ GL_SGIX_reference_plane ------------------------ */ - -#ifndef GL_SGIX_reference_plane -#define GL_SGIX_reference_plane 1 - -typedef void (GLAPIENTRY * PFNGLREFERENCEPLANESGIXPROC) (const GLdouble* equation); - -#define glReferencePlaneSGIX GLEW_GET_FUN(__glewReferencePlaneSGIX) - -#define GLEW_SGIX_reference_plane GLEW_GET_VAR(__GLEW_SGIX_reference_plane) - -#endif /* GL_SGIX_reference_plane */ - -/* ---------------------------- GL_SGIX_resample --------------------------- */ - -#ifndef GL_SGIX_resample -#define GL_SGIX_resample 1 - -#define GL_PACK_RESAMPLE_SGIX 0x842E -#define GL_UNPACK_RESAMPLE_SGIX 0x842F -#define GL_RESAMPLE_DECIMATE_SGIX 0x8430 -#define GL_RESAMPLE_REPLICATE_SGIX 0x8433 -#define GL_RESAMPLE_ZERO_FILL_SGIX 0x8434 - -#define GLEW_SGIX_resample GLEW_GET_VAR(__GLEW_SGIX_resample) - -#endif /* GL_SGIX_resample */ - -/* ----------------------------- GL_SGIX_shadow ---------------------------- */ - -#ifndef GL_SGIX_shadow -#define GL_SGIX_shadow 1 - -#define GL_TEXTURE_COMPARE_SGIX 0x819A -#define GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B -#define GL_TEXTURE_LEQUAL_R_SGIX 0x819C -#define GL_TEXTURE_GEQUAL_R_SGIX 0x819D - -#define GLEW_SGIX_shadow GLEW_GET_VAR(__GLEW_SGIX_shadow) - -#endif /* GL_SGIX_shadow */ - -/* ------------------------- GL_SGIX_shadow_ambient ------------------------ */ - -#ifndef GL_SGIX_shadow_ambient -#define GL_SGIX_shadow_ambient 1 - -#define GL_SHADOW_AMBIENT_SGIX 0x80BF - -#define GLEW_SGIX_shadow_ambient GLEW_GET_VAR(__GLEW_SGIX_shadow_ambient) - -#endif /* GL_SGIX_shadow_ambient */ - -/* ----------------------------- GL_SGIX_sprite ---------------------------- */ - -#ifndef GL_SGIX_sprite -#define GL_SGIX_sprite 1 - -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERFSGIXPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERFVSGIXPROC) (GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERISGIXPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERIVSGIXPROC) (GLenum pname, GLint* params); - -#define glSpriteParameterfSGIX GLEW_GET_FUN(__glewSpriteParameterfSGIX) -#define glSpriteParameterfvSGIX GLEW_GET_FUN(__glewSpriteParameterfvSGIX) -#define glSpriteParameteriSGIX GLEW_GET_FUN(__glewSpriteParameteriSGIX) -#define glSpriteParameterivSGIX GLEW_GET_FUN(__glewSpriteParameterivSGIX) - -#define GLEW_SGIX_sprite GLEW_GET_VAR(__GLEW_SGIX_sprite) - -#endif /* GL_SGIX_sprite */ - -/* ----------------------- GL_SGIX_tag_sample_buffer ----------------------- */ - -#ifndef GL_SGIX_tag_sample_buffer -#define GL_SGIX_tag_sample_buffer 1 - -typedef void (GLAPIENTRY * PFNGLTAGSAMPLEBUFFERSGIXPROC) (void); - -#define glTagSampleBufferSGIX GLEW_GET_FUN(__glewTagSampleBufferSGIX) - -#define GLEW_SGIX_tag_sample_buffer GLEW_GET_VAR(__GLEW_SGIX_tag_sample_buffer) - -#endif /* GL_SGIX_tag_sample_buffer */ - -/* ------------------------ GL_SGIX_texture_add_env ------------------------ */ - -#ifndef GL_SGIX_texture_add_env -#define GL_SGIX_texture_add_env 1 - -#define GLEW_SGIX_texture_add_env GLEW_GET_VAR(__GLEW_SGIX_texture_add_env) - -#endif /* GL_SGIX_texture_add_env */ - -/* -------------------- GL_SGIX_texture_coordinate_clamp ------------------- */ - -#ifndef GL_SGIX_texture_coordinate_clamp -#define GL_SGIX_texture_coordinate_clamp 1 - -#define GL_TEXTURE_MAX_CLAMP_S_SGIX 0x8369 -#define GL_TEXTURE_MAX_CLAMP_T_SGIX 0x836A -#define GL_TEXTURE_MAX_CLAMP_R_SGIX 0x836B - -#define GLEW_SGIX_texture_coordinate_clamp GLEW_GET_VAR(__GLEW_SGIX_texture_coordinate_clamp) - -#endif /* GL_SGIX_texture_coordinate_clamp */ - -/* ------------------------ GL_SGIX_texture_lod_bias ----------------------- */ - -#ifndef GL_SGIX_texture_lod_bias -#define GL_SGIX_texture_lod_bias 1 - -#define GLEW_SGIX_texture_lod_bias GLEW_GET_VAR(__GLEW_SGIX_texture_lod_bias) - -#endif /* GL_SGIX_texture_lod_bias */ - -/* ---------------------- GL_SGIX_texture_multi_buffer --------------------- */ - -#ifndef GL_SGIX_texture_multi_buffer -#define GL_SGIX_texture_multi_buffer 1 - -#define GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E - -#define GLEW_SGIX_texture_multi_buffer GLEW_GET_VAR(__GLEW_SGIX_texture_multi_buffer) - -#endif /* GL_SGIX_texture_multi_buffer */ - -/* ------------------------- GL_SGIX_texture_range ------------------------- */ - -#ifndef GL_SGIX_texture_range -#define GL_SGIX_texture_range 1 - -#define GL_RGB_SIGNED_SGIX 0x85E0 -#define GL_RGBA_SIGNED_SGIX 0x85E1 -#define GL_ALPHA_SIGNED_SGIX 0x85E2 -#define GL_LUMINANCE_SIGNED_SGIX 0x85E3 -#define GL_INTENSITY_SIGNED_SGIX 0x85E4 -#define GL_LUMINANCE_ALPHA_SIGNED_SGIX 0x85E5 -#define GL_RGB16_SIGNED_SGIX 0x85E6 -#define GL_RGBA16_SIGNED_SGIX 0x85E7 -#define GL_ALPHA16_SIGNED_SGIX 0x85E8 -#define GL_LUMINANCE16_SIGNED_SGIX 0x85E9 -#define GL_INTENSITY16_SIGNED_SGIX 0x85EA -#define GL_LUMINANCE16_ALPHA16_SIGNED_SGIX 0x85EB -#define GL_RGB_EXTENDED_RANGE_SGIX 0x85EC -#define GL_RGBA_EXTENDED_RANGE_SGIX 0x85ED -#define GL_ALPHA_EXTENDED_RANGE_SGIX 0x85EE -#define GL_LUMINANCE_EXTENDED_RANGE_SGIX 0x85EF -#define GL_INTENSITY_EXTENDED_RANGE_SGIX 0x85F0 -#define GL_LUMINANCE_ALPHA_EXTENDED_RANGE_SGIX 0x85F1 -#define GL_RGB16_EXTENDED_RANGE_SGIX 0x85F2 -#define GL_RGBA16_EXTENDED_RANGE_SGIX 0x85F3 -#define GL_ALPHA16_EXTENDED_RANGE_SGIX 0x85F4 -#define GL_LUMINANCE16_EXTENDED_RANGE_SGIX 0x85F5 -#define GL_INTENSITY16_EXTENDED_RANGE_SGIX 0x85F6 -#define GL_LUMINANCE16_ALPHA16_EXTENDED_RANGE_SGIX 0x85F7 -#define GL_MIN_LUMINANCE_SGIS 0x85F8 -#define GL_MAX_LUMINANCE_SGIS 0x85F9 -#define GL_MIN_INTENSITY_SGIS 0x85FA -#define GL_MAX_INTENSITY_SGIS 0x85FB - -#define GLEW_SGIX_texture_range GLEW_GET_VAR(__GLEW_SGIX_texture_range) - -#endif /* GL_SGIX_texture_range */ - -/* ----------------------- GL_SGIX_texture_scale_bias ---------------------- */ - -#ifndef GL_SGIX_texture_scale_bias -#define GL_SGIX_texture_scale_bias 1 - -#define GL_POST_TEXTURE_FILTER_BIAS_SGIX 0x8179 -#define GL_POST_TEXTURE_FILTER_SCALE_SGIX 0x817A -#define GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX 0x817B -#define GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX 0x817C - -#define GLEW_SGIX_texture_scale_bias GLEW_GET_VAR(__GLEW_SGIX_texture_scale_bias) - -#endif /* GL_SGIX_texture_scale_bias */ - -/* ------------------------- GL_SGIX_vertex_preclip ------------------------ */ - -#ifndef GL_SGIX_vertex_preclip -#define GL_SGIX_vertex_preclip 1 - -#define GL_VERTEX_PRECLIP_SGIX 0x83EE -#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF - -#define GLEW_SGIX_vertex_preclip GLEW_GET_VAR(__GLEW_SGIX_vertex_preclip) - -#endif /* GL_SGIX_vertex_preclip */ - -/* ---------------------- GL_SGIX_vertex_preclip_hint ---------------------- */ - -#ifndef GL_SGIX_vertex_preclip_hint -#define GL_SGIX_vertex_preclip_hint 1 - -#define GL_VERTEX_PRECLIP_SGIX 0x83EE -#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF - -#define GLEW_SGIX_vertex_preclip_hint GLEW_GET_VAR(__GLEW_SGIX_vertex_preclip_hint) - -#endif /* GL_SGIX_vertex_preclip_hint */ - -/* ----------------------------- GL_SGIX_ycrcb ----------------------------- */ - -#ifndef GL_SGIX_ycrcb -#define GL_SGIX_ycrcb 1 - -#define GLEW_SGIX_ycrcb GLEW_GET_VAR(__GLEW_SGIX_ycrcb) - -#endif /* GL_SGIX_ycrcb */ - -/* -------------------------- GL_SGI_color_matrix -------------------------- */ - -#ifndef GL_SGI_color_matrix -#define GL_SGI_color_matrix 1 - -#define GL_COLOR_MATRIX_SGI 0x80B1 -#define GL_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B2 -#define GL_MAX_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B3 -#define GL_POST_COLOR_MATRIX_RED_SCALE_SGI 0x80B4 -#define GL_POST_COLOR_MATRIX_GREEN_SCALE_SGI 0x80B5 -#define GL_POST_COLOR_MATRIX_BLUE_SCALE_SGI 0x80B6 -#define GL_POST_COLOR_MATRIX_ALPHA_SCALE_SGI 0x80B7 -#define GL_POST_COLOR_MATRIX_RED_BIAS_SGI 0x80B8 -#define GL_POST_COLOR_MATRIX_GREEN_BIAS_SGI 0x80B9 -#define GL_POST_COLOR_MATRIX_BLUE_BIAS_SGI 0x80BA -#define GL_POST_COLOR_MATRIX_ALPHA_BIAS_SGI 0x80BB - -#define GLEW_SGI_color_matrix GLEW_GET_VAR(__GLEW_SGI_color_matrix) - -#endif /* GL_SGI_color_matrix */ - -/* --------------------------- GL_SGI_color_table -------------------------- */ - -#ifndef GL_SGI_color_table -#define GL_SGI_color_table 1 - -#define GL_COLOR_TABLE_SGI 0x80D0 -#define GL_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D1 -#define GL_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D2 -#define GL_PROXY_COLOR_TABLE_SGI 0x80D3 -#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D4 -#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D5 -#define GL_COLOR_TABLE_SCALE_SGI 0x80D6 -#define GL_COLOR_TABLE_BIAS_SGI 0x80D7 -#define GL_COLOR_TABLE_FORMAT_SGI 0x80D8 -#define GL_COLOR_TABLE_WIDTH_SGI 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE_SGI 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE_SGI 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE_SGI 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE_SGI 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE_SGI 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE_SGI 0x80DF - -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void* table); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLESGIPROC) (GLenum target, GLenum format, GLenum type, void* table); - -#define glColorTableParameterfvSGI GLEW_GET_FUN(__glewColorTableParameterfvSGI) -#define glColorTableParameterivSGI GLEW_GET_FUN(__glewColorTableParameterivSGI) -#define glColorTableSGI GLEW_GET_FUN(__glewColorTableSGI) -#define glCopyColorTableSGI GLEW_GET_FUN(__glewCopyColorTableSGI) -#define glGetColorTableParameterfvSGI GLEW_GET_FUN(__glewGetColorTableParameterfvSGI) -#define glGetColorTableParameterivSGI GLEW_GET_FUN(__glewGetColorTableParameterivSGI) -#define glGetColorTableSGI GLEW_GET_FUN(__glewGetColorTableSGI) - -#define GLEW_SGI_color_table GLEW_GET_VAR(__GLEW_SGI_color_table) - -#endif /* GL_SGI_color_table */ - -/* ----------------------- GL_SGI_texture_color_table ---------------------- */ - -#ifndef GL_SGI_texture_color_table -#define GL_SGI_texture_color_table 1 - -#define GL_TEXTURE_COLOR_TABLE_SGI 0x80BC -#define GL_PROXY_TEXTURE_COLOR_TABLE_SGI 0x80BD - -#define GLEW_SGI_texture_color_table GLEW_GET_VAR(__GLEW_SGI_texture_color_table) - -#endif /* GL_SGI_texture_color_table */ - -/* ------------------------- GL_SUNX_constant_data ------------------------- */ - -#ifndef GL_SUNX_constant_data -#define GL_SUNX_constant_data 1 - -#define GL_UNPACK_CONSTANT_DATA_SUNX 0x81D5 -#define GL_TEXTURE_CONSTANT_DATA_SUNX 0x81D6 - -typedef void (GLAPIENTRY * PFNGLFINISHTEXTURESUNXPROC) (void); - -#define glFinishTextureSUNX GLEW_GET_FUN(__glewFinishTextureSUNX) - -#define GLEW_SUNX_constant_data GLEW_GET_VAR(__GLEW_SUNX_constant_data) - -#endif /* GL_SUNX_constant_data */ - -/* -------------------- GL_SUN_convolution_border_modes -------------------- */ - -#ifndef GL_SUN_convolution_border_modes -#define GL_SUN_convolution_border_modes 1 - -#define GL_WRAP_BORDER_SUN 0x81D4 - -#define GLEW_SUN_convolution_border_modes GLEW_GET_VAR(__GLEW_SUN_convolution_border_modes) - -#endif /* GL_SUN_convolution_border_modes */ - -/* -------------------------- GL_SUN_global_alpha -------------------------- */ - -#ifndef GL_SUN_global_alpha -#define GL_SUN_global_alpha 1 - -#define GL_GLOBAL_ALPHA_SUN 0x81D9 -#define GL_GLOBAL_ALPHA_FACTOR_SUN 0x81DA - -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORBSUNPROC) (GLbyte factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORDSUNPROC) (GLdouble factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORFSUNPROC) (GLfloat factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORISUNPROC) (GLint factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORSSUNPROC) (GLshort factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUBSUNPROC) (GLubyte factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUISUNPROC) (GLuint factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUSSUNPROC) (GLushort factor); - -#define glGlobalAlphaFactorbSUN GLEW_GET_FUN(__glewGlobalAlphaFactorbSUN) -#define glGlobalAlphaFactordSUN GLEW_GET_FUN(__glewGlobalAlphaFactordSUN) -#define glGlobalAlphaFactorfSUN GLEW_GET_FUN(__glewGlobalAlphaFactorfSUN) -#define glGlobalAlphaFactoriSUN GLEW_GET_FUN(__glewGlobalAlphaFactoriSUN) -#define glGlobalAlphaFactorsSUN GLEW_GET_FUN(__glewGlobalAlphaFactorsSUN) -#define glGlobalAlphaFactorubSUN GLEW_GET_FUN(__glewGlobalAlphaFactorubSUN) -#define glGlobalAlphaFactoruiSUN GLEW_GET_FUN(__glewGlobalAlphaFactoruiSUN) -#define glGlobalAlphaFactorusSUN GLEW_GET_FUN(__glewGlobalAlphaFactorusSUN) - -#define GLEW_SUN_global_alpha GLEW_GET_VAR(__GLEW_SUN_global_alpha) - -#endif /* GL_SUN_global_alpha */ - -/* --------------------------- GL_SUN_mesh_array --------------------------- */ - -#ifndef GL_SUN_mesh_array -#define GL_SUN_mesh_array 1 - -#define GL_QUAD_MESH_SUN 0x8614 -#define GL_TRIANGLE_MESH_SUN 0x8615 - -#define GLEW_SUN_mesh_array GLEW_GET_VAR(__GLEW_SUN_mesh_array) - -#endif /* GL_SUN_mesh_array */ - -/* ------------------------ GL_SUN_read_video_pixels ----------------------- */ - -#ifndef GL_SUN_read_video_pixels -#define GL_SUN_read_video_pixels 1 - -typedef void (GLAPIENTRY * PFNGLREADVIDEOPIXELSSUNPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid* pixels); - -#define glReadVideoPixelsSUN GLEW_GET_FUN(__glewReadVideoPixelsSUN) - -#define GLEW_SUN_read_video_pixels GLEW_GET_VAR(__GLEW_SUN_read_video_pixels) - -#endif /* GL_SUN_read_video_pixels */ - -/* --------------------------- GL_SUN_slice_accum -------------------------- */ - -#ifndef GL_SUN_slice_accum -#define GL_SUN_slice_accum 1 - -#define GL_SLICE_ACCUM_SUN 0x85CC - -#define GLEW_SUN_slice_accum GLEW_GET_VAR(__GLEW_SUN_slice_accum) - -#endif /* GL_SUN_slice_accum */ - -/* -------------------------- GL_SUN_triangle_list ------------------------- */ - -#ifndef GL_SUN_triangle_list -#define GL_SUN_triangle_list 1 - -#define GL_RESTART_SUN 0x01 -#define GL_REPLACE_MIDDLE_SUN 0x02 -#define GL_REPLACE_OLDEST_SUN 0x03 -#define GL_TRIANGLE_LIST_SUN 0x81D7 -#define GL_REPLACEMENT_CODE_SUN 0x81D8 -#define GL_REPLACEMENT_CODE_ARRAY_SUN 0x85C0 -#define GL_REPLACEMENT_CODE_ARRAY_TYPE_SUN 0x85C1 -#define GL_REPLACEMENT_CODE_ARRAY_STRIDE_SUN 0x85C2 -#define GL_REPLACEMENT_CODE_ARRAY_POINTER_SUN 0x85C3 -#define GL_R1UI_V3F_SUN 0x85C4 -#define GL_R1UI_C4UB_V3F_SUN 0x85C5 -#define GL_R1UI_C3F_V3F_SUN 0x85C6 -#define GL_R1UI_N3F_V3F_SUN 0x85C7 -#define GL_R1UI_C4F_N3F_V3F_SUN 0x85C8 -#define GL_R1UI_T2F_V3F_SUN 0x85C9 -#define GL_R1UI_T2F_N3F_V3F_SUN 0x85CA -#define GL_R1UI_T2F_C4F_N3F_V3F_SUN 0x85CB - -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEPOINTERSUNPROC) (GLenum type, GLsizei stride, const void* pointer); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUBSUNPROC) (GLubyte code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUBVSUNPROC) (const GLubyte* code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUISUNPROC) (GLuint code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVSUNPROC) (const GLuint* code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUSSUNPROC) (GLushort code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUSVSUNPROC) (const GLushort* code); - -#define glReplacementCodePointerSUN GLEW_GET_FUN(__glewReplacementCodePointerSUN) -#define glReplacementCodeubSUN GLEW_GET_FUN(__glewReplacementCodeubSUN) -#define glReplacementCodeubvSUN GLEW_GET_FUN(__glewReplacementCodeubvSUN) -#define glReplacementCodeuiSUN GLEW_GET_FUN(__glewReplacementCodeuiSUN) -#define glReplacementCodeuivSUN GLEW_GET_FUN(__glewReplacementCodeuivSUN) -#define glReplacementCodeusSUN GLEW_GET_FUN(__glewReplacementCodeusSUN) -#define glReplacementCodeusvSUN GLEW_GET_FUN(__glewReplacementCodeusvSUN) - -#define GLEW_SUN_triangle_list GLEW_GET_VAR(__GLEW_SUN_triangle_list) - -#endif /* GL_SUN_triangle_list */ - -/* ----------------------------- GL_SUN_vertex ----------------------------- */ - -#ifndef GL_SUN_vertex -#define GL_SUN_vertex 1 - -typedef void (GLAPIENTRY * PFNGLCOLOR3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLCOLOR3FVERTEX3FVSUNPROC) (const GLfloat* c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX2FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX2FVSUNPROC) (const GLubyte* c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX3FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX3FVSUNPROC) (const GLubyte* c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLNORMAL3FVERTEX3FSUNPROC) (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC) (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC) (const GLuint* rc, const GLubyte *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC) (GLuint rc, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC) (const GLfloat* tc, const GLubyte *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVERTEX4FVSUNPROC) (const GLfloat* tc, const GLfloat *v); - -#define glColor3fVertex3fSUN GLEW_GET_FUN(__glewColor3fVertex3fSUN) -#define glColor3fVertex3fvSUN GLEW_GET_FUN(__glewColor3fVertex3fvSUN) -#define glColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewColor4fNormal3fVertex3fSUN) -#define glColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewColor4fNormal3fVertex3fvSUN) -#define glColor4ubVertex2fSUN GLEW_GET_FUN(__glewColor4ubVertex2fSUN) -#define glColor4ubVertex2fvSUN GLEW_GET_FUN(__glewColor4ubVertex2fvSUN) -#define glColor4ubVertex3fSUN GLEW_GET_FUN(__glewColor4ubVertex3fSUN) -#define glColor4ubVertex3fvSUN GLEW_GET_FUN(__glewColor4ubVertex3fvSUN) -#define glNormal3fVertex3fSUN GLEW_GET_FUN(__glewNormal3fVertex3fSUN) -#define glNormal3fVertex3fvSUN GLEW_GET_FUN(__glewNormal3fVertex3fvSUN) -#define glReplacementCodeuiColor3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor3fVertex3fSUN) -#define glReplacementCodeuiColor3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor3fVertex3fvSUN) -#define glReplacementCodeuiColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4fNormal3fVertex3fSUN) -#define glReplacementCodeuiColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4fNormal3fVertex3fvSUN) -#define glReplacementCodeuiColor4ubVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4ubVertex3fSUN) -#define glReplacementCodeuiColor4ubVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4ubVertex3fvSUN) -#define glReplacementCodeuiNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiNormal3fVertex3fSUN) -#define glReplacementCodeuiNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiNormal3fVertex3fvSUN) -#define glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN) -#define glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN) -#define glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN) -#define glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN) -#define glReplacementCodeuiTexCoord2fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fVertex3fSUN) -#define glReplacementCodeuiTexCoord2fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fVertex3fvSUN) -#define glReplacementCodeuiVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiVertex3fSUN) -#define glReplacementCodeuiVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiVertex3fvSUN) -#define glTexCoord2fColor3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor3fVertex3fSUN) -#define glTexCoord2fColor3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor3fVertex3fvSUN) -#define glTexCoord2fColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor4fNormal3fVertex3fSUN) -#define glTexCoord2fColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor4fNormal3fVertex3fvSUN) -#define glTexCoord2fColor4ubVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor4ubVertex3fSUN) -#define glTexCoord2fColor4ubVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor4ubVertex3fvSUN) -#define glTexCoord2fNormal3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fNormal3fVertex3fSUN) -#define glTexCoord2fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fNormal3fVertex3fvSUN) -#define glTexCoord2fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fVertex3fSUN) -#define glTexCoord2fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fVertex3fvSUN) -#define glTexCoord4fColor4fNormal3fVertex4fSUN GLEW_GET_FUN(__glewTexCoord4fColor4fNormal3fVertex4fSUN) -#define glTexCoord4fColor4fNormal3fVertex4fvSUN GLEW_GET_FUN(__glewTexCoord4fColor4fNormal3fVertex4fvSUN) -#define glTexCoord4fVertex4fSUN GLEW_GET_FUN(__glewTexCoord4fVertex4fSUN) -#define glTexCoord4fVertex4fvSUN GLEW_GET_FUN(__glewTexCoord4fVertex4fvSUN) - -#define GLEW_SUN_vertex GLEW_GET_VAR(__GLEW_SUN_vertex) - -#endif /* GL_SUN_vertex */ - -/* -------------------------- GL_WIN_phong_shading ------------------------- */ - -#ifndef GL_WIN_phong_shading -#define GL_WIN_phong_shading 1 - -#define GL_PHONG_WIN 0x80EA -#define GL_PHONG_HINT_WIN 0x80EB - -#define GLEW_WIN_phong_shading GLEW_GET_VAR(__GLEW_WIN_phong_shading) - -#endif /* GL_WIN_phong_shading */ - -/* -------------------------- GL_WIN_specular_fog -------------------------- */ - -#ifndef GL_WIN_specular_fog -#define GL_WIN_specular_fog 1 - -#define GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC - -#define GLEW_WIN_specular_fog GLEW_GET_VAR(__GLEW_WIN_specular_fog) - -#endif /* GL_WIN_specular_fog */ - -/* ---------------------------- GL_WIN_swap_hint --------------------------- */ - -#ifndef GL_WIN_swap_hint -#define GL_WIN_swap_hint 1 - -typedef void (GLAPIENTRY * PFNGLADDSWAPHINTRECTWINPROC) (GLint x, GLint y, GLsizei width, GLsizei height); - -#define glAddSwapHintRectWIN GLEW_GET_FUN(__glewAddSwapHintRectWIN) - -#define GLEW_WIN_swap_hint GLEW_GET_VAR(__GLEW_WIN_swap_hint) - -#endif /* GL_WIN_swap_hint */ - -/* ------------------------------------------------------------------------- */ - -#if defined(GLEW_MX) && defined(_WIN32) -#define GLEW_FUN_EXPORT -#else -#define GLEW_FUN_EXPORT GLEWAPI -#endif /* GLEW_MX */ - -#if defined(GLEW_MX) -#define GLEW_VAR_EXPORT -#else -#define GLEW_VAR_EXPORT GLEWAPI -#endif /* GLEW_MX */ - -#if defined(GLEW_MX) && defined(_WIN32) -struct GLEWContextStruct -{ -#endif /* GLEW_MX */ - -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE3DPROC __glewCopyTexSubImage3D; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSPROC __glewDrawRangeElements; -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DPROC __glewTexImage3D; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE3DPROC __glewTexSubImage3D; - -GLEW_FUN_EXPORT PFNGLACTIVETEXTUREPROC __glewActiveTexture; -GLEW_FUN_EXPORT PFNGLCLIENTACTIVETEXTUREPROC __glewClientActiveTexture; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE1DPROC __glewCompressedTexImage1D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE2DPROC __glewCompressedTexImage2D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE3DPROC __glewCompressedTexImage3D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC __glewCompressedTexSubImage1D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC __glewCompressedTexSubImage2D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC __glewCompressedTexSubImage3D; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXIMAGEPROC __glewGetCompressedTexImage; -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXDPROC __glewLoadTransposeMatrixd; -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXFPROC __glewLoadTransposeMatrixf; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXDPROC __glewMultTransposeMatrixd; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXFPROC __glewMultTransposeMatrixf; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DPROC __glewMultiTexCoord1d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DVPROC __glewMultiTexCoord1dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FPROC __glewMultiTexCoord1f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FVPROC __glewMultiTexCoord1fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IPROC __glewMultiTexCoord1i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IVPROC __glewMultiTexCoord1iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SPROC __glewMultiTexCoord1s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SVPROC __glewMultiTexCoord1sv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DPROC __glewMultiTexCoord2d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DVPROC __glewMultiTexCoord2dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FPROC __glewMultiTexCoord2f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FVPROC __glewMultiTexCoord2fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IPROC __glewMultiTexCoord2i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IVPROC __glewMultiTexCoord2iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SPROC __glewMultiTexCoord2s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SVPROC __glewMultiTexCoord2sv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DPROC __glewMultiTexCoord3d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DVPROC __glewMultiTexCoord3dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FPROC __glewMultiTexCoord3f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FVPROC __glewMultiTexCoord3fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IPROC __glewMultiTexCoord3i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IVPROC __glewMultiTexCoord3iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SPROC __glewMultiTexCoord3s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SVPROC __glewMultiTexCoord3sv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DPROC __glewMultiTexCoord4d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DVPROC __glewMultiTexCoord4dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FPROC __glewMultiTexCoord4f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FVPROC __glewMultiTexCoord4fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IPROC __glewMultiTexCoord4i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IVPROC __glewMultiTexCoord4iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SPROC __glewMultiTexCoord4s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SVPROC __glewMultiTexCoord4sv; -GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEPROC __glewSampleCoverage; - -GLEW_FUN_EXPORT PFNGLBLENDCOLORPROC __glewBlendColor; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONPROC __glewBlendEquation; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEPROC __glewBlendFuncSeparate; -GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTERPROC __glewFogCoordPointer; -GLEW_FUN_EXPORT PFNGLFOGCOORDDPROC __glewFogCoordd; -GLEW_FUN_EXPORT PFNGLFOGCOORDDVPROC __glewFogCoorddv; -GLEW_FUN_EXPORT PFNGLFOGCOORDFPROC __glewFogCoordf; -GLEW_FUN_EXPORT PFNGLFOGCOORDFVPROC __glewFogCoordfv; -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSPROC __glewMultiDrawArrays; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSPROC __glewMultiDrawElements; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFPROC __glewPointParameterf; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVPROC __glewPointParameterfv; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIPROC __glewPointParameteri; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIVPROC __glewPointParameteriv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BPROC __glewSecondaryColor3b; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BVPROC __glewSecondaryColor3bv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DPROC __glewSecondaryColor3d; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DVPROC __glewSecondaryColor3dv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FPROC __glewSecondaryColor3f; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FVPROC __glewSecondaryColor3fv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IPROC __glewSecondaryColor3i; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IVPROC __glewSecondaryColor3iv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SPROC __glewSecondaryColor3s; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SVPROC __glewSecondaryColor3sv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBPROC __glewSecondaryColor3ub; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBVPROC __glewSecondaryColor3ubv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIPROC __glewSecondaryColor3ui; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIVPROC __glewSecondaryColor3uiv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USPROC __glewSecondaryColor3us; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USVPROC __glewSecondaryColor3usv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTERPROC __glewSecondaryColorPointer; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DPROC __glewWindowPos2d; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVPROC __glewWindowPos2dv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FPROC __glewWindowPos2f; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVPROC __glewWindowPos2fv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IPROC __glewWindowPos2i; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVPROC __glewWindowPos2iv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SPROC __glewWindowPos2s; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVPROC __glewWindowPos2sv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DPROC __glewWindowPos3d; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVPROC __glewWindowPos3dv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FPROC __glewWindowPos3f; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVPROC __glewWindowPos3fv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IPROC __glewWindowPos3i; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVPROC __glewWindowPos3iv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SPROC __glewWindowPos3s; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVPROC __glewWindowPos3sv; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYPROC __glewBeginQuery; -GLEW_FUN_EXPORT PFNGLBINDBUFFERPROC __glewBindBuffer; -GLEW_FUN_EXPORT PFNGLBUFFERDATAPROC __glewBufferData; -GLEW_FUN_EXPORT PFNGLBUFFERSUBDATAPROC __glewBufferSubData; -GLEW_FUN_EXPORT PFNGLDELETEBUFFERSPROC __glewDeleteBuffers; -GLEW_FUN_EXPORT PFNGLDELETEQUERIESPROC __glewDeleteQueries; -GLEW_FUN_EXPORT PFNGLENDQUERYPROC __glewEndQuery; -GLEW_FUN_EXPORT PFNGLGENBUFFERSPROC __glewGenBuffers; -GLEW_FUN_EXPORT PFNGLGENQUERIESPROC __glewGenQueries; -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERIVPROC __glewGetBufferParameteriv; -GLEW_FUN_EXPORT PFNGLGETBUFFERPOINTERVPROC __glewGetBufferPointerv; -GLEW_FUN_EXPORT PFNGLGETBUFFERSUBDATAPROC __glewGetBufferSubData; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVPROC __glewGetQueryObjectiv; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVPROC __glewGetQueryObjectuiv; -GLEW_FUN_EXPORT PFNGLGETQUERYIVPROC __glewGetQueryiv; -GLEW_FUN_EXPORT PFNGLISBUFFERPROC __glewIsBuffer; -GLEW_FUN_EXPORT PFNGLISQUERYPROC __glewIsQuery; -GLEW_FUN_EXPORT PFNGLMAPBUFFERPROC __glewMapBuffer; -GLEW_FUN_EXPORT PFNGLUNMAPBUFFERPROC __glewUnmapBuffer; - -GLEW_FUN_EXPORT PFNGLATTACHSHADERPROC __glewAttachShader; -GLEW_FUN_EXPORT PFNGLBINDATTRIBLOCATIONPROC __glewBindAttribLocation; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEPROC __glewBlendEquationSeparate; -GLEW_FUN_EXPORT PFNGLCOMPILESHADERPROC __glewCompileShader; -GLEW_FUN_EXPORT PFNGLCREATEPROGRAMPROC __glewCreateProgram; -GLEW_FUN_EXPORT PFNGLCREATESHADERPROC __glewCreateShader; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMPROC __glewDeleteProgram; -GLEW_FUN_EXPORT PFNGLDELETESHADERPROC __glewDeleteShader; -GLEW_FUN_EXPORT PFNGLDETACHSHADERPROC __glewDetachShader; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBARRAYPROC __glewDisableVertexAttribArray; -GLEW_FUN_EXPORT PFNGLDRAWBUFFERSPROC __glewDrawBuffers; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBARRAYPROC __glewEnableVertexAttribArray; -GLEW_FUN_EXPORT PFNGLGETACTIVEATTRIBPROC __glewGetActiveAttrib; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMPROC __glewGetActiveUniform; -GLEW_FUN_EXPORT PFNGLGETATTACHEDSHADERSPROC __glewGetAttachedShaders; -GLEW_FUN_EXPORT PFNGLGETATTRIBLOCATIONPROC __glewGetAttribLocation; -GLEW_FUN_EXPORT PFNGLGETPROGRAMINFOLOGPROC __glewGetProgramInfoLog; -GLEW_FUN_EXPORT PFNGLGETPROGRAMIVPROC __glewGetProgramiv; -GLEW_FUN_EXPORT PFNGLGETSHADERINFOLOGPROC __glewGetShaderInfoLog; -GLEW_FUN_EXPORT PFNGLGETSHADERSOURCEPROC __glewGetShaderSource; -GLEW_FUN_EXPORT PFNGLGETSHADERIVPROC __glewGetShaderiv; -GLEW_FUN_EXPORT PFNGLGETUNIFORMLOCATIONPROC __glewGetUniformLocation; -GLEW_FUN_EXPORT PFNGLGETUNIFORMFVPROC __glewGetUniformfv; -GLEW_FUN_EXPORT PFNGLGETUNIFORMIVPROC __glewGetUniformiv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVPROC __glewGetVertexAttribPointerv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVPROC __glewGetVertexAttribdv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVPROC __glewGetVertexAttribfv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVPROC __glewGetVertexAttribiv; -GLEW_FUN_EXPORT PFNGLISPROGRAMPROC __glewIsProgram; -GLEW_FUN_EXPORT PFNGLISSHADERPROC __glewIsShader; -GLEW_FUN_EXPORT PFNGLLINKPROGRAMPROC __glewLinkProgram; -GLEW_FUN_EXPORT PFNGLSHADERSOURCEPROC __glewShaderSource; -GLEW_FUN_EXPORT PFNGLSTENCILFUNCSEPARATEPROC __glewStencilFuncSeparate; -GLEW_FUN_EXPORT PFNGLSTENCILMASKSEPARATEPROC __glewStencilMaskSeparate; -GLEW_FUN_EXPORT PFNGLSTENCILOPSEPARATEPROC __glewStencilOpSeparate; -GLEW_FUN_EXPORT PFNGLUNIFORM1FPROC __glewUniform1f; -GLEW_FUN_EXPORT PFNGLUNIFORM1FVPROC __glewUniform1fv; -GLEW_FUN_EXPORT PFNGLUNIFORM1IPROC __glewUniform1i; -GLEW_FUN_EXPORT PFNGLUNIFORM1IVPROC __glewUniform1iv; -GLEW_FUN_EXPORT PFNGLUNIFORM2FPROC __glewUniform2f; -GLEW_FUN_EXPORT PFNGLUNIFORM2FVPROC __glewUniform2fv; -GLEW_FUN_EXPORT PFNGLUNIFORM2IPROC __glewUniform2i; -GLEW_FUN_EXPORT PFNGLUNIFORM2IVPROC __glewUniform2iv; -GLEW_FUN_EXPORT PFNGLUNIFORM3FPROC __glewUniform3f; -GLEW_FUN_EXPORT PFNGLUNIFORM3FVPROC __glewUniform3fv; -GLEW_FUN_EXPORT PFNGLUNIFORM3IPROC __glewUniform3i; -GLEW_FUN_EXPORT PFNGLUNIFORM3IVPROC __glewUniform3iv; -GLEW_FUN_EXPORT PFNGLUNIFORM4FPROC __glewUniform4f; -GLEW_FUN_EXPORT PFNGLUNIFORM4FVPROC __glewUniform4fv; -GLEW_FUN_EXPORT PFNGLUNIFORM4IPROC __glewUniform4i; -GLEW_FUN_EXPORT PFNGLUNIFORM4IVPROC __glewUniform4iv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2FVPROC __glewUniformMatrix2fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3FVPROC __glewUniformMatrix3fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4FVPROC __glewUniformMatrix4fv; -GLEW_FUN_EXPORT PFNGLUSEPROGRAMPROC __glewUseProgram; -GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMPROC __glewValidateProgram; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DPROC __glewVertexAttrib1d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVPROC __glewVertexAttrib1dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FPROC __glewVertexAttrib1f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVPROC __glewVertexAttrib1fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SPROC __glewVertexAttrib1s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVPROC __glewVertexAttrib1sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DPROC __glewVertexAttrib2d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVPROC __glewVertexAttrib2dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FPROC __glewVertexAttrib2f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVPROC __glewVertexAttrib2fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SPROC __glewVertexAttrib2s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVPROC __glewVertexAttrib2sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DPROC __glewVertexAttrib3d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVPROC __glewVertexAttrib3dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FPROC __glewVertexAttrib3f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVPROC __glewVertexAttrib3fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SPROC __glewVertexAttrib3s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVPROC __glewVertexAttrib3sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NBVPROC __glewVertexAttrib4Nbv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NIVPROC __glewVertexAttrib4Niv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NSVPROC __glewVertexAttrib4Nsv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBPROC __glewVertexAttrib4Nub; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBVPROC __glewVertexAttrib4Nubv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUIVPROC __glewVertexAttrib4Nuiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUSVPROC __glewVertexAttrib4Nusv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4BVPROC __glewVertexAttrib4bv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DPROC __glewVertexAttrib4d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVPROC __glewVertexAttrib4dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FPROC __glewVertexAttrib4f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVPROC __glewVertexAttrib4fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4IVPROC __glewVertexAttrib4iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SPROC __glewVertexAttrib4s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVPROC __glewVertexAttrib4sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVPROC __glewVertexAttrib4ubv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UIVPROC __glewVertexAttrib4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4USVPROC __glewVertexAttrib4usv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERPROC __glewVertexAttribPointer; - -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X3FVPROC __glewUniformMatrix2x3fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X4FVPROC __glewUniformMatrix2x4fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X2FVPROC __glewUniformMatrix3x2fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X4FVPROC __glewUniformMatrix3x4fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X2FVPROC __glewUniformMatrix4x2fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X3FVPROC __glewUniformMatrix4x3fv; - -GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERPROC __glewBeginConditionalRender; -GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKPROC __glewBeginTransformFeedback; -GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONPROC __glewBindFragDataLocation; -GLEW_FUN_EXPORT PFNGLCLAMPCOLORPROC __glewClampColor; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERFIPROC __glewClearBufferfi; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERFVPROC __glewClearBufferfv; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERIVPROC __glewClearBufferiv; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERUIVPROC __glewClearBufferuiv; -GLEW_FUN_EXPORT PFNGLCOLORMASKIPROC __glewColorMaski; -GLEW_FUN_EXPORT PFNGLDISABLEIPROC __glewDisablei; -GLEW_FUN_EXPORT PFNGLENABLEIPROC __glewEnablei; -GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERPROC __glewEndConditionalRender; -GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKPROC __glewEndTransformFeedback; -GLEW_FUN_EXPORT PFNGLGETBOOLEANI_VPROC __glewGetBooleani_v; -GLEW_FUN_EXPORT PFNGLGETFRAGDATALOCATIONPROC __glewGetFragDataLocation; -GLEW_FUN_EXPORT PFNGLGETSTRINGIPROC __glewGetStringi; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIIVPROC __glewGetTexParameterIiv; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIUIVPROC __glewGetTexParameterIuiv; -GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGPROC __glewGetTransformFeedbackVarying; -GLEW_FUN_EXPORT PFNGLGETUNIFORMUIVPROC __glewGetUniformuiv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIIVPROC __glewGetVertexAttribIiv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIUIVPROC __glewGetVertexAttribIuiv; -GLEW_FUN_EXPORT PFNGLISENABLEDIPROC __glewIsEnabledi; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIIVPROC __glewTexParameterIiv; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIUIVPROC __glewTexParameterIuiv; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSPROC __glewTransformFeedbackVaryings; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIPROC __glewUniform1ui; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIVPROC __glewUniform1uiv; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIPROC __glewUniform2ui; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIVPROC __glewUniform2uiv; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIPROC __glewUniform3ui; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIVPROC __glewUniform3uiv; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIPROC __glewUniform4ui; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIVPROC __glewUniform4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IPROC __glewVertexAttribI1i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IVPROC __glewVertexAttribI1iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIPROC __glewVertexAttribI1ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIVPROC __glewVertexAttribI1uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IPROC __glewVertexAttribI2i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IVPROC __glewVertexAttribI2iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIPROC __glewVertexAttribI2ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIVPROC __glewVertexAttribI2uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IPROC __glewVertexAttribI3i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IVPROC __glewVertexAttribI3iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIPROC __glewVertexAttribI3ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIVPROC __glewVertexAttribI3uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4BVPROC __glewVertexAttribI4bv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IPROC __glewVertexAttribI4i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IVPROC __glewVertexAttribI4iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4SVPROC __glewVertexAttribI4sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UBVPROC __glewVertexAttribI4ubv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIPROC __glewVertexAttribI4ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIVPROC __glewVertexAttribI4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4USVPROC __glewVertexAttribI4usv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIPOINTERPROC __glewVertexAttribIPointer; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDPROC __glewDrawArraysInstanced; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDPROC __glewDrawElementsInstanced; -GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTINDEXPROC __glewPrimitiveRestartIndex; -GLEW_FUN_EXPORT PFNGLTEXBUFFERPROC __glewTexBuffer; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREPROC __glewFramebufferTexture; -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERI64VPROC __glewGetBufferParameteri64v; -GLEW_FUN_EXPORT PFNGLGETINTEGER64I_VPROC __glewGetInteger64i_v; - -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBDIVISORPROC __glewVertexAttribDivisor; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEIPROC __glewBlendEquationSeparatei; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONIPROC __glewBlendEquationi; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEIPROC __glewBlendFuncSeparatei; -GLEW_FUN_EXPORT PFNGLBLENDFUNCIPROC __glewBlendFunci; -GLEW_FUN_EXPORT PFNGLMINSAMPLESHADINGPROC __glewMinSampleShading; - -GLEW_FUN_EXPORT PFNGLTBUFFERMASK3DFXPROC __glewTbufferMask3DFX; - -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECALLBACKAMDPROC __glewDebugMessageCallbackAMD; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEENABLEAMDPROC __glewDebugMessageEnableAMD; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEINSERTAMDPROC __glewDebugMessageInsertAMD; -GLEW_FUN_EXPORT PFNGLGETDEBUGMESSAGELOGAMDPROC __glewGetDebugMessageLogAMD; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONINDEXEDAMDPROC __glewBlendEquationIndexedAMD; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC __glewBlendEquationSeparateIndexedAMD; -GLEW_FUN_EXPORT PFNGLBLENDFUNCINDEXEDAMDPROC __glewBlendFuncIndexedAMD; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC __glewBlendFuncSeparateIndexedAMD; - -GLEW_FUN_EXPORT PFNGLDELETENAMESAMDPROC __glewDeleteNamesAMD; -GLEW_FUN_EXPORT PFNGLGENNAMESAMDPROC __glewGenNamesAMD; -GLEW_FUN_EXPORT PFNGLISNAMEAMDPROC __glewIsNameAMD; - -GLEW_FUN_EXPORT PFNGLBEGINPERFMONITORAMDPROC __glewBeginPerfMonitorAMD; -GLEW_FUN_EXPORT PFNGLDELETEPERFMONITORSAMDPROC __glewDeletePerfMonitorsAMD; -GLEW_FUN_EXPORT PFNGLENDPERFMONITORAMDPROC __glewEndPerfMonitorAMD; -GLEW_FUN_EXPORT PFNGLGENPERFMONITORSAMDPROC __glewGenPerfMonitorsAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERDATAAMDPROC __glewGetPerfMonitorCounterDataAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERINFOAMDPROC __glewGetPerfMonitorCounterInfoAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC __glewGetPerfMonitorCounterStringAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERSAMDPROC __glewGetPerfMonitorCountersAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORGROUPSTRINGAMDPROC __glewGetPerfMonitorGroupStringAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORGROUPSAMDPROC __glewGetPerfMonitorGroupsAMD; -GLEW_FUN_EXPORT PFNGLSELECTPERFMONITORCOUNTERSAMDPROC __glewSelectPerfMonitorCountersAMD; - -GLEW_FUN_EXPORT PFNGLSETMULTISAMPLEFVAMDPROC __glewSetMultisamplefvAMD; - -GLEW_FUN_EXPORT PFNGLTESSELLATIONFACTORAMDPROC __glewTessellationFactorAMD; -GLEW_FUN_EXPORT PFNGLTESSELLATIONMODEAMDPROC __glewTessellationModeAMD; - -GLEW_FUN_EXPORT PFNGLDRAWELEMENTARRAYAPPLEPROC __glewDrawElementArrayAPPLE; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC __glewDrawRangeElementArrayAPPLE; -GLEW_FUN_EXPORT PFNGLELEMENTPOINTERAPPLEPROC __glewElementPointerAPPLE; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC __glewMultiDrawElementArrayAPPLE; -GLEW_FUN_EXPORT PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC __glewMultiDrawRangeElementArrayAPPLE; - -GLEW_FUN_EXPORT PFNGLDELETEFENCESAPPLEPROC __glewDeleteFencesAPPLE; -GLEW_FUN_EXPORT PFNGLFINISHFENCEAPPLEPROC __glewFinishFenceAPPLE; -GLEW_FUN_EXPORT PFNGLFINISHOBJECTAPPLEPROC __glewFinishObjectAPPLE; -GLEW_FUN_EXPORT PFNGLGENFENCESAPPLEPROC __glewGenFencesAPPLE; -GLEW_FUN_EXPORT PFNGLISFENCEAPPLEPROC __glewIsFenceAPPLE; -GLEW_FUN_EXPORT PFNGLSETFENCEAPPLEPROC __glewSetFenceAPPLE; -GLEW_FUN_EXPORT PFNGLTESTFENCEAPPLEPROC __glewTestFenceAPPLE; -GLEW_FUN_EXPORT PFNGLTESTOBJECTAPPLEPROC __glewTestObjectAPPLE; - -GLEW_FUN_EXPORT PFNGLBUFFERPARAMETERIAPPLEPROC __glewBufferParameteriAPPLE; -GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC __glewFlushMappedBufferRangeAPPLE; - -GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERIVAPPLEPROC __glewGetObjectParameterivAPPLE; -GLEW_FUN_EXPORT PFNGLOBJECTPURGEABLEAPPLEPROC __glewObjectPurgeableAPPLE; -GLEW_FUN_EXPORT PFNGLOBJECTUNPURGEABLEAPPLEPROC __glewObjectUnpurgeableAPPLE; - -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC __glewGetTexParameterPointervAPPLE; -GLEW_FUN_EXPORT PFNGLTEXTURERANGEAPPLEPROC __glewTextureRangeAPPLE; - -GLEW_FUN_EXPORT PFNGLBINDVERTEXARRAYAPPLEPROC __glewBindVertexArrayAPPLE; -GLEW_FUN_EXPORT PFNGLDELETEVERTEXARRAYSAPPLEPROC __glewDeleteVertexArraysAPPLE; -GLEW_FUN_EXPORT PFNGLGENVERTEXARRAYSAPPLEPROC __glewGenVertexArraysAPPLE; -GLEW_FUN_EXPORT PFNGLISVERTEXARRAYAPPLEPROC __glewIsVertexArrayAPPLE; - -GLEW_FUN_EXPORT PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC __glewFlushVertexArrayRangeAPPLE; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYPARAMETERIAPPLEPROC __glewVertexArrayParameteriAPPLE; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYRANGEAPPLEPROC __glewVertexArrayRangeAPPLE; - -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBAPPLEPROC __glewDisableVertexAttribAPPLE; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBAPPLEPROC __glewEnableVertexAttribAPPLE; -GLEW_FUN_EXPORT PFNGLISVERTEXATTRIBENABLEDAPPLEPROC __glewIsVertexAttribEnabledAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB1DAPPLEPROC __glewMapVertexAttrib1dAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB1FAPPLEPROC __glewMapVertexAttrib1fAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB2DAPPLEPROC __glewMapVertexAttrib2dAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB2FAPPLEPROC __glewMapVertexAttrib2fAPPLE; - -GLEW_FUN_EXPORT PFNGLCLEARDEPTHFPROC __glewClearDepthf; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEFPROC __glewDepthRangef; -GLEW_FUN_EXPORT PFNGLGETSHADERPRECISIONFORMATPROC __glewGetShaderPrecisionFormat; -GLEW_FUN_EXPORT PFNGLRELEASESHADERCOMPILERPROC __glewReleaseShaderCompiler; -GLEW_FUN_EXPORT PFNGLSHADERBINARYPROC __glewShaderBinary; - -GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONINDEXEDPROC __glewBindFragDataLocationIndexed; -GLEW_FUN_EXPORT PFNGLGETFRAGDATAINDEXPROC __glewGetFragDataIndex; - -GLEW_FUN_EXPORT PFNGLCREATESYNCFROMCLEVENTARBPROC __glewCreateSyncFromCLeventARB; - -GLEW_FUN_EXPORT PFNGLCLAMPCOLORARBPROC __glewClampColorARB; - -GLEW_FUN_EXPORT PFNGLCOPYBUFFERSUBDATAPROC __glewCopyBufferSubData; - -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECALLBACKARBPROC __glewDebugMessageCallbackARB; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECONTROLARBPROC __glewDebugMessageControlARB; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEINSERTARBPROC __glewDebugMessageInsertARB; -GLEW_FUN_EXPORT PFNGLGETDEBUGMESSAGELOGARBPROC __glewGetDebugMessageLogARB; - -GLEW_FUN_EXPORT PFNGLDRAWBUFFERSARBPROC __glewDrawBuffersARB; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEIARBPROC __glewBlendEquationSeparateiARB; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONIARBPROC __glewBlendEquationiARB; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEIARBPROC __glewBlendFuncSeparateiARB; -GLEW_FUN_EXPORT PFNGLBLENDFUNCIARBPROC __glewBlendFunciARB; - -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSBASEVERTEXPROC __glewDrawElementsBaseVertex; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC __glewDrawElementsInstancedBaseVertex; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC __glewDrawRangeElementsBaseVertex; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC __glewMultiDrawElementsBaseVertex; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINDIRECTPROC __glewDrawArraysIndirect; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINDIRECTPROC __glewDrawElementsIndirect; - -GLEW_FUN_EXPORT PFNGLBINDFRAMEBUFFERPROC __glewBindFramebuffer; -GLEW_FUN_EXPORT PFNGLBINDRENDERBUFFERPROC __glewBindRenderbuffer; -GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFERPROC __glewBlitFramebuffer; -GLEW_FUN_EXPORT PFNGLCHECKFRAMEBUFFERSTATUSPROC __glewCheckFramebufferStatus; -GLEW_FUN_EXPORT PFNGLDELETEFRAMEBUFFERSPROC __glewDeleteFramebuffers; -GLEW_FUN_EXPORT PFNGLDELETERENDERBUFFERSPROC __glewDeleteRenderbuffers; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERRENDERBUFFERPROC __glewFramebufferRenderbuffer; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE1DPROC __glewFramebufferTexture1D; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE2DPROC __glewFramebufferTexture2D; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE3DPROC __glewFramebufferTexture3D; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYERPROC __glewFramebufferTextureLayer; -GLEW_FUN_EXPORT PFNGLGENFRAMEBUFFERSPROC __glewGenFramebuffers; -GLEW_FUN_EXPORT PFNGLGENRENDERBUFFERSPROC __glewGenRenderbuffers; -GLEW_FUN_EXPORT PFNGLGENERATEMIPMAPPROC __glewGenerateMipmap; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC __glewGetFramebufferAttachmentParameteriv; -GLEW_FUN_EXPORT PFNGLGETRENDERBUFFERPARAMETERIVPROC __glewGetRenderbufferParameteriv; -GLEW_FUN_EXPORT PFNGLISFRAMEBUFFERPROC __glewIsFramebuffer; -GLEW_FUN_EXPORT PFNGLISRENDERBUFFERPROC __glewIsRenderbuffer; -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEPROC __glewRenderbufferStorage; -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC __glewRenderbufferStorageMultisample; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREARBPROC __glewFramebufferTextureARB; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREFACEARBPROC __glewFramebufferTextureFaceARB; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYERARBPROC __glewFramebufferTextureLayerARB; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIARBPROC __glewProgramParameteriARB; - -GLEW_FUN_EXPORT PFNGLGETPROGRAMBINARYPROC __glewGetProgramBinary; -GLEW_FUN_EXPORT PFNGLPROGRAMBINARYPROC __glewProgramBinary; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIPROC __glewProgramParameteri; - -GLEW_FUN_EXPORT PFNGLGETUNIFORMDVPROC __glewGetUniformdv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1DEXTPROC __glewProgramUniform1dEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1DVEXTPROC __glewProgramUniform1dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2DEXTPROC __glewProgramUniform2dEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2DVEXTPROC __glewProgramUniform2dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3DEXTPROC __glewProgramUniform3dEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3DVEXTPROC __glewProgramUniform3dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4DEXTPROC __glewProgramUniform4dEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4DVEXTPROC __glewProgramUniform4dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2DVEXTPROC __glewProgramUniformMatrix2dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3DVEXTPROC __glewProgramUniformMatrix2x3dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4DVEXTPROC __glewProgramUniformMatrix2x4dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3DVEXTPROC __glewProgramUniformMatrix3dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2DVEXTPROC __glewProgramUniformMatrix3x2dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4DVEXTPROC __glewProgramUniformMatrix3x4dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4DVEXTPROC __glewProgramUniformMatrix4dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2DVEXTPROC __glewProgramUniformMatrix4x2dvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3DVEXTPROC __glewProgramUniformMatrix4x3dvEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM1DPROC __glewUniform1d; -GLEW_FUN_EXPORT PFNGLUNIFORM1DVPROC __glewUniform1dv; -GLEW_FUN_EXPORT PFNGLUNIFORM2DPROC __glewUniform2d; -GLEW_FUN_EXPORT PFNGLUNIFORM2DVPROC __glewUniform2dv; -GLEW_FUN_EXPORT PFNGLUNIFORM3DPROC __glewUniform3d; -GLEW_FUN_EXPORT PFNGLUNIFORM3DVPROC __glewUniform3dv; -GLEW_FUN_EXPORT PFNGLUNIFORM4DPROC __glewUniform4d; -GLEW_FUN_EXPORT PFNGLUNIFORM4DVPROC __glewUniform4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2DVPROC __glewUniformMatrix2dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X3DVPROC __glewUniformMatrix2x3dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X4DVPROC __glewUniformMatrix2x4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3DVPROC __glewUniformMatrix3dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X2DVPROC __glewUniformMatrix3x2dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X4DVPROC __glewUniformMatrix3x4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4DVPROC __glewUniformMatrix4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X2DVPROC __glewUniformMatrix4x2dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X3DVPROC __glewUniformMatrix4x3dv; - -GLEW_FUN_EXPORT PFNGLCOLORSUBTABLEPROC __glewColorSubTable; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPROC __glewColorTable; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERFVPROC __glewColorTableParameterfv; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERIVPROC __glewColorTableParameteriv; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER1DPROC __glewConvolutionFilter1D; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER2DPROC __glewConvolutionFilter2D; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFPROC __glewConvolutionParameterf; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFVPROC __glewConvolutionParameterfv; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIPROC __glewConvolutionParameteri; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIVPROC __glewConvolutionParameteriv; -GLEW_FUN_EXPORT PFNGLCOPYCOLORSUBTABLEPROC __glewCopyColorSubTable; -GLEW_FUN_EXPORT PFNGLCOPYCOLORTABLEPROC __glewCopyColorTable; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER1DPROC __glewCopyConvolutionFilter1D; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER2DPROC __glewCopyConvolutionFilter2D; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPROC __glewGetColorTable; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVPROC __glewGetColorTableParameterfv; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVPROC __glewGetColorTableParameteriv; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONFILTERPROC __glewGetConvolutionFilter; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERFVPROC __glewGetConvolutionParameterfv; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERIVPROC __glewGetConvolutionParameteriv; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPROC __glewGetHistogram; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERFVPROC __glewGetHistogramParameterfv; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERIVPROC __glewGetHistogramParameteriv; -GLEW_FUN_EXPORT PFNGLGETMINMAXPROC __glewGetMinmax; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERFVPROC __glewGetMinmaxParameterfv; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERIVPROC __glewGetMinmaxParameteriv; -GLEW_FUN_EXPORT PFNGLGETSEPARABLEFILTERPROC __glewGetSeparableFilter; -GLEW_FUN_EXPORT PFNGLHISTOGRAMPROC __glewHistogram; -GLEW_FUN_EXPORT PFNGLMINMAXPROC __glewMinmax; -GLEW_FUN_EXPORT PFNGLRESETHISTOGRAMPROC __glewResetHistogram; -GLEW_FUN_EXPORT PFNGLRESETMINMAXPROC __glewResetMinmax; -GLEW_FUN_EXPORT PFNGLSEPARABLEFILTER2DPROC __glewSeparableFilter2D; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDARBPROC __glewDrawArraysInstancedARB; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDARBPROC __glewDrawElementsInstancedARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBDIVISORARBPROC __glewVertexAttribDivisorARB; - -GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDBUFFERRANGEPROC __glewFlushMappedBufferRange; -GLEW_FUN_EXPORT PFNGLMAPBUFFERRANGEPROC __glewMapBufferRange; - -GLEW_FUN_EXPORT PFNGLCURRENTPALETTEMATRIXARBPROC __glewCurrentPaletteMatrixARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXPOINTERARBPROC __glewMatrixIndexPointerARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXUBVARBPROC __glewMatrixIndexubvARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXUIVARBPROC __glewMatrixIndexuivARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXUSVARBPROC __glewMatrixIndexusvARB; - -GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEARBPROC __glewSampleCoverageARB; - -GLEW_FUN_EXPORT PFNGLACTIVETEXTUREARBPROC __glewActiveTextureARB; -GLEW_FUN_EXPORT PFNGLCLIENTACTIVETEXTUREARBPROC __glewClientActiveTextureARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DARBPROC __glewMultiTexCoord1dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DVARBPROC __glewMultiTexCoord1dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FARBPROC __glewMultiTexCoord1fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FVARBPROC __glewMultiTexCoord1fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IARBPROC __glewMultiTexCoord1iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IVARBPROC __glewMultiTexCoord1ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SARBPROC __glewMultiTexCoord1sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SVARBPROC __glewMultiTexCoord1svARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DARBPROC __glewMultiTexCoord2dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DVARBPROC __glewMultiTexCoord2dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FARBPROC __glewMultiTexCoord2fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FVARBPROC __glewMultiTexCoord2fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IARBPROC __glewMultiTexCoord2iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IVARBPROC __glewMultiTexCoord2ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SARBPROC __glewMultiTexCoord2sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SVARBPROC __glewMultiTexCoord2svARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DARBPROC __glewMultiTexCoord3dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DVARBPROC __glewMultiTexCoord3dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FARBPROC __glewMultiTexCoord3fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FVARBPROC __glewMultiTexCoord3fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IARBPROC __glewMultiTexCoord3iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IVARBPROC __glewMultiTexCoord3ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SARBPROC __glewMultiTexCoord3sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SVARBPROC __glewMultiTexCoord3svARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DARBPROC __glewMultiTexCoord4dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DVARBPROC __glewMultiTexCoord4dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FARBPROC __glewMultiTexCoord4fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FVARBPROC __glewMultiTexCoord4fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IARBPROC __glewMultiTexCoord4iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IVARBPROC __glewMultiTexCoord4ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SARBPROC __glewMultiTexCoord4sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SVARBPROC __glewMultiTexCoord4svARB; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYARBPROC __glewBeginQueryARB; -GLEW_FUN_EXPORT PFNGLDELETEQUERIESARBPROC __glewDeleteQueriesARB; -GLEW_FUN_EXPORT PFNGLENDQUERYARBPROC __glewEndQueryARB; -GLEW_FUN_EXPORT PFNGLGENQUERIESARBPROC __glewGenQueriesARB; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVARBPROC __glewGetQueryObjectivARB; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVARBPROC __glewGetQueryObjectuivARB; -GLEW_FUN_EXPORT PFNGLGETQUERYIVARBPROC __glewGetQueryivARB; -GLEW_FUN_EXPORT PFNGLISQUERYARBPROC __glewIsQueryARB; - -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFARBPROC __glewPointParameterfARB; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVARBPROC __glewPointParameterfvARB; - -GLEW_FUN_EXPORT PFNGLPROVOKINGVERTEXPROC __glewProvokingVertex; - -GLEW_FUN_EXPORT PFNGLGETNCOLORTABLEARBPROC __glewGetnColorTableARB; -GLEW_FUN_EXPORT PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC __glewGetnCompressedTexImageARB; -GLEW_FUN_EXPORT PFNGLGETNCONVOLUTIONFILTERARBPROC __glewGetnConvolutionFilterARB; -GLEW_FUN_EXPORT PFNGLGETNHISTOGRAMARBPROC __glewGetnHistogramARB; -GLEW_FUN_EXPORT PFNGLGETNMAPDVARBPROC __glewGetnMapdvARB; -GLEW_FUN_EXPORT PFNGLGETNMAPFVARBPROC __glewGetnMapfvARB; -GLEW_FUN_EXPORT PFNGLGETNMAPIVARBPROC __glewGetnMapivARB; -GLEW_FUN_EXPORT PFNGLGETNMINMAXARBPROC __glewGetnMinmaxARB; -GLEW_FUN_EXPORT PFNGLGETNPIXELMAPFVARBPROC __glewGetnPixelMapfvARB; -GLEW_FUN_EXPORT PFNGLGETNPIXELMAPUIVARBPROC __glewGetnPixelMapuivARB; -GLEW_FUN_EXPORT PFNGLGETNPIXELMAPUSVARBPROC __glewGetnPixelMapusvARB; -GLEW_FUN_EXPORT PFNGLGETNPOLYGONSTIPPLEARBPROC __glewGetnPolygonStippleARB; -GLEW_FUN_EXPORT PFNGLGETNSEPARABLEFILTERARBPROC __glewGetnSeparableFilterARB; -GLEW_FUN_EXPORT PFNGLGETNTEXIMAGEARBPROC __glewGetnTexImageARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMDVARBPROC __glewGetnUniformdvARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMFVARBPROC __glewGetnUniformfvARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMIVARBPROC __glewGetnUniformivARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMUIVARBPROC __glewGetnUniformuivARB; -GLEW_FUN_EXPORT PFNGLREADNPIXELSARBPROC __glewReadnPixelsARB; - -GLEW_FUN_EXPORT PFNGLMINSAMPLESHADINGARBPROC __glewMinSampleShadingARB; - -GLEW_FUN_EXPORT PFNGLBINDSAMPLERPROC __glewBindSampler; -GLEW_FUN_EXPORT PFNGLDELETESAMPLERSPROC __glewDeleteSamplers; -GLEW_FUN_EXPORT PFNGLGENSAMPLERSPROC __glewGenSamplers; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIIVPROC __glewGetSamplerParameterIiv; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIUIVPROC __glewGetSamplerParameterIuiv; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERFVPROC __glewGetSamplerParameterfv; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIVPROC __glewGetSamplerParameteriv; -GLEW_FUN_EXPORT PFNGLISSAMPLERPROC __glewIsSampler; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIIVPROC __glewSamplerParameterIiv; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIUIVPROC __glewSamplerParameterIuiv; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERFPROC __glewSamplerParameterf; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERFVPROC __glewSamplerParameterfv; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIPROC __glewSamplerParameteri; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIVPROC __glewSamplerParameteriv; - -GLEW_FUN_EXPORT PFNGLACTIVESHADERPROGRAMPROC __glewActiveShaderProgram; -GLEW_FUN_EXPORT PFNGLBINDPROGRAMPIPELINEPROC __glewBindProgramPipeline; -GLEW_FUN_EXPORT PFNGLCREATESHADERPROGRAMVPROC __glewCreateShaderProgramv; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMPIPELINESPROC __glewDeleteProgramPipelines; -GLEW_FUN_EXPORT PFNGLGENPROGRAMPIPELINESPROC __glewGenProgramPipelines; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPIPELINEINFOLOGPROC __glewGetProgramPipelineInfoLog; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPIPELINEIVPROC __glewGetProgramPipelineiv; -GLEW_FUN_EXPORT PFNGLISPROGRAMPIPELINEPROC __glewIsProgramPipeline; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1DPROC __glewProgramUniform1d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1DVPROC __glewProgramUniform1dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FPROC __glewProgramUniform1f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FVPROC __glewProgramUniform1fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IPROC __glewProgramUniform1i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IVPROC __glewProgramUniform1iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIPROC __glewProgramUniform1ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIVPROC __glewProgramUniform1uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2DPROC __glewProgramUniform2d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2DVPROC __glewProgramUniform2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FPROC __glewProgramUniform2f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FVPROC __glewProgramUniform2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IPROC __glewProgramUniform2i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IVPROC __glewProgramUniform2iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIPROC __glewProgramUniform2ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIVPROC __glewProgramUniform2uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3DPROC __glewProgramUniform3d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3DVPROC __glewProgramUniform3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FPROC __glewProgramUniform3f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FVPROC __glewProgramUniform3fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IPROC __glewProgramUniform3i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IVPROC __glewProgramUniform3iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIPROC __glewProgramUniform3ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIVPROC __glewProgramUniform3uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4DPROC __glewProgramUniform4d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4DVPROC __glewProgramUniform4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FPROC __glewProgramUniform4f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FVPROC __glewProgramUniform4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IPROC __glewProgramUniform4i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IVPROC __glewProgramUniform4iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIPROC __glewProgramUniform4ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIVPROC __glewProgramUniform4uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2DVPROC __glewProgramUniformMatrix2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2FVPROC __glewProgramUniformMatrix2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC __glewProgramUniformMatrix2x3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC __glewProgramUniformMatrix2x3fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC __glewProgramUniformMatrix2x4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC __glewProgramUniformMatrix2x4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3DVPROC __glewProgramUniformMatrix3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3FVPROC __glewProgramUniformMatrix3fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC __glewProgramUniformMatrix3x2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC __glewProgramUniformMatrix3x2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC __glewProgramUniformMatrix3x4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC __glewProgramUniformMatrix3x4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4DVPROC __glewProgramUniformMatrix4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4FVPROC __glewProgramUniformMatrix4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC __glewProgramUniformMatrix4x2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC __glewProgramUniformMatrix4x2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC __glewProgramUniformMatrix4x3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC __glewProgramUniformMatrix4x3fv; -GLEW_FUN_EXPORT PFNGLUSEPROGRAMSTAGESPROC __glewUseProgramStages; -GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMPIPELINEPROC __glewValidateProgramPipeline; - -GLEW_FUN_EXPORT PFNGLATTACHOBJECTARBPROC __glewAttachObjectARB; -GLEW_FUN_EXPORT PFNGLCOMPILESHADERARBPROC __glewCompileShaderARB; -GLEW_FUN_EXPORT PFNGLCREATEPROGRAMOBJECTARBPROC __glewCreateProgramObjectARB; -GLEW_FUN_EXPORT PFNGLCREATESHADEROBJECTARBPROC __glewCreateShaderObjectARB; -GLEW_FUN_EXPORT PFNGLDELETEOBJECTARBPROC __glewDeleteObjectARB; -GLEW_FUN_EXPORT PFNGLDETACHOBJECTARBPROC __glewDetachObjectARB; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMARBPROC __glewGetActiveUniformARB; -GLEW_FUN_EXPORT PFNGLGETATTACHEDOBJECTSARBPROC __glewGetAttachedObjectsARB; -GLEW_FUN_EXPORT PFNGLGETHANDLEARBPROC __glewGetHandleARB; -GLEW_FUN_EXPORT PFNGLGETINFOLOGARBPROC __glewGetInfoLogARB; -GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERFVARBPROC __glewGetObjectParameterfvARB; -GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERIVARBPROC __glewGetObjectParameterivARB; -GLEW_FUN_EXPORT PFNGLGETSHADERSOURCEARBPROC __glewGetShaderSourceARB; -GLEW_FUN_EXPORT PFNGLGETUNIFORMLOCATIONARBPROC __glewGetUniformLocationARB; -GLEW_FUN_EXPORT PFNGLGETUNIFORMFVARBPROC __glewGetUniformfvARB; -GLEW_FUN_EXPORT PFNGLGETUNIFORMIVARBPROC __glewGetUniformivARB; -GLEW_FUN_EXPORT PFNGLLINKPROGRAMARBPROC __glewLinkProgramARB; -GLEW_FUN_EXPORT PFNGLSHADERSOURCEARBPROC __glewShaderSourceARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1FARBPROC __glewUniform1fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1FVARBPROC __glewUniform1fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1IARBPROC __glewUniform1iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1IVARBPROC __glewUniform1ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2FARBPROC __glewUniform2fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2FVARBPROC __glewUniform2fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2IARBPROC __glewUniform2iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2IVARBPROC __glewUniform2ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3FARBPROC __glewUniform3fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3FVARBPROC __glewUniform3fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3IARBPROC __glewUniform3iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3IVARBPROC __glewUniform3ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4FARBPROC __glewUniform4fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4FVARBPROC __glewUniform4fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4IARBPROC __glewUniform4iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4IVARBPROC __glewUniform4ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2FVARBPROC __glewUniformMatrix2fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3FVARBPROC __glewUniformMatrix3fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4FVARBPROC __glewUniformMatrix4fvARB; -GLEW_FUN_EXPORT PFNGLUSEPROGRAMOBJECTARBPROC __glewUseProgramObjectARB; -GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMARBPROC __glewValidateProgramARB; - -GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINENAMEPROC __glewGetActiveSubroutineName; -GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC __glewGetActiveSubroutineUniformName; -GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC __glewGetActiveSubroutineUniformiv; -GLEW_FUN_EXPORT PFNGLGETPROGRAMSTAGEIVPROC __glewGetProgramStageiv; -GLEW_FUN_EXPORT PFNGLGETSUBROUTINEINDEXPROC __glewGetSubroutineIndex; -GLEW_FUN_EXPORT PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC __glewGetSubroutineUniformLocation; -GLEW_FUN_EXPORT PFNGLGETUNIFORMSUBROUTINEUIVPROC __glewGetUniformSubroutineuiv; -GLEW_FUN_EXPORT PFNGLUNIFORMSUBROUTINESUIVPROC __glewUniformSubroutinesuiv; - -GLEW_FUN_EXPORT PFNGLCOMPILESHADERINCLUDEARBPROC __glewCompileShaderIncludeARB; -GLEW_FUN_EXPORT PFNGLDELETENAMEDSTRINGARBPROC __glewDeleteNamedStringARB; -GLEW_FUN_EXPORT PFNGLGETNAMEDSTRINGARBPROC __glewGetNamedStringARB; -GLEW_FUN_EXPORT PFNGLGETNAMEDSTRINGIVARBPROC __glewGetNamedStringivARB; -GLEW_FUN_EXPORT PFNGLISNAMEDSTRINGARBPROC __glewIsNamedStringARB; -GLEW_FUN_EXPORT PFNGLNAMEDSTRINGARBPROC __glewNamedStringARB; - -GLEW_FUN_EXPORT PFNGLCLIENTWAITSYNCPROC __glewClientWaitSync; -GLEW_FUN_EXPORT PFNGLDELETESYNCPROC __glewDeleteSync; -GLEW_FUN_EXPORT PFNGLFENCESYNCPROC __glewFenceSync; -GLEW_FUN_EXPORT PFNGLGETINTEGER64VPROC __glewGetInteger64v; -GLEW_FUN_EXPORT PFNGLGETSYNCIVPROC __glewGetSynciv; -GLEW_FUN_EXPORT PFNGLISSYNCPROC __glewIsSync; -GLEW_FUN_EXPORT PFNGLWAITSYNCPROC __glewWaitSync; - -GLEW_FUN_EXPORT PFNGLPATCHPARAMETERFVPROC __glewPatchParameterfv; -GLEW_FUN_EXPORT PFNGLPATCHPARAMETERIPROC __glewPatchParameteri; - -GLEW_FUN_EXPORT PFNGLTEXBUFFERARBPROC __glewTexBufferARB; - -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE1DARBPROC __glewCompressedTexImage1DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE2DARBPROC __glewCompressedTexImage2DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE3DARBPROC __glewCompressedTexImage3DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC __glewCompressedTexSubImage1DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC __glewCompressedTexSubImage2DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC __glewCompressedTexSubImage3DARB; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXIMAGEARBPROC __glewGetCompressedTexImageARB; - -GLEW_FUN_EXPORT PFNGLGETMULTISAMPLEFVPROC __glewGetMultisamplefv; -GLEW_FUN_EXPORT PFNGLSAMPLEMASKIPROC __glewSampleMaski; -GLEW_FUN_EXPORT PFNGLTEXIMAGE2DMULTISAMPLEPROC __glewTexImage2DMultisample; -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DMULTISAMPLEPROC __glewTexImage3DMultisample; - -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VPROC __glewGetQueryObjecti64v; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VPROC __glewGetQueryObjectui64v; -GLEW_FUN_EXPORT PFNGLQUERYCOUNTERPROC __glewQueryCounter; - -GLEW_FUN_EXPORT PFNGLBINDTRANSFORMFEEDBACKPROC __glewBindTransformFeedback; -GLEW_FUN_EXPORT PFNGLDELETETRANSFORMFEEDBACKSPROC __glewDeleteTransformFeedbacks; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKPROC __glewDrawTransformFeedback; -GLEW_FUN_EXPORT PFNGLGENTRANSFORMFEEDBACKSPROC __glewGenTransformFeedbacks; -GLEW_FUN_EXPORT PFNGLISTRANSFORMFEEDBACKPROC __glewIsTransformFeedback; -GLEW_FUN_EXPORT PFNGLPAUSETRANSFORMFEEDBACKPROC __glewPauseTransformFeedback; -GLEW_FUN_EXPORT PFNGLRESUMETRANSFORMFEEDBACKPROC __glewResumeTransformFeedback; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYINDEXEDPROC __glewBeginQueryIndexed; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC __glewDrawTransformFeedbackStream; -GLEW_FUN_EXPORT PFNGLENDQUERYINDEXEDPROC __glewEndQueryIndexed; -GLEW_FUN_EXPORT PFNGLGETQUERYINDEXEDIVPROC __glewGetQueryIndexediv; - -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXDARBPROC __glewLoadTransposeMatrixdARB; -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXFARBPROC __glewLoadTransposeMatrixfARB; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXDARBPROC __glewMultTransposeMatrixdARB; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXFARBPROC __glewMultTransposeMatrixfARB; - -GLEW_FUN_EXPORT PFNGLBINDBUFFERBASEPROC __glewBindBufferBase; -GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGEPROC __glewBindBufferRange; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC __glewGetActiveUniformBlockName; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMBLOCKIVPROC __glewGetActiveUniformBlockiv; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMNAMEPROC __glewGetActiveUniformName; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMSIVPROC __glewGetActiveUniformsiv; -GLEW_FUN_EXPORT PFNGLGETINTEGERI_VPROC __glewGetIntegeri_v; -GLEW_FUN_EXPORT PFNGLGETUNIFORMBLOCKINDEXPROC __glewGetUniformBlockIndex; -GLEW_FUN_EXPORT PFNGLGETUNIFORMINDICESPROC __glewGetUniformIndices; -GLEW_FUN_EXPORT PFNGLUNIFORMBLOCKBINDINGPROC __glewUniformBlockBinding; - -GLEW_FUN_EXPORT PFNGLBINDVERTEXARRAYPROC __glewBindVertexArray; -GLEW_FUN_EXPORT PFNGLDELETEVERTEXARRAYSPROC __glewDeleteVertexArrays; -GLEW_FUN_EXPORT PFNGLGENVERTEXARRAYSPROC __glewGenVertexArrays; -GLEW_FUN_EXPORT PFNGLISVERTEXARRAYPROC __glewIsVertexArray; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLDVPROC __glewGetVertexAttribLdv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DPROC __glewVertexAttribL1d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DVPROC __glewVertexAttribL1dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DPROC __glewVertexAttribL2d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DVPROC __glewVertexAttribL2dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DPROC __glewVertexAttribL3d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DVPROC __glewVertexAttribL3dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DPROC __glewVertexAttribL4d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DVPROC __glewVertexAttribL4dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLPOINTERPROC __glewVertexAttribLPointer; - -GLEW_FUN_EXPORT PFNGLVERTEXBLENDARBPROC __glewVertexBlendARB; -GLEW_FUN_EXPORT PFNGLWEIGHTPOINTERARBPROC __glewWeightPointerARB; -GLEW_FUN_EXPORT PFNGLWEIGHTBVARBPROC __glewWeightbvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTDVARBPROC __glewWeightdvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTFVARBPROC __glewWeightfvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTIVARBPROC __glewWeightivARB; -GLEW_FUN_EXPORT PFNGLWEIGHTSVARBPROC __glewWeightsvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTUBVARBPROC __glewWeightubvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTUIVARBPROC __glewWeightuivARB; -GLEW_FUN_EXPORT PFNGLWEIGHTUSVARBPROC __glewWeightusvARB; - -GLEW_FUN_EXPORT PFNGLBINDBUFFERARBPROC __glewBindBufferARB; -GLEW_FUN_EXPORT PFNGLBUFFERDATAARBPROC __glewBufferDataARB; -GLEW_FUN_EXPORT PFNGLBUFFERSUBDATAARBPROC __glewBufferSubDataARB; -GLEW_FUN_EXPORT PFNGLDELETEBUFFERSARBPROC __glewDeleteBuffersARB; -GLEW_FUN_EXPORT PFNGLGENBUFFERSARBPROC __glewGenBuffersARB; -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERIVARBPROC __glewGetBufferParameterivARB; -GLEW_FUN_EXPORT PFNGLGETBUFFERPOINTERVARBPROC __glewGetBufferPointervARB; -GLEW_FUN_EXPORT PFNGLGETBUFFERSUBDATAARBPROC __glewGetBufferSubDataARB; -GLEW_FUN_EXPORT PFNGLISBUFFERARBPROC __glewIsBufferARB; -GLEW_FUN_EXPORT PFNGLMAPBUFFERARBPROC __glewMapBufferARB; -GLEW_FUN_EXPORT PFNGLUNMAPBUFFERARBPROC __glewUnmapBufferARB; - -GLEW_FUN_EXPORT PFNGLBINDPROGRAMARBPROC __glewBindProgramARB; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMSARBPROC __glewDeleteProgramsARB; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBARRAYARBPROC __glewDisableVertexAttribArrayARB; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBARRAYARBPROC __glewEnableVertexAttribArrayARB; -GLEW_FUN_EXPORT PFNGLGENPROGRAMSARBPROC __glewGenProgramsARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMENVPARAMETERDVARBPROC __glewGetProgramEnvParameterdvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMENVPARAMETERFVARBPROC __glewGetProgramEnvParameterfvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC __glewGetProgramLocalParameterdvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC __glewGetProgramLocalParameterfvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMSTRINGARBPROC __glewGetProgramStringARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMIVARBPROC __glewGetProgramivARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVARBPROC __glewGetVertexAttribPointervARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVARBPROC __glewGetVertexAttribdvARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVARBPROC __glewGetVertexAttribfvARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVARBPROC __glewGetVertexAttribivARB; -GLEW_FUN_EXPORT PFNGLISPROGRAMARBPROC __glewIsProgramARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4DARBPROC __glewProgramEnvParameter4dARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4DVARBPROC __glewProgramEnvParameter4dvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4FARBPROC __glewProgramEnvParameter4fARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4FVARBPROC __glewProgramEnvParameter4fvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4DARBPROC __glewProgramLocalParameter4dARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4DVARBPROC __glewProgramLocalParameter4dvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4FARBPROC __glewProgramLocalParameter4fARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4FVARBPROC __glewProgramLocalParameter4fvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMSTRINGARBPROC __glewProgramStringARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DARBPROC __glewVertexAttrib1dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVARBPROC __glewVertexAttrib1dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FARBPROC __glewVertexAttrib1fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVARBPROC __glewVertexAttrib1fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SARBPROC __glewVertexAttrib1sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVARBPROC __glewVertexAttrib1svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DARBPROC __glewVertexAttrib2dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVARBPROC __glewVertexAttrib2dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FARBPROC __glewVertexAttrib2fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVARBPROC __glewVertexAttrib2fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SARBPROC __glewVertexAttrib2sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVARBPROC __glewVertexAttrib2svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DARBPROC __glewVertexAttrib3dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVARBPROC __glewVertexAttrib3dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FARBPROC __glewVertexAttrib3fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVARBPROC __glewVertexAttrib3fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SARBPROC __glewVertexAttrib3sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVARBPROC __glewVertexAttrib3svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NBVARBPROC __glewVertexAttrib4NbvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NIVARBPROC __glewVertexAttrib4NivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NSVARBPROC __glewVertexAttrib4NsvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBARBPROC __glewVertexAttrib4NubARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBVARBPROC __glewVertexAttrib4NubvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUIVARBPROC __glewVertexAttrib4NuivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUSVARBPROC __glewVertexAttrib4NusvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4BVARBPROC __glewVertexAttrib4bvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DARBPROC __glewVertexAttrib4dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVARBPROC __glewVertexAttrib4dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FARBPROC __glewVertexAttrib4fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVARBPROC __glewVertexAttrib4fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4IVARBPROC __glewVertexAttrib4ivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SARBPROC __glewVertexAttrib4sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVARBPROC __glewVertexAttrib4svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVARBPROC __glewVertexAttrib4ubvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UIVARBPROC __glewVertexAttrib4uivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4USVARBPROC __glewVertexAttrib4usvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERARBPROC __glewVertexAttribPointerARB; - -GLEW_FUN_EXPORT PFNGLBINDATTRIBLOCATIONARBPROC __glewBindAttribLocationARB; -GLEW_FUN_EXPORT PFNGLGETACTIVEATTRIBARBPROC __glewGetActiveAttribARB; -GLEW_FUN_EXPORT PFNGLGETATTRIBLOCATIONARBPROC __glewGetAttribLocationARB; - -GLEW_FUN_EXPORT PFNGLCOLORP3UIPROC __glewColorP3ui; -GLEW_FUN_EXPORT PFNGLCOLORP3UIVPROC __glewColorP3uiv; -GLEW_FUN_EXPORT PFNGLCOLORP4UIPROC __glewColorP4ui; -GLEW_FUN_EXPORT PFNGLCOLORP4UIVPROC __glewColorP4uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP1UIPROC __glewMultiTexCoordP1ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP1UIVPROC __glewMultiTexCoordP1uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP2UIPROC __glewMultiTexCoordP2ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP2UIVPROC __glewMultiTexCoordP2uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP3UIPROC __glewMultiTexCoordP3ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP3UIVPROC __glewMultiTexCoordP3uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP4UIPROC __glewMultiTexCoordP4ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP4UIVPROC __glewMultiTexCoordP4uiv; -GLEW_FUN_EXPORT PFNGLNORMALP3UIPROC __glewNormalP3ui; -GLEW_FUN_EXPORT PFNGLNORMALP3UIVPROC __glewNormalP3uiv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORP3UIPROC __glewSecondaryColorP3ui; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORP3UIVPROC __glewSecondaryColorP3uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP1UIPROC __glewTexCoordP1ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP1UIVPROC __glewTexCoordP1uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP2UIPROC __glewTexCoordP2ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP2UIVPROC __glewTexCoordP2uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP3UIPROC __glewTexCoordP3ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP3UIVPROC __glewTexCoordP3uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP4UIPROC __glewTexCoordP4ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP4UIVPROC __glewTexCoordP4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP1UIPROC __glewVertexAttribP1ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP1UIVPROC __glewVertexAttribP1uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP2UIPROC __glewVertexAttribP2ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP2UIVPROC __glewVertexAttribP2uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP3UIPROC __glewVertexAttribP3ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP3UIVPROC __glewVertexAttribP3uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP4UIPROC __glewVertexAttribP4ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP4UIVPROC __glewVertexAttribP4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXP2UIPROC __glewVertexP2ui; -GLEW_FUN_EXPORT PFNGLVERTEXP2UIVPROC __glewVertexP2uiv; -GLEW_FUN_EXPORT PFNGLVERTEXP3UIPROC __glewVertexP3ui; -GLEW_FUN_EXPORT PFNGLVERTEXP3UIVPROC __glewVertexP3uiv; -GLEW_FUN_EXPORT PFNGLVERTEXP4UIPROC __glewVertexP4ui; -GLEW_FUN_EXPORT PFNGLVERTEXP4UIVPROC __glewVertexP4uiv; - -GLEW_FUN_EXPORT PFNGLDEPTHRANGEARRAYVPROC __glewDepthRangeArrayv; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEINDEXEDPROC __glewDepthRangeIndexed; -GLEW_FUN_EXPORT PFNGLGETDOUBLEI_VPROC __glewGetDoublei_v; -GLEW_FUN_EXPORT PFNGLGETFLOATI_VPROC __glewGetFloati_v; -GLEW_FUN_EXPORT PFNGLSCISSORARRAYVPROC __glewScissorArrayv; -GLEW_FUN_EXPORT PFNGLSCISSORINDEXEDPROC __glewScissorIndexed; -GLEW_FUN_EXPORT PFNGLSCISSORINDEXEDVPROC __glewScissorIndexedv; -GLEW_FUN_EXPORT PFNGLVIEWPORTARRAYVPROC __glewViewportArrayv; -GLEW_FUN_EXPORT PFNGLVIEWPORTINDEXEDFPROC __glewViewportIndexedf; -GLEW_FUN_EXPORT PFNGLVIEWPORTINDEXEDFVPROC __glewViewportIndexedfv; - -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DARBPROC __glewWindowPos2dARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVARBPROC __glewWindowPos2dvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FARBPROC __glewWindowPos2fARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVARBPROC __glewWindowPos2fvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IARBPROC __glewWindowPos2iARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVARBPROC __glewWindowPos2ivARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SARBPROC __glewWindowPos2sARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVARBPROC __glewWindowPos2svARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DARBPROC __glewWindowPos3dARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVARBPROC __glewWindowPos3dvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FARBPROC __glewWindowPos3fARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVARBPROC __glewWindowPos3fvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IARBPROC __glewWindowPos3iARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVARBPROC __glewWindowPos3ivARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SARBPROC __glewWindowPos3sARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVARBPROC __glewWindowPos3svARB; - -GLEW_FUN_EXPORT PFNGLDRAWBUFFERSATIPROC __glewDrawBuffersATI; - -GLEW_FUN_EXPORT PFNGLDRAWELEMENTARRAYATIPROC __glewDrawElementArrayATI; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTARRAYATIPROC __glewDrawRangeElementArrayATI; -GLEW_FUN_EXPORT PFNGLELEMENTPOINTERATIPROC __glewElementPointerATI; - -GLEW_FUN_EXPORT PFNGLGETTEXBUMPPARAMETERFVATIPROC __glewGetTexBumpParameterfvATI; -GLEW_FUN_EXPORT PFNGLGETTEXBUMPPARAMETERIVATIPROC __glewGetTexBumpParameterivATI; -GLEW_FUN_EXPORT PFNGLTEXBUMPPARAMETERFVATIPROC __glewTexBumpParameterfvATI; -GLEW_FUN_EXPORT PFNGLTEXBUMPPARAMETERIVATIPROC __glewTexBumpParameterivATI; - -GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP1ATIPROC __glewAlphaFragmentOp1ATI; -GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP2ATIPROC __glewAlphaFragmentOp2ATI; -GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP3ATIPROC __glewAlphaFragmentOp3ATI; -GLEW_FUN_EXPORT PFNGLBEGINFRAGMENTSHADERATIPROC __glewBeginFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLBINDFRAGMENTSHADERATIPROC __glewBindFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP1ATIPROC __glewColorFragmentOp1ATI; -GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP2ATIPROC __glewColorFragmentOp2ATI; -GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP3ATIPROC __glewColorFragmentOp3ATI; -GLEW_FUN_EXPORT PFNGLDELETEFRAGMENTSHADERATIPROC __glewDeleteFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLENDFRAGMENTSHADERATIPROC __glewEndFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLGENFRAGMENTSHADERSATIPROC __glewGenFragmentShadersATI; -GLEW_FUN_EXPORT PFNGLPASSTEXCOORDATIPROC __glewPassTexCoordATI; -GLEW_FUN_EXPORT PFNGLSAMPLEMAPATIPROC __glewSampleMapATI; -GLEW_FUN_EXPORT PFNGLSETFRAGMENTSHADERCONSTANTATIPROC __glewSetFragmentShaderConstantATI; - -GLEW_FUN_EXPORT PFNGLMAPOBJECTBUFFERATIPROC __glewMapObjectBufferATI; -GLEW_FUN_EXPORT PFNGLUNMAPOBJECTBUFFERATIPROC __glewUnmapObjectBufferATI; - -GLEW_FUN_EXPORT PFNGLPNTRIANGLESFATIPROC __glewPNTrianglesfATI; -GLEW_FUN_EXPORT PFNGLPNTRIANGLESIATIPROC __glewPNTrianglesiATI; - -GLEW_FUN_EXPORT PFNGLSTENCILFUNCSEPARATEATIPROC __glewStencilFuncSeparateATI; -GLEW_FUN_EXPORT PFNGLSTENCILOPSEPARATEATIPROC __glewStencilOpSeparateATI; - -GLEW_FUN_EXPORT PFNGLARRAYOBJECTATIPROC __glewArrayObjectATI; -GLEW_FUN_EXPORT PFNGLFREEOBJECTBUFFERATIPROC __glewFreeObjectBufferATI; -GLEW_FUN_EXPORT PFNGLGETARRAYOBJECTFVATIPROC __glewGetArrayObjectfvATI; -GLEW_FUN_EXPORT PFNGLGETARRAYOBJECTIVATIPROC __glewGetArrayObjectivATI; -GLEW_FUN_EXPORT PFNGLGETOBJECTBUFFERFVATIPROC __glewGetObjectBufferfvATI; -GLEW_FUN_EXPORT PFNGLGETOBJECTBUFFERIVATIPROC __glewGetObjectBufferivATI; -GLEW_FUN_EXPORT PFNGLGETVARIANTARRAYOBJECTFVATIPROC __glewGetVariantArrayObjectfvATI; -GLEW_FUN_EXPORT PFNGLGETVARIANTARRAYOBJECTIVATIPROC __glewGetVariantArrayObjectivATI; -GLEW_FUN_EXPORT PFNGLISOBJECTBUFFERATIPROC __glewIsObjectBufferATI; -GLEW_FUN_EXPORT PFNGLNEWOBJECTBUFFERATIPROC __glewNewObjectBufferATI; -GLEW_FUN_EXPORT PFNGLUPDATEOBJECTBUFFERATIPROC __glewUpdateObjectBufferATI; -GLEW_FUN_EXPORT PFNGLVARIANTARRAYOBJECTATIPROC __glewVariantArrayObjectATI; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC __glewGetVertexAttribArrayObjectfvATI; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC __glewGetVertexAttribArrayObjectivATI; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBARRAYOBJECTATIPROC __glewVertexAttribArrayObjectATI; - -GLEW_FUN_EXPORT PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC __glewClientActiveVertexStreamATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3BATIPROC __glewNormalStream3bATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3BVATIPROC __glewNormalStream3bvATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3DATIPROC __glewNormalStream3dATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3DVATIPROC __glewNormalStream3dvATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3FATIPROC __glewNormalStream3fATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3FVATIPROC __glewNormalStream3fvATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3IATIPROC __glewNormalStream3iATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3IVATIPROC __glewNormalStream3ivATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3SATIPROC __glewNormalStream3sATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3SVATIPROC __glewNormalStream3svATI; -GLEW_FUN_EXPORT PFNGLVERTEXBLENDENVFATIPROC __glewVertexBlendEnvfATI; -GLEW_FUN_EXPORT PFNGLVERTEXBLENDENVIATIPROC __glewVertexBlendEnviATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2DATIPROC __glewVertexStream2dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2DVATIPROC __glewVertexStream2dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2FATIPROC __glewVertexStream2fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2FVATIPROC __glewVertexStream2fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2IATIPROC __glewVertexStream2iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2IVATIPROC __glewVertexStream2ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2SATIPROC __glewVertexStream2sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2SVATIPROC __glewVertexStream2svATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3DATIPROC __glewVertexStream3dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3DVATIPROC __glewVertexStream3dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3FATIPROC __glewVertexStream3fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3FVATIPROC __glewVertexStream3fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3IATIPROC __glewVertexStream3iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3IVATIPROC __glewVertexStream3ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3SATIPROC __glewVertexStream3sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3SVATIPROC __glewVertexStream3svATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4DATIPROC __glewVertexStream4dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4DVATIPROC __glewVertexStream4dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4FATIPROC __glewVertexStream4fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4FVATIPROC __glewVertexStream4fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4IATIPROC __glewVertexStream4iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4IVATIPROC __glewVertexStream4ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4SATIPROC __glewVertexStream4sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4SVATIPROC __glewVertexStream4svATI; - -GLEW_FUN_EXPORT PFNGLGETUNIFORMBUFFERSIZEEXTPROC __glewGetUniformBufferSizeEXT; -GLEW_FUN_EXPORT PFNGLGETUNIFORMOFFSETEXTPROC __glewGetUniformOffsetEXT; -GLEW_FUN_EXPORT PFNGLUNIFORMBUFFEREXTPROC __glewUniformBufferEXT; - -GLEW_FUN_EXPORT PFNGLBLENDCOLOREXTPROC __glewBlendColorEXT; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEEXTPROC __glewBlendEquationSeparateEXT; - -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEEXTPROC __glewBlendFuncSeparateEXT; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONEXTPROC __glewBlendEquationEXT; - -GLEW_FUN_EXPORT PFNGLCOLORSUBTABLEEXTPROC __glewColorSubTableEXT; -GLEW_FUN_EXPORT PFNGLCOPYCOLORSUBTABLEEXTPROC __glewCopyColorSubTableEXT; - -GLEW_FUN_EXPORT PFNGLLOCKARRAYSEXTPROC __glewLockArraysEXT; -GLEW_FUN_EXPORT PFNGLUNLOCKARRAYSEXTPROC __glewUnlockArraysEXT; - -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER1DEXTPROC __glewConvolutionFilter1DEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER2DEXTPROC __glewConvolutionFilter2DEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFEXTPROC __glewConvolutionParameterfEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFVEXTPROC __glewConvolutionParameterfvEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIEXTPROC __glewConvolutionParameteriEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIVEXTPROC __glewConvolutionParameterivEXT; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC __glewCopyConvolutionFilter1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC __glewCopyConvolutionFilter2DEXT; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONFILTEREXTPROC __glewGetConvolutionFilterEXT; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC __glewGetConvolutionParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC __glewGetConvolutionParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETSEPARABLEFILTEREXTPROC __glewGetSeparableFilterEXT; -GLEW_FUN_EXPORT PFNGLSEPARABLEFILTER2DEXTPROC __glewSeparableFilter2DEXT; - -GLEW_FUN_EXPORT PFNGLBINORMALPOINTEREXTPROC __glewBinormalPointerEXT; -GLEW_FUN_EXPORT PFNGLTANGENTPOINTEREXTPROC __glewTangentPointerEXT; - -GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE1DEXTPROC __glewCopyTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE2DEXTPROC __glewCopyTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE1DEXTPROC __glewCopyTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE2DEXTPROC __glewCopyTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE3DEXTPROC __glewCopyTexSubImage3DEXT; - -GLEW_FUN_EXPORT PFNGLCULLPARAMETERDVEXTPROC __glewCullParameterdvEXT; -GLEW_FUN_EXPORT PFNGLCULLPARAMETERFVEXTPROC __glewCullParameterfvEXT; - -GLEW_FUN_EXPORT PFNGLDEPTHBOUNDSEXTPROC __glewDepthBoundsEXT; - -GLEW_FUN_EXPORT PFNGLBINDMULTITEXTUREEXTPROC __glewBindMultiTextureEXT; -GLEW_FUN_EXPORT PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC __glewCheckNamedFramebufferStatusEXT; -GLEW_FUN_EXPORT PFNGLCLIENTATTRIBDEFAULTEXTPROC __glewClientAttribDefaultEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC __glewCompressedMultiTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC __glewCompressedMultiTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC __glewCompressedMultiTexImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC __glewCompressedMultiTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC __glewCompressedMultiTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC __glewCompressedMultiTexSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC __glewCompressedTextureImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC __glewCompressedTextureImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC __glewCompressedTextureImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC __glewCompressedTextureSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC __glewCompressedTextureSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC __glewCompressedTextureSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXIMAGE1DEXTPROC __glewCopyMultiTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXIMAGE2DEXTPROC __glewCopyMultiTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC __glewCopyMultiTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC __glewCopyMultiTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC __glewCopyMultiTexSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTUREIMAGE1DEXTPROC __glewCopyTextureImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTUREIMAGE2DEXTPROC __glewCopyTextureImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC __glewCopyTextureSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC __glewCopyTextureSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC __glewCopyTextureSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC __glewDisableClientStateIndexedEXT; -GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEIEXTPROC __glewDisableClientStateiEXT; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC __glewDisableVertexArrayAttribEXT; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXARRAYEXTPROC __glewDisableVertexArrayEXT; -GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEINDEXEDEXTPROC __glewEnableClientStateIndexedEXT; -GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEIEXTPROC __glewEnableClientStateiEXT; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXARRAYATTRIBEXTPROC __glewEnableVertexArrayAttribEXT; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXARRAYEXTPROC __glewEnableVertexArrayEXT; -GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC __glewFlushMappedNamedBufferRangeEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC __glewFramebufferDrawBufferEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC __glewFramebufferDrawBuffersEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERREADBUFFEREXTPROC __glewFramebufferReadBufferEXT; -GLEW_FUN_EXPORT PFNGLGENERATEMULTITEXMIPMAPEXTPROC __glewGenerateMultiTexMipmapEXT; -GLEW_FUN_EXPORT PFNGLGENERATETEXTUREMIPMAPEXTPROC __glewGenerateTextureMipmapEXT; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC __glewGetCompressedMultiTexImageEXT; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC __glewGetCompressedTextureImageEXT; -GLEW_FUN_EXPORT PFNGLGETDOUBLEINDEXEDVEXTPROC __glewGetDoubleIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETDOUBLEI_VEXTPROC __glewGetDoublei_vEXT; -GLEW_FUN_EXPORT PFNGLGETFLOATINDEXEDVEXTPROC __glewGetFloatIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETFLOATI_VEXTPROC __glewGetFloati_vEXT; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC __glewGetFramebufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXENVFVEXTPROC __glewGetMultiTexEnvfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXENVIVEXTPROC __glewGetMultiTexEnvivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXGENDVEXTPROC __glewGetMultiTexGendvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXGENFVEXTPROC __glewGetMultiTexGenfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXGENIVEXTPROC __glewGetMultiTexGenivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXIMAGEEXTPROC __glewGetMultiTexImageEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC __glewGetMultiTexLevelParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC __glewGetMultiTexLevelParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIIVEXTPROC __glewGetMultiTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIUIVEXTPROC __glewGetMultiTexParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERFVEXTPROC __glewGetMultiTexParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIVEXTPROC __glewGetMultiTexParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC __glewGetNamedBufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPOINTERVEXTPROC __glewGetNamedBufferPointervEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERSUBDATAEXTPROC __glewGetNamedBufferSubDataEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetNamedFramebufferAttachmentParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC __glewGetNamedProgramLocalParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC __glewGetNamedProgramLocalParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC __glewGetNamedProgramLocalParameterdvEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC __glewGetNamedProgramLocalParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMSTRINGEXTPROC __glewGetNamedProgramStringEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMIVEXTPROC __glewGetNamedProgramivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC __glewGetNamedRenderbufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETPOINTERINDEXEDVEXTPROC __glewGetPointerIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETPOINTERI_VEXTPROC __glewGetPointeri_vEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREIMAGEEXTPROC __glewGetTextureImageEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC __glewGetTextureLevelParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC __glewGetTextureLevelParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIIVEXTPROC __glewGetTextureParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIUIVEXTPROC __glewGetTextureParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERFVEXTPROC __glewGetTextureParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIVEXTPROC __glewGetTextureParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC __glewGetVertexArrayIntegeri_vEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYINTEGERVEXTPROC __glewGetVertexArrayIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC __glewGetVertexArrayPointeri_vEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYPOINTERVEXTPROC __glewGetVertexArrayPointervEXT; -GLEW_FUN_EXPORT PFNGLMAPNAMEDBUFFEREXTPROC __glewMapNamedBufferEXT; -GLEW_FUN_EXPORT PFNGLMAPNAMEDBUFFERRANGEEXTPROC __glewMapNamedBufferRangeEXT; -GLEW_FUN_EXPORT PFNGLMATRIXFRUSTUMEXTPROC __glewMatrixFrustumEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADIDENTITYEXTPROC __glewMatrixLoadIdentityEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADTRANSPOSEDEXTPROC __glewMatrixLoadTransposedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADTRANSPOSEFEXTPROC __glewMatrixLoadTransposefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADDEXTPROC __glewMatrixLoaddEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADFEXTPROC __glewMatrixLoadfEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTTRANSPOSEDEXTPROC __glewMatrixMultTransposedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTTRANSPOSEFEXTPROC __glewMatrixMultTransposefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTDEXTPROC __glewMatrixMultdEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTFEXTPROC __glewMatrixMultfEXT; -GLEW_FUN_EXPORT PFNGLMATRIXORTHOEXTPROC __glewMatrixOrthoEXT; -GLEW_FUN_EXPORT PFNGLMATRIXPOPEXTPROC __glewMatrixPopEXT; -GLEW_FUN_EXPORT PFNGLMATRIXPUSHEXTPROC __glewMatrixPushEXT; -GLEW_FUN_EXPORT PFNGLMATRIXROTATEDEXTPROC __glewMatrixRotatedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXROTATEFEXTPROC __glewMatrixRotatefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXSCALEDEXTPROC __glewMatrixScaledEXT; -GLEW_FUN_EXPORT PFNGLMATRIXSCALEFEXTPROC __glewMatrixScalefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXTRANSLATEDEXTPROC __glewMatrixTranslatedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXTRANSLATEFEXTPROC __glewMatrixTranslatefEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXBUFFEREXTPROC __glewMultiTexBufferEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDPOINTEREXTPROC __glewMultiTexCoordPointerEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVFEXTPROC __glewMultiTexEnvfEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVFVEXTPROC __glewMultiTexEnvfvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVIEXTPROC __glewMultiTexEnviEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVIVEXTPROC __glewMultiTexEnvivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENDEXTPROC __glewMultiTexGendEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENDVEXTPROC __glewMultiTexGendvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENFEXTPROC __glewMultiTexGenfEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENFVEXTPROC __glewMultiTexGenfvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENIEXTPROC __glewMultiTexGeniEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENIVEXTPROC __glewMultiTexGenivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE1DEXTPROC __glewMultiTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE2DEXTPROC __glewMultiTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE3DEXTPROC __glewMultiTexImage3DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIIVEXTPROC __glewMultiTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIUIVEXTPROC __glewMultiTexParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERFEXTPROC __glewMultiTexParameterfEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERFVEXTPROC __glewMultiTexParameterfvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIEXTPROC __glewMultiTexParameteriEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIVEXTPROC __glewMultiTexParameterivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXRENDERBUFFEREXTPROC __glewMultiTexRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE1DEXTPROC __glewMultiTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE2DEXTPROC __glewMultiTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE3DEXTPROC __glewMultiTexSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDBUFFERDATAEXTPROC __glewNamedBufferDataEXT; -GLEW_FUN_EXPORT PFNGLNAMEDBUFFERSUBDATAEXTPROC __glewNamedBufferSubDataEXT; -GLEW_FUN_EXPORT PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC __glewNamedCopyBufferSubDataEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC __glewNamedFramebufferRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC __glewNamedFramebufferTexture1DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC __glewNamedFramebufferTexture2DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC __glewNamedFramebufferTexture3DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC __glewNamedFramebufferTextureEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC __glewNamedFramebufferTextureFaceEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC __glewNamedFramebufferTextureLayerEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC __glewNamedProgramLocalParameter4dEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC __glewNamedProgramLocalParameter4dvEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC __glewNamedProgramLocalParameter4fEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC __glewNamedProgramLocalParameter4fvEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC __glewNamedProgramLocalParameterI4iEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC __glewNamedProgramLocalParameterI4ivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC __glewNamedProgramLocalParameterI4uiEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC __glewNamedProgramLocalParameterI4uivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC __glewNamedProgramLocalParameters4fvEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC __glewNamedProgramLocalParametersI4ivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC __glewNamedProgramLocalParametersI4uivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMSTRINGEXTPROC __glewNamedProgramStringEXT; -GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC __glewNamedRenderbufferStorageEXT; -GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC __glewNamedRenderbufferStorageMultisampleCoverageEXT; -GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewNamedRenderbufferStorageMultisampleEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FEXTPROC __glewProgramUniform1fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FVEXTPROC __glewProgramUniform1fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IEXTPROC __glewProgramUniform1iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IVEXTPROC __glewProgramUniform1ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIEXTPROC __glewProgramUniform1uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIVEXTPROC __glewProgramUniform1uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FEXTPROC __glewProgramUniform2fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FVEXTPROC __glewProgramUniform2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IEXTPROC __glewProgramUniform2iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IVEXTPROC __glewProgramUniform2ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIEXTPROC __glewProgramUniform2uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIVEXTPROC __glewProgramUniform2uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FEXTPROC __glewProgramUniform3fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FVEXTPROC __glewProgramUniform3fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IEXTPROC __glewProgramUniform3iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IVEXTPROC __glewProgramUniform3ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIEXTPROC __glewProgramUniform3uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIVEXTPROC __glewProgramUniform3uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FEXTPROC __glewProgramUniform4fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FVEXTPROC __glewProgramUniform4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IEXTPROC __glewProgramUniform4iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IVEXTPROC __glewProgramUniform4ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIEXTPROC __glewProgramUniform4uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIVEXTPROC __glewProgramUniform4uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC __glewProgramUniformMatrix2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC __glewProgramUniformMatrix2x3fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC __glewProgramUniformMatrix2x4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC __glewProgramUniformMatrix3fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC __glewProgramUniformMatrix3x2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC __glewProgramUniformMatrix3x4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC __glewProgramUniformMatrix4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC __glewProgramUniformMatrix4x2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC __glewProgramUniformMatrix4x3fvEXT; -GLEW_FUN_EXPORT PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC __glewPushClientAttribDefaultEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREBUFFEREXTPROC __glewTextureBufferEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE1DEXTPROC __glewTextureImage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DEXTPROC __glewTextureImage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DEXTPROC __glewTextureImage3DEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIIVEXTPROC __glewTextureParameterIivEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIUIVEXTPROC __glewTextureParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERFEXTPROC __glewTextureParameterfEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERFVEXTPROC __glewTextureParameterfvEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIEXTPROC __glewTextureParameteriEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIVEXTPROC __glewTextureParameterivEXT; -GLEW_FUN_EXPORT PFNGLTEXTURERENDERBUFFEREXTPROC __glewTextureRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE1DEXTPROC __glewTextureSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE2DEXTPROC __glewTextureSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE3DEXTPROC __glewTextureSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLUNMAPNAMEDBUFFEREXTPROC __glewUnmapNamedBufferEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYCOLOROFFSETEXTPROC __glewVertexArrayColorOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC __glewVertexArrayEdgeFlagOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC __glewVertexArrayFogCoordOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYINDEXOFFSETEXTPROC __glewVertexArrayIndexOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC __glewVertexArrayMultiTexCoordOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYNORMALOFFSETEXTPROC __glewVertexArrayNormalOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC __glewVertexArraySecondaryColorOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC __glewVertexArrayTexCoordOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC __glewVertexArrayVertexAttribIOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC __glewVertexArrayVertexAttribOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC __glewVertexArrayVertexOffsetEXT; - -GLEW_FUN_EXPORT PFNGLCOLORMASKINDEXEDEXTPROC __glewColorMaskIndexedEXT; -GLEW_FUN_EXPORT PFNGLDISABLEINDEXEDEXTPROC __glewDisableIndexedEXT; -GLEW_FUN_EXPORT PFNGLENABLEINDEXEDEXTPROC __glewEnableIndexedEXT; -GLEW_FUN_EXPORT PFNGLGETBOOLEANINDEXEDVEXTPROC __glewGetBooleanIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETINTEGERINDEXEDVEXTPROC __glewGetIntegerIndexedvEXT; -GLEW_FUN_EXPORT PFNGLISENABLEDINDEXEDEXTPROC __glewIsEnabledIndexedEXT; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDEXTPROC __glewDrawArraysInstancedEXT; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDEXTPROC __glewDrawElementsInstancedEXT; - -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSEXTPROC __glewDrawRangeElementsEXT; - -GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTEREXTPROC __glewFogCoordPointerEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDDEXTPROC __glewFogCoorddEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDDVEXTPROC __glewFogCoorddvEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDFEXTPROC __glewFogCoordfEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDFVEXTPROC __glewFogCoordfvEXT; - -GLEW_FUN_EXPORT PFNGLFRAGMENTCOLORMATERIALEXTPROC __glewFragmentColorMaterialEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFEXTPROC __glewFragmentLightModelfEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFVEXTPROC __glewFragmentLightModelfvEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIEXTPROC __glewFragmentLightModeliEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIVEXTPROC __glewFragmentLightModelivEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFEXTPROC __glewFragmentLightfEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFVEXTPROC __glewFragmentLightfvEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIEXTPROC __glewFragmentLightiEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIVEXTPROC __glewFragmentLightivEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFEXTPROC __glewFragmentMaterialfEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFVEXTPROC __glewFragmentMaterialfvEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIEXTPROC __glewFragmentMaterialiEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIVEXTPROC __glewFragmentMaterialivEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTFVEXTPROC __glewGetFragmentLightfvEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTIVEXTPROC __glewGetFragmentLightivEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALFVEXTPROC __glewGetFragmentMaterialfvEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALIVEXTPROC __glewGetFragmentMaterialivEXT; -GLEW_FUN_EXPORT PFNGLLIGHTENVIEXTPROC __glewLightEnviEXT; - -GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFEREXTPROC __glewBlitFramebufferEXT; - -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewRenderbufferStorageMultisampleEXT; - -GLEW_FUN_EXPORT PFNGLBINDFRAMEBUFFEREXTPROC __glewBindFramebufferEXT; -GLEW_FUN_EXPORT PFNGLBINDRENDERBUFFEREXTPROC __glewBindRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC __glewCheckFramebufferStatusEXT; -GLEW_FUN_EXPORT PFNGLDELETEFRAMEBUFFERSEXTPROC __glewDeleteFramebuffersEXT; -GLEW_FUN_EXPORT PFNGLDELETERENDERBUFFERSEXTPROC __glewDeleteRenderbuffersEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC __glewFramebufferRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE1DEXTPROC __glewFramebufferTexture1DEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE2DEXTPROC __glewFramebufferTexture2DEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE3DEXTPROC __glewFramebufferTexture3DEXT; -GLEW_FUN_EXPORT PFNGLGENFRAMEBUFFERSEXTPROC __glewGenFramebuffersEXT; -GLEW_FUN_EXPORT PFNGLGENRENDERBUFFERSEXTPROC __glewGenRenderbuffersEXT; -GLEW_FUN_EXPORT PFNGLGENERATEMIPMAPEXTPROC __glewGenerateMipmapEXT; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetFramebufferAttachmentParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC __glewGetRenderbufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLISFRAMEBUFFEREXTPROC __glewIsFramebufferEXT; -GLEW_FUN_EXPORT PFNGLISRENDERBUFFEREXTPROC __glewIsRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEEXTPROC __glewRenderbufferStorageEXT; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREEXTPROC __glewFramebufferTextureEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC __glewFramebufferTextureFaceEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIEXTPROC __glewProgramParameteriEXT; - -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERS4FVEXTPROC __glewProgramEnvParameters4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC __glewProgramLocalParameters4fvEXT; - -GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONEXTPROC __glewBindFragDataLocationEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGDATALOCATIONEXTPROC __glewGetFragDataLocationEXT; -GLEW_FUN_EXPORT PFNGLGETUNIFORMUIVEXTPROC __glewGetUniformuivEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIIVEXTPROC __glewGetVertexAttribIivEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIUIVEXTPROC __glewGetVertexAttribIuivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIEXTPROC __glewUniform1uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIVEXTPROC __glewUniform1uivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIEXTPROC __glewUniform2uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIVEXTPROC __glewUniform2uivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIEXTPROC __glewUniform3uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIVEXTPROC __glewUniform3uivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIEXTPROC __glewUniform4uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIVEXTPROC __glewUniform4uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IEXTPROC __glewVertexAttribI1iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IVEXTPROC __glewVertexAttribI1ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIEXTPROC __glewVertexAttribI1uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIVEXTPROC __glewVertexAttribI1uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IEXTPROC __glewVertexAttribI2iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IVEXTPROC __glewVertexAttribI2ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIEXTPROC __glewVertexAttribI2uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIVEXTPROC __glewVertexAttribI2uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IEXTPROC __glewVertexAttribI3iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IVEXTPROC __glewVertexAttribI3ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIEXTPROC __glewVertexAttribI3uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIVEXTPROC __glewVertexAttribI3uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4BVEXTPROC __glewVertexAttribI4bvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IEXTPROC __glewVertexAttribI4iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IVEXTPROC __glewVertexAttribI4ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4SVEXTPROC __glewVertexAttribI4svEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UBVEXTPROC __glewVertexAttribI4ubvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIEXTPROC __glewVertexAttribI4uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIVEXTPROC __glewVertexAttribI4uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4USVEXTPROC __glewVertexAttribI4usvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIPOINTEREXTPROC __glewVertexAttribIPointerEXT; - -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMEXTPROC __glewGetHistogramEXT; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERFVEXTPROC __glewGetHistogramParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERIVEXTPROC __glewGetHistogramParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETMINMAXEXTPROC __glewGetMinmaxEXT; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERFVEXTPROC __glewGetMinmaxParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERIVEXTPROC __glewGetMinmaxParameterivEXT; -GLEW_FUN_EXPORT PFNGLHISTOGRAMEXTPROC __glewHistogramEXT; -GLEW_FUN_EXPORT PFNGLMINMAXEXTPROC __glewMinmaxEXT; -GLEW_FUN_EXPORT PFNGLRESETHISTOGRAMEXTPROC __glewResetHistogramEXT; -GLEW_FUN_EXPORT PFNGLRESETMINMAXEXTPROC __glewResetMinmaxEXT; - -GLEW_FUN_EXPORT PFNGLINDEXFUNCEXTPROC __glewIndexFuncEXT; - -GLEW_FUN_EXPORT PFNGLINDEXMATERIALEXTPROC __glewIndexMaterialEXT; - -GLEW_FUN_EXPORT PFNGLAPPLYTEXTUREEXTPROC __glewApplyTextureEXT; -GLEW_FUN_EXPORT PFNGLTEXTURELIGHTEXTPROC __glewTextureLightEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREMATERIALEXTPROC __glewTextureMaterialEXT; - -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSEXTPROC __glewMultiDrawArraysEXT; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSEXTPROC __glewMultiDrawElementsEXT; - -GLEW_FUN_EXPORT PFNGLSAMPLEMASKEXTPROC __glewSampleMaskEXT; -GLEW_FUN_EXPORT PFNGLSAMPLEPATTERNEXTPROC __glewSamplePatternEXT; - -GLEW_FUN_EXPORT PFNGLCOLORTABLEEXTPROC __glewColorTableEXT; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEEXTPROC __glewGetColorTableEXT; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVEXTPROC __glewGetColorTableParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVEXTPROC __glewGetColorTableParameterivEXT; - -GLEW_FUN_EXPORT PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC __glewGetPixelTransformParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC __glewGetPixelTransformParameterivEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERFEXTPROC __glewPixelTransformParameterfEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC __glewPixelTransformParameterfvEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERIEXTPROC __glewPixelTransformParameteriEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC __glewPixelTransformParameterivEXT; - -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFEXTPROC __glewPointParameterfEXT; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVEXTPROC __glewPointParameterfvEXT; - -GLEW_FUN_EXPORT PFNGLPOLYGONOFFSETEXTPROC __glewPolygonOffsetEXT; - -GLEW_FUN_EXPORT PFNGLPROVOKINGVERTEXEXTPROC __glewProvokingVertexEXT; - -GLEW_FUN_EXPORT PFNGLBEGINSCENEEXTPROC __glewBeginSceneEXT; -GLEW_FUN_EXPORT PFNGLENDSCENEEXTPROC __glewEndSceneEXT; - -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BEXTPROC __glewSecondaryColor3bEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BVEXTPROC __glewSecondaryColor3bvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DEXTPROC __glewSecondaryColor3dEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DVEXTPROC __glewSecondaryColor3dvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FEXTPROC __glewSecondaryColor3fEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FVEXTPROC __glewSecondaryColor3fvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IEXTPROC __glewSecondaryColor3iEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IVEXTPROC __glewSecondaryColor3ivEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SEXTPROC __glewSecondaryColor3sEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SVEXTPROC __glewSecondaryColor3svEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBEXTPROC __glewSecondaryColor3ubEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBVEXTPROC __glewSecondaryColor3ubvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIEXTPROC __glewSecondaryColor3uiEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIVEXTPROC __glewSecondaryColor3uivEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USEXTPROC __glewSecondaryColor3usEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USVEXTPROC __glewSecondaryColor3usvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTEREXTPROC __glewSecondaryColorPointerEXT; - -GLEW_FUN_EXPORT PFNGLACTIVEPROGRAMEXTPROC __glewActiveProgramEXT; -GLEW_FUN_EXPORT PFNGLCREATESHADERPROGRAMEXTPROC __glewCreateShaderProgramEXT; -GLEW_FUN_EXPORT PFNGLUSESHADERPROGRAMEXTPROC __glewUseShaderProgramEXT; - -GLEW_FUN_EXPORT PFNGLBINDIMAGETEXTUREEXTPROC __glewBindImageTextureEXT; -GLEW_FUN_EXPORT PFNGLMEMORYBARRIEREXTPROC __glewMemoryBarrierEXT; - -GLEW_FUN_EXPORT PFNGLACTIVESTENCILFACEEXTPROC __glewActiveStencilFaceEXT; - -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE1DEXTPROC __glewTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE2DEXTPROC __glewTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE3DEXTPROC __glewTexSubImage3DEXT; - -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DEXTPROC __glewTexImage3DEXT; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC __glewFramebufferTextureLayerEXT; - -GLEW_FUN_EXPORT PFNGLTEXBUFFEREXTPROC __glewTexBufferEXT; - -GLEW_FUN_EXPORT PFNGLCLEARCOLORIIEXTPROC __glewClearColorIiEXT; -GLEW_FUN_EXPORT PFNGLCLEARCOLORIUIEXTPROC __glewClearColorIuiEXT; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIIVEXTPROC __glewGetTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIUIVEXTPROC __glewGetTexParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIIVEXTPROC __glewTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIUIVEXTPROC __glewTexParameterIuivEXT; - -GLEW_FUN_EXPORT PFNGLARETEXTURESRESIDENTEXTPROC __glewAreTexturesResidentEXT; -GLEW_FUN_EXPORT PFNGLBINDTEXTUREEXTPROC __glewBindTextureEXT; -GLEW_FUN_EXPORT PFNGLDELETETEXTURESEXTPROC __glewDeleteTexturesEXT; -GLEW_FUN_EXPORT PFNGLGENTEXTURESEXTPROC __glewGenTexturesEXT; -GLEW_FUN_EXPORT PFNGLISTEXTUREEXTPROC __glewIsTextureEXT; -GLEW_FUN_EXPORT PFNGLPRIORITIZETEXTURESEXTPROC __glewPrioritizeTexturesEXT; - -GLEW_FUN_EXPORT PFNGLTEXTURENORMALEXTPROC __glewTextureNormalEXT; - -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VEXTPROC __glewGetQueryObjecti64vEXT; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VEXTPROC __glewGetQueryObjectui64vEXT; - -GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKEXTPROC __glewBeginTransformFeedbackEXT; -GLEW_FUN_EXPORT PFNGLBINDBUFFERBASEEXTPROC __glewBindBufferBaseEXT; -GLEW_FUN_EXPORT PFNGLBINDBUFFEROFFSETEXTPROC __glewBindBufferOffsetEXT; -GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGEEXTPROC __glewBindBufferRangeEXT; -GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKEXTPROC __glewEndTransformFeedbackEXT; -GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC __glewGetTransformFeedbackVaryingEXT; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC __glewTransformFeedbackVaryingsEXT; - -GLEW_FUN_EXPORT PFNGLARRAYELEMENTEXTPROC __glewArrayElementEXT; -GLEW_FUN_EXPORT PFNGLCOLORPOINTEREXTPROC __glewColorPointerEXT; -GLEW_FUN_EXPORT PFNGLDRAWARRAYSEXTPROC __glewDrawArraysEXT; -GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTEREXTPROC __glewEdgeFlagPointerEXT; -GLEW_FUN_EXPORT PFNGLINDEXPOINTEREXTPROC __glewIndexPointerEXT; -GLEW_FUN_EXPORT PFNGLNORMALPOINTEREXTPROC __glewNormalPointerEXT; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTEREXTPROC __glewTexCoordPointerEXT; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTEREXTPROC __glewVertexPointerEXT; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLDVEXTPROC __glewGetVertexAttribLdvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC __glewVertexArrayVertexAttribLOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DEXTPROC __glewVertexAttribL1dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DVEXTPROC __glewVertexAttribL1dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DEXTPROC __glewVertexAttribL2dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DVEXTPROC __glewVertexAttribL2dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DEXTPROC __glewVertexAttribL3dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DVEXTPROC __glewVertexAttribL3dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DEXTPROC __glewVertexAttribL4dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DVEXTPROC __glewVertexAttribL4dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLPOINTEREXTPROC __glewVertexAttribLPointerEXT; - -GLEW_FUN_EXPORT PFNGLBEGINVERTEXSHADEREXTPROC __glewBeginVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLBINDLIGHTPARAMETEREXTPROC __glewBindLightParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDMATERIALPARAMETEREXTPROC __glewBindMaterialParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDPARAMETEREXTPROC __glewBindParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDTEXGENPARAMETEREXTPROC __glewBindTexGenParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDTEXTUREUNITPARAMETEREXTPROC __glewBindTextureUnitParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDVERTEXSHADEREXTPROC __glewBindVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLDELETEVERTEXSHADEREXTPROC __glewDeleteVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC __glewDisableVariantClientStateEXT; -GLEW_FUN_EXPORT PFNGLENABLEVARIANTCLIENTSTATEEXTPROC __glewEnableVariantClientStateEXT; -GLEW_FUN_EXPORT PFNGLENDVERTEXSHADEREXTPROC __glewEndVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLEXTRACTCOMPONENTEXTPROC __glewExtractComponentEXT; -GLEW_FUN_EXPORT PFNGLGENSYMBOLSEXTPROC __glewGenSymbolsEXT; -GLEW_FUN_EXPORT PFNGLGENVERTEXSHADERSEXTPROC __glewGenVertexShadersEXT; -GLEW_FUN_EXPORT PFNGLGETINVARIANTBOOLEANVEXTPROC __glewGetInvariantBooleanvEXT; -GLEW_FUN_EXPORT PFNGLGETINVARIANTFLOATVEXTPROC __glewGetInvariantFloatvEXT; -GLEW_FUN_EXPORT PFNGLGETINVARIANTINTEGERVEXTPROC __glewGetInvariantIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC __glewGetLocalConstantBooleanvEXT; -GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTFLOATVEXTPROC __glewGetLocalConstantFloatvEXT; -GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTINTEGERVEXTPROC __glewGetLocalConstantIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTBOOLEANVEXTPROC __glewGetVariantBooleanvEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTFLOATVEXTPROC __glewGetVariantFloatvEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTINTEGERVEXTPROC __glewGetVariantIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTPOINTERVEXTPROC __glewGetVariantPointervEXT; -GLEW_FUN_EXPORT PFNGLINSERTCOMPONENTEXTPROC __glewInsertComponentEXT; -GLEW_FUN_EXPORT PFNGLISVARIANTENABLEDEXTPROC __glewIsVariantEnabledEXT; -GLEW_FUN_EXPORT PFNGLSETINVARIANTEXTPROC __glewSetInvariantEXT; -GLEW_FUN_EXPORT PFNGLSETLOCALCONSTANTEXTPROC __glewSetLocalConstantEXT; -GLEW_FUN_EXPORT PFNGLSHADEROP1EXTPROC __glewShaderOp1EXT; -GLEW_FUN_EXPORT PFNGLSHADEROP2EXTPROC __glewShaderOp2EXT; -GLEW_FUN_EXPORT PFNGLSHADEROP3EXTPROC __glewShaderOp3EXT; -GLEW_FUN_EXPORT PFNGLSWIZZLEEXTPROC __glewSwizzleEXT; -GLEW_FUN_EXPORT PFNGLVARIANTPOINTEREXTPROC __glewVariantPointerEXT; -GLEW_FUN_EXPORT PFNGLVARIANTBVEXTPROC __glewVariantbvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTDVEXTPROC __glewVariantdvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTFVEXTPROC __glewVariantfvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTIVEXTPROC __glewVariantivEXT; -GLEW_FUN_EXPORT PFNGLVARIANTSVEXTPROC __glewVariantsvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTUBVEXTPROC __glewVariantubvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTUIVEXTPROC __glewVariantuivEXT; -GLEW_FUN_EXPORT PFNGLVARIANTUSVEXTPROC __glewVariantusvEXT; -GLEW_FUN_EXPORT PFNGLWRITEMASKEXTPROC __glewWriteMaskEXT; - -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTPOINTEREXTPROC __glewVertexWeightPointerEXT; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTFEXTPROC __glewVertexWeightfEXT; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTFVEXTPROC __glewVertexWeightfvEXT; - -GLEW_FUN_EXPORT PFNGLIMPORTSYNCEXTPROC __glewImportSyncEXT; - -GLEW_FUN_EXPORT PFNGLFRAMETERMINATORGREMEDYPROC __glewFrameTerminatorGREMEDY; - -GLEW_FUN_EXPORT PFNGLSTRINGMARKERGREMEDYPROC __glewStringMarkerGREMEDY; - -GLEW_FUN_EXPORT PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC __glewGetImageTransformParameterfvHP; -GLEW_FUN_EXPORT PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC __glewGetImageTransformParameterivHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERFHPPROC __glewImageTransformParameterfHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERFVHPPROC __glewImageTransformParameterfvHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERIHPPROC __glewImageTransformParameteriHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERIVHPPROC __glewImageTransformParameterivHP; - -GLEW_FUN_EXPORT PFNGLMULTIMODEDRAWARRAYSIBMPROC __glewMultiModeDrawArraysIBM; -GLEW_FUN_EXPORT PFNGLMULTIMODEDRAWELEMENTSIBMPROC __glewMultiModeDrawElementsIBM; - -GLEW_FUN_EXPORT PFNGLCOLORPOINTERLISTIBMPROC __glewColorPointerListIBM; -GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTERLISTIBMPROC __glewEdgeFlagPointerListIBM; -GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTERLISTIBMPROC __glewFogCoordPointerListIBM; -GLEW_FUN_EXPORT PFNGLINDEXPOINTERLISTIBMPROC __glewIndexPointerListIBM; -GLEW_FUN_EXPORT PFNGLNORMALPOINTERLISTIBMPROC __glewNormalPointerListIBM; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTERLISTIBMPROC __glewSecondaryColorPointerListIBM; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERLISTIBMPROC __glewTexCoordPointerListIBM; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTERLISTIBMPROC __glewVertexPointerListIBM; - -GLEW_FUN_EXPORT PFNGLCOLORPOINTERVINTELPROC __glewColorPointervINTEL; -GLEW_FUN_EXPORT PFNGLNORMALPOINTERVINTELPROC __glewNormalPointervINTEL; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERVINTELPROC __glewTexCoordPointervINTEL; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTERVINTELPROC __glewVertexPointervINTEL; - -GLEW_FUN_EXPORT PFNGLTEXSCISSORFUNCINTELPROC __glewTexScissorFuncINTEL; -GLEW_FUN_EXPORT PFNGLTEXSCISSORINTELPROC __glewTexScissorINTEL; - -GLEW_FUN_EXPORT PFNGLBUFFERREGIONENABLEDEXTPROC __glewBufferRegionEnabledEXT; -GLEW_FUN_EXPORT PFNGLDELETEBUFFERREGIONEXTPROC __glewDeleteBufferRegionEXT; -GLEW_FUN_EXPORT PFNGLDRAWBUFFERREGIONEXTPROC __glewDrawBufferRegionEXT; -GLEW_FUN_EXPORT PFNGLNEWBUFFERREGIONEXTPROC __glewNewBufferRegionEXT; -GLEW_FUN_EXPORT PFNGLREADBUFFERREGIONEXTPROC __glewReadBufferRegionEXT; - -GLEW_FUN_EXPORT PFNGLRESIZEBUFFERSMESAPROC __glewResizeBuffersMESA; - -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DMESAPROC __glewWindowPos2dMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVMESAPROC __glewWindowPos2dvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FMESAPROC __glewWindowPos2fMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVMESAPROC __glewWindowPos2fvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IMESAPROC __glewWindowPos2iMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVMESAPROC __glewWindowPos2ivMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SMESAPROC __glewWindowPos2sMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVMESAPROC __glewWindowPos2svMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DMESAPROC __glewWindowPos3dMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVMESAPROC __glewWindowPos3dvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FMESAPROC __glewWindowPos3fMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVMESAPROC __glewWindowPos3fvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IMESAPROC __glewWindowPos3iMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVMESAPROC __glewWindowPos3ivMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SMESAPROC __glewWindowPos3sMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVMESAPROC __glewWindowPos3svMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4DMESAPROC __glewWindowPos4dMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4DVMESAPROC __glewWindowPos4dvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4FMESAPROC __glewWindowPos4fMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4FVMESAPROC __glewWindowPos4fvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4IMESAPROC __glewWindowPos4iMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4IVMESAPROC __glewWindowPos4ivMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4SMESAPROC __glewWindowPos4sMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4SVMESAPROC __glewWindowPos4svMESA; - -GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERNVPROC __glewBeginConditionalRenderNV; -GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERNVPROC __glewEndConditionalRenderNV; - -GLEW_FUN_EXPORT PFNGLCOPYIMAGESUBDATANVPROC __glewCopyImageSubDataNV; - -GLEW_FUN_EXPORT PFNGLCLEARDEPTHDNVPROC __glewClearDepthdNV; -GLEW_FUN_EXPORT PFNGLDEPTHBOUNDSDNVPROC __glewDepthBoundsdNV; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEDNVPROC __glewDepthRangedNV; - -GLEW_FUN_EXPORT PFNGLEVALMAPSNVPROC __glewEvalMapsNV; -GLEW_FUN_EXPORT PFNGLGETMAPATTRIBPARAMETERFVNVPROC __glewGetMapAttribParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETMAPATTRIBPARAMETERIVNVPROC __glewGetMapAttribParameterivNV; -GLEW_FUN_EXPORT PFNGLGETMAPCONTROLPOINTSNVPROC __glewGetMapControlPointsNV; -GLEW_FUN_EXPORT PFNGLGETMAPPARAMETERFVNVPROC __glewGetMapParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETMAPPARAMETERIVNVPROC __glewGetMapParameterivNV; -GLEW_FUN_EXPORT PFNGLMAPCONTROLPOINTSNVPROC __glewMapControlPointsNV; -GLEW_FUN_EXPORT PFNGLMAPPARAMETERFVNVPROC __glewMapParameterfvNV; -GLEW_FUN_EXPORT PFNGLMAPPARAMETERIVNVPROC __glewMapParameterivNV; - -GLEW_FUN_EXPORT PFNGLGETMULTISAMPLEFVNVPROC __glewGetMultisamplefvNV; -GLEW_FUN_EXPORT PFNGLSAMPLEMASKINDEXEDNVPROC __glewSampleMaskIndexedNV; -GLEW_FUN_EXPORT PFNGLTEXRENDERBUFFERNVPROC __glewTexRenderbufferNV; - -GLEW_FUN_EXPORT PFNGLDELETEFENCESNVPROC __glewDeleteFencesNV; -GLEW_FUN_EXPORT PFNGLFINISHFENCENVPROC __glewFinishFenceNV; -GLEW_FUN_EXPORT PFNGLGENFENCESNVPROC __glewGenFencesNV; -GLEW_FUN_EXPORT PFNGLGETFENCEIVNVPROC __glewGetFenceivNV; -GLEW_FUN_EXPORT PFNGLISFENCENVPROC __glewIsFenceNV; -GLEW_FUN_EXPORT PFNGLSETFENCENVPROC __glewSetFenceNV; -GLEW_FUN_EXPORT PFNGLTESTFENCENVPROC __glewTestFenceNV; - -GLEW_FUN_EXPORT PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC __glewGetProgramNamedParameterdvNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC __glewGetProgramNamedParameterfvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4DNVPROC __glewProgramNamedParameter4dNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC __glewProgramNamedParameter4dvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4FNVPROC __glewProgramNamedParameter4fNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC __glewProgramNamedParameter4fvNV; - -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC __glewRenderbufferStorageMultisampleCoverageNV; - -GLEW_FUN_EXPORT PFNGLPROGRAMVERTEXLIMITNVPROC __glewProgramVertexLimitNV; - -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4INVPROC __glewProgramEnvParameterI4iNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4IVNVPROC __glewProgramEnvParameterI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4UINVPROC __glewProgramEnvParameterI4uiNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4UIVNVPROC __glewProgramEnvParameterI4uivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERSI4IVNVPROC __glewProgramEnvParametersI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC __glewProgramEnvParametersI4uivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4INVPROC __glewProgramLocalParameterI4iNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC __glewProgramLocalParameterI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4UINVPROC __glewProgramLocalParameterI4uiNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC __glewProgramLocalParameterI4uivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC __glewProgramLocalParametersI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC __glewProgramLocalParametersI4uivNV; - -GLEW_FUN_EXPORT PFNGLGETUNIFORMI64VNVPROC __glewGetUniformi64vNV; -GLEW_FUN_EXPORT PFNGLGETUNIFORMUI64VNVPROC __glewGetUniformui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1I64NVPROC __glewProgramUniform1i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1I64VNVPROC __glewProgramUniform1i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UI64NVPROC __glewProgramUniform1ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UI64VNVPROC __glewProgramUniform1ui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2I64NVPROC __glewProgramUniform2i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2I64VNVPROC __glewProgramUniform2i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UI64NVPROC __glewProgramUniform2ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UI64VNVPROC __glewProgramUniform2ui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3I64NVPROC __glewProgramUniform3i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3I64VNVPROC __glewProgramUniform3i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UI64NVPROC __glewProgramUniform3ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UI64VNVPROC __glewProgramUniform3ui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4I64NVPROC __glewProgramUniform4i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4I64VNVPROC __glewProgramUniform4i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UI64NVPROC __glewProgramUniform4ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UI64VNVPROC __glewProgramUniform4ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM1I64NVPROC __glewUniform1i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM1I64VNVPROC __glewUniform1i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM1UI64NVPROC __glewUniform1ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM1UI64VNVPROC __glewUniform1ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM2I64NVPROC __glewUniform2i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM2I64VNVPROC __glewUniform2i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM2UI64NVPROC __glewUniform2ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM2UI64VNVPROC __glewUniform2ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM3I64NVPROC __glewUniform3i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM3I64VNVPROC __glewUniform3i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM3UI64NVPROC __glewUniform3ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM3UI64VNVPROC __glewUniform3ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM4I64NVPROC __glewUniform4i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM4I64VNVPROC __glewUniform4i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM4UI64NVPROC __glewUniform4ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM4UI64VNVPROC __glewUniform4ui64vNV; - -GLEW_FUN_EXPORT PFNGLCOLOR3HNVPROC __glewColor3hNV; -GLEW_FUN_EXPORT PFNGLCOLOR3HVNVPROC __glewColor3hvNV; -GLEW_FUN_EXPORT PFNGLCOLOR4HNVPROC __glewColor4hNV; -GLEW_FUN_EXPORT PFNGLCOLOR4HVNVPROC __glewColor4hvNV; -GLEW_FUN_EXPORT PFNGLFOGCOORDHNVPROC __glewFogCoordhNV; -GLEW_FUN_EXPORT PFNGLFOGCOORDHVNVPROC __glewFogCoordhvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1HNVPROC __glewMultiTexCoord1hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1HVNVPROC __glewMultiTexCoord1hvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2HNVPROC __glewMultiTexCoord2hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2HVNVPROC __glewMultiTexCoord2hvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3HNVPROC __glewMultiTexCoord3hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3HVNVPROC __glewMultiTexCoord3hvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4HNVPROC __glewMultiTexCoord4hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4HVNVPROC __glewMultiTexCoord4hvNV; -GLEW_FUN_EXPORT PFNGLNORMAL3HNVPROC __glewNormal3hNV; -GLEW_FUN_EXPORT PFNGLNORMAL3HVNVPROC __glewNormal3hvNV; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3HNVPROC __glewSecondaryColor3hNV; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3HVNVPROC __glewSecondaryColor3hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD1HNVPROC __glewTexCoord1hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD1HVNVPROC __glewTexCoord1hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD2HNVPROC __glewTexCoord2hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD2HVNVPROC __glewTexCoord2hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD3HNVPROC __glewTexCoord3hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD3HVNVPROC __glewTexCoord3hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD4HNVPROC __glewTexCoord4hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD4HVNVPROC __glewTexCoord4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEX2HNVPROC __glewVertex2hNV; -GLEW_FUN_EXPORT PFNGLVERTEX2HVNVPROC __glewVertex2hvNV; -GLEW_FUN_EXPORT PFNGLVERTEX3HNVPROC __glewVertex3hNV; -GLEW_FUN_EXPORT PFNGLVERTEX3HVNVPROC __glewVertex3hvNV; -GLEW_FUN_EXPORT PFNGLVERTEX4HNVPROC __glewVertex4hNV; -GLEW_FUN_EXPORT PFNGLVERTEX4HVNVPROC __glewVertex4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1HNVPROC __glewVertexAttrib1hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1HVNVPROC __glewVertexAttrib1hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2HNVPROC __glewVertexAttrib2hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2HVNVPROC __glewVertexAttrib2hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3HNVPROC __glewVertexAttrib3hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3HVNVPROC __glewVertexAttrib3hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4HNVPROC __glewVertexAttrib4hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4HVNVPROC __glewVertexAttrib4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1HVNVPROC __glewVertexAttribs1hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2HVNVPROC __glewVertexAttribs2hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3HVNVPROC __glewVertexAttribs3hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4HVNVPROC __glewVertexAttribs4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTHNVPROC __glewVertexWeighthNV; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTHVNVPROC __glewVertexWeighthvNV; - -GLEW_FUN_EXPORT PFNGLBEGINOCCLUSIONQUERYNVPROC __glewBeginOcclusionQueryNV; -GLEW_FUN_EXPORT PFNGLDELETEOCCLUSIONQUERIESNVPROC __glewDeleteOcclusionQueriesNV; -GLEW_FUN_EXPORT PFNGLENDOCCLUSIONQUERYNVPROC __glewEndOcclusionQueryNV; -GLEW_FUN_EXPORT PFNGLGENOCCLUSIONQUERIESNVPROC __glewGenOcclusionQueriesNV; -GLEW_FUN_EXPORT PFNGLGETOCCLUSIONQUERYIVNVPROC __glewGetOcclusionQueryivNV; -GLEW_FUN_EXPORT PFNGLGETOCCLUSIONQUERYUIVNVPROC __glewGetOcclusionQueryuivNV; -GLEW_FUN_EXPORT PFNGLISOCCLUSIONQUERYNVPROC __glewIsOcclusionQueryNV; - -GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC __glewProgramBufferParametersIivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC __glewProgramBufferParametersIuivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC __glewProgramBufferParametersfvNV; - -GLEW_FUN_EXPORT PFNGLFLUSHPIXELDATARANGENVPROC __glewFlushPixelDataRangeNV; -GLEW_FUN_EXPORT PFNGLPIXELDATARANGENVPROC __glewPixelDataRangeNV; - -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERINVPROC __glewPointParameteriNV; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIVNVPROC __glewPointParameterivNV; - -GLEW_FUN_EXPORT PFNGLGETVIDEOI64VNVPROC __glewGetVideoi64vNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOIVNVPROC __glewGetVideoivNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOUI64VNVPROC __glewGetVideoui64vNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOUIVNVPROC __glewGetVideouivNV; -GLEW_FUN_EXPORT PFNGLPRESENTFRAMEDUALFILLNVPROC __glewPresentFrameDualFillNV; -GLEW_FUN_EXPORT PFNGLPRESENTFRAMEKEYEDNVPROC __glewPresentFrameKeyedNV; - -GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTINDEXNVPROC __glewPrimitiveRestartIndexNV; -GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTNVPROC __glewPrimitiveRestartNV; - -GLEW_FUN_EXPORT PFNGLCOMBINERINPUTNVPROC __glewCombinerInputNV; -GLEW_FUN_EXPORT PFNGLCOMBINEROUTPUTNVPROC __glewCombinerOutputNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERFNVPROC __glewCombinerParameterfNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERFVNVPROC __glewCombinerParameterfvNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERINVPROC __glewCombinerParameteriNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERIVNVPROC __glewCombinerParameterivNV; -GLEW_FUN_EXPORT PFNGLFINALCOMBINERINPUTNVPROC __glewFinalCombinerInputNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC __glewGetCombinerInputParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC __glewGetCombinerInputParameterivNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC __glewGetCombinerOutputParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC __glewGetCombinerOutputParameterivNV; -GLEW_FUN_EXPORT PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC __glewGetFinalCombinerInputParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC __glewGetFinalCombinerInputParameterivNV; - -GLEW_FUN_EXPORT PFNGLCOMBINERSTAGEPARAMETERFVNVPROC __glewCombinerStageParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC __glewGetCombinerStageParameterfvNV; - -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERUI64VNVPROC __glewGetBufferParameterui64vNV; -GLEW_FUN_EXPORT PFNGLGETINTEGERUI64VNVPROC __glewGetIntegerui64vNV; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC __glewGetNamedBufferParameterui64vNV; -GLEW_FUN_EXPORT PFNGLISBUFFERRESIDENTNVPROC __glewIsBufferResidentNV; -GLEW_FUN_EXPORT PFNGLISNAMEDBUFFERRESIDENTNVPROC __glewIsNamedBufferResidentNV; -GLEW_FUN_EXPORT PFNGLMAKEBUFFERNONRESIDENTNVPROC __glewMakeBufferNonResidentNV; -GLEW_FUN_EXPORT PFNGLMAKEBUFFERRESIDENTNVPROC __glewMakeBufferResidentNV; -GLEW_FUN_EXPORT PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC __glewMakeNamedBufferNonResidentNV; -GLEW_FUN_EXPORT PFNGLMAKENAMEDBUFFERRESIDENTNVPROC __glewMakeNamedBufferResidentNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMUI64NVPROC __glewProgramUniformui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMUI64VNVPROC __glewProgramUniformui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORMUI64NVPROC __glewUniformui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORMUI64VNVPROC __glewUniformui64vNV; - -GLEW_FUN_EXPORT PFNGLTEXTUREBARRIERNVPROC __glewTextureBarrierNV; - -GLEW_FUN_EXPORT PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC __glewTexImage2DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC __glewTexImage3DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC __glewTextureImage2DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC __glewTextureImage2DMultisampleNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC __glewTextureImage3DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC __glewTextureImage3DMultisampleNV; - -GLEW_FUN_EXPORT PFNGLACTIVEVARYINGNVPROC __glewActiveVaryingNV; -GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKNVPROC __glewBeginTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLBINDBUFFERBASENVPROC __glewBindBufferBaseNV; -GLEW_FUN_EXPORT PFNGLBINDBUFFEROFFSETNVPROC __glewBindBufferOffsetNV; -GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGENVPROC __glewBindBufferRangeNV; -GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKNVPROC __glewEndTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLGETACTIVEVARYINGNVPROC __glewGetActiveVaryingNV; -GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC __glewGetTransformFeedbackVaryingNV; -GLEW_FUN_EXPORT PFNGLGETVARYINGLOCATIONNVPROC __glewGetVaryingLocationNV; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC __glewTransformFeedbackAttribsNV; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC __glewTransformFeedbackVaryingsNV; - -GLEW_FUN_EXPORT PFNGLBINDTRANSFORMFEEDBACKNVPROC __glewBindTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLDELETETRANSFORMFEEDBACKSNVPROC __glewDeleteTransformFeedbacksNV; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKNVPROC __glewDrawTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLGENTRANSFORMFEEDBACKSNVPROC __glewGenTransformFeedbacksNV; -GLEW_FUN_EXPORT PFNGLISTRANSFORMFEEDBACKNVPROC __glewIsTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLPAUSETRANSFORMFEEDBACKNVPROC __glewPauseTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLRESUMETRANSFORMFEEDBACKNVPROC __glewResumeTransformFeedbackNV; - -GLEW_FUN_EXPORT PFNGLVDPAUFININVPROC __glewVDPAUFiniNV; -GLEW_FUN_EXPORT PFNGLVDPAUGETSURFACEIVNVPROC __glewVDPAUGetSurfaceivNV; -GLEW_FUN_EXPORT PFNGLVDPAUINITNVPROC __glewVDPAUInitNV; -GLEW_FUN_EXPORT PFNGLVDPAUISSURFACENVPROC __glewVDPAUIsSurfaceNV; -GLEW_FUN_EXPORT PFNGLVDPAUMAPSURFACESNVPROC __glewVDPAUMapSurfacesNV; -GLEW_FUN_EXPORT PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC __glewVDPAURegisterOutputSurfaceNV; -GLEW_FUN_EXPORT PFNGLVDPAUREGISTERVIDEOSURFACENVPROC __glewVDPAURegisterVideoSurfaceNV; -GLEW_FUN_EXPORT PFNGLVDPAUSURFACEACCESSNVPROC __glewVDPAUSurfaceAccessNV; -GLEW_FUN_EXPORT PFNGLVDPAUUNMAPSURFACESNVPROC __glewVDPAUUnmapSurfacesNV; -GLEW_FUN_EXPORT PFNGLVDPAUUNREGISTERSURFACENVPROC __glewVDPAUUnregisterSurfaceNV; - -GLEW_FUN_EXPORT PFNGLFLUSHVERTEXARRAYRANGENVPROC __glewFlushVertexArrayRangeNV; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYRANGENVPROC __glewVertexArrayRangeNV; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLI64VNVPROC __glewGetVertexAttribLi64vNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLUI64VNVPROC __glewGetVertexAttribLui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1I64NVPROC __glewVertexAttribL1i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1I64VNVPROC __glewVertexAttribL1i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64NVPROC __glewVertexAttribL1ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64VNVPROC __glewVertexAttribL1ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2I64NVPROC __glewVertexAttribL2i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2I64VNVPROC __glewVertexAttribL2i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2UI64NVPROC __glewVertexAttribL2ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2UI64VNVPROC __glewVertexAttribL2ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3I64NVPROC __glewVertexAttribL3i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3I64VNVPROC __glewVertexAttribL3i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3UI64NVPROC __glewVertexAttribL3ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3UI64VNVPROC __glewVertexAttribL3ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4I64NVPROC __glewVertexAttribL4i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4I64VNVPROC __glewVertexAttribL4i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4UI64NVPROC __glewVertexAttribL4ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4UI64VNVPROC __glewVertexAttribL4ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLFORMATNVPROC __glewVertexAttribLFormatNV; - -GLEW_FUN_EXPORT PFNGLBUFFERADDRESSRANGENVPROC __glewBufferAddressRangeNV; -GLEW_FUN_EXPORT PFNGLCOLORFORMATNVPROC __glewColorFormatNV; -GLEW_FUN_EXPORT PFNGLEDGEFLAGFORMATNVPROC __glewEdgeFlagFormatNV; -GLEW_FUN_EXPORT PFNGLFOGCOORDFORMATNVPROC __glewFogCoordFormatNV; -GLEW_FUN_EXPORT PFNGLGETINTEGERUI64I_VNVPROC __glewGetIntegerui64i_vNV; -GLEW_FUN_EXPORT PFNGLINDEXFORMATNVPROC __glewIndexFormatNV; -GLEW_FUN_EXPORT PFNGLNORMALFORMATNVPROC __glewNormalFormatNV; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORFORMATNVPROC __glewSecondaryColorFormatNV; -GLEW_FUN_EXPORT PFNGLTEXCOORDFORMATNVPROC __glewTexCoordFormatNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBFORMATNVPROC __glewVertexAttribFormatNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIFORMATNVPROC __glewVertexAttribIFormatNV; -GLEW_FUN_EXPORT PFNGLVERTEXFORMATNVPROC __glewVertexFormatNV; - -GLEW_FUN_EXPORT PFNGLAREPROGRAMSRESIDENTNVPROC __glewAreProgramsResidentNV; -GLEW_FUN_EXPORT PFNGLBINDPROGRAMNVPROC __glewBindProgramNV; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMSNVPROC __glewDeleteProgramsNV; -GLEW_FUN_EXPORT PFNGLEXECUTEPROGRAMNVPROC __glewExecuteProgramNV; -GLEW_FUN_EXPORT PFNGLGENPROGRAMSNVPROC __glewGenProgramsNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPARAMETERDVNVPROC __glewGetProgramParameterdvNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPARAMETERFVNVPROC __glewGetProgramParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMSTRINGNVPROC __glewGetProgramStringNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMIVNVPROC __glewGetProgramivNV; -GLEW_FUN_EXPORT PFNGLGETTRACKMATRIXIVNVPROC __glewGetTrackMatrixivNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVNVPROC __glewGetVertexAttribPointervNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVNVPROC __glewGetVertexAttribdvNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVNVPROC __glewGetVertexAttribfvNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVNVPROC __glewGetVertexAttribivNV; -GLEW_FUN_EXPORT PFNGLISPROGRAMNVPROC __glewIsProgramNV; -GLEW_FUN_EXPORT PFNGLLOADPROGRAMNVPROC __glewLoadProgramNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4DNVPROC __glewProgramParameter4dNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4DVNVPROC __glewProgramParameter4dvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4FNVPROC __glewProgramParameter4fNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4FVNVPROC __glewProgramParameter4fvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERS4DVNVPROC __glewProgramParameters4dvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERS4FVNVPROC __glewProgramParameters4fvNV; -GLEW_FUN_EXPORT PFNGLREQUESTRESIDENTPROGRAMSNVPROC __glewRequestResidentProgramsNV; -GLEW_FUN_EXPORT PFNGLTRACKMATRIXNVPROC __glewTrackMatrixNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DNVPROC __glewVertexAttrib1dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVNVPROC __glewVertexAttrib1dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FNVPROC __glewVertexAttrib1fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVNVPROC __glewVertexAttrib1fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SNVPROC __glewVertexAttrib1sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVNVPROC __glewVertexAttrib1svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DNVPROC __glewVertexAttrib2dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVNVPROC __glewVertexAttrib2dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FNVPROC __glewVertexAttrib2fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVNVPROC __glewVertexAttrib2fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SNVPROC __glewVertexAttrib2sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVNVPROC __glewVertexAttrib2svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DNVPROC __glewVertexAttrib3dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVNVPROC __glewVertexAttrib3dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FNVPROC __glewVertexAttrib3fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVNVPROC __glewVertexAttrib3fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SNVPROC __glewVertexAttrib3sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVNVPROC __glewVertexAttrib3svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DNVPROC __glewVertexAttrib4dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVNVPROC __glewVertexAttrib4dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FNVPROC __glewVertexAttrib4fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVNVPROC __glewVertexAttrib4fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SNVPROC __glewVertexAttrib4sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVNVPROC __glewVertexAttrib4svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBNVPROC __glewVertexAttrib4ubNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVNVPROC __glewVertexAttrib4ubvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERNVPROC __glewVertexAttribPointerNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1DVNVPROC __glewVertexAttribs1dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1FVNVPROC __glewVertexAttribs1fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1SVNVPROC __glewVertexAttribs1svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2DVNVPROC __glewVertexAttribs2dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2FVNVPROC __glewVertexAttribs2fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2SVNVPROC __glewVertexAttribs2svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3DVNVPROC __glewVertexAttribs3dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3FVNVPROC __glewVertexAttribs3fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3SVNVPROC __glewVertexAttribs3svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4DVNVPROC __glewVertexAttribs4dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4FVNVPROC __glewVertexAttribs4fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4SVNVPROC __glewVertexAttribs4svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4UBVNVPROC __glewVertexAttribs4ubvNV; - -GLEW_FUN_EXPORT PFNGLBEGINVIDEOCAPTURENVPROC __glewBeginVideoCaptureNV; -GLEW_FUN_EXPORT PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC __glewBindVideoCaptureStreamBufferNV; -GLEW_FUN_EXPORT PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC __glewBindVideoCaptureStreamTextureNV; -GLEW_FUN_EXPORT PFNGLENDVIDEOCAPTURENVPROC __glewEndVideoCaptureNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTURESTREAMDVNVPROC __glewGetVideoCaptureStreamdvNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTURESTREAMFVNVPROC __glewGetVideoCaptureStreamfvNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTURESTREAMIVNVPROC __glewGetVideoCaptureStreamivNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTUREIVNVPROC __glewGetVideoCaptureivNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURENVPROC __glewVideoCaptureNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC __glewVideoCaptureStreamParameterdvNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC __glewVideoCaptureStreamParameterfvNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC __glewVideoCaptureStreamParameterivNV; - -GLEW_FUN_EXPORT PFNGLCLEARDEPTHFOESPROC __glewClearDepthfOES; -GLEW_FUN_EXPORT PFNGLCLIPPLANEFOESPROC __glewClipPlanefOES; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEFOESPROC __glewDepthRangefOES; -GLEW_FUN_EXPORT PFNGLFRUSTUMFOESPROC __glewFrustumfOES; -GLEW_FUN_EXPORT PFNGLGETCLIPPLANEFOESPROC __glewGetClipPlanefOES; -GLEW_FUN_EXPORT PFNGLORTHOFOESPROC __glewOrthofOES; - -GLEW_FUN_EXPORT PFNGLDETAILTEXFUNCSGISPROC __glewDetailTexFuncSGIS; -GLEW_FUN_EXPORT PFNGLGETDETAILTEXFUNCSGISPROC __glewGetDetailTexFuncSGIS; - -GLEW_FUN_EXPORT PFNGLFOGFUNCSGISPROC __glewFogFuncSGIS; -GLEW_FUN_EXPORT PFNGLGETFOGFUNCSGISPROC __glewGetFogFuncSGIS; - -GLEW_FUN_EXPORT PFNGLSAMPLEMASKSGISPROC __glewSampleMaskSGIS; -GLEW_FUN_EXPORT PFNGLSAMPLEPATTERNSGISPROC __glewSamplePatternSGIS; - -GLEW_FUN_EXPORT PFNGLGETSHARPENTEXFUNCSGISPROC __glewGetSharpenTexFuncSGIS; -GLEW_FUN_EXPORT PFNGLSHARPENTEXFUNCSGISPROC __glewSharpenTexFuncSGIS; - -GLEW_FUN_EXPORT PFNGLTEXIMAGE4DSGISPROC __glewTexImage4DSGIS; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE4DSGISPROC __glewTexSubImage4DSGIS; - -GLEW_FUN_EXPORT PFNGLGETTEXFILTERFUNCSGISPROC __glewGetTexFilterFuncSGIS; -GLEW_FUN_EXPORT PFNGLTEXFILTERFUNCSGISPROC __glewTexFilterFuncSGIS; - -GLEW_FUN_EXPORT PFNGLASYNCMARKERSGIXPROC __glewAsyncMarkerSGIX; -GLEW_FUN_EXPORT PFNGLDELETEASYNCMARKERSSGIXPROC __glewDeleteAsyncMarkersSGIX; -GLEW_FUN_EXPORT PFNGLFINISHASYNCSGIXPROC __glewFinishAsyncSGIX; -GLEW_FUN_EXPORT PFNGLGENASYNCMARKERSSGIXPROC __glewGenAsyncMarkersSGIX; -GLEW_FUN_EXPORT PFNGLISASYNCMARKERSGIXPROC __glewIsAsyncMarkerSGIX; -GLEW_FUN_EXPORT PFNGLPOLLASYNCSGIXPROC __glewPollAsyncSGIX; - -GLEW_FUN_EXPORT PFNGLFLUSHRASTERSGIXPROC __glewFlushRasterSGIX; - -GLEW_FUN_EXPORT PFNGLTEXTUREFOGSGIXPROC __glewTextureFogSGIX; - -GLEW_FUN_EXPORT PFNGLFRAGMENTCOLORMATERIALSGIXPROC __glewFragmentColorMaterialSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFSGIXPROC __glewFragmentLightModelfSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFVSGIXPROC __glewFragmentLightModelfvSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELISGIXPROC __glewFragmentLightModeliSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIVSGIXPROC __glewFragmentLightModelivSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFSGIXPROC __glewFragmentLightfSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFVSGIXPROC __glewFragmentLightfvSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTISGIXPROC __glewFragmentLightiSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIVSGIXPROC __glewFragmentLightivSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFSGIXPROC __glewFragmentMaterialfSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFVSGIXPROC __glewFragmentMaterialfvSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALISGIXPROC __glewFragmentMaterialiSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIVSGIXPROC __glewFragmentMaterialivSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTFVSGIXPROC __glewGetFragmentLightfvSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTIVSGIXPROC __glewGetFragmentLightivSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALFVSGIXPROC __glewGetFragmentMaterialfvSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALIVSGIXPROC __glewGetFragmentMaterialivSGIX; - -GLEW_FUN_EXPORT PFNGLFRAMEZOOMSGIXPROC __glewFrameZoomSGIX; - -GLEW_FUN_EXPORT PFNGLPIXELTEXGENSGIXPROC __glewPixelTexGenSGIX; - -GLEW_FUN_EXPORT PFNGLREFERENCEPLANESGIXPROC __glewReferencePlaneSGIX; - -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERFSGIXPROC __glewSpriteParameterfSGIX; -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERFVSGIXPROC __glewSpriteParameterfvSGIX; -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERISGIXPROC __glewSpriteParameteriSGIX; -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERIVSGIXPROC __glewSpriteParameterivSGIX; - -GLEW_FUN_EXPORT PFNGLTAGSAMPLEBUFFERSGIXPROC __glewTagSampleBufferSGIX; - -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERFVSGIPROC __glewColorTableParameterfvSGI; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERIVSGIPROC __glewColorTableParameterivSGI; -GLEW_FUN_EXPORT PFNGLCOLORTABLESGIPROC __glewColorTableSGI; -GLEW_FUN_EXPORT PFNGLCOPYCOLORTABLESGIPROC __glewCopyColorTableSGI; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVSGIPROC __glewGetColorTableParameterfvSGI; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVSGIPROC __glewGetColorTableParameterivSGI; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLESGIPROC __glewGetColorTableSGI; - -GLEW_FUN_EXPORT PFNGLFINISHTEXTURESUNXPROC __glewFinishTextureSUNX; - -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORBSUNPROC __glewGlobalAlphaFactorbSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORDSUNPROC __glewGlobalAlphaFactordSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORFSUNPROC __glewGlobalAlphaFactorfSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORISUNPROC __glewGlobalAlphaFactoriSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORSSUNPROC __glewGlobalAlphaFactorsSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUBSUNPROC __glewGlobalAlphaFactorubSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUISUNPROC __glewGlobalAlphaFactoruiSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUSSUNPROC __glewGlobalAlphaFactorusSUN; - -GLEW_FUN_EXPORT PFNGLREADVIDEOPIXELSSUNPROC __glewReadVideoPixelsSUN; - -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEPOINTERSUNPROC __glewReplacementCodePointerSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUBSUNPROC __glewReplacementCodeubSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUBVSUNPROC __glewReplacementCodeubvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUISUNPROC __glewReplacementCodeuiSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVSUNPROC __glewReplacementCodeuivSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUSSUNPROC __glewReplacementCodeusSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUSVSUNPROC __glewReplacementCodeusvSUN; - -GLEW_FUN_EXPORT PFNGLCOLOR3FVERTEX3FSUNPROC __glewColor3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR3FVERTEX3FVSUNPROC __glewColor3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX2FSUNPROC __glewColor4ubVertex2fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX2FVSUNPROC __glewColor4ubVertex2fvSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX3FSUNPROC __glewColor4ubVertex3fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX3FVSUNPROC __glewColor4ubVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLNORMAL3FVERTEX3FSUNPROC __glewNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLNORMAL3FVERTEX3FVSUNPROC __glewNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC __glewReplacementCodeuiColor3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC __glewReplacementCodeuiColor4ubVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC __glewReplacementCodeuiColor4ubVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC __glewReplacementCodeuiVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC __glewReplacementCodeuiVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC __glewTexCoord2fColor3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC __glewTexCoord2fColor3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC __glewTexCoord2fColor4ubVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC __glewTexCoord2fColor4ubVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FVERTEX3FSUNPROC __glewTexCoord2fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FVERTEX3FVSUNPROC __glewTexCoord2fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FVERTEX4FSUNPROC __glewTexCoord4fVertex4fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FVERTEX4FVSUNPROC __glewTexCoord4fVertex4fvSUN; - -GLEW_FUN_EXPORT PFNGLADDSWAPHINTRECTWINPROC __glewAddSwapHintRectWIN; - -#if defined(GLEW_MX) && !defined(_WIN32) -struct GLEWContextStruct -{ -#endif /* GLEW_MX */ - -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_3; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_4; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_5; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_2_0; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_2_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_0; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_2; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_3; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_0; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_1; -GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_tbuffer; -GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_texture_compression_FXT1; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_blend_minmax_factor; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_conservative_depth; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_debug_output; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_depth_clamp_separate; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_draw_buffers_blend; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_name_gen_delete; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_performance_monitor; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_sample_positions; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_seamless_cubemap_per_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_shader_stencil_export; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_texture_texture4; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_transform_feedback3_lines_triangles; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_vertex_shader_tessellator; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_aux_depth_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_client_storage; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_element_array; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_fence; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_float_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_flush_buffer_range; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_object_purgeable; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_pixel_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_rgb_422; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_row_bytes; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_specular_vector; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_texture_range; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_transform_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_array_range; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_program_evaluators; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_ycbcr_422; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_ES2_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_blend_func_extended; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_cl_event; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_color_buffer_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_copy_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_debug_output; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_buffer_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_buffers; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_buffers_blend; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_elements_base_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_indirect; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_instanced; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_explicit_attrib_location; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_coord_conventions; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_program; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_program_shadow; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_sRGB; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_geometry_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_get_program_binary; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_gpu_shader5; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_gpu_shader_fp64; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_half_float_pixel; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_half_float_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_imaging; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_instanced_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_map_buffer_range; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_matrix_palette; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multitexture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_occlusion_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_occlusion_query2; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_pixel_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_point_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_point_sprite; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_provoking_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_robustness; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sample_shading; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sampler_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_seamless_cube_map; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_separate_shader_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_bit_encoding; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_precision; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_stencil_export; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_subroutine; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_texture_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_100; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_include; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shadow; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shadow_ambient; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sync; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_tessellation_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_border_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_object_rgb32; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression_bptc; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression_rgtc; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_cube_map; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_cube_map_array; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_add; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_combine; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_crossbar; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_dot3; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_gather; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_mirrored_repeat; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_non_power_of_two; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_query_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rectangle; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rg; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rgb10_a2ui; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_swizzle; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_timer_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback2; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback3; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transpose_matrix; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_uniform_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_array_bgra; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_attrib_64bit; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_blend; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_program; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_type_2_10_10_10_rev; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_viewport_array; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_window_pos; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_point_sprites; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_texture_env_combine3; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_texture_env_route; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_vertex_shader_output_point_size; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_draw_buffers; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_element_array; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_envmap_bumpmap; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_fragment_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_map_object_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_meminfo; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_pn_triangles; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_separate_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_shader_texture_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_text_fragment_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_compression_3dc; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_env_combine3; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_mirror_once; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_attrib_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_streams; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_422_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_Cg_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_abgr; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_bgra; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_bindable_uniform; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_color; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_equation_separate; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_func_separate; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_logic_op; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_minmax; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_subtract; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_clip_volume_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_cmyka; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_color_subtable; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_compiled_vertex_array; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_convolution; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_coordinate_frame; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_copy_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_cull_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_depth_bounds_test; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_direct_state_access; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_buffers2; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_instanced; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_range_elements; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_fog_coord; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_fragment_lighting; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_blit; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_sRGB; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_geometry_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_gpu_program_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_gpu_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_histogram; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_array_formats; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_func; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_material; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_light_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_misc_attribute; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_multi_draw_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_depth_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_float; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_paletted_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_transform; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_transform_color_table; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_point_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_polygon_offset; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_provoking_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_rescale_normal; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_scene_marker; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_secondary_color; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_separate_shader_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_separate_specular_color; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shader_image_load_store; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shadow_funcs; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shared_texture_palette; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_clear_tag; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_two_side; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_wrap; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_subtexture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture3D; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_array; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_dxt1; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_latc; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_rgtc; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_s3tc; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_cube_map; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_edge_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_add; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_combine; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_dot3; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_filter_anisotropic; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_integer; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_lod_bias; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_mirror_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_perturb_normal; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_rectangle; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_sRGB; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_sRGB_decode; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_shared_exponent; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_snorm; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_swizzle; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_timer_query; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_transform_feedback; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_array; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_array_bgra; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_attrib_64bit; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_weighting; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_x11_sync_object; -GLEW_VAR_EXPORT GLboolean __GLEW_GREMEDY_frame_terminator; -GLEW_VAR_EXPORT GLboolean __GLEW_GREMEDY_string_marker; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_convolution_border_modes; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_image_transform; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_occlusion_test; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_texture_lighting; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_cull_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_multimode_draw_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_rasterpos_clip; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_static_data; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_texture_mirrored_repeat; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_vertex_array_lists; -GLEW_VAR_EXPORT GLboolean __GLEW_INGR_color_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_INGR_interlace_read; -GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_parallel_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_texture_scissor; -GLEW_VAR_EXPORT GLboolean __GLEW_KTX_buffer_region; -GLEW_VAR_EXPORT GLboolean __GLEW_MESAX_texture_stack; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_pack_invert; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_resize_buffers; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_window_pos; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_ycbcr_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_NVX_gpu_memory_info; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_blend_square; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_conditional_render; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_copy_depth_to_color; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_copy_image; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_buffer_float; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_range_unclamped; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_evaluators; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_explicit_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fence; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_float_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fog_distance; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program_option; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_framebuffer_multisample_coverage; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_geometry_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_geometry_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program_fp64; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_shader5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_half_float; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_light_max_exponent; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_multisample_coverage; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_multisample_filter_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_occlusion_query; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_packed_depth_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_parameter_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_parameter_buffer_object2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_pixel_data_range; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_point_sprite; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_present_video; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_primitive_restart; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_register_combiners; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_register_combiners2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_shader_buffer_load; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_tessellation_program5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texgen_emboss; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texgen_reflection; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_barrier; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_compression_vtc; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_env_combine4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_expand_normal; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_rectangle; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader3; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_transform_feedback; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_transform_feedback2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vdpau_interop; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_array_range; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_array_range2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_attrib_integer_64bit; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_buffer_unified_memory; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program1_1; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program2_option; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program3; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_video_capture; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_byte_coordinates; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_compressed_paletted_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_read_format; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_single_precision; -GLEW_VAR_EXPORT GLboolean __GLEW_OML_interlace; -GLEW_VAR_EXPORT GLboolean __GLEW_OML_resample; -GLEW_VAR_EXPORT GLboolean __GLEW_OML_subsample; -GLEW_VAR_EXPORT GLboolean __GLEW_PGI_misc_hints; -GLEW_VAR_EXPORT GLboolean __GLEW_PGI_vertex_hints; -GLEW_VAR_EXPORT GLboolean __GLEW_REND_screen_coordinates; -GLEW_VAR_EXPORT GLboolean __GLEW_S3_s3tc; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_color_range; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_detail_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_fog_function; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_generate_mipmap; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_pixel_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_point_line_texgen; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_sharpen_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture4D; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_border_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_edge_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_filter4; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_select; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async_histogram; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async_pixel; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_blend_alpha_minmax; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_clipmap; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_convolution_accuracy; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_depth_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_flush_raster; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fog_offset; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fog_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fragment_specular_lighting; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_framezoom; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_interlace; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_ir_instrument1; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_list_priority; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_pixel_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_pixel_texture_bits; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_reference_plane; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_resample; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_shadow; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_shadow_ambient; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_sprite; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_tag_sample_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_add_env; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_coordinate_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_lod_bias; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_multi_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_range; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_scale_bias; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_vertex_preclip; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_vertex_preclip_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_ycrcb; -GLEW_VAR_EXPORT GLboolean __GLEW_SGI_color_matrix; -GLEW_VAR_EXPORT GLboolean __GLEW_SGI_color_table; -GLEW_VAR_EXPORT GLboolean __GLEW_SGI_texture_color_table; -GLEW_VAR_EXPORT GLboolean __GLEW_SUNX_constant_data; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_convolution_border_modes; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_global_alpha; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_mesh_array; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_read_video_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_slice_accum; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_triangle_list; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_WIN_phong_shading; -GLEW_VAR_EXPORT GLboolean __GLEW_WIN_specular_fog; -GLEW_VAR_EXPORT GLboolean __GLEW_WIN_swap_hint; - -#ifdef GLEW_MX -}; /* GLEWContextStruct */ -#endif /* GLEW_MX */ - -/* ------------------------------------------------------------------------- */ - -/* error codes */ -#define GLEW_OK 0 -#define GLEW_NO_ERROR 0 -#define GLEW_ERROR_NO_GL_VERSION 1 /* missing GL version */ -#define GLEW_ERROR_GL_VERSION_10_ONLY 2 /* Need at least OpenGL 1.1 */ -#define GLEW_ERROR_GLX_VERSION_11_ONLY 3 /* Need at least GLX 1.2 */ - -/* string codes */ -#define GLEW_VERSION 1 -#define GLEW_VERSION_MAJOR 2 -#define GLEW_VERSION_MINOR 3 -#define GLEW_VERSION_MICRO 4 - -/* API */ -#ifdef GLEW_MX - -typedef struct GLEWContextStruct GLEWContext; -GLEWAPI GLenum glewContextInit (GLEWContext* ctx); -GLEWAPI GLboolean glewContextIsSupported (const GLEWContext* ctx, const char* name); - -#define glewInit() glewContextInit(glewGetContext()) -#define glewIsSupported(x) glewContextIsSupported(glewGetContext(), x) -#define glewIsExtensionSupported(x) glewIsSupported(x) - -#define GLEW_GET_VAR(x) (*(const GLboolean*)&(glewGetContext()->x)) -#ifdef _WIN32 -# define GLEW_GET_FUN(x) glewGetContext()->x -#else -# define GLEW_GET_FUN(x) x -#endif - -#else /* GLEW_MX */ - -GLEWAPI GLenum glewInit (); -GLEWAPI GLboolean glewIsSupported (const char* name); -#define glewIsExtensionSupported(x) glewIsSupported(x) - -#define GLEW_GET_VAR(x) (*(const GLboolean*)&x) -#define GLEW_GET_FUN(x) x - -#endif /* GLEW_MX */ - -GLEWAPI GLboolean glewExperimental; -GLEWAPI GLboolean glewGetExtension (const char* name); -GLEWAPI const GLubyte* glewGetErrorString (GLenum error); -GLEWAPI const GLubyte* glewGetString (GLenum name); - -#ifdef __cplusplus -} -#endif - -#ifdef GLEW_APIENTRY_DEFINED -#undef GLEW_APIENTRY_DEFINED -#undef APIENTRY -#undef GLAPIENTRY -#define GLAPIENTRY -#endif - -#ifdef GLEW_CALLBACK_DEFINED -#undef GLEW_CALLBACK_DEFINED -#undef CALLBACK -#endif - -#ifdef GLEW_WINGDIAPI_DEFINED -#undef GLEW_WINGDIAPI_DEFINED -#undef WINGDIAPI -#endif - -#undef GLAPI -/* #undef GLEWAPI */ - -#endif /* __glew_h__ */ diff --git a/Demos/Glut/GL/glext.h b/Demos/Glut/GL/glext.h deleted file mode 100644 index 10c2bc0f8..000000000 --- a/Demos/Glut/GL/glext.h +++ /dev/null @@ -1,3326 +0,0 @@ -#ifndef __glext_h_ -#define __glext_h_ - -#ifdef __cplusplus -extern "C" { -#endif - -/* -** Copyright 1998, 1999, 2000, 2001, NVIDIA Corporation. -** All rights Reserved. -** -** THE INFORMATION CONTAINED HEREIN IS PROPRIETARY AND CONFIDENTIAL TO -** NVIDIA, CORPORATION. USE, REPRODUCTION OR DISCLOSURE TO ANY THIRD PARTY -** IS SUBJECT TO WRITTEN PRE-APPROVAL BY NVIDIA, CORPORATION. -*/ - -/* -** License Applicability. Except to the extent portions of this file are -** made subject to an alternative license as permitted in the SGI Free -** Software License B, Version 1.1 (the "License"), the contents of this -** file are subject only to the provisions of the License. You may not use -** this file except in compliance with the License. You may obtain a copy -** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600 -** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at: -** -** http://oss.sgi.com/projects/FreeB -** -** Note that, as provided in the License, the Software is distributed on an -** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS -** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND -** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A -** PARTICULAR PURPOSE, AND NON-INFRINGEMENT. -** -** Original Code. The Original Code is: OpenGL Sample Implementation, -** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics, -** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc. -** Copyright in any portions created by third parties is as indicated -** elsewhere herein. All Rights Reserved. -** -** Additional Notice Provisions: This software was created using the -** OpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has -** not been independently verified as being compliant with the OpenGL(R) -** version 1.2.1 Specification. -*/ - -#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) -#define WIN32_LEAN_AND_MEAN 1 -#include -#endif - -#ifndef APIENTRY -#define APIENTRY -#endif - -/*************************************************************/ - -/* Header file version number, required by OpenGL ABI for Linux */ -#define GL_GLEXT_VERSION 6 - -#ifndef GL_VERSION_1_2 -#define GL_CONSTANT_COLOR 0x8001 -#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 -#define GL_CONSTANT_ALPHA 0x8003 -#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 -#define GL_BLEND_COLOR 0x8005 -#define GL_FUNC_ADD 0x8006 -#define GL_MIN 0x8007 -#define GL_MAX 0x8008 -#define GL_BLEND_EQUATION 0x8009 -#define GL_FUNC_SUBTRACT 0x800A -#define GL_FUNC_REVERSE_SUBTRACT 0x800B -#define GL_CONVOLUTION_1D 0x8010 -#define GL_CONVOLUTION_2D 0x8011 -#define GL_SEPARABLE_2D 0x8012 -#define GL_CONVOLUTION_BORDER_MODE 0x8013 -#define GL_CONVOLUTION_FILTER_SCALE 0x8014 -#define GL_CONVOLUTION_FILTER_BIAS 0x8015 -#define GL_REDUCE 0x8016 -#define GL_CONVOLUTION_FORMAT 0x8017 -#define GL_CONVOLUTION_WIDTH 0x8018 -#define GL_CONVOLUTION_HEIGHT 0x8019 -#define GL_MAX_CONVOLUTION_WIDTH 0x801A -#define GL_MAX_CONVOLUTION_HEIGHT 0x801B -#define GL_POST_CONVOLUTION_RED_SCALE 0x801C -#define GL_POST_CONVOLUTION_GREEN_SCALE 0x801D -#define GL_POST_CONVOLUTION_BLUE_SCALE 0x801E -#define GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F -#define GL_POST_CONVOLUTION_RED_BIAS 0x8020 -#define GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 -#define GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 -#define GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 -#define GL_HISTOGRAM 0x8024 -#define GL_PROXY_HISTOGRAM 0x8025 -#define GL_HISTOGRAM_WIDTH 0x8026 -#define GL_HISTOGRAM_FORMAT 0x8027 -#define GL_HISTOGRAM_RED_SIZE 0x8028 -#define GL_HISTOGRAM_GREEN_SIZE 0x8029 -#define GL_HISTOGRAM_BLUE_SIZE 0x802A -#define GL_HISTOGRAM_ALPHA_SIZE 0x802B -#define GL_HISTOGRAM_LUMINANCE_SIZE 0x802C -#define GL_HISTOGRAM_SINK 0x802D -#define GL_MINMAX 0x802E -#define GL_MINMAX_FORMAT 0x802F -#define GL_MINMAX_SINK 0x8030 -#define GL_TABLE_TOO_LARGE 0x8031 -#define GL_UNSIGNED_BYTE_3_3_2 0x8032 -#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 -#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 -#define GL_UNSIGNED_INT_8_8_8_8 0x8035 -#define GL_UNSIGNED_INT_10_10_10_2 0x8036 -#define GL_RESCALE_NORMAL 0x803A -#define GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 -#define GL_UNSIGNED_SHORT_5_6_5 0x8363 -#define GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 -#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 -#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 -#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 -#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 -#define GL_COLOR_MATRIX 0x80B1 -#define GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 -#define GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 -#define GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 -#define GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 -#define GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 -#define GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 -#define GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 -#define GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 -#define GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA -#define GL_COLOR_TABLE 0x80D0 -#define GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 -#define GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 -#define GL_PROXY_COLOR_TABLE 0x80D3 -#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 -#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 -#define GL_COLOR_TABLE_SCALE 0x80D6 -#define GL_COLOR_TABLE_BIAS 0x80D7 -#define GL_COLOR_TABLE_FORMAT 0x80D8 -#define GL_COLOR_TABLE_WIDTH 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF -#define GL_CLAMP_TO_EDGE 0x812F -#define GL_TEXTURE_MIN_LOD 0x813A -#define GL_TEXTURE_MAX_LOD 0x813B -#define GL_TEXTURE_BASE_LEVEL 0x813C -#define GL_TEXTURE_MAX_LEVEL 0x813D -#endif - -#ifndef GL_ARB_multitexture -#define GL_TEXTURE0_ARB 0x84C0 -#define GL_TEXTURE1_ARB 0x84C1 -#define GL_TEXTURE2_ARB 0x84C2 -#define GL_TEXTURE3_ARB 0x84C3 -#define GL_TEXTURE4_ARB 0x84C4 -#define GL_TEXTURE5_ARB 0x84C5 -#define GL_TEXTURE6_ARB 0x84C6 -#define GL_TEXTURE7_ARB 0x84C7 -#define GL_TEXTURE8_ARB 0x84C8 -#define GL_TEXTURE9_ARB 0x84C9 -#define GL_TEXTURE10_ARB 0x84CA -#define GL_TEXTURE11_ARB 0x84CB -#define GL_TEXTURE12_ARB 0x84CC -#define GL_TEXTURE13_ARB 0x84CD -#define GL_TEXTURE14_ARB 0x84CE -#define GL_TEXTURE15_ARB 0x84CF -#define GL_TEXTURE16_ARB 0x84D0 -#define GL_TEXTURE17_ARB 0x84D1 -#define GL_TEXTURE18_ARB 0x84D2 -#define GL_TEXTURE19_ARB 0x84D3 -#define GL_TEXTURE20_ARB 0x84D4 -#define GL_TEXTURE21_ARB 0x84D5 -#define GL_TEXTURE22_ARB 0x84D6 -#define GL_TEXTURE23_ARB 0x84D7 -#define GL_TEXTURE24_ARB 0x84D8 -#define GL_TEXTURE25_ARB 0x84D9 -#define GL_TEXTURE26_ARB 0x84DA -#define GL_TEXTURE27_ARB 0x84DB -#define GL_TEXTURE28_ARB 0x84DC -#define GL_TEXTURE29_ARB 0x84DD -#define GL_TEXTURE30_ARB 0x84DE -#define GL_TEXTURE31_ARB 0x84DF -#define GL_ACTIVE_TEXTURE_ARB 0x84E0 -#define GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 -#define GL_MAX_TEXTURE_UNITS_ARB 0x84E2 -#endif - -#ifndef GL_ARB_transpose_matrix -#define GL_TRANSPOSE_MODELVIEW_MATRIX_ARB 0x84E3 -#define GL_TRANSPOSE_PROJECTION_MATRIX_ARB 0x84E4 -#define GL_TRANSPOSE_TEXTURE_MATRIX_ARB 0x84E5 -#define GL_TRANSPOSE_COLOR_MATRIX_ARB 0x84E6 -#endif - -#ifndef GL_ARB_multisample -#define GL_MULTISAMPLE_ARB 0x809D -#define GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F -#define GL_SAMPLE_COVERAGE_ARB 0x80A0 -#define GL_SAMPLE_BUFFERS_ARB 0x80A8 -#define GL_SAMPLES_ARB 0x80A9 -#define GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA -#define GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB -#define GL_MULTISAMPLE_BIT_ARB 0x20000000 -#endif - -#ifndef GL_ARB_texture_cube_map -#define GL_NORMAL_MAP_ARB 0x8511 -#define GL_REFLECTION_MAP_ARB 0x8512 -#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARB 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_ARB 0x851C -#endif - -#ifndef GL_ARB_texture_compression -#define GL_COMPRESSED_ALPHA_ARB 0x84E9 -#define GL_COMPRESSED_LUMINANCE_ARB 0x84EA -#define GL_COMPRESSED_LUMINANCE_ALPHA_ARB 0x84EB -#define GL_COMPRESSED_INTENSITY_ARB 0x84EC -#define GL_COMPRESSED_RGB_ARB 0x84ED -#define GL_COMPRESSED_RGBA_ARB 0x84EE -#define GL_TEXTURE_COMPRESSION_HINT_ARB 0x84EF -#define GL_TEXTURE_IMAGE_SIZE_ARB 0x86A0 -#define GL_TEXTURE_COMPRESSED_ARB 0x86A1 -#define GL_NUM_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A2 -#define GL_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A3 -#endif - -#ifndef GL_EXT_abgr -#define GL_ABGR_EXT 0x8000 -#endif - -#ifndef GL_EXT_blend_color -#define GL_CONSTANT_COLOR_EXT 0x8001 -#define GL_ONE_MINUS_CONSTANT_COLOR_EXT 0x8002 -#define GL_CONSTANT_ALPHA_EXT 0x8003 -#define GL_ONE_MINUS_CONSTANT_ALPHA_EXT 0x8004 -#define GL_BLEND_COLOR_EXT 0x8005 -#endif - -#ifndef GL_EXT_polygon_offset -#define GL_POLYGON_OFFSET_EXT 0x8037 -#define GL_POLYGON_OFFSET_FACTOR_EXT 0x8038 -#define GL_POLYGON_OFFSET_BIAS_EXT 0x8039 -#endif - -#ifndef GL_EXT_texture -#define GL_ALPHA4_EXT 0x803B -#define GL_ALPHA8_EXT 0x803C -#define GL_ALPHA12_EXT 0x803D -#define GL_ALPHA16_EXT 0x803E -#define GL_LUMINANCE4_EXT 0x803F -#define GL_LUMINANCE8_EXT 0x8040 -#define GL_LUMINANCE12_EXT 0x8041 -#define GL_LUMINANCE16_EXT 0x8042 -#define GL_LUMINANCE4_ALPHA4_EXT 0x8043 -#define GL_LUMINANCE6_ALPHA2_EXT 0x8044 -#define GL_LUMINANCE8_ALPHA8_EXT 0x8045 -#define GL_LUMINANCE12_ALPHA4_EXT 0x8046 -#define GL_LUMINANCE12_ALPHA12_EXT 0x8047 -#define GL_LUMINANCE16_ALPHA16_EXT 0x8048 -#define GL_INTENSITY_EXT 0x8049 -#define GL_INTENSITY4_EXT 0x804A -#define GL_INTENSITY8_EXT 0x804B -#define GL_INTENSITY12_EXT 0x804C -#define GL_INTENSITY16_EXT 0x804D -#define GL_RGB2_EXT 0x804E -#define GL_RGB4_EXT 0x804F -#define GL_RGB5_EXT 0x8050 -#define GL_RGB8_EXT 0x8051 -#define GL_RGB10_EXT 0x8052 -#define GL_RGB12_EXT 0x8053 -#define GL_RGB16_EXT 0x8054 -#define GL_RGBA2_EXT 0x8055 -#define GL_RGBA4_EXT 0x8056 -#define GL_RGB5_A1_EXT 0x8057 -#define GL_RGBA8_EXT 0x8058 -#define GL_RGB10_A2_EXT 0x8059 -#define GL_RGBA12_EXT 0x805A -#define GL_RGBA16_EXT 0x805B -#define GL_TEXTURE_RED_SIZE_EXT 0x805C -#define GL_TEXTURE_GREEN_SIZE_EXT 0x805D -#define GL_TEXTURE_BLUE_SIZE_EXT 0x805E -#define GL_TEXTURE_ALPHA_SIZE_EXT 0x805F -#define GL_TEXTURE_LUMINANCE_SIZE_EXT 0x8060 -#define GL_TEXTURE_INTENSITY_SIZE_EXT 0x8061 -#define GL_REPLACE_EXT 0x8062 -#define GL_PROXY_TEXTURE_1D_EXT 0x8063 -#define GL_PROXY_TEXTURE_2D_EXT 0x8064 -#define GL_TEXTURE_TOO_LARGE_EXT 0x8065 -#endif - -#ifndef GL_EXT_texture3D -#define GL_PACK_SKIP_IMAGES 0x806B -#define GL_PACK_SKIP_IMAGES_EXT 0x806B -#define GL_PACK_IMAGE_HEIGHT 0x806C -#define GL_PACK_IMAGE_HEIGHT_EXT 0x806C -#define GL_UNPACK_SKIP_IMAGES 0x806D -#define GL_UNPACK_SKIP_IMAGES_EXT 0x806D -#define GL_UNPACK_IMAGE_HEIGHT 0x806E -#define GL_UNPACK_IMAGE_HEIGHT_EXT 0x806E -#define GL_TEXTURE_3D 0x806F -#define GL_TEXTURE_3D_EXT 0x806F -#define GL_PROXY_TEXTURE_3D 0x8070 -#define GL_PROXY_TEXTURE_3D_EXT 0x8070 -#define GL_TEXTURE_DEPTH 0x8071 -#define GL_TEXTURE_DEPTH_EXT 0x8071 -#define GL_TEXTURE_WRAP_R 0x8072 -#define GL_TEXTURE_WRAP_R_EXT 0x8072 -#define GL_MAX_3D_TEXTURE_SIZE 0x8073 -#define GL_MAX_3D_TEXTURE_SIZE_EXT 0x8073 -#endif - -#ifndef GL_SGIS_texture_filter4 -#define GL_FILTER4_SGIS 0x8146 -#define GL_TEXTURE_FILTER4_SIZE_SGIS 0x8147 -#endif - -#ifndef GL_EXT_subtexture -#endif - -#ifndef GL_EXT_copy_texture -#endif - -#ifndef GL_EXT_histogram -#define GL_HISTOGRAM_EXT 0x8024 -#define GL_PROXY_HISTOGRAM_EXT 0x8025 -#define GL_HISTOGRAM_WIDTH_EXT 0x8026 -#define GL_HISTOGRAM_FORMAT_EXT 0x8027 -#define GL_HISTOGRAM_RED_SIZE_EXT 0x8028 -#define GL_HISTOGRAM_GREEN_SIZE_EXT 0x8029 -#define GL_HISTOGRAM_BLUE_SIZE_EXT 0x802A -#define GL_HISTOGRAM_ALPHA_SIZE_EXT 0x802B -#define GL_HISTOGRAM_LUMINANCE_SIZE_EXT 0x802C -#define GL_HISTOGRAM_SINK_EXT 0x802D -#define GL_MINMAX_EXT 0x802E -#define GL_MINMAX_FORMAT_EXT 0x802F -#define GL_MINMAX_SINK_EXT 0x8030 -#define GL_TABLE_TOO_LARGE_EXT 0x8031 -#endif - -#ifndef GL_EXT_convolution -#define GL_CONVOLUTION_1D_EXT 0x8010 -#define GL_CONVOLUTION_2D_EXT 0x8011 -#define GL_SEPARABLE_2D_EXT 0x8012 -#define GL_CONVOLUTION_BORDER_MODE_EXT 0x8013 -#define GL_CONVOLUTION_FILTER_SCALE_EXT 0x8014 -#define GL_CONVOLUTION_FILTER_BIAS_EXT 0x8015 -#define GL_REDUCE_EXT 0x8016 -#define GL_CONVOLUTION_FORMAT_EXT 0x8017 -#define GL_CONVOLUTION_WIDTH_EXT 0x8018 -#define GL_CONVOLUTION_HEIGHT_EXT 0x8019 -#define GL_MAX_CONVOLUTION_WIDTH_EXT 0x801A -#define GL_MAX_CONVOLUTION_HEIGHT_EXT 0x801B -#define GL_POST_CONVOLUTION_RED_SCALE_EXT 0x801C -#define GL_POST_CONVOLUTION_GREEN_SCALE_EXT 0x801D -#define GL_POST_CONVOLUTION_BLUE_SCALE_EXT 0x801E -#define GL_POST_CONVOLUTION_ALPHA_SCALE_EXT 0x801F -#define GL_POST_CONVOLUTION_RED_BIAS_EXT 0x8020 -#define GL_POST_CONVOLUTION_GREEN_BIAS_EXT 0x8021 -#define GL_POST_CONVOLUTION_BLUE_BIAS_EXT 0x8022 -#define GL_POST_CONVOLUTION_ALPHA_BIAS_EXT 0x8023 -#endif - -#ifndef GL_SGI_color_matrix -#define GL_COLOR_MATRIX_SGI 0x80B1 -#define GL_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B2 -#define GL_MAX_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B3 -#define GL_POST_COLOR_MATRIX_RED_SCALE_SGI 0x80B4 -#define GL_POST_COLOR_MATRIX_GREEN_SCALE_SGI 0x80B5 -#define GL_POST_COLOR_MATRIX_BLUE_SCALE_SGI 0x80B6 -#define GL_POST_COLOR_MATRIX_ALPHA_SCALE_SGI 0x80B7 -#define GL_POST_COLOR_MATRIX_RED_BIAS_SGI 0x80B8 -#define GL_POST_COLOR_MATRIX_GREEN_BIAS_SGI 0x80B9 -#define GL_POST_COLOR_MATRIX_BLUE_BIAS_SGI 0x80BA -#define GL_POST_COLOR_MATRIX_ALPHA_BIAS_SGI 0x80BB -#endif - -#ifndef GL_SGI_color_table -#define GL_COLOR_TABLE_SGI 0x80D0 -#define GL_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D1 -#define GL_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D2 -#define GL_PROXY_COLOR_TABLE_SGI 0x80D3 -#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D4 -#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D5 -#define GL_COLOR_TABLE_SCALE_SGI 0x80D6 -#define GL_COLOR_TABLE_BIAS_SGI 0x80D7 -#define GL_COLOR_TABLE_FORMAT_SGI 0x80D8 -#define GL_COLOR_TABLE_WIDTH_SGI 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE_SGI 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE_SGI 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE_SGI 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE_SGI 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE_SGI 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE_SGI 0x80DF -#endif - -#ifndef GL_SGIS_pixel_texture -#define GL_PIXEL_TEXTURE_SGIS 0x8353 -#define GL_PIXEL_FRAGMENT_RGB_SOURCE_SGIS 0x8354 -#define GL_PIXEL_FRAGMENT_ALPHA_SOURCE_SGIS 0x8355 -#define GL_PIXEL_GROUP_COLOR_SGIS 0x8356 -#endif - -#ifndef GL_SGIX_pixel_texture -#define GL_PIXEL_TEX_BUM_SGIX 0x8139 -#define GL_PIXEL_TEX_BUM_MODE_SGIX 0x832B -#endif - -#ifndef GL_SGIS_texture4D -#define GL_PACK_SKIP_VOLUMES_SGIS 0x8130 -#define GL_PACK_IMAGE_DEPTH_SGIS 0x8131 -#define GL_UNPACK_SKIP_VOLUMES_SGIS 0x8132 -#define GL_UNPACK_IMAGE_DEPTH_SGIS 0x8133 -#define GL_TEXTURE_4D_SGIS 0x8134 -#define GL_PROXY_TEXTURE_4D_SGIS 0x8135 -#define GL_TEXTURE_4DSIZE_SGIS 0x8136 -#define GL_TEXTURE_WRAP_Q_SGIS 0x8137 -#define GL_MAX_4D_TEXTURE_SIZE_SGIS 0x8138 -#define GL_TEXTURE_4D_BINDING_SGIS 0x814F -#endif - -#ifndef GL_SGI_texture_color_table -#define GL_TEXTURE_COLOR_TABLE_SGI 0x80BC -#define GL_PROXY_TEXTURE_COLOR_TABLE_SGI 0x80BD -#endif - -#ifndef GL_EXT_cmyka -#define GL_CMYK_EXT 0x800C -#define GL_CMYKA_EXT 0x800D -#define GL_PACK_CMYK_HINT_EXT 0x800E -#define GL_UNPACK_CMYK_HINT_EXT 0x800F -#endif - -#ifndef GL_EXT_texture_object -#define GL_TEXTURE_PRIORITY_EXT 0x8066 -#define GL_TEXTURE_RESIDENT_EXT 0x8067 -#define GL_TEXTURE_1D_BINDING_EXT 0x8068 -#define GL_TEXTURE_2D_BINDING_EXT 0x8069 -#define GL_TEXTURE_3D_BINDING_EXT 0x806A -#endif - -#ifndef GL_SGIS_detail_texture -#define GL_DETAIL_TEXTURE_2D_SGIS 0x8095 -#define GL_DETAIL_TEXTURE_2D_BINDING_SGIS 0x8096 -#define GL_LINEAR_DETAIL_SGIS 0x8097 -#define GL_LINEAR_DETAIL_ALPHA_SGIS 0x8098 -#define GL_LINEAR_DETAIL_COLOR_SGIS 0x8099 -#define GL_DETAIL_TEXTURE_LEVEL_SGIS 0x809A -#define GL_DETAIL_TEXTURE_MODE_SGIS 0x809B -#define GL_DETAIL_TEXTURE_FUNC_POINTS_SGIS 0x809C -#endif - -#ifndef GL_SGIS_sharpen_texture -#define GL_LINEAR_SHARPEN_SGIS 0x80AD -#define GL_LINEAR_SHARPEN_ALPHA_SGIS 0x80AE -#define GL_LINEAR_SHARPEN_COLOR_SGIS 0x80AF -#define GL_SHARPEN_TEXTURE_FUNC_POINTS_SGIS 0x80B0 -#endif - -#ifndef GL_EXT_packed_pixels -#define GL_UNSIGNED_BYTE_3_3_2_EXT 0x8032 -#define GL_UNSIGNED_SHORT_4_4_4_4_EXT 0x8033 -#define GL_UNSIGNED_SHORT_5_5_5_1_EXT 0x8034 -#define GL_UNSIGNED_INT_8_8_8_8_EXT 0x8035 -#define GL_UNSIGNED_INT_10_10_10_2_EXT 0x8036 -#endif - -#ifndef GL_SGIS_texture_lod -#define GL_TEXTURE_MIN_LOD_SGIS 0x813A -#define GL_TEXTURE_MAX_LOD_SGIS 0x813B -#define GL_TEXTURE_BASE_LEVEL_SGIS 0x813C -#define GL_TEXTURE_MAX_LEVEL_SGIS 0x813D -#endif - -#ifndef GL_SGIS_multisample -#define GL_MULTISAMPLE_SGIS 0x809D -#define GL_SAMPLE_ALPHA_TO_MASK_SGIS 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_SGIS 0x809F -#define GL_SAMPLE_MASK_SGIS 0x80A0 -#define GL_1PASS_SGIS 0x80A1 -#define GL_2PASS_0_SGIS 0x80A2 -#define GL_2PASS_1_SGIS 0x80A3 -#define GL_4PASS_0_SGIS 0x80A4 -#define GL_4PASS_1_SGIS 0x80A5 -#define GL_4PASS_2_SGIS 0x80A6 -#define GL_4PASS_3_SGIS 0x80A7 -#define GL_SAMPLE_BUFFERS_SGIS 0x80A8 -#define GL_SAMPLES_SGIS 0x80A9 -#define GL_SAMPLE_MASK_VALUE_SGIS 0x80AA -#define GL_SAMPLE_MASK_INVERT_SGIS 0x80AB -#define GL_SAMPLE_PATTERN_SGIS 0x80AC -#endif - -#ifndef GL_EXT_rescale_normal -#define GL_RESCALE_NORMAL_EXT 0x803A -#endif - -#ifndef GL_EXT_vertex_array -#define GL_VERTEX_ARRAY_EXT 0x8074 -#define GL_NORMAL_ARRAY_EXT 0x8075 -#define GL_COLOR_ARRAY_EXT 0x8076 -#define GL_INDEX_ARRAY_EXT 0x8077 -#define GL_TEXTURE_COORD_ARRAY_EXT 0x8078 -#define GL_EDGE_FLAG_ARRAY_EXT 0x8079 -#define GL_VERTEX_ARRAY_SIZE_EXT 0x807A -#define GL_VERTEX_ARRAY_TYPE_EXT 0x807B -#define GL_VERTEX_ARRAY_STRIDE_EXT 0x807C -#define GL_VERTEX_ARRAY_COUNT_EXT 0x807D -#define GL_NORMAL_ARRAY_TYPE_EXT 0x807E -#define GL_NORMAL_ARRAY_STRIDE_EXT 0x807F -#define GL_NORMAL_ARRAY_COUNT_EXT 0x8080 -#define GL_COLOR_ARRAY_SIZE_EXT 0x8081 -#define GL_COLOR_ARRAY_TYPE_EXT 0x8082 -#define GL_COLOR_ARRAY_STRIDE_EXT 0x8083 -#define GL_COLOR_ARRAY_COUNT_EXT 0x8084 -#define GL_INDEX_ARRAY_TYPE_EXT 0x8085 -#define GL_INDEX_ARRAY_STRIDE_EXT 0x8086 -#define GL_INDEX_ARRAY_COUNT_EXT 0x8087 -#define GL_TEXTURE_COORD_ARRAY_SIZE_EXT 0x8088 -#define GL_TEXTURE_COORD_ARRAY_TYPE_EXT 0x8089 -#define GL_TEXTURE_COORD_ARRAY_STRIDE_EXT 0x808A -#define GL_TEXTURE_COORD_ARRAY_COUNT_EXT 0x808B -#define GL_EDGE_FLAG_ARRAY_STRIDE_EXT 0x808C -#define GL_EDGE_FLAG_ARRAY_COUNT_EXT 0x808D -#define GL_VERTEX_ARRAY_POINTER_EXT 0x808E -#define GL_NORMAL_ARRAY_POINTER_EXT 0x808F -#define GL_COLOR_ARRAY_POINTER_EXT 0x8090 -#define GL_INDEX_ARRAY_POINTER_EXT 0x8091 -#define GL_TEXTURE_COORD_ARRAY_POINTER_EXT 0x8092 -#define GL_EDGE_FLAG_ARRAY_POINTER_EXT 0x8093 -#endif - -#ifndef GL_EXT_misc_attribute -#endif - -#ifndef GL_SGIS_generate_mipmap -#define GL_GENERATE_MIPMAP_SGIS 0x8191 -#define GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 -#endif - -#ifndef GL_SGIX_clipmap -#define GL_LINEAR_CLIPMAP_LINEAR_SGIX 0x8170 -#define GL_TEXTURE_CLIPMAP_CENTER_SGIX 0x8171 -#define GL_TEXTURE_CLIPMAP_FRAME_SGIX 0x8172 -#define GL_TEXTURE_CLIPMAP_OFFSET_SGIX 0x8173 -#define GL_TEXTURE_CLIPMAP_VIRTUAL_DEPTH_SGIX 0x8174 -#define GL_TEXTURE_CLIPMAP_LOD_OFFSET_SGIX 0x8175 -#define GL_TEXTURE_CLIPMAP_DEPTH_SGIX 0x8176 -#define GL_MAX_CLIPMAP_DEPTH_SGIX 0x8177 -#define GL_MAX_CLIPMAP_VIRTUAL_DEPTH_SGIX 0x8178 -#define GL_NEAREST_CLIPMAP_NEAREST_SGIX 0x844D -#define GL_NEAREST_CLIPMAP_LINEAR_SGIX 0x844E -#define GL_LINEAR_CLIPMAP_NEAREST_SGIX 0x844F -#endif - -#ifndef GL_SGIX_shadow -#define GL_TEXTURE_COMPARE_SGIX 0x819A -#define GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B -#define GL_TEXTURE_LEQUAL_R_SGIX 0x819C -#define GL_TEXTURE_GEQUAL_R_SGIX 0x819D -#endif - -#ifndef GL_SGIS_texture_edge_clamp -#define GL_CLAMP_TO_EDGE_SGIS 0x812F -#endif - -#ifndef GL_SGIS_texture_border_clamp -#define GL_CLAMP_TO_BORDER_SGIS 0x812D -#endif - -#ifndef GL_EXT_blend_minmax -#define GL_FUNC_ADD_EXT 0x8006 -#define GL_MIN_EXT 0x8007 -#define GL_MAX_EXT 0x8008 -#define GL_BLEND_EQUATION_EXT 0x8009 -#endif - -#ifndef GL_EXT_blend_subtract -#define GL_FUNC_SUBTRACT_EXT 0x800A -#define GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B -#endif - -#ifndef GL_EXT_blend_logic_op -#endif - -#ifndef GL_SGIX_interlace -#define GL_INTERLACE_SGIX 0x8094 -#endif - -#ifndef GL_SGIX_pixel_tiles -#define GL_PIXEL_TILE_BEST_ALIGNMENT_SGIX 0x813E -#define GL_PIXEL_TILE_CACHE_INCREMENT_SGIX 0x813F -#define GL_PIXEL_TILE_WIDTH_SGIX 0x8140 -#define GL_PIXEL_TILE_HEIGHT_SGIX 0x8141 -#define GL_PIXEL_TILE_GRID_WIDTH_SGIX 0x8142 -#define GL_PIXEL_TILE_GRID_HEIGHT_SGIX 0x8143 -#define GL_PIXEL_TILE_GRID_DEPTH_SGIX 0x8144 -#define GL_PIXEL_TILE_CACHE_SIZE_SGIX 0x8145 -#endif - -#ifndef GL_SGIS_texture_select -#define GL_DUAL_ALPHA4_SGIS 0x8110 -#define GL_DUAL_ALPHA8_SGIS 0x8111 -#define GL_DUAL_ALPHA12_SGIS 0x8112 -#define GL_DUAL_ALPHA16_SGIS 0x8113 -#define GL_DUAL_LUMINANCE4_SGIS 0x8114 -#define GL_DUAL_LUMINANCE8_SGIS 0x8115 -#define GL_DUAL_LUMINANCE12_SGIS 0x8116 -#define GL_DUAL_LUMINANCE16_SGIS 0x8117 -#define GL_DUAL_INTENSITY4_SGIS 0x8118 -#define GL_DUAL_INTENSITY8_SGIS 0x8119 -#define GL_DUAL_INTENSITY12_SGIS 0x811A -#define GL_DUAL_INTENSITY16_SGIS 0x811B -#define GL_DUAL_LUMINANCE_ALPHA4_SGIS 0x811C -#define GL_DUAL_LUMINANCE_ALPHA8_SGIS 0x811D -#define GL_QUAD_ALPHA4_SGIS 0x811E -#define GL_QUAD_ALPHA8_SGIS 0x811F -#define GL_QUAD_LUMINANCE4_SGIS 0x8120 -#define GL_QUAD_LUMINANCE8_SGIS 0x8121 -#define GL_QUAD_INTENSITY4_SGIS 0x8122 -#define GL_QUAD_INTENSITY8_SGIS 0x8123 -#define GL_DUAL_TEXTURE_SELECT_SGIS 0x8124 -#define GL_QUAD_TEXTURE_SELECT_SGIS 0x8125 -#endif - -#ifndef GL_SGIX_sprite -#define GL_SPRITE_SGIX 0x8148 -#define GL_SPRITE_MODE_SGIX 0x8149 -#define GL_SPRITE_AXIS_SGIX 0x814A -#define GL_SPRITE_TRANSLATION_SGIX 0x814B -#define GL_SPRITE_AXIAL_SGIX 0x814C -#define GL_SPRITE_OBJECT_ALIGNED_SGIX 0x814D -#define GL_SPRITE_EYE_ALIGNED_SGIX 0x814E -#endif - -#ifndef GL_SGIX_texture_multi_buffer -#define GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E -#endif - -#ifndef GL_SGIS_point_parameters -#define GL_POINT_SIZE_MIN_EXT 0x8126 -#define GL_POINT_SIZE_MIN_SGIS 0x8126 -#define GL_POINT_SIZE_MAX_EXT 0x8127 -#define GL_POINT_SIZE_MAX_SGIS 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE_EXT 0x8128 -#define GL_POINT_FADE_THRESHOLD_SIZE_SGIS 0x8128 -#define GL_DISTANCE_ATTENUATION_EXT 0x8129 -#define GL_DISTANCE_ATTENUATION_SGIS 0x8129 -#endif - -#ifndef GL_SGIX_instruments -#define GL_INSTRUMENT_BUFFER_POINTER_SGIX 0x8180 -#define GL_INSTRUMENT_MEASUREMENTS_SGIX 0x8181 -#endif - -#ifndef GL_SGIX_texture_scale_bias -#define GL_POST_TEXTURE_FILTER_BIAS_SGIX 0x8179 -#define GL_POST_TEXTURE_FILTER_SCALE_SGIX 0x817A -#define GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX 0x817B -#define GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX 0x817C -#endif - -#ifndef GL_SGIX_framezoom -#define GL_FRAMEZOOM_SGIX 0x818B -#define GL_FRAMEZOOM_FACTOR_SGIX 0x818C -#define GL_MAX_FRAMEZOOM_FACTOR_SGIX 0x818D -#endif - -#ifndef GL_SGIX_tag_sample_buffer -#endif - -#ifndef GL_SGIX_reference_plane -#define GL_REFERENCE_PLANE_SGIX 0x817D -#define GL_REFERENCE_PLANE_EQUATION_SGIX 0x817E -#endif - -#ifndef GL_SGIX_flush_raster -#endif - -#ifndef GL_SGIX_depth_texture -#define GL_DEPTH_COMPONENT16_SGIX 0x81A5 -#define GL_DEPTH_COMPONENT24_SGIX 0x81A6 -#define GL_DEPTH_COMPONENT32_SGIX 0x81A7 -#endif - -#ifndef GL_SGIS_fog_function -#define GL_FOG_FUNC_SGIS 0x812A -#define GL_FOG_FUNC_POINTS_SGIS 0x812B -#define GL_MAX_FOG_FUNC_POINTS_SGIS 0x812C -#endif - -#ifndef GL_SGIX_fog_offset -#define GL_FOG_OFFSET_SGIX 0x8198 -#define GL_FOG_OFFSET_VALUE_SGIX 0x8199 -#endif - -#ifndef GL_HP_image_transform -#define GL_IMAGE_SCALE_X_HP 0x8155 -#define GL_IMAGE_SCALE_Y_HP 0x8156 -#define GL_IMAGE_TRANSLATE_X_HP 0x8157 -#define GL_IMAGE_TRANSLATE_Y_HP 0x8158 -#define GL_IMAGE_ROTATE_ANGLE_HP 0x8159 -#define GL_IMAGE_ROTATE_ORIGIN_X_HP 0x815A -#define GL_IMAGE_ROTATE_ORIGIN_Y_HP 0x815B -#define GL_IMAGE_MAG_FILTER_HP 0x815C -#define GL_IMAGE_MIN_FILTER_HP 0x815D -#define GL_IMAGE_CUBIC_WEIGHT_HP 0x815E -#define GL_CUBIC_HP 0x815F -#define GL_AVERAGE_HP 0x8160 -#define GL_IMAGE_TRANSFORM_2D_HP 0x8161 -#define GL_POST_IMAGE_TRANSFORM_COLOR_TABLE_HP 0x8162 -#define GL_PROXY_POST_IMAGE_TRANSFORM_COLOR_TABLE_HP 0x8163 -#endif - -#ifndef GL_HP_convolution_border_modes -#define GL_IGNORE_BORDER_HP 0x8150 -#define GL_CONSTANT_BORDER_HP 0x8151 -#define GL_REPLICATE_BORDER_HP 0x8153 -#define GL_CONVOLUTION_BORDER_COLOR_HP 0x8154 -#endif - -#ifndef GL_INGR_palette_buffer -#endif - -#ifndef GL_SGIX_texture_add_env -#define GL_TEXTURE_ENV_BIAS_SGIX 0x80BE -#endif - -#ifndef GL_EXT_color_subtable -#endif - -#ifndef GL_PGI_vertex_hints -#define GL_VERTEX_DATA_HINT_PGI 0x1A22A -#define GL_VERTEX_CONSISTENT_HINT_PGI 0x1A22B -#define GL_MATERIAL_SIDE_HINT_PGI 0x1A22C -#define GL_MAX_VERTEX_HINT_PGI 0x1A22D -#define GL_COLOR3_BIT_PGI 0x00010000 -#define GL_COLOR4_BIT_PGI 0x00020000 -#define GL_EDGEFLAG_BIT_PGI 0x00040000 -#define GL_INDEX_BIT_PGI 0x00080000 -#define GL_MAT_AMBIENT_BIT_PGI 0x00100000 -#define GL_MAT_AMBIENT_AND_DIFFUSE_BIT_PGI 0x00200000 -#define GL_MAT_DIFFUSE_BIT_PGI 0x00400000 -#define GL_MAT_EMISSION_BIT_PGI 0x00800000 -#define GL_MAT_COLOR_INDEXES_BIT_PGI 0x01000000 -#define GL_MAT_SHININESS_BIT_PGI 0x02000000 -#define GL_MAT_SPECULAR_BIT_PGI 0x04000000 -#define GL_NORMAL_BIT_PGI 0x08000000 -#define GL_TEXCOORD1_BIT_PGI 0x10000000 -#define GL_TEXCOORD2_BIT_PGI 0x20000000 -#define GL_TEXCOORD3_BIT_PGI 0x40000000 -#define GL_TEXCOORD4_BIT_PGI 0x80000000 -#define GL_VERTEX23_BIT_PGI 0x00000004 -#define GL_VERTEX4_BIT_PGI 0x00000008 -#endif - -#ifndef GL_PGI_misc_hints -#define GL_PREFER_DOUBLEBUFFER_HINT_PGI 0x1A1F8 -#define GL_CONSERVE_MEMORY_HINT_PGI 0x1A1FD -#define GL_RECLAIM_MEMORY_HINT_PGI 0x1A1FE -#define GL_NATIVE_GRAPHICS_HANDLE_PGI 0x1A202 -#define GL_NATIVE_GRAPHICS_BEGIN_HINT_PGI 0x1A203 -#define GL_NATIVE_GRAPHICS_END_HINT_PGI 0x1A204 -#define GL_ALWAYS_FAST_HINT_PGI 0x1A20C -#define GL_ALWAYS_SOFT_HINT_PGI 0x1A20D -#define GL_ALLOW_DRAW_OBJ_HINT_PGI 0x1A20E -#define GL_ALLOW_DRAW_WIN_HINT_PGI 0x1A20F -#define GL_ALLOW_DRAW_FRG_HINT_PGI 0x1A210 -#define GL_ALLOW_DRAW_MEM_HINT_PGI 0x1A211 -#define GL_STRICT_DEPTHFUNC_HINT_PGI 0x1A216 -#define GL_STRICT_LIGHTING_HINT_PGI 0x1A217 -#define GL_STRICT_SCISSOR_HINT_PGI 0x1A218 -#define GL_FULL_STIPPLE_HINT_PGI 0x1A219 -#define GL_CLIP_NEAR_HINT_PGI 0x1A220 -#define GL_CLIP_FAR_HINT_PGI 0x1A221 -#define GL_WIDE_LINE_HINT_PGI 0x1A222 -#define GL_BACK_NORMALS_HINT_PGI 0x1A223 -#endif - -#ifndef GL_EXT_paletted_texture -#define GL_COLOR_INDEX1_EXT 0x80E2 -#define GL_COLOR_INDEX2_EXT 0x80E3 -#define GL_COLOR_INDEX4_EXT 0x80E4 -#define GL_COLOR_INDEX8_EXT 0x80E5 -#define GL_COLOR_INDEX12_EXT 0x80E6 -#define GL_COLOR_INDEX16_EXT 0x80E7 -#define GL_TEXTURE_INDEX_SIZE_EXT 0x80ED -#endif - -#ifndef GL_EXT_clip_volume_hint -#define GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 -#endif - -#ifndef GL_SGIX_list_priority -#define GL_LIST_PRIORITY_SGIX 0x8182 -#endif - -#ifndef GL_SGIX_ir_instrument1 -#define GL_IR_INSTRUMENT1_SGIX 0x817F -#endif - -#ifndef GL_SGIX_calligraphic_fragment -#define GL_CALLIGRAPHIC_FRAGMENT_SGIX 0x8183 -#endif - -#ifndef GL_SGIX_texture_lod_bias -#define GL_TEXTURE_LOD_BIAS_S_SGIX 0x818E -#define GL_TEXTURE_LOD_BIAS_T_SGIX 0x818F -#define GL_TEXTURE_LOD_BIAS_R_SGIX 0x8190 -#endif - -#ifndef GL_SGIX_shadow_ambient -#define GL_SHADOW_AMBIENT_SGIX 0x80BF -#endif - -#ifndef GL_EXT_index_texture -#endif - -#ifndef GL_EXT_index_material -#define GL_INDEX_MATERIAL_EXT 0x81B8 -#define GL_INDEX_MATERIAL_PARAMETER_EXT 0x81B9 -#define GL_INDEX_MATERIAL_FACE_EXT 0x81BA -#endif - -#ifndef GL_EXT_index_func -#define GL_INDEX_TEST_EXT 0x81B5 -#define GL_INDEX_TEST_FUNC_EXT 0x81B6 -#define GL_INDEX_TEST_REF_EXT 0x81B7 -#endif - -#ifndef GL_EXT_index_array_formats -#define GL_IUI_V2F_EXT 0x81AD -#define GL_IUI_V3F_EXT 0x81AE -#define GL_IUI_N3F_V2F_EXT 0x81AF -#define GL_IUI_N3F_V3F_EXT 0x81B0 -#define GL_T2F_IUI_V2F_EXT 0x81B1 -#define GL_T2F_IUI_V3F_EXT 0x81B2 -#define GL_T2F_IUI_N3F_V2F_EXT 0x81B3 -#define GL_T2F_IUI_N3F_V3F_EXT 0x81B4 -#endif - -#ifndef GL_EXT_compiled_vertex_array -#define GL_ARRAY_ELEMENT_LOCK_FIRST_EXT 0x81A8 -#define GL_ARRAY_ELEMENT_LOCK_COUNT_EXT 0x81A9 -#endif - -#ifndef GL_EXT_cull_vertex -#define GL_CULL_VERTEX_EXT 0x81AA -#define GL_CULL_VERTEX_EYE_POSITION_EXT 0x81AB -#define GL_CULL_VERTEX_OBJECT_POSITION_EXT 0x81AC -#endif - -#ifndef GL_SGIX_ycrcb -#define GL_YCRCB_422_SGIX 0x81BB -#define GL_YCRCB_444_SGIX 0x81BC -#endif - -#ifndef GL_SGIX_fragment_lighting -#define GL_FRAGMENT_LIGHTING_SGIX 0x8400 -#define GL_FRAGMENT_COLOR_MATERIAL_SGIX 0x8401 -#define GL_FRAGMENT_COLOR_MATERIAL_FACE_SGIX 0x8402 -#define GL_FRAGMENT_COLOR_MATERIAL_PARAMETER_SGIX 0x8403 -#define GL_MAX_FRAGMENT_LIGHTS_SGIX 0x8404 -#define GL_MAX_ACTIVE_LIGHTS_SGIX 0x8405 -#define GL_CURRENT_RASTER_NORMAL_SGIX 0x8406 -#define GL_LIGHT_ENV_MODE_SGIX 0x8407 -#define GL_FRAGMENT_LIGHT_MODEL_LOCAL_VIEWER_SGIX 0x8408 -#define GL_FRAGMENT_LIGHT_MODEL_TWO_SIDE_SGIX 0x8409 -#define GL_FRAGMENT_LIGHT_MODEL_AMBIENT_SGIX 0x840A -#define GL_FRAGMENT_LIGHT_MODEL_NORMAL_INTERPOLATION_SGIX 0x840B -#define GL_FRAGMENT_LIGHT0_SGIX 0x840C -#define GL_FRAGMENT_LIGHT1_SGIX 0x840D -#define GL_FRAGMENT_LIGHT2_SGIX 0x840E -#define GL_FRAGMENT_LIGHT3_SGIX 0x840F -#define GL_FRAGMENT_LIGHT4_SGIX 0x8410 -#define GL_FRAGMENT_LIGHT5_SGIX 0x8411 -#define GL_FRAGMENT_LIGHT6_SGIX 0x8412 -#define GL_FRAGMENT_LIGHT7_SGIX 0x8413 -#endif - -#ifndef GL_IBM_rasterpos_clip -#define GL_RASTER_POSITION_UNCLIPPED_IBM 0x19262 -#endif - -#ifndef GL_HP_texture_lighting -#define GL_TEXTURE_LIGHTING_MODE_HP 0x8167 -#define GL_TEXTURE_POST_SPECULAR_HP 0x8168 -#define GL_TEXTURE_PRE_SPECULAR_HP 0x8169 -#endif - -#ifndef GL_EXT_draw_range_elements -#define GL_MAX_ELEMENTS_VERTICES_EXT 0x80E8 -#define GL_MAX_ELEMENTS_INDICES_EXT 0x80E9 -#endif - -#ifndef GL_WIN_phong_shading -#define GL_PHONG_WIN 0x80EA -#define GL_PHONG_HINT_WIN 0x80EB -#endif - -#ifndef GL_WIN_specular_fog -#define GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC -#endif - -#ifndef GL_EXT_light_texture -#define GL_FRAGMENT_MATERIAL_EXT 0x8349 -#define GL_FRAGMENT_NORMAL_EXT 0x834A -#define GL_FRAGMENT_COLOR_EXT 0x834C -#define GL_ATTENUATION_EXT 0x834D -#define GL_SHADOW_ATTENUATION_EXT 0x834E -#define GL_TEXTURE_APPLICATION_MODE_EXT 0x834F -#define GL_TEXTURE_LIGHT_EXT 0x8350 -#define GL_TEXTURE_MATERIAL_FACE_EXT 0x8351 -#define GL_TEXTURE_MATERIAL_PARAMETER_EXT 0x8352 -/* reuse GL_FRAGMENT_DEPTH_EXT */ -#endif - -#ifndef GL_SGIX_blend_alpha_minmax -#define GL_ALPHA_MIN_SGIX 0x8320 -#define GL_ALPHA_MAX_SGIX 0x8321 -#endif - -#ifndef GL_EXT_bgra -#define GL_BGR_EXT 0x80E0 -#define GL_BGRA_EXT 0x80E1 -#endif - -#ifndef GL_INTEL_texture_scissor -#endif - -#ifndef GL_INTEL_parallel_arrays -#define GL_PARALLEL_ARRAYS_INTEL 0x83F4 -#define GL_VERTEX_ARRAY_PARALLEL_POINTERS_INTEL 0x83F5 -#define GL_NORMAL_ARRAY_PARALLEL_POINTERS_INTEL 0x83F6 -#define GL_COLOR_ARRAY_PARALLEL_POINTERS_INTEL 0x83F7 -#define GL_TEXTURE_COORD_ARRAY_PARALLEL_POINTERS_INTEL 0x83F8 -#endif - -#ifndef GL_HP_occlusion_test -#define GL_OCCLUSION_TEST_HP 0x8165 -#define GL_OCCLUSION_TEST_RESULT_HP 0x8166 -#endif - -#ifndef GL_EXT_pixel_transform -#define GL_PIXEL_TRANSFORM_2D_EXT 0x8330 -#define GL_PIXEL_MAG_FILTER_EXT 0x8331 -#define GL_PIXEL_MIN_FILTER_EXT 0x8332 -#define GL_PIXEL_CUBIC_WEIGHT_EXT 0x8333 -#define GL_CUBIC_EXT 0x8334 -#define GL_AVERAGE_EXT 0x8335 -#define GL_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8336 -#define GL_MAX_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8337 -#define GL_PIXEL_TRANSFORM_2D_MATRIX_EXT 0x8338 -#endif - -#ifndef GL_EXT_pixel_transform_color_table -#endif - -#ifndef GL_EXT_shared_texture_palette -#define GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB -#endif - -#ifndef GL_EXT_separate_specular_color -#define GL_LIGHT_MODEL_COLOR_CONTROL_EXT 0x81F8 -#define GL_SINGLE_COLOR_EXT 0x81F9 -#define GL_SEPARATE_SPECULAR_COLOR_EXT 0x81FA -#endif - -#ifndef GL_EXT_secondary_color -#define GL_COLOR_SUM_EXT 0x8458 -#define GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 -#define GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A -#define GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B -#define GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C -#define GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D -#define GL_SECONDARY_COLOR_ARRAY_EXT 0x845E -#endif - -#ifndef GL_EXT_texture_perturb_normal -#define GL_PERTURB_EXT 0x85AE -#define GL_TEXTURE_NORMAL_EXT 0x85AF -#endif - -#ifndef GL_EXT_multi_draw_arrays -#endif - -#ifndef GL_EXT_fog_coord -#define GL_FOG_COORDINATE_SOURCE_EXT 0x8450 -#define GL_FOG_COORDINATE_EXT 0x8451 -#define GL_FRAGMENT_DEPTH_EXT 0x8452 -#define GL_CURRENT_FOG_COORDINATE_EXT 0x8453 -#define GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 -#define GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 -#define GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 -#define GL_FOG_COORDINATE_ARRAY_EXT 0x8457 -#endif - -#ifndef GL_REND_screen_coordinates -#define GL_SCREEN_COORDINATES_REND 0x8490 -#define GL_INVERTED_SCREEN_W_REND 0x8491 -#endif - -#ifndef GL_EXT_coordinate_frame -#define GL_TANGENT_ARRAY_EXT 0x8439 -#define GL_BINORMAL_ARRAY_EXT 0x843A -#define GL_CURRENT_TANGENT_EXT 0x843B -#define GL_CURRENT_BINORMAL_EXT 0x843C -#define GL_TANGENT_ARRAY_TYPE_EXT 0x843E -#define GL_TANGENT_ARRAY_STRIDE_EXT 0x843F -#define GL_BINORMAL_ARRAY_TYPE_EXT 0x8440 -#define GL_BINORMAL_ARRAY_STRIDE_EXT 0x8441 -#define GL_TANGENT_ARRAY_POINTER_EXT 0x8442 -#define GL_BINORMAL_ARRAY_POINTER_EXT 0x8443 -#define GL_MAP1_TANGENT_EXT 0x8444 -#define GL_MAP2_TANGENT_EXT 0x8445 -#define GL_MAP1_BINORMAL_EXT 0x8446 -#define GL_MAP2_BINORMAL_EXT 0x8447 -#endif - -#ifndef GL_EXT_texture_env_combine -#define GL_COMBINE_EXT 0x8570 -#define GL_COMBINE_RGB_EXT 0x8571 -#define GL_COMBINE_ALPHA_EXT 0x8572 -#define GL_RGB_SCALE_EXT 0x8573 -#define GL_ADD_SIGNED_EXT 0x8574 -#define GL_INTERPOLATE_EXT 0x8575 -#define GL_CONSTANT_EXT 0x8576 -#define GL_PRIMARY_COLOR_EXT 0x8577 -#define GL_PREVIOUS_EXT 0x8578 -#define GL_SOURCE0_RGB_EXT 0x8580 -#define GL_SOURCE1_RGB_EXT 0x8581 -#define GL_SOURCE2_RGB_EXT 0x8582 -#define GL_SOURCE3_RGB_EXT 0x8583 -#define GL_SOURCE4_RGB_EXT 0x8584 -#define GL_SOURCE5_RGB_EXT 0x8585 -#define GL_SOURCE6_RGB_EXT 0x8586 -#define GL_SOURCE7_RGB_EXT 0x8587 -#define GL_SOURCE0_ALPHA_EXT 0x8588 -#define GL_SOURCE1_ALPHA_EXT 0x8589 -#define GL_SOURCE2_ALPHA_EXT 0x858A -#define GL_SOURCE3_ALPHA_EXT 0x858B -#define GL_SOURCE4_ALPHA_EXT 0x858C -#define GL_SOURCE5_ALPHA_EXT 0x858D -#define GL_SOURCE6_ALPHA_EXT 0x858E -#define GL_SOURCE7_ALPHA_EXT 0x858F -#define GL_OPERAND0_RGB_EXT 0x8590 -#define GL_OPERAND1_RGB_EXT 0x8591 -#define GL_OPERAND2_RGB_EXT 0x8592 -#define GL_OPERAND3_RGB_EXT 0x8593 -#define GL_OPERAND4_RGB_EXT 0x8594 -#define GL_OPERAND5_RGB_EXT 0x8595 -#define GL_OPERAND6_RGB_EXT 0x8596 -#define GL_OPERAND7_RGB_EXT 0x8597 -#define GL_OPERAND0_ALPHA_EXT 0x8598 -#define GL_OPERAND1_ALPHA_EXT 0x8599 -#define GL_OPERAND2_ALPHA_EXT 0x859A -#define GL_OPERAND3_ALPHA_EXT 0x859B -#define GL_OPERAND4_ALPHA_EXT 0x859C -#define GL_OPERAND5_ALPHA_EXT 0x859D -#define GL_OPERAND6_ALPHA_EXT 0x859E -#define GL_OPERAND7_ALPHA_EXT 0x859F -#endif - -#ifndef GL_APPLE_specular_vector -#define GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 -#endif - -#ifndef GL_APPLE_transform_hint -#define GL_TRANSFORM_HINT_APPLE 0x85B1 -#endif - -#ifndef GL_SGIX_fog_scale -#define GL_FOG_SCALE_SGIX 0x81FC -#define GL_FOG_SCALE_VALUE_SGIX 0x81FD -#endif - -#ifndef GL_SUNX_constant_data -#define GL_UNPACK_CONSTANT_DATA_SUNX 0x81D5 -#define GL_TEXTURE_CONSTANT_DATA_SUNX 0x81D6 -#endif - -#ifndef GL_SUN_global_alpha -#define GL_GLOBAL_ALPHA_SUN 0x81D9 -#define GL_GLOBAL_ALPHA_FACTOR_SUN 0x81DA -#endif - -#ifndef GL_SUN_triangle_list -#define GL_RESTART_SUN 0x01 -#define GL_REPLACE_MIDDLE_SUN 0x02 -#define GL_REPLACE_OLDEST_SUN 0x03 -#define GL_TRIANGLE_LIST_SUN 0x81D7 -#define GL_REPLACEMENT_CODE_SUN 0x81D8 -#define GL_REPLACEMENT_CODE_ARRAY_SUN 0x85C0 -#define GL_REPLACEMENT_CODE_ARRAY_TYPE_SUN 0x85C1 -#define GL_REPLACEMENT_CODE_ARRAY_STRIDE_SUN 0x85C2 -#define GL_REPLACEMENT_CODE_ARRAY_POINTER_SUN 0x85C3 -#define GL_R1UI_V3F_SUN 0x85C4 -#define GL_R1UI_C4UB_V3F_SUN 0x85C5 -#define GL_R1UI_C3F_V3F_SUN 0x85C6 -#define GL_R1UI_N3F_V3F_SUN 0x85C7 -#define GL_R1UI_C4F_N3F_V3F_SUN 0x85C8 -#define GL_R1UI_T2F_V3F_SUN 0x85C9 -#define GL_R1UI_T2F_N3F_V3F_SUN 0x85CA -#define GL_R1UI_T2F_C4F_N3F_V3F_SUN 0x85CB -#endif - -#ifndef GL_SUN_vertex -#endif - -#ifndef GL_EXT_blend_func_separate -#define GL_BLEND_DST_RGB_EXT 0x80C8 -#define GL_BLEND_SRC_RGB_EXT 0x80C9 -#define GL_BLEND_DST_ALPHA_EXT 0x80CA -#define GL_BLEND_SRC_ALPHA_EXT 0x80CB -#endif - -#ifndef GL_INGR_color_clamp -#define GL_RED_MIN_CLAMP_INGR 0x8560 -#define GL_GREEN_MIN_CLAMP_INGR 0x8561 -#define GL_BLUE_MIN_CLAMP_INGR 0x8562 -#define GL_ALPHA_MIN_CLAMP_INGR 0x8563 -#define GL_RED_MAX_CLAMP_INGR 0x8564 -#define GL_GREEN_MAX_CLAMP_INGR 0x8565 -#define GL_BLUE_MAX_CLAMP_INGR 0x8566 -#define GL_ALPHA_MAX_CLAMP_INGR 0x8567 -#endif - -#ifndef GL_INGR_interlace_read -#define GL_INTERLACE_READ_INGR 0x8568 -#endif - -#ifndef GL_EXT_stencil_wrap -#define GL_INCR_WRAP_EXT 0x8507 -#define GL_DECR_WRAP_EXT 0x8508 -#endif - -#ifndef GL_EXT_422_pixels -#define GL_422_EXT 0x80CC -#define GL_422_REV_EXT 0x80CD -#define GL_422_AVERAGE_EXT 0x80CE -#define GL_422_REV_AVERAGE_EXT 0x80CF -#endif - -#ifndef GL_NV_texgen_reflection -#define GL_NORMAL_MAP_NV 0x8511 -#define GL_REFLECTION_MAP_NV 0x8512 -#endif - -#ifndef GL_EXT_texture_cube_map -#define GL_NORMAL_MAP_EXT 0x8511 -#define GL_REFLECTION_MAP_EXT 0x8512 -#define GL_TEXTURE_CUBE_MAP_EXT 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C -#endif - -#ifndef GL_SUN_convolution_border_modes -#define GL_WRAP_BORDER_SUN 0x81D4 -#endif - -#ifndef GL_EXT_texture_env_add -#endif - -#ifndef GL_EXT_texture_lod_bias -#define GL_MAX_TEXTURE_LOD_BIAS_EXT 0x84FD -#define GL_TEXTURE_FILTER_CONTROL_EXT 0x8500 -#define GL_TEXTURE_LOD_BIAS_EXT 0x8501 -#endif - -#ifndef GL_EXT_texture_filter_anisotropic -#define GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE -#define GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF -#endif - -#ifndef GL_EXT_vertex_weighting -#define GL_MODELVIEW0_STACK_DEPTH_EXT GL_MODELVIEW_STACK_DEPTH -#define GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 -#define GL_MODELVIEW0_MATRIX_EXT GL_MODELVIEW_MATRIX -#define GL_MODELVIEW_MATRIX1_EXT 0x8506 -#define GL_VERTEX_WEIGHTING_EXT 0x8509 -#define GL_MODELVIEW0_EXT GL_MODELVIEW -#define GL_MODELVIEW1_EXT 0x850A -#define GL_CURRENT_VERTEX_WEIGHT_EXT 0x850B -#define GL_VERTEX_WEIGHT_ARRAY_EXT 0x850C -#define GL_VERTEX_WEIGHT_ARRAY_SIZE_EXT 0x850D -#define GL_VERTEX_WEIGHT_ARRAY_TYPE_EXT 0x850E -#define GL_VERTEX_WEIGHT_ARRAY_STRIDE_EXT 0x850F -#define GL_VERTEX_WEIGHT_ARRAY_POINTER_EXT 0x8510 -#endif - -#ifndef GL_NV_light_max_exponent -#define GL_MAX_SHININESS_NV 0x8504 -#define GL_MAX_SPOT_EXPONENT_NV 0x8505 -#endif - -#ifndef GL_NV_vertex_array_range -#define GL_VERTEX_ARRAY_RANGE_NV 0x851D -#define GL_VERTEX_ARRAY_RANGE_LENGTH_NV 0x851E -#define GL_VERTEX_ARRAY_RANGE_VALID_NV 0x851F -#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_NV 0x8520 -#define GL_VERTEX_ARRAY_RANGE_POINTER_NV 0x8521 -#endif - -#ifndef GL_NV_vertex_array_range2 -#define GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 -#endif - -#ifndef GL_NV_register_combiners -#define GL_REGISTER_COMBINERS_NV 0x8522 -#define GL_VARIABLE_A_NV 0x8523 -#define GL_VARIABLE_B_NV 0x8524 -#define GL_VARIABLE_C_NV 0x8525 -#define GL_VARIABLE_D_NV 0x8526 -#define GL_VARIABLE_E_NV 0x8527 -#define GL_VARIABLE_F_NV 0x8528 -#define GL_VARIABLE_G_NV 0x8529 -#define GL_CONSTANT_COLOR0_NV 0x852A -#define GL_CONSTANT_COLOR1_NV 0x852B -#define GL_PRIMARY_COLOR_NV 0x852C -#define GL_SECONDARY_COLOR_NV 0x852D -#define GL_SPARE0_NV 0x852E -#define GL_SPARE1_NV 0x852F -#define GL_DISCARD_NV 0x8530 -#define GL_E_TIMES_F_NV 0x8531 -#define GL_SPARE0_PLUS_SECONDARY_COLOR_NV 0x8532 -#define GL_UNSIGNED_IDENTITY_NV 0x8536 -#define GL_UNSIGNED_INVERT_NV 0x8537 -#define GL_EXPAND_NORMAL_NV 0x8538 -#define GL_EXPAND_NEGATE_NV 0x8539 -#define GL_HALF_BIAS_NORMAL_NV 0x853A -#define GL_HALF_BIAS_NEGATE_NV 0x853B -#define GL_SIGNED_IDENTITY_NV 0x853C -#define GL_SIGNED_NEGATE_NV 0x853D -#define GL_SCALE_BY_TWO_NV 0x853E -#define GL_SCALE_BY_FOUR_NV 0x853F -#define GL_SCALE_BY_ONE_HALF_NV 0x8540 -#define GL_BIAS_BY_NEGATIVE_ONE_HALF_NV 0x8541 -#define GL_COMBINER_INPUT_NV 0x8542 -#define GL_COMBINER_MAPPING_NV 0x8543 -#define GL_COMBINER_COMPONENT_USAGE_NV 0x8544 -#define GL_COMBINER_AB_DOT_PRODUCT_NV 0x8545 -#define GL_COMBINER_CD_DOT_PRODUCT_NV 0x8546 -#define GL_COMBINER_MUX_SUM_NV 0x8547 -#define GL_COMBINER_SCALE_NV 0x8548 -#define GL_COMBINER_BIAS_NV 0x8549 -#define GL_COMBINER_AB_OUTPUT_NV 0x854A -#define GL_COMBINER_CD_OUTPUT_NV 0x854B -#define GL_COMBINER_SUM_OUTPUT_NV 0x854C -#define GL_MAX_GENERAL_COMBINERS_NV 0x854D -#define GL_NUM_GENERAL_COMBINERS_NV 0x854E -#define GL_COLOR_SUM_CLAMP_NV 0x854F -#define GL_COMBINER0_NV 0x8550 -#define GL_COMBINER1_NV 0x8551 -#define GL_COMBINER2_NV 0x8552 -#define GL_COMBINER3_NV 0x8553 -#define GL_COMBINER4_NV 0x8554 -#define GL_COMBINER5_NV 0x8555 -#define GL_COMBINER6_NV 0x8556 -#define GL_COMBINER7_NV 0x8557 -/* reuse GL_TEXTURE0_ARB */ -/* reuse GL_TEXTURE1_ARB */ -/* reuse GL_ZERO */ -/* reuse GL_NONE */ -/* reuse GL_FOG */ -#endif - -#ifndef GL_NV_fog_distance -#define GL_FOG_DISTANCE_MODE_NV 0x855A -#define GL_EYE_RADIAL_NV 0x855B -#define GL_EYE_PLANE_ABSOLUTE_NV 0x855C -/* reuse GL_EYE_PLANE */ -#endif - -#ifndef GL_NV_texgen_emboss -#define GL_EMBOSS_LIGHT_NV 0x855D -#define GL_EMBOSS_CONSTANT_NV 0x855E -#define GL_EMBOSS_MAP_NV 0x855F -#endif - -#ifndef GL_NV_blend_square -#endif - -#ifndef GL_NV_texture_env_combine4 -#define GL_COMBINE4_NV 0x8503 -#define GL_SOURCE3_RGB_NV 0x8583 -#define GL_SOURCE3_ALPHA_NV 0x858B -#define GL_OPERAND3_RGB_NV 0x8593 -#define GL_OPERAND3_ALPHA_NV 0x859B -#endif - - -#ifndef GL_MESA_resize_buffers -#endif - -#ifndef GL_MESA_window_pos -#endif - -#ifndef GL_EXT_texture_compression_s3tc -#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 -#define GL_COMPRESSED_RGBA_S3TC_DXT3_EXT 0x83F2 -#define GL_COMPRESSED_RGBA_S3TC_DXT5_EXT 0x83F3 -#endif - -#ifndef GL_IBM_cull_vertex -#define GL_CULL_VERTEX_IBM 103050 -#endif - -#ifndef GL_IBM_multimode_draw_arrays -#endif - -#ifndef GL_IBM_vertex_array_lists -#define GL_VERTEX_ARRAY_LIST_IBM 103070 -#define GL_NORMAL_ARRAY_LIST_IBM 103071 -#define GL_COLOR_ARRAY_LIST_IBM 103072 -#define GL_INDEX_ARRAY_LIST_IBM 103073 -#define GL_TEXTURE_COORD_ARRAY_LIST_IBM 103074 -#define GL_EDGE_FLAG_ARRAY_LIST_IBM 103075 -#define GL_FOG_COORDINATE_ARRAY_LIST_IBM 103076 -#define GL_SECONDARY_COLOR_ARRAY_LIST_IBM 103077 -#define GL_VERTEX_ARRAY_LIST_STRIDE_IBM 103080 -#define GL_NORMAL_ARRAY_LIST_STRIDE_IBM 103081 -#define GL_COLOR_ARRAY_LIST_STRIDE_IBM 103082 -#define GL_INDEX_ARRAY_LIST_STRIDE_IBM 103083 -#define GL_TEXTURE_COORD_ARRAY_LIST_STRIDE_IBM 103084 -#define GL_EDGE_FLAG_ARRAY_LIST_STRIDE_IBM 103085 -#define GL_FOG_COORDINATE_ARRAY_LIST_STRIDE_IBM 103086 -#define GL_SECONDARY_COLOR_ARRAY_LIST_STRIDE_IBM 103087 -#endif - -#ifndef GL_SGIX_subsample -#define GL_PACK_SUBSAMPLE_RATE_SGIX 0x85A0 -#define GL_UNPACK_SUBSAMPLE_RATE_SGIX 0x85A1 -#define GL_PIXEL_SUBSAMPLE_4444_SGIX 0x85A2 -#define GL_PIXEL_SUBSAMPLE_2424_SGIX 0x85A3 -#define GL_PIXEL_SUBSAMPLE_4242_SGIX 0x85A4 -#endif - -#ifndef GL_SGIX_ycrcb_subsample -#endif - -#ifndef GL_SGIX_ycrcba -#define GL_YCRCB_SGIX 0x8318 -#define GL_YCRCBA_SGIX 0x8319 -#endif - -#ifndef GL_SGI_depth_pass_instrument -#define GL_DEPTH_PASS_INSTRUMENT_SGIX 0x8310 -#define GL_DEPTH_PASS_INSTRUMENT_COUNTERS_SGIX 0x8311 -#define GL_DEPTH_PASS_INSTRUMENT_MAX_SGIX 0x8312 -#endif - -#ifndef GL_3DFX_texture_compression_FXT1 -#define GL_COMPRESSED_RGB_FXT1_3DFX 0x86B0 -#define GL_COMPRESSED_RGBA_FXT1_3DFX 0x86B1 -#endif - -#ifndef GL_3DFX_multisample -#define GL_MULTISAMPLE_3DFX 0x86B2 -#define GL_SAMPLE_BUFFERS_3DFX 0x86B3 -#define GL_SAMPLES_3DFX 0x86B4 -#define GL_MULTISAMPLE_BIT_3DFX 0x20000000 -#endif - -#ifndef GL_3DFX_tbuffer -#endif - -#ifndef GL_EXT_multisample -#define GL_MULTISAMPLE_EXT 0x809D -#define GL_SAMPLE_ALPHA_TO_MASK_EXT 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_EXT 0x809F -#define GL_SAMPLE_MASK_EXT 0x80A0 -#define GL_1PASS_EXT 0x80A1 -#define GL_2PASS_0_EXT 0x80A2 -#define GL_2PASS_1_EXT 0x80A3 -#define GL_4PASS_0_EXT 0x80A4 -#define GL_4PASS_1_EXT 0x80A5 -#define GL_4PASS_2_EXT 0x80A6 -#define GL_4PASS_3_EXT 0x80A7 -#define GL_SAMPLE_BUFFERS_EXT 0x80A8 -#define GL_SAMPLES_EXT 0x80A9 -#define GL_SAMPLE_MASK_VALUE_EXT 0x80AA -#define GL_SAMPLE_MASK_INVERT_EXT 0x80AB -#define GL_SAMPLE_PATTERN_EXT 0x80AC -#endif - -#ifndef GL_SGIX_vertex_preclip -#define GL_VERTEX_PRECLIP_SGIX 0x83EE -#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF -#endif - -#ifndef GL_SGIX_convolution_accuracy -#define GL_CONVOLUTION_HINT_SGIX 0x8316 -#endif - -#ifndef GL_SGIX_resample -#define GL_PACK_RESAMPLE_SGIX 0x842C -#define GL_UNPACK_RESAMPLE_SGIX 0x842D -#define GL_RESAMPLE_REPLICATE_SGIX 0x842E -#define GL_RESAMPLE_ZERO_FILL_SGIX 0x842F -#define GL_RESAMPLE_DECIMATE_SGIX 0x8430 -#endif - -#ifndef GL_SGIS_point_line_texgen -#define GL_EYE_DISTANCE_TO_POINT_SGIS 0x81F0 -#define GL_OBJECT_DISTANCE_TO_POINT_SGIS 0x81F1 -#define GL_EYE_DISTANCE_TO_LINE_SGIS 0x81F2 -#define GL_OBJECT_DISTANCE_TO_LINE_SGIS 0x81F3 -#define GL_EYE_POINT_SGIS 0x81F4 -#define GL_OBJECT_POINT_SGIS 0x81F5 -#define GL_EYE_LINE_SGIS 0x81F6 -#define GL_OBJECT_LINE_SGIS 0x81F7 -#endif - -#ifndef GL_SGIS_texture_color_mask -#define GL_TEXTURE_COLOR_WRITEMASK_SGIS 0x81EF -#endif - - -/*************************************************************/ - -#ifndef GL_VERSION_1_2 -#define GL_VERSION_1_2 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glBlendColor (GLclampf, GLclampf, GLclampf, GLclampf); -extern void APIENTRY glBlendEquation (GLenum); -extern void APIENTRY glDrawRangeElements (GLenum, GLuint, GLuint, GLsizei, GLenum, const GLvoid *); -extern void APIENTRY glColorTable (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glColorTableParameterfv (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glColorTableParameteriv (GLenum, GLenum, const GLint *); -extern void APIENTRY glCopyColorTable (GLenum, GLenum, GLint, GLint, GLsizei); -extern void APIENTRY glGetColorTable (GLenum, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetColorTableParameterfv (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetColorTableParameteriv (GLenum, GLenum, GLint *); -extern void APIENTRY glColorSubTable (GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glCopyColorSubTable (GLenum, GLsizei, GLint, GLint, GLsizei); -extern void APIENTRY glConvolutionFilter1D (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glConvolutionFilter2D (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glConvolutionParameterf (GLenum, GLenum, GLfloat); -extern void APIENTRY glConvolutionParameterfv (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glConvolutionParameteri (GLenum, GLenum, GLint); -extern void APIENTRY glConvolutionParameteriv (GLenum, GLenum, const GLint *); -extern void APIENTRY glCopyConvolutionFilter1D (GLenum, GLenum, GLint, GLint, GLsizei); -extern void APIENTRY glCopyConvolutionFilter2D (GLenum, GLenum, GLint, GLint, GLsizei, GLsizei); -extern void APIENTRY glGetConvolutionFilter (GLenum, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetConvolutionParameterfv (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetConvolutionParameteriv (GLenum, GLenum, GLint *); -extern void APIENTRY glGetSeparableFilter (GLenum, GLenum, GLenum, GLvoid *, GLvoid *, GLvoid *); -extern void APIENTRY glSeparableFilter2D (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *, const GLvoid *); -extern void APIENTRY glGetHistogram (GLenum, GLboolean, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetHistogramParameterfv (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetHistogramParameteriv (GLenum, GLenum, GLint *); -extern void APIENTRY glGetMinmax (GLenum, GLboolean, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetMinmaxParameterfv (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetMinmaxParameteriv (GLenum, GLenum, GLint *); -extern void APIENTRY glHistogram (GLenum, GLsizei, GLenum, GLboolean); -extern void APIENTRY glMinmax (GLenum, GLenum, GLboolean); -extern void APIENTRY glResetHistogram (GLenum); -extern void APIENTRY glResetMinmax (GLenum); -extern void APIENTRY glTexImage3D (GLenum, GLint, GLint, GLsizei, GLsizei, GLsizei, GLint, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glTexSubImage3D (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glCopyTexSubImage3D (GLenum, GLint, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLBLENDCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -typedef void (APIENTRY * PFNGLBLENDEQUATIONPROC) (GLenum mode); -typedef void (APIENTRY * PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); -typedef void (APIENTRY * PFNGLCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); -typedef void (APIENTRY * PFNGLCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLCOPYCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOPYCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); -typedef void (APIENTRY * PFNGLCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); -typedef void (APIENTRY * PFNGLCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat params); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERIPROC) (GLenum target, GLenum pname, GLint params); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (APIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (APIENTRY * PFNGLGETCONVOLUTIONFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); -typedef void (APIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETSEPARABLEFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); -typedef void (APIENTRY * PFNGLSEPARABLEFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); -typedef void (APIENTRY * PFNGLGETHISTOGRAMPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (APIENTRY * PFNGLGETHISTOGRAMPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETHISTOGRAMPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETMINMAXPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (APIENTRY * PFNGLGETMINMAXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETMINMAXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLHISTOGRAMPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); -typedef void (APIENTRY * PFNGLMINMAXPROC) (GLenum target, GLenum internalformat, GLboolean sink); -typedef void (APIENTRY * PFNGLRESETHISTOGRAMPROC) (GLenum target); -typedef void (APIENTRY * PFNGLRESETMINMAXPROC) (GLenum target); -typedef void (APIENTRY * PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (APIENTRY * PFNGLTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (APIENTRY * PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -#endif - -#ifndef GL_ARB_multitexture -#define GL_ARB_multitexture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glActiveTextureARB (GLenum); -extern void APIENTRY glClientActiveTextureARB (GLenum); -extern void APIENTRY glMultiTexCoord1dARB (GLenum, GLdouble); -extern void APIENTRY glMultiTexCoord1dvARB (GLenum, const GLdouble *); -extern void APIENTRY glMultiTexCoord1fARB (GLenum, GLfloat); -extern void APIENTRY glMultiTexCoord1fvARB (GLenum, const GLfloat *); -extern void APIENTRY glMultiTexCoord1iARB (GLenum, GLint); -extern void APIENTRY glMultiTexCoord1ivARB (GLenum, const GLint *); -extern void APIENTRY glMultiTexCoord1sARB (GLenum, GLshort); -extern void APIENTRY glMultiTexCoord1svARB (GLenum, const GLshort *); -extern void APIENTRY glMultiTexCoord2dARB (GLenum, GLdouble, GLdouble); -extern void APIENTRY glMultiTexCoord2dvARB (GLenum, const GLdouble *); -extern void APIENTRY glMultiTexCoord2fARB (GLenum, GLfloat, GLfloat); -extern void APIENTRY glMultiTexCoord2fvARB (GLenum, const GLfloat *); -extern void APIENTRY glMultiTexCoord2iARB (GLenum, GLint, GLint); -extern void APIENTRY glMultiTexCoord2ivARB (GLenum, const GLint *); -extern void APIENTRY glMultiTexCoord2sARB (GLenum, GLshort, GLshort); -extern void APIENTRY glMultiTexCoord2svARB (GLenum, const GLshort *); -extern void APIENTRY glMultiTexCoord3dARB (GLenum, GLdouble, GLdouble, GLdouble); -extern void APIENTRY glMultiTexCoord3dvARB (GLenum, const GLdouble *); -extern void APIENTRY glMultiTexCoord3fARB (GLenum, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glMultiTexCoord3fvARB (GLenum, const GLfloat *); -extern void APIENTRY glMultiTexCoord3iARB (GLenum, GLint, GLint, GLint); -extern void APIENTRY glMultiTexCoord3ivARB (GLenum, const GLint *); -extern void APIENTRY glMultiTexCoord3sARB (GLenum, GLshort, GLshort, GLshort); -extern void APIENTRY glMultiTexCoord3svARB (GLenum, const GLshort *); -extern void APIENTRY glMultiTexCoord4dARB (GLenum, GLdouble, GLdouble, GLdouble, GLdouble); -extern void APIENTRY glMultiTexCoord4dvARB (GLenum, const GLdouble *); -extern void APIENTRY glMultiTexCoord4fARB (GLenum, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glMultiTexCoord4fvARB (GLenum, const GLfloat *); -extern void APIENTRY glMultiTexCoord4iARB (GLenum, GLint, GLint, GLint, GLint); -extern void APIENTRY glMultiTexCoord4ivARB (GLenum, const GLint *); -extern void APIENTRY glMultiTexCoord4sARB (GLenum, GLshort, GLshort, GLshort, GLshort); -extern void APIENTRY glMultiTexCoord4svARB (GLenum, const GLshort *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLACTIVETEXTUREARBPROC) (GLenum texture); -typedef void (APIENTRY * PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); -typedef void (APIENTRY * PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); -typedef void (APIENTRY * PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); -typedef void (APIENTRY * PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); -typedef void (APIENTRY * PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); -#endif - -#ifndef GL_ARB_transpose_matrix -#define GL_ARB_transpose_matrix 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glLoadTransposeMatrixfARB (const GLfloat *); -extern void APIENTRY glLoadTransposeMatrixdARB (const GLdouble *); -extern void APIENTRY glMultTransposeMatrixfARB (const GLfloat *); -extern void APIENTRY glMultTransposeMatrixdARB (const GLdouble *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLLOADTRANSPOSEMATRIXFARBPROC) (const GLfloat *m); -typedef void (APIENTRY * PFNGLLOADTRANSPOSEMATRIXDARBPROC) (const GLdouble *m); -typedef void (APIENTRY * PFNGLMULTTRANSPOSEMATRIXFARBPROC) (const GLfloat *m); -typedef void (APIENTRY * PFNGLMULTTRANSPOSEMATRIXDARBPROC) (const GLdouble *m); -#endif - -#ifndef GL_ARB_multisample -#define GL_ARB_multisample 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glSampleCoverageARB (GLclampf, GLboolean); -extern void APIENTRY glSamplePassARB (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLSAMPLECOVERAGEARBPROC) (GLclampf value, GLboolean invert); -typedef void (APIENTRY * PFNGLSAMPLEPASSARBPROC) (GLenum pass); -#endif - -#ifndef GL_ARB_texture_env_add -#define GL_ARB_texture_env_add 1 -#endif - -#ifndef GL_ARB_texture_cube_map -#define GL_ARB_texture_cube_map 1 -#endif - -#ifndef GL_ARB_texture_compression -#define GL_ARB_texture_compression 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glCompressedTexImage3DARB (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLint, GLsizei, const GLvoid *); -extern void APIENTRY glCompressedTexImage2DARB (GLenum, GLint, GLenum, GLsizei, GLsizei, GLint, GLsizei, const GLvoid *); -extern void APIENTRY glCompressedTexImage1DARB (GLenum, GLint, GLenum, GLsizei, GLint, GLsizei, const GLvoid *); -extern void APIENTRY glCompressedTexSubImage3DARB (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLsizei, const GLvoid *); -extern void APIENTRY glCompressedTexSubImage2DARB (GLenum, GLint, GLint, GLint, GLsizei, GLsizei, GLenum, GLsizei, const GLvoid *); -extern void APIENTRY glCompressedTexSubImage1DARB (GLenum, GLint, GLint, GLsizei, GLenum, GLsizei, const GLvoid *); -extern void APIENTRY glGetCompressedTexImageARB (GLenum, GLint, void *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (APIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint level, void *img); -#endif - -#ifndef GL_EXT_abgr -#define GL_EXT_abgr 1 -#endif - -#ifndef GL_EXT_blend_color -#define GL_EXT_blend_color 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glBlendColorEXT (GLclampf, GLclampf, GLclampf, GLclampf); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLBLENDCOLOREXTPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -#endif - -#ifndef GL_EXT_polygon_offset -#define GL_EXT_polygon_offset 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glPolygonOffsetEXT (GLfloat, GLfloat); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLPOLYGONOFFSETEXTPROC) (GLfloat factor, GLfloat bias); -#endif - -#ifndef GL_EXT_texture -#define GL_EXT_texture 1 -#endif - -#ifndef GL_EXT_texture3D -#define GL_EXT_texture3D 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTexImage3DEXT (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLint, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glTexSubImage3DEXT (GLenum, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTEXIMAGE3DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (APIENTRY * PFNGLTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); -#endif - -#ifndef GL_SGIS_texture_filter4 -#define GL_SGIS_texture_filter4 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glGetTexFilterFuncSGIS (GLenum, GLenum, GLfloat *); -extern void APIENTRY glTexFilterFuncSGIS (GLenum, GLenum, GLsizei, const GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLGETTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLfloat *weights); -typedef void (APIENTRY * PFNGLTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLsizei n, const GLfloat *weights); -#endif - -#ifndef GL_EXT_subtexture -#define GL_EXT_subtexture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTexSubImage1DEXT (GLenum, GLint, GLint, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glTexSubImage2DEXT (GLenum, GLint, GLint, GLint, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (APIENTRY * PFNGLTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -#endif - -#ifndef GL_EXT_copy_texture -#define GL_EXT_copy_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glCopyTexImage1DEXT (GLenum, GLint, GLenum, GLint, GLint, GLsizei, GLint); -extern void APIENTRY glCopyTexImage2DEXT (GLenum, GLint, GLenum, GLint, GLint, GLsizei, GLsizei, GLint); -extern void APIENTRY glCopyTexSubImage1DEXT (GLenum, GLint, GLint, GLint, GLint, GLsizei); -extern void APIENTRY glCopyTexSubImage2DEXT (GLenum, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei); -extern void APIENTRY glCopyTexSubImage3DEXT (GLenum, GLint, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOPYTEXIMAGE1DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (APIENTRY * PFNGLCOPYTEXIMAGE2DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (APIENTRY * PFNGLCOPYTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (APIENTRY * PFNGLCOPYTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (APIENTRY * PFNGLCOPYTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -#endif - -#ifndef GL_EXT_histogram -#define GL_EXT_histogram 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glGetHistogramEXT (GLenum, GLboolean, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetHistogramParameterfvEXT (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetHistogramParameterivEXT (GLenum, GLenum, GLint *); -extern void APIENTRY glGetMinmaxEXT (GLenum, GLboolean, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetMinmaxParameterfvEXT (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetMinmaxParameterivEXT (GLenum, GLenum, GLint *); -extern void APIENTRY glHistogramEXT (GLenum, GLsizei, GLenum, GLboolean); -extern void APIENTRY glMinmaxEXT (GLenum, GLenum, GLboolean); -extern void APIENTRY glResetHistogramEXT (GLenum); -extern void APIENTRY glResetMinmaxEXT (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLGETHISTOGRAMEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (APIENTRY * PFNGLGETHISTOGRAMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETHISTOGRAMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETMINMAXEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (APIENTRY * PFNGLGETMINMAXPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETMINMAXPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLHISTOGRAMEXTPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); -typedef void (APIENTRY * PFNGLMINMAXEXTPROC) (GLenum target, GLenum internalformat, GLboolean sink); -typedef void (APIENTRY * PFNGLRESETHISTOGRAMEXTPROC) (GLenum target); -typedef void (APIENTRY * PFNGLRESETMINMAXEXTPROC) (GLenum target); -#endif - -#ifndef GL_EXT_convolution -#define GL_EXT_convolution 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glConvolutionFilter1DEXT (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glConvolutionFilter2DEXT (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glConvolutionParameterfEXT (GLenum, GLenum, GLfloat); -extern void APIENTRY glConvolutionParameterfvEXT (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glConvolutionParameteriEXT (GLenum, GLenum, GLint); -extern void APIENTRY glConvolutionParameterivEXT (GLenum, GLenum, const GLint *); -extern void APIENTRY glCopyConvolutionFilter1DEXT (GLenum, GLenum, GLint, GLint, GLsizei); -extern void APIENTRY glCopyConvolutionFilter2DEXT (GLenum, GLenum, GLint, GLint, GLsizei, GLsizei); -extern void APIENTRY glGetConvolutionFilterEXT (GLenum, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetConvolutionParameterfvEXT (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetConvolutionParameterivEXT (GLenum, GLenum, GLint *); -extern void APIENTRY glGetSeparableFilterEXT (GLenum, GLenum, GLenum, GLvoid *, GLvoid *, GLvoid *); -extern void APIENTRY glSeparableFilter2DEXT (GLenum, GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); -typedef void (APIENTRY * PFNGLCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat params); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint params); -typedef void (APIENTRY * PFNGLCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (APIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (APIENTRY * PFNGLGETCONVOLUTIONFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); -typedef void (APIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETSEPARABLEFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); -typedef void (APIENTRY * PFNGLSEPARABLEFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); -#endif - -#ifndef GL_EXT_color_matrix -#define GL_EXT_color_matrix 1 -#endif - -#ifndef GL_SGI_color_table -#define GL_SGI_color_table 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glColorTableSGI (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glColorTableParameterfvSGI (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glColorTableParameterivSGI (GLenum, GLenum, const GLint *); -extern void APIENTRY glCopyColorTableSGI (GLenum, GLenum, GLint, GLint, GLsizei); -extern void APIENTRY glGetColorTableSGI (GLenum, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetColorTableParameterfvSGI (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetColorTableParameterivSGI (GLenum, GLenum, GLint *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); -typedef void (APIENTRY * PFNGLCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLCOPYCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (APIENTRY * PFNGLGETCOLORTABLESGIPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, GLint *params); -#endif - -#ifndef GL_SGIX_pixel_texture -#define GL_SGIX_pixel_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glPixelTexGenSGIX (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLPIXELTEXGENSGIXPROC) (GLenum mode); -#endif - -#ifndef GL_SGIS_pixel_texture -#define GL_SGIS_pixel_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glPixelTexGenParameteriSGIS (GLenum, GLint); -extern void APIENTRY glPixelTexGenParameterivSGIS (GLenum, const GLint *); -extern void APIENTRY glPixelTexGenParameterfSGIS (GLenum, GLfloat); -extern void APIENTRY glPixelTexGenParameterfvSGIS (GLenum, const GLfloat *); -extern void APIENTRY glGetPixelTexGenParameterivSGIS (GLenum, GLint *); -extern void APIENTRY glGetPixelTexGenParameterfvSGIS (GLenum, GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLPIXELTEXGENPARAMETERISGISPROC) (GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLPIXELTEXGENPARAMETERIVSGISPROC) (GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLPIXELTEXGENPARAMETERFSGISPROC) (GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLPIXELTEXGENPARAMETERFVSGISPROC) (GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLGETPIXELTEXGENPARAMETERIVSGISPROC) (GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETPIXELTEXGENPARAMETERFVSGISPROC) (GLenum pname, GLfloat *params); -#endif - -#ifndef GL_SGIS_texture4D -#define GL_SGIS_texture4D 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTexImage4DSGIS (GLenum, GLint, GLenum, GLsizei, GLsizei, GLsizei, GLsizei, GLint, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glTexSubImage4DSGIS (GLenum, GLint, GLint, GLint, GLint, GLint, GLsizei, GLsizei, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTEXIMAGE4DSGISPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei size4d, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (APIENTRY * PFNGLTEXSUBIMAGE4DSGISPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint woffset, GLsizei width, GLsizei height, GLsizei depth, GLsizei size4d, GLenum format, GLenum type, const GLvoid *pixels); -#endif - -#ifndef GL_SGI_texture_color_table -#define GL_SGI_texture_color_table 1 -#endif - -#ifndef GL_EXT_cmyka -#define GL_EXT_cmyka 1 -#endif - -#ifndef GL_EXT_texture_object -#define GL_EXT_texture_object 1 -#ifdef GL_GLEXT_PROTOTYPES -extern GLboolean APIENTRY glAreTexturesResidentEXT (GLsizei, const GLuint *, GLboolean *); -extern void APIENTRY glBindTextureEXT (GLenum, GLuint); -extern void APIENTRY glDeleteTexturesEXT (GLsizei, const GLuint *); -extern void APIENTRY glGenTexturesEXT (GLsizei, GLuint *); -extern GLboolean APIENTRY glIsTextureEXT (GLuint); -extern void APIENTRY glPrioritizeTexturesEXT (GLsizei, const GLuint *, const GLclampf *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef GLboolean (APIENTRY * PFNGLARETEXTURESRESIDENTEXTPROC) (GLsizei n, const GLuint *textures, GLboolean *residences); -typedef void (APIENTRY * PFNGLBINDTEXTUREEXTPROC) (GLenum target, GLuint texture); -typedef void (APIENTRY * PFNGLDELETETEXTURESEXTPROC) (GLsizei n, const GLuint *textures); -typedef void (APIENTRY * PFNGLGENTEXTURESEXTPROC) (GLsizei n, GLuint *textures); -typedef GLboolean (APIENTRY * PFNGLISTEXTUREEXTPROC) (GLuint texture); -typedef void (APIENTRY * PFNGLPRIORITIZETEXTURESEXTPROC) (GLsizei n, const GLuint *textures, const GLclampf *priorities); -#endif - -#ifndef GL_SGIS_detail_texture -#define GL_SGIS_detail_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glDetailTexFuncSGIS (GLenum, GLsizei, const GLfloat *); -extern void APIENTRY glGetDetailTexFuncSGIS (GLenum, GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLDETAILTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat *points); -typedef void (APIENTRY * PFNGLGETDETAILTEXFUNCSGISPROC) (GLenum target, GLfloat *points); -#endif - -#ifndef GL_SGIS_sharpen_texture -#define GL_SGIS_sharpen_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glSharpenTexFuncSGIS (GLenum, GLsizei, const GLfloat *); -extern void APIENTRY glGetSharpenTexFuncSGIS (GLenum, GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLSHARPENTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat *points); -typedef void (APIENTRY * PFNGLGETSHARPENTEXFUNCSGISPROC) (GLenum target, GLfloat *points); -#endif - -#ifndef GL_EXT_packed_pixels -#define GL_EXT_packed_pixels 1 -#endif - -#ifndef GL_SGIS_texture_lod -#define GL_SGIS_texture_lod 1 -#endif - -#ifndef GL_SGIS_multisample -#define GL_SGIS_multisample 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glSampleMaskSGIS (GLclampf, GLboolean); -extern void APIENTRY glSamplePatternSGIS (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLSAMPLEMASKSGISPROC) (GLclampf value, GLboolean invert); -typedef void (APIENTRY * PFNGLSAMPLEPATTERNSGISPROC) (GLenum pattern); -#endif - -#ifndef GL_EXT_rescale_normal -#define GL_EXT_rescale_normal 1 -#endif - -#ifndef GL_EXT_vertex_array -#define GL_EXT_vertex_array 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glArrayElementEXT (GLint); -extern void APIENTRY glColorPointerEXT (GLint, GLenum, GLsizei, GLsizei, const GLvoid *); -extern void APIENTRY glDrawArraysEXT (GLenum, GLint, GLsizei); -extern void APIENTRY glEdgeFlagPointerEXT (GLsizei, GLsizei, const GLboolean *); -extern void APIENTRY glGetPointervEXT (GLenum, GLvoid* *); -extern void APIENTRY glIndexPointerEXT (GLenum, GLsizei, GLsizei, const GLvoid *); -extern void APIENTRY glNormalPointerEXT (GLenum, GLsizei, GLsizei, const GLvoid *); -extern void APIENTRY glTexCoordPointerEXT (GLint, GLenum, GLsizei, GLsizei, const GLvoid *); -extern void APIENTRY glVertexPointerEXT (GLint, GLenum, GLsizei, GLsizei, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLARRAYELEMENTEXTPROC) (GLint i); -typedef void (APIENTRY * PFNGLCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (APIENTRY * PFNGLDRAWARRAYSEXTPROC) (GLenum mode, GLint first, GLsizei count); -typedef void (APIENTRY * PFNGLEDGEFLAGPOINTEREXTPROC) (GLsizei stride, GLsizei count, const GLboolean *pointer); -typedef void (APIENTRY * PFNGLGETPOINTERVEXTPROC) (GLenum pname, GLvoid* *params); -typedef void (APIENTRY * PFNGLINDEXPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (APIENTRY * PFNGLNORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (APIENTRY * PFNGLTEXCOORDPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (APIENTRY * PFNGLVERTEXPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -#endif - -#ifndef GL_EXT_misc_attribute -#define GL_EXT_misc_attribute 1 -#endif - -#ifndef GL_SGIS_generate_mipmap -#define GL_SGIS_generate_mipmap 1 -#endif - -#ifndef GL_SGIX_clipmap -#define GL_SGIX_clipmap 1 -#endif - -#ifndef GL_SGIX_shadow -#define GL_SGIX_shadow 1 -#endif - -#ifndef GL_SGIS_texture_edge_clamp -#define GL_SGIS_texture_edge_clamp 1 -#endif - -#ifndef GL_SGIS_texture_border_clamp -#define GL_SGIS_texture_border_clamp 1 -#endif - -#ifndef GL_EXT_blend_minmax -#define GL_EXT_blend_minmax 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glBlendEquationEXT (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLBLENDEQUATIONEXTPROC) (GLenum mode); -#endif - -#ifndef GL_EXT_blend_subtract -#define GL_EXT_blend_subtract 1 -#endif - -#ifndef GL_EXT_blend_logic_op -#define GL_EXT_blend_logic_op 1 -#endif - -#ifndef GL_SGIX_interlace -#define GL_SGIX_interlace 1 -#endif - -#ifndef GL_SGIX_pixel_tiles -#define GL_SGIX_pixel_tiles 1 -#endif - -#ifndef GL_SGIX_texture_select -#define GL_SGIX_texture_select 1 -#endif - -#ifndef GL_SGIX_sprite -#define GL_SGIX_sprite 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glSpriteParameterfSGIX (GLenum, GLfloat); -extern void APIENTRY glSpriteParameterfvSGIX (GLenum, const GLfloat *); -extern void APIENTRY glSpriteParameteriSGIX (GLenum, GLint); -extern void APIENTRY glSpriteParameterivSGIX (GLenum, const GLint *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLSPRITEPARAMETERFSGIXPROC) (GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLSPRITEPARAMETERFVSGIXPROC) (GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLSPRITEPARAMETERISGIXPROC) (GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLSPRITEPARAMETERIVSGIXPROC) (GLenum pname, const GLint *params); -#endif - -#ifndef GL_SGIX_texture_multi_buffer -#define GL_SGIX_texture_multi_buffer 1 -#endif - -#ifndef GL_EXT_point_parameters -#define GL_EXT_point_parameters 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glPointParameterfEXT (GLenum, GLfloat); -extern void APIENTRY glPointParameterfvEXT (GLenum, const GLfloat *); -extern void APIENTRY glPointParameterfSGIS (GLenum, GLfloat); -extern void APIENTRY glPointParameterfvSGIS (GLenum, const GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLPOINTPARAMETERFEXTPROC) (GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLPOINTPARAMETERFVEXTPROC) (GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLPOINTPARAMETERFSGISPROC) (GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLPOINTPARAMETERFVSGISPROC) (GLenum pname, const GLfloat *params); -#endif - -#ifndef GL_SGIX_instruments -#define GL_SGIX_instruments 1 -#ifdef GL_GLEXT_PROTOTYPES -extern GLint APIENTRY glGetInstrumentsSGIX (void); -extern void APIENTRY glInstrumentsBufferSGIX (GLsizei, GLint *); -extern GLint APIENTRY glPollInstrumentsSGIX (GLint *); -extern void APIENTRY glReadInstrumentsSGIX (GLint); -extern void APIENTRY glStartInstrumentsSGIX (void); -extern void APIENTRY glStopInstrumentsSGIX (GLint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef GLint (APIENTRY * PFNGLGETINSTRUMENTSSGIXPROC) (void); -typedef void (APIENTRY * PFNGLINSTRUMENTSBUFFERSGIXPROC) (GLsizei size, GLint *buffer); -typedef GLint (APIENTRY * PFNGLPOLLINSTRUMENTSSGIXPROC) (GLint *marker_p); -typedef void (APIENTRY * PFNGLREADINSTRUMENTSSGIXPROC) (GLint marker); -typedef void (APIENTRY * PFNGLSTARTINSTRUMENTSSGIXPROC) (void); -typedef void (APIENTRY * PFNGLSTOPINSTRUMENTSSGIXPROC) (GLint marker); -#endif - -#ifndef GL_SGIX_texture_scale_bias -#define GL_SGIX_texture_scale_bias 1 -#endif - -#ifndef GL_SGIX_framezoom -#define GL_SGIX_framezoom 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFrameZoomSGIX (GLint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFRAMEZOOMSGIXPROC) (GLint factor); -#endif - -#ifndef GL_SGIX_tag_sample_buffer -#define GL_SGIX_tag_sample_buffer 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTagSampleBufferSGIX (void); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTAGSAMPLEBUFFERSGIXPROC) (void); -#endif - -#ifndef GL_SGIX_reference_plane -#define GL_SGIX_reference_plane 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glReferencePlaneSGIX (const GLdouble *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLREFERENCEPLANESGIXPROC) (const GLdouble *equation); -#endif - -#ifndef GL_SGIX_flush_raster -#define GL_SGIX_flush_raster 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFlushRasterSGIX (void); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFLUSHRASTERSGIXPROC) (void); -#endif - -#ifndef GL_SGIX_depth_texture -#define GL_SGIX_depth_texture 1 -#endif - -#ifndef GL_SGIS_fog_function -#define GL_SGIS_fog_function 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFogFuncSGIS (GLsizei, const GLfloat *); -extern void APIENTRY glGetFogFuncSGIS (const GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFOGFUNCSGISPROC) (GLsizei n, const GLfloat *points); -typedef void (APIENTRY * PFNGLGETFOGFUNCSGISPROC) (const GLfloat *points); -#endif - -#ifndef GL_SGIX_fog_offset -#define GL_SGIX_fog_offset 1 -#endif - -#ifndef GL_HP_image_transform -#define GL_HP_image_transform 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glImageTransformParameteriHP (GLenum, GLenum, GLint); -extern void APIENTRY glImageTransformParameterfHP (GLenum, GLenum, GLfloat); -extern void APIENTRY glImageTransformParameterivHP (GLenum, GLenum, const GLint *); -extern void APIENTRY glImageTransformParameterfvHP (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glGetImageTransformParameterivHP (GLenum, GLenum, GLint *); -extern void APIENTRY glGetImageTransformParameterfvHP (GLenum, GLenum, GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLIMAGETRANSFORMPARAMETERIHPPROC) (GLenum target, GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLIMAGETRANSFORMPARAMETERFHPPROC) (GLenum target, GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, GLfloat *params); -#endif - -#ifndef GL_HP_convolution_border_modes -#define GL_HP_convolution_border_modes 1 -#endif - -#ifndef GL_SGIX_texture_add_env -#define GL_SGIX_texture_add_env 1 -#endif - -#ifndef GL_EXT_color_subtable -#define GL_EXT_color_subtable 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glColorSubTableEXT (GLenum, GLsizei, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glCopyColorSubTableEXT (GLenum, GLsizei, GLint, GLint, GLsizei); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); -typedef void (APIENTRY * PFNGLCOPYCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); -#endif - -#ifndef GL_PGI_vertex_hints -#define GL_PGI_vertex_hints 1 -#endif - -#ifndef GL_PGI_misc_hints -#define GL_PGI_misc_hints 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glHintPGI (GLenum, GLint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLHINTPGIPROC) (GLenum target, GLint mode); -#endif - -#ifndef GL_EXT_paletted_texture -#define GL_EXT_paletted_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glColorTableEXT (GLenum, GLenum, GLsizei, GLenum, GLenum, const GLvoid *); -extern void APIENTRY glGetColorTableEXT (GLenum, GLenum, GLenum, GLvoid *); -extern void APIENTRY glGetColorTableParameterivEXT (GLenum, GLenum, GLint *); -extern void APIENTRY glGetColorTableParameterfvEXT (GLenum, GLenum, GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOLORTABLEEXTPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); -typedef void (APIENTRY * PFNGLGETCOLORTABLEEXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *data); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETCOLORTABLEPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); -#endif - -#ifndef GL_EXT_clip_volume_hint -#define GL_EXT_clip_volume_hint 1 -#endif - -#ifndef GL_SGIX_list_priority -#define GL_SGIX_list_priority 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glGetListParameterfvSGIX (GLuint, GLenum, GLfloat *); -extern void APIENTRY glGetListParameterivSGIX (GLuint, GLenum, GLint *); -extern void APIENTRY glListParameterfSGIX (GLuint, GLenum, GLfloat); -extern void APIENTRY glListParameterfvSGIX (GLuint, GLenum, const GLfloat *); -extern void APIENTRY glListParameteriSGIX (GLuint, GLenum, GLint); -extern void APIENTRY glListParameterivSGIX (GLuint, GLenum, const GLint *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLGETLISTPARAMETERFVSGIXPROC) (GLuint list, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETLISTPARAMETERIVSGIXPROC) (GLuint list, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLLISTPARAMETERFSGIXPROC) (GLuint list, GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLLISTPARAMETERFVSGIXPROC) (GLuint list, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLLISTPARAMETERISGIXPROC) (GLuint list, GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLLISTPARAMETERIVSGIXPROC) (GLuint list, GLenum pname, const GLint *params); -#endif - -#ifndef GL_SGIX_ir_instrument1 -#define GL_SGIX_ir_instrument1 1 -#endif - -#ifndef GL_SGIX_calligraphic_fragment -#define GL_SGIX_calligraphic_fragment 1 -#endif - -#ifndef GL_SGIX_texture_lod_bias -#define GL_SGIX_texture_lod_bias 1 -#endif - -#ifndef GL_SGIX_shadow_ambient -#define GL_SGIX_shadow_ambient 1 -#endif - -#ifndef GL_EXT_index_texture -#define GL_EXT_index_texture 1 -#endif - -#ifndef GL_EXT_index_material -#define GL_EXT_index_material 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glIndexMaterialEXT (GLenum, GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLINDEXMATERIALEXTPROC) (GLenum face, GLenum mode); -#endif - -#ifndef GL_EXT_index_func -#define GL_EXT_index_func 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glIndexFuncEXT (GLenum, GLclampf); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLINDEXFUNCEXTPROC) (GLenum func, GLclampf ref); -#endif - -#ifndef GL_EXT_index_array_formats -#define GL_EXT_index_array_formats 1 -#endif - -#ifndef GL_EXT_compiled_vertex_array -#define GL_EXT_compiled_vertex_array 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glLockArraysEXT (GLint, GLsizei); -extern void APIENTRY glUnlockArraysEXT (void); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLLOCKARRAYSEXTPROC) (GLint first, GLsizei count); -typedef void (APIENTRY * PFNGLUNLOCKARRAYSEXTPROC) (void); -#endif - -#ifndef GL_EXT_cull_vertex -#define GL_EXT_cull_vertex 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glCullParameterdvEXT (GLenum, GLdouble *); -extern void APIENTRY glCullParameterfvEXT (GLenum, GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCULLPARAMETERDVEXTPROC) (GLenum pname, GLdouble *params); -typedef void (APIENTRY * PFNGLCULLPARAMETERFVEXTPROC) (GLenum pname, GLfloat *params); -#endif - -#ifndef GL_SGIX_ycrcb -#define GL_SGIX_ycrcb 1 -#endif - -#ifndef GL_SGIX_fragment_lighting -#define GL_SGIX_fragment_lighting 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFragmentColorMaterialSGIX (GLenum, GLenum); -extern void APIENTRY glFragmentLightfSGIX (GLenum, GLenum, GLfloat); -extern void APIENTRY glFragmentLightfvSGIX (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glFragmentLightiSGIX (GLenum, GLenum, GLint); -extern void APIENTRY glFragmentLightivSGIX (GLenum, GLenum, const GLint *); -extern void APIENTRY glFragmentLightModelfSGIX (GLenum, GLfloat); -extern void APIENTRY glFragmentLightModelfvSGIX (GLenum, const GLfloat *); -extern void APIENTRY glFragmentLightModeliSGIX (GLenum, GLint); -extern void APIENTRY glFragmentLightModelivSGIX (GLenum, const GLint *); -extern void APIENTRY glFragmentMaterialfSGIX (GLenum, GLenum, GLfloat); -extern void APIENTRY glFragmentMaterialfvSGIX (GLenum, GLenum, const GLfloat *); -extern void APIENTRY glFragmentMaterialiSGIX (GLenum, GLenum, GLint); -extern void APIENTRY glFragmentMaterialivSGIX (GLenum, GLenum, const GLint *); -extern void APIENTRY glGetFragmentLightfvSGIX (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetFragmentLightivSGIX (GLenum, GLenum, GLint *); -extern void APIENTRY glGetFragmentMaterialfvSGIX (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetFragmentMaterialivSGIX (GLenum, GLenum, GLint *); -extern void APIENTRY glLightEnviSGIX (GLenum, GLint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFRAGMENTCOLORMATERIALSGIXPROC) (GLenum face, GLenum mode); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTFSGIXPROC) (GLenum light, GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTISGIXPROC) (GLenum light, GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTMODELFSGIXPROC) (GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTMODELFVSGIXPROC) (GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTMODELISGIXPROC) (GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLFRAGMENTLIGHTMODELIVSGIXPROC) (GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLFRAGMENTMATERIALFSGIXPROC) (GLenum face, GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLFRAGMENTMATERIALISGIXPROC) (GLenum face, GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLGETFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLLIGHTENVISGIXPROC) (GLenum pname, GLint param); -#endif - -#ifndef GL_IBM_rasterpos_clip -#define GL_IBM_rasterpos_clip 1 -#endif - -#ifndef GL_HP_texture_lighting -#define GL_HP_texture_lighting 1 -#endif - -#ifndef GL_EXT_draw_range_elements -#define GL_EXT_draw_range_elements 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glDrawRangeElementsEXT (GLenum, GLuint, GLuint, GLsizei, GLenum, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLDRAWRANGEELEMENTSEXTPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); -#endif - -#ifndef GL_WIN_phong_shading -#define GL_WIN_phong_shading 1 -#endif - -#ifndef GL_WIN_specular_fog -#define GL_WIN_specular_fog 1 -#endif - -#ifndef GL_EXT_light_texture -#define GL_EXT_light_texture 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glApplyTextureEXT (GLenum); -extern void APIENTRY glTextureLightEXT (GLenum); -extern void APIENTRY glTextureMaterialEXT (GLenum, GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLAPPLYTEXTUREEXTPROC) (GLenum mode); -typedef void (APIENTRY * PFNGLTEXTURELIGHTEXTPROC) (GLenum pname); -typedef void (APIENTRY * PFNGLTEXTUREMATERIALEXTPROC) (GLenum face, GLenum mode); -#endif - -#ifndef GL_SGIX_blend_alpha_minmax -#define GL_SGIX_blend_alpha_minmax 1 -#endif - -#ifndef GL_EXT_bgra -#define GL_EXT_bgra 1 -#endif - -#ifndef GL_INTEL_parallel_arrays -#define GL_INTEL_parallel_arrays 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glVertexPointervINTEL (GLint, GLenum, const GLvoid* *); -extern void APIENTRY glNormalPointervINTEL (GLenum, const GLvoid* *); -extern void APIENTRY glColorPointervINTEL (GLint, GLenum, const GLvoid* *); -extern void APIENTRY glTexCoordPointervINTEL (GLint, GLenum, const GLvoid* *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLVERTEXPOINTERVINTELPROC) (GLint size, GLenum type, const GLvoid* *pointer); -typedef void (APIENTRY * PFNGLNORMALPOINTERVINTELPROC) (GLenum type, const GLvoid* *pointer); -typedef void (APIENTRY * PFNGLCOLORPOINTERVINTELPROC) (GLint size, GLenum type, const GLvoid* *pointer); -typedef void (APIENTRY * PFNGLTEXCOORDPOINTERVINTELPROC) (GLint size, GLenum type, const GLvoid* *pointer); -#endif - -#ifndef GL_HP_occlusion_test -#define GL_HP_occlusion_test 1 -#endif - -#ifndef GL_EXT_pixel_transform -#define GL_EXT_pixel_transform 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glPixelTransformParameteriEXT (GLenum, GLenum, GLint); -extern void APIENTRY glPixelTransformParameterfEXT (GLenum, GLenum, GLfloat); -extern void APIENTRY glPixelTransformParameterivEXT (GLenum, GLenum, const GLint *); -extern void APIENTRY glPixelTransformParameterfvEXT (GLenum, GLenum, const GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLPIXELTRANSFORMPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLPIXELTRANSFORMPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat *params); -#endif - -#ifndef GL_EXT_pixel_transform_color_table -#define GL_EXT_pixel_transform_color_table 1 -#endif - -#ifndef GL_EXT_shared_texture_palette -#define GL_EXT_shared_texture_palette 1 -#endif - -#ifndef GL_EXT_separate_specular_color -#define GL_EXT_separate_specular_color 1 -#endif - -#ifndef GL_EXT_secondary_color -#define GL_EXT_secondary_color 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glSecondaryColor3bEXT (GLbyte, GLbyte, GLbyte); -extern void APIENTRY glSecondaryColor3bvEXT (const GLbyte *); -extern void APIENTRY glSecondaryColor3dEXT (GLdouble, GLdouble, GLdouble); -extern void APIENTRY glSecondaryColor3dvEXT (const GLdouble *); -extern void APIENTRY glSecondaryColor3fEXT (GLfloat, GLfloat, GLfloat); -extern void APIENTRY glSecondaryColor3fvEXT (const GLfloat *); -extern void APIENTRY glSecondaryColor3iEXT (GLint, GLint, GLint); -extern void APIENTRY glSecondaryColor3ivEXT (const GLint *); -extern void APIENTRY glSecondaryColor3sEXT (GLshort, GLshort, GLshort); -extern void APIENTRY glSecondaryColor3svEXT (const GLshort *); -extern void APIENTRY glSecondaryColor3ubEXT (GLubyte, GLubyte, GLubyte); -extern void APIENTRY glSecondaryColor3ubvEXT (const GLubyte *); -extern void APIENTRY glSecondaryColor3uiEXT (GLuint, GLuint, GLuint); -extern void APIENTRY glSecondaryColor3uivEXT (const GLuint *); -extern void APIENTRY glSecondaryColor3usEXT (GLushort, GLushort, GLushort); -extern void APIENTRY glSecondaryColor3usvEXT (const GLushort *); -extern void APIENTRY glSecondaryColorPointerEXT (GLint, GLenum, GLsizei, GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3BEXTPROC) (GLbyte red, GLbyte green, GLbyte blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3BVEXTPROC) (const GLbyte *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3DEXTPROC) (GLdouble red, GLdouble green, GLdouble blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3DVEXTPROC) (const GLdouble *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3FEXTPROC) (GLfloat red, GLfloat green, GLfloat blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3FVEXTPROC) (const GLfloat *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3IEXTPROC) (GLint red, GLint green, GLint blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3IVEXTPROC) (const GLint *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3SEXTPROC) (GLshort red, GLshort green, GLshort blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3SVEXTPROC) (const GLshort *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3UBEXTPROC) (GLubyte red, GLubyte green, GLubyte blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3UBVEXTPROC) (const GLubyte *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3UIEXTPROC) (GLuint red, GLuint green, GLuint blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3UIVEXTPROC) (const GLuint *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3USEXTPROC) (GLushort red, GLushort green, GLushort blue); -typedef void (APIENTRY * PFNGLSECONDARYCOLOR3USVEXTPROC) (const GLushort *v); -typedef void (APIENTRY * PFNGLSECONDARYCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); -#endif - -#ifndef GL_EXT_texture_perturb_normal -#define GL_EXT_texture_perturb_normal 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTextureNormalEXT (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTEXTURENORMALEXTPROC) (GLenum mode); -#endif - -#ifndef GL_EXT_multi_draw_arrays -#define GL_EXT_multi_draw_arrays 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glMultiDrawArraysEXT (GLenum, GLint *, GLsizei *, GLsizei); -extern void APIENTRY glMultiDrawElementsEXT (GLenum, const GLsizei *, GLenum, const GLvoid* *, GLsizei); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, GLint *first, GLsizei *count, GLsizei primcount); -typedef void (APIENTRY * PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount); -#endif - -#ifndef GL_EXT_fog_coord -#define GL_EXT_fog_coord 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFogCoordfEXT (GLfloat); -extern void APIENTRY glFogCoordfvEXT (const GLfloat *); -extern void APIENTRY glFogCoorddEXT (GLdouble); -extern void APIENTRY glFogCoorddvEXT (const GLdouble *); -extern void APIENTRY glFogCoordPointerEXT (GLenum, GLsizei, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFOGCOORDFEXTPROC) (GLfloat coord); -typedef void (APIENTRY * PFNGLFOGCOORDFVEXTPROC) (const GLfloat *coord); -typedef void (APIENTRY * PFNGLFOGCOORDDEXTPROC) (GLdouble coord); -typedef void (APIENTRY * PFNGLFOGCOORDDVEXTPROC) (const GLdouble *coord); -typedef void (APIENTRY * PFNGLFOGCOORDPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -#endif - -#ifndef GL_REND_screen_coordinates -#define GL_REND_screen_coordinates 1 -#endif - -#ifndef GL_EXT_coordinate_frame -#define GL_EXT_coordinate_frame 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTangent3bEXT (GLbyte, GLbyte, GLbyte); -extern void APIENTRY glTangent3bvEXT (const GLbyte *); -extern void APIENTRY glTangent3dEXT (GLdouble, GLdouble, GLdouble); -extern void APIENTRY glTangent3dvEXT (const GLdouble *); -extern void APIENTRY glTangent3fEXT (GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTangent3fvEXT (const GLfloat *); -extern void APIENTRY glTangent3iEXT (GLint, GLint, GLint); -extern void APIENTRY glTangent3ivEXT (const GLint *); -extern void APIENTRY glTangent3sEXT (GLshort, GLshort, GLshort); -extern void APIENTRY glTangent3svEXT (const GLshort *); -extern void APIENTRY glBinormal3bEXT (GLbyte, GLbyte, GLbyte); -extern void APIENTRY glBinormal3bvEXT (const GLbyte *); -extern void APIENTRY glBinormal3dEXT (GLdouble, GLdouble, GLdouble); -extern void APIENTRY glBinormal3dvEXT (const GLdouble *); -extern void APIENTRY glBinormal3fEXT (GLfloat, GLfloat, GLfloat); -extern void APIENTRY glBinormal3fvEXT (const GLfloat *); -extern void APIENTRY glBinormal3iEXT (GLint, GLint, GLint); -extern void APIENTRY glBinormal3ivEXT (const GLint *); -extern void APIENTRY glBinormal3sEXT (GLshort, GLshort, GLshort); -extern void APIENTRY glBinormal3svEXT (const GLshort *); -extern void APIENTRY glTangentPointerEXT (GLenum, GLsizei, const GLvoid *); -extern void APIENTRY glBinormalPointerEXT (GLenum, GLsizei, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTANGENT3BEXTPROC) (GLbyte tx, GLbyte ty, GLbyte tz); -typedef void (APIENTRY * PFNGLTANGENT3BVEXTPROC) (const GLbyte *v); -typedef void (APIENTRY * PFNGLTANGENT3DEXTPROC) (GLdouble tx, GLdouble ty, GLdouble tz); -typedef void (APIENTRY * PFNGLTANGENT3DVEXTPROC) (const GLdouble *v); -typedef void (APIENTRY * PFNGLTANGENT3FEXTPROC) (GLfloat tx, GLfloat ty, GLfloat tz); -typedef void (APIENTRY * PFNGLTANGENT3FVEXTPROC) (const GLfloat *v); -typedef void (APIENTRY * PFNGLTANGENT3IEXTPROC) (GLint tx, GLint ty, GLint tz); -typedef void (APIENTRY * PFNGLTANGENT3IVEXTPROC) (const GLint *v); -typedef void (APIENTRY * PFNGLTANGENT3SEXTPROC) (GLshort tx, GLshort ty, GLshort tz); -typedef void (APIENTRY * PFNGLTANGENT3SVEXTPROC) (const GLshort *v); -typedef void (APIENTRY * PFNGLBINORMAL3BEXTPROC) (GLbyte bx, GLbyte by, GLbyte bz); -typedef void (APIENTRY * PFNGLBINORMAL3BVEXTPROC) (const GLbyte *v); -typedef void (APIENTRY * PFNGLBINORMAL3DEXTPROC) (GLdouble bx, GLdouble by, GLdouble bz); -typedef void (APIENTRY * PFNGLBINORMAL3DVEXTPROC) (const GLdouble *v); -typedef void (APIENTRY * PFNGLBINORMAL3FEXTPROC) (GLfloat bx, GLfloat by, GLfloat bz); -typedef void (APIENTRY * PFNGLBINORMAL3FVEXTPROC) (const GLfloat *v); -typedef void (APIENTRY * PFNGLBINORMAL3IEXTPROC) (GLint bx, GLint by, GLint bz); -typedef void (APIENTRY * PFNGLBINORMAL3IVEXTPROC) (const GLint *v); -typedef void (APIENTRY * PFNGLBINORMAL3SEXTPROC) (GLshort bx, GLshort by, GLshort bz); -typedef void (APIENTRY * PFNGLBINORMAL3SVEXTPROC) (const GLshort *v); -typedef void (APIENTRY * PFNGLTANGENTPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (APIENTRY * PFNGLBINORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -#endif - -#ifndef GL_EXT_texture_env_combine -#define GL_EXT_texture_env_combine 1 -#endif - -#ifndef GL_APPLE_specular_vector -#define GL_APPLE_specular_vector 1 -#endif - -#ifndef GL_APPLE_transform_hint -#define GL_APPLE_transform_hint 1 -#endif - -#ifndef GL_SGIX_fog_scale -#define GL_SGIX_fog_scale 1 -#endif - -#ifndef GL_SUNX_constant_data -#define GL_SUNX_constant_data 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFinishTextureSUNX (void); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFINISHTEXTURESUNXPROC) (void); -#endif - -#ifndef GL_SUN_global_alpha -#define GL_SUN_global_alpha 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glGlobalAlphaFactorbSUN (GLbyte); -extern void APIENTRY glGlobalAlphaFactorsSUN (GLshort); -extern void APIENTRY glGlobalAlphaFactoriSUN (GLint); -extern void APIENTRY glGlobalAlphaFactorfSUN (GLfloat); -extern void APIENTRY glGlobalAlphaFactordSUN (GLdouble); -extern void APIENTRY glGlobalAlphaFactorubSUN (GLubyte); -extern void APIENTRY glGlobalAlphaFactorusSUN (GLushort); -extern void APIENTRY glGlobalAlphaFactoruiSUN (GLuint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORBSUNPROC) (GLbyte factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORSSUNPROC) (GLshort factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORISUNPROC) (GLint factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORFSUNPROC) (GLfloat factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORDSUNPROC) (GLdouble factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORUBSUNPROC) (GLubyte factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORUSSUNPROC) (GLushort factor); -typedef void (APIENTRY * PFNGLGLOBALALPHAFACTORUISUNPROC) (GLuint factor); -#endif - -#ifndef GL_SUN_triangle_list -#define GL_SUN_triangle_list 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glReplacementCodeuiSUN (GLuint); -extern void APIENTRY glReplacementCodeusSUN (GLushort); -extern void APIENTRY glReplacementCodeubSUN (GLubyte); -extern void APIENTRY glReplacementCodeuivSUN (const GLuint *); -extern void APIENTRY glReplacementCodeusvSUN (const GLushort *); -extern void APIENTRY glReplacementCodeubvSUN (const GLubyte *); -extern void APIENTRY glReplacementCodePointerSUN (GLenum, GLsizei, const GLvoid* *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUISUNPROC) (GLuint code); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUSSUNPROC) (GLushort code); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUBSUNPROC) (GLubyte code); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUIVSUNPROC) (const GLuint *code); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUSVSUNPROC) (const GLushort *code); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUBVSUNPROC) (const GLubyte *code); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEPOINTERSUNPROC) (GLenum type, GLsizei stride, const GLvoid* *pointer); -#endif - -#ifndef GL_SUN_vertex -#define GL_SUN_vertex 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glColor4ubVertex2fSUN (GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat); -extern void APIENTRY glColor4ubVertex2fvSUN (const GLubyte *, const GLfloat *); -extern void APIENTRY glColor4ubVertex3fSUN (GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glColor4ubVertex3fvSUN (const GLubyte *, const GLfloat *); -extern void APIENTRY glColor3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glColor3fVertex3fvSUN (const GLfloat *, const GLfloat *); -extern void APIENTRY glNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *); -extern void APIENTRY glColor4fNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glColor4fNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glTexCoord2fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord2fVertex3fvSUN (const GLfloat *, const GLfloat *); -extern void APIENTRY glTexCoord4fVertex4fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord4fVertex4fvSUN (const GLfloat *, const GLfloat *); -extern void APIENTRY glTexCoord2fColor4ubVertex3fSUN (GLfloat, GLfloat, GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord2fColor4ubVertex3fvSUN (const GLfloat *, const GLubyte *, const GLfloat *); -extern void APIENTRY glTexCoord2fColor3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord2fColor3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glTexCoord2fNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord2fNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glTexCoord2fColor4fNormal3fVertex3fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord2fColor4fNormal3fVertex3fvSUN (const GLfloat *, const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glTexCoord4fColor4fNormal3fVertex4fSUN (GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glTexCoord4fColor4fNormal3fVertex4fvSUN (const GLfloat *, const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiVertex3fvSUN (const GLenum *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiColor4ubVertex3fSUN (GLenum, GLubyte, GLubyte, GLubyte, GLubyte, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiColor4ubVertex3fvSUN (const GLenum *, const GLubyte *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiColor3fVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiColor3fVertex3fvSUN (const GLenum *, const GLfloat *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiNormal3fVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiNormal3fVertex3fvSUN (const GLenum *, const GLfloat *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiColor4fNormal3fVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiColor4fNormal3fVertex3fvSUN (const GLenum *, const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiTexCoord2fVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiTexCoord2fVertex3fvSUN (const GLenum *, const GLfloat *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN (const GLenum *, const GLfloat *, const GLfloat *, const GLfloat *); -extern void APIENTRY glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN (GLenum, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN (const GLenum *, const GLfloat *, const GLfloat *, const GLfloat *, const GLfloat *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOLOR4UBVERTEX2FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); -typedef void (APIENTRY * PFNGLCOLOR4UBVERTEX2FVSUNPROC) (const GLubyte *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLCOLOR4UBVERTEX3FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLCOLOR4UBVERTEX3FVSUNPROC) (const GLubyte *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLCOLOR3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLCOLOR3FVERTEX3FVSUNPROC) (const GLfloat *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLNORMAL3FVERTEX3FSUNPROC) (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD2FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLTEXCOORD2FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD4FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (APIENTRY * PFNGLTEXCOORD4FVERTEX4FVSUNPROC) (const GLfloat *tc, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC) (const GLfloat *tc, const GLubyte *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (APIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC) (GLenum rc, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC) (GLenum rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC) (const GLenum *rc, const GLubyte *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC) (GLenum rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *c, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC) (GLenum rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLenum rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC) (GLenum rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *tc, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLenum rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLenum rc, GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLenum *rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -#endif - -#ifndef GL_EXT_blend_func_separate -#define GL_EXT_blend_func_separate 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glBlendFuncSeparateEXT (GLenum, GLenum, GLenum, GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLBLENDFUNCSEPARATEEXTPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); -#endif - -#ifndef GL_INGR_color_clamp -#define GL_INGR_color_clamp 1 -#endif - -#ifndef GL_INGR_interlace_read -#define GL_INGR_interlace_read 1 -#endif - -#ifndef GL_EXT_stencil_wrap -#define GL_EXT_stencil_wrap 1 -#endif - -#ifndef GL_EXT_422_pixels -#define GL_EXT_422_pixels 1 -#endif - -#ifndef GL_NV_texgen_reflection -#define GL_NV_texgen_reflection 1 -#endif - -#ifndef GL_SUN_convolution_border_modes -#define GL_SUN_convolution_border_modes 1 -#endif - -#ifndef GL_EXT_texture_env_add -#define GL_EXT_texture_env_add 1 -#endif - -#ifndef GL_EXT_texture_lod_bias -#define GL_EXT_texture_lod_bias 1 -#endif - -#ifndef GL_EXT_texture_filter_anisotropic -#define GL_EXT_texture_filter_anisotropic 1 -#endif - -#ifndef GL_EXT_vertex_weighting -#define GL_EXT_vertex_weighting 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glVertexWeightfEXT (GLfloat); -extern void APIENTRY glVertexWeightfvEXT (const GLfloat *); -extern void APIENTRY glVertexWeightPointerEXT (GLsizei, GLenum, GLsizei, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLVERTEXWEIGHTFEXTPROC) (GLfloat weight); -typedef void (APIENTRY * PFNGLVERTEXWEIGHTFVEXTPROC) (const GLfloat *weight); -typedef void (APIENTRY * PFNGLVERTEXWEIGHTPOINTEREXTPROC) (GLsizei size, GLenum type, GLsizei stride, const GLvoid *pointer); -#endif - -#ifndef GL_NV_light_max_exponent -#define GL_NV_light_max_exponent 1 -#endif - -#ifndef GL_NV_vertex_array_range -#define GL_NV_vertex_array_range 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glFlushVertexArrayRangeNV (void); -extern void APIENTRY glVertexArrayRangeNV (GLsizei, const GLvoid *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLFLUSHVERTEXARRAYRANGENVPROC) (void); -typedef void (APIENTRY * PFNGLVERTEXARRAYRANGENVPROC) (GLsizei size, const GLvoid *pointer); -#endif - -#ifndef GL_NV_vertex_array_range2 -#define GL_NV_vertex_array_range2 1 -#endif - -#ifndef GL_NV_register_combiners -#define GL_NV_register_combiners 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glCombinerParameterfvNV (GLenum, const GLfloat *); -extern void APIENTRY glCombinerParameterfNV (GLenum, GLfloat); -extern void APIENTRY glCombinerParameterivNV (GLenum, const GLint *); -extern void APIENTRY glCombinerParameteriNV (GLenum, GLint); -extern void APIENTRY glCombinerInputNV (GLenum, GLenum, GLenum, GLenum, GLenum, GLenum); -extern void APIENTRY glCombinerOutputNV (GLenum, GLenum, GLenum, GLenum, GLenum, GLenum, GLenum, GLboolean, GLboolean, GLboolean); -extern void APIENTRY glFinalCombinerInputNV (GLenum, GLenum, GLenum, GLenum); -extern void APIENTRY glGetCombinerInputParameterfvNV (GLenum, GLenum, GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetCombinerInputParameterivNV (GLenum, GLenum, GLenum, GLenum, GLint *); -extern void APIENTRY glGetCombinerOutputParameterfvNV (GLenum, GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetCombinerOutputParameterivNV (GLenum, GLenum, GLenum, GLint *); -extern void APIENTRY glGetFinalCombinerInputParameterfvNV (GLenum, GLenum, GLfloat *); -extern void APIENTRY glGetFinalCombinerInputParameterivNV (GLenum, GLenum, GLint *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOMBINERPARAMETERFVNVPROC) (GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLCOMBINERPARAMETERFNVPROC) (GLenum pname, GLfloat param); -typedef void (APIENTRY * PFNGLCOMBINERPARAMETERIVNVPROC) (GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLCOMBINERPARAMETERINVPROC) (GLenum pname, GLint param); -typedef void (APIENTRY * PFNGLCOMBINERINPUTNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); -typedef void (APIENTRY * PFNGLCOMBINEROUTPUTNVPROC) (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); -typedef void (APIENTRY * PFNGLFINALCOMBINERINPUTNVPROC) (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); -typedef void (APIENTRY * PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC) (GLenum variable, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC) (GLenum variable, GLenum pname, GLint *params); -#endif - -#ifndef GL_NV_fog_distance -#define GL_NV_fog_distance 1 -#endif - -#ifndef GL_NV_texgen_emboss -#define GL_NV_texgen_emboss 1 -#endif - -#ifndef GL_NV_blend_square -#define GL_NV_blend_square 1 -#endif - -#ifndef GL_NV_texture_env_combine4 -#define GL_NV_texture_env_combine4 1 -#endif - -#ifndef GL_MESA_resize_buffers -#define GL_MESA_resize_buffers 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glResizeBuffersMESA (void); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLRESIZEBUFFERSMESAPROC) (void); -#endif - -#ifndef GL_MESA_window_pos -#define GL_MESA_window_pos 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glWindowPos2dMESA (GLdouble, GLdouble); -extern void APIENTRY glWindowPos2dvMESA (const GLdouble *); -extern void APIENTRY glWindowPos2fMESA (GLfloat, GLfloat); -extern void APIENTRY glWindowPos2fvMESA (const GLfloat *); -extern void APIENTRY glWindowPos2iMESA (GLint, GLint); -extern void APIENTRY glWindowPos2ivMESA (const GLint *); -extern void APIENTRY glWindowPos2sMESA (GLshort, GLshort); -extern void APIENTRY glWindowPos2svMESA (const GLshort *); -extern void APIENTRY glWindowPos3dMESA (GLdouble, GLdouble, GLdouble); -extern void APIENTRY glWindowPos3dvMESA (const GLdouble *); -extern void APIENTRY glWindowPos3fMESA (GLfloat, GLfloat, GLfloat); -extern void APIENTRY glWindowPos3fvMESA (const GLfloat *); -extern void APIENTRY glWindowPos3iMESA (GLint, GLint, GLint); -extern void APIENTRY glWindowPos3ivMESA (const GLint *); -extern void APIENTRY glWindowPos3sMESA (GLshort, GLshort, GLshort); -extern void APIENTRY glWindowPos3svMESA (const GLshort *); -extern void APIENTRY glWindowPos4dMESA (GLdouble, GLdouble, GLdouble, GLdouble); -extern void APIENTRY glWindowPos4dvMESA (const GLdouble *); -extern void APIENTRY glWindowPos4fMESA (GLfloat, GLfloat, GLfloat, GLfloat); -extern void APIENTRY glWindowPos4fvMESA (const GLfloat *); -extern void APIENTRY glWindowPos4iMESA (GLint, GLint, GLint, GLint); -extern void APIENTRY glWindowPos4ivMESA (const GLint *); -extern void APIENTRY glWindowPos4sMESA (GLshort, GLshort, GLshort, GLshort); -extern void APIENTRY glWindowPos4svMESA (const GLshort *); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLWINDOWPOS2DMESAPROC) (GLdouble x, GLdouble y); -typedef void (APIENTRY * PFNGLWINDOWPOS2DVMESAPROC) (const GLdouble *v); -typedef void (APIENTRY * PFNGLWINDOWPOS2FMESAPROC) (GLfloat x, GLfloat y); -typedef void (APIENTRY * PFNGLWINDOWPOS2FVMESAPROC) (const GLfloat *v); -typedef void (APIENTRY * PFNGLWINDOWPOS2IMESAPROC) (GLint x, GLint y); -typedef void (APIENTRY * PFNGLWINDOWPOS2IVMESAPROC) (const GLint *v); -typedef void (APIENTRY * PFNGLWINDOWPOS2SMESAPROC) (GLshort x, GLshort y); -typedef void (APIENTRY * PFNGLWINDOWPOS2SVMESAPROC) (const GLshort *v); -typedef void (APIENTRY * PFNGLWINDOWPOS3DMESAPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (APIENTRY * PFNGLWINDOWPOS3DVMESAPROC) (const GLdouble *v); -typedef void (APIENTRY * PFNGLWINDOWPOS3FMESAPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLWINDOWPOS3FVMESAPROC) (const GLfloat *v); -typedef void (APIENTRY * PFNGLWINDOWPOS3IMESAPROC) (GLint x, GLint y, GLint z); -typedef void (APIENTRY * PFNGLWINDOWPOS3IVMESAPROC) (const GLint *v); -typedef void (APIENTRY * PFNGLWINDOWPOS3SMESAPROC) (GLshort x, GLshort y, GLshort z); -typedef void (APIENTRY * PFNGLWINDOWPOS3SVMESAPROC) (const GLshort *v); -typedef void (APIENTRY * PFNGLWINDOWPOS4DMESAPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (APIENTRY * PFNGLWINDOWPOS4DVMESAPROC) (const GLdouble *v); -typedef void (APIENTRY * PFNGLWINDOWPOS4FMESAPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (APIENTRY * PFNGLWINDOWPOS4FVMESAPROC) (const GLfloat *v); -typedef void (APIENTRY * PFNGLWINDOWPOS4IMESAPROC) (GLint x, GLint y, GLint z, GLint w); -typedef void (APIENTRY * PFNGLWINDOWPOS4IVMESAPROC) (const GLint *v); -typedef void (APIENTRY * PFNGLWINDOWPOS4SMESAPROC) (GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (APIENTRY * PFNGLWINDOWPOS4SVMESAPROC) (const GLshort *v); -#endif - -#ifndef GL_IBM_cull_vertex -#define GL_IBM_cull_vertex 1 -#endif - -#ifndef GL_IBM_multimode_draw_arrays -#define GL_IBM_multimode_draw_arrays 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glMultiModeDrawArraysIBM (GLenum, const GLint *, const GLsizei *, GLsizei, GLint); -extern void APIENTRY glMultiModeDrawElementsIBM (const GLenum *, const GLsizei *, GLenum, const GLvoid* *, GLsizei, GLint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLMULTIMODEDRAWARRAYSIBMPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); -typedef void (APIENTRY * PFNGLMULTIMODEDRAWELEMENTSIBMPROC) (const GLenum *mode, const GLsizei *count, GLenum type, const GLvoid* *indices, GLsizei primcount, GLint modestride); -#endif - -#ifndef GL_IBM_vertex_array_lists -#define GL_IBM_vertex_array_lists 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glColorPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); -extern void APIENTRY glSecondaryColorPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); -extern void APIENTRY glEdgeFlagPointerListIBM (GLint, const GLboolean* *, GLint); -extern void APIENTRY glFogCoordPointerListIBM (GLenum, GLint, const GLvoid* *, GLint); -extern void APIENTRY glIndexPointerListIBM (GLenum, GLint, const GLvoid* *, GLint); -extern void APIENTRY glNormalPointerListIBM (GLenum, GLint, const GLvoid* *, GLint); -extern void APIENTRY glTexCoordPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); -extern void APIENTRY glVertexPointerListIBM (GLint, GLenum, GLint, const GLvoid* *, GLint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLSECONDARYCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLEDGEFLAGPOINTERLISTIBMPROC) (GLint stride, const GLboolean* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLFOGCOORDPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLINDEXPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLNORMALPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLTEXCOORDPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -typedef void (APIENTRY * PFNGLVERTEXPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid* *pointer, GLint ptrstride); -#endif - -#ifndef GL_SGIX_subsample -#define GL_SGIX_subsample 1 -#endif - -#ifndef GL_SGIX_ycrcba -#define GL_SGIX_ycrcba 1 -#endif - -#ifndef GL_SGIX_ycrcb_subsample -#define GL_SGIX_ycrcb_subsample 1 -#endif - -#ifndef GL_SGIX_depth_pass_instrument -#define GL_SGIX_depth_pass_instrument 1 -#endif - -#ifndef GL_3DFX_texture_compression_FXT1 -#define GL_3DFX_texture_compression_FXT1 1 -#endif - -#ifndef GL_3DFX_multisample -#define GL_3DFX_multisample 1 -#endif - -#ifndef GL_3DFX_tbuffer -#define GL_3DFX_tbuffer 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTbufferMask3DFX (GLuint); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTBUFFERMASK3DFXPROC) (GLuint mask); -#endif - -#ifndef GL_EXT_multisample -#define GL_EXT_multisample 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glSampleMaskEXT (GLclampf, GLboolean); -extern void APIENTRY glSamplePatternEXT (GLenum); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLSAMPLEMASKEXTPROC) (GLclampf value, GLboolean invert); -typedef void (APIENTRY * PFNGLSAMPLEPATTERNEXTPROC) (GLenum pattern); -#endif - -#ifndef GL_SGI_vertex_preclip -#define GL_SGI_vertex_preclip 1 -#endif - -#ifndef GL_SGIX_convolution_accuracy -#define GL_SGIX_convolution_accuracy 1 -#endif - -#ifndef GL_SGIX_resample -#define GL_SGIX_resample 1 -#endif - -#ifndef GL_SGIS_point_line_texgen -#define GL_SGIS_point_line_texgen 1 -#endif - -#ifndef GL_SGIS_texture_color_mask -#define GL_SGIS_texture_color_mask 1 -#ifdef GL_GLEXT_PROTOTYPES -extern void APIENTRY glTextureColorMaskSGIS (GLboolean, GLboolean, GLboolean, GLboolean); -#endif /* GL_GLEXT_PROTOTYPES */ -typedef void (APIENTRY * PFNGLTEXTURECOLORMASKSGISPROC) (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); -#endif - - - -/* added by Cass -- this part will be auto-generated in the future*/ - -#ifndef GL_EXT_texture_compression_s3tc -#define GL_EXT_texture_compression_s3tc 1 -#endif - -/* Extensions */ -#define GL_ARB_texture_border_clamp 1 -#define GL_ARB_texture_env_combine 1 -#define GL_ARB_texture_env_dot3 1 -#define GL_EXT_texture_env_dot3 1 -#define GL_IBM_texture_mirrored_repeat 1 -#define GL_NV_evaluators 1 -#define GL_NV_fence 1 -#define GL_NV_multisample_filter_hint 1 -#define GL_NV_packed_depth_stencil 1 -#define GL_NV_register_combiners2 1 -#define GL_NV_texture_compression_vtc 1 -#define GL_NV_texture_rectangle 1 -#define GL_NV_texture_shader 1 -#define GL_NV_texture_shader2 1 -#define GL_NV_vertex_program 1 -#define GL_NV_point_sprite 1 -#define GL_NV_occlusion_query 1 - -/* ARB_texture_border_clamp */ -#define GL_CLAMP_TO_BORDER_ARB 0x812D - -/* ARB_texture_env_combine */ -#define GL_COMBINE_ARB 0x8570 -#define GL_COMBINE_RGB_ARB 0x8571 -#define GL_COMBINE_ALPHA_ARB 0x8572 -#define GL_RGB_SCALE_ARB 0x8573 -#define GL_ADD_SIGNED_ARB 0x8574 -#define GL_INTERPOLATE_ARB 0x8575 -#define GL_CONSTANT_ARB 0x8576 -#define GL_PRIMARY_COLOR_ARB 0x8577 -#define GL_PREVIOUS_ARB 0x8578 -#define GL_SOURCE0_RGB_ARB 0x8580 -#define GL_SOURCE1_RGB_ARB 0x8581 -#define GL_SOURCE2_RGB_ARB 0x8582 -#define GL_SOURCE0_ALPHA_ARB 0x8588 -#define GL_SOURCE1_ALPHA_ARB 0x8589 -#define GL_SOURCE2_ALPHA_ARB 0x858A -#define GL_OPERAND0_RGB_ARB 0x8590 -#define GL_OPERAND1_RGB_ARB 0x8591 -#define GL_OPERAND2_RGB_ARB 0x8592 -#define GL_OPERAND0_ALPHA_ARB 0x8598 -#define GL_OPERAND1_ALPHA_ARB 0x8599 -#define GL_OPERAND2_ALPHA_ARB 0x859A -#define GL_SUBTRACT_ARB 0x84E7 - -/* ARB_texture_env_dot3 */ -#define GL_DOT3_RGB_ARB 0x86AE -#define GL_DOT3_RGBA_ARB 0x86AF - -/* EXT_texture_env_dot3 */ -#define GL_DOT3_RGB_EXT 0x8740 -#define GL_DOT3_RGBA_EXT 0x8741 - -/* IBM_texture_mirrored_repeat */ -#define GL_MIRRORED_REPEAT_IBM 0x8370 - -/* NV_vertex_program */ -#define GL_VERTEX_PROGRAM_NV 0x8620 -#define GL_VERTEX_STATE_PROGRAM_NV 0x8621 -#define GL_ATTRIB_ARRAY_SIZE_NV 0x8623 -#define GL_ATTRIB_ARRAY_STRIDE_NV 0x8624 -#define GL_ATTRIB_ARRAY_TYPE_NV 0x8625 -#define GL_CURRENT_ATTRIB_NV 0x8626 -#define GL_PROGRAM_LENGTH_NV 0x8627 -#define GL_PROGRAM_STRING_NV 0x8628 -#define GL_MODELVIEW_PROJECTION_NV 0x8629 -#define GL_IDENTITY_NV 0x862A -#define GL_INVERSE_NV 0x862B -#define GL_TRANSPOSE_NV 0x862C -#define GL_INVERSE_TRANSPOSE_NV 0x862D -#define GL_MAX_TRACK_MATRIX_STACK_DEPTH_NV 0x862E -#define GL_MAX_TRACK_MATRICES_NV 0x862F -#define GL_MATRIX0_NV 0x8630 -#define GL_MATRIX1_NV 0x8631 -#define GL_MATRIX2_NV 0x8632 -#define GL_MATRIX3_NV 0x8633 -#define GL_MATRIX4_NV 0x8634 -#define GL_MATRIX5_NV 0x8635 -#define GL_MATRIX6_NV 0x8636 -#define GL_MATRIX7_NV 0x8637 -#define GL_CURRENT_MATRIX_STACK_DEPTH_NV 0x8640 -#define GL_CURRENT_MATRIX_NV 0x8641 -#define GL_VERTEX_PROGRAM_POINT_SIZE_NV 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE_NV 0x8643 -#define GL_PROGRAM_PARAMETER_NV 0x8644 -#define GL_ATTRIB_ARRAY_POINTER_NV 0x8645 -#define GL_PROGRAM_TARGET_NV 0x8646 -#define GL_PROGRAM_RESIDENT_NV 0x8647 -#define GL_TRACK_MATRIX_NV 0x8648 -#define GL_TRACK_MATRIX_TRANSFORM_NV 0x8649 -#define GL_VERTEX_PROGRAM_BINDING_NV 0x864A -#define GL_PROGRAM_ERROR_POSITION_NV 0x864B -#define GL_VERTEX_ATTRIB_ARRAY0_NV 0x8650 -#define GL_VERTEX_ATTRIB_ARRAY1_NV 0x8651 -#define GL_VERTEX_ATTRIB_ARRAY2_NV 0x8652 -#define GL_VERTEX_ATTRIB_ARRAY3_NV 0x8653 -#define GL_VERTEX_ATTRIB_ARRAY4_NV 0x8654 -#define GL_VERTEX_ATTRIB_ARRAY5_NV 0x8655 -#define GL_VERTEX_ATTRIB_ARRAY6_NV 0x8656 -#define GL_VERTEX_ATTRIB_ARRAY7_NV 0x8657 -#define GL_VERTEX_ATTRIB_ARRAY8_NV 0x8658 -#define GL_VERTEX_ATTRIB_ARRAY9_NV 0x8659 -#define GL_VERTEX_ATTRIB_ARRAY10_NV 0x865A -#define GL_VERTEX_ATTRIB_ARRAY11_NV 0x865B -#define GL_VERTEX_ATTRIB_ARRAY12_NV 0x865C -#define GL_VERTEX_ATTRIB_ARRAY13_NV 0x865D -#define GL_VERTEX_ATTRIB_ARRAY14_NV 0x865E -#define GL_VERTEX_ATTRIB_ARRAY15_NV 0x865F -#define GL_MAP1_VERTEX_ATTRIB0_4_NV 0x8660 -#define GL_MAP1_VERTEX_ATTRIB1_4_NV 0x8661 -#define GL_MAP1_VERTEX_ATTRIB2_4_NV 0x8662 -#define GL_MAP1_VERTEX_ATTRIB3_4_NV 0x8663 -#define GL_MAP1_VERTEX_ATTRIB4_4_NV 0x8664 -#define GL_MAP1_VERTEX_ATTRIB5_4_NV 0x8665 -#define GL_MAP1_VERTEX_ATTRIB6_4_NV 0x8666 -#define GL_MAP1_VERTEX_ATTRIB7_4_NV 0x8667 -#define GL_MAP1_VERTEX_ATTRIB8_4_NV 0x8668 -#define GL_MAP1_VERTEX_ATTRIB9_4_NV 0x8669 -#define GL_MAP1_VERTEX_ATTRIB10_4_NV 0x866A -#define GL_MAP1_VERTEX_ATTRIB11_4_NV 0x866B -#define GL_MAP1_VERTEX_ATTRIB12_4_NV 0x866C -#define GL_MAP1_VERTEX_ATTRIB13_4_NV 0x866D -#define GL_MAP1_VERTEX_ATTRIB14_4_NV 0x866E -#define GL_MAP1_VERTEX_ATTRIB15_4_NV 0x866F -#define GL_MAP2_VERTEX_ATTRIB0_4_NV 0x8670 -#define GL_MAP2_VERTEX_ATTRIB1_4_NV 0x8671 -#define GL_MAP2_VERTEX_ATTRIB2_4_NV 0x8672 -#define GL_MAP2_VERTEX_ATTRIB3_4_NV 0x8673 -#define GL_MAP2_VERTEX_ATTRIB4_4_NV 0x8674 -#define GL_MAP2_VERTEX_ATTRIB5_4_NV 0x8675 -#define GL_MAP2_VERTEX_ATTRIB6_4_NV 0x8676 -#define GL_MAP2_VERTEX_ATTRIB7_4_NV 0x8677 -#define GL_MAP2_VERTEX_ATTRIB8_4_NV 0x8678 -#define GL_MAP2_VERTEX_ATTRIB9_4_NV 0x8679 -#define GL_MAP2_VERTEX_ATTRIB10_4_NV 0x867A -#define GL_MAP2_VERTEX_ATTRIB11_4_NV 0x867B -#define GL_MAP2_VERTEX_ATTRIB12_4_NV 0x867C -#define GL_MAP2_VERTEX_ATTRIB13_4_NV 0x867D -#define GL_MAP2_VERTEX_ATTRIB14_4_NV 0x867E -#define GL_MAP2_VERTEX_ATTRIB15_4_NV 0x867F - -/* NV_evaluators */ -#define GL_EVAL_2D_NV 0x86C0 -#define GL_EVAL_TRIANGULAR_2D_NV 0x86C1 -#define GL_MAP_TESSELLATION_NV 0x86C2 -#define GL_MAP_ATTRIB_U_ORDER_NV 0x86C3 -#define GL_MAP_ATTRIB_V_ORDER_NV 0x86C4 -#define GL_EVAL_FRACTIONAL_TESSELLATION_NV 0x86C5 -#define GL_EVAL_VERTEX_ATTRIB0_NV 0x86C6 -#define GL_EVAL_VERTEX_ATTRIB1_NV 0x86C7 -#define GL_EVAL_VERTEX_ATTRIB2_NV 0x86C8 -#define GL_EVAL_VERTEX_ATTRIB3_NV 0x86C9 -#define GL_EVAL_VERTEX_ATTRIB4_NV 0x86CA -#define GL_EVAL_VERTEX_ATTRIB5_NV 0x86CB -#define GL_EVAL_VERTEX_ATTRIB6_NV 0x86CC -#define GL_EVAL_VERTEX_ATTRIB7_NV 0x86CD -#define GL_EVAL_VERTEX_ATTRIB8_NV 0x86CE -#define GL_EVAL_VERTEX_ATTRIB9_NV 0x86CF -#define GL_EVAL_VERTEX_ATTRIB10_NV 0x86D0 -#define GL_EVAL_VERTEX_ATTRIB11_NV 0x86D1 -#define GL_EVAL_VERTEX_ATTRIB12_NV 0x86D2 -#define GL_EVAL_VERTEX_ATTRIB13_NV 0x86D3 -#define GL_EVAL_VERTEX_ATTRIB14_NV 0x86D4 -#define GL_EVAL_VERTEX_ATTRIB15_NV 0x86D5 -#define GL_MAX_MAP_TESSELLATION_NV 0x86D6 -#define GL_MAX_RATIONAL_EVAL_ORDER_NV 0x86D7 - -/* NV_fence */ -#define GL_ALL_COMPLETED_NV 0x84F2 -#define GL_FENCE_STATUS_NV 0x84F3 -#define GL_FENCE_CONDITION_NV 0x84F4 - -/* NV_occlusion_query */ -#define GL_PIXEL_COUNTER_BITS_NV 0x8864 -#define GL_CURRENT_OCCLUSION_QUERY_ID_NV 0x8865 -#define GL_PIXEL_COUNT_NV 0x8866 -#define GL_PIXEL_COUNT_AVAILABLE_NV 0x8867 - -/* NV_point_sprite */ -#define GL_POINT_SPRITE_NV 0x8861 -#define GL_COORD_REPLACE_NV 0x8862 -#define GL_POINT_SPRITE_R_MODE_NV 0x8863 - -/* NV_texture_rectangle */ -#define GL_TEXTURE_RECTANGLE_NV 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_NV 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_NV 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_NV 0x84F8 - -/* NV_texture_shader */ -#define GL_OFFSET_TEXTURE_RECTANGLE_NV 0x864C -#define GL_OFFSET_TEXTURE_RECTANGLE_SCALE_NV 0x864D -#define GL_DOT_PRODUCT_TEXTURE_RECTANGLE_NV 0x864E -#define GL_RGBA_UNSIGNED_DOT_PRODUCT_MAPPING_NV 0x86D9 -#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA -#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB -#define GL_DSDT_MAG_INTENSITY_NV 0x86DC -#define GL_SHADER_CONSISTENT_NV 0x86DD -#define GL_TEXTURE_SHADER_NV 0x86DE -#define GL_SHADER_OPERATION_NV 0x86DF -#define GL_CULL_MODES_NV 0x86E0 -#define GL_OFFSET_TEXTURE_MATRIX_NV 0x86E1 -#define GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 -#define GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 -#define GL_OFFSET_TEXTURE_2D_MATRIX_NV GL_OFFSET_TEXTURE_MATRIX_NV -#define GL_OFFSET_TEXTURE_2D_SCALE_NV GL_OFFSET_TEXTURE_SCALE_NV -#define GL_OFFSET_TEXTURE_2D_BIAS_NV GL_OFFSET_TEXTURE_BIAS_NV -#define GL_PREVIOUS_TEXTURE_INPUT_NV 0x86E4 -#define GL_CONST_EYE_NV 0x86E5 -#define GL_PASS_THROUGH_NV 0x86E6 -#define GL_CULL_FRAGMENT_NV 0x86E7 -#define GL_OFFSET_TEXTURE_2D_NV 0x86E8 -#define GL_DEPENDENT_AR_TEXTURE_2D_NV 0x86E9 -#define GL_DEPENDENT_GB_TEXTURE_2D_NV 0x86EA -#define GL_ISOTROPIC_BRDF_NV 0x86EB -#define GL_DOT_PRODUCT_NV 0x86EC -#define GL_DOT_PRODUCT_DEPTH_REPLACE_NV 0x86ED -#define GL_DOT_PRODUCT_TEXTURE_2D_NV 0x86EE -#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF -#define GL_DOT_PRODUCT_TEXTURE_CUBE_MAP_NV 0x86F0 -#define GL_DOT_PRODUCT_DIFFUSE_CUBE_MAP_NV 0x86F1 -#define GL_DOT_PRODUCT_REFLECT_CUBE_MAP_NV 0x86F2 -#define GL_DOT_PRODUCT_CONST_EYE_REFLECT_CUBE_MAP_NV 0x86F3 -#define GL_HILO_NV 0x86F4 -#define GL_DSDT_NV 0x86F5 -#define GL_DSDT_MAG_NV 0x86F6 -#define GL_DSDT_MAG_VIB_NV 0x86F7 -#define GL_HILO16_NV 0x86F8 -#define GL_SIGNED_HILO_NV 0x86F9 -#define GL_SIGNED_HILO16_NV 0x86FA -#define GL_SIGNED_RGBA_NV 0x86FB -#define GL_SIGNED_RGBA8_NV 0x86FC -#define GL_SIGNED_RGB_NV 0x86FE -#define GL_SIGNED_RGB8_NV 0x86FF -#define GL_SIGNED_LUMINANCE_NV 0x8701 -#define GL_SIGNED_LUMINANCE8_NV 0x8702 -#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 -#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 -#define GL_SIGNED_ALPHA_NV 0x8705 -#define GL_SIGNED_ALPHA8_NV 0x8706 -#define GL_SIGNED_INTENSITY_NV 0x8707 -#define GL_SIGNED_INTENSITY8_NV 0x8708 -#define GL_DSDT8_NV 0x8709 -#define GL_DSDT8_MAG8_NV 0x870A -#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B -#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C -#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D -#define GL_HI_SCALE_NV 0x870E -#define GL_LO_SCALE_NV 0x870F -#define GL_DS_SCALE_NV 0x8710 -#define GL_DT_SCALE_NV 0x8711 -#define GL_MAGNITUDE_SCALE_NV 0x8712 -#define GL_VIBRANCE_SCALE_NV 0x8713 -#define GL_HI_BIAS_NV 0x8714 -#define GL_LO_BIAS_NV 0x8715 -#define GL_DS_BIAS_NV 0x8716 -#define GL_DT_BIAS_NV 0x8717 -#define GL_MAGNITUDE_BIAS_NV 0x8718 -#define GL_VIBRANCE_BIAS_NV 0x8719 -#define GL_TEXTURE_BORDER_VALUES_NV 0x871A -#define GL_TEXTURE_HI_SIZE_NV 0x871B -#define GL_TEXTURE_LO_SIZE_NV 0x871C -#define GL_TEXTURE_DS_SIZE_NV 0x871D -#define GL_TEXTURE_DT_SIZE_NV 0x871E -#define GL_TEXTURE_MAG_SIZE_NV 0x871F - -/* NV_texture_shader2 */ -#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF - -/* NV_register_combiners2 */ -#define GL_PER_STAGE_CONSTANTS_NV 0x8535 - -/* NV_packed_depth_stencil */ -#define GL_DEPTH_STENCIL_NV 0x84F9 -#define GL_UNSIGNED_INT_24_8_NV 0x84FA - -/* NV_multisample_filter_hint */ -#define GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 - -/* NV_texture_compression_vtc */ - -/* NV_vertex_program */ -typedef GLboolean (APIENTRY * PFNGLAREPROGRAMSRESIDENTNVPROC) (GLsizei n, const GLuint *programs, GLboolean *residences); -typedef void (APIENTRY * PFNGLBINDPROGRAMNVPROC) (GLenum target, GLuint id); -typedef void (APIENTRY * PFNGLDELETEPROGRAMSNVPROC) (GLsizei n, const GLuint *programs); -typedef void (APIENTRY * PFNGLEXECUTEPROGRAMNVPROC) (GLenum target, GLuint id, const GLfloat *params); -typedef void (APIENTRY * PFNGLGENPROGRAMSNVPROC) (GLsizei n, GLuint *programs); -typedef void (APIENTRY * PFNGLGETPROGRAMPARAMETERDVNVPROC) (GLenum target, GLuint index, GLenum pname, GLdouble *params); -typedef void (APIENTRY * PFNGLGETPROGRAMPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETPROGRAMIVNVPROC) (GLuint id, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETPROGRAMSTRINGNVPROC) (GLuint id, GLenum pname, GLubyte *program); -typedef void (APIENTRY * PFNGLGETTRACKMATRIXIVNVPROC) (GLenum target, GLuint address, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETVERTEXATTRIBDVNVPROC) (GLuint index, GLenum pname, GLdouble *params); -typedef void (APIENTRY * PFNGLGETVERTEXATTRIBFVNVPROC) (GLuint index, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETVERTEXATTRIBIVNVPROC) (GLuint index, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETVERTEXATTRIBPOINTERVNVPROC) (GLuint index, GLenum pname, GLvoid* *pointer); -typedef GLboolean (APIENTRY * PFNGLISPROGRAMNVPROC) (GLuint id); -typedef void (APIENTRY * PFNGLLOADPROGRAMNVPROC) (GLenum target, GLuint id, GLsizei len, const GLubyte *program); -typedef void (APIENTRY * PFNGLPROGRAMPARAMETER4DNVPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (APIENTRY * PFNGLPROGRAMPARAMETER4DVNVPROC) (GLenum target, GLuint index, const GLdouble *v); -typedef void (APIENTRY * PFNGLPROGRAMPARAMETER4FNVPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (APIENTRY * PFNGLPROGRAMPARAMETER4FVNVPROC) (GLenum target, GLuint index, const GLfloat *v); -typedef void (APIENTRY * PFNGLPROGRAMPARAMETERS4DVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLdouble *v); -typedef void (APIENTRY * PFNGLPROGRAMPARAMETERS4FVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat *v); -typedef void (APIENTRY * PFNGLREQUESTRESIDENTPROGRAMSNVPROC) (GLsizei n, const GLuint *programs); -typedef void (APIENTRY * PFNGLTRACKMATRIXNVPROC) (GLenum target, GLuint address, GLenum matrix, GLenum transform); -typedef void (APIENTRY * PFNGLVERTEXATTRIBPOINTERNVPROC) (GLuint index, GLint fsize, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (APIENTRY * PFNGLVERTEXATTRIB1DNVPROC) (GLuint index, GLdouble x); -typedef void (APIENTRY * PFNGLVERTEXATTRIB1DVNVPROC) (GLuint index, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB1FNVPROC) (GLuint index, GLfloat x); -typedef void (APIENTRY * PFNGLVERTEXATTRIB1FVNVPROC) (GLuint index, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB1SNVPROC) (GLuint index, GLshort x); -typedef void (APIENTRY * PFNGLVERTEXATTRIB1SVNVPROC) (GLuint index, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB2DNVPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (APIENTRY * PFNGLVERTEXATTRIB2DVNVPROC) (GLuint index, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB2FNVPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (APIENTRY * PFNGLVERTEXATTRIB2FVNVPROC) (GLuint index, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB2SNVPROC) (GLuint index, GLshort x, GLshort y); -typedef void (APIENTRY * PFNGLVERTEXATTRIB2SVNVPROC) (GLuint index, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB3DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (APIENTRY * PFNGLVERTEXATTRIB3DVNVPROC) (GLuint index, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB3FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (APIENTRY * PFNGLVERTEXATTRIB3FVNVPROC) (GLuint index, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB3SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (APIENTRY * PFNGLVERTEXATTRIB3SVNVPROC) (GLuint index, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4DVNVPROC) (GLuint index, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4FVNVPROC) (GLuint index, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4SVNVPROC) (GLuint index, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4UBNVPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (APIENTRY * PFNGLVERTEXATTRIB4UBVNVPROC) (GLuint index, const GLubyte *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS1DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS1FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS1SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS2DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS2FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS2SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS3DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS3FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS3SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS4DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS4FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS4SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); -typedef void (APIENTRY * PFNGLVERTEXATTRIBS4UBVNVPROC) (GLuint index, GLsizei count, const GLubyte *v); - -/* NV_evaluators */ -typedef void (APIENTRY * PFNGLMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const GLvoid *points); -typedef void (APIENTRY * PFNGLMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (APIENTRY * PFNGLMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLGETMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, GLvoid *points); -typedef void (APIENTRY * PFNGLGETMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLGETMAPATTRIBPARAMETERIVNVPROC) (GLenum target, GLuint index, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETMAPATTRIBPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat *params); -typedef void (APIENTRY * PFNGLEVALMAPSNVPROC) (GLenum target, GLenum mode); - -/* NV_fence */ -typedef void (APIENTRY * PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint *fences); -typedef void (APIENTRY * PFNGLGENFENCESNVPROC) (GLsizei n, GLuint *fences); -typedef GLboolean (APIENTRY * PFNGLISFENCENVPROC) (GLuint fence); -typedef GLboolean (APIENTRY * PFNGLTESTFENCENVPROC) (GLuint fence); -typedef void (APIENTRY * PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLFINISHFENCENVPROC) (GLuint fence); -typedef void (APIENTRY * PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); - -/* NV_occlusion_query */ -typedef void (APIENTRY * PFNGLGENOCCLUSIONQUERIESNVPROC) (GLsizei n, GLuint *ids); -typedef void (APIENTRY * PFNGLDELETEOCCLUSIONQUERIESNVPROC) (GLsizei n, const GLuint *ids); -typedef void (APIENTRY * PFNGLISOCCLUSIONQUERYNVPROC) (GLuint id); -typedef void (APIENTRY * PFNGLBEGINOCCLUSIONQUERYNVPROC) (GLuint id); -typedef void (APIENTRY * PFNGLENDOCCLUSIONQUERYNVPROC) (GLvoid); -typedef void (APIENTRY * PFNGLGETOCCLUSIONQUERYIVNVPROC) (GLuint id, GLenum pname, GLint *params); -typedef void (APIENTRY * PFNGLGETOCCLUSIONQUERYUIVNVPROC) (GLuint id, GLenum pname, GLuint *params); - -/* NV_point_sprite */ -typedef void (APIENTRY * PFNGLPOINTPARAMETERINVPROC) (GLenum pname, int param); -typedef void (APIENTRY * PFNGLPOINTPARAMETERIVNVPROC) (GLenum pname, const int *params); - -/* NV_register_combiners2 */ -typedef void (APIENTRY * PFNGLCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, const GLfloat *params); -typedef void (APIENTRY * PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, GLfloat *params); - - -#ifdef __cplusplus -} -#endif - -#endif - diff --git a/Demos/Glut/GL/glut.h b/Demos/Glut/GL/glut.h deleted file mode 100644 index 5662b6588..000000000 --- a/Demos/Glut/GL/glut.h +++ /dev/null @@ -1,22 +0,0 @@ -#ifndef __GLUT_H__ -#define __GLUT_H__ - -#define FREEGLUT_STATIC 1 -/* - * glut.h - * - * The freeglut library include file - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * PAWEL W. OLSZTA BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER - * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -#include "freeglut_std.h" - -/*** END OF FILE ***/ - -#endif /* __GLUT_H__ */ diff --git a/Demos/Glut/GL/glxew.h b/Demos/Glut/GL/glxew.h deleted file mode 100644 index 6d249f73e..000000000 --- a/Demos/Glut/GL/glxew.h +++ /dev/null @@ -1,1587 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -/* - * Mesa 3-D graphics library - * Version: 7.0 - * - * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* -** Copyright (c) 2007 The Khronos Group Inc. -** -** Permission is hereby granted, free of charge, to any person obtaining a -** copy of this software and/or associated documentation files (the -** "Materials"), to deal in the Materials without restriction, including -** without limitation the rights to use, copy, modify, merge, publish, -** distribute, sublicense, and/or sell copies of the Materials, and to -** permit persons to whom the Materials are furnished to do so, subject to -** the following conditions: -** -** The above copyright notice and this permission notice shall be included -** in all copies or substantial portions of the Materials. -** -** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. -*/ - -#ifndef __glxew_h__ -#define __glxew_h__ -#define __GLXEW_H__ - -#ifdef __glxext_h_ -#error glxext.h included before glxew.h -#endif - -#if defined(GLX_H) || defined(__GLX_glx_h__) || defined(__glx_h__) -#error glx.h included before glxew.h -#endif - -#define __glxext_h_ - -#define GLX_H -#define __GLX_glx_h__ -#define __glx_h__ - -#include -#include -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - -/* ---------------------------- GLX_VERSION_1_0 --------------------------- */ - -#ifndef GLX_VERSION_1_0 -#define GLX_VERSION_1_0 1 - -#define GLX_USE_GL 1 -#define GLX_BUFFER_SIZE 2 -#define GLX_LEVEL 3 -#define GLX_RGBA 4 -#define GLX_DOUBLEBUFFER 5 -#define GLX_STEREO 6 -#define GLX_AUX_BUFFERS 7 -#define GLX_RED_SIZE 8 -#define GLX_GREEN_SIZE 9 -#define GLX_BLUE_SIZE 10 -#define GLX_ALPHA_SIZE 11 -#define GLX_DEPTH_SIZE 12 -#define GLX_STENCIL_SIZE 13 -#define GLX_ACCUM_RED_SIZE 14 -#define GLX_ACCUM_GREEN_SIZE 15 -#define GLX_ACCUM_BLUE_SIZE 16 -#define GLX_ACCUM_ALPHA_SIZE 17 -#define GLX_BAD_SCREEN 1 -#define GLX_BAD_ATTRIBUTE 2 -#define GLX_NO_EXTENSION 3 -#define GLX_BAD_VISUAL 4 -#define GLX_BAD_CONTEXT 5 -#define GLX_BAD_VALUE 6 -#define GLX_BAD_ENUM 7 - -typedef XID GLXDrawable; -typedef XID GLXPixmap; -#ifdef __sun -typedef struct __glXContextRec *GLXContext; -#else -typedef struct __GLXcontextRec *GLXContext; -#endif - -typedef unsigned int GLXVideoDeviceNV; - -extern Bool glXQueryExtension (Display *dpy, int *errorBase, int *eventBase); -extern Bool glXQueryVersion (Display *dpy, int *major, int *minor); -extern int glXGetConfig (Display *dpy, XVisualInfo *vis, int attrib, int *value); -extern XVisualInfo* glXChooseVisual (Display *dpy, int screen, int *attribList); -extern GLXPixmap glXCreateGLXPixmap (Display *dpy, XVisualInfo *vis, Pixmap pixmap); -extern void glXDestroyGLXPixmap (Display *dpy, GLXPixmap pix); -extern GLXContext glXCreateContext (Display *dpy, XVisualInfo *vis, GLXContext shareList, Bool direct); -extern void glXDestroyContext (Display *dpy, GLXContext ctx); -extern Bool glXIsDirect (Display *dpy, GLXContext ctx); -extern void glXCopyContext (Display *dpy, GLXContext src, GLXContext dst, GLulong mask); -extern Bool glXMakeCurrent (Display *dpy, GLXDrawable drawable, GLXContext ctx); -extern GLXContext glXGetCurrentContext (void); -extern GLXDrawable glXGetCurrentDrawable (void); -extern void glXWaitGL (void); -extern void glXWaitX (void); -extern void glXSwapBuffers (Display *dpy, GLXDrawable drawable); -extern void glXUseXFont (Font font, int first, int count, int listBase); - -#define GLXEW_VERSION_1_0 GLXEW_GET_VAR(__GLXEW_VERSION_1_0) - -#endif /* GLX_VERSION_1_0 */ - -/* ---------------------------- GLX_VERSION_1_1 --------------------------- */ - -#ifndef GLX_VERSION_1_1 -#define GLX_VERSION_1_1 - -#define GLX_VENDOR 0x1 -#define GLX_VERSION 0x2 -#define GLX_EXTENSIONS 0x3 - -extern const char* glXQueryExtensionsString (Display *dpy, int screen); -extern const char* glXGetClientString (Display *dpy, int name); -extern const char* glXQueryServerString (Display *dpy, int screen, int name); - -#define GLXEW_VERSION_1_1 GLXEW_GET_VAR(__GLXEW_VERSION_1_1) - -#endif /* GLX_VERSION_1_1 */ - -/* ---------------------------- GLX_VERSION_1_2 ---------------------------- */ - -#ifndef GLX_VERSION_1_2 -#define GLX_VERSION_1_2 1 - -typedef Display* ( * PFNGLXGETCURRENTDISPLAYPROC) (void); - -#define glXGetCurrentDisplay GLXEW_GET_FUN(__glewXGetCurrentDisplay) - -#define GLXEW_VERSION_1_2 GLXEW_GET_VAR(__GLXEW_VERSION_1_2) - -#endif /* GLX_VERSION_1_2 */ - -/* ---------------------------- GLX_VERSION_1_3 ---------------------------- */ - -#ifndef GLX_VERSION_1_3 -#define GLX_VERSION_1_3 1 - -#define GLX_RGBA_BIT 0x00000001 -#define GLX_FRONT_LEFT_BUFFER_BIT 0x00000001 -#define GLX_WINDOW_BIT 0x00000001 -#define GLX_COLOR_INDEX_BIT 0x00000002 -#define GLX_PIXMAP_BIT 0x00000002 -#define GLX_FRONT_RIGHT_BUFFER_BIT 0x00000002 -#define GLX_BACK_LEFT_BUFFER_BIT 0x00000004 -#define GLX_PBUFFER_BIT 0x00000004 -#define GLX_BACK_RIGHT_BUFFER_BIT 0x00000008 -#define GLX_AUX_BUFFERS_BIT 0x00000010 -#define GLX_CONFIG_CAVEAT 0x20 -#define GLX_DEPTH_BUFFER_BIT 0x00000020 -#define GLX_X_VISUAL_TYPE 0x22 -#define GLX_TRANSPARENT_TYPE 0x23 -#define GLX_TRANSPARENT_INDEX_VALUE 0x24 -#define GLX_TRANSPARENT_RED_VALUE 0x25 -#define GLX_TRANSPARENT_GREEN_VALUE 0x26 -#define GLX_TRANSPARENT_BLUE_VALUE 0x27 -#define GLX_TRANSPARENT_ALPHA_VALUE 0x28 -#define GLX_STENCIL_BUFFER_BIT 0x00000040 -#define GLX_ACCUM_BUFFER_BIT 0x00000080 -#define GLX_NONE 0x8000 -#define GLX_SLOW_CONFIG 0x8001 -#define GLX_TRUE_COLOR 0x8002 -#define GLX_DIRECT_COLOR 0x8003 -#define GLX_PSEUDO_COLOR 0x8004 -#define GLX_STATIC_COLOR 0x8005 -#define GLX_GRAY_SCALE 0x8006 -#define GLX_STATIC_GRAY 0x8007 -#define GLX_TRANSPARENT_RGB 0x8008 -#define GLX_TRANSPARENT_INDEX 0x8009 -#define GLX_VISUAL_ID 0x800B -#define GLX_SCREEN 0x800C -#define GLX_NON_CONFORMANT_CONFIG 0x800D -#define GLX_DRAWABLE_TYPE 0x8010 -#define GLX_RENDER_TYPE 0x8011 -#define GLX_X_RENDERABLE 0x8012 -#define GLX_FBCONFIG_ID 0x8013 -#define GLX_RGBA_TYPE 0x8014 -#define GLX_COLOR_INDEX_TYPE 0x8015 -#define GLX_MAX_PBUFFER_WIDTH 0x8016 -#define GLX_MAX_PBUFFER_HEIGHT 0x8017 -#define GLX_MAX_PBUFFER_PIXELS 0x8018 -#define GLX_PRESERVED_CONTENTS 0x801B -#define GLX_LARGEST_PBUFFER 0x801C -#define GLX_WIDTH 0x801D -#define GLX_HEIGHT 0x801E -#define GLX_EVENT_MASK 0x801F -#define GLX_DAMAGED 0x8020 -#define GLX_SAVED 0x8021 -#define GLX_WINDOW 0x8022 -#define GLX_PBUFFER 0x8023 -#define GLX_PBUFFER_HEIGHT 0x8040 -#define GLX_PBUFFER_WIDTH 0x8041 -#define GLX_PBUFFER_CLOBBER_MASK 0x08000000 -#define GLX_DONT_CARE 0xFFFFFFFF - -typedef XID GLXFBConfigID; -typedef XID GLXPbuffer; -typedef XID GLXWindow; -typedef struct __GLXFBConfigRec *GLXFBConfig; - -typedef struct { - int event_type; - int draw_type; - unsigned long serial; - Bool send_event; - Display *display; - GLXDrawable drawable; - unsigned int buffer_mask; - unsigned int aux_buffer; - int x, y; - int width, height; - int count; -} GLXPbufferClobberEvent; -typedef union __GLXEvent { - GLXPbufferClobberEvent glxpbufferclobber; - long pad[24]; -} GLXEvent; - -typedef GLXFBConfig* ( * PFNGLXCHOOSEFBCONFIGPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); -typedef GLXContext ( * PFNGLXCREATENEWCONTEXTPROC) (Display *dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); -typedef GLXPbuffer ( * PFNGLXCREATEPBUFFERPROC) (Display *dpy, GLXFBConfig config, const int *attrib_list); -typedef GLXPixmap ( * PFNGLXCREATEPIXMAPPROC) (Display *dpy, GLXFBConfig config, Pixmap pixmap, const int *attrib_list); -typedef GLXWindow ( * PFNGLXCREATEWINDOWPROC) (Display *dpy, GLXFBConfig config, Window win, const int *attrib_list); -typedef void ( * PFNGLXDESTROYPBUFFERPROC) (Display *dpy, GLXPbuffer pbuf); -typedef void ( * PFNGLXDESTROYPIXMAPPROC) (Display *dpy, GLXPixmap pixmap); -typedef void ( * PFNGLXDESTROYWINDOWPROC) (Display *dpy, GLXWindow win); -typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLEPROC) (void); -typedef int ( * PFNGLXGETFBCONFIGATTRIBPROC) (Display *dpy, GLXFBConfig config, int attribute, int *value); -typedef GLXFBConfig* ( * PFNGLXGETFBCONFIGSPROC) (Display *dpy, int screen, int *nelements); -typedef void ( * PFNGLXGETSELECTEDEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long *event_mask); -typedef XVisualInfo* ( * PFNGLXGETVISUALFROMFBCONFIGPROC) (Display *dpy, GLXFBConfig config); -typedef Bool ( * PFNGLXMAKECONTEXTCURRENTPROC) (Display *display, GLXDrawable draw, GLXDrawable read, GLXContext ctx); -typedef int ( * PFNGLXQUERYCONTEXTPROC) (Display *dpy, GLXContext ctx, int attribute, int *value); -typedef void ( * PFNGLXQUERYDRAWABLEPROC) (Display *dpy, GLXDrawable draw, int attribute, unsigned int *value); -typedef void ( * PFNGLXSELECTEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long event_mask); - -#define glXChooseFBConfig GLXEW_GET_FUN(__glewXChooseFBConfig) -#define glXCreateNewContext GLXEW_GET_FUN(__glewXCreateNewContext) -#define glXCreatePbuffer GLXEW_GET_FUN(__glewXCreatePbuffer) -#define glXCreatePixmap GLXEW_GET_FUN(__glewXCreatePixmap) -#define glXCreateWindow GLXEW_GET_FUN(__glewXCreateWindow) -#define glXDestroyPbuffer GLXEW_GET_FUN(__glewXDestroyPbuffer) -#define glXDestroyPixmap GLXEW_GET_FUN(__glewXDestroyPixmap) -#define glXDestroyWindow GLXEW_GET_FUN(__glewXDestroyWindow) -#define glXGetCurrentReadDrawable GLXEW_GET_FUN(__glewXGetCurrentReadDrawable) -#define glXGetFBConfigAttrib GLXEW_GET_FUN(__glewXGetFBConfigAttrib) -#define glXGetFBConfigs GLXEW_GET_FUN(__glewXGetFBConfigs) -#define glXGetSelectedEvent GLXEW_GET_FUN(__glewXGetSelectedEvent) -#define glXGetVisualFromFBConfig GLXEW_GET_FUN(__glewXGetVisualFromFBConfig) -#define glXMakeContextCurrent GLXEW_GET_FUN(__glewXMakeContextCurrent) -#define glXQueryContext GLXEW_GET_FUN(__glewXQueryContext) -#define glXQueryDrawable GLXEW_GET_FUN(__glewXQueryDrawable) -#define glXSelectEvent GLXEW_GET_FUN(__glewXSelectEvent) - -#define GLXEW_VERSION_1_3 GLXEW_GET_VAR(__GLXEW_VERSION_1_3) - -#endif /* GLX_VERSION_1_3 */ - -/* ---------------------------- GLX_VERSION_1_4 ---------------------------- */ - -#ifndef GLX_VERSION_1_4 -#define GLX_VERSION_1_4 1 - -#define GLX_SAMPLE_BUFFERS 100000 -#define GLX_SAMPLES 100001 - -extern void ( * glXGetProcAddress (const GLubyte *procName)) (void); - -#define GLXEW_VERSION_1_4 GLXEW_GET_VAR(__GLXEW_VERSION_1_4) - -#endif /* GLX_VERSION_1_4 */ - -/* -------------------------- GLX_3DFX_multisample ------------------------- */ - -#ifndef GLX_3DFX_multisample -#define GLX_3DFX_multisample 1 - -#define GLX_SAMPLE_BUFFERS_3DFX 0x8050 -#define GLX_SAMPLES_3DFX 0x8051 - -#define GLXEW_3DFX_multisample GLXEW_GET_VAR(__GLXEW_3DFX_multisample) - -#endif /* GLX_3DFX_multisample */ - -/* ------------------------ GLX_AMD_gpu_association ------------------------ */ - -#ifndef GLX_AMD_gpu_association -#define GLX_AMD_gpu_association 1 - -#define GLX_GPU_VENDOR_AMD 0x1F00 -#define GLX_GPU_RENDERER_STRING_AMD 0x1F01 -#define GLX_GPU_OPENGL_VERSION_STRING_AMD 0x1F02 -#define GLX_GPU_FASTEST_TARGET_GPUS_AMD 0x21A2 -#define GLX_GPU_RAM_AMD 0x21A3 -#define GLX_GPU_CLOCK_AMD 0x21A4 -#define GLX_GPU_NUM_PIPES_AMD 0x21A5 -#define GLX_GPU_NUM_SIMD_AMD 0x21A6 -#define GLX_GPU_NUM_RB_AMD 0x21A7 -#define GLX_GPU_NUM_SPI_AMD 0x21A8 - -#define GLXEW_AMD_gpu_association GLXEW_GET_VAR(__GLXEW_AMD_gpu_association) - -#endif /* GLX_AMD_gpu_association */ - -/* ------------------------- GLX_ARB_create_context ------------------------ */ - -#ifndef GLX_ARB_create_context -#define GLX_ARB_create_context 1 - -#define GLX_CONTEXT_DEBUG_BIT_ARB 0x0001 -#define GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 -#define GLX_CONTEXT_MAJOR_VERSION_ARB 0x2091 -#define GLX_CONTEXT_MINOR_VERSION_ARB 0x2092 -#define GLX_CONTEXT_FLAGS_ARB 0x2094 - -typedef GLXContext ( * PFNGLXCREATECONTEXTATTRIBSARBPROC) (Display* dpy, GLXFBConfig config, GLXContext share_context, Bool direct, const int *attrib_list); - -#define glXCreateContextAttribsARB GLXEW_GET_FUN(__glewXCreateContextAttribsARB) - -#define GLXEW_ARB_create_context GLXEW_GET_VAR(__GLXEW_ARB_create_context) - -#endif /* GLX_ARB_create_context */ - -/* --------------------- GLX_ARB_create_context_profile -------------------- */ - -#ifndef GLX_ARB_create_context_profile -#define GLX_ARB_create_context_profile 1 - -#define GLX_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 -#define GLX_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 -#define GLX_CONTEXT_PROFILE_MASK_ARB 0x9126 - -#define GLXEW_ARB_create_context_profile GLXEW_GET_VAR(__GLXEW_ARB_create_context_profile) - -#endif /* GLX_ARB_create_context_profile */ - -/* ------------------- GLX_ARB_create_context_robustness ------------------- */ - -#ifndef GLX_ARB_create_context_robustness -#define GLX_ARB_create_context_robustness 1 - -#define GLX_CONTEXT_ROBUST_ACCESS_BIT_ARB 0x00000004 -#define GLX_LOSE_CONTEXT_ON_RESET_ARB 0x8252 -#define GLX_CONTEXT_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 -#define GLX_NO_RESET_NOTIFICATION_ARB 0x8261 - -#define GLXEW_ARB_create_context_robustness GLXEW_GET_VAR(__GLXEW_ARB_create_context_robustness) - -#endif /* GLX_ARB_create_context_robustness */ - -/* ------------------------- GLX_ARB_fbconfig_float ------------------------ */ - -#ifndef GLX_ARB_fbconfig_float -#define GLX_ARB_fbconfig_float 1 - -#define GLX_RGBA_FLOAT_BIT 0x00000004 -#define GLX_RGBA_FLOAT_TYPE 0x20B9 - -#define GLXEW_ARB_fbconfig_float GLXEW_GET_VAR(__GLXEW_ARB_fbconfig_float) - -#endif /* GLX_ARB_fbconfig_float */ - -/* ------------------------ GLX_ARB_framebuffer_sRGB ----------------------- */ - -#ifndef GLX_ARB_framebuffer_sRGB -#define GLX_ARB_framebuffer_sRGB 1 - -#define GLX_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20B2 - -#define GLXEW_ARB_framebuffer_sRGB GLXEW_GET_VAR(__GLXEW_ARB_framebuffer_sRGB) - -#endif /* GLX_ARB_framebuffer_sRGB */ - -/* ------------------------ GLX_ARB_get_proc_address ----------------------- */ - -#ifndef GLX_ARB_get_proc_address -#define GLX_ARB_get_proc_address 1 - -extern void ( * glXGetProcAddressARB (const GLubyte *procName)) (void); - -#define GLXEW_ARB_get_proc_address GLXEW_GET_VAR(__GLXEW_ARB_get_proc_address) - -#endif /* GLX_ARB_get_proc_address */ - -/* -------------------------- GLX_ARB_multisample -------------------------- */ - -#ifndef GLX_ARB_multisample -#define GLX_ARB_multisample 1 - -#define GLX_SAMPLE_BUFFERS_ARB 100000 -#define GLX_SAMPLES_ARB 100001 - -#define GLXEW_ARB_multisample GLXEW_GET_VAR(__GLXEW_ARB_multisample) - -#endif /* GLX_ARB_multisample */ - -/* ---------------------- GLX_ARB_vertex_buffer_object --------------------- */ - -#ifndef GLX_ARB_vertex_buffer_object -#define GLX_ARB_vertex_buffer_object 1 - -#define GLX_CONTEXT_ALLOW_BUFFER_BYTE_ORDER_MISMATCH_ARB 0x2095 - -#define GLXEW_ARB_vertex_buffer_object GLXEW_GET_VAR(__GLXEW_ARB_vertex_buffer_object) - -#endif /* GLX_ARB_vertex_buffer_object */ - -/* ----------------------- GLX_ATI_pixel_format_float ---------------------- */ - -#ifndef GLX_ATI_pixel_format_float -#define GLX_ATI_pixel_format_float 1 - -#define GLX_RGBA_FLOAT_ATI_BIT 0x00000100 - -#define GLXEW_ATI_pixel_format_float GLXEW_GET_VAR(__GLXEW_ATI_pixel_format_float) - -#endif /* GLX_ATI_pixel_format_float */ - -/* ------------------------- GLX_ATI_render_texture ------------------------ */ - -#ifndef GLX_ATI_render_texture -#define GLX_ATI_render_texture 1 - -#define GLX_BIND_TO_TEXTURE_RGB_ATI 0x9800 -#define GLX_BIND_TO_TEXTURE_RGBA_ATI 0x9801 -#define GLX_TEXTURE_FORMAT_ATI 0x9802 -#define GLX_TEXTURE_TARGET_ATI 0x9803 -#define GLX_MIPMAP_TEXTURE_ATI 0x9804 -#define GLX_TEXTURE_RGB_ATI 0x9805 -#define GLX_TEXTURE_RGBA_ATI 0x9806 -#define GLX_NO_TEXTURE_ATI 0x9807 -#define GLX_TEXTURE_CUBE_MAP_ATI 0x9808 -#define GLX_TEXTURE_1D_ATI 0x9809 -#define GLX_TEXTURE_2D_ATI 0x980A -#define GLX_MIPMAP_LEVEL_ATI 0x980B -#define GLX_CUBE_MAP_FACE_ATI 0x980C -#define GLX_TEXTURE_CUBE_MAP_POSITIVE_X_ATI 0x980D -#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_X_ATI 0x980E -#define GLX_TEXTURE_CUBE_MAP_POSITIVE_Y_ATI 0x980F -#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_Y_ATI 0x9810 -#define GLX_TEXTURE_CUBE_MAP_POSITIVE_Z_ATI 0x9811 -#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_Z_ATI 0x9812 -#define GLX_FRONT_LEFT_ATI 0x9813 -#define GLX_FRONT_RIGHT_ATI 0x9814 -#define GLX_BACK_LEFT_ATI 0x9815 -#define GLX_BACK_RIGHT_ATI 0x9816 -#define GLX_AUX0_ATI 0x9817 -#define GLX_AUX1_ATI 0x9818 -#define GLX_AUX2_ATI 0x9819 -#define GLX_AUX3_ATI 0x981A -#define GLX_AUX4_ATI 0x981B -#define GLX_AUX5_ATI 0x981C -#define GLX_AUX6_ATI 0x981D -#define GLX_AUX7_ATI 0x981E -#define GLX_AUX8_ATI 0x981F -#define GLX_AUX9_ATI 0x9820 -#define GLX_BIND_TO_TEXTURE_LUMINANCE_ATI 0x9821 -#define GLX_BIND_TO_TEXTURE_INTENSITY_ATI 0x9822 - -typedef void ( * PFNGLXBINDTEXIMAGEATIPROC) (Display *dpy, GLXPbuffer pbuf, int buffer); -typedef void ( * PFNGLXDRAWABLEATTRIBATIPROC) (Display *dpy, GLXDrawable draw, const int *attrib_list); -typedef void ( * PFNGLXRELEASETEXIMAGEATIPROC) (Display *dpy, GLXPbuffer pbuf, int buffer); - -#define glXBindTexImageATI GLXEW_GET_FUN(__glewXBindTexImageATI) -#define glXDrawableAttribATI GLXEW_GET_FUN(__glewXDrawableAttribATI) -#define glXReleaseTexImageATI GLXEW_GET_FUN(__glewXReleaseTexImageATI) - -#define GLXEW_ATI_render_texture GLXEW_GET_VAR(__GLXEW_ATI_render_texture) - -#endif /* GLX_ATI_render_texture */ - -/* ------------------- GLX_EXT_create_context_es2_profile ------------------ */ - -#ifndef GLX_EXT_create_context_es2_profile -#define GLX_EXT_create_context_es2_profile 1 - -#define GLX_CONTEXT_ES2_PROFILE_BIT_EXT 0x00000004 - -#define GLXEW_EXT_create_context_es2_profile GLXEW_GET_VAR(__GLXEW_EXT_create_context_es2_profile) - -#endif /* GLX_EXT_create_context_es2_profile */ - -/* --------------------- GLX_EXT_fbconfig_packed_float --------------------- */ - -#ifndef GLX_EXT_fbconfig_packed_float -#define GLX_EXT_fbconfig_packed_float 1 - -#define GLX_RGBA_UNSIGNED_FLOAT_BIT_EXT 0x00000008 -#define GLX_RGBA_UNSIGNED_FLOAT_TYPE_EXT 0x20B1 - -#define GLXEW_EXT_fbconfig_packed_float GLXEW_GET_VAR(__GLXEW_EXT_fbconfig_packed_float) - -#endif /* GLX_EXT_fbconfig_packed_float */ - -/* ------------------------ GLX_EXT_framebuffer_sRGB ----------------------- */ - -#ifndef GLX_EXT_framebuffer_sRGB -#define GLX_EXT_framebuffer_sRGB 1 - -#define GLX_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20B2 - -#define GLXEW_EXT_framebuffer_sRGB GLXEW_GET_VAR(__GLXEW_EXT_framebuffer_sRGB) - -#endif /* GLX_EXT_framebuffer_sRGB */ - -/* ------------------------- GLX_EXT_import_context ------------------------ */ - -#ifndef GLX_EXT_import_context -#define GLX_EXT_import_context 1 - -#define GLX_SHARE_CONTEXT_EXT 0x800A -#define GLX_VISUAL_ID_EXT 0x800B -#define GLX_SCREEN_EXT 0x800C - -typedef XID GLXContextID; - -typedef void ( * PFNGLXFREECONTEXTEXTPROC) (Display* dpy, GLXContext context); -typedef GLXContextID ( * PFNGLXGETCONTEXTIDEXTPROC) (const GLXContext context); -typedef GLXContext ( * PFNGLXIMPORTCONTEXTEXTPROC) (Display* dpy, GLXContextID contextID); -typedef int ( * PFNGLXQUERYCONTEXTINFOEXTPROC) (Display* dpy, GLXContext context, int attribute,int *value); - -#define glXFreeContextEXT GLXEW_GET_FUN(__glewXFreeContextEXT) -#define glXGetContextIDEXT GLXEW_GET_FUN(__glewXGetContextIDEXT) -#define glXImportContextEXT GLXEW_GET_FUN(__glewXImportContextEXT) -#define glXQueryContextInfoEXT GLXEW_GET_FUN(__glewXQueryContextInfoEXT) - -#define GLXEW_EXT_import_context GLXEW_GET_VAR(__GLXEW_EXT_import_context) - -#endif /* GLX_EXT_import_context */ - -/* -------------------------- GLX_EXT_scene_marker ------------------------- */ - -#ifndef GLX_EXT_scene_marker -#define GLX_EXT_scene_marker 1 - -#define GLXEW_EXT_scene_marker GLXEW_GET_VAR(__GLXEW_EXT_scene_marker) - -#endif /* GLX_EXT_scene_marker */ - -/* -------------------------- GLX_EXT_swap_control ------------------------- */ - -#ifndef GLX_EXT_swap_control -#define GLX_EXT_swap_control 1 - -#define GLX_SWAP_INTERVAL_EXT 0x20F1 -#define GLX_MAX_SWAP_INTERVAL_EXT 0x20F2 - -typedef void ( * PFNGLXSWAPINTERVALEXTPROC) (Display* dpy, GLXDrawable drawable, int interval); - -#define glXSwapIntervalEXT GLXEW_GET_FUN(__glewXSwapIntervalEXT) - -#define GLXEW_EXT_swap_control GLXEW_GET_VAR(__GLXEW_EXT_swap_control) - -#endif /* GLX_EXT_swap_control */ - -/* ---------------------- GLX_EXT_texture_from_pixmap ---------------------- */ - -#ifndef GLX_EXT_texture_from_pixmap -#define GLX_EXT_texture_from_pixmap 1 - -#define GLX_TEXTURE_1D_BIT_EXT 0x00000001 -#define GLX_TEXTURE_2D_BIT_EXT 0x00000002 -#define GLX_TEXTURE_RECTANGLE_BIT_EXT 0x00000004 -#define GLX_BIND_TO_TEXTURE_RGB_EXT 0x20D0 -#define GLX_BIND_TO_TEXTURE_RGBA_EXT 0x20D1 -#define GLX_BIND_TO_MIPMAP_TEXTURE_EXT 0x20D2 -#define GLX_BIND_TO_TEXTURE_TARGETS_EXT 0x20D3 -#define GLX_Y_INVERTED_EXT 0x20D4 -#define GLX_TEXTURE_FORMAT_EXT 0x20D5 -#define GLX_TEXTURE_TARGET_EXT 0x20D6 -#define GLX_MIPMAP_TEXTURE_EXT 0x20D7 -#define GLX_TEXTURE_FORMAT_NONE_EXT 0x20D8 -#define GLX_TEXTURE_FORMAT_RGB_EXT 0x20D9 -#define GLX_TEXTURE_FORMAT_RGBA_EXT 0x20DA -#define GLX_TEXTURE_1D_EXT 0x20DB -#define GLX_TEXTURE_2D_EXT 0x20DC -#define GLX_TEXTURE_RECTANGLE_EXT 0x20DD -#define GLX_FRONT_LEFT_EXT 0x20DE -#define GLX_FRONT_RIGHT_EXT 0x20DF -#define GLX_BACK_LEFT_EXT 0x20E0 -#define GLX_BACK_RIGHT_EXT 0x20E1 -#define GLX_AUX0_EXT 0x20E2 -#define GLX_AUX1_EXT 0x20E3 -#define GLX_AUX2_EXT 0x20E4 -#define GLX_AUX3_EXT 0x20E5 -#define GLX_AUX4_EXT 0x20E6 -#define GLX_AUX5_EXT 0x20E7 -#define GLX_AUX6_EXT 0x20E8 -#define GLX_AUX7_EXT 0x20E9 -#define GLX_AUX8_EXT 0x20EA -#define GLX_AUX9_EXT 0x20EB - -typedef void ( * PFNGLXBINDTEXIMAGEEXTPROC) (Display* display, GLXDrawable drawable, int buffer, const int *attrib_list); -typedef void ( * PFNGLXRELEASETEXIMAGEEXTPROC) (Display* display, GLXDrawable drawable, int buffer); - -#define glXBindTexImageEXT GLXEW_GET_FUN(__glewXBindTexImageEXT) -#define glXReleaseTexImageEXT GLXEW_GET_FUN(__glewXReleaseTexImageEXT) - -#define GLXEW_EXT_texture_from_pixmap GLXEW_GET_VAR(__GLXEW_EXT_texture_from_pixmap) - -#endif /* GLX_EXT_texture_from_pixmap */ - -/* -------------------------- GLX_EXT_visual_info -------------------------- */ - -#ifndef GLX_EXT_visual_info -#define GLX_EXT_visual_info 1 - -#define GLX_X_VISUAL_TYPE_EXT 0x22 -#define GLX_TRANSPARENT_TYPE_EXT 0x23 -#define GLX_TRANSPARENT_INDEX_VALUE_EXT 0x24 -#define GLX_TRANSPARENT_RED_VALUE_EXT 0x25 -#define GLX_TRANSPARENT_GREEN_VALUE_EXT 0x26 -#define GLX_TRANSPARENT_BLUE_VALUE_EXT 0x27 -#define GLX_TRANSPARENT_ALPHA_VALUE_EXT 0x28 -#define GLX_NONE_EXT 0x8000 -#define GLX_TRUE_COLOR_EXT 0x8002 -#define GLX_DIRECT_COLOR_EXT 0x8003 -#define GLX_PSEUDO_COLOR_EXT 0x8004 -#define GLX_STATIC_COLOR_EXT 0x8005 -#define GLX_GRAY_SCALE_EXT 0x8006 -#define GLX_STATIC_GRAY_EXT 0x8007 -#define GLX_TRANSPARENT_RGB_EXT 0x8008 -#define GLX_TRANSPARENT_INDEX_EXT 0x8009 - -#define GLXEW_EXT_visual_info GLXEW_GET_VAR(__GLXEW_EXT_visual_info) - -#endif /* GLX_EXT_visual_info */ - -/* ------------------------- GLX_EXT_visual_rating ------------------------- */ - -#ifndef GLX_EXT_visual_rating -#define GLX_EXT_visual_rating 1 - -#define GLX_VISUAL_CAVEAT_EXT 0x20 -#define GLX_SLOW_VISUAL_EXT 0x8001 -#define GLX_NON_CONFORMANT_VISUAL_EXT 0x800D - -#define GLXEW_EXT_visual_rating GLXEW_GET_VAR(__GLXEW_EXT_visual_rating) - -#endif /* GLX_EXT_visual_rating */ - -/* -------------------------- GLX_INTEL_swap_event ------------------------- */ - -#ifndef GLX_INTEL_swap_event -#define GLX_INTEL_swap_event 1 - -#define GLX_EXCHANGE_COMPLETE_INTEL 0x8180 -#define GLX_COPY_COMPLETE_INTEL 0x8181 -#define GLX_FLIP_COMPLETE_INTEL 0x8182 -#define GLX_BUFFER_SWAP_COMPLETE_INTEL_MASK 0x04000000 - -#define GLXEW_INTEL_swap_event GLXEW_GET_VAR(__GLXEW_INTEL_swap_event) - -#endif /* GLX_INTEL_swap_event */ - -/* -------------------------- GLX_MESA_agp_offset -------------------------- */ - -#ifndef GLX_MESA_agp_offset -#define GLX_MESA_agp_offset 1 - -typedef unsigned int ( * PFNGLXGETAGPOFFSETMESAPROC) (const void* pointer); - -#define glXGetAGPOffsetMESA GLXEW_GET_FUN(__glewXGetAGPOffsetMESA) - -#define GLXEW_MESA_agp_offset GLXEW_GET_VAR(__GLXEW_MESA_agp_offset) - -#endif /* GLX_MESA_agp_offset */ - -/* ------------------------ GLX_MESA_copy_sub_buffer ----------------------- */ - -#ifndef GLX_MESA_copy_sub_buffer -#define GLX_MESA_copy_sub_buffer 1 - -typedef void ( * PFNGLXCOPYSUBBUFFERMESAPROC) (Display* dpy, GLXDrawable drawable, int x, int y, int width, int height); - -#define glXCopySubBufferMESA GLXEW_GET_FUN(__glewXCopySubBufferMESA) - -#define GLXEW_MESA_copy_sub_buffer GLXEW_GET_VAR(__GLXEW_MESA_copy_sub_buffer) - -#endif /* GLX_MESA_copy_sub_buffer */ - -/* ------------------------ GLX_MESA_pixmap_colormap ----------------------- */ - -#ifndef GLX_MESA_pixmap_colormap -#define GLX_MESA_pixmap_colormap 1 - -typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPMESAPROC) (Display* dpy, XVisualInfo *visual, Pixmap pixmap, Colormap cmap); - -#define glXCreateGLXPixmapMESA GLXEW_GET_FUN(__glewXCreateGLXPixmapMESA) - -#define GLXEW_MESA_pixmap_colormap GLXEW_GET_VAR(__GLXEW_MESA_pixmap_colormap) - -#endif /* GLX_MESA_pixmap_colormap */ - -/* ------------------------ GLX_MESA_release_buffers ----------------------- */ - -#ifndef GLX_MESA_release_buffers -#define GLX_MESA_release_buffers 1 - -typedef Bool ( * PFNGLXRELEASEBUFFERSMESAPROC) (Display* dpy, GLXDrawable d); - -#define glXReleaseBuffersMESA GLXEW_GET_FUN(__glewXReleaseBuffersMESA) - -#define GLXEW_MESA_release_buffers GLXEW_GET_VAR(__GLXEW_MESA_release_buffers) - -#endif /* GLX_MESA_release_buffers */ - -/* ------------------------- GLX_MESA_set_3dfx_mode ------------------------ */ - -#ifndef GLX_MESA_set_3dfx_mode -#define GLX_MESA_set_3dfx_mode 1 - -#define GLX_3DFX_WINDOW_MODE_MESA 0x1 -#define GLX_3DFX_FULLSCREEN_MODE_MESA 0x2 - -typedef GLboolean ( * PFNGLXSET3DFXMODEMESAPROC) (GLint mode); - -#define glXSet3DfxModeMESA GLXEW_GET_FUN(__glewXSet3DfxModeMESA) - -#define GLXEW_MESA_set_3dfx_mode GLXEW_GET_VAR(__GLXEW_MESA_set_3dfx_mode) - -#endif /* GLX_MESA_set_3dfx_mode */ - -/* ------------------------- GLX_MESA_swap_control ------------------------- */ - -#ifndef GLX_MESA_swap_control -#define GLX_MESA_swap_control 1 - -typedef int ( * PFNGLXGETSWAPINTERVALMESAPROC) (void); -typedef int ( * PFNGLXSWAPINTERVALMESAPROC) (unsigned int interval); - -#define glXGetSwapIntervalMESA GLXEW_GET_FUN(__glewXGetSwapIntervalMESA) -#define glXSwapIntervalMESA GLXEW_GET_FUN(__glewXSwapIntervalMESA) - -#define GLXEW_MESA_swap_control GLXEW_GET_VAR(__GLXEW_MESA_swap_control) - -#endif /* GLX_MESA_swap_control */ - -/* --------------------------- GLX_NV_copy_image --------------------------- */ - -#ifndef GLX_NV_copy_image -#define GLX_NV_copy_image 1 - -typedef void ( * PFNGLXCOPYIMAGESUBDATANVPROC) (Display *dpy, GLXContext srcCtx, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLXContext dstCtx, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); - -#define glXCopyImageSubDataNV GLXEW_GET_FUN(__glewXCopyImageSubDataNV) - -#define GLXEW_NV_copy_image GLXEW_GET_VAR(__GLXEW_NV_copy_image) - -#endif /* GLX_NV_copy_image */ - -/* -------------------------- GLX_NV_float_buffer -------------------------- */ - -#ifndef GLX_NV_float_buffer -#define GLX_NV_float_buffer 1 - -#define GLX_FLOAT_COMPONENTS_NV 0x20B0 - -#define GLXEW_NV_float_buffer GLXEW_GET_VAR(__GLXEW_NV_float_buffer) - -#endif /* GLX_NV_float_buffer */ - -/* ---------------------- GLX_NV_multisample_coverage ---------------------- */ - -#ifndef GLX_NV_multisample_coverage -#define GLX_NV_multisample_coverage 1 - -#define GLX_COLOR_SAMPLES_NV 0x20B3 -#define GLX_COVERAGE_SAMPLES_NV 100001 - -#define GLXEW_NV_multisample_coverage GLXEW_GET_VAR(__GLXEW_NV_multisample_coverage) - -#endif /* GLX_NV_multisample_coverage */ - -/* -------------------------- GLX_NV_present_video ------------------------- */ - -#ifndef GLX_NV_present_video -#define GLX_NV_present_video 1 - -#define GLX_NUM_VIDEO_SLOTS_NV 0x20F0 - -typedef int ( * PFNGLXBINDVIDEODEVICENVPROC) (Display* dpy, unsigned int video_slot, unsigned int video_device, const int *attrib_list); -typedef unsigned int* ( * PFNGLXENUMERATEVIDEODEVICESNVPROC) (Display *dpy, int screen, int *nelements); - -#define glXBindVideoDeviceNV GLXEW_GET_FUN(__glewXBindVideoDeviceNV) -#define glXEnumerateVideoDevicesNV GLXEW_GET_FUN(__glewXEnumerateVideoDevicesNV) - -#define GLXEW_NV_present_video GLXEW_GET_VAR(__GLXEW_NV_present_video) - -#endif /* GLX_NV_present_video */ - -/* --------------------------- GLX_NV_swap_group --------------------------- */ - -#ifndef GLX_NV_swap_group -#define GLX_NV_swap_group 1 - -typedef Bool ( * PFNGLXBINDSWAPBARRIERNVPROC) (Display* dpy, GLuint group, GLuint barrier); -typedef Bool ( * PFNGLXJOINSWAPGROUPNVPROC) (Display* dpy, GLXDrawable drawable, GLuint group); -typedef Bool ( * PFNGLXQUERYFRAMECOUNTNVPROC) (Display* dpy, int screen, GLuint *count); -typedef Bool ( * PFNGLXQUERYMAXSWAPGROUPSNVPROC) (Display* dpy, int screen, GLuint *maxGroups, GLuint *maxBarriers); -typedef Bool ( * PFNGLXQUERYSWAPGROUPNVPROC) (Display* dpy, GLXDrawable drawable, GLuint *group, GLuint *barrier); -typedef Bool ( * PFNGLXRESETFRAMECOUNTNVPROC) (Display* dpy, int screen); - -#define glXBindSwapBarrierNV GLXEW_GET_FUN(__glewXBindSwapBarrierNV) -#define glXJoinSwapGroupNV GLXEW_GET_FUN(__glewXJoinSwapGroupNV) -#define glXQueryFrameCountNV GLXEW_GET_FUN(__glewXQueryFrameCountNV) -#define glXQueryMaxSwapGroupsNV GLXEW_GET_FUN(__glewXQueryMaxSwapGroupsNV) -#define glXQuerySwapGroupNV GLXEW_GET_FUN(__glewXQuerySwapGroupNV) -#define glXResetFrameCountNV GLXEW_GET_FUN(__glewXResetFrameCountNV) - -#define GLXEW_NV_swap_group GLXEW_GET_VAR(__GLXEW_NV_swap_group) - -#endif /* GLX_NV_swap_group */ - -/* ----------------------- GLX_NV_vertex_array_range ----------------------- */ - -#ifndef GLX_NV_vertex_array_range -#define GLX_NV_vertex_array_range 1 - -typedef void * ( * PFNGLXALLOCATEMEMORYNVPROC) (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority); -typedef void ( * PFNGLXFREEMEMORYNVPROC) (void *pointer); - -#define glXAllocateMemoryNV GLXEW_GET_FUN(__glewXAllocateMemoryNV) -#define glXFreeMemoryNV GLXEW_GET_FUN(__glewXFreeMemoryNV) - -#define GLXEW_NV_vertex_array_range GLXEW_GET_VAR(__GLXEW_NV_vertex_array_range) - -#endif /* GLX_NV_vertex_array_range */ - -/* -------------------------- GLX_NV_video_capture ------------------------- */ - -#ifndef GLX_NV_video_capture -#define GLX_NV_video_capture 1 - -#define GLX_DEVICE_ID_NV 0x20CD -#define GLX_UNIQUE_ID_NV 0x20CE -#define GLX_NUM_VIDEO_CAPTURE_SLOTS_NV 0x20CF - -typedef XID GLXVideoCaptureDeviceNV; - -typedef int ( * PFNGLXBINDVIDEOCAPTUREDEVICENVPROC) (Display* dpy, unsigned int video_capture_slot, GLXVideoCaptureDeviceNV device); -typedef GLXVideoCaptureDeviceNV * ( * PFNGLXENUMERATEVIDEOCAPTUREDEVICESNVPROC) (Display* dpy, int screen, int *nelements); -typedef void ( * PFNGLXLOCKVIDEOCAPTUREDEVICENVPROC) (Display* dpy, GLXVideoCaptureDeviceNV device); -typedef int ( * PFNGLXQUERYVIDEOCAPTUREDEVICENVPROC) (Display* dpy, GLXVideoCaptureDeviceNV device, int attribute, int *value); -typedef void ( * PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC) (Display* dpy, GLXVideoCaptureDeviceNV device); - -#define glXBindVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXBindVideoCaptureDeviceNV) -#define glXEnumerateVideoCaptureDevicesNV GLXEW_GET_FUN(__glewXEnumerateVideoCaptureDevicesNV) -#define glXLockVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXLockVideoCaptureDeviceNV) -#define glXQueryVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXQueryVideoCaptureDeviceNV) -#define glXReleaseVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXReleaseVideoCaptureDeviceNV) - -#define GLXEW_NV_video_capture GLXEW_GET_VAR(__GLXEW_NV_video_capture) - -#endif /* GLX_NV_video_capture */ - -/* -------------------------- GLX_NV_video_output -------------------------- */ - -#ifndef GLX_NV_video_output -#define GLX_NV_video_output 1 - -#define GLX_VIDEO_OUT_COLOR_NV 0x20C3 -#define GLX_VIDEO_OUT_ALPHA_NV 0x20C4 -#define GLX_VIDEO_OUT_DEPTH_NV 0x20C5 -#define GLX_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 -#define GLX_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 -#define GLX_VIDEO_OUT_FRAME_NV 0x20C8 -#define GLX_VIDEO_OUT_FIELD_1_NV 0x20C9 -#define GLX_VIDEO_OUT_FIELD_2_NV 0x20CA -#define GLX_VIDEO_OUT_STACKED_FIELDS_1_2_NV 0x20CB -#define GLX_VIDEO_OUT_STACKED_FIELDS_2_1_NV 0x20CC - -typedef int ( * PFNGLXBINDVIDEOIMAGENVPROC) (Display* dpy, GLXVideoDeviceNV VideoDevice, GLXPbuffer pbuf, int iVideoBuffer); -typedef int ( * PFNGLXGETVIDEODEVICENVPROC) (Display* dpy, int screen, int numVideoDevices, GLXVideoDeviceNV *pVideoDevice); -typedef int ( * PFNGLXGETVIDEOINFONVPROC) (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice, unsigned long *pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo); -typedef int ( * PFNGLXRELEASEVIDEODEVICENVPROC) (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice); -typedef int ( * PFNGLXRELEASEVIDEOIMAGENVPROC) (Display* dpy, GLXPbuffer pbuf); -typedef int ( * PFNGLXSENDPBUFFERTOVIDEONVPROC) (Display* dpy, GLXPbuffer pbuf, int iBufferType, unsigned long *pulCounterPbuffer, GLboolean bBlock); - -#define glXBindVideoImageNV GLXEW_GET_FUN(__glewXBindVideoImageNV) -#define glXGetVideoDeviceNV GLXEW_GET_FUN(__glewXGetVideoDeviceNV) -#define glXGetVideoInfoNV GLXEW_GET_FUN(__glewXGetVideoInfoNV) -#define glXReleaseVideoDeviceNV GLXEW_GET_FUN(__glewXReleaseVideoDeviceNV) -#define glXReleaseVideoImageNV GLXEW_GET_FUN(__glewXReleaseVideoImageNV) -#define glXSendPbufferToVideoNV GLXEW_GET_FUN(__glewXSendPbufferToVideoNV) - -#define GLXEW_NV_video_output GLXEW_GET_VAR(__GLXEW_NV_video_output) - -#endif /* GLX_NV_video_output */ - -/* -------------------------- GLX_OML_swap_method -------------------------- */ - -#ifndef GLX_OML_swap_method -#define GLX_OML_swap_method 1 - -#define GLX_SWAP_METHOD_OML 0x8060 -#define GLX_SWAP_EXCHANGE_OML 0x8061 -#define GLX_SWAP_COPY_OML 0x8062 -#define GLX_SWAP_UNDEFINED_OML 0x8063 - -#define GLXEW_OML_swap_method GLXEW_GET_VAR(__GLXEW_OML_swap_method) - -#endif /* GLX_OML_swap_method */ - -/* -------------------------- GLX_OML_sync_control ------------------------- */ - -#ifndef GLX_OML_sync_control -#define GLX_OML_sync_control 1 - -typedef Bool ( * PFNGLXGETMSCRATEOMLPROC) (Display* dpy, GLXDrawable drawable, int32_t* numerator, int32_t* denominator); -typedef Bool ( * PFNGLXGETSYNCVALUESOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t* ust, int64_t* msc, int64_t* sbc); -typedef int64_t ( * PFNGLXSWAPBUFFERSMSCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder); -typedef Bool ( * PFNGLXWAITFORMSCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder, int64_t* ust, int64_t* msc, int64_t* sbc); -typedef Bool ( * PFNGLXWAITFORSBCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_sbc, int64_t* ust, int64_t* msc, int64_t* sbc); - -#define glXGetMscRateOML GLXEW_GET_FUN(__glewXGetMscRateOML) -#define glXGetSyncValuesOML GLXEW_GET_FUN(__glewXGetSyncValuesOML) -#define glXSwapBuffersMscOML GLXEW_GET_FUN(__glewXSwapBuffersMscOML) -#define glXWaitForMscOML GLXEW_GET_FUN(__glewXWaitForMscOML) -#define glXWaitForSbcOML GLXEW_GET_FUN(__glewXWaitForSbcOML) - -#define GLXEW_OML_sync_control GLXEW_GET_VAR(__GLXEW_OML_sync_control) - -#endif /* GLX_OML_sync_control */ - -/* ------------------------ GLX_SGIS_blended_overlay ----------------------- */ - -#ifndef GLX_SGIS_blended_overlay -#define GLX_SGIS_blended_overlay 1 - -#define GLX_BLENDED_RGBA_SGIS 0x8025 - -#define GLXEW_SGIS_blended_overlay GLXEW_GET_VAR(__GLXEW_SGIS_blended_overlay) - -#endif /* GLX_SGIS_blended_overlay */ - -/* -------------------------- GLX_SGIS_color_range ------------------------- */ - -#ifndef GLX_SGIS_color_range -#define GLX_SGIS_color_range 1 - -#define GLX_MIN_RED_SGIS 0 -#define GLX_MAX_GREEN_SGIS 0 -#define GLX_MIN_BLUE_SGIS 0 -#define GLX_MAX_ALPHA_SGIS 0 -#define GLX_MIN_GREEN_SGIS 0 -#define GLX_MIN_ALPHA_SGIS 0 -#define GLX_MAX_RED_SGIS 0 -#define GLX_EXTENDED_RANGE_SGIS 0 -#define GLX_MAX_BLUE_SGIS 0 - -#define GLXEW_SGIS_color_range GLXEW_GET_VAR(__GLXEW_SGIS_color_range) - -#endif /* GLX_SGIS_color_range */ - -/* -------------------------- GLX_SGIS_multisample ------------------------- */ - -#ifndef GLX_SGIS_multisample -#define GLX_SGIS_multisample 1 - -#define GLX_SAMPLE_BUFFERS_SGIS 100000 -#define GLX_SAMPLES_SGIS 100001 - -#define GLXEW_SGIS_multisample GLXEW_GET_VAR(__GLXEW_SGIS_multisample) - -#endif /* GLX_SGIS_multisample */ - -/* ---------------------- GLX_SGIS_shared_multisample ---------------------- */ - -#ifndef GLX_SGIS_shared_multisample -#define GLX_SGIS_shared_multisample 1 - -#define GLX_MULTISAMPLE_SUB_RECT_WIDTH_SGIS 0x8026 -#define GLX_MULTISAMPLE_SUB_RECT_HEIGHT_SGIS 0x8027 - -#define GLXEW_SGIS_shared_multisample GLXEW_GET_VAR(__GLXEW_SGIS_shared_multisample) - -#endif /* GLX_SGIS_shared_multisample */ - -/* --------------------------- GLX_SGIX_fbconfig --------------------------- */ - -#ifndef GLX_SGIX_fbconfig -#define GLX_SGIX_fbconfig 1 - -#define GLX_WINDOW_BIT_SGIX 0x00000001 -#define GLX_RGBA_BIT_SGIX 0x00000001 -#define GLX_PIXMAP_BIT_SGIX 0x00000002 -#define GLX_COLOR_INDEX_BIT_SGIX 0x00000002 -#define GLX_SCREEN_EXT 0x800C -#define GLX_DRAWABLE_TYPE_SGIX 0x8010 -#define GLX_RENDER_TYPE_SGIX 0x8011 -#define GLX_X_RENDERABLE_SGIX 0x8012 -#define GLX_FBCONFIG_ID_SGIX 0x8013 -#define GLX_RGBA_TYPE_SGIX 0x8014 -#define GLX_COLOR_INDEX_TYPE_SGIX 0x8015 - -typedef XID GLXFBConfigIDSGIX; -typedef struct __GLXFBConfigRec *GLXFBConfigSGIX; - -typedef GLXFBConfigSGIX* ( * PFNGLXCHOOSEFBCONFIGSGIXPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); -typedef GLXContext ( * PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC) (Display* dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); -typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC) (Display* dpy, GLXFBConfig config, Pixmap pixmap); -typedef int ( * PFNGLXGETFBCONFIGATTRIBSGIXPROC) (Display* dpy, GLXFBConfigSGIX config, int attribute, int *value); -typedef GLXFBConfigSGIX ( * PFNGLXGETFBCONFIGFROMVISUALSGIXPROC) (Display* dpy, XVisualInfo *vis); -typedef XVisualInfo* ( * PFNGLXGETVISUALFROMFBCONFIGSGIXPROC) (Display *dpy, GLXFBConfig config); - -#define glXChooseFBConfigSGIX GLXEW_GET_FUN(__glewXChooseFBConfigSGIX) -#define glXCreateContextWithConfigSGIX GLXEW_GET_FUN(__glewXCreateContextWithConfigSGIX) -#define glXCreateGLXPixmapWithConfigSGIX GLXEW_GET_FUN(__glewXCreateGLXPixmapWithConfigSGIX) -#define glXGetFBConfigAttribSGIX GLXEW_GET_FUN(__glewXGetFBConfigAttribSGIX) -#define glXGetFBConfigFromVisualSGIX GLXEW_GET_FUN(__glewXGetFBConfigFromVisualSGIX) -#define glXGetVisualFromFBConfigSGIX GLXEW_GET_FUN(__glewXGetVisualFromFBConfigSGIX) - -#define GLXEW_SGIX_fbconfig GLXEW_GET_VAR(__GLXEW_SGIX_fbconfig) - -#endif /* GLX_SGIX_fbconfig */ - -/* --------------------------- GLX_SGIX_hyperpipe -------------------------- */ - -#ifndef GLX_SGIX_hyperpipe -#define GLX_SGIX_hyperpipe 1 - -#define GLX_HYPERPIPE_DISPLAY_PIPE_SGIX 0x00000001 -#define GLX_PIPE_RECT_SGIX 0x00000001 -#define GLX_PIPE_RECT_LIMITS_SGIX 0x00000002 -#define GLX_HYPERPIPE_RENDER_PIPE_SGIX 0x00000002 -#define GLX_HYPERPIPE_STEREO_SGIX 0x00000003 -#define GLX_HYPERPIPE_PIXEL_AVERAGE_SGIX 0x00000004 -#define GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX 80 -#define GLX_BAD_HYPERPIPE_CONFIG_SGIX 91 -#define GLX_BAD_HYPERPIPE_SGIX 92 -#define GLX_HYPERPIPE_ID_SGIX 0x8030 - -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int networkId; -} GLXHyperpipeNetworkSGIX; -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int XOrigin; - int YOrigin; - int maxHeight; - int maxWidth; -} GLXPipeRectLimits; -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int channel; - unsigned int participationType; - int timeSlice; -} GLXHyperpipeConfigSGIX; -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int srcXOrigin; - int srcYOrigin; - int srcWidth; - int srcHeight; - int destXOrigin; - int destYOrigin; - int destWidth; - int destHeight; -} GLXPipeRect; - -typedef int ( * PFNGLXBINDHYPERPIPESGIXPROC) (Display *dpy, int hpId); -typedef int ( * PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC) (Display *dpy, int hpId); -typedef int ( * PFNGLXHYPERPIPEATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *attribList); -typedef int ( * PFNGLXHYPERPIPECONFIGSGIXPROC) (Display *dpy, int networkId, int npipes, GLXHyperpipeConfigSGIX *cfg, int *hpId); -typedef int ( * PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *returnAttribList); -typedef int ( * PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *attribList, void *returnAttribList); -typedef GLXHyperpipeConfigSGIX * ( * PFNGLXQUERYHYPERPIPECONFIGSGIXPROC) (Display *dpy, int hpId, int *npipes); -typedef GLXHyperpipeNetworkSGIX * ( * PFNGLXQUERYHYPERPIPENETWORKSGIXPROC) (Display *dpy, int *npipes); - -#define glXBindHyperpipeSGIX GLXEW_GET_FUN(__glewXBindHyperpipeSGIX) -#define glXDestroyHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXDestroyHyperpipeConfigSGIX) -#define glXHyperpipeAttribSGIX GLXEW_GET_FUN(__glewXHyperpipeAttribSGIX) -#define glXHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXHyperpipeConfigSGIX) -#define glXQueryHyperpipeAttribSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeAttribSGIX) -#define glXQueryHyperpipeBestAttribSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeBestAttribSGIX) -#define glXQueryHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeConfigSGIX) -#define glXQueryHyperpipeNetworkSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeNetworkSGIX) - -#define GLXEW_SGIX_hyperpipe GLXEW_GET_VAR(__GLXEW_SGIX_hyperpipe) - -#endif /* GLX_SGIX_hyperpipe */ - -/* ---------------------------- GLX_SGIX_pbuffer --------------------------- */ - -#ifndef GLX_SGIX_pbuffer -#define GLX_SGIX_pbuffer 1 - -#define GLX_FRONT_LEFT_BUFFER_BIT_SGIX 0x00000001 -#define GLX_FRONT_RIGHT_BUFFER_BIT_SGIX 0x00000002 -#define GLX_PBUFFER_BIT_SGIX 0x00000004 -#define GLX_BACK_LEFT_BUFFER_BIT_SGIX 0x00000004 -#define GLX_BACK_RIGHT_BUFFER_BIT_SGIX 0x00000008 -#define GLX_AUX_BUFFERS_BIT_SGIX 0x00000010 -#define GLX_DEPTH_BUFFER_BIT_SGIX 0x00000020 -#define GLX_STENCIL_BUFFER_BIT_SGIX 0x00000040 -#define GLX_ACCUM_BUFFER_BIT_SGIX 0x00000080 -#define GLX_SAMPLE_BUFFERS_BIT_SGIX 0x00000100 -#define GLX_MAX_PBUFFER_WIDTH_SGIX 0x8016 -#define GLX_MAX_PBUFFER_HEIGHT_SGIX 0x8017 -#define GLX_MAX_PBUFFER_PIXELS_SGIX 0x8018 -#define GLX_OPTIMAL_PBUFFER_WIDTH_SGIX 0x8019 -#define GLX_OPTIMAL_PBUFFER_HEIGHT_SGIX 0x801A -#define GLX_PRESERVED_CONTENTS_SGIX 0x801B -#define GLX_LARGEST_PBUFFER_SGIX 0x801C -#define GLX_WIDTH_SGIX 0x801D -#define GLX_HEIGHT_SGIX 0x801E -#define GLX_EVENT_MASK_SGIX 0x801F -#define GLX_DAMAGED_SGIX 0x8020 -#define GLX_SAVED_SGIX 0x8021 -#define GLX_WINDOW_SGIX 0x8022 -#define GLX_PBUFFER_SGIX 0x8023 -#define GLX_BUFFER_CLOBBER_MASK_SGIX 0x08000000 - -typedef XID GLXPbufferSGIX; -typedef struct { int type; unsigned long serial; Bool send_event; Display *display; GLXDrawable drawable; int event_type; int draw_type; unsigned int mask; int x, y; int width, height; int count; } GLXBufferClobberEventSGIX; - -typedef GLXPbuffer ( * PFNGLXCREATEGLXPBUFFERSGIXPROC) (Display* dpy, GLXFBConfig config, unsigned int width, unsigned int height, int *attrib_list); -typedef void ( * PFNGLXDESTROYGLXPBUFFERSGIXPROC) (Display* dpy, GLXPbuffer pbuf); -typedef void ( * PFNGLXGETSELECTEDEVENTSGIXPROC) (Display* dpy, GLXDrawable drawable, unsigned long *mask); -typedef void ( * PFNGLXQUERYGLXPBUFFERSGIXPROC) (Display* dpy, GLXPbuffer pbuf, int attribute, unsigned int *value); -typedef void ( * PFNGLXSELECTEVENTSGIXPROC) (Display* dpy, GLXDrawable drawable, unsigned long mask); - -#define glXCreateGLXPbufferSGIX GLXEW_GET_FUN(__glewXCreateGLXPbufferSGIX) -#define glXDestroyGLXPbufferSGIX GLXEW_GET_FUN(__glewXDestroyGLXPbufferSGIX) -#define glXGetSelectedEventSGIX GLXEW_GET_FUN(__glewXGetSelectedEventSGIX) -#define glXQueryGLXPbufferSGIX GLXEW_GET_FUN(__glewXQueryGLXPbufferSGIX) -#define glXSelectEventSGIX GLXEW_GET_FUN(__glewXSelectEventSGIX) - -#define GLXEW_SGIX_pbuffer GLXEW_GET_VAR(__GLXEW_SGIX_pbuffer) - -#endif /* GLX_SGIX_pbuffer */ - -/* ------------------------- GLX_SGIX_swap_barrier ------------------------- */ - -#ifndef GLX_SGIX_swap_barrier -#define GLX_SGIX_swap_barrier 1 - -typedef void ( * PFNGLXBINDSWAPBARRIERSGIXPROC) (Display *dpy, GLXDrawable drawable, int barrier); -typedef Bool ( * PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC) (Display *dpy, int screen, int *max); - -#define glXBindSwapBarrierSGIX GLXEW_GET_FUN(__glewXBindSwapBarrierSGIX) -#define glXQueryMaxSwapBarriersSGIX GLXEW_GET_FUN(__glewXQueryMaxSwapBarriersSGIX) - -#define GLXEW_SGIX_swap_barrier GLXEW_GET_VAR(__GLXEW_SGIX_swap_barrier) - -#endif /* GLX_SGIX_swap_barrier */ - -/* -------------------------- GLX_SGIX_swap_group -------------------------- */ - -#ifndef GLX_SGIX_swap_group -#define GLX_SGIX_swap_group 1 - -typedef void ( * PFNGLXJOINSWAPGROUPSGIXPROC) (Display *dpy, GLXDrawable drawable, GLXDrawable member); - -#define glXJoinSwapGroupSGIX GLXEW_GET_FUN(__glewXJoinSwapGroupSGIX) - -#define GLXEW_SGIX_swap_group GLXEW_GET_VAR(__GLXEW_SGIX_swap_group) - -#endif /* GLX_SGIX_swap_group */ - -/* ------------------------- GLX_SGIX_video_resize ------------------------- */ - -#ifndef GLX_SGIX_video_resize -#define GLX_SGIX_video_resize 1 - -#define GLX_SYNC_FRAME_SGIX 0x00000000 -#define GLX_SYNC_SWAP_SGIX 0x00000001 - -typedef int ( * PFNGLXBINDCHANNELTOWINDOWSGIXPROC) (Display* display, int screen, int channel, Window window); -typedef int ( * PFNGLXCHANNELRECTSGIXPROC) (Display* display, int screen, int channel, int x, int y, int w, int h); -typedef int ( * PFNGLXCHANNELRECTSYNCSGIXPROC) (Display* display, int screen, int channel, GLenum synctype); -typedef int ( * PFNGLXQUERYCHANNELDELTASSGIXPROC) (Display* display, int screen, int channel, int *x, int *y, int *w, int *h); -typedef int ( * PFNGLXQUERYCHANNELRECTSGIXPROC) (Display* display, int screen, int channel, int *dx, int *dy, int *dw, int *dh); - -#define glXBindChannelToWindowSGIX GLXEW_GET_FUN(__glewXBindChannelToWindowSGIX) -#define glXChannelRectSGIX GLXEW_GET_FUN(__glewXChannelRectSGIX) -#define glXChannelRectSyncSGIX GLXEW_GET_FUN(__glewXChannelRectSyncSGIX) -#define glXQueryChannelDeltasSGIX GLXEW_GET_FUN(__glewXQueryChannelDeltasSGIX) -#define glXQueryChannelRectSGIX GLXEW_GET_FUN(__glewXQueryChannelRectSGIX) - -#define GLXEW_SGIX_video_resize GLXEW_GET_VAR(__GLXEW_SGIX_video_resize) - -#endif /* GLX_SGIX_video_resize */ - -/* ---------------------- GLX_SGIX_visual_select_group --------------------- */ - -#ifndef GLX_SGIX_visual_select_group -#define GLX_SGIX_visual_select_group 1 - -#define GLX_VISUAL_SELECT_GROUP_SGIX 0x8028 - -#define GLXEW_SGIX_visual_select_group GLXEW_GET_VAR(__GLXEW_SGIX_visual_select_group) - -#endif /* GLX_SGIX_visual_select_group */ - -/* ---------------------------- GLX_SGI_cushion ---------------------------- */ - -#ifndef GLX_SGI_cushion -#define GLX_SGI_cushion 1 - -typedef void ( * PFNGLXCUSHIONSGIPROC) (Display* dpy, Window window, float cushion); - -#define glXCushionSGI GLXEW_GET_FUN(__glewXCushionSGI) - -#define GLXEW_SGI_cushion GLXEW_GET_VAR(__GLXEW_SGI_cushion) - -#endif /* GLX_SGI_cushion */ - -/* ----------------------- GLX_SGI_make_current_read ----------------------- */ - -#ifndef GLX_SGI_make_current_read -#define GLX_SGI_make_current_read 1 - -typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLESGIPROC) (void); -typedef Bool ( * PFNGLXMAKECURRENTREADSGIPROC) (Display* dpy, GLXDrawable draw, GLXDrawable read, GLXContext ctx); - -#define glXGetCurrentReadDrawableSGI GLXEW_GET_FUN(__glewXGetCurrentReadDrawableSGI) -#define glXMakeCurrentReadSGI GLXEW_GET_FUN(__glewXMakeCurrentReadSGI) - -#define GLXEW_SGI_make_current_read GLXEW_GET_VAR(__GLXEW_SGI_make_current_read) - -#endif /* GLX_SGI_make_current_read */ - -/* -------------------------- GLX_SGI_swap_control ------------------------- */ - -#ifndef GLX_SGI_swap_control -#define GLX_SGI_swap_control 1 - -typedef int ( * PFNGLXSWAPINTERVALSGIPROC) (int interval); - -#define glXSwapIntervalSGI GLXEW_GET_FUN(__glewXSwapIntervalSGI) - -#define GLXEW_SGI_swap_control GLXEW_GET_VAR(__GLXEW_SGI_swap_control) - -#endif /* GLX_SGI_swap_control */ - -/* --------------------------- GLX_SGI_video_sync -------------------------- */ - -#ifndef GLX_SGI_video_sync -#define GLX_SGI_video_sync 1 - -typedef int ( * PFNGLXGETVIDEOSYNCSGIPROC) (unsigned int* count); -typedef int ( * PFNGLXWAITVIDEOSYNCSGIPROC) (int divisor, int remainder, unsigned int* count); - -#define glXGetVideoSyncSGI GLXEW_GET_FUN(__glewXGetVideoSyncSGI) -#define glXWaitVideoSyncSGI GLXEW_GET_FUN(__glewXWaitVideoSyncSGI) - -#define GLXEW_SGI_video_sync GLXEW_GET_VAR(__GLXEW_SGI_video_sync) - -#endif /* GLX_SGI_video_sync */ - -/* --------------------- GLX_SUN_get_transparent_index --------------------- */ - -#ifndef GLX_SUN_get_transparent_index -#define GLX_SUN_get_transparent_index 1 - -typedef Status ( * PFNGLXGETTRANSPARENTINDEXSUNPROC) (Display* dpy, Window overlay, Window underlay, unsigned long *pTransparentIndex); - -#define glXGetTransparentIndexSUN GLXEW_GET_FUN(__glewXGetTransparentIndexSUN) - -#define GLXEW_SUN_get_transparent_index GLXEW_GET_VAR(__GLXEW_SUN_get_transparent_index) - -#endif /* GLX_SUN_get_transparent_index */ - -/* -------------------------- GLX_SUN_video_resize ------------------------- */ - -#ifndef GLX_SUN_video_resize -#define GLX_SUN_video_resize 1 - -#define GLX_VIDEO_RESIZE_SUN 0x8171 -#define GL_VIDEO_RESIZE_COMPENSATION_SUN 0x85CD - -typedef int ( * PFNGLXGETVIDEORESIZESUNPROC) (Display* display, GLXDrawable window, float* factor); -typedef int ( * PFNGLXVIDEORESIZESUNPROC) (Display* display, GLXDrawable window, float factor); - -#define glXGetVideoResizeSUN GLXEW_GET_FUN(__glewXGetVideoResizeSUN) -#define glXVideoResizeSUN GLXEW_GET_FUN(__glewXVideoResizeSUN) - -#define GLXEW_SUN_video_resize GLXEW_GET_VAR(__GLXEW_SUN_video_resize) - -#endif /* GLX_SUN_video_resize */ - -/* ------------------------------------------------------------------------- */ - -#ifdef GLEW_MX -#define GLXEW_EXPORT -#else -#define GLXEW_EXPORT extern -#endif /* GLEW_MX */ - -extern PFNGLXGETCURRENTDISPLAYPROC __glewXGetCurrentDisplay; - -extern PFNGLXCHOOSEFBCONFIGPROC __glewXChooseFBConfig; -extern PFNGLXCREATENEWCONTEXTPROC __glewXCreateNewContext; -extern PFNGLXCREATEPBUFFERPROC __glewXCreatePbuffer; -extern PFNGLXCREATEPIXMAPPROC __glewXCreatePixmap; -extern PFNGLXCREATEWINDOWPROC __glewXCreateWindow; -extern PFNGLXDESTROYPBUFFERPROC __glewXDestroyPbuffer; -extern PFNGLXDESTROYPIXMAPPROC __glewXDestroyPixmap; -extern PFNGLXDESTROYWINDOWPROC __glewXDestroyWindow; -extern PFNGLXGETCURRENTREADDRAWABLEPROC __glewXGetCurrentReadDrawable; -extern PFNGLXGETFBCONFIGATTRIBPROC __glewXGetFBConfigAttrib; -extern PFNGLXGETFBCONFIGSPROC __glewXGetFBConfigs; -extern PFNGLXGETSELECTEDEVENTPROC __glewXGetSelectedEvent; -extern PFNGLXGETVISUALFROMFBCONFIGPROC __glewXGetVisualFromFBConfig; -extern PFNGLXMAKECONTEXTCURRENTPROC __glewXMakeContextCurrent; -extern PFNGLXQUERYCONTEXTPROC __glewXQueryContext; -extern PFNGLXQUERYDRAWABLEPROC __glewXQueryDrawable; -extern PFNGLXSELECTEVENTPROC __glewXSelectEvent; - -extern PFNGLXCREATECONTEXTATTRIBSARBPROC __glewXCreateContextAttribsARB; - -extern PFNGLXBINDTEXIMAGEATIPROC __glewXBindTexImageATI; -extern PFNGLXDRAWABLEATTRIBATIPROC __glewXDrawableAttribATI; -extern PFNGLXRELEASETEXIMAGEATIPROC __glewXReleaseTexImageATI; - -extern PFNGLXFREECONTEXTEXTPROC __glewXFreeContextEXT; -extern PFNGLXGETCONTEXTIDEXTPROC __glewXGetContextIDEXT; -extern PFNGLXIMPORTCONTEXTEXTPROC __glewXImportContextEXT; -extern PFNGLXQUERYCONTEXTINFOEXTPROC __glewXQueryContextInfoEXT; - -extern PFNGLXSWAPINTERVALEXTPROC __glewXSwapIntervalEXT; - -extern PFNGLXBINDTEXIMAGEEXTPROC __glewXBindTexImageEXT; -extern PFNGLXRELEASETEXIMAGEEXTPROC __glewXReleaseTexImageEXT; - -extern PFNGLXGETAGPOFFSETMESAPROC __glewXGetAGPOffsetMESA; - -extern PFNGLXCOPYSUBBUFFERMESAPROC __glewXCopySubBufferMESA; - -extern PFNGLXCREATEGLXPIXMAPMESAPROC __glewXCreateGLXPixmapMESA; - -extern PFNGLXRELEASEBUFFERSMESAPROC __glewXReleaseBuffersMESA; - -extern PFNGLXSET3DFXMODEMESAPROC __glewXSet3DfxModeMESA; - -extern PFNGLXGETSWAPINTERVALMESAPROC __glewXGetSwapIntervalMESA; -extern PFNGLXSWAPINTERVALMESAPROC __glewXSwapIntervalMESA; - -extern PFNGLXCOPYIMAGESUBDATANVPROC __glewXCopyImageSubDataNV; - -extern PFNGLXBINDVIDEODEVICENVPROC __glewXBindVideoDeviceNV; -extern PFNGLXENUMERATEVIDEODEVICESNVPROC __glewXEnumerateVideoDevicesNV; - -extern PFNGLXBINDSWAPBARRIERNVPROC __glewXBindSwapBarrierNV; -extern PFNGLXJOINSWAPGROUPNVPROC __glewXJoinSwapGroupNV; -extern PFNGLXQUERYFRAMECOUNTNVPROC __glewXQueryFrameCountNV; -extern PFNGLXQUERYMAXSWAPGROUPSNVPROC __glewXQueryMaxSwapGroupsNV; -extern PFNGLXQUERYSWAPGROUPNVPROC __glewXQuerySwapGroupNV; -extern PFNGLXRESETFRAMECOUNTNVPROC __glewXResetFrameCountNV; - -extern PFNGLXALLOCATEMEMORYNVPROC __glewXAllocateMemoryNV; -extern PFNGLXFREEMEMORYNVPROC __glewXFreeMemoryNV; - -extern PFNGLXBINDVIDEOCAPTUREDEVICENVPROC __glewXBindVideoCaptureDeviceNV; -extern PFNGLXENUMERATEVIDEOCAPTUREDEVICESNVPROC __glewXEnumerateVideoCaptureDevicesNV; -extern PFNGLXLOCKVIDEOCAPTUREDEVICENVPROC __glewXLockVideoCaptureDeviceNV; -extern PFNGLXQUERYVIDEOCAPTUREDEVICENVPROC __glewXQueryVideoCaptureDeviceNV; -extern PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC __glewXReleaseVideoCaptureDeviceNV; - -extern PFNGLXBINDVIDEOIMAGENVPROC __glewXBindVideoImageNV; -extern PFNGLXGETVIDEODEVICENVPROC __glewXGetVideoDeviceNV; -extern PFNGLXGETVIDEOINFONVPROC __glewXGetVideoInfoNV; -extern PFNGLXRELEASEVIDEODEVICENVPROC __glewXReleaseVideoDeviceNV; -extern PFNGLXRELEASEVIDEOIMAGENVPROC __glewXReleaseVideoImageNV; -extern PFNGLXSENDPBUFFERTOVIDEONVPROC __glewXSendPbufferToVideoNV; - -extern PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML; -extern PFNGLXGETSYNCVALUESOMLPROC __glewXGetSyncValuesOML; -extern PFNGLXSWAPBUFFERSMSCOMLPROC __glewXSwapBuffersMscOML; -extern PFNGLXWAITFORMSCOMLPROC __glewXWaitForMscOML; -extern PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML; - -extern PFNGLXCHOOSEFBCONFIGSGIXPROC __glewXChooseFBConfigSGIX; -extern PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC __glewXCreateContextWithConfigSGIX; -extern PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC __glewXCreateGLXPixmapWithConfigSGIX; -extern PFNGLXGETFBCONFIGATTRIBSGIXPROC __glewXGetFBConfigAttribSGIX; -extern PFNGLXGETFBCONFIGFROMVISUALSGIXPROC __glewXGetFBConfigFromVisualSGIX; -extern PFNGLXGETVISUALFROMFBCONFIGSGIXPROC __glewXGetVisualFromFBConfigSGIX; - -extern PFNGLXBINDHYPERPIPESGIXPROC __glewXBindHyperpipeSGIX; -extern PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC __glewXDestroyHyperpipeConfigSGIX; -extern PFNGLXHYPERPIPEATTRIBSGIXPROC __glewXHyperpipeAttribSGIX; -extern PFNGLXHYPERPIPECONFIGSGIXPROC __glewXHyperpipeConfigSGIX; -extern PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC __glewXQueryHyperpipeAttribSGIX; -extern PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC __glewXQueryHyperpipeBestAttribSGIX; -extern PFNGLXQUERYHYPERPIPECONFIGSGIXPROC __glewXQueryHyperpipeConfigSGIX; -extern PFNGLXQUERYHYPERPIPENETWORKSGIXPROC __glewXQueryHyperpipeNetworkSGIX; - -extern PFNGLXCREATEGLXPBUFFERSGIXPROC __glewXCreateGLXPbufferSGIX; -extern PFNGLXDESTROYGLXPBUFFERSGIXPROC __glewXDestroyGLXPbufferSGIX; -extern PFNGLXGETSELECTEDEVENTSGIXPROC __glewXGetSelectedEventSGIX; -extern PFNGLXQUERYGLXPBUFFERSGIXPROC __glewXQueryGLXPbufferSGIX; -extern PFNGLXSELECTEVENTSGIXPROC __glewXSelectEventSGIX; - -extern PFNGLXBINDSWAPBARRIERSGIXPROC __glewXBindSwapBarrierSGIX; -extern PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC __glewXQueryMaxSwapBarriersSGIX; - -extern PFNGLXJOINSWAPGROUPSGIXPROC __glewXJoinSwapGroupSGIX; - -extern PFNGLXBINDCHANNELTOWINDOWSGIXPROC __glewXBindChannelToWindowSGIX; -extern PFNGLXCHANNELRECTSGIXPROC __glewXChannelRectSGIX; -extern PFNGLXCHANNELRECTSYNCSGIXPROC __glewXChannelRectSyncSGIX; -extern PFNGLXQUERYCHANNELDELTASSGIXPROC __glewXQueryChannelDeltasSGIX; -extern PFNGLXQUERYCHANNELRECTSGIXPROC __glewXQueryChannelRectSGIX; - -extern PFNGLXCUSHIONSGIPROC __glewXCushionSGI; - -extern PFNGLXGETCURRENTREADDRAWABLESGIPROC __glewXGetCurrentReadDrawableSGI; -extern PFNGLXMAKECURRENTREADSGIPROC __glewXMakeCurrentReadSGI; - -extern PFNGLXSWAPINTERVALSGIPROC __glewXSwapIntervalSGI; - -extern PFNGLXGETVIDEOSYNCSGIPROC __glewXGetVideoSyncSGI; -extern PFNGLXWAITVIDEOSYNCSGIPROC __glewXWaitVideoSyncSGI; - -extern PFNGLXGETTRANSPARENTINDEXSUNPROC __glewXGetTransparentIndexSUN; - -extern PFNGLXGETVIDEORESIZESUNPROC __glewXGetVideoResizeSUN; -extern PFNGLXVIDEORESIZESUNPROC __glewXVideoResizeSUN; - -#if defined(GLEW_MX) -struct GLXEWContextStruct -{ -#endif /* GLEW_MX */ - -GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_0; -GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_1; -GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_2; -GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_3; -GLXEW_EXPORT GLboolean __GLXEW_VERSION_1_4; -GLXEW_EXPORT GLboolean __GLXEW_3DFX_multisample; -GLXEW_EXPORT GLboolean __GLXEW_AMD_gpu_association; -GLXEW_EXPORT GLboolean __GLXEW_ARB_create_context; -GLXEW_EXPORT GLboolean __GLXEW_ARB_create_context_profile; -GLXEW_EXPORT GLboolean __GLXEW_ARB_create_context_robustness; -GLXEW_EXPORT GLboolean __GLXEW_ARB_fbconfig_float; -GLXEW_EXPORT GLboolean __GLXEW_ARB_framebuffer_sRGB; -GLXEW_EXPORT GLboolean __GLXEW_ARB_get_proc_address; -GLXEW_EXPORT GLboolean __GLXEW_ARB_multisample; -GLXEW_EXPORT GLboolean __GLXEW_ARB_vertex_buffer_object; -GLXEW_EXPORT GLboolean __GLXEW_ATI_pixel_format_float; -GLXEW_EXPORT GLboolean __GLXEW_ATI_render_texture; -GLXEW_EXPORT GLboolean __GLXEW_EXT_create_context_es2_profile; -GLXEW_EXPORT GLboolean __GLXEW_EXT_fbconfig_packed_float; -GLXEW_EXPORT GLboolean __GLXEW_EXT_framebuffer_sRGB; -GLXEW_EXPORT GLboolean __GLXEW_EXT_import_context; -GLXEW_EXPORT GLboolean __GLXEW_EXT_scene_marker; -GLXEW_EXPORT GLboolean __GLXEW_EXT_swap_control; -GLXEW_EXPORT GLboolean __GLXEW_EXT_texture_from_pixmap; -GLXEW_EXPORT GLboolean __GLXEW_EXT_visual_info; -GLXEW_EXPORT GLboolean __GLXEW_EXT_visual_rating; -GLXEW_EXPORT GLboolean __GLXEW_INTEL_swap_event; -GLXEW_EXPORT GLboolean __GLXEW_MESA_agp_offset; -GLXEW_EXPORT GLboolean __GLXEW_MESA_copy_sub_buffer; -GLXEW_EXPORT GLboolean __GLXEW_MESA_pixmap_colormap; -GLXEW_EXPORT GLboolean __GLXEW_MESA_release_buffers; -GLXEW_EXPORT GLboolean __GLXEW_MESA_set_3dfx_mode; -GLXEW_EXPORT GLboolean __GLXEW_MESA_swap_control; -GLXEW_EXPORT GLboolean __GLXEW_NV_copy_image; -GLXEW_EXPORT GLboolean __GLXEW_NV_float_buffer; -GLXEW_EXPORT GLboolean __GLXEW_NV_multisample_coverage; -GLXEW_EXPORT GLboolean __GLXEW_NV_present_video; -GLXEW_EXPORT GLboolean __GLXEW_NV_swap_group; -GLXEW_EXPORT GLboolean __GLXEW_NV_vertex_array_range; -GLXEW_EXPORT GLboolean __GLXEW_NV_video_capture; -GLXEW_EXPORT GLboolean __GLXEW_NV_video_output; -GLXEW_EXPORT GLboolean __GLXEW_OML_swap_method; -GLXEW_EXPORT GLboolean __GLXEW_OML_sync_control; -GLXEW_EXPORT GLboolean __GLXEW_SGIS_blended_overlay; -GLXEW_EXPORT GLboolean __GLXEW_SGIS_color_range; -GLXEW_EXPORT GLboolean __GLXEW_SGIS_multisample; -GLXEW_EXPORT GLboolean __GLXEW_SGIS_shared_multisample; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_fbconfig; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_hyperpipe; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_pbuffer; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_swap_barrier; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_swap_group; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_video_resize; -GLXEW_EXPORT GLboolean __GLXEW_SGIX_visual_select_group; -GLXEW_EXPORT GLboolean __GLXEW_SGI_cushion; -GLXEW_EXPORT GLboolean __GLXEW_SGI_make_current_read; -GLXEW_EXPORT GLboolean __GLXEW_SGI_swap_control; -GLXEW_EXPORT GLboolean __GLXEW_SGI_video_sync; -GLXEW_EXPORT GLboolean __GLXEW_SUN_get_transparent_index; -GLXEW_EXPORT GLboolean __GLXEW_SUN_video_resize; - -#ifdef GLEW_MX -}; /* GLXEWContextStruct */ -#endif /* GLEW_MX */ - -/* ------------------------------------------------------------------------ */ - -#ifdef GLEW_MX - -typedef struct GLXEWContextStruct GLXEWContext; -extern GLenum glxewContextInit (GLXEWContext* ctx); -extern GLboolean glxewContextIsSupported (const GLXEWContext* ctx, const char* name); - -#define glxewInit() glxewContextInit(glxewGetContext()) -#define glxewIsSupported(x) glxewContextIsSupported(glxewGetContext(), x) - -#define GLXEW_GET_VAR(x) (*(const GLboolean*)&(glxewGetContext()->x)) -#define GLXEW_GET_FUN(x) x - -#else /* GLEW_MX */ - -#define GLXEW_GET_VAR(x) (*(const GLboolean*)&x) -#define GLXEW_GET_FUN(x) x - -extern GLboolean glxewIsSupported (const char* name); - -#endif /* GLEW_MX */ - -extern GLboolean glxewGetExtension (const char* name); - -#ifdef __cplusplus -} -#endif - -#endif /* __glxew_h__ */ diff --git a/Demos/Glut/GL/glxext.h b/Demos/Glut/GL/glxext.h deleted file mode 100644 index b3de958da..000000000 --- a/Demos/Glut/GL/glxext.h +++ /dev/null @@ -1,546 +0,0 @@ -#ifndef __glxext_h_ -#define __glxext_h_ - -#ifdef __cplusplus -extern "C" { -#endif - -/* -** License Applicability. Except to the extent portions of this file are -** made subject to an alternative license as permitted in the SGI Free -** Software License B, Version 1.1 (the "License"), the contents of this -** file are subject only to the provisions of the License. You may not use -** this file except in compliance with the License. You may obtain a copy -** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600 -** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at: -** -** http://oss.sgi.com/projects/FreeB -** -** Note that, as provided in the License, the Software is distributed on an -** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS -** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND -** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A -** PARTICULAR PURPOSE, AND NON-INFRINGEMENT. -** -** Original Code. The Original Code is: OpenGL Sample Implementation, -** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics, -** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc. -** Copyright in any portions created by third parties is as indicated -** elsewhere herein. All Rights Reserved. -** -** Additional Notice Provisions: This software was created using the -** OpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has -** not been independently verified as being compliant with the OpenGL(R) -** version 1.2.1 Specification. -*/ - -#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) -#define WIN32_LEAN_AND_MEAN 1 -#include -#else -#include -#endif - -#ifndef APIENTRY -#define APIENTRY -#endif - - -/*************************************************************/ - -/* Header file version number, required by OpenGL ABI for Linux */ -#define GLX_GLXEXT_VERSION 2 - -#ifndef GLX_VERSION_1_3 -#define GLX_WINDOW_BIT 0x00000001 -#define GLX_PIXMAP_BIT 0x00000002 -#define GLX_PBUFFER_BIT 0x00000004 -#define GLX_RGBA_BIT 0x00000001 -#define GLX_COLOR_INDEX_BIT 0x00000002 -#define GLX_PBUFFER_CLOBBER_MASK 0x08000000 -#define GLX_FRONT_LEFT_BUFFER_BIT 0x00000001 -#define GLX_FRONT_RIGHT_BUFFER_BIT 0x00000002 -#define GLX_BACK_LEFT_BUFFER_BIT 0x00000004 -#define GLX_BACK_RIGHT_BUFFER_BIT 0x00000008 -#define GLX_AUX_BUFFERS_BIT 0x00000010 -#define GLX_DEPTH_BUFFER_BIT 0x00000020 -#define GLX_STENCIL_BUFFER_BIT 0x00000040 -#define GLX_ACCUM_BUFFER_BIT 0x00000080 -#define GLX_CONFIG_CAVEAT 0x20 -#define GLX_X_VISUAL_TYPE 0x22 -#define GLX_TRANSPARENT_TYPE 0x23 -#define GLX_TRANSPARENT_INDEX_VALUE 0x24 -#define GLX_TRANSPARENT_RED_VALUE 0x25 -#define GLX_TRANSPARENT_GREEN_VALUE 0x26 -#define GLX_TRANSPARENT_BLUE_VALUE 0x27 -#define GLX_TRANSPARENT_ALPHA_VALUE 0x28 -#define GLX_DONT_CARE 0xFFFFFFFF -#define GLX_NONE 0x8000 -#define GLX_SLOW_CONFIG 0x8001 -#define GLX_TRUE_COLOR 0x8002 -#define GLX_DIRECT_COLOR 0x8003 -#define GLX_PSEUDO_COLOR 0x8004 -#define GLX_STATIC_COLOR 0x8005 -#define GLX_GRAY_SCALE 0x8006 -#define GLX_STATIC_GRAY 0x8007 -#define GLX_TRANSPARENT_RGB 0x8008 -#define GLX_TRANSPARENT_INDEX 0x8009 -#define GLX_VISUAL_ID 0x800B -#define GLX_SCREEN 0x800C -#define GLX_NON_CONFORMANT_CONFIG 0x800D -#define GLX_DRAWABLE_TYPE 0x8010 -#define GLX_RENDER_TYPE 0x8011 -#define GLX_X_RENDERABLE 0x8012 -#define GLX_FBCONFIG_ID 0x8013 -#define GLX_RGBA_TYPE 0x8014 -#define GLX_COLOR_INDEX_TYPE 0x8015 -#define GLX_MAX_PBUFFER_WIDTH 0x8016 -#define GLX_MAX_PBUFFER_HEIGHT 0x8017 -#define GLX_MAX_PBUFFER_PIXELS 0x8018 -#define GLX_PRESERVED_CONTENTS 0x801B -#define GLX_LARGEST_PBUFFER 0x801C -#define GLX_WIDTH 0x801D -#define GLX_HEIGHT 0x801E -#define GLX_EVENT_MASK 0x801F -#define GLX_DAMAGED 0x8020 -#define GLX_SAVED 0x8021 -#define GLX_WINDOW 0x8022 -#define GLX_PBUFFER 0x8023 -#define GLX_PBUFFER_HEIGHT 0x8040 -#define GLX_PBUFFER_WIDTH 0x8041 -#endif - -#ifndef GLX_EXT_visual_info -#define GLX_X_VISUAL_TYPE_EXT 0x22 -#define GLX_TRANSPARENT_TYPE_EXT 0x23 -#define GLX_TRANSPARENT_INDEX_VALUE_EXT 0x24 -#define GLX_TRANSPARENT_RED_VALUE_EXT 0x25 -#define GLX_TRANSPARENT_GREEN_VALUE_EXT 0x26 -#define GLX_TRANSPARENT_BLUE_VALUE_EXT 0x27 -#define GLX_TRANSPARENT_ALPHA_VALUE_EXT 0x28 -#define GLX_NONE_EXT 0x8000 -#define GLX_TRUE_COLOR_EXT 0x8002 -#define GLX_DIRECT_COLOR_EXT 0x8003 -#define GLX_PSEUDO_COLOR_EXT 0x8004 -#define GLX_STATIC_COLOR_EXT 0x8005 -#define GLX_GRAY_SCALE_EXT 0x8006 -#define GLX_STATIC_GRAY_EXT 0x8007 -#define GLX_TRANSPARENT_RGB_EXT 0x8008 -#define GLX_TRANSPARENT_INDEX_EXT 0x8009 -#endif - -#ifndef GLX_SGI_swap_control -#endif - -#ifndef GLX_SGI_video_sync -#endif - -#ifndef GLX_SGI_make_current_read -#endif - -#ifndef GLX_SGIX_video_source -#endif - -#ifndef GLX_EXT_visual_rating -#define GLX_VISUAL_CAVEAT_EXT 0x20 -#define GLX_SLOW_VISUAL_EXT 0x8001 -#define GLX_NON_CONFORMANT_VISUAL_EXT 0x800D -/* reuse GLX_NONE_EXT */ -#endif - -#ifndef GLX_EXT_import_context -#define GLX_SHARE_CONTEXT_EXT 0x800A -#define GLX_VISUAL_ID_EXT 0x800B -#define GLX_SCREEN_EXT 0x800C -#endif - -#ifndef GLX_SGIX_fbconfig -#define GLX_WINDOW_BIT_SGIX 0x00000001 -#define GLX_PIXMAP_BIT_SGIX 0x00000002 -#define GLX_RGBA_BIT_SGIX 0x00000001 -#define GLX_COLOR_INDEX_BIT_SGIX 0x00000002 -#define GLX_DRAWABLE_TYPE_SGIX 0x8010 -#define GLX_RENDER_TYPE_SGIX 0x8011 -#define GLX_X_RENDERABLE_SGIX 0x8012 -#define GLX_FBCONFIG_ID_SGIX 0x8013 -#define GLX_RGBA_TYPE_SGIX 0x8014 -#define GLX_COLOR_INDEX_TYPE_SGIX 0x8015 -/* reuse GLX_SCREEN_EXT */ -#endif - -#ifndef GLX_SGIX_pbuffer -#define GLX_PBUFFER_BIT_SGIX 0x00000004 -#define GLX_BUFFER_CLOBBER_MASK_SGIX 0x08000000 -#define GLX_FRONT_LEFT_BUFFER_BIT_SGIX 0x00000001 -#define GLX_FRONT_RIGHT_BUFFER_BIT_SGIX 0x00000002 -#define GLX_BACK_LEFT_BUFFER_BIT_SGIX 0x00000004 -#define GLX_BACK_RIGHT_BUFFER_BIT_SGIX 0x00000008 -#define GLX_AUX_BUFFERS_BIT_SGIX 0x00000010 -#define GLX_DEPTH_BUFFER_BIT_SGIX 0x00000020 -#define GLX_STENCIL_BUFFER_BIT_SGIX 0x00000040 -#define GLX_ACCUM_BUFFER_BIT_SGIX 0x00000080 -#define GLX_SAMPLE_BUFFERS_BIT_SGIX 0x00000100 -#define GLX_MAX_PBUFFER_WIDTH_SGIX 0x8016 -#define GLX_MAX_PBUFFER_HEIGHT_SGIX 0x8017 -#define GLX_MAX_PBUFFER_PIXELS_SGIX 0x8018 -#define GLX_OPTIMAL_PBUFFER_WIDTH_SGIX 0x8019 -#define GLX_OPTIMAL_PBUFFER_HEIGHT_SGIX 0x801A -#define GLX_PRESERVED_CONTENTS_SGIX 0x801B -#define GLX_LARGEST_PBUFFER_SGIX 0x801C -#define GLX_WIDTH_SGIX 0x801D -#define GLX_HEIGHT_SGIX 0x801E -#define GLX_EVENT_MASK_SGIX 0x801F -#define GLX_DAMAGED_SGIX 0x8020 -#define GLX_SAVED_SGIX 0x8021 -#define GLX_WINDOW_SGIX 0x8022 -#define GLX_PBUFFER_SGIX 0x8023 -#endif - -#ifndef GLX_SGI_cushion -#endif - -#ifndef GLX_SGIX_video_resize -#define GLX_SYNC_FRAME_SGIX 0x00000000 -#define GLX_SYNC_SWAP_SGIX 0x00000001 -#endif - -#ifndef GLX_SGIX_dmbuffer -#define GLX_DIGITAL_MEDIA_PBUFFER_SGIX 0x8024 -#endif - -#ifndef GLX_SGIX_swap_group -#endif - -#ifndef GLX_SGIX_swap_barrier -#endif - -#ifndef GLX_SGIS_blended_overlay -#define GLX_BLENDED_RGBA_SGIS 0x8025 -#endif - -#ifndef GLX_SGIS_shared_multisample -#define GLX_MULTISAMPLE_SUB_RECT_WIDTH_SGIS 0x8026 -#define GLX_MULTISAMPLE_SUB_RECT_HEIGHT_SGIS 0x8027 -#endif - -#ifndef GLX_SUN_get_transparent_index -#endif - -#ifndef GLX_3DFX_multisample -#define GLX_SAMPLE_BUFFERS_3DFX 0x8050 -#define GLX_SAMPLES_3DFX 0x8051 -#endif - -#ifndef GLX_MESA_copy_sub_buffer -#endif - -#ifndef GLX_MESA_pixmap_colormap -#endif - -#ifndef GLX_MESA_release_buffers -#endif - -#ifndef GLX_MESA_set_3dfx_mode -#define GLX_3DFX_WINDOW_MODE_MESA 0x1 -#define GLX_3DFX_FULLSCREEN_MODE_MESA 0x2 -#endif - - -/*************************************************************/ - -#ifndef GLX_ARB_get_proc_address -typedef void (*__GLXextFuncPtr)(); -#endif - -#ifndef GLX_SGIX_video_source -typedef XID GLXVideoSourceSGIX; -#endif - -#ifndef GLX_SGIX_fbconfig -typedef XID GLXFBConfigIDSGIX; -typedef struct __GLXFBConfigRec *GLXFBConfigSGIX; -#endif - -#ifndef GLX_SGIX_pbuffer -typedef XID GLXPbufferSGIX; -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came for SendEvent request */ - Display *display; /* display the event was read from */ - GLXDrawable drawable; /* i.d. of Drawable */ - int event_type; /* GLX_DAMAGED_SGIX or GLX_SAVED_SGIX */ - int draw_type; /* GLX_WINDOW_SGIX or GLX_PBUFFER_SGIX */ - unsigned int mask; /* mask indicating which buffers are affected*/ - int x, y; - int width, height; - int count; /* if nonzero, at least this many more */ -} GLXBufferClobberEventSGIX; -#endif - -#ifdef GL_NV_vertex_array_range -#ifndef PFNGLXALLOCATEMEMORYNVPROC -#ifdef GLX_GLXEXT_PROTOTYPES -extern void *glXAllocateMemoryNV (GLsizei, GLfloat, GLfloat, GLfloat); -#endif -typedef void * ( * PFNGLXALLOCATEMEMORYNVPROC) (GLsizei, GLfloat, GLfloat, GLfloat); -#endif -#ifndef PFNGLXFREEMEMORYNVPROC -#ifdef GLX_GLXEXT_PROTOTYPES -extern void glXFreeMemoryNV (void *); -#endif -typedef void ( * PFNGLXFREEMEMORYNVPROC) (void *); -#endif -#endif - -#ifndef GLX_VERSION_1_3 -#define GLX_VERSION_1_3 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern GLXFBConfig * glXGetFBConfigs (Display *, int, int *); -extern GLXFBConfig * glXChooseFBConfig (Display *, int, const int *, int *); -extern int glXGetFBConfigAttrib (Display *, GLXFBConfig, int, int *); -extern XVisualInfo * glXGetVisualFromFBConfig (Display *, GLXFBConfig); -extern GLXWindow glXCreateWindow (Display *, GLXFBConfig, Window, const int *); -extern void glXDestroyWindow (Display *, GLXWindow); -extern GLXPixmap glXCreatePixmap (Display *, GLXFBConfig, Pixmap, const int *); -extern void glXDestroyPixmap (Display *, GLXPixmap); -extern GLXPbuffer glXCreatePbuffer (Display *, GLXFBConfig, const int *); -extern void glXDestroyPbuffer (Display *, GLXPbuffer); -extern void glXQueryDrawable (Display *, GLXDrawable, int, unsigned int *); -extern GLXContext glXCreateNewContext (Display *, GLXFBConfig, int, GLXContext, Bool); -extern Bool glXMakeContextCurrent (Display *, GLXDrawable, GLXDrawable, GLXContext); -extern GLXDrawable glXGetCurrentReadDrawable (void); -extern Display * glXGetCurrentDisplay (void); -extern int glXQueryContext (Display *, GLXContext, int, int *); -extern void glXSelectEvent (Display *, GLXDrawable, unsigned long); -extern void glXGetSelectedEvent (Display *, GLXDrawable, unsigned long *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef GLXFBConfig * ( * PFNGLXGETFBCONFIGSPROC) (Display *dpy, int screen, int *nelements); -typedef GLXFBConfig * ( * PFNGLXCHOOSEFBCONFIGPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); -typedef int ( * PFNGLXGETFBCONFIGATTRIBPROC) (Display *dpy, GLXFBConfig config, int attribute, int *value); -typedef XVisualInfo * ( * PFNGLXGETVISUALFROMFBCONFIGPROC) (Display *dpy, GLXFBConfig config); -typedef GLXWindow ( * PFNGLXCREATEWINDOWPROC) (Display *dpy, GLXFBConfig config, Window win, const int *attrib_list); -typedef void ( * PFNGLXDESTROYWINDOWPROC) (Display *dpy, GLXWindow win); -typedef GLXPixmap ( * PFNGLXCREATEPIXMAPPROC) (Display *dpy, GLXFBConfig config, Pixmap pixmap, const int *attrib_list); -typedef void ( * PFNGLXDESTROYPIXMAPPROC) (Display *dpy, GLXPixmap pixmap); -typedef GLXPbuffer ( * PFNGLXCREATEPBUFFERPROC) (Display *dpy, GLXFBConfig config, const int *attrib_list); -typedef void ( * PFNGLXDESTROYPBUFFERPROC) (Display *dpy, GLXPbuffer pbuf); -typedef void ( * PFNGLXQUERYDRAWABLEPROC) (Display *dpy, GLXDrawable draw, int attribute, unsigned int *value); -typedef GLXContext ( * PFNGLXCREATENEWCONTEXTPROC) (Display *dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); -typedef Bool ( * PFNGLXMAKECONTEXTCURRENTPROC) (Display *dpy, GLXDrawable draw, GLXDrawable read, GLXContext ctx); -typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLEPROC) (void); -typedef Display * ( * PFNGLXGETCURRENTDISPLAYPROC) (void); -typedef int ( * PFNGLXQUERYCONTEXTPROC) (Display *dpy, GLXContext ctx, int attribute, int *value); -typedef void ( * PFNGLXSELECTEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long event_mask); -typedef void ( * PFNGLXGETSELECTEDEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long *event_mask); -#endif - -#ifndef GLX_ARB_get_proc_address -#define GLX_ARB_get_proc_address 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern __GLXextFuncPtr glXGetProcAddressARB (const GLubyte *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef __GLXextFuncPtr ( * PFNGLXGETPROCADDRESSARBPROC) (const GLubyte *procName); -#endif - -#ifndef GLX_SGIS_multisample -#define GLX_SGIS_multisample 1 -#endif - -#ifndef GLX_EXT_visual_info -#define GLX_EXT_visual_info 1 -#endif - -#ifndef GLX_SGI_swap_control -#define GLX_SGI_swap_control 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern int glXSwapIntervalSGI (int); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef int ( * PFNGLXSWAPINTERVALSGIPROC) (int interval); -#endif - -#ifndef GLX_SGI_video_sync -#define GLX_SGI_video_sync 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern int glXGetVideoSyncSGI (unsigned int *); -extern int glXWaitVideoSyncSGI (int, int, unsigned int *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef int ( * PFNGLXGETVIDEOSYNCSGIPROC) (unsigned int *count); -typedef int ( * PFNGLXWAITVIDEOSYNCSGIPROC) (int divisor, int remainder, unsigned int *count); -#endif - -#ifndef GLX_SGI_make_current_read -#define GLX_SGI_make_current_read 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern Bool glXMakeCurrentReadSGI (Display *, GLXDrawable, GLXDrawable, GLXContext); -extern GLXDrawable glXGetCurrentReadDrawableSGI (void); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef Bool ( * PFNGLXMAKECURRENTREADSGIPROC) (Display *dpy, GLXDrawable draw, GLXDrawable read, GLXContext ctx); -typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLESGIPROC) (void); -#endif - -#ifdef _VL_H -#ifndef GLX_SGIX_video_source -#define GLX_SGIX_video_source 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern GLXVideoSourceSGIX glXCreateGLXVideoSourceSGIX (Display *, int, VLServer, VLPath, int, VLNode); -extern void glXDestroyGLXVideoSourceSGIX (Display *, GLXVideoSourceSGIX); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef GLXVideoSourceSGIX ( * PFNGLXCREATEGLXVIDEOSOURCESGIXPROC) (Display *display, int screen, VLServer server, VLPath path, int nodeClass, VLNode drainNode); -typedef void ( * PFNGLXDESTROYGLXVIDEOSOURCESGIXPROC) (Display *dpy, GLXVideoSourceSGIX glxvideosource); -#endif - -#endif /* _VL_H */ -#ifndef GLX_EXT_visual_rating -#define GLX_EXT_visual_rating 1 -#endif - -#ifndef GLX_EXT_import_context -#define GLX_EXT_import_context 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern Display * glXGetCurrentDisplayEXT (void); -extern int glXQueryContextInfoEXT (Display *, GLXContext, int, int *); -extern GLXContextID glXGetContextIDEXT (GLXContext); -extern GLXContext glXImportContextEXT (Display *, GLXContextID); -extern void glXFreeContextEXT (Display *, GLXContext); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef Display * ( * PFNGLXGETCURRENTDISPLAYEXTPROC) (void); -typedef int ( * PFNGLXQUERYCONTEXTINFOEXTPROC) (Display *dpy, GLXContext context, int attribute, int *value); -typedef GLXContextID ( * PFNGLXGETCONTEXTIDEXTPROC) (GLXContext context); -typedef GLXContext ( * PFNGLXIMPORTCONTEXTEXTPROC) (Display *dpy, GLXContextID contextID); -typedef void ( * PFNGLXFREECONTEXTEXTPROC) (Display *dpy, GLXContext context); -#endif - -#ifndef GLX_SGIX_fbconfig -#define GLX_SGIX_fbconfig 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern int glXGetFBConfigAttribSGIX (Display *, GLXFBConfigSGIX, int, int *); -extern GLXFBConfigSGIX * glXChooseFBConfigSGIX (Display *, int, int *, int *); -extern GLXPixmap glXCreateGLXPixmapWithConfigSGIX (Display *, GLXFBConfigSGIX, Pixmap); -extern GLXContext glXCreateContextWithConfigSGIX (Display *, GLXFBConfigSGIX, int, GLXContext, Bool); -extern XVisualInfo * glXGetVisualFromFBConfigSGIX (Display *, GLXFBConfigSGIX); -extern GLXFBConfigSGIX glXGetFBConfigFromVisualSGIX (Display *, XVisualInfo *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef int ( * PFNGLXGETFBCONFIGATTRIBSGIXPROC) (Display *dpy, GLXFBConfigSGIX config, int attribute, int *value); -typedef GLXFBConfigSGIX * ( * PFNGLXCHOOSEFBCONFIGSGIXPROC) (Display *dpy, int screen, int *attrib_list, int *nelements); -typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC) (Display *dpy, GLXFBConfigSGIX config, Pixmap pixmap); -typedef GLXContext ( * PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC) (Display *dpy, GLXFBConfigSGIX config, int render_type, GLXContext share_list, Bool direct); -typedef XVisualInfo * ( * PFNGLXGETVISUALFROMFBCONFIGSGIXPROC) (Display *dpy, GLXFBConfigSGIX config); -typedef GLXFBConfigSGIX ( * PFNGLXGETFBCONFIGFROMVISUALSGIXPROC) (Display *dpy, XVisualInfo *vis); -#endif - -#ifndef GLX_SGIX_pbuffer -#define GLX_SGIX_pbuffer 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern GLXPbufferSGIX glXCreateGLXPbufferSGIX (Display *, GLXFBConfigSGIX, unsigned int, unsigned int, int *); -extern void glXDestroyGLXPbufferSGIX (Display *, GLXPbufferSGIX); -extern int glXQueryGLXPbufferSGIX (Display *, GLXPbufferSGIX, int, unsigned int *); -extern void glXSelectEventSGIX (Display *, GLXDrawable, unsigned long); -extern void glXGetSelectedEventSGIX (Display *, GLXDrawable, unsigned long *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef GLXPbufferSGIX ( * PFNGLXCREATEGLXPBUFFERSGIXPROC) (Display *dpy, GLXFBConfigSGIX config, unsigned int width, unsigned int height, int *attrib_list); -typedef void ( * PFNGLXDESTROYGLXPBUFFERSGIXPROC) (Display *dpy, GLXPbufferSGIX pbuf); -typedef int ( * PFNGLXQUERYGLXPBUFFERSGIXPROC) (Display *dpy, GLXPbufferSGIX pbuf, int attribute, unsigned int *value); -typedef void ( * PFNGLXSELECTEVENTSGIXPROC) (Display *dpy, GLXDrawable drawable, unsigned long mask); -typedef void ( * PFNGLXGETSELECTEDEVENTSGIXPROC) (Display *dpy, GLXDrawable drawable, unsigned long *mask); -#endif - -#ifndef GLX_SGI_cushion -#define GLX_SGI_cushion 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern void glXCushionSGI (Display *, Window, float); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef void ( * PFNGLXCUSHIONSGIPROC) (Display *dpy, Window window, float cushion); -#endif - -#ifndef GLX_SGIX_video_resize -#define GLX_SGIX_video_resize 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern int glXBindChannelToWindowSGIX (Display *, int, int, Window); -extern int glXChannelRectSGIX (Display *, int, int, int, int, int, int); -extern int glXQueryChannelRectSGIX (Display *, int, int, int *, int *, int *, int *); -extern int glXQueryChannelDeltasSGIX (Display *, int, int, int *, int *, int *, int *); -extern int glXChannelRectSyncSGIX (Display *, int, int, GLenum); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef int ( * PFNGLXBINDCHANNELTOWINDOWSGIXPROC) (Display *display, int screen, int channel, Window window); -typedef int ( * PFNGLXCHANNELRECTSGIXPROC) (Display *display, int screen, int channel, int x, int y, int w, int h); -typedef int ( * PFNGLXQUERYCHANNELRECTSGIXPROC) (Display *display, int screen, int channel, int *dx, int *dy, int *dw, int *dh); -typedef int ( * PFNGLXQUERYCHANNELDELTASSGIXPROC) (Display *display, int screen, int channel, int *x, int *y, int *w, int *h); -typedef int ( * PFNGLXCHANNELRECTSYNCSGIXPROC) (Display *display, int screen, int channel, GLenum synctype); -#endif - -#ifdef _DM_BUFFER_H_ -#ifndef GLX_SGIX_dmbuffer -#define GLX_SGIX_dmbuffer 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern Bool glXAssociateDMPbufferSGIX (Display *, GLXPbufferSGIX, DMparams *, DMbuffer); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef Bool ( * PFNGLXASSOCIATEDMPBUFFERSGIXPROC) (Display *dpy, GLXPbufferSGIX pbuffer, DMparams *params, DMbuffer dmbuffer); -#endif - -#endif /* _DM_BUFFER_H_ */ -#ifndef GLX_SGIX_swap_group -#define GLX_SGIX_swap_group 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern void glXJoinSwapGroupSGIX (Display *, GLXDrawable, GLXDrawable); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef void ( * PFNGLXJOINSWAPGROUPSGIXPROC) (Display *dpy, GLXDrawable drawable, GLXDrawable member); -#endif - -#ifndef GLX_SGIX_swap_barrier -#define GLX_SGIX_swap_barrier 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern void glXBindSwapBarrierSGIX (Display *, GLXDrawable, int); -extern Bool glXQueryMaxSwapBarriersSGIX (Display *, int, int *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef void ( * PFNGLXBINDSWAPBARRIERSGIXPROC) (Display *dpy, GLXDrawable drawable, int barrier); -typedef Bool ( * PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC) (Display *dpy, int screen, int *max); -#endif - -#ifndef GLX_SUN_get_transparent_index -#define GLX_SUN_get_transparent_index 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern Status glXGetTransparentIndexSUN (Display *, Window, Window, long *); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef Status ( * PFNGLXGETTRANSPARENTINDEXSUNPROC) (Display *dpy, Window overlay, Window underlay, long *pTransparentIndex); -#endif - -#ifndef GLX_MESA_copy_sub_buffer -#define GLX_MESA_copy_sub_buffer 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern void glXCopySubBufferMESA (Display *, GLXDrawable, int, int, int, int); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef void ( * PFNGLXCOPYSUBBUFFERMESAPROC) (Display *dpy, GLXDrawable drawable, int x, int y, int width, int height); -#endif - -#ifndef GLX_MESA_pixmap_colormap -#define GLX_MESA_pixmap_colormap 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern GLXPixmap glXCreateGLXPixmapMESA (Display *, XVisualInfo *, Pixmap, Colormap); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPMESAPROC) (Display *dpy, XVisualInfo *visual, Pixmap pixmap, Colormap cmap); -#endif - -#ifndef GLX_MESA_release_buffers -#define GLX_MESA_release_buffers 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern Bool glXReleaseBuffersMESA (Display *, GLXDrawable); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef Bool ( * PFNGLXRELEASEBUFFERSMESAPROC) (Display *dpy, GLXDrawable drawable); -#endif - -#ifndef GLX_MESA_set_3dfx_mode -#define GLX_MESA_set_3dfx_mode 1 -#ifdef GLX_GLXEXT_PROTOTYPES -extern Bool glXSet3DfxModeMESA (int); -#endif /* GLX_GLXEXT_PROTOTYPES */ -typedef Bool ( * PFNGLXSET3DFXMODEMESAPROC) (int mode); -#endif - - -#ifdef __cplusplus -} -#endif - -#endif - diff --git a/Demos/Glut/GL/wglew.h b/Demos/Glut/GL/wglew.h deleted file mode 100644 index 05f054fc8..000000000 --- a/Demos/Glut/GL/wglew.h +++ /dev/null @@ -1,1363 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -/* -** Copyright (c) 2007 The Khronos Group Inc. -** -** Permission is hereby granted, free of charge, to any person obtaining a -** copy of this software and/or associated documentation files (the -** "Materials"), to deal in the Materials without restriction, including -** without limitation the rights to use, copy, modify, merge, publish, -** distribute, sublicense, and/or sell copies of the Materials, and to -** permit persons to whom the Materials are furnished to do so, subject to -** the following conditions: -** -** The above copyright notice and this permission notice shall be included -** in all copies or substantial portions of the Materials. -** -** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. -*/ - -#ifndef __wglew_h__ -#define __wglew_h__ -#define __WGLEW_H__ - -#ifdef __wglext_h_ -#error wglext.h included before wglew.h -#endif - -#define __wglext_h_ - -#if !defined(WINAPI) -# ifndef WIN32_LEAN_AND_MEAN -# define WIN32_LEAN_AND_MEAN 1 -# endif -#include -# undef WIN32_LEAN_AND_MEAN -#endif - -/* - * GLEW_STATIC needs to be set when using the static version. - * GLEW_BUILD is set when building the DLL version. - */ -#ifdef GLEW_STATIC -# define GLEWAPI extern -#else -# ifdef GLEW_BUILD -# define GLEWAPI extern __declspec(dllexport) -# else -# define GLEWAPI extern __declspec(dllimport) -# endif -#endif - -#ifdef __cplusplus -extern "C" { -#endif - -/* -------------------------- WGL_3DFX_multisample ------------------------- */ - -#ifndef WGL_3DFX_multisample -#define WGL_3DFX_multisample 1 - -#define WGL_SAMPLE_BUFFERS_3DFX 0x2060 -#define WGL_SAMPLES_3DFX 0x2061 - -#define WGLEW_3DFX_multisample WGLEW_GET_VAR(__WGLEW_3DFX_multisample) - -#endif /* WGL_3DFX_multisample */ - -/* ------------------------- WGL_3DL_stereo_control ------------------------ */ - -#ifndef WGL_3DL_stereo_control -#define WGL_3DL_stereo_control 1 - -#define WGL_STEREO_EMITTER_ENABLE_3DL 0x2055 -#define WGL_STEREO_EMITTER_DISABLE_3DL 0x2056 -#define WGL_STEREO_POLARITY_NORMAL_3DL 0x2057 -#define WGL_STEREO_POLARITY_INVERT_3DL 0x2058 - -typedef BOOL (WINAPI * PFNWGLSETSTEREOEMITTERSTATE3DLPROC) (HDC hDC, UINT uState); - -#define wglSetStereoEmitterState3DL WGLEW_GET_FUN(__wglewSetStereoEmitterState3DL) - -#define WGLEW_3DL_stereo_control WGLEW_GET_VAR(__WGLEW_3DL_stereo_control) - -#endif /* WGL_3DL_stereo_control */ - -/* ------------------------ WGL_AMD_gpu_association ------------------------ */ - -#ifndef WGL_AMD_gpu_association -#define WGL_AMD_gpu_association 1 - -#define WGL_GPU_VENDOR_AMD 0x1F00 -#define WGL_GPU_RENDERER_STRING_AMD 0x1F01 -#define WGL_GPU_OPENGL_VERSION_STRING_AMD 0x1F02 -#define WGL_GPU_FASTEST_TARGET_GPUS_AMD 0x21A2 -#define WGL_GPU_RAM_AMD 0x21A3 -#define WGL_GPU_CLOCK_AMD 0x21A4 -#define WGL_GPU_NUM_PIPES_AMD 0x21A5 -#define WGL_GPU_NUM_SIMD_AMD 0x21A6 -#define WGL_GPU_NUM_RB_AMD 0x21A7 -#define WGL_GPU_NUM_SPI_AMD 0x21A8 - -typedef VOID (WINAPI * PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC) (HGLRC dstCtx, GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); -typedef HGLRC (WINAPI * PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC) (UINT id); -typedef HGLRC (WINAPI * PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC) (UINT id, HGLRC hShareContext, const int* attribList); -typedef BOOL (WINAPI * PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC) (HGLRC hglrc); -typedef UINT (WINAPI * PFNWGLGETCONTEXTGPUIDAMDPROC) (HGLRC hglrc); -typedef HGLRC (WINAPI * PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC) (void); -typedef UINT (WINAPI * PFNWGLGETGPUIDSAMDPROC) (UINT maxCount, UINT* ids); -typedef INT (WINAPI * PFNWGLGETGPUINFOAMDPROC) (UINT id, INT property, GLenum dataType, UINT size, void* data); -typedef BOOL (WINAPI * PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC) (HGLRC hglrc); - -#define wglBlitContextFramebufferAMD WGLEW_GET_FUN(__wglewBlitContextFramebufferAMD) -#define wglCreateAssociatedContextAMD WGLEW_GET_FUN(__wglewCreateAssociatedContextAMD) -#define wglCreateAssociatedContextAttribsAMD WGLEW_GET_FUN(__wglewCreateAssociatedContextAttribsAMD) -#define wglDeleteAssociatedContextAMD WGLEW_GET_FUN(__wglewDeleteAssociatedContextAMD) -#define wglGetContextGPUIDAMD WGLEW_GET_FUN(__wglewGetContextGPUIDAMD) -#define wglGetCurrentAssociatedContextAMD WGLEW_GET_FUN(__wglewGetCurrentAssociatedContextAMD) -#define wglGetGPUIDsAMD WGLEW_GET_FUN(__wglewGetGPUIDsAMD) -#define wglGetGPUInfoAMD WGLEW_GET_FUN(__wglewGetGPUInfoAMD) -#define wglMakeAssociatedContextCurrentAMD WGLEW_GET_FUN(__wglewMakeAssociatedContextCurrentAMD) - -#define WGLEW_AMD_gpu_association WGLEW_GET_VAR(__WGLEW_AMD_gpu_association) - -#endif /* WGL_AMD_gpu_association */ - -/* ------------------------- WGL_ARB_buffer_region ------------------------- */ - -#ifndef WGL_ARB_buffer_region -#define WGL_ARB_buffer_region 1 - -#define WGL_FRONT_COLOR_BUFFER_BIT_ARB 0x00000001 -#define WGL_BACK_COLOR_BUFFER_BIT_ARB 0x00000002 -#define WGL_DEPTH_BUFFER_BIT_ARB 0x00000004 -#define WGL_STENCIL_BUFFER_BIT_ARB 0x00000008 - -typedef HANDLE (WINAPI * PFNWGLCREATEBUFFERREGIONARBPROC) (HDC hDC, int iLayerPlane, UINT uType); -typedef VOID (WINAPI * PFNWGLDELETEBUFFERREGIONARBPROC) (HANDLE hRegion); -typedef BOOL (WINAPI * PFNWGLRESTOREBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height, int xSrc, int ySrc); -typedef BOOL (WINAPI * PFNWGLSAVEBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height); - -#define wglCreateBufferRegionARB WGLEW_GET_FUN(__wglewCreateBufferRegionARB) -#define wglDeleteBufferRegionARB WGLEW_GET_FUN(__wglewDeleteBufferRegionARB) -#define wglRestoreBufferRegionARB WGLEW_GET_FUN(__wglewRestoreBufferRegionARB) -#define wglSaveBufferRegionARB WGLEW_GET_FUN(__wglewSaveBufferRegionARB) - -#define WGLEW_ARB_buffer_region WGLEW_GET_VAR(__WGLEW_ARB_buffer_region) - -#endif /* WGL_ARB_buffer_region */ - -/* ------------------------- WGL_ARB_create_context ------------------------ */ - -#ifndef WGL_ARB_create_context -#define WGL_ARB_create_context 1 - -#define WGL_CONTEXT_DEBUG_BIT_ARB 0x0001 -#define WGL_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 -#define WGL_CONTEXT_MAJOR_VERSION_ARB 0x2091 -#define WGL_CONTEXT_MINOR_VERSION_ARB 0x2092 -#define WGL_CONTEXT_LAYER_PLANE_ARB 0x2093 -#define WGL_CONTEXT_FLAGS_ARB 0x2094 -#define ERROR_INVALID_VERSION_ARB 0x2095 -#define ERROR_INVALID_PROFILE_ARB 0x2096 - -typedef HGLRC (WINAPI * PFNWGLCREATECONTEXTATTRIBSARBPROC) (HDC hDC, HGLRC hShareContext, const int* attribList); - -#define wglCreateContextAttribsARB WGLEW_GET_FUN(__wglewCreateContextAttribsARB) - -#define WGLEW_ARB_create_context WGLEW_GET_VAR(__WGLEW_ARB_create_context) - -#endif /* WGL_ARB_create_context */ - -/* --------------------- WGL_ARB_create_context_profile -------------------- */ - -#ifndef WGL_ARB_create_context_profile -#define WGL_ARB_create_context_profile 1 - -#define WGL_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 -#define WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 -#define WGL_CONTEXT_PROFILE_MASK_ARB 0x9126 - -#define WGLEW_ARB_create_context_profile WGLEW_GET_VAR(__WGLEW_ARB_create_context_profile) - -#endif /* WGL_ARB_create_context_profile */ - -/* ------------------- WGL_ARB_create_context_robustness ------------------- */ - -#ifndef WGL_ARB_create_context_robustness -#define WGL_ARB_create_context_robustness 1 - -#define WGL_CONTEXT_ROBUST_ACCESS_BIT_ARB 0x00000004 -#define WGL_LOSE_CONTEXT_ON_RESET_ARB 0x8252 -#define WGL_CONTEXT_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 -#define WGL_NO_RESET_NOTIFICATION_ARB 0x8261 - -#define WGLEW_ARB_create_context_robustness WGLEW_GET_VAR(__WGLEW_ARB_create_context_robustness) - -#endif /* WGL_ARB_create_context_robustness */ - -/* ----------------------- WGL_ARB_extensions_string ----------------------- */ - -#ifndef WGL_ARB_extensions_string -#define WGL_ARB_extensions_string 1 - -typedef const char* (WINAPI * PFNWGLGETEXTENSIONSSTRINGARBPROC) (HDC hdc); - -#define wglGetExtensionsStringARB WGLEW_GET_FUN(__wglewGetExtensionsStringARB) - -#define WGLEW_ARB_extensions_string WGLEW_GET_VAR(__WGLEW_ARB_extensions_string) - -#endif /* WGL_ARB_extensions_string */ - -/* ------------------------ WGL_ARB_framebuffer_sRGB ----------------------- */ - -#ifndef WGL_ARB_framebuffer_sRGB -#define WGL_ARB_framebuffer_sRGB 1 - -#define WGL_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20A9 - -#define WGLEW_ARB_framebuffer_sRGB WGLEW_GET_VAR(__WGLEW_ARB_framebuffer_sRGB) - -#endif /* WGL_ARB_framebuffer_sRGB */ - -/* ----------------------- WGL_ARB_make_current_read ----------------------- */ - -#ifndef WGL_ARB_make_current_read -#define WGL_ARB_make_current_read 1 - -#define ERROR_INVALID_PIXEL_TYPE_ARB 0x2043 -#define ERROR_INCOMPATIBLE_DEVICE_CONTEXTS_ARB 0x2054 - -typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCARBPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTARBPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); - -#define wglGetCurrentReadDCARB WGLEW_GET_FUN(__wglewGetCurrentReadDCARB) -#define wglMakeContextCurrentARB WGLEW_GET_FUN(__wglewMakeContextCurrentARB) - -#define WGLEW_ARB_make_current_read WGLEW_GET_VAR(__WGLEW_ARB_make_current_read) - -#endif /* WGL_ARB_make_current_read */ - -/* -------------------------- WGL_ARB_multisample -------------------------- */ - -#ifndef WGL_ARB_multisample -#define WGL_ARB_multisample 1 - -#define WGL_SAMPLE_BUFFERS_ARB 0x2041 -#define WGL_SAMPLES_ARB 0x2042 - -#define WGLEW_ARB_multisample WGLEW_GET_VAR(__WGLEW_ARB_multisample) - -#endif /* WGL_ARB_multisample */ - -/* ---------------------------- WGL_ARB_pbuffer ---------------------------- */ - -#ifndef WGL_ARB_pbuffer -#define WGL_ARB_pbuffer 1 - -#define WGL_DRAW_TO_PBUFFER_ARB 0x202D -#define WGL_MAX_PBUFFER_PIXELS_ARB 0x202E -#define WGL_MAX_PBUFFER_WIDTH_ARB 0x202F -#define WGL_MAX_PBUFFER_HEIGHT_ARB 0x2030 -#define WGL_PBUFFER_LARGEST_ARB 0x2033 -#define WGL_PBUFFER_WIDTH_ARB 0x2034 -#define WGL_PBUFFER_HEIGHT_ARB 0x2035 -#define WGL_PBUFFER_LOST_ARB 0x2036 - -DECLARE_HANDLE(HPBUFFERARB); - -typedef HPBUFFERARB (WINAPI * PFNWGLCREATEPBUFFERARBPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList); -typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFERARBPROC) (HPBUFFERARB hPbuffer); -typedef HDC (WINAPI * PFNWGLGETPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer); -typedef BOOL (WINAPI * PFNWGLQUERYPBUFFERARBPROC) (HPBUFFERARB hPbuffer, int iAttribute, int* piValue); -typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer, HDC hDC); - -#define wglCreatePbufferARB WGLEW_GET_FUN(__wglewCreatePbufferARB) -#define wglDestroyPbufferARB WGLEW_GET_FUN(__wglewDestroyPbufferARB) -#define wglGetPbufferDCARB WGLEW_GET_FUN(__wglewGetPbufferDCARB) -#define wglQueryPbufferARB WGLEW_GET_FUN(__wglewQueryPbufferARB) -#define wglReleasePbufferDCARB WGLEW_GET_FUN(__wglewReleasePbufferDCARB) - -#define WGLEW_ARB_pbuffer WGLEW_GET_VAR(__WGLEW_ARB_pbuffer) - -#endif /* WGL_ARB_pbuffer */ - -/* -------------------------- WGL_ARB_pixel_format ------------------------- */ - -#ifndef WGL_ARB_pixel_format -#define WGL_ARB_pixel_format 1 - -#define WGL_NUMBER_PIXEL_FORMATS_ARB 0x2000 -#define WGL_DRAW_TO_WINDOW_ARB 0x2001 -#define WGL_DRAW_TO_BITMAP_ARB 0x2002 -#define WGL_ACCELERATION_ARB 0x2003 -#define WGL_NEED_PALETTE_ARB 0x2004 -#define WGL_NEED_SYSTEM_PALETTE_ARB 0x2005 -#define WGL_SWAP_LAYER_BUFFERS_ARB 0x2006 -#define WGL_SWAP_METHOD_ARB 0x2007 -#define WGL_NUMBER_OVERLAYS_ARB 0x2008 -#define WGL_NUMBER_UNDERLAYS_ARB 0x2009 -#define WGL_TRANSPARENT_ARB 0x200A -#define WGL_SHARE_DEPTH_ARB 0x200C -#define WGL_SHARE_STENCIL_ARB 0x200D -#define WGL_SHARE_ACCUM_ARB 0x200E -#define WGL_SUPPORT_GDI_ARB 0x200F -#define WGL_SUPPORT_OPENGL_ARB 0x2010 -#define WGL_DOUBLE_BUFFER_ARB 0x2011 -#define WGL_STEREO_ARB 0x2012 -#define WGL_PIXEL_TYPE_ARB 0x2013 -#define WGL_COLOR_BITS_ARB 0x2014 -#define WGL_RED_BITS_ARB 0x2015 -#define WGL_RED_SHIFT_ARB 0x2016 -#define WGL_GREEN_BITS_ARB 0x2017 -#define WGL_GREEN_SHIFT_ARB 0x2018 -#define WGL_BLUE_BITS_ARB 0x2019 -#define WGL_BLUE_SHIFT_ARB 0x201A -#define WGL_ALPHA_BITS_ARB 0x201B -#define WGL_ALPHA_SHIFT_ARB 0x201C -#define WGL_ACCUM_BITS_ARB 0x201D -#define WGL_ACCUM_RED_BITS_ARB 0x201E -#define WGL_ACCUM_GREEN_BITS_ARB 0x201F -#define WGL_ACCUM_BLUE_BITS_ARB 0x2020 -#define WGL_ACCUM_ALPHA_BITS_ARB 0x2021 -#define WGL_DEPTH_BITS_ARB 0x2022 -#define WGL_STENCIL_BITS_ARB 0x2023 -#define WGL_AUX_BUFFERS_ARB 0x2024 -#define WGL_NO_ACCELERATION_ARB 0x2025 -#define WGL_GENERIC_ACCELERATION_ARB 0x2026 -#define WGL_FULL_ACCELERATION_ARB 0x2027 -#define WGL_SWAP_EXCHANGE_ARB 0x2028 -#define WGL_SWAP_COPY_ARB 0x2029 -#define WGL_SWAP_UNDEFINED_ARB 0x202A -#define WGL_TYPE_RGBA_ARB 0x202B -#define WGL_TYPE_COLORINDEX_ARB 0x202C -#define WGL_TRANSPARENT_RED_VALUE_ARB 0x2037 -#define WGL_TRANSPARENT_GREEN_VALUE_ARB 0x2038 -#define WGL_TRANSPARENT_BLUE_VALUE_ARB 0x2039 -#define WGL_TRANSPARENT_ALPHA_VALUE_ARB 0x203A -#define WGL_TRANSPARENT_INDEX_VALUE_ARB 0x203B - -typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATARBPROC) (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, FLOAT *pfValues); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, int *piValues); - -#define wglChoosePixelFormatARB WGLEW_GET_FUN(__wglewChoosePixelFormatARB) -#define wglGetPixelFormatAttribfvARB WGLEW_GET_FUN(__wglewGetPixelFormatAttribfvARB) -#define wglGetPixelFormatAttribivARB WGLEW_GET_FUN(__wglewGetPixelFormatAttribivARB) - -#define WGLEW_ARB_pixel_format WGLEW_GET_VAR(__WGLEW_ARB_pixel_format) - -#endif /* WGL_ARB_pixel_format */ - -/* ----------------------- WGL_ARB_pixel_format_float ---------------------- */ - -#ifndef WGL_ARB_pixel_format_float -#define WGL_ARB_pixel_format_float 1 - -#define WGL_TYPE_RGBA_FLOAT_ARB 0x21A0 - -#define WGLEW_ARB_pixel_format_float WGLEW_GET_VAR(__WGLEW_ARB_pixel_format_float) - -#endif /* WGL_ARB_pixel_format_float */ - -/* ------------------------- WGL_ARB_render_texture ------------------------ */ - -#ifndef WGL_ARB_render_texture -#define WGL_ARB_render_texture 1 - -#define WGL_BIND_TO_TEXTURE_RGB_ARB 0x2070 -#define WGL_BIND_TO_TEXTURE_RGBA_ARB 0x2071 -#define WGL_TEXTURE_FORMAT_ARB 0x2072 -#define WGL_TEXTURE_TARGET_ARB 0x2073 -#define WGL_MIPMAP_TEXTURE_ARB 0x2074 -#define WGL_TEXTURE_RGB_ARB 0x2075 -#define WGL_TEXTURE_RGBA_ARB 0x2076 -#define WGL_NO_TEXTURE_ARB 0x2077 -#define WGL_TEXTURE_CUBE_MAP_ARB 0x2078 -#define WGL_TEXTURE_1D_ARB 0x2079 -#define WGL_TEXTURE_2D_ARB 0x207A -#define WGL_MIPMAP_LEVEL_ARB 0x207B -#define WGL_CUBE_MAP_FACE_ARB 0x207C -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x207D -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x207E -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x207F -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x2080 -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x2081 -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x2082 -#define WGL_FRONT_LEFT_ARB 0x2083 -#define WGL_FRONT_RIGHT_ARB 0x2084 -#define WGL_BACK_LEFT_ARB 0x2085 -#define WGL_BACK_RIGHT_ARB 0x2086 -#define WGL_AUX0_ARB 0x2087 -#define WGL_AUX1_ARB 0x2088 -#define WGL_AUX2_ARB 0x2089 -#define WGL_AUX3_ARB 0x208A -#define WGL_AUX4_ARB 0x208B -#define WGL_AUX5_ARB 0x208C -#define WGL_AUX6_ARB 0x208D -#define WGL_AUX7_ARB 0x208E -#define WGL_AUX8_ARB 0x208F -#define WGL_AUX9_ARB 0x2090 - -typedef BOOL (WINAPI * PFNWGLBINDTEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); -typedef BOOL (WINAPI * PFNWGLRELEASETEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); -typedef BOOL (WINAPI * PFNWGLSETPBUFFERATTRIBARBPROC) (HPBUFFERARB hPbuffer, const int* piAttribList); - -#define wglBindTexImageARB WGLEW_GET_FUN(__wglewBindTexImageARB) -#define wglReleaseTexImageARB WGLEW_GET_FUN(__wglewReleaseTexImageARB) -#define wglSetPbufferAttribARB WGLEW_GET_FUN(__wglewSetPbufferAttribARB) - -#define WGLEW_ARB_render_texture WGLEW_GET_VAR(__WGLEW_ARB_render_texture) - -#endif /* WGL_ARB_render_texture */ - -/* ----------------------- WGL_ATI_pixel_format_float ---------------------- */ - -#ifndef WGL_ATI_pixel_format_float -#define WGL_ATI_pixel_format_float 1 - -#define WGL_TYPE_RGBA_FLOAT_ATI 0x21A0 -#define GL_RGBA_FLOAT_MODE_ATI 0x8820 -#define GL_COLOR_CLEAR_UNCLAMPED_VALUE_ATI 0x8835 - -#define WGLEW_ATI_pixel_format_float WGLEW_GET_VAR(__WGLEW_ATI_pixel_format_float) - -#endif /* WGL_ATI_pixel_format_float */ - -/* -------------------- WGL_ATI_render_texture_rectangle ------------------- */ - -#ifndef WGL_ATI_render_texture_rectangle -#define WGL_ATI_render_texture_rectangle 1 - -#define WGL_TEXTURE_RECTANGLE_ATI 0x21A5 - -#define WGLEW_ATI_render_texture_rectangle WGLEW_GET_VAR(__WGLEW_ATI_render_texture_rectangle) - -#endif /* WGL_ATI_render_texture_rectangle */ - -/* ------------------- WGL_EXT_create_context_es2_profile ------------------ */ - -#ifndef WGL_EXT_create_context_es2_profile -#define WGL_EXT_create_context_es2_profile 1 - -#define WGL_CONTEXT_ES2_PROFILE_BIT_EXT 0x00000004 - -#define WGLEW_EXT_create_context_es2_profile WGLEW_GET_VAR(__WGLEW_EXT_create_context_es2_profile) - -#endif /* WGL_EXT_create_context_es2_profile */ - -/* -------------------------- WGL_EXT_depth_float -------------------------- */ - -#ifndef WGL_EXT_depth_float -#define WGL_EXT_depth_float 1 - -#define WGL_DEPTH_FLOAT_EXT 0x2040 - -#define WGLEW_EXT_depth_float WGLEW_GET_VAR(__WGLEW_EXT_depth_float) - -#endif /* WGL_EXT_depth_float */ - -/* ---------------------- WGL_EXT_display_color_table ---------------------- */ - -#ifndef WGL_EXT_display_color_table -#define WGL_EXT_display_color_table 1 - -typedef GLboolean (WINAPI * PFNWGLBINDDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef GLboolean (WINAPI * PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef void (WINAPI * PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef GLboolean (WINAPI * PFNWGLLOADDISPLAYCOLORTABLEEXTPROC) (GLushort* table, GLuint length); - -#define wglBindDisplayColorTableEXT WGLEW_GET_FUN(__wglewBindDisplayColorTableEXT) -#define wglCreateDisplayColorTableEXT WGLEW_GET_FUN(__wglewCreateDisplayColorTableEXT) -#define wglDestroyDisplayColorTableEXT WGLEW_GET_FUN(__wglewDestroyDisplayColorTableEXT) -#define wglLoadDisplayColorTableEXT WGLEW_GET_FUN(__wglewLoadDisplayColorTableEXT) - -#define WGLEW_EXT_display_color_table WGLEW_GET_VAR(__WGLEW_EXT_display_color_table) - -#endif /* WGL_EXT_display_color_table */ - -/* ----------------------- WGL_EXT_extensions_string ----------------------- */ - -#ifndef WGL_EXT_extensions_string -#define WGL_EXT_extensions_string 1 - -typedef const char* (WINAPI * PFNWGLGETEXTENSIONSSTRINGEXTPROC) (void); - -#define wglGetExtensionsStringEXT WGLEW_GET_FUN(__wglewGetExtensionsStringEXT) - -#define WGLEW_EXT_extensions_string WGLEW_GET_VAR(__WGLEW_EXT_extensions_string) - -#endif /* WGL_EXT_extensions_string */ - -/* ------------------------ WGL_EXT_framebuffer_sRGB ----------------------- */ - -#ifndef WGL_EXT_framebuffer_sRGB -#define WGL_EXT_framebuffer_sRGB 1 - -#define WGL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20A9 - -#define WGLEW_EXT_framebuffer_sRGB WGLEW_GET_VAR(__WGLEW_EXT_framebuffer_sRGB) - -#endif /* WGL_EXT_framebuffer_sRGB */ - -/* ----------------------- WGL_EXT_make_current_read ----------------------- */ - -#ifndef WGL_EXT_make_current_read -#define WGL_EXT_make_current_read 1 - -#define ERROR_INVALID_PIXEL_TYPE_EXT 0x2043 - -typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCEXTPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTEXTPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); - -#define wglGetCurrentReadDCEXT WGLEW_GET_FUN(__wglewGetCurrentReadDCEXT) -#define wglMakeContextCurrentEXT WGLEW_GET_FUN(__wglewMakeContextCurrentEXT) - -#define WGLEW_EXT_make_current_read WGLEW_GET_VAR(__WGLEW_EXT_make_current_read) - -#endif /* WGL_EXT_make_current_read */ - -/* -------------------------- WGL_EXT_multisample -------------------------- */ - -#ifndef WGL_EXT_multisample -#define WGL_EXT_multisample 1 - -#define WGL_SAMPLE_BUFFERS_EXT 0x2041 -#define WGL_SAMPLES_EXT 0x2042 - -#define WGLEW_EXT_multisample WGLEW_GET_VAR(__WGLEW_EXT_multisample) - -#endif /* WGL_EXT_multisample */ - -/* ---------------------------- WGL_EXT_pbuffer ---------------------------- */ - -#ifndef WGL_EXT_pbuffer -#define WGL_EXT_pbuffer 1 - -#define WGL_DRAW_TO_PBUFFER_EXT 0x202D -#define WGL_MAX_PBUFFER_PIXELS_EXT 0x202E -#define WGL_MAX_PBUFFER_WIDTH_EXT 0x202F -#define WGL_MAX_PBUFFER_HEIGHT_EXT 0x2030 -#define WGL_OPTIMAL_PBUFFER_WIDTH_EXT 0x2031 -#define WGL_OPTIMAL_PBUFFER_HEIGHT_EXT 0x2032 -#define WGL_PBUFFER_LARGEST_EXT 0x2033 -#define WGL_PBUFFER_WIDTH_EXT 0x2034 -#define WGL_PBUFFER_HEIGHT_EXT 0x2035 - -DECLARE_HANDLE(HPBUFFEREXT); - -typedef HPBUFFEREXT (WINAPI * PFNWGLCREATEPBUFFEREXTPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList); -typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer); -typedef HDC (WINAPI * PFNWGLGETPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer); -typedef BOOL (WINAPI * PFNWGLQUERYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer, int iAttribute, int* piValue); -typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer, HDC hDC); - -#define wglCreatePbufferEXT WGLEW_GET_FUN(__wglewCreatePbufferEXT) -#define wglDestroyPbufferEXT WGLEW_GET_FUN(__wglewDestroyPbufferEXT) -#define wglGetPbufferDCEXT WGLEW_GET_FUN(__wglewGetPbufferDCEXT) -#define wglQueryPbufferEXT WGLEW_GET_FUN(__wglewQueryPbufferEXT) -#define wglReleasePbufferDCEXT WGLEW_GET_FUN(__wglewReleasePbufferDCEXT) - -#define WGLEW_EXT_pbuffer WGLEW_GET_VAR(__WGLEW_EXT_pbuffer) - -#endif /* WGL_EXT_pbuffer */ - -/* -------------------------- WGL_EXT_pixel_format ------------------------- */ - -#ifndef WGL_EXT_pixel_format -#define WGL_EXT_pixel_format 1 - -#define WGL_NUMBER_PIXEL_FORMATS_EXT 0x2000 -#define WGL_DRAW_TO_WINDOW_EXT 0x2001 -#define WGL_DRAW_TO_BITMAP_EXT 0x2002 -#define WGL_ACCELERATION_EXT 0x2003 -#define WGL_NEED_PALETTE_EXT 0x2004 -#define WGL_NEED_SYSTEM_PALETTE_EXT 0x2005 -#define WGL_SWAP_LAYER_BUFFERS_EXT 0x2006 -#define WGL_SWAP_METHOD_EXT 0x2007 -#define WGL_NUMBER_OVERLAYS_EXT 0x2008 -#define WGL_NUMBER_UNDERLAYS_EXT 0x2009 -#define WGL_TRANSPARENT_EXT 0x200A -#define WGL_TRANSPARENT_VALUE_EXT 0x200B -#define WGL_SHARE_DEPTH_EXT 0x200C -#define WGL_SHARE_STENCIL_EXT 0x200D -#define WGL_SHARE_ACCUM_EXT 0x200E -#define WGL_SUPPORT_GDI_EXT 0x200F -#define WGL_SUPPORT_OPENGL_EXT 0x2010 -#define WGL_DOUBLE_BUFFER_EXT 0x2011 -#define WGL_STEREO_EXT 0x2012 -#define WGL_PIXEL_TYPE_EXT 0x2013 -#define WGL_COLOR_BITS_EXT 0x2014 -#define WGL_RED_BITS_EXT 0x2015 -#define WGL_RED_SHIFT_EXT 0x2016 -#define WGL_GREEN_BITS_EXT 0x2017 -#define WGL_GREEN_SHIFT_EXT 0x2018 -#define WGL_BLUE_BITS_EXT 0x2019 -#define WGL_BLUE_SHIFT_EXT 0x201A -#define WGL_ALPHA_BITS_EXT 0x201B -#define WGL_ALPHA_SHIFT_EXT 0x201C -#define WGL_ACCUM_BITS_EXT 0x201D -#define WGL_ACCUM_RED_BITS_EXT 0x201E -#define WGL_ACCUM_GREEN_BITS_EXT 0x201F -#define WGL_ACCUM_BLUE_BITS_EXT 0x2020 -#define WGL_ACCUM_ALPHA_BITS_EXT 0x2021 -#define WGL_DEPTH_BITS_EXT 0x2022 -#define WGL_STENCIL_BITS_EXT 0x2023 -#define WGL_AUX_BUFFERS_EXT 0x2024 -#define WGL_NO_ACCELERATION_EXT 0x2025 -#define WGL_GENERIC_ACCELERATION_EXT 0x2026 -#define WGL_FULL_ACCELERATION_EXT 0x2027 -#define WGL_SWAP_EXCHANGE_EXT 0x2028 -#define WGL_SWAP_COPY_EXT 0x2029 -#define WGL_SWAP_UNDEFINED_EXT 0x202A -#define WGL_TYPE_RGBA_EXT 0x202B -#define WGL_TYPE_COLORINDEX_EXT 0x202C - -typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATEXTPROC) (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, FLOAT *pfValues); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, int *piValues); - -#define wglChoosePixelFormatEXT WGLEW_GET_FUN(__wglewChoosePixelFormatEXT) -#define wglGetPixelFormatAttribfvEXT WGLEW_GET_FUN(__wglewGetPixelFormatAttribfvEXT) -#define wglGetPixelFormatAttribivEXT WGLEW_GET_FUN(__wglewGetPixelFormatAttribivEXT) - -#define WGLEW_EXT_pixel_format WGLEW_GET_VAR(__WGLEW_EXT_pixel_format) - -#endif /* WGL_EXT_pixel_format */ - -/* ------------------- WGL_EXT_pixel_format_packed_float ------------------- */ - -#ifndef WGL_EXT_pixel_format_packed_float -#define WGL_EXT_pixel_format_packed_float 1 - -#define WGL_TYPE_RGBA_UNSIGNED_FLOAT_EXT 0x20A8 - -#define WGLEW_EXT_pixel_format_packed_float WGLEW_GET_VAR(__WGLEW_EXT_pixel_format_packed_float) - -#endif /* WGL_EXT_pixel_format_packed_float */ - -/* -------------------------- WGL_EXT_swap_control ------------------------- */ - -#ifndef WGL_EXT_swap_control -#define WGL_EXT_swap_control 1 - -typedef int (WINAPI * PFNWGLGETSWAPINTERVALEXTPROC) (void); -typedef BOOL (WINAPI * PFNWGLSWAPINTERVALEXTPROC) (int interval); - -#define wglGetSwapIntervalEXT WGLEW_GET_FUN(__wglewGetSwapIntervalEXT) -#define wglSwapIntervalEXT WGLEW_GET_FUN(__wglewSwapIntervalEXT) - -#define WGLEW_EXT_swap_control WGLEW_GET_VAR(__WGLEW_EXT_swap_control) - -#endif /* WGL_EXT_swap_control */ - -/* --------------------- WGL_I3D_digital_video_control --------------------- */ - -#ifndef WGL_I3D_digital_video_control -#define WGL_I3D_digital_video_control 1 - -#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_FRAMEBUFFER_I3D 0x2050 -#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_VALUE_I3D 0x2051 -#define WGL_DIGITAL_VIDEO_CURSOR_INCLUDED_I3D 0x2052 -#define WGL_DIGITAL_VIDEO_GAMMA_CORRECTED_I3D 0x2053 - -typedef BOOL (WINAPI * PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC) (HDC hDC, int iAttribute, int* piValue); -typedef BOOL (WINAPI * PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC) (HDC hDC, int iAttribute, const int* piValue); - -#define wglGetDigitalVideoParametersI3D WGLEW_GET_FUN(__wglewGetDigitalVideoParametersI3D) -#define wglSetDigitalVideoParametersI3D WGLEW_GET_FUN(__wglewSetDigitalVideoParametersI3D) - -#define WGLEW_I3D_digital_video_control WGLEW_GET_VAR(__WGLEW_I3D_digital_video_control) - -#endif /* WGL_I3D_digital_video_control */ - -/* ----------------------------- WGL_I3D_gamma ----------------------------- */ - -#ifndef WGL_I3D_gamma -#define WGL_I3D_gamma 1 - -#define WGL_GAMMA_TABLE_SIZE_I3D 0x204E -#define WGL_GAMMA_EXCLUDE_DESKTOP_I3D 0x204F - -typedef BOOL (WINAPI * PFNWGLGETGAMMATABLEI3DPROC) (HDC hDC, int iEntries, USHORT* puRed, USHORT *puGreen, USHORT *puBlue); -typedef BOOL (WINAPI * PFNWGLGETGAMMATABLEPARAMETERSI3DPROC) (HDC hDC, int iAttribute, int* piValue); -typedef BOOL (WINAPI * PFNWGLSETGAMMATABLEI3DPROC) (HDC hDC, int iEntries, const USHORT* puRed, const USHORT *puGreen, const USHORT *puBlue); -typedef BOOL (WINAPI * PFNWGLSETGAMMATABLEPARAMETERSI3DPROC) (HDC hDC, int iAttribute, const int* piValue); - -#define wglGetGammaTableI3D WGLEW_GET_FUN(__wglewGetGammaTableI3D) -#define wglGetGammaTableParametersI3D WGLEW_GET_FUN(__wglewGetGammaTableParametersI3D) -#define wglSetGammaTableI3D WGLEW_GET_FUN(__wglewSetGammaTableI3D) -#define wglSetGammaTableParametersI3D WGLEW_GET_FUN(__wglewSetGammaTableParametersI3D) - -#define WGLEW_I3D_gamma WGLEW_GET_VAR(__WGLEW_I3D_gamma) - -#endif /* WGL_I3D_gamma */ - -/* ---------------------------- WGL_I3D_genlock ---------------------------- */ - -#ifndef WGL_I3D_genlock -#define WGL_I3D_genlock 1 - -#define WGL_GENLOCK_SOURCE_MULTIVIEW_I3D 0x2044 -#define WGL_GENLOCK_SOURCE_EXTERNAL_SYNC_I3D 0x2045 -#define WGL_GENLOCK_SOURCE_EXTERNAL_FIELD_I3D 0x2046 -#define WGL_GENLOCK_SOURCE_EXTERNAL_TTL_I3D 0x2047 -#define WGL_GENLOCK_SOURCE_DIGITAL_SYNC_I3D 0x2048 -#define WGL_GENLOCK_SOURCE_DIGITAL_FIELD_I3D 0x2049 -#define WGL_GENLOCK_SOURCE_EDGE_FALLING_I3D 0x204A -#define WGL_GENLOCK_SOURCE_EDGE_RISING_I3D 0x204B -#define WGL_GENLOCK_SOURCE_EDGE_BOTH_I3D 0x204C - -typedef BOOL (WINAPI * PFNWGLDISABLEGENLOCKI3DPROC) (HDC hDC); -typedef BOOL (WINAPI * PFNWGLENABLEGENLOCKI3DPROC) (HDC hDC); -typedef BOOL (WINAPI * PFNWGLGENLOCKSAMPLERATEI3DPROC) (HDC hDC, UINT uRate); -typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEDELAYI3DPROC) (HDC hDC, UINT uDelay); -typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEEDGEI3DPROC) (HDC hDC, UINT uEdge); -typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEI3DPROC) (HDC hDC, UINT uSource); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSAMPLERATEI3DPROC) (HDC hDC, UINT* uRate); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEDELAYI3DPROC) (HDC hDC, UINT* uDelay); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEEDGEI3DPROC) (HDC hDC, UINT* uEdge); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEI3DPROC) (HDC hDC, UINT* uSource); -typedef BOOL (WINAPI * PFNWGLISENABLEDGENLOCKI3DPROC) (HDC hDC, BOOL* pFlag); -typedef BOOL (WINAPI * PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC) (HDC hDC, UINT* uMaxLineDelay, UINT *uMaxPixelDelay); - -#define wglDisableGenlockI3D WGLEW_GET_FUN(__wglewDisableGenlockI3D) -#define wglEnableGenlockI3D WGLEW_GET_FUN(__wglewEnableGenlockI3D) -#define wglGenlockSampleRateI3D WGLEW_GET_FUN(__wglewGenlockSampleRateI3D) -#define wglGenlockSourceDelayI3D WGLEW_GET_FUN(__wglewGenlockSourceDelayI3D) -#define wglGenlockSourceEdgeI3D WGLEW_GET_FUN(__wglewGenlockSourceEdgeI3D) -#define wglGenlockSourceI3D WGLEW_GET_FUN(__wglewGenlockSourceI3D) -#define wglGetGenlockSampleRateI3D WGLEW_GET_FUN(__wglewGetGenlockSampleRateI3D) -#define wglGetGenlockSourceDelayI3D WGLEW_GET_FUN(__wglewGetGenlockSourceDelayI3D) -#define wglGetGenlockSourceEdgeI3D WGLEW_GET_FUN(__wglewGetGenlockSourceEdgeI3D) -#define wglGetGenlockSourceI3D WGLEW_GET_FUN(__wglewGetGenlockSourceI3D) -#define wglIsEnabledGenlockI3D WGLEW_GET_FUN(__wglewIsEnabledGenlockI3D) -#define wglQueryGenlockMaxSourceDelayI3D WGLEW_GET_FUN(__wglewQueryGenlockMaxSourceDelayI3D) - -#define WGLEW_I3D_genlock WGLEW_GET_VAR(__WGLEW_I3D_genlock) - -#endif /* WGL_I3D_genlock */ - -/* -------------------------- WGL_I3D_image_buffer ------------------------- */ - -#ifndef WGL_I3D_image_buffer -#define WGL_I3D_image_buffer 1 - -#define WGL_IMAGE_BUFFER_MIN_ACCESS_I3D 0x00000001 -#define WGL_IMAGE_BUFFER_LOCK_I3D 0x00000002 - -typedef BOOL (WINAPI * PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC) (HDC hdc, HANDLE* pEvent, LPVOID *pAddress, DWORD *pSize, UINT count); -typedef LPVOID (WINAPI * PFNWGLCREATEIMAGEBUFFERI3DPROC) (HDC hDC, DWORD dwSize, UINT uFlags); -typedef BOOL (WINAPI * PFNWGLDESTROYIMAGEBUFFERI3DPROC) (HDC hDC, LPVOID pAddress); -typedef BOOL (WINAPI * PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC) (HDC hdc, LPVOID* pAddress, UINT count); - -#define wglAssociateImageBufferEventsI3D WGLEW_GET_FUN(__wglewAssociateImageBufferEventsI3D) -#define wglCreateImageBufferI3D WGLEW_GET_FUN(__wglewCreateImageBufferI3D) -#define wglDestroyImageBufferI3D WGLEW_GET_FUN(__wglewDestroyImageBufferI3D) -#define wglReleaseImageBufferEventsI3D WGLEW_GET_FUN(__wglewReleaseImageBufferEventsI3D) - -#define WGLEW_I3D_image_buffer WGLEW_GET_VAR(__WGLEW_I3D_image_buffer) - -#endif /* WGL_I3D_image_buffer */ - -/* ------------------------ WGL_I3D_swap_frame_lock ------------------------ */ - -#ifndef WGL_I3D_swap_frame_lock -#define WGL_I3D_swap_frame_lock 1 - -typedef BOOL (WINAPI * PFNWGLDISABLEFRAMELOCKI3DPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLENABLEFRAMELOCKI3DPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLISENABLEDFRAMELOCKI3DPROC) (BOOL* pFlag); -typedef BOOL (WINAPI * PFNWGLQUERYFRAMELOCKMASTERI3DPROC) (BOOL* pFlag); - -#define wglDisableFrameLockI3D WGLEW_GET_FUN(__wglewDisableFrameLockI3D) -#define wglEnableFrameLockI3D WGLEW_GET_FUN(__wglewEnableFrameLockI3D) -#define wglIsEnabledFrameLockI3D WGLEW_GET_FUN(__wglewIsEnabledFrameLockI3D) -#define wglQueryFrameLockMasterI3D WGLEW_GET_FUN(__wglewQueryFrameLockMasterI3D) - -#define WGLEW_I3D_swap_frame_lock WGLEW_GET_VAR(__WGLEW_I3D_swap_frame_lock) - -#endif /* WGL_I3D_swap_frame_lock */ - -/* ------------------------ WGL_I3D_swap_frame_usage ----------------------- */ - -#ifndef WGL_I3D_swap_frame_usage -#define WGL_I3D_swap_frame_usage 1 - -typedef BOOL (WINAPI * PFNWGLBEGINFRAMETRACKINGI3DPROC) (void); -typedef BOOL (WINAPI * PFNWGLENDFRAMETRACKINGI3DPROC) (void); -typedef BOOL (WINAPI * PFNWGLGETFRAMEUSAGEI3DPROC) (float* pUsage); -typedef BOOL (WINAPI * PFNWGLQUERYFRAMETRACKINGI3DPROC) (DWORD* pFrameCount, DWORD *pMissedFrames, float *pLastMissedUsage); - -#define wglBeginFrameTrackingI3D WGLEW_GET_FUN(__wglewBeginFrameTrackingI3D) -#define wglEndFrameTrackingI3D WGLEW_GET_FUN(__wglewEndFrameTrackingI3D) -#define wglGetFrameUsageI3D WGLEW_GET_FUN(__wglewGetFrameUsageI3D) -#define wglQueryFrameTrackingI3D WGLEW_GET_FUN(__wglewQueryFrameTrackingI3D) - -#define WGLEW_I3D_swap_frame_usage WGLEW_GET_VAR(__WGLEW_I3D_swap_frame_usage) - -#endif /* WGL_I3D_swap_frame_usage */ - -/* --------------------------- WGL_NV_DX_interop --------------------------- */ - -#ifndef WGL_NV_DX_interop -#define WGL_NV_DX_interop 1 - -#define WGL_ACCESS_READ_ONLY_NV 0x0000 -#define WGL_ACCESS_READ_WRITE_NV 0x0001 -#define WGL_ACCESS_WRITE_DISCARD_NV 0x0002 - -typedef BOOL (WINAPI * PFNWGLDXCLOSEDEVICENVPROC) (HANDLE hDevice); -typedef BOOL (WINAPI * PFNWGLDXLOCKOBJECTSNVPROC) (HANDLE hDevice, GLint count, HANDLE* hObjects); -typedef BOOL (WINAPI * PFNWGLDXOBJECTACCESSNVPROC) (HANDLE hObject, GLenum access); -typedef HANDLE (WINAPI * PFNWGLDXOPENDEVICENVPROC) (void* dxDevice); -typedef HANDLE (WINAPI * PFNWGLDXREGISTEROBJECTNVPROC) (HANDLE hDevice, void* dxObject, GLuint name, GLenum type, GLenum access); -typedef BOOL (WINAPI * PFNWGLDXSETRESOURCESHAREHANDLENVPROC) (void* dxObject, HANDLE shareHandle); -typedef BOOL (WINAPI * PFNWGLDXUNLOCKOBJECTSNVPROC) (HANDLE hDevice, GLint count, HANDLE* hObjects); -typedef BOOL (WINAPI * PFNWGLDXUNREGISTEROBJECTNVPROC) (HANDLE hDevice, HANDLE hObject); - -#define wglDXCloseDeviceNV WGLEW_GET_FUN(__wglewDXCloseDeviceNV) -#define wglDXLockObjectsNV WGLEW_GET_FUN(__wglewDXLockObjectsNV) -#define wglDXObjectAccessNV WGLEW_GET_FUN(__wglewDXObjectAccessNV) -#define wglDXOpenDeviceNV WGLEW_GET_FUN(__wglewDXOpenDeviceNV) -#define wglDXRegisterObjectNV WGLEW_GET_FUN(__wglewDXRegisterObjectNV) -#define wglDXSetResourceShareHandleNV WGLEW_GET_FUN(__wglewDXSetResourceShareHandleNV) -#define wglDXUnlockObjectsNV WGLEW_GET_FUN(__wglewDXUnlockObjectsNV) -#define wglDXUnregisterObjectNV WGLEW_GET_FUN(__wglewDXUnregisterObjectNV) - -#define WGLEW_NV_DX_interop WGLEW_GET_VAR(__WGLEW_NV_DX_interop) - -#endif /* WGL_NV_DX_interop */ - -/* --------------------------- WGL_NV_copy_image --------------------------- */ - -#ifndef WGL_NV_copy_image -#define WGL_NV_copy_image 1 - -typedef BOOL (WINAPI * PFNWGLCOPYIMAGESUBDATANVPROC) (HGLRC hSrcRC, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, HGLRC hDstRC, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); - -#define wglCopyImageSubDataNV WGLEW_GET_FUN(__wglewCopyImageSubDataNV) - -#define WGLEW_NV_copy_image WGLEW_GET_VAR(__WGLEW_NV_copy_image) - -#endif /* WGL_NV_copy_image */ - -/* -------------------------- WGL_NV_float_buffer -------------------------- */ - -#ifndef WGL_NV_float_buffer -#define WGL_NV_float_buffer 1 - -#define WGL_FLOAT_COMPONENTS_NV 0x20B0 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_R_NV 0x20B1 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RG_NV 0x20B2 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGB_NV 0x20B3 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGBA_NV 0x20B4 -#define WGL_TEXTURE_FLOAT_R_NV 0x20B5 -#define WGL_TEXTURE_FLOAT_RG_NV 0x20B6 -#define WGL_TEXTURE_FLOAT_RGB_NV 0x20B7 -#define WGL_TEXTURE_FLOAT_RGBA_NV 0x20B8 - -#define WGLEW_NV_float_buffer WGLEW_GET_VAR(__WGLEW_NV_float_buffer) - -#endif /* WGL_NV_float_buffer */ - -/* -------------------------- WGL_NV_gpu_affinity -------------------------- */ - -#ifndef WGL_NV_gpu_affinity -#define WGL_NV_gpu_affinity 1 - -#define WGL_ERROR_INCOMPATIBLE_AFFINITY_MASKS_NV 0x20D0 -#define WGL_ERROR_MISSING_AFFINITY_MASK_NV 0x20D1 - -DECLARE_HANDLE(HGPUNV); -typedef struct _GPU_DEVICE { - DWORD cb; - CHAR DeviceName[32]; - CHAR DeviceString[128]; - DWORD Flags; - RECT rcVirtualScreen; -} GPU_DEVICE, *PGPU_DEVICE; - -typedef HDC (WINAPI * PFNWGLCREATEAFFINITYDCNVPROC) (const HGPUNV *phGpuList); -typedef BOOL (WINAPI * PFNWGLDELETEDCNVPROC) (HDC hdc); -typedef BOOL (WINAPI * PFNWGLENUMGPUDEVICESNVPROC) (HGPUNV hGpu, UINT iDeviceIndex, PGPU_DEVICE lpGpuDevice); -typedef BOOL (WINAPI * PFNWGLENUMGPUSFROMAFFINITYDCNVPROC) (HDC hAffinityDC, UINT iGpuIndex, HGPUNV *hGpu); -typedef BOOL (WINAPI * PFNWGLENUMGPUSNVPROC) (UINT iGpuIndex, HGPUNV *phGpu); - -#define wglCreateAffinityDCNV WGLEW_GET_FUN(__wglewCreateAffinityDCNV) -#define wglDeleteDCNV WGLEW_GET_FUN(__wglewDeleteDCNV) -#define wglEnumGpuDevicesNV WGLEW_GET_FUN(__wglewEnumGpuDevicesNV) -#define wglEnumGpusFromAffinityDCNV WGLEW_GET_FUN(__wglewEnumGpusFromAffinityDCNV) -#define wglEnumGpusNV WGLEW_GET_FUN(__wglewEnumGpusNV) - -#define WGLEW_NV_gpu_affinity WGLEW_GET_VAR(__WGLEW_NV_gpu_affinity) - -#endif /* WGL_NV_gpu_affinity */ - -/* ---------------------- WGL_NV_multisample_coverage ---------------------- */ - -#ifndef WGL_NV_multisample_coverage -#define WGL_NV_multisample_coverage 1 - -#define WGL_COVERAGE_SAMPLES_NV 0x2042 -#define WGL_COLOR_SAMPLES_NV 0x20B9 - -#define WGLEW_NV_multisample_coverage WGLEW_GET_VAR(__WGLEW_NV_multisample_coverage) - -#endif /* WGL_NV_multisample_coverage */ - -/* -------------------------- WGL_NV_present_video ------------------------- */ - -#ifndef WGL_NV_present_video -#define WGL_NV_present_video 1 - -#define WGL_NUM_VIDEO_SLOTS_NV 0x20F0 - -DECLARE_HANDLE(HVIDEOOUTPUTDEVICENV); - -typedef BOOL (WINAPI * PFNWGLBINDVIDEODEVICENVPROC) (HDC hDc, unsigned int uVideoSlot, HVIDEOOUTPUTDEVICENV hVideoDevice, const int* piAttribList); -typedef int (WINAPI * PFNWGLENUMERATEVIDEODEVICESNVPROC) (HDC hDc, HVIDEOOUTPUTDEVICENV* phDeviceList); -typedef BOOL (WINAPI * PFNWGLQUERYCURRENTCONTEXTNVPROC) (int iAttribute, int* piValue); - -#define wglBindVideoDeviceNV WGLEW_GET_FUN(__wglewBindVideoDeviceNV) -#define wglEnumerateVideoDevicesNV WGLEW_GET_FUN(__wglewEnumerateVideoDevicesNV) -#define wglQueryCurrentContextNV WGLEW_GET_FUN(__wglewQueryCurrentContextNV) - -#define WGLEW_NV_present_video WGLEW_GET_VAR(__WGLEW_NV_present_video) - -#endif /* WGL_NV_present_video */ - -/* ---------------------- WGL_NV_render_depth_texture ---------------------- */ - -#ifndef WGL_NV_render_depth_texture -#define WGL_NV_render_depth_texture 1 - -#define WGL_NO_TEXTURE_ARB 0x2077 -#define WGL_BIND_TO_TEXTURE_DEPTH_NV 0x20A3 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_DEPTH_NV 0x20A4 -#define WGL_DEPTH_TEXTURE_FORMAT_NV 0x20A5 -#define WGL_TEXTURE_DEPTH_COMPONENT_NV 0x20A6 -#define WGL_DEPTH_COMPONENT_NV 0x20A7 - -#define WGLEW_NV_render_depth_texture WGLEW_GET_VAR(__WGLEW_NV_render_depth_texture) - -#endif /* WGL_NV_render_depth_texture */ - -/* -------------------- WGL_NV_render_texture_rectangle -------------------- */ - -#ifndef WGL_NV_render_texture_rectangle -#define WGL_NV_render_texture_rectangle 1 - -#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGB_NV 0x20A0 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGBA_NV 0x20A1 -#define WGL_TEXTURE_RECTANGLE_NV 0x20A2 - -#define WGLEW_NV_render_texture_rectangle WGLEW_GET_VAR(__WGLEW_NV_render_texture_rectangle) - -#endif /* WGL_NV_render_texture_rectangle */ - -/* --------------------------- WGL_NV_swap_group --------------------------- */ - -#ifndef WGL_NV_swap_group -#define WGL_NV_swap_group 1 - -typedef BOOL (WINAPI * PFNWGLBINDSWAPBARRIERNVPROC) (GLuint group, GLuint barrier); -typedef BOOL (WINAPI * PFNWGLJOINSWAPGROUPNVPROC) (HDC hDC, GLuint group); -typedef BOOL (WINAPI * PFNWGLQUERYFRAMECOUNTNVPROC) (HDC hDC, GLuint* count); -typedef BOOL (WINAPI * PFNWGLQUERYMAXSWAPGROUPSNVPROC) (HDC hDC, GLuint* maxGroups, GLuint *maxBarriers); -typedef BOOL (WINAPI * PFNWGLQUERYSWAPGROUPNVPROC) (HDC hDC, GLuint* group, GLuint *barrier); -typedef BOOL (WINAPI * PFNWGLRESETFRAMECOUNTNVPROC) (HDC hDC); - -#define wglBindSwapBarrierNV WGLEW_GET_FUN(__wglewBindSwapBarrierNV) -#define wglJoinSwapGroupNV WGLEW_GET_FUN(__wglewJoinSwapGroupNV) -#define wglQueryFrameCountNV WGLEW_GET_FUN(__wglewQueryFrameCountNV) -#define wglQueryMaxSwapGroupsNV WGLEW_GET_FUN(__wglewQueryMaxSwapGroupsNV) -#define wglQuerySwapGroupNV WGLEW_GET_FUN(__wglewQuerySwapGroupNV) -#define wglResetFrameCountNV WGLEW_GET_FUN(__wglewResetFrameCountNV) - -#define WGLEW_NV_swap_group WGLEW_GET_VAR(__WGLEW_NV_swap_group) - -#endif /* WGL_NV_swap_group */ - -/* ----------------------- WGL_NV_vertex_array_range ----------------------- */ - -#ifndef WGL_NV_vertex_array_range -#define WGL_NV_vertex_array_range 1 - -typedef void * (WINAPI * PFNWGLALLOCATEMEMORYNVPROC) (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority); -typedef void (WINAPI * PFNWGLFREEMEMORYNVPROC) (void *pointer); - -#define wglAllocateMemoryNV WGLEW_GET_FUN(__wglewAllocateMemoryNV) -#define wglFreeMemoryNV WGLEW_GET_FUN(__wglewFreeMemoryNV) - -#define WGLEW_NV_vertex_array_range WGLEW_GET_VAR(__WGLEW_NV_vertex_array_range) - -#endif /* WGL_NV_vertex_array_range */ - -/* -------------------------- WGL_NV_video_capture ------------------------- */ - -#ifndef WGL_NV_video_capture -#define WGL_NV_video_capture 1 - -#define WGL_UNIQUE_ID_NV 0x20CE -#define WGL_NUM_VIDEO_CAPTURE_SLOTS_NV 0x20CF - -DECLARE_HANDLE(HVIDEOINPUTDEVICENV); - -typedef BOOL (WINAPI * PFNWGLBINDVIDEOCAPTUREDEVICENVPROC) (UINT uVideoSlot, HVIDEOINPUTDEVICENV hDevice); -typedef UINT (WINAPI * PFNWGLENUMERATEVIDEOCAPTUREDEVICESNVPROC) (HDC hDc, HVIDEOINPUTDEVICENV* phDeviceList); -typedef BOOL (WINAPI * PFNWGLLOCKVIDEOCAPTUREDEVICENVPROC) (HDC hDc, HVIDEOINPUTDEVICENV hDevice); -typedef BOOL (WINAPI * PFNWGLQUERYVIDEOCAPTUREDEVICENVPROC) (HDC hDc, HVIDEOINPUTDEVICENV hDevice, int iAttribute, int* piValue); -typedef BOOL (WINAPI * PFNWGLRELEASEVIDEOCAPTUREDEVICENVPROC) (HDC hDc, HVIDEOINPUTDEVICENV hDevice); - -#define wglBindVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewBindVideoCaptureDeviceNV) -#define wglEnumerateVideoCaptureDevicesNV WGLEW_GET_FUN(__wglewEnumerateVideoCaptureDevicesNV) -#define wglLockVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewLockVideoCaptureDeviceNV) -#define wglQueryVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewQueryVideoCaptureDeviceNV) -#define wglReleaseVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewReleaseVideoCaptureDeviceNV) - -#define WGLEW_NV_video_capture WGLEW_GET_VAR(__WGLEW_NV_video_capture) - -#endif /* WGL_NV_video_capture */ - -/* -------------------------- WGL_NV_video_output -------------------------- */ - -#ifndef WGL_NV_video_output -#define WGL_NV_video_output 1 - -#define WGL_BIND_TO_VIDEO_RGB_NV 0x20C0 -#define WGL_BIND_TO_VIDEO_RGBA_NV 0x20C1 -#define WGL_BIND_TO_VIDEO_RGB_AND_DEPTH_NV 0x20C2 -#define WGL_VIDEO_OUT_COLOR_NV 0x20C3 -#define WGL_VIDEO_OUT_ALPHA_NV 0x20C4 -#define WGL_VIDEO_OUT_DEPTH_NV 0x20C5 -#define WGL_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 -#define WGL_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 -#define WGL_VIDEO_OUT_FRAME 0x20C8 -#define WGL_VIDEO_OUT_FIELD_1 0x20C9 -#define WGL_VIDEO_OUT_FIELD_2 0x20CA -#define WGL_VIDEO_OUT_STACKED_FIELDS_1_2 0x20CB -#define WGL_VIDEO_OUT_STACKED_FIELDS_2_1 0x20CC - -DECLARE_HANDLE(HPVIDEODEV); - -typedef BOOL (WINAPI * PFNWGLBINDVIDEOIMAGENVPROC) (HPVIDEODEV hVideoDevice, HPBUFFERARB hPbuffer, int iVideoBuffer); -typedef BOOL (WINAPI * PFNWGLGETVIDEODEVICENVPROC) (HDC hDC, int numDevices, HPVIDEODEV* hVideoDevice); -typedef BOOL (WINAPI * PFNWGLGETVIDEOINFONVPROC) (HPVIDEODEV hpVideoDevice, unsigned long* pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo); -typedef BOOL (WINAPI * PFNWGLRELEASEVIDEODEVICENVPROC) (HPVIDEODEV hVideoDevice); -typedef BOOL (WINAPI * PFNWGLRELEASEVIDEOIMAGENVPROC) (HPBUFFERARB hPbuffer, int iVideoBuffer); -typedef BOOL (WINAPI * PFNWGLSENDPBUFFERTOVIDEONVPROC) (HPBUFFERARB hPbuffer, int iBufferType, unsigned long* pulCounterPbuffer, BOOL bBlock); - -#define wglBindVideoImageNV WGLEW_GET_FUN(__wglewBindVideoImageNV) -#define wglGetVideoDeviceNV WGLEW_GET_FUN(__wglewGetVideoDeviceNV) -#define wglGetVideoInfoNV WGLEW_GET_FUN(__wglewGetVideoInfoNV) -#define wglReleaseVideoDeviceNV WGLEW_GET_FUN(__wglewReleaseVideoDeviceNV) -#define wglReleaseVideoImageNV WGLEW_GET_FUN(__wglewReleaseVideoImageNV) -#define wglSendPbufferToVideoNV WGLEW_GET_FUN(__wglewSendPbufferToVideoNV) - -#define WGLEW_NV_video_output WGLEW_GET_VAR(__WGLEW_NV_video_output) - -#endif /* WGL_NV_video_output */ - -/* -------------------------- WGL_OML_sync_control ------------------------- */ - -#ifndef WGL_OML_sync_control -#define WGL_OML_sync_control 1 - -typedef BOOL (WINAPI * PFNWGLGETMSCRATEOMLPROC) (HDC hdc, INT32* numerator, INT32 *denominator); -typedef BOOL (WINAPI * PFNWGLGETSYNCVALUESOMLPROC) (HDC hdc, INT64* ust, INT64 *msc, INT64 *sbc); -typedef INT64 (WINAPI * PFNWGLSWAPBUFFERSMSCOMLPROC) (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder); -typedef INT64 (WINAPI * PFNWGLSWAPLAYERBUFFERSMSCOMLPROC) (HDC hdc, INT fuPlanes, INT64 target_msc, INT64 divisor, INT64 remainder); -typedef BOOL (WINAPI * PFNWGLWAITFORMSCOMLPROC) (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder, INT64* ust, INT64 *msc, INT64 *sbc); -typedef BOOL (WINAPI * PFNWGLWAITFORSBCOMLPROC) (HDC hdc, INT64 target_sbc, INT64* ust, INT64 *msc, INT64 *sbc); - -#define wglGetMscRateOML WGLEW_GET_FUN(__wglewGetMscRateOML) -#define wglGetSyncValuesOML WGLEW_GET_FUN(__wglewGetSyncValuesOML) -#define wglSwapBuffersMscOML WGLEW_GET_FUN(__wglewSwapBuffersMscOML) -#define wglSwapLayerBuffersMscOML WGLEW_GET_FUN(__wglewSwapLayerBuffersMscOML) -#define wglWaitForMscOML WGLEW_GET_FUN(__wglewWaitForMscOML) -#define wglWaitForSbcOML WGLEW_GET_FUN(__wglewWaitForSbcOML) - -#define WGLEW_OML_sync_control WGLEW_GET_VAR(__WGLEW_OML_sync_control) - -#endif /* WGL_OML_sync_control */ - -/* ------------------------------------------------------------------------- */ - -#ifdef GLEW_MX -#define WGLEW_EXPORT -#else -#define WGLEW_EXPORT GLEWAPI -#endif /* GLEW_MX */ - -#ifdef GLEW_MX -struct WGLEWContextStruct -{ -#endif /* GLEW_MX */ - -WGLEW_EXPORT PFNWGLSETSTEREOEMITTERSTATE3DLPROC __wglewSetStereoEmitterState3DL; - -WGLEW_EXPORT PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC __wglewBlitContextFramebufferAMD; -WGLEW_EXPORT PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC __wglewCreateAssociatedContextAMD; -WGLEW_EXPORT PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __wglewCreateAssociatedContextAttribsAMD; -WGLEW_EXPORT PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC __wglewDeleteAssociatedContextAMD; -WGLEW_EXPORT PFNWGLGETCONTEXTGPUIDAMDPROC __wglewGetContextGPUIDAMD; -WGLEW_EXPORT PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC __wglewGetCurrentAssociatedContextAMD; -WGLEW_EXPORT PFNWGLGETGPUIDSAMDPROC __wglewGetGPUIDsAMD; -WGLEW_EXPORT PFNWGLGETGPUINFOAMDPROC __wglewGetGPUInfoAMD; -WGLEW_EXPORT PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __wglewMakeAssociatedContextCurrentAMD; - -WGLEW_EXPORT PFNWGLCREATEBUFFERREGIONARBPROC __wglewCreateBufferRegionARB; -WGLEW_EXPORT PFNWGLDELETEBUFFERREGIONARBPROC __wglewDeleteBufferRegionARB; -WGLEW_EXPORT PFNWGLRESTOREBUFFERREGIONARBPROC __wglewRestoreBufferRegionARB; -WGLEW_EXPORT PFNWGLSAVEBUFFERREGIONARBPROC __wglewSaveBufferRegionARB; - -WGLEW_EXPORT PFNWGLCREATECONTEXTATTRIBSARBPROC __wglewCreateContextAttribsARB; - -WGLEW_EXPORT PFNWGLGETEXTENSIONSSTRINGARBPROC __wglewGetExtensionsStringARB; - -WGLEW_EXPORT PFNWGLGETCURRENTREADDCARBPROC __wglewGetCurrentReadDCARB; -WGLEW_EXPORT PFNWGLMAKECONTEXTCURRENTARBPROC __wglewMakeContextCurrentARB; - -WGLEW_EXPORT PFNWGLCREATEPBUFFERARBPROC __wglewCreatePbufferARB; -WGLEW_EXPORT PFNWGLDESTROYPBUFFERARBPROC __wglewDestroyPbufferARB; -WGLEW_EXPORT PFNWGLGETPBUFFERDCARBPROC __wglewGetPbufferDCARB; -WGLEW_EXPORT PFNWGLQUERYPBUFFERARBPROC __wglewQueryPbufferARB; -WGLEW_EXPORT PFNWGLRELEASEPBUFFERDCARBPROC __wglewReleasePbufferDCARB; - -WGLEW_EXPORT PFNWGLCHOOSEPIXELFORMATARBPROC __wglewChoosePixelFormatARB; -WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBFVARBPROC __wglewGetPixelFormatAttribfvARB; -WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBIVARBPROC __wglewGetPixelFormatAttribivARB; - -WGLEW_EXPORT PFNWGLBINDTEXIMAGEARBPROC __wglewBindTexImageARB; -WGLEW_EXPORT PFNWGLRELEASETEXIMAGEARBPROC __wglewReleaseTexImageARB; -WGLEW_EXPORT PFNWGLSETPBUFFERATTRIBARBPROC __wglewSetPbufferAttribARB; - -WGLEW_EXPORT PFNWGLBINDDISPLAYCOLORTABLEEXTPROC __wglewBindDisplayColorTableEXT; -WGLEW_EXPORT PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC __wglewCreateDisplayColorTableEXT; -WGLEW_EXPORT PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC __wglewDestroyDisplayColorTableEXT; -WGLEW_EXPORT PFNWGLLOADDISPLAYCOLORTABLEEXTPROC __wglewLoadDisplayColorTableEXT; - -WGLEW_EXPORT PFNWGLGETEXTENSIONSSTRINGEXTPROC __wglewGetExtensionsStringEXT; - -WGLEW_EXPORT PFNWGLGETCURRENTREADDCEXTPROC __wglewGetCurrentReadDCEXT; -WGLEW_EXPORT PFNWGLMAKECONTEXTCURRENTEXTPROC __wglewMakeContextCurrentEXT; - -WGLEW_EXPORT PFNWGLCREATEPBUFFEREXTPROC __wglewCreatePbufferEXT; -WGLEW_EXPORT PFNWGLDESTROYPBUFFEREXTPROC __wglewDestroyPbufferEXT; -WGLEW_EXPORT PFNWGLGETPBUFFERDCEXTPROC __wglewGetPbufferDCEXT; -WGLEW_EXPORT PFNWGLQUERYPBUFFEREXTPROC __wglewQueryPbufferEXT; -WGLEW_EXPORT PFNWGLRELEASEPBUFFERDCEXTPROC __wglewReleasePbufferDCEXT; - -WGLEW_EXPORT PFNWGLCHOOSEPIXELFORMATEXTPROC __wglewChoosePixelFormatEXT; -WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBFVEXTPROC __wglewGetPixelFormatAttribfvEXT; -WGLEW_EXPORT PFNWGLGETPIXELFORMATATTRIBIVEXTPROC __wglewGetPixelFormatAttribivEXT; - -WGLEW_EXPORT PFNWGLGETSWAPINTERVALEXTPROC __wglewGetSwapIntervalEXT; -WGLEW_EXPORT PFNWGLSWAPINTERVALEXTPROC __wglewSwapIntervalEXT; - -WGLEW_EXPORT PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC __wglewGetDigitalVideoParametersI3D; -WGLEW_EXPORT PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC __wglewSetDigitalVideoParametersI3D; - -WGLEW_EXPORT PFNWGLGETGAMMATABLEI3DPROC __wglewGetGammaTableI3D; -WGLEW_EXPORT PFNWGLGETGAMMATABLEPARAMETERSI3DPROC __wglewGetGammaTableParametersI3D; -WGLEW_EXPORT PFNWGLSETGAMMATABLEI3DPROC __wglewSetGammaTableI3D; -WGLEW_EXPORT PFNWGLSETGAMMATABLEPARAMETERSI3DPROC __wglewSetGammaTableParametersI3D; - -WGLEW_EXPORT PFNWGLDISABLEGENLOCKI3DPROC __wglewDisableGenlockI3D; -WGLEW_EXPORT PFNWGLENABLEGENLOCKI3DPROC __wglewEnableGenlockI3D; -WGLEW_EXPORT PFNWGLGENLOCKSAMPLERATEI3DPROC __wglewGenlockSampleRateI3D; -WGLEW_EXPORT PFNWGLGENLOCKSOURCEDELAYI3DPROC __wglewGenlockSourceDelayI3D; -WGLEW_EXPORT PFNWGLGENLOCKSOURCEEDGEI3DPROC __wglewGenlockSourceEdgeI3D; -WGLEW_EXPORT PFNWGLGENLOCKSOURCEI3DPROC __wglewGenlockSourceI3D; -WGLEW_EXPORT PFNWGLGETGENLOCKSAMPLERATEI3DPROC __wglewGetGenlockSampleRateI3D; -WGLEW_EXPORT PFNWGLGETGENLOCKSOURCEDELAYI3DPROC __wglewGetGenlockSourceDelayI3D; -WGLEW_EXPORT PFNWGLGETGENLOCKSOURCEEDGEI3DPROC __wglewGetGenlockSourceEdgeI3D; -WGLEW_EXPORT PFNWGLGETGENLOCKSOURCEI3DPROC __wglewGetGenlockSourceI3D; -WGLEW_EXPORT PFNWGLISENABLEDGENLOCKI3DPROC __wglewIsEnabledGenlockI3D; -WGLEW_EXPORT PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC __wglewQueryGenlockMaxSourceDelayI3D; - -WGLEW_EXPORT PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC __wglewAssociateImageBufferEventsI3D; -WGLEW_EXPORT PFNWGLCREATEIMAGEBUFFERI3DPROC __wglewCreateImageBufferI3D; -WGLEW_EXPORT PFNWGLDESTROYIMAGEBUFFERI3DPROC __wglewDestroyImageBufferI3D; -WGLEW_EXPORT PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC __wglewReleaseImageBufferEventsI3D; - -WGLEW_EXPORT PFNWGLDISABLEFRAMELOCKI3DPROC __wglewDisableFrameLockI3D; -WGLEW_EXPORT PFNWGLENABLEFRAMELOCKI3DPROC __wglewEnableFrameLockI3D; -WGLEW_EXPORT PFNWGLISENABLEDFRAMELOCKI3DPROC __wglewIsEnabledFrameLockI3D; -WGLEW_EXPORT PFNWGLQUERYFRAMELOCKMASTERI3DPROC __wglewQueryFrameLockMasterI3D; - -WGLEW_EXPORT PFNWGLBEGINFRAMETRACKINGI3DPROC __wglewBeginFrameTrackingI3D; -WGLEW_EXPORT PFNWGLENDFRAMETRACKINGI3DPROC __wglewEndFrameTrackingI3D; -WGLEW_EXPORT PFNWGLGETFRAMEUSAGEI3DPROC __wglewGetFrameUsageI3D; -WGLEW_EXPORT PFNWGLQUERYFRAMETRACKINGI3DPROC __wglewQueryFrameTrackingI3D; - -WGLEW_EXPORT PFNWGLDXCLOSEDEVICENVPROC __wglewDXCloseDeviceNV; -WGLEW_EXPORT PFNWGLDXLOCKOBJECTSNVPROC __wglewDXLockObjectsNV; -WGLEW_EXPORT PFNWGLDXOBJECTACCESSNVPROC __wglewDXObjectAccessNV; -WGLEW_EXPORT PFNWGLDXOPENDEVICENVPROC __wglewDXOpenDeviceNV; -WGLEW_EXPORT PFNWGLDXREGISTEROBJECTNVPROC __wglewDXRegisterObjectNV; -WGLEW_EXPORT PFNWGLDXSETRESOURCESHAREHANDLENVPROC __wglewDXSetResourceShareHandleNV; -WGLEW_EXPORT PFNWGLDXUNLOCKOBJECTSNVPROC __wglewDXUnlockObjectsNV; -WGLEW_EXPORT PFNWGLDXUNREGISTEROBJECTNVPROC __wglewDXUnregisterObjectNV; - -WGLEW_EXPORT PFNWGLCOPYIMAGESUBDATANVPROC __wglewCopyImageSubDataNV; - -WGLEW_EXPORT PFNWGLCREATEAFFINITYDCNVPROC __wglewCreateAffinityDCNV; -WGLEW_EXPORT PFNWGLDELETEDCNVPROC __wglewDeleteDCNV; -WGLEW_EXPORT PFNWGLENUMGPUDEVICESNVPROC __wglewEnumGpuDevicesNV; -WGLEW_EXPORT PFNWGLENUMGPUSFROMAFFINITYDCNVPROC __wglewEnumGpusFromAffinityDCNV; -WGLEW_EXPORT PFNWGLENUMGPUSNVPROC __wglewEnumGpusNV; - -WGLEW_EXPORT PFNWGLBINDVIDEODEVICENVPROC __wglewBindVideoDeviceNV; -WGLEW_EXPORT PFNWGLENUMERATEVIDEODEVICESNVPROC __wglewEnumerateVideoDevicesNV; -WGLEW_EXPORT PFNWGLQUERYCURRENTCONTEXTNVPROC __wglewQueryCurrentContextNV; - -WGLEW_EXPORT PFNWGLBINDSWAPBARRIERNVPROC __wglewBindSwapBarrierNV; -WGLEW_EXPORT PFNWGLJOINSWAPGROUPNVPROC __wglewJoinSwapGroupNV; -WGLEW_EXPORT PFNWGLQUERYFRAMECOUNTNVPROC __wglewQueryFrameCountNV; -WGLEW_EXPORT PFNWGLQUERYMAXSWAPGROUPSNVPROC __wglewQueryMaxSwapGroupsNV; -WGLEW_EXPORT PFNWGLQUERYSWAPGROUPNVPROC __wglewQuerySwapGroupNV; -WGLEW_EXPORT PFNWGLRESETFRAMECOUNTNVPROC __wglewResetFrameCountNV; - -WGLEW_EXPORT PFNWGLALLOCATEMEMORYNVPROC __wglewAllocateMemoryNV; -WGLEW_EXPORT PFNWGLFREEMEMORYNVPROC __wglewFreeMemoryNV; - -WGLEW_EXPORT PFNWGLBINDVIDEOCAPTUREDEVICENVPROC __wglewBindVideoCaptureDeviceNV; -WGLEW_EXPORT PFNWGLENUMERATEVIDEOCAPTUREDEVICESNVPROC __wglewEnumerateVideoCaptureDevicesNV; -WGLEW_EXPORT PFNWGLLOCKVIDEOCAPTUREDEVICENVPROC __wglewLockVideoCaptureDeviceNV; -WGLEW_EXPORT PFNWGLQUERYVIDEOCAPTUREDEVICENVPROC __wglewQueryVideoCaptureDeviceNV; -WGLEW_EXPORT PFNWGLRELEASEVIDEOCAPTUREDEVICENVPROC __wglewReleaseVideoCaptureDeviceNV; - -WGLEW_EXPORT PFNWGLBINDVIDEOIMAGENVPROC __wglewBindVideoImageNV; -WGLEW_EXPORT PFNWGLGETVIDEODEVICENVPROC __wglewGetVideoDeviceNV; -WGLEW_EXPORT PFNWGLGETVIDEOINFONVPROC __wglewGetVideoInfoNV; -WGLEW_EXPORT PFNWGLRELEASEVIDEODEVICENVPROC __wglewReleaseVideoDeviceNV; -WGLEW_EXPORT PFNWGLRELEASEVIDEOIMAGENVPROC __wglewReleaseVideoImageNV; -WGLEW_EXPORT PFNWGLSENDPBUFFERTOVIDEONVPROC __wglewSendPbufferToVideoNV; - -WGLEW_EXPORT PFNWGLGETMSCRATEOMLPROC __wglewGetMscRateOML; -WGLEW_EXPORT PFNWGLGETSYNCVALUESOMLPROC __wglewGetSyncValuesOML; -WGLEW_EXPORT PFNWGLSWAPBUFFERSMSCOMLPROC __wglewSwapBuffersMscOML; -WGLEW_EXPORT PFNWGLSWAPLAYERBUFFERSMSCOMLPROC __wglewSwapLayerBuffersMscOML; -WGLEW_EXPORT PFNWGLWAITFORMSCOMLPROC __wglewWaitForMscOML; -WGLEW_EXPORT PFNWGLWAITFORSBCOMLPROC __wglewWaitForSbcOML; -WGLEW_EXPORT GLboolean __WGLEW_3DFX_multisample; -WGLEW_EXPORT GLboolean __WGLEW_3DL_stereo_control; -WGLEW_EXPORT GLboolean __WGLEW_AMD_gpu_association; -WGLEW_EXPORT GLboolean __WGLEW_ARB_buffer_region; -WGLEW_EXPORT GLboolean __WGLEW_ARB_create_context; -WGLEW_EXPORT GLboolean __WGLEW_ARB_create_context_profile; -WGLEW_EXPORT GLboolean __WGLEW_ARB_create_context_robustness; -WGLEW_EXPORT GLboolean __WGLEW_ARB_extensions_string; -WGLEW_EXPORT GLboolean __WGLEW_ARB_framebuffer_sRGB; -WGLEW_EXPORT GLboolean __WGLEW_ARB_make_current_read; -WGLEW_EXPORT GLboolean __WGLEW_ARB_multisample; -WGLEW_EXPORT GLboolean __WGLEW_ARB_pbuffer; -WGLEW_EXPORT GLboolean __WGLEW_ARB_pixel_format; -WGLEW_EXPORT GLboolean __WGLEW_ARB_pixel_format_float; -WGLEW_EXPORT GLboolean __WGLEW_ARB_render_texture; -WGLEW_EXPORT GLboolean __WGLEW_ATI_pixel_format_float; -WGLEW_EXPORT GLboolean __WGLEW_ATI_render_texture_rectangle; -WGLEW_EXPORT GLboolean __WGLEW_EXT_create_context_es2_profile; -WGLEW_EXPORT GLboolean __WGLEW_EXT_depth_float; -WGLEW_EXPORT GLboolean __WGLEW_EXT_display_color_table; -WGLEW_EXPORT GLboolean __WGLEW_EXT_extensions_string; -WGLEW_EXPORT GLboolean __WGLEW_EXT_framebuffer_sRGB; -WGLEW_EXPORT GLboolean __WGLEW_EXT_make_current_read; -WGLEW_EXPORT GLboolean __WGLEW_EXT_multisample; -WGLEW_EXPORT GLboolean __WGLEW_EXT_pbuffer; -WGLEW_EXPORT GLboolean __WGLEW_EXT_pixel_format; -WGLEW_EXPORT GLboolean __WGLEW_EXT_pixel_format_packed_float; -WGLEW_EXPORT GLboolean __WGLEW_EXT_swap_control; -WGLEW_EXPORT GLboolean __WGLEW_I3D_digital_video_control; -WGLEW_EXPORT GLboolean __WGLEW_I3D_gamma; -WGLEW_EXPORT GLboolean __WGLEW_I3D_genlock; -WGLEW_EXPORT GLboolean __WGLEW_I3D_image_buffer; -WGLEW_EXPORT GLboolean __WGLEW_I3D_swap_frame_lock; -WGLEW_EXPORT GLboolean __WGLEW_I3D_swap_frame_usage; -WGLEW_EXPORT GLboolean __WGLEW_NV_DX_interop; -WGLEW_EXPORT GLboolean __WGLEW_NV_copy_image; -WGLEW_EXPORT GLboolean __WGLEW_NV_float_buffer; -WGLEW_EXPORT GLboolean __WGLEW_NV_gpu_affinity; -WGLEW_EXPORT GLboolean __WGLEW_NV_multisample_coverage; -WGLEW_EXPORT GLboolean __WGLEW_NV_present_video; -WGLEW_EXPORT GLboolean __WGLEW_NV_render_depth_texture; -WGLEW_EXPORT GLboolean __WGLEW_NV_render_texture_rectangle; -WGLEW_EXPORT GLboolean __WGLEW_NV_swap_group; -WGLEW_EXPORT GLboolean __WGLEW_NV_vertex_array_range; -WGLEW_EXPORT GLboolean __WGLEW_NV_video_capture; -WGLEW_EXPORT GLboolean __WGLEW_NV_video_output; -WGLEW_EXPORT GLboolean __WGLEW_OML_sync_control; - -#ifdef GLEW_MX -}; /* WGLEWContextStruct */ -#endif /* GLEW_MX */ - -/* ------------------------------------------------------------------------- */ - -#ifdef GLEW_MX - -typedef struct WGLEWContextStruct WGLEWContext; -GLEWAPI GLenum wglewContextInit (WGLEWContext* ctx); -GLEWAPI GLboolean wglewContextIsSupported (const WGLEWContext* ctx, const char* name); - -#define wglewInit() wglewContextInit(wglewGetContext()) -#define wglewIsSupported(x) wglewContextIsSupported(wglewGetContext(), x) - -#define WGLEW_GET_VAR(x) (*(const GLboolean*)&(wglewGetContext()->x)) -#define WGLEW_GET_FUN(x) wglewGetContext()->x - -#else /* GLEW_MX */ - -#define WGLEW_GET_VAR(x) (*(const GLboolean*)&x) -#define WGLEW_GET_FUN(x) x - -GLEWAPI GLboolean wglewIsSupported (const char* name); - -#endif /* GLEW_MX */ - -GLEWAPI GLboolean wglewGetExtension (const char* name); - -#ifdef __cplusplus -} -#endif - -#undef GLEWAPI - -#endif /* __wglew_h__ */ diff --git a/Demos/Glut/GL/wglext.h b/Demos/Glut/GL/wglext.h deleted file mode 100644 index 8c6192c27..000000000 --- a/Demos/Glut/GL/wglext.h +++ /dev/null @@ -1,466 +0,0 @@ -#ifndef __wglext_h_ -#define __wglext_h_ - -#ifdef __cplusplus -extern "C" { -#endif - -/* -** License Applicability. Except to the extent portions of this file are -** made subject to an alternative license as permitted in the SGI Free -** Software License B, Version 1.1 (the "License"), the contents of this -** file are subject only to the provisions of the License. You may not use -** this file except in compliance with the License. You may obtain a copy -** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600 -** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at: -** -** http://oss.sgi.com/projects/FreeB -** -** Note that, as provided in the License, the Software is distributed on an -** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS -** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND -** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A -** PARTICULAR PURPOSE, AND NON-INFRINGEMENT. -** -** Original Code. The Original Code is: OpenGL Sample Implementation, -** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics, -** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc. -** Copyright in any portions created by third parties is as indicated -** elsewhere herein. All Rights Reserved. -** -** Additional Notice Provisions: This software was created using the -** OpenGL(R) version 1.2.1 Sample Implementation published by SGI, but has -** not been independently verified as being compliant with the OpenGL(R) -** version 1.2.1 Specification. -*/ - -#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) -#define WIN32_LEAN_AND_MEAN 1 -#include -#endif - -#ifndef APIENTRY -#define APIENTRY -#endif - -/*************************************************************/ - -/* Header file version number */ -#define WGL_WGLEXT_VERSION 1 - -#ifndef WGL_ARB_buffer_region -#define WGL_FRONT_COLOR_BUFFER_BIT_ARB 0x00000001 -#define WGL_BACK_COLOR_BUFFER_BIT_ARB 0x00000002 -#define WGL_DEPTH_BUFFER_BIT_ARB 0x00000004 -#define WGL_STENCIL_BUFFER_BIT_ARB 0x00000008 -#endif - -#ifndef WGL_ARB_extensions_string -#endif - -#ifndef WGL_ARB_pixel_format -#define WGL_NUMBER_PIXEL_FORMATS_ARB 0x2000 -#define WGL_DRAW_TO_WINDOW_ARB 0x2001 -#define WGL_DRAW_TO_BITMAP_ARB 0x2002 -#define WGL_ACCELERATION_ARB 0x2003 -#define WGL_NEED_PALETTE_ARB 0x2004 -#define WGL_NEED_SYSTEM_PALETTE_ARB 0x2005 -#define WGL_SWAP_LAYER_BUFFERS_ARB 0x2006 -#define WGL_SWAP_METHOD_ARB 0x2007 -#define WGL_NUMBER_OVERLAYS_ARB 0x2008 -#define WGL_NUMBER_UNDERLAYS_ARB 0x2009 -#define WGL_TRANSPARENT_ARB 0x200A -#define WGL_TRANSPARENT_RED_VALUE_ARB 0x2037 -#define WGL_TRANSPARENT_GREEN_VALUE_ARB 0x2038 -#define WGL_TRANSPARENT_BLUE_VALUE_ARB 0x2039 -#define WGL_TRANSPARENT_ALPHA_VALUE_ARB 0x203A -#define WGL_TRANSPARENT_INDEX_VALUE_ARB 0x203B -#define WGL_SHARE_DEPTH_ARB 0x200C -#define WGL_SHARE_STENCIL_ARB 0x200D -#define WGL_SHARE_ACCUM_ARB 0x200E -#define WGL_SUPPORT_GDI_ARB 0x200F -#define WGL_SUPPORT_OPENGL_ARB 0x2010 -#define WGL_DOUBLE_BUFFER_ARB 0x2011 -#define WGL_STEREO_ARB 0x2012 -#define WGL_PIXEL_TYPE_ARB 0x2013 -#define WGL_COLOR_BITS_ARB 0x2014 -#define WGL_RED_BITS_ARB 0x2015 -#define WGL_RED_SHIFT_ARB 0x2016 -#define WGL_GREEN_BITS_ARB 0x2017 -#define WGL_GREEN_SHIFT_ARB 0x2018 -#define WGL_BLUE_BITS_ARB 0x2019 -#define WGL_BLUE_SHIFT_ARB 0x201A -#define WGL_ALPHA_BITS_ARB 0x201B -#define WGL_ALPHA_SHIFT_ARB 0x201C -#define WGL_ACCUM_BITS_ARB 0x201D -#define WGL_ACCUM_RED_BITS_ARB 0x201E -#define WGL_ACCUM_GREEN_BITS_ARB 0x201F -#define WGL_ACCUM_BLUE_BITS_ARB 0x2020 -#define WGL_ACCUM_ALPHA_BITS_ARB 0x2021 -#define WGL_DEPTH_BITS_ARB 0x2022 -#define WGL_STENCIL_BITS_ARB 0x2023 -#define WGL_AUX_BUFFERS_ARB 0x2024 -#define WGL_NO_ACCELERATION_ARB 0x2025 -#define WGL_GENERIC_ACCELERATION_ARB 0x2026 -#define WGL_FULL_ACCELERATION_ARB 0x2027 -#define WGL_SWAP_EXCHANGE_ARB 0x2028 -#define WGL_SWAP_COPY_ARB 0x2029 -#define WGL_SWAP_UNDEFINED_ARB 0x202A -#define WGL_TYPE_RGBA_ARB 0x202B -#define WGL_TYPE_COLORINDEX_ARB 0x202C -#endif - -#ifndef WGL_ARB_make_current_read -#define ERROR_INVALID_PIXEL_TYPE_ARB 0x2043 -#define ERROR_INCOMPATIBLE_DEVICE_CONTEXTS_ARB 0x2054 -#endif - -#ifndef WGL_ARB_pbuffer -#define WGL_DRAW_TO_PBUFFER_ARB 0x202D -#define WGL_MAX_PBUFFER_PIXELS_ARB 0x202E -#define WGL_MAX_PBUFFER_WIDTH_ARB 0x202F -#define WGL_MAX_PBUFFER_HEIGHT_ARB 0x2030 -#define WGL_PBUFFER_LARGEST_ARB 0x2033 -#define WGL_PBUFFER_WIDTH_ARB 0x2034 -#define WGL_PBUFFER_HEIGHT_ARB 0x2035 -#define WGL_PBUFFER_LOST_ARB 0x2036 -#endif - -#ifndef WGL_ARB_render_texture -#define WGL_BIND_TO_TEXTURE_RGB_ARB 0x2070 -#define WGL_BIND_TO_TEXTURE_RGBA_ARB 0x2071 -#define WGL_TEXTURE_FORMAT_ARB 0x2072 -#define WGL_TEXTURE_TARGET_ARB 0x2073 -#define WGL_MIPMAP_TEXTURE_ARB 0x2074 -#define WGL_TEXTURE_RGB_ARB 0x2075 -#define WGL_TEXTURE_RGBA_ARB 0x2076 -#define WGL_NO_TEXTURE_ARB 0x2077 -#define WGL_TEXTURE_CUBE_MAP_ARB 0x2078 -#define WGL_TEXTURE_1D_ARB 0x2079 -#define WGL_TEXTURE_2D_ARB 0x207A -#define WGL_MIPMAP_LEVEL_ARB 0x207B -#define WGL_CUBE_MAP_FACE_ARB 0x207C -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x207D -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x207E -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x207F -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x2080 -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x2081 -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x2082 -#define WGL_FRONT_LEFT_ARB 0x2083 -#define WGL_FRONT_RIGHT_ARB 0x2084 -#define WGL_BACK_LEFT_ARB 0x2085 -#define WGL_BACK_RIGHT_ARB 0x2086 -#define WGL_AUX0_ARB 0x2087 -#define WGL_AUX1_ARB 0x2088 -#define WGL_AUX2_ARB 0x2089 -#define WGL_AUX3_ARB 0x208A -#define WGL_AUX4_ARB 0x208B -#define WGL_AUX5_ARB 0x208C -#define WGL_AUX6_ARB 0x208D -#define WGL_AUX7_ARB 0x208E -#define WGL_AUX8_ARB 0x208F -#define WGL_AUX9_ARB 0x2090 -#endif - -#ifndef WGL_EXT_make_current_read -#define ERROR_INVALID_PIXEL_TYPE_EXT 0x2043 -#endif - -#ifndef WGL_EXT_pixel_format -#define WGL_NUMBER_PIXEL_FORMATS_EXT 0x2000 -#define WGL_DRAW_TO_WINDOW_EXT 0x2001 -#define WGL_DRAW_TO_BITMAP_EXT 0x2002 -#define WGL_ACCELERATION_EXT 0x2003 -#define WGL_NEED_PALETTE_EXT 0x2004 -#define WGL_NEED_SYSTEM_PALETTE_EXT 0x2005 -#define WGL_SWAP_LAYER_BUFFERS_EXT 0x2006 -#define WGL_SWAP_METHOD_EXT 0x2007 -#define WGL_NUMBER_OVERLAYS_EXT 0x2008 -#define WGL_NUMBER_UNDERLAYS_EXT 0x2009 -#define WGL_TRANSPARENT_EXT 0x200A -#define WGL_TRANSPARENT_VALUE_EXT 0x200B -#define WGL_SHARE_DEPTH_EXT 0x200C -#define WGL_SHARE_STENCIL_EXT 0x200D -#define WGL_SHARE_ACCUM_EXT 0x200E -#define WGL_SUPPORT_GDI_EXT 0x200F -#define WGL_SUPPORT_OPENGL_EXT 0x2010 -#define WGL_DOUBLE_BUFFER_EXT 0x2011 -#define WGL_STEREO_EXT 0x2012 -#define WGL_PIXEL_TYPE_EXT 0x2013 -#define WGL_COLOR_BITS_EXT 0x2014 -#define WGL_RED_BITS_EXT 0x2015 -#define WGL_RED_SHIFT_EXT 0x2016 -#define WGL_GREEN_BITS_EXT 0x2017 -#define WGL_GREEN_SHIFT_EXT 0x2018 -#define WGL_BLUE_BITS_EXT 0x2019 -#define WGL_BLUE_SHIFT_EXT 0x201A -#define WGL_ALPHA_BITS_EXT 0x201B -#define WGL_ALPHA_SHIFT_EXT 0x201C -#define WGL_ACCUM_BITS_EXT 0x201D -#define WGL_ACCUM_RED_BITS_EXT 0x201E -#define WGL_ACCUM_GREEN_BITS_EXT 0x201F -#define WGL_ACCUM_BLUE_BITS_EXT 0x2020 -#define WGL_ACCUM_ALPHA_BITS_EXT 0x2021 -#define WGL_DEPTH_BITS_EXT 0x2022 -#define WGL_STENCIL_BITS_EXT 0x2023 -#define WGL_AUX_BUFFERS_EXT 0x2024 -#define WGL_NO_ACCELERATION_EXT 0x2025 -#define WGL_GENERIC_ACCELERATION_EXT 0x2026 -#define WGL_FULL_ACCELERATION_EXT 0x2027 -#define WGL_SWAP_EXCHANGE_EXT 0x2028 -#define WGL_SWAP_COPY_EXT 0x2029 -#define WGL_SWAP_UNDEFINED_EXT 0x202A -#define WGL_TYPE_RGBA_EXT 0x202B -#define WGL_TYPE_COLORINDEX_EXT 0x202C -#endif - -#ifndef WGL_EXT_pbuffer -#define WGL_DRAW_TO_PBUFFER_EXT 0x202D -#define WGL_MAX_PBUFFER_PIXELS_EXT 0x202E -#define WGL_MAX_PBUFFER_WIDTH_EXT 0x202F -#define WGL_MAX_PBUFFER_HEIGHT_EXT 0x2030 -#define WGL_OPTIMAL_PBUFFER_WIDTH_EXT 0x2031 -#define WGL_OPTIMAL_PBUFFER_HEIGHT_EXT 0x2032 -#define WGL_PBUFFER_LARGEST_EXT 0x2033 -#define WGL_PBUFFER_WIDTH_EXT 0x2034 -#define WGL_PBUFFER_HEIGHT_EXT 0x2035 -#endif - -#ifndef WGL_EXT_depth_float -#define WGL_DEPTH_FLOAT_EXT 0x2040 -#endif - -#ifndef WGL_NV_render_texture_rectangle -#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGB_NV 0x20A0 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGBA_NV 0x20A1 -#define WGL_TEXTURE_RECTANGLE_NV 0x20A2 -#endif - -#ifndef WGL_NV_render_depth_texture -#define WGL_TEXTURE_DEPTH_COMPONENT_NV 0x20A6 -#define WGL_DEPTH_TEXTURE_FORMAT_NV 0x20A5 -#define WGL_BIND_TO_TEXTURE_DEPTH_NV 0x20A3 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_DEPTH_NV 0x20A4 -#define WGL_DEPTH_COMPONENT_NV 0x20A7 -#endif - -#ifndef WGL_3DFX_multisample -#define WGL_SAMPLE_BUFFERS_3DFX 0x2060 -#define WGL_SAMPLES_3DFX 0x2061 -#endif - -#ifndef WGL_EXT_multisample -#define WGL_SAMPLE_BUFFERS_EXT 0x2041 -#define WGL_SAMPLES_EXT 0x2042 -#endif - -#ifndef WGL_I3D_unknown_genlock_extension_name -#define WGL_GENLOCK_SOURCE_MULTIVIEW_I3D 0x2044 -#define WGL_GENLOCK_SOURCE_EXTENAL_SYNC_I3D 0x2045 -#define WGL_GENLOCK_SOURCE_EXTENAL_FIELD_I3D 0x2046 -#define WGL_GENLOCK_SOURCE_EXTENAL_TTL_I3D 0x2047 -#define WGL_GENLOCK_SOURCE_DIGITAL_SYNC_I3D 0x2048 -#define WGL_GENLOCK_SOURCE_DIGITAL_FIELD_I3D 0x2049 -#define WGL_GENLOCK_SOURCE_EDGE_FALLING_I3D 0x204A -#define WGL_GENLOCK_SOURCE_EDGE_RISING_I3D 0x204B -#define WGL_GENLOCK_SOURCE_EDGE_BOTH_I3D 0x204C -#endif - -#ifndef WGL_I3D_unknown_gamma_extension_name -#define WGL_GAMMA_TABLE_SIZE_I3D 0x204E -#define WGL_GAMMA_EXCLUDE_DESKTOP_I3D 0x204F -#endif - -#ifndef WGL_I3D_unknown_digital_video_cursor_extension_name -#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_FRAMEBUFFER_I3D 0x2050 -#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_VALUE_I3D 0x2051 -#define WGL_DIGITAL_VIDEO_CURSOR_INCLUDED_I3D 0x2052 -#define WGL_DIGITAL_VIDEO_GAMMA_CORRECTED_I3D 0x2053 -#endif - - -/*************************************************************/ - -#ifndef WGL_ARB_pbuffer -DECLARE_HANDLE(HPBUFFERARB); -#endif -#ifndef WGL_EXT_pbuffer -DECLARE_HANDLE(HPBUFFEREXT); -#endif - -#ifndef WGL_ARB_buffer_region -#define WGL_ARB_buffer_region 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern HANDLE WINAPI wglCreateBufferRegionARB (HDC, int, UINT); -extern VOID WINAPI wglDeleteBufferRegionARB (HANDLE); -extern BOOL WINAPI wglSaveBufferRegionARB (HANDLE, int, int, int, int); -extern BOOL WINAPI wglRestoreBufferRegionARB (HANDLE, int, int, int, int, int, int); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef HANDLE (WINAPI * PFNWGLCREATEBUFFERREGIONARBPROC) (HDC hDC, int iLayerPlane, UINT uType); -typedef VOID (WINAPI * PFNWGLDELETEBUFFERREGIONARBPROC) (HANDLE hRegion); -typedef BOOL (WINAPI * PFNWGLSAVEBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height); -typedef BOOL (WINAPI * PFNWGLRESTOREBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height, int xSrc, int ySrc); -#endif - -#ifndef WGL_ARB_extensions_string -#define WGL_ARB_extensions_string 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern const char * WINAPI wglGetExtensionsStringARB (HDC); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef const char * (WINAPI * PFNWGLGETEXTENSIONSSTRINGARBPROC) (HDC hdc); -#endif - -#ifndef WGL_ARB_pixel_format -#define WGL_ARB_pixel_format 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern BOOL WINAPI wglGetPixelFormatAttribivARB (HDC, int, int, UINT, const int *, int *); -extern BOOL WINAPI wglGetPixelFormatAttribfvARB (HDC, int, int, UINT, const int *, FLOAT *); -extern BOOL WINAPI wglChoosePixelFormatARB (HDC, const int *, const FLOAT *, UINT, int *, UINT *); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int *piAttributes, int *piValues); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int *piAttributes, FLOAT *pfValues); -typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATARBPROC) (HDC hdc, const int *piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); -#endif - -#ifndef WGL_ARB_make_current_read -#define WGL_ARB_make_current_read 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern BOOL WINAPI wglMakeContextCurrentARB (HDC, HDC, HGLRC); -extern HDC WINAPI wglGetCurrentReadDCARB (void); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTARBPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); -typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCARBPROC) (void); -#endif - -#ifndef WGL_ARB_pbuffer -#define WGL_ARB_pbuffer 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern HPBUFFERARB WINAPI wglCreatePbufferARB (HDC, int, int, int, const int *); -extern HDC WINAPI wglGetPbufferDCARB (HPBUFFERARB); -extern int WINAPI wglReleasePbufferDCARB (HPBUFFERARB, HDC); -extern BOOL WINAPI wglDestroyPbufferARB (HPBUFFERARB); -extern BOOL WINAPI wglQueryPbufferARB (HPBUFFERARB, int, int *); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef HPBUFFERARB (WINAPI * PFNWGLCREATEPBUFFERARBPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int *piAttribList); -typedef HDC (WINAPI * PFNWGLGETPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer); -typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer, HDC hDC); -typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFERARBPROC) (HPBUFFERARB hPbuffer); -typedef BOOL (WINAPI * PFNWGLQUERYPBUFFERARBPROC) (HPBUFFERARB hPbuffer, int iAttribute, int *piValue); -#endif - -#ifndef WGL_EXT_display_color_table -#define WGL_EXT_display_color_table 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern GLboolean WINAPI wglCreateDisplayColorTableEXT (GLushort); -extern GLboolean WINAPI wglLoadDisplayColorTableEXT (const GLushort *, GLuint); -extern GLboolean WINAPI wglBindDisplayColorTableEXT (GLushort); -extern VOID WINAPI wglDestroyDisplayColorTableEXT (GLushort); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef GLboolean (WINAPI * PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef GLboolean (WINAPI * PFNWGLLOADDISPLAYCOLORTABLEEXTPROC) (const GLushort *table, GLuint length); -typedef GLboolean (WINAPI * PFNWGLBINDDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef VOID (WINAPI * PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC) (GLushort id); -#endif - -#ifndef WGL_EXT_extensions_string -#define WGL_EXT_extensions_string 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern const char * WINAPI wglGetExtensionsStringEXT (void); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef const char * (WINAPI * PFNWGLGETEXTENSIONSSTRINGEXTPROC) (void); -#endif - -#ifndef WGL_EXT_make_current_read -#define WGL_EXT_make_current_read 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern BOOL WINAPI wglMakeContextCurrentEXT (HDC, HDC, HGLRC); -extern HDC WINAPI wglGetCurrentReadDCEXT (void); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTEXTPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); -typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCEXTPROC) (void); -#endif - -#ifndef WGL_EXT_pbuffer -#define WGL_EXT_pbuffer 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern HPBUFFEREXT WINAPI wglCreatePbufferEXT (HDC, int, int, int, const int *); -extern HDC WINAPI wglGetPbufferDCEXT (HPBUFFEREXT); -extern int WINAPI wglReleasePbufferDCEXT (HPBUFFEREXT, HDC); -extern BOOL WINAPI wglDestroyPbufferEXT (HPBUFFEREXT); -extern BOOL WINAPI wglQueryPbufferEXT (HPBUFFEREXT, int, int *); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef HPBUFFEREXT (WINAPI * PFNWGLCREATEPBUFFEREXTPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int *piAttribList); -typedef HDC (WINAPI * PFNWGLGETPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer); -typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer, HDC hDC); -typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer); -typedef BOOL (WINAPI * PFNWGLQUERYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer, int iAttribute, int *piValue); -#endif - -#ifndef WGL_EXT_pixel_format -#define WGL_EXT_pixel_format 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern BOOL WINAPI wglGetPixelFormatAttribivEXT (HDC, int, int, UINT, int *, int *); -extern BOOL WINAPI wglGetPixelFormatAttribfvEXT (HDC, int, int, UINT, int *, FLOAT *); -extern BOOL WINAPI wglChoosePixelFormatEXT (HDC, const int *, const FLOAT *, UINT, int *, UINT *); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int *piAttributes, int *piValues); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int *piAttributes, FLOAT *pfValues); -typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATEXTPROC) (HDC hdc, const int *piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); -#endif - -#ifndef WGL_EXT_swap_control -#define WGL_EXT_swap_control 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern BOOL WINAPI wglSwapIntervalEXT (int); -extern int WINAPI wglGetSwapIntervalEXT (void); -#endif /* WGL_WGLEXT_PROTOTYPES */ -typedef BOOL (WINAPI * PFNWGLSWAPINTERVALEXTPROC) (int interval); -typedef int (WINAPI * PFNWGLGETSWAPINTERVALEXTPROC) (void); -#endif - -#ifndef WGL_WGL_EXT_depth_float -#define WGL_WGL_EXT_depth_float 1 -#endif - -#ifndef WGL_WGL_3DFX_multisample -#define WGL_WGL_3DFX_multisample 1 -#endif - -#ifndef WGL_WGL_EXT_multisample -#define WGL_WGL_EXT_multisample 1 -#endif - -/* added by Cass -- but this should already be in here! */ -#ifndef WGL_NV_allocate_memory -#define WGL_NV_allocate_memory 1 -#ifdef WGL_WGLEXT_PROTOTYPES -extern void * wglAllocateMemoryNV(int size, float readfreq, float writefreq, float priority); -extern void wglFreeMemoryNV(void * pointer); -#endif -typedef void * (APIENTRY * PFNWGLALLOCATEMEMORYNVPROC) (int size, float readfreq, float writefreq, float priority); -typedef void (APIENTRY * PFNWGLFREEMEMORYNVPROC) (void *pointer); -#endif - -/* WGL_ARB_render_texture */ -#ifndef WGL_ARB_render_texture -#define WGL_ARB_render_texture 1 -typedef BOOL (WINAPI * PFNWGLBINDTEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); -typedef BOOL (WINAPI * PFNWGLRELEASETEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); -typedef BOOL (WINAPI * PFNWGLSETPBUFFERATTRIBARBPROC) (HPBUFFERARB hPbuffer, const int * piAttribList); -#endif - -#ifndef WGL_NV_render_texture_rectangle -#define WGL_NV_render_texture_rectangle 1 -#endif - -#ifndef WGL_NV_render_depth_texture -#define WGL_NV_render_depth_texture 1 -#endif - -#ifdef __cplusplus -} -#endif - -#endif - - diff --git a/Demos/Glut/btGlutInclude.h b/Demos/Glut/btGlutInclude.h deleted file mode 100644 index d79cb5656..000000000 --- a/Demos/Glut/btGlutInclude.h +++ /dev/null @@ -1,43 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2011 Advanced Micro Devices, Inc. http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef BT_GLUT_INCLUDE_H -#define BT_GLUT_INCLUDE_H - - -#ifdef _WIN32//for glut.h -#include -#endif - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#include -#include -#else - - -#ifdef _WINDOWS -#include -#include -#include -#else -#include -#include -#endif //_WINDOWS -#endif //APPLE - -#endif //BT_GLUT_INCLUDE_H diff --git a/Demos/Glut/glew32s.lib b/Demos/Glut/glew32s.lib deleted file mode 100644 index eb2d718e0..000000000 Binary files a/Demos/Glut/glew32s.lib and /dev/null differ diff --git a/Demos/Glut/glew64s.lib b/Demos/Glut/glew64s.lib deleted file mode 100644 index e9b15a682..000000000 Binary files a/Demos/Glut/glew64s.lib and /dev/null differ diff --git a/Demos/Glut/glut32.lib b/Demos/Glut/glut32.lib deleted file mode 100644 index 4f0a17685..000000000 Binary files a/Demos/Glut/glut32.lib and /dev/null differ diff --git a/Demos/Glut/glut64.lib b/Demos/Glut/glut64.lib deleted file mode 100644 index c9bd577b2..000000000 Binary files a/Demos/Glut/glut64.lib and /dev/null differ diff --git a/Demos/GyroscopicDemo/CMakeLists.txt b/Demos/GyroscopicDemo/CMakeLists.txt deleted file mode 100644 index f47d62f37..000000000 --- a/Demos/GyroscopicDemo/CMakeLists.txt +++ /dev/null @@ -1,51 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppGyroscopicDemo - GyroscopicDemo.cpp - GyroscopicDemo.h - main.cpp - ) -ELSE (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppGyroscopicDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32GyroscopicDemo.cpp - GyroscopicDemo.cpp - GyroscopicDemo.h - ) -ENDIF (USE_GLUT) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppGyroscopicDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppGyroscopicDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppGyroscopicDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/GyroscopicDemo/GyroscopicDemo.cpp b/Demos/GyroscopicDemo/GyroscopicDemo.cpp deleted file mode 100644 index cc1a926c5..000000000 --- a/Demos/GyroscopicDemo/GyroscopicDemo.cpp +++ /dev/null @@ -1,240 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" - -#include "GLDebugFont.h" -#include //printf debugging - -#include "GyroscopicDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - - -#include "GLDebugDrawer.h" -static GLDebugDrawer gDebugDrawer; - - - - - -void GyroscopicDemo::setupEmptyDynamicsWorld() -{ - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - m_overlappingPairCache = new btDbvtBroadphase(); - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration); -} - -void GyroscopicDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} -void GyroscopicDemo::initPhysics() -{ - m_azi=90; - m_ele = 20; - - setTexturing(true); - setShadows(true); - setCameraUp(btVector3(0,0,1)); - setCameraForwardAxis(1); - m_sundirection.setValue(0,-1000,-1000); - setCameraDistance(7.f); - - setupEmptyDynamicsWorld(); - m_dynamicsWorld->setGravity(btVector3(0,0,-9.8)); - m_dynamicsWorld->setDebugDrawer(&gDebugDrawer); - - - //btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(0.5))); - btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,0,1),0); - - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,0,0)); - btRigidBody* groundBody; - groundBody= localCreateRigidBody(0, groundTransform, groundShape); - groundBody->setFriction(btSqrt(2)); - btVector3 positions[2] = { - btVector3(0.8,-2,2), - btVector3(0.8,2,2) - }; - bool gyro[2] = { - true, - false - }; - - for (int i=0;i<2;i++) - { - btCylinderShapeZ* top = new btCylinderShapeZ(btVector3(1,1,0.125)); - btCapsuleShapeZ* pin = new btCapsuleShapeZ(0.05,1.5); - top->setMargin(0.01); - pin->setMargin(0.01); - btCompoundShape* compound = new btCompoundShape(); - compound->addChildShape(btTransform::getIdentity(),top); - compound->addChildShape(btTransform::getIdentity(),pin); - btVector3 localInertia; - top->calculateLocalInertia(1,localInertia); - btRigidBody* body = new btRigidBody(1,0,compound,localInertia); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(positions[i]); - body->setCenterOfMassTransform(tr); - body->setAngularVelocity(btVector3(0,0,15)); - body->setLinearVelocity(btVector3(0,.2,0)); - body->setFriction(btSqrt(1)); - m_dynamicsWorld->addRigidBody(body); - if (gyro[i]) - { - body->setFlags(BT_ENABLE_GYROSCOPIC_FORCE_IMPLICIT_BODY); - } else - { - body->setFlags(0); - } - body->setDamping(0.00001f,0.0001f); - - - } - -} - -void GyroscopicDemo::exitPhysics() -{ - - int i; - - //removed/delete constraints - for (i=m_dynamicsWorld->getNumConstraints()-1; i>=0 ;i--) - { - btTypedConstraint* constraint = m_dynamicsWorld->getConstraint(i); - m_dynamicsWorld->removeConstraint(constraint); - delete constraint; - } - - //remove the rigidbodies from the dynamics world and delete them - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - - - - //delete collision shapes - for (int j=0;jgetDebugDrawer() && once) - { - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits); - once=false; - } - } - - - { - //during idle mode, just run 1 simulation step maximum - - int numSimSteps = m_dynamicsWorld->stepSimulation(dt,100,1./1000.f); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - - } - renderme(); - - - glFlush(); - swapBuffers(); -} - - - - -void GyroscopicDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - - renderme(); - - glFlush(); - swapBuffers(); -} - - diff --git a/Demos/GyroscopicDemo/GyroscopicDemo.h b/Demos/GyroscopicDemo/GyroscopicDemo.h deleted file mode 100644 index ad482dfdc..000000000 --- a/Demos/GyroscopicDemo/GyroscopicDemo.h +++ /dev/null @@ -1,71 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef BT_GYROSCOPIC_DEMO_H -#define BT_GYROSCOPIC_DEMO_H - -#ifdef _WINDOWS -#include "Win32DemoApplication.h" -#define PlatformDemoApplication Win32DemoApplication -#else -#include "GlutDemoApplication.h" -#define PlatformDemoApplication GlutDemoApplication -#endif - -///GyroscopicDemo shows how to create a constraint, like Hinge or btGenericD6constraint -class GyroscopicDemo : public PlatformDemoApplication -{ - //keep track of variables to delete memory at the end - btAlignedObjectArray m_collisionShapes; - - class btBroadphaseInterface* m_overlappingPairCache; - - class btCollisionDispatcher* m_dispatcher; - - class btConstraintSolver* m_constraintSolver; - - class btDefaultCollisionConfiguration* m_collisionConfiguration; - - void setupEmptyDynamicsWorld(); - - void clientResetScene(); - - - public: - - GyroscopicDemo(); - - virtual ~GyroscopicDemo(); - - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - GyroscopicDemo* demo = new GyroscopicDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //BT_GYROSCOPIC_DEMO_H - diff --git a/Demos/GyroscopicDemo/GyroscopicSetup.cpp b/Demos/GyroscopicDemo/GyroscopicSetup.cpp deleted file mode 100644 index 3b3b497dd..000000000 --- a/Demos/GyroscopicDemo/GyroscopicSetup.cpp +++ /dev/null @@ -1,95 +0,0 @@ -#include "GyroscopicSetup.h" - -static int gyroflags[4] = { - 0,//none, no gyroscopic term - BT_ENABLE_GYROSCOPIC_FORCE_EXPLICIT, - BT_ENABLE_GYROSCOPIC_FORCE_IMPLICIT_WORLD, - BT_ENABLE_GYROSCOPIC_FORCE_IMPLICIT_BODY -}; - -static const char* gyroNames[4] = { - "No Coriolis", - "Explicit", - "Implicit (World)", - "Implicit (Body)" -}; - - -void GyroscopicSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - gfxBridge.setUpAxis(2); - createEmptyDynamicsWorld(); - m_dynamicsWorld->setGravity(btVector3(0, 0, 0)); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - - - btVector3 positions[4] = { - btVector3( -10, 8,4), - btVector3( -5, 8,4), - btVector3( 0, 8,4), - btVector3( 5, 8,4), - }; - - - for (int i = 0; i<4; i++) - { - btCylinderShapeZ* pin = new btCylinderShapeZ(btVector3(0.1,0.1, 0.2)); - btBoxShape* box = new btBoxShape(btVector3(1,0.1,0.1)); - box->setMargin(0.01); - pin->setMargin(0.01); - btCompoundShape* compound = new btCompoundShape(); - compound->addChildShape(btTransform::getIdentity(), pin); - btTransform offsetBox(btMatrix3x3::getIdentity(),btVector3(0,0,0.2)); - compound->addChildShape(offsetBox, box); - btScalar masses[2] = {0.3,0.1}; - btVector3 localInertia; - btTransform principal; - compound->calculatePrincipalAxisTransform(masses,principal,localInertia); - - btRigidBody* body = new btRigidBody(1, 0, compound, localInertia); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(positions[i]); - body->setCenterOfMassTransform(tr); - body->setAngularVelocity(btVector3(0, 0.1, 10));//51)); - //body->setLinearVelocity(btVector3(3, 0, 0)); - body->setFriction(btSqrt(1)); - m_dynamicsWorld->addRigidBody(body); - body->setFlags(gyroflags[i]); - m_dynamicsWorld->getSolverInfo().m_maxGyroscopicForce = 10.f; - body->setDamping(0.0000f, 0.000f); - - - } - - { - //btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(0.5))); - btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0, 0, 1), 0); - - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0, 0, 0)); - btRigidBody* groundBody; - groundBody = createRigidBody(0, groundTransform, groundShape); - groundBody->setFriction(btSqrt(2)); - } - gfxBridge.autogenerateGraphicsObjects(m_dynamicsWorld); -} - -void GyroscopicSetup::syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge) -{ - CommonRigidBodySetup::syncPhysicsToGraphics(gfxBridge); - //render method names above objects - for (int i=0;igetNumCollisionObjects();i++) - { - btRigidBody* body = btRigidBody::upcast(m_dynamicsWorld->getCollisionObjectArray()[i]); - if (body && body->getInvMass()>0) - { - btTransform tr = body->getWorldTransform(); - btVector3 pos = tr.getOrigin()+btVector3(0,0,2); - btScalar size=1; - gfxBridge.drawText3D(gyroNames[i],pos.x(),pos.y(),pos.z(),size); - } - } -} diff --git a/Demos/GyroscopicDemo/GyroscopicSetup.h b/Demos/GyroscopicDemo/GyroscopicSetup.h deleted file mode 100644 index 0a7f8a197..000000000 --- a/Demos/GyroscopicDemo/GyroscopicSetup.h +++ /dev/null @@ -1,16 +0,0 @@ - -#ifndef GYROSCOPIC_SETUP_H -#define GYROSCOPIC_SETUP_H - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -struct GyroscopicSetup : public CommonRigidBodySetup -{ - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge); - -}; - - -#endif //GYROSCOPIC_SETUP_H diff --git a/Demos/GyroscopicDemo/Win32GyroscopicDemo.cpp b/Demos/GyroscopicDemo/Win32GyroscopicDemo.cpp deleted file mode 100644 index 0a82e8c54..000000000 --- a/Demos/GyroscopicDemo/Win32GyroscopicDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "GyroscopicDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new GyroscopicDemo(); -} - -#endif diff --git a/Demos/GyroscopicDemo/main.cpp b/Demos/GyroscopicDemo/main.cpp deleted file mode 100644 index aa2e373f0..000000000 --- a/Demos/GyroscopicDemo/main.cpp +++ /dev/null @@ -1,20 +0,0 @@ -#include "GyroscopicDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" - -#include "btBulletDynamicsCommon.h" - -int main(int argc,char** argv) -{ - - - - GyroscopicDemo* constraintDemo = new GyroscopicDemo(); - - - constraintDemo->initPhysics(); - constraintDemo->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits); - - return glutmain(argc, argv,640,480,"Constraint Demo. http://www.continuousphysics.com/Bullet/phpBB2/",constraintDemo); -} - diff --git a/Demos/HelloWorld/CMakeLists.txt b/Demos/HelloWorld/CMakeLists.txt deleted file mode 100644 index 3c15ad1d7..000000000 --- a/Demos/HelloWorld/CMakeLists.txt +++ /dev/null @@ -1,29 +0,0 @@ -# HelloWorld is a minimal sample creating, stepping and deleting a Bullet dynamics world - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -) - -LINK_LIBRARIES( - BulletDynamics BulletCollision LinearMath -) - -IF (WIN32) - ADD_EXECUTABLE(AppHelloWorld - HelloWorld.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppHelloWorld - HelloWorld.cpp - ) -ENDIF() - - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppHelloWorld PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppHelloWorld PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppHelloWorld PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/HelloWorld/HelloWorld.cpp b/Demos/HelloWorld/HelloWorld.cpp deleted file mode 100644 index f1934b269..000000000 --- a/Demos/HelloWorld/HelloWorld.cpp +++ /dev/null @@ -1,180 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///-----includes_start----- -#include "btBulletDynamicsCommon.h" -#include - -/// This is a Hello World program for running a basic Bullet physics simulation - -int main(int argc, char** argv) -{ - ///-----includes_end----- - - int i; - ///-----initialization_start----- - - ///collision configuration contains default setup for memory, collision setup. Advanced users can create their own configuration. - btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collisionConfiguration); - - ///btDbvtBroadphase is a good general purpose broadphase. You can also try out btAxis3Sweep. - btBroadphaseInterface* overlappingPairCache = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* solver = new btSequentialImpulseConstraintSolver; - - btDiscreteDynamicsWorld* dynamicsWorld = new btDiscreteDynamicsWorld(dispatcher,overlappingPairCache,solver,collisionConfiguration); - - dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///-----initialization_end----- - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); - - //keep track of the shapes, we release memory at exit. - //make sure to re-use collision shapes among rigid bodies whenever possible! - btAlignedObjectArray collisionShapes; - - collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-56,0)); - - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - dynamicsWorld->addRigidBody(body); - } - - - { - //create a dynamic rigidbody - - //btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1)); - btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - startTransform.setOrigin(btVector3(2,10,0)); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,colShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - dynamicsWorld->addRigidBody(body); - } - - - -/// Do some simulation - - - ///-----stepsimulation_start----- - for (i=0;i<100;i++) - { - dynamicsWorld->stepSimulation(1.f/60.f,10); - - //print positions of all objects - for (int j=dynamicsWorld->getNumCollisionObjects()-1; j>=0 ;j--) - { - btCollisionObject* obj = dynamicsWorld->getCollisionObjectArray()[j]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - btTransform trans; - body->getMotionState()->getWorldTransform(trans); - printf("world pos = %f,%f,%f\n",float(trans.getOrigin().getX()),float(trans.getOrigin().getY()),float(trans.getOrigin().getZ())); - } - } - } - - ///-----stepsimulation_end----- - - //cleanup in the reverse order of creation/initialization - - ///-----cleanup_start----- - - //remove the rigidbodies from the dynamics world and delete them - for (i=dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;jm_collisionFlags |= btCollisionObject::customMaterialCallback; -inline btScalar calculateCombinedFriction(float friction0,float friction1) -{ - return 0.f; - btScalar friction = friction0 * friction1; - - const btScalar MAX_FRICTION = 10.f; - if (friction < -MAX_FRICTION) - friction = -MAX_FRICTION; - if (friction > MAX_FRICTION) - friction = MAX_FRICTION; - return friction; - -} - -inline btScalar calculateCombinedRestitution(float restitution0,float restitution1) -{ - return restitution0 * restitution1; -} - - -/////////////////////////////////////////////////////////////// - - -static bool CustomMaterialCombinerCallback(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) -{ - - if (enable) - { - btAdjustInternalEdgeContacts(cp,colObj1Wrap,colObj0Wrap, partId1,index1); - //btAdjustInternalEdgeContacts(cp,colObj1,colObj0, partId1,index1, BT_TRIANGLE_CONVEX_BACKFACE_MODE); - //btAdjustInternalEdgeContacts(cp,colObj1,colObj0, partId1,index1, BT_TRIANGLE_CONVEX_DOUBLE_SIDED+BT_TRIANGLE_CONCAVE_DOUBLE_SIDED); - } - - float friction0 = colObj0Wrap->getCollisionObject()->getFriction(); - float friction1 = colObj1Wrap->getCollisionObject()->getFriction(); - float restitution0 = colObj0Wrap->getCollisionObject()->getRestitution(); - float restitution1 = colObj1Wrap->getCollisionObject()->getRestitution(); - - if (colObj0Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK) - { - friction0 = 1.0;//partId0,index0 - restitution0 = 0.f; - } - if (colObj1Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK) - { - if (index1&1) - { - friction1 = 1.0f;//partId1,index1 - } else - { - friction1 = 0.f; - } - restitution1 = 0.f; - } - - cp.m_combinedFriction = calculateCombinedFriction(friction0,friction1); - cp.m_combinedRestitution = calculateCombinedRestitution(restitution0,restitution1); - - //this return value is currently ignored, but to be on the safe side: return false if you don't calculate friction - return true; -} - -extern ContactAddedCallback gContactAddedCallback; - - const int NUM_VERTS_X = 2; - const int NUM_VERTS_Y = 2; - const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - -void InternalEdgeDemo::setVertexPositions(float waveheight, float offset) -{ - int i; - int j; - - for ( i=0;isetCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->setActivationState(DISABLE_DEACTIVATION); - } else - { - staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->forceActivationState(ACTIVE_TAG); - } - } - - DemoApplication::keyboardCallback(key,x,y); - -} - - - -void InternalEdgeDemo::initPhysics() -{ - - setTexturing(true); - setShadows(false);//true); - - #define TRISIZE 10.f - - gContactAddedCallback = CustomMaterialCombinerCallback; - -#define USE_TRIMESH_SHAPE 1 -#ifdef USE_TRIMESH_SHAPE - - int vertStride = sizeof(btVector3); - int indexStride = 3*sizeof(int); - - - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - - gVertices = new btVector3[totalVerts]; - gIndices = new int[totalTriangles*3]; - - int i; - - - setVertexPositions(waveheight,0.f); - - - //gVertices[1].setY(21.1); - //gVertices[1].setY(121.1); - gVertices[1].setY(.1f); - -#ifdef ROTATE_GROUND - //gVertices[1].setY(-1.1); -#else - //gVertices[1].setY(0.1); - //gVertices[1].setY(-0.1); - //gVertices[1].setY(-20.1); - //gVertices[1].setY(-20); -#endif - - int index=0; - for ( i=0;igetOptimizedBvh()->calculateSerializeBufferSize(); - buffer = btAlignedAlloc(numBytes,16); - bool swapEndian = false; - trimeshShape->getOptimizedBvh()->serialize(buffer,numBytes,swapEndian); - FILE* file = fopen("bvh.bin","wb"); - fwrite(buffer,1,numBytes,file); - fclose(file); - btAlignedFree(buffer); - - - -#else - - trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression,false); - - char* fileName = "bvh.bin"; - - FILE* file = fopen(fileName,"rb"); - int size=0; - btOptimizedBvh* bvh = 0; - - if (fseek(file, 0, SEEK_END) || (size = ftell(file)) == EOF || fseek(file, 0, SEEK_SET)) { /* File operations denied? ok, just close and return failure */ - printf("Error: cannot get filesize from %s\n", fileName); - exit(0); - } else - { - - fseek(file, 0, SEEK_SET); - - int buffersize = size+btOptimizedBvh::getAlignmentSerializationPadding(); - - void* buffer = btAlignedAlloc(buffersize,16); - int read = fread(buffer,1,size,file); - fclose(file); - bool swapEndian = false; - bvh = btOptimizedBvh::deSerializeInPlace(buffer,buffersize,swapEndian); - } - - trimeshShape->setOptimizedBvh(bvh); - -#endif - - btCollisionShape* groundShape = trimeshShape; - - btTriangleInfoMap* triangleInfoMap = new btTriangleInfoMap(); - - - btGenerateInternalEdgeInfo(trimeshShape,triangleInfoMap); - - - -#else - btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50)); - - m_collisionShapes.push_back(groundShape); - -#endif //USE_TRIMESH_SHAPE - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - - - m_broadphase = new btDbvtBroadphase(); - m_solver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); -/* -m_dynamicsWorld->getSolverInfo().m_splitImpulse = true; - m_dynamicsWorld->getSolverInfo().m_splitImpulsePenetrationThreshold = 1e30f; - m_dynamicsWorld->getSolverInfo().m_maxErrorReduction = 1e30f; - m_dynamicsWorld->getSolverInfo().m_erp =1.f; - m_dynamicsWorld->getSolverInfo().m_erp2 = 1.f; -*/ - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,-2,0)); - - - btConvexHullShape* colShape = new btConvexHullShape(); - for (int i=0;iaddPoint(vtx); - } - //this will enable polyhedral contact clipping, better quality, slightly slower - colShape->initializePolyhedralFeatures(); - - //the polyhedral contact clipping can use either GJK or SAT test to find the separating axis - m_dynamicsWorld->getDispatchInfo().m_enableSatConvex=false; - - m_collisionShapes.push_back(colShape); - - { - for (int i=0;i<1;i++) - { - startTransform.setOrigin(btVector3(-10.f+i*3.f,2.2f+btScalar(i)*0.1f,-1.3f)); - btRigidBody* body = localCreateRigidBody(10, startTransform,colShape); - body->setActivationState(DISABLE_DEACTIVATION); - body->setLinearVelocity(btVector3(0,0,-1)); - //body->setContactProcessingThreshold(0.f); - } - } - { - btBoxShape* colShape = new btBoxShape(btVector3(1,1,1)); - colShape->initializePolyhedralFeatures(); - m_collisionShapes.push_back(colShape); - startTransform.setOrigin(btVector3(-16.f+i*3.f,1.f+btScalar(i)*0.1f,-1.3f)); - btRigidBody* body = localCreateRigidBody(10, startTransform,colShape); - body->setActivationState(DISABLE_DEACTIVATION); - body->setLinearVelocity(btVector3(0,0,-1)); - } - - startTransform.setIdentity(); -#ifdef ROTATE_GROUND - btQuaternion orn(btVector3(0,0,1),SIMD_PI); - startTransform.setOrigin(btVector3(-20,0,0)); - startTransform.setRotation(orn); -#endif //ROTATE_GROUND - - staticBody = localCreateRigidBody(mass, startTransform,groundShape); - //staticBody->setContactProcessingThreshold(-0.031f); - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);//STATIC_OBJECT); - - //enable custom material callback - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - setDebugMode(btIDebugDraw::DBG_DrawText|btIDebugDraw::DBG_NoHelpText+btIDebugDraw::DBG_DrawWireframe+btIDebugDraw::DBG_DrawContactPoints); - - -#ifdef BT_INTERNAL_EDGE_DEBUG_DRAW - btSetDebugDrawer(&gDebugDrawer); -#endif //BT_INTERNAL_EDGE_DEBUG_DRAW - - -} - - -void InternalEdgeDemo::clientResetScene() -{ - DemoApplication::clientResetScene(); - for (int i=0;igetNumCollisionObjects();i++) - { - btCollisionObject* colobj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(colobj); - if (body && body->getInvMass() != 0.f) - { - - body->setLinearVelocity(btVector3(0,0,-1)); - } - - } -} - -void InternalEdgeDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_animatedMesh) - { - static float offset=0.f; - offset+=0.01f; - - // setVertexPositions(waveheight,offset); -#if 0 ///not currently supported, we need to update the btInternalTriangleInfoMap - int i; - int j; - btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT); - btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT); - - for ( i=NUM_VERTS_X/2-3;ipartialRefitTree(aabbMin,aabbMax); -#else - btVector3 aabbMin,aabbMax; - trimeshShape->getMeshInterface()->calculateAabbBruteForce(aabbMin,aabbMax); - trimeshShape->refitTree(aabbMin,aabbMax); - -#endif - - - //for debugging: clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation. - //m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - } - - - - m_dynamicsWorld->stepSimulation(dt); - ///enable one of the following to debug (render debug lines each frame) - //m_dynamicsWorld->stepSimulation(1./800.,0); - //m_dynamicsWorld->stepSimulation(1./60.,100,1./800.); - //m_dynamicsWorld->stepSimulation(1./60.,0); - - - int lineWidth=450; - int xStart = m_glutScreenWidth - lineWidth; - int yStart = 20; - - if((getDebugMode() & btIDebugDraw::DBG_DrawText)!=0) - { - setOrthographicProjection(); - glDisable(GL_LIGHTING); - glColor3f(0, 0, 0); - char buf[124]; - - glRasterPos3f(xStart, yStart, 0); - if (enable) - { - sprintf(buf,"InternalEdgeUtility enabled"); - } else - { - sprintf(buf,"InternalEdgeUtility disabled"); - } - GLDebugDrawString(xStart,20,buf); - yStart+=20; - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"Press 'n' to toggle InternalEdgeUtility"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - glRasterPos3f(xStart, yStart, 0); - - resetPerspectiveProjection(); - glEnable(GL_LIGHTING); - } - - - renderme(); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - - glFlush(); - swapBuffers(); - -} - - - - -void InternalEdgeDemo::displayCallback(void) { - - clientMoveAndDisplay(); - /* - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - - glFlush(); - glutSwapBuffers(); - */ - -} - - - -void InternalEdgeDemo::exitPhysics() -{ - - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btTriangleIndexVertexArray* m_indexVertexArrays; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - bool m_animatedMesh; - - public: - - InternalEdgeDemo() : m_animatedMesh(true) - { - - } - void initPhysics(); - - void exitPhysics(); - - virtual ~InternalEdgeDemo() - { - exitPhysics(); - } - - virtual void clientResetScene(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - //to show refit works - void setVertexPositions(float waveheight, float offset); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - InternalEdgeDemo* demo = new InternalEdgeDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - }; -}; - -#endif //CONCAVE_DEMO_H - diff --git a/Demos/InternalEdgeDemo/Taru.mdl b/Demos/InternalEdgeDemo/Taru.mdl deleted file mode 100644 index 73f708c82..000000000 --- a/Demos/InternalEdgeDemo/Taru.mdl +++ /dev/null @@ -1,49 +0,0 @@ -#define TaruVtxCount 43 -#define TaruIdxCount 132 - -static float TaruVtx[] = { -1.08664f,-1.99237f,0.0f, -0.768369f,-1.99237f,-0.768369f, -1.28852f,1.34412e-007f,-1.28852f, -1.82224f,1.90735e-007f,0.0f, -0.0f,-1.99237f,-1.08664f, -0.0f,0.0f,-1.82224f, -0.0f,-1.99237f,-1.08664f, --0.768369f,-1.99237f,-0.768369f, --1.28852f,1.34412e-007f,-1.28852f, -0.0f,0.0f,-1.82224f, --1.08664f,-1.99237f,1.82086e-007f, --1.82224f,1.90735e-007f,1.59305e-007f, --0.768369f,-1.99237f,0.76837f, --1.28852f,2.47058e-007f,1.28852f, -1.42495e-007f,-1.99237f,1.08664f, -2.38958e-007f,2.70388e-007f,1.82224f, -0.768369f,-1.99237f,0.768369f, -1.28852f,2.47058e-007f,1.28852f, -0.768369f,1.99237f,-0.768369f, -1.08664f,1.99237f,0.0f, -0.0f,1.99237f,-1.08664f, --0.768369f,1.99237f,-0.768369f, -0.0f,1.99237f,-1.08664f, --1.08664f,1.99237f,0.0f, --0.768369f,1.99237f,0.768369f, -1.42495e-007f,1.99237f,1.08664f, -0.768369f,1.99237f,0.768369f, -1.42495e-007f,-1.99237f,1.08664f, --0.768369f,-1.99237f,0.76837f, --1.08664f,-1.99237f,1.82086e-007f, --0.768369f,-1.99237f,-0.768369f, -0.0f,-1.99237f,-1.08664f, -0.768369f,-1.99237f,-0.768369f, -1.08664f,-1.99237f,0.0f, -0.768369f,-1.99237f,0.768369f, -0.768369f,1.99237f,-0.768369f, -0.0f,1.99237f,-1.08664f, --0.768369f,1.99237f,-0.768369f, --1.08664f,1.99237f,0.0f, --0.768369f,1.99237f,0.768369f, -1.42495e-007f,1.99237f,1.08664f, -0.768369f,1.99237f,0.768369f, -1.08664f,1.99237f,0.0f, -}; - diff --git a/Demos/InternalEdgeDemo/Win32InternalEdgeDemo.cpp b/Demos/InternalEdgeDemo/Win32InternalEdgeDemo.cpp deleted file mode 100644 index f55071383..000000000 --- a/Demos/InternalEdgeDemo/Win32InternalEdgeDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "InternalEdgeDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new InternalEdgeDemo(); -} - -#endif diff --git a/Demos/InternalEdgeDemo/main.cpp b/Demos/InternalEdgeDemo/main.cpp deleted file mode 100644 index 596ecb385..000000000 --- a/Demos/InternalEdgeDemo/main.cpp +++ /dev/null @@ -1,19 +0,0 @@ - -#include "InternalEdgeDemo.h" -#include "GlutStuff.h" - -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - - -int main(int argc,char** argv) -{ - - InternalEdgeDemo* internalEdgeDemo = new InternalEdgeDemo(); - internalEdgeDemo->initPhysics(); - internalEdgeDemo->setCameraDistance(30.f); - - - return glutmain(argc, argv,640,480,"Internal Edge Demo",internalEdgeDemo); -} - diff --git a/Demos/MovingConcaveDemo/CMakeLists.txt b/Demos/MovingConcaveDemo/CMakeLists.txt deleted file mode 100644 index e4a173022..000000000 --- a/Demos/MovingConcaveDemo/CMakeLists.txt +++ /dev/null @@ -1,36 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - - - -ADD_EXECUTABLE(AppMovingConcaveDemo -ConcavePhysicsDemo.cpp -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppMovingConcaveDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppMovingConcaveDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppMovingConcaveDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/MovingConcaveDemo/ConcaveDemo.h b/Demos/MovingConcaveDemo/ConcaveDemo.h deleted file mode 100644 index 0a7e31bcb..000000000 --- a/Demos/MovingConcaveDemo/ConcaveDemo.h +++ /dev/null @@ -1,48 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef CONCAVE_DEMO_H -#define CONCAVE_DEMO_H - -#include "GlutDemoApplication.h" - -struct btCollisionAlgorithmCreateFunc; - -///ConcaveDemo shows usage of static concave triangle meshes -///It also shows per-triangle material (friction/restitution) through CustomMaterialCombinerCallback -class ConcaveDemo : public GlutDemoApplication -{ - - btCollisionShape * m_trimeshShape; - - public: - - void initGImpactCollision(); - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void renderme(); - virtual void keyboardCallback(unsigned char key, int x, int y); - - ///Demo functions - void shootTrimesh(const btVector3& startPosition,const btVector3& destination); - - -}; - -#endif //CONCAVE_DEMO_H - diff --git a/Demos/MovingConcaveDemo/ConcavePhysicsDemo.cpp b/Demos/MovingConcaveDemo/ConcavePhysicsDemo.cpp deleted file mode 100644 index b04c61885..000000000 --- a/Demos/MovingConcaveDemo/ConcavePhysicsDemo.cpp +++ /dev/null @@ -1,1926 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "ConcaveDemo.h" - - -#include "LinearMath/btDefaultMotionState.h" -#include "LinearMath/btIDebugDraw.h" -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btDefaultMotionState.h" -#include "BulletCollision/Gimpact/btGImpactShape.h" -#include "BulletCollision/Gimpact/btGImpactCollisionAlgorithm.h" -#include "GLDebugFont.h" - - - -#include "GLDebugDrawer.h" - -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - - -GLDebugDrawer debugDrawer1; - -//***************************THE FAMOUS BUNNY TRIMESH********************************************// - -#define REAL btScalar -const int NUM_TRIANGLES =902; -const int NUM_VERTICES = 453; -const int NUM_INDICES = NUM_TRIANGLES * 3; - - -REAL gVertices[NUM_VERTICES * 3] = { - REAL(-0.334392), REAL(0.133007), REAL(0.062259), - REAL(-0.350189), REAL(0.150354), REAL(-0.147769), - REAL(-0.234201), REAL(0.343811), REAL(-0.174307), - REAL(-0.200259), REAL(0.285207), REAL(0.093749), - REAL(0.003520), REAL(0.475208), REAL(-0.159365), - REAL(0.001856), REAL(0.419203), REAL(0.098582), - REAL(-0.252802), REAL(0.093666), REAL(0.237538), - REAL(-0.162901), REAL(0.237984), REAL(0.206905), - REAL(0.000865), REAL(0.318141), REAL(0.235370), - REAL(-0.414624), REAL(0.164083), REAL(-0.278254), - REAL(-0.262213), REAL(0.357334), REAL(-0.293246), - REAL(0.004628), REAL(0.482694), REAL(-0.338626), - REAL(-0.402162), REAL(0.133528), REAL(-0.443247), - REAL(-0.243781), REAL(0.324275), REAL(-0.436763), - REAL(0.005293), REAL(0.437592), REAL(-0.458332), - REAL(-0.339884), REAL(-0.041150), REAL(-0.668211), - REAL(-0.248382), REAL(0.255825), REAL(-0.627493), - REAL(0.006261), REAL(0.376103), REAL(-0.631506), - REAL(-0.216201), REAL(-0.126776), REAL(-0.886936), - REAL(-0.171075), REAL(0.011544), REAL(-0.881386), - REAL(-0.181074), REAL(0.098223), REAL(-0.814779), - REAL(-0.119891), REAL(0.218786), REAL(-0.760153), - REAL(-0.078895), REAL(0.276780), REAL(-0.739281), - REAL(0.006801), REAL(0.310959), REAL(-0.735661), - REAL(-0.168842), REAL(0.102387), REAL(-0.920381), - REAL(-0.104072), REAL(0.177278), REAL(-0.952530), - REAL(-0.129704), REAL(0.211848), REAL(-0.836678), - REAL(-0.099875), REAL(0.310931), REAL(-0.799381), - REAL(0.007237), REAL(0.361687), REAL(-0.794439), - REAL(-0.077913), REAL(0.258753), REAL(-0.921640), - REAL(0.007957), REAL(0.282241), REAL(-0.931680), - REAL(-0.252222), REAL(-0.550401), REAL(-0.557810), - REAL(-0.267633), REAL(-0.603419), REAL(-0.655209), - REAL(-0.446838), REAL(-0.118517), REAL(-0.466159), - REAL(-0.459488), REAL(-0.093017), REAL(-0.311341), - REAL(-0.370645), REAL(-0.100108), REAL(-0.159454), - REAL(-0.371984), REAL(-0.091991), REAL(-0.011044), - REAL(-0.328945), REAL(-0.098269), REAL(0.088659), - REAL(-0.282452), REAL(-0.018862), REAL(0.311501), - REAL(-0.352403), REAL(-0.131341), REAL(0.144902), - REAL(-0.364126), REAL(-0.200299), REAL(0.202388), - REAL(-0.283965), REAL(-0.231869), REAL(0.023668), - REAL(-0.298943), REAL(-0.155218), REAL(0.369716), - REAL(-0.293787), REAL(-0.121856), REAL(0.419097), - REAL(-0.290163), REAL(-0.290797), REAL(0.107824), - REAL(-0.264165), REAL(-0.272849), REAL(0.036347), - REAL(-0.228567), REAL(-0.372573), REAL(0.290309), - REAL(-0.190431), REAL(-0.286997), REAL(0.421917), - REAL(-0.191039), REAL(-0.240973), REAL(0.507118), - REAL(-0.287272), REAL(-0.276431), REAL(-0.065444), - REAL(-0.295675), REAL(-0.280818), REAL(-0.174200), - REAL(-0.399537), REAL(-0.313131), REAL(-0.376167), - REAL(-0.392666), REAL(-0.488581), REAL(-0.427494), - REAL(-0.331669), REAL(-0.570185), REAL(-0.466054), - REAL(-0.282290), REAL(-0.618140), REAL(-0.589220), - REAL(-0.374238), REAL(-0.594882), REAL(-0.323298), - REAL(-0.381071), REAL(-0.629723), REAL(-0.350777), - REAL(-0.382112), REAL(-0.624060), REAL(-0.221577), - REAL(-0.272701), REAL(-0.566522), REAL(0.259157), - REAL(-0.256702), REAL(-0.663406), REAL(0.286079), - REAL(-0.280948), REAL(-0.428359), REAL(0.055790), - REAL(-0.184974), REAL(-0.508894), REAL(0.326265), - REAL(-0.279971), REAL(-0.526918), REAL(0.395319), - REAL(-0.282599), REAL(-0.663393), REAL(0.412411), - REAL(-0.188329), REAL(-0.475093), REAL(0.417954), - REAL(-0.263384), REAL(-0.663396), REAL(0.466604), - REAL(-0.209063), REAL(-0.663393), REAL(0.509344), - REAL(-0.002044), REAL(-0.319624), REAL(0.553078), - REAL(-0.001266), REAL(-0.371260), REAL(0.413296), - REAL(-0.219753), REAL(-0.339762), REAL(-0.040921), - REAL(-0.256986), REAL(-0.282511), REAL(-0.006349), - REAL(-0.271706), REAL(-0.260881), REAL(0.001764), - REAL(-0.091191), REAL(-0.419184), REAL(-0.045912), - REAL(-0.114944), REAL(-0.429752), REAL(-0.124739), - REAL(-0.113970), REAL(-0.382987), REAL(-0.188540), - REAL(-0.243012), REAL(-0.464942), REAL(-0.242850), - REAL(-0.314815), REAL(-0.505402), REAL(-0.324768), - REAL(0.002774), REAL(-0.437526), REAL(-0.262766), - REAL(-0.072625), REAL(-0.417748), REAL(-0.221440), - REAL(-0.160112), REAL(-0.476932), REAL(-0.293450), - REAL(0.003859), REAL(-0.453425), REAL(-0.443916), - REAL(-0.120363), REAL(-0.581567), REAL(-0.438689), - REAL(-0.091499), REAL(-0.584191), REAL(-0.294511), - REAL(-0.116469), REAL(-0.599861), REAL(-0.188308), - REAL(-0.208032), REAL(-0.513640), REAL(-0.134649), - REAL(-0.235749), REAL(-0.610017), REAL(-0.040939), - REAL(-0.344916), REAL(-0.622487), REAL(-0.085380), - REAL(-0.336401), REAL(-0.531864), REAL(-0.212298), - REAL(0.001961), REAL(-0.459550), REAL(-0.135547), - REAL(-0.058296), REAL(-0.430536), REAL(-0.043440), - REAL(0.001378), REAL(-0.449511), REAL(-0.037762), - REAL(-0.130135), REAL(-0.510222), REAL(0.079144), - REAL(0.000142), REAL(-0.477549), REAL(0.157064), - REAL(-0.114284), REAL(-0.453206), REAL(0.304397), - REAL(-0.000592), REAL(-0.443558), REAL(0.285401), - REAL(-0.056215), REAL(-0.663402), REAL(0.326073), - REAL(-0.026248), REAL(-0.568010), REAL(0.273318), - REAL(-0.049261), REAL(-0.531064), REAL(0.389854), - REAL(-0.127096), REAL(-0.663398), REAL(0.479316), - REAL(-0.058384), REAL(-0.663401), REAL(0.372891), - REAL(-0.303961), REAL(0.054199), REAL(0.625921), - REAL(-0.268594), REAL(0.193403), REAL(0.502766), - REAL(-0.277159), REAL(0.126123), REAL(0.443289), - REAL(-0.287605), REAL(-0.005722), REAL(0.531844), - REAL(-0.231396), REAL(-0.121289), REAL(0.587387), - REAL(-0.253475), REAL(-0.081797), REAL(0.756541), - REAL(-0.195164), REAL(-0.137969), REAL(0.728011), - REAL(-0.167673), REAL(-0.156573), REAL(0.609388), - REAL(-0.145917), REAL(-0.169029), REAL(0.697600), - REAL(-0.077776), REAL(-0.214247), REAL(0.622586), - REAL(-0.076873), REAL(-0.214971), REAL(0.696301), - REAL(-0.002341), REAL(-0.233135), REAL(0.622859), - REAL(-0.002730), REAL(-0.213526), REAL(0.691267), - REAL(-0.003136), REAL(-0.192628), REAL(0.762731), - REAL(-0.056136), REAL(-0.201222), REAL(0.763806), - REAL(-0.114589), REAL(-0.166192), REAL(0.770723), - REAL(-0.155145), REAL(-0.129632), REAL(0.791738), - REAL(-0.183611), REAL(-0.058705), REAL(0.847012), - REAL(-0.165562), REAL(0.001980), REAL(0.833386), - REAL(-0.220084), REAL(0.019914), REAL(0.768935), - REAL(-0.255730), REAL(0.090306), REAL(0.670782), - REAL(-0.255594), REAL(0.113833), REAL(0.663389), - REAL(-0.226380), REAL(0.212655), REAL(0.617740), - REAL(-0.003367), REAL(-0.195342), REAL(0.799680), - REAL(-0.029743), REAL(-0.210508), REAL(0.827180), - REAL(-0.003818), REAL(-0.194783), REAL(0.873636), - REAL(-0.004116), REAL(-0.157907), REAL(0.931268), - REAL(-0.031280), REAL(-0.184555), REAL(0.889476), - REAL(-0.059885), REAL(-0.184448), REAL(0.841330), - REAL(-0.135333), REAL(-0.164332), REAL(0.878200), - REAL(-0.085574), REAL(-0.170948), REAL(0.925547), - REAL(-0.163833), REAL(-0.094170), REAL(0.897114), - REAL(-0.138444), REAL(-0.104250), REAL(0.945975), - REAL(-0.083497), REAL(-0.084934), REAL(0.979607), - REAL(-0.004433), REAL(-0.146642), REAL(0.985872), - REAL(-0.150715), REAL(0.032650), REAL(0.884111), - REAL(-0.135892), REAL(-0.035520), REAL(0.945455), - REAL(-0.070612), REAL(0.036849), REAL(0.975733), - REAL(-0.004458), REAL(-0.042526), REAL(1.015670), - REAL(-0.004249), REAL(0.046042), REAL(1.003240), - REAL(-0.086969), REAL(0.133224), REAL(0.947633), - REAL(-0.003873), REAL(0.161605), REAL(0.970499), - REAL(-0.125544), REAL(0.140012), REAL(0.917678), - REAL(-0.125651), REAL(0.250246), REAL(0.857602), - REAL(-0.003127), REAL(0.284070), REAL(0.878870), - REAL(-0.159174), REAL(0.125726), REAL(0.888878), - REAL(-0.183807), REAL(0.196970), REAL(0.844480), - REAL(-0.159890), REAL(0.291736), REAL(0.732480), - REAL(-0.199495), REAL(0.207230), REAL(0.779864), - REAL(-0.206182), REAL(0.164608), REAL(0.693257), - REAL(-0.186315), REAL(0.160689), REAL(0.817193), - REAL(-0.192827), REAL(0.166706), REAL(0.782271), - REAL(-0.175112), REAL(0.110008), REAL(0.860621), - REAL(-0.161022), REAL(0.057420), REAL(0.855111), - REAL(-0.172319), REAL(0.036155), REAL(0.816189), - REAL(-0.190318), REAL(0.064083), REAL(0.760605), - REAL(-0.195072), REAL(0.129179), REAL(0.731104), - REAL(-0.203126), REAL(0.410287), REAL(0.680536), - REAL(-0.216677), REAL(0.309274), REAL(0.642272), - REAL(-0.241515), REAL(0.311485), REAL(0.587832), - REAL(-0.002209), REAL(0.366663), REAL(0.749413), - REAL(-0.088230), REAL(0.396265), REAL(0.678635), - REAL(-0.170147), REAL(0.109517), REAL(0.840784), - REAL(-0.160521), REAL(0.067766), REAL(0.830650), - REAL(-0.181546), REAL(0.139805), REAL(0.812146), - REAL(-0.180495), REAL(0.148568), REAL(0.776087), - REAL(-0.180255), REAL(0.129125), REAL(0.744192), - REAL(-0.186298), REAL(0.078308), REAL(0.769352), - REAL(-0.167622), REAL(0.060539), REAL(0.806675), - REAL(-0.189876), REAL(0.102760), REAL(0.802582), - REAL(-0.108340), REAL(0.455446), REAL(0.657174), - REAL(-0.241585), REAL(0.527592), REAL(0.669296), - REAL(-0.265676), REAL(0.513366), REAL(0.634594), - REAL(-0.203073), REAL(0.478550), REAL(0.581526), - REAL(-0.266772), REAL(0.642330), REAL(0.602061), - REAL(-0.216961), REAL(0.564846), REAL(0.535435), - REAL(-0.202210), REAL(0.525495), REAL(0.475944), - REAL(-0.193888), REAL(0.467925), REAL(0.520606), - REAL(-0.265837), REAL(0.757267), REAL(0.500933), - REAL(-0.240306), REAL(0.653440), REAL(0.463215), - REAL(-0.309239), REAL(0.776868), REAL(0.304726), - REAL(-0.271009), REAL(0.683094), REAL(0.382018), - REAL(-0.312111), REAL(0.671099), REAL(0.286687), - REAL(-0.268791), REAL(0.624342), REAL(0.377231), - REAL(-0.302457), REAL(0.533996), REAL(0.360289), - REAL(-0.263656), REAL(0.529310), REAL(0.412564), - REAL(-0.282311), REAL(0.415167), REAL(0.447666), - REAL(-0.239201), REAL(0.442096), REAL(0.495604), - REAL(-0.220043), REAL(0.569026), REAL(0.445877), - REAL(-0.001263), REAL(0.395631), REAL(0.602029), - REAL(-0.057345), REAL(0.442535), REAL(0.572224), - REAL(-0.088927), REAL(0.506333), REAL(0.529106), - REAL(-0.125738), REAL(0.535076), REAL(0.612913), - REAL(-0.126251), REAL(0.577170), REAL(0.483159), - REAL(-0.149594), REAL(0.611520), REAL(0.557731), - REAL(-0.163188), REAL(0.660791), REAL(0.491080), - REAL(-0.172482), REAL(0.663387), REAL(0.415416), - REAL(-0.160464), REAL(0.591710), REAL(0.370659), - REAL(-0.156445), REAL(0.536396), REAL(0.378302), - REAL(-0.136496), REAL(0.444358), REAL(0.425226), - REAL(-0.095564), REAL(0.373768), REAL(0.473659), - REAL(-0.104146), REAL(0.315912), REAL(0.498104), - REAL(-0.000496), REAL(0.384194), REAL(0.473817), - REAL(-0.000183), REAL(0.297770), REAL(0.401486), - REAL(-0.129042), REAL(0.270145), REAL(0.434495), - REAL(0.000100), REAL(0.272963), REAL(0.349138), - REAL(-0.113060), REAL(0.236984), REAL(0.385554), - REAL(0.007260), REAL(0.016311), REAL(-0.883396), - REAL(0.007865), REAL(0.122104), REAL(-0.956137), - REAL(-0.032842), REAL(0.115282), REAL(-0.953252), - REAL(-0.089115), REAL(0.108449), REAL(-0.950317), - REAL(-0.047440), REAL(0.014729), REAL(-0.882756), - REAL(-0.104458), REAL(0.013137), REAL(-0.882070), - REAL(-0.086439), REAL(-0.584866), REAL(-0.608343), - REAL(-0.115026), REAL(-0.662605), REAL(-0.436732), - REAL(-0.071683), REAL(-0.665372), REAL(-0.606385), - REAL(-0.257884), REAL(-0.665381), REAL(-0.658052), - REAL(-0.272542), REAL(-0.665381), REAL(-0.592063), - REAL(-0.371322), REAL(-0.665382), REAL(-0.353620), - REAL(-0.372362), REAL(-0.665381), REAL(-0.224420), - REAL(-0.335166), REAL(-0.665380), REAL(-0.078623), - REAL(-0.225999), REAL(-0.665375), REAL(-0.038981), - REAL(-0.106719), REAL(-0.665374), REAL(-0.186351), - REAL(-0.081749), REAL(-0.665372), REAL(-0.292554), - REAL(0.006943), REAL(-0.091505), REAL(-0.858354), - REAL(0.006117), REAL(-0.280985), REAL(-0.769967), - REAL(0.004495), REAL(-0.502360), REAL(-0.559799), - REAL(-0.198638), REAL(-0.302135), REAL(-0.845816), - REAL(-0.237395), REAL(-0.542544), REAL(-0.587188), - REAL(-0.270001), REAL(-0.279489), REAL(-0.669861), - REAL(-0.134547), REAL(-0.119852), REAL(-0.959004), - REAL(-0.052088), REAL(-0.122463), REAL(-0.944549), - REAL(-0.124463), REAL(-0.293508), REAL(-0.899566), - REAL(-0.047616), REAL(-0.289643), REAL(-0.879292), - REAL(-0.168595), REAL(-0.529132), REAL(-0.654931), - REAL(-0.099793), REAL(-0.515719), REAL(-0.645873), - REAL(-0.186168), REAL(-0.605282), REAL(-0.724690), - REAL(-0.112970), REAL(-0.583097), REAL(-0.707469), - REAL(-0.108152), REAL(-0.665375), REAL(-0.700408), - REAL(-0.183019), REAL(-0.665378), REAL(-0.717630), - REAL(-0.349529), REAL(-0.334459), REAL(-0.511985), - REAL(-0.141182), REAL(-0.437705), REAL(-0.798194), - REAL(-0.212670), REAL(-0.448725), REAL(-0.737447), - REAL(-0.261111), REAL(-0.414945), REAL(-0.613835), - REAL(-0.077364), REAL(-0.431480), REAL(-0.778113), - REAL(0.005174), REAL(-0.425277), REAL(-0.651592), - REAL(0.089236), REAL(-0.431732), REAL(-0.777093), - REAL(0.271006), REAL(-0.415749), REAL(-0.610577), - REAL(0.223981), REAL(-0.449384), REAL(-0.734774), - REAL(0.153275), REAL(-0.438150), REAL(-0.796391), - REAL(0.358414), REAL(-0.335529), REAL(-0.507649), - REAL(0.193434), REAL(-0.665946), REAL(-0.715325), - REAL(0.118363), REAL(-0.665717), REAL(-0.699021), - REAL(0.123515), REAL(-0.583454), REAL(-0.706020), - REAL(0.196851), REAL(-0.605860), REAL(-0.722345), - REAL(0.109788), REAL(-0.516035), REAL(-0.644590), - REAL(0.178656), REAL(-0.529656), REAL(-0.652804), - REAL(0.061157), REAL(-0.289807), REAL(-0.878626), - REAL(0.138234), REAL(-0.293905), REAL(-0.897958), - REAL(0.066933), REAL(-0.122643), REAL(-0.943820), - REAL(0.149571), REAL(-0.120281), REAL(-0.957264), - REAL(0.280989), REAL(-0.280321), REAL(-0.666487), - REAL(0.246581), REAL(-0.543275), REAL(-0.584224), - REAL(0.211720), REAL(-0.302754), REAL(-0.843303), - REAL(0.086966), REAL(-0.665627), REAL(-0.291520), - REAL(0.110634), REAL(-0.665702), REAL(-0.185021), - REAL(0.228099), REAL(-0.666061), REAL(-0.036201), - REAL(0.337743), REAL(-0.666396), REAL(-0.074503), - REAL(0.376722), REAL(-0.666513), REAL(-0.219833), - REAL(0.377265), REAL(-0.666513), REAL(-0.349036), - REAL(0.281411), REAL(-0.666217), REAL(-0.588670), - REAL(0.267564), REAL(-0.666174), REAL(-0.654834), - REAL(0.080745), REAL(-0.665602), REAL(-0.605452), - REAL(0.122016), REAL(-0.662963), REAL(-0.435280), - REAL(0.095767), REAL(-0.585141), REAL(-0.607228), - REAL(0.118944), REAL(0.012799), REAL(-0.880702), - REAL(0.061944), REAL(0.014564), REAL(-0.882086), - REAL(0.104725), REAL(0.108156), REAL(-0.949130), - REAL(0.048513), REAL(0.115159), REAL(-0.952753), - REAL(0.112696), REAL(0.236643), REAL(0.386937), - REAL(0.128177), REAL(0.269757), REAL(0.436071), - REAL(0.102643), REAL(0.315600), REAL(0.499370), - REAL(0.094535), REAL(0.373481), REAL(0.474824), - REAL(0.136270), REAL(0.443946), REAL(0.426895), - REAL(0.157071), REAL(0.535923), REAL(0.380222), - REAL(0.161350), REAL(0.591224), REAL(0.372630), - REAL(0.173035), REAL(0.662865), REAL(0.417531), - REAL(0.162808), REAL(0.660299), REAL(0.493077), - REAL(0.148250), REAL(0.611070), REAL(0.559555), - REAL(0.125719), REAL(0.576790), REAL(0.484702), - REAL(0.123489), REAL(0.534699), REAL(0.614440), - REAL(0.087621), REAL(0.506066), REAL(0.530188), - REAL(0.055321), REAL(0.442365), REAL(0.572915), - REAL(0.219936), REAL(0.568361), REAL(0.448571), - REAL(0.238099), REAL(0.441375), REAL(0.498528), - REAL(0.281711), REAL(0.414315), REAL(0.451121), - REAL(0.263833), REAL(0.528513), REAL(0.415794), - REAL(0.303284), REAL(0.533081), REAL(0.363998), - REAL(0.269687), REAL(0.623528), REAL(0.380528), - REAL(0.314255), REAL(0.670153), REAL(0.290524), - REAL(0.272023), REAL(0.682273), REAL(0.385343), - REAL(0.311480), REAL(0.775931), REAL(0.308527), - REAL(0.240239), REAL(0.652714), REAL(0.466159), - REAL(0.265619), REAL(0.756464), REAL(0.504187), - REAL(0.192562), REAL(0.467341), REAL(0.522972), - REAL(0.201605), REAL(0.524885), REAL(0.478417), - REAL(0.215743), REAL(0.564193), REAL(0.538084), - REAL(0.264969), REAL(0.641527), REAL(0.605317), - REAL(0.201031), REAL(0.477940), REAL(0.584002), - REAL(0.263086), REAL(0.512567), REAL(0.637832), - REAL(0.238615), REAL(0.526867), REAL(0.672237), - REAL(0.105309), REAL(0.455123), REAL(0.658482), - REAL(0.183993), REAL(0.102195), REAL(0.804872), - REAL(0.161563), REAL(0.060042), REAL(0.808692), - REAL(0.180748), REAL(0.077754), REAL(0.771600), - REAL(0.175168), REAL(0.128588), REAL(0.746368), - REAL(0.175075), REAL(0.148030), REAL(0.778264), - REAL(0.175658), REAL(0.139265), REAL(0.814333), - REAL(0.154191), REAL(0.067291), REAL(0.832578), - REAL(0.163818), REAL(0.109013), REAL(0.842830), - REAL(0.084760), REAL(0.396004), REAL(0.679695), - REAL(0.238888), REAL(0.310760), REAL(0.590775), - REAL(0.213380), REAL(0.308625), REAL(0.644905), - REAL(0.199666), REAL(0.409678), REAL(0.683003), - REAL(0.190143), REAL(0.128597), REAL(0.733463), - REAL(0.184833), REAL(0.063516), REAL(0.762902), - REAL(0.166070), REAL(0.035644), REAL(0.818261), - REAL(0.154361), REAL(0.056943), REAL(0.857042), - REAL(0.168542), REAL(0.109489), REAL(0.862725), - REAL(0.187387), REAL(0.166131), REAL(0.784599), - REAL(0.180428), REAL(0.160135), REAL(0.819438), - REAL(0.201823), REAL(0.163991), REAL(0.695756), - REAL(0.194206), REAL(0.206635), REAL(0.782275), - REAL(0.155438), REAL(0.291260), REAL(0.734412), - REAL(0.177696), REAL(0.196424), REAL(0.846693), - REAL(0.152305), REAL(0.125256), REAL(0.890786), - REAL(0.119546), REAL(0.249876), REAL(0.859104), - REAL(0.118369), REAL(0.139643), REAL(0.919173), - REAL(0.079410), REAL(0.132973), REAL(0.948652), - REAL(0.062419), REAL(0.036648), REAL(0.976547), - REAL(0.127847), REAL(-0.035919), REAL(0.947070), - REAL(0.143624), REAL(0.032206), REAL(0.885913), - REAL(0.074888), REAL(-0.085173), REAL(0.980577), - REAL(0.130184), REAL(-0.104656), REAL(0.947620), - REAL(0.156201), REAL(-0.094653), REAL(0.899074), - REAL(0.077366), REAL(-0.171194), REAL(0.926545), - REAL(0.127722), REAL(-0.164729), REAL(0.879810), - REAL(0.052670), REAL(-0.184618), REAL(0.842019), - REAL(0.023477), REAL(-0.184638), REAL(0.889811), - REAL(0.022626), REAL(-0.210587), REAL(0.827500), - REAL(0.223089), REAL(0.211976), REAL(0.620493), - REAL(0.251444), REAL(0.113067), REAL(0.666494), - REAL(0.251419), REAL(0.089540), REAL(0.673887), - REAL(0.214360), REAL(0.019258), REAL(0.771595), - REAL(0.158999), REAL(0.001490), REAL(0.835374), - REAL(0.176696), REAL(-0.059249), REAL(0.849218), - REAL(0.148696), REAL(-0.130091), REAL(0.793599), - REAL(0.108290), REAL(-0.166528), REAL(0.772088), - REAL(0.049820), REAL(-0.201382), REAL(0.764454), - REAL(0.071341), REAL(-0.215195), REAL(0.697209), - REAL(0.073148), REAL(-0.214475), REAL(0.623510), - REAL(0.140502), REAL(-0.169461), REAL(0.699354), - REAL(0.163374), REAL(-0.157073), REAL(0.611416), - REAL(0.189466), REAL(-0.138550), REAL(0.730366), - REAL(0.247593), REAL(-0.082554), REAL(0.759610), - REAL(0.227468), REAL(-0.121982), REAL(0.590197), - REAL(0.284702), REAL(-0.006586), REAL(0.535347), - REAL(0.275741), REAL(0.125287), REAL(0.446676), - REAL(0.266650), REAL(0.192594), REAL(0.506044), - REAL(0.300086), REAL(0.053287), REAL(0.629620), - REAL(0.055450), REAL(-0.663935), REAL(0.375065), - REAL(0.122854), REAL(-0.664138), REAL(0.482323), - REAL(0.046520), REAL(-0.531571), REAL(0.391918), - REAL(0.024824), REAL(-0.568450), REAL(0.275106), - REAL(0.053855), REAL(-0.663931), REAL(0.328224), - REAL(0.112829), REAL(-0.453549), REAL(0.305788), - REAL(0.131265), REAL(-0.510617), REAL(0.080746), - REAL(0.061174), REAL(-0.430716), REAL(-0.042710), - REAL(0.341019), REAL(-0.532887), REAL(-0.208150), - REAL(0.347705), REAL(-0.623533), REAL(-0.081139), - REAL(0.238040), REAL(-0.610732), REAL(-0.038037), - REAL(0.211764), REAL(-0.514274), REAL(-0.132078), - REAL(0.120605), REAL(-0.600219), REAL(-0.186856), - REAL(0.096985), REAL(-0.584476), REAL(-0.293357), - REAL(0.127621), REAL(-0.581941), REAL(-0.437170), - REAL(0.165902), REAL(-0.477425), REAL(-0.291453), - REAL(0.077720), REAL(-0.417975), REAL(-0.220519), - REAL(0.320892), REAL(-0.506363), REAL(-0.320874), - REAL(0.248214), REAL(-0.465684), REAL(-0.239842), - REAL(0.118764), REAL(-0.383338), REAL(-0.187114), - REAL(0.118816), REAL(-0.430106), REAL(-0.123307), - REAL(0.094131), REAL(-0.419464), REAL(-0.044777), - REAL(0.274526), REAL(-0.261706), REAL(0.005110), - REAL(0.259842), REAL(-0.283292), REAL(-0.003185), - REAL(0.222861), REAL(-0.340431), REAL(-0.038210), - REAL(0.204445), REAL(-0.664380), REAL(0.513353), - REAL(0.259286), REAL(-0.664547), REAL(0.471281), - REAL(0.185402), REAL(-0.476020), REAL(0.421718), - REAL(0.279163), REAL(-0.664604), REAL(0.417328), - REAL(0.277157), REAL(-0.528122), REAL(0.400208), - REAL(0.183069), REAL(-0.509812), REAL(0.329995), - REAL(0.282599), REAL(-0.429210), REAL(0.059242), - REAL(0.254816), REAL(-0.664541), REAL(0.290687), - REAL(0.271436), REAL(-0.567707), REAL(0.263966), - REAL(0.386561), REAL(-0.625221), REAL(-0.216870), - REAL(0.387086), REAL(-0.630883), REAL(-0.346073), - REAL(0.380021), REAL(-0.596021), REAL(-0.318679), - REAL(0.291269), REAL(-0.619007), REAL(-0.585707), - REAL(0.339280), REAL(-0.571198), REAL(-0.461946), - REAL(0.400045), REAL(-0.489778), REAL(-0.422640), - REAL(0.406817), REAL(-0.314349), REAL(-0.371230), - REAL(0.300588), REAL(-0.281718), REAL(-0.170549), - REAL(0.290866), REAL(-0.277304), REAL(-0.061905), - REAL(0.187735), REAL(-0.241545), REAL(0.509437), - REAL(0.188032), REAL(-0.287569), REAL(0.424234), - REAL(0.227520), REAL(-0.373262), REAL(0.293102), - REAL(0.266526), REAL(-0.273650), REAL(0.039597), - REAL(0.291592), REAL(-0.291676), REAL(0.111386), - REAL(0.291914), REAL(-0.122741), REAL(0.422683), - REAL(0.297574), REAL(-0.156119), REAL(0.373368), - REAL(0.286603), REAL(-0.232731), REAL(0.027162), - REAL(0.364663), REAL(-0.201399), REAL(0.206850), - REAL(0.353855), REAL(-0.132408), REAL(0.149228), - REAL(0.282208), REAL(-0.019715), REAL(0.314960), - REAL(0.331187), REAL(-0.099266), REAL(0.092701), - REAL(0.375463), REAL(-0.093120), REAL(-0.006467), - REAL(0.375917), REAL(-0.101236), REAL(-0.154882), - REAL(0.466635), REAL(-0.094416), REAL(-0.305669), - REAL(0.455805), REAL(-0.119881), REAL(-0.460632), - REAL(0.277465), REAL(-0.604242), REAL(-0.651871), - REAL(0.261022), REAL(-0.551176), REAL(-0.554667), - REAL(0.093627), REAL(0.258494), REAL(-0.920589), - REAL(0.114248), REAL(0.310608), REAL(-0.798070), - REAL(0.144232), REAL(0.211434), REAL(-0.835001), - REAL(0.119916), REAL(0.176940), REAL(-0.951159), - REAL(0.184061), REAL(0.101854), REAL(-0.918220), - REAL(0.092431), REAL(0.276521), REAL(-0.738231), - REAL(0.133504), REAL(0.218403), REAL(-0.758602), - REAL(0.194987), REAL(0.097655), REAL(-0.812476), - REAL(0.185542), REAL(0.011005), REAL(-0.879202), - REAL(0.230315), REAL(-0.127450), REAL(-0.884202), - REAL(0.260471), REAL(0.255056), REAL(-0.624378), - REAL(0.351567), REAL(-0.042194), REAL(-0.663976), - REAL(0.253742), REAL(0.323524), REAL(-0.433716), - REAL(0.411612), REAL(0.132299), REAL(-0.438264), - REAL(0.270513), REAL(0.356530), REAL(-0.289984), - REAL(0.422146), REAL(0.162819), REAL(-0.273130), - REAL(0.164724), REAL(0.237490), REAL(0.208912), - REAL(0.253806), REAL(0.092900), REAL(0.240640), - REAL(0.203608), REAL(0.284597), REAL(0.096223), - REAL(0.241006), REAL(0.343093), REAL(-0.171396), - REAL(0.356076), REAL(0.149288), REAL(-0.143443), - REAL(0.337656), REAL(0.131992), REAL(0.066374) -}; - -int gIndices[NUM_TRIANGLES][3] = { - {126,134,133}, - {342,138,134}, - {133,134,138}, - {126,342,134}, - {312,316,317}, - {169,163,162}, - {312,317,319}, - {312,319,318}, - {169,162,164}, - {169,168,163}, - {312,314,315}, - {169,164,165}, - {169,167,168}, - {312,315,316}, - {312,313,314}, - {169,165,166}, - {169,166,167}, - {312,318,313}, - {308,304,305}, - {308,305,306}, - {179,181,188}, - {177,173,175}, - {177,175,176}, - {302,293,300}, - {322,294,304}, - {188,176,175}, - {188,175,179}, - {158,177,187}, - {305,293,302}, - {305,302,306}, - {322,304,308}, - {188,181,183}, - {158,173,177}, - {293,298,300}, - {304,294,296}, - {304,296,305}, - {185,176,188}, - {185,188,183}, - {187,177,176}, - {187,176,185}, - {305,296,298}, - {305,298,293}, - {436,432, 28}, - {436, 28, 23}, - {434,278,431}, - { 30,208,209}, - { 30,209, 29}, - { 19, 20, 24}, - {208,207,211}, - {208,211,209}, - { 19,210,212}, - {433,434,431}, - {433,431,432}, - {433,432,436}, - {436,437,433}, - {277,275,276}, - {277,276,278}, - {209,210, 25}, - { 21, 26, 24}, - { 21, 24, 20}, - { 25, 26, 27}, - { 25, 27, 29}, - {435,439,277}, - {439,275,277}, - {432,431, 30}, - {432, 30, 28}, - {433,437,438}, - {433,438,435}, - {434,277,278}, - { 24, 25,210}, - { 24, 26, 25}, - { 29, 27, 28}, - { 29, 28, 30}, - { 19, 24,210}, - {208, 30,431}, - {208,431,278}, - {435,434,433}, - {435,277,434}, - { 25, 29,209}, - { 27, 22, 23}, - { 27, 23, 28}, - { 26, 22, 27}, - { 26, 21, 22}, - {212,210,209}, - {212,209,211}, - {207,208,278}, - {207,278,276}, - {439,435,438}, - { 12, 9, 10}, - { 12, 10, 13}, - { 2, 3, 5}, - { 2, 5, 4}, - { 16, 13, 14}, - { 16, 14, 17}, - { 22, 21, 16}, - { 13, 10, 11}, - { 13, 11, 14}, - { 1, 0, 3}, - { 1, 3, 2}, - { 15, 12, 16}, - { 19, 18, 15}, - { 19, 15, 16}, - { 19, 16, 20}, - { 9, 1, 2}, - { 9, 2, 10}, - { 3, 7, 8}, - { 3, 8, 5}, - { 16, 17, 23}, - { 16, 23, 22}, - { 21, 20, 16}, - { 10, 2, 4}, - { 10, 4, 11}, - { 0, 6, 7}, - { 0, 7, 3}, - { 12, 13, 16}, - {451,446,445}, - {451,445,450}, - {442,440,439}, - {442,439,438}, - {442,438,441}, - {421,420,422}, - {412,411,426}, - {412,426,425}, - {408,405,407}, - {413, 67, 68}, - {413, 68,414}, - {391,390,412}, - { 80,384,386}, - {404,406,378}, - {390,391,377}, - {390,377, 88}, - {400,415,375}, - {398,396,395}, - {398,395,371}, - {398,371,370}, - {112,359,358}, - {112,358,113}, - {351,352,369}, - {125,349,348}, - {345,343,342}, - {342,340,339}, - {341,335,337}, - {328,341,327}, - {331,323,333}, - {331,322,323}, - {327,318,319}, - {327,319,328}, - {315,314,324}, - {302,300,301}, - {302,301,303}, - {320,311,292}, - {285,284,289}, - {310,307,288}, - {310,288,290}, - {321,350,281}, - {321,281,282}, - {423,448,367}, - {272,273,384}, - {272,384,274}, - {264,265,382}, - {264,382,383}, - {440,442,261}, - {440,261,263}, - {252,253,254}, - {252,254,251}, - {262,256,249}, - {262,249,248}, - {228,243,242}, - {228, 31,243}, - {213,215,238}, - {213,238,237}, - { 19,212,230}, - {224,225,233}, - {224,233,231}, - {217,218, 56}, - {217, 56, 54}, - {217,216,239}, - {217,239,238}, - {217,238,215}, - {218,217,215}, - {218,215,214}, - { 6,102,206}, - {186,199,200}, - {197,182,180}, - {170,171,157}, - {201,200,189}, - {170,190,191}, - {170,191,192}, - {175,174,178}, - {175,178,179}, - {168,167,155}, - {122,149,158}, - {122,158,159}, - {135,153,154}, - {135,154,118}, - {143,140,141}, - {143,141,144}, - {132,133,136}, - {130,126,133}, - {124,125,127}, - {122,101,100}, - {122,100,121}, - {110,108,107}, - {110,107,109}, - { 98, 99, 97}, - { 98, 97, 64}, - { 98, 64, 66}, - { 87, 55, 57}, - { 83, 82, 79}, - { 83, 79, 84}, - { 78, 74, 50}, - { 49, 71, 41}, - { 49, 41, 37}, - { 49, 37, 36}, - { 58, 44, 60}, - { 60, 59, 58}, - { 51, 34, 33}, - { 39, 40, 42}, - { 39, 42, 38}, - {243,240, 33}, - {243, 33,229}, - { 39, 38, 6}, - { 44, 46, 40}, - { 55, 56, 57}, - { 64, 62, 65}, - { 64, 65, 66}, - { 41, 71, 45}, - { 75, 50, 51}, - { 81, 79, 82}, - { 77, 88, 73}, - { 93, 92, 94}, - { 68, 47, 46}, - { 96, 97, 99}, - { 96, 99, 95}, - {110,109,111}, - {111,112,110}, - {114,113,123}, - {114,123,124}, - {132,131,129}, - {133,137,136}, - {135,142,145}, - {145,152,135}, - {149,147,157}, - {157,158,149}, - {164,150,151}, - {153,163,168}, - {153,168,154}, - {185,183,182}, - {185,182,184}, - {161,189,190}, - {200,199,191}, - {200,191,190}, - {180,178,195}, - {180,195,196}, - {102,101,204}, - {102,204,206}, - { 43, 48,104}, - { 43,104,103}, - {216,217, 54}, - {216, 54, 32}, - {207,224,231}, - {230,212,211}, - {230,211,231}, - {227,232,241}, - {227,241,242}, - {235,234,241}, - {235,241,244}, - {430,248,247}, - {272,274,253}, - {272,253,252}, - {439,260,275}, - {225,224,259}, - {225,259,257}, - {269,270,407}, - {269,407,405}, - {270,269,273}, - {270,273,272}, - {273,269,268}, - {273,268,267}, - {273,267,266}, - {273,266,265}, - {273,265,264}, - {448,279,367}, - {281,350,368}, - {285,286,301}, - {290,323,310}, - {290,311,323}, - {282,281,189}, - {292,311,290}, - {292,290,291}, - {307,306,302}, - {307,302,303}, - {316,315,324}, - {316,324,329}, - {331,351,350}, - {330,334,335}, - {330,335,328}, - {341,337,338}, - {344,355,354}, - {346,345,348}, - {346,348,347}, - {364,369,352}, - {364,352,353}, - {365,363,361}, - {365,361,362}, - {376,401,402}, - {373,372,397}, - {373,397,400}, - {376, 92,377}, - {381,378,387}, - {381,387,385}, - {386, 77, 80}, - {390,389,412}, - {416,417,401}, - {403,417,415}, - {408,429,430}, - {419,423,418}, - {427,428,444}, - {427,444,446}, - {437,436,441}, - {450,445, 11}, - {450, 11, 4}, - {447,449, 5}, - {447, 5, 8}, - {441,438,437}, - {425,426,451}, - {425,451,452}, - {417,421,415}, - {408,407,429}, - {399,403,400}, - {399,400,397}, - {394,393,416}, - {389,411,412}, - {386,383,385}, - {408,387,378}, - {408,378,406}, - {377,391,376}, - { 94,375,415}, - {372,373,374}, - {372,374,370}, - {359,111,360}, - {359,112,111}, - {113,358,349}, - {113,349,123}, - {346,343,345}, - {343,340,342}, - {338,336,144}, - {338,144,141}, - {327,341,354}, - {327,354,326}, - {331,350,321}, - {331,321,322}, - {314,313,326}, - {314,326,325}, - {300,298,299}, - {300,299,301}, - {288,287,289}, - {189,292,282}, - {287,288,303}, - {284,285,297}, - {368,280,281}, - {448,447,279}, - {274,226,255}, - {267,268,404}, - {267,404,379}, - {429,262,430}, - {439,440,260}, - {257,258,249}, - {257,249,246}, - {430,262,248}, - {234,228,242}, - {234,242,241}, - {237,238,239}, - {237,239,236}, - { 15, 18,227}, - { 15,227,229}, - {222,223, 82}, - {222, 82, 83}, - {214,215,213}, - {214,213, 81}, - { 38,102, 6}, - {122,159,200}, - {122,200,201}, - {174,171,192}, - {174,192,194}, - {197,193,198}, - {190,170,161}, - {181,179,178}, - {181,178,180}, - {166,156,155}, - {163,153,152}, - {163,152,162}, - {120,156,149}, - {120,149,121}, - {152,153,135}, - {140,143,142}, - {135,131,132}, - {135,132,136}, - {130,129,128}, - {130,128,127}, - {100,105,119}, - {100,119,120}, - {106,104,107}, - {106,107,108}, - { 91, 95, 59}, - { 93, 94, 68}, - { 91, 89, 92}, - { 76, 53, 55}, - { 76, 55, 87}, - { 81, 78, 79}, - { 74, 73, 49}, - { 69, 60, 45}, - { 58, 62, 64}, - { 58, 64, 61}, - { 53, 31, 32}, - { 32, 54, 53}, - { 42, 43, 38}, - { 35, 36, 0}, - { 35, 0, 1}, - { 34, 35, 1}, - { 34, 1, 9}, - { 44, 40, 41}, - { 44, 41, 45}, - { 33,240, 51}, - { 63, 62, 58}, - { 63, 58, 59}, - { 45, 71, 70}, - { 76, 75, 51}, - { 76, 51, 52}, - { 86, 85, 84}, - { 86, 84, 87}, - { 89, 72, 73}, - { 89, 73, 88}, - { 91, 92, 96}, - { 91, 96, 95}, - { 72, 91, 60}, - { 72, 60, 69}, - {104,106,105}, - {119,105,117}, - {119,117,118}, - {124,127,128}, - {117,116,129}, - {117,129,131}, - {118,117,131}, - {135,140,142}, - {146,150,152}, - {146,152,145}, - {149,122,121}, - {166,165,151}, - {166,151,156}, - {158,172,173}, - {161,160,189}, - {199,198,193}, - {199,193,191}, - {204,201,202}, - {178,174,194}, - {200,159,186}, - {109, 48, 67}, - { 48,107,104}, - {216, 32,236}, - {216,236,239}, - {223,214, 81}, - {223, 81, 82}, - { 33, 12, 15}, - { 32,228,234}, - { 32,234,236}, - {240, 31, 52}, - {256,255,246}, - {256,246,249}, - {258,263,248}, - {258,248,249}, - {275,260,259}, - {275,259,276}, - {207,276,259}, - {270,271,429}, - {270,429,407}, - {413,418,366}, - {413,366,365}, - {368,367,279}, - {368,279,280}, - {303,301,286}, - {303,286,287}, - {283,282,292}, - {283,292,291}, - {320,292,189}, - {298,296,297}, - {298,297,299}, - {318,327,326}, - {318,326,313}, - {329,330,317}, - {336,333,320}, - {326,354,353}, - {334,332,333}, - {334,333,336}, - {342,339,139}, - {342,139,138}, - {345,342,126}, - {347,357,356}, - {369,368,351}, - {363,356,357}, - {363,357,361}, - {366,367,368}, - {366,368,369}, - {375,373,400}, - { 92, 90,377}, - {409,387,408}, - {386,385,387}, - {386,387,388}, - {412,394,391}, - {396,398,399}, - {408,406,405}, - {415,421,419}, - {415,419,414}, - {425,452,448}, - {425,448,424}, - {444,441,443}, - {448,452,449}, - {448,449,447}, - {446,444,443}, - {446,443,445}, - {250,247,261}, - {250,261,428}, - {421,422,423}, - {421,423,419}, - {427,410,250}, - {417,403,401}, - {403,402,401}, - {420,392,412}, - {420,412,425}, - {420,425,424}, - {386,411,389}, - {383,382,381}, - {383,381,385}, - {378,379,404}, - {372,371,395}, - {372,395,397}, - {371,372,370}, - {361,359,360}, - {361,360,362}, - {368,350,351}, - {349,347,348}, - {356,355,344}, - {356,344,346}, - {344,341,340}, - {344,340,343}, - {338,337,336}, - {328,335,341}, - {324,352,351}, - {324,351,331}, - {320,144,336}, - {314,325,324}, - {322,308,309}, - {310,309,307}, - {287,286,289}, - {203,280,279}, - {203,279,205}, - {297,295,283}, - {297,283,284}, - {447,205,279}, - {274,384, 80}, - {274, 80,226}, - {266,267,379}, - {266,379,380}, - {225,257,246}, - {225,246,245}, - {256,254,253}, - {256,253,255}, - {430,247,250}, - {226,235,244}, - {226,244,245}, - {232,233,244}, - {232,244,241}, - {230, 18, 19}, - { 32, 31,228}, - {219,220, 86}, - {219, 86, 57}, - {226,213,235}, - {206, 7, 6}, - {122,201,101}, - {201,204,101}, - {180,196,197}, - {170,192,171}, - {200,190,189}, - {194,193,195}, - {183,181,180}, - {183,180,182}, - {155,154,168}, - {149,156,151}, - {149,151,148}, - {155,156,120}, - {145,142,143}, - {145,143,146}, - {136,137,140}, - {133,132,130}, - {128,129,116}, - {100,120,121}, - {110,112,113}, - {110,113,114}, - { 66, 65, 63}, - { 66, 63, 99}, - { 66, 99, 98}, - { 96, 46, 61}, - { 89, 88, 90}, - { 86, 87, 57}, - { 80, 78, 81}, - { 72, 69, 49}, - { 67, 48, 47}, - { 67, 47, 68}, - { 56, 55, 53}, - { 50, 49, 36}, - { 50, 36, 35}, - { 40, 39, 41}, - {242,243,229}, - {242,229,227}, - { 6, 37, 39}, - { 42, 47, 48}, - { 42, 48, 43}, - { 61, 46, 44}, - { 45, 70, 69}, - { 69, 70, 71}, - { 69, 71, 49}, - { 74, 78, 77}, - { 83, 84, 85}, - { 73, 74, 77}, - { 93, 96, 92}, - { 68, 46, 93}, - { 95, 99, 63}, - { 95, 63, 59}, - {115,108,110}, - {115,110,114}, - {125,126,127}, - {129,130,132}, - {137,133,138}, - {137,138,139}, - {148,146,143}, - {148,143,147}, - {119,118,154}, - {161,147,143}, - {165,164,151}, - {158,157,171}, - {158,171,172}, - {159,158,187}, - {159,187,186}, - {194,192,191}, - {194,191,193}, - {189,202,201}, - {182,197,184}, - {205, 8, 7}, - { 48,109,107}, - {218,219, 57}, - {218, 57, 56}, - {207,231,211}, - {232,230,231}, - {232,231,233}, - { 53, 52, 31}, - {388,411,386}, - {409,430,250}, - {262,429,254}, - {262,254,256}, - {442,444,428}, - {273,264,383}, - {273,383,384}, - {429,271,251}, - {429,251,254}, - {413,365,362}, - { 67,413,360}, - {282,283,295}, - {285,301,299}, - {202,281,280}, - {284,283,291}, - {284,291,289}, - {320,189,160}, - {308,306,307}, - {307,309,308}, - {319,317,330}, - {319,330,328}, - {353,352,324}, - {332,331,333}, - {340,341,338}, - {354,341,344}, - {349,358,357}, - {349,357,347}, - {364,355,356}, - {364,356,363}, - {364,365,366}, - {364,366,369}, - {374,376,402}, - {375, 92,373}, - { 77,389,390}, - {382,380,381}, - {389, 77,386}, - {393,394,412}, - {393,412,392}, - {401,394,416}, - {415,400,403}, - {411,410,427}, - {411,427,426}, - {422,420,424}, - {247,248,263}, - {247,263,261}, - {445,443, 14}, - {445, 14, 11}, - {449,450, 4}, - {449, 4, 5}, - {443,441, 17}, - {443, 17, 14}, - {436, 23, 17}, - {436, 17,441}, - {424,448,422}, - {448,423,422}, - {414,419,418}, - {414,418,413}, - {406,404,405}, - {399,397,395}, - {399,395,396}, - {420,416,392}, - {388,410,411}, - {386,384,383}, - {390, 88, 77}, - {375, 94, 92}, - {415,414, 68}, - {415, 68, 94}, - {370,374,402}, - {370,402,398}, - {361,357,358}, - {361,358,359}, - {125,348,126}, - {346,344,343}, - {340,338,339}, - {337,335,334}, - {337,334,336}, - {325,353,324}, - {324,331,332}, - {324,332,329}, - {323,322,309}, - {323,309,310}, - {294,295,297}, - {294,297,296}, - {289,286,285}, - {202,280,203}, - {288,307,303}, - {282,295,321}, - { 67,360,111}, - {418,423,367}, - {418,367,366}, - {272,252,251}, - {272,251,271}, - {272,271,270}, - {255,253,274}, - {265,266,380}, - {265,380,382}, - {442,428,261}, - {440,263,258}, - {440,258,260}, - {409,250,410}, - {255,226,245}, - {255,245,246}, - { 31,240,243}, - {236,234,235}, - {236,235,237}, - {233,225,245}, - {233,245,244}, - {220,221, 85}, - {220, 85, 86}, - { 81,213,226}, - { 81,226, 80}, - { 7,206,205}, - {186,184,198}, - {186,198,199}, - {204,203,205}, - {204,205,206}, - {195,193,196}, - {171,174,172}, - {173,174,175}, - {173,172,174}, - {155,167,166}, - {160,161,143}, - {160,143,144}, - {119,154,155}, - {148,151,150}, - {148,150,146}, - {140,137,139}, - {140,139,141}, - {127,126,130}, - {114,124,128}, - {114,128,115}, - {117,105,106}, - {117,106,116}, - {104,105,100}, - {104,100,103}, - { 59, 60, 91}, - { 97, 96, 61}, - { 97, 61, 64}, - { 91, 72, 89}, - { 87, 84, 79}, - { 87, 79, 76}, - { 78, 80, 77}, - { 49, 50, 74}, - { 60, 44, 45}, - { 61, 44, 58}, - { 51, 50, 35}, - { 51, 35, 34}, - { 39, 37, 41}, - { 33, 34, 9}, - { 33, 9, 12}, - { 0, 36, 37}, - { 0, 37, 6}, - { 40, 46, 47}, - { 40, 47, 42}, - { 53, 54, 56}, - { 65, 62, 63}, - { 72, 49, 73}, - { 79, 78, 75}, - { 79, 75, 76}, - { 52, 53, 76}, - { 92, 89, 90}, - { 96, 93, 46}, - {102,103,100}, - {102,100,101}, - {116,106,108}, - {116,108,115}, - {123,125,124}, - {116,115,128}, - {118,131,135}, - {140,135,136}, - {148,147,149}, - {120,119,155}, - {164,162,152}, - {164,152,150}, - {157,147,161}, - {157,161,170}, - {186,187,185}, - {186,185,184}, - {193,197,196}, - {202,203,204}, - {194,195,178}, - {198,184,197}, - { 67,111,109}, - { 38, 43,103}, - { 38,103,102}, - {214,223,222}, - {214,222,221}, - {214,221,220}, - {214,220,219}, - {214,219,218}, - {213,237,235}, - {221,222, 83}, - {221, 83, 85}, - { 15,229, 33}, - {227, 18,230}, - {227,230,232}, - { 52, 51,240}, - { 75, 78, 50}, - {408,430,409}, - {260,258,257}, - {260,257,259}, - {224,207,259}, - {268,269,405}, - {268,405,404}, - {413,362,360}, - {447, 8,205}, - {299,297,285}, - {189,281,202}, - {290,288,289}, - {290,289,291}, - {322,321,295}, - {322,295,294}, - {333,323,311}, - {333,311,320}, - {317,316,329}, - {320,160,144}, - {353,325,326}, - {329,332,334}, - {329,334,330}, - {339,338,141}, - {339,141,139}, - {348,345,126}, - {347,356,346}, - {123,349,125}, - {364,353,354}, - {364,354,355}, - {365,364,363}, - {376,391,394}, - {376,394,401}, - { 92,376,374}, - { 92,374,373}, - {377, 90, 88}, - {380,379,378}, - {380,378,381}, - {388,387,409}, - {388,409,410}, - {416,393,392}, - {399,398,402}, - {399,402,403}, - {250,428,427}, - {421,417,416}, - {421,416,420}, - {426,427,446}, - {426,446,451}, - {444,442,441}, - {452,451,450}, - {452,450,449} -}; - - -//***************************THE END OF FAMOUS BUNNY TRIMESH********************************************// - -//****GLOBALS - -//****GLOBALS - -///User can override this material combiner by implementing gContactAddedCallback and setting body0->m_collisionFlags |= btCollisionObject::customMaterialCallback; -inline btScalar calculateCombinedFriction(float friction0,float friction1) -{ - btScalar friction = friction0 * friction1; - - const btScalar MAX_FRICTION = 10.f; - if (friction < -MAX_FRICTION) - friction = -MAX_FRICTION; - if (friction > MAX_FRICTION) - friction = MAX_FRICTION; - return friction; - -} - -inline btScalar calculateCombinedRestitution(float restitution0,float restitution1) -{ - return restitution0 * restitution1; -} - - - -bool CustomMaterialCombinerCallback(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) -{ - - float friction0 = colObj0Wrap->getCollisionObject()->getFriction(); - float friction1 = colObj1Wrap->getCollisionObject()->getFriction(); - float restitution0 = colObj0Wrap->getCollisionObject()->getRestitution(); - float restitution1 = colObj1Wrap->getCollisionObject()->getRestitution(); - - if (colObj0Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK) - { - friction0 = 1.0;//partId0,index0 - restitution0 = 0.f; - } - if (colObj1Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK) - { - if (index1&1) - { - friction1 = 1.0f;//partId1,index1 - } else - { - friction1 = 0.f; - } - restitution1 = 0.f; - } - - cp.m_combinedFriction = calculateCombinedFriction(friction0,friction1); - cp.m_combinedRestitution = calculateCombinedRestitution(restitution0,restitution1); - - //this return value is currently ignored, but to be on the safe side: return false if you don't calculate friction - return true; -} - -extern ContactAddedCallback gContactAddedCallback; - - - -int main(int argc,char** argv) -{ - gContactAddedCallback = CustomMaterialCombinerCallback; - - ConcaveDemo* concaveDemo = new ConcaveDemo(); - concaveDemo->initPhysics(); - concaveDemo->setCameraDistance(30.f); -//cannot run stepFront yet, the OpenGL context is not opened (stepFront updates camera...) -// concaveDemo->stepFront(); -// concaveDemo->stepFront(); -// concaveDemo->stepFront(); -// concaveDemo->stepFront(); - - return glutmain(argc, argv,640,480,"Moving Concave Mesh Demo",concaveDemo); -} - -void ConcaveDemo::renderme() -{ - updateCamera(); - - btScalar m[16]; - - if (m_dynamicsWorld) - { - btVector3 worldBoundsMin,worldBoundsMax; - getDynamicsWorld()->getBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax); - - - int numObjects = m_dynamicsWorld->getNumCollisionObjects(); - btVector3 wireColor(1,0,0); - for (int i=0;igetCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(colObj); - - if (body && body->getMotionState()) - { - btDefaultMotionState* myMotionState = (btDefaultMotionState*)body->getMotionState(); - myMotionState->m_graphicsWorldTrans.getOpenGLMatrix(m); - } else - { - colObj->getWorldTransform().getOpenGLMatrix(m); - } - - btVector3 wireColor(1.f,1.0f,0.5f); //wants deactivation - if (i & 1) - { - wireColor = btVector3(0.f,0.0f,1.f); - } - ///color differently for active, sleeping, wantsdeactivation states - if (colObj->getActivationState() == 1) //active - { - if (i & 1) - { - wireColor += btVector3 (1.f,0.f,0.f); - } else - { - wireColor += btVector3 (.5f,0.f,0.f); - } - } - if (colObj->getActivationState() == 2) //ISLAND_SLEEPING - { - if (i & 1) - { - wireColor += btVector3 (0.f,1.f, 0.f); - } else - { - wireColor += btVector3 (0.f,0.5f,0.f); - } - } - - m_shapeDrawer->drawOpenGL(m,colObj->getCollisionShape(),wireColor,getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - - float xOffset = 10.f; - float yStart = 20.f; - float yIncr = 20.f; - char buf[124]; - - glColor3f(0, 0, 0); - - setOrthographicProjection(); - - sprintf(buf,"mouse to interact"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - /* glRasterPos3f(xOffset,xOffset,0); - sprintf(buf,"space to reset"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - */ - - sprintf(buf,"cursor keys and z,x to navigate"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - - sprintf(buf,"i to toggle simulation, s single step"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - - sprintf(buf,"q to quit"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - - sprintf(buf,". to shoot TRIMESH (dot)"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - // not yet hooked up again after refactoring... - -/* glRasterPos3f(xOffset,xOffset,0); - sprintf(buf,"d to toggle deactivation"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; -*/ - - /* - glRasterPos3f(xOffset,xOffset,0); - sprintf(buf,"a to draw temporal AABBs"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - */ - - - sprintf(buf,"h to toggle help text"); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - //bool useBulletLCP = !(getDebugMode() & btIDebugDraw::DBG_DisableBulletLCP); - - bool useCCD = ((getDebugMode() & btIDebugDraw::DBG_EnableCCD) != 0); - - - sprintf(buf,"1 CCD mode (adhoc) = %i",useCCD); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - - sprintf(buf,"+- shooting speed = %10.2f",m_ShootBoxInitialSpeed); - GLDebugDrawString(xOffset,xOffset,buf); - xOffset += yIncr; - - resetPerspectiveProjection(); - - - } - -} - - - -void ConcaveDemo::initGImpactCollision() -{ - // create trimesh - btTriangleIndexVertexArray* indexVertexArrays = new btTriangleIndexVertexArray(NUM_TRIANGLES, - &gIndices[0][0], - 3*sizeof(int), - NUM_VERTICES,(REAL*) &gVertices[0],sizeof(REAL)*3); - - btGImpactMeshShape * trimesh = new btGImpactMeshShape(indexVertexArrays); - trimesh->setLocalScaling(btVector3(4.f,4.f,4.f)); - trimesh->updateBound(); - m_trimeshShape = trimesh; - - //register algorithm - - btCollisionDispatcher * dispatcher = static_cast(m_dynamicsWorld ->getDispatcher()); - btGImpactCollisionAlgorithm::registerAlgorithm(dispatcher); - -} - -void ConcaveDemo::initPhysics() -{ - - btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration(); - - //btConstraintSolver* solver = new btSequentialImpulseConstraintSolver; - btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collisionConfiguration); - //btOverlappingPairCache* broadphase = new btSimpleBroadphase(); - btBroadphaseInterface* broadphase = new btSimpleBroadphase(); - - btConstraintSolver* constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(dispatcher,broadphase,constraintSolver,collisionConfiguration); - - - //create trimesh model and shape - initGImpactCollision(); - - - - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - - btCollisionShape* staticboxShape1 = new btBoxShape(btVector3(200,1,200));//floor - btCollisionShape* staticboxShape2 = new btBoxShape(btVector3(1,50,200));//left wall - btCollisionShape* staticboxShape3 = new btBoxShape(btVector3(1,50,200));//right wall - btCollisionShape* staticboxShape4 = new btBoxShape(btVector3(200,50,1));//front wall - btCollisionShape* staticboxShape5 = new btBoxShape(btVector3(200,50,1));//back wall - - btCompoundShape* staticScenario = new btCompoundShape();//static scenario - - startTransform.setOrigin(btVector3(0,0,0)); - staticScenario->addChildShape(startTransform,staticboxShape1); - startTransform.setOrigin(btVector3(-200,25,0)); - staticScenario->addChildShape(startTransform,staticboxShape2); - startTransform.setOrigin(btVector3(200,25,0)); - staticScenario->addChildShape(startTransform,staticboxShape3); - startTransform.setOrigin(btVector3(0,25,200)); - staticScenario->addChildShape(startTransform,staticboxShape4); - startTransform.setOrigin(btVector3(0,25,-200)); - staticScenario->addChildShape(startTransform,staticboxShape5); - - startTransform.setOrigin(btVector3(0,0,0)); - - btRigidBody* staticBody = localCreateRigidBody(mass, startTransform,staticScenario); - - staticBody->setCollisionFlags(staticBody->getCollisionFlags()|btCollisionObject::CF_STATIC_OBJECT); - - //enable custom material callback - staticBody->setCollisionFlags(staticBody->getCollisionFlags()|btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - - //static plane - btVector3 normal(0.4,1.5,-0.4); - normal.normalize(); - btCollisionShape* staticplaneShape6 = new btStaticPlaneShape(normal,0.0);// A plane - - startTransform.setOrigin(btVector3(0,0,0)); - - btRigidBody* staticBody2 = localCreateRigidBody(mass, startTransform,staticplaneShape6 ); - - staticBody2->setCollisionFlags(staticBody2->getCollisionFlags()|btCollisionObject::CF_STATIC_OBJECT); - - { - for (int i=0;i<9;i++) - { - btCollisionShape* boxShape = new btBoxShape(btVector3(1,1,1)); - startTransform.setOrigin(btVector3(2*i-5,2,-3)); - localCreateRigidBody(1, startTransform,boxShape); - } - } - - shootTrimesh(btVector3(0,10,0),btVector3(0,0,0)); - - shootTrimesh(btVector3(0,20,0),btVector3(0,10,0)); - - //m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - -} - -void ConcaveDemo::keyboardCallback(unsigned char key, int x, int y) -{ - m_lastKey = 0; - - switch (key) - { - case 'q' : exit(0); break; - - case 'l' : stepLeft(); break; - case 'r' : stepRight(); break; - case 'f' : stepFront(); break; - case 'b' : stepBack(); break; - case 'z' : zoomIn(); break; - case 'x' : zoomOut(); break; - case 'i' : toggleIdle(); break; - case 'h': - if (m_debugMode & btIDebugDraw::DBG_NoHelpText) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_NoHelpText); - else - m_debugMode |= btIDebugDraw::DBG_NoHelpText; - break; - - case 'w': - if (m_debugMode & btIDebugDraw::DBG_DrawWireframe) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawWireframe); - else - m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - break; - - case 'p': - if (m_debugMode & btIDebugDraw::DBG_ProfileTimings) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_ProfileTimings); - else - m_debugMode |= btIDebugDraw::DBG_ProfileTimings; - break; - - case 'm': - if (m_debugMode & btIDebugDraw::DBG_EnableSatComparison) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_EnableSatComparison); - else - m_debugMode |= btIDebugDraw::DBG_EnableSatComparison; - break; - - case 'n': - if (m_debugMode & btIDebugDraw::DBG_DisableBulletLCP) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DisableBulletLCP); - else - m_debugMode |= btIDebugDraw::DBG_DisableBulletLCP; - break; - - case 't' : - if (m_debugMode & btIDebugDraw::DBG_DrawText) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawText); - else - m_debugMode |= btIDebugDraw::DBG_DrawText; - break; - case 'y': - if (m_debugMode & btIDebugDraw::DBG_DrawFeaturesText) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawFeaturesText); - else - m_debugMode |= btIDebugDraw::DBG_DrawFeaturesText; - break; - case 'a': - if (m_debugMode & btIDebugDraw::DBG_DrawAabb) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawAabb); - else - m_debugMode |= btIDebugDraw::DBG_DrawAabb; - break; - case 'c' : - if (m_debugMode & btIDebugDraw::DBG_DrawContactPoints) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawContactPoints); - else - m_debugMode |= btIDebugDraw::DBG_DrawContactPoints; - break; - - case 'd' : - if (m_debugMode & btIDebugDraw::DBG_NoDeactivation) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_NoDeactivation); - else - m_debugMode |= btIDebugDraw::DBG_NoDeactivation; - if (m_debugMode | btIDebugDraw::DBG_NoDeactivation) - { - gDisableDeactivation = true; - } else - { - gDisableDeactivation = false; - } - break; - - - - - case 'o' : - { - m_stepping = !m_stepping; - break; - } - case 's' : clientMoveAndDisplay(); break; -// case ' ' : newRandom(); break; - case ' ': - clientResetScene(); - break; - case '1': - { - if (m_debugMode & btIDebugDraw::DBG_EnableCCD) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_EnableCCD); - else - m_debugMode |= btIDebugDraw::DBG_EnableCCD; - break; - } - - case '.': - { - shootTrimesh(getCameraPosition(),getCameraTargetPosition()); - break; - } - - case '+': - { - m_ShootBoxInitialSpeed += 10.f; - break; - } - case '-': - { - m_ShootBoxInitialSpeed -= 10.f; - break; - } - - default: -// std::cout << "unused key : " << key << std::endl; - break; - } - - if (getDynamicsWorld() && getDynamicsWorld()->getDebugDrawer()) - getDynamicsWorld()->getDebugDrawer()->setDebugMode(m_debugMode); - - glutPostRedisplay(); - -} - - -void ConcaveDemo::shootTrimesh(const btVector3& startPosition,const btVector3& destination) -{ - - if (m_dynamicsWorld) - { - float mass = 4.f; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(startPosition); - - btRigidBody* body = this->localCreateRigidBody(mass, startTransform,m_trimeshShape); - - btVector3 linVel(destination[0]-startPosition[0],destination[1]-startPosition[1],destination[2]-startPosition[2]); - linVel.normalize(); - linVel*=m_ShootBoxInitialSpeed*0.25; - - body->getWorldTransform().setOrigin(startPosition); - body->getWorldTransform().setRotation(btQuaternion(0,0,0,1)); - body->setLinearVelocity(linVel); - body->setAngularVelocity(btVector3(0,0,0)); - } -} - -void ConcaveDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = float(getDeltaTimeMicroseconds()) * 0.000001f; - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - glutSwapBuffers(); - -} - - - - -void ConcaveDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - glutSwapBuffers(); -} - - diff --git a/Demos/MultiMaterialDemo/CMakeLists.txt b/Demos/MultiMaterialDemo/CMakeLists.txt deleted file mode 100644 index 0acf2c1e1..000000000 --- a/Demos/MultiMaterialDemo/CMakeLists.txt +++ /dev/null @@ -1,33 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppMultiMaterialDemo - MultiMaterialDemo.cpp - main.cpp -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppMultiMaterialDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppMultiMaterialDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppMultiMaterialDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/MultiMaterialDemo/MultiMaterialDemo.cpp b/Demos/MultiMaterialDemo/MultiMaterialDemo.cpp deleted file mode 100644 index 14e961982..000000000 --- a/Demos/MultiMaterialDemo/MultiMaterialDemo.cpp +++ /dev/null @@ -1,383 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" -#include "GLDebugDrawer.h" -#include "MultiMaterialDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -#include "BulletCollision/CollisionShapes/btTriangleShape.h" -#include "BulletCollision/CollisionShapes/btTriangleIndexVertexMaterialArray.h" -#include "BulletCollision/CollisionShapes/btMultimaterialTriangleMeshShape.h" -#include "BulletCollision/CollisionShapes/btMaterial.h" -#include "BulletCollision/CollisionDispatch/btCollisionObjectWrapper.h" - -// Create a custom material, just because we can -class CustomMaterial : public btMaterial -{ -public: - int foo1; - int foo2; - CustomMaterial(){} - CustomMaterial(int a, int b) {foo1 = a; foo2 = b;} -}; - -// Storage for the vertex data -static btVector3* gVertices = 0; -// Storage for the face data -static int* gIndices = 0; -// Storage for the material data -static CustomMaterial* gMaterials = 0; -// Storage for the face -> material index data -static int* gFaceMaterialIndices = 0; - -static btBvhTriangleMeshShape* trimeshShape =0; -static btRigidBody* staticBody = 0; -static float waveheight = 0.f; - -const float TRIANGLE_SIZE=1.f; - - -///User can override this material combiner by implementing gContactAddedCallback and setting body0->m_collisionFlags |= btCollisionObject::customMaterialCallback; -inline btScalar calculateCombinedFriction(float friction0,float friction1) -{ - btScalar friction = friction0 * friction1; - - const btScalar MAX_FRICTION = 10.f; - if (friction < -MAX_FRICTION) - friction = -MAX_FRICTION; - if (friction > MAX_FRICTION) - friction = MAX_FRICTION; - return friction; - -} - -inline btScalar calculateCombinedRestitution(float restitution0,float restitution1) -{ - return restitution0 * restitution1; -} - - - -static bool CustomMaterialCombinerCallback(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1) -{ - - // Apply material properties - if (colObj0Wrap->getCollisionShape()->getShapeType() == TRIANGLE_SHAPE_PROXYTYPE) - { - const btCollisionShape* parent0 = colObj0Wrap->getCollisionObject()->getCollisionShape(); - if(parent0 != 0 && parent0->getShapeType() == MULTIMATERIAL_TRIANGLE_MESH_PROXYTYPE) - { - btMultimaterialTriangleMeshShape* shape = (btMultimaterialTriangleMeshShape*)parent0; - const btMaterial * props = shape->getMaterialProperties(partId0, index0); - cp.m_combinedFriction = calculateCombinedFriction(props->m_friction, colObj1Wrap->getCollisionObject()->getFriction()); - cp.m_combinedRestitution = props->m_restitution * colObj1Wrap->getCollisionObject()->getRestitution(); - } - } - else if (colObj1Wrap->getCollisionShape()->getShapeType() == TRIANGLE_SHAPE_PROXYTYPE) - { - const btCollisionShape* parent1 = colObj1Wrap->getCollisionObject()->getCollisionShape(); - if(parent1 != 0 && parent1->getShapeType() == MULTIMATERIAL_TRIANGLE_MESH_PROXYTYPE) - { - btMultimaterialTriangleMeshShape* shape = (btMultimaterialTriangleMeshShape*)parent1; - const btMaterial * props = shape->getMaterialProperties(partId1, index1); - cp.m_combinedFriction = calculateCombinedFriction(props->m_friction, colObj0Wrap->getCollisionObject()->getFriction()); - cp.m_combinedRestitution = props->m_restitution * colObj0Wrap->getCollisionObject()->getRestitution(); - } - } - - //this return value is currently ignored, but to be on the safe side: return false if you don't calculate friction - return true; -} - -extern ContactAddedCallback gContactAddedCallback; - -const int NUM_VERTS_X = 20; -const int NUM_VERTS_Y = 50; -const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - -void MultiMaterialDemo::setVertexPositions(float waveheight, float offset) -{ - int i; - int j; - - for ( i=0;isetCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->setActivationState(DISABLE_DEACTIVATION); - } else - { - staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT); - staticBody->forceActivationState(ACTIVE_TAG); - } - } - - DemoApplication::keyboardCallback(key,x,y); - -} - -void MultiMaterialDemo::initPhysics() -{ -#define TRISIZE 50.f - - gContactAddedCallback = CustomMaterialCombinerCallback; - - // The number of triangles - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - // The number of materials - const int totalMaterials = 2; - - int vertStride = sizeof(btVector3); - int indexStride = 3*sizeof(int); - // int materialStride = sizeof(CustomMaterial); - // int triangleMaterialStride = sizeof(int); - - gVertices = new btVector3[totalVerts]; - gIndices = new int[totalTriangles*3]; - gMaterials = new CustomMaterial[totalMaterials]; - gFaceMaterialIndices = new int[totalTriangles]; - - // Explicitly set up the materials. It's a small array so let's do it bit by bit. - gMaterials[0].m_friction = 0; - gMaterials[0].m_restitution = 0.9; - gMaterials[0].foo1 = 5; - gMaterials[0].foo2 = 7; - gMaterials[1].m_friction = 0.9; - gMaterials[1].m_restitution = 0.1; - gMaterials[1].foo1 = 53; - gMaterials[1].foo2 = 15; - - int i; - // Set up the vertex data - setVertexPositions(waveheight,0.f); - int index=0; - // Set up the face data - for ( i=0;imaterial index data - for(int a = 0; a < totalTriangles; a++) - { - // This will give the first half of the faces low friction and high restitution - // and the second half of the faces high friction and low restitution - if(a > totalTriangles*0.5f) - gFaceMaterialIndices[a] = 0; - else - gFaceMaterialIndices[a] = 1; - } - - // Create the array structure - m_indexVertexArrays = new btTriangleIndexVertexMaterialArray( - totalTriangles, gIndices, indexStride, - totalVerts,(btScalar*) &gVertices[0].x(),vertStride, - totalMaterials, (unsigned char *)gMaterials, sizeof(CustomMaterial), - gFaceMaterialIndices, sizeof(int)); - - bool useQuantizedAabbCompression = true; - // Create the multimaterial mesh shape - trimeshShape = new btMultimaterialTriangleMeshShape((btTriangleIndexVertexMaterialArray*)m_indexVertexArrays,useQuantizedAabbCompression); - m_collisionShapes.push_back(trimeshShape); - - btCollisionShape* groundShape = trimeshShape; - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - m_broadphase = new btAxisSweep3(worldMin,worldMax); - m_solver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,-2,0)); - - btCollisionShape* colShape = new btBoxShape(btVector3(0.5f,0.5f,0.5f)); - m_collisionShapes.push_back(colShape); - - { - for (int i=0;i<1;i++) - { - startTransform.setOrigin(btVector3(10,10,-20)); - btRigidBody* body = localCreateRigidBody(1, startTransform,colShape); - body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - body->setFriction(0.9f); - body->setGravity(btVector3(0,-20.f,0)); - body->applyCentralImpulse(btVector3(-7.7f,0,0)); - } - } - - startTransform.setIdentity(); - staticBody = localCreateRigidBody(mass, startTransform,groundShape); - - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_STATIC_OBJECT); - - //enable custom material callback - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); -} - -void MultiMaterialDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_animatedMesh) - { - static float offset=0.f; - offset+=0.01f; - - // setVertexPositions(waveheight,offset); - - int i; - int j; - btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT); - btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT); - - for ( i=NUM_VERTS_X/2-3;ipartialRefitTree(aabbMin,aabbMax); - - //clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation. - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - } - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - glutSwapBuffers(); - -} - - - - -void MultiMaterialDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - glFlush(); - glutSwapBuffers(); -} - - - -void MultiMaterialDemo::exitPhysics() -{ - - - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btTriangleIndexVertexArray* m_indexVertexArrays; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - bool m_animatedMesh; - - public: - - MultiMaterialDemo() : m_animatedMesh(true) - { - - } - void initPhysics(); - - void exitPhysics(); - - virtual ~MultiMaterialDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - //to show refit works - void setVertexPositions(float waveheight, float offset); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - MultiMaterialDemo* demo = new MultiMaterialDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - }; -}; - -#endif //CONCAVE_DEMO_H - diff --git a/Demos/MultiMaterialDemo/main.cpp b/Demos/MultiMaterialDemo/main.cpp deleted file mode 100644 index 9b8d35bd9..000000000 --- a/Demos/MultiMaterialDemo/main.cpp +++ /dev/null @@ -1,22 +0,0 @@ - -#include "MultiMaterialDemo.h" -#include "GlutStuff.h" - -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - MultiMaterialDemo* multiMaterialDemo = new MultiMaterialDemo(); - multiMaterialDemo->initPhysics(); - multiMaterialDemo->setCameraDistance(30.f); - - multiMaterialDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - return glutmain(argc, argv,640,480,"Multimaterial Mesh Demo",multiMaterialDemo); -} - diff --git a/Demos/MultiThreadedDemo/CMakeLists.txt b/Demos/MultiThreadedDemo/CMakeLists.txt deleted file mode 100644 index 0a4ac250a..000000000 --- a/Demos/MultiThreadedDemo/CMakeLists.txt +++ /dev/null @@ -1,42 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${VECTOR_MATH_INCLUDE} -) - -IF(WIN32) - ADD_DEFINITIONS(-DGLEW_STATIC) -ENDIF(WIN32) - -LINK_LIBRARIES( -OpenGLSupport BulletMultiThreaded BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppMultiThreadedDemo - main.cpp - MultiThreadedDemo.cpp - MultiThreadedDemo.h -) -IF (UNIX) - TARGET_LINK_LIBRARIES(AppMultiThreadedDemo pthread) -ENDIF(UNIX) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppMultiThreadedDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppMultiThreadedDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppMultiThreadedDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/MultiThreadedDemo/Makefile.am b/Demos/MultiThreadedDemo/Makefile.am deleted file mode 100644 index 71d8dd3ca..000000000 --- a/Demos/MultiThreadedDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=MultiThreadedDemo - -MultiThreadedDemo_SOURCES=MultiThreadedDemo.cpp MultiThreadedDemo.h main.cpp -MultiThreadedDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL -I@top_builddir@/Extras $(CXXFLAGS) -MultiThreadedDemo_LDADD=-L../OpenGL -L../../Extras -L../../src -lbulletmultithreaded -lbulletopenglsupport -lbulletdynamics -lbulletcollision -lbulletmath @opengl_LIBS@ -lpthread diff --git a/Demos/MultiThreadedDemo/MultiThreadedDemo.cpp b/Demos/MultiThreadedDemo/MultiThreadedDemo.cpp deleted file mode 100644 index 5d4d3a1a1..000000000 --- a/Demos/MultiThreadedDemo/MultiThreadedDemo.cpp +++ /dev/null @@ -1,505 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#define USE_PARALLEL_SOLVER 1 //experimental parallel solver -#define USE_PARALLEL_DISPATCHER 1 - -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/CollisionDispatch/btSphereSphereCollisionAlgorithm.h" -#include "BulletCollision/CollisionDispatch/btSphereTriangleCollisionAlgorithm.h" -#include "BulletCollision/CollisionDispatch/btSimulationIslandManager.h" - -#ifdef USE_PARALLEL_DISPATCHER -#include "BulletMultiThreaded/SpuGatheringCollisionDispatcher.h" -#include "BulletMultiThreaded/PlatformDefinitions.h" - -#ifdef USE_LIBSPE2 -#include "BulletMultiThreaded/SpuLibspe2Support.h" -#elif defined (_WIN32) -#include "BulletMultiThreaded/Win32ThreadSupport.h" -#include "BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" - -#elif defined (USE_PTHREADS) - -#include "BulletMultiThreaded/PosixThreadSupport.h" -#include "BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" - -#else -//other platforms run the parallel code sequentially (until pthread support or other parallel implementation is added) - -#include "BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h" -#endif //USE_LIBSPE2 - -#ifdef USE_PARALLEL_SOLVER -#include "BulletMultiThreaded/btParallelConstraintSolver.h" -#include "BulletMultiThreaded/SequentialThreadSupport.h" - - -btThreadSupportInterface* createSolverThreadSupport(int maxNumThreads) -{ -//#define SEQUENTIAL -#ifdef SEQUENTIAL - SequentialThreadSupport::SequentialThreadConstructionInfo tci("solverThreads",SolverThreadFunc,SolverlsMemoryFunc); - SequentialThreadSupport* threadSupport = new SequentialThreadSupport(tci); - threadSupport->startSPU(); -#else - -#ifdef _WIN32 - Win32ThreadSupport::Win32ThreadConstructionInfo threadConstructionInfo("solverThreads",SolverThreadFunc,SolverlsMemoryFunc,maxNumThreads); - Win32ThreadSupport* threadSupport = new Win32ThreadSupport(threadConstructionInfo); - threadSupport->startSPU(); -#elif defined (USE_PTHREADS) - PosixThreadSupport::ThreadConstructionInfo solverConstructionInfo("solver", SolverThreadFunc, - SolverlsMemoryFunc, maxNumThreads); - - PosixThreadSupport* threadSupport = new PosixThreadSupport(solverConstructionInfo); - -#else - SequentialThreadSupport::SequentialThreadConstructionInfo tci("solverThreads",SolverThreadFunc,SolverlsMemoryFunc); - SequentialThreadSupport* threadSupport = new SequentialThreadSupport(tci); - threadSupport->startSPU(); -#endif - -#endif - - return threadSupport; -} - -#endif //USE_PARALLEL_SOLVER - -#endif//USE_PARALLEL_DISPATCHER - - - - -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btIDebugDraw.h" - - - -#include //printf debugging - -#include "MultiThreadedDemo.h" -#include "GL_ShapeDrawer.h" - -#include "GlutStuff.h" - - -extern float eye[3]; -extern int glutScreenWidth; -extern int glutScreenHeight; - -const int maxProxies = 32766; -const int maxOverlap = 65535; - - - - -#ifdef _DEBUG -const int gNumObjects = 120; -#else -const int gNumObjects = 120;//try this in release mode: 3000. never go above 16384, unless you increate maxNumObjects value in DemoApplication.cp -#endif - - -const int maxNumObjects = 32760; - -static int shapeIndex[maxNumObjects]; - - -#define CUBE_HALF_EXTENTS 0.5 - -#define EXTRA_HEIGHT -10.f -//GL_LineSegmentShape shapeE(btVector3(-50,0,0), -// btVector3(50,0,0)); - - -void MultiThreadedDemo::createStack( btCollisionShape* boxShape, float halfCubeSize, int size, float zPos ) -{ - btTransform trans; - trans.setIdentity(); - - for(int i=0; istepSimulation(1.0f/60.f,0); - //CProfileManager::dumpAll(); - -#else - //during idle mode, just run 1 simulation step maximum - int maxSimSubSteps = m_idle ? 1 : 1; - if (m_idle) - dt = 1.0/420.f; - - int numSimSteps = 0; - numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps); - - -#ifdef VERBOSE_TIMESTEPPING_CONSOLEOUTPUT - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } -#endif //VERBOSE_TIMESTEPPING_CONSOLEOUTPUT - -#endif - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - } - -#ifdef USE_QUICKPROF - btProfiler::beginBlock("render"); -#endif //USE_QUICKPROF - - renderme(); - - - //render the graphics objects, with center of mass shift - - updateCamera(); - - - -#ifdef USE_QUICKPROF - btProfiler::endBlock("render"); -#endif - glFlush(); - - - glutSwapBuffers(); - -} - - - -void MultiThreadedDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - - renderme(); - - glFlush(); - glutSwapBuffers(); -} - - - - - -void MultiThreadedDemo::initPhysics() -{ -#ifdef USE_PARALLEL_DISPATCHER - m_threadSupportSolver = 0; - m_threadSupportCollision = 0; -#endif - -//#define USE_GROUND_PLANE 1 -#ifdef USE_GROUND_PLANE - m_collisionShapes.push_back(new btStaticPlaneShape(btVector3(0,1,0),0.5)); -#else - - ///Please don't make the box sizes larger then 1000: the collision detection will be inaccurate. - ///See http://www.continuousphysics.com/Bullet/phpBB2/viewtopic.php?t=346 - m_collisionShapes.push_back(new btBoxShape (btVector3(200,CUBE_HALF_EXTENTS,200))); -#endif - - m_collisionShapes.push_back(new btBoxShape (btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS))); - - - - setCameraDistance(32.5f); - - m_azi = 90.f; - - m_dispatcher=0; - btDefaultCollisionConstructionInfo cci; - cci.m_defaultMaxPersistentManifoldPoolSize = 32768; - m_collisionConfiguration = new btDefaultCollisionConfiguration(cci); - -#ifdef USE_PARALLEL_DISPATCHER - int maxNumOutstandingTasks = 4; - -#ifdef USE_WIN32_THREADING - -m_threadSupportCollision = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo( - "collision", - processCollisionTask, - createCollisionLocalStoreMemory, - maxNumOutstandingTasks)); -#else - -#ifdef USE_LIBSPE2 - - spe_program_handle_t * program_handle; -#ifndef USE_CESOF - program_handle = spe_image_open ("./spuCollision.elf"); - if (program_handle == NULL) - { - perror( "SPU OPEN IMAGE ERROR\n"); - } - else - { - printf( "IMAGE OPENED\n"); - } -#else - extern spe_program_handle_t spu_program; - program_handle = &spu_program; -#endif - SpuLibspe2Support* threadSupportCollision = new SpuLibspe2Support( program_handle, maxNumOutstandingTasks); -#elif defined (USE_PTHREADS) - PosixThreadSupport::ThreadConstructionInfo constructionInfo("collision", - processCollisionTask, - createCollisionLocalStoreMemory, - maxNumOutstandingTasks); - m_threadSupportCollision = new PosixThreadSupport(constructionInfo); -#else - - SequentialThreadSupport::SequentialThreadConstructionInfo colCI("collision",processCollisionTask,createCollisionLocalStoreMemory); - SequentialThreadSupport* m_threadSupportCollision = new SequentialThreadSupport(colCI); - -#endif //USE_LIBSPE2 - -///Playstation 3 SPU (SPURS) version is available through PS3 Devnet -/// For Unix/Mac someone could implement a pthreads version of btThreadSupportInterface? -///you can hook it up to your custom task scheduler by deriving from btThreadSupportInterface -#endif - - - m_dispatcher = new SpuGatheringCollisionDispatcher(m_threadSupportCollision,maxNumOutstandingTasks,m_collisionConfiguration); -// m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); -#else - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); -#endif //USE_PARALLEL_DISPATCHER - - - btVector3 worldAabbMin(-1000,-1000,-1000); - btVector3 worldAabbMax(1000,1000,1000); - - - - m_broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax,maxProxies); - - - -#ifdef USE_PARALLEL_SOLVER - m_threadSupportSolver = createSolverThreadSupport(maxNumOutstandingTasks); - m_solver = new btParallelConstraintSolver(m_threadSupportSolver); - //this solver requires the contacts to be in a contiguous pool, so avoid dynamic allocation - m_dispatcher->setDispatcherFlags(btCollisionDispatcher::CD_DISABLE_CONTACTPOOL_DYNAMIC_ALLOCATION); -#else - - btSequentialImpulseConstraintSolver* solver = new btSequentialImpulseConstraintSolver(); - m_solver = solver; - //default solverMode is SOLVER_RANDMIZE_ORDER. Warmstarting seems not to improve convergence, see - //solver->setSolverMode(0);//btSequentialImpulseConstraintSolver::SOLVER_USE_WARMSTARTING | btSequentialImpulseConstraintSolver::SOLVER_RANDMIZE_ORDER); -#endif //USE_PARALLEL_SOLVER - - - btDiscreteDynamicsWorld* world = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld = world; - - world->getSimulationIslandManager()->setSplitIslands(false); - world->getSolverInfo().m_numIterations = 4; - world->getSolverInfo().m_solverMode = SOLVER_SIMD+SOLVER_USE_WARMSTARTING;//+SOLVER_RANDMIZE_ORDER; - - m_dynamicsWorld->getDispatchInfo().m_enableSPU = true; - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - - - int i; - - btTransform tr; - tr.setIdentity(); - - - for (i=0;i0) - { - shapeIndex[i] = 1;//sphere - } - else - shapeIndex[i] = 0; - } - - - btTransform trans; - trans.setIdentity(); - - btScalar halfExtents = CUBE_HALF_EXTENTS; - - trans.setOrigin(btVector3(0,-halfExtents,0)); - - - - localCreateRigidBody(0.f,trans,m_collisionShapes[shapeIndex[0]]); - - int numWalls = 15; - int wallHeight = 15; - float wallDistance = 3; - - - for ( i=0;isetLinearVelocity(btVector3(0,0,-10)); -#endif -// clientResetScene(); - - -} - - - - - - -void MultiThreadedDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - class btThreadSupportInterface* m_threadSupportCollision; - class btThreadSupportInterface* m_threadSupportSolver; - - btConstraintSolver* m_solver; - - btCollisionAlgorithmCreateFunc* m_boxBoxCF; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - - public: - - void initPhysics(); - - void exitPhysics(); - - virtual ~MultiThreadedDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - void createStack( btCollisionShape* boxShape, float halfCubeSize, int size, float zPos ); - - static DemoApplication* Create() - { - MultiThreadedDemo* demo = new MultiThreadedDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - -}; - -#endif //MULTI_THREADED_DEMO_H - diff --git a/Demos/MultiThreadedDemo/main.cpp b/Demos/MultiThreadedDemo/main.cpp deleted file mode 100644 index 36b56deae..000000000 --- a/Demos/MultiThreadedDemo/main.cpp +++ /dev/null @@ -1,36 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#include -#include "MultiThreadedDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - MultiThreadedDemo* demo = new MultiThreadedDemo(); - - demo->initPhysics(); - demo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - - glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",demo); - - delete demo; - - return EXIT_SUCCESS; -} diff --git a/Demos/NativeClient/bin_html/bind.js b/Demos/NativeClient/bin_html/bind.js deleted file mode 100644 index 92fbbd218..000000000 --- a/Demos/NativeClient/bin_html/bind.js +++ /dev/null @@ -1,22 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -/** - * @fileoverview This class implements an extension to Function object that - * lets you bind a scope for |this| to a function. - */ - -/** - * Bind a scope to a function. Used to bind an object to |this| for event - * handlers. - * @param {!Object} scope The scope in which the function executes. |scope| - * becomes |this| during function execution. - * @return {function} the bound version of the original function. - */ -Function.prototype.bind = function(scope) { - var boundContext = this; - return function() { - return boundContext.apply(scope, arguments); - } -} diff --git a/Demos/NativeClient/bin_html/dragger.js b/Demos/NativeClient/bin_html/dragger.js deleted file mode 100644 index 232d8b5fb..000000000 --- a/Demos/NativeClient/bin_html/dragger.js +++ /dev/null @@ -1,134 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -/** - * @fileoverview This class implements a mouse-drag event. It registers for - * mousedown events, and when it sees one, starts capturing mousemove events - * until it gets a mousup event. It manufactures three drag events: the - * DRAG_START, DRAG and DRAG_END. - */ - -// Requires bind - -/** - * Constructor for the Dragger. Register for mousedown events that happen on - * |opt_target|. If |opt_target| is null or undefined, then this object - * observes mousedown on the whole document. - * @param {?Element} opt_target The event target. Defaults to the whole - * document. - * @constructor - */ -tumbler.Dragger = function(opt_target) { - /** - * The event target. - * @type {Element} - * @private - */ - this.target_ = opt_target || document; - - /** - * The array of objects that get notified of drag events. Each object in - * this array get sent a handleStartDrag(), handleDrag() and handleEndDrag() - * message. - * @type {Array.} - * @private - */ - this.listeners_ = []; - - /** - * Flag to indicate whether the object is in a drag sequence or not. - * @type {boolean} - * @private - */ - this.isDragging_ = false; - - /** - * The function objects that get attached as event handlers. These are - * cached so that they can be removed on mouse up. - * @type {function} - * @private - */ - this.boundMouseMove_ = null; - this.boundMouseUp_ = null; - - this.target_.addEventListener('mousedown', - this.onMouseDown.bind(this), - false); -} - -/** - * The ids used for drag event types. - * @enum {string} - */ -tumbler.Dragger.DragEvents = { - DRAG_START: 'dragstart', // Start a drag sequence - DRAG: 'drag', // Mouse moved during a drag sequence. - DRAG_END: 'dragend' // End a drag sewquence. -}; - -/** - * Add a drag listener. Each listener should respond to thhree methods: - * handleStartDrag(), handleDrag() and handleEndDrag(). This method assumes - * that |listener| does not already exist in the array of listeners. - * @param {!Object} listener The object that will listen to drag events. - */ -tumbler.Dragger.prototype.addDragListener = function(listener) { - this.listeners_.push(listener); -} - -/** - * Handle a mousedown event: register for mousemove and mouseup, then tell - * the target that is has a DRAG_START event. - * @param {Event} event The mousedown event that triggered this method. - */ -tumbler.Dragger.prototype.onMouseDown = function(event) { - this.boundMouseMove_ = this.onMouseMove.bind(this); - this.boundMouseUp_ = this.onMouseUp.bind(this); - this.target_.addEventListener('mousemove', this.boundMouseMove_); - this.target_.addEventListener('mouseup', this.boundMouseUp_); - this.isDragging_ = true; - var dragStartEvent = { type: tumbler.Dragger.DragEvents.DRAG_START, - clientX: event.offsetX, - clientY: event.offsetY }; - var i; - for (i = 0; i < this.listeners_.length; ++i) { - this.listeners_[i].handleStartDrag(this.target_, dragStartEvent); - } -} - -/** - * Handle a mousemove event: tell the target that is has a DRAG event. - * @param {Event} event The mousemove event that triggered this method. - */ -tumbler.Dragger.prototype.onMouseMove = function(event) { - if (!this.isDragging_) - return; - var dragEvent = { type: tumbler.Dragger.DragEvents.DRAG, - clientX: event.offsetX, - clientY: event.offsetY}; - var i; - for (i = 0; i < this.listeners_.length; ++i) { - this.listeners_[i].handleDrag(this.target_, dragEvent); - } -} - -/** - * Handle a mouseup event: un-register for mousemove and mouseup, then tell - * the target that is has a DRAG_END event. - * @param {Event} event The mouseup event that triggered this method. - */ -tumbler.Dragger.prototype.onMouseUp = function(event) { - this.target_.removeEventListener('mouseup', this.boundMouseUp_, false); - this.target_.removeEventListener('mousemove', this.boundMouseMove_, false); - this.boundMouseUp_ = null; - this.boundMouseMove_ = null; - this.isDragging_ = false; - var dragEndEvent = { type: tumbler.Dragger.DragEvents.DRAG_END, - clientX: event.offsetX, - clientY: event.offsetY}; - var i; - for (i = 0; i < this.listeners_.length; ++i) { - this.listeners_[i].handleEndDrag(this.target_, dragEndEvent); - } -} diff --git a/Demos/NativeClient/bin_html/httpd.cmd b/Demos/NativeClient/bin_html/httpd.cmd deleted file mode 100644 index 43143fbc1..000000000 --- a/Demos/NativeClient/bin_html/httpd.cmd +++ /dev/null @@ -1,9 +0,0 @@ -@echo off -setlocal - -REM Relative path of CygWin -set CYGWIN=%~dp0%..\third_party\cygwin\bin - -PATH=%CYGWIN%;%PATH% - -python httpd.py diff --git a/Demos/NativeClient/bin_html/httpd.py b/Demos/NativeClient/bin_html/httpd.py deleted file mode 100644 index 65434a875..000000000 --- a/Demos/NativeClient/bin_html/httpd.py +++ /dev/null @@ -1,114 +0,0 @@ -#!/usr/bin/python -# -# Copyright (c) 2011, The Native Client Authors. All rights reserved. -# Use of this source code is governed by a BSD-style license that can be -# found in the LICENSE file. -# - -"""A tiny web server. - -This is intended to be used for testing, and only run from within the examples -directory. -""" - -import BaseHTTPServer -import logging -import os -import SimpleHTTPServer -import SocketServer -import sys -import urlparse - -logging.getLogger().setLevel(logging.INFO) - -# Using 'localhost' means that we only accept connections -# via the loop back interface. -SERVER_PORT = 5103 -SERVER_HOST = '' - -# We only run from the examples directory (the one that contains scons-out), so -# that not too much is exposed via this HTTP server. Everything in the -# directory is served, so there should never be anything potentially sensitive -# in the serving directory, especially if the machine might be a -# multi-user machine and not all users are trusted. We only serve via -# the loopback interface. - -SAFE_DIR_COMPONENTS = ['bin_html'] -SAFE_DIR_SUFFIX = apply(os.path.join, SAFE_DIR_COMPONENTS) - -def SanityCheckDirectory(): - if os.getcwd().endswith(SAFE_DIR_SUFFIX): - return - logging.error('httpd.py should only be run from the %s', SAFE_DIR_SUFFIX) - logging.error('directory for testing purposes.') - logging.error('We are currently in %s', os.getcwd()) - sys.exit(1) - - -# An HTTP server that will quit when |is_running| is set to False. We also use -# SocketServer.ThreadingMixIn in order to handle requests asynchronously for -# faster responses. -class QuittableHTTPServer(SocketServer.ThreadingMixIn, - BaseHTTPServer.HTTPServer): - def serve_forever(self, timeout=0.5): - self.is_running = True - self.timeout = timeout - while self.is_running: - self.handle_request() - - def shutdown(self): - self.is_running = False - return 1 - - -# "Safely" split a string at |sep| into a [key, value] pair. If |sep| does not -# exist in |str|, then the entire |str| is the key and the value is set to an -# empty string. -def KeyValuePair(str, sep='='): - if sep in str: - return str.split(sep) - else: - return [str, ''] - - -# A small handler that looks for '?quit=1' query in the path and shuts itself -# down if it finds that parameter. -class QuittableHTTPHandler(SimpleHTTPServer.SimpleHTTPRequestHandler): - def do_GET(self): - (_, _, _, query, _) = urlparse.urlsplit(self.path) - url_params = dict([KeyValuePair(key_value) - for key_value in query.split('&')]) - if 'quit' in url_params and '1' in url_params['quit']: - self.send_response(200, 'OK') - self.send_header('Content-type', 'text/html') - self.send_header('Content-length', '0') - self.end_headers() - self.server.shutdown() - return - - SimpleHTTPServer.SimpleHTTPRequestHandler.do_GET(self) - - -def Run(server_address, - server_class=QuittableHTTPServer, - handler_class=QuittableHTTPHandler): - httpd = server_class(server_address, handler_class) - logging.info("Starting local server on port %d", server_address[1]) - logging.info("To shut down send http://localhost:%d?quit=1", - server_address[1]) - try: - httpd.serve_forever() - except KeyboardInterrupt: - logging.info("Received keyboard interrupt.") - httpd.server_close() - - logging.info("Shutting down local server on port %d", server_address[1]) - - -if __name__ == '__main__': - SanityCheckDirectory() - if len(sys.argv) > 1: - Run((SERVER_HOST, int(sys.argv[1]))) - else: - Run((SERVER_HOST, SERVER_PORT)) - sys.exit(0) diff --git a/Demos/NativeClient/bin_html/index.html b/Demos/NativeClient/bin_html/index.html deleted file mode 100644 index a3002da5e..000000000 --- a/Demos/NativeClient/bin_html/index.html +++ /dev/null @@ -1,33 +0,0 @@ - - - - - Interactive Cube Example - - - - - - - - -

Interactive Cube Example

-

- The Native Client module executed in this page draws a 3D cube - and allows you to rotate it using a virtual trackball method. -

-
- - - diff --git a/Demos/NativeClient/bin_html/trackball.js b/Demos/NativeClient/bin_html/trackball.js deleted file mode 100644 index 88b9a62df..000000000 --- a/Demos/NativeClient/bin_html/trackball.js +++ /dev/null @@ -1,296 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -/** - * @fileoverview Implement a virtual trackball in the tumbler.Trackball - * class. This class maps 2D mouse events to 3D rotations by simulating a - * trackball that you roll by dragging the mouse. There are two principle - * methods in the class: startAtPointInFrame which you use to begin a trackball - * simulation and rollToPoint, which you use while dragging the mouse. The - * rollToPoint method returns a rotation expressed as a quaternion. - */ - - -// Requires tumbler.Application -// Requires tumbler.DragEvent -// Requires tumbler.Vector3 - -/** - * Constructor for the Trackball object. This class maps 2D mouse drag events - * into 3D rotations by simulating a trackball. The idea is to simulate - * clicking on the trackball, and then rolling it as you drag the mouse. - * The math behind the trackball is simple: start with a vector from the first - * mouse-click on the ball to the center of the 3D view. At the same time, set - * the radius of the ball to be the smaller dimension of the 3D view. As you - * drag the mouse around in the 3D view, a second vector is computed from the - * surface of the ball to the center. The axis of rotation is the cross - * product of these two vectors, and the angle of rotation is the angle between - * the two vectors. - * @constructor - */ -tumbler.Trackball = function() { - /** - * The square of the trackball's radius. The math never looks at the radius, - * but looks at the radius squared. - * @type {number} - * @private - */ - this.sqrRadius_ = 0; - - /** - * The 3D vector representing the point on the trackball where the mouse - * was clicked. Default is pointing stright through the center of the ball. - * @type {Object} - * @private - */ - this.rollStart_ = new tumbler.Vector3(0, 0, 1); - - /** - * The 2D center of the frame that encloses the trackball. - * @type {!Object} - * @private - */ - this.center_ = { x: 0, y: 0 }; - - /** - * Cached camera orientation. When a drag START event happens this is set to - * the current orientation in the calling view's plugin. The default is the - * identity quaternion. - * @type {Array.} - * @private - */ - this.cameraOrientation_ = [0, 0, 0, 1]; -}; - -/** - * Compute the dimensions of the virtual trackball to fit inside |frameSize|. - * The radius of the trackball is set to be 1/2 of the smaller of the two frame - * dimensions, the center point is at the midpoint of each side. - * @param {!goog.math.Size} frameSize 2D-point representing the size of the - * element that encloses the virtual trackball. - * @private - */ -tumbler.Trackball.prototype.initInFrame_ = function(frameSize) { - // Compute the radius of the virtual trackball. This is 1/2 of the smaller - // of the frame's width and height. - var halfFrameSize = 0.5 * Math.min(frameSize.width, frameSize.height); - // Cache the square of the trackball's radius. - this.sqrRadius_ = halfFrameSize * halfFrameSize; - // Figure the center of the view. - this.center_.x = frameSize.width * 0.5; - this.center_.y = frameSize.height * 0.5; -}; - -/** - * Method to convert (by translation) a 2D client point from a coordinate space - * with origin in the lower-left corner of the client view to a space with - * origin in the center of the client view. Use this method before mapping the - * 2D point to he 3D tackball point (see also the projectOnTrackball_() method). - * Call the startAtPointInFrame before calling this method so that the - * |center_| property is correctly initialized. - * @param {!Object} clientPoint map this point to the coordinate space with - * origin in thecenter of the client view. - * @return {Object} the converted point. - * @private - */ -tumbler.Trackball.prototype.convertClientPoint_ = function(clientPoint) { - var difference = { x: clientPoint.x - this.center_.x, - y: clientPoint.y - this.center_.y } - return difference; -}; - -/** - * Method to map a 2D point to a 3D point on the virtual trackball that was set - * up using the startAtPointInFrame method. If the point lies outside of the - * radius of the virtual trackball, then the z-coordinate of the 3D point - * is set to 0. - * @param {!Object.} point 2D-point in the coordinate space with origin - * in the center of the client view. - * @return {tumbler.Vector3} the 3D point on the virtual trackball. - * @private - */ -tumbler.Trackball.prototype.projectOnTrackball_ = function(point) { - var sqrRadius2D = point.x * point.x + point.y * point.y; - var zValue; - if (sqrRadius2D > this.sqrRadius_) { - // |point| lies outside the virtual trackball's sphere, so use a virtual - // z-value of 0. This is equivalent to clicking on the horizontal equator - // of the trackball. - zValue = 0; - } else { - // A sphere can be defined as: r^2 = x^2 + y^2 + z^2, so z = - // sqrt(r^2 - (x^2 + y^2)). - zValue = Math.sqrt(this.sqrRadius_ - sqrRadius2D); - } - var trackballPoint = new tumbler.Vector3(point.x, point.y, zValue); - return trackballPoint; -}; - -/** - * Method to start up the trackball. The trackball works by pretending that a - * ball encloses the 3D view. You roll this pretend ball with the mouse. For - * example, if you click on the center of the ball and move the mouse straight - * to the right, you roll the ball around its Y-axis. This produces a Y-axis - * rotation. You can click on the "edge" of the ball and roll it around - * in a circle to get a Z-axis rotation. - * @param {!Object.} startPoint 2D-point, usually the mouse-down - * point. - * @param {!Object.} frameSize 2D-point representing the size of - * the element that encloses the virtual trackball. - */ -tumbler.Trackball.prototype.startAtPointInFrame = - function(startPoint, frameSize) { - this.initInFrame_(frameSize); - // Compute the starting vector from the surface of the ball to its center. - this.rollStart_ = this.projectOnTrackball_( - this.convertClientPoint_(startPoint)); -}; - -/** - * Method to roll the virtual trackball; call this in response to a mouseDrag - * event. Takes |dragPoint| and projects it from 2D mouse coordinates onto the - * virtual track ball that was set up in startAtPointInFrame method. - * Returns a quaternion that represents the rotation from |rollStart_| to - * |rollEnd_|. - * @param {!Object.} dragPoint 2D-point representing the - * destination mouse point. - * @return {Array.} a quaternion that represents the rotation from - * the point wnere the mouse was clicked on the trackball to this point. - * The quaternion looks like this: [[v], cos(angle/2)], where [v] is the - * imaginary part of the quaternion and is computed as [x, y, z] * - * sin(angle/2). - */ -tumbler.Trackball.prototype.rollToPoint = function(dragPoint) { - var rollTo = this.convertClientPoint_(dragPoint); - if ((Math.abs(this.rollStart_.x - rollTo.x) < - tumbler.Trackball.DOUBLE_EPSILON) && - (Math.abs(this.rollStart_.y, rollTo.y) < - tumbler.Trackball.DOUBLE_EPSILON)) { - // Not enough change in the vectors to roll the ball, return the identity - // quaternion. - return [0, 0, 0, 1]; - } - - // Compute the ending vector from the surface of the ball to its center. - var rollEnd = this.projectOnTrackball_(rollTo); - - // Take the cross product of the two vectors. r = s X e - var rollVector = this.rollStart_.cross(rollEnd); - var invStartMag = 1.0 / this.rollStart_.magnitude(); - var invEndMag = 1.0 / rollEnd.magnitude(); - - // cos(a) = (s . e) / (||s|| ||e||) - var cosAng = this.rollStart_.dot(rollEnd) * invStartMag * invEndMag; - // sin(a) = ||(s X e)|| / (||s|| ||e||) - var sinAng = rollVector.magnitude() * invStartMag * invEndMag; - // Build a quaternion that represents the rotation about |rollVector|. - // Use atan2 for a better angle. If you use only cos or sin, you only get - // half the possible angles, and you can end up with rotations that flip - // around near the poles. - var rollHalfAngle = Math.atan2(sinAng, cosAng) * 0.5; - rollVector.normalize(); - // The quaternion looks like this: [[v], cos(angle/2)], where [v] is the - // imaginary part of the quaternion and is computed as [x, y, z] * - // sin(angle/2). - rollVector.scale(Math.sin(rollHalfAngle)); - var ballQuaternion = [rollVector.x, - rollVector.y, - rollVector.z, - Math.cos(rollHalfAngle)]; - return ballQuaternion; -}; - -/** - * Handle the drag START event: grab the current camera orientation from the - * sending view and set up the virtual trackball. - * @param {!tumbler.Application} view The view controller that called this - * method. - * @param {!tumbler.DragEvent} dragStartEvent The DRAG_START event that - * triggered this handler. - */ -tumbler.Trackball.prototype.handleStartDrag = - function(controller, dragStartEvent) { - // Cache the camera orientation. The orientations from the trackball as it - // rolls are concatenated to this orientation and pushed back into the - // plugin on the other side of the JavaScript bridge. - controller.setCameraOrientation(this.cameraOrientation_); - // Invert the y-coordinate for the trackball computations. - var frameSize = { width: controller.offsetWidth, - height: controller.offsetHeight }; - var flippedY = { x: dragStartEvent.clientX, - y: frameSize.height - dragStartEvent.clientY }; - this.startAtPointInFrame(flippedY, frameSize); -}; - -/** - * Handle the drag DRAG event: concatenate the current orientation to the - * cached orientation. Send this final value through to the GSPlugin via the - * setValueForKey() method. - * @param {!tumbler.Application} view The view controller that called this - * method. - * @param {!tumbler.DragEvent} dragEvent The DRAG event that triggered this - * handler. - */ -tumbler.Trackball.prototype.handleDrag = - function(controller, dragEvent) { - // Flip the y-coordinate so that the 2D origin is in the lower-left corner. - var frameSize = { width: controller.offsetWidth, - height: controller.offsetHeight }; - var flippedY = { x: dragEvent.clientX, - y: frameSize.height - dragEvent.clientY }; - controller.setCameraOrientation( - tumbler.multQuaternions(this.rollToPoint(flippedY), - this.cameraOrientation_)); -}; - -/** - * Handle the drag END event: get the final orientation and concatenate it to - * the cached orientation. - * @param {!tumbler.Application} view The view controller that called this - * method. - * @param {!tumbler.DragEvent} dragEndEvent The DRAG_END event that triggered - * this handler. - */ -tumbler.Trackball.prototype.handleEndDrag = - function(controller, dragEndEvent) { - // Flip the y-coordinate so that the 2D origin is in the lower-left corner. - var frameSize = { width: controller.offsetWidth, - height: controller.offsetHeight }; - var flippedY = { x: dragEndEvent.clientX, - y: frameSize.height - dragEndEvent.clientY }; - this.cameraOrientation_ = tumbler.multQuaternions(this.rollToPoint(flippedY), - this.cameraOrientation_); - controller.setCameraOrientation(this.cameraOrientation_); -}; - -/** - * A utility function to multiply two quaterions. Returns the product q0 * q1. - * This is effectively the same thing as concatenating the two rotations - * represented in each quaternion together. Note that quaternion multiplication - * is NOT commutative: q0 * q1 != q1 * q0. - * @param {!Array.} q0 A 4-element array representing the first - * quaternion. - * @param {!Array.} q1 A 4-element array representing the second - * quaternion. - * @return {Array.} A 4-element array representing the product q0 * q1. - */ -tumbler.multQuaternions = function(q0, q1) { - // Return q0 * q1 (note the order). - var qMult = [ - q0[3] * q1[0] + q0[0] * q1[3] + q0[1] * q1[2] - q0[2] * q1[1], - q0[3] * q1[1] - q0[0] * q1[2] + q0[1] * q1[3] + q0[2] * q1[0], - q0[3] * q1[2] + q0[0] * q1[1] - q0[1] * q1[0] + q0[2] * q1[3], - q0[3] * q1[3] - q0[0] * q1[0] - q0[1] * q1[1] - q0[2] * q1[2] - ]; - return qMult; -}; - -/** - * Real numbers that are less than this distance apart are considered - * equivalent. - * TODO(dspringer): It seems as though there should be a const like this - * in Closure somewhere (goog.math?). - * @type {number} - */ -tumbler.Trackball.DOUBLE_EPSILON = 1.0e-16; diff --git a/Demos/NativeClient/bin_html/tumbler.js b/Demos/NativeClient/bin_html/tumbler.js deleted file mode 100644 index e8e42ebdc..000000000 --- a/Demos/NativeClient/bin_html/tumbler.js +++ /dev/null @@ -1,133 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -/** - * @fileoverview The tumbler Application object. This object instantiates a - * Trackball object and connects it to the element named |tumbler_content|. - * It also conditionally embeds a debuggable module or a release module into - * the |tumbler_content| element. - */ - -// Requires tumbler -// Requires tumbler.Dragger -// Requires tumbler.Trackball - -/** - * Constructor for the Application class. Use the run() method to populate - * the object with controllers and wire up the events. - * @constructor - */ -tumbler.Application = function() { - /** - * The native module for the application. This refers to the module loaded - * via the tag. - * @type {Element} - * @private - */ - this.module_ = null; - - /** - * The trackball object. - * @type {tumbler.Trackball} - * @private - */ - this.trackball_ = null; - - /** - * The mouse-drag event object. - * @type {tumbler.Dragger} - * @private - */ - this.dragger_ = null; - - /** - * The function objects that get attached as event handlers. These are - * cached so that they can be removed when they are no longer needed. - * @type {function} - * @private - */ - this.boundModuleDidLoad_ = null; -} - -/** - * The ids used for elements in the DOM. The Tumlber Application expects these - * elements to exist. - * @enum {string} - * @private - */ -tumbler.Application.DomIds_ = { - MODULE: 'tumbler', // The element representing the NaCl module - VIEW: 'tumbler_view' // The
containing the NaCl element. -} - -/** - * Called by the module loading function once the module has been loaded. - * @param {?Element} nativeModule The instance of the native module. - */ -tumbler.Application.prototype.moduleDidLoad = function() { - this.module_ = document.getElementById(tumbler.Application.DomIds_.MODULE); - // Unbind the load function. - this.boundModuleDidLoad_ = null; - - /** - * Set the camera orientation property on the NaCl module. - * @param {Array.} orientation A 4-element array representing the - * camera orientation as a quaternion. - */ - this.module_.setCameraOrientation = function(orientation) { - var methodString = 'setCameraOrientation ' + - 'orientation:' + - JSON.stringify(orientation); - this.postMessage(methodString); - } - - this.trackball_ = new tumbler.Trackball(); - this.dragger_ = new tumbler.Dragger(this.module_); - this.dragger_.addDragListener(this.trackball_); -} - -/** - * Asserts that cond is true; issues an alert and throws an Error otherwise. - * @param {bool} cond The condition. - * @param {String} message The error message issued if cond is false. - */ -tumbler.Application.prototype.assert = function(cond, message) { - if (!cond) { - message = "Assertion failed: " + message; - alert(message); - throw new Error(message); - } -} - -/** - * The run() method starts and 'runs' the application. The trackball object - * is allocated and all the events get wired up. - * @param {?String} opt_contentDivName The id of a DOM element in which to - * embed the Native Client module. If unspecified, defaults to - * VIEW. The DOM element must exist. - */ -tumbler.Application.prototype.run = function(opt_contentDivName) { - contentDivName = opt_contentDivName || tumbler.Application.DomIds_.VIEW; - var contentDiv = document.getElementById(contentDivName); - this.assert(contentDiv, "Missing DOM element '" + contentDivName + "'"); - - // Note that the element is wrapped inside a
, which has a 'load' - // event listener attached. This method is used instead of attaching the - // 'load' event listener directly to the element to ensure that the - // listener is active before the NaCl module 'load' event fires. - this.boundModuleDidLoad_ = this.moduleDidLoad.bind(this); - contentDiv.addEventListener('load', this.boundModuleDidLoad_, true); - - // Load the published .nexe. This includes the 'nacl' attribute which - // shows how to load multi-architecture modules. Each entry in the "nexes" - // object in the .nmf manifest file is a key-value pair: the key is the - // runtime ('x86-32', 'x86-64', etc.); the value is a URL for the desired - // NaCl module. To load the debug versions of your .nexes, set the 'nacl' - // attribute to the _dbg.nmf version of the manifest file. - contentDiv.innerHTML = '' -} diff --git a/Demos/NativeClient/bin_html/tumbler.nmf b/Demos/NativeClient/bin_html/tumbler.nmf deleted file mode 100644 index c4bf50a4b..000000000 --- a/Demos/NativeClient/bin_html/tumbler.nmf +++ /dev/null @@ -1,6 +0,0 @@ -{ - "program": { - "x86-64": {"url": "NativeClientTumbler_x64.exe"}, - "x86-32": {"url": "NativeClientTumbler.exe"} - } -} diff --git a/Demos/NativeClient/bin_html/vector3.js b/Demos/NativeClient/bin_html/vector3.js deleted file mode 100644 index a79f78173..000000000 --- a/Demos/NativeClient/bin_html/vector3.js +++ /dev/null @@ -1,91 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -/** - * @fileoverview A 3D vector class. Proviudes some utility functions on - * 3-dimentional vectors. - */ - -// Requires tumbler - -/** - * Constructor for the Vector3 object. This class contains a 3-tuple that - * represents a vector in 3D space. - * @param {?number} opt_x The x-coordinate for this vector. If null or - * undefined, the x-coordinate value is set to 0. - * @param {?number} opt_y The y-coordinate for this vector. If null or - * undefined, the y-coordinate value is set to 0. - * @param {?number} opt_z The z-coordinate for this vector. If null or - * undefined, the z-coordinate value is set to 0. - * @constructor - */ -tumbler.Vector3 = function(opt_x, opt_y, opt_z) { - /** - * The vector's 3-tuple. - * @type {number} - */ - this.x = opt_x || 0; - this.y = opt_y || 0; - this.z = opt_z || 0; -} - -/** - * Method to return the magnitude of a Vector3. - * @return {number} the magnitude of the vector. - */ -tumbler.Vector3.prototype.magnitude = function() { - return Math.sqrt(this.dot(this)); -} - -/** - * Normalize the vector in-place. - * @return {number} the magnitude of the vector. - */ -tumbler.Vector3.prototype.normalize = function() { - var mag = this.magnitude(); - if (mag < tumbler.Vector3.DOUBLE_EPSILON) - return 0.0; // |this| is equivalent to the 0-vector, don't normalize. - this.scale(1.0 / mag); - return mag; -} - -/** - * Scale the vector in-place by |s|. - * @param {!number} s The scale factor. - */ -tumbler.Vector3.prototype.scale = function(s) { - this.x *= s; - this.y *= s; - this.z *= s; -} - -/** - * Compute the dot product: |this| . v. - * @param {!tumbler.Vector3} v The vector to dot. - * @return {number} the result of |this| . v. - */ -tumbler.Vector3.prototype.dot = function(v) { - return this.x * v.x + this.y * v.y + this.z * v.z; -} - -/** - * Compute the cross product: |this| X v. - * @param {!tumbler.Vector3} v The vector to cross with. - * @return {tumbler.Vector3} the result of |this| X v. - */ -tumbler.Vector3.prototype.cross = function(v) { - var vCross = new tumbler.Vector3(this.y * v.z - this.z * v.y, - this.z * v.x - this.x * v.z, - this.x * v.y - this.y * v.x); - return vCross; -} - -/** - * Real numbers that are less than this distance apart are considered - * equivalent. - * TODO(dspringer): It seems as though there should be a const like this - * in generally available somewhere. - * @type {number} - */ -tumbler.Vector3.DOUBLE_EPSILON = 1.0e-16; diff --git a/Demos/NativeClient/callback.h b/Demos/NativeClient/callback.h deleted file mode 100644 index 4d67262ad..000000000 --- a/Demos/NativeClient/callback.h +++ /dev/null @@ -1,92 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_CALLBACK_H_ -#define EXAMPLES_TUMBLER_CALLBACK_H_ - -#include -#include -#include - -namespace tumbler { - -class ScriptingBridge; - -// Templates used to support method call-backs when a method or property is -// accessed from the browser code. - -// Class suite used to publish a method name to Javascript. Typical use is -// like this: -// photo::MethodCallback* calculate_callback_; -// calculate_callback_ = -// new scripting::MethodCallback(this, -// &Calculator::Calculate); -// bridge->AddMethodNamed("calculate", calculate_callback_); -// ... -// delete calculate_callback_; -// -// The caller must delete the callback. - -// Methods get parameters as a dictionary that maps parameter names to values. -typedef std::map MethodParameter; - -// Pure virtual class used in STL containers. -class MethodCallbackExecutor { - public: - virtual ~MethodCallbackExecutor() {} - virtual void Execute( - const ScriptingBridge& bridge, - const MethodParameter& parameters) = 0; -}; - -template -class MethodCallback : public MethodCallbackExecutor { - public: - typedef void (T::*Method)( - const ScriptingBridge& bridge, - const MethodParameter& parameters); - - MethodCallback(T* instance, Method method) - : instance_(instance), method_(method) {} - virtual ~MethodCallback() {} - virtual void Execute( - const ScriptingBridge& bridge, - const MethodParameter& parameters) { - // Use "this->" to force C++ to look inside our templatized base class; see - // Effective C++, 3rd Ed, item 43, p210 for details. - ((this->instance_)->*(this->method_))(bridge, parameters); - } - - private: - T* instance_; - Method method_; -}; - -template -class ConstMethodCallback : public MethodCallbackExecutor { - public: - typedef void (T::*ConstMethod)( - const ScriptingBridge& bridge, - const MethodParameter& parameters) const; - - ConstMethodCallback(const T* instance, ConstMethod method) - : instance_(instance), const_method_(method) {} - virtual ~ConstMethodCallback() {} - virtual void Execute( - const ScriptingBridge& bridge, - const MethodParameter& parameters) { - // Use "this->" to force C++ to look inside our templatized base class; see - // Effective C++, 3rd Ed, item 43, p210 for details. - ((this->instance_)->*(this->const_method_))(bridge, parameters); - } - - private: - const T* instance_; - ConstMethod const_method_; -}; - -} // namespace tumbler - -#endif // EXAMPLES_TUMBLER_CALLBACK_H_ - diff --git a/Demos/NativeClient/cube.cc b/Demos/NativeClient/cube.cc deleted file mode 100644 index 777e6ebdc..000000000 --- a/Demos/NativeClient/cube.cc +++ /dev/null @@ -1,267 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "cube.h" - -#include - -#include "shader_util.h" -#include "transforms.h" - -namespace tumbler { - -static const size_t kVertexCount = 24; -static const int kIndexCount = 36; - -Cube::Cube(SharedOpenGLContext opengl_context) - : opengl_context_(opengl_context), - width_(1), - height_(1) { - eye_[0] = eye_[1] = 0.0f; - eye_[2] = 2.0f; - orientation_[0] = 0.0f; - orientation_[1] = 0.0f; - orientation_[2] = 0.0f; - orientation_[3] = 1.0f; -} - -Cube::~Cube() { - glDeleteBuffers(3, cube_vbos_); - glDeleteProgram(shader_program_object_); -} - -void Cube::PrepareOpenGL() { - CreateShaders(); - CreateCube(); - glClearColor(1.0f, 1.0f, 1.0f, 1.0f); - glEnable(GL_DEPTH_TEST); -} - -void Cube::Resize(int width, int height) { - width_ = std::max(width, 1); - height_ = std::max(height, 1); - // Set the viewport - glViewport(0, 0, width_, height_); - // Compute the perspective projection matrix with a 60 degree FOV. - GLfloat aspect = static_cast(width_) / static_cast(height_); - transform_4x4::LoadIdentity(perspective_proj_); - transform_4x4::Perspective(perspective_proj_, 60.0f, aspect, 1.0f, 20.0f); -} - -void Cube::Draw() { - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - // Compute a new model-view matrix, then use that to make the composite - // model-view-projection matrix: MVP = MV . P. - GLfloat model_view[16]; - ComputeModelViewTransform(model_view); - transform_4x4::Multiply(mvp_matrix_, model_view, perspective_proj_); - - glBindBuffer(GL_ARRAY_BUFFER, cube_vbos_[0]); - glUseProgram(shader_program_object_); - glEnableVertexAttribArray(position_location_); - glVertexAttribPointer(position_location_, - 3, - GL_FLOAT, - GL_FALSE, - 3 * sizeof(GLfloat), - NULL); - glEnableVertexAttribArray(color_location_); - glBindBuffer(GL_ARRAY_BUFFER, cube_vbos_[1]); - glVertexAttribPointer(color_location_, - 3, - GL_FLOAT, - GL_FALSE, - 3 * sizeof(GLfloat), - NULL); - glUniformMatrix4fv(mvp_location_, 1, GL_FALSE, mvp_matrix_); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, cube_vbos_[2]); - glDrawElements(GL_TRIANGLES, kIndexCount, GL_UNSIGNED_SHORT, 0); - glBindBuffer(GL_ARRAY_BUFFER, 0); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); -} - -bool Cube::CreateShaders() { - const char vertex_shader_src[] = - "uniform mat4 u_mvpMatrix; \n" - "attribute vec4 a_position; \n" - "attribute vec3 a_color; \n" - "varying lowp vec4 v_color; \n" - "void main() \n" - "{ \n" - " v_color.xyz = a_color; \n" - " v_color.w = 1.0; \n" - " gl_Position = u_mvpMatrix * a_position; \n" - "} \n"; - - const char fragment_shader_src[] = - "varying lowp vec4 v_color; \n" - "void main() \n" - "{ \n" - " gl_FragColor = v_color; \n" - "} \n"; - - // Load the shaders and get a linked program object - shader_program_object_ = - shader_util::CreateProgramFromVertexAndFragmentShaders( - vertex_shader_src, fragment_shader_src); - if (shader_program_object_ == 0) - return false; - position_location_ = glGetAttribLocation(shader_program_object_, - "a_position"); - color_location_ = glGetAttribLocation(shader_program_object_, "a_color"); - mvp_location_ = glGetUniformLocation(shader_program_object_, "u_mvpMatrix"); - return true; -} - -void Cube::CreateCube() { - static const GLfloat cube_vertices[] = { - // Vertex coordinates interleaved with color values - // Bottom - -0.5f, -0.5f, -0.5f, - -0.5f, -0.5f, 0.5f, - 0.5f, -0.5f, 0.5f, - 0.5f, -0.5f, -0.5f, - // Top - -0.5f, 0.5f, -0.5f, - -0.5f, 0.5f, 0.5f, - 0.5f, 0.5f, 0.5f, - 0.5f, 0.5f, -0.5f, - // Back - -0.5f, -0.5f, -0.5f, - -0.5f, 0.5f, -0.5f, - 0.5f, 0.5f, -0.5f, - 0.5f, -0.5f, -0.5f, - // Front - -0.5f, -0.5f, 0.5f, - -0.5f, 0.5f, 0.5f, - 0.5f, 0.5f, 0.5f, - 0.5f, -0.5f, 0.5f, - // Left - -0.5f, -0.5f, -0.5f, - -0.5f, -0.5f, 0.5f, - -0.5f, 0.5f, 0.5f, - -0.5f, 0.5f, -0.5f, - // Right - 0.5f, -0.5f, -0.5f, - 0.5f, -0.5f, 0.5f, - 0.5f, 0.5f, 0.5f, - 0.5f, 0.5f, -0.5f - }; - - static const GLfloat cube_colors[] = { - // Vertex coordinates interleaved with color values - // Bottom - 1.0, 0.0, 0.0, - 1.0, 0.0, 0.0, - 1.0, 0.0, 0.0, - 1.0, 0.0, 0.0, - // Top - 0.0, 1.0, 0.0, - 0.0, 1.0, 0.0, - 0.0, 1.0, 0.0, - 0.0, 1.0, 0.0, - // Back - 0.0, 0.0, 1.0, - 0.0, 0.0, 1.0, - 0.0, 0.0, 1.0, - 0.0, 0.0, 1.0, - // Front - 1.0, 0.0, 1.0, - 1.0, 0.0, 1.0, - 1.0, 0.0, 1.0, - 1.0, 0.0, 1.0, - // Left - 1.0, 1.0, 0.0, - 1.0, 1.0, 0.0, - 1.0, 1.0, 0.0, - 1.0, 1.0, 0.0, - // Right - 0.0, 1.0, 1.0, - 0.0, 1.0, 1.0, - 0.0, 1.0, 1.0, - 0.0, 1.0, 1.0 - }; - - static const GLushort cube_indices[] = { - // Bottom - 0, 2, 1, - 0, 3, 2, - // Top - 4, 5, 6, - 4, 6, 7, - // Back - 8, 9, 10, - 8, 10, 11, - // Front - 12, 15, 14, - 12, 14, 13, - // Left - 16, 17, 18, - 16, 18, 19, - // Right - 20, 23, 22, - 20, 22, 21 - }; - - // Generate the VBOs and upload them to the graphics context. - glGenBuffers(3, cube_vbos_); - glBindBuffer(GL_ARRAY_BUFFER, cube_vbos_[0]); - glBufferData(GL_ARRAY_BUFFER, - kVertexCount * sizeof(GLfloat) * 3, - cube_vertices, - GL_STATIC_DRAW); - glBindBuffer(GL_ARRAY_BUFFER, cube_vbos_[1]); - glBufferData(GL_ARRAY_BUFFER, - kVertexCount * sizeof(GLfloat) * 3, - cube_colors, - GL_STATIC_DRAW); - glBindBuffer(GL_ARRAY_BUFFER, 0); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, cube_vbos_[2]); - glBufferData(GL_ELEMENT_ARRAY_BUFFER, - kIndexCount * sizeof(GL_UNSIGNED_SHORT), - cube_indices, - GL_STATIC_DRAW); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); -} - -void Cube::ComputeModelViewTransform(GLfloat* model_view) { - // This method takes into account the possiblity that |orientation_| - // might not be normalized. - double sqrx = orientation_[0] * orientation_[0]; - double sqry = orientation_[1] * orientation_[1]; - double sqrz = orientation_[2] * orientation_[2]; - double sqrw = orientation_[3] * orientation_[3]; - double sqrLength = 1.0 / (sqrx + sqry + sqrz + sqrw); - - transform_4x4::LoadIdentity(model_view); - model_view[0] = (sqrx - sqry - sqrz + sqrw) * sqrLength; - model_view[5] = (-sqrx + sqry - sqrz + sqrw) * sqrLength; - model_view[10] = (-sqrx - sqry + sqrz + sqrw) * sqrLength; - - double temp1 = orientation_[0] * orientation_[1]; - double temp2 = orientation_[2] * orientation_[3]; - model_view[1] = 2.0 * (temp1 + temp2) * sqrLength; - model_view[4] = 2.0 * (temp1 - temp2) * sqrLength; - - temp1 = orientation_[0] * orientation_[2]; - temp2 = orientation_[1] * orientation_[3]; - model_view[2] = 2.0 * (temp1 - temp2) * sqrLength; - model_view[8] = 2.0 * (temp1 + temp2) * sqrLength; - temp1 = orientation_[1] * orientation_[2]; - temp2 = orientation_[0] * orientation_[3]; - model_view[6] = 2.0 * (temp1 + temp2) * sqrLength; - model_view[9] = 2.0 * (temp1 - temp2) * sqrLength; - model_view[3] = 0.0; - model_view[7] = 0.0; - model_view[11] = 0.0; - - // Concatenate the translation to the eye point. - model_view[12] = -eye_[0]; - model_view[13] = -eye_[1]; - model_view[14] = -eye_[2]; - model_view[15] = 1.0; -} - -} // namespace tumbler diff --git a/Demos/NativeClient/cube.h b/Demos/NativeClient/cube.h deleted file mode 100644 index 1c3b62baa..000000000 --- a/Demos/NativeClient/cube.h +++ /dev/null @@ -1,97 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_CUBE_H_ -#define EXAMPLES_TUMBLER_CUBE_H_ - -#include -#include -#include "opengl_context.h" -#include "opengl_context_ptrs.h" - -namespace tumbler { - -// The Cube class provides a place to implement 3D rendering. It has a -// frame that it occupies in a browser window. -class Cube { - public: - explicit Cube(SharedOpenGLContext opengl_context); - ~Cube(); - - // Called once when a new RenderContext is first bound to the view. The - // bound context is guaranteed to be current and valid before calling this - // method. - void PrepareOpenGL(); - - // Called whenever the size of the browser view changes. This method is - // called at least once when the view is first made visible. Clamps the - // sizes to 1. - void Resize(int width, int height); - - // Called every time the view need to be drawn. The bound context is - // guaranteed to be current and valid before this method is called. The - // visible portion of the context is flushed to the browser after this - // method returns. - void Draw(); - - // Accessor for width and height. To change these, call Resize. - const int width() const { - return width_; - } - - const int height() const { - return height_; - } - - // Accessor/mutator for the camera orientation. - void GetOrientation(std::vector* orientation) const { - if (!orientation) - return; - (*orientation)[0] = static_cast(orientation_[0]); - (*orientation)[1] = static_cast(orientation_[1]); - (*orientation)[2] = static_cast(orientation_[2]); - (*orientation)[3] = static_cast(orientation_[3]); - } - void SetOrientation(const std::vector& orientation) { - orientation_[0] = static_cast(orientation[0]); - orientation_[1] = static_cast(orientation[1]); - orientation_[2] = static_cast(orientation[2]); - orientation_[3] = static_cast(orientation[3]); - } - - private: - // Create the shaders used to draw the cube, and link them into a program. - // Initializes |shader_progam_object_|, |position_loction_| and - // |mvp_location_|. - bool CreateShaders(); - - // Generates a cube as a series of GL_TRIANGLE_STRIPs, and initializes - // |index_count_| to the number of indices in the index list used as a VBO. - // Creates the |vbo_ids_| required for the vertex and index data and uploads - // the the VBO data. - void CreateCube(); - - // Build up the model-view transform from the eye and orienation properties. - // Assumes that |model_view| is a 4x4 matrix. - void ComputeModelViewTransform(GLfloat* model_view); - - SharedOpenGLContext opengl_context_; - int width_; - int height_; - GLuint shader_program_object_; // The compiled shaders. - GLint position_location_; // The position attribute location. - GLint color_location_; // The color attribute location. - GLint mvp_location_; // The Model-View-Projection composite matrix. - GLuint cube_vbos_[3]; - GLfloat eye_[3]; // The eye point of the virtual camera. - // The orientation of the virtual camera stored as a quaternion. The - // quaternion is laid out as {{x, y, z}, w}. - GLfloat orientation_[4]; - GLfloat perspective_proj_[16]; - GLfloat mvp_matrix_[16]; -}; - -} // namespace tumbler - -#endif // EXAMPLES_TUMBLER_CUBE_H_ diff --git a/Demos/NativeClient/opengl_context.cc b/Demos/NativeClient/opengl_context.cc deleted file mode 100644 index 1c0afa711..000000000 --- a/Demos/NativeClient/opengl_context.cc +++ /dev/null @@ -1,72 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "opengl_context.h" - -#include -#include "ppapi/gles2/gl2ext_ppapi.h" - -namespace { -// This is called by the brower when the 3D context has been flushed to the -// browser window. -void FlushCallback(void* data, int32_t result) { - static_cast(data)->set_flush_pending(false); -} -} // namespace - -namespace tumbler { - -OpenGLContext::OpenGLContext(pp::Instance* instance) - : pp::Graphics3DClient_Dev(instance), - flush_pending_(false) { - pp::Module* module = pp::Module::Get(); - assert(module); - gles2_interface_ = static_cast( - module->GetBrowserInterface(PPB_OPENGLES2_DEV_INTERFACE)); - assert(gles2_interface_); -} - -OpenGLContext::~OpenGLContext() { - glSetCurrentContextPPAPI(0); -} - -bool OpenGLContext::MakeContextCurrent(pp::Instance* instance) { - if (instance == NULL) { - glSetCurrentContextPPAPI(0); - return false; - } - // Lazily create the Pepper context. - if (context_.is_null()) { - context_ = pp::Context3D_Dev(*instance, 0, pp::Context3D_Dev(), NULL); - if (context_.is_null()) { - glSetCurrentContextPPAPI(0); - return false; - } - surface_ = pp::Surface3D_Dev(*instance, 0, NULL); - context_.BindSurfaces(surface_, surface_); - instance->BindGraphics(surface_); - } - glSetCurrentContextPPAPI(context_.pp_resource()); - return true; -} - -void OpenGLContext::InvalidateContext(pp::Instance* instance) { - if (instance == NULL) - return; - // Unbind the existing surface and re-bind to null surfaces. - instance->BindGraphics(pp::Surface3D_Dev()); - context_.BindSurfaces(pp::Surface3D_Dev(), pp::Surface3D_Dev()); - glSetCurrentContextPPAPI(0); -} - -void OpenGLContext::FlushContext() { - if (flush_pending()) { - // A flush is pending so do nothing; just drop this flush on the floor. - return; - } - set_flush_pending(true); - surface_.SwapBuffers(pp::CompletionCallback(&FlushCallback, this)); -} -} // namespace tumbler - diff --git a/Demos/NativeClient/opengl_context.h b/Demos/NativeClient/opengl_context.h deleted file mode 100644 index 851b9dbfc..000000000 --- a/Demos/NativeClient/opengl_context.h +++ /dev/null @@ -1,90 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_OPENGL_CONTEXT_H_ -#define EXAMPLES_TUMBLER_OPENGL_CONTEXT_H_ - -/// -/// @file -/// OpenGLContext manages the OpenGL context in the browser that is associated -/// with a @a pp::Instance instance. -/// - -#include - -#include -#include - -#include "opengl_context_ptrs.h" -#include "ppapi/c/dev/ppb_opengles_dev.h" -#include "ppapi/cpp/dev/context_3d_dev.h" -#include "ppapi/cpp/dev/graphics_3d_client_dev.h" -#include "ppapi/cpp/dev/graphics_3d_dev.h" -#include "ppapi/cpp/dev/surface_3d_dev.h" -#include "ppapi/cpp/instance.h" - -namespace tumbler { - -/// OpenGLContext manages an OpenGL rendering context in the browser. -/// -class OpenGLContext : public pp::Graphics3DClient_Dev { - public: - explicit OpenGLContext(pp::Instance* instance); - - /// Release all the in-browser resources used by this context, and make this - /// context invalid. - virtual ~OpenGLContext(); - - /// The Graphics3DClient interfcace. - virtual void Graphics3DContextLost() { - assert(!"Unexpectedly lost graphics context"); - } - - /// Make @a this the current 3D context in @a instance. - /// @param instance The instance of the NaCl module that will receive the - /// the current 3D context. - /// @return success. - bool MakeContextCurrent(pp::Instance* instance); - - /// Flush the contents of this context to the browser's 3D device. - void FlushContext(); - - /// Make the underlying 3D device invalid, so that any subsequent rendering - /// commands will have no effect. The next call to MakeContextCurrent() will - /// cause the underlying 3D device to get rebound and start receiving - /// receiving rendering commands again. Use InvalidateContext(), for - /// example, when resizing the context's viewing area. - void InvalidateContext(pp::Instance* instance); - - /// The OpenGL ES 2.0 interface. - const struct PPB_OpenGLES2_Dev* gles2() const { - return gles2_interface_; - } - - /// The PP_Resource needed to make GLES2 calls through the Pepper interface. - const PP_Resource gl_context() const { - return context_.pp_resource(); - } - - /// Indicate whether a flush is pending. This can only be called from the - /// main thread; it is not thread safe. - bool flush_pending() const { - return flush_pending_; - } - void set_flush_pending(bool flag) { - flush_pending_ = flag; - } - - private: - pp::Context3D_Dev context_; - pp::Surface3D_Dev surface_; - bool flush_pending_; - - const struct PPB_OpenGLES2_Dev* gles2_interface_; -}; - -} // namespace tumbler - -#endif // EXAMPLES_TUMBLER_OPENGL_CONTEXT_H_ - diff --git a/Demos/NativeClient/opengl_context_ptrs.h b/Demos/NativeClient/opengl_context_ptrs.h deleted file mode 100644 index 347852134..000000000 --- a/Demos/NativeClient/opengl_context_ptrs.h +++ /dev/null @@ -1,22 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_OPENGL_CONTEXT_PTRS_H_ -#define EXAMPLES_TUMBLER_OPENGL_CONTEXT_PTRS_H_ - -// A convenience wrapper for a shared OpenGLContext pointer type. As other -// smart pointer types are needed, add them here. - -#include - -namespace tumbler { - -class OpenGLContext; - -typedef std::tr1::shared_ptr SharedOpenGLContext; - -} // namespace tumbler - -#endif // EXAMPLES_TUMBLER_OPENGL_CONTEXT_PTRS_H_ - diff --git a/Demos/NativeClient/premake4.lua b/Demos/NativeClient/premake4.lua deleted file mode 100644 index 1957fbb3a..000000000 --- a/Demos/NativeClient/premake4.lua +++ /dev/null @@ -1,27 +0,0 @@ - project "NativeClientTumbler" - - kind "ConsoleApp" - - targetdir "bin_html" - - includedirs { "." } - - --libdirs {} - - links { - "ppapi_gles2", - "ppapi", - "ppapi_cpp", - "ppruntime" - } - - - files { - "cube.cc", - "opengl_context.cc", - "scripting_bridge.cc", - "shader_util.cc", - "transforms.cc", - "tumbler.cc", - "tumbler_module.cc" - } \ No newline at end of file diff --git a/Demos/NativeClient/scripting_bridge.cc b/Demos/NativeClient/scripting_bridge.cc deleted file mode 100644 index abc67ca2e..000000000 --- a/Demos/NativeClient/scripting_bridge.cc +++ /dev/null @@ -1,95 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "scripting_bridge.h" - -namespace { -const char* const kWhiteSpaceCharacters = " \t"; - -// Helper function to pull out the next token in |token_string|. A token is -// delimited by whitespace. Scanning begins at |*pos|, if pos goes beyond the -// end of |token_string|, it is set to std::string::npos and an empty string -// is returned. On return, |*pos| will point to the beginning of the next -// token. |pos| must not be NULL. -const std::string ScanToken(const std::string& token_string, size_t* pos) { - std::string token; - if (*pos == std::string::npos) { - return token; - } - size_t token_start_pos = token_string.find_first_not_of(kWhiteSpaceCharacters, - *pos); - size_t token_end_pos = token_string.find_first_of(kWhiteSpaceCharacters, - token_start_pos); - if (token_start_pos != std::string::npos) { - token = token_string.substr(token_start_pos, token_end_pos); - } - *pos = token_end_pos; - return token; -} - -// Take a string of the form 'name:value' and split it into two strings, one -// containing 'name' and the other 'value'. If the ':' separator is missing, -// or is the last character in |parameter|, |parameter| is copied to -// |param_name|, |param_value| is left unchanged and false is returned. -bool ParseParameter(const std::string& parameter, - std::string* param_name, - std::string* param_value) { - bool success = false; - size_t sep_pos = parameter.find_first_of(':'); - if (sep_pos != std::string::npos) { - *param_name = parameter.substr(0, sep_pos); - if (sep_pos < parameter.length() - 1) { - *param_value = parameter.substr(sep_pos + 1); - success = true; - } else { - success = false; - } - } else { - *param_name = parameter; - success = false; - } - return success; -} -} // namespace - -namespace tumbler { - -bool ScriptingBridge::AddMethodNamed(const std::string& method_name, - SharedMethodCallbackExecutor method) { - if (method_name.size() == 0 || method == NULL) - return false; - method_dictionary_.insert( - std::pair(method_name, - method)); - return true; -} - -bool ScriptingBridge::InvokeMethod(const std::string& method) { - size_t current_pos = 0; - const std::string method_name = ScanToken(method, ¤t_pos); - MethodDictionary::iterator method_iter; - method_iter = method_dictionary_.find(method_name); - if (method_iter != method_dictionary_.end()) { - // Pull out the method parameters and build a dictionary that maps - // parameter names to values. - std::map param_dict; - while (current_pos != std::string::npos) { - const std::string parameter = ScanToken(method, ¤t_pos); - if (parameter.length()) { - std::string param_name; - std::string param_value; - if (ParseParameter(parameter, ¶m_name, ¶m_value)) { - // Note that duplicate parameter names will override each other. The - // last one in the method string will be used. - param_dict[param_name] = param_value; - } - } - } - (*method_iter->second).Execute(*this, param_dict); - return true; - } - return false; -} - -} // namespace tumbler diff --git a/Demos/NativeClient/scripting_bridge.h b/Demos/NativeClient/scripting_bridge.h deleted file mode 100644 index f6a366c65..000000000 --- a/Demos/NativeClient/scripting_bridge.h +++ /dev/null @@ -1,52 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_SCRIPTING_BRIDGE_H_ -#define EXAMPLES_TUMBLER_SCRIPTING_BRIDGE_H_ - -#include -#include -#include -#include - -#include "callback.h" -#include "ppapi/cpp/var.h" - -namespace tumbler { - -class MethodCallbackExecutor; - -// This class handles the interface between the browser and the NaCl module. -// There is a single point of entry from the browser: postMessage(). The -// string passed to postMessage() has this format: -// 'function_name arg_name0:arg_0 arg_name1:arg1 ...' -// The arguments have undetermined type; they are placed in a map of argument -// names and values. Values are all strings, it is up to the target code to -// do any type coercion. -// Methods called by the scripting bridge must have a signature like this: -// void Method(const ScriptingBridge& bridge, -// const ParameterDictionary&); -class ScriptingBridge { - public: - // Shared pointer type used in the method map. - typedef std::tr1::shared_ptr - SharedMethodCallbackExecutor; - - virtual ~ScriptingBridge() {} - - // Causes |method_name| to be published as a method that can be called via - // postMessage() from the browser. Associates this method with |method|. - bool AddMethodNamed(const std::string& method_name, - SharedMethodCallbackExecutor method); - - bool InvokeMethod(const std::string& method); - - private: - typedef std::map MethodDictionary; - - MethodDictionary method_dictionary_; -}; - -} // namespace tumbler -#endif // EXAMPLES_TUMBLER_SCRIPTING_BRIDGE_H_ diff --git a/Demos/NativeClient/shader_util.cc b/Demos/NativeClient/shader_util.cc deleted file mode 100644 index 802955b66..000000000 --- a/Demos/NativeClient/shader_util.cc +++ /dev/null @@ -1,95 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "shader_util.h" - -#include -#include - -namespace shader_util { - -GLuint CreateShaderOfType(GLenum type, const char *shader_src) { - GLuint shader; - GLint compiled; - - // Create the shader object - shader = glCreateShader(type); - - if (shader == 0) - return 0; - - // Load and compile the shader source - glShaderSource(shader, 1, &shader_src, NULL); - glCompileShader(shader); - - // Check the compile status - glGetShaderiv(shader, GL_COMPILE_STATUS, &compiled); - if (compiled == 0) { - GLint info_len = 0; - glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &info_len); - if (info_len > 1) { - char* info_log = reinterpret_cast(malloc(sizeof(char) * info_len)); - glGetShaderInfoLog(shader, info_len, NULL, info_log); - // TODO(dspringer): We could really use a logging API. - printf("Error compiling shader:\n%s\n", info_log); - free(info_log); - } - glDeleteShader(shader); - return 0; - } - - return shader; -} - -GLuint CreateProgramFromVertexAndFragmentShaders( - const char *vertex_shader_src, const char *fragment_shader_src) { - GLuint vertex_shader; - GLuint fragment_shader; - GLuint program_object; - GLint linked; - - // Load the vertex/fragment shaders - vertex_shader = CreateShaderOfType(GL_VERTEX_SHADER, vertex_shader_src); - if (vertex_shader == 0) - return 0; - fragment_shader = CreateShaderOfType(GL_FRAGMENT_SHADER, fragment_shader_src); - if (fragment_shader == 0) { - glDeleteShader(vertex_shader); - return 0; - } - - // Create the program object and attach the shaders. - program_object = glCreateProgram(); - if (program_object == 0) - return 0; - glAttachShader(program_object, vertex_shader); - glAttachShader(program_object, fragment_shader); - - // Link the program - glLinkProgram(program_object); - - // Check the link status - glGetProgramiv(program_object, GL_LINK_STATUS, &linked); - if (linked == 0) { - GLint info_len = 0; - glGetProgramiv(program_object, GL_INFO_LOG_LENGTH, &info_len); - if (info_len > 1) { - char* info_log = reinterpret_cast(malloc(info_len)); - glGetProgramInfoLog(program_object, info_len, NULL, info_log); - // TODO(dspringer): We could really use a logging API. - printf("Error linking program:\n%s\n", info_log); - free(info_log); - } - glDeleteProgram(program_object); - return 0; - } - - // Delete these here because they are attached to the program object. - glDeleteShader(vertex_shader); - glDeleteShader(fragment_shader); - - return program_object; -} - -} // namespace shader_util diff --git a/Demos/NativeClient/shader_util.h b/Demos/NativeClient/shader_util.h deleted file mode 100644 index 635b16b9f..000000000 --- a/Demos/NativeClient/shader_util.h +++ /dev/null @@ -1,29 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -// Some simple helper functions that load shaders and create program objects. - -#ifndef EXAMPLES_TUMBLER_SHADER_UTIL_H_ -#define EXAMPLES_TUMBLER_SHADER_UTIL_H_ - -#include - -namespace shader_util { - -// Load and compile a shader. |type| can be one of GL_VERTEX_SHADER or -// GL_FRAGMENT_SHADER. Returns a non-0 value representing the compiled -// shader on success, 0 on failure. The caller is responsible for deleting -// the returned shader using glDeleteShader(). -GLuint CreateShaderOfType(GLenum type, const char *shader_src); - -// Load and compile the vertex and fragment shaders, then link these together -// into a complete program. Returns a non-0 value representing the program on, -// success or 0 on failure. The caller is responsible for deleting the -// returned program using glDeleteProgram(). -GLuint CreateProgramFromVertexAndFragmentShaders( - const char *vertex_shader_src, const char *fragment_shader_src); - -} // namespace shader_util - -#endif // EXAMPLES_TUMBLER_SHADER_UTIL_H_ diff --git a/Demos/NativeClient/transforms.cc b/Demos/NativeClient/transforms.cc deleted file mode 100644 index 10ab16c94..000000000 --- a/Demos/NativeClient/transforms.cc +++ /dev/null @@ -1,116 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "transforms.h" - -#include -#include -#include - -namespace transform_4x4 { - -static const GLfloat kPI = 3.1415926535897932384626433832795f; - -void Translate(GLfloat* m, GLfloat tx, GLfloat ty, GLfloat tz) { - m[12] += (m[0] * tx + m[4] * ty + m[8] * tz); - m[13] += (m[1] * tx + m[5] * ty + m[9] * tz); - m[14] += (m[2] * tx + m[6] * ty + m[10] * tz); - m[15] += (m[3] * tx + m[7] * ty + m[11] * tz); -} - -void Frustum(GLfloat* m, - GLfloat left, - GLfloat right, - GLfloat bottom, - GLfloat top, - GLfloat near_z, - GLfloat far_z) { - GLfloat delta_x = right - left; - GLfloat delta_y = top - bottom; - GLfloat delta_z = far_z - near_z; - GLfloat frustum[16]; - - if ((near_z <= 0.0f) || (far_z <= 0.0f) || - (delta_x <= 0.0f) || (delta_y <= 0.0f) || (delta_z <= 0.0f)) - return; - - frustum[0] = 2.0f * near_z / delta_x; - frustum[1] = frustum[2] = frustum[3] = 0.0f; - - frustum[5] = 2.0f * near_z / delta_y; - frustum[4] = frustum[6] = frustum[7] = 0.0f; - - frustum[8] = (right + left) / delta_x; - frustum[9] = (top + bottom) / delta_y; - frustum[10] = -(near_z + far_z) / delta_z; - frustum[11] = -1.0f; - - frustum[14] = -2.0f * near_z * far_z / delta_z; - frustum[12] = frustum[13] = frustum[15] = 0.0f; - - transform_4x4::Multiply(m, frustum, m); -} - - -void Perspective(GLfloat* m, - GLfloat fovy, - GLfloat aspect, - GLfloat near_z, - GLfloat far_z) { - GLfloat frustum_w, frustum_h; - - frustum_h = tanf((fovy * 0.5f) / 180.0f * kPI) * near_z; - frustum_w = frustum_h * aspect; - transform_4x4::Frustum(m, -frustum_w, frustum_w, -frustum_h, frustum_h, - near_z, far_z); -} - -void Multiply(GLfloat *m, GLfloat *a, GLfloat* b) { - GLfloat tmp[16]; - // tmp = a . b - GLfloat a0, a1, a2, a3; - a0 = a[0]; - a1 = a[1]; - a2 = a[2]; - a3 = a[3]; - tmp[0] = a0 * b[0] + a1 * b[4] + a2 * b[8] + a3 * b[12]; - tmp[1] = a0 * b[1] + a1 * b[5] + a2 * b[9] + a3 * b[13]; - tmp[2] = a0 * b[2] + a1 * b[6] + a2 * b[10] + a3 * b[14]; - tmp[3] = a0 * b[3] + a1 * b[7] + a2 * b[11] + a3 * b[15]; - - a0 = a[4]; - a1 = a[5]; - a2 = a[6]; - a3 = a[7]; - tmp[4] = a0 * b[0] + a1 * b[4] + a2 * b[8] + a3 * b[12]; - tmp[5] = a0 * b[1] + a1 * b[5] + a2 * b[9] + a3 * b[13]; - tmp[6] = a0 * b[2] + a1 * b[6] + a2 * b[10] + a3 * b[14]; - tmp[7] = a0 * b[3] + a1 * b[7] + a2 * b[11] + a3 * b[15]; - - a0 = a[8]; - a1 = a[9]; - a2 = a[10]; - a3 = a[11]; - tmp[8] = a0 * b[0] + a1 * b[4] + a2 * b[8] + a3 * b[12]; - tmp[9] = a0 * b[1] + a1 * b[5] + a2 * b[9] + a3 * b[13]; - tmp[10] = a0 * b[2] + a1 * b[6] + a2 * b[10] + a3 * b[14]; - tmp[11] = a0 * b[3] + a1 * b[7] + a2 * b[11] + a3 * b[15]; - - a0 = a[12]; - a1 = a[13]; - a2 = a[14]; - a3 = a[15]; - tmp[12] = a0 * b[0] + a1 * b[4] + a2 * b[8] + a3 * b[12]; - tmp[13] = a0 * b[1] + a1 * b[5] + a2 * b[9] + a3 * b[13]; - tmp[14] = a0 * b[2] + a1 * b[6] + a2 * b[10] + a3 * b[14]; - tmp[15] = a0 * b[3] + a1 * b[7] + a2 * b[11] + a3 * b[15]; - memcpy(m, tmp, sizeof(GLfloat) * 4 * 4); -} - -void LoadIdentity(GLfloat* m) { - memset(m, 0, sizeof(GLfloat) * 4 * 4); - m[0] = m[5] = m[10] = m[15] = 1.0f; -} - -} // namespace transform_4x4 diff --git a/Demos/NativeClient/transforms.h b/Demos/NativeClient/transforms.h deleted file mode 100644 index 5ac3d6e52..000000000 --- a/Demos/NativeClient/transforms.h +++ /dev/null @@ -1,45 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_TRANSFORMS_H_ -#define EXAMPLES_TUMBLER_TRANSFORMS_H_ - -#include - -// A very simple set of 4x4 matrix routines. In all these routines, the input -// matrix is assumed to be a 4x4 of GLfloats. - -namespace transform_4x4 { - -// Pre-multply |m| with a projection transformation 4x4 matrix from a -// truncated pyramid viewing frustum. -void Frustum(GLfloat* m, - GLfloat left, - GLfloat right, - GLfloat bottom, - GLfloat top, - GLfloat near_z, - GLfloat far_z); - -// Replace |m| with the 4x4 identity matrix. -void LoadIdentity(GLfloat* m); - -// |m| <- |a| . |b|. |m| can point at the same memory as either |a| or |b|. -void Multiply(GLfloat *m, GLfloat *a, GLfloat* b); - -// Pre-multiply |m| with a single-point perspective matrix based on the viewing -// frustum whose view angle is |fovy|. -void Perspective(GLfloat* m, - GLfloat fovy, - GLfloat aspect, - GLfloat near_z, - GLfloat far_z); - -// Pre-multiply |m| with a matrix that represents a translation by |tx|, |ty|, -// |tz|. -void Translate(GLfloat* m, GLfloat tx, GLfloat ty, GLfloat tz); -} // namespace transform_4x4 - -#endif // EXAMPLES_TUMBLER_TRANSFORMS_H_ - diff --git a/Demos/NativeClient/tumbler.cc b/Demos/NativeClient/tumbler.cc deleted file mode 100644 index 1beecd39f..000000000 --- a/Demos/NativeClient/tumbler.cc +++ /dev/null @@ -1,136 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "tumbler.h" - -#include -#include -#include -#include - -#include "cube.h" -#include "opengl_context.h" -#include "scripting_bridge.h" -#include "ppapi/cpp/rect.h" -#include "ppapi/cpp/size.h" -#include "ppapi/cpp/var.h" - -namespace { -const size_t kQuaternionElementCount = 4; -const char* const kArrayStartCharacter = "["; -const char* const kArrayEndCharacter = "]"; -const char* const kArrayDelimiter = ","; - -// Return the value of parameter named |param_name| from |parameters|. If -// |param_name| doesn't exist, then return an empty string. -std::string GetParameterNamed( - const std::string& param_name, - const tumbler::MethodParameter& parameters) { - tumbler::MethodParameter::const_iterator i = - parameters.find(param_name); - if (i == parameters.end()) { - return ""; - } - return i->second; -} - -// Convert the JSON string |array| into a vector of floats. |array| is -// expected to be a string bounded by '[' and ']', and a comma-delimited list -// of numbers. Any errors result in the return of an empty array. -std::vector CreateArrayFromJSON(const std::string& json_array) { - std::vector float_array; - size_t array_start_pos = json_array.find_first_of(kArrayStartCharacter); - size_t array_end_pos = json_array.find_last_of(kArrayEndCharacter); - if (array_start_pos == std::string::npos || - array_end_pos == std::string::npos) - return float_array; // Malformed JSON: missing '[' or ']'. - // Pull out the array elements. - size_t token_pos = array_start_pos + 1; - while (token_pos < array_end_pos) { - float_array.push_back(strtof(json_array.data() + token_pos, NULL)); - size_t delim_pos = json_array.find_first_of(kArrayDelimiter, token_pos); - if (delim_pos == std::string::npos) - break; - token_pos = delim_pos + 1; - } - return float_array; -} -} // namespace - -namespace tumbler { - -Tumbler::Tumbler(PP_Instance instance) - : pp::Instance(instance), - cube_(NULL) { -} - -Tumbler::~Tumbler() { - // Destroy the cube view while GL context is current. - opengl_context_->MakeContextCurrent(this); - delete cube_; -} - -bool Tumbler::Init(uint32_t /* argc */, - const char* /* argn */[], - const char* /* argv */[]) { - // Add all the methods to the scripting bridge. - ScriptingBridge::SharedMethodCallbackExecutor set_orientation_method( - new tumbler::MethodCallback( - this, &Tumbler::SetCameraOrientation)); - scripting_bridge_.AddMethodNamed("setCameraOrientation", - set_orientation_method); - return true; -} - -void Tumbler::HandleMessage(const pp::Var& message) { - if (!message.is_string()) - return; - scripting_bridge_.InvokeMethod(message.AsString()); -} - -void Tumbler::DidChangeView(const pp::Rect& position, const pp::Rect& clip) { - int cube_width = cube_ ? cube_->width() : 0; - int cube_height = cube_ ? cube_->height() : 0; - if (position.size().width() == cube_width && - position.size().height() == cube_height) - return; // Size didn't change, no need to update anything. - - if (opengl_context_ == NULL) - opengl_context_.reset(new OpenGLContext(this)); - opengl_context_->InvalidateContext(this); - if (!opengl_context_->MakeContextCurrent(this)) - return; - if (cube_ == NULL) { - cube_ = new Cube(opengl_context_); - cube_->PrepareOpenGL(); - } - cube_->Resize(position.size().width(), position.size().height()); - DrawSelf(); -} - -void Tumbler::DrawSelf() { - if (cube_ == NULL || opengl_context_ == NULL) - return; - opengl_context_->MakeContextCurrent(this); - cube_->Draw(); - opengl_context_->FlushContext(); -} - -void Tumbler::SetCameraOrientation( - const tumbler::ScriptingBridge& bridge, - const tumbler::MethodParameter& parameters) { - // |parameters| is expected to contain one object named "orientation", whose - // value is a JSON string that represents an array of four floats. - if (parameters.size() != 1 || cube_ == NULL) - return; - std::string orientation_desc = GetParameterNamed("orientation", parameters); - std::vector orientation = CreateArrayFromJSON(orientation_desc); - if (orientation.size() != kQuaternionElementCount) { - return; - } - cube_->SetOrientation(orientation); - DrawSelf(); -} -} // namespace tumbler - diff --git a/Demos/NativeClient/tumbler.h b/Demos/NativeClient/tumbler.h deleted file mode 100644 index e29d3535d..000000000 --- a/Demos/NativeClient/tumbler.h +++ /dev/null @@ -1,64 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef EXAMPLES_TUMBLER_TUMBLER_H_ -#define EXAMPLES_TUMBLER_TUMBLER_H_ - -#include -#include -#include - -#include "cube.h" -#include "opengl_context.h" -#include "opengl_context_ptrs.h" -#include "scripting_bridge.h" -#include "ppapi/cpp/instance.h" - -namespace tumbler { - -class Tumbler : public pp::Instance { - public: - explicit Tumbler(PP_Instance instance); - - // The dtor makes the 3D context current before deleting the cube view, then - // destroys the 3D context both in the module and in the browser. - virtual ~Tumbler(); - - // Called by the browser when the NaCl module is loaded and all ready to go. - virtual bool Init(uint32_t argc, const char* argn[], const char* argv[]); - - // Called whenever the in-browser window changes size. - virtual void DidChangeView(const pp::Rect& position, const pp::Rect& clip); - - // Called by the browser to handle the postMessage() call in Javascript. - virtual void HandleMessage(const pp::Var& message); - - // Bind and publish the module's methods to JavaScript. - void InitializeMethods(ScriptingBridge* bridge); - - // Set the camera orientation to the quaternion in |args[0]|. |args| must - // have length at least 1; the first element is expeted to be an Array - // object containing 4 floating point number elements (the quaternion). - // This method is bound to the JavaScript "setCameraOrientation" method and - // is called like this: - // module.setCameraOrientation([0.0, 1.0, 0.0, 0.0]); - void SetCameraOrientation( - const tumbler::ScriptingBridge& bridge, - const tumbler::MethodParameter& parameters); - - // Called to draw the contents of the module's browser area. - void DrawSelf(); - - private: - // Browser connectivity and scripting support. - ScriptingBridge scripting_bridge_; - - SharedOpenGLContext opengl_context_; - // Wouldn't it be awesome if we had boost::scoped_ptr<>? - Cube* cube_; -}; - -} // namespace tumbler - -#endif // EXAMPLES_TUMBLER_TUMBLER_H_ diff --git a/Demos/NativeClient/tumbler_module.cc b/Demos/NativeClient/tumbler_module.cc deleted file mode 100644 index e58d73e46..000000000 --- a/Demos/NativeClient/tumbler_module.cc +++ /dev/null @@ -1,45 +0,0 @@ -// Copyright (c) 2011 The Native Client Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "tumbler.h" -#include "ppapi/cpp/instance.h" -#include "ppapi/cpp/module.h" -#include "ppapi/gles2/gl2ext_ppapi.h" - -/// The Module class. The browser calls the CreateInstance() method to create -/// an instance of your NaCl module on the web page. The browser creates a new -/// instance for each tag with type="application/x-nacl". -class TumberModule : public pp::Module { - public: - TumberModule() : pp::Module() {} - virtual ~TumberModule() { - glTerminatePPAPI(); - } - - /// Called by the browser when the module is first loaded and ready to run. - /// This is called once per module, not once per instance of the module on - /// the page. - virtual bool Init() { - return glInitializePPAPI(get_browser_interface()) == GL_TRUE; - } - - /// Create and return a Tumbler instance object. - /// @param[in] instance The browser-side instance. - /// @return the plugin-side instance. - virtual pp::Instance* CreateInstance(PP_Instance instance) { - return new tumbler::Tumbler(instance); - } -}; - -namespace pp { -/// Factory function called by the browser when the module is first loaded. -/// The browser keeps a singleton of this module. It calls the -/// CreateInstance() method on the object you return to make instances. There -/// is one instance per tag on the page. This is the main binding -/// point for your NaCl module with the browser. -Module* CreateModule() { - return new TumberModule(); -} -} // namespace pp - diff --git a/Demos/OpenGL/CMakeLists.txt b/Demos/OpenGL/CMakeLists.txt deleted file mode 100644 index 721ec4e99..000000000 --- a/Demos/OpenGL/CMakeLists.txt +++ /dev/null @@ -1,68 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - - -# You shouldn't have to modify anything below this line -######################################################## - - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Extras/ConvexHull -${GLUT_INCLUDE_DIR} -) - - -ADD_LIBRARY(OpenGLSupport - GLDebugFont.cpp - GLDebugFont.h - GL_DialogDynamicsWorld.cpp - GL_DialogDynamicsWorld.h - GL_DialogWindow.cpp - GL_DialogWindow.h - GL_ShapeDrawer.cpp - GL_ShapeDrawer.h - GL_Simplex1to4.cpp - GL_Simplex1to4.h - GLDebugDrawer.cpp - GLDebugDrawer.h - - RenderTexture.cpp - RenderTexture.h - DemoApplication.cpp - DemoApplication.h - - GlutDemoApplication.cpp - GlutDemoApplication.h - GlutStuff.cpp - GlutStuff.h - - stb_image.cpp - stb_image.h - - Win32DemoApplication.cpp - Win32DemoApplication.h -) - - -IF (BUILD_SHARED_LIBS) - TARGET_LINK_LIBRARIES(OpenGLSupport BulletDynamics BulletCollision ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}) -ENDIF (BUILD_SHARED_LIBS) - -#INSTALL of other files requires CMake 2.6 -IF (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 2.5) - IF(INSTALL_EXTRA_LIBS) - IF (APPLE AND BUILD_SHARED_LIBS AND FRAMEWORK) - INSTALL(TARGETS OpenGLSupport DESTINATION .) - ELSE (APPLE AND BUILD_SHARED_LIBS AND FRAMEWORK) - INSTALL(TARGETS OpenGLSupport DESTINATION lib) - INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} DESTINATION include FILES_MATCHING PATTERN "*.h") - ENDIF (APPLE AND BUILD_SHARED_LIBS AND FRAMEWORK) - ENDIF (INSTALL_EXTRA_LIBS) -ENDIF (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 2.5) diff --git a/Demos/OpenGL/CommandLineArguments.h b/Demos/OpenGL/CommandLineArguments.h deleted file mode 100644 index e24ad99b6..000000000 --- a/Demos/OpenGL/CommandLineArguments.h +++ /dev/null @@ -1,112 +0,0 @@ -/****************************************************************************** - * Copyright 2010 Duane Merrill - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - * - * For more information, see our Google Code project site: - * http://code.google.com/p/back40computing/ - * - * Thanks! - ******************************************************************************/ - -#ifndef COMMAND_LINE_ARGS_H -#define COMMAND_LINE_ARGS_H - -/****************************************************************************** - * Command-line parsing - ******************************************************************************/ -#include -#include -#include -#include -class CommandLineArguments -{ -protected: - - std::map pairs; - -public: - - // Constructor - CommandLineArguments(int argc, char **argv) - { - using namespace std; - - for (int i = 1; i < argc; i++) - { - string arg = argv[i]; - - if ((arg[0] != '-') || (arg[1] != '-')) { - continue; - } - - string::size_type pos; - string key, val; - if ((pos = arg.find( '=')) == string::npos) { - key = string(arg, 2, arg.length() - 2); - val = ""; - } else { - key = string(arg, 2, pos - 2); - val = string(arg, pos + 1, arg.length() - 1); - } - pairs[key] = val; - } - } - - bool CheckCmdLineFlag(const char* arg_name) - { - using namespace std; - map::iterator itr; - if ((itr = pairs.find(arg_name)) != pairs.end()) { - return true; - } - return false; - } - - template - void GetCmdLineArgument(const char *arg_name, T &val); - - int ParsedArgc() - { - return pairs.size(); - } -}; - -template -void CommandLineArguments::GetCmdLineArgument(const char *arg_name, T &val) -{ - using namespace std; - map::iterator itr; - if ((itr = pairs.find(arg_name)) != pairs.end()) { - istringstream strstream(itr->second); - strstream >> val; - } -} - -template <> -void CommandLineArguments::GetCmdLineArgument(const char* arg_name, char* &val) -{ - using namespace std; - map::iterator itr; - if ((itr = pairs.find(arg_name)) != pairs.end()) { - - string s = itr->second; - val = (char*) malloc(sizeof(char) * (s.length() + 1)); - strcpy(val, s.c_str()); - - } else { - val = NULL; - } -} - -#endif //COMMAND_LINE_ARGS_H diff --git a/Demos/OpenGL/DebugCastResult.h b/Demos/OpenGL/DebugCastResult.h deleted file mode 100644 index ee476bf9f..000000000 --- a/Demos/OpenGL/DebugCastResult.h +++ /dev/null @@ -1,88 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef DEBUG_CAST_RESULT_H -#define DEBUG_CAST_RESULT_H - -#include "BulletCollision/NarrowPhaseCollision/btConvexCast.h" -#include "LinearMath/btTransform.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" -#ifdef WIN32 -#include -#endif -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#else -#include -#endif -struct btDebugCastResult : public btConvexCast::CastResult -{ - - btTransform m_fromTrans; - const btPolyhedralConvexShape* m_shape; - btVector3 m_linVel; - btVector3 m_angVel; - GL_ShapeDrawer* m_shapeDrawer; - - btDebugCastResult(const btTransform& fromTrans,const btPolyhedralConvexShape* shape, - const btVector3& linVel,const btVector3& angVel,GL_ShapeDrawer* drawer) - :m_fromTrans(fromTrans), - m_shape(shape), - m_linVel(linVel), - m_angVel(angVel), - m_shapeDrawer(drawer) - { - } - - virtual void drawCoordSystem(const btTransform& tr) - { - btScalar m[16]; - tr.getOpenGLMatrix(m); - glPushMatrix(); - btglLoadMatrix(m); - glBegin(GL_LINES); - btglColor3(1, 0, 0); - btglVertex3(0, 0, 0); - btglVertex3(1, 0, 0); - btglColor3(0, 1, 0); - btglVertex3(0, 0, 0); - btglVertex3(0, 1, 0); - btglColor3(0, 0, 1); - btglVertex3(0, 0, 0); - btglVertex3(0, 0, 1); - glEnd(); - glPopMatrix(); - } - - virtual void DebugDraw(btScalar fraction) - { - btVector3 worldBoundsMin(-1000,-1000,-1000); - btVector3 worldBoundsMax(1000,1000,1000); - - - ATTRIBUTE_ALIGNED16(btScalar) m[16]; - btTransform hitTrans; - btTransformUtil::integrateTransform(m_fromTrans,m_linVel,m_angVel,fraction,hitTrans); - hitTrans.getOpenGLMatrix(m); - if (m_shapeDrawer) - m_shapeDrawer->drawOpenGL(m,m_shape,btVector3(1,0,0),btIDebugDraw::DBG_NoDebug,worldBoundsMin,worldBoundsMax); - } -}; - - -#endif //DEBUG_CAST_RESULT_H diff --git a/Demos/OpenGL/DemoApplication.cpp b/Demos/OpenGL/DemoApplication.cpp deleted file mode 100644 index 317166ed2..000000000 --- a/Demos/OpenGL/DemoApplication.cpp +++ /dev/null @@ -1,1464 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - -#include "DemoApplication.h" -#include "LinearMath/btIDebugDraw.h" -#include "BulletDynamics/Dynamics/btDynamicsWorld.h" - -#include "BulletDynamics/ConstraintSolver/btPoint2PointConstraint.h"//picking -#include "BulletDynamics/ConstraintSolver/btGeneric6DofConstraint.h"//picking - -#include "BulletCollision/CollisionShapes/btCollisionShape.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/CollisionShapes/btSphereShape.h" -#include "BulletCollision/CollisionShapes/btCompoundShape.h" -#include "BulletCollision/CollisionShapes/btUniformScalingShape.h" -#include "BulletDynamics/ConstraintSolver/btConstraintSolver.h" -#include "GL_ShapeDrawer.h" -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btDefaultMotionState.h" -#include "LinearMath/btSerializer.h" -#include "GLDebugFont.h" - - -extern bool gDisableDeactivation; -int numObjects = 0; -const int maxNumObjects = 16384; -btTransform startTransforms[maxNumObjects]; -btCollisionShape* gShapePtr[maxNumObjects];//1 rigidbody has 1 shape (no re-use of shapes) -#define SHOW_NUM_DEEP_PENETRATIONS 1 - -extern int gNumClampedCcdMotions; - -#ifdef SHOW_NUM_DEEP_PENETRATIONS -extern int gNumDeepPenetrationChecks; - -extern int gNumSplitImpulseRecoveries; -extern int gNumGjkChecks; -extern int gNumAlignedAllocs; -extern int gNumAlignedFree; -extern int gTotalBytesAlignedAllocs; - -#endif // - - -DemoApplication::DemoApplication() -//see btIDebugDraw.h for modes -: -m_dynamicsWorld(0), -m_pickConstraint(0), -m_shootBoxShape(0), -m_cameraDistance(15.0), -m_debugMode(0), -m_ele(20.f), -m_azi(0.f), -m_cameraPosition(0.f,0.f,0.f), -m_cameraTargetPosition(0.f,0.f,0.f), -m_mouseOldX(0), -m_mouseOldY(0), -m_mouseButtons(0), -m_modifierKeys(0), -m_scaleBottom(0.5f), -m_scaleFactor(2.f), -m_cameraUp(0,1,0), -m_forwardAxis(2), -m_zoomStepSize(0.4), -m_glutScreenWidth(0), -m_glutScreenHeight(0), -m_frustumZNear(1.f), -m_frustumZFar(10000.f), -m_ortho(0), -m_ShootBoxInitialSpeed(40.f), -m_stepping(true), -m_singleStep(false), -m_idle(false), - -m_enableshadows(false), -m_sundirection(btVector3(1,-2,1)*1000), -m_defaultContactProcessingThreshold(BT_LARGE_FLOAT) -{ -#ifndef BT_NO_PROFILE - m_profileIterator = CProfileManager::Get_Iterator(); -#endif //BT_NO_PROFILE - - m_shapeDrawer = new GL_ShapeDrawer (); - m_shapeDrawer->enableTexture(true); - m_enableshadows = false; -} - - - -DemoApplication::~DemoApplication() -{ -#ifndef BT_NO_PROFILE - CProfileManager::Release_Iterator(m_profileIterator); -#endif //BT_NO_PROFILE - - if (m_shootBoxShape) - delete m_shootBoxShape; - - if (m_shapeDrawer) - delete m_shapeDrawer; - - //GLDebugResetFont(0,0); -} - - -void DemoApplication::overrideGLShapeDrawer (GL_ShapeDrawer* shapeDrawer) -{ - shapeDrawer->enableTexture (m_shapeDrawer->hasTextureEnabled()); - delete m_shapeDrawer; - m_shapeDrawer = shapeDrawer; -} - -void DemoApplication::myinit(void) -{ - - GLfloat light_ambient[] = { btScalar(0.2), btScalar(0.2), btScalar(0.2), btScalar(1.0) }; - GLfloat light_diffuse[] = { btScalar(1.0), btScalar(1.0), btScalar(1.0), btScalar(1.0) }; - GLfloat light_specular[] = { btScalar(1.0), btScalar(1.0), btScalar(1.0), btScalar(1.0 )}; - /* light_position is NOT default value */ - GLfloat light_position0[] = { btScalar(1.0), btScalar(10.0), btScalar(1.0), btScalar(0.0 )}; - GLfloat light_position1[] = { btScalar(-1.0), btScalar(-10.0), btScalar(-1.0), btScalar(0.0) }; - - glLightfv(GL_LIGHT0, GL_AMBIENT, light_ambient); - glLightfv(GL_LIGHT0, GL_DIFFUSE, light_diffuse); - glLightfv(GL_LIGHT0, GL_SPECULAR, light_specular); - glLightfv(GL_LIGHT0, GL_POSITION, light_position0); - - glLightfv(GL_LIGHT1, GL_AMBIENT, light_ambient); - glLightfv(GL_LIGHT1, GL_DIFFUSE, light_diffuse); - glLightfv(GL_LIGHT1, GL_SPECULAR, light_specular); - glLightfv(GL_LIGHT1, GL_POSITION, light_position1); - - glEnable(GL_LIGHTING); - glEnable(GL_LIGHT0); - glEnable(GL_LIGHT1); - - - glShadeModel(GL_SMOOTH); - glEnable(GL_DEPTH_TEST); - glDepthFunc(GL_LESS); - - glClearColor(btScalar(0.7),btScalar(0.7),btScalar(0.7),btScalar(0)); - - // glEnable(GL_CULL_FACE); - // glCullFace(GL_BACK); -} - - -void DemoApplication::setCameraDistance(float dist) -{ - m_cameraDistance = dist; -} - -float DemoApplication::getCameraDistance() -{ - return m_cameraDistance; -} - - - -void DemoApplication::toggleIdle() { - if (m_idle) { - m_idle = false; - } - else { - m_idle = true; - } -} - -void bCreateDiagonalMatrix(GLfloat value, GLfloat result[4][4]) -{ - for (int i=0;i<4;i++) - { - for (int j=0;j<4;j++) - { - if (i==j) - { - result[i][j] = value; - } else - { - result[i][j] = 0.f; - } - } - } -} - -void bCreateOrtho(GLfloat left, GLfloat right, GLfloat bottom, GLfloat top, GLfloat zNear, GLfloat zFar, GLfloat result[4][4]) -{ - bCreateDiagonalMatrix(1.f,result); - - result[0][0] = 2.f / (right - left); - result[1][1] = 2.f / (top - bottom); - result[2][2] = - 2.f / (zFar - zNear); - result[3][0] = - (right + left) / (right - left); - result[3][1] = - (top + bottom) / (top - bottom); - result[3][2] = - (zFar + zNear) / (zFar - zNear); -} - -void bCreateLookAt(const btVector3& eye, const btVector3& center,const btVector3& up, GLfloat result[16]) -{ - btVector3 f = (center - eye).normalized(); - btVector3 u = up.normalized(); - btVector3 s = (f.cross(u)).normalized(); - u = s.cross(f); - - result[0*4+0] = s.x(); - result[1*4+0] = s.y(); - result[2*4+0] = s.z(); - - result[0*4+1] = u.x(); - result[1*4+1] = u.y(); - result[2*4+1] = u.z(); - - result[0*4+2] =-f.x(); - result[1*4+2] =-f.y(); - result[2*4+2] =-f.z(); - - result[0*4+3] = 0.f; - result[1*4+3] = 0.f; - result[2*4+3] = 0.f; - - result[3*4+0] = -s.dot(eye); - result[3*4+1] = -u.dot(eye); - result[3*4+2] = f.dot(eye); - result[3*4+3] = 1.f; -} - - -void DemoApplication::updateCamera() { - - - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - btScalar rele = m_ele * btScalar(0.01745329251994329547);// rads per deg - btScalar razi = m_azi * btScalar(0.01745329251994329547);// rads per deg - - - btQuaternion rot(m_cameraUp,razi); - - - btVector3 eyePos(0,0,0); - eyePos[m_forwardAxis] = -m_cameraDistance; - - btVector3 forward(eyePos[0],eyePos[1],eyePos[2]); - if (forward.length2() < SIMD_EPSILON) - { - forward.setValue(1.f,0.f,0.f); - } - btVector3 right = m_cameraUp.cross(forward); - btQuaternion roll(right,-rele); - - eyePos = btMatrix3x3(rot) * btMatrix3x3(roll) * eyePos; - - m_cameraPosition[0] = eyePos.getX(); - m_cameraPosition[1] = eyePos.getY(); - m_cameraPosition[2] = eyePos.getZ(); - m_cameraPosition += m_cameraTargetPosition; - - if (m_glutScreenWidth == 0 && m_glutScreenHeight == 0) - return; - - btScalar aspect; - btVector3 extents; - - aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight; - extents.setValue(aspect * 1.0f, 1.0f,0); - - - if (m_ortho) - { - // reset matrix - glLoadIdentity(); - - - extents *= m_cameraDistance; - btVector3 lower = m_cameraTargetPosition - extents; - btVector3 upper = m_cameraTargetPosition + extents; - //gluOrtho2D(lower.x, upper.x, lower.y, upper.y); - glOrtho(lower.getX(), upper.getX(), lower.getY(), upper.getY(),-1000,1000); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - //glTranslatef(100,210,0); - } else - { -// glFrustum (-aspect, aspect, -1.0, 1.0, 1.0, 10000.0); - glFrustum (-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar); - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - GLfloat resultMat[16]; - bCreateLookAt(m_cameraPosition,m_cameraTargetPosition, m_cameraUp, resultMat); - glMultMatrixf(resultMat); - } - -} - - - -const float STEPSIZE = 5; - -void DemoApplication::stepLeft() -{ - m_azi -= STEPSIZE; if (m_azi < 0) m_azi += 360; updateCamera(); -} -void DemoApplication::stepRight() -{ - m_azi += STEPSIZE; if (m_azi >= 360) m_azi -= 360; updateCamera(); -} -void DemoApplication::stepFront() -{ - m_ele += STEPSIZE; if (m_ele >= 360) m_ele -= 360; updateCamera(); -} -void DemoApplication::stepBack() -{ - m_ele -= STEPSIZE; if (m_ele < 0) m_ele += 360; updateCamera(); -} -void DemoApplication::zoomIn() -{ - m_cameraDistance -= btScalar(m_zoomStepSize); updateCamera(); - if (m_cameraDistance < btScalar(0.1)) - m_cameraDistance = btScalar(0.1); - -} -void DemoApplication::zoomOut() -{ - m_cameraDistance += btScalar(m_zoomStepSize); updateCamera(); - -} - - - - - - - - - - -void DemoApplication::reshape(int w, int h) -{ - GLDebugResetFont(w,h); - - m_glutScreenWidth = w; - m_glutScreenHeight = h; - - glViewport(0, 0, w, h); - updateCamera(); -} - - - -void DemoApplication::keyboardCallback(unsigned char key, int x, int y) -{ - (void)x; - (void)y; - - m_lastKey = 0; - -#ifndef BT_NO_PROFILE - if (key >= 0x31 && key <= 0x39) - { - int child = key-0x31; - m_profileIterator->Enter_Child(child); - } - if (key==0x30) - { - m_profileIterator->Enter_Parent(); - } -#endif //BT_NO_PROFILE - - switch (key) - { - case 8: - { - int numObj = getDynamicsWorld()->getNumCollisionObjects(); - if (numObj) - { - btCollisionObject* obj = getDynamicsWorld()->getCollisionObjectArray()[numObj-1]; - - getDynamicsWorld()->removeCollisionObject(obj); - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - delete obj; - - - } - break; - } - case 'q' : -#ifdef BT_USE_FREEGLUT - //return from glutMainLoop(), detect memory leaks etc. - glutLeaveMainLoop(); -#else - exit(0); -#endif - break; - - case 'l' : stepLeft(); break; - case 'r' : stepRight(); break; - case 'f' : stepFront(); break; - case 'b' : stepBack(); break; - case 'z' : zoomIn(); break; - case 'x' : zoomOut(); break; - case 'i' : toggleIdle(); break; - case 'g' : m_enableshadows=!m_enableshadows;break; - case 'u' : m_shapeDrawer->enableTexture(!m_shapeDrawer->enableTexture(false));break; - case 'h': - if (m_debugMode & btIDebugDraw::DBG_NoHelpText) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_NoHelpText); - else - m_debugMode |= btIDebugDraw::DBG_NoHelpText; - break; - - case 'w': - if (m_debugMode & btIDebugDraw::DBG_DrawWireframe) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawWireframe); - else - m_debugMode |= btIDebugDraw::DBG_DrawWireframe; - break; - - case 'p': - if (m_debugMode & btIDebugDraw::DBG_ProfileTimings) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_ProfileTimings); - else - m_debugMode |= btIDebugDraw::DBG_ProfileTimings; - break; - - case '\\': - { - int maxSerializeBufferSize = 1024*1024*5; - btDefaultSerializer* serializer = new btDefaultSerializer(maxSerializeBufferSize); - //serializer->setSerializationFlags(BT_SERIALIZE_NO_DUPLICATE_ASSERT); - m_dynamicsWorld->serialize(serializer); - FILE* f2 = fopen("testFile.bullet","wb"); - fwrite(serializer->getBufferPointer(),serializer->getCurrentBufferSize(),1,f2); - fclose(f2); - delete serializer; - break; - - } - - case 'm': - if (m_debugMode & btIDebugDraw::DBG_EnableSatComparison) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_EnableSatComparison); - else - m_debugMode |= btIDebugDraw::DBG_EnableSatComparison; - break; - - case 'n': - if (m_debugMode & btIDebugDraw::DBG_DisableBulletLCP) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DisableBulletLCP); - else - m_debugMode |= btIDebugDraw::DBG_DisableBulletLCP; - break; - case 'N': - if (m_debugMode & btIDebugDraw::DBG_DrawNormals) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawNormals); - else - m_debugMode |= btIDebugDraw::DBG_DrawNormals; - break; - - case 't' : - if (m_debugMode & btIDebugDraw::DBG_DrawText) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawText); - else - m_debugMode |= btIDebugDraw::DBG_DrawText; - break; - case 'y': - if (m_debugMode & btIDebugDraw::DBG_DrawFeaturesText) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawFeaturesText); - else - m_debugMode |= btIDebugDraw::DBG_DrawFeaturesText; - break; - case 'a': - if (m_debugMode & btIDebugDraw::DBG_DrawAabb) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawAabb); - else - m_debugMode |= btIDebugDraw::DBG_DrawAabb; - break; - case 'c' : - if (m_debugMode & btIDebugDraw::DBG_DrawContactPoints) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawContactPoints); - else - m_debugMode |= btIDebugDraw::DBG_DrawContactPoints; - break; - case 'C' : - if (m_debugMode & btIDebugDraw::DBG_DrawConstraints) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawConstraints); - else - m_debugMode |= btIDebugDraw::DBG_DrawConstraints; - break; - case 'L' : - if (m_debugMode & btIDebugDraw::DBG_DrawConstraintLimits) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_DrawConstraintLimits); - else - m_debugMode |= btIDebugDraw::DBG_DrawConstraintLimits; - break; - - case 'd' : - if (m_debugMode & btIDebugDraw::DBG_NoDeactivation) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_NoDeactivation); - else - m_debugMode |= btIDebugDraw::DBG_NoDeactivation; - if (m_debugMode & btIDebugDraw::DBG_NoDeactivation) - { - gDisableDeactivation = true; - } else - { - gDisableDeactivation = false; - } - break; - - - - - case 'o' : - { - m_ortho = !m_ortho;//m_stepping = !m_stepping; - break; - } - case 's' : clientMoveAndDisplay(); break; - // case ' ' : newRandom(); break; - case ' ': - clientResetScene(); - break; - case '1': - { - if (m_debugMode & btIDebugDraw::DBG_EnableCCD) - m_debugMode = m_debugMode & (~btIDebugDraw::DBG_EnableCCD); - else - m_debugMode |= btIDebugDraw::DBG_EnableCCD; - break; - } - - case '.': - { - shootBox(getRayTo(x,y));//getCameraTargetPosition()); - break; - } - - case '+': - { - m_ShootBoxInitialSpeed += 10.f; - break; - } - case '-': - { - m_ShootBoxInitialSpeed -= 10.f; - break; - } - - default: - // std::cout << "unused key : " << key << std::endl; - break; - } - - if (getDynamicsWorld() && getDynamicsWorld()->getDebugDrawer()) - getDynamicsWorld()->getDebugDrawer()->setDebugMode(m_debugMode); - - - -} - -void DemoApplication::setDebugMode(int mode) -{ - m_debugMode = mode; - if (getDynamicsWorld() && getDynamicsWorld()->getDebugDrawer()) - getDynamicsWorld()->getDebugDrawer()->setDebugMode(mode); -} - - - - - - -void DemoApplication::moveAndDisplay() -{ - if (!m_idle) - clientMoveAndDisplay(); - else - displayCallback(); -} - - - - -void DemoApplication::displayCallback() -{ -} - -#define NUM_SPHERES_ON_DIAGONAL 9 - -void DemoApplication::setShootBoxShape () -{ - if (!m_shootBoxShape) - { - btBoxShape* box = new btBoxShape(btVector3(0.5,0.5,0.5)); - // box->initializePolyhedralFeatures(); - m_shootBoxShape = box; - } -} - -void DemoApplication::shootBox(const btVector3& destination) -{ - - if (m_dynamicsWorld) - { - float mass = 1.f; - btTransform startTransform; - startTransform.setIdentity(); - btVector3 camPos = getCameraPosition(); - startTransform.setOrigin(camPos); - - setShootBoxShape (); - - btRigidBody* body = this->localCreateRigidBody(mass, startTransform,m_shootBoxShape); - body->setLinearFactor(btVector3(1,1,1)); - //body->setRestitution(1); - - btVector3 linVel(destination[0]-camPos[0],destination[1]-camPos[1],destination[2]-camPos[2]); - linVel.normalize(); - linVel*=m_ShootBoxInitialSpeed; - - body->getWorldTransform().setOrigin(camPos); - body->getWorldTransform().setRotation(btQuaternion(0,0,0,1)); - body->setLinearVelocity(linVel); - body->setAngularVelocity(btVector3(0,0,0)); - body->setCcdMotionThreshold(0.5); - body->setCcdSweptSphereRadius(0.4f);//value should be smaller (embedded) than the half extends of the box (see ::setShootBoxShape) -// printf("shootBox uid=%d\n", body->getBroadphaseHandle()->getUid()); -// printf("camPos=%f,%f,%f\n",camPos.getX(),camPos.getY(),camPos.getZ()); -// printf("destination=%f,%f,%f\n",destination.getX(),destination.getY(),destination.getZ()); - - } -} - - -int gPickingConstraintId = 0; -btVector3 gOldPickingPos; -btVector3 gHitPos(-1,-1,-1); -btScalar gOldPickingDist = 0.f; -btRigidBody* pickedBody = 0;//for deactivation state - - -btVector3 DemoApplication::getRayTo(int x,int y) -{ - - - - if (m_ortho) - { - - btScalar aspect; - btVector3 extents; - aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight; - extents.setValue(aspect * 1.0f, 1.0f,0); - - extents *= m_cameraDistance; - btVector3 lower = m_cameraTargetPosition - extents; - btVector3 upper = m_cameraTargetPosition + extents; - - btScalar u = x / btScalar(m_glutScreenWidth); - btScalar v = (m_glutScreenHeight - y) / btScalar(m_glutScreenHeight); - - btVector3 p(0,0,0); - p.setValue((1.0f - u) * lower.getX() + u * upper.getX(),(1.0f - v) * lower.getY() + v * upper.getY(),m_cameraTargetPosition.getZ()); - return p; - } - - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float tanFov = (top-bottom)*0.5f / nearPlane; - float fov = btScalar(2.0) * btAtan(tanFov); - - btVector3 rayFrom = getCameraPosition(); - btVector3 rayForward = (getCameraTargetPosition()-getCameraPosition()); - rayForward.normalize(); - float farPlane = 10000.f; - rayForward*= farPlane; - - btVector3 rightOffset; - btVector3 vertical = m_cameraUp; - - btVector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - btScalar aspect; - - aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight; - - hor*=aspect; - - - btVector3 rayToCenter = rayFrom + rayForward; - btVector3 dHor = hor * 1.f/float(m_glutScreenWidth); - btVector3 dVert = vertical * 1.f/float(m_glutScreenHeight); - - - btVector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += btScalar(x) * dHor; - rayTo -= btScalar(y) * dVert; - return rayTo; -} - -btScalar mousePickClamping = 30.f; - - -void DemoApplication::mouseFunc(int button, int state, int x, int y) -{ - if (state == 0) - { - m_mouseButtons |= 1<rayTest(m_cameraPosition,rayTo,rayCallback); - if (rayCallback.hasHit()) - { - - btRigidBody* body = btRigidBody::upcast(rayCallback.m_collisionObject); - if (body) - { - body->setActivationState(ACTIVE_TAG); - btVector3 impulse = rayTo; - impulse.normalize(); - float impulseStrength = 10.f; - impulse *= impulseStrength; - btVector3 relPos = rayCallback.m_hitPointWorld - body->getCenterOfMassPosition(); - body->applyImpulse(impulse,relPos); - } - } - } -#endif - - - - } else - { - - } - break; - } - case 0: - { - if (state==0) - { - - - //add a point to point constraint for picking - if (m_dynamicsWorld) - { - - btVector3 rayFrom; - if (m_ortho) - { - rayFrom = rayTo; - rayFrom.setZ(-100.f); - } else - { - rayFrom = m_cameraPosition; - } - - btCollisionWorld::ClosestRayResultCallback rayCallback(rayFrom,rayTo); - m_dynamicsWorld->rayTest(rayFrom,rayTo,rayCallback); - if (rayCallback.hasHit()) - { - - btVector3 pickPos = rayCallback.m_hitPointWorld; - - pickObject(pickPos, rayCallback.m_collisionObject); - - gOldPickingPos = rayTo; - gHitPos = pickPos; - - gOldPickingDist = (pickPos-rayFrom).length(); - } - } - - } else - { - removePickingConstraint(); - } - - break; - - } - default: - { - } - } - -} - -void DemoApplication::pickObject(const btVector3& pickPos, const btCollisionObject* hitObj) -{ - - btRigidBody* body = (btRigidBody*)btRigidBody::upcast(hitObj); - if (body) - { - //other exclusions? - if (!(body->isStaticObject() || body->isKinematicObject())) - { - pickedBody = body; - pickedBody->setActivationState(DISABLE_DEACTIVATION); - - - //printf("pickPos=%f,%f,%f\n",pickPos.getX(),pickPos.getY(),pickPos.getZ()); - - - btVector3 localPivot = body->getCenterOfMassTransform().inverse() * pickPos; - - if ((m_modifierKeys& BT_ACTIVE_SHIFT)!=0) - { - btTransform tr; - tr.setIdentity(); - tr.setOrigin(localPivot); - btGeneric6DofConstraint* dof6 = new btGeneric6DofConstraint(*body, tr,false); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - dof6->setAngularLowerLimit(btVector3(0,0,0)); - dof6->setAngularUpperLimit(btVector3(0,0,0)); - - m_dynamicsWorld->addConstraint(dof6,true); - m_pickConstraint = dof6; - - dof6->setParam(BT_CONSTRAINT_STOP_CFM,0.8,0); - dof6->setParam(BT_CONSTRAINT_STOP_CFM,0.8,1); - dof6->setParam(BT_CONSTRAINT_STOP_CFM,0.8,2); - dof6->setParam(BT_CONSTRAINT_STOP_CFM,0.8,3); - dof6->setParam(BT_CONSTRAINT_STOP_CFM,0.8,4); - dof6->setParam(BT_CONSTRAINT_STOP_CFM,0.8,5); - - dof6->setParam(BT_CONSTRAINT_STOP_ERP,0.1,0); - dof6->setParam(BT_CONSTRAINT_STOP_ERP,0.1,1); - dof6->setParam(BT_CONSTRAINT_STOP_ERP,0.1,2); - dof6->setParam(BT_CONSTRAINT_STOP_ERP,0.1,3); - dof6->setParam(BT_CONSTRAINT_STOP_ERP,0.1,4); - dof6->setParam(BT_CONSTRAINT_STOP_ERP,0.1,5); - } else - { - btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*body,localPivot); - m_dynamicsWorld->addConstraint(p2p,true); - m_pickConstraint = p2p; - p2p->m_setting.m_impulseClamp = mousePickClamping; - //very weak constraint for picking - p2p->m_setting.m_tau = 0.001f; - /* - p2p->setParam(BT_CONSTRAINT_CFM,0.8,0); - p2p->setParam(BT_CONSTRAINT_CFM,0.8,1); - p2p->setParam(BT_CONSTRAINT_CFM,0.8,2); - p2p->setParam(BT_CONSTRAINT_ERP,0.1,0); - p2p->setParam(BT_CONSTRAINT_ERP,0.1,1); - p2p->setParam(BT_CONSTRAINT_ERP,0.1,2); - */ - - - } - - //save mouse position for dragging - - } - } - -} - -void DemoApplication::removePickingConstraint() -{ - if (m_pickConstraint && m_dynamicsWorld) - { - m_dynamicsWorld->removeConstraint(m_pickConstraint); - delete m_pickConstraint; - //printf("removed constraint %i",gPickingConstraintId); - m_pickConstraint = 0; - pickedBody->forceActivationState(ACTIVE_TAG); - pickedBody->setDeactivationTime( 0.f ); - pickedBody = 0; - } -} - -void DemoApplication::mouseMotionFunc(int x,int y) -{ - - if (m_pickConstraint) - { - //move the constraint pivot - - if (m_pickConstraint->getConstraintType() == D6_CONSTRAINT_TYPE) - { - btGeneric6DofConstraint* pickCon = static_cast(m_pickConstraint); - if (pickCon) - { - //keep it at the same picking distance - - btVector3 newRayTo = getRayTo(x,y); - btVector3 rayFrom; - btVector3 oldPivotInB = pickCon->getFrameOffsetA().getOrigin(); - - btVector3 newPivotB; - if (m_ortho) - { - newPivotB = oldPivotInB; - newPivotB.setX(newRayTo.getX()); - newPivotB.setY(newRayTo.getY()); - } else - { - rayFrom = m_cameraPosition; - btVector3 dir = newRayTo-rayFrom; - dir.normalize(); - dir *= gOldPickingDist; - - newPivotB = rayFrom + dir; - } - pickCon->getFrameOffsetA().setOrigin(newPivotB); - } - - } else - { - btPoint2PointConstraint* pickCon = static_cast(m_pickConstraint); - if (pickCon) - { - //keep it at the same picking distance - - btVector3 newRayTo = getRayTo(x,y); - btVector3 rayFrom; - btVector3 oldPivotInB = pickCon->getPivotInB(); - btVector3 newPivotB; - if (m_ortho) - { - newPivotB = oldPivotInB; - newPivotB.setX(newRayTo.getX()); - newPivotB.setY(newRayTo.getY()); - } else - { - rayFrom = m_cameraPosition; - btVector3 dir = newRayTo-rayFrom; - dir.normalize(); - dir *= gOldPickingDist; - - newPivotB = rayFrom + dir; - } - pickCon->setPivotB(newPivotB); - } - } - } - - float dx, dy; - dx = btScalar(x) - m_mouseOldX; - dy = btScalar(y) - m_mouseOldY; - - - ///only if ALT key is pressed (Maya style) - if (m_modifierKeys& BT_ACTIVE_ALT) - { - if(m_mouseButtons & 2) - { - btVector3 hor = getRayTo(0,0)-getRayTo(1,0); - btVector3 vert = getRayTo(0,0)-getRayTo(0,1); - btScalar multiplierX = btScalar(0.001); - btScalar multiplierY = btScalar(0.001); - if (m_ortho) - { - multiplierX = 1; - multiplierY = 1; - } - - - m_cameraTargetPosition += hor* dx * multiplierX; - m_cameraTargetPosition += vert* dy * multiplierY; - } - - if(m_mouseButtons & (2 << 2) && m_mouseButtons & 1) - { - } - else if(m_mouseButtons & 1) - { - m_azi += dx * btScalar(0.2); - m_azi = fmodf(m_azi, btScalar(360.f)); - m_ele += dy * btScalar(0.2); - m_ele = fmodf(m_ele, btScalar(180.f)); - } - else if(m_mouseButtons & 4) - { - m_cameraDistance -= dy * btScalar(0.02f); - if (m_cameraDistancegetShapeType() != INVALID_SHAPE_PROXYTYPE)); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - -#define USE_MOTIONSTATE 1 -#ifdef USE_MOTIONSTATE - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo cInfo(mass,myMotionState,shape,localInertia); - - btRigidBody* body = new btRigidBody(cInfo); - body->setContactProcessingThreshold(m_defaultContactProcessingThreshold); - -#else - btRigidBody* body = new btRigidBody(mass,0,shape,localInertia); - body->setWorldTransform(startTransform); -#endif// - - m_dynamicsWorld->addRigidBody(body); - - return body; -} - -//See http://www.lighthouse3d.com/opengl/glut/index.php?bmpfontortho -void DemoApplication::setOrthographicProjection() -{ - - // switch to projection mode - glMatrixMode(GL_PROJECTION); - - // save previous matrix which contains the - //settings for the perspective projection - glPushMatrix(); - // reset matrix - glLoadIdentity(); - // set a 2D orthographic projection - glOrtho(0, m_glutScreenWidth, 0, m_glutScreenHeight,-1000,1000); - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - - // invert the y axis, down is positive - glScalef(1, -1, 1); - // mover the origin from the bottom left corner - // to the upper left corner - glTranslatef(btScalar(0), btScalar(-m_glutScreenHeight), btScalar(0)); - -} - -void DemoApplication::resetPerspectiveProjection() -{ - - glMatrixMode(GL_PROJECTION); - glPopMatrix(); - glMatrixMode(GL_MODELVIEW); - updateCamera(); -} - - - - -extern CProfileIterator * m_profileIterator; - -void DemoApplication::displayProfileString(int xOffset,int yStart,char* message) -{ - glRasterPos3f(btScalar(xOffset),btScalar(yStart),btScalar(0)); - GLDebugDrawString(xOffset,yStart,message); -} - - -void DemoApplication::showProfileInfo(int& xOffset,int& yStart, int yIncr) -{ -#ifndef BT_NO_PROFILE - - static double time_since_reset = 0.f; - if (!m_idle) - { - time_since_reset = CProfileManager::Get_Time_Since_Reset(); - } - - - { - //recompute profiling data, and store profile strings - - char blockTime[128]; - - double totalTime = 0; - - int frames_since_reset = CProfileManager::Get_Frame_Count_Since_Reset(); - - m_profileIterator->First(); - - double parent_time = m_profileIterator->Is_Root() ? time_since_reset : m_profileIterator->Get_Current_Parent_Total_Time(); - - { - sprintf(blockTime,"--- Profiling: %s (total running time: %.3f ms) ---", m_profileIterator->Get_Current_Parent_Name(), parent_time ); - displayProfileString(xOffset,yStart,blockTime); - yStart += yIncr; - sprintf(blockTime,"press (1,2...) to display child timings, or 0 for parent" ); - displayProfileString(xOffset,yStart,blockTime); - yStart += yIncr; - - } - - - double accumulated_time = 0.f; - - for (int i = 0; !m_profileIterator->Is_Done(); m_profileIterator->Next()) - { - double current_total_time = m_profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - double fraction = parent_time > SIMD_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - - sprintf(blockTime,"%d -- %s (%.2f %%) :: %.3f ms / frame (%d calls)", - ++i, m_profileIterator->Get_Current_Name(), fraction, - (current_total_time / (double)frames_since_reset),m_profileIterator->Get_Current_Total_Calls()); - displayProfileString(xOffset,yStart,blockTime); - yStart += yIncr; - totalTime += current_total_time; - } - - sprintf(blockTime,"%s (%.3f %%) :: %.3f ms", "Unaccounted", - // (min(0, time_since_reset - totalTime) / time_since_reset) * 100); - parent_time > SIMD_EPSILON ? ((parent_time - accumulated_time) / parent_time) * 100 : 0.f, parent_time - accumulated_time); - - displayProfileString(xOffset,yStart,blockTime); - yStart += yIncr; - - - - sprintf(blockTime,"-------------------------------------------------"); - displayProfileString(xOffset,yStart,blockTime); - yStart += yIncr; - - } -#endif//BT_NO_PROFILE - - - - -} - - -// -void DemoApplication::renderscene(int pass) -{ - btScalar m[16]; - btMatrix3x3 rot;rot.setIdentity(); - const int numObjects=m_dynamicsWorld->getNumCollisionObjects(); - btVector3 wireColor(1,0,0); - for(int i=0;igetCollisionObjectArray()[i]; - btRigidBody* body=btRigidBody::upcast(colObj); - if(body&&body->getMotionState()) - { - btDefaultMotionState* myMotionState = (btDefaultMotionState*)body->getMotionState(); - myMotionState->m_graphicsWorldTrans.getOpenGLMatrix(m); - rot=myMotionState->m_graphicsWorldTrans.getBasis(); - } - else - { - colObj->getWorldTransform().getOpenGLMatrix(m); - rot=colObj->getWorldTransform().getBasis(); - } - btVector3 wireColor(1.f,1.0f,0.5f); //wants deactivation - if(i&1) wireColor=btVector3(0.f,0.0f,1.f); - ///color differently for active, sleeping, wantsdeactivation states - if (colObj->getActivationState() == 1) //active - { - if (i & 1) - { - wireColor += btVector3 (1.f,0.f,0.f); - } - else - { - wireColor += btVector3 (.5f,0.f,0.f); - } - } - if(colObj->getActivationState()==2) //ISLAND_SLEEPING - { - if(i&1) - { - wireColor += btVector3 (0.f,1.f, 0.f); - } - else - { - wireColor += btVector3 (0.f,0.5f,0.f); - } - } - - btVector3 aabbMin(0,0,0),aabbMax(0,0,0); - //m_dynamicsWorld->getBroadphase()->getBroadphaseAabb(aabbMin,aabbMax); - - aabbMin-=btVector3(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT); - aabbMax+=btVector3(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT); -// printf("aabbMin=(%f,%f,%f)\n",aabbMin.getX(),aabbMin.getY(),aabbMin.getZ()); -// printf("aabbMax=(%f,%f,%f)\n",aabbMax.getX(),aabbMax.getY(),aabbMax.getZ()); -// m_dynamicsWorld->getDebugDrawer()->drawAabb(aabbMin,aabbMax,btVector3(1,1,1)); - - - if (!(getDebugMode()& btIDebugDraw::DBG_DrawWireframe)) - { - switch(pass) - { - case 0: m_shapeDrawer->drawOpenGL(m,colObj->getCollisionShape(),wireColor,getDebugMode(),aabbMin,aabbMax);break; - case 1: m_shapeDrawer->drawShadow(m,m_sundirection*rot,colObj->getCollisionShape(),aabbMin,aabbMax);break; - case 2: m_shapeDrawer->drawOpenGL(m,colObj->getCollisionShape(),wireColor*btScalar(0.3),0,aabbMin,aabbMax);break; - } - } - } -} - -// -void DemoApplication::renderme() -{ - myinit(); - - updateCamera(); - - if (m_dynamicsWorld) - { - if(m_enableshadows) - { - glClear(GL_STENCIL_BUFFER_BIT); - glEnable(GL_CULL_FACE); - renderscene(0); - - glDisable(GL_LIGHTING); - glDepthMask(GL_FALSE); - glDepthFunc(GL_LEQUAL); - glEnable(GL_STENCIL_TEST); - glColorMask(GL_FALSE,GL_FALSE,GL_FALSE,GL_FALSE); - glStencilFunc(GL_ALWAYS,1,0xFFFFFFFFL); - glFrontFace(GL_CCW); - glStencilOp(GL_KEEP,GL_KEEP,GL_INCR); - renderscene(1); - glFrontFace(GL_CW); - glStencilOp(GL_KEEP,GL_KEEP,GL_DECR); - renderscene(1); - glFrontFace(GL_CCW); - - glPolygonMode(GL_FRONT,GL_FILL); - glPolygonMode(GL_BACK,GL_FILL); - glShadeModel(GL_SMOOTH); - glEnable(GL_DEPTH_TEST); - glDepthFunc(GL_LESS); - glEnable(GL_LIGHTING); - glDepthMask(GL_TRUE); - glCullFace(GL_BACK); - glFrontFace(GL_CCW); - glEnable(GL_CULL_FACE); - glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_TRUE); - - glDepthFunc(GL_LEQUAL); - glStencilFunc( GL_NOTEQUAL, 0, 0xFFFFFFFFL ); - glStencilOp( GL_KEEP, GL_KEEP, GL_KEEP ); - glDisable(GL_LIGHTING); - renderscene(2); - glEnable(GL_LIGHTING); - glDepthFunc(GL_LESS); - glDisable(GL_STENCIL_TEST); - glDisable(GL_CULL_FACE); - } - else - { - glDisable(GL_CULL_FACE); - renderscene(0); - } - - int xOffset = 10; - int yStart = 20; - int yIncr = 20; - - - glDisable(GL_LIGHTING); - glColor3f(0, 0, 0); - - if ((m_debugMode & btIDebugDraw::DBG_NoHelpText)==0) - { - setOrthographicProjection(); - - showProfileInfo(xOffset,yStart,yIncr); - -#ifdef USE_QUICKPROF - - - if ( getDebugMode() & btIDebugDraw::DBG_ProfileTimings) - { - static int counter = 0; - counter++; - std::map::iterator iter; - for (iter = btProfiler::mProfileBlocks.begin(); iter != btProfiler::mProfileBlocks.end(); ++iter) - { - char blockTime[128]; - sprintf(blockTime, "%s: %lf",&((*iter).first[0]),btProfiler::getBlockTime((*iter).first, btProfiler::BLOCK_CYCLE_SECONDS));//BLOCK_TOTAL_PERCENT)); - glRasterPos3f(xOffset,yStart,0); - GLDebugDrawString(BMF_GetFont(BMF_kHelvetica10),blockTime); - yStart += yIncr; - - } - - } -#endif //USE_QUICKPROF - - - - - resetPerspectiveProjection(); - } - - glDisable(GL_LIGHTING); - - - } - - updateCamera(); - -} - -#include "BulletCollision/BroadphaseCollision/btAxisSweep3.h" - - -void DemoApplication::clientResetScene() -{ - removePickingConstraint(); - -#ifdef SHOW_NUM_DEEP_PENETRATIONS - gNumDeepPenetrationChecks = 0; - gNumGjkChecks = 0; -#endif //SHOW_NUM_DEEP_PENETRATIONS - - gNumClampedCcdMotions = 0; - int numObjects = 0; - int i; - - if (m_dynamicsWorld) - { - int numConstraints = m_dynamicsWorld->getNumConstraints(); - for (i=0;igetConstraint(0)->setEnabled(true); - } - numObjects = m_dynamicsWorld->getNumCollisionObjects(); - - ///create a copy of the array, not a reference! - btCollisionObjectArray copyArray = m_dynamicsWorld->getCollisionObjectArray(); - - - - - for (i=0;igetMotionState()) - { - btDefaultMotionState* myMotionState = (btDefaultMotionState*)body->getMotionState(); - myMotionState->m_graphicsWorldTrans = myMotionState->m_startWorldTrans; - body->setCenterOfMassTransform( myMotionState->m_graphicsWorldTrans ); - colObj->setInterpolationWorldTransform( myMotionState->m_startWorldTrans ); - colObj->forceActivationState(ACTIVE_TAG); - colObj->activate(); - colObj->setDeactivationTime(0); - //colObj->setActivationState(WANTS_DEACTIVATION); - } - //removed cached contact points (this is not necessary if all objects have been removed from the dynamics world) - if (m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()) - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(colObj->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - - btRigidBody* body = btRigidBody::upcast(colObj); - if (body && !body->isStaticObject()) - { - btRigidBody::upcast(colObj)->setLinearVelocity(btVector3(0,0,0)); - btRigidBody::upcast(colObj)->setAngularVelocity(btVector3(0,0,0)); - } - } - - } - - ///reset some internal cached data in the broadphase - m_dynamicsWorld->getBroadphase()->resetPool(getDynamicsWorld()->getDispatcher()); - m_dynamicsWorld->getConstraintSolver()->reset(); - - } - -} diff --git a/Demos/OpenGL/DemoApplication.h b/Demos/OpenGL/DemoApplication.h deleted file mode 100644 index acbcc80e7..000000000 --- a/Demos/OpenGL/DemoApplication.h +++ /dev/null @@ -1,272 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef DEMO_APPLICATION_H -#define DEMO_APPLICATION_H - - -#include "GlutStuff.h" -#include "GL_ShapeDrawer.h" - -#include -#include -#include - - -#include "LinearMath/btVector3.h" -#include "LinearMath/btMatrix3x3.h" -#include "LinearMath/btTransform.h" -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btAlignedObjectArray.h" - -class btCollisionShape; -class btDynamicsWorld; -class btRigidBody; -class btTypedConstraint; - - - -class DemoApplication -{ -protected: - void displayProfileString(int xOffset,int yStart,char* message); - class CProfileIterator* m_profileIterator; - - protected: -#ifdef USE_BT_CLOCK - btClock m_clock; -#endif //USE_BT_CLOCK - - ///this is the most important class - btDynamicsWorld* m_dynamicsWorld; - - ///constraint for mouse picking - btTypedConstraint* m_pickConstraint; - - virtual void removePickingConstraint(); - - virtual void pickObject(const btVector3& pickPos, const class btCollisionObject* hitObj); - - - btCollisionShape* m_shootBoxShape; - - float m_cameraDistance; - int m_debugMode; - - float m_ele; - float m_azi; - btVector3 m_cameraPosition; - btVector3 m_cameraTargetPosition;//look at - - int m_mouseOldX; - int m_mouseOldY; - int m_mouseButtons; -public: - int m_modifierKeys; -protected: - - float m_scaleBottom; - float m_scaleFactor; - btVector3 m_cameraUp; - int m_forwardAxis; - float m_zoomStepSize; - - int m_glutScreenWidth; - int m_glutScreenHeight; - - float m_frustumZNear; - float m_frustumZFar; - - int m_ortho; - - float m_ShootBoxInitialSpeed; - - bool m_stepping; - bool m_singleStep; - bool m_idle; - int m_lastKey; - - void showProfileInfo(int& xOffset,int& yStart, int yIncr); - void renderscene(int pass); - - GL_ShapeDrawer* m_shapeDrawer; - bool m_enableshadows; - btVector3 m_sundirection; - btScalar m_defaultContactProcessingThreshold; - -public: - - DemoApplication(); - - virtual ~DemoApplication(); - - void setDynamicsWorld(btDynamicsWorld* world) - { - m_dynamicsWorld=world; - } - - - btDynamicsWorld* getDynamicsWorld() - { - return m_dynamicsWorld; - } - - virtual void initPhysics() = 0; - - virtual void setDrawClusters(bool drawClusters) - { - - } - - void overrideGLShapeDrawer (GL_ShapeDrawer* shapeDrawer); - - void setOrthographicProjection(); - void resetPerspectiveProjection(); - - bool setTexturing(bool enable) { return(m_shapeDrawer->enableTexture(enable)); } - bool setShadows(bool enable) { bool p=m_enableshadows;m_enableshadows=enable;return(p); } - bool getTexturing() const - { - return m_shapeDrawer->hasTextureEnabled(); - } - bool getShadows() const - { - return m_enableshadows; - } - - - int getDebugMode() - { - return m_debugMode ; - } - - void setDebugMode(int mode); - - void setAzi(float azi) - { - m_azi = azi; - } - - void setEle(float ele) - { - m_ele = ele; - } - - void setCameraUp(const btVector3& camUp) - { - m_cameraUp = camUp; - } - void setCameraForwardAxis(int axis) - { - m_forwardAxis = axis; - } - - virtual void myinit(); - - void toggleIdle(); - - virtual void updateCamera(); - - btVector3 getCameraPosition() - { - return m_cameraPosition; - } - btVector3 getCameraTargetPosition() - { - return m_cameraTargetPosition; - } - - btScalar getDeltaTimeMicroseconds() - { -#ifdef USE_BT_CLOCK - btScalar dt = (btScalar)m_clock.getTimeMicroseconds(); - m_clock.reset(); - return dt; -#else - return btScalar(16666.); -#endif - } - void setFrustumZPlanes(float zNear, float zFar) - { - m_frustumZNear = zNear; - m_frustumZFar = zFar; - } - - ///glut callbacks - - float getCameraDistance(); - void setCameraDistance(float dist); - void moveAndDisplay(); - - virtual void clientMoveAndDisplay() = 0; - - virtual void clientResetScene(); - - ///Demo functions - virtual void setShootBoxShape (); - virtual void shootBox(const btVector3& destination); - - - btVector3 getRayTo(int x,int y); - - btRigidBody* localCreateRigidBody(float mass, const btTransform& startTransform,btCollisionShape* shape); - - ///callback methods by glut - - virtual void keyboardCallback(unsigned char key, int x, int y); - - virtual void keyboardUpCallback(unsigned char key, int x, int y) {} - - virtual void specialKeyboard(int key, int x, int y){} - - virtual void specialKeyboardUp(int key, int x, int y){} - - virtual void reshape(int w, int h); - - virtual void mouseFunc(int button, int state, int x, int y); - - virtual void mouseMotionFunc(int x,int y); - - virtual void displayCallback(); - - virtual void renderme(); - - virtual void swapBuffers() = 0; - - virtual void updateModifierKeys() = 0; - - void stepLeft(); - void stepRight(); - void stepFront(); - void stepBack(); - void zoomIn(); - void zoomOut(); - - bool isIdle() const - { - return m_idle; - } - - void setIdle(bool idle) - { - m_idle = idle; - } - - -}; - -#endif //DEMO_APPLICATION_H - - diff --git a/Demos/OpenGL/GLDebugDrawer.cpp b/Demos/OpenGL/GLDebugDrawer.cpp deleted file mode 100644 index bddd135be..000000000 --- a/Demos/OpenGL/GLDebugDrawer.cpp +++ /dev/null @@ -1,130 +0,0 @@ - -#include "GLDebugDrawer.h" -#include "GLDebugFont.h" -#include "GlutStuff.h" - - - -#include //printf debugging -GLDebugDrawer::GLDebugDrawer() -:m_debugMode(0) -{ - -} - -GLDebugDrawer::~GLDebugDrawer() -{ -} - -void GLDebugDrawer::drawLine(const btVector3& from,const btVector3& to,const btVector3& fromColor, const btVector3& toColor) -{ - glBegin(GL_LINES); - glColor3f(fromColor.getX(), fromColor.getY(), fromColor.getZ()); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glColor3f(toColor.getX(), toColor.getY(), toColor.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - glEnd(); -} - -void GLDebugDrawer::drawLine(const btVector3& from,const btVector3& to,const btVector3& color) -{ - drawLine(from,to,color,color); -} - -void GLDebugDrawer::drawSphere (const btVector3& p, btScalar radius, const btVector3& color) -{ - glColor4f (color.getX(), color.getY(), color.getZ(), btScalar(1.0f)); - glPushMatrix (); - glTranslatef (p.getX(), p.getY(), p.getZ()); - - int lats = 5; - int longs = 5; - - int i, j; - for(i = 0; i <= lats; i++) { - btScalar lat0 = SIMD_PI * (-btScalar(0.5) + (btScalar) (i - 1) / lats); - btScalar z0 = radius*sin(lat0); - btScalar zr0 = radius*cos(lat0); - - btScalar lat1 = SIMD_PI * (-btScalar(0.5) + (btScalar) i / lats); - btScalar z1 = radius*sin(lat1); - btScalar zr1 = radius*cos(lat1); - - glBegin(GL_QUAD_STRIP); - for(j = 0; j <= longs; j++) { - btScalar lng = 2 * SIMD_PI * (btScalar) (j - 1) / longs; - btScalar x = cos(lng); - btScalar y = sin(lng); - - glNormal3f(x * zr0, y * zr0, z0); - glVertex3f(x * zr0, y * zr0, z0); - glNormal3f(x * zr1, y * zr1, z1); - glVertex3f(x * zr1, y * zr1, z1); - } - glEnd(); - } - - glPopMatrix(); -} - - - -void GLDebugDrawer::drawTriangle(const btVector3& a,const btVector3& b,const btVector3& c,const btVector3& color,btScalar alpha) -{ -// if (m_debugMode > 0) - { - const btVector3 n=btCross(b-a,c-a).normalized(); - glBegin(GL_TRIANGLES); - glColor4f(color.getX(), color.getY(), color.getZ(),alpha); - glNormal3d(n.getX(),n.getY(),n.getZ()); - glVertex3d(a.getX(),a.getY(),a.getZ()); - glVertex3d(b.getX(),b.getY(),b.getZ()); - glVertex3d(c.getX(),c.getY(),c.getZ()); - glEnd(); - } -} - -void GLDebugDrawer::setDebugMode(int debugMode) -{ - m_debugMode = debugMode; - -} - -void GLDebugDrawer::draw3dText(const btVector3& location,const char* textString) -{ - glRasterPos3f(location.x(), location.y(), location.z()); - //BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),textString); -} - -void GLDebugDrawer::reportErrorWarning(const char* warningString) -{ - printf("%s\n",warningString); -} - -void GLDebugDrawer::drawContactPoint(const btVector3& pointOnB,const btVector3& normalOnB,btScalar distance,int lifeTime,const btVector3& color) -{ - - { - btVector3 to=pointOnB+normalOnB*1;//distance; - const btVector3&from = pointOnB; - glColor4f(color.getX(), color.getY(), color.getZ(),1.f); - //glColor4f(0,0,0,1.f); - glBegin(GL_LINES); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - glEnd(); - - -// glRasterPos3f(from.x(), from.y(), from.z()); -// char buf[12]; -// sprintf(buf," %d",lifeTime); - //BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),buf); - - - } -} - - - - - diff --git a/Demos/OpenGL/GLDebugDrawer.h b/Demos/OpenGL/GLDebugDrawer.h deleted file mode 100644 index 6ac987d0b..000000000 --- a/Demos/OpenGL/GLDebugDrawer.h +++ /dev/null @@ -1,37 +0,0 @@ -#ifndef GL_DEBUG_DRAWER_H -#define GL_DEBUG_DRAWER_H - -#include "LinearMath/btIDebugDraw.h" - - - -class GLDebugDrawer : public btIDebugDraw -{ - int m_debugMode; - -public: - - GLDebugDrawer(); - virtual ~GLDebugDrawer(); - - virtual void drawLine(const btVector3& from,const btVector3& to,const btVector3& fromColor, const btVector3& toColor); - - virtual void drawLine(const btVector3& from,const btVector3& to,const btVector3& color); - - virtual void drawSphere (const btVector3& p, btScalar radius, const btVector3& color); - - virtual void drawTriangle(const btVector3& a,const btVector3& b,const btVector3& c,const btVector3& color,btScalar alpha); - - virtual void drawContactPoint(const btVector3& PointOnB,const btVector3& normalOnB,btScalar distance,int lifeTime,const btVector3& color); - - virtual void reportErrorWarning(const char* warningString); - - virtual void draw3dText(const btVector3& location,const char* textString); - - virtual void setDebugMode(int debugMode); - - virtual int getDebugMode() const { return m_debugMode;} - -}; - -#endif//GL_DEBUG_DRAWER_H diff --git a/Demos/OpenGL/GLDebugFont.cpp b/Demos/OpenGL/GLDebugFont.cpp deleted file mode 100644 index a54e957a9..000000000 --- a/Demos/OpenGL/GLDebugFont.cpp +++ /dev/null @@ -1,1014 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "GLDebugFont.h" -#ifdef DONT_USE_GLUT -#include "OpenGLWindow/OpenGLInclude.h" -#else -#ifdef _WIN32//for glut.h -#include -#endif - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#if (defined (TARGET_OS_IPHONE) && TARGET_OS_IPHONE) || (defined (TARGET_IPHONE_SIMULATOR) && TARGET_IPHONE_SIMULATOR) -#import -#define glOrtho glOrthof -#else -#include -#include -#include -#endif -#else - - - -#ifdef _WINDOWS -#include -#include -#include -#else -#include -#include -#endif -#endif -#endif -#include -#include //for memset - -extern unsigned char sFontData[]; -static bool sTexturesInitialized = false; - -static GLuint sTexture = -1; -static int sScreenWidth = -1; -static int sScreenHeight = -1; - - -void GLDebugResetFont(int screenWidth,int screenHeight) -{ - - if (screenWidth==0 && screenHeight==0) - { - sScreenWidth = screenWidth; - sScreenHeight = screenHeight; - - if (sTexturesInitialized) - { - glDeleteTextures(1, &sTexture); - glBindTexture(GL_TEXTURE_2D,0); - sTexturesInitialized = false; - } - return; - } - if ((sScreenWidth == screenWidth) && (sScreenHeight == screenHeight)) - return; - - sScreenWidth = screenWidth; - sScreenHeight = screenHeight; - - if (!sTexturesInitialized) - { - sTexturesInitialized = true; - glGenTextures(1, &sTexture); - glBindTexture(GL_TEXTURE_2D, sTexture); - glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR); - glTexImage2D(GL_TEXTURE_2D, 0, 3, 256 , 256 , 0, GL_RGB, GL_UNSIGNED_BYTE, &sFontData[0]); - } - -// printf("generating font at resolution %d,%d\n",screenWidth,screenHeight); - -} - -#define USE_ARRAYS 1 - -void GLDebugDrawStringInternal(int x,int y,const char* string, const btVector3& rgb) -{ - GLDebugDrawStringInternal(x,y,string,rgb,true,10); -} - -void GLDebugDrawStringInternal(int x,int y,const char* string, const btVector3& rgb, bool enableBlend, int spacing) -{ - - if (!sTexturesInitialized) - { - GLDebugResetFont(sScreenWidth,sScreenHeight); - } - if (strlen(string)) - { - - glColor4f(rgb.getX(),rgb.getY(),rgb.getZ(),1.f); - float cx; - float cy; - - glMatrixMode(GL_TEXTURE); - glLoadIdentity(); - - glDisable(GL_TEXTURE_GEN_S); - glDisable(GL_TEXTURE_GEN_T); - glDisable(GL_TEXTURE_GEN_R); - - glEnable(GL_TEXTURE_2D); - glBlendFunc(GL_SRC_ALPHA,GL_ONE); - glDepthFunc (GL_LEQUAL); - - if (enableBlend) - { - glEnable(GL_BLEND); - } else - { - glDisable(GL_BLEND); - } - glEnable (GL_DEPTH_TEST); - glBindTexture(GL_TEXTURE_2D, sTexture); - glDisable(GL_DEPTH_TEST); - glMatrixMode(GL_PROJECTION); - glPushMatrix(); - glLoadIdentity(); - - glOrtho(0,sScreenWidth,0,sScreenHeight,-1,1); - - glMatrixMode(GL_MODELVIEW); - glPushMatrix(); - glLoadIdentity(); - glTranslatef(btScalar(x),btScalar(sScreenHeight - y),btScalar(0)); - -#if USE_ARRAYS - - glDisableClientState(GL_COLOR_ARRAY); - glDisableClientState(GL_NORMAL_ARRAY); - glEnableClientState(GL_VERTEX_ARRAY); - glEnableClientState (GL_TEXTURE_COORD_ARRAY); -#endif - - GLfloat verts[] ={ - 0.0f, 1.0f, 0.0f, - -1.0f, -1.0f, 0.0f, - 1.0f, -1.0f, 0.0f, - 0.f,0.f,0.f - }; - - GLfloat uv_texcoords[] = { - 0,0, - 0,0, - 0,0, - 0,0 - }; - verts[0] = 0; verts[1] = 0; verts[2] = 0; - verts[3] = 16-1; verts[4] = 0; verts[5] = 0; - verts[6] = 16-1; verts[7] = 16-1; verts[8] = 0; - verts[9] = 0; verts[10] = 16-1; verts[11] = 0; - - for (int i=0;i=0) - { - cx=float(ch%16) * btScalar(1./16.f); - cy=float(ch/16) * btScalar(1./16.f); - - uv_texcoords[0] = cx; uv_texcoords[1] = btScalar(1-cy-1./16.f); - uv_texcoords[2] = btScalar(cx+1./16.f); uv_texcoords[3] = btScalar(1-cy-1./16.f); - uv_texcoords[4] = btScalar(cx+1./16.f); uv_texcoords[5] = btScalar(1-cy); - uv_texcoords[6] = cx; uv_texcoords[7] = btScalar(1-cy); -#if USE_ARRAYS - glTexCoordPointer(2,GL_FLOAT,0,uv_texcoords); - glVertexPointer(3, GL_FLOAT, 0, verts); - glDrawArrays(GL_TRIANGLE_FAN, 0, 4); -#else - glBegin(GL_QUADS); - glTexCoord2f(cx,1-cy-1./16.f); - - glVertex2i(0,0); - glTexCoord2f(cx+1./16.f,1-cy-1./16.f); - - glVertex2i(16 - 1,0); - glTexCoord2f(cx+1./16.f,1-cy); - - glVertex2i(16 - 1,16 -1); - glTexCoord2f(cx,1-cy); - - glVertex2i(0,16 -1); - glEnd(); -#endif - - glTranslatef(spacing,0,0); - } - } - - glMatrixMode(GL_PROJECTION); - glPopMatrix(); - glMatrixMode(GL_MODELVIEW); - glPopMatrix(); -#if 1 - glEnable(GL_DEPTH_TEST); - glBlendFunc(GL_SRC_ALPHA,GL_ONE); - glDepthFunc (GL_LEQUAL); - glDisable(GL_BLEND); - glDisable(GL_TEXTURE_2D); - - glMatrixMode(GL_TEXTURE); - glLoadIdentity(); - glScalef(btScalar(0.025),btScalar(0.025),btScalar(0.025)); -#endif - glMatrixMode(GL_MODELVIEW); -#if USE_ARRAYS - glDisableClientState(GL_VERTEX_ARRAY); - glDisableClientState (GL_TEXTURE_COORD_ARRAY); -#endif - //glDisable(GL_TEXTURE_2D); - } -} - -void GLDebugDrawString(int x,int y,const char* string) -{ - - btVector3 rgb(1,1,1); - GLDebugDrawStringInternal(x,y,string,rgb); -} - - -unsigned char sFontData[] = -{ - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,145,145,145,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,213,213,213,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,2,2,2,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213, - 213,213,255,255,255,255,255,255,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,213,213,213,255,255,255,255,255,255,255,255,255,213,213,213,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,178,178,178,178,178,178,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,0,0,0,0,0,0,0,0,0,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,178,178,178,255,255,255,255,255,255,255,255,255,145,145,145,103,103,103,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,2,2,2,255,255,255,178,178,178,103,103,103,145,145,145,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 255,255,145,145,145,103,103,103,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,178,178,178,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,178,178,178,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,103,103,103,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,145,145,145,178,178,178,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,0,0,0,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,70,70,70,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70, - 70,70,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,70,70, - 70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,213,213,213,255,255,255,255,255,255,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,103,103,103,255,255,255,213,213,213,70,70,70,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,255,255,255,246,246,246,178,178,178,246,246,246,70,70,70,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37, - 37,37,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,178,178,178,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,213,213, - 213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,255,255,255,103,103,103,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,178,178,178,255,255,255,37,37,37,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,255,255,255,255,255,255,145,145,145,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,103,103,103,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,145,145,145,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,70,70,70,255,255,255,70,70,70,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,213,213,213,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,70,70,70,255,255,255,37,37,37,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,103,103,103,246,246,246,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,70,70,70,255,255,255,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,0,0,0,37,37,37,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,0,0,0,37,37,37,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,70,70,70,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,213,213,213,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,37,37,37,255,255,255,178,178,178,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,70,70,70,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,145,145,145,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,70,70,70,255,255,255,37,37,37,0,0,0,145,145,145,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,178,178,178,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,0,0,0,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,0,0,0,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,255,255,255,213,213,213,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,246,246,246,103,103,103,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,37,37,37,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,103,103,103,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,103,103,103,70,70,70,0,0,0,103,103,103,255,255, - 255,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,2,2,2,255,255,255,255,255, - 255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,178,178,178,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,255,255,255,246,246, - 246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,103,103,103,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255, - 255,255,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,178,178,178,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,178,178,178,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178, - 178,178,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,145,145,145,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,145,145,145,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,255,255,255,145,145,145,0,0,0,37,37,37,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,145,145,145,0,0,0,37,37,37,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2, - 2,2,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103, - 103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255, - 255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,178,178, - 178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37, - 37,37,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246, - 246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,0,0,0,37,37,37,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,246,246,246,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,103,103, - 103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,0,0,0,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103, - 103,103,246,246,246,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,103,103,103,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,70,70,70,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,37,37,37,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,37,37,37,70,70,70,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,178,178,178,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,246,246,246,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,145,145,145,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,213,213,213,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,213,213,213,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246, - 246,246,255,255,255,255,255,255,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,145,145,145,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,178,178,178,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,246,246,246,103,103,103,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,103,103,103,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255, - 255,255,213,213,213,178,178,178,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,178,178,178,0,0,0,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,178,178,178,255,255,255,255,255,255,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,103,103,103,178,178,178,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,37,37,37,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,2,2,2,37,37,37,145,145,145,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255, - 255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,145,145,145,255,255,255,103,103,103,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,178,178,178,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,246,246,246,0,0,0,0,0,0,246,246,246,70,70, - 70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,2,2,2,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,2,2,2,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,178,178,178,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,70,70,70,2,2,2,2,2,2,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,103,103,103,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,255,255,255,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,178,178,178,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,103,103,103,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,145,145,145,255,255,255,103,103,103,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,178,178,178,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,246,246,246,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,255,255,255,246,246,246,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,145,145,145,103,103,103,178,178,178,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,103,103,103,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255, - 255,255,213,213,213,0,0,0,37,37,37,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,213,213,213,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,70,70,70,103,103,103,246,246,246,0,0,0,213,213,213,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,103,103,103,103,103,103,255,255,255,255,255,255,246,246, - 246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,213,213,213,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,145,145,145,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,70,70,70,178,178,178,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255, - 255,255,255,255,255,0,0,0,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,145,145,145,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,103,103,103,103,103,103,145,145,145,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,178,178,178,103,103,103,178,178,178,255,255,255,145,145,145,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,213,213,213,213,213,213,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213, - 213,213,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,213,213,213,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,213,213,213,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,255,255,255,145,145,145,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,178,178,178,255,255,255,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246, - 246,246,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,178,178,178,255,255,255,178,178,178,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,178,178,178,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,0,0,0,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,37,37,37,178,178,178,255,255,255,37,37,37,178,178,178,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,0,0,0,70,70,70,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,213,213,213,103,103,103,103,103,103,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,37,37,37,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255, - 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,103,103,103,255,255,255,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246, - 246,246,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,255,255,255,2,2,2,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,103,103,103,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,103,103,103,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,103,103,103,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,213,213,213,255,255,255,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,37,37,37,255,255,255,255,255,255,70,70,70,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,145,145,145,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,178,178,178,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,213,213,213,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,145,145,145,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,145,145,145,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,178,178,178,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,178,178,178,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,37,37, - 37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,246,246,246,255,255,255,145,145,145,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,213,213,213,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246, - 246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,246,246,246,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255, - 255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,0,0,0,103,103,103,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 255,255,145,145,145,103,103,103,178,178,178,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,213,213,213,255,255,255,246,246,246,2,2,2,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,103,103,103,178,178,178,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37, - 37,37,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,2,2,2,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,145,145,145,0,0,0,0,0,0,255,255,255,103,103, - 103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,103,103,103,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2, - 2,2,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,37,37,37,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,255,255,255,2,2,2,246,246,246,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,145,145,145,103,103, - 103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,213,213,213,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,246,246,246,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103, - 103,103,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,103,103,103,246,246,246,255,255,255,103,103,103,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,70,70,70,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,2,2,2,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,145,145,145,2,2,2,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,70,70,70,255,255,255,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213, - 213,213,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,255,255,255,255,255,255,2,2,2,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,70,70,70,0,0,0,255,255,255,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,0,0,0,255,255,255,37,37,37,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,37,37,37,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,103,103,103,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,103,103,103,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,255,255,255,246,246,246,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255, - 255,255,103,103,103,103,103,103,0,0,0,70,70,70,103,103,103,255,255,255,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,246,246,246,2,2,2,0,0,0,0,0,0,213,213,213,255,255,255,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,0,0,0,213,213,213,255,255,255,145,145,145,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,145,145,145,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,103,103,103,213,213,213,255,255,255,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 255,255,255,255,255,255,255,255,2,2,2,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,178,178,178,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255, - 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,213,213,213,103,103,103,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,103,103,103,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,145,145,145,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,178,178,178,103,103,103,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,103,103,103,145,145,145,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255, - 255,255,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,103,103,103,103,103,103,213,213,213,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,103,103,103,0,0,0,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,70,70,70,0,0,0,37,37,37,255,255,255,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,103,103,103,103,103,103,103,103,103,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,255,255,255,103,103,103,0,0,0,2,2,2,178,178,178,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,255,255,255,103,103,103,0,0,0,70,70,70,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,103,103,103,255,255,255,255,255,255,178,178,178,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,145,145,145,178,178,178,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,246,246,246,255,255,255,2,2,2,213,213,213,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,103,103,103,103,103,103,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,178,178,178,103,103,103,255,255,255,213,213,213,70,70,70,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,103,103,103,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,103,103,103,103,103,103,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,2,2,2,178,178,178,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,246,246,246,255,255,255,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,255,255,255,213,213,213,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,37,37,37,255,255,255,178,178,178,37,37,37,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,246,246,246,255,255,255,178,178,178,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,70,70,70,255,255,255,70,70,70,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,145,145,145,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246, - 246,246,213,213,213,0,0,0,70,70,70,255,255,255,37,37,37,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,70,70,70,255,255,255,37,37,37,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,246,246,246,103,103,103,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,213,213,213,255,255,255,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145, - 145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37, - 37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,246,246,246,2,2,2,103,103,103,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,246,246,246,103,103,103,103,103,103,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,103,103,103,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213, - 213,213,255,255,255,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,103,103,103,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,103,103,103,0,0,0,103,103,103,255,255,255,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,103,103,103,255,255,255,246,246,246,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,255,255,255,246,246, - 246,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,103,103,103,103,103,103,0,0,0,255,255,255,255,255,255,145,145,145,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,213,213,213,255,255,255,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,2,2,2,0,0,0,255,255,255,255,255,255,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,70,70,70,0,0,0,103,103,103,255,255,255,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,145,145,145,103,103,103,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255, - 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,70,70,70,246,246,246,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,103,103,103,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255, - 255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,178,178,178,255,255,255,178,178,178,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,103,103,103,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,255,255,255,178,178,178,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213, - 213,213,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,103,103,103,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,246,246,246,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,213,213,213,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,37,37,37,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,213,213,213,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,213,213,213,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,178,178,178,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246, - 246,246,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,246,246,246,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,178,178,178,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145, - 145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,246,246,246,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37, - 37,37,255,255,255,103,103,103,103,103,103,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,103,103,103,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,103,103,103,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,213,213,213,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,213,213,213,103,103,103,103,103,103,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,246,246,246,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,178,178,178,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,246,246,246,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,246,246,246,213,213,213,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,213,213,213,255,255,255,255,255,255,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,178, - 178,178,0,0,0,0,0,0,213,213,213,213,213,213,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,2,2,2,178,178,178,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,178,178,178,255,255,255,178,178,178,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,145,145,145,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103, - 103,103,255,255,255,178,178,178,0,0,0,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,103,103,103,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,246,246,246,255,255,255,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,2,2,2,178,178,178,255,255,255,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,213,213,213,37,37,37,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,213,213,213,255,255,255,37,37, - 37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,213,213,213,255,255,255,145,145,145,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255, - 255,255,255,255,255,145,145,145,0,0,0,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,37,37,37,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,70,70,70,2,2,2,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255, - 255,255,0,0,0,255,255,255,2,2,2,0,0,0,2,2,2,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255, - 255,255,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,2,2,2,255,255,255,145,145,145,70,70, - 70,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70, - 70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,145,145,145,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,255,255, - 255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,246,246,246,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37, - 37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,213,213,213,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,2,2,2,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,213,213,213,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,37,37,37,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,2,2,2,255,255,255,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,246,246,246,103,103,103,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,103,103,103,246,246,246,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,2,2,2,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,103,103,103,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,213,213,213,246,246,246,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,145,145,145,246,246,246,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,103,103,103,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,103,103,103,255,255,255,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37, - 37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,37,37,37,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,145,145,145,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,37,37,37,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,70,70,70,0,0,0,2,2,2,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,37,37,37,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0, - 0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,145,145,145,0,0,0,70,70,70,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,178,178,178,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0, - 0,145,145,145,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,213,213,213,145,145,145,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,159,159,159,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,246,246,246,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,255,255,255,255,255,255,37,37,37,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,255,255,255,255,255,255,255,255, - 255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,213,213,213,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,213,213,213,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,246,246,246,0,0,0,0,0,0,213,213,213,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,213,213,213,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0, - 0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103, - 103,103,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2, - 2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,178,178,178,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,178,178,178,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,2,2,2,178,178,178,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,178,178,178,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,255,255, - 255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,145,145, - 145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,70,70,70,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255, - 255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,145,145,145,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,145,145,145,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,213,213,213,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,178,178, - 178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,70,70,70,0,0,0,0,0,0,2,2,2,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,37,37,37,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,70,70,70,0,0,0,2,2,2,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,37,37,37,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,2,2,2,0,0,0,70,70,70,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,37,37,37,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,145,145,145,0,0,0,70,70,70,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,246,246,246,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,70,70,70,0,0,0,145,145,145,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,145,145,145,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,213,213,213,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,70,70,70,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,37,37,37,246,246,246,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,255,255,255,37,37,37,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,37,37,37,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,213,213,213,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,145,145,145,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,213,213,213,0,0,0,145,145,145,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,213,213,213,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,255,255,255,0,0,0,255,255,255,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,145,145,145,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,246,246,246,0,0,0,255,255,255,0,0,0,213,213,213,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,0,0,0,103,103,103,246,246,246,255,255,255,0,0,0,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178, - 178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,255,255,255,37,37,37,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,2,2,2,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,255,255,255,70,70,70,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,2,2,2,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,70,70,70,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,246,246,246,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,37,37,37,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,213,213,213,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,37,37,37,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,37,37,37,246,246,246,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,70,70,70,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,246,246,246,103,103,103,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,213,213,213,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,37,37,37,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37, - 37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,37,37,37,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,246,246,246,103,103,103,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,246,246,246,103,103,103,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,246,246,246,103,103,103,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,178,178,178,246,246,246,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,255,255,246,246,246,246,246,246,246,246,246,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,246,246,246,103,103,103,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213, - 213,213,178,178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,213,213,213,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,37,37,37,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,246,246,246,246,246,246,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,255,255,255,37,37,37,70,70,70,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,70,70,70,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,246,246,246,2,2,2,145,145,145,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,70,70,70,255,255,255,246,246,246,178,178,178,213,213,213,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,246,246,246,2,2,2,145,145,145,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,37,37,37,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,145,145,145,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,2,2,2,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,178,178,178,145,145,145,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,37,37,37,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,246,246,246,255,255,255,0,0,0,178,178,178,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,37,37,37,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,246,246,246,103,103,103,103,103,103,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,37,37,37,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,255,255,255,255,255,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37,37,0,0,0,145,145,145,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255, - 255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,103,103,103,0,0,0,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,246,246,246,0,0,0,255,255,255,213,213,213,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,37,37,37,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,255,255,255,0,0,0,255,255,255,2,2,2,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,255,255,255,103,103,103,255,255,255,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,246,246,246,255,255,255,178,178,178,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,37,37,37,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,37,37, - 37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,2,2,2,246,246,246,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,103,103,103,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,37,37,37,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,213,213,213,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,2,2,2,178,178,178,255,255,255,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,2,2,2,2,2,2,178,178, - 178,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,213,213,213,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,145,145,145,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,246,246,246,246,246,246,246,246,246,246,246,246,246,246, - 246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,103,103,103,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,246,246,246,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,37,37, - 37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,103,103,103,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,0,0,0,0,0,0,103,103,103,0,0,0,70,70,70,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,255,255,255,178,178,178,178,178,178,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,103,103,103,255,255,255,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,2,2,2,255,255,255,0,0,0,178,178,178,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,246,246,246,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,2,2,2,246,246,246,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,246,246,246,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,213,213,213,178,178,178,255,255,255,70,70,70,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,103,103,103,255,255,255,2,2,2,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,145,145,145,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,255,255,255,2,2,2,103,103,103,213,213,213,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,178,178,178,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,103,103,103,0,0,0,145,145,145,103,103,103,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,255,255,255,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,246,246,246,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,103,103,103,246,246,246,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,37,37,37,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,70,70,70,0,0,0,0,0,0,2,2,2,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,70,70,70,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,178,178,178,255,255,255,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,103,103,103,255,255, - 255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,213,213,213,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,246,246,246,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246, - 246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,213,213,213,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,70,70,70,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,246,246,246,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,246,246,246,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,2,2,2,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,103,103,103,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,246,246,246,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,70,70,70,103,103,103,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,37,37,37,246,246,246,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,246,246,246,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,213,213,213,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,178,178,178,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,103,103,103,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2, - 2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,178,178,178,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,246,246,246,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,213,213,213,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,2,2,2,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,246,246,246,246,246,246,103,103,103,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,103,103,103,103,103,103,145,145,145,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,2,2,2,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,2,2,2,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,255,255,255,255,255,255,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,145,145,145,246,246,246,246,246,246,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,255,255,255,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,70,70,70,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,255,255,255,255,255,255,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,178, - 178,178,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,255,255,255,255,255,255,103,103,103,145,145,145,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,2,2,2,0,0,0,255,255,255,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246, - 246,246,37,37,37,0,0,0,37,37,37,246,246,246,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,103,103,103,0,0,0,0,0,0,246,246,246,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,103,103,103,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,0,0,0,103,103,103,103,103,103,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,246,246,246,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,255,255,255,246,246,246,255,255,255,255,255,255,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,70,70,70,246,246,246,37,37,37,246,246,246,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,246,246,246,255,255,255,0,0,0,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,246,246,246,255,255,255,255,255,255,246,246,246,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,103,103,103,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,213,213,213,103,103,103,145,145,145,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,70,70,70,255,255,255,2,2,2,0,0,0,246,246,246,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,2,2,2,2,2,2,255,255,255,103,103,103,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,37,37,37,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,2,2,2,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,255,255,255,246,246,246,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,246,246,246,246,246,246,103,103,103,255,255,255,178,178,178,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255, - 255,255,145,145,145,255,255,255,37,37,37,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,255,255,255,145,145,145,178,178, - 178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,2,2,2,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,255,255,255,103,103,103,213,213,213,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0, - 0,0,0,0,0,255,255,255,255,255,255,145,145,145,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,145,145,145,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,2,2,2,0,0,0,70,70, - 70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,2,2,2,0,0,0,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,255,255,255,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0, - 0,0,0,0,0,103,103,103,103,103,103,0,0,0,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,103,103,103,2,2,2,70,70,70,70,70, - 70,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,70,70,70,0,0,0,178,178,178,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,70,70,70,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,255,255,255,103,103,103,255,255,255,2,2,2,103,103,103,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,213,213,213,103, - 103,103,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,213,213,213,0,0,0,255,255,255,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,178,178,178,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,103,103,103,0,0,0,246,246,246,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,103,103,103,0,0,0,103,103,103,37,37,37,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,213,213,213,255,255,255,246,246,246,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178, - 178,178,246,246,246,37,37,37,0,0,0,0,0,0,0,0,0,103,103,103,213,213,213,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,178,178,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,2,2,255,255,255,255,255,255,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,178,178,178,255,255,255,145,145,145,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,145,145,145,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,70,70,70,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,2,2,2,0,0,0,70,70,70,70,70,70,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,246,246,246,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,37,37,2,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,103,103,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,70,70,70,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, -}; diff --git a/Demos/OpenGL/GLDebugFont.h b/Demos/OpenGL/GLDebugFont.h deleted file mode 100644 index bf2c2575d..000000000 --- a/Demos/OpenGL/GLDebugFont.h +++ /dev/null @@ -1,29 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#ifndef BT_DEBUG_FONT_H -#define BT_DEBUG_FONT_H - -#include "LinearMath/btVector3.h" - - -void GLDebugDrawStringInternal(int x,int y,const char* string,const btVector3& rgb, bool enableBlend, int spacing); -void GLDebugDrawStringInternal(int x,int y,const char* string,const btVector3& rgb); -void GLDebugDrawString(int x,int y,const char* string); -void GLDebugResetFont(int screenWidth,int screenHeight); - -#endif //BT_DEBUG_FONT_H - diff --git a/Demos/OpenGL/GL_DialogDynamicsWorld.cpp b/Demos/OpenGL/GL_DialogDynamicsWorld.cpp deleted file mode 100644 index 08948d273..000000000 --- a/Demos/OpenGL/GL_DialogDynamicsWorld.cpp +++ /dev/null @@ -1,761 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#include "GL_DialogDynamicsWorld.h" -#include "GL_DialogWindow.h" -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/CollisionDispatch/btBox2dBox2dCollisionAlgorithm.h" -#include "BulletCollision/CollisionDispatch/btConvex2dConvex2dAlgorithm.h" -#include "BulletCollision/CollisionShapes/btBox2dShape.h" -#include "BulletCollision/CollisionShapes/btConvex2dShape.h" -#include "BulletCollision/NarrowPhaseCollision/btMinkowskiPenetrationDepthSolver.h" - -GL_DialogDynamicsWorld::GL_DialogDynamicsWorld() -{ - m_upperBorder = 0; - m_lowerBorder =0; - - m_pickConstraint = 0; - m_screenWidth = 0; - m_screenHeight = 0; - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_broadphase = new btDbvtBroadphase(); - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_constraintSolver,m_collisionConfiguration); - m_dynamicsWorld ->getSolverInfo().m_splitImpulse = true; - //m_dynamicsWorld->setGravity(btVector3(0,10,0)); - m_dynamicsWorld->setGravity(btVector3(0,0,0)); - - m_simplexSolver = new btVoronoiSimplexSolver(); - m_pdSolver = new btMinkowskiPenetrationDepthSolver(); - - btConvex2dConvex2dAlgorithm::CreateFunc* convexAlgo2d = new btConvex2dConvex2dAlgorithm::CreateFunc(m_simplexSolver,m_pdSolver); - - m_dispatcher->registerCollisionCreateFunc(CONVEX_2D_SHAPE_PROXYTYPE,CONVEX_2D_SHAPE_PROXYTYPE,convexAlgo2d); - m_dispatcher->registerCollisionCreateFunc(BOX_2D_SHAPE_PROXYTYPE,CONVEX_2D_SHAPE_PROXYTYPE,convexAlgo2d); - m_dispatcher->registerCollisionCreateFunc(CONVEX_2D_SHAPE_PROXYTYPE,BOX_2D_SHAPE_PROXYTYPE,convexAlgo2d); - m_dispatcher->registerCollisionCreateFunc(BOX_2D_SHAPE_PROXYTYPE,BOX_2D_SHAPE_PROXYTYPE,new btBox2dBox2dCollisionAlgorithm::CreateFunc()); - - ///enable boarders, to avoid 'loosing' menus -#if 1 - btTransform tr; - tr.setIdentity(); - - { - btStaticPlaneShape* plane = new btStaticPlaneShape(btVector3(0,1,0),0); - m_upperBorder = new btCollisionObject(); - tr.setOrigin(btVector3(0,-BT_LARGE_FLOAT,0)); - m_upperBorder->setWorldTransform(tr); - m_upperBorder->setCollisionShape(plane); - m_dynamicsWorld->addCollisionObject(m_upperBorder); - } - - { - btStaticPlaneShape* plane = new btStaticPlaneShape(btVector3(0,-1,0),0); - m_lowerBorder = new btCollisionObject(); - - tr.setIdentity(); - tr.setOrigin(btVector3(0,BT_LARGE_FLOAT,0)); - m_lowerBorder->setWorldTransform(tr); - m_lowerBorder->setCollisionShape(plane); - m_dynamicsWorld->addCollisionObject(m_lowerBorder); - } - { - btStaticPlaneShape* plane = new btStaticPlaneShape(btVector3(1,0,0),0); - m_leftBorder = new btCollisionObject(); - tr.setIdentity(); - tr.setOrigin(btVector3(-BT_LARGE_FLOAT,0,0)); - m_leftBorder->setWorldTransform(tr); - m_leftBorder->setCollisionShape(plane); - m_dynamicsWorld->addCollisionObject(m_leftBorder); - } - { - btStaticPlaneShape* plane = new btStaticPlaneShape(btVector3(-1,0,0),0); - m_rightBorder = new btCollisionObject(); - tr.setIdentity(); - tr.setOrigin(btVector3(BT_LARGE_FLOAT,0,0)); - m_rightBorder->setWorldTransform(tr); - m_rightBorder->setCollisionShape(plane); - m_dynamicsWorld->addCollisionObject(m_rightBorder); - } -#endif - -} - -GL_DialogDynamicsWorld::~GL_DialogDynamicsWorld() -{ - delete m_dynamicsWorld; - delete m_dispatcher; - delete m_constraintSolver; - delete m_broadphase; - delete m_collisionConfiguration; -} - -void GL_DialogDynamicsWorld::setScreenSize(int width, int height) -{ - - - int i; - - for ( i=0;igetCollisionObjectArray().size();i++) - { - btCollisionObject* colObj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(colObj); - if (body) - { - m_dynamicsWorld->removeRigidBody(body); - btVector3 newPos = colObj->getWorldTransform().getOrigin() + btVector3(btScalar(m_screenWidth/2.),btScalar(m_screenHeight/2),btScalar(0))-btVector3(btScalar(width/2.),btScalar(height/2.),btScalar(0)); - colObj->getWorldTransform().setOrigin(newPos); - m_dynamicsWorld->addRigidBody(body); - } else - { - m_dynamicsWorld->removeCollisionObject(colObj); - btVector3 newPos = colObj->getWorldTransform().getOrigin() + btVector3(btScalar(m_screenWidth/2.),btScalar(m_screenHeight/2.),btScalar(0))-btVector3(btScalar(width/2.),btScalar(height/2.),btScalar(0)); - colObj->getWorldTransform().setOrigin(newPos); - m_dynamicsWorld->addCollisionObject(colObj); - } - } - - for ( i=0;isetScreenSize(width,height); - } - if (width && height) - { - if (m_upperBorder) - { - m_dynamicsWorld->removeCollisionObject(m_upperBorder); - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(0),btScalar(-height/2.),btScalar(0.))); - m_upperBorder->setWorldTransform(tr); - m_dynamicsWorld->addCollisionObject(m_upperBorder); - } - - if (m_lowerBorder) - { - m_dynamicsWorld->removeCollisionObject(m_lowerBorder); - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(0),btScalar(height/2.),btScalar(0))); - m_lowerBorder->setWorldTransform(tr); - m_dynamicsWorld->addCollisionObject(m_lowerBorder); - } - if (m_leftBorder) - { - m_dynamicsWorld->removeCollisionObject(m_leftBorder); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(-width/2.),btScalar(0),btScalar(0))); - m_leftBorder->setWorldTransform(tr); - m_dynamicsWorld->addCollisionObject(m_leftBorder); - } - if (m_rightBorder) - { - m_dynamicsWorld->removeCollisionObject(m_rightBorder); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(btScalar(width/2.),btScalar(0),btScalar(0))); - m_rightBorder->setWorldTransform(tr); - m_dynamicsWorld->addCollisionObject(m_rightBorder); - - } - - } - - - m_screenWidth = width; - m_screenHeight = height; -} - -GL_DialogWindow* GL_DialogDynamicsWorld::createDialog(int horPos,int vertPos,int dialogWidth,int dialogHeight, const char* dialogTitle ) -{ - btBox2dShape* boxShape = new btBox2dShape(btVector3(dialogWidth/2.f,dialogHeight/2.f,0.4f)); - btScalar mass = 100.f; - btVector3 localInertia; - boxShape->calculateLocalInertia(mass,localInertia); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,0,boxShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - btTransform trans; - trans.setIdentity(); -// trans.setOrigin(btVector3(btScalar(horPos-m_screenWidth/2+dialogWidth/2), btScalar(vertPos+m_screenHeight/2.+dialogHeight/2),btScalar(0.))); - trans.setOrigin(btVector3(btScalar(horPos-m_screenWidth/2+dialogWidth/2), btScalar(vertPos-m_screenHeight/2.+dialogHeight/2),btScalar(0.))); - - - - body->setWorldTransform(trans); - body->setDamping(0.999f,0.99f); - - //body->setActivationState(ISLAND_SLEEPING); - body->setLinearFactor(btVector3(1,1,0)); - //body->setAngularFactor(btVector3(0,0,1)); - body->setAngularFactor(btVector3(0,0,0)); - - GL_DialogWindow* dialogWindow = new GL_DialogWindow(horPos,vertPos,dialogWidth,dialogHeight,body,dialogTitle); - m_dialogs.push_back(dialogWindow); - m_dynamicsWorld->addRigidBody(body); - - return dialogWindow; - -} - -GL_SliderControl* GL_DialogDynamicsWorld::createSlider(GL_DialogWindow* dialog, const char* sliderText, btScalar initialFraction) -{ - btBox2dShape* boxShape = new btBox2dShape(btVector3(6.f,6.f,0.4f)); - btScalar mass = .1f; - btVector3 localInertia; - boxShape->calculateLocalInertia(mass,localInertia); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,0,boxShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - btTransform trans; - trans.setIdentity(); - int sliderX = dialog->getDialogHorPos() - m_screenWidth/2 + dialog->getDialogWidth()/2; -// int sliderY = dialog->getDialogVertPos() + m_screenHeight/2 + dialog->getDialogHeight()/2 + dialog->getNumControls()*20; - int sliderY = dialog->getDialogVertPos() - m_screenHeight/2 + dialog->getDialogHeight()/2 + dialog->getNumControls()*20; - trans.setOrigin(btVector3((btScalar)sliderX, (btScalar)sliderY,(btScalar)-0.2f)); - - body->setWorldTransform(trans); - //body->setDamping(0.999,0.99); - - //body->setActivationState(ISLAND_SLEEPING); - body->setLinearFactor(btVector3(1,1,0)); - //body->setAngularFactor(btVector3(0,0,1)); - body->setAngularFactor(btVector3(0,0,0)); - - m_dynamicsWorld->addRigidBody(body); - body->setCollisionFlags(body->getFlags()|btCollisionObject::CF_NO_CONTACT_RESPONSE); - - btRigidBody* dialogBody = btRigidBody::upcast(dialog->getCollisionObject()); - btAssert(dialogBody); - - - - btTransform frameInA; - frameInA.setIdentity(); - int offsX = -dialog->getDialogWidth()/2 + 16; - int offsY = -dialog->getDialogHeight()/2 + dialog->getNumControls()*20 + 36; - btVector3 offset(btVector3((btScalar)offsX, (btScalar)offsY, (btScalar)0.2f)); - frameInA.setOrigin(offset); - - - btTransform frameInB; - frameInB.setIdentity(); - //frameInB.setOrigin(-offset/2); - -// btScalar lowerLimit = 80.f; -// btScalar upperLimit = 170.f; - btScalar lowerLimit = 141.f; - btScalar upperLimit = 227.f; - - btScalar actualLimit = lowerLimit+initialFraction*(upperLimit-lowerLimit); - - -#if 0 - bool useFrameA = false; - - btGeneric6DofConstraint* constraint = new btGeneric6DofConstraint(*dialogBody,*body,frameInA,frameInB,useFrameA); - m_dynamicsWorld->addConstraint(constraint,true); - constraint->setLimit(0,lowerLimit,upperLimit); -#else - btSliderConstraint* sliderConstraint = new btSliderConstraint(*dialogBody,*body,frameInA,frameInB,true);//useFrameA); - sliderConstraint->setLowerLinLimit(actualLimit); - sliderConstraint->setUpperLinLimit(actualLimit); - m_dynamicsWorld->addConstraint(sliderConstraint,true); - -#endif - - - GL_SliderControl* slider = new GL_SliderControl(sliderText, body,dialog,lowerLimit,upperLimit, sliderConstraint); - body->setUserPointer(slider); - dialog->addControl(slider); - - slider->m_fraction = initialFraction; - - return slider; -} - - - -GL_ToggleControl* GL_DialogDynamicsWorld::createToggle(GL_DialogWindow* dialog, const char* toggleText) -{ - - - btBox2dShape* boxShape = new btBox2dShape(btVector3(6.f,6.f,0.4f)); - btScalar mass = 0.1f; - btVector3 localInertia; - boxShape->calculateLocalInertia(mass,localInertia); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,0,boxShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - btTransform trans; - trans.setIdentity(); - - int toggleX = dialog->getDialogHorPos() - m_screenWidth/2 + dialog->getDialogWidth()/2; -// int toggleY = dialog->getDialogVertPos() + m_screenHeight/2 + dialog->getDialogHeight()/2 + dialog->getNumControls()*20; - int toggleY = dialog->getDialogVertPos() - m_screenHeight/2 + dialog->getDialogHeight()/2 + dialog->getNumControls()*20; - trans.setOrigin(btVector3((btScalar)toggleX, (btScalar)toggleY,(btScalar) -0.2f)); - - body->setWorldTransform(trans); - body->setDamping(0.999f,0.99f); - - //body->setActivationState(ISLAND_SLEEPING); - body->setLinearFactor(btVector3(1,1,0)); - //body->setAngularFactor(btVector3(0,0,1)); - body->setAngularFactor(btVector3(0,0,0)); - - m_dynamicsWorld->addRigidBody(body); - body->setCollisionFlags(body->getFlags()|btCollisionObject::CF_NO_CONTACT_RESPONSE); - - btRigidBody* dialogBody = btRigidBody::upcast(dialog->getCollisionObject()); - btAssert(dialogBody); - - - - btTransform frameInA; - frameInA.setIdentity(); - btVector3 offset(btVector3(+dialog->getDialogWidth()/2.f-32.f,-dialog->getDialogHeight()/2.f+dialog->getNumControls()*20.f+36.f,0.2f)); - frameInA.setOrigin(offset); - - - btTransform frameInB; - frameInB.setIdentity(); - //frameInB.setOrigin(-offset/2); - bool useFrameA = true; - - btGeneric6DofConstraint* constraint = new btGeneric6DofConstraint(*dialogBody,*body,frameInA,frameInB,useFrameA); - m_dynamicsWorld->addConstraint(constraint,true); - - - GL_ToggleControl* toggle = new GL_ToggleControl(toggleText, body,dialog); - body->setUserPointer(toggle); - dialog->addControl(toggle); - return toggle; -} - -void GL_DialogDynamicsWorld::draw(btScalar timeStep) -{ - if (timeStep) - { - m_dynamicsWorld->stepSimulation(timeStep); - } - - for (int i=0;idraw(timeStep); - } -} - -static btRigidBody* pickedBody = 0;//for deactivation state -static btScalar mousePickClamping = 111130.f; - -//static int gPickingConstraintId = 0; -static btVector3 gOldPickingPos; -static btVector3 gHitPos(-1,-1,-1); - -static btScalar gOldPickingDist = 0.f; - -bool GL_DialogDynamicsWorld::mouseFunc(int button, int state, int x, int y) -{ - if (state == 0) - { - m_mouseButtons |= 1<rayTest(m_cameraPosition,rayTo,rayCallback); - if (rayCallback.hasHit()) - { - - btRigidBody* body = btRigidBody::upcast(rayCallback.m_collisionObject); - if (body) - { - body->setActivationState(ACTIVE_TAG); - btVector3 impulse = rayTo; - impulse.normalize(); - float impulseStrength = 10.f; - impulse *= impulseStrength; - btVector3 relPos = rayCallback.m_hitPointWorld - body->getCenterOfMassPosition(); - body->applyImpulse(impulse,relPos); - } - } - } -#endif - - - - } else - { - - } - break; - } - - case 0: - { - if (state==0) - { - - - //add a point to point constraint for picking - if (m_dynamicsWorld) - { - - btVector3 rayFrom; - if (1)//m_ortho) - { - rayFrom = rayTo; - rayFrom.setZ(-100.f); - } - //else - //{ - // rayFrom = m_cameraPosition; - //} - - btCollisionWorld::ClosestRayResultCallback rayCallback(rayFrom,rayTo); - m_dynamicsWorld->rayTest(rayFrom,rayTo,rayCallback); - if (rayCallback.hasHit()) - { - - - btScalar maxPickingClamp = mousePickClamping; - - btRigidBody* body = (btRigidBody*)btRigidBody::upcast(rayCallback.m_collisionObject); - if (body) - { - bool doPick = true; - if (body->getUserPointer()) - { - ///deal with controls in a special way - GL_DialogControl* ctrl = (GL_DialogControl*)body->getUserPointer(); - - switch(ctrl->getType()) - { - case GL_TOGGLE_CONTROL: - { - GL_ToggleControl* toggle = (GL_ToggleControl*) ctrl; - toggle->m_active = !toggle->m_active; - doPick = false; - break; - } - case GL_SLIDER_CONTROL: - { - GL_SliderControl* slider = (GL_SliderControl*) ctrl; - btTypedConstraint* constraint = slider->getConstraint(); - if (constraint->getConstraintType() == SLIDER_CONSTRAINT_TYPE) - { - btSliderConstraint* sliderConstraint = (btSliderConstraint*) constraint; - sliderConstraint->setLowerLinLimit(slider->getLowerLimit()); - sliderConstraint->setUpperLinLimit(slider->getUpperLimit()); - } - maxPickingClamp = 100; - } - default: - { - } - }; - - }; - - if (doPick) - { - //other exclusions? - if (!(body->isStaticObject() || body->isKinematicObject())) - { - pickedBody = body; - pickedBody->setActivationState(DISABLE_DEACTIVATION); - - - - btVector3 pickPos = rayCallback.m_hitPointWorld; - //printf("pickPos=%f,%f,%f\n",pickPos.getX(),pickPos.getY(),pickPos.getZ()); - - - btVector3 localPivot = body->getCenterOfMassTransform().inverse() * pickPos; - - btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*body,localPivot); - p2p->m_setting.m_impulseClamp = maxPickingClamp; - - m_dynamicsWorld->addConstraint(p2p); - m_pickConstraint = p2p; - - //save mouse position for dragging - gOldPickingPos = rayTo; - gHitPos = pickPos; - - gOldPickingDist = (pickPos-rayFrom).length(); - - //very weak constraint for picking - p2p->m_setting.m_tau = 0.1f; - } - } - return true; - } - } - } - - } else - { - - if (m_pickConstraint && m_dynamicsWorld) - { - m_dynamicsWorld->removeConstraint(m_pickConstraint); - delete m_pickConstraint; - //printf("removed constraint %i",gPickingConstraintId); - m_pickConstraint = 0; - pickedBody->forceActivationState(ACTIVE_TAG); - pickedBody->setDeactivationTime( 0.f ); - - - if (pickedBody->getUserPointer()) - { - ///deal with controls in a special way - GL_DialogControl* ctrl = (GL_DialogControl*)pickedBody->getUserPointer(); - if (ctrl->getType()==GL_SLIDER_CONTROL) - { - GL_SliderControl* sliderControl = (GL_SliderControl*) ctrl; - - btSliderConstraint* slider = 0; - btTypedConstraint* constraint = sliderControl->getConstraint(); - if (constraint->getConstraintType() == SLIDER_CONSTRAINT_TYPE) - { - slider = (btSliderConstraint*)constraint; - } - if (slider) - { - btScalar linDepth = slider->getLinearPos(); - btScalar lowLim = slider->getLowerLinLimit(); - btScalar hiLim = slider->getUpperLinLimit(); - slider->setPoweredLinMotor(false); - if(linDepth <= lowLim) - { - slider->setLowerLinLimit(lowLim); - slider->setUpperLinLimit(lowLim); - } - else if(linDepth > hiLim) - { - slider->setLowerLinLimit(hiLim); - slider->setUpperLinLimit(hiLim); - } - else - { - slider->setLowerLinLimit(linDepth); - slider->setUpperLinLimit(linDepth); - } - } - } - - } - - pickedBody = 0; - - } - - - - } - - break; - - } - - default: - { - } - } - - return false; - -} - - - -btVector3 GL_DialogDynamicsWorld::getRayTo(int x,int y) -{ - float cameraDistance = m_screenHeight/2.f;//m_screenWidth/2;//1.f; - btVector3 cameraTargetPosition(0,0,0); - btVector3 cameraUp(0,-1,0); - - if (1)//_ortho) - { - - btScalar aspect; - btVector3 extents; - if (m_screenWidth> m_screenHeight) - { - - aspect = m_screenWidth / (btScalar)m_screenHeight; - extents.setValue(aspect * 1.0f, 1.0f,0); - } else - { - cameraDistance = m_screenWidth/2.f; - aspect = m_screenHeight / (btScalar)m_screenWidth; - extents.setValue(1.0f, aspect*1.f,0); - } - - - - extents *= cameraDistance; - btVector3 lower = cameraTargetPosition - extents; - btVector3 upper = cameraTargetPosition + extents; - - btScalar u = x / btScalar(m_screenWidth); - btScalar v = (m_screenHeight - y) / btScalar(m_screenHeight); - - btVector3 p(0,0,0); - p.setValue( - (1.0f - u) * lower.getX() + u * upper.getX(), - -((1.0f - v) * lower.getY() + v * upper.getY()), - cameraTargetPosition.getZ()); - return p; - } - - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float tanFov = (top-bottom)*0.5f / nearPlane; - float fov = 2 * atanf (tanFov); - - btVector3 cameraPosition(0,0,-100); - btVector3 rayFrom = cameraPosition; - btVector3 rayForward = (cameraTargetPosition-cameraPosition); - rayForward.normalize(); - float farPlane = 10000.f; - rayForward*= farPlane; - - btVector3 rightOffset; - btVector3 vertical = cameraUp; - - btVector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - btScalar aspect; - - if (m_screenWidth > m_screenHeight) - { - aspect = m_screenWidth / (btScalar)m_screenHeight; - - hor*=aspect; - } else - { - aspect = m_screenHeight / (btScalar)m_screenWidth; - vertical*=aspect; - } - - - btVector3 rayToCenter = rayFrom + rayForward; - btVector3 dHor = hor * 1.f/float(m_screenWidth); - btVector3 dVert = vertical * 1.f/float(m_screenHeight); - - - btVector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += btScalar(x) * dHor; - rayTo -= btScalar(y) * dVert; - //rayTo += y * dVert; - - return rayTo; -} - - - -void GL_DialogDynamicsWorld::mouseMotionFunc(int x,int y) -{ - - if (m_pickConstraint) - { - //move the constraint pivot - btPoint2PointConstraint* p2p = static_cast(m_pickConstraint); - if (p2p) - { - //keep it at the same picking distance - - btVector3 newRayTo = getRayTo(x,y); - btVector3 rayFrom; - btVector3 oldPivotInB = p2p->getPivotInB(); - btVector3 newPivotB; - if (1)//_ortho) - { - newPivotB = oldPivotInB; - newPivotB.setX(newRayTo.getX()); - newPivotB.setY(newRayTo.getY()); - } else - { - //rayFrom = m_cameraPosition; - // btVector3 dir = newRayTo-rayFrom; - // dir.normalize(); - // dir *= gOldPickingDist; - - // newPivotB = rayFrom + dir; - } - - - - p2p->setPivotB(newPivotB); - } - - } - - btScalar dx, dy; - dx = btScalar(x) - m_mouseOldX; - dy = btScalar(y) - m_mouseOldY; - - - - - m_mouseOldX = x; - m_mouseOldY = y; -// updateCamera(); - - -} - - diff --git a/Demos/OpenGL/GL_DialogDynamicsWorld.h b/Demos/OpenGL/GL_DialogDynamicsWorld.h deleted file mode 100644 index 8292ae48a..000000000 --- a/Demos/OpenGL/GL_DialogDynamicsWorld.h +++ /dev/null @@ -1,91 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#ifndef GL_DIALOG_DYNAMICS_WORLD_H -#define GL_DIALOG_DYNAMICS_WORLD_H - -class btDiscreteDynamicsWorld; -class GL_DialogWindow; -class btDefaultCollisionConfiguration; -struct btDbvtBroadphase; -class btSequentialImpulseConstraintSolver; -class btCollisionDispatcher; -class btVoronoiSimplexSolver; -class btMinkowskiPenetrationDepthSolver; -class btCollisionObject; -class btTypedConstraint; -struct GL_ToggleControl; -struct GL_SliderControl; - - -#include "LinearMath/btAlignedObjectArray.h" -#include "LinearMath/btVector3.h" - -class GL_DialogDynamicsWorld -{ - - btDefaultCollisionConfiguration* m_collisionConfiguration; - btDbvtBroadphase* m_broadphase; - btSequentialImpulseConstraintSolver* m_constraintSolver; - btCollisionDispatcher* m_dispatcher; - btVoronoiSimplexSolver* m_simplexSolver; - btMinkowskiPenetrationDepthSolver* m_pdSolver; - - btDiscreteDynamicsWorld* m_dynamicsWorld; - - btCollisionObject* m_lowerBorder; - btCollisionObject* m_upperBorder; - btCollisionObject* m_leftBorder; - btCollisionObject* m_rightBorder; - - btAlignedObjectArray m_dialogs; - - int m_screenWidth; - int m_screenHeight; - - - ///for picking - int m_mouseOldX; - int m_mouseOldY; - int m_mouseButtons; - ///constraint for mouse picking - btTypedConstraint* m_pickConstraint; - - btVector3 getRayTo(int x,int y); - -public: - - GL_DialogDynamicsWorld(); - - virtual ~GL_DialogDynamicsWorld(); - - virtual void setScreenSize(int width, int height); - - virtual GL_DialogWindow* createDialog(int horPos,int vertPos,int dialogWidth,int dialogHeight, const char* dialogTitle ); - - GL_ToggleControl* createToggle(GL_DialogWindow* dialog, const char* toggleText); - - GL_SliderControl* createSlider(GL_DialogWindow* dialog, const char* sliderText, btScalar initialFraction = btScalar(0.5f)); - - virtual void draw(btScalar timeStep); - - virtual bool mouseFunc(int button, int state, int x, int y); - - virtual void mouseMotionFunc(int x,int y); - -}; - -#endif //GL_DIALOG_DYNAMICS_WORLD_H diff --git a/Demos/OpenGL/GL_DialogWindow.cpp b/Demos/OpenGL/GL_DialogWindow.cpp deleted file mode 100644 index b3ecae8fb..000000000 --- a/Demos/OpenGL/GL_DialogWindow.cpp +++ /dev/null @@ -1,358 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "GL_DialogWindow.h" - - - -#include "GLDebugFont.h" -#include "btBulletDynamicsCommon.h" - -#include // for sprintf() - -#define USE_ARRAYS 1 - - -GL_DialogWindow::GL_DialogWindow(int horPos,int vertPos,int dialogWidth,int dialogHeight, btCollisionObject* collisionObject,const char* dialogTitle) -:m_dialogHorPos(horPos), -m_dialogVertPos(vertPos), -m_dialogWidth(dialogWidth), -m_dialogHeight(dialogHeight), -m_screenWidth(0), -m_screenHeight(0), -m_dialogTitle(dialogTitle), -m_MaxClipPlanes(-1), -m_collisionObject(collisionObject) - -{ -} - -void GL_DialogWindow::setScreenSize(int width, int height) -{ - m_screenWidth = width; - m_screenHeight = height; -} -GL_DialogWindow::~GL_DialogWindow() -{ - -} - - - -static void drawLine(int _X0, int _Y0, int _X1, int _Y1, unsigned int _Color0, unsigned int _Color1) -{ - const GLfloat dx = +0.5f; - const GLfloat dy = -0.5f; - - GLfloat vVertices[] = {(GLfloat)_X0+dx,(GLfloat)_Y0+dy,(GLfloat)_X1+dx,(GLfloat)_Y1+dy}; - - bool antiAliased = false; - if( antiAliased ) - glEnable(GL_LINE_SMOOTH); - else - glDisable(GL_LINE_SMOOTH); - glDisable(GL_TEXTURE_2D); - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - -#ifdef USE_ARRAYS - glColor4ub(GLubyte(_Color0>>16), GLubyte(_Color0>>8), GLubyte(_Color0), GLubyte(_Color0>>24)); - glDisableClientState(GL_COLOR_ARRAY); - glDisableClientState(GL_NORMAL_ARRAY); - glDisableClientState(GL_TEXTURE_COORD_ARRAY); - glLineWidth(2.0f); - glVertexPointer(2, GL_FLOAT, 0, vVertices); - glEnableClientState(GL_VERTEX_ARRAY); - glDrawArrays(GL_LINES,0,2); -#else - glLineWidth(13.0f); - glBegin(GL_LINES); - glColor4ub(GLubyte(_Color0>>16), GLubyte(_Color0>>8), GLubyte(_Color0), GLubyte(_Color0>>24)); - glVertex2f((GLfloat)_X0+dx, (GLfloat)_Y0+dy); - glColor4ub(GLubyte(_Color1>>16), GLubyte(_Color1>>8), GLubyte(_Color1), GLubyte(_Color1>>24)); - glVertex2f((GLfloat)_X1+dx, (GLfloat)_Y1+dy); - glEnd(); -#endif - glDisable(GL_LINE_SMOOTH); -} - -static void drawRect(int horStart, int vertStart, int horEnd, int vertEnd, unsigned int argbColor00,unsigned int argbColor10,unsigned int argbColor01,unsigned int argbColor11) -{ - float dx = 0; - float dy = 0; - glDisable(GL_TEXTURE_2D); - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); -#ifdef USE_ARRAYS - GLfloat verts[] ={ - 0.0f, 1.0f, 0.0f, - -1.0f, -1.0f, 0.0f, - 1.0f, -1.0f, 0.0f, - 0.f,0.f,0.f - }; - - glColor4ub(GLubyte(argbColor00>>16), GLubyte(argbColor00>>8), GLubyte(argbColor00), GLubyte(argbColor00>>24)); - verts[0] = (GLfloat)horStart+dx; verts[1] = (GLfloat)vertStart+dy; - verts[2] = (GLfloat)horEnd+dx; verts[3] = (GLfloat)vertStart+dy; - verts[4] = (GLfloat)horEnd+dx; verts[5] = (GLfloat)vertEnd+dy; - verts[6] = (GLfloat)horStart+dx; verts[7] = (GLfloat)vertEnd+dy; - - glDisableClientState(GL_COLOR_ARRAY); - glDisableClientState(GL_NORMAL_ARRAY); - glDisableClientState (GL_TEXTURE_COORD_ARRAY); - glEnableClientState(GL_VERTEX_ARRAY); - glVertexPointer(2, GL_FLOAT, 0, verts); - glDrawArrays(GL_TRIANGLE_FAN, 0, 4); - -#else - glBegin(GL_QUADS); - glColor4ub(GLubyte(argbColor00>>16), GLubyte(argbColor00>>8), GLubyte(argbColor00), GLubyte(argbColor00>>24)); - glVertex2f((GLfloat)horStart+dx, (GLfloat)vertStart+dy); - glColor4ub(GLubyte(argbColor10>>16), GLubyte(argbColor10>>8), GLubyte(argbColor10), GLubyte(argbColor10>>24)); - glVertex2f((GLfloat)horEnd+dx, (GLfloat)vertStart+dy); - glColor4ub(GLubyte(argbColor11>>16), GLubyte(argbColor11>>8), GLubyte(argbColor11), GLubyte(argbColor11>>24)); - glVertex2f((GLfloat)horEnd+dx, (GLfloat)vertEnd+dy); - glColor4ub(GLubyte(argbColor01>>16), GLubyte(argbColor01>>8), GLubyte(argbColor01), GLubyte(argbColor01>>24)); - glVertex2f((GLfloat)horStart+dx, (GLfloat)vertEnd+dy); - glEnd(); -#endif - -} - -void GL_DialogWindow::draw(btScalar deltaTime) -{ - if (!m_screenWidth || !m_screenHeight) - return; - - m_dialogHorPos = int(m_collisionObject->getWorldTransform().getOrigin()[0]+m_screenWidth/2.f-m_dialogWidth/2.f); - - m_dialogVertPos = int(m_collisionObject->getWorldTransform().getOrigin()[1]+m_screenHeight/2.f-m_dialogHeight/2.f); - saveOpenGLState(); - - //drawRect(m_dialogHorPos,m_dialogVertPos,m_dialogHorPos+m_dialogWidth,m_dialogVertPos+m_dialogHeight,0xa6000000); - unsigned int argbColor = 0x86000000; - int charHeight = 16; - int charWidth = 10; - - int titleHeight = charHeight + 2; - - drawRect(m_dialogHorPos,m_dialogVertPos,m_dialogHorPos+m_dialogWidth-1,m_dialogVertPos+titleHeight,argbColor,argbColor,argbColor,argbColor); - //const unsigned int COL0 = 0x50ffffff; - const unsigned int COL0 = 0xffffffff; - const unsigned int COL1 = 0xff1f1f1f; - - drawRect(m_dialogHorPos,m_dialogVertPos,m_dialogHorPos+m_dialogWidth-1,m_dialogVertPos+1,COL0,COL0,COL1,COL1); - - argbColor = 0x864f4f4f; - drawRect(m_dialogHorPos+1,m_dialogVertPos+titleHeight,m_dialogHorPos+m_dialogWidth-1,m_dialogVertPos+m_dialogHeight,argbColor,argbColor,argbColor,argbColor); - - - int y = m_dialogVertPos+charHeight+1; - glLineWidth(3); - drawLine(m_dialogHorPos, y, m_dialogHorPos+m_dialogWidth-1, y, 0x80afafaf,0x80afafaf); - - - - unsigned int clight = 0x5FFFFFFF; // bar contour - drawLine(m_dialogHorPos, m_dialogVertPos, m_dialogHorPos, m_dialogVertPos+m_dialogHeight, clight,clight); - drawLine(m_dialogHorPos, m_dialogVertPos, m_dialogHorPos+m_dialogWidth, m_dialogVertPos, clight,clight); - drawLine(m_dialogHorPos+m_dialogWidth, m_dialogVertPos, m_dialogHorPos+m_dialogWidth, m_dialogVertPos+m_dialogHeight, clight,clight); - drawLine(m_dialogHorPos, m_dialogVertPos+m_dialogHeight, m_dialogHorPos+m_dialogWidth, m_dialogVertPos+m_dialogHeight, clight,clight); - int dshad = 3; // bar shadows - - unsigned int cshad = (((0x40000000>>24)/2)<<24) & 0xFF000000; - drawRect(m_dialogHorPos, m_dialogVertPos+m_dialogHeight, m_dialogHorPos+dshad, m_dialogVertPos+m_dialogHeight+dshad, 0, cshad, 0, 0); - drawRect(m_dialogHorPos+dshad+1, m_dialogVertPos+m_dialogHeight, m_dialogHorPos+m_dialogWidth-1, m_dialogVertPos+m_dialogHeight+dshad, cshad, cshad, 0, 0); - drawRect(m_dialogHorPos+m_dialogWidth, m_dialogVertPos+m_dialogHeight, m_dialogHorPos+m_dialogWidth+dshad, m_dialogVertPos+m_dialogHeight+dshad, cshad, 0, 0, 0); - drawRect(m_dialogHorPos+m_dialogWidth, m_dialogVertPos, m_dialogHorPos+m_dialogWidth+dshad, m_dialogVertPos+dshad, 0, 0, cshad, 0); - drawRect(m_dialogHorPos+m_dialogWidth, m_dialogVertPos+dshad+1, m_dialogHorPos+m_dialogWidth+dshad, m_dialogVertPos+m_dialogHeight-1, cshad, 0, cshad, 0); - - int yInc = 16; - int curHorPos = m_dialogHorPos+5; - int curVertPos = m_dialogVertPos; - curVertPos += yInc; - - GLDebugDrawString(m_dialogHorPos+m_dialogWidth/2-((int(strlen(m_dialogTitle)/2))*charWidth),m_dialogVertPos+yInc ,m_dialogTitle); - curVertPos += 20; - - - for (int i=0;idraw(curHorPos,curVertPos,deltaTime); - } - - restoreOpenGLState(); -} - - -void GL_DialogWindow::saveOpenGLState() -{ -#if 0 - glPushAttrib(GL_ALL_ATTRIB_BITS); - glPushClientAttrib(GL_CLIENT_ALL_ATTRIB_BITS); -#endif - - glMatrixMode(GL_TEXTURE); - glPushMatrix(); - glLoadIdentity(); - glMatrixMode(GL_MODELVIEW); - glPushMatrix(); - glLoadIdentity(); - glMatrixMode(GL_PROJECTION); - glPushMatrix(); - GLint Vp[4]; - glGetIntegerv(GL_VIEWPORT, Vp); - - if( m_screenWidth>0 && m_screenHeight>0 ) - { - Vp[0] = 0; - Vp[1] = 0; - Vp[2] = m_screenWidth-1; - Vp[3] = m_screenHeight-1; - glViewport(Vp[0], Vp[1], Vp[2], Vp[3]); - } - glLoadIdentity(); - glOrtho(Vp[0], Vp[0]+Vp[2], Vp[1]+Vp[3], Vp[1], -1, 1); - glGetIntegerv(GL_VIEWPORT, m_ViewportInit); - glGetFloatv(GL_PROJECTION_MATRIX, m_ProjMatrixInit); - - glGetFloatv(GL_LINE_WIDTH, &m_PrevLineWidth); - // glDisable(GL_POLYGON_STIPPLE); - glLineWidth(1); - - glDisable(GL_LINE_SMOOTH); -// glDisable(GL_LINE_STIPPLE); - glDisable(GL_CULL_FACE); - glDisable(GL_DEPTH_TEST); - glDisable(GL_LIGHTING); - glEnable(GL_BLEND); - - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glGetTexEnviv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, &m_PrevTexEnv); - glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); - glDisable(GL_TEXTURE_2D); - -} - -void GL_DialogWindow::restoreOpenGLState() -{ - glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, m_PrevTexEnv); - glLineWidth(m_PrevLineWidth); - glMatrixMode(GL_PROJECTION); - glPopMatrix(); - glMatrixMode(GL_MODELVIEW); - glPopMatrix(); - glMatrixMode(GL_TEXTURE); - glPopMatrix(); - glPopClientAttrib(); - glPopAttrib(); - -} - - -void GL_TextControl::draw(int& parentHorPos,int& parentVertPos,btScalar deltaTime) -{ - for (int i=0;igetWorldTransform().getOrigin()[0]+m_parentWindow->getScreenWidth()/2); - int controlVertPos = int(m_toggleBody->getWorldTransform().getOrigin()[1]+m_parentWindow->getScreenHeight()/2); - - int parentHorPos = controlHorPos-8; - int parentVertPos = controlVertPos-8; - - unsigned int grey = 0xff6f6f6f; - - drawRect(parentHorPos, parentVertPos, parentHorPos+16, parentVertPos+16, grey, grey, grey, grey); - - int borderSize = 2; - unsigned int white = 0xffefefef; - drawRect(parentHorPos+borderSize, parentVertPos+borderSize, parentHorPos+16-borderSize, parentVertPos+16-borderSize, white,white,white,white); - - - if (m_active) - { - //unsigned int red = 0xff8f0000; - // unsigned int white = 0xff8f0000; - unsigned int black = 0xff1f1f1f; - borderSize = 4; - drawRect(parentHorPos+borderSize, parentVertPos+borderSize, parentHorPos+16-borderSize, parentVertPos+16-borderSize, black,black,black,black); - } - - btVector3 rgb(1,1,1); - - GLDebugDrawStringInternal(parentHorPos2,parentVertPos+16,m_toggleText,rgb); - parentVertPos2+=20; - -} - -void GL_SliderControl::draw(int& parentHorPos2,int& parentVertPos2,btScalar deltaTime) -{ - - int controlHorPos = int(m_sliderBody->getWorldTransform().getOrigin()[0]+m_parentWindow->getScreenWidth()/2); - int controlVertPos = int(m_sliderBody->getWorldTransform().getOrigin()[1]+m_parentWindow->getScreenHeight()/2); - - int parentHorPos = controlHorPos-8; - int parentVertPos = controlVertPos-8; - - unsigned int grey = 0xff6f6f6f; - int borderSize = 2; - unsigned int white = 0xffefefef; - int sliderPosS = parentHorPos2+150+borderSize; - int sliderPosE = parentHorPos2+m_parentWindow->getDialogWidth()-40-borderSize; - int sliderPos = controlHorPos; - if(sliderPos < sliderPosS) sliderPos = sliderPosS; - if(sliderPos > sliderPosE) sliderPos = sliderPosE; -// drawRect(parentHorPos2+80+borderSize, parentVertPos2+borderSize, parentHorPos2+m_parentWindow->getDialogWidth()-16-borderSize, parentVertPos2+2-borderSize, white,white,white,white); - drawRect( sliderPosS, - parentVertPos2+borderSize, - sliderPosE, - parentVertPos2+2-borderSize, - white,white,white,white); - - drawRect(parentHorPos, parentVertPos, parentHorPos+16, parentVertPos+16, grey, grey, grey, grey); - - - - drawRect(parentHorPos+borderSize, parentVertPos+borderSize, parentHorPos+16-borderSize, parentVertPos+16-borderSize, white,white,white,white); - - - - btVector3 rgb(1,1,1); - -// btSliderConstraint* pSlider = (btSliderConstraint*)m_constraint; -// btScalar currPos = pSlider->getLinearPos(); -// if(currPos < pSlider->getLowerLinLimit()) currPos = pSlider->getLowerLinLimit(); -// if(currPos > pSlider->getUpperLinLimit()) currPos = pSlider->getUpperLinLimit(); -// m_fraction = (currPos - pSlider->getLowerLinLimit()) / (pSlider->getUpperLinLimit() - pSlider->getLowerLinLimit()); - m_fraction = (btScalar)(sliderPos - sliderPosS) / (btScalar)(sliderPosE - sliderPosS); - - char tmpBuf[256]; - sprintf(tmpBuf, "%s %3d%%", m_sliderText, (int)(m_fraction * 100.f)); - -// GLDebugDrawStringInternal(parentHorPos2,parentVertPos2+8,m_sliderText,rgb); - GLDebugDrawStringInternal(parentHorPos2,parentVertPos2+8, tmpBuf, rgb); - parentVertPos2+=20; - -} diff --git a/Demos/OpenGL/GL_DialogWindow.h b/Demos/OpenGL/GL_DialogWindow.h deleted file mode 100644 index 75cb04e75..000000000 --- a/Demos/OpenGL/GL_DialogWindow.h +++ /dev/null @@ -1,285 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef GL_DIALOG_WINDOW_H -#define GL_DIALOG_WINDOW_H - -class btCollisionObject; - - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#if (defined (TARGET_OS_IPHONE) && TARGET_OS_IPHONE) || (defined (TARGET_IPHONE_SIMULATOR) && TARGET_IPHONE_SIMULATOR) -#import -#define glOrtho glOrthof -#else -#include -#include -#include -#endif -#else - - -#ifdef _WIN32 -#include -#include -#include -#else -#include -#include -#endif -#endif - - -#include "LinearMath/btScalar.h" -#include "LinearMath/btAlignedObjectArray.h" -class btTypedConstraint; - -class GL_DialogWindow; - -enum GL_DIALOG_CONTROL_TYPES -{ - GL_TEXT_CONTROL=1, - GL_TOGGLE_CONTROL, - GL_SLIDER_CONTROL, - GL_CONTROL_MAX_TYPE -}; - -class GL_DialogControl -{ -protected: - int m_type; - -public: - - virtual ~GL_DialogControl() - { - } - virtual void draw(int& parentHorPos,int& parentVertPos,btScalar deltaTime)=0; - - int getType() const - { - return m_type; - } -}; - -struct GL_TextControl : public GL_DialogControl -{ -public: - - btAlignedObjectArray m_textLines; - - GL_TextControl() - { - m_type = GL_TEXT_CONTROL; - } - - virtual ~GL_TextControl() {} - - virtual void draw(int& parentHorPos,int& parentVertPos,btScalar deltaTime); -}; - - -struct GL_ToggleControl : public GL_DialogControl -{ - btCollisionObject* m_toggleBody; - GL_DialogWindow* m_parentWindow; - - const char* m_toggleText; - -public: - - bool m_active; - - - GL_ToggleControl(const char* toggleText,btCollisionObject* toggleBody, GL_DialogWindow* parentWindow) - :m_toggleBody(toggleBody), - m_parentWindow(parentWindow), - m_toggleText(toggleText), - m_active(false) - { - m_type = GL_TOGGLE_CONTROL; - } - - virtual void draw(int& parentHorPos,int& parentVertPos,btScalar deltaTime); -}; - -struct GL_SliderControl : public GL_DialogControl -{ - btCollisionObject* m_sliderBody; - GL_DialogWindow* m_parentWindow; - btScalar m_lowerLimit; - btScalar m_upperLimit; - btTypedConstraint* m_constraint; - btScalar m_fraction; - - const char* m_sliderText; -public: - - GL_SliderControl(const char* sliderText,btCollisionObject* sliderBody, GL_DialogWindow* parentWindow, btScalar lowerLimit,btScalar upperLimit,btTypedConstraint* constaint) - :m_sliderBody(sliderBody), - m_parentWindow(parentWindow), - m_lowerLimit(lowerLimit), - m_upperLimit(upperLimit), - m_constraint(constaint), - m_sliderText(sliderText) - { - m_type = GL_SLIDER_CONTROL; - } - - virtual void draw(int& parentHorPos,int& parentVertPos,btScalar deltaTime); - - btScalar btGetFraction() { return m_fraction; } - - btScalar getLowerLimit() - { - return m_lowerLimit; - } - btScalar getUpperLimit() - { - return m_upperLimit; - } - btTypedConstraint* getConstraint() - { - return m_constraint; - } -}; - -///Very basic OpenGL Graphical Userinterface Window with text, toggle, slider control -class GL_DialogWindow -{ - - int m_dialogHorPos; - int m_dialogVertPos; - int m_dialogWidth; - int m_dialogHeight; - - int m_screenWidth; - int m_screenHeight; - - const char* m_dialogTitle; - - //saved OpenGL settings - GLfloat m_PrevLineWidth; - GLint m_PrevTexEnv; - GLint m_PrevPolygonMode[2]; - GLint m_MaxClipPlanes; - GLint m_PrevTexture; - GLint m_PrevArrayBufferARB; - GLint m_PrevElementArrayBufferARB; - GLboolean m_PrevVertexProgramARB; - GLboolean m_PrevFragmentProgramARB; - GLuint m_PrevProgramObjectARB; - GLboolean m_PrevTexture3D; - GLboolean m_PrevActiveTexture1D[32]; - GLboolean m_PrevActiveTexture2D[32]; - GLboolean m_PrevActiveTexture3D[32]; - GLint m_PrevActiveTextureARB; - bool m_SupportTexRect; - GLboolean m_PrevTexRectARB; - GLint m_PrevBlendEquation; - GLint m_PrevBlendEquationRGB; - GLint m_PrevBlendEquationAlpha; - GLint m_PrevBlendSrcRGB; - GLint m_PrevBlendDstRGB; - GLint m_PrevBlendSrcAlpha; - GLint m_PrevBlendDstAlpha; - GLint m_ViewportInit[4]; - GLfloat m_ProjMatrixInit[16]; - - btCollisionObject* m_collisionObject; - - btAlignedObjectArray m_controls; - -protected: - - - void saveOpenGLState(); - void restoreOpenGLState(); - -// void drawLine(int _X0, int _Y0, int _X1, int _Y1, unsigned int _Color0, unsigned int _Color1, bool antiAliased); -// void drawRect(int horStart, int vertStart, int horEnd, int vertEnd, unsigned int argbColor00,unsigned int argbColor10,unsigned int argbColor01,unsigned int argbColor11); - -public: - - - GL_DialogWindow(int horPos,int vertPos,int dialogWidth,int dialogHeight,btCollisionObject* colObject, const char* dialogTitle); - - virtual ~GL_DialogWindow(); - - void draw(btScalar deltaTime); - - void setScreenSize(int width, int height); - - void setStartPosition(int dialogHorPos,int dialogVertPos); - - void addControl(GL_DialogControl* control) - { - m_controls.push_back(control); - } - - void removeControl(GL_DialogControl* control) - { - m_controls.remove(control); - } - - btCollisionObject* getCollisionObject() - { - return m_collisionObject; - } - - int getDialogHorPos() const - { - return m_dialogHorPos; - } - int getDialogVertPos() const - { - return m_dialogVertPos; - } - int getDialogWidth() const - { - return m_dialogWidth; - } - - int getDialogHeight() const - { - return m_dialogHeight; - } - int getScreenWidth() const - { - return m_screenWidth; - } - int getScreenHeight() const - { - return m_screenHeight; - } - - int getNumControls() const - { - return m_controls.size(); - } - - const GL_DialogControl* getControl(int index) const - { - return m_controls[index]; - } - GL_DialogControl* getControl(int index) - { - return m_controls[index]; - } -}; - -#endif //GL_DIALOG_WINDOW_H diff --git a/Demos/OpenGL/GL_ShapeDrawer.cpp b/Demos/OpenGL/GL_ShapeDrawer.cpp deleted file mode 100644 index a471db017..000000000 --- a/Demos/OpenGL/GL_ShapeDrawer.cpp +++ /dev/null @@ -1,929 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifdef _WIN32 //needed for glut.h -#include -#endif -#include "GLDebugFont.h" - - - -#include "GlutStuff.h" -#include "GL_ShapeDrawer.h" -#include "BulletCollision/CollisionShapes/btPolyhedralConvexShape.h" -#include "BulletCollision/CollisionShapes/btTriangleMeshShape.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/CollisionShapes/btSphereShape.h" -#include "BulletCollision/CollisionShapes/btConeShape.h" -#include "BulletCollision/CollisionShapes/btCylinderShape.h" -#include "BulletCollision/CollisionShapes/btTetrahedronShape.h" -#include "BulletCollision/CollisionShapes/btCompoundShape.h" -#include "BulletCollision/CollisionShapes/btCapsuleShape.h" -#include "BulletCollision/CollisionShapes/btConvexTriangleMeshShape.h" -#include "BulletCollision/CollisionShapes/btUniformScalingShape.h" -#include "BulletCollision/CollisionShapes/btStaticPlaneShape.h" -#include "BulletCollision/CollisionShapes/btMultiSphereShape.h" -#include "BulletCollision/CollisionShapes/btConvexPolyhedron.h" - -/// -#include "BulletCollision/CollisionShapes/btShapeHull.h" - -#include "LinearMath/btTransformUtil.h" - - -#include "LinearMath/btIDebugDraw.h" -//for debugmodes - -#include //printf debugging - -//#define USE_DISPLAY_LISTS 1 -#ifdef USE_DISPLAY_LISTS - -#include - -using namespace std; - -//Set for storing Display list per trimesh -struct TRIMESH_KEY -{ - btCollisionShape* m_shape; - GLuint m_dlist;//OpenGL display list -}; - -typedef map TRIMESH_KEY_MAP; - -typedef pair TRIMESH_KEY_PAIR; - -TRIMESH_KEY_MAP g_display_lists; - -class GlDisplaylistDrawcallback : public btTriangleCallback -{ -public: - - virtual void processTriangle(btVector3* triangle,int partId, int triangleIndex) - { - - btVector3 diff1 = triangle[1] - triangle[0]; - btVector3 diff2 = triangle[2] - triangle[0]; - btVector3 normal = diff1.cross(diff2); - - normal.normalize(); - - glBegin(GL_TRIANGLES); - glColor3f(1, 1, 1); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - - //glColor3f(0, 1, 0); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - - //glColor3f(0, 1, 0); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glEnd(); - - /*glBegin(GL_LINES); - glColor3f(1, 1, 0); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glColor3f(1, 1, 0); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glColor3f(1, 1, 0); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glNormal3d(normal.getX(),normal.getY(),normal.getZ()); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glEnd();*/ - - - } -}; - -GLuint OGL_get_displaylist_for_shape(btCollisionShape * shape) -{ - TRIMESH_KEY_MAP::iterator map_iter; - - unsigned long key = (unsigned long)shape; - map_iter = g_display_lists.find(key); - if(map_iter!=g_display_lists.end()) - { - return map_iter->second.m_dlist; - } - - return 0; -} - -void OGL_displaylist_clean() -{ - TRIMESH_KEY_MAP::iterator map_iter,map_itend; - - map_iter = g_display_lists.begin(); - - while(map_iter!=map_itend) - { - glDeleteLists(map_iter->second.m_dlist,1); - map_iter++; - } - - g_display_lists.clear(); -} - - -void OGL_displaylist_register_shape(btCollisionShape * shape) -{ - btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT)); - btVector3 aabbMin(-btScalar(BT_LARGE_FLOAT),-btScalar(BT_LARGE_FLOAT),-btScalar(BT_LARGE_FLOAT)); - GlDisplaylistDrawcallback drawCallback; - TRIMESH_KEY dlist; - - dlist.m_dlist = glGenLists(1); - dlist.m_shape = shape; - - unsigned long key = (unsigned long)shape; - - g_display_lists.insert(TRIMESH_KEY_PAIR(key,dlist)); - - glNewList(dlist.m_dlist,GL_COMPILE); - -// glEnable(GL_CULL_FACE); - - glCullFace(GL_BACK); - - if (shape->isConcave()) - { - btConcaveShape* concaveMesh = (btConcaveShape*) shape; - //todo pass camera, for some culling - concaveMesh->processAllTriangles(&drawCallback,aabbMin,aabbMax); - } - -// glDisable(GL_CULL_FACE); - - glEndList(); -} -#endif //USE_DISPLAY_LISTS - -void GL_ShapeDrawer::drawCoordSystem() { - glBegin(GL_LINES); - glColor3f(1, 0, 0); - glVertex3d(0, 0, 0); - glVertex3d(1, 0, 0); - glColor3f(0, 1, 0); - glVertex3d(0, 0, 0); - glVertex3d(0, 1, 0); - glColor3f(0, 0, 1); - glVertex3d(0, 0, 0); - glVertex3d(0, 0, 1); - glEnd(); - -} - - - - - -class GlDrawcallback : public btTriangleCallback -{ - -public: - - bool m_wireframe; - - GlDrawcallback() - :m_wireframe(false) - { - } - - virtual void processTriangle(btVector3* triangle,int partId, int triangleIndex) - { - - (void)triangleIndex; - (void)partId; - - - if (m_wireframe) - { - glBegin(GL_LINES); - glColor3f(1, 0, 0); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glColor3f(0, 1, 0); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glColor3f(0, 0, 1); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glEnd(); - } else - { - glBegin(GL_TRIANGLES); - //glColor3f(1, 1, 1); - - - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glEnd(); - } - } -}; - -class TriangleGlDrawcallback : public btInternalTriangleIndexCallback -{ -public: - virtual void internalProcessTriangleIndex(btVector3* triangle,int partId,int triangleIndex) - { - (void)triangleIndex; - (void)partId; - - - glBegin(GL_TRIANGLES);//LINES); - glColor3f(1, 0, 0); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glColor3f(0, 1, 0); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glVertex3d(triangle[1].getX(), triangle[1].getY(), triangle[1].getZ()); - glColor3f(0, 0, 1); - glVertex3d(triangle[2].getX(), triangle[2].getY(), triangle[2].getZ()); - glVertex3d(triangle[0].getX(), triangle[0].getY(), triangle[0].getZ()); - glEnd(); - } -}; - - -void GL_ShapeDrawer::drawSphere(btScalar radius, int lats, int longs) -{ - int i, j; - for(i = 0; i <= lats; i++) { - btScalar lat0 = SIMD_PI * (-btScalar(0.5) + (btScalar) (i - 1) / lats); - btScalar z0 = radius*sin(lat0); - btScalar zr0 = radius*cos(lat0); - - btScalar lat1 = SIMD_PI * (-btScalar(0.5) + (btScalar) i / lats); - btScalar z1 = radius*sin(lat1); - btScalar zr1 = radius*cos(lat1); - - glBegin(GL_QUAD_STRIP); - for(j = 0; j <= longs; j++) { - btScalar lng = 2 * SIMD_PI * (btScalar) (j - 1) / longs; - btScalar x = cos(lng); - btScalar y = sin(lng); - glNormal3f(x * zr1, y * zr1, z1); - glVertex3f(x * zr1, y * zr1, z1); - glNormal3f(x * zr0, y * zr0, z0); - glVertex3f(x * zr0, y * zr0, z0); - } - glEnd(); - } -} - - -GL_ShapeDrawer::ShapeCache* GL_ShapeDrawer::cache(btConvexShape* shape) -{ - ShapeCache* sc=(ShapeCache*)shape->getUserPointer(); - if(!sc) - { - sc=new(btAlignedAlloc(sizeof(ShapeCache),16)) ShapeCache(shape); - sc->m_shapehull.buildHull(shape->getMargin()); - m_shapecaches.push_back(sc); - shape->setUserPointer(sc); - /* Build edges */ - const int ni=sc->m_shapehull.numIndices(); - const int nv=sc->m_shapehull.numVertices(); - const unsigned int* pi=sc->m_shapehull.getIndexPointer(); - const btVector3* pv=sc->m_shapehull.getVertexPointer(); - btAlignedObjectArray edges; - sc->m_edges.reserve(ni); - edges.resize(nv*nv,0); - for(int i=0;im_edges.push_back(ShapeCache::Edge()); - e=&sc->m_edges[sc->m_edges.size()-1]; - e->n[0]=nrm;e->n[1]=-nrm; - e->v[0]=a;e->v[1]=b; - } - else - { - e->n[1]=nrm; - } - } - } - } - return(sc); -} - -void renderSquareA(float x, float y, float z) -{ - glBegin(GL_LINE_LOOP); - glVertex3f(x, y, z); - glVertex3f(x + 10.f, y, z); - glVertex3f(x + 10.f, y + 10.f, z); - glVertex3f(x, y + 10.f, z); - glEnd(); -} - -inline void glDrawVector(const btVector3& v) { glVertex3d(v[0], v[1], v[2]); } - - -void GL_ShapeDrawer::drawOpenGL(btScalar* m, const btCollisionShape* shape, const btVector3& color,int debugMode,const btVector3& worldBoundsMin,const btVector3& worldBoundsMax) -{ - - if (shape->getShapeType() == CUSTOM_CONVEX_SHAPE_TYPE) - { - btVector3 org(m[12], m[13], m[14]); - btVector3 dx(m[0], m[1], m[2]); - btVector3 dy(m[4], m[5], m[6]); -// btVector3 dz(m[8], m[9], m[10]); - const btBoxShape* boxShape = static_cast(shape); - btVector3 halfExtent = boxShape->getHalfExtentsWithMargin(); - dx *= halfExtent[0]; - dy *= halfExtent[1]; -// dz *= halfExtent[2]; - glColor3f(1,1,1); - glDisable(GL_LIGHTING); - glLineWidth(2); - - glBegin(GL_LINE_LOOP); - glDrawVector(org - dx - dy); - glDrawVector(org - dx + dy); - glDrawVector(org + dx + dy); - glDrawVector(org + dx - dy); - glEnd(); - return; - } - else if((shape->getShapeType() == BOX_SHAPE_PROXYTYPE) && (debugMode & btIDebugDraw::DBG_FastWireframe)) - { - btVector3 org(m[12], m[13], m[14]); - btVector3 dx(m[0], m[1], m[2]); - btVector3 dy(m[4], m[5], m[6]); - btVector3 dz(m[8], m[9], m[10]); - const btBoxShape* boxShape = static_cast(shape); - btVector3 halfExtent = boxShape->getHalfExtentsWithMargin(); - dx *= halfExtent[0]; - dy *= halfExtent[1]; - dz *= halfExtent[2]; - glBegin(GL_LINE_LOOP); - glDrawVector(org - dx - dy - dz); - glDrawVector(org + dx - dy - dz); - glDrawVector(org + dx + dy - dz); - glDrawVector(org - dx + dy - dz); - glDrawVector(org - dx + dy + dz); - glDrawVector(org + dx + dy + dz); - glDrawVector(org + dx - dy + dz); - glDrawVector(org - dx - dy + dz); - glEnd(); - glBegin(GL_LINES); - glDrawVector(org + dx - dy - dz); - glDrawVector(org + dx - dy + dz); - glDrawVector(org + dx + dy - dz); - glDrawVector(org + dx + dy + dz); - glDrawVector(org - dx - dy - dz); - glDrawVector(org - dx + dy - dz); - glDrawVector(org - dx - dy + dz); - glDrawVector(org - dx + dy + dz); - glEnd(); - return; - } - - glPushMatrix(); - btglMultMatrix(m); - - - if (shape->getShapeType() == UNIFORM_SCALING_SHAPE_PROXYTYPE) - { - const btUniformScalingShape* scalingShape = static_cast(shape); - const btConvexShape* convexShape = scalingShape->getChildShape(); - float scalingFactor = (float)scalingShape->getUniformScalingFactor(); - { - btScalar tmpScaling[4][4]={{scalingFactor,0,0,0}, - {0,scalingFactor,0,0}, - {0,0,scalingFactor,0}, - {0,0,0,1}}; - - drawOpenGL( (btScalar*)tmpScaling,convexShape,color,debugMode,worldBoundsMin,worldBoundsMax); - } - glPopMatrix(); - return; - } - - if (shape->getShapeType() == COMPOUND_SHAPE_PROXYTYPE) - { - const btCompoundShape* compoundShape = static_cast(shape); - for (int i=compoundShape->getNumChildShapes()-1;i>=0;i--) - { - btTransform childTrans = compoundShape->getChildTransform(i); - const btCollisionShape* colShape = compoundShape->getChildShape(i); - ATTRIBUTE_ALIGNED16(btScalar) childMat[16]; - childTrans.getOpenGLMatrix(childMat); - drawOpenGL(childMat,colShape,color,debugMode,worldBoundsMin,worldBoundsMax); - } - - } else - { - if(m_textureenabled&&(!m_textureinitialized)) - { - GLubyte* image=new GLubyte[256*256*4]; - for(int y=0;y<256;++y) - { - const int t=y>>4; - GLubyte* pi=image+y*256*3; - for(int x=0;x<256;++x) - { - const int s=x>>4; - const GLubyte b=180; - GLubyte c=b+((s+(t&1))&1)*(255-b); - pi[0]=pi[1]=pi[2]=pi[3]=c;pi+=3; - } - } - - glGenTextures(1,(GLuint*)&m_texturehandle); - glBindTexture(GL_TEXTURE_2D,m_texturehandle); - - - glGenTextures(1,(GLuint*)&m_texturehandle); - glBindTexture(GL_TEXTURE_2D,m_texturehandle); - glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR); - glTexImage2D(GL_TEXTURE_2D, 0, 3, 256 , 256 , 0, GL_RGB, GL_UNSIGNED_BYTE, image); - //glGenerateMipmap(GL_TEXTURE_2D); - delete[] image; - - - } - - glMatrixMode(GL_TEXTURE); - glLoadIdentity(); - glScalef(0.025f,0.025f,0.025f); - glMatrixMode(GL_MODELVIEW); - - static const GLfloat planex[]={1,0,0,0}; - // static const GLfloat planey[]={0,1,0,0}; - static const GLfloat planez[]={0,0,1,0}; - glTexGenfv(GL_S,GL_OBJECT_PLANE,planex); - glTexGenfv(GL_T,GL_OBJECT_PLANE,planez); - glTexGeni(GL_S,GL_TEXTURE_GEN_MODE,GL_OBJECT_LINEAR); - glTexGeni(GL_T,GL_TEXTURE_GEN_MODE,GL_OBJECT_LINEAR); - glEnable(GL_TEXTURE_GEN_S); - glEnable(GL_TEXTURE_GEN_T); - glEnable(GL_TEXTURE_GEN_R); - m_textureinitialized=true; - - - - - //drawCoordSystem(); - - //glPushMatrix(); - glEnable(GL_COLOR_MATERIAL); - if(m_textureenabled) - { - glEnable(GL_TEXTURE_2D); - glBindTexture(GL_TEXTURE_2D,m_texturehandle); - } else - { - glDisable(GL_TEXTURE_2D); - } - - - glColor3f(color.x(),color.y(), color.z()); - - //bool useWireframeFallback = true; - - if (!(debugMode & btIDebugDraw::DBG_DrawWireframe)) - { - ///you can comment out any of the specific cases, and use the default - - ///the benefit of 'default' is that it approximates the actual collision shape including collision margin - //int shapetype=m_textureenabled?MAX_BROADPHASE_COLLISION_TYPES:shape->getShapeType(); - int shapetype=shape->getShapeType(); - switch (shapetype) - { - - case SPHERE_SHAPE_PROXYTYPE: - { - const btSphereShape* sphereShape = static_cast(shape); - float radius = sphereShape->getMargin();//radius doesn't include the margin, so draw with margin - drawSphere(radius,10,10); - //useWireframeFallback = false; - break; - } - - case BOX_SHAPE_PROXYTYPE: - { - const btBoxShape* boxShape = static_cast(shape); - btVector3 halfExtent = boxShape->getHalfExtentsWithMargin(); - - static int indices[36] = { - 0,1,2, - 3,2,1, - 4,0,6, - 6,0,2, - 5,1,4, - 4,1,0, - 7,3,1, - 7,1,5, - 5,4,7, - 7,4,6, - 7,2,3, - 7,6,2}; - - btVector3 vertices[8]={ - btVector3(halfExtent[0],halfExtent[1],halfExtent[2]), - btVector3(-halfExtent[0],halfExtent[1],halfExtent[2]), - btVector3(halfExtent[0],-halfExtent[1],halfExtent[2]), - btVector3(-halfExtent[0],-halfExtent[1],halfExtent[2]), - btVector3(halfExtent[0],halfExtent[1],-halfExtent[2]), - btVector3(-halfExtent[0],halfExtent[1],-halfExtent[2]), - btVector3(halfExtent[0],-halfExtent[1],-halfExtent[2]), - btVector3(-halfExtent[0],-halfExtent[1],-halfExtent[2])}; -#if 1 - glBegin (GL_TRIANGLES); - int si=36; - for (int i=0;i(shape); - int upIndex = coneShape->getConeUpIndex(); - float radius = coneShape->getRadius();//+coneShape->getMargin(); - float height = coneShape->getHeight();//+coneShape->getMargin(); - switch (upIndex) - { - case 0: - glRotatef(90.0, 0.0, 1.0, 0.0); - break; - case 1: - glRotatef(-90.0, 1.0, 0.0, 0.0); - break; - case 2: - break; - default: - { - } - }; - - glTranslatef(0.0, 0.0, -0.5*height); - glutSolidCone(radius,height,10,10); - //useWireframeFallback = false; - break; - - } -#endif - - case STATIC_PLANE_PROXYTYPE: - { - const btStaticPlaneShape* staticPlaneShape = static_cast(shape); - btScalar planeConst = staticPlaneShape->getPlaneConstant(); - const btVector3& planeNormal = staticPlaneShape->getPlaneNormal(); - btVector3 planeOrigin = planeNormal * planeConst; - btVector3 vec0,vec1; - btPlaneSpace1(planeNormal,vec0,vec1); - btScalar vecLen = 100.f; - btVector3 pt0 = planeOrigin + vec0*vecLen; - btVector3 pt1 = planeOrigin - vec0*vecLen; - btVector3 pt2 = planeOrigin + vec1*vecLen; - btVector3 pt3 = planeOrigin - vec1*vecLen; - glBegin(GL_LINES); - glVertex3f(pt0.getX(),pt0.getY(),pt0.getZ()); - glVertex3f(pt1.getX(),pt1.getY(),pt1.getZ()); - glVertex3f(pt2.getX(),pt2.getY(),pt2.getZ()); - glVertex3f(pt3.getX(),pt3.getY(),pt3.getZ()); - glEnd(); - - - break; - - } - - - case MULTI_SPHERE_SHAPE_PROXYTYPE: - { - const btMultiSphereShape* multiSphereShape = static_cast(shape); - - btTransform childTransform; - childTransform.setIdentity(); - - - for (int i = multiSphereShape->getSphereCount()-1; i>=0;i--) - { - btSphereShape sc(multiSphereShape->getSphereRadius(i)); - childTransform.setOrigin(multiSphereShape->getSpherePosition(i)); - ATTRIBUTE_ALIGNED16(btScalar) childMat[16]; - childTransform.getOpenGLMatrix(childMat); - drawOpenGL(childMat,&sc,color,debugMode,worldBoundsMin,worldBoundsMax); - } - - break; - } - - default: - { - if (shape->isConvex()) - { - const btConvexPolyhedron* poly = shape->isPolyhedral() ? ((btPolyhedralConvexShape*) shape)->getConvexPolyhedron() : 0; - if (poly) - { - int i; - glBegin (GL_TRIANGLES); - for (i=0;im_faces.size();i++) - { - btVector3 centroid(0,0,0); - int numVerts = poly->m_faces[i].m_indices.size(); - if (numVerts>2) - { - btVector3 v1 = poly->m_vertices[poly->m_faces[i].m_indices[0]]; - for (int v=0;vm_faces[i].m_indices.size()-2;v++) - { - - btVector3 v2 = poly->m_vertices[poly->m_faces[i].m_indices[v+1]]; - btVector3 v3 = poly->m_vertices[poly->m_faces[i].m_indices[v+2]]; - btVector3 normal = (v3-v1).cross(v2-v1); - normal.normalize (); - glNormal3f(normal.getX(),normal.getY(),normal.getZ()); - glVertex3f (v1.x(), v1.y(), v1.z()); - glVertex3f (v2.x(), v2.y(), v2.z()); - glVertex3f (v3.x(), v3.y(), v3.z()); - } - } - } - glEnd (); - } else - { - ShapeCache* sc=cache((btConvexShape*)shape); - //glutSolidCube(1.0); - btShapeHull* hull = &sc->m_shapehull/*(btShapeHull*)shape->getUserPointer()*/; - - if (hull->numTriangles () > 0) - { - int index = 0; - const unsigned int* idx = hull->getIndexPointer(); - const btVector3* vtx = hull->getVertexPointer(); - - glBegin (GL_TRIANGLES); - - for (int i = 0; i < hull->numTriangles (); i++) - { - int i1 = index++; - int i2 = index++; - int i3 = index++; - btAssert(i1 < hull->numIndices () && - i2 < hull->numIndices () && - i3 < hull->numIndices ()); - - int index1 = idx[i1]; - int index2 = idx[i2]; - int index3 = idx[i3]; - btAssert(index1 < hull->numVertices () && - index2 < hull->numVertices () && - index3 < hull->numVertices ()); - - btVector3 v1 = vtx[index1]; - btVector3 v2 = vtx[index2]; - btVector3 v3 = vtx[index3]; - btVector3 normal = (v3-v1).cross(v2-v1); - normal.normalize (); - glNormal3f(normal.getX(),normal.getY(),normal.getZ()); - glVertex3f (v1.x(), v1.y(), v1.z()); - glVertex3f (v2.x(), v2.y(), v2.z()); - glVertex3f (v3.x(), v3.y(), v3.z()); - - } - glEnd (); - - } - } - } - } - } - - } - - - glNormal3f(0,1,0); - - - /// for polyhedral shapes - if (debugMode==btIDebugDraw::DBG_DrawFeaturesText && (shape->isPolyhedral())) - { - btPolyhedralConvexShape* polyshape = (btPolyhedralConvexShape*) shape; - - { - - glColor3f(1.f, 1.f, 1.f); - int i; - for (i=0;igetNumVertices();i++) - { - btVector3 vtx; - polyshape->getVertex(i,vtx); - char buf[12]; - sprintf(buf," %d",i); - //btDrawString(BMF_GetFont(BMF_kHelvetica10),buf); - } - - for (i=0;igetNumPlanes();i++) - { - btVector3 normal; - btVector3 vtx; - polyshape->getPlane(normal,vtx,i); - //btScalar d = vtx.dot(normal); - - //char buf[12]; - //sprintf(buf," plane %d",i); - //btDrawString(BMF_GetFont(BMF_kHelvetica10),buf); - - } - } - - } - - -#ifdef USE_DISPLAY_LISTS - - if (shape->getShapeType() == TRIANGLE_MESH_SHAPE_PROXYTYPE||shape->getShapeType() == GIMPACT_SHAPE_PROXYTYPE) - { - GLuint dlist = OGL_get_displaylist_for_shape((btCollisionShape * )shape); - if (dlist) - { - glCallList(dlist); - } - else - { -#else - if (shape->isConcave() && !shape->isInfinite()) - { - btConcaveShape* concaveMesh = (btConcaveShape*) shape; - - GlDrawcallback drawCallback; - drawCallback.m_wireframe = (debugMode & btIDebugDraw::DBG_DrawWireframe)!=0; - - concaveMesh->processAllTriangles(&drawCallback,worldBoundsMin,worldBoundsMax); - - } -#endif - -#ifdef USE_DISPLAY_LISTS - } -} -#endif - - - - - - } - glPopMatrix(); - -} - -// -void GL_ShapeDrawer::drawShadow(btScalar* m,const btVector3& extrusion,const btCollisionShape* shape,const btVector3& worldBoundsMin,const btVector3& worldBoundsMax) -{ - glPushMatrix(); - btglMultMatrix(m); - if(shape->getShapeType() == UNIFORM_SCALING_SHAPE_PROXYTYPE) - { - const btUniformScalingShape* scalingShape = static_cast(shape); - const btConvexShape* convexShape = scalingShape->getChildShape(); - float scalingFactor = (float)scalingShape->getUniformScalingFactor(); - btScalar tmpScaling[4][4]={ {scalingFactor,0,0,0}, - {0,scalingFactor,0,0}, - {0,0,scalingFactor,0}, - {0,0,0,1}}; - drawShadow((btScalar*)tmpScaling,extrusion,convexShape,worldBoundsMin,worldBoundsMax); - glPopMatrix(); - return; - } - else if(shape->getShapeType()==COMPOUND_SHAPE_PROXYTYPE) - { - const btCompoundShape* compoundShape = static_cast(shape); - for (int i=compoundShape->getNumChildShapes()-1;i>=0;i--) - { - btTransform childTrans = compoundShape->getChildTransform(i); - const btCollisionShape* colShape = compoundShape->getChildShape(i); - ATTRIBUTE_ALIGNED16(btScalar) childMat[16]; - childTrans.getOpenGLMatrix(childMat); - drawShadow(childMat,extrusion*childTrans.getBasis(),colShape,worldBoundsMin,worldBoundsMax); - } - } - else - { - // bool useWireframeFallback = true; - if (shape->isConvex()) - { - ShapeCache* sc=cache((btConvexShape*)shape); - btShapeHull* hull =&sc->m_shapehull; - glBegin(GL_QUADS); - for(int i=0;im_edges.size();++i) - { - const btScalar d=btDot(sc->m_edges[i].n[0],extrusion); - if((d*btDot(sc->m_edges[i].n[1],extrusion))<0) - { - const int q= d<0?1:0; - const btVector3& a= hull->getVertexPointer()[sc->m_edges[i].v[q]]; - const btVector3& b= hull->getVertexPointer()[sc->m_edges[i].v[1-q]]; - glVertex3f(a[0],a[1],a[2]); - glVertex3f(b[0],b[1],b[2]); - glVertex3f(b[0]+extrusion[0],b[1]+extrusion[1],b[2]+extrusion[2]); - glVertex3f(a[0]+extrusion[0],a[1]+extrusion[1],a[2]+extrusion[2]); - } - } - glEnd(); - } - - } - - - - - if (shape->isConcave())//>getShapeType() == TRIANGLE_MESH_SHAPE_PROXYTYPE||shape->getShapeType() == GIMPACT_SHAPE_PROXYTYPE) - // if (shape->getShapeType() == TRIANGLE_MESH_SHAPE_PROXYTYPE) - { - btConcaveShape* concaveMesh = (btConcaveShape*) shape; - - GlDrawcallback drawCallback; - drawCallback.m_wireframe = false; - - concaveMesh->processAllTriangles(&drawCallback,worldBoundsMin,worldBoundsMax); - - } - glPopMatrix(); - -} - -// -GL_ShapeDrawer::GL_ShapeDrawer() -{ - m_texturehandle = 0; - m_textureenabled = false; - m_textureinitialized = false; -} - -GL_ShapeDrawer::~GL_ShapeDrawer() -{ - int i; - for (i=0;i~ShapeCache(); - btAlignedFree(m_shapecaches[i]); - } - m_shapecaches.clear(); - if(m_textureinitialized) - { - glDeleteTextures(1,(const GLuint*) &m_texturehandle); - } -} - - diff --git a/Demos/OpenGL/GL_ShapeDrawer.h b/Demos/OpenGL/GL_ShapeDrawer.h deleted file mode 100644 index eeab4d71d..000000000 --- a/Demos/OpenGL/GL_ShapeDrawer.h +++ /dev/null @@ -1,69 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef GL_SHAPE_DRAWER_H -#define GL_SHAPE_DRAWER_H - -class btCollisionShape; -class btShapeHull; -#include "LinearMath/btAlignedObjectArray.h" -#include "LinearMath/btVector3.h" - -#include "BulletCollision/CollisionShapes/btShapeHull.h" - -/// OpenGL shape drawing -class GL_ShapeDrawer -{ -protected: - struct ShapeCache - { - struct Edge { btVector3 n[2];int v[2]; }; - ShapeCache(btConvexShape* s) : m_shapehull(s) {} - btShapeHull m_shapehull; - btAlignedObjectArray m_edges; - }; - //clean-up memory of dynamically created shape hulls - btAlignedObjectArray m_shapecaches; - unsigned int m_texturehandle; - bool m_textureenabled; - bool m_textureinitialized; - - - ShapeCache* cache(btConvexShape*); - -public: - GL_ShapeDrawer(); - - virtual ~GL_ShapeDrawer(); - - ///drawOpenGL might allocate temporary memoty, stores pointer in shape userpointer - virtual void drawOpenGL(btScalar* m, const btCollisionShape* shape, const btVector3& color,int debugMode,const btVector3& worldBoundsMin,const btVector3& worldBoundsMax); - virtual void drawShadow(btScalar* m, const btVector3& extrusion,const btCollisionShape* shape,const btVector3& worldBoundsMin,const btVector3& worldBoundsMax); - - bool enableTexture(bool enable) { bool p=m_textureenabled;m_textureenabled=enable;return(p); } - bool hasTextureEnabled() const - { - return m_textureenabled; - } - - void drawSphere(btScalar r, int lats, int longs); - static void drawCoordSystem(); - -}; - -void OGL_displaylist_register_shape(btCollisionShape * shape); -void OGL_displaylist_clean(); - -#endif //GL_SHAPE_DRAWER_H - diff --git a/Demos/OpenGL/GL_Simplex1to4.cpp b/Demos/OpenGL/GL_Simplex1to4.cpp deleted file mode 100644 index 440f41d01..000000000 --- a/Demos/OpenGL/GL_Simplex1to4.cpp +++ /dev/null @@ -1,80 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#include "GL_Simplex1to4.h" -#include "BulletCollision/NarrowPhaseCollision/btSimplexSolverInterface.h" -#include "GL_ShapeDrawer.h" -#ifdef _WIN32 -#include -#endif - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#else -#include -#endif -#include "GlutStuff.h" -#include "LinearMath/btTransform.h" - -GL_Simplex1to4::GL_Simplex1to4() -:m_simplexSolver(0) -{ -} - -GL_Simplex1to4::~GL_Simplex1to4() -{ -} - -/// -/// Debugging method calcClosest calculates the closest point to the origin, using m_simplexSolver -/// -void GL_Simplex1to4::calcClosest(btScalar* m) -{ - btTransform tr; - tr.setFromOpenGLMatrix(m); - - - - GL_ShapeDrawer::drawCoordSystem(); - - if (m_simplexSolver) - { - m_simplexSolver->reset(); - bool res; - - btVector3 v; - - for (int i=0;iaddVertex(v,v,btVector3(0.f,0.f,0.f)); - res = m_simplexSolver->closest(v); - } - - //draw v? - glDisable(GL_LIGHTING); - glBegin(GL_LINES); - btglColor3(1.f, 0.f, 0.f); - btglVertex3(0.f, 0.f, 0.f); - btglVertex3(v.x(),v.y(),v.z()); - glEnd(); - - glEnable(GL_LIGHTING); - - - } - -} diff --git a/Demos/OpenGL/GL_Simplex1to4.h b/Demos/OpenGL/GL_Simplex1to4.h deleted file mode 100644 index e256aab82..000000000 --- a/Demos/OpenGL/GL_Simplex1to4.h +++ /dev/null @@ -1,41 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef GL_SIMPLEX_1TO4_H -#define GL_SIMPLEX_1TO4_H - -#include "BulletCollision/CollisionShapes/btTetrahedronShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btSimplexSolverInterface.h" - -///GL_Simplex1to4 is a class to debug a Simplex Solver with 1 to 4 points. -///Can be used by GJK. -class GL_Simplex1to4 : public btBU_Simplex1to4 -{ - btSimplexSolverInterface* m_simplexSolver; - - public: - - GL_Simplex1to4(); - virtual ~GL_Simplex1to4(); - - void calcClosest(btScalar* m); - - void setSimplexSolver(btSimplexSolverInterface* simplexSolver) { - m_simplexSolver = simplexSolver; - } - -}; - -#endif //GL_SIMPLEX_1TO4_H diff --git a/Demos/OpenGL/GlutDemoApplication.cpp b/Demos/OpenGL/GlutDemoApplication.cpp deleted file mode 100644 index 0ceaede76..000000000 --- a/Demos/OpenGL/GlutDemoApplication.cpp +++ /dev/null @@ -1,87 +0,0 @@ - -#ifndef _WINDOWS - -#include "GlutDemoApplication.h" - -#include "GlutStuff.h" - -#include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h" -#include "BulletDynamics/Dynamics/btRigidBody.h" - -void GlutDemoApplication::updateModifierKeys() -{ - m_modifierKeys = 0; - if (glutGetModifiers() & GLUT_ACTIVE_ALT) - m_modifierKeys |= BT_ACTIVE_ALT; - - if (glutGetModifiers() & GLUT_ACTIVE_CTRL) - m_modifierKeys |= BT_ACTIVE_CTRL; - - if (glutGetModifiers() & GLUT_ACTIVE_SHIFT) - m_modifierKeys |= BT_ACTIVE_SHIFT; -} - -void GlutDemoApplication::specialKeyboard(int key, int x, int y) -{ - (void)x; - (void)y; - - switch (key) - { - case GLUT_KEY_F1: - { - - break; - } - - case GLUT_KEY_F2: - { - - break; - } - - - case GLUT_KEY_END: - { - int numObj = getDynamicsWorld()->getNumCollisionObjects(); - if (numObj) - { - btCollisionObject* obj = getDynamicsWorld()->getCollisionObjectArray()[numObj-1]; - - getDynamicsWorld()->removeCollisionObject(obj); - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - delete obj; - - - } - break; - } - case GLUT_KEY_LEFT : stepLeft(); break; - case GLUT_KEY_RIGHT : stepRight(); break; - case GLUT_KEY_UP : stepFront(); break; - case GLUT_KEY_DOWN : stepBack(); break; - case GLUT_KEY_PAGE_UP : zoomIn(); break; - case GLUT_KEY_PAGE_DOWN : zoomOut(); break; - case GLUT_KEY_HOME : toggleIdle(); break; - default: - // std::cout << "unused (special) key : " << key << std::endl; - break; - } - - glutPostRedisplay(); - -} - -void GlutDemoApplication::swapBuffers() -{ - glutSwapBuffers(); - -} - -#endif //_WINDOWS - - diff --git a/Demos/OpenGL/GlutDemoApplication.h b/Demos/OpenGL/GlutDemoApplication.h deleted file mode 100644 index 9d3a72178..000000000 --- a/Demos/OpenGL/GlutDemoApplication.h +++ /dev/null @@ -1,36 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#ifndef GLUT_DEMO_APPLICATION_H -#define GLUT_DEMO_APPLICATION_H - -#include "DemoApplication.h" - -ATTRIBUTE_ALIGNED16(class) GlutDemoApplication : public DemoApplication -{ -public: - - BT_DECLARE_ALIGNED_ALLOCATOR(); - - void specialKeyboard(int key, int x, int y); - - virtual void swapBuffers(); - - virtual void updateModifierKeys(); - -}; -#endif //GLUT_DEMO_APPLICATION_H - diff --git a/Demos/OpenGL/GlutStuff.cpp b/Demos/OpenGL/GlutStuff.cpp deleted file mode 100644 index 397303b16..000000000 --- a/Demos/OpenGL/GlutStuff.cpp +++ /dev/null @@ -1,134 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef DONT_USE_GLUT - -#include "DemoApplication.h" - -#if !defined(_WIN32) && !defined(__APPLE__) -//assume linux workaround -//#include -#endif - -//glut is C code, this global gDemoApplication links glut to the C++ demo -static DemoApplication* gDemoApplication = 0; - - -#include "GlutStuff.h" - -static void glutKeyboardCallback(unsigned char key, int x, int y) -{ - gDemoApplication->keyboardCallback(key,x,y); -} - -static void glutKeyboardUpCallback(unsigned char key, int x, int y) -{ - gDemoApplication->keyboardUpCallback(key,x,y); -} - -static void glutSpecialKeyboardCallback(int key, int x, int y) -{ - gDemoApplication->specialKeyboard(key,x,y); -} - -static void glutSpecialKeyboardUpCallback(int key, int x, int y) -{ - gDemoApplication->specialKeyboardUp(key,x,y); -} - - -static void glutReshapeCallback(int w, int h) -{ - gDemoApplication->reshape(w,h); -} - -static void glutMoveAndDisplayCallback() -{ - gDemoApplication->moveAndDisplay(); -} - -static void glutMouseFuncCallback(int button, int state, int x, int y) -{ - gDemoApplication->mouseFunc(button,state,x,y); -} - - -static void glutMotionFuncCallback(int x,int y) -{ - gDemoApplication->mouseMotionFunc(x,y); -} - - -static void glutDisplayCallback(void) -{ - gDemoApplication->displayCallback(); -} - -//#include - -int glutmain(int argc, char **argv,int width,int height,const char* title,DemoApplication* demoApp) { - - gDemoApplication = demoApp; - -#if !defined(_WIN32) && !defined(__APPLE__) -//Access pthreads as a workaround for a bug in Linux/Ubuntu -//See https://bugs.launchpad.net/ubuntu/+source/nvidia-graphics-drivers-319/+bug/1248642 - -// int i=pthread_getconcurrency(); - // printf("pthread_getconcurrency()=%d\n",i); -#endif - - glutInit(&argc, argv); - glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA | GLUT_DEPTH | GLUT_STENCIL); - glutInitWindowPosition(width/2, height/2); - glutInitWindowSize(width, height); - glutCreateWindow(title); -#ifdef BT_USE_FREEGLUT - glutSetOption (GLUT_ACTION_ON_WINDOW_CLOSE, GLUT_ACTION_GLUTMAINLOOP_RETURNS); -#endif - - gDemoApplication->myinit(); - - glutKeyboardFunc(glutKeyboardCallback); - glutKeyboardUpFunc(glutKeyboardUpCallback); - glutSpecialFunc(glutSpecialKeyboardCallback); - glutSpecialUpFunc(glutSpecialKeyboardUpCallback); - - glutReshapeFunc(glutReshapeCallback); - //createMenu(); - glutIdleFunc(glutMoveAndDisplayCallback); - glutMouseFunc(glutMouseFuncCallback); - glutPassiveMotionFunc(glutMotionFuncCallback); - glutMotionFunc(glutMotionFuncCallback); - glutDisplayFunc( glutDisplayCallback ); - - glutMoveAndDisplayCallback(); - -//enable vsync to avoid tearing on Apple (todo: for Windows) - -#if defined(__APPLE__) && !defined (VMDMESA) -int swap_interval = 1; -CGLContextObj cgl_context = CGLGetCurrentContext(); -CGLSetParameter(cgl_context, kCGLCPSwapInterval, &swap_interval); -#endif - - - - glutMainLoop(); - return 0; -} - - -#endif //DONT_USE_GLUT diff --git a/Demos/OpenGL/GlutStuff.h b/Demos/OpenGL/GlutStuff.h deleted file mode 100644 index 68b840c06..000000000 --- a/Demos/OpenGL/GlutStuff.h +++ /dev/null @@ -1,94 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef GLUT_STUFF_H -#define GLUT_STUFF_H - -#ifdef DONT_USE_GLUT -#include "OpenGLWindow/OpenGLInclude.h" -#define BT_ACTIVE_ALT 8192 -#define BT_ACTIVE_SHIFT 8193 -#define BT_ACTIVE_CTRL 8194 -#else //DONT_USE_GLUT - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#include -#include -#else//(__APPLE__) && !defined (VMDMESA) - - -#ifdef _WINDOWS - #include - #include - #include -#else //_WINDOWS - -#ifdef _WIN32 - #include -#endif//_WIN32 -#include -#include - -#endif//_WINDOWS -#endif //(__APPLE__) && !defined (VMDMESA) - -#ifdef _WINDOWS - #define BT_ACTIVE_ALT VK_LMENU - #define BT_ACTIVE_SHIFT VK_LSHIFT - #define BT_ACTIVE_CTRL VK_LCONTROL -#else //_WINDOWS - #define BT_KEY_K 'k' - #define BT_KEY_LEFT GLUT_KEY_LEFT - #define BT_KEY_RIGHT GLUT_KEY_RIGHT - #define BT_KEY_UP GLUT_KEY_UP - #define BT_KEY_DOWN GLUT_KEY_DOWN - #define BT_KEY_F1 GLUT_KEY_F1 - #define BT_KEY_F2 GLUT_KEY_F2 - #define BT_KEY_F3 GLUT_KEY_F3 - #define BT_KEY_F4 GLUT_KEY_F4 - #define BT_KEY_F5 GLUT_KEY_F5 - #define BT_KEY_PAGEUP GLUT_KEY_PAGE_UP - #define BT_KEY_PAGEDOWN GLUT_KEY_PAGE_DOWN - #define BT_KEY_END GLUT_KEY_END - #define BT_KEY_HOME GLUT_KEY_HOME - #define BT_ACTIVE_ALT GLUT_ACTIVE_ALT - #define BT_ACTIVE_CTRL GLUT_ACTIVE_ALT - #define BT_ACTIVE_SHIFT GLUT_ACTIVE_SHIFT -#endif -#if BT_USE_FREEGLUT -#include "GL/freeglut_ext.h" //to be able to return from glutMainLoop() -#endif -#endif // DONT_USE_GLUT - - -class DemoApplication; - -int glutmain(int argc, char **argv,int width,int height,const char* title,DemoApplication* demoApp); - -#if defined(BT_USE_DOUBLE_PRECISION) -#define btglLoadMatrix glLoadMatrixd -#define btglMultMatrix glMultMatrixd -#define btglColor3 glColor3d -#define btglVertex3 glVertex3d -#else -#define btglLoadMatrix glLoadMatrixf -#define btglMultMatrix glMultMatrixf -#define btglColor3 glColor3f -#define btglVertex3 glVertex3d -#endif - -#endif //GLUT_STUFF_H diff --git a/Demos/OpenGL/Makefile.am b/Demos/OpenGL/Makefile.am deleted file mode 100644 index 11eeed4d5..000000000 --- a/Demos/OpenGL/Makefile.am +++ /dev/null @@ -1,12 +0,0 @@ -noinst_LIBRARIES = libbulletopenglsupport.a - -libbulletopenglsupport_a_SOURCES = \ - DemoApplication.cpp GLDebugDrawer.h GL_Simplex1to4.cpp \ - GLDebugFont.cpp GLDebugFont.h GlutDemoApplication.cpp GlutDemoApplication.h \ - GlutStuff.h \ - DemoApplication.h GL_ShapeDrawer.cpp \ - GL_Simplex1to4.h RenderTexture.cpp \ - DebugCastResult.h GLDebugDrawer.cpp \ - GL_ShapeDrawer.h GlutStuff.cpp RenderTexture.h - -INCLUDES=-I../../src diff --git a/Demos/OpenGL/RenderTexture.cpp b/Demos/OpenGL/RenderTexture.cpp deleted file mode 100644 index 2c8b88b82..000000000 --- a/Demos/OpenGL/RenderTexture.cpp +++ /dev/null @@ -1,86 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "RenderTexture.h" -#include - - -renderTexture::renderTexture(int width,int height) -:m_height(height),m_width(width) -{ - m_buffer = new unsigned char[m_width*m_height*4]; - - //clear screen - memset(m_buffer,0,m_width*m_height*4); - - //clear screen version 2 - for (int x=0;x>=1; - y++; - } - x++; - } - //xx+=16; - xx+=10; - } -} - -renderTexture::~renderTexture() -{ - delete [] m_buffer; -} - - - diff --git a/Demos/OpenGL/RenderTexture.h b/Demos/OpenGL/RenderTexture.h deleted file mode 100644 index 1153018a1..000000000 --- a/Demos/OpenGL/RenderTexture.h +++ /dev/null @@ -1,78 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef RENDER_TEXTURE_H -#define RENDER_TEXTURE_H - -#include "LinearMath/btVector3.h" -#include "GLDebugFont.h" - -/// -///renderTexture provides a software-render context (setpixel/printf) -/// -class renderTexture -{ - int m_height; - int m_width; - unsigned char* m_buffer; - -public: - - renderTexture(int width,int height); - ~renderTexture(); - - ///rgba input is in range [0..1] for each component - inline void setPixel(int x,int y,const btVector4& rgba) - { - btAssert(x>=0); - btAssert(y>=0); - btAssert(x -#include - - -#include "DemoApplication.h" - -#include "GLDebugDrawer.h" -#include "GLDebugFont.h" - -#include "BulletDynamics/Dynamics/btDynamicsWorld.h" - -/// This Win32AppMain is shared code between all demos. -/// The actual demo, derived from DemoApplication is created using 'createDemo', in a separate .cpp file -DemoApplication* gDemoApplication = 0; -DemoApplication* createDemo(); - - -// Function Declarations - -LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam); -void EnableOpenGL(HWND hWnd, HDC * hDC, HGLRC * hRC); -void DisableOpenGL(HWND hWnd, HDC hDC, HGLRC hRC); -static bool sOpenGLInitialized = false; -static int sWidth = 0; -static int sHeight =0; -static int quitRequest = 0; - -// WinMain - - -#ifdef USE_AMD_OPENCL - - - -#include "btOpenCLUtils.h" - -#include - -cl_context g_cxMainContext; -cl_device_id g_cdDevice; -cl_command_queue g_cqCommandQue; - - -// Returns true if OpenCL is initialized properly, false otherwise. -bool initCL( void* glCtx, void* glDC ) -{ - const char* vendorSDK = btOpenCLUtils::getSdkVendorName(); - printf("This program was compiled using the %s OpenCL SDK\n",vendorSDK); - - int ciErrNum = 0; - -#ifdef BT_USE_CLEW - ciErrNum = clewInit( "OpenCL.dll" ); - if ( ciErrNum != CLEW_SUCCESS ) { - return false; - } -#endif - -#if defined(CL_PLATFORM_MINI_CL) - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#elif defined(CL_PLATFORM_AMD) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#elif defined(CL_PLATFORM_NVIDIA) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#else - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#endif - - g_cxMainContext = btOpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - int numDev = btOpenCLUtils::getNumDevices(g_cxMainContext); - if (!numDev) - return false; - - g_cdDevice = btOpenCLUtils::getDevice(g_cxMainContext,0); - - btOpenCLDeviceInfo clInfo; - btOpenCLUtils::getDeviceInfo(g_cdDevice,clInfo); - btOpenCLUtils::printDeviceInfo(g_cdDevice); - - // create a command-queue - g_cqCommandQue = clCreateCommandQueue(g_cxMainContext, g_cdDevice, 0, &ciErrNum); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - return true; -} - -#endif //#ifdef USE_AMD_OPENCL - - - -int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, - LPSTR lpCmdLine, int iCmdShow) -{ - WNDCLASS wc; - HWND hWnd; - HDC hDC; - HGLRC hRC; - MSG msg; - BOOL quit = FALSE; - float theta = 0.0f; - - gDemoApplication = createDemo(); - -#ifdef USE_AMD_OPENCL - - bool initialized = initCL(0,0); - btAssert(initialized); -#endif //USE_AMD_OPENCL - - // register window class - wc.style = CS_OWNDC; - wc.lpfnWndProc = WndProc; - wc.cbClsExtra = 0; - wc.cbWndExtra = 0; - wc.hInstance = hInstance; - wc.hIcon = LoadIcon( NULL, IDI_APPLICATION ); - wc.hCursor = LoadCursor( NULL, IDC_ARROW ); - wc.hbrBackground = (HBRUSH)GetStockObject( BLACK_BRUSH ); - wc.lpszMenuName = NULL; - wc.lpszClassName = "BulletPhysics"; - RegisterClass( &wc ); - - // create main window - hWnd = CreateWindow( - "BulletPhysics", "Bullet Physics Sample. http://bulletphysics.org", - WS_CAPTION | WS_VISIBLE | WS_OVERLAPPEDWINDOW, -// 0, 0, 640, 480, - 0, 0, 1024, 768, - NULL, NULL, hInstance, NULL ); - - // enable OpenGL for the window - EnableOpenGL( hWnd, &hDC, &hRC ); - - - GLDebugDrawer debugDraw; - gDemoApplication->myinit(); - //gDemoApplication->reshape(1024, 768); - gDemoApplication->initPhysics(); - if (gDemoApplication->getDynamicsWorld()) - gDemoApplication->getDynamicsWorld()->setDebugDrawer(&debugDraw); - - gDemoApplication->reshape(sWidth,sHeight); - - // program main loop - while ( !quit ) - { - - // check for messages - if ( PeekMessage( &msg, NULL, 0, 0, PM_REMOVE ) ) - { - - // handle or dispatch messages - if ( msg.message == WM_QUIT ) - { - quit = TRUE; - } - else - { - TranslateMessage( &msg ); - DispatchMessage( &msg ); - } - -// gDemoApplication->displayCallback(); - - - }; - - // OpenGL animation code goes here - - glClearColor( .7f, 0.7f, 0.7f, 1.f ); - - gDemoApplication->moveAndDisplay(); - - - SwapBuffers( hDC ); - - theta += 1.0f; - - - } - - - - // shutdown OpenGL - DisableOpenGL( hWnd, hDC, hRC ); - - // destroy the window explicitly - DestroyWindow( hWnd ); - - delete gDemoApplication; - - return msg.wParam; - -} - -// Window Procedure - -LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) -{ - - - - switch (message) - { - - case WM_SYSKEYDOWN: - { - if (lParam & 1<<29) - { - gDemoApplication->m_modifierKeys = VK_LMENU; - } - break; - } - case WM_SYSKEYUP: - { - if (lParam & 1<<29) - { - gDemoApplication->m_modifierKeys = VK_LMENU; - } else - { - gDemoApplication->m_modifierKeys = 0; - } - - break; - } - - - case WM_SIZE: // Size Action Has Taken Place - - switch (wParam) // Evaluate Size Action - { - case SIZE_MINIMIZED: // Was Window Minimized? - return 0; // Return - - case SIZE_MAXIMIZED: // Was Window Maximized? - sWidth = LOWORD (lParam); - sHeight = HIWORD (lParam); - if (sOpenGLInitialized) - { - gDemoApplication->reshape(sWidth,sHeight); - } - return 0; // Return - - case SIZE_RESTORED: // Was Window Restored? - sWidth = LOWORD (lParam); - sHeight = HIWORD (lParam); - if (sOpenGLInitialized) - { - gDemoApplication->reshape(sWidth,sHeight); - } - return 0; // Return - } - break; - - case WM_CREATE: - return 0; - - case WM_MBUTTONUP: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseFunc(1,1,xPos,yPos); - break; - } - case WM_MBUTTONDOWN: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseFunc(1,0,xPos,yPos); - break; - } - - case WM_LBUTTONUP: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseFunc(0,1,xPos,yPos); - break; - } - case 0x020A://WM_MOUSEWHEEL: - { - - int zDelta = (short)HIWORD(wParam); - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - if (zDelta>0) - gDemoApplication->zoomIn(); - else - gDemoApplication->zoomOut(); - break; - } - - case WM_MOUSEMOVE: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseMotionFunc(xPos,yPos); - break; - } - case WM_RBUTTONUP: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseFunc(2,1,xPos,yPos); - break; - } - case WM_RBUTTONDOWN: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseFunc(2,0,xPos,yPos); - break; - } - case WM_LBUTTONDOWN: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - gDemoApplication->mouseFunc(0,0,xPos,yPos); - break; - } -/*#define WM_LBUTTONUP 0x0202 -#define WM_LBUTTONDBLCLK 0x0203 -#define WM_RBUTTONDOWN 0x0204 -#define WM_RBUTTONUP 0x0205 -#define WM_RBUTTONDBLCLK 0x0206 -#define WM_MBUTTONDOWN 0x0207 -#define WM_MBUTTONUP 0x0208 -#define WM_MBUTTONDBLCLK 0x0209 -*/ - - - - case WM_CLOSE: - PostQuitMessage( 0 ); - return 0; - - case WM_DESTROY: - return 0; - - case WM_KEYUP: - switch ( wParam ) - { - - case VK_PRIOR: - case VK_NEXT: - case VK_END: - case VK_HOME: - case VK_LEFT: - case VK_UP: - case VK_RIGHT: - case VK_DOWN: - { - if (gDemoApplication) - gDemoApplication->specialKeyboardUp(wParam,0,0); - return 0; - } - default: - { - gDemoApplication->keyboardUpCallback(tolower(wParam),0,0); - } - return DefWindowProc( hWnd, message, wParam, lParam ); - } - - case WM_KEYDOWN: - printf("bla\n"); - switch ( wParam ) - { - case VK_CONTROL: - case VK_PRIOR: - case VK_NEXT: - case VK_END: - case VK_HOME: - case VK_LEFT: - case VK_UP: - case VK_RIGHT: - case VK_DOWN: - { - if (gDemoApplication) - gDemoApplication->specialKeyboard(wParam,0,0); - break; - } - - case ' ': - { - if (gDemoApplication) - gDemoApplication->clientResetScene(); - break; - } - case 'Q': - case VK_ESCAPE: - { - quitRequest = 1; - PostQuitMessage(0); - } - return 0; - - } - return 0; - - case WM_CHAR: - if (!quitRequest) - gDemoApplication->keyboardCallback(wParam,0,0); - break; - - default: - return DefWindowProc( hWnd, message, wParam, lParam ); - - } - return 0; -} - -// Enable OpenGL - -void EnableOpenGL(HWND hWnd, HDC * hDC, HGLRC * hRC) -{ - PIXELFORMATDESCRIPTOR pfd; - int format; - - // get the device context (DC) - *hDC = GetDC( hWnd ); - - // set the pixel format for the DC - ZeroMemory( &pfd, sizeof( pfd ) ); - pfd.nSize = sizeof( pfd ); - pfd.nVersion = 1; - pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL | PFD_DOUBLEBUFFER; - pfd.iPixelType = PFD_TYPE_RGBA; - pfd.cColorBits = 24; - pfd.cDepthBits = 16; - pfd.cStencilBits = 1; - pfd.iLayerType = PFD_MAIN_PLANE; - format = ChoosePixelFormat( *hDC, &pfd ); - SetPixelFormat( *hDC, format, &pfd ); - - // create and enable the render context (RC) - *hRC = wglCreateContext( *hDC ); - wglMakeCurrent( *hDC, *hRC ); - sOpenGLInitialized = true; - - -} - -// Disable OpenGL - -void DisableOpenGL(HWND hWnd, HDC hDC, HGLRC hRC) -{ - sOpenGLInitialized = false; - - wglMakeCurrent( NULL, NULL ); - wglDeleteContext( hRC ); - ReleaseDC( hWnd, hDC ); -} - -#endif //_WINDOWS diff --git a/Demos/OpenGL/Win32DemoApplication.cpp b/Demos/OpenGL/Win32DemoApplication.cpp deleted file mode 100644 index f959cbf4f..000000000 --- a/Demos/OpenGL/Win32DemoApplication.cpp +++ /dev/null @@ -1,79 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifdef _WINDOWS - -#include "Win32DemoApplication.h" - - - - -#if 0 -void Win32DemoApplication::renderme() -{ -} -void Win32DemoApplication::setTexturing(bool useTexture) -{ -} - -void Win32DemoApplication::setShadows(bool useShadows) -{ -} - -void Win32DemoApplication::setCameraDistance(float camDist) -{ -} -void Win32DemoApplication::clientResetScene() -{ - -} -#endif - -void Win32DemoApplication::updateModifierKeys() -{ - //not yet -} - - - -void Win32DemoApplication::specialKeyboard(int key, int x, int y) -{ - (void)x; - (void)y; - - switch (key) - { - case VK_LEFT : stepLeft(); break; - case VK_RIGHT : stepRight(); break; - case VK_UP : stepFront(); break; - case VK_DOWN : stepBack(); break; - -// case GLUT_KEY_PAGE_UP : zoomIn(); break; -// case GLUT_KEY_PAGE_DOWN : zoomOut(); break; -// case GLUT_KEY_HOME : toggleIdle(); break; - - default: - // std::cout << "unused (special) key : " << key << std::endl; - break; - } - -} - -void Win32DemoApplication::swapBuffers() -{ -} - -#endif - diff --git a/Demos/OpenGL/Win32DemoApplication.h b/Demos/OpenGL/Win32DemoApplication.h deleted file mode 100644 index af3eec90e..000000000 --- a/Demos/OpenGL/Win32DemoApplication.h +++ /dev/null @@ -1,41 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#ifndef WIN32_DEMO_APPLICATION_H -#define WIN32_DEMO_APPLICATION_H - - -#include "DemoApplication.h" - -ATTRIBUTE_ALIGNED16(class) Win32DemoApplication : public DemoApplication -{ -protected: - - -public: - - BT_DECLARE_ALIGNED_ALLOCATOR(); - - virtual void swapBuffers(); - - void specialKeyboard(int key, int x, int y); - - virtual void updateModifierKeys(); - - -}; - -#endif //WIN32_DEMO_APPLICATION_H \ No newline at end of file diff --git a/Demos/OpenGL/premake4.lua b/Demos/OpenGL/premake4.lua deleted file mode 100644 index a1c15e70e..000000000 --- a/Demos/OpenGL/premake4.lua +++ /dev/null @@ -1,18 +0,0 @@ - project "OpenGLSupport" - - kind "StaticLib" - targetdir "../../lib" - includedirs { - ".", - "../../src" - } - configuration {"Windows"} - includedirs { - "../Glut" - } - configuration{} - - files { - "**.cpp", - "**.h" - } diff --git a/Demos/OpenGL/stb_image.cpp b/Demos/OpenGL/stb_image.cpp deleted file mode 100644 index 226d7a8c8..000000000 --- a/Demos/OpenGL/stb_image.cpp +++ /dev/null @@ -1,4341 +0,0 @@ -#include "stb_image.h" - -#ifndef STBI_HEADER_FILE_ONLY - -#ifndef STBI_NO_HDR -#include // ldexp -#include // strcmp, strtok -#endif - -#ifndef STBI_NO_STDIO -#include -#endif -#include -#include -#include -#include - -#ifndef _MSC_VER - #ifdef __cplusplus - #define stbi_inline inline - #else - #define stbi_inline - #endif -#else - #define stbi_inline __forceinline -#endif - - -// implementation: -typedef unsigned char uint8; -typedef unsigned short uint16; -typedef signed short int16; -typedef unsigned int uint32; -typedef signed int int32; -typedef unsigned int uint; - -// should produce compiler error if size is wrong -typedef unsigned char validate_uint32[sizeof(uint32)==4 ? 1 : -1]; - -#if defined(STBI_NO_STDIO) && !defined(STBI_NO_WRITE) -#define STBI_NO_WRITE -#endif - -#define STBI_NOTUSED(v) (void)sizeof(v) - -#ifdef _MSC_VER -#define STBI_HAS_LROTL -#endif - -#ifdef STBI_HAS_LROTL - #define stbi_lrot(x,y) _lrotl(x,y) -#else - #define stbi_lrot(x,y) (((x) << (y)) | ((x) >> (32 - (y)))) -#endif - -/////////////////////////////////////////////// -// -// stbi struct and start_xxx functions - -// stbi structure is our basic context used by all images, so it -// contains all the IO context, plus some basic image information -typedef struct -{ - uint32 img_x, img_y; - int img_n, img_out_n; - - stbi_io_callbacks io; - void *io_user_data; - - int read_from_callbacks; - int buflen; - uint8 buffer_start[128]; - - uint8 *img_buffer, *img_buffer_end; - uint8 *img_buffer_original; -} stbi; - - -static void refill_buffer(stbi *s); - -// initialize a memory-decode context -static void start_mem(stbi *s, uint8 const *buffer, int len) -{ - s->io.read = NULL; - s->read_from_callbacks = 0; - s->img_buffer = s->img_buffer_original = (uint8 *) buffer; - s->img_buffer_end = (uint8 *) buffer+len; -} - -// initialize a callback-based context -static void start_callbacks(stbi *s, stbi_io_callbacks *c, void *user) -{ - s->io = *c; - s->io_user_data = user; - s->buflen = sizeof(s->buffer_start); - s->read_from_callbacks = 1; - s->img_buffer_original = s->buffer_start; - refill_buffer(s); -} - -#ifndef STBI_NO_STDIO - -static int stdio_read(void *user, char *data, int size) -{ - return (int) fread(data,1,size,(FILE*) user); -} - -static void stdio_skip(void *user, unsigned n) -{ - fseek((FILE*) user, n, SEEK_CUR); -} - -static int stdio_eof(void *user) -{ - return feof((FILE*) user); -} - -static stbi_io_callbacks stbi_stdio_callbacks = -{ - stdio_read, - stdio_skip, - stdio_eof, -}; - -static void start_file(stbi *s, FILE *f) -{ - start_callbacks(s, &stbi_stdio_callbacks, (void *) f); -} - -//static void stop_file(stbi *s) { } - -#endif // !STBI_NO_STDIO - -static void stbi_rewind(stbi *s) -{ - // conceptually rewind SHOULD rewind to the beginning of the stream, - // but we just rewind to the beginning of the initial buffer, because - // we only use it after doing 'test', which only ever looks at at most 92 bytes - s->img_buffer = s->img_buffer_original; -} - -static int stbi_jpeg_test(stbi *s); -static stbi_uc *stbi_jpeg_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_jpeg_info(stbi *s, int *x, int *y, int *comp); -static int stbi_png_test(stbi *s); -static stbi_uc *stbi_png_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_png_info(stbi *s, int *x, int *y, int *comp); -static int stbi_bmp_test(stbi *s); -static stbi_uc *stbi_bmp_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_tga_test(stbi *s); -static stbi_uc *stbi_tga_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_tga_info(stbi *s, int *x, int *y, int *comp); -static int stbi_psd_test(stbi *s); -static stbi_uc *stbi_psd_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_hdr_test(stbi *s); -static float *stbi_hdr_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_pic_test(stbi *s); -static stbi_uc *stbi_pic_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_gif_test(stbi *s); -static stbi_uc *stbi_gif_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_gif_info(stbi *s, int *x, int *y, int *comp); - - -// this is not threadsafe -static const char *failure_reason; - -const char *stbi_failure_reason(void) -{ - return failure_reason; -} - -static int e(const char *str) -{ - failure_reason = str; - return 0; -} - -// e - error -// epf - error returning pointer to float -// epuc - error returning pointer to unsigned char - -#ifdef STBI_NO_FAILURE_STRINGS - #define e(x,y) 0 -#elif defined(STBI_FAILURE_USERMSG) - #define e(x,y) e(y) -#else - #define e(x,y) e(x) -#endif - -#define epf(x,y) ((float *) (e(x,y)?NULL:NULL)) -#define epuc(x,y) ((unsigned char *) (e(x,y)?NULL:NULL)) - -void stbi_image_free(void *retval_from_stbi_load) -{ - free(retval_from_stbi_load); -} - -#ifndef STBI_NO_HDR -static float *ldr_to_hdr(stbi_uc *data, int x, int y, int comp); -static stbi_uc *hdr_to_ldr(float *data, int x, int y, int comp); -#endif - -static unsigned char *stbi_load_main(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - if (stbi_jpeg_test(s)) return stbi_jpeg_load(s,x,y,comp,req_comp); - if (stbi_png_test(s)) return stbi_png_load(s,x,y,comp,req_comp); - if (stbi_bmp_test(s)) return stbi_bmp_load(s,x,y,comp,req_comp); - if (stbi_gif_test(s)) return stbi_gif_load(s,x,y,comp,req_comp); - if (stbi_psd_test(s)) return stbi_psd_load(s,x,y,comp,req_comp); - if (stbi_pic_test(s)) return stbi_pic_load(s,x,y,comp,req_comp); - - #ifndef STBI_NO_HDR - if (stbi_hdr_test(s)) { - float *hdr = stbi_hdr_load(s, x,y,comp,req_comp); - return hdr_to_ldr(hdr, *x, *y, req_comp ? req_comp : *comp); - } - #endif - - // test tga last because it's a crappy test! - if (stbi_tga_test(s)) - return stbi_tga_load(s,x,y,comp,req_comp); - return epuc("unknown image type", "Image not of any known type, or corrupt"); -} - -#ifndef STBI_NO_STDIO -unsigned char *stbi_load(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - FILE *f = fopen(filename, "rb"); - unsigned char *result; - if (!f) return epuc("can't fopen", "Unable to open file"); - result = stbi_load_from_file(f,x,y,comp,req_comp); - fclose(f); - return result; -} - -unsigned char *stbi_load_from_file(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_file(&s,f); - return stbi_load_main(&s,x,y,comp,req_comp); -} -#endif //!STBI_NO_STDIO - -unsigned char *stbi_load_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_mem(&s,buffer,len); - return stbi_load_main(&s,x,y,comp,req_comp); -} - -unsigned char *stbi_load_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi_load_main(&s,x,y,comp,req_comp); -} - -#ifndef STBI_NO_HDR - -float *stbi_loadf_main(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - unsigned char *data; - #ifndef STBI_NO_HDR - if (stbi_hdr_test(s)) - return stbi_hdr_load(s,x,y,comp,req_comp); - #endif - data = stbi_load_main(s, x, y, comp, req_comp); - if (data) - return ldr_to_hdr(data, *x, *y, req_comp ? req_comp : *comp); - return epf("unknown image type", "Image not of any known type, or corrupt"); -} - -float *stbi_loadf_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_mem(&s,buffer,len); - return stbi_loadf_main(&s,x,y,comp,req_comp); -} - -float *stbi_loadf_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi_loadf_main(&s,x,y,comp,req_comp); -} - -#ifndef STBI_NO_STDIO -float *stbi_loadf(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - FILE *f = fopen(filename, "rb"); - float *result; - if (!f) return epf("can't fopen", "Unable to open file"); - result = stbi_loadf_from_file(f,x,y,comp,req_comp); - fclose(f); - return result; -} - -float *stbi_loadf_from_file(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_file(&s,f); - return stbi_loadf_main(&s,x,y,comp,req_comp); -} -#endif // !STBI_NO_STDIO - -#endif // !STBI_NO_HDR - -// these is-hdr-or-not is defined independent of whether STBI_NO_HDR is -// defined, for API simplicity; if STBI_NO_HDR is defined, it always -// reports false! - -int stbi_is_hdr_from_memory(stbi_uc const *buffer, int len) -{ - #ifndef STBI_NO_HDR - stbi s; - start_mem(&s,buffer,len); - return stbi_hdr_test(&s); - #else - STBI_NOTUSED(buffer); - STBI_NOTUSED(len); - return 0; - #endif -} - -#ifndef STBI_NO_STDIO -extern int stbi_is_hdr (char const *filename) -{ - FILE *f = fopen(filename, "rb"); - int result=0; - if (f) { - result = stbi_is_hdr_from_file(f); - fclose(f); - } - return result; -} - -extern int stbi_is_hdr_from_file(FILE *f) -{ - #ifndef STBI_NO_HDR - stbi s; - start_file(&s,f); - return stbi_hdr_test(&s); - #else - return 0; - #endif -} -#endif // !STBI_NO_STDIO - -extern int stbi_is_hdr_from_callbacks(stbi_io_callbacks const *clbk, void *user) -{ - #ifndef STBI_NO_HDR - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi_hdr_test(&s); - #else - return 0; - #endif -} - -#ifndef STBI_NO_HDR -static float h2l_gamma_i=1.0f/2.2f, h2l_scale_i=1.0f; -static float l2h_gamma=2.2f, l2h_scale=1.0f; - -void stbi_hdr_to_ldr_gamma(float gamma) { h2l_gamma_i = 1/gamma; } -void stbi_hdr_to_ldr_scale(float scale) { h2l_scale_i = 1/scale; } - -void stbi_ldr_to_hdr_gamma(float gamma) { l2h_gamma = gamma; } -void stbi_ldr_to_hdr_scale(float scale) { l2h_scale = scale; } -#endif - - -////////////////////////////////////////////////////////////////////////////// -// -// Common code used by all image loaders -// - -enum -{ - SCAN_load=0, - SCAN_type, - SCAN_header -}; - -static void refill_buffer(stbi *s) -{ - int n = (s->io.read)(s->io_user_data,(char*)s->buffer_start,s->buflen); - if (n == 0) { - // at end of file, treat same as if from memory - s->read_from_callbacks = 0; - s->img_buffer = s->img_buffer_end-1; - *s->img_buffer = 0; - } else { - s->img_buffer = s->buffer_start; - s->img_buffer_end = s->buffer_start + n; - } -} - -stbi_inline static int get8(stbi *s) -{ - if (s->img_buffer < s->img_buffer_end) - return *s->img_buffer++; - if (s->read_from_callbacks) { - refill_buffer(s); - return *s->img_buffer++; - } - return 0; -} - -stbi_inline static int at_eof(stbi *s) -{ - if (s->io.read) { - if (!(s->io.eof)(s->io_user_data)) return 0; - // if feof() is true, check if buffer = end - // special case: we've only got the special 0 character at the end - if (s->read_from_callbacks == 0) return 1; - } - - return s->img_buffer >= s->img_buffer_end; -} - -stbi_inline static uint8 get8u(stbi *s) -{ - return (uint8) get8(s); -} - -static void skip(stbi *s, int n) -{ - if (s->io.read) { - int blen = s->img_buffer_end - s->img_buffer; - if (blen < n) { - s->img_buffer = s->img_buffer_end; - (s->io.skip)(s->io_user_data, n - blen); - return; - } - } - s->img_buffer += n; -} - -static int getn(stbi *s, stbi_uc *buffer, int n) -{ - if (s->io.read) { - int blen = s->img_buffer_end - s->img_buffer; - if (blen < n) { - int res, count; - - memcpy(buffer, s->img_buffer, blen); - - count = (s->io.read)(s->io_user_data, (char*) buffer + blen, n - blen); - res = (count == (n-blen)); - s->img_buffer = s->img_buffer_end; - return res; - } - } - - if (s->img_buffer+n <= s->img_buffer_end) { - memcpy(buffer, s->img_buffer, n); - s->img_buffer += n; - return 1; - } else - return 0; -} - -static int get16(stbi *s) -{ - int z = get8(s); - return (z << 8) + get8(s); -} - -static uint32 get32(stbi *s) -{ - uint32 z = get16(s); - return (z << 16) + get16(s); -} - -static int get16le(stbi *s) -{ - int z = get8(s); - return z + (get8(s) << 8); -} - -static uint32 get32le(stbi *s) -{ - uint32 z = get16le(s); - return z + (get16le(s) << 16); -} - -////////////////////////////////////////////////////////////////////////////// -// -// generic converter from built-in img_n to req_comp -// individual types do this automatically as much as possible (e.g. jpeg -// does all cases internally since it needs to colorspace convert anyway, -// and it never has alpha, so very few cases ). png can automatically -// interleave an alpha=255 channel, but falls back to this for other cases -// -// assume data buffer is malloced, so malloc a new one and free that one -// only failure mode is malloc failing - -static uint8 compute_y(int r, int g, int b) -{ - return (uint8) (((r*77) + (g*150) + (29*b)) >> 8); -} - -static unsigned char *convert_format(unsigned char *data, int img_n, int req_comp, uint x, uint y) -{ - int i,j; - unsigned char *good; - - if (req_comp == img_n) return data; - assert(req_comp >= 1 && req_comp <= 4); - - good = (unsigned char *) malloc(req_comp * x * y); - if (good == NULL) { - free(data); - return epuc("outofmem", "Out of memory"); - } - - for (j=0; j < (int) y; ++j) { - unsigned char *src = data + j * x * img_n ; - unsigned char *dest = good + j * x * req_comp; - - #define COMBO(a,b) ((a)*8+(b)) - #define CASE(a,b) case COMBO(a,b): for(i=x-1; i >= 0; --i, src += a, dest += b) - // convert source image with img_n components to one with req_comp components; - // avoid switch per pixel, so use switch per scanline and massive macros - switch (COMBO(img_n, req_comp)) { - CASE(1,2) dest[0]=src[0], dest[1]=255; break; - CASE(1,3) dest[0]=dest[1]=dest[2]=src[0]; break; - CASE(1,4) dest[0]=dest[1]=dest[2]=src[0], dest[3]=255; break; - CASE(2,1) dest[0]=src[0]; break; - CASE(2,3) dest[0]=dest[1]=dest[2]=src[0]; break; - CASE(2,4) dest[0]=dest[1]=dest[2]=src[0], dest[3]=src[1]; break; - CASE(3,4) dest[0]=src[0],dest[1]=src[1],dest[2]=src[2],dest[3]=255; break; - CASE(3,1) dest[0]=compute_y(src[0],src[1],src[2]); break; - CASE(3,2) dest[0]=compute_y(src[0],src[1],src[2]), dest[1] = 255; break; - CASE(4,1) dest[0]=compute_y(src[0],src[1],src[2]); break; - CASE(4,2) dest[0]=compute_y(src[0],src[1],src[2]), dest[1] = src[3]; break; - CASE(4,3) dest[0]=src[0],dest[1]=src[1],dest[2]=src[2]; break; - default: assert(0); - } - #undef CASE - } - - free(data); - return good; -} - -#ifndef STBI_NO_HDR -static float *ldr_to_hdr(stbi_uc *data, int x, int y, int comp) -{ - int i,k,n; - float *output = (float *) malloc(x * y * comp * sizeof(float)); - if (output == NULL) { free(data); return epf("outofmem", "Out of memory"); } - // compute number of non-alpha components - if (comp & 1) n = comp; else n = comp-1; - for (i=0; i < x*y; ++i) { - for (k=0; k < n; ++k) { - output[i*comp + k] = (float) pow(data[i*comp+k]/255.0f, l2h_gamma) * l2h_scale; - } - if (k < comp) output[i*comp + k] = data[i*comp+k]/255.0f; - } - free(data); - return output; -} - -#define float2int(x) ((int) (x)) -static stbi_uc *hdr_to_ldr(float *data, int x, int y, int comp) -{ - int i,k,n; - stbi_uc *output = (stbi_uc *) malloc(x * y * comp); - if (output == NULL) { free(data); return epuc("outofmem", "Out of memory"); } - // compute number of non-alpha components - if (comp & 1) n = comp; else n = comp-1; - for (i=0; i < x*y; ++i) { - for (k=0; k < n; ++k) { - float z = (float) pow(data[i*comp+k]*h2l_scale_i, h2l_gamma_i) * 255 + 0.5f; - if (z < 0) z = 0; - if (z > 255) z = 255; - output[i*comp + k] = (uint8) float2int(z); - } - if (k < comp) { - float z = data[i*comp+k] * 255 + 0.5f; - if (z < 0) z = 0; - if (z > 255) z = 255; - output[i*comp + k] = (uint8) float2int(z); - } - } - free(data); - return output; -} -#endif - -////////////////////////////////////////////////////////////////////////////// -// -// "baseline" JPEG/JFIF decoder (not actually fully baseline implementation) -// -// simple implementation -// - channel subsampling of at most 2 in each dimension -// - doesn't support delayed output of y-dimension -// - simple interface (only one output format: 8-bit interleaved RGB) -// - doesn't try to recover corrupt jpegs -// - doesn't allow partial loading, loading multiple at once -// - still fast on x86 (copying globals into locals doesn't help x86) -// - allocates lots of intermediate memory (full size of all components) -// - non-interleaved case requires this anyway -// - allows good upsampling (see next) -// high-quality -// - upsampled channels are bilinearly interpolated, even across blocks -// - quality integer IDCT derived from IJG's 'slow' -// performance -// - fast huffman; reasonable integer IDCT -// - uses a lot of intermediate memory, could cache poorly -// - load http://nothings.org/remote/anemones.jpg 3 times on 2.8Ghz P4 -// stb_jpeg: 1.34 seconds (MSVC6, default release build) -// stb_jpeg: 1.06 seconds (MSVC6, processor = Pentium Pro) -// IJL11.dll: 1.08 seconds (compiled by intel) -// IJG 1998: 0.98 seconds (MSVC6, makefile provided by IJG) -// IJG 1998: 0.95 seconds (MSVC6, makefile + proc=PPro) - -// huffman decoding acceleration -#define FAST_BITS 9 // larger handles more cases; smaller stomps less cache - -typedef struct -{ - uint8 fast[1 << FAST_BITS]; - // weirdly, repacking this into AoS is a 10% speed loss, instead of a win - uint16 code[256]; - uint8 values[256]; - uint8 size[257]; - unsigned int maxcode[18]; - int delta[17]; // old 'firstsymbol' - old 'firstcode' -} huffman; - -typedef struct -{ - #ifdef STBI_SIMD - unsigned short dequant2[4][64]; - #endif - stbi *s; - huffman huff_dc[4]; - huffman huff_ac[4]; - uint8 dequant[4][64]; - -// sizes for components, interleaved MCUs - int img_h_max, img_v_max; - int img_mcu_x, img_mcu_y; - int img_mcu_w, img_mcu_h; - -// definition of jpeg image component - struct - { - int id; - int h,v; - int tq; - int hd,ha; - int dc_pred; - - int x,y,w2,h2; - uint8 *data; - void *raw_data; - uint8 *linebuf; - } img_comp[4]; - - uint32 code_buffer; // jpeg entropy-coded buffer - int code_bits; // number of valid bits - unsigned char marker; // marker seen while filling entropy buffer - int nomore; // flag if we saw a marker so must stop - - int scan_n, order[4]; - int restart_interval, todo; -} jpeg; - -static int build_huffman(huffman *h, int *count) -{ - int i,j,k=0,code; - // build size list for each symbol (from JPEG spec) - for (i=0; i < 16; ++i) - for (j=0; j < count[i]; ++j) - h->size[k++] = (uint8) (i+1); - h->size[k] = 0; - - // compute actual symbols (from jpeg spec) - code = 0; - k = 0; - for(j=1; j <= 16; ++j) { - // compute delta to add to code to compute symbol id - h->delta[j] = k - code; - if (h->size[k] == j) { - while (h->size[k] == j) - h->code[k++] = (uint16) (code++); - if (code-1 >= (1 << j)) return e("bad code lengths","Corrupt JPEG"); - } - // compute largest code + 1 for this size, preshifted as needed later - h->maxcode[j] = code << (16-j); - code <<= 1; - } - h->maxcode[j] = 0xffffffff; - - // build non-spec acceleration table; 255 is flag for not-accelerated - memset(h->fast, 255, 1 << FAST_BITS); - for (i=0; i < k; ++i) { - int s = h->size[i]; - if (s <= FAST_BITS) { - int c = h->code[i] << (FAST_BITS-s); - int m = 1 << (FAST_BITS-s); - for (j=0; j < m; ++j) { - h->fast[c+j] = (uint8) i; - } - } - } - return 1; -} - -static void grow_buffer_unsafe(jpeg *j) -{ - do { - int b = j->nomore ? 0 : get8(j->s); - if (b == 0xff) { - int c = get8(j->s); - if (c != 0) { - j->marker = (unsigned char) c; - j->nomore = 1; - return; - } - } - j->code_buffer |= b << (24 - j->code_bits); - j->code_bits += 8; - } while (j->code_bits <= 24); -} - -// (1 << n) - 1 -static uint32 bmask[17]={0,1,3,7,15,31,63,127,255,511,1023,2047,4095,8191,16383,32767,65535}; - -// decode a jpeg huffman value from the bitstream -stbi_inline static int decode(jpeg *j, huffman *h) -{ - unsigned int temp; - int c,k; - - if (j->code_bits < 16) grow_buffer_unsafe(j); - - // look at the top FAST_BITS and determine what symbol ID it is, - // if the code is <= FAST_BITS - c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS)-1); - k = h->fast[c]; - if (k < 255) { - int s = h->size[k]; - if (s > j->code_bits) - return -1; - j->code_buffer <<= s; - j->code_bits -= s; - return h->values[k]; - } - - // naive test is to shift the code_buffer down so k bits are - // valid, then test against maxcode. To speed this up, we've - // preshifted maxcode left so that it has (16-k) 0s at the - // end; in other words, regardless of the number of bits, it - // wants to be compared against something shifted to have 16; - // that way we don't need to shift inside the loop. - temp = j->code_buffer >> 16; - for (k=FAST_BITS+1 ; ; ++k) - if (temp < h->maxcode[k]) - break; - if (k == 17) { - // error! code not found - j->code_bits -= 16; - return -1; - } - - if (k > j->code_bits) - return -1; - - // convert the huffman code to the symbol id - c = ((j->code_buffer >> (32 - k)) & bmask[k]) + h->delta[k]; - assert((((j->code_buffer) >> (32 - h->size[c])) & bmask[h->size[c]]) == h->code[c]); - - // convert the id to a symbol - j->code_bits -= k; - j->code_buffer <<= k; - return h->values[c]; -} - -// combined JPEG 'receive' and JPEG 'extend', since baseline -// always extends everything it receives. -stbi_inline static int extend_receive(jpeg *j, int n) -{ - unsigned int m = 1 << (n-1); - unsigned int k; - if (j->code_bits < n) grow_buffer_unsafe(j); - - #if 1 - k = stbi_lrot(j->code_buffer, n); - j->code_buffer = k & ~bmask[n]; - k &= bmask[n]; - j->code_bits -= n; - #else - k = (j->code_buffer >> (32 - n)) & bmask[n]; - j->code_bits -= n; - j->code_buffer <<= n; - #endif - // the following test is probably a random branch that won't - // predict well. I tried to table accelerate it but failed. - // maybe it's compiling as a conditional move? - if (k < m) - return (-1 << n) + k + 1; - else - return k; -} - -// given a value that's at position X in the zigzag stream, -// where does it appear in the 8x8 matrix coded as row-major? -static uint8 dezigzag[64+15] = -{ - 0, 1, 8, 16, 9, 2, 3, 10, - 17, 24, 32, 25, 18, 11, 4, 5, - 12, 19, 26, 33, 40, 48, 41, 34, - 27, 20, 13, 6, 7, 14, 21, 28, - 35, 42, 49, 56, 57, 50, 43, 36, - 29, 22, 15, 23, 30, 37, 44, 51, - 58, 59, 52, 45, 38, 31, 39, 46, - 53, 60, 61, 54, 47, 55, 62, 63, - // let corrupt input sample past end - 63, 63, 63, 63, 63, 63, 63, 63, - 63, 63, 63, 63, 63, 63, 63 -}; - -// decode one 64-entry block-- -static int decode_block(jpeg *j, short data[64], huffman *hdc, huffman *hac, int b) -{ - int diff,dc,k; - int t = decode(j, hdc); - if (t < 0) return e("bad huffman code","Corrupt JPEG"); - - // 0 all the ac values now so we can do it 32-bits at a time - memset(data,0,64*sizeof(data[0])); - - diff = t ? extend_receive(j, t) : 0; - dc = j->img_comp[b].dc_pred + diff; - j->img_comp[b].dc_pred = dc; - data[0] = (short) dc; - - // decode AC components, see JPEG spec - k = 1; - do { - int r,s; - int rs = decode(j, hac); - if (rs < 0) return e("bad huffman code","Corrupt JPEG"); - s = rs & 15; - r = rs >> 4; - if (s == 0) { - if (rs != 0xf0) break; // end block - k += 16; - } else { - k += r; - // decode into unzigzag'd location - data[dezigzag[k++]] = (short) extend_receive(j,s); - } - } while (k < 64); - return 1; -} - -// take a -128..127 value and clamp it and convert to 0..255 -stbi_inline static uint8 clamp(int x) -{ - // trick to use a single test to catch both cases - if ((unsigned int) x > 255) { - if (x < 0) return 0; - if (x > 255) return 255; - } - return (uint8) x; -} - -#define f2f(x) (int) (((x) * 4096 + 0.5)) -#define fsh(x) ((x) << 12) - -// derived from jidctint -- DCT_ISLOW -#define IDCT_1D(s0,s1,s2,s3,s4,s5,s6,s7) \ - int t0,t1,t2,t3,p1,p2,p3,p4,p5,x0,x1,x2,x3; \ - p2 = s2; \ - p3 = s6; \ - p1 = (p2+p3) * f2f(0.5411961f); \ - t2 = p1 + p3*f2f(-1.847759065f); \ - t3 = p1 + p2*f2f( 0.765366865f); \ - p2 = s0; \ - p3 = s4; \ - t0 = fsh(p2+p3); \ - t1 = fsh(p2-p3); \ - x0 = t0+t3; \ - x3 = t0-t3; \ - x1 = t1+t2; \ - x2 = t1-t2; \ - t0 = s7; \ - t1 = s5; \ - t2 = s3; \ - t3 = s1; \ - p3 = t0+t2; \ - p4 = t1+t3; \ - p1 = t0+t3; \ - p2 = t1+t2; \ - p5 = (p3+p4)*f2f( 1.175875602f); \ - t0 = t0*f2f( 0.298631336f); \ - t1 = t1*f2f( 2.053119869f); \ - t2 = t2*f2f( 3.072711026f); \ - t3 = t3*f2f( 1.501321110f); \ - p1 = p5 + p1*f2f(-0.899976223f); \ - p2 = p5 + p2*f2f(-2.562915447f); \ - p3 = p3*f2f(-1.961570560f); \ - p4 = p4*f2f(-0.390180644f); \ - t3 += p1+p4; \ - t2 += p2+p3; \ - t1 += p2+p4; \ - t0 += p1+p3; - -#ifdef STBI_SIMD -typedef unsigned short stbi_dequantize_t; -#else -typedef uint8 stbi_dequantize_t; -#endif - -// .344 seconds on 3*anemones.jpg -static void idct_block(uint8 *out, int out_stride, short data[64], stbi_dequantize_t *dequantize) -{ - int i,val[64],*v=val; - stbi_dequantize_t *dq = dequantize; - uint8 *o; - short *d = data; - - // columns - for (i=0; i < 8; ++i,++d,++dq, ++v) { - // if all zeroes, shortcut -- this avoids dequantizing 0s and IDCTing - if (d[ 8]==0 && d[16]==0 && d[24]==0 && d[32]==0 - && d[40]==0 && d[48]==0 && d[56]==0) { - // no shortcut 0 seconds - // (1|2|3|4|5|6|7)==0 0 seconds - // all separate -0.047 seconds - // 1 && 2|3 && 4|5 && 6|7: -0.047 seconds - int dcterm = d[0] * dq[0] << 2; - v[0] = v[8] = v[16] = v[24] = v[32] = v[40] = v[48] = v[56] = dcterm; - } else { - IDCT_1D(d[ 0]*dq[ 0],d[ 8]*dq[ 8],d[16]*dq[16],d[24]*dq[24], - d[32]*dq[32],d[40]*dq[40],d[48]*dq[48],d[56]*dq[56]) - // constants scaled things up by 1<<12; let's bring them back - // down, but keep 2 extra bits of precision - x0 += 512; x1 += 512; x2 += 512; x3 += 512; - v[ 0] = (x0+t3) >> 10; - v[56] = (x0-t3) >> 10; - v[ 8] = (x1+t2) >> 10; - v[48] = (x1-t2) >> 10; - v[16] = (x2+t1) >> 10; - v[40] = (x2-t1) >> 10; - v[24] = (x3+t0) >> 10; - v[32] = (x3-t0) >> 10; - } - } - - for (i=0, v=val, o=out; i < 8; ++i,v+=8,o+=out_stride) { - // no fast case since the first 1D IDCT spread components out - IDCT_1D(v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7]) - // constants scaled things up by 1<<12, plus we had 1<<2 from first - // loop, plus horizontal and vertical each scale by sqrt(8) so together - // we've got an extra 1<<3, so 1<<17 total we need to remove. - // so we want to round that, which means adding 0.5 * 1<<17, - // aka 65536. Also, we'll end up with -128 to 127 that we want - // to encode as 0..255 by adding 128, so we'll add that before the shift - x0 += 65536 + (128<<17); - x1 += 65536 + (128<<17); - x2 += 65536 + (128<<17); - x3 += 65536 + (128<<17); - // tried computing the shifts into temps, or'ing the temps to see - // if any were out of range, but that was slower - o[0] = clamp((x0+t3) >> 17); - o[7] = clamp((x0-t3) >> 17); - o[1] = clamp((x1+t2) >> 17); - o[6] = clamp((x1-t2) >> 17); - o[2] = clamp((x2+t1) >> 17); - o[5] = clamp((x2-t1) >> 17); - o[3] = clamp((x3+t0) >> 17); - o[4] = clamp((x3-t0) >> 17); - } -} - -#ifdef STBI_SIMD -static stbi_idct_8x8 stbi_idct_installed = idct_block; - -void stbi_install_idct(stbi_idct_8x8 func) -{ - stbi_idct_installed = func; -} -#endif - -#define MARKER_none 0xff -// if there's a pending marker from the entropy stream, return that -// otherwise, fetch from the stream and get a marker. if there's no -// marker, return 0xff, which is never a valid marker value -static uint8 get_marker(jpeg *j) -{ - uint8 x; - if (j->marker != MARKER_none) { x = j->marker; j->marker = MARKER_none; return x; } - x = get8u(j->s); - if (x != 0xff) return MARKER_none; - while (x == 0xff) - x = get8u(j->s); - return x; -} - -// in each scan, we'll have scan_n components, and the order -// of the components is specified by order[] -#define RESTART(x) ((x) >= 0xd0 && (x) <= 0xd7) - -// after a restart interval, reset the entropy decoder and -// the dc prediction -static void reset(jpeg *j) -{ - j->code_bits = 0; - j->code_buffer = 0; - j->nomore = 0; - j->img_comp[0].dc_pred = j->img_comp[1].dc_pred = j->img_comp[2].dc_pred = 0; - j->marker = MARKER_none; - j->todo = j->restart_interval ? j->restart_interval : 0x7fffffff; - // no more than 1<<31 MCUs if no restart_interal? that's plenty safe, - // since we don't even allow 1<<30 pixels -} - -static int parse_entropy_coded_data(jpeg *z) -{ - reset(z); - if (z->scan_n == 1) { - int i,j; - #ifdef STBI_SIMD - __declspec(align(16)) - #endif - short data[64]; - int n = z->order[0]; - // non-interleaved data, we just need to process one block at a time, - // in trivial scanline order - // number of blocks to do just depends on how many actual "pixels" this - // component has, independent of interleaved MCU blocking and such - int w = (z->img_comp[n].x+7) >> 3; - int h = (z->img_comp[n].y+7) >> 3; - for (j=0; j < h; ++j) { - for (i=0; i < w; ++i) { - if (!decode_block(z, data, z->huff_dc+z->img_comp[n].hd, z->huff_ac+z->img_comp[n].ha, n)) return 0; - #ifdef STBI_SIMD - stbi_idct_installed(z->img_comp[n].data+z->img_comp[n].w2*j*8+i*8, z->img_comp[n].w2, data, z->dequant2[z->img_comp[n].tq]); - #else - idct_block(z->img_comp[n].data+z->img_comp[n].w2*j*8+i*8, z->img_comp[n].w2, data, z->dequant[z->img_comp[n].tq]); - #endif - // every data block is an MCU, so countdown the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) grow_buffer_unsafe(z); - // if it's NOT a restart, then just bail, so we get corrupt data - // rather than no data - if (!RESTART(z->marker)) return 1; - reset(z); - } - } - } - } else { // interleaved! - int i,j,k,x,y; - short data[64]; - for (j=0; j < z->img_mcu_y; ++j) { - for (i=0; i < z->img_mcu_x; ++i) { - // scan an interleaved mcu... process scan_n components in order - for (k=0; k < z->scan_n; ++k) { - int n = z->order[k]; - // scan out an mcu's worth of this component; that's just determined - // by the basic H and V specified for the component - for (y=0; y < z->img_comp[n].v; ++y) { - for (x=0; x < z->img_comp[n].h; ++x) { - int x2 = (i*z->img_comp[n].h + x)*8; - int y2 = (j*z->img_comp[n].v + y)*8; - if (!decode_block(z, data, z->huff_dc+z->img_comp[n].hd, z->huff_ac+z->img_comp[n].ha, n)) return 0; - #ifdef STBI_SIMD - stbi_idct_installed(z->img_comp[n].data+z->img_comp[n].w2*y2+x2, z->img_comp[n].w2, data, z->dequant2[z->img_comp[n].tq]); - #else - idct_block(z->img_comp[n].data+z->img_comp[n].w2*y2+x2, z->img_comp[n].w2, data, z->dequant[z->img_comp[n].tq]); - #endif - } - } - } - // after all interleaved components, that's an interleaved MCU, - // so now count down the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) grow_buffer_unsafe(z); - // if it's NOT a restart, then just bail, so we get corrupt data - // rather than no data - if (!RESTART(z->marker)) return 1; - reset(z); - } - } - } - } - return 1; -} - -static int process_marker(jpeg *z, int m) -{ - int L; - switch (m) { - case MARKER_none: // no marker found - return e("expected marker","Corrupt JPEG"); - - case 0xC2: // SOF - progressive - return e("progressive jpeg","JPEG format not supported (progressive)"); - - case 0xDD: // DRI - specify restart interval - if (get16(z->s) != 4) return e("bad DRI len","Corrupt JPEG"); - z->restart_interval = get16(z->s); - return 1; - - case 0xDB: // DQT - define quantization table - L = get16(z->s)-2; - while (L > 0) { - int q = get8(z->s); - int p = q >> 4; - int t = q & 15,i; - if (p != 0) return e("bad DQT type","Corrupt JPEG"); - if (t > 3) return e("bad DQT table","Corrupt JPEG"); - for (i=0; i < 64; ++i) - z->dequant[t][dezigzag[i]] = get8u(z->s); - #ifdef STBI_SIMD - for (i=0; i < 64; ++i) - z->dequant2[t][i] = z->dequant[t][i]; - #endif - L -= 65; - } - return L==0; - - case 0xC4: // DHT - define huffman table - L = get16(z->s)-2; - while (L > 0) { - uint8 *v; - int sizes[16],i,m=0; - int q = get8(z->s); - int tc = q >> 4; - int th = q & 15; - if (tc > 1 || th > 3) return e("bad DHT header","Corrupt JPEG"); - for (i=0; i < 16; ++i) { - sizes[i] = get8(z->s); - m += sizes[i]; - } - L -= 17; - if (tc == 0) { - if (!build_huffman(z->huff_dc+th, sizes)) return 0; - v = z->huff_dc[th].values; - } else { - if (!build_huffman(z->huff_ac+th, sizes)) return 0; - v = z->huff_ac[th].values; - } - for (i=0; i < m; ++i) - v[i] = get8u(z->s); - L -= m; - } - return L==0; - } - // check for comment block or APP blocks - if ((m >= 0xE0 && m <= 0xEF) || m == 0xFE) { - skip(z->s, get16(z->s)-2); - return 1; - } - return 0; -} - -// after we see SOS -static int process_scan_header(jpeg *z) -{ - int i; - int Ls = get16(z->s); - z->scan_n = get8(z->s); - if (z->scan_n < 1 || z->scan_n > 4 || z->scan_n > (int) z->s->img_n) return e("bad SOS component count","Corrupt JPEG"); - if (Ls != 6+2*z->scan_n) return e("bad SOS len","Corrupt JPEG"); - for (i=0; i < z->scan_n; ++i) { - int id = get8(z->s), which; - int q = get8(z->s); - for (which = 0; which < z->s->img_n; ++which) - if (z->img_comp[which].id == id) - break; - if (which == z->s->img_n) return 0; - z->img_comp[which].hd = q >> 4; if (z->img_comp[which].hd > 3) return e("bad DC huff","Corrupt JPEG"); - z->img_comp[which].ha = q & 15; if (z->img_comp[which].ha > 3) return e("bad AC huff","Corrupt JPEG"); - z->order[i] = which; - } - if (get8(z->s) != 0) return e("bad SOS","Corrupt JPEG"); - get8(z->s); // should be 63, but might be 0 - if (get8(z->s) != 0) return e("bad SOS","Corrupt JPEG"); - - return 1; -} - -static int process_frame_header(jpeg *z, int scan) -{ - stbi *s = z->s; - int Lf,p,i,q, h_max=1,v_max=1,c; - Lf = get16(s); if (Lf < 11) return e("bad SOF len","Corrupt JPEG"); // JPEG - p = get8(s); if (p != 8) return e("only 8-bit","JPEG format not supported: 8-bit only"); // JPEG baseline - s->img_y = get16(s); if (s->img_y == 0) return e("no header height", "JPEG format not supported: delayed height"); // Legal, but we don't handle it--but neither does IJG - s->img_x = get16(s); if (s->img_x == 0) return e("0 width","Corrupt JPEG"); // JPEG requires - c = get8(s); - if (c != 3 && c != 1) return e("bad component count","Corrupt JPEG"); // JFIF requires - s->img_n = c; - for (i=0; i < c; ++i) { - z->img_comp[i].data = NULL; - z->img_comp[i].linebuf = NULL; - } - - if (Lf != 8+3*s->img_n) return e("bad SOF len","Corrupt JPEG"); - - for (i=0; i < s->img_n; ++i) { - z->img_comp[i].id = get8(s); - if (z->img_comp[i].id != i+1) // JFIF requires - if (z->img_comp[i].id != i) // some version of jpegtran outputs non-JFIF-compliant files! - return e("bad component ID","Corrupt JPEG"); - q = get8(s); - z->img_comp[i].h = (q >> 4); if (!z->img_comp[i].h || z->img_comp[i].h > 4) return e("bad H","Corrupt JPEG"); - z->img_comp[i].v = q & 15; if (!z->img_comp[i].v || z->img_comp[i].v > 4) return e("bad V","Corrupt JPEG"); - z->img_comp[i].tq = get8(s); if (z->img_comp[i].tq > 3) return e("bad TQ","Corrupt JPEG"); - } - - if (scan != SCAN_load) return 1; - - if ((1 << 30) / s->img_x / s->img_n < s->img_y) return e("too large", "Image too large to decode"); - - for (i=0; i < s->img_n; ++i) { - if (z->img_comp[i].h > h_max) h_max = z->img_comp[i].h; - if (z->img_comp[i].v > v_max) v_max = z->img_comp[i].v; - } - - // compute interleaved mcu info - z->img_h_max = h_max; - z->img_v_max = v_max; - z->img_mcu_w = h_max * 8; - z->img_mcu_h = v_max * 8; - z->img_mcu_x = (s->img_x + z->img_mcu_w-1) / z->img_mcu_w; - z->img_mcu_y = (s->img_y + z->img_mcu_h-1) / z->img_mcu_h; - - for (i=0; i < s->img_n; ++i) { - // number of effective pixels (e.g. for non-interleaved MCU) - z->img_comp[i].x = (s->img_x * z->img_comp[i].h + h_max-1) / h_max; - z->img_comp[i].y = (s->img_y * z->img_comp[i].v + v_max-1) / v_max; - // to simplify generation, we'll allocate enough memory to decode - // the bogus oversized data from using interleaved MCUs and their - // big blocks (e.g. a 16x16 iMCU on an image of width 33); we won't - // discard the extra data until colorspace conversion - z->img_comp[i].w2 = z->img_mcu_x * z->img_comp[i].h * 8; - z->img_comp[i].h2 = z->img_mcu_y * z->img_comp[i].v * 8; - z->img_comp[i].raw_data = malloc(z->img_comp[i].w2 * z->img_comp[i].h2+15); - if (z->img_comp[i].raw_data == NULL) { - for(--i; i >= 0; --i) { - free(z->img_comp[i].raw_data); - z->img_comp[i].data = NULL; - } - return e("outofmem", "Out of memory"); - } - // align blocks for installable-idct using mmx/sse - z->img_comp[i].data = (uint8*) (((size_t) z->img_comp[i].raw_data + 15) & ~15); - z->img_comp[i].linebuf = NULL; - } - - return 1; -} - -// use comparisons since in some cases we handle more than one case (e.g. SOF) -#define DNL(x) ((x) == 0xdc) -#define SOI(x) ((x) == 0xd8) -#define EOI(x) ((x) == 0xd9) -#define SOF(x) ((x) == 0xc0 || (x) == 0xc1) -#define SOS(x) ((x) == 0xda) - -static int decode_jpeg_header(jpeg *z, int scan) -{ - int m; - z->marker = MARKER_none; // initialize cached marker to empty - m = get_marker(z); - if (!SOI(m)) return e("no SOI","Corrupt JPEG"); - if (scan == SCAN_type) return 1; - m = get_marker(z); - while (!SOF(m)) { - if (!process_marker(z,m)) return 0; - m = get_marker(z); - while (m == MARKER_none) { - // some files have extra padding after their blocks, so ok, we'll scan - if (at_eof(z->s)) return e("no SOF", "Corrupt JPEG"); - m = get_marker(z); - } - } - if (!process_frame_header(z, scan)) return 0; - return 1; -} - -static int decode_jpeg_image(jpeg *j) -{ - int m; - j->restart_interval = 0; - if (!decode_jpeg_header(j, SCAN_load)) return 0; - m = get_marker(j); - while (!EOI(m)) { - if (SOS(m)) { - if (!process_scan_header(j)) return 0; - if (!parse_entropy_coded_data(j)) return 0; - if (j->marker == MARKER_none ) { - // handle 0s at the end of image data from IP Kamera 9060 - while (!at_eof(j->s)) { - int x = get8(j->s); - if (x == 255) { - j->marker = get8u(j->s); - break; - } else if (x != 0) { - return 0; - } - } - // if we reach eof without hitting a marker, get_marker() below will fail and we'll eventually return 0 - } - } else { - if (!process_marker(j, m)) return 0; - } - m = get_marker(j); - } - return 1; -} - -// static jfif-centered resampling (across block boundaries) - -typedef uint8 *(*resample_row_func)(uint8 *out, uint8 *in0, uint8 *in1, - int w, int hs); - -#define div4(x) ((uint8) ((x) >> 2)) - -static uint8 *resample_row_1(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - STBI_NOTUSED(out); - STBI_NOTUSED(in_far); - STBI_NOTUSED(w); - STBI_NOTUSED(hs); - return in_near; -} - -static uint8* resample_row_v_2(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // need to generate two samples vertically for every one in input - int i; - STBI_NOTUSED(hs); - for (i=0; i < w; ++i) - out[i] = div4(3*in_near[i] + in_far[i] + 2); - return out; -} - -static uint8* resample_row_h_2(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // need to generate two samples horizontally for every one in input - int i; - uint8 *input = in_near; - - if (w == 1) { - // if only one sample, can't do any interpolation - out[0] = out[1] = input[0]; - return out; - } - - out[0] = input[0]; - out[1] = div4(input[0]*3 + input[1] + 2); - for (i=1; i < w-1; ++i) { - int n = 3*input[i]+2; - out[i*2+0] = div4(n+input[i-1]); - out[i*2+1] = div4(n+input[i+1]); - } - out[i*2+0] = div4(input[w-2]*3 + input[w-1] + 2); - out[i*2+1] = input[w-1]; - - STBI_NOTUSED(in_far); - STBI_NOTUSED(hs); - - return out; -} - -#define div16(x) ((uint8) ((x) >> 4)) - -static uint8 *resample_row_hv_2(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // need to generate 2x2 samples for every one in input - int i,t0,t1; - if (w == 1) { - out[0] = out[1] = div4(3*in_near[0] + in_far[0] + 2); - return out; - } - - t1 = 3*in_near[0] + in_far[0]; - out[0] = div4(t1+2); - for (i=1; i < w; ++i) { - t0 = t1; - t1 = 3*in_near[i]+in_far[i]; - out[i*2-1] = div16(3*t0 + t1 + 8); - out[i*2 ] = div16(3*t1 + t0 + 8); - } - out[w*2-1] = div4(t1+2); - - STBI_NOTUSED(hs); - - return out; -} - -static uint8 *resample_row_generic(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // resample with nearest-neighbor - int i,j; - for (i=0; i < w; ++i) - for (j=0; j < hs; ++j) - out[i*hs+j] = in_near[i]; - return out; -} - -#define float2fixed(x) ((int) ((x) * 65536 + 0.5)) - -// 0.38 seconds on 3*anemones.jpg (0.25 with processor = Pro) -// VC6 without processor=Pro is generating multiple LEAs per multiply! -static void YCbCr_to_RGB_row(uint8 *out, const uint8 *y, const uint8 *pcb, const uint8 *pcr, int count, int step) -{ - int i; - for (i=0; i < count; ++i) { - int y_fixed = (y[i] << 16) + 32768; // rounding - int r,g,b; - int cr = pcr[i] - 128; - int cb = pcb[i] - 128; - r = y_fixed + cr*float2fixed(1.40200f); - g = y_fixed - cr*float2fixed(0.71414f) - cb*float2fixed(0.34414f); - b = y_fixed + cb*float2fixed(1.77200f); - r >>= 16; - g >>= 16; - b >>= 16; - if ((unsigned) r > 255) { if (r < 0) r = 0; else r = 255; } - if ((unsigned) g > 255) { if (g < 0) g = 0; else g = 255; } - if ((unsigned) b > 255) { if (b < 0) b = 0; else b = 255; } - out[0] = (uint8)r; - out[1] = (uint8)g; - out[2] = (uint8)b; - out[3] = 255; - out += step; - } -} - -#ifdef STBI_SIMD -static stbi_YCbCr_to_RGB_run stbi_YCbCr_installed = YCbCr_to_RGB_row; - -void stbi_install_YCbCr_to_RGB(stbi_YCbCr_to_RGB_run func) -{ - stbi_YCbCr_installed = func; -} -#endif - - -// clean up the temporary component buffers -static void cleanup_jpeg(jpeg *j) -{ - int i; - for (i=0; i < j->s->img_n; ++i) { - if (j->img_comp[i].data) { - free(j->img_comp[i].raw_data); - j->img_comp[i].data = NULL; - } - if (j->img_comp[i].linebuf) { - free(j->img_comp[i].linebuf); - j->img_comp[i].linebuf = NULL; - } - } -} - -typedef struct -{ - resample_row_func resample; - uint8 *line0,*line1; - int hs,vs; // expansion factor in each axis - int w_lores; // horizontal pixels pre-expansion - int ystep; // how far through vertical expansion we are - int ypos; // which pre-expansion row we're on -} stbi_resample; - -static uint8 *load_jpeg_image(jpeg *z, int *out_x, int *out_y, int *comp, int req_comp) -{ - int n, decode_n; - // validate req_comp - if (req_comp < 0 || req_comp > 4) return epuc("bad req_comp", "Internal error"); - z->s->img_n = 0; - - // load a jpeg image from whichever source - if (!decode_jpeg_image(z)) { cleanup_jpeg(z); return NULL; } - - // determine actual number of components to generate - n = req_comp ? req_comp : z->s->img_n; - - if (z->s->img_n == 3 && n < 3) - decode_n = 1; - else - decode_n = z->s->img_n; - - // resample and color-convert - { - int k; - uint i,j; - uint8 *output; - uint8 *coutput[4]; - - stbi_resample res_comp[4]; - - for (k=0; k < decode_n; ++k) { - stbi_resample *r = &res_comp[k]; - - // allocate line buffer big enough for upsampling off the edges - // with upsample factor of 4 - z->img_comp[k].linebuf = (uint8 *) malloc(z->s->img_x + 3); - if (!z->img_comp[k].linebuf) { cleanup_jpeg(z); return epuc("outofmem", "Out of memory"); } - - r->hs = z->img_h_max / z->img_comp[k].h; - r->vs = z->img_v_max / z->img_comp[k].v; - r->ystep = r->vs >> 1; - r->w_lores = (z->s->img_x + r->hs-1) / r->hs; - r->ypos = 0; - r->line0 = r->line1 = z->img_comp[k].data; - - if (r->hs == 1 && r->vs == 1) r->resample = resample_row_1; - else if (r->hs == 1 && r->vs == 2) r->resample = resample_row_v_2; - else if (r->hs == 2 && r->vs == 1) r->resample = resample_row_h_2; - else if (r->hs == 2 && r->vs == 2) r->resample = resample_row_hv_2; - else r->resample = resample_row_generic; - } - - // can't error after this so, this is safe - output = (uint8 *) malloc(n * z->s->img_x * z->s->img_y + 1); - if (!output) { cleanup_jpeg(z); return epuc("outofmem", "Out of memory"); } - - // now go ahead and resample - for (j=0; j < z->s->img_y; ++j) { - uint8 *out = output + n * z->s->img_x * j; - for (k=0; k < decode_n; ++k) { - stbi_resample *r = &res_comp[k]; - int y_bot = r->ystep >= (r->vs >> 1); - coutput[k] = r->resample(z->img_comp[k].linebuf, - y_bot ? r->line1 : r->line0, - y_bot ? r->line0 : r->line1, - r->w_lores, r->hs); - if (++r->ystep >= r->vs) { - r->ystep = 0; - r->line0 = r->line1; - if (++r->ypos < z->img_comp[k].y) - r->line1 += z->img_comp[k].w2; - } - } - if (n >= 3) { - uint8 *y = coutput[0]; - if (z->s->img_n == 3) { - #ifdef STBI_SIMD - stbi_YCbCr_installed(out, y, coutput[1], coutput[2], z->s.img_x, n); - #else - YCbCr_to_RGB_row(out, y, coutput[1], coutput[2], z->s->img_x, n); - #endif - } else - for (i=0; i < z->s->img_x; ++i) { - out[0] = out[1] = out[2] = y[i]; - out[3] = 255; // not used if n==3 - out += n; - } - } else { - uint8 *y = coutput[0]; - if (n == 1) - for (i=0; i < z->s->img_x; ++i) out[i] = y[i]; - else - for (i=0; i < z->s->img_x; ++i) *out++ = y[i], *out++ = 255; - } - } - cleanup_jpeg(z); - *out_x = z->s->img_x; - *out_y = z->s->img_y; - if (comp) *comp = z->s->img_n; // report original components, not output - return output; - } -} - -static unsigned char *stbi_jpeg_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - jpeg j; - j.s = s; - return load_jpeg_image(&j, x,y,comp,req_comp); -} - -static int stbi_jpeg_test(stbi *s) -{ - int r; - jpeg j; - j.s = s; - r = decode_jpeg_header(&j, SCAN_type); - stbi_rewind(s); - return r; -} - -static int stbi_jpeg_info_raw(jpeg *j, int *x, int *y, int *comp) -{ - if (!decode_jpeg_header(j, SCAN_header)) { - stbi_rewind( j->s ); - return 0; - } - if (x) *x = j->s->img_x; - if (y) *y = j->s->img_y; - if (comp) *comp = j->s->img_n; - return 1; -} - -static int stbi_jpeg_info(stbi *s, int *x, int *y, int *comp) -{ - jpeg j; - j.s = s; - return stbi_jpeg_info_raw(&j, x, y, comp); -} - -// public domain zlib decode v0.2 Sean Barrett 2006-11-18 -// simple implementation -// - all input must be provided in an upfront buffer -// - all output is written to a single output buffer (can malloc/realloc) -// performance -// - fast huffman - -// fast-way is faster to check than jpeg huffman, but slow way is slower -#define ZFAST_BITS 9 // accelerate all cases in default tables -#define ZFAST_MASK ((1 << ZFAST_BITS) - 1) - -// zlib-style huffman encoding -// (jpegs packs from left, zlib from right, so can't share code) -typedef struct -{ - uint16 fast[1 << ZFAST_BITS]; - uint16 firstcode[16]; - int maxcode[17]; - uint16 firstsymbol[16]; - uint8 size[288]; - uint16 value[288]; -} zhuffman; - -stbi_inline static int bitreverse16(int n) -{ - n = ((n & 0xAAAA) >> 1) | ((n & 0x5555) << 1); - n = ((n & 0xCCCC) >> 2) | ((n & 0x3333) << 2); - n = ((n & 0xF0F0) >> 4) | ((n & 0x0F0F) << 4); - n = ((n & 0xFF00) >> 8) | ((n & 0x00FF) << 8); - return n; -} - -stbi_inline static int bit_reverse(int v, int bits) -{ - assert(bits <= 16); - // to bit reverse n bits, reverse 16 and shift - // e.g. 11 bits, bit reverse and shift away 5 - return bitreverse16(v) >> (16-bits); -} - -static int zbuild_huffman(zhuffman *z, uint8 *sizelist, int num) -{ - int i,k=0; - int code, next_code[16], sizes[17]; - - // DEFLATE spec for generating codes - memset(sizes, 0, sizeof(sizes)); - memset(z->fast, 255, sizeof(z->fast)); - for (i=0; i < num; ++i) - ++sizes[sizelist[i]]; - sizes[0] = 0; - for (i=1; i < 16; ++i) - assert(sizes[i] <= (1 << i)); - code = 0; - for (i=1; i < 16; ++i) { - next_code[i] = code; - z->firstcode[i] = (uint16) code; - z->firstsymbol[i] = (uint16) k; - code = (code + sizes[i]); - if (sizes[i]) - if (code-1 >= (1 << i)) return e("bad codelengths","Corrupt JPEG"); - z->maxcode[i] = code << (16-i); // preshift for inner loop - code <<= 1; - k += sizes[i]; - } - z->maxcode[16] = 0x10000; // sentinel - for (i=0; i < num; ++i) { - int s = sizelist[i]; - if (s) { - int c = next_code[s] - z->firstcode[s] + z->firstsymbol[s]; - z->size[c] = (uint8)s; - z->value[c] = (uint16)i; - if (s <= ZFAST_BITS) { - int k = bit_reverse(next_code[s],s); - while (k < (1 << ZFAST_BITS)) { - z->fast[k] = (uint16) c; - k += (1 << s); - } - } - ++next_code[s]; - } - } - return 1; -} - -// zlib-from-memory implementation for PNG reading -// because PNG allows splitting the zlib stream arbitrarily, -// and it's annoying structurally to have PNG call ZLIB call PNG, -// we require PNG read all the IDATs and combine them into a single -// memory buffer - -typedef struct -{ - uint8 *zbuffer, *zbuffer_end; - int num_bits; - uint32 code_buffer; - - char *zout; - char *zout_start; - char *zout_end; - int z_expandable; - - zhuffman z_length, z_distance; -} zbuf; - -stbi_inline static int zget8(zbuf *z) -{ - if (z->zbuffer >= z->zbuffer_end) return 0; - return *z->zbuffer++; -} - -static void fill_bits(zbuf *z) -{ - do { - assert(z->code_buffer < (1U << z->num_bits)); - z->code_buffer |= zget8(z) << z->num_bits; - z->num_bits += 8; - } while (z->num_bits <= 24); -} - -stbi_inline static unsigned int zreceive(zbuf *z, int n) -{ - unsigned int k; - if (z->num_bits < n) fill_bits(z); - k = z->code_buffer & ((1 << n) - 1); - z->code_buffer >>= n; - z->num_bits -= n; - return k; -} - -stbi_inline static int zhuffman_decode(zbuf *a, zhuffman *z) -{ - int b,s,k; - if (a->num_bits < 16) fill_bits(a); - b = z->fast[a->code_buffer & ZFAST_MASK]; - if (b < 0xffff) { - s = z->size[b]; - a->code_buffer >>= s; - a->num_bits -= s; - return z->value[b]; - } - - // not resolved by fast table, so compute it the slow way - // use jpeg approach, which requires MSbits at top - k = bit_reverse(a->code_buffer, 16); - for (s=ZFAST_BITS+1; ; ++s) - if (k < z->maxcode[s]) - break; - if (s == 16) return -1; // invalid code! - // code size is s, so: - b = (k >> (16-s)) - z->firstcode[s] + z->firstsymbol[s]; - assert(z->size[b] == s); - a->code_buffer >>= s; - a->num_bits -= s; - return z->value[b]; -} - -static int expand(zbuf *z, int n) // need to make room for n bytes -{ - char *q; - int cur, limit; - if (!z->z_expandable) return e("output buffer limit","Corrupt PNG"); - cur = (int) (z->zout - z->zout_start); - limit = (int) (z->zout_end - z->zout_start); - while (cur + n > limit) - limit *= 2; - q = (char *) realloc(z->zout_start, limit); - if (q == NULL) return e("outofmem", "Out of memory"); - z->zout_start = q; - z->zout = q + cur; - z->zout_end = q + limit; - return 1; -} - -static int length_base[31] = { - 3,4,5,6,7,8,9,10,11,13, - 15,17,19,23,27,31,35,43,51,59, - 67,83,99,115,131,163,195,227,258,0,0 }; - -static int length_extra[31]= -{ 0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0 }; - -static int dist_base[32] = { 1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193, -257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0}; - -static int dist_extra[32] = -{ 0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13}; - -static int parse_huffman_block(zbuf *a) -{ - for(;;) { - int z = zhuffman_decode(a, &a->z_length); - if (z < 256) { - if (z < 0) return e("bad huffman code","Corrupt PNG"); // error in huffman codes - if (a->zout >= a->zout_end) if (!expand(a, 1)) return 0; - *a->zout++ = (char) z; - } else { - uint8 *p; - int len,dist; - if (z == 256) return 1; - z -= 257; - len = length_base[z]; - if (length_extra[z]) len += zreceive(a, length_extra[z]); - z = zhuffman_decode(a, &a->z_distance); - if (z < 0) return e("bad huffman code","Corrupt PNG"); - dist = dist_base[z]; - if (dist_extra[z]) dist += zreceive(a, dist_extra[z]); - if (a->zout - a->zout_start < dist) return e("bad dist","Corrupt PNG"); - if (a->zout + len > a->zout_end) if (!expand(a, len)) return 0; - p = (uint8 *) (a->zout - dist); - while (len--) - *a->zout++ = *p++; - } - } -} - -static int compute_huffman_codes(zbuf *a) -{ - static uint8 length_dezigzag[19] = { 16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15 }; - zhuffman z_codelength; - uint8 lencodes[286+32+137];//padding for maximum single op - uint8 codelength_sizes[19]; - int i,n; - - int hlit = zreceive(a,5) + 257; - int hdist = zreceive(a,5) + 1; - int hclen = zreceive(a,4) + 4; - - memset(codelength_sizes, 0, sizeof(codelength_sizes)); - for (i=0; i < hclen; ++i) { - int s = zreceive(a,3); - codelength_sizes[length_dezigzag[i]] = (uint8) s; - } - if (!zbuild_huffman(&z_codelength, codelength_sizes, 19)) return 0; - - n = 0; - while (n < hlit + hdist) { - int c = zhuffman_decode(a, &z_codelength); - assert(c >= 0 && c < 19); - if (c < 16) - lencodes[n++] = (uint8) c; - else if (c == 16) { - c = zreceive(a,2)+3; - memset(lencodes+n, lencodes[n-1], c); - n += c; - } else if (c == 17) { - c = zreceive(a,3)+3; - memset(lencodes+n, 0, c); - n += c; - } else { - assert(c == 18); - c = zreceive(a,7)+11; - memset(lencodes+n, 0, c); - n += c; - } - } - if (n != hlit+hdist) return e("bad codelengths","Corrupt PNG"); - if (!zbuild_huffman(&a->z_length, lencodes, hlit)) return 0; - if (!zbuild_huffman(&a->z_distance, lencodes+hlit, hdist)) return 0; - return 1; -} - -static int parse_uncompressed_block(zbuf *a) -{ - uint8 header[4]; - int len,nlen,k; - if (a->num_bits & 7) - zreceive(a, a->num_bits & 7); // discard - // drain the bit-packed data into header - k = 0; - while (a->num_bits > 0) { - header[k++] = (uint8) (a->code_buffer & 255); // wtf this warns? - a->code_buffer >>= 8; - a->num_bits -= 8; - } - assert(a->num_bits == 0); - // now fill header the normal way - while (k < 4) - header[k++] = (uint8) zget8(a); - len = header[1] * 256 + header[0]; - nlen = header[3] * 256 + header[2]; - if (nlen != (len ^ 0xffff)) return e("zlib corrupt","Corrupt PNG"); - if (a->zbuffer + len > a->zbuffer_end) return e("read past buffer","Corrupt PNG"); - if (a->zout + len > a->zout_end) - if (!expand(a, len)) return 0; - memcpy(a->zout, a->zbuffer, len); - a->zbuffer += len; - a->zout += len; - return 1; -} - -static int parse_zlib_header(zbuf *a) -{ - int cmf = zget8(a); - int cm = cmf & 15; - /* int cinfo = cmf >> 4; */ - int flg = zget8(a); - if ((cmf*256+flg) % 31 != 0) return e("bad zlib header","Corrupt PNG"); // zlib spec - if (flg & 32) return e("no preset dict","Corrupt PNG"); // preset dictionary not allowed in png - if (cm != 8) return e("bad compression","Corrupt PNG"); // DEFLATE required for png - // window = 1 << (8 + cinfo)... but who cares, we fully buffer output - return 1; -} - -// @TODO: should statically initialize these for optimal thread safety -static uint8 default_length[288], default_distance[32]; -static void init_defaults(void) -{ - int i; // use <= to match clearly with spec - for (i=0; i <= 143; ++i) default_length[i] = 8; - for ( ; i <= 255; ++i) default_length[i] = 9; - for ( ; i <= 279; ++i) default_length[i] = 7; - for ( ; i <= 287; ++i) default_length[i] = 8; - - for (i=0; i <= 31; ++i) default_distance[i] = 5; -} - -int stbi_png_partial; // a quick hack to only allow decoding some of a PNG... I should implement real streaming support instead -static int parse_zlib(zbuf *a, int parse_header) -{ - int final, type; - if (parse_header) - if (!parse_zlib_header(a)) return 0; - a->num_bits = 0; - a->code_buffer = 0; - do { - final = zreceive(a,1); - type = zreceive(a,2); - if (type == 0) { - if (!parse_uncompressed_block(a)) return 0; - } else if (type == 3) { - return 0; - } else { - if (type == 1) { - // use fixed code lengths - if (!default_distance[31]) init_defaults(); - if (!zbuild_huffman(&a->z_length , default_length , 288)) return 0; - if (!zbuild_huffman(&a->z_distance, default_distance, 32)) return 0; - } else { - if (!compute_huffman_codes(a)) return 0; - } - if (!parse_huffman_block(a)) return 0; - } - if (stbi_png_partial && a->zout - a->zout_start > 65536) - break; - } while (!final); - return 1; -} - -static int do_zlib(zbuf *a, char *obuf, int olen, int exp, int parse_header) -{ - a->zout_start = obuf; - a->zout = obuf; - a->zout_end = obuf + olen; - a->z_expandable = exp; - - return parse_zlib(a, parse_header); -} - -char *stbi_zlib_decode_malloc_guesssize(const char *buffer, int len, int initial_size, int *outlen) -{ - zbuf a; - char *p = (char *) malloc(initial_size); - if (p == NULL) return NULL; - a.zbuffer = (uint8 *) buffer; - a.zbuffer_end = (uint8 *) buffer + len; - if (do_zlib(&a, p, initial_size, 1, 1)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - free(a.zout_start); - return NULL; - } -} - -char *stbi_zlib_decode_malloc(char const *buffer, int len, int *outlen) -{ - return stbi_zlib_decode_malloc_guesssize(buffer, len, 16384, outlen); -} - -char *stbi_zlib_decode_malloc_guesssize_headerflag(const char *buffer, int len, int initial_size, int *outlen, int parse_header) -{ - zbuf a; - char *p = (char *) malloc(initial_size); - if (p == NULL) return NULL; - a.zbuffer = (uint8 *) buffer; - a.zbuffer_end = (uint8 *) buffer + len; - if (do_zlib(&a, p, initial_size, 1, parse_header)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - free(a.zout_start); - return NULL; - } -} - -int stbi_zlib_decode_buffer(char *obuffer, int olen, char const *ibuffer, int ilen) -{ - zbuf a; - a.zbuffer = (uint8 *) ibuffer; - a.zbuffer_end = (uint8 *) ibuffer + ilen; - if (do_zlib(&a, obuffer, olen, 0, 1)) - return (int) (a.zout - a.zout_start); - else - return -1; -} - -char *stbi_zlib_decode_noheader_malloc(char const *buffer, int len, int *outlen) -{ - zbuf a; - char *p = (char *) malloc(16384); - if (p == NULL) return NULL; - a.zbuffer = (uint8 *) buffer; - a.zbuffer_end = (uint8 *) buffer+len; - if (do_zlib(&a, p, 16384, 1, 0)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - free(a.zout_start); - return NULL; - } -} - -int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char *ibuffer, int ilen) -{ - zbuf a; - a.zbuffer = (uint8 *) ibuffer; - a.zbuffer_end = (uint8 *) ibuffer + ilen; - if (do_zlib(&a, obuffer, olen, 0, 0)) - return (int) (a.zout - a.zout_start); - else - return -1; -} - -// public domain "baseline" PNG decoder v0.10 Sean Barrett 2006-11-18 -// simple implementation -// - only 8-bit samples -// - no CRC checking -// - allocates lots of intermediate memory -// - avoids problem of streaming data between subsystems -// - avoids explicit window management -// performance -// - uses stb_zlib, a PD zlib implementation with fast huffman decoding - - -typedef struct -{ - uint32 length; - uint32 type; -} chunk; - -#define PNG_TYPE(a,b,c,d) (((a) << 24) + ((b) << 16) + ((c) << 8) + (d)) - -static chunk get_chunk_header(stbi *s) -{ - chunk c; - c.length = get32(s); - c.type = get32(s); - return c; -} - -static int check_png_header(stbi *s) -{ - static uint8 png_sig[8] = { 137,80,78,71,13,10,26,10 }; - int i; - for (i=0; i < 8; ++i) - if (get8u(s) != png_sig[i]) return e("bad png sig","Not a PNG"); - return 1; -} - -typedef struct -{ - stbi *s; - uint8 *idata, *expanded, *out; -} png; - - -enum { - F_none=0, F_sub=1, F_up=2, F_avg=3, F_paeth=4, - F_avg_first, F_paeth_first -}; - -static uint8 first_row_filter[5] = -{ - F_none, F_sub, F_none, F_avg_first, F_paeth_first -}; - -static int paeth(int a, int b, int c) -{ - int p = a + b - c; - int pa = abs(p-a); - int pb = abs(p-b); - int pc = abs(p-c); - if (pa <= pb && pa <= pc) return a; - if (pb <= pc) return b; - return c; -} - -// create the png data from post-deflated data -static int create_png_image_raw(png *a, uint8 *raw, uint32 raw_len, int out_n, uint32 x, uint32 y) -{ - stbi *s = a->s; - uint32 i,j,stride = x*out_n; - int k; - int img_n = s->img_n; // copy it into a local for later - assert(out_n == s->img_n || out_n == s->img_n+1); - if (stbi_png_partial) y = 1; - a->out = (uint8 *) malloc(x * y * out_n); - if (!a->out) return e("outofmem", "Out of memory"); - if (!stbi_png_partial) { - if (s->img_x == x && s->img_y == y) { - if (raw_len != (img_n * x + 1) * y) return e("not enough pixels","Corrupt PNG"); - } else { // interlaced: - if (raw_len < (img_n * x + 1) * y) return e("not enough pixels","Corrupt PNG"); - } - } - for (j=0; j < y; ++j) { - uint8 *cur = a->out + stride*j; - uint8 *prior = cur - stride; - int filter = *raw++; - if (filter > 4) return e("invalid filter","Corrupt PNG"); - // if first row, use special filter that doesn't sample previous row - if (j == 0) filter = first_row_filter[filter]; - // handle first pixel explicitly - for (k=0; k < img_n; ++k) { - switch (filter) { - case F_none : cur[k] = raw[k]; break; - case F_sub : cur[k] = raw[k]; break; - case F_up : cur[k] = raw[k] + prior[k]; break; - case F_avg : cur[k] = raw[k] + (prior[k]>>1); break; - case F_paeth : cur[k] = (uint8) (raw[k] + paeth(0,prior[k],0)); break; - case F_avg_first : cur[k] = raw[k]; break; - case F_paeth_first: cur[k] = raw[k]; break; - } - } - if (img_n != out_n) cur[img_n] = 255; - raw += img_n; - cur += out_n; - prior += out_n; - // this is a little gross, so that we don't switch per-pixel or per-component - if (img_n == out_n) { - #define CASE(f) \ - case f: \ - for (i=x-1; i >= 1; --i, raw+=img_n,cur+=img_n,prior+=img_n) \ - for (k=0; k < img_n; ++k) - switch (filter) { - CASE(F_none) cur[k] = raw[k]; break; - CASE(F_sub) cur[k] = raw[k] + cur[k-img_n]; break; - CASE(F_up) cur[k] = raw[k] + prior[k]; break; - CASE(F_avg) cur[k] = raw[k] + ((prior[k] + cur[k-img_n])>>1); break; - CASE(F_paeth) cur[k] = (uint8) (raw[k] + paeth(cur[k-img_n],prior[k],prior[k-img_n])); break; - CASE(F_avg_first) cur[k] = raw[k] + (cur[k-img_n] >> 1); break; - CASE(F_paeth_first) cur[k] = (uint8) (raw[k] + paeth(cur[k-img_n],0,0)); break; - } - #undef CASE - } else { - assert(img_n+1 == out_n); - #define CASE(f) \ - case f: \ - for (i=x-1; i >= 1; --i, cur[img_n]=255,raw+=img_n,cur+=out_n,prior+=out_n) \ - for (k=0; k < img_n; ++k) - switch (filter) { - CASE(F_none) cur[k] = raw[k]; break; - CASE(F_sub) cur[k] = raw[k] + cur[k-out_n]; break; - CASE(F_up) cur[k] = raw[k] + prior[k]; break; - CASE(F_avg) cur[k] = raw[k] + ((prior[k] + cur[k-out_n])>>1); break; - CASE(F_paeth) cur[k] = (uint8) (raw[k] + paeth(cur[k-out_n],prior[k],prior[k-out_n])); break; - CASE(F_avg_first) cur[k] = raw[k] + (cur[k-out_n] >> 1); break; - CASE(F_paeth_first) cur[k] = (uint8) (raw[k] + paeth(cur[k-out_n],0,0)); break; - } - #undef CASE - } - } - return 1; -} - -static int create_png_image(png *a, uint8 *raw, uint32 raw_len, int out_n, int interlaced) -{ - uint8 *final; - int p; - int save; - if (!interlaced) - return create_png_image_raw(a, raw, raw_len, out_n, a->s->img_x, a->s->img_y); - save = stbi_png_partial; - stbi_png_partial = 0; - - // de-interlacing - final = (uint8 *) malloc(a->s->img_x * a->s->img_y * out_n); - for (p=0; p < 7; ++p) { - int xorig[] = { 0,4,0,2,0,1,0 }; - int yorig[] = { 0,0,4,0,2,0,1 }; - int xspc[] = { 8,8,4,4,2,2,1 }; - int yspc[] = { 8,8,8,4,4,2,2 }; - int i,j,x,y; - // pass1_x[4] = 0, pass1_x[5] = 1, pass1_x[12] = 1 - x = (a->s->img_x - xorig[p] + xspc[p]-1) / xspc[p]; - y = (a->s->img_y - yorig[p] + yspc[p]-1) / yspc[p]; - if (x && y) { - if (!create_png_image_raw(a, raw, raw_len, out_n, x, y)) { - free(final); - return 0; - } - for (j=0; j < y; ++j) - for (i=0; i < x; ++i) - memcpy(final + (j*yspc[p]+yorig[p])*a->s->img_x*out_n + (i*xspc[p]+xorig[p])*out_n, - a->out + (j*x+i)*out_n, out_n); - free(a->out); - raw += (x*out_n+1)*y; - raw_len -= (x*out_n+1)*y; - } - } - a->out = final; - - stbi_png_partial = save; - return 1; -} - -static int compute_transparency(png *z, uint8 tc[3], int out_n) -{ - stbi *s = z->s; - uint32 i, pixel_count = s->img_x * s->img_y; - uint8 *p = z->out; - - // compute color-based transparency, assuming we've - // already got 255 as the alpha value in the output - assert(out_n == 2 || out_n == 4); - - if (out_n == 2) { - for (i=0; i < pixel_count; ++i) { - p[1] = (p[0] == tc[0] ? 0 : 255); - p += 2; - } - } else { - for (i=0; i < pixel_count; ++i) { - if (p[0] == tc[0] && p[1] == tc[1] && p[2] == tc[2]) - p[3] = 0; - p += 4; - } - } - return 1; -} - -static int expand_palette(png *a, uint8 *palette, int len, int pal_img_n) -{ - uint32 i, pixel_count = a->s->img_x * a->s->img_y; - uint8 *p, *temp_out, *orig = a->out; - - p = (uint8 *) malloc(pixel_count * pal_img_n); - if (p == NULL) return e("outofmem", "Out of memory"); - - // between here and free(out) below, exitting would leak - temp_out = p; - - if (pal_img_n == 3) { - for (i=0; i < pixel_count; ++i) { - int n = orig[i]*4; - p[0] = palette[n ]; - p[1] = palette[n+1]; - p[2] = palette[n+2]; - p += 3; - } - } else { - for (i=0; i < pixel_count; ++i) { - int n = orig[i]*4; - p[0] = palette[n ]; - p[1] = palette[n+1]; - p[2] = palette[n+2]; - p[3] = palette[n+3]; - p += 4; - } - } - free(a->out); - a->out = temp_out; - - STBI_NOTUSED(len); - - return 1; -} - -static int stbi_unpremultiply_on_load = 0; -static int stbi_de_iphone_flag = 0; - -void stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply) -{ - stbi_unpremultiply_on_load = flag_true_if_should_unpremultiply; -} -void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert) -{ - stbi_de_iphone_flag = flag_true_if_should_convert; -} - -static void stbi_de_iphone(png *z) -{ - stbi *s = z->s; - uint32 i, pixel_count = s->img_x * s->img_y; - uint8 *p = z->out; - - if (s->img_out_n == 3) { // convert bgr to rgb - for (i=0; i < pixel_count; ++i) { - uint8 t = p[0]; - p[0] = p[2]; - p[2] = t; - p += 3; - } - } else { - assert(s->img_out_n == 4); - if (stbi_unpremultiply_on_load) { - // convert bgr to rgb and unpremultiply - for (i=0; i < pixel_count; ++i) { - uint8 a = p[3]; - uint8 t = p[0]; - if (a) { - p[0] = p[2] * 255 / a; - p[1] = p[1] * 255 / a; - p[2] = t * 255 / a; - } else { - p[0] = p[2]; - p[2] = t; - } - p += 4; - } - } else { - // convert bgr to rgb - for (i=0; i < pixel_count; ++i) { - uint8 t = p[0]; - p[0] = p[2]; - p[2] = t; - p += 4; - } - } - } -} - -static int parse_png_file(png *z, int scan, int req_comp) -{ - uint8 palette[1024], pal_img_n=0; - uint8 has_trans=0, tc[3]; - uint32 ioff=0, idata_limit=0, i, pal_len=0; - int first=1,k,interlace=0, iphone=0; - stbi *s = z->s; - - z->expanded = NULL; - z->idata = NULL; - z->out = NULL; - - if (!check_png_header(s)) return 0; - - if (scan == SCAN_type) return 1; - - for (;;) { - chunk c = get_chunk_header(s); - switch (c.type) { - case PNG_TYPE('C','g','B','I'): - iphone = stbi_de_iphone_flag; - skip(s, c.length); - break; - case PNG_TYPE('I','H','D','R'): { - int depth,color,comp,filter; - if (!first) return e("multiple IHDR","Corrupt PNG"); - first = 0; - if (c.length != 13) return e("bad IHDR len","Corrupt PNG"); - s->img_x = get32(s); if (s->img_x > (1 << 24)) return e("too large","Very large image (corrupt?)"); - s->img_y = get32(s); if (s->img_y > (1 << 24)) return e("too large","Very large image (corrupt?)"); - depth = get8(s); if (depth != 8) return e("8bit only","PNG not supported: 8-bit only"); - color = get8(s); if (color > 6) return e("bad ctype","Corrupt PNG"); - if (color == 3) pal_img_n = 3; else if (color & 1) return e("bad ctype","Corrupt PNG"); - comp = get8(s); if (comp) return e("bad comp method","Corrupt PNG"); - filter= get8(s); if (filter) return e("bad filter method","Corrupt PNG"); - interlace = get8(s); if (interlace>1) return e("bad interlace method","Corrupt PNG"); - if (!s->img_x || !s->img_y) return e("0-pixel image","Corrupt PNG"); - if (!pal_img_n) { - s->img_n = (color & 2 ? 3 : 1) + (color & 4 ? 1 : 0); - if ((1 << 30) / s->img_x / s->img_n < s->img_y) return e("too large", "Image too large to decode"); - if (scan == SCAN_header) return 1; - } else { - // if paletted, then pal_n is our final components, and - // img_n is # components to decompress/filter. - s->img_n = 1; - if ((1 << 30) / s->img_x / 4 < s->img_y) return e("too large","Corrupt PNG"); - // if SCAN_header, have to scan to see if we have a tRNS - } - break; - } - - case PNG_TYPE('P','L','T','E'): { - if (first) return e("first not IHDR", "Corrupt PNG"); - if (c.length > 256*3) return e("invalid PLTE","Corrupt PNG"); - pal_len = c.length / 3; - if (pal_len * 3 != c.length) return e("invalid PLTE","Corrupt PNG"); - for (i=0; i < pal_len; ++i) { - palette[i*4+0] = get8u(s); - palette[i*4+1] = get8u(s); - palette[i*4+2] = get8u(s); - palette[i*4+3] = 255; - } - break; - } - - case PNG_TYPE('t','R','N','S'): { - if (first) return e("first not IHDR", "Corrupt PNG"); - if (z->idata) return e("tRNS after IDAT","Corrupt PNG"); - if (pal_img_n) { - if (scan == SCAN_header) { s->img_n = 4; return 1; } - if (pal_len == 0) return e("tRNS before PLTE","Corrupt PNG"); - if (c.length > pal_len) return e("bad tRNS len","Corrupt PNG"); - pal_img_n = 4; - for (i=0; i < c.length; ++i) - palette[i*4+3] = get8u(s); - } else { - if (!(s->img_n & 1)) return e("tRNS with alpha","Corrupt PNG"); - if (c.length != (uint32) s->img_n*2) return e("bad tRNS len","Corrupt PNG"); - has_trans = 1; - for (k=0; k < s->img_n; ++k) - tc[k] = (uint8) get16(s); // non 8-bit images will be larger - } - break; - } - - case PNG_TYPE('I','D','A','T'): { - if (first) return e("first not IHDR", "Corrupt PNG"); - if (pal_img_n && !pal_len) return e("no PLTE","Corrupt PNG"); - if (scan == SCAN_header) { s->img_n = pal_img_n; return 1; } - if (ioff + c.length > idata_limit) { - uint8 *p; - if (idata_limit == 0) idata_limit = c.length > 4096 ? c.length : 4096; - while (ioff + c.length > idata_limit) - idata_limit *= 2; - p = (uint8 *) realloc(z->idata, idata_limit); if (p == NULL) return e("outofmem", "Out of memory"); - z->idata = p; - } - if (!getn(s, z->idata+ioff,c.length)) return e("outofdata","Corrupt PNG"); - ioff += c.length; - break; - } - - case PNG_TYPE('I','E','N','D'): { - uint32 raw_len; - if (first) return e("first not IHDR", "Corrupt PNG"); - if (scan != SCAN_load) return 1; - if (z->idata == NULL) return e("no IDAT","Corrupt PNG"); - z->expanded = (uint8 *) stbi_zlib_decode_malloc_guesssize_headerflag((char *) z->idata, ioff, 16384, (int *) &raw_len, !iphone); - if (z->expanded == NULL) return 0; // zlib should set error - free(z->idata); z->idata = NULL; - if ((req_comp == s->img_n+1 && req_comp != 3 && !pal_img_n) || has_trans) - s->img_out_n = s->img_n+1; - else - s->img_out_n = s->img_n; - if (!create_png_image(z, z->expanded, raw_len, s->img_out_n, interlace)) return 0; - if (has_trans) - if (!compute_transparency(z, tc, s->img_out_n)) return 0; - if (iphone && s->img_out_n > 2) - stbi_de_iphone(z); - if (pal_img_n) { - // pal_img_n == 3 or 4 - s->img_n = pal_img_n; // record the actual colors we had - s->img_out_n = pal_img_n; - if (req_comp >= 3) s->img_out_n = req_comp; - if (!expand_palette(z, palette, pal_len, s->img_out_n)) - return 0; - } - free(z->expanded); z->expanded = NULL; - return 1; - } - - default: - // if critical, fail - if (first) return e("first not IHDR", "Corrupt PNG"); - if ((c.type & (1 << 29)) == 0) { - #ifndef STBI_NO_FAILURE_STRINGS - // not threadsafe - static char invalid_chunk[] = "XXXX chunk not known"; - invalid_chunk[0] = (uint8) (c.type >> 24); - invalid_chunk[1] = (uint8) (c.type >> 16); - invalid_chunk[2] = (uint8) (c.type >> 8); - invalid_chunk[3] = (uint8) (c.type >> 0); - #endif - return e(invalid_chunk, "PNG not supported: unknown chunk type"); - } - skip(s, c.length); - break; - } - // end of chunk, read and skip CRC - get32(s); - } -} - -static unsigned char *do_png(png *p, int *x, int *y, int *n, int req_comp) -{ - unsigned char *result=NULL; - if (req_comp < 0 || req_comp > 4) return epuc("bad req_comp", "Internal error"); - if (parse_png_file(p, SCAN_load, req_comp)) { - result = p->out; - p->out = NULL; - if (req_comp && req_comp != p->s->img_out_n) { - result = convert_format(result, p->s->img_out_n, req_comp, p->s->img_x, p->s->img_y); - p->s->img_out_n = req_comp; - if (result == NULL) return result; - } - *x = p->s->img_x; - *y = p->s->img_y; - if (n) *n = p->s->img_n; - } - free(p->out); p->out = NULL; - free(p->expanded); p->expanded = NULL; - free(p->idata); p->idata = NULL; - - return result; -} - -static unsigned char *stbi_png_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - png p; - p.s = s; - return do_png(&p, x,y,comp,req_comp); -} - -static int stbi_png_test(stbi *s) -{ - int r; - r = check_png_header(s); - stbi_rewind(s); - return r; -} - -static int stbi_png_info_raw(png *p, int *x, int *y, int *comp) -{ - if (!parse_png_file(p, SCAN_header, 0)) { - stbi_rewind( p->s ); - return 0; - } - if (x) *x = p->s->img_x; - if (y) *y = p->s->img_y; - if (comp) *comp = p->s->img_n; - return 1; -} - -static int stbi_png_info(stbi *s, int *x, int *y, int *comp) -{ - png p; - p.s = s; - return stbi_png_info_raw(&p, x, y, comp); -} - -// Microsoft/Windows BMP image - -static int bmp_test(stbi *s) -{ - int sz; - if (get8(s) != 'B') return 0; - if (get8(s) != 'M') return 0; - get32le(s); // discard filesize - get16le(s); // discard reserved - get16le(s); // discard reserved - get32le(s); // discard data offset - sz = get32le(s); - if (sz == 12 || sz == 40 || sz == 56 || sz == 108) return 1; - return 0; -} - -static int stbi_bmp_test(stbi *s) -{ - int r = bmp_test(s); - stbi_rewind(s); - return r; -} - - -// returns 0..31 for the highest set bit -static int high_bit(unsigned int z) -{ - int n=0; - if (z == 0) return -1; - if (z >= 0x10000) n += 16, z >>= 16; - if (z >= 0x00100) n += 8, z >>= 8; - if (z >= 0x00010) n += 4, z >>= 4; - if (z >= 0x00004) n += 2, z >>= 2; - if (z >= 0x00002) n += 1, z >>= 1; - return n; -} - -static int bitcount(unsigned int a) -{ - a = (a & 0x55555555) + ((a >> 1) & 0x55555555); // max 2 - a = (a & 0x33333333) + ((a >> 2) & 0x33333333); // max 4 - a = (a + (a >> 4)) & 0x0f0f0f0f; // max 8 per 4, now 8 bits - a = (a + (a >> 8)); // max 16 per 8 bits - a = (a + (a >> 16)); // max 32 per 8 bits - return a & 0xff; -} - -static int shiftsigned(int v, int shift, int bits) -{ - int result; - int z=0; - - if (shift < 0) v <<= -shift; - else v >>= shift; - result = v; - - z = bits; - while (z < 8) { - result += v >> z; - z += bits; - } - return result; -} - -static stbi_uc *bmp_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - uint8 *out; - unsigned int mr=0,mg=0,mb=0,ma=0, fake_a=0; - stbi_uc pal[256][4]; - int psize=0,i,j,compress=0,width; - int bpp, flip_vertically, pad, target, offset, hsz; - if (get8(s) != 'B' || get8(s) != 'M') return epuc("not BMP", "Corrupt BMP"); - get32le(s); // discard filesize - get16le(s); // discard reserved - get16le(s); // discard reserved - offset = get32le(s); - hsz = get32le(s); - if (hsz != 12 && hsz != 40 && hsz != 56 && hsz != 108) return epuc("unknown BMP", "BMP type not supported: unknown"); - if (hsz == 12) { - s->img_x = get16le(s); - s->img_y = get16le(s); - } else { - s->img_x = get32le(s); - s->img_y = get32le(s); - } - if (get16le(s) != 1) return epuc("bad BMP", "bad BMP"); - bpp = get16le(s); - if (bpp == 1) return epuc("monochrome", "BMP type not supported: 1-bit"); - flip_vertically = ((int) s->img_y) > 0; - s->img_y = abs((int) s->img_y); - if (hsz == 12) { - if (bpp < 24) - psize = (offset - 14 - 24) / 3; - } else { - compress = get32le(s); - if (compress == 1 || compress == 2) return epuc("BMP RLE", "BMP type not supported: RLE"); - get32le(s); // discard sizeof - get32le(s); // discard hres - get32le(s); // discard vres - get32le(s); // discard colorsused - get32le(s); // discard max important - if (hsz == 40 || hsz == 56) { - if (hsz == 56) { - get32le(s); - get32le(s); - get32le(s); - get32le(s); - } - if (bpp == 16 || bpp == 32) { - mr = mg = mb = 0; - if (compress == 0) { - if (bpp == 32) { - mr = 0xffu << 16; - mg = 0xffu << 8; - mb = 0xffu << 0; - ma = 0xffu << 24; - fake_a = 1; // @TODO: check for cases like alpha value is all 0 and switch it to 255 - } else { - mr = 31u << 10; - mg = 31u << 5; - mb = 31u << 0; - } - } else if (compress == 3) { - mr = get32le(s); - mg = get32le(s); - mb = get32le(s); - // not documented, but generated by photoshop and handled by mspaint - if (mr == mg && mg == mb) { - // ?!?!? - return epuc("bad BMP", "bad BMP"); - } - } else - return epuc("bad BMP", "bad BMP"); - } - } else { - assert(hsz == 108); - mr = get32le(s); - mg = get32le(s); - mb = get32le(s); - ma = get32le(s); - get32le(s); // discard color space - for (i=0; i < 12; ++i) - get32le(s); // discard color space parameters - } - if (bpp < 16) - psize = (offset - 14 - hsz) >> 2; - } - s->img_n = ma ? 4 : 3; - if (req_comp && req_comp >= 3) // we can directly decode 3 or 4 - target = req_comp; - else - target = s->img_n; // if they want monochrome, we'll post-convert - out = (stbi_uc *) malloc(target * s->img_x * s->img_y); - if (!out) return epuc("outofmem", "Out of memory"); - if (bpp < 16) { - int z=0; - if (psize == 0 || psize > 256) { free(out); return epuc("invalid", "Corrupt BMP"); } - for (i=0; i < psize; ++i) { - pal[i][2] = get8u(s); - pal[i][1] = get8u(s); - pal[i][0] = get8u(s); - if (hsz != 12) get8(s); - pal[i][3] = 255; - } - skip(s, offset - 14 - hsz - psize * (hsz == 12 ? 3 : 4)); - if (bpp == 4) width = (s->img_x + 1) >> 1; - else if (bpp == 8) width = s->img_x; - else { free(out); return epuc("bad bpp", "Corrupt BMP"); } - pad = (-width)&3; - for (j=0; j < (int) s->img_y; ++j) { - for (i=0; i < (int) s->img_x; i += 2) { - int v=get8(s),v2=0; - if (bpp == 4) { - v2 = v & 15; - v >>= 4; - } - out[z++] = pal[v][0]; - out[z++] = pal[v][1]; - out[z++] = pal[v][2]; - if (target == 4) out[z++] = 255; - if (i+1 == (int) s->img_x) break; - v = (bpp == 8) ? get8(s) : v2; - out[z++] = pal[v][0]; - out[z++] = pal[v][1]; - out[z++] = pal[v][2]; - if (target == 4) out[z++] = 255; - } - skip(s, pad); - } - } else { - int rshift=0,gshift=0,bshift=0,ashift=0,rcount=0,gcount=0,bcount=0,acount=0; - int z = 0; - int easy=0; - skip(s, offset - 14 - hsz); - if (bpp == 24) width = 3 * s->img_x; - else if (bpp == 16) width = 2*s->img_x; - else /* bpp = 32 and pad = 0 */ width=0; - pad = (-width) & 3; - if (bpp == 24) { - easy = 1; - } else if (bpp == 32) { - if (mb == 0xff && mg == 0xff00 && mr == 0x00ff0000 && ma == 0xff000000) - easy = 2; - } - if (!easy) { - if (!mr || !mg || !mb) { free(out); return epuc("bad masks", "Corrupt BMP"); } - // right shift amt to put high bit in position #7 - rshift = high_bit(mr)-7; rcount = bitcount(mr); - gshift = high_bit(mg)-7; gcount = bitcount(mr); - bshift = high_bit(mb)-7; bcount = bitcount(mr); - ashift = high_bit(ma)-7; acount = bitcount(mr); - } - for (j=0; j < (int) s->img_y; ++j) { - if (easy) { - for (i=0; i < (int) s->img_x; ++i) { - int a; - out[z+2] = get8u(s); - out[z+1] = get8u(s); - out[z+0] = get8u(s); - z += 3; - a = (easy == 2 ? get8(s) : 255); - if (target == 4) out[z++] = (uint8) a; - } - } else { - for (i=0; i < (int) s->img_x; ++i) { - uint32 v = (bpp == 16 ? get16le(s) : get32le(s)); - int a; - out[z++] = (uint8) shiftsigned(v & mr, rshift, rcount); - out[z++] = (uint8) shiftsigned(v & mg, gshift, gcount); - out[z++] = (uint8) shiftsigned(v & mb, bshift, bcount); - a = (ma ? shiftsigned(v & ma, ashift, acount) : 255); - if (target == 4) out[z++] = (uint8) a; - } - } - skip(s, pad); - } - } - if (flip_vertically) { - stbi_uc t; - for (j=0; j < (int) s->img_y>>1; ++j) { - stbi_uc *p1 = out + j *s->img_x*target; - stbi_uc *p2 = out + (s->img_y-1-j)*s->img_x*target; - for (i=0; i < (int) s->img_x*target; ++i) { - t = p1[i], p1[i] = p2[i], p2[i] = t; - } - } - } - - if (req_comp && req_comp != target) { - out = convert_format(out, target, req_comp, s->img_x, s->img_y); - if (out == NULL) return out; // convert_format frees input on failure - } - - *x = s->img_x; - *y = s->img_y; - if (comp) *comp = s->img_n; - return out; -} - -static stbi_uc *stbi_bmp_load(stbi *s,int *x, int *y, int *comp, int req_comp) -{ - return bmp_load(s, x,y,comp,req_comp); -} - - -// Targa Truevision - TGA -// by Jonathan Dummer - -static int tga_info(stbi *s, int *x, int *y, int *comp) -{ - int tga_w, tga_h, tga_comp; - int sz; - get8u(s); // discard Offset - sz = get8u(s); // color type - if( sz > 1 ) { - stbi_rewind(s); - return 0; // only RGB or indexed allowed - } - sz = get8u(s); // image type - // only RGB or grey allowed, +/- RLE - if ((sz != 1) && (sz != 2) && (sz != 3) && (sz != 9) && (sz != 10) && (sz != 11)) return 0; - skip(s,9); - tga_w = get16le(s); - if( tga_w < 1 ) { - stbi_rewind(s); - return 0; // test width - } - tga_h = get16le(s); - if( tga_h < 1 ) { - stbi_rewind(s); - return 0; // test height - } - sz = get8(s); // bits per pixel - // only RGB or RGBA or grey allowed - if ((sz != 8) && (sz != 16) && (sz != 24) && (sz != 32)) { - stbi_rewind(s); - return 0; - } - tga_comp = sz; - if (x) *x = tga_w; - if (y) *y = tga_h; - if (comp) *comp = tga_comp / 8; - return 1; // seems to have passed everything -} - -int stbi_tga_info(stbi *s, int *x, int *y, int *comp) -{ - return tga_info(s, x, y, comp); -} - -static int tga_test(stbi *s) -{ - int sz; - get8u(s); // discard Offset - sz = get8u(s); // color type - if ( sz > 1 ) return 0; // only RGB or indexed allowed - sz = get8u(s); // image type - if ( (sz != 1) && (sz != 2) && (sz != 3) && (sz != 9) && (sz != 10) && (sz != 11) ) return 0; // only RGB or grey allowed, +/- RLE - get16(s); // discard palette start - get16(s); // discard palette length - get8(s); // discard bits per palette color entry - get16(s); // discard x origin - get16(s); // discard y origin - if ( get16(s) < 1 ) return 0; // test width - if ( get16(s) < 1 ) return 0; // test height - sz = get8(s); // bits per pixel - if ( (sz != 8) && (sz != 16) && (sz != 24) && (sz != 32) ) return 0; // only RGB or RGBA or grey allowed - return 1; // seems to have passed everything -} - -static int stbi_tga_test(stbi *s) -{ - int res = tga_test(s); - stbi_rewind(s); - return res; -} - -static stbi_uc *tga_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - // read in the TGA header stuff - int tga_offset = get8u(s); - int tga_indexed = get8u(s); - int tga_image_type = get8u(s); - int tga_is_RLE = 0; - int tga_palette_start = get16le(s); - int tga_palette_len = get16le(s); - int tga_palette_bits = get8u(s); - int tga_x_origin = get16le(s); - int tga_y_origin = get16le(s); - int tga_width = get16le(s); - int tga_height = get16le(s); - int tga_bits_per_pixel = get8u(s); - int tga_inverted = get8u(s); - // image data - unsigned char *tga_data; - unsigned char *tga_palette = NULL; - int i, j; - unsigned char raw_data[4]; - unsigned char trans_data[4]; - int RLE_count = 0; - int RLE_repeating = 0; - int read_next_pixel = 1; - - // do a tiny bit of precessing - if ( tga_image_type >= 8 ) - { - tga_image_type -= 8; - tga_is_RLE = 1; - } - /* int tga_alpha_bits = tga_inverted & 15; */ - tga_inverted = 1 - ((tga_inverted >> 5) & 1); - - // error check - if ( //(tga_indexed) || - (tga_width < 1) || (tga_height < 1) || - (tga_image_type < 1) || (tga_image_type > 3) || - ((tga_bits_per_pixel != 8) && (tga_bits_per_pixel != 16) && - (tga_bits_per_pixel != 24) && (tga_bits_per_pixel != 32)) - ) - { - return NULL; // we don't report this as a bad TGA because we don't even know if it's TGA - } - - // If I'm paletted, then I'll use the number of bits from the palette - if ( tga_indexed ) - { - tga_bits_per_pixel = tga_palette_bits; - } - - // tga info - *x = tga_width; - *y = tga_height; - if ( (req_comp < 1) || (req_comp > 4) ) - { - // just use whatever the file was - req_comp = tga_bits_per_pixel / 8; - *comp = req_comp; - } else - { - // force a new number of components - *comp = tga_bits_per_pixel/8; - } - tga_data = (unsigned char*)malloc( tga_width * tga_height * req_comp ); - if (!tga_data) return epuc("outofmem", "Out of memory"); - - // skip to the data's starting position (offset usually = 0) - skip(s, tga_offset ); - // do I need to load a palette? - if ( tga_indexed ) - { - // any data to skip? (offset usually = 0) - skip(s, tga_palette_start ); - // load the palette - tga_palette = (unsigned char*)malloc( tga_palette_len * tga_palette_bits / 8 ); - if (!tga_palette) return epuc("outofmem", "Out of memory"); - if (!getn(s, tga_palette, tga_palette_len * tga_palette_bits / 8 )) { - free(tga_data); - free(tga_palette); - return epuc("bad palette", "Corrupt TGA"); - } - } - // load the data - trans_data[0] = trans_data[1] = trans_data[2] = trans_data[3] = 0; - for (i=0; i < tga_width * tga_height; ++i) - { - // if I'm in RLE mode, do I need to get a RLE chunk? - if ( tga_is_RLE ) - { - if ( RLE_count == 0 ) - { - // yep, get the next byte as a RLE command - int RLE_cmd = get8u(s); - RLE_count = 1 + (RLE_cmd & 127); - RLE_repeating = RLE_cmd >> 7; - read_next_pixel = 1; - } else if ( !RLE_repeating ) - { - read_next_pixel = 1; - } - } else - { - read_next_pixel = 1; - } - // OK, if I need to read a pixel, do it now - if ( read_next_pixel ) - { - // load however much data we did have - if ( tga_indexed ) - { - // read in 1 byte, then perform the lookup - int pal_idx = get8u(s); - if ( pal_idx >= tga_palette_len ) - { - // invalid index - pal_idx = 0; - } - pal_idx *= tga_bits_per_pixel / 8; - for (j = 0; j*8 < tga_bits_per_pixel; ++j) - { - raw_data[j] = tga_palette[pal_idx+j]; - } - } else - { - // read in the data raw - for (j = 0; j*8 < tga_bits_per_pixel; ++j) - { - raw_data[j] = get8u(s); - } - } - // convert raw to the intermediate format - switch (tga_bits_per_pixel) - { - case 8: - // Luminous => RGBA - trans_data[0] = raw_data[0]; - trans_data[1] = raw_data[0]; - trans_data[2] = raw_data[0]; - trans_data[3] = 255; - break; - case 16: - // Luminous,Alpha => RGBA - trans_data[0] = raw_data[0]; - trans_data[1] = raw_data[0]; - trans_data[2] = raw_data[0]; - trans_data[3] = raw_data[1]; - break; - case 24: - // BGR => RGBA - trans_data[0] = raw_data[2]; - trans_data[1] = raw_data[1]; - trans_data[2] = raw_data[0]; - trans_data[3] = 255; - break; - case 32: - // BGRA => RGBA - trans_data[0] = raw_data[2]; - trans_data[1] = raw_data[1]; - trans_data[2] = raw_data[0]; - trans_data[3] = raw_data[3]; - break; - } - // clear the reading flag for the next pixel - read_next_pixel = 0; - } // end of reading a pixel - // convert to final format - switch (req_comp) - { - case 1: - // RGBA => Luminance - tga_data[i*req_comp+0] = compute_y(trans_data[0],trans_data[1],trans_data[2]); - break; - case 2: - // RGBA => Luminance,Alpha - tga_data[i*req_comp+0] = compute_y(trans_data[0],trans_data[1],trans_data[2]); - tga_data[i*req_comp+1] = trans_data[3]; - break; - case 3: - // RGBA => RGB - tga_data[i*req_comp+0] = trans_data[0]; - tga_data[i*req_comp+1] = trans_data[1]; - tga_data[i*req_comp+2] = trans_data[2]; - break; - case 4: - // RGBA => RGBA - tga_data[i*req_comp+0] = trans_data[0]; - tga_data[i*req_comp+1] = trans_data[1]; - tga_data[i*req_comp+2] = trans_data[2]; - tga_data[i*req_comp+3] = trans_data[3]; - break; - } - // in case we're in RLE mode, keep counting down - --RLE_count; - } - // do I need to invert the image? - if ( tga_inverted ) - { - for (j = 0; j*2 < tga_height; ++j) - { - int index1 = j * tga_width * req_comp; - int index2 = (tga_height - 1 - j) * tga_width * req_comp; - for (i = tga_width * req_comp; i > 0; --i) - { - unsigned char temp = tga_data[index1]; - tga_data[index1] = tga_data[index2]; - tga_data[index2] = temp; - ++index1; - ++index2; - } - } - } - // clear my palette, if I had one - if ( tga_palette != NULL ) - { - free( tga_palette ); - } - // the things I do to get rid of an error message, and yet keep - // Microsoft's C compilers happy... [8^( - tga_palette_start = tga_palette_len = tga_palette_bits = - tga_x_origin = tga_y_origin = 0; - // OK, done - return tga_data; -} - -static stbi_uc *stbi_tga_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return tga_load(s,x,y,comp,req_comp); -} - - -// ************************************************************************************************* -// Photoshop PSD loader -- PD by Thatcher Ulrich, integration by Nicolas Schulz, tweaked by STB - -static int psd_test(stbi *s) -{ - if (get32(s) != 0x38425053) return 0; // "8BPS" - else return 1; -} - -static int stbi_psd_test(stbi *s) -{ - int r = psd_test(s); - stbi_rewind(s); - return r; -} - -static stbi_uc *psd_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - int pixelCount; - int channelCount, compression; - int channel, i, count, len; - int w,h; - uint8 *out; - - // Check identifier - if (get32(s) != 0x38425053) // "8BPS" - return epuc("not PSD", "Corrupt PSD image"); - - // Check file type version. - if (get16(s) != 1) - return epuc("wrong version", "Unsupported version of PSD image"); - - // Skip 6 reserved bytes. - skip(s, 6 ); - - // Read the number of channels (R, G, B, A, etc). - channelCount = get16(s); - if (channelCount < 0 || channelCount > 16) - return epuc("wrong channel count", "Unsupported number of channels in PSD image"); - - // Read the rows and columns of the image. - h = get32(s); - w = get32(s); - - // Make sure the depth is 8 bits. - if (get16(s) != 8) - return epuc("unsupported bit depth", "PSD bit depth is not 8 bit"); - - // Make sure the color mode is RGB. - // Valid options are: - // 0: Bitmap - // 1: Grayscale - // 2: Indexed color - // 3: RGB color - // 4: CMYK color - // 7: Multichannel - // 8: Duotone - // 9: Lab color - if (get16(s) != 3) - return epuc("wrong color format", "PSD is not in RGB color format"); - - // Skip the Mode Data. (It's the palette for indexed color; other info for other modes.) - skip(s,get32(s) ); - - // Skip the image resources. (resolution, pen tool paths, etc) - skip(s, get32(s) ); - - // Skip the reserved data. - skip(s, get32(s) ); - - // Find out if the data is compressed. - // Known values: - // 0: no compression - // 1: RLE compressed - compression = get16(s); - if (compression > 1) - return epuc("bad compression", "PSD has an unknown compression format"); - - // Create the destination image. - out = (stbi_uc *) malloc(4 * w*h); - if (!out) return epuc("outofmem", "Out of memory"); - pixelCount = w*h; - - // Initialize the data to zero. - //memset( out, 0, pixelCount * 4 ); - - // Finally, the image data. - if (compression) { - // RLE as used by .PSD and .TIFF - // Loop until you get the number of unpacked bytes you are expecting: - // Read the next source byte into n. - // If n is between 0 and 127 inclusive, copy the next n+1 bytes literally. - // Else if n is between -127 and -1 inclusive, copy the next byte -n+1 times. - // Else if n is 128, noop. - // Endloop - - // The RLE-compressed data is preceeded by a 2-byte data count for each row in the data, - // which we're going to just skip. - skip(s, h * channelCount * 2 ); - - // Read the RLE data by channel. - for (channel = 0; channel < 4; channel++) { - uint8 *p; - - p = out+channel; - if (channel >= channelCount) { - // Fill this channel with default data. - for (i = 0; i < pixelCount; i++) *p = (channel == 3 ? 255 : 0), p += 4; - } else { - // Read the RLE data. - count = 0; - while (count < pixelCount) { - len = get8(s); - if (len == 128) { - // No-op. - } else if (len < 128) { - // Copy next len+1 bytes literally. - len++; - count += len; - while (len) { - *p = get8u(s); - p += 4; - len--; - } - } else if (len > 128) { - uint8 val; - // Next -len+1 bytes in the dest are replicated from next source byte. - // (Interpret len as a negative 8-bit int.) - len ^= 0x0FF; - len += 2; - val = get8u(s); - count += len; - while (len) { - *p = val; - p += 4; - len--; - } - } - } - } - } - - } else { - // We're at the raw image data. It's each channel in order (Red, Green, Blue, Alpha, ...) - // where each channel consists of an 8-bit value for each pixel in the image. - - // Read the data by channel. - for (channel = 0; channel < 4; channel++) { - uint8 *p; - - p = out + channel; - if (channel > channelCount) { - // Fill this channel with default data. - for (i = 0; i < pixelCount; i++) *p = channel == 3 ? 255 : 0, p += 4; - } else { - // Read the data. - for (i = 0; i < pixelCount; i++) - *p = get8u(s), p += 4; - } - } - } - - if (req_comp && req_comp != 4) { - out = convert_format(out, 4, req_comp, w, h); - if (out == NULL) return out; // convert_format frees input on failure - } - - if (comp) *comp = channelCount; - *y = h; - *x = w; - - return out; -} - -static stbi_uc *stbi_psd_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return psd_load(s,x,y,comp,req_comp); -} - -// ************************************************************************************************* -// Softimage PIC loader -// by Tom Seddon -// -// See http://softimage.wiki.softimage.com/index.php/INFO:_PIC_file_format -// See http://ozviz.wasp.uwa.edu.au/~pbourke/dataformats/softimagepic/ - -static int pic_is4(stbi *s,const char *str) -{ - int i; - for (i=0; i<4; ++i) - if (get8(s) != (stbi_uc)str[i]) - return 0; - - return 1; -} - -static int pic_test(stbi *s) -{ - int i; - - if (!pic_is4(s,"\x53\x80\xF6\x34")) - return 0; - - for(i=0;i<84;++i) - get8(s); - - if (!pic_is4(s,"PICT")) - return 0; - - return 1; -} - -typedef struct -{ - stbi_uc size,type,channel; -} pic_packet_t; - -static stbi_uc *pic_readval(stbi *s, int channel, stbi_uc *dest) -{ - int mask=0x80, i; - - for (i=0; i<4; ++i, mask>>=1) { - if (channel & mask) { - if (at_eof(s)) return epuc("bad file","PIC file too short"); - dest[i]=get8u(s); - } - } - - return dest; -} - -static void pic_copyval(int channel,stbi_uc *dest,const stbi_uc *src) -{ - int mask=0x80,i; - - for (i=0;i<4; ++i, mask>>=1) - if (channel&mask) - dest[i]=src[i]; -} - -static stbi_uc *pic_load2(stbi *s,int width,int height,int *comp, stbi_uc *result) -{ - int act_comp=0,num_packets=0,y,chained; - pic_packet_t packets[10]; - - // this will (should...) cater for even some bizarre stuff like having data - // for the same channel in multiple packets. - do { - pic_packet_t *packet; - - if (num_packets==sizeof(packets)/sizeof(packets[0])) - return epuc("bad format","too many packets"); - - packet = &packets[num_packets++]; - - chained = get8(s); - packet->size = get8u(s); - packet->type = get8u(s); - packet->channel = get8u(s); - - act_comp |= packet->channel; - - if (at_eof(s)) return epuc("bad file","file too short (reading packets)"); - if (packet->size != 8) return epuc("bad format","packet isn't 8bpp"); - } while (chained); - - *comp = (act_comp & 0x10 ? 4 : 3); // has alpha channel? - - for(y=0; ytype) { - default: - return epuc("bad format","packet has bad compression type"); - - case 0: {//uncompressed - int x; - - for(x=0;xchannel,dest)) - return 0; - break; - } - - case 1://Pure RLE - { - int left=width, i; - - while (left>0) { - stbi_uc count,value[4]; - - count=get8u(s); - if (at_eof(s)) return epuc("bad file","file too short (pure read count)"); - - if (count > left) - count = (uint8) left; - - if (!pic_readval(s,packet->channel,value)) return 0; - - for(i=0; ichannel,dest,value); - left -= count; - } - } - break; - - case 2: {//Mixed RLE - int left=width; - while (left>0) { - int count = get8(s), i; - if (at_eof(s)) return epuc("bad file","file too short (mixed read count)"); - - if (count >= 128) { // Repeated - stbi_uc value[4]; - int i; - - if (count==128) - count = get16(s); - else - count -= 127; - if (count > left) - return epuc("bad file","scanline overrun"); - - if (!pic_readval(s,packet->channel,value)) - return 0; - - for(i=0;ichannel,dest,value); - } else { // Raw - ++count; - if (count>left) return epuc("bad file","scanline overrun"); - - for(i=0;ichannel,dest)) - return 0; - } - left-=count; - } - break; - } - } - } - } - - return result; -} - -static stbi_uc *pic_load(stbi *s,int *px,int *py,int *comp,int req_comp) -{ - stbi_uc *result; - int i, x,y; - - for (i=0; i<92; ++i) - get8(s); - - x = get16(s); - y = get16(s); - if (at_eof(s)) return epuc("bad file","file too short (pic header)"); - if ((1 << 28) / x < y) return epuc("too large", "Image too large to decode"); - - get32(s); //skip `ratio' - get16(s); //skip `fields' - get16(s); //skip `pad' - - // intermediate buffer is RGBA - result = (stbi_uc *) malloc(x*y*4); - memset(result, 0xff, x*y*4); - - if (!pic_load2(s,x,y,comp, result)) { - free(result); - result=0; - } - *px = x; - *py = y; - if (req_comp == 0) req_comp = *comp; - result=convert_format(result,4,req_comp,x,y); - - return result; -} - -static int stbi_pic_test(stbi *s) -{ - int r = pic_test(s); - stbi_rewind(s); - return r; -} - -static stbi_uc *stbi_pic_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return pic_load(s,x,y,comp,req_comp); -} - -// ************************************************************************************************* -// GIF loader -- public domain by Jean-Marc Lienher -- simplified/shrunk by stb -typedef struct stbi_gif_lzw_struct { - int16 prefix; - uint8 first; - uint8 suffix; -} stbi_gif_lzw; - -typedef struct stbi_gif_struct -{ - int w,h; - stbi_uc *out; // output buffer (always 4 components) - int flags, bgindex, ratio, transparent, eflags; - uint8 pal[256][4]; - uint8 lpal[256][4]; - stbi_gif_lzw codes[4096]; - uint8 *color_table; - int parse, step; - int lflags; - int start_x, start_y; - int max_x, max_y; - int cur_x, cur_y; - int line_size; -} stbi_gif; - -static int gif_test(stbi *s) -{ - int sz; - if (get8(s) != 'G' || get8(s) != 'I' || get8(s) != 'F' || get8(s) != '8') return 0; - sz = get8(s); - if (sz != '9' && sz != '7') return 0; - if (get8(s) != 'a') return 0; - return 1; -} - -static int stbi_gif_test(stbi *s) -{ - int r = gif_test(s); - stbi_rewind(s); - return r; -} - -static void stbi_gif_parse_colortable(stbi *s, uint8 pal[256][4], int num_entries, int transp) -{ - int i; - for (i=0; i < num_entries; ++i) { - pal[i][2] = get8u(s); - pal[i][1] = get8u(s); - pal[i][0] = get8u(s); - pal[i][3] = transp ? 0 : 255; - } -} - -static int stbi_gif_header(stbi *s, stbi_gif *g, int *comp, int is_info) -{ - uint8 version; - if (get8(s) != 'G' || get8(s) != 'I' || get8(s) != 'F' || get8(s) != '8') - return e("not GIF", "Corrupt GIF"); - - version = get8u(s); - if (version != '7' && version != '9') return e("not GIF", "Corrupt GIF"); - if (get8(s) != 'a') return e("not GIF", "Corrupt GIF"); - - failure_reason = ""; - g->w = get16le(s); - g->h = get16le(s); - g->flags = get8(s); - g->bgindex = get8(s); - g->ratio = get8(s); - g->transparent = -1; - - if (comp != 0) *comp = 4; // can't actually tell whether it's 3 or 4 until we parse the comments - - if (is_info) return 1; - - if (g->flags & 0x80) - stbi_gif_parse_colortable(s,g->pal, 2 << (g->flags & 7), -1); - - return 1; -} - -static int stbi_gif_info_raw(stbi *s, int *x, int *y, int *comp) -{ - stbi_gif g; - if (!stbi_gif_header(s, &g, comp, 1)) { - stbi_rewind( s ); - return 0; - } - if (x) *x = g.w; - if (y) *y = g.h; - return 1; -} - -static void stbi_out_gif_code(stbi_gif *g, uint16 code) -{ - uint8 *p, *c; - - // recurse to decode the prefixes, since the linked-list is backwards, - // and working backwards through an interleaved image would be nasty - if (g->codes[code].prefix >= 0) - stbi_out_gif_code(g, g->codes[code].prefix); - - if (g->cur_y >= g->max_y) return; - - p = &g->out[g->cur_x + g->cur_y]; - c = &g->color_table[g->codes[code].suffix * 4]; - - if (c[3] >= 128) { - p[0] = c[2]; - p[1] = c[1]; - p[2] = c[0]; - p[3] = c[3]; - } - g->cur_x += 4; - - if (g->cur_x >= g->max_x) { - g->cur_x = g->start_x; - g->cur_y += g->step; - - while (g->cur_y >= g->max_y && g->parse > 0) { - g->step = (1 << g->parse) * g->line_size; - g->cur_y = g->start_y + (g->step >> 1); - --g->parse; - } - } -} - -static uint8 *stbi_process_gif_raster(stbi *s, stbi_gif *g) -{ - uint8 lzw_cs; - int32 len, code; - uint32 first; - int32 codesize, codemask, avail, oldcode, bits, valid_bits, clear; - stbi_gif_lzw *p; - - lzw_cs = get8u(s); - clear = 1 << lzw_cs; - first = 1; - codesize = lzw_cs + 1; - codemask = (1 << codesize) - 1; - bits = 0; - valid_bits = 0; - for (code = 0; code < clear; code++) { - g->codes[code].prefix = -1; - g->codes[code].first = (uint8) code; - g->codes[code].suffix = (uint8) code; - } - - // support no starting clear code - avail = clear+2; - oldcode = -1; - - len = 0; - for(;;) { - if (valid_bits < codesize) { - if (len == 0) { - len = get8(s); // start new block - if (len == 0) - return g->out; - } - --len; - bits |= (int32) get8(s) << valid_bits; - valid_bits += 8; - } else { - int32 code = bits & codemask; - bits >>= codesize; - valid_bits -= codesize; - // @OPTIMIZE: is there some way we can accelerate the non-clear path? - if (code == clear) { // clear code - codesize = lzw_cs + 1; - codemask = (1 << codesize) - 1; - avail = clear + 2; - oldcode = -1; - first = 0; - } else if (code == clear + 1) { // end of stream code - skip(s, len); - while ((len = get8(s)) > 0) - skip(s,len); - return g->out; - } else if (code <= avail) { - if (first) return epuc("no clear code", "Corrupt GIF"); - - if (oldcode >= 0) { - p = &g->codes[avail++]; - if (avail > 4096) return epuc("too many codes", "Corrupt GIF"); - p->prefix = (int16) oldcode; - p->first = g->codes[oldcode].first; - p->suffix = (code == avail) ? p->first : g->codes[code].first; - } else if (code == avail) - return epuc("illegal code in raster", "Corrupt GIF"); - - stbi_out_gif_code(g, (uint16) code); - - if ((avail & codemask) == 0 && avail <= 0x0FFF) { - codesize++; - codemask = (1 << codesize) - 1; - } - - oldcode = code; - } else { - return epuc("illegal code in raster", "Corrupt GIF"); - } - } - } -} - -static void stbi_fill_gif_background(stbi_gif *g) -{ - int i; - uint8 *c = g->pal[g->bgindex]; - // @OPTIMIZE: write a dword at a time - for (i = 0; i < g->w * g->h * 4; i += 4) { - uint8 *p = &g->out[i]; - p[0] = c[2]; - p[1] = c[1]; - p[2] = c[0]; - p[3] = c[3]; - } -} - -// this function is designed to support animated gifs, although stb_image doesn't support it -static uint8 *stbi_gif_load_next(stbi *s, stbi_gif *g, int *comp, int req_comp) -{ - int i; - uint8 *old_out = 0; - - if (g->out == 0) { - if (!stbi_gif_header(s, g, comp,0)) return 0; // failure_reason set by stbi_gif_header - g->out = (uint8 *) malloc(4 * g->w * g->h); - if (g->out == 0) return epuc("outofmem", "Out of memory"); - stbi_fill_gif_background(g); - } else { - // animated-gif-only path - if (((g->eflags & 0x1C) >> 2) == 3) { - old_out = g->out; - g->out = (uint8 *) malloc(4 * g->w * g->h); - if (g->out == 0) return epuc("outofmem", "Out of memory"); - memcpy(g->out, old_out, g->w*g->h*4); - } - } - - for (;;) { - switch (get8(s)) { - case 0x2C: /* Image Descriptor */ - { - int32 x, y, w, h; - uint8 *o; - - x = get16le(s); - y = get16le(s); - w = get16le(s); - h = get16le(s); - if (((x + w) > (g->w)) || ((y + h) > (g->h))) - return epuc("bad Image Descriptor", "Corrupt GIF"); - - g->line_size = g->w * 4; - g->start_x = x * 4; - g->start_y = y * g->line_size; - g->max_x = g->start_x + w * 4; - g->max_y = g->start_y + h * g->line_size; - g->cur_x = g->start_x; - g->cur_y = g->start_y; - - g->lflags = get8(s); - - if (g->lflags & 0x40) { - g->step = 8 * g->line_size; // first interlaced spacing - g->parse = 3; - } else { - g->step = g->line_size; - g->parse = 0; - } - - if (g->lflags & 0x80) { - stbi_gif_parse_colortable(s,g->lpal, 2 << (g->lflags & 7), g->eflags & 0x01 ? g->transparent : -1); - g->color_table = (uint8 *) g->lpal; - } else if (g->flags & 0x80) { - for (i=0; i < 256; ++i) // @OPTIMIZE: reset only the previous transparent - g->pal[i][3] = 255; - if (g->transparent >= 0 && (g->eflags & 0x01)) - g->pal[g->transparent][3] = 0; - g->color_table = (uint8 *) g->pal; - } else - return epuc("missing color table", "Corrupt GIF"); - - o = stbi_process_gif_raster(s, g); - if (o == NULL) return NULL; - - if (req_comp && req_comp != 4) - o = convert_format(o, 4, req_comp, g->w, g->h); - return o; - } - - case 0x21: // Comment Extension. - { - int len; - if (get8(s) == 0xF9) { // Graphic Control Extension. - len = get8(s); - if (len == 4) { - g->eflags = get8(s); - get16le(s); // delay - g->transparent = get8(s); - } else { - skip(s, len); - break; - } - } - while ((len = get8(s)) != 0) - skip(s, len); - break; - } - - case 0x3B: // gif stream termination code - return (uint8 *) 1; - - default: - return epuc("unknown code", "Corrupt GIF"); - } - } -} - -static stbi_uc *stbi_gif_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - uint8 *u = 0; - stbi_gif g={0}; - - u = stbi_gif_load_next(s, &g, comp, req_comp); - if (u == (void *) 1) u = 0; // end of animated gif marker - if (u) { - *x = g.w; - *y = g.h; - } - - return u; -} - -static int stbi_gif_info(stbi *s, int *x, int *y, int *comp) -{ - return stbi_gif_info_raw(s,x,y,comp); -} - - -// ************************************************************************************************* -// Radiance RGBE HDR loader -// originally by Nicolas Schulz -#ifndef STBI_NO_HDR -static int hdr_test(stbi *s) -{ - const char *signature = "#?RADIANCE\n"; - int i; - for (i=0; signature[i]; ++i) - if (get8(s) != signature[i]) - return 0; - return 1; -} - -static int stbi_hdr_test(stbi* s) -{ - int r = hdr_test(s); - stbi_rewind(s); - return r; -} - -#define HDR_BUFLEN 1024 -static char *hdr_gettoken(stbi *z, char *buffer) -{ - int len=0; - char c = '\0'; - - c = (char) get8(z); - - while (!at_eof(z) && c != '\n') { - buffer[len++] = c; - if (len == HDR_BUFLEN-1) { - // flush to end of line - while (!at_eof(z) && get8(z) != '\n') - ; - break; - } - c = (char) get8(z); - } - - buffer[len] = 0; - return buffer; -} - -static void hdr_convert(float *output, stbi_uc *input, int req_comp) -{ - if ( input[3] != 0 ) { - float f1; - // Exponent - f1 = (float) ldexp(1.0f, input[3] - (int)(128 + 8)); - if (req_comp <= 2) - output[0] = (input[0] + input[1] + input[2]) * f1 / 3; - else { - output[0] = input[0] * f1; - output[1] = input[1] * f1; - output[2] = input[2] * f1; - } - if (req_comp == 2) output[1] = 1; - if (req_comp == 4) output[3] = 1; - } else { - switch (req_comp) { - case 4: output[3] = 1; /* fallthrough */ - case 3: output[0] = output[1] = output[2] = 0; - break; - case 2: output[1] = 1; /* fallthrough */ - case 1: output[0] = 0; - break; - } - } -} - -static float *hdr_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - char buffer[HDR_BUFLEN]; - char *token; - int valid = 0; - int width, height; - stbi_uc *scanline; - float *hdr_data; - int len; - unsigned char count, value; - int i, j, k, c1,c2, z; - - - // Check identifier - if (strcmp(hdr_gettoken(s,buffer), "#?RADIANCE") != 0) - return epf("not HDR", "Corrupt HDR image"); - - // Parse header - for(;;) { - token = hdr_gettoken(s,buffer); - if (token[0] == 0) break; - if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) valid = 1; - } - - if (!valid) return epf("unsupported format", "Unsupported HDR format"); - - // Parse width and height - // can't use sscanf() if we're not using stdio! - token = hdr_gettoken(s,buffer); - if (strncmp(token, "-Y ", 3)) return epf("unsupported data layout", "Unsupported HDR format"); - token += 3; - height = strtol(token, &token, 10); - while (*token == ' ') ++token; - if (strncmp(token, "+X ", 3)) return epf("unsupported data layout", "Unsupported HDR format"); - token += 3; - width = strtol(token, NULL, 10); - - *x = width; - *y = height; - - *comp = 3; - if (req_comp == 0) req_comp = 3; - - // Read data - hdr_data = (float *) malloc(height * width * req_comp * sizeof(float)); - - // Load image data - // image data is stored as some number of sca - if ( width < 8 || width >= 32768) { - // Read flat data - for (j=0; j < height; ++j) { - for (i=0; i < width; ++i) { - stbi_uc rgbe[4]; - main_decode_loop: - getn(s, rgbe, 4); - hdr_convert(hdr_data + j * width * req_comp + i * req_comp, rgbe, req_comp); - } - } - } else { - // Read RLE-encoded data - scanline = NULL; - - for (j = 0; j < height; ++j) { - c1 = get8(s); - c2 = get8(s); - len = get8(s); - if (c1 != 2 || c2 != 2 || (len & 0x80)) { - // not run-length encoded, so we have to actually use THIS data as a decoded - // pixel (note this can't be a valid pixel--one of RGB must be >= 128) - uint8 rgbe[4]; - rgbe[0] = (uint8) c1; - rgbe[1] = (uint8) c2; - rgbe[2] = (uint8) len; - rgbe[3] = (uint8) get8u(s); - hdr_convert(hdr_data, rgbe, req_comp); - i = 1; - j = 0; - free(scanline); - goto main_decode_loop; // yes, this makes no sense - } - len <<= 8; - len |= get8(s); - if (len != width) { free(hdr_data); free(scanline); return epf("invalid decoded scanline length", "corrupt HDR"); } - if (scanline == NULL) scanline = (stbi_uc *) malloc(width * 4); - - for (k = 0; k < 4; ++k) { - i = 0; - while (i < width) { - count = get8u(s); - if (count > 128) { - // Run - value = get8u(s); - count -= 128; - for (z = 0; z < count; ++z) - scanline[i++ * 4 + k] = value; - } else { - // Dump - for (z = 0; z < count; ++z) - scanline[i++ * 4 + k] = get8u(s); - } - } - } - for (i=0; i < width; ++i) - hdr_convert(hdr_data+(j*width + i)*req_comp, scanline + i*4, req_comp); - } - free(scanline); - } - - return hdr_data; -} - -static float *stbi_hdr_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return hdr_load(s,x,y,comp,req_comp); -} - -static int stbi_hdr_info(stbi *s, int *x, int *y, int *comp) -{ - char buffer[HDR_BUFLEN]; - char *token; - int valid = 0; - - if (strcmp(hdr_gettoken(s,buffer), "#?RADIANCE") != 0) { - stbi_rewind( s ); - return 0; - } - - for(;;) { - token = hdr_gettoken(s,buffer); - if (token[0] == 0) break; - if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) valid = 1; - } - - if (!valid) { - stbi_rewind( s ); - return 0; - } - token = hdr_gettoken(s,buffer); - if (strncmp(token, "-Y ", 3)) { - stbi_rewind( s ); - return 0; - } - token += 3; - *y = strtol(token, &token, 10); - while (*token == ' ') ++token; - if (strncmp(token, "+X ", 3)) { - stbi_rewind( s ); - return 0; - } - token += 3; - *x = strtol(token, NULL, 10); - *comp = 3; - return 1; -} -#endif // STBI_NO_HDR - -static int stbi_bmp_info(stbi *s, int *x, int *y, int *comp) -{ - int hsz; - if (get8(s) != 'B' || get8(s) != 'M') { - stbi_rewind( s ); - return 0; - } - skip(s,12); - hsz = get32le(s); - if (hsz != 12 && hsz != 40 && hsz != 56 && hsz != 108) { - stbi_rewind( s ); - return 0; - } - if (hsz == 12) { - *x = get16le(s); - *y = get16le(s); - } else { - *x = get32le(s); - *y = get32le(s); - } - if (get16le(s) != 1) { - stbi_rewind( s ); - return 0; - } - *comp = get16le(s) / 8; - return 1; -} - -static int stbi_psd_info(stbi *s, int *x, int *y, int *comp) -{ - int channelCount; - if (get32(s) != 0x38425053) { - stbi_rewind( s ); - return 0; - } - if (get16(s) != 1) { - stbi_rewind( s ); - return 0; - } - skip(s, 6); - channelCount = get16(s); - if (channelCount < 0 || channelCount > 16) { - stbi_rewind( s ); - return 0; - } - *y = get32(s); - *x = get32(s); - if (get16(s) != 8) { - stbi_rewind( s ); - return 0; - } - if (get16(s) != 3) { - stbi_rewind( s ); - return 0; - } - *comp = 4; - return 1; -} - -static int stbi_pic_info(stbi *s, int *x, int *y, int *comp) -{ - int act_comp=0,num_packets=0,chained; - pic_packet_t packets[10]; - - skip(s, 92); - - *x = get16(s); - *y = get16(s); - if (at_eof(s)) return 0; - if ( (*x) != 0 && (1 << 28) / (*x) < (*y)) { - stbi_rewind( s ); - return 0; - } - - skip(s, 8); - - do { - pic_packet_t *packet; - - if (num_packets==sizeof(packets)/sizeof(packets[0])) - return 0; - - packet = &packets[num_packets++]; - chained = get8(s); - packet->size = get8u(s); - packet->type = get8u(s); - packet->channel = get8u(s); - act_comp |= packet->channel; - - if (at_eof(s)) { - stbi_rewind( s ); - return 0; - } - if (packet->size != 8) { - stbi_rewind( s ); - return 0; - } - } while (chained); - - *comp = (act_comp & 0x10 ? 4 : 3); - - return 1; -} - -static int stbi_info_main(stbi *s, int *x, int *y, int *comp) -{ - if (stbi_jpeg_info(s, x, y, comp)) - return 1; - if (stbi_png_info(s, x, y, comp)) - return 1; - if (stbi_gif_info(s, x, y, comp)) - return 1; - if (stbi_bmp_info(s, x, y, comp)) - return 1; - if (stbi_psd_info(s, x, y, comp)) - return 1; - if (stbi_pic_info(s, x, y, comp)) - return 1; - #ifndef STBI_NO_HDR - if (stbi_hdr_info(s, x, y, comp)) - return 1; - #endif - // test tga last because it's a crappy test! - if (stbi_tga_info(s, x, y, comp)) - return 1; - return e("unknown image type", "Image not of any known type, or corrupt"); -} - -#ifndef STBI_NO_STDIO -int stbi_info(char const *filename, int *x, int *y, int *comp) -{ - FILE *f = fopen(filename, "rb"); - int result; - if (!f) return e("can't fopen", "Unable to open file"); - result = stbi_info_from_file(f, x, y, comp); - fclose(f); - return result; -} - -int stbi_info_from_file(FILE *f, int *x, int *y, int *comp) -{ - int r; - stbi s; - long pos = ftell(f); - start_file(&s, f); - r = stbi_info_main(&s,x,y,comp); - fseek(f,pos,SEEK_SET); - return r; -} -#endif // !STBI_NO_STDIO - -int stbi_info_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp) -{ - stbi s; - start_mem(&s,buffer,len); - return stbi_info_main(&s,x,y,comp); -} - -int stbi_info_from_callbacks(stbi_io_callbacks const *c, void *user, int *x, int *y, int *comp) -{ - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) c, user); - return stbi_info_main(&s,x,y,comp); -} - -#endif // STBI_HEADER_FILE_ONLY - -/* - revision history: - 1.33 (2011-07-14) - make stbi_is_hdr work in STBI_NO_HDR (as specified), minor compiler-friendly improvements - 1.32 (2011-07-13) - support for "info" function for all supported filetypes (SpartanJ) - 1.31 (2011-06-20) - a few more leak fixes, bug in PNG handling (SpartanJ) - 1.30 (2011-06-11) - added ability to load files via callbacks to accomidate custom input streams (Ben Wenger) - removed deprecated format-specific test/load functions - removed support for installable file formats (stbi_loader) -- would have been broken for IO callbacks anyway - error cases in bmp and tga give messages and don't leak (Raymond Barbiero, grisha) - fix inefficiency in decoding 32-bit BMP (David Woo) - 1.29 (2010-08-16) - various warning fixes from Aurelien Pocheville - 1.28 (2010-08-01) - fix bug in GIF palette transparency (SpartanJ) - 1.27 (2010-08-01) - cast-to-uint8 to fix warnings - 1.26 (2010-07-24) - fix bug in file buffering for PNG reported by SpartanJ - 1.25 (2010-07-17) - refix trans_data warning (Won Chun) - 1.24 (2010-07-12) - perf improvements reading from files on platforms with lock-heavy fgetc() - minor perf improvements for jpeg - deprecated type-specific functions so we'll get feedback if they're needed - attempt to fix trans_data warning (Won Chun) - 1.23 fixed bug in iPhone support - 1.22 (2010-07-10) - removed image *writing* support - stbi_info support from Jetro Lauha - GIF support from Jean-Marc Lienher - iPhone PNG-extensions from James Brown - warning-fixes from Nicolas Schulz and Janez Zemva (i.e. Janez (U+017D)emva) - 1.21 fix use of 'uint8' in header (reported by jon blow) - 1.20 added support for Softimage PIC, by Tom Seddon - 1.19 bug in interlaced PNG corruption check (found by ryg) - 1.18 2008-08-02 - fix a threading bug (local mutable static) - 1.17 support interlaced PNG - 1.16 major bugfix - convert_format converted one too many pixels - 1.15 initialize some fields for thread safety - 1.14 fix threadsafe conversion bug - header-file-only version (#define STBI_HEADER_FILE_ONLY before including) - 1.13 threadsafe - 1.12 const qualifiers in the API - 1.11 Support installable IDCT, colorspace conversion routines - 1.10 Fixes for 64-bit (don't use "unsigned long") - optimized upsampling by Fabian "ryg" Giesen - 1.09 Fix format-conversion for PSD code (bad global variables!) - 1.08 Thatcher Ulrich's PSD code integrated by Nicolas Schulz - 1.07 attempt to fix C++ warning/errors again - 1.06 attempt to fix C++ warning/errors again - 1.05 fix TGA loading to return correct *comp and use good luminance calc - 1.04 default float alpha is 1, not 255; use 'void *' for stbi_image_free - 1.03 bugfixes to STBI_NO_STDIO, STBI_NO_HDR - 1.02 support for (subset of) HDR files, float interface for preferred access to them - 1.01 fix bug: possible bug in handling right-side up bmps... not sure - fix bug: the stbi_bmp_load() and stbi_tga_load() functions didn't work at all - 1.00 interface to zlib that skips zlib header - 0.99 correct handling of alpha in palette - 0.98 TGA loader by lonesock; dynamically add loaders (untested) - 0.97 jpeg errors on too large a file; also catch another malloc failure - 0.96 fix detection of invalid v value - particleman@mollyrocket forum - 0.95 during header scan, seek to markers in case of padding - 0.94 STBI_NO_STDIO to disable stdio usage; rename all #defines the same - 0.93 handle jpegtran output; verbose errors - 0.92 read 4,8,16,24,32-bit BMP files of several formats - 0.91 output 24-bit Windows 3.0 BMP files - 0.90 fix a few more warnings; bump version number to approach 1.0 - 0.61 bugfixes due to Marc LeBlanc, Christopher Lloyd - 0.60 fix compiling as c++ - 0.59 fix warnings: merge Dave Moore's -Wall fixes - 0.58 fix bug: zlib uncompressed mode len/nlen was wrong endian - 0.57 fix bug: jpg last huffman symbol before marker was >9 bits but less than 16 available - 0.56 fix bug: zlib uncompressed mode len vs. nlen - 0.55 fix bug: restart_interval not initialized to 0 - 0.54 allow NULL for 'int *comp' - 0.53 fix bug in png 3->4; speedup png decoding - 0.52 png handles req_comp=3,4 directly; minor cleanup; jpeg comments - 0.51 obey req_comp requests, 1-component jpegs return as 1-component, - on 'test' only check type, not whether we support this variant - 0.50 first released version -*/ diff --git a/Demos/OpenGL/stb_image.h b/Demos/OpenGL/stb_image.h deleted file mode 100644 index f66bfd12f..000000000 --- a/Demos/OpenGL/stb_image.h +++ /dev/null @@ -1,332 +0,0 @@ -/* stbi-1.33 - public domain JPEG/PNG reader - http://nothings.org/stb_image.c - when you control the images you're loading - no warranty implied; use at your own risk - - QUICK NOTES: - Primarily of interest to game developers and other people who can - avoid problematic images and only need the trivial interface - - JPEG baseline (no JPEG progressive) - PNG 8-bit only - - TGA (not sure what subset, if a subset) - BMP non-1bpp, non-RLE - PSD (composited view only, no extra channels) - - GIF (*comp always reports as 4-channel) - HDR (radiance rgbE format) - PIC (Softimage PIC) - - - decode from memory or through FILE (define STBI_NO_STDIO to remove code) - - decode from arbitrary I/O callbacks - - overridable dequantizing-IDCT, YCbCr-to-RGB conversion (define STBI_SIMD) - - Latest revisions: - 1.33 (2011-07-14) minor fixes suggested by Dave Moore - 1.32 (2011-07-13) info support for all filetypes (SpartanJ) - 1.31 (2011-06-19) a few more leak fixes, bug in PNG handling (SpartanJ) - 1.30 (2011-06-11) added ability to load files via io callbacks (Ben Wenger) - 1.29 (2010-08-16) various warning fixes from Aurelien Pocheville - 1.28 (2010-08-01) fix bug in GIF palette transparency (SpartanJ) - 1.27 (2010-08-01) cast-to-uint8 to fix warnings (Laurent Gomila) - allow trailing 0s at end of image data (Laurent Gomila) - 1.26 (2010-07-24) fix bug in file buffering for PNG reported by SpartanJ - - See end of file for full revision history. - - TODO: - stbi_info support for BMP,PSD,HDR,PIC - - - ============================ Contributors ========================= - - Image formats Optimizations & bugfixes - Sean Barrett (jpeg, png, bmp) Fabian "ryg" Giesen - Nicolas Schulz (hdr, psd) - Jonathan Dummer (tga) Bug fixes & warning fixes - Jean-Marc Lienher (gif) Marc LeBlanc - Tom Seddon (pic) Christpher Lloyd - Thatcher Ulrich (psd) Dave Moore - Won Chun - the Horde3D community - Extensions, features Janez Zemva - Jetro Lauha (stbi_info) Jonathan Blow - James "moose2000" Brown (iPhone PNG) Laurent Gomila - Ben "Disch" Wenger (io callbacks) Aruelien Pocheville - Martin "SpartanJ" Golini Ryamond Barbiero - David Woo - - - If your name should be here but isn't, let Sean know. - -*/ - -#ifndef STBI_INCLUDE_STB_IMAGE_H -#define STBI_INCLUDE_STB_IMAGE_H - -// To get a header file for this, either cut and paste the header, -// or create stb_image.h, #define STBI_HEADER_FILE_ONLY, and -// then include stb_image.c from it. - -//// begin header file //////////////////////////////////////////////////// -// -// Limitations: -// - no jpeg progressive support -// - non-HDR formats support 8-bit samples only (jpeg, png) -// - no delayed line count (jpeg) -- IJG doesn't support either -// - no 1-bit BMP -// - GIF always returns *comp=4 -// -// Basic usage (see HDR discussion below): -// int x,y,n; -// unsigned char *data = stbi_load(filename, &x, &y, &n, 0); -// // ... process data if not NULL ... -// // ... x = width, y = height, n = # 8-bit components per pixel ... -// // ... replace '0' with '1'..'4' to force that many components per pixel -// // ... but 'n' will always be the number that it would have been if you said 0 -// stbi_image_free(data) -// -// Standard parameters: -// int *x -- outputs image width in pixels -// int *y -- outputs image height in pixels -// int *comp -- outputs # of image components in image file -// int req_comp -- if non-zero, # of image components requested in result -// -// The return value from an image loader is an 'unsigned char *' which points -// to the pixel data. The pixel data consists of *y scanlines of *x pixels, -// with each pixel consisting of N interleaved 8-bit components; the first -// pixel pointed to is top-left-most in the image. There is no padding between -// image scanlines or between pixels, regardless of format. The number of -// components N is 'req_comp' if req_comp is non-zero, or *comp otherwise. -// If req_comp is non-zero, *comp has the number of components that _would_ -// have been output otherwise. E.g. if you set req_comp to 4, you will always -// get RGBA output, but you can check *comp to easily see if it's opaque. -// -// An output image with N components has the following components interleaved -// in this order in each pixel: -// -// N=#comp components -// 1 grey -// 2 grey, alpha -// 3 red, green, blue -// 4 red, green, blue, alpha -// -// If image loading fails for any reason, the return value will be NULL, -// and *x, *y, *comp will be unchanged. The function stbi_failure_reason() -// can be queried for an extremely brief, end-user unfriendly explanation -// of why the load failed. Define STBI_NO_FAILURE_STRINGS to avoid -// compiling these strings at all, and STBI_FAILURE_USERMSG to get slightly -// more user-friendly ones. -// -// Paletted PNG, BMP, GIF, and PIC images are automatically depalettized. -// -// =========================================================================== -// -// iPhone PNG support: -// -// By default we convert iphone-formatted PNGs back to RGB; nominally they -// would silently load as BGR, except the existing code should have just -// failed on such iPhone PNGs. But you can disable this conversion by -// by calling stbi_convert_iphone_png_to_rgb(0), in which case -// you will always just get the native iphone "format" through. -// -// Call stbi_set_unpremultiply_on_load(1) as well to force a divide per -// pixel to remove any premultiplied alpha *only* if the image file explicitly -// says there's premultiplied data (currently only happens in iPhone images, -// and only if iPhone convert-to-rgb processing is on). -// -// =========================================================================== -// -// HDR image support (disable by defining STBI_NO_HDR) -// -// stb_image now supports loading HDR images in general, and currently -// the Radiance .HDR file format, although the support is provided -// generically. You can still load any file through the existing interface; -// if you attempt to load an HDR file, it will be automatically remapped to -// LDR, assuming gamma 2.2 and an arbitrary scale factor defaulting to 1; -// both of these constants can be reconfigured through this interface: -// -// stbi_hdr_to_ldr_gamma(2.2f); -// stbi_hdr_to_ldr_scale(1.0f); -// -// (note, do not use _inverse_ constants; stbi_image will invert them -// appropriately). -// -// Additionally, there is a new, parallel interface for loading files as -// (linear) floats to preserve the full dynamic range: -// -// float *data = stbi_loadf(filename, &x, &y, &n, 0); -// -// If you load LDR images through this interface, those images will -// be promoted to floating point values, run through the inverse of -// constants corresponding to the above: -// -// stbi_ldr_to_hdr_scale(1.0f); -// stbi_ldr_to_hdr_gamma(2.2f); -// -// Finally, given a filename (or an open file or memory block--see header -// file for details) containing image data, you can query for the "most -// appropriate" interface to use (that is, whether the image is HDR or -// not), using: -// -// stbi_is_hdr(char *filename); -// -// =========================================================================== -// -// I/O callbacks -// -// I/O callbacks allow you to read from arbitrary sources, like packaged -// files or some other source. Data read from callbacks are processed -// through a small internal buffer (currently 128 bytes) to try to reduce -// overhead. -// -// The three functions you must define are "read" (reads some bytes of data), -// "skip" (skips some bytes of data), "eof" (reports if the stream is at the end). - - -#ifndef STBI_NO_STDIO - -#if defined(_MSC_VER) && _MSC_VER >= 0x1400 -#define _CRT_SECURE_NO_WARNINGS // suppress bogus warnings about fopen() -#endif - -#include -#endif - -#define STBI_VERSION 1 - -enum -{ - STBI_default = 0, // only used for req_comp - - STBI_grey = 1, - STBI_grey_alpha = 2, - STBI_rgb = 3, - STBI_rgb_alpha = 4 -}; - -typedef unsigned char stbi_uc; - -#ifdef __cplusplus -extern "C" { -#endif - -////////////////////////////////////////////////////////////////////////////// -// -// PRIMARY API - works on images of any type -// - -// -// load image by filename, open file, or memory buffer -// - -extern stbi_uc *stbi_load_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp); - -#ifndef STBI_NO_STDIO -extern stbi_uc *stbi_load (char const *filename, int *x, int *y, int *comp, int req_comp); -extern stbi_uc *stbi_load_from_file (FILE *f, int *x, int *y, int *comp, int req_comp); -// for stbi_load_from_file, file pointer is left pointing immediately after image -#endif - -typedef struct -{ - int (*read) (void *user,char *data,int size); // fill 'data' with 'size' bytes. return number of bytes actually read - void (*skip) (void *user,unsigned n); // skip the next 'n' bytes - int (*eof) (void *user); // returns nonzero if we are at end of file/data -} stbi_io_callbacks; - -extern stbi_uc *stbi_load_from_callbacks (stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp); - -#ifndef STBI_NO_HDR - extern float *stbi_loadf_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp); - - #ifndef STBI_NO_STDIO - extern float *stbi_loadf (char const *filename, int *x, int *y, int *comp, int req_comp); - extern float *stbi_loadf_from_file (FILE *f, int *x, int *y, int *comp, int req_comp); - #endif - - extern float *stbi_loadf_from_callbacks (stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp); - - extern void stbi_hdr_to_ldr_gamma(float gamma); - extern void stbi_hdr_to_ldr_scale(float scale); - - extern void stbi_ldr_to_hdr_gamma(float gamma); - extern void stbi_ldr_to_hdr_scale(float scale); -#endif // STBI_NO_HDR - -// stbi_is_hdr is always defined -extern int stbi_is_hdr_from_callbacks(stbi_io_callbacks const *clbk, void *user); -extern int stbi_is_hdr_from_memory(stbi_uc const *buffer, int len); -#ifndef STBI_NO_STDIO -extern int stbi_is_hdr (char const *filename); -extern int stbi_is_hdr_from_file(FILE *f); -#endif // STBI_NO_STDIO - - -// get a VERY brief reason for failure -// NOT THREADSAFE -extern const char *stbi_failure_reason (void); - -// free the loaded image -- this is just free() -extern void stbi_image_free (void *retval_from_stbi_load); - -// get image dimensions & components without fully decoding -extern int stbi_info_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp); -extern int stbi_info_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp); - -#ifndef STBI_NO_STDIO -extern int stbi_info (char const *filename, int *x, int *y, int *comp); -extern int stbi_info_from_file (FILE *f, int *x, int *y, int *comp); - -#endif - - - -// for image formats that explicitly notate that they have premultiplied alpha, -// we just return the colors as stored in the file. set this flag to force -// unpremultiplication. results are undefined if the unpremultiply overflow. -extern void stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply); - -// indicate whether we should process iphone images back to canonical format, -// or just pass them through "as-is" -extern void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert); - - -// ZLIB client - used by PNG, available for other purposes - -extern char *stbi_zlib_decode_malloc_guesssize(const char *buffer, int len, int initial_size, int *outlen); -extern char *stbi_zlib_decode_malloc(const char *buffer, int len, int *outlen); -extern int stbi_zlib_decode_buffer(char *obuffer, int olen, const char *ibuffer, int ilen); - -extern char *stbi_zlib_decode_noheader_malloc(const char *buffer, int len, int *outlen); -extern int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char *ibuffer, int ilen); - - -// define faster low-level operations (typically SIMD support) -#ifdef STBI_SIMD -typedef void (*stbi_idct_8x8)(stbi_uc *out, int out_stride, short data[64], unsigned short *dequantize); -// compute an integer IDCT on "input" -// input[x] = data[x] * dequantize[x] -// write results to 'out': 64 samples, each run of 8 spaced by 'out_stride' -// CLAMP results to 0..255 -typedef void (*stbi_YCbCr_to_RGB_run)(stbi_uc *output, stbi_uc const *y, stbi_uc const *cb, stbi_uc const *cr, int count, int step); -// compute a conversion from YCbCr to RGB -// 'count' pixels -// write pixels to 'output'; each pixel is 'step' bytes (either 3 or 4; if 4, write '255' as 4th), order R,G,B -// y: Y input channel -// cb: Cb input channel; scale/biased to be 0..255 -// cr: Cr input channel; scale/biased to be 0..255 - -extern void stbi_install_idct(stbi_idct_8x8 func); -extern void stbi_install_YCbCr_to_RGB(stbi_YCbCr_to_RGB_run func); -#endif // STBI_SIMD - - -#ifdef __cplusplus -} -#endif - -// -// -//// end header file ///////////////////////////////////////////////////// -#endif // STBI_INCLUDE_STB_IMAGE_H diff --git a/Demos/OpenPL_Demo/CApi.cpp b/Demos/OpenPL_Demo/CApi.cpp deleted file mode 100644 index 171c7700b..000000000 --- a/Demos/OpenPL_Demo/CApi.cpp +++ /dev/null @@ -1,159 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/* - Draft high-level generic physics C-API. For low-level access, use the physics SDK native API's. - Work in progress, functionality will be added on demand. - - If possible, use the richer Bullet C++ API, by including -*/ - -#include "Bullet-C-Api.h" -#include "btBulletDynamicsCommon.h" - -/* - Create and Delete a Physics SDK -*/ - -plPhysicsSdkHandle plNewBulletSdk() -{ - return 0; -} - -void plDeletePhysicsSdk(plPhysicsSdkHandle physicsSdk) -{ - -} - -/* Dynamics World */ -plDynamicsWorldHandle plCreateDynamicsWorld(plPhysicsSdkHandle physicsSdk) -{ - return (plDynamicsWorldHandle) new btDiscreteDynamicsWorld; -} -void plDeleteDynamicsWorld(plDynamicsWorldHandle world) -{ - btDynamicsWorld* dynamicsWorld = reinterpret_cast< btDynamicsWorld* >(world); - delete dynamicsWorld; -} - -void plStepSimulation(plDynamicsWorldHandle world, plReal timeStep) -{ - btDynamicsWorld* dynamicsWorld = reinterpret_cast< btDynamicsWorld* >(world); - assert(dynamicsWorld); - dynamicsWorld->stepSimulation(timeStep); -} - -void plAddRigidBody(plDynamicsWorldHandle world, plRigidBodyHandle object) -{ - btDynamicsWorld* dynamicsWorld = reinterpret_cast< btDynamicsWorld* >(world); - assert(dynamicsWorld); - btRigidBody* body = reinterpret_cast< btRigidBody* >(object); - assert(body); - - dynamicsWorld->addRigidBody(body); -} - -void plRemoveRigidBody(plDynamicsWorldHandle world, plRigidBodyHandle object) -{ - btDynamicsWorld* dynamicsWorld = reinterpret_cast< btDynamicsWorld* >(world); - assert(dynamicsWorld); - btRigidBody* body = reinterpret_cast< btRigidBody* >(object); - assert(body); - - dynamicsWorld->removeRigidBody(body); -} - -/* Rigid Body */ - -plRigidBodyHandle plCreateRigidBody( void* user_data, float mass, plCollisionShapeHandle cshape ) -{ - btTransform trans; - trans.setIdentity(); - btVector3 localInertia; - btCollisionShape* shape = reinterpret_cast( cshape); - assert(shape); - shape->calculateLocalInertia(mass,localInertia); - btRigidBody* body = new btRigidBody(mass, trans,shape,localInertia); - body->m_userObjectPointer = user_data; - return (plRigidBodyHandle) body; -} - -void plDeleteRigidBody(plRigidBodyHandle cbody) -{ - btRigidBody* body = reinterpret_cast< btRigidBody* >(cbody); - assert(body); - delete body; -} - - -/* Collision Shape definition */ - -plCollisionShapeHandle plNewSphereShape(plReal radius) -{ - return (plCollisionShapeHandle) new btSphereShape(radius); - -} - -plCollisionShapeHandle plNewBoxShape(plReal x, plReal y, plReal z) -{ - return (plCollisionShapeHandle) new btBoxShape(btVector3(x,y,z)); -} - -plCollisionShapeHandle plNewCapsuleShape(plReal radius, plReal height) -{ - //capsule is convex hull of 2 spheres, so use btMultiSphereShape - btVector3 inertiaHalfExtents(radius,height,radius); - const int numSpheres = 2; - btVector3 positions[numSpheres] = {btVector3(0,height,0),btVector3(0,-height,0)}; - btScalar radi[numSpheres] = {radius,radius}; - return (plCollisionShapeHandle) new btMultiSphereShape(inertiaHalfExtents,positions,radi,numSpheres); -} -plCollisionShapeHandle plNewConeShape(plReal radius, plReal height) -{ - return (plCollisionShapeHandle) new btConeShape(radius,height); -} - -plCollisionShapeHandle plNewCylinderShape(plReal radius, plReal height) -{ - return (plCollisionShapeHandle) new btCylinderShape(btVector3(radius,height,radius)); -} - -void plDeleteShape(plCollisionShapeHandle cshape) -{ - btCollisionShape* shape = reinterpret_cast( cshape); - assert(shape); - delete shape; -} -void plSetScaling(plCollisionShapeHandle cshape, plVector3 cscaling) -{ - btCollisionShape* shape = reinterpret_cast( cshape); - assert(shape); - btVector3 scaling(cscaling[0],cscaling[1],cscaling[2]); - shape->setLocalScaling(scaling); -} - - - -void plSetPosition(plRigidBodyHandle object, const plVector3 position) -{ -} -void plSetOrientation(plRigidBodyHandle object, const plQuaternion orientation) -{ -} - - -//plRigidBodyHandle plRayCast(plDynamicsWorldHandle world, const plVector3 rayStart, const plVector3 rayEnd, plVector3 hitpoint, plVector3 normal); - -// extern plRigidBodyHandle plObjectCast(plDynamicsWorldHandle world, const plVector3 rayStart, const plVector3 rayEnd, plVector3 hitpoint, plVector3 normal); diff --git a/Demos/OpenPL_Demo/OpenPL_Demo.c b/Demos/OpenPL_Demo/OpenPL_Demo.c deleted file mode 100644 index cef1f76ae..000000000 --- a/Demos/OpenPL_Demo/OpenPL_Demo.c +++ /dev/null @@ -1,44 +0,0 @@ - -#include "Bullet-C-Api.h" - - -int main() -{ - float timeStep = 1.f/60.f; - - /* initialize */ - plPhysicsSdkHandle sdk = plNewBulletSdk(); - - plDynamicsWorldHandle world = plCreateDynamicsWorld(sdk); - - - float radius = 1.f; - plCollisionShapeHandle collisionShape = plNewSphereShape(radius); - - void* user_data = 0;/* can point to a graphics object */ - - float mass = 1.f; - - plRigidBodyHandle body = plCreateRigidBody(user_data, mass, collisionShape ); - - plAddRigidBody(world, body); - - - - plStepSimulation(world,0.1f); - - /* cleanup */ - - plRemoveRigidBody(world, body); - - - plDeleteRigidBody(body); - - plDeleteShape( collisionShape); - - plDeleteDynamicsWorld( world); - - plDeletePhysicsSdk(sdk); - - return 0; -} \ No newline at end of file diff --git a/Demos/RagdollDemo/CMakeLists.txt b/Demos/RagdollDemo/CMakeLists.txt deleted file mode 100644 index 286c0542c..000000000 --- a/Demos/RagdollDemo/CMakeLists.txt +++ /dev/null @@ -1,34 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppRagdollDemo - RagdollDemo.cpp - main.cpp -) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppRagdollDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppRagdollDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppRagdollDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/RagdollDemo/RagdollDemo.cpp b/Demos/RagdollDemo/RagdollDemo.cpp deleted file mode 100644 index 0ec12df1d..000000000 --- a/Demos/RagdollDemo/RagdollDemo.cpp +++ /dev/null @@ -1,507 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Ragdoll Demo -Copyright (c) 2007 Starbreeze Studios - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -Written by: Marten Svanfeldt -*/ - -#define CONSTRAINT_DEBUG_SIZE 0.2f - - -#include "btBulletDynamicsCommon.h" -#include "GlutStuff.h" -#include "GL_ShapeDrawer.h" - -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" -#include "RagdollDemo.h" - - -// Enrico: Shouldn't these three variables be real constants and not defines? - -#ifndef M_PI -#define M_PI 3.14159265358979323846 -#endif - -#ifndef M_PI_2 -#define M_PI_2 1.57079632679489661923 -#endif - -#ifndef M_PI_4 -#define M_PI_4 0.785398163397448309616 -#endif - -class RagDoll -{ - enum - { - BODYPART_PELVIS = 0, - BODYPART_SPINE, - BODYPART_HEAD, - - BODYPART_LEFT_UPPER_LEG, - BODYPART_LEFT_LOWER_LEG, - - BODYPART_RIGHT_UPPER_LEG, - BODYPART_RIGHT_LOWER_LEG, - - BODYPART_LEFT_UPPER_ARM, - BODYPART_LEFT_LOWER_ARM, - - BODYPART_RIGHT_UPPER_ARM, - BODYPART_RIGHT_LOWER_ARM, - - BODYPART_COUNT - }; - - enum - { - JOINT_PELVIS_SPINE = 0, - JOINT_SPINE_HEAD, - - JOINT_LEFT_HIP, - JOINT_LEFT_KNEE, - - JOINT_RIGHT_HIP, - JOINT_RIGHT_KNEE, - - JOINT_LEFT_SHOULDER, - JOINT_LEFT_ELBOW, - - JOINT_RIGHT_SHOULDER, - JOINT_RIGHT_ELBOW, - - JOINT_COUNT - }; - - btDynamicsWorld* m_ownerWorld; - btCollisionShape* m_shapes[BODYPART_COUNT]; - btRigidBody* m_bodies[BODYPART_COUNT]; - btTypedConstraint* m_joints[JOINT_COUNT]; - - btRigidBody* localCreateRigidBody (btScalar mass, const btTransform& startTransform, btCollisionShape* shape) - { - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,shape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - m_ownerWorld->addRigidBody(body); - - return body; - } - -public: - RagDoll (btDynamicsWorld* ownerWorld, const btVector3& positionOffset) - : m_ownerWorld (ownerWorld) - { - // Setup the geometry - m_shapes[BODYPART_PELVIS] = new btCapsuleShape(btScalar(0.15), btScalar(0.20)); - m_shapes[BODYPART_SPINE] = new btCapsuleShape(btScalar(0.15), btScalar(0.28)); - m_shapes[BODYPART_HEAD] = new btCapsuleShape(btScalar(0.10), btScalar(0.05)); - m_shapes[BODYPART_LEFT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07), btScalar(0.45)); - m_shapes[BODYPART_LEFT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05), btScalar(0.37)); - m_shapes[BODYPART_RIGHT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07), btScalar(0.45)); - m_shapes[BODYPART_RIGHT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05), btScalar(0.37)); - m_shapes[BODYPART_LEFT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05), btScalar(0.33)); - m_shapes[BODYPART_LEFT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04), btScalar(0.25)); - m_shapes[BODYPART_RIGHT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05), btScalar(0.33)); - m_shapes[BODYPART_RIGHT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04), btScalar(0.25)); - - // Setup all the rigid bodies - btTransform offset; offset.setIdentity(); - offset.setOrigin(positionOffset); - - btTransform transform; - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.), btScalar(0.))); - m_bodies[BODYPART_PELVIS] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_PELVIS]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.2), btScalar(0.))); - m_bodies[BODYPART_SPINE] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_SPINE]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.6), btScalar(0.))); - m_bodies[BODYPART_HEAD] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_HEAD]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_LEFT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_LEFT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_RIGHT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_RIGHT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,M_PI_2); - m_bodies[BODYPART_LEFT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,M_PI_2); - m_bodies[BODYPART_LEFT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-M_PI_2); - m_bodies[BODYPART_RIGHT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-M_PI_2); - m_bodies[BODYPART_RIGHT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_ARM]); - - // Setup some damping on the m_bodies - for (int i = 0; i < BODYPART_COUNT; ++i) - { - m_bodies[i]->setDamping(0.05, 0.85); - m_bodies[i]->setDeactivationTime(0.8); - m_bodies[i]->setSleepingThresholds(1.6, 2.5); - } - - // Now setup the constraints - btHingeConstraint* hingeC; - btConeTwistConstraint* coneC; - - btTransform localA, localB; - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.15), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_SPINE], localA, localB); - hingeC->setLimit(btScalar(-M_PI_4), btScalar(M_PI_2)); - m_joints[JOINT_PELVIS_SPINE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_PELVIS_SPINE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI_2); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.30), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_HEAD], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, M_PI_2); - m_joints[JOINT_SPINE_HEAD] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_SPINE_HEAD], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,-M_PI_4*5); localA.setOrigin(btVector3(btScalar(-0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,-M_PI_4*5); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_LEFT_UPPER_LEG], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, 0); - m_joints[JOINT_LEFT_HIP] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_LEG], *m_bodies[BODYPART_LEFT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_LEFT_KNEE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI_4); localA.setOrigin(btVector3(btScalar(0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_4); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_RIGHT_UPPER_LEG], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, 0); - m_joints[JOINT_RIGHT_HIP] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_LEG], *m_bodies[BODYPART_RIGHT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_RIGHT_KNEE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI); localA.setOrigin(btVector3(btScalar(-0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_LEFT_UPPER_ARM], localA, localB); - coneC->setLimit(M_PI_2, M_PI_2, 0); - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_joints[JOINT_LEFT_SHOULDER] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_ARM], *m_bodies[BODYPART_LEFT_LOWER_ARM], localA, localB); -// hingeC->setLimit(btScalar(-M_PI_2), btScalar(0)); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_LEFT_ELBOW] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_ELBOW], true); - - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,0); localA.setOrigin(btVector3(btScalar(0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_RIGHT_UPPER_ARM], localA, localB); - coneC->setLimit(M_PI_2, M_PI_2, 0); - m_joints[JOINT_RIGHT_SHOULDER] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_ARM], *m_bodies[BODYPART_RIGHT_LOWER_ARM], localA, localB); -// hingeC->setLimit(btScalar(-M_PI_2), btScalar(0)); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_RIGHT_ELBOW] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_ELBOW], true); - } - - virtual ~RagDoll () - { - int i; - - // Remove all constraints - for ( i = 0; i < JOINT_COUNT; ++i) - { - m_ownerWorld->removeConstraint(m_joints[i]); - delete m_joints[i]; m_joints[i] = 0; - } - - // Remove all bodies and shapes - for ( i = 0; i < BODYPART_COUNT; ++i) - { - m_ownerWorld->removeRigidBody(m_bodies[i]); - - delete m_bodies[i]->getMotionState(); - - delete m_bodies[i]; m_bodies[i] = 0; - delete m_shapes[i]; m_shapes[i] = 0; - } - } -}; - - - - -void RagdollDemo::initPhysics() -{ - // Setup the basic world - - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(5.)); - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax(10000,10000,10000); - m_broadphase = new btAxisSweep3 (worldAabbMin, worldAabbMax); - - m_solver = new btSequentialImpulseConstraintSolver; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - //m_dynamicsWorld->getDispatchInfo().m_useConvexConservativeDistanceUtil = true; - //m_dynamicsWorld->getDispatchInfo().m_convexConservativeDistanceThreshold = 0.01f; - - - - // Setup a big ground box - { - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(200.),btScalar(10.),btScalar(200.))); - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-10,0)); - -#define CREATE_GROUND_COLLISION_OBJECT 1 -#ifdef CREATE_GROUND_COLLISION_OBJECT - btCollisionObject* fixedGround = new btCollisionObject(); - fixedGround->setCollisionShape(groundShape); - fixedGround->setWorldTransform(groundTransform); - m_dynamicsWorld->addCollisionObject(fixedGround); -#else - localCreateRigidBody(btScalar(0.),groundTransform,groundShape); -#endif //CREATE_GROUND_COLLISION_OBJECT - - } - - // Spawn one ragdoll - btVector3 startOffset(1,0.5,0); - spawnRagdoll(startOffset); - startOffset.setValue(-1,0.5,0); - spawnRagdoll(startOffset); - - clientResetScene(); -} - -void RagdollDemo::spawnRagdoll(const btVector3& startOffset) -{ - RagDoll* ragDoll = new RagDoll (m_dynamicsWorld, startOffset); - m_ragdolls.push_back(ragDoll); -} - -void RagdollDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - float minFPS = 1000000.f/60.f; - if (ms > minFPS) - ms = minFPS; - - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - - } - - renderme(); - - glFlush(); - - glutSwapBuffers(); -} - -void RagdollDemo::displayCallback() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - glutSwapBuffers(); -} - -void RagdollDemo::keyboardCallback(unsigned char key, int x, int y) -{ - switch (key) - { - case 'e': - { - btVector3 startOffset(0,2,0); - spawnRagdoll(startOffset); - break; - } - default: - DemoApplication::keyboardCallback(key, x, y); - } - - -} - - - -void RagdollDemo::exitPhysics() -{ - - int i; - - for (i=0;igetNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_ragdolls; - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - -public: - void initPhysics(); - - void exitPhysics(); - - virtual ~RagdollDemo() - { - exitPhysics(); - } - - void spawnRagdoll(const btVector3& startOffset); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - static DemoApplication* Create() - { - RagdollDemo* demo = new RagdollDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } - -}; - - -#endif diff --git a/Demos/RagdollDemo/main.cpp b/Demos/RagdollDemo/main.cpp deleted file mode 100644 index 0cbf63b9f..000000000 --- a/Demos/RagdollDemo/main.cpp +++ /dev/null @@ -1,31 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2008 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "RagdollDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char* argv[]) -{ - RagdollDemo demoApp; - - demoApp.initPhysics(); - demoApp.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",&demoApp); -} diff --git a/Demos/RaytestDemo/CMakeLists.txt b/Demos/RaytestDemo/CMakeLists.txt deleted file mode 100644 index 8dfeef10a..000000000 --- a/Demos/RaytestDemo/CMakeLists.txt +++ /dev/null @@ -1,70 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppRaytestDemo - main.cpp - RaytestDemo.cpp - RaytestDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppRaytestDemo - main.cpp - RaytestDemo.cpp - RaytestDemo.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppRaytestDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32RaytestDemo.cpp - RaytestDemo.cpp - RaytestDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppRaytestDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppRaytestDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppRaytestDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/RaytestDemo/Makefile.am b/Demos/RaytestDemo/Makefile.am deleted file mode 100644 index 05546162b..000000000 --- a/Demos/RaytestDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=BasicDemo - -BasicDemo_SOURCES=BasicDemo.cpp BasicDemo.h main.cpp -BasicDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -BasicDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/RaytestDemo/RaytestDemo.cpp b/Demos/RaytestDemo/RaytestDemo.cpp deleted file mode 100644 index d16fb1e02..000000000 --- a/Demos/RaytestDemo/RaytestDemo.cpp +++ /dev/null @@ -1,333 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - -#include "RaytestDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/NarrowPhaseCollision/btRaycastCallback.h" -#include "BulletCollision/Gimpact/btGImpactShape.h" - -#include //printf debugging -#include "GLDebugDrawer.h" -static GLDebugDrawer sDebugDraw; - - - -void RaytestDemo::castRays() -{ - - static float up = 0.f; - static float dir = 1.f; - //add some simple animation - if (!m_idle) - { - up+=0.01*dir; - - if (btFabs(up)>2) - { - dir*=-1.f; - } - - btTransform tr = m_dynamicsWorld->getCollisionObjectArray()[1]->getWorldTransform(); - static float angle = 0.f; - angle+=0.01f; - tr.setRotation(btQuaternion(btVector3(0,1,0),angle)); - m_dynamicsWorld->getCollisionObjectArray()[1]->setWorldTransform(tr); - } - - - ///step the simulation - if (m_dynamicsWorld) - { - - m_dynamicsWorld->updateAabbs(); - m_dynamicsWorld->computeOverlappingPairs(); - - btVector3 red(1,0,0); - btVector3 blue(0,0,1); - - ///all hits - { - btVector3 from(-30,1+up,0); - btVector3 to(30,1,0); - sDebugDraw.drawLine(from,to,btVector4(0,0,0,1)); - btCollisionWorld::AllHitsRayResultCallback allResults(from,to); - allResults.m_flags |= btTriangleRaycastCallback::kF_KeepUnflippedNormal; - //kF_UseGjkConvexRaytest flag is now enabled by default, use the faster but more approximate algorithm - allResults.m_flags |= btTriangleRaycastCallback::kF_UseSubSimplexConvexCastRaytest; - - m_dynamicsWorld->rayTest(from,to,allResults); - - for (int i=0;irayTest(from,to,closestResults); - - - if (closestResults.hasHit()) - { - - btVector3 p = from.lerp(to,closestResults.m_closestHitFraction); - sDebugDraw.drawSphere(p,0.1,blue); - sDebugDraw.drawLine(p,p+closestResults.m_hitNormalWorld,blue); - - } - } - } - -} - - -void RaytestDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - castRays(); - - if (m_dynamicsWorld) - { - float ms = getDeltaTimeMicroseconds(); - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - - m_dynamicsWorld->debugDrawWorld(); - } - - - - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void RaytestDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - castRays(); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - - - - -void RaytestDemo::initPhysics() -{ - m_ele = 10; - m_azi = 75; - - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(20.)); - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld ->setDebugDrawer(&sDebugDraw); - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - body->setRollingFriction(1); - body->setFriction(1); - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - - { - btVector3 convexPoints[]={ btVector3(-1,-1,-1),btVector3(-1,-1,1),btVector3(-1,1,1),btVector3(-1,1,-1), - btVector3(2,0,0)}; - - btVector3 quad[] = { - btVector3(0,1,-1), - btVector3(0,1,1), - btVector3(0,-1,1), - btVector3(0,-1,-1)}; - - btTriangleMesh* mesh = new btTriangleMesh(); - mesh->addTriangle(quad[0],quad[1],quad[2],true); - mesh->addTriangle(quad[0],quad[2],quad[3],true); - - //btBvhTriangleMeshShape* trimesh = new btBvhTriangleMeshShape(mesh,true,true); - btGImpactMeshShape * trimesh = new btGImpactMeshShape(mesh); - trimesh->updateBound(); - - -#define NUM_SHAPES 6 - btCollisionShape* colShapes[NUM_SHAPES] = { - trimesh, - new btConvexHullShape(&convexPoints[0].getX(),sizeof(convexPoints)/sizeof(btVector3),sizeof(btVector3)), - new btSphereShape(1), - new btCapsuleShape(0.2,1), - new btCylinderShape(btVector3(0.2,1,0.2)), - new btBoxShape(btVector3(1,1,1)) - }; - - for (int i=0;icalculateLocalInertia(mass,localInertia); - - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,0,colShape,localInertia); - rbInfo.m_startWorldTransform = startTransform; - btRigidBody* body = new btRigidBody(rbInfo); - body->setRollingFriction(0.03); - body->setFriction(1); - body->setAnisotropicFriction(colShape->getAnisotropicRollingFrictionDirection(),btCollisionObject::CF_ANISOTROPIC_ROLLING_FRICTION); - - m_dynamicsWorld->addRigidBody(body); - - } - - } -} -void RaytestDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void RaytestDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - public: - - RaytestDemo() - { - } - virtual ~RaytestDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - void castRays(); - virtual void displayCallback(); - virtual void clientResetScene(); - - static DemoApplication* Create() - { - RaytestDemo* demo = new RaytestDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //BT_RAYTEST_DEMO_H - diff --git a/Demos/RaytestDemo/Win32RaytestDemo.cpp b/Demos/RaytestDemo/Win32RaytestDemo.cpp deleted file mode 100644 index 6a7f32fec..000000000 --- a/Demos/RaytestDemo/Win32RaytestDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "RaytestDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new RaytestDemo(); -} - -#endif diff --git a/Demos/RaytestDemo/main.cpp b/Demos/RaytestDemo/main.cpp deleted file mode 100644 index 87e003277..000000000 --- a/Demos/RaytestDemo/main.cpp +++ /dev/null @@ -1,41 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "RaytestDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - - - - -int main(int argc,char** argv) -{ - - RaytestDemo ccdDemo; - ccdDemo.initPhysics(); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/Raytracer/CMakeLists.txt b/Demos/Raytracer/CMakeLists.txt deleted file mode 100644 index 2f3b6a991..000000000 --- a/Demos/Raytracer/CMakeLists.txt +++ /dev/null @@ -1,34 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppRaytracer - Raytracer.cpp - main.cpp -) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppRaytracer PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppRaytracer PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppRaytracer PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/Raytracer/Raytracer.cpp b/Demos/Raytracer/Raytracer.cpp deleted file mode 100644 index 97810a1ff..000000000 --- a/Demos/Raytracer/Raytracer.cpp +++ /dev/null @@ -1,627 +0,0 @@ -/* -* Copyright (c) 2005 Erwin Coumans -* -* Permission to use, copy, modify, distribute and sell this software -* and its documentation for any purpose is hereby granted without fee, -* provided that the above copyright notice appear in all copies. -* Erwin Coumans makes no representations about the suitability -* of this software for any purpose. -* It is provided "as is" without express or implied warranty. -*/ - - - -#include "BulletCollision/CollisionDispatch/btCollisionWorld.h" - -/* -Raytracer uses the Convex rayCast to visualize the Collision Shapes/Minkowski Sum. -Very basic raytracer, rendering into a texture. -*/ - -///Low level demo, doesn't include btBulletCollisionCommon.h - -#include "LinearMath/btQuaternion.h" -#include "LinearMath/btTransform.h" -#include "GL_ShapeDrawer.h" -#include "GLDebugDrawer.h" - -#include "Raytracer.h" -#include "GlutStuff.h" - - -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h" -#include "BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h" - -#include "BulletCollision/CollisionShapes/btSphereShape.h" -#include "BulletCollision/CollisionShapes/btMultiSphereShape.h" - -#include "BulletCollision/CollisionShapes/btConvexHullShape.h" -#include "LinearMath/btAabbUtil2.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/CollisionShapes/btCompoundShape.h" - - -#include "BulletCollision/CollisionShapes/btTetrahedronShape.h" -#include "BulletCollision/CollisionShapes/btConeShape.h" -#include "BulletCollision/CollisionShapes/btCylinderShape.h" -#include "BulletCollision/CollisionShapes/btMinkowskiSumShape.h" - -#include "BulletCollision/CollisionDispatch/btDefaultCollisionConfiguration.h" -#include "BulletCollision/BroadphaseCollision/btAxisSweep3.h" - -#include "RenderTexture.h" - - - -static btVoronoiSimplexSolver simplexSolver; - -static float yaw=0.f,pitch=0.f,roll=0.f; -static const int maxNumObjects = 4; -static const int numObjects = 3; - - -static btConvexShape* shapePtr[maxNumObjects]; -static btTransform transforms[maxNumObjects]; - -renderTexture* raytracePicture = 0; - -//this applies to the raytracer virtual screen/image buffer -static int screenWidth = 128;//256; -//float aspectRatio = (3.f/4.f); -static int screenHeight = 64;//256;//screenWidth * aspectRatio; -GLuint glTextureId; - -btConeShape myCone(1,1); -btSphereShape mysphere(1); -btBoxShape mybox(btVector3(1,1,1)); - -btCollisionWorld* m_collisionWorld = 0; - - - -/// -/// -/// - -void Raytracer::initPhysics() -{ - m_ele = 0; - - raytracePicture = new renderTexture(screenWidth,screenHeight); - myCone.setMargin(0.2f); - - //choose shape - shapePtr[0] = &myCone; - shapePtr[1] = &mysphere; - shapePtr[2] = &mybox; - - for (int i=0;isetCollisionShape(shapePtr[s]); - obj->setWorldTransform(transforms[s]); - m_collisionWorld->addCollisionObject(obj); - } - - -} - -Raytracer::~Raytracer() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_collisionWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_collisionWorld->getCollisionObjectArray()[i]; - m_collisionWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision world - delete m_collisionWorld; - - //delete broadphase - delete m_overlappingPairCache; - - //delete dispatcher - delete m_dispatcher; - - delete m_collisionConfiguration; - - delete raytracePicture; - raytracePicture=0; -} - -//to be implemented by the demo - -void Raytracer::clientMoveAndDisplay() -{ - displayCallback(); -} - - - - - - -bool Raytracer::worldRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint) -{ - - struct AllRayResultCallback : public btCollisionWorld::RayResultCallback - { - AllRayResultCallback(const btVector3& rayFromWorld,const btVector3& rayToWorld) - :m_rayFromWorld(rayFromWorld), - m_rayToWorld(rayToWorld) - { - } - - btVector3 m_rayFromWorld;//used to calculate hitPointWorld from hitFraction - btVector3 m_rayToWorld; - - btVector3 m_hitNormalWorld; - btVector3 m_hitPointWorld; - - virtual btScalar addSingleResult(btCollisionWorld::LocalRayResult& rayResult,bool normalInWorldSpace) - { - -//caller already does the filter on the m_closestHitFraction - btAssert(rayResult.m_hitFraction <= m_closestHitFraction); - - m_closestHitFraction = rayResult.m_hitFraction; - - m_collisionObject = rayResult.m_collisionObject; - if (normalInWorldSpace) - { - m_hitNormalWorld = rayResult.m_hitNormalLocal; - } else - { - ///need to transform normal into worldspace - m_hitNormalWorld = m_collisionObject->getWorldTransform().getBasis()*rayResult.m_hitNormalLocal; - } - m_hitPointWorld.setInterpolate3(m_rayFromWorld,m_rayToWorld,rayResult.m_hitFraction); - return 1.f; - } - }; - - - AllRayResultCallback resultCallback(rayFrom,rayTo); -// btCollisionWorld::ClosestRayResultCallback resultCallback(rayFrom,rayTo); - m_collisionWorld->rayTest(rayFrom,rayTo,resultCallback); - if (resultCallback.hasHit()) - { - worldNormal = resultCallback.m_hitNormalWorld; - return true; - } - return false; -} - - -bool Raytracer::singleObjectRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint) -{ - -// btScalar closestHitResults = 1.f; - - btCollisionWorld::ClosestRayResultCallback resultCallback(rayFrom,rayTo); - - bool hasHit = false; - btConvexCast::CastResult rayResult; - btSphereShape pointShape(0.0f); - btTransform rayFromTrans; - btTransform rayToTrans; - - rayFromTrans.setIdentity(); - rayFromTrans.setOrigin(rayFrom); - rayToTrans.setIdentity(); - rayToTrans.setOrigin(rayTo); - - for (int s=0;sgetAabb(transforms[s],aabbMin,aabbMax); - btScalar hitLambda = 1.f; - btVector3 hitNormal; - btCollisionObject tmpObj; - tmpObj.setWorldTransform(transforms[s]); - - - if (btRayAabb(rayFrom,rayTo,aabbMin,aabbMax,hitLambda,hitNormal)) - { - //reset previous result - - btCollisionWorld::rayTestSingle(rayFromTrans,rayToTrans, &tmpObj, shapePtr[s], transforms[s], resultCallback); - if (resultCallback.hasHit()) - { - //float fog = 1.f - 0.1f * rayResult.m_fraction; - resultCallback.m_hitNormalWorld.normalize();//.m_normal.normalize(); - worldNormal = resultCallback.m_hitNormalWorld; - //worldNormal = transforms[s].getBasis() *rayResult.m_normal; - worldNormal.normalize(); - hasHit = true; - } - } - } - - return hasHit; -} - - -bool Raytracer::lowlevelRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint) -{ - - btScalar closestHitResults = 1.f; - - bool hasHit = false; - btConvexCast::CastResult rayResult; - btSphereShape pointShape(0.0f); - btTransform rayFromTrans; - btTransform rayToTrans; - - rayFromTrans.setIdentity(); - rayFromTrans.setOrigin(rayFrom); - rayToTrans.setIdentity(); - rayToTrans.setOrigin(rayTo); - - for (int s=0;sgetAabb(transforms[s],aabbMin,aabbMax); - btScalar hitLambda = 1.f; - btVector3 hitNormal; - btCollisionObject tmpObj; - tmpObj.setWorldTransform(transforms[s]); - - - if (btRayAabb(rayFrom,rayTo,aabbMin,aabbMax,hitLambda,hitNormal)) - { - //reset previous result - - //choose the continuous collision detection method - btSubsimplexConvexCast convexCaster(&pointShape,shapePtr[s],&simplexSolver); - //btGjkConvexCast convexCaster(&pointShape,shapePtr[s],&simplexSolver); - //btContinuousConvexCollision convexCaster(&pointShape,shapePtr[s],&simplexSolver,0); - - if (convexCaster.calcTimeOfImpact(rayFromTrans,rayToTrans,transforms[s],transforms[s],rayResult)) - { - if (rayResult.m_fraction < closestHitResults) - { - closestHitResults = rayResult.m_fraction; - - worldNormal = transforms[s].getBasis() *rayResult.m_normal; - worldNormal.normalize(); - hasHit = true; - } - } - } - } - - return hasHit; - -} - - -void Raytracer::displayCallback() -{ - - updateCamera(); - - for (int i=0;isetPixel(x,y,rgba); - } - } - -#if 1 - btVector3 rayTo; - btTransform colObjWorldTransform; - colObjWorldTransform.setIdentity(); - - int mode = 0; - - for (x=0;xsetPixel(x,y,rgba); - } else - { - // btVector4 rgba = raytracePicture->getPixel(x,y); - } - if (!rgba.length2()) - { - raytracePicture->setPixel(x,y,btVector4(1,1,1,1)); - } - } - } -#endif - -extern unsigned char sFontData[]; - if (0) - { - - const char* text="ABC abc 123 !@#"; - int x=0; - for (int cc = 0;ccsetPixel(x,y,rgba); - raytracePicture->addPixel(x,y,rgba); - } - y++; - } - x++; - } - } - } - - - //raytracePicture->grapicalPrintf("CCD RAYTRACER",sFontData); - char buffer[256]; - sprintf(buffer,"%d rays",screenWidth*screenHeight*numObjects); - //sprintf(buffer,"Toggle",screenWidth*screenHeight*numObjects); - //sprintf(buffer,"TEST",screenWidth*screenHeight*numObjects); - //raytracePicture->grapicalPrintf(buffer,sFontData,0,10);//&BMF_font_helv10,0,10); - raytracePicture->grapicalPrintf(buffer,sFontData,0,0);//&BMF_font_helv10,0,10); - - - glMatrixMode(GL_PROJECTION); - glPushMatrix(); - glLoadIdentity(); - glFrustum(-1.0,1.0,-1.0,1.0,3,2020.0); - - glMatrixMode(GL_MODELVIEW); - glPushMatrix(); - glLoadIdentity(); // reset The Modelview Matrix - glTranslatef(0.0f,0.0f,-3.1f); // Move Into The Screen 5 Units - - - - glEnable(GL_TEXTURE_2D); - glBindTexture(GL_TEXTURE_2D,glTextureId ); - - const unsigned char *ptr = raytracePicture->getBuffer(); - glTexImage2D(GL_TEXTURE_2D, - 0, - GL_RGBA, - raytracePicture->getWidth(),raytracePicture->getHeight(), - 0, - GL_RGBA, - GL_UNSIGNED_BYTE, - ptr); - - - glEnable (GL_BLEND); - glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glColor4f (1,1,1,1); // alpha=0.5=half visible - - glBegin(GL_QUADS); - glTexCoord2f(0.0f, 0.0f); - glVertex2f(-1,1); - glTexCoord2f(1.0f, 0.0f); - glVertex2f(1,1); - glTexCoord2f(1.0f, 1.0f); - glVertex2f(1,-1); - glTexCoord2f(0.0f, 1.0f); - glVertex2f(-1,-1); - glEnd(); - - - - glMatrixMode(GL_MODELVIEW); - glPopMatrix(); - glMatrixMode(GL_PROJECTION); - glPopMatrix(); - glMatrixMode(GL_MODELVIEW); - - - glDisable(GL_TEXTURE_2D); - glDisable(GL_DEPTH_TEST); - - GL_ShapeDrawer::drawCoordSystem(); - - - - { - for (int i=0;igetAabb(transforms[i],aabbMin,aabbMax); - } - } - - glPushMatrix(); - - - - - glPopMatrix(); - - pitch += 0.005f; - yaw += 0.01f; - m_azi += 1.f; - - glFlush(); - glutSwapBuffers(); -} - diff --git a/Demos/Raytracer/Raytracer.h b/Demos/Raytracer/Raytracer.h deleted file mode 100644 index a8ff33f7f..000000000 --- a/Demos/Raytracer/Raytracer.h +++ /dev/null @@ -1,65 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef RAYTRACER_H -#define RAYTRACER_H - -#include "GlutDemoApplication.h" - -class btDefaultCollisionConfiguration; -class btCollisionDispatcher; -class btAxisSweep3; -class btCollisionWorld; - -///Raytracer shows the inner working of the ray casting, using ray tracing rendering into a texture. -class Raytracer : public GlutDemoApplication -{ - - btDefaultCollisionConfiguration* m_collisionConfiguration; - btCollisionDispatcher* m_dispatcher; - btAxisSweep3* m_overlappingPairCache; - btCollisionWorld* m_collisionWorld; - bool m_initialized; - - public: - - void initPhysics(); - - virtual ~Raytracer(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - ///worldRaytest performs a ray versus all objects in a collision world, returning true is a hit is found (filling in worldNormal and worldHitPoint) - bool worldRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint); - - ///singleObjectRaytest performs a ray versus one collision shape, returning true is a hit is found (filling in worldNormal and worldHitPoint) - bool singleObjectRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint); - - ///lowlevelRaytest performs a ray versus convex shape, returning true is a hit is found (filling in worldNormal and worldHitPoint) - bool lowlevelRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint); - - static DemoApplication* Create() - { - Raytracer* demo = new Raytracer(); - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -#endif //RAYTRACER_H - - diff --git a/Demos/Raytracer/RaytracerSetup.cpp b/Demos/Raytracer/RaytracerSetup.cpp deleted file mode 100644 index 6855ffc43..000000000 --- a/Demos/Raytracer/RaytracerSetup.cpp +++ /dev/null @@ -1,318 +0,0 @@ - -#include "RaytracerSetup.h" -#include "Bullet3AppSupport/Common2dCanvasInterface.h" -//#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h" -//#include "BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h" -//#include "BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h" - -struct RaytracerInternalData -{ - int m_canvasIndex; - struct Common2dCanvasInterface* m_canvas; - - int m_width; - int m_height; - - btAlignedObjectArray m_shapePtr; - btAlignedObjectArray m_transforms; - btVoronoiSimplexSolver m_simplexSolver; - btScalar m_pitch; - btScalar m_roll; - btScalar m_yaw; - - RaytracerInternalData() - :m_canvasIndex(-1), - m_canvas(0), - m_roll(0), - m_pitch(0), - m_yaw(0), - m_width(128), - m_height(128) - { - btConeShape* cone = new btConeShape(1,1); - btSphereShape* sphere = new btSphereShape(1); - btBoxShape* box = new btBoxShape (btVector3(1,1,1)); - m_shapePtr.push_back(cone); - m_shapePtr.push_back(sphere); - m_shapePtr.push_back(box); - - updateTransforms(); - } - void updateTransforms() - { - int numObjects = m_shapePtr.size(); - m_transforms.resize(numObjects); - for (int i=0;im_canvas = gfxBridge.get2dCanvasInterface(); - - - if (m_internalData->m_canvas) - { - - m_internalData->m_canvasIndex = m_internalData->m_canvas->createCanvas("raytracer",m_internalData->m_width,m_internalData->m_height); - for (int i=0;im_width;i++) - { - for (int j=0;jm_height;j++) - { - unsigned char red=255; - unsigned char green=255; - unsigned char blue=255; - unsigned char alpha=255; - m_internalData->m_canvas->setPixel(m_internalData->m_canvasIndex,i,j,red,green,blue,alpha); - } - } - m_internalData->m_canvas->refreshImageData(m_internalData->m_canvasIndex); - - //int bitmapId = gfxBridge.createRenderBitmap(width,height); - } - - - - -} - - -///worldRaytest performs a ray versus all objects in a collision world, returning true is a hit is found (filling in worldNormal and worldHitPoint) -bool RaytracerPhysicsSetup::worldRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint) -{ - return false; -} - - -///singleObjectRaytest performs a ray versus one collision shape, returning true is a hit is found (filling in worldNormal and worldHitPoint) -bool RaytracerPhysicsSetup::singleObjectRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint) -{ - return false; -} - - -///lowlevelRaytest performs a ray versus convex shape, returning true is a hit is found (filling in worldNormal and worldHitPoint) -bool RaytracerPhysicsSetup::lowlevelRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint) -{ - btScalar closestHitResults = 1.f; - - bool hasHit = false; - btConvexCast::CastResult rayResult; - btSphereShape pointShape(0.0f); - btTransform rayFromTrans; - btTransform rayToTrans; - - rayFromTrans.setIdentity(); - rayFromTrans.setOrigin(rayFrom); - rayToTrans.setIdentity(); - rayToTrans.setOrigin(rayTo); - - int numObjects = m_internalData->m_shapePtr.size(); - - for (int s=0;sm_shapePtr[s]->getAabb( m_internalData->m_transforms[s],aabbMin,aabbMax); - btScalar hitLambda = 1.f; - btVector3 hitNormal; - btCollisionObject tmpObj; - tmpObj.setWorldTransform( m_internalData->m_transforms[s]); - - - if (btRayAabb(rayFrom,rayTo,aabbMin,aabbMax,hitLambda,hitNormal)) - { - //reset previous result - - //choose the continuous collision detection method - btSubsimplexConvexCast convexCaster(&pointShape, m_internalData->m_shapePtr[s],&m_internalData->m_simplexSolver); - //btGjkConvexCast convexCaster(&pointShape,shapePtr[s],&simplexSolver); - //btContinuousConvexCollision convexCaster(&pointShape,shapePtr[s],&simplexSolver,0); - - if (convexCaster.calcTimeOfImpact(rayFromTrans,rayToTrans, m_internalData->m_transforms[s], m_internalData->m_transforms[s],rayResult)) - { - if (rayResult.m_fraction < closestHitResults) - { - closestHitResults = rayResult.m_fraction; - - worldNormal = m_internalData->m_transforms[s].getBasis() *rayResult.m_normal; - worldNormal.normalize(); - hasHit = true; - } - } - } - } - - - return hasHit; - -} - -void RaytracerPhysicsSetup::exitPhysics() -{ - - if (m_internalData->m_canvas && m_internalData->m_canvasIndex>=0) - { - m_internalData->m_canvas->destroyCanvas(m_internalData->m_canvasIndex); - } -} - -void RaytracerPhysicsSetup::stepSimulation(float deltaTime) -{ - - m_internalData->updateTransforms(); - - - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - - float tanFov = (top-bottom)*0.5f / nearPlane; - - float fov = 2.0 * atanf (tanFov); - - btVector3 cameraPosition(5,0,0); - btVector3 cameraTargetPosition(0,0,0); - - btVector3 rayFrom = cameraPosition; - btVector3 rayForward = cameraTargetPosition-cameraPosition; - rayForward.normalize(); - float farPlane = 600.f; - rayForward*= farPlane; - - btVector3 rightOffset; - btVector3 vertical(0.f,1.f,0.f); - btVector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - btVector3 rayToCenter = rayFrom + rayForward; - - btVector3 dHor = hor * 1.f/float(m_internalData->m_width); - btVector3 dVert = vertical * 1.f/float(m_internalData->m_height); - - - - - int mode = 0; - int x,y; - - for (x=0;xm_width;x++) - { - for (int y=0;ym_height;y++) - { - btVector4 rgba(0,0,0,0); - btVector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += x * dHor; - rayTo -= y * dVert; - btVector3 worldNormal(0,0,0); - btVector3 worldPoint(0,0,0); - - - - bool hasHit = false; - int mode = 0; - switch (mode) - { - case 0: - hasHit = lowlevelRaytest(rayFrom,rayTo,worldNormal,worldPoint); - break; - case 1: - hasHit = singleObjectRaytest(rayFrom,rayTo,worldNormal,worldPoint); - break; - case 2: - hasHit = worldRaytest(rayFrom,rayTo,worldNormal,worldPoint); - break; - default: - { - } - } - - if (hasHit) - { - float lightVec0 = worldNormal.dot(btVector3(0,-1,-1));//0.4f,-1.f,-0.4f)); - float lightVec1= worldNormal.dot(btVector3(-1,0,-1));//-0.4f,-1.f,-0.4f)); - - - rgba = btVector4(lightVec0,lightVec1,0,1.f); - rgba.setMin(btVector3(1,1,1)); - rgba.setMax(btVector3(0.2,0.2,0.2)); - rgba[3] = 1.f; - unsigned char red = rgba[0] * 255; - unsigned char green = rgba[1] * 255; - unsigned char blue = rgba[2] * 255; - unsigned char alpha=255; - m_internalData->m_canvas->setPixel(m_internalData->m_canvasIndex,x,y,red,green,blue,alpha); - - } else - { - // btVector4 rgba = raytracePicture->getPixel(x,y); - } - if (!rgba.length2()) - { - m_internalData->m_canvas->setPixel(m_internalData->m_canvasIndex,x,y,255,0,0,255); - } - } - } - m_internalData->m_canvas->refreshImageData(m_internalData->m_canvasIndex); -} - - -void RaytracerPhysicsSetup::debugDraw(int debugDrawFlags) -{ -} - -bool RaytracerPhysicsSetup::pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) -{ - return false; -} -bool RaytracerPhysicsSetup::movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) -{ - return false; -} -void RaytracerPhysicsSetup::removePickingConstraint() -{ -} - - -void RaytracerPhysicsSetup::syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge) -{ -} \ No newline at end of file diff --git a/Demos/Raytracer/RaytracerSetup.h b/Demos/Raytracer/RaytracerSetup.h deleted file mode 100644 index b7683d410..000000000 --- a/Demos/Raytracer/RaytracerSetup.h +++ /dev/null @@ -1,42 +0,0 @@ -#ifndef RAYTRACER_SETUP_H -#define RAYTRACER_SETUP_H - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -struct RaytracerPhysicsSetup : public CommonPhysicsSetup -{ - - struct RaytracerInternalData* m_internalData; - - RaytracerPhysicsSetup(); - - virtual ~RaytracerPhysicsSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void exitPhysics(); - - virtual void stepSimulation(float deltaTime); - - virtual void debugDraw(int debugDrawFlags); - - virtual bool pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld); - virtual bool movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld); - virtual void removePickingConstraint(); - - virtual void syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge); - - ///worldRaytest performs a ray versus all objects in a collision world, returning true is a hit is found (filling in worldNormal and worldHitPoint) - bool worldRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint); - - ///singleObjectRaytest performs a ray versus one collision shape, returning true is a hit is found (filling in worldNormal and worldHitPoint) - bool singleObjectRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint); - - ///lowlevelRaytest performs a ray versus convex shape, returning true is a hit is found (filling in worldNormal and worldHitPoint) - bool lowlevelRaytest(const btVector3& rayFrom,const btVector3& rayTo,btVector3& worldNormal,btVector3& worldHitPoint); - - -}; - -#endif //RAYTRACER_SETUP_H diff --git a/Demos/Raytracer/main.cpp b/Demos/Raytracer/main.cpp deleted file mode 100644 index dd515294c..000000000 --- a/Demos/Raytracer/main.cpp +++ /dev/null @@ -1,16 +0,0 @@ - -#include "Raytracer.h" -#include "GlutStuff.h" - - -int main(int argc,char** argv) -{ - Raytracer* raytraceDemo = new Raytracer(); - - raytraceDemo->initPhysics(); - - raytraceDemo->setCameraDistance(6.f); - - return glutmain(argc, argv,640,640,"Bullet GJK Implicit Shape Raytracer Demo",raytraceDemo); -} - diff --git a/Demos/RollingFrictionDemo/CMakeLists.txt b/Demos/RollingFrictionDemo/CMakeLists.txt deleted file mode 100644 index 9753cd0df..000000000 --- a/Demos/RollingFrictionDemo/CMakeLists.txt +++ /dev/null @@ -1,70 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppRollingFrictionDemo - main.cpp - RollingFrictionDemo.cpp - RollingFrictionDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppRollingFrictionDemo - main.cpp - RollingFrictionDemo.cpp - RollingFrictionDemo.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppRollingFrictionDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32RollingFrictionDemo.cpp - RollingFrictionDemo.cpp - RollingFrictionDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppRollingFrictionDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppRollingFrictionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppRollingFrictionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/RollingFrictionDemo/Makefile.am b/Demos/RollingFrictionDemo/Makefile.am deleted file mode 100644 index 05546162b..000000000 --- a/Demos/RollingFrictionDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=BasicDemo - -BasicDemo_SOURCES=BasicDemo.cpp BasicDemo.h main.cpp -BasicDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -BasicDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/RollingFrictionDemo/RollingFrictionDemo.cpp b/Demos/RollingFrictionDemo/RollingFrictionDemo.cpp deleted file mode 100644 index 37d11c600..000000000 --- a/Demos/RollingFrictionDemo/RollingFrictionDemo.cpp +++ /dev/null @@ -1,291 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -///create 125 (5x5x5) dynamic object -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - -///scaling of the objects (0.1 = 20 centimeter boxes ) -#define SCALING 1. -#define START_POS_X -5 -#define START_POS_Y -5 -#define START_POS_Z -3 - -#include "RollingFrictionDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" -#include "GLDebugDrawer.h" -static GLDebugDrawer sDebugDraw; -#include //printf debugging - - -void RollingFrictionDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void RollingFrictionDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - - - - -void RollingFrictionDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(SCALING*26.)); - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld->setDebugDrawer(&sDebugDraw); -// m_dynamicsWorld->getSolverInfo().m_singleAxisRollingFrictionThreshold = 0.f;//faster but lower quality - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - { - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(20.),btScalar(50.),btScalar(10.))); - - // btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - groundTransform.setRotation(btQuaternion(btVector3(0,0,1),SIMD_PI*0.03)); - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - body->setFriction(1); - body->setRollingFriction(1); - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - { - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(100.),btScalar(50.),btScalar(100.))); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-54,0)); - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - body->setFriction(1); - body->setRollingFriction(1); - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance -#define NUM_SHAPES 10 - btCollisionShape* colShapes[NUM_SHAPES] = { - new btSphereShape(btScalar(1.)), - new btCapsuleShape(0.5,1), - new btCapsuleShapeX(0.5,1), - new btCapsuleShapeZ(0.5,1), - new btConeShape(0.5,1), - new btConeShapeX(0.5,1), - new btConeShapeZ(0.5,1), - new btCylinderShape(btVector3(0.5,1,0.5)), - new btCylinderShapeX(btVector3(1,0.5,0.5)), - new btCylinderShapeZ(btVector3(0.5,0.5,1)), - }; - for (int i=0;icalculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,colShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - body->setFriction(1.f); - body->setRollingFriction(.3); - body->setAnisotropicFriction(colShape->getAnisotropicRollingFrictionDirection(),btCollisionObject::CF_ANISOTROPIC_ROLLING_FRICTION); - - - m_dynamicsWorld->addRigidBody(body); - } - } - } - } - } - - -} -void RollingFrictionDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void RollingFrictionDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - public: - - RollingFrictionDemo() - { - } - virtual ~RollingFrictionDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - virtual void clientResetScene(); - - static DemoApplication* Create() - { - RollingFrictionDemo* demo = new RollingFrictionDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //_ROLLING_FRICTION_DEMO_H - diff --git a/Demos/RollingFrictionDemo/Win32RollingFrictionDemo.cpp b/Demos/RollingFrictionDemo/Win32RollingFrictionDemo.cpp deleted file mode 100644 index 0439c817f..000000000 --- a/Demos/RollingFrictionDemo/Win32RollingFrictionDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "RollingFrictionDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new RollingFrictionDemo(); -} - -#endif diff --git a/Demos/RollingFrictionDemo/main.cpp b/Demos/RollingFrictionDemo/main.cpp deleted file mode 100644 index 561be99df..000000000 --- a/Demos/RollingFrictionDemo/main.cpp +++ /dev/null @@ -1,41 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "RollingFrictionDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - - - - -int main(int argc,char** argv) -{ - - RollingFrictionDemo ccdDemo; - ccdDemo.initPhysics(); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/SerializeDemo/AMD/CMakeLists.txt b/Demos/SerializeDemo/AMD/CMakeLists.txt deleted file mode 100644 index d6807022f..000000000 --- a/Demos/SerializeDemo/AMD/CMakeLists.txt +++ /dev/null @@ -1,140 +0,0 @@ - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter -${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL -${AMD_OPENCL_INCLUDES} -) - -ADD_DEFINITIONS(-DDESERIALIZE_SOFT_BODIES) -ADD_DEFINITIONS(-DUSE_AMD_OPENCL) -ADD_DEFINITIONS(-DCL_PLATFORM_AMD) - -IF(WIN32) -ADD_DEFINITIONS(-DGLEW_STATIC) -ENDIF(WIN32) - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport - BulletWorldImporter - BulletSoftBody - BulletDynamics - BulletCollision - BulletFileLoader - LinearMath - BulletSoftBodySolvers_OpenCL_AMD - BulletMultiThreaded - ${GLUT_glut_LIBRARY} - ${OPENGL_gl_LIBRARY} - ${OPENGL_glu_LIBRARY} - ${CMAK_GLEW_LIBRARY} - ${CMAKE_ATISTREAMSDK_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppSerializeDemo_AMD - ../main.cpp - ../SerializeDemo.cpp - ../SerializeDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLUtils.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLUtils.h - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLInclude.h - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/clew.c - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/clew.h - - ) - ELSE() - ADD_EXECUTABLE(AppSerializeDemo_AMD - ../main.cpp - ../SerializeDemo.cpp - ../SerializeDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLUtils.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLUtils.h - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLInclude.h - - ) - ENDIF() - -ELSE (USE_GLUT) - - LINK_LIBRARIES( - OpenGLSupport - BulletWorldImporter - BulletSoftBody - BulletDynamics - BulletCollision - BulletFileLoader - LinearMath - BulletSoftBodySolvers_OpenCL_AMD - BulletMultiThreaded - ${OPENGL_gl_LIBRARY} - ${OPENGL_glu_LIBRARY} - ${CMAKE_GLEW_LIBRARY} - ${CMAKE_ATISTREAMSDK_LIBRARY} - ) - - ADD_EXECUTABLE(AppSerializeDemo_AMD - WIN32 - ../../OpenGL/Win32AppMain.cpp - ../Win32SerializeDemo.cpp - ../SerializeDemo.cpp - ../SerializeDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLUtils.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLUtils.h - ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SharedOpenCL/btOpenCLInclude.h - ) -ENDIF (USE_GLUT) - -IF(WIN32) -IF (CMAKE_CL_64) - IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - ADD_CUSTOM_COMMAND( TARGET AppSerializeDemo_AMD POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR} ) - ENDIF() -ELSE(CMAKE_CL_64) - IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES) - ADD_CUSTOM_COMMAND( TARGET AppSerializeDemo_AMD POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}) - ENDIF() -ENDIF(CMAKE_CL_64) -ENDIF(WIN32) - - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES AND NOT INTERNAL_UPDATE_SERIALIZATION_STRUCTURES) - ADD_CUSTOM_COMMAND( - TARGET AppSerializeDemo_AMD - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SerializeDemo/testFileCloth.bullet ${CMAKE_CURRENT_BINARY_DIR}/testFile.bullet - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/ApplyForces.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/ApplyForces.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/ComputeBounds.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/ComputeBounds.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/Integrate.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/Integrate.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/OutputToVertexArray.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/OutputToVertexArray.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/PrepareLinks.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/PrepareLinks.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/SolveCollisionsAndUpdateVelocities.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/SolveCollisionsAndUpdateVelocities.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/SolveCollisionsAndUpdateVelocitiesSIMDBatched.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/SolveCollisionsAndUpdateVelocitiesSIMDBatched.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/SolvePositions.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/SolvePositions.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/SolvePositionsSIMDBatched.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/SolvePositionsSIMDBatched.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdateConstants.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/UpdateConstants.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdateFixedVertexPositions.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/UpdateFixedVertexPositions.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdateNodes.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/UpdateNodes.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdateNormals.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/UpdateNormals.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdatePositions.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/UpdatePositions.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdatePositionsFromVelocities.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/UpdatePositionsFromVelocities.cl - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/VSolveLinks.cl ${CMAKE_CURRENT_BINARY_DIR}/OpenCLC10/VSolveLinks.cl - - ) -ENDIF () - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppSerializeDemo_AMD PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppSerializeDemo_AMD PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppSerializeDemo_AMD PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos/SerializeDemo/AMD/premake4.lua b/Demos/SerializeDemo/AMD/premake4.lua deleted file mode 100644 index a3a52a3b7..000000000 --- a/Demos/SerializeDemo/AMD/premake4.lua +++ /dev/null @@ -1,65 +0,0 @@ - - hasCL = findOpenCL_AMD() - - if (hasCL) then - - project "AppOpenCLClothDemo_AMD" - - defines { "USE_AMD_OPENCL","CL_PLATFORM_AMD"} - - initOpenCL_AMD() - - language "C++" - - kind "ConsoleApp" - targetdir "../../.." - - libdirs {"../../../Glut"} - - links { - "LinearMath", - "BulletCollision", - "BulletDynamics", - "BulletSoftBody", - "BulletSoftBodySolvers_OpenCL_AMD", - "opengl32" - } - - configuration "x64" - links { - "glut64", - "glew64s" - } - configuration "x32" - links { - "glut32", - "glew32s" - } - - configuration{} - - - includedirs { - "../../../src", - "../../../Glut", - "../../SharedOpenCL", - "../../OpenGL" - } - - files { - "../cl_cloth_demo.cpp", - "../../SharedOpenCL/btOclUtils.h", - "../../SharedOpenCL/btOclCommon.h", - "../../SharedOpenCL/btOclUtils.cpp", - "../../SharedOpenCL/btOclCommon.cpp", - "../../OpenGL/GLDebugDrawer.cpp", - "../../OpenGL/stb_image.cpp", - "../../OpenGL/stb_image.h", - "../gl_win.cpp", - "../clstuff.cpp", - "../clstuff.h", - "../gl_win.h", - "../cloth.h" - } - - end \ No newline at end of file diff --git a/Demos/SerializeDemo/CMakeLists.txt b/Demos/SerializeDemo/CMakeLists.txt deleted file mode 100644 index 9cf57df25..000000000 --- a/Demos/SerializeDemo/CMakeLists.txt +++ /dev/null @@ -1,80 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -IF(BUILD_AMD_OPENCL_DEMOS AND BUILD_MULTITHREADING) - SUBDIRS(AMD) -ENDIF() - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader -${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter -${GLUT_INCLUDE_DIR} - -) - -ADD_DEFINITIONS(-DDESERIALIZE_SOFT_BODIES) - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppSerializeDemo - main.cpp - SerializeDemo.cpp - SerializeDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppSerializeDemo - main.cpp - SerializeDemo.cpp - SerializeDemo.h - ) - ENDIF() - -ELSE (USE_GLUT) - - LINK_LIBRARIES( - OpenGLSupport BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - ADD_EXECUTABLE(AppSerializeDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32SerializeDemo.cpp - SerializeDemo.cpp - SerializeDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ENDIF (USE_GLUT) - -IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES AND NOT INTERNAL_UPDATE_SERIALIZATION_STRUCTURES) - ADD_CUSTOM_COMMAND( - TARGET AppSerializeDemo - POST_BUILD - COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SerializeDemo/testFile.bullet ${CMAKE_CURRENT_BINARY_DIR}/testFile.bullet - ) -ENDIF () - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppSerializeDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppSerializeDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppSerializeDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - - diff --git a/Demos/SerializeDemo/SerializeDemo.cpp b/Demos/SerializeDemo/SerializeDemo.cpp deleted file mode 100644 index d6deddf78..000000000 --- a/Demos/SerializeDemo/SerializeDemo.cpp +++ /dev/null @@ -1,969 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2010 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#define TEST_SERIALIZATION 1 -//#undef DESERIALIZE_SOFT_BODIES - -#ifdef BT_INTERNAL_UPDATE_SERIALIZATION_STRUCTURES -#define CREATE_NEW_BULLETFILE 1 -#endif //BT_INTERNAL_UPDATE_SERIALIZATION_STRUCTURES - -///create 125 (5x5x5) dynamic object -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - -///scaling of the objects (0.1 = 20 centimeter boxes ) -#define SCALING 1. -#define START_POS_X -5 -#define START_POS_Y -5 -#define START_POS_Z -3 - -#include "SerializeDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" -#ifdef TEST_SERIALIZATION -#include "LinearMath/btSerializer.h" -#include "btBulletFile.h" -#include "btBulletWorldImporter.h" -#endif //TEST_SERIALIZATION - -#include "BulletCollision/Gimpact/btGImpactCollisionAlgorithm.h" -#include //printf debugging - - - -#ifdef DESERIALIZE_SOFT_BODIES -#include "BulletSoftBody/btSoftBodySolvers.h" - - -#ifdef USE_AMD_OPENCL - #include - #include - #include "../SharedOpenCL/btOpenCLUtils.h" - - extern cl_context g_cxMainContext; - extern cl_device_id g_cdDevice; - extern cl_command_queue g_cqCommandQue; -#endif - -btSoftBodySolver* fSoftBodySolver=0; - -#include "BulletSoftBody/btSoftBodyHelpers.h" -#include "BulletSoftBody/btSoftRigidDynamicsWorld.h" -#include "BulletSoftBody/btSoftBodyRigidBodyCollisionConfiguration.h" -#endif - -void SerializeDemo::keyboardCallback(unsigned char key, int x, int y) -{ - btAlignedObjectArray bodies; - if (key == 'g') - { - int numManifolds = getDynamicsWorld()->getDispatcher()->getNumManifolds(); - - for (int i=0;igetDispatcher()->getManifoldByIndexInternal(i); - if (!manifold->getNumContacts()) - continue; - - btScalar minDist = 1e30f; - int minIndex = -1; - for (int v=0;vgetNumContacts();v++) - { - if (minDist >manifold->getContactPoint(v).getDistance()) - { - minDist = manifold->getContactPoint(v).getDistance(); - minIndex = v; - } - } - if (minDist>0.) - continue; - - btCollisionObject* colObj0 = (btCollisionObject*)manifold->getBody0(); - btCollisionObject* colObj1 = (btCollisionObject*)manifold->getBody1(); - // int tag0 = (colObj0)->getIslandTag(); - // int tag1 = (colObj1)->getIslandTag(); - btRigidBody* body0 = btRigidBody::upcast(colObj0); - btRigidBody* body1 = btRigidBody::upcast(colObj1); - if (bodies.findLinearSearch(body0)==bodies.size()) - bodies.push_back(body0); - if (bodies.findLinearSearch(body1)==bodies.size()) - bodies.push_back(body1); - - if (body0 && body1) - { - if (!colObj0->isStaticOrKinematicObject() && !colObj1->isStaticOrKinematicObject()) - { - if (body0->checkCollideWithOverride(body1)) - { - { - btTransform trA,trB; - trA.setIdentity(); - trB.setIdentity(); - btVector3 contactPosWorld = manifold->getContactPoint(minIndex).m_positionWorldOnA; - btTransform globalFrame; - globalFrame.setIdentity(); - globalFrame.setOrigin(contactPosWorld); - - trA = body0->getWorldTransform().inverse()*globalFrame; - trB = body1->getWorldTransform().inverse()*globalFrame; - - btGeneric6DofConstraint* dof6 = new btGeneric6DofConstraint(*body0,*body1,trA,trB,true); - dof6->setOverrideNumSolverIterations(100); - - dof6->setBreakingImpulseThreshold(35); - - for (int i=0;i<6;i++) - dof6->setLimit(i,0,0); - getDynamicsWorld()->addConstraint(dof6,true); - - } - } - } - } - - } - - for (int i=0;iremoveRigidBody(bodies[i]); - getDynamicsWorld()->addRigidBody(bodies[i]); - } - }else - { - PlatformDemoApplication::keyboardCallback(key,x,y); - } -} - - -void SerializeDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - - -#ifdef DESERIALIZE_SOFT_BODIES - if (fSoftBodySolver) - fSoftBodySolver->copyBackToSoftBodies(); -#endif - - m_dynamicsWorld->debugDrawWorld(); - -#ifdef DESERIALIZE_SOFT_BODIES - if (m_dynamicsWorld->getWorldType()==BT_SOFT_RIGID_DYNAMICS_WORLD) - { - //optional but useful: debug drawing - btSoftRigidDynamicsWorld* softWorld = (btSoftRigidDynamicsWorld*)m_dynamicsWorld; - - for ( int i=0;igetSoftBodyArray().size();i++) - { - btSoftBody* psb=(btSoftBody*)softWorld->getSoftBodyArray()[i]; - if (softWorld->getDebugDrawer() && !(softWorld->getDebugDrawer()->getDebugMode() & (btIDebugDraw::DBG_DrawWireframe))) - { - btSoftBodyHelpers::DrawFrame(psb,softWorld->getDebugDrawer()); - btSoftBodyHelpers::Draw(psb,softWorld->getDebugDrawer(),softWorld->getDrawFlags()); - } - } - } -#endif //DESERIALIZE_SOFT_BODIES - - } - - renderme(); - - glFlush(); - - swapBuffers(); - -} -#ifdef USE_AMD_OPENCL - -///the CachingCLFuncs class will try to create/load precompiled binary programs, instead of the slow on-line compilation of programs -class CachingCLFuncs : public CLFunctions -{ - cl_device_id m_device; - - public: - - CachingCLFuncs (cl_command_queue cqCommandQue, cl_context cxMainContext, cl_device_id device) - :CLFunctions(cqCommandQue,cxMainContext), - m_device(device) - { - } - - virtual cl_kernel compileCLKernelFromString( const char* kernelSource, const char* kernelName, const char* additionalMacros, const char* srcFileNameForCaching) - { - - cl_int pErrNum; - cl_program prog; - - prog = btOpenCLUtils::compileCLProgramFromFile( m_cxMainContext,m_device, &pErrNum,additionalMacros ,srcFileNameForCaching); - if (!prog) - { - printf("Using embedded kernel source instead:\n"); - prog = btOpenCLUtils::compileCLProgramFromString( m_cxMainContext,m_device, kernelSource, &pErrNum,additionalMacros); - } - - return btOpenCLUtils::compileCLKernelFromString( m_cxMainContext,m_device, kernelSource, kernelName, &pErrNum, prog,additionalMacros); - } - -}; -#endif - - -void SerializeDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - if (m_dynamicsWorld->getWorldType()==BT_SOFT_RIGID_DYNAMICS_WORLD) - { -#ifdef DESERIALIZE_SOFT_BODIES - - //optional but useful: debug drawing - btSoftRigidDynamicsWorld* softWorld = (btSoftRigidDynamicsWorld*)m_dynamicsWorld; - - for ( int i=0;igetSoftBodyArray().size();i++) - { - btSoftBody* psb=(btSoftBody*)softWorld->getSoftBodyArray()[i]; - if (softWorld->getDebugDrawer() && !(softWorld->getDebugDrawer()->getDebugMode() & (btIDebugDraw::DBG_DrawWireframe))) - { - btSoftBodyHelpers::DrawFrame(psb,softWorld->getDebugDrawer()); - btSoftBodyHelpers::Draw(psb,softWorld->getDebugDrawer(),softWorld->getDrawFlags()); - } - } -#endif //DESERIALIZE_SOFT_BODIES - } - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - -enum SolverType -{ - kSolverAccelerationOpenCL_CPU = 1, - kSolverAccelerationOpenCL_GPU = 2, - kSolverAccelerationNone = 3 -}; - - -void SerializeDemo::setupEmptyDynamicsWorld() -{ - ///collision configuration contains default setup for memory, collision setup - //m_collisionConfiguration = new btDefaultCollisionConfiguration(); -#ifdef DESERIALIZE_SOFT_BODIES - m_collisionConfiguration = new btSoftBodyRigidBodyCollisionConfiguration(); -#else - m_collisionConfiguration = new btDefaultCollisionConfiguration(); -#endif //DESERIALIZE_SOFT_BODIES - - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - btGImpactCollisionAlgorithm::registerAlgorithm(m_dispatcher); - - m_broadphase = new btDbvtBroadphase(); - - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - -#ifdef DESERIALIZE_SOFT_BODIES - - - - #ifdef USE_AMD_OPENCL - - int solverAccel = kSolverAccelerationOpenCL_GPU; - - if ( 1 ) { - switch (solverAccel) - { - case kSolverAccelerationOpenCL_GPU: - { - btOpenCLSoftBodySolverSIMDAware* softSolv= new btOpenCLSoftBodySolverSIMDAware( g_cqCommandQue, g_cxMainContext ); - //btOpenCLSoftBodySolver* softSolv= new btOpenCLSoftBodySolver( g_cqCommandQue, g_cxMainContext); - fSoftBodySolver = softSolv; - - CLFunctions* funcs = new CachingCLFuncs(g_cqCommandQue, g_cxMainContext,g_cdDevice); - softSolv->setCLFunctions(funcs); - - - break; - } - case kSolverAccelerationOpenCL_CPU: - { - //fSoftBodySolver = new btCPUSoftBodySolver(); - break; - }; - case kSolverAccelerationNone: - default: - { - fSoftBodySolver = NULL; - } - }; - } - else - { - if ( solverAccel != kSolverAccelerationNone ) - { - } - else - { - } - fSoftBodySolver = NULL; - } -#else - - fSoftBodySolver = NULL; -#endif - - btSoftRigidDynamicsWorld* world = new btSoftRigidDynamicsWorld(m_dispatcher, m_broadphase, m_solver, - m_collisionConfiguration, fSoftBodySolver); - m_dynamicsWorld = world; - - - //world->setDrawFlags(world->getDrawFlags()^fDrawFlags::Clusters); -#else - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - //m_dynamicsWorld ->getSolverInfo().m_solverMode|=SOLVER_RANDMIZE_ORDER; - //m_dynamicsWorld->getDispatchInfo().m_enableSatConvex = true; - //m_dynamicsWorld->getSolverInfo().m_splitImpulse=true; -#endif //DESERIALIZE_SOFT_BODIES - - //btGImpactCollisionAlgorithm::registerAlgorithm((btCollisionDispatcher*)m_dynamicsWorld->getDispatcher()); - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - -} - - -#ifdef DESERIALIZE_SOFT_BODIES -#include "BulletSoftBody/btSoftBodyData.h" -class MySoftBulletWorldImporter : public btBulletWorldImporter -{ - - btSoftRigidDynamicsWorld* m_softRigidWorld; - - btHashMap m_materialMap; - - btHashMap m_clusterBodyMap; - btHashMap m_softBodyMap; - - - -public: - - MySoftBulletWorldImporter(btSoftRigidDynamicsWorld* world) - :btBulletWorldImporter(world), - m_softRigidWorld(world) - { - - } - - virtual ~MySoftBulletWorldImporter() - { - - } - - virtual bool convertAllObjects( bParse::btBulletFile* bulletFile2) - { - bool result = btBulletWorldImporter::convertAllObjects(bulletFile2); - int i; - //now the soft bodies - for (i=0;im_softBodies.size();i++) - { - if (bulletFile2->getFlags() & bParse::FD_DOUBLE_PRECISION) - { - btAssert(0); //not yet - //btSoftBodyFloatData* softBodyData = (btSoftBodyFloatData*)bulletFile2->m_softBodies[i]; - } else - { - btSoftBodyFloatData* softBodyData = (btSoftBodyFloatData*)bulletFile2->m_softBodies[i]; - int i; - int numNodes = softBodyData->m_numNodes; - - - btSoftBody* psb=new btSoftBody(&m_softRigidWorld->getWorldInfo()); - m_softBodyMap.insert(softBodyData,psb); - - //materials - for (i=0;im_numMaterials;i++) - { - SoftBodyMaterialData* matData = softBodyData->m_materials[i]; - btSoftBody::Material** matPtr = m_materialMap.find(matData); - btSoftBody::Material* mat = 0; - if (matPtr&& *matPtr) - { - mat = *matPtr; - } else - { - mat = psb->appendMaterial(); - mat->m_flags = matData->m_flags; - mat->m_kAST = matData->m_angularStiffness; - mat->m_kLST = matData->m_linearStiffness; - mat->m_kVST = matData->m_volumeStiffness; - m_materialMap.insert(matData,mat); - } - } - - - - - for (i=0;im_nodes[i]; - btVector3 position; - position.deSerializeFloat(nodeData.m_position); - btScalar mass = nodeData.m_inverseMass? 1./nodeData.m_inverseMass : 0.f; - psb->appendNode(position,mass); - btSoftBody::Node* node = &psb->m_nodes[psb->m_nodes.size()-1]; - node->m_area = nodeData.m_area; - node->m_battach = nodeData.m_attach; - node->m_f.deSerializeFloat(nodeData.m_accumulatedForce); - node->m_im = nodeData.m_inverseMass; - - btSoftBody::Material** matPtr = m_materialMap.find(nodeData.m_material); - if (matPtr && *matPtr) - { - node->m_material = *matPtr; - } else - { - printf("no mat?\n"); - } - - node->m_n.deSerializeFloat(nodeData.m_normal); - node->m_q = node->m_x; - node->m_v.deSerializeFloat(nodeData.m_velocity); - - } - - for (i=0;im_numLinks;i++) - { - SoftBodyLinkData& linkData = softBodyData->m_links[i]; - btSoftBody::Material** matPtr = m_materialMap.find(linkData.m_material); - if (matPtr && *matPtr) - { - psb->appendLink(linkData.m_nodeIndices[0],linkData.m_nodeIndices[1],*matPtr); - } else - { - psb->appendLink(linkData.m_nodeIndices[0],linkData.m_nodeIndices[1]); - } - btSoftBody::Link* link = &psb->m_links[psb->m_links.size()-1]; - link->m_bbending = linkData.m_bbending; - link->m_rl = linkData.m_restLength; - } - - for (i=0;im_numFaces;i++) - { - SoftBodyFaceData& faceData = softBodyData->m_faces[i]; - btSoftBody::Material** matPtr = m_materialMap.find(faceData.m_material); - if (matPtr && *matPtr) - { - psb->appendFace(faceData.m_nodeIndices[0],faceData.m_nodeIndices[1],faceData.m_nodeIndices[2],*matPtr); - } else - { - psb->appendFace(faceData.m_nodeIndices[0],faceData.m_nodeIndices[1],faceData.m_nodeIndices[2]); - } - btSoftBody::Face* face = &psb->m_faces[psb->m_faces.size()-1]; - face->m_normal.deSerializeFloat(faceData.m_normal); - face->m_ra = faceData.m_restArea; - } - - - - //anchors - for (i=0;im_numAnchors;i++) - { - btCollisionObject** colAptr = m_bodyMap.find(softBodyData->m_anchors[i].m_rigidBody); - if (colAptr && *colAptr) - { - btRigidBody* body = btRigidBody::upcast(*colAptr); - if (body) - { - bool disableCollision = false; - btVector3 localPivot; - localPivot.deSerializeFloat(softBodyData->m_anchors[i].m_localFrame); - psb->appendAnchor(softBodyData->m_anchors[i].m_nodeIndex,body,localPivot, disableCollision); - } - } - } - - if (softBodyData->m_pose) - { - psb->m_pose.m_aqq.deSerializeFloat( softBodyData->m_pose->m_aqq); - psb->m_pose.m_bframe = (softBodyData->m_pose->m_bframe!=0); - psb->m_pose.m_bvolume = (softBodyData->m_pose->m_bvolume!=0); - psb->m_pose.m_com.deSerializeFloat(softBodyData->m_pose->m_com); - - psb->m_pose.m_pos.resize(softBodyData->m_pose->m_numPositions); - for (i=0;im_pose->m_numPositions;i++) - { - psb->m_pose.m_pos[i].deSerializeFloat(softBodyData->m_pose->m_positions[i]); - } - psb->m_pose.m_rot.deSerializeFloat(softBodyData->m_pose->m_rot); - psb->m_pose.m_scl.deSerializeFloat(softBodyData->m_pose->m_scale); - psb->m_pose.m_wgh.resize(softBodyData->m_pose->m_numWeigts); - for (i=0;im_pose->m_numWeigts;i++) - { - psb->m_pose.m_wgh[i] = softBodyData->m_pose->m_weights[i]; - } - psb->m_pose.m_volume = softBodyData->m_pose->m_restVolume; - } - -#if 1 - psb->m_cfg.piterations=softBodyData->m_config.m_positionIterations; - psb->m_cfg.diterations=softBodyData->m_config.m_driftIterations; - psb->m_cfg.citerations=softBodyData->m_config.m_clusterIterations; - psb->m_cfg.viterations=softBodyData->m_config.m_velocityIterations; - - //psb->setTotalMass(0.1); - psb->m_cfg.aeromodel = (btSoftBody::eAeroModel::_)softBodyData->m_config.m_aeroModel; - psb->m_cfg.kLF = softBodyData->m_config.m_lift; - psb->m_cfg.kDG = softBodyData->m_config.m_drag; - psb->m_cfg.kMT = softBodyData->m_config.m_poseMatch; - psb->m_cfg.collisions = softBodyData->m_config.m_collisionFlags; - psb->m_cfg.kDF = 1.f;//softBodyData->m_config.m_dynamicFriction; - psb->m_cfg.kDP = softBodyData->m_config.m_damping; - psb->m_cfg.kPR = softBodyData->m_config.m_pressure; - psb->m_cfg.kVC = softBodyData->m_config.m_volume; - psb->m_cfg.kAHR = softBodyData->m_config.m_anchorHardness; - psb->m_cfg.kKHR = softBodyData->m_config.m_kineticContactHardness; - psb->m_cfg.kSHR = softBodyData->m_config.m_softContactHardness; - psb->m_cfg.kSRHR_CL = softBodyData->m_config.m_softRigidClusterHardness; - psb->m_cfg.kSKHR_CL = softBodyData->m_config.m_softKineticClusterHardness; - psb->m_cfg.kSSHR_CL = softBodyData->m_config.m_softSoftClusterHardness; -#endif - -// pm->m_kLST = 1; - -#if 1 - //clusters - if (softBodyData->m_numClusters) - { - m_clusterBodyMap.insert(softBodyData->m_clusters,psb); - int j; - psb->m_clusters.resize(softBodyData->m_numClusters); - for (i=0;im_numClusters;i++) - { - psb->m_clusters[i] = new(btAlignedAlloc(sizeof(btSoftBody::Cluster),16)) btSoftBody::Cluster(); - psb->m_clusters[i]->m_adamping = softBodyData->m_clusters[i].m_adamping; - psb->m_clusters[i]->m_av.deSerializeFloat(softBodyData->m_clusters[i].m_av); - psb->m_clusters[i]->m_clusterIndex = softBodyData->m_clusters[i].m_clusterIndex; - psb->m_clusters[i]->m_collide = (softBodyData->m_clusters[i].m_collide!=0); - psb->m_clusters[i]->m_com.deSerializeFloat(softBodyData->m_clusters[i].m_com); - psb->m_clusters[i]->m_containsAnchor = (softBodyData->m_clusters[i].m_containsAnchor!=0); - psb->m_clusters[i]->m_dimpulses[0].deSerializeFloat(softBodyData->m_clusters[i].m_dimpulses[0]); - psb->m_clusters[i]->m_dimpulses[1].deSerializeFloat(softBodyData->m_clusters[i].m_dimpulses[1]); - - psb->m_clusters[i]->m_framerefs.resize(softBodyData->m_clusters[i].m_numFrameRefs); - for (j=0;jm_clusters[i].m_numFrameRefs;j++) - { - psb->m_clusters[i]->m_framerefs[j].deSerializeFloat(softBodyData->m_clusters[i].m_framerefs[j]); - } - psb->m_clusters[i]->m_nodes.resize(softBodyData->m_clusters[i].m_numNodes); - for (j=0;jm_clusters[i].m_numNodes;j++) - { - int nodeIndex = softBodyData->m_clusters[i].m_nodeIndices[j]; - psb->m_clusters[i]->m_nodes[j] = &psb->m_nodes[nodeIndex]; - } - - psb->m_clusters[i]->m_masses.resize(softBodyData->m_clusters[i].m_numMasses); - for (j=0;jm_clusters[i].m_numMasses;j++) - { - psb->m_clusters[i]->m_masses[j] = softBodyData->m_clusters[i].m_masses[j]; - } - psb->m_clusters[i]->m_framexform.deSerializeFloat(softBodyData->m_clusters[i].m_framexform); - psb->m_clusters[i]->m_idmass = softBodyData->m_clusters[i].m_idmass; - psb->m_clusters[i]->m_imass = softBodyData->m_clusters[i].m_imass; - psb->m_clusters[i]->m_invwi.deSerializeFloat(softBodyData->m_clusters[i].m_invwi); - psb->m_clusters[i]->m_ldamping = softBodyData->m_clusters[i].m_ldamping; - psb->m_clusters[i]->m_locii.deSerializeFloat(softBodyData->m_clusters[i].m_locii); - psb->m_clusters[i]->m_lv.deSerializeFloat(softBodyData->m_clusters[i].m_lv); - psb->m_clusters[i]->m_matching = softBodyData->m_clusters[i].m_matching; - psb->m_clusters[i]->m_maxSelfCollisionImpulse = 0;//softBodyData->m_clusters[i].m_maxSelfCollisionImpulse; - psb->m_clusters[i]->m_ndamping = softBodyData->m_clusters[i].m_ndamping; - psb->m_clusters[i]->m_ndimpulses = softBodyData->m_clusters[i].m_ndimpulses; - psb->m_clusters[i]->m_nvimpulses = softBodyData->m_clusters[i].m_nvimpulses; - psb->m_clusters[i]->m_selfCollisionImpulseFactor = softBodyData->m_clusters[i].m_selfCollisionImpulseFactor; - psb->m_clusters[i]->m_vimpulses[0].deSerializeFloat(softBodyData->m_clusters[i].m_vimpulses[0]); - psb->m_clusters[i]->m_vimpulses[1].deSerializeFloat(softBodyData->m_clusters[i].m_vimpulses[1]); - - } - //psb->initializeClusters(); - //psb->updateClusters(); - - } -#else - - psb->m_cfg.piterations = 2; - psb->m_cfg.collisions = btSoftBody::fCollision::CL_SS+ btSoftBody::fCollision::CL_RS; - //psb->setTotalMass(50,true); - //psb->generateClusters(64); - //psb->m_cfg.kDF=1; - psb->generateClusters(8); - - -#endif // - - - - psb->updateConstants(); - m_softRigidWorld->getWorldInfo().m_dispatcher = m_softRigidWorld->getDispatcher(); - - m_softRigidWorld->addSoftBody(psb); - - - } - } - - - //now the soft body joints - for (i=0;im_softBodies.size();i++) - { - if (bulletFile2->getFlags() & bParse::FD_DOUBLE_PRECISION) - { - btAssert(0); //not yet - //btSoftBodyFloatData* softBodyData = (btSoftBodyFloatData*)bulletFile2->m_softBodies[i]; - } else - { - btSoftBodyFloatData* softBodyData = (btSoftBodyFloatData*)bulletFile2->m_softBodies[i]; - btSoftBody** sbp = m_softBodyMap.find(softBodyData); - if (sbp && *sbp) - { - btSoftBody* sb = *sbp; - for (int i=0;im_numJoints;i++) - { - btSoftBodyJointData* sbjoint = &softBodyData->m_joints[i]; - - - btSoftBody::Body bdyB; - - btSoftBody* sbB = 0; - btTransform transA; - transA.setIdentity(); - transA = sb->m_clusters[0]->m_framexform; - - btCollisionObject** colBptr = m_bodyMap.find(sbjoint->m_bodyB); - if (colBptr && *colBptr) - { - btRigidBody* rbB = btRigidBody::upcast(*colBptr); - if (rbB) - { - bdyB = rbB; - } else - { - bdyB = *colBptr; - } - } - - - btSoftBody** bodyBptr = m_clusterBodyMap.find(sbjoint->m_bodyB); - if (bodyBptr && *bodyBptr ) - { - sbB = *bodyBptr; - bdyB = sbB->m_clusters[0]; - } - - - if (sbjoint->m_jointType==btSoftBody::Joint::eType::Linear) - { - btSoftBody::LJoint::Specs specs; - specs.cfm = sbjoint->m_cfm; - specs.erp = sbjoint->m_erp; - specs.split = sbjoint->m_split; - btVector3 relA; - relA.deSerializeFloat(sbjoint->m_refs[0]); - specs.position = transA*relA; - sb->appendLinearJoint(specs,sb->m_clusters[0],bdyB); - } - - if (sbjoint->m_jointType==btSoftBody::Joint::eType::Angular) - { - btSoftBody::AJoint::Specs specs; - specs.cfm = sbjoint->m_cfm; - specs.erp = sbjoint->m_erp; - specs.split = sbjoint->m_split; - btVector3 relA; - relA.deSerializeFloat(sbjoint->m_refs[0]); - specs.axis = transA.getBasis()*relA; - sb->appendAngularJoint(specs,sb->m_clusters[0],bdyB); - } - } - } - - } - } - - return result; - - } -}; -#endif //DESERIALIZE_SOFT_BODIES - -SerializeDemo::SerializeDemo() -:m_verboseMode(0), -m_fileName("testFile.bullet") -{ - m_idle=true; - -} -SerializeDemo::~SerializeDemo() -{ - m_fileLoader->deleteAllData(); - delete m_fileLoader; - exitPhysics(); -} - -void SerializeDemo::initPhysics() -{ - setTexturing(true); - setShadows(false);//true); - - setCameraDistance(btScalar(SCALING*30.)); - - setupEmptyDynamicsWorld(); - -#ifdef DESERIALIZE_SOFT_BODIES - m_fileLoader = new MySoftBulletWorldImporter((btSoftRigidDynamicsWorld*)m_dynamicsWorld); -#else - m_fileLoader = new btBulletWorldImporter(m_dynamicsWorld); -#endif //DESERIALIZE_SOFT_BODIES - - m_fileLoader->setVerboseMode(m_verboseMode); - - const char* filename = "testFile.bullet"; - - const char* prefix[]={"./","../","../../","../../../","../../../../", "SerializeDemo/", "Demos/SerializeDemo/", - "../Demos/SerializeDemo/","../../Demos/SerializeDemo/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - bool fileFound = false; - - for (int i=0;iloadFile(relativeFileName, "testFileSwappedEndianness.bullet")) -// if (!m_fileLoader->loadFile("../SoftDemo/testFile.bullet")) - { - ///create a few basic rigid bodies and save them to testFile.bullet - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); - // btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - btCollisionObject* groundObject = 0; - - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - groundObject = body; - } - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - int numSpheres = 2; - btVector3 positions[2] = {btVector3(0.1f,0.2f,0.3f),btVector3(0.4f,0.5f,0.6f)}; - btScalar radii[2] = {0.3f,0.4f}; - - btMultiSphereShape* colShape = new btMultiSphereShape(positions,radii,numSpheres); - - //btCollisionShape* colShape = new btCapsuleShapeZ(SCALING*1,SCALING*1); - //btCollisionShape* colShape = new btCylinderShapeZ(btVector3(SCALING*1,SCALING*1,SCALING*1)); - //btCollisionShape* colShape = new btBoxShape(btVector3(SCALING*1,SCALING*1,SCALING*1)); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - float start_x = START_POS_X - ARRAY_SIZE_X/2; - float start_y = START_POS_Y; - float start_z = START_POS_Z - ARRAY_SIZE_Z/2; - - for (int k=0;kaddRigidBody(body); - //body->setActivationState(ISLAND_SLEEPING); - } - } - } - } - - int maxSerializeBufferSize = 1024*1024*5; - - btDefaultSerializer* serializer = new btDefaultSerializer(maxSerializeBufferSize); - - static const char* groundName = "GroundName"; - serializer->registerNameForPointer(groundObject, groundName); - - for (int i=0;iregisterNameForPointer(m_collisionShapes[i],name); - } - - btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*(btRigidBody*)getDynamicsWorld()->getCollisionObjectArray()[2],btVector3(0,1,0)); - m_dynamicsWorld->addConstraint(p2p); - - const char* name = "constraintje"; - serializer->registerNameForPointer(p2p,name); - - m_dynamicsWorld->serialize(serializer); -#if 1 - FILE* f2 = fopen("testFile.bullet","wb"); - fwrite(serializer->getBufferPointer(),serializer->getCurrentBufferSize(),1,f2); - fclose(f2); -#endif - - } - - //clientResetScene(); - -} - - -void SerializeDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - //removed/delete constraints - int i; - for (i=m_dynamicsWorld->getNumConstraints()-1; i>=0 ;i--) - { - btTypedConstraint* constraint = m_dynamicsWorld->getConstraint(i); - m_dynamicsWorld->removeConstraint(constraint); - delete constraint; - } - - //remove the rigidbodies from the dynamics world and delete them - - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - class btBulletWorldImporter* m_fileLoader; - const char* m_fileName; - int m_verboseMode; - - public: - - SerializeDemo(); - virtual ~SerializeDemo(); - - void initPhysics(); - - void setupEmptyDynamicsWorld(); - - void exitPhysics(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - void setFileName(const char* name) - { - m_fileName = name; - } - const char* getFileName() const - { - return m_fileName; - } - - void setVerboseMode(int mode) - { - m_verboseMode = mode; - } - int getVerboseMode() const - { - return m_verboseMode; - } - - static DemoApplication* Create() - { - SerializeDemo* demo = new SerializeDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //SERIALIZE_DEMO_H - diff --git a/Demos/SerializeDemo/SerializeSetup.cpp b/Demos/SerializeDemo/SerializeSetup.cpp deleted file mode 100644 index e0773b58e..000000000 --- a/Demos/SerializeDemo/SerializeSetup.cpp +++ /dev/null @@ -1,61 +0,0 @@ -#include "SerializeSetup.h" -#include "../Extras/Serialize/BulletWorldImporter/btBulletWorldImporter.h" - -SerializeSetup::SerializeSetup() -{ - -} -SerializeSetup::~SerializeSetup() -{ - -} - -void SerializeSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - this->createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawWireframe+btIDebugDraw::DBG_DrawContactPoints); - btBulletWorldImporter* importer = new btBulletWorldImporter(m_dynamicsWorld); - const char* someFileName="spider.bullet"; - - const char* prefix[]={"./","./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - FILE* f=0; - bool fileFound = false; - int result = 0; - - for (int i=0;!f && iloadFile(relativeFileName); - - //for now, guess the up axis from gravity - if (m_dynamicsWorld->getGravity()[1] == 0.f) - { - gfxBridge.setUpAxis(2); - } else - { - gfxBridge.setUpAxis(1); - } - - gfxBridge.autogenerateGraphicsObjects(m_dynamicsWorld); -} - -void SerializeSetup::stepSimulation(float deltaTime) -{ - CommonRigidBodySetup::stepSimulation(deltaTime); -} diff --git a/Demos/SerializeDemo/SerializeSetup.h b/Demos/SerializeDemo/SerializeSetup.h deleted file mode 100644 index 843135540..000000000 --- a/Demos/SerializeDemo/SerializeSetup.h +++ /dev/null @@ -1,15 +0,0 @@ -#ifndef SERIALIZE_SETUP_H -#define SERIALIZE_SETUP_H -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -class SerializeSetup : public CommonRigidBodySetup -{ -public: - SerializeSetup(); - virtual ~SerializeSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - virtual void stepSimulation(float deltaTime); -}; - -#endif //SERIALIZE_SETUP_H diff --git a/Demos/SerializeDemo/Win32SerializeDemo.cpp b/Demos/SerializeDemo/Win32SerializeDemo.cpp deleted file mode 100644 index 0cf13e86b..000000000 --- a/Demos/SerializeDemo/Win32SerializeDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2010 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "SerializeDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new SerializeDemo(); -} - -#endif diff --git a/Demos/SerializeDemo/main.cpp b/Demos/SerializeDemo/main.cpp deleted file mode 100644 index 87b88f8f0..000000000 --- a/Demos/SerializeDemo/main.cpp +++ /dev/null @@ -1,134 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "SerializeDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" -#include "btBulletFile.h" -#include "CommandLineArguments.h" - - -#ifdef USE_AMD_OPENCL - - - -#include "btOpenCLUtils.h" - -#include - -cl_context g_cxMainContext; -cl_device_id g_cdDevice; -cl_command_queue g_cqCommandQue; - - -// Returns true if OpenCL is initialized properly, false otherwise. -bool initCL( void* glCtx, void* glDC ) -{ - const char* vendorSDK = btOpenCLUtils::getSdkVendorName(); - printf("This program was compiled using the %s OpenCL SDK\n",vendorSDK); - - int ciErrNum = 0; - -#ifdef BT_USE_CLEW - ciErrNum = clewInit( "OpenCL.dll" ); - if ( ciErrNum != CLEW_SUCCESS ) { - return false; - } -#endif - -#if defined(CL_PLATFORM_MINI_CL) - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#elif defined(CL_PLATFORM_AMD) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#elif defined(CL_PLATFORM_NVIDIA) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#else - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#endif - - g_cxMainContext = btOpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - int numDev = btOpenCLUtils::getNumDevices(g_cxMainContext); - if (!numDev) - return false; - - g_cdDevice = btOpenCLUtils::getDevice(g_cxMainContext,0); - - btOpenCLDeviceInfo clInfo; - btOpenCLUtils::getDeviceInfo(g_cdDevice,clInfo); - btOpenCLUtils::printDeviceInfo(g_cdDevice); - - // create a command-queue - g_cqCommandQue = clCreateCommandQueue(g_cxMainContext, g_cdDevice, 0, &ciErrNum); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - return true; -} - -#endif //#ifdef USE_AMD_OPENCL - - -int main(int argc,char** argv) -{ - CommandLineArguments arg(argc,argv); - char* filename=0; - arg.GetCmdLineArgument("filename", filename); - bool dumpXml = arg.CheckCmdLineFlag("dump_xml"); - if (!dumpXml && !filename) - { - printf("There are some optional commandline arguments for this demo:\n"); - printf("Load another .bullet file instead of testFile.bullet:\n"); - printf("--filename=testfile.bullet\n"); - printf("Dump the imported .bullet file to XML\n"); - printf("--dump_xml\n"); - - } - - - - GLDebugDrawer gDebugDrawer; -#ifdef USE_AMD_OPENCL - - bool initialized = initCL(0,0); - btAssert(initialized); -#endif //USE_AMD_OPENCL - - - SerializeDemo serializeDemo; - - int mode = 0; - if (dumpXml) - mode |=bParse::FD_VERBOSE_EXPORT_XML; - if (filename) - serializeDemo.setFileName(filename); - serializeDemo.setVerboseMode(mode); - - serializeDemo.initPhysics(); - serializeDemo.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - -#ifdef CHECK_MEMORY_LEAKS - serializeDemo.exitPhysics(); -#else - return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.org",&serializeDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/SerializeDemo/testFile.bullet b/Demos/SerializeDemo/testFile.bullet deleted file mode 100644 index d535938f0..000000000 Binary files a/Demos/SerializeDemo/testFile.bullet and /dev/null differ diff --git a/Demos/SerializeDemo/testFileCloth.bullet b/Demos/SerializeDemo/testFileCloth.bullet deleted file mode 100644 index 7dd84b68a..000000000 Binary files a/Demos/SerializeDemo/testFileCloth.bullet and /dev/null differ diff --git a/Demos/SimplexDemo/CMakeLists.txt b/Demos/SimplexDemo/CMakeLists.txt deleted file mode 100644 index d6ce31d1a..000000000 --- a/Demos/SimplexDemo/CMakeLists.txt +++ /dev/null @@ -1,33 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppSimplexDemo - SimplexDemo.cpp -) - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppSimplexDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppSimplexDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppSimplexDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/SimplexDemo/SimplexDemo.cpp b/Demos/SimplexDemo/SimplexDemo.cpp deleted file mode 100644 index f804c73d9..000000000 --- a/Demos/SimplexDemo/SimplexDemo.cpp +++ /dev/null @@ -1,123 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/* - SimplexDemo demonstrated the working of the subdistance algorithm as used in GJK. - It draws the simplex, and calculates the closest vector from simplex to the origin -*/ - -#include "GL_Simplex1to4.h" -#include "LinearMath/btQuaternion.h" -#include "LinearMath/btTransform.h" -#include "GL_ShapeDrawer.h" - -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "SimplexDemo.h" -#include "GlutStuff.h" - -btVoronoiSimplexSolver simplexSolver; - - - -float yaw=0.f,pitch=0.f,roll=0.f; -const int maxNumObjects = 4; -const int numObjects = 1; -int screenWidth = 640; -int screenHeight = 480; -/// simplex contains the vertices, and some extra code to draw and debug -GL_Simplex1to4 simplex; - - -btPolyhedralConvexShape* shapePtr[maxNumObjects]; - - -/// -/// -/// -int main(int argc,char** argv) -{ - - SimplexDemo* demo = new SimplexDemo(); - - demo->initPhysics(); - - return glutmain(argc, argv,screenWidth,screenHeight,"SimplexDemo",demo); -} - -//to be implemented by the demo - -void SimplexDemo::clientMoveAndDisplay() -{ - - displayCallback(); -} - - - -void SimplexDemo::displayCallback() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDisable(GL_LIGHTING); - - GL_ShapeDrawer::drawCoordSystem(); - - btScalar m[16]; - int i; - - btVector3 worldBoundsMin(-1000,-1000,-1000); - btVector3 worldBoundsMax(1000,1000,1000); - - for (i=0;idrawOpenGL(m,shapePtr[i],btVector3(1,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax); - - /// calculate closest point from simplex to the origin, and draw this vector - simplex.calcClosest(m); - - } - pitch += 0.005f; - yaw += 0.01f; - - glFlush(); - glutSwapBuffers(); -} - -void SimplexDemo::initPhysics() -{ - - simplex.setSimplexSolver(&simplexSolver); - - simplex.addVertex(btVector3(-2,0,-2)); - simplex.addVertex(btVector3(2,0,-2)); - simplex.addVertex(btVector3(0,0,2)); - simplex.addVertex(btVector3(0,2,0)); - - shapePtr[0] = &simplex; - - btTransform tr; - tr.setIdentity(); -} - - diff --git a/Demos/SimplexDemo/SimplexDemo.h b/Demos/SimplexDemo/SimplexDemo.h deleted file mode 100644 index 72f620039..000000000 --- a/Demos/SimplexDemo/SimplexDemo.h +++ /dev/null @@ -1,36 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef SIMPLEX_DEMO_H -#define SIMPLEX_DEMO_H - -#include "GlutDemoApplication.h" - -///SimplexDemo shows the working of the sub-distance algorithm, used inside GJK -class SimplexDemo : public GlutDemoApplication -{ - public: - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - -}; - -#endif //SIMPLEX_DEMO_H - - diff --git a/Demos/SliderConstraintDemo/CMakeLists.txt b/Demos/SliderConstraintDemo/CMakeLists.txt deleted file mode 100644 index d8b40c60c..000000000 --- a/Demos/SliderConstraintDemo/CMakeLists.txt +++ /dev/null @@ -1,36 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( -OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppSliderConstraintDemo - SliderConstraintDemo.cpp - main.cpp -) - - - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppSliderConstraintDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppSliderConstraintDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppSliderConstraintDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/SliderConstraintDemo/SliderConstraintDemo.cpp b/Demos/SliderConstraintDemo/SliderConstraintDemo.cpp deleted file mode 100644 index 12fe4e56d..000000000 --- a/Demos/SliderConstraintDemo/SliderConstraintDemo.cpp +++ /dev/null @@ -1,512 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/* -Added by Roman Ponomarev (rponom@gmail.com) -April 04, 2008 - -Added support for ODE sover -April 24, 2008 -*/ - - - - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" - -#include "GLDebugDrawer.h" - - -#include //printf debugging - -#include "SliderConstraintDemo.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - - - -#define SLIDER_DEMO_USE_ODE_SOLVER 0 -#define SLIDER_DEMO_USE_6DOF 0 - -#define CUBE_HALF_EXTENTS 1.f - -#define SLIDER_ENABLE_ALL_DEMOS 1 - - - -// A couple of sliders -#if SLIDER_DEMO_USE_6DOF - static btGeneric6DofConstraint *spSlider1, *spSlider2; -#else - static btSliderConstraint *spSlider1, *spSlider2; -#endif - -static btPoint2PointConstraint* spP2PConst; -//static btHingeConstraint* spHingeConst; - - - -static void draw_axes(const btRigidBody& rb, const btTransform& frame) -{ - glBegin(GL_LINES); - // draw world transform - btVector3 from = rb.getWorldTransform().getOrigin(); - btVector3 to = from + rb.getWorldTransform().getBasis() * btVector3(5,0,0); - // X in red - glColor3f(255.0F, 0.0F, 0.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - to = from + rb.getWorldTransform().getBasis() * btVector3(0,5,0); - // Y in green - glColor3f(0.0F, 255.0F, 0.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - to = from + rb.getWorldTransform().getBasis() * btVector3(0,0,5); - // Z in blue - glColor3f(0.0F, 0.0F, 255.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - // draw slider frame - btTransform calc_frame = rb.getWorldTransform() * frame; - from = calc_frame.getOrigin(); - to = from + calc_frame.getBasis() * btVector3(10,0,0); - // X in red - glColor3f(255.0F, 0.0F, 0.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - to = from + calc_frame.getBasis() * btVector3(0,10,0); - // Y in green - glColor3f(0.0F, 255.0F, 0.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - to = from + calc_frame.getBasis() * btVector3(0,0,10); - // Z in blue - glColor3f(0.0F, 0.0F, 255.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - glEnd(); -} // draw_axes() - - - -#if SLIDER_DEMO_USE_6DOF -static void drawSlider(btGeneric6DofConstraint* pSlider) -{ - draw_axes(pSlider->getRigidBodyA(), pSlider->getFrameOffsetA()); - draw_axes(pSlider->getRigidBodyB(), pSlider->getFrameOffsetB()); -} // drawSlider() -#else -static void drawSlider(btSliderConstraint* pSlider) -{ - draw_axes(pSlider->getRigidBodyA(), pSlider->getFrameOffsetA()); - draw_axes(pSlider->getRigidBodyB(), pSlider->getFrameOffsetB()); - // draw limits in white - btVector3 from(pSlider->getLowerLinLimit(), 0, 0); - btVector3 to(pSlider->getUpperLinLimit(), 0, 0); - btTransform trans; - if(pSlider->getUseLinearReferenceFrameA()) - { - trans = pSlider->getRigidBodyA().getWorldTransform() * pSlider->getFrameOffsetA(); - } - else - { - trans = pSlider->getRigidBodyB().getWorldTransform() * pSlider->getFrameOffsetB(); - } - from = trans * from; - to = trans * to; - glBegin(GL_LINES); - glColor3f(255.0F, 255.0F, 255.0F); - glVertex3d(from.getX(), from.getY(), from.getZ()); - glVertex3d(to.getX(), to.getY(), to.getZ()); - glEnd(); -} // drawSlider() -#endif - - - -void SliderConstraintDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - setCameraDistance(26.f); - - // init world - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - m_overlappingPairCache = new btAxisSweep3(worldMin,worldMax); - -#if SLIDER_DEMO_USE_ODE_SOLVER - m_constraintSolver = new btOdeQuickstepConstraintSolver(); -#else - m_constraintSolver = new btSequentialImpulseConstraintSolver(); -#endif - - btDiscreteDynamicsWorld* wp = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration); - // wp->getSolverInfo().m_numIterations = 20; // default is 10 - m_dynamicsWorld = wp; -// wp->getSolverInfo().m_erp = 0.8; - - // add floor - //btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); - m_collisionShapes.push_back(groundShape); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-76,0)); - btRigidBody* groundBody; - groundBody = localCreateRigidBody(0, groundTransform, groundShape); - - // add box shape (will be reused for all bodies) - btCollisionShape* shape = new btBoxShape(btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)); - m_collisionShapes.push_back(shape); - // mass of dymamic bodies - btScalar mass = btScalar(1.); - - // add dynamic rigid body A1 - btTransform trans; - trans.setIdentity(); - btVector3 worldPos(-20,0,0); - trans.setOrigin(worldPos); - btTransform frameInA, frameInB; - frameInA = btTransform::getIdentity(); - frameInB = btTransform::getIdentity(); - -#if SLIDER_ENABLE_ALL_DEMOS - btRigidBody* pRbA1 = localCreateRigidBody(mass, trans, shape); -// btRigidBody* pRbA1 = localCreateRigidBody(0.f, trans, shape); - pRbA1->setActivationState(DISABLE_DEACTIVATION); - - // add dynamic rigid body B1 - worldPos.setValue(-30,0,0); - trans.setOrigin(worldPos); - btRigidBody* pRbB1 = localCreateRigidBody(mass, trans, shape); -// btRigidBody* pRbB1 = localCreateRigidBody(0.f, trans, shape); - pRbB1->setActivationState(DISABLE_DEACTIVATION); - - // create slider constraint between A1 and B1 and add it to world - -#if SLIDER_DEMO_USE_6DOF - spSlider1 = new btGeneric6DofConstraint(*pRbA1, *pRbB1, frameInA, frameInB, true); - btVector3 lowerSliderLimit = btVector3(-20,0,0); - btVector3 hiSliderLimit = btVector3(-10,0,0); -// btVector3 lowerSliderLimit = btVector3(-20,-5,-5); -// btVector3 hiSliderLimit = btVector3(-10,5,5); - spSlider1->setLinearLowerLimit(lowerSliderLimit); - spSlider1->setLinearUpperLimit(hiSliderLimit); - spSlider1->setAngularLowerLimit(btVector3(0,0,0)); - spSlider1->setAngularUpperLimit(btVector3(0,0,0)); -#else - spSlider1 = new btSliderConstraint(*pRbA1, *pRbB1, frameInA, frameInB, true); -// spSlider1 = new btSliderConstraint(*pRbA1, *pRbB1, frameInA, frameInB, false); - spSlider1->setLowerLinLimit(-15.0F); - spSlider1->setUpperLinLimit(-5.0F); -// spSlider1->setLowerLinLimit(5.0F); -// spSlider1->setUpperLinLimit(15.0F); -// spSlider1->setLowerLinLimit(-10.0F); -// spSlider1->setUpperLinLimit(-10.0F); - - spSlider1->setLowerAngLimit(-SIMD_PI / 3.0F); - spSlider1->setUpperAngLimit( SIMD_PI / 3.0F); -#endif - - m_dynamicsWorld->addConstraint(spSlider1, true); - spSlider1->setDbgDrawSize(btScalar(5.f)); -#endif - -#if SLIDER_ENABLE_ALL_DEMOS - // add kinematic rigid body A2 -// worldPos.setValue(20,4,0); - worldPos.setValue(5,-20,0); - trans.setOrigin(worldPos); - btRigidBody* pRbA2 = localCreateRigidBody(0., trans, shape); -// btRigidBody* pRbA2 = localCreateRigidBody(mass, trans, shape); -// btRigidBody* pRbA2 = localCreateRigidBody(mass * 10000, trans, shape); - pRbA2->setActivationState(DISABLE_DEACTIVATION); - - // add dynamic rigid body B2 -// worldPos.setValue(-20,4,0); - worldPos.setValue(-5,-20,0); - trans.setOrigin(worldPos); -// btRigidBody* pRbB2 = localCreateRigidBody(0., trans, shape); - btRigidBody* pRbB2 = localCreateRigidBody(mass, trans, shape); -// btRigidBody* pRbB2 = localCreateRigidBody(mass * 10000, trans, shape); - pRbB2->setActivationState(DISABLE_DEACTIVATION); - -// frameInA.getBasis().setEulerZYX(1.f, 1.f, 1.f); -// frameInB.getBasis().setEulerZYX(1.f, 1.f, 1.f); -// frameInA.getBasis().setEulerZYX(1.f, 1.f, 1.f); -// frameInB.getBasis().setEulerZYX(1.f, 1.f, 1.f); - - -// frameInA.setOrigin(btVector3(-20., 5., 0)); -// frameInB.setOrigin(btVector3( 20., 5., 0)); - frameInA.setOrigin(btVector3(-5., 20., 0)); - frameInB.setOrigin(btVector3( 5., 20., 0)); - - - // create slider constraint between A2 and B2 and add it to world -#if SLIDER_DEMO_USE_6DOF - spSlider2 = new btGeneric6DofConstraint(*pRbA2, *pRbB2, frameInA, frameInB, true); - spSlider2->setLinearLowerLimit(lowerSliderLimit); - spSlider2->setLinearUpperLimit(hiSliderLimit); - spSlider2->setAngularLowerLimit(btVector3(0,0,0)); - spSlider2->setAngularUpperLimit(btVector3(0,0,0)); -#else - spSlider2 = new btSliderConstraint(*pRbA2, *pRbB2, frameInA, frameInB, true); -// spSlider2 = new btSliderConstraint(*pRbA2, *pRbB2, frameInA, frameInB, false); -// spSlider2->setLowerLinLimit(0.0F); -// spSlider2->setUpperLinLimit(0.0F); - spSlider2->setLowerLinLimit(-2.0F); - spSlider2->setUpperLinLimit(2.0F); -// spSlider2->setLowerLinLimit(5.0F); -// spSlider2->setUpperLinLimit(25.0F); -// spSlider2->setUpperLinLimit(-5.0F); -// spSlider2->setUpperLinLimit(-9.99F); - - -// spSlider2->setLowerAngLimit(SIMD_PI / 2.0F); -// spSlider2->setUpperAngLimit(-SIMD_PI / 2.0F); - - // spSlider2->setLowerAngLimit(-SIMD_PI / 2.0F); -// spSlider2->setUpperAngLimit(SIMD_PI / 2.0F); - -// spSlider2->setLowerAngLimit(-SIMD_PI); -// spSlider2->setUpperAngLimit(SIMD_PI *0.8F); - - -// spSlider2->setLowerAngLimit(-0.01F); -// spSlider2->setUpperAngLimit(0.01F); - spSlider2->setLowerAngLimit(-1.570796326F * 0.5f); - spSlider2->setUpperAngLimit(1.570796326F * 0.5f); -// spSlider2->setLowerAngLimit(1.F); -// spSlider2->setUpperAngLimit(-1.F); - - -// spSlider2->setDampingLimLin(0.5f); - -#if 0 - // add motors - spSlider2->setPoweredLinMotor(true); - spSlider2->setMaxLinMotorForce(0.1); - spSlider2->setTargetLinMotorVelocity(-5.0); - - spSlider2->setPoweredAngMotor(true); -// spSlider2->setMaxAngMotorForce(0.01); - spSlider2->setMaxAngMotorForce(10.0); - spSlider2->setTargetAngMotorVelocity(1.0); - - // change default damping and restitution - - spSlider2->setDampingDirLin(0.005F); - spSlider2->setRestitutionLimLin(1.1F); -#endif - - // various ODE tests -// spSlider2->setDampingLimLin(0.1F); // linear bounce factor for ODE == 1.0 - DampingLimLin; -// spSlider2->setDampingLimAng(0.1F); // angular bounce factor for ODE == 1.0 - DampingLimAng; -// spSlider2->setSoftnessOrthoAng(0.1); -// spSlider2->setSoftnessOrthoLin(0.1); -// spSlider2->setSoftnessLimLin(0.1); -// spSlider2->setSoftnessLimAng(0.1); -#endif - m_dynamicsWorld->addConstraint(spSlider2, true); - spSlider2->setDbgDrawSize(btScalar(5.f)); -#endif - -#if SLIDER_ENABLE_ALL_DEMOS -{ - // add dynamic rigid body A1 - trans.setIdentity(); - worldPos.setValue(20,0,0); - trans.setOrigin(worldPos); - btRigidBody* pRbA3 = localCreateRigidBody(0.0F, trans, shape); - pRbA3->setActivationState(DISABLE_DEACTIVATION); - - // add dynamic rigid body B1 - worldPos.setValue(25,0,0); - trans.setOrigin(worldPos); - btRigidBody* pRbB3 = localCreateRigidBody(mass, trans, shape); - pRbB3->setActivationState(DISABLE_DEACTIVATION); - - btVector3 pivA( 2.5, 0., 0.); - btVector3 pivB(-2.5, 0., 0.); - spP2PConst = new btPoint2PointConstraint(*pRbA3, *pRbB3, pivA, pivB); - m_dynamicsWorld->addConstraint(spP2PConst, true); - spP2PConst->setDbgDrawSize(btScalar(5.f)); - -} -#endif - -#if 0 // SLIDER_ENABLE_ALL_DEMOS - // add dynamic rigid body A4 - trans.setIdentity(); - worldPos.setValue(20,10,0); - trans.setOrigin(worldPos); - btRigidBody* pRbA4 = localCreateRigidBody(0.0F, trans, shape); - pRbA4->setActivationState(DISABLE_DEACTIVATION); - - // add dynamic rigid body B1 - worldPos.setValue(27,10,0); - trans.setOrigin(worldPos); - btRigidBody* pRbB4 = localCreateRigidBody(mass, trans, shape); - pRbB1->setActivationState(DISABLE_DEACTIVATION); - - - btVector3 pivA( 2., 0., 0.); - btVector3 pivB(-5., 0., 0.); - btVector3 axisA(0., 0., 1.); - btVector3 axisB(0., 0., 1.); - - spHingeConst = new btHingeConstraint(*pRbA4, *pRbB4, pivA, pivB, axisA, axisB); -// spHingeConst->setLimit(-1.57, 1.57); - spHingeConst->setLimit(1.57, -1.57); - spHingeConst->enableAngularMotor(true, 10.0, 0.19); - - m_dynamicsWorld->addConstraint(spHingeConst, true); - spHingeConst->setDbgDrawSize(btScalar(5.f)); - -#endif - -} // SliderConstraintDemo::initPhysics() - - - -SliderConstraintDemo::~SliderConstraintDemo() -{ - //cleanup in the reverse order of creation/initialization - int i; - //removed/delete constraints - for (i=m_dynamicsWorld->getNumConstraints()-1; i>=0 ;i--) - { - btTypedConstraint* constraint = m_dynamicsWorld->getConstraint(i); - m_dynamicsWorld->removeConstraint(constraint); - delete constraint; - } - //remove the rigidbodies from the dynamics world and delete them - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - //delete collision shapes - for (int j=0;jstepSimulation(dt,maxSimSubSteps); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - bool verbose = false; - if (verbose) - { - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } - } - renderme(); -// drawSlider(spSlider1); -// drawSlider(spSlider2); - glFlush(); - glutSwapBuffers(); -} // SliderConstraintDemo::clientMoveAndDisplay() - - - -void SliderConstraintDemo::displayCallback(void) -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - if(m_dynamicsWorld) - { - m_dynamicsWorld->debugDrawWorld(); - } -// drawSlider(spSlider1); -// drawSlider(spSlider2); - renderme(); - glFlush(); - glutSwapBuffers(); -} // SliderConstraintDemo::displayCallback() - - -void SliderConstraintDemo::keyboardCallback(unsigned char key, int x, int y) -{ - (void)x; - (void)y; - switch (key) - { - case 'O' : - { - bool offectOnOff; - offectOnOff = spSlider1->getUseFrameOffset(); - offectOnOff = !offectOnOff; - spSlider1->setUseFrameOffset(offectOnOff); - printf("Slider1 %s frame offset\n", offectOnOff ? "uses" : "does not use"); - offectOnOff = spSlider2->getUseFrameOffset(); - offectOnOff = !offectOnOff; - spSlider2->setUseFrameOffset(offectOnOff); - printf("Slider2 %s frame offset\n", offectOnOff ? "uses" : "does not use"); - } - break; - default : - { - DemoApplication::keyboardCallback(key, x, y); - } - break; - } -} - diff --git a/Demos/SliderConstraintDemo/SliderConstraintDemo.h b/Demos/SliderConstraintDemo/SliderConstraintDemo.h deleted file mode 100644 index f709ef22b..000000000 --- a/Demos/SliderConstraintDemo/SliderConstraintDemo.h +++ /dev/null @@ -1,73 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - - -#ifndef SLIDER_CONSTRAINT_DEMO_H -#define SLIDER_CONSTRAINT_DEMO_H - - - -#include "btBulletDynamicsCommon.h" -#include "BulletDynamics/ConstraintSolver/btSliderConstraint.h" -#include "GlutDemoApplication.h" - - - - -/// SliderConstraintDemo shows how to create a slider constraint -class SliderConstraintDemo : public GlutDemoApplication -{ - //keep track of variables to delete memory at the end - btAlignedObjectArray m_collisionShapes; - - class btBroadphaseInterface* m_overlappingPairCache; - - class btCollisionDispatcher* m_dispatcher; - - class btConstraintSolver* m_constraintSolver; - - class btDefaultCollisionConfiguration* m_collisionConfiguration; - - public: - - virtual ~SliderConstraintDemo(); - - void initPhysics(); - - void initModel(); - - void drawSliders(); - void drawSliderConstraint(btSliderConstraint* constraint); - - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - static DemoApplication* Create() - { - SliderConstraintDemo* demo = new SliderConstraintDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } - - virtual void keyboardCallback(unsigned char key, int x, int y); - -}; - -#endif //SLIDER_CONSTRAINT_DEMO_H - diff --git a/Demos/SliderConstraintDemo/main.cpp b/Demos/SliderConstraintDemo/main.cpp deleted file mode 100644 index c6775a7df..000000000 --- a/Demos/SliderConstraintDemo/main.cpp +++ /dev/null @@ -1,25 +0,0 @@ -/* -Added by Roman Ponomarev (rponom@gmail.com) -April 04, 2008 -*/ -#include "SliderConstraintDemo.h" -#include "GlutStuff.h" - -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - SliderConstraintDemo* sliderConstraintDemo = new SliderConstraintDemo(); - - sliderConstraintDemo->initPhysics(); - sliderConstraintDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - sliderConstraintDemo->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits); - - - return glutmain(argc, argv,640,480,"Slider Constraint Demo. http://www.continuousphysics.com/Bullet/phpBB2/", sliderConstraintDemo); -} - diff --git a/Demos/SoftDemo/AMD/premake4.lua b/Demos/SoftDemo/AMD/premake4.lua deleted file mode 100644 index b0868b4f5..000000000 --- a/Demos/SoftDemo/AMD/premake4.lua +++ /dev/null @@ -1,59 +0,0 @@ - - hasCL = findOpenCL_AMD() - - if (hasCL) then - - project "AppSoftBodyDemo_AMD" - - defines { "USE_AMD_OPENCL","CL_PLATFORM_AMD"} - - initOpenCL_AMD() - - language "C++" - - kind "ConsoleApp" - targetdir "../../.." - - libdirs {"../../../Glut"} - - links { - "LinearMath", - "BulletCollision", - "BulletDynamics", - "BulletSoftBody", - "BulletSoftBodySolvers_OpenCL_AMD", - "OpenGLSupport", - "opengl32" - } - - configuration "x64" - links { - "glut64", - "glew64s" - } - configuration "x32" - links { - "glut32", - "glew32s" - } - - configuration{} - - - includedirs { - "../../SharedOpenCL", - "../../../src", - "../../../Glut", - "../../OpenGL" - } - - files { - "../SoftDemo.cpp", - "../SoftDemo.h", - "../main.cpp", - "../../SharedOpenCL/btOpenCLUtils.cpp", - "../../SharedOpenCL/btOpenCLUtils.h", - "../../SharedOpenCL/btOpenCLInclude.h" - } - - end \ No newline at end of file diff --git a/Demos/SoftDemo/CMakeLists.txt b/Demos/SoftDemo/CMakeLists.txt deleted file mode 100644 index 7fe2edc8f..000000000 --- a/Demos/SoftDemo/CMakeLists.txt +++ /dev/null @@ -1,49 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - - -# You shouldn't have to modify anything below this line -######################################################## - -IF (USE_GLUT) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${GLUT_INCLUDE_DIR} - ) - - LINK_LIBRARIES( - OpenGLSupport BulletSoftBody BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - IF (WIN32) - ADD_EXECUTABLE(AppSoftBodyDemo - main.cpp - SoftDemo.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - ELSE() - ADD_EXECUTABLE(AppSoftBodyDemo - main.cpp - SoftDemo.cpp - - ) - ENDIF() - - - -ELSE(USE_GLUT) - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppSoftBodyDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppSoftBodyDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppSoftBodyDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/SoftDemo/Makefile.am b/Demos/SoftDemo/Makefile.am deleted file mode 100644 index ede95b818..000000000 --- a/Demos/SoftDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=SoftDemo - -SoftDemo_SOURCES=SoftDemo.cpp SoftDemo.h main.cpp -SoftDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -SoftDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletSoftBody -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/SoftDemo/SoftDemo.cpp b/Demos/SoftDemo/SoftDemo.cpp deleted file mode 100644 index 1928b36bf..000000000 --- a/Demos/SoftDemo/SoftDemo.cpp +++ /dev/null @@ -1,2300 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///btSoftBody implementation by Nathanael Presson - - -#include "btBulletDynamicsCommon.h" -#include "BulletSoftBody/btSoftRigidDynamicsWorld.h" - -#include "BulletCollision/CollisionDispatch/btSphereSphereCollisionAlgorithm.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkEpa2.h" -#include "LinearMath/btQuickprof.h" -#include "LinearMath/btIDebugDraw.h" - -#include "../GimpactTestDemo/BunnyMesh.h" -#include "../GimpactTestDemo/TorusMesh.h" -#include //printf debugging -#include "LinearMath/btConvexHull.h" -#include "BulletSoftBody/btSoftBodyRigidBodyCollisionConfiguration.h" -#include "BulletSoftBody/btSoftBodyHelpers.h" - -#include "SoftDemo.h" -#include "GL_ShapeDrawer.h" -#include "GLDebugFont.h" -#include "GlutStuff.h" - -extern float eye[3]; -extern int glutScreenWidth; -extern int glutScreenHeight; - -static bool sDemoMode = false; - -const int maxProxies = 32766; -const int maxOverlap = 65535; - -static btVector3* gGroundVertices=0; -static int* gGroundIndices=0; -static btBvhTriangleMeshShape* trimeshShape =0; -static btRigidBody* staticBody = 0; -static float waveheight = 5.f; - -const float TRIANGLE_SIZE=8.f; -int current_demo=20; -#define DEMO_MODE_TIMEOUT 15.f //15 seconds for each demo - - -#ifdef _DEBUG -const int gNumObjects = 1; -#else -const int gNumObjects = 1;//try this in release mode: 3000. never go above 16384, unless you increate maxNumObjects value in DemoApplication.cp -#endif - -const int maxNumObjects = 32760; - -#define CUBE_HALF_EXTENTS 1.5 -#define EXTRA_HEIGHT -10.f - - -#ifdef USE_AMD_OPENCL -#include "btOpenCLUtils.h" -#include "BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolver_OpenCL.h" -#include "BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolver_OpenCLSIMDAware.h" -#include "BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverVertexBuffer_OpenGL.h" - -btOpenCLSoftBodySolver* g_openCLSIMDSolver=0; -btSoftBodySolverOutputCLtoCPU* g_softBodyOutput = 0; - -cl_context g_cxMainContext; -cl_device_id g_cdDevice; -cl_command_queue g_cqCommandQue; - -void initCL( void* glCtx, void* glDC ) -{ - int ciErrNum = 0; - -#if defined(CL_PLATFORM_MINI_CL) - cl_device_type deviceType = CL_DEVICE_TYPE_CPU;//or use CL_DEVICE_TYPE_DEBUG to debug MiniCL -#elif defined(CL_PLATFORM_INTEL) - cl_device_type deviceType = CL_DEVICE_TYPE_CPU; -#elif defined(CL_PLATFORM_AMD) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#elif defined(CL_PLATFORM_NVIDIA) - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; -#else -#ifdef __APPLE__ - cl_device_type deviceType = CL_DEVICE_TYPE_ALL;//GPU; -#else - cl_device_type deviceType = CL_DEVICE_TYPE_CPU;//CL_DEVICE_TYPE_ALL -#endif//__APPLE__ -#endif - - g_cxMainContext = btOpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - - int numDev = btOpenCLUtils::getNumDevices(g_cxMainContext); - if (!numDev) - { - btAssert(0); - exit(0);//this is just a demo, exit now - } - - g_cdDevice = btOpenCLUtils::getDevice(g_cxMainContext,0); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - btOpenCLDeviceInfo clInfo; - btOpenCLUtils::getDeviceInfo(g_cdDevice,clInfo); - btOpenCLUtils::printDeviceInfo(g_cdDevice); - - // create a command-queue - g_cqCommandQue = clCreateCommandQueue(g_cxMainContext, g_cdDevice, 0, &ciErrNum); - oclCHECKERROR(ciErrNum, CL_SUCCESS); -} - -class CachingCLFunctions : public CLFunctions -{ -protected: - - cl_device_id m_device; - - const char* strip(const char* name, const char* pattern); - -public: - CachingCLFunctions(cl_command_queue cqCommandQue, cl_context cxMainContext) : - CLFunctions(cqCommandQue,cxMainContext) - { - size_t actualSize; - cl_int retval = clGetCommandQueueInfo ( cqCommandQue, CL_QUEUE_DEVICE, sizeof(cl_device_id), - &m_device, &actualSize); - } - - /** - * Compile a compute shader kernel from a string and return the appropriate cl_kernel object. - */ - virtual cl_kernel compileCLKernelFromString( const char* kernelSource, const char* kernelName, const char* additionalMacros , const char* orgSrcFileNameForCaching) - { - char srcFileNameForCaching[1024]; - sprintf(srcFileNameForCaching,"%s/%s","../../src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL",orgSrcFileNameForCaching); - - btAssert(additionalMacros); - btAssert(srcFileNameForCaching && strlen(srcFileNameForCaching)); - - printf("compiling kernelName: %s ",kernelName); - cl_kernel kernel=0; - cl_int ciErrNum; - - - size_t program_length = strlen(kernelSource); - - cl_program m_cpProgram = btOpenCLUtils::compileCLProgramFromString(m_cxMainContext, m_device, kernelSource, &ciErrNum, additionalMacros); - - - // Create the kernel - kernel = clCreateKernel(m_cpProgram, kernelName, &ciErrNum); - if (ciErrNum != CL_SUCCESS) - { - const char* msg = ""; - switch(ciErrNum) - { - case CL_INVALID_PROGRAM: - msg = "Program is not a valid program object."; - break; - case CL_INVALID_PROGRAM_EXECUTABLE: - msg = "There is no successfully built executable for program."; - break; - case CL_INVALID_KERNEL_NAME: - msg = "kernel_name is not found in program."; - break; - case CL_INVALID_KERNEL_DEFINITION: - msg = "the function definition for __kernel function given by kernel_name such as the number of arguments, the argument types are not the same for all devices for which the program executable has been built."; - break; - case CL_INVALID_VALUE: - msg = "kernel_name is NULL."; - break; - case CL_OUT_OF_HOST_MEMORY: - msg = "Failure to allocate resources required by the OpenCL implementation on the host."; - break; - default: - { - } - } - - printf("Error in clCreateKernel for kernel '%s', error is \"%s\", Line %u in file %s !!!\n\n", kernelName, msg, __LINE__, __FILE__); - - #ifndef BT_SUPPRESS_OPENCL_ASSERTS - btAssert(0); - #endif //BT_SUPPRESS_OPENCL_ASSERTS - m_kernelCompilationFailures++; - return 0; - } - - printf("ready. \n"); - if (!kernel) - m_kernelCompilationFailures++; - return kernel; - } - -}; - - -#endif //USE_AMD_OPENCL - -// -void SoftDemo::createStack( btCollisionShape* boxShape, float halfCubeSize, int size, float zPos ) -{ - btTransform trans; - trans.setIdentity(); - - for(int i=0; igetWorldUserInfo(); - - if(softDemo->m_drag) - { - const int x=softDemo->m_lastmousepos[0]; - const int y=softDemo->m_lastmousepos[1]; - const btVector3 rayFrom=softDemo->getCameraPosition(); - const btVector3 rayTo=softDemo->getRayTo(x,y); - const btVector3 rayDir=(rayTo-rayFrom).normalized(); - const btVector3 N=(softDemo->getCameraTargetPosition()-softDemo->getCameraPosition()).normalized(); - const btScalar O=btDot(softDemo->m_impact,N); - const btScalar den=btDot(N,rayDir); - if((den*den)>0) - { - const btScalar num=O-btDot(N,rayFrom); - const btScalar hit=num/den; - if((hit>0)&&(hit<1500)) - { - softDemo->m_goal=rayFrom+rayDir*hit; - } - } - btVector3 delta=softDemo->m_goal-softDemo->m_node->m_x; - static const btScalar maxdrag=10; - if(delta.length2()>(maxdrag*maxdrag)) - { - delta=delta.normalized()*maxdrag; - } - softDemo->m_node->m_v+=delta/timeStep; - } - -} - - - -void SoftDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - renderme(); - - glFlush(); - swapBuffers(); -} - - -// -// ImplicitShape -// - -// -struct ImplicitSphere : btSoftBody::ImplicitFn -{ - btVector3 center; - btScalar sqradius; - ImplicitSphere() {} - ImplicitSphere(const btVector3& c,btScalar r) : center(c),sqradius(r*r) {} - btScalar Eval(const btVector3& x) - { - return((x-center).length2()-sqradius); - } -}; - -// -// Tetra meshes -// - -struct TetraBunny -{ -#include "bunny.inl" -}; - -struct TetraCube -{ -#include "cube.inl" -}; - - -// -// Random -// - -static inline btScalar UnitRand() -{ - return(rand()/(btScalar)RAND_MAX); -} - -static inline btScalar SignedUnitRand() -{ - return(UnitRand()*2-1); -} - -static inline btVector3 Vector3Rand() -{ - const btVector3 p=btVector3(SignedUnitRand(),SignedUnitRand(),SignedUnitRand()); - return(p.normalized()); -} - -// -// Rb rain -// -static void Ctor_RbUpStack(SoftDemo* pdemo,int count) -{ - float mass=10; - - btCompoundShape* cylinderCompound = new btCompoundShape; - btCollisionShape* cylinderShape = new btCylinderShapeX(btVector3(4,1,1)); - btCollisionShape* boxShape = new btBoxShape(btVector3(4,1,1)); - btTransform localTransform; - localTransform.setIdentity(); - cylinderCompound->addChildShape(localTransform,boxShape); - btQuaternion orn(SIMD_HALF_PI,0,0); - localTransform.setRotation(orn); - // localTransform.setOrigin(btVector3(1,1,1)); - cylinderCompound->addChildShape(localTransform,cylinderShape); - - - btCollisionShape* shape[]={cylinderCompound, - new btBoxShape(btVector3(1,1,1)), - new btSphereShape(1.5) - - }; - static const int nshapes=sizeof(shape)/sizeof(shape[0]); - for(int i=0;ilocalCreateRigidBody(mass,startTransform,shape[i%nshapes]); - //pdemo->localCreateRigidBody(mass,startTransform,shape[0]); - } -} - -// -// Big ball -// -static void Ctor_BigBall(SoftDemo* pdemo,btScalar mass=10) -{ - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,13,0)); - pdemo->localCreateRigidBody(mass,startTransform,new btSphereShape(3)); -} - -// -// Big plate -// -static btRigidBody* Ctor_BigPlate(SoftDemo* pdemo,btScalar mass=15,btScalar height=4) -{ - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,height,0.5)); - btRigidBody* body=pdemo->localCreateRigidBody(mass,startTransform,new btBoxShape(btVector3(5,1,5))); - body->setFriction(1); - return(body); -} - -// -// Linear stair -// -static void Ctor_LinearStair(SoftDemo* pdemo,const btVector3& org,const btVector3& sizes,btScalar angle,int count) -{ - btBoxShape* shape=new btBoxShape(sizes); - for(int i=0;ilocalCreateRigidBody(0,startTransform,shape); - body->setFriction(1); - } -} - -// -// Softbox -// -static btSoftBody* Ctor_SoftBox(SoftDemo* pdemo,const btVector3& p,const btVector3& s) -{ - const btVector3 h=s*0.5; - const btVector3 c[]={ p+h*btVector3(-1,-1,-1), - p+h*btVector3(+1,-1,-1), - p+h*btVector3(-1,+1,-1), - p+h*btVector3(+1,+1,-1), - p+h*btVector3(-1,-1,+1), - p+h*btVector3(+1,-1,+1), - p+h*btVector3(-1,+1,+1), - p+h*btVector3(+1,+1,+1)}; - btSoftBody* psb=btSoftBodyHelpers::CreateFromConvexHull(pdemo->m_softBodyWorldInfo,c,8); - psb->generateBendingConstraints(2); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - return(psb); - -} - -// -// SoftBoulder -// -static btSoftBody* Ctor_SoftBoulder(SoftDemo* pdemo,const btVector3& p,const btVector3& s,int np,int id) -{ - btAlignedObjectArray pts; - if(id) srand(id); - for(int i=0;im_softBodyWorldInfo,&pts[0],pts.size()); - psb->generateBendingConstraints(2); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - return(psb); -} - -//#define TRACEDEMO { pdemo->demoname=__FUNCTION__+5;printf("Launching demo: " __FUNCTION__ "\r\n"); } - -// -// Basic ropes -// -static void Init_Ropes(SoftDemo* pdemo) -{ - //TRACEDEMO - const int n=15; - for(int i=0;im_softBodyWorldInfo, btVector3(-10,0,i*0.25), - btVector3(10,0,i*0.25), - 16, - 1+2); - psb->m_cfg.piterations = 4; - psb->m_materials[0]->m_kLST = 0.1+(i/(btScalar)(n-1))*0.9; - psb->setTotalMass(20); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - } -} - -// -// Rope attach -// -static void Init_RopeAttach(SoftDemo* pdemo) -{ - //TRACEDEMO - pdemo->m_softBodyWorldInfo.m_sparsesdf.RemoveReferences(0); - struct Functors - { - static btSoftBody* CtorRope(SoftDemo* pdemo,const btVector3& p) - { - btSoftBody* psb=btSoftBodyHelpers::CreateRope(pdemo->m_softBodyWorldInfo,p,p+btVector3(10,0,0),8,1); - psb->setTotalMass(50); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); - } - }; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(12,8,0)); - btRigidBody* body=pdemo->localCreateRigidBody(50,startTransform,new btBoxShape(btVector3(2,6,2))); - btSoftBody* psb0=Functors::CtorRope(pdemo,btVector3(0,8,-1)); - btSoftBody* psb1=Functors::CtorRope(pdemo,btVector3(0,8,+1)); - psb0->appendAnchor(psb0->m_nodes.size()-1,body); - psb1->appendAnchor(psb1->m_nodes.size()-1,body); -} - -// -// Cloth attach -// -static void Init_ClothAttach(SoftDemo* pdemo) -{ - //TRACEDEMO - const btScalar s=4; - const btScalar h=6; - const int r=9; - btSoftBody* psb=btSoftBodyHelpers::CreatePatch(pdemo->m_softBodyWorldInfo,btVector3(-s,h,-s), - btVector3(+s,h,-s), - btVector3(-s,h,+s), - btVector3(+s,h,+s),r,r,4+8,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,h,-(s+3.5))); - btRigidBody* body=pdemo->localCreateRigidBody(20,startTransform,new btBoxShape(btVector3(s,1,3))); - psb->appendAnchor(0,body); - psb->appendAnchor(r-1,body); - pdemo->m_cutting=true; -} - -// -// Impact -// -static void Init_Impact(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateRope(pdemo->m_softBodyWorldInfo, btVector3(0,0,0), - btVector3(0,-1,0), - 0, - 1); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - psb->m_cfg.kCHR=0.5; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,20,0)); - pdemo->localCreateRigidBody(10,startTransform,new btBoxShape(btVector3(2,2,2))); -} - -static void Init_CapsuleCollision(SoftDemo* pdemo) -{ -#ifdef USE_AMD_OPENCL - btAlignedObjectArray emptyArray; - if (g_openCLSIMDSolver) - g_openCLSIMDSolver->optimize(emptyArray); -#endif //USE_AMD_OPENCL - - //TRACEDEMO - const btScalar s=4; - const btScalar h=6; - const int r=20; - - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,h-2,0)); - - btCollisionShape* capsuleShape= new btCapsuleShapeX(1,5); - capsuleShape->setMargin( 0.5 ); - - // capsule->setLocalScaling(btVector3(5,1,1)); -// btRigidBody* body=pdemo->localCreateRigidBody(20,startTransform,capsuleShape); - btRigidBody* body=pdemo->localCreateRigidBody(0,startTransform,capsuleShape); - body->setFriction( 0.8f ); - - int fixed=0;//4+8; - btSoftBody* psb=btSoftBodyHelpers::CreatePatch(pdemo->m_softBodyWorldInfo,btVector3(-s,h,-s), - btVector3(+s,h,-s), - btVector3(-s,h,+s), - btVector3(+s,h,+s),r,r,fixed,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - psb->setTotalMass(0.1); - - psb->m_cfg.piterations = 10; - psb->m_cfg.citerations = 10; - psb->m_cfg.diterations = 10; -// psb->m_cfg.viterations = 10; - - - // psb->appendAnchor(0,body); -// psb->appendAnchor(r-1,body); -// pdemo->m_cutting=true; -} - -// -// Collide -// -static void Init_Collide(SoftDemo* pdemo) -{ - //TRACEDEMO - struct Functor - { - static btSoftBody* Create(SoftDemo* pdemo,const btVector3& x,const btVector3& a) - { - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo,gVertices, - &gIndices[0][0], - NUM_TRIANGLES); - psb->generateBendingConstraints(2); - psb->m_cfg.piterations=2; - psb->m_cfg.collisions|=btSoftBody::fCollision::VF_SS; - psb->randomizeConstraints(); - btMatrix3x3 m; - m.setEulerZYX(a.x(),a.y(),a.z()); - psb->transform(btTransform(m,x)); - psb->scale(btVector3(2,2,2)); - psb->setTotalMass(50,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); - } - }; - for(int i=0;i<3;++i) - { - Functor::Create(pdemo,btVector3(3*i,2,0),btVector3(SIMD_PI/2*(1-(i&1)),SIMD_PI/2*(i&1),0)); - } - pdemo->m_cutting=true; -} - -// -// Collide2 -// -static void Init_Collide2(SoftDemo* pdemo) -{ - //TRACEDEMO - struct Functor - { - static btSoftBody* Create(SoftDemo* pdemo,const btVector3& x,const btVector3& a) - { - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo,gVerticesBunny, - &gIndicesBunny[0][0], - BUNNY_NUM_TRIANGLES); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 0.5; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_cfg.piterations = 2; - psb->m_cfg.kDF = 0.5; - psb->m_cfg.collisions |= btSoftBody::fCollision::VF_SS; - psb->randomizeConstraints(); - btMatrix3x3 m; - m.setEulerZYX(a.x(),a.y(),a.z()); - psb->transform(btTransform(m,x)); - psb->scale(btVector3(6,6,6)); - psb->setTotalMass(100,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); - } - }; - for(int i=0;i<3;++i) - { - Functor::Create(pdemo,btVector3(0,-1+5*i,0),btVector3(0,SIMD_PI/2*(i&1),0)); - } - pdemo->m_cutting=true; -} - -// -// Collide3 -// -static void Init_Collide3(SoftDemo* pdemo) -{ - //TRACEDEMO - { - const btScalar s=8; - btSoftBody* psb=btSoftBodyHelpers::CreatePatch( pdemo->m_softBodyWorldInfo,btVector3(-s,0,-s), - btVector3(+s,0,-s), - btVector3(-s,0,+s), - btVector3(+s,0,+s), - 15,15,1+2+4+8,true); - psb->m_materials[0]->m_kLST = 0.4; - psb->m_cfg.collisions |= btSoftBody::fCollision::VF_SS; - psb->setTotalMass(150); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - } - { - const btScalar s=4; - const btVector3 o=btVector3(5,10,0); - btSoftBody* psb=btSoftBodyHelpers::CreatePatch( pdemo->m_softBodyWorldInfo, - btVector3(-s,0,-s)+o, - btVector3(+s,0,-s)+o, - btVector3(-s,0,+s)+o, - btVector3(+s,0,+s)+o, - 7,7,0,true); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 0.1; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_materials[0]->m_kLST = 0.5; - psb->m_cfg.collisions |= btSoftBody::fCollision::VF_SS; - psb->setTotalMass(150); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - pdemo->m_cutting=true; - } -} - -// -// Aerodynamic forces, 50x1g flyers -// -static void Init_Aero(SoftDemo* pdemo) -{ - //TRACEDEMO - const btScalar s=2; - const btScalar h=10; - const int segments=6; - const int count=50; - for(int i=0;im_softBodyWorldInfo,btVector3(-s,h,-s), - btVector3(+s,h,-s), - btVector3(-s,h,+s), - btVector3(+s,h,+s), - segments,segments, - 0,true); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_cfg.kLF = 0.004; - psb->m_cfg.kDG = 0.0003; - psb->m_cfg.aeromodel = btSoftBody::eAeroModel::V_TwoSided; - btTransform trs; - btQuaternion rot; - btVector3 ra=Vector3Rand()*0.1; - btVector3 rp=Vector3Rand()*15+btVector3(0,20,80); - rot.setEuler(SIMD_PI/8+ra.x(),-SIMD_PI/7+ra.y(),ra.z()); - trs.setIdentity(); - trs.setOrigin(rp); - trs.setRotation(rot); - psb->transform(trs); - psb->setTotalMass(0.1); - psb->addForce(btVector3(0,2,0),0); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - } - pdemo->m_autocam=true; -} - -static void Init_Aero2(SoftDemo* pdemo) -{ - //TRACEDEMO - const btScalar s=5; - //psb->getWorldInfo()->m_gravity.setValue(0,0,0); - - const int segments=10; - const int count=5; - btVector3 pos(-s*segments, 0, 0); - btScalar gap = 0.5; - - for(int i=0;im_softBodyWorldInfo,btVector3(-s,0,-s*3), - btVector3(+s,0,-s*3), - btVector3(-s,0,+s), - btVector3(+s,0,+s), - segments,segments*3, - 1+2,true); - - psb->getCollisionShape()->setMargin(0.5); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 0.0004; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - - psb->m_cfg.kLF = 0.05; - psb->m_cfg.kDG = 0.01; - - //psb->m_cfg.kLF = 0.004; - //psb->m_cfg.kDG = 0.0003; - - psb->m_cfg.piterations = 2; - psb->m_cfg.aeromodel = btSoftBody::eAeroModel::V_TwoSidedLiftDrag; - - - psb->setWindVelocity(btVector3(4, -12.0, -25.0)); - - btTransform trs; - btQuaternion rot; - pos += btVector3(s*2 + gap, 0, 0); - rot.setRotation(btVector3(1, 0, 0), btScalar(SIMD_PI/2)); - trs.setIdentity(); - trs.setOrigin(pos); - trs.setRotation(rot); - psb->transform(trs); - psb->setTotalMass(2.0); - - - - //this could help performance in some cases - btSoftBodyHelpers::ReoptimizeLinkOrder(psb); - - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - } - - pdemo->m_autocam=true; -} - -// -// Friction -// -static void Init_Friction(SoftDemo* pdemo) -{ - //TRACEDEMO - const btScalar bs=2; - const btScalar ts=bs+bs/4; - for(int i=0,ni=20;im_cfg.kDF = 0.1 * ((i+1)/(btScalar)ni); - psb->addVelocity(btVector3(0,0,-10)); - } -} - -// -// Pressure -// -static void Init_Pressure(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateEllipsoid(pdemo->m_softBodyWorldInfo,btVector3(35,25,0), - btVector3(1,1,1)*3, - 512); - psb->m_materials[0]->m_kLST = 0.1; - psb->m_cfg.kDF = 1; - psb->m_cfg.kDP = 0.001; // fun factor... - psb->m_cfg.kPR = 2500; - psb->setTotalMass(30,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - Ctor_BigPlate(pdemo); - Ctor_LinearStair(pdemo,btVector3(0,0,0),btVector3(2,1,5),0,10); - pdemo->m_autocam=true; - -} - -// -// Volume conservation -// -static void Init_Volume(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateEllipsoid(pdemo->m_softBodyWorldInfo,btVector3(35,25,0), - btVector3(1,1,1)*3, - 512); - psb->m_materials[0]->m_kLST = 0.45; - psb->m_cfg.kVC = 20; - psb->setTotalMass(50,true); - psb->setPose(true,false); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - Ctor_BigPlate(pdemo); - Ctor_LinearStair(pdemo,btVector3(0,0,0),btVector3(2,1,5),0,10); - pdemo->m_autocam=true; - -} - -// -// Stick+Bending+Rb's -// -static void Init_Sticks(SoftDemo* pdemo) -{ - //TRACEDEMO - const int n=16; - const int sg=4; - const btScalar sz=5; - const btScalar hg=4; - const btScalar in=1/(btScalar)(n-1); - for(int y=0;ym_softBodyWorldInfo, org, - org+btVector3(hg*0.001,hg,0), - sg, - 1); - psb->m_cfg.kDP = 0.005; - psb->m_cfg.kCHR = 0.1; - for(int i=0;i<3;++i) - { - psb->generateBendingConstraints(2+i); - } - psb->setMass(1,0); - psb->setTotalMass(0.01); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - } - } - Ctor_BigBall(pdemo); -} - -// -// Bending -// -static void Init_Bending(SoftDemo* pdemo) -{ - //TRACEDEMO - const btScalar s=4; - const btVector3 x[]={ btVector3(-s,0,-s), - btVector3(+s,0,-s), - btVector3(+s,0,+s), - btVector3(-s,0,+s)}; - const btScalar m[]={ 0,0,0,1}; - btSoftBody* psb=new btSoftBody(&pdemo->m_softBodyWorldInfo,4,x,m); - psb->appendLink(0,1); - psb->appendLink(1,2); - psb->appendLink(2,3); - psb->appendLink(3,0); - psb->appendLink(0,2); - - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); -} - -// -// 100kg cloth locked at corners, 10 falling 10kg rb's. -// -static void Init_Cloth(SoftDemo* pdemo) -{ - //TRACEDEMO - const btScalar s=8; - btSoftBody* psb=btSoftBodyHelpers::CreatePatch( pdemo->m_softBodyWorldInfo,btVector3(-s,0,-s), - btVector3(+s,0,-s), - btVector3(-s,0,+s), - btVector3(+s,0,+s), - 31,31, - // 31,31, - 1+2+4+8,true); - - psb->getCollisionShape()->setMargin(0.5); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 0.4; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->setTotalMass(150); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - Ctor_RbUpStack(pdemo,10); - pdemo->m_cutting=true; -} - -// -// 100kg Stanford's bunny -// -static void Init_Bunny(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo,gVerticesBunny, - &gIndicesBunny[0][0], - BUNNY_NUM_TRIANGLES); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 0.5; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_cfg.piterations = 2; - psb->m_cfg.kDF = 0.5; - psb->randomizeConstraints(); - psb->scale(btVector3(6,6,6)); - psb->setTotalMass(100,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - pdemo->m_cutting=true; - -} - -// -// 100kg Stanford's bunny with pose matching -// -static void Init_BunnyMatch(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo, gVerticesBunny, - &gIndicesBunny[0][0], - BUNNY_NUM_TRIANGLES); - psb->m_cfg.kDF = 0.5; - psb->m_cfg.kMT = 0.05; - psb->m_cfg.piterations = 5; - psb->randomizeConstraints(); - psb->scale(btVector3(6,6,6)); - psb->setTotalMass(100,true); - psb->setPose(false,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - -} - -// -// 50Kg Torus -// -static void Init_Torus(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh( pdemo->m_softBodyWorldInfo, gVertices, - &gIndices[0][0], - NUM_TRIANGLES); - psb->generateBendingConstraints(2); - psb->m_cfg.piterations=2; - psb->randomizeConstraints(); - btMatrix3x3 m; - m.setEulerZYX(SIMD_PI/2,0,0); - psb->transform(btTransform(m,btVector3(0,4,0))); - psb->scale(btVector3(2,2,2)); - psb->setTotalMass(50,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - pdemo->m_cutting=true; - - -} - -// -// 50Kg Torus with pose matching -// -static void Init_TorusMatch(SoftDemo* pdemo) -{ - //TRACEDEMO - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo, gVertices, - &gIndices[0][0], - NUM_TRIANGLES); - psb->m_materials[0]->m_kLST = 0.1; - psb->m_cfg.kMT = 0.05; - psb->randomizeConstraints(); - btMatrix3x3 m; - m.setEulerZYX(SIMD_PI/2,0,0); - psb->transform(btTransform(m,btVector3(0,4,0))); - psb->scale(btVector3(2,2,2)); - psb->setTotalMass(50,true); - psb->setPose(false,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); -} - -// -// Cutting1 -// -static void Init_Cutting1(SoftDemo* pdemo) -{ - const btScalar s=6; - const btScalar h=2; - const int r=16; - const btVector3 p[]={ btVector3(+s,h,-s), - btVector3(-s,h,-s), - btVector3(+s,h,+s), - btVector3(-s,h,+s)}; - btSoftBody* psb=btSoftBodyHelpers::CreatePatch(pdemo->m_softBodyWorldInfo,p[0],p[1],p[2],p[3],r,r,1+2+4+8,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - psb->m_cfg.piterations=1; - pdemo->m_cutting=true; -} - -// -// Clusters -// - -// -static void Ctor_Gear(SoftDemo* pdemo,const btVector3& pos,btScalar speed) -{ - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(pos); - btCompoundShape* shape=new btCompoundShape(); -#if 1 - shape->addChildShape(btTransform(btQuaternion(0,0,0)),new btBoxShape(btVector3(5,1,6))); - shape->addChildShape(btTransform(btQuaternion(0,0,SIMD_HALF_PI)),new btBoxShape(btVector3(5,1,6))); -#else - shape->addChildShape(btTransform(btQuaternion(0,0,0)),new btCylinderShapeZ(btVector3(5,1,7))); - shape->addChildShape(btTransform(btQuaternion(0,0,SIMD_HALF_PI)),new btBoxShape(btVector3(4,1,8))); -#endif - btRigidBody* body=pdemo->localCreateRigidBody(10,startTransform,shape); - body->setFriction(1); - btDynamicsWorld* world=pdemo->getDynamicsWorld(); - btHingeConstraint* hinge=new btHingeConstraint(*body,btTransform::getIdentity()); - if(speed!=0) hinge->enableAngularMotor(true,speed,3); - world->addConstraint(hinge); -} - -// -static btSoftBody* Ctor_ClusterBunny(SoftDemo* pdemo,const btVector3& x,const btVector3& a) -{ - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo,gVerticesBunny,&gIndicesBunny[0][0],BUNNY_NUM_TRIANGLES); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 1; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_cfg.piterations = 2; - psb->m_cfg.kDF = 1; - psb->m_cfg.collisions = btSoftBody::fCollision::CL_SS+ - btSoftBody::fCollision::CL_RS; - psb->randomizeConstraints(); - btMatrix3x3 m; - m.setEulerZYX(a.x(),a.y(),a.z()); - psb->transform(btTransform(m,x)); - psb->scale(btVector3(8,8,8)); - psb->setTotalMass(150,true); - psb->generateClusters(1); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); -} - -// -static btSoftBody* Ctor_ClusterTorus(SoftDemo* pdemo,const btVector3& x,const btVector3& a,const btVector3& s=btVector3(2,2,2)) -{ - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo,gVertices,&gIndices[0][0],NUM_TRIANGLES); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 1; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_cfg.piterations = 2; - psb->m_cfg.collisions = btSoftBody::fCollision::CL_SS+ - btSoftBody::fCollision::CL_RS; - psb->randomizeConstraints(); - psb->scale(s); - psb->rotate(btQuaternion(a[0],a[1],a[2])); - psb->translate(x); - psb->setTotalMass(50,true); - psb->generateClusters(64); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); -} - -// -static struct MotorControl : btSoftBody::AJoint::IControl -{ - MotorControl() - { - goal=0; - maxtorque=0; - } - btScalar Speed(btSoftBody::AJoint*,btScalar current) - { - return(current+btMin(maxtorque,btMax(-maxtorque,goal-current))); - } - btScalar goal; - btScalar maxtorque; -} motorcontrol; - -// -struct SteerControl : btSoftBody::AJoint::IControl -{ - SteerControl(btScalar s) - { - angle=0; - sign=s; - } - void Prepare(btSoftBody::AJoint* joint) - { - joint->m_refs[0][0]=btCos(angle*sign); - joint->m_refs[0][2]=btSin(angle*sign); - } - btScalar Speed(btSoftBody::AJoint* joint,btScalar current) - { - return(motorcontrol.Speed(joint,current)); - } - btScalar angle; - btScalar sign; -}; - -static SteerControl steercontrol_f(+1); -static SteerControl steercontrol_r(-1); - -// -static void Init_ClusterDeform(SoftDemo* pdemo) -{ - btSoftBody* psb=Ctor_ClusterTorus(pdemo,btVector3(0,0,0),btVector3(SIMD_PI/2,0,SIMD_HALF_PI)); - psb->generateClusters(8); - psb->m_cfg.kDF=1; -} - -// -static void Init_ClusterCollide1(SoftDemo* pdemo) -{ - const btScalar s=8; - btSoftBody* psb=btSoftBodyHelpers::CreatePatch( pdemo->m_softBodyWorldInfo,btVector3(-s,0,-s), - btVector3(+s,0,-s), - btVector3(-s,0,+s), - btVector3(+s,0,+s), - 17,17,//9,9,//31,31, - 1+2+4+8, - true); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_kLST = 0.4; - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->m_cfg.kDF = 1; - psb->m_cfg.kSRHR_CL = 1; - psb->m_cfg.kSR_SPLT_CL = 0; - psb->m_cfg.collisions = btSoftBody::fCollision::CL_SS+ - - btSoftBody::fCollision::CL_RS; - psb->generateBendingConstraints(2,pm); - - psb->getCollisionShape()->setMargin(0.05); - psb->setTotalMass(50); - - ///pass zero in generateClusters to create cluster for each tetrahedron or triangle - psb->generateClusters(0); - //psb->generateClusters(64); - - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - - Ctor_RbUpStack(pdemo,10); -} - -// -static void Init_ClusterCollide2(SoftDemo* pdemo) -{ - struct Functor - { - static btSoftBody* Create(SoftDemo* pdemo,const btVector3& x,const btVector3& a) - { - btSoftBody* psb=btSoftBodyHelpers::CreateFromTriMesh(pdemo->m_softBodyWorldInfo,gVertices, - &gIndices[0][0], - NUM_TRIANGLES); - btSoftBody::Material* pm=psb->appendMaterial(); - pm->m_flags -= btSoftBody::fMaterial::DebugDraw; - psb->generateBendingConstraints(2,pm); - psb->m_cfg.piterations=2; - psb->m_cfg.kDF =1; - psb->m_cfg.kSSHR_CL =1; - psb->m_cfg.kSS_SPLT_CL =0; - psb->m_cfg.kSKHR_CL =0.1f; - psb->m_cfg.kSK_SPLT_CL =1; - psb->m_cfg.collisions= btSoftBody::fCollision::CL_SS+ - btSoftBody::fCollision::CL_RS; - psb->randomizeConstraints(); - btMatrix3x3 m; - m.setEulerZYX(a.x(),a.y(),a.z()); - psb->transform(btTransform(m,x)); - psb->scale(btVector3(2,2,2)); - psb->setTotalMass(50,true); - psb->generateClusters(16); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); - } - }; - for(int i=0;i<3;++i) - { - Functor::Create(pdemo,btVector3(3*i,2,0),btVector3(SIMD_PI/2*(1-(i&1)),SIMD_PI/2*(i&1),0)); - } -} - -// -static void Init_ClusterSocket(SoftDemo* pdemo) -{ - btSoftBody* psb=Ctor_ClusterTorus(pdemo,btVector3(0,0,0),btVector3(SIMD_PI/2,0,SIMD_HALF_PI)); - btRigidBody* prb=Ctor_BigPlate(pdemo,50,8); - psb->m_cfg.kDF=1; - btSoftBody::LJoint::Specs lj; - lj.position = btVector3(0,5,0); - psb->appendLinearJoint(lj,prb); -} - -// -static void Init_ClusterHinge(SoftDemo* pdemo) -{ - btSoftBody* psb=Ctor_ClusterTorus(pdemo,btVector3(0,0,0),btVector3(SIMD_PI/2,0,SIMD_HALF_PI)); - btRigidBody* prb=Ctor_BigPlate(pdemo,50,8); - psb->m_cfg.kDF=1; - btSoftBody::AJoint::Specs aj; - aj.axis = btVector3(0,0,1); - psb->appendAngularJoint(aj,prb); -} - -// -static void Init_ClusterCombine(SoftDemo* pdemo) -{ - const btVector3 sz(2,4,2); - btSoftBody* psb0=Ctor_ClusterTorus(pdemo,btVector3(0,8,0),btVector3(SIMD_PI/2,0,SIMD_HALF_PI),sz); - btSoftBody* psb1=Ctor_ClusterTorus(pdemo,btVector3(0,8,10),btVector3(SIMD_PI/2,0,SIMD_HALF_PI),sz); - btSoftBody* psbs[]={psb0,psb1}; - for(int j=0;j<2;++j) - { - psbs[j]->m_cfg.kDF=1; - psbs[j]->m_cfg.kDP=0; - psbs[j]->m_cfg.piterations=1; - psbs[j]->m_clusters[0]->m_matching = 0.05; - psbs[j]->m_clusters[0]->m_ndamping = 0.05; - } - btSoftBody::AJoint::Specs aj; - aj.axis = btVector3(0,0,1); - aj.icontrol = &motorcontrol; - psb0->appendAngularJoint(aj,psb1); - - btSoftBody::LJoint::Specs lj; - lj.position = btVector3(0,8,5); - psb0->appendLinearJoint(lj,psb1); -} - -// -static void Init_ClusterCar(SoftDemo* pdemo) -{ - pdemo->setAzi(180); - const btVector3 origin(100,80,0); - const btQuaternion orientation(-SIMD_PI/2,0,0); - const btScalar widthf=8; - const btScalar widthr=9; - const btScalar length=8; - const btScalar height=4; - const btVector3 wheels[]= { - btVector3(+widthf,-height,+length), // Front left - btVector3(-widthf,-height,+length), // Front right - btVector3(+widthr,-height,-length), // Rear left - btVector3(-widthr,-height,-length), // Rear right - }; - btSoftBody* pa=Ctor_ClusterBunny(pdemo,btVector3(0,0,0),btVector3(0,0,0)); - btSoftBody* pfl=Ctor_ClusterTorus(pdemo,wheels[0],btVector3(0,0,SIMD_HALF_PI),btVector3(2,4,2)); - btSoftBody* pfr=Ctor_ClusterTorus(pdemo,wheels[1],btVector3(0,0,SIMD_HALF_PI),btVector3(2,4,2)); - btSoftBody* prl=Ctor_ClusterTorus(pdemo,wheels[2],btVector3(0,0,SIMD_HALF_PI),btVector3(2,5,2)); - btSoftBody* prr=Ctor_ClusterTorus(pdemo,wheels[3],btVector3(0,0,SIMD_HALF_PI),btVector3(2,5,2)); - - pfl->m_cfg.kDF = - pfr->m_cfg.kDF = - prl->m_cfg.kDF = - prr->m_cfg.kDF = 1; - - btSoftBody::LJoint::Specs lspecs; - lspecs.cfm = 1; - lspecs.erp = 1; - lspecs.position = btVector3(0,0,0); - - lspecs.position=wheels[0];pa->appendLinearJoint(lspecs,pfl); - lspecs.position=wheels[1];pa->appendLinearJoint(lspecs,pfr); - lspecs.position=wheels[2];pa->appendLinearJoint(lspecs,prl); - lspecs.position=wheels[3];pa->appendLinearJoint(lspecs,prr); - - btSoftBody::AJoint::Specs aspecs; - aspecs.cfm = 1; - aspecs.erp = 1; - aspecs.axis = btVector3(1,0,0); - - aspecs.icontrol = &steercontrol_f; - pa->appendAngularJoint(aspecs,pfl); - pa->appendAngularJoint(aspecs,pfr); - - aspecs.icontrol = &motorcontrol; - pa->appendAngularJoint(aspecs,prl); - pa->appendAngularJoint(aspecs,prr); - - pa->rotate(orientation); - pfl->rotate(orientation); - pfr->rotate(orientation); - prl->rotate(orientation); - prr->rotate(orientation); - pa->translate(origin); - pfl->translate(origin); - pfr->translate(origin); - prl->translate(origin); - prr->translate(origin); - pfl->m_cfg.piterations = - pfr->m_cfg.piterations = - prl->m_cfg.piterations = - prr->m_cfg.piterations = 1; - pfl->m_clusters[0]->m_matching = - pfr->m_clusters[0]->m_matching = - prl->m_clusters[0]->m_matching = - prr->m_clusters[0]->m_matching = 0.05; - pfl->m_clusters[0]->m_ndamping = - pfr->m_clusters[0]->m_ndamping = - prl->m_clusters[0]->m_ndamping = - prr->m_clusters[0]->m_ndamping = 0.05; - - Ctor_LinearStair(pdemo,btVector3(0,-8,0),btVector3(3,2,40),0,20); - Ctor_RbUpStack(pdemo,50); - pdemo->m_autocam=true; - -} - -// -static void Init_ClusterRobot(SoftDemo* pdemo) -{ - struct Functor - { - static btSoftBody* CreateBall(SoftDemo* pdemo,const btVector3& pos) - { - btSoftBody* psb=btSoftBodyHelpers::CreateEllipsoid(pdemo->m_softBodyWorldInfo,pos,btVector3(1,1,1)*3,512); - psb->m_materials[0]->m_kLST = 0.45; - psb->m_cfg.kVC = 20; - psb->setTotalMass(50,true); - psb->setPose(true,false); - psb->generateClusters(1); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - return(psb); - } - }; - const btVector3 base=btVector3(0,25,8); - btSoftBody* psb0=Functor::CreateBall(pdemo,base+btVector3(-8,0,0)); - btSoftBody* psb1=Functor::CreateBall(pdemo,base+btVector3(+8,0,0)); - btSoftBody* psb2=Functor::CreateBall(pdemo,base+btVector3(0,0,+8*btSqrt(2))); - const btVector3 ctr=(psb0->clusterCom(0)+psb1->clusterCom(0)+psb2->clusterCom(0))/3; - btCylinderShape* pshp=new btCylinderShape(btVector3(8,1,8)); - btRigidBody* prb=pdemo->localCreateRigidBody(50,btTransform(btQuaternion(0,0,0),ctr+btVector3(0,5,0)),pshp); - btSoftBody::LJoint::Specs ls; - ls.erp=0.5f; - ls.position=psb0->clusterCom(0);psb0->appendLinearJoint(ls,prb); - ls.position=psb1->clusterCom(0);psb1->appendLinearJoint(ls,prb); - ls.position=psb2->clusterCom(0);psb2->appendLinearJoint(ls,prb); - - btBoxShape* pbox=new btBoxShape(btVector3(20,1,40)); - btRigidBody* pgrn=pdemo->localCreateRigidBody(0,btTransform(btQuaternion(0,-SIMD_HALF_PI/2,0),btVector3(0,0,0)),pbox); - - pdemo->m_autocam=true; - -} - -// -static void Init_ClusterStackSoft(SoftDemo* pdemo) -{ - for(int i=0;i<10;++i) - { - btSoftBody* psb=Ctor_ClusterTorus(pdemo,btVector3(0,-9+8.25*i,0),btVector3(0,0,0)); - psb->m_cfg.kDF=1; - } -} - -// -static void Init_ClusterStackMixed(SoftDemo* pdemo) -{ - for(int i=0;i<10;++i) - { - if((i+1)&1) - { - Ctor_BigPlate(pdemo,50,-9+4.25*i); - } - else - { - btSoftBody* psb=Ctor_ClusterTorus(pdemo,btVector3(0,-9+4.25*i,0),btVector3(0,0,0)); - psb->m_cfg.kDF=1; - } - } -} - - -// -// TetraBunny -// -static void Init_TetraBunny(SoftDemo* pdemo) -{ - btSoftBody* psb=btSoftBodyHelpers::CreateFromTetGenData(pdemo->m_softBodyWorldInfo, - TetraBunny::getElements(), - 0, - TetraBunny::getNodes(), - false,true,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - psb->rotate(btQuaternion(SIMD_PI/2,0,0)); - psb->setVolumeMass(150); - psb->m_cfg.piterations=2; - //psb->m_cfg.piterations=1; - pdemo->m_cutting=false; - //psb->getCollisionShape()->setMargin(0.01); - psb->m_cfg.collisions = btSoftBody::fCollision::CL_SS+ btSoftBody::fCollision::CL_RS - //+ btSoftBody::fCollision::CL_SELF - ; - - ///pass zero in generateClusters to create cluster for each tetrahedron or triangle - psb->generateClusters(0); - //psb->m_materials[0]->m_kLST=.2; - psb->m_cfg.kDF = 10. ; - - -} - -// -// TetraCube -// -static void Init_TetraCube(SoftDemo* pdemo) -{ - btSoftBody* psb=btSoftBodyHelpers::CreateFromTetGenData(pdemo->m_softBodyWorldInfo, - TetraCube::getElements(), - 0, - TetraCube::getNodes(), - false,true,true); - pdemo->getSoftDynamicsWorld()->addSoftBody(psb); - psb->scale(btVector3(4,4,4)); - psb->translate(btVector3(0,5,0)); - psb->setVolumeMass(300); - - - ///fix one vertex - //psb->setMass(0,0); - //psb->setMass(10,0); - //psb->setMass(20,0); - psb->m_cfg.piterations=1; - //psb->generateClusters(128); - psb->generateClusters(16); - //psb->getCollisionShape()->setMargin(0.5); - - psb->getCollisionShape()->setMargin(0.01); - psb->m_cfg.collisions = btSoftBody::fCollision::CL_SS+ btSoftBody::fCollision::CL_RS - //+ btSoftBody::fCollision::CL_SELF - ; - psb->m_materials[0]->m_kLST=0.8; - pdemo->m_cutting=false; -} - - - - - - /* Init */ - void (*demofncs[])(SoftDemo*)= - { - Init_Cloth, - Init_Pressure, - Init_Volume, - Init_Ropes, - Init_RopeAttach, - Init_ClothAttach, - Init_Sticks, - Init_CapsuleCollision, - Init_Collide, - Init_Collide2, - Init_Collide3, - Init_Impact, - Init_Aero, - Init_Aero2, - Init_Friction, - Init_Torus, - Init_TorusMatch, - Init_Bunny, - Init_BunnyMatch, - Init_Cutting1, - Init_ClusterDeform, - Init_ClusterCollide1, - Init_ClusterCollide2, - Init_ClusterSocket, - Init_ClusterHinge, - Init_ClusterCombine, - Init_ClusterCar, - Init_ClusterRobot, - Init_ClusterStackSoft, - Init_ClusterStackMixed, - Init_TetraCube, - Init_TetraBunny, - }; - -void SoftDemo::clientResetScene() -{ - m_azi = 0; - m_cameraDistance = 30.f; - m_cameraTargetPosition.setValue(0,0,0); - - DemoApplication::clientResetScene(); - /* Clean up */ - for(int i=m_dynamicsWorld->getNumCollisionObjects()-1;i>=0;i--) - { - btCollisionObject* obj=m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body=btRigidBody::upcast(obj); - if(body&&body->getMotionState()) - { - delete body->getMotionState(); - } - while(m_dynamicsWorld->getNumConstraints()) - { - btTypedConstraint* pc=m_dynamicsWorld->getConstraint(0); - m_dynamicsWorld->removeConstraint(pc); - delete pc; - } - btSoftBody* softBody = btSoftBody::upcast(obj); - if (softBody) - { - getSoftDynamicsWorld()->removeSoftBody(softBody); - } else - { - btRigidBody* body = btRigidBody::upcast(obj); - if (body) - m_dynamicsWorld->removeRigidBody(body); - else - m_dynamicsWorld->removeCollisionObject(obj); - } - delete obj; - } - - - //create ground object - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(0,-12,0)); - - btCollisionObject* newOb = new btCollisionObject(); - newOb->setWorldTransform(tr); - newOb->setInterpolationWorldTransform( tr); - int lastDemo = (sizeof(demofncs)/sizeof(demofncs[0]))-1; - - if (current_demo<0) - current_demo = lastDemo; - if (current_demo > lastDemo) - current_demo =0; - - - if (current_demo>19) - { - newOb->setCollisionShape(m_collisionShapes[0]); - } else - { - newOb->setCollisionShape(m_collisionShapes[1]); - } - - m_dynamicsWorld->addCollisionObject(newOb); - - m_softBodyWorldInfo.m_sparsesdf.Reset(); - - - - - - - - motorcontrol.goal = 0; - motorcontrol.maxtorque = 0; - - - - m_softBodyWorldInfo.air_density = (btScalar)1.2; - m_softBodyWorldInfo.water_density = 0; - m_softBodyWorldInfo.water_offset = 0; - m_softBodyWorldInfo.water_normal = btVector3(0,0,0); - m_softBodyWorldInfo.m_gravity.setValue(0,-10,0); - - - m_autocam = false; - m_raycast = false; - m_cutting = false; - m_results.fraction = 1.f; - demofncs[current_demo](this); -} - - -void SoftDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT|GL_STENCIL_BUFFER_BIT); - - - - - float ms = getDeltaTimeMicroseconds(); - float dt = ms / 1000000.f;//1.0/60.; - - - - if (m_dynamicsWorld) - { - - if (sDemoMode) - { - static float demoCounter = DEMO_MODE_TIMEOUT; - demoCounter-= dt; - if (demoCounter<0) - { - - demoCounter=DEMO_MODE_TIMEOUT; - current_demo++; - current_demo=current_demo%(sizeof(demofncs)/sizeof(demofncs[0])); - clientResetScene(); - } - } - - -//#define FIXED_STEP -#ifdef FIXED_STEP - m_dynamicsWorld->stepSimulation(dt=1.0f/60.f,0); - -#else - //during idle mode, just run 1 simulation step maximum, otherwise 4 at max - // int maxSimSubSteps = m_idle ? 1 : 4; - //if (m_idle) - // dt = 1.0/420.f; - - int numSimSteps; - numSimSteps = m_dynamicsWorld->stepSimulation(dt); - //numSimSteps = m_dynamicsWorld->stepSimulation(dt,10,1./240.f); - -#ifdef VERBOSE_TIMESTEPPING_CONSOLEOUTPUT - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } -#endif //VERBOSE_TIMESTEPPING_CONSOLEOUTPUT - -#endif - -#ifdef USE_AMD_OPENCL - if (g_openCLSIMDSolver) - g_openCLSIMDSolver->copyBackToSoftBodies(); -#endif //USE_AMD_OPENCL - - if(m_drag) - { - m_node->m_v*=0; - } - - m_softBodyWorldInfo.m_sparsesdf.GarbageCollect(); - - //optional but useful: debug drawing - - } - -#ifdef USE_QUICKPROF - btProfiler::beginBlock("render"); -#endif //USE_QUICKPROF - - renderme(); - - //render the graphics objects, with center of mass shift - - updateCamera(); - - - -#ifdef USE_QUICKPROF - btProfiler::endBlock("render"); -#endif - glFlush(); - //some additional debugging info -#ifdef PRINT_CONTACT_STATISTICS - printf("num manifolds: %i\n",gNumManifold); - printf("num gOverlappingPairs: %i\n",gOverlappingPairs); - -#endif //PRINT_CONTACT_STATISTICS - - - swapBuffers(); - -} - - - -void SoftDemo::renderme() -{ - btIDebugDraw* idraw=m_dynamicsWorld->getDebugDrawer(); - - glDisable(GL_TEXTURE_2D); - glDisable(GL_LIGHTING); - m_dynamicsWorld->debugDrawWorld(); - - //int debugMode = m_dynamicsWorld->getDebugDrawer()? m_dynamicsWorld->getDebugDrawer()->getDebugMode() : -1; - - btSoftRigidDynamicsWorld* softWorld = (btSoftRigidDynamicsWorld*)m_dynamicsWorld; - //btIDebugDraw* sdraw = softWorld ->getDebugDrawer(); - - - for ( int i=0;igetSoftBodyArray().size();i++) - { - btSoftBody* psb=(btSoftBody*)softWorld->getSoftBodyArray()[i]; - if (softWorld->getDebugDrawer() && !(softWorld->getDebugDrawer()->getDebugMode() & (btIDebugDraw::DBG_DrawWireframe))) - { - btSoftBodyHelpers::DrawFrame(psb,softWorld->getDebugDrawer()); - btSoftBodyHelpers::Draw(psb,softWorld->getDebugDrawer(),softWorld->getDrawFlags()); - } - } - - /* Bodies */ - btVector3 ps(0,0,0); - int nps=0; - - btSoftBodyArray& sbs=getSoftDynamicsWorld()->getSoftBodyArray(); - for(int ib=0;ibm_nodes.size(); - for(int i=0;im_nodes.size();++i) - { - ps+=psb->m_nodes[i].m_x; - } - } - ps/=nps; - if(m_autocam) - m_cameraTargetPosition+=(ps-m_cameraTargetPosition)*0.05; - /* Anm */ - if(!isIdle()) - m_animtime=m_clock.getTimeMilliseconds()/1000.f; - /* Ray cast */ - if(m_raycast) - { - /* Prepare rays */ - const int res=64; - const btScalar fres=res-1; - const btScalar size=8; - const btScalar dist=10; - btTransform trs; - trs.setOrigin(ps); - btScalar rayLength = 1000.f; - - const btScalar angle=m_animtime*0.2; - trs.setRotation(btQuaternion(angle,SIMD_PI/4,0)); - btVector3 dir=trs.getBasis()*btVector3(0,-1,0); - trs.setOrigin(ps-dir*dist); - btAlignedObjectArray origins; - btAlignedObjectArray fractions; - origins.resize(res*res); - fractions.resize(res*res,1.f); - for(int y=0;yrayTest(rayFrom,rayTo,results)) - { - *fraction=results.fraction; - } - } - ++org;++fraction; - } - long ms=btMax(m_clock.getTimeMilliseconds(),1); - long rayperseconds=(1000*(origins.size()*sbs.size()))/ms; - printf("%d ms (%d rays/s)\r\n",int(ms),int(rayperseconds)); - } - } - /* Draw rays */ - const btVector3 c[]={ origins[0], - origins[res-1], - origins[res*(res-1)], - origins[res*(res-1)+res-1]}; - idraw->drawLine(c[0],c[1],btVector3(0,0,0)); - idraw->drawLine(c[1],c[3],btVector3(0,0,0)); - idraw->drawLine(c[3],c[2],btVector3(0,0,0)); - idraw->drawLine(c[2],c[0],btVector3(0,0,0)); - for(int i=0,ni=origins.size();idrawLine(org,org+dir*rayLength*fraction,btVector3(1,0,0)); - } - else - { - idraw->drawLine(org,org-dir*rayLength*0.1,btVector3(0,0,0)); - } - } -#undef RES - } - /* Water level */ - static const btVector3 axis[]={btVector3(1,0,0), - btVector3(0,1,0), - btVector3(0,0,1)}; - if(m_softBodyWorldInfo.water_density>0) - { - const btVector3 c= btVector3((btScalar)0.25,(btScalar)0.25,1); - const btScalar a= (btScalar)0.5; - const btVector3 n= m_softBodyWorldInfo.water_normal; - const btVector3 o= -n*m_softBodyWorldInfo.water_offset; - const btVector3 x= btCross(n,axis[n.minAxis()]).normalized(); - const btVector3 y= btCross(x,n).normalized(); - const btScalar s= 25; - idraw->drawTriangle(o-x*s-y*s,o+x*s-y*s,o+x*s+y*s,c,a); - idraw->drawTriangle(o-x*s-y*s,o+x*s+y*s,o-x*s+y*s,c,a); - } - // - - int lineWidth=280; - int xStart = m_glutScreenWidth - lineWidth; - int yStart = 20; - - if((getDebugMode() & btIDebugDraw::DBG_NoHelpText)==0) - { - setOrthographicProjection(); - glDisable(GL_LIGHTING); - glColor3f(0, 0, 0); - char buf[124]; - - glRasterPos3f(xStart, yStart, 0); - if (sDemoMode) - { - sprintf(buf,"d to toggle demo mode (on)"); - } else - { - sprintf(buf,"d to toggle demo mode (off)"); - } - GLDebugDrawString(xStart,20,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"] for next demo (%d)",current_demo); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"c to visualize clusters"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"; to toggle camera mode"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - glRasterPos3f(xStart, yStart, 0); - sprintf(buf,"n,m,l,k for power and steering"); - yStart+=20; - GLDebugDrawString(xStart,yStart,buf); - - - resetPerspectiveProjection(); - glEnable(GL_LIGHTING); - } - - DemoApplication::renderme(); - -} - -void SoftDemo::setDrawClusters(bool drawClusters) -{ - if (drawClusters) - { - getSoftDynamicsWorld()->setDrawFlags(getSoftDynamicsWorld()->getDrawFlags()|fDrawFlags::Clusters); - } else - { - getSoftDynamicsWorld()->setDrawFlags(getSoftDynamicsWorld()->getDrawFlags()& (~fDrawFlags::Clusters)); - } -} - - - -void SoftDemo::keyboardCallback(unsigned char key, int x, int y) -{ - switch(key) - { - case 'd': sDemoMode = !sDemoMode; break; - case 'n': motorcontrol.maxtorque=10;motorcontrol.goal+=1;break; - case 'm': motorcontrol.maxtorque=10;motorcontrol.goal-=1;break; - case 'l': steercontrol_f.angle+=0.1;steercontrol_r.angle+=0.1;break; - case 'k': steercontrol_f.angle-=0.1;steercontrol_r.angle-=0.1;break; - case ']': ++current_demo;clientResetScene();break; - case '[': --current_demo;clientResetScene();break; - case ',': m_raycast=!m_raycast;break; - case ';': m_autocam=!m_autocam;break; - case 'c': getSoftDynamicsWorld()->setDrawFlags(getSoftDynamicsWorld()->getDrawFlags()^fDrawFlags::Clusters);break; - case '`': - { - btSoftBodyArray& sbs=getSoftDynamicsWorld()->getSoftBodyArray(); - for(int ib=0;ibstaticSolve(128); - } - } - break; - default: DemoApplication::keyboardCallback(key,x,y); - } -} - -// -void SoftDemo::mouseMotionFunc(int x,int y) -{ - if(m_node&&(m_results.fraction<1.f)) - { - if(!m_drag) - { -#define SQ(_x_) (_x_)*(_x_) - if((SQ(x-m_lastmousepos[0])+SQ(y-m_lastmousepos[1]))>6) - { - m_drag=true; - } -#undef SQ - } - if(m_drag) - { - m_lastmousepos[0] = x; - m_lastmousepos[1] = y; - } - } - else - { - DemoApplication::mouseMotionFunc(x,y); - } -} - -// -void SoftDemo::mouseFunc(int button, int state, int x, int y) -{ - if(button==0) - { - switch(state) - { - case 0: - { - m_results.fraction=1.f; - DemoApplication::mouseFunc(button,state,x,y); - if(!m_pickConstraint) - { - const btVector3 rayFrom=m_cameraPosition; - const btVector3 rayTo=getRayTo(x,y); - const btVector3 rayDir=(rayTo-rayFrom).normalized(); - btSoftBodyArray& sbs=getSoftDynamicsWorld()->getSoftBodyArray(); - for(int ib=0;ibrayTest(rayFrom,rayTo,res)) - { - m_results=res; - } - } - if(m_results.fraction<1.f) - { - m_impact = rayFrom+(rayTo-rayFrom)*m_results.fraction; - m_drag = m_cutting ? false : true; - m_lastmousepos[0] = x; - m_lastmousepos[1] = y; - m_node = 0; - switch(m_results.feature) - { - case btSoftBody::eFeature::Tetra: - { - btSoftBody::Tetra& tet=m_results.body->m_tetras[m_results.index]; - m_node=tet.m_n[0]; - for(int i=1;i<4;++i) - { - if( (m_node->m_x-m_impact).length2()> - (tet.m_n[i]->m_x-m_impact).length2()) - { - m_node=tet.m_n[i]; - } - } - break; - } - case btSoftBody::eFeature::Face: - { - btSoftBody::Face& f=m_results.body->m_faces[m_results.index]; - m_node=f.m_n[0]; - for(int i=1;i<3;++i) - { - if( (m_node->m_x-m_impact).length2()> - (f.m_n[i]->m_x-m_impact).length2()) - { - m_node=f.m_n[i]; - } - } - } - break; - } - if(m_node) m_goal=m_node->m_x; - return; - } - } - } - break; - case 1: - if((!m_drag)&&m_cutting&&(m_results.fraction<1.f)) - { - ImplicitSphere isphere(m_impact,1); - printf("Mass before: %f\r\n",m_results.body->getTotalMass()); - m_results.body->refine(&isphere,0.0001,true); - printf("Mass after: %f\r\n",m_results.body->getTotalMass()); - } - m_results.fraction=1.f; - m_drag=false; - DemoApplication::mouseFunc(button,state,x,y); - break; - } - } - else - { - DemoApplication::mouseFunc(button,state,x,y); - } -} - - -void SoftDemo::initPhysics() -{ - ///create concave ground mesh - - - m_azi = 0; - - //reset and disable motorcontrol at the start - motorcontrol.goal = 0; - motorcontrol.maxtorque = 0; - - btCollisionShape* groundShape = 0; - { - int i; - int j; - - const int NUM_VERTS_X = 30; - const int NUM_VERTS_Y = 30; - const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - - gGroundVertices = new btVector3[totalVerts]; - gGroundIndices = new int[totalTriangles*3]; - - btScalar offset(-50); - - for ( i=0;isetMargin(0.5); - } - - m_collisionShapes.push_back(groundShape); - - btCollisionShape* groundBox = new btBoxShape (btVector3(100,CUBE_HALF_EXTENTS,100)); - m_collisionShapes.push_back(groundBox); - - btCompoundShape* cylinderCompound = new btCompoundShape; - btCollisionShape* cylinderShape = new btCylinderShape (btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)); - btTransform localTransform; - localTransform.setIdentity(); - cylinderCompound->addChildShape(localTransform,cylinderShape); - btQuaternion orn(btVector3(0,1,0),SIMD_PI); - localTransform.setRotation(orn); - cylinderCompound->addChildShape(localTransform,cylinderShape); - - m_collisionShapes.push_back(cylinderCompound); - - - m_dispatcher=0; - - ///register some softbody collision algorithms on top of the default btDefaultCollisionConfiguration - m_collisionConfiguration = new btSoftBodyRigidBodyCollisionConfiguration(); - - - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - m_softBodyWorldInfo.m_dispatcher = m_dispatcher; - - //////////////////////////// - ///Register softbody versus softbody collision algorithm - - - ///Register softbody versus rigidbody collision algorithm - - - //////////////////////////// - - btVector3 worldAabbMin(-1000,-1000,-1000); - btVector3 worldAabbMax(1000,1000,1000); - - m_broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax,maxProxies); - - m_softBodyWorldInfo.m_broadphase = m_broadphase; - - btSequentialImpulseConstraintSolver* solver = new btSequentialImpulseConstraintSolver(); - - m_solver = solver; - - btSoftBodySolver* softBodySolver = 0; -#ifdef USE_AMD_OPENCL - - static bool once = true; - if (once) - { - once=false; - initCL(0,0); - } - - if( g_openCLSIMDSolver ) - delete g_openCLSIMDSolver; - if( g_softBodyOutput ) - delete g_softBodyOutput; - - if (1) - { - g_openCLSIMDSolver = new btOpenCLSoftBodySolverSIMDAware( g_cqCommandQue, g_cxMainContext); - // g_openCLSIMDSolver = new btOpenCLSoftBodySolver( g_cqCommandQue, g_cxMainContext); - g_openCLSIMDSolver->setCLFunctions(new CachingCLFunctions(g_cqCommandQue, g_cxMainContext)); - } - - - - softBodySolver = g_openCLSIMDSolver; - g_softBodyOutput = new btSoftBodySolverOutputCLtoCPU; -#endif //USE_AMD_OPENCL - - btDiscreteDynamicsWorld* world = new btSoftRigidDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration,softBodySolver); - m_dynamicsWorld = world; - m_dynamicsWorld->setInternalTickCallback(pickingPreTickCallback,this,true); - - - m_dynamicsWorld->getDispatchInfo().m_enableSPU = true; - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - m_softBodyWorldInfo.m_gravity.setValue(0,-10,0); - - // clientResetScene(); - - m_softBodyWorldInfo.m_sparsesdf.Initialize(); - clientResetScene(); -} - - - - - - -void SoftDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_SoftSoftCollisionAlgorithms; - - btAlignedObjectArray m_SoftRigidCollisionAlgorithms; - - btSoftBodyWorldInfo m_softBodyWorldInfo; - - - - bool m_autocam; - bool m_cutting; - bool m_raycast; - btScalar m_animtime; - btClock m_clock; - int m_lastmousepos[2]; - btVector3 m_impact; - btSoftBody::sRayCast m_results; - btSoftBody::Node* m_node; - btVector3 m_goal; - bool m_drag; - - - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - - btConstraintSolver* m_solver; - - btCollisionAlgorithmCreateFunc* m_boxBoxCF; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - -public: - - void initPhysics(); - - void exitPhysics(); - - SoftDemo() : m_drag(false) - { - setTexturing(true); - setShadows(true); - } - virtual ~SoftDemo() - { - exitPhysics(); - } - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - void createStack( btCollisionShape* boxShape, float halfCubeSize, int size, float zPos ); - - static DemoApplication* Create() - { - SoftDemo* demo = new SoftDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - virtual void setDrawClusters(bool drawClusters); - - virtual const btSoftRigidDynamicsWorld* getSoftDynamicsWorld() const - { - ///just make it a btSoftRigidDynamicsWorld please - ///or we will add type checking - return (btSoftRigidDynamicsWorld*) m_dynamicsWorld; - } - - virtual btSoftRigidDynamicsWorld* getSoftDynamicsWorld() - { - ///just make it a btSoftRigidDynamicsWorld please - ///or we will add type checking - return (btSoftRigidDynamicsWorld*) m_dynamicsWorld; - } - - // - void clientResetScene(); - void renderme(); - void keyboardCallback(unsigned char key, int x, int y); - void mouseFunc(int button, int state, int x, int y); - void mouseMotionFunc(int x,int y); - -}; - -#define MACRO_SOFT_DEMO(a) class SoftDemo##a : public SoftDemo\ -{\ -public:\ - static DemoApplication* Create()\ - {\ - SoftDemo* demo = new SoftDemo##a;\ - extern int current_demo;\ - current_demo=a;\ - demo->myinit();\ - demo->initPhysics();\ - return demo;\ - }\ -}; - - -MACRO_SOFT_DEMO(0) //Init_Cloth -MACRO_SOFT_DEMO(1) //Init_Pressure -MACRO_SOFT_DEMO(2)//Init_Volume -MACRO_SOFT_DEMO(3)//Init_Ropes -MACRO_SOFT_DEMO(4)//Init_Ropes_Attach -MACRO_SOFT_DEMO(5)//Init_ClothAttach -MACRO_SOFT_DEMO(6)//Init_Sticks -MACRO_SOFT_DEMO(7)//Init_Collide -MACRO_SOFT_DEMO(8)//Init_Collide2 -MACRO_SOFT_DEMO(9)//Init_Collide3 -MACRO_SOFT_DEMO(10)//Init_Impact -MACRO_SOFT_DEMO(11)//Init_Aero -MACRO_SOFT_DEMO(12)//Init_Friction -MACRO_SOFT_DEMO(13)//Init_Torus -MACRO_SOFT_DEMO(14)//Init_TorusMatch -MACRO_SOFT_DEMO(15)//Init_Bunny -MACRO_SOFT_DEMO(16)//Init_BunnyMatch -MACRO_SOFT_DEMO(17)//Init_Cutting1 -MACRO_SOFT_DEMO(18)//Init_ClusterDeform -MACRO_SOFT_DEMO(19)//Init_ClusterCollide1 -MACRO_SOFT_DEMO(20)//Init_ClusterCollide2 -MACRO_SOFT_DEMO(21)//Init_ClusterSocket -MACRO_SOFT_DEMO(22)//Init_ClusterHinge -MACRO_SOFT_DEMO(23)//Init_ClusterCombine -MACRO_SOFT_DEMO(24)//Init_ClusterCar -MACRO_SOFT_DEMO(25)//Init_ClusterRobot -MACRO_SOFT_DEMO(26)//Init_ClusterStackSoft -MACRO_SOFT_DEMO(27)//Init_ClusterStackMixed -MACRO_SOFT_DEMO(28)//Init_TetraCube -MACRO_SOFT_DEMO(29)//Init_TetraBunny - - -#endif //CCD_PHYSICS_DEMO_H - - - - - diff --git a/Demos/SoftDemo/bunny.inl b/Demos/SoftDemo/bunny.inl deleted file mode 100644 index fbdbfd3fb..000000000 --- a/Demos/SoftDemo/bunny.inl +++ /dev/null @@ -1,4 +0,0 @@ -static const char* getNodes() { return( -"454 3 0 0\n"" 0 -2.0063499999999999 0.79804200000000003 0.373554\n"" 1 -2.1011299999999999 0.90212400000000004 -0.88661400000000001\n"" 2 -1.4052100000000001 2.0628700000000002 -1.0458400000000001\n"" 3 -1.2015499999999999 1.7112400000000001 0.56249400000000005\n"" 4 0.02112 2.8512499999999998 -0.95618999999999998\n"" 5 0.011136 2.5152199999999998 0.59149200000000002\n"" 6 -1.51681 0.56199600000000005 1.42523\n"" 7 -0.977406 1.4278999999999999 1.24143\n"" 8 0.0051900000000000002 1.9088499999999999 1.41222\n"" 9 -2.4877400000000001 0.98449799999999998 -1.6695199999999999\n"" 10 -1.57328 2.1440000000000001 -1.7594799999999999\n"" 11 0.027768000000000001 2.8961600000000001 -2.0317599999999998\n"" 12 -2.4129700000000001 0.80116799999999999 -2.6594799999999998\n"" 13 -1.46269 1.9456500000000001 -2.6205799999999999\n"" 14 0.031758000000000002 2.6255500000000001 -2.7499899999999999\n"" 15 -2.0392999999999999 -0.24690000000000001 -4.0092699999999999\n"" 16 -1.4902899999999999 1.53495 -3.7649599999999999\n"" 17 0.037566000000000002 2.2566199999999998 -3.78904\n"" 18 -1.29721 -0.760656 -5.3216200000000002\n"" 19 -1.0264500000000001 0.069264000000000006 -5.2883199999999997\n"" 20 -1.0864400000000001 0.58933800000000003 -4.8886700000000003\n"" 21 -0.71934600000000004 1.3127200000000001 -4.5609200000000003\n"" 22 -0.47337000000000001 1.6606799999999999 -4.4356900000000001\n"" 23 0.040806000000000002 1.86575 -4.4139699999999999\n"" 24 -1.01305 0.61432200000000003 -5.5222899999999999\n"" 25 -0.62443199999999999 1.0636699999999999 -5.7151800000000001\n"" 26 -0.77822400000000003 1.2710900000000001 -5.0200699999999996\n"" 27 -0.59924999999999995 1.8655900000000001 -4.7962899999999999\n"" 28 0.043422000000000002 2.1701199999999998 -4.7666300000000001\n"" 29 -0.467478 1.5525199999999999 -5.5298400000000001\n"" 30 0.047742 1.6934499999999999 -5.5900800000000004\n"" 31 -1.5133300000000001 -3.3024100000000001 -3.3468599999999999\n"" 32 -1.6057999999999999 -3.6205099999999999 -3.9312499999999999\n"" 33 -2.6810299999999998 -0.71110200000000001 -2.7969499999999998\n"" 34 -2.7569300000000001 -0.55810199999999999 -1.86805\n"" 35 -2.2238699999999998 -0.60064799999999996 -0.95672400000000002\n"" 36 -2.2319 -0.55194600000000005 -0.066264000000000003\n"" 37 -1.97367 -0.58961399999999997 0.53195400000000004\n"" 38 -1.6947099999999999 -0.11317199999999999 1.8690100000000001\n"" 39 -2.11442 -0.78804600000000002 0.86941199999999996\n"" 40 -2.1847599999999998 -1.2017899999999999 1.2143299999999999\n"" 41 -1.7037899999999999 -1.3912100000000001 0.142008\n"" 42 -1.79366 -0.93130800000000002 2.2183000000000002\n"" 43 -1.7627200000000001 -0.73113600000000001 2.51458\n"" 44 -1.74098 -1.74478 0.64694399999999996\n"" 45 -1.5849899999999999 -1.6370899999999999 0.218082\n"" 46 -1.3714 -2.2354400000000001 1.7418499999999999\n"" 47 -1.14259 -1.7219800000000001 2.5314999999999999\n"" 48 -1.1462300000000001 -1.44584 3.04271\n"" 49 -1.72363 -1.65859 -0.39266400000000001\n"" 50 -1.7740499999999999 -1.6849099999999999 -1.0451999999999999\n"" 51 -2.3972199999999999 -1.87879 -2.2570000000000001\n"" 52 -2.3559999999999999 -2.9314900000000002 -2.5649600000000001\n"" 53 -1.9900100000000001 -3.4211100000000001 -2.7963200000000001\n"" 54 -1.69374 -3.7088399999999999 -3.53532\n"" 55 -2.2454299999999998 -3.5692900000000001 -1.9397899999999999\n"" 56 -2.2864300000000002 -3.77834 -2.10466\n"" 57 -2.2926700000000002 -3.7443599999999999 -1.3294600000000001\n"" 58 -1.6362099999999999 -3.39913 1.55494\n"" 59 -1.5402100000000001 -3.9804400000000002 1.7164699999999999\n"" 60 -1.6856899999999999 -2.5701499999999999 0.33473999999999998\n"" 61 -1.1098399999999999 -3.0533600000000001 1.9575899999999999\n"" 62 -1.6798299999999999 -3.1615099999999998 2.3719100000000002\n"" 63 -1.6955899999999999 -3.9803600000000001 2.4744700000000002\n"" 64 -1.1299699999999999 -2.8505600000000002 2.5077199999999999\n"" 65 -1.5803 -3.9803799999999998 2.79962\n"" 66 -1.2543800000000001 -3.9803600000000001 3.05606\n"" 67 -0.012264000000000001 -1.91774 3.31847\n"" 68 -0.0075960000000000003 -2.22756 2.4797799999999999\n"" 69 -1.3185199999999999 -2.03857 -0.24552599999999999\n"" 70 -1.54192 -1.6950700000000001 -0.038094000000000003\n"" 71 -1.6302399999999999 -1.5652900000000001 0.010584\n"" 72 -0.54714600000000002 -2.5150999999999999 -0.27547199999999999\n"" 73 -0.68966400000000005 -2.5785100000000001 -0.74843400000000004\n"" 74 -0.68381999999999998 -2.29792 -1.13124\n"" 75 -1.45807 -2.78965 -1.4571000000000001\n"" 76 -1.88889 -3.03241 -1.94861\n"" 77 0.016643999999999999 -2.6251600000000002 -1.5766\n"" 78 -0.43575000000000003 -2.5064899999999999 -1.32864\n"" 79 -0.96067199999999997 -2.8615900000000001 -1.7606999999999999\n"" 80 0.023154000000000001 -2.7205499999999998 -2.6635\n"" 81 -0.72217799999999999 -3.4893999999999998 -2.6321300000000001\n"" 82 -0.54899399999999998 -3.50515 -1.7670699999999999\n"" 83 -0.69881400000000005 -3.59917 -1.12985\n"" 84 -1.2481899999999999 -3.0818400000000001 -0.807894\n"" 85 -1.41449 -3.6600999999999999 -0.24563399999999999\n"" 86 -2.0695000000000001 -3.7349199999999998 -0.51227999999999996\n"" 87 -2.0184099999999998 -3.1911800000000001 -1.27379\n"" 88 0.011766 -2.7572999999999999 -0.81328199999999995\n"" 89 -0.34977599999999998 -2.5832199999999998 -0.26063999999999998\n"" 90 0.0082679999999999993 -2.6970700000000001 -0.226572\n"" 91 -0.78081 -3.0613299999999999 0.47486400000000001\n"" 92 0.000852 -2.8652899999999999 0.942384\n"" 93 -0.68570399999999998 -2.7192400000000001 1.8263799999999999\n"" 94 -0.003552 -2.6613500000000001 1.71241\n"" 95 -0.33728999999999998 -3.98041 1.95644\n"" 96 -0.15748799999999999 -3.4080599999999999 1.63991\n"" 97 -0.295566 -3.1863800000000002 2.3391199999999999\n"" 98 -0.76257600000000003 -3.9803899999999999 2.8759000000000001\n"" 99 -0.350304 -3.98041 2.2373500000000002\n"" 100 -1.8237699999999999 0.32519399999999998 3.7555299999999998\n"" 101 -1.6115600000000001 1.16042 3.0165999999999999\n"" 102 -1.6629499999999999 0.75673800000000002 2.6597300000000001\n"" 103 -1.72563 -0.034332000000000001 3.1910599999999998\n"" 104 -1.3883799999999999 -0.72773399999999999 3.5243199999999999\n"" 105 -1.52085 -0.490782 4.53925\n"" 106 -1.1709799999999999 -0.82781400000000005 4.3680700000000003\n"" 107 -1.00604 -0.939438 3.6563300000000001\n"" 108 -0.875502 -1.01417 4.1856\n"" 109 -0.46665600000000002 -1.28548 3.7355200000000002\n"" 110 -0.46123799999999998 -1.28983 4.17781\n"" 111 -0.014045999999999999 -1.3988100000000001 3.7371500000000002\n"" 112 -0.016379999999999999 -1.2811600000000001 4.1475999999999997\n"" 113 -0.018815999999999999 -1.15577 4.57639\n"" 114 -0.336816 -1.20733 4.58284\n"" 115 -0.68753399999999998 -0.99715200000000004 4.6243400000000001\n"" 116 -0.93086999999999998 -0.77779200000000004 4.7504299999999997\n"" 117 -1.1016699999999999 -0.35222999999999999 5.0820699999999999\n"" 118 -0.99337200000000003 0.01188 5.0003200000000003\n"" 119 -1.3205 0.11948400000000001 4.6136100000000004\n"" 120 -1.5343800000000001 0.54183599999999998 4.0246899999999997\n"" 121 -1.53356 0.68299799999999999 3.9803299999999999\n"" 122 -1.3582799999999999 1.27593 3.7064400000000002\n"" 123 -0.020202000000000001 -1.17205 4.7980799999999997\n"" 124 -0.17845800000000001 -1.26305 4.9630799999999997\n"" 125 -0.022908000000000001 -1.1687000000000001 5.2418199999999997\n"" 126 -0.024695999999999999 -0.94744200000000001 5.5876099999999997\n"" 127 -0.18768000000000001 -1.1073299999999999 5.3368599999999997\n"" 128 -0.35931000000000002 -1.10669 5.0479799999999999\n"" 129 -0.811998 -0.98599199999999998 5.2691999999999997\n"" 130 -0.51344400000000001 -1.02569 5.55328\n"" 131 -0.98299800000000004 -0.56501999999999997 5.3826799999999997\n"" 132 -0.83066399999999996 -0.62549999999999994 5.6758499999999996\n"" 133 -0.50098200000000004 -0.50960399999999995 5.8776400000000004\n"" 134 -0.026598 -0.87985199999999997 5.9152300000000002\n"" 135 -0.90429000000000004 0.19589999999999999 5.3046699999999998\n"" 136 -0.81535199999999997 -0.21312 5.6727299999999996\n"" 137 -0.42367199999999999 0.22109400000000001 5.8544\n"" 138 -0.026748000000000001 -0.25515599999999999 6.0940200000000004\n"" 139 -0.025493999999999999 0.276252 6.0194400000000003\n"" 140 -0.521814 0.79934400000000005 5.6858000000000004\n"" 141 -0.023238000000000002 0.96962999999999999 5.8229899999999999\n"" 142 -0.75326400000000004 0.84007200000000004 5.5060700000000002\n"" 143 -0.75390599999999997 1.5014799999999999 5.1456099999999996\n"" 144 -0.018762000000000001 1.70442 5.2732200000000002\n"" 145 -0.955044 0.75435600000000003 5.3332699999999997\n"" 146 -1.10284 1.1818200000000001 5.0668800000000003\n"" 147 -0.95933999999999997 1.7504200000000001 4.3948799999999997\n"" 148 -1.1969700000000001 1.2433799999999999 4.6791799999999997\n"" 149 -1.23709 0.98764799999999997 4.1595399999999998\n"" 150 -1.1178900000000001 0.96413400000000005 4.9031599999999997\n"" 151 -1.15696 1.00024 4.6936299999999997\n"" 152 -1.05067 0.66004799999999997 5.1637300000000002\n"" 153 -0.96613199999999999 0.34451999999999999 5.1306700000000003\n"" 154 -1.0339100000000001 0.21693000000000001 4.8971299999999998\n"" 155 -1.14191 0.38449800000000001 4.5636299999999999\n"" 156 -1.1704300000000001 0.77507400000000004 4.3866199999999997\n"" 157 -1.2187600000000001 2.4617200000000001 4.0832199999999998\n"" 158 -1.30006 1.85564 3.8536299999999999\n"" 159 -1.44909 1.8689100000000001 3.5269900000000001\n"" 160 -0.013254 2.19998 4.49648\n"" 161 -0.52937999999999996 2.3775900000000001 4.0718100000000002\n"" 162 -1.02088 0.65710199999999996 5.0446999999999997\n"" 163 -0.96312600000000004 0.40659600000000001 4.9839000000000002\n"" 164 -1.08928 0.83882999999999996 4.8728800000000003\n"" 165 -1.08297 0.89140799999999998 4.6565200000000004\n"" 166 -1.0815300000000001 0.77475000000000005 4.4651500000000004\n"" 167 -1.1177900000000001 0.46984799999999999 4.6161099999999999\n"" 168 -1.00573 0.363234 4.8400499999999997\n"" 169 -1.1392599999999999 0.61656 4.8154899999999996\n"" 170 -0.65003999999999995 2.7326800000000002 3.9430399999999999\n"" 171 -1.4495100000000001 3.1655500000000001 4.0157800000000003\n"" 172 -1.59406 3.0802 3.8075600000000001\n"" 173 -1.21844 2.8713000000000002 3.48916\n"" 174 -1.60063 3.85398 3.6123699999999999\n"" 175 -1.3017700000000001 3.3890799999999999 3.2126100000000002\n"" 176 -1.21326 3.1529699999999998 2.8556599999999999\n"" 177 -1.16333 2.80755 3.12364\n"" 178 -1.5950200000000001 4.5435999999999996 3.0055999999999998\n"" 179 -1.44184 3.9206400000000001 2.77929\n"" 180 -1.8554299999999999 4.6612099999999996 1.82836\n"" 181 -1.62605 4.09856 2.2921100000000001\n"" 182 -1.8726700000000001 4.0265899999999997 1.7201200000000001\n"" 183 -1.6127499999999999 3.7460499999999999 2.2633899999999998\n"" 184 -1.81474 3.2039800000000001 2.1617299999999999\n"" 185 -1.5819399999999999 3.1758600000000001 2.4753799999999999\n"" 186 -1.69387 2.4910000000000001 2.6859999999999999\n"" 187 -1.4352100000000001 2.6525799999999999 2.9736199999999999\n"" 188 -1.32026 3.4141599999999999 2.6752600000000002\n"" 189 -0.0075779999999999997 2.3737900000000001 3.6121699999999999\n"" 190 -0.34406999999999999 2.6552099999999998 3.4333399999999998\n"" 191 -0.53356199999999998 3.0379999999999998 3.1746400000000001\n"" 192 -0.75442799999999999 3.2104599999999999 3.6774800000000001\n"" 193 -0.75750600000000001 3.4630200000000002 2.8989500000000001\n"" 194 -0.89756400000000003 3.6691199999999999 3.34639\n"" 195 -0.979128 3.96475 2.9464800000000002\n"" 196 -1.0348900000000001 3.9803199999999999 2.4925000000000002\n"" 197 -0.96278399999999997 3.5502600000000002 2.2239499999999999\n"" 198 -0.93867 3.2183799999999998 2.2698100000000001\n"" 199 -0.81897600000000004 2.66615 2.5513599999999999\n"" 200 -0.573384 2.24261 2.8419500000000002\n"" 201 -0.62487599999999999 1.89547 2.9886200000000001\n"" 202 -0.0029759999999999999 2.3051599999999999 2.8429000000000002\n"" 203 -0.001098 1.7866200000000001 2.4089200000000002\n"" 204 -0.77425200000000005 1.62087 2.60697\n"" 205 0.00059999999999999995 1.63778 2.09483\n"" 206 -0.67835999999999996 1.4218999999999999 2.31332\n"" 207 0.043560000000000001 0.097865999999999995 -5.3003799999999996\n"" 208 0.047190000000000003 0.73262400000000005 -5.7368199999999998\n"" 209 -0.197052 0.69169199999999997 -5.7195099999999996\n"" 210 -0.53469 0.65069399999999999 -5.7019000000000002\n"" 211 -0.28464 0.088373999999999994 -5.2965400000000002\n"" 212 -0.62674799999999997 0.078822000000000003 -5.2924199999999999\n"" 213 -0.51863400000000004 -3.5091999999999999 -3.6500599999999999\n"" 214 -0.69015599999999999 -3.9756300000000002 -2.62039\n"" 215 -0.43009799999999998 -3.9922300000000002 -3.6383100000000002\n"" 216 -1.5472999999999999 -3.9922900000000001 -3.9483100000000002\n"" 217 -1.6352500000000001 -3.9922900000000001 -3.5523799999999999\n"" 218 -2.2279300000000002 -3.9922900000000001 -2.1217199999999998\n"" 219 -2.2341700000000002 -3.9922900000000001 -1.3465199999999999\n"" 220 -2.0110000000000001 -3.9922800000000001 -0.47173799999999999\n"" 221 -1.35599 -3.9922499999999999 -0.23388600000000001\n"" 222 -0.64031400000000005 -3.9922399999999998 -1.1181099999999999\n"" 223 -0.49049399999999999 -3.9922300000000002 -1.75532\n"" 224 0.041658000000000001 -0.54903000000000002 -5.1501200000000003\n"" 225 0.036701999999999999 -1.68591 -4.6197999999999997\n"" 226 0.026970000000000001 -3.01416 -3.3587899999999999\n"" 227 -1.1918299999999999 -1.81281 -5.0749000000000004\n"" 228 -1.4243699999999999 -3.2552599999999998 -3.5231300000000001\n"" 229 -1.62001 -1.67693 -4.0191699999999999\n"" 230 -0.80728200000000006 -0.71911199999999997 -5.7540199999999997\n"" 231 -0.31252799999999997 -0.73477800000000004 -5.6672900000000004\n"" 232 -0.74677800000000005 -1.76105 -5.3974000000000002\n"" 233 -0.28569600000000001 -1.73786 -5.2757500000000004\n"" 234 -1.0115700000000001 -3.1747899999999998 -3.9295900000000001\n"" 235 -0.59875800000000001 -3.0943100000000001 -3.8752399999999998\n"" 236 -1.1170100000000001 -3.6316899999999999 -4.3481399999999999\n"" 237 -0.67781999999999998 -3.49858 -4.2448100000000002\n"" 238 -0.64891200000000004 -3.9922499999999999 -4.2024499999999998\n"" 239 -1.0981099999999999 -3.99227 -4.3057800000000004\n"" 240 -2.0971700000000002 -2.0067499999999998 -3.0719099999999999\n"" 241 -0.84709199999999996 -2.6262300000000001 -4.7891599999999999\n"" 242 -1.2760199999999999 -2.6923499999999998 -4.4246800000000004\n"" 243 -1.56667 -2.4896699999999998 -3.6830099999999999\n"" 244 -0.46418399999999999 -2.5888800000000001 -4.6686800000000002\n"" 245 0.031043999999999999 -2.55166 -3.9095499999999999\n"" 246 0.535416 -2.5903900000000002 -4.66256\n"" 247 1.6260399999999999 -2.4944899999999999 -3.6634600000000002\n"" 248 1.34389 -2.6962999999999999 -4.4086400000000001\n"" 249 0.91964999999999997 -2.6288999999999998 -4.7783499999999997\n"" 250 2.1504799999999999 -2.0131700000000001 -3.04589\n"" 251 1.1606000000000001 -3.9956800000000001 -4.2919499999999999\n"" 252 0.71017799999999998 -3.9943 -4.1941300000000004\n"" 253 0.74109000000000003 -3.5007199999999998 -4.2361199999999997\n"" 254 1.1811100000000001 -3.6351599999999999 -4.3340699999999996\n"" 255 0.65872799999999998 -3.0962100000000001 -3.86754\n"" 256 1.0719399999999999 -3.17794 -3.91682\n"" 257 0.36694199999999999 -1.7388399999999999 -5.2717599999999996\n"" 258 0.82940400000000003 -1.7634300000000001 -5.3877499999999996\n"" 259 0.40159800000000001 -0.73585800000000001 -5.6629199999999997\n"" 260 0.89742599999999995 -0.72168600000000005 -5.7435799999999997\n"" 261 1.6859299999999999 -1.6819299999999999 -3.99892\n"" 262 1.47949 -3.2596500000000002 -3.5053399999999999\n"" 263 1.2703199999999999 -1.8165199999999999 -5.0598200000000002\n"" 264 0.52179600000000004 -3.99376 -1.74912\n"" 265 0.66380399999999995 -3.9942099999999998 -1.1101300000000001\n"" 266 1.36859 -3.9963700000000002 -0.21720600000000001\n"" 267 2.0264600000000002 -3.99838 -0.44701800000000003\n"" 268 2.2603300000000002 -3.9990800000000002 -1.319\n"" 269 2.2635900000000002 -3.9990800000000002 -2.09422\n"" 270 1.6884699999999999 -3.9973000000000001 -3.5320200000000002\n"" 271 1.60538 -3.9970400000000001 -3.9289999999999998\n"" 272 0.48447000000000001 -3.9936099999999999 -3.6327099999999999\n"" 273 0.73209599999999997 -3.9777800000000001 -2.6116799999999998\n"" 274 0.57460199999999995 -3.51085 -3.64337\n"" 275 0.71366399999999997 0.076794000000000001 -5.2842099999999999\n"" 276 0.37166399999999999 0.087384000000000003 -5.2925199999999997\n"" 277 0.62834999999999996 0.64893599999999996 -5.6947799999999997\n"" 278 0.291078 0.69095399999999996 -5.71652\n"" 279 0.676176 1.4198599999999999 2.3216199999999998\n"" 280 0.76906200000000002 1.6185400000000001 2.6164299999999998\n"" 281 0.61585800000000002 1.8935999999999999 2.9962200000000001\n"" 282 0.56720999999999999 2.2408899999999998 2.8489399999999998\n"" 283 0.81762000000000001 2.6636799999999998 2.5613700000000001\n"" 284 0.94242599999999999 3.2155399999999998 2.2813300000000001\n"" 285 0.96809999999999996 3.5473400000000002 2.2357800000000001\n"" 286 1.0382100000000001 3.9771899999999998 2.5051899999999998\n"" 287 0.97684800000000005 3.9617900000000001 2.9584600000000001\n"" 288 0.88949999999999996 3.66642 3.3573300000000001\n"" 289 0.75431400000000004 3.4607399999999999 2.90821\n"" 290 0.74093399999999998 3.2081900000000001 3.6866400000000001\n"" 291 0.52572600000000003 3.0364 3.18113\n"" 292 0.331926 2.6541899999999998 3.4374899999999999\n"" 293 1.31962 3.4101699999999999 2.69143\n"" 294 1.42859 2.64825 2.9911699999999999\n"" 295 1.6902699999999999 2.4858899999999999 2.7067299999999999\n"" 296 1.583 3.1710799999999999 2.4947599999999999\n"" 297 1.8197000000000001 3.1984900000000001 2.1839900000000001\n"" 298 1.61812 3.7411699999999999 2.2831700000000001\n"" 299 1.8855299999999999 4.0209200000000003 1.7431399999999999\n"" 300 1.6321399999999999 4.0936399999999997 2.3120599999999998\n"" 301 1.8688800000000001 4.6555900000000001 1.8511599999999999\n"" 302 1.44143 3.91628 2.7969499999999998\n"" 303 1.59371 4.53878 3.0251199999999998\n"" 304 1.15537 2.8040500000000002 3.1378300000000001\n"" 305 1.20963 3.1493099999999998 2.8704999999999998\n"" 306 1.2944599999999999 3.3851599999999999 3.2284999999999999\n"" 307 1.5898099999999999 3.8491599999999999 3.6318999999999999\n"" 308 1.2061900000000001 2.8676400000000002 3.5040100000000001\n"" 309 1.5785199999999999 3.0754000000000001 3.8269899999999999\n"" 310 1.4316899999999999 3.1612 4.0334199999999996\n"" 311 0.63185400000000003 2.7307399999999999 3.9508899999999998\n"" 312 1.1039600000000001 0.61316999999999999 4.8292299999999999\n"" 313 0.96937799999999996 0.36025200000000002 4.85215\n"" 314 1.08449 0.46652399999999999 4.6295999999999999\n"" 315 1.05101 0.77152799999999999 4.4782099999999998\n"" 316 1.0504500000000001 0.88817999999999997 4.6695799999999998\n"" 317 1.0539499999999999 0.83559000000000005 4.8860000000000001\n"" 318 0.92514600000000002 0.40374599999999999 4.9954700000000001\n"" 319 0.982908 0.65407800000000005 5.0569800000000003\n"" 320 0.50856000000000001 2.37602 4.0781700000000001\n"" 321 1.43333 1.86456 3.5446499999999999\n"" 322 1.2802800000000001 1.85175 3.8694299999999999\n"" 323 1.198 2.4580700000000002 4.09802\n"" 324 1.14086 0.77158199999999999 4.4007800000000001\n"" 325 1.109 0.38109599999999999 4.5774100000000004\n"" 326 0.99641999999999997 0.213864 4.9095700000000004\n"" 327 0.92616600000000004 0.34165800000000002 5.1422499999999998\n"" 328 1.01125 0.65693400000000002 5.1763500000000002\n"" 329 1.12432 0.99678599999999995 4.7075899999999997\n"" 330 1.08257 0.96081000000000005 4.9166299999999996\n"" 331 1.2109399999999999 0.98394599999999999 4.1745400000000004\n"" 332 1.1652400000000001 1.2398100000000001 4.6936499999999999\n"" 333 0.93262800000000001 1.74756 4.4064699999999997\n"" 334 1.0661799999999999 1.1785399999999999 5.0801600000000002\n"" 335 0.91383000000000003 0.75153599999999998 5.3447199999999997\n"" 336 0.71727600000000002 1.49926 5.1546200000000004\n"" 337 0.71021400000000001 0.83785799999999999 5.5150399999999999\n"" 338 0.47645999999999999 0.79783800000000005 5.69191\n"" 339 0.37451400000000001 0.219888 5.85928\n"" 340 0.76708200000000004 -0.21551400000000001 5.6824199999999996\n"" 341 0.86174399999999995 0.19323599999999999 5.31548\n"" 342 0.44932800000000001 -0.51103799999999999 5.8834600000000004\n"" 343 0.78110400000000002 -0.62793600000000005 5.6857199999999999\n"" 344 0.93720599999999998 -0.56791800000000003 5.3944400000000003\n"" 345 0.464196 -1.0271600000000001 5.5592699999999997\n"" 346 0.76633200000000001 -0.98837399999999997 5.2788599999999999\n"" 347 0.31602000000000002 -1.10771 5.0521099999999999\n"" 348 0.14086199999999999 -1.1078300000000001 5.33887\n"" 349 0.13575599999999999 -1.26352 4.9649999999999999\n"" 350 1.33853 1.27186 3.72296\n"" 351 1.5086599999999999 0.67840199999999995 3.9989599999999998\n"" 352 1.50851 0.53724000000000005 4.0433199999999996\n"" 353 1.28616 0.115548 4.6295700000000002\n"" 354 0.95399400000000001 0.00894 5.0122400000000003\n"" 355 1.0601799999999999 -0.35549399999999998 5.0953099999999996\n"" 356 0.89217599999999997 -0.78054599999999996 4.76159\n"" 357 0.64973999999999998 -0.99916799999999995 4.63253\n"" 358 0.29892000000000002 -1.2082900000000001 4.5867199999999997\n"" 359 0.42804599999999998 -1.2911699999999999 4.1832500000000001\n"" 360 0.438888 -1.28685 3.7410600000000001\n"" 361 0.84301199999999998 -1.01677 4.1961199999999996\n"" 362 0.980244 -0.942438 3.6684999999999999\n"" 363 1.1368 -0.83130000000000004 4.3822000000000001\n"" 364 1.48556 -0.49532399999999999 4.5576600000000003\n"" 365 1.3648100000000001 -0.73189199999999999 3.5411800000000002\n"" 366 1.70821 -0.039516000000000003 3.2120799999999998\n"" 367 1.65445 0.751722 2.6800600000000001\n"" 368 1.5999000000000001 1.1555599999999999 3.03626\n"" 369 1.8005199999999999 0.31972200000000001 3.77772\n"" 370 0.3327 -3.9836100000000001 2.2503899999999999\n"" 371 0.737124 -3.9848300000000001 2.8939400000000002\n"" 372 0.27911999999999998 -3.1894300000000002 2.3515100000000002\n"" 373 0.14894399999999999 -3.4106999999999998 1.6506400000000001\n"" 374 0.32312999999999997 -3.98359 1.9693400000000001\n"" 375 0.67697399999999996 -2.7212900000000002 1.83473\n"" 376 0.78759000000000001 -3.0636999999999999 0.48447600000000002\n"" 377 0.36704399999999998 -2.5842999999999998 -0.25625999999999999\n"" 378 2.0461100000000001 -3.1973199999999999 -1.2488999999999999\n"" 379 2.08623 -3.7412000000000001 -0.48683399999999999\n"" 380 1.42824 -3.66439 -0.22822200000000001\n"" 381 1.27058 -3.0856400000000002 -0.79246799999999995\n"" 382 0.72363 -3.6013099999999998 -1.12114\n"" 383 0.58191000000000004 -3.5068600000000001 -1.76014\n"" 384 0.76572600000000002 -3.4916499999999999 -2.6230199999999999\n"" 385 0.99541199999999996 -2.8645499999999999 -1.7487200000000001\n"" 386 0.46632000000000001 -2.5078499999999999 -1.32311\n"" 387 1.9253499999999999 -3.0381800000000001 -1.9252400000000001\n"" 388 1.4892799999999999 -2.7940999999999998 -1.4390499999999999\n"" 389 0.712584 -2.30003 -1.1226799999999999\n"" 390 0.71289599999999997 -2.5806399999999998 -0.739842\n"" 391 0.56478600000000001 -2.5167799999999998 -0.26866200000000001\n"" 392 1.64716 -1.5702400000000001 0.03066\n"" 393 1.55905 -1.6997500000000001 -0.019109999999999999\n"" 394 1.33717 -2.0425900000000001 -0.22925999999999999\n"" 395 1.2266699999999999 -3.9862799999999998 3.08012\n"" 396 1.55572 -3.9872800000000002 2.82769\n"" 397 1.1124099999999999 -2.8561200000000002 2.5303100000000001\n"" 398 1.6749799999999999 -3.9876200000000002 2.5039699999999998\n"" 399 1.6629400000000001 -3.16873 2.4012500000000001\n"" 400 1.0984100000000001 -3.0588700000000002 1.97997\n"" 401 1.6955899999999999 -2.5752600000000001 0.35545199999999999\n"" 402 1.5288999999999999 -3.98725 1.7441199999999999\n"" 403 1.62862 -3.4062399999999999 1.5838000000000001\n"" 404 2.3193700000000002 -3.7513299999999998 -1.30122\n"" 405 2.3225199999999999 -3.7852999999999999 -2.0764399999999998\n"" 406 2.2801300000000002 -3.57613 -1.9120699999999999\n"" 407 1.7476100000000001 -3.7140399999999998 -3.51424\n"" 408 2.0356800000000002 -3.42719 -2.7716799999999999\n"" 409 2.4002699999999999 -2.9386700000000001 -2.5358399999999999\n"" 410 2.4409000000000001 -1.88609 -2.2273800000000001\n"" 411 1.8035300000000001 -1.69031 -1.02329\n"" 412 1.7452000000000001 -1.6638200000000001 -0.37142999999999998\n"" 413 1.1264099999999999 -1.4492700000000001 3.0566200000000001\n"" 414 1.12819 -1.7254100000000001 2.5453999999999999\n"" 415 1.3651199999999999 -2.2395700000000001 1.75861\n"" 416 1.5991599999999999 -1.6418999999999999 0.23758199999999999\n"" 417 1.7495499999999999 -1.7500599999999999 0.66831600000000002\n"" 418 1.7514799999999999 -0.73644600000000005 2.5360999999999998\n"" 419 1.7854399999999999 -0.93671400000000005 2.2402099999999998\n"" 420 1.7196199999999999 -1.39639 0.16297200000000001\n"" 421 2.18798 -1.2083900000000001 1.2411000000000001\n"" 422 2.1231300000000002 -0.79444800000000004 0.89536800000000005\n"" 423 1.6932499999999999 -0.11829000000000001 1.8897600000000001\n"" 424 1.98712 -0.59559600000000001 0.55620599999999998\n"" 425 2.25278 -0.55871999999999999 -0.038802000000000003\n"" 426 2.2555000000000001 -0.60741599999999996 -0.92929200000000001\n"" 427 2.7998099999999999 -0.566496 -1.8340099999999999\n"" 428 2.7348300000000001 -0.71928599999999998 -2.7637900000000002\n"" 429 1.66479 -3.6254499999999998 -3.9112300000000002\n"" 430 1.56613 -3.3070599999999999 -3.3279999999999998\n"" 431 0.56176199999999998 1.5509599999999999 -5.5235300000000001\n"" 432 0.68548799999999999 1.86365 -4.7884200000000003\n"" 433 0.86539200000000005 1.2685999999999999 -5.0100100000000003\n"" 434 0.71949600000000002 1.0616399999999999 -5.70695\n"" 435 1.1043700000000001 0.611124 -5.5093199999999998\n"" 436 0.55458600000000002 1.65913 -4.4293899999999997\n"" 437 0.80102399999999996 1.3104199999999999 -4.5516100000000002\n"" 438 1.1699200000000001 0.58592999999999995 -4.87486\n"" 439 1.1132500000000001 0.066030000000000005 -5.2752100000000004\n"" 440 1.3818900000000001 -0.76470000000000005 -5.3052099999999998\n"" 441 1.5628299999999999 1.53034 -3.74627\n"" 442 2.1093999999999999 -0.253164 -3.98386\n"" 443 1.5224500000000001 1.9411400000000001 -2.6023000000000001\n"" 444 2.4696699999999998 0.793794 -2.6295799999999998\n"" 445 1.6230800000000001 2.1391800000000001 -1.7399\n"" 446 2.53288 0.97691399999999995 -1.6387799999999999\n"" 447 0.988344 1.4249400000000001 1.2534700000000001\n"" 448 1.52284 0.55740000000000001 1.44384\n"" 449 1.2216499999999999 1.7075800000000001 0.57733800000000002\n"" 450 1.44604 2.0585599999999999 -1.0283800000000001\n"" 451 2.13646 0.89572799999999997 -0.86065800000000003\n"" 452 2.0259399999999999 0.79195199999999999 0.39824399999999999\n"" 453 -0.42761063083709772 1.6952470543869633 2.5510779406671853\n""# Generated by tetgen -YY bunny.smesh \n"); } -static const char* getElements() { return( -"1374 4 0\n"" 0 395 372 399 371\n"" 1 96 46 93 44\n"" 2 135 140 137 163\n"" 3 318 326 354 313\n"" 4 133 127 128 126\n"" 5 76 83 55 218\n"" 6 193 188 198 176\n"" 7 450 443 451 1\n"" 8 437 442 438 441\n"" 9 160 336 320 144\n"" 10 79 50 51 75\n"" 11 408 378 387 273\n"" 12 94 38 47 68\n"" 13 323 308 322 311\n"" 14 339 135 163 341\n"" 15 152 135 153 145\n"" 16 333 166 160 147\n"" 17 348 346 347 342\n"" 18 446 426 451 444\n"" 19 46 92 94 93\n"" 20 208 21 26 207\n"" 21 38 360 48 413\n"" 22 229 80 243 245\n"" 23 241 229 227 242\n"" 24 34 50 35 51\n"" 25 9 33 35 34\n"" 26 103 122 121 206\n"" 27 257 260 259 440\n"" 28 142 318 163 144\n"" 29 446 443 444 451\n"" 30 272 251 252 274\n"" 31 193 199 176 198\n"" 32 165 149 147 166\n"" 33 447 3 8 449\n"" 34 29 208 209 30\n"" 35 300 285 286 299\n"" 36 100 104 119 105\n"" 37 39 44 40 41\n"" 38 315 318 313 316\n"" 39 422 417 421 419\n"" 40 382 273 264 383\n"" 41 145 143 150 146\n"" 42 406 268 405 404\n"" 43 427 411 426 428\n"" 44 323 290 308 311\n"" 45 232 18 230 227\n"" 46 243 79 80 240\n"" 47 391 412 390 389\n"" 48 360 423 107 362\n"" 49 389 71 393 392\n"" 50 142 162 163 145\n"" 51 245 247 261 80\n"" 52 376 373 375 92\n"" 53 324 352 325 362\n"" 54 119 104 106 105\n"" 55 165 149 166 151\n"" 56 428 389 411 442\n"" 57 366 351 331 352\n"" 58 166 318 316 163\n"" 59 368 281 280 350\n"" 60 315 168 313 166\n"" 61 417 422 423 419\n"" 62 279 203 205 453\n"" 63 80 243 245 226\n"" 64 416 41 420 45\n"" 65 319 330 317 335\n"" 66 15 442 225 224\n"" 67 116 131 117 129\n"" 68 335 318 337 319\n"" 69 188 197 193 198\n"" 70 326 314 325 313\n"" 71 313 315 314 325\n"" 72 451 3 449 450\n"" 73 451 449 452 450\n"" 74 299 286 300 301\n"" 75 450 1 3 2\n"" 76 107 103 120 149\n"" 77 76 82 81 79\n"" 78 81 83 218 214\n"" 79 14 10 2 11\n"" 80 22 436 437 23\n"" 81 318 144 316 163\n"" 82 420 426 425 412\n"" 83 450 14 11 445\n"" 84 262 254 429 274\n"" 85 443 442 441 444\n"" 86 356 353 364 363\n"" 87 102 122 206 101\n"" 88 315 168 325 313\n"" 89 281 331 280 350\n"" 90 107 155 120 104\n"" 91 443 426 444 451\n"" 92 123 118 354 113\n"" 93 84 220 86 83\n"" 94 268 406 405 269\n"" 95 287 293 289 286\n"" 96 17 16 443 13\n"" 97 315 168 166 325\n"" 98 283 296 297 284\n"" 99 333 144 336 160\n"" 100 450 13 1 2\n"" 101 414 423 418 419\n"" 102 331 352 324 362\n"" 103 144 315 333 316\n"" 104 21 442 16 15\n"" 105 45 72 91 69\n"" 106 437 208 21 433\n"" 107 288 310 290 306\n"" 108 213 217 214 31\n"" 109 335 327 328 341\n"" 110 109 67 48 111\n"" 111 316 314 315 312\n"" 112 45 60 91 44\n"" 113 128 118 115 116\n"" 114 423 45 38 448\n"" 115 155 362 166 325\n"" 116 130 136 132 133\n"" 117 92 72 89 91\n"" 118 145 143 142 150\n"" 119 153 140 163 142\n"" 120 317 313 312 319\n"" 121 347 118 126 354\n"" 122 148 165 147 143\n"" 123 170 157 171 173\n"" 124 78 50 74 240\n"" 125 381 273 385 378\n"" 126 337 330 335 317\n"" 127 267 273 379 268\n"" 128 80 247 261 250\n"" 129 80 225 261 245\n"" 130 80 442 261 225\n"" 131 211 24 212 20\n"" 132 398 395 399 371\n"" 133 390 389 377 391\n"" 134 308 292 290 291\n"" 135 176 191 177 199\n"" 136 318 166 313 163\n"" 137 23 16 436 17\n"" 138 354 353 325 326\n"" 139 423 362 366 279\n"" 140 415 400 375 403\n"" 141 217 239 216 213\n"" 142 377 89 88 90\n"" 143 10 12 13 9\n"" 144 155 325 113 112\n"" 145 151 164 165 150\n"" 146 113 118 128 123\n"" 147 95 97 99 96\n"" 148 449 3 8 5\n"" 149 61 99 97 64\n"" 150 223 83 222 82\n"" 151 37 38 6 39\n"" 152 0 7 6 37\n"" 153 385 430 247 250\n"" 154 108 109 110 107\n"" 155 415 401 417 403\n"" 156 102 121 122 101\n"" 157 120 107 149 156\n"" 158 104 100 119 120\n"" 159 3 4 2 5\n"" 160 207 21 224 437\n"" 161 270 273 408 430\n"" 162 80 247 226 245\n"" 163 80 228 81 243\n"" 164 43 107 48 38\n"" 165 354 340 344 341\n"" 166 312 316 313 317\n"" 167 435 275 277 439\n"" 168 27 30 29 28\n"" 169 52 76 31 240\n"" 170 338 339 163 318\n"" 171 47 43 42 48\n"" 172 61 96 59 58\n"" 173 428 389 442 261\n"" 174 194 171 192 174\n"" 175 318 339 341 338\n"" 176 417 422 416 423\n"" 177 123 124 125 128\n"" 178 113 108 115 155\n"" 179 300 285 299 298\n"" 180 320 160 189 333\n"" 181 443 35 1 13\n"" 182 96 46 44 61\n"" 183 316 314 313 315\n"" 184 119 107 155 106\n"" 185 357 325 356 361\n"" 186 224 15 21 20\n"" 187 319 336 337 317\n"" 188 306 287 307 302\n"" 189 143 141 140 144\n"" 190 366 423 279 367\n"" 191 74 73 88 89\n"" 192 447 7 8 3\n"" 193 449 8 447 5\n"" 194 436 21 22 437\n"" 195 92 72 91 45\n"" 196 153 140 142 135\n"" 197 206 121 103 149\n"" 198 35 69 389 71\n"" 199 165 168 167 166\n"" 200 12 1 13 9\n"" 201 361 112 113 325\n"" 202 195 175 193 194\n"" 203 292 304 322 321\n"" 204 337 336 144 338\n"" 205 399 372 400 371\n"" 206 332 336 334 333\n"" 207 111 68 67 48\n"" 208 389 391 393 72\n"" 209 196 179 188 195\n"" 210 104 119 155 120\n"" 211 168 166 325 155\n"" 212 112 108 113 155\n"" 213 449 425 451 452\n"" 214 220 214 83 221\n"" 215 261 246 245 225\n"" 216 93 44 46 92\n"" 217 80 255 226 247\n"" 218 384 262 247 430\n"" 219 336 144 319 337\n"" 220 144 315 316 166\n"" 221 332 336 333 316\n"" 222 175 191 194 192\n"" 223 362 353 325 363\n"" 224 110 113 115 114\n"" 225 400 370 374 402\n"" 226 319 337 335 317\n"" 227 430 262 247 248\n"" 228 324 362 315 331\n"" 229 80 228 235 81\n"" 230 347 342 126 348\n"" 231 295 283 296 297\n"" 232 306 304 305 308\n"" 233 356 353 325 354\n"" 234 21 23 437 433\n"" 235 195 174 194 178\n"" 236 192 175 177 173\n"" 237 302 287 303 286\n"" 238 208 211 26 209\n"" 239 118 128 115 113\n"" 240 351 366 369 352\n"" 241 342 344 340 343\n"" 242 118 347 123 354\n"" 243 354 168 163 313\n"" 244 356 325 363 361\n"" 245 282 321 294 304\n"" 246 268 379 267 404\n"" 247 296 305 284 283\n"" 248 290 304 308 291\n"" 249 316 318 313 319\n"" 250 143 160 147 161\n"" 251 149 201 122 147\n"" 252 38 448 45 6\n"" 253 92 415 417 94\n"" 254 225 224 261 440\n"" 255 198 185 184 186\n"" 256 7 205 447 8\n"" 257 368 351 350 367\n"" 258 74 13 12 35\n"" 259 190 147 161 158\n"" 260 270 429 262 407\n"" 261 3 4 450 2\n"" 262 15 443 442 16\n"" 263 193 188 195 196\n"" 264 342 347 340 344\n"" 265 391 393 45 416\n"" 266 92 415 94 375\n"" 267 61 60 91 58\n"" 268 60 72 69 91\n"" 269 289 283 305 291\n"" 270 96 44 93 92\n"" 271 324 362 325 315\n"" 272 13 2 14 10\n"" 273 62 63 61 64\n"" 274 144 166 160 315\n"" 275 417 423 416 94\n"" 276 449 4 450 3\n"" 277 450 13 443 1\n"" 278 352 364 365 369\n"" 279 7 448 205 6\n"" 280 225 440 261 263\n"" 281 116 155 119 118\n"" 282 2 4 450 11\n"" 283 416 377 92 89\n"" 284 376 403 415 375\n"" 285 417 376 415 92\n"" 286 416 377 89 391\n"" 287 249 262 246 256\n"" 288 336 317 316 330\n"" 289 47 43 48 38\n"" 290 354 168 313 113\n"" 291 115 168 118 113\n"" 292 34 50 51 33\n"" 293 166 169 167 165\n"" 294 319 316 317 313\n"" 295 318 144 337 319\n"" 296 354 325 313 326\n"" 297 30 436 433 431\n"" 298 289 283 291 284\n"" 299 58 91 96 59\n"" 300 185 182 183 197\n"" 301 224 438 276 437\n"" 302 15 442 80 225\n"" 303 111 110 112 109\n"" 304 52 76 240 51\n"" 305 208 26 30 29\n"" 306 7 449 3 447\n"" 307 296 294 283 295\n"" 308 306 291 289 305\n"" 309 338 140 141 144\n"" 310 331 352 351 324\n"" 311 322 281 333 320\n"" 312 83 81 76 82\n"" 313 384 262 274 255\n"" 314 60 45 91 69\n"" 315 15 20 19 16\n"" 316 197 188 193 196\n"" 317 80 229 225 245\n"" 318 18 233 227 232\n"" 319 344 345 343 342\n"" 320 417 414 94 415\n"" 321 443 16 441 442\n"" 322 177 199 187 176\n"" 323 149 206 121 453\n"" 324 350 279 331 280\n"" 325 181 188 196 179\n"" 326 102 121 101 103\n"" 327 347 357 354 356\n"" 328 338 327 318 337\n"" 329 337 330 334 335\n"" 330 319 336 317 316\n"" 331 193 175 188 176\n"" 332 164 143 162 165\n"" 333 120 104 100 103\n"" 334 376 416 92 417\n"" 335 113 325 155 168\n"" 336 416 376 92 391\n"" 337 420 45 41 393\n"" 338 249 262 248 246\n"" 339 147 189 161 160\n"" 340 18 231 224 233\n"" 341 71 45 70 41\n"" 342 126 341 135 339\n"" 343 21 23 22 437\n"" 344 148 165 143 151\n"" 345 337 327 318 335\n"" 346 354 318 313 163\n"" 347 115 118 155 116\n"" 348 341 340 338 339\n"" 349 166 168 313 163\n"" 350 166 318 313 315\n"" 351 48 68 67 47\n"" 352 150 162 145 152\n"" 353 140 339 137 163\n"" 354 199 185 187 176\n"" 355 333 144 316 336\n"" 356 338 327 337 341\n"" 357 389 70 72 393\n"" 358 331 366 350 351\n"" 359 94 45 92 44\n"" 360 9 33 12 35\n"" 361 126 139 137 138\n"" 362 321 295 282 294\n"" 363 135 140 136 137\n"" 364 153 162 163 152\n"" 365 325 362 363 361\n"" 366 80 235 226 81\n"" 367 74 377 89 88\n"" 368 13 14 450 443\n"" 369 157 172 158 171\n"" 370 450 443 14 445\n"" 371 155 107 120 156\n"" 372 135 339 163 137\n"" 373 365 325 352 362\n"" 374 153 140 135 163\n"" 375 448 206 205 6\n"" 376 137 141 139 339\n"" 377 103 107 120 104\n"" 378 448 425 447 452\n"" 379 165 162 168 163\n"" 380 76 83 79 87\n"" 381 420 45 393 416\n"" 382 334 329 330 336\n"" 383 89 45 92 416\n"" 384 181 195 179 196\n"" 385 420 448 41 416\n"" 386 438 277 435 275\n"" 387 400 399 402 403\n"" 388 304 296 283 305\n"" 389 170 158 190 161\n"" 390 387 386 388 250\n"" 391 54 218 217 53\n"" 392 311 304 308 322\n"" 393 149 281 201 189\n"" 394 211 24 209 212\n"" 395 166 333 149 147\n"" 396 426 424 420 425\n"" 397 394 376 401 416\n"" 398 147 159 122 158\n"" 399 202 203 201 453\n"" 400 280 203 279 453\n"" 401 135 126 339 137\n"" 402 449 4 3 5\n"" 403 14 2 450 11\n"" 404 126 125 127 347\n"" 405 423 413 38 414\n"" 406 185 198 188 176\n"" 407 144 163 142 162\n"" 408 201 122 204 453\n"" 409 447 425 451 449\n"" 410 290 289 306 291\n"" 411 35 69 71 49\n"" 412 207 224 211 231\n"" 413 135 154 163 118\n"" 414 126 118 341 354\n"" 415 191 175 194 193\n"" 416 436 16 437 17\n"" 417 420 422 416 421\n"" 418 135 142 153 145\n"" 419 15 443 16 13\n"" 420 440 275 259 224\n"" 421 416 421 422 417\n"" 422 442 275 440 224\n"" 423 347 340 354 126\n"" 424 254 256 253 274\n"" 425 34 50 33 35\n"" 426 176 191 175 177\n"" 427 433 278 434 277\n"" 428 175 191 192 177\n"" 429 101 206 102 204\n"" 430 132 135 136 130\n"" 431 49 35 50 36\n"" 432 353 356 325 363\n"" 433 435 277 433 434\n"" 434 224 275 276 438\n"" 435 212 230 18 19\n"" 436 143 150 148 151\n"" 437 235 228 243 234\n"" 438 29 22 26 30\n"" 439 125 347 349 123\n"" 440 237 234 235 236\n"" 441 144 336 319 316\n"" 442 165 316 166 144\n"" 443 142 318 338 163\n"" 444 137 141 140 139\n"" 445 447 279 205 448\n"" 446 106 116 108 155\n"" 447 217 238 239 215\n"" 448 16 17 443 441\n"" 449 407 262 270 430\n"" 450 88 74 389 77\n"" 451 78 79 80 81\n"" 452 126 138 134 342\n"" 453 165 150 143 151\n"" 454 409 430 387 250\n"" 455 128 118 116 131\n"" 456 339 126 340 342\n"" 457 173 192 171 170\n"" 458 400 376 403 373\n"" 459 15 18 212 224\n"" 460 37 49 36 35\n"" 461 81 82 83 214\n"" 462 173 157 171 172\n"" 463 220 214 219 83\n"" 464 114 113 128 123\n"" 465 366 423 367 418\n"" 466 379 273 378 406\n"" 467 30 436 23 433\n"" 468 23 432 28 436\n"" 469 147 144 160 143\n"" 470 79 243 31 240\n"" 471 33 74 50 240\n"" 472 342 348 345 126\n"" 473 94 416 417 92\n"" 474 416 377 391 92\n"" 475 147 158 149 157\n"" 476 273 274 384 430\n"" 477 203 281 201 453\n"" 478 243 235 245 226\n"" 479 18 229 227 225\n"" 480 45 72 69 70\n"" 481 189 149 147 201\n"" 482 175 195 193 188\n"" 483 362 107 155 166\n"" 484 185 199 198 176\n"" 485 331 166 333 149\n"" 486 31 76 81 79\n"" 487 323 290 310 308\n"" 488 43 107 104 48\n"" 489 436 16 21 437\n"" 490 368 279 350 280\n"" 491 424 416 423 448\n"" 492 150 142 164 143\n"" 493 258 248 246 249\n"" 494 381 383 385 273\n"" 495 73 49 72 74\n"" 496 117 106 119 116\n"" 497 74 377 88 389\n"" 498 408 273 387 384\n"" 499 191 170 173 190\n"" 500 199 177 200 191\n"" 501 13 80 74 12\n"" 502 130 135 128 131\n"" 503 92 90 89 377\n"" 504 84 219 83 86\n"" 505 408 378 273 406\n"" 506 386 384 80 385\n"" 507 392 426 389 420\n"" 508 80 79 243 81\n"" 509 158 177 173 190\n"" 510 377 72 89 391\n"" 511 394 376 416 391\n"" 512 442 224 440 261\n"" 513 130 131 129 132\n"" 514 95 63 61 59\n"" 515 252 274 253 272\n"" 516 273 274 272 384\n"" 517 225 263 246 257\n"" 518 76 52 31 53\n"" 519 243 79 31 81\n"" 520 448 420 424 416\n"" 521 347 358 349 123\n"" 522 138 137 126 133\n"" 523 368 279 367 350\n"" 524 38 360 413 423\n"" 525 165 168 166 163\n"" 526 207 211 26 208\n"" 527 54 217 32 228\n"" 528 125 347 348 349\n"" 529 118 347 128 123\n"" 530 423 94 45 416\n"" 531 250 389 428 261\n"" 532 119 116 118 117\n"" 533 358 113 347 357\n"" 534 168 164 165 169\n"" 535 242 235 243 234\n"" 536 354 318 341 327\n"" 537 226 247 255 245\n"" 538 377 72 389 74\n"" 539 168 354 163 118\n"" 540 163 316 166 165\n"" 541 145 163 142 153\n"" 542 262 80 247 255\n"" 543 281 304 292 321\n"" 544 12 1 9 35\n"" 545 392 426 420 412\n"" 546 51 79 76 240\n"" 547 274 270 273 272\n"" 548 270 274 273 430\n"" 549 329 331 332 324\n"" 550 325 313 168 113\n"" 551 306 304 308 290\n"" 552 71 35 49 41\n"" 553 348 346 342 345\n"" 554 270 262 274 430\n"" 555 353 363 365 364\n"" 556 29 22 30 27\n"" 557 447 425 424 451\n"" 558 53 31 217 54\n"" 559 194 171 175 192\n"" 560 29 25 209 210\n"" 561 123 358 349 113\n"" 562 80 385 384 247\n"" 563 204 202 201 453\n"" 564 259 225 440 224\n"" 565 128 347 125 123\n"" 566 111 68 48 413\n"" 567 48 68 47 414\n"" 568 415 68 414 94\n"" 569 437 208 207 21\n"" 570 424 1 3 451\n"" 571 447 452 449 448\n"" 572 389 390 377 88\n"" 573 158 170 190 173\n"" 574 169 165 168 167\n"" 575 155 154 119 118\n"" 576 115 168 155 118\n"" 577 354 168 113 118\n"" 578 147 201 161 189\n"" 579 115 168 113 155\n"" 580 168 166 155 167\n"" 581 259 225 257 440\n"" 582 263 247 261 246\n"" 583 281 279 201 453\n"" 584 128 135 136 126\n"" 585 275 260 439 440\n"" 586 66 63 65 64\n"" 587 277 438 276 275\n"" 588 163 339 341 318\n"" 589 325 314 324 315\n"" 590 338 327 341 318\n"" 591 319 327 328 335\n"" 592 391 45 89 416\n"" 593 203 281 280 202\n"" 594 362 423 206 279\n"" 595 239 237 213 238\n"" 596 362 353 365 325\n"" 597 80 235 243 226\n"" 598 80 228 243 235\n"" 599 15 21 20 16\n"" 600 31 214 81 53\n"" 601 227 244 233 225\n"" 602 442 21 224 15\n"" 603 284 293 298 285\n"" 604 233 18 227 225\n"" 605 18 233 224 225\n"" 606 205 203 204 453\n"" 607 163 154 168 118\n"" 608 208 21 433 26\n"" 609 443 389 442 444\n"" 610 27 23 30 28\n"" 611 54 218 56 217\n"" 612 391 412 389 393\n"" 613 9 13 10 1\n"" 614 61 44 96 91\n"" 615 316 314 312 313\n"" 616 416 376 401 417\n"" 617 116 108 155 115\n"" 618 106 107 155 108\n"" 619 442 389 411 426\n"" 620 164 142 162 143\n"" 621 321 294 322 295\n"" 622 144 165 143 147\n"" 623 357 325 313 354\n"" 624 389 35 41 426\n"" 625 448 7 205 447\n"" 626 227 244 229 241\n"" 627 206 38 103 102\n"" 628 206 448 205 279\n"" 629 10 4 2 11\n"" 630 246 256 245 255\n"" 631 37 49 35 41\n"" 632 128 127 124 125\n"" 633 126 138 133 134\n"" 634 312 318 319 313\n"" 635 81 235 226 213\n"" 636 213 228 235 234\n"" 637 228 81 243 31\n"" 638 81 228 235 213\n"" 639 317 336 337 330\n"" 640 330 336 337 334\n"" 641 316 330 317 329\n"" 642 319 330 335 328\n"" 643 231 18 232 233\n"" 644 18 231 232 230\n"" 645 17 437 436 441\n"" 646 287 307 302 303\n"" 647 287 306 307 288\n"" 648 303 288 287 307\n"" 649 323 320 333 311\n"" 650 393 420 416 392\n"" 651 79 51 76 75\n"" 652 336 329 316 332\n"" 653 213 236 234 237\n"" 654 76 31 81 53\n"" 655 45 72 391 89\n"" 656 31 76 79 240\n"" 657 395 372 397 399\n"" 658 393 45 41 70\n"" 659 45 416 94 92\n"" 660 211 21 224 207\n"" 661 376 417 415 401\n"" 662 262 254 274 256\n"" 663 320 304 292 311\n"" 664 1 10 9 2\n"" 665 162 165 168 164\n"" 666 385 247 80 250\n"" 667 371 400 370 372\n"" 668 384 247 385 430\n"" 669 128 130 131 129\n"" 670 443 13 442 80\n"" 671 284 293 289 305\n"" 672 448 206 6 423\n"" 673 360 107 109 362\n"" 674 112 360 359 111\n"" 675 287 305 306 289\n"" 676 362 325 112 361\n"" 677 362 166 325 315\n"" 678 437 17 16 441\n"" 679 438 277 276 433\n"" 680 200 189 190 201\n"" 681 416 422 424 423\n"" 682 320 292 281 189\n"" 683 110 108 113 112\n"" 684 108 110 113 115\n"" 685 144 318 316 319\n"" 686 250 386 389 80\n"" 687 166 318 315 316\n"" 688 63 62 59 58\n"" 689 319 327 335 318\n"" 690 337 327 335 341\n"" 691 1 450 3 451\n"" 692 239 237 236 213\n"" 693 21 442 437 16\n"" 694 450 443 445 451\n"" 695 14 13 450 2\n"" 696 39 44 42 40\n"" 697 363 357 356 361\n"" 698 350 366 367 351\n"" 699 331 366 362 279\n"" 700 368 366 369 351\n"" 701 47 43 38 42\n"" 702 140 339 163 338\n"" 703 289 285 293 284\n"" 704 339 141 338 140\n"" 705 137 141 339 140\n"" 706 234 216 213 32\n"" 707 273 408 430 384\n"" 708 273 270 408 269\n"" 709 84 220 83 85\n"" 710 158 170 157 161\n"" 711 255 262 274 256\n"" 712 304 282 283 294\n"" 713 83 218 219 87\n"" 714 377 72 74 89\n"" 715 206 205 204 453\n"" 716 446 443 451 445\n"" 717 304 292 322 320\n"" 718 155 362 112 107\n"" 719 292 283 304 282\n"" 720 443 1 426 451\n"" 721 149 362 166 107\n"" 722 272 271 274 270\n"" 723 306 287 289 288\n"" 724 366 331 350 279\n"" 725 331 366 352 362\n"" 726 61 95 96 97\n"" 727 224 442 275 438\n"" 728 273 387 384 385\n"" 729 262 271 429 270\n"" 730 185 182 197 184\n"" 731 153 162 145 163\n"" 732 74 443 35 426\n"" 733 41 389 426 420\n"" 734 40 47 46 44\n"" 735 262 246 247 248\n"" 736 1 37 3 0\n"" 737 433 432 431 436\n"" 738 23 432 436 30\n"" 739 67 360 413 111\n"" 740 109 360 112 111\n"" 741 361 360 112 362\n"" 742 246 258 249 257\n"" 743 87 218 219 55\n"" 744 151 149 166 156\n"" 745 165 149 151 148\n"" 746 149 165 147 148\n"" 747 155 154 118 168\n"" 748 217 214 218 215\n"" 749 31 214 53 217\n"" 750 291 304 283 305\n"" 751 23 16 22 436\n"" 752 143 162 165 144\n"" 753 103 102 100 101\n"" 754 195 175 179 188\n"" 755 182 196 197 180\n"" 756 400 376 375 403\n"" 757 149 281 189 331\n"" 758 146 143 150 148\n"" 759 150 146 152 145\n"" 760 168 162 164 169\n"" 761 262 384 274 430\n"" 762 54 218 53 56\n"" 763 125 127 347 128\n"" 764 304 306 291 290\n"" 765 262 80 384 247\n"" 766 153 162 152 145\n"" 767 150 162 152 164\n"" 768 168 162 169 163\n"" 769 262 80 255 384\n"" 770 38 68 414 47\n"" 771 423 206 38 107\n"" 772 46 68 94 47\n"" 773 385 430 250 387\n"" 774 413 68 48 414\n"" 775 46 68 93 94\n"" 776 41 416 448 45\n"" 777 111 68 413 67\n"" 778 77 88 74 73\n"" 779 393 41 420 392\n"" 780 274 256 253 255\n"" 781 26 23 433 30\n"" 782 218 217 53 214\n"" 783 231 212 18 224\n"" 784 446 426 444 427\n"" 785 113 114 128 115\n"" 786 128 114 123 124\n"" 787 285 289 293 286\n"" 788 301 285 299 286\n"" 789 300 285 298 286\n"" 790 297 285 298 299\n"" 791 26 23 30 22\n"" 792 44 38 94 45\n"" 793 187 158 159 177\n"" 794 218 76 81 53\n"" 795 162 143 142 144\n"" 796 397 373 400 372\n"" 797 164 142 145 162\n"" 798 128 135 126 118\n"" 799 289 283 284 305\n"" 800 282 189 281 292\n"" 801 200 186 187 199\n"" 802 21 24 211 20\n"" 803 11 13 14 10\n"" 804 2 13 1 10\n"" 805 72 377 389 391\n"" 806 74 72 73 89\n"" 807 92 72 45 89\n"" 808 413 366 418 362\n"" 809 281 304 282 292\n"" 810 429 251 274 254\n"" 811 438 439 275 435\n"" 812 37 424 1 3\n"" 813 202 189 201 281\n"" 814 333 189 320 281\n"" 815 94 38 68 423\n"" 816 389 261 250 80\n"" 817 242 241 235 234\n"" 818 364 366 365 369\n"" 819 302 305 306 287\n"" 820 362 366 352 365\n"" 821 350 366 279 367\n"" 822 368 366 351 367\n"" 823 191 176 175 193\n"" 824 173 191 177 192\n"" 825 103 121 101 100\n"" 826 176 191 199 193\n"" 827 191 177 200 190\n"" 828 275 442 439 438\n"" 829 275 442 440 439\n"" 830 224 442 225 261\n"" 831 442 224 437 438\n"" 832 258 246 263 257\n"" 833 386 384 385 383\n"" 834 149 333 331 189\n"" 835 318 326 327 354\n"" 836 207 437 224 276\n"" 837 56 76 218 53\n"" 838 350 333 322 281\n"" 839 37 38 45 6\n"" 840 232 244 227 241\n"" 841 423 206 6 38\n"" 842 411 386 250 410\n"" 843 224 229 18 225\n"" 844 6 423 38 448\n"" 845 218 57 219 55\n"" 846 68 423 38 414\n"" 847 377 376 391 92\n"" 848 415 376 375 92\n"" 849 103 121 100 120\n"" 850 101 121 122 100\n"" 851 102 121 103 122\n"" 852 7 206 6 205\n"" 853 38 206 6 102\n"" 854 107 38 103 206\n"" 855 448 206 423 279\n"" 856 298 305 284 296\n"" 857 30 432 436 431\n"" 858 23 432 30 28\n"" 859 119 107 104 155\n"" 860 142 337 318 144\n"" 861 107 103 43 104\n"" 862 426 424 425 451\n"" 863 107 156 155 166\n"" 864 119 107 106 104\n"" 865 156 107 149 166\n"" 866 103 107 43 38\n"" 867 103 122 206 102\n"" 868 448 41 45 37\n"" 869 423 416 45 448\n"" 870 81 228 213 31\n"" 871 217 239 213 215\n"" 872 403 376 415 401\n"" 873 443 74 80 389\n"" 874 135 163 341 118\n"" 875 133 126 136 137\n"" 876 228 216 213 217\n"" 877 447 451 7 449\n"" 878 71 41 393 392\n"" 879 282 321 304 281\n"" 880 95 63 99 61\n"" 881 185 197 183 188\n"" 882 433 23 437 436\n"" 883 212 24 210 19\n"" 884 257 260 440 258\n"" 885 184 197 185 198\n"" 886 175 178 195 179\n"" 887 61 60 58 44\n"" 888 362 363 361 365\n"" 889 447 451 424 7\n"" 890 132 135 130 131\n"" 891 61 91 96 58\n"" 892 385 430 387 384\n"" 893 127 133 130 126\n"" 894 80 274 226 255\n"" 895 80 274 255 384\n"" 896 219 87 86 84\n"" 897 275 259 224 276\n"" 898 18 229 15 227\n"" 899 320 304 311 322\n"" 900 23 21 26 433\n"" 901 109 38 48 107\n"" 902 342 139 126 138\n"" 903 21 23 26 22\n"" 904 426 428 444 427\n"" 905 331 166 362 315\n"" 906 122 206 204 453\n"" 907 12 1 35 13\n"" 908 189 331 281 333\n"" 909 35 9 34 1\n"" 910 426 412 389 411\n"" 911 287 305 289 293\n"" 912 320 160 333 336\n"" 913 0 35 37 36\n"" 914 262 255 247 256\n"" 915 353 352 325 324\n"" 916 336 329 330 316\n"" 917 275 260 440 259\n"" 918 16 442 437 441\n"" 919 380 378 273 381\n"" 920 7 424 447 448\n"" 921 400 376 373 375\n"" 922 222 223 214 83\n"" 923 30 22 23 27\n"" 924 262 271 274 429\n"" 925 45 44 37 41\n"" 926 380 265 382 273\n"" 927 149 333 189 147\n"" 928 242 245 229 243\n"" 929 131 135 128 118\n"" 930 245 256 247 255\n"" 931 391 412 393 394\n"" 932 99 61 97 95\n"" 933 281 203 280 453\n"" 934 350 333 331 322\n"" 935 41 71 393 70\n"" 936 398 400 399 402\n"" 937 323 309 308 310\n"" 938 37 3 0 7\n"" 939 72 393 45 391\n"" 940 408 270 430 407\n"" 941 40 47 44 42\n"" 942 298 305 293 284\n"" 943 250 385 386 80\n"" 944 266 379 273 380\n"" 945 191 170 192 173\n"" 946 364 354 356 355\n"" 947 200 186 159 187\n"" 948 159 147 190 158\n"" 949 229 244 225 245\n"" 950 427 250 411 428\n"" 951 342 347 126 340\n"" 952 13 80 12 15\n"" 953 342 346 347 344\n"" 954 268 273 379 406\n"" 955 352 365 366 369\n"" 956 78 50 240 51\n"" 957 322 321 304 294\n"" 958 183 180 196 182\n"" 959 266 379 267 273\n"" 960 58 59 60 91\n"" 961 405 273 269 406\n"" 962 84 220 85 86\n"" 963 81 82 214 223\n"" 964 21 24 26 211\n"" 965 87 219 86 57\n"" 966 442 411 428 426\n"" 967 35 443 1 426\n"" 968 47 44 94 46\n"" 969 357 325 113 313\n"" 970 313 357 354 113\n"" 971 31 217 228 213\n"" 972 99 61 66 64\n"" 973 144 166 147 160\n"" 974 298 284 285 297\n"" 975 398 400 371 399\n"" 976 51 78 50 79\n"" 977 298 284 297 296\n"" 978 7 451 3 449\n"" 979 281 279 280 331\n"" 980 158 177 190 159\n"" 981 117 106 105 119\n"" 982 278 276 277 433\n"" 983 200 122 201 177\n"" 984 72 35 389 74\n"" 985 54 228 31 217\n"" 986 379 406 378 404\n"" 987 347 127 126 128\n"" 988 109 362 112 360\n"" 989 126 339 340 341\n"" 990 142 338 140 163\n"" 991 38 44 47 42\n"" 992 150 142 145 164\n"" 993 426 424 451 420\n"" 994 431 208 433 30\n"" 995 437 207 433 276\n"" 996 135 154 153 163\n"" 997 163 341 354 318\n"" 998 443 13 74 35\n"" 999 143 142 144 140\n"" 1000 320 322 323 333\n"" 1001 122 147 158 149\n"" 1002 112 359 361 113\n"" 1003 359 112 361 360\n"" 1004 149 121 201 453\n"" 1005 361 358 113 359\n"" 1006 361 113 357 325\n"" 1007 113 359 358 112\n"" 1008 409 388 410 250\n"" 1009 71 69 389 70\n"" 1010 430 409 387 408\n"" 1011 32 217 216 228\n"" 1012 400 374 372 373\n"" 1013 419 422 423 421\n"" 1014 51 78 79 240\n"" 1015 387 386 250 385\n"" 1016 48 360 109 111\n"" 1017 438 277 433 435\n"" 1018 316 331 329 315\n"" 1019 74 50 49 35\n"" 1020 302 305 287 293\n"" 1021 287 293 286 302\n"" 1022 258 440 257 263\n"" 1023 188 183 181 196\n"" 1024 1 426 41 35\n"" 1025 236 216 213 234\n"" 1026 292 283 291 304\n"" 1027 381 383 273 382\n"" 1028 50 15 33 35\n"" 1029 79 240 78 80\n"" 1030 177 122 201 190\n"" 1031 307 308 309 310\n"" 1032 229 240 33 243\n"" 1033 200 187 177 199\n"" 1034 31 214 213 81\n"" 1035 128 133 126 136\n"" 1036 37 424 448 41\n"" 1037 263 247 246 248\n"" 1038 444 389 442 426\n"" 1039 423 417 414 94\n"" 1040 177 190 191 173\n"" 1041 417 419 415 421\n"" 1042 300 293 302 286\n"" 1043 442 13 15 80\n"" 1044 121 103 149 120\n"" 1045 136 126 135 137\n"" 1046 201 122 121 149\n"" 1047 331 316 333 315\n"" 1048 18 19 15 212\n"" 1049 38 45 423 94\n"" 1050 113 347 354 123\n"" 1051 273 405 269 408\n"" 1052 26 208 30 433\n"" 1053 431 208 278 433\n"" 1054 429 251 271 274\n"" 1055 109 38 360 48\n"" 1056 400 398 371 370\n"" 1057 174 173 175 171\n"" 1058 149 362 107 206\n"" 1059 245 242 229 244\n"" 1060 417 423 414 419\n"" 1061 185 199 186 198\n"" 1062 158 170 173 157\n"" 1063 177 122 190 159\n"" 1064 308 292 311 290\n"" 1065 380 378 379 273\n"" 1066 218 81 214 53\n"" 1067 232 244 233 227\n"" 1068 72 49 35 74\n"" 1069 235 245 226 244\n"" 1070 234 243 242 228\n"" 1071 316 331 332 329\n"" 1072 451 41 424 1\n"" 1073 362 353 363 365\n"" 1074 224 20 21 211\n"" 1075 258 248 263 246\n"" 1076 393 389 392 412\n"" 1077 212 15 224 20\n"" 1078 342 346 344 345\n"" 1079 229 74 240 80\n"" 1080 302 301 300 286\n"" 1081 203 202 204 453\n"" 1082 216 234 236 32\n"" 1083 386 388 410 411\n"" 1084 144 163 165 316\n"" 1085 347 344 346 356\n"" 1086 21 442 224 437\n"" 1087 190 122 201 147\n"" 1088 6 424 7 448\n"" 1089 269 270 408 407\n"" 1090 126 125 347 348\n"" 1091 37 44 45 38\n"" 1092 393 72 45 70\n"" 1093 413 423 418 414\n"" 1094 31 32 54 53\n"" 1095 29 22 27 26\n"" 1096 403 376 401 402\n"" 1097 83 220 221 85\n"" 1098 433 207 278 276\n"" 1099 218 57 55 56\n"" 1100 155 116 119 106\n"" 1101 173 175 171 192\n"" 1102 244 225 245 233\n"" 1103 158 173 172 157\n"" 1104 281 203 201 202\n"" 1105 344 354 356 347\n"" 1106 315 144 333 160\n"" 1107 392 426 412 389\n"" 1108 87 83 79 84\n"" 1109 347 358 357 349\n"" 1110 342 139 339 126\n"" 1111 126 341 340 354\n"" 1112 37 424 3 7\n"" 1113 210 29 25 26\n"" 1114 261 389 442 80\n"" 1115 107 112 155 108\n"" 1116 389 250 428 411\n"" 1117 80 12 15 74\n"" 1118 380 265 273 266\n"" 1119 190 122 147 159\n"" 1120 142 338 144 140\n"" 1121 109 362 107 112\n"" 1122 362 423 366 418\n"" 1123 97 66 98 64\n"" 1124 300 293 286 298\n"" 1125 130 136 133 128\n"" 1126 389 77 80 386\n"" 1127 142 337 338 318\n"" 1128 56 76 55 218\n"" 1129 214 82 83 223\n"" 1130 246 261 263 225\n"" 1131 35 12 15 33\n"" 1132 420 1 451 426\n"" 1133 63 99 61 66\n"" 1134 96 44 92 91\n"" 1135 219 214 218 83\n"" 1136 323 308 309 322\n"" 1137 224 229 225 15\n"" 1138 38 413 48 414\n"" 1139 281 149 279 331\n"" 1140 183 188 197 196\n"" 1141 180 195 181 196\n"" 1142 50 15 35 74\n"" 1143 113 347 357 354\n"" 1144 331 166 315 333\n"" 1145 19 15 212 20\n"" 1146 69 389 70 72\n"" 1147 216 236 213 239\n"" 1148 6 424 448 37\n"" 1149 74 229 33 15\n"" 1150 185 199 187 186\n"" 1151 71 389 41 392\n"" 1152 195 174 175 194\n"" 1153 398 400 402 370\n"" 1154 282 283 294 295\n"" 1155 244 227 229 225\n"" 1156 308 310 306 290\n"" 1157 288 310 306 307\n"" 1158 307 308 310 306\n"" 1159 251 274 254 252\n"" 1160 55 219 87 57\n"" 1161 64 63 65 62\n"" 1162 15 13 16 12\n"" 1163 190 201 189 161\n"" 1164 316 331 333 332\n"" 1165 329 331 324 315\n"" 1166 364 354 353 356\n"" 1167 166 144 147 165\n"" 1168 334 329 336 332\n"" 1169 420 422 424 416\n"" 1170 350 333 281 331\n"" 1171 322 292 321 281\n"" 1172 209 24 210 212\n"" 1173 424 37 1 41\n"" 1174 269 407 408 405\n"" 1175 429 430 407 408\n"" 1176 15 443 13 442\n"" 1177 214 221 222 83\n"" 1178 13 17 16 14\n"" 1179 333 166 315 160\n"" 1180 224 20 211 212\n"" 1181 122 201 121 453\n"" 1182 246 247 245 256\n"" 1183 391 393 416 394\n"" 1184 37 44 38 39\n"" 1185 344 354 355 356\n"" 1186 189 147 333 160\n"" 1187 437 208 433 207\n"" 1188 181 195 178 179\n"" 1189 403 376 402 373\n"" 1190 183 180 181 196\n"" 1191 433 276 438 437\n"" 1192 380 273 382 381\n"" 1193 209 24 26 210\n"" 1194 379 406 404 268\n"" 1195 7 451 424 3\n"" 1196 400 402 373 403\n"" 1197 21 207 211 26\n"" 1198 451 41 1 420\n"" 1199 201 149 279 281\n"" 1200 347 344 354 340\n"" 1201 419 417 415 414\n"" 1202 344 345 346 343\n"" 1203 79 83 76 82\n"" 1204 128 133 130 127\n"" 1205 6 424 37 7\n"" 1206 190 147 201 161\n"" 1207 87 218 55 83\n"" 1208 39 44 41 37\n"" 1209 245 242 235 243\n"" 1210 389 41 392 420\n"" 1211 24 212 20 19\n"" 1212 451 41 420 424\n"" 1213 78 75 50 79\n"" 1214 440 257 263 225\n"" 1215 81 83 76 218\n"" 1216 385 378 387 381\n"" 1217 430 387 384 408\n"" 1218 329 315 324 316\n"" 1219 281 280 279 453\n"" 1220 279 205 206 453\n"" 1221 253 254 274 252\n"" 1222 325 357 356 354\n"" 1223 443 17 13 14\n"" 1224 322 292 281 320\n"" 1225 399 372 397 400\n"" 1226 56 76 53 55\n"" 1227 212 231 18 230\n"" 1228 24 26 211 209\n"" 1229 420 1 426 41\n"" 1230 182 196 183 197\n"" 1231 229 74 80 15\n"" 1232 118 347 126 128\n"" 1233 180 195 178 181\n"" 1234 361 358 357 113\n"" 1235 239 213 215 238\n"" 1236 224 229 15 18\n"" 1237 423 68 94 414\n"" 1238 6 45 37 448\n"" 1239 48 360 111 413\n"" 1240 302 301 286 303\n"" 1241 35 41 1 37\n"" 1242 431 278 434 433\n"" 1243 145 164 162 150\n"" 1244 174 173 171 172\n"" 1245 423 279 367 448\n"" 1246 362 423 107 206\n"" 1247 272 271 251 274\n"" 1248 273 385 378 387\n"" 1249 200 122 177 159\n"" 1250 452 425 447 449\n"" 1251 210 29 26 209\n"" 1252 130 135 136 128\n"" 1253 234 213 237 235\n"" 1254 216 54 217 32\n"" 1255 402 373 376 374\n"" 1256 164 143 165 150\n"" 1257 427 250 410 411\n"" 1258 386 388 250 410\n"" 1259 96 61 59 95\n"" 1260 159 200 187 177\n"" 1261 389 443 442 80\n"" 1262 398 395 396 399\n"" 1263 87 83 55 76\n"" 1264 389 77 74 80\n"" 1265 229 15 80 225\n"" 1266 207 433 278 208\n"" 1267 96 59 91 95\n"" 1268 341 126 135 118\n"" 1269 62 61 59 58\n"" 1270 206 149 279 453\n"" 1271 400 370 372 374\n"" 1272 389 35 426 74\n"" 1273 360 423 362 413\n"" 1274 54 228 32 31\n"" 1275 109 38 107 360\n"" 1276 87 83 84 219\n"" 1277 72 35 69 389\n"" 1278 246 262 247 256\n"" 1279 352 364 353 365\n"" 1280 268 273 406 269\n"" 1281 443 74 13 80\n"" 1282 242 244 241 229\n"" 1283 149 279 362 206\n"" 1284 99 64 66 97\n"" 1285 376 373 92 374\n"" 1286 26 29 25 27\n"" 1287 32 213 228 216\n"" 1288 118 163 341 354\n"" 1289 161 158 147 157\n"" 1290 61 60 44 91\n"" 1291 292 308 304 291\n"" 1292 163 144 165 162\n"" 1293 407 262 430 429\n"" 1294 63 62 61 59\n"" 1295 153 163 154 168\n"" 1296 350 281 322 321\n"" 1297 262 271 270 274\n"" 1298 442 426 428 444\n"" 1299 38 44 42 39\n"" 1300 80 240 229 243\n"" 1301 194 171 174 175\n"" 1302 155 362 325 112\n"" 1303 306 304 291 305\n"" 1304 77 78 74 80\n"" 1305 80 74 240 78\n"" 1306 38 44 94 47\n"" 1307 273 405 408 406\n"" 1308 293 298 285 286\n"" 1309 88 389 390 77\n"" 1310 311 304 292 308\n"" 1311 99 66 98 97\n"" 1312 26 210 24 25\n"" 1313 259 224 276 207\n"" 1314 61 62 64 58\n"" 1315 244 242 235 245\n"" 1316 244 241 235 242\n"" 1317 63 61 64 66\n"" 1318 149 201 279 453\n"" 1319 206 122 121 453\n"" 1320 413 366 362 365\n"" 1321 409 388 250 387\n"" 1322 423 362 413 418\n"" 1323 38 414 48 47\n"" 1324 38 360 423 107\n"" 1325 290 289 288 306\n"" 1326 333 322 323 331\n"" 1327 389 443 74 426\n"" 1328 35 71 389 41\n"" 1329 279 149 362 331\n"" 1330 74 12 15 35\n"" 1331 424 423 422 448\n"" 1332 190 201 177 200\n"" 1333 365 325 353 352\n"" 1334 385 383 384 273\n"" 1335 331 322 321 350\n"" 1336 71 70 389 393\n"" 1337 126 139 339 137\n"" 1338 44 45 92 91\n"" 1339 72 49 69 35\n"" 1340 175 178 174 195\n"" 1341 247 246 245 261\n"" 1342 41 424 448 420\n"" 1343 46 92 44 94\n"" 1344 402 400 373 374\n"" 1345 198 197 185 188\n"" 1346 304 296 294 283\n"" 1347 116 131 129 128\n"" 1348 50 15 74 33\n"" 1349 110 108 112 109\n"" 1350 448 425 424 447\n"" 1351 166 331 362 149\n"" 1352 206 149 103 107\n"" 1353 209 26 208 29\n"" 1354 211 231 224 212\n"" 1355 33 50 51 240\n"" 1356 32 213 234 228\n"" 1357 444 389 426 443\n"" 1358 107 112 108 109\n"" 1359 217 213 214 215\n"" 1360 16 22 436 21\n"" 1361 142 337 144 338\n"" 1362 323 311 322 320\n"" 1363 411 386 389 250\n"" 1364 265 273 264 382\n"" 1365 211 230 231 212\n"" 1366 295 296 294 297\n"" 1367 0 35 1 37\n"" 1368 229 74 33 240\n"" 1369 131 118 116 117\n"" 1370 122 204 101 201\n"" 1371 206 122 204 101\n"" 1372 83 220 86 219\n"" 1373 113 358 347 123\n""# Generated by tetgen -YY bunny.smesh \n"); } diff --git a/Demos/SoftDemo/cube.inl b/Demos/SoftDemo/cube.inl deleted file mode 100644 index 7015a23e6..000000000 --- a/Demos/SoftDemo/cube.inl +++ /dev/null @@ -1,4 +0,0 @@ -static const char* getNodes() { return( -"400 3 0 0\n"" 0 1 1 -1\n"" 1 1 -1 -1\n"" 2 -1 -1 -1\n"" 3 1 1 1\n"" 4 -1 -1 1\n"" 5 -1 1 -1\n"" 6 1 -1 1\n"" 7 -1 1 1\n"" 8 -1 -1 -0.000116\n"" 9 0.00039500000000000006 -1 1\n"" 10 1 -1 -0.00065799999999999995\n"" 11 1 0.00061700000000000004 -1\n"" 12 0.00098999999999999999 1 -1\n"" 13 -1 1 0.00045400000000000008\n"" 14 0.00052800000000008396 1 1\n"" 15 1 1 -0.00038699999999991519\n"" 16 -1 -5.9999999999504894e-006 1\n"" 17 -1 0.00021000000000004349 -1\n"" 18 1 0.00067400000000006344 1\n"" 19 1.0863393114549872e-007 3.0682525964387253e-008 1\n"" 20 0.00097299999999989062 -1 -1\n"" 21 -1.4065544284846965e-008 1 5.0429866114086973e-008\n"" 22 1 -7.0792689266241382e-008 -4.4728299621228391e-008\n"" 23 8.4069120565846353e-008 3.8392827594879719e-007 -1\n"" 24 1 0.49980668112692161 -0.4996917965899465\n"" 25 1 0.50006700000000004 -1\n"" 26 1 1 -0.50034809999999996\n"" 27 1 1 0.50025040000000009\n"" 28 0.50020930000000008 1 1\n"" 29 -1 0.50010129999999997 1\n"" 30 -0.49958379999999991 1 1\n"" 31 -1 9.2038384777827427e-008 -1.100605984127867e-008\n"" 32 -0.5001201999999999 -1 1\n"" 33 1.0486788869007099e-007 -1 -3.3620911388254626e-008\n"" 34 -1 -1 0.50008699999999995\n"" 35 1 -0.50010220000000005 -1\n"" 36 1 -1 -0.49985400000000002\n"" 37 1 -0.4996526 1\n"" 38 1 -1 0.49990490000000004\n"" 39 -0.49930649999999999 1 -1\n"" 40 -1 1 -0.50002420000000003\n"" 41 1 -0.24974260000000004 -0.50015432157969908\n"" 42 0.50015422769290296 -0.24974260000000001 -1\n"" 43 0.50009680402228707 1 0.24993170000000009\n"" 44 1 0.50009675187018254 0.24993170000000009\n"" 45 0.24987467313200107 0.24987468273492527 -0.24987454967853764\n"" 46 0.50006970000000006 1 -1\n"" 47 -1 1 0.50062509999999982\n"" 48 -0.24952789999999991 1 0.50013191885453001\n"" 49 -0.24952789999999991 0.50013187836130635 1\n"" 50 -1 -0.50000239999999996 -1\n"" 51 -0.49917350000000005 -1 -1\n"" 52 -1 -0.37500110896930483 0.49999770999384097\n"" 53 -0.49999768418870116 -0.37500109958532857 1\n"" 54 0.50016842960649455 -0.24948929999999997 1\n"" 55 1 -0.24948929999999997 0.50016837821653382\n"" 56 -1 0.50011355427218929 -0.24978510000000004\n"" 57 -0.50011349993113807 1 -0.24978510000000009\n"" 58 0.49983560886453382 -1 -0.25025600000000003\n"" 59 1 -0.24959280000000006 -1\n"" 60 0.46861653427920624 0.31279234072878337 -1\n"" 61 0.46874721181012263 1 -0.31263609558485356\n"" 62 1 1 0.24986720000000007\n"" 63 1 0.50004500000000007 1\n"" 64 0.41666006216462159 0.41668749191836219 1\n"" 65 1 0.62492318088559184 0.62497446433589154\n"" 66 0.62493687874554793 1 0.62494713479954256\n"" 67 -0.32510780807963724 -0.32510780489834346 -0.32510793388507692\n"" 68 1 0.12495484505171366 -0.3748231366627352\n"" 69 -0.24915825000000003 0.50024732783000192 -1\n"" 70 1 0.74957571448653726 -0.74971600694021778\n"" 71 0.64874656072370729 1 -0.64882932411306993\n"" 72 0.6488668035834122 0.64886599996407779 -1\n"" 73 -1 0.41673079803079871 0.41664307505523179\n"" 74 -0.62468209179782908 1 0.62494186195929313\n"" 75 -0.62476903429567798 0.62489835940819183 1\n"" 76 -1 0.75020764999999989 1\n"" 77 0.12520010648567331 0.45856412436943739 0.37477910185628149\n"" 78 -0.24942439999999994 1 1\n"" 79 -0.37474797737976173 1 0.74996984889996166\n"" 80 -0.3748348177892612 0.74992638728967431 1\n"" 81 -1 -1 -0.49994339999999993\n"" 82 -0.50002894420427402 -1 0.24998549999999997\n"" 83 -1 -0.50045000000000006 1\n"" 84 -0.015617775048046156 -0.5000062299955631 1\n"" 85 -0.062520154989433377 -1 0.50002475010607028\n"" 86 0.50024029999999997 -1 1\n"" 87 1 -0.24929619999999997 1\n"" 88 0.37505270907528421 -0.3750526949043349 0.12522791934472338\n"" 89 -1 0.5001348000000001 -1\n"" 90 -1 1 -0.24999450000000001\n"" 91 1 -0.62477132796083668 -0.25025600000000003\n"" 92 0.50052129999999995 -1 -1\n"" 93 1 0.018238422269637886 -0.6785517711937521\n"" 94 0.750039598406532 -0.12448790000000004 -1\n"" 95 0.32367160517680327 0.022514689090561368 -0.65701963759824777\n"" 96 0.32369468988306127 0.65698780035674154 -0.022395524628340657\n"" 97 1 1 -0.25020424999999996\n"" 98 1 0.62501462613012171 -0.12492844204372336\n"" 99 0.16205966081319645 0.60689608104137205 -1\n"" 100 0.23307615322925276 1 -0.65509826790501591\n"" 101 0.6349049175761754 0.105723024682608 1\n"" 102 1 0.18290638148392097 0.59627500837254621\n"" 103 0.67708420758319754 0.67702605426027662 1\n"" 104 1 0.7498625000000001 1\n"" 105 0.75029925000000008 1 1\n"" 106 0.75006454389022692 1 0.37500606926950353\n"" 107 1 0.7500645207487896 0.37502882687227923\n"" 108 -0.39273716375981493 0.28664398202145958 -0.051638660454459806\n"" 109 -0.41671246738153483 -0.41657507574696978 -1\n"" 110 -0.24910025000000008 -1 -0.50024283860374685\n"" 111 -1 -0.50000177258228129 0.01562108247952367\n"" 112 -1 0.062713405747402015 -0.49998686350971472\n"" 113 -0.21672667787876426 1 -0.60296047487967241\n"" 114 1 0.7499052299192317 -0.37495181123207261\n"" 115 0.74540338978064358 1 -0.37527617499999999\n"" 116 0.52159008257288741 0.55923294709068649 -0.50062662770660094\n"" 117 0.75009235000000007 1 -1\n"" 118 -0.52928249862025711 0.10679011696853863 1\n"" 119 -1 0.034077217919757319 0.58381620432891879\n"" 120 -1 0.7383278941763165 0.25053954999999994\n"" 121 -0.70891631291249579 1 0.25053954999999989\n"" 122 -0.46050965421976553 0.49218708190674731 0.49218708126315491\n"" 123 -1 0.68039176952095026 0.65291562053589947\n"" 124 0.10567541850782136 0.6349221513724419 1\n"" 125 0.18288602711749127 1 0.59629803533945958\n"" 126 0.54298856425431818 0.54298737875163716 0.56762073808494473\n"" 127 -0.67702799351191578 -0.67732215502802495 -1\n"" 128 -0.74942264999999997 -1 -1\n"" 129 -1 -1 -0.74980449999999998\n"" 130 -1 -0.49218854513728494 -0.49218946358719012\n"" 131 -0.42414945787750447 -1 0.62500198796368489\n"" 132 -0.34611026252144428 -0.35284219355707647 0.34611025416343177\n"" 133 -1 -0.25018009999999996 1\n"" 134 1 -0.62478846817134759 0.62485153607962096\n"" 135 0.46873640237350567 -1 0.46875741869756882\n"" 136 0.62487945516234578 -0.62473271086601501 1\n"" 137 1 -1 0.75017445000000005\n"" 138 0.74996116568713633 -0.37481680473944939 1\n"" 139 1 -0.37487247538331225 0.74993327711783697\n"" 140 0.52037384429375466 0.13732055395658338 0.20134643019667742\n"" 141 0.15110486348630267 -0.58850137906978839 -0.32248691722782763\n"" 142 0.18460607304185575 -0.25601325165021294 0.59072519783751942\n"" 143 0.58280144730296801 -0.1236683742487249 -0.25429890766156527\n"" 144 -0.62459780071323356 0.62480472798869868 -1\n"" 145 -1 0.62491663124728913 -0.6248890159372763\n"" 146 -0.62484746422599169 1 -0.62502715932999464\n"" 147 -0.7093663193037405 1 -0.043380902757278066\n"" 148 -1 0.70881555044570888 -0.042280622034258974\n"" 149 1 -1 -0.25034290000000009\n"" 150 1 -0.40640338795560693 0.10958986646960317\n"" 151 0.62965348921187414 -1 0.11553823232370244\n"" 152 0.62491481284490769 -0.62481034920526324 -1\n"" 153 0.62518044398996542 -1 -0.62501367730297908\n"" 154 1 -0.63771354537448766 -0.63764519345816328\n"" 155 1 0.31875234539841601 -0.74994017167142224\n"" 156 1 0.25014510000000001 -1\n"" 157 0.74289722234692146 0.382058894292784 -1\n"" 158 0.32367160517680327 0.022514689090561313 -1\n"" 159 -0.16523027793533418 0.12134647368575949 -0.52708319267772263\n"" 160 0.66127538009577513 0.12758426427554953 -1\n"" 161 0.66190311587317174 -0.14472935797430672 -0.63288146125613987\n"" 162 0.32369468988306133 1 -0.022395524628340657\n"" 163 0.66678290425073372 1 -0.041514421404229618\n"" 164 0.25040265000000006 1 -1\n"" 165 0.0399620660587649 1 -0.35479393735090492\n"" 166 0.39507172571995386 0.7484116421252891 -1\n"" 167 1 -0.072369672334633761 0.72403943393322545\n"" 168 1 0.25022030000000006 1\n"" 169 -1 0.34715093732334323 0.069506853183406409\n"" 170 0.004224600474193374 -0.00030510666109673235 0.14430736392114327\n"" 171 -0.094962845556292308 0.5834952204256858 0.029410273259612763\n"" 172 -0.37516021595805987 -1 -0.12532788579913123\n"" 173 -0.24910025000000008 -0.73780528173239301 -1\n"" 174 -0.24899625000000003 -1 -1\n"" 175 -1 -0.68752594294730018 0.32233197415569781\n"" 176 -0.63898818329694262 -0.019780155017187176 -0.25640753531059018\n"" 177 -0.24918545000000003 1 -1\n"" 178 -0.090115044090208485 0.73312064098608642 -1\n"" 179 0.70087100707296945 0.7030864101348856 -0.70306291837965817\n"" 180 0.43929348327839085 1 -0.54468859277252801\n"" 181 0.24904127574612012 0.39074020564473289 -0.70186910867307939\n"" 182 1 0.37487410261969639 -0.24965440370335262\n"" 183 -1 0.25002235 1\n"" 184 -1 0.3834446703544917 0.71903607815447956\n"" 185 -0.1156880925075553 0.64434016438489528 0.64434017606689242\n"" 186 -0.49172745225271947 1 0.39835250767529351\n"" 187 -0.49767862299671706 0.38046779215689319 1\n"" 188 -0.71839703681869116 0.71780974657570373 0.44934935063382636\n"" 189 -0.51344827724776054 0.71469177745101886 0.71472798522876002\n"" 190 -0.23617534848477656 0.19448005635194549 1\n"" 191 0.10846459384596518 0.30820266021358389 1\n"" 192 0.25057285000000007 1 1\n"" 193 0.017230183845622971 1 0.32091029596366771\n"" 194 0.73101248242769623 0.7310147155780512 0.70877874225568527\n"" 195 0.31697048198150773 0.74665075980915008 0.4006579958540028\n"" 196 0.22826577744747956 0.47891948624469016 0.71004422740180217\n"" 197 1 0.41190390341165745 0.48757967789479273\n"" 198 0.39445308838583859 1 0.75656358081536812\n"" 199 0.37539107500000007 0.73916688955610543 1\n"" 200 1 0.37513265000000007 0.77169890914285255\n"" 201 0.73942011355234571 0.37513265000000007 1\n"" 202 0.63994038137069154 0.63994036678159205 0.2035446667438317\n"" 203 -0.46370016318896046 -0.62998103084618617 -0.61483850042635191\n"" 204 -1 -0.21786745446900305 -0.71882640763337879\n"" 205 -0.7381625142245487 -0.24989619999999996 -1\n"" 206 -1 -0.68409919087038817 -0.74320185410965045\n"" 207 -0.32233403971208485 -0.68753538843092254 1\n"" 208 -0.24999429999999997 -1 1\n"" 209 -1 -0.68747379665002328 0.68733786195201785\n"" 210 -1 -1 0.74993719999999997\n"" 211 -0.68734034505209507 -0.68746383783523624 1\n"" 212 0.012621642749083783 -0.62121055252239044 0.25549907282899653\n"" 213 -0.6302385799280833 -0.18856073836207951 0.63023858315073289\n"" 214 -1 -0.24375245663389172 0.20780956095073669\n"" 215 0.27457426263537876 -0.71671644193112283 1\n"" 216 0.25031765 -1 0.74826556642116959\n"" 217 0.67415846717387884 -1 0.72313083855082583\n"" 218 0.62503542334105555 -0.31221159888129457 0.62503541050290967\n"" 219 0.5971993096065894 0.14306806366195202 0.59872066564664705\n"" 220 1 0.017233350071975677 0.32090429254255515\n"" 221 0.26312362546126472 0.33468192363906535 0.084065768486193945\n"" 222 0.32197792152690552 -1 0.018797337932729474\n"" 223 0.18800195544968995 -1 -0.56289551925444881\n"" 224 0.57038729142869704 -0.57307887210152808 -0.20881754066389768\n"" 225 -0.0086896099297664228 -0.40801963637004723 -1\n"" 226 0.18460607304185569 -0.25601325165021294 1\n"" 227 -0.20780680948491165 -0.24375608761730455 1\n"" 228 0.16210795897650465 -0.16280891134401318 -0.30907215240469521\n"" 229 1 -0.26636148213032163 -0.17942676839456378\n"" 230 0.56446572384612781 0.1973176117738667 -0.43724659666019622\n"" 231 0.68853374013319157 -0.17744483013216472 0.09783510961497599\n"" 232 -1 0.25009230000000005 -1\n"" 233 -0.44245798368554617 0.091797696559903857 -1\n"" 234 -0.37472098690918887 0.74987909210814685 -1\n"" 235 -1 0.75000438735900432 -0.37495636858710685\n"" 236 -0.74996704638216471 1 -0.37508384505925174\n"" 237 -1 0.74990679999999998 -1\n"" 238 -0.54712707263607874 0.54712707774677038 -0.44245689687343565\n"" 239 -0.74990204999999999 1 -1\n"" 240 -0.72822316548562926 0.72874031845750664 0.1036085388532241\n"" 241 1 -0.71873547817891748 0.28112338497214717\n"" 242 1 -1 0.24972335000000001\n"" 243 0.75048264999999992 -1 -1\n"" 244 0.74989614566839657 -1 -0.37495931701899499\n"" 245 0.32778297288621805 -0.39528027615360428 -0.64821309452322518\n"" 246 1 -0.38051416654716286 -0.74727639147947866\n"" 247 0.75568696149005932 -0.39170758577960507 -1\n"" 248 0.67082477453227773 0.69774082076774491 -0.21670307025395311\n"" 249 0.25644629494787752 0.72897062001391455 -0.35498913750943906\n"" 250 -0.66044139980269567 0.12332997433814857 0.28570391360731856\n"" 251 -0.20800059812674501 0.28777064045558248 0.28593682199556314\n"" 252 0.29133599196527848 -0.095788071590640317 0.30648986161740821\n"" 253 -0.19340828105680374 -0.0068671095901119807 -0.17510149752792639\n"" 254 -0.21084753812463372 1 -0.20339622724796672\n"" 255 -0.098922382084248209 0.356624117376247 -0.256263439404529\n"" 256 -1 -0.74213790787259271 -0.24206983063972595\n"" 257 -0.72511478181115718 -1 -0.25002969999999997\n"" 258 -0.1250383368944159 -1 -0.24987830054645518\n"" 259 -0.5432409326212666 -0.58336779772250913 -0.0060938376146522089\n"" 260 -1 -1 0.25020549999999997\n"" 261 -0.69517902037783963 -1 0.48465629903462193\n"" 262 -1 0.19801494027267907 -0.22908951271298833\n"" 263 -1 -0.21170789004360985 -0.2804810168349573\n"" 264 0.12431896494966958 0.19380761445281547 -0.51506516411314296\n"" 265 0.016877018602808991 0.32057899216794972 -1\n"" 266 0.31815206866103007 0.69886802178230512 -0.69773364246572678\n"" 267 1 0.29452437620263039 0.03597223402760958\n"" 268 -0.23854616157962166 0.70039865549364788 0.32382827237146705\n"" 269 -0.072417036863037423 1 0.7240118059209224\n"" 270 -0.65715846697692126 0.26022065746019457 0.6943166148678479\n"" 271 0.032006652383344852 0.12877070459954792 0.60754383991332461\n"" 272 0.70679839053632465 0.35784100137989416 0.35408213575434944\n"" 273 1 0.75583880296190964 0.10796710954834202\n"" 274 -0.066417091587110066 -0.67493516441615642 -0.64835749920354258\n"" 275 -0.66000110931003353 -0.29732769674682547 -0.5356675566159671\n"" 276 -1 -0.7460956789293286 -0.49597432811515113\n"" 277 -0.63537062135554268 -1 -0.62487395000000001\n"" 278 -0.072189529852730625 -0.75207129129950046 1\n"" 279 -0.12479964999999998 -1 0.76180792382505302\n"" 280 -0.64633703603487636 -0.58450521092750218 0.50482020379778969\n"" 281 -0.19793040641595078 -1 0.22917284009874619\n"" 282 0.36430902573049584 -0.60319992435881997 0.46610302519244695\n"" 283 -0.014560432971481855 -0.28974170434477692 0.31899501601243035\n"" 284 -0.16677858939457951 -0.59736466720530357 0.62746423626615599\n"" 285 -0.70838149553417962 -0.14588171485233958 1\n"" 286 -1 -0.20773576611374234 0.72382280144202749\n"" 287 0.65401865792186442 -0.65865126715652123 0.6540215253821221\n"" 288 0.76868552550191671 -0.1162896631221611 1\n"" 289 0.39236022879703553 0.3070079448900544 0.42979647060190596\n"" 290 0.3368388593683827 0.015623435483033674 1\n"" 291 0.19283437348027005 -1 0.30983198636425424\n"" 292 0.23987671409711908 -0.66618838122351409 0.0008945936534150746\n"" 293 0.42213117252176491 -0.74712687995942406 -0.48458654817973601\n"" 294 1 -0.66026812967233972 0.017464640590841476\n"" 295 0.76163529643898698 -1 -0.11209435873849422\n"" 296 0.71607191560259942 -0.37037315933178871 -0.41086960011962592\n"" 297 -0.21716346053460103 -0.19947717862659675 -1\n"" 298 -0.066700914192858729 -0.25756978212559839 -0.62896708724727191\n"" 299 0.32965714090299714 -0.016623876027232615 -0.04345086208713933\n"" 300 0.3771146741942551 -0.33750921003054202 -0.17865283786030017\n"" 301 0.68867680851486557 0.35765454098697025 -0.68521532739244984\n"" 302 0.68683764447685003 -0.49596319168560488 0.30085803648362652\n"" 303 0.7090270874729655 -0.090415723473831255 0.40719961870896915\n"" 304 -0.71897798523587353 0.032300798531047246 -1\n"" 305 -0.78106895850102998 0.78106955040650416 -1\n"" 306 -1 1 -0.75022459999999991\n"" 307 -0.6917164744917017 0.69170418541265011 -0.69178840942223951\n"" 308 -0.44874465612278081 0.23033846865992608 -0.37975265656437374\n"" 309 -0.42791646676676653 1 -0.48213646482850109\n"" 310 -0.50093773209802361 0.36943796178744326 -1\n"" 311 -0.27376979380830829 0.64426231976101334 -0.66489790575084351\n"" 312 -1 0.35637030336560244 -0.50592472907968644\n"" 313 -0.67546025565396317 0.47435524682845248 -0.12755140965778172\n"" 314 1 -1 -0.74991180000000002\n"" 315 1 -0.75028080000000008 -1\n"" 316 0.75389683099717963 -0.68868788457723729 -0.44203141186583489\n"" 317 0.30599251534318156 -0.52261127269823027 -1\n"" 318 0.40047237565428867 -0.18178393484624253 -0.46933497457143036\n"" 319 0.59482353914036401 0.38624515090984007 -0.049897636224658731\n"" 320 -1 0.12332997433814856 0.2857039136073185\n"" 321 -1 -0.14689524813441618 0.42688908174824769\n"" 322 -0.66262979736993932 -0.22367581355790006 0.28652907305244368\n"" 323 -0.73506511384989526 0.43296210769478211 0.23284828493726362\n"" 324 -0.35917397776062404 -0.0011820981956873755 0.46134022362807492\n"" 325 -0.46329592253134338 -0.04321417701540118 0.047101266600350966\n"" 326 -0.27019578023748486 0.66094639539627242 -0.2626201492532621\n"" 327 -0.034393111593928383 0.28261880242562187 0.033764464745287937\n"" 328 0.18250360638285329 -1 -0.25535398043003921\n"" 329 -0.3030416241215706 -0.68638401151842854 -0.29392180366815041\n"" 330 -0.20024923856661142 -0.43390131265744347 0.010814269493628442\n"" 331 -0.70928533124789683 -1 0.043514240508664342\n"" 332 -0.66723744746271052 -0.6603325322519602 -0.32775579384930814\n"" 333 -0.75004930000000003 -1 1\n"" 334 -0.19527119007052851 0.17101403421852743 -1\n"" 335 0.035377884590221398 0.72616811699961958 0.38837547693302749\n"" 336 -0.3958963327893722 1 0.076655950240576198\n"" 337 -1 0.21457329427678187 0.47543850615348943\n"" 338 -0.7309823244201562 0.04824246580043276 0.53867561355267524\n"" 339 0.31731660817460328 0.019726050398274825 0.58867762989660533\n"" 340 -0.23374781763549932 0.32728908975345111 0.68606341552187544\n"" 341 -0.05707064185106852 -1 -0.71659883209883557\n"" 342 0.025895325626349025 -1 -0.41197380535174077\n"" 343 -0.63238580600180661 -0.3446250983839011 -0.21239475499198135\n"" 344 -1 -0.44899498782248648 -0.76904522126668295\n"" 345 -0.47299161220497166 -0.16458691872110107 -1\n"" 346 -0.71473237282422963 -0.73570249654826969 -0.71737349776128545\n"" 347 -0.74042724546706096 -1 0.74043153378626769\n"" 348 -0.75006482996996637 -0.43746254158362985 1\n"" 349 -1 -0.45163184813329721 0.75853196322407168\n"" 350 -0.50484417551448635 -0.72312317896459377 0.74770602252103513\n"" 351 -0.40758966352762416 -0.67845102844514626 0.2869272680702189\n"" 352 0.34674400209661604 -0.46348651949776365 1\n"" 353 -0.064367666161959269 -0.33637242545568102 0.74735946563471645\n"" 354 0.092602515587840606 -0.73476755239921543 0.53136369836931496\n"" 355 0.7405253302829875 -1 0.37931276242110001\n"" 356 0.72074474478028516 -0.071123657589263783 0.72858260191381197\n"" 357 -0.37493998320650845 -0.13123609584112483 -0.59370675998889832\n"" 358 -0.038352185780633007 -0.36921106178200458 -0.36036098843849301\n"" 359 -0.21058188105209746 -0.51336343843000509 -1\n"" 360 0.48755585676167218 -0.72413212665883209 0.19600157800093837\n"" 361 0.72678157399644117 -0.45646629587434373 0.011780680786240783\n"" 362 1 -0.2170765504241112 0.26033741814256661\n"" 363 -0.74541512030390267 -0.021189991595686748 -0.68170217165320612\n"" 364 -0.37387254482300358 0.32527982613660117 -0.69267828171913437\n"" 365 0.014913421017989981 0.548850834537849 -0.51262186425268497\n"" 366 -0.74537069514237131 0.2884463439624349 -1\n"" 367 -1 0.37511355000000007 -0.76842458715696027\n"" 368 -0.68532657097754035 0.18056419100293586 -0.02075972921423834\n"" 369 0.78133395148913365 -1 -0.78126287896225588\n"" 370 0.78115294817471781 -0.78112807555219699 -1\n"" 371 0.59082087507768066 -0.57000731366339108 -0.68829605397498683\n"" 372 0.062122976656860403 -0.70293283755163305 -1\n"" 373 0.71559274300689513 0.42281759201802555 -0.31813908171117911\n"" 374 0.7564597747876356 0.13217713297538497 -0.16417576007580004\n"" 375 0.40814884545639363 0.4915141193769953 -0.2436752542444009\n"" 376 -0.75696767061236314 -0.5164837362163468 0.21622587965261447\n"" 377 -0.452391830423859 0.55519361636450704 0.12429201972918034\n"" 378 -0.43481019055019038 -0.12925317405502307 1\n"" 379 -0.24742795067222612 -0.11366422696012682 0.2223275751188645\n"" 380 -0.006677616808027087 -0.21615237698969206 -0.065426614396930594\n"" 381 -0.062406752747729527 -0.70182414510247981 -0.087999792237402064\n"" 382 0.10306104864954116 0.76464771966531997 0.11700653142882178\n"" 383 0.27486783995540093 -0.12812237061584772 0.79536259891875982\n"" 384 -0.74059417471417499 -0.15757730258109431 0.00074049988054281091\n"" 385 -0.64002796579304344 -0.45394506207193958 -1\n"" 386 -0.42239397063762912 -0.42048979870740139 0.69490811148992537\n"" 387 -0.17195299402586212 -0.76346805360446235 0.40560748360163079\n"" 388 0.37676760090127209 -0.4417530820461561 0.70978247252690463\n"" 389 -0.20593363392839478 -0.044483242006169432 0.7439953909431003\n"" 390 -0.31521564832256066 -0.39420460209868968 -0.72065547292536469\n"" 391 -0.07315504595340451 0.34077703680706245 -0.71267230392230696\n"" 392 -0.0052948425242513517 1 -0.74523404665783877\n"" 393 -0.70127839101164502 0.30537699044254324 -0.64148488859352526\n"" 394 0.25061214999999992 -1 -1\n"" 395 0.40565131063307963 -0.76032995286218041 -1\n"" 396 0.38398614307047785 -1 -0.75304567260853106\n"" 397 0.23839244367761547 -0.68688896416028877 -0.73641430830181331\n"" 398 0.76674691103343318 0.57740125411814403 -0.50231823898754502\n"" 399 0.14110565781161721 -0.59279131304323562 0.77705687354697894\n""# Generated by tetgen -a0.01 cube.smesh \n"); } -static const char* getElements() { return( -"1580 4 0\n"" 0 120 148 13 240\n"" 1 77 251 185 268\n"" 2 126 194 66 198\n"" 3 297 298 159 357\n"" 4 13 148 147 240\n"" 5 219 272 102 303\n"" 6 134 137 37 136\n"" 7 302 360 88 361\n"" 8 23 264 95 391\n"" 9 307 311 238 364\n"" 10 57 309 254 326\n"" 11 345 357 233 363\n"" 12 176 343 325 384\n"" 13 275 332 67 343\n"" 14 141 245 228 318\n"" 15 108 368 323 377\n"" 16 7 47 74 123\n"" 17 73 188 184 270\n"" 18 56 235 148 313\n"" 19 46 72 117 179\n"" 20 66 105 28 194\n"" 21 205 275 204 344\n"" 22 66 194 28 198\n"" 23 96 221 45 375\n"" 24 93 160 94 161\n"" 25 225 317 245 397\n"" 26 121 186 74 188\n"" 27 213 280 52 322\n"" 28 52 322 280 376\n"" 29 96 195 77 221\n"" 30 8 257 256 331\n"" 31 358 380 330 381\n"" 32 99 181 166 266\n"" 33 120 123 73 188\n"" 34 122 189 187 340\n"" 35 141 292 224 300\n"" 36 313 326 240 377\n"" 37 203 274 173 390\n"" 38 140 299 221 319\n"" 39 44 197 107 272\n"" 40 171 326 108 377\n"" 41 71 166 46 179\n"" 42 69 364 334 391\n"" 43 26 114 97 115\n"" 44 228 253 159 358\n"" 45 221 272 202 289\n"" 46 123 184 73 188\n"" 47 22 220 140 231\n"" 48 250 324 322 325\n"" 49 270 324 213 338\n"" 50 147 240 57 336\n"" 51 69 265 178 391\n"" 52 100 249 165 365\n"" 53 296 316 224 371\n"" 54 74 188 186 189\n"" 55 21 171 165 249\n"" 56 23 297 225 298\n"" 57 191 196 64 290\n"" 58 87 139 138 288\n"" 59 126 198 196 199\n"" 60 223 328 141 342\n"" 61 293 371 153 396\n"" 62 238 308 108 313\n"" 63 49 187 80 189\n"" 64 143 300 224 361\n"" 65 111 256 130 343\n"" 66 62 107 106 273\n"" 67 64 196 126 219\n"" 68 314 154 315 369\n"" 69 50 205 204 344\n"" 70 0 70 26 71\n"" 71 95 158 23 265\n"" 72 37 138 87 139\n"" 73 125 193 43 195\n"" 74 56 312 238 313\n"" 75 257 259 172 332\n"" 76 25 70 0 72\n"" 77 141 300 228 358\n"" 78 32 207 208 350\n"" 79 101 201 200 219\n"" 80 13 147 121 240\n"" 81 67 275 176 357\n"" 82 116 249 180 266\n"" 83 197 219 200 272\n"" 84 152 247 42 371\n"" 85 95 158 60 160\n"" 86 45 230 116 375\n"" 87 88 282 142 283\n"" 88 96 162 61 249\n"" 89 209 280 211 350\n"" 90 84 353 226 399\n"" 91 33 258 172 381\n"" 92 118 285 213 378\n"" 93 196 271 77 289\n"" 94 282 287 218 388\n"" 95 196 198 125 199\n"" 96 74 7 76 30\n"" 97 95 230 181 264\n"" 98 297 359 225 390\n"" 99 280 347 261 350\n"" 100 253 299 170 380\n"" 101 125 269 193 335\n"" 102 245 293 224 300\n"" 103 41 143 68 161\n"" 104 58 295 244 316\n"" 105 83 348 211 349\n"" 106 75 29 76 123\n"" 107 171 249 96 255\n"" 108 124 196 125 199\n"" 109 61 248 96 249\n"" 110 221 255 45 327\n"" 111 254 326 171 336\n"" 112 194 198 126 199\n"" 113 208 278 9 279\n"" 114 94 93 11 160\n"" 115 275 357 345 363\n"" 116 127 173 109 203\n"" 117 134 139 55 218\n"" 118 45 255 253 327\n"" 119 154 35 315 370\n"" 120 283 284 142 353\n"" 121 186 336 268 377\n"" 122 59 93 11 94\n"" 123 110 203 51 277\n"" 124 59 246 94 247\n"" 125 116 248 61 249\n"" 126 41 229 143 296\n"" 127 91 154 36 316\n"" 128 71 179 116 180\n"" 129 45 299 221 327\n"" 130 319 373 182 374\n"" 131 64 219 101 290\n"" 132 116 301 179 398\n"" 133 122 323 188 377\n"" 134 182 373 68 374\n"" 135 97 115 114 248\n"" 136 60 158 95 181\n"" 137 185 268 48 335\n"" 138 66 125 43 195\n"" 139 86 215 136 287\n"" 140 106 202 163 273\n"" 141 43 106 66 195\n"" 142 271 324 283 389\n"" 143 95 158 42 245\n"" 144 186 188 122 189\n"" 145 25 179 157 301\n"" 146 173 274 110 341\n"" 147 136 138 37 287\n"" 148 244 293 58 316\n"" 149 107 197 65 272\n"" 150 42 160 158 161\n"" 151 28 105 103 194\n"" 152 200 201 126 219\n"" 153 147 235 90 236\n"" 154 224 292 141 293\n"" 155 220 272 140 303\n"" 156 4 209 83 211\n"" 157 207 278 208 279\n"" 158 296 300 143 318\n"" 159 226 352 84 399\n"" 160 104 65 63 194\n"" 161 212 282 88 283\n"" 162 255 308 238 364\n"" 163 150 229 91 361\n"" 164 43 163 106 202\n"" 165 126 219 196 289\n"" 166 48 185 79 189\n"" 167 257 329 110 332\n"" 168 170 299 252 380\n"" 169 30 74 75 76\n"" 170 30 79 78 80\n"" 171 39 234 146 307\n"" 172 218 252 142 339\n"" 173 185 251 77 340\n"" 174 102 200 197 219\n"" 175 49 189 185 340\n"" 176 213 348 286 349\n"" 177 133 286 285 348\n"" 178 65 197 126 272\n"" 179 187 189 49 340\n"" 180 213 285 53 378\n"" 181 63 194 65 200\n"" 182 131 279 85 387\n"" 183 120 169 148 323\n"" 184 197 200 126 272\n"" 185 46 166 72 179\n"" 186 15 248 98 273\n"" 187 98 114 24 373\n"" 188 46 180 100 266\n"" 189 22 231 140 374\n"" 190 171 335 77 382\n"" 191 27 106 62 107\n"" 192 255 264 159 391\n"" 193 132 325 322 379\n"" 194 240 323 313 377\n"" 195 155 160 93 301\n"" 196 221 299 170 327\n"" 197 158 160 95 161\n"" 198 79 80 30 189\n"" 199 178 365 311 391\n"" 200 16 285 133 286\n"" 201 249 255 171 365\n"" 202 188 270 73 323\n"" 203 162 165 61 249\n"" 204 107 126 65 194\n"" 205 155 156 93 160\n"" 206 219 303 102 356\n"" 207 259 330 132 351\n"" 208 224 293 141 300\n"" 209 77 271 170 289\n"" 210 231 252 140 299\n"" 211 147 240 148 313\n"" 212 152 370 153 395\n"" 213 154 246 35 247\n"" 214 291 354 212 387\n"" 215 211 348 280 349\n"" 216 144 234 39 307\n"" 217 212 292 33 381\n"" 218 133 348 83 349\n"" 219 119 337 270 338\n"" 220 120 188 73 323\n"" 221 211 280 209 349\n"" 222 209 211 333 347\n"" 223 251 325 108 379\n"" 224 236 238 146 309\n"" 225 274 329 110 342\n"" 226 39 305 144 307\n"" 227 144 305 89 307\n"" 228 96 249 248 375\n"" 229 113 178 177 392\n"" 230 91 294 224 295\n"" 231 94 160 42 161\n"" 232 165 171 21 326\n"" 233 170 324 251 379\n"" 234 211 347 209 350\n"" 235 116 179 115 398\n"" 236 214 263 31 384\n"" 237 70 117 71 0\n"" 238 43 195 96 202\n"" 239 90 235 40 236\n"" 240 134 136 37 287\n"" 241 67 253 159 357\n"" 242 33 328 258 381\n"" 243 71 116 115 180\n"" 244 55 241 134 302\n"" 245 155 301 24 398\n"" 246 275 345 205 363\n"" 247 52 209 175 280\n"" 248 287 302 241 355\n"" 249 79 185 48 269\n"" 250 45 181 116 230\n"" 251 68 182 24 373\n"" 252 106 126 66 195\n"" 253 170 299 253 327\n"" 254 228 298 245 358\n"" 255 275 357 67 390\n"" 256 126 195 77 196\n"" 257 176 275 67 343\n"" 258 17 363 232 367\n"" 259 248 249 116 375\n"" 260 251 324 250 325\n"" 261 122 251 185 340\n"" 262 238 311 309 326\n"" 263 157 160 155 301\n"" 264 60 181 99 265\n"" 265 98 248 114 373\n"" 266 34 261 209 347\n"" 267 132 330 212 351\n"" 268 245 274 141 358\n"" 269 190 191 19 271\n"" 270 236 238 57 313\n"" 271 105 104 103 194\n"" 272 94 246 161 247\n"" 273 35 246 59 247\n"" 274 140 319 267 374\n"" 275 212 281 33 291\n"" 276 117 71 46 179\n"" 277 70 117 72 179\n"" 278 159 253 228 264\n"" 279 80 185 49 189\n"" 280 209 333 4 210\n"" 281 2 128 127 206\n"" 282 100 164 46 166\n"" 283 74 76 7 123\n"" 284 80 187 75 189\n"" 285 103 194 63 201\n"" 286 171 326 249 365\n"" 287 136 6 137 37\n"" 288 216 291 85 354\n"" 289 47 120 13 121\n"" 290 101 288 54 356\n"" 291 130 263 111 343\n"" 292 168 200 101 201\n"" 293 68 143 41 229\n"" 294 282 291 135 354\n"" 295 49 191 190 340\n"" 296 184 189 75 270\n"" 297 202 272 126 289\n"" 298 218 356 339 383\n"" 299 352 388 215 399\n"" 300 124 192 125 269\n"" 301 70 117 0 72\n"" 302 136 218 138 287\n"" 303 108 255 171 327\n"" 304 223 293 153 396\n"" 305 25 156 155 157\n"" 306 115 116 61 180\n"" 307 320 321 250 338\n"" 308 60 166 99 181\n"" 309 228 245 141 358\n"" 310 127 346 203 385\n"" 311 96 249 171 382\n"" 312 219 272 140 289\n"" 313 112 275 204 363\n"" 314 126 197 65 200\n"" 315 270 337 250 338\n"" 316 42 158 95 161\n"" 317 183 187 118 270\n"" 318 212 283 132 284\n"" 319 204 275 205 363\n"" 320 165 180 61 249\n"" 321 67 275 203 332\n"" 322 14 185 80 269\n"" 323 224 296 91 316\n"" 324 209 261 175 280\n"" 325 290 339 219 383\n"" 326 193 269 48 335\n"" 327 106 195 43 202\n"" 328 176 357 275 363\n"" 329 77 251 170 271\n"" 330 44 267 220 272\n"" 331 75 189 187 270\n"" 332 65 194 126 200\n"" 333 68 267 182 374\n"" 334 125 195 66 198\n"" 335 17 204 50 205\n"" 336 250 325 322 384\n"" 337 66 195 126 198\n"" 338 79 185 80 189\n"" 339 159 298 67 357\n"" 340 218 302 88 303\n"" 341 78 80 79 269\n"" 342 77 221 170 327\n"" 343 90 147 13 148\n"" 344 319 373 230 375\n"" 345 126 200 194 201\n"" 346 143 161 41 296\n"" 347 297 357 345 390\n"" 348 126 195 106 202\n"" 349 64 196 124 199\n"" 350 209 333 211 4\n"" 351 44 202 107 273\n"" 352 195 196 125 335\n"" 353 284 353 84 399\n"" 354 125 196 195 198\n"" 355 64 126 103 201\n"" 356 63 200 168 201\n"" 357 278 279 207 284\n"" 358 175 209 34 261\n"" 359 224 294 91 361\n"" 360 274 298 225 390\n"" 361 258 329 172 381\n"" 362 293 316 153 371\n"" 363 37 139 134 287\n"" 364 200 219 126 272\n"" 365 110 277 257 332\n"" 366 158 225 42 245\n"" 367 191 271 190 340\n"" 368 6 86 136 217\n"" 369 96 163 43 202\n"" 370 41 246 154 296\n"" 371 2 127 50 206\n"" 372 120 240 188 323\n"" 373 171 268 77 335\n"" 374 257 277 276 332\n"" 375 308 313 238 393\n"" 376 98 248 202 273\n"" 377 167 303 55 356\n"" 378 136 137 6 217\n"" 379 88 283 252 380\n"" 380 188 323 240 377\n"" 381 140 272 267 319\n"" 382 121 188 120 240\n"" 383 323 368 313 377\n"" 384 172 258 110 329\n"" 385 192 198 28 199\n"" 386 284 354 85 387\n"" 387 155 157 156 160\n"" 388 143 230 45 299\n"" 389 173 341 20 372\n"" 390 248 319 96 375\n"" 391 242 241 151 355\n"" 392 30 80 75 189\n"" 393 51 173 127 203\n"" 394 81 256 8 257\n"" 395 187 270 122 340\n"" 396 38 241 242 355\n"" 397 141 293 245 300\n"" 398 93 156 11 160\n"" 399 88 252 218 303\n"" 400 29 123 75 184\n"" 401 159 334 297 357\n"" 402 206 344 130 346\n"" 403 185 269 125 335\n"" 404 151 294 10 295\n"" 405 105 66 27 194\n"" 406 150 302 55 362\n"" 407 261 280 209 347\n"" 408 312 367 145 393\n"" 409 194 200 63 201\n"" 410 176 275 112 363\n"" 411 334 357 159 364\n"" 412 231 302 88 361\n"" 413 57 238 236 309\n"" 414 88 300 292 380\n"" 415 192 124 125 199\n"" 416 148 240 120 323\n"" 417 126 194 103 201\n"" 418 259 331 82 351\n"" 419 119 184 183 270\n"" 420 150 241 55 302\n"" 421 126 272 219 289\n"" 422 230 301 116 373\n"" 423 123 188 74 189\n"" 424 74 186 79 189\n"" 425 92 369 243 370\n"" 426 131 280 261 350\n"" 427 143 299 228 300\n"" 428 220 303 231 362\n"" 429 277 332 203 346\n"" 430 256 257 81 276\n"" 431 154 314 36 369\n"" 432 100 180 165 249\n"" 433 149 294 91 295\n"" 434 274 329 141 358\n"" 435 126 201 64 219\n"" 436 64 201 101 219\n"" 437 207 211 53 350\n"" 438 283 330 132 379\n"" 439 243 369 1 370\n"" 440 24 373 114 398\n"" 441 143 230 161 318\n"" 442 161 296 245 371\n"" 443 110 257 172 329\n"" 444 96 162 43 163\n"" 445 248 373 319 375\n"" 446 171 221 77 327\n"" 447 21 254 171 336\n"" 448 306 5 239 305\n"" 449 197 220 102 272\n"" 450 82 281 172 351\n"" 451 113 146 39 234\n"" 452 143 229 68 374\n"" 453 68 93 41 161\n"" 454 172 351 281 381\n"" 455 112 204 17 363\n"" 456 124 191 185 196\n"" 457 215 216 9 278\n"" 458 19 383 353 389\n"" 459 185 189 122 340\n"" 460 137 38 287 134\n"" 461 122 270 250 324\n"" 462 126 202 107 272\n"" 463 70 71 117 179\n"" 464 84 227 226 353\n"" 465 109 173 390 203\n"" 466 13 121 120 240\n"" 467 53 285 213 348\n"" 468 228 358 300 380\n"" 469 14 80 78 269\n"" 470 55 302 218 303\n"" 471 285 286 213 348\n"" 472 107 202 106 273\n"" 473 307 367 366 393\n"" 474 147 148 90 235\n"" 475 94 161 42 247\n"" 476 276 332 277 346\n"" 477 141 293 223 397\n"" 478 51 203 127 346\n"" 479 22 229 150 231\n"" 480 163 202 96 248\n"" 481 48 269 185 335\n"" 482 162 163 96 248\n"" 483 141 274 245 397\n"" 484 115 163 61 248\n"" 485 147 236 57 313\n"" 486 158 181 60 265\n"" 487 311 365 364 391\n"" 488 193 195 125 335\n"" 489 125 185 124 269\n"" 490 224 296 245 300\n"" 491 49 185 124 191\n"" 492 132 280 213 322\n"" 493 96 202 195 221\n"" 494 233 357 334 364\n"" 495 99 166 164 266\n"" 496 245 293 141 397\n"" 497 36 244 149 316\n"" 498 74 79 30 189\n"" 499 30 75 74 189\n"" 500 12 178 99 392\n"" 501 322 325 259 384\n"" 502 195 196 126 198\n"" 503 57 313 238 326\n"" 504 48 268 186 336\n"" 505 91 296 154 316\n"" 506 14 192 124 269\n"" 507 259 332 111 343\n"" 508 238 311 255 364\n"" 509 45 230 95 264\n"" 510 140 252 221 299\n"" 511 176 262 112 263\n"" 512 32 211 207 350\n"" 513 261 376 351 82\n"" 514 19 227 190 389\n"" 515 2 129 128 206\n"" 516 102 220 167 303\n"" 517 181 249 116 266\n"" 518 170 271 251 324\n"" 519 186 188 121 240\n"" 520 213 321 286 338\n"" 521 124 185 14 269\n"" 522 91 295 224 316\n"" 523 143 299 231 374\n"" 524 159 364 255 391\n"" 525 310 334 69 364\n"" 526 170 283 271 379\n"" 527 229 231 143 361\n"" 528 241 287 134 302\n"" 529 70 72 25 179\n"" 530 72 157 25 179\n"" 531 26 71 70 179\n"" 532 70 114 26 179\n"" 533 287 388 282 399\n"" 534 68 229 22 374\n"" 535 61 180 116 249\n"" 536 115 116 71 179\n"" 537 143 296 229 361\n"" 538 142 354 282 399\n"" 539 25 155 70 179\n"" 540 139 288 167 356\n"" 541 114 115 26 179\n"" 542 26 115 71 179\n"" 543 116 180 179 266\n"" 544 164 166 100 266\n"" 545 100 166 46 266\n"" 546 171 255 221 327\n"" 547 132 330 325 379\n"" 548 140 289 252 339\n"" 549 24 182 98 373\n"" 550 180 249 100 266\n"" 551 320 321 214 322\n"" 552 213 285 270 338\n"" 553 214 321 52 322\n"" 554 122 188 186 268\n"" 555 271 289 196 339\n"" 556 108 251 250 325\n"" 557 153 293 244 316\n"" 558 43 193 162 382\n"" 559 80 124 49 185\n"" 560 159 67 358 253\n"" 561 142 282 212 283\n"" 562 14 124 80 185\n"" 563 110 174 173 341\n"" 564 187 189 122 270\n"" 565 252 299 88 380\n"" 566 55 218 139 356\n"" 567 227 378 190 389\n"" 568 33 292 222 328\n"" 569 47 121 74 188\n"" 570 74 123 47 188\n"" 571 120 121 47 188\n"" 572 47 123 120 188\n"" 573 55 303 218 356\n"" 574 167 288 18 356\n"" 575 58 224 151 295\n"" 576 18 167 87 288\n"" 577 116 230 181 301\n"" 578 161 246 41 296\n"" 579 91 244 149 295\n"" 580 33 281 212 381\n"" 581 23 225 158 245\n"" 582 79 186 48 189\n"" 583 75 184 123 189\n"" 584 74 75 76 189\n"" 585 75 123 76 189\n"" 586 76 123 74 189\n"" 587 67 357 298 390\n"" 588 124 185 125 196\n"" 589 186 240 121 336\n"" 590 64 191 124 196\n"" 591 209 210 34 347\n"" 592 80 185 79 269\n"" 593 63 103 104 194\n"" 594 27 107 65 194\n"" 595 9 278 216 279\n"" 596 66 126 106 194\n"" 597 104 27 65 194\n"" 598 66 106 27 194\n"" 599 106 107 27 194\n"" 600 27 3 105 194\n"" 601 105 3 104 194\n"" 602 104 3 27 194\n"" 603 77 335 195 382\n"" 604 136 217 86 287\n"" 605 226 290 54 383\n"" 606 290 356 54 383\n"" 607 218 339 142 383\n"" 608 21 268 193 336\n"" 609 193 268 48 336\n"" 610 171 268 21 336\n"" 611 103 194 126 199\n"" 612 28 198 194 199\n"" 613 125 198 192 199\n"" 614 28 194 103 199\n"" 615 106 163 62 273\n"" 616 98 202 44 273\n"" 617 221 252 170 299\n"" 618 141 300 245 318\n"" 619 185 196 77 335\n"" 620 244 295 91 316\n"" 621 62 163 15 273\n"" 622 231 299 143 300\n"" 623 317 371 245 397\n"" 624 126 196 64 199\n"" 625 103 126 64 199\n"" 626 93 94 59 246\n"" 627 127 344 206 346\n"" 628 224 292 222 360\n"" 629 225 359 274 390\n"" 630 221 319 45 375\n"" 631 25 157 155 301\n"" 632 19 271 191 290\n"" 633 110 341 274 342\n"" 634 163 248 15 273\n"" 635 132 283 212 330\n"" 636 119 321 320 338\n"" 637 186 189 122 268\n"" 638 106 194 126 202\n"" 639 126 194 107 202\n"" 640 107 194 106 202\n"" 641 141 358 329 381\n"" 642 88 302 282 360\n"" 643 263 275 176 343\n"" 644 173 203 110 274\n"" 645 260 175 34 261\n"" 646 250 270 122 323\n"" 647 21 165 162 249\n"" 648 193 335 268 382\n"" 649 130 332 275 343\n"" 650 204 275 130 344\n"" 651 51 110 174 203\n"" 652 110 173 174 203\n"" 653 174 173 51 203\n"" 654 70 155 24 398\n"" 655 177 113 39 234\n"" 656 218 252 88 282\n"" 657 352 383 54 388\n"" 658 112 263 204 275\n"" 659 54 352 226 383\n"" 660 134 287 241 355\n"" 661 238 307 146 309\n"" 662 224 295 58 316\n"" 663 325 343 259 384\n"" 664 259 329 67 330\n"" 665 88 292 224 360\n"" 666 9 215 86 216\n"" 667 221 299 45 319\n"" 668 245 296 161 318\n"" 669 136 134 137 287\n"" 670 83 211 209 349\n"" 671 132 324 283 379\n"" 672 84 284 207 353\n"" 673 138 139 37 287\n"" 674 140 252 231 303\n"" 675 219 289 140 339\n"" 676 181 230 45 264\n"" 677 228 300 299 380\n"" 678 85 279 216 354\n"" 679 169 320 250 323\n"" 680 68 230 143 374\n"" 681 207 227 84 353\n"" 682 240 313 57 326\n"" 683 49 190 187 340\n"" 684 286 348 133 349\n"" 685 52 280 213 349\n"" 686 263 343 176 384\n"" 687 51 277 203 346\n"" 688 220 267 140 272\n"" 689 137 217 136 287\n"" 690 203 329 274 390\n"" 691 31 320 250 368\n"" 692 224 316 293 371\n"" 693 231 252 88 303\n"" 694 252 271 170 283\n"" 695 253 358 228 380\n"" 696 256 276 130 332\n"" 697 19 353 227 389\n"" 698 219 339 303 356\n"" 699 170 252 221 289\n"" 700 142 271 252 283\n"" 701 209 347 280 350\n"" 702 142 252 88 283\n"" 703 251 324 271 340\n"" 704 95 264 181 391\n"" 705 171 251 77 268\n"" 706 98 319 248 373\n"" 707 331 351 259 376\n"" 708 41 154 91 296\n"" 709 10 241 151 242\n"" 710 330 380 292 381\n"" 711 132 284 283 353\n"" 712 140 272 221 289\n"" 713 126 196 77 289\n"" 714 152 371 317 395\n"" 715 36 149 91 316\n"" 716 108 253 176 308\n"" 717 255 365 264 391\n"" 718 202 248 163 273\n"" 719 224 300 88 361\n"" 720 65 126 107 272\n"" 721 67 159 358 298\n"" 722 88 300 231 361\n"" 723 153 223 58 293\n"" 724 146 238 236 307\n"" 725 202 248 98 319\n"" 726 141 328 292 381\n"" 727 42 161 95 245\n"" 728 176 253 108 325\n"" 729 10 294 149 295\n"" 730 155 179 25 301\n"" 731 68 161 143 230\n"" 732 264 365 181 391\n"" 733 225 274 245 298\n"" 734 225 245 23 298\n"" 735 41 161 93 246\n"" 736 97 163 115 248\n"" 737 93 161 94 246\n"" 738 45 255 96 375\n"" 739 212 291 282 354\n"" 740 148 313 323 169\n"" 741 224 292 88 300\n"" 742 142 283 212 354\n"" 743 61 162 96 248\n"" 744 97 114 98 248\n"" 745 185 189 48 268\n"" 746 205 345 275 385\n"" 747 48 268 193 335\n"" 748 24 155 68 301\n"" 749 60 160 157 301\n"" 750 159 357 308 364\n"" 751 297 345 109 390\n"" 752 61 163 162 248\n"" 753 61 116 115 248\n"" 754 230 299 143 374\n"" 755 140 267 22 374\n"" 756 102 303 167 356\n"" 757 134 287 218 302\n"" 758 218 282 88 302\n"" 759 93 161 68 230\n"" 760 357 363 308 364\n"" 761 224 295 294 361\n"" 762 153 244 36 316\n"" 763 303 339 218 356\n"" 764 294 302 150 361\n"" 765 153 371 152 395\n"" 766 57 326 254 336\n"" 767 48 189 186 268\n"" 768 238 308 255 326\n"" 769 214 322 52 376\n"" 770 132 322 259 376\n"" 771 111 331 259 376\n"" 772 121 240 147 336\n"" 773 253 379 330 380\n"" 774 223 274 141 397\n"" 775 176 308 262 313\n"" 776 31 262 176 263\n"" 777 334 364 159 391\n"" 778 255 311 238 326\n"" 779 110 274 203 329\n"" 780 315 369 154 370\n"" 781 146 234 113 311\n"" 782 363 366 232 367\n"" 783 159 298 228 358\n"" 784 292 328 33 381\n"" 785 68 301 230 373\n"" 786 271 340 324 389\n"" 787 176 263 112 275\n"" 788 1 369 315 370\n"" 789 159 308 255 364\n"" 790 253 255 159 308\n"" 791 262 312 56 313\n"" 792 19 290 226 383\n"" 793 84 352 215 399\n"" 794 23 158 95 245\n"" 795 145 235 56 238\n"" 796 132 322 213 324\n"" 797 77 268 185 335\n"" 798 175 214 52 376\n"" 799 108 255 253 308\n"" 800 56 238 235 313\n"" 801 111 175 8 331\n"" 802 52 286 213 321\n"" 803 149 244 91 316\n"" 804 237 5 306 305\n"" 805 165 326 113 365\n"" 806 58 293 224 316\n"" 807 204 263 130 275\n"" 808 222 292 58 328\n"" 809 175 261 260 331\n"" 810 45 253 228 299\n"" 811 250 321 320 322\n"" 812 102 272 220 303\n"" 813 182 267 98 319\n"" 814 170 379 253 380\n"" 815 151 241 10 294\n"" 816 52 321 213 322\n"" 817 215 278 84 399\n"" 818 282 354 216 399\n"" 819 22 267 68 374\n"" 820 230 373 319 374\n"" 821 97 98 15 248\n"" 822 274 341 223 342\n"" 823 15 163 97 248\n"" 824 153 316 36 369\n"" 825 132 351 212 387\n"" 826 185 251 122 268\n"" 827 122 189 185 268\n"" 828 250 324 270 338\n"" 829 233 345 297 357\n"" 830 129 277 128 346\n"" 831 165 249 171 326\n"" 832 122 268 251 377\n"" 833 259 329 172 332\n"" 834 255 364 311 365\n"" 835 140 220 22 267\n"" 836 142 282 218 388\n"" 837 108 326 313 377\n"" 838 221 252 140 289\n"" 839 77 196 195 335\n"" 840 251 271 77 340\n"" 841 250 251 122 324\n"" 842 238 309 57 326\n"" 843 227 386 378 389\n"" 844 171 255 108 326\n"" 845 256 259 111 331\n"" 846 178 365 266 392\n"" 847 178 311 69 391\n"" 848 102 219 197 272\n"" 849 172 259 257 331\n"" 850 258 342 329 381\n"" 851 143 296 224 300\n"" 852 88 299 231 300\n"" 853 182 319 98 373\n"" 854 44 220 197 272\n"" 855 107 202 44 272\n"" 856 333 210 209 347\n"" 857 299 300 88 380\n"" 858 67 253 176 325\n"" 859 212 354 284 387\n"" 860 203 110 332 277\n"" 861 171 251 108 327\n"" 862 96 221 171 255\n"" 863 45 221 96 255\n"" 864 58 293 223 328\n"" 865 148 235 147 313\n"" 866 36 316 154 369\n"" 867 92 395 394 396\n"" 868 132 351 280 376\n"" 869 253 299 45 327\n"" 870 233 334 310 364\n"" 871 195 335 193 382\n"" 872 193 268 21 382\n"" 873 223 293 141 328\n"" 874 292 293 58 328\n"" 875 38 137 287 217\n"" 876 315 1 314 369\n"" 877 141 274 223 342\n"" 878 188 268 122 377\n"" 879 141 293 292 328\n"" 880 235 236 147 313\n"" 881 235 238 236 313\n"" 882 57 240 147 313\n"" 883 88 282 212 292\n"" 884 23 297 159 334\n"" 885 259 325 132 330\n"" 886 23 334 159 391\n"" 887 283 324 132 389\n"" 888 205 345 304 363\n"" 889 253 325 67 330\n"" 890 43 162 96 382\n"" 891 257 331 259 332\n"" 892 256 331 257 332\n"" 893 172 329 257 332\n"" 894 54 356 218 383\n"" 895 259 331 256 332\n"" 896 208 131 32 350\n"" 897 280 348 213 349\n"" 898 118 270 213 285\n"" 899 16 270 118 285\n"" 900 253 308 159 357\n"" 901 81 276 257 277\n"" 902 228 253 45 264\n"" 903 31 262 169 368\n"" 904 262 313 169 368\n"" 905 108 313 308 368\n"" 906 159 255 253 264\n"" 907 253 255 45 264\n"" 908 95 181 158 265\n"" 909 45 264 255 365\n"" 910 113 311 178 392\n"" 911 177 178 12 392\n"" 912 100 365 165 392\n"" 913 369 370 92 395\n"" 914 72 179 166 266\n"" 915 150 294 241 302\n"" 916 134 218 55 302\n"" 917 166 179 71 266\n"" 918 179 180 71 266\n"" 919 46 166 71 266\n"" 920 71 180 46 266\n"" 921 308 364 363 393\n"" 922 238 313 312 393\n"" 923 238 364 308 393\n"" 924 366 367 363 393\n"" 925 218 287 282 302\n"" 926 72 166 60 266\n"" 927 166 181 60 266\n"" 928 116 373 301 398\n"" 929 225 372 317 397\n"" 930 226 388 352 399\n"" 931 145 238 56 312\n"" 932 176 325 108 368\n"" 933 152 35 154 370\n"" 934 108 327 251 379\n"" 935 135 291 216 354\n"" 936 283 324 271 379\n"" 937 213 324 322 338\n"" 938 284 351 132 387\n"" 939 321 322 250 338\n"" 940 73 323 270 337\n"" 941 270 323 250 337\n"" 942 286 321 119 338\n"" 943 250 323 320 337\n"" 944 320 323 73 337\n"" 945 213 322 321 338\n"" 946 122 189 188 270\n"" 947 183 184 29 270\n"" 948 29 187 183 270\n"" 949 16 183 118 270\n"" 950 119 183 16 270\n"" 951 252 271 142 339\n"" 952 196 289 219 339\n"" 953 69 311 310 364\n"" 954 185 191 49 340\n"" 955 29 184 75 270\n"" 956 75 187 29 270\n"" 957 184 188 123 270\n"" 958 188 189 123 270\n"" 959 123 189 184 270\n"" 960 255 308 108 326\n"" 961 108 308 238 326\n"" 962 245 298 274 358\n"" 963 111 332 256 343\n"" 964 53 227 207 386\n"" 965 58 244 153 293\n"" 966 91 296 224 361\n"" 967 268 336 171 377\n"" 968 162 249 96 382\n"" 969 141 329 274 342\n"" 970 259 322 132 325\n"" 971 213 348 280 386\n"" 972 130 275 263 343\n"" 973 161 230 95 318\n"" 974 95 230 45 318\n"" 975 228 298 95 318\n"" 976 302 303 55 362\n"" 977 45 230 143 318\n"" 978 95 245 161 318\n"" 979 77 251 171 327\n"" 980 233 363 357 364\n"" 981 213 280 132 386\n"" 982 173 109 390 359\n"" 983 159 297 23 298\n"" 984 213 286 52 349\n"" 985 108 251 171 377\n"" 986 209 280 52 349\n"" 987 252 289 271 339\n"" 988 84 278 207 284\n"" 989 142 252 218 282\n"" 990 88 252 142 282\n"" 991 190 271 19 389\n"" 992 257 276 256 332\n"" 993 251 268 171 377\n"" 994 122 270 188 323\n"" 995 138 218 139 287\n"" 996 226 383 352 388\n"" 997 73 169 120 323\n"" 998 73 320 169 323\n"" 999 324 325 251 379\n"" 1000 364 365 255 391\n"" 1001 228 300 141 318\n"" 1002 224 296 143 361\n"" 1003 87 167 139 288\n"" 1004 297 334 233 357\n"" 1005 85 284 279 354\n"" 1006 122 324 251 340\n"" 1007 170 221 77 289\n"" 1008 170 271 252 289\n"" 1009 77 195 126 289\n"" 1010 167 220 55 303\n"" 1011 139 218 134 287\n"" 1012 216 217 135 287\n"" 1013 135 282 216 287\n"" 1014 245 300 296 318\n"" 1015 58 292 224 293\n"" 1016 171 249 21 382\n"" 1017 172 259 82 351\n"" 1018 131 284 279 387\n"" 1019 134 241 38 355\n"" 1020 18 288 101 356\n"" 1021 38 287 134 355\n"" 1022 139 167 55 356\n"" 1023 139 218 138 356\n"" 1024 142 383 271 389\n"" 1025 216 282 135 354\n"" 1026 353 383 142 389\n"" 1027 271 283 142 389\n"" 1028 131 350 284 387\n"" 1029 274 358 298 390\n"" 1030 86 216 215 287\n"" 1031 86 217 216 287\n"" 1032 195 202 126 289\n"" 1033 195 221 202 289\n"" 1034 77 221 195 289\n"" 1035 140 272 219 303\n"" 1036 33 291 222 292\n"" 1037 212 291 33 292\n"" 1038 229 296 91 361\n"" 1039 140 231 220 303\n"" 1040 145 307 238 393\n"" 1041 222 224 58 292\n"" 1042 270 324 122 340\n"" 1043 96 319 221 375\n"" 1044 216 278 215 399\n"" 1045 274 341 173 372\n"" 1046 88 252 231 299\n"" 1047 216 279 278 399\n"" 1048 115 248 116 398\n"" 1049 274 359 225 372\n"" 1050 153 395 92 396\n"" 1051 245 298 228 318\n"" 1052 95 298 245 318\n"" 1053 143 300 228 318\n"" 1054 231 303 302 362\n"" 1055 91 229 41 296\n"" 1056 293 396 223 397\n"" 1057 249 255 45 375\n"" 1058 42 245 225 317\n"" 1059 304 345 233 363\n"" 1060 55 303 220 362\n"" 1061 231 302 150 362\n"" 1062 216 354 279 399\n"" 1063 361 224 151 360\n"" 1064 282 388 142 399\n"" 1065 96 255 249 375\n"" 1066 151 222 135 360\n"" 1067 222 292 291 360\n"" 1068 159 264 23 391\n"" 1069 127 206 128 346\n"" 1070 95 265 23 391\n"" 1071 69 334 265 391\n"" 1072 159 264 228 298\n"" 1073 228 264 95 298\n"" 1074 23 245 95 298\n"" 1075 282 292 88 360\n"" 1076 67 330 329 358\n"" 1077 23 264 159 298\n"" 1078 95 264 23 298\n"" 1079 229 231 22 374\n"" 1080 60 157 72 301\n"" 1081 157 179 72 301\n"" 1082 116 266 179 301\n"" 1083 95 160 60 301\n"" 1084 60 266 181 301\n"" 1085 181 266 116 301\n"" 1086 60 181 95 301\n"" 1087 181 230 95 301\n"" 1088 160 161 93 301\n"" 1089 161 230 93 301\n"" 1090 68 155 93 301\n"" 1091 93 230 68 301\n"" 1092 179 266 72 301\n"" 1093 72 266 60 301\n"" 1094 95 161 160 301\n"" 1095 95 230 161 301\n"" 1096 308 357 176 363\n"" 1097 255 326 171 365\n"" 1098 91 294 150 361\n"" 1099 294 360 302 361\n"" 1100 231 300 143 361\n"" 1101 88 302 231 303\n"" 1102 245 371 293 397\n"" 1103 146 236 40 307\n"" 1104 236 238 235 307\n"" 1105 235 238 145 307\n"" 1106 110 203 332 329\n"" 1107 177 234 178 311\n"" 1108 113 234 177 311\n"" 1109 169 262 56 313\n"" 1110 148 169 56 313\n"" 1111 89 237 145 307\n"" 1112 89 305 237 307\n"" 1113 306 40 145 307\n"" 1114 146 40 306 307\n"" 1115 237 306 145 307\n"" 1116 237 305 306 307\n"" 1117 306 239 146 307\n"" 1118 305 239 306 307\n"" 1119 146 239 39 307\n"" 1120 239 305 39 307\n"" 1121 40 235 145 307\n"" 1122 40 236 235 307\n"" 1123 177 178 113 311\n"" 1124 253 255 108 327\n"" 1125 307 309 238 311\n"" 1126 178 234 69 311\n"" 1127 170 251 77 327\n"" 1128 271 324 170 379\n"" 1129 146 307 234 311\n"" 1130 181 266 99 365\n"" 1131 69 234 144 311\n"" 1132 234 307 144 311\n"" 1133 228 299 253 380\n"" 1134 100 266 249 365\n"" 1135 178 266 99 392\n"" 1136 99 266 178 365\n"" 1137 113 365 311 392\n"" 1138 99 266 164 392\n"" 1139 108 308 176 368\n"" 1140 313 323 169 368\n"" 1141 45 255 249 365\n"" 1142 232 363 304 366\n"" 1143 308 313 176 368\n"" 1144 146 309 307 311\n"" 1145 113 309 146 311\n"" 1146 52 280 175 376\n"" 1147 144 310 69 311\n"" 1148 115 179 114 398\n"" 1149 114 248 115 398\n"" 1150 176 262 31 368\n"" 1151 212 284 132 387\n"" 1152 89 366 144 367\n"" 1153 153 370 369 395\n"" 1154 153 369 92 395\n"" 1155 301 373 24 398\n"" 1156 53 350 348 386\n"" 1157 108 325 250 368\n"" 1158 371 395 153 396\n"" 1159 24 301 68 373\n"" 1160 70 179 155 398\n"" 1161 161 296 143 318\n"" 1162 95 264 228 318\n"" 1163 228 264 45 318\n"" 1164 45 264 95 318\n"" 1165 45 299 228 318\n"" 1166 228 299 143 318\n"" 1167 143 299 45 318\n"" 1168 68 373 230 374\n"" 1169 267 319 182 374\n"" 1170 259 351 132 376\n"" 1171 202 272 221 319\n"" 1172 221 272 140 319\n"" 1173 202 221 96 319\n"" 1174 96 248 202 319\n"" 1175 116 373 248 375\n"" 1176 44 202 98 319\n"" 1177 98 267 44 319\n"" 1178 267 272 44 319\n"" 1179 44 272 202 319\n"" 1180 230 373 116 375\n"" 1181 143 231 229 374\n"" 1182 116 249 181 375\n"" 1183 45 319 230 375\n"" 1184 116 181 45 375\n"" 1185 175 331 111 376\n"" 1186 280 322 132 376\n"" 1187 171 336 326 377\n"" 1188 261 347 131 350\n"" 1189 131 347 32 350\n"" 1190 128 206 129 346\n"" 1191 238 313 108 326\n"" 1192 171 254 21 326\n"" 1193 329 358 330 381\n"" 1194 251 327 170 379\n"" 1195 325 330 253 379\n"" 1196 172 281 33 381\n"" 1197 212 282 142 354\n"" 1198 110 329 258 342\n"" 1199 205 344 50 385\n"" 1200 376 261 351 280\n"" 1201 173 174 20 341\n"" 1202 322 324 132 379\n"" 1203 322 325 324 379\n"" 1204 298 358 67 390\n"" 1205 67 329 203 390\n"" 1206 21 254 165 326\n"" 1207 184 270 119 337\n"" 1208 142 284 283 354\n"" 1209 73 270 184 337\n"" 1210 218 303 252 339\n"" 1211 250 323 108 368\n"" 1212 245 274 225 397\n"" 1213 165 254 113 326\n"" 1214 275 344 205 385\n"" 1215 254 309 113 326\n"" 1216 309 311 113 326\n"" 1217 96 221 77 382\n"" 1218 249 326 165 365\n"" 1219 125 196 185 335\n"" 1220 224 245 371 293\n"" 1221 203 329 67 332\n"" 1222 50 206 127 344\n"" 1223 162 193 21 382\n"" 1224 8 256 111 331\n"" 1225 82 259 172 331\n"" 1226 245 224 371 296\n"" 1227 260 8 175 331\n"" 1228 250 368 325 384\n"" 1229 219 356 290 383\n"" 1230 96 195 43 382\n"" 1231 271 339 290 383\n"" 1232 212 330 292 381\n"" 1233 265 334 23 391\n"" 1234 329 330 259 381\n"" 1235 329 342 141 381\n"" 1236 77 221 171 382\n"" 1237 43 195 193 382\n"" 1238 292 380 141 381\n"" 1239 141 380 358 381\n"" 1240 111 259 256 332\n"" 1241 135 355 151 360\n"" 1242 130 344 275 346\n"" 1243 206 276 129 346\n"" 1244 207 350 53 386\n"" 1245 128 277 51 346\n"" 1246 51 127 128 346\n"" 1247 353 386 227 389\n"" 1248 271 290 19 383\n"" 1249 339 356 219 383\n"" 1250 322 324 250 338\n"" 1251 250 337 320 338\n"" 1252 320 337 119 338\n"" 1253 119 270 16 338\n"" 1254 270 285 16 338\n"" 1255 213 286 285 338\n"" 1256 285 286 16 338\n"" 1257 16 286 119 338\n"" 1258 343 376 259 384\n"" 1259 250 320 31 384\n"" 1260 252 303 140 339\n"" 1261 140 303 219 339\n"" 1262 191 271 196 339\n"" 1263 191 290 271 339\n"" 1264 196 290 191 339\n"" 1265 196 219 64 339\n"" 1266 219 290 64 339\n"" 1267 64 290 196 339\n"" 1268 31 368 250 384\n"" 1269 31 263 176 384\n"" 1270 322 376 214 384\n"" 1271 185 196 191 340\n"" 1272 196 271 191 340\n"" 1273 203 275 67 390\n"" 1274 345 357 275 390\n"" 1275 77 196 185 340\n"" 1276 77 271 196 340\n"" 1277 187 190 118 340\n"" 1278 118 270 187 340\n"" 1279 256 332 130 343\n"" 1280 67 325 176 343\n"" 1281 67 329 259 343\n"" 1282 67 332 329 343\n"" 1283 329 332 259 343\n"" 1284 298 357 297 390\n"" 1285 227 353 207 386\n"" 1286 344 346 127 385\n"" 1287 203 346 275 385\n"" 1288 348 350 280 386\n"" 1289 67 330 325 343\n"" 1290 325 330 259 343\n"" 1291 259 330 67 343\n"" 1292 284 350 207 386\n"" 1293 280 350 284 386\n"" 1294 207 353 284 386\n"" 1295 130 276 206 346\n"" 1296 130 332 276 346\n"" 1297 129 276 81 346\n"" 1298 276 277 81 346\n"" 1299 81 277 129 346\n"" 1300 203 332 275 346\n"" 1301 275 332 130 346\n"" 1302 53 348 213 386\n"" 1303 284 353 132 386\n"" 1304 280 348 211 350\n"" 1305 211 348 53 350\n"" 1306 85 281 131 387\n"" 1307 207 284 279 350\n"" 1308 279 284 131 350\n"" 1309 207 279 208 350\n"" 1310 208 279 131 350\n"" 1311 333 211 32 350\n"" 1312 333 347 211 350\n"" 1313 32 347 333 350\n"" 1314 350 351 284 387\n"" 1315 85 291 281 387\n"" 1316 281 381 351 387\n"" 1317 240 336 186 377\n"" 1318 313 368 108 377\n"" 1319 21 268 171 382\n"" 1320 171 221 96 382\n"" 1321 268 335 171 382\n"" 1322 218 287 136 388\n"" 1323 54 383 218 388\n"" 1324 218 383 142 388\n"" 1325 142 383 226 388\n"" 1326 82 261 131 351\n"" 1327 261 280 131 351\n"" 1328 284 350 280 351\n"" 1329 280 350 131 351\n"" 1330 226 227 19 353\n"" 1331 85 354 291 387\n"" 1332 131 351 350 387\n"" 1333 150 231 229 361\n"" 1334 88 360 224 361\n"" 1335 279 284 85 387\n"" 1336 281 291 212 387\n"" 1337 135 287 217 355\n"" 1338 150 302 231 361\n"" 1339 217 287 38 355\n"" 1340 283 284 212 354\n"" 1341 132 353 283 389\n"" 1342 118 340 190 389\n"" 1343 190 340 271 389\n"" 1344 271 383 19 389\n"" 1345 138 288 139 356\n"" 1346 176 368 31 384\n"" 1347 102 167 168 356\n"" 1348 101 219 200 356\n"" 1349 200 219 102 356\n"" 1350 167 18 168 356\n"" 1351 168 18 101 356\n"" 1352 101 290 219 356\n"" 1353 54 290 101 356\n"" 1354 138 218 54 356\n"" 1355 54 288 138 356\n"" 1356 259 376 322 384\n"" 1357 325 368 176 384\n"" 1358 168 200 102 356\n"" 1359 101 200 168 356\n"" 1360 176 253 67 357\n"" 1361 176 308 253 357\n"" 1362 307 310 144 364\n"" 1363 266 365 100 392\n"" 1364 135 291 282 360\n"" 1365 222 291 135 360\n"" 1366 282 291 212 360\n"" 1367 291 292 212 360\n"" 1368 212 292 282 360\n"" 1369 58 222 151 360\n"" 1370 58 224 222 360\n"" 1371 151 224 58 360\n"" 1372 22 231 150 362\n"" 1373 220 231 22 362\n"" 1374 241 294 151 360\n"" 1375 241 302 294 360\n"" 1376 282 302 287 360\n"" 1377 302 355 287 360\n"" 1378 282 287 135 360\n"" 1379 287 355 135 360\n"" 1380 241 355 302 360\n"" 1381 151 355 241 360\n"" 1382 294 295 151 361\n"" 1383 151 360 294 361\n"" 1384 204 205 17 363\n"" 1385 205 304 17 363\n"" 1386 132 324 213 386\n"" 1387 17 304 232 363\n"" 1388 250 320 169 368\n"" 1389 113 326 311 365\n"" 1390 274 372 225 397\n"" 1391 238 312 145 393\n"" 1392 372 395 317 397\n"" 1393 144 307 89 367\n"" 1394 89 307 145 367\n"" 1395 181 264 45 365\n"" 1396 249 266 181 365\n"" 1397 311 326 255 365\n"" 1398 310 311 144 364\n"" 1399 144 311 307 364\n"" 1400 176 313 262 368\n"" 1401 169 320 31 368\n"" 1402 144 366 307 367\n"" 1403 169 323 250 368\n"" 1404 232 366 89 367\n"" 1405 112 363 17 367\n"" 1406 275 346 344 385\n"" 1407 317 395 371 397\n"" 1408 145 367 307 393\n"" 1409 363 364 233 393\n"" 1410 363 367 112 393\n"" 1411 164 266 100 392\n"" 1412 307 364 238 393\n"" 1413 112 367 312 393\n"" 1414 165 365 113 392\n"" 1415 311 365 178 392\n"" 1416 12 99 164 392\n"" 1417 173 359 274 372\n"" 1418 248 373 116 398\n"" 1419 245 317 42 371\n"" 1420 42 317 152 371\n"" 1421 161 245 42 371\n"" 1422 42 247 161 371\n"" 1423 161 247 246 371\n"" 1424 246 296 161 371\n"" 1425 154 296 246 371\n"" 1426 154 316 296 371\n"" 1427 246 247 154 371\n"" 1428 152 154 35 371\n"" 1429 154 247 35 371\n"" 1430 35 247 152 371\n"" 1431 152 370 154 371\n"" 1432 114 373 248 398\n"" 1433 179 301 155 398\n"" 1434 114 179 70 398\n"" 1435 24 114 70 398\n"" 1436 153 370 152 371\n"" 1437 154 369 316 371\n"" 1438 154 370 369 371\n"" 1439 316 369 153 371\n"" 1440 369 370 153 371\n"" 1441 215 388 287 399\n"" 1442 278 284 84 399\n"" 1443 231 299 140 374\n"" 1444 299 319 140 374\n"" 1445 45 299 230 374\n"" 1446 45 319 299 374\n"" 1447 230 319 45 374\n"" 1448 45 365 249 375\n"" 1449 249 365 181 375\n"" 1450 181 365 45 375\n"" 1451 311 364 69 391\n"" 1452 259 343 111 376\n"" 1453 111 214 175 376\n"" 1454 175 280 261 376\n"" 1455 224 361 151 295\n"" 1456 82 351 331 376\n"" 1457 127 203 109 385\n"" 1458 50 344 127 385\n"" 1459 82 331 261 376\n"" 1460 261 331 175 376\n"" 1461 250 251 108 377\n"" 1462 108 323 250 377\n"" 1463 122 251 250 377\n"" 1464 250 323 122 377\n"" 1465 188 240 186 377\n"" 1466 186 268 188 377\n"" 1467 240 326 57 377\n"" 1468 326 336 57 377\n"" 1469 57 336 240 377\n"" 1470 108 325 253 379\n"" 1471 170 327 253 379\n"" 1472 253 327 108 379\n"" 1473 252 283 170 380\n"" 1474 212 283 88 380\n"" 1475 212 330 283 380\n"" 1476 330 379 283 380\n"" 1477 283 379 170 380\n"" 1478 253 330 67 380\n"" 1479 330 358 67 380\n"" 1480 67 358 253 380\n"" 1481 21 249 162 382\n"" 1482 300 358 141 380\n"" 1483 292 300 141 380\n"" 1484 77 195 96 382\n"" 1485 88 292 212 380\n"" 1486 292 330 212 380\n"" 1487 330 351 259 381\n"" 1488 172 329 259 381\n"" 1489 259 351 172 381\n"" 1490 212 351 330 381\n"" 1491 141 342 328 381\n"" 1492 328 342 258 381\n"" 1493 142 353 226 383\n"" 1494 226 353 19 383\n"" 1495 142 339 271 383\n"" 1496 274 359 173 390\n"" 1497 225 298 297 390\n"" 1498 31 320 214 384\n"" 1499 250 322 320 384\n"" 1500 320 322 214 384\n"" 1501 111 376 343 384\n"" 1502 214 376 111 384\n"" 1503 111 263 214 384\n"" 1504 111 343 263 384\n"" 1505 53 378 227 386\n"" 1506 213 378 53 386\n"" 1507 203 385 275 390\n"" 1508 132 351 284 386\n"" 1509 284 351 280 386\n"" 1510 280 351 132 386\n"" 1511 109 385 203 390\n"" 1512 109 359 297 390\n"" 1513 351 381 212 387\n"" 1514 212 381 281 387\n"" 1515 131 281 82 387\n"" 1516 281 351 82 387\n"" 1517 82 351 131 387\n"" 1518 313 148 323 240\n"" 1519 136 287 215 388\n"" 1520 215 352 136 388\n"" 1521 136 352 54 388\n"" 1522 54 138 136 388\n"" 1523 54 218 138 388\n"" 1524 138 218 136 388\n"" 1525 283 353 142 389\n"" 1526 190 378 118 389\n"" 1527 324 340 270 389\n"" 1528 270 340 118 389\n"" 1529 378 386 213 389\n"" 1530 213 386 324 389\n"" 1531 132 386 353 389\n"" 1532 324 386 132 389\n"" 1533 118 378 213 389\n"" 1534 213 270 118 389\n"" 1535 213 324 270 389\n"" 1536 275 385 345 390\n"" 1537 345 385 109 390\n"" 1538 67 358 329 390\n"" 1539 329 358 274 390\n"" 1540 181 265 95 391\n"" 1541 99 265 181 391\n"" 1542 181 365 99 391\n"" 1543 178 265 99 391\n"" 1544 99 365 178 391\n"" 1545 233 364 310 393\n"" 1546 310 366 233 393\n"" 1547 304 363 233 393\n"" 1548 304 366 363 393\n"" 1549 233 366 304 393\n"" 1550 310 364 307 393\n"" 1551 308 363 176 393\n"" 1552 176 363 112 393\n"" 1553 312 313 262 393\n"" 1554 262 313 308 393\n"" 1555 144 310 307 393\n"" 1556 144 366 310 393\n"" 1557 307 366 144 393\n"" 1558 262 308 176 393\n"" 1559 112 262 176 393\n"" 1560 112 312 262 393\n"" 1561 223 341 274 397\n"" 1562 341 372 274 397\n"" 1563 223 396 341 397\n"" 1564 394 395 372 397\n"" 1565 394 396 395 397\n"" 1566 395 396 371 397\n"" 1567 371 396 293 397\n"" 1568 341 396 394 397\n"" 1569 341 394 20 397\n"" 1570 394 372 20 397\n"" 1571 20 372 341 397\n"" 1572 279 284 278 399\n"" 1573 279 354 284 399\n"" 1574 216 287 282 399\n"" 1575 215 287 216 399\n"" 1576 142 353 284 399\n"" 1577 284 354 142 399\n"" 1578 226 353 142 399\n"" 1579 142 388 226 399\n""# Generated by tetgen -a0.01 cube.smesh \n"); } diff --git a/Demos/SoftDemo/main.cpp b/Demos/SoftDemo/main.cpp deleted file mode 100644 index 3408ae3d6..000000000 --- a/Demos/SoftDemo/main.cpp +++ /dev/null @@ -1,37 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "SoftDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" - -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - SoftDemo* softDemo = new SoftDemo(); - - softDemo->initPhysics(); - softDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - - glutmain(argc, argv,1024,768,"Bullet Physics Demo. http://bulletphysics.com",softDemo); - - delete softDemo; - return 0; - -} diff --git a/Demos/TerrainDemo/Makefile.am b/Demos/TerrainDemo/Makefile.am deleted file mode 100644 index 3dbfb1093..000000000 --- a/Demos/TerrainDemo/Makefile.am +++ /dev/null @@ -1,6 +0,0 @@ - -noinst_PROGRAMS=TerrainDemo - -TerrainDemo_SOURCES=TerrainDemo.cpp TerrainDemo.h main.cpp -TerrainDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -TerrainDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/TerrainDemo/TerrainDemo.cpp b/Demos/TerrainDemo/TerrainDemo.cpp deleted file mode 100644 index cc32b689f..000000000 --- a/Demos/TerrainDemo/TerrainDemo.cpp +++ /dev/null @@ -1,921 +0,0 @@ - -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006,2008 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "TerrainDemo.h" // always include our own header first! - -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h" - -#include "GLDebugDrawer.h" - -#include "GL_ShapeDrawer.h" - -#include "GlutStuff.h" -#include "GLDebugFont.h" - - - -// constants ------------------------------------------------------------------- -static const float s_gravity = 9.8; // 9.8 m/s^2 - -static const int s_gridSize = 64 + 1; // must be (2^N) + 1 -static const float s_gridSpacing = 5.0; - -static const float s_gridHeightScale = 0.2; - -// the singularity at the center of the radial model means we need a lot of -// finely-spaced time steps to get the physics right. -// These numbers are probably too aggressive for a real game! -static const int s_requestedHz = 180; -static const float s_engineTimeStep = 1.0 / s_requestedHz; - -// delta phase: radians per second -static const float s_deltaPhase = 0.25 * 2.0 * SIMD_PI; - -// what type of terrain is generated? -enum eTerrainModel { - eRadial = 1, // deterministic - eFractal = 2 // random -}; - - -typedef unsigned char byte_t; - - - -//////////////////////////////////////////////////////////////////////////////// -// -// static helper methods -// -// Only used within this file (helpers and terrain generation, etc) -// -//////////////////////////////////////////////////////////////////////////////// - -static const char * -getTerrainTypeName -( -eTerrainModel model -) -{ - switch (model) { - case eRadial: - return "Radial"; - - case eFractal: - return "Fractal"; - - default: - btAssert(!"bad terrain model type"); - } - - return NULL; -} - - - -static const char * -getDataTypeName -( -PHY_ScalarType type -) -{ - switch (type) { - case PHY_UCHAR: - return "UnsignedChar"; - - case PHY_SHORT: - return "Short"; - - case PHY_FLOAT: - return "Float"; - - default: - btAssert(!"bad heightfield data type"); - } - - return NULL; -} - - - -static const char * -getUpAxisName -( -int axis -) -{ - switch (axis) { - case 0: - return "X"; - - case 1: - return "Y"; - - case 2: - return "Z"; - - default: - btAssert(!"bad up axis"); - } - - return NULL; -} - - - -static btVector3 -getUpVector -( -int upAxis, -btScalar regularValue, -btScalar upValue -) -{ - btAssert(upAxis >= 0 && upAxis <= 2 && "bad up axis"); - - btVector3 v(regularValue, regularValue, regularValue); - v[upAxis] = upValue; - - return v; -} - - - -// TODO: it would probably cleaner to have a struct per data type, so -// you could lookup byte sizes, conversion functions, etc. -static int getByteSize -( -PHY_ScalarType type -) -{ - int size = 0; - - switch (type) { - case PHY_FLOAT: - size = sizeof(float); - break; - - case PHY_UCHAR: - size = sizeof(unsigned char); - break; - - case PHY_SHORT: - size = sizeof(short); - break; - - default: - btAssert(!"Bad heightfield data type"); - } - - return size; -} - - - -static float -convertToFloat -( -const byte_t * p, -PHY_ScalarType type -) -{ - btAssert(p); - - switch (type) { - case PHY_FLOAT: - { - float * pf = (float *) p; - return *pf; - } - - case PHY_UCHAR: - { - unsigned char * pu = (unsigned char *) p; - return ((*pu) * s_gridHeightScale); - } - - case PHY_SHORT: - { - short * ps = (short *) p; - return ((*ps) * s_gridHeightScale); - } - - default: - btAssert(!"bad type"); - } - - return 0; -} - - - -static float -getGridHeight -( -byte_t * grid, -int i, -int j, -PHY_ScalarType type -) -{ - btAssert(grid); - btAssert(i >= 0 && i < s_gridSize); - btAssert(j >= 0 && j < s_gridSize); - - int bpe = getByteSize(type); - btAssert(bpe > 0 && "bad bytes per element"); - - int idx = (j * s_gridSize) + i; - long offset = ((long) bpe) * idx; - - byte_t * p = grid + offset; - - return convertToFloat(p, type); -} - - - -static void -convertFromFloat -( -byte_t * p, -float value, -PHY_ScalarType type -) -{ - btAssert(p && "null"); - - switch (type) { - case PHY_FLOAT: - { - float * pf = (float *) p; - *pf = value; - } - break; - - case PHY_UCHAR: - { - unsigned char * pu = (unsigned char *) p; - *pu = (unsigned char) (value / s_gridHeightScale); - } - break; - - case PHY_SHORT: - { - short * ps = (short *) p; - *ps = (short) (value / s_gridHeightScale); - } - break; - - default: - btAssert(!"bad type"); - } -} - - - -// creates a radially-varying heightfield -static void -setRadial -( -byte_t * grid, -int bytesPerElement, -PHY_ScalarType type, -float phase = 0.0 -) -{ - btAssert(grid); - btAssert(bytesPerElement > 0); - - // min/max - float period = 0.5 / s_gridSpacing; - float floor = 0.0; - float min_r = 3.0 * sqrt(s_gridSpacing); - float magnitude = 50.0 * sqrt(s_gridSpacing); - - // pick a base_phase such that phase = 0 results in max height - // (this way, if you create a heightfield with phase = 0, - // you can rely on the min/max heights that result) - float base_phase = (0.5 * SIMD_PI) - (period * min_r); - phase += base_phase; - - // center of grid - float cx = 0.5 * s_gridSize * s_gridSpacing; - float cy = cx; // assume square grid - byte_t * p = grid; - for (int i = 0; i < s_gridSize; ++i) { - float x = i * s_gridSpacing; - for (int j = 0; j < s_gridSize; ++j) { - float y = j * s_gridSpacing; - - float dx = x - cx; - float dy = y - cy; - - float r = sqrt((dx * dx) + (dy * dy)); - - float z = period; - if (r < min_r) { - r = min_r; - } - z = (1.0 / r) * sin(period * r + phase); - if (z > period) { - z = period; - } else if (z < -period) { - z = -period; - } - z = floor + magnitude * z; - - convertFromFloat(p, z, type); - p += bytesPerElement; - } - } -} - - - -static float -randomHeight -( -int step -) -{ - return (0.33 * s_gridSpacing * s_gridSize * step * (rand() - (0.5 * RAND_MAX))) / (1.0 * RAND_MAX * s_gridSize); -} - - - -static void -dumpGrid -( -const byte_t * grid, -int bytesPerElement, -PHY_ScalarType type, -int max -) -{ - //std::cerr << "Grid:\n"; - - char buffer[32]; - - for (int j = 0; j < max; ++j) { - for (int i = 0; i < max; ++i) { - long offset = j * s_gridSize + i; - float z = convertToFloat(grid + offset * bytesPerElement, type); - sprintf(buffer, "%6.2f", z); - //std::cerr << " " << buffer; - } - //std::cerr << "\n"; - } -} - - - -static void -updateHeight -( -byte_t * p, -float new_val, -PHY_ScalarType type -) -{ - float old_val = convertToFloat(p, type); - if (!old_val) { - convertFromFloat(p, new_val, type); - } -} - - - -// creates a random, fractal heightfield -static void -setFractal -( -byte_t * grid, -int bytesPerElement, -PHY_ScalarType type, -int step -) -{ - btAssert(grid); - btAssert(bytesPerElement > 0); - btAssert(step > 0); - btAssert(step < s_gridSize); - - int newStep = step / 2; -// std::cerr << "Computing grid with step = " << step << ": before\n"; -// dumpGrid(grid, bytesPerElement, type, step + 1); - - // special case: starting (must set four corners) - if (s_gridSize - 1 == step) { - // pick a non-zero (possibly negative) base elevation for testing - float base = randomHeight(step / 2); - - convertFromFloat(grid, base, type); - convertFromFloat(grid + step * bytesPerElement, base, type); - convertFromFloat(grid + step * s_gridSize * bytesPerElement, base, type); - convertFromFloat(grid + (step * s_gridSize + step) * bytesPerElement, base, type); - } - - // determine elevation of each corner - float c00 = convertToFloat(grid, type); - float c01 = convertToFloat(grid + step * bytesPerElement, type); - float c10 = convertToFloat(grid + (step * s_gridSize) * bytesPerElement, type); - float c11 = convertToFloat(grid + (step * s_gridSize + step) * bytesPerElement, type); - - // set top middle - updateHeight(grid + newStep * bytesPerElement, 0.5 * (c00 + c01) + randomHeight(step), type); - - // set left middle - updateHeight(grid + (newStep * s_gridSize) * bytesPerElement, 0.5 * (c00 + c10) + randomHeight(step), type); - - // set right middle - updateHeight(grid + (newStep * s_gridSize + step) * bytesPerElement, 0.5 * (c01 + c11) + randomHeight(step), type); - - // set bottom middle - updateHeight(grid + (step * s_gridSize + newStep) * bytesPerElement, 0.5 * (c10 + c11) + randomHeight(step), type); - - // set middle - updateHeight(grid + (newStep * s_gridSize + newStep) * bytesPerElement, 0.25 * (c00 + c01 + c10 + c11) + randomHeight(step), type); - -// std::cerr << "Computing grid with step = " << step << ": after\n"; -// dumpGrid(grid, bytesPerElement, type, step + 1); - - // terminate? - if (newStep < 2) { - return; - } - - // recurse - setFractal(grid, bytesPerElement, type, newStep); - setFractal(grid + newStep * bytesPerElement, bytesPerElement, type, newStep); - setFractal(grid + (newStep * s_gridSize) * bytesPerElement, bytesPerElement, type, newStep); - setFractal(grid + ((newStep * s_gridSize) + newStep) * bytesPerElement, bytesPerElement, type, newStep); -} - - - -static byte_t * -getRawHeightfieldData -( -eTerrainModel model, -PHY_ScalarType type, -btScalar& minHeight, -btScalar& maxHeight -) -{ -// std::cerr << "\nRegenerating terrain\n"; -// std::cerr << " model = " << model << "\n"; -// std::cerr << " type = " << type << "\n"; - - long nElements = ((long) s_gridSize) * s_gridSize; -// std::cerr << " nElements = " << nElements << "\n"; - - int bytesPerElement = getByteSize(type); -// std::cerr << " bytesPerElement = " << bytesPerElement << "\n"; - btAssert(bytesPerElement > 0 && "bad bytes per element"); - - long nBytes = nElements * bytesPerElement; -// std::cerr << " nBytes = " << nBytes << "\n"; - byte_t * raw = new byte_t[nBytes]; - btAssert(raw && "out of memory"); - - // reseed randomization every 30 seconds -// srand(time(NULL) / 30); - - // populate based on model - switch (model) { - case eRadial: - setRadial(raw, bytesPerElement, type); - break; - - case eFractal: - for (int i = 0; i < nBytes; i++) - { - raw[i] = 0; - } - setFractal(raw, bytesPerElement, type, s_gridSize - 1); - break; - - default: - btAssert(!"bad model type"); - } - - if (0) { - // inside if(0) so it keeps compiling but isn't - // exercised and doesn't cause warnings -// std::cerr << "final grid:\n"; - dumpGrid(raw, bytesPerElement, type, s_gridSize - 1); - } - - // find min/max - for (int i = 0; i < s_gridSize; ++i) { - for (int j = 0; j < s_gridSize; ++j) { - float z = getGridHeight(raw, i, j, type); -// std::cerr << "i=" << i << ", j=" << j << ": z=" << z << "\n"; - - // update min/max - if (!i && !j) { - minHeight = z; - maxHeight = z; - } else { - if (z < minHeight) { - minHeight = z; - } - if (z > maxHeight) { - maxHeight = z; - } - } - } - } - - if (maxHeight < -minHeight) { - maxHeight = -minHeight; - } - if (minHeight > -maxHeight) { - minHeight = -maxHeight; - } - -// std::cerr << " minHeight = " << minHeight << "\n"; -// std::cerr << " maxHeight = " << maxHeight << "\n"; - - return raw; -} - - - -//////////////////////////////////////////////////////////////////////////////// -// -// TerrainDemo class -// -//////////////////////////////////////////////////////////////////////////////// - -/// class that demonstrates the btHeightfieldTerrainShape object -class TerrainDemo : public GlutDemoApplication { -public: - // constructor, destructor --------------------------------------------- - TerrainDemo(void); - ~TerrainDemo(void); - - virtual void initPhysics() {} - - // public class methods ------------------------------------------------ - void initialize(void); - - // DemoApplication class interface methods ----------------------------- - void clientMoveAndDisplay(void); - void keyboardCallback(unsigned char key, int x, int y); - void renderme(void); - -private: - // private helper methods ---------------------------------------------- - void resetPhysics(void); - void clearWorld(void); - - // private data members ------------------------------------------------ - btDefaultCollisionConfiguration * m_collisionConfiguration; - btCollisionDispatcher * m_dispatcher; - btAxisSweep3 * m_overlappingPairCache; - btSequentialImpulseConstraintSolver * m_constraintSolver; - btAlignedObjectArray m_collisionShapes; - int m_upAxis; - PHY_ScalarType m_type; - eTerrainModel m_model; - byte_t * m_rawHeightfieldData; - btScalar m_minHeight; - btScalar m_maxHeight; - float m_phase; // for dynamics - bool m_isDynamic; -}; - - - -TerrainDemo::TerrainDemo(void) -: -m_collisionConfiguration(NULL), -m_dispatcher(NULL), -m_overlappingPairCache(NULL), -m_constraintSolver(NULL), -m_upAxis(1), -m_type(PHY_FLOAT), -m_model(eFractal), -m_rawHeightfieldData(NULL), -m_phase(0.0), -m_isDynamic(true) -{ -} - - - -TerrainDemo::~TerrainDemo(void) -{ - clearWorld(); - - //delete dynamics world - delete m_dynamicsWorld; - - //delete solver - delete m_constraintSolver; - - //delete broadphase - delete m_overlappingPairCache; - - //delete dispatcher - delete m_dispatcher; - - delete m_collisionConfiguration; - -} - - - -//////////////////////////////////////////////////////////////////////////////// -// -// TerrainDemo -- public class methods -// -//////////////////////////////////////////////////////////////////////////////// - -/// one-time class and physics initialization -void TerrainDemo::initialize(void) -{ -// std::cerr << "initializing...\n"; - - // set up basic state - m_upAxis = 1; // start with Y-axis as "up" - m_type = PHY_FLOAT; - m_model = eRadial;//eFractal; - m_isDynamic = true; - - // set up the physics world - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - btVector3 worldMin(-1000,-1000,-1000); - btVector3 worldMax(1000,1000,1000); - m_overlappingPairCache = new btAxisSweep3(worldMin,worldMax); - m_constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration); - - // initialize axis- or type-dependent physics from here - this->resetPhysics(); -} - - - -//////////////////////////////////////////////////////////////////////////////// -// -// TerrainDemo -- DemoApplication class interface methods -// -//////////////////////////////////////////////////////////////////////////////// - -void TerrainDemo::clientMoveAndDisplay(void) -{ - // elapsed time - float us = getDeltaTimeMicroseconds(); - float seconds = 1.0e-6 * us; - - // we'll carefully iterate through each time step so we can update - // the dynamic model if necessary - long nStepsPerIteration = 1; - while (seconds > 1.0e-6) { - float dt = nStepsPerIteration * s_engineTimeStep; - if (dt > seconds) { - dt = seconds; - } - seconds -= dt; - // std::cerr << " Stepping through " << dt << " seconds\n"; - - // if dynamic and radial, go ahead and update the field - if (m_rawHeightfieldData && m_isDynamic && eRadial == m_model) { - m_phase += s_deltaPhase * dt; - if (m_phase > 2.0 * SIMD_PI) { - m_phase -= 2.0 * SIMD_PI; - } - int bpe = getByteSize(m_type); - btAssert(bpe > 0 && "Bad bytes per element"); - setRadial(m_rawHeightfieldData, bpe, m_type, m_phase); - } - - if (m_dynamicsWorld) { - m_dynamicsWorld->stepSimulation(dt, - nStepsPerIteration + 1, s_engineTimeStep); - } - } - - // okay, render - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - renderme(); - glFlush(); - glutSwapBuffers(); -} - - -static PHY_ScalarType nextType (PHY_ScalarType type) -{ - switch (type) - { - case PHY_FLOAT: - return PHY_SHORT; - break; - case PHY_SHORT: - return PHY_UCHAR; - break; - case PHY_UCHAR: - return PHY_FLOAT; - break; - } - btAssert (0); - return PHY_FLOAT; -} - -void TerrainDemo::keyboardCallback(unsigned char key, int x, int y) { - - if (',' == key) { - // increment model - m_model = (eFractal == m_model) ? eRadial : eFractal; - this->resetPhysics(); - } - if ('/' == key) { - // increment type - m_type = nextType(m_type); - this->resetPhysics(); - } - if ('\\' == key) { - // increment axis - m_upAxis++; - if (m_upAxis > 2) { - m_upAxis = 0; - } - this->resetPhysics(); - } - if ('[' == key) { - // toggle dynamics - m_isDynamic = !m_isDynamic; - } - - // let demo base class handle! - DemoApplication::keyboardCallback(key, x, y); -} - - - -static void doPrint(int x,int& y,int dy,const char * text) -{ - GLDebugDrawString(x,y, text); - y += dy; -} - - - -/// override the default display just so we can overlay a bit more text -void TerrainDemo::renderme(void) -{ - // give base class a shot - DemoApplication::renderme(); - - // overlay any debug information - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - // switch to orthographic - setOrthographicProjection(); - - // we'll draw on the right top of the screen - const int lineWidth = 200; - const int lineHeight = 16; - char buffer[256]; - - int xStart = m_glutScreenWidth - lineWidth; - int yStart = lineHeight; - - sprintf(buffer, "Terrain Type: %s", getTerrainTypeName(m_model)); - doPrint(xStart, yStart, lineHeight, buffer); - doPrint(xStart, yStart, lineHeight, "Press ',' to cycle terrain types"); - doPrint(xStart, yStart, lineHeight, ""); - - sprintf(buffer, "Data Type: %s", getDataTypeName(m_type)); - doPrint(xStart, yStart, lineHeight, buffer); - doPrint(xStart, yStart, lineHeight, "Press '/' to cycle data types"); - doPrint(xStart, yStart, lineHeight, ""); - - sprintf(buffer, "'up' axis: %s", getUpAxisName(m_upAxis)); - doPrint(xStart, yStart, lineHeight, buffer); - doPrint(xStart, yStart, lineHeight, "Press '\\' to cycle 'up' axes"); - doPrint(xStart, yStart, lineHeight, ""); - - if (eRadial == m_model) { - sprintf(buffer, "Dynamic: %s", m_isDynamic ? "yes" : "no"); - doPrint(xStart, yStart, lineHeight, buffer); - doPrint(xStart, yStart, lineHeight, "Press '[' to toggle dynamics"); - } -} - - - -//////////////////////////////////////////////////////////////////////////////// -// -// TerrainDemo -- private helper methods -// -//////////////////////////////////////////////////////////////////////////////// - -/// called whenever key terrain attribute is changed -void TerrainDemo::resetPhysics(void) -{ - // remove old heightfield - clearWorld(); - - // reset gravity to point in appropriate direction - m_dynamicsWorld->setGravity(getUpVector(m_upAxis, 0.0, -s_gravity)); - - // get new heightfield of appropriate type - m_rawHeightfieldData = - getRawHeightfieldData(m_model, m_type, m_minHeight, m_maxHeight); - btAssert(m_rawHeightfieldData && "failed to create raw heightfield"); - - bool flipQuadEdges = false; - btHeightfieldTerrainShape * heightfieldShape = - new btHeightfieldTerrainShape(s_gridSize, s_gridSize, - m_rawHeightfieldData, - s_gridHeightScale, - m_minHeight, m_maxHeight, - m_upAxis, m_type, flipQuadEdges); - btAssert(heightfieldShape && "null heightfield"); - - // scale the shape - btVector3 localScaling = getUpVector(m_upAxis, s_gridSpacing, 1.0); - heightfieldShape->setLocalScaling(localScaling); - - // stash this shape away - m_collisionShapes.push_back(heightfieldShape); - - // set origin to middle of heightfield - btTransform tr; - tr.setIdentity(); - tr.setOrigin(btVector3(0,-20,0)); - - // create ground object - float mass = 0.0; - localCreateRigidBody(mass, tr, heightfieldShape); -} - - -/// removes all objects and shapes from the world -void TerrainDemo::clearWorld(void) -{ - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;jinitialize(); - - return demo; -} - diff --git a/Demos/TerrainDemo/TerrainDemo.h b/Demos/TerrainDemo/TerrainDemo.h deleted file mode 100644 index 1b6a3e6ac..000000000 --- a/Demos/TerrainDemo/TerrainDemo.h +++ /dev/null @@ -1,27 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006,2008 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef TERRAIN_DEMO_H -#define TERRAIN_DEMO_H - - -#include "GlutDemoApplication.h" - - -// all we need to expose publicly is the factory method! -GlutDemoApplication * btCreateTerrainDemo(void); - - -#endif //TERRAIN_DEMO_H - diff --git a/Demos/TerrainDemo/main.cpp b/Demos/TerrainDemo/main.cpp deleted file mode 100644 index 6510f24f2..000000000 --- a/Demos/TerrainDemo/main.cpp +++ /dev/null @@ -1,14 +0,0 @@ - -#include "TerrainDemo.h" -#include "GlutStuff.h" - -int main(int argc,char** argv) -{ - DemoApplication * demo = btCreateTerrainDemo(); - btAssert(demo && "failed to create terrain demo object"); - - return glutmain(argc, argv, 800, 600, - "Terrain Demo. http://www.continuousphysics.com/Bullet/phpBB2/", - demo); -} - diff --git a/Demos/ThreadingDemo/CMakeLists.txt b/Demos/ThreadingDemo/CMakeLists.txt deleted file mode 100644 index 7ecd933f3..000000000 --- a/Demos/ThreadingDemo/CMakeLists.txt +++ /dev/null @@ -1,48 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -#currently this demo has only been tested under Windows 32bit -#IF (WIN32) - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ../OpenGL - ${VECTOR_MATH_INCLUDE} -) - -LINK_LIBRARIES( -BulletMultiThreaded BulletDynamics BulletCollision LinearMath -) - -IF (WIN32) -ADD_EXECUTABLE(AppThreadingDemo - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppThreadingDemo - main.cpp - ) -ENDIF() - -IF (UNIX) - TARGET_LINK_LIBRARIES(AppThreadingDemo pthread) -ENDIF(UNIX) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppThreadingDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppThreadingDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppThreadingDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - -#ENDIF(WIN32) diff --git a/Demos/ThreadingDemo/main.cpp b/Demos/ThreadingDemo/main.cpp deleted file mode 100644 index 17fbd1b09..000000000 --- a/Demos/ThreadingDemo/main.cpp +++ /dev/null @@ -1,185 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2010 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/// ThreadingDemo shows how to use the cross platform thread support interface. -/// You can start threads and perform a blocking wait for completion -/// Under Windows it uses Win32 Threads. On Mac and Linux it uses pthreads. On PlayStation 3 Cell SPU it uses SPURS. - -/// June 2010 -/// New: critical section/barriers and non-blocking pollingn for completion, currently Windows only - -void SampleThreadFunc(void* userPtr,void* lsMemory); -void* SamplelsMemoryFunc(); - -#include -#include "BulletMultiThreaded/PlatformDefinitions.h" - -#ifdef USE_PTHREADS -//#ifdef __APPLE__ -#include "BulletMultiThreaded/PosixThreadSupport.h" - -btThreadSupportInterface* createThreadSupport(int numThreads) -{ - PosixThreadSupport::ThreadConstructionInfo constructionInfo("testThreads", - SampleThreadFunc, - SamplelsMemoryFunc, - numThreads); - btThreadSupportInterface* threadSupport = new PosixThreadSupport(constructionInfo); - - return threadSupport; - -} - - -#elif defined( _WIN32) -#include "BulletMultiThreaded/Win32ThreadSupport.h" - -btThreadSupportInterface* createThreadSupport(int numThreads) -{ - Win32ThreadSupport::Win32ThreadConstructionInfo threadConstructionInfo("testThreads",SampleThreadFunc,SamplelsMemoryFunc,numThreads); - Win32ThreadSupport* threadSupport = new Win32ThreadSupport(threadConstructionInfo); - return threadSupport; - -} - -#endif - - -struct SampleArgs -{ - SampleArgs() - :m_fakeWork(1) - { - } - btCriticalSection* m_cs; - float m_fakeWork; -}; - -struct SampleThreadLocalStorage -{ - int threadId; -}; - - -void SampleThreadFunc(void* userPtr,void* lsMemory) -{ - printf("thread started\n"); - - SampleThreadLocalStorage* localStorage = (SampleThreadLocalStorage*) lsMemory; - - SampleArgs* args = (SampleArgs*) userPtr; - int workLeft = true; - while (workLeft) - { - args->m_cs->lock(); - int count = args->m_cs->getSharedParam(0); - args->m_cs->setSharedParam(0,count-1); - args->m_cs->unlock(); - if (count>0) - { - printf("thread %d processed number %d\n",localStorage->threadId, count); - } - //do some fake work - for (int i=0;i<1000000;i++) - args->m_fakeWork = btScalar(1.21)*args->m_fakeWork; - workLeft = count>0; - } - printf("finished\n"); - //do nothing -} - - -void* SamplelsMemoryFunc() -{ - //don't create local store memory, just return 0 - return new SampleThreadLocalStorage; -} - - - - - - - - - - -int main(int argc,char** argv) -{ - int numThreads = 8; - - btThreadSupportInterface* threadSupport = createThreadSupport(numThreads); - - - threadSupport->startSPU(); - - for (int i=0;igetNumTasks();i++) - { - SampleThreadLocalStorage* storage = (SampleThreadLocalStorage*)threadSupport->getThreadLocalMemory(i); - btAssert(storage); - storage->threadId = i; - } - - - SampleArgs args; - args.m_cs = threadSupport->createCriticalSection(); - args.m_cs->setSharedParam(0,100); - - - unsigned int arg0,arg1; - int i; - for (i=0;isendRequest(1, (ppu_address_t) &args, i); - } - - bool blockingWait =true; - if (blockingWait) - { - for (i=0;iwaitForResponse(&arg0,&arg1); - printf("finished waiting for response: %d %d\n", arg0,arg1); - } - } else - { -#if _WIN32 - int numActiveThreads = numThreads; - while (numActiveThreads) - { - if (((Win32ThreadSupport*)threadSupport)->isTaskCompleted(&arg0,&arg1,0)) - { - numActiveThreads--; - printf("numActiveThreads = %d\n",numActiveThreads); - - } else - { - printf("polling\n"); - } - }; -#else - btAssert(0); - printf("non-blocking wait is not supported on this platform\n"); - exit(0); -#endif - } - -printf("stopping threads\n"); - - delete threadSupport; - printf("Press ENTER to quit\n"); - getchar(); - return 0; -} diff --git a/Demos/UserCollisionAlgorithm/CMakeLists.txt b/Demos/UserCollisionAlgorithm/CMakeLists.txt deleted file mode 100644 index 087835d6a..000000000 --- a/Demos/UserCollisionAlgorithm/CMakeLists.txt +++ /dev/null @@ -1,40 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - ADD_EXECUTABLE(AppUserCollisionAlgorithm - UserCollisionAlgorithm.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppUserCollisionAlgorithm - UserCollisionAlgorithm.cpp - ) -ENDIF() - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppUserCollisionAlgorithm PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppUserCollisionAlgorithm PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppUserCollisionAlgorithm PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/UserCollisionAlgorithm/UserCollisionAlgorithm.cpp b/Demos/UserCollisionAlgorithm/UserCollisionAlgorithm.cpp deleted file mode 100644 index 5d094f2e4..000000000 --- a/Demos/UserCollisionAlgorithm/UserCollisionAlgorithm.cpp +++ /dev/null @@ -1,175 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btIDebugDraw.h" -#include "GLDebugDrawer.h" -#include "UserCollisionAlgorithm.h" -#include "GL_ShapeDrawer.h" -#include "GlutStuff.h" - -//The user defined collision algorithm -#include "BulletCollision/CollisionDispatch/btSphereSphereCollisionAlgorithm.h" - -GLDebugDrawer debugDrawer; - -static const int NUM_VERTICES = 5; -static const int NUM_TRIANGLES=4; - -btVector3 gVertices[NUM_VERTICES]; -int gIndices[NUM_TRIANGLES*3]; -const float TRIANGLE_SIZE=10.f; - - -///User can override this material combiner by implementing gContactAddedCallback and setting body0->m_collisionFlags |= btCollisionObject::customMaterialCallback; -inline btScalar calculateCombinedFriction(float friction0,float friction1) -{ - btScalar friction = friction0 * friction1; - - const btScalar MAX_FRICTION = 10.f; - if (friction < -MAX_FRICTION) - friction = -MAX_FRICTION; - if (friction > MAX_FRICTION) - friction = MAX_FRICTION; - return friction; - -} - -inline btScalar calculateCombinedRestitution(float restitution0,float restitution1) -{ - return restitution0 * restitution1; -} - - - - - - -int main(int argc,char** argv) -{ - - UserCollisionAlgorithm* userCollisionAlgorithm = new UserCollisionAlgorithm; - userCollisionAlgorithm->initPhysics(); - userCollisionAlgorithm->setCameraDistance(30.f); - - return glutmain(argc, argv,640,480,"Static Concave Mesh Demo",userCollisionAlgorithm); -} - -void UserCollisionAlgorithm::initPhysics() -{ - #define TRISIZE 5.f - - - const int NUM_VERTS_X = 50; - const int NUM_VERTS_Y = 50; - const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - - btVector3* gVertices = new btVector3[totalVerts]; - - int i; - for ( i=0;iaddTriangle(gVertices[j*NUM_VERTS_X+i],gVertices[j*NUM_VERTS_X+i+1],gVertices[(j+1)*NUM_VERTS_X+i+1]); - trimesh->addTriangle(gVertices[j*NUM_VERTS_X+i],gVertices[(j+1)*NUM_VERTS_X+i+1],gVertices[(j+1)*NUM_VERTS_X+i]); - } - } - - delete[] gVertices; - - bool useQuantizedBvhTree = true; - btCollisionShape* trimeshShape = new btBvhTriangleMeshShape(trimesh,useQuantizedBvhTree); - - //ConstraintSolver* solver = new btSequentialImpulseConstraintSolver; - btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration(); - btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collisionConfiguration); - - btVector3 maxAabb(10000,10000,10000); - btBroadphaseInterface* broadphase = new btAxisSweep3(-maxAabb,maxAabb);//SimpleBroadphase(); - dispatcher->registerCollisionCreateFunc(GIMPACT_SHAPE_PROXYTYPE,GIMPACT_SHAPE_PROXYTYPE,new btSphereSphereCollisionAlgorithm::CreateFunc); - - btConstraintSolver* constraintSolver = new btSequentialImpulseConstraintSolver(); - m_dynamicsWorld = new btDiscreteDynamicsWorld(dispatcher,broadphase,constraintSolver,collisionConfiguration); - - float mass = 0.f; - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,-2,0)); - - btRigidBody* staticBody= localCreateRigidBody(mass, startTransform,trimeshShape); - //enable custom material callback - staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK); - - { - for (int i=0;i<10;i++) - { - btCollisionShape* sphereShape = new btSphereShape(1); - startTransform.setOrigin(btVector3(1,2*i,1)); - //btRigidBody* body = localCreateRigidBody(1, startTransform,sphereShape); - localCreateRigidBody(1, startTransform,sphereShape); - } - } - - - - m_dynamicsWorld->setDebugDrawer(&debugDrawer); -} - -void UserCollisionAlgorithm::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - - m_dynamicsWorld->stepSimulation(dt); - - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - - renderme(); - - glFlush(); - glutSwapBuffers(); - -} - - - - - - -void UserCollisionAlgorithm::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - glFlush(); - glutSwapBuffers(); -} - - diff --git a/Demos/UserCollisionAlgorithm/UserCollisionAlgorithm.h b/Demos/UserCollisionAlgorithm/UserCollisionAlgorithm.h deleted file mode 100644 index acfa37c09..000000000 --- a/Demos/UserCollisionAlgorithm/UserCollisionAlgorithm.h +++ /dev/null @@ -1,36 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef USER_COLLISION_ALGORITHM_DEMO_H -#define USER_COLLISION_ALGORITHM_DEMO_H - -#include "GlutDemoApplication.h" - -///UserCollisionAlgorithmDemo shows how to register and use your own collision algorithm for a certain shape pair type -class UserCollisionAlgorithm : public GlutDemoApplication -{ - public: - - void initPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - - - -}; - -#endif //USER_COLLISION_ALGORITHM_DEMO_H - diff --git a/Demos/VehicleDemo/CMakeLists.txt b/Demos/VehicleDemo/CMakeLists.txt deleted file mode 100644 index 5cb862e20..000000000 --- a/Demos/VehicleDemo/CMakeLists.txt +++ /dev/null @@ -1,34 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - - -# You shouldn't have to modify anything below this line -######################################################## - - - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - -LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -ADD_EXECUTABLE(AppVehicleDemo - heightfield128x128.cpp - VehicleDemo.cpp - main.cpp -) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppVehicleDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppVehicleDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppVehicleDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/VehicleDemo/Makefile.am b/Demos/VehicleDemo/Makefile.am deleted file mode 100644 index 4a260785b..000000000 --- a/Demos/VehicleDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=VehicleDemo - -VehicleDemo_SOURCES=VehicleDemo.cpp VehicleDemo.h heightfield128x128.cpp main.cpp -VehicleDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -VehicleDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/VehicleDemo/VehicleDemo.cpp b/Demos/VehicleDemo/VehicleDemo.cpp deleted file mode 100644 index e48a50204..000000000 --- a/Demos/VehicleDemo/VehicleDemo.cpp +++ /dev/null @@ -1,683 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/// September 2006: VehicleDemo is work in progress, this file is mostly just a placeholder -/// This VehicleDemo file is very early in development, please check it later -/// One todo is a basic engine model: -/// A function that maps user input (throttle) into torque/force applied on the wheels -/// with gears etc. -#include "btBulletDynamicsCommon.h" -#include "BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h" -extern char MyHeightfield[]; -// -// By default, Bullet Vehicle uses Y as up axis. -// You can override the up axis, for example Z-axis up. Enable this define to see how to: -//#define FORCE_ZAXIS_UP 1 -// - -#ifdef FORCE_ZAXIS_UP - int rightIndex = 0; - int upIndex = 2; - int forwardIndex = 1; - btVector3 wheelDirectionCS0(0,0,-1); - btVector3 wheelAxleCS(1,0,0); -#else - int rightIndex = 0; - int upIndex = 1; - int forwardIndex = 2; - btVector3 wheelDirectionCS0(0,-1,0); - btVector3 wheelAxleCS(-1,0,0); -#endif - -#include "GLDebugDrawer.h" -#include //printf debugging - -#include "GL_ShapeDrawer.h" - -#include "GlutStuff.h" -#include "VehicleDemo.h" - -const int maxProxies = 32766; -const int maxOverlap = 65535; - -///btRaycastVehicle is the interface for the constraint that implements the raycast vehicle -///notice that for higher-quality slow-moving vehicles, another approach might be better -///implementing explicit hinged-wheel constraints with cylinder collision, rather then raycasts -float gEngineForce = 0.f; -float gBreakingForce = 0.f; - -float maxEngineForce = 1000.f;//this should be engine/velocity dependent -float maxBreakingForce = 100.f; - -float gVehicleSteering = 0.f; -float steeringIncrement = 0.04f; -float steeringClamp = 0.3f; -float wheelRadius = 0.5f; -float wheelWidth = 0.4f; -float wheelFriction = 1000;//BT_LARGE_FLOAT; -float suspensionStiffness = 20.f; -float suspensionDamping = 2.3f; -float suspensionCompression = 4.4f; -float rollInfluence = 0.1f;//1.0f; - - -btScalar suspensionRestLength(0.6); - -#define CUBE_HALF_EXTENTS 1 - - - -//////////////////////////////////// - - - - -VehicleDemo::VehicleDemo() -: -m_carChassis(0), -m_indexVertexArrays(0), -m_vertices(0), -m_cameraHeight(4.f), -m_minCameraDistance(3.f), -m_maxCameraDistance(10.f) -{ - m_vehicle = 0; - m_wheelShape = 0; - m_cameraPosition = btVector3(30,30,30); -} - -VehicleDemo::~VehicleDemo() -{ - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;jsetGravity(btVector3(0,0,-10)); -#endif - - //m_dynamicsWorld->setGravity(btVector3(0,0,0)); -btTransform tr; -tr.setIdentity(); - -//either use heightfield or triangle mesh -//#define USE_TRIMESH_GROUND 1 -#ifdef USE_TRIMESH_GROUND - int i; - -const float TRIANGLE_SIZE=20.f; - - //create a triangle-mesh ground - int vertStride = sizeof(btVector3); - int indexStride = 3*sizeof(int); - - const int NUM_VERTS_X = 20; - const int NUM_VERTS_Y = 20; - const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y; - - const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1); - - m_vertices = new btVector3[totalVerts]; - int* gIndices = new int[totalTriangles*3]; - - - - for ( i=0;igetAabb(btTransform::getIdentity(),mmin,mmax); - - groundShape = heightFieldShape; - - heightFieldShape->setUseDiamondSubdivision(true); - - btVector3 localScaling(100,1,100); - localScaling[upIndex]=1.f; - groundShape->setLocalScaling(localScaling); - - //tr.setOrigin(btVector3(0,9940,0)); - tr.setOrigin(btVector3(0,49.4,0)); - -#endif // - - m_collisionShapes.push_back(groundShape); - - //create ground object - localCreateRigidBody(0,tr,groundShape); - tr.setOrigin(btVector3(0,0,0));//-64.5f,0)); - -#ifdef FORCE_ZAXIS_UP -// indexRightAxis = 0; -// indexUpAxis = 2; -// indexForwardAxis = 1; - btCollisionShape* chassisShape = new btBoxShape(btVector3(1.f,2.f, 0.5f)); - btCompoundShape* compound = new btCompoundShape(); - btTransform localTrans; - localTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - localTrans.setOrigin(btVector3(0,0,1)); -#else - btCollisionShape* chassisShape = new btBoxShape(btVector3(1.f,0.5f,2.f)); - m_collisionShapes.push_back(chassisShape); - - btCompoundShape* compound = new btCompoundShape(); - m_collisionShapes.push_back(compound); - btTransform localTrans; - localTrans.setIdentity(); - //localTrans effectively shifts the center of mass with respect to the chassis - localTrans.setOrigin(btVector3(0,1,0)); -#endif - - compound->addChildShape(localTrans,chassisShape); - - tr.setOrigin(btVector3(0,0.f,0)); - - m_carChassis = localCreateRigidBody(800,tr,compound);//chassisShape); - //m_carChassis->setDamping(0.2,0.2); - - m_wheelShape = new btCylinderShapeX(btVector3(wheelWidth,wheelRadius,wheelRadius)); - - clientResetScene(); - - /// create vehicle - { - - m_vehicleRayCaster = new btDefaultVehicleRaycaster(m_dynamicsWorld); - m_vehicle = new btRaycastVehicle(m_tuning,m_carChassis,m_vehicleRayCaster); - - ///never deactivate the vehicle - m_carChassis->setActivationState(DISABLE_DEACTIVATION); - - m_dynamicsWorld->addVehicle(m_vehicle); - - float connectionHeight = 1.2f; - - - bool isFrontWheel=true; - - //choose coordinate system - m_vehicle->setCoordinateSystem(rightIndex,upIndex,forwardIndex); - -#ifdef FORCE_ZAXIS_UP - btVector3 connectionPointCS0(CUBE_HALF_EXTENTS-(0.3*wheelWidth),2*CUBE_HALF_EXTENTS-wheelRadius, connectionHeight); -#else - btVector3 connectionPointCS0(CUBE_HALF_EXTENTS-(0.3*wheelWidth),connectionHeight,2*CUBE_HALF_EXTENTS-wheelRadius); -#endif - - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),2*CUBE_HALF_EXTENTS-wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),connectionHeight,2*CUBE_HALF_EXTENTS-wheelRadius); -#endif - - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),-2*CUBE_HALF_EXTENTS+wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(-CUBE_HALF_EXTENTS+(0.3*wheelWidth),connectionHeight,-2*CUBE_HALF_EXTENTS+wheelRadius); -#endif //FORCE_ZAXIS_UP - isFrontWheel = false; - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); -#ifdef FORCE_ZAXIS_UP - connectionPointCS0 = btVector3(CUBE_HALF_EXTENTS-(0.3*wheelWidth),-2*CUBE_HALF_EXTENTS+wheelRadius, connectionHeight); -#else - connectionPointCS0 = btVector3(CUBE_HALF_EXTENTS-(0.3*wheelWidth),connectionHeight,-2*CUBE_HALF_EXTENTS+wheelRadius); -#endif - m_vehicle->addWheel(connectionPointCS0,wheelDirectionCS0,wheelAxleCS,suspensionRestLength,wheelRadius,m_tuning,isFrontWheel); - - for (int i=0;igetNumWheels();i++) - { - btWheelInfo& wheel = m_vehicle->getWheelInfo(i); - wheel.m_suspensionStiffness = suspensionStiffness; - wheel.m_wheelsDampingRelaxation = suspensionDamping; - wheel.m_wheelsDampingCompression = suspensionCompression; - wheel.m_frictionSlip = wheelFriction; - wheel.m_rollInfluence = rollInfluence; - } - } - - - setCameraDistance(26.f); - -} - - -//to be implemented by the demo -void VehicleDemo::renderme() -{ - - updateCamera(); - - btScalar m[16]; - int i; - - - btVector3 wheelColor(1,0,0); - - btVector3 worldBoundsMin,worldBoundsMax; - getDynamicsWorld()->getBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax); - - - - for (i=0;igetNumWheels();i++) - { - //synchronize the wheels with the (interpolated) chassis worldtransform - m_vehicle->updateWheelTransform(i,true); - //draw wheels (cylinders) - m_vehicle->getWheelInfo(i).m_worldTransform.getOpenGLMatrix(m); - m_shapeDrawer->drawOpenGL(m,m_wheelShape,wheelColor,getDebugMode(),worldBoundsMin,worldBoundsMax); - } - - - DemoApplication::renderme(); - -} - -void VehicleDemo::clientMoveAndDisplay() -{ - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - { - int wheelIndex = 2; - m_vehicle->applyEngineForce(gEngineForce,wheelIndex); - m_vehicle->setBrake(gBreakingForce,wheelIndex); - wheelIndex = 3; - m_vehicle->applyEngineForce(gEngineForce,wheelIndex); - m_vehicle->setBrake(gBreakingForce,wheelIndex); - - - wheelIndex = 0; - m_vehicle->setSteeringValue(gVehicleSteering,wheelIndex); - wheelIndex = 1; - m_vehicle->setSteeringValue(gVehicleSteering,wheelIndex); - - } - - - float dt = getDeltaTimeMicroseconds() * 0.000001f; - - if (m_dynamicsWorld) - { - //during idle mode, just run 1 simulation step maximum - int maxSimSubSteps = m_idle ? 1 : 2; - if (m_idle) - dt = 1.0/420.f; - - int numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps); - - -//#define VERBOSE_FEEDBACK -#ifdef VERBOSE_FEEDBACK - if (!numSimSteps) - printf("Interpolated transforms\n"); - else - { - if (numSimSteps > maxSimSubSteps) - { - //detect dropping frames - printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps); - } else - { - printf("Simulated (%i) steps\n",numSimSteps); - } - } -#endif //VERBOSE_FEEDBACK - - } - - - - - - - -#ifdef USE_QUICKPROF - btProfiler::beginBlock("render"); -#endif //USE_QUICKPROF - - - renderme(); - - //optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - -#ifdef USE_QUICKPROF - btProfiler::endBlock("render"); -#endif - - - glFlush(); - glutSwapBuffers(); - -} - - - -void VehicleDemo::displayCallback(void) -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - -//optional but useful: debug drawing - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - glutSwapBuffers(); -} - - - -void VehicleDemo::clientResetScene() -{ - gVehicleSteering = 0.f; - m_carChassis->setCenterOfMassTransform(btTransform::getIdentity()); - m_carChassis->setLinearVelocity(btVector3(0,0,0)); - m_carChassis->setAngularVelocity(btVector3(0,0,0)); - m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(m_carChassis->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher()); - if (m_vehicle) - { - m_vehicle->resetSuspension(); - for (int i=0;igetNumWheels();i++) - { - //synchronize the wheels with the (interpolated) chassis worldtransform - m_vehicle->updateWheelTransform(i,true); - } - } - -} - - - -void VehicleDemo::specialKeyboardUp(int key, int x, int y) -{ - switch (key) - { - case GLUT_KEY_UP : - { - gEngineForce = 0.f; - break; - } - case GLUT_KEY_DOWN : - { - gBreakingForce = 0.f; - break; - } - default: - DemoApplication::specialKeyboardUp(key,x,y); - break; - } - -} - - -void VehicleDemo::specialKeyboard(int key, int x, int y) -{ - -// printf("key = %i x=%i y=%i\n",key,x,y); - - switch (key) - { - case GLUT_KEY_LEFT : - { - gVehicleSteering += steeringIncrement; - if ( gVehicleSteering > steeringClamp) - gVehicleSteering = steeringClamp; - - break; - } - case GLUT_KEY_RIGHT : - { - gVehicleSteering -= steeringIncrement; - if ( gVehicleSteering < -steeringClamp) - gVehicleSteering = -steeringClamp; - - break; - } - case GLUT_KEY_UP : - { - gEngineForce = maxEngineForce; - gBreakingForce = 0.f; - break; - } - case GLUT_KEY_DOWN : - { - gBreakingForce = maxBreakingForce; - gEngineForce = 0.f; - break; - } - default: - DemoApplication::specialKeyboard(key,x,y); - break; - } - -// glutPostRedisplay(); - - -} - - - -void VehicleDemo::updateCamera() -{ - -//#define DISABLE_CAMERA 1 -#ifdef DISABLE_CAMERA - DemoApplication::updateCamera(); - return; -#endif //DISABLE_CAMERA - - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - - btTransform chassisWorldTrans; - - //look at the vehicle - m_carChassis->getMotionState()->getWorldTransform(chassisWorldTrans); - m_cameraTargetPosition = chassisWorldTrans.getOrigin(); - - //interpolate the camera height -#ifdef FORCE_ZAXIS_UP - m_cameraPosition[2] = (15.0*m_cameraPosition[2] + m_cameraTargetPosition[2] + m_cameraHeight)/16.0; -#else - m_cameraPosition[1] = (15.0*m_cameraPosition[1] + m_cameraTargetPosition[1] + m_cameraHeight)/16.0; -#endif - - btVector3 camToObject = m_cameraTargetPosition - m_cameraPosition; - - //keep distance between min and max distance - float cameraDistance = camToObject.length(); - float correctionFactor = 0.f; - if (cameraDistance < m_minCameraDistance) - { - correctionFactor = 0.15*(m_minCameraDistance-cameraDistance)/cameraDistance; - } - if (cameraDistance > m_maxCameraDistance) - { - correctionFactor = 0.15*(m_maxCameraDistance-cameraDistance)/cameraDistance; - } - m_cameraPosition -= correctionFactor*camToObject; - - btScalar aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight; - glFrustum (-aspect, aspect, -1.0, 1.0, 1.0, 10000.0); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - - gluLookAt(m_cameraPosition[0],m_cameraPosition[1],m_cameraPosition[2], - m_cameraTargetPosition[0],m_cameraTargetPosition[1], m_cameraTargetPosition[2], - m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ()); - - - -} - diff --git a/Demos/VehicleDemo/VehicleDemo.h b/Demos/VehicleDemo/VehicleDemo.h deleted file mode 100644 index 4a05c8fcf..000000000 --- a/Demos/VehicleDemo/VehicleDemo.h +++ /dev/null @@ -1,91 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -#ifndef VEHICLE_DEMO_H -#define VEHICLE_DEMO_H - -class btVehicleTuning; -struct btVehicleRaycaster; -class btCollisionShape; - -#include "BulletDynamics/Vehicle/btRaycastVehicle.h" - -#include "GlutDemoApplication.h" - -///VehicleDemo shows how to setup and use the built-in raycast vehicle -class VehicleDemo : public GlutDemoApplication -{ - public: - - btRigidBody* m_carChassis; - - btAlignedObjectArray m_collisionShapes; - - class btBroadphaseInterface* m_overlappingPairCache; - - class btCollisionDispatcher* m_dispatcher; - - class btConstraintSolver* m_constraintSolver; - - class btDefaultCollisionConfiguration* m_collisionConfiguration; - - class btTriangleIndexVertexArray* m_indexVertexArrays; - - btVector3* m_vertices; - - - btRaycastVehicle::btVehicleTuning m_tuning; - btVehicleRaycaster* m_vehicleRayCaster; - btRaycastVehicle* m_vehicle; - btCollisionShape* m_wheelShape; - - float m_cameraHeight; - - float m_minCameraDistance; - float m_maxCameraDistance; - - - VehicleDemo(); - - virtual ~VehicleDemo(); - - virtual void clientMoveAndDisplay(); - - virtual void clientResetScene(); - - virtual void displayCallback(); - - ///a very basic camera following the vehicle - virtual void updateCamera(); - - virtual void specialKeyboard(int key, int x, int y); - - virtual void specialKeyboardUp(int key, int x, int y); - - void renderme(); - - void initPhysics(); - - static DemoApplication* Create() - { - VehicleDemo* demo = new VehicleDemo(); - demo->myinit(); - demo->initPhysics(); - return demo; - } -}; - -#endif //VEHICLE_DEMO_H - - diff --git a/Demos/VehicleDemo/heightfield128x128.cpp b/Demos/VehicleDemo/heightfield128x128.cpp deleted file mode 100644 index 46d2bab76..000000000 --- a/Demos/VehicleDemo/heightfield128x128.cpp +++ /dev/null @@ -1,1641 +0,0 @@ -char MyHeightfield[]={char(136),char(125),char(117),char(93),char(79),char(89),char(81),char(67),char(61),char(49), -char(48),char(52),char(63),char(75),char(78),char(88),char(111),char(126),char(130),char(116), -char(109),char(113),char(118),char(142),char(161),char(185),char(198),char(198),char(197),char(204), -char(200),char(191),char(190),char(181),char(166),char(144),char(117),char(96),char(86),char(95), -char(99),char(86),char(59),char(52),char(49),char(48),char(50),char(50),char(51),char(56), -char(67),char(70),char(73),char(79),char(91),char(103),char(111),char(125),char(132),char(139), -char(163),char(185),char(198),char(207),char(207),char(191),char(169),char(151),char(134),char(114), -char(96),char(93),char(93),char(89),char(93),char(93),char(81),char(68),char(61),char(53), -char(43),char(33),char(28),char(34),char(43),char(53),char(70),char(69),char(61),char(57), -char(54),char(56),char(65),char(65),char(75),char(93),char(105),char(114),char(110),char(124), -char(147),char(157),char(174),char(186),char(198),char(210),char(229),char(233),char(242),char(251), -char(250),char(239),char(229),char(220),char(204),char(181),char(158),char(156),char(158),char(165), -char(159),char(158),char(156),char(143),char(127),char(118),char(121),char(124),char(133),char(130), -char(119),char(101),char(89),char(83),char(83),char(69),char(58),char(44),char(45),char(54), -char(64),char(73),char(70),char(80),char(102),char(121),char(121),char(105),char(102),char(106), -char(114),char(142),char(156),char(174),char(197),char(204),char(201),char(197),char(190),char(187), -char(187),char(178),char(159),char(131),char(105),char(92),char(84),char(99),char(101),char(83), -char(56),char(45),char(37),char(35),char(38),char(37),char(46),char(60),char(71),char(73), -char(72),char(71),char(76),char(98),char(112),char(135),char(150),char(156),char(169),char(184), -char(194),char(202),char(216),char(209),char(187),char(172),char(155),char(126),char(100),char(93), -char(91),char(94),char(99),char(96),char(85),char(78),char(71),char(61),char(56),char(45), -char(37),char(42),char(51),char(63),char(74),char(75),char(72),char(59),char(47),char(50), -char(55),char(56),char(66),char(77),char(86),char(92),char(108),char(124),char(140),char(147), -char(162),char(181),char(193),char(208),char(227),char(233),char(241),char(246),char(241),char(230), -char(218),char(206),char(192),char(169),char(149),char(147),char(141),char(144),char(143),char(153), -char(149),char(137),char(129),char(119),char(126),char(118),char(150),char(136),char(122),char(119), -char(116),char(98),char(94),char(82),char(66),char(54),char(54),char(59),char(69),char(71), -char(82),char(94),char(110),char(114),char(116),char(110),char(106),char(106),char(121),char(141), -char(143),char(156),char(178),char(195),char(196),char(187),char(185),char(188),char(188),char(171), -char(146),char(120),char(99),char(82),char(82),char(98),char(104),char(89),char(65),char(46), -char(35),char(28),char(29),char(37),char(43),char(54),char(70),char(72),char(65),char(62), -char(71),char(94),char(115),char(131),char(151),char(170),char(177),char(183),char(193),char(207), -char(222),char(219),char(203),char(185),char(167),char(142),char(118),char(113),char(116),char(116), -char(115),char(104),char(92),char(90),char(84),char(76),char(67),char(59),char(52),char(57), -char(68),char(73),char(82),char(83),char(70),char(62),char(53),char(50),char(52),char(52), -char(57),char(58),char(63),char(74),char(101),char(120),char(134),char(143),char(160),char(175), -char(197),char(210),char(224),char(230),char(230),char(227),char(227),char(224),char(216),char(204), -char(187),char(173),char(156),char(150),char(141),char(141),char(141),char(146),char(138),char(138), -char(121),char(116),char(130),char(117),char(178),char(156),char(141),char(143),char(139),char(120), -char(105),char(89),char(79),char(67),char(63),char(75),char(79),char(82),char(109),char(129), -char(129),char(124),char(120),char(128),char(127),char(122),char(131),char(139),char(146),char(158), -char(167),char(181),char(188),char(190),char(185),char(178),char(174),char(164),char(142),char(108), -char(87),char(74),char(83),char(108),char(106),char(87),char(66),char(47),char(35),char(28), -char(30),char(39),char(44),char(49),char(54),char(50),char(45),char(54),char(67),char(86), -char(108),char(124),char(148),char(172),char(186),char(197),char(202),char(209),char(220),char(220), -char(202),char(176),char(161),char(152),char(145),char(139),char(144),char(145),char(128),char(111), -char(104),char(108),char(111),char(99),char(81),char(71),char(59),char(56),char(63),char(70), -char(82),char(79),char(68),char(61),char(50),char(50),char(56),char(52),char(42),char(42), -char(58),char(76),char(103),char(116),char(125),char(144),char(164),char(178),char(197),char(202), -char(213),char(219),char(223),char(213),char(211),char(209),char(204),char(193),char(176),char(169), -char(171),char(166),char(153),char(143),char(134),char(138),char(131),char(138),char(124),char(120), -char(135),char(132),char(200),char(179),char(162),char(160),char(155),char(135),char(107),char(94), -char(85),char(77),char(78),char(95),char(107),char(109),char(125),char(139),char(145),char(140), -char(132),char(140),char(145),char(141),char(143),char(141),char(141),char(146),char(150),char(161), -char(172),char(183),char(177),char(171),char(169),char(157),char(136),char(106),char(85),char(76), -char(80),char(98),char(96),char(84),char(62),char(37),char(29),char(28),char(32),char(37), -char(40),char(40),char(39),char(40),char(44),char(53),char(68),char(80),char(92),char(113), -char(147),char(175),char(192),char(204),char(208),char(213),char(215),char(210),char(188),char(164), -char(158),char(163),char(167),char(161),char(155),char(154),char(149),char(139),char(129),char(125), -char(128),char(113),char(84),char(70),char(56),char(46),char(48),char(60),char(72),char(71), -char(61),char(52),char(47),char(46),char(49),char(48),char(37),char(38),char(54),char(82), -char(109),char(111),char(121),char(142),char(159),char(171),char(187),char(191),char(207),char(217), -char(213),char(196),char(185),char(193),char(192),char(186),char(183),char(180),char(185),char(184), -char(161),char(146),char(150),char(156),char(148),char(145),char(138),char(140),char(140),char(142), -char(230),char(208),char(192),char(182),char(171),char(142),char(126),char(118),char(110),char(104), -char(99),char(107),char(115),char(125),char(134),char(142),char(147),char(139),char(143),char(154), -char(155),char(153),char(147),char(145),char(142),char(131),char(120),char(131),char(138),char(144), -char(148),char(147),char(152),char(149),char(123),char(100),char(81),char(74),char(85),char(90), -char(91),char(82),char(59),char(41),char(29),char(29),char(36),char(40),char(43),char(45), -char(41),char(40),char(44),char(58),char(74),char(79),char(93),char(115),char(144),char(165), -char(178),char(195),char(206),char(206),char(207),char(206),char(182),char(165),char(165),char(167), -char(172),char(177),char(172),char(163),char(158),char(162),char(164),char(153),char(149),char(127), -char(89),char(73),char(58),char(47),char(46),char(54),char(59),char(55),char(54),char(51), -char(49),char(45),char(48),char(45),char(43),char(48),char(56),char(80),char(100),char(97), -char(108),char(136),char(160),char(177),char(186),char(194),char(195),char(199),char(195),char(183), -char(178),char(187),char(186),char(179),char(183),char(179),char(188),char(187),char(170),char(162), -char(164),char(161),char(163),char(159),char(161),char(160),char(144),char(139),char(248),char(231), -char(213),char(200),char(188),char(170),char(157),char(156),char(149),char(138),char(132),char(127), -char(132),char(142),char(150),char(151),char(149),char(146),char(147),char(159),char(149),char(143), -char(138),char(136),char(138),char(125),char(105),char(95),char(102),char(113),char(124),char(124), -char(124),char(132),char(119),char(99),char(81),char(71),char(82),char(88),char(82),char(72), -char(64),char(47),char(38),char(40),char(39),char(41),char(43),char(45),char(44),char(37), -char(40),char(56),char(73),char(84),char(100),char(112),char(131),char(154),char(168),char(185), -char(201),char(210),char(211),char(204),char(188),char(175),char(170),char(171),char(182),char(195), -char(196),char(183),char(168),char(169),char(179),char(172),char(160),char(133),char(97),char(68), -char(51),char(48),char(47),char(46),char(42),char(44),char(52),char(52),char(53),char(54), -char(56),char(57),char(58),char(66),char(65),char(76),char(93),char(95),char(104),char(124), -char(154),char(181),char(188),char(188),char(190),char(185),char(180),char(173),char(172),char(172), -char(171),char(171),char(163),char(170),char(180),char(188),char(180),char(175),char(171),char(166), -char(173),char(186),char(188),char(172),char(155),char(131),char(248),char(240),char(234),char(217), -char(207),char(193),char(177),char(178),char(178),char(168),char(157),char(159),char(160),char(153), -char(147),char(143),char(143),char(148),char(149),char(156),char(146),char(137),char(131),char(122), -char(119),char(107),char(87),char(84),char(89),char(100),char(116),char(113),char(110),char(107), -char(101),char(94),char(75),char(65),char(67),char(67),char(58),char(52),char(52),char(50), -char(52),char(51),char(46),char(46),char(44),char(45),char(44),char(42),char(46),char(54), -char(70),char(81),char(89),char(109),char(128),char(143),char(161),char(187),char(205),char(211), -char(215),char(210),char(198),char(188),char(176),char(173),char(186),char(198),char(201),char(196), -char(185),char(183),char(180),char(162),char(148),char(136),char(108),char(73),char(50),char(41), -char(41),char(44),char(37),char(33),char(46),char(52),char(55),char(52),char(57),char(59), -char(64),char(76),char(82),char(82),char(93),char(103),char(105),char(127),char(159),char(173), -char(181),char(183),char(187),char(179),char(162),char(151),char(153),char(153),char(149),char(164), -char(161),char(164),char(180),char(187),char(182),char(178),char(175),char(177),char(181),char(193), -char(204),char(191),char(172),char(140),char(242),char(238),char(235),char(224),char(220),char(207), -char(197),char(196),char(192),char(188),char(182),char(173),char(166),char(153),char(145),char(133), -char(126),char(125),char(132),char(135),char(129),char(114),char(115),char(107),char(104),char(100), -char(82),char(72),char(75),char(83),char(107),char(116),char(105),char(87),char(82),char(80), -char(68),char(57),char(47),char(45),char(41),char(39),char(39),char(41),char(46),char(50), -char(47),char(47),char(49),char(56),char(58),char(55),char(52),char(56),char(65),char(82), -char(94),char(109),char(122),char(138),char(167),char(195),char(211),char(212),char(215),char(207), -char(197),char(191),char(181),char(176),char(193),char(203),char(200),char(197),char(193),char(189), -char(183),char(162),char(144),char(128),char(109),char(78),char(51),char(41),char(40),char(39), -char(32),char(28),char(35),char(41),char(47),char(51),char(63),char(68),char(75),char(77), -char(79),char(77),char(90),char(106),char(115),char(126),char(145),char(164),char(174),char(181), -char(187),char(171),char(155),char(142),char(136),char(127),char(133),char(148),char(154),char(164), -char(175),char(181),char(185),char(180),char(181),char(181),char(185),char(200),char(210),char(201), -char(180),char(148),char(242),char(236),char(235),char(229),char(222),char(215),char(205),char(205), -char(202),char(205),char(206),char(196),char(176),char(156),char(142),char(132),char(114),char(97), -char(109),char(119),char(118),char(104),char(92),char(95),char(98),char(86),char(66),char(58), -char(60),char(70),char(87),char(97),char(81),char(65),char(62),char(59),char(54),char(44), -char(43),char(39),char(34),char(31),char(31),char(34),char(40),char(45),char(44),char(44), -char(48),char(58),char(70),char(64),char(62),char(65),char(71),char(79),char(93),char(111), -char(128),char(145),char(173),char(194),char(207),char(215),char(209),char(204),char(201),char(193), -char(180),char(182),char(199),char(208),char(201),char(195),char(190),char(183),char(175),char(159), -char(139),char(125),char(106),char(80),char(59),char(44),char(37),char(33),char(30),char(27), -char(27),char(32),char(43),char(58),char(65),char(76),char(76),char(75),char(79),char(85), -char(94),char(107),char(114),char(114),char(135),char(143),char(159),char(170),char(174),char(169), -char(158),char(143),char(121),char(115),char(126),char(149),char(161),char(180),char(186),char(190), -char(181),char(186),char(190),char(191),char(203),char(211),char(220),char(212),char(192),char(162), -char(244),char(244),char(244),char(239),char(229),char(218),char(209),char(215),char(215),char(208), -char(215),char(207),char(188),char(166),char(151),char(132),char(109),char(88),char(88),char(100), -char(103),char(94),char(81),char(91),char(82),char(62),char(54),char(51),char(50),char(57), -char(67),char(69),char(54),char(42),char(43),char(42),char(43),char(41),char(40),char(35), -char(34),char(33),char(28),char(31),char(35),char(35),char(39),char(45),char(53),char(62), -char(73),char(79),char(78),char(72),char(66),char(71),char(81),char(106),char(135),char(158), -char(173),char(188),char(196),char(205),char(204),char(202),char(202),char(188),char(180),char(184), -char(198),char(206),char(200),char(202),char(200),char(190),char(170),char(144),char(130),char(121), -char(105),char(77),char(54),char(40),char(35),char(35),char(32),char(28),char(25),char(29), -char(43),char(60),char(66),char(70),char(74),char(82),char(87),char(90),char(102),char(107), -char(104),char(108),char(114),char(121),char(139),char(165),char(168),char(162),char(152),char(141), -char(124),char(120),char(126),char(147),char(169),char(180),char(185),char(191),char(180),char(181), -char(193),char(201),char(209),char(218),char(226),char(217),char(192),char(165),char(247),char(248), -char(248),char(248),char(239),char(225),char(220),char(219),char(220),char(215),char(221),char(212), -char(189),char(170),char(154),char(122),char(97),char(84),char(85),char(90),char(94),char(93), -char(77),char(81),char(70),char(48),char(42),char(38),char(36),char(41),char(46),char(47), -char(38),char(35),char(33),char(36),char(41),char(41),char(35),char(35),char(32),char(31), -char(29),char(33),char(36),char(38),char(45),char(52),char(53),char(63),char(74),char(84), -char(91),char(80),char(62),char(63),char(78),char(102),char(131),char(153),char(168),char(183), -char(193),char(202),char(193),char(183),char(181),char(177),char(173),char(176),char(191),char(199), -char(192),char(197),char(203),char(193),char(175),char(142),char(122),char(117),char(99),char(67), -char(43),char(35),char(36),char(36),char(31),char(26),char(26),char(33),char(37),char(52), -char(67),char(71),char(70),char(70),char(79),char(96),char(107),char(109),char(103),char(100), -char(100),char(117),char(131),char(151),char(161),char(148),char(135),char(134),char(128),char(133), -char(139),char(151),char(171),char(180),char(184),char(187),char(186),char(193),char(193),char(207), -char(213),char(218),char(216),char(207),char(187),char(175),char(251),char(251),char(250),char(252), -char(251),char(238),char(231),char(228),char(224),char(224),char(222),char(204),char(178),char(159), -char(147),char(121),char(104),char(87),char(82),char(79),char(82),char(77),char(58),char(55), -char(54),char(40),char(34),char(30),char(28),char(34),char(36),char(31),char(33),char(38), -char(34),char(31),char(33),char(35),char(30),char(32),char(31),char(29),char(29),char(37), -char(47),char(49),char(51),char(56),char(57),char(68),char(78),char(81),char(84),char(76), -char(65),char(62),char(65),char(87),char(111),char(134),char(153),char(164),char(174),char(184), -char(178),char(178),char(178),char(166),char(161),char(164),char(175),char(181),char(173),char(176), -char(183),char(181),char(166),char(133),char(113),char(105),char(87),char(63),char(43),char(36), -char(37),char(35),char(35),char(30),char(27),char(36),char(41),char(46),char(63),char(72), -char(69),char(70),char(78),char(101),char(104),char(102),char(102),char(101),char(98),char(115), -char(136),char(141),char(148),char(145),char(131),char(133),char(135),char(143),char(155),char(152), -char(170),char(183),char(188),char(185),char(196),char(207),char(207),char(211),char(209),char(211), -char(208),char(204),char(188),char(179),char(252),char(255),char(253),char(253),char(252),char(247), -char(246),char(241),char(235),char(229),char(218),char(196),char(167),char(153),char(143),char(128), -char(105),char(87),char(77),char(79),char(73),char(65),char(46),char(38),char(36),char(31), -char(24),char(24),char(19),char(18),char(22),char(24),char(25),char(27),char(29),char(32), -char(31),char(27),char(23),char(23),char(24),char(29),char(38),char(45),char(52),char(57), -char(63),char(62),char(67),char(86),char(98),char(90),char(80),char(69),char(61),char(60), -char(66),char(90),char(116),char(133),char(148),char(161),char(171),char(167),char(159),char(166), -char(174),char(169),char(166),char(170),char(173),char(169),char(164),char(165),char(169),char(173), -char(159),char(138),char(115),char(101),char(82),char(63),char(46),char(38),char(33),char(31), -char(30),char(28),char(26),char(35),char(47),char(55),char(59),char(70),char(73),char(76), -char(85),char(93),char(101),char(99),char(104),char(112),char(108),char(115),char(122),char(131), -char(127),char(124),char(117),char(126),char(135),char(141),char(151),char(163),char(167),char(173), -char(171),char(179),char(190),char(214),char(217),char(212),char(206),char(201),char(195),char(194), -char(193),char(176),char(247),char(250),char(254),char(251),char(249),char(251),char(254),char(248), -char(238),char(228),char(216),char(187),char(169),char(153),char(147),char(137),char(106),char(79), -char(63),char(66),char(60),char(49),char(39),char(31),char(24),char(19),char(13),char(13), -char(10),char(8),char(11),char(16),char(19),char(21),char(27),char(30),char(27),char(20), -char(18),char(18),char(23),char(31),char(38),char(45),char(52),char(59),char(67),char(70), -char(81),char(99),char(105),char(100),char(85),char(74),char(69),char(67),char(83),char(103), -char(115),char(126),char(136),char(155),char(170),char(160),char(145),char(157),char(179),char(184), -char(180),char(180),char(179),char(173),char(173),char(169),char(165),char(165),char(157),char(141), -char(119),char(102),char(85),char(69),char(49),char(36),char(27),char(25),char(23),char(29), -char(33),char(35),char(47),char(60),char(62),char(65),char(71),char(79),char(94),char(97), -char(103),char(104),char(107),char(109),char(112),char(120),char(122),char(127),char(124),char(114), -char(111),char(117),char(127),char(137),char(147),char(165),char(172),char(164),char(162),char(173), -char(190),char(209),char(220),char(215),char(206),char(193),char(177),char(172),char(176),char(174), -char(236),char(245),char(249),char(246),char(243),char(247),char(252),char(246),char(236),char(216), -char(203),char(183),char(165),char(154),char(153),char(147),char(113),char(79),char(59),char(50), -char(48),char(42),char(35),char(23),char(14),char(11),char(6),char(6),char(3),char(2), -char(4),char(10),char(15),char(20),char(25),char(25),char(17),char(15),char(19),char(24), -char(22),char(25),char(32),char(40),char(50),char(63),char(71),char(80),char(95),char(110), -char(111),char(105),char(95),char(88),char(90),char(93),char(110),char(118),char(114),char(120), -char(128),char(143),char(158),char(160),char(155),char(173),char(204),char(214),char(209),char(201), -char(195),char(191),char(187),char(176),char(158),char(150),char(147),char(135),char(114),char(107), -char(93),char(76),char(57),char(35),char(22),char(21),char(21),char(25),char(35),char(40), -char(46),char(58),char(64),char(66),char(73),char(85),char(91),char(94),char(113),char(115), -char(109),char(105),char(112),char(119),char(122),char(126),char(125),char(118),char(111),char(116), -char(126),char(133),char(146),char(159),char(168),char(168),char(171),char(178),char(194),char(212), -char(220),char(208),char(199),char(186),char(175),char(157),char(156),char(163),char(227),char(241), -char(244),char(241),char(234),char(242),char(246),char(244),char(229),char(207),char(197),char(181), -char(166),char(155),char(152),char(133),char(109),char(71),char(48),char(42),char(35),char(31), -char(28),char(15),char(7),char(9),char(6),char(4),char(3),char(2),char(4),char(8), -char(14),char(17),char(19),char(19),char(17),char(17),char(20),char(25),char(27),char(26), -char(35),char(43),char(54),char(68),char(73),char(82),char(99),char(105),char(105),char(100), -char(94),char(98),char(103),char(113),char(122),char(118),char(120),char(129),char(134),char(147), -char(159),char(161),char(164),char(188),char(216),char(228),char(230),char(226),char(218),char(213), -char(207),char(201),char(179),char(150),char(142),char(137),char(121),char(105),char(93),char(82), -char(69),char(45),char(23),char(18),char(23),char(29),char(35),char(44),char(57),char(67), -char(74),char(74),char(76),char(84),char(86),char(90),char(109),char(112),char(112),char(116), -char(126),char(127),char(121),char(121),char(120),char(114),char(106),char(105),char(114),char(125), -char(138),char(155),char(165),char(175),char(167),char(175),char(195),char(206),char(213),char(207), -char(192),char(168),char(155),char(135),char(133),char(138),char(205),char(228),char(234),char(230), -char(224),char(229),char(230),char(223),char(209),char(203),char(192),char(180),char(164),char(152), -char(147),char(126),char(94),char(67),char(50),char(33),char(25),char(21),char(19),char(13), -char(7),char(7),char(6),char(3),char(2),char(2),char(3),char(6),char(8),char(13), -char(15),char(19),char(20),char(19),char(20),char(27),char(35),char(35),char(40),char(43), -char(48),char(55),char(65),char(82),char(97),char(99),char(92),char(94),char(99),char(110), -char(122),char(138),char(143),char(141),char(146),char(157),char(148),char(147),char(158),char(168), -char(183),char(202),char(223),char(232),char(233),char(235),char(236),char(229),char(223),char(214), -char(189),char(156),char(140),char(131),char(120),char(108),char(96),char(82),char(74),char(54), -char(30),char(23),char(27),char(32),char(43),char(49),char(60),char(75),char(86),char(85), -char(78),char(77),char(80),char(87),char(98),char(103),char(110),char(126),char(130),char(127), -char(123),char(123),char(124),char(121),char(113),char(106),char(105),char(112),char(121),char(141), -char(153),char(169),char(172),char(186),char(199),char(206),char(212),char(207),char(182),char(157), -char(142),char(135),char(126),char(116),char(189),char(205),char(215),char(217),char(218),char(206), -char(209),char(202),char(195),char(193),char(186),char(174),char(165),char(153),char(133),char(118), -char(93),char(68),char(43),char(26),char(19),char(15),char(12),char(9),char(8),char(6), -char(7),char(3),char(2),char(1),char(3),char(4),char(4),char(7),char(10),char(13), -char(15),char(22),char(25),char(29),char(44),char(46),char(42),char(44),char(41),char(48), -char(64),char(80),char(95),char(99),char(99),char(99),char(100),char(115),char(137),char(148), -char(156),char(165),char(168),char(176),char(176),char(157),char(151),char(171),char(194),char(207), -char(224),char(232),char(232),char(237),char(234),char(229),char(221),char(204),char(181),char(154), -char(144),char(141),char(129),char(111),char(98),char(89),char(76),char(55),char(33),char(27), -char(29),char(34),char(49),char(57),char(64),char(78),char(82),char(86),char(80),char(69), -char(67),char(68),char(76),char(84),char(94),char(106),char(123),char(124),char(127),char(123), -char(124),char(125),char(109),char(101),char(102),char(109),char(110),char(122),char(146),char(159), -char(178),char(191),char(189),char(196),char(203),char(186),char(162),char(151),char(140),char(128), -char(124),char(106),char(175),char(181),char(190),char(196),char(207),char(195),char(195),char(190), -char(182),char(182),char(184),char(173),char(155),char(140),char(123),char(112),char(97),char(68), -char(38),char(24),char(13),char(8),char(5),char(5),char(5),char(5),char(6),char(3), -char(2),char(2),char(3),char(3),char(3),char(4),char(7),char(10),char(13),char(19), -char(26),char(33),char(50),char(56),char(46),char(38),char(36),char(49),char(65),char(72), -char(88),char(98),char(110),char(115),char(110),char(121),char(147),char(165),char(166),char(170), -char(177),char(180),char(184),char(177),char(167),char(180),char(200),char(210),char(221),char(229), -char(230),char(232),char(224),char(218),char(211),char(187),char(163),char(141),char(133),char(141), -char(134),char(113),char(90),char(79),char(74),char(54),char(32),char(26),char(27),char(32), -char(46),char(57),char(59),char(62),char(64),char(71),char(70),char(59),char(55),char(58), -char(68),char(76),char(84),char(91),char(107),char(112),char(110),char(112),char(115),char(117), -char(110),char(100),char(93),char(99),char(106),char(108),char(126),char(148),char(176),char(182), -char(175),char(178),char(174),char(161),char(142),char(126),char(119),char(116),char(111),char(104), -char(162),char(161),char(174),char(176),char(188),char(186),char(176),char(172),char(172),char(163), -char(170),char(161),char(141),char(124),char(118),char(113),char(101),char(71),char(42),char(21), -char(13),char(8),char(6),char(5),char(4),char(5),char(5),char(3),char(2),char(3), -char(2),char(4),char(4),char(4),char(7),char(8),char(10),char(15),char(23),char(38), -char(56),char(59),char(49),char(44),char(47),char(59),char(74),char(80),char(91),char(106), -char(113),char(112),char(116),char(129),char(149),char(167),char(169),char(170),char(170),char(175), -char(182),char(175),char(171),char(183),char(197),char(204),char(213),char(222),char(222),char(222), -char(225),char(218),char(203),char(176),char(154),char(142),char(136),char(141),char(136),char(114), -char(87),char(72),char(68),char(55),char(38),char(31),char(31),char(35),char(46),char(55), -char(56),char(59),char(61),char(64),char(66),char(62),char(54),char(53),char(56),char(68), -char(73),char(74),char(89),char(91),char(100),char(113),char(112),char(102),char(104),char(100), -char(94),char(102),char(96),char(95),char(105),char(128),char(155),char(160),char(164),char(159), -char(141),char(130),char(127),char(116),char(105),char(107),char(111),char(112),char(140),char(139), -char(150),char(155),char(159),char(164),char(156),char(153),char(149),char(133),char(142),char(135), -char(118),char(99),char(94),char(90),char(77),char(59),char(35),char(19),char(11),char(9), -char(4),char(4),char(4),char(6),char(5),char(3),char(4),char(5),char(5),char(6), -char(7),char(6),char(5),char(5),char(8),char(13),char(23),char(37),char(52),char(58), -char(57),char(55),char(57),char(63),char(79),char(93),char(96),char(102),char(110),char(113), -char(125),char(142),char(159),char(176),char(183),char(178),char(173),char(174),char(169),char(169), -char(175),char(184),char(196),char(210),char(217),char(219),char(219),char(218),char(218),char(210), -char(191),char(171),char(154),char(147),char(145),char(133),char(126),char(109),char(86),char(76), -char(70),char(57),char(46),char(45),char(49),char(54),char(62),char(63),char(67),char(70), -char(68),char(68),char(76),char(75),char(69),char(63),char(55),char(58),char(64),char(66), -char(78),char(82),char(87),char(97),char(96),char(101),char(109),char(107),char(94),char(98), -char(90),char(88),char(89),char(112),char(138),char(145),char(149),char(137),char(118),char(117), -char(112),char(106),char(103),char(105),char(124),char(120),char(133),char(128),char(129),char(133), -char(141),char(138),char(134),char(132),char(122),char(109),char(97),char(98),char(97),char(84), -char(74),char(69),char(61),char(57),char(35),char(20),char(11),char(7),char(6),char(7), -char(8),char(8),char(8),char(7),char(9),char(9),char(10),char(10),char(12),char(13), -char(10),char(8),char(9),char(13),char(20),char(29),char(40),char(52),char(60),char(55), -char(60),char(68),char(80),char(97),char(97),char(99),char(109),char(117),char(135),char(151), -char(170),char(188),char(193),char(191),char(187),char(167),char(156),char(161),char(171),char(184), -char(202),char(211),char(209),char(215),char(218),char(218),char(209),char(195),char(182),char(173), -char(160),char(152),char(146),char(132),char(125),char(114),char(100),char(83),char(65),char(56), -char(57),char(59),char(62),char(71),char(74),char(74),char(74),char(75),char(71),char(70), -char(81),char(83),char(80),char(68),char(57),char(63),char(67),char(71),char(65),char(73), -char(83),char(93),char(96),char(106),char(111),char(95),char(85),char(82),char(77),char(82), -char(86),char(97),char(116),char(133),char(146),char(127),char(116),char(112),char(101),char(102), -char(106),char(117),char(120),char(119),char(126),char(121),char(120),char(120),char(125),char(124), -char(118),char(115),char(104),char(86),char(76),char(78),char(80),char(73),char(65),char(63), -char(61),char(57),char(36),char(23),char(18),char(13),char(8),char(9),char(12),char(15), -char(15),char(14),char(17),char(16),char(17),char(19),char(23),char(28),char(18),char(13), -char(14),char(13),char(19),char(25),char(34),char(54),char(66),char(61),char(65),char(75), -char(82),char(89),char(94),char(103),char(113),char(120),char(133),char(151),char(177),char(195), -char(202),char(206),char(196),char(170),char(160),char(163),char(171),char(192),char(206),char(206), -char(204),char(207),char(216),char(220),char(205),char(191),char(179),char(172),char(166),char(157), -char(145),char(124),char(112),char(116),char(110),char(83),char(65),char(56),char(59),char(68), -char(77),char(84),char(89),char(94),char(92),char(84),char(84),char(85),char(91),char(91), -char(90),char(77),char(61),char(68),char(76),char(79),char(75),char(86),char(95),char(97), -char(94),char(98),char(90),char(81),char(69),char(67),char(73),char(77),char(79),char(78), -char(90),char(117),char(135),char(119),char(104),char(103),char(100),char(100),char(110),char(112), -char(108),char(113),char(119),char(112),char(113),char(116),char(123),char(121),char(112),char(106), -char(92),char(75),char(70),char(65),char(63),char(58),char(53),char(57),char(59),char(54), -char(36),char(26),char(22),char(19),char(11),char(11),char(15),char(25),char(29),char(30), -char(29),char(30),char(28),char(31),char(37),char(36),char(24),char(19),char(16),char(15), -char(21),char(28),char(41),char(51),char(57),char(63),char(74),char(84),char(89),char(86), -char(88),char(94),char(101),char(110),char(129),char(160),char(188),char(196),char(204),char(214), -char(210),char(191),char(178),char(171),char(176),char(196),char(206),char(208),char(205),char(204), -char(219),char(224),char(213),char(193),char(174),char(157),char(149),char(143),char(133),char(117), -char(108),char(110),char(111),char(89),char(68),char(54),char(52),char(65),char(79),char(92), -char(103),char(107),char(104),char(99),char(93),char(99),char(106),char(111),char(105),char(89), -char(68),char(68),char(78),char(84),char(90),char(94),char(95),char(95),char(81),char(75), -char(72),char(70),char(60),char(59),char(65),char(74),char(78),char(74),char(92),char(106), -char(114),char(105),char(93),char(99),char(106),char(106),char(112),char(106),char(97),char(105), -char(107),char(104),char(101),char(109),char(120),char(115),char(117),char(106),char(82),char(66), -char(66),char(61),char(53),char(45),char(44),char(46),char(56),char(62),char(44),char(33), -char(28),char(21),char(18),char(18),char(23),char(35),char(45),char(50),char(47),char(42), -char(43),char(45),char(49),char(48),char(36),char(28),char(22),char(23),char(24),char(34), -char(46),char(48),char(51),char(65),char(75),char(78),char(80),char(75),char(79),char(89), -char(93),char(103),char(130),char(161),char(187),char(194),char(208),char(225),char(224),char(211), -char(199),char(179),char(172),char(186),char(196),char(202),char(209),char(212),char(214),char(214), -char(207),char(194),char(178),char(153),char(147),char(148),char(135),char(113),char(105),char(109), -char(102),char(93),char(79),char(63),char(58),char(72),char(87),char(100),char(114),char(118), -char(117),char(109),char(107),char(113),char(111),char(108),char(107),char(88),char(74),char(79), -char(85),char(87),char(97),char(91),char(85),char(91),char(74),char(70),char(67),char(62), -char(58),char(58),char(61),char(73),char(69),char(71),char(88),char(101),char(113),char(110), -char(104),char(113),char(109),char(110),char(116),char(114),char(102),char(99),char(91),char(88), -char(84),char(89),char(101),char(108),char(110),char(105),char(80),char(71),char(60),char(57), -char(49),char(42),char(44),char(42),char(51),char(56),char(55),char(43),char(31),char(27), -char(29),char(30),char(37),char(50),char(60),char(59),char(53),char(50),char(51),char(52), -char(57),char(56),char(49),char(41),char(35),char(33),char(33),char(44),char(50),char(48), -char(54),char(67),char(79),char(78),char(69),char(63),char(65),char(76),char(81),char(92), -char(118),char(151),char(176),char(188),char(203),char(220),char(224),char(217),char(210),char(191), -char(174),char(173),char(186),char(195),char(203),char(213),char(208),char(204),char(198),char(194), -char(187),char(171),char(154),char(146),char(132),char(112),char(111),char(115),char(106),char(93), -char(81),char(72),char(75),char(98),char(115),char(122),char(131),char(132),char(138),char(134), -char(126),char(120),char(119),char(118),char(109),char(94),char(82),char(88),char(90),char(94), -char(96),char(82),char(79),char(79),char(74),char(71),char(64),char(53),char(54),char(60), -char(63),char(69),char(59),char(64),char(82),char(93),char(109),char(115),char(117),char(117), -char(115),char(107),char(115),char(114),char(113),char(107),char(62),char(65),char(69),char(70), -char(86),char(98),char(109),char(98),char(78),char(66),char(58),char(56),char(49),char(41), -char(42),char(49),char(52),char(54),char(62),char(57),char(43),char(43),char(46),char(45), -char(50),char(68),char(68),char(57),char(54),char(52),char(50),char(52),char(58),char(57), -char(56),char(55),char(50),char(46),char(45),char(51),char(57),char(56),char(63),char(77), -char(88),char(80),char(62),char(57),char(63),char(66),char(71),char(90),char(117),char(145), -char(167),char(178),char(189),char(205),char(215),char(216),char(209),char(194),char(178),char(173), -char(181),char(188),char(200),char(206),char(196),char(192),char(197),char(194),char(187),char(175), -char(155),char(143),char(134),char(117),char(111),char(114),char(106),char(94),char(83),char(86), -char(98),char(116),char(139),char(147),char(142),char(141),char(147),char(150),char(144),char(135), -char(130),char(130),char(125),char(103),char(93),char(91),char(92),char(102),char(99),char(91), -char(89),char(82),char(80),char(79),char(69),char(60),char(66),char(69),char(67),char(69), -char(59),char(70),char(86),char(91),char(94),char(106),char(120),char(126),char(122),char(105), -char(105),char(106),char(105),char(105),char(42),char(50),char(58),char(69),char(78),char(83), -char(93),char(91),char(79),char(68),char(61),char(52),char(49),char(45),char(44),char(55), -char(64),char(63),char(67),char(66),char(59),char(63),char(70),char(64),char(64),char(73), -char(71),char(65),char(59),char(48),char(40),char(50),char(61),char(65),char(74),char(76), -char(62),char(49),char(51),char(59),char(69),char(78),char(84),char(93),char(92),char(81), -char(63),char(54),char(59),char(61),char(60),char(82),char(117),char(144),char(163),char(175), -char(183),char(195),char(201),char(198),char(198),char(200),char(191),char(183),char(183),char(188), -char(194),char(197),char(193),char(194),char(193),char(185),char(182),char(173),char(160),char(149), -char(141),char(121),char(105),char(102),char(100),char(91),char(85),char(101),char(130),char(143), -char(158),char(157),char(144),char(142),char(148),char(156),char(154),char(148),char(144),char(148), -char(138),char(105),char(100),char(98),char(95),char(109),char(114),char(112),char(109),char(97), -char(93),char(91),char(82),char(74),char(84),char(84),char(84),char(87),char(76),char(84), -char(88),char(96),char(87),char(97),char(112),char(115),char(118),char(112),char(114),char(111), -char(99),char(95),char(29),char(39),char(50),char(59),char(74),char(85),char(92),char(87), -char(82),char(73),char(72),char(66),char(66),char(63),char(56),char(68),char(77),char(79), -char(80),char(78),char(82),char(78),char(81),char(81),char(83),char(72),char(70),char(67), -char(62),char(49),char(41),char(45),char(59),char(77),char(85),char(79),char(64),char(58), -char(64),char(73),char(86),char(88),char(88),char(93),char(86),char(76),char(61),char(52), -char(52),char(51),char(53),char(78),char(113),char(141),char(159),char(172),char(175),char(185), -char(188),char(176),char(177),char(184),char(187),char(186),char(185),char(188),char(192),char(196), -char(196),char(198),char(190),char(176),char(173),char(168),char(161),char(160),char(157),char(136), -char(121),char(111),char(107),char(101),char(103),char(121),char(154),char(172),char(174),char(166), -char(156),char(145),char(143),char(153),char(156),char(152),char(155),char(155),char(139),char(118), -char(119),char(119),char(116),char(120),char(131),char(136),char(126),char(115),char(97),char(98), -char(94),char(92),char(101),char(93),char(98),char(102),char(95),char(91),char(90),char(97), -char(84),char(92),char(102),char(110),char(123),char(120),char(111),char(107),char(93),char(81), -char(28),char(40),char(53),char(58),char(70),char(86),char(87),char(83),char(82),char(78), -char(83),char(79),char(77),char(68),char(67),char(74),char(83),char(83),char(81),char(79), -char(87),char(85),char(91),char(90),char(90),char(81),char(75),char(71),char(70),char(68), -char(56),char(51),char(64),char(81),char(80),char(79),char(74),char(69),char(79),char(86), -char(93),char(90),char(96),char(92),char(81),char(65),char(54),char(50),char(48),char(46), -char(48),char(71),char(105),char(134),char(150),char(159),char(166),char(174),char(169),char(155), -char(146),char(158),char(180),char(187),char(185),char(183),char(183),char(188),char(193),char(192), -char(178),char(170),char(176),char(181),char(180),char(178),char(165),char(151),char(141),char(131), -char(125),char(123),char(124),char(142),char(173),char(186),char(182),char(179),char(171),char(161), -char(155),char(156),char(157),char(162),char(167),char(161),char(146),char(139),char(128),char(131), -char(136),char(141),char(153),char(151),char(136),char(129),char(113),char(110),char(107),char(104), -char(95),char(91),char(102),char(102),char(98),char(87),char(81),char(92),char(98),char(105), -char(102),char(104),char(110),char(104),char(97),char(95),char(90),char(77),char(36),char(43), -char(56),char(66),char(67),char(77),char(87),char(91),char(84),char(83),char(87),char(83), -char(76),char(69),char(74),char(82),char(86),char(81),char(85),char(87),char(93),char(97), -char(107),char(97),char(86),char(88),char(85),char(82),char(81),char(82),char(74),char(65), -char(74),char(85),char(82),char(79),char(78),char(78),char(86),char(88),char(92),char(89), -char(94),char(98),char(84),char(64),char(51),char(51),char(50),char(50),char(59),char(78), -char(105),char(125),char(134),char(144),char(153),char(152),char(146),char(136),char(128),char(142), -char(164),char(174),char(175),char(171),char(171),char(181),char(184),char(177),char(175),char(174), -char(177),char(181),char(184),char(181),char(167),char(157),char(150),char(148),char(149),char(149), -char(153),char(162),char(184),char(201),char(202),char(198),char(187),char(181),char(160),char(154), -char(163),char(172),char(167),char(156),char(149),char(140),char(126),char(130),char(140),char(154), -char(161),char(163),char(152),char(139),char(123),char(126),char(120),char(107),char(90),char(94), -char(104),char(102),char(94),char(88),char(87),char(99),char(119),char(112),char(96),char(96), -char(93),char(89),char(84),char(80),char(85),char(81),char(50),char(55),char(63),char(69), -char(74),char(85),char(92),char(91),char(87),char(92),char(96),char(96),char(90),char(78), -char(78),char(86),char(95),char(93),char(96),char(99),char(101),char(105),char(109),char(95), -char(95),char(103),char(106),char(105),char(105),char(96),char(95),char(88),char(87),char(93), -char(94),char(88),char(87),char(90),char(96),char(96),char(95),char(94),char(89),char(88), -char(85),char(79),char(69),char(70),char(66),char(61),char(75),char(90),char(105),char(117), -char(120),char(125),char(125),char(121),char(123),char(130),char(130),char(137),char(154),char(165), -char(166),char(162),char(167),char(176),char(177),char(174),char(176),char(176),char(172),char(171), -char(176),char(170),char(161),char(156),char(152),char(153),char(163),char(169),char(171),char(175), -char(189),char(209),char(219),char(226),char(217),char(202),char(174),char(152),char(147),char(155), -char(153),char(135),char(128),char(125),char(125),char(140),char(143),char(146),char(155),char(165), -char(160),char(156),char(140),char(132),char(130),char(122),char(109),char(112),char(104),char(94), -char(94),char(102),char(111),char(116),char(139),char(130),char(104),char(91),char(80),char(80), -char(78),char(78),char(85),char(80),char(63),char(68),char(73),char(79),char(93),char(101), -char(96),char(97),char(101),char(102),char(106),char(106),char(104),char(90),char(76),char(79), -char(93),char(107),char(109),char(111),char(108),char(106),char(103),char(107),char(116),char(121), -char(127),char(133),char(134),char(126),char(120),char(103),char(96),char(98),char(102),char(98), -char(95),char(99),char(101),char(99),char(93),char(89),char(74),char(71),char(73),char(75), -char(75),char(80),char(77),char(67),char(74),char(94),char(105),char(107),char(105),char(108), -char(105),char(102),char(112),char(128),char(131),char(133),char(141),char(150),char(155),char(152), -char(152),char(163),char(171),char(171),char(169),char(160),char(154),char(158),char(162),char(160), -char(157),char(154),char(155),char(159),char(163),char(177),char(190),char(196),char(203),char(216), -char(228),char(234),char(232),char(214),char(193),char(164),char(149),char(144),char(142),char(127), -char(118),char(128),char(135),char(142),char(139),char(138),char(156),char(171),char(178),char(185), -char(169),char(160),char(153),char(144),char(124),char(113),char(103),char(94),char(103),char(114), -char(118),char(121),char(141),char(141),char(119),char(93),char(73),char(69),char(76),char(89), -char(82),char(82),char(72),char(72),char(83),char(91),char(105),char(112),char(102),char(113), -char(117),char(110),char(116),char(109),char(110),char(99),char(82),char(74),char(89),char(106), -char(113),char(114),char(115),char(108),char(102),char(118),char(138),char(144),char(142),char(147), -char(150),char(152),char(142),char(128),char(111),char(101),char(102),char(106),char(99),char(95), -char(98),char(88),char(74),char(65),char(56),char(54),char(54),char(60),char(69),char(70), -char(72),char(71),char(80),char(94),char(93),char(89),char(94),char(100),char(97),char(98), -char(116),char(133),char(131),char(117),char(113),char(123),char(138),char(138),char(139),char(150), -char(163),char(167),char(160),char(151),char(150),char(149),char(143),char(147),char(156),char(162), -char(155),char(156),char(165),char(186),char(204),char(213),char(215),char(224),char(238),char(241), -char(235),char(221),char(202),char(173),char(154),char(140),char(134),char(120),char(116),char(139), -char(149),char(148),char(140),char(150),char(164),char(176),char(193),char(197),char(186),char(178), -char(172),char(164),char(140),char(123),char(112),char(103),char(101),char(111),char(113),char(113), -char(120),char(129),char(124),char(109),char(88),char(84),char(96),char(99),char(81),char(77), -char(84),char(86),char(89),char(94),char(110),char(120),char(117),char(128),char(133),char(132), -char(125),char(112),char(108),char(99),char(82),char(80),char(96),char(110),char(107),char(107), -char(114),char(113),char(112),char(125),char(143),char(144),char(145),char(152),char(160),char(162), -char(160),char(155),char(134),char(115),char(106),char(103),char(103),char(101),char(91),char(75), -char(59),char(47),char(40),char(37),char(37),char(43),char(52),char(57),char(65),char(72), -char(78),char(88),char(87),char(72),char(72),char(82),char(88),char(99),char(113),char(125), -char(121),char(101),char(92),char(102),char(117),char(130),char(138),char(143),char(153),char(155), -char(151),char(151),char(148),char(140),char(133),char(139),char(152),char(161),char(155),char(159), -char(173),char(191),char(213),char(224),char(227),char(235),char(243),char(244),char(238),char(225), -char(208),char(183),char(163),char(144),char(135),char(124),char(126),char(145),char(156),char(157), -char(160),char(157),char(162),char(169),char(192),char(195),char(187),char(182),char(176),char(171), -char(159),char(129),char(115),char(105),char(91),char(95),char(98),char(103),char(108),char(114), -char(128),char(131),char(116),char(112),char(113),char(103),char(86),char(81),char(95),char(100), -char(104),char(113),char(117),char(127),char(134),char(143),char(149),char(155),char(139),char(131), -char(117),char(106),char(88),char(80),char(86),char(101),char(102),char(108),char(109),char(116), -char(117),char(126),char(136),char(139),char(144),char(145),char(159),char(171),char(175),char(164), -char(150),char(134),char(111),char(92),char(93),char(101),char(97),char(82),char(63),char(49), -char(37),char(28),char(28),char(32),char(41),char(48),char(60),char(66),char(63),char(63), -char(68),char(64),char(56),char(62),char(74),char(91),char(110),char(113),char(107),char(92), -char(82),char(91),char(103),char(118),char(132),char(137),char(137),char(137),char(145),char(146), -char(144),char(134),char(128),char(142),char(150),char(150),char(155),char(159),char(176),char(201), -char(222),char(230),char(229),char(234),char(245),char(243),char(242),char(233),char(213),char(193), -char(167),char(142),char(136),char(137),char(147),char(159),char(162),char(166),char(174),char(167), -char(167),char(172),char(183),char(188),char(187),char(189),char(184),char(175),char(166),char(133), -char(108),char(100),char(88),char(75),char(82),char(83),char(93),char(115),char(133),char(133), -char(123),char(117),char(126),char(110),char(106),char(102),char(102),char(107),char(122),char(129), -char(130),char(139),char(140),char(138),char(144),char(157),char(150),char(149),char(131),char(117), -char(103),char(83),char(74),char(82),char(87),char(92),char(97),char(107),char(108),char(107), -char(119),char(124),char(138),char(147),char(162),char(175),char(186),char(177),char(159),char(143), -char(119),char(106),char(102),char(107),char(104),char(87),char(69),char(56),char(44),char(34), -char(30),char(34),char(39),char(39),char(45),char(51),char(48),char(48),char(54),char(56), -char(52),char(57),char(66),char(82),char(96),char(97),char(96),char(91),char(82),char(81), -char(95),char(119),char(140),char(148),char(138),char(142),char(153),char(150),char(147),char(135), -char(121),char(126),char(137),char(143),char(157),char(166),char(172),char(196),char(214),char(219), -char(220),char(231),char(244),char(248),char(241),char(231),char(202),char(184),char(165),char(143), -char(132),char(134),char(151),char(165),char(169),char(171),char(172),char(168),char(170),char(177), -char(182),char(191),char(197),char(196),char(190),char(181),char(166),char(143),char(124),char(109), -char(100),char(83),char(74),char(70),char(85),char(109),char(130),char(128),char(125),char(124), -char(124),char(119),char(121),char(120),char(92),char(104),char(129),char(135),char(141),char(149), -char(138),char(136),char(140),char(150),char(158),char(155),char(137),char(113),char(108),char(93), -char(77),char(65),char(70),char(71),char(81),char(88),char(92),char(93),char(107),char(116), -char(129),char(149),char(169),char(184),char(198),char(189),char(171),char(154),char(138),char(125), -char(113),char(106),char(99),char(83),char(70),char(67),char(49),char(35),char(34),char(34), -char(32),char(34),char(36),char(43),char(49),char(46),char(52),char(56),char(54),char(48), -char(52),char(67),char(78),char(82),char(82),char(81),char(80),char(79),char(90),char(114), -char(136),char(149),char(148),char(153),char(164),char(159),char(143),char(126),char(110),char(106), -char(118),char(143),char(158),char(159),char(163),char(181),char(203),char(213),char(215),char(227), -char(241),char(247),char(237),char(221),char(204),char(189),char(169),char(149),char(140),char(138), -char(153),char(169),char(172),char(164),char(160),char(169),char(175),char(180),char(185),char(187), -char(196),char(196),char(199),char(198),char(183),char(165),char(144),char(127),char(109),char(92), -char(78),char(78),char(94),char(110),char(127),char(129),char(123),char(127),char(123),char(124), -char(125),char(137),char(84),char(94),char(123),char(137),char(141),char(146),char(147),char(149), -char(150),char(156),char(161),char(144),char(122),char(111),char(114),char(101),char(85),char(73), -char(65),char(61),char(70),char(77),char(79),char(84),char(103),char(117),char(135),char(154), -char(179),char(194),char(199),char(197),char(188),char(172),char(160),char(146),char(124),char(110), -char(98),char(82),char(76),char(72),char(54),char(34),char(31),char(32),char(27),char(30), -char(31),char(36),char(43),char(45),char(52),char(55),char(53),char(49),char(48),char(54), -char(59),char(64),char(63),char(64),char(69),char(72),char(87),char(110),char(131),char(147), -char(150),char(156),char(165),char(159),char(136),char(119),char(113),char(103),char(112),char(139), -char(151),char(153),char(162),char(178),char(197),char(211),char(220),char(230),char(239),char(242), -char(232),char(210),char(201),char(195),char(184),char(166),char(165),char(161),char(164),char(180), -char(174),char(159),char(156),char(171),char(178),char(175),char(179),char(184),char(197),char(198), -char(199),char(201),char(189),char(170),char(146),char(133),char(119),char(92),char(82),char(83), -char(96),char(114),char(124),char(136),char(131),char(126),char(121),char(130),char(143),char(150), -char(96),char(101),char(122),char(143),char(154),char(164),char(175),char(171),char(158),char(155), -char(153),char(134),char(122),char(121),char(110),char(109),char(96),char(79),char(70),char(67), -char(73),char(74),char(74),char(80),char(96),char(124),char(151),char(166),char(187),char(198), -char(201),char(208),char(205),char(197),char(180),char(156),char(128),char(115),char(99),char(85), -char(84),char(76),char(60),char(44),char(36),char(34),char(29),char(29),char(28),char(29), -char(35),char(44),char(49),char(48),char(52),char(59),char(59),char(54),char(58),char(59), -char(57),char(59),char(60),char(63),char(82),char(104),char(119),char(138),char(150),char(155), -char(160),char(152),char(124),char(106),char(105),char(106),char(112),char(127),char(141),char(151), -char(164),char(176),char(185),char(202),char(217),char(228),char(236),char(232),char(229),char(215), -char(201),char(196),char(192),char(180),char(179),char(173),char(170),char(177),char(169),char(157), -char(159),char(162),char(169),char(169),char(168),char(182),char(195),char(192),char(190),char(188), -char(175),char(157),char(144),char(135),char(116),char(98),char(88),char(81),char(93),char(110), -char(120),char(133),char(142),char(128),char(124),char(143),char(159),char(158),char(110),char(112), -char(124),char(156),char(169),char(182),char(193),char(178),char(161),char(153),char(146),char(135), -char(132),char(135),char(117),char(104),char(97),char(81),char(87),char(87),char(93),char(82), -char(78),char(84),char(98),char(127),char(150),char(170),char(191),char(202),char(207),char(210), -char(213),char(202),char(177),char(147),char(127),char(109),char(93),char(84),char(78),char(76), -char(65),char(55),char(45),char(36),char(30),char(27),char(24),char(27),char(36),char(43), -char(40),char(39),char(48),char(64),char(64),char(56),char(60),char(61),char(60),char(56), -char(52),char(63),char(86),char(99),char(113),char(140),char(160),char(161),char(157),char(144), -char(117),char(99),char(98),char(106),char(114),char(122),char(137),char(154),char(166),char(170), -char(178),char(195),char(212),char(220),char(226),char(229),char(228),char(223),char(207),char(193), -char(189),char(183),char(176),char(176),char(169),char(163),char(155),char(145),char(148),char(149), -char(157),char(167),char(165),char(167),char(171),char(171),char(171),char(166),char(155),char(146), -char(140),char(137),char(115),char(103),char(96),char(90),char(97),char(100),char(103),char(117), -char(139),char(135),char(133),char(141),char(151),char(158),char(133),char(136),char(142),char(164), -char(176),char(186),char(188),char(183),char(170),char(160),char(147),char(149),char(155),char(147), -char(137),char(118),char(101),char(93),char(100),char(103),char(111),char(96),char(91),char(98), -char(114),char(142),char(155),char(169),char(190),char(198),char(201),char(203),char(202),char(193), -char(174),char(144),char(126),char(107),char(100),char(92),char(83),char(77),char(73),char(56), -char(47),char(39),char(32),char(26),char(21),char(25),char(33),char(36),char(35),char(33), -char(38),char(57),char(67),char(71),char(74),char(72),char(66),char(57),char(55),char(66), -char(87),char(102),char(121),char(146),char(158),char(150),char(142),char(137),char(126),char(113), -char(106),char(108),char(119),char(133),char(143),char(158),char(169),char(170),char(179),char(197), -char(215),char(220),char(226),char(230),char(228),char(218),char(205),char(187),char(180),char(173), -char(168),char(171),char(163),char(147),char(132),char(123),char(126),char(136),char(145),char(157), -char(156),char(149),char(150),char(145),char(145),char(137),char(131),char(131),char(128),char(124), -char(106),char(98),char(95),char(89),char(84),char(86),char(91),char(108),char(121),char(126), -char(131),char(134),char(133),char(148),char(153),char(158),char(156),char(165),char(176),char(180), -char(174),char(180),char(180),char(170),char(160),char(165),char(178),char(171),char(159),char(147), -char(126),char(124),char(119),char(118),char(120),char(113),char(110),char(119),char(132),char(147), -char(155),char(169),char(186),char(190),char(197),char(201),char(199),char(190),char(170),char(144), -char(130),char(116),char(107),char(106),char(92),char(82),char(74),char(60),char(49),char(46), -char(37),char(33),char(26),char(24),char(29),char(32),char(32),char(31),char(38),char(55), -char(72),char(81),char(86),char(84),char(79),char(70),char(59),char(66),char(86),char(102), -char(118),char(134),char(141),char(135),char(130),char(130),char(128),char(123),char(120),char(116), -char(127),char(147),char(158),char(173),char(181),char(182),char(186),char(201),char(218),char(221), -char(223),char(226),char(225),char(220),char(203),char(186),char(177),char(167),char(159),char(161), -char(150),char(126),char(114),char(109),char(114),char(122),char(138),char(151),char(149),char(150), -char(140),char(134),char(133),char(128),char(133),char(138),char(134),char(113),char(96),char(89), -char(85),char(68),char(65),char(73),char(83),char(95),char(109),char(109),char(120),char(122), -char(120),char(128),char(163),char(161),char(156),char(164),char(172),char(172),char(178),char(182), -char(185),char(182),char(176),char(182),char(193),char(185),char(180),char(171),char(162),char(156), -char(145),char(137),char(135),char(137),char(139),char(151),char(148),char(151),char(160),char(173), -char(184),char(189),char(201),char(206),char(196),char(182),char(165),char(144),char(133),char(127), -char(121),char(118),char(95),char(78),char(70),char(60),char(57),char(56),char(50),char(43), -char(33),char(30),char(33),char(35),char(32),char(31),char(39),char(57),char(75),char(83), -char(85),char(78),char(77),char(76),char(69),char(77),char(90),char(96),char(107),char(114), -char(124),char(127),char(130),char(131),char(131),char(132),char(129),char(121),char(130),char(154), -char(169),char(182),char(187),char(190),char(194),char(193),char(199),char(203),char(210),char(218), -char(223),char(226),char(215),char(200),char(181),char(169),char(159),char(146),char(130),char(116), -char(106),char(106),char(118),char(125),char(140),char(149),char(155),char(152),char(142),char(145), -char(145),char(136),char(138),char(146),char(136),char(106),char(94),char(78),char(69),char(56), -char(54),char(60),char(72),char(80),char(96),char(102),char(102),char(103),char(109),char(114), -char(173),char(167),char(159),char(164),char(172),char(174),char(181),char(183),char(174),char(174), -char(176),char(186),char(188),char(176),char(180),char(180),char(173),char(166),char(161),char(155), -char(154),char(161),char(161),char(170),char(164),char(167),char(185),char(191),char(192),char(198), -char(204),char(205),char(198),char(182),char(176),char(164),char(157),char(148),char(137),char(125), -char(110),char(96),char(79),char(70),char(71),char(66),char(63),char(54),char(39),char(38), -char(44),char(42),char(37),char(36),char(42),char(56),char(69),char(80),char(78),char(68), -char(66),char(72),char(80),char(88),char(92),char(95),char(101),char(108),char(122),char(127), -char(133),char(136),char(140),char(142),char(125),char(115),char(124),char(147),char(163),char(169), -char(175),char(184),char(190),char(189),char(187),char(189),char(196),char(202),char(210),char(216), -char(216),char(207),char(185),char(171),char(162),char(140),char(122),char(112),char(107),char(108), -char(120),char(132),char(143),char(152),char(165),char(153),char(147),char(152),char(157),char(149), -char(140),char(137),char(124),char(96),char(84),char(74),char(57),char(53),char(53),char(59), -char(73),char(78),char(88),char(95),char(89),char(85),char(90),char(92),char(189),char(178), -char(162),char(160),char(157),char(165),char(169),char(167),char(162),char(160),char(165),char(170), -char(172),char(162),char(165),char(174),char(176),char(177),char(168),char(165),char(169),char(178), -char(184),char(185),char(184),char(188),char(206),char(203),char(198),char(207),char(202),char(203), -char(200),char(191),char(195),char(191),char(183),char(164),char(144),char(125),char(123),char(118), -char(93),char(84),char(82),char(74),char(63),char(57),char(46),char(46),char(50),char(43), -char(38),char(37),char(39),char(50),char(60),char(68),char(63),char(57),char(56),char(71), -char(89),char(101),char(103),char(101),char(104),char(109),char(123),char(135),char(138),char(141), -char(143),char(137),char(116),char(104),char(113),char(135),char(148),char(153),char(161),char(179), -char(190),char(191),char(185),char(182),char(183),char(188),char(197),char(206),char(213),char(203), -char(178),char(159),char(155),char(136),char(118),char(102),char(102),char(106),char(119),char(136), -char(141),char(148),char(161),char(150),char(148),char(152),char(150),char(150),char(136),char(126), -char(114),char(97),char(77),char(68),char(56),char(56),char(56),char(59),char(69),char(71), -char(78),char(85),char(80),char(76),char(73),char(80),char(192),char(181),char(162),char(150), -char(147),char(145),char(153),char(150),char(151),char(150),char(152),char(154),char(158),char(151), -char(156),char(163),char(169),char(174),char(168),char(163),char(172),char(184),char(203),char(205), -char(203),char(205),char(213),char(215),char(209),char(214),char(204),char(200),char(199),char(198), -char(203),char(206),char(196),char(173),char(146),char(125),char(123),char(115),char(99),char(86), -char(76),char(69),char(57),char(53),char(54),char(56),char(53),char(44),char(41),char(38), -char(40),char(45),char(52),char(57),char(55),char(52),char(55),char(72),char(93),char(104), -char(104),char(107),char(110),char(113),char(126),char(138),char(140),char(142),char(140),char(127), -char(114),char(108),char(116),char(137),char(149),char(153),char(154),char(173),char(189),char(191), -char(177),char(172),char(178),char(177),char(180),char(187),char(193),char(182),char(161),char(150), -char(145),char(138),char(122),char(102),char(99),char(111),char(126),char(135),char(135),char(134), -char(149),char(150),char(151),char(155),char(148),char(137),char(124),char(109),char(104),char(101), -char(83),char(67),char(56),char(58),char(61),char(62),char(60),char(63),char(62),char(64), -char(69),char(67),char(63),char(70),char(189),char(177),char(165),char(150),char(140),char(136), -char(138),char(136),char(140),char(134),char(131),char(143),char(149),char(148),char(156),char(159), -char(156),char(162),char(168),char(167),char(171),char(195),char(214),char(213),char(209),char(207), -char(213),char(223),char(220),char(217),char(206),char(206),char(204),char(207),char(211),char(212), -char(200),char(177),char(143),char(120),char(109),char(101),char(92),char(79),char(60),char(55), -char(49),char(49),char(57),char(63),char(54),char(46),char(43),char(41),char(41),char(42), -char(44),char(46),char(48),char(48),char(57),char(75),char(90),char(96),char(96),char(102), -char(109),char(118),char(127),char(131),char(134),char(129),char(122),char(117),char(120),char(123), -char(125),char(144),char(164),char(163),char(157),char(166),char(184),char(185),char(177),char(178), -char(180),char(174),char(166),char(168),char(167),char(164),char(155),char(151),char(151),char(151), -char(135),char(119),char(113),char(122),char(134),char(137),char(131),char(134),char(142),char(146), -char(149),char(154),char(144),char(120),char(112),char(95),char(88),char(98),char(89),char(73), -char(58),char(59),char(64),char(64),char(58),char(60),char(58),char(59),char(66),char(68), -char(63),char(60),char(189),char(174),char(168),char(154),char(138),char(126),char(117),char(122), -char(132),char(131),char(126),char(129),char(135),char(148),char(159),char(155),char(164),char(169), -char(177),char(182),char(189),char(211),char(219),char(218),char(215),char(207),char(208),char(220), -char(229),char(231),char(220),char(217),char(216),char(210),char(213),char(214),char(201),char(172), -char(141),char(121),char(104),char(89),char(74),char(65),char(59),char(51),char(47),char(50), -char(62),char(64),char(54),char(46),char(42),char(39),char(38),char(36),char(37),char(42), -char(46),char(50),char(62),char(83),char(96),char(100),char(99),char(101),char(114),char(123), -char(120),char(118),char(122),char(119),char(117),char(120),char(129),char(131),char(134),char(154), -char(173),char(177),char(180),char(180),char(189),char(193),char(187),char(184),char(185),char(178), -char(166),char(157),char(152),char(155),char(160),char(162),char(160),char(151),char(142),char(138), -char(130),char(131),char(143),char(147),char(142),char(141),char(139),char(135),char(137),char(137), -char(123),char(103),char(100),char(94),char(87),char(90),char(85),char(76),char(62),char(63), -char(62),char(67),char(68),char(69),char(69),char(66),char(64),char(65),char(65),char(57), -char(176),char(168),char(166),char(157),char(148),char(128),char(113),char(113),char(123),char(127), -char(121),char(121),char(126),char(152),char(164),char(167),char(182),char(190),char(196),char(202), -char(208),char(222),char(231),char(230),char(225),char(220),char(219),char(226),char(237),char(242), -char(234),char(225),char(217),char(209),char(214),char(204),char(184),char(153),char(133),char(118), -char(100),char(81),char(64),char(56),char(52),char(45),char(45),char(56),char(62),char(59), -char(52),char(44),char(40),char(37),char(33),char(32),char(39),char(47),char(56),char(67), -char(84),char(105),char(117),char(112),char(109),char(113),char(124),char(135),char(126),char(114), -char(112),char(112),char(116),char(122),char(137),char(143),char(145),char(168),char(191),char(194), -char(202),char(206),char(204),char(200),char(190),char(178),char(175),char(175),char(169),char(152), -char(150),char(153),char(158),char(168),char(164),char(147),char(144),char(146),char(144),char(150), -char(166),char(159),char(155),char(145),char(135),char(130),char(133),char(122),char(107),char(88), -char(73),char(84),char(86),char(88),char(79),char(74),char(63),char(68),char(66),char(75), -char(77),char(78),char(79),char(77),char(67),char(63),char(61),char(57),char(170),char(166), -char(165),char(163),char(156),char(131),char(120),char(115),char(125),char(129),char(120),char(121), -char(128),char(156),char(168),char(180),char(193),char(200),char(209),char(213),char(216),char(227), -char(231),char(236),char(238),char(236),char(236),char(241),char(245),char(243),char(236),char(226), -char(220),char(212),char(204),char(187),char(169),char(152),char(133),char(121),char(99),char(71), -char(57),char(47),char(40),char(35),char(40),char(55),char(66),char(58),char(49),char(44), -char(38),char(36),char(35),char(40),char(48),char(56),char(71),char(86),char(107),char(127), -char(134),char(130),char(127),char(127),char(129),char(139),char(130),char(111),char(101),char(102), -char(111),char(126),char(145),char(153),char(157),char(179),char(201),char(206),char(211),char(218), -char(215),char(204),char(193),char(180),char(170),char(169),char(167),char(153),char(149),char(155), -char(159),char(166),char(163),char(154),char(159),char(161),char(157),char(168),char(174),char(168), -char(167),char(148),char(131),char(123),char(120),char(103),char(87),char(69),char(58),char(68), -char(80),char(85),char(81),char(77),char(70),char(69),char(69),char(79),char(83),char(83), -char(88),char(86),char(78),char(71),char(67),char(69),char(181),char(180),char(176),char(173), -char(160),char(131),char(121),char(124),char(132),char(136),char(136),char(138),char(145),char(166), -char(173),char(187),char(201),char(207),char(213),char(216),char(225),char(233),char(232),char(241), -char(247),char(244),char(243),char(247),char(243),char(235),char(229),char(221),char(220),char(216), -char(202),char(176),char(161),char(153),char(134),char(122),char(98),char(61),char(46),char(42), -char(37),char(38),char(38),char(50),char(66),char(61),char(53),char(51),char(47),char(43), -char(42),char(49),char(58),char(70),char(87),char(103),char(122),char(137),char(144),char(152), -char(154),char(148),char(140),char(134),char(130),char(118),char(103),char(101),char(117),char(135), -char(145),char(155),char(168),char(189),char(208),char(217),char(215),char(213),char(206),char(196), -char(189),char(188),char(177),char(166),char(161),char(149),char(145),char(161),char(165),char(167), -char(175),char(178),char(172),char(171),char(175),char(183),char(173),char(162),char(164),char(151), -char(134),char(118),char(107),char(93),char(79),char(62),char(57),char(60),char(73),char(78), -char(85),char(86),char(82),char(75),char(67),char(75),char(86),char(91),char(94),char(88), -char(77),char(79),char(76),char(84),char(191),char(198),char(195),char(183),char(167),char(145), -char(124),char(124),char(137),char(145),char(148),char(154),char(154),char(167),char(175),char(193), -char(208),char(217),char(215),char(215),char(226),char(239),char(240),char(244),char(249),char(246), -char(239),char(242),char(239),char(225),char(220),char(218),char(223),char(222),char(206),char(175), -char(151),char(140),char(121),char(102),char(84),char(62),char(50),char(47),char(41),char(41), -char(38),char(50),char(68),char(70),char(59),char(59),char(59),char(55),char(49),char(55), -char(66),char(79),char(100),char(125),char(145),char(157),char(160),char(169),char(174),char(166), -char(150),char(134),char(126),char(120),char(110),char(109),char(124),char(135),char(139),char(150), -char(168),char(193),char(216),char(222),char(214),char(205),char(193),char(182),char(182),char(187), -char(184),char(175),char(168),char(156),char(154),char(166),char(171),char(177),char(188),char(186), -char(178),char(174),char(185),char(187),char(174),char(155),char(148),char(152),char(138),char(120), -char(98),char(88),char(86),char(74),char(67),char(68),char(71),char(80),char(90),char(85), -char(85),char(90),char(80),char(76),char(83),char(93),char(94),char(80),char(68),char(75), -char(78),char(88),char(185),char(200),char(200),char(194),char(179),char(166),char(137),char(133), -char(139),char(144),char(148),char(148),char(148),char(155),char(171),char(190),char(205),char(217), -char(218),char(217),char(225),char(241),char(239),char(239),char(245),char(244),char(233),char(236), -char(232),char(217),char(215),char(213),char(219),char(217),char(199),char(178),char(150),char(135), -char(115),char(87),char(71),char(59),char(54),char(51),char(45),char(40),char(39),char(55), -char(76),char(77),char(59),char(52),char(56),char(62),char(58),char(61),char(73),char(86), -char(108),char(142),char(167),char(180),char(181),char(184),char(190),char(178),char(161),char(151), -char(138),char(132),char(121),char(113),char(114),char(124),char(131),char(137),char(150),char(174), -char(199),char(212),char(209),char(201),char(182),char(173),char(175),char(176),char(189),char(192), -char(187),char(173),char(174),char(187),char(190),char(192),char(188),char(177),char(173),char(169), -char(176),char(183),char(173),char(157),char(150),char(148),char(139),char(119),char(94),char(83), -char(82),char(82),char(77),char(75),char(86),char(93),char(91),char(84),char(90),char(102), -char(101),char(90),char(87),char(89),char(88),char(76),char(69),char(76),char(82),char(88), -char(170),char(183),char(195),char(198),char(190),char(176),char(153),char(144),char(137),char(135), -char(136),char(135),char(145),char(154),char(171),char(184),char(199),char(215),char(229),char(230), -char(233),char(241),char(240),char(239),char(241),char(236),char(222),char(220),char(218),char(204), -char(203),char(200),char(203),char(204),char(191),char(173),char(147),char(118),char(92),char(71), -char(61),char(55),char(55),char(50),char(46),char(43),char(45),char(58),char(78),char(78), -char(61),char(51),char(54),char(62),char(61),char(62),char(78),char(96),char(120),char(154), -char(177),char(192),char(199),char(200),char(195),char(180),char(167),char(155),char(149),char(139), -char(127),char(118),char(108),char(111),char(117),char(123),char(130),char(145),char(170),char(192), -char(197),char(195),char(183),char(173),char(170),char(177),char(188),char(196),char(199),char(194), -char(200),char(207),char(210),char(208),char(188),char(165),char(157),char(153),char(156),char(167), -char(170),char(164),char(153),char(135),char(125),char(109),char(95),char(81),char(76),char(81), -char(91),char(94),char(104),char(105),char(102),char(98),char(103),char(110),char(118),char(104), -char(90),char(85),char(84),char(81),char(79),char(85),char(89),char(90),char(173),char(175), -char(180),char(185),char(181),char(170),char(158),char(144),char(133),char(128),char(127),char(130), -char(148),char(168),char(176),char(186),char(205),char(225),char(240),char(245),char(245),char(246), -char(245),char(240),char(236),char(228),char(215),char(209),char(206),char(193),char(188),char(188), -char(194),char(199),char(185),char(162),char(129),char(90),char(71),char(58),char(53),char(51), -char(53),char(48),char(48),char(48),char(50),char(62),char(79),char(81),char(76),char(68), -char(65),char(66),char(68),char(74),char(94),char(117),char(135),char(156),char(176),char(196), -char(202),char(197),char(183),char(169),char(154),char(140),char(139),char(134),char(124),char(118), -char(115),char(113),char(114),char(120),char(128),char(130),char(149),char(175),char(186),char(192), -char(192),char(181),char(176),char(184),char(191),char(200),char(203),char(208),char(210),char(209), -char(213),char(210),char(186),char(164),char(152),char(140),char(144),char(153),char(163),char(162), -char(143),char(126),char(108),char(92),char(89),char(82),char(75),char(79),char(99),char(112), -char(109),char(104),char(110),char(113),char(114),char(123),char(121),char(104),char(89),char(88), -char(89),char(84),char(89),char(92),char(96),char(100),char(195),char(186),char(174),char(168), -char(162),char(157),char(152),char(139),char(126),char(117),char(124),char(130),char(151),char(171), -char(175),char(189),char(206),char(231),char(244),char(247),char(246),char(244),char(246),char(240), -char(231),char(218),char(211),char(206),char(198),char(191),char(184),char(186),char(197),char(197), -char(173),char(146),char(107),char(74),char(60),char(53),char(45),char(41),char(39),char(38), -char(45),char(54),char(61),char(69),char(79),char(86),char(87),char(79),char(79),char(83), -char(89),char(95),char(117),char(139),char(146),char(153),char(172),char(192),char(196),char(182), -char(168),char(157),char(144),char(137),char(132),char(125),char(123),char(120),char(121),char(117), -char(110),char(114),char(128),char(129),char(133),char(153),char(179),char(190),char(189),char(181), -char(180),char(191),char(192),char(197),char(197),char(203),char(204),char(200),char(199),char(195), -char(181),char(170),char(162),char(143),char(140),char(144),char(150),char(147),char(137),char(121), -char(101),char(82),char(86),char(86),char(80),char(83),char(106),char(119),char(110),char(102), -char(110),char(119),char(124),char(129),char(124),char(108),char(94),char(97),char(90),char(82), -char(86),char(88),char(106),char(111),char(206),char(195),char(182),char(162),char(147),char(147), -char(145),char(131),char(121),char(111),char(115),char(129),char(153),char(169),char(177),char(189), -char(207),char(227),char(239),char(242),char(240),char(239),char(243),char(234),char(221),char(202), -char(201),char(197),char(187),char(188),char(187),char(191),char(193),char(190),char(158),char(120), -char(88),char(68),char(48),char(43),char(37),char(33),char(27),char(31),char(43),char(64), -char(74),char(76),char(84),char(91),char(93),char(89),char(89),char(93),char(105),char(114), -char(135),char(156),char(162),char(162),char(170),char(184),char(195),char(183),char(167),char(158), -char(147),char(135),char(127),char(118),char(114),char(116),char(120),char(119),char(114),char(114), -char(125),char(131),char(126),char(136),char(162),char(172),char(176),char(179),char(180),char(185), -char(183),char(180),char(185),char(187),char(190),char(189),char(185),char(176),char(170),char(167), -char(159),char(147),char(136),char(128),char(130),char(131),char(128),char(111),char(93),char(85), -char(94),char(88),char(90),char(104),char(120),char(126),char(126),char(121),char(119),char(122), -char(128),char(130),char(125),char(117),char(103),char(95),char(80),char(78),char(77),char(85), -char(113),char(112),char(199),char(194),char(183),char(161),char(138),char(133),char(134),char(125), -char(117),char(116),char(117),char(129),char(150),char(169),char(177),char(188),char(208),char(216), -char(225),char(230),char(238),char(240),char(236),char(225),char(211),char(197),char(200),char(199), -char(193),char(190),char(190),char(189),char(185),char(180),char(151),char(107),char(80),char(62), -char(44),char(36),char(29),char(24),char(25),char(36),char(46),char(61),char(76),char(89), -char(98),char(102),char(105),char(106),char(105),char(113),char(129),char(136),char(151),char(170), -char(176),char(175),char(177),char(186),char(196),char(194),char(173),char(156),char(142),char(120), -char(112),char(107),char(107),char(116),char(118),char(118),char(123),char(125),char(130),char(134), -char(124),char(127),char(138),char(144),char(150),char(165),char(176),char(176),char(171),char(157), -char(165),char(171),char(177),char(178),char(166),char(152),char(149),char(154),char(151),char(149), -char(139),char(119),char(110),char(111),char(102),char(93),char(85),char(90),char(99),char(94), -char(100),char(118),char(123),char(129),char(135),char(143),char(137),char(134),char(137),char(142), -char(122),char(110),char(94),char(81),char(71),char(73),char(80),char(87),char(109),char(112), -char(185),char(178),char(173),char(165),char(148),char(128),char(129),char(127),char(125),char(128), -char(131),char(139),char(153),char(160),char(169),char(180),char(194),char(198),char(208),char(221), -char(236),char(243),char(237),char(223),char(207),char(196),char(199),char(203),char(204),char(200), -char(191),char(187),char(179),char(170),char(146),char(110),char(85),char(69),char(52),char(38), -char(25),char(21),char(28),char(41),char(50),char(57),char(74),char(95),char(104),char(103), -char(109),char(118),char(128),char(142),char(148),char(151),char(161),char(173),char(180),char(183), -char(186),char(191),char(196),char(197),char(179),char(150),char(130),char(109),char(93),char(94), -char(105),char(113),char(109),char(104),char(117),char(127),char(129),char(132),char(123),char(117), -char(119),char(123),char(135),char(151),char(167),char(166),char(151),char(139),char(145),char(158), -char(168),char(170),char(151),char(132),char(134),char(145),char(152),char(152),char(141),char(128), -char(115),char(99),char(82),char(82),char(93),char(103),char(108),char(104),char(101),char(109), -char(120),char(138),char(143),char(153),char(141),char(131),char(127),char(135),char(116),char(93), -char(74),char(68),char(67),char(73),char(85),char(95),char(112),char(106),char(162),char(149), -char(152),char(157),char(161),char(137),char(140),char(137),char(137),char(137),char(135),char(144), -char(159),char(158),char(163),char(175),char(177),char(180),char(193),char(213),char(226),char(238), -char(235),char(219),char(198),char(190),char(189),char(195),char(200),char(198),char(191),char(188), -char(177),char(164),char(145),char(118),char(99),char(86),char(69),char(47),char(30),char(26), -char(31),char(43),char(49),char(56),char(70),char(85),char(95),char(103),char(109),char(119), -char(134),char(150),char(159),char(161),char(166),char(170),char(173),char(174),char(177),char(179), -char(184),char(191),char(179),char(151),char(126),char(105),char(82),char(80),char(93),char(100), -char(92),char(83),char(95),char(112),char(114),char(116),char(111),char(108),char(112),char(119), -char(134),char(140),char(144),char(140),char(126),char(128),char(138),char(148),char(157),char(161), -char(152),char(128),char(128),char(142),char(148),char(146),char(142),char(138),char(127),char(105), -char(84),char(88),char(105),char(113),char(115),char(110),char(101),char(96),char(116),char(138), -char(147),char(146),char(138),char(115),char(104),char(109),char(100),char(75),char(60),char(66), -char(72),char(76),char(83),char(102),char(115),char(103),char(136),char(129),char(131),char(137), -char(153),char(147),char(148),char(143),char(142),char(138),char(133),char(134),char(149),char(150), -char(154),char(169),char(171),char(176),char(187),char(204),char(216),char(226),char(223),char(207), -char(190),char(185),char(185),char(179),char(186),char(195),char(192),char(189),char(184),char(167), -char(145),char(127),char(117),char(97),char(77),char(50),char(35),char(35),char(40),char(46), -char(49),char(57),char(67),char(83),char(97),char(108),char(119),char(124),char(128),char(145), -char(159),char(156),char(160),char(167),char(166),char(166),char(165),char(162),char(171),char(180), -char(168),char(148),char(124),char(97),char(73),char(67),char(78),char(84),char(76),char(66), -char(76),char(95),char(107),char(109),char(103),char(100),char(110),char(117),char(119),char(117), -char(114),char(112),char(109),char(115),char(128),char(140),char(149),char(155),char(154),char(131), -char(130),char(139),char(140),char(145),char(151),char(145),char(129),char(112),char(99),char(99), -char(111),char(113),char(108),char(108),char(110),char(98),char(106),char(123),char(135),char(134), -char(138),char(112),char(96),char(93),char(79),char(56),char(51),char(62),char(68),char(74), -char(91),char(109),char(119),char(114),char(111),char(117),char(126),char(134),char(139),char(144), -char(147),char(144),char(143),char(136),char(125),char(125),char(139),char(140),char(149),char(159), -char(163),char(171),char(184),char(199),char(212),char(218),char(220),char(209),char(198),char(189), -char(187),char(177),char(177),char(195),char(191),char(186),char(178),char(162),char(138),char(125), -char(117),char(106),char(89),char(56),char(41),char(41),char(49),char(50),char(55),char(63), -char(67),char(84),char(100),char(106),char(121),char(130),char(136),char(148),char(154),char(147), -char(152),char(155),char(155),char(163),char(170),char(168),char(171),char(172),char(157),char(141), -char(113),char(80),char(60),char(57),char(60),char(61),char(57),char(49),char(62),char(89), -char(107),char(107),char(103),char(101),char(104),char(101),char(99),char(96),char(93),char(89), -char(93),char(104),char(115),char(126),char(129),char(135),char(141),char(129),char(126),char(126), -char(127),char(135),char(139),char(134),char(124),char(112),char(107),char(99),char(102),char(108), -char(104),char(106),char(119),char(119),char(111),char(114),char(122),char(125),char(122),char(108), -char(94),char(81),char(66),char(56),char(52),char(53),char(56),char(68),char(90),char(113), -char(125),char(124),char(93),char(101),char(127),char(142),char(136),char(140),char(142),char(141), -char(141),char(125),char(109),char(112),char(124),char(133),char(142),char(146),char(149),char(154), -char(167),char(184),char(202),char(214),char(210),char(208),char(203),char(195),char(185),char(182), -char(184),char(191),char(186),char(179),char(167),char(149),char(132),char(125),char(117),char(116), -char(104),char(74),char(51),char(46),char(57),char(60),char(62),char(70),char(76),char(83), -char(97),char(102),char(119),char(135),char(143),char(151),char(150),char(144),char(147),char(150), -char(149),char(165),char(180),char(182),char(174),char(166),char(153),char(133),char(97),char(61), -char(46),char(47),char(49),char(50),char(49),char(46),char(57),char(83),char(98),char(102), -char(98),char(92),char(82),char(79),char(87),char(88),char(80),char(73),char(75),char(91), -char(106),char(100),char(99),char(103),char(113),char(120),char(118),char(115),char(117),char(116), -char(116),char(116),char(117),char(112),char(101),char(89),char(87),char(101),char(101),char(115), -char(129),char(132),char(127),char(119),char(119),char(116),char(111),char(105),char(93),char(73), -char(74),char(70),char(65),char(56),char(54),char(70),char(95),char(114),char(127),char(123), -char(86),char(87),char(114),char(139),char(145),char(139),char(134),char(130),char(129),char(110), -char(92),char(96),char(108),char(120),char(132),char(144),char(147),char(153),char(157),char(172), -char(186),char(194),char(186),char(191),char(195),char(186),char(166),char(169),char(180),char(176), -char(175),char(167),char(155),char(139),char(134),char(132),char(129),char(129),char(110),char(88), -char(63),char(54),char(62),char(65),char(65),char(74),char(87),char(93),char(101),char(110), -char(129),char(142),char(144),char(145),char(141),char(139),char(139),char(147),char(155),char(172), -char(182),char(183),char(176),char(162),char(152),char(128),char(92),char(62),char(48),char(48), -char(53),char(53),char(51),char(52),char(58),char(64),char(78),char(90),char(88),char(81), -char(70),char(72),char(78),char(78),char(71),char(65),char(60),char(71),char(87),char(84), -char(80),char(83),char(96),char(112),char(114),char(108),char(104),char(103),char(97),char(100), -char(109),char(107),char(90),char(84),char(89),char(98),char(100),char(122),char(133),char(141), -char(140),char(133),char(129),char(116),char(115),char(110),char(97),char(83),char(88),char(81), -char(77),char(67),char(59),char(78),char(108),char(115),char(115),char(116),char(77),char(80), -char(104),char(136),char(145),char(135),char(125),char(113),char(103),char(87),char(75),char(83), -char(95),char(117),char(135),char(149),char(145),char(151),char(155),char(158),char(156),char(161), -char(167),char(175),char(176),char(168),char(145),char(144),char(152),char(154),char(154),char(149), -char(137),char(131),char(135),char(140),char(148),char(143),char(114),char(93),char(73),char(62), -char(61),char(63),char(64),char(75),char(91),char(109),char(115),char(120),char(135),char(145), -char(147),char(146),char(142),char(138),char(134),char(140),char(153),char(169),char(180),char(183), -char(177),char(161),char(145),char(113),char(84),char(70),char(61),char(58),char(58),char(55), -char(50),char(48),char(47),char(48),char(60),char(71),char(77),char(81),char(71),char(67), -char(65),char(58),char(51),char(54),char(53),char(58),char(64),char(66),char(64),char(67), -char(80),char(92),char(94),char(91),char(87),char(87),char(76),char(76),char(90),char(102), -char(98),char(101),char(108),char(109),char(112),char(129),char(139),char(159),char(159),char(154), -char(148),char(130),char(119),char(111),char(104),char(95),char(90),char(86),char(82),char(76), -char(69),char(86),char(101),char(103),char(98),char(105),char(72),char(84),char(108),char(129), -char(139),char(138),char(126),char(102),char(78),char(64),char(63),char(67),char(85),char(116), -char(132),char(134),char(139),char(144),char(146),char(132),char(132),char(143),char(154),char(155), -char(149),char(144),char(125),char(119),char(120),char(132),char(131),char(135),char(129),char(123), -char(131),char(143),char(149),char(139),char(117),char(92),char(73),char(68),char(65),char(63), -char(73),char(86),char(100),char(112),char(117),char(120),char(123),char(133),char(143),char(141), -char(137),char(137),char(137),char(139),char(146),char(157),char(174),char(184),char(176),char(156), -char(128),char(96),char(81),char(76),char(68),char(66),char(62),char(56),char(49),char(43), -char(45),char(46),char(49),char(55),char(62),char(62),char(56),char(52),char(51),char(45), -char(33),char(35),char(41),char(46),char(47),char(46),char(52),char(56),char(57),char(64), -char(67),char(74),char(84),char(83),char(74),char(71),char(87),char(107),char(115),char(120), -char(129),char(131),char(134),char(152),char(160),char(170),char(175),char(173),char(161),char(147), -char(129),char(124),char(124),char(119),char(101),char(92),char(84),char(80),char(76),char(85), -char(89),char(90),char(92),char(100),char(66),char(83),char(100),char(111),char(132),char(141), -char(131),char(107),char(79),char(58),char(61),char(69),char(86),char(110),char(125),char(124), -char(135),char(138),char(132),char(123),char(129),char(138),char(138),char(136),char(133),char(123), -char(109),char(100),char(99),char(103),char(107),char(120),char(113),char(109),char(112),char(124), -char(133),char(130),char(119),char(98),char(80),char(76),char(73),char(71),char(83),char(94), -char(102),char(101),char(109),char(122),char(118),char(121),char(130),char(129),char(129),char(137), -char(135),char(132),char(140),char(151),char(166),char(175),char(166),char(144),char(118),char(98), -char(88),char(79),char(67),char(70),char(65),char(57),char(54),char(50),char(52),char(48), -char(42),char(42),char(43),char(38),char(36),char(36),char(36),char(34),char(25),char(20), -char(23),char(28),char(30),char(32),char(42),char(53),char(48),char(47),char(52),char(66), -char(86),char(90),char(86),char(85),char(101),char(114),char(124),char(129),char(141),char(148), -char(153),char(169),char(175),char(174),char(187),char(184),char(168),char(155),char(143),char(137), -char(140),char(136),char(111),char(96),char(82),char(73),char(71),char(73),char(80),char(90), -char(93),char(100),char(63),char(76),char(86),char(99),char(121),char(126),char(124),char(112), -char(92),char(74),char(65),char(75),char(88),char(109),char(125),char(132),char(132),char(125), -char(126),char(133),char(131),char(132),char(131),char(128),char(127),char(116),char(101),char(88), -char(81),char(80),char(85),char(94),char(90),char(86),char(89),char(99),char(119),char(128), -char(125),char(109),char(96),char(89),char(84),char(86),char(91),char(92),char(96),char(93), -char(97),char(113),char(123),char(118),char(117),char(116),char(117),char(125),char(125),char(128), -char(135),char(138),char(151),char(159),char(154),char(137),char(118),char(105),char(88),char(77), -char(71),char(68),char(62),char(57),char(62),char(60),char(54),char(48),char(37),char(31), -char(28),char(27),char(26),char(24),char(23),char(25),char(22),char(14),char(14),char(19), -char(20),char(26),char(35),char(46),char(47),char(39),char(45),char(63),char(84),char(90), -char(93),char(95),char(109),char(127),char(135),char(138),char(144),char(155),char(169),char(180), -char(179),char(181),char(189),char(185),char(170),char(150),char(139),char(128),char(128),char(129), -char(105),char(86),char(71),char(68),char(64),char(64),char(73),char(89),char(93),char(96), -char(61),char(74),char(85),char(97),char(110),char(102),char(107),char(103),char(100),char(85), -char(67),char(72),char(82),char(99),char(117),char(131),char(131),char(121),char(131),char(141), -char(140),char(132),char(133),char(130),char(117),char(104),char(88),char(79),char(68),char(69), -char(72),char(71),char(75),char(76),char(80),char(83),char(97),char(115),char(125),char(114), -char(107),char(106),char(100),char(100),char(107),char(105),char(103),char(99),char(94),char(101), -char(121),char(119),char(109),char(99),char(92),char(105),char(118),char(127),char(131),char(124), -char(131),char(146),char(142),char(127),char(113),char(104),char(87),char(75),char(74),char(75), -char(72),char(64),char(69),char(66),char(56),char(47),char(39),char(30),char(23),char(20), -char(19),char(17),char(17),char(23),char(22),char(17),char(17),char(20),char(23),char(27), -char(32),char(39),char(43),char(36),char(42),char(67),char(88),char(92),char(96),char(106), -char(116),char(141),char(146),char(151),char(152),char(165),char(187),char(195),char(188),char(190), -char(185),char(180),char(167),char(141),char(125),char(112),char(106),char(109),char(94),char(70), -char(63),char(60),char(56),char(59),char(68),char(84),char(89),char(97),char(59),char(70), -char(86),char(97),char(97),char(87),char(92),char(100),char(99),char(84),char(76),char(70), -char(77),char(89),char(110),char(124),char(127),char(129),char(140),char(148),char(142),char(131), -char(127),char(122),char(104),char(88),char(76),char(75),char(73),char(73),char(66),char(60), -char(67),char(73),char(76),char(79),char(83),char(93),char(110),char(117),char(117),char(119), -char(115),char(116),char(124),char(126),char(116),char(107),char(102),char(105),char(117),char(120), -char(109),char(93),char(86),char(101),char(119),char(122),char(121),char(120),char(127),char(138), -char(133),char(117),char(104),char(97),char(87),char(80),char(80),char(86),char(90),char(82), -char(77),char(71),char(53),char(44),char(40),char(33),char(25),char(19),char(15),char(18), -char(21),char(24),char(23),char(20),char(21),char(26),char(28),char(26),char(30),char(38), -char(43),char(44),char(52),char(70),char(85),char(94),char(99),char(111),char(124),char(140), -char(145),char(157),char(158),char(172),char(194),char(202),char(197),char(190),char(178),char(172), -char(158),char(138),char(123),char(111),char(103),char(96),char(90),char(72),char(62),char(55), -char(52),char(62),char(73),char(83),char(89),char(98),char(58),char(65),char(79),char(91), -char(83),char(84),char(85),char(92),char(94),char(91),char(89),char(79),char(86),char(90), -char(111),char(124),char(129),char(140),char(138),char(143),char(137),char(126),char(117),char(111), -char(98),char(77),char(65),char(69),char(80),char(79),char(61),char(56),char(64),char(70), -char(72),char(74),char(72),char(76),char(89),char(110),char(121),char(122),char(121),char(127), -char(128),char(128),char(123),char(111),char(102),char(103),char(111),char(120),char(120),char(112), -char(106),char(116),char(125),char(126),char(124),char(120),char(116),char(115),char(115),char(110), -char(96),char(90),char(89),char(89),char(92),char(92),char(93),char(87),char(75),char(72), -char(55),char(40),char(35),char(33),char(27),char(20),char(18),char(23),char(25),char(27), -char(28),char(26),char(27),char(31),char(37),char(33),char(33),char(39),char(45),char(47), -char(58),char(66),char(77),char(90),char(97),char(104),char(118),char(118),char(126),char(149), -char(163),char(184),char(198),char(197),char(195),char(183),char(172),char(174),char(154),char(131), -char(115),char(107),char(103),char(88),char(87),char(75),char(68),char(60),char(55),char(68), -char(75),char(80),char(93),char(98),char(62),char(71),char(71),char(75),char(71),char(77), -char(77),char(78),char(91),char(96),char(97),char(97),char(99),char(96),char(115),char(135), -char(141),char(141),char(142),char(144),char(142),char(125),char(116),char(104),char(93),char(77), -char(62),char(67),char(75),char(72),char(63),char(55),char(61),char(67),char(61),char(59), -char(57),char(66),char(80),char(101),char(123),char(138),char(143),char(139),char(135),char(127), -char(122),char(112),char(102),char(103),char(118),char(135),char(140),char(138),char(137),char(136), -char(137),char(128),char(124),char(116),char(102),char(94),char(95),char(99),char(95),char(86), -char(88),char(94),char(99),char(99),char(92),char(84),char(75),char(70),char(56),char(39), -char(31),char(34),char(34),char(27),char(24),char(28),char(31),char(34),char(37),char(37), -char(40),char(42),char(47),char(45),char(42),char(43),char(48),char(48),char(60),char(68), -char(78),char(91),char(98),char(100),char(102),char(94),char(115),char(137),char(154),char(185), -char(194),char(187),char(182),char(175),char(175),char(174),char(152),char(125),char(104),char(89), -char(87),char(85),char(84),char(79),char(76),char(74),char(69),char(73),char(76),char(84), -char(94),char(111),char(65),char(74),char(67),char(62),char(61),char(62),char(67),char(75), -char(90),char(100),char(99),char(104),char(104),char(99),char(121),char(144),char(146),char(141), -char(148),char(156),char(149),char(125),char(122),char(107),char(91),char(83),char(74),char(70), -char(67),char(63),char(62),char(57),char(58),char(63),char(54),char(52),char(59),char(67), -char(86),char(107),char(127),char(155),char(169),char(160),char(148),char(138),char(125),char(117), -char(109),char(115),char(138),char(156),char(161),char(159),char(157),char(152),char(146),char(127), -char(112),char(109),char(97),char(84),char(83),char(87),char(91),char(90),char(91),char(98), -char(98),char(100),char(99),char(89),char(81),char(71),char(56),char(42),char(39),char(46), -char(43),char(34),char(32),char(33),char(40),char(42),char(43),char(46),char(51),char(50), -char(48),char(47),char(49),char(55),char(62),char(64),char(70),char(81),char(93),char(102), -char(105),char(98),char(89),char(94),char(108),char(120),char(126),char(156),char(178),char(184), -char(178),char(169),char(168),char(159),char(137),char(121),char(97),char(77),char(73),char(84), -char(89),char(86),char(77),char(83),char(81),char(76),char(79),char(82),char(100),char(126), -char(65),char(71),char(67),char(63),char(60),char(59),char(70),char(83),char(98),char(106), -char(105),char(105),char(100),char(106),char(129),char(148),char(153),char(154),char(158),char(160), -char(149),char(127),char(123),char(118),char(105),char(94),char(89),char(77),char(68),char(62), -char(59),char(55),char(49),char(51),char(47),char(48),char(58),char(73),char(95),char(111), -char(127),char(151),char(165),char(162),char(156),char(150),char(133),char(121),char(117),char(120), -char(144),char(166),char(173),char(170),char(161),char(151),char(141),char(130),char(115),char(105), -char(89),char(76),char(73),char(78),char(90),char(98),char(104),char(114),char(113),char(107), -char(105),char(103),char(95),char(83),char(72),char(59),char(56),char(59),char(52),char(48), -char(46),char(40),char(44),char(54),char(51),char(54),char(56),char(52),char(48),char(50), -char(56),char(68),char(76),char(78),char(80),char(98),char(109),char(109),char(109),char(106), -char(97),char(106),char(105),char(103),char(106),char(128),char(157),char(173),char(177),char(166), -char(158),char(144),char(132),char(122),char(99),char(80),char(79),char(80),char(80),char(75), -char(71),char(75),char(75),char(71),char(74),char(80),char(110),char(129),char(71),char(69), -char(67),char(60),char(59),char(72),char(86),char(95),char(98),char(100),char(109),char(103), -char(91),char(104),char(119),char(142),char(154),char(155),char(164),char(156),char(147),char(130), -char(117),char(121),char(124),char(114),char(105),char(88),char(76),char(64),char(55),char(44), -char(39),char(38),char(36),char(39),char(55),char(78),char(96),char(108),char(123),char(146), -char(156),char(152),char(144),char(143),char(137),char(124),char(116),char(128),char(150),char(174), -char(187),char(180),char(164),char(141),char(132),char(130),char(117),char(100),char(89),char(79), -char(75),char(78),char(86),char(97),char(110),char(122),char(128),char(124),char(115),char(112), -char(112),char(103),char(86),char(76),char(79),char(75),char(72),char(69),char(61),char(50), -char(44),char(51),char(52),char(57),char(63),char(62),char(58),char(63),char(65),char(70), -char(72),char(72),char(83),char(113),char(125),char(110),char(110),char(120),char(122),char(123), -char(116),char(107),char(107),char(123),char(144),char(162),char(168),char(157),char(149),char(137), -char(128),char(113),char(104),char(89),char(82),char(78),char(74),char(68),char(71),char(71), -char(72),char(63),char(60),char(74),char(107),char(128),char(67),char(62),char(63),char(62), -char(71),char(90),char(95),char(97),char(99),char(108),char(109),char(97),char(82),char(91), -char(95),char(121),char(138),char(145),char(155),char(154),char(146),char(128),char(119),char(125), -char(126),char(114),char(105),char(95),char(78),char(61),char(47),char(37),char(33),char(29), -char(30),char(32),char(50),char(79),char(102),char(111),char(118),char(137),char(142),char(135), -char(127),char(134),char(141),char(128),char(122),char(140),char(161),char(179),char(191),char(183), -char(160),char(136),char(125),char(121),char(107),char(92),char(88),char(86),char(85),char(82), -char(89),char(98),char(109),char(123),char(132),char(137),char(133),char(125),char(125),char(115), -char(97),char(89),char(95),char(92),char(87),char(85),char(78),char(62),char(49),char(49), -char(52),char(59),char(72),char(80),char(75),char(76),char(70),char(69),char(68),char(74), -char(91),char(120),char(133),char(125),char(119),char(132),char(133),char(122),char(122),char(121), -char(119),char(117),char(136),char(152),char(157),char(151),char(149),char(134),char(119),char(109), -char(108),char(98),char(80),char(79),char(78),char(82),char(80),char(77),char(73),char(59), -char(53),char(70),char(104),char(121),char(59),char(58),char(61),char(71),char(86),char(97), -char(99),char(101),char(108),char(113),char(100),char(87),char(77),char(78),char(80),char(99), -char(125),char(148),char(154),char(161),char(155),char(133),char(134),char(130),char(118),char(108), -char(101),char(88),char(64),char(56),char(47),char(43),char(32),char(24),char(26),char(30), -char(45),char(71),char(101),char(109),char(110),char(126),char(132),char(130),char(131),char(139), -char(144),char(135),char(131),char(146),char(164),char(183),char(188),char(175),char(156),char(145), -char(133),char(126),char(116),char(95),char(87),char(92),char(95),char(90),char(96),char(108), -char(123),char(135),char(142),char(145),char(144),char(142),char(134),char(121),char(114),char(107), -char(104),char(103),char(101),char(95),char(87),char(76),char(63),char(60),char(68),char(78), -char(83),char(94),char(96),char(87),char(82),char(77),char(80),char(94),char(104),char(118), -char(129),char(134),char(134),char(140),char(137),char(122),char(121),char(130),char(125),char(114), -char(122),char(133),char(141),char(148),char(145),char(138),char(129),char(120),char(114),char(104), -char(91),char(84),char(89),char(88),char(84),char(79),char(75),char(67),char(60),char(76), -char(101),char(109),char(52),char(53),char(64),char(66),char(82),char(88),char(91),char(103), -char(104),char(100),char(91),char(82),char(81),char(83),char(85),char(96),char(120),char(145), -char(154),char(167),char(161),char(143),char(143),char(136),char(122),char(111),char(101),char(79), -char(57),char(46),char(41),char(40),char(31),char(22),char(24),char(37),char(54),char(76), -char(93),char(96),char(103),char(117),char(133),char(146),char(155),char(156),char(155),char(146), -char(137),char(154),char(175),char(190),char(185),char(170),char(161),char(161),char(153),char(146), -char(135),char(115),char(107),char(109),char(107),char(100),char(105),char(117),char(131),char(148), -char(152),char(145),char(143),char(142),char(132),char(128),char(133),char(130),char(118),char(113), -char(111),char(97),char(82),char(74),char(63),char(68),char(86),char(99),char(99),char(107), -char(114),char(103),char(103),char(100),char(99),char(111),char(117),char(119),char(127),char(137), -char(139),char(140),char(138),char(126),char(117),char(118),char(111),char(111),char(113),char(118), -char(130),char(141),char(138),char(141),char(144),char(133),char(120),char(111),char(109),char(95), -char(94),char(84),char(78),char(81),char(81),char(81),char(83),char(86),char(95),char(100), -char(52),char(54),char(59),char(58),char(66),char(71),char(82),char(89),char(81),char(79), -char(84),char(88),char(86),char(86),char(92),char(107),char(125),char(136),char(149),char(153), -char(145),char(143),char(147),char(140),char(128),char(109),char(92),char(73),char(51),char(40), -char(38),char(33),char(28),char(26),char(31),char(46),char(70),char(88),char(99),char(100), -char(99),char(108),char(134),char(157),char(174),char(170),char(159),char(154),char(151),char(160), -char(181),char(194),char(184),char(164),char(162),char(167),char(166),char(157),char(143),char(138), -char(127),char(122),char(125),char(124),char(124),char(130),char(140),char(151),char(150),char(146), -char(144),char(136),char(127),char(134),char(142),char(143),char(136),char(127),char(112),char(96), -char(77),char(65),char(61),char(68),char(94),char(115),char(121),char(124),char(121),char(111), -char(118),char(119),char(117),char(120),char(123),char(118),char(115),char(128),char(129),char(130), -char(133),char(121),char(104),char(95),char(93),char(101),char(103),char(113),char(125),char(133), -char(134),char(139),char(149),char(140),char(133),char(129),char(129),char(115),char(99),char(85), -char(87),char(91),char(93),char(98),char(101),char(100),char(94),char(95),char(48),char(51), -char(49),char(43),char(46),char(48),char(58),char(62),char(56),char(63),char(78),char(93), -char(91),char(86),char(103),char(121),char(131),char(134),char(138),char(133),char(122),char(129), -char(133),char(129),char(121),char(109),char(90),char(76),char(55),char(42),char(34),char(31), -char(32),char(33),char(41),char(52),char(73),char(86),char(102),char(107),char(108),char(115), -char(135),char(159),char(181),char(179),char(159),char(158),char(159),char(162),char(182),char(195), -char(182),char(162),char(163),char(171),char(167),char(156),char(147),char(150),char(144),char(137), -char(135),char(131),char(131),char(137),char(145),char(155),char(155),char(146),char(146),char(141), -char(133),char(138),char(141),char(146),char(147),char(137),char(120),char(108),char(91),char(76), -char(75),char(82),char(102),char(121),char(138),char(146),char(135),char(133),char(134),char(134), -char(132),char(121),char(119),char(115),char(105),char(118),char(117),char(121),char(120),char(104), -char(92),char(87),char(89),char(97),char(104),char(111),char(122),char(129),char(132),char(133), -char(142),char(147),char(148),char(156),char(152),char(130),char(103),char(101),char(102),char(102), -char(107),char(103),char(107),char(111),char(97),char(92),char(50),char(45),char(39),char(30), -char(30),char(33),char(35),char(41),char(47),char(57),char(74),char(89),char(100),char(100), -char(116),char(128),char(136),char(134),char(124),char(110),char(100),char(99),char(105),char(107), -char(102),char(108),char(101),char(86),char(66),char(44),char(36),char(32),char(36),char(39), -char(41),char(48),char(60),char(73),char(89),char(100),char(119),char(129),char(135),char(155), -char(175),char(177),char(164),char(159),char(162),char(173),char(179),char(181),char(173),char(170), -char(171),char(169),char(162),char(158),char(159),char(159),char(157),char(148),char(135),char(134), -char(139),char(141),char(151),char(165),char(164),char(151),char(151),char(151),char(141),char(138), -char(138),char(146),char(155),char(145),char(134),char(125),char(116),char(103),char(99),char(108), -char(119),char(131),char(148),char(161),char(161),char(161),char(165),char(155),char(139),char(128), -char(121),char(118),char(113),char(111),char(107),char(111),char(107),char(91),char(80),char(82), -char(85),char(100),char(107),char(114),char(120),char(129),char(131),char(135),char(136),char(145), -char(158),char(170),char(165),char(141),char(119),char(119),char(115),char(110),char(114),char(110), -char(108),char(107),char(89),char(91),char(53),char(42),char(33),char(25),char(27),char(33), -char(31),char(39),char(56),char(67),char(77),char(87),char(107),char(118),char(124),char(121), -char(126),char(124),char(112),char(97),char(89),char(85),char(90),char(93),char(97),char(107), -char(110),char(90),char(64),char(50),char(51),char(41),char(38),char(45),char(45),char(51), -char(54),char(60),char(76),char(98),char(121),char(137),char(137),char(152),char(160),char(157), -char(160),char(163),char(174),char(178),char(166),char(166),char(171),char(171),char(167),char(157), -char(156),char(163),char(165),char(164),char(162),char(149),char(142),char(148),char(156),char(157), -char(164),char(165),char(162),char(163),char(166),char(164),char(155),char(150),char(153),char(163), -char(166),char(155),char(147),char(144),char(137),char(120),char(114),char(117),char(131),char(150), -char(163),char(165),char(179),char(187),char(190),char(175),char(155),char(146),char(134),char(122), -char(114),char(111),char(112),char(109),char(100),char(92),char(78),char(78),char(80),char(93), -char(99),char(110),char(114),char(121),char(128),char(141),char(139),char(141),char(155),char(168), -char(165),char(146),char(131),char(134),char(139),char(126),char(123),char(130),char(120),char(110), -char(93),char(92),char(44),char(35),char(33),char(29),char(30),char(33),char(32),char(42), -char(56),char(68),char(78),char(87),char(100),char(115),char(118),char(106),char(100),char(103), -char(105),char(95),char(81),char(81),char(88),char(95),char(101),char(109),char(109),char(81), -char(60),char(51),char(55),char(49),char(48),char(55),char(56),char(54),char(51),char(57), -char(74),char(93),char(114),char(133),char(139),char(151),char(147),char(144),char(157),char(166), -char(175),char(171),char(159),char(155),char(164),char(165),char(157),char(145),char(145),char(149), -char(145),char(149),char(159),char(160),char(159),char(164),char(173),char(173),char(172),char(167), -char(165),char(176),char(181),char(171),char(163),char(162),char(166),char(172),char(171),char(169), -char(167),char(163),char(154),char(140),char(125),char(127),char(141),char(157),char(172),char(180), -char(189),char(197),char(194),char(182),char(168),char(157),char(148),char(136),char(121),char(116), -char(114),char(110),char(103),char(102),char(96),char(92),char(90),char(94),char(109),char(119), -char(119),char(122),char(131),char(137),char(123),char(129),char(142),char(157),char(165),char(151), -char(143),char(151),char(156),char(140),char(130),char(138),char(124),char(109),char(100),char(90), -char(50),char(36),char(33),char(33),char(35),char(36),char(35),char(43),char(52),char(69), -char(83),char(86),char(90),char(97),char(101),char(93),char(75),char(81),char(86),char(86), -char(81),char(72),char(75),char(95),char(105),char(104),char(94),char(74),char(60),char(55), -char(55),char(54),char(52),char(53),char(55),char(52),char(49),char(59),char(73),char(88), -char(105),char(124),char(137),char(138),char(134),char(137),char(145),char(154),char(156),char(154), -char(155),char(152),char(152),char(150),char(146),char(145),char(141),char(144),char(140),char(143), -char(154),char(163),char(170),char(175),char(178),char(181),char(177),char(169),char(169),char(175), -char(173),char(164),char(162),char(162),char(166),char(172),char(171),char(174),char(174),char(168), -char(161),char(149),char(141),char(144),char(158),char(166),char(181),char(188),char(190),char(201), -char(198),char(185),char(172),char(159),char(149),char(138),char(119),char(113),char(114),char(107), -char(97),char(98),char(111),char(106),char(98),char(104),char(127),char(137),char(132),char(131), -char(132),char(125),char(113),char(119),char(134),char(146),char(157),char(156),char(152),char(157), -char(154),char(140),char(132),char(132),char(119),char(106),char(111),char(106),char(63),char(50), -char(36),char(33),char(34),char(33),char(33),char(43),char(49),char(68),char(79),char(84), -char(80),char(81),char(81),char(75),char(60),char(62),char(61),char(67),char(73),char(70), -char(69),char(84),char(94),char(85),char(83),char(78),char(67),char(58),char(51),char(49), -char(46),char(45),char(45),char(46),char(52),char(64),char(74),char(88),char(107),char(123), -char(124),char(124),char(122),char(123),char(127),char(130),char(137),char(146),char(149),char(142), -char(138),char(139),char(147),char(152),char(144),char(145),char(152),char(150),char(148),char(153), -char(167),char(174),char(176),char(183),char(179),char(169),char(165),char(158),char(150),char(152), -char(161),char(161),char(164),char(167),char(166),char(168),char(173),char(179),char(173),char(158), -char(152),char(160),char(171),char(171),char(179),char(181),char(186),char(198),char(196),char(183), -char(170),char(159),char(137),char(123),char(112),char(104),char(113),char(107),char(98),char(98), -char(117),char(121),char(110),char(114),char(131),char(145),char(145),char(137),char(130),char(116), -char(116),char(116),char(125),char(134),char(142),char(148),char(150),char(157),char(153),char(144), -char(134),char(132),char(125),char(124),char(131),char(126),char(69),char(55),char(36),char(34), -char(34),char(29),char(29),char(36),char(44),char(64),char(73),char(73),char(66),char(66), -char(68),char(61),char(55),char(53),char(54),char(58),char(65),char(74),char(78),char(73), -char(74),char(70),char(77),char(74),char(71),char(58),char(41),char(42),char(42),char(37), -char(38),char(47),char(55),char(62),char(69),char(93),char(116),char(127),char(128),char(135), -char(132),char(128),char(131),char(126),char(123),char(133),char(139),char(132),char(124),char(135), -char(158),char(166),char(153),char(147),char(154),char(150),char(143),char(149),char(166),char(172), -char(170),char(170),char(171),char(166),char(156),char(149),char(135),char(130),char(140),char(150), -char(150),char(153),char(162),char(167),char(176),char(186),char(187),char(170),char(155),char(161), -char(171),char(170),char(169),char(178),char(189),char(192),char(187),char(176),char(158),char(146), -char(127),char(118),char(109),char(96),char(97),char(101),char(97),char(104),char(115),char(123), -char(121),char(126),char(140),char(151),char(152),char(152),char(137),char(113),char(110),char(111), -char(119),char(127),char(132),char(136),char(141),char(154),char(159),char(153),char(142),char(141), -char(140),char(148),char(148),char(135),char(69),char(52),char(39),char(42),char(40),char(31), -char(27),char(33),char(38),char(54),char(60),char(57),char(49),char(46),char(51),char(48), -char(47),char(42),char(46),char(47),char(54),char(61),char(73),char(70),char(67),char(63), -char(68),char(74),char(74),char(65),char(44),char(43),char(43),char(39),char(39),char(43), -char(51),char(55),char(65),char(93),char(116),char(128),char(141),char(155),char(153),char(145), -char(140),char(135),char(130),char(124),char(118),char(120),char(121),char(131),char(151),char(164), -char(167),char(153),char(146),char(143),char(138),char(150),char(165),char(169),char(167),char(163), -char(165),char(164),char(151),char(144),char(128),char(122),char(136),char(151),char(149),char(150), -char(162),char(166),char(173),char(191),char(197),char(178),char(160),char(158),char(168),char(168), -char(167),char(177),char(184),char(185),char(184),char(172),char(158),char(143),char(124),char(112), -char(100),char(89),char(86),char(96),char(91),char(103),char(114),char(125),char(134),char(135), -char(142),char(146),char(149),char(154),char(131),char(105),char(103),char(105),char(111),char(117), -char(128),char(131),char(139),char(158),char(171),char(163),char(158),char(150),char(156),char(159), -char(152),char(139),char(71),char(61),char(55),char(51),char(46),char(41),char(36),char(35), -char(39),char(40),char(45),char(45),char(38),char(38),char(39),char(38),char(39),char(35), -char(40),char(42),char(47),char(48),char(63),char(65),char(65),char(64),char(64),char(70), -char(70),char(63),char(50),char(42),char(43),char(38),char(38),char(41),char(48),char(56), -char(72),char(97),char(114),char(129),char(147),char(156),char(158),char(151),char(145),char(141), -char(131),char(118),char(114),char(117),char(124),char(138),char(148),char(156),char(157),char(143), -char(136),char(140),char(147),char(151),char(157),char(165),char(167),char(162),char(161),char(160), -char(152),char(143),char(132),char(130),char(143),char(151),char(153),char(162),char(172),char(167), -char(170),char(185),char(192),char(180),char(166),char(163),char(165),char(170),char(168),char(173), -char(179),char(185),char(182),char(163),char(154),char(141),char(126),char(106),char(92),char(84), -char(84),char(91),char(92),char(99),char(110),char(126),char(138),char(145),char(149),char(143), -char(139),char(137),char(121),char(100),char(90),char(90),char(94),char(98),char(112),char(133), -char(142),char(155),char(173),char(176),char(181),char(181),char(174),char(165),char(158),char(147), -char(83),char(79),char(75),char(61),char(49),char(47),char(43),char(35),char(39),char(40), -char(39),char(36),char(31),char(29),char(30),char(29),char(35),char(33),char(34),char(41), -char(45),char(47),char(58),char(62),char(60),char(63),char(61),char(63),char(65),char(61), -char(53),char(44),char(44),char(43),char(43),char(50),char(62),char(75),char(88),char(107), -char(122),char(134),char(141),char(143),char(143),char(134),char(133),char(133),char(121),char(117), -char(124),char(128),char(136),char(145),char(144),char(146),char(140),char(127),char(130),char(148), -char(162),char(154),char(146),char(156),char(162),char(159),char(156),char(156),char(157),char(153), -char(143),char(139),char(146),char(156),char(169),char(180),char(182),char(168),char(169),char(182), -char(191),char(192),char(183),char(183),char(187),char(182),char(180),char(184),char(186),char(190), -char(184),char(158),char(148),char(135),char(117),char(99),char(87),char(83),char(77),char(80), -char(92),char(102),char(112),char(134),char(149),char(155),char(158),char(146),char(130),char(117), -char(108),char(100),char(86),char(84),char(87),char(84),char(96),char(118),char(138),char(147), -char(165),char(180),char(192),char(203),char(187),char(180),char(173),char(166),char(98),char(90), -char(89),char(69),char(51),char(46),char(44),char(42),char(41),char(43),char(39),char(31), -char(27),char(22),char(20),char(22),char(26),char(25),char(27),char(38),char(46),char(48), -char(53),char(55),char(53),char(61),char(67),char(69),char(61),char(63),char(57),char(51), -char(53),char(59),char(67),char(77),char(92),char(98),char(109),char(123),char(128),char(140), -char(141),char(131),char(118),char(109),char(114),char(121),char(112),char(109),char(116),char(127), -char(137),char(139),char(132),char(131),char(133),char(134),char(143),char(159),char(170),char(159), -char(152),char(162),char(165),char(160),char(158),char(167),char(169),char(160),char(151),char(149), -char(155),char(168),char(178),char(187),char(186),char(176),char(177),char(185),char(194),char(205), -char(207),char(203),char(202),char(195),char(192),char(192),char(199),char(199),char(196),char(175), -char(158),char(142),char(125),char(110),char(100),char(94),char(82),char(79),char(88),char(101), -char(115),char(142),char(153),char(161),char(163),char(146),char(125),char(107),char(98),char(90), -char(83),char(81),char(84),char(89),char(86),char(106),char(128),char(140),char(151),char(167), -char(186),char(198),char(197),char(191),char(189),char(184),char(105),char(90),char(90),char(73), -char(53),char(48),char(44),char(42),char(38),char(38),char(35),char(31),char(26),char(22), -char(16),char(17),char(22),char(21),char(25),char(33),char(40),char(44),char(46),char(42), -char(45),char(59),char(79),char(82),char(80),char(85),char(78),char(76),char(70),char(79), -char(93),char(103),char(118),char(120),char(127),char(130),char(134),char(144),char(149),char(135), -char(117),char(107),char(112),char(113),char(108),char(106),char(109),char(119),char(121),char(114), -char(111),char(112),char(120),char(133),char(147),char(162),char(173),char(164),char(154),char(162), -char(172),char(171),char(175),char(171),char(159),char(148),char(145),char(145),char(153),char(172), -char(183),char(187),char(187),char(191),char(190),char(191),char(206),char(216),char(220),char(212), -char(200),char(196),char(200),char(196),char(202),char(201),char(205),char(195),char(176),char(154), -char(135),char(118),char(105),char(100),char(100),char(86),char(92),char(101),char(118),char(137), -char(150),char(163),char(160),char(143),char(123),char(104),char(95),char(88),char(79),char(80), -char(81),char(90),char(93),char(109),char(122),char(136),char(146),char(159),char(184),char(197), -char(200),char(196),char(203),char(197),char(97),char(77),char(77),char(68),char(60),char(51), -char(44),char(35),char(32),char(28),char(25),char(23),char(19),char(19),char(17),char(15), -char(17),char(20),char(24),char(30),char(35),char(37),char(33),char(30),char(33),char(51), -char(82),char(95),char(95),char(95),char(97),char(98),char(99),char(109),char(120),char(126), -char(134),char(135),char(135),char(137),char(135),char(141),char(150),char(140),char(120),char(111), -char(122),char(121),char(112),char(103),char(100),char(105),char(108),char(99),char(93),char(95), -char(105),char(126),char(138),char(149),char(164),char(165),char(155),char(154),char(164),char(174), -char(177),char(166),char(156),char(153),char(155),char(152),char(156),char(173),char(186),char(192), -char(193),char(201),char(207),char(213),char(229),char(229),char(228),char(221),char(210),char(202), -char(203),char(198),char(199),char(208),char(208),char(204),char(192),char(174),char(143),char(123), -char(110),char(105),char(105),char(96),char(91),char(90),char(102),char(127),char(141),char(150), -char(139),char(127),char(110),char(94),char(92),char(81),char(75),char(78),char(87),char(92), -char(106),char(117),char(128),char(137),char(152),char(162),char(181),char(193),char(199),char(200), -char(204),char(200),char(81),char(70),char(65),char(60),char(57),char(47),char(35),char(30), -char(25),char(19),char(15),char(15),char(14),char(13),char(13),char(14),char(12),char(19), -char(24),char(28),char(31),char(27),char(23),char(25),char(31),char(46),char(77),char(90), -char(86),char(87),char(99),char(108),char(127),char(144),char(149),char(147),char(149),char(145), -char(141),char(145),char(141),char(148),char(150),char(140),char(126),char(121),char(123),char(129), -char(117),char(101),char(91),char(90),char(93),char(94),char(91),char(91),char(106),char(120), -char(127),char(143),char(157),char(164),char(157),char(144),char(148),char(164),char(163),char(161), -char(161),char(156),char(159),char(158),char(160),char(171),char(184),char(192),char(199),char(211), -char(220),char(231),char(241),char(234),char(232),char(228),char(222),char(221),char(210),char(204), -char(206),char(211),char(205),char(195),char(187),char(174),char(149),char(129),char(115),char(111), -char(100),char(95),char(83),char(78),char(93),char(110),char(118),char(124),char(117),char(110), -char(98),char(84),char(77),char(68),char(65),char(78),char(90),char(99),char(121),char(129), -char(131),char(143),char(153),char(159),char(167),char(171),char(185),char(192),char(187),char(183), -char(73),char(59),char(50),char(43),char(42),char(35),char(26),char(23),char(17),char(14), -char(11),char(9),char(9),char(7),char(8),char(9),char(10),char(16),char(23),char(27), -char(26),char(20),char(18),char(26),char(29),char(44),char(71),char(79),char(76),char(84), -char(106),char(128),char(155),char(173),char(167),char(155),char(148),char(145),char(147),char(150), -char(149),char(157),char(162),char(153),char(134),char(129),char(130),char(136),char(127),char(118), -char(104),char(88),char(81),char(82),char(86),char(89),char(105),char(119),char(123),char(135), -char(144),char(147),char(141),char(130),char(137),char(159),char(163),char(157),char(157),char(149), -char(146),char(153),char(164),char(179),char(191),char(199),char(205),char(214),char(218),char(226), -char(233),char(226),char(226),char(229),char(230),char(233),char(221),char(210),char(208),char(208), -char(202),char(186),char(179),char(166),char(142),char(117),char(108),char(105),char(98),char(90), -char(77),char(69),char(77),char(82),char(94),char(97),char(95),char(98),char(100),char(91), -char(79),char(73),char(69),char(78),char(93),char(113),char(128),char(140),char(136),char(148), -char(160),char(164),char(158),char(150),char(158),char(177),char(171),char(164),char(70),char(53), -char(46),char(35),char(27),char(23),char(23),char(20),char(15),char(10),char(7),char(4), -char(4),char(3),char(5),char(6),char(7),char(13),char(20),char(26),char(27),char(23), -char(23),char(33),char(40),char(50),char(65),char(74),char(81),char(96),char(129),char(162), -char(185),char(201),char(190),char(177),char(168),char(158),char(152),char(147),char(152),char(159), -char(169),char(166),char(144),char(136),char(143),char(145),char(139),char(129),char(119),char(100), -char(81),char(78),char(77),char(82),char(101),char(114),char(121),char(124),char(134),char(143), -char(137),char(121),char(122),char(150),char(168),char(159),char(148),char(144),char(140),char(146), -char(161),char(179),char(193),char(200),char(200),char(206),char(214),char(220),char(218),char(215), -char(217),char(228),char(238),char(237),char(224),char(213),char(204),char(205),char(202),char(189), -char(174),char(158),char(135),char(113),char(103),char(93),char(86),char(84),char(74),char(60), -char(61),char(72),char(78),char(75),char(77),char(77),char(91),char(95),char(84),char(80), -char(76),char(80),char(99),char(115),char(139),char(149),char(143),char(156),char(159),char(162), -char(158),char(150),char(152),char(158),char(159),char(162),char(62),char(46),char(39),char(25), -char(17),char(15),char(16),char(17),char(15),char(8),char(5),char(2),char(2),char(3), -char(3),char(6),char(7),char(12),char(16),char(24),char(26),char(24),char(34),char(43), -char(54),char(62),char(70),char(79),char(88),char(112),char(154),char(183),char(200),char(218), -char(219),char(207),char(195),char(188),char(172),char(159),char(160),char(166),char(174),char(171), -char(157),char(155),char(162),char(153),char(142),char(131),char(127),char(114),char(95),char(84), -char(74),char(71),char(82),char(95),char(104),char(110),char(119),char(130),char(131),char(126), -char(122),char(137),char(159),char(154),char(139),char(138),char(136),char(144),char(162),char(178), -char(188),char(190),char(189),char(189),char(194),char(199),char(203),char(209),char(216),char(225), -char(235),char(231),char(218),char(205),char(193),char(184),char(180),char(175),char(161),char(147), -char(125),char(106),char(98),char(91),char(79),char(72),char(69),char(57),char(54),char(61), -char(63),char(66),char(63),char(61),char(70),char(81),char(79),char(81),char(81),char(86), -char(108),char(119),char(139),char(151),char(157),char(162),char(167),char(164),char(171),char(161), -char(150),char(143),char(150),char(151),char(55),char(45),char(34),char(22),char(14),char(11), -char(12),char(14),char(11),char(7),char(5),char(2),char(2),char(2),char(3),char(5), -char(6),char(11),char(16),char(22),char(21),char(26),char(44),char(52),char(62),char(76), -char(77),char(90),char(108),char(137),char(166),char(195),char(212),char(228),char(230),char(218), -char(207),char(203),char(191),char(180),char(173),char(169),char(177),char(183),char(179),char(172), -char(166),char(152),char(143),char(136),char(125),char(118),char(105),char(85),char(77),char(72), -char(65),char(68),char(84),char(101),char(106),char(109),char(112),char(120),char(118),char(128), -char(146),char(144),char(133),char(125),char(132),char(142),char(163),char(178),char(183),char(185), -char(186),char(183),char(182),char(184),char(191),char(201),char(212),char(219),char(221),char(215), -char(199),char(187),char(174),char(159),char(150),char(150),char(141),char(127),char(101),char(83), -char(78),char(77),char(65),char(61),char(63),char(60),char(62),char(54),char(53),char(55), -char(55),char(51),char(50),char(64),char(75),char(78),char(88),char(97),char(110),char(127), -char(143),char(157),char(166),char(177),char(176),char(176),char(179),char(163),char(149),char(143), -char(147),char(149),char(43),char(37),char(26),char(20),char(17),char(14),char(13),char(13), -char(10),char(5),char(3),char(2),char(2),char(3),char(4),char(3),char(5),char(8), -char(14),char(18),char(23),char(33),char(49),char(57),char(65),char(74),char(81),char(97), -char(130),char(157),char(175),char(196),char(212),char(223),char(224),char(211),char(211),char(208), -char(199),char(198),char(191),char(185),char(195),char(201),char(196),char(181),char(160),char(153), -char(151),char(132),char(119),char(112),char(97),char(87),char(80),char(74),char(65),char(57), -char(65),char(81),char(87),char(81),char(81),char(92),char(92),char(100),char(113),char(122), -char(116),char(107),char(118),char(138),char(160),char(173),char(181),char(180),char(184),char(184), -char(177),char(175),char(178),char(184),char(198),char(204),char(188),char(181),char(170),char(154), -char(150),char(140),char(128),char(120),char(118),char(105),char(80),char(63),char(62),char(60), -char(62),char(61),char(64),char(64),char(69),char(58),char(51),char(49),char(46),char(43), -char(46),char(56),char(67),char(77),char(85),char(98),char(119),char(136),char(147),char(161), -char(174),char(179),char(176),char(173),char(177),char(169),char(158),char(152),char(155),char(159), -char(38),char(32),char(23),char(18),char(15),char(13),char(13),char(13),char(10),char(4), -char(2),char(2),char(2),char(3),char(5),char(6),char(5),char(6),char(11),char(19), -char(30),char(44),char(55),char(64),char(73),char(72),char(85),char(106),char(130),char(161), -char(184),char(198),char(201),char(211),char(220),char(216),char(214),char(213),char(203),char(202), -char(205),char(211),char(220),char(219),char(210),char(187),char(165),char(159),char(146),char(121), -char(102),char(106),char(99),char(81),char(73),char(71),char(62),char(54),char(62),char(72), -char(69),char(64),char(65),char(69),char(70),char(77),char(91),char(98),char(93),char(90), -char(105),char(132),char(163),char(179),char(178),char(176),char(182),char(178),char(163),char(156), -char(155),char(160),char(173),char(171),char(155),char(150),char(139),char(131),char(133),char(126), -char(119),char(105),char(89),char(72),char(58),char(49),char(52),char(51),char(65),char(74), -char(69),char(66),char(69),char(63),char(55),char(54),char(49),char(47),char(42),char(49), -char(62),char(73),char(87),char(95),char(119),char(135),char(145),char(153),char(166),char(171), -char(168),char(166),char(172),char(173),char(166),char(165),char(175),char(177),char(39),char(26), -char(22),char(17),char(12),char(10),char(10),char(8),char(6),char(4),char(3),char(3), -char(2),char(4),char(6),char(10),char(11),char(12),char(17),char(23),char(32),char(40), -char(49),char(66),char(81),char(82),char(87),char(103),char(125),char(154),char(183),char(202), -char(204),char(211),char(220),char(227),char(226),char(224),char(215),char(215),char(213),char(220), -char(232),char(223),char(212),char(191),char(166),char(154),char(140),char(120),char(102),char(104), -char(96),char(78),char(69),char(63),char(58),char(56),char(63),char(66),char(65),char(60), -char(58),char(52),char(49),char(55),char(63),char(66),char(75),char(80),char(90),char(120), -char(156),char(178),char(185),char(187),char(185),char(177),char(169),char(155),char(144),char(147), -char(153),char(142),char(135),char(127),char(112),char(110),char(117),char(111),char(105),char(101), -char(83),char(67),char(55),char(44),char(43),char(51),char(62),char(69),char(75),char(76), -char(72),char(62),char(60),char(59),char(50),char(47),char(43),char(43),char(61),char(81), -char(91),char(102),char(117),char(136),char(147),char(157),char(158),char(167),char(169),char(166), -char(164),char(172),char(170),char(174),char(178),char(186),char(45),char(29),char(18),char(14), -char(11),char(9),char(7),char(5),char(6),char(6),char(5),char(4),char(3),char(6), -char(9),char(15),char(21),char(22),char(27),char(32),char(34),char(38),char(47),char(64), -char(87),char(100),char(104),char(108),char(125),char(148),char(184),char(204),char(208),char(212), -char(219),char(238),char(239),char(236),char(235),char(232),char(228),char(231),char(227),char(217), -char(211),char(196),char(172),char(153),char(141),char(129),char(113),char(109),char(101),char(88), -char(76),char(67),char(58),char(54),char(56),char(61),char(62),char(60),char(52),char(42), -char(36),char(39),char(39),char(38),char(49),char(68),char(87),char(111),char(143),char(165), -char(182),char(188),char(177),char(167),char(163),char(149),char(138),char(127),char(122),char(114), -char(111),char(100),char(88),char(86),char(87),char(85),char(88),char(90),char(83),char(72), -char(59),char(44),char(44),char(53),char(53),char(58),char(76),char(89),char(81),char(67), -char(65),char(63),char(53),char(50),char(48),char(45),char(68),char(90),char(98),char(107), -char(133),char(145),char(157),char(167),char(166),char(160),char(164),char(171),char(171),char(175), -char(178),char(176),char(179),char(184),char(54),char(34),char(23),char(15),char(13),char(9), -char(4),char(5),char(8),char(8),char(10),char(9),char(7),char(11),char(15),char(19), -char(23),char(28),char(30),char(29),char(36),char(42),char(51),char(73),char(87),char(102), -char(120),char(123),char(124),char(144),char(174),char(192),char(200),char(210),char(224),char(237), -char(239),char(241),char(241),char(236),char(235),char(233),char(223),char(218),char(214),char(199), -char(181),char(166),char(150),char(137),char(127),char(123),char(119),char(101),char(79),char(63), -char(50),char(46),char(50),char(54),char(55),char(53),char(42),char(30),char(26),char(28), -char(26),char(27),char(36),char(55),char(82),char(108),char(129),char(143),char(159),char(169), -char(163),char(157),char(148),char(134),char(120),char(107),char(91),char(87),char(93),char(86), -char(78),char(72),char(63),char(63),char(67),char(64),char(63),char(63),char(49),char(41), -char(39),char(46),char(51),char(56),char(69),char(86),char(83),char(67),char(65),char(57), -char(51),char(45),char(46),char(51),char(71),char(96),char(114),char(120),char(145),char(157), -char(169),char(180),char(186),char(174),char(174),char(175),char(175),char(188),char(189),char(178), -char(181),char(177),char(69),char(50),char(38),char(26),char(18),char(11),char(6),char(7), -char(9),char(9),char(13),char(13),char(15),char(18),char(19),char(20),char(23),char(31), -char(30),char(32),char(36),char(48),char(59),char(71),char(86),char(105),char(125),char(126), -char(135),char(147),char(159),char(171),char(189),char(198),char(219),char(234),char(242),char(245), -char(243),char(241),char(238),char(231),char(225),char(220),char(215),char(205),char(187),char(165), -char(151),char(141),char(138),char(129),char(114),char(98),char(80),char(68),char(55),char(46), -char(44),char(42),char(42),char(41),char(35),char(27),char(24),char(24),char(22),char(20), -char(28),char(43),char(66),char(85),char(101),char(122),char(139),char(148),char(139),char(134), -char(131),char(117),char(102),char(90),char(73),char(65),char(73),char(75),char(63),char(52), -char(48),char(55),char(61),char(57),char(54),char(55),char(42),char(33),char(36),char(40), -char(45),char(57),char(77),char(94),char(86),char(73),char(59),char(44),char(39),char(36), -char(44),char(57),char(84),char(117),char(135),char(145),char(162),char(167),char(178),char(188), -char(203),char(196),char(181),char(172),char(170),char(187),char(184),char(179),char(187),char(186), -char(84),char(63),char(44),char(30),char(25),char(17),char(15),char(14),char(14),char(14), -char(18),char(21),char(22),char(28),char(26),char(24),char(29),char(36),char(43),char(46), -char(50),char(63),char(77),char(81),char(94),char(118),char(122),char(132),char(146),char(156), -char(159),char(170),char(181),char(196),char(218),char(236),char(241),char(244),char(240),char(237), -char(233),char(224),char(219),char(212),char(211),char(204),char(186),char(162),char(148),char(140), -char(135),char(127),char(111),char(99),char(86),char(67),char(48),char(41),char(44),char(42), -char(39),char(33),char(24),char(20),char(19),char(18),char(14),char(14),char(22),char(31), -char(45),char(57),char(77),char(103),char(118),char(128),char(122),char(106),char(100),char(104), -char(97),char(75),char(63),char(60),char(61),char(63),char(54),char(44),char(38),char(43), -char(49),char(52),char(53),char(43),char(31),char(27),char(32),char(40),char(48),char(57), -char(78),char(93),char(85),char(72),char(56),char(43),char(37),char(37),char(40),char(54), -char(95),char(123),char(144),char(166),char(175),char(185),char(192),char(197),char(206),char(206), -char(198),char(182),char(173),char(188),char(189),char(190),char(184),char(196),char(83),char(69), -char(49),char(33),char(29),char(22),char(25),char(24),char(19),char(17),char(19),char(22), -char(25),char(31),char(30),char(34),char(45),char(58),char(63),char(67),char(67),char(71), -char(88),char(93),char(101),char(115),char(129),char(142),char(162),char(179),char(180),char(184), -char(193),char(205),char(225),char(241),char(238),char(239),char(231),char(227),char(229),char(223), -char(212),char(209),char(204),char(194),char(184),char(168),char(151),char(136),char(132),char(124), -char(113),char(95),char(76),char(60),char(47),char(45),char(46),char(44),char(43),char(32), -char(17),char(16),char(14),char(11),char(9),char(8),char(13),char(18),char(25),char(37), -char(60),char(79),char(97),char(115),char(105),char(88),char(84),char(90),char(89),char(77), -char(65),char(63),char(59),char(48),char(41),char(39),char(35),char(38),char(46),char(50), -char(46),char(35),char(29),char(27),char(31),char(41),char(49),char(60),char(69),char(78), -char(76),char(64),char(52),char(43),char(40),char(41),char(43),char(58),char(90),char(115), -char(142),char(171),char(185),char(187),char(190),char(196),char(200),char(204),char(204),char(194), -char(186),char(199),char(202),char(199),char(192),char(200),char(81),char(66),char(46),char(39), -char(35),char(26),char(27),char(27),char(21),char(19),char(22),char(22),char(25),char(32), -char(42),char(51),char(69),char(82),char(83),char(80),char(80),char(80),char(85),char(100), -char(112),char(120),char(129),char(152),char(180),char(193),char(190),char(192),char(198),char(210), -char(228),char(240),char(242),char(238),char(230),char(225),char(219),char(218),char(212),char(202), -char(200),char(197),char(185),char(170),char(151),char(131),char(124),char(112),char(102),char(81), -char(61),char(52),char(43),char(39),char(41),char(45),char(44),char(32),char(20),char(12), -char(7),char(5),char(5),char(4),char(7),char(13),char(19),char(23),char(39),char(56), -char(74),char(91),char(91),char(80),char(74),char(76),char(75),char(70),char(68),char(71), -char(58),char(41),char(34),char(37),char(41),char(45),char(52),char(45),char(37),char(32), -char(29),char(33),char(36),char(43),char(45),char(50),char(61),char(69),char(63),char(55), -char(48),char(45),char(44),char(44),char(44),char(61),char(83),char(110),char(144),char(169), -char(181),char(185),char(184),char(191),char(196),char(206),char(204),char(193),char(198),char(207), -char(202),char(200),char(200),char(209),char(79),char(65),char(52),char(48),char(43),char(35), -char(35),char(32),char(28),char(25),char(25),char(31),char(39),char(47),char(55),char(68), -char(89),char(98),char(97),char(94),char(98),char(103),char(104),char(117),char(127),char(137), -char(142),char(161),char(183),char(187),char(184),char(193),char(200),char(215),char(235),char(244), -char(239),char(227),char(215),char(211),char(207),char(211),char(215),char(203),char(196),char(196), -char(183),char(167),char(145),char(131),char(124),char(101),char(86),char(71),char(52),char(45), -char(41),char(37),char(36),char(44),char(45),char(33),char(22),char(11),char(4),char(2), -char(2),char(3),char(3),char(7),char(11),char(17),char(24),char(35),char(52),char(67), -char(71),char(67),char(64),char(57),char(56),char(55),char(62),char(67),char(63),char(57), -char(48),char(43),char(41),char(41),char(44),char(42),char(35),char(28),char(24),char(28), -char(31),char(33),char(37),char(48),char(51),char(60),char(59),char(49),char(43),char(43), -char(43),char(53),char(61),char(81),char(98),char(122),char(146),char(164),char(167),char(176), -char(182),char(199),char(202),char(209),char(200),char(193),char(202),char(211),char(207),char(204), -char(207),char(217),char(77),char(73),char(65),char(55),char(53),char(47),char(42),char(34), -char(30),char(31),char(36),char(41),char(48),char(62),char(83),char(90),char(99),char(98), -char(99),char(108),char(125),char(128),char(129),char(131),char(133),char(143),char(158),char(169), -char(169),char(171),char(180),char(194),char(209),char(226),char(232),char(239),char(234),char(221), -char(197),char(184),char(184),char(197),char(200),char(191),char(189),char(193),char(186),char(169), -char(151),char(137),char(124),char(97),char(85),char(69),char(48),char(41),char(43),char(40), -char(32),char(35),char(36),char(31),char(19),char(8),char(2),char(1),char(1),char(1), -char(1),char(3),char(6),char(12),char(18),char(24),char(35),char(48),char(51),char(48), -char(43),char(44),char(50),char(52),char(65),char(76),char(71),char(63),char(49),char(40), -char(39),char(39),char(39),char(37),char(34),char(27),char(23),char(24),char(23),char(27), -char(35),char(50),char(52),char(47),char(50),char(47),char(43),char(40),char(42),char(61), -char(72),char(88),char(104),char(130),char(153),char(169),char(161),char(169),char(189),char(201), -char(197),char(202),char(204),char(205),char(206),char(200),char(202),char(202),char(206),char(203), -char(77),char(80),char(75),char(62),char(60),char(49),char(51),char(43),char(35),char(42), -char(41),char(50),char(62),char(84),char(99),char(104),char(105),char(110),char(109),char(120), -char(137),char(139),char(138),char(144),char(137),char(146),char(165),char(168),char(157),char(155), -char(166),char(185),char(202),char(216),char(221),char(223),char(217),char(209),char(190),char(169), -char(163),char(168),char(169),char(171),char(169),char(174),char(178),char(167),char(157),char(134), -char(106),char(96),char(87),char(74),char(55),char(43),char(42),char(42),char(34),char(28), -char(26),char(22),char(15),char(7),char(3),char(1),char(0),char(0),char(0),char(1), -char(4),char(8),char(14),char(19),char(25),char(35),char(42),char(37),char(31),char(38), -char(51),char(62),char(66),char(71),char(72),char(58),char(43),char(35),char(32),char(34), -char(34),char(32),char(28),char(21),char(22),char(22),char(21),char(28),char(35),char(47), -char(52),char(52),char(55),char(53),char(50),char(46),char(49),char(57),char(67),char(75), -char(98),char(119),char(138),char(163),char(171),char(181),char(192),char(194),char(187),char(202), -char(204),char(203),char(192),char(185),char(196),char(201),char(198),char(185),char(86),char(94), -char(87),char(75),char(68),char(65),char(69),char(61),char(47),char(47),char(50),char(62), -char(78),char(96),char(104),char(101),char(105),char(111),char(107),char(122),char(136),char(140), -char(151),char(157),char(151),char(154),char(162),char(157),char(147),char(145),char(158),char(174), -char(191),char(212),char(216),char(208),char(198),char(184),char(180),char(165),char(150),char(143), -char(144),char(143),char(141),char(141),char(148),char(154),char(153),char(132),char(104),char(94), -char(88),char(79),char(66),char(45),char(34),char(32),char(30),char(23),char(18),char(14), -char(12),char(7),char(2),char(0),char(0),char(0),char(0),char(1),char(5),char(9), -char(12),char(16),char(21),char(29),char(36),char(35),char(31),char(38),char(47),char(54), -char(57),char(53),char(57),char(49),char(37),char(31),char(27),char(29),char(27),char(23), -char(20),char(19),char(21),char(22),char(20),char(26),char(35),char(41),char(56),char(62), -char(61),char(53),char(52),char(59),char(56),char(50),char(52),char(65),char(88),char(102), -char(123),char(151),char(173),char(188),char(187),char(189),char(189),char(198),char(203),char(189), -char(178),char(173),char(189),char(188),char(177),char(175),char(100),char(112),char(105),char(94), -char(80),char(83),char(87),char(71),char(58),char(56),char(64),char(69),char(83),char(100), -char(110),char(108),char(109),char(119),char(117),char(118),char(131),char(148),char(167),char(166), -char(162),char(156),char(157),char(155),char(143),char(145),char(150),char(154),char(177),char(192), -char(196),char(198),char(185),char(170),char(165),char(152),char(136),char(124),char(124),char(122), -char(123),char(127),char(136),char(143),char(133),char(121),char(97),char(78),char(79),char(82), -char(73),char(51),char(37),char(34),char(30),char(21),char(15),char(9),char(6),char(3), -char(2),char(0),char(0),char(0),char(0),char(0),char(3),char(7),char(10),char(15), -char(18),char(21),char(24),char(24),char(26),char(31),char(38),char(42),char(48),char(43), -char(44),char(41),char(37),char(31),char(25),char(26),char(26),char(27),char(22),char(23), -char(28),char(27),char(28),char(36),char(49),char(51),char(57),char(66),char(76),char(74), -char(67),char(64),char(54),char(55),char(67),char(75),char(84),char(82),char(104),char(135), -char(157),char(170),char(170),char(171),char(179),char(185),char(192),char(181),char(167),char(165), -char(176),char(186),char(178),char(176),char(102),char(108),char(111),char(109),char(96),char(103), -char(101),char(82),char(66),char(72),char(77),char(88),char(96),char(106),char(106),char(109), -char(111),char(117),char(126),char(124),char(137),char(161),char(174),char(174),char(156),char(149), -char(152),char(152),char(149),char(145),char(145),char(153),char(167),char(181),char(191),char(196), -char(182),char(159),char(149),char(147),char(145),char(137),char(128),char(125),char(124),char(126), -char(131),char(132),char(120),char(103),char(84),char(71),char(73),char(74),char(65),char(50), -char(41),char(35),char(28),char(20),char(15),char(9),char(4),char(2),char(1),char(0), -char(0),char(0),char(0),char(0),char(2),char(6),char(9),char(10),char(10),char(12), -char(14),char(18),char(19),char(24),char(32),char(36),char(35),char(32),char(31),char(34), -char(33),char(30),char(26),char(26),char(26),char(29),char(33),char(37),char(40),char(35), -char(32),char(40),char(50),char(61),char(66),char(68),char(75),char(78),char(72),char(61), -char(59),char(61),char(77),char(83),char(87),char(77),char(91),char(119),char(127),char(141), -char(153),char(162),char(168),char(163),char(177),char(189),char(172),char(168),char(177),char(182), -char(174),char(166),char(105),char(113),char(121),char(121),char(118),char(120),char(112),char(96), -char(91),char(88),char(86),char(91),char(103),char(109),char(107),char(109),char(117),char(122), -char(137),char(133),char(140),char(162),char(174),char(169),char(159),char(152),char(155),char(166), -char(164),char(160),char(163),char(167),char(168),char(176),char(183),char(187),char(175),char(157), -char(150),char(150),char(149),char(141),char(135),char(123),char(126),char(130),char(129),char(136), -char(121),char(94),char(76),char(61),char(58),char(58),char(54),char(50),char(41),char(32), -char(25),char(24),char(18),char(11),char(7),char(4),char(2),char(0),char(0),char(0), -char(0),char(0),char(0),char(2),char(5),char(5),char(4),char(6),char(9),char(13), -char(16),char(21),char(28),char(30),char(25),char(22),char(26),char(29),char(29),char(27), -char(26),char(26),char(25),char(32),char(40),char(42),char(49),char(44),char(39),char(39), -char(53),char(68),char(76),char(72),char(68),char(70),char(63),char(62),char(54),char(65), -char(78),char(87),char(94),char(83),char(88),char(107),char(115),char(129),char(144),char(152), -char(152),char(152),char(165),char(183),char(179),char(173),char(178),char(180),char(171),char(158), -char(117),char(122),char(121),char(121),char(124),char(127),char(129),char(127),char(121),char(102), -char(94),char(88),char(103),char(107),char(105),char(108),char(120),char(127),char(132),char(134), -char(145),char(163),char(171),char(170),char(159),char(161),char(163),char(175),char(173),char(175), -char(180),char(177),char(177),char(177),char(179),char(179),char(170),char(153),char(150),char(146), -char(147),char(138),char(135),char(129),char(125),char(133),char(135),char(134),char(126),char(107), -char(85),char(58),char(47),char(49),char(48),char(47),char(38),char(27),char(22),char(23), -char(21),char(15),char(10),char(6),char(3),char(1),char(0),char(0),char(0),char(0), -char(0),char(1),char(1),char(1),char(3),char(3),char(6),char(10),char(14),char(20), -char(23),char(23),char(19),char(17),char(19),char(19),char(20),char(26),char(26),char(25), -char(24),char(31),char(37),char(48),char(56),char(53),char(55),char(59),char(61),char(76), -char(76),char(70),char(65),char(68),char(64),char(65),char(63),char(76),char(88),char(95), -char(99),char(93),char(93),char(105),char(126),char(136),char(140),char(133),char(147),char(155), -char(158),char(176),char(173),char(177),char(180),char(179),char(172),char(162),char(117),char(126), -char(119),char(118),char(123),char(124),char(138),char(144),char(125),char(103),char(98),char(95), -char(104),char(105),char(103),char(110),char(113),char(123),char(134),char(138),char(147),char(164), -char(171),char(165),char(159),char(164),char(172),char(184),char(183),char(181),char(180),char(179), -char(171),char(169),char(171),char(169),char(157),char(152),char(157),char(166),char(168),char(157), -char(143),char(138),char(141),char(149),char(157),char(147),char(131),char(107),char(82),char(58), -char(42),char(43),char(50),char(51),char(37),char(28),char(26),char(23),char(20),char(16), -char(12),char(6),char(3),char(1),char(1),char(0),char(0),char(0),char(0),char(0), -char(0),char(2),char(2),char(4),char(8),char(12),char(13),char(14),char(17),char(19), -char(18),char(16),char(16),char(16),char(18),char(21),char(28),char(29),char(26),char(31), -char(38),char(48),char(57),char(62),char(69),char(80),char(79),char(85),char(84),char(76), -char(63),char(65),char(66),char(72),char(75),char(86),char(102),char(107),char(103),char(99), -char(100),char(110),char(136),char(137),char(135),char(134),char(153),char(153),char(159),char(177), -char(175),char(183),char(188),char(190),char(186),char(177),char(105),char(114),char(103),char(107), -char(116),char(123),char(141),char(138),char(122),char(113),char(110),char(103),char(115),char(125), -char(122),char(127),char(130),char(135),char(148),char(149),char(151),char(161),char(167),char(160), -char(158),char(156),char(167),char(180),char(180),char(183),char(179),char(176),char(170),char(166), -char(164),char(164),char(154),char(161),char(165),char(178),char(183),char(170),char(155),char(150), -char(143),char(150),char(156),char(154),char(140),char(113),char(85),char(69),char(51),char(48), -char(60),char(65),char(49),char(37),char(35),char(27),char(18),char(11),char(7),char(5), -char(4),char(3),char(3),char(1),char(0),char(0),char(0),char(0),char(2),char(2), -char(2),char(3),char(6),char(10),char(10),char(10),char(12),char(14),char(16),char(15), -char(13),char(16),char(17),char(20),char(24),char(26),char(28),char(34),char(41),char(45), -char(58),char(64),char(71),char(86),char(93),char(91),char(89),char(83),char(67),char(74), -char(76),char(73),char(78),char(86),char(96),char(109),char(105),char(103),char(107),char(112), -char(124),char(130),char(124),char(132),char(157),char(157),char(166),char(184),char(182),char(188), -char(196),char(196),char(191),char(183),char(97),char(93),char(83),char(88),char(112),char(122), -char(127),char(128),char(128),char(119),char(110),char(116),char(142),char(149),char(152),char(156), -char(155),char(166),char(170),char(171),char(173),char(171),char(175),char(165),char(152),char(150), -char(160),char(171),char(178),char(188),char(186),char(184),char(182),char(178),char(173),char(162), -char(147),char(153),char(165),char(185),char(185),char(179),char(181),char(174),char(159),char(150), -char(154),char(150),char(137),char(114),char(92),char(74),char(58),char(60),char(72),char(78), -char(64),char(44),char(34),char(30),char(17),char(9),char(6),char(5),char(4),char(4), -char(4),char(4),char(2),char(2),char(3),char(3),char(4),char(3),char(3),char(5), -char(6),char(6),char(7),char(7),char(9),char(11),char(14),char(13),char(13),char(14), -char(17),char(19),char(21),char(23),char(29),char(35),char(39),char(45),char(44),char(53), -char(65),char(74),char(87),char(89),char(85),char(77),char(74),char(84),char(87),char(82), -char(81),char(85),char(93),char(105),char(110),char(104),char(109),char(112),char(112),char(121), -char(122),char(135),char(151),char(163),char(171),char(178),char(178),char(180),char(189),char(193), -char(195),char(185),char(84),char(69),char(66),char(79),char(100),char(103),char(110),char(119), -char(121),char(121),char(113),char(127),char(152),char(160),char(164),char(166),char(166),char(176), -char(180),char(188),char(190),char(187),char(183),char(173),char(154),char(160),char(163),char(169), -char(188),char(196),char(192),char(196),char(193),char(195),char(177),char(159),char(152),char(154), -char(160),char(175),char(191),char(196),char(194),char(186),char(177),char(161),char(153),char(150), -char(137),char(115),char(97),char(80),char(64),char(64),char(73),char(73),char(61),char(41), -char(32),char(32),char(23),char(13),char(8),char(4),char(3),char(4),char(6),char(7), -char(6),char(5),char(6),char(7),char(5),char(5),char(7),char(8),char(9),char(8), -char(8),char(7),char(7),char(8),char(9),char(10),char(10),char(11),char(12),char(16), -char(19),char(21),char(27),char(34),char(37),char(40),char(40),char(49),char(60),char(61), -char(63),char(69),char(70),char(76),char(77),char(86),char(86),char(82),char(82),char(78), -char(85),char(100),char(106),char(103),char(100),char(103),char(111),char(126),char(129),char(137), -char(147),char(159),char(167),char(170),char(158),char(156),char(169),char(187),char(186),char(173), -char(77),char(59),char(54),char(60),char(75),char(81),char(91),char(96),char(108),char(121), -char(121),char(139),char(156),char(162),char(165),char(172),char(171),char(180),char(184),char(187), -char(198),char(193),char(179),char(164),char(163),char(172),char(170),char(174),char(184),char(203), -char(204),char(205),char(205),char(197),char(177),char(166),char(165),char(164),char(159),char(166), -char(182),char(193),char(195),char(188),char(176),char(166),char(147),char(132),char(127),char(117), -char(105),char(93),char(76),char(69),char(74),char(72),char(59),char(39),char(28),char(26), -char(22),char(14),char(9),char(5),char(4),char(5),char(8),char(10),char(10),char(9), -char(11),char(12),char(9),char(9),char(10),char(14),char(15),char(13),char(12),char(11), -char(8),char(5),char(5),char(4),char(6),char(10),char(13),char(18),char(18),char(18), -char(24),char(33),char(37),char(32),char(34),char(44),char(49),char(52),char(59),char(64), -char(66),char(79),char(83),char(91),char(89),char(71),char(64),char(62),char(63),char(79), -char(89),char(95),char(105),char(108),char(113),char(127),char(122),char(137),char(148),char(152), -char(149),char(150),char(143),char(150),char(166),char(172),char(171),char(157),char(80),char(63), -char(58),char(57),char(60),char(65),char(68),char(80),char(91),char(110),char(125),char(145), -char(150),char(161),char(168),char(160),char(170),char(179),char(183),char(183),char(185),char(173), -char(169),char(169),char(173),char(179),char(182),char(183),char(192),char(203),char(202),char(204), -char(203),char(191),char(182),char(170),char(169),char(180),char(180),char(175),char(180),char(191), -char(199),char(198),char(190),char(176),char(159),char(146),char(139),char(133),char(114),char(110), -char(102),char(87),char(77),char(66),char(58),char(44),char(29),char(20),char(14),char(10), -char(7),char(5),char(4),char(6),char(10),char(15),char(18),char(17),char(18),char(19), -char(19),char(19),char(17),char(21),char(23),char(21),char(21),char(20),char(12),char(7), -char(6),char(5),char(7),char(9),char(17),char(22),char(20),char(29),char(32),char(40), -char(43),char(33),char(35),char(41),char(47),char(52),char(56),char(57),char(69),char(77), -char(78),char(83),char(83),char(70),char(65),char(65),char(68),char(84),char(97),char(92), -char(101),char(116),char(117),char(125),char(128),char(139),char(146),char(146),char(138),char(134), -char(134),char(137),char(151),char(160),char(166),char(151),char(88),char(69),char(64),char(62), -char(61),char(61),char(59),char(62),char(78),char(99),char(120),char(137),char(141),char(158), -char(166),char(162),char(166),char(176),char(175),char(174),char(167),char(160),char(169),char(174), -char(173),char(179),char(185),char(191),char(196),char(190),char(194),char(191),char(188),char(176), -char(170),char(167),char(178),char(189),char(188),char(179),char(180),char(195),char(201),char(206), -char(203),char(196),char(182),char(163),char(153),char(142),char(127),char(126),char(119),char(104), -char(88),char(78),char(69),char(52),char(35),char(23),char(16),char(11),char(7),char(4), -char(7),char(13),char(18),char(24),char(24),char(27),char(30),char(30),char(29),char(29), -char(26),char(27),char(27),char(25),char(30),char(30),char(20),char(13),char(9),char(9), -char(10),char(12),char(24),char(31),char(29),char(37),char(41),char(49),char(53),char(46), -char(45),char(50),char(52),char(66),char(63),char(62),char(75),char(76),char(80),char(78), -char(74),char(75),char(76),char(79),char(84),char(95),char(110),char(100),char(102),char(115), -char(120),char(126),char(122),char(127),char(140),char(128),char(118),char(122),char(125),char(124), -char(136),char(153),char(149),char(149),char(81),char(70),char(67),char(64),char(65),char(64), -char(64),char(60),char(73),char(94),char(120),char(135),char(144),char(155),char(165),char(166), -char(167),char(163),char(168),char(170),char(168),char(160),char(167),char(180),char(180),char(182), -char(184),char(186),char(192),char(189),char(189),char(187),char(181),char(171),char(169),char(166), -char(180),char(189),char(187),char(180),char(182),char(194),char(199),char(211),char(217),char(204), -char(186),char(174),char(159),char(145),char(141),char(136),char(129),char(118),char(103),char(86), -char(77),char(66),char(47),char(32),char(22),char(14),char(9),char(8),char(10),char(18), -char(28),char(31),char(39),char(45),char(45),char(44),char(38),char(32),char(29),char(29), -char(30),char(30),char(37),char(37),char(29),char(19),char(10),char(10),char(11),char(16), -char(26),char(31),char(37),char(43),char(45),char(49),char(60),char(59),char(58),char(61), -char(72),char(86),char(84),char(79),char(85),char(90),char(85),char(81),char(79),char(76), -char(85),char(92),char(93),char(98),char(108),char(107),char(109),char(119),char(126),char(120), -char(114),char(124),char(130),char(113),char(109),char(116),char(120),char(124),char(123),char(132), -char(132),char(134),char(67),char(64),char(58),char(56),char(63),char(74),char(77),char(74), -char(71),char(81),char(111),char(133),char(149),char(160),char(165),char(158),char(154),char(146), -char(154),char(158),char(166),char(162),char(156),char(162),char(166),char(170),char(167),char(169), -char(188),char(187),char(181),char(180),char(173),char(172),char(181),char(171),char(169),char(185), -char(183),char(170),char(172),char(186),char(198),char(213),char(220),char(212),char(195),char(189), -char(171),char(152),char(156),char(157),char(145),char(135),char(126),char(112),char(96),char(78), -char(59),char(39),char(26),char(18),char(14),char(17),char(21),char(28),char(41),char(51), -char(63),char(70),char(66),char(55),char(40),char(35),char(36),char(39),char(36),char(34), -char(38),char(37),char(29),char(22),char(15),char(12),char(14),char(19),char(25),char(32), -char(40),char(48),char(51),char(52),char(56),char(67),char(80),char(89),char(89),char(93), -char(92),char(93),char(97),char(108),char(98),char(86),char(83),char(83),char(94),char(104), -char(102),char(100),char(108),char(114),char(122),char(134),char(137),char(125),char(116),char(113), -char(112),char(101),char(105),char(124),char(129),char(132),char(132),char(125),char(123),char(120), -char(58),char(66),char(59),char(55),char(62),char(87),char(91),char(85),char(85),char(89), -char(107),char(128),char(144),char(160),char(163),char(165),char(159),char(151),char(146),char(144), -char(156),char(152),char(140),char(141),char(152),char(155),char(145),char(157),char(175),char(180), -char(164),char(162),char(164),char(166),char(172),char(162),char(162),char(176),char(179),char(174), -char(171),char(175),char(189),char(213),char(227),char(219),char(197),char(190),char(186),char(181), -char(179),char(175),char(158),char(139),char(132),char(125),char(116),char(100),char(75),char(55), -char(45),char(35),char(29),char(30),char(35),char(41),char(50),char(63),char(81),char(89), -char(77),char(60),char(44),char(36),char(38),char(37),char(32),char(37),char(40),char(34), -char(26),char(24),char(17),char(16),char(21),char(21),char(29),char(34),char(38),char(45), -char(57),char(57),char(64),char(83),char(93),char(108),char(108),char(101),char(101),char(100), -char(112),char(123),char(116),char(107),char(100),char(103),char(106),char(101),char(101),char(103), -char(113),char(125),char(140),char(158),char(152),char(137),char(126),char(114),char(110),char(110), -char(108),char(114),char(113),char(128),char(134),char(126),char(124),char(114),char(58),char(61), -char(62),char(61),char(69),char(84),char(99),char(97),char(96),char(108),char(114),char(129), -char(150),char(150),char(160),char(168),char(170),char(160),char(153),char(144),char(146),char(144), -char(133),char(128),char(130),char(122),char(114),char(135),char(162),char(165),char(150),char(155), -char(161),char(154),char(152),char(144),char(143),char(153),char(154),char(152),char(156),char(164), -char(178),char(206),char(221),char(216),char(203),char(201),char(206),char(205),char(199),char(198), -char(180),char(158),char(150),char(145),char(131),char(115),char(98),char(77),char(61),char(46), -char(41),char(44),char(51),char(62),char(66),char(69),char(84),char(94),char(86),char(69), -char(54),char(40),char(38),char(37),char(33),char(39),char(44),char(33),char(21),char(19), -char(19),char(22),char(28),char(32),char(35),char(36),char(36),char(38),char(55),char(66), -char(82),char(94),char(101),char(117),char(120),char(114),char(117),char(123),char(136),char(137), -char(131),char(129),char(122),char(117),char(109),char(102),char(107),char(121),char(124),char(137), -char(149),char(158),char(164),char(147),char(138),char(118),char(105),char(107),char(110),char(108), -char(104),char(110),char(122),char(123),char(110),char(108),char(51),char(55),char(58),char(69), -char(80),char(91),char(106),char(114),char(119),char(131),char(130),char(142),char(160),char(162), -char(165),char(166),char(168),char(162),char(154),char(143),char(138),char(134),char(122),char(103), -char(100),char(96),char(89),char(107),char(131),char(139),char(141),char(146),char(154),char(150), -char(142),char(129),char(122),char(128),char(132),char(126),char(129),char(153),char(175),char(191), -char(200),char(202),char(205),char(211),char(215),char(213),char(215),char(217),char(202),char(180), -char(166),char(158),char(144),char(131),char(119),char(93),char(69),char(50),char(48),char(60), -char(76),char(85),char(85),char(89),char(103),char(107),char(98),char(79),char(60),char(47), -char(44),char(41),char(41),char(44),char(39),char(28),char(17),char(15),char(18),char(28), -char(34),char(37),char(40),char(38),char(36),char(44),char(55),char(75),char(94),char(101), -char(111),char(118),char(122),char(121),char(127),char(137),char(151),char(156),char(147),char(138), -char(131),char(124),char(112),char(104),char(111),char(123),char(134),char(139),char(144),char(157), -char(169),char(147),char(138),char(121),char(97),char(100),char(104),char(104),char(106),char(113), -char(116),char(116),char(99),char(102), - -}; \ No newline at end of file diff --git a/Demos/VehicleDemo/main.cpp b/Demos/VehicleDemo/main.cpp deleted file mode 100644 index 0bc51c218..000000000 --- a/Demos/VehicleDemo/main.cpp +++ /dev/null @@ -1,18 +0,0 @@ - -#include "VehicleDemo.h" -#include "GlutStuff.h" -#include "GLDebugDrawer.h" -#include "btBulletDynamicsCommon.h" -GLDebugDrawer gDebugDrawer; - -int main(int argc,char** argv) -{ - - VehicleDemo* vehicleDemo = new VehicleDemo; - - vehicleDemo->initPhysics(); - vehicleDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer); - - return glutmain(argc, argv,640,480,"Bullet Vehicle Demo. http://www.continuousphysics.com/Bullet/phpBB2/", vehicleDemo); -} - diff --git a/Demos/VoronoiFractureDemo/CMakeLists.txt b/Demos/VoronoiFractureDemo/CMakeLists.txt deleted file mode 100644 index 2abff4ece..000000000 --- a/Demos/VoronoiFractureDemo/CMakeLists.txt +++ /dev/null @@ -1,76 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -../OpenGL -${GLUT_INCLUDE_DIR} -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppVoronoiFractureDemo - main.cpp - VoronoiFractureDemo.cpp - VoronoiFractureDemo.h - btConvexConvexMprAlgorithm.cpp - btConvexConvexMprAlgorithm.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppVoronoiFractureDemo - main.cpp - VoronoiFractureDemo.cpp - VoronoiFractureDemo.h - btConvexConvexMprAlgorithm.cpp - btConvexConvexMprAlgorithm.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppVoronoiFractureDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32VoronoiFractureDemo.cpp - VoronoiFractureDemo.cpp - VoronoiFractureDemo.h - btConvexConvexMprAlgorithm.cpp - btConvexConvexMprAlgorithm.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppVoronoiFractureDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppVoronoiFractureDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppVoronoiFractureDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos/VoronoiFractureDemo/Makefile.am b/Demos/VoronoiFractureDemo/Makefile.am deleted file mode 100644 index 05546162b..000000000 --- a/Demos/VoronoiFractureDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=BasicDemo - -BasicDemo_SOURCES=BasicDemo.cpp BasicDemo.h main.cpp -BasicDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -BasicDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos/VoronoiFractureDemo/VoronoiFractureDemo.cpp b/Demos/VoronoiFractureDemo/VoronoiFractureDemo.cpp deleted file mode 100644 index 19cf7ddd2..000000000 --- a/Demos/VoronoiFractureDemo/VoronoiFractureDemo.cpp +++ /dev/null @@ -1,737 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -/* -Voronoi fracture and shatter code and demo copyright (c) 2011 Alain Ducharme - - Reset scene (press spacebar) to generate new random voronoi shattered cuboids - - Check console for total time required to: compute and mesh all 3D shards, calculate volumes and centers of mass and create rigid bodies - - Modify VORONOIPOINTS define below to change number of potential voronoi shards - - Note that demo's visual cracks between voronoi shards are NOT present in the internally generated voronoi mesh! -*/ - -//Number of random voronoi points to generate for shattering -#define VORONOIPOINTS 100 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (2048) -#define BREAKING_THRESHOLD 3 -#define CONVEX_MARGIN 0.04 -static int useMpr = 0; - -#include "VoronoiFractureDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" -#include "GLDebugFont.h" -#include //printf debugging - -#include "GLDebugDrawer.h" -static GLDebugDrawer sDebugDraw; -static bool useGenericConstraint = false; - -#include "btConvexConvexMprAlgorithm.h" - - -void VoronoiFractureDemo::attachFixedConstraints() -{ - btAlignedObjectArray bodies; - - int numManifolds = getDynamicsWorld()->getDispatcher()->getNumManifolds(); - - for (int i=0;igetDispatcher()->getManifoldByIndexInternal(i); - if (!manifold->getNumContacts()) - continue; - - btScalar minDist = 1e30f; - int minIndex = -1; - for (int v=0;vgetNumContacts();v++) - { - if (minDist >manifold->getContactPoint(v).getDistance()) - { - minDist = manifold->getContactPoint(v).getDistance(); - minIndex = v; - } - } - if (minDist>0.) - continue; - - btCollisionObject* colObj0 = (btCollisionObject*)manifold->getBody0(); - btCollisionObject* colObj1 = (btCollisionObject*)manifold->getBody1(); - // int tag0 = (colObj0)->getIslandTag(); -// int tag1 = (colObj1)->getIslandTag(); - btRigidBody* body0 = btRigidBody::upcast(colObj0); - btRigidBody* body1 = btRigidBody::upcast(colObj1); - if (bodies.findLinearSearch(body0)==bodies.size()) - bodies.push_back(body0); - if (bodies.findLinearSearch(body1)==bodies.size()) - bodies.push_back(body1); - - if (body0 && body1) - { - if (!colObj0->isStaticOrKinematicObject() && !colObj1->isStaticOrKinematicObject()) - { - if (body0->checkCollideWithOverride(body1)) - { - { - btTransform trA,trB; - trA.setIdentity(); - trB.setIdentity(); - btVector3 contactPosWorld = manifold->getContactPoint(minIndex).m_positionWorldOnA; - btTransform globalFrame; - globalFrame.setIdentity(); - globalFrame.setOrigin(contactPosWorld); - - trA = body0->getWorldTransform().inverse()*globalFrame; - trB = body1->getWorldTransform().inverse()*globalFrame; - float totalMass = 1.f/body0->getInvMass() + 1.f/body1->getInvMass(); - - - if (useGenericConstraint) - { - btGeneric6DofConstraint* dof6 = new btGeneric6DofConstraint(*body0,*body1,trA,trB,true); - dof6->setOverrideNumSolverIterations(30); - - - dof6->setBreakingImpulseThreshold(BREAKING_THRESHOLD*totalMass); - - for (int i=0;i<6;i++) - dof6->setLimit(i,0,0); - getDynamicsWorld()->addConstraint(dof6,true); - - } else - { - btFixedConstraint* fixed = new btFixedConstraint(*body0,*body1,trA,trB); - fixed->setBreakingImpulseThreshold(BREAKING_THRESHOLD*totalMass); - fixed ->setOverrideNumSolverIterations(30); - getDynamicsWorld()->addConstraint(fixed,true); - - } - - } - } - } - } - - } - - for (int i=0;iremoveRigidBody(bodies[i]); - getDynamicsWorld()->addRigidBody(bodies[i]); - } -} - -void VoronoiFractureDemo::keyboardCallback(unsigned char key, int x, int y) -{ - if (key == 'g') - { - attachFixedConstraints(); - }else - { - PlatformDemoApplication::keyboardCallback(key,x,y); - } -} - - -void VoronoiFractureDemo::getVerticesInsidePlanes(const btAlignedObjectArray& planes, btAlignedObjectArray& verticesOut, std::set& planeIndicesOut) -{ - // Based on btGeometryUtil.cpp (Gino van den Bergen / Erwin Coumans) - verticesOut.resize(0); - planeIndicesOut.clear(); - const int numPlanes = planes.size(); - int i, j, k, l; - for (i=0;i btScalar(0.0001)) - { - for (k=j+1;k btScalar(0.0001)) && (n3n1.length2() > btScalar(0.0001) )) - { - btScalar quotient = (N1.dot(n2n3)); - if (btFabs(quotient) > btScalar(0.0001)) - { - btVector3 potentialVertex = (n2n3 * N1[3] + n3n1 * N2[3] + n1n2 * N3[3]) * (btScalar(-1.) / quotient); - for (l=0; l btScalar(0.000001)) - break; - } - if (l == numPlanes) - { - // vertex (three plane intersection) inside all planes - verticesOut.push_back(potentialVertex); - planeIndicesOut.insert(i); - planeIndicesOut.insert(j); - planeIndicesOut.insert(k); - } - } - } - } - } - } - } -} - -static btVector3 curVoronoiPoint; - -struct pointCmp -{ - bool operator()(const btVector3& p1, const btVector3& p2) const - { - float v1 = (p1-curVoronoiPoint).length2(); - float v2 = (p2-curVoronoiPoint).length2(); - bool result0 = v1 < v2; - //bool result1 = ((btScalar)(p1-curVoronoiPoint).length2()) < ((btScalar)(p2-curVoronoiPoint).length2()); - //apparently result0 is not always result1, because extended precision used in registered is different from precision when values are stored in memory - return result0; - } -}; - -void VoronoiFractureDemo::voronoiBBShatter(const btAlignedObjectArray& points, const btVector3& bbmin, const btVector3& bbmax, const btQuaternion& bbq, const btVector3& bbt, btScalar matDensity) { - // points define voronoi cells in world space (avoid duplicates) - // bbmin & bbmax = bounding box min and max in local space - // bbq & bbt = bounding box quaternion rotation and translation - // matDensity = Material density for voronoi shard mass calculation - btVector3 bbvx = quatRotate(bbq, btVector3(1.0, 0.0, 0.0)); - btVector3 bbvy = quatRotate(bbq, btVector3(0.0, 1.0, 0.0)); - btVector3 bbvz = quatRotate(bbq, btVector3(0.0, 0.0, 1.0)); - btQuaternion bbiq = bbq.inverse(); - btConvexHullComputer* convexHC = new btConvexHullComputer(); - btAlignedObjectArray vertices; - btVector3 rbb, nrbb; - btScalar nlength, maxDistance, distance; - btAlignedObjectArray sortedVoronoiPoints; - sortedVoronoiPoints.copyFromArray(points); - btVector3 normal, plane; - btAlignedObjectArray planes; - std::set planeIndices; - std::set::iterator planeIndicesIter; - int numplaneIndices; - int cellnum = 0; - int i, j, k; - - int numpoints = points.size(); - for (i=0; i < numpoints ;i++) { - curVoronoiPoint = points[i]; - btVector3 icp = quatRotate(bbiq, curVoronoiPoint - bbt); - rbb = icp - bbmax; - nrbb = bbmin - icp; - planes.resize(6); - planes[0] = bbvx; planes[0][3] = rbb.x(); - planes[1] = bbvy; planes[1][3] = rbb.y(); - planes[2] = bbvz; planes[2][3] = rbb.z(); - planes[3] = -bbvx; planes[3][3] = nrbb.x(); - planes[4] = -bbvy; planes[4][3] = nrbb.y(); - planes[5] = -bbvz; planes[5][3] = nrbb.z(); - maxDistance = SIMD_INFINITY; - sortedVoronoiPoints.heapSort(pointCmp()); - for (j=1; j < numpoints; j++) { - normal = sortedVoronoiPoints[j] - curVoronoiPoint; - nlength = normal.length(); - if (nlength > maxDistance) - break; - plane = normal.normalized(); - plane[3] = -nlength / btScalar(2.); - planes.push_back(plane); - getVerticesInsidePlanes(planes, vertices, planeIndices); - if (vertices.size() == 0) - break; - numplaneIndices = planeIndices.size(); - if (numplaneIndices != planes.size()) { - planeIndicesIter = planeIndices.begin(); - for (k=0; k < numplaneIndices; k++) { - if (k != *planeIndicesIter) - planes[k] = planes[*planeIndicesIter]; - planeIndicesIter++; - } - planes.resize(numplaneIndices); - } - maxDistance = vertices[0].length(); - for (k=1; k < vertices.size(); k++) { - distance = vertices[k].length(); - if (maxDistance < distance) - maxDistance = distance; - } - maxDistance *= btScalar(2.); - } - if (vertices.size() == 0) - continue; - - // Clean-up voronoi convex shard vertices and generate edges & faces - convexHC->compute(&vertices[0].getX(), sizeof(btVector3), vertices.size(),CONVEX_MARGIN,0.0); - - // At this point we have a complete 3D voronoi shard mesh contained in convexHC - - // Calculate volume and center of mass (Stan Melax volume integration) - int numFaces = convexHC->faces.size(); - int v0, v1, v2; // Triangle vertices - btScalar volume = btScalar(0.); - btVector3 com(0., 0., 0.); - for (j=0; j < numFaces; j++) { - const btConvexHullComputer::Edge* edge = &convexHC->edges[convexHC->faces[j]]; - v0 = edge->getSourceVertex(); - v1 = edge->getTargetVertex(); - edge = edge->getNextEdgeOfFace(); - v2 = edge->getTargetVertex(); - while (v2 != v0) { - // Counter-clockwise triangulated voronoi shard mesh faces (v0-v1-v2) and edges here... - btScalar vol = convexHC->vertices[v0].triple(convexHC->vertices[v1], convexHC->vertices[v2]); - volume += vol; - com += vol * (convexHC->vertices[v0] + convexHC->vertices[v1] + convexHC->vertices[v2]); - edge = edge->getNextEdgeOfFace(); - v1 = v2; - v2 = edge->getTargetVertex(); - } - } - com /= volume * btScalar(4.); - volume /= btScalar(6.); - - // Shift all vertices relative to center of mass - int numVerts = convexHC->vertices.size(); - for (j=0; j < numVerts; j++) - { - convexHC->vertices[j] -= com; - } - - // Note: - // At this point convex hulls contained in convexHC should be accurate (line up flush with other pieces, no cracks), - // ...however Bullet Physics rigid bodies demo visualizations appear to produce some visible cracks. - // Use the mesh in convexHC for visual display or to perform boolean operations with. - - // Create Bullet Physics rigid body shards - btCollisionShape* shardShape = new btConvexHullShape(&(convexHC->vertices[0].getX()), convexHC->vertices.size()); - shardShape->setMargin(CONVEX_MARGIN); // for this demo; note convexHC has optional margin parameter for this - m_collisionShapes.push_back(shardShape); - btTransform shardTransform; - shardTransform.setIdentity(); - shardTransform.setOrigin(curVoronoiPoint + com); // Shard's adjusted location - btDefaultMotionState* shardMotionState = new btDefaultMotionState(shardTransform); - btScalar shardMass(volume * matDensity); - btVector3 shardInertia(0.,0.,0.); - shardShape->calculateLocalInertia(shardMass, shardInertia); - btRigidBody::btRigidBodyConstructionInfo shardRBInfo(shardMass, shardMotionState, shardShape, shardInertia); - btRigidBody* shardBody = new btRigidBody(shardRBInfo); - m_dynamicsWorld->addRigidBody(shardBody); - - cellnum ++; - - } - printf("Generated %d voronoi btRigidBody shards\n", cellnum); -} - -void VoronoiFractureDemo::voronoiConvexHullShatter(const btAlignedObjectArray& points, const btAlignedObjectArray& verts, const btQuaternion& bbq, const btVector3& bbt, btScalar matDensity) { - // points define voronoi cells in world space (avoid duplicates) - // verts = source (convex hull) mesh vertices in local space - // bbq & bbt = source (convex hull) mesh quaternion rotation and translation - // matDensity = Material density for voronoi shard mass calculation - btConvexHullComputer* convexHC = new btConvexHullComputer(); - btAlignedObjectArray vertices, chverts; - btVector3 rbb, nrbb; - btScalar nlength, maxDistance, distance; - btAlignedObjectArray sortedVoronoiPoints; - sortedVoronoiPoints.copyFromArray(points); - btVector3 normal, plane; - btAlignedObjectArray planes, convexPlanes; - std::set planeIndices; - std::set::iterator planeIndicesIter; - int numplaneIndices; - int cellnum = 0; - int i, j, k; - - // Convert verts to world space and get convexPlanes - int numverts = verts.size(); - chverts.resize(verts.size()); - for (i=0; i < numverts ;i++) { - chverts[i] = quatRotate(bbq, verts[i]) + bbt; - } - //btGeometryUtil::getPlaneEquationsFromVertices(chverts, convexPlanes); - // Using convexHullComputer faster than getPlaneEquationsFromVertices for large meshes... - convexHC->compute(&chverts[0].getX(), sizeof(btVector3), numverts, 0.0, 0.0); - int numFaces = convexHC->faces.size(); - int v0, v1, v2; // vertices - for (i=0; i < numFaces; i++) { - const btConvexHullComputer::Edge* edge = &convexHC->edges[convexHC->faces[i]]; - v0 = edge->getSourceVertex(); - v1 = edge->getTargetVertex(); - edge = edge->getNextEdgeOfFace(); - v2 = edge->getTargetVertex(); - plane = (convexHC->vertices[v1]-convexHC->vertices[v0]).cross(convexHC->vertices[v2]-convexHC->vertices[v0]).normalize(); - plane[3] = -plane.dot(convexHC->vertices[v0]); - convexPlanes.push_back(plane); - } - const int numconvexPlanes = convexPlanes.size(); - - int numpoints = points.size(); - for (i=0; i < numpoints ;i++) { - curVoronoiPoint = points[i]; - planes.copyFromArray(convexPlanes); - for (j=0; j < numconvexPlanes ;j++) { - planes[j][3] += planes[j].dot(curVoronoiPoint); - } - maxDistance = SIMD_INFINITY; - sortedVoronoiPoints.heapSort(pointCmp()); - for (j=1; j < numpoints; j++) { - normal = sortedVoronoiPoints[j] - curVoronoiPoint; - nlength = normal.length(); - if (nlength > maxDistance) - break; - plane = normal.normalized(); - plane[3] = -nlength / btScalar(2.); - planes.push_back(plane); - getVerticesInsidePlanes(planes, vertices, planeIndices); - if (vertices.size() == 0) - break; - numplaneIndices = planeIndices.size(); - if (numplaneIndices != planes.size()) { - planeIndicesIter = planeIndices.begin(); - for (k=0; k < numplaneIndices; k++) { - if (k != *planeIndicesIter) - planes[k] = planes[*planeIndicesIter]; - planeIndicesIter++; - } - planes.resize(numplaneIndices); - } - maxDistance = vertices[0].length(); - for (k=1; k < vertices.size(); k++) { - distance = vertices[k].length(); - if (maxDistance < distance) - maxDistance = distance; - } - maxDistance *= btScalar(2.); - } - if (vertices.size() == 0) - continue; - - // Clean-up voronoi convex shard vertices and generate edges & faces - convexHC->compute(&vertices[0].getX(), sizeof(btVector3), vertices.size(),0.0,0.0); - - // At this point we have a complete 3D voronoi shard mesh contained in convexHC - - // Calculate volume and center of mass (Stan Melax volume integration) - numFaces = convexHC->faces.size(); - btScalar volume = btScalar(0.); - btVector3 com(0., 0., 0.); - for (j=0; j < numFaces; j++) { - const btConvexHullComputer::Edge* edge = &convexHC->edges[convexHC->faces[j]]; - v0 = edge->getSourceVertex(); - v1 = edge->getTargetVertex(); - edge = edge->getNextEdgeOfFace(); - v2 = edge->getTargetVertex(); - while (v2 != v0) { - // Counter-clockwise triangulated voronoi shard mesh faces (v0-v1-v2) and edges here... - btScalar vol = convexHC->vertices[v0].triple(convexHC->vertices[v1], convexHC->vertices[v2]); - volume += vol; - com += vol * (convexHC->vertices[v0] + convexHC->vertices[v1] + convexHC->vertices[v2]); - edge = edge->getNextEdgeOfFace(); - v1 = v2; - v2 = edge->getTargetVertex(); - } - } - com /= volume * btScalar(4.); - volume /= btScalar(6.); - - // Shift all vertices relative to center of mass - int numVerts = convexHC->vertices.size(); - for (j=0; j < numVerts; j++) - { - convexHC->vertices[j] -= com; - } - - // Note: - // At this point convex hulls contained in convexHC should be accurate (line up flush with other pieces, no cracks), - // ...however Bullet Physics rigid bodies demo visualizations appear to produce some visible cracks. - // Use the mesh in convexHC for visual display or to perform boolean operations with. - - // Create Bullet Physics rigid body shards - btCollisionShape* shardShape = new btConvexHullShape(&(convexHC->vertices[0].getX()), convexHC->vertices.size()); - shardShape->setMargin(CONVEX_MARGIN); // for this demo; note convexHC has optional margin parameter for this - m_collisionShapes.push_back(shardShape); - btTransform shardTransform; - shardTransform.setIdentity(); - shardTransform.setOrigin(curVoronoiPoint + com); // Shard's adjusted location - btDefaultMotionState* shardMotionState = new btDefaultMotionState(shardTransform); - btScalar shardMass(volume * matDensity); - btVector3 shardInertia(0.,0.,0.); - shardShape->calculateLocalInertia(shardMass, shardInertia); - btRigidBody::btRigidBodyConstructionInfo shardRBInfo(shardMass, shardMotionState, shardShape, shardInertia); - btRigidBody* shardBody = new btRigidBody(shardRBInfo); - m_dynamicsWorld->addRigidBody(shardBody); - - cellnum ++; - - } - printf("Generated %d voronoi btRigidBody shards\n", cellnum); -} - -void VoronoiFractureDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(1. / 60., 0);// ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - glFlush(); - - swapBuffers(); -} - - -void VoronoiFractureDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - -void VoronoiFractureDemo::renderme() -{ - DemoApplication::renderme(); - char buf[124]; - - int lineWidth = 200; - int xStart = m_glutScreenWidth - lineWidth; - - if (useMpr) - { - sprintf(buf, "Using GJK+MPR"); - } - else - { - sprintf(buf, "Using GJK+EPA"); - } - GLDebugDrawString(xStart, 20, buf); - -} - - -void VoronoiFractureDemo::initPhysics() -{ - srand(13); - useGenericConstraint = !useGenericConstraint; - printf("useGenericConstraint = %d\n", useGenericConstraint); - - - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(20.)); - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - useMpr = 1 - useMpr; - - if (useMpr) - { - printf("using GJK+MPR convex-convex collision detection\n"); - btConvexConvexMprAlgorithm::CreateFunc* cf = new btConvexConvexMprAlgorithm::CreateFunc; - m_dispatcher->registerCollisionCreateFunc(CONVEX_HULL_SHAPE_PROXYTYPE, CONVEX_HULL_SHAPE_PROXYTYPE, cf); - m_dispatcher->registerCollisionCreateFunc(CONVEX_HULL_SHAPE_PROXYTYPE, BOX_SHAPE_PROXYTYPE, cf); - m_dispatcher->registerCollisionCreateFunc(BOX_SHAPE_PROXYTYPE, CONVEX_HULL_SHAPE_PROXYTYPE, cf); - } - else - { - printf("using default (GJK+EPA) convex-convex collision detection\n"); - } - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld->getSolverInfo().m_splitImpulse = true; - m_dynamicsWorld->setDebugDrawer(&sDebugDraw); - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///create a few basic rigid bodies - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - { - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(10.),btScalar(8.),btScalar(1.))); - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - groundTransform.setOrigin(btVector3(0,0,0)); - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - // ==> Voronoi Shatter Basic Demo: Random Cuboid - - // Random size cuboid (defined by bounding box max and min) - btVector3 bbmax(btScalar(rand() / btScalar(RAND_MAX)) * 12. +0.5, btScalar(rand() / btScalar(RAND_MAX)) * 1. +0.5, btScalar(rand() / btScalar(RAND_MAX)) * 1. +0.5); - btVector3 bbmin = -bbmax; - // Place it 10 units above ground - btVector3 bbt(0,15,0); - // Use an arbitrary material density for shards (should be consitent/relative with/to rest of RBs in world) - btScalar matDensity = 1; - // Using random rotation - btQuaternion bbq(btScalar(rand() / btScalar(RAND_MAX)) * 2. -1.,btScalar(rand() / btScalar(RAND_MAX)) * 2. -1.,btScalar(rand() / btScalar(RAND_MAX)) * 2. -1.,btScalar(rand() / btScalar(RAND_MAX)) * 2. -1.); - bbq.normalize(); - // Generate random points for voronoi cells - btAlignedObjectArray points; - btVector3 point; - btVector3 diff = bbmax - bbmin; - for (int i=0; i < VORONOIPOINTS; i++) { - // Place points within box area (points are in world coordinates) - point = quatRotate(bbq, btVector3(btScalar(rand() / btScalar(RAND_MAX)) * diff.x() -diff.x()/2., btScalar(rand() / btScalar(RAND_MAX)) * diff.y() -diff.y()/2., btScalar(rand() / btScalar(RAND_MAX)) * diff.z() -diff.z()/2.)) + bbt; - points.push_back(point); - } - m_perfmTimer.reset(); - voronoiBBShatter(points, bbmin, bbmax, bbq, bbt, matDensity); - printf("Total Time: %f seconds\n", m_perfmTimer.getTimeMilliseconds()/1000.); - - for (int i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - obj->getCollisionShape()->setMargin(CONVEX_MARGIN+0.01); - } - m_dynamicsWorld->performDiscreteCollisionDetection(); - - for (int i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - obj->getCollisionShape()->setMargin(CONVEX_MARGIN); - } - - attachFixedConstraints(); - -} -void VoronoiFractureDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void VoronoiFractureDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - int i; - //remove all constraints - for (i=m_dynamicsWorld->getNumConstraints()-1;i>=0;i--) - { - btTypedConstraint* constraint = m_dynamicsWorld->getConstraint(i); - m_dynamicsWorld->removeConstraint(constraint); - delete constraint; - } - - //remove the rigidbodies from the dynamics world and delete them - - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j -#include - -class btBroadphaseInterface; -class btCollisionShape; -class btOverlappingPairCache; -class btCollisionDispatcher; -class btConstraintSolver; -struct btCollisionAlgorithmCreateFunc; -class btDefaultCollisionConfiguration; - -///VoronoiFractureDemo is good starting point for learning the code base and porting. - -class VoronoiFractureDemo : public PlatformDemoApplication -{ - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - btClock m_perfmTimer; - - public: - - VoronoiFractureDemo() - { - srand((unsigned)time(NULL)); // Seed it... - } - virtual ~VoronoiFractureDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void renderme(); - - void getVerticesInsidePlanes(const btAlignedObjectArray& planes, btAlignedObjectArray& verticesOut, std::set& planeIndicesOut); - void voronoiBBShatter(const btAlignedObjectArray& points, const btVector3& bbmin, const btVector3& bbmax, const btQuaternion& bbq, const btVector3& bbt, btScalar matDensity); - void voronoiConvexHullShatter(const btAlignedObjectArray& points, const btAlignedObjectArray& verts, const btQuaternion& bbq, const btVector3& bbt, btScalar matDensity); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - virtual void clientResetScene(); - - virtual void keyboardCallback(unsigned char key, int x, int y); - - void attachFixedConstraints(); - - - static DemoApplication* Create() - { - VoronoiFractureDemo* demo = new VoronoiFractureDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //BASIC_DEMO_H - diff --git a/Demos/VoronoiFractureDemo/Win32VoronoiFractureDemo.cpp b/Demos/VoronoiFractureDemo/Win32VoronoiFractureDemo.cpp deleted file mode 100644 index 064534ed7..000000000 --- a/Demos/VoronoiFractureDemo/Win32VoronoiFractureDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "VoronoiFractureDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new VoronoiFractureDemo(); -} - -#endif diff --git a/Demos/VoronoiFractureDemo/btConvexConvexMprAlgorithm.cpp b/Demos/VoronoiFractureDemo/btConvexConvexMprAlgorithm.cpp deleted file mode 100644 index e14a0e67d..000000000 --- a/Demos/VoronoiFractureDemo/btConvexConvexMprAlgorithm.cpp +++ /dev/null @@ -1,288 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2014 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -#include "btConvexConvexMprAlgorithm.h" - -//#include -#include "BulletCollision/NarrowPhaseCollision/btDiscreteCollisionDetectorInterface.h" -#include "BulletCollision/BroadphaseCollision/btBroadphaseInterface.h" -#include "BulletCollision/CollisionDispatch/btCollisionObject.h" -#include "BulletCollision/CollisionShapes/btConvexShape.h" - -#include "BulletCollision/CollisionShapes/btTriangleShape.h" - - - -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/BroadphaseCollision/btBroadphaseProxy.h" -#include "BulletCollision/CollisionDispatch/btCollisionDispatcher.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" -#include "BulletCollision/CollisionDispatch/btManifoldResult.h" - -#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h" -#include "BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h" - - - -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/CollisionShapes/btSphereShape.h" - -#include "BulletCollision/NarrowPhaseCollision/btMinkowskiPenetrationDepthSolver.h" - -#include "BulletCollision/NarrowPhaseCollision/btGjkEpa2.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h" -#include "BulletCollision/NarrowPhaseCollision/btPolyhedralContactClipping.h" -#include "BulletCollision/CollisionDispatch/btCollisionObjectWrapper.h" - -#include "BulletCollision/NarrowPhaseCollision/btComputeGjkEpaPenetration.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkEpa3.h" -#include "BulletCollision/NarrowPhaseCollision/btMprPenetration.h" - -//this is just an internal debug variable to switch between GJK+MPR or GJK+EPA -bool gUseMprCollisionFunction = true; - -btConvexConvexMprAlgorithm::CreateFunc::CreateFunc() -{ - -} - -btConvexConvexMprAlgorithm::CreateFunc::~CreateFunc() -{ -} - -btConvexConvexMprAlgorithm::btConvexConvexMprAlgorithm(btPersistentManifold* mf,const btCollisionAlgorithmConstructionInfo& ci,const btCollisionObjectWrapper* body0Wrap,const btCollisionObjectWrapper* body1Wrap) -: btActivatingCollisionAlgorithm(ci,body0Wrap,body1Wrap), -m_ownManifold (false), -m_manifoldPtr(mf) -{ - (void)body0Wrap; - (void)body1Wrap; -} - - - - -btConvexConvexMprAlgorithm::~btConvexConvexMprAlgorithm() -{ - if (m_ownManifold) - { - if (m_manifoldPtr) - m_dispatcher->releaseManifold(m_manifoldPtr); - } -} - - -btVector3 btBulletShapeSupportFunc(const void* shapeAptr, const btVector3& dir, bool includeMargin) -{ - btConvexShape* shape = (btConvexShape*) shapeAptr; - if (includeMargin) - { - return shape->localGetSupportingVertex(dir); - } - - return shape->localGetSupportingVertexWithoutMargin(dir); -} - -btVector3 btBulletShapeCenterFunc(const void* shapeAptr) -{ - return btVector3(0,0,0); -} - - -struct btMprConvexWrap -{ - const btConvexShape* m_convex; - btTransform m_worldTrans; - inline btScalar getMargin() const - { - return m_convex->getMargin(); - } - inline btVector3 getObjectCenterInWorld() const - { - return m_worldTrans.getOrigin(); - } - inline const btTransform& getWorldTransform() const - { - return m_worldTrans; - } - inline btVector3 getLocalSupportWithMargin(const btVector3& dir) const - { - return m_convex->localGetSupportingVertex(dir); - } - inline btVector3 getLocalSupportWithoutMargin(const btVector3& dir) const - { - return m_convex->localGetSupportingVertexWithoutMargin(dir); - } -}; - -struct btMyDistanceInfo -{ - btVector3 m_pointOnA; - btVector3 m_pointOnB; - btVector3 m_normalBtoA; - btScalar m_distance; -}; - -// -// Convex-Convex collision algorithm -// -void btConvexConvexMprAlgorithm ::processCollision (const btCollisionObjectWrapper* body0Wrap,const btCollisionObjectWrapper* body1Wrap,const btDispatcherInfo& dispatchInfo,btManifoldResult* resultOut) -{ - - if (!m_manifoldPtr) - { - //swapped? - m_manifoldPtr = m_dispatcher->getNewManifold(body0Wrap->getCollisionObject(),body1Wrap->getCollisionObject()); - m_ownManifold = true; - } - resultOut->setPersistentManifold(m_manifoldPtr); - - //comment-out next line to test multi-contact generation - //resultOut->getPersistentManifold()->clearManifold(); - - - const btConvexShape* min0 = static_cast(body0Wrap->getCollisionShape()); - const btConvexShape* min1 = static_cast(body1Wrap->getCollisionShape()); - - btVector3 normalOnB; - btVector3 pointOnBWorld; - - btGjkPairDetector::ClosestPointInput input; - - btVoronoiSimplexSolver vs; - btGjkEpaPenetrationDepthSolver epa; - - - if (gUseMprCollisionFunction) - { - - btMprConvexWrap a,b; - a.m_worldTrans = body0Wrap->getWorldTransform(); - b.m_worldTrans = body1Wrap->getWorldTransform(); - a.m_convex = (const btConvexShape*)body0Wrap->getCollisionShape(); - b.m_convex = (const btConvexShape*)body1Wrap->getCollisionShape(); - btVoronoiSimplexSolver simplexSolver; - simplexSolver.reset(); - btGjkCollisionDescription colDesc; - btMyDistanceInfo distInfo; - int res = btComputeGjkDistance(a,b,colDesc,&distInfo); - if (res==0) - { - //printf("use GJK results in distance %f\n",distInfo.m_distance); - } else - { - btMprCollisionDescription mprDesc; - res = btComputeMprPenetration(a,b,mprDesc, &distInfo); - - //printf("use MPR results in distance %f\n",distInfo.m_distance); - - } - if (res == 0) - { -#if 0 - printf("Dist=%f,normalOnB[%f,%f,%f],pA=[%f,%f,%f],pB[%f,%f,%f]\n", - distInfo.m_distance, distInfo.m_normalBtoA[0], distInfo.m_normalBtoA[1], distInfo.m_normalBtoA[2], - distInfo.m_pointOnA[0], distInfo.m_pointOnA[1], distInfo.m_pointOnA[2], - distInfo.m_pointOnB[0], distInfo.m_pointOnB[1], distInfo.m_pointOnB[2]); -#endif - - if (distInfo.m_distance<=0) - { - resultOut->addContactPoint(distInfo.m_normalBtoA, distInfo.m_pointOnB, distInfo.m_distance); - } - //ASSERT_EQ(0,result); - //ASSERT_NEAR(btFabs(btScalar(i-z))-btScalar(j)-ssd.m_radiusB, distInfo.m_distance, abs_error); - //btVector3 computedA = distInfo.m_pointOnB+distInfo.m_distance*distInfo.m_normalBtoA; - //ASSERT_NEAR(computedA.x(),distInfo.m_pointOnA.x(),abs_error); - //ASSERT_NEAR(computedA.y(),distInfo.m_pointOnA.y(),abs_error); - //ASSERT_NEAR(computedA.z(),distInfo.m_pointOnA.z(),abs_error); - } - - -#if 0 - btCollisionDescription colDesc; - colDesc.m_objA = min0; - colDesc.m_objB = min1; - colDesc.m_localSupportFuncA = &btBulletShapeSupportFunc; - colDesc.m_localSupportFuncB = &btBulletShapeSupportFunc; - colDesc.m_localOriginFuncA = &btBulletShapeCenterFunc; - colDesc.m_localOriginFuncB = &btBulletShapeCenterFunc; - - colDesc.m_transformA = body0Wrap->getWorldTransform(); - colDesc.m_transformB = body1Wrap->getWorldTransform(); - colDesc.m_marginA = body0Wrap->getCollisionShape()->getMargin(); - colDesc.m_marginB = body1Wrap->getCollisionShape()->getMargin(); - btDistanceInfo distInfo; - //int result = btComputeGjkEpaPenetration(colDesc, &distInfo); - //int result = btComputeGjkEpaPenetration2(colDesc, &distInfo); - int result = btComputeMprPenetration(colDesc, &distInfo); - - if (result==0) - { - resultOut->addContactPoint(distInfo.m_normalBtoA,distInfo.m_pointOnB,distInfo.m_distance); - } - - //bool res = b3MprPenetration(pairIndex,bodyIndexA,bodyIndexB,cpuBodyBuf,convexData,collidable2,cpuVertices,sepAxis,hasSepAxis,depthOut,dirOut,posOut); - - /*btCollisionDescription colDesc; - btDistanceInfo distInfo; - int btComputeGjkEpaPenetration(min0, min1, &colDesc, &distInfo); - */ -#endif - } else - { - - btGjkPairDetector gjkPairDetector(min0,min1,&vs,&epa);//m_simplexSolver,m_pdSolver); - //TODO: if (dispatchInfo.m_useContinuous) - gjkPairDetector.setMinkowskiA(min0); - gjkPairDetector.setMinkowskiB(min1); - - { - //if (dispatchInfo.m_convexMaxDistanceUseCPT) - //{ - // input.m_maximumDistanceSquared = min0->getMargin() + min1->getMargin() + m_manifoldPtr->getContactProcessingThreshold(); - //} else - //{ - input.m_maximumDistanceSquared = min0->getMargin() + min1->getMargin() + m_manifoldPtr->getContactBreakingThreshold(); - // } - - input.m_maximumDistanceSquared*= input.m_maximumDistanceSquared; - } - - input.m_transformA = body0Wrap->getWorldTransform(); - input.m_transformB = body1Wrap->getWorldTransform(); - - - gjkPairDetector.getClosestPoints(input,*resultOut,dispatchInfo.m_debugDraw); - } - if (m_ownManifold) - { - resultOut->refreshContactPoints(); - } - -} - - -btScalar btConvexConvexMprAlgorithm::calculateTimeOfImpact(btCollisionObject* col0,btCollisionObject* col1,const btDispatcherInfo& dispatchInfo,btManifoldResult* resultOut) -{ - (void)resultOut; - (void)dispatchInfo; - btAssert(0); - return 0; -} - diff --git a/Demos/VoronoiFractureDemo/btConvexConvexMprAlgorithm.h b/Demos/VoronoiFractureDemo/btConvexConvexMprAlgorithm.h deleted file mode 100644 index 6edbdccae..000000000 --- a/Demos/VoronoiFractureDemo/btConvexConvexMprAlgorithm.h +++ /dev/null @@ -1,87 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef BT_CONVEX_CONVEX_MPR_ALGORITHM_H -#define BT_CONVEX_CONVEX_MPR_ALGORITHM_H - -#include "BulletCollision/CollisionDispatch/btActivatingCollisionAlgorithm.h" -#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h" -#include "BulletCollision/NarrowPhaseCollision/btPersistentManifold.h" -#include "BulletCollision/BroadphaseCollision/btBroadphaseProxy.h" -#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h" -#include "BulletCollision/CollisionDispatch/btCollisionCreateFunc.h" -#include "BulletCollision/CollisionDispatch/btCollisionDispatcher.h" -#include "LinearMath/btTransformUtil.h" //for btConvexSeparatingDistanceUtil - -class btConvexPenetrationDepthSolver; - -///Enabling USE_SEPDISTANCE_UTIL2 requires 100% reliable distance computation. However, when using large size ratios GJK can be imprecise -///so the distance is not conservative. In that case, enabling this USE_SEPDISTANCE_UTIL2 would result in failing/missing collisions. -///Either improve GJK for large size ratios (testing a 100 units versus a 0.1 unit object) or only enable the util -///for certain pairs that have a small size ratio - -///The convexConvexAlgorithm collision algorithm implements time of impact, convex closest points and penetration depth calculations between two convex objects. -///Multiple contact points are calculated by perturbing the orientation of the smallest object orthogonal to the separating normal. -///This idea was described by Gino van den Bergen in this forum topic http://www.bulletphysics.com/Bullet/phpBB3/viewtopic.php?f=4&t=288&p=888#p888 -class btConvexConvexMprAlgorithm : public btActivatingCollisionAlgorithm -{ - - - bool m_ownManifold; - btPersistentManifold* m_manifoldPtr; - ///cache separating vector to speedup collision detection - -public: - - btConvexConvexMprAlgorithm(btPersistentManifold* mf,const btCollisionAlgorithmConstructionInfo& ci,const btCollisionObjectWrapper* body0Wrap,const btCollisionObjectWrapper* body1Wrap); - - virtual ~btConvexConvexMprAlgorithm(); - - virtual void processCollision (const btCollisionObjectWrapper* body0Wrap,const btCollisionObjectWrapper* body1Wrap,const btDispatcherInfo& dispatchInfo,btManifoldResult* resultOut); - - virtual btScalar calculateTimeOfImpact(btCollisionObject* body0,btCollisionObject* body1,const btDispatcherInfo& dispatchInfo,btManifoldResult* resultOut); - - virtual void getAllContactManifolds(btManifoldArray& manifoldArray) - { - ///should we use m_ownManifold to avoid adding duplicates? - if (m_manifoldPtr && m_ownManifold) - manifoldArray.push_back(m_manifoldPtr); - } - -const btPersistentManifold* getManifold() - { - return m_manifoldPtr; - } - - struct CreateFunc :public btCollisionAlgorithmCreateFunc - { - - - - CreateFunc(); - - virtual ~CreateFunc(); - - virtual btCollisionAlgorithm* CreateCollisionAlgorithm(btCollisionAlgorithmConstructionInfo& ci, const btCollisionObjectWrapper* body0Wrap,const btCollisionObjectWrapper* body1Wrap) - { - void* mem = ci.m_dispatcher1->allocateCollisionAlgorithm(sizeof(btConvexConvexMprAlgorithm)); - return new(mem) btConvexConvexMprAlgorithm(ci.m_manifold,ci,body0Wrap,body1Wrap); - } - }; - - -}; - -#endif //BT_CONVEX_CONVEX_MPR_ALGORITHM_H diff --git a/Demos/VoronoiFractureDemo/main.cpp b/Demos/VoronoiFractureDemo/main.cpp deleted file mode 100644 index 9da8fe59e..000000000 --- a/Demos/VoronoiFractureDemo/main.cpp +++ /dev/null @@ -1,41 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "VoronoiFractureDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - - - - -int main(int argc,char** argv) -{ - - - VoronoiFractureDemo ccdDemo; - ccdDemo.initPhysics(); - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos/premake4.lua b/Demos/premake4.lua deleted file mode 100644 index cf4bf0b8d..000000000 --- a/Demos/premake4.lua +++ /dev/null @@ -1,104 +0,0 @@ - - - -function createDemos( demos, incdirs, linknames) - for _, name in ipairs(demos) do - - project ( "App_" .. name ) - - kind "ConsoleApp" - targetdir ".." - - configuration {} - - includedirs {incdirs} - links { - linknames - } - - configuration { "Windows" } - defines { "GLEW_STATIC"} - links { "opengl32","glu32","winmm"} - includedirs{ "Glut" } - libdirs {"Glut"} - files { "../build3/bullet.rc" } - - configuration {"Windows", "x32"} - links {"glew32s","glut32"} - configuration {"Windows", "x64"} - links {"glew64s", "glut64"} - - - configuration {"MacOSX"} - --print "hello" - linkoptions { "-framework Carbon -framework OpenGL -framework AGL -framework Glut" } - - configuration {"not Windows", "not MacOSX"} - links {"GL","GLU","glut","pthread"} - configuration{} - - - files { - "./" .. name .. "/*.cpp" , - "./" .. name .. "/*.h" - } - end -end - --- "CharacterDemo", fixme: it includes BspDemo files - - local localdemos = { - "BasicDemo", - "Box2dDemo", - "BspDemo", - "CcdPhysicsDemo", - "CollisionDemo", - "CollisionInterfaceDemo", - "ConcaveConvexcastDemo", - "ConcaveDemo", - "ConcaveRaycastDemo", - "ConstraintDemo", - "ContinuousConvexCollision", - "ConvexHullDistance", - "DynamicControlDemo", - "EPAPenDepthDemo", - "ForkLiftDemo", - "FeatherstoneMultiBodyDemo", - "FractureDemo", - "GenericJointDemo", - "GimpactTestDemo", - "GjkConvexCastDemo", - "GyroscopicDemo", - "InternalEdgeDemo", - "MovingConcaveDemo", - "MultiMaterialDemo", - "RagdollDemo", - "Raytracer", - "RaytestDemo", - "RollingFrictionDemo", - "SimplexDemo", - "SliderConstraintDemo", - "TerrainDemo", - "UserCollisionAlgorithm", - "VehicleDemo", - "VoronoiFractureDemo" - } - --- the following demos require custom include or link settings - - createDemos({"HelloWorld"},{"../src"},{"BulletDynamics","BulletCollision","LinearMath"}) - - createDemos(localdemos,{"../src","OpenGL","../btgui",},{"OpenGLSupport","BulletDynamics", "BulletCollision", "LinearMath"}) - - createDemos({"ConvexDecompositionDemo"},{"../Extras/HACD","../Extras/ConvexDecomposition","../src","OpenGL"},{"OpenGLSupport","BulletDynamics", "BulletCollision", "LinearMath","HACD","ConvexDecomposition"}) - - createDemos({"SoftDemo"},{"../src","OpenGL"}, {"OpenGLSupport","BulletSoftBody", "BulletDynamics", "BulletCollision", "LinearMath"}) - - createDemos({"SerializeDemo"},{"../Extras/Serialize/BulletFileLoader","../Extras/Serialize/BulletWorldImporter","../src","OpenGL","../btgui"},{"OpenGLSupport","BulletWorldImporter", "BulletFileLoader", "BulletSoftBody", "BulletDynamics", "BulletCollision", "LinearMath"}) - -createDemos({"BulletXmlImportDemo"},{"../Extras/Serialize/BulletFileLoader","../Extras/Serialize/BulletXmlWorldImporter", "../Extras/Serialize/BulletWorldImporter","../src","OpenGL","btgui"},{"OpenGLSupport","BulletXmlWorldImporter","BulletWorldImporter", "BulletFileLoader", "BulletSoftBody", "BulletDynamics", "BulletCollision", "LinearMath"}) - - -include "OpenGL" - - diff --git a/Demos3/AllBullet2Demos/BulletDemoEntries.h b/Demos3/AllBullet2Demos/BulletDemoEntries.h deleted file mode 100644 index c7198ae55..000000000 --- a/Demos3/AllBullet2Demos/BulletDemoEntries.h +++ /dev/null @@ -1,178 +0,0 @@ - -#ifndef BULLET_DEMO_ENTRIES_H -#define BULLET_DEMO_ENTRIES_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "../bullet2/BasicDemo/BasicDemo.h" - -#include "../bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.h" - -#include "../bullet2/BasicDemo/HingeDemo.h" -#include "../bullet2/BasicDemo/HingeDemo.h" - -#include "../bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.h" -#include "../bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.h" -#include "../bullet2/ConstraintDemo/Dof6Spring2Setup.h" -#include "../bullet2/RagdollDemo/RagdollDemo.h" -#include "../bullet2/LuaDemo/LuaPhysicsSetup.h" -#include "../bullet2/ChainDemo/ChainDemo.h" -#include "../../Demos/ForkLiftDemo/ForkLiftPhysicsSetup.h" -#include "../../Demos/CcdPhysicsDemo/CcdPhysicsSetup.h" -#include "../../Demos/GyroscopicDemo/GyroscopicSetup.h" -#include "../bullet2/ConstraintDemo/ConstraintPhysicsSetup.h" -#include "../ImportURDFDemo/ImportURDFSetup.h" -#include "../ImportObjDemo/ImportObjSetup.h" -#include "../ImportSTLDemo/ImportSTLSetup.h" -#include "../ImportColladaDemo/ImportColladaSetup.h" -#include "../Demos/Raytracer/RaytracerSetup.h" -#include "../../Demos/SerializeDemo/SerializeSetup.h" -#include "../bullet2/MultiBodyDemo/TestJointTorqueSetup.h" -#include "../bullet2/MultiBodyDemo/MultiBodyVehicle.h" - -#include "../bullet2/CollisionDetection/SupportFuncDemo.h" -#include "../bullet2/BasicConcepts/CoordinateSystemDemo.h" - -#include "../../Demos3/FiniteElementMethod/FiniteElementDemo.h" -//#include "../../Demos3/bullet2/SoftDemo/SoftDemo.h" -#include "../Geometry/SphereCreation.h" -#include "../Geometry/DistributePoints.h" -#include "../Geometry/RenderInstancingDemo.h" - -#define MYCREATEFUNC(func) \ -static BulletDemoInterface* func##CreateFunc(CommonGraphicsApp* app)\ -{\ - CommonPhysicsSetup* physicsSetup = new func##Setup();\ - return new BasicDemo(app, physicsSetup);\ -} - -#define MYCREATEFUNC2(func,setup) \ -static BulletDemoInterface* func(CommonGraphicsApp* app)\ -{\ - CommonPhysicsSetup* physicsSetup = new setup(app);\ - return new BasicDemo(app, physicsSetup);\ -} - -MYCREATEFUNC(TestJointTorque); -MYCREATEFUNC(MultiBodyVehicle); -MYCREATEFUNC2(LuaDemoCreateFunc,LuaPhysicsSetup); -MYCREATEFUNC(Serialize); -MYCREATEFUNC(CcdPhysics); -MYCREATEFUNC(Gyroscopic); -MYCREATEFUNC(ForkLiftPhysics); -MYCREATEFUNC(KinematicObject); -MYCREATEFUNC(ConstraintPhysics); -MYCREATEFUNC(Dof6Spring2); -MYCREATEFUNC(ImportUrdf); -MYCREATEFUNC2(ImportObjCreateFunc,ImportObjSetup); -MYCREATEFUNC2(ImportSTLCreateFunc,ImportSTLSetup); -MYCREATEFUNC(CoordinateFrameDemoPhysics); - -MYCREATEFUNC(RaytracerPhysics); -//Bullet2RigidBodyDemo - - -static BulletDemoInterface* MyImportColladaCreateFunc(CommonGraphicsApp* app) -{ - CommonPhysicsSetup* physicsSetup = new ImportColladaSetup(app); - return new BasicDemo(app, physicsSetup); -} - - - - -struct BulletDemoEntry -{ - int m_menuLevel; - const char* m_name; - BulletDemoInterface::CreateFunc* m_createFunc; -}; - - -static BulletDemoEntry allDemos[]= -{ - - {0,"Basic Concepts",0}, - {1,"Basis Frame", &CoordinateSystemDemo::CreateFunc}, - {1,"SupportFunc", &MySupportFuncDemo::CreateFunc}, - - {0,"API Demos", 0}, - {1,"Raytracer",RaytracerPhysicsCreateFunc}, - {1,"BasicDemo",BasicDemo::MyCreateFunc}, - {1,"ForkLift",ForkLiftPhysicsCreateFunc}, - { 1, "CcdDemo", CcdPhysicsCreateFunc }, - { 1, "Gyroscopic", GyroscopicCreateFunc }, - { 1, "Kinematic", KinematicObjectCreateFunc }, - { 1, "HingeMotor", ConstraintPhysicsCreateFunc }, - {1,"6DofSpring2", Dof6Spring2CreateFunc}, - { 1, "LuaDemo",LuaDemoCreateFunc}, - - {0,"File Formats", 0}, - - { 1, ".bullet",SerializeCreateFunc}, - { 1, "Wavefront Obj", ImportObjCreateFunc}, - { 1, "URDF", ImportUrdfCreateFunc }, - { 1, "STL", ImportSTLCreateFunc}, - { 1, "COLLADA", MyImportColladaCreateFunc}, - {0,"Experiments", 0}, - {1, "Finite Element Demo", FiniteElementDemo::CreateFunc}, - {1,"SphereCreation", &SphereCreation::CreateFunc}, - {1,"DistributePoints", &DistributePoints::CreateFunc}, - {1,"Coordinate Frames", CoordinateFrameDemoPhysicsCreateFunc}, - {1,"Instanced Rendering", &RenderInstancingDemo::CreateFunc}, -// {0,"Soft Body", 0}, - -// {1,"Cloth1", SoftDemo::CreateFunc}, -/* {1,"ChainDemo",ChainDemo::MyCreateFunc}, -// {0, "Stress tests", 0 }, - - {1,"SIHingeDemo",HingeDemo::SICreateFunc}, - {1,"PGSHingeDemo",HingeDemo::PGSCreateFunc}, - {1,"DantzigHingeDemo",HingeDemo::DantzigCreateFunc}, - {1,"LemkeHingeDemo",HingeDemo::LemkeCreateFunc}, - {1,"InertiaHingeDemo",HingeDemo::InertiaCreateFunc}, - {1,"ABMHingeDemo",HingeDemo::FeatherstoneCreateFunc}, - - {1,"Ragdoll",RagDollDemo::MyCreateFunc}, - */ - { 0, "Multibody" ,0}, - {1,"MultiBody1",FeatherstoneDemo1::MyCreateFunc}, -// {"MultiBody2",FeatherstoneDemo2::MyCreateFunc}, - {1,"MultiDofDemo",MultiDofDemo::MyCreateFunc}, - {1,"TestJointTorque",TestJointTorqueCreateFunc}, - {1,"MultiBodyVehicle", MultiBodyVehicleCreateFunc}, - - -}; - -#include - - -static void saveCurrentDemoEntry(int currentEntry,const char* startFileName) -{ - FILE* f = fopen(startFileName,"w"); - if (f) - { - fprintf(f,"%d\n",currentEntry); - fclose(f); - } -}; - -static int loadCurrentDemoEntry(const char* startFileName) -{ - int currentEntry= 0; - FILE* f = fopen(startFileName,"r"); - if (f) - { - int result; - result = fscanf(f,"%d",¤tEntry); - if (result) - { - return currentEntry; - } - fclose(f); - } - return 0; -}; - -#endif//BULLET_DEMO_ENTRIES_H - diff --git a/Demos3/AllBullet2Demos/CMakeLists.txt b/Demos3/AllBullet2Demos/CMakeLists.txt deleted file mode 100644 index 5e3a7c5b9..000000000 --- a/Demos3/AllBullet2Demos/CMakeLists.txt +++ /dev/null @@ -1,131 +0,0 @@ - - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ${BULLET_PHYSICS_SOURCE_DIR}/btgui - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/lua-5.2.3/src - ${BULLET_PHYSICS_SOURCE_DIR}/Demos3/FiniteElementMethod -) - -SET(App_AllBullet2Demos_SRCS - main.cpp - BulletDemoEntries.h - ../../Demos/BasicDemo/BasicDemoPhysicsSetup.cpp - ../../Demos/BasicDemo/BasicDemoPhysicsSetup.h - ../../Demos/CcdPhysicsDemo/CcdPhysicsSetup.cpp - ../../Demos/CcdPhysicsDemo/CcdPhysicsSetup.h - ../../Demos/Raytracer/RaytracerSetup.cpp - ../../Demos/Raytracer/RaytracerSetup.h - ../../Demos/GyroscopicDemo/GyroscopicSetup.cpp - ../../Demos/GyroscopicDemo/GyroscopicSetup.h - ../../Demos/ForkLiftDemo/ForkLiftPhysicsSetup.cpp - ../../Demos/ForkLiftDemo/ForkLiftPhysicsSetup.h - ../../Demos/SerializeDemo/SerializeSetup.cpp - ../../Extras/Serialize/BulletFileLoader/bChunk.cpp - ../../Extras/Serialize/BulletFileLoader/bDNA.cpp - ../../Extras/Serialize/BulletFileLoader/bFile.cpp - ../../Extras/Serialize/BulletFileLoader/btBulletFile.cpp - ../../Extras/Serialize/BulletWorldImporter/btBulletWorldImporter.cpp - ../../Extras/Serialize/BulletWorldImporter/btWorldImporter.cpp - ../bullet2/MultiBodyDemo/TestJointTorqueSetup.cpp - ../bullet2/MultiBodyDemo/MultiBodyVehicle.cpp - ../bullet2/ConstraintDemo/ConstraintPhysicsSetup.cpp - ../bullet2/ConstraintDemo/ConstraintPhysicsSetup.h - ../bullet2/ConstraintDemo/Dof6Spring2Setup.cpp - ../bullet2/ConstraintDemo/Dof6Spring2Setup.h - ../bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.cpp - ../bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.h - ../bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.cpp - ../bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.h - ../bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.cpp - ../bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.h - ../bullet2/BasicDemo/BasicDemo.cpp - ../bullet2/BasicDemo/BasicDemo.h -# ../bullet2/SoftDemo/SoftDemo.cpp -# the next few demos are not converted to 'newer' structure yet -# target is to convert all Bullet 2 demos in new structure but need to settle down on features -# ../bullet2/BasicDemo/HingeDemo.cpp -# ../bullet2/BasicDemo/HingeDemo.h -# ../bullet2/ChainDemo/ChainDemo.cpp -# ../bullet2/ChainDemo/ChainDemo.h -# ../bullet2/RagdollDemo/RagdollDemo.cpp -# ../bullet2/RagdollDemo/RagdollDemo.h - ../bullet2/LuaDemo/LuaPhysicsSetup.cpp - ../bullet2/LuaDemo/LuaPhysicsSetup.h - ../ImportURDFDemo/URDF2Bullet.cpp - ../ImportURDFDemo/ImportURDFSetup.cpp - ../ImportURDFDemo/ImportURDFSetup.h - ../ImportObjDemo/ImportObjSetup.cpp - ../ImportObjDemo/LoadMeshFromObj.cpp - ../ImportObjDemo/LoadMeshFromObj.h - ../ImportObjDemo/Wavefront2GLInstanceGraphicsShape.cpp - ../ImportColladaDemo/ImportColladaSetup.cpp - ../ImportColladaDemo/LoadMeshFromCollada.cpp - ../ImportSTLDemo/ImportSTLSetup.cpp - ../Wavefront/tiny_obj_loader.cpp - ../Wavefront/tiny_obj_loader.h - ../FiniteElementMethod/FiniteElementDemo.cpp - ../../btgui/Bullet3AppSupport/b3Clock.cpp - ../../btgui/Bullet3AppSupport/b3Clock.h - ../../btgui/urdf/urdfdom/urdf_parser/src/pose.cpp - ../../btgui/urdf/urdfdom/urdf_parser/src/model.cpp - ../../btgui/urdf/urdfdom/urdf_parser/src/link.cpp - ../../btgui/urdf/urdfdom/urdf_parser/src/joint.cpp - ../../btgui/urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h - ../../btgui/urdf/urdfdom_headers/urdf_exception/include/urdf_exception/exception.h - ../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/pose.h - ../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/model.h - ../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/link.h - ../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/joint.h - ../../btgui/tinyxml/tinystr.cpp - ../../btgui/tinyxml/tinyxml.cpp - ../../btgui/tinyxml/tinyxmlerror.cpp - ../../btgui/tinyxml/tinyxmlparser.cpp - ../../btgui/urdf/boost_replacement/lexical_cast.h - ../../btgui/urdf/boost_replacement/shared_ptr.h - ../../btgui/urdf/boost_replacement/printf_console.cpp - ../../btgui/urdf/boost_replacement/printf_console.h - ../../btgui/urdf/boost_replacement/string_split.cpp - ../../btgui/urdf/boost_replacement/string_split.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc -) - -LINK_LIBRARIES( - Bullet3AppSupport lua-5.2.3 Bullet3Common BulletSoftBody BulletDynamics BulletCollision LinearMath OpenGLWindow gwen ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - SET(App_AllBullet2Demos_SRCS ${App_AllBullet2Demos_SRCS} ${App_AllBullet2Demos_Common_SRCS}) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/OpenGLWindow/GlewWindows - ) - ADD_DEFINITIONS(-DGLEW_STATIC) -ELSE(WIN32) - IF(APPLE) - find_library(COCOA NAMES Cocoa) - MESSAGE(${COCOA}) - link_libraries(${COCOA}) - ELSE(APPLE) - ADD_DEFINITIONS("-DGLEW_INIT_OPENGL11_FUNCTIONS=1") - ADD_DEFINITIONS("-DGLEW_STATIC") - ADD_DEFINITIONS("-DGLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS=1") - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/OpenGLWindow/GlewWindows - ) - LINK_LIBRARIES( pthread dl) - ENDIF(APPLE) -ENDIF(WIN32) - - - - -ADD_EXECUTABLE(App_AllBullet2Demos - ${App_AllBullet2Demos_SRCS} -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(App_AllBullet2Demos PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(App_AllBullet2Demos PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(App_AllBullet2Demos PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos3/AllBullet2Demos/main.cpp b/Demos3/AllBullet2Demos/main.cpp deleted file mode 100644 index aec219c93..000000000 --- a/Demos3/AllBullet2Demos/main.cpp +++ /dev/null @@ -1,759 +0,0 @@ -#include "OpenGLWindow/OpenGLInclude.h" -//#include "OpenGL/gl.h" -//#define USE_OPENGL2 - -#include "OpenGLWindow/SimpleOpenGL2App.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" - -#include "OpenGLWindow/CommonRenderInterface.h" -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#else - -#include "GL/glew.h" -#ifdef _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#else -//let's cross the fingers it is Linux/X11 -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif //_WIN32 -#endif//__APPLE__ -#include "Gwen/Renderers/OpenGL_DebugFont.h" - -#include "Bullet3Common/b3Vector3.h" -#include "assert.h" -#include -#include "Bullet3AppSupport/gwenInternalData.h" -#include "Bullet3AppSupport/gwenUserInterface.h" -#include "BulletDemoEntries.h" -#include "Bullet3AppSupport/b3Clock.h" -#include "Bullet3AppSupport/GwenParameterInterface.h" -#include "Bullet3AppSupport/GwenProfileWindow.h" -#include "Bullet3AppSupport/GwenTextureWindow.h" -#include "Bullet3AppSupport/GraphingTexture.h" -#include "Bullet3AppSupport/Common2dCanvasInterface.h" -#include "Bullet3Common/b3CommandLineArgs.h" - -#include "OpenGLWindow/SimpleCamera.h" -#include "OpenGLWindow/SimpleOpenGL2Renderer.h" - -CommonGraphicsApp* app=0; - -b3gWindowInterface* s_window = 0; -CommonParameterInterface* s_parameterInterface=0; -CommonRenderInterface* s_instancingRenderer=0; -#define DEMO_SELECTION_COMBOBOX 13 -const char* startFileName = "bulletDemo.txt"; - -static GwenUserInterface* gui = 0; -static int sCurrentDemoIndex = 0; -static int sCurrentHightlighted = 0; -static BulletDemoInterface* sCurrentDemo = 0; -static b3AlignedObjectArray allNames; -bool drawGUI=true; -extern bool useShadowMap; -static bool visualWireframe=false; -static bool renderVisualGeometry=true; -static bool renderGrid = true; -int gDebugDrawFlags = 0; -static bool pauseSimulation=false; -int midiBaseIndex = 176; -extern bool gDisableDeactivation; - -//#include -//unsigned int fp_control_state = _controlfp(_EM_INEXACT, _MCW_EM); - - - - - - - -b3KeyboardCallback prevKeyboardCallback = 0; - -void MyKeyboardCallback(int key, int state) -{ - - //printf("key=%d, state=%d\n", key, state); - bool handled = false; - if (gui) - { - - handled = gui->keyboardCallback(key, state); - } - if (!handled && sCurrentDemo) - { - handled = sCurrentDemo->keyboardCallback(key,state); - } - - //checkout: is it desired to ignore keys, if the demo already handles them? - //if (handled) - // return; - - if (key=='a' && state) - { - gDebugDrawFlags ^= btIDebugDraw::DBG_DrawAabb; - } - if (key=='c' && state) - { - gDebugDrawFlags ^= btIDebugDraw::DBG_DrawConstraints; - gDebugDrawFlags ^= btIDebugDraw::DBG_DrawContactPoints; - } - if (key == 'd' && state) - { - gDebugDrawFlags ^= btIDebugDraw::DBG_NoDeactivation; - gDisableDeactivation = ((gDebugDrawFlags & btIDebugDraw::DBG_NoDeactivation) != 0); - } - if (key=='l' && state) - { - gDebugDrawFlags ^= btIDebugDraw::DBG_DrawConstraintLimits; - } - if (key=='w' && state) - { - visualWireframe=!visualWireframe; - gDebugDrawFlags ^= btIDebugDraw::DBG_DrawWireframe; - } - if (key=='v' && state) - { - renderVisualGeometry = !renderVisualGeometry; - } - if (key=='g' && state) - { - renderGrid = !renderGrid; - } - - - if (key=='i' && state) - { - pauseSimulation = !pauseSimulation; - } - - if (key=='s' && state) - { - useShadowMap=!useShadowMap; - } - - if (key==B3G_ESCAPE && s_window) - { - s_window->setRequestExit(); - } - - if (prevKeyboardCallback) - prevKeyboardCallback(key,state); -} - -b3MouseMoveCallback prevMouseMoveCallback = 0; -static void MyMouseMoveCallback( float x, float y) -{ - bool handled = false; - if (sCurrentDemo) - handled = sCurrentDemo->mouseMoveCallback(x,y); - if (!handled && gui) - handled = gui->mouseMoveCallback(x,y); - if (!handled) - { - if (prevMouseMoveCallback) - prevMouseMoveCallback(x,y); - } -} - -b3MouseButtonCallback prevMouseButtonCallback = 0; - -static void MyMouseButtonCallback(int button, int state, float x, float y) -{ - bool handled = false; - //try picking first - if (sCurrentDemo) - handled = sCurrentDemo->mouseButtonCallback(button,state,x,y); - - if (!handled && gui) - handled = gui->mouseButtonCallback(button,state,x,y); - - if (!handled) - { - if (prevMouseButtonCallback ) - prevMouseButtonCallback (button,state,x,y); - } - // b3DefaultMouseButtonCallback(button,state,x,y); -} - -#include - -void openURDFDemo(const char* filename) -{ - - if (sCurrentDemo) - { - sCurrentDemo->exitPhysics(); - s_instancingRenderer->removeAllInstances(); - delete sCurrentDemo; - sCurrentDemo=0; - } - - s_parameterInterface->removeAllParameters(); - - ImportUrdfSetup* physicsSetup = new ImportUrdfSetup(); - physicsSetup->setFileName(filename); - - - sCurrentDemo = new BasicDemo(app, physicsSetup); - app->setUpAxis(2); - - if (sCurrentDemo) - { - sCurrentDemo->initPhysics(); - } - - -} - -void selectDemo(int demoIndex) -{ - sCurrentDemoIndex = demoIndex; - sCurrentHightlighted = demoIndex; - int numDemos = sizeof(allDemos)/sizeof(BulletDemoEntry); - if (demoIndex>numDemos) - { - demoIndex = 0; - } - if (sCurrentDemo) - { - sCurrentDemo->exitPhysics(); - s_instancingRenderer->removeAllInstances(); - delete sCurrentDemo; - sCurrentDemo=0; - } - if (allDemos[demoIndex].m_createFunc) - { - s_parameterInterface->removeAllParameters(); - sCurrentDemo = (*allDemos[demoIndex].m_createFunc)(app); - if (sCurrentDemo) - { - if (gui) - { - bool isLeft = true; - gui->setStatusBarMessage("Status: OK", false); - } - sCurrentDemo->initPhysics(); - } - } - -} - -void MyComboBoxCallback(int comboId, const char* item) -{ - //printf("comboId = %d, item = %s\n",comboId, item); - if (comboId==DEMO_SELECTION_COMBOBOX) - { - //find selected item - for (int i=0;isetStatusBarMessage(msg,isLeft); - } -} - - -void MyStatusBarWarning(const char* msg) -{ - printf("Warning: %s\n", msg); - if (gui) - { - bool isLeft = false; - gui->setStatusBarMessage(msg,isLeft); - } -} - -struct MyMenuItemHander :public Gwen::Event::Handler -{ - int m_buttonId; - - MyMenuItemHander( int buttonId) - :m_buttonId(buttonId) - { - } - - void onButtonA(Gwen::Controls::Base* pControl) - { - //const Gwen::String& name = pControl->GetName(); - Gwen::Controls::TreeNode* node = (Gwen::Controls::TreeNode*)pControl; - // Gwen::Controls::Label* l = node->GetButton(); - - Gwen::UnicodeString la = node->GetButton()->GetText();// node->GetButton()->GetName();// GetText(); - Gwen::String laa = Gwen::Utility::UnicodeToString(la); - // const char* ha = laa.c_str(); - - //printf("selected %s\n", ha); - //int dep = but->IsDepressed(); - //int tog = but->GetToggleState(); -// if (m_data->m_toggleButtonCallback) - // (*m_data->m_toggleButtonCallback)(m_buttonId, tog); - } - void onButtonB(Gwen::Controls::Base* pControl) - { - Gwen::Controls::Label* label = (Gwen::Controls::Label*) pControl; - Gwen::UnicodeString la = label->GetText();// node->GetButton()->GetName();// GetText(); - Gwen::String laa = Gwen::Utility::UnicodeToString(la); - //const char* ha = laa.c_str(); - - - selectDemo(sCurrentHightlighted); - saveCurrentDemoEntry(sCurrentDemoIndex, startFileName); - } - void onButtonC(Gwen::Controls::Base* pControl) - { -// Gwen::Controls::Label* label = (Gwen::Controls::Label*) pControl; - // Gwen::UnicodeString la = label->GetText();// node->GetButton()->GetName();// GetText(); - // Gwen::String laa = Gwen::Utility::UnicodeToString(la); - // const char* ha = laa.c_str(); - - -// printf("onButtonC ! %s\n", ha); - } - void onButtonD(Gwen::Controls::Base* pControl) - { -/* Gwen::Controls::Label* label = (Gwen::Controls::Label*) pControl; - Gwen::UnicodeString la = label->GetText();// node->GetButton()->GetName();// GetText(); - Gwen::String laa = Gwen::Utility::UnicodeToString(la); - const char* ha = laa.c_str(); - */ - - // printf("onKeyReturn ! \n"); - selectDemo(sCurrentHightlighted); - saveCurrentDemoEntry(sCurrentDemoIndex, startFileName); - - } - - void onButtonE(Gwen::Controls::Base* pControl) - { - // printf("select %d\n",m_buttonId); - sCurrentHightlighted = m_buttonId; - } - - void onButtonF(Gwen::Controls::Base* pControl) - { - //printf("selection changed!\n"); - } - - void onButtonG(Gwen::Controls::Base* pControl) - { - //printf("onButtonG !\n"); - } - - - -}; -#include "Bullet3Common/b3HashMap.h" - -struct GL3TexLoader : public MyTextureLoader -{ - b3HashMap m_hashMap; - - virtual void LoadTexture( Gwen::Texture* pTexture ) - { - Gwen::String namestr = pTexture->name.Get(); - const char* n = namestr.c_str(); - GLint* texIdPtr = m_hashMap[n]; - if (texIdPtr) - { - pTexture->m_intData = *texIdPtr; - } - } - virtual void FreeTexture( Gwen::Texture* pTexture ) - { - } -}; - -void fileOpenCallback() -{ - - char filename[1024]; - int len = s_window->fileOpenDialog(filename,1024); - if (len) - { - //todo(erwincoumans) check if it is actually URDF - //printf("file open:%s\n", filename); - openURDFDemo(filename); - } -} - -#define MAX_GRAPH_WINDOWS 5 - -struct QuickCanvas : public Common2dCanvasInterface -{ - GL3TexLoader* m_myTexLoader; - - MyGraphWindow* m_gw[MAX_GRAPH_WINDOWS]; - GraphingTexture* m_gt[MAX_GRAPH_WINDOWS]; - int m_curNumGraphWindows; - - QuickCanvas(GL3TexLoader* myTexLoader) - :m_myTexLoader(myTexLoader), - m_curNumGraphWindows(0) - { - for (int i=0;igetInternalData()); - input.m_width=width; - input.m_height=height; - input.m_xPos = 300; - input.m_yPos = height-input.m_height; - input.m_name=canvasName; - input.m_texName = canvasName; - m_gt[slot] = new GraphingTexture; - m_gt[slot]->create(width,height); - int texId = m_gt[slot]->getTextureId(); - m_myTexLoader->m_hashMap.insert(canvasName, texId); - m_gw[slot] = setupTextureWindow(input); - - return slot; - } - return -1; - } - virtual void destroyCanvas(int canvasId) - { - btAssert(canvasId==0);//hardcoded to zero for now, only a single canvas - btAssert(m_curNumGraphWindows==1); - destroyTextureWindow(m_gw[canvasId]); - m_curNumGraphWindows--; - } - virtual void setPixel(int canvasId, int x, int y, unsigned char red, unsigned char green,unsigned char blue, unsigned char alpha) - { - btAssert(canvasId==0);//hardcoded - btAssert(m_curNumGraphWindows==1); - m_gt[canvasId]->setPixel(x,y,red,green,blue,alpha); - } - virtual void refreshImageData(int canvasId) - { - m_gt[canvasId]->uploadImageData(); - } -}; - -extern float shadowMapWorldSize; -int main(int argc, char* argv[]) -{ - b3CommandLineArgs args(argc,argv); - - shadowMapWorldSize = 25; - - b3Clock clock; - - //float dt = 1./120.f; - int width = 1024; - int height=768; - - // wci.m_resizeCallback = MyResizeCallback; - - SimpleOpenGL3App* simpleApp=0; - bool useOpenGL2=false; - if (useOpenGL2) - { - app = new SimpleOpenGL2App("AllBullet2Demos",width,height); - app->m_renderer = new SimpleOpenGL2Renderer(width,height); - } else - { - simpleApp = new SimpleOpenGL3App("AllBullet2Demos",width,height); - app = simpleApp; - } - char* gVideoFileName = 0; - args.GetCmdLineArgument("mp4",gVideoFileName); - - if (gVideoFileName) - simpleApp->dumpFramesToVideo(gVideoFileName); - - - s_instancingRenderer = app->m_renderer; - s_window = app->m_window; - prevMouseMoveCallback = s_window->getMouseMoveCallback(); - s_window->setMouseMoveCallback(MyMouseMoveCallback); - - prevMouseButtonCallback = s_window->getMouseButtonCallback(); - s_window->setMouseButtonCallback(MyMouseButtonCallback); - prevKeyboardCallback = s_window->getKeyboardCallback(); - s_window->setKeyboardCallback(MyKeyboardCallback); - - app->m_renderer->setCameraDistance(13); - app->m_renderer->setCameraPitch(0); - app->m_renderer->setCameraTargetPosition(0,0,0); - - b3SetCustomWarningMessageFunc(MyStatusBarWarning); - b3SetCustomPrintfFunc(MyStatusBarPrintf); - - - /* - SimpleOpenGL3App* app = new SimpleOpenGL3App("AllBullet2Demos",width,height); - s_instancingRenderer->setCameraDistance(13); - s_instancingRenderer->setCameraPitch(0); - s_instancingRenderer->setCameraTargetPosition(0,0,0); - s_window->setMouseMoveCallback(MyMouseMoveCallback); - s_window->setMouseButtonCallback(MyMouseButtonCallback); - s_window->setKeyboardCallback(MyKeyboardCallback); - - */ - assert(glGetError()==GL_NO_ERROR); - - - - gui = new GwenUserInterface; - GL3TexLoader* myTexLoader = new GL3TexLoader; - - Gwen::Renderer::Base* gwenRenderer = 0; - if (useOpenGL2) - { - gwenRenderer = new Gwen::Renderer::OpenGL_DebugFont(); - } else - { - sth_stash* fontstash=simpleApp->getFontStash(); - gwenRenderer = new GwenOpenGL3CoreRenderer(simpleApp->m_primRenderer,fontstash,width,height,s_window->getRetinaScale(),myTexLoader); - } - // - - gui->init(width,height,gwenRenderer,s_window->getRetinaScale()); -// gui->getInternalData()->m_explorerPage - Gwen::Controls::TreeControl* tree = gui->getInternalData()->m_explorerTreeCtrl; - - - //gui->getInternalData()->pRenderer->setTextureLoader(myTexLoader); - - - MyProfileWindow* profWindow = setupProfileWindow(gui->getInternalData()); - profileWindowSetVisible(profWindow,false); - gui->setFocus(); -#if 0 - { - MyGraphInput input(gui->getInternalData()); - input.m_width=300; - input.m_height=300; - input.m_xPos = 0; - input.m_yPos = height-input.m_height; - input.m_name="Test Graph1"; - input.m_texName = "graph1"; - GraphingTexture* gt = new GraphingTexture; - gt->create(256,256); - int texId = gt->getTextureId(); - myTexLoader->m_hashMap.insert("graph1", texId); - //MyGraphWindow* gw = - setupTextureWindow(input); - } - if (1) - { - MyGraphInput input(gui->getInternalData()); - input.m_width=300; - input.m_height=300; - input.m_xPos = width-input.m_width; - input.m_yPos = height-input.m_height; - input.m_name="Test Graph2"; - input.m_texName = "graph2"; - GraphingTexture* gt = new GraphingTexture; - int texWidth = 512; - int texHeight = 512; - gt->create(texWidth,texHeight); - for (int i=0;isetPixel(i,j,0,0,0,255); - } - } - gt->uploadImageData(); - - int texId = gt->getTextureId(); - input.m_xPos = width-input.m_width; - myTexLoader->m_hashMap.insert("graph2", texId); - //MyGraphWindow* gw = - setupTextureWindow(input); - } - //destroyTextureWindow(gw); -#endif - s_parameterInterface = app->m_parameterInterface = new GwenParameterInterface(gui->getInternalData()); - app->m_2dCanvasInterface = new QuickCanvas(myTexLoader); - - //gui->getInternalData()->m_demoPage; - - int numDemos = sizeof(allDemos)/sizeof(BulletDemoEntry); - - //char nodeText[1024]; - //int curDemo = 0; - int selectedDemo = loadCurrentDemoEntry(startFileName); - Gwen::Controls::TreeNode* curNode = tree; - MyMenuItemHander* handler2 = new MyMenuItemHander(-1); - - tree->onReturnKeyDown.Add(handler2, &MyMenuItemHander::onButtonD); - - for (int d = 0; dAddNode(nodeUText); - if (d == selectedDemo) - { - pNode->SetSelected(true); - tree->ExpandAll(); - selectDemo(d); - - - } - MyMenuItemHander* handler = new MyMenuItemHander(d); - pNode->onNamePress.Add(handler, &MyMenuItemHander::onButtonA); - pNode->GetButton()->onDoubleClick.Add(handler, &MyMenuItemHander::onButtonB); - pNode->GetButton()->onDown.Add(handler, &MyMenuItemHander::onButtonC); - pNode->onSelect.Add(handler, &MyMenuItemHander::onButtonE); - pNode->onReturnKeyDown.Add(handler, &MyMenuItemHander::onButtonG); - pNode->onSelectChange.Add(handler, &MyMenuItemHander::onButtonF); -// pNode->onKeyReturn.Add(handler, &MyMenuItemHander::onButtonD); -// pNode->GetButton()->onKeyboardReturn.Add(handler, &MyMenuItemHander::onButtonD); - // pNode->onNamePress.Add(handler, &MyMenuItemHander::onButtonD); -// pNode->onKeyboardPressed.Add(handler, &MyMenuItemHander::onButtonD); -// pNode->OnKeyPress - } - else - { - curNode = tree->AddNode(nodeUText); - } - } - -/* for (int i=0;iregisterComboBox(DEMO_SELECTION_COMBOBOX,allNames.size(),&allNames[0],sCurrentDemoIndex); - - //const char* names2[] = {"comboF", "comboG","comboH"}; - //gui->registerComboBox(2,3,&names2[0],0); - - gui->setComboBoxCallback(MyComboBoxCallback); - */ - unsigned long int prevTimeInMicroseconds = clock.getTimeMicroseconds(); - - gui->registerFileOpenCallback(fileOpenCallback); - - do - { - - assert(glGetError()==GL_NO_ERROR); - s_instancingRenderer->init(); - DrawGridData dg; - dg.upAxis = app->getUpAxis(); - - { - BT_PROFILE("Update Camera"); - s_instancingRenderer->updateCamera(dg.upAxis); - } - - if (renderGrid) - { - BT_PROFILE("Draw Grid"); - app->drawGrid(dg); - } - static int frameCount = 0; - frameCount++; - - if (0) - { - BT_PROFILE("Draw frame counter"); - char bla[1024]; - sprintf(bla,"Frame %d", frameCount); - app->drawText(bla,10,10); - } - - if (sCurrentDemo) - { - if (!pauseSimulation) - { - unsigned long int curTimeInMicroseconds = clock.getTimeMicroseconds(); - unsigned long int diff = curTimeInMicroseconds-prevTimeInMicroseconds; - float deltaTimeInSeconds = (diff)*1.e-6; - //printf("---------------------------------------------------\n"); - //printf("Framecount = %d\n",frameCount); - - sCurrentDemo->stepSimulation(deltaTimeInSeconds);//1./60.f); - prevTimeInMicroseconds = curTimeInMicroseconds; - } - - if (renderVisualGeometry) - { - if (visualWireframe) - { - glPolygonMode( GL_FRONT_AND_BACK, GL_LINE ); - } - BT_PROFILE("Render Scene"); - sCurrentDemo->renderScene(); - } - { - glPolygonMode( GL_FRONT_AND_BACK, GL_FILL ); - sCurrentDemo->physicsDebugDraw(gDebugDrawFlags); - } - } - - static int toggle = 1; - if (1) - { - if (!pauseSimulation) - processProfileData(profWindow,false); - { - if (useOpenGL2) - { - saveOpenGLState(width,height); - } - BT_PROFILE("Draw Gwen GUI"); - gui->draw(s_instancingRenderer->getScreenWidth(),s_instancingRenderer->getScreenHeight()); - if (useOpenGL2) - { - restoreOpenGLState(); - } - } - } - toggle=1-toggle; - { - BT_PROFILE("Sync Parameters"); - s_parameterInterface->syncParameters(); - } - { - BT_PROFILE("Swap Buffers"); - app->swapBuffer(); - } - - gui->forceUpdateScrollBars(); - } while (!s_window->requestedExit()); - -// selectDemo(0); - delete gui; - delete app; - return 0; -} diff --git a/Demos3/AllBullet2Demos/premake4.lua b/Demos3/AllBullet2Demos/premake4.lua deleted file mode 100644 index 4626235b5..000000000 --- a/Demos3/AllBullet2Demos/premake4.lua +++ /dev/null @@ -1,131 +0,0 @@ - - project "App_AllBullet2Demos" - - language "C++" - - kind "ConsoleApp" - - includedirs { - ".", - "../../src", - "../../btgui", - "../../btgui/lua-5.2.3/src", - "../../Demos3/FiniteElementMethod" - } - - - links{"Bullet3AppSupport","gwen", "OpenGL_Window","BulletDynamics","BulletCollision","LinearMath","Bullet3Common","lua-5.2.3"} - initOpenGL() - initGlew() - - if _OPTIONS["midi"] then - if os.is("Windows") then - files {"../../btgui/MidiTest/RtMidi.cpp"} - links {"winmm"} - defines {"__WINDOWS_MM__", "WIN32","B3_USE_MIDI"} - end - - if os.is("Linux") then - defines {"__LINUX_ALSA__"} - links {"asound","pthread"} - end - - if os.is("MacOSX") then - files {"../../btgui/MidiTest/RtMidi.cpp"} - links{"CoreAudio.framework", "coreMIDI.framework", "Cocoa.framework"} - defines {"__MACOSX_CORE__","B3_USE_MIDI"} - end - end - - files { - "**.cpp", - "**.h", - "../bullet2/LuaDemo/LuaPhysicsSetup.cpp", - "../bullet2/LuaDemo/LuaPhysicsSetup.h", - "../bullet2/MultiBodyDemo/TestJointTorqueSetup.cpp", - "../bullet2/MultiBodyDemo/TestJointTorqueSetup.h", - "../bullet2/MultiBodyDemo/MultiBodyVehicle.cpp", - "../bullet2/MultiBodyDemo/MultiBodyVehicle.h", - "../bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.cpp", - "../bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.h", --- "../DifferentialGearDemo/DifferentialGearSetup.cpp", --- "../DifferentialGearDemo/DifferentialGearSetup.h", - "../FiniteElementMethod/FiniteElementDemo.cpp", - "../../Demos/BasicDemo/BasicDemoPhysicsSetup.cpp", - "../../Demos/BasicDemo/BasicDemoPhysicsSetup.h", - "../../Demos/ForkLiftDemo/ForkLiftPhysicsSetup.cpp", - "../../Demos/ForkLiftDemo/ForkLiftPhysicsSetup.h", - "../../Demos/CcdPhysicsDemo/CcdPhysicsSetup.cpp", - "../../Demos/CcdPhysicsDemo/CcdPhysicsSetup.h", - "../../Demos/Raytracer/RaytracerSetup.cpp", - "../../Demos/Raytracer/RaytracerSetup.h", - "../../Demos/GyroscopicDemo/GyroscopicSetup.cpp", - "../../Demos/GyroscopicDemo/GyroscopicSetup.h", - "../../Demos/SerializeDemo/SerializeSetup.cpp", - "../../Extras/Serialize/BulletFileLoader/bChunk.cpp", - "../../Extras/Serialize/BulletFileLoader/bDNA.cpp", - "../../Extras/Serialize/BulletFileLoader/bFile.cpp", - "../../Extras/Serialize/BulletFileLoader/btBulletFile.cpp", - "../../Extras/Serialize/BulletWorldImporter/btBulletWorldImporter.cpp", - "../../Extras/Serialize/BulletWorldImporter/btWorldImporter.cpp", - "../bullet2/ConstraintDemo/ConstraintPhysicsSetup.cpp", - "../bullet2/ConstraintDemo/ConstraintPhysicsSetup.h", - "../bullet2/ConstraintDemo/Dof6Spring2Setup.cpp", - "../bullet2/ConstraintDemo/Dof6Spring2Setup.h", --- "../bullet2/SoftDemo/SoftDemo.cpp", - "../ImportColladaDemo/LoadMeshFromCollada.cpp", - "../ImportColladaDemo/ImportColladaSetup.cpp", - "../ImportURDFDemo/URDF2Bullet.cpp", - "../ImportURDFDemo/ImportURDFSetup.cpp", - "../ImportObjDemo/ImportObjSetup.cpp", - "../ImportObjDemo/LoadMeshFromObj.cpp", - "../ImportObjDemo/LoadMeshFromObj.h", - "../ImportObjDemo/Wavefront2GLInstanceGraphicsShape.cpp", - "../ImportSTLDemo/ImportSTLSetup.cpp", - "../Wavefront/tiny_obj_loader.cpp", - "../Wavefront/tiny_obj_loader.h", - "../../btgui/urdf/urdfdom/urdf_parser/src/pose.cpp", - "../../btgui/urdf/urdfdom/urdf_parser/src/model.cpp", - "../../btgui/urdf/urdfdom/urdf_parser/src/link.cpp", - "../../btgui/urdf/urdfdom/urdf_parser/src/joint.cpp", - "../../btgui/urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h", - "../../btgui/urdf/urdfdom_headers/urdf_exception/include/urdf_exception/exception.h", - "../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/pose.h", - "../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/model.h", - "../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/link.h", - "../../btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/joint.h", - "../../btgui/tinyxml/tinystr.cpp", - "../../btgui/tinyxml/tinyxml.cpp", - "../../btgui/tinyxml/tinyxmlerror.cpp", - "../../btgui/tinyxml/tinyxmlparser.cpp", - "../../btgui/urdf/boost_replacement/lexical_cast.h", - "../../btgui/urdf/boost_replacement/shared_ptr.h", - "../../btgui/urdf/boost_replacement/printf_console.cpp", - "../../btgui/urdf/boost_replacement/printf_console.h", - "../../btgui/urdf/boost_replacement/string_split.cpp", - "../../btgui/urdf/boost_replacement/string_split.h", - "../bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.cpp", - "../bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.h", - "../bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.cpp", - "../bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.h", - "../bullet2/BasicDemo/BasicDemo.cpp", - "../bullet2/BasicDemo/BasicDemo.h", --- "../bullet2/BasicDemo/HingeDemo.cpp", --- "../bullet2/BasicDemo/HingeDemo.h", --- "../bullet2/ChainDemo/ChainDemo.cpp", --- "../bullet2/ChainDemo/ChainDemo.h", - --- "../bullet2/RagdollDemo/RagdollDemo.cpp", --- "../bullet2/RagdollDemo/RagdollDemo.h", --- "../bullet2/LuaDemo/LuaDemo.cpp", --- "../bullet2/LuaDemo/LuaDemo.h", - - - } - -if os.is("Linux") then - initX11() -end -if os.is("MacOSX") then - links{"Cocoa.framework"} -end diff --git a/Demos3/BasicDemo/BasicDemo.cpp b/Demos3/BasicDemo/BasicDemo.cpp deleted file mode 100644 index 425506520..000000000 --- a/Demos3/BasicDemo/BasicDemo.cpp +++ /dev/null @@ -1,242 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -///create 125 (5x5x5) dynamic object -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - -///scaling of the objects (0.1 = 20 centimeter boxes ) -#define SCALING 1. -#define START_POS_X -5 -#define START_POS_Y -5 -#define START_POS_Z -3 - -#include "BasicDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" - -#include //printf debugging -#include "GLDebugDrawer.h" - -static GLDebugDrawer gDebugDraw; - - -void BasicDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void BasicDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - - - - - -void BasicDemo::initPhysics() -{ - setTexturing(true); - setShadows(true); - - setCameraDistance(btScalar(SCALING*50.)); - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld->setDebugDrawer(&gDebugDraw); - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///create a few basic rigid bodies - btBoxShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.))); - //groundShape->initializePolyhedralFeatures(); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btBoxShape* colShape = new btBoxShape(btVector3(SCALING*1,SCALING*1,SCALING*1)); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - float start_x = START_POS_X - ARRAY_SIZE_X/2; - float start_y = START_POS_Y; - float start_z = START_POS_Z - ARRAY_SIZE_Z/2; - - for (int k=0;kaddRigidBody(body); - } - } - } - } - - -} -void BasicDemo::clientResetScene() -{ - exitPhysics(); - initPhysics(); -} - - -void BasicDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - public: - - BasicDemo() - { - } - virtual ~BasicDemo() - { - exitPhysics(); - } - void initPhysics(); - - void exitPhysics(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - virtual void clientResetScene(); - - static DemoApplication* Create() - { - BasicDemo* demo = new BasicDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //BASIC_DEMO_H - diff --git a/Demos3/BasicDemo/CMakeLists.txt b/Demos3/BasicDemo/CMakeLists.txt deleted file mode 100644 index 6a7646e36..000000000 --- a/Demos3/BasicDemo/CMakeLists.txt +++ /dev/null @@ -1,69 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -${BULLET_PHYSICS_SOURCE_DIR}/ObsoleteDemos/OpenGL -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppBasicDemo - main.cpp - BasicDemo.cpp - BasicDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppBasicDemo - main.cpp - BasicDemo.cpp - BasicDemo.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppBasicDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32BasicDemo.cpp - BasicDemo.cpp - BasicDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos3/BasicDemo/Makefile.am b/Demos3/BasicDemo/Makefile.am deleted file mode 100644 index 05546162b..000000000 --- a/Demos3/BasicDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=BasicDemo - -BasicDemo_SOURCES=BasicDemo.cpp BasicDemo.h main.cpp -BasicDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -BasicDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos3/BasicDemo/Win32BasicDemo.cpp b/Demos3/BasicDemo/Win32BasicDemo.cpp deleted file mode 100644 index 72f92a15f..000000000 --- a/Demos3/BasicDemo/Win32BasicDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BasicDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new BasicDemo(); -} - -#endif diff --git a/Demos3/BasicDemo/main.cpp b/Demos3/BasicDemo/main.cpp deleted file mode 100644 index d666630a8..000000000 --- a/Demos3/BasicDemo/main.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BasicDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - - -int main(int argc,char** argv) -{ - - BasicDemo ccdDemo; - ccdDemo.initPhysics(); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos3/BasicDemoConsole/main.cpp b/Demos3/BasicDemoConsole/main.cpp deleted file mode 100644 index b54118527..000000000 --- a/Demos3/BasicDemoConsole/main.cpp +++ /dev/null @@ -1,14 +0,0 @@ - -#include -#include "../../Demos/BasicDemo/BasicDemoPhysicsSetup.h" - -int main(int argc, char* argv[]) -{ - BasicDemoPhysicsSetup physicsSetup; - GraphicsPhysicsBridge br; - physicsSetup.initPhysics(br); - physicsSetup.stepSimulation(1./60.); - physicsSetup.exitPhysics(); - - printf("hello\n"); -} \ No newline at end of file diff --git a/Demos3/BasicDemoConsole/premake4.lua b/Demos3/BasicDemoConsole/premake4.lua deleted file mode 100644 index 13b66fd6c..000000000 --- a/Demos3/BasicDemoConsole/premake4.lua +++ /dev/null @@ -1,26 +0,0 @@ -project "App_BasicDemoConsole" - - kind "ConsoleApp" - targetdir "../../bin" - - includedirs {"../../src","../../btgui"} - configuration { "Windows" } --- links { "opengl32","glu32","gdi32","winmm", "user32" } - files { "../../build3/bullet.rc" } --- configuration {"MacOSX"} - --print "hello" - -- linkoptions { "-framework Carbon -framework OpenGL -framework AGL -framework Glut" } --- configuration {"not Windows", "not MacOSX"} --- links {"GL","GLU","glut"} - configuration{} - - links { - "BulletDynamics", "BulletCollision", "LinearMath" - } - - files { - "*.cpp" , - "*.h", - "../../Demos/BasicDemo/BasicDemoPhysicsSetup.cpp", - "../../Demos/BasicDemo/BasicDemoPhysicsSetup.h" - } diff --git a/Demos3/BasicDemoCustomOpenGL2/main.cpp b/Demos3/BasicDemoCustomOpenGL2/main.cpp deleted file mode 100644 index 90ddcd5e0..000000000 --- a/Demos3/BasicDemoCustomOpenGL2/main.cpp +++ /dev/null @@ -1,256 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2014 Erwin Coumans http://bulletphysics.org - -//This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///This main.cpp replaces glut by Bullet 3 own platform management for OpenGL and input devices - -#include -#include "../../Demos/BasicDemo/BasicDemoPhysicsSetup.h" - - -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#else - -#include "GL/glew.h" -#ifdef _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#else -//let's cross the fingers it is Linux/X11 -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif //_WIN32 -#endif//__APPLE__ - -#include "../../Demos/OpenGL/DemoApplication.h" -#include "../../Demos/OpenGL/GLDebugDrawer.h" - -int sWidth = 800; -int sHeight = 600; -DemoApplication* gApp = 0; -bool isShiftPressed = false; -bool isCtrlPressed = false; -bool isAltPressed = false; - -/* -todo: add wheel callback -typedef void (*b3WheelCallback)(float deltax, float deltay); -*/ - -void MyKeyboardCallback(int orgKeycode, int state) -{ - int keycode = orgKeycode; - - if (gApp) - { - - switch (orgKeycode) - { - case B3G_SHIFT: - { - isShiftPressed = (state==1); - break; - } - case B3G_ALT: - { - isAltPressed = (state==1); - break; - } - case B3G_CONTROL: - { - isCtrlPressed = (state==1); - break; - } - default: - { - } - }; - - if (state) - { - gApp->keyboardCallback(keycode,0,0); - } else - { - gApp->keyboardUpCallback(keycode,0,0); - } - } -} -void MyMouseMoveCallback( float x, float y) -{ - if (gApp) - { - //printf("mouseMotionFunc %f,%f\n",x,y); - gApp->mouseMotionFunc(x,y); - } -} - -void MyMouseButtonCallback(int button, int state, float x, float y) -{ - if (gApp) - { - //printf("mouseFunc %d,%d, %f,%f\n",button,state,x,y); - gApp->mouseFunc(button,1-state,x,y); - } -} - -void MyResizeCallback(float width, float height) -{ - sWidth = width; - sHeight = height; - if (gApp) - { - gApp->reshape(width,height); - } -} - -int main(int argc, char* argv[]) -{ - - b3gDefaultOpenGLWindow* window = new b3gDefaultOpenGLWindow(); - //window->setKeyboardCallback(keyCallback); - b3gWindowConstructionInfo wci; - wci.m_openglVersion = 2; - wci.m_width = sWidth; - wci.m_height = sHeight; - // wci.m_resizeCallback = MyResizeCallback; - - window->createWindow(wci); - window->setResizeCallback(MyResizeCallback); - window->setMouseButtonCallback(MyMouseButtonCallback); - - window->setMouseMoveCallback(MyMouseMoveCallback); - window->setKeyboardCallback(MyKeyboardCallback); - -// window->setWindowTitle("render test"); - - int majorGlVersion, minorGlVersion; - - if (!sscanf((const char*)glGetString(GL_VERSION), "%d.%d", &majorGlVersion, &minorGlVersion)==2) - { - printf("Exit: Error cannot extract OpenGL version from GL_VERSION string\n"); - exit(0); - } - if (majorGlVersion>=3 && wci.m_openglVersion>=3) - { - // float retinaScale = 1.f; - -#ifndef __APPLE__ -#ifndef _WIN32 - //we need glewExperimental on Linux - glewExperimental = GL_TRUE; -#endif // _WIN32 - glewInit(); -#endif - - //we need to call glGetError twice, because of some Ubuntu/Intel/OpenGL issue - - glGetError(); - glGetError(); - - btAssert(glGetError()==GL_NO_ERROR); - - - //retinaScale = window->getRetinaScale(); - - //primRenderer = new GLPrimitiveRenderer(sWidth,sHeight); - //sth_stash* font = initFont(primRenderer ); - //gwenRenderer = new GwenOpenGL3CoreRenderer(primRenderer,font,sWidth,sHeight,retinaScale); - - } else - { - //OpenGL 2.x - /*gwenRenderer = new Gwen::Renderer::OpenGL_DebugFont(); - skin.SetRender( gwenRenderer ); - - pCanvas = new Gwen::Controls::Canvas( &skin ); - pCanvas->SetSize( sWidth, sHeight); - pCanvas->SetDrawBackground( true ); - pCanvas->SetBackgroundColor( Gwen::Color( 150, 170, 170, 255 ) ); - */ - - } - - -// glClearColor(0.2,0.2,0.2,1); - - - - BasicDemoPhysicsSetup physicsSetup; - GraphicsPhysicsBridge br; - physicsSetup.initPhysics(br); - - - struct MyAppie : public DemoApplication - { - virtual void initPhysics() - { - } - virtual void clientMoveAndDisplay() - { - } - virtual void swapBuffers() - { - } - virtual void updateModifierKeys() - { - m_modifierKeys = 0; - if (isAltPressed) - m_modifierKeys |= BT_ACTIVE_ALT; - - if (isCtrlPressed) - m_modifierKeys |= BT_ACTIVE_CTRL; - - if (isShiftPressed) - m_modifierKeys |= BT_ACTIVE_SHIFT; - - } - - }; - - { - MyAppie appie; - appie.setDynamicsWorld(physicsSetup.m_dynamicsWorld); - appie.reshape(sWidth,sHeight); - appie.setShadows(true); - gApp = &appie; - GLDebugDrawer draw; - physicsSetup.m_dynamicsWorld->setDebugDrawer(&draw); - btClock timer; - unsigned long prevTime = timer.getTimeMicroseconds(); - - do - { - unsigned long curTime = timer.getTimeMicroseconds(); - if (!appie.isIdle()) - { - physicsSetup.stepSimulation((curTime-prevTime)*(1./1000000.)); - } - prevTime = curTime; - window->startRendering(); - br.syncPhysicsToGraphics(physicsSetup.m_dynamicsWorld); - appie.renderme(); - physicsSetup.m_dynamicsWorld->debugDrawWorld(); - window->endRendering(); - - } while (!window->requestedExit()); - } - window->closeWindow(); - delete window; - - physicsSetup.exitPhysics(); - - - printf("hello\n"); -} diff --git a/Demos3/BasicDemoCustomOpenGL2/premake4.lua b/Demos3/BasicDemoCustomOpenGL2/premake4.lua deleted file mode 100644 index c37918dc5..000000000 --- a/Demos3/BasicDemoCustomOpenGL2/premake4.lua +++ /dev/null @@ -1,39 +0,0 @@ -project "App_BasicDemoCustomOpenGL2" - - kind "ConsoleApp" - targetdir "../../bin" - - includedirs { - "../../src", - "../../btgui" - } - - defines { "DONT_USE_GLUT", "USE_OPENGL2"} - - initOpenGL() - initGlew() - - links { - "OpenGL_Window","BulletDynamics", "BulletCollision", "LinearMath" - } - - files { - "*.cpp" , - "*.h", - "../../Demos/BasicDemo/BasicDemoPhysicsSetup.cpp", - "../../Demos/BasicDemo/BasicDemoPhysicsSetup.h", - "../../Demos/OpenGL/DemoApplication.cpp", - "../../Demos/OpenGL/DemoApplication.h", - "../../Demos/OpenGL/GL_ShapeDrawer.cpp", - "../../Demos/OpenGL/GL_ShapeDrawer.h", - "../../Demos/OpenGL/GL_ShapeDrawer.cpp", - "../../Demos/OpenGL/GLDebugDrawer.cpp", - "../../Demos/OpenGL/GLDebugDrawer.h", - "../../Demos/OpenGL/GLDebugFont.cpp", - "../../Demos/OpenGL/GLDebugFont.h" - } -if os.is("Linux") then initX11() end - -if os.is("MacOSX") then - links{"Cocoa.framework"} -end diff --git a/Demos3/BasicGpuDemo/BasicGpuDemo.cpp b/Demos3/BasicGpuDemo/BasicGpuDemo.cpp deleted file mode 100644 index 1dbf3567e..000000000 --- a/Demos3/BasicGpuDemo/BasicGpuDemo.cpp +++ /dev/null @@ -1,437 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - - -///create 125 (5x5x5) dynamic object -#define ARRAY_SIZE_X 20 -#define ARRAY_SIZE_Y 20 -#define ARRAY_SIZE_Z 20 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - -///scaling of the objects (0.1 = 20 centimeter boxes ) -#define SCALING 1. -#define START_POS_X -5 -#define START_POS_Y -5 -#define START_POS_Z -3 - -#include "BasicGpuDemo.h" -#include "GlutStuff.h" -///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files. -#include "btBulletDynamicsCommon.h" -#include "b3GpuDynamicsWorld.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" - - - -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" - - -#include "Bullet3Collision/BroadPhaseCollision/b3DynamicBvhBroadphase.h" - - - -#include //printf debugging -#include "GLDebugDrawer.h" - -static GLDebugDrawer gDebugDraw; - - -void BasicGpuDemo::clientMoveAndDisplay() -{ - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - //simple dynamics world doesn't handle fixed-time-stepping - float ms = getDeltaTimeMicroseconds(); - - ///step the simulation - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(ms / 1000000.f); - //optional but useful: debug drawing - m_dynamicsWorld->debugDrawWorld(); - } - - renderme(); - - glFlush(); - - swapBuffers(); - -} - - - -void BasicGpuDemo::displayCallback(void) { - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - renderme(); - - //optional but useful: debug drawing to detect problems - if (m_dynamicsWorld) - m_dynamicsWorld->debugDrawWorld(); - - glFlush(); - swapBuffers(); -} - -struct btInternalData -{ - cl_context m_clContext; - cl_device_id m_clDevice; - cl_command_queue m_clQueue; - const char* m_clDeviceName; - bool m_clInitialized; - - btInternalData() - { - m_clContext = 0; - m_clDevice = 0; - m_clQueue = 0; - m_clDeviceName = 0; - m_clInitialized =false; - } -}; - -void BasicGpuDemo::initCL(int preferredDeviceIndex, int preferredPlatformIndex) -{ - void* glCtx=0; - void* glDC = 0; - - - - int ciErrNum = 0; - //#ifdef CL_PLATFORM_INTEL - //cl_device_type deviceType = CL_DEVICE_TYPE_ALL; - //#else - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; - //#endif - - cl_platform_id platformId; - - // if (useInterop) - // { - // m_data->m_clContext = b3OpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC); - // } else - { - m_clData->m_clContext = b3OpenCLUtils::createContextFromType(deviceType, &ciErrNum, 0,0,preferredDeviceIndex, preferredPlatformIndex,&platformId); - b3OpenCLUtils::printPlatformInfo(platformId); - } - - - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - int numDev = b3OpenCLUtils::getNumDevices(m_clData->m_clContext); - - if (numDev>0) - { - m_clData->m_clDevice= b3OpenCLUtils::getDevice(m_clData->m_clContext,0); - m_clData->m_clQueue = clCreateCommandQueue(m_clData->m_clContext, m_clData->m_clDevice, 0, &ciErrNum); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - b3OpenCLUtils::printDeviceInfo(m_clData->m_clDevice); - b3OpenCLDeviceInfo info; - b3OpenCLUtils::getDeviceInfo(m_clData->m_clDevice,&info); - m_clData->m_clDeviceName = info.m_deviceName; - m_clData->m_clInitialized = true; - - } - -} - -void BasicGpuDemo::exitCL() -{ - -} - -BasicGpuDemo::BasicGpuDemo() -{ - m_np=0; - m_bp=0; - m_clData = new btInternalData; - setCameraDistance(btScalar(SCALING*60.)); - this->setAzi(45); - this->setEle(45); - -} - -BasicGpuDemo::~BasicGpuDemo() -{ - exitPhysics(); - exitCL(); - delete m_clData; -} - - -extern bool gUseLargeBatches; - -void BasicGpuDemo::initPhysics() -{ - gUseLargeBatches = true;//for testing, this option is faster on NVIDIA GPUs - //use the Bullet 2.x btQuickprof for profiling of Bullet 3.x - b3SetCustomEnterProfileZoneFunc(CProfileManager::Start_Profile); - b3SetCustomLeaveProfileZoneFunc(CProfileManager::Stop_Profile); - - setTexturing(true); - setShadows(false);//too slow with many objects - - - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = 0; - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = 0; - - m_broadphase = 0; - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - - m_solver = 0; - - initCL(-1,-1); - - - if (!m_clData->m_clInitialized) - { - printf("Error: cannot initialize OpenCL\n"); - exit(0); - } - - b3Config config; - m_np = new b3GpuNarrowPhase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue,config); - m_bp = new b3GpuSapBroadphase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - - b3DynamicBvhBroadphase* broadphaseDbvt = new b3DynamicBvhBroadphase(config.m_maxConvexBodies); - - m_rbp = new b3GpuRigidBodyPipeline(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue, m_np, m_bp,broadphaseDbvt,config); - - m_dynamicsWorld = new b3GpuDynamicsWorld(m_bp,m_np,m_rbp); - - m_dynamicsWorld->setDebugDrawer(&gDebugDraw); - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - - createObjects(); -} - -void BasicGpuDemo::createObjects() -{ - ///create a few basic rigid bodies - btBoxShape* groundShape = new btBoxShape(btVector3(btScalar(150.),btScalar(50.),btScalar(150.))); - //groundShape->initializePolyhedralFeatures(); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - if (0) - { - btTransform tr; - tr.setIdentity(); - btVector3 faraway(-1e30,-1e30,-1e30); - - tr.setOrigin(faraway); - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(tr); - btSphereShape* dummyShape = new btSphereShape(0.f); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,dummyShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - - - } - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - //btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,0,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - body->setWorldTransform(groundTransform); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btBoxShape* colShape = new btBoxShape(btVector3(SCALING*1,SCALING*1,SCALING*1)); - //btCollisionShape* colShape = new btSphereShape(btScalar(SCALING*1.f)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - float start_x = START_POS_X - ARRAY_SIZE_X/2; - float start_y = START_POS_Y; - float start_z = START_POS_Z - ARRAY_SIZE_Z/2; - - for (int k=0;ksetWorldTransform(startTransform); - - - m_dynamicsWorld->addRigidBody(body); - } - } - } - } - - - - - m_np->writeAllBodiesToGpu(); - m_bp->writeAabbsToGpu(); - m_rbp->writeAllInstancesToGpu(); - -} -void BasicGpuDemo::clientResetScene() -{ - /* - exitPhysics(); - initPhysics(); - */ - - - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj );//reset will take care of this - delete obj; - } - - //delete collision shapes - for (int j=0;jreset(); - - createObjects(); -} - - -void BasicGpuDemo::exitPhysics() -{ - - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - int i; - for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject( obj ); - delete obj; - } - - //delete collision shapes - for (int j=0;j m_collisionShapes; - - btBroadphaseInterface* m_broadphase; - - btCollisionDispatcher* m_dispatcher; - - btConstraintSolver* m_solver; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - - class b3GpuNarrowPhase* m_np; - class b3GpuSapBroadphase* m_bp; - class b3GpuRigidBodyPipeline* m_rbp; - - - - struct btInternalData* m_clData; - - void initCL(int d, int p); - void exitCL(); - - public: - - BasicGpuDemo(); - virtual ~BasicGpuDemo(); - - void initPhysics(); - - void exitPhysics(); - - void createObjects(); - - virtual void clientMoveAndDisplay(); - - virtual void displayCallback(); - virtual void clientResetScene(); - - static DemoApplication* Create() - { - BasicGpuDemo* demo = new BasicGpuDemo; - demo->myinit(); - demo->initPhysics(); - return demo; - } - - -}; - -#endif //GPU_BASIC_DEMO_H - diff --git a/Demos3/BasicGpuDemo/CMakeLists.txt b/Demos3/BasicGpuDemo/CMakeLists.txt deleted file mode 100644 index d17e7696a..000000000 --- a/Demos3/BasicGpuDemo/CMakeLists.txt +++ /dev/null @@ -1,69 +0,0 @@ -# This is basically the overall name of the project in Visual Studio this is the name of the Solution File - - -# For every executable you have with a main method you should have an add_executable line below. -# For every add executable line you should list every .cpp and .h file you have associated with that executable. - - -# This is the variable for Windows. I use this to define the root of my directory structure. -SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut) - -# You shouldn't have to modify anything below this line -######################################################## - -INCLUDE_DIRECTORIES( -${BULLET_PHYSICS_SOURCE_DIR}/src -${BULLET_PHYSICS_SOURCE_DIR}/ObsoleteDemos/OpenGL -) - - - -IF (USE_GLUT) - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - -IF (WIN32) -ADD_EXECUTABLE(AppBasicDemo - main.cpp - BasicDemo.cpp - BasicDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) -ELSE() - ADD_EXECUTABLE(AppBasicDemo - main.cpp - BasicDemo.cpp - BasicDemo.h - ) -ENDIF() - - - - -ELSE (USE_GLUT) - - - - LINK_LIBRARIES( - OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} - ) - - - ADD_EXECUTABLE(AppBasicDemo - WIN32 - ../OpenGL/Win32AppMain.cpp - Win32BasicDemo.cpp - BasicDemo.cpp - BasicDemo.h - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc - ) - - -ENDIF (USE_GLUT) - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) \ No newline at end of file diff --git a/Demos3/BasicGpuDemo/Makefile.am b/Demos3/BasicGpuDemo/Makefile.am deleted file mode 100644 index 05546162b..000000000 --- a/Demos3/BasicGpuDemo/Makefile.am +++ /dev/null @@ -1,5 +0,0 @@ -noinst_PROGRAMS=BasicDemo - -BasicDemo_SOURCES=BasicDemo.cpp BasicDemo.h main.cpp -BasicDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS) -BasicDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@ diff --git a/Demos3/BasicGpuDemo/Win32BasicDemo.cpp b/Demos3/BasicGpuDemo/Win32BasicDemo.cpp deleted file mode 100644 index 72f92a15f..000000000 --- a/Demos3/BasicGpuDemo/Win32BasicDemo.cpp +++ /dev/null @@ -1,25 +0,0 @@ -#ifdef _WINDOWS -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BasicDemo.h" - -///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo -DemoApplication* createDemo() -{ - return new BasicDemo(); -} - -#endif diff --git a/Demos3/BasicGpuDemo/b3GpuDynamicsWorld.cpp b/Demos3/BasicGpuDemo/b3GpuDynamicsWorld.cpp deleted file mode 100644 index faeb09f97..000000000 --- a/Demos3/BasicGpuDemo/b3GpuDynamicsWorld.cpp +++ /dev/null @@ -1,710 +0,0 @@ -#include "b3GpuDynamicsWorld.h" -#include "BulletDynamics/Dynamics/btRigidBody.h" - -//#include "../../../opencl/gpu_rigidbody_pipeline2/CLPhysicsDemo.h" -//#include "../../../opencl/gpu_rigidbody_pipeline/b3GpuNarrowPhaseAndSolver.h" -#include "BulletCollision/CollisionShapes/btPolyhedralConvexShape.h" -#include "BulletCollision/CollisionShapes/btBvhTriangleMeshShape.h" -#include "BulletCollision/CollisionShapes/btCompoundShape.h" -#include "BulletCollision/CollisionShapes/btSphereShape.h" -#include "BulletCollision/CollisionShapes/btStaticPlaneShape.h" -#include "BulletCollision/CollisionShapes/btConvexHullShape.h" -#include "BulletDynamics/ConstraintSolver/btPoint2PointConstraint.h" -#include "BulletDynamics/ConstraintSolver/btGeneric6DofConstraint.h" - -#include "LinearMath/btQuickprof.h" -//#include "Bullet3Common/b3Logging.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3Dynamics/ConstraintSolver/b3Point2PointConstraint.h" -#include "Bullet3Dynamics/ConstraintSolver/b3Generic6DofConstraint.h" - -#include "Bullet3Collision/NarrowPhaseCollision/b3RigidBodyCL.h" - - -#ifdef _WIN32 - #include -#endif - - -//#if (BT_BULLET_VERSION >= 282) -//#define BT_USE_BODY_UPDATE_REVISION -//#endif - - -b3GpuDynamicsWorld::b3GpuDynamicsWorld(class b3GpuSapBroadphase* bp,class b3GpuNarrowPhase* np, class b3GpuRigidBodyPipeline* rigidBodyPipeline) - :btDynamicsWorld(0,0,0), - m_gravity(0,-10,0), -m_cpuGpuSync(true), -m_bp(bp), -m_np(np), -m_rigidBodyPipeline(rigidBodyPipeline), -m_localTime(0.f), -m_staticBody(0) -{ - btConvexHullShape* nullShape = new btConvexHullShape(); - m_staticBody = new btRigidBody(0,0,nullShape); - addRigidBody(m_staticBody,0,0); -} - -b3GpuDynamicsWorld::~b3GpuDynamicsWorld() -{ - -} - - -#include - -int b3GpuDynamicsWorld::stepSimulation( btScalar timeStepUnused, int maxSubStepsUnused, btScalar fixedTimeStep) -{ - ///Don't use more than 1 simulation step, it destroys the performance having to copy the data between CPU and GPU multiple times per frame - ///Please use the CPU version in btDiscreteDynamicsWorld if you don't like this - - - CProfileManager::Reset(); - - BT_PROFILE("stepSimulation"); - - { - BT_PROFILE("sync constraints CPU"); - //todo: determine what data has changed, or perform copy on GPU? - for (int i=0;igetUserConstraintPtr(); - if (c) - { - switch (constraint->getConstraintType()) - { - case POINT2POINT_CONSTRAINT_TYPE: - { - btPoint2PointConstraint* p2 = (btPoint2PointConstraint*) constraint; - b3Point2PointConstraint* p3 = (b3Point2PointConstraint*) c; - p3->setPivotA((const b3Vector3&)p2->getPivotInA()); - p3->setPivotB((const b3Vector3&)p2->getPivotInB()); - p3->m_setting.m_damping = p2->m_setting.m_damping; - p3->m_setting.m_impulseClamp = p2->m_setting.m_impulseClamp; - p3->m_setting.m_tau = p2->m_setting.m_tau; - - break; - }; - - case D6_CONSTRAINT_TYPE: - { - btGeneric6DofConstraint* dof2 = (btGeneric6DofConstraint*) constraint; - b3Generic6DofConstraint* dof3 = (b3Generic6DofConstraint*) c; - const b3RigidBodyData* bodiesCL = m_np->getBodiesCpu(); - - b3Transform frameInA = (b3Transform&) dof2->getFrameOffsetA(); - b3Transform frameInB = (b3Transform&) dof2->getFrameOffsetB(); - dof3->setFrames(frameInA,frameInB,bodiesCL); - break; - } - - default: - { - } - }; - } - } - } - - // detect any change (very simple) - { - B3_PROFILE("body update revision detection (CPU)"); -#ifdef BT_USE_BODY_UPDATE_REVISION - b3Assert(m_bodyUpdateRevisions.size() == m_collisionObjects.size()); - b3Assert(m_np->getNumRigidBodies() == m_bodyUpdateRevisions.size()); -#endif //BT_USE_BODY_UPDATE_REVISION - - b3RigidBodyData* bodiesCL = (b3RigidBodyData*)m_np->getBodiesCpu(); - for (int i=0;im_collisionObjects.size();i++) - { - if (i>=m_np->getNumRigidBodies()) - { - b3Error("bodiesCL out-of-range\n"); - continue; - } - -#ifdef BT_USE_BODY_UPDATE_REVISION - if (m_bodyUpdateRevisions[i] != m_collisionObjects[i]->getUpdateRevisionInternal()) -#endif//BT_USE_BODY_UPDATE_REVISION - { - m_cpuGpuSync = true; - -#ifdef BT_USE_BODY_UPDATE_REVISION - m_bodyUpdateRevisions[i] = m_collisionObjects[i]->getUpdateRevisionInternal(); -#endif - - - btRigidBody* body = btRigidBody::upcast(m_collisionObjects[i]); - if (body) - { - b3Vector3 pos = (const b3Vector3&)m_collisionObjects[i]->getWorldTransform().getOrigin(); - btQuaternion orn2 = m_collisionObjects[i]->getWorldTransform().getRotation(); - b3Quaternion orn(orn2[0],orn2[1],orn2[2],orn2[3]); - body->integrateVelocities(fixedTimeStep); - m_np->setObjectTransformCpu(&pos[0],&orn[0],i); - b3Vector3 linVel = (const b3Vector3&)body->getLinearVelocity(); - b3Vector3 angVel = (const b3Vector3&)body->getAngularVelocity(); - m_np->setObjectVelocityCpu(&linVel[0],&angVel[0],i); - - - } - - } - } - } - - - - - if (m_cpuGpuSync) - { - BT_PROFILE("cpuGpuSync"); - m_cpuGpuSync = false; - m_np->writeAllBodiesToGpu(); - m_bp->writeAabbsToGpu(); - m_rigidBodyPipeline->writeAllInstancesToGpu(); - } - - - - //internalSingleStepSimulation(fixedTimeStep); - // dispatch preTick callback - if(0 != m_internalPreTickCallback) - { - BT_PROFILE("internalPreTickCallback"); - (*m_internalPreTickCallback)(this, fixedTimeStep); - } - - { - BT_PROFILE("m_rigidBodyPipeline->stepSimulation"); - m_rigidBodyPipeline->stepSimulation(fixedTimeStep); - } - - { - BT_PROFILE("readbackBodiesToCpu"); - //now copy info back to rigid bodies.... - m_np->readbackAllBodiesToCpu(); - } - - { - BT_PROFILE("scatter transforms into rigidbody (CPU)"); - - const b3RigidBodyData* bodiesCL = m_np->getBodiesCpu(); - - for (int i=0;im_collisionObjects.size();i++) - { - btVector3 pos; - btQuaternion orn; - if (m_np->getObjectTransformFromCpu(&pos[0],&orn[0],i)) - { - btTransform newTrans; - newTrans.setOrigin(pos); - newTrans.setRotation(orn); - - btCollisionObject* colObj = this->m_collisionObjects[i]; - colObj->setWorldTransform(newTrans); - - btRigidBody* body = btRigidBody::upcast(m_collisionObjects[i]); - if (body) - { - body->setLinearVelocity((btVector3&)bodiesCL[i].m_linVel); - body->setAngularVelocity((btVector3&)bodiesCL[i].m_angVel); - } - } - - -#ifdef BT_USE_BODY_UPDATE_REVISION - //ignore this revision update - m_bodyUpdateRevisions[i] = m_collisionObjects[i]->getUpdateRevisionInternal(); -#endif //BT_USE_BODY_UPDATE_REVISION - - } - - { - BT_PROFILE("synchronizeMotionStates"); - synchronizeMotionStates(); - } - } - - { - B3_PROFILE("clearForces"); - clearForces(); - } - -#ifndef BT_NO_PROFILE - CProfileManager::Increment_Frame_Counter(); -// CProfileManager::dumpAll(); -#endif //BT_NO_PROFILE - - - return 1; -} - - -void b3GpuDynamicsWorld::clearForces() -{ - ///@todo: iterate over awake simulation islands! - for ( int i=0;iclearForces(); - } -} - -void b3GpuDynamicsWorld::setGravity(const btVector3& gravity) -{ - m_gravity = gravity; - m_rigidBodyPipeline->setGravity(gravity); -} - -int b3GpuDynamicsWorld::findOrRegisterCollisionShape(const btCollisionShape* colShape) -{ - int index = m_uniqueShapes.findLinearSearch(colShape); - if (index==m_uniqueShapes.size()) - { - if (colShape->isPolyhedral()) - { - m_uniqueShapes.push_back(colShape); - - btPolyhedralConvexShape* convex = (btPolyhedralConvexShape*)colShape; - int numVertices=convex->getNumVertices(); - - int strideInBytes=sizeof(btVector3); - btAlignedObjectArray tmpVertices; - tmpVertices.resize(numVertices); - for (int i=0;igetVertex(i,tmpVertices[i]); - const float scaling[4]={1,1,1,1}; - //bool noHeightField=true; - - //int gpuShapeIndex = m_np->registerConvexHullShape(&tmpVertices[0].getX(), strideInBytes, numVertices, scaling); - const float* verts = numVertices? &tmpVertices[0].getX() : 0; - - int gpuShapeIndex = m_np->registerConvexHullShape(verts,strideInBytes, numVertices, scaling); - m_uniqueShapeMapping.push_back(gpuShapeIndex); - } else - { - if (colShape->getShapeType()==TRIANGLE_MESH_SHAPE_PROXYTYPE) - { - m_uniqueShapes.push_back(colShape); - - btBvhTriangleMeshShape* trimesh = (btBvhTriangleMeshShape*) colShape; - btStridingMeshInterface* meshInterface = trimesh->getMeshInterface(); - b3AlignedObjectArray vertices; - b3AlignedObjectArray indices; - - btVector3 trimeshScaling(1,1,1); - for (int partId=0;partIdgetNumSubParts();partId++) - { - - const unsigned char *vertexbase = 0; - int numverts = 0; - PHY_ScalarType type = PHY_INTEGER; - int stride = 0; - const unsigned char *indexbase = 0; - int indexstride = 0; - int numfaces = 0; - PHY_ScalarType indicestype = PHY_INTEGER; - //PHY_ScalarType indexType=0; - - b3Vector3 triangleVerts[3]; - meshInterface->getLockedReadOnlyVertexIndexBase(&vertexbase,numverts, type,stride,&indexbase,indexstride,numfaces,indicestype,partId); - btVector3 aabbMin,aabbMax; - - for (int triangleIndex = 0 ; triangleIndex < numfaces;triangleIndex++) - { - unsigned int* gfxbase = (unsigned int*)(indexbase+triangleIndex*indexstride); - - for (int j=2;j>=0;j--) - { - - int graphicsindex = indicestype==PHY_SHORT?((unsigned short*)gfxbase)[j]:gfxbase[j]; - if (type == PHY_FLOAT) - { - float* graphicsbase = (float*)(vertexbase+graphicsindex*stride); - triangleVerts[j] = b3MakeVector3( - graphicsbase[0]*trimeshScaling.getX(), - graphicsbase[1]*trimeshScaling.getY(), - graphicsbase[2]*trimeshScaling.getZ()); - } - else - { - double* graphicsbase = (double*)(vertexbase+graphicsindex*stride); - triangleVerts[j] = b3MakeVector3( btScalar(graphicsbase[0]*trimeshScaling.getX()), - btScalar(graphicsbase[1]*trimeshScaling.getY()), - btScalar(graphicsbase[2]*trimeshScaling.getZ())); - } - } - vertices.push_back(triangleVerts[0]); - vertices.push_back(triangleVerts[1]); - vertices.push_back(triangleVerts[2]); - indices.push_back(indices.size()); - indices.push_back(indices.size()); - indices.push_back(indices.size()); - } - } - //GraphicsShape* gfxShape = 0;//b3BulletDataExtractor::createGraphicsShapeFromWavefrontObj(objData); - - //GraphicsShape* gfxShape = b3BulletDataExtractor::createGraphicsShapeFromConvexHull(&sUnitSpherePoints[0],MY_UNITSPHERE_POINTS); - float meshScaling[4] = {1,1,1,1}; - //int shapeIndex = renderer.registerShape(gfxShape->m_vertices,gfxShape->m_numvertices,gfxShape->m_indices,gfxShape->m_numIndices); - //float groundPos[4] = {0,0,0,0}; - - //renderer.registerGraphicsInstance(shapeIndex,groundPos,rotOrn,color,meshScaling); - if (vertices.size() && indices.size()) - { - int gpuShapeIndex = m_np->registerConcaveMesh(&vertices,&indices, meshScaling); - m_uniqueShapeMapping.push_back(gpuShapeIndex); - } else - { - printf("Error: no vertices in mesh in b3GpuDynamicsWorld::addRigidBody\n"); - index = -1; - b3Assert(0); - } - - - } else - { - if (colShape->getShapeType()==COMPOUND_SHAPE_PROXYTYPE) - { - - btCompoundShape* compound = (btCompoundShape*) colShape; - b3AlignedObjectArray childShapes; - - for (int i=0;igetNumChildShapes();i++) - { - //for now, only support polyhedral child shapes - b3Assert(compound->getChildShape(i)->isPolyhedral()); - b3GpuChildShape child; - child.m_shapeIndex = findOrRegisterCollisionShape(compound->getChildShape(i)); - btVector3 pos = compound->getChildTransform(i).getOrigin(); - btQuaternion orn = compound->getChildTransform(i).getRotation(); - for (int v=0;v<4;v++) - { - child.m_childPosition[v] = pos[v]; - child.m_childOrientation[v] = orn[v]; - } - childShapes.push_back(child); - } - index = m_uniqueShapes.size(); - m_uniqueShapes.push_back(colShape); - - int gpuShapeIndex = m_np->registerCompoundShape(&childShapes); - m_uniqueShapeMapping.push_back(gpuShapeIndex); - - - - - /*printf("Error: unsupported compound type (%d) in b3GpuDynamicsWorld::addRigidBody\n",colShape->getShapeType()); - index = -1; - b3Assert(0); - */ - } else - { - if (colShape->getShapeType()==SPHERE_SHAPE_PROXYTYPE) - { - m_uniqueShapes.push_back(colShape); - btSphereShape* sphere = (btSphereShape*)colShape; - - int gpuShapeIndex = m_np->registerSphereShape(sphere->getRadius()); - m_uniqueShapeMapping.push_back(gpuShapeIndex); - } else - { - if (colShape->getShapeType()==STATIC_PLANE_PROXYTYPE) - { - m_uniqueShapes.push_back(colShape); - btStaticPlaneShape* plane = (btStaticPlaneShape*)colShape; - - int gpuShapeIndex = m_np->registerPlaneShape((b3Vector3&)plane->getPlaneNormal(),plane->getPlaneConstant()); - m_uniqueShapeMapping.push_back(gpuShapeIndex); - } else - { - printf("Error: unsupported shape type (%d) in b3GpuDynamicsWorld::addRigidBody\n",colShape->getShapeType()); - index = -1; - b3Assert(0); - } - } - } - } - } - - } - - return index; -} - -void b3GpuDynamicsWorld::addRigidBody(btRigidBody* body) -{ - m_cpuGpuSync = true; - //body->setMotionState(0); - - - int index = findOrRegisterCollisionShape(body->getCollisionShape()); - - if (index>=0) - { - int gpuShapeIndex= m_uniqueShapeMapping[index]; - float mass = body->getInvMass() ? 1.f/body->getInvMass() : 0.f; - btVector3 pos = body->getWorldTransform().getOrigin(); - btQuaternion orn = body->getWorldTransform().getRotation(); - - int bodyIndex = m_rigidBodyPipeline->registerPhysicsInstance(mass,&pos.getX(),&orn.getX(),gpuShapeIndex,m_collisionObjects.size(),false); - - body->setUserIndex(bodyIndex); - - m_collisionObjects.push_back(body); - m_bodyUpdateRevisions.push_back(-1); - } -} - -void b3GpuDynamicsWorld::removeRigidBody(btRigidBody* colObj) -{ - m_cpuGpuSync = true; - btDynamicsWorld::removeCollisionObject(colObj); - m_bodyUpdateRevisions.resize(this->m_collisionObjects.size()); - for (int i=0;igetUserIndex(); - - if (getNumCollisionObjects()==0) - { - m_uniqueShapes.resize(0); - m_uniqueShapeMapping.resize(0); - m_np->reset(); - m_bp->reset(); - m_rigidBodyPipeline->reset(); -#ifdef BT_USE_BODY_UPDATE_REVISION - m_bodyUpdateRevisions.resize(0); -#endif //BT_USE_BODY_UPDATE_REVISION - } - -} - - -void b3GpuDynamicsWorld::reset() -{ - m_staticBody = 0; - - if (m_collisionObjects.size()) - b3Warning("m_collisionObjects should be empty before calling b3GpuDynamicsWorld::reset"); - m_collisionObjects.clear(); - if (m_bodyUpdateRevisions.size()) - b3Warning("world (m_bodyUpdateRevisions) should be empty before calling b3GpuDynamicsWorld::reset"); - m_bodyUpdateRevisions.clear(); - - if (m_constraints.size()) - b3Warning("m_constraints should be empty before calling b3GpuDynamicsWorld::reset"); - m_constraints.clear(); - - - m_uniqueShapes.resize(0); - m_uniqueShapeMapping.resize(0); - m_np->reset(); - m_bp->reset(); - m_rigidBodyPipeline->reset(); -#ifdef BT_USE_BODY_UPDATE_REVISION - m_bodyUpdateRevisions.resize(0); -#endif - - btConvexHullShape* nullShape = new btConvexHullShape(); - m_staticBody = new btRigidBody(0,0,nullShape); - addRigidBody(m_staticBody,0,0); -} - -void b3GpuDynamicsWorld::removeCollisionObject(btCollisionObject* colObj) -{ - m_cpuGpuSync = true; - btDynamicsWorld::removeCollisionObject(colObj); - m_bodyUpdateRevisions.resize(this->m_collisionObjects.size()); - for (int i=0;i rays; - b3RayInfo ray; - ray.m_from = (const b3Vector3&)rayFromWorld; - ray.m_to = (const b3Vector3&)rayToWorld; - rays.push_back(ray); - - b3AlignedObjectArray hitResults; - b3RayHit hit; - hit.m_hitFraction = 1.f; - - hitResults.push_back(hit); - - m_rigidBodyPipeline->castRays(rays,hitResults); - b3Printf("hit = %f\n", hitResults[0].m_hitFraction); - if (hitResults[0].m_hitFraction<1.f) - { - b3Assert(hitResults[0].m_hitBody >=0); - b3Assert(hitResults[0].m_hitBody < m_collisionObjects.size()); - b3Vector3 hitNormalLocal = hitResults[0].m_hitNormal; - btCollisionObject* colObj = m_collisionObjects[hitResults[0].m_hitBody]; - LocalRayResult rayResult(colObj,0,(btVector3&)hitNormalLocal,hitResults[0].m_hitFraction); - rayResult.m_hitFraction = hitResults[0].m_hitFraction; - - resultCallback.addSingleResult(rayResult,true); - } - - -} - -void b3GpuDynamicsWorld::synchronizeMotionStates() -{ - //iterate over all collision objects - for ( int i=0;igetMotionState() && !body->isStaticOrKinematicObject()) - { - //we need to call the update at least once, even for sleeping objects - //otherwise the 'graphics' transform never updates properly - const btTransform& centerOfMassWorldTrans = body->getWorldTransform(); - body->getMotionState()->setWorldTransform(centerOfMassWorldTrans); - } -} - -void b3GpuDynamicsWorld::debugDrawWorld() -{ - BT_PROFILE("debugDrawWorld"); - - btCollisionWorld::debugDrawWorld(); -} - -void b3GpuDynamicsWorld::addConstraint(btTypedConstraint* constraint, bool disableCollisionsBetweenLinkedBodies) -{ - constraint->setUserConstraintPtr(0); - - m_constraints.push_back(constraint); - - switch (constraint->getConstraintType()) - { - case POINT2POINT_CONSTRAINT_TYPE: - { - btPoint2PointConstraint* p = (btPoint2PointConstraint*) constraint; - int rbA = p->getRigidBodyA().getUserIndex(); - int rbB = p->getRigidBodyB().getUserIndex(); - btVector3 pivotInB = p->getPivotInB(); - if (rbB<=0) - { - pivotInB = p->getRigidBodyA().getWorldTransform()*p->getPivotInA(); - rbB = m_staticBody->getUserIndex(); - } - if (rbA>=0 && rbB>=0) - { - b3Point2PointConstraint* p2p = new b3Point2PointConstraint(rbA,rbB, (const b3Vector3&)p->getPivotInA(),(const b3Vector3&)pivotInB); - p2p->setBreakingImpulseThreshold(p->getBreakingImpulseThreshold()); - constraint->setUserConstraintPtr(p2p); - m_rigidBodyPipeline->addConstraint(p2p); - } else - { - b3Error("invalid body index in addConstraint,b3Point2PointConstraint\n"); - } - break; - } - case D6_CONSTRAINT_TYPE: - { - btGeneric6DofConstraint* dof2 = (btGeneric6DofConstraint*) constraint; - const b3RigidBodyData* bodiesCL = m_np->getBodiesCpu(); - - int rbA = dof2->getRigidBodyA().getUserIndex(); - int rbB = dof2->getRigidBodyB().getUserIndex(); - - btTransform frameInA = dof2->getFrameOffsetB(); - btTransform frameInB = dof2->getFrameOffsetB(); - - if (rbA<=0) - { - frameInA = dof2->getRigidBodyB().getWorldTransform()*dof2->getFrameOffsetB(); - rbA = m_staticBody->getUserIndex(); - } - - if (rbB<=0) - { - frameInB = dof2->getRigidBodyA().getWorldTransform()*dof2->getFrameOffsetA(); - rbB = m_staticBody->getUserIndex(); - } - if (rbA>=0 && rbB>=0) - { - b3Generic6DofConstraint* dof3 = new b3Generic6DofConstraint(rbA,rbB,(b3Transform&)frameInA,(b3Transform&)frameInB,false,bodiesCL);//(();//(rbA,rbB, (const b3Vector3&)p->getPivotInA(),(const b3Vector3&)pivotInB); - { - btVector3 limit(0,0,0); - dof2->getLinearLowerLimit(limit); - dof3->setLinearLowerLimit((const b3Vector3&)limit); - - dof2->setLinearUpperLimit(limit); - dof3->setLinearUpperLimit((const b3Vector3&)limit); - - dof2->setAngularLowerLimit(limit); - dof3->setAngularLowerLimit((const b3Vector3&)limit); - - dof2->setAngularUpperLimit(limit); - dof3->setAngularUpperLimit((const b3Vector3&)limit); - /* for (int i=0;i<6;i++) - { - dof3->setParam(BT_CONSTRAINT_STOP_CFM,dof2->getParam(BT_CONSTRAINT_STOP_CFM,i),i); - dof3->setParam(BT_CONSTRAINT_STOP_ERP,dof2->getParam(BT_CONSTRAINT_STOP_ERP,i),i); - } - */ - dof3->setBreakingImpulseThreshold(dof2->getBreakingImpulseThreshold()); - } -// p2p->setBreakingImpulseThreshold(p->getBreakingImpulseThreshold()); - constraint->setUserConstraintPtr(dof3); - m_rigidBodyPipeline->addConstraint(dof3); - } else - { - b3Error("invalid body index in addConstraint, btGeneric6DofConstraint.\n"); - } - -// b3Generic6DofConstraint - break; - } - default: - b3Warning("Warning: b3GpuDynamicsWorld::addConstraint with unsupported constraint type\n"); - }; - - -} - -void b3GpuDynamicsWorld::removeConstraint(btTypedConstraint* constraint) -{ - b3TypedConstraint* c = (b3TypedConstraint*) constraint->getUserConstraintPtr(); - - if (c) - { - this->m_rigidBodyPipeline->removeConstraint(c); - delete c; - } - m_constraints.remove(constraint); -} - diff --git a/Demos3/BasicGpuDemo/b3GpuDynamicsWorld.h b/Demos3/BasicGpuDemo/b3GpuDynamicsWorld.h deleted file mode 100644 index 03a4a3386..000000000 --- a/Demos3/BasicGpuDemo/b3GpuDynamicsWorld.h +++ /dev/null @@ -1,113 +0,0 @@ -#ifndef B3_GPU_DYNAMICS_WORLD_H -#define B3_GPU_DYNAMICS_WORLD_H - -#include "LinearMath/btVector3.h" - -class btRigidBody; -class btCollisionObject; -struct b3GpuInternalData;//use this struct to avoid 'leaking' all OpenCL headers into clients code base -class CLPhysicsDemo; -class btActionInterface; -class btTypedConstraint; - -#include "LinearMath/btAlignedObjectArray.h" -#include "BulletDynamics/Dynamics/btDynamicsWorld.h" -#include "Bullet3Common/b3Logging.h" - - -class b3GpuDynamicsWorld : public btDynamicsWorld -{ - - btAlignedObjectArray m_uniqueShapes; - btAlignedObjectArray m_uniqueShapeMapping; - btAlignedObjectArray m_constraints; - btAlignedObjectArray m_bodyUpdateRevisions; - class b3GpuRigidBodyPipeline* m_rigidBodyPipeline; - class b3GpuNarrowPhase* m_np; - class b3GpuSapBroadphase* m_bp; - - - btVector3 m_gravity; - bool m_cpuGpuSync; - float m_localTime; - class btRigidBody* m_staticBody;//used for picking and Bullet 2.x compatibility. In Bullet 3.x all constraints have explicitly 2 bodies. - int findOrRegisterCollisionShape(const btCollisionShape* colShape); - - - -public: - b3GpuDynamicsWorld(class b3GpuSapBroadphase* bp,class b3GpuNarrowPhase* np, class b3GpuRigidBodyPipeline* rigidBodyPipeline); - - virtual ~b3GpuDynamicsWorld(); - - virtual int stepSimulation( btScalar timeStep,int maxSubSteps=1, btScalar fixedTimeStep=btScalar(1.)/btScalar(60.)); - - virtual void synchronizeMotionStates(); - - - void debugDrawWorld(); - - void setGravity(const btVector3& gravity); - - void addRigidBody(btRigidBody* body); - - void removeCollisionObject(btCollisionObject* colObj); - - virtual void removeRigidBody(btRigidBody* body); - - virtual void addConstraint(btTypedConstraint* constraint, bool disableCollisionsBetweenLinkedBodies=false); - - virtual void removeConstraint(btTypedConstraint* constraint); - void rayTest(const btVector3& rayFromWorld, const btVector3& rayToWorld, RayResultCallback& resultCallback) const; - - btAlignedObjectArray& getCollisionObjectArray(); - - const btAlignedObjectArray& getCollisionObjectArray() const; - - - btVector3 getGravity () const - { - return m_gravity; - } - - virtual void addRigidBody(btRigidBody* body, short group, short mask) - { - addRigidBody(body); - } - - virtual void addAction(btActionInterface* action) - { - btAssert(0); - } - - virtual void removeAction(btActionInterface* action) - { - btAssert(0); - } - - virtual void setConstraintSolver(btConstraintSolver* solver) - { - btAssert(0); - } - - virtual btConstraintSolver* getConstraintSolver() - { - btAssert(0); - return 0; - } - - - virtual void clearForces(); - - virtual btDynamicsWorldType getWorldType() const - { - return BT_GPU_DYNAMICS_WORLD; - } - - ///this can be useful to synchronize a single rigid body -> graphics object - void synchronizeSingleMotionState(btRigidBody* body); - - void reset(); -}; - -#endif //B3_GPU_DYNAMICS_WORLD_H diff --git a/Demos3/BasicGpuDemo/main.cpp b/Demos3/BasicGpuDemo/main.cpp deleted file mode 100644 index 7559a36a7..000000000 --- a/Demos3/BasicGpuDemo/main.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/ - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "BasicGpuDemo.h" -#include "GlutStuff.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btHashMap.h" - - - -int main(int argc,char** argv) -{ - - BasicGpuDemo ccdDemo; - ccdDemo.initPhysics(); - - -#ifdef CHECK_MEMORY_LEAKS - ccdDemo.exitPhysics(); -#else - return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&ccdDemo); -#endif - - //default glut doesn't return from mainloop - return 0; -} - diff --git a/Demos3/CMakeLists.txt b/Demos3/CMakeLists.txt deleted file mode 100644 index 21d271b99..000000000 --- a/Demos3/CMakeLists.txt +++ /dev/null @@ -1,5 +0,0 @@ -if (OPENGL_FOUND) -if (BUILD_OPENGL3_DEMOS) - SUBDIRS( AllBullet2Demos GpuDemos SimpleOpenGL3 ) -endif(BUILD_OPENGL3_DEMOS) -endif(OPENGL_FOUND) diff --git a/Demos3/CpuDemos/CpuDemo.h b/Demos3/CpuDemos/CpuDemo.h deleted file mode 100644 index e0637f7fd..000000000 --- a/Demos3/CpuDemos/CpuDemo.h +++ /dev/null @@ -1,59 +0,0 @@ - -#ifndef CPU_DEMO_H -#define CPU_DEMO_H - -struct GLInstancingRenderer; -struct GwenUserInterface; - -struct CpuDemo -{ - - struct ConstructionInfo - { - bool m_useInstancedCollisionShapes; - GLInstancingRenderer* m_instancingRenderer; - struct GLPrimitiveRenderer* m_primRenderer; - - class b3gWindowInterface* m_window; - class GwenUserInterface* m_gui; - - ConstructionInfo() - :m_useInstancedCollisionShapes(true), - m_instancingRenderer(0), - m_window(0), - m_gui(0) - { - } - }; - - - virtual void initPhysics(const ConstructionInfo& ci)=0; - - virtual void exitPhysics()=0; - - virtual void renderScene()=0; - - virtual void clientMoveAndDisplay()=0; - - - virtual const char* getName() { - return ""; - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - - typedef class CpuDemo* (CreateFunc)(); -}; - -#endif //CPU_DEMO_H - diff --git a/Demos3/CpuDemos/deformable/CpuSoftBodyDemo.cpp b/Demos3/CpuDemos/deformable/CpuSoftBodyDemo.cpp deleted file mode 100644 index 208c9131a..000000000 --- a/Demos3/CpuDemos/deformable/CpuSoftBodyDemo.cpp +++ /dev/null @@ -1,469 +0,0 @@ -#include "CpuSoftBodyDemo.h" -#include "OpenGLWindow/ShapeData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" - - -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" - -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "CpuSoftBodyDemoInternalData.h" -#include "Bullet3Collision/BroadPhaseCollision/b3DynamicBvhBroadphase.h" -#include "stb_image/stb_image.h" -#include "CpuSoftClothDemoInternalData.h" - -#include "ExplicitEuler.h" -#include "PositionBasedDynamics.h" - -static b3KeyboardCallback oldCallback = 0; -extern bool gReset; - -float clothWidth = 4; -float clothHeight= 4; - -int width = 64; -int height = 64; - -int numPoints = width*height; -float clothMass = 100.f; - - - -CpuSoftBodyDemo::CpuSoftBodyDemo() -:m_instancingRenderer(0), -m_window(0) -{ - m_data = new CpuSoftBodyDemoInternalData; -} -CpuSoftBodyDemo::~CpuSoftBodyDemo() -{ - - delete m_data; -} - - - - - - - -static void PairKeyboardCallback(int key, int state) -{ - if (key=='R' && state) - { - gReset = true; - } - - //b3DefaultKeyboardCallback(key,state); - oldCallback(key,state); -} - -void CpuSoftBodyDemo::setupScene(const ConstructionInfo& ci) -{ - -} - -void CpuSoftBodyDemo::initPhysics(const ConstructionInfo& ci) -{ - - GLint err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - if (ci.m_window) - { - m_window = ci.m_window; - oldCallback = ci.m_window->getKeyboardCallback(); - ci.m_window->setKeyboardCallback(PairKeyboardCallback); - - } - - m_instancingRenderer = ci.m_instancingRenderer; - - - - setupScene(ci); - - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - - - m_instancingRenderer->writeTransforms(); - -} - -void CpuSoftBodyDemo::exitPhysics() -{ - - m_window->setKeyboardCallback(oldCallback); - -} - - -#include "Bullet3Common/shared/b3Float4.h" - -struct GraphicsVertex -{ - float pos[4]; - float normal[3]; - float texcoord[2]; -}; - - - -void CpuSoftClothDemo::renderScene() -{ - //wireframe - bool wireframe=false; - if (wireframe) - { - m_instancingRenderer->init(); - m_instancingRenderer->updateCamera(); - m_instancingRenderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(1,0,0),b3MakeVector3(1,0,0,1),1); - m_instancingRenderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(0,1,0),b3MakeVector3(0,1,0,1),1); - m_instancingRenderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(0,0,1),b3MakeVector3(0,0,1,1),1); - - float color[4]={1,0,0,1}; - m_instancingRenderer->drawPoints(m_data->m_clothVertices,color,numPoints,sizeof(GraphicsVertex),2); - } else - { - m_instancingRenderer->renderScene(); - } - -} -void CpuSoftBodyDemo::renderScene() -{ - m_instancingRenderer->renderScene(); -} - -void CpuSoftBodyDemo::clientMoveAndDisplay() -{ - GLint err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - - -} - - -void CpuSoftClothDemo::clientMoveAndDisplay() -{ - if (m_data->m_clothShapeIndex>=0 && m_data->m_clothVertices) - { - - float deltaTime = 1./100.;//1./60.f; - //float deltaTime = 1./60.f; - - //write positions - int vertexStride =sizeof(GraphicsVertex);//9 * sizeof(float); - - int method = 1; - switch (method) - { - case 0: - ExplicitEuler::solveConstraints(m_clothData, (char*)m_data->m_clothVertices, vertexStride, deltaTime); - break; - case 1: - PositionBasedDynamics::solveConstraints(m_clothData, (char*)m_data->m_clothVertices, vertexStride, deltaTime); - break; - default: - b3Error("unknown method for CpuSoftClothDemo::solveConstraints"); - }; - - //read positions - - m_instancingRenderer->updateShape(m_data->m_clothShapeIndex,m_data->m_clothVertices); - } -} - -CpuSoftClothDemo::CpuSoftClothDemo() -{ - m_clothData = new CpuSoftClothDemoInternalData(); - -} -CpuSoftClothDemo::~CpuSoftClothDemo() -{ - delete m_clothData; -} - - -unsigned char* CpuSoftClothDemo::loadImage(const char* fileName, int& width, int& height, int& n) -{ - unsigned char *data = stbi_load(fileName, &width, &height, &n, 0); - if (data) - { - GLubyte* image=new GLubyte[512*256*4]; - for(int y=0;y<256;++y) - { - const int t=y>>4; - GLubyte* pi=image+y*512*3; - for(int x=0;x<512;++x) - { - const int s=x>>5; - const GLubyte b=180; - GLubyte c=b+((s+t&1)&1)*(255-b); - pi[0]=pi[1]=pi[2]=c;pi+=3; - } - } - - { - - for (int i=0;iregisterShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - b3Vector3 position = b3MakeVector3(0,-50,0);//((j+1)&1)+i*2.2,1+j*2.,((j+1)&1)+k*2.2); - b3Quaternion orn(0,0,0,1); - b3Vector4 scaling=b3MakeVector4(100,1,100,1); - float color[4]={0.8,0.8,0.8,1}; - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - - } - - - GraphicsVertex* cpu_buffer = new GraphicsVertex[width*height]; - memset(cpu_buffer, 0, width*height*sizeof(GraphicsVertex)); - - - int numVertices = 0; - // Initial test data for rendering - for(int y = 0; y < height; y++) - { - for(int x = 0; x < width; x++) - { - float posX = (x/((float)(width-1)))*(clothWidth); - float posZ = ((y-height/2.f)/((float)(height-1)))*(clothHeight); - - cpu_buffer[y*width+x].pos[0] = 0; - cpu_buffer[y*width+x].pos[1] = -posX; - cpu_buffer[y*width+x].pos[2] = posZ; - cpu_buffer[y*width+x].pos[3] = 0.f; - - cpu_buffer[y*width+x].normal[0] = 1; - cpu_buffer[y*width+x].normal[1] = 0; - cpu_buffer[y*width+x].normal[2] = 0; - cpu_buffer[y*width+x].texcoord[0] = 1*x/((float)(width-1)); - cpu_buffer[y*width+x].texcoord[1] = (1.f-4*y/((float)(height-1))); - numVertices++; - } - } - - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - int numIndices = 0; - - // Generate and fill index array for rendering - int* indices = new int[width*3*2+2 + height*width*3*2]; - - for(int y = 0; y < height-1; y++) - { - for(int x = 0; x < width-1; x++) - { - // *3 indices/triangle, *2 triangles/quad - int baseIndex = (x + y*(width-1))*3*2; - indices[baseIndex] = x + y*width; - indices[baseIndex+1] = x+1 + y*width; - indices[baseIndex+2] = x+width + y*width; - - - indices[baseIndex+3] = x + 1 + y*width; - indices[baseIndex+4] = x+(width+1) + y*width; - indices[baseIndex+5] = x+width + y*width; - numIndices+=6; - - } - } - - - int num_barrel_vertices = sizeof(barrel_vertices)/(9*sizeof(float)); - int num_barrel_indices = sizeof(barrel_indices)/sizeof(int); - - int textureIndex = -1; - { - int width,height,n; - FILE* f = fopen("test.tst","wb"); - fclose(f); - const char* filename = "data/bullet_logo.png"; - const unsigned char* image=0; - - const char* prefix[]={"./","../","../../","../../../","../../../../"}; - int numprefix = sizeof(prefix)/sizeof(const char*); - - for (int i=0;!image && iregisterTexture(image,width,height); - } - } -// int shapeIndex = ci.m_instancingRenderer->registerShape(barrel_vertices,num_barrel_vertices,barrel_indices,num_barrel_indices); - - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - m_data->m_clothVertices = &cpu_buffer[0].pos[0]; - - int shapeIndex = ci.m_instancingRenderer->registerShape(&cpu_buffer[0].pos[0],numVertices,indices,numIndices,B3_GL_TRIANGLES,textureIndex); - m_data->m_clothShapeIndex = shapeIndex; - - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - - float pos[4] = {0,0,0,0}; - float orn[4] = {0,0,0,1}; - float color[4] = {1,1,1,1}; - float scaling[4] = {10,10,10,1}; - - ci.m_instancingRenderer->registerGraphicsInstance(shapeIndex,pos,orn,color,scaling); - ci.m_instancingRenderer->setCameraDistance(24); - ci.m_instancingRenderer->setCameraTargetPosition(pos); - - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - - - int numParticles = width*height; - - m_clothData->m_forces.resize(numParticles); - m_clothData->m_velocities.resize(numParticles); - m_clothData->m_particleMasses.resize(numParticles); - - - - for(int y = 0; y < height; y++) - { - for(int x = 0; x < width; x++) - { - float mass = clothMass/numParticles; - if (x==0 && y==(height-1)) - mass=0.f; - if (x==0 && y==0) - mass=0.f; - int index = x+width*y; - - m_clothData->m_particleMasses[index] = mass; - } - } - - - ClothMaterial mat; - mat.m_stiffness = 0.5; - mat.m_damping = -0.25; - - m_clothData->m_materials.push_back(mat); - - - //add springs - for (int x=0;xm_springs.push_back(spring); - - } - } - - for (int x=0;xm_springs.push_back(spring); - } - } - - for (int x=0;xm_springs.push_back(spring); - } - - { - ClothSpring spring; - int indexA = x+1+y*width; - int indexB = (x)+(y+1)*width; - spring.m_particleIndexA = indexA; - spring.m_particleIndexB = indexB; - spring.m_material = 0; - const b3Vector3& posA = (const b3Vector3&) cpu_buffer[indexA].pos; - const b3Vector3& posB = (const b3Vector3&) cpu_buffer[indexB].pos; - spring.m_restLength = (posA-posB).length(); - m_clothData->m_springs.push_back(spring); - } - - } - } - - -} \ No newline at end of file diff --git a/Demos3/CpuDemos/deformable/CpuSoftBodyDemo.h b/Demos3/CpuDemos/deformable/CpuSoftBodyDemo.h deleted file mode 100644 index 0fe89f137..000000000 --- a/Demos3/CpuDemos/deformable/CpuSoftBodyDemo.h +++ /dev/null @@ -1,79 +0,0 @@ -#ifndef CPU_SOFT_BODY_DEMO_H -#define CPU_SOFT_BODY_DEMO_H - -#include "../CpuDemo.h" - -class CpuSoftBodyDemo : public CpuDemo -{ -protected: - class GLInstancingRenderer* m_instancingRenderer; - class b3gWindowInterface* m_window; - - struct CpuSoftBodyDemoInternalData* m_data; - -public: - - CpuSoftBodyDemo(); - virtual ~CpuSoftBodyDemo(); - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void destroyScene(){}; - - virtual void exitPhysics(); - - virtual const char* getName() - { - return "CPUSOFT"; - } - static CpuDemo* MyCreateFunc() - { - CpuDemo* demo = new CpuSoftBodyDemo; - return demo; - } - - virtual void renderScene(); - - - - virtual void clientMoveAndDisplay(); - - -}; - -class CpuSoftClothDemo : public CpuSoftBodyDemo -{ -protected: - - struct CpuSoftClothDemoInternalData* m_clothData; - -public: - CpuSoftClothDemo(); - virtual ~CpuSoftClothDemo(); - - unsigned char* loadImage(const char* fileName, int& width, int& height, int& n); - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void renderScene(); - - virtual const char* getName() - { - return "CpuSoftCloth"; - } - - - virtual void clientMoveAndDisplay(); - - static CpuDemo* MyCreateFunc() - { - CpuDemo* demo = new CpuSoftClothDemo; - return demo; - } - -}; - -#endif //CPU_SOFT_BODY_DEMO_H - diff --git a/Demos3/CpuDemos/deformable/CpuSoftBodyDemoInternalData.h b/Demos3/CpuDemos/deformable/CpuSoftBodyDemoInternalData.h deleted file mode 100644 index a3ac757a0..000000000 --- a/Demos3/CpuDemos/deformable/CpuSoftBodyDemoInternalData.h +++ /dev/null @@ -1,21 +0,0 @@ -#ifndef CPU_SOFTBODY_INTERNAL_DATA_H -#define CPU_SOFTBODY_INTERNAL_DATA_H - -//#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" - -#include "Bullet3Common/b3Vector3.h" - -struct CpuSoftBodyDemoInternalData -{ - int m_clothShapeIndex; - float* m_clothVertices; - - CpuSoftBodyDemoInternalData() - : m_clothShapeIndex(-1), - m_clothVertices(0) - { - } -}; - -#endif//CPU_SOFTBODY_INTERNAL_DATA_H - diff --git a/Demos3/CpuDemos/deformable/CpuSoftClothDemoInternalData.h b/Demos3/CpuDemos/deformable/CpuSoftClothDemoInternalData.h deleted file mode 100644 index 3b1400bbd..000000000 --- a/Demos3/CpuDemos/deformable/CpuSoftClothDemoInternalData.h +++ /dev/null @@ -1,31 +0,0 @@ -#ifndef CPU_SOFTCLOTH_INTERNAL_DATA_H -#define CPU_SOFTCLOTH_INTERNAL_DATA_H - -#include "Bullet3Common/b3AlignedObjectArray.h" -#include "Bullet3Common/b3Vector3.h" - -struct ClothSpring -{ - int m_particleIndexA; - int m_particleIndexB; - float m_restLength; - int m_material; -}; - -struct ClothMaterial -{ - float m_stiffness; - float m_damping; -}; - -struct CpuSoftClothDemoInternalData -{ - b3AlignedObjectArray m_springs; - b3AlignedObjectArray m_materials; - b3AlignedObjectArray m_velocities; - b3AlignedObjectArray m_forces; - b3AlignedObjectArray m_particleMasses; -}; - -#endif //CPU_SOFTCLOTH_INTERNAL_DATA_H - diff --git a/Demos3/CpuDemos/deformable/ExplicitEuler.cpp b/Demos3/CpuDemos/deformable/ExplicitEuler.cpp deleted file mode 100644 index cab093921..000000000 --- a/Demos3/CpuDemos/deformable/ExplicitEuler.cpp +++ /dev/null @@ -1,105 +0,0 @@ -#include "ExplicitEuler.h" - -#include "CpuSoftClothDemoInternalData.h" - - - - - -void ExplicitEuler::computeGravityForces(struct CpuSoftClothDemoInternalData* clothData, char* vertexPositions, int vertexStride, float dt) -{ - - B3_PROFILE("computeForces"); - int numPoints = clothData->m_particleMasses.size(); - - b3Vector3 gravityAcceleration = b3MakeVector3(0,-9.8,0); - //f=m*a - for (int i=0;im_particleMasses[i]; - - b3Vector3 particleMassVec = b3MakeVector3(particleMass,particleMass,particleMass,0); - clothData->m_forces[i] = gravityAcceleration*particleMass; - } - } - -} - -void ExplicitEuler::computeSpringForces(struct CpuSoftClothDemoInternalData* clothData, char* vertexPositions, int vertexStride, float dt) -{ - - //add spring forces - for(int i=0;im_springs.size();i++) - { - - int indexA = clothData->m_springs[i].m_particleIndexA; - int indexB = clothData->m_springs[i].m_particleIndexB; - float restLength = clothData->m_springs[i].m_restLength; - const ClothMaterial& mat = clothData->m_materials[clothData->m_springs[i].m_material]; - - const b3Vector3& posA = (const b3Vector3&)vertexPositions[indexA*vertexStride]; - const b3Vector3& posB = (const b3Vector3&)vertexPositions[indexB*vertexStride]; - const b3Vector3& velA = clothData->m_velocities[indexA]; - const b3Vector3& velB = clothData->m_velocities[indexB]; - - b3Vector3 deltaP = posA-posB; - b3Vector3 deltaV = velA-velB; - float dist = deltaP.length(); - b3Vector3 deltaPNormalized = deltaP/dist; - - float spring = -mat.m_stiffness * (dist-restLength)*100000; - float damper = mat.m_damping * b3Dot(deltaV,deltaPNormalized)*100; - - b3Vector3 springForce = (spring+damper)*deltaPNormalized; - float particleMassA = clothData->m_particleMasses[indexA]; - float particleMassB = clothData->m_particleMasses[indexB]; - - //if (springForce.length()) - { - if (particleMassA) - { - clothData->m_forces[indexA] += springForce*particleMassA; - } - - if (particleMassB) - { - clothData->m_forces[indexB] -= springForce*particleMassB; - } - } - } -} -void ExplicitEuler::integrateExplicitEuler(struct CpuSoftClothDemoInternalData* clothData, char* vertexPositions, int vertexStride,float deltaTime) -{ - B3_PROFILE("integrateEuler"); - b3Vector3 deltaTimeVec = b3MakeVector3(deltaTime,deltaTime,deltaTime,0); - - int numPoints = clothData->m_particleMasses.size(); - - for (int i=0;im_particleMasses[i]; - if (mass) - { - - - - b3Vector3 dv = (clothData->m_forces[i]/mass)*deltaTimeVec; - clothData->m_velocities[i]+= dv; - clothData->m_velocities[i]*=0.999; - - b3Vector3& pos = (b3Vector3&)vertexPositions[i*vertexStride]; - - pos += clothData->m_velocities[i]*deltaTimeVec; - } - } - -} - -void ExplicitEuler::solveConstraints(struct CpuSoftClothDemoInternalData* data, char* vertexPositions, int vertexStride,float deltaTime) -{ - computeGravityForces(data,vertexPositions,vertexStride,deltaTime); - computeSpringForces(data,vertexPositions,vertexStride,deltaTime); - - integrateExplicitEuler(data,vertexPositions,vertexStride,deltaTime); -} \ No newline at end of file diff --git a/Demos3/CpuDemos/deformable/ExplicitEuler.h b/Demos3/CpuDemos/deformable/ExplicitEuler.h deleted file mode 100644 index 631320993..000000000 --- a/Demos3/CpuDemos/deformable/ExplicitEuler.h +++ /dev/null @@ -1,16 +0,0 @@ - -#ifndef EXPLICIT_EULER_H -#define EXPLICIT_EULER_H - -struct ExplicitEuler -{ - static void computeGravityForces(struct CpuSoftClothDemoInternalData* clothData, char* vtx, int vertexStride, float dt); - static void computeSpringForces(struct CpuSoftClothDemoInternalData* clothData, char* vertexPositions, int vertexStride, float dt); - - static void integrateExplicitEuler(struct CpuSoftClothDemoInternalData* clothData, char* vtx, int vertexStride,float dt); - - static void solveConstraints(struct CpuSoftClothDemoInternalData* clothData, char* vtx, int vertexStride,float dt); - -}; - -#endif //EXPLICIT_EULER_H \ No newline at end of file diff --git a/Demos3/CpuDemos/deformable/PositionBasedDynamics.cpp b/Demos3/CpuDemos/deformable/PositionBasedDynamics.cpp deleted file mode 100644 index 84dea8eb6..000000000 --- a/Demos3/CpuDemos/deformable/PositionBasedDynamics.cpp +++ /dev/null @@ -1,72 +0,0 @@ - -#include "PositionBasedDynamics.h" -#include "CpuSoftClothDemoInternalData.h" -#include "ExplicitEuler.h" - -void PositionBasedDynamics::solveLinks(struct CpuSoftClothDemoInternalData* clothData, char* vertexPositions, int vertexStride,float dt) -{ - float kst = 1.f; - float kLST = 1.f;//0.8f; - float damping = 0.999; - int numPoints = clothData->m_particleMasses.size(); - - b3AlignedObjectArray startPositions; - - startPositions.resize(numPoints); - for (int i=0;im_springs.size();i++) - { - ClothSpring& link=clothData->m_springs[i]; - //if(l.m_c0>0)//avoid links between two particles with mass==0 - { - - float invMassA = clothData->m_particleMasses[link.m_particleIndexA]? 1.f/clothData->m_particleMasses[link.m_particleIndexA] : 0.f; - float invMassB = clothData->m_particleMasses[link.m_particleIndexB]? 1.f/clothData->m_particleMasses[link.m_particleIndexB] : 0.f; - - float m_c0 = (invMassA+invMassB)*kLST; - float m_c1 = link.m_restLength*link.m_restLength; - - b3Vector3& posA = (b3Vector3&)vertexPositions[link.m_particleIndexA*vertexStride]; - b3Vector3& posB = (b3Vector3&)vertexPositions[link.m_particleIndexB*vertexStride]; - - const b3Vector3 del=posB-posA; - const float len=del.length2(); - if (m_c1+len > B3_EPSILON) - { - const float k=((m_c1-len)/(m_c0*(m_c1+len)))*kst; - posA-=del*(k*invMassA); - posB+=del*(k*invMassB); - } - } - } - - - - //adjust velocity - for (int i=0;im_velocities[i]+=(diff/dt); - clothData->m_velocities[i]*=damping; - } -} - -void PositionBasedDynamics::solveConstraints(struct CpuSoftClothDemoInternalData* clothData, char* vtx, int vertexStride,float dt) -{ - B3_PROFILE("computeGravityForces"); - ExplicitEuler::computeGravityForces(clothData,vtx,vertexStride,dt); - ExplicitEuler::integrateExplicitEuler(clothData,vtx,vertexStride,dt); - - int numIter=10; - for (int i=0;i //for GetLocalTime/GetSystemTime -#else -#include //gettimeofday -#endif - -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#elif defined _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#elif defined __linux -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif - - - -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "OpenGLWindow/GLInstancingRenderer.h" - -#include -#include -#include "OpenGLWindow/fontstash.h" -#include "OpenGLWindow/opengl_fontstashcallbacks.h" -#include "gwenUserInterface.h" - -#include "../btgui/Bullet3AppSupport/b3Quickprof.h" -#include "../btgui/OpenGLWindow/GLRenderToTexture.h" - -bool exportFrame=false; -bool exportMovie = false; -int frameIndex = 0; -GLRenderToTexture* renderTexture =0; - -int g_OpenGLWidth=1024; -int g_OpenGLHeight = 768; -bool dump_timings = false; -int maxFrameCount = 102; -extern char OpenSansData[]; - -static void MyResizeCallback( float width, float height) -{ - g_OpenGLWidth = width; - g_OpenGLHeight = height; -} - -b3gWindowInterface* window=0; -GwenUserInterface* gui = 0; - -bool gPause = false; -bool gDrawGui = true; -bool gStep = false; -bool gReset = false; - -enum -{ - MYPAUSE=1, - MYPROFILE=2, - MYRESET, -}; - -enum -{ - MYCOMBOBOX1 = 1, -}; - -#include "CpuDemo.h" - -struct EmptyDemo : public CpuDemo -{ - virtual const char* getName() { - return "EmptyDemo"; - } - - virtual void initPhysics(const ConstructionInfo& ci) - { - } - - virtual void exitPhysics() - { - } - - virtual void renderScene() - { - } - - virtual void clientMoveAndDisplay() - { - } - - static CpuDemo* MyCreateFunc() - { - CpuDemo* demo = new EmptyDemo; - return demo; - } - - -}; -#include "rendering/RenderDemo.h" -#include "rigidbody/RigidBodyDemo.h" -#include "deformable/CpuSoftBodyDemo.h" - - -b3AlignedObjectArray demoNames; -int selectedDemo = 0; -CpuDemo::CreateFunc* allDemos[]= -{ - CpuSoftClothDemo::MyCreateFunc, - RigidBodyDemo::MyCreateFunc, - RenderDemo::MyCreateFunc, - EmptyDemo::MyCreateFunc, -}; - - -void MyComboBoxCallback(int comboId, const char* item) -{ - int numDemos = demoNames.size(); - for (int i=0;imouseMoveCallback(x,y); - if (!handled) - { - if (sDemo) - handled = sDemo->mouseMoveCallback(x,y); - if (!handled) - b3DefaultMouseMoveCallback(x,y); - } - } -} -static void MyMouseButtonCallback(int button, int state, float x, float y) -{ - if (gui) - { - bool handled = gui->mouseButtonCallback(button,state,x,y); - if (!handled) - { - //try picking first - if (sDemo) - handled = sDemo->mouseButtonCallback(button,state,x,y); - - if (!handled) - b3DefaultMouseButtonCallback(button,state,x,y); - } - } -} - -extern bool useShadowMap; -bool useWireFrame = false; - -void MyKeyboardCallback(int key, int state) -{ - - if (key=='w' && state) - { - useWireFrame = !useWireFrame; - if (useWireFrame) - { - glPolygonMode( GL_FRONT_AND_BACK, GL_LINE ); - } else - { - glPolygonMode( GL_FRONT_AND_BACK, GL_FILL ); - } - } - if (key=='s' && state) - { - useShadowMap=!useShadowMap; - } - if (key=='g' && state) - { - gDrawGui = !gDrawGui; - } - - if (key==B3G_ESCAPE && window) - { - window->setRequestExit(); - } - if (key==B3G_F2) - { - if (state) - exportMovie = !exportMovie; - } - if (key==B3G_F1) - { - if (state) - exportFrame = true; - } - if (sDemo) - sDemo->keyboardCallback(key,state); - - b3DefaultKeyboardCallback(key,state); -} - - - - - - - int droidRegular=0;//, droidItalic, droidBold, droidJapanese, dejavu; - -sth_stash* stash=0; -OpenGL2RenderCallbacks* renderCallbacks = 0; - -void exitFont() -{ - sth_delete(stash); - stash=0; - - delete renderCallbacks; - renderCallbacks=0; -} -sth_stash* initFont(GLPrimitiveRenderer* primRender) -{ - GLint err; - - struct sth_stash* stash = 0; - int datasize; - - float sx,sy,dx,dy,lh; - GLuint texture; - - renderCallbacks = new OpenGL2RenderCallbacks(primRender); - - stash = sth_create(512,512,renderCallbacks);//256,256);//,1024);//512,512); - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (!stash) - { - fprintf(stderr, "Could not create stash.\n"); - return 0; - } -#ifdef LOAD_FONT_FROM_FILE - unsigned char* data=0; - const char* fontPaths[]={ - "./", - "../../bin/", - "../bin/", - "bin/" - }; - - int numPaths=sizeof(fontPaths)/sizeof(char*); - - // Load the first truetype font from memory (just because we can). - - FILE* fp = 0; - const char* fontPath ="./"; - char fullFontFileName[1024]; - - for (int i=0;i] [--benchmark] [--maxFrameCount=][--dump_timings] [--disable_opencl] [--cl_device=] [--cl_platform=] [--disable_cached_cl_kernels] [--load_cl_kernels_from_disk] [--x_dim=] [--y_dim=] [--z_dim=] [--x_gap=] [--y_gap=] [--z_gap=] [--use_concave_mesh] [--pair_benchmark_file=] [--new_batching] [--no_instanced_collision_shapes]\n"); -}; - - -void DumpSimulationTime(FILE* f) -{ - b3ProfileIterator* profileIterator = b3ProfileManager::Get_Iterator(); - - profileIterator->First(); - if (profileIterator->Is_Done()) - return; - - float accumulated_time=0,parent_time = profileIterator->Is_Root() ? b3ProfileManager::Get_Time_Since_Reset() : profileIterator->Get_Current_Parent_Total_Time(); - int i; - int frames_since_reset = b3ProfileManager::Get_Frame_Count_Since_Reset(); - - //fprintf(f,"%.3f,", parent_time ); - float totalTime = 0.f; - - - - static bool headersOnce = true; - - if (headersOnce) - { - headersOnce = false; - fprintf(f,"root,"); - - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - float fraction = parent_time > B3_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - const char* name = profileIterator->Get_Current_Name(); - fprintf(f,"%s,",name); - } - fprintf(f,"\n"); - } - - - fprintf(f,"%.3f,",parent_time); - profileIterator->First(); - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - float fraction = parent_time > B3_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - const char* name = profileIterator->Get_Current_Name(); - //if (!strcmp(name,"stepSimulation")) - { - fprintf(f,"%.3f,",current_total_time); - } - totalTime += current_total_time; - //recurse into children - } - - fprintf(f,"\n"); - - - b3ProfileManager::Release_Iterator(profileIterator); - - -} -///extern const char* g_deviceName; -const char* g_deviceName = "blaat"; - -#include "Bullet3Common/b3Vector3.h" - -FILE* defaultOutput = stdout; - -void myprintf(const char* msg) -{ - fprintf(defaultOutput,msg); -} - - - - - -//#define STB_IMAGE_WRITE_IMPLEMENTATION -#include "OpenGLWindow/stb_image_write.h" -void writeTextureToPng(int textureWidth, int textureHeight, const char* fileName) -{ - int numComponents = 4; - //glPixelStorei(GL_PACK_ALIGNMENT,1); - GLuint err=glGetError(); - assert(err==GL_NO_ERROR); - glReadBuffer(GL_BACK);//COLOR_ATTACHMENT0); - err=glGetError(); - assert(err==GL_NO_ERROR); - float* orgPixels = (float*)malloc(textureWidth*textureHeight*numComponents*4); - glReadPixels(0,0,textureWidth, textureHeight, GL_RGBA, GL_FLOAT, orgPixels); - //it is useful to have the actual float values for debugging purposes - - //convert float->char - char* pixels = (char*)malloc(textureWidth*textureHeight*numComponents); - err=glGetError(); - assert(err==GL_NO_ERROR); - - for (int j=0;jcreateWindow(wci); - window->setResizeCallback(MyResizeCallback); - window->setMouseMoveCallback(MyMouseMoveCallback); - window->setMouseButtonCallback(MyMouseButtonCallback); - window->setKeyboardCallback(MyKeyboardCallback); - - window->setWindowTitle("Bullet 3.x GPU Rigid Body http://bulletphysics.org"); - - - -#ifndef __APPLE__ - glewInit(); -#endif - - gui = new GwenUserInterface(); - - b3Printf("started GwenUserInterface\n"); - - - GLPrimitiveRenderer prim(g_OpenGLWidth,g_OpenGLHeight); - - stash = initFont(&prim); - - - if (gui) - { - gui->init(g_OpenGLWidth,g_OpenGLHeight,stash,window->getRetinaScale()); - - b3Printf("init fonts\n"); - - - gui->setToggleButtonCallback(MyButtonCallback); - - gui->registerToggleButton(MYPAUSE,"Pause"); - gui->registerToggleButton(MYPROFILE,"Profile"); - gui->registerToggleButton(MYRESET,"Reset"); - - int numItems = sizeof(allDemos)/sizeof(CpuDemo::CreateFunc*); - demoNames.clear(); - for (int i=0;igetName()); - delete demo; - } - - gui->registerComboBox(MYCOMBOBOX1,numItems,&demoNames[0]); - gui->setComboBoxCallback(MyComboBoxCallback); - } - - - - do - { - bool syncOnly = false; - gReset = false; - - - - - static bool once=true; - - - //glClearColor(0.3f, 0.3f, 0.3f, 1.0f); - glClearColor(1,1,1,1); - glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); - - window->setWheelCallback(b3DefaultWheelCallback); - - - - - { - CpuDemo* demo = allDemos[selectedDemo](); - sDemo = demo; -// demo->myinit(); - bool useGpu = false; - - - int maxObjectCapacity=1024*1024;//128*1024; - int maxShapeCapacityInBytes=10*1024*1024; - - //maxObjectCapacity = b3Max(maxObjectCapacity,ci.arraySizeX*ci.arraySizeX*ci.arraySizeX+10); - - - CpuDemo::ConstructionInfo ci; - ci.m_instancingRenderer = new GLInstancingRenderer(maxObjectCapacity,maxShapeCapacityInBytes); - ci.m_window = window; - ci.m_gui = gui; - ci.m_instancingRenderer->init(); - ci.m_instancingRenderer->resize(g_OpenGLWidth,g_OpenGLHeight); - ci.m_instancingRenderer->InitShaders(); - ci.m_primRenderer = &prim; - - -// render.init(); - - - { - demo->initPhysics(ci); - } - - - - - - - - FILE* csvFile = 0; - FILE* detailsFile = 0; - - if (benchmark) - { - gPause = false; - char prefixFileName[1024]; - char csvFileName[1024]; - char detailsFileName[1024]; - - - - //todo: move this time stuff into the Platform/Window class -#ifdef _WIN32 - SYSTEMTIME time; - GetLocalTime(&time); - char buf[1024]; - DWORD dwCompNameLen = 1024; - if (0 != GetComputerName(buf, &dwCompNameLen)) - { - printf("%s", buf); - } else - { - printf("unknown", buf); - } - - sprintf(prefixFileName,"%s_%s_%s_date_%d-%d-%d_time_%d-%d-%d","CPU",buf,demoNames[selectedDemo],time.wDay,time.wMonth,time.wYear,time.wHour,time.wMinute,time.wSecond); - -#else - timeval now; - gettimeofday(&now,0); - - struct tm* ptm; - ptm = localtime (&now.tv_sec); - char buf[1024]; -#ifdef __APPLE__ - sprintf(buf,"MacOSX"); -#else - sprintf(buf,"Unix"); -#endif - sprintf(prefixFileName,"%s_%s_%s_%d_%d_%d_date_%d-%d-%d_time_%d-%d-%d",info.m_deviceName,buf,demoNames[selectedDemo],ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ, - ptm->tm_mday, - ptm->tm_mon+1, - ptm->tm_year+1900, - ptm->tm_hour, - ptm->tm_min, - ptm->tm_sec); - -#endif - - sprintf(csvFileName,"%s.csv",prefixFileName); - sprintf(detailsFileName,"%s.txt",prefixFileName); - printf("Open csv file %s and details file %s\n", csvFileName,detailsFileName); - - //GetSystemTime(&time2); - - csvFile=fopen(csvFileName,"w"); - detailsFile = fopen(detailsFileName,"w"); - if (detailsFile) - defaultOutput = detailsFile; - - //if (f) - // fprintf(f,"%s (%dx%dx%d=%d),\n", g_deviceName,ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ,ci.arraySizeX*ci.arraySizeY*ci.arraySizeZ); - } - - - - - do - { - - - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - - if (exportFrame || exportMovie) - { - - if (!renderTexture) - { - renderTexture = new GLRenderToTexture(); - GLuint renderTextureId; - glGenTextures(1, &renderTextureId); - - // "Bind" the newly created texture : all future texture functions will modify this texture - glBindTexture(GL_TEXTURE_2D, renderTextureId); - - // Give an empty image to OpenGL ( the last "0" ) - //glTexImage2D(GL_TEXTURE_2D, 0,GL_RGB, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_UNSIGNED_BYTE, 0); - //glTexImage2D(GL_TEXTURE_2D, 0,GL_RGBA32F, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_FLOAT, 0); - glTexImage2D(GL_TEXTURE_2D, 0,GL_RGBA32F, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_FLOAT, 0); - - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - //glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); - //glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - - renderTexture->init(g_OpenGLWidth,g_OpenGLHeight,renderTextureId, RENDERTEXTURE_COLOR); - } - - bool result = renderTexture->enable(); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - b3ProfileManager::Reset(); - b3ProfileManager::Increment_Frame_Counter(); - -// render.reshape(g_OpenGLWidth,g_OpenGLHeight); - ci.m_instancingRenderer->resize(g_OpenGLWidth,g_OpenGLHeight); - prim.setScreenSize(g_OpenGLWidth,g_OpenGLHeight); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - window->startRendering(); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - glClear(GL_COLOR_BUFFER_BIT| GL_DEPTH_BUFFER_BIT);//|GL_STENCIL_BUFFER_BIT); - glEnable(GL_DEPTH_TEST); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (!gPause) - { - B3_PROFILE("clientMoveAndDisplay"); - - demo->clientMoveAndDisplay(); - } - else - { - - } - - { - B3_PROFILE("renderScene"); - demo->renderScene(); - } - err = glGetError(); - assert(err==GL_NO_ERROR); - - - /*if (demo->getDynamicsWorld() && demo->getDynamicsWorld()->getNumCollisionObjects()) - { - B3_PROFILE("renderPhysicsWorld"); - b3AlignedObjectArray arr = demo->getDynamicsWorld()->getCollisionObjectArray(); - b3CollisionObject** colObjArray = &arr[0]; - - render.renderPhysicsWorld(demo->getDynamicsWorld()->getNumCollisionObjects(),colObjArray, syncOnly); - syncOnly = true; - - } - */ - - - if (exportFrame || exportMovie) - { - - char fileName[1024]; - sprintf(fileName,"screenShot%d.png",frameIndex++); - writeTextureToPng(g_OpenGLWidth,g_OpenGLHeight,fileName); - exportFrame = false; - renderTexture->disable(); - } - - - { - B3_PROFILE("gui->draw"); - if (gui && gDrawGui) - gui->draw(g_OpenGLWidth,g_OpenGLHeight); - } - err = glGetError(); - assert(err==GL_NO_ERROR); - - - { - B3_PROFILE("window->endRendering"); - window->endRendering(); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - { - B3_PROFILE("glFinish"); - } - - - - if (dump_timings) - { - b3ProfileManager::dumpAll(stdout); - } - - if (csvFile) - { - static int frameCount=0; - - if (frameCount>0) - { - DumpSimulationTime(csvFile); - if (detailsFile) - { - fprintf(detailsFile,"\n==================================\nFrame %d:\n", frameCount); - b3ProfileManager::dumpAll(detailsFile); - } - } - - if (frameCount>=maxFrameCount) - window->setRequestExit(); - frameCount++; - } - - - if (gStep) - gPause=true; - - } while (!window->requestedExit() && !gReset); - - - demo->exitPhysics(); - b3ProfileManager::CleanupMemory(); - delete ci.m_instancingRenderer; - - delete demo; - sDemo = 0; - - if (detailsFile) - { - fclose(detailsFile); - detailsFile=0; - } - if (csvFile) - { - fclose(csvFile); - csvFile=0; - } - } - - - - } while (gReset); - - - if (gui) - gui->setComboBoxCallback(0); - - { - - - - delete gui; - gui=0; - - exitFont(); - - - window->closeWindow(); - delete window; - window = 0; - - } - - return 0; -} diff --git a/Demos3/CpuDemos/premake4.lua b/Demos3/CpuDemos/premake4.lua deleted file mode 100644 index 1c26293a6..000000000 --- a/Demos3/CpuDemos/premake4.lua +++ /dev/null @@ -1,81 +0,0 @@ - - -project ("App_Bullet3_CPU_Demos") - -language "C++" - -kind "ConsoleApp" -targetdir "../../bin" - - -initOpenGL() -initGlew() - -includedirs { - "..", - "../../src", - "../../btgui" -} - -links { - "gwen", - "Bullet2FileLoader", - "Bullet3Dynamics", - "Bullet3Collision", - "Bullet3Geometry", - "Bullet3Common", -} - -files { - "**.cpp", - "**.h", - - "../Wavefront/tiny_obj_loader.cpp", - "../Wavefront/tiny_obj_loader.h", - - "../../btgui/OpenGLWindow/GLInstancingRenderer.cpp", - "../../btgui/OpenGLWindow/GLInstancingRenderer.h", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.cpp", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.h", - "../../btgui/OpenGLWindow/LoadShader.cpp", - "../../btgui/OpenGLWindow/LoadShader.h", - "../../btgui/OpenGLWindow/TwFonts.cpp", - "../../btgui/OpenGLWindow/TwFonts.h", - "../../btgui/OpenGLWindow/GLRenderToTexture.cpp", - "../../btgui/OpenGLWindow/GLRenderToTexture.h", - "../../btgui/OpenGLWindow/fontstash.cpp", - "../../btgui/OpenGLWindow/fontstash.h", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.h", - "../../btgui/OpenGLWindow/OpenSans.cpp", - "../../btgui/stb_image/stb_image.cpp", - "../../btgui/stb_image/stb_image.h", - "../../btgui/Bullet3AppSupport/b3Quickprof.cpp", - "../../btgui/Bullet3AppSupport/b3Quickprof.h", - "../../btgui/Bullet3AppSupport/b3Clock.cpp", - "../../btgui/Bullet3AppSupport/b3Clock.h", -} - -if os.is("Windows") then - files{ - "../../btgui/OpenGLWindow/Win32OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/Win32OpenGLWindow.h", - "../../btgui/OpenGLWindow/Win32Window.cpp", - "../../btgui/OpenGLWindow/Win32Window.h", - } -end -if os.is("Linux") then - links{"X11"} - files { - "../../btgui/OpenGLWindow/X11OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/X11OpenGLWindows.h" - } -end -if os.is("MacOSX") then - links {"Cocoa.framework"} - files { - "../../btgui/OpenGLWindow/MacOpenGLWindow.h", - "../../btgui/OpenGLWindow/MacOpenGLWindow.mm", - } -end - diff --git a/Demos3/CpuDemos/rendering/RenderDemo.cpp b/Demos3/CpuDemos/rendering/RenderDemo.cpp deleted file mode 100644 index e28fa93b6..000000000 --- a/Demos3/CpuDemos/rendering/RenderDemo.cpp +++ /dev/null @@ -1,53 +0,0 @@ -#include "RenderDemo.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/ShapeData.h" -#include "Bullet3Common/b3Quaternion.h" - - -static b3Vector4 colors[4] = -{ - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), -}; - - -void RenderDemo::initPhysics(const ConstructionInfo& ci) -{ - m_instancingRenderer = ci.m_instancingRenderer; - m_instancingRenderer ->setCameraDistance(10); - float target[4]={0,0,0,0}; - m_instancingRenderer->setCameraTargetPosition(target); - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - - b3Vector3 position = b3MakeVector3(0,0,0);//((j+1)&1)+i*2.2,1+j*2.,((j+1)&1)+k*2.2); - b3Quaternion orn(0,0,0,1); - - static int curColor=0; - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - b3Vector4 scaling=b3MakeVector4(1,1,1,1); - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - - ci.m_instancingRenderer->writeTransforms(); - - -} - -void RenderDemo::exitPhysics() -{ -} - -void RenderDemo::renderScene() -{ - m_instancingRenderer->renderScene(); -} - -void RenderDemo::clientMoveAndDisplay() -{ -} diff --git a/Demos3/CpuDemos/rendering/RenderDemo.h b/Demos3/CpuDemos/rendering/RenderDemo.h deleted file mode 100644 index 066ddfde5..000000000 --- a/Demos3/CpuDemos/rendering/RenderDemo.h +++ /dev/null @@ -1,36 +0,0 @@ - -#include "../CpuDemo.h" - -struct RenderDemo : public CpuDemo -{ - GLInstancingRenderer* m_instancingRenderer; - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void exitPhysics(); - - virtual void renderScene(); - - virtual void clientMoveAndDisplay(); - virtual const char* getName() { - return "RenderDemo"; - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - - static CpuDemo* MyCreateFunc() - { - CpuDemo* demo = new RenderDemo; - return demo; - } -}; \ No newline at end of file diff --git a/Demos3/CpuDemos/rigidbody/RigidBodyDemo.cpp b/Demos3/CpuDemos/rigidbody/RigidBodyDemo.cpp deleted file mode 100644 index d158d325d..000000000 --- a/Demos3/CpuDemos/rigidbody/RigidBodyDemo.cpp +++ /dev/null @@ -1,150 +0,0 @@ -#include "RigidBodyDemo.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/ShapeData.h" -#include "Bullet3Common/b3Quaternion.h" - -#include "Bullet3Collision/BroadPhaseCollision/b3DynamicBvhBroadphase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3CpuNarrowPhase.h" -#include "Bullet3Dynamics/b3CpuRigidBodyPipeline.h" -#include "Bullet3Dynamics/shared/b3IntegrateTransforms.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" - - -static b3Vector4 colors[4] = -{ - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), -}; - - - -void RigidBodyDemo::initPhysics(const ConstructionInfo& ci) -{ - m_instancingRenderer = ci.m_instancingRenderer; - - int x_dim=1; - int y_dim=2; - int z_dim=1; - - int aabbCapacity = x_dim*y_dim*z_dim+10; - - b3Config config; - - m_bp = new b3DynamicBvhBroadphase(aabbCapacity); - m_np = new b3CpuNarrowPhase(config); - m_rb = new b3CpuRigidBodyPipeline(m_np,m_bp, config); - - - - - - m_instancingRenderer ->setCameraDistance(100); - float target[4]={0,0,0,0}; - m_instancingRenderer->setCameraTargetPosition(target); - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - - - - - - - - { - static int curColor=0; - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - - b3Vector3 position = b3MakeVector3(0,0,0);//((j+1)&1)+i*2.2,1+j*2.,((j+1)&1)+k*2.2); - b3Quaternion orn(0,0,0,1); - b3Vector4 scaling=b3MakeVector4(100,1,100,1); - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - float mass=0.f; - int collidableIndex = m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int bodyIndex = m_rb->getNumBodies(); - - - int userData=-1; - int rbid = m_rb->registerPhysicsInstance(mass, position, orn, collidableIndex, userData); - } - - ci.m_instancingRenderer->writeTransforms(); - - { - - b3Vector4 scaling=b3MakeVector4(1,1,1,1); - int collidableIndex = m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - for (int x=0;xregisterGraphicsInstance(shapeId,position,orn,color,scaling); - float mass=1.f; - - int userData=-1; - int bodyIndex = m_rb->getNumBodies(); - int rbid = m_rb->registerPhysicsInstance(mass, position, orn, collidableIndex, userData); - - } - } - } - } - - - printf("num objects = %d\n",m_rb->getNumBodies()); - - -} - -void RigidBodyDemo::exitPhysics() -{ - delete m_rb; - m_rb=0; - delete m_np; - m_np=0; - delete m_bp; - m_bp=0; -} - -void RigidBodyDemo::renderScene() -{ - { - B3_PROFILE("writeSingleInstanceTransformToCPU"); - const b3RigidBodyData* bodies = m_rb->getBodyBuffer(); - //sync transforms - int numBodies = m_rb->getNumBodies(); - for (int i=0;iwriteSingleInstanceTransformToCPU(&bodies[i].m_pos.x,bodies[i].m_quat,i); - } - } - { - B3_PROFILE("writeTransforms"); - m_instancingRenderer->writeTransforms(); - } - { - B3_PROFILE("renderScene"); - m_instancingRenderer->renderScene(); - } -} - -void RigidBodyDemo::clientMoveAndDisplay() -{ - m_rb->stepSimulation(1.f/60.f); -} diff --git a/Demos3/CpuDemos/rigidbody/RigidBodyDemo.h b/Demos3/CpuDemos/rigidbody/RigidBodyDemo.h deleted file mode 100644 index 7b138c08d..000000000 --- a/Demos3/CpuDemos/rigidbody/RigidBodyDemo.h +++ /dev/null @@ -1,46 +0,0 @@ -#ifndef B3_RIGID_BODY_DEMO_H -#define B3_RIGID_BODY_DEMO_H - -#include "../CpuDemo.h" - -struct RigidBodyDemo : public CpuDemo -{ - - struct b3DynamicBvhBroadphase* m_bp; - class b3CpuNarrowPhase* m_np; - - struct b3CpuRigidBodyPipeline* m_rb; - - GLInstancingRenderer* m_instancingRenderer; - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void exitPhysics(); - - virtual void renderScene(); - - virtual void clientMoveAndDisplay(); - virtual const char* getName() { - return "RigidBodyDemo"; - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - - static CpuDemo* MyCreateFunc() - { - CpuDemo* demo = new RigidBodyDemo; - return demo; - } -}; -#endif //B3_RIGID_BODY_DEMO_H - diff --git a/Demos3/FiniteElementMethod/FiniteElementDemo.cpp b/Demos3/FiniteElementMethod/FiniteElementDemo.cpp deleted file mode 100644 index 05360ed86..000000000 --- a/Demos3/FiniteElementMethod/FiniteElementDemo.cpp +++ /dev/null @@ -1,381 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2011-2014 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///the Finite Element Method is extracted from the OpenTissue library, -///under the zlib license: http://www.opentissue.org/mediawiki/index.php/Main_Page - - -#include "FiniteElementDemo.h" -#include "OpenGLWindow/CommonRenderInterface.h" -#include "LinearMath/btQuaternion.h" -//#include "OpenGLWindow/ShapeData.h" - -#include "MyFemMesh.h" -#include -#include -#include -#include "LinearMath/btAlignedObjectArray.h" -#include "Bullet3AppSupport/CommonParameterInterface.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" - -//typedef OpenTissue::math::BasicMathTypes math_types; -typedef OpenTissue::math::BasicMathTypes math_types; -typedef OpenTissue::fem::Mesh mesh_type; -typedef math_types::vector3_type vector3_type; -typedef math_types::real_type real_type; - - -static int fixedNodes = 1; - -struct FiniteElementDemoInternalData -{ - mesh_type m_mesh1; - - bool m_stiffness_warp_on; ///< Boolean value indicating whether stiffness warping is turned on or off. - - bool m_collideGroundPlane; - - bool m_fixNodes; - - real_type m_gravity; - - btScalar m_young;// = 500000; - btScalar m_poisson;// = 0.33; - real_type m_density;// = 1000; - - //--- infinite m_c_yield plasticity settings means that plasticity is turned off - real_type m_c_yield;// = .04; //--- should be less than maximum expected elastic strain in order to see effect (works as a minimum). - real_type m_c_creep;// = .20; //--- controls how fast the plasticity effect occurs (it is a rate-like control). - real_type m_c_max;// = 0.2; //--- This is maximum allowed plasticity strain (works as a maximum). - double m_damp; - int m_tetrahedralMeshRenderIndex; - - FiniteElementDemoInternalData() - { - m_stiffness_warp_on= true; - m_collideGroundPlane = true; - m_fixNodes = fixedNodes==1; - fixedNodes=1-fixedNodes; - m_gravity = 9.81; - m_young = 500000;//47863;//100000; - m_poisson = 0.33; - - m_density = 1054.00;//1000; - //--- infinite m_c_yield plasticity settings means that plasticity is turned off - m_c_yield = 0;//0.03;//.04; //--- should be less than maximum expected elastic strain in order to see effect (works as a minimum). - m_c_creep = 0;//0.20;//.20; //--- controls how fast the plasticity effect occurs (it is a rate-like control). - m_c_max = 1e30f;//0.2; //--- This is maximum allowed plasticity strain (works as a maximum). - m_damp=0.2f; - m_tetrahedralMeshRenderIndex=-1; - } - -}; - -FiniteElementDemo::FiniteElementDemo(CommonGraphicsApp* app) -:m_app(app), -m_x(0), -m_y(0), -m_z(0) -{ - m_app->setUpAxis(2); - m_data = new FiniteElementDemoInternalData; - - -} -FiniteElementDemo::~FiniteElementDemo() -{ - delete m_data; - m_app->m_renderer->enableBlend(false); - m_app->m_renderer->removeAllInstances(); -} - - - -void FiniteElementDemo::initPhysics() -{ - { - - OpenTissue::t4mesh::generate_blocks(10,3,3,0.1,0.1,0.1,m_data->m_mesh1); - - for (int n=0;nm_mesh1.m_nodes.size();n++) - { - m_data->m_mesh1.m_nodes[n].m_coord(m_app->getUpAxis())+=.5f; - m_data->m_mesh1.m_nodes[n].m_model_coord = m_data->m_mesh1.m_nodes[n].m_coord; - - } - OpenTissue::fem::init(m_data->m_mesh1,double(m_data->m_young),double(m_data->m_poisson),m_data->m_density,m_data->m_c_yield,m_data->m_c_creep,m_data->m_c_max); - - - - } - - { - - SliderParams slider("Young",&m_data->m_young); -// slider.m_showValues = false; - slider.m_minVal=50000; - slider.m_maxVal=1000000; - m_app->m_parameterInterface->registerSliderFloatParameter(slider); - } - - { - - SliderParams slider("Poisson",&m_data->m_poisson); - // slider.m_showValues = false; - slider.m_minVal=0.01; - slider.m_maxVal=0.49; - m_app->m_parameterInterface->registerSliderFloatParameter(slider); - } - - { - - - - - int strideInBytes = 9*sizeof(float); - int numVertices =m_data->m_mesh1.m_nodes.size(); - - btAlignedObjectArray verts; - verts.resize(numVertices); - for (int n=0;nm_mesh1.m_nodes.size();n++) - { - verts[n].xyzw[0] = m_data->m_mesh1.m_nodes[n].m_coord(0); - verts[n].xyzw[1] = m_data->m_mesh1.m_nodes[n].m_coord(1); - verts[n].xyzw[2] = m_data->m_mesh1.m_nodes[n].m_coord(2); - verts[n].xyzw[3] = 1; - verts[n].normal[0] = 0; - verts[n].normal[1] = 1; - verts[n].normal[2] = 0; - verts[n].uv[0] = 0.5; - verts[n].uv[1] = 0.4; - - } - btAlignedObjectArray indices; - for (int t=0;tm_mesh1.m_tetrahedra.size();t++) - { - int index0 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[0]; - int index1 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[1]; - int index2 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[2]; - int index3 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[3]; - indices.push_back(index0); indices.push_back(index1); indices.push_back(index2); - indices.push_back(index2); indices.push_back(index1); indices.push_back(index3); - indices.push_back(index1); indices.push_back(index0); indices.push_back(index3); - indices.push_back(index0); indices.push_back(index2); indices.push_back(index3); - - } - - m_data->m_tetrahedralMeshRenderIndex = m_app->m_renderer->registerShape(&verts[0].xyzw[0],verts.size(),&indices[0],indices.size()); - - float pos[4] = {0,0,0,1}; - float orn[4] = {0,0,0,1}; - float color[4] = {0,1,1,1}; - float scaling[4] = {1,1,1,1}; - m_app->m_renderer->registerGraphicsInstance(m_data->m_tetrahedralMeshRenderIndex,pos,orn,color,scaling); - } - - { - //ground shape - btVector3 cubeHalfExtents(10,10,10); - cubeHalfExtents[m_app->getUpAxis()] = 0.01; - int cubeIn = m_app->registerCubeShape(cubeHalfExtents[0],cubeHalfExtents[1],cubeHalfExtents[2]); - - float pos[4] = {0,0,0,1}; - pos[m_app->getUpAxis()]=-0.02; - float orn[4] = {0,0,0,1}; - float color[4] = {0,1,1,1}; - float scaling[4] = {1,1,1,1}; - m_app->m_renderer->registerGraphicsInstance(cubeIn,pos,orn,color,scaling); - - - } - m_app->m_renderer->writeTransforms(); -} -void FiniteElementDemo::exitPhysics() -{ - -} -void FiniteElementDemo::stepSimulation(float deltaTime) -{ - m_x+=0.01f; - m_y+=0.01f; - m_z+=0.01f; - double dt = 1./60.;//double (deltaTime); - double poisson =m_data->m_poisson; - OpenTissue::fem::init(m_data->m_mesh1,double(m_data->m_young),poisson,m_data->m_density,m_data->m_c_yield,m_data->m_c_creep,m_data->m_c_max); - - - for (int n=0;nm_mesh1.m_nodes.size();n++) - { - - - if (m_data->m_fixNodes) - { - if (m_data->m_mesh1.m_nodes[n].m_model_coord(0) < 0.01) - { - m_data->m_mesh1.m_nodes[n].m_fixed = true; - } - } else - { - if (m_data->m_mesh1.m_nodes[n].m_model_coord(0) < 0.01) - { - m_data->m_mesh1.m_nodes[n].m_fixed = false; - } - } - if (m_data->m_collideGroundPlane && m_data->m_mesh1.m_nodes[n].m_coord(m_app->getUpAxis())<0.f) - { - float depth = -m_data->m_mesh1.m_nodes[n].m_coord(m_app->getUpAxis()); - if (depth>0.1) - depth=0.1; - - m_data->m_mesh1.m_nodes[n].m_f_external(m_app->getUpAxis()) = depth*1000; - - if (m_data->m_mesh1.m_nodes[n].m_velocity(m_app->getUpAxis()) < 0.f) - { - m_data->m_mesh1.m_nodes[n].m_velocity(m_app->getUpAxis())=0.f; - } - - int frictionAxisA=0; - int frictionAxisB=2; - if (m_app->getUpAxis()==1) - { - frictionAxisA=0; - frictionAxisB=2; - } else - { - frictionAxisA=0; - frictionAxisB=1; - } - m_data->m_mesh1.m_nodes[n].m_velocity(frictionAxisA)=0.f; - m_data->m_mesh1.m_nodes[n].m_velocity(frictionAxisB)=0.f; - - } else - { - vector3_type gravity = vector3_type(0.0, 0.0 , 0.0); - gravity(m_app->getUpAxis()) = -(m_data->m_mesh1.m_nodes[n].m_mass * m_data->m_gravity); - m_data->m_mesh1.m_nodes[n].m_f_external =gravity; - } - //m_data->m_mesh1.m_nodes[n].m_velocity.clear(); - } - - OpenTissue::fem::simulate(m_data->m_mesh1,dt,m_data->m_stiffness_warp_on,m_data->m_damp);//,0.1,20,20);//,1.0,20,20); - -} -void FiniteElementDemo::renderScene() -{ - { - int strideInBytes = 9*sizeof(float); - int numVertices =m_data->m_mesh1.m_nodes.size(); - - btAlignedObjectArray verts; - verts.resize(numVertices); - for (int n=0;nm_mesh1.m_nodes.size();n++) - { - verts[n].xyzw[0] = m_data->m_mesh1.m_nodes[n].m_coord(0); - verts[n].xyzw[1] = m_data->m_mesh1.m_nodes[n].m_coord(1); - verts[n].xyzw[2] = m_data->m_mesh1.m_nodes[n].m_coord(2); - verts[n].xyzw[3] = 1; - verts[n].normal[0] = 0; - verts[n].normal[1] = 1; - verts[n].normal[2] = 0; - verts[n].uv[0] = 0.5; - verts[n].uv[1] = 0.4; - - } - btAlignedObjectArray indices; - for (int t=0;tm_mesh1.m_tetrahedra.size();t++) - { - int index0 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[0]; - int index1 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[1]; - int index2 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[2]; - int index3 =m_data->m_mesh1.m_tetrahedra[t].m_nodes[3]; - indices.push_back(index0); indices.push_back(index1); indices.push_back(index2); - indices.push_back(index2); indices.push_back(index1); indices.push_back(index3); - indices.push_back(index1); indices.push_back(index0); indices.push_back(index3); - indices.push_back(index0); indices.push_back(index2); indices.push_back(index3); - - } - - m_app->m_renderer->updateShape(m_data->m_tetrahedralMeshRenderIndex,&verts[0].xyzw[0]); - - } - m_app->m_renderer->renderScene(); -} - -void FiniteElementDemo::physicsDebugDraw(int debugDrawFlags) -{ - { - btAlignedObjectArray m_linePoints; - btAlignedObjectArray m_lineIndices; - - //geometry::Tetrahedron tet; - for (int t=0;tm_mesh1.m_tetrahedra.size();t++) - { - vector3_type v0d = m_data->m_mesh1.m_nodes[m_data->m_mesh1.m_tetrahedra[t].m_nodes[0]].m_coord; - vector3_type v1d = m_data->m_mesh1.m_nodes[m_data->m_mesh1.m_tetrahedra[t].m_nodes[1]].m_coord; - vector3_type v2d = m_data->m_mesh1.m_nodes[m_data->m_mesh1.m_tetrahedra[t].m_nodes[2]].m_coord; - vector3_type v3d = m_data->m_mesh1.m_nodes[m_data->m_mesh1.m_tetrahedra[t].m_nodes[3]].m_coord; - btVector3 v0(v0d(0),v0d(1),v0d(2)); - btVector3 v1(v1d(0),v1d(1),v1d(2)); - btVector3 v2(v2d(0),v2d(1),v2d(2)); - btVector3 v3(v3d(0),v3d(1),v3d(2)); - btVector3FloatData vf0,vf1,vf2,vf3; - v0.serializeFloat(vf0); - v1.serializeFloat(vf1); - v2.serializeFloat(vf2); - v3.serializeFloat(vf3); - unsigned int baseIndex = m_linePoints.size(); - m_linePoints.push_back(vf0); - m_linePoints.push_back(vf1); - m_linePoints.push_back(vf2); - m_linePoints.push_back(vf3); - m_lineIndices.push_back(baseIndex+0); - m_lineIndices.push_back(baseIndex+1); - m_lineIndices.push_back(baseIndex+0); - m_lineIndices.push_back(baseIndex+2); - m_lineIndices.push_back(baseIndex+0); - m_lineIndices.push_back(baseIndex+3); - - m_lineIndices.push_back(baseIndex+1); - m_lineIndices.push_back(baseIndex+2); - m_lineIndices.push_back(baseIndex+2); - m_lineIndices.push_back(baseIndex+3); - m_lineIndices.push_back(baseIndex+1); - m_lineIndices.push_back(baseIndex+3); - } - - float debugColor[4]={0,0,0.4,1}; - m_app->m_renderer->drawLines(&m_linePoints[0].m_floats[0],debugColor, - m_linePoints.size(),sizeof(btVector3FloatData), - &m_lineIndices[0], - m_lineIndices.size(), - 1); - - - }; - -} -bool FiniteElementDemo::mouseMoveCallback(float x,float y) -{ - return false; -} -bool FiniteElementDemo::mouseButtonCallback(int button, int state, float x, float y) -{ - return false; -} -bool FiniteElementDemo::keyboardCallback(int key, int state) -{ - return false; -} - diff --git a/Demos3/FiniteElementMethod/FiniteElementDemo.h b/Demos3/FiniteElementMethod/FiniteElementDemo.h deleted file mode 100644 index 59ab3fb19..000000000 --- a/Demos3/FiniteElementMethod/FiniteElementDemo.h +++ /dev/null @@ -1,59 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2011-2014 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///the Finite Element Method is extracted from the OpenTissue library, -///under the zlib license: http://www.opentissue.org/mediawiki/index.php/Main_Page - - -#ifndef FINITE_ELEMENT_DEMO_H -#define FINITE_ELEMENT_DEMO_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "OpenGLWindow/CommonGraphicsApp.h" - - -///quick demo showing the right-handed coordinate system and positive rotations around each axis -class FiniteElementDemo : public BulletDemoInterface -{ - CommonGraphicsApp* m_app; - float m_x; - float m_y; - float m_z; - - struct FiniteElementDemoInternalData* m_data; -public: - - FiniteElementDemo(CommonGraphicsApp* app); - - virtual ~FiniteElementDemo(); - - static BulletDemoInterface* CreateFunc(CommonGraphicsApp* app) - { - return new FiniteElementDemo(app); - } - - virtual void initPhysics(); - virtual void exitPhysics(); - virtual void stepSimulation(float deltaTime); - virtual void renderScene(); - - - virtual void physicsDebugDraw(int debugDrawFlags); - virtual bool mouseMoveCallback(float x,float y); - virtual bool mouseButtonCallback(int button, int state, float x, float y); - virtual bool keyboardCallback(int key, int state); -}; -#endif //FINITE_ELEMENT_DEMO_H - diff --git a/Demos3/FiniteElementMethod/MyFemMesh.h b/Demos3/FiniteElementMethod/MyFemMesh.h deleted file mode 100644 index ee05d6398..000000000 --- a/Demos3/FiniteElementMethod/MyFemMesh.h +++ /dev/null @@ -1,214 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2011-2014 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -///the Finite Element Method is extracted from the OpenTissue library, -///under the zlib license: http://www.opentissue.org/mediawiki/index.php/Main_Page - - -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_MESH_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_MESH_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -//#include -#include -#include -#include - -namespace OpenTissue -{ - namespace fem - { - - template - class Mesh -/* : public OpenTissue::t4mesh::T4Mesh< - math_types - , OpenTissue::fem::detail::NodeTraits - , OpenTissue::fem::detail::TetrahedronTraits - > - */ - { - public: - - - - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - - class MyNodeType - { - public: - - MyNodeType() - :m_fixed(false) - { - - } - - typedef typename std::map matrix_container; - - typedef typename matrix_container::iterator matrix_iterator; - - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::real_type real_type; - - vector3_type m_coord; ///< Default Coordinate of tetramesh node. - vector3_type m_model_coord; - vector3_type m_f_external; - vector3_type m_velocity; - real_type m_mass; - bool m_fixed; - // Needed by the ConjugateGradient method - vector3_type m_update; - vector3_type m_prev; - vector3_type m_residual; - matrix_container m_K_row; ///< Currently stored in a map container, key correspond to column and mapped value to 3-by-3 sub block. - matrix_container m_A_row; - - vector3_type m_f0; - vector3_type m_b; - matrix_iterator Kbegin() { return m_K_row.begin(); } - matrix_iterator Kend() { return m_K_row.end(); } - matrix_iterator Abegin() { return m_A_row.begin(); } - matrix_iterator Aend() { return m_A_row.end(); } - - matrix3x3_type & K(int const & column_idx) { return m_K_row[column_idx]; } - matrix3x3_type & A(int const & column_idx) { return m_A_row[column_idx]; } - - int m_idx; - int idx() const { - return m_idx; - } - - - - }; - - class MyTetrahedronType - { - public: - - typedef typename math_types::matrix3x3_type matrix3x3_type; - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - - real_type m_young; - real_type m_poisson; - real_type m_density; - int m_nodes[4]; - - - Mesh* m_owner; - - matrix3x3_type m_Ke[4][4]; ///< Stiffness element matrix - matrix3x3_type m_Re; ///< Rotational warp of tetrahedron. - real_type m_V; ///< Volume of tetrahedron - - vector3_type m_e10; ///< edge from p0 to p1 - vector3_type m_e20; ///< edge from p0 to p2 - vector3_type m_e30; ///< edge from p0 to p3 - - //--- Stuff used exclusive by plastic effects - - vector3_type m_B[4]; ///< placeholders for Jacobian of shapefunctions: B = SN. - vector3_type m_D; ///< Elasticity Matrix in vector from - real_type m_plastic[6]; ///< Plastic strain tensor. - real_type m_yield; - real_type m_creep; - real_type m_max; - - MyNodeType* node(int i) - { - return &m_owner->m_nodes[m_nodes[i]]; - } - - MyNodeType* i() - { - return &m_owner->m_nodes[m_nodes[0]]; - } - MyNodeType* j() - { - return &m_owner->m_nodes[m_nodes[1]]; - } - - MyNodeType* k() - { - return &m_owner->m_nodes[m_nodes[2]]; - } - MyNodeType* m() - { - return &m_owner->m_nodes[m_nodes[3]]; - } - - MyTetrahedronType(int bla, int bla2) - { - - } - - }; - - - typedef std::vector< MyNodeType> node_container; - typedef std::vector< MyTetrahedronType > tetrahedra_container; - typedef MyNodeType node_type; - - public: - - node_container m_nodes; ///< Internal node storage. - - void insert(int a,int b,int c,int d) - { - MyTetrahedronType t(1,1); - t.m_owner = this; - t.m_nodes[0] = a; - t.m_nodes[1] = b; - t.m_nodes[2] = c; - t.m_nodes[3] = d; - m_tetrahedra.push_back(t); - - - } - void insert() - { - MyNodeType n; - n.m_idx = m_nodes.size(); - m_nodes.push_back(n); - - } - void clear() - { - m_nodes.clear(); - m_tetrahedra.clear(); - - } - - tetrahedra_container m_tetrahedra; ///< Internal tetrahedra storage. - - - }; - - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_MESH_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/collision/collision_geometry_interface.h b/Demos3/FiniteElementMethod/OpenTissue/collision/collision_geometry_interface.h deleted file mode 100644 index 23bca36d0..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/collision/collision_geometry_interface.h +++ /dev/null @@ -1,68 +0,0 @@ -#ifndef OPENTISSUE_COLLISION_COLLISION_GEOMETRY_INTERFACE_H -#define OPENTISSUE_COLLISION_COLLISION_GEOMETRY_INTERFACE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace collision - { - - - /** - * Collision Geometry Interface. - * The purpose of this class is to create a common interface for - * collision geometries. - * - * The interface should make it easier to integrate geometry types into - * a collision detection engine. In particular it should help make multiple - * dispatching easier (the class_id interface) and it should support basic - * functionality for computing bounding boxes (compute_collision_aabb method) - * - * - */ - template< typename math_types > - class GeometryInterface - : virtual public OpenTissue::utility::ClassIDInterface - { - public: - - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - - public: - - /** - * Compute Bounding Box. - * This method computes an axis aligned bounding - * box (AABB) that encloses the geometry. - * - * @param r The position of the model frame (i.e the coordinate frame the geometry lives in). - * @param R The orientation of the model frame (i.e the coordinate frame the geometry lives in). - * @param min_coord Upon return holds the minimum corner of the box. - * @param max_coord Upon return holds the maximum corner of the box. - * - */ - virtual void compute_collision_aabb( - vector3_type const & r - , matrix3x3_type const & R - , vector3_type & min_coord - , vector3_type & max_coord - ) const = 0; - - }; - - } // namespace collision - -} // namespace OpenTissue - -// OPENTISSUE_COLLISION_COLLISION_GEOMETRY_INTERFACE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/configuration.h b/Demos3/FiniteElementMethod/OpenTissue/configuration.h deleted file mode 100644 index 39ed8cfd5..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/configuration.h +++ /dev/null @@ -1,50 +0,0 @@ -#ifndef OPENTISSUE_CONFIGURATIOM_H -#define OPENTISSUE_CONFIGURATIOM_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#if (_MSC_VER >= 1200) -# pragma once -# pragma warning(default: 56 61 62 191 263 264 265 287 289 296 347 529 686) -# pragma warning(disable: 503) -#endif - -#ifdef WIN32 -# define WIN32_LEAN_AND_MEAN -# define _USE_MATH_DEFINES -# define NOMINMAX -# include -# undef WIN32_LEAN_AND_MEAN -# undef NOMINMAX -#endif - - -/** - * OpenTissue Version - */ -#define OPENTISSUE_VERSION 0.994 -#define OPENTISSUE_VERSION_MAJOR 0 -#define OPENTISSUE_VERSION_MINOR 994 - -#include - -/** - * OpenTissue Path. - * This is the path where OpenTissue was copied onto ones - * system. It can be used to locate shader programs or data resources. - */ -std::string const opentissue_path = "F:/develop/opentissue/sandbox/"; - -/** - * OpenTissue Version String. - * This string value can be used by end users for compatibility testing. - */ -std::string const opentissue_version = "0.994"; - - -//OPENTISSUE_CONFIGURATIOM_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_aof.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_aof.h deleted file mode 100644 index e8bd0fc97..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_aof.h +++ /dev/null @@ -1,366 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_AOF_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_AOF_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - - -#include -#include -#include -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - namespace detail - { - - /** - * Compute Average Outward Flux at designated nodal position of a signed distance grid. - * - * - * @param phi The signed distance grid. - * @param i The i'th index of the node. - * @param j The j'th index of the node. - * @param k The k'th index of the node. - * @param scale Default value is 0.5, this determines the scale on which the flux is computed. 0.5 correponds to ``voxel-based''. - * - * @return The flux value. - */ - template - inline typename grid_type::value_type - compute_aof_value( - grid_type const & phi - , size_t const & i - , size_t const & j - , size_t const & k - , double scale = 0.5 - ) - { - using std::min; - using std::sqrt; - - typedef typename grid_type::iterator iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::value_type value_type; - typedef typename grid_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::real_type real_type; - - real_type dx = phi.dx()*scale; - real_type dy = phi.dy()*scale; - real_type dz = phi.dz()*scale; - - vector3_type n[26]; - vector3_type dp[26]; - - dp[0] = vector3_type( dx, 0, 0); - dp[1] = vector3_type(-dx, 0, 0); - dp[2] = vector3_type( 0, dy, 0); - dp[3] = vector3_type( 0,-dy, 0); - dp[4] = vector3_type( 0, 0, dz); - dp[5] = vector3_type( 0, 0,-dz); - dp[6] = vector3_type( dx, dy, dz); - dp[7] = vector3_type( dx, dy,-dz); - dp[8] = vector3_type( dx,-dy, dz); - dp[9] = vector3_type( dx,-dy,-dz); - dp[10] = vector3_type(-dx, dy, dz); - dp[11] = vector3_type(-dx, dy,-dz); - dp[12] = vector3_type(-dx,-dy, dz); - dp[13] = vector3_type(-dx,-dy,-dz); - dp[14] = vector3_type( dx, dy, 0); - dp[15] = vector3_type( dx,-dy, 0); - dp[16] = vector3_type(-dx, dy, 0); - dp[17] = vector3_type(-dx,-dy, 0); - dp[18] = vector3_type( dx, 0, dz); - dp[19] = vector3_type( dx, 0,-dz); - dp[20] = vector3_type(-dx, 0, dz); - dp[21] = vector3_type(-dx, 0,-dz); - dp[22] = vector3_type( 0, dy, dz); - dp[23] = vector3_type( 0, dy,-dz); - dp[24] = vector3_type( 0,-dy, dz); - dp[25] = vector3_type( 0,-dy,-dz); - for(size_t cnt=0;cnt<26u;++cnt) - n[cnt] = unit(dp[cnt]); - - vector3_type p; - idx2coord(phi,i,j,k,p); - real_type flux = real_type(); - for(size_t cnt=0;cnt<26u;++cnt) - { - vector3_type q = p + dp[cnt]; - vector3_type g = gradient_at_point(phi,q); - flux += unit(g)*n[cnt]; - } - flux /= 26.0; - return static_cast(flux); - } - - } //namespace detail - - - /** - * Average Outward Flux. - * - * @param phi A the distance grid. - * @param F A grid containing the values of the average outward flux. - */ - template - inline void aof( - grid_type const & phi - , grid_type & F - ) - { - using std::min; - using std::sqrt; - - typedef typename grid_type::iterator iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::value_type value_type; - typedef typename grid_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::real_type real_type; - - value_type const unused = phi.unused(); - size_t const & I = phi.I(); - size_t const & J = phi.J(); - size_t const & K = phi.K(); - F.create(phi.min_coord(),phi.max_coord(),I,J,K); - - real_type dx = phi.dx()*0.5; - real_type dy = phi.dy()*0.5; - real_type dz = phi.dz()*0.5; - //real_type rho = sqrt(dx*dx+dy*dy+dz*dz); - vector3_type n[26]; - vector3_type dp[26]; - dp[0] = vector3_type( dx, 0, 0); - dp[1] = vector3_type(-dx, 0, 0); - dp[2] = vector3_type( 0, dy, 0); - dp[3] = vector3_type( 0,-dy, 0); - dp[4] = vector3_type( 0, 0, dz); - dp[5] = vector3_type( 0, 0,-dz); - dp[6] = vector3_type( dx, dy, dz); - dp[7] = vector3_type( dx, dy,-dz); - dp[8] = vector3_type( dx,-dy, dz); - dp[9] = vector3_type( dx,-dy,-dz); - dp[10] = vector3_type(-dx, dy, dz); - dp[11] = vector3_type(-dx, dy,-dz); - dp[12] = vector3_type(-dx,-dy, dz); - dp[13] = vector3_type(-dx,-dy,-dz); - dp[14] = vector3_type( dx, dy, 0); - dp[15] = vector3_type( dx,-dy, 0); - dp[16] = vector3_type(-dx, dy, 0); - dp[17] = vector3_type(-dx,-dy, 0); - dp[18] = vector3_type( dx, 0, dz); - dp[19] = vector3_type( dx, 0,-dz); - dp[20] = vector3_type(-dx, 0, dz); - dp[21] = vector3_type(-dx, 0,-dz); - dp[22] = vector3_type( 0, dy, dz); - dp[23] = vector3_type( 0, dy,-dz); - dp[24] = vector3_type( 0,-dy, dz); - dp[25] = vector3_type( 0,-dy,-dz); - for(size_t i=0;i<26u;++i) - n[i] = unit(dp[i]); - //n[0] = unit(vector3_type( 1, 0, 0)); - //n[1] = unit(vector3_type(-1, 0, 0)); - //n[2] = unit(vector3_type( 0, 1, 0)); - //n[3] = unit(vector3_type( 0,-1, 0)); - //n[4] = unit(vector3_type( 0, 0, 1)); - //n[5] = unit(vector3_type( 0, 0,-1)); - //n[6] = unit(vector3_type( 1, 1, 1)); - //n[7] = unit(vector3_type( 1, 1,-1)); - //n[8] = unit(vector3_type( 1,-1, 1)); - //n[9] = unit(vector3_type( 1,-1,-1)); - //n[10] = unit(vector3_type(-1, 1, 1)); - //n[11] = unit(vector3_type(-1, 1,-1)); - //n[12] = unit(vector3_type(-1,-1, 1)); - //n[13] = unit(vector3_type(-1,-1,-1)); - //n[14] = unit(vector3_type( 1, 1, 0)); - //n[15] = unit(vector3_type( 1,-1, 0)); - //n[16] = unit(vector3_type(-1, 1, 0)); - //n[17] = unit(vector3_type(-1,-1, 0)); - //n[18] = unit(vector3_type( 1, 0, 1)); - //n[19] = unit(vector3_type( 1, 0,-1)); - //n[20] = unit(vector3_type(-1, 0, 1)); - //n[21] = unit(vector3_type(-1, 0,-1)); - //n[22] = unit(vector3_type( 0, 1, 1)); - //n[23] = unit(vector3_type( 0, 1,-1)); - //n[24] = unit(vector3_type( 0,-1, 1)); - //n[25] = unit(vector3_type( 0,-1,-1)); - //for(size_t i=0;i<26u;++i) - // dp[i] = n[i]*rho; - iterator f = F.begin(); - const_index_iterator v = phi.begin(); - const_index_iterator vend = phi.end(); - for(;v!=vend;++v,++f) - { - if((*v)==unused) - { - (*f) = value_type(); //--- should default to zero!!! - continue; - } - size_t i = v.i(); - size_t j = v.j(); - size_t k = v.k(); - vector3_type p; - idx2coord(phi,i,j,k,p); - real_type flux = real_type(); - for(size_t i=0;i<26u;++i) - { - vector3_type q = p + dp[i]; - vector3_type g = gradient_at_point(phi,q); - flux += unit(g)*n[i]; - } - flux /= 26.0; - (*f) = static_cast(flux); - } - - //vector3_type n_mpp = unit(vector3_type( -1, 1, 1)); - //vector3_type n_mp0 = unit(vector3_type( -1, 1, 0)); - //vector3_type n_mpm = unit(vector3_type( -1, 1, -1)); - //vector3_type n_m0p = unit(vector3_type( -1, 0, 1)); - //vector3_type n_m00 = unit(vector3_type( -1, 0, 0)); - //vector3_type n_m0m = unit(vector3_type( -1, 0, -1)); - //vector3_type n_mmp = unit(vector3_type( -1, -1, 1)); - //vector3_type n_mm0 = unit(vector3_type( -1, -1, 0)); - //vector3_type n_mmm = unit(vector3_type( -1, -1, -1)); - //vector3_type n_0pp = unit(vector3_type( 0, 1, 1)); - //vector3_type n_0p0 = unit(vector3_type( 0, 1, 0)); - //vector3_type n_0pm = unit(vector3_type( 0, 1, -1)); - //vector3_type n_00p = unit(vector3_type( 0, 0, 1)); - //vector3_type n_000 = unit(vector3_type( 0, 0, 0)); - //vector3_type n_00m = unit(vector3_type( 0, 0, -1)); - //vector3_type n_0mp = unit(vector3_type( 0, -1, 1)); - //vector3_type n_0m0 = unit(vector3_type( 0, -1, 0)); - //vector3_type n_0mm = unit(vector3_type( 0, -1, -1)); - //vector3_type n_ppp = unit(vector3_type( 1, 1, 1)); - //vector3_type n_pp0 = unit(vector3_type( 1, 1, 0)); - //vector3_type n_ppm = unit(vector3_type( 1, 1, -1)); - //vector3_type n_p0p = unit(vector3_type( 1, 0, 1)); - //vector3_type n_p00 = unit(vector3_type( 1, 0, 0)); - //vector3_type n_p0m = unit(vector3_type( 1, 0, -1)); - //vector3_type n_pmp = unit(vector3_type( 1, -1, 1)); - //vector3_type n_pm0 = unit(vector3_type( 1, -1, 0)); - //vector3_type n_pmm = unit(vector3_type( 1, -1, -1)); - //vector3_type g_mpp; - //vector3_type g_mp0; - //vector3_type g_mpm; - //vector3_type g_m0p; - //vector3_type g_m00; - //vector3_type g_m0m; - //vector3_type g_mmp; - //vector3_type g_mm0; - //vector3_type g_mmm; - //vector3_type g_0pp; - //vector3_type g_0p0; - //vector3_type g_0pm; - //vector3_type g_00p; - //vector3_type g_000; - //vector3_type g_00m; - //vector3_type g_0mp; - //vector3_type g_0m0; - //vector3_type g_0mm; - //vector3_type g_ppp; - //vector3_type g_pp0; - //vector3_type g_ppm; - //vector3_type g_p0p; - //vector3_type g_p00; - //vector3_type g_p0m; - //vector3_type g_pmp; - //vector3_type g_pm0; - //vector3_type g_pmm; - //iterator f = F.begin(); - //const_index_iterator v = phi.begin(); - //const_index_iterator vend = phi.end(); - //for(;v!=vend;++v,++f) - //{ - // if((*v)==unused) - // { - // (*f) = value_type(); //--- should default to zero!!! - // continue; - // } - // size_t i = v.i(); - // size_t j = v.j(); - // size_t k = v.k(); - // size_t im1 = ( i ) ? i - 1 : 0; - // size_t jm1 = ( j ) ? j - 1 : 0; - // size_t km1 = ( k ) ? k - 1 : 0; - // size_t ip1 = min( i + 1u, I - 1u ); - // size_t jp1 = min( j + 1u, J - 1u ); - // size_t kp1 = min( k + 1u, K - 1u ); - // gradient(phi, im1, jp1, kp1, g_mpp ); - // gradient(phi, im1, jp1, k, g_mp0 ); - // gradient(phi, im1, jp1, km1, g_mpm ); - // gradient(phi, im1, j, kp1, g_m0p ); - // gradient(phi, im1, j, k, g_m00 ); - // gradient(phi, im1, j, km1, g_m0m ); - // gradient(phi, im1, jm1, kp1, g_mmp ); - // gradient(phi, im1, jm1, k, g_mm0 ); - // gradient(phi, im1, jm1, km1, g_mmm ); - // gradient(phi, i, jp1, kp1, g_0pp ); - // gradient(phi, i, jp1, k, g_0p0 ); - // gradient(phi, i, jp1, km1, g_0pm ); - // gradient(phi, i, j, kp1, g_00p ); - // gradient(phi, i, j, k, g_000 ); - // gradient(phi, i, j, km1, g_00m ); - // gradient(phi, i, jm1, kp1, g_0mp ); - // gradient(phi, i, jm1, k, g_0m0 ); - // gradient(phi, i, jm1, km1, g_0mm ); - // gradient(phi, ip1, jp1, kp1, g_ppp ); - // gradient(phi, ip1, jp1, k, g_pp0 ); - // gradient(phi, ip1, jp1, km1, g_ppm ); - // gradient(phi, ip1, j, kp1, g_p0p ); - // gradient(phi, ip1, j, k, g_p00 ); - // gradient(phi, ip1, j, km1, g_p0m ); - // gradient(phi, ip1, jm1, kp1, g_pmp ); - // gradient(phi, ip1, jm1, k, g_pm0 ); - // gradient(phi, ip1, jm1, km1, g_pmm ); - // real_type flux = real_type(); - // flux += unit(g_mpp) * n_mpp; - // flux += unit(g_mp0) * n_mp0; - // flux += unit(g_mpm) * n_mpm; - // flux += unit(g_m0p) * n_m0p; - // flux += unit(g_m00) * n_m00; - // flux += unit(g_m0m) * n_m0m; - // flux += unit(g_mmp) * n_mmp; - // flux += unit(g_mm0) * n_mm0; - // flux += unit(g_mmm) * n_mmm; - // flux += unit(g_0pp) * n_0pp; - // flux += unit(g_0p0) * n_0p0; - // flux += unit(g_0pm) * n_0pm; - // flux += unit(g_00p) * n_00p; - // flux += unit(g_000) * n_000; - // flux += unit(g_00m) * n_00m; - // flux += unit(g_0mp) * n_0mp; - // flux += unit(g_0m0) * n_0m0; - // flux += unit(g_0mm) * n_0mm; - // flux += unit(g_ppp) * n_ppp; - // flux += unit(g_pp0) * n_pp0; - // flux += unit(g_ppm) * n_ppm; - // flux += unit(g_p0p) * n_p0p; - // flux += unit(g_p00) * n_p00; - // flux += unit(g_p0m) * n_p0m; - // flux += unit(g_pmp) * n_pmp; - // flux += unit(g_pm0) * n_pm0; - // flux += unit(g_pmm) * n_pmm; - // flux /= 26.0; - // (*f) = static_cast(flux); - //} - - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_AOF_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_approximate_gaussian_filter.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_approximate_gaussian_filter.h deleted file mode 100644 index d246f8ebd..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_approximate_gaussian_filter.h +++ /dev/null @@ -1,86 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_APPROXIMATE_GAUSSIAN_FILTER_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_APPROXIMATE_GAUSSIAN_FILTER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Fast convolution by an approximate "integer" guassian filter. - * This just applies several box_filter's (boxsize=size and order times), - * and is only efficient for low orders. - * If size is even, the order must also be even for the resulting image to lay on the same grid - * (else translated 0.5 voxel towards (0,0,0) ). - * @param src Source grid to be convolved. - * @param order Order of filter. Corresponds to the number of times the boxfilter is applied. - * @param size Size of filter. - * @param dst Upon return, contains the filtered grid. - */ - template - inline void approximate_gaussian_filter(grid_type const& src, size_t order, size_t size, grid_type& dst) - { - typedef typename grid_type::index_vector index_vector; - dst=src; - for(size_t i=0; i0 && (i%2) && !(size%2)) - { - std::cout << "--calling translate()" << std::endl; - translate(dst, index_vector(1,1,1), dst); - } - } - } - - /** - * Approximate Gaussian filter with compensation on image borders. - * Attenuation on border regions is compensated. - * This is equivalent to Gaussian filtering using only filter coefficients - * that are inside the "shape" being considered. - * @param src Source grid to be convolved. - * @param order Order of filter. Corresponds to the number of times the boxfilter is applied. - * @param size Size of filter. - * @param dst Upon return, contains the filtered grid. - */ - template - inline void approximate_gaussian_filter_border_correct(grid_type const& src, size_t order, size_t size, grid_type &dst) - { - grid_type lowFreq=src; - - // apply filter in normal fashion - approximate_gaussian_filter(lowFreq, order, size, lowFreq); - - // compensate for border regions in filtering - // FIXME: refactor this! - /* { - Image3Df smask(src.Size()); - smask.Fill(1); - approximate_gaussian_filter(smask,order,size,smask); - for(typename grid_type::index_iterator p=lowFreq.begin(); p!=lowFreq.end(); ++p) - { - if(smask(p.Pos())) - { - *p/=smask(p.Pos()); - } - } - }*/ - dst=lowFreq; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_APPROXIMATE_GAUSSIAN_FILTER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_average.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_average.h deleted file mode 100644 index f2d21207e..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_average.h +++ /dev/null @@ -1,90 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_AVERAGE_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_AVERAGE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - template < typename grid_type > - inline void average( grid_type & phi ) - { - using std::min; - - typedef typename grid_type::index_iterator iterator; - typedef typename grid_type::value_type value_type; - - grid_type tmp = phi; - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - - iterator pend = phi.end(); - iterator p = phi.begin(); - iterator t = tmp.begin(); - - for(;p!=pend;++p,++t) - { - size_t i = p.i(); - size_t j = p.j(); - size_t k = p.k(); - - static size_t idx[27]; - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - idx[0] = ( kp1 * J + jp1 ) * I + im1; - idx[1] = ( k * J + jp1 ) * I + im1; - idx[2] = ( km1 * J + jp1 ) * I + im1; - idx[3] = ( kp1 * J + j ) * I + im1; - idx[4] = ( k * J + j ) * I + im1; - idx[5] = ( km1 * J + j ) * I + im1; - idx[6] = ( kp1 * J + jm1 ) * I + im1; - idx[7] = ( k * J + jm1 ) * I + im1; - idx[8] = ( km1 * J + jm1 ) * I + im1; - idx[9] = ( kp1 * J + jp1 ) * I + i; - idx[10] = ( k * J + jp1 ) * I + i; - idx[11] = ( km1 * J + jp1 ) * I + i; - idx[12] = ( kp1 * J + j ) * I + i; - idx[13] = ( k * J + j ) * I + i; - idx[14] = ( km1 * J + j ) * I + i; - idx[15] = ( kp1 * J + jm1 ) * I + i; - idx[16] = ( k * J + jm1 ) * I + i; - idx[17] = ( km1 * J + jm1 ) * I + i; - idx[18] = ( kp1 * J + jp1 ) * I + ip1; - idx[19] = ( k * J + jp1 ) * I + ip1; - idx[20] = ( km1 * J + jp1 ) * I + ip1; - idx[21] = ( kp1 * J + j ) * I + ip1; - idx[22] = ( k * J + j ) * I + ip1; - idx[23] = ( km1 * J + j ) * I + ip1; - idx[24] = ( kp1 * J + jm1 ) * I + ip1; - idx[25] = ( k * J + jm1 ) * I + ip1; - idx[26] = ( km1 * J + jm1 ) * I + ip1; - value_type avg = value_type(); //--- default constructed zero by standard!!! - for(size_t i=0;i<27u;++i) - avg += phi(idx[i]); - avg /= value_type(25); - *t = avg; - } - phi = tmp; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_AVERAGE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_bisection_line_search.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_bisection_line_search.h deleted file mode 100644 index 870dba7ff..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_bisection_line_search.h +++ /dev/null @@ -1,76 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_BISECTION_LINE_SEARCH_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_BISECTION_LINE_SEARCH_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Grid Bisection Line Search - * - * @param q_a - * @param q_b - * @param phi - * @param maximize If true the bisection method tries to find the maximimum value between q_a and q_b otherwise it tries to find the minimum value. - * - * @return The point that maximizes the value of phi on the line between q_a and q_b. - */ - template - inline vector3_type bisection_line_search(vector3_type q_a, vector3_type q_b, grid_type & phi, bool maximize = true) - { - using std::fabs; - typedef typename vector3_type::value_type real_type; - - real_type const precision = 10e-5;//OpenTissue::math::working_precision(100); - real_type const too_small_interval = sqr_length(q_b-q_a)*0.0001; //--- 1/100'th of distance! - vector3_type n = unit(gradient_at_point(phi,q_a)); - vector3_type r; - - - real_type const sign = maximize? 1.0 : -1.0; - - - bool forever = true; - do - { - vector3_type q_c = (q_a + q_b)*.5; - if( sqr_length(q_a - q_b) < too_small_interval ) - { - r = q_c; - break; - } - vector3_type dir = unit(gradient_at_point(phi,q_c)); - real_type n_dot_dir = inner_prod(n , dir)*sign; - if(fabs(n_dot_dir) < precision) - { - r = q_c; - break; - } - if(n_dot_dir > 0) - { - q_a = q_c; - } - if(n_dot_dir < 0) - { - q_b = q_c; - } - } - while (forever); - return r; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_BISECTION_LINE_SEARCH_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_blockify.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_blockify.h deleted file mode 100644 index 4122a72ba..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_blockify.h +++ /dev/null @@ -1,139 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_BLOCKIFY_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_BLOCKIFY_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - - -#include -#include -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Level Set Blockifier. - * This function takes a level set grid and re-initializes it into - * small cubic blocks (-1 inside and +1 outside). - * - * @param phi The level set grid. - */ - template - inline void blockify(grid_type & phi) - { - typedef typename grid_type::value_type value_type; - typedef typename grid_type::index_iterator iterator; - - value_type unused = phi.unused(); - value_type inside = value_type(-1.0); - value_type outside = value_type( 1.0); - - size_t offset = 7u; - size_t spacing = 11u; - size_t block = offset + spacing; - iterator begin = phi.begin(); - iterator end = phi.end(); - iterator p; - for(p=begin;p!=end;++p) - { - if(*p==unused) - continue; - - bool inside_i = ((p.i() % block)>offset); - bool inside_j = ((p.j() % block)>offset); - bool inside_k = ((p.k() % block)>offset); - if(inside_i && inside_j && inside_k) - *p = inside; - else - *p = outside; - } - } - - /** Initialize a grid with a pattern of boxes of width offset. - * - * @param phi The grid to initialize. - * @param inside Value to fill inside blocks - * @param outside Value to fill outside blocks - * @param offset The offset from the borders. - * @param spacing The width, height, depth and half the spacing of boxes. - */ - template - inline void blockify(grid_type & phi, value_type inside, value_type outside, size_t offset, size_t spacing) - { - typedef typename grid_type::value_type internal_type; - typedef typename grid_type::index_iterator iterator; - - internal_type unused = phi.unused(); - internal_type inside_ = (internal_type)( inside ); - internal_type outside_ = (internal_type)( outside ); - - size_t block = offset + spacing; - iterator begin = phi.begin(); - iterator end = phi.end(); - iterator p; - for(p=begin;p!=end;++p) - { - if(*p==unused) - continue; - - bool inside_i = ((p.i() % block)>offset); - bool inside_j = ((p.j() % block)>offset); - bool inside_k = ((p.k() % block)>offset); - if(inside_i && inside_j && inside_k) - *p = inside_; - else - *p = outside_; - } - } - - /** Initialize a slice of a grid with a pattern of boxes of width offset. - * - * @param phi The grid to initialize. - * @param inside Value to fill inside blocks - * @param outside Value to fill outside blocks - * @param offset The offset from the borders. - * @param spacing The width, height, and half the spacing of boxes. - * @param slice The slice in z-depth that needs to be filled - */ - template - inline void blockify(grid_type & phi, value_type inside, value_type outside, size_t offset, size_t spacing, size_t slice) - { - typedef typename grid_type::value_type internal_type; - typedef typename grid_type::index_iterator iterator; - - internal_type unused = phi.unused(); - internal_type inside_ = (internal_type)( inside ); - internal_type outside_ = (internal_type)( outside ); - - size_t block = offset + spacing; - iterator begin = phi.begin(); - iterator end = phi.end(); - iterator p; - for(p=begin;p!=end;++p) - { - if (p.k()!=slice) - continue; - if(*p==unused) - continue; - bool inside_i = ((p.i() % block)>offset); - bool inside_j = ((p.j() % block)>offset); - if(inside_i && inside_j) - *p = inside_; - else - *p = outside_; - } - } - - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_BLOCKIFY_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_closing.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_closing.h deleted file mode 100644 index 9305249ac..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_closing.h +++ /dev/null @@ -1,47 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_CLOSING_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_CLOSING_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Closing Operation. - * - * @param phi Input level set. - * @param radius Radius of spherical structural element. - * @param dt Time-step to use in update. - * @param psi Output levelset. Note if input is a signed distance map then output may not be a signed distance map, thus you may need to redistance output levelset. - */ - template< - typename grid_type_in - , typename real_type - , typename grid_type_out - > - inline void closing( - grid_type_in const & phi - , real_type const & radius - , real_type const & dt - , grid_type_out & psi - ) - { - erosion(phi,radius,dt,psi); - dilation(psi,radius,dt,psi); - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_CLOSING_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_compute_sign_function.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_compute_sign_function.h deleted file mode 100644 index a559fe93e..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_compute_sign_function.h +++ /dev/null @@ -1,49 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_COMPUTE_SIGN_FUNCTION_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_COMPUTE_SIGN_FUNCTION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - template < typename grid_type > - inline void compute_sign_function( grid_type const & phi, grid_type & S0 ) - { - using std::sqrt; - - typedef typename grid_type::value_type real_type; - typedef typename grid_type::const_index_iterator const_iterator; - typedef typename grid_type::index_iterator iterator; - - S0.create(phi.min_coord(),phi.max_coord(),phi.I(),phi.J(),phi.K()); - // yellowbook p67. - - real_type delta = phi.dx()*phi.dx() + phi.dy()*phi.dy() + phi.dz()*phi.dz(); - const_iterator begin = phi.begin(); - const_iterator end = phi.end(); - - for ( const_iterator idx = begin;idx!=end;++idx) - { - size_t i = idx.i(); - size_t j = idx.j(); - size_t k = idx.k(); - real_type c = phi( i,j,k ); - S0( i,j,k ) = c / ( sqrt( c * c + delta ) );//---TODO: Verify this formula!!! - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_COMPUTE_SIGN_FUNCTION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_coord2idx.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_coord2idx.h deleted file mode 100644 index 0b269ae05..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_coord2idx.h +++ /dev/null @@ -1,65 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_COORD_TO_IDX_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_COORD_TO_IDX_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Coordinate 2 Voxel Indices. - * This method computes the indices (i,j,k) of - * the voxel containing the specified point. - * - * The voxel index of the voxel containing the points is equal to index - * of the grid node of the containing voxel with lowest coordinates - * (ie. lower-left-back grid node). - * - * @param grid The grid. - * @param point The point. - * @param i Upon return this parameter contains the index of the voxel along the I-axe. - * @param j Upon return this parameter contains the index of the voxel along the J-axe. - * @param k Upon return this parameter contains the index of the voxel along the K-axe. - */ - template - inline void coord2idx( grid_type const & grid, vector3_type const & point, size_t & i, size_t & j, size_t & k ) - { - using std::floor; - - typedef typename vector3_type::value_type real_type; - - real_type const & dx = grid.dx(); - real_type const & dy = grid.dy(); - real_type const & dz = grid.dz(); - real_type const & mx = grid.min_coord( 0 ); - real_type const & my = grid.min_coord( 1 ); - real_type const & mz = grid.min_coord( 2 ); - - real_type xval = ( point( 0 ) - mx ) / dx; - i = static_cast( floor( xval ) ); - if ( ( xval - i ) > .5 ) - ++i; - real_type yval = ( point( 1 ) - my ) / dy; - j = static_cast( floor( yval ) ); - if ( ( yval - j ) > .5 ) - ++j; - real_type zval = ( point( 2 ) - mz ) / dz; - k = static_cast( floor( zval ) ); - if ( ( zval - k ) > .5 ) - ++k; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_COORD_TO_IDX_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_crop.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_crop.h deleted file mode 100644 index 8ffaba834..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_crop.h +++ /dev/null @@ -1,116 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_CROP_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_CROP_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Crop grid to bounding box that do not include treshold. - * Can be used to automatically crop emptyness from scanned data. - * @param M Original grid to be cropped. - * @param m Destination grid. - * @param treshold Maximum value that needs to be cropped. - * @return Upon return the destination grid m contains the cropped grid. - */ - template < typename grid_type > - inline void crop(grid_type const & M, grid_type & m, typename grid_type::value_type const & treshold) - { - using std::min; - using std::max; - - typedef typename grid_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - - typedef OpenTissue::math::Vector3 index_vector; - - index_vector min_idx( M.I(), M.J(), M.K() ); - index_vector max_idx( 0, 0, 0 ); - - for(size_t k=0; k treshold ) - { - min_idx = min( min_idx, index_vector(i,j,k) ); - max_idx = max( max_idx, index_vector(i,j,k) ); - } - } - index_vector new_dim = (max_idx - min_idx) + index_vector(1); - - vector3_type min_coord,max_coord; - idx2coord(M, min_idx(0), min_idx(1), min_idx(2),min_coord); - idx2coord(M, max_idx(0), max_idx(1), max_idx(2),max_coord); - - m.create( min_coord, max_coord, new_dim(0), new_dim(1), new_dim(2) ); - - size_t i_offset = min_idx(0); - size_t j_offset = min_idx(1); - size_t k_offset = min_idx(2); - for(size_t k=0; k - inline void crop( - grid_type const & M - , grid_type & m - , size_t min_i - , size_t min_j - , size_t min_k - , size_t max_i - , size_t max_j - , size_t max_k - ) - { - typedef typename grid_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - typedef typename grid_type::index_iterator index_iterator; - - vector3_type min_coord,max_coord; - idx2coord(M, min_i, min_j, min_k, min_coord); - idx2coord(M, max_i, max_j, max_k, max_coord); - m.create( min_coord, max_coord, max_i-min_i+1, max_j-min_j+1, max_k-min_k+1 ); - - for(size_t k=0; k - -#include - -namespace OpenTissue -{ -namespace grid -{ - - /** - * Calculate curvature flow. - * - * WARNING: Unexpected behavior if input and output level sets are the same. - * - * - * @param phi Input level set. - * @param mu Mean Curvature coefficient. - * @param dt Time-step to use in update. - * @param psi Output levelset. Note if input is a signed distance map - * then output may not be a signed distance map, thus - * you may need to redistance output levelset. - */ - template< - typename grid_type - , typename real_type - > - inline void curvature_flow( - grid_type const & phi - , real_type const & mu - , real_type const & dt - , grid_type & psi - ) - { - using std::min; - using std::max; - using std::sqrt; - - typedef typename grid_type::value_type value_type; - typedef typename grid_type::iterator iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - - assert(mu>0 || !"curvature_flow(): curvature coefficient must be positive"); - assert(dt>0 || !"curvature_flow(): time-step must be positive"); - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - real_type dx = static_cast ( phi.dx() ); - real_type dy = static_cast ( phi.dy() ); - real_type dz = static_cast ( phi.dz() ); - real_type m_inv_dx2 = static_cast ( 1.0 / (dx*dx) ); - real_type m_inv_dy2 = static_cast ( 1.0 / (dy*dy) ); - real_type m_inv_dz2 = static_cast ( 1.0 / (dz*dz) ); - real_type m_inv_4dxy = static_cast ( 0.25 / (dx*dy) ); - real_type m_inv_4dxz = static_cast ( 0.25 / (dx*dz) ); - real_type m_inv_4dyz = static_cast ( 0.25 / (dy*dz) ); - - real_type min_delta = static_cast (min(dx,min(dy,dz) )); - - real_type kappa_limit = static_cast ( 1.0 / ( max(dx, max(dy,dz) ) ) ); - - value_type zero = static_cast(0.0); - grid_type F = phi; //--- speed function - - if(&psi != &phi) - psi = phi; - - iterator fbegin = F.begin(); - index_iterator sbegin = psi.begin(); - index_iterator send = psi.end(); - - real_type threshold = static_cast(10e-15); //--- small number used to avoid division by zero!!! - - real_type time = static_cast(0.0); - while (time < dt) - { - value_type max_F = zero; //--- maximum speed, used to setup CFL condition - iterator f = fbegin; - index_iterator s = sbegin; - for(;s!=send; ++s,++f) - { - size_t i = s.i(); - size_t j = s.j(); - size_t k = s.k(); - - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1, I - 1 ); - size_t jp1 = min( j + 1, J - 1 ); - size_t kp1 = min( k + 1, K - 1 ); - - size_t idx_000 = ( k * J + j ) * I + i; - size_t idx_m00 = ( k * J + j ) * I + im1; - size_t idx_p00 = ( k * J + j ) * I + ip1; - size_t idx_0m0 = ( k * J + jm1 ) * I + i; - size_t idx_0p0 = ( k * J + jp1 ) * I + i; - size_t idx_00m = ( km1 * J + j ) * I + i; - size_t idx_00p = ( kp1 * J + j ) * I + i; - size_t idx_pp0 = ( k * J + jp1 ) * I + ip1; - size_t idx_mp0 = ( k * J + jp1 ) * I + im1; - size_t idx_pm0 = ( k * J + jm1 ) * I + ip1; - size_t idx_mm0 = ( k * J + jm1 ) * I + im1; - size_t idx_p0p = ( kp1 * J + j ) * I + ip1; - size_t idx_m0p = ( kp1 * J + j ) * I + im1; - size_t idx_p0m = ( km1 * J + j ) * I + ip1; - size_t idx_m0m = ( km1 * J + j ) * I + im1; - size_t idx_0pp = ( kp1 * J + jp1 ) * I + i; - size_t idx_0pm = ( km1 * J + jp1 ) * I + i; - size_t idx_0mp = ( kp1 * J + jm1 ) * I + i; - size_t idx_0mm = ( km1 * J + jm1 ) * I + i; - - real_type d000 = 2.0 * psi( idx_000 ); - real_type dp00 = psi( idx_p00 ); - real_type dm00 = psi( idx_m00 ); - real_type d0p0 = psi( idx_0p0 ); - real_type d0m0 = psi( idx_0m0 ); - real_type d00p = psi( idx_00p ); - real_type d00m = psi( idx_00m ); - real_type dpp0 = psi( idx_pp0 ); - real_type dmp0 = psi( idx_mp0 ); - real_type dpm0 = psi( idx_pm0 ); - real_type dmm0 = psi( idx_mm0 ); - real_type dp0p = psi( idx_p0p ); - real_type dm0p = psi( idx_m0p ); - real_type dp0m = psi( idx_p0m ); - real_type dm0m = psi( idx_m0m ); - real_type d0pp = psi( idx_0pp ); - real_type d0pm = psi( idx_0pm ); - real_type d0mp = psi( idx_0mp ); - real_type d0mm = psi( idx_0mm ); - //---- Hessian matrix is defines as - // - // | d/(dx*dx) d(/(dx*dy) d/(dx*dz) | - // H = | d/(dy*dx) d(/(dy*dy) d/(dy*dz) | phi - // | d/(dz*dx) d(/(dz*dy) d/(dz*dz) | - // - // - //--- Following is a central diff approximation - real_type psi_x = (dp00 - dm00) * m_inv_dx2; - real_type psi_y = (d0p0 - d0m0) * m_inv_dy2; - real_type psi_z = (d00p - d00m) * m_inv_dz2; - real_type psi_xx = ( dp00 + dm00 - d000 ) * m_inv_dx2; - real_type psi_yy = ( d0p0 + d0m0 - d000 ) * m_inv_dy2; - real_type psi_zz = ( d00p + d00m - d000 ) * m_inv_dz2; - real_type psi_xy = ( dpp0 - dmp0 - dpm0 + dmm0 ) * m_inv_4dxy; - real_type psi_xz = ( dp0p - dm0p - dp0m + dm0m ) * m_inv_4dxz; - real_type psi_yz = ( d0pp - d0pm - d0mp + d0mm ) * m_inv_4dyz; - real_type norm_grad_psi = sqrt( (psi_x*psi_x) + (psi_y*psi_y) + (psi_z*psi_z) ); - real_type kappa = - ( - (psi_x*psi_x)*psi_yy - + (psi_x*psi_x)*psi_zz - + (psi_y*psi_y)*psi_xx - + (psi_y*psi_y)*psi_zz - + (psi_z*psi_z)*psi_xx - + (psi_z*psi_z)*psi_yy - - 2*(psi_x*psi_y)*psi_xy - - 2*(psi_x*psi_z)*psi_xz - - 2*(psi_y*psi_z)*psi_yz - ) - / - (norm_grad_psi*norm_grad_psi*norm_grad_psi + threshold ); - - kappa = max( kappa, -kappa_limit ); - kappa = min( kappa, kappa_limit ); - - *f = static_cast(mu * kappa); - max_F = max(max_F, std::fabs(*f)); - } - real_type time_left = max( dt - time, 0.0 ); - if(time_left <= 0) - return; - - value_type time_step = static_cast( min( time_left, min_delta / (max_F) ) ); - - std::cout << "\tcurvature_flow() : timestep = " << time_step << std::endl; - - for(s=sbegin, f=fbegin;s!=send;++s,++f) - (*s) = (*s) + time_step * (*f); - time += time_step; - } - } - -} // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_CURVATURE_FLOW_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_dilation.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_dilation.h deleted file mode 100644 index 8ce3ad10f..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_dilation.h +++ /dev/null @@ -1,57 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_DILATION_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_DILATION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Dilate level set. - * - * @param phi Input level set. - * @param radius Radius of spherical structural element. - * @param dt Time-step to use in update. - * @param psi Output levelset. Note if input is a signed distance map then output may not be a signed distance map, thus you may need to redistance output levelset. - */ - template< - typename grid_type_in - , typename real_type - , typename grid_type_out - > - inline void dilation( - grid_type_in const & phi - , real_type const & radius - , real_type const & dt - , grid_type_out & psi - ) - { - typedef typename grid_type_in::value_type input_type; - typedef typename grid_type_out::value_type output_type; - typedef typename grid_type_in::const_index_iterator input_iterator; - - assert(radius>0 || !"dilation(): radius must be positive"); - assert(dt>0 || !"dilation(): time-step must be positive"); - - input_iterator input_begin = phi.begin(); - input_iterator input_end = phi.end(); - input_iterator input; - input_type unused = phi.unused(); - for(input=input_begin;input!=input_end;++input) - if(*input!=unused) - psi(input.get_index()) = *input - dt*radius; - } - - } // namespace grid - -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_DILATION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_div_grad.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_div_grad.h deleted file mode 100644 index b4e671c67..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_div_grad.h +++ /dev/null @@ -1,167 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_DIV_GRAD_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_DIV_GRAD_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Div-Grad. - * Computes the divergence of the gradient of a specified field. Ie. the flux of the gradient field! - * - * @param phi A the grid. - * @param M A grid containing the values of the divergence of the gradient field of phi. - */ - template - inline void div_grad( - grid_type const & phi - , grid_type & M - ) - { - using std::min; - - typedef OpenTissue::math::Vector3< typename grid_type::value_type> vector3_type; - - typedef typename grid_type::iterator iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::value_type value_type; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - size_t const & I = phi.I(); - size_t const & J = phi.J(); - size_t const & K = phi.K(); - M.create(phi.min_coord(),phi.max_coord(),I,J,K); - static value_type unused = phi.unused(); - - vector3_type /*g000,*/gp00,gm00,g0p0,g0m0,g00p,g00m; - vector3_type gppp,gppm,gpmp,gpmm,gmpp,gmpm,gmmp,gmmm; - vector3_type gpp0, gpm0, gmp0, gmm0, gp0p, gp0m, gm0p, gm0m, g0pp, g0pm, g0mp, g0mm; - - static vector3_type np00 = unit(vector3_type( 1, 0, 0)); - static vector3_type nm00 = unit(vector3_type(-1, 0, 0)); - static vector3_type n0p0 = unit(vector3_type( 0, 1, 0)); - static vector3_type n0m0 = unit(vector3_type( 0,-1, 0)); - static vector3_type n00p = unit(vector3_type( 0, 0, 1)); - static vector3_type n00m = unit(vector3_type( 0, 0,-1)); - static vector3_type nppp = unit(vector3_type( 1, 1, 1)); - static vector3_type nppm = unit(vector3_type( 1, 1,-1)); - static vector3_type npmp = unit(vector3_type( 1,-1, 1)); - static vector3_type npmm = unit(vector3_type( 1,-1,-1)); - static vector3_type nmpp = unit(vector3_type(-1, 1, 1)); - static vector3_type nmpm = unit(vector3_type(-1, 1,-1)); - static vector3_type nmmp = unit(vector3_type(-1,-1, 1)); - static vector3_type nmmm = unit(vector3_type(-1,-1,-1)); - static vector3_type npp0 = unit(vector3_type( 1, 1, 0)); - static vector3_type npm0 = unit(vector3_type( 1,-1, 0)); - static vector3_type nmp0 = unit(vector3_type(-1, 1, 0)); - static vector3_type nmm0 = unit(vector3_type(-1,-1, 0)); - static vector3_type np0p = unit(vector3_type( 1, 0, 1)); - static vector3_type np0m = unit(vector3_type( 1, 0,-1)); - static vector3_type nm0p = unit(vector3_type(-1, 0, 1)); - static vector3_type nm0m = unit(vector3_type(-1, 0,-1)); - static vector3_type n0pp = unit(vector3_type( 0, 1, 1)); - static vector3_type n0pm = unit(vector3_type( 0, 1,-1)); - static vector3_type n0mp = unit(vector3_type( 0,-1, 1)); - static vector3_type n0mm = unit(vector3_type( 0,-1,-1)); - - - iterator m = M.begin(); - const_index_iterator pbegin = phi.begin(); - const_index_iterator pend = phi.end(); - const_index_iterator p = pbegin; - for(;p!=pend;++p,++m) - { - if((*p)==unused) - { - *m = value_type(); //--- should default to zero!!! - continue; - } - - size_t i = p.i(); - size_t j = p.j(); - size_t k = p.k(); - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - - gradient(phi, ip1, j, k, gp00); - gradient(phi, im1, j, k, gm00); - gradient(phi, i, jp1, k, g0p0); - gradient(phi, i, jm1, k, g0m0); - gradient(phi, i, j, kp1, g00p); - gradient(phi, i, j, km1, g00m); - gradient(phi, ip1, jp1, k, gpp0); - gradient(phi, ip1, jm1, k, gpm0); - gradient(phi, im1, jp1, k, gmp0); - gradient(phi, im1, jm1, k, gmm0); - gradient(phi, ip1, j, kp1, gp0p); - gradient(phi, ip1, j, km1, gp0m); - gradient(phi, im1, j, kp1, gm0p); - gradient(phi, im1, j, km1, gm0m); - gradient(phi, i, jp1, kp1, g0pp); - gradient(phi, i, jp1, km1, g0pm); - gradient(phi, i, jm1, kp1, g0mp); - gradient(phi, i, jm1, km1, g0mm); - gradient(phi, ip1, jp1, kp1, gppp); - gradient(phi, ip1, jp1, km1, gppm); - gradient(phi, ip1, jm1, kp1, gpmp); - gradient(phi, ip1, jm1, km1, gpmm); - gradient(phi, im1, jp1, kp1, gmpp); - gradient(phi, im1, jp1, km1, gmpm); - gradient(phi, ip1, jm1, kp1, gmmp); - gradient(phi, im1, jm1, km1, gmmm); - - real_type flux = real_type(); //--- should default to zero!!! - flux += gp00 * np00; - flux += gm00 * nm00; - flux += g0p0 * n0p0; - flux += g0m0 * n0m0; - flux += g00p * n00p; - flux += g00m * n00m; - flux += gpp0 * npp0; - flux += gpm0 * npm0; - flux += gmp0 * nmp0; - flux += gmm0 * nmm0; - flux += gp0p * np0p; - flux += gp0m * np0m; - flux += gm0p * nm0p; - flux += gm0m * nm0m; - flux += g0pp * n0pp; - flux += g0pm * n0pm; - flux += g0mp * n0mp; - flux += g0mm * n0mm; - flux += gppp * nppp; - flux += gppm * nppm; - flux += gpmp * npmp; - flux += gpmm * npmm; - flux += gmpp * nmpp; - flux += gmpm * nmpm; - flux += gmmp * nmmp; - flux += gmmm * nmmm; - - (*m) = static_cast(flux); - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_DIV_GRAD_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_enclosing_indices.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_enclosing_indices.h deleted file mode 100644 index f94073ded..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_enclosing_indices.h +++ /dev/null @@ -1,79 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_ENCLOSING_INDICES_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_ENCLOSING_INDICES_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Get Enclosing Indices. - * Finds enclosing node indices for a given point. - * Assumes that the point is strictly inside the volume. - * - * @param grid The grid. - * @param point Vector with coordinates of the point. - * @param i0 Upon return, this parameter contains the i-index of the lower-left-back node. - * @param j0 Upon return, this parameter contains the j-index of the lower-left-back node. - * @param k0 Upon return, this parameter contains the k-index of the lower-left-back node. - * @param i1 Upon return, this parameter contains the i-index of the upper-right-front node. - * @param j1 Upon return, this parameter contains the j-index of the upper-right-front node. - * @param k1 Upon return, this parameter contains the k-index of the upper-right-front node. - */ - template - inline void enclosing_indices( - grid_type const & grid - , vector3_type const & point - , size_t& i0 - , size_t& j0 - , size_t& k0 - , size_t& i1 - , size_t& j1 - , size_t& k1 - ) - { - using std::max; - using std::min; - using std::floor; - - typedef typename vector3_type::value_type real_type; - - real_type const & dx = grid.dx(); - real_type const & dy = grid.dy(); - real_type const & dz = grid.dz(); - size_t const & I = grid.I(); - size_t const & J = grid.J(); - size_t const & K = grid.K(); - - vector3_type range = grid.max_coord() - grid.min_coord(); - vector3_type diff = point - grid.min_coord(); - - diff = min( max(diff, vector3_type( real_type() ) ) , range); - - diff(0) /= dx; - diff(1) /= dy; - diff(2) /= dz; - - i0 = static_cast( floor( diff(0) ) ); - j0 = static_cast( floor( diff(1) ) ); - k0 = static_cast( floor( diff(2) ) ); - i1 = ( i0 + 1 ) % I; - j1 = ( j0 + 1 ) % J; - k1 = ( k0 + 1 ) % K; - - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_ENCLOSING_INDICES_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_erosion.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_erosion.h deleted file mode 100644 index ce270382c..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_erosion.h +++ /dev/null @@ -1,56 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_EROSION_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_EROSION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Erode level set. - * - * @param phi Input level set. - * @param radius Radius of spherical structural element. - * @param dt Time-step to use in update. - * @param psi Output levelset. Note if input is a signed distance map then output may not be a signed distance map, thus you may need to redistance output levelset. - */ - template< - typename grid_type_in - , typename real_type - , typename grid_type_out - > - inline void erosion( - grid_type_in const & phi - , real_type const & radius - , real_type const & dt - , grid_type_out & psi - ) - { - typedef typename grid_type_in::value_type input_type; - typedef typename grid_type_out::value_type output_type; - typedef typename grid_type_in::const_index_iterator input_iterator; - - assert(radius>0 || !"erosion(): radius must be positive"); - assert(dt>0 || !"erosion(): time-step must be positive"); - - input_iterator input_begin = phi.begin(); - input_iterator input_end = phi.end(); - input_iterator input; - input_type unused = phi.unused(); - for(input=input_begin;input!=input_end;++input) - if(*input!=unused) - psi(input.get_index()) = *input + dt*radius; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_EROSION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_extrapolation.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_extrapolation.h deleted file mode 100644 index 65d3c9210..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_extrapolation.h +++ /dev/null @@ -1,136 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_EXTRAPOLATION_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_EXTRAPOLATION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * - * @param max_iterations The maximum number of iterations allowed to do extrapolation. - * @param stead_threshold The threshold value used to test for steady state. - */ - template < typename grid_type > - inline void extrapolation( - grid_type & S - , grid_type const & phi - , size_t max_iterations = 10 - // , double steady_threshold = 0.05 - ) - { - using std::min; - using std::max; - using std::fabs; - - typedef OpenTissue::math::Vector3< typename grid_type::value_type> vector3_type; - - typedef typename grid_type::iterator iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::value_type value_type; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - Gradient gradient; - - size_t I = S.I(); - size_t J = S.J(); - size_t K = S.K(); - - real_type dx = S.dx(); - real_type dy = S.dy(); - real_type dz = S.dz(); - - value_type zero = static_cast(0.0); - - grid_type F = S; //--- speed function - grid_type sign_phi; //--- sign function - compute_sign_function(phi,sign_phi); - - iterator fbegin = F.begin(); - index_iterator sbegin = S.begin(); - index_iterator send = S.end(); - - size_t iteration = 0; - bool steady_state = false; - - while (!steady_state) - { - value_type max_F = zero; //--- maximum speed, used to setup CFL condition - const_index_iterator p = phi.begin(); - iterator s_phi = sign_phi.begin(); - iterator f = fbegin; - index_iterator s = sbegin; - for(;s!=send; ++s,++f,++s_phi,++p) - { - size_t i = s.i(); - size_t j = s.j(); - size_t k = s.k(); - - vector3_type n = gradient(p); - - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - size_t idx = ( k * J + j ) * I + i; - size_t idx_im1 = ( k * J + j ) * I + im1; - size_t idx_ip1 = ( k * J + j ) * I + ip1; - size_t idx_jm1 = ( k * J + jm1 ) * I + i; - size_t idx_jp1 = ( k * J + jp1 ) * I + i; - size_t idx_km1 = ( km1 * J + j ) * I + i; - size_t idx_kp1 = ( kp1 * J + j ) * I + i; - value_type s_idx = S(idx); - value_type s_idx_im1 = S(idx_im1); - value_type s_idx_ip1 = S(idx_ip1); - value_type s_idx_jm1 = S(idx_jm1); - value_type s_idx_jp1 = S(idx_jp1); - value_type s_idx_km1 = S(idx_km1); - value_type s_idx_kp1 = S(idx_kp1); - value_type Spx = (s_idx_ip1 - s_idx )/ dx; - value_type Spy = (s_idx_jp1 - s_idx )/ dy; - value_type Spz = (s_idx_kp1 - s_idx )/ dz; - value_type Smx = (s_idx - s_idx_im1)/ dx; - value_type Smy = (s_idx - s_idx_jm1)/ dy; - value_type Smz = (s_idx - s_idx_km1)/ dz; - - *f = max( (*s_phi)*n(0) , zero)*Smx - + min( (*s_phi)*n(0) , zero)*Spx - + max( (*s_phi)*n(1) , zero)*Smy - + min( (*s_phi)*n(1) , zero)*Spy - + max( (*s_phi)*n(2) , zero)*Smz - + min( (*s_phi)*n(2) , zero)*Spz; - - max_F = max(max_F, fabs(*f)); - } - value_type time_step = static_cast( 1.0 / (max_F + 1.0) ); - for(s=sbegin, f=fbegin;s!=send;++s,++f) - (*s) = (*s) - time_step * (*f); - ++iteration; - if(iteration> max_iterations) - steady_state = true; - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_EXTRAPOLATION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_fast_blur.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_fast_blur.h deleted file mode 100644 index 9acdec8de..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_fast_blur.h +++ /dev/null @@ -1,292 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_FAST_BLUR_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_FAST_BLUR_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - // The idea is to represent the blurred image as f(x,s) in terms of position - // x and scale s. Gaussian blurring is accomplished by using the input image - // I(x,s0) as the initial image (of scale s0 > 0) for the partial differential - // equation - // s*df/ds = s^2*Laplacian(f) - // where the Laplacian operator is - // Laplacian = (d/dx)^2, dimension 1 - // Laplacian = (d/dx)^2+(d/dy)^2, dimension 2 - // Laplacian = (d/dx)^2+(d/dy)^2+(d/dz)^2, dimension 3 - // - // The term s*df/ds is approximated by - // s*df(x,s)/ds = (f(x,b*s)-f(x,s))/ln(b) - // for b > 1, but close to 1, where ln(b) is the natural logarithm of b. If - // you take the limit of the right-hand side as b approaches 1, you get the - // left-hand side. - // - // The term s^2*((d/dx)^2)f is approximated by - // s^2*((d/dx)^2)f = (f(x+h*s,s)-2*f(x,s)+f(x-h*s,s))/h^2 - // for h > 0, but close to zero. - // - // Equating the approximations for the left-hand side and the right-hand side - // of the partial differential equation leads to the numerical method used in - // this code. - // - // For iterative application of these functions, the caller is responsible - // for constructing a geometric sequence of scales, - // s0, s1 = s0*b, s2 = s1*b = s0*b^2, ... - // where the base b satisfies 1 < b < exp(0.5*d) where d is the dimension of - // the image. The upper bound on b guarantees stability of the finite - // difference method used to approximate the partial differential equation. - // The method assumes a pixel size of h = 1. - // - // - // Sample usage: - // - // const int iterations = ; - // double scale = 1.0, log_base = 0.125, base = exp(0.125); - // grid_type tmp(); // Same dimensions as image! - // for (int i = 0; i < iterations; ++i, scale *= base) - // { - // fast_blur(image, tmp, scale, log_base); - // ; - // } - - //---------------------------------------------------------------------------- - - namespace detail - { - template - inline void fast_blur ( grid_type & image, grid_type & tmp, double si, double sj, double sk, double log_base) - { - using std::min; - using std::ceil; - using std::floor; - - typedef typename grid_type::value_type value_type; - typedef typename grid_type::iterator iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - size_t I = image.I(); - size_t J = image.J(); - size_t K = image.K(); - - index_iterator s = image.begin(); - index_iterator s_end = image.end(); - iterator t = tmp.begin(); - for( ; s != s_end; ++s, ++t) - { - size_t i = s.i(); - size_t j = s.j(); - size_t k = s.k(); - - double dip = i + si; - double dim = i - si; - int ip = static_cast( floor(dip) ); - int im = static_cast( ceil(dim) ); - - double djp = j + sj; - double djm = j - sj; - int jp = static_cast( floor(djp) ); - int jm = static_cast( ceil(djm) ); - - double dkp = k + sk; - double dkm = k - sk; - int kp = static_cast( floor(dkp) ); - int km = static_cast( ceil(dkm) ); - - im = ( i ) ? im : 0; - jm = ( j ) ? jm : 0; - km = ( k ) ? km : 0; - ip = min( ip, I - 1 ); - jp = min( jp, J - 1 ); - kp = min( kp, K - 1 ); - - //size_t idx = ( k * J + j ) * I + i; - size_t idx_im = ( k * J + j ) * I + im; - size_t idx_ip = ( k * J + j ) * I + ip; - size_t idx_jm = ( k * J + jm ) * I + i; - size_t idx_jp = ( k * J + jp ) * I + i; - size_t idx_km = ( km * J + j ) * I + i; - size_t idx_kp = ( kp * J + j ) * I + i; - - real_type v000 = *s; - real_type vm00 = image(idx_im); - real_type vp00 = image(idx_ip); - real_type v0m0 = image(idx_jm); - real_type v0p0 = image(idx_jp); - real_type v00m = image(idx_km); - real_type v00p = image(idx_kp); - - // i portion of second central difference - double isum = -2.0*v000 + vp00 + vm00; - if ( ip < I-1 ) // not on boundary, interpolate linearly - { - real_type vpp00 = image( (k*J+j)*I+(ip+1) ); - isum += (dip-ip)*( vpp00 - vp00 ); - } - if ( im > 0 ) // not on boundary, interpolate linearly - { - real_type vmm00 = image( (k*J+j)*I+(im-1) ); - isum += (dim-im)*( vm00 - vmm00 ); - } - - // j portion of second central difference - double jsum = -2.0*v000 + v0p0 + v0m0; - if ( jp < J-1 ) // not on boundary, interpolate linearly - { - real_type v0pp0 = image( (k*J+(jp+1))*I+i ); - jsum += (djp-jp)*( v0pp0 - v0p0 ); - } - if ( jm > 0 ) // not on boundary, interpolate linearly - { - real_type v0mm0 = image( (k*J+(jm-1))*I+i ); - jsum += (djm-jm)*( v0m0 - v0mm0 ); - } - - // k portion of second central difference - double ksum = -2.0*v000 + v00p + v00m; - if ( kp < K-1 ) // use boundary value - { - real_type v00pp = image( ((kp+1)*J+j)*I+i ); - ksum += (dkp-kp)*( v00pp - v00p ); - } - if ( km > 0 ) // use boundary value - { - real_type v00mm = image( ((km-1)*J+j)*I+i ); - ksum += (dkm-km)*( v00m - v00mm ); - } - - *t = static_cast(v000 + log_base*(isum+jsum+ksum)); - } - - image = tmp; - } - - // for (k = 0; k < K; ++k) - // { - // double dkp = k + sk; - // double dkm = k - sk; - // int kp = static_cast( floor(dkp) ); - // int km = static_cast( ceil(dkm) ); - // - // for (j = 0; j < J; ++j) - // { - // double djp = j + sj; - // double djm = j - sj; - // int jp = static_cast( floor(djp) ); - // int jm = static_cast( ceil(djm) ); - // - // for (i = 0; i < I; ++i) - // { - // double dip = i + si; - // double dim = i - si; - // int ip = static_cast( floor(dip) ); - // int im = static_cast( ceil(dim) ); - // - // // i portion of second central difference - // double isum = -2.0*image(i,j,k); - // if ( ip >= I-1 ) // use boundary value - // { - // isum += image(I-1,j,k); - // } - // else // linearly interpolate - // { - // isum += image(ip,j,k)+(dip-ip)*(image(ip+1,j,k)-image(ip,j,k)); - // } - // - // if ( im <= 0 ) // use boundary value - // { - // isum += image(0,j,k); - // } - // else // linearly interpolate - // { - // isum += image(im,j,k)+(dim-im)*(image(im,j,k)-image(im-1,j,k)); - // } - // - // // j portion of second central difference - // double jsum = -2.0*image(i,j,k); - // if ( jp >= J-1 ) // use boundary value - // { - // jsum += image(i,J-1,k); - // } - // else // linearly interpolate - // { - // jsum += image(i,jp,k)+(djp-jp)*(image(i,jp+1,k)-image(i,jp,k)); - // } - // - // if ( jm <= 0 ) // use boundary value - // { - // jsum += image(i,0,k); - // } - // else // linearly interpolate - // { - // jsum += image(i,jm,k)+(djm-jm)*(image(i,jm,k)-image(i,jm-1,k)); - // } - // - // // k portion of second central difference - // double ksum = -2.0*image(i,j,k); - // if ( kp >= K-1 ) // use boundary value - // { - // ksum += image(i,j,K-1); - // } - // else // linearly interpolate - // { - // ksum += image(i,j,kp)+(dkp-kp)*(image(i,j,kp+1)-image(i,j,kp)); - // } - // - // if ( km <= 0 ) // use boundary value - // { - // ksum += image(i,j,0); - // } - // else // linearly interpolate - // { - // ksum += image(i,j,km)+(dkm-km)*(image(i,j,km)-image(i,j,km-1)); - // } - // - // tmp(i,j,k) = static_cast(image(i,j,k) + log_base*(isum+jsum+ksum)); - // } - // } - // } - - // for (k = 0; k < K; ++k) - // { - // for (j = 0; j < J; ++j) - // { - // for (i = 0; i < I; ++i) - // image(i,j,k) = tmp(i,j,k); - // } - // } - - } // namespace detail - - template - inline void fast_blur ( grid_type & image, double sx, double sy, double sz, double log_base, size_t iterations) - { - using std::exp; - - double base = exp(log_base); - grid_type tmp(image); - for( size_t i=0; i - inline void fast_blur ( grid_type & image, double s, double log_base, size_t iterations) - { - fast_blur(image, s, s, s, log_base, iterations); - } - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_FAST_BLUR_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient.h deleted file mode 100644 index 10c2140d3..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient.h +++ /dev/null @@ -1,171 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_GRADIENT_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_GRADIENT_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - - template - inline void gradient( - grid_type const & grid - , size_t i - , size_t j - , size_t k - , vector3_type & gradient - ) - { - using std::min; - - typedef typename grid_type::value_type value_type; - typedef typename vector3_type::value_type real_type; - - static value_type const unused = grid.unused(); - - size_t const & I = grid.I(); - size_t const & J = grid.J(); - size_t const & K = grid.K(); - - size_t im1 = 0, jm1 = 0, km1 = 0; - if ( i>0 ) - im1 = i - 1; - if ( j>0 ) - jm1 = j - 1; - if ( k>0 ) - km1 = k - 1; - - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - - size_t idx = ( k * J + j ) * I + i; - size_t idx_im1 = ( k * J + j ) * I + im1; - size_t idx_ip1 = ( k * J + j ) * I + ip1; - size_t idx_jm1 = ( k * J + jm1 ) * I + i; - size_t idx_jp1 = ( k * J + jp1 ) * I + i; - size_t idx_km1 = ( km1 * J + j ) * I + i; - size_t idx_kp1 = ( kp1 * J + j ) * I + i; - - //--- Return Unused-vector if any of the values in the map is unused. - gradient = vector3_type(unused,unused,unused); - - value_type s_idx = grid( idx ); - if ( s_idx == unused ) - return; - - value_type s_im1 = grid( idx_im1 ); - if ( s_im1 == unused ) - return; - - value_type s_ip1 = grid( idx_ip1 ); - if ( s_ip1 == unused ) - return; - - value_type s_jm1 = grid( idx_jm1 ); - if ( s_jm1 == unused ) - return; - - value_type s_jp1 = grid( idx_jp1 ); - if ( s_jp1 == unused ) - return; - - value_type s_km1 = grid( idx_km1 ); - if ( s_km1 == unused ) - return; - - value_type s_kp1 = grid( idx_kp1 ); - if ( s_kp1 == unused ) - return; - - real_type r_idx = static_cast( s_idx ); - real_type r_im1 = static_cast( s_im1 ); - real_type r_ip1 = static_cast( s_ip1 ); - real_type r_jm1 = static_cast( s_jm1 ); - real_type r_jp1 = static_cast( s_jp1 ); - real_type r_km1 = static_cast( s_km1 ); - real_type r_kp1 = static_cast( s_kp1 ); - - if ( i == 0 ) - { - gradient( 0 ) = ( r_ip1 - r_idx ); - gradient( 0 ) /= grid.dx(); - } - else if ( i == ( grid.I() - 1 ) ) - { - gradient( 0 ) = ( r_idx - r_im1 ); - gradient( 0 ) /= grid.dx(); - } - else - { - gradient( 0 ) = ( r_ip1 - r_im1 ); - gradient( 0 ) /= ( 2 * grid.dx() ); - } - if ( j == 0 ) - { - gradient( 1 ) = ( r_jp1 - r_idx ); - gradient( 1 ) /= grid.dy(); - } - else if ( j == ( grid.J() - 1 ) ) - { - gradient( 1 ) = ( r_idx - r_jm1 ); - gradient( 1 ) /= grid.dy(); - } - else - { - gradient( 1 ) = ( r_jp1 - r_jm1 ); - gradient( 1 ) /= ( 2 * grid.dy() ); - } - - if ( k == 0 ) - { - gradient( 2 ) = ( r_kp1 - r_idx ); - gradient( 2 ) /= grid.dz(); - } - else if ( k == ( grid.K() - 1 ) ) - { - gradient( 2 ) = ( r_idx - r_km1 ); - gradient( 2 ) /= grid.dz(); - } - else - { - gradient( 2 ) = ( r_kp1 - r_km1 ); - gradient( 2 ) /= ( 2 * grid.dz() ); - } - } - - template - inline void gradient (grid_iterator const & iter, vector3_type & gradient ) - { - typedef typename grid_iterator::grid_type grid_type; - - size_t i = iter.i(); - size_t j = iter.j(); - size_t k = iter.k(); - grid_type const & grid = iter.get_grid(); - gradient(grid, i, j, k, gradient); - } - - template - inline typename grid_iterator::math_types::vector3_type gradient (grid_iterator const & iter ) - { - typedef typename grid_iterator::math_types::vector3_type vector3_type; - - vector3_type gradient; - - gradient(iter, gradient); - return gradient; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_GRADIENT_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient_at_point.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient_at_point.h deleted file mode 100644 index 990f8b8ce..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient_at_point.h +++ /dev/null @@ -1,70 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_GRADIENT_AT_POINT_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_GRADIENT_AT_POINT_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - template - inline vector3_type gradient_at_point (grid_type const & grid, vector3_type const & point ) - { - typedef typename grid_type::value_type value_type; - - const static value_type infty = grid.infinity(); - const static value_type unused = grid.unused(); - - size_t i0, j0, k0, i1, j1, k1; - enclosing_indices(grid, point, i0, j0, k0, i1, j1, k1 ); - - vector3_type g000,g001,g010,g011,g100,g101,g110,g111; - gradient( grid, i0, j0, k0, g000 ); - gradient( grid, i1, j0, k0, g001 ); - gradient( grid, i0, j1, k0, g010 ); - gradient( grid, i1, j1, k0, g011 ); - gradient( grid, i0, j0, k1, g100 ); - gradient( grid, i1, j0, k1, g101 ); - gradient( grid, i0, j1, k1, g110 ); - gradient( grid, i1, j1, k1, g111 ); - - if ( g000( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g001( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g010( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g011( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g100( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g101( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g110( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - if ( g111( 0 ) == unused ) - return vector3_type( infty, infty, infty ); - - typename vector3_type::value_type s = ( point(0) - ( i0*grid.dx() + grid.min_coord(0) ) ) / grid.dx(); - typename vector3_type::value_type t = ( point(1) - ( j0*grid.dy() + grid.min_coord(1) ) ) / grid.dy(); - typename vector3_type::value_type u = ( point(2) - ( k0*grid.dz() + grid.min_coord(2) ) ) / grid.dz(); - - return OpenTissue::math::trillinear(g000, g001, g010, g011, g100, g101, g110, g111, s, t, u ) ; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_GRADIENT_AT_POINT_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient_magnitude.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient_magnitude.h deleted file mode 100644 index ce1633c6b..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_gradient_magnitude.h +++ /dev/null @@ -1,69 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRADIENT_MAGNITUDE_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRADIENT_MAGNITUDE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - template - inline void gradient_magnitude( - grid_type const & grid - , size_t i - , size_t j - , size_t k - , real_type & grad_mag - ) - { - using std::sqrt; - - typedef OpenTissue::math::Vector3 vector3_type; - vector3_type g; - gradient(map,i,j,k,g); - grad_mag = sqrt(g*g); - } - - template - inline void gradient_magnitude (grid_iterator const & iter, real_type & grad_mag ) - { - typedef typename grid_iterator::grid_type grid_type; - - size_t i = iter.i(); - size_t j = iter.j(); - size_t k = iter.k(); - - grid_type const & grid = iter.get_grid(); - - gradient_magnitude(grid, i, j, k, grad_mag); - } - - template - inline typename grid_iterator::math_types::real_type gradient_magnitude( grid_iterator const & iter ) - { - typedef typename grid_iterator::math_types::real_type real_type; - - real_type grad_mag; - - gradient_magnitude(iter, grad_mag); - - return grad_mag; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRADIENT_MAGNITUDE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_hessian.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_hessian.h deleted file mode 100644 index a5ecd0f4d..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_hessian.h +++ /dev/null @@ -1,156 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_HESSIAN_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_HESSIAN_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - - template - inline void hessian( - grid_type const & grid - , size_t i - , size_t j - , size_t k - , matrix3x3_type & H - ) - { - using std::min; - - typedef typename matrix3x3_type::value_type real_type; - - static grid_type * old_grid = 0; - static real_type m_inv_dx2 = 0; ///< Pre-computed value of 1./grid.dx()*grid.dx() - static real_type m_inv_dy2 = 0; ///< Pre-computed value of 1./grid.dy()*grid.dy() - static real_type m_inv_dz2 = 0; ///< Pre-computed value of 1./grid.dz()*grid.dz() - static real_type m_inv_4dxy = 0; ///< Pre-computed value of 1./4*grid.dx()*grid.dy() - static real_type m_inv_4dxz = 0; ///< Pre-computed value of 1./4*grid.dx()*grid.dz() - static real_type m_inv_4dyz = 0; ///< Pre-computed value of 1./4*grid.dy()*grid.dz() - - if(old_grid!=&grid) - { - old_grid = const_cast(&grid); - m_inv_dx2 = 1.0 / grid.dx() * grid.dx(); - m_inv_dy2 = 1.0 / grid.dy() * grid.dy(); - m_inv_dz2 = 1.0 / grid.dz() * grid.dz(); - m_inv_4dxy = 0.25 / grid.dx() * grid.dy(); - m_inv_4dxz = 0.25 / grid.dx() * grid.dz(); - m_inv_4dyz = 0.25 / grid.dy() * grid.dz(); - } - - size_t I = grid.I(); - size_t J = grid.J(); - size_t K = grid.K(); - - size_t im1 = 0, jm1 = 0, km1 = 0; - if ( i ) - im1 = i - 1; - if ( j ) - jm1 = j - 1; - if ( k ) - km1 = k - 1; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - - size_t idx_000 = ( k * J + j ) * I + i; - size_t idx_m00 = ( k * J + j ) * I + im1; - size_t idx_p00 = ( k * J + j ) * I + ip1; - size_t idx_0m0 = ( k * J + jm1 ) * I + i; - size_t idx_0p0 = ( k * J + jp1 ) * I + i; - size_t idx_00m = ( km1 * J + j ) * I + i; - size_t idx_00p = ( kp1 * J + j ) * I + i; - - real_type d000 = 2.0 * grid( idx_000 ); - real_type dp00 = grid( idx_p00 ); - real_type dm00 = grid( idx_m00 ); - real_type d0p0 = grid( idx_0p0 ); - real_type d0m0 = grid( idx_0m0 ); - real_type d00p = grid( idx_00p ); - real_type d00m = grid( idx_00m ); - - size_t idx_pp0 = ( k * J + jp1 ) * I + ip1; - size_t idx_mp0 = ( k * J + jp1 ) * I + im1; - size_t idx_pm0 = ( k * J + jm1 ) * I + ip1; - size_t idx_mm0 = ( k * J + jm1 ) * I + im1; - size_t idx_p0p = ( kp1 * J + j ) * I + ip1; - size_t idx_m0p = ( kp1 * J + j ) * I + im1; - - real_type dpp0 = grid( idx_pp0 ); - real_type dmp0 = grid( idx_mp0 ); - real_type dpm0 = grid( idx_pm0 ); - real_type dmm0 = grid( idx_mm0 ); - real_type dp0p = grid( idx_p0p ); - real_type dm0p = grid( idx_m0p ); - - size_t idx_p0m = ( km1 * J + j ) * I + ip1; - size_t idx_m0m = ( km1 * J + j ) * I + im1; - size_t idx_0pp = ( kp1 * J + jp1 ) * I + i; - size_t idx_0pm = ( km1 * J + jp1 ) * I + i; - size_t idx_0mp = ( kp1 * J + jm1 ) * I + i; - size_t idx_0mm = ( km1 * J + jm1 ) * I + i; - - real_type dp0m = grid( idx_p0m ); - real_type dm0m = grid( idx_m0m ); - real_type d0pp = grid( idx_0pp ); - real_type d0pm = grid( idx_0pm ); - real_type d0mp = grid( idx_0mp ); - real_type d0mm = grid( idx_0mm ); - //---- Hessian matrix is defines as - // - // | d/(dx*dx) d(/(dx*dy) d/(dx*dz) | - // H = | d/(dy*dx) d(/(dy*dy) d/(dy*dz) | phi - // | d/(dz*dx) d(/(dz*dy) d/(dz*dz) | - // - // - //--- Following is a central diff approximation - H( 0, 0 ) = ( dp00 + dm00 - d000 ) * m_inv_dx2; - H( 1, 1 ) = ( d0p0 + d0m0 - d000 ) * m_inv_dy2; - H( 2, 2 ) = ( d00p + d00m - d000 ) * m_inv_dz2; - H( 1, 0 ) = H( 0, 1 ) = ( dpp0 - dmp0 - dpm0 + dmm0 ) * m_inv_4dxy; - H( 0, 2 ) = H( 2, 0 ) = ( dp0p - dm0p - dp0m + dm0m ) * m_inv_4dxz; - H( 1, 2 ) = H( 2, 1 ) = ( d0pp - d0pm - d0mp + d0mm ) * m_inv_4dyz; - } - - template - inline void hessian (grid_iterator const & iter, matrix3x3_type & H ) - { - typedef typename grid_iterator::grid_type grid_type; - - size_t i = iter.i(); - size_t j = iter.j(); - size_t k = iter.k(); - - grid_type const & grid = iter.get_grid(); - - hessian(grid, i, j, k, H); - } - - - template - inline OpenTissue::math::Matrix3x3< typename grid_iterator::math_types::real_type > - hessian (grid_iterator const & iter ) - { - typedef typename grid_iterator::math_types::real_type real_type; - typedef OpenTissue::math::Matrix3x3< real_type > matrix3x3_type; - - matrix3x3_type H; - - hessian(iter, H); - - return H; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_HESSIAN_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_idx2coord.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_idx2coord.h deleted file mode 100644 index d36a636b2..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_idx2coord.h +++ /dev/null @@ -1,92 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IDX_TO_COORD_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IDX_TO_COORD_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Index To Coordinate Conversion. - * This method computes the coordinates of the voxel with indices (i,j,k) - * - * @param map The grid. - * @param i The index of the voxel along the I-axe. - * @param j The index of the voxel along the J-axe. - * @param k The index of the voxel along the K-axe. - * @param point Upon return this parameter contains the coordinates. - */ - template - inline void idx2coord( grid_type const & grid, size_t i, size_t j, size_t k, vector3_type & point ) - { - typedef typename vector3_type::value_type real_type; - assert(i - inline void idx2coord (grid_iterator const & iter, vector3_type & point ) - { - typedef typename grid_iterator::grid_type grid_type; - - size_t i = iter.i(); - size_t j = iter.j(); - size_t k = iter.k(); - - grid_type const & grid = iter.get_grid(); - - idx2coord(grid, i, j, k, point); - } - - /** - * Index To Coordinate Conversion. - * This method computes the coordinates of the voxel with indices (i,j,k) - * - * @param iter An iterator to the voxel. - * @return Holds the coordinates. - */ - template - inline typename grid_iterator::math_types::vector3_type idx2coord (grid_iterator const & iter ) - { - typedef typename grid_iterator::math_types::vector3_type vector3_type; - - vector3_type point; - - idx2coord(iter, point); - - return point; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IDX_TO_COORD_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_ignore_region.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_ignore_region.h deleted file mode 100644 index 886f25618..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_ignore_region.h +++ /dev/null @@ -1,74 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IGNORE_REGION_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IGNORE_REGION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Tag used to specify inside region of a level set (phi<0) - */ - struct inside_region_tag {}; - - /** - * Tag used to specify outside region of a level set (phi>0) - */ - struct outside_region_tag {}; - - - /** - * Mask out inside region. - * This function masks out the inside region of level set - * function by assigning the unused value to all phi<0. - * - * @param phi The level set grid. - */ - template - inline void ignore_region(grid_type & phi, inside_region_tag const & /*region*/) - { - typedef typename grid_type::value_type value_type; - typedef typename grid_type::index_iterator iterator; - - value_type unused = phi.unused(); - iterator end = phi.end(); - iterator p = phi.begin(); - for(;p!=end;++p) - if(*p < 0 ) - *p = unused; - } - - /** - * Mask out outside region. - * This function masks out the inside region of level set - * function by assigning the unused value to all phi>0. - * - * @param phi The level set grid. - */ - template - inline void ignore_region(grid_type & phi, outside_region_tag const & /*region*/) - { - typedef typename grid_type::value_type value_type; - typedef typename grid_type::index_iterator iterator; - - value_type unused = phi.unused(); - iterator end = phi.end(); - iterator p = phi.begin(); - for(;p!=end;++p) - if(*p > 0 ) - *p = unused; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IGNORE_REGION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_is_point_inside.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_is_point_inside.h deleted file mode 100644 index b5af27619..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_is_point_inside.h +++ /dev/null @@ -1,43 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IS_POINT_INSIDE_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IS_POINT_INSIDE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Point Inclusion Test. - * - * Checks if a given points is strictly inside the grid. - * Notice if point lies on boundary of grid, then - * it is not consider to be inside the grid. - * - * @param point Vector with coordinates for a point. - * @return True if point is strictly inside. False otherwise. - */ - template - inline bool is_point_inside( grid_type const & grid, vector3_type const & point ) - { - for ( size_t i = 0u;i < 3u;++i ) - { - if ( point( i ) <= grid.min_coord( i ) ) - return false; - if ( point( i ) >= grid.max_coord( i ) ) - return false; - } - return true; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_IS_POINT_INSIDE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_iterators.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_iterators.h deleted file mode 100644 index 2be1178d1..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_iterators.h +++ /dev/null @@ -1,346 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_ITERATORS_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_ITERATORS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - namespace detail - { - - //! basic iterator for walking through the WHOLE container - template - class Iterator - : public std::iterator< std::random_access_iterator_tag, typename grid_type_::value_type > - { - public: - - typedef grid_type_ grid_type; - typedef typename grid_type::math_types math_types; - - private: - - typedef OpenTissue::grid::detail::Iterator self_type; - - protected: - - typedef typename grid_type::index_vector index_vector; - grid_type * m_grid; - pointer_type m_pos; - - public: - - - grid_type & get_grid() { return *m_grid; } - grid_type const & get_grid() const { return *m_grid; } - - pointer_type const & get_pointer() const { return m_pos; } - pointer_type & get_pointer() { return m_pos; } - - public: - - Iterator() - : m_grid( 0 ) - , m_pos( 0 ) - {} - - Iterator( grid_type * grid, pointer_type pos ) - : m_grid( grid ) - , m_pos( pos ) - {} - - reference_type operator*() - { - return * m_pos; - } - - self_type operator++( int ) - { - self_type tmp = *this; - m_pos++; - return tmp; - } - - self_type &operator++() - { - m_pos++; - return *this; - } - - void operator+=( size_t m ) - { - m_pos += m; - } - - self_type operator+ ( size_t m ) - { - self_type tmp = *this; - tmp.m_pos += m; - return tmp; - } - - self_type operator- ( size_t m ) - { - self_type tmp = *this; - tmp.m_pos -= m; - return tmp; - } - - self_type operator--( int ) - { - self_type tmp = *this; - m_pos--; - return tmp; - } - - self_type &operator--() - { - m_pos--; - return *this; - } - - void operator-=( size_t m ) { m_pos -= m; } - int operator- ( self_type const & other ) const { return m_pos -other.m_pos; } - bool operator< ( self_type const & other ) const { return m_pos < other.m_pos; } - bool operator<=( self_type const & other ) const { return m_pos <= other.m_pos; } - bool operator> ( self_type const & other ) const { return m_pos > other.m_pos; } - bool operator>=( self_type const & other ) const { return m_pos >= other.m_pos; } - - // TODO: henrikd 2005-06-27 - confirm these! - index_vector compute_index() const - { - int offset = m_pos - m_grid->data(); - index_vector res; - res(2) = offset / ( m_grid->J() * m_grid->I() ); - offset = offset % ( m_grid->J() * m_grid->I() ); - res(1) = offset / m_grid->I(); - res(0) = offset % m_grid->I(); - return res; - } - - void operator+=( index_vector const & idx ) - { - m_pos += idx(0) + m_grid->I() * idx(1) + m_grid->I() * m_grid->J() * idx(2); - } - - self_type const & operator=( index_vector const & idx ) - { - m_pos = m_grid->data() + idx(0) + m_grid->I() * idx(1) + m_grid->I() * m_grid->J() * idx(2); - return *this; - } - - bool operator!=( self_type const & other ) - { - return m_pos != other.m_pos; - } - - bool operator==( self_type const & other ) - { - return m_pos == other.m_pos; - } - }; - - - //! iterator that keeps track of i,j,k position - /*! for walking through the WHOLE container */ - template - class IndexIterator - : public OpenTissue::grid::detail::Iterator - { - public: - - typedef typename grid_type::math_types math_types; - - protected: - - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::index_vector3_type index_vector; - - private: - - typedef OpenTissue::grid::detail::Iterator base_type; - typedef OpenTissue::grid::detail::IndexIterator self_type; - - // TODO: Use index_vector directly when vector is implemented as it should be! - size_t m_i; - size_t m_j; - size_t m_k; - - static size_t const m_out_of_bounds = 0u - 1u; - - void update_indices() - { - index_vector v = this->compute_index(); - m_i = v(0); - m_j = v(1); - m_k = v(2); - } - - public: - - IndexIterator() - : base_type() - , m_i(0) - , m_j(0) - , m_k(0) - {} - - IndexIterator( base_type const& other ) - : base_type( other ) - { - operator=( other ); - } - - IndexIterator( grid_type * grid, pointer_type pos ) - : base_type( grid, pos ) - { - // optionally move ijk if m_pos is not at begining of m_grid - if ( this->m_pos != this->m_grid->data() ) - { - base_type::operator=( base_type( this->m_grid, this->m_pos ).compute_index() ); - } - } - - public: - - size_t const& i() const { return m_i; } - size_t const& j() const { return m_j; } - size_t const& k() const { return m_k; } - - index_vector get_index() const - { - return index_vector( m_i, m_j, m_k ); - } - - vector3_type get_coord() const - { - return vector3_type( - m_i * this->m_grid->dx() + this->m_grid->min_coord( 0 ) - , m_j * this->m_grid->dy() + this->m_grid->min_coord( 1 ) - , m_k * this->m_grid->dz() + this->m_grid->min_coord( 2 ) - ); - } - - public: - - self_type operator++( int ) - { - self_type tmp = *this; - ++( *this ); - return tmp; - } - - self_type &operator++() - { - ++this->m_pos; - ++m_i; - if ( m_i >= this->m_grid->I() ) - { - m_i = 0u; - ++m_j; - if ( m_j >= this->m_grid->J() ) - { - m_j = 0u; - ++m_k; - } - } - return *this; - } - - self_type operator--( int ) - { - self_type tmp = *this; - --( *this ); - return tmp; - } - - self_type &operator--() - { - --this->m_pos; - --m_i; - if ( m_i == m_out_of_bounds ) - { - m_i = this->m_grid->I() - 1; - --m_j; - if ( m_j == m_out_of_bounds ) - { - m_j = this->m_grid->J() - 1; - --m_k; - } - } - return *this; - } - - // jump to new location - self_type const & operator=( index_vector const& idx ) - { - m_i = idx(0); - m_j = idx(1); - m_k = idx(2); - this->m_pos = &( *this->m_grid ) ( idx ); - return *this; - } - - void operator+=( size_t m ) - { - this->m_pos += m; - update_indices(); - } - - void operator-=( size_t m ) - { - this->m_pos -= m; - update_indices(); - } - - self_type operator+ ( size_t m ) - { - self_type tmp = *this; - tmp.m_pos += m; - tmp.update_indices(); - return tmp; - } - - self_type operator- ( size_t m ) - { - self_type tmp = *this; - tmp.m_pos -= m; - tmp.update_indices(); - return tmp; - } - - self_type const & operator= ( base_type const & other ) - { - this->m_grid = const_cast( &( other.get_grid() ) ); - this->m_pos = other.get_pointer(); - if ( this->m_pos == this->m_grid->data() ) - { - m_i = 0u; - m_j = 0u; - m_k = 0u; - } - else - { - update_indices(); - } - return *this; - } - - }; - - } // namespace detail - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_ITERATORS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_junctions.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_junctions.h deleted file mode 100644 index 42af31836..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_junctions.h +++ /dev/null @@ -1,532 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_JUNCTIONS_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_JUNCTIONS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include // Needed for BasicMathTypes - -#include -#include -#include -#include -#include - -#include - -#include -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - namespace detail - { - - template - class JunctionCandidate - { - public: - - typedef math_types_ math_types; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::real_type real_type; - - public: - - vector3_type m_center; //--- Estimated center of the largest enclosing sphere. - real_type m_radius; //--- Upper estimate of the radius of the largest enclosed sphere located at the junction point. - size_t m_cnt_boundary; //--- number of boundary that the largest enclosed sphere touches. - - public: - - JunctionCandidate(vector3_type const & center, real_type const & radius) - : m_center(center) - , m_radius(radius) - , m_cnt_boundary() - { - assert(m_radius>0 || !"JunctionCandidate(): Non-positive radius"); - } - }; - - - - template - class JunctionCollisionPolicy - { - public: - - typedef typename junction_candiate_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::real_type real_type; - typedef face_type data_type; - typedef junction_candiate_type query_type; - typedef bool result_container; - typedef OpenTissue::spatial_hashing::PrimeNumberHashFunction hash_function; - - typedef OpenTissue::spatial_hashing::Grid< vector3_type, OpenTissue::math::Vector3, data_type, hash_function> hash_grid; - - public: - - vector3_type min_coord(face_type const & face) const - { - vector3_type coord; - mesh::compute_face_minimum_coord(face,coord); - return coord; - } - - vector3_type max_coord(face_type const & face) const - { - vector3_type coord; - mesh::compute_face_maximum_coord(face,coord); - return coord; - } - - vector3_type min_coord(junction_candiate_type const & candidate) const - { - return vector3_type( - candidate.m_center(0) - candidate.m_radius - , candidate.m_center(1) - candidate.m_radius - , candidate.m_center(2) - candidate.m_radius - ); - } - - vector3_type max_coord(junction_candiate_type const & candidate) const - { - return vector3_type( - candidate.m_center(0) + candidate.m_radius - , candidate.m_center(1) + candidate.m_radius - , candidate.m_center(2) + candidate.m_radius - ); - } - - void reset(result_container & /*results*/) { } - - void report(data_type const & data, query_type const & query,result_container & /*results*/) - { - face_type * face = const_cast(&data); - junction_candiate_type * candidate = const_cast(&query); - - if(candidate->m_cnt_boundary >= 4) - return; - - - OpenTissue::geometry::Triangle triangle; - triangle.set( face ); - - typedef OpenTissue::math::BasicMathTypes< real_type, size_t> math_types; - OpenTissue::geometry::Sphere sphere(candidate->m_center,candidate->m_radius); - - if(OpenTissue::intersect::sphere_triangle(sphere,triangle)) - { - ++(candidate->m_cnt_boundary); - } - - } - }; - - }// namespace detail - - - - /** - * Detect MREP junctions. - * - * KE 2006-02-15: This is work in progress, please ignore it! - * - * @param aof A the aof grid. - * @param F A grid containing non-zero values for junctions. - */ - template - inline void junctions( - grid_type const & aof - , grid_type & phi - , mesh_type /*const*/ & mesh - , point_container & points - ) - { - using std::fabs; - using std::min; - using std::max; - using std::sqrt; - - typedef typename point_container::value_type vector3_type; - typedef typename vector3_type::value_type real_type; - typedef typename grid_type::value_type value_type; - typedef typename grid_type::const_iterator const_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename mesh_type::face_type face_type; - - - //--- vorticity w = grad cross grad(phi) Is this any good???? - // - // d gz d gy - // wx = ------ - ------ - // dy dz - // - // d gx d gz - // wy = ------ - ------ - // dz dx - // - // d gy d gx - // wy = ------ - ------ - // dx dy - // - - - - - //{ - //------------------------------------------------------- - //--- Thining based detection, sucks!!! ---------------- - //------------------------------------------------------- - //size_t I = phi.I(); - //size_t J = phi.J(); - //size_t K = phi.K(); - //value_type s[27]; - //grid_type tmp = aof; - //{ - // index_iterator t = tmp.begin(); - // const_index_iterator a = aof.begin(); - // const_index_iterator end = aof.end(); - // for(;a!=end;++a,++t) - // { - // (*t) = 0; - // size_t i = a.i(); - // size_t j = a.j(); - // size_t k = a.k(); - // if( (*a) > 0) - // (*t) = detail::compute_aof_value(phi,i,j,k,0.1); - // if( (*t) < 1e-5) - // { - // (*t) = 0; - // continue; - // } - // if( phi(i,j,k) > 0) - // { - // (*t) = 0; - // continue; - // } - // } - //} - //{ - // phi = tmp; - // index_iterator t = phi.begin(); - // index_iterator a = tmp.begin(); - // index_iterator end = tmp.end(); - // for(;a!=end;++a,++t) - // { - // size_t i = a.i(); - // size_t j = a.j(); - // size_t k = a.k(); - // if( (*a) < 1e-5) - // continue; - // size_t im1 = ( i ) ? i - 1 : 0; - // size_t jm1 = ( j ) ? j - 1 : 0; - // size_t km1 = ( k ) ? k - 1 : 0; - // size_t ip1 = min( i + 1u, I - 1u ); - // size_t jp1 = min( j + 1u, J - 1u ); - // size_t kp1 = min( k + 1u, K - 1u ); - // s[0] = tmp( im1, jm1, km1); - // s[1] = tmp( im1, jm1, k); - // s[2] = tmp( im1, jm1, kp1); - // s[3] = tmp( im1, j, km1); - // s[4] = tmp( im1, j, k); - // s[5] = tmp( im1, j, kp1); - // s[6] = tmp( im1, jp1, km1); - // s[7] = tmp( im1, jp1, k); - // s[8] = tmp( im1, jp1, kp1); - // s[9] = tmp( i, jm1, km1); - // s[10] = tmp( i, jm1, k); - // s[11] = tmp( i, jm1, kp1); - // s[12] = tmp( i, j, km1); - // s[13] = tmp( i, j, k); - // s[14] = tmp( i, j, kp1); - // s[15] = tmp( i, jp1, km1); - // s[16] = tmp( i, jp1, k); - // s[17] = tmp( i, jp1, kp1); - // s[18] = tmp( ip1, jm1, km1); - // s[19] = tmp( ip1, jm1, k); - // s[20] = tmp( ip1, jm1, kp1); - // s[21] = tmp( ip1, j, km1); - // s[22] = tmp( ip1, j, k); - // s[23] = tmp( ip1, j, kp1); - // s[24] = tmp( ip1, jp1, km1); - // s[25] = tmp( ip1, jp1, k); - // s[26] = tmp( ip1, jp1, kp1); - // bool has_zero_neighbor = false; - // bool has_larger_neighbor = false; - // bool is_maxima = true; - // for(size_t i=0u;i<27u;++i) - // { - // if(s[i]<=0) - // has_zero_neighbor = true; - // if(s[i]>s[13]) - // has_larger_neighbor = true; - // if(i!=13 && s[13]< s[i]) - // is_maxima = false; - // } - // if(!is_maxima && has_larger_neighbor && has_zero_neighbor)//--- thining - // { - // (*t) = 0; - // continue; - // } - // vector3_type p; - // idx2coord(aof, i, j, k, p); - // points.push_back(p); - // } - //} - - - - - //------------------------------------------------------- - //--- Angle based detection, sucks!!! ------------------- - //------------------------------------------------------- - //vector3_type g[27]; - //vector3_type p[27]; - //value_type s[27]; - //vector3_type d[27]; - //vector3_type q[27]; - //size_t I = phi.I(); - //size_t J = phi.J(); - //size_t K = phi.K(); - // const_index_iterator a = aof.begin(); - // const_index_iterator end = aof.end(); - // for(;a!=end;++a,++t) - // { - // size_t i = a.i(); - // size_t j = a.j(); - // size_t k = a.k(); - // if( (*a) < 1e-5) || phi(i,j,k) > 0) - // { - // continue; - // } - //size_t im1 = ( i ) ? i - 1 : 0; - //size_t jm1 = ( j ) ? j - 1 : 0; - //size_t km1 = ( k ) ? k - 1 : 0; - //size_t ip1 = min( i + 1u, I - 1u ); - //size_t jp1 = min( j + 1u, J - 1u ); - //size_t kp1 = min( k + 1u, K - 1u ); - //grid_gradient(phi, im1, jm1, km1, g[0]); - //grid_gradient(phi, im1, jm1, k, g[1]); - //grid_gradient(phi, im1, jm1, kp1, g[2]); - //grid_gradient(phi, im1, j, km1, g[3]); - //grid_gradient(phi, im1, j, k, g[4]); - //grid_gradient(phi, im1, j, kp1, g[5]); - //grid_gradient(phi, im1, jp1, km1, g[6]); - //grid_gradient(phi, im1, jp1, k, g[7]); - //grid_gradient(phi, im1, jp1, kp1, g[8]); - //grid_gradient(phi, i, jm1, km1, g[9]); - //grid_gradient(phi, i, jm1, k, g[10]); - //grid_gradient(phi, i, jm1, kp1, g[11]); - //grid_gradient(phi, i, j, km1, g[12]); - //grid_gradient(phi, i, j, k, g[13]); - //grid_gradient(phi, i, j, kp1, g[14]); - //grid_gradient(phi, i, jp1, km1, g[15]); - //grid_gradient(phi, i, jp1, k, g[16]); - //grid_gradient(phi, i, jp1, kp1, g[17]); - //grid_gradient(phi, ip1, jm1, km1, g[18]); - //grid_gradient(phi, ip1, jm1, k, g[19]); - //grid_gradient(phi, ip1, jm1, kp1, g[20]); - //grid_gradient(phi, ip1, j, km1, g[21]); - //grid_gradient(phi, ip1, j, k, g[22]); - //grid_gradient(phi, ip1, j, kp1, g[23]); - //grid_gradient(phi, ip1, jp1, km1, g[24]); - //grid_gradient(phi, ip1, jp1, k, g[25]); - //grid_gradient(phi, ip1, jp1, kp1, g[26]); - //grid_idx2coord(phi, im1, jm1, km1, p[0]); - //grid_idx2coord(phi, im1, jm1, k, p[1]); - //grid_idx2coord(phi, im1, jm1, kp1, p[2]); - //grid_idx2coord(phi, im1, j, km1, p[3]); - //grid_idx2coord(phi, im1, j, k, p[4]); - //grid_idx2coord(phi, im1, j, kp1, p[5]); - //grid_idx2coord(phi, im1, jp1, km1, p[6]); - //grid_idx2coord(phi, im1, jp1, k, p[7]); - //grid_idx2coord(phi, im1, jp1, kp1, p[8]); - //grid_idx2coord(phi, i, jm1, km1, p[9]); - //grid_idx2coord(phi, i, jm1, k, p[10]); - //grid_idx2coord(phi, i, jm1, kp1, p[11]); - //grid_idx2coord(phi, i, j, km1, p[12]); - //grid_idx2coord(phi, i, j, k, p[13]); - //grid_idx2coord(phi, i, j, kp1, p[14]); - //grid_idx2coord(phi, i, jp1, km1, p[15]); - //grid_idx2coord(phi, i, jp1, k, p[16]); - //grid_idx2coord(phi, i, jp1, kp1, p[17]); - //grid_idx2coord(phi, ip1, jm1, km1, p[18]); - //grid_idx2coord(phi, ip1, jm1, k, p[19]); - //grid_idx2coord(phi, ip1, jm1, kp1, p[20]); - //grid_idx2coord(phi, ip1, j, km1, p[21]); - //grid_idx2coord(phi, ip1, j, k, p[22]); - //grid_idx2coord(phi, ip1, j, kp1, p[23]); - //grid_idx2coord(phi, ip1, jp1, km1, p[24]); - //grid_idx2coord(phi, ip1, jp1, k, p[25]); - //grid_idx2coord(phi, ip1, jp1, kp1, p[26]); - //s[0] = phi( im1, jm1, km1); - //s[1] = phi( im1, jm1, k); - //s[2] = phi( im1, jm1, kp1); - //s[3] = phi( im1, j, km1); - //s[4] = phi( im1, j, k); - //s[5] = phi( im1, j, kp1); - //s[6] = phi( im1, jp1, km1); - //s[7] = phi( im1, jp1, k); - //s[8] = phi( im1, jp1, kp1); - //s[9] = phi( i, jm1, km1); - //s[10] = phi( i, jm1, k); - //s[11] = phi( i, jm1, kp1); - //s[12] = phi( i, j, km1); - //s[13] = phi( i, j, k); - //s[14] = phi( i, j, kp1); - //s[15] = phi( i, jp1, km1); - //s[16] = phi( i, jp1, k); - //s[17] = phi( i, jp1, kp1); - //s[18] = phi( ip1, jm1, km1); - //s[19] = phi( ip1, jm1, k); - //s[20] = phi( ip1, jm1, kp1); - //s[21] = phi( ip1, j, km1); - //s[22] = phi( ip1, j, k); - //s[23] = phi( ip1, j, kp1); - //s[24] = phi( ip1, jp1, km1); - //s[25] = phi( ip1, jp1, k); - //s[26] = phi( ip1, jp1, kp1); - //for(size_t i=0u;i<27u;++i) - //{ - // q[i] = p[i] - g[i]*s[i]; - // d[i] = q[i] - p[i]; - //} - //bool is_junction = false; - //real_type min_cos_theta = 100000.0; - //real_type max_cos_theta = 0.0; - //for(size_t i=0u;i<27u;++i) - //{ - // if(i==13) - // continue; - // for(size_t j=i+1;j<27u;++j) - // { - // if(j==13) - // continue; - // real_type cos_theta = fabs( g[i] * g[j] ); - // cos_theta = max(0.0, min(cos_theta, 1.0)); - // min_cos_theta = min(cos_theta,min_cos_theta); - // max_cos_theta = max(cos_theta,max_cos_theta); - // } - //} - //std::cout << min_cos_theta << " " << max_cos_theta << std::endl; - //if(min_cos_theta >0.01 && min_cos_theta< 0.99) - // is_junction = true; - //if(is_junction) - //points.push_back(p[13]); - // } - //------------------------------------------------------- - //------------------------------------------------------- - //------------------------------------------------------- - - std::cout << "junctions(): junction candiates = " << points.size() << std::endl; - } - - - template - inline void junctions2( - grid_type const & aof - , grid_type const & phi - , mesh_type /*const*/ & mesh - , point_container & points - ) - { - //--- For each point in the clamped AOF take a sphere with radius - //--- equal to the distance value plus some small threshold (voxel size!), test - //--- the sphere for intersection with the mesh-faces - //--- - //--- If at least four intersection points are found, then the AOF point is a potential junction... no! Think of a pyramid - //--- - //--- At least four points is necessary but not a sufficient condition... - //--- - //--- For each intersection take a vector from the AOF point to the face intersection point, if all such vectors - //--- contrain the sphere then we have a junction point. That is the vectors must span the entire R^3 (to remove - //--- 3DOF of translation motion of the sphere along the mrep). - //--- - //--- Do we need sub-pixel precision of AOF points?...... - //--- - //--- - //--- - //--- culver : exact polyhedra - //--- foskey : theta-SMA - //--- hoffmann: voronoi-region/distance map - //--- - //--- - //--- - //--- - - using std::fabs; - using std::min; - using std::sqrt; - - typedef typename point_container::value_type vector3_type; - typedef typename vector3_type::value_type real_type; - typedef typename grid_type::const_iterator const_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - - typedef typename grid_type::math_types math_types; - typedef typename mesh_type::face_type face_type; - typedef detail::JunctionCandidate candidate_type; - - typedef std::list candidate_container; - typedef detail::JunctionCollisionPolicy collision_policy; - typedef AABBDataQuery< typename collision_policy::hash_grid, collision_policy > query_algorithm; - - bool results = false; - query_algorithm query; - candidate_container candidates; - - { - real_type dx = phi.dx()*0.5; - real_type dy = phi.dy()*0.5; - real_type dz = phi.dz()*0.5; - real_type rho = sqrt(dx*dx+dy*dy+dz*dz)*.5; - - const_iterator p = phi.begin(); - const_index_iterator a = aof.begin(); - const_index_iterator end = aof.end(); - for(;a!=end;++a,++p) - { - if( (*a) < 1e-5 || (*p) >= 0) - continue; - vector3_type center; - idx2coord(a,center); - real_type radius = fabs( *p ); - candidate_type candidate(center,radius + rho); - candidates.push_back(candidate); - } - } - - query.init(candidates.begin(),candidates.end()); - query(mesh.face_begin(), mesh.face_end(), candidates.begin(), candidates.end(), results, typename query_algorithm::all_tag() ); - - size_t cnt = 0; - for(typename candidate_container::iterator c = candidates.begin(); c!=candidates.end();++c) - { - if(c->m_cnt_boundary >= 4) - { - points.push_back(c->m_center ); - ++cnt; - } - } - std::cout << "junctions2(): junction candiates = " << cnt << std::endl; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_JUNCTIONS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_local_minima.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_local_minima.h deleted file mode 100644 index 99b921011..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_local_minima.h +++ /dev/null @@ -1,160 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_LOCAL_MINIMA_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_LOCAL_MINIMA_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - namespace detail - { - /** - * Test if a specified node is a strict local minima. - * - * @param i - * @param j - * @param k - * @param phi - * - * @return True if node i,j,k is a local minima, otherwise false. - */ - template < typename grid_type > - inline bool is_local_minima( - size_t i - , size_t j - , size_t k - , grid_type const & phi - ) - { - using std::min; - static size_t idx[27]; - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - idx[0] = ( kp1 * J + jp1 ) * I + im1; - idx[1] = ( k * J + jp1 ) * I + im1; - idx[2] = ( km1 * J + jp1 ) * I + im1; - idx[3] = ( kp1 * J + j ) * I + im1; - idx[4] = ( k * J + j ) * I + im1; - idx[5] = ( km1 * J + j ) * I + im1; - idx[6] = ( kp1 * J + jm1 ) * I + im1; - idx[7] = ( k * J + jm1 ) * I + im1; - idx[8] = ( km1 * J + jm1 ) * I + im1; - idx[9] = ( kp1 * J + jp1 ) * I + i; - idx[10] = ( k * J + jp1 ) * I + i; - idx[11] = ( km1 * J + jp1 ) * I + i; - idx[12] = ( kp1 * J + j ) * I + i; - idx[13] = ( k * J + j ) * I + i; - idx[14] = ( km1 * J + j ) * I + i; - idx[15] = ( kp1 * J + jm1 ) * I + i; - idx[16] = ( k * J + jm1 ) * I + i; - idx[17] = ( km1 * J + jm1 ) * I + i; - idx[18] = ( kp1 * J + jp1 ) * I + ip1; - idx[19] = ( k * J + jp1 ) * I + ip1; - idx[20] = ( km1 * J + jp1 ) * I + ip1; - idx[21] = ( kp1 * J + j ) * I + ip1; - idx[22] = ( k * J + j ) * I + ip1; - idx[23] = ( km1 * J + j ) * I + ip1; - idx[24] = ( kp1 * J + jm1 ) * I + ip1; - idx[25] = ( k * J + jm1 ) * I + ip1; - idx[26] = ( km1 * J + jm1 ) * I + ip1; - - for(size_t i=0;i<27u;++i) - if( phi(idx[13]) > phi(idx[i]) ) - return false; - return true; - } - - } // namespace detail - - - /** - * Extract local minima nodes. - * Note that local minima may exist at non-nodal locations. This function - * only considers nodal positions. Thus if you are looking for local minima - * at sub-pixel accuracy, then you need another approach. - * - * @param phi The map from where local minima nodes should be extracted from. - * @param points Upon return this container contains all the coordinates of all nodes that where local minima. - */ - template < typename grid_type,typename point_container > - inline void local_minima_as_points( - grid_type const & phi - , point_container & points - ) - { - typedef typename point_container::value_type vector3_type; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename vector3_type::value_type real_type; - typedef typename grid_type::value_type value_type; - - const_index_iterator pend = phi.end(); - const_index_iterator p = phi.begin(); - for(;p!=pend;++p) - { - if(detail::is_local_minima(p.i(),p.j(),p.k(),phi)) - { - vector3_type point; - idx2coord(phi,p.i(),p.j(),p.k(),point); - points.push_back(point); - } - } - } - - /** - * Extract Local Minima as Points. - * - * @param phi - * @param mask A mask that can be used to mask-out nodes in phi, which is not - * of interest. Positive values correspond to nodes that are allowed - * to be classified as local minima. - * @param points - */ - template < typename grid_type,typename point_container > - inline void local_minima_as_points( - grid_type const & phi - , grid_type const & mask - , point_container & points - ) - { - typedef typename point_container::value_type vector3_type; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename vector3_type::value_type real_type; - typedef typename grid_type::value_type value_type; - const_index_iterator end = phi.end(); - const_index_iterator p = phi.begin(); - const_index_iterator m = mask.begin(); - for(;p!=end;++p,++m) - { - if( (*m) <= 0 ) - continue; - if(detail::is_local_minima(p.i(),p.j(),p.k(),phi)) - { - vector3_type point; - idx2coord(phi,p.i(),p.j(),p.k(),point); - points.push_back(point); - } - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_LOCAL_MINIMA_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_mean_curvature.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_mean_curvature.h deleted file mode 100644 index ec9e2cf51..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_mean_curvature.h +++ /dev/null @@ -1,94 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_MEAN_CURVATURE_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_MEAN_CURVATURE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - template - inline void mean_curvature( - grid_type const & grid - , size_t i - , size_t j - , size_t k - , real_type & K - ) - { - using std::min; - using std::max; - using std::pow; - - typedef OpenTissue::math::Vector3 vector3_type; - typedef OpenTissue::math::Matrix3x3 matrix3x3_type; - - real_type limit_K = boost::numeric_cast( 1. / min( grid.dx(), min( grid.dy(), grid.dz() ) ) ); - - vector3_type g; - matrix3x3_type H; - - gradient( grid, i, j, k, g ); - hessian( grid, i, j, k, H ); - real_type h = g * g; - - //--- Test whether the gradient was zero, if so we simply imagine it has norm one, a better - //--- solution would proberly be to pick a random node and compute the curvature information - //--- herein (this is suggest by Oscher and Fedkiw). - if ( h == 0 ) - h = 1; - //--- Compute Mean curvature, defined as: kappa = \nabla \cdot (\nabla \phi / \norm{\nabla \phi} ) - const static real_type exponent = boost::numeric_cast( 3. / 2. ); - K = ( 1.0 / pow( h, exponent ) ) * ( - g( 0 ) * g( 0 ) * ( H( 1, 1 ) + H( 2, 2 ) ) - 2. * g( 1 ) * g( 2 ) * H( 1, 2 ) + - g( 1 ) * g( 1 ) * ( H( 0, 0 ) + H( 2, 2 ) ) - 2. * g( 0 ) * g( 2 ) * H( 0, 2 ) + - g( 2 ) * g( 2 ) * ( H( 0, 0 ) + H( 1, 1 ) ) - 2. * g( 0 ) * g( 1 ) * H( 0, 1 ) - ); - //--- Clamp Curvature, it does not make sense if we compute - //--- a curvature value that can not be representated with the - //--- current map resolution. - K = min( K, limit_K ); - K = max( K, -limit_K ); - } - - template - inline void mean_curvature (grid_iterator const & iter, real_type & K) - { - typedef typename grid_iterator::grid_type grid_type; - - size_t i = iter.i(); - size_t j = iter.j(); - size_t k = iter.k(); - - grid_type const & grid = iter.get_grid(); - mean_curvature(grid, i, j, k, K); - } - - template - inline typename grid_iterator::math_types::real_type mean_curvature( grid_iterator const & iter ) - { - typedef typename grid_iterator::math_types::real_type real_type; - - real_type K; - mean_curvature(iter, K); - - return K; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_MEAN_CURVATURE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_metamorphosis.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_metamorphosis.h deleted file mode 100644 index f64300830..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_metamorphosis.h +++ /dev/null @@ -1,239 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_METAMORPHOSIS_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_METAMORPHOSIS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Auxilliary function used by metamorphosis(). - * - * This function compute the normal velocity flow. - * - * - * - * @param phi The current surface - * @param gamma The inside-outside function of target surface - * @param F Upon return contains the normal velocity flow field. - */ - template< - typename grid_type - > - inline void metamorphosis_speed_function( - grid_type const & phi - , grid_type const & gamma - , grid_type & F - ) - { - using std::min; - using std::max; - using std::sqrt; - - typedef typename grid_type::value_type value_type; - typedef typename grid_type::iterator iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - real_type dx = phi.dx(); - real_type dy = phi.dy(); - real_type dz = phi.dz(); - - const_index_iterator end = phi.end(); - const_index_iterator u = phi.begin(); - index_iterator f = F.begin(); - const_index_iterator g = gamma.begin(); - - for(;u!=end; ++u,++g,++f) - { - size_t i = u.i(); - size_t j = u.j(); - size_t k = u.k(); - - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - size_t idx = ( k * J + j ) * I + i; - size_t idx_im1 = ( k * J + j ) * I + im1; - size_t idx_ip1 = ( k * J + j ) * I + ip1; - size_t idx_jm1 = ( k * J + jm1 ) * I + i; - size_t idx_jp1 = ( k * J + jp1 ) * I + i; - size_t idx_km1 = ( km1 * J + j ) * I + i; - size_t idx_kp1 = ( kp1 * J + j ) * I + i; - real_type u_idx = phi(idx); - real_type u_idx_im1 = phi(idx_im1); - real_type u_idx_ip1 = phi(idx_ip1); - real_type u_idx_jm1 = phi(idx_jm1); - real_type u_idx_jp1 = phi(idx_jp1); - real_type u_idx_km1 = phi(idx_km1); - real_type u_idx_kp1 = phi(idx_kp1); - - real_type Upx = (u_idx_ip1 - u_idx )/ dx; - real_type Upy = (u_idx_jp1 - u_idx )/ dy; - real_type Upz = (u_idx_kp1 - u_idx )/ dz; - real_type Umx = (u_idx - u_idx_im1)/ dx; - real_type Umy = (u_idx - u_idx_jm1)/ dy; - real_type Umz = (u_idx - u_idx_km1)/ dz; - - real_type Upx_min = min( Upx, 0.0); - real_type Upx_max = max( Upx, 0.0); - real_type Umx_min = min( Umx, 0.0); - real_type Umx_max = max( Umx, 0.0); - - real_type Upy_min = min( Upy, 0.0); - real_type Upy_max = max( Upy, 0.0); - real_type Umy_min = min( Umy, 0.0); - real_type Umy_max = max( Umy, 0.0); - - real_type Upz_min = min( Upz, 0.0); - real_type Upz_max = max( Upz, 0.0); - real_type Umz_min = min( Umz, 0.0); - real_type Umz_max = max( Umz, 0.0); - - if(-(*g)>=0) - *f = (*g)*sqrt( - Upx_min*Upx_min - + Umx_max*Umx_max - + Upy_min*Upy_min - + Umy_max*Umy_max - + Upz_min*Upz_min - + Umz_max*Umz_max - ); - else - *f = (*g)*sqrt( - Upx_max*Upx_max - + Umx_min*Umx_min - + Upy_max*Upy_max - + Umy_min*Umy_min - + Upz_max*Upz_max - + Umz_min*Umz_min - ); - } - //std::cout << "metamorphosis_speed_function(): done..." << std::endl; - } - - - /** - * Solid Shape Metamorphosis. - * - * Solve the PDE: - * - * \frac{\partial \phi(x) }{ \partial t} = | \nabla \phi(x)| \gamma(x) - * - * where \gamma usually is an inside-outside function of the target - * object. Usually the signed distance map of the target is used as - * \gamma. That is - * - * \gamma (x) = \phi_target (x) - * - * It could be defined more genrally as - * - * \gamma (x) = f ( \phi_target (x) ) - * - * where the function f is used to control the speed of the moving - * interface of phi. - * - * - * The process is controlled by the user by defining the initial overlapping - * regions of source and target. - * - * - * The final metamorphosis strategy is - * - * \frac{\partial \phi(x) }{ \partial t} = | \nabla \phi(x)| \gamma( T(x,alpha) ) - * - * Given the coordinate transform: - * - * y = T(x,alpha) - * - * where x is a point in source and y is corresponding point in - * target, and 0 \leq alpha \leq 1 is a parameterization such that - * - * T(x,0) = x - * T(x,1) = y - * - * The transform T is for instance useful for alignment of the objects. - * - * - * The flow is implemented using a upwind (Godonov) scheme. Currently - * implementation do not support the T-transform. The user do have the - * option of applying an f-function outside the function, since only - * the gamma-field is surplied to this function. - * - * - * @param phi Input/output level set. - * @param gamma The inside/outside function of the target object. - * @param dt The time-step size. - */ - template< - typename grid_type - > - inline void metamorphosis( - grid_type & phi - , grid_type const & gamma - , typename grid_type::math_types::real_type const & dt - ) - { - typedef typename grid_type::value_type value_type; - typedef typename grid_type::iterator iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - using std::min; - using std::max; - using std::fabs; - - real_type dx = phi.dx(); - real_type dy = phi.dy(); - real_type dz = phi.dz(); - - grid_type F = phi; - - real_type min_delta = min ( dx, min( dy, dz)); - assert(min_delta>0 || !"metamorphosis(): minimum spacing was non-positive!"); - real_type max_gamma = max ( fabs( max(gamma)), fabs( min(gamma) ) ); - assert(max_gamma>0 || !"metamorphosis(): maximum absolute speed was non-positive!"); - real_type time = static_cast(0.0); - - while (time < dt) - { - metamorphosis_speed_function(phi,gamma,F); - - real_type time_step = min( dt, min_delta / (3.0*max_gamma) ); - assert(time_step>0 || !"metamorphosis(): time_step was non-positive!"); - std::cout << "\ttime step = " << time_step << std::endl; - - index_iterator end = phi.end(); - index_iterator u = phi.begin(); - index_iterator f = F.begin(); - for(;u!=end; ++u,++f) - (*u) = (*u) + time_step *(*f); - - time += time_step; - } - std::cout << "metamorphosis(): done..." << std::endl; - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_METAMORPHOSIS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_opening.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_opening.h deleted file mode 100644 index 720ff90e8..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_opening.h +++ /dev/null @@ -1,48 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_OPENING_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_OPENING_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Opening Operation. - * - * @param phi Input level set. - * @param radius Radius of spherical structural element. - * @param dt Time-step to use in update. - * @param psi Output levelset. Note if input is a signed distance map then output may not be a signed distance map, thus you may need to redistance output levelset. - */ - template< - typename grid_type_in - , typename real_type - , typename grid_type_out - > - inline void opening( - grid_type_in const & phi - , real_type const & radius - , real_type const & dt - , grid_type_out & psi - ) - { - dilation(phi,radius,dt,psi); - erosion(psi,radius,dt,psi); - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_OPENING_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_poisson_solver.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_poisson_solver.h deleted file mode 100644 index 6cc9edae4..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_poisson_solver.h +++ /dev/null @@ -1,177 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_POISSON_SOLVER_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_POISSON_SOLVER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Gauss-Seidel Poisson Solver with Pure Von Neuman Boundary Conditions. - * - * Theory: Given the PDE - * - * \nabla^2 \phi = W - * - * Solve for phi. Writing out we have - * - * \frac{\partial^2}{\partial x^2} phi + \frac{\partial^2}{\partial y^2} phi + \frac{\partial^2}{\partial z^2} phi = W - * - * Using central diff approximation leads to - * - * a_2 ( phi_{i+1,j,k} + phi_{i-1,j,k} ) + a_1( phi_{i,j+1,k} + phi_{i,j-1,k} ) + a_0( phi_{i,j,k+1} + phi_{i,j,k-1} ) - a_3 W - * phi_{i,j,k} = -------------------------------------------------------------------------------------------------------------------------------- - * 2 a_4 - * - * where - * - * a_0 = (dx*dx*dy*dy) - * a_1 = (dx*dx*dz*dz) - * a_2 = (dy*dy*dz*dz) - * a_3 = (dx*dx*dy*dy*dz*dz) - * a_4 = a_0 + a_1 + a_2 - * - * In case dx=dy=dz this simplifies to - * - * phi_{i+1,j,k} + phi_{i-1,j,k} + phi_{i,j+1,k} + phi_{i,j-1,k} + phi_{i,j,k+1} + phi_{i,j,k-1} - dx*dx W - * phi_{i,j,k} = ---------------------------------------------------------------------------------------------------------- - * 8 - * - * The solver uses pure Neumann bondary conditions. i.e.: - * - * \nabla phi = 0 - * - * on any boundary. This means that values outside boundary are copied from - * nearest boundary voxel => claming out-of-bound indices onto boundary. - * - * @param phi Contains initial guess for solution, and upon - * return contains the solution. - * @param b The right hand side of the poisson equation. - * @param max_iterations The maximum number of iterations allowed. Default is 30 iterations. - */ - template < typename grid_type > - inline void poisson_solver( - grid_type & phi - , grid_type const & W - , size_t max_iterations = 10 - ) - { - using std::min; - - typedef typename grid_type::value_type value_type; - typedef typename grid_type::const_iterator const_iterator; - typedef typename grid_type::index_iterator index_iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - real_type dx = phi.dx(); - real_type dy = phi.dy(); - real_type dz = phi.dz(); - - if(dx!=dy || dx!=dz || dy!=dz) - { - //std::cout << "poisson_solver(): non-uniform grid" << std::endl; - - real_type a0 = dx*dx*dy*dy; - real_type a1 = dx*dx*dz*dz; - real_type a2 = dy*dy*dz*dz; - real_type a3 = dx*dx*dy*dy*dz*dz; - real_type a4 = 1.0/(2*(a0 + a1 + a2)); - - for(size_t iteration=0;iteration - -#include - -#include -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - namespace detail - { - class FullRedistance - { - protected: - - template < typename grid_type > - typename grid_type::value_type compute_speed( - grid_type const & phi - , grid_type const & S0 - , grid_type & speed - ) - { - using std::min; - using std::max; - using std::sqrt; - using std::fabs; - - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::const_iterator const_iterator; - typedef typename grid_type::iterator iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::value_type real_type; - - assert(phi.I()==S0.I() || !"compute_speed(): incompatible grid dimensions"); - assert(phi.J()==S0.J() || !"compute_speed(): incompatible grid dimensions"); - assert(phi.K()==S0.K() || !"compute_speed(): incompatible grid dimensions"); - assert(phi.min_coord()==S0.min_coord() || !"compute_speed(): incompatible grid side lengths"); - assert(phi.max_coord()==S0.max_coord() || !"compute_speed(): incompatible grid side lengths"); - - speed.create(phi.min_coord(),phi.max_coord(),phi.I(),phi.J(),phi.K()); - - real_type inv_dx = static_cast ( 1.0 / phi.dx()); - real_type inv_dy = static_cast ( 1.0 / phi.dy()); - real_type inv_dz = static_cast ( 1.0 / phi.dz()); - - real_type inv_dx2 = inv_dx*inv_dx; - real_type inv_dy2 = inv_dx*inv_dy; - real_type inv_dz2 = inv_dx*inv_dz; - - real_type cfl_condition = real_type(0.0); - real_type zero = static_cast(0.0); - - iterator f = speed.begin(); - const_index_iterator p = phi.begin(); - const_index_iterator end = phi.end(); - const_iterator s0 = S0.begin(); - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - - for ( ; p != end; ++p, ++f,++s0) - { - size_t i = p.i(); - size_t j = p.j(); - size_t k = p.k(); - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1, I - 1 ); - size_t jp1 = min( j + 1, J - 1 ); - size_t kp1 = min( k + 1, K - 1 ); - size_t idx_000 = ( k * J + j ) * I + i; - size_t idx_m00 = ( k * J + j ) * I + im1; - size_t idx_p00 = ( k * J + j ) * I + ip1; - size_t idx_0m0 = ( k * J + jm1 ) * I + i; - size_t idx_0p0 = ( k * J + jp1 ) * I + i; - size_t idx_00m = ( km1 * J + j ) * I + i; - size_t idx_00p = ( kp1 * J + j ) * I + i; - real_type d000 = phi( idx_000 ); - real_type dp00 = phi( idx_p00 ); - real_type dm00 = phi( idx_m00 ); - real_type d0p0 = phi( idx_0p0 ); - real_type d0m0 = phi( idx_0m0 ); - real_type d00p = phi( idx_00p ); - real_type d00m = phi( idx_00m ); - assert( is_finite( d000 ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dp00 ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dm00 ) || !"compute_speed(): NaN encountered"); - assert( is_finite( d0p0 ) || !"compute_speed(): NaN encountered"); - assert( is_finite( d0m0 ) || !"compute_speed(): NaN encountered"); - assert( is_finite( d00p ) || !"compute_speed(): NaN encountered"); - assert( is_finite( d00m ) || !"compute_speed(): NaN encountered"); - real_type dxp = (dp00 - d000)*inv_dx; - real_type dxm = (d000 - dm00)*inv_dx; - real_type dyp = (d0p0 - d000)*inv_dy; - real_type dym = (d000 - d0m0)*inv_dy; - real_type dzp = (d00p - d000)*inv_dz; - real_type dzm = (d000 - d00m)*inv_dz; - assert( is_finite( dxp ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dxm ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dyp ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dym ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dzp ) || !"compute_speed(): NaN encountered"); - assert( is_finite( dzm ) || !"compute_speed(): NaN encountered"); - real_type dxp_max = max( dxp, zero ); - real_type dxm_max = max( dxm, zero ); - real_type dyp_max = max( dyp, zero ); - real_type dym_max = max( dym, zero ); - real_type dzp_max = max( dzp, zero ); - real_type dzm_max = max( dzm, zero ); - real_type dxp_min = min( dxp, zero ); - real_type dxm_min = min( dxm, zero ); - real_type dyp_min = min( dyp, zero ); - real_type dym_min = min( dym, zero ); - real_type dzp_min = min( dzp, zero ); - real_type dzm_min = min( dzm, zero ); - real_type dxp_max_2 = dxp_max * dxp_max; - real_type dxm_max_2 = dxm_max * dxm_max; - real_type dyp_max_2 = dyp_max * dyp_max; - real_type dym_max_2 = dym_max * dym_max; - real_type dzp_max_2 = dzp_max * dzp_max; - real_type dzm_max_2 = dzm_max * dzm_max; - real_type dxp_min_2 = dxp_min * dxp_min; - real_type dxm_min_2 = dxm_min * dxm_min; - real_type dyp_min_2 = dyp_min * dyp_min; - real_type dym_min_2 = dym_min * dym_min; - real_type dzp_min_2 = dzp_min * dzp_min; - real_type dzm_min_2 = dzm_min * dzm_min; - // yellowbook p58 - real_type phi_x_2_p = max( dxm_max_2, dxp_min_2 ); - real_type phi_x_2_m = max( dxm_min_2, dxp_max_2 ); - real_type phi_y_2_p = max( dym_max_2, dyp_min_2 ); - real_type phi_y_2_m = max( dym_min_2, dyp_max_2 ); - real_type phi_z_2_p = max( dzm_max_2, dzp_min_2 ); - real_type phi_z_2_m = max( dzm_min_2, dzp_max_2 ); - // peng99 eq40 - real_type norm_grad_phi_p = sqrt( phi_x_2_p + phi_y_2_p + phi_z_2_p ); - real_type norm_grad_phi_m = sqrt( phi_x_2_m + phi_y_2_m + phi_z_2_m ); - // Godunov scheme (yellowbook p58 eq6.3 and 6.4) - if ( (*s0) > 0 ) - { - (*f) = (*s0) * ( norm_grad_phi_p - 1.0 ); - } - else if ( (*s0) < 0 ) - { - (*f) = (*s0) * ( norm_grad_phi_m - 1.0 ); - } - else - { - (*f) = 0; - } - real_type phi_x = fabs((dp00 - dm00)*inv_dx*.5); - real_type phi_y = fabs((d0p0 - d0m0)*inv_dy*.5); - real_type phi_z = fabs((d00p - d00m)*inv_dz*.5); - real_type norm_grad_phi = sqrt(phi_x*phi_x + phi_y*phi_y + phi_z*phi_z); - - real_type tmp = fabs( (*s0)*phi_x*inv_dx2/norm_grad_phi + (*s0)*phi_y*inv_dy2/norm_grad_phi + (*s0)*phi_z*inv_dz2/norm_grad_phi ); - cfl_condition = max( cfl_condition, tmp ); - } - return 1.0/cfl_condition; - } - - template < typename grid_type , typename real_type > - real_type update( - grid_type const & phi - , grid_type const & speed - , real_type const & time_step - , grid_type & psi - , real_type const & gamma = 10e30 - ) - { - typedef typename grid_type::const_index_iterator const_iterator; - typedef typename grid_type::iterator iterator; - - assert(phi.I()==psi.I() || !"update(): incompatible grid dimensions"); - assert(phi.J()==psi.J() || !"update(): incompatible grid dimensions"); - assert(phi.K()==psi.K() || !"update(): incompatible grid dimensions"); - assert(phi.min_coord()==psi.min_coord() || !"update(): incompatible grid side lengths"); - assert(phi.max_coord()==psi.max_coord() || !"update(): incompatible grid side lengths"); - assert(time_step>0 || !"update(): time-step must be positive"); - - real_type steady = real_type(0.0); - const_iterator i = phi.begin(); - const_iterator f = speed.begin(); - iterator o = psi.begin(); - const_iterator end = phi.end(); - for ( ; i!=end;++i, ++o, ++f) - { - real_type diff = time_step * (*f); - (*o) = (*i) - diff; - diff = std::fabs(diff); - if ( (*o) < gamma && steady < diff ) - steady = diff; - } - return steady; - } - - public: - - /** - * Signed Distance Map Reinitialization. - * - * Brute-force implementation of the reinitialization of the distance function. - * The following Hamilton-Jacobi equation is solved: - * d_tau + S(d) * ( |grad phi| - 1 ) = 0 - * d(x,0) = d_0(x) = phi(x,t) - * to steady state, with S(d) approximated by: - * s = d / ( sqrt( d^2 + |Dd|^2 * delta_x^2) ) - * - * Calculates gradient magnitude of phi using upwind-scheme. - * Performs PDE update using forward Euler time discretization. - * - * @param phi Input level set that should be redistanced into a signed distance grid. - * @param psi Output level set. That is the redistaned phi. - * @param max_iterations The maximum number of iterations allowed to do re-initialization. - * @param stead_threshold The threshold value used to test for steady state. - */ - template < typename grid_type > - void operator()( - grid_type const & phi - , grid_type & psi - , size_t max_iterations = 10 - , double steady_threshold = 0.05 - ) - { - using std::min; - using std::max; - - typedef typename grid_type::value_type real_type; - - assert(phi.I()==psi.I() || !"operator(): incompatible grid dimensions"); - assert(phi.J()==psi.J() || !"operator(): incompatible grid dimensions"); - assert(phi.K()==psi.K() || !"operator(): incompatible grid dimensions"); - assert(phi.min_coord()==psi.min_coord() || !"operator(): incompatible grid side lengths"); - assert(phi.max_coord()==psi.max_coord() || !"operator(): incompatible grid side lengths"); - - static grid_type S0; // TODO: Hmm, these temporaries take up a lot of space!!! - static grid_type speed; - - compute_sign_function(phi,S0); - - real_type alpha = static_cast ( 0.9 ); //--- CFL number - //real_type min_delta = static_cast ( (min( phi.dx(), min( phi.dy(), phi.dz() ) ) ) ); - real_type max_delta = static_cast ( (max( phi.dx(), max( phi.dy(), phi.dz() ) ) ) ); - - grid_type * phi_in = const_cast(&phi); - grid_type * phi_out = ψ - - real_type gamma = static_cast( max_delta * max_iterations ); - real_type steady = static_cast(0.0); - - for(size_t iterations=0;iterations 0 || !"resample(): j scale factor must be positive"); - assert(factor_k > 0 || !"resample(): k scale factor must be positive"); - - typedef typename grid_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - typedef typename grid_type::index_iterator index_iterator; - - // TODO: Add gaussian smoothing with a standard deviation corresponding to factor_n. - //grid_type S = M; - //grid_gaussian_convolution(M,S,factor_i/2.0,factor_j/2.0,factor_k/2.0); - - m.create( - M.min_coord(), M.max_coord() - , static_cast( floor(M.I()/factor_i) ) - , static_cast( floor(M.J()/factor_j) ) - , static_cast( floor(M.K()/factor_k) ) - ); - - vector3_type point; - for( index_iterator iter = m.begin(); iter != m.end(); ++iter ) - { - idx2coord( iter,point ); - (*iter) = value_at_point( M, point ); - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_RESAMPLE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_second_derivative.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_second_derivative.h deleted file mode 100644 index f12efab6a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_second_derivative.h +++ /dev/null @@ -1,86 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_SECOND_DERIVATVE_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_SECOND_DERIVATVE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include // Needed for vector3. -#include // Needed for matrix3x3. - -namespace OpenTissue -{ - namespace grid - { - - template - inline void second_derivative( - grid_type const & grid - , size_t i - , size_t j - , size_t k - , real_type & derivative - ) - { - using std::fabs; - - typedef OpenTissue::math::Vector3 vector3_type; - typedef OpenTissue::math::Matrix3x3 matrix3x3_type; - - static vector3_type g; - static matrix3x3_type H; - - - real_type const too_small = 10e-7; - - gradient(grid, i, j, k, g ); - - real_type tmp = g*g; - if(fabs(tmp) < too_small) - { - derivative = 0.0; - return; - } - - hessian(grid, i, j, k, H); - derivative = (1.0)/(tmp)* (g * (H *g)); - } - - template - inline void second_derivative (grid_iterator const & iter, real_type & derivative) - { - typedef typename grid_iterator::grid_type grid_type; - - size_t i = iter.i(); - size_t j = iter.j(); - size_t k = iter.k(); - - grid_type const & grid = iter.get_grid(); - second_derivative(grid, i, j, k, derivative); - } - - template - inline typename grid_iterator::math_types::real_type - second_derivative( grid_iterator const & iter ) - { - typedef typename grid_iterator::math_types::real_type real_type; - - real_type derivative; - - second_derivative(iter, derivative); - - return derivative; - } - - } // namespace grid - -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_SECOND_DERIVATVE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_split2slices.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_split2slices.h deleted file mode 100644 index cc70222c7..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_split2slices.h +++ /dev/null @@ -1,63 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_SPLIT2SLICES_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_SPLIT2SLICES_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Split a 3D grid into multiple 2D grids along some major axis. - * - * @param grid The grid that should be split inot slices. - * @param slices Upon return this container holds grids corresponding to all the slices. - * @param axis The axis to split along. - */ - template - inline void split2slices(grid_type & grid, grid_container & slices, size_t axis = 2) - { - typename grid_type::math_types math_types; - typename math_types::vector3_type vector3_type; - - assert( axis==2 || !"split2slices(): Only splits along k-axis is currently supported"); - - slices.clear(); - - if (axis != 2) - return; - - vector3_type min_coord = grid.min_coord(); - vector3_type max_coord = grid.max_coord(); - min_coord(2) = 0; - max_coord(2) = 0; - for (size_t z = 0; z < grid.K(); ++z) - { - - grid_type slice; - slice.create(min_coord, max_coord, grid.I(), grid.J(), 2); - for (size_t y = 0; y < grid.J(); ++y) - for (size_t x = 0; x < grid.I(); ++x) - { - slice(x, y, 0) = grid(x, y, z); - slice(x, y, 1) = grid(x, y, z); // HACKING!!! - } - slices.push_back(slice); - } - } - - } // namespace grid - -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_SPLIT2SLICES_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_strict_local_minima.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_strict_local_minima.h deleted file mode 100644 index 2a7651e18..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_strict_local_minima.h +++ /dev/null @@ -1,160 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_STRICT_GRID_LOCAL_MINIMA_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_STRICT_GRID_LOCAL_MINIMA_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - - namespace detail - { - - /** - * Test if a specified node is a strict local minima. - * - * @param i - * @param j - * @param k - * @param phi - * - * @return True if node i,j,k is a local minima, otherwise false. - */ - template < typename grid_type > - inline bool is_strict_local_minima( - size_t i - , size_t j - , size_t k - , grid_type const & phi - ) - { - using std::min; - static size_t idx[27]; - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - idx[0] = ( kp1 * J + jp1 ) * I + im1; - idx[1] = ( k * J + jp1 ) * I + im1; - idx[2] = ( km1 * J + jp1 ) * I + im1; - idx[3] = ( kp1 * J + j ) * I + im1; - idx[4] = ( k * J + j ) * I + im1; - idx[5] = ( km1 * J + j ) * I + im1; - idx[6] = ( kp1 * J + jm1 ) * I + im1; - idx[7] = ( k * J + jm1 ) * I + im1; - idx[8] = ( km1 * J + jm1 ) * I + im1; - idx[9] = ( kp1 * J + jp1 ) * I + i; - idx[10] = ( k * J + jp1 ) * I + i; - idx[11] = ( km1 * J + jp1 ) * I + i; - idx[12] = ( kp1 * J + j ) * I + i; - idx[13] = ( k * J + j ) * I + i; - idx[14] = ( km1 * J + j ) * I + i; - idx[15] = ( kp1 * J + jm1 ) * I + i; - idx[16] = ( k * J + jm1 ) * I + i; - idx[17] = ( km1 * J + jm1 ) * I + i; - idx[18] = ( kp1 * J + jp1 ) * I + ip1; - idx[19] = ( k * J + jp1 ) * I + ip1; - idx[20] = ( km1 * J + jp1 ) * I + ip1; - idx[21] = ( kp1 * J + j ) * I + ip1; - idx[22] = ( k * J + j ) * I + ip1; - idx[23] = ( km1 * J + j ) * I + ip1; - idx[24] = ( kp1 * J + jm1 ) * I + ip1; - idx[25] = ( k * J + jm1 ) * I + ip1; - idx[26] = ( km1 * J + jm1 ) * I + ip1; - for(size_t i=0;i<27u;++i) - if( phi(idx[13]) >= phi(idx[i]) ) - return false; - return true; - } - - } // namespace detail - - /** - * Extract local minima nodes. - * Note that local minima may exist at non-nodal locations. This function - * only considers nodal positions. Thus if you are looking for local minima - * at sub-pixel accuracy, then you need another approach. - * - * @param phi The map from where local minima nodes should be extracted from. - * @param points Upon return this container contains all the coordinates of all nodes that where local minima. - */ - template < typename grid_type,typename point_container > - inline void strict_local_minima_as_points( - grid_type const & phi - , point_container & points - ) - { - typedef typename point_container::value_type vector3_type; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename vector3_type::value_type real_type; - typedef typename grid_type::value_type value_type; - - const_index_iterator pend = phi.end(); - const_index_iterator p = phi.begin(); - for(;p!=pend;++p) - { - if(detail::is_strict_local_minima(p.i(),p.j(),p.k(),phi)) - { - vector3_type point; - idx2coord(phi,p.i(),p.j(),p.k(),point); - points.push_back(point); - } - } - } - - /** - * Extract Strict Local Minima as Points. - * - * @param phi - * @param mask A mask that can be used to mask-out nodes in phi, which is not - * of interest. Positive values correspond to nodes that are allowed - * to be classified as local minima. - * @param points - */ - template < typename grid_type,typename point_container > - inline void strict_local_minima_as_points( - grid_type const & phi - , grid_type const & mask - , point_container & points - ) - { - typedef typename point_container::value_type vector3_type; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename vector3_type::value_type real_type; - typedef typename grid_type::value_type value_type; - const_index_iterator end = phi.end(); - const_index_iterator p = phi.begin(); - const_index_iterator m = mask.begin(); - for(;p!=end;++p,++m) - { - if( (*m) <= 0 ) - continue; - if(detail::is_strict_local_minima(p.i(),p.j(),p.k(),phi)) - { - vector3_type point; - idx2coord(phi,p.i(),p.j(),p.k(),point); - points.push_back(point); - } - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_STRICT_GRID_LOCAL_MINIMA_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_translate.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_translate.h deleted file mode 100644 index ef49febd3..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_translate.h +++ /dev/null @@ -1,87 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_TRANSLATE_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_TRANSLATE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include // for abs() - -namespace OpenTissue -{ - namespace grid - { - /** - * Translate a grid by an integer vector and wrap around at border. - * - * Behavior is un-expected if input and output grid is the same.... - * TODO: make it work for zero-trans and negative trans. - * - * @param src Source grid to be translated. - * @param v translation vector. - * @param dst Upon return, contains the translated grid. - */ - template - inline void translate(grid_type const& src, vector3_int_type const& v, grid_type & dst) - { - assert( v(0)>0 && !"translate(): Only works for positive translations for now"); - assert( v(1)>0 && !"translate(): Only works for positive translations for now"); - assert( v(2)>0 && !"translate(): Only works for positive translations for now"); - - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::vector3_type vector3_type; - - // make sure translation is >0 - vector3_int_type t=v; - //if( t(0)<0 ) - // t(0) += src.I()*(1+abs(t(0)/src.I())); - //if( t(1)<0 ) - // t(1) += src.J()*(1+abs(t(1)/src.J())); - //if( t(2)<0 ) - // t(2) += src.K()*(1+abs(t(2)/src.K())); - - // Save last block of data - grid_type tmp; - tmp.create(vector3_type(0,0,0), vector3_type(1,1,1), t(0), t(1), t(2)); - size_t ti = src.I()-t(0); - size_t tj = src.J()-t(1); - size_t tk = src.K()-t(2); - size_t lk=0; - size_t lj=0; - size_t li=0; - for (size_t gk=tk; gk p( src.end() ), end( src.begin() ); - //for(p; p!=end; ++p) - //{ - // dst( (p.base().i()+t(0))%src.I(), (p.base().j()+t(1))%src.J(), (p.base().k()+t(2))%src.K() ) = *p; - //} - for(const_index_iterator p=src.end()-1; p!=src.begin()-1; --p) - { - dst( (p.i()+t(0))%src.I(), (p.j()+t(1))%src.J(), (p.k()+t(2))%src.K() ) = *p; - } - // copy over the stored values - for (size_t k=0; k - -#include //--- needed for gradient_func and value_func - -namespace OpenTissue -{ - namespace grid - { - - /** - * Uniform Point Sampling of Grid. - * - * @param phi The (signed distance grid) level set grid. - * @param points Upon return this container containts the random points. - * @param sub_Sample Optimal argument, allows one to control the density of points. - */ - template - inline void uniform_point_sampling( - grid_type const & phi - , vector3_container & points - , size_t sub_sample = 2u - ) - { - typedef typename vector3_container::value_type vector3_type; - typedef typename vector3_type::value_type real_type; - - points.clear(); - - real_type min_x = phi.min_coord(0); - real_type min_y = phi.min_coord(1); - real_type min_z = phi.min_coord(2); - - real_type max_x = phi.max_coord(0); - real_type max_y = phi.max_coord(1); - real_type max_z = phi.max_coord(2); - - real_type dx = phi.dx()*sub_sample; - real_type dy = phi.dy()*sub_sample; - real_type dz = phi.dz()*sub_sample; - - for ( real_type x = (min_x+dx); x < (max_x-dx); x += dx ) - for ( real_type y = (min_y+dy); y < (max_y-dy); y += dy ) - for ( real_type z = (min_z+dz); z < (max_z-dz); z += dz ) - { - points.push_back( vector3_type( x, y, z ) ); - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UNIFORM_POINT_SAMPLING_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_upwind_gradient.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_upwind_gradient.h deleted file mode 100644 index e7c97c5ed..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_upwind_gradient.h +++ /dev/null @@ -1,107 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UPWIND_GRADIENT_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UPWIND_GRADIENT_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Compute Upwind Gradient at Specified Node location. - * - * @param phi A the map in which we want to know the gradient. - * @param F A map containing the values of the speed function. - * @param i The i'th index of the node at which we want to compute the gradient. - * @param j The j'th index of the node at which we want to compute the gradient. - * @param k The k'th index of the node at which we want to compute the gradient. - * @param gradient Upon completion contains the upwind gradient - */ - template - inline void upwind_gradient( - grid_type const & phi - , grid_type const & F - , size_t i - , size_t j - , size_t k - , vector3_type & gradient - ) - { - using std::min; - - typedef typename grid_type::value_type value_type; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - real_type inv_dx = 1.0/phi.dx(); - real_type inv_dy = 1.0/phi.dy(); - real_type inv_dz = 1.0/phi.dz(); - real_type inv_2dx = 0.5/phi.dx(); - real_type inv_2dy = 0.5/phi.dy(); - real_type inv_2dz = 0.5/phi.dz(); - - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - size_t i000 = ( k * J + j ) * I + i; - size_t im00 = ( k * J + j ) * I + im1; - size_t ip00 = ( k * J + j ) * I + ip1; - size_t i0m0 = ( k * J + jm1 ) * I + i; - size_t i0p0 = ( k * J + jp1 ) * I + i; - size_t i00m = ( km1 * J + j ) * I + i; - size_t i00p = ( kp1 * J + j ) * I + i; - real_type f = F(i000); - real_type v000 = phi(i000); - real_type vp00 = phi(ip00); - real_type vm00 = phi(im00); - real_type v0p0 = phi(i0p0); - real_type v0m0 = phi(i0m0); - real_type v00p = phi(i00p); - real_type v00m = phi(i00m); - // phi^t+1 = phi_t + dt*F - // F > 0 use forward diffs - // F < 0 use backward diffs - real_type nx = 0; - real_type ny = 0; - real_type nz = 0; - if(f>0) - { - nx = (vp00 - v000 ) * inv_dx; - ny = (v0p0 - v000 ) * inv_dy; - nz = (v00p - v000 ) * inv_dz; - } - else if(f<0) - { - nx = (v000 - vm00) * inv_dx; - ny = (v000 - v0m0) * inv_dy; - nz = (v000 - v00m) * inv_dz; - } - else - { - nx = (vp00 - vm00) * inv_2dx; - ny = (v0p0 - v0m0) * inv_2dy; - nz = (v00p - v00m) * inv_2dz; - } - gradient = vector3_type(nx,ny,nz); - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UPWIND_GRADIENT_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_upwind_gradient_field.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_upwind_gradient_field.h deleted file mode 100644 index 27157934c..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_upwind_gradient_field.h +++ /dev/null @@ -1,115 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UPWIND_GRADIENT_FIELD_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UPWIND_GRADIENT_FIELD_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace grid - { - - /** - * Picks upwind direction of gradient according to the speed function (F). - */ - template < typename grid_type > - inline void upwind_gradient_field( - grid_type const & phi - , grid_type const & F - , grid_type & Nx - , grid_type & Ny - , grid_type & Nz - ) - { - using std::min; - - typedef OpenTissue::math::Vector3< typename grid_type::value_type> vector3_type; - - typedef typename grid_type::value_type value_type; - typedef typename grid_type::iterator iterator; - typedef typename grid_type::const_iterator const_iterator; - typedef typename grid_type::const_index_iterator const_index_iterator; - typedef typename grid_type::math_types math_types; - typedef typename math_types::real_type real_type; - - size_t I = phi.I(); - size_t J = phi.J(); - size_t K = phi.K(); - real_type inv_dx = 1.0/phi.dx(); - real_type inv_dy = 1.0/phi.dy(); - real_type inv_dz = 1.0/phi.dz(); - - real_type inv_2dx = 0.5/phi.dx(); - real_type inv_2dy = 0.5/phi.dy(); - real_type inv_2dz = 0.5/phi.dz(); - - iterator nx = Nx.begin(); - iterator ny = Ny.begin(); - iterator nz = Nz.begin(); - const_iterator f = F.begin(); - const_index_iterator pbegin = phi.begin(); - const_index_iterator pend = phi.end(); - const_index_iterator p = pbegin; - - for(;p!=pend; ++f,++p,++nx,++ny,++nz) - { - size_t i = p.i(); - size_t j = p.j(); - size_t k = p.k(); - - size_t im1 = ( i ) ? i - 1 : 0; - size_t jm1 = ( j ) ? j - 1 : 0; - size_t km1 = ( k ) ? k - 1 : 0; - size_t ip1 = min( i + 1u, I - 1u ); - size_t jp1 = min( j + 1u, J - 1u ); - size_t kp1 = min( k + 1u, K - 1u ); - size_t i000 = ( k * J + j ) * I + i; - size_t im00 = ( k * J + j ) * I + im1; - size_t ip00 = ( k * J + j ) * I + ip1; - size_t i0m0 = ( k * J + jm1 ) * I + i; - size_t i0p0 = ( k * J + jp1 ) * I + i; - size_t i00m = ( km1 * J + j ) * I + i; - size_t i00p = ( kp1 * J + j ) * I + i; - real_type v000 = phi(i000); - real_type vp00 = phi(ip00); - real_type vm00 = phi(im00); - real_type v0p0 = phi(i0p0); - real_type v0m0 = phi(i0m0); - real_type v00p = phi(i00p); - real_type v00m = phi(i00m); - // phi^t+1 = phi_t + dt*F - // F > 0 use forward diffs - // F < 0 use backward diffs - if((*f)>0) - { - *nx = (vp00 - v000 ) * inv_dx; - *ny = (v0p0 - v000 ) * inv_dy; - *nz = (v00p - v000 ) * inv_dz; - } - else if((*f)<0) - { - *nx = (v000 - vm00) * inv_dx; - *ny = (v000 - v0m0) * inv_dy; - *nz = (v000 - v00m) * inv_dz; - } - else - { - *nx = (vp00 - vm00) * inv_2dx; - *ny = (v0p0 - v0m0) * inv_2dy; - *nz = (v00p - v00m) * inv_2dz; - } - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_UPWIND_GRADIENT_FIELD_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_value_at_point.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_value_at_point.h deleted file mode 100644 index 97e88e12e..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_value_at_point.h +++ /dev/null @@ -1,77 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_VALUE_AT_POINT_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_VALUE_AT_POINT_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * - * - * Warning this method do not test whether the point lies inside the grid. If the point is - * outside the behavior is undefined. - */ - template - inline typename grid_type::value_type value_at_point(grid_type const & grid, vector3_type const & point ) - { - typedef typename grid_type::value_type value_type; - typedef typename vector3_type::value_type real_type; - - //const static value_type infty = grid.infinity(); - const static value_type unused = grid.unused(); - const static value_type zero = value_type(); //--- by standard default constructed is zero!!! - - size_t i0, j0, k0, i1, j1, k1; - enclosing_indices( grid, point, i0, j0, k0, i1, j1, k1 ); - - value_type d000 = grid( i0, j0, k0 ); - value_type d001 = grid( i1, j0, k0 ); - value_type d010 = grid( i0, j1, k0 ); - value_type d011 = grid( i1, j1, k0 ); - value_type d100 = grid( i0, j0, k1 ); - value_type d101 = grid( i1, j0, k1 ); - value_type d110 = grid( i0, j1, k1 ); - value_type d111 = grid( i1, j1, k1 ); - - size_t cnt_unused = 0; - -#define MAGIC(val) \ - if ( (val) == unused) { \ - (val) = zero; \ - ++cnt_unused; \ - } - MAGIC( d000 ); - MAGIC( d001 ); - MAGIC( d010 ); - MAGIC( d011 ); - MAGIC( d100 ); - MAGIC( d101 ); - MAGIC( d110 ); - MAGIC( d111 ); -#undef MAGIC - - if ( cnt_unused == 8 ) - return unused; - - real_type s = ( point(0) - ( i0*grid.dx() + grid.min_coord(0) ) ) / grid.dx(); - real_type t = ( point(1) - ( j0*grid.dy() + grid.min_coord(1) ) ) / grid.dy(); - real_type u = ( point(2) - ( k0*grid.dz() + grid.min_coord(2) ) ) / grid.dz(); - return OpenTissue::math::trillinear( d000, d001, d010, d011, d100, d101, d110, d111, s, t, u ); - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_VALUE_AT_POINT_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_voxel_plane_clip.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_voxel_plane_clip.h deleted file mode 100644 index 97daa9c21..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/grid/util/grid_voxel_plane_clip.h +++ /dev/null @@ -1,54 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_VOXEL_PLANE_CLIP_H -#define OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_VOXEL_PLANE_CLIP_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace grid - { - /** - * Clip a voxelgrid against a plane. - * @param voxels Input voxel grid. - * @param plane Plane to clip against. - * @param below Upon return, contains grid of all voxels below plane. - * @param above Upon return, contains grid of all voxels above plane. - */ - template < typename grid_type, typename plane_type > - inline void voxel_plane_clip( - grid_type const& voxels - , plane_type const& plane - , grid_type & below - , grid_type & above - ) - { - typedef typename grid_type::value_type value_type; - typedef typename grid_type::const_index_iterator const_index_iterator; - - const_index_iterator voxel; - for ( voxel=voxels.begin(); voxel!=voxels.end(); ++voxel ) - { - if ( plane.signed_distance( voxel.get_coord() ) >= 0 ) - { - above( voxel.get_index() ) = voxels( voxel.get_index() ); - below( voxel.get_index() ) = value_type(0); - } - else - { - below( voxel.get_index() ) = voxels( voxel.get_index() ); - above( voxel.get_index() ) = value_type(0); - } - } - } - - } // namespace grid -} // namespace OpenTissue - -// OPENTISSUE_CORE_CONTAINERS_GRID_UTIL_GRID_VOXEL_PLANE_CLIP_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_core_access.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_core_access.h deleted file mode 100644 index ddb111a87..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_core_access.h +++ /dev/null @@ -1,74 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_CORE_ACCESS_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_CORE_ACCESS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace t4mesh - { - class t4mesh_core_access - { - public: - - template< typename feature_type, typename index_type> - static void set_index(feature_type & f, index_type idx) - { - f.set_index(idx); - } - - template< typename feature_type, typename mesh_type> - static void set_owner(feature_type & f, mesh_type * owner) - { - f.set_owner(owner); - } - - template< typename tetrahedron_type, typename index_type> - static void set_node0(tetrahedron_type & tetrahedron, index_type idx) - { - tetrahedron.set_node0(idx); - } - - template< typename tetrahedron_type, typename index_type> - static void set_node1(tetrahedron_type & tetrahedron, index_type idx) - { - tetrahedron.set_node1(idx); - } - - template< typename tetrahedron_type, typename index_type> - static void set_node2(tetrahedron_type & tetrahedron, index_type idx) - { - tetrahedron.set_node2(idx); - } - - template< typename tetrahedron_type, typename index_type> - static void set_node3(tetrahedron_type & tetrahedron, index_type idx) - { - tetrahedron.set_node3(idx); - } - - template< typename node_type, typename index_type> - static void tetrahedra_push_back(node_type & node, index_type idx) - { - node.tetrahedra_push_back(idx); - } - - template< typename node_type, typename index_type> - static void tetrahedra_remove(node_type & node, index_type idx) - { - node.tetrahedra_remove(idx); - } - - }; - - } // namespace trimesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_CORE_ACCESS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_default_point_container.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_default_point_container.h deleted file mode 100644 index 6cb8cef66..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_default_point_container.h +++ /dev/null @@ -1,70 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_DEFAULT_POINT_CONTAINER_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_DEFAULT_POINT_CONTAINER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace t4mesh - { - - /** - * Default Point Container. - * This utility class can be used to make the coordniates of the nodes in - * a tetrahedra mesh appear as a point container, i.e. as though the coordinates - * are stored as - * - * std::vector coordinates; - * - * and accesses as - * - * coordinates[node->idx()] - * - * instead of - * - * node->m_coord - * - * Many algoritms in OpenTissue have been implemented in such a way that they - * do not rely on nodes to have a m_coord member. Instead coordinates are passed - * as point containers. This utility make it convenient to use these algorithms - * on nodes where coordinates are stored in m_coord member. - * - */ - template - struct default_point_container - { - typedef M mesh_type; - typedef typename mesh_type::math_types math_types; - typedef typename math_types::vector3_type value_type; - - mesh_type * m_mesh; - - default_point_container(mesh_type * mesh) : m_mesh(mesh) {} - - value_type & operator[] (unsigned int const & idx) - { - return m_mesh->node(idx)->m_coord; - } - - value_type const & operator[] (unsigned int const & idx)const - { - return m_mesh->node(idx)->m_coord; - } - - void clear(){} - size_t size() const {return m_mesh->size_nodes();} - void resize(size_t){} - }; - - - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_DEFAULT_POINT_CONTAINER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_default_traits.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_default_traits.h deleted file mode 100644 index a47ffff00..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_default_traits.h +++ /dev/null @@ -1,38 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_DEFAULT_TRAITS_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_DEFAULT_TRAITS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace t4mesh - { - - template - class DefaultNodeTraits - { - public: - - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::real_type real_type; - - vector3_type m_coord; ///< Default Coordinate of tetramesh node. - }; - - class DefaultTetrahedronTraits { }; - - class DefaultT4EdgeTraits { }; - - class DefaultT4FaceTraits { }; - - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_DEFAULT_TRAITS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4boundary_faces.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4boundary_faces.h deleted file mode 100644 index dee6b33d3..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4boundary_faces.h +++ /dev/null @@ -1,153 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_T4BOUNDARY_FACES_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_T4BOUNDARY_FACES_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace t4mesh - { - - /** - * t4mesh Face. - */ - template - class T4Face : public F - { - public: - - typedef M mesh_type; - typedef F face_traits; - typedef T4Face face_type; - typedef typename mesh_type::index_type index_type; - - protected: - - index_type m_idx0; ///< First node index. - index_type m_idx1; ///< Second node index. - index_type m_idx2; ///< Third node index. - - public: - - T4Face() - : m_idx0(-1) - , m_idx1(-1) - , m_idx2(-1) - {} - - T4Face(index_type const & index0, index_type const & index1, index_type const & index2) - : m_idx0(index0) - , m_idx1(index1) - , m_idx2(index2) - {} - - public: - - const index_type & idx0() const { return m_idx0; } - const index_type & idx1() const { return m_idx1; } - const index_type & idx2() const { return m_idx2; } - - }; - - /** - * Tetrahedra Mesh Boundary Faces. - * Note that if subsequent changes are made to the t4mesh are not reflected in - * the faces stored in this class. Meaning that a new face-queury - * must be initiated everytime the t4mesh changes its topology. - * - * Example of usage: - * - * typedef t4mesh<...> MyMeshType; - * MyMeshType mymesh; - * ... - * class MyFaceTraits : public DefaultFaceTraits - * { - * public: - * Color m_color; - * ... - * }; - * typedef T4BoundaryFaces MyBoundaryFaces; - * MyBoundaryFaces bounday(mymesh); - * for(MyBoundaryFaces::face_iterator face=boundary.begin();face!=boundary.end();++face) - * { - * face->m_color = Color::white; - * std::cout << face->idx0() << std::endl; - * } - */ - template - class T4BoundaryFaces - { - public: - - typedef M mesh_type; - typedef F face_traits; - typedef T4Face face_type; - typedef std::list face_container; - typedef typename face_container::iterator face_iterator; - typedef typename face_container::const_iterator const_face_iterator; - - protected: - - face_container m_faces; ///< Container of extrated boundary faces. - - public: - - face_iterator begin() { return m_faces.begin(); } - face_iterator end() { return m_faces.end(); } - const_face_iterator begin() const { return m_faces.begin(); } - const_face_iterator end() const { return m_faces.end(); } - - public: - - /** - * Default Constructor. - * Constructs an empty set of boundary faces. - */ - T4BoundaryFaces() - : m_faces() - {} - - /** - * Specialezed Constructor - * Traverses the tetrahedral mesh, and extracts all boundary faces. A boundary - * face is a face that only have one neighboring tetrahedron. A face inside - * the tetrahedral mesh will have exactly two neighboring tetrahedra. - * - * Face node indices are given in CCW order. - * - * @param mesh The tetrahedral mesh from which boundary - * faces are extracted. - */ - T4BoundaryFaces(mesh_type & mesh) - : m_faces() - { - typename mesh_type::tetrahedron_iterator tetrahedron; - for( tetrahedron = mesh.tetrahedron_begin(); tetrahedron != mesh.tetrahedron_end(); ++tetrahedron) - { - if(tetrahedron->jkm()==mesh.tetrahedron_end()) - m_faces.push_back(face_type(tetrahedron->j()->idx(),tetrahedron->k()->idx(),tetrahedron->m()->idx())); - if(tetrahedron->ijm()==mesh.tetrahedron_end()) - m_faces.push_back(face_type(tetrahedron->i()->idx(),tetrahedron->j()->idx(),tetrahedron->m()->idx())); - if(tetrahedron->kim()==mesh.tetrahedron_end()) - m_faces.push_back(face_type(tetrahedron->k()->idx(),tetrahedron->i()->idx(),tetrahedron->m()->idx())); - if(tetrahedron->ikj()==mesh.tetrahedron_end()) - m_faces.push_back(face_type(tetrahedron->i()->idx(),tetrahedron->k()->idx(),tetrahedron->j()->idx())); - } - } - - }; - - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_T4BOUNDARY_FACES_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4edges.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4edges.h deleted file mode 100644 index caed6272a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4edges.h +++ /dev/null @@ -1,219 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_T4EDGES_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_T4EDGES_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace t4mesh - { - - /** - * t4mesh Edge. - * An edge is uniquely defined by the indices of its two end nodes. - * The order of indices do not matter. - */ - template - class T4Edge : public E - { - public: - - typedef M mesh_type; - typedef E edge_traits; - typedef T4Edge edge_type; - typedef typename mesh_type::index_type index_type; - - protected: - - index_type m_idxA; ///< Index to first node. - index_type m_idxB; ///< Index to second node. - - public: - - T4Edge() - : m_idxA(-1) - , m_idxB(-1) - {} - - T4Edge(index_type const & indexA, index_type const & indexB) - : m_idxA(indexA) - , m_idxB(indexB) - {} - - public: - - index_type const & idxA() const { return m_idxA; } - index_type const & idxB() const { return m_idxB; } - - bool operator==(edge_type const & edge) const - { - if(m_idxA==edge.idxA() && m_idxB==edge.idxB()) - return true; - if(m_idxB==edge.idxA() && m_idxA==edge.idxB()) - return true; - return false; - } - - bool operator!=(edge_type const & edge)const{ return !((*this)==edge); } - - }; - - /** - * Tetrahedra Mesh Edges. - * Edges are not represented explicitly in a t4mesh, only nodes and tetrahedra - * are representated. Thus this class extracts all unique edges from a t4mesh, by - * traversing it and generating explicit edges. - * - * Note that if subsequent changes are made to the t4mesh, the edge changes are - * not reflected by the edges stored in this class. Meaning that a new edge-queury - * must be initiated everytime the t4mesh changes its topology. - * - */ - template - class T4Edges - { - public: - - typedef M mesh_type; - typedef E edge_traits; - typedef T4Edge edge_type; - typedef typename mesh_type::index_type index_type; - typedef std::list edge_container; - typedef typename edge_container::iterator edge_iterator; - typedef typename edge_container::const_iterator const_edge_iterator; - - protected: - - typedef enum{white,grey,black} color_type; - typedef std::vector color_container; - typedef typename mesh_type::node_type node_type; - typedef typename node_type::tetrahedron_circulator tetrahedron_type; - typedef std::list work_queue; - - protected: - - edge_container m_edges; - - public: - - edge_iterator begin() { return m_edges.begin(); } - edge_iterator end() { return m_edges.end(); } - const_edge_iterator begin() const { return m_edges.begin(); } - const_edge_iterator end() const { return m_edges.end(); } - - - protected: - - /** - * Internally used functor, needed for visiting neighboring - * nodes and extracting un-seen edges. - */ - struct VisitT4Edge - { - void visit( - index_type & idxA - , index_type & idxB - , work_queue & work - , color_container & colors - , edge_container & edges - , mesh_type & mesh - ) - { - if(idxA==idxB)//--- self-loop, ignore it - return; - - //std::cout << "\tvisting:" <swap(where,last); - } - - this->unlink(last); - //--- This might be a bit stupid, it would - //--- proberly be better to keep track of last unused - //--- entry and only resize vector when there is no - //--- more space - m_tetrahedra.pop_back(); - return where; - } - - protected: - - protected: - - - }; - - } // namespace detail - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_T4MESH_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4node.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4node.h deleted file mode 100644 index 7ca712985..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4node.h +++ /dev/null @@ -1,138 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_T4NODE_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_T4NODE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace t4mesh - { - - template< typename mesh_type_> - class T4Node : public mesh_type_::node_traits - { - public: - - typedef mesh_type_ mesh_type; - typedef typename mesh_type::node_type node_type; - typedef typename mesh_type::tetrahedron_type tetrahedron_type; - typedef typename mesh_type::index_type index_type; - typedef std::list tetrahedra_index_container; - typedef typename tetrahedra_index_container::iterator tetrahedra_idx_iterator; - - protected: - - index_type m_idx; ///< Global index of node - mesh_type * m_owner; ///< Pointer to mesh which the node belongs to. - tetrahedra_index_container m_tetrahedra; ///< Indices of tetrahedra this node is part of. - - private: - - friend class t4mesh_core_access; - - void set_index(index_type idx) { m_idx = idx; } - void set_owner(mesh_type * owner) { m_owner = owner; } - void tetrahedra_push_back(index_type idx) { m_tetrahedra.push_back(idx); } - void tetrahedra_remove(index_type idx) { m_tetrahedra.remove(idx); } - - public: - - class tetrahedron_circulator - { - private: - - node_type * m_node; ///< A pointer to the node - tetrahedra_idx_iterator m_it; ///< An ``local'' iterator to the tetrahedron index, indicating current tetrahedron of this iterator. - - public: - - tetrahedron_circulator() - : m_node( 0 ) - , m_it( 0 ) - {} - - tetrahedron_circulator( node_type * node, tetrahedra_idx_iterator pos) - : m_node( node ) - , m_it( pos ) - { - assert(m_node || !"tetrahedron_circulator() : node was null"); - assert(m_node->m_owner || !"tetrahedron_circulator(..) : owner was null"); - } - - bool operator== ( tetrahedron_circulator const & other ) const - { - return ( m_node == other.m_node && m_it == other.m_it ); - } - - bool operator!= ( tetrahedron_circulator const & other ) const - { - return !( *this == other); - } - - tetrahedron_type & operator*() - { - assert(m_node || !"tetrahedron_circulator::* : node was null"); - assert(m_node->m_owner || !"tetrahedron_circulator::* : owner was null"); - return *(m_node->m_owner->tetrahedron(*m_it)); - } - - tetrahedron_type * operator->() - { - assert(m_node || !"tetrahedron_circulator::-> : node was null"); - assert(m_node->m_owner || !"tetrahedron_circulator::-> : owner was null"); - return &(*(m_node->m_owner->tetrahedron(*m_it))); - } - - tetrahedron_circulator & operator++() - { - assert(m_node || !"tetrahedron_circulator::++ : node was null"); - assert(m_node->m_owner || !"tetrahedron_circulator::++ : owner was null"); - ++m_it; - return *this; - } - - }; - - tetrahedron_circulator begin() { return tetrahedron_circulator( this, m_tetrahedra.begin() ); } - tetrahedron_circulator end() { return tetrahedron_circulator( this, m_tetrahedra.end() ); } - - /** - * Get Number of Tetrahedra. - * - * @return The number of tetrahedra that this node is part of. If - * zero it means the node is an isolated node. - */ - size_t size_tetrahedra() const { return m_tetrahedra.size(); } - - bool isolated() const { return m_tetrahedra.empty(); } - - public: - - T4Node() - : m_idx( mesh_type::undefined() ) - , m_owner(0) - , m_tetrahedra() - {} - - public: - - index_type idx() const { return m_idx; } - mesh_type * owner() { return m_owner; } - mesh_type const * owner() const { return m_owner; } - - }; - - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_T4NODE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4tetrahedron.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4tetrahedron.h deleted file mode 100644 index 8f81b3d9e..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/t4mesh_t4tetrahedron.h +++ /dev/null @@ -1,105 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_T4TETRAHEDRON_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_T4TETRAHEDRON_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace t4mesh - { - - template< typename mesh_type_> - class T4Tetrahedron : public mesh_type_::tetrahedron_traits - { - public: - typedef mesh_type_ mesh_type; - typedef typename mesh_type::node_type node_type; - typedef typename mesh_type::tetrahedron_type tetrahedron_type; - typedef typename mesh_type::index_type index_type; - - index_type m_idx; ///< Global index of tetrahedron - mesh_type * m_owner; ///< Pointer to mesh which the node belongs to. - index_type m_nodes[4]; ///< Global index of node i,j,k and m - - private: - - friend class t4mesh_core_access; - - void set_index(index_type idx) { m_idx = idx; } - void set_owner(mesh_type * owner) { m_owner = owner; } - void set_node0(index_type idx) { m_nodes[0] = idx; } - void set_node1(index_type idx) { m_nodes[1] = idx; } - void set_node2(index_type idx) { m_nodes[2] = idx; } - void set_node3(index_type idx) { m_nodes[3] = idx; } - - public: -#ifdef TODO_ERWIN - T4Tetrahedron() - : m_idx( mesh_type::undefined() ) - , m_owner(0) - { - this->m_nodes.assign( mesh_type::undefined() ); - } -#endif - - public: - - node_type* node(index_type idx) - { - return &m_owner->m_nodes[m_nodes[idx]]; - } - - const node_type* node(index_type idx) const - { - return &m_owner->m_nodes[m_nodes[idx]]; - } - - node_type* i() - { - return node(0); - } - node_type* j() - { - return node(1); - } - node_type* k() - { - return node(2); - } - node_type* m() - { - return node(3); - } - - - index_type idx() const { return m_idx; } - - index_type node_idx(index_type const & local_idx) const - { - assert(0<=local_idx); - assert(local_idx<=3); - - return m_nodes[local_idx]; - } - - - mesh_type * owner() { return m_owner; } - mesh_type const * owner() const { return m_owner; } - - - - }; - - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_T4TETRAHEDRON_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_block_generator.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_block_generator.h deleted file mode 100644 index f5c28ab39..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_block_generator.h +++ /dev/null @@ -1,114 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_BLOCK_GENERATOR_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_BLOCK_GENERATOR_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - - -namespace OpenTissue -{ - namespace t4mesh - { - - - /** - * t4mesh Block Generator. - * - * @param I The number of blocks along x axis. - * @param J The number of blocks along y axis. - * @param K The number of blocks along z axis. - * @param block_width The edgelength of the blocks along x-axis. - * @param block_height The edgelength of the blocks along x-axis. - * @param block_depth The edgelength of the blocks along x-axis. - * @param mesh A generic t4mesh, which upon return holds the generated mesh. - */ - template < typename real_type, typename t4mesh_type > - void generate_blocks( - unsigned int const & I - , unsigned int const & J - , unsigned int const & K - , real_type const & block_width - , real_type const & block_height - , real_type const & block_depth - , t4mesh_type & mesh - ) - { - - mesh.clear(); - - unsigned int numVertices = (I + 1) * (J + 1) * (K + 1); - for (unsigned int i=0; i - - -#include - -namespace OpenTissue -{ - - namespace t4mesh - { - - namespace mesh_coupling - { - - template - class collision_policy - { - public: - - typedef typename surface_mesh::vertex_type vertex_type; - typedef typename volume_mesh::tetrahedron_type tetrahedron_type; - - typedef double real_type; - typedef math::Vector3 point_type; - - typedef vertex_type* data_type; - typedef tetrahedron_type query_type; - - typedef OpenTissue::spatial_hashing::GridHashFunction hash_function; - typedef OpenTissue::spatial_hashing::Grid< point_type, math::Vector3, data_type, hash_function> hash_grid; - - class result_type - { - public: - vertex_type * m_data; - tetrahedron_type * m_query; - real_type m_w0; - real_type m_w1; - real_type m_w2; - real_type m_w3; - }; - - typedef std::list result_container; - - public: - - point_type position(data_type const & data) const - { - return data->m_coord; - } - - point_type min_coord(query_type const & query) const - { - using std::min; - - point_type & p0 = query.i()->m_coord; - point_type & p1 = query.j()->m_coord; - point_type & p2 = query.k()->m_coord; - point_type & p3 = query.m()->m_coord; - return min( p0, min( p1 , min( p2, p3) ) ); - } - - point_type max_coord(query_type const & query) const - { - using std::max; - - point_type & p0 = query.i()->m_coord; - point_type & p1 = query.j()->m_coord; - point_type & p2 = query.k()->m_coord; - point_type & p3 = query.m()->m_coord; - return max( p0, max( p1 , max( p2, p3) ) ); - } - - void reset(result_container & results) { results.clear(); }; - void report(data_type const & data, query_type const & query,result_container & results) - { - //--- First we do a quick rejection test. If the vertex is allready reported then simply ignore it!!! - if(data->m_tag == 1) - return; - - point_type & pi = query.i()->m_coord; - point_type & pj = query.j()->m_coord; - point_type & pk = query.k()->m_coord; - point_type & pm = query.m()->m_coord; - point_type & p = data->m_coord; - - real_type delta = 10e-5; - real_type lower = - delta; - real_type upper = 1.+ delta; - result_type result; - OpenTissue::geometry::barycentric_algebraic(pi,pj,pk,pm,p,result.m_w0,result.m_w1,result.m_w2,result.m_w3); - if( - (result.m_w0>lower)&&(result.m_w0lower)&&(result.m_w1lower)&&(result.m_w2lower)&&(result.m_w3m_tag = 1; - result.m_data = const_cast( data ); - result.m_query = const_cast( &query ); - results.push_back( result ); - return; - } - } - }; - - /** - * Bind Mesh Surface to t4mesh. - * - * - * @param M A surface mesh that should be bound to a volume mesh. - * @param V A T4Mesh it is implicitly assumed that node traits have a - * real_type and vector3_type (these are defined in the - * default node traits). - */ - template - void bind_surface (surface_mesh & M,volume_mesh & V,point_container & barycentric,index_container & bind_indices) - { - - //--- - //--- The main idea behind mesh coupling is to create a multiresolution for the - //--- animataion. The idea is to separate the visual geometry from the geometry - //--- used to compute the dynamics. This allows one to use highly detailed visual - //--- representation of objects, while using a computational low cost coarse volume - //--- mesh for the computing the dynamcis. - //--- - //--- A technique for doing this is callled mesh coupling or cartoon meshing. Below - //--- we describe how it is used together with tetrahedral meshes. It is however a - //--- general approach and can be used with other types of geometries, FFD lattices - //--- are probably anohter very common example on mesh coupling. - //--- - //--- When using Mesh Coulping the first step is to bind the vertices of the surface - //--- mesh to the tetrahedral elements of the volume mesh. - //--- - //--- Here we use a spatial hashing algorithm to find vertex tetrahedron pairs, where - //--- the vertex is embedded inside the tetrahedron. The actual test is done by first - //--- computing the barycentric coordinates of the vertex with respect to a tetrahedron - //--- in question. - //--- - //--- If each barycentric coordinate is greather than equal to zero and less than equal - //--- to one then the vertex is embedded in the tetrahedron. In pratice we need to apply - //--- treshold testing to counter numerical precision problems. It may therefor happen - //--- that vertices lying close to a face of a tetrahedron gets reported twice. Once of - //--- the tetrahedron embedding it and once for the neighboring tetetrahedron. The same - //--- happens if the vertex lies exactly on a face. - //--- - //--- Therefore, we firstdo a quick rejection test. If the vertex is allready reported - //--- then simply ignore it!!! - //--- - //--- Before rendering each frame, we must update the vertex positions to reflect the - //--- underlying deformation of the tetrahedral mesh. This is done using the barycentric - //--- coordinates, such that the new vertex position is given by - //--- - //--- c = w0 p0 + w1 p1 + w2 p2 + w3 p3 - //--- - //--- Where p0, p1 ,p2, and p3 are the nodal coordinates of the tetrahedron which - //--- the vertex was bounded to. - //--- - //--- If stiffness warping is used, the element rotation, Re, can be - //--- used to update the undeformed vertex normal, n0, into the deformed - //--- vertex normal, n, by, - //--- - //--- n = Re n0 - //--- - //--- Often a tetrahedra mesh is used with a conservative coverage of the surface mesh. - //--- That means one is guaranteed that all vertices of the surface mesh are embedded - //--- inside one unique tetrahedron. However, mesh coupling can be used in cases where - //--- one only have a partial coverage. The solution is to bind a vertex to the - //--- closest tetrahedron. Eventhough the vertex lies outside the tetrahedra mesh, the - //--- barycentric coordinates extend the deformation of the tetrahedra mesh beyond - //--- its surface. - //--- - typedef collision_policy policy; - typedef OpenTissue::spatial_hashing::PointDataQuery point_query_type; - typename policy::result_container results; - point_query_type point_query; - point_query.auto_init_settings(V.tetrahedron_begin(),V.tetrahedron_end()); - //--- perform query - mesh::clear_vertex_tags(M); - - std::vector vertex_ptr_container(M.size_vertices()); - unsigned int i = 0; - for(typename surface_mesh::vertex_iterator v= M.vertex_begin();v!=M.vertex_end();++v,++i) - { - vertex_ptr_container[i] = &(*v); - } - - point_query( - vertex_ptr_container.begin() - , vertex_ptr_container.end() - , V.tetrahedron_begin() - , V.tetrahedron_end() - , results - , typename point_query_type::all_tag() - ); - - unsigned int size = static_cast( results.size() ); - barycentric.resize(size); - bind_indices.resize(size); - typename policy::result_container::iterator Rbegin = results.begin(); - typename policy::result_container::iterator Rend = results.end(); - for(typename policy::result_container::iterator R = Rbegin;R!=Rend;++R) - { - unsigned int i = static_cast( R->m_data->get_handle().get_idx() ); - - barycentric[i](0) = R->m_w1; - barycentric[i](1) = R->m_w2; - barycentric[i](2) = R->m_w3; - bind_indices[i] = R->m_query->idx(); - } - }; - - /** - * Update Surface Mesh. - * - * - * @param M A surface mesh that is bound to a volume mesh. - * @param V The volume mesh that the surface is bound to. It - * is implicitly assumed that the node traits define - * a real_type and vector3_type ((these are defined in - * the default node traits). - * @param barycentric - * @param bind_info - */ - template - void update_surface ( - surface_mesh & M, - volume_mesh & V, - point_container const & barycentric, - index_container const & bind_info - ) - { - typename surface_mesh::vertex_iterator begin = M.vertex_begin(); - typename surface_mesh::vertex_iterator end = M.vertex_end(); - - typedef typename volume_mesh::tetrahedron_iterator tetrahedron_iterator; - typedef typename volume_mesh::node_type node_type; - typedef typename node_type::real_type real_type; - typedef typename node_type::vector3_type vector3_type; - - for( typename surface_mesh::vertex_iterator v = begin; v!=end; ++v) - { - unsigned int i = static_cast( v->get_handle().get_idx() ); - tetrahedron_iterator T = V.tetrahedron( bind_info[i] ); - - real_type w1 = barycentric[i](0); - real_type w2 = barycentric[i](1); - real_type w3 = barycentric[i](2); - real_type w0 = 1 - w1 - w2 - w3; - - vector3_type & p0 = T->i()->m_coord; - vector3_type & p1 = T->j()->m_coord; - vector3_type & p2 = T->k()->m_coord; - vector3_type & p3 = T->m()->m_coord; - v->m_coord = p0*w0 + p1*w1 + p2*w2 + p3*w3; - - } - }; - - } // namespace mesh_coupling - - } // namespace t4mesh - -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_MESH_COUPLING_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_remove_redundant_nodes.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_remove_redundant_nodes.h deleted file mode 100644 index e69de29bb..000000000 diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_constrained_delaunay_tetrahedralization.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_constrained_delaunay_tetrahedralization.h deleted file mode 100644 index 681840702..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_constrained_delaunay_tetrahedralization.h +++ /dev/null @@ -1,48 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_CONSTRAINED_DELAUNAY_TRIANGULATION_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_CONSTRAINED_DELAUNAY_TRIANGULATION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace t4mesh - { - namespace tetgen - { - - /** - * Constrained Delaunay Tetrahedralization Routine. - * - uses TetGen to create the resulting tetrahedal mesh - * - * @param polymesh A poly mesh, which holds a closed two-manifold. - * @param t4mesh A generic t4mesh, which upon return holds the generated tetrahedal mesh. - * - * @return if succesfull then the return value is true otherwise it is false. - */ - template - inline bool constrained_delaunay_tetrahedralization(const polymesh_type& polymesh, t4mesh_type & t4mesh) - { - OpenTissue::t4mesh::mesh_lofter_settings config; - - config.m_intermediate_file = "tmp"; - config.m_quality_ratio = 0.0; - config.m_maximum_volume = 0.0; - config.m_quiet_output = true; - - return OpenTissue::t4mesh::mesh_lofter(t4mesh, polymesh, config); - } - - } // namespace tetgen - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_CONSTRAINED_DELAUNAY_TRIANGULATION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_mesh_lofter.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_mesh_lofter.h deleted file mode 100644 index 36bc1a5ae..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_mesh_lofter.h +++ /dev/null @@ -1,128 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_MESH_LOFTER_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_MESH_LOFTER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include -#include - -#include -#include -#include -#include - - -namespace OpenTissue -{ - namespace t4mesh - { - - struct mesh_lofter_settings - { - mesh_lofter_settings() - : m_quality_ratio(2./*std::sqrt(2.)*/) - , m_maximum_volume(0.) - , m_intermediate_file("") - , m_quiet_output(false) - , m_verify_input(false) - {} - double m_quality_ratio; ///< quality t4mesh is issued if > 0. A minimum radius-edge ratio may be specifyed (default 2.0). - double m_maximum_volume; ///< max volume constraints on t4mesh if > 0. - std::string m_intermediate_file; ///< use intermediate files to/fro tetget if name specified. - bool m_quiet_output; ///< keep output spam as silent as possible, great for RELEASE. - bool m_verify_input; ///< DEBUG: detects plc intersections, i.e. verify "bad" input mesh. - }; - - - /** - * t4mesh_mesh_lofter. - * - uses tetgen to loft/extrude a closed two-manifold polymesh to a generic tetrahedal mesh - * - * @param polymesh A poly mesh, which holds a closed two-manifold. - * @param t4mesh A generic t4mesh, which upon return holds the generated tetrahedal mesh. - * @param settings The settings/configuration for TetGen, can be omitted to use the default settings. - * - */ - // TODO: Implement work-in-mem solution, thus avoid using intermediate files [MKC] - template - bool mesh_lofter(t4mesh_type& t4mesh, const polymesh_type& polymesh, const mesh_lofter_settings & settings = mesh_lofter_settings()) - { - // local functions are no go in C++, thus we need to wrap them in a local class, tsk! - class local_aux - { - public: - static bool error(const std::string& text) - { - using std::operator<<; - std::cerr << "ERROR [t4mesh_mesh_lofter]:\n- " << text << std::endl; - return false; - } - }; - - // convenient pointer to use with TetGen - char* tmp_file = settings.m_intermediate_file.size()>0?const_cast(settings.m_intermediate_file.c_str()):NULL; - - // "no tmp file" won't work check - if (!tmp_file) - return local_aux::error("current version only supports using intermediate files"); - - if (!is_manifold(polymesh)) - return local_aux::error("polymesh is not a two-manifold"); - - if (tmp_file) - if (!tetgen_write(settings.m_intermediate_file+".poly", polymesh)) - return local_aux::error("mesh_tetgen_write failed in writing the polymesh file: '"+settings.m_intermediate_file+".poly'"); - - std::stringstream tmp; - tmp << "p"; // piecewise linear complex (always) - if (settings.m_verify_input) - tmp << "d"; - else { - if (settings.m_quality_ratio > 0) - tmp << "q" << settings.m_quality_ratio; // quality - if (settings.m_maximum_volume > 0) - tmp << "a" << settings.m_maximum_volume; // max volume - if (settings.m_quiet_output) - tmp << "Q"; // keep quiet :) - } - std::string txt = tmp.str().c_str(); - tetgenbehavior config; - // MKC: setting vars in tetgenbehavior explicitly is too complicated, and requires a deeper knowledge of the system :( - if (!config.parse_commandline(const_cast(txt.c_str()))) // parsing a "cmd" line will set the correct vars and their dependecies. - return local_aux::error("TetGen parse_commandline failed: '"+txt+"'"); - - tetgenio in, out; - if (tmp_file) - if (!in.load_poly(tmp_file)) - return local_aux::error("TetGen load_poly failed: '"+settings.m_intermediate_file+"'"); - - // let TetGen do some magic :) - tetrahedralize(&config, &in, &out); - - if (out.numberoftetrahedra < 1) - return local_aux::error("TetGen tetrahedralize failed: no tetrahedra generated!"); - - if (tmp_file) { - out.save_elements(tmp_file); - out.save_nodes(tmp_file); - - if (!tetgen_read(settings.m_intermediate_file, t4mesh)) - return local_aux::error("t4mesh_tetgen_read failed in reading the data: '"+settings.m_intermediate_file+"'"); - } - - return true; - } - - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_MESH_LOFTER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_quality_tetrahedralization.h b/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_quality_tetrahedralization.h deleted file mode 100644 index 5f05ab450..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/containers/t4mesh/util/t4mesh_tetgen_quality_tetrahedralization.h +++ /dev/null @@ -1,48 +0,0 @@ -#ifndef OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_QUALITY_TETRAHEDRALIZATION_H -#define OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_QUALITY_TETRAHEDRALIZATION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace t4mesh - { - namespace tetgen - { - - /** - * Quality Tetrahedralization Routine. - * - uses TetGen to create the resulting tetrahedal mesh - * - * @param polymesh A poly mesh, which holds a closed two-manifold. - * @param t4mesh A generic t4mesh, which upon return holds the generated tetrahedal mesh. - * - * @return if succesfull then the return value is true otherwise it is false. - */ - template - inline bool quality_tetrahedralization(const polymesh_type& polymesh, t4mesh_type & t4mesh) - { - OpenTissue::t4mesh::mesh_lofter_settings config; - - config.m_intermediate_file = "tmp"; - config.m_quality_ratio = 2.0; - config.m_maximum_volume = 0.0; - config.m_quiet_output = true; - - return OpenTissue::t4mesh::mesh_lofter(t4mesh, polymesh, config); - } - - } // namespace tetgen - } // namespace t4mesh -} // namespace OpenTissue - -//OPENTISSUE_CORE_CONTAINERS_T4MESH_UTIL_T4MESH_TETGEN_QUALITY_TETRAHEDRALIZATION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_aabb.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_aabb.h deleted file mode 100644 index 77a042fe4..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_aabb.h +++ /dev/null @@ -1,368 +0,0 @@ -#ifndef OPENTISSUE_CORE_GEOMETRY_GEOMETRY_AABB_H -#define OPENTISSUE_CORE_GEOMETRY_GEOMETRY_AABB_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -#include -#include - - -namespace OpenTissue -{ - - namespace geometry - { - - /** - * Axed Aligned Bounding Box (AABB). - */ - template< typename math_types_ > - class AABB - : public VolumeShape< math_types_ > - , public OpenTissue::utility::ClassID< AABB > - { - public: - - typedef math_types_ math_types; - typedef typename math_types::value_traits value_traits; - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - typedef typename math_types::quaternion_type quaternion_type; - - public: - - vector3_type m_min; ///< Coordinates of minimum corner. - vector3_type m_max; ///< Coordinates of maximum corner. - - public: - - size_t const class_id() const { return OpenTissue::utility::ClassID >::class_id(); } - - AABB() - { - m_min.clear(); - m_max.clear(); - } - - explicit AABB( - real_type const & xmin - , real_type const & ymin - , real_type const & zmin - , real_type const & xmax - , real_type const & ymax - , real_type const & zmax - ) - { - set(xmin,ymin,zmin,xmax,ymax,zmax); - } - - explicit AABB( vector3_type const & pmin_v, vector3_type const & pmax_v) { set(pmin_v,pmax_v); } - - virtual ~AABB() {} - - public: - - void compute_surface_points(std::vector & points) const - { - vector3_type dia; - dia = m_max - m_min; - - vector3_type p000 = m_min; - vector3_type p001 = m_min + vector3_type( dia[0], value_traits::zero(), value_traits::zero()); - vector3_type p010 = m_min + vector3_type(value_traits::zero(), dia[1], value_traits::zero()); - vector3_type p011 = m_min + vector3_type( dia[0], dia[1], value_traits::zero()); - vector3_type p100 = m_min + vector3_type(value_traits::zero(), value_traits::zero(), dia[2]); - vector3_type p101 = m_min + vector3_type( dia[0], value_traits::zero(), dia[2]); - vector3_type p110 = m_min + vector3_type(value_traits::zero(), dia[1], dia[2]); - vector3_type p111 = m_min + vector3_type( dia[0], dia[1], dia[2]); - - points.push_back(p000); - points.push_back(p001); - points.push_back(p010); - points.push_back(p011); - points.push_back(p100); - points.push_back(p101); - points.push_back(p110); - points.push_back(p111); - } - - vector3_type center() const { return vector3_type( (m_max+m_min)/value_traits::two() ); } - - public: - /** - * Assingment Method. - * Assigns the size of the specified AABB to this AABB. - * - * @param other_aabb Another AABB - */ - void set(AABB const & other_aabb) - { - this->m_min = other_aabb.m_min; - this->m_max = other_aabb.m_max; - } - - void set( vector3_type const & pmin_v, vector3_type const & pmax_v) - { - assert(pmin_v[0] <= pmax_v[0] || !"AABB.set(): minimum must be less than or equal to maximum"); - assert(pmin_v[1] <= pmax_v[1] || !"AABB.set(): minimum must be less than or equal to maximum"); - assert(pmin_v[2] <= pmax_v[2] || !"AABB.set(): minimum must be less than or equal to maximum"); - m_min = pmin_v; - m_max = pmax_v; - } - - /** - * Set AABB box. - * - * @param xmin - * @param ymin - * @param zmin - * @param xmax - * @param ymax - * @param zmax - */ - void set( - real_type const & xmin - , real_type const & ymin - , real_type const & zmin - , real_type const & xmax - , real_type const & ymax - , real_type const & zmax - ) - { - assert(xmin<=xmax || !"AABB.set(): minimum must be less than or equal to maximum"); - assert(ymin<=ymax || !"AABB.set(): minimum must be less than or equal to maximum"); - assert(zmin<=zmax || !"AABB.set(): minimum must be less than or equal to maximum"); - m_min = vector3_type(xmin,ymin,zmin); - m_max = vector3_type(xmax,ymax,zmax); - } - - /** - * Set AABB box. - * - * @param xmin - * @param ymin - * @param zmin - * @param width - * @param height - * @param depth - */ - void extent( - real_type const & xmin - , real_type const & ymin - , real_type const & zmin - , real_type const & width - , real_type const & height - , real_type const & depth - ) - { - assert(width>=0 || !"AABB.extent(): width must be non-negative"); - assert(height>=0 || !"AABB.extent(): height must be non-negative"); - assert(depth>=0 || !"AABB.extent(): depth must be non-negative"); - m_min = vector3_type(xmin,ymin,zmin); - m_max = vector3_type(xmin+width,ymin+height,zmin+depth); - } - - public: - - real_type const & x() const { return m_min[0]; } - real_type const & y() const { return m_min[1]; } - real_type const & z() const { return m_min[2]; } - real_type w() const { return m_max[0] - m_min[0]; } - real_type h() const { return m_max[1] - m_min[1]; } - real_type d() const { return m_max[2] - m_min[2]; } - - vector3_type & min() { return m_min; } - vector3_type & max() { return m_max; } - vector3_type const & min() const { return m_min; } - vector3_type const & max() const { return m_max; } - - /** - * Update Bounding Box - * This method updates the size of the AABB such that it encloses the - * given nodes. - * - * @param n0 - * @param n1 - * @param n2 - */ - void update(vector3_type const & n0,vector3_type const & n1, vector3_type const & n2) - { - using std::min; - using std::max; - - m_min[0] = min(n2[0],min(n1[0],n0[0])); - m_min[1] = min(n2[1],min(n1[1],n0[1])); - m_min[2] = min(n2[2],min(n1[2],n0[2])); - m_max[0] = max(n2[0],max(n1[0],n0[0])); - m_max[1] = max(n2[1],max(n1[1],n0[1])); - m_max[2] = max(n2[2],max(n1[2],n0[2])); - } - - /** - * Update Bounding Box - * This method updates the size of the AABB such that it encloses the - * given nodes. - * - * @param n0 - * @param n1 - * @param n2 - * @param n3 - */ - void update(vector3_type const & n0,vector3_type const & n1,vector3_type const & n2, vector3_type const & n3) - { - using std::min; - using std::max; - - m_min[0] = min(n3[0],min(n2[0],min(n1[0],n0[0]))); - m_min[1] = min(n3[1],min(n2[1],min(n1[1],n0[1]))); - m_min[2] = min(n3[2],min(n2[2],min(n1[2],n0[2]))); - m_max[0] = max(n3[0],max(n2[0],max(n1[0],n0[0]))); - m_max[1] = max(n3[1],max(n2[1],max(n1[1],n0[1]))); - m_max[2] = max(n3[2],max(n2[2],max(n1[2],n0[2]))); - } - - /** - * Update Box. - * This method updates the size of the AABB such that it encloses - * the given AABBs. - * - * @param A - * @param B - */ - void update(AABB const & A,AABB const & B) - { - using std::min; - using std::max; - - m_min[0] = min(A.m_min[0],B.m_min[0]); - m_min[1] = min(A.m_min[1],B.m_min[1]); - m_min[2] = min(A.m_min[2],B.m_min[2]); - m_max[0] = max(A.m_max[0],B.m_max[0]); - m_max[1] = max(A.m_max[1],B.m_max[1]); - m_max[2] = max(A.m_max[2],B.m_max[2]); - } - - /** - * Get Volume. - * - * @return The current value of the volume of the AABB. - */ - real_type volume() const - { - vector3_type vd = m_max-m_min; - return vd[0]*vd[1]*vd[2]; - } - - real_type area() const - { - vector3_type vd = m_max-m_min; - return 2*vd[0]*vd[1] + 2*vd[0]*vd[2] + 2*vd[2]*vd[1]; - } - - real_type diameter() const - { - vector3_type vd = m_max-m_min; - return length(vd); - } - - void translate(vector3_type const & T) - { - m_max += T; - m_min += T; - } - - void rotate(matrix3x3_type const & /*R*/) { } - - void scale(real_type const & s) - { - assert(s>=value_traits::zero() || !"AABB::scale: s must be non-negative"); - vector3_type c = center(); - m_min -= c; - m_max -= c; - m_min *= s; - m_max *= s; - m_min += c; - m_max += c; - } - - vector3_type get_support_point(vector3_type const & v) const - { - vector3_type dir = unit(v); - vector3_type ext = (m_max - m_min)/2.; - vector3_type c = center(); - vector3_type p(0,0,0); - - real_type sign = value_traits::zero(); - real_type tst = ext[0] * dir[0]; - if(tst>0) - sign = value_traits::one(); - else if(tst<0) - sign = -value_traits::one(); - else //(tst==0) - sign = value_traits::zero(); - p[0] += sign * ext[0]; - - tst = ext[1] * dir[1]; - if(tst>0) - sign = value_traits::one(); - else if(tst<0) - sign = -value_traits::one(); - else //(tst==0) - sign = value_traits::zero(); - p[1] += sign * ext[1]; - - tst = ext[2] * dir[2]; - if(tst>0) - sign = value_traits::one(); - else if(tst<0) - sign = -value_traits::one(); - else //(tst==0) - sign = value_traits::zero(); - p[2] += sign * ext[2]; - p += c; - return p; - } - - - - /** - * Compute Bounding Box. - * This method computes an axis aligned bounding - * box (AABB) that encloses the geometry. - * - * @param r The position of the model frame (i.e the coordinate frame the geometry lives in). - * @param R The orientation of the model frame (i.e the coordinate frame the geometry lives in). - * @param min_coord Upon return holds the minimum corner of the box. - * @param max_coord Upon return holds the maximum corner of the box. - * - */ - void compute_collision_aabb( - vector3_type const & r - , matrix3x3_type const & /*R*/ - , vector3_type & min_coord - , vector3_type & max_coord - ) const - { - min_coord = r + this->min(); - max_coord = r + this->max(); - } - - - }; - - } // namespace geometry - -} // namespace OpenTissue - -//OPENTISSUE_CORE_GEOMETRY_GEOMETRY_AABB_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_barycentric.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_barycentric.h deleted file mode 100644 index b4717bba8..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_barycentric.h +++ /dev/null @@ -1,394 +0,0 @@ -#ifndef OPENTISSUE_CORE_GEOMETRY_BARYCENTRIC_H -#define OPENTISSUE_CORE_GEOMETRY_BARYCENTRIC_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - -#include -#include - -namespace OpenTissue -{ - namespace geometry - { - - /* - * Compute Barycentric Coordinates. - * This method computes the barycentric coodinates for a point x3 of an edge - * given by the points x1 and x2. - * - * The barycentric coordinates w1 and w2 are defined such - * that x3' = w1*x1 + w2*x2, is the point on the line closest to x3. - * - * if 0 <= w1,w2 <= 1 then the point lies inside or on the perimeter of the triangle. - * - * @warning This method uses a geometric approach to compute the barycentric coordinates. - * - * @param x1 The first point of the edge. - * @param x2 The second point of the edge. - * @param x3 The point for which the barycentric coordinates should be computed. - * @param w1 Upon return this parameter contains the value of the first barycentric coordinate. - * @param w2 Upon return this parameter contains the value of the second barycentric coordinate. - */ - template - inline void barycentric_geometric( - V const & x1 - , V const & x2 - , V const & x3 - , typename V::value_type & w1 - , typename V::value_type & w2 - ) - { - using std::sqrt; - - typedef typename V::value_type T; - typedef typename V::value_traits value_traits; - - V const u = x2-x1; - T const uu = dot(u,u); - - assert( is_number(uu) || !"barycentric_geometric(): NaN encountered"); - assert( uu > value_traits::zero() || !"barycentric_geometric(): Degenerate edge encountered"); - - // Project x3 onto edge running from x1 to x2. - V const q = (dot(u, x3-x1)/ uu )*u + x1; - V const a = q - x2; - //V const b = q-x1; - T const aa = dot(a,a); - - assert( is_number(aa) || !"barycentric_geometric(): NaN encountered"); - - //T const bb = dot(b,b); - w1 = sqrt( aa / uu ); - w2 = value_traits::one() - w1; // sqrt( bb / uu ); - - assert( is_number(w1) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(w2) || !"barycentric_geometric(): NaN encountered"); - - assert( w1 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w1 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w2 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w2 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - } - - /* - * Compute Barycentric Coordinates. - * This method computes the barycentric coodinates for a point x4 of a triangle - * given by the points x1,x2, and x3 (in counter clockwise order). - * - * The barycentric coordinates w1,w2, and w3 are defined such - * that x4' = w1*x1 + w2*x2 + w3*x3, is the point in plane of the - * triangle closest to x4. - * - * if 0 <= w1,w2,w3 <= 1 then the point lies inside or on the perimeter of the triangle. - * - * @warning This method uses a geometric approach to compute the barycentric coordinates. - * - * @param x1 The first point of the triangle. - * @param x2 The second point of the triangle. - * @param x3 The third point of the triangle. - * @param x4 The point for which the barycentric coordinates should be computed. - * @param w1 Upon return this parameter contains the value of the first barycentric coordinate. - * @param w2 Upon return this parameter contains the value of the second barycentric coordinate. - * @param w3 Upon return this parameter contains the value of the third barycentric coordinate. - */ - template - inline void barycentric_geometric( - V const & x1 - , V const & x2 - , V const & x3 - , V const & x4 - , typename V::value_type & w1 - , typename V::value_type & w2 - , typename V::value_type & w3 - ) - { - using std::sqrt; - - typedef typename V::value_type T; - typedef typename V::value_traits value_traits; - - V const n = cross( x1-x3, x2-x3); - T const nn = dot(n,n); - - assert( is_number(nn) || !"barycentric_geometric(): NaN encountered"); - assert( nn > value_traits::zero() || !"barycentric_geometric(): Degenerate triangle encountered"); - - V const q = x4 - ( dot(n, x4 - x1)*n / nn ); - V const a = cross( x2-q, x3-q); - V const b = cross( x1-q, x3-q); - //V const c = cross( x1-q, x2-q); - - T const aa = dot(a,a); - T const bb = dot(b,b); - //T const cc = dot(c,c); - - assert( is_number(aa) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(bb) || !"barycentric_geometric(): NaN encountered"); - //assert( is_number(cc) || !"barycentric_geometric(): NaN encountered"); - - w1 = sqrt( aa / nn ); - w2 = sqrt( bb / nn ); - w3 = value_traits::one() - w1 - w2; // sqrt( cc / nn ); - - assert( is_number(w1) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(w2) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(w3) || !"barycentric_geometric(): NaN encountered"); - - assert( w1 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w1 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w2 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w2 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w3 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w3 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - } - - /* - * Compute Barycentric Coordinates. - * This method computes the barycentric coodinates for a point p of a tetrahedron - * given by the points x1,x2,x3, x4 (in right-hand order). - * - * @warning This method uses a geometric approach to compute the barycentric coordinates. - * - * @param x1 The first point of the triangle. - * @param x2 The second point of the triangle. - * @param x3 The third point of the triangle. - * @param x4 The fourth point of the triangle. - * @param p The point for which the barycentric coordinates should be computed. - * @param w1 Upon return this parameter contains the value of the first barycentric coordinate. - * @param w2 Upon return this parameter contains the value of the second barycentric coordinate. - * @param w3 Upon return this parameter contains the value of the third barycentric coordinate. - * @param w4 Upon return this parameter contains the value of the fourth barycentric coordinate. - */ - template - inline void barycentric_geometric( - V const & x1 - , V const & x2 - , V const & x3 - , V const & x4 - , V const & p - , typename V::value_type & w1 - , typename V::value_type & w2 - , typename V::value_type & w3 - , typename V::value_type & w4 - ) - { - using std::fabs; - - typedef typename V::value_type T; - typedef typename V::value_traits value_traits; - - T const V6 = fabs( dot( (x1-x4), cross( x2-x4, x3-x4 ) ) ); - - assert( is_number(V6) || !"barycentric_geometric(): NaN encountered"); - assert( V6 > value_traits::zero() || !"barycentric_geometric(): Degenerate tetrahedron encountered"); - - w1 = fabs( dot( (x2-p), cross( (x3-p), (x4-p) ) ) ) / V6; - w2 = fabs( dot( (x1-p), cross( (x3-p), (x4-p) ) ) ) / V6; - w3 = fabs( dot( (x1-p), cross( (x2-p), (x4-p) ) ) ) / V6; - //w4 = fabs( dot( (x1-p), cross( (x2-p), (x3-p) ) ) ); - w4 = value_traits::one() - w1 -w2 - w3; - - assert( is_number(w1) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(w2) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(w3) || !"barycentric_geometric(): NaN encountered"); - assert( is_number(w4) || !"barycentric_geometric(): NaN encountered"); - - assert( w1 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w1 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w2 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w2 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w3 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w3 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w4 >= value_traits::zero() || !"barycentric_geometric(): Illegal coordinate encountered"); - assert( w4 <= value_traits::one() || !"barycentric_geometric(): Illegal coordinate encountered"); - } - - /* - * Compute Barycentric Coordinates. - * This method computes the barycentric coodinates for a point p of a triangle - * given by the points x1,x2, and x3 (in counter clockwise order). - * - * The barycentric coordinates w1, w2, and w3 are defined such - * that p' = w1*x1 + w2*x2 + w3*x3, is the point in plane of the - * triangle closest to p. - * - * if 0 <= w1,w2,w3 <= 1 then the point lies inside or on the perimeter of the triangle. - * - * @warning This method uses a algebraic approach to compute the barycentric coordinates. - * - * @param x1 The first point of the triangle. - * @param x2 The second point of the triangle. - * @param x3 The third point of the triangle. - * @param p The point for which the barycentric coordinates should be computed. - * @param w1 Upon return this parameter contains the value of the first barycentric coordinate. - * @param w2 Upon return this parameter contains the value of the second barycentric coordinate. - * @param w3 Upon return this parameter contains the value of the third barycentric coordinate. - */ - template - inline void barycentric_algebraic( - V const & x1 - , V const & x2 - , V const & x3 - , V const & p - , typename V::value_type & w1 - , typename V::value_type & w2 - , typename V::value_type & w3 - ) - { - typedef typename V::value_type T; - typedef math::ValueTraits value_traits; - - //--- We compute barycentric coordinates, w1,w2,w3, of p, that is we solve the linear system - //--- - //--- |(x1-x3).(x1-x3) (x1-x3).(x2-x3)| |w1| |(x1-x3).(p-x3)| - //--- |(x1-x3).(x2-x3) (x2-x3).(x2-x3)| |w2| = |(x2-x3).(p-x3)| - //--- w1 + w2 + w3 = 1 - //--- - V x13 = x1-x3; - V x23 = x2-x3; - V x43 = p-x3; - - //--- - //--- We introduce the shorthand notation - //--- - //--- |a11 a12| |w1| |b1| - //--- |a12 a22| |w2| = |b2| - //--- - //--- Isolating w2 from the second equation yields - //--- - //--- w2 = (b2 - a12 w1)/a22 - //--- = b2/a22 - (a12/a22)w1 - //--- - //--- And substituting into the first gives - //--- - //--- a11 w1 + a12 ((b2 - a12 w1)/a22) = b1 - //--- a11 w1 + (a12/a22)*b2 - a12*(a12/a22)*w1 = b1 - //--- (a11 - a12*(a12/a22))*w1 = b1 - (a12/a22)*b2 - //--- - //--- Letting f = a12/a22 (to minimize computations by collecting common subterms) and - //--- - //--- m = (a11 - a12*f) - //--- n = b1 - f*b2 - //--- - //--- we have - //--- - //--- w1 = n/m - //--- w2 = b2/a22 - f*w1 - //--- w3 = 1 - w1 - w2 - //--- - //--- Since we always have a11>0 and a22>0 a solution will always exist - //--- regardless of the value of a12,b1 and b2 - //--- - - T a11 = dot(x13 , x13); - T a12 = dot(x13 , x23); - T a22 = dot(x23 , x23); - T b1 = dot(x13 , x43); - T b2 = dot(x23 , x43); - - assert( is_number(a11) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(a12) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(a22) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(b1) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(b2) || !"barycentric_algebraic(): NaN encountered"); - - assert( a22 < value_traits::zero() || a22>value_traits::zero() || !"barycentric_algebraic(): Degenerate triangle encountered"); - - T f = a12/a22; - T m = (a11 - a12*f); - T n = b1-(b2*f); - - assert( is_number(f) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(m) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(n) || !"barycentric_algebraic(): NaN encountered"); - - assert( m < value_traits::zero() || m > value_traits::zero() || !"barycentric_algebraic(): potential division by zero"); - - w1 = n/m; - w2 = b2/a22 - f*w1; - w3 = value_traits::one() - w1 - w2; - - assert( is_number(w1) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(w2) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(w3) || !"barycentric_algebraic(): NaN encountered"); - } - - /* - * Compute Barycentric Coordinates. - * This method computes the barycentric coodinates for a point p of a tetrahedron - * given by the points x1,x2,x3, p (in right-hand order). - * - * @warning This method uses a algebraic approach to compute the barycentric coordinates. - * - * @param x1 The first point of the triangle. - * @param x2 The second point of the triangle. - * @param x3 The third point of the triangle. - * @param x4 The fourth point of the triangle. - * @param p The point for which the barycentric coordinates should be computed. - * @param w1 Upon return this parameter contains the value of the first barycentric coordinate. - * @param w2 Upon return this parameter contains the value of the second barycentric coordinate. - * @param w3 Upon return this parameter contains the value of the third barycentric coordinate. - * @param w4 Upon return this parameter contains the value of the fourth barycentric coordinate. - */ - template - inline void barycentric_algebraic( - V const & x1 - , V const & x2 - , V const & x3 - , V const & x4 - , V const & p - , typename V::value_type & w1 - , typename V::value_type & w2 - , typename V::value_type & w3 - , typename V::value_type & w4 - ) - { - typedef typename V::value_type T; - typedef math::ValueTraits value_traits; - typedef math::Matrix3x3 M; // 2008-08-01 kenny: This is rather bad, it makes this function hardwired to our own matrix3x3 type! - - M P; - - P(0,0) = x1(0) - x4(0); - P(1,0) = x1(1) - x4(1); - P(2,0) = x1(2) - x4(2); - - P(0,1) = x2(0) - x4(0); - P(1,1) = x2(1) - x4(1); - P(2,1) = x2(2) - x4(2); - - P(0,2) = x3(0) - x4(0); - P(1,2) = x3(1) - x4(1); - P(2,2) = x3(2) - x4(2); - - P = math::inverse(P); // 2008-08-01 kenny: This is very specific for our OT library, it should probably be a policy? - - V w = P * V(p-x4); - - w1 = w(0); - w2 = w(1); - w3 = w(2); - w4 = value_traits::one() - w1 - w2 - w3; - - assert( is_number(w1) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(w2) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(w3) || !"barycentric_algebraic(): NaN encountered"); - assert( is_number(w4) || !"barycentric_algebraic(): NaN encountered"); - - } - - } // namespace geometry -} // namespace OpenTissue - -// OPENTISSUE_CORE_GEOMETRY_BARYCENTRIC_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_base_shape.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_base_shape.h deleted file mode 100644 index 8d1b08cc4..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_base_shape.h +++ /dev/null @@ -1,64 +0,0 @@ -#ifndef OPENTISSUE_CORE_GEOMETRY_GEOMETRY_BASE_SHAPE_H -#define OPENTISSUE_CORE_GEOMETRY_GEOMETRY_BASE_SHAPE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include - - -namespace OpenTissue -{ - - namespace geometry - { - - /** - * BaseShape Template Class - * If you implement a new geometry type then you should derive your geometry class from the BaseShape class - * - * @tparam math_types standard math types containing at least the real, vector3 and matrix3x3 types. - **/ - template< typename math_types > - class BaseShape - : public OpenTissue::collision::GeometryInterface< math_types > - { - public: - - virtual ~BaseShape() {} - - public: - - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - - -// 2007-07-24 kenny: generic design problem with compute_surface_points -// 2007-09-11 micky: I agree, it's not possible to have a pure abstract interface and letting the user decide his choice of point container. -// 2007-09-11 micky: compute_surface_points and get_support_point should be removed from this interface. Both functions belong to some collision interface. -// 2007-09-18 kenny: I partial agree... get_support_point is used by GJK (exclusively as I recall?) However, compute_surface_points is used by some of the geometry utils. Fitting tools and such. - - // TODO 2007-02-06 kenny: Yikes what if end-user wants to use std::list or some homebrewed container type? It is a bit ugly that the container type is hardwired into the abstract base class:-( Could we make something like a pure virtual template class? - virtual void compute_surface_points( std::vector & points) const = 0; - virtual vector3_type get_support_point(vector3_type const & v) const = 0; - - virtual void translate(vector3_type const & T) = 0; - virtual void rotate(matrix3x3_type const & R) = 0; - virtual void scale(real_type const & s) = 0; - - }; - - } // namespace geometry - -} // namespace OpenTissue - -//OPENTISSUE_CORE_GEOMETRY_GEOMETRY_BASE_SHAPE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_compute_tetrahedron_aabb.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_compute_tetrahedron_aabb.h deleted file mode 100644 index 615213656..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_compute_tetrahedron_aabb.h +++ /dev/null @@ -1,103 +0,0 @@ -#ifndef OPENTISSUE_CORE_GEOMETRY_GEOMETRY_COMPUTE_TETRAHEDRON_AABB_H -#define OPENTISSUE_CORE_GEOMETRY_GEOMETRY_COMPUTE_TETRAHEDRON_AABB_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace geometry - { - /** - * Compute AABB of Tetrahedron. - * - * - * @param p0 The position of a corner of the tetrahedron. - * @param p1 The position of a corner of the tetrahedron. - * @param p2 The position of a corner of the tetrahedron. - * @param p3 The position of a corner of the tetrahedron. - * @param min_coord Upon return holds the minimum coordinate corner of the AABB. - * @param max_coord Upon return holds the maximum coordinate corner of the AABB. - */ - template - void compute_tetrahedron_aabb( - vector3_type const & p0 - , vector3_type const & p1 - , vector3_type const & p2 - , vector3_type const & p3 - , vector3_type & min_coord - , vector3_type & max_coord - ) - { - using std::min; - - min_coord = min(p0, p1); - min_coord = min(min_coord, p2); - min_coord = min(min_coord, p3); - - max_coord = max(p0, p1); - max_coord = max(max_coord, p2); - max_coord = max(max_coord, p3); - } - - /** - * Compute Tetrahedron AABB. - * - * This function computes a tight fitting axis aligned bounding box around the specified tetrahedron. - * - * @param tetrahedron The specified tetrahedron. - * @param min_coord Upon return holds the minimum coordinate corner of the AABB. - * @param max_coord Upon return holds the maximum coordinate corner of the AABB. - */ - template - void compute_tetrahedron_aabb( - tetrahedron_type const & tetrahedron - , vector3_type & min_coord - , vector3_type & max_coord - ) - { - compute_tetrahedron_aabb(tetrahedron.p0(),tetrahedron.p1(),tetrahedron.p2(),tetrahedron.p3(),min_coord,max_coord); - } - - /** - * Compute Tetrahedron AABB. - * - * This function computes a tight fitting axis aligned bounding box around the specified tetrahedron. - * - * @param tetrahedron The specified tetrahedron. - * @param aabb Upon return holds the computed AABB. - */ - template - void compute_tetrahedron_aabb(tetrahedron_type const & tetrahedron,aabb_type & aabb) - { - compute_tetrahedron_aabb(tetrahedron.p0(),tetrahedron.p1(),tetrahedron.p2(),tetrahedron.p3(),aabb.min(),aabb.max()); - } - - /** - * Compute Tetrahedron AABB. - * - * This function computes a tight fitting axis aligned bounding box around the specified tetrahedron. - * - * @param tetrahedron The specified tetrahedron. - * @return The computed AABB. - */ - template - geometry::AABB compute_tetrahedron_aabb(tetrahedron_type const & tetrahedron) - { - geometry::AABB aabb; - compute_tetrahedron_aabb(tetrahedron,aabb); - return aabb; - } - - } //End of namespace geometry -} //End of namespace OpenTissue - -// OPENTISSUE_CORE_GEOMETRY_GEOMETRY_COMPUTE_TETRAHEDRON_AABB_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron.h deleted file mode 100644 index fd00cd0c1..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron.h +++ /dev/null @@ -1,272 +0,0 @@ -#ifndef OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_H -#define OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -#include -#include -#include - -#include -#include -#include - - -namespace OpenTissue -{ - - namespace geometry - { - - template< typename math_types_ > - class Tetrahedron - : public VolumeShape< math_types_ > - , public OpenTissue::utility::ClassID< OpenTissue::geometry::Tetrahedron > - { - public: - - typedef math_types_ math_types; - typedef typename math_types::value_traits value_traits; - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - typedef typename math_types::quaternion_type quaternion_type; - - protected: - - vector3_type m_p0; ///< Tetrahedron vertex number 1 - vector3_type m_p1; ///< Tetrahedron vertex number 2 - vector3_type m_p2; ///< Tetrahedron vertex number 3 - vector3_type m_p3; ///< Tetrahedron vertex number 4 - - public: - - size_t const class_id() const { return OpenTissue::utility::ClassID >::class_id(); } - - Tetrahedron() - { - m_p0.clear(); - m_p1.clear(); - m_p2.clear(); - m_p3.clear(); - } - - virtual ~Tetrahedron() {} - - Tetrahedron(Tetrahedron const & tetrahedron_) { set(tetrahedron_); } - - Tetrahedron( vector3_type const & p0, vector3_type const & p1, vector3_type const & p2, vector3_type const & p3) - { - set(p0,p1,p2,p3); - } - - Tetrahedron const & operator=(Tetrahedron const & tetrahedron_) - { - set(tetrahedron_); - return *this; - } - - void set(Tetrahedron const & t) - { - m_p0 = t.m_p0; - m_p1 = t.m_p1; - m_p2 = t.m_p2; - m_p3 = t.m_p3; - } - - void set(vector3_type const & p0, vector3_type const & p1, vector3_type const & p2, vector3_type const & p3) - { - m_p0 = p0; - m_p1 = p1; - m_p2 = p2; - m_p3 = p3; - } - - real_type area() const - { - vector3_type u,v,uXv; - real_type A = value_traits::zero(); - - u = m_p1-m_p0; - v = m_p2-m_p0; - uXv = (u % v); - A += length(uXv); - - u = m_p0-m_p3; - v = m_p1-m_p3; - uXv = (u % v); - A += length(uXv); - - u = m_p1-m_p3; - v = m_p2-m_p3; - uXv = (u % v); - A += length(uXv); - - u = m_p2-m_p3; - v = m_p0-m_p3; - uXv = (u % v); - A += length(uXv); - - return A/value_traits::two(); - } - - void compute_surface_points(std::vector & points) const - { - points.push_back(m_p0); - points.push_back(m_p1); - points.push_back(m_p2); - points.push_back(m_p3); - } - - vector3_type & p0() { return m_p0; }; - vector3_type & p1() { return m_p1; }; - vector3_type & p2() { return m_p2; }; - vector3_type & p3() { return m_p3; }; - vector3_type const & p0() const { return m_p0; }; - vector3_type const & p1() const { return m_p1; }; - vector3_type const & p2() const { return m_p2; }; - vector3_type const & p3() const { return m_p3; }; - - vector3_type center() const { return vector3_type( (m_p0+m_p1+m_p2+m_p3)/4. ); }; - - /** - * Compute Barycentric Coordinates. - * - * @param p The point for which the barycentric coordinates should be computed. - * @param w1 Upon return this parameter contains the value of the first barycentric coordinate. - * @param w2 Upon return this parameter contains the value of the second barycentric coordinate. - * @param w3 Upon return this parameter contains the value of the third barycentric coordinate. - * @param w4 Upon return this parameter contains the value of the fourth barycentric coordinate. - */ - void barycentric(vector3_type const & p,real_type & w1,real_type & w2,real_type & w3,real_type & w4) const - { - OpenTissue::geometry::barycentric_algebraic(m_p0,m_p1,m_p2,m_p3,p,w1,w2,w3,w4); - } - - real_type diameter() const - { - using std::max; - using std::sqrt; - - vector3_type x30 = m_p3 - m_p0; - vector3_type x20 = m_p2 - m_p0; - vector3_type x10 = m_p1 - m_p0; - real_type d = max( max(x30*x30, x20*x20), x10*x10); - return sqrt(d); - } - - vector3_type get_support_point(vector3_type const & v) const - { - vector3_type p; - real_type tst = -FLT_MAX;//math::detail::lowest(); - real_type tmp = v * m_p0; - if (tmp>tst) - { - tst = tmp; - p = m_p0; - } - tmp = v * m_p1; - if (tmp>tst) - { - tst = tmp; - p = m_p1; - } - tmp = v *m_p2; - if (tmp>tst) - { - tst = tmp; - p = m_p2; - } - tmp = v * m_p3; - if (tmp>tst) - { - tst = tmp; - p = m_p3; - } - return p; - } - - void translate(vector3_type const & T) - { - m_p0 += T; - m_p1 += T; - m_p2 += T; - m_p3 += T; - } - - void rotate(matrix3x3_type const & R) - { - vector3_type c = center(); - m_p0 = (R*(m_p0 - c)) + c; - m_p1 = (R*(m_p1 - c)) + c; - m_p2 = (R*(m_p2 - c)) + c; - m_p3 = (R*(m_p3 - c)) + c; - } - - void scale(real_type const & s) - { - vector3_type c = center(); - m_p0 = s*(m_p0 - c) + c; - m_p1 = s*(m_p1 - c) + c; - m_p2 = s*(m_p2 - c) + c; - m_p3 = s*(m_p3 - c) + c; - } - - real_type volume() const - { - /* - ** From Zienkiewicz & Taylor p.637 - ** V = 1/6*det( 1 x0 y0 z0; 1 x1 y1 z1; 1 x2 y2 z2; 1 x3 y3 z3) - ** where x0 = n0->i; y0 = n0[1]; ... - ** Calculated by Mathematica ;-) - */ - return (m_p0[2]*m_p1[1]*m_p2[0] - m_p0[1]*m_p1[2]*m_p2[0] - m_p0[2]*m_p1[0]*m_p2[1] - + m_p0[0]*m_p1[2]*m_p2[1] + m_p0[1]*m_p1[0]*m_p2[2] - m_p0[0]*m_p1[1]*m_p2[2] - - m_p0[2]*m_p1[1]*m_p3[0] + m_p0[1]*m_p1[2]*m_p3[0] + m_p0[2]*m_p2[1]*m_p3[0] - - m_p1[2]*m_p2[1]*m_p3[0] - m_p0[1]*m_p2[2]*m_p3[0] + m_p1[1]*m_p2[2]*m_p3[0] - + m_p0[2]*m_p1[0]*m_p3[1] - m_p0[0]*m_p1[2]*m_p3[1] - m_p0[2]*m_p2[0]*m_p3[1] - + m_p1[2]*m_p2[0]*m_p3[1] + m_p0[0]*m_p2[2]*m_p3[1] - m_p1[0]*m_p2[2]*m_p3[1] - - m_p0[1]*m_p1[0]*m_p3[2] + m_p0[0]*m_p1[1]*m_p3[2] + m_p0[1]*m_p2[0]*m_p3[2] - - m_p1[1]*m_p2[0]*m_p3[2] - m_p0[0]*m_p2[1]*m_p3[2] + m_p1[0]*m_p2[1]*m_p3[2])/6.; - } - - - /** - * Compute Bounding Box. - * This method computes an axis aligned bounding - * box (AABB) that encloses the geometry. - * - * @param r The position of the model frame (i.e the coordinate frame the geometry lives in). - * @param R The orientation of the model frame (i.e the coordinate frame the geometry lives in). - * @param min_coord Upon return holds the minimum corner of the box. - * @param max_coord Upon return holds the maximum corner of the box. - * - */ - void compute_collision_aabb( - vector3_type const & r - , matrix3x3_type const & R - , vector3_type & min_coord - , vector3_type & max_coord - ) const - { - compute_tetrahedron_aabb( *this, min_coord, max_coord ); - } - - - }; - - } // namespace geometry - -} // namespace OpenTissue - -// OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron_slicer.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron_slicer.h deleted file mode 100644 index cd7930dc0..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron_slicer.h +++ /dev/null @@ -1,157 +0,0 @@ -#ifndef OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_SLICER_H -#define OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_SLICER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - - -namespace OpenTissue -{ - namespace geometry - { - - - template - class TetrahedronSlicer - { - public: - - typedef vector3_type_ vector3_type; - typedef typename vector3_type::value_type real_type; - - - vector3_type m_nodes[4]; ///< Nodes of tetrahedron - int m_edges[6][2]; ///< Edge topology of tetrahedron - ///< m_edges[i][0] index of the first node of the i'th edge - ///< m_edges[i][1] index of the second node of the i'th edge - - vector3_type m_intersections[4]; ///< Intersection points of slice and tetrahedron. - vector3_type m_triangle1[3]; ///< Vertices of first triangle in slice. - vector3_type m_triangle2[3]; ///< Vertices of second trinagle in slice. - - public: - - TetrahedronSlicer( - vector3_type const & p0 - , vector3_type const & p1 - , vector3_type const & p2 - , vector3_type const & p3 - ) - { - m_nodes[0] = p0; - m_nodes[1] = p1; - m_nodes[2] = p2; - m_nodes[3] = p3; - - // - // Node indices and edge labels: - // - // 3 - // + - // / \ - // / \ - // / . \ - // / \ - // / \ - // / . \ - // / \ - // / \ - // / . \ - // C F E - // / \ - // / . \ - // / \ - // / . \ - // / 2+ \ - // / . . \ - // / . B D. \ - // / . . \ - // +------------------A------------------+ - //0 1 - // - // - m_edges[ 0 ][ 0 ] = 0; // A - m_edges[ 0 ][ 1 ] = 1; - m_edges[ 1 ][ 0 ] = 0; // B - m_edges[ 1 ][ 1 ] = 2; - m_edges[ 2 ][ 0 ] = 0; // C - m_edges[ 2 ][ 1 ] = 3; - m_edges[ 3 ][ 0 ] = 1; // D - m_edges[ 3 ][ 1 ] = 2; - m_edges[ 4 ][ 0 ] = 1; // E - m_edges[ 4 ][ 1 ] = 3; - m_edges[ 5 ][ 0 ] = 2; // F - m_edges[ 5 ][ 1 ] = 3; - - }; - - protected: - - template - void compute_slice(plane_type const & plane) - { - //--- Loop over all edges and find those that cross the plane - int count = 0; - for(int i=0;i<6;++i) - { - vector3_type & a = m_nodes[m_edges[i][0]]; - vector3_type & b = m_nodes[m_edges[i][1]]; - real_type dst_a = plane.signed_distance(a); - real_type dst_b = plane.signed_distance(b); - if ( (dst_a*dst_b<0) || (dst_a==0 && dst_b>0) || (dst_b==0 && dst_a>0)) - { - //--- Compute coordinates of the plane intersections - vector3_type & a = m_nodes[m_edges[ i ][0]]; - vector3_type & b = m_nodes[m_edges[ i ][1]]; - m_intersections[count++] = plane.get_intersection(a,b); - } - } - assert(count==3 || count==4); //--no other possibilities? - - //--- Order plane intersections to a a CCW polygon (as seen from positive side of plane) - vector3_type & n = plane.n(); - vector3_type e10 = m_intersections[1] - m_intersections[0]; - vector3_type e21 = m_intersections[2] - m_intersections[1]; - if(n*(e10%e20)<0) - { - m_triangle1[0] = m_intersections[0]; - m_triangle1[1] = m_intersections[2]; - m_triangle1[2] = m_intersections[1]; - } - else - { - m_triangle1[0] = m_intersections[0]; - m_triangle1[1] = m_intersections[1]; - m_triangle1[2] = m_intersections[2]; - } - if ( count == 4 ) - { - for(int i=0;i<3;++i) - { - int next = (i+1)%3; - int prev = i; - vector3_type e = m_triangle1[next] - m_triangle1[prev]; - vector3_type h = m_intersections[4] - m_triangle1[prev]; - if(n*(h%e)>0) - { - m_triangle2[0] = m_triangle1[prev]; - m_triangle2[1] = m_intersections[4]; - m_triangle2[2] = m_triangle1[next]; - break; - } - } - } - }; - - }; - - } // namespace geometry -} // namespace OpenTissue - -//OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_SLICER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron_z_slicer.h b/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron_z_slicer.h deleted file mode 100644 index 3b9a07721..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/geometry/geometry_tetrahedron_z_slicer.h +++ /dev/null @@ -1,165 +0,0 @@ - #ifndef OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_Z_SLICER_H -#define OPENTISSUE_CORE_GEOMETRY_GEOMETRY_TETRAHEDRON_Z_SLICER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace geometry - { - /** - * Specialized Tetrahedron Slicer. - * Cut a tetrahedron with a specified z-plane and returns the - * sliced tetrahedron. - * - * This code was originally implemented by Andreas Bæentzen, IMM (jab@imm.dtu.dk). - * - */ - template - class ZTetrahedronSlicer - { - public: - - typedef vector3_type_ vector3_type; - typedef typename vector3_type::value_type real_type; - - protected: - - vector3_type m_p[4]; ///< Nodes of tetrahedron. - - public: - - ZTetrahedronSlicer( - vector3_type const & p0 - , vector3_type const & p1 - , vector3_type const & p2 - , vector3_type const & p3 - ) - { - m_p[0] = p0; - m_p[1] = p1; - m_p[2] = p2; - m_p[3] = p3; - - //--- Primitive bubble sort - ensures that tetrahedron vertices - //--- are sorted according to z value. - while(swap(0,1)||swap(1,2)||swap(2,3)); - }; - - protected: - - /** - * Swap the order of two nodes if their z-value allows it. - * - * @param i A node index. - * @param j A node index. - * - * @return true if swapped otherwise false. - */ - bool swap(int i,int j) - { - if(m_p[j](2)< m_p[i](2)) - { - vector3_type tmp = m_p[j]; - m_p[j] = m_p[i]; - m_p[i] = tmp; - return true; - } - return false; - }; - - /** - * Computes intersection point of edge going from node i towards node j - * - * @param z The z value, indicating the z-plane aginst which the edge is tested. - * @param i The node index of the starting node (got lowest z-value). - * @param j The node index of the ending node (got highest z-value). - * @param p Upon return this argument holds the intersection point. - */ - void intersect(real_type const & z, int i, int j, vector3_type & p) const - { - p = m_p[i]; - vector3_type dir = m_p[j] - m_p[i]; - real_type s = (z-m_p[i](2))/(m_p[j](2)-m_p[i](2)); - p += s * dir; - }; - - public: - - /** - * Compute Intersection Slice of Tetrahedron and Z-plane. - * - * @param z The z-plane to slice against. - * @param slice Upon return holds the intersection points of the sliced tetrahedron. - * - * @return The number of vertices in the sliced tetrahedron. - */ - unsigned int intersect(real_type const & z, vector3_type slice[4]) const - { - if( z < m_p[0](2) || z > m_p[3](2) ) - return 0; - if( z m_p[0](2)) - // { - // if(z < m_p[3](2)) - // { - // intersect(z,0,3,slice[cnt++]); - // if(z - -#include - - -namespace OpenTissue -{ - namespace geometry - { - /** - * VolumeShape Template Class. - * If you implement a new volumetric geometry then you should derive your new class from the VolumeShape class . - * - * @tparam math_types standard math types containing at least the real, vector3 and matrix3x3 types. - **/ - template - class VolumeShape - : public BaseShape< math_types > - { - public: - - virtual ~VolumeShape() {} - - public: - - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - - /** - * Get Center Position. - * - * @return The center point of the volume shape, in most cases this would be the mean point. - */ - virtual vector3_type center() const = 0; - - /** - * Get Volume. - * - * @return The actual volume of the shape. - */ - virtual real_type volume() const = 0; - - /** - * Get Area. - * - * @return The actual surface area of the volume. - */ - virtual real_type area() const = 0; - - /** - * Get Diameter. - * - * - * @return A measure of the diameter of the shape. Not all shapes have a well-defined - * diameter in such cases the measure would simply be a measure of the longst - * extent of the shape. - */ - virtual real_type diameter() const = 0; - - }; - - } // namespace geometry - -} // namespace OpenTissue - -//OPENTISSUE_CORE_GEOMETRY_GEOMETRY_VOLUME_SHAPE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_basic_types.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_basic_types.h deleted file mode 100644 index c6286de98..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_basic_types.h +++ /dev/null @@ -1,52 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_BASIC_TYPES_H -#define OPENTISSUE_CORE_MATH_MATH_BASIC_TYPES_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include -#include -#include -#include - -namespace OpenTissue -{ - namespace math - { - - // TODO add doxygen documentation explaining rationale behind this typebinder class. Why have we made it, and for what purpose? Also give example usages - template< typename real_type_ - , typename index_type_ - > - class BasicMathTypes - { - public: - - typedef real_type_ real_type; - typedef index_type_ index_type; - typedef Vector3 vector3_type; - typedef Quaternion quaternion_type; - typedef DualQuaternion dual_quaternion_type; - typedef Matrix3x3 matrix3x3_type; - typedef CoordSys coordsys_type; - - typedef Vector3 index_vector3_type; - typedef ValueTraits value_traits; - }; - - - // TODO add doxygen comments explaining what this type is useful for - typedef BasicMathTypes default_math_types; - - } // namespace math -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_BASIC_TYPES_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_compute_contiguous_angle_interval.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_compute_contiguous_angle_interval.h deleted file mode 100644 index 311f8c255..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_compute_contiguous_angle_interval.h +++ /dev/null @@ -1,139 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_COMPUTE_CONTIGUOUS_ANGLE_INTERVAL_H -#define OPENTISSUE_CORE_MATH_COMPUTE_CONTIGUOUS_ANGLE_INTERVAL_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -#include -#include -#include -#include - -namespace OpenTissue -{ - namespace math - { - - /** - * Compute Contiguous Angle Interval. - * This function tries to find a contiguous interval of angle values. As - * input it takes a sequence of angle values. From this sequence the - * function tries to compute the starting and ending angle (in terms - * of counter-clock-wise rotation order) of a contiguous interval. - * interval containing all the angles. - * - * One could interact with the function as follows - * - * std::vector angles; - * - * ... fill angles with values ... - * - * double min_val, max_val; - * compute_contiguous_angle_interval( angles.begin(), angles.end(), min_val, max_val ); - * - * The resulting minimum and maximum values yields the starting and ending points - * of the contiguous interval. The periodicity of rotation angles is used to adjust - * the end-points of the interval to always be positive values. - * - * The supplied angles can be given in any sort of interval as long as - * the width of the interval is no longer than 2 pi ( one full rotation). Typically - * one would supply values from either -pi..pi or 0..2pi intervals. - * - * @param begin An iterator to the first angle value - * @param end An iterator to one past the last angle value - * @param theta_min Upon return this value holds the starting value of the contiguous angle interval. - * @param theta_max Upon return this value holds the ending value of the contiguous angle interval. - */ - template - inline void compute_contiguous_angle_interval( - iterator_type const & begin - , iterator_type const & end - , typename iterator_type::value_type & theta_min - , typename iterator_type::value_type & theta_max ) - { - //using std::cos; - //using std::sin; - //using std::sqrt; - //using std::atan2; - - typedef typename iterator_type::value_type T; - typedef OpenTissue::math::ValueTraits value_traits; - - - T const two_pi = value_traits::pi()*value_traits::two(); - - // Determine the number of samples - size_t const N = std::distance( begin, end); - - // Make a copy of the samples and sort them in ascending order - std::vector storage; - storage.resize( N ); - std::copy( begin, end, storage.begin() ); - std::sort( storage.begin(), storage.end() ); - - // Find the two theta values with the largest gap inbetween. That - // is the largest angle difference as measured in a counter-clock-wise manner. - T max_delta_theta = value_traits::zero(); - size_t max_i = N; - - for(size_t i = 0u;i max_delta_theta) - { - max_i = i; - max_delta_theta = delta_theta; - theta_min = theta_j; - theta_max = theta_i; - } - } - - //// Compute the mean angle by converting angles to points on - //// the unit-circle and calculating the mean point. - //T mx = value_traits::zero(); - //T my = value_traits::zero(); - //for(iterator_type theta = begin; theta != end; ++ theta) - //{ - // T const c = cos( *theta ); - // T const s = sin( *theta ); - // mx += c; - // my += s; - //} - - //T norm = sqrt( mx*mx + my*my); - //assert( is_number(norm) || !"compute_contiguous_angle_interval(): NaN encountered"); - - //if(norm<= value_traits::zero()) - // throw std::logic_error("insufficient angle samples to determine a mean angle"); - - //mx /= norm; - //my /= norm; - - //assert( is_number(mx) || !"compute_contiguous_angle_interval(): NaN encountered"); - //assert( is_number(my) || !"compute_contiguous_angle_interval(): NaN encountered"); - - while(theta_min < value_traits::zero()) - theta_min += two_pi; - - while(theta_max < theta_min) - theta_max += two_pi; - - assert( theta_min <= theta_max || !"compute_contiguous_angle_interval(): invalid interval"); - } - - - } // namespace math -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_COMPUTE_CONTIGUOUS_ANGLE_INTERVAL_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_constants.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_constants.h deleted file mode 100644 index 59b1363aa..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_constants.h +++ /dev/null @@ -1,209 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_CONSTANTS_H -#define OPENTISSUE_CORE_MATH_MATH_CONSTANTS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -//#include -#include - - -namespace OpenTissue -{ - - namespace math - { - - // constant: 0 (zero) - namespace detail - { - - template - inline T zero(); - - template <> - inline float zero() { return 0.0f; } - - template <> - inline double zero() { return 0.0; } - - template <> - inline int zero() { return 0; } - - template <> - inline long unsigned int zero() { return 0; } - - template <> - inline unsigned int zero() { return 0u; } - - } // namespace detail - - - // constant: 1 (one) - namespace detail - { - - template - inline T one(); - - template <> - inline float one() { return 1.0f; } - - template <> - inline double one() { return 1.0; } - - template <> - inline int one() { return 1; } - - template <> - inline unsigned int one() { return 1u; } - - } // namespace detail - - - // constant: 2 (two) - namespace detail - { - - template - inline T two(); - - template <> - inline float two() { return 2.0f; } - - template <> - inline double two() { return 2.0; } - - template <> - inline int two() { return 2; } - - template <> - inline unsigned int two() { return 2u; } - - } // namespace detail - - - // constant: 3 (three) - namespace detail - { - - template - inline T three(); - - template <> - inline float three() { return 3.0f; } - - template <> - inline double three() { return 3.0; } - - template <> - inline int three() { return 3; } - - template <> - inline unsigned int three() { return 3u; } - - } // namespace detail - - - // constant: 4 (four) - namespace detail - { - - template - inline T four(); - - template <> - inline float four() { return 4.0f; } - - template <> - inline double four() { return 4.0; } - - template <> - inline int four() { return 4; } - - template <> - inline unsigned int four() { return 4u; } - - } // namespace detail - - - // constant: 8 (eight) - namespace detail - { - - template - inline T eight(); - - template <> - inline float eight() { return 8.0f; } - - template <> - inline double eight() { return 8.0; } - - template <> - inline int eight() { return 8; } - - template <> - inline unsigned int eight() { return 8u; } - - } // namespace detail - - - // constant: ½ (half) - namespace detail - { - - template - inline T half(); - - template <> - inline float half() { return 0.5f; } - - template <> - inline double half() { return 0.5; } - - } // namespace detail - - - // constant: pi and fractions of pi - namespace detail - { - - template - inline T pi() { return (T)(M_PI); } - - template - inline T pi_half() { return (T)(M_PI_2); } - - template - inline T pi_quarter() { return (T)(M_PI_4); } - - } // namespace detail - - - // constant: specials - namespace detail - { - - - // one degree in radians - template - inline T degree() { return (T)(0.017453292519943295769236907684886); } - - // one radian in degrees - template - inline T radian() { return (T)(57.295779513082320876798154814105); } - - } - - } // namespace math - -} // namespace OpenTissue - -// #define OPENTISSUE_CORE_MATH_MATH_CONSTANTS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_coordsys.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_coordsys.h deleted file mode 100644 index ce71c34d1..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_coordsys.h +++ /dev/null @@ -1,320 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_COORDSYS_H -#define OPENTISSUE_CORE_MATH_MATH_COORDSYS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include -#include - -#include - -namespace OpenTissue -{ - - namespace math - { - - /** - * A Coordinate System. - * - * Remeber, this represents a transform that brings you from a local frame - * into a global frame, that is: - * - * BF -> WCS - */ - template< - typename value_type_ - //, typename value_traits_ = ValueTraits - > - class CoordSys - { - protected: - - typedef typename OpenTissue::math::ValueTraits value_traits_ ; // TODO value_traits_ should be parameterized as a class template parameter. - - public: - - typedef value_traits_ value_traits; ///< Convenience typedef to make value traits accessible for all template functions using Vector3 types. - typedef value_type_ value_type; ///< Typedef is required for compliance with many other libraries and data containers! - - typedef Vector3 vector3_type; - typedef Quaternion quaternion_type; - typedef Matrix3x3 matrix3x3_type; - typedef Quaternion rotation_type; ///< typedef to make interface for different coordsystypes the same - - protected: - - vector3_type m_T; ///< The Position. - quaternion_type m_Q; ///< The orientation in Quaternion form. - - public: - - vector3_type & T() { return m_T; } - vector3_type const & T() const { return m_T; } - quaternion_type & Q() { return m_Q; } - quaternion_type const & Q() const { return m_Q; } - - public: - - CoordSys() - : m_T(value_traits::zero(),value_traits::zero(),value_traits::zero()) - , m_Q(value_traits::one(),value_traits::zero(),value_traits::zero(),value_traits::zero()) - {} - - explicit CoordSys(vector3_type const & T_val, quaternion_type const & Q_val) - { - m_T = T_val; - m_Q = unit(Q_val); - } - - explicit CoordSys(vector3_type const & T_val, matrix3x3_type const & R_val) - { - m_T = T_val; - m_Q = R_val; - } - - CoordSys & operator=(CoordSys const & C) - { - m_T = C.m_T; - m_Q = C.m_Q; - return *this; - } - - public: - - // TODO: Comparing floats with == or != is not safe NOTE T might not be a float type it could be anything? This suggest that we need some kind of metaprogramming technique to deal with this problem? - bool operator==(CoordSys const & C) const { return m_T == C.m_T && m_Q==C.m_Q; } - - public: - - void identity() - { - m_T.clear(); - m_Q.identity(); - } - - /** - * This method assumes that the point is in this coordinate system. - * In other words this method maps local points into non local - * points: - * - * BF -> WCS - * - * Let p be the point and let f designate the function of this - * method then we have - * - * [p]_WCS = f(p) - * - */ - void xform_point(vector3_type & p) const { p = m_Q.rotate(p) + m_T; } - - /** - * This method assumes that the vector is in this - * coordinate system. That is it maps the vector - * from BF into WCS. - */ - void xform_vector(vector3_type & v) const { v = m_Q.rotate(v); } - - /** - * Transform Matrix. - * - * @param O A reference to a rotation matrix, which should be transformed. - */ - void xform_matrix(matrix3x3_type & O) const - { - O = matrix3x3_type(m_Q) * O; - } - - /** - * Transform Coordinate System. - * This method transforms the specified coordinate - * system by this coordinate transform. - * - * That is: - * - * Tnew = Tx Rx Told - * Rnew = Rx Rold - * - * @param X The transform by which the current - * transform should be changed with.. - */ - CoordSys operator*(CoordSys const & X1) const - { - return CoordSys( m_Q.rotate(X1.T()) + m_T , unit( prod( m_Q , X1.Q()) ) ); - } - - public: - - bool is_equal(CoordSys const & C, value_type const & accuracy) const - { - return m_T.is_equal(C.m_T,accuracy) && m_Q.is_equal(C.m_Q,accuracy); - } - - }; // class CoordSys - - - - /** - * Coordinate Transformation Product. - * This function should be used to concatenate coordinate transformations. - * In terms of homogeneous coordinates L and R corresponds to the matrices. - * - * L = | R_l T_l | - * | 0 1 | - * - * R = | R_r T_r | - * | 0 1 | - * - * This function computes the equivalent of the product - * - * X = L R - * - * = | R_l T_l | | R_r T_r | - * | 0 1 | | 0 1 | - * - * = | R_l R_r R_l T_r + T_l | - * | 0 1 | - * - * @param L The left coordinate transformation - * @param R The right coordinate transformation - * - * @return The coordinate transformation corresponding to the product L*R. - */ - template - inline CoordSys prod(CoordSys const & L, CoordSys const & R) - { - return CoordSys( L.Q().rotate( R.T() ) + L.T() , unit( prod( L.Q() , R.Q()) ) ); - } - - /** - * Inverse Transform. - * - * If we have - * - * BF -> WCS - * - * Then we want to find - * - * WCS -> BF - * - */ - template - inline CoordSys inverse(CoordSys const & X) - { - //--- - //--- p' = R p + T - //--- - //--- => - //--- - //--- p = R^{-1} p' + R^{-1}(-T) - //--- - return CoordSys( conj(X.Q()).rotate(-X.T()) , conj(X.Q()) ); - } - - /** - * Model Update Transform. - * This method computes the necessary transform needed in - * order to transform coordinates from one local frame - * into another local frame. This utility is useful when - * one wants to do model updates instead of world updates. - * - * In mathematical terms we have two transforms: - * - * C1 : H -> G - * C2 : F -> G - * - * And we want to find - * - * C3 : H -> F - * - * This transform is computed and assigned to this coordinate - * system. - */ - template - inline CoordSys model_update(CoordSys const & A, CoordSys const & B) - { - return model_update(A.T(),A.Q(),B.T(),B.Q()); - } - - /** - * Model Update Transform. - * This method computes the necessary transform needed in - * order to transform coordinates from one local frame - * into another local frame. This utility is useful when - * one wants to do model updates instead of world updates. - * - * In mathematical terms we have two transforms: - * - * C1 : H -> G - * C2 : F -> G - * - * And we want to find - * - * C3 : H -> F - * - * This transform is computed and assigned to this coordinate - * system. - * - * Very important: Note that this method finds the transform A -> B. - */ - template - inline CoordSys model_update(Vector3 const & TA, Quaternion const & QA, Vector3 const & TB, Quaternion const & QB) - { - //--- - //--- p' = RA p + TA (*1) from A->WCS - //--- - //--- p = RB^T (p' - TB) (*2) from WCS-B - //--- - //--- Insert (*1) into (*2) A -> B - //--- - //--- p = RB^T ( RA p + TA - TB) - //--- = RB^T RA p + RB^T (TA - TB) - //--- So - //--- R = RB^T RA - //--- T = RB^T (TA - TB) - //--- - Quaternion q; - if(QA==QB) - { - q.identity(); - } - else - { - q = unit( prod( conj(QB), QA) ); - } - return CoordSys( conj(QB).rotate(TA - TB), q); - } - - template - inline std::ostream & operator<< (std::ostream & o, CoordSys const & C) - { - o << "[" << C.T() << "," << C.Q() << "]"; - return o; - } - - template - inline std::istream & operator>>(std::istream & i, CoordSys & C) - { - char dummy; - i >> dummy; - i >> C.T(); - i >> dummy; - i >> C.Q(); - i >> dummy; - return i; - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_COORDSYS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_covariance.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_covariance.h deleted file mode 100644 index 45a4dd2bd..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_covariance.h +++ /dev/null @@ -1,84 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_COVARIANCE_H -#define OPENTISSUE_CORE_MATH_MATH_COVARIANCE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - - namespace math - { - - /** - * - * @param mean Resulting mean point. - * @param C Resulting covariance matrix. - */ - template< typename vector3_iterator, typename vector3_type, typename matrix3x3_type> - inline void - covariance( - vector3_iterator begin, vector3_iterator end - , vector3_type & mean, matrix3x3_type & C - ) - { - typedef typename vector3_type::value_traits value_traits; - - unsigned int N = 0; - - mean.clear(); - - for(vector3_iterator v = begin;v!=end;++v,++N) - mean += (*v); - mean /= N; - - C.clear(); - for(vector3_iterator v = begin;v!=end;++v,++N) - { - C(0,0) += ((*v)(0) - mean(0))*((*v)(0) - mean(0)); - C(1,1) += ((*v)(1) - mean(1))*((*v)(1) - mean(1)); - C(2,2) += ((*v)(2) - mean(2))*((*v)(2) - mean(2)); - C(0,1) += ((*v)(0) - mean(0))*((*v)(1) - mean(1)); - C(0,2) += ((*v)(0) - mean(0))*((*v)(2) - mean(2)); - C(1,2) += ((*v)(1) - mean(1))*((*v)(2) - mean(2)); - } - C(1,0) = C(0,1); - C(2,0) = C(0,2); - C(2,1) = C(1,2); - C /= N; - } - - /** - * - * - * @param mean Resulting mean point. - * @param C Resulting covariance matrix. - */ - template - inline void - covariance_union( - vector3_type const & mean1, matrix3x3_type const & C1 - , vector3_type const & mean2, matrix3x3_type const & C2 - , vector3_type & mean, matrix3x3_type & C - ) - { - typedef typename vector3_type::value_traits value_traits; - - mean = (mean1 + mean2)/value_traits::two(); - matrix3x3_type KK = outer_prod(mean,mean); - matrix3x3_type NN = outer_prod(mean1,mean1); - matrix3x3_type MM = outer_prod(mean2,mean2); - C = ((C1 + NN + C2 + MM)/value_traits::two() - KK) ; - } - - } // namespace math - -} // namespace OpenTissue - -// OPENTISSUE_CORE_MATH_MATH_COVARIANCE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_dual_quaternion.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_dual_quaternion.h deleted file mode 100644 index ca811117b..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_dual_quaternion.h +++ /dev/null @@ -1,198 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_DUAL_QUATERNION_H -#define OPENTISSUE_CORE_MATH_MATH_DUAL_QUATERNION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2010 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include - -#include - -// 2010-07-16 Kenny : code review, where is the unit tests? - -namespace OpenTissue -{ - - namespace math - { - - // 2010-07-16 Kenny: code review, why do you keep uncommented code around? - // 2010-07-16 perb: I have keept this as I thought this was the direction OpenTissue was going, - // considering that it is in both the vector3 and quaternion class - // I thought it was a preparation to get rid of the next TODO... - template < - typename value_type_ - //, typename value_traits_ = ValueTraits - > - class DualQuaternion - { - protected: - - // 2010-07-16 Kenny: code review, the TODO comment seems unneeded? - // 2010-07-16 perb - typedef typename OpenTissue::math::ValueTraits value_traits_ ; // TODO value_traits_ should be parameterized as a class template parameter. - - public: - - typedef value_traits_ value_traits; ///< Convience typedef to make value traits accesible for all template functions using Vector3 types. - typedef value_type_ value_type; ///< Typedef is required for compliance with many other libraries and data containers! - typedef size_t index_type; - typedef Vector3 vector3_type; - typedef Quaternion quaternion_type; - - protected: - - quaternion_type m_real; ///< The real part of this dual quaternion. This represents the rotation when used as a rigid motion. - quaternion_type m_dual; ///< The dual part of this dual quaternion. This represents the displacement when used as a rigid motion. - - public: - - quaternion_type & r() { return m_real; } - quaternion_type const & r() const { return m_real; } - - quaternion_type & d() { return m_dual; } - quaternion_type const & d() const { return m_dual; } - - public: - - DualQuaternion() - : m_real( quaternion_type( value_traits::one(), value_traits::zero(), value_traits::zero(), value_traits::zero() ) ) - , m_dual( quaternion_type( value_traits::zero(), value_traits::zero(), value_traits::zero(), value_traits::zero() ) ) - {} - - /** - * This constructs a dual quaternion representing the transformation of the given vector - * - * @param v Vector describing a translation - * - * @return A dual quaternion describing the translation given - */ - DualQuaternion( vector3_type const & v ) - : m_real( quaternion_type( value_traits::one(), value_traits::zero(), value_traits::zero(), value_traits::zero() ) ) - , m_dual( quaternion_type( value_traits::one(), v[0] / value_traits::two(), v[1] / value_traits::two(), v[2] / value_traits::two() ) ) - {} - - /** - * This constructs a unit dual quaternion describing a rotation and a translation - * - * @param rotation A unit quaternion describing a rotation - * @param translation A vector describing a translation - * - * @return A unit dual quaternion describing the rotation and translation given - */ - DualQuaternion( quaternion_type const & rotation, vector3_type const & translation ) - : m_real( rotation ) - , m_dual( prod( quaternion_type( value_traits::zero(), translation[0], translation[1], translation[2] ), rotation) / value_traits::two() ) - {} - - DualQuaternion( DualQuaternion< value_type > const & d ) { *this = d; } - - DualQuaternion( quaternion_type const & s_val, quaternion_type const & d_val ) - : m_real( s_val ) - , m_dual( d_val ) - {} - - ~DualQuaternion() - {} - - DualQuaternion & operator=( DualQuaternion const & cpy ) - { - m_real = cpy.m_real; - m_dual = cpy.m_dual; - - return *this; - } - - DualQuaternion & operator+= ( DualQuaternion const & qd ) - { - // 2010-07-16 Kenny: code review, safe guard for self assignment? if (this!=&qd)??? - // 2010-07-16 perb: I am not sure why this would be a problem. - // 2010-07-16 kenny: Argh, sorry, I read the code too fast, I read it as an assignment operator. - m_real += qd.r(); - m_dual += qd.d(); - - return *this; - } - - public: - - friend std::ostream & operator<< ( std::ostream & o, DualQuaternion< value_type > const & d ) - { - o << "[" << d.r() << "," << d.d() << "]"; - - return o; - } - - friend std::istream & operator>>( std::istream & i, DualQuaternion< value_type > & d ) - { - char dummy; - - i >> dummy; - i >> d.r(); - i >> dummy; - i >> d.d(); - i >> dummy; - - return i; - } - }; // class DualQuaternion - - - ////////////////////////////////////////////////////////////////////////// - /// Declaration of DualQuaternion non-member functions - ////////////////////////////////////////////////////////////////////////// - - template < typename T, typename T2 > - inline DualQuaternion operator*( DualQuaternion const& dq, T2 const& v ) { return DualQuaternion< T >( dq.r() * v, dq.d() * v ); } - - template < typename T2, typename T > - inline DualQuaternion operator*( T2 const& v, DualQuaternion const& dq ) { return DualQuaternion< T >( dq.r() * v, dq.d() * v ); } - - template < typename T, typename T2 > - inline DualQuaternion operator/( DualQuaternion const& dq, T2 const& v ) { return DualQuaternion< T >( dq.r() / v, dq.d() / v ); } - - template < typename T > - inline DualQuaternion< T > operator-( DualQuaternion< T > q ) { return DualQuaternion< T >( -q.r(), -q.d() ); } - - - /** - * Dual conjugate. This is the conjugate that considers the dual quaternion as a dual number with quaternion elements. - * - * @warning There are two different types. The quaternion conjugate and the dual conjugate. - */ - template< typename T > - inline DualQuaternion< T > conj_dual( DualQuaternion< T > const & dq ) - { - return DualQuaternion< T >( dq.r(), -dq.d() ); - } - - /** - * Quaternion conjugate. This is the conjugate that considers the dual quaternion as a quaternion with dual number elements. - * - * @warning There are two different types. The quaternion conjugate and the dual conjugate. - */ - template< typename T > - inline DualQuaternion< T > conj_quaternion( DualQuaternion< T > const & dq ) - { - return DualQuaternion< T >( conj( dq.r() ), conj( dq.d() ) ); - } - - template< typename T > - inline DualQuaternion< T > prod( DualQuaternion< T > const & q, DualQuaternion< T > const & p ) - { - return DualQuaternion< T >( prod( q.r(), p.r() ), prod( q.r(), p.d() ) + prod( q.d(), p.r() ) ); - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_DUAL_QUATERNION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_eigen_system_decomposition.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_eigen_system_decomposition.h deleted file mode 100644 index 70bdf4108..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_eigen_system_decomposition.h +++ /dev/null @@ -1,173 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_EIGEN_SYSTEM_DECOMPOSITION_H -#define OPENTISSUE_CORE_MATH_MATH_EIGEN_SYSTEM_DECOMPOSITION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include // for sqrt() and fabs - -namespace OpenTissue -{ - - namespace math - { - /** - * Eigen System Decomposition. - * - * @param A Matrix to find eigenvectors and eigenvalues of. - * @param V Upon return the columns of this matrix contains the - * eigenvectors. IMPORTANT: V may not form a right-handed - * coordinate system (ie. V might not be a rotation matrix). If - * a rotation matrix is needed one should compute the determinant - * of V and flip the sign of one of V's columns in case the - * determinant is negative. That is: - * - * if(det(V)<0) { V(0,0) =- V(0,0); V(1,0) =- V(1,0); V(2,0) =- V(2,0); } - * - * - * @param diag Upon return this vector contains the - * eigenvalues, such that entry 0 correpsonds to - * eigenvector 0 and so on. - */ - template - inline void eigen(matrix3x3_type const & A,matrix3x3_type & V,vector3_type & diag) - { - typedef typename vector3_type::value_type real_type; - typedef typename vector3_type::value_traits value_traits; - - using std::sqrt; - using std::fabs; - - vector3_type sub_diag; - - sub_diag.clear(); - diag.clear(); - - V = A; - - real_type const & fM00 = V(0,0); - real_type fM01 = V(0,1); - real_type fM02 = V(0,2); - real_type const & fM11 = V(1,1); - real_type const & fM12 = V(1,2); - real_type const & fM22 = V(2,2); - - diag(0) = fM00; - sub_diag(2) = value_traits::zero(); - if ( fM02 != value_traits::zero() ) - { - real_type fLength = sqrt(fM01*fM01+fM02*fM02); - real_type fInvLength = (value_traits::one())/fLength; - fM01 *= fInvLength; - fM02 *= fInvLength; - real_type fQ = (value_traits::two())*fM01*fM12+fM02*(fM22-fM11); - diag(1) = fM11+fM02*fQ; - diag(2) = fM22-fM02*fQ; - sub_diag(0) = fLength; - sub_diag(1) = fM12-fM01*fQ; - V(0,0) = value_traits::one(); - V(0,1) = value_traits::zero(); - V(0,2) = value_traits::zero(); - V(1,0) = value_traits::zero(); - V(1,1) = fM01; - V(1,2) = fM02; - V(2,0) = value_traits::zero(); - V(2,1) = fM02; - V(2,2) = -fM01; - } - else - { - diag(1) = fM11; - diag(2) = fM22; - sub_diag(0) = fM01; - sub_diag(1) = fM12; - V(0,0) = value_traits::one(); - V(0,1) = value_traits::zero(); - V(0,2) = value_traits::zero(); - V(1,0) = value_traits::zero(); - V(1,1) = value_traits::one(); - V(1,2) = value_traits::zero(); - V(2,0) = value_traits::zero(); - V(2,1) = value_traits::zero(); - V(2,2) = value_traits::one(); - } - - const int max_iterations = 32; - const int dim = 3; - for (int i0 = 0; i0 < dim; ++i0) - { - int i1; - for (i1 = 0; i1 < max_iterations; ++i1) - { - int i2; - for (i2 = i0; i2 <= dim-2; ++i2) - { - real_type fTmp = fabs(diag(i2)) + fabs(diag(i2+1)); - if ( fabs(sub_diag(i2)) + fTmp == fTmp ) - break; - } - if ( i2 == i0 ) - break; - real_type fG = (diag(i0+1) - diag(i0))/(value_traits::two()* sub_diag(i0)); - real_type fR = sqrt(fG*fG+value_traits::one()); - if ( fG < value_traits::zero() ) - fG = diag(i2)-diag(i0)+sub_diag(i0)/(fG-fR); - else - fG = diag(i2)-diag(i0)+sub_diag(i0)/(fG+fR); - - real_type fSin = value_traits::one(); - real_type fCos = value_traits::one(); - real_type fP = value_traits::zero(); - - for (int i3 = i2-1; i3 >= i0; --i3) - { - real_type fF = fSin*sub_diag(i3); - real_type fB = fCos*sub_diag(i3); - if ( fabs(fF) >= fabs(fG) ) - { - fCos = fG/fF; - fR = sqrt(fCos*fCos+value_traits::one()); - sub_diag(i3+1) = fF*fR; - fSin = value_traits::one()/fR; - fCos *= fSin; - } - else - { - fSin = fF/fG; - fR = sqrt(fSin*fSin+value_traits::one()); - sub_diag(i3+1) = fG*fR; - fCos = value_traits::one()/fR; - fSin *= fCos; - } - fG = diag(i3+1)-fP; - fR = (diag(i3)-fG)*fSin+value_traits::two()*fB*fCos; - fP = fSin*fR; - diag(i3+1) = fG+fP; - fG = fCos*fR-fB; - for (int i4 = 0; i4 < dim; ++i4) - { - fF = V(i4,i3+1); - V(i4,i3+1) = fSin*V(i4,i3)+fCos*fF; - V(i4,i3) = fCos*V(i4,i3)-fSin*fF; - } - } - diag(i0) -= fP; - sub_diag(i0) = fG; - sub_diag(i2) = value_traits::zero(); - } - if ( i1 == max_iterations ) - break; - } - } - - } // namespace math - -} // namespace OpenTissue - -// OPENTISSUE_CORE_MATH_MATH_EIGEN_SYSTEM_DECOMPOSITION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_functions.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_functions.h deleted file mode 100644 index 04f19736a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_functions.h +++ /dev/null @@ -1,158 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_FUNCTIONS_H -#define OPENTISSUE_CORE_MATH_MATH_FUNCTIONS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - - - -namespace OpenTissue -{ - - /** - * The following functions are defined below: - * - clamp (and the variations: clamp_min, clamp_max, clamp_zero_one) - * - fac (faculty) - * - sgn (sign function) - * - sinc - */ - namespace math - { - - /** - * clamp function to clamp a value to be in the interval (min_value; max_value). - * - * @param value The value to be clamped. - * @param min_value The minimum allowed value. - * @param max_value The maximum allowed value (ohhh, really?). - * @return The clamped value. If value already is in (min_value; max_value) no clamping is performed. - */ - template - inline T clamp(T const & value, T const & min_value, T const & max_value) - { - assert(min_value <= max_value || !"max_value cannot be less than min_value"); - using std::min; - using std::max; - - return T(min(max_value, max(min_value, value))); - } - - - /** - * clamp function to clamp a value never to be less than min_value. - * - * @param value The value to be clamped. - * @param min_value The minimum allowed value. - * @return The clamped value if value is less than min_value, otherwise the original value is returned. - */ - template - inline T clamp_min(T const & value, T const & min_value) - { - using std::max; - return clamp(value, min_value, max(value, min_value)); - } - - - /** - * clamp function to clamp a value never to be greater than max_value. - * - * @param value The value to be clamped. - * @param max_value The maximum allowed value. - * @return The clamped value if value is greater than max_value, otherwise the original value is returned. - */ - template - inline T clamp_max(T const & value, T const & max_value) - { - using std::min; - return clamp(value, min(value, max_value), max_value); - } - - - /** - * clamp function to easily clamp a value between 0 and 1. - * note: this function is mostly usable for T = some real type. - * - * @param value The value to be clamped. - * @return The clamped value. If value already is in (0; 1) no clamping is performed. - */ - template - inline T clamp_zero_one(T const & value) - { - return clamp(value, detail::zero(), detail::one()); - } - - - template - inline T fac(unsigned long n) - { - // TODO what about implicit type conversions? This could have been done more elegangtly using partial specialization - unsigned long val = 1; - for(; n > 0; val *= n--); - return T(val); - } - - - template - inline T sgn(T const & val) - { - static T const zero = detail::zero(); - static T const one = detail::one(); - return val > zero ? one : val < zero ? -one : zero; - } - - - /** - * Compute Sinc Function. - * The implementation of this method was greatly inspired by the - * one in Open Dynamics Engine v. 0.039 - * - * This method returns sin(x)/x. this has a singularity at 0 so special - * handling is needed for small arguments. - * - * @param x - * @return The value of sin(x)/x - */ - template - inline T sinc(T & x) - { - using std::fabs; - using std::sin; - - static T const tiny = (T)(1.0e-4); - static T const factor = (T)(0.166666666666666666667); - - //--- if |x| < 1e-4 then use a taylor series expansion. this two term expansion - //--- is actually accurate to one LS bit within this range if double precision - //--- is being used - so don't worry! - return (fabs(x) < tiny) ? (detail::one() - x*x*factor) : (sin(x)/x); - } - - - // use this to convert radians into degrees - template - inline T to_degrees(T const & radians) - { - return radians*detail::radian(); - } - - - // use this to convert degrees into radians - template - inline T to_radians(T const & degrees) - { - return degrees*detail::degree(); - } - - } // namespace math - -} // namespace OpenTissue - -// #define OPENTISSUE_CORE_MATH_MATH_FUNCTIONS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_invert4x4.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_invert4x4.h deleted file mode 100644 index 0e738399f..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_invert4x4.h +++ /dev/null @@ -1,65 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_INVERT4x4_H -#define OPENTISSUE_CORE_MATH_MATH_INVERT4x4_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - - -namespace OpenTissue -{ - - namespace math - { - - template - inline void invert4x4(real_type M[4][4]) - { - real_type a00 = M[0][0]; real_type a01 = M[0][1]; real_type a02 = M[0][2]; real_type a03 = M[0][3]; - real_type a10 = M[1][0]; real_type a11 = M[1][1]; real_type a12 = M[1][2]; real_type a13 = M[1][3]; - real_type a20 = M[2][0]; real_type a21 = M[2][1]; real_type a22 = M[2][2]; real_type a23 = M[2][3]; - real_type a30 = M[3][0]; real_type a31 = M[3][1]; real_type a32 = M[3][2]; real_type a33 = M[3][3]; - - M[0][0] = a11*a22*a33 - a11*a23*a32 - a21*a12*a33 + a21*a13*a32 + a31*a12*a23 - a31*a13*a22; - M[0][1] = - a01*a22*a33 + a01*a23*a32 + a21*a02*a33 - a21*a03*a32 - a31*a02*a23 + a31*a03*a22; - M[0][2] = a01*a12*a33 - a01*a13*a32 - a11*a02*a33 + a11*a03*a32 + a31*a02*a13 - a31*a03*a12; - M[0][3] = - a01*a12*a23 + a01*a13*a22 + a11*a02*a23 - a11*a03*a22 - a21*a02*a13 + a21*a03*a12; - M[1][0] = - a10*a22*a33 + a10*a23*a32 + a20*a12*a33 - a20*a13*a32 - a30*a12*a23 + a30*a13*a22; - M[1][1] = a00*a22*a33 - a00*a23*a32 - a20*a02*a33 + a20*a03*a32 + a30*a02*a23 - a30*a03*a22; - M[1][2] = - a00*a12*a33 + a00*a13*a32 + a10*a02*a33 - a10*a03*a32 - a30*a02*a13 + a30*a03*a12; - M[1][3] = a00*a12*a23 - a00*a13*a22 - a10*a02*a23 + a10*a03*a22 + a20*a02*a13 - a20*a03*a12; - M[2][0] = a10*a21*a33 - a10*a23*a31 - a20*a11*a33 + a20*a13*a31 + a30*a11*a23 - a30*a13*a21; - M[2][1] = - a00*a21*a33 + a00*a23*a31 + a20*a01*a33 - a20*a03*a31 - a30*a01*a23 + a30*a03*a21; - M[2][2] = a00*a11*a33 - a00*a13*a31 - a10*a01*a33 + a10*a03*a31 + a30*a01*a13 - a30*a03*a11; - M[2][3] = - a00*a11*a23 + a00*a13*a21 + a10*a01*a23 - a10*a03*a21 - a20*a01*a13 + a20*a03*a11; - M[3][0] = - a10*a21*a32 + a10*a22*a31 + a20*a11*a32 - a20*a12*a31 - a30*a11*a22 + a30*a12*a21; - M[3][1] = a00*a21*a32 - a00*a22*a31 - a20*a01*a32 + a20*a02*a31 + a30*a01*a22 - a30*a02*a21; - M[3][2] = - a00*a11*a32 + a00*a12*a31 + a10*a01*a32 - a10*a02*a31 - a30*a01*a12 + a30*a02*a11; - M[3][3] = a00*a11*a22 - a00*a12*a21 - a10*a01*a22 + a10*a02*a21 + a20*a01*a12 - a20*a02*a11; - //real_type D = - // ( - // a00*a11*a22*a33 - a00*a11*a23*a32 - a00*a21*a12*a33 + a00*a21*a13*a32 + a00*a31*a12*a23 - a00*a31*a13*a22 - // - a10*a01*a22*a33 + a10*a01*a23*a32 + a10*a21*a02*a33 - a10*a21*a03*a32 - a10*a31*a02*a23 + a10*a31*a03*a22 - // + a20*a01*a12*a33 - a20*a01*a13*a32 - a20*a11*a02*a33 + a20*a11*a03*a32 + a20*a31*a02*a13 - a20*a31*a03*a12 - // - a30*a01*a12*a23 + a30*a01*a13*a22 + a30*a11*a02*a23 - a30*a11*a03*a22 - a30*a21*a02*a13 + a30*a21*a03*a12 - // ); - real_type D = a00*M[0][0] + a10*M[0][1] + a20*M[0][2] + a30*M[0][3]; - if(D) - { - M[0][0] /=D; M[0][1] /=D; M[0][2] /=D; M[0][3] /=D; - M[1][0] /=D; M[1][1] /=D; M[1][2] /=D; M[1][3] /=D; - M[2][0] /=D; M[2][1] /=D; M[2][2] /=D; M[2][3] /=D; - M[3][0] /=D; M[3][1] /=D; M[3][2] /=D; M[3][3] /=D; - } - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_INVERT4x4_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_is_finite.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_is_finite.h deleted file mode 100644 index b245f6f9c..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_is_finite.h +++ /dev/null @@ -1,32 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_IS_FINITE_H -#define OPENTISSUE_CORE_MATH_IS_FINITE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#ifdef WIN32 -#include -#endif - -namespace OpenTissue -{ - namespace math - { - -#ifdef WIN32 -#define is_finite(val) (_finite(val)!=0) ///< Is finite number test -#else -#define is_finite(val) (finite(val)!=0) ///< Is finite number test -#endif - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_IS_FINITE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_is_number.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_is_number.h deleted file mode 100644 index 40e315803..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_is_number.h +++ /dev/null @@ -1,38 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_IS_NUMBER_H -#define OPENTISSUE_CORE_MATH_IS_NUMBER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#ifdef WIN32 -#include -#else -#include -#endif - -namespace OpenTissue -{ - namespace math - { - -#ifdef WIN32 -#define is_number(val) (_isnan(val)==0) ///< Is a number test -#else -#if (__APPLE__) -#define is_number(val) (std::isnan(val)==0) ///< Is a number test -#else -#define is_number(val) (isnan(val)==0) ///< Is a number test -#endif -#endif - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_IS_NUMBER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_matrix3x3.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_matrix3x3.h deleted file mode 100644 index aa811024d..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_matrix3x3.h +++ /dev/null @@ -1,788 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_MATRIX3X3_H -#define OPENTISSUE_CORE_MATH_MATH_MATRIX3X3_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - -#include -#include -#include - - -namespace OpenTissue -{ - - namespace math - { - - template class Quaternion; - - template< - typename value_type_ - //, typename value_traits_ = ValueTraits - > - class Matrix3x3 - { - protected: - - typedef typename math::ValueTraits value_traits_ ; // TODO value_traits_ should be parameterized as a class template parameter. - - public: - - typedef value_traits_ value_traits; ///< Convience typedef to make value traits accesible for all template functions using Vector3 types. - typedef value_type_ value_type; ///< Typedef is required for compliance with many other libraries and data containers! - typedef Vector3 vector3_type; // TODO should Vector3 type be template parameterized? - typedef Quaternion quaternion_type; - typedef size_t index_type; // TODO should the index type be template parameterized? - - protected: - - // TODO 2007-02-19 KE: Refactor this stuff into an array - vector3_type m_row0; ///< The 1st row of the matrix - vector3_type m_row1; ///< The 2nd row of the matrix - vector3_type m_row2; ///< The 3rd row of the matrix - - public: - - Matrix3x3() - : m_row0(value_traits::zero() ,value_traits::zero() ,value_traits::zero() ) - , m_row1(value_traits::zero() ,value_traits::zero() ,value_traits::zero() ) - , m_row2(value_traits::zero() ,value_traits::zero() ,value_traits::zero() ) - {} - - ~Matrix3x3(){} - - explicit Matrix3x3( - value_type const & m00 , value_type const & m01 , value_type const & m02 - , value_type const & m10 , value_type const & m11 , value_type const & m12 - , value_type const & m20 , value_type const & m21 , value_type const & m22 - ) - : m_row0(m00,m01,m02) - , m_row1(m10,m11,m12) - , m_row2(m20,m21,m22) - {} - - - explicit Matrix3x3(vector3_type const & row0, vector3_type const & row1, vector3_type const & row2) - : m_row0(row0) - , m_row1(row1) - , m_row2(row2) - {} - - explicit Matrix3x3(quaternion_type const & q) { *this = q; } - - Matrix3x3(Matrix3x3 const & M) - : m_row0(M.m_row0) - , m_row1(M.m_row1) - , m_row2(M.m_row2) - {} - - public: - - value_type & operator()(index_type i, index_type j) - { - assert( ( i>=0 && i<3 ) || !"Matrix3x3::(i,j) i must be in range [0..2]"); - assert( ( j>=0 && j<3 ) || !"Matrix3x3::(i,j) j must be in range [0..2]"); - return (*(&m_row0+i))(j); - } - - value_type const & operator()(index_type i, index_type j) const - { - assert( ( i>=0 && i<3 ) || !"Matrix3x3::(i,j) i must be in range [0..2]"); - assert( ( j>=0 && j<3 ) || !"Matrix3x3::(i,j) j must be in range [0..2]"); - return (*(&m_row0+i))(j); - } - - vector3_type & operator[](index_type i) - { - assert( ( i>=0 && i<3 ) || !"Matrix3x3::(i,j) i must be in range [0..2]"); - return *(&m_row0+i); - } - - vector3_type const & operator[](index_type i) const - { - assert( ( i>=0 && i<3 ) || !"Matrix3x3::(i,j) i must be in range [0..2]"); - return *(&m_row0+i); - } - - Matrix3x3 & operator=( Matrix3x3 const & cpy ) - { - m_row0=cpy.m_row0; - m_row1=cpy.m_row1; - m_row2=cpy.m_row2; - return *this; - } - - // TODO: Comparing floats with == or != is not safe NOTE T might not be a float type it could be anything? This suggest that we need some kinf of metaprogramming technique to deal with ths problem? - bool operator==(Matrix3x3 const & cmp ) const - { - return (m_row0==cmp.m_row0) && (m_row1==cmp.m_row1) && (m_row2==cmp.m_row2); - } - - bool operator!=( Matrix3x3 const & cmp ) const - { - return !(*this==cmp); - } - - Matrix3x3 operator+ ( Matrix3x3 const & m ) const { return Matrix3x3( m_row0+m.m_row0, m_row1+m.m_row1, m_row2+m.m_row2); } - Matrix3x3 operator- ( Matrix3x3 const & m ) const { return Matrix3x3( m_row0-m.m_row0, m_row1-m.m_row1, m_row2-m.m_row2); } - Matrix3x3 & operator+= ( Matrix3x3 const & m ) { m_row0+=m.m_row0; m_row1+=m.m_row1; m_row2+=m.m_row2; return *this; } - Matrix3x3 & operator-= ( Matrix3x3 const & m ) { m_row0-=m.m_row0; m_row1-=m.m_row1; m_row2-=m.m_row2; return *this; } - Matrix3x3 & operator*= ( value_type const & s ) {m_row0*=s;m_row1*=s;m_row2*=s;return *this;} - - Matrix3x3 & operator/= ( value_type const & s ) - { - assert(s || !"Matrix3x3/=(): division by zero"); - m_row0/=s; - m_row1/=s; - m_row2/=s; - return *this; - } - - vector3_type operator*(vector3_type const &v) const { return vector3_type(m_row0*v, m_row1*v, m_row2*v); } - Matrix3x3 operator-() const { return Matrix3x3(-m_row0,-m_row1,-m_row2); } - - size_t size1() const { return 3u; } - size_t size2() const { return 3u; } - - /** - * Assigns this quaternion to a matrix. - * This method performs a conversion of a quaternion that represents a rotation into the correponding rotationmatrix. - * - * @param q A reference to a quaternion. This is the quaternion that represents a rotation. - */ - Matrix3x3 & operator=(quaternion_type const & q) - { - m_row0(0) = value_traits::one() - value_traits::two() * ( (q.v()(1)*q.v()(1)) + (q.v()(2)*q.v()(2))); - m_row1(1) = value_traits::one() - value_traits::two() * ( (q.v()(0)*q.v()(0)) + (q.v()(2)*q.v()(2))); - m_row2(2) = value_traits::one() - value_traits::two() * ( (q.v()(1)*q.v()(1)) + (q.v()(0)*q.v()(0))); - m_row1(0) = value_traits::two() * ( (q.v()(0)*q.v()(1)) + (q.s()*q.v()(2))); - m_row0(1) = value_traits::two() * ( (q.v()(0)*q.v()(1)) - (q.s()*q.v()(2))); - m_row2(0) = value_traits::two() * (-(q.s()*q.v()(1)) + (q.v()(0)*q.v()(2))); - m_row0(2) = value_traits::two() * ( (q.s()*q.v()(1)) + (q.v()(0)*q.v()(2))); - m_row2(1) = value_traits::two() * ( (q.v()(2)*q.v()(1)) + (q.s()*q.v()(0))); - m_row1(2) = value_traits::two() * ( (q.v()(2)*q.v()(1)) - (q.s()*q.v()(0))); - return *this; - } - - void clear() - { - m_row0.clear(); - m_row1.clear(); - m_row2.clear(); - } - - public: - - friend Matrix3x3 fabs(Matrix3x3 const & A) - { - using std::fabs; - - return Matrix3x3( - fabs(A(0,0)), fabs(A(0,1)), fabs(A(0,2)), - fabs(A(1,0)), fabs(A(1,1)), fabs(A(1,2)), - fabs(A(2,0)), fabs(A(2,1)), fabs(A(2,2)) - ); - } - - public: - - vector3_type column(index_type i) const - { - assert((i>=0 && i<3) || !"Matrix3x3::column(): index must be in range [0..2]"); - - return vector3_type(m_row0(i), m_row1(i), m_row2(i)); - } - - void set_column(index_type i, vector3_type const & column) - { - assert((i>=0 && i<3) || !"Matrix3x3::set_column(): index must be in range [0..2]"); - - m_row0(i) = column(0); - m_row1(i) = column(1); - m_row2(i) = column(2); - } - - vector3_type & row(index_type i) { return (*this)[i]; } - vector3_type const & row(index_type i) const { return (*this)[i]; } - - }; // class Matrix3x3 - - - template - inline Matrix3x3 operator*( Matrix3x3 const & m, T const &s ) - { - return Matrix3x3(m.row(0)*s, m.row(1)*s, m.row(2)*s); - } - - template - inline Matrix3x3 operator*( T const & s, Matrix3x3 const & m ) - { - return Matrix3x3(m.row(0)*s, m.row(1)*s, m.row(2)*s); - } - - template - inline Matrix3x3 operator/( Matrix3x3 const & m, T const & s ) - { - return Matrix3x3(m.row(0)/s, m.row(1)/s, m.row(2)/s); - } - - template - inline Matrix3x3 operator/( T const & s, Matrix3x3 const & m ) - { - return Matrix3x3(m.row(0)/s, m.row(1)/s, m.row(2)/s); - } - - template - inline Matrix3x3 operator*(Matrix3x3 const & A,Matrix3x3 const & B) - { - typedef typename Matrix3x3::value_traits value_traits; - Matrix3x3 C; - - for (int c=0; c<3; ++c) - for (int r=0; r<3; ++r){ - C(r,c) = value_traits::zero(); - for(int i=0; i<3; ++i){ - C(r,c) += A(r,i) * B(i,c); - } - } - return C; - } - - /** - * Creates a rotation matrix. - * This method returns a rotation matrix around the x-axe. It - * assumes that post-multiplication by colum vectors is used. - * - * @param radians The rotation angle in radians. - */ - template - inline Matrix3x3 Rx(T const & radians) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::cos; - using std::sin; - - T cosinus = (T)( cos(radians) ); - T sinus = (T)( sin(radians) ); - - return Matrix3x3( - value_traits::one(), value_traits::zero(), value_traits::zero(), - value_traits::zero(), cosinus, -sinus, - value_traits::zero(), sinus, cosinus - ); - } - - /** - * Creates a rotation matrix. - * This method returns a rotation matrix around the y-axe. It - * assumes that post-multiplication by colum vectors is used. - * - * @param radians The rotation angle in radians. - */ - template - inline Matrix3x3 Ry(T const & radians) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::cos; - using std::sin; - - T cosinus = (T)( cos(radians) ); - T sinus = (T)( sin(radians) ); - return Matrix3x3( - cosinus, value_traits::zero(), sinus, - value_traits::zero(), value_traits::one(), value_traits::zero(), - -sinus, value_traits::zero(), cosinus - ); - } - - /** - * Creates a rotation matrix. - * This method returns a rotation matrix around the z-axe. It assumes that post-multiplication by colum vectors is used. - * - * @param radians The rotation angle in radians. - */ - template - inline Matrix3x3 Rz(T const & radians) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::cos; - using std::sin; - - T cosinus = (T)( cos(radians) ); - T sinus = (T)( sin(radians) ); - - return Matrix3x3( - cosinus, -sinus, value_traits::zero(), - sinus, cosinus, value_traits::zero(), - value_traits::zero(), value_traits::zero(), value_traits::one() - ); - } - - /** - * Creates a rotation matrix. - * This method returns a general rotation matrix around a specified axe. It assumes that post-multiplication by colum vectors is used. - * - * @param radians The rotation angle in radians. - * @param axe A vector. This is the rotation axe. - */ - template - inline Matrix3x3 Ru(T const & radians, Vector3 const & axis) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::cos; - using std::sin; - - T cosinus = (T)( cos(radians) ); - T sinus = (T)( sin(radians) ); - Vector3 u = unit(axis); - - //Foley p.227 (5.76) - return Matrix3x3( - u(0)*u(0) + cosinus*(value_traits::one() - u(0)*u(0)), u(0)*u(1)*(value_traits::one()-cosinus) - sinus*u(2), u(0)*u(2)*(value_traits::one()-cosinus) + sinus*u(1), - u(0)*u(1)*(value_traits::one()-cosinus) + sinus*u(2), u(1)*u(1) + cosinus*(value_traits::one() - u(1)*u(1)), u(1)*u(2)*(value_traits::one()-cosinus) - sinus*u(0), - u(0)*u(2)*(value_traits::one()-cosinus) - sinus*u(1), u(1)*u(2)*(value_traits::one()-cosinus) + sinus*u(0), u(2)*u(2) + cosinus*(value_traits::one() - u(2)*u(2)) - ); - } - - /** - * Direction of Flight (DoF) - * - * @param k The desired direction of flight. - */ - template - inline Matrix3x3 z_dof(Vector3 const & k) - { - Vector3 i,j; - orthonormal_vectors(i,j,unit(k)); - return Matrix3x3( - i(0) , j(0), k(0) - , i(1) , j(1), k(1) - , i(2) , j(2), k(2) - ); - } - - template - inline bool is_orthonormal(Matrix3x3 const & M,T const & threshold) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::fabs; - - assert(threshold>=value_traits::zero() || !"is_orthonormal(): threshold must be non-negative"); - - T dot01 = M.m_row0*M.m_row1; - T dot02 = M.m_row0*M.m_row2; - T dot12 = M.m_row1*M.m_row2; - if(fabs(dot01)>threshold) return false; - if(fabs(dot02)>threshold) return false; - if(fabs(dot12)>threshold) return false; - T dot00 = M.m_row0*M.m_row0; - T dot11 = M.m_row1*M.m_row1; - T dot22 = M.m_row2*M.m_row2; - if((dot00-value_traits::one())>threshold) return false; - if((dot11-value_traits::one())>threshold) return false; - if((dot22-value_traits::one())>threshold) return false; - return true; - } - - template - inline bool is_orthonormal(Matrix3x3 const & M) - { - typedef typename Matrix3x3::value_traits value_traits; - - return is_orthonormal(M, value_traits::zero()); - } - - template - inline bool is_zero(Matrix3x3 M, T const & threshold) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::fabs; - - assert(threshold>=value_traits::zero() || !"is_zero(): threshold must be non-negative"); - - if(fabs(M(0,0))>threshold) return false; - if(fabs(M(0,1))>threshold) return false; - if(fabs(M(0,2))>threshold) return false; - if(fabs(M(1,0))>threshold) return false; - if(fabs(M(1,1))>threshold) return false; - if(fabs(M(1,2))>threshold) return false; - if(fabs(M(2,0))>threshold) return false; - if(fabs(M(2,1))>threshold) return false; - if(fabs(M(2,2))>threshold) return false; - return true; - } - - template - inline bool is_zero(Matrix3x3 const & M) - { - typedef typename Matrix3x3::value_traits value_traits; - - return is_zero(M, value_traits::zero()); - } - - template - inline bool is_symmetric(Matrix3x3 M, T const & threshold) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::fabs; - - assert(threshold>=value_traits::zero() || !"is_symmetric(): threshold must be non-negative"); - - if(fabs(M(0,1)-M(1,0))>threshold) return false; - if(fabs(M(0,2)-M(2,0))>threshold) return false; - if(fabs(M(1,2)-M(2,1))>threshold) return false; - return true; - } - - template - inline bool is_symmetric(Matrix3x3 const & M) - { - typedef typename Matrix3x3::value_traits value_traits; - - return is_symmetric(M, value_traits::zero()); - } - - template - inline bool is_diagonal(Matrix3x3 M, T const & threshold) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::fabs; - - assert(threshold>=value_traits::zero() || !"is_diagonal(): threshold must be non-negative"); - - if(fabs(M(0,1))>threshold) return false; - if(fabs(M(0,2))>threshold) return false; - if(fabs(M(1,0))>threshold) return false; - if(fabs(M(1,2))>threshold) return false; - if(fabs(M(2,0))>threshold) return false; - if(fabs(M(2,1))>threshold) return false; - return true; - } - - template - inline bool is_diagonal(Matrix3x3 const & M) - { - typedef typename Matrix3x3::value_traits value_traits; - - return is_diagonal(M, value_traits::zero()); - } - - template - inline bool is_identity(Matrix3x3 M, T const & threshold) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::fabs; - - assert(threshold>=value_traits::zero() || !"is_identity(): threshold must be non-negative"); - - if(fabs(M(0,0)-value_traits::one())>threshold) return false; - if(fabs(M(0,1))>threshold) return false; - if(fabs(M(0,2))>threshold) return false; - if(fabs(M(1,0))>threshold) return false; - if(fabs(M(1,1)-value_traits::one())>threshold) return false; - if(fabs(M(1,2))>threshold) return false; - if(fabs(M(2,0))>threshold) return false; - if(fabs(M(2,1))>threshold) return false; - if(fabs(M(2,2)-value_traits::one())>threshold) return false; - return true; - } - - template - inline bool is_identity(Matrix3x3 const & M) - { - typedef typename Matrix3x3::value_traits value_traits; - - return is_identity(M, value_traits::zero()); - } - - template - inline Matrix3x3 outer_prod( Vector3 const & v1, Vector3 const & v2 ) - { - return Matrix3x3( - ( v1( 0 ) * v2( 0 ) ), ( v1( 0 ) * v2( 1 ) ), ( v1( 0 ) * v2( 2 ) ), - ( v1( 1 ) * v2( 0 ) ), ( v1( 1 ) * v2( 1 ) ), ( v1( 1 ) * v2( 2 ) ), - ( v1( 2 ) * v2( 0 ) ), ( v1( 2 ) * v2( 1 ) ), ( v1( 2 ) * v2( 2 ) ) - ); - } - - template - inline Matrix3x3 ortonormalize(Matrix3x3 const & A) - { - typedef typename Matrix3x3::vector3_type vector3_type; - - vector3_type row0(A(0,0),A(0,1),A(0,2)); - vector3_type row1(A(1,0),A(1,1),A(1,2)); - vector3_type row2(A(2,0),A(2,1),A(2,2)); - - T const l0 = length(row0); - if(l0) row0 /= l0; - - row1 -= row0 * dot(row0 , row1); - T const l1 = length(row1); - if(l1) row1 /= l1; - - row2 = cross( row0 , row1); - - return Matrix3x3( - row0(0), row0(1), row0(2), - row1(0), row1(1), row1(2), - row2(0), row2(1), row2(2) - ); - } - - template - inline Matrix3x3 trans(Matrix3x3 const & M) - { - return Matrix3x3( - M(0,0), M(1,0), M(2,0), - M(0,1), M(1,1), M(2,1), - M(0,2), M(1,2), M(2,2) - ); - } - - - template - inline Matrix3x3 diag(T const & d0,T const & d1,T const & d2 ) - { - typedef typename Matrix3x3::value_traits value_traits; - - return Matrix3x3( - d0, value_traits::zero(), value_traits::zero(), - value_traits::zero(), d1, value_traits::zero(), - value_traits::zero(), value_traits::zero(), d2 - ); - } - - template - inline Matrix3x3 diag(Vector3 const & d) { return diag( d(0), d(1), d(2)); } - - template - inline Matrix3x3 diag(T const & d ) { return diag(d,d,d); } - - template - inline Matrix3x3 inverse(Matrix3x3 const & A) - { - typedef typename Matrix3x3::value_traits value_traits; - - //From messer p.283 we know - // - // -1 1 - // A = ----- adj A - // det A - // - // i+j - // ij-cofactor of A = -1 det A - // ij - // - // i,j entry of the adjoint. - // i+j - // adjoint A = ji-cofactor = A = -1 det A - // ij ji - // - // As it can be seen the only numerical error - // in these calculations is from the resolution - // of the scalars. So it is a very accurate method. - // - Matrix3x3 adj; - adj(0,0) = A(1,1)*A(2,2) - A(2,1)*A(1,2); - adj(1,1) = A(0,0)*A(2,2) - A(2,0)*A(0,2); - adj(2,2) = A(0,0)*A(1,1) - A(1,0)*A(0,1); - adj(0,1) = A(1,0)*A(2,2) - A(2,0)*A(1,2); - adj(0,2) = A(1,0)*A(2,1) - A(2,0)*A(1,1); - adj(1,0) = A(0,1)*A(2,2) - A(2,1)*A(0,2); - adj(1,2) = A(0,0)*A(2,1) - A(2,0)*A(0,1); - adj(2,0) = A(0,1)*A(1,2) - A(1,1)*A(0,2); - adj(2,1) = A(0,0)*A(1,2) - A(1,0)*A(0,2); - T det = A(0,0)*adj(0,0) - A(0,1)*adj(0,1) + A(0,2)*adj(0,2); - if(det) - { - adj(0,1) = -adj(0,1); - adj(1,0) = -adj(1,0); - adj(1,2) = -adj(1,2); - adj(2,1) = -adj(2,1); - return trans(adj)/det; - } - - return diag(value_traits::one()); - } - - template - inline T max_value(Matrix3x3 const & A) - { - using std::max; - - return max(A(0,0), max( A(0,1), max( A(0,2), max ( A(1,0), max ( A(1,1), max ( A(1,2), max (A(2,0), max ( A(2,1) , A(2,2) ) ) ) ) ) ) ) ); - } - - template - inline T min_value(Matrix3x3 const & A) - { - using std::min; - - return min(A(0,0), min( A(0,1), min( A(0,2), min ( A(1,0), min ( A(1,1), min ( A(1,2), min (A(2,0), min ( A(2,1) , A(2,2) ) ) ) ) ) ) ) ); - } - - template - inline T det(Matrix3x3 const & A) - { - return A(0,0)*(A(1,1)*A(2,2) - A(2,1)*A(1,2)) - A(0,1)*(A(1,0)*A(2,2) - A(2,0)*A(1,2)) + A(0,2)*(A(1,0)*A(2,1) - A(2,0)*A(1,1)); - } - - template - inline T trace(Matrix3x3 const & A) - { - return (A(0,0) + A(1,1) + A(2,2)); - } - - template - inline T norm_1(Matrix3x3 const & A) - { - using std::fabs; - using std::max; - - T r0 = fabs(A(0,0)) + fabs(A(0,1)) + fabs(A(0,2)); - T r1 = fabs(A(1,0)) + fabs(A(1,1)) + fabs(A(1,2)); - T r2 = fabs(A(2,0)) + fabs(A(2,1)) + fabs(A(2,2)); - - return max ( r0, max( r1, r2 ) ); - } - - template - inline T norm_2(Matrix3x3 const & A) - { - using std::fabs; - using std::max; - using std::sqrt; - - Matrix3x3 V; - typename Matrix3x3::vector3_type d; - math::eigen(A,V,d); - - T lambda = max( fabs(d(0)), max( fabs(d(1)) , fabs(d(2)) )); - return sqrt( lambda ); - } - - template - inline T norm_inf(Matrix3x3 const & A) - { - using std::fabs; - using std::max; - - T c0 = fabs(A(0,0)) + fabs(A(1,0)) + fabs(A(2,0)); - T c1 = fabs(A(0,1)) + fabs(A(1,1)) + fabs(A(2,1)); - T c2 = fabs(A(0,2)) + fabs(A(1,2)) + fabs(A(2,2)); - return max ( c0, max( c1, c2 ) ); - } - - template - inline Matrix3x3 truncate(Matrix3x3 const & A,T const & epsilon) - { - typedef typename Matrix3x3::value_traits value_traits; - - using std::fabs; - - assert(epsilon>value_traits::zero() || !"truncate(Matrix3x3,epsilon): epsilon must be positive"); - - return Matrix3x3( - fabs(A(0,0)) - inline Matrix3x3 star(Vector3 const & v) - { - typedef typename Matrix3x3::value_traits value_traits; - - //--- Changes a cross-product into a matrix multiplication. - //--- Rewrites the component of a vector3_type cross-product as a matrix. - //--- a x b = a*b = ba* - return Matrix3x3( - value_traits::zero(), -v(2), v(1), - v(2), value_traits::zero(), -v(0), - -v(1), v(0), value_traits::zero() - ); - } - - template - inline std::ostream & operator<< (std::ostream & o,Matrix3x3 const & A) - { - o << "[" << A(0,0) - << "," << A(0,1) - << "," << A(0,2) - << ";" << A(1,0) - << "," << A(1,1) - << "," << A(1,2) - << ";" << A(2,0) - << "," << A(2,1) - << "," << A(2,2) - << "]"; - return o; - } - - template - inline std::istream & operator>>(std::istream & i,Matrix3x3 & A) - { - char dummy; - i >> dummy; - i >> A(0,0); - i >> dummy; - i >> A(0,1); - i >> dummy; - i >> A(0,2); - i >> dummy; - i >> A(1,0); - i >> dummy; - i >> A(1,1); - i >> dummy; - i >> A(1,2); - i >> dummy; - i >> A(2,0); - i >> dummy; - i >> A(2,1); - i >> dummy; - i >> A(2,2); - i >> dummy; - return i; - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_MATRIX3X3_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_polar_decomposition.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_polar_decomposition.h deleted file mode 100644 index 4cec1a7cd..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_polar_decomposition.h +++ /dev/null @@ -1,149 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_POLAR_DECOMPOSITION_H -#define OPENTISSUE_CORE_MATH_MATH_POLAR_DECOMPOSITION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - -#include - - -namespace OpenTissue -{ - - namespace math - { - - // TODO: [micky] don't introduce yet another sub namespace to avoid name clashing. - // Rename the function 'eigen' instead!! - namespace polar_decomposition - { - /* - * Polar Decomposition of matrix A (as described by Etzmuss et. al in ``A Fast Finite Solution for Cloth Modelling'') - * - * A = R S - * - * Where R is a special orthogonal matrix (R*R^T = I and det(R)=1) - * - * S^2 = A^T A - * - * let d be vector of eigenvalues and let v_0,v_1, and v_2 be corresponding eigenvectors of (A^T A), then - * - * S = sqrt(d_0) v_0 * v_0^T + ... + sqrt(d_2) v_2 * v_2^T - * - * Now compute - * - * R = A * S^-1 - * - * - * @return If the decompostion is succesfull then the return value is true otherwise it is false. - */ - template - inline bool eigen(matrix3x3_type const & A,matrix3x3_type & R,matrix3x3_type & S) - { - using std::sqrt; - - // A = U D V^T // A is square so: thin SVD = SVD - // A = (U V^T) (V D V^T) - // = R S - // - //Notice S is symmetric R should be orthonormal? - // - // proof of - // S = sqrt( A^T A ) - // - // start by - // - // S * S = A^T A - // V D V^T V D V^T = V D U^T U D V^T - // V D D V^T = V D D V^T - //Assume - //A = R S - //pre-multiply and use assumption then - // A^T A = A^T R S - // A^T A = S^T S = S S - // last step used S is symmetric - typedef typename matrix3x3_type::vector3_type vector3_type; - typedef typename matrix3x3_type::value_traits value_traits; - matrix3x3_type V; - vector3_type d; - matrix3x3_type S2 = trans(A)*A; - eigen(S2,V,d); - - //--- Test if all eigenvalues are positive - if( d(0) <= value_traits::zero() || d(1) <= value_traits::zero() || d(2) <= value_traits::zero() ) - return false; - - vector3_type v0 = vector3_type( V(0,0), V(1,0), V(2,0) ); - vector3_type v1 = vector3_type( V(0,1), V(1,1), V(2,1) ); - vector3_type v2 = vector3_type( V(0,2), V(1,2), V(2,2) ); - S = outer_prod(v0,v0)* sqrt(d(0)) + outer_prod(v1,v1)* sqrt(d(1)) + outer_prod(v2,v2)* sqrt(d(2)); - R = A * inverse(S); - return true; - } - - /** - * This method is rather bad, it is iterative and there is no way of telling how good the solution is. thus we recommend the eigen method for polar decomposition. - * - * Polar Decomposition as described by Shoemake and Duff in ``Matrix Animation and Polar Decomposition'' - * - * A = R S - * - * Where R is a special orthogonal matrix (R*R^T = I and det(R)=1) - * - * Set R_0 = A - * Do - * R_{i+1} = 1/2( R_i + R^{-T}_i ) - * Until R_{i+1}-R_i = 0 - * - * - * @return If a solution was found within the specified threshold value then the return value is true otherwise it is false. - */ - template - inline bool newton(matrix3x3_type const & A, matrix3x3_type & R,unsigned int max_iterations, typename matrix3x3_type::value_type const & threshold) - { - typedef typename matrix3x3_type::value_traits value_traits; - typedef typename matrix3x3_type::value_type real_type; - - assert(max_iterations>0 || !"polar_decompostion::newton() max_iterations must be positive"); - assert(threshold>value_traits::zero() || !"polar_decomposition::newton(): theshold must be positive"); - - matrix3x3_type Q[2]; - int cur = 0, next = 1; - Q[cur] = A; - - bool within_threshold = false; - - for(unsigned int iteration=0;iteration< max_iterations;++iteration) - { - Q[next] = ( Q[cur] + trans(inverse(Q[cur])) )*.5; - real_type test = max_value ( Q[next] - Q[cur] ); - if( test < threshold ) - { - within_threshold = true; - break; - } - cur = (cur + 1)%2; - next = (next + 1)%2; - } - R = Q[next]; - return within_threshold; - } - - }// namespace polar_decomposition - - }// namespace math - -}// namespace OpenTissue - -// OPENTISSUE_CORE_MATH_MATH_POLAR_DECOMPOSITION_H -#endif - diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_power2.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_power2.h deleted file mode 100644 index 533a80cce..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_power2.h +++ /dev/null @@ -1,83 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_POWER2_H -#define OPENTISSUE_CORE_MATH_MATH_POWER2_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - - namespace math - { - - /** - * This method test whether there exist some positive integer, n, such that - * - * 2^n == val - * - * In which case it returns true otherwise it returns false. - */ - template< class T> - inline bool is_power2( T val ) - { - T next = 1u; - for ( unsigned int i = 0u; i < 32u; ++i ) - { - if ( val == next ) - return true; - next = next << 1u; - } - return false; - } - - /** - * This function finds the smallest positive integer, n, such that - * - * val <= 2^n - * - * and returns the value 2^n. - */ - template - inline T upper_power2( T val ) - { - T next = 1u; - for ( unsigned int i = 0u; i < 32u; ++i ) - { - if ( next >= val ) - return next; - next = next << 1u; - } - return 0u; - } - - /** - * This function finds the largest positive integer, n, such that - * - * 2^n <= val - * - * and returns the value 2^n. - */ - template - inline T lower_power2( T val ) - { - T next = 1u << 31u; - for ( unsigned int i = 0u; i < 32u; ++i ) - { - if ( next <= val ) - return next; - next = next >> 1u; - } - return 0u; - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_POWER2_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_precision.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_precision.h deleted file mode 100644 index 5fc3cfab9..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_precision.h +++ /dev/null @@ -1,42 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_PRECISION_H -#define OPENTISSUE_CORE_MATH_MATH_PRECISION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include // for std::numeric_limits::epsilon() - - -namespace OpenTissue -{ - - namespace math - { - template - inline T machine_precision() - { - return std::numeric_limits::epsilon(); - } - - template - inline T working_precision() - { - return std::numeric_limits::epsilon()*10; - } - - template - inline T working_precision(unsigned int scale_factor) - { - return std::numeric_limits::epsilon()*scale_factor; - } - - } -} - -//OPENTISSUE_CORE_MATH_MATH_PRECISION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_prime_numbers.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_prime_numbers.h deleted file mode 100644 index 4b975d89a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_prime_numbers.h +++ /dev/null @@ -1,209 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_PRIME_NUMBERS_H -#define OPENTISSUE_CORE_MATH_MATH_PRIME_NUMBERS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include //--- for floor and sqrt - - -namespace OpenTissue -{ - - namespace math - { - - - namespace detail - { - - /** - * Used exclusively by the Miller-Rabin algorithm. It - * is essential the same as modular exponentiation a - * raised to n-1 modulo n. - * - * This "version" is specialized to test for notrivial - * square roots of 1. - */ - inline bool withness(int a,int n) - { - int ndec = n-1;int d = 1; int k = ndec; - if(k!=0) - { - int c=0; - while((k&0x80000000)==0) - k<<=1;c++; - while(c<32) - { - int x =d; - d=(d*d)%n; - if((d==1)&&(x!=1)&&(x!=ndec)) - return true;//--- Notrival square root of 1 was discovered. - if((k&0x80000000)!=0) - d=(d*a)%n; - k<<=1;c++; - } - } - if(d!=1) - return true; - return false; - } - - }//namespace detail - - - /** - * Prime Test. - * This method tests if the specified integer is a prime. - * - * Do Always find a correct solution, but is - * very slow for large numbers. - * - * Runs in time 2^(beta/2) where beta is the - * number of bits of n. - * - * @param n The number to test. - * @return If n was prime then the return value is - * true otherwise it is false. - */ - inline bool trial_division(int n) - { - using std::sqrt; - using std::floor; - - double sqrN = sqrt(static_cast(n)); - int j = static_cast( floor(sqrN) ); - for(int i=2;i<=j;++i) - { - if((n%i)==0) - return false; - } - return true; - } - - /** - * Modular Exponentiation. - * Computes a raised to the power of b modular n - */ - inline int modular_exponentiation(int a,int b,int n) - { - int d = 1; - while(b!=0) - { - if((b&1)!=0) - d=(d*a)%n; - a = (a*a)%n; - b>>=1; - } - return d; - } - - /** - * Prime Test. - * This method tests if the specified integer is a prime. - * - * Extremely fast, does not allways find - * a correct solution. However it fails - * rarely and it only makes error of one - * type. - * - * Some base-2 pseudo primes are 341, 561,645 and 1105. - * - * @param n The number to test. - * @return If n was prime then the return value is - * true otherwise it is false. - */ - inline bool pseudo_prime(int n) - { - if((n==1)||(n==2))//--- trivial cases - return true; - if(modular_exponentiation(2,n-1,n)!=1) - return false;//--- definitely not a prime, i.e. composite - return true;//--- possible prime or a base-2 pseudoprime - } - - - /** - * Closest Prime Search. - * This method tries to find the closest - * prime number to n. - * - * @param n The seed number from where the - * search should be done from. - * @return The closest prime number to n. - */ - inline int prime_search(int n) - { - int l = n; - if((l%2)==0) - l--; - for(;l>1;l=l-2) - { - // if(trial_division(l)) - // if(pseudo_prime(l)) - if(miller_rabin(l,4)) - break; - } - int o = n; - if((o%2)==0) - o++; - int max_val = detail::highest(); - for(;o - -#include -#include -#include -#include - -#include -#include - - -namespace OpenTissue -{ - - namespace math - { - - template< - typename value_type_ - //, typename value_traits_ = ValueTraits - > - class Quaternion - { - protected: - - typedef typename OpenTissue::math::ValueTraits value_traits_ ; // TODO value_traits_ should be parameterized as a class template parameter. - - public: - - typedef value_traits_ value_traits; ///< Convenience typedef to make value traits accessible for all template functions using Vector3 types. - typedef value_type_ value_type; ///< Typedef is required for compliance with many other libraries and data containers! - typedef Vector3 vector3_type; // TODO should Vector3 type be template parameterized? - typedef Matrix3x3 matrix3x3_type; - typedef size_t index_type; // TODO should the index type be template parameterized? - - protected: - - value_type m_s; ///< The real part. - vector3_type m_v; ///< The R3 part or imaginary part. - - public: - - value_type & s() { return m_s; } - value_type const & s() const { return m_s; } - - vector3_type & v() { return m_v; } - vector3_type const & v() const { return m_v; } - - public: - - Quaternion() - : m_s(value_traits::one()) - , m_v(value_traits::zero(),value_traits::zero(),value_traits::zero()) - {} - - ~Quaternion(){} - - Quaternion(Quaternion const & q) { *this = q; } - - explicit Quaternion(matrix3x3_type const & M){ *this = M; } - - explicit Quaternion(value_type const & s_val, value_type const & x, value_type const & y, value_type const & z) - : m_s(s_val) - , m_v(x,y,z) - { } - - explicit Quaternion(value_type const & s_val, vector3_type const & v_val) - : m_s(s_val) - , m_v(v_val) - { } - - Quaternion & operator=(Quaternion const & cpy) - { - m_s = cpy.m_s; - m_v = cpy.m_v; - return *this; - } - - /** - * Assignment operator. - * This method is a little special. Quaternions can be used to represent rotations, so can matrices. - * This method transforms a rotation matrix into a Quaternion and then it assigns it to this Quaternion. - * In short this method converts matrices into quaternions. - * - * @param M A reference to a matrix. This matrix should be a rotation matrix. That is an orthogonal matrix. - */ - Quaternion & operator=(matrix3x3_type const & M) - { - using std::sqrt; - - value_type const & M00 = M(0,0); - value_type const & M01 = M(0,1); - value_type const & M02 = M(0,2); - value_type const & M10 = M(1,0); - value_type const & M11 = M(1,1); - value_type const & M12 = M(1,2); - value_type const & M20 = M(2,0); - value_type const & M21 = M(2,1); - value_type const & M22 = M(2,2); - - value_type tr = M00 + M11 + M22; - value_type r; - - value_type const half = value_traits::one()/value_traits::two(); - - if(tr>=value_traits::zero()) - { - r = sqrt(tr + value_traits::one()); - m_s = half*r; - r = half/r; - m_v[0] = (M21 - M12) * r; - m_v[1] = (M02 - M20) * r; - m_v[2] = (M10 - M01) * r; - } - else - { - int i = 0; - if(M11>M00) - i = 1; - if(M22>M(i,i)) - i = 2; - switch(i) - { - case 0: - r = sqrt((M00 - (M11+M22)) + value_traits::one()); - m_v[0] = half*r; - r = half/r; - m_v[1] = (M01 + M10) * r; - m_v[2] = (M20 + M02) * r; - m_s = (M21 - M12) * r; - break; - case 1: - r = sqrt((M11 - (M22+M00)) + value_traits::one()); - m_v[1] = half*r; - r = half/r; - m_v[2] = (M12 + M21)*r; - m_v[0] = (M01 + M10)*r; - m_s = (M02 - M20)*r; - break; - case 2: - r = sqrt((M22 - (M00+M11)) + value_traits::one()); - m_v[2] = half*r; - r = half/r; - m_v[0] = (M20 + M02) * r; - m_v[1] = (M12 + M21) * r; - m_s = (M10 - M01) * r; - break; - }; - } - return *this; - } - - public: - - // TODO: Comparing floats with == or != is not safe NOTE value_type might not be a float type it could be anything? This suggest that we need some kind of metaprogramming technique to deal with this problem? - bool operator==(Quaternion const & cmp) const { return m_s==cmp.m_s && m_v==cmp.m_v; } - bool operator!=(Quaternion const & cmp) const { return !(*this==cmp); } - - public: - - Quaternion & operator+= (Quaternion const & q ) - { - m_s += q.m_s; - m_v += q.m_v; - return *this; - } - - Quaternion & operator-= (Quaternion const & q ) - { - m_s -= q.m_s; - m_v -= q.m_v; - return *this; - } - - Quaternion operator+ ( Quaternion const &q ) const { return Quaternion(m_s + q.m_s, m_v + q.m_v); } - Quaternion operator- ( Quaternion const &q ) const { return Quaternion(m_s - q.m_s, m_v - q.m_v); } - - Quaternion & operator*=(value_type const &s_val ) - { - m_s *= s_val; - m_v *= s_val; - return *this; - } - - Quaternion & operator/=( value_type const &s_val ) - { - assert(s_val || !"Quaternion::operator/=(): division by zero"); - m_s /= s_val; - m_v /= s_val; - return *this; - } - - Quaternion operator-() const { return Quaternion(-m_s,-m_v); } - - value_type operator*(Quaternion const &q) const { return m_s*q.m_s + m_v*q.m_v; } - - /** - * Multiplication of quaternions. - * This method multiplies two quaternions with each other - * and assigns the result to this Quaternion. - * - * @param b The second Quaternion. - */ - Quaternion operator%(Quaternion const & b) - { - return Quaternion( m_s*b.s() - dot(m_v , b.v()), cross(m_v , b.v()) + b.v()*m_s + m_v*b.s() ); - } - - /** - * Quaternion Vector Multiplication. - * - * @param v A Quaternion as a vector, i.e. zero scalar value. - */ - Quaternion operator%(vector3_type const & v_val) - { - return Quaternion( - dot( m_v() , v_val) , cross(m_v , v_val) + v_val*m_s ); - } - - public: - - /** - * Assigns the quaternion to the identity rotation. - * This is a commonly used constant. It corresponds to the identity matrix. - */ - void identity() - { - m_s = value_traits::one(); - m_v.clear(); - } - - /** - * This method constructs a unit Quaternion which represents the specified rotation around the x-axis. - * - * @param rad The rotation angle in radians around the axis. - */ - void Rx(value_type const & rad) - { - using std::cos; - using std::sin; - - value_type teta = rad/value_traits::two(); - value_type cteta = (value_type)( cos(teta) ); - value_type steta = (value_type)( sin(teta) ); - - m_s = cteta; - m_v(0) = steta; - m_v(1) = value_traits::zero(); - m_v(2) = value_traits::zero(); - } - - /** - * This method constructs a unit Quaternion which represents the specified rotation around the y-axis. - * - * @param rad The rotation angle in radians around the axis. - */ - void Ry(value_type const & rad) - { - using std::cos; - using std::sin; - - value_type teta = rad/value_traits::two(); - value_type cteta = (value_type)( cos(teta) ); - value_type steta = (value_type)( sin(teta) ); - - m_s = cteta; - m_v(0) = value_traits::zero(); - m_v(1) = steta; - m_v(2) = value_traits::zero(); - } - - /** - * This method constructs a unit Quaternion which represents the specified rotation around the z-axis. - * - * @param rad The rotation angle in radians around the axis. - */ - void Rz(value_type const & rad) - { - using std::cos; - using std::sin; - - value_type teta = rad/value_traits::two(); - value_type cteta = (value_type)( cos(teta) ); - value_type steta = (value_type)( sin(teta) ); - - m_s = cteta; - m_v(0) = value_traits::zero(); - m_v(1) = value_traits::zero(); - m_v(2) = steta; - } - - /** - * Rotate Vector by Quaternion. - * - * computes r' = q*r*conj(q) - */ - vector3_type rotate(vector3_type const & r) const { return ((*this) % r % conj(*this)).v(); } - - public: - - /** - * Equality comparison with an error bound. - * The test is exactly the same as with the method without error bound the only difference - * is that the corresponding terms of the quaternions are said to be equal if they do not - * differ by more than the error bound value. - * - * @param q A reference to a Quaternion. This is the - * Quaternion to compare with. - * @param threshold A reference to the acceptable error bound. - * - * @return The test result. The return value is one if - * the quaternions are equal otherwise the return - * value is zero. - */ - bool is_equal(Quaternion const & q,value_type const & threshold) const - { - using std::fabs; - - assert( threshold>=value_traits::zero() || !"is_equal(): threshold must be non-negative"); - - return fabs(m_s-q.m_s) - inline Vector3 rotate(Quaternion const & q, Vector3 const & r) - { - return prod( prod(q , r) , conj(q)).v(); - } - - template - inline Quaternion prod(Quaternion const & a, Quaternion const & b) - { - return Quaternion( a.s()*b.s() - dot(a.v() , b.v()), cross(a.v() , b.v()) + b.v()*a.s() + a.v()*b.s() ); - } - - template - inline Quaternion prod(Quaternion const & a, Vector3 const & b) - { - return Quaternion( - dot(a.v() , b), cross(a.v() , b) + b*a.s() ); - } - - template - inline Quaternion prod(Vector3 const & a, Quaternion const & b) - { - return Quaternion( - dot(a , b.v()), cross(a , b.v()) + a*b.s() ); - } - - template - inline Quaternion operator%(Quaternion const & a, Quaternion const & b) { return prod(a,b); } - template - inline Quaternion operator%(Quaternion const & a, Vector3 const & b) { return prod(a,b); } - template - inline Quaternion operator%(Vector3 const & a, Quaternion const & b) { return prod(a,b); } - template - inline Quaternion operator*( const Quaternion &q, const T2 &s_val ) { return Quaternion( q.s()*s_val, q.v()*s_val); } - template - inline Quaternion operator*( const T2 &s_val, const Quaternion &q ) { return Quaternion( q.s()*s_val, q.v()*s_val); } - template - inline Quaternion operator/( const Quaternion &q, const T2 &s_val ) { return Quaternion( q.s()/s_val, q.v()/s_val); } - template - inline Quaternion operator/( const T2 &s_val, const Quaternion &q ) { return Quaternion( q.s()/s_val, q.v()/s_val); } - - template - inline T const length(Quaternion const & q) - { - using std::sqrt; - return sqrt( q*q ); - } - - template - inline Quaternion unit(Quaternion const & q) - { - typedef typename Quaternion::value_traits value_traits; - - using std::sqrt; - using std::fabs; - - T l = length(q); - - if(fabs(l) > value_traits::zero()) - return Quaternion (q.s()/l,q.v()/l); - return Quaternion (value_traits::zero(),value_traits::zero(),value_traits::zero(),value_traits::zero()); - } - - template - inline Quaternion normalize(Quaternion const & q) { return unit(q); } - - /** - * Natural Logarithm - * Returns the Quaternion equal to the natural logarithm of - * the specified Quaternion. - * - * @param q A reference to an unit quaternion. - * @return - */ - template - inline Quaternion log(Quaternion const & q) - { - typedef typename Quaternion::value_traits value_traits; - - using std::acos; - using std::sin; - - if(q.s()==value_traits::one() && is_zero(q.v())) - return Quaternion(value_traits::zero(),value_traits::zero(),value_traits::zero(),value_traits::zero()); - - T teta = (T)( acos(q.s()) ); - T st = (T)( sin(teta) ); - return Quaternion( value_traits::zero(), q.v()*(teta/st) ); - } - - /** - * Orthogonal Quaternion. - * This method sets this Quaternion to an orthogonal Quaternion - * of the specified Quaternion. In other words the resulting - * angle between the specified Quaternion and this Quaternion - * is pi/2. - */ - template - inline Quaternion hat(Quaternion const & q) - { - return Quaternion( q.v()(2), - q.v()(1) , q.v()(0), -q.s()); - } - - /** - * Exponent - * Sets the Quaternion equal to the exponent of - * the specified Quaternion. - * - * @param q A reference to a pure Quaternion (zero - * T part). - */ - template - inline Quaternion exp(Quaternion const & q) - { - using std::sqrt; - using std::cos; - using std::sin; - - //--- teta^2 x^2 + teta^2 y^2 +teta^2 z^2 = - //--- teta^2 (x^2 + y^2 + z^2) = teta^2 - T teta = (T)( sqrt(q.v() *q.v()) ); - T ct = (T)( cos(teta) ); - T st = (T)( sin(teta) ); - - return Quaternion(ct,q.v()*st); - } - - /** - * QLERP - Linear Interpolation of Quaterions. - * - * @param A Quaternion A - * @param B Quaternion B - * @param w The weight - * - * @return The resulting Quaternion, (1-w)A+w B. Note the resulting - * Quaternion may not be a unit quaternion even though A and B are - * unit quaternions. If a unit Quaternion is needed write - * unit(qlerp(A,B,w)). - * - * -Added by spreak for the SBS algorithm, see OpenTissue/kinematics/skinning/SBS - */ - template - // TODO why not simply call this function lerp? - inline Quaternion qlerp(Quaternion const & A,Quaternion const & B,T const & w) - { - typedef typename Quaternion::value_traits value_traits; - - assert(w>=value_traits::zero() || !"qlerp(): w must not be less than 0"); - assert(w<=value_traits::one() || !"qlerp(): w must not be larger than 1"); - T mw = value_traits::one() - w; - return ((mw * A) + (w * B)); - } - - /** - * Spherical Linear Interpolation of Quaternions. - * - * @param A - * @param B - * @param w The weight - * - * @return The resulting Quaternion. - */ - template - inline Quaternion slerp(Quaternion const & A,Quaternion const & B,T const & w) - { - typedef typename Quaternion::value_traits value_traits; - - using std::acos; - using std::sin; - - assert(w>=value_traits::zero() || !"slerp(): w must not be less than 0"); - assert(w<=value_traits::one() || !"slerp(): w must not be larger than 1"); - - T q_tiny = (T)( 10e-7 ); // TODO prober constant type conversion? - - T norm = A*B; - - bool flip = false; - if( norm < value_traits::zero() ) - { - norm = -norm; - flip = true; - } - T weight = w; - T inv_weight; - if(value_traits::one() - norm < q_tiny) - { - inv_weight = value_traits::one() - weight; - } - else - { - T theta = (T)( acos(norm) ); - T s_val = (T)( value_traits::one() / sin(theta) ); - inv_weight = (T)( sin((value_traits::one() - weight) * theta) * s_val ); - weight = (T)( sin(weight * theta) * s_val ); - } - if(flip) - { - weight = -weight; - } - return ( inv_weight * A + weight * B); - } - - /** - * "Cubical" Spherical Interpolation. - * In popular terms this corresponds to a cubic spline in - * ordinary 3D space. However it is really a series of - * spherical linear interpolations, which defines a - * cubic on the unit Quaternion sphere. - * - * @param q0 - * @param q1 - * @param q2 - * @param q3 - * @param u - * - * @return - */ - template - inline Quaternion squad( - Quaternion const & q0 - , Quaternion const & q1 - , Quaternion const & q2 - , Quaternion const & q3 - , T const & u - ) - { - typedef typename Quaternion::value_traits value_traits; - - assert(u>=value_traits::zero() || !"squad(): u must not be less than 0"); - assert(u<=value_traits::one() || !"squad(): u must not be larger than 1"); - - T u2 = value_traits::two() *u*(value_traits::one() -u); - return slerp( slerp(q0,q3,u), slerp(q1,q2,u), u2); - } - - /** - * Quaternion Conjugate. - */ - template - inline Quaternion conj(Quaternion const & q) - { - return Quaternion(q.s(),-q.v()); - } - - - /** - * Get Axis Angle Representation. - * This function converts a unit-quaternion into the - * equivalent angle-axis representation. - * - * @param Q The quaternion - * @param axis Upon return this argument holds value of the equivalent rotation axis. - * @param theta Upon return this argument holds value of the equivalent rotation angle. - */ - template - inline void get_axis_angle(Quaternion const & Q,Vector3 & axis, T & theta) - { - using std::atan2; - - typedef typename Quaternion::value_traits value_traits; - typedef Vector3 V; - - // - // By definition a unit quaternion Q can be written as - // - // Q = [s,v] = [cos(theta/2), n sin(theta/2)] - // - // where n is a unit vector. This is the same as a rotation of - // theta radian around the axis n. - // - // - // Rotations are difficult to work with for several reasons. - // - // Firstly both Q and -Q represent the same rotation. This is - // easily proven, rotate a arbitrary vector r by Q then we have - // - // r^\prime = Q r Q^* - // - // Now rotate the same vector by -Q - // - // r^\prime = (-Q) r (-Q)^* = Q r Q^* - // - // because -Q = [-s,-v] and (-Q)^* = [-s , v] = - [s,-v]^* = - Q^*. - // - // Thus the quaternion representation of a single rotation is not unique. - // - // Secondly the rotation it self is not well-posed. A rotation of theta - // radians around the unit axis n could equally well be done as a rotation - // of -theta radians around the negative unit axis n. - // - // This is seen by straightforward substitution - // - // [ cos(-theta/2), sin(-theta/2) (-n) ] = [ cos(theta/2), sin(theta/2) n ] - // - // Thus we get the same quaternion regardless of whether we - // use (+theta,+n) or (-theta,-n). - // - // - // From the Quaternion we see that - // - // \frac{v}{\norm{v}} = \frac{ sin(theta/2) n }{| sin(theta/2) | } = sign(sin(theta/2)) n - // - // Thus we can easily get the rotation axis. However, we can not immediately - // determine the positive rotation axis direction. The problem boils down to the - // fact that we can not see the sign of the sinus-factor. - // - // Let us proceed by setting - // - // x = cos(theta/2) = s - // y = | sin(theta/2) | = \norm{v} - // - // Then we basically have two possibilities for finding theta - // - // theta_1 = 2 atan2( y, x) equivalent to sign(sin(theta/2)) = 1 - // - // or - // - // theta_2 = 2 atan2( -y, x) equivalent to sign(sin(theta/2)) = -1 - // - // If theta_1 is the solution we have - // - // n = \frac{v}{\norm{v}} - // - // If theta_2 is the solution we must have - // - // n = - \frac{v}{\norm{v}} - // - // Observe that we always have theta_2 = 2 pi - theta_1. Therefore theta_1 < theta_2. - // - // Let us imagine that we always choose $theta_1$ as the solution then - // the corresponding quaternion for that solution would be - // - // - // Q_1 = [cos(theta_1/2), sin(theta_1/2) \frac{v}{\norm{v}}] - // = [s , \norm{v} \frac{v}{\norm{v}}] - // = Q - // - // Now if we choose theta_2 as the solution we would have - // - // Q_2 = [cos(theta_2/2), sin(theta_2/2) -\frac{v}{\norm{v}}] - // = [s , -\norm{v} -\frac{v}{\norm{v}}] - // = [s , \norm{v} \frac{v}{\norm{v}}] - // = Q - // - // Thus we observe that regardless of which solution we pick we always have Q = Q_1 = Q_2. - // - // At this point one may be confused. However, it should be clear that theta_2 is equivalent - // to the theta_1 rotation. The difference is simply that theta_2 corresponds to flipping the - // rotation axis of the theta_1 case. - // - T const ct2 = Q.s(); //--- cos(theta/2) - T const st2 = length( Q.v() ); //--- |sin(theta/2)| - - theta = value_traits::two()* atan2(st2,ct2); - - assert( st2 >= value_traits::zero() || !"get_axis_angle(): |sin(theta/2)| must be non-negative"); - assert( theta >= value_traits::zero() || !"get_axis_angle(): theta must be non-negative"); - assert( is_number(theta) || !"get_axis_angle(): NaN encountered"); - - axis = st2 > value_traits::zero() ? Q.v() / st2 : V(value_traits::zero(), value_traits::zero(), value_traits::zero()); - } - - /** - * Get Rotation Angle wrt. an Axis. - * Think of it as if you have a fixated body A so only body B is allowed to move. - * - * Let BF_B' indicate the initial orientation of body B's body frame - * and BF_B the current orientation, now BF_A should be thought of as - * being immovable ie. constant. - * - * Q_initial : BF_A -> BF_B' - * Q_cur : BF_A -> BF_B - * - * Now we must have the relation - * - * Q_rel Q_initial = Q_cur - * - * From which we deduce - * - * Q_rel = Q_cur conj(Q_initial) - * - * And we see that - * - * Q_rel : BF_B' -> BF_B - * - * That is how much the body frame of body B have rotated (measured - * with respect to the fixed body frame A). - * - * - * @param Q_rel Rotation from initial orientation of B to current orientation of B. - * @param axis The rotation axis in the body frame of body B. - * - * @return The angle in radians. - */ - template - inline T get_angle(Quaternion const & Q_rel,Vector3 const & axis) - { - typedef typename Quaternion::value_traits value_traits; - - using std::atan2; - - //--- The angle between the two bodies is extracted from the Quaternion Q_rel - //--- - //--- [s,v] = [ cos(theta/2) , sin(theta/2) * u ] - //--- - //--- where s is a value_type and v is a 3-vector. u is a unit length axis and - //--- theta is a rotation along that axis. - //--- - //--- we can get theta/2 by: - //--- - //--- theta/2 = atan2 ( sin(theta/2) , cos(theta/2) ) - //--- - //--- but we can not get sin(theta/2) directly, only its absolute value: - //--- - //--- |v| = |sin(theta/2)| * |u| = |sin(theta/2)| - //--- - //--- using this value will have a strange effect. - //--- - //--- Recall that there are two Quaternion representations of a given - //--- rotation, q and -q. - //--- - //--- Typically as a body rotates along the axis it will go through a - //--- complete cycle using one representation and then the next cycle - //--- will use the other representation. - //--- - //--- This corresponds to u pointing in the direction of the joint axis and - //--- then in the opposite direction. The result is that theta - //--- will appear to go "backwards" every other cycle. - //--- - //--- Here is a fix: if u points "away" from the direction of the joint - //--- axis (i.e. more than 90 degrees) then use -q instead of q. This - //--- represents the same rotation, but results in the cos(theta/2) value - //--- being sign inverted. - T ct2 = Q_rel.s(); //--- cos(theta/2) - T st2 = length( Q_rel.v() ); //--- |sin(theta/2)| - T theta = value_traits::zero(); - - //--- Remember that Q_rel : BF_B' -> BF_B, so we need the axis in body B's local frame - if( Q_rel.v() * axis >= value_traits::zero()) - { - //--- u points in direction of axis. - //std::cout << "u points in direction of axis" << std::endl; - theta = value_traits::two()* atan2(st2,ct2); - } - else - { - //--- u points in opposite direction. - //std::cout << "u points in opposite direction" << std::endl; - theta = value_traits::two() * atan2(st2,-ct2); - } - //--- The angle we get will be between 0..2*pi, but we want - //--- to return angles between -pi..pi - if (theta > value_traits::pi()) - theta -= value_traits::two()*value_traits::pi(); - - //--- The angle we've just extracted has the wrong sign (Why???). - theta = -theta; - // - // Say we have a rotation, R, relating the coordinates of two frames X and Y, now - // let the coordinates of the vector v be given in frame X as - // - // [v]_X - // - // And in frame Y as - // - // [v]_Y - // - // Now R is defined such that - // - // R [v]_X = [v]_Y - // - // That is it changes the coordinates of v from X to Y. - // - // This is pretty straightforward, but there is some subtlety in it, say - // frame Y is rotated theta radians around the z-axis, then the rotation - // matrix relating the coordinates is the opposite rotation. - // - // What we want to measure is how much the frame axis have rotated, but - // what we are given is a rotation transforming coordinates, therefore - // we need to flip the sign of the extracted angle!!! - return theta; - } - - template - inline std::ostream & operator<< (std::ostream & o,Quaternion const & q) - { - o << "[" << q.s() << "," << q.v()(0) << "," << q.v()(1) << "," << q.v()(2) << "]"; - return o; - } - - template - inline std::istream & operator>>(std::istream & i,Quaternion & q) - { - char dummy; - - i >> dummy; - i >> q.s(); - i >> dummy; - i >> q.v()(0); - i >> dummy; - i >> q.v()(1); - i >> dummy; - i >> q.v()(2); - i >> dummy; - - return i; - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_QUATERNION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_value_traits.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_value_traits.h deleted file mode 100644 index a09def20c..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_value_traits.h +++ /dev/null @@ -1,48 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_VALUE_TRAITS_H -#define OPENTISSUE_CORE_MATH_MATH_VALUE_TRAITS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - - -namespace OpenTissue -{ - - namespace math - { - - template - class ValueTraits - { - public: - - static T zero() { return detail::zero(); } - static T one() { return detail::one(); } - static T two() { return detail::two(); } - static T three() { return detail::three(); } - static T four() { return detail::four(); } - static T eight() { return detail::eight(); } - static T half() { return detail::half(); } - static T pi() { return detail::pi(); } - static T pi_2() { return detail::pi_half(); } - static T pi_half() { return detail::pi_half(); } - static T pi_quarter(){ return detail::pi_quarter();} - static T pi_4() { return detail::pi_quarter();} - static T degree() { return detail::degree(); } - static T radian() { return detail::radian(); } - - }; - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_VALUE_TRAITS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_vector3.h b/Demos3/FiniteElementMethod/OpenTissue/core/math/math_vector3.h deleted file mode 100644 index 661ff659b..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/core/math/math_vector3.h +++ /dev/null @@ -1,577 +0,0 @@ -#ifndef OPENTISSUE_CORE_MATH_MATH_VECTORX3_H -#define OPENTISSUE_CORE_MATH_MATH_VECTORX3_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - - - -#include -#include -#include - -// TODO 2007-06-05 hod - Could not get this to work on linux. -// Might have somthing to do with http://gcc.gnu.org/faq.html#friend -//#include -#include - - -namespace OpenTissue -{ - - namespace math - { - - template < - typename value_type_ - //, typename value_traits_ = ValueTraits - > - class Vector3 - { - protected: - - typedef typename OpenTissue::math::ValueTraits value_traits_ ; // TODO value_traits_ should be parameterized as a class template parameter. - - public: - - typedef value_traits_ value_traits; ///< Convience typedef to make value traits accesible for all template functions using Vector3 types. - typedef value_type_ value_type; ///< Typedef is required for compliance with many other libraries and data containers! - typedef size_t index_type; // TODO should the index type be template parameterized? - - private: - - // TODO 2007-02-17 KE: Refactor this stuff into an array - - value_type x; ///< The first coordinate of this vector. - value_type y; ///< The second coordinate of this vector. - value_type z; ///< The third coordinate of this vector. - - public: - - - Vector3() - : x( value_traits::zero() ) - , y( value_traits::zero() ) - , z( value_traits::zero() ) - {} - - Vector3( Vector3 const & v ) - : x(v(0)) - , y(v(1)) - , z(v(2)) - {} - - explicit Vector3( value_type const& val ) - : x( val ) - , y( val ) - , z( val ) - {} - - template - Vector3( T1 const & x_val, T2 const & y_val, T3 const & z_val ) - : x( (value_type)(x_val) ) - , y( (value_type)(y_val) ) - , z( (value_type)(z_val) ) - {} - - ~Vector3() - {} - - Vector3 & operator=(Vector3 const & cpy) - { - x=cpy(0); - y=cpy(1); - z=cpy(2); - return *this; - } - - public: - - void clear() { x = y = z = value_traits::zero(); } - - size_t size() const { return 3u;} - - public: - - value_type & operator() ( index_type index ) - { - assert( (index>=0 && index<3) || !"vecto3():index should be in range [0..2]"); - return *((&x) + index); - } - - value_type const & operator() ( index_type index ) const - { - assert( (index>=0 && index<3) || !"vecto3():index should be in range [0..2]"); - return *((&x) + index); - } - - value_type & operator[] ( index_type index ) - { - assert( (index>=0 && index<3) || !"vecto3[]:index should be in range [0..2]"); - return *((&x) + index); - } - - value_type const & operator[] ( index_type index ) const - { - assert( (index>=0 && index<3) || !"vecto3[]:index should be in range [0..2]"); - return *((&x) + index); - } - - public: - - bool operator< (Vector3 const & v) const - { - if ( x < v(0) ) return true; - if ( x > v(0) ) return false; - if ( y < v(1) ) return true; - if ( y > v(1) ) return false; - return z < v(2); - } - - bool operator> (Vector3 const & v) const - { - if ( x > v(0) ) return true; - if ( x < v(0) ) return false; - if ( y > v(1) ) return true; - if ( y < v(1) ) return false; - return z > v(2); - } - - // TODO: Comparing floats with == or != is not safe NOTE value_type might not be a float type it could be anything? This suggest that we need some kinf of metaprogramming technique to deal with ths problem? - bool operator==(Vector3 const & cmp) const { return x==cmp.x && y==cmp.y && z==cmp.z; } - bool operator!=(Vector3 const & cmp) const { return x!=cmp.x || y!=cmp.y || z!=cmp.z; } - - public: - - Vector3 & operator+= ( Vector3 const & v ) - { - x += v(0); - y += v(1); - z += v(2); - return *this; - } - - Vector3 & operator-= ( Vector3 const & v ) - { - x -= v(0); - y -= v(1); - z -= v(2); - return *this; - } - - Vector3 & operator*=( value_type const & s ) - { - x *= s; - y *= s; - z *= s; - return *this; - } - - Vector3 & operator/=( value_type const & s ) - { - assert(s || !"Vector3::/=(): division by zero"); - x /= s; - y /= s; - z /= s; - return *this; - } - - Vector3 operator+ ( Vector3 const & v ) const { return Vector3( x+v(0), y+v(1), z+v(2)); } - Vector3 operator- ( Vector3 const & v ) const { return Vector3( x-v(0), y-v(1), z-v(2)); } - Vector3 operator- ( ) const { return Vector3(-x,-y,-z); } - Vector3 operator% ( Vector3 const & v ) const { return Vector3(y*v(2)-v(1)*z, v(0)*z-x*v(2), x*v(1)-v(0)*y); } - value_type operator* ( Vector3 const & v ) const { return x*v(0) + y*v(1) + z*v(2); } - bool operator<=( Vector3 const & v ) const { return x <= v(0) && y <= v(1) && z <= v(2); } - bool operator>=( Vector3 const & v ) const { return x >= v(0) && y >= v(1) && z >= v(2); } - - public: - - friend Vector3 fabs( Vector3 const & v ) - { - using std::fabs; - return Vector3 ( - (value_type)( fabs( v(0) ) ) - , (value_type)( fabs( v(1) ) ) - , (value_type)( fabs( v(2) ) ) - ); - } - - friend Vector3 min( Vector3 const & A, Vector3 const & B ) - { - using std::min; - return Vector3( min( A(0), B(0) ), min( A(1), B(1) ), min( A(2), B(2) ) ); - } - - friend Vector3 max( Vector3 const & A, Vector3 const & B ) - { - using std::max; - return Vector3( max( A(0), B(0) ), max( A(1), B(1) ), max( A(2), B(2) ) ); - } - - friend Vector3 floor(Vector3 const & v) - { - using std::floor; - return Vector3( - (value_type)( floor(v(0)) ) - , (value_type)( floor(v(1)) ) - , (value_type)( floor(v(2)) ) - ); - } - - friend Vector3 ceil(Vector3 const & v) - { - using std::ceil; - return Vector3( - (value_type)( ceil(v(0)) ) - , (value_type)( ceil(v(1)) ) - , (value_type)( ceil(v(2)) ) - ); - } - - friend std::ostream & operator<< (std::ostream & o,Vector3 const & v) - { - o << "["; - o << v(0); - o << ","; - o << v(1); - o << "," << v(2) << "]"; - return o; - } - - friend std::istream & operator>>(std::istream & i,Vector3 & v) - { - char dummy; - i >> dummy; - i >> v(0); - i >> dummy; - i >> v(1); - i >> dummy; - i >> v(2); - i >> dummy; - return i; - } - public: - - // TODO 2007-02-17 KE: Kill this it should be handled with comparator traits in operator== and operator!= - bool is_equal(Vector3 const & v, value_type const & threshold) const - { - using std::fabs; - return fabs(x-v.x)<=threshold && fabs(y-v.y)<=threshold && fabs(z-v.z)<=threshold; - } - - }; // class Vector3 - - - ////////////////////////////////////////////////////////////////////////// - /// Declaration of vector3 non-member functions - ////////////////////////////////////////////////////////////////////////// - - template - inline Vector3 round(Vector3 const & v) - { - using std::floor; - - static T const half = detail::half(); - - return Vector3 ( - floor( v(0) + half ) - , floor( v(1) + half ) - , floor( v(2) + half ) - ); - } - - template - inline typename Vector3::index_type min_index(Vector3 const & v) - { - return v(0) <= v(1) && v(0) < v(2) ? 0 : v(1) <= v(0) && v(1) < v(2) ? 1 : 2; - } - - template - inline typename Vector3::index_type max_index(Vector3 const & v) - { - return v(2) >= v(0) && v(2) >= v(1) ? 2 : v(1) >= v(0) && v(1) > v(2) ? 1 : 0; - } - - template - inline typename Vector3::index_type mid_index(Vector3 const & v) - { - typename Vector3::index_type test = min_index(v) + max_index(v); - return test == 2 ? 1 : test == 1 ? 2 : 0; - } - - template - inline T min_value(Vector3 const & v) - { - using std::min; - return min(v(0),min(v(1),v(2))); - } - - template - inline T max_value(Vector3 const & v) - { - using std::max; - return max(v(0),max(v(1),v(2))); - } - - template - inline T mid_value(Vector3 const & v) - { - return v(mid_index(v)); - } - - template - inline bool is_zero(Vector3 const & v, T const & threshold) - { - using std::fabs; - return fabs(v(0))<=threshold && fabs(v(1))<=threshold && fabs(v(2))<=threshold; - } - - template - inline bool is_zero(Vector3 const & v) - { - typedef typename Vector3::value_traits value_traits; - return is_zero(v,value_traits::zero()); - } - - - - - template - inline Vector3 cross( Vector3 const & a, Vector3 const & b ) - { - return Vector3( a[1] * b[2] - b[1] * a[2], -a[0] * b[2] + b[0] * a[2], a[0] * b[1] - b[0] * a[1] ); - } - - template - inline T dot( Vector3 const & a, Vector3 const & b ) { return a(0)*b(0) + a(1)*b(1) + a(2)*b(2); } - - template - inline T inner_prod( Vector3 const & a, Vector3 const & b ) { return dot(a,b); } - - template - inline T length(Vector3 const & v) - { - using std::sqrt; - return (T)( sqrt( dot(v,v) ) ); - } - - template - inline T sqr_length(Vector3 const & v) { return (T)(v*v); } - - template - inline T norm(Vector3 const & v) { return length(v); } - - template - inline T norm_1(Vector3 const & v) - { - using std::fabs; - using std::max; - return max( fabs(v(0)), max( fabs(v(1)), fabs(v(2)) ) ); - } - - template - inline T distance(Vector3 const & a, Vector3 const & b) - { - return length(b-a); - } - - template - inline T sqr_distance(Vector3 const & a, Vector3 const & b) - { - return sqr_length(b-a); - } - - template - inline Vector3 sgn( Vector3 const & v ) - { - using OpenTissue::math::sgn; - return Vector3(sgn(v(0)), sgn(v(1)), sgn(v(2))); - } - - template - inline Vector3 unit( Vector3 const & v ) - { - typedef typename Vector3::value_traits value_traits; - - - using std::sqrt; - T const l = length(v); - if (l <= value_traits::zero()) - { - return Vector3( value_traits::zero() ); - } - T const inv = value_traits::one()/l; - return Vector3( inv*v(0), inv*v(1), inv*v(2) ); - } - - template - inline Vector3 normalize( Vector3 const & v ) { return unit(v); } - - template - inline void truncate(Vector3 & v, T const & precision_value) - { - typedef typename Vector3::value_traits value_traits; - - v(0) = ((v(0)>-precision_value)&&(v(0)-precision_value)&&(v(1)-precision_value)&&(v(2) - inline void truncate(Vector3 & v) - { - typedef typename Vector3::value_traits value_traits; - - truncate( v, value_traits::zero() ); - } - - /** - * Get Orthogonal Vector. - * - * @param v Any vector - * - * @return A vector orthogonal to v. - */ - template - inline Vector3 orthogonal(Vector3 const & v) - { - typedef typename Vector3::value_traits value_traits; - - using std::fabs; - - //--- Find a vector not collinear with v, we simply pick the - //--- y-axis direction as our prefered direction, afterwards - //--- we test if this was a good choice if not we pick the - //--- x-axis direction - Vector3 tmp; - if (fabs(v(1)) > fabs(v(0))) - tmp = Vector3(value_traits::one(),value_traits::zero(),value_traits::zero()); - else - tmp = Vector3(value_traits::zero(),value_traits::zero(),value_traits::one()); - //--- Now we find an orthogonal vector by using - //--- the cross product - return cross(v,tmp); - } - - template - inline Vector3 operator*( Vector3 const& v, T2 const& s ) { return Vector3( v(0)*s, v(1)*s, v(2)*s ); } - - template - inline Vector3 operator*( T2 const& s, Vector3 const& v ) { return Vector3( v(0)*s, v(1)*s, v(2)*s ); } - - template - inline Vector3 operator/( Vector3 const& v, T2 const& s ) { return Vector3( v(0)/s, v(1)/s, v(2)/s ); } - - /** - * Compute Orthonormal Vectors. - * Compute unit vectors of a right handed coordinate frame, given initial z-axis (k-vector). - * - * @param i Upon return contains a orthogonal vector to j and k - * @param j Upon return contains a orthogonal vector to i and k - * @param k A given direction for the last vector, assumed to be a unit-vector. - */ - template - inline void orthonormal_vectors( vector3_type & i, vector3_type & j, vector3_type const & k ) - { - typedef typename vector3_type::value_traits value_traits; - - using std::fabs; - vector3_type m_abs_k = fabs( k); - - if ( m_abs_k( 0 ) > m_abs_k( 1 ) ) - { - if ( m_abs_k( 0 ) > m_abs_k( 2 ) ) - i = vector3_type( value_traits::zero(), value_traits::one(), value_traits::zero() ); - else - i = vector3_type( value_traits::one(), value_traits::zero(), value_traits::zero() ); - } - else - { - if ( m_abs_k( 1 ) > m_abs_k( 2 ) ) - i = vector3_type( value_traits::zero(), value_traits::zero(), value_traits::one() ); - else - i = vector3_type( value_traits::one(), value_traits::zero(), value_traits::zero() ); - } - j = unit( cross(k,i) ); - i = cross(j,k); - } - - /** - * Get increasing order of vector elements as a permutation array. - * - * Note this template function generalizes to any size of vectors - * (not just 3-dimensional ones). - * - * @param v The vector to be examined. - * @param pi Upon return this container contains the permuation - * order, v(pi[0]) is smallest element of v, v(pi[1]) the - * next smallest and so on. - */ - template - inline void get_increasing_order( vector_type const & v, permutation_container & pi ) - { - unsigned int n = v.size(); - - for(unsigned int i=0u;i 0u;--j ) - { - if ( v( pi[ j ] ) < v( pi[ j - 1 ] ) ) - { - unsigned int tmp = pi[ j - 1 ]; - pi[ j - 1 ] = pi[ j ]; - pi[ j ] = tmp; - } - } - } - } - - - namespace detail - { - - template - inline Vector3 const & axis_x() - { - static Vector3 const xa(one(), zero(), zero()); - return xa; - } - - - template - inline Vector3 const & axis_y() - { - static Vector3 const ya(zero(), one(), zero()); - return ya; - } - - - template - inline Vector3 const & axis_z() - { - static Vector3 const za(zero(), zero(), one()); - return za; - } - - } - - } // namespace math - -} // namespace OpenTissue - -//OPENTISSUE_CORE_MATH_MATH_VECTORX3_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem.h deleted file mode 100644 index d91785e2b..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem.h +++ /dev/null @@ -1,17 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -//#include -#include -#include - -//OPENTISSUE_DYNAMICS_FEM_FEM_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_add_plasticity_force.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_add_plasticity_force.h deleted file mode 100644 index 12097a692..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_add_plasticity_force.h +++ /dev/null @@ -1,221 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_ADD_PLASTICITY_FORCE_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_ADD_PLASTICITY_FORCE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include -#include //std::min -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - - template - void add_plasticity_force_single1(tetrahedron_type& tet, real_type const & dt) - { - - using std::min; - using std::sqrt; - - typedef typename tetrahedron_type::vector3_type vector3_type; - - - assert(tet.m_yield>=0 || !"add_plasticity_force(): yield must be non-negative"); - assert(tet.m_creep>=0 || !"add_plasticity_force(): creep must be non-negative"); - assert(tet.m_creep<=(1.0/dt) || !"add_plasticity_force(): creep must be less that reciprocal time-step"); - assert(tet.m_max>=0 || !"add_plasticity_force(): max must be non-negative"); - - //--- Storage for total and elastic strains (plastic strains are stored in the tetrahedra) - real_type e_total[6]; - real_type e_elastic[6]; - - for(int i=0;i<6;++i) - e_elastic[i] = e_total[i] = 0; - - //--- Compute total strain: e_total = Be (Re^{-1} x - x0) - for(unsigned int j=0;j<4;++j) - { - vector3_type & x_j = tet.node(j)->m_coord; - vector3_type & x0_j = tet.node(j)->m_model_coord; - - vector3_type tmp = (trans(tet.m_Re)*x_j) - x0_j; - real_type bj = tet.m_B[j](0); - real_type cj = tet.m_B[j](1); - real_type dj = tet.m_B[j](2); - e_total[0] += bj*tmp(0); - e_total[1] += cj*tmp(1); - e_total[2] += dj*tmp(2); - e_total[3] += cj*tmp(0) + bj*tmp(1); - e_total[4] += dj*tmp(0) + bj*tmp(2); - e_total[5] += dj*tmp(1) + cj*tmp(2); - } - - //--- Compute elastic strain - for(int i=0;i<6;++i) - e_elastic[i] = e_total[i] - tet.m_plastic[i]; - - //--- if elastic strain exceeds c_yield then it is added to plastic strain by c_creep - real_type norm_elastic = 0; - for(int i=0;i<6;++i) - norm_elastic += e_elastic[i]*e_elastic[i]; - norm_elastic = sqrt(norm_elastic); - //max_elastic = max(max_elastic,norm_elastic); - - if(norm_elastic > tet.m_yield) - { - real_type amount = dt*min(tet.m_creep,(1.0/dt)); //--- make sure creep do not exceed 1/dt - for(int i=0;i<6;++i) - tet.m_plastic[i] += amount*e_elastic[i]; - } - - //--- if plastic strain exceeds c_max then it is clamped to maximum magnitude - real_type norm_plastic = 0; - for(int i=0;i<6;++i) - norm_plastic += tet.m_plastic[i]*tet.m_plastic[i]; - norm_plastic = sqrt(norm_plastic); - //max_plastic = max(max_plastic,norm_plastic); - - if(norm_plastic > tet.m_max) - { - real_type scale = tet.m_max/norm_plastic; - for(int i=0;i<6;++i) - tet.m_plastic[i] *= scale; - } - //--- Compute plastic forces: f_plastic = Re Pe e_plastic; where Pe = Ve Be^T E - for(unsigned int j=0;j<4;++j) - { - real_type * plastic = tet.m_plastic; - real_type bj = tet.m_B[j](0); - real_type cj = tet.m_B[j](1); - real_type dj = tet.m_B[j](2); - real_type E0 = tet.m_D(0); - real_type E1 = tet.m_D(1); - real_type E2 = tet.m_D(2); - vector3_type f; - - //--- - //--- - //--- Recall the structure of the B and E matrices - //--- - //--- | bj 0 0 | | E0 E1 E1 | - //--- B_j = | 0 cj 0 | | E1 E0 E0 | - //--- | 0 0 dj | E = | E1 E1 E0 | - //--- | cj bj 0 | | E2 | - //--- | dj 0 bj | | E2 | - //--- | 0 dj cj | | E2 | - //--- - //--- This implyies that the product B_j^T E is - //--- - //--- | bj E0 bj E1 bj E1 cj E2 dj E2 0 | - //--- | cj E1 cj E0 cj E1 bj E2 0 dj E2 | - //--- | dj E1 dj E1 dj E0 0 bj E2 cj E2 | - //--- - //--- Notice that eventhough this is a 3X6 matrix with 18-3=15 nonzero elements - //--- it actually only contains 9 different value. - //--- - //--- In fact these values could be precomputed and stored in each tetrahedron. - //--- Furthermore they could be pre-multiplied by the volume of the tetrahedron - //--- to yield the matrix, - //--- - //--- P_j = Ve B_j^T E - //--- - //--- The plastic force that should be subtracted from node j is then computed - //--- in each iteration as - //--- - //--- f_j = Re P_j e_plastic - //--- - //--- - real_type bjE0 = bj*E0; - real_type bjE1 = bj*E1; - real_type bjE2 = bj*E2; - real_type cjE0 = cj*E0; - real_type cjE1 = cj*E1; - real_type cjE2 = cj*E2; - real_type djE0 = dj*E0; - real_type djE1 = dj*E1; - real_type djE2 = dj*E2; - - f(0) = bjE0*plastic[0] + bjE1*plastic[1] + bjE1*plastic[2] + cjE2*plastic[3] + djE2*plastic[4]; - f(1) = cjE1*plastic[0] + cjE0*plastic[1] + cjE1*plastic[2] + bjE2*plastic[3] + + djE2*plastic[5]; - f(2) = djE1*plastic[0] + djE1*plastic[1] + djE0*plastic[2] + bjE2*plastic[4] + cjE2*plastic[5]; - - f *= tet.m_V; - tet.node(j)->m_f_external += tet.m_Re*f; - } - } - /** - * Add plasticity forces. - * - * @param begin Iterator to first tetrahedron. - * @param end Iterator to one past last tetrahedron. - * @param dt Simulation time step - * - */ - template < typename tetrahedron_iterator,typename real_type > - inline void add_plasticity_force2( - tetrahedron_iterator begin - , tetrahedron_iterator end - , real_type const & dt - ) - { - //typedef typename tetrahedron_iterator::value_type::matrix3x3_type matrix3x3_type; - - //real_type max_elastic = 0; - //real_type max_plastic = 0; - - assert(dt>0 || !"add_plasticity_force(): time-step must be positive"); - //--- - //--- The total strain is given by - //--- - //--- e_total = Be u - //--- - //--- Where u is the nodal displacement, ie u = x - x0. Applying - //--- the idea of stiffness warping we have - //--- - //--- e_total = Be ( Re^{-1} x - x0) - //--- - //--- where R_e is the rotational deformation of the e'th - //--- tetrahedral element. - //--- - //--- The elastic strain is given as the total strain minus the plastic strain - //--- - //--- e_elastic = e_total - e_plastic - //--- - //--- e_plastic is initial initialized to zero. Plastic strain causes plastic forces in the material - //--- - //--- f_plastic = Re Ke u_plastic - //--- - //--- Using e_plastic = Be u_plastic - //--- - //--- f_plastic = Re Ke Be^{-1} e_plastic - //--- f_plastic = Re (Ve Be^T E Be ) Be^{-1} e_plastic - //--- f_plastic = Re (Ve Be^T E) e_plastic - //--- - //--- Introducing the plasticity matrix Pe = (Ve Be^T E) we have - //--- - //--- f_plastic = Re Pe e_plastic - //--- - - for (tetrahedron_iterator T = begin; T != end; ++T) - { - add_plasticity_force_single(T,dt); - - } - //std::cout << "max elastic = " << max_elastic << std::endl; - //std::cout << "max plastic = " << max_plastic << std::endl; - - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_ADD_PLASTICITY_FORCE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_clear_stiffness_assembly.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_clear_stiffness_assembly.h deleted file mode 100644 index c0cce081f..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_clear_stiffness_assembly.h +++ /dev/null @@ -1,37 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_CLEAR_STIFFNESS_ASSEMBLY_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_CLEAR_STIFFNESS_ASSEMBLY_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * - * @param begin - * @param end - */ - template < typename node_type > - inline void clear_stiffness_assembly_single(node_type* node) - { - typedef typename node_type::matrix_iterator matrix_iterator; - node->m_f0.clear(); - for (matrix_iterator Kij = node->Kbegin() ; Kij != node->Kend(); ++Kij ) - Kij->second.clear(); - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_CLEAR_STIFFNESS_ASSEMBLY_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_b.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_b.h deleted file mode 100644 index bf7c01d82..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_b.h +++ /dev/null @@ -1,403 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_B_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_B_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - /** - * Calculate B-matrices (derivatives of shape functions N, i.e B = SN). - * - * @param e10 Given the four corner points p0,p1,p2, and p3. This is p1-p0. - * @param e20 Given the four corner points p0,p1,p2, and p3. This is p2-p0. - * @param e30 Given the four corner points p0,p1,p2, and p3. This is p3-p0. - * @param volume The volume of the tetrahedron. - * @param B Upon return this array of 4 B-vectors contains the computed values. - */ - template - inline void compute_B( - vector3_type const& e10, - vector3_type const& e20, - vector3_type const& e30, - real_type volume, - vector3_type * B - ) - { - // - // In summary we want to calculate - // - // B = S N - // - // where - // - // B = [ B0 B1 B2 B3 ], N = [ N0 N1 N2 N3 ] - // - // Here S is the operational matrix given by - // - - - // | d/dx 0 0 | - // | 0 d/dy 0 | - // | 0 0 d/dz | - // S = | d/dy d/dx 0 | - // | d/dz 0 d/dx | - // | 0 d/dz d/dy | - // - - - // N_i's are called the shape functions and they are used to interpolate values. For - // 3D linear elastostatics these can be written as - // - // - - - // | w_i 0 0 | - // N_i = | 0 w_i 0 | - // | 0 0 w_i | - // - - - // - // The w_i's are functions in the coordinates x,y, and z and will be derived - // shortly below of here. - // - // The matrix B_i is given by: - // - // | b_i 0 0 | - // | 0 c_i 0 | - // B_i = | 0 0 d_i | - // | c_i b_i 0 | - // | d_i 0 b_i | - // | 0 d_i c_i | - // - // The entries are stored as - // - // B[i] = [ b_i c_i d_i ] - // - // In the following we go into details of deriving formulas for the interpolating - // functions N_i. From these formulas it follows how to compute the derivatives. - // Finally we show a clever way of implementing the computaitons. - // - // Using a linear polynomial for interpolating a u(x,y,z)-value at a given - // position x,y,z inside the tetrahedron - // - // u(x,y,z) = a_0 + a_1 x + a_2 y + a_3 z = P^T A - // - // where the a's are the polynomial coefficients (to be determed) and - // - // | 1 | | a0 | - // P = | x | , and A = | a1 | - // | y | | a2 | - // | z | | a3 | - // - // Say we know the u-values, u0(x0,y0,z0),...,u3(x3,y2,z3), at the four tetrahedron corner - // points, P0^T [x0 y0 z0],...,P3^T=[x3 y3 z3], then we can set up the linear system - // - // | u0 | | 1 x0 y0 z0 | | a0 | - // | u1 | = | 1 x1 y1 z1 | | a1 | = C A - // | u2 | | 1 x2 y2 z2 | | a2 | - // | u3 | | 1 x3 y3 z3 | | a3 | - // - // The C matrix is invertible (as long as the four points are in general postion, meaning - // that no point can be written as a linear combination of any of the three other points), - // so we can solve the polynomial coefficients by - // - // | u0 | - // A = C^-1 | u1 | - // | u2 | - // | u3 | - // Substitution into the polynomial interpolation formula yields - // - // | u0 | - // u(x,y,z) = P^T A = P^T C^{-1} | u1 | (*1) - // | u2 | - // | u3 | - // - // Denoting the i'th column of, P^T C^{-1}, by N_i we have u(x,y,z) = sum_i N_i u_i - // - // - // Let us now try to look at the bary-centric coordinates, w0,...,w1 of (x,y,z), these - // can also be used for interpolation - // - // | u0 | |u0| - // u(z,y,z) = w0 u0 + w1 u1 + w2 u2 + w3 u3 = [w0 w1 w2 w3] | u1 | = W^T |u1| - // | u2 | |u2| - // | u3 | |u3| - // - // From the coordinates of the four points and the condition 1 = w0 + w1 + w2 + w3 we can set - // up the linear system - // - // | 1 | | 1 1 1 1 | | w0 | - // | x | = | x0 x1 x2 x3 | | w1 | - // | y | | y0 y1 y2 y3 | | w2 | - // | z | | z0 z1 z2 z3 | | w3 | - // - // - // P = Q W - // - // Since the four points are in general postion, Q is invertible and we can solve for W - // - // W = Q^{-1} P - // - // Insertion into the barycentric interpolation formula yields - // - // |u0| |u0| |u0| - // u(x,y,z) = W^T |u1| = ( Q^{-1} P )^T |u1| = P^T Q^{-T} |u1| (*2) - // |u2| |u2| |u2| - // |u3| |u3| |u3| - // - // Comparision with the polynomial interpolation derivation we see that C = Q^T, furthermore - // we notice that w_i = N_i. So (not very surprinsingly) bary-centric interpolation is really - // just linear polynomial interpolation. - // - // Notice that for the volume, V, of the tetrahedron we have the relation: 6 V = det( C ) = det ( Q^T ) - // - // When computing the stiffness matrix we are interested in derivatives of the N_i's with - // respect to the x,y and z coordinates. - // - // - // From (*1) and (*2) we see (recall we use zero-indexing) - // - // d N_i - // ----- = C^{-1}_{1,i} = Q^{-T}_{1,i} (*3a) - // d x - // - // d N_i - // ----- = C^{-1}_{2,i} = Q^{-T}_{2,i} (*3b) - // d y - // - // d N_i - // ----- = C^{-1}_{3,i} = Q^{-T}_{3,i} (*3c) - // d z - // - // Instead of actually computing the inverse of the 4x4 C or Q matrices a computational - // more efficient solution can be derived, which only requires us to solve for a 3x3 system. - // - // By Cramers rule we have - // - // (-1)^{i+j} det( C_ji) - // C^{-1}_{i,j} = ---------------------- - // det(C) - // - // where det(C_ji) is the determinant of C with the j'th row and i'th column removed. - // - // Now defined - // - // e10 = P1 - P0 - // e20 = P2 - P0 - // e30 = P3 - P0 - // - // and the matrix E - // - // | e10^T | | (x1-x0) (y1-y0) (z1-z0) | - // E = | e20^T | = | (x2-x0) (y2-y0) (z2-z0) | - // | e30^T | | (x3-x0) (y3-y0) (z3-z0) | - // - // Then - // - // det(C) = det(E) and C^{-1}_{i+1,j+1} = E^{-1}_{i,j} (*4) - // - // This can shown by straightforward computation, immediately is is verified that - // - // {-1}^((i+1)+(j+1)) = {-1}^(i+j) - // - // So we have to show - // - // det( C_(i+1,j+1)) det( E_(ij)) - // --------------------- = -------------- - // det(C) det(E) - // - // assume det(C)= det(E) (left for reader as exercise:-) then inorder to prove - // second half of (*4) we have to show - // - // det( C_(i+1,j+1)) = det( E_(ij)) - // - // A total of 9 cases exist, for here we will show a single case and leave - // the remaining cases for the reader, use i=1 and j= 0, implying - // - // det( C_(12)) = det( E_(01)) - // - // So - // - - - // | 1 x0 z0 | - - - // det | 1 x2 z2 | = det | (x2-x0) (z2-z0)| - // | 1 x3 z3 | | (x3-x0) (z3-z0)| - // - - - - - // - // Which is trivially true. So we have - // - // | . ... | | . ... | - // C^{-1} = | . E^{-1} | ; Q^{-T} = | . E^{-T} | - // - // As can be seen from (*3) we do not have all the values needed since - // the first columns of C^{-1} and Q^{-T} are missing. To remedy this problem we can use - // the condition of the bary-centric coordinates - // - // w0 = 1 - w1 - w2 - w3 - // - // Taking the derivate wrt. x,y, and z yields - // - // d N_0 - // ----- = 1 - E^{-1}_01 - E^{-1}_02 - E^{-1}_03 (*5a) - // d x - // - // d N_0 - // ----- = 1 - E^{-1}_11 - E^{-1}_12 - E^{-1}_13 (*5b) - // d y - // - // d N_0 - // ----- = 1 - E^{-1}_21 - E^{-1}_22 - E^{-1}_23 (*5c) - // d z - // - // - // and for i>0 we have - // - // d N_i - // ----- = E^{-1}_0i (*6a) - // d x - // - // d N_i - // ----- = E^{-1}_1i (*6b) - // d y - // - // - // d N_i - // ----- = E^{-1}_2i (*6c) - // d z - // - // The notation b_i = d N_i / dx, c_i = d N_i / dy, and d_i = d N_i / dz is used. Furthermore - // all the derivatives are returned as four B-vectors, where - // - // B[i] = [ b_i c_i d_i] - // - // - // - // The above may seem as a mathematical trick, so let us try to derive our - // equations a litlle differently, but before doing so we must first develop - // some equations for the volume of a tetrahedron. - // - // | e10^T | - // 6 V = det(E) = | e20^T | = e10 \cdot (e20 \times e30) - // | e30^T | - // - // where e10 = p1-p0, e20 = p2-p0 and so on. - // In general given the right-hand order i,j,k, and m of the nodes we - // write vol(i,j,k,m) = eji \cdot (eki \times emi) / 6 - // - // Barycentric coordinates are infact the volume weighted weights coresponding to - // the four tetrahedra lying inside the tetrahedron and having apex at the - // point p=[x,y,z]^T and bases equal to the 4 triangular faces of the enclosing - // tetrahedron. To realize this we will examine bary-centric coordinates - // in the 2D case, that is the case of the Triangle. In 2D area corresponds - // to the volume, so given a trianle and a point p inside it - // - // + 2 - // /| - // / | - // / | - // / | - // / + p| - // / | - // / | - // 0 +-------+ 1 - // - // Let the area weighted weights be defined as - // - // w_0 = area(1,2,p) / area(0,1,2) - // w_1 = area(0,P,2) / area(0,1,2) = area(2,0,P) / area(0,1,2) - // w_2 = area(0,1,p) / area(0,1,2) - // - // It is intuitive to see that if p moves towards the i'th corner point then - // the nominator of w_i goes towards area(0,1,2). This means that w_i -> 1 - // while w_j ->0 for j\neq i. - // - // Having introduced the barycentric coordinates as the area weighted weights - // it is quite intuitive to see that we also must have - // - // 1 = \sum_i w_i - // - // In 3D the barycentric coordinates are the volume weighted weights. That is - // given the right handed order 0,1,2 and 3 of the corner points, we have by - // analogy to the 2D case - // - // vol(0,1,2,p) - // w_3 = ------------ = (p-p0) \codt ( e10 \times \e20 ) / 6V - // V - // - // vol(0,1,3,p) - // w_2 = ------------ = (p-p0) \codt ( e10 \times \e30 ) / 6V - // V - // - // vol(0,2,3,p) - // w_1 = ------------ = (p-p0) \codt ( e20 \times \e30 ) / 6V - // V - // - // vol(1,3,2,p) - // w_0 = ------------ = (p-p0) \codt ( e31 \times \e21 ) / 6V - // V - // - // But since we allready know w_3, w_2 and w_1 it is faster to compute w_0 as - // - // w_0 = 1 - w_1 - w_2 - w_3 - // - // Recal from previous that we seek the derivatives of w_i's wrt. the coordinaes when - // we compute the B functions. Let us write the [x y z] coordinates as [x_0 x_1 x_2] then - // - // d w_3 - // ------- = ( e10 \times \e20 )_{x_j} / 6V - // d x_j - // - // That is the j'th coordinate of the cross product divided by 6 times the volume. Similar for - // - // d w_2 - // ------- = ( e10 \times \e30 )_{x_j} / 6V - // d x_j - // - // d w_1 - // ------- = ( e20 \times \e30 )_{x_j} / 6V - // d x_j - // - // and finally - // - // d w_0 d w_i - // ------- = 1 - sum_i>0 ------- - // d x_j d x_j - // - // Our formulas may seem differnt from those in (*6), however - // - // d w_k - // ------- = ( eji \times \emi )_{x_j} / 6V = E_{-1}_{k,j} - // d x_j - // - // That is the adjoint of E_(j,k) is given by ( eji \times \emi )_{x_j} / 6. - // - // - // - - real_type div6V = 1/(6.0*volume); - - B[1](0) = (e20(2) * e30(1) - e20(1) * e30(2)) * div6V; // b0 = -det(E_11), (where E_ij is the submatrix of E with row i and column j removed) - B[2](0) = (e10(1) * e30(2) - e10(2) * e30(1)) * div6V; // b1 = det(E_12) - B[3](0) = (e10(2) * e20(1) - e10(1) * e20(2)) * div6V; // b2 = -det(E_13) - B[0](0) = -B[1](0) - B[2](0) - B[3](0); // b3 = -b0 - b1 - b2 - - B[1](1) = (e20(0) * e30(2) - e20(2) * e30(0)) * div6V; // c0 = det(E_21) - B[2](1) = (e10(2) * e30(0) - e10(0) * e30(2)) * div6V; // c1 = -det(E_22) - B[3](1) = (e10(0) * e20(2) - e10(2) * e20(0)) * div6V; // c2 = det(E_23) - B[0](1) = -B[1](1) - B[2](1) - B[3](1); // c3 = -c0 - c1 - c2 - - B[1](2) = (e20(1) * e30(0) - e20(0) * e30(1)) * div6V; // d0 = -det(E_31) - B[2](2) = (e10(0) * e30(1) - e10(1) * e30(0)) * div6V; // d1 = det(E_32) - B[3](2) = (e10(1) * e20(0) - e10(0) * e20(1)) * div6V; // d2 = -det(E_33) - B[0](2) = -B[1](2) - B[2](2) - B[3](2); // d3 = -d0 - d1 - d2 - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_B_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_isotropic_elasticity.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_isotropic_elasticity.h deleted file mode 100644 index 555f68ca7..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_isotropic_elasticity.h +++ /dev/null @@ -1,121 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_ISOTROPIC_ELASTICITY_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_ISOTROPIC_ELASTICITY_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Compute Isotropic Elasticity Matrix. - * - * @param young Young Modulus. - * @param poisson Poisson ratio. - * @param D Upon return holds the elasticity matrix in vector form D = [D0,D1,D2] - */ - template - inline void compute_isotropic_elasticity_vector( - real_type const & young - , real_type const & poisson - , vector3_type & D - ) - { - assert(young>0 || !"compute_isotropic_elasticity_vector(): Young modulus must be positive"); - assert(poisson>0 || !"compute_isotropic_elasticity_vector(): Poisson ratio must be positive"); - assert(poisson<0.5 || !"compute_isotropic_elasticity_vector(): Poisson ratio must be less than a half"); - - // The isotropic Elasticity matrix D is given by - // - - - - - // | 1-nu nu nu 0 0 0 | | D0 D1 D1 0 0 0 | - // young | nu 1-nu nu 0 0 0 | | D1 D0 D1 0 0 0 | - // ------------- | nu nu 1-nu 0 0 0 | | D1 D1 D0 0 0 0 | - // (1+nu)(1-2nu) | 0 0 0 (1-2nu)/2 0 0 | = | 0 0 0 D2 0 0 | - // | 0 0 0 0 (1-2nu)/2 0 | | 0 0 0 0 D2 0 | - // | 0 0 0 0 0 (1-2nu)/2 | | 0 0 0 0 0 D2 | - // - - - - - - real_type poisson2 = 2.0*poisson; - real_type scale = young / ((1.0 + poisson) * (1.0 - poisson2)); - D(0) = (1.0 - poisson) * scale; - D(1) = poisson * scale; - D(2) = young / (2.0 + poisson2); - } - - /** - * Compute Elasticy Matrix. - * - * @param young Youngs modulus (stiffness) - * @param poisson Poissons ratio (compressability) - * @param D Upon return holds the isotropoc linear elasticity matrix. - */ - template - inline void compute_isotropic_elasticity_matix( - real_type const & young - , real_type const & poisson - , matrix_type & D - ) - { - assert(young>0 || !"compute_isotropic_elasticity_matix(): Young modulus must be positive"); - assert(poisson>0 || !"compute_isotropic_elasticity_matix(): Poisson ratio must be positive"); - assert(poisson<0.5 || !"compute_isotropic_elasticity_matix(): Poisson ratio must be less than a half"); - assert(D.size1()==6 || !"compute_isotropic_elasticity_matix(): D-matrix did not have 6 rows"); - assert(D.size2()==6 || !"compute_isotropic_elasticity_matix(): D-matrix did not have 6 columns"); - - typedef typename matrix_type::value_type value_type; - - value_type lambda = (poisson*young)/(( 1+poisson )*( 1- (2*poisson) )); //--- Lame modulus - value_type mu = young/(2*(1+poisson)); //--- Shear Modulus - value_type tmp = lambda+(2*mu); - - D(0,0) = tmp; D(0,1) = lambda; D(0,2) = lambda; D(0,3) = 0; D(0,4) = 0; D(0,5) = 0; - D(1,0) = lambda; D(1,1) = tmp; D(1,2) = lambda; D(1,3) = 0; D(1,4) = 0; D(1,5) = 0; - D(2,0) = lambda; D(2,1) = lambda; D(2,2) = tmp; D(2,3) = 0; D(2,4) = 0; D(2,5) = 0; - D(3,0) = 0; D(3,1) = 0; D(3,2) = 0; D(3,3) = mu; D(3,4) = 0; D(3,4) = 0; - D(4,0) = 0; D(4,1) = 0; D(4,2) = 0; D(4,3) = 0; D(4,4) = mu; D(4,5) = 0; - D(5,0) = 0; D(5,1) = 0; D(5,2) = 0; D(5,3) = 0; D(5,4) = 0; D(5,5) = mu; - } - - /** - * Alternative representation of isotropic elasticity matrix. - * - * - * @param young Youngs modulus (stiffness) - * @param poisson Poissons ratio (compressability) - * @param D00 - * @param D01 - * @param D33 - * - */ - template - inline void compute_isotropic_elasticity_vector( - real_type const & young - , real_type const & poisson - , real_type & D00 - , real_type & D01 - , real_type & D33 - ) - { - assert(young>0 || !"compute_isotropic_elasticity_vector(): Young modulus must be positive"); - assert(poisson>0 || !"compute_isotropic_elasticity_vector(): Poisson ratio must be positive"); - assert(poisson<0.5 || !"compute_isotropic_elasticity_vector(): Poisson ratio must be less than a half"); - - D01 = (poisson*young)/(( 1 + poisson )*( 1- (2*poisson) )); //--- Lame modulus - D33 = young/(2*(1+poisson)); //--- Shear Modulus - D00 = D01+(2*D33); - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_ISOTROPIC_ELASTICITY_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_ke.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_ke.h deleted file mode 100644 index a5f742af0..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_ke.h +++ /dev/null @@ -1,299 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_KE_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_KE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Compute Stiffness matrix of tetrahedral element. - * - * @param p0 - * @param p1 - * @param p2 - * @param p3 - * @param E Youngs modulus. - * @param nu Poisson ratio. - * @param Ke Upon return contains the computed stiffness values. - */ - template - inline void compute_Ke( - vector3_type const & p0, - vector3_type const & p1, - vector3_type const & p2, - vector3_type const & p3, - real_type const & E, - real_type const & nu, - matrix3x3_type Ke[4][4] - ) - { - using std::fabs; - - real_type d = p0(0); - real_type d4 = p0(1); - real_type d8 = p0(2); - real_type d1 = p1(0) - d; - real_type d5 = p1(1) - d4; - real_type d9 = p1(2) - d8; - real_type d2 = p2(0) - d; - real_type d6 = p2(1) - d4; - real_type d10 = p2(2) - d8; - real_type d3 = p3(0) - d; - real_type d7 = p3(1) - d4; - real_type d11 = p3(2) - d8; - real_type d12 = (d1 * d6 * d11 + d2 * d7 * d9 + d3 * d5 * d10) - d1 * d7 * d10 - d2 * d5 * d11 - d3 * d6 * d9; - real_type d13 = 1.0 / d12; - real_type d14 = fabs(d12 / 6.0); - vector3_type B[4]; - B[0].clear(); - B[1].clear(); - B[2].clear(); - B[3].clear(); - B[1](0) = (d10 * d7 - d6 * d11) * d13; - B[2](0) = (d5 * d11 - d9 * d7) * d13; - B[3](0) = (d9 * d6 - d5 * d10) * d13; - B[0](0) = -B[1](0) - B[2](0) - B[3](0); - B[1](1) = (d2 * d11 - d10 * d3) * d13; - B[2](1) = (d9 * d3 - d1 * d11) * d13; - B[3](1) = (d1 * d10 - d9 * d2) * d13; - B[0](1) = -B[1](1) - B[2](1) - B[3](1); - B[1](2) = (d6 * d3 - d2 * d7) * d13; - B[2](2) = (d1 * d7 - d5 * d3) * d13; - B[3](2) = (d5 * d2 - d1 * d6) * d13; - B[0](2) = -B[1](2) - B[2](2) - B[3](2); - real_type d15 = E / (1.0 + nu) / (1.0 - 2 * nu); - real_type d16 = (1.0 - nu) * d15; - real_type d17 = nu * d15; - real_type d18 = E / 2 / (1.0 + nu); - for(int i = 0; i < 4; ++i) - { - for(int j = 0; j < 4; ++j) - { - real_type d19 = B[i](0); - real_type d20 = B[i](1); - real_type d21 = B[i](2); - real_type d22 = B[j](0); - real_type d23 = B[j](1); - real_type d24 = B[j](2); - Ke[i][j](0,0) = d16 * d19 * d22 + d18 * (d20 * d23 + d21 * d24); - Ke[i][j](0,1) = d17 * d19 * d23 + d18 * (d20 * d22); - Ke[i][j](0,2) = d17 * d19 * d24 + d18 * (d21 * d22); - Ke[i][j](1,0) = d17 * d20 * d22 + d18 * (d19 * d23); - Ke[i][j](1,1) = d16 * d20 * d23 + d18 * (d19 * d22 + d21 * d24); - Ke[i][j](1,2) = d17 * d20 * d24 + d18 * (d21 * d23); - Ke[i][j](2,0) = d17 * d21 * d22 + d18 * (d19 * d24); - Ke[i][j](2,1) = d17 * d21 * d23 + d18 * (d20 * d24); - Ke[i][j](2,2) = d16 * d21 * d24 + d18 * (d20 * d23 + d19 * d22); - Ke[i][j] *= d14; - } - } - } - - /** - * Compute Stiffness matrix of tetrahedral element. - * - */ - template - inline void compute_Ke( - vector3_type * B, - vector3_type const& D, - real_type const & volume, - matrix3x3_type Ke[4][4] - ) - { - for (unsigned int i=0; i<4; ++i) - for (unsigned int j=i; j<4; ++j) - compute_Ke_ij( B[i], D, B[j], volume, Ke[i][j] ); - - for (unsigned int i=1; i<4; ++i) - for (unsigned int j=0; j - inline void compute_Ke_ij( - vector3_type const& Bi, - vector3_type const& D, - vector3_type const& Bj, - real_type const & volume, - matrix3x3_type & Ke_ij - ) - { - assert(Ke_ij.size1() == 3 || !"compute_Ke_ij(): Incompatible dimension"); - assert(Ke_ij.size2() == 3 || !"compute_Ke_ij(): Incompatible dimension"); - - // - // Calculate Ke_ij = Bi^T D Bj V - // - // The matrix Bi is given by: - // - // | bi 0 0 | - // | 0 ci 0 | - // Bi = | 0 0 di | - // | ci bi 0 | - // | di 0 bi | - // | 0 di ci | - // - // Similar for Bj. The elasticity matrix D is given by - // - // - // - - - - - // | 1-nu nu nu 0 0 0 | | D0 D1 D1 0 0 0 | - // young | nu 1-nu nu 0 0 0 | | D1 D0 D1 0 0 0 | - // D= ------------- | nu nu 1-nu 0 0 0 | | D1 D1 D0 0 0 0 | - // (1+nu)(1-2nu) | 0 0 0 (1-2nu)/2 0 0 | = | 0 0 0 D2 0 0 | - // | 0 0 0 0 (1-2nu)/2 0 | | 0 0 0 0 D2 0 | - // | 0 0 0 0 0 (1-2nu)/2 | | 0 0 0 0 0 D2 | - // - - - - - // - // - // We have something like - // - // Bi^T D Bj - // - // These matrices have a particular pattern, especially the B-matrices: - // - // - // |x 0 0|T - // |0 x 0| - // |0 0 x| - // | x 0 0 x 0 x| |x x 0| - // | 0 x 0 x x 0| = |0 x x| Bk(i,j)^T = Bk(j,i) - // | 0 0 x 0 x x| |x 0 x| - // - // And the product has the pattern - // - // - // | x x x 0 0 0 | |x 0 0| - // | x x x 0 0 0 | |0 x 0| - // | x x x 0 0 0 | |0 0 x| - // | x 0 0 x 0 x| | 0 0 0 x 0 0 | |x x 0| - // | 0 x 0 x x 0| | 0 0 0 0 x 0 | |0 x x| - // | 0 0 x 0 x x| | 0 0 0 0 0 x | |x 0 x| - // - // - // If we compute T = Bi^T E, then we get a matrix with pattern - // - // | x x x x 0 x| - // | x x x x x 0| - // | x x x 0 x x| - // - // Now computing Kij = T Bj, - // - // |x 0 0 | - // |0 x 0 | - // |0 0 x | - // |x x x | | x x x x 0 x| |x x 0 | - // |x x x | = | x x x x x 0| |0 x x | - // |x x x | | x x x 0 x x| |x 0 x | - // - // - // and exploiting that for isotropic materials we have, - // - // D(0,0) = D(1,1) = D(2,2) = D0 - // D(0,1) = D(1,2) = D(0,2) = D(1,0) = D(2,1) = D(2,0) = D1 - // D(3,3) = D(4,4) = D(5,5) = D2 - // - // Finally we do not need to store the B-matrices, observe that since - // - // b(0) = invC(1,0); b(1) = invC(1,1); b(2) = invC(1,2); b(3) = invC(1,3); - // c(0) = invC(2,0); c(1) = invC(2,1); c(2) = invC(2,2); c(3) = invC(2,3); - // d(0) = invC(3,0); d(1) = invC(3,1); d(2) = invC(3,2); d(3) = invC(3,3); - // - // and - // - // | bi 0 0 | - // | 0 ci 0 | - // Bi = | 0 0 di | - // | ci bi 0 | - // | 0 di ci | - // | di 0 bi | - // - // therefore - // - // | invC(1,i) 0 0 | - // | 0 invC(2,i) 0 | - // Bi = | 0 0 invC(3,i) | - // | invC(2,i) invC(1,i) 0 | - // | 0 invC(3,i) invC(2,i) | - // | invC(3,i) 0 invC(1,i) | - // - // Putting it all together and using matlab, we have, - // - //syms bi ci di real - //Bi = [ bi 0 0 ; 0 ci 0 ; 0 0 di ; ci bi 0 ; 0 di ci ; di 0 bi ] - //syms bj cj dj real - //Bj = [ bj 0 0 ; 0 cj 0 ; 0 0 dj ; cj bj 0 ; 0 dj cj ; dj 0 bj ] - //syms G H J real - //D = [ G H H 0 0 0; H G H 0 0 0; H H G 0 0 0; 0 0 0 J 0 0; 0 0 0 0 J 0; 0 0 0 0 0 J] - //T = Bi'*E - //Kij = T*Bj - //syms invC1i invC2i invC3i real; - //Kij = subs(Kij,bi,invC1i); - //Kij = subs(Kij,ci,invC2i); - //Kij = subs(Kij,di,invC3i); - //syms invC1j invC2j invC3j real; - //Kij = subs(Kij,bj,invC1j); - //Kij = subs(Kij,cj,invC2j); - //Kij = subs(Kij,dj,invC3j); - //Kij = collect(Kij,G) - //Kij = collect(Kij,H) - //Kij = collect(Kij,J) - // - // which yields - // - // - - - // | D0 bi bj + D2 (ci cj + di dj) D1 bi cj + D2 ci bj D1 bi dj + D2 di bj | - // Ke_ij = V | D1 ci bj + D2 bi cj D0 ci cj + D2 (bi bj + di dj) D1 ci dj + D2 di cj | - // | D1 di bj + D2 bi dj D1 di cj + D2 ci dj D0 di dj + D2 (bi bj + ci cj) | - // - - - real_type bi = Bi(0); - real_type ci = Bi(1); - real_type di = Bi(2); - - real_type bj = Bj(0); - real_type cj = Bj(1); - real_type dj = Bj(2); - - real_type D0 = D(0)*volume; - real_type D1 = D(1)*volume; - real_type D2 = D(2)*volume; - - Ke_ij(0,0) = D0 * bi * bj + D2 * (ci * cj + di * dj); - Ke_ij(0,1) = D1 * bi * cj + D2 * (ci * bj); - Ke_ij(0,2) = D1 * bi * dj + D2 * (di * bj); - - Ke_ij(1,0) = D1 * ci * bj + D2 * (bi * cj); - Ke_ij(1,1) = D0 * ci * cj + D2 * (bi * bj + di * dj); - Ke_ij(1,2) = D1 * ci * dj + D2 * (di * cj); - - Ke_ij(2,0) = D1 * di * bj + D2 * (bi * dj); - Ke_ij(2,1) = D1 * di * cj + D2 * (ci * dj); - Ke_ij(2,2) = D0 * di * dj + D2 * (ci * cj + bi * bj); - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_KE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_mass.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_mass.h deleted file mode 100644 index 1ff3cbd2e..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_mass.h +++ /dev/null @@ -1,175 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_MASS_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_MASS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - /** - * Compute Mass. - * - * Note: Volume should have been computed prior to invoking this - * function. Thus make sure that initialize_stiffness_elements have - * been invoked prior to this function. - * - * @param mesh - */ - template - inline void compute_mass(fem_mesh & mesh) - { - typedef typename fem_mesh::real_type real_type; - - //--- - //--- A mass matrix is a discrete representation of a continuous mass distribution. - //--- To compute our mass matrix for a tetrahedral element with linear shape - //--- functions we need the formula (pp. 266 in Cook) - //--- - //--- a!b!c!d! - //--- \int_V N_1^a N_2^b N_3^c N_4^d dV = 6V -------------------------- (**) - //--- (3 + a + b +c + d)! - //--- - //--- A consistent element mass matrix (pp. 376 Cook) is defined as - //--- - //--- m = \int_V \rho N^T N dV (***) - //--- - //--- This equation can be derived from work balance, the details of which is unimportant - //--- here (look Cook pp. 375-376 for details). - //--- Assumping \rho is constant over each tetrahedral element and using the linear shape - //--- functions the above definition (***) results in - //--- - //--- |N_1| - //--- m = \rho \int_V |N_2| |N_1 N_2 N_3 N_4| dV - //--- |N_3| - //--- |N_4| - //--- - //--- |(N_1 N_1) (N_1 N_2) (N_1 N_3) (N_1 N_4)| - //--- m = \rho \int_V |(N_2 N_1) (N_2 N_2) (N_2 N_3) (N_2 N_4)| dV - //--- |(N_3 N_1) (N_3 N_2) (N_3 N_3) (N_3 N_4)| - //--- |(N_4 N_1) (N_4 N_2) (N_4 N_3) (N_4 N_4)| - //--- - //--- by (**) - //--- - //--- | 2 1 1 1| - //--- m = \rho V/20 | 1 2 1 1| (****) - //--- | 1 1 2 1| - //--- | 1 1 1 2| - //--- - //--- V - //--- m_ij = \rho --- (1+delta_ij) - //--- 20 - //--- - //--- in 3D this means that for the tetrahedral element - //--- - //--- | 2 2 2 1 1 1 1 1 1 1 1 1 | - //--- | 2 2 2 1 1 1 1 1 1 1 1 1 | - //--- | 2 2 2 1 1 1 1 1 1 1 1 1 | - //--- | | - //--- | 1 1 1 2 2 2 1 1 1 1 1 1 | - //--- | 1 1 1 2 2 2 1 1 1 1 1 1 | - //--- V | 1 1 1 2 2 2 1 1 1 1 1 1 | - //--- Me = \rho --- | | - //--- 20 | 1 1 1 1 1 1 2 2 2 1 1 1 | - //--- | 1 1 1 1 1 1 2 2 2 1 1 1 | - //--- | 1 1 1 1 1 1 2 2 2 1 1 1 | - //--- | | - //--- | 1 1 1 1 1 1 1 1 1 2 2 2 | - //--- | 1 1 1 1 1 1 1 1 1 2 2 2 | - //--- | 1 1 1 1 1 1 1 1 1 2 2 2 | - //--- - //--- Notice that in order to obtain the global/system mass matrix an assembly similar to the - //--- stiffnees matrix assembly must be carried out. Further, the global M matrix will - //--- have the same sub-block pattern as the global K matrix. - //--- - //--- A consistent mass matrix is often not used in computer graphics. Instead and - //--- ad-hoc approach named ``lumped'' mass matrix is applied. - //--- The lumped mass matrix is obtained by placing particle masses at the nodes. - //--- This corresponds to shifting all the masses in the rows of (****) onto the - //--- diagonal. In 3D this yields the element mass matrix - //--- - //--- | 1 0 0 0 0 0 0 0 0 0 0 0 | - //--- | 0 1 0 0 0 0 0 0 0 0 0 0 | - //--- | 0 0 1 0 0 0 0 0 0 0 0 0 | - //--- | | - //--- | 0 0 0 1 0 0 0 0 0 0 0 0 | - //--- | 0 0 0 0 1 0 0 0 0 0 0 0 | - //--- V | 0 0 0 0 0 1 0 0 0 0 0 0 | - //--- Me = \rho --- | | - //--- 4 | 0 0 0 0 0 0 1 0 0 0 0 0 | - //--- | 0 0 0 0 0 0 0 1 0 0 0 0 | - //--- | 0 0 0 0 0 0 0 0 1 0 0 0 | - //--- | | - //--- | 0 0 0 0 0 0 0 0 0 1 0 0 | - //--- | 0 0 0 0 0 0 0 0 0 0 1 0 | - //--- | 0 0 0 0 0 0 0 0 0 0 0 1 | - //--- - //--- Thus a lumped mass matrix is diagonal whereas a consistent mass matrix - //--- is not. Observe that the global mass matrix would also diagonal and the - //--- assembly is simplified to an iteration over all tetrahedra, while - //--- incementing the nodal mass by one fourth of the tetrahedral mass. - //--- - //--- for each node n - //--- mass(n) = 0 - //--- next n - //--- for each tetrahedron e - //--- mass(n_i) += \rho_e Ve / 4 - //--- mass(n_j) += \rho_e Ve / 4 - //--- mass(n_k) += \rho_e Ve / 4 - //--- mass(n_m) += \rho_e Ve / 4 - //--- next e - //--- - //--- where n_i,n_j,n_k and n_m are the four nodes of the e'th tetrahedron. - //--- - //--- The advantage of lumping is less storage and higher performace. On the downside - //--- lumping introduces a discontinouty in the displacement field. - //--- - //--- Obrien.shen state that the errors in lumping is negligeble for small-size course - //--- meshes used in computer graphics. However, for finer meshes the errors becomes - //--- noticeable. - //--- - //--- There do exist other approaches for computing mass matrices, even mehtods which - //--- combine other methods. We refer the interested reader to Cook for more details. Here - //--- we have limited our selfes to the two most common methods. - //--- - //--- It is worthwhile to notice that under the reasonable assumptions that V and \rho are - //--- positive for all elements both the element mass matrices and the global mass matrices - //--- are symmetric positive definite matrices. - - for (int n=0;n::max(); - else - mesh.m_nodes[n].m_mass = 0; - } - - for (int t=0;tm_mass += amount; - mesh.m_tetrahedra[t].j()->m_mass += amount; - mesh.m_tetrahedra[t].k()->m_mass += amount; - mesh.m_tetrahedra[t].m()->m_mass += amount; - } - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_MASS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_volume.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_volume.h deleted file mode 100644 index 6b673774a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_compute_volume.h +++ /dev/null @@ -1,93 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_VOLUME_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_VOLUME_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Compute volume of tetrahedron. - * - * @param e10 edge vector from p0 to p1, i.e. e10 = p1-p0. - * @param e20 edge vector from p0 to p2, i.e. e20 = p2-p0. - * @param e30 edge vector from p0 to p3, i.e. e30 = p3-p0. - * - * @return The signed volume of the tetrahedra with nodes p0,p1,p2 and p3. - */ - template - inline typename vector3_type::value_type compute_volume(vector3_type const& e10, vector3_type const& e20, vector3_type const& e30) - { - typedef typename vector3_type::value_type real_type; - // Calculate the volume given by: - // | 1 1 1 1 | - // | e1x e2x e3x | | p0x p1x p2x p3x | - // 6V = | e1 \cdot (e2 x e3) | = | e1y e2y e3y | = 6V | p0y p1y p2y p3y | - // | e1z e2z e3z | | p0z p1z p2z p3z | - // - real_type sixV = e10*(e20 % e30); - return sixV / 6.0; - } - - /** - * Compute Tetrahedron Volume - * - * @param p0 - * @param p1 - * @param p2 - * @param p3 - * - * @return The signed volume of the tetrahedra with nodes p0,p1,p2 and p3. - */ - template - inline typename vector3_type::value_type compute_volume(vector3_type const & p0,vector3_type const & p1,vector3_type const & p2,vector3_type const & p3) - { - typedef typename vector3_type::value_type real_type; - - real_type d = p0(0); - real_type d4 = p0(1); - real_type d8 = p0(2); - real_type d1 = p1(0) - d; - real_type d5 = p1(1) - d4; - real_type d9 = p1(2) - d8; - real_type d2 = p2(0) - d; - real_type d6 = p2(1) - d4; - real_type d10 = p2(2) - d8; - real_type d3 = p3(0) - d; - real_type d7 = p3(1) - d4; - real_type d11 = p3(2) - d8; - real_type d12 = (d1 * d6 * d11 + d2 * d7 * d9 + d3 * d5 * d10) - d1 * d7 * d10 - d2 * d5 * d11 - d3 * d6 * d9; - return d12 / 6.0; - /* - ** From Zienkiewicz & Taylor p.637 - ** V = 1/6*det( 1 x0 y0 z0; 1 x1 y1 z1; 1 x2 y2 z2; 1 x3 y3 z3) - ** where x0 = n0->i; y0 = n0(1); ... - ** Calculated by Mathematica ;-) - */ - /* - return (p0(2)*p1(1)*p2(0) - p0(1)*p1(2)*p2(0) - p0(2)*p1(0)*p2(1) - + p0(0)*p1(2)*p2(1) + p0(1)*p1(0)*p2(2) - p0(0)*p1(1)*p2(2) - - p0(2)*p1(1)*p3(0) + p0(1)*p1(2)*p3(0) + p0(2)*p2(1)*p3(0) - - p1(2)*p2(1)*p3(0) - p0(1)*p2(2)*p3(0) + p1(1)*p2(2)*p3(0) - + p0(2)*p1(0)*p3(1) - p0(0)*p1(2)*p3(1) - p0(2)*p2(0)*p3(1) - + p1(2)*p2(0)*p3(1) + p0(0)*p2(2)*p3(1) - p1(0)*p2(2)*p3(1) - - p0(1)*p1(0)*p3(2) + p0(0)*p1(1)*p3(2) + p0(1)*p2(0)*p3(2) - - p1(1)*p2(0)*p3(2) - p0(0)*p2(1)*p3(2) + p1(0)*p2(1)*p3(2))/6.; - */ - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_COMPUTE_VOLUME_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_conjugate_gradients.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_conjugate_gradients.h deleted file mode 100644 index 684a927f3..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_conjugate_gradients.h +++ /dev/null @@ -1,141 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_CONJUGATE_GRADIENTS_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_CONJUGATE_GRADIENTS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#define n_i (&mesh.m_nodes[n]) -#define n_j (&mesh.m_nodes[j]) - - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Conjugate Gradient Solver. - * This solver has been hard-wired for a WarpT4Mesh to solve the equation - * - * A v = b - * - */ - template < typename fem_mesh > - inline void conjugate_gradients( - fem_mesh & mesh - , unsigned int min_iterations - , unsigned int max_iterations - ) - { - using std::fabs; - - typedef typename fem_mesh::real_type real_type; - typedef typename fem_mesh::vector3_type vector3_type; - typedef typename fem_mesh::matrix3x3_type matrix3x3_type; - typedef typename fem_mesh::node_type::matrix_iterator matrix_iterator; - - - real_type tiny = 1e-010; // TODO: Should be user controllable - real_type tolerence = 0.001; // TODO: Should be user controllable - - //--- r = b - A v - //--- p = r - for(int n=0;nm_fixed) - continue; - - n_i->m_residual = n_i->m_b; - - matrix_iterator Abegin = n_i->Abegin(); - matrix_iterator Aend = n_i->Aend(); - for (matrix_iterator A = Abegin; A != Aend;++A) - { - unsigned int j = A->first; - matrix3x3_type & A_ij = A->second; - vector3_type & v_j = n_j->m_velocity; - - n_i->m_residual -= A_ij * v_j; - } - n_i->m_prev = n_i->m_residual; - } - - for(unsigned int iteration = 0; iteration < max_iterations; ++iteration) - { - real_type d = 0.0; - real_type d2 = 0.0; - - //--- u = A p - //--- d = r*r - //--- d2 = p*u - - for(int n=0;nm_fixed) - continue; - - n_i->m_update.clear(); - - matrix_iterator Abegin = n_i->Abegin(); - matrix_iterator Aend = n_i->Aend(); - for (matrix_iterator A = Abegin; A != Aend;++A) - { - - unsigned int j = A->first; - matrix3x3_type & A_ij = A->second; - - n_i->m_update += A_ij * n_j->m_prev; - - } - d += n_i->m_residual * n_i->m_residual; - d2 += n_i->m_prev * n_i->m_update; - } - - if(fabs(d2) < tiny) - d2 = tiny; - - real_type d3 = d / d2; - real_type d1 = 0.0; - //--- v += p * d3 - //--- r -= u * d3 - //--- d1 = r*r - - for(int n=0;nm_fixed) - continue; - n_i->m_velocity += n_i->m_prev * d3; - n_i->m_residual -= n_i->m_update * d3; - d1 += n_i->m_residual * n_i->m_residual; - } - if(iteration >= min_iterations && d1 < tolerence) - break; - - if(fabs(d) < tiny) - d = tiny; - - real_type d4 = d1 / d; - //--- p = r + d4 * p - for(int n=0;nm_fixed) - continue; - n_i->m_prev = n_i->m_residual + n_i->m_prev * d4; - } - } - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_CONJUGATE_GRADIENTS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_dynamics_assembly.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_dynamics_assembly.h deleted file mode 100644 index da09007a0..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_dynamics_assembly.h +++ /dev/null @@ -1,104 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_DYNAMICS_ASSEMBLY_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_DYNAMICS_ASSEMBLY_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#define n_i (&mesh.m_nodes[n]) -#define n_j (&mesh.m_nodes[j]) - - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Setup dynamic equation. - * This is the equation of motion given as: - * - * - * A v^{i+1} = b - * - * - * where - * - - * A = M + \delta t C + \delta t^2 K - * b = M v^i - \delta t (K x^i + f_0 + f_plas - f_ext) - * - * In this implementation, the following holds: - * - * M is a diagonal matrix with diagonal elements given by m_mass. - * C is a diagonal matrix given by massCoef*M, which is Raleigh damping with stiffness coefficient zero. - * - * Also plastic forces, f_plas, is ignored. - * - * @param dt The time step, \delta t, which is about to be taken. - * @param mass_damping Coefficient for mass damping in the Raleigh damping equation. - * The coefficient \alpha in C = \alpha M + \beta K. In this implementation \beta = 0. - * - * - * - * - */ - template < typename fem_mesh, typename real_type > - inline void dynamics_assembly( - fem_mesh & mesh, - real_type const & mass_damping, - real_type const & dt - ) - { - typedef typename fem_mesh::vector3_type vector3_type; - typedef typename fem_mesh::matrix3x3_type matrix3x3_type; - typedef typename fem_mesh::node_type::matrix_iterator matrix_iterator; - - for (int n = 0;nidx(); - vector3_type & b_i = n_i->m_b; - real_type & m_i = n_i->m_mass; - - b_i.clear(); - - matrix_iterator Kbegin = n_i->Kbegin(); - matrix_iterator Kend = n_i->Kend(); - for (matrix_iterator K = Kbegin; K != Kend;++K) - { - unsigned int j = K->first; - matrix3x3_type & K_ij = K->second; - vector3_type & x_j = n_j->m_coord; - matrix3x3_type & A_ij = n_i->A(j); - - A_ij = K_ij * (dt*dt); - b_i -= K_ij * x_j; - if (i == j) - { - real_type c_i = mass_damping*m_i; - real_type tmp = m_i + dt*c_i; - A_ij(0,0) += tmp; A_ij(1,1) += tmp; A_ij(2,2) += tmp; - } - } - b_i -= n_i->m_f0; - b_i += n_i->m_f_external; - b_i *= dt; - b_i += n_i->m_velocity * m_i; - } - } - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_DYNAMICS_ASSEMBLY_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_init.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_init.h deleted file mode 100644 index 1d984e1d3..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_init.h +++ /dev/null @@ -1,84 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_INIT_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_INIT_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include -#include -#include -#include -#include - -namespace OpenTissue -{ - namespace fem - { - /** - * Initialize Data Structres. - * Should be invoked at start-up before any calls to animate_warping. - * - * This function assumes that mesh geometry have been set up prior - * to invokation (i.e. both world coord and orignial coord are initlized - * and the same). - * - * This method initialized the model with the same material parameters. End - * user could write his or her own initilization method replacing - * the steps where young modules, poisson ratio and densities are - * assigned to the model. - * - * @param mesh - * @param young Young Moduls, a value of 500000 seems work quite well. - * @param poisson Poisson ration, a value of 0.33 seems work quite well. - * @param density Mass density, a value of 1000 seems to work quite well. - * @param c_yield Plastic yield. - * @param c_creep Plastic creep. - * @param c_max Plastic max. - */ - template < typename fem_mesh,typename real_type > - inline void init( - fem_mesh & mesh, - real_type const & young, - real_type const & poisson, - real_type const & density, - real_type const & c_yield, - real_type const & c_creep, - real_type const & c_max - ) - { - assert(poisson>=0 || !"uniform_poisson() : Poisson ratio must be non-negative"); - assert(poisson<=0.5 || !"uniform_poisson() : Poisson ratio must not be larger than a half"); - assert(density>0 || !"uniform_density(): density must be positive"); - - //--- Assign material parameters - for (int t=0;t - -#include -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Initialize plasticity material parameters. - * - * Note: Initialize_stiffness_elements must have been invoked prior - * to calling this function. - * - * @param begin Iterator to first tetrahedron. - * @param end Iterator to one past last tetrahedron. - * @param c_yield Plastic yield. - * @param c_creep Plastic creep. - * @param c_max Plastic max. - */ - template < typename tetrahedron_type,typename real_type > - inline void initialize_plastic_single( - tetrahedron_type* T - , real_type const & c_yield - , real_type const & c_creep - , real_type const & c_max - ) - { - assert(c_yield>=0 || !"initialize_plastic(): yield must be non-negative"); - assert(c_creep>=0 || !"initialize_plastic(): creep must be non-negative"); - assert(c_max>=0 || !"initialize_plastic(): max must be non-negative"); - - T->m_yield = c_yield; - T->m_creep = c_creep; - T->m_max = c_max; - for(int i=0;i<6;++i) - T->m_plastic[i] = 0; - - compute_B(T->m_e10, T->m_e20, T->m_e30, T->m_V, T->m_B); - compute_isotropic_elasticity_vector (T->m_young, T->m_poisson, T->m_D); - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_INITIALIZE_PLASTIC_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_initialize_stiffness_elements.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_initialize_stiffness_elements.h deleted file mode 100644 index c3507c62b..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_initialize_stiffness_elements.h +++ /dev/null @@ -1,68 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_INITIALIZE_STIFFNESS_ELEMENTS_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_INITIALIZE_STIFFNESS_ELEMENTS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * - * - * NOTE: Material parameters (young modulus and poisson ratio) must have - * been set prior to invoking this function. - * - * @param begin - * @param end - */ - template < typename tetrahedron_type > - inline void initialize_stiffness_elements_single(tetrahedron_type* T) - { - { - T->m_e10 = T->j()->m_model_coord - T->i()->m_model_coord; - T->m_e20 = T->k()->m_model_coord - T->i()->m_model_coord; - T->m_e30 = T->m()->m_model_coord - T->i()->m_model_coord; - - T->m_V = compute_volume(T->m_e10, T->m_e20, T->m_e30); - - //T->m_V = compute_volume( - // T->i()->m_model_coord, - // T->j()->m_model_coord, - // T->k()->m_model_coord, - // T->m()->m_model_coord - // ); - - assert(T->m_V>0 || !"initialize_stiffness_elements(): Element with negative volume is encountered! Maybe you got a bad mesh?"); - - T->m_Re = math::diag(1.0); - - //compute_Ke(T->m_B, T->m_D, T->m_V, T->m_Ke); - compute_Ke( - T->node(0)->m_model_coord, - T->node(1)->m_model_coord, - T->node(2)->m_model_coord, - T->node(3)->m_model_coord, - T->m_young, T->m_poisson, - T->m_Ke - ); - } - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_INITIALIZE_STIFFNESS_ELEMENTS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_mesh.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_mesh.h deleted file mode 100644 index 5025f6533..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_mesh.h +++ /dev/null @@ -1,40 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_MESH_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_MESH_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include - -namespace OpenTissue -{ - namespace fem - { - - template - class Mesh - : public OpenTissue::t4mesh::T4Mesh< - math_types - , OpenTissue::fem::detail::NodeTraits - , OpenTissue::fem::detail::TetrahedronTraits - > - { - public: - - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - }; - - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_MESH_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_node_traits.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_node_traits.h deleted file mode 100644 index 3129e5c63..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_node_traits.h +++ /dev/null @@ -1,86 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_NODE_TRAITS_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_NODE_TRAITS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - template - class NodeTraits - { - public: - - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - - typedef typename std::map matrix_container; - typedef typename matrix_container::iterator matrix_iterator; - - public: - - NodeTraits(int i,int j) - { - } - matrix_container m_K_row; ///< Currently stored in a map container, key correspond to column and mapped value to 3-by-3 sub block. - matrix_container m_A_row; - vector3_type m_f0; - vector3_type m_b; - - bool m_fixed; ///< If the node is in-moveable this flag is set to true otherwise it is false. - - vector3_type m_model_coord; - vector3_type m_coord; ///< World coord - - vector3_type m_velocity; - real_type m_mass; - vector3_type m_f_external; - - // Needed by the ConjugateGradient method - vector3_type m_update; - vector3_type m_prev; - vector3_type m_residual; - - public: - - matrix_iterator Kbegin() - { - return m_K_row.begin(); - } - matrix_iterator Kend() { return m_K_row.end(); } - matrix_iterator Abegin() { return m_A_row.begin(); } - matrix_iterator Aend() { return m_A_row.end(); } - - matrix3x3_type & K(int const & column_idx) { - return m_K_row[column_idx]; - } - matrix3x3_type & A(int const & column_idx) { return m_A_row[column_idx]; } - - public: - - NodeTraits() - : m_fixed(false) - { - } - - }; - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_NODE_TRAITS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_position_update.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_position_update.h deleted file mode 100644 index 7765886d6..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_position_update.h +++ /dev/null @@ -1,41 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_POSITION_UPDATE_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_POSITION_UPDATE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Position Update. - * - * Note: Velocities must have been computed prior to invoking this function. - * @param mesh - * @param dt - */ - template < typename fem_mesh, typename real_type > - inline void position_update(fem_mesh & mesh, real_type const & dt) - { - for (int n=0;n - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - /** - * - */ - template - inline void reset_orientation_single(tetrahedron_type* T) - { - T->m_Re = math::diag(1.0); - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_RESET_ORIENTATION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_simulate.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_simulate.h deleted file mode 100644 index 15314d366..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_simulate.h +++ /dev/null @@ -1,131 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_SIMULATE_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_SIMULATE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include -#include -#include -#include -#include -#include -#include -#include - -namespace OpenTissue -{ - namespace fem - { - /** - * Simulate. - * Note external forces must have been computed prior to invocation. - * - * The dynamic equation has the following form (where u=x-x_0, and x' is derivative wrt. time) - * - * M x'' + Cx' + K (x-x_0) = f_ext - * - * This can be transformed to a system of 2x3n equations of first order derivative: - * - * x' = v - * M v' = - C v - K (x-x_0) + f_ext - * - * The semi-implicit Euler scheme approximates the above with: - * - * x^(i+1) = x^i + \delta t * v^(i+1) - * M v^(i+1) = M v^i + \delta t ( - C v^(i+1) - K ( x^i - x_0 ) + f^i_ext - * - * This is solved using implicit integration. - * - * @param mesh - * @param time_step - * @param use_stiffness_warping - */ - template < typename fem_mesh, typename real_type > - inline void simulate( - fem_mesh & mesh - , real_type const & time_step - , bool use_stiffness_warping, - real_type mass_damping = 2.0, - unsigned int min_iterations=20, - unsigned int max_iterations=20 - ) - { - // Some theory: - // - // - // Implicit discretization of - // - // M d^2x/dt^2 + C dx/dt + K (x-x0) = f_ext - // - // Evaluate at (i+1), and use d^2x/dt^2 = (v^{i+1} - v^i)/timestep and dx/dt = v^{i+1} - // - // M (v^{i+1} - v^i)/timestep + C v^{i+1} + K (x^{i+1}-x0) = f_ext - // - // and x^{i+1} = x^i + v^{i+1}*timestep - // - // M (v^{i+1} - v^i)/timestep + C v^{i+1} + K ( (x^i + v^{i+1}*timestep) -x0) = f_ext - // - // M (v^{i+1} - v^i)/timestep + C v^{i+1} + K*x^i + timestep*K*v^{i+1} - K x0 = f_ext - // - // M v^{i+1} - M v^i + timestep*C v^{i+1} + timestep*timestep*K*v^{i+1} = timestep * (f_ext - K*x^i + K x0) - // - // (M + timestep*C + timestep*timestep*K) v^{i+1} = M v^i + timestep * (f_ext - K*x^i + K x0) - // - // let f0 = -K x0 - // - // (M + timestep*C + timestep*timestep*K) v^{i+1} = M v^i + timestep * (f_ext - K*x^i -f0) - // - // (M + timestep*C + timestep*timestep*K) v^{i+1} = M v^i - timestep * (K*x^i + f0 - f_ext) - // - // so we need to solve A v^{i+1} = b for v^{i+1}, where - // - // A = (M + timestep*C + timestep*timestep*K) - // b = M v^i - timestep * (K*x^i + f0 - f_ext) - // - // afterwards we do a position update - // - // x^{i+1} = x^i + v^{i+1}*timestep - // - // Notice that a fully implicit scheme requres K^{i+1}, however for linear elastic materials K is constant. - - for (int n=0;n - -#define p_i (&T->m_owner->m_nodes[T->m_nodes[i]]) -#define p_j (&T->m_owner->m_nodes[T->m_nodes[j]]) - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Stiffness Matrix Assembly. - * Observe that prior to invocations of this method the rotations of all tetrahedra - * must have been setted. Also all stiffness assembly data should have been cleared - * prior to invocations by using the clear_stiffness_assembly method. - * - * - * From linear elastostatics we have - * - * K u = f - * - * where u is vertex displacements and f is the resulting nodal forces and K is the stiffness matrix. - * Using u = x - x0, where x is current position and x0 original position we have - * - * K (x - x0) = f - * K x - K x0 = f - * - * Introducing f0 = - K x0 as the force offset vectors we have - * - * f = K x + f0 - * - * The idea of stiffness warping is to rotate the x-position back into the - * original coordinate system in which K were original computed, then compute - * nodal forces in this frame and finally rotate teh nodal forces back to - * the current frame. - * - * Let R denote the current orientation, then R^{-1} rotates back to the - * orignal frame which means we have - * - * f = R K ( R^{-1} x - x0 ) - * f = R K R^{-1} x - R K x0 - * - * So with stiffness warping we have to compute - * - * K' = R K R^{-1} - * f0' = - R K x0 - * - * For n nodes the system stiffness matrix K' is a 3n X 3n symmetric and sparse matrix. - * It would be insane to actual allocated such a matrix instead the matrix is - * stored inside the nodes of the volume mesh. - * - * Each node stores a row of K' and the correspond entries of the f0' vector. - * - * That is the i'th node stores all non-zero 3-by-3 sub-block of the i'th row - * of the stiffness matrix and it also stores the i'th 3-dimensional subvector of f0 - * - * K' f0' - * j - * - . - - - - * | . | | | - * | . | | | - * i-> |......X....| |x| - * | . | | | - * | . | | | - * - . - - - - * - * - * Let M denote the set of all tetrahedral elements then the assembly - * of the warped stiffness matrix can be written as - * - * K'_ij = sum Re Ke_ij Re^T - * e \in M - * and - * i, j \in e - * - * And the assembly of the force offset vector - * - * f0'_i = sum - Re Ke_ij x0_j - * e \in M - * and - * i, j \in e - * - * - * Notice that this can be optimized if node i as a meber of the e'th element - * then the contribution to the above summation can be written as (recal - * the indices j,k and m denote the three ofther nodes of e): - * - * -Re Ke_ii x0_i - Re Ke_ij x0_j -Re Ke_im x0_m - Re Ke_ik x0_k - * -Re ( Ke_ii x0_i + Ke_ij x0_j + Ke_im x0_m + Ke_ik x0_k) - * - * which saves us a few matrix multiplications and we then finally have - * - * f0'_i = sum -Re ( Ke_ii x0_i + Ke_ij x0_j + Ke_im x0_m + Ke_ik x0_k) - * e \in M - * and - * i \in e - * - * Assuming that f0'_i is initially cleared to zero for all i. This result in the - * implementation strategy: - * - * for each element e do - * for each node i of e do - * tmp = 0 - * for each node j of e do - * tmp += Ke_ij * xo_j - * next j - * f0'_i -= Re*tmp - * next i - * next e - * - * Also the stiffness matrix can be optimized slightly by exploiting the symmetry property. - * The symmetry indicates that it is sufficient to only compute the upper triangular and - * diagonal parts. The lower triangular parts can be found simply be taking the transpose - * of the upper triangular parts. - * - * So the e'th tetrahedral element contributes with - * - * K'_ij += Re Ke_ij Re^{T} - * K'_ji += Re Ke_ji Re^{T} = ( Re Ke_ij Re^{T} )^T - * - * because Ke_ji = Ke_ij^T. Assuming that all K'_ij is initially cleared to zero this results - * in the implementation strategy: - * - * for each element e do - * for each node i of e do - * for each node j of e do - * if i >= j then - * tmp = Re Ke_ij Re^{T} - * K'_ij += tmp - * if j > i then - * K'_ji += trans(tmp) - * end if - * end if - * next j - * next i - * next e - * - * The two implementation strategies can now be combined into one, which - * is what we have implemented below. - * - * Note that if Re is initially set to the identity matrix, then the stiffness - * warping reduces to the traditional assembly of stiffness matrix (as it is - * used in linear elastostatics). - * - * - * If the i'th node is set to be fixed, this actually corresponds to - * letting K'_ii = identity and letting K'_ij and K'_ji be zero for all j not - * equal to i. This is known as a Direchlet boundary condition. However, we do - * not this during our assembly. Instead we assemble the K' matrix as though - * there were no fixed nodes. Later on when we use the K' matrix in computations - * such as K' x, we simply test whether x_j is fixed when it is multilpied by - * the j'th column of K' i.e. K'_*j. If so we simply do nothing!!! This is - * computatonally more tracjktable and it also allow us to more easily turn - * nodes fixed and un-fixed dynamically during animation. - * - * - * - * - * - * @param begin - * @param end - * - */ - template - inline void stiffness_assembly_single1(tetrahedron_type* T) - { - typedef typename tetrahedron_type::real_type real_type; - typedef typename tetrahedron_type::vector3_type vector3_type; - typedef typename tetrahedron_type::matrix3x3_type matrix3x3_type; - - { - matrix3x3_type & Re = T->m_Re; - for (int i = 0; i < 4; ++i) - { - vector3_type f; - f.clear(); - for (int j = 0; j < 4; ++j) - { - matrix3x3_type & Ke_ij = T->m_Ke[i][j]; - vector3_type & x0_j = p_j->m_model_coord; - - f += Ke_ij * x0_j; - if (j >= i) - { - - matrix3x3_type tmp = Re * Ke_ij * trans(Re); - - p_i->K(p_j->idx()) += tmp; - if (j > i) - p_j->K(p_i->idx()) += trans(tmp); - } - } - - p_i->m_f0 -= Re*f; - - } - } - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_STIFFNESS_ASSEMBLY_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_tetrahedron_traits.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_tetrahedron_traits.h deleted file mode 100644 index 72382fd13..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_tetrahedron_traits.h +++ /dev/null @@ -1,56 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_DEFORMATION_FEM_STIFFNESSWARPING_H -#define OPENTISSUE_DYNAMICS_DEFORMATION_FEM_STIFFNESSWARPING_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - template - class TetrahedronTraits - { - public: - - typedef typename math_types::real_type real_type; - typedef typename math_types::vector3_type vector3_type; - typedef typename math_types::matrix3x3_type matrix3x3_type; - - public: - - real_type m_young; - real_type m_poisson; - real_type m_density; - - matrix3x3_type m_Ke[4][4]; ///< Stiffness element matrix - matrix3x3_type m_Re; ///< Rotational warp of tetrahedron. - real_type m_V; ///< Volume of tetrahedron - - vector3_type m_e10; ///< edge from p0 to p1 - vector3_type m_e20; ///< edge from p0 to p2 - vector3_type m_e30; ///< edge from p0 to p3 - - //--- Stuff used exclusive by plastic effects - - vector3_type m_B[4]; ///< placeholders for Jacobian of shapefunctions: B = SN. - vector3_type m_D; ///< Elasticity Matrix in vector from - real_type m_plastic[6]; ///< Plastic strain tensor. - real_type m_yield; - real_type m_creep; - real_type m_max; - }; - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_DEFORMATION_FEM_STIFFNESSWARPING_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_density.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_density.h deleted file mode 100644 index e648056d4..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_density.h +++ /dev/null @@ -1,38 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_DENSITY_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_DENSITY_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - /** - * Set Uniform Density. - * - * @param begin - * @param end - * @param density - */ - template - inline void uniform_density(tetrahedron_iterator const & begin, tetrahedron_iterator const & end,real_type const & density) - { - assert(density>0 || !"uniform_density(): density must be positive"); - for (tetrahedron_iterator T = begin;T!=end;++T) - T->m_density = density; - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_DENSITY_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_poisson.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_poisson.h deleted file mode 100644 index 204d9cdd8..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_poisson.h +++ /dev/null @@ -1,44 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_POISSON_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_POISSON_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - /** - * - * @param begin - * @param end - * @param poisson - */ - template - inline void uniform_poisson( - tetrahedron_iterator const & begin - , tetrahedron_iterator const & end - , real_type const & poisson - ) - { - assert(poisson>=0 || !"uniform_poisson() : Poisson ratio must be non-negative"); - assert(poisson<=0.5 || !"uniform_poisson() : Poisson ratio must not be larger than a half"); - - for (tetrahedron_iterator T = begin;T!=end;++T) - T->m_poisson = poisson; - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_POISSON_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_young.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_young.h deleted file mode 100644 index 84ff51f1c..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_uniform_young.h +++ /dev/null @@ -1,43 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_YOUNG_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_YOUNG_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - /** - * - * @param begin - * @param end - * @param young - */ - template - inline void uniform_young( - tetrahedron_iterator const & begin - , tetrahedron_iterator const & end - ,real_type const & young - ) - { - assert(young>=0 || !"uniform_young(): Young modulus must not be negative"); - - for (tetrahedron_iterator T = begin;T!=end;++T) - T->m_young = young; - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_UNIFORM_YOUNG_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_update_orientation.h b/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_update_orientation.h deleted file mode 100644 index 3717133ed..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/dynamics/fem/fem_update_orientation.h +++ /dev/null @@ -1,222 +0,0 @@ -#ifndef OPENTISSUE_DYNAMICS_FEM_FEM_UPDATE_ORIENTATION_H -#define OPENTISSUE_DYNAMICS_FEM_FEM_UPDATE_ORIENTATION_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace fem - { - namespace detail - { - - /** - * - */ - template - inline void update_orientation_single(tetrahedron_type* T) - { - typedef typename tetrahedron_type::real_type real_type; - typedef typename tetrahedron_type::vector3_type vector3_type; - typedef typename tetrahedron_type::matrix3x3_type matrix3x3_type; - - { - real_type div6V = 1.0 / T->m_V*6.0; - //--- The derivation in the orignal paper on stiffness warping were stated as - //--- - //--- | n1^T | - //--- N = | n2^T | : WCS -> U - //--- | n3^T | - //--- - //--- | n1'^T | - //--- N' = | n2'^T | : WCS -> D - //--- | n3'^T | - //--- - //--- From which we have - //--- - //--- R = N' N^T - //--- - //--- This is valid under the assumption that the n-vectors form a orthonormal basis. In that - //--- paper the n-vectors were determined using a heuristic approach. Besides - //--- the rotation were computed on a per vertex basis not on a per-tetrahedron - //--- bases as we have outline above. - //--- - //--- - //--- Later Muller et. al. used barycentric coordinates to find the transform. We - //--- will here go into details on this method. Let the deformed corners be q0, q1, - //--- q2, and q3 and the undeformed corners p0, p1, p2,and p3. Looking at some - //--- point p = [x y z 1]^T inside the undeformed tetrahedron this can be written - //--- - //--- | w0 | - //--- p = | p0 p1 p2 p3 | | w1 | = P w (*1) - //--- | 1 1 1 1 | | w2 | - //--- | w3 | - //--- - //--- The same point in the deformed tetrahedron has the same barycentric coordinates - //--- which mean - //--- - //--- | w0 | - //--- q = | q0 q1 q2 q3 | | w1 | = Q w (*2) - //--- | 1 1 1 1 | | w2 | - //--- | w3 | - //--- - //--- We can now use (*1) to solve for w and insert this into (*2), this yields - //--- - //--- q = Q P^{-1} p - //--- - //--- The matirx Q P^{-1} transforms p into q. Due to P and Q having their fourth rows - //--- equal to 1 it can be shown that this matrix have the block structure - //--- - //--- Q P^{-1} = | R t | (*3) - //--- | 0^T 1 | - //--- - //--- Which we recognize as a transformation matrix of homegeneous coordinates. The t vector - //--- gives the translation, the R matrix includes, scaling, shearing and rotation. - //--- - //--- We thus need to extract the rotational information from this R matrix. In their - //--- paper Mueller et. al. suggest using Polar Decompostions (cite Shoemake and Duff; Etzmuss). - //--- However, a simpler although more imprecise approach would simply be to apply a Grahram-Schimdt - //--- orthonormalization to transform R into an orthonormal matrix. This seems to work quite well - //--- in practice. We have not observed any visual difference in using polar decomposition or - //--- orthonormalization. - //--- - //--- Now for some optimizations. Since we are only interested in the R part of (*3) we can - //--- compute this more efficiently exploiting the fact that barycentric coordinates sum - //--- up to one. If we substitute w0 = 1 - w1 - w2 - w3 in (*1) and (*2) we can throw away - //--- the fourth rows since they simply state 1=1, which is trivially true. - //--- - //--- | 1-w1-w2-w3 | - //--- p = | p0 p1 p2 p3 | | w1 | - //--- | w2 | - //--- | w3 | - //--- - //--- Which is - //--- - //--- | 1 | - //--- p = | p0 (p1-p0) (p2-p0) (p3-p0) | | w1 | - //--- | w2 | - //--- | w3 | - //--- - //--- We can move the first column over on the left hand side - //--- - //--- | w1 | - //--- (p-p0) = | (p1-p0) (p2-p0) (p3-p0) | | w2 | - //--- | w3 | - //--- - //--- Introducing e10 = p1-p0, e20 = p2-p0, e30 = p3-p0, and E = [e10 e20 e30 ] we have - //--- - //--- w1 - //--- (p-p0) = E w2 (*5) - //--- w3 - //--- - //--- Similar for *(2) we have - //--- - //--- w1 - //--- (q-q0) = E' w2 (*6) - //--- w3 - //--- - //--- Where E' = [e10' e20' e3'] and e10' = q1-q0, e20' = q2-q0, e30' = q3-q0. Now - //--- inverting (*5) and insertion into (*6) yields - //--- - //--- (q-q0) = E' E^{-1} (p-p0) - //--- - //--- By comparison with (*3) we see that - //--- - //--- R = E' E^{-1} - //--- - //--- Using Cramers rule the inverse of E can be written as - //--- - //--- | (e2 x e3)^T | - //--- E^{-1} = 1/6V | (e3 x e1)^T | - //--- | (e1 x e2)^T | - //--- - //--- This can easily be confirmed by straigthforward computation - //--- - //--- | e1 \cdot (e2 x e3) e2 \cdot (e2 x e3) e3 \cdot (e2 x e3) | - //--- E^{-1} E = 1/6v | e1 \cdot (e3 x e1) e2 \cdot (e3 x e1) e3 \cdot (e3 x e1) | - //--- | e1 \cdot (e1 x e2) e2 \cdot (e1 x e2) e3 \cdot (e1 x e2) | - //--- - //--- | 6V 0 0 | - //--- = 1/6V | 0 6V 0 | = I - //--- | 0 0 6V | - //--- - //--- Using the notation - //--- - //--- n1 = e2 x e3 / 6V - //--- n2 = e3 x e1 / 6V - //--- n3 = e1 x e2 / 6V - //--- - //--- we write - //--- - //--- | n1^T | - //--- E^{-1} = | n2^T | - //--- | n3^T | - //--- - //--- And we end up with - //--- - //--- | n1^T | - //--- R = [e10' e20' e30'] | n2^T | - //--- | n3^T | - //--- - //--- Observe that E' is very in-expensive to compute and all non-primed quantities (n1, n2, n3) can - //--- be precomputed and stored on a per tetrahedron basis if there is enough memory available. Even - //--- in case where memory is not available n1, n2 and n3 are quite cheap to compute. - //--- - - real_type e1x = T->m_e10(0); - real_type e1y = T->m_e10(1); - real_type e1z = T->m_e10(2); - real_type e2x = T->m_e20(0); - real_type e2y = T->m_e20(1); - real_type e2z = T->m_e20(2); - real_type e3x = T->m_e30(0); - real_type e3y = T->m_e30(1); - real_type e3z = T->m_e30(2); - real_type n1x = (e2y * e3z - e3y * e2z) * div6V; - real_type n1y = (e3x * e2z - e2x * e3z) * div6V; - real_type n1z = (e2x * e3y - e3x * e2y) * div6V; - real_type n2x = (e1z * e3y - e1y * e3z) * div6V; - real_type n2y = (e1x * e3z - e1z * e3x) * div6V; - real_type n2z = (e1y * e3x - e1x * e3y) * div6V; - real_type n3x = (e1y * e2z - e1z * e2y) * div6V; - real_type n3y = (e1z * e2x - e1x * e2z) * div6V; - real_type n3z = (e1x * e2y - e1y * e2x) * div6V; - const vector3_type & p0 = T->m_owner->m_nodes[T->m_nodes[0]].m_coord; - const vector3_type & p1 = T->m_owner->m_nodes[T->m_nodes[1]].m_coord; - const vector3_type & p2 = T->m_owner->m_nodes[T->m_nodes[2]].m_coord; - const vector3_type & p3 = T->m_owner->m_nodes[T->m_nodes[3]].m_coord; - - e1x = p1(0) - p0(0); - e1y = p1(1) - p0(1); - e1z = p1(2) - p0(2); - e2x = p2(0) - p0(0); - e2y = p2(1) - p0(1); - e2z = p2(2) - p0(2); - e3x = p3(0) - p0(0); - e3y = p3(1) - p0(1); - e3z = p3(2) - p0(2); - T->m_Re(0,0) = e1x * n1x + e2x * n2x + e3x * n3x; T->m_Re(0,1) = e1x * n1y + e2x * n2y + e3x * n3y; T->m_Re(0,2) = e1x * n1z + e2x * n2z + e3x * n3z; - T->m_Re(1,0) = e1y * n1x + e2y * n2x + e3y * n3x; T->m_Re(1,1) = e1y * n1y + e2y * n2y + e3y * n3y; T->m_Re(1,2) = e1y * n1z + e2y * n2z + e3y * n3z; - T->m_Re(2,0) = e1z * n1x + e2z * n2x + e3z * n3x; T->m_Re(2,1) = e1z * n1y + e2z * n2y + e3z * n3y; T->m_Re(2,2) = e1z * n1z + e2z * n2z + e3z * n3z; - - T->m_Re = ortonormalize(T->m_Re); - - //matrix3x3_type M = T->m_Re,S; - //OpenTissue::PolarDecomposition3x3 decomp; - //decomp.eigen(M, T->m_Re, S);//--- Etzmuss-style - //decomp.newton(M, T->m_Re );//--- Shoemake-Duff-style - } - } - - } // namespace detail - } // namespace fem -} // namespace OpenTissue - -//OPENTISSUE_DYNAMICS_FEM_FEM_UPDATE_ORIENTATION_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_class_id.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_class_id.h deleted file mode 100644 index e3f868bee..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_class_id.h +++ /dev/null @@ -1,162 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_CLASS_ID_H -#define OPENTISSUE_UTILITY_UTILITY_CLASS_ID_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace utility - { - - /** @internal ID Generator class. - * This class encapsulates the generation of unique IDs as used by ClassID. - * - * @warning - * This class should never be used directly. - */ - class BaseIDGenerator - { - - template < class T > - friend class ClassID; - - private: - - BaseIDGenerator(); // Disable default constructor - - /** ID generation method - * - * @return - * An increasing unique ID. - */ - static size_t const generate_id() - { - static size_t id = 0; - return id++; - } - - }; - - - /** The Class ID interface. - */ - class ClassIDInterface - { - public: - - /** Destructor - */ - virtual ~ClassIDInterface(){} - - /** Query the class ID. - * - * @return - * The object's class ID - */ - virtual size_t const class_id() const = 0; - }; - - - - /** - * CRTP Implementation of the ClassIDInterface. - * - * Usage: - * To enable class IDs for a custom class, simply inherite this class giving - * itself as the template argument. - * - * Example: - * \code - * class SomeClass: - * public ClassID - * { ... }; - * \endcode - * - * @tparam T - * The deriving class - */ - template < class T > - class ClassID - : virtual public ClassIDInterface - { - public: - - /** - * Query the object ID. - * - * @return - * The object ID - */ - static size_t const id() - { - static size_t my_id = BaseIDGenerator::generate_id(); - return my_id; - } - - /** - */ - virtual size_t const class_id() const - { - return id(); - } - }; - - /** Helper class for solving ambiguousity between class IDs. - * This class enables inheritance from another class, which already have a class ID. - * - * Problem: - * \code - * class SomeBase: - * public ClassID - * { ... }; - * class SomeClass: - * public SomeBase - * , public ClassID - * { ... }; // Error: id() and class_id() will be ambiguous - * \endcode - * - * Solution: - * \code - * class SomeClass: - * public ClassIDCompositor - * { ... }; - * \endcode - * - * @tparam Base - * Some base class, which will also be inherited - * @tparam Self - * The deriving class - */ - template < class Base, class Self > - class ClassIDCompositor - : public Base - , public ClassID - { - public: - - /** - */ - static size_t const id() - { - return ClassID::id(); - } - - /** - */ - virtual size_t const class_id() const - { - return ClassID::id(); - } - }; - - } // namespace utility -} // namespace OpenTissue -// OPENTISSUE_UTILITY_UTILITY_CLASS_ID_H -#endif - diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_empty_traits.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_empty_traits.h deleted file mode 100644 index bc0c4506a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_empty_traits.h +++ /dev/null @@ -1,30 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_EMPTY_TRAITS_H -#define OPENTISSUE_UTILITY_UTILITY_EMPTY_TRAITS_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// - -namespace OpenTissue -{ - namespace utility - { - /** - * Empty Traits Class. - * This is basically an empty class it usage - * is intended as a default argument for the - * many algorithms and data structures where - * the default traits is simply the ``empty'' - * traits. - * - */ - class EmptyTraits { }; - - } -} - -// OPENTISSUE_UTILITY_UTILITY_EMPTY_TRAITS_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_fps_counter.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_fps_counter.h deleted file mode 100644 index 29a8caa1b..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_fps_counter.h +++ /dev/null @@ -1,73 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_FPS_COUNTER_H -#define OPENTISSUE_UTILITY_UTILITY_FPS_COUNTER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace utility - { - /* - * Frame Per Second (FPS) Counter - */ - template - class FPSCounter - { - public: - FPSCounter() - : m_fps(0) - , m_fpscnt(0) - , m_time(0.) - { - m_hrc.start(); - } - - /* - * /return the last known fps - */ - unsigned long operator()() const - { - return m_fps; - - } - - /* - * /return true if 1 sec has passed - */ - bool frame() - { - m_hrc.stop(); - m_time += m_hrc(); - m_fpscnt++; - if (m_time >= 1.) { - // m_time -= 1.; - m_time = 0.; - m_fps = m_fpscnt; - m_fpscnt = 0; - } - m_hrc.start(); - return 0 == m_fpscnt; - } - - private: - - Timer m_hrc; - unsigned long m_fps; - unsigned long m_fpscnt; - double m_time; - }; - - } //End of namespace utility - -} //End of namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_FPS_COUNTER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_get_environment_variable.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_get_environment_variable.h deleted file mode 100644 index 3159fe267..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_get_environment_variable.h +++ /dev/null @@ -1,44 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_GET_ENVIRONMENT_VARIABLE_H -#define OPENTISSUE_UTILITY_UTILITY_GET_ENVIRONMENT_VARIABLE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -#include //--- For getenv -#include -#include - -namespace OpenTissue -{ - namespace utility - { - - /** - * Retrieve Value of Environment Variable. - * If environment variable can not be found then a std::logic_error warning is thrown. - * - * @param A string containing the name of the environment - * variable. Example: "OPENTISSUE". - * @return A string containing the value. - */ - inline std::string get_environment_variable(std::string const & name) - { - char * value = getenv( name.c_str() ); - if(value) - return std::string( value ); - throw std::logic_error("get_environment_variable(): the specified environment variable was not set"); - } - - } // namespace utility - -} // namespace OpenTissue - -//OPENTISSUE_UTILITY_UTILITY_GET_ENVIRONMENT_VARIABLE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_get_system_memory_info.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_get_system_memory_info.h deleted file mode 100644 index 41609942e..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_get_system_memory_info.h +++ /dev/null @@ -1,108 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_GET_SYSTEM_MEMORY_INFO_H -#define OPENTISSUE_UTILITY_UTILITY_GET_SYSTEM_MEMORY_INFO_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#ifdef WIN32 -# define NOMINMAX -# define WIN32_LEAN_AND_MEAN -# include -# undef WIN32_LEAN_AND_MEAN -# undef NOMINMAX -#endif - -namespace OpenTissue -{ - namespace utility - { - -#ifdef WIN32 - - double get_memory_usage() - { - typedef double real_type; - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - real_type memory_usage = statex.dwMemoryLoad; - return memory_usage; - } - - unsigned int get_total_physical_memory_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int total_physical_memory_in_bytes = statex.ullTotalPhys; - return total_physical_memory_in_bytes; - } - - unsigned int get_free_physical_memory_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int free_physical_memory_in_bytes = statex.ullAvailPhys; - return free_physical_memory_in_bytes; - } - - unsigned int get_total_page_file_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int total_page_file_in_bytes = statex.ullTotalPageFile; - return total_page_file_in_bytes; - } - - unsigned int get_free_page_file_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int free_page_file_in_bytes = statex.ullAvailPageFile; - return free_page_file_in_bytes; - } - - unsigned int get_total_virtual_memory_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int total_virtual_memory = statex.ullTotalVirtual; - return total_virtual_memory; - } - - unsigned int get_free_virtual_memory_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int free_virtual_memory_in_bytes = statex.ullAvailVirtual; - return free_virtual_memory; - } - - unsigned int get_free_extended_memory_in_bytes() - { - MEMORYSTATUSEX statex; - statex.dwLength = sizeof (statex); - GlobalMemoryStatusEx (&statex); - unsigned int free_extended_memory_in_bytes = statex.ullAvailExtendedVirtual; - return free_extended_memory_in_bytes; - } - - -#endif - - } //End of namespace utility - -} //End of namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_GET_SYSTEM_MEMORY_INFO_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_greater_ptr.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_greater_ptr.h deleted file mode 100644 index 9b7c6c405..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_greater_ptr.h +++ /dev/null @@ -1,33 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_GREATER_PTR_H -#define OPENTISSUE_UTILITY_UTILITY_GREATER_PTR_H -// -// OpenTissue, A toolbox for physical based simulation and animation. -// Copyright (C) 2007 Department of Computer Science, University of Copenhagen -// -#include - -#include - -namespace OpenTissue -{ - namespace utility - { - - /** - * Greater Than Test. - * This is used for doing a greater than test on data - * structures containing pointers to data and not instances. - */ - template - struct greater_ptr - : public std::binary_function - { - bool operator()(const T& x, const T& y) const { return (*x)>(*y); } - }; - - } //End of namespace utility - -} //End of namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_GREATER_PTR_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_identifier.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_identifier.h deleted file mode 100644 index b1ebbc75a..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_identifier.h +++ /dev/null @@ -1,100 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_IDENTIFIER_H -#define OPENTISSUE_UTILITY_UTILITY_IDENTIFIER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#include - -namespace OpenTissue -{ - namespace utility - { - - /** - * Identifier Class. - * This is an utility class that is supposed to make it easier to create - * new objects with unique identifiers. The idea is to simply inherit the - * new object class from the identifier class. - * - * At construction-time the class tries to generate a new unique - * identifier. Hereafter it is the users responsibility not to mess - * up the id-name string. However, end-users can always be sure that - * the index value provided by the identifier class is unique. - */ - class Identifier - { - protected: - - std::string m_ID; ///< An Identifier string. - size_t m_index; ///< Unique object index. - - public: - - Identifier() - { - generate_new_index(); - m_ID = "ID" + m_index; - } - - virtual ~Identifier(){} - - public: - - Identifier(Identifier const & id) - { - m_ID = id.m_ID; - m_index = id.m_index; - } - - Identifier & operator=(Identifier const & id) - { - m_ID = id.m_ID; - m_index = id.m_index; - return *this; - } - - bool operator==(Identifier const & id) const { return (m_index == id.m_index); } - - bool operator!=(Identifier const & id) const { return !(*this == id); } - - public: - - void set_id(std::string const & id) { m_ID = id; } - - std::string const & get_id() const { return m_ID; } - - size_t get_index() const {return m_index; } - - protected: - - /** - * Static Member Not Initialized in Header Trick (smnih) - * - * This way we avoid having a - * - * static size_t m_next_idx - * - * member variable which must be initialized in a - * source file. - */ - void generate_new_index() - { - static size_t next_index = 0; - m_index = next_index; - ++next_index; - } - - }; - - } // namespace utility - -} // namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_IDENTIFIER_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_less_ptr.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_less_ptr.h deleted file mode 100644 index eab2753b9..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_less_ptr.h +++ /dev/null @@ -1,33 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_LESS_PTR_H -#define OPENTISSUE_UTILITY_UTILITY_LESS_PTR_H -// -// OpenTissue, A toolbox for physical based simulation and animation. -// Copyright (C) 2007 Department of Computer Science, University of Copenhagen -// -#include - -#include - -namespace OpenTissue -{ - namespace utility - { - - /** - * Less Than Test. - * This is used for doing a less than test on data - * structures containing pointers to data and not instances. - */ - template - struct less_ptr - : public std::binary_function - { - bool operator()(const T& x, const T& y) const { return (*x)<(*y); } - }; - - } //End of namespace utility - -} //End of namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_LESS_PTR_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_material.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_material.h deleted file mode 100644 index b1ad90852..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_material.h +++ /dev/null @@ -1,108 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_MATERIAL_H -#define OPENTISSUE_UTILITY_UTILITY_MATERIAL_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace utility - { - - /** - * A Material. - * This class encapsulates openGL material parameters. - */ - class Material - { - protected: - - float m_ambient[ 4 ]; ///< The ambient color rgba. - float m_diffuse[ 4 ]; ///< The diffuse color rgba. - float m_specular[ 4 ]; ///< The specular color rgba. - float m_shininess; ///< The shininess of this material 0..180. - - public: - - Material() - : m_shininess(128) - { - set_default(); - } - - void ambient( float const & red, float const & green, float const & blue, float const & alpha = 1.0f ) - { - m_ambient[ 0 ] = red; - m_ambient[ 1 ] = green; - m_ambient[ 2 ] = blue; - m_ambient[ 3 ] = alpha; - } - - void diffuse( float const & red, float const & green, float const & blue, float const & alpha = 1.0f ) - { - m_diffuse[ 0 ] = red; - m_diffuse[ 1 ] = green; - m_diffuse[ 2 ] = blue; - m_diffuse[ 3 ] = alpha; - } - - void specular( float const & red, float const & green, float const & blue, float const & alpha = 1.0f ) - { - m_specular[ 0 ] = red; - m_specular[ 1 ] = green; - m_specular[ 2 ] = blue; - m_specular[ 3 ] = alpha; - } - - void shininess( float const & value ) - { - m_shininess = value; - } - - /* - void use() - { - if ( glIsEnabled( GL_COLOR_MATERIAL ) || !glIsEnabled( GL_LIGHTING ) ) - { - glColor4f( m_diffuse[ 0 ], m_diffuse[ 1 ], m_diffuse[ 2 ], m_diffuse[ 3 ] ); - } - else - { - glMaterialfv( GL_FRONT_AND_BACK, GL_AMBIENT, m_ambient ); - glMaterialfv( GL_FRONT_AND_BACK, GL_DIFFUSE, m_diffuse ); - glMaterialfv( GL_FRONT_AND_BACK, GL_SPECULAR, m_specular ); - glMaterialfv( GL_FRONT_AND_BACK, GL_SHININESS, &m_shininess ); - } - } - */ - - void set_default() - { - m_ambient[ 0 ] = 0.1f; - m_ambient[ 1 ] = 0.1f; - m_ambient[ 2 ] = 0.0f; - m_ambient[ 3 ] = 1.0f; - m_diffuse[ 0 ] = 0.6f; - m_diffuse[ 1 ] = 0.6f; - m_diffuse[ 2 ] = 0.1f; - m_diffuse[ 3 ] = 1.0f; - m_specular[ 0 ] = 1.0f; - m_specular[ 1 ] = 1.0f; - m_specular[ 2 ] = 0.75f; - m_specular[ 3 ] = 1.0f; - m_shininess = 128; - } - - }; - - } // namespace utility - -} // namespace OpenTissue - -//OPENTISSUE_UTILITY_UTILITY_MATERIAL_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_pop_boost_filter.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_pop_boost_filter.h deleted file mode 100644 index 74df18a09..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_pop_boost_filter.h +++ /dev/null @@ -1,10 +0,0 @@ -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#if (_MSC_VER >= 1200) -# pragma warning(pop) -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_push_boost_filter.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_push_boost_filter.h deleted file mode 100644 index ba9a26e42..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_push_boost_filter.h +++ /dev/null @@ -1,23 +0,0 @@ -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#if (_MSC_VER >= 1200) -# pragma warning(push) -//# pragma warning(disable: 99) // 'identifier' : type name first seen using 'objecttype1' now seen using 'objecttype2' -//# pragma warning(disable: 100) // 'identifier' : unreferenced formal parameter -//# pragma warning(disable: 127) // conditional expression is constant -//# pragma warning(disable: 217) // 'operator' : member template functions cannot be used for copy-assignment or copy-construction -# pragma warning(disable: 265) // 'class' : class has virtual functions, but destructor is not virtual -//# pragma warning(disable: 267) // 'var' : conversion from 'size_t' to 'type', possible loss of data -//# pragma warning(disable: 347) // behavior change: 'function template' is called instead of 'function' -//# pragma warning(disable: 390) // ';' : empty controlled statement found; is this the intent? -//# pragma warning(disable: 503) // 'identifier' : decorated name length exceeded, name was truncated -//# pragma warning(disable: 511) // 'class' : copy constructor could not be generated -//# pragma warning(disable: 512) // 'class' : assignment operator could not be generated -//# pragma warning(disable: 701) // Potentially uninitialized local variable 'name' used -//# pragma warning(disable: 4355) // 'this' : used in base member initializer list -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_qhull.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_qhull.h deleted file mode 100644 index f48f343a3..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_qhull.h +++ /dev/null @@ -1,45 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_QHULL_H -#define OPENTISSUE_UTILITY_UTILITY_QHULL_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - - ////////////////////////////////////////////////////////////////// - // - // This is a bit tricky, I cant just include qhull_a.h as - // QHull advices, because MVC complains about math.h which - // is included "indirectly by qhull_a.h - // - // Hopefully furture releases of QHull will allow me to - // just write: - // - // extern "C" - // { - // #include - // } - // -#if defined(__cplusplus) - extern "C" - { -#endif -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#if defined(__cplusplus) - } -#endif - -//OPENTISSUE_UTILITY_UTILITY_QHULL_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_runtime_type.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_runtime_type.h deleted file mode 100644 index 7dfe41c2c..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_runtime_type.h +++ /dev/null @@ -1,37 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_RUNTIME_TYPE_H -#define OPENTISSUE_UTILITY_UTILITY_RUNTIME_TYPE_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -namespace OpenTissue -{ - namespace utility - { - /** - * Runtime type. - * great for passing non-integral values as template arguments. - */ - template < typename Type > - struct RuntimeType - { - typedef Type type; - RuntimeType(){} - RuntimeType(const RuntimeType& rhs):m_value(rhs.m_value){} - RuntimeType& operator = (const type& rhs) {m_value=rhs; return *this;} - operator const type& () const {return m_value;} - protected: - type m_value; - }; - - } // namespace utility - -} // namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_RUNTIME_TYPE_H -#endif diff --git a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_timer.h b/Demos3/FiniteElementMethod/OpenTissue/utility/utility_timer.h deleted file mode 100644 index 69b07c1cc..000000000 --- a/Demos3/FiniteElementMethod/OpenTissue/utility/utility_timer.h +++ /dev/null @@ -1,102 +0,0 @@ -#ifndef OPENTISSUE_UTILITY_UTILITY_TIMER_H -#define OPENTISSUE_UTILITY_UTILITY_TIMER_H -// -// OpenTissue Template Library -// - A generic toolbox for physics-based modeling and simulation. -// Copyright (C) 2008 Department of Computer Science, University of Copenhagen. -// -// OTTL is licensed under zlib: http://opensource.org/licenses/zlib-license.php -// -#include - -#ifdef WIN32 -# define NOMINMAX -# define WIN32_LEAN_AND_MEAN -# include -# undef WIN32_LEAN_AND_MEAN -# undef NOMINMAX -#else -# include -#endif - -#include - -namespace OpenTissue -{ - namespace utility - { - - /** - * High Resoultion Timer. - * Based on http://www-106.ibm.com/developerworks/library/l-rt1/ - * - * RunTime: High-performance programming techniques on Linux and Windows 2000 - * Setting up timing routines - * by - * Edward G. Bradford (egb@us.ibm.com) - * Senior Programmer, IBM - * 01 Apr 2001 - * - * Example usage (We recommand doubles): - * - * Timer timer; - * - * timer.start() - * ... - * timer.stop() - * std::cout << "It took " << timer() << " seconds to do it" << std::endl; - */ - template - class Timer - { -#ifdef WIN32 - private: - LARGE_INTEGER m_start; ///< - LARGE_INTEGER m_end; ///< - LARGE_INTEGER m_freq; ///< - bool m_first; ///< - public: - Timer():m_first(true){} - public: - void start() - { - if(m_first) - { - QueryPerformanceFrequency(&m_freq); - m_first = false; - } - QueryPerformanceCounter(&m_start); - } - void stop() - { - QueryPerformanceCounter(&m_end); - } - real_type operator()()const - { - real_type end = static_cast(m_end.QuadPart); - real_type start = static_cast(m_start.QuadPart); - real_type freq = static_cast(m_freq.QuadPart); - return (end - start)/ freq; - } -#else - private: - struct timeval m_start; ///< - struct timeval m_end; ///< - struct timezone m_tz; ///< - public: - void start() { gettimeofday(&m_start, &m_tz); } - void stop() { gettimeofday(&m_end,&m_tz); } - real_type operator()()const - { - real_type t1 = static_cast(m_start.tv_sec) + static_cast(m_start.tv_usec)/(1000*1000); - real_type t2 = static_cast(m_end.tv_sec) + static_cast(m_end.tv_usec)/(1000*1000); - return t2-t1; - } -#endif - }; - - } //End of namespace utility -} //End of namespace OpenTissue - -// OPENTISSUE_UTILITY_UTILITY_TIMER_H -#endif diff --git a/Demos3/Geometry/DistributePoints.h b/Demos3/Geometry/DistributePoints.h deleted file mode 100644 index 23213468c..000000000 --- a/Demos3/Geometry/DistributePoints.h +++ /dev/null @@ -1,308 +0,0 @@ -#ifndef DISTRIBUTE_POINTS_H -#define DISTRIBUTE_POINTS_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "OpenGLWindow/CommonGraphicsApp.h" -#include "BulletCollision/CollisionShapes/btConvexHullShape.h" -#include "BulletCollision/CollisionShapes/btConvexPolyhedron.h" -#include "btBulletDynamicsCommon.h" - -inline btScalar randRange(btScalar minRange, btScalar maxRange) -{ - return (rand() / (btScalar(RAND_MAX) + btScalar(1.0))) * (maxRange - minRange) + minRange; -} - -void myCallback(btBroadphasePair& collisionPair, btCollisionDispatcher& dispatcher, const btDispatcherInfo& dispatchInfo) -{ - if (1) - { - btCollisionObject* colObj0 = (btCollisionObject*)collisionPair.m_pProxy0->m_clientObject; - btCollisionObject* colObj1 = (btCollisionObject*)collisionPair.m_pProxy1->m_clientObject; - btRigidBody* body0 = btRigidBody::upcast(colObj0); - btRigidBody* body1 = btRigidBody::upcast(colObj1); - if (body0 && body1) - { - btVector3 vec = body1->getWorldTransform().getOrigin()-body0->getWorldTransform().getOrigin(); - - vec.safeNormalize(); - //add a small 'random' direction to avoid getting stuck in a plane - //vec += 0.00001*btVector3(randRange(0,1),randRange(0,1),randRange(0,1)); - //magnitude: 1./vec.length1(); - btScalar l = vec.length(); - btScalar mag = 1.1/(l*l*l); - - body0->applyImpulse(-mag*vec,btVector3(0,0,0)); - body1->applyImpulse(mag*vec,btVector3(0,0,0)); - - } - - } else - { - btCollisionDispatcher::defaultNearCallback(collisionPair,dispatcher,dispatchInfo); - } -} - -class DistributePoints : public BulletDemoInterface -{ - CommonGraphicsApp* m_app; - float m_x; - float m_y; - - btDefaultCollisionConfiguration* m_collisionConfiguration; - btCollisionDispatcher* m_dispatcher; - btDiscreteDynamicsWorld* m_dynamicsWorld; - btDbvtBroadphase* m_broadphase; - btSequentialImpulseConstraintSolver* m_solver; - -public: - - DistributePoints(CommonGraphicsApp* app) - :m_app(app), - m_x(0), - m_y(0) - { - m_app->setUpAxis(1); - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - m_broadphase = new btDbvtBroadphase(); - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher, m_broadphase, m_solver, m_collisionConfiguration); - m_dispatcher->setNearCallback(myCallback); - - - } - virtual ~DistributePoints() - { - delete m_dynamicsWorld; - delete m_solver; - delete m_broadphase; - delete m_dispatcher; - delete m_collisionConfiguration; - } - static BulletDemoInterface* CreateFunc(CommonGraphicsApp* app) - { - return new DistributePoints(app); - } - - inline btScalar randRange(btScalar minRange, btScalar maxRange) - { - return (rand() / (btScalar(RAND_MAX) + btScalar(1.0))) * (maxRange - minRange) + minRange; - } - - virtual void initPhysics() - { - //create spheres, attached with point to point constraint - //use a collision callback, apply forces - - - btScalar radius = 0.01; - btSphereShape* sphere = new btSphereShape(1); - int sphereId = m_app->registerGraphicsSphereShape(radius,false); - - for (int i=0;i<256;i++) - { - - btScalar mass =1.f; - btVector3 localInertia; - sphere->calculateLocalInertia(mass,localInertia); - btRigidBody::btRigidBodyConstructionInfo ci(mass,0,sphere,localInertia); - ci.m_startWorldTransform.setIdentity(); - btVector3 center(randRange(-1,1),randRange(-1,1),randRange(-1,1)); - center.normalize(); - ci.m_startWorldTransform.setOrigin(center); - btRigidBody* body = new btRigidBody(ci); - const btVector3& pos = body->getWorldTransform().getOrigin(); - btQuaternion orn = body->getWorldTransform().getRotation(); - btVector4 color(1,0,0,1); - btVector3 scaling(radius,radius,radius); - - int instanceId = m_app->m_renderer->registerGraphicsInstance(sphereId,pos,orn,color,scaling); - body->setUserIndex(instanceId); - m_dynamicsWorld->addRigidBody(body); - btVector3 pivotInA = -body->getWorldTransform().getOrigin(); - btVector3 pivotInB(0,0,0); - // btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*body, btTypedConstraint::getFixedBody(),pivotInA,pivotInB); - // m_dynamicsWorld->addConstraint(p2p); - body->setActivationState(DISABLE_DEACTIVATION); - } - m_dynamicsWorld->setGravity(btVector3(0,0,0)); - - m_app->m_renderer->writeTransforms(); - - - } - virtual void exitPhysics() - { - - } - - - virtual void stepSimulation(float deltaTime) - { - m_dynamicsWorld->stepSimulation(1./60.,0); - for (int i=0;igetNumCollisionObjects();i++) - { - btRigidBody* body = btRigidBody::upcast(m_dynamicsWorld->getCollisionObjectArray()[i]); - if (body && body->getUserIndex()>=0) - { - btTransform pos = body->getWorldTransform(); - pos.setOrigin(pos.getOrigin().normalized()); - body->setWorldTransform(pos); - body->setAngularVelocity(btVector3(0,0,0)); - body->setLinearVelocity(btVector3(0,0,0)); - - } - } - - - - } - virtual void renderScene() - { - //sync transforms - for (int i=0;igetNumCollisionObjects();i++) - { - btRigidBody* body = btRigidBody::upcast(m_dynamicsWorld->getCollisionObjectArray()[i]); - if (body && body->getUserIndex()>=0) - { - const btVector3& pos = body->getWorldTransform().getOrigin(); - btQuaternion orn = body->getWorldTransform().getRotation(); - - m_app->m_renderer->writeSingleInstanceTransformToCPU(pos,orn,body->getUserIndex()); - } - } - - - - m_app->m_renderer->writeTransforms(); - - m_app->m_renderer->renderScene(); - - - } - virtual void physicsDebugDraw(int debugDrawFlags) - { - - int lineWidth = 1; - int pointSize = 2; - - btAlignedObjectArray m_vertices; - for (int i=0;igetNumCollisionObjects();i++) - { - btRigidBody* body = btRigidBody::upcast(m_dynamicsWorld->getCollisionObjectArray()[i]); - if (body && body->getUserIndex()>=0) - { - btTransform pos = body->getWorldTransform(); - m_vertices.push_back(pos.getOrigin()); - } - } - - btConvexHullShape* m_convexHull = new btConvexHullShape(&m_vertices[0].x(),m_vertices.size(),sizeof(btVector3)); - m_convexHull->initializePolyhedralFeatures(); - const btConvexPolyhedron* poly = m_convexHull->getConvexPolyhedron(); - - btScalar averageEdgeLength = 0.f; - btScalar numLengths=0; - - for (int p=0;pm_faces.size();p++) - { - for (int f=2;fm_faces[p].m_indices.size();f++) - { - btVector4 color0(0,0,1,1); - btVector4 color1(0,0,1,1); - btVector4 color2(0,0,1,1); - - int index0=poly->m_faces[p].m_indices[f-2]; - int index1=poly->m_faces[p].m_indices[f-1]; - int index2=poly->m_faces[p].m_indices[f]; - - btVector3 v0 = poly->m_vertices[index0]; - btVector3 v1 = poly->m_vertices[index1]; - btVector3 v2 = poly->m_vertices[index2]; - btVector3 e0 = v1-v0; - btVector3 e1 = v2-v1; - btVector3 e2 = v0-v2; - btScalar e0Length = e0.length(); - btScalar e1Length = e1.length(); - btScalar e2Length = e2.length(); - averageEdgeLength+=e0Length; - averageEdgeLength+=e1Length; - averageEdgeLength+=e2Length; - numLengths+=3; - } - } - averageEdgeLength/=numLengths; - btScalar maxLengthDiff = 0.f; - - for (int p=0;pm_faces.size();p++) - { - for (int f=2;fm_faces[p].m_indices.size();f++) - { - btVector4 color0(0,0,1,1); - btVector4 color1(0,0,1,1); - btVector4 color2(0,0,1,1); - - int index0=poly->m_faces[p].m_indices[f-2]; - int index1=poly->m_faces[p].m_indices[f-1]; - int index2=poly->m_faces[p].m_indices[f]; - - btVector3 v0 = poly->m_vertices[index0]; - btVector3 v1 = poly->m_vertices[index1]; - btVector3 v2 = poly->m_vertices[index2]; - btVector3 e0 = v1-v0; - btVector3 e1 = v2-v1; - btVector3 e2 = v0-v2; - btScalar e0LengthDiff = btFabs(averageEdgeLength-e0.length()); - btScalar e1LengthDiff = btFabs(averageEdgeLength-e1.length()); - btScalar e2LengthDiff = btFabs(averageEdgeLength-e2.length()); - - btSetMax(maxLengthDiff,e0LengthDiff); - btSetMax(maxLengthDiff,e1LengthDiff); - btSetMax(maxLengthDiff,e2LengthDiff); - - m_app->m_renderer->drawLine(&v0.x(), - &v1.x(), - color0,lineWidth); - m_app->m_renderer->drawLine(&v1.x(), - &v2.x(), - color1,lineWidth); - m_app->m_renderer->drawLine(&v2.x(), - &v0.x(), - color2,lineWidth); - - } - //printf("maxEdgeLength=%f\n",maxEdgeLength); - } - for (int i=0;im_vertices.size();i++) - { - btVector4 color(1,0,0,1); - - m_app->m_renderer->drawPoint(poly->m_vertices[i],color,pointSize); - - } - - delete m_convexHull; - - char msg[1024]; - btScalar targetDist = 2.0f*sqrtf(4.0f/(btScalar)m_vertices.size()); - sprintf(msg,"average Edge Length = %f, maxLengthDiff = %f",averageEdgeLength,maxLengthDiff); - b3Printf(msg); - - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - -}; -#endif //DISTRIBUTE_POINTS_H - diff --git a/Demos3/Geometry/RenderInstancingDemo.h b/Demos3/Geometry/RenderInstancingDemo.h deleted file mode 100644 index 454d35510..000000000 --- a/Demos3/Geometry/RenderInstancingDemo.h +++ /dev/null @@ -1,131 +0,0 @@ -#ifndef RENDER_INSTANCING_DEMO_H -#define RENDER_INSTANCING_DEMO_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "OpenGLWindow/CommonGraphicsApp.h" -#include "Bullet3Common/b3Quaternion.h" - - - -///quick demo showing the right-handed coordinate system and positive rotations around each axis -class RenderInstancingDemo : public BulletDemoInterface -{ - CommonGraphicsApp* m_app; - float m_x; - float m_y; - float m_z; - b3AlignedObjectArray m_movingInstances; - enum - { - numCubesX = 20, - numCubesY = 20 - }; -public: - - RenderInstancingDemo(CommonGraphicsApp* app) - :m_app(app), - m_x(0), - m_y(0), - m_z(0) - { - m_app->setUpAxis(2); - - { - b3Vector3 extents=b3MakeVector3(100,100,100); - extents[m_app->getUpAxis()]=1; - - int xres = 20; - int yres = 20; - - b3Vector4 color0=b3MakeVector4(0.1, 0.1, 0.1,1); - b3Vector4 color1=b3MakeVector4(0.6, 0.6, 0.6,1); - m_app->registerGrid(xres, yres, color0, color1); - } - - { - int boxId = m_app->registerCubeShape(0.1,0.1,0.1); - - - - for (int i=-numCubesX/2;igetUpAxis()] = 1; - b3Quaternion orn(0,0,0,1); - b3Vector4 color=b3MakeVector4(0.3,0.3,0.3,1); - b3Vector3 scaling=b3MakeVector3(1,1,1); - int instanceId = m_app->m_renderer->registerGraphicsInstance(boxId,pos,orn,color,scaling); - m_movingInstances.push_back(instanceId); - } - } - } - - m_app->m_renderer->writeTransforms(); - } - virtual ~RenderInstancingDemo() - { - m_app->m_renderer->enableBlend(false); - } - - static BulletDemoInterface* CreateFunc(CommonGraphicsApp* app) - { - return new RenderInstancingDemo(app); - } - virtual void physicsDebugDraw(int debugDrawMode) - { - - } - virtual void initPhysics() - { - } - virtual void exitPhysics() - { - - } - virtual void stepSimulation(float deltaTime) - { - m_x+=0.01f; - m_y+=0.01f; - m_z+=0.01f; - int index=0; - for (int i=-numCubesX/2;igetUpAxis()] = 1+1*b3Sin(m_x+i-j); - float orn[4]={0,0,0,1}; - m_app->m_renderer->writeSingleInstanceTransformToCPU(pos,orn,m_movingInstances[index++]); - } - } - m_app->m_renderer->writeTransforms(); - - } - virtual void renderScene() - { - m_app->m_renderer->renderScene(); - } - - - virtual void physicsDebugDraw() - { - - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - -}; -#endif //RENDER_INSTANCING_DEMO_H - diff --git a/Demos3/Geometry/SphereCreation.h b/Demos3/Geometry/SphereCreation.h deleted file mode 100644 index bb832cecb..000000000 --- a/Demos3/Geometry/SphereCreation.h +++ /dev/null @@ -1,345 +0,0 @@ -#ifndef SPHERE_CREATION_H -#define SPHERE_CREATION_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "OpenGLWindow/CommonGraphicsApp.h" -#include "BulletCollision/CollisionShapes/btConvexHullShape.h" -#include "BulletCollision/CollisionShapes/btConvexPolyhedron.h" - - -class SphereCreation : public BulletDemoInterface -{ - CommonGraphicsApp* m_app; - float m_x; - float m_y; - - btAlignedObjectArray m_vertices; - btConvexHullShape* m_convexHull; - -public: - - SphereCreation(CommonGraphicsApp* app) - :m_app(app), - m_x(0), - m_y(0) - { - m_app->setUpAxis(1); - m_app->m_renderer->writeTransforms(); - } - virtual ~SphereCreation() - { - } - static BulletDemoInterface* CreateFunc(CommonGraphicsApp* app) - { - return new SphereCreation(app); - } - - inline btScalar randRange(btScalar minRange, btScalar maxRange) - { - return (rand() / (btScalar(RAND_MAX) + btScalar(1.0))) * (maxRange - minRange) + minRange; - } - - virtual void initPhysics() - { - srand(0); - //create random vertices - int numVerts = 256; - for (int i=0;iinitializePolyhedralFeatures(); - - } - virtual void exitPhysics() - { - //dump vertices - - printf("indices:\n"); - const btConvexPolyhedron* poly = m_convexHull->getConvexPolyhedron(); - for (int i=0;im_vertices.size();i++) - { - printf("%f,%f,%f,%f,%f,%f,%f,%f,%f,\n",poly->m_vertices[i].x(), - poly->m_vertices[i].y(), - poly->m_vertices[i].z(), - 1.f, - poly->m_vertices[i].x(), - poly->m_vertices[i].y(), - poly->m_vertices[i].z(), - 0.5f,0.5f); - } - - for (int p=0;pm_faces.size();p++) - { - for (int f=2;fm_faces[p].m_indices.size();f++) - { - int index0=poly->m_faces[p].m_indices[f-2]; - int index1=poly->m_faces[p].m_indices[f-1]; - int index2=poly->m_faces[p].m_indices[f]; - printf("%d,%d,%d,\n",index0,index1,index2); - } - } -} - void distributeVerticesOnSphere(int iterations,btScalar relaxation) - { - btScalar previousAverage=0; - - btScalar averageDist = 0; - btScalar previousAverageError = 0.0f; - btScalar maxError = -1e30f; - btScalar averageError = 0.f; - - ///bring closest the closest neighbor of each vertex closer to the 'average' neighbor distance - for (int i=0;i=0) - { - btVector3 vec = m_vertices[closestOther]-m_vertices[v]; - vec.safeNormalize(); - if (previousAverage) - { - averageError+=btFabs(errorDist); - m_vertices[v] -= vec*previousAverageError*relaxation; - m_vertices[closestOther] += vec*previousAverageError*relaxation; - m_vertices[v].normalize(); - m_vertices[closestOther].normalize(); - } - } - - } - averageDist /= btScalar(m_vertices.size()); - averageError /= btScalar(m_vertices.size()); - previousAverageError = averageError; - previousAverage = averageDist; - } - char msg[1024]; - btScalar targetDist = 2.0f*sqrtf(4.0f/(btScalar)m_vertices.size()); - sprintf(msg,"averageDist = %f, previousAverageError = %f, maxError = %f, target = %f\n",averageDist,previousAverageError,maxError,targetDist); - b3Printf(msg); - } - virtual void stepSimulation(float deltaTime) - { - m_x+=0.01f; - m_y+=0.02f; - //bringVerticesTogether(); - - } - virtual void renderScene() - { - m_app->m_renderer->renderScene(); - - } - virtual void physicsDebugDraw(int debugDrawFlags) - { - int lineWidth = 1; - int pointSize = 2; - - distributeVerticesOnSphere(12,0.2f); - - delete m_convexHull; - m_convexHull = new btConvexHullShape(&m_vertices[0].x(),m_vertices.size(),sizeof(btVector3)); - m_convexHull->initializePolyhedralFeatures(); - const btConvexPolyhedron* poly = m_convexHull->getConvexPolyhedron(); - - if (m_vertices.size() != poly->m_vertices.size()) - { - printf("Warning: m_vertices.size()=%d and poly->m_vertices.size()=%d\n", m_vertices.size(), - poly->m_vertices.size()); - return; - } else - { - for (int i=0;im_vertices[i]; - } - } - - btScalar maxEdgeLength = -1e30f; - btScalar averageEdgeLength=0.f; - btScalar numLengts = 0; - - for (int p=0;pm_faces.size();p++) - { - for (int f=2;fm_faces[p].m_indices.size();f++) - { - btVector4 color0(0,0,1,1); - btVector4 color1(0,0,1,1); - btVector4 color2(0,0,1,1); - - int index0=poly->m_faces[p].m_indices[f-2]; - int index1=poly->m_faces[p].m_indices[f-1]; - int index2=poly->m_faces[p].m_indices[f]; - - btVector3 v0 = poly->m_vertices[index0]; - btVector3 v1 = poly->m_vertices[index1]; - btVector3 v2 = poly->m_vertices[index2]; - btVector3 e0 = v1-v0; - btVector3 e1 = v2-v1; - btVector3 e2 = v0-v2; - btScalar e0Length = e0.length(); - btScalar e1Length = e1.length(); - btScalar e2Length = e2.length(); - averageEdgeLength+= e0Length; - averageEdgeLength+= e1Length; - averageEdgeLength+= e2Length; - numLengts+=3.f; - - } - } - - averageEdgeLength/=numLengts; - - for (int p=0;pm_faces.size();p++) - { - for (int f=2;fm_faces[p].m_indices.size();f++) - { - btVector4 color0(0,0,1,1); - btVector4 color1(0,0,1,1); - btVector4 color2(0,0,1,1); - - int index0=poly->m_faces[p].m_indices[f-2]; - int index1=poly->m_faces[p].m_indices[f-1]; - int index2=poly->m_faces[p].m_indices[f]; - - btVector3 v0 = m_vertices[index0]; - btVector3 v1 = m_vertices[index1]; - btVector3 v2 = m_vertices[index2]; - btVector3 e0 = v1-v0; - btVector3 e1 = v2-v1; - btVector3 e2 = v0-v2; - btScalar e0Length = e0.length(); - btScalar e1Length = e1.length(); - btScalar e2Length = e2.length(); - btScalar scaling = -0.01;//-0.01f;//0;//-0.02f; - if (e0Length>maxEdgeLength) - maxEdgeLength = e0Length; - { - btScalar errorLength = averageEdgeLength-e0Length; - m_vertices[index0] += e0.normalized()*errorLength*scaling; - m_vertices[index1] -= e0.normalized()*errorLength*scaling; - m_vertices[index0].normalize(); - m_vertices[index1].normalize(); - color0.setValue(1,0,0,1); - //shift vertices - - } - if (e1Length>maxEdgeLength) - maxEdgeLength = e1Length; - - { - btScalar errorLength = averageEdgeLength-e1Length; - m_vertices[index1] += e1.normalized()*errorLength*scaling; - m_vertices[index2] -= e1.normalized()*errorLength*scaling; - m_vertices[index1].normalize(); - m_vertices[index2].normalize(); - - color1.setValue(1,0,0,1); - - } - if (e2Length>maxEdgeLength) - maxEdgeLength = e2Length; - { - btScalar errorLength = averageEdgeLength-e2Length; - m_vertices[index2] += e2.normalized()*errorLength*scaling; - m_vertices[index0] -= e2.normalized()*errorLength*scaling; - color2.setValue(1,0,0,1); - - m_vertices[index2].normalize(); - m_vertices[index0].normalize(); - } - } - } - - for (int p=0;pm_faces.size();p++) - { - for (int f=2;fm_faces[p].m_indices.size();f++) - { - btVector4 color0(0,0,1,1); - btVector4 color1(0,0,1,1); - btVector4 color2(0,0,1,1); - - int index0=poly->m_faces[p].m_indices[f-2]; - int index1=poly->m_faces[p].m_indices[f-1]; - int index2=poly->m_faces[p].m_indices[f]; - - btVector3 v0 = m_vertices[index0]; - btVector3 v1 = m_vertices[index1]; - btVector3 v2 = m_vertices[index2]; - m_app->m_renderer->drawLine(&v0.x(), - &v1.x(), - color0,lineWidth); - m_app->m_renderer->drawLine(&v1.x(), - &v2.x(), - color1,lineWidth); - m_app->m_renderer->drawLine(&v2.x(), - &v0.x(), - color2,lineWidth); - - } - //printf("maxEdgeLength=%f\n",maxEdgeLength); - } - for (int i=0;im_renderer->drawPoint(m_vertices[i],color,pointSize); - - } - - - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - -}; -#endif //SPHERE_CREATION_H - diff --git a/Demos3/GpuDemos/CMakeLists.txt b/Demos3/GpuDemos/CMakeLists.txt deleted file mode 100644 index 3dd1ec183..000000000 --- a/Demos3/GpuDemos/CMakeLists.txt +++ /dev/null @@ -1,76 +0,0 @@ - -ADD_DEFINITIONS(-DB3_USE_CLEW) - -INCLUDE_DIRECTORIES( - .. - ${BULLET_PHYSICS_SOURCE_DIR}/src - ${BULLET_PHYSICS_SOURCE_DIR}/btgui -) - - -SET(App_Bullet3_OpenCL_Demos_SRCS - ../../src/clew/clew.c - GpuDemo.cpp - main_opengl3core.cpp - ParticleDemo.cpp - broadphase/PairBench.cpp - constraints/ConstraintsDemo.cpp - raytrace/RaytracedShadowDemo.cpp - rigidbody/Bullet2FileDemo.cpp - rigidbody/BulletDataExtractor.cpp - rigidbody/ConcaveScene.cpp - rigidbody/GpuCompoundScene.cpp - rigidbody/GpuConvexScene.cpp - rigidbody/GpuRigidBodyDemo.cpp - rigidbody/GpuSphereScene.cpp - shadows/ShadowMapDemo.cpp - softbody/GpuSoftBodyDemo.cpp - ../Wavefront/tiny_obj_loader.cpp - ../../btgui/stb_image/stb_image.cpp - ../../btgui/Bullet3AppSupport/b3Quickprof.cpp - ../../btgui/Bullet3AppSupport/b3Clock.cpp - ../../btgui/Bullet3AppSupport/gwenUserInterface.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc -) - -LINK_LIBRARIES( - Bullet2FileLoader Bullet3OpenCL_clew Bullet3Dynamics Bullet3Collision Bullet3Geometry Bullet3Common OpenGLWindow gwen ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - - -IF (WIN32) - SET(App_Bullet3_OpenCL_Demos_SRCS ${App_Bullet3_OpenCL_Demos_SRCS} ${App_Bullet3_OpenCL_Demos_Common_SRCS} ../../btgui/OpenGLWindow/GlewWindows/glew.c) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/OpenGLWindow/GlewWindows - ) - ADD_DEFINITIONS(-DGLEW_STATIC) -ELSE(WIN32) - IF(APPLE) - find_library(COCOA NAMES Cocoa) - MESSAGE(${COCOA}) - link_libraries(${COCOA}) - ELSE(APPLE) - SET(App_Bullet3_OpenCL_Demos_SRCS ${App_Bullet3_OpenCL_Demos_SRCS} ${App_Bullet3_OpenCL_Demos_Common_SRCS} ../../btgui/OpenGLWindow/GlewWindows/glew.c) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/OpenGLWindow/GlewWindows - ) - ADD_DEFINITIONS("-DGLEW_INIT_OPENGL11_FUNCTIONS=1") - ADD_DEFINITIONS("-DGLEW_STATIC") - ADD_DEFINITIONS("-DGLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS=1") - - LINK_LIBRARIES( X11 pthread dl) - ENDIF(APPLE) -ENDIF(WIN32) - - -ADD_EXECUTABLE(App_Bullet3_OpenCL_Demos - ${App_Bullet3_OpenCL_Demos_SRCS} -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(App_Bullet3_OpenCL_Demos PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(App_Bullet3_OpenCL_Demos PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(App_Bullet3_OpenCL_Demos PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos3/GpuDemos/GpuDemo.cpp b/Demos3/GpuDemos/GpuDemo.cpp deleted file mode 100644 index e931f699e..000000000 --- a/Demos3/GpuDemos/GpuDemo.cpp +++ /dev/null @@ -1,131 +0,0 @@ -#include "GpuDemo.h" -#include "GpuDemoInternalData.h" -#include "Bullet3Common/b3Scalar.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/ShapeData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/OpenGLInclude.h" -bool gAllowCpuOpenCL = false; -#include "stb_image/stb_image.h" -GpuDemo::GpuDemo() -:m_clData(0) -{ - m_clData = new GpuDemoInternalData(); -} - -GpuDemo::~GpuDemo() -{ - if (m_clData) - { - b3Assert(m_clData->m_clInitialized==false); - - delete m_clData; - } -} - -void GpuDemo::exitCL() -{ - if (m_clData->m_clInitialized) - { - clReleaseCommandQueue(m_clData->m_clQueue); - clReleaseContext(m_clData->m_clContext); - m_clData->m_clInitialized = false; - } - -} - - - -void GpuDemo::initCL(int preferredDeviceIndex, int preferredPlatformIndex) -{ - void* glCtx=0; - void* glDC = 0; - - - - int ciErrNum = 0; - - cl_device_type deviceType = CL_DEVICE_TYPE_GPU; - if (gAllowCpuOpenCL) - deviceType = CL_DEVICE_TYPE_ALL; - - - - // if (useInterop) - // { - // m_data->m_clContext = b3OpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC); - // } else - { - m_clData->m_clContext = b3OpenCLUtils::createContextFromType(deviceType, &ciErrNum, 0,0,preferredDeviceIndex, preferredPlatformIndex,&m_clData->m_platformId); - } - - - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - int numDev = b3OpenCLUtils::getNumDevices(m_clData->m_clContext); - - if (numDev>0) - { - m_clData->m_clDevice= b3OpenCLUtils::getDevice(m_clData->m_clContext,0); - m_clData->m_clQueue = clCreateCommandQueue(m_clData->m_clContext, m_clData->m_clDevice, 0, &ciErrNum); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - - - b3OpenCLDeviceInfo info; - b3OpenCLUtils::getDeviceInfo(m_clData->m_clDevice,&info); - m_clData->m_clDeviceName = info.m_deviceName; - m_clData->m_clInitialized = true; - - } - -} - -GpuDemoInternalData* GpuDemo::getInternalData() -{ - return m_clData; -} - -int GpuDemo::registerGraphicsSphereShape(const ConstructionInfo& ci, float radius, bool usePointSprites, int largeSphereThreshold, int mediumSphereThreshold) -{ - - int strideInBytes = 9*sizeof(float); - - int graphicsShapeIndex = -1; - - if (radius>=largeSphereThreshold) - { - int numVertices = sizeof(detailed_sphere_vertices)/strideInBytes; - int numIndices = sizeof(detailed_sphere_indices)/sizeof(int); - graphicsShapeIndex = ci.m_instancingRenderer->registerShape(&detailed_sphere_vertices[0],numVertices,detailed_sphere_indices,numIndices); - } else - { - - if (usePointSprites) - { - int numVertices = sizeof(point_sphere_vertices)/strideInBytes; - int numIndices = sizeof(point_sphere_indices)/sizeof(int); - graphicsShapeIndex = ci.m_instancingRenderer->registerShape(&point_sphere_vertices[0],numVertices,point_sphere_indices,numIndices,B3_GL_POINTS); - } else - { - if (radius>=mediumSphereThreshold) - { - int numVertices = sizeof(medium_sphere_vertices)/strideInBytes; - int numIndices = sizeof(medium_sphere_indices)/sizeof(int); - graphicsShapeIndex = ci.m_instancingRenderer->registerShape(&medium_sphere_vertices[0],numVertices,medium_sphere_indices,numIndices); - } else - { - int numVertices = sizeof(low_sphere_vertices)/strideInBytes; - int numIndices = sizeof(low_sphere_indices)/sizeof(int); - graphicsShapeIndex = ci.m_instancingRenderer->registerShape(&low_sphere_vertices[0],numVertices,low_sphere_indices,numIndices); - } - } - } - return graphicsShapeIndex; -} - - -unsigned char* GpuDemo::loadImage(const char* fileName, int& width, int& height, int& n) -{ - unsigned char *data = stbi_load(fileName, &width, &height, &n, 0); - return data; -} diff --git a/Demos3/GpuDemos/GpuDemo.h b/Demos3/GpuDemos/GpuDemo.h deleted file mode 100644 index 8970d639e..000000000 --- a/Demos3/GpuDemos/GpuDemo.h +++ /dev/null @@ -1,100 +0,0 @@ -#ifndef GPU_DEMO_H -#define GPU_DEMO_H -class GLInstancingRenderer; -class GLPrimitiveRenderer; - - - - -class GpuDemo -{ -protected: - - struct GpuDemoInternalData* m_clData; - - - virtual void initCL(int preferredDeviceIndex, int preferredPlatformIndex); - virtual void exitCL(); -public: - - typedef class GpuDemo* (CreateFunc)(); - - struct ConstructionInfo - { - bool useOpenCL; - int preferredOpenCLPlatformIndex; - int preferredOpenCLDeviceIndex; - int arraySizeX; - int arraySizeY; - int arraySizeZ; - bool m_useConcaveMesh; - float gapX; - float gapY; - float gapZ; - bool m_useInstancedCollisionShapes; - GLInstancingRenderer* m_instancingRenderer; - GLPrimitiveRenderer* m_primRenderer; - - class b3gWindowInterface* m_window; - class GwenUserInterface* m_gui; - - ConstructionInfo() - :useOpenCL(true), - preferredOpenCLPlatformIndex(-1), - preferredOpenCLDeviceIndex(-1), - #ifdef __APPLE__ - arraySizeX(10), - arraySizeY(10), - arraySizeZ(10), - #else - - arraySizeX(30), - arraySizeY(30), - arraySizeZ(30), -#endif - m_useConcaveMesh(false), - gapX(16.3), - gapY(6.3), - gapZ(16.3), - m_useInstancedCollisionShapes(true), - m_instancingRenderer(0), - m_window(0), - m_gui(0) - { - } - }; - - GpuDemo(); - virtual ~GpuDemo(); - - virtual const char* getName()=0; - - virtual void initPhysics(const ConstructionInfo& ci)=0; - - virtual void exitPhysics()=0; - - virtual void renderScene()=0; - - virtual void clientMoveAndDisplay()=0; - - unsigned char* loadImage(const char* fileName, int& width, int& height, int& n); - - int registerGraphicsSphereShape(const ConstructionInfo& ci, float radius, bool usePointSprites=true, int largeSphereThreshold=100, int mediumSphereThreshold=10); - - struct GpuDemoInternalData* getInternalData(); - - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } -}; - -#endif diff --git a/Demos3/GpuDemos/GpuDemoInternalData.h b/Demos3/GpuDemos/GpuDemoInternalData.h deleted file mode 100644 index be6584c35..000000000 --- a/Demos3/GpuDemos/GpuDemoInternalData.h +++ /dev/null @@ -1,27 +0,0 @@ -#ifndef GPU_DEMO_INTERNAL_DATA_H -#define GPU_DEMO_INTERNAL_DATA_H - -#include "Bullet3OpenCL/Initialize/b3OpenCLInclude.h" - -struct GpuDemoInternalData -{ - cl_platform_id m_platformId; - cl_context m_clContext; - cl_device_id m_clDevice; - cl_command_queue m_clQueue; - bool m_clInitialized; - char* m_clDeviceName; - - GpuDemoInternalData() - :m_platformId(0), - m_clContext(0), - m_clDevice(0), - m_clQueue(0), - m_clInitialized(false), - m_clDeviceName(0) - { - - } -}; - -#endif diff --git a/Demos3/GpuDemos/ParticleDemo.cpp b/Demos3/GpuDemos/ParticleDemo.cpp deleted file mode 100644 index ca14a8752..000000000 --- a/Demos3/GpuDemos/ParticleDemo.cpp +++ /dev/null @@ -1,464 +0,0 @@ -#include "ParticleDemo.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/ShapeData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" - -#define MSTRINGIFY(A) #A -static const char* particleKernelsString = -#include "ParticleKernels.cl" - -#define INTEROPKERNEL_SRC_PATH "demo/gpudemo/ParticleKernels.cl" -#include "Bullet3Common/b3Vector3.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -//#include "../../opencl/primitives/AdlPrimitives/Math/Math.h" -//#include "../../opencl/broadphase_benchmark/b3GridBroadphaseCL.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "GpuDemoInternalData.h" -#include "Bullet3Common/b3Random.h" - - -//1000000 particles -//#define NUM_PARTICLES_X 100 -//#define NUM_PARTICLES_Y 100 -//#define NUM_PARTICLES_Z 100 - -//512k particles -//#define NUM_PARTICLES_X 80 -//#define NUM_PARTICLES_Y 80 -//#define NUM_PARTICLES_Z 80 - -//256k particles -#define NUM_PARTICLES_X 60 -#define NUM_PARTICLES_Y 60 -#define NUM_PARTICLES_Z 60 - -//27k particles -//#define NUM_PARTICLES_X 30 -//#define NUM_PARTICLES_Y 30 -//#define NUM_PARTICLES_Z 30 - - - -B3_ATTRIBUTE_ALIGNED16(struct) b3SimParams -{ - B3_DECLARE_ALIGNED_ALLOCATOR(); - b3Vector3 m_gravity; - float m_worldMin[4]; - float m_worldMax[4]; - - float m_particleRad; - float m_globalDamping; - float m_boundaryDamping; - float m_collisionDamping; - - float m_spring; - float m_shear; - float m_attraction; - float m_dummy; - - - b3SimParams() - { - m_gravity.setValue(0,-.3,0.f); - m_particleRad = 0.01f; - m_globalDamping = 1.0f; - m_boundaryDamping = -0.99f; - m_collisionDamping = 0.025f;//0.02f; - m_spring = 0.5f; - m_shear = 0.1f; - m_attraction = 0.001f; - m_worldMin[0] = -1.f; - m_worldMin[1] = -2*m_particleRad; - m_worldMin[2] =-1.f; - - m_worldMax[0] = 5.f; - m_worldMax[1] = 5.f; - m_worldMax[2] = 5.f; - - } -}; - -struct ParticleInternalData -{ - - cl_kernel m_updatePositionsKernel; - cl_kernel m_updatePositionsKernel2; - - cl_kernel m_updateAabbsKernel; - - cl_kernel m_collideParticlesKernel; - - b3GpuSapBroadphase* m_broadphaseGPU; - - - cl_mem m_clPositionBuffer; - - b3AlignedObjectArray m_velocitiesCPU; - b3OpenCLArray* m_velocitiesGPU; - - b3AlignedObjectArray m_simParamCPU; - b3OpenCLArray* m_simParamGPU; - - - - ParticleInternalData() - : - m_clPositionBuffer(0), - m_velocitiesGPU(0), - m_simParamGPU(0), - m_updatePositionsKernel(0), - m_updatePositionsKernel2(0), - m_updateAabbsKernel(0), - m_collideParticlesKernel(0) - { - m_simParamCPU.resize(1); - } - - -}; - - -ParticleDemo::ParticleDemo() -:m_instancingRenderer(0) -{ - m_data = new ParticleInternalData; -} - -ParticleDemo::~ParticleDemo() -{ - exitCL(); - - delete m_data; - -} - -void ParticleDemo::exitCL() -{ - if (m_clData->m_clInitialized) - { - clReleaseKernel(m_data->m_updatePositionsKernel); - clReleaseKernel(m_data->m_updatePositionsKernel2); - clReleaseKernel(m_data->m_updateAabbsKernel); - clReleaseKernel(m_data->m_collideParticlesKernel); - } - - GpuDemo::exitCL(); -} - -void ParticleDemo::initCL(int preferredDeviceIndex, int preferredPlatformIndex) -{ - GpuDemo::initCL(preferredDeviceIndex,preferredPlatformIndex); -} - - -void ParticleDemo::setupScene(const ConstructionInfo& ci) -{ - - initCL(ci.preferredOpenCLDeviceIndex,ci.preferredOpenCLPlatformIndex); - - int numParticles = NUM_PARTICLES_X*NUM_PARTICLES_Y*NUM_PARTICLES_Z; - - - int maxObjects = NUM_PARTICLES_X*NUM_PARTICLES_Y*NUM_PARTICLES_Z+1024; - - int maxPairsSmallProxy = 32; - float radius = m_data->m_simParamCPU[0].m_particleRad; - - m_data->m_broadphaseGPU = new b3GpuSapBroadphase(m_clData->m_clContext ,m_clData->m_clDevice,m_clData->m_clQueue);//overlappingPairCache,b3Vector3(4.f, 4.f, 4.f), 128, 128, 128,maxObjects, maxObjects, maxPairsSmallProxy, 100.f, 128, - - /*m_data->m_broadphaseGPU = new b3GridBroadphaseCl(overlappingPairCache,b3Vector3(radius,radius,radius), 128, 128, 128, - maxObjects, maxObjects, maxPairsSmallProxy, 100.f, 128, - m_clData->m_clContext ,m_clData->m_clDevice,m_clData->m_clQueue); - */ - - m_data->m_velocitiesGPU = new b3OpenCLArray(m_clData->m_clContext,m_clData->m_clQueue,numParticles); - m_data->m_velocitiesCPU.resize(numParticles); - for (int i=0;im_velocitiesCPU[i].setValue(0,0,0); - } - m_data->m_velocitiesGPU->copyFromHost(m_data->m_velocitiesCPU); - - m_data->m_simParamGPU = new b3OpenCLArray(m_clData->m_clContext,m_clData->m_clQueue,1,false); - m_data->m_simParamGPU->copyFromHost(m_data->m_simParamCPU); - - cl_int pErrNum; - - cl_program prog = b3OpenCLUtils::compileCLProgramFromString(m_clData->m_clContext,m_clData->m_clDevice,particleKernelsString,0,"",INTEROPKERNEL_SRC_PATH,true); - m_data->m_updatePositionsKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext, m_clData->m_clDevice,particleKernelsString, "updatePositionsKernel" ,&pErrNum,prog); - oclCHECKERROR(pErrNum, CL_SUCCESS); - m_data->m_updatePositionsKernel2 = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext, m_clData->m_clDevice,particleKernelsString, "integrateMotionKernel" ,&pErrNum,prog); - oclCHECKERROR(pErrNum, CL_SUCCESS); - - m_data->m_updateAabbsKernel= b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext, m_clData->m_clDevice,particleKernelsString, "updateAabbsKernel" ,&pErrNum,prog); - oclCHECKERROR(pErrNum, CL_SUCCESS); - - m_data->m_collideParticlesKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext, m_clData->m_clDevice,particleKernelsString, "collideParticlesKernel" ,&pErrNum,prog); - oclCHECKERROR(pErrNum, CL_SUCCESS); - - m_instancingRenderer = ci.m_instancingRenderer; - - int strideInBytes = 9*sizeof(float); - bool pointSprite = true; - int shapeId =-1; - - if (pointSprite) - { - int numVertices = sizeof(point_sphere_vertices)/strideInBytes; - int numIndices = sizeof(point_sphere_indices)/sizeof(int); - shapeId = m_instancingRenderer->registerShape(&point_sphere_vertices[0],numVertices,point_sphere_indices,numIndices,B3_GL_POINTS); - } else - { - int numVertices = sizeof(low_sphere_vertices)/strideInBytes; - int numIndices = sizeof(low_sphere_indices)/sizeof(int); - shapeId = m_instancingRenderer->registerShape(&low_sphere_vertices[0],numVertices,low_sphere_indices,numIndices); - } - - float position[4] = {0,0,0,0}; - float quaternion[4] = {0,0,0,1}; - - float scaling[4] = {radius,radius,radius,1}; - - int userIndex = 0; - - int totalParticles = NUM_PARTICLES_X*NUM_PARTICLES_Y*NUM_PARTICLES_Z; - - int curColor = 0; - b3Vector4 colors[4] = - { - b3MakeVector4(1,1,1,1), - b3MakeVector4(1,1,0.3,1), - b3MakeVector4(0.3,1,1,1), - b3MakeVector4(0.3,0.3,1,1), - }; - - - { - srand(1234); - float angle = b3RandRange(-B3_PI, B3_PI); - for (int ii=0;iim_simParamCPU[0].m_particleRad; - position[0] = arg*b3Cos(arg + angle); - position[1] = 3.0f + arg; - position[2] = arg*b3Sin(arg + angle); - - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - - - int id = m_instancingRenderer->registerGraphicsInstance(shapeId,position,quaternion,color,scaling); - - - int collidableIndex = userIndex; - b3Vector3 aabbMin,aabbMax; - b3Vector3 particleRadius=b3MakeVector3(rad,rad,rad); - - aabbMin = b3MakeVector3(position[0],position[1],position[2])-particleRadius; - aabbMax = b3MakeVector3(position[0],position[1],position[2])+particleRadius; - //m_data->m_broadphaseGPU->createProxy(aabbMin,aabbMax,collidableIndex,1,1); - userIndex++; - angle += b3RandRange(-(float)B3_PI, (float)B3_PI); - } - } - - - m_data->m_broadphaseGPU->writeAabbsToGpu(); - - //float camPos[4]={1.5,0.5,2.5,0}; - float camPos[4]={0,0.5,0,0}; - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(4); - m_instancingRenderer->writeTransforms(); - -} - -void ParticleDemo::initPhysics(const ConstructionInfo& ci) -{ - setupScene(ci); -} - -void ParticleDemo::exitPhysics() -{ -} - -void ParticleDemo::renderScene() -{ - - if (m_instancingRenderer) - { - m_instancingRenderer->renderScene(); - } - -} - - -void ParticleDemo::clientMoveAndDisplay() -{ - int numParticles = NUM_PARTICLES_X*NUM_PARTICLES_Y*NUM_PARTICLES_Z; - GLuint vbo = m_instancingRenderer->getInternalData()->m_vbo; - glBindBuffer(GL_ARRAY_BUFFER, vbo); - glFlush(); - - int posArraySize = numParticles*sizeof(float)*4; - - cl_bool blocking= CL_TRUE; - char* hostPtr= (char*)glMapBufferRange( GL_ARRAY_BUFFER,m_instancingRenderer->getMaxShapeCapacity(),posArraySize, GL_MAP_WRITE_BIT|GL_MAP_READ_BIT );//GL_READ_WRITE);//GL_WRITE_ONLY - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - glFinish(); - - - -#if 1 - - - - //do some stuff using the OpenCL buffer - - bool useCpu = false; - if (useCpu) - { - - - float* posBuffer = (float*)hostPtr; - - for (int i=0;im_clPositionBuffer) - { - m_data->m_clPositionBuffer = clCreateBuffer(m_clData->m_clContext, CL_MEM_READ_WRITE, - posArraySize, 0, &ciErrNum); - - clFinish(m_clData->m_clQueue); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - ciErrNum = clEnqueueWriteBuffer ( m_clData->m_clQueue,m_data->m_clPositionBuffer, - blocking,0,posArraySize,hostPtr,0,0,0 - ); - clFinish(m_clData->m_clQueue); - } - - - - - - - if (0) - { - b3BufferInfoCL bInfo[] = { - b3BufferInfoCL( m_data->m_velocitiesGPU->getBufferCL(), true ), - b3BufferInfoCL( m_data->m_clPositionBuffer) - }; - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_updatePositionsKernel,"m_updatePositionsKernel" ); - - launcher.setBuffers( bInfo, sizeof(bInfo)/sizeof(b3BufferInfoCL) ); - launcher.setConst( numParticles); - - launcher.launch1D( numParticles); - clFinish(m_clData->m_clQueue); - - } - - - if (1) - { - b3BufferInfoCL bInfo[] = { - b3BufferInfoCL( m_data->m_clPositionBuffer), - b3BufferInfoCL( m_data->m_velocitiesGPU->getBufferCL() ), - b3BufferInfoCL( m_data->m_simParamGPU->getBufferCL(),true) - }; - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_updatePositionsKernel2 ,"m_updatePositionsKernel2"); - - launcher.setConst( numParticles); - launcher.setBuffers( bInfo, sizeof(bInfo)/sizeof(b3BufferInfoCL) ); - float timeStep = 1.f/60.f; - launcher.setConst( timeStep); - - launcher.launch1D( numParticles); - clFinish(m_clData->m_clQueue); - - } - - if (0) - { - b3BufferInfoCL bInfo[] = { - b3BufferInfoCL( m_data->m_clPositionBuffer), - b3BufferInfoCL( m_data->m_broadphaseGPU->getAabbBufferWS()), - }; - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_updateAabbsKernel,"m_updateAabbsKernel" ); - launcher.setBuffers( bInfo, sizeof(bInfo)/sizeof(b3BufferInfoCL) ); - launcher.setConst( m_data->m_simParamCPU[0].m_particleRad); - launcher.setConst( numParticles); - - launcher.launch1D( numParticles); - clFinish(m_clData->m_clQueue); - } - - //broadphase - int numPairsGPU=0; - cl_mem pairsGPU = 0; - - { - //m_data->m_broadphaseGPU->calculateOverlappingPairs(64*numParticles); - pairsGPU = m_data->m_broadphaseGPU->getOverlappingPairBuffer(); - numPairsGPU = m_data->m_broadphaseGPU->getNumOverlap(); - } - - if (numPairsGPU) - { - b3BufferInfoCL bInfo[] = { - b3BufferInfoCL( m_data->m_clPositionBuffer), - b3BufferInfoCL( m_data->m_velocitiesGPU->getBufferCL() ), - b3BufferInfoCL( m_data->m_broadphaseGPU->getOverlappingPairBuffer(),true), - }; - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_collideParticlesKernel,"m_collideParticlesKernel"); - launcher.setBuffers( bInfo, sizeof(bInfo)/sizeof(b3BufferInfoCL) ); - launcher.setConst( numPairsGPU); - launcher.launch1D( numPairsGPU); - clFinish(m_clData->m_clQueue); - - //__kernel void collideParticlesKernel( __global float4* pPos, __global float4* pVel, __global int2* pairs, const int numPairs) - } - - - if (1) - { - ciErrNum = clEnqueueReadBuffer ( m_clData->m_clQueue, - m_data->m_clPositionBuffer, - blocking, - 0, - posArraySize, - hostPtr,0,0,0); - - //clReleaseMemObject(clBuffer); - clFinish(m_clData->m_clQueue); - - - } - } - -#endif - - glUnmapBuffer( GL_ARRAY_BUFFER); - glFlush(); - - - -} diff --git a/Demos3/GpuDemos/ParticleDemo.h b/Demos3/GpuDemos/ParticleDemo.h deleted file mode 100644 index 228101c79..000000000 --- a/Demos3/GpuDemos/ParticleDemo.h +++ /dev/null @@ -1,49 +0,0 @@ -#ifndef PARTICLE_DEMO_H -#define PARTICLE_DEMO_H - -#include "GpuDemo.h" -struct GLInstancingRenderer; - -class ParticleDemo : public GpuDemo -{ -public: - - - protected: - struct ParticleInternalData* m_data; - - GLInstancingRenderer* m_instancingRenderer; - - virtual void initCL(int preferredDeviceIndex, int preferredPlatformIndex); - virtual void exitCL(); - -public: - - ParticleDemo(); - - virtual ~ParticleDemo(); - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void exitPhysics(); - - virtual const char* getName() - { - return "ParticleDemo"; - } - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new ParticleDemo; - return demo; - } - - - - virtual void renderScene(); - - virtual void clientMoveAndDisplay(); -}; - -#endif //PARTICLE_DEMO_H diff --git a/Demos3/GpuDemos/ParticleKernels.cl b/Demos3/GpuDemos/ParticleKernels.cl deleted file mode 100644 index c3a32d541..000000000 --- a/Demos3/GpuDemos/ParticleKernels.cl +++ /dev/null @@ -1,148 +0,0 @@ -MSTRINGIFY( - - -typedef struct -{ - float4 m_gravity; - float4 m_worldMin; - float4 m_worldMax; - - float m_particleRad; - float m_globalDamping; - float m_boundaryDamping; - float m_collisionDamping; - - float m_spring; - float m_shear; - float m_attraction; - float m_dummy; -} btSimParams; - - -__kernel void updatePositionsKernel( __global float4* linearVelocities, __global float4* positions,const int numNodes) -{ - int nodeID = get_global_id(0); - float timeStep = 0.0166666; - - float BT_GPU_ANGULAR_MOTION_THRESHOLD = (0.25f * 3.14159254); - - if( nodeID < numNodes ) - { - positions[nodeID] += linearVelocities[nodeID]*timeStep; - } -} - - - -__kernel void integrateMotionKernel( int numParticles, - __global float4* pPos, - __global float4* pVel, - __global const btSimParams* simParams, - float timeStep ) -{ - int index = get_global_id(0); - if(index >= numParticles) - { - return; - } - float4 pos = pPos[index]; - float4 vel = pVel[index]; - pos.w = 1.0f; - vel.w = 0.0f; - // apply gravity - float4 gravity = simParams[0].m_gravity; - float particleRad = simParams[0].m_particleRad; - float globalDamping = simParams[0].m_globalDamping; - float boundaryDamping = simParams[0].m_boundaryDamping; - - vel += gravity * timeStep; - vel *= globalDamping; - // integrate position - pos += vel * timeStep; - // collide with world boundaries - float4 worldMin = simParams[0].m_worldMin; - float4 worldMax = simParams[0].m_worldMax; - - /* - if(pos.x < (worldMin.x + 2*particleRad)) - { - pos.x = worldMin.x + 2*particleRad; - vel.x *= boundaryDamping; - } - if(pos.x > (worldMax.x - 2*particleRad)) - { - pos.x = worldMax.x - 2*particleRad; - vel.x *= boundaryDamping; - } - */ - if(pos.y < (worldMin.y + 2*particleRad)) - { - pos.y = worldMin.y + 2*particleRad; - vel.y *= boundaryDamping; - } - /* - if(pos.y > (worldMax.y - 2*particleRad)) - { - pos.y = worldMax.y - 2*particleRad; - vel.y *= boundaryDamping; - } - if(pos.z < (worldMin.z + 2*particleRad)) - { - pos.z = worldMin.z + 2*particleRad; - vel.z *= boundaryDamping; - } - if(pos.z > (worldMax.z - 2*particleRad)) - { - pos.z = worldMax.z - 2*particleRad; - vel.z *= boundaryDamping; - } - */ - // write back position and velocity - pPos[index] = pos; - pVel[index] = vel; -} - -typedef struct -{ - float fx; - float fy; - float fz; - int uw; -} btAABBCL; - -__kernel void collideParticlesKernel( __global float4* pPos, __global float4* pVel, __global int2* pairs, const int numPairs) -{ - int index = get_global_id(0); - if (index - -#include "pairsKernel.h" - -//we use an offset, just for testing to make sure there is no assumption in the broadphase that 'index' starts at 0 -#define TEST_INDEX_OFFSET 1024 - -#ifdef B3_USE_MIDI -#include "../../../btgui/MidiTest/RtMidi.h" -bool chooseMidiPort( RtMidiIn *rtmidi ) -{ - if (!rtmidi) - return false; - /* - - std::cout << "\nWould you like to open a virtual input port? [y/N] "; - - std::string keyHit; - std::getline( std::cin, keyHit ); - if ( keyHit == "y" ) { - rtmidi->openVirtualPort(); - return true; - } - */ - - std::string portName; - unsigned int i = 0, nPorts = rtmidi->getPortCount(); - if ( nPorts == 0 ) { - std::cout << "No input ports available!" << std::endl; - return false; - } - - if ( nPorts == 1 ) { - std::cout << "\nOpening " << rtmidi->getPortName() << std::endl; - } - else { - for ( i=0; igetPortName(i); - std::cout << " Input port #" << i << ": " << portName << '\n'; - } - - do { - std::cout << "\nChoose a port number: "; - std::cin >> i; - } while ( i >= nPorts ); - } - -// std::getline( std::cin, keyHit ); // used to clear out stdin - rtmidi->openPort( i ); - - return true; -} - - -#endif - -static b3KeyboardCallback oldCallback = 0; - -char* gPairBenchFileName = 0; -extern bool useShadowMap; -float maxExtents = -1e30f; -int largeCount = 0; - -float timeStepPos = 0.000166666; -float mAmplitude = 251.f; -int dimensions[3]={10,10,10};//initialized with x_dim/y_dim/z_dim -const char* axisNames[3] = {"# x-axis","# y-axis","# z-axis"}; -extern bool gReset; - -static int curUseLargeAabbOption=0; -const char* useLargeAabbOptions[] = -{ - "NoLargeAabb", - "UseLargeAabb", -}; - -struct BroadphaseEntry -{ - const char* m_name; - b3GpuBroadphaseInterface::CreateFunc* m_createFunc; -}; - - -static PairBench* sPairDemo = 0; - -#define BP_COMBO_INDEX 123 - -static int curSelectedBroadphase = 0; -static BroadphaseEntry allBroadphases[]= -{ - {"Gpu Grid",b3GpuGridBroadphase::CreateFunc}, - {"Parallel Linear BVH",b3GpuParallelLinearBvhBroadphase::CreateFunc}, - {"CPU Brute Force",b3GpuSapBroadphase::CreateFuncBruteForceCpu}, - {"GPU Brute Force",b3GpuSapBroadphase::CreateFuncBruteForceGpu}, - {"GPU 1-SAP Original",b3GpuSapBroadphase::CreateFuncOriginal}, - {"GPU 1-SAP Barrier",b3GpuSapBroadphase::CreateFuncBarrier}, - {"GPU 1-SAP LDS",b3GpuSapBroadphase::CreateFuncLocalMemory} -}; - - -struct PairBenchInternalData -{ - b3GpuBroadphaseInterface* m_broadphaseGPU; - b3GpuBroadphaseInterface* m_validationBroadphase; - - cl_kernel m_moveObjectsKernel; - cl_kernel m_sineWaveKernel; - cl_kernel m_colorPairsKernel; - cl_kernel m_updateAabbSimple; - - GwenUserInterface* m_gui; - - b3OpenCLArray* m_instancePosOrnColor; - b3OpenCLArray* m_bodyTimes; - PairBenchInternalData() - :m_broadphaseGPU(0), - m_moveObjectsKernel(0), - m_sineWaveKernel(0), - m_colorPairsKernel(0), - m_instancePosOrnColor(0), - m_bodyTimes(0), - m_updateAabbSimple(0) - { - } - - int m_oldYposition; - - b3AlignedObjectArray m_myControls; -#ifdef B3_USE_MIDI - RtMidiIn* m_midiIn; -#endif //B3_USE_MIDI -}; - - -PairBench::PairBench() -:m_instancingRenderer(0), -m_window(0) -{ - m_data = new PairBenchInternalData; - - m_data->m_validationBroadphase = 0; -} -PairBench::~PairBench() -{ - delete m_data; -} - - - - - - - -static void PairKeyboardCallback(int key, int state) -{ - if (key=='R' && state) - { - gReset = true; - } - - //b3DefaultKeyboardCallback(key,state); - oldCallback(key,state); -} - -static inline float parseFloat(const char*& token) -{ - token += strspn(token, " \t"); - float f = (float)atof(token); - token += strcspn(token, " \t\r"); - return f; -} - -enum PairToggleButtons -{ - MY_RESET = 1024, -}; - - -#define PAIRS_CL_PROGRAM_PATH "Demos3/GpuDemos/broadphase/pairsKernel.cl" - - - - -struct PairComboBoxHander :public Gwen::Event::Handler -{ - - int m_buttonId; - int m_active; - - PairComboBoxHander (int buttonId) - :m_buttonId(buttonId), - m_active(false) - { - } - - void onSelect( Gwen::Controls::Base* pControl ) - { - if (m_active) - { - Gwen::Controls::ComboBox* but = (Gwen::Controls::ComboBox*) pControl; - - Gwen::String str = Gwen::Utility::UnicodeToString( but->GetSelectedItem()->GetText()); - - int numItems = sizeof(allBroadphases)/sizeof(BroadphaseEntry); - - //find selected item - for (int i=0;ideleteBroadphase(); - sPairDemo->createBroadphase(dimensions[0],dimensions[1],dimensions[2]); - break; - } - } - } - - } - - void onSelectUseLargeAabb( Gwen::Controls::Base* pControl ) - { - if (m_active) - { - Gwen::Controls::ComboBox* but = (Gwen::Controls::ComboBox*) pControl; - - Gwen::String str = Gwen::Utility::UnicodeToString( but->GetSelectedItem()->GetText()); - - int numItems = sizeof(useLargeAabbOptions)/sizeof(const char*); - - //find selected item - for (int i=0;ideleteBroadphase(); - sPairDemo->createBroadphase(dimensions[0],dimensions[1],dimensions[2]); - break; - } - } - - - - } - } - -}; - - -template -struct MySliderEventHandler : public Gwen::Event::Handler -{ - Gwen::Controls::TextBox* m_label; - Gwen::Controls::Slider* m_pSlider; - char m_variableName[1024]; - T* m_targetValue; - - MySliderEventHandler(const char* varName, Gwen::Controls::TextBox* label, Gwen::Controls::Slider* pSlider,T* target) - :m_label(label), - m_pSlider(pSlider), - m_targetValue(target) - { - memcpy(m_variableName,varName,strlen(varName)+1); - } - - - void SliderMoved( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::Slider* pSlider = (Gwen::Controls::Slider*)pControl; - //printf("value = %f\n", pSlider->GetValue());//UnitPrint( Utility::Format( L"Slider Value: %.2f", pSlider->GetValue() ) ); - float bla = pSlider->GetValue(); - T v = T(bla); - SetValue(v); - - } - - void SetValue(T v) - { - if (v < m_pSlider->GetRangeMin()) - { - printf("?\n"); - } - - if (v > m_pSlider->GetRangeMax()) - { - printf("?\n"); - - } - m_pSlider->SetValue(v,true); - (*m_targetValue) = v; - int val = int(v);//todo: specialize on template type - char txt[1024]; - sprintf(txt,"%s : %d", m_variableName,val); - m_label->SetText(txt); - - } -}; - -MySliderEventHandler* test = 0; - -#ifdef B3_USE_MIDI -//todo: create a mapping from midi channel to variable 'slider' or 'knob' - - -void PairMidiCallback( double deltatime, std::vector< unsigned char > *message, void *userData ) -{ - unsigned int nBytes = message->size(); - if (nBytes==3) - { - if (test && message->at(1)==16) - { - test->SetValue(message->at(2)); - } - } -} - -#endif - -void PairBench::initPhysics(const ConstructionInfo& ci) -{ - dimensions[0] = ci.arraySizeX; - dimensions[1] = ci.arraySizeY; - dimensions[2] = ci.arraySizeZ; - -#ifdef B3_USE_MIDI - m_data->m_midiIn = new RtMidiIn(); - if (!chooseMidiPort(m_data->m_midiIn)) - { - delete m_data->m_midiIn; - m_data->m_midiIn = 0; - } else - { - m_data->m_midiIn->setCallback( &PairMidiCallback,this ); - // Don't ignore sysex, timing, or active sensing messages. - m_data->m_midiIn->ignoreTypes( false, false, false ); - } -#endif //B3_USE_MIDI - m_instancingRenderer = ci.m_instancingRenderer; - sPairDemo = this; - useShadowMap = false; - - m_data->m_gui = ci.m_gui; - - //remember the old position in the GUI, to restore at exit - - GwenInternalData* data = m_data->m_gui->getInternalData(); - m_data->m_oldYposition = data->m_curYposition; - - - - data->m_curYposition+=40; - - { - - - int startItem = curSelectedBroadphase; - int numBroadphases = sizeof(allBroadphases)/sizeof(BroadphaseEntry); - - Gwen::Controls::ComboBox* combobox = new Gwen::Controls::ComboBox(data->m_demoPage->GetPage()); - PairComboBoxHander* handler = new PairComboBoxHander(555); - m_data->m_myControls.push_back(combobox); - - - combobox->onSelection.Add(handler,&PairComboBoxHander::onSelect); - int ypos = data->m_curYposition; - combobox->SetPos(10, ypos ); - combobox->SetWidth( 100 ); - - - for (int i=0;iAddItem(Gwen::Utility::StringToUnicode(allBroadphases[i].m_name)); - if (i==startItem) - combobox->OnItemSelected(item); - } - - handler->m_active = true; - - data->m_curYposition+=22; - } - - { - int startItem = curUseLargeAabbOption; - int numUseLargeAabb = sizeof(useLargeAabbOptions)/sizeof(const char*); - - Gwen::Controls::ComboBox* combobox = new Gwen::Controls::ComboBox(data->m_demoPage->GetPage()); - PairComboBoxHander* handler = new PairComboBoxHander(555); - m_data->m_myControls.push_back(combobox); - - - combobox->onSelection.Add(handler,&PairComboBoxHander::onSelectUseLargeAabb); - int ypos = data->m_curYposition; - combobox->SetPos(10, ypos ); - combobox->SetWidth( 100 ); - - for (int i=0;iAddItem(Gwen::Utility::StringToUnicode(useLargeAabbOptions[i])); - if (i==startItem) - combobox->OnItemSelected(item); - } - - handler->m_active = true; - - data->m_curYposition+=22; - } - data->m_curYposition+=22; - - if (1) - for (int i=0;i<3;i++) - { - { - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox(data->m_demoPage->GetPage()); - m_data->m_myControls.push_back(label); - label->SetText( "Text Label" ); - label->SetPos( 10, 10 + 25 ); - label->SetWidth(100); - label->SetPos(10,data->m_curYposition); - data->m_curYposition+=22; - - Gwen::Controls::HorizontalSlider* pSlider = new Gwen::Controls::HorizontalSlider( data->m_demoPage->GetPage()); - m_data->m_myControls.push_back(pSlider); - pSlider->SetPos( 10, data->m_curYposition ); - pSlider->SetSize( 100, 20 ); - pSlider->SetRange( 0, 100 ); - pSlider->SetValue( dimensions[i] ); - char labelName[1024]; - sprintf(labelName,"%s",axisNames[0]); - MySliderEventHandler* handler = new MySliderEventHandler(labelName,label,pSlider,&dimensions[i]); - pSlider->onValueChanged.Add( handler, &MySliderEventHandler::SliderMoved ); - handler->SliderMoved(pSlider); - float v = pSlider->GetValue(); - data->m_curYposition+=22; - } - } - if (1) - { - { - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox(data->m_demoPage->GetPage()); - m_data->m_myControls.push_back(label); - const char* labelName = "Scale: "; - label->SetText( labelName); - label->SetPos( 10, 10 + 25 ); - label->SetWidth(100); - label->SetPos(10,data->m_curYposition); - data->m_curYposition+=22; - - Gwen::Controls::HorizontalSlider* pSlider = new Gwen::Controls::HorizontalSlider( data->m_demoPage->GetPage()); - m_data->m_myControls.push_back(pSlider); - pSlider->SetPos( 10, data->m_curYposition ); - pSlider->SetSize( 100, 20 ); - pSlider->SetRange( 0, 300); - pSlider->SetValue( mAmplitude ); - - MySliderEventHandler* handler = new MySliderEventHandler(labelName,label,pSlider,&mAmplitude); - test = handler; - pSlider->onValueChanged.Add( handler, &MySliderEventHandler::SliderMoved ); - handler->SliderMoved(pSlider); - float v = pSlider->GetValue(); - data->m_curYposition+=22; - } - } - //pSlider->onValueChanged.Add( this, &Slider::SliderMoved ); - - - data->m_curYposition+=22; - - /*m_data->m_gui->registerToggleButton(MY_RESET,"reset"); - sOldCallback = m_data->m_gui->getToggleButtonCallback(); - m_data->m_gui->setToggleButtonCallback(PairButtonCallback); - */ - - int startItem = 0; - //m_data->m_gui->registerComboBox(BP_COMBO_INDEX,numBroadphases,&mydemonames[0],startItem); - - //sOldComboCallback = m_data->m_gui->getComboBoxCallback(); - - //m_data->m_gui->setComboBoxCallback(PairComboBoxCallback); - - - initCL(ci.preferredOpenCLDeviceIndex,ci.preferredOpenCLPlatformIndex); - - if (m_clData->m_clContext) - { - cl_int err; - cl_program pairBenchProg=b3OpenCLUtils::compileCLProgramFromString(m_clData->m_clContext,m_clData->m_clDevice,pairsKernelsCL,&err,"",PAIRS_CL_PROGRAM_PATH); - int errNum=0; - m_data->m_moveObjectsKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext,m_clData->m_clDevice,pairsKernelsCL,"moveObjectsKernel",&errNum,pairBenchProg); - m_data->m_sineWaveKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext,m_clData->m_clDevice,pairsKernelsCL,"sineWaveKernel",&errNum,pairBenchProg); - m_data->m_colorPairsKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext,m_clData->m_clDevice,pairsKernelsCL,"colorPairsKernel2",&errNum,pairBenchProg); - m_data->m_updateAabbSimple = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext,m_clData->m_clDevice,pairsKernelsCL,"updateAabbSimple",&errNum,pairBenchProg); - - //Method for validating the overlapping pairs requires that the - //reference broadphase does not maintain internal state aside from AABB data. - //That is, overwriting the AABB state in the broadphase using - // b3GpuBroadphaseInterface::getAllAabbsGPU(), - // b3GpuBroadphaseInterface::getSmallAabbIndicesGPU(), and - // b3GpuBroadphaseInterface::getLargeAabbIndicesGPU() - //and then calling b3GpuBroadphaseInterface::calculateOverlappingPairs() should - //always produce the same result regardless of the current state of the broadphase. - m_data->m_validationBroadphase = b3GpuParallelLinearBvhBroadphase::CreateFunc(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - } - - if (ci.m_window) - { - m_window = ci.m_window; - oldCallback = ci.m_window->getKeyboardCallback(); - ci.m_window->setKeyboardCallback(PairKeyboardCallback); - - } - - - -#ifndef B3_NO_PROFILE - b3ProfileManager::CleanupMemory(); -#endif //B3_NO_PROFILE - - createBroadphase(ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ); - -} - -void PairBench::createBroadphase(int arraySizeX, int arraySizeY, int arraySizeZ) -{ - - - m_data->m_broadphaseGPU = (allBroadphases[curSelectedBroadphase].m_createFunc)(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_vertices)/sizeof(int); - int shapeId = m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=TEST_INDEX_OFFSET; - - - if (gPairBenchFileName) - { - - - //char* fileName = "32006GPUAABBs.txt"; - char relativeFileName[1024]; - const char* prefix[]={"./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int prefixIndex=-1; - { - - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;i500) - { - b3Vector4 color=b3MakeVector4(0,1,0,0.1); - int id = m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - m_data->m_broadphaseGPU->createLargeProxy(aabbMin,aabbMax,index,group,mask); - } else - { - b3Vector4 color=b3MakeVector4(1,0,0,1); - int id = m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - m_data->m_broadphaseGPU->createProxy(aabbMin,aabbMax,index,group,mask); - index++; - } - - - - - patcnt++; - } - } - prefixIndex = i; - break; - } - - } - - if (prefixIndex<0) - { - b3Printf("Cannot find %s\n",gPairBenchFileName); - } - - } - - - } - else - { - for (int i=0;iregisterGraphicsInstance(shapeId,position,orn,color,scaling); - - - b3Vector3 aabbMin = position-scaling; - b3Vector3 aabbMax = position+scaling; - - if (large) - { - m_data->m_broadphaseGPU->createLargeProxy(aabbMin,aabbMax,index,group,mask); - - } else - { - m_data->m_broadphaseGPU->createProxy(aabbMin,aabbMax,index,group,mask); - } - index++; - } - } - } - } - - float camPos[4]={15.5,12.5,15.5,0}; - m_instancingRenderer->setCameraTargetPosition(camPos); - if (gPairBenchFileName) - { - m_instancingRenderer->setCameraDistance(830); - } else - { - m_instancingRenderer->setCameraDistance(130); - } - - m_instancingRenderer->writeTransforms(); - m_data->m_broadphaseGPU->writeAabbsToGpu(); - -} - -void PairBench::deleteBroadphase() -{ - delete m_data->m_broadphaseGPU; - m_data->m_broadphaseGPU = 0; - delete m_data->m_instancePosOrnColor; - m_data->m_instancePosOrnColor = 0; - delete m_data->m_bodyTimes; - m_data->m_bodyTimes = 0; - - m_data->m_broadphaseGPU = 0; - m_instancingRenderer->removeAllInstances(); -} - -void PairBench::exitPhysics() -{ - if(m_data->m_validationBroadphase) - { - delete m_data->m_validationBroadphase; - m_data->m_validationBroadphase = 0; - } - -#ifdef B3_USE_MIDI - if (m_data->m_midiIn) - { - delete m_data->m_midiIn; - m_data->m_midiIn = 0; - } -#endif //B3_USE_MIDI - m_data->m_gui->getInternalData()->m_curYposition = m_data->m_oldYposition; - - for (int i=0;im_myControls.size();i++) - { - delete m_data->m_myControls[i]; - } - - sPairDemo = 0; - - m_window->setKeyboardCallback(oldCallback); - exitCL(); - -} - - -void PairBench::renderScene() -{ - m_instancingRenderer->renderScene(); -} - -struct OverlappingPairSortPredicate -{ - inline bool operator() (const b3Int4& a, const b3Int4& b) const - { - if(a.x != b.x) return (a.x < b.x); - if(a.y != b.y) return (a.y < b.y); - if(a.z != b.z) return (a.z < b.z); - return (a.w < b.w); - } -}; - -void PairBench::clientMoveAndDisplay() -{ - //color all objects blue - - bool animate=true; - int numObjects= 0; - { - B3_PROFILE("Num Objects"); - numObjects = m_instancingRenderer->getInternalData()->m_totalNumInstances; - } - b3Vector4* positions = 0; - if (numObjects) - { - B3_PROFILE("Sync"); - GLuint vbo = m_instancingRenderer->getInternalData()->m_vbo; - - - - int arraySizeInBytes = numObjects * (3)*sizeof(b3Vector4); - - glBindBuffer(GL_ARRAY_BUFFER, vbo); - cl_bool blocking= CL_TRUE; - char* hostPtr= 0; - { - B3_PROFILE("glMapBufferRange"); - hostPtr = (char*)glMapBufferRange( GL_ARRAY_BUFFER,m_instancingRenderer->getMaxShapeCapacity(),arraySizeInBytes, GL_MAP_WRITE_BIT|GL_MAP_READ_BIT );//GL_READ_WRITE);//GL_WRITE_ONLY - } - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - positions = (b3Vector4*)hostPtr; - - if (m_data->m_instancePosOrnColor && m_data->m_instancePosOrnColor->size() != 3*numObjects) - { - delete m_data->m_instancePosOrnColor; - m_data->m_instancePosOrnColor=0; - } - if (!m_data->m_instancePosOrnColor) - { - m_data->m_instancePosOrnColor = new b3OpenCLArray(m_clData->m_clContext,m_clData->m_clQueue); - m_data->m_instancePosOrnColor->resize(3*numObjects); - m_data->m_instancePosOrnColor->copyFromHostPointer(positions,3*numObjects,0); - m_data->m_bodyTimes = new b3OpenCLArray(m_clData->m_clContext,m_clData->m_clQueue); - m_data->m_bodyTimes ->resize(numObjects); - b3AlignedObjectArray tmp; - tmp.resize(numObjects); - for (int i=0;im_bodyTimes->copyFromHost(tmp); - } - - if (!gPairBenchFileName) - { - if (1) - { - if (1) - { - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_sineWaveKernel,"m_sineWaveKernel"); - launcher.setBuffer(m_data->m_instancePosOrnColor->getBufferCL() ); - launcher.setBuffer(m_data->m_bodyTimes->getBufferCL() ); - - launcher.setConst(timeStepPos); - launcher.setConst(mAmplitude); - launcher.setConst( numObjects); - launcher.launch1D( numObjects); - clFinish(m_clData->m_clQueue); - } - else - { - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_moveObjectsKernel,"m_moveObjectsKernel"); - launcher.setBuffer(m_data->m_instancePosOrnColor->getBufferCL() ); - launcher.setConst( numObjects); - launcher.launch1D( numObjects); - clFinish(m_clData->m_clQueue); - } - } - } - } - - bool updateOnGpu=true; - - if (1) - { - if (updateOnGpu) - { - B3_PROFILE("updateOnGpu"); - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_updateAabbSimple,"m_updateAabbSimple"); - launcher.setBuffer(m_data->m_instancePosOrnColor->getBufferCL() ); - launcher.setConst( numObjects); - launcher.setBuffer(m_data->m_broadphaseGPU->getAabbBufferWS()); - launcher.launch1D( numObjects); - clFinish(m_clData->m_clQueue); - - } else - { - B3_PROFILE("updateOnCpu"); - if (!gPairBenchFileName) - { - int allAabbs = m_data->m_broadphaseGPU->getAllAabbsCPU().size(); - - - b3AlignedObjectArray posOrnColorsCpu; - if (m_data->m_instancePosOrnColor) - m_data->m_instancePosOrnColor->copyToHost(posOrnColorsCpu); - - - - for (int nodeId=0;nodeIdm_broadphaseGPU->getAllAabbsCPU()[nodeId]; - b3Vector3 halfExtents = 0.5f*(orgAabb.m_maxVec-orgAabb.m_minVec); - int orgNodeIndex = orgAabb.m_minIndices[3]; - int orgBroadphaseIndex = orgAabb.m_signedMaxIndices[3]; - - m_data->m_broadphaseGPU->getAllAabbsCPU()[nodeId].m_minVec = position-halfExtents; - m_data->m_broadphaseGPU->getAllAabbsCPU()[nodeId].m_minIndices[3] = orgNodeIndex; - m_data->m_broadphaseGPU->getAllAabbsCPU()[nodeId].m_maxVec = position+halfExtents; - m_data->m_broadphaseGPU->getAllAabbsCPU()[nodeId].m_signedMaxIndices[3]= orgBroadphaseIndex; - } - } - m_data->m_broadphaseGPU->writeAabbsToGpu(); - } - - - - } - } - - int prealloc = 3*1024*1024; - int maxOverlap = b3Min(prealloc,16*numObjects); - - unsigned long dt = 0; - if (numObjects) - { - b3Clock cl; - dt = cl.getTimeMicroseconds(); - B3_PROFILE("calculateOverlappingPairs"); - int sz = sizeof(b3Int4)*64*numObjects; - - - m_data->m_broadphaseGPU->calculateOverlappingPairs(maxOverlap); - int numPairs = m_data->m_broadphaseGPU->getNumOverlap(); - //printf("numPairs = %d\n", numPairs); - dt = cl.getTimeMicroseconds()-dt; - - } - - const bool VALIDATE_BROADPHASE = false; //Check that overlapping pairs of 2 broadphases are the same - if(numObjects && VALIDATE_BROADPHASE) - { - B3_PROFILE("validate broadphases"); - - { - B3_PROFILE("calculateOverlappingPairs m_validationBroadphase"); - //m_data->m_validationBroadphase->getAllAabbsCPU() = m_data->m_broadphaseGPU->getAllAabbsCPU(); - - m_data->m_validationBroadphase->getAllAabbsGPU().copyFromOpenCLArray( m_data->m_broadphaseGPU->getAllAabbsGPU() ); - m_data->m_validationBroadphase->getSmallAabbIndicesGPU().copyFromOpenCLArray( m_data->m_broadphaseGPU->getSmallAabbIndicesGPU() ); - m_data->m_validationBroadphase->getLargeAabbIndicesGPU().copyFromOpenCLArray( m_data->m_broadphaseGPU->getLargeAabbIndicesGPU() ); - - m_data->m_validationBroadphase->calculateOverlappingPairs(maxOverlap); - } - - static b3AlignedObjectArray overlappingPairs; - static b3AlignedObjectArray overlappingPairsReference; - m_data->m_broadphaseGPU->getOverlappingPairsGPU().copyToHost(overlappingPairs); - m_data->m_validationBroadphase->getOverlappingPairsGPU().copyToHost(overlappingPairsReference); - - //Reorder pairs so that (pair.x < pair.y) is always true - { - B3_PROFILE("reorder pairs"); - - for(int i = 0; i < overlappingPairs.size(); ++i) - { - b3Int4 pair = overlappingPairs[i]; - if(pair.x > pair.y) - { - b3Swap(pair.x, pair.y); - b3Swap(pair.z, pair.w); - overlappingPairs[i] = pair; - } - } - for(int i = 0; i < overlappingPairsReference.size(); ++i) - { - b3Int4 pair = overlappingPairsReference[i]; - if(pair.x > pair.y) - { - b3Swap(pair.x, pair.y); - b3Swap(pair.z, pair.w); - overlappingPairsReference[i] = pair; - } - } - } - - // - { - B3_PROFILE("Sort overlapping pairs from most to least significant bit"); - - overlappingPairs.quickSort( OverlappingPairSortPredicate() ); - overlappingPairsReference.quickSort( OverlappingPairSortPredicate() ); - } - - //Compare - { - B3_PROFILE("compare pairs"); - - int numPairs = overlappingPairs.size(); - int numPairsReference = overlappingPairsReference.size(); - - bool success = true; - - if(numPairs == numPairsReference) - { - for(int i = 0; i < numPairsReference; ++i) - { - const b3Int4& pairA = overlappingPairs[i]; - const b3Int4& pairB = overlappingPairsReference[i]; - if( pairA.x != pairB.x - || pairA.y != pairB.y - || pairA.z != pairB.z - || pairA.w != pairB.w ) - { - b3Error("Error: one or more overlappingPairs differs from reference.\n"); - success = false; - break; - } - } - } - else - { - b3Error("Error: numPairs %d != numPairsReference %d \n", numPairs, numPairsReference); - success = false; - } - - printf("Broadphase validation: %d \n", success); - } - } - - if (m_data->m_gui) - { - B3_PROFILE("update Gui"); - int allAabbs = m_data->m_broadphaseGPU->getAllAabbsCPU().size(); - int numOverlap = m_data->m_broadphaseGPU->getNumOverlap(); - - float time = dt/1000.f; - //printf("time = %f\n", time); - - char msg[1024]; - sprintf(msg,"#objects = %d, #overlapping pairs = %d, time = %f ms", allAabbs,numOverlap,time ); - //printf("msg=%s\n",msg); - m_data->m_gui->setStatusBarMessage(msg,true); - } - - - if (numObjects) - { - B3_PROFILE("animate"); - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - //color overlapping objects in red - - - if (m_data->m_broadphaseGPU->getNumOverlap()) - { - bool colorPairsOnHost = false; - if (colorPairsOnHost ) - { - - } else - { - int numPairs = m_data->m_broadphaseGPU->getNumOverlap(); - cl_mem pairBuf = m_data->m_broadphaseGPU->getOverlappingPairBuffer(); - - b3LauncherCL launcher(m_clData->m_clQueue, m_data->m_colorPairsKernel,"m_colorPairsKernel"); - launcher.setBuffer(m_data->m_instancePosOrnColor->getBufferCL() ); - launcher.setConst( numObjects); - launcher.setBuffer( pairBuf); - int indexOffset = TEST_INDEX_OFFSET; - launcher.setConst(indexOffset); - launcher.setConst( numPairs); - launcher.launch1D( numPairs); - clFinish(m_clData->m_clQueue); - } - } - - if (numObjects) - { - m_data->m_instancePosOrnColor->copyToHostPointer(positions,3*numObjects,0); - } - - glUnmapBuffer( GL_ARRAY_BUFFER); - err = glGetError(); - assert(err==GL_NO_ERROR); - } - -} diff --git a/Demos3/GpuDemos/broadphase/PairBench.h b/Demos3/GpuDemos/broadphase/PairBench.h deleted file mode 100644 index 724ac9130..000000000 --- a/Demos3/GpuDemos/broadphase/PairBench.h +++ /dev/null @@ -1,48 +0,0 @@ -#ifndef PAIR_BENCH_H -#define PAIR_BENCH_H - -#include "../GpuDemo.h" - -class PairBench : public GpuDemo -{ - - class GLInstancingRenderer* m_instancingRenderer; - class b3gWindowInterface* m_window; - - struct PairBenchInternalData* m_data; - - - -public: - - PairBench(); - virtual ~PairBench(); - - virtual void initPhysics(const ConstructionInfo& ci); - virtual void exitPhysics(); - - - void createBroadphase(int xdim, int ydim, int zdim); - void deleteBroadphase(); - - virtual const char* getName() - { - return "PairBench"; - } - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new PairBench; - return demo; - } - - - - virtual void renderScene(); - - virtual void clientMoveAndDisplay(); - - -}; - -#endif - diff --git a/Demos3/GpuDemos/broadphase/pairsKernel.cl b/Demos3/GpuDemos/broadphase/pairsKernel.cl deleted file mode 100644 index b99a22e6b..000000000 --- a/Demos3/GpuDemos/broadphase/pairsKernel.cl +++ /dev/null @@ -1,79 +0,0 @@ -__kernel void moveObjectsKernel(__global float4* posOrnColors, int numObjects) -{ - int iGID = get_global_id(0); - if (iGID>=numObjects) - return; - __global float4* positions = &posOrnColors[0]; - if (iGID<0.5*numObjects) - { - positions[iGID].y +=0.01f; - } - __global float4* colors = &posOrnColors[numObjects*2]; - colors[iGID] = (float4)(0,0,1,1); -} - -__kernel void colorPairsKernel2(__global float4* posOrnColors, int numObjects, __global const int4* pairs, int indexOffset, int numPairs) -{ - int iPairId = get_global_id(0); - if (iPairId>=numPairs) - return; - __global float4* colors = &posOrnColors[numObjects*2]; - - int iObjectA = pairs[iPairId].x-indexOffset; - int iObjectB = pairs[iPairId].y-indexOffset; - colors[iObjectA] = (float4)(1,0,0,1); - colors[iObjectB] = (float4)(1,0,0,1); -} - -__kernel void - sineWaveKernel( __global float4* posOrnColors, __global float* pBodyTimes,float timeStepPos, float mAmplitude,const int numNodes) -{ - int nodeID = get_global_id(0); - if( nodeID < numNodes ) - { - pBodyTimes[nodeID] += timeStepPos; - float4 position = posOrnColors[nodeID]; - position.x = native_cos(pBodyTimes[nodeID]*2.17f)*mAmplitude + native_sin(pBodyTimes[nodeID])*mAmplitude*0.5f; - position.y = native_cos(pBodyTimes[nodeID]*1.38f)*mAmplitude + native_sin(pBodyTimes[nodeID]*mAmplitude); - position.z = native_cos(pBodyTimes[nodeID]*2.17f)*mAmplitude + native_sin(pBodyTimes[nodeID]*0.777f)*mAmplitude; - - posOrnColors[nodeID] = position; - __global float4* colors = &posOrnColors[numNodes*2]; - colors[nodeID] = (float4)(0,0,1,1); - } -} - -typedef struct -{ - float fx; - float fy; - float fz; - int uw; -} b3AABBCL; - -__kernel void updateAabbSimple( __global float4* posOrnColors, const int numNodes, __global b3AABBCL* pAABB) -{ - int nodeId = get_global_id(0); - if( nodeId < numNodes ) - { - - b3AABBCL orgAabbMin = pAABB[nodeId*2]; - b3AABBCL orgAabbMax = pAABB[nodeId*2+1]; - int orgNodeId = orgAabbMin.uw; - int orgBroadphaseIndex = orgAabbMax.uw; - - float4 position = posOrnColors[nodeId]; - float4 argAabbMinVec = (float4)(orgAabbMin.fx,orgAabbMin.fy,orgAabbMin.fz,0.f); - float4 argAabbMaxVec = (float4)(orgAabbMax.fx,orgAabbMax.fy,orgAabbMax.fz,0.f); - float4 halfExtents = 0.5f*(argAabbMaxVec-argAabbMinVec); - - pAABB[nodeId*2].fx = position.x-halfExtents.x; - pAABB[nodeId*2].fy = position.y-halfExtents.y; - pAABB[nodeId*2].fz = position.z-halfExtents.z; - pAABB[nodeId*2].uw = orgNodeId; - pAABB[nodeId*2+1].fx = position.x+halfExtents.x; - pAABB[nodeId*2+1].fy = position.y+halfExtents.y; - pAABB[nodeId*2+1].fz = position.z+halfExtents.z; - pAABB[nodeId*2+1].uw = orgBroadphaseIndex; - } -} diff --git a/Demos3/GpuDemos/broadphase/pairsKernel.h b/Demos3/GpuDemos/broadphase/pairsKernel.h deleted file mode 100644 index 2a98f2221..000000000 --- a/Demos3/GpuDemos/broadphase/pairsKernel.h +++ /dev/null @@ -1,77 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* pairsKernelsCL= \ -"__kernel void moveObjectsKernel(__global float4* posOrnColors, int numObjects)\n" -"{\n" -" int iGID = get_global_id(0);\n" -" if (iGID>=numObjects)\n" -" return;\n" -" __global float4* positions = &posOrnColors[0];\n" -" if (iGID<0.5*numObjects)\n" -" {\n" -" positions[iGID].y +=0.01f;\n" -" }\n" -" __global float4* colors = &posOrnColors[numObjects*2];\n" -" colors[iGID] = (float4)(0,0,1,1);\n" -"}\n" -"__kernel void colorPairsKernel2(__global float4* posOrnColors, int numObjects, __global const int4* pairs, int indexOffset, int numPairs)\n" -"{\n" -" int iPairId = get_global_id(0);\n" -" if (iPairId>=numPairs)\n" -" return;\n" -" __global float4* colors = &posOrnColors[numObjects*2];\n" -" int iObjectA = pairs[iPairId].x-indexOffset;\n" -" int iObjectB = pairs[iPairId].y-indexOffset;\n" -" colors[iObjectA] = (float4)(1,0,0,1);\n" -" colors[iObjectB] = (float4)(1,0,0,1);\n" -"}\n" -"__kernel void \n" -" sineWaveKernel( __global float4* posOrnColors, __global float* pBodyTimes,float timeStepPos, float mAmplitude,const int numNodes)\n" -"{\n" -" int nodeID = get_global_id(0);\n" -" if( nodeID < numNodes )\n" -" {\n" -" pBodyTimes[nodeID] += timeStepPos;\n" -" float4 position = posOrnColors[nodeID];\n" -" position.x = native_cos(pBodyTimes[nodeID]*2.17f)*mAmplitude + native_sin(pBodyTimes[nodeID])*mAmplitude*0.5f;\n" -" position.y = native_cos(pBodyTimes[nodeID]*1.38f)*mAmplitude + native_sin(pBodyTimes[nodeID]*mAmplitude);\n" -" position.z = native_cos(pBodyTimes[nodeID]*2.17f)*mAmplitude + native_sin(pBodyTimes[nodeID]*0.777f)*mAmplitude;\n" -" \n" -" posOrnColors[nodeID] = position;\n" -" __global float4* colors = &posOrnColors[numNodes*2];\n" -" colors[nodeID] = (float4)(0,0,1,1);\n" -" }\n" -"}\n" -"typedef struct \n" -"{\n" -" float fx;\n" -" float fy;\n" -" float fz;\n" -" int uw;\n" -"} b3AABBCL;\n" -"__kernel void updateAabbSimple( __global float4* posOrnColors, const int numNodes, __global b3AABBCL* pAABB)\n" -"{\n" -" int nodeId = get_global_id(0);\n" -" if( nodeId < numNodes )\n" -" {\n" -" \n" -" b3AABBCL orgAabbMin = pAABB[nodeId*2];\n" -" b3AABBCL orgAabbMax = pAABB[nodeId*2+1];\n" -" int orgNodeId = orgAabbMin.uw;\n" -" int orgBroadphaseIndex = orgAabbMax.uw;\n" -" \n" -" float4 position = posOrnColors[nodeId];\n" -" float4 argAabbMinVec = (float4)(orgAabbMin.fx,orgAabbMin.fy,orgAabbMin.fz,0.f);\n" -" float4 argAabbMaxVec = (float4)(orgAabbMax.fx,orgAabbMax.fy,orgAabbMax.fz,0.f);\n" -" float4 halfExtents = 0.5f*(argAabbMaxVec-argAabbMinVec);\n" -" \n" -" pAABB[nodeId*2].fx = position.x-halfExtents.x;\n" -" pAABB[nodeId*2].fy = position.y-halfExtents.y;\n" -" pAABB[nodeId*2].fz = position.z-halfExtents.z;\n" -" pAABB[nodeId*2].uw = orgNodeId;\n" -" pAABB[nodeId*2+1].fx = position.x+halfExtents.x;\n" -" pAABB[nodeId*2+1].fy = position.y+halfExtents.y;\n" -" pAABB[nodeId*2+1].fz = position.z+halfExtents.z;\n" -" pAABB[nodeId*2+1].uw = orgBroadphaseIndex; \n" -" }\n" -"}\n" -; diff --git a/Demos3/GpuDemos/constraints/ConstraintsDemo.cpp b/Demos3/GpuDemos/constraints/ConstraintsDemo.cpp deleted file mode 100644 index 14101b00b..000000000 --- a/Demos3/GpuDemos/constraints/ConstraintsDemo.cpp +++ /dev/null @@ -1,290 +0,0 @@ -/* -Copyright (c) 2013 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - -#include "ConstraintsDemo.h" -#include "OpenGLWindow/ShapeData.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "../rigidbody/GpuRigidBodyDemoInternalData.h" -#include "Bullet3AppSupport/gwenUserInterface.h" -#include "Bullet3Dynamics/ConstraintSolver/b3Point2PointConstraint.h" -#include "Bullet3Dynamics/ConstraintSolver/b3Generic6DofConstraint.h" -#include "Bullet3Dynamics/ConstraintSolver/b3FixedConstraint.h" - -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "Bullet3OpenCL/Raycast/b3GpuRaycast.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3ConvexUtility.h" - -#include "OpenGLWindow/GLRenderToTexture.h" - -void GpuConstraintsDemo::setupScene(const ConstructionInfo& ci) -{ - m_primRenderer = ci.m_primRenderer; - - m_raycaster = new b3GpuRaycast(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - - int index=0; - createStaticEnvironment(ci); - - index+=createDynamicsObjects(ci); - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); -// m_data->m_rigidBodyPipeline->setGravity(b3Vector3(4,-10,0)); - float camPos[4]={ci.arraySizeX,0.5*ci.arraySizeY*ci.gapY,ci.arraySizeZ,0}; - //float camPos[4]={1,12.5,1.5,0}; - - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(180); - - m_instancingRenderer->setCameraPitch(200);//90); - m_instancingRenderer->updateCamera(); - - char msg[1024]; - int numInstances = index; - sprintf(msg,"Num objects = %d",numInstances); - if (ci.m_gui) - ci.m_gui->setStatusBarMessage(msg,true); -} - -void GpuConstraintsDemo::destroyScene() -{ - delete m_raycaster; - m_raycaster = 0; -} - -int GpuConstraintsDemo::createDynamicsObjects(const ConstructionInfo& ci) -{ -/* int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(barrel_vertices)/strideInBytes; - int numIndices = sizeof(barrel_indices)/sizeof(int); - return createDynamicsObjects2(ci,barrel_vertices,numVertices,barrel_indices,numIndices); - */ - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - return createDynamicsObjects2(ci,cube_vertices,numVertices,cube_indices,numIndices); - -} - - - -int GpuConstraintsDemo::createDynamicsObjects2(const ConstructionInfo& ci, const float* vertices, int numVertices, const int* indices, int numIndices) -{ - int strideInBytes = 9*sizeof(float); - - int shapeId = ci.m_instancingRenderer->registerShape(&vertices[0],numVertices,indices,numIndices); - int group=1; - int mask=1; - int index=0; - - - - - - { - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), - }; - - int curColor = 0; - float scaling[4] = {1,1,1,1}; - int insta = 0; - - b3ConvexUtility* utilPtr = new b3ConvexUtility(); - - { - b3AlignedObjectArray verts; - - unsigned char* vts = (unsigned char*) vertices; - for (int i=0;iinitializePolyhedralFeatures(&verts[0],verts.size(),merge); - } - } - - int colIndex=-1; - if (ci.m_useInstancedCollisionShapes) - colIndex = m_data->m_np->registerConvexHullShape(utilPtr); - - int constraintType=0; - for (int i=0;im_np->registerConvexHullShape(&vertices[0],strideInBytes,numVertices, scaling); - if (!ci.m_useInstancedCollisionShapes) - colIndex = m_data->m_np->registerConvexHullShape(utilPtr); - - float mass = 1.f; - if (j==0 || j==ci.arraySizeY-1) - { - mass=0.f; - } - //b3Vector3 position((j&1)+i*2.2,1+j*2.,(j&1)+k*2.2); - //b3Vector3 position((-ci.arraySizeX/2*ci.gapX)+i*ci.gapX,1+j*2.,(-ci.arraySizeZ/2*ci.gapZ)+k*ci.gapZ); - b3Vector3 position=b3MakeVector3(-ci.arraySizeX/2*2+1+j*2., - 10+i*ci.gapY, - (-ci.arraySizeZ/2*ci.gapZ)+k*ci.gapZ); - - b3Quaternion orn(0,0,0,1); - - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - b3Vector4 scaling=b3MakeVector4(1,1,1,1); - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - bool useGpu = false; - b3TypedConstraint* c = 0; - - if (prevBody>=0) - { - switch (constraintType) - { - case 0: - { - ///enable next line to force CPU constraint solving - //c = new b3Point2PointConstraint(pid,prevBody,b3Vector3(-1.1,0,0),b3Vector3(1.1,0,0)); - float breakingThreshold=44; -// c->setBreakingImpulseThreshold(breakingThreshold); - b3Vector3 pivotInA=b3MakeVector3(-1.1,0,0); - b3Vector3 pivotInB=b3MakeVector3(1.1,0,0); - int cid = m_data->m_rigidBodyPipeline->createPoint2PointConstraint(pid,prevBody,pivotInA,pivotInB,breakingThreshold); - break; - } - case 1: - { - - b3Vector3 pivotInA=b3MakeVector3(-1.05,0,0); - b3Vector3 pivotInB=b3MakeVector3(1.05,0,0); - - b3Transform frameInA,frameInB; - frameInA.setIdentity(); - frameInB.setIdentity(); - frameInA.setOrigin(pivotInA); - frameInB.setOrigin(pivotInB); - b3Quaternion relTargetAB = frameInA.getRotation()*frameInB.getRotation().inverse(); - - //c = new b3FixedConstraint(pid,prevBody,frameInA,frameInB); - float breakingThreshold = 45;//37.f; - //c->setBreakingImpulseThreshold(37.1); - int cid = m_data->m_rigidBodyPipeline->createFixedConstraint(pid,prevBody,pivotInA,pivotInB,relTargetAB,breakingThreshold); - - - - break; - } - case 2: - { - /* - b3Transform frameInA,frameInB; - frameInA.setIdentity(); - frameInB.setIdentity(); - frameInA.setOrigin(b3Vector3(0,-1.1,0)); - frameInB.setOrigin(b3Vector3(0,1.1,0)); - - b3Generic6DofConstraint* dof6 = new b3Generic6DofConstraint(pid,prevBody,frameInA,frameInB,false,m_data->m_np->getBodiesCpu()); - for (int i=0;i<6;i++) - dof6->setLimit(i,0,0); - c=dof6; - */ - break; - } - default: - { - - b3Assert(0); - } - }; - if (c) - { - m_data->m_rigidBodyPipeline->addConstraint(c); - } - - - } - - - prevBody = pid; - - index++; - } - } - } - delete utilPtr; - } - return index; -} - - -void GpuConstraintsDemo::createStaticEnvironment(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - - - { - b3Vector4 scaling=b3MakeVector4(400,400,400,1); - int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,-405,0); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0.f,position,orn,colIndex,index,false); - - } -} diff --git a/Demos3/GpuDemos/constraints/ConstraintsDemo.h b/Demos3/GpuDemos/constraints/ConstraintsDemo.h deleted file mode 100644 index 8a8892e84..000000000 --- a/Demos3/GpuDemos/constraints/ConstraintsDemo.h +++ /dev/null @@ -1,46 +0,0 @@ -#ifndef B3_GPU_CONSTRAINTS_DEMO_H -#define B3_GPU_CONSTRAINTS_DEMO_H - -#include "../rigidbody/GpuRigidBodyDemo.h" -#include "Bullet3Common/b3AlignedObjectArray.h" - - -class GpuConstraintsDemo : public GpuRigidBodyDemo -{ -protected: - class GLPrimitiveRenderer* m_primRenderer; - - class b3GpuRaycast* m_raycaster; - -public: - - GpuConstraintsDemo() :m_primRenderer(0), m_raycaster(0) - { - } - virtual ~GpuConstraintsDemo(){} - virtual const char* getName() - { - return "GpuConstraints"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuConstraintsDemo; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void destroyScene(); - - virtual int createDynamicsObjects(const ConstructionInfo& ci); - - virtual int createDynamicsObjects2(const ConstructionInfo& ci,const float* vertices, int numVertices, const int* indices,int numIndices); - - virtual void createStaticEnvironment(const ConstructionInfo& ci); - -}; - - - -#endif //B3_GPU_CONSTRAINTS_DEMO_H diff --git a/Demos3/GpuDemos/main_opengl3core.cpp b/Demos3/GpuDemos/main_opengl3core.cpp deleted file mode 100644 index fcd620ae3..000000000 --- a/Demos3/GpuDemos/main_opengl3core.cpp +++ /dev/null @@ -1,1169 +0,0 @@ - -//#include "GpuDemo.h" - -#ifdef _WIN32 -#include //for GetLocalTime/GetSystemTime -#else -#include //gettimeofday -#endif - -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#elif defined _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#elif defined __linux -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif - -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "GpuDemoInternalData.h" - -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GwenOpenGL3CoreRenderer.h" -//#include "b3GpuDynamicsWorld.h" -#include -#include -#include "OpenGLWindow/fontstash.h" -#include "OpenGLWindow/opengl_fontstashcallbacks.h" -#include "Bullet3AppSupport/gwenUserInterface.h" -#include "ParticleDemo.h" -#include "broadphase/PairBench.h" -#include "rigidbody/GpuRigidBodyDemo.h" -#include "rigidbody/ConcaveScene.h" -#include "rigidbody/GpuConvexScene.h" -#include "rigidbody/GpuCompoundScene.h" -#include "rigidbody/GpuSphereScene.h" -#include "rigidbody/Bullet2FileDemo.h" -#include "softbody/GpuSoftBodyDemo.h" -#include "../btgui/Bullet3AppSupport/b3Quickprof.h" - -#include "../btgui/OpenGLWindow/GLRenderToTexture.h" -#include "raytrace/RaytracedShadowDemo.h" -//#include "shadows/ShadowMapDemo.h" -#include "constraints/ConstraintsDemo.h" - -bool exportFrame=false; -bool exportMovie = false; -int frameIndex = 0; -GLRenderToTexture* renderTexture =0; -//#include "BroadphaseBenchmark.h" - -int g_OpenGLWidth=1024; -int g_OpenGLHeight = 768; -bool dump_timings = false; -int maxFrameCount = 102; -extern char OpenSansData[]; -extern char* gPairBenchFileName; -extern int shadowMapWidth; -extern int shadowMapHeight; -extern bool gDebugLauncherCL; -extern bool gAllowCpuOpenCL; -extern bool gUseLargeBatches; - -extern bool gDebugForceLoadingFromSource; -extern bool gDebugSkipLoadingBinary; -extern bool useShadowMap; -extern float shadowMapWorldSize; -extern bool gUseJacobi; -extern bool useUniformGrid; - -extern bool gUseDbvt; -extern bool gDumpContactStats; -extern bool gCalcWorldSpaceAabbOnCpu; -extern bool gUseCalculateOverlappingPairsHost; -extern bool gIntegrateOnCpu; -extern bool gConvertConstraintOnCpu; - - -static const char* sStartFileName = "bullet3StartDemo.txt"; - -static void saveCurrentDemoEntry(int currentEntry,const char* startFileName) -{ - FILE* f = fopen(startFileName,"w"); - if (f) - { - fprintf(f,"%d\n",currentEntry); - fclose(f); - } -}; - -static int loadCurrentDemoEntry(const char* startFileName) -{ - int currentEntry= 0; - FILE* f = fopen(startFileName,"r"); - if (f) - { - int bytesScanned; - bytesScanned = fscanf(f,"%d",¤tEntry); - fclose(f); - } - return currentEntry; -}; - -static void MyResizeCallback( float width, float height) -{ - g_OpenGLWidth = width; - g_OpenGLHeight = height; -} - -b3gWindowInterface* window=0; -GwenUserInterface* gui = 0; -bool gPause = false; -bool gDrawGui = true; -bool gStep = false; -bool gReset = false; - -enum -{ - MYPAUSE=1, - MYPROFILE=2, - MYRESET, -}; - -enum -{ - MYCOMBOBOX1 = 1, -}; - -b3AlignedObjectArray demoNames; -int selectedDemo = 1; -GpuDemo::CreateFunc* allDemos[]= -{ - //ConcaveCompound2Scene::MyCreateFunc, - - - - - //ConcaveSphereScene::MyCreateFunc, - - - -// ConcaveSphereScene::MyCreateFunc, - - - ConcaveScene::MyCreateFunc, - - - GpuBoxPlaneScene::MyCreateFunc, - GpuConstraintsDemo::MyCreateFunc, - //GpuConvexPlaneScene::MyCreateFunc, - - GpuConvexScene::MyCreateFunc, - - GpuCompoundScene::MyCreateFunc, - GpuCompoundPlaneScene::MyCreateFunc, - - GpuSphereScene::MyCreateFunc, - - - - - ConcaveSphereScene::MyCreateFunc, - - ConcaveCompoundScene::MyCreateFunc, - - - - //GpuTetraScene::MyCreateFunc, - - //GpuSoftClothDemo::MyCreateFunc, - - Bullet2FileDemo::MyCreateFunc, - - - PairBench::MyCreateFunc, - - GpuRaytraceScene::MyCreateFunc, - - //ShadowMapDemo::MyCreateFunc, - - //GpuRigidBodyDemo::MyCreateFunc, - - //BroadphaseBenchmark::CreateFunc, - //GpuBoxDemo::CreateFunc, - - - - ParticleDemo::MyCreateFunc, - - - - //GpuCompoundDemo::CreateFunc, - //EmptyDemo::CreateFunc, -}; - - -void MyComboBoxCallback(int comboId, const char* item) -{ - int numDemos = demoNames.size(); - for (int i=0;imouseMoveCallback(x,y); - if (!handled) - { - if (sDemo) - handled = sDemo->mouseMoveCallback(x,y); - if (!handled) - b3DefaultMouseMoveCallback(x,y); - } - } -} -static void MyMouseButtonCallback(int button, int state, float x, float y) -{ - if (gui) - { - bool handled = gui->mouseButtonCallback(button,state,x,y); - if (!handled) - { - //try picking first - if (sDemo) - handled = sDemo->mouseButtonCallback(button,state,x,y); - - if (!handled) - b3DefaultMouseButtonCallback(button,state,x,y); - } - } -} - -extern bool useShadowMap; -static bool wireframe=false; -void MyKeyboardCallback(int key, int state) -{ - if (key=='w' && state) - { - wireframe=!wireframe; - if (wireframe) - { - glPolygonMode( GL_FRONT_AND_BACK, GL_LINE ); - } else - { - glPolygonMode( GL_FRONT_AND_BACK, GL_FILL ); - } - } - - if (key=='s' && state) - { - useShadowMap=!useShadowMap; - } - if (key=='g' && state) - { - gDrawGui = !gDrawGui; - } - - if (key==B3G_ESCAPE && window) - { - window->setRequestExit(); - } - if (key==B3G_F2) - { - if (state) - exportMovie = !exportMovie; - } - if (key==B3G_F1) - { - if (state) - exportFrame = true; - } - if (sDemo) - sDemo->keyboardCallback(key,state); - - b3DefaultKeyboardCallback(key,state); -} - - - -bool enableExperimentalCpuConcaveCollision=false; - - - - - int droidRegular=0;//, droidItalic, droidBold, droidJapanese, dejavu; - -sth_stash* stash=0; -OpenGL2RenderCallbacks* renderCallbacks = 0; - -void exitFont() -{ - sth_delete(stash); - stash=0; - - delete renderCallbacks; - renderCallbacks=0; -} -sth_stash* initFont(GLPrimitiveRenderer* primRender) -{ - GLint err; - - struct sth_stash* stash = 0; - int datasize; - - float sx,sy,dx,dy,lh; - GLuint texture; - - renderCallbacks = new OpenGL2RenderCallbacks(primRender); - - stash = sth_create(512,512,renderCallbacks);//256,256);//,1024);//512,512); - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (!stash) - { - fprintf(stderr, "Could not create stash.\n"); - return 0; - } -#ifdef LOAD_FONT_FROM_FILE - unsigned char* data=0; - const char* fontPaths[]={ - "./", - "../../bin/", - "../bin/", - "bin/" - }; - - int numPaths=sizeof(fontPaths)/sizeof(char*); - - // Load the first truetype font from memory (just because we can). - - FILE* fp = 0; - const char* fontPath ="./"; - char fullFontFileName[1024]; - - for (int i=0;i] [--benchmark] [--maxFrameCount=][--dump_timings] [--disable_opencl] [--cl_device=] [--cl_platform=] [--disable_cached_cl_kernels] [--load_cl_kernels_from_disk] [--x_dim=] [--y_dim=] [--z_dim=] [--x_gap=] [--y_gap=] [--z_gap=] [--use_concave_mesh] [--pair_benchmark_file=] [--new_batching] [--no_instanced_collision_shapes]\n"); - printf("[--disable_shadowmap] [--shadowmap_size=int] [--shadowmap_resolution=] [--use_jacobi] [--use_uniform_grid]\n"); -}; - - -void DumpSimulationTime(FILE* f) -{ - b3ProfileIterator* profileIterator = b3ProfileManager::Get_Iterator(); - - profileIterator->First(); - if (profileIterator->Is_Done()) - return; - - float accumulated_time=0,parent_time = profileIterator->Is_Root() ? b3ProfileManager::Get_Time_Since_Reset() : profileIterator->Get_Current_Parent_Total_Time(); - int i; - int frames_since_reset = b3ProfileManager::Get_Frame_Count_Since_Reset(); - - //fprintf(f,"%.3f,", parent_time ); - float totalTime = 0.f; - - - - static bool headersOnce = true; - - if (headersOnce) - { - headersOnce = false; - fprintf(f,"root,"); - - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - float fraction = parent_time > B3_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - const char* name = profileIterator->Get_Current_Name(); - fprintf(f,"%s,",name); - } - fprintf(f,"\n"); - } - - - fprintf(f,"%.3f,",parent_time); - profileIterator->First(); - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - float fraction = parent_time > B3_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - const char* name = profileIterator->Get_Current_Name(); - //if (!strcmp(name,"stepSimulation")) - { - fprintf(f,"%.3f,",current_total_time); - } - totalTime += current_total_time; - //recurse into children - } - - fprintf(f,"\n"); - - - b3ProfileManager::Release_Iterator(profileIterator); - - -} -///extern const char* g_deviceName; -const char* g_deviceName = "blaat"; -extern bool useNewBatchingKernel; -#include "Bullet3Common/b3Vector3.h" - -FILE* defaultOutput = stdout; - -void myprintf(const char* msg) -{ - fprintf(defaultOutput,"%s",msg); -} - - - - - -//#define STB_IMAGE_WRITE_IMPLEMENTATION -#include "OpenGLWindow/stb_image_write.h" -void writeTextureToPng(int textureWidth, int textureHeight, const char* fileName) -{ - int numComponents = 4; - //glPixelStorei(GL_PACK_ALIGNMENT,1); - GLuint err=glGetError(); - assert(err==GL_NO_ERROR); - glReadBuffer(GL_BACK);//COLOR_ATTACHMENT0); - err=glGetError(); - assert(err==GL_NO_ERROR); - float* orgPixels = (float*)malloc(textureWidth*textureHeight*numComponents*4); - glReadPixels(0,0,textureWidth, textureHeight, GL_RGBA, GL_FLOAT, orgPixels); - //it is useful to have the actual float values for debugging purposes - - //convert float->char - char* pixels = (char*)malloc(textureWidth*textureHeight*numComponents); - err=glGetError(); - assert(err==GL_NO_ERROR); - - for (int j=0;jcreateWindow(wci); - window->setResizeCallback(MyResizeCallback); - window->setMouseMoveCallback(MyMouseMoveCallback); - window->setMouseButtonCallback(MyMouseButtonCallback); - window->setKeyboardCallback(MyKeyboardCallback); - - window->setWindowTitle("Bullet 3.x GPU Rigid Body http://bulletphysics.org"); - printf("-----------------------------------------------------\n"); - - - - -#ifndef __APPLE__ - glewInit(); -#endif - - gui = new GwenUserInterface(); - - printf("started GwenUserInterface"); - - - GLPrimitiveRenderer prim(g_OpenGLWidth,g_OpenGLHeight); - - stash = initFont(&prim); - - - if (gui) - { - Gwen::Renderer::Base* gwenRenderer = new GwenOpenGL3CoreRenderer(&prim,stash, g_OpenGLWidth,g_OpenGLHeight,window->getRetinaScale()); - - - gui->init(g_OpenGLWidth,g_OpenGLHeight,gwenRenderer,window->getRetinaScale()); - - printf("init fonts"); - - - gui->setToggleButtonCallback(MyButtonCallback); - - gui->registerToggleButton(MYPAUSE,"Pause"); - gui->registerToggleButton(MYPROFILE,"Profile"); - gui->registerToggleButton(MYRESET,"Reset"); - - int numItems = sizeof(allDemos)/sizeof(ParticleDemo::CreateFunc*); - demoNames.clear(); - for (int i=0;igetName()); - delete demo; - } - - gui->registerComboBox(MYCOMBOBOX1,numItems,&demoNames[0],selectedDemo); - gui->setComboBoxCallback(MyComboBoxCallback); - } - - - - do - { - bool syncOnly = false; - gReset = false; - - { - GLint err; - glEnable(GL_BLEND); - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glDisable(GL_DEPTH_TEST); - err = glGetError(); - b3Assert(err==GL_NO_ERROR); - window->startRendering(); - glClearColor(1,1,1,1); - glClear(GL_COLOR_BUFFER_BIT| GL_DEPTH_BUFFER_BIT);//|GL_STENCIL_BUFFER_BIT); - glEnable(GL_DEPTH_TEST); - - sth_begin_draw(stash); - //sth_draw_text(stash, droidRegular,12.f, dx, dy-50, "How does this OpenGL True Type font look? ", &dx,width,height); - int spacing = 0;//g_OpenGLHeight; - float sx,sy,dx,dy,lh; - sx = 0; - sy = g_OpenGLHeight; - dx = sx; dy = sy; - //if (1) - const char* msg[] = {"Please wait, initializing the OpenCL demo", - "Please make sure to run the demo on a high-end discrete GPU with OpenCL support", - "The first time it can take a bit longer to compile the OpenCL kernels.", - "Check the console if it takes longer than 1 minute or if a demos has issues.", - "Please share the full commandline output when reporting issues:", - "App_Bullet3_OpenCL_Demos_* >> error.log", - - "", - "", -#ifdef _DEBUG - "Some of the demos load a large .obj file,", - "please use an optimized build of this app for faster parsing", - - "", - "", -#endif - "You can press F1 to create a single screenshot,", - "or press F2 toggle screenshot (useful to create movies)", - "", - "", - "There are various command-line options such as --benchmark", - "See http://github.com/erwincoumans/bullet3 for more information" - }; - int fontSize = 68; - - int nummsg = sizeof(msg)/sizeof(const char*); - for (int i=0;iendRendering(); - } - - - - static bool once=true; - - - //glClearColor(0.3f, 0.3f, 0.3f, 1.0f); - glClearColor(1,1,1,1); - glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); - - window->setWheelCallback(b3DefaultWheelCallback); - - - - - { - GpuDemo* demo = allDemos[selectedDemo](); - sDemo = demo; -// demo->myinit(); - bool useGpu = false; - - - //int maxObjectCapacity=128*1024; - int maxObjectCapacity=1024*1024; - maxObjectCapacity = b3Max(maxObjectCapacity,ci.arraySizeX*ci.arraySizeX*ci.arraySizeX+10); - - { - ci.m_instancingRenderer = new GLInstancingRenderer(maxObjectCapacity);//render.getInstancingRenderer(); - ci.m_window = window; - ci.m_gui = gui; - ci.m_instancingRenderer->init(); - ci.m_instancingRenderer->resize(g_OpenGLWidth,g_OpenGLHeight); - ci.m_instancingRenderer->InitShaders(); - ci.m_primRenderer = &prim; -// render.init(); - } - - { - demo->initPhysics(ci); - } - - - - - - printf("-----------------------------------------------------\n"); - - FILE* csvFile = 0; - FILE* detailsFile = 0; - - if (benchmark) - { - - char prefixFileName[1024]; - char csvFileName[1024]; - char detailsFileName[1024]; - - b3OpenCLDeviceInfo info; - b3OpenCLUtils::getDeviceInfo(demo->getInternalData()->m_clDevice,&info); - - //todo: move this time stuff into the Platform/Window class -#ifdef _WIN32 - SYSTEMTIME time; - GetLocalTime(&time); - char buf[1024]; - DWORD dwCompNameLen = 1024; - if (0 != GetComputerName(buf, &dwCompNameLen)) - { - printf("%s", buf); - } else - { - printf("unknown", buf); - } - - sprintf(prefixFileName,"%s_%s_%s_%d_%d_%d_date_%d-%d-%d_time_%d-%d-%d",info.m_deviceName,buf,demoNames[selectedDemo],ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ,time.wDay,time.wMonth,time.wYear,time.wHour,time.wMinute,time.wSecond); - -#else - timeval now; - gettimeofday(&now,0); - - struct tm* ptm; - ptm = localtime (&now.tv_sec); - char buf[1024]; -#ifdef __APPLE__ - sprintf(buf,"MacOSX"); -#else - sprintf(buf,"Unix"); -#endif - sprintf(prefixFileName,"%s_%s_%s_%d_%d_%d_date_%d-%d-%d_time_%d-%d-%d",info.m_deviceName,buf,demoNames[selectedDemo],ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ, - ptm->tm_mday, - ptm->tm_mon+1, - ptm->tm_year+1900, - ptm->tm_hour, - ptm->tm_min, - ptm->tm_sec); - -#endif - - sprintf(csvFileName,"%s.csv",prefixFileName); - sprintf(detailsFileName,"%s.txt",prefixFileName); - printf("Open csv file %s and details file %s\n", csvFileName,detailsFileName); - - //GetSystemTime(&time2); - - csvFile=fopen(csvFileName,"w"); - detailsFile = fopen(detailsFileName,"w"); - if (detailsFile) - defaultOutput = detailsFile; - - //if (f) - // fprintf(f,"%s (%dx%dx%d=%d),\n", g_deviceName,ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ,ci.arraySizeX*ci.arraySizeY*ci.arraySizeZ); - } - - - fprintf(defaultOutput,"Demo settings:\n"); - fprintf(defaultOutput," SelectedDemo=%d, demoname = %s\n", selectedDemo, demo->getName()); - fprintf(defaultOutput," x_dim=%d, y_dim=%d, z_dim=%d\n",ci.arraySizeX,ci.arraySizeY,ci.arraySizeZ); - fprintf(defaultOutput," x_gap=%f, y_gap=%f, z_gap=%f\n",ci.gapX,ci.gapY,ci.gapZ); - fprintf(defaultOutput,"\nOpenCL settings:\n"); - fprintf(defaultOutput," Preferred cl_device index %d\n", ci.preferredOpenCLDeviceIndex); - fprintf(defaultOutput," Preferred cl_platform index%d\n", ci.preferredOpenCLPlatformIndex); - fprintf(defaultOutput,"\n"); - - if (demo->getInternalData()->m_platformId) - { - b3OpenCLUtils::printPlatformInfo( demo->getInternalData()->m_platformId); - fprintf(defaultOutput,"\n"); - b3OpenCLUtils::printDeviceInfo( demo->getInternalData()->m_clDevice); - fprintf(defaultOutput,"\n"); - } - do - { - - - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - - if (exportFrame || exportMovie) - { - - if (!renderTexture) - { - renderTexture = new GLRenderToTexture(); - GLuint renderTextureId; - glGenTextures(1, &renderTextureId); - - // "Bind" the newly created texture : all future texture functions will modify this texture - glBindTexture(GL_TEXTURE_2D, renderTextureId); - - // Give an empty image to OpenGL ( the last "0" ) - //glTexImage2D(GL_TEXTURE_2D, 0,GL_RGB, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_UNSIGNED_BYTE, 0); - //glTexImage2D(GL_TEXTURE_2D, 0,GL_RGBA32F, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_FLOAT, 0); - glTexImage2D(GL_TEXTURE_2D, 0,GL_RGBA32F, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_FLOAT, 0); - - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - //glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); - //glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - - renderTexture->init(g_OpenGLWidth,g_OpenGLHeight,renderTextureId, RENDERTEXTURE_COLOR); - } - - bool result = renderTexture->enable(); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - b3ProfileManager::Reset(); - b3ProfileManager::Increment_Frame_Counter(); - -// render.reshape(g_OpenGLWidth,g_OpenGLHeight); - ci.m_instancingRenderer->resize(g_OpenGLWidth,g_OpenGLHeight); - prim.setScreenSize(g_OpenGLWidth,g_OpenGLHeight); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - window->startRendering(); - ci.m_instancingRenderer->updateCamera(); - err = glGetError(); - assert(err==GL_NO_ERROR); - - glClear(GL_COLOR_BUFFER_BIT| GL_DEPTH_BUFFER_BIT);//|GL_STENCIL_BUFFER_BIT); - glEnable(GL_DEPTH_TEST); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (!gPause) - { - B3_PROFILE("clientMoveAndDisplay"); - - demo->clientMoveAndDisplay(); - } - else - { - - } - - { - B3_PROFILE("renderScene"); - demo->renderScene(); - } - err = glGetError(); - assert(err==GL_NO_ERROR); - - - /*if (demo->getDynamicsWorld() && demo->getDynamicsWorld()->getNumCollisionObjects()) - { - B3_PROFILE("renderPhysicsWorld"); - b3AlignedObjectArray arr = demo->getDynamicsWorld()->getCollisionObjectArray(); - b3CollisionObject** colObjArray = &arr[0]; - - render.renderPhysicsWorld(demo->getDynamicsWorld()->getNumCollisionObjects(),colObjArray, syncOnly); - syncOnly = true; - - } - */ - - - if (exportFrame || exportMovie) - { - - char fileName[1024]; - sprintf(fileName,"screenShot%d.png",frameIndex++); - writeTextureToPng(g_OpenGLWidth,g_OpenGLHeight,fileName); - exportFrame = false; - renderTexture->disable(); - } - - - { - B3_PROFILE("gui->draw"); - if (gui && gDrawGui) - gui->draw(g_OpenGLWidth,g_OpenGLHeight); - } - err = glGetError(); - assert(err==GL_NO_ERROR); - - - { - B3_PROFILE("window->endRendering"); - window->endRendering(); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - { - B3_PROFILE("glFinish"); - } - - - - if (dump_timings) - { - b3ProfileManager::dumpAll(stdout); - } - - if (csvFile) - { - static int frameCount=0; - - if (frameCount>0) - { - DumpSimulationTime(csvFile); - if (detailsFile) - { - fprintf(detailsFile,"\n==================================\nFrame %d:\n", frameCount); - b3ProfileManager::dumpAll(detailsFile); - } - } - - if (frameCount>=maxFrameCount) - window->setRequestExit(); - frameCount++; - } - - - if (gStep) - gPause=true; - - } while (!window->requestedExit() && !gReset); - - - demo->exitPhysics(); - b3ProfileManager::CleanupMemory(); - delete ci.m_instancingRenderer; - - delete demo; - sDemo = 0; - - if (detailsFile) - { - fclose(detailsFile); - detailsFile=0; - } - if (csvFile) - { - fclose(csvFile); - csvFile=0; - } - } - - - - } while (gReset); - - - if (gui) - gui->setComboBoxCallback(0); - - { - - - - delete gui; - gui=0; - - exitFont(); - - - window->closeWindow(); - delete window; - window = 0; - - } - - return 0; -} diff --git a/Demos3/GpuDemos/premake4.lua b/Demos3/GpuDemos/premake4.lua deleted file mode 100644 index 87c492cc2..000000000 --- a/Demos3/GpuDemos/premake4.lua +++ /dev/null @@ -1,111 +0,0 @@ -function createProject(vendor) - - hasCL = findOpenCL(vendor) - - if (hasCL) then - - project ("App_Bullet3_OpenCL_Demos_" .. vendor) - - initOpenCL(vendor) - - language "C++" - - kind "ConsoleApp" - targetdir "../../bin" - - - initOpenGL() - initGlew() - - includedirs { - "..", - "../../src", - "../../btgui" - } - - links { - "Bullet3AppSupport", - "gwen", - "Bullet2FileLoader", - "Bullet3OpenCL_" .. vendor, - "Bullet3Dynamics", - "Bullet3Collision", - "Bullet3Geometry", - "Bullet3Common", - - } - - files { - "**.cpp", - "**.h", - - "../Wavefront/tiny_obj_loader.cpp", - "../Wavefront/tiny_obj_loader.h", - - - "../../btgui/OpenGLWindow/GLInstancingRenderer.cpp", - "../../btgui/OpenGLWindow/GLInstancingRenderer.h", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.cpp", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.h", - "../../btgui/OpenGLWindow/LoadShader.cpp", - "../../btgui/OpenGLWindow/LoadShader.h", - "../../btgui/OpenGLWindow/TwFonts.cpp", - "../../btgui/OpenGLWindow/TwFonts.h", - "../../btgui/OpenGLWindow/GLRenderToTexture.cpp", - "../../btgui/OpenGLWindow/GLRenderToTexture.h", - "../../btgui/OpenGLWindow/fontstash.cpp", - "../../btgui/OpenGLWindow/fontstash.h", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.h", - "../../btgui/OpenGLWindow/OpenSans.cpp", - "../../btgui/stb_image/stb_image.cpp", - "../../btgui/stb_image/stb_image.h", - } - - if _OPTIONS["midi"] then - if os.is("Windows") then - files {"../../btgui/MidiTest/RtMidi.cpp"} - links {"winmm"} - defines {"__WINDOWS_MM__", "WIN32","B3_USE_MIDI"} - end - - if os.is("Linux") then - end - - if os.is("MacOSX") then - files {"../../btgui/MidiTest/RtMidi.cpp"} - links{"CoreAudio.framework", "coreMIDI.framework", "Cocoa.framework"} - defines {"__MACOSX_CORE__","B3_USE_MIDI"} - end - end - - if os.is("Windows") then - files{ - "../../btgui/OpenGLWindow/Win32OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/Win32OpenGLWindow.h", - "../../btgui/OpenGLWindow/Win32Window.cpp", - "../../btgui/OpenGLWindow/Win32Window.h", - } - end - if os.is("Linux") then - initX11() - files { - "../../btgui/OpenGLWindow/X11OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/X11OpenGLWindows.h" - } - end - if os.is("MacOSX") then - links {"Cocoa.framework"} - files { - "../../btgui/OpenGLWindow/MacOpenGLWindow.h", - "../../btgui/OpenGLWindow/MacOpenGLWindow.mm", - } - end - end -end - -createProject("clew") -createProject("Apple") -createProject("AMD") -createProject("Intel") -createProject("NVIDIA") diff --git a/Demos3/GpuDemos/raytrace/RaytracedShadowDemo.cpp b/Demos3/GpuDemos/raytrace/RaytracedShadowDemo.cpp deleted file mode 100644 index 9446a1571..000000000 --- a/Demos3/GpuDemos/raytrace/RaytracedShadowDemo.cpp +++ /dev/null @@ -1,449 +0,0 @@ - -#include "RaytracedShadowDemo.h" - - - - -#include "OpenGLWindow/ShapeData.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "../rigidbody/GpuRigidBodyDemoInternalData.h" -#include "Bullet3AppSupport/gwenUserInterface.h" -#include "Bullet3Dynamics/ConstraintSolver/b3Point2PointConstraint.h" -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "Bullet3OpenCL/Raycast/b3GpuRaycast.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3ConvexUtility.h" - -#include "OpenGLWindow/GLRenderToTexture.h" - - - -struct GpuRaytraceInternalData -{ - GLuint* m_texId; - unsigned char* m_texels; - int textureWidth; - int textureHeight; - struct GLRenderToTexture* m_renderToTexture; - -}; -#include - -GpuRaytraceScene::GpuRaytraceScene() -{ - - m_raytraceData = new GpuRaytraceInternalData; - m_raytraceData->m_renderToTexture = 0;//new GLRenderToTexture(); - - m_raytraceData->m_texId = new GLuint; - m_raytraceData->textureWidth = 512;//1024;//1024; - m_raytraceData->textureHeight = 512;//1024; - - //create new texture - glGenTextures(1, m_raytraceData->m_texId); - GLenum err = glGetError(); - assert(err==GL_NO_ERROR); - - - - glBindTexture(GL_TEXTURE_2D, *m_raytraceData->m_texId); - m_raytraceData->m_texels = (unsigned char*)malloc(m_raytraceData->textureWidth*m_raytraceData->textureHeight*3); - memset(m_raytraceData->m_texels,0,m_raytraceData->textureWidth*m_raytraceData->textureHeight*3); - for (int i=0;itextureWidth;i++) - { - for (int y=0;ytextureHeight;y++) - { - int color = 0; - if (ytextureHeight-1 && (y>0) && (i>0 && itextureWidth-1)) - color = 255; - - m_raytraceData->m_texels[(i+m_raytraceData->textureWidth*y)*3+0] = color; - m_raytraceData->m_texels[(i+m_raytraceData->textureWidth*y)*3+1] = color; - m_raytraceData->m_texels[(i+m_raytraceData->textureWidth*y)*3+2] = color; - } - } - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, m_raytraceData->textureWidth, m_raytraceData->textureHeight, 0, GL_RGB, GL_UNSIGNED_BYTE, m_raytraceData->m_texels); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); - err = glGetError(); - assert(err==GL_NO_ERROR); - -} -GpuRaytraceScene::~GpuRaytraceScene() -{ - glDeleteTextures(1,m_raytraceData->m_texId); - delete[] m_raytraceData->m_texels; - delete m_raytraceData->m_renderToTexture; - delete m_raytraceData->m_texId; - delete m_raytraceData; -} - - - -int GpuRaytraceScene::createDynamicsObjects(const ConstructionInfo& ci2) -{ - //m_raytraceData->m_renderToTexture->init(ci2.m_instancingRenderer->getScreenWidth(),ci2.m_instancingRenderer->getScreenHeight()); - ConstructionInfo ci = ci2; - ci.arraySizeX = 2; - ci.arraySizeY = 50; - ci.arraySizeZ = 2; - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - return createDynamicsObjects2(ci,cube_vertices,numVertices,cube_indices,numIndices); - - float radius=1.f; - int colIndex = m_data->m_np->registerSphereShape(radius);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int shapeId = registerGraphicsSphereShape(ci,radius,false); - - int group=1; - int mask=1; - int index=0; - - { - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), - }; - - int curColor = 0; - float scaling[4] = {1,1,1,1}; - int prevBody = -1; - int insta = 0; - - - //int colIndex = m_data->m_np->registerSphereShape(1); - for (int i=0;i<1;i++) - //for (int i=0;iregisterGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - - if (prevBody>=0) - { - //b3Point2PointConstraint* p2p = new b3Point2PointConstraint(pid,prevBody,b3Vector3(0,-1.1,0),b3Vector3(0,1.1,0)); -// m_data->m_rigidBodyPipeline->addConstraint(p2p);//,false); - } - prevBody = pid; - - index++; - } - } - } - } - return index; - -} - - -//create primary rays - -void GpuRaytraceScene::renderScene() -{ - - renderScene2(); - return; - //m_raytraceData->m_renderToTexture->enable(); - m_instancingRenderer->renderScene(); - //m_raytraceData->m_renderToTexture->disable(); -} - -void GpuRaytraceScene::renderScene2() -{ - //If using the BVH to accelerate raycasting, the AABBs need to be updated or else they will - //not match the actual rigid body positions after integration. The result is that rigid bodies - //are not drawn or appear clipped, especially if they are moving quickly. - m_data->m_rigidBodyPipeline->setupGpuAabbsFull(); - -// GpuBoxPlaneScene::renderScene(); -// return; - B3_PROFILE("raytrace"); - - //raytrace into the texels - { - B3_PROFILE("update camera"); - m_instancingRenderer->updateCamera(); - } - //generate primary rays - - { - B3_PROFILE("readbackAllBodiesToCpu"); - m_data->m_np->readbackAllBodiesToCpu(); - } - - - { - B3_PROFILE("Generate primary rays"); - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float farPlane = 1000.f; - - float tanFov = (top-bottom)*0.5f / nearPlane; - float screenWidth = m_instancingRenderer->getScreenWidth(); - float screenHeight = m_instancingRenderer->getScreenHeight(); - - float fov = 2. * atanf (tanFov); - float aspect = screenWidth / screenHeight; - - b3Vector3 rayFrom, camTarget; - m_instancingRenderer->getCameraPosition(rayFrom); - m_instancingRenderer->getCameraTargetPosition(camTarget); - b3Vector3 rayForward = camTarget-rayFrom; - rayForward.normalize(); - - rayForward*= farPlane; - - b3Vector3 rightOffset; - b3Vector3 vertical=b3MakeVector3(0.f,1.f,0.f); - b3Vector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - hor *= aspect*2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - b3Vector3 rayToCenter = rayFrom + rayForward; - float texWidth = m_raytraceData->textureWidth; - float texHeight = m_raytraceData->textureHeight; - - - float widthFactor = (screenWidth/texWidth); - float heightFactor = (screenHeight/texHeight); - - //should be screenwidth/height - - b3Vector3 dHor = hor * 1./float(screenWidth); - b3Vector3 dVert = vertical * 1./float(screenHeight); - - b3Transform rayFromTrans; - rayFromTrans.setIdentity(); - rayFromTrans.setOrigin(rayFrom); - - b3Transform rayFromLocal; - b3Transform rayToLocal; - - - - - - //create primary rays - primaryRays.resize(m_raytraceData->textureWidth*m_raytraceData->textureHeight); - - b3Vector3 rayTo; - b3RayInfo ray; - - { - for (int x=0;xtextureWidth;x++) - { - for (int y=0;ytextureHeight;y++) - { - - rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += x * dHor*widthFactor; - rayTo -= y * dVert*heightFactor; - - ray.m_from = rayFrom; - ray.m_to = rayTo; - primaryRays[x+m_raytraceData->textureWidth*y] = ray; - } - } - } - } - - b3AlignedObjectArray hits; - { - B3_PROFILE("hits.resize"); - hits.resize(primaryRays.size()); - } - if (1) - { - B3_PROFILE("init hits"); - for (int i=0;icastRaysHost(primaryRays, hits, this->m_data->m_np->getNumRigidBodies(), m_data->m_np->getBodiesCpu(), m_data->m_np->getNumCollidablesGpu(), m_data->m_np->getCollidablesCpu(),m_data->m_np->getInternalData()); - m_raycaster->castRays(primaryRays, hits, this->m_data->m_np->getNumRigidBodies(), m_data->m_np->getBodiesCpu(), m_data->m_np->getNumCollidablesGpu(), m_data->m_np->getCollidablesCpu(), m_data->m_np->getInternalData(), m_data->m_bp); - } - - - b3AlignedObjectArray shadowRays; - { - B3_PROFILE("shadowRays.resize"); - shadowRays.resize(primaryRays.size()); - } - b3AlignedObjectArray shadowHits; - { - B3_PROFILE("shadowHits.resize"); - shadowHits.resize(hits.size()); - } - - { - B3_PROFILE("init shadow rays"); - for (int i=0;icastRaysHost(primaryRays, hits, this->m_data->m_np->getNumRigidBodies(), m_data->m_np->getBodiesCpu(), m_data->m_np->getNumCollidablesGpu(), m_data->m_np->getCollidablesCpu()); - m_raycaster->castRays(shadowRays, shadowHits, this->m_data->m_np->getNumRigidBodies(), m_data->m_np->getBodiesCpu(), m_data->m_np->getNumCollidablesGpu(), m_data->m_np->getCollidablesCpu(), m_data->m_np->getInternalData(), m_data->m_bp); - } - - { - B3_PROFILE("write texels"); - - for (int i=0;i0.f) - { - if (shadowHits[i].m_hitFraction<1.f) - { - dotje = -1.f; - } - } - - if (dotje>0.f) - { - m_raytraceData->m_texels[(i)*3+0] = 128+128.f*hits[i].m_hitNormal.x; - m_raytraceData->m_texels[(i)*3+1] = 128+128.f*hits[i].m_hitNormal.y; - m_raytraceData->m_texels[(i)*3+2] = 128+128.f*hits[i].m_hitNormal.z; - - if (hits[i].m_hitBody==0) - { - m_raytraceData->m_texels[(i)*3+0] = 255; - m_raytraceData->m_texels[(i)*3+1] = 255; - m_raytraceData->m_texels[(i)*3+2] = 255; - } else - { - } - } else - { - if (dotje == -1.f) - { - m_raytraceData->m_texels[(i)*3+0] = 0; - m_raytraceData->m_texels[(i)*3+1] = 0; - m_raytraceData->m_texels[(i)*3+2] = 255; - } else - { - m_raytraceData->m_texels[(i)*3+0] = 255; - m_raytraceData->m_texels[(i)*3+1] = 0; - m_raytraceData->m_texels[(i)*3+2] = 0; - } - } - } else - { - m_raytraceData->m_texels[(i)*3+0] = 128; - m_raytraceData->m_texels[(i)*3+1] = 128; - m_raytraceData->m_texels[(i)*3+2] = 192; - } - } - } - GLint err; - - { - B3_PROFILE("get error"); - err = glGetError(); - assert(err==GL_NO_ERROR); - glActiveTexture(GL_TEXTURE0); - } - { - B3_PROFILE("glTexImage2D"); - glBindTexture(GL_TEXTURE_2D, *m_raytraceData->m_texId); - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, m_raytraceData->textureWidth, m_raytraceData->textureHeight, 0, GL_RGB, GL_UNSIGNED_BYTE, m_raytraceData->m_texels); - } - - { - B3_PROFILE("glGetError"); - err = glGetError(); - assert(err==GL_NO_ERROR); - } - b3Assert(m_primRenderer); - float color[4] = {1,1,1,1}; - //float rect[4] = {0,0,m_raytraceData->textureWidth,m_raytraceData->textureHeight}; - float rect[4] = {0,0,m_instancingRenderer->getScreenWidth(),m_instancingRenderer->getScreenHeight()}; - float u[2] = {0,1}; - float v[2] = {0,1}; - int useRGBA = 1; - { - B3_PROFILE("drawTexturedRect"); - m_primRenderer->drawTexturedRect(rect[0],rect[1],rect[2],rect[3],color,u[0],v[0],u[1],v[1], useRGBA); - } - { - B3_PROFILE("glGetError"); - err = glGetError(); - assert(err==GL_NO_ERROR); - } -} diff --git a/Demos3/GpuDemos/raytrace/RaytracedShadowDemo.h b/Demos3/GpuDemos/raytrace/RaytracedShadowDemo.h deleted file mode 100644 index da39c5028..000000000 --- a/Demos3/GpuDemos/raytrace/RaytracedShadowDemo.h +++ /dev/null @@ -1,33 +0,0 @@ -#ifndef RAYTRACED_SHADOW_DEMO_H -#define RAYTRACED_SHADOW_DEMO_H - -#include "../rigidbody/GpuConvexScene.h" - -class GpuRaytraceScene : public GpuBoxPlaneScene -{ -protected: - b3AlignedObjectArray primaryRays; - - struct GpuRaytraceInternalData* m_raytraceData; - -public: - GpuRaytraceScene(); - virtual ~GpuRaytraceScene(); - virtual const char* getName() - { - return "GPURaytrace"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuRaytraceScene; - return demo; - } - - virtual int createDynamicsObjects(const ConstructionInfo& ci); - - void renderScene(); - void renderScene2(); -}; - -#endif //RAYTRACED_SHADOW_DEMO_H diff --git a/Demos3/GpuDemos/rigidbody/Bullet2FileDemo.cpp b/Demos3/GpuDemos/rigidbody/Bullet2FileDemo.cpp deleted file mode 100644 index b5ce2503f..000000000 --- a/Demos3/GpuDemos/rigidbody/Bullet2FileDemo.cpp +++ /dev/null @@ -1,43 +0,0 @@ - -#include "Bullet2FileDemo.h" -#include "BulletDataExtractor.h" -#include "GpuRigidBodyDemoInternalData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" - -Bullet2FileDemo::Bullet2FileDemo() -{ - m_loader = 0; -} -Bullet2FileDemo::~Bullet2FileDemo() -{ - delete m_loader; -} - -void Bullet2FileDemo::setupScene(const ConstructionInfo& ci) -{ - b3Assert(ci.m_instancingRenderer); - //const char* fileName="data/testFile.bullet"; - const char* fileName="data/testFileFracture.bullet"; - FILE* f = 0; - - const char* prefix[]={"./","../","../../","../../../","../../../../"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - - for (int i=0;!f && im_np,*m_data->m_rigidBodyPipeline,relativeFileName); - } -// m_loader = new b3BulletDataExtractor(*ci.m_instancingRenderer,*m_data->m_np,*m_data->m_rigidBodyPipeline); -// m_loader->convertAllObjects(bulletFile); - - b3Vector3 pos=b3MakeVector3(-20,10,0); - ci.m_instancingRenderer->setCameraTargetPosition(pos); - ci.m_instancingRenderer->setCameraDistance(10); -} diff --git a/Demos3/GpuDemos/rigidbody/Bullet2FileDemo.h b/Demos3/GpuDemos/rigidbody/Bullet2FileDemo.h deleted file mode 100644 index 0efe6c95f..000000000 --- a/Demos3/GpuDemos/rigidbody/Bullet2FileDemo.h +++ /dev/null @@ -1,32 +0,0 @@ -#ifndef BULLET2_FILE_DEMO_H -#define BULLET2_FILE_DEMO_H - - - -#include "GpuRigidBodyDemo.h" - -class Bullet2FileDemo : public GpuRigidBodyDemo -{ - class b3BulletDataExtractor* m_loader; - -public: - - Bullet2FileDemo(); - virtual ~Bullet2FileDemo(); - virtual const char* getName() - { - return "Bullet2File"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new Bullet2FileDemo; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - -}; - -#endif//BULLET2_FILE_DEMO_H - diff --git a/Demos3/GpuDemos/rigidbody/BulletDataExtractor.cpp b/Demos3/GpuDemos/rigidbody/BulletDataExtractor.cpp deleted file mode 100644 index 7ba6d6161..000000000 --- a/Demos3/GpuDemos/rigidbody/BulletDataExtractor.cpp +++ /dev/null @@ -1,644 +0,0 @@ -int NUM_OBJECTS_X = 20; -int NUM_OBJECTS_Y = 20; -int NUM_OBJECTS_Z = 20; - - - -float X_GAP = 2.3f; -float Y_GAP = 2.f; -float Z_GAP = 2.3f; - -#include "BulletDataExtractor.h" -#include "Bullet3Serialize/Bullet2FileLoader/b3BulletFile.h" -bool keepStaticObjects = true; -extern bool enableExperimentalCpuConcaveCollision; - -#include - -#include "OpenGLWindow/OpenGLInclude.h" - - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "Bullet3Common/b3Matrix3x3.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3ConvexUtility.h" -#include "OpenGLWindow/ShapeData.h" - -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" - -///work-in-progress -///This ReadBulletSample is kept as simple as possible without dependencies to the Bullet SDK. -///It can be used to load .bullet data for other physics SDKs -///For a more complete example how to load and convert Bullet data using the Bullet SDK check out -///the Bullet/Demos/SerializeDemo and Bullet/Serialize/BulletWorldImporter - - -//using namespace Bullet; - -struct GraphicsVertex -{ - float xyzw[4]; - float normal[3]; - float uv[2]; -}; -struct GraphicsShape -{ - const float* m_vertices; - int m_numvertices; - const int* m_indices; - int m_numIndices; - float m_scaling[4]; -}; - -struct InstanceGroup -{ - Bullet3SerializeBullet2::b3CollisionShapeData* m_shape; - int m_collisionShapeIndex; - - b3AlignedObjectArray m_rigidBodies; -}; - - -void createScene( GLInstancingRenderer& renderer,b3GpuNarrowPhase& np, b3GpuRigidBodyPipeline& rbWorld, const char* fileName) -{ - //const char* fileName="../../bin/convex-trimesh.bullet"; - //const char* fileName="../../bin/1000 convex.bullet"; - //const char* fileName="../../bin/1000 stack.bullet"; - //const char* fileName="../../bin/3000 fall.bullet"; - - - //const char* fileName="../../bin/testFile.bullet"; - - - - FILE* f = fopen(fileName,"rb"); - if (f) - { - fclose(f); - - bool verboseDumpAllTypes = false; - - bParse::b3BulletFile* bulletFile2 = new bParse::b3BulletFile(fileName); - - bool ok = (bulletFile2->getFlags()& bParse::FD_OK)!=0; - - if (ok) - bulletFile2->parse(verboseDumpAllTypes); - else - { - printf("Error loading file %s.\n",fileName); - exit(0); - } - ok = (bulletFile2->getFlags()& bParse::FD_OK)!=0; - - if (!(bulletFile2->getFlags() & bParse::FD_DOUBLE_PRECISION)) - { - if (!ok) - { - printf("Error parsing file %s.\n",fileName); - exit(0); - } - - if (verboseDumpAllTypes) - { - bulletFile2->dumpChunks(bulletFile2->getFileDNA()); - } - - - b3BulletDataExtractor extractor(renderer,np,rbWorld); - - extractor.convertAllObjects(bulletFile2); - delete bulletFile2; - return; - - } else - { - printf("Error: double precision .bullet files not supported in this demo\n"); - } - - delete bulletFile2; - } else - { - printf("Warning: cannot find file %s, using programmatically created scene instead.\n",fileName); - } -} - - - -enum LocalBroadphaseNativeTypes -{ - // polyhedral convex shapes - BOX_SHAPE_PROXYTYPE, - TRIANGLE_SHAPE_PROXYTYPE, - TETRAHEDRAL_SHAPE_PROXYTYPE, - CONVEX_TRIANGLEMESH_SHAPE_PROXYTYPE, - CONVEX_HULL_SHAPE_PROXYTYPE, - CONVEX_POINT_CLOUD_SHAPE_PROXYTYPE, - CUSTOM_POLYHEDRAL_SHAPE_TYPE, -//implicit convex shapes -IMPLICIT_CONVEX_SHAPES_START_HERE, - SPHERE_SHAPE_PROXYTYPE, - MULTI_SPHERE_SHAPE_PROXYTYPE, - CAPSULE_SHAPE_PROXYTYPE, - CONE_SHAPE_PROXYTYPE, - CONVEX_SHAPE_PROXYTYPE, - CYLINDER_SHAPE_PROXYTYPE, - UNIFORM_SCALING_SHAPE_PROXYTYPE, - MINKOWSKI_SUM_SHAPE_PROXYTYPE, - MINKOWSKI_DIFFERENCE_SHAPE_PROXYTYPE, - BOX_2D_SHAPE_PROXYTYPE, - CONVEX_2D_SHAPE_PROXYTYPE, - CUSTOM_CONVEX_SHAPE_TYPE, -//concave shapes -CONCAVE_SHAPES_START_HERE, - //keep all the convex shapetype below here, for the check IsConvexShape in broadphase proxy! - TRIANGLE_MESH_SHAPE_PROXYTYPE, - SCALED_TRIANGLE_MESH_SHAPE_PROXYTYPE, - ///used for demo integration FAST/Swift collision library and Bullet - FAST_CONCAVE_MESH_PROXYTYPE, - //terrain - TERRAIN_SHAPE_PROXYTYPE, -///Used for GIMPACT Trimesh integration - GIMPACT_SHAPE_PROXYTYPE, -///Multimaterial mesh - MULTIMATERIAL_TRIANGLE_MESH_PROXYTYPE, - - EMPTY_SHAPE_PROXYTYPE, - STATIC_PLANE_PROXYTYPE, - CUSTOM_CONCAVE_SHAPE_TYPE, -CONCAVE_SHAPES_END_HERE, - - COMPOUND_SHAPE_PROXYTYPE, - - SOFTBODY_SHAPE_PROXYTYPE, - HFFLUID_SHAPE_PROXYTYPE, - HFFLUID_BUOYANT_CONVEX_SHAPE_PROXYTYPE, - INVALID_SHAPE_PROXYTYPE, - - MAX_BROADPHASE_COLLISION_TYPES - -}; - -b3BulletDataExtractor::b3BulletDataExtractor(GLInstancingRenderer& renderer, b3GpuNarrowPhase& np, b3GpuRigidBodyPipeline& rbWorld) - :m_renderer(renderer), m_np(np), m_rbPipeline(rbWorld) -{ -} - -b3BulletDataExtractor::~b3BulletDataExtractor() -{ -} - - - -void b3BulletDataExtractor::convertAllObjects(bParse::b3BulletFile* bulletFile2) -{ - int i; - - for (i=0;im_collisionShapes.size();i++) - { - Bullet3SerializeBullet2::b3CollisionShapeData* shapeData = (Bullet3SerializeBullet2::b3CollisionShapeData*)bulletFile2->m_collisionShapes[i]; - if (shapeData->m_name) - printf("converting shape %s\n", shapeData->m_name); - int shapeIndex = convertCollisionShape(shapeData); - //valid conversion? - if (shapeIndex>=0) - { - InstanceGroup* group = new InstanceGroup; - group->m_shape = shapeData; - group->m_collisionShapeIndex = shapeIndex; - m_instanceGroups.push_back(group); - - } - } - - for (i=0;im_rigidBodies.size();i++) - { - - Bullet3SerializeBullet2::b3RigidBodyFloatData* colObjData = (Bullet3SerializeBullet2::b3RigidBodyFloatData*)bulletFile2->m_rigidBodies[i]; - Bullet3SerializeBullet2::b3CollisionShapeData* shapeData = (Bullet3SerializeBullet2::b3CollisionShapeData*)colObjData->m_collisionObjectData.m_collisionShape; - for (int j=0;jm_shape == shapeData) - { - m_instanceGroups[j]->m_rigidBodies.push_back(bulletFile2->m_rigidBodies[i]); - } - } - } - - //now register all objects in order - for (int i=0;im_rigidBodies.size()>0) - { - - m_renderer.registerShape(m_graphicsShapes[i]->m_vertices,m_graphicsShapes[i]->m_numvertices,m_graphicsShapes[i]->m_indices,m_graphicsShapes[i]->m_numIndices); - - for (int j=0;jm_rigidBodies.size();j++) - { - Bullet3SerializeBullet2::b3RigidBodyFloatData* colObjData = (Bullet3SerializeBullet2::b3RigidBodyFloatData*)m_instanceGroups[i]->m_rigidBodies[j]; - - b3Matrix3x3 mat; - mat.deSerializeFloat((const b3Matrix3x3FloatData&)colObjData->m_collisionObjectData.m_worldTransform.m_basis); - b3Quaternion orn; - mat.getRotation(orn); - float quaternion[4] = {orn[0],orn[1],orn[2],orn[3]}; - float pos[4] = {colObjData->m_collisionObjectData.m_worldTransform.m_origin.m_floats[0], - colObjData->m_collisionObjectData.m_worldTransform.m_origin.m_floats[1], - colObjData->m_collisionObjectData.m_worldTransform.m_origin.m_floats[2], - 0.f}; - float color[4] = {0,0,0,1}; - float mass = 0.f; - if (colObjData->m_inverseMass==0.f) - { - color[1] = 1; - } else - { - mass = 1.f/colObjData->m_inverseMass; - color[2] = 1; - } - if (keepStaticObjects || colObjData->m_inverseMass!=0.f) - { - - m_rbPipeline.registerPhysicsInstance(mass,pos,quaternion,m_instanceGroups[i]->m_collisionShapeIndex,0,true); - m_renderer.registerGraphicsInstance(m_instanceGroups[i]->m_collisionShapeIndex,pos,quaternion,color,m_graphicsShapes[i]->m_scaling); - } - - - - } - } - } - - for (i=0;im_collisionObjects.size();i++) - { - - } - - - - m_rbPipeline.writeAllInstancesToGpu(); -} - - - -int b3BulletDataExtractor::convertCollisionShape( Bullet3SerializeBullet2::b3CollisionShapeData* shapeData ) -{ - int shapeIndex = -1; - - switch (shapeData->m_shapeType) - { - case STATIC_PLANE_PROXYTYPE: - { - Bullet3SerializeBullet2::b3StaticPlaneShapeData* planeData = (Bullet3SerializeBullet2::b3StaticPlaneShapeData*)shapeData; - shapeIndex = createPlaneShape(planeData->m_planeNormal,planeData->m_planeConstant, planeData->m_localScaling); - break; - } - - case CYLINDER_SHAPE_PROXYTYPE: - case CAPSULE_SHAPE_PROXYTYPE: - case BOX_SHAPE_PROXYTYPE: - case SPHERE_SHAPE_PROXYTYPE: - case MULTI_SPHERE_SHAPE_PROXYTYPE: - case CONVEX_HULL_SHAPE_PROXYTYPE: - { - Bullet3SerializeBullet2::b3ConvexInternalShapeData* bsd = (Bullet3SerializeBullet2::b3ConvexInternalShapeData*)shapeData; - - switch (shapeData->m_shapeType) - { - case BOX_SHAPE_PROXYTYPE: - { - shapeIndex = createBoxShape(bsd->m_implicitShapeDimensions, bsd->m_localScaling,bsd->m_collisionMargin); - break; - } - case SPHERE_SHAPE_PROXYTYPE: - { - shapeIndex = createSphereShape(bsd->m_implicitShapeDimensions.m_floats[0],bsd->m_localScaling, bsd->m_collisionMargin); - break; - } - case CONVEX_HULL_SHAPE_PROXYTYPE: - { - Bullet3SerializeBullet2::b3ConvexHullShapeData* convexData = (Bullet3SerializeBullet2::b3ConvexHullShapeData*)bsd; - int numPoints = convexData->m_numUnscaledPoints; - b3Vector3 localScaling; - localScaling.deSerializeFloat((b3Vector3FloatData&)bsd->m_localScaling); - b3AlignedObjectArray tmpPoints; - int i; - if (convexData->m_unscaledPointsFloatPtr) - { - for ( i=0;im_unscaledPointsFloatPtr[i].m_floats[0], - convexData->m_unscaledPointsFloatPtr[i].m_floats[1], - convexData->m_unscaledPointsFloatPtr[i].m_floats[2]);//convexData->m_unscaledPointsFloatPtr[i].m_floats[3]); - - tmpPoints.push_back(pt*localScaling); - } - } - float unitScaling[4] = {1,1,1,1}; - - - int strideInBytes = sizeof(b3Vector3); - strideInBytes = 4*sizeof(float); - int noHeightField = 1; - shapeIndex = m_np.registerConvexHullShape(&tmpPoints[0].m_floats[0],strideInBytes, numPoints,&unitScaling[0]); - - printf("createConvexHull with %d vertices\n",numPoints); - - GraphicsShape* gfxShape = createGraphicsShapeFromConvexHull(&tmpPoints[0],tmpPoints.size()); - m_graphicsShapes.push_back(gfxShape); - - return shapeIndex; - break; - } -#if 0 - case CAPSULE_SHAPE_PROXYTYPE: - { - b3CapsuleShapeData* capData = (b3CapsuleShapeData*)shapeData; - switch (capData->m_upAxis) - { - case 0: - { - shape = createCapsuleShapeX(implicitShapeDimensions.getY(),2*implicitShapeDimensions.getX()); - break; - } - case 1: - { - shape = createCapsuleShapeY(implicitShapeDimensions.getX(),2*implicitShapeDimensions.getY()); - break; - } - case 2: - { - shape = createCapsuleShapeZ(implicitShapeDimensions.getX(),2*implicitShapeDimensions.getZ()); - break; - } - default: - { - printf("error: wrong up axis for b3CapsuleShape\n"); - } - - }; - - break; - } - case CYLINDER_SHAPE_PROXYTYPE: - { - b3CylinderShapeData* cylData = (b3CylinderShapeData*) shapeData; - b3Vector3 halfExtents = implicitShapeDimensions+margin; - switch (cylData->m_upAxis) - { - case 0: - { - shape = createCylinderShapeX(halfExtents.getY(),halfExtents.getX()); - break; - } - case 1: - { - shape = createCylinderShapeY(halfExtents.getX(),halfExtents.getY()); - break; - } - case 2: - { - shape = createCylinderShapeZ(halfExtents.getX(),halfExtents.getZ()); - break; - } - default: - { - printf("unknown Cylinder up axis\n"); - } - - }; - - - - break; - } - case MULTI_SPHERE_SHAPE_PROXYTYPE: - { - b3MultiSphereShapeData* mss = (b3MultiSphereShapeData*)bsd; - int numSpheres = mss->m_localPositionArraySize; - int i; - for ( i=0;im_localPositionArrayPtr[i].m_pos); - radii[i] = mss->m_localPositionArrayPtr[i].m_radius; - } - shape = new b3MultiSphereShape(&tmpPos[0],&radii[0],numSpheres); - break; - } - -#endif - - default: - { - printf("error: cannot create shape type (%d)\n",shapeData->m_shapeType); - } - } - - break; - } - - case TRIANGLE_MESH_SHAPE_PROXYTYPE: - { - Bullet3SerializeBullet2::b3TriangleMeshShapeData* trimesh = (Bullet3SerializeBullet2::b3TriangleMeshShapeData*)shapeData; - printf("numparts = %d\n",trimesh->m_meshInterface.m_numMeshParts); - if (trimesh->m_meshInterface.m_numMeshParts) - { - for (int i=0;im_meshInterface.m_numMeshParts;i++) - { - Bullet3SerializeBullet2::b3MeshPartData& dat = trimesh->m_meshInterface.m_meshPartsPtr[i]; - printf("numtris = %d, numverts = %d\n", dat.m_numTriangles,dat.m_numVertices);//,dat.m_vertices3f,dat.m_3indices16 - printf("scaling = %f,%f,%f\n", trimesh->m_meshInterface.m_scaling.m_floats[0],trimesh->m_meshInterface.m_scaling.m_floats[1],trimesh->m_meshInterface.m_scaling.m_floats[2]); - // dat. - //dat. - - } - - ///trimesh->m_meshInterface.m_meshPartsPtr - //trimesh->m_meshInterface.m_scaling - } - //trimesh->m_meshInterface - //b3TriangleIndexVertexArray* meshInterface = createMeshInterface(trimesh->m_meshInterface); - - - //scaling - //b3Vector3 scaling; scaling.deSerializeFloat(trimesh->m_meshInterface.m_scaling); - //meshInterface->setScaling(scaling); - - //printf("trimesh->m_collisionMargin=%f\n",trimesh->m_collisionMargin); - break; - } - -#if 0 - case COMPOUND_SHAPE_PROXYTYPE: - { - b3CompoundShapeData* compoundData = (b3CompoundShapeData*)shapeData; - b3CompoundShape* compoundShape = createCompoundShape(); - - - b3AlignedObjectArray childShapes; - for (int i=0;im_numChildShapes;i++) - { - b3CollisionShape* childShape = convertCollisionShape(compoundData->m_childShapePtr[i].m_childShape); - if (childShape) - { - b3Transform localTransform; - localTransform.deSerializeFloat(compoundData->m_childShapePtr[i].m_transform); - compoundShape->addChildShape(localTransform,childShape); - } else - { - printf("error: couldn't create childShape for compoundShape\n"); - } - - } - shape = compoundShape; - - break; - } - - case GIMPACT_SHAPE_PROXYTYPE: - { - b3GImpactMeshShapeData* gimpactData = (b3GImpactMeshShapeData*) shapeData; - if (gimpactData->m_gimpactSubType == CONST_GIMPACT_TRIMESH_SHAPE) - { - b3TriangleIndexVertexArray* meshInterface = createMeshInterface(gimpactData->m_meshInterface); - b3GImpactMeshShape* gimpactShape = createGimpactShape(meshInterface); - b3Vector3 localScaling; - localScaling.deSerializeFloat(gimpactData->m_localScaling); - gimpactShape->setLocalScaling(localScaling); - gimpactShape->setMargin(b3Scalar(gimpactData->m_collisionMargin)); - gimpactShape->updateBound(); - shape = gimpactShape; - } else - { - printf("unsupported gimpact sub type\n"); - } - break; - } - case SOFTBODY_SHAPE_PROXYTYPE: - { - return 0; - } -#endif - default: - { - printf("unsupported shape type (%d)\n",shapeData->m_shapeType); - } - } - - return shapeIndex; - -} - -int b3BulletDataExtractor::createBoxShape( const Bullet3SerializeBullet2::b3Vector3FloatData& halfDimensions, const Bullet3SerializeBullet2::b3Vector3FloatData& localScaling, float collisionMargin) -{ - float cubeScaling[4] = { - halfDimensions.m_floats[0]*localScaling.m_floats[0]+collisionMargin, - halfDimensions.m_floats[1]*localScaling.m_floats[1]+collisionMargin, - halfDimensions.m_floats[2]*localScaling.m_floats[2]+collisionMargin, - 1}; - int strideInBytes = sizeof(float)*9; - int noHeightField = 1; - int cubeCollisionShapeIndex = m_np.registerConvexHullShape(&cube_vertices[0],strideInBytes, sizeof(cube_vertices)/strideInBytes,&cubeScaling[0]); - - { - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - - GraphicsShape* gfxShape = new GraphicsShape; - gfxShape->m_vertices = cube_vertices; - gfxShape->m_numvertices = numVertices; - gfxShape->m_indices = cube_indices; - gfxShape->m_numIndices = numIndices; - for (int i=0;i<4;i++) - gfxShape->m_scaling[i] = cubeScaling[i]; - m_graphicsShapes.push_back(gfxShape); - } - - printf("createBoxShape with half extents %f,%f,%f\n",cubeScaling[0], cubeScaling[1],cubeScaling[2]); - //halfDimensions * localScaling - return cubeCollisionShapeIndex; -} - -int b3BulletDataExtractor::createSphereShape( float radius, const Bullet3SerializeBullet2::b3Vector3FloatData& localScaling, float collisionMargin) -{ - printf("createSphereShape with radius %f\n",radius); - return -1; -} - - -int b3BulletDataExtractor::createPlaneShape( const Bullet3SerializeBullet2::b3Vector3FloatData& planeNormal, float planeConstant, const Bullet3SerializeBullet2::b3Vector3FloatData& localScaling) -{ - printf("createPlaneShape with normal %f,%f,%f and planeConstant %f\n",planeNormal.m_floats[0], planeNormal.m_floats[1],planeNormal.m_floats[2],planeConstant); - return -1; -} - - - - - -GraphicsShape* b3BulletDataExtractor::createGraphicsShapeFromConvexHull(const b3Vector3* tmpPoints, int numPoints) -{ - b3ConvexUtility* utilPtr = new b3ConvexUtility(); - bool merge = true; - utilPtr->initializePolyhedralFeatures(tmpPoints,numPoints,merge); - - b3AlignedObjectArray* vertices = new b3AlignedObjectArray; - { - int numVertices = utilPtr->m_vertices.size(); - int numIndices = 0; - b3AlignedObjectArray* indicesPtr = new b3AlignedObjectArray; - for (int f=0;fm_faces.size();f++) - { - const b3MyFace& face = utilPtr->m_faces[f]; - b3Vector3 normal=b3MakeVector3(face.m_plane[0],face.m_plane[1],face.m_plane[2]); - if (face.m_indices.size()>2) - { - - GraphicsVertex vtx; - const b3Vector3& orgVertex = utilPtr->m_vertices[face.m_indices[0]]; - vtx.xyzw[0] = orgVertex[0];vtx.xyzw[1] = orgVertex[1];vtx.xyzw[2] = orgVertex[2];vtx.xyzw[3] = 0.f; - vtx.normal[0] = normal[0];vtx.normal[1] = normal[1];vtx.normal[2] = normal[2]; - vtx.uv[0] = 0.5f;vtx.uv[1] = 0.5f; - int newvtxindex0 = vertices->size(); - vertices->push_back(vtx); - - for (int j=1;jpush_back(newvtxindex0); - { - GraphicsVertex vtx; - const b3Vector3& orgVertex = utilPtr->m_vertices[face.m_indices[j]]; - vtx.xyzw[0] = orgVertex[0];vtx.xyzw[1] = orgVertex[1];vtx.xyzw[2] = orgVertex[2];vtx.xyzw[3] = 0.f; - vtx.normal[0] = normal[0];vtx.normal[1] = normal[1];vtx.normal[2] = normal[2]; - vtx.uv[0] = 0.5f;vtx.uv[1] = 0.5f; - int newvtxindexj = vertices->size(); - vertices->push_back(vtx); - indicesPtr->push_back(newvtxindexj); - } - - { - GraphicsVertex vtx; - const b3Vector3& orgVertex = utilPtr->m_vertices[face.m_indices[j+1]]; - vtx.xyzw[0] = orgVertex[0];vtx.xyzw[1] = orgVertex[1];vtx.xyzw[2] = orgVertex[2];vtx.xyzw[3] = 0.f; - vtx.normal[0] = normal[0];vtx.normal[1] = normal[1];vtx.normal[2] = normal[2]; - vtx.uv[0] = 0.5f;vtx.uv[1] = 0.5f; - int newvtxindexj1 = vertices->size(); - vertices->push_back(vtx); - indicesPtr->push_back(newvtxindexj1); - } - } - } - } - - - GraphicsShape* gfxShape = new GraphicsShape; - gfxShape->m_vertices = &vertices->at(0).xyzw[0]; - gfxShape->m_numvertices = vertices->size(); - gfxShape->m_indices = &indicesPtr->at(0); - gfxShape->m_numIndices = indicesPtr->size(); - for (int i=0;i<4;i++) - gfxShape->m_scaling[i] = 1;//bake the scaling into the vertices - return gfxShape; - } -} diff --git a/Demos3/GpuDemos/rigidbody/BulletDataExtractor.h b/Demos3/GpuDemos/rigidbody/BulletDataExtractor.h deleted file mode 100644 index 3ffde6b91..000000000 --- a/Demos3/GpuDemos/rigidbody/BulletDataExtractor.h +++ /dev/null @@ -1,53 +0,0 @@ -#ifndef BULLET_DATA_EXTRACTOR_H -#define BULLET_DATA_EXTRACTOR_H - - -#include "Bullet3Serialize/Bullet2FileLoader/autogenerated/bullet2.h" -#include "Bullet3Common/b3AlignedObjectArray.h" -#include "Bullet3Common/b3Vector3.h" - -class GLInstancingRenderer; -class b3GpuRigidBodyPipeline; -class b3GpuNarrowPhase; - -void createScene(GLInstancingRenderer& renderer,b3GpuNarrowPhase& np, b3GpuRigidBodyPipeline& rbWorld, const char* fileName); - -namespace bParse -{ - class b3BulletFile; -}; - -class b3BulletDataExtractor -{ - GLInstancingRenderer& m_renderer; - b3GpuNarrowPhase& m_np; - b3GpuRigidBodyPipeline& m_rbPipeline; - - public: - - b3AlignedObjectArray m_instanceGroups; - b3AlignedObjectArray m_graphicsShapes; - - b3BulletDataExtractor(GLInstancingRenderer& renderer, b3GpuNarrowPhase& np, b3GpuRigidBodyPipeline& rbPipeline); - - virtual ~b3BulletDataExtractor(); - - virtual void convertAllObjects(bParse::b3BulletFile* bulletFile); - - //return -1 for invalid - virtual int convertCollisionShape( Bullet3SerializeBullet2::b3CollisionShapeData* shapeData ); - - virtual int createPlaneShape( const Bullet3SerializeBullet2::b3Vector3FloatData& planeNormal, float planeConstant, const Bullet3SerializeBullet2::b3Vector3FloatData& localScaling); - - virtual int createBoxShape( const Bullet3SerializeBullet2::b3Vector3FloatData& halfDimensions, const Bullet3SerializeBullet2::b3Vector3FloatData& localScaling, float collisionMargin); - - virtual int createSphereShape( float radius, const Bullet3SerializeBullet2::b3Vector3FloatData& localScaling, float collisionMargin); - - static GraphicsShape* createGraphicsShapeFromConvexHull(const b3Vector3* tmpPoints, int numPoints); - static GraphicsShape* createGraphicsShapeFromWavefrontObj(class objLoader* obj); - -}; - - - -#endif //BULLET_DATA_EXTRACTOR_H \ No newline at end of file diff --git a/Demos3/GpuDemos/rigidbody/ConcaveScene.cpp b/Demos3/GpuDemos/rigidbody/ConcaveScene.cpp deleted file mode 100644 index 1abb93b8a..000000000 --- a/Demos3/GpuDemos/rigidbody/ConcaveScene.cpp +++ /dev/null @@ -1,758 +0,0 @@ -#include "ConcaveScene.h" -#include "GpuRigidBodyDemo.h" -#include "OpenGLWindow/ShapeData.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "GpuRigidBodyDemoInternalData.h" -#include"../../Wavefront/tiny_obj_loader.h" -#include "Bullet3Common/b3Transform.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3ConvexUtility.h" - -#include "Bullet3AppSupport/gwenUserInterface.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#define CONCAVE_GAPX 14 -#define CONCAVE_GAPY 5 -#define CONCAVE_GAPZ 14 - -GLInstanceGraphicsShape* createGraphicsShapeFromWavefrontObj(std::vector& shapes) -{ - - b3AlignedObjectArray* vertices = new b3AlignedObjectArray; - { -// int numVertices = obj->vertexCount; - // int numIndices = 0; - b3AlignedObjectArray* indicesPtr = new b3AlignedObjectArray; - - for (int s=0;ssize(); - - - indicesPtr->push_back(vtxBaseIndex); - indicesPtr->push_back(vtxBaseIndex+1); - indicesPtr->push_back(vtxBaseIndex+2); - - GLInstanceVertex vtx0; - vtx0.xyzw[0] = shape.mesh.positions[shape.mesh.indices[f]*3+0]; - vtx0.xyzw[1] = shape.mesh.positions[shape.mesh.indices[f]*3+1]; - vtx0.xyzw[2] = shape.mesh.positions[shape.mesh.indices[f]*3+2]; - vtx0.xyzw[3] = 0.f; - - vtx0.uv[0] = 0.5f;//shape.mesh.positions[shape.mesh.indices[f]*3+2];? - vtx0.uv[1] = 0.5f; - - GLInstanceVertex vtx1; - vtx1.xyzw[0] = shape.mesh.positions[shape.mesh.indices[f+1]*3+0]; - vtx1.xyzw[1] = shape.mesh.positions[shape.mesh.indices[f+1]*3+1]; - vtx1.xyzw[2] = shape.mesh.positions[shape.mesh.indices[f+1]*3+2]; - vtx1.xyzw[3]= 0.f; - vtx1.uv[0] = 0.5f;//obj->textureList[face->vertex_index[1]]->e[0]; - vtx1.uv[1] = 0.5f;//obj->textureList[face->vertex_index[1]]->e[1]; - - GLInstanceVertex vtx2; - vtx2.xyzw[0] = shape.mesh.positions[shape.mesh.indices[f+2]*3+0]; - vtx2.xyzw[1] = shape.mesh.positions[shape.mesh.indices[f+2]*3+1]; - vtx2.xyzw[2] = shape.mesh.positions[shape.mesh.indices[f+2]*3+2]; - vtx2.xyzw[3] = 0.f; - vtx2.uv[0] = 0.5f; - vtx2.uv[1] = 0.5f; - - - b3Vector3 v0=b3MakeVector3(vtx0.xyzw[0],vtx0.xyzw[1],vtx0.xyzw[2]); - b3Vector3 v1=b3MakeVector3(vtx1.xyzw[0],vtx1.xyzw[1],vtx1.xyzw[2]); - b3Vector3 v2=b3MakeVector3(vtx2.xyzw[0],vtx2.xyzw[1],vtx2.xyzw[2]); - - normal = (v1-v0).cross(v2-v0); - normal.normalize(); - vtx0.normal[0] = normal[0]; - vtx0.normal[1] = normal[1]; - vtx0.normal[2] = normal[2]; - vtx1.normal[0] = normal[0]; - vtx1.normal[1] = normal[1]; - vtx1.normal[2] = normal[2]; - vtx2.normal[0] = normal[0]; - vtx2.normal[1] = normal[1]; - vtx2.normal[2] = normal[2]; - vertices->push_back(vtx0); - vertices->push_back(vtx1); - vertices->push_back(vtx2); - } - } - } - - - GLInstanceGraphicsShape* gfxShape = new GLInstanceGraphicsShape; - gfxShape->m_vertices = vertices; - gfxShape->m_numvertices = vertices->size(); - gfxShape->m_indices = indicesPtr; - gfxShape->m_numIndices = indicesPtr->size(); - for (int i=0;i<4;i++) - gfxShape->m_scaling[i] = 1;//bake the scaling into the vertices - return gfxShape; - } -} - - -void ConcaveScene::createConcaveMesh(const ConstructionInfo& ci, const char* fileName, const b3Vector3& shift, const b3Vector3& scaling) -{ - - - - - char relativeFileName[1024]; - const char* prefix[]={"./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int prefixIndex=-1; - { - - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;i shapes; - std::string err = tinyobj::LoadObj(shapes, relativeFileName, prefix[prefixIndex]); - - GLInstanceGraphicsShape* shape = createGraphicsShapeFromWavefrontObj(shapes); - - - b3AlignedObjectArray verts; - for (int i=0;im_numvertices;i++) - { - for (int j=0;j<3;j++) - shape->m_vertices->at(i).xyzw[j] += shift[j]; - - b3Vector3 vtx=b3MakeVector3(shape->m_vertices->at(i).xyzw[0], - shape->m_vertices->at(i).xyzw[1], - shape->m_vertices->at(i).xyzw[2]); - verts.push_back(vtx*scaling); - } - - int colIndex = m_data->m_np->registerConcaveMesh(&verts,shape->m_indices,b3MakeVector3(1,1,1)); - - { - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - - - int shapeId = ci.m_instancingRenderer->registerShape(&shape->m_vertices->at(0).xyzw[0], shape->m_numvertices, &shape->m_indices->at(0), shape->m_numIndices); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color=b3MakeVector4(0.3,0.3,1,1.f);//0.5);//1.f - - - { - float mass = 0.f; - b3Vector3 position=b3MakeVector3(0,0,0); - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - index++; - } - - - - delete shape->m_indices; - delete shape->m_vertices; - delete shape; - - } - } - - - -} - -void ConcaveScene::setupScene(const ConstructionInfo& ci) -{ - - if (1) - { - - //char* fileName = "slopedPlane100.obj"; - //char* fileName = "plane100.obj"; -// char* fileName = "plane100.obj"; - - //char* fileName = "teddy.obj";//"plane.obj"; -// char* fileName = "sponza_closed.obj";//"plane.obj"; - //char* fileName = "leoTest1.obj"; - const char* fileName = "samurai_monastry.obj"; -// char* fileName = "teddy2_VHACD_CHs.obj"; - - b3Vector3 shift1=b3MakeVector3(0,0,0);//0,230,80);//150,-100,-120); - - b3Vector4 scaling=b3MakeVector4(10,10,10,1); - - // createConcaveMesh(ci,"plane100.obj",shift1,scaling); - //createConcaveMesh(ci,"plane100.obj",shift,scaling); - - // b3Vector3 shift2(0,0,0);//0,230,80);//150,-100,-120); - // createConcaveMesh(ci,"teddy.obj",shift2,scaling); - - // b3Vector3 shift3(130,-150,-75);//0,230,80);//150,-100,-120); - // createConcaveMesh(ci,"leoTest1.obj",shift3,scaling); - createConcaveMesh(ci,fileName,shift1,scaling); - - } else - { - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - { - b3Vector4 scaling=b3MakeVector4(400,1.,400,1); - int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,-2,0); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0.f,position,orn,colIndex,index,false); - - } - } - - createDynamicObjects(ci); - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - - float camPos[4]={0,0,0,0};//65.5,4.5,65.5,0}; - //float camPos[4]={1,12.5,1.5,0}; - m_instancingRenderer->setCameraPitch(45); - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(355); - char msg[1024]; - int numInstances = m_data->m_rigidBodyPipeline->getNumBodies(); - sprintf(msg,"Num objects = %d",numInstances); - if (ci.m_gui) - ci.m_gui->setStatusBarMessage(msg,true); - -} - -void ConcaveScene::createDynamicObjects(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - - - int index=0; - - - if (1) - { - int curColor = 0; - b3Vector4 colors[4] = - { - b3MakeVector4(1,1,1,1), - b3MakeVector4(1,1,0.3,1), - b3MakeVector4(0.3,1,1,1), - b3MakeVector4(0.3,0.3,1,1), - }; - - - b3ConvexUtility* utilPtr = new b3ConvexUtility(); - b3Vector4 scaling=b3MakeVector4(1,1,1,1); - - { - b3AlignedObjectArray verts; - - unsigned char* vts = (unsigned char*) cube_vertices; - for (int i=0;iinitializePolyhedralFeatures(&verts[0],verts.size(),merge); - } - } - -// int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - - int colIndex=-1; - if (ci.m_useInstancedCollisionShapes) - colIndex = m_data->m_np->registerConvexHullShape(utilPtr); - - for (int i=0;im_np->registerConvexHullShape(utilPtr); - - float mass = 1; - - //b3Vector3 position(-2*ci.gapX+i*ci.gapX,25+j*ci.gapY,-2*ci.gapZ+k*ci.gapZ); - b3Vector3 position=b3MakeVector3(-(ci.arraySizeX/2)*CONCAVE_GAPX+i*CONCAVE_GAPX, - 23+j*CONCAVE_GAPY, - -(ci.arraySizeZ/2)*CONCAVE_GAPZ+k*CONCAVE_GAPZ); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - index++; - } - } - } - } - -} - -void ConcaveCompoundScene::setupScene(const ConstructionInfo& ci) -{ - ConcaveScene::setupScene(ci); - - float camPos[4]={0,50,0,0};//65.5,4.5,65.5,0}; - //float camPos[4]={1,12.5,1.5,0}; - m_instancingRenderer->setCameraPitch(45); - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(40); - - -} - -void ConcaveCompound2Scene::createDynamicObjects(const ConstructionInfo& ci) -{ - - const char* fileName = "teddy2_VHACD_CHs.obj"; - //char* fileName = "cube_offset.obj"; - - - b3Vector3 shift=b3MakeVector3(0,0,0);//0,230,80);//150,-100,-120); - b3Vector4 scaling=b3MakeVector4(1,1,1,1); - const char* prefix[]={"./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int prefixIndex=-1; - - char relativeFileName[1024]; - { - - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;i shapes; - std::string err = tinyobj::LoadObj(shapes, relativeFileName, prefix[prefixIndex]); - - - if (shapes.size()>0) - { - - - int strideInBytes = 9*sizeof(float); - - b3AlignedObjectArray vertexArray; - b3AlignedObjectArray indexArray; - - - - - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - int colIndex = 0; - - b3AlignedObjectArray vertices; - int stride2 = sizeof(GLInstanceVertex); - b3Assert(stride2 == strideInBytes); - - { - - - b3AlignedObjectArray childShapes; - - int numChildShapes = shapes.size(); - - for (int i=0;i tmpVertices; - //add transformed graphics vertices and indices - b3Vector3 myScaling=b3MakeVector3(50,50,50);//300,300,300); - for (int v=0;vm_np->registerConvexHullShape(&tmpVertices[0].xyzw[0],strideInBytes,numVertices, scaling); - child.m_shapeIndex = childColIndex; - childShapes.push_back(child); - colIndex = childColIndex; - } - colIndex= m_data->m_np->registerCompoundShape(&childShapes); - - } - - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&vertexArray[0].xyzw[0],vertexArray.size(),&indexArray[0],indexArray.size()); - - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,0,1,1), - b3MakeVector4(0,1,1,1), - }; - - int curColor = 0; - for (int i=0;i<1;i++)//ci.arraySizeX;i++) - { - for (int j=0;j<4;j++) - { - // for (int k=0;kregisterGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - index++; - } - } - } - - } - -} - -void ConcaveCompoundScene::createDynamicObjects(const ConstructionInfo& ci) -{ - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - - b3AlignedObjectArray vertexArray; - b3AlignedObjectArray indexArray; - - - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - float scaling[4] = {1,1,1,1}; - int colIndex = 0; - - GLInstanceVertex* cubeVerts = (GLInstanceVertex*)&cube_vertices[0]; - int stride2 = sizeof(GLInstanceVertex); - b3Assert(stride2 == strideInBytes); - - { - int childColIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - - -b3Vector3 childPositions[3] = { - b3MakeVector3(0,-2,0), - b3MakeVector3(0,0,0), - b3MakeVector3(0,0,2) - }; - - b3AlignedObjectArray childShapes; - int numChildShapes = 3; - for (int i=0;im_np->registerCompoundShape(&childShapes); - - } - - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&vertexArray[0].xyzw[0],vertexArray.size(),&indexArray[0],indexArray.size()); - - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,0,1,1), - b3MakeVector4(0,1,1,1), - }; - - int curColor = 0; - for (int i=0;iregisterGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - index++; - } - } - } -} - - -void ConcaveSphereScene::setupScene(const ConstructionInfo& ci) -{ - ConcaveScene::setupScene(ci); - - float camPos[4]={0,50,0,0};//65.5,4.5,65.5,0}; - //float camPos[4]={1,12.5,1.5,0}; - m_instancingRenderer->setCameraPitch(45); - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(40); - - -} - -void ConcaveSphereScene::createDynamicObjects(const ConstructionInfo& ci) -{ - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), - }; - - int index=0; - int curColor = 0; - float radius = 1; - //int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int colIndex = m_data->m_np->registerSphereShape(radius);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int prevGraphicsShapeIndex = registerGraphicsSphereShape(ci,radius,false); - - for (int i=0;iregisterGraphicsInstance(prevGraphicsShapeIndex,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - index++; - } - } - } -} diff --git a/Demos3/GpuDemos/rigidbody/ConcaveScene.h b/Demos3/GpuDemos/rigidbody/ConcaveScene.h deleted file mode 100644 index 79e87e422..000000000 --- a/Demos3/GpuDemos/rigidbody/ConcaveScene.h +++ /dev/null @@ -1,101 +0,0 @@ -#ifndef CONCAVE_SCENE_H -#define CONCAVE_SCENE_H - -#include "GpuRigidBodyDemo.h" -#include "Bullet3Common/b3Vector3.h" - -class ConcaveScene : public GpuRigidBodyDemo -{ -public: - - ConcaveScene(){} - virtual ~ConcaveScene(){} - virtual const char* getName() - { - return "BoxTrimesh"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new ConcaveScene; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void createDynamicObjects(const ConstructionInfo& ci); - - virtual void createConcaveMesh(const ConstructionInfo& ci, const char* fileName, const b3Vector3& shift, const b3Vector3& scaling); - -}; - - -class ConcaveSphereScene : public ConcaveScene -{ -public: - - ConcaveSphereScene(){} - virtual ~ConcaveSphereScene(){} - virtual const char* getName() - { - return "SphereTrimesh"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new ConcaveSphereScene; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void createDynamicObjects(const ConstructionInfo& ci); - -}; - - -class ConcaveCompoundScene : public ConcaveScene -{ -public: - - ConcaveCompoundScene(){} - virtual ~ConcaveCompoundScene(){} - virtual const char* getName() - { - return "CompoundConcave"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new ConcaveCompoundScene; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void createDynamicObjects(const ConstructionInfo& ci); - -}; - - -class ConcaveCompound2Scene : public ConcaveCompoundScene -{ -public: - - ConcaveCompound2Scene(){} - virtual ~ConcaveCompound2Scene(){} - virtual const char* getName() - { - return "GRBConcave2Compound"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new ConcaveCompound2Scene; - return demo; - } - virtual void createDynamicObjects(const ConstructionInfo& ci); -}; - - -#endif //CONCAVE_SCENE_H diff --git a/Demos3/GpuDemos/rigidbody/GpuCompoundScene.cpp b/Demos3/GpuDemos/rigidbody/GpuCompoundScene.cpp deleted file mode 100644 index a7a9c88ed..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuCompoundScene.cpp +++ /dev/null @@ -1,273 +0,0 @@ -#include "GpuCompoundScene.h" -#include "GpuRigidBodyDemo.h" -#include "OpenGLWindow/ShapeData.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "GpuRigidBodyDemoInternalData.h" -#include "Bullet3Common/b3Transform.h" - -#include "OpenGLWindow/GLInstanceGraphicsShape.h" - -#define NUM_COMPOUND_CHILDREN_X 4 -#define NUM_COMPOUND_CHILDREN_Y 4 -#define NUM_COMPOUND_CHILDREN_Z 4 - - - -void GpuCompoundScene::setupScene(const ConstructionInfo& ci) -{ - - createStaticEnvironment(ci); - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - float scaling[4] = {1,1,1,1}; - - GLInstanceVertex* cubeVerts = (GLInstanceVertex*)&cube_vertices[0]; - int stride2 = sizeof(GLInstanceVertex); - b3Assert(stride2 == strideInBytes); - int index=0; - int colIndex = -1; - b3AlignedObjectArray vertexArray; - b3AlignedObjectArray indexArray; - { - int childColIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - - -/* b3Vector3 childPositions[3] = { - b3Vector3(0,-2,0), - b3Vector3(0,0,0), - b3Vector3(0,0,2) - }; - */ - - - b3AlignedObjectArray childShapes; - - for (int x=0;xm_np->registerCompoundShape(&childShapes); - - } - - - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&vertexArray[0].xyzw[0],vertexArray.size(),&indexArray[0],indexArray.size()); - - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,0,1,1), - b3MakeVector4(0,1,1,1), - }; - - int curColor = 0; - for (int i=0;iregisterGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - index++; - } - } - } - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - - - float camPos[4]={0,0,0};//65.5,4.5,65.5,0}; - //float camPos[4]={1,12.5,1.5,0}; - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(320); - -} - - - - - - -void GpuCompoundScene::createStaticEnvironment(const ConstructionInfo& ci) -{ - - int strideInBytes = 9*sizeof(float); - - - - - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - int colIndex = 0; - - { - if (1) - { - float radius = 41; - int prevGraphicsShapeIndex = -1; - { - - - - if (radius>=100) - { - int numVertices = sizeof(detailed_sphere_vertices)/strideInBytes; - int numIndices = sizeof(detailed_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&detailed_sphere_vertices[0],numVertices,detailed_sphere_indices,numIndices); - } else - { - bool usePointSprites = false; - if (usePointSprites) - { - int numVertices = sizeof(point_sphere_vertices)/strideInBytes; - int numIndices = sizeof(point_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&point_sphere_vertices[0],numVertices,point_sphere_indices,numIndices,B3_GL_POINTS); - } else - { - if (radius>=10) - { - int numVertices = sizeof(medium_sphere_vertices)/strideInBytes; - int numIndices = sizeof(medium_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&medium_sphere_vertices[0],numVertices,medium_sphere_indices,numIndices); - } else - { - int numVertices = sizeof(low_sphere_vertices)/strideInBytes; - int numIndices = sizeof(low_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&low_sphere_vertices[0],numVertices,low_sphere_indices,numIndices); - } - } - } - - } - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), - }; - - int curColor = 1; - - //int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int colIndex = m_data->m_np->registerSphereShape(radius);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - float mass = 0.f; - - //b3Vector3 position((j&1)+i*2.2,1+j*2.,(j&1)+k*2.2); - b3Vector3 position=b3MakeVector3(0,-41,0); - - - b3Quaternion orn(0,0,0,1); - - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - b3Vector4 scaling=b3MakeVector4(radius,radius,radius,1); - int id = ci.m_instancingRenderer->registerGraphicsInstance(prevGraphicsShapeIndex,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - index++; - - - } - } -} - -void GpuCompoundPlaneScene::createStaticEnvironment(const ConstructionInfo& ci) -{ - - int index=0; - b3Vector3 normal=b3MakeVector3(0,1,0); - float constant=0.f; - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - - b3Vector4 scaling=b3MakeVector4(400,1.,400,1); - - //int colIndex = m_data->m_np->registerPlaneShape(normal,constant);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,0,0); - b3Quaternion orn(0,0,0,1); - // b3Quaternion orn(b3Vector3(1,0,0),0.3); - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0.f,position,orn,colIndex,index,false); -} \ No newline at end of file diff --git a/Demos3/GpuDemos/rigidbody/GpuCompoundScene.h b/Demos3/GpuDemos/rigidbody/GpuCompoundScene.h deleted file mode 100644 index de3f9e171..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuCompoundScene.h +++ /dev/null @@ -1,50 +0,0 @@ -#ifndef GPU_COMPOUND_SCENE_H -#define GPU_COMPOUND_SCENE_H - -#include "GpuRigidBodyDemo.h" - -class GpuCompoundScene : public GpuRigidBodyDemo -{ -public: - - GpuCompoundScene(){} - virtual ~GpuCompoundScene(){} - virtual const char* getName() - { - return "CompoundOnSphere"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuCompoundScene; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void createStaticEnvironment(const ConstructionInfo& ci); - -}; - - -class GpuCompoundPlaneScene : public GpuCompoundScene -{ -public: - - GpuCompoundPlaneScene(){} - virtual ~GpuCompoundPlaneScene(){} - virtual const char* getName() - { - return "CompoundOnPlane"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuCompoundPlaneScene; - return demo; - } - - virtual void createStaticEnvironment(const ConstructionInfo& ci); - -}; -#endif //GPU_COMPOUND_SCENE_H diff --git a/Demos3/GpuDemos/rigidbody/GpuConvexScene.cpp b/Demos3/GpuDemos/rigidbody/GpuConvexScene.cpp deleted file mode 100644 index 10c334d3f..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuConvexScene.cpp +++ /dev/null @@ -1,546 +0,0 @@ -#include "GpuConvexScene.h" -#include "GpuRigidBodyDemo.h" -#include "OpenGLWindow/ShapeData.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "GpuRigidBodyDemoInternalData.h" -#include "Bullet3AppSupport/gwenUserInterface.h" -#include "Bullet3Dynamics/ConstraintSolver/b3Point2PointConstraint.h" -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "Bullet3OpenCL/Raycast/b3GpuRaycast.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3ConvexUtility.h" -#include "Bullet3Dynamics/ConstraintSolver/b3FixedConstraint.h" - -#include "OpenGLWindow/GLRenderToTexture.h" - -b3Vector4 colors[4] = -{ - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), -}; - -void GpuConvexScene::setupScene(const ConstructionInfo& ci) -{ - m_primRenderer = ci.m_primRenderer; - - m_raycaster = new b3GpuRaycast(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - - int index=0; - createStaticEnvironment(ci); - - index+=createDynamicsObjects(ci); - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - - float camPos[4]={0,0,0,0};//ci.arraySizeX,ci.arraySizeY/2,ci.arraySizeZ,0}; - //float camPos[4]={1,12.5,1.5,0}; - - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(150); - //m_instancingRenderer->setCameraYaw(85); - m_instancingRenderer->setCameraYaw(30); - m_instancingRenderer->setCameraPitch(225); - - - m_instancingRenderer->updateCamera(); - - char msg[1024]; - int numInstances = index; - sprintf(msg,"Num objects = %d",numInstances); - if (ci.m_gui) - ci.m_gui->setStatusBarMessage(msg,true); -} - -void GpuConvexScene::destroyScene() -{ - delete m_raycaster; - m_raycaster = 0; -} - -int GpuConvexScene::createDynamicsObjects(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - /*int numVertices = sizeof(barrel_vertices)/strideInBytes; - int numIndices = sizeof(barrel_indices)/sizeof(int); - return createDynamicsObjects2(ci,barrel_vertices,numVertices,barrel_indices,numIndices); - */ - - int numVertices = sizeof(tetra_vertices)/strideInBytes; - int numIndices = sizeof(tetra_indices)/sizeof(int); - return createDynamicsObjects2(ci,tetra_vertices,numVertices,tetra_indices,numIndices); - -} - -int GpuBoxPlaneScene::createDynamicsObjects(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - return createDynamicsObjects2(ci,cube_vertices_textured,numVertices,cube_indices,numIndices); -} - - -int GpuConvexScene::createDynamicsObjects2(const ConstructionInfo& ci, const float* vertices, int numVertices, const int* indices, int numIndices) -{ - int strideInBytes = 9*sizeof(float); - int textureIndex = -1; - if (0) - { - int width,height,n; - - const char* filename = "data/cube.png"; - const unsigned char* image=0; - - const char* prefix[]={"./","../","../../","../../../","../../../../"}; - int numprefix = sizeof(prefix)/sizeof(const char*); - - for (int i=0;!image && iregisterTexture(image,width,height); - } - } - - int shapeId = ci.m_instancingRenderer->registerShape(&vertices[0],numVertices,indices,numIndices,B3_GL_TRIANGLES,textureIndex); - int group=1; - int mask=1; - int index=0; - - - - - - { - - - int curColor = 0; - float scaling[4] = {1,1,1,1}; - int prevBody = -1; - int insta = 0; - - b3ConvexUtility* utilPtr = new b3ConvexUtility(); - - { - b3AlignedObjectArray verts; - - unsigned char* vts = (unsigned char*) vertices; - for (int i=0;iinitializePolyhedralFeatures(&verts[0],verts.size(),merge); - } - } - - int colIndex=-1; - if (ci.m_useInstancedCollisionShapes) - colIndex = m_data->m_np->registerConvexHullShape(utilPtr); - - //int colIndex = m_data->m_np->registerSphereShape(1); - for (int i=0;im_np->registerConvexHullShape(&vertices[0],strideInBytes,numVertices, scaling); - if (!ci.m_useInstancedCollisionShapes) - colIndex = m_data->m_np->registerConvexHullShape(utilPtr); - - float mass = 1.f; - if (j==0)//ci.arraySizeY-1) - { - //mass=0.f; - } - b3Vector3 position = b3MakeVector3(((j+1)&1)+i*2.2,1+j*2.,((j+1)&1)+k*2.2); - //b3Vector3 position = b3MakeVector3(i*2,1+j*2,k*2); - //b3Vector3 position=b3MakeVector3(1,0.9,1); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - b3Vector4 scalin=b3MakeVector4(1,1,1,1); - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index,false); - - - if (prevBody>=0) - { - //b3Point2PointConstraint* p2p = new b3Point2PointConstraint(pid,prevBody,b3Vector3(0,-1.1,0),b3Vector3(0,1.1,0)); -// m_data->m_rigidBodyPipeline->addConstraint(p2p);//,false); - } - prevBody = pid; - - index++; - } - } - } - delete utilPtr; - } - return index; -} - - -void GpuConvexScene::createStaticEnvironment(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - - - { - b3Vector4 scaling=b3MakeVector4(400,400,400,1); - int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,-400,0); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0.f,position,orn,colIndex,index,false); - - } -} - -void GpuConvexPlaneScene::createStaticEnvironment(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - - - { - b3Vector4 scaling=b3MakeVector4(400,400,400,1); - int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,-400,0); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0.f,position,orn,colIndex,index,false); - - } - -} - -/* -void GpuConvexPlaneScene::createStaticEnvironment(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int group=1; - int mask=1; - int index=0; - - - { - b3Vector4 scaling=b3MakeVector4(100,0.001,100,1); - - - //int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 normal=b3MakeVector3(0,1,0); - float constant=0.f; - int colIndex = m_data->m_np->registerPlaneShape(normal,constant);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,0,0); - - - - b3Quaternion orn(0,0,0,1); - - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0.f,position,orn,colIndex,index,false); - - } - -} -*/ - - - - -struct TetraBunny -{ -#include "bunny.inl" -}; - -struct TetraCube -{ -#include "cube.inl" -}; - - - - -static int nextLine(const char* buffer) -{ - int numBytesRead=0; - - while (*buffer != '\n') - { - buffer++; - numBytesRead++; - } - - - if (buffer[0]==0x0a) - { - buffer++; - numBytesRead++; - } - return numBytesRead; -} - -static float mytetra_vertices[] = -{ - -1.f, 0, -1.f, 0.5f, 0, 1,0, 0,0, - -1.f, 0, 1.f, 0.5f, 0, 1,0, 1,0, - 1.f, 0, 1.f, 0.5f, 0, 1,0, 1,1, - 1.f, 0, -1.f, 0.5f, 0, 1,0, 0,1 -}; - -static int mytetra_indices[]= -{ - 0,1,2, - 3,1,2,3,2,0, - 3,0,1 -}; - - -/* Create from TetGen .ele, .face, .node data */ -void GpuTetraScene::createFromTetGenData(const char* ele, - const char* node, - const ConstructionInfo& ci) -{ - b3Scalar scaling(10); - - b3AlignedObjectArray pos; - int nnode=0; - int ndims=0; - int nattrb=0; - int hasbounds=0; - int result = sscanf(node,"%d %d %d %d",&nnode,&ndims,&nattrb,&hasbounds); - result = sscanf(node,"%d %d %d %d",&nnode,&ndims,&nattrb,&hasbounds); - node += nextLine(node); - - //b3AlignedObjectArray rigidBodyPositions; - //b3AlignedObjectArray rigidBodyIds; - - pos.resize(nnode); - for(int i=0;i>index; - // sn>>x;sn>>y;sn>>z; - node += nextLine(node); - - //for(int j=0;j>a; - - //if(hasbounds) - // sn>>bound; - - pos[index].setX(b3Scalar(x)*scaling); - pos[index].setY(b3Scalar(y)*scaling); - pos[index].setZ(b3Scalar(z)*scaling); - } - - - if(ele&&ele[0]) - { - int ntetra=0; - int ncorner=0; - int neattrb=0; - sscanf(ele,"%d %d %d",&ntetra,&ncorner,&neattrb); - ele += nextLine(ele); - - //se>>ntetra;se>>ncorner;se>>neattrb; - for(int i=0;i>index; - //se>>ni[0];se>>ni[1];se>>ni[2];se>>ni[3]; - sscanf(ele,"%d %d %d %d %d",&index,&ni[0],&ni[1],&ni[2],&ni[3]); - ele+=nextLine(ele); - - b3Vector3 average=b3MakeVector3(0,0,0); - - for (int v=0;v<4;v++) - { - average+=pos[ni[v]]; - } - average/=4; - - for (int v=0;v<4;v++) - { - b3Vector3 shiftedPos = pos[ni[v]]-average; - mytetra_vertices[0+v*9] = shiftedPos.getX(); - mytetra_vertices[1+v*9] = shiftedPos.getY(); - mytetra_vertices[2+v*9] = shiftedPos.getZ(); - } - //todo: subtract average - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(mytetra_vertices)/strideInBytes; - int numIndices = sizeof(mytetra_indices)/sizeof(int); - int shapeId = ci.m_instancingRenderer->registerShape(&mytetra_vertices[0],numVertices,mytetra_indices,numIndices); - int group=1; - int mask=1; - - - - { - b3Vector4 scaling=b3MakeVector4(1,1,1,1); - int colIndex = m_data->m_np->registerConvexHullShape(&mytetra_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 position=b3MakeVector3(0,150,0); -// position+=average;//*1.2;//*2; - position+=average*1.2;//*2; - //rigidBodyPositions.push_back(position); - b3Quaternion orn(0,0,0,1); - - static int curColor=0; - b3Vector4 color = colors[curColor++]; - curColor&=3; - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(1.f,position,orn,colIndex,0,false); - //rigidBodyIds.push_back(pid); - - } - - - - //for(int j=0;j>a; - //psb->appendTetra(ni[0],ni[1],ni[2],ni[3]); - - } - // printf("Nodes: %u\r\n",psb->m_nodes.size()); - // printf("Links: %u\r\n",psb->m_links.size()); - // printf("Faces: %u\r\n",psb->m_faces.size()); - // printf("Tetras: %u\r\n",psb->m_tetras.size()); - - } - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - m_data->m_np->writeAllBodiesToGpu(); - m_data->m_bp->writeAabbsToGpu(); - m_data->m_rigidBodyPipeline->setupGpuAabbsFull(); - m_data->m_bp->calculateOverlappingPairs(m_data->m_config.m_maxBroadphasePairs); - - int numPairs = m_data->m_bp->getNumOverlap(); - cl_mem pairs = m_data->m_bp->getOverlappingPairBuffer(); - b3OpenCLArray clPairs(m_clData->m_clContext,m_clData->m_clQueue); - clPairs.setFromOpenCLBuffer(pairs,numPairs); - b3AlignedObjectArray allPairs; - clPairs.copyToHost(allPairs); - - for (int p=0;pm_np->getObjectTransformFromCpu(posA,ornA,bodyIndexA); - m_data->m_np->getObjectTransformFromCpu(posB,ornB,bodyIndexB); - - b3Vector3 pivotWorld = (posA+posB)*0.5f; - b3Transform transA,transB; - transA.setIdentity(); - transA.setOrigin(posA); - transA.setRotation(ornA); - transB.setIdentity(); - transB.setOrigin(posB); - transB.setRotation(ornB); - b3Vector3 pivotInA = transA.inverse()*pivotWorld; - b3Vector3 pivotInB = transB.inverse()*pivotWorld; - - b3Transform frameInA,frameInB; - frameInA.setIdentity(); - frameInB.setIdentity(); - frameInA.setOrigin(pivotInA); - frameInB.setOrigin(pivotInB); - b3Quaternion relTargetAB = frameInA.getRotation()*frameInB.getRotation().inverse(); - - //c = new b3FixedConstraint(pid,prevBody,frameInA,frameInB); - float breakingThreshold = 45;//37.f; - //c->setBreakingImpulseThreshold(37.1); - bool useGPU = true; - if (useGPU) - { - int cid = m_data->m_rigidBodyPipeline->createFixedConstraint(bodyIndexA,bodyIndexB,pivotInA,pivotInB,relTargetAB,breakingThreshold); - } else - { - b3FixedConstraint* c = new b3FixedConstraint(bodyIndexA,bodyIndexB,frameInA,frameInB); - c->setBreakingImpulseThreshold(breakingThreshold); - m_data->m_rigidBodyPipeline->addConstraint(c); - } - - - } - - printf("numPairs = %d\n",numPairs); - -} - - -int GpuTetraScene::createDynamicsObjects(const ConstructionInfo& ci) -{ - - //createFromTetGenData(TetraCube::getElements(),TetraCube::getNodes(),ci); - createFromTetGenData(TetraBunny::getElements(),TetraBunny::getNodes(),ci); - - return 0; -} diff --git a/Demos3/GpuDemos/rigidbody/GpuConvexScene.h b/Demos3/GpuDemos/rigidbody/GpuConvexScene.h deleted file mode 100644 index be5b187df..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuConvexScene.h +++ /dev/null @@ -1,114 +0,0 @@ -#ifndef GPU_CONVEX_SCENE_H -#define GPU_CONVEX_SCENE_H - -#include "GpuRigidBodyDemo.h" -#include "Bullet3Common/b3AlignedObjectArray.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3RaycastInfo.h" - -class GpuConvexScene : public GpuRigidBodyDemo -{ -protected: - class GLPrimitiveRenderer* m_primRenderer; - - class b3GpuRaycast* m_raycaster; - -public: - - GpuConvexScene() :m_primRenderer(0), m_raycaster(0) - { - } - virtual ~GpuConvexScene(){} - virtual const char* getName() - { - return "Tetrahedra"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuConvexScene; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void destroyScene(); - - virtual int createDynamicsObjects(const ConstructionInfo& ci); - - virtual int createDynamicsObjects2(const ConstructionInfo& ci,const float* vertices, int numVertices, const int* indices,int numIndices); - - virtual void createStaticEnvironment(const ConstructionInfo& ci); - -}; - - -class GpuConvexPlaneScene : public GpuConvexScene -{ -public: - - GpuConvexPlaneScene(){} - virtual ~GpuConvexPlaneScene(){} - virtual const char* getName() - { - return "ConvexOnPlane"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuConvexPlaneScene; - return demo; - } - - virtual void createStaticEnvironment(const ConstructionInfo& ci); - -}; - - -class GpuBoxPlaneScene : public GpuConvexPlaneScene -{ -public: - - GpuBoxPlaneScene(){} - virtual ~GpuBoxPlaneScene(){} - virtual const char* getName() - { - return "BoxBox"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuBoxPlaneScene; - return demo; - } - - virtual int createDynamicsObjects(const ConstructionInfo& ci); - - -}; - -class GpuTetraScene : public GpuConvexScene -{ - -protected: -void createFromTetGenData(const char* ele, - const char* node, - const ConstructionInfo& ci); - -public: - virtual const char* getName() - { - return "TetraBreakable"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuTetraScene; - return demo; - } - - virtual int createDynamicsObjects(const ConstructionInfo& ci); - -}; - - -#endif //GPU_CONVEX_SCENE_H diff --git a/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemo.cpp b/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemo.cpp deleted file mode 100644 index d5e44db10..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemo.cpp +++ /dev/null @@ -1,503 +0,0 @@ -#include "GpuRigidBodyDemo.h" -#include "OpenGLWindow/ShapeData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuGridBroadphase.h" - -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "GpuRigidBodyDemoInternalData.h" -#include "Bullet3Collision/BroadPhaseCollision/b3DynamicBvhBroadphase.h" -#include "Bullet3Collision/NarrowPhaseCollision/shared/b3RigidBodyData.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhaseInternalData.h" - -#include "OpenGLWindow/GLPrimitiveRenderer.h" - -static b3KeyboardCallback oldCallback = 0; -extern bool gReset; -bool useUniformGrid = false; -bool convertOnCpu = false; -static bool sShowShadowMap = true; -#define MSTRINGIFY(A) #A - -static const char* s_rigidBodyKernelString = MSTRINGIFY( - -typedef struct -{ - float4 m_pos; - float4 m_quat; - float4 m_linVel; - float4 m_angVel; - unsigned int m_collidableIdx; - float m_invMass; - float m_restituitionCoeff; - float m_frictionCoeff; -} Body; - -__kernel void - copyTransformsToVBOKernel( __global Body* gBodies, __global float4* posOrnColor, const int numNodes) -{ - int nodeID = get_global_id(0); - if( nodeID < numNodes ) - { - posOrnColor[nodeID] = (float4) (gBodies[nodeID].m_pos.xyz,1.0); - posOrnColor[nodeID + numNodes] = gBodies[nodeID].m_quat; - } -} -); - - - - - -GpuRigidBodyDemo::GpuRigidBodyDemo() -:m_instancingRenderer(0), -m_window(0) -{ - m_data = new GpuRigidBodyDemoInternalData; -} -GpuRigidBodyDemo::~GpuRigidBodyDemo() -{ - - delete m_data; -} - - - - - - - -static void PairKeyboardCallback(int key, int state) -{ - if (key=='R' && state) - { - gReset = true; - } - - //b3DefaultKeyboardCallback(key,state); - oldCallback(key,state); -} - -void GpuRigidBodyDemo::setupScene(const ConstructionInfo& ci) -{ - -} - -void GpuRigidBodyDemo::initPhysics(const ConstructionInfo& ci) -{ - - if (ci.m_window) - { - m_window = ci.m_window; - oldCallback = ci.m_window->getKeyboardCallback(); - ci.m_window->setKeyboardCallback(PairKeyboardCallback); - - } - - m_instancingRenderer = ci.m_instancingRenderer; - m_primRenderer = ci.m_primRenderer; - initCL(ci.preferredOpenCLDeviceIndex,ci.preferredOpenCLPlatformIndex); - - if (m_clData->m_clContext) - { - int errNum=0; - - cl_program rbProg=0; - m_data->m_copyTransformsToVBOKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext,m_clData->m_clDevice,s_rigidBodyKernelString,"copyTransformsToVBOKernel",&errNum,rbProg); - - m_data->m_config.m_maxConvexBodies = b3Max(m_data->m_config.m_maxConvexBodies,ci.arraySizeX*ci.arraySizeY*ci.arraySizeZ+10); - m_data->m_config.m_maxConvexShapes = m_data->m_config.m_maxConvexBodies; - int maxPairsPerBody = 16; - m_data->m_config.m_maxBroadphasePairs = maxPairsPerBody*m_data->m_config.m_maxConvexBodies; - m_data->m_config.m_maxContactCapacity = m_data->m_config.m_maxBroadphasePairs; - - - b3GpuNarrowPhase* np = new b3GpuNarrowPhase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue,m_data->m_config); - b3GpuBroadphaseInterface* bp =0; - - if (useUniformGrid) - { - bp = new b3GpuGridBroadphase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - } else - { - bp = new b3GpuSapBroadphase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - } - m_data->m_np = np; - m_data->m_bp = bp; - m_data->m_broadphaseDbvt = new b3DynamicBvhBroadphase(m_data->m_config.m_maxConvexBodies); - - m_data->m_rigidBodyPipeline = new b3GpuRigidBodyPipeline(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue, np, bp,m_data->m_broadphaseDbvt,m_data->m_config); - - - setupScene(ci); - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - np->writeAllBodiesToGpu(); - bp->writeAabbsToGpu(); - - } - - - - m_instancingRenderer->writeTransforms(); - - - -} - -void GpuRigidBodyDemo::exitPhysics() -{ - destroyScene(); - - delete m_data->m_instancePosOrnColor; - delete m_data->m_rigidBodyPipeline; - delete m_data->m_broadphaseDbvt; - - m_window->setKeyboardCallback(oldCallback); - - delete m_data->m_np; - m_data->m_np = 0; - delete m_data->m_bp; - m_data->m_bp = 0; - - exitCL(); -} - - -void GpuRigidBodyDemo::renderScene() -{ - m_instancingRenderer->renderScene(); - if (sShowShadowMap) - { - glDisable(GL_DEPTH_TEST); - - float borderColor[4]={0,0,0,1}; - m_primRenderer->drawRect(9,29,191,211,borderColor); - float color[4]={1,1,1,1}; - //m_shadowData->m_instancingRenderer->renderScene(); - m_instancingRenderer->enableShadowMap(); - glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_NONE ); - // glTexParameteri( GL_TEXTURE_2D, GL_DEPTH_TEXTURE_MODE, GL_LUMINANCE ); - m_primRenderer->drawTexturedRect(10,30,190,210,color,0,0,1,1,true); - glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_COMPARE_REF_TO_TEXTURE); - glEnable(GL_DEPTH_TEST); - - } - -} - -void GpuRigidBodyDemo::clientMoveAndDisplay() -{ - bool animate=true; - int numObjects= m_data->m_rigidBodyPipeline->getNumBodies(); - //printf("numObjects=%d\n",numObjects); - if (numObjects > m_instancingRenderer->getInstanceCapacity()) - { - static bool once = true; - if (once) - { - once=false; - b3Assert(0); - b3Error("m_instancingRenderer out-of-memory\n"); - } - numObjects = m_instancingRenderer->getInstanceCapacity(); - } - - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - b3Vector4* positions = 0; - if (animate && numObjects) - { - B3_PROFILE("gl2cl"); - - if (!m_data->m_instancePosOrnColor) - { - GLuint vbo = m_instancingRenderer->getInternalData()->m_vbo; - int arraySizeInBytes = numObjects * (3)*sizeof(b3Vector4); - glBindBuffer(GL_ARRAY_BUFFER, vbo); - cl_bool blocking= CL_TRUE; - positions= (b3Vector4*)glMapBufferRange( GL_ARRAY_BUFFER,m_instancingRenderer->getMaxShapeCapacity(),arraySizeInBytes, GL_MAP_READ_BIT );//GL_READ_WRITE);//GL_WRITE_ONLY - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - m_data->m_instancePosOrnColor = new b3OpenCLArray(m_clData->m_clContext,m_clData->m_clQueue); - m_data->m_instancePosOrnColor->resize(3*numObjects); - m_data->m_instancePosOrnColor->copyFromHostPointer(positions,3*numObjects,0); - glUnmapBuffer( GL_ARRAY_BUFFER); - err = glGetError(); - assert(err==GL_NO_ERROR); - } - } - - { - B3_PROFILE("stepSimulation"); - m_data->m_rigidBodyPipeline->stepSimulation(1./60.f); - - } - - if (numObjects) - { - if (convertOnCpu) - { - b3GpuNarrowPhaseInternalData* npData = m_data->m_np->getInternalData(); - npData->m_bodyBufferGPU->copyToHost(*npData->m_bodyBufferCPU); - - b3AlignedObjectArray vboCPU; - m_data->m_instancePosOrnColor->copyToHost(vboCPU); - - for (int i=0;im_bodyBufferCPU->at(i).m_pos; - b3Quat orn = npData->m_bodyBufferCPU->at(i).m_quat; - pos.w = 1.f; - vboCPU[i] = pos; - vboCPU[i + numObjects] = (b3Vector4&)orn; - } - m_data->m_instancePosOrnColor->copyFromHost(vboCPU); - - } else - { - B3_PROFILE("cl2gl_convert"); - int ciErrNum = 0; - cl_mem bodies = m_data->m_rigidBodyPipeline->getBodyBuffer(); - b3LauncherCL launch(m_clData->m_clQueue,m_data->m_copyTransformsToVBOKernel,"m_copyTransformsToVBOKernel"); - launch.setBuffer(bodies); - launch.setBuffer(m_data->m_instancePosOrnColor->getBufferCL()); - launch.setConst(numObjects); - launch.launch1D(numObjects); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - } - } - - if (animate && numObjects) - { - B3_PROFILE("cl2gl_upload"); - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - GLuint vbo = m_instancingRenderer->getInternalData()->m_vbo; - - int arraySizeInBytes = numObjects * (3)*sizeof(b3Vector4); - - glBindBuffer(GL_ARRAY_BUFFER, vbo); - cl_bool blocking= CL_TRUE; - positions= (b3Vector4*)glMapBufferRange( GL_ARRAY_BUFFER,m_instancingRenderer->getMaxShapeCapacity(),arraySizeInBytes, GL_MAP_WRITE_BIT );//GL_READ_WRITE);//GL_WRITE_ONLY - err = glGetError(); - assert(err==GL_NO_ERROR); - m_data->m_instancePosOrnColor->copyToHostPointer(positions,3*numObjects,0); - glUnmapBuffer( GL_ARRAY_BUFFER); - err = glGetError(); - assert(err==GL_NO_ERROR); - } - -} - -b3Vector3 GpuRigidBodyDemo::getRayTo(int x,int y) -{ - if (!m_instancingRenderer) - return b3MakeVector3(0,0,0); - - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float tanFov = (top-bottom)*0.5f / nearPlane; - float fov = b3Scalar(2.0) * b3Atan(tanFov); - - b3Vector3 camPos,camTarget; - m_instancingRenderer->getCameraPosition(camPos); - m_instancingRenderer->getCameraTargetPosition(camTarget); - - b3Vector3 rayFrom = camPos; - b3Vector3 rayForward = (camTarget-camPos); - rayForward.normalize(); - float farPlane = 10000.f; - rayForward*= farPlane; - - b3Vector3 rightOffset; - b3Vector3 m_cameraUp=b3MakeVector3(0,1,0); - b3Vector3 vertical = m_cameraUp; - - b3Vector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - b3Scalar aspect; - float width = m_instancingRenderer->getScreenWidth(); - float height = m_instancingRenderer->getScreenHeight(); - - aspect = width / height; - - hor*=aspect; - - - b3Vector3 rayToCenter = rayFrom + rayForward; - b3Vector3 dHor = hor * 1.f/width; - b3Vector3 dVert = vertical * 1.f/height; - - - b3Vector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += b3Scalar(x) * dHor; - rayTo -= b3Scalar(y) * dVert; - return rayTo; -} - -bool GpuRigidBodyDemo::keyboardCallback(int key, int state) -{ - - if (m_data) - { - if (key==B3G_ALT ) - { - m_data->m_altPressed = state; - } - if (key==B3G_CONTROL ) - { - m_data->m_controlPressed = state; - } - } - return false; -} - -bool GpuRigidBodyDemo::mouseMoveCallback(float x,float y) -{ - if (m_data->m_altPressed!=0 || m_data->m_controlPressed!=0) - return false; - - if (m_data->m_pickBody>=0 && m_data->m_pickConstraint>=0) - { - m_data->m_rigidBodyPipeline->removeConstraintByUid(m_data->m_pickConstraint); - b3Vector3 newRayTo = getRayTo(x,y); - b3Vector3 rayFrom; - b3Vector3 oldPivotInB = m_data->m_pickPivotInB; - b3Vector3 newPivotB; - m_instancingRenderer->getCameraPosition(rayFrom); - b3Vector3 dir = newRayTo-rayFrom; - dir.normalize(); - dir *= m_data->m_pickDistance; - newPivotB = rayFrom + dir; - m_data->m_pickPivotInB = newPivotB; - m_data->m_rigidBodyPipeline->copyConstraintsToHost(); - m_data->m_pickConstraint = m_data->m_rigidBodyPipeline->createPoint2PointConstraint(m_data->m_pickBody,m_data->m_pickFixedBody,m_data->m_pickPivotInA,m_data->m_pickPivotInB,1e30); - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - return true; - } - return false; -} -bool GpuRigidBodyDemo::mouseButtonCallback(int button, int state, float x, float y) -{ - - if (state==1) - { - if(button==0 && (m_data->m_altPressed==0 && m_data->m_controlPressed==0)) - { - b3AlignedObjectArray rays; - b3AlignedObjectArray hitResults; - b3Vector3 camPos; - m_instancingRenderer->getCameraPosition(camPos); - - b3RayInfo ray; - ray.m_from = camPos; - ray.m_to = getRayTo(x,y); - rays.push_back(ray); - b3RayHit hit; - hit.m_hitFraction = 1.f; - hitResults.push_back(hit); - m_data->m_rigidBodyPipeline->castRays(rays,hitResults); - if (hitResults[0].m_hitFraction<1.f) - { - - int hitBodyA = hitResults[0].m_hitBody; - if (m_data->m_np->getBodiesCpu()[hitBodyA].m_invMass) - { - //printf("hit!\n"); - m_data->m_np->readbackAllBodiesToCpu(); - m_data->m_pickBody = hitBodyA; - - - - - //pivotInA - b3Vector3 pivotInB; - pivotInB.setInterpolate3(ray.m_from,ray.m_to,hitResults[0].m_hitFraction); - b3Vector3 posA; - b3Quaternion ornA; - m_data->m_np->getObjectTransformFromCpu(posA,ornA,hitBodyA); - b3Transform tr; - tr.setOrigin(posA); - tr.setRotation(ornA); - b3Vector3 pivotInA = tr.inverse()*pivotInB; - if (m_data->m_pickFixedBody<0) - { - b3Vector3 pos=b3MakeVector3(0,0,0); - b3Quaternion orn(0,0,0,1); - int fixedSphere = m_data->m_np->registerConvexHullShape(0,0,0,0);//>registerSphereShape(0.1); - m_data->m_pickFixedBody = m_data->m_rigidBodyPipeline->registerPhysicsInstance(0,pos,orn,fixedSphere,0,false); - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - m_data->m_bp->writeAabbsToGpu(); - - if (m_data->m_pickGraphicsShapeIndex<0) - { - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(point_sphere_vertices)/strideInBytes; - int numIndices = sizeof(point_sphere_indices)/sizeof(int); - m_data->m_pickGraphicsShapeIndex = m_instancingRenderer->registerShape(&point_sphere_vertices[0],numVertices,point_sphere_indices,numIndices,B3_GL_POINTS); - - float color[4] ={1,0,0,1}; - float scaling[4]={1,1,1,1}; - - m_data->m_pickGraphicsShapeInstance = m_instancingRenderer->registerGraphicsInstance(m_data->m_pickGraphicsShapeIndex,pivotInB,orn,color,scaling); - m_instancingRenderer->writeTransforms(); - delete m_data->m_instancePosOrnColor; - m_data->m_instancePosOrnColor=0; - } else - { - m_instancingRenderer->writeSingleInstanceTransformToCPU(pivotInB,orn,m_data->m_pickGraphicsShapeInstance); - m_instancingRenderer->writeSingleInstanceTransformToGPU(pivotInB,orn,m_data->m_pickGraphicsShapeInstance); - m_data->m_np->setObjectTransformCpu(pos,orn,m_data->m_pickFixedBody); - } - - } - pivotInB.w = 0.f; - m_data->m_pickPivotInA = pivotInA; - m_data->m_pickPivotInB = pivotInB; - m_data->m_rigidBodyPipeline->copyConstraintsToHost(); - m_data->m_pickConstraint = m_data->m_rigidBodyPipeline->createPoint2PointConstraint(hitBodyA,m_data->m_pickFixedBody,pivotInA,pivotInB,1e30);//hitResults[0].m_hitResult0 - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - m_data->m_np->writeAllBodiesToGpu(); - m_data->m_pickDistance = (pivotInB-camPos).length(); - - return true; - } - } - } - } else - { - if (button==0) - { - if (m_data->m_pickConstraint>=0) - { - m_data->m_rigidBodyPipeline->removeConstraintByUid(m_data->m_pickConstraint); - m_data->m_pickConstraint=-1; - } - } - } - - //printf("button=%d, state=%d\n",button,state); - return false; -} diff --git a/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemo.h b/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemo.h deleted file mode 100644 index 698fb4c17..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemo.h +++ /dev/null @@ -1,51 +0,0 @@ -#ifndef GPU_RIGID_BODY_DEMO_H -#define GPU_RIGID_BODY_DEMO_H - -#include "../GpuDemo.h" -#include "Bullet3Common/b3Vector3.h" - -class GpuRigidBodyDemo : public GpuDemo -{ -protected: - class GLInstancingRenderer* m_instancingRenderer; - class GLPrimitiveRenderer* m_primRenderer; - class b3gWindowInterface* m_window; - - struct GpuRigidBodyDemoInternalData* m_data; - -public: - - GpuRigidBodyDemo(); - virtual ~GpuRigidBodyDemo(); - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void destroyScene(){}; - - virtual void exitPhysics(); - - virtual const char* getName() - { - return "GRBD"; - } - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuRigidBodyDemo; - return demo; - } - - virtual void renderScene(); - - virtual void clientMoveAndDisplay(); - - //for picking - b3Vector3 getRayTo(int x,int y); - virtual bool mouseMoveCallback(float x,float y); - virtual bool mouseButtonCallback(int button, int state, float x, float y); - virtual bool keyboardCallback(int key, int state); -}; - -#endif //GPU_RIGID_BODY_DEMO_H - diff --git a/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemoInternalData.h b/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemoInternalData.h deleted file mode 100644 index 9147a5080..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuRigidBodyDemoInternalData.h +++ /dev/null @@ -1,55 +0,0 @@ -#ifndef GPU_RIGIDBODY_INTERNAL_DATA_H -#define GPU_RIGIDBODY_INTERNAL_DATA_H - -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3OpenCLArray.h" -#include "Bullet3Common/b3Vector3.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" - -struct GpuRigidBodyDemoInternalData -{ - - cl_kernel m_copyTransformsToVBOKernel; - - b3OpenCLArray* m_instancePosOrnColor; - - class b3GpuRigidBodyPipeline* m_rigidBodyPipeline; - - class b3GpuNarrowPhase* m_np; - class b3GpuBroadphaseInterface* m_bp; - class b3DynamicBvhBroadphase* m_broadphaseDbvt; - - b3Vector3 m_pickPivotInA; - b3Vector3 m_pickPivotInB; - float m_pickDistance; - int m_pickBody; - int m_pickConstraint; - - int m_altPressed; - int m_controlPressed; - - int m_pickFixedBody; - int m_pickGraphicsShapeIndex; - int m_pickGraphicsShapeInstance; - b3Config m_config; - - GpuRigidBodyDemoInternalData() - :m_instancePosOrnColor(0), - m_copyTransformsToVBOKernel(0), m_rigidBodyPipeline(0), - m_np(0), - m_bp(0), - m_broadphaseDbvt(0), - m_pickConstraint(-1), - m_pickFixedBody(-1), - m_pickGraphicsShapeIndex(-1), - m_pickGraphicsShapeInstance(-1), - m_pickBody(-1), - m_altPressed(0), - m_controlPressed(0) - - { - } -}; - -#endif//GPU_RIGIDBODY_INTERNAL_DATA_H - diff --git a/Demos3/GpuDemos/rigidbody/GpuSphereScene.cpp b/Demos3/GpuDemos/rigidbody/GpuSphereScene.cpp deleted file mode 100644 index b3f0f4629..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuSphereScene.cpp +++ /dev/null @@ -1,204 +0,0 @@ -#include "GpuSphereScene.h" -#include "GpuRigidBodyDemo.h" -#include "OpenGLWindow/ShapeData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "GpuRigidBodyDemoInternalData.h" -#include "Bullet3AppSupport/gwenUserInterface.h" - - - - -void GpuSphereScene::setupScene(const ConstructionInfo& ci) -{ - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - - int group=1; - int mask=1; - int index=0; - bool writeInstanceToGpu = false; - - if (0) - { - float radius = 60; - int prevGraphicsShapeIndex = -1; - { - - - - if (1)//radius>=100) - { - int numVertices = sizeof(detailed_sphere_vertices)/strideInBytes; - int numIndices = sizeof(detailed_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&detailed_sphere_vertices[0],numVertices,detailed_sphere_indices,numIndices); - } else - { - bool usePointSprites = false; - if (usePointSprites) - { - int numVertices = sizeof(point_sphere_vertices)/strideInBytes; - int numIndices = sizeof(point_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&point_sphere_vertices[0],numVertices,point_sphere_indices,numIndices,B3_GL_POINTS); - } else - { - if (radius>=10) - { - int numVertices = sizeof(medium_sphere_vertices)/strideInBytes; - int numIndices = sizeof(medium_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&medium_sphere_vertices[0],numVertices,medium_sphere_indices,numIndices); - } else - { - int numVertices = sizeof(low_sphere_vertices)/strideInBytes; - int numIndices = sizeof(low_sphere_indices)/sizeof(int); - prevGraphicsShapeIndex = ci.m_instancingRenderer->registerShape(&low_sphere_vertices[0],numVertices,low_sphere_indices,numIndices); - } - } - } - - } - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), - }; - - int curColor = 0; - - //int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int colIndex = m_data->m_np->registerSphereShape(radius);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - float mass = 0.f; - - //b3Vector3 position((j&1)+i*2.2,1+j*2.,(j&1)+k*2.2); - b3Vector3 position=b3MakeVector3(0,0,0); - - b3Quaternion orn(0,0,0,1); - - b3Vector4 color = colors[curColor]; - curColor++; - curColor&=3; - b3Vector4 scaling=b3MakeVector4(radius,radius,radius,1); - int id = ci.m_instancingRenderer->registerGraphicsInstance(prevGraphicsShapeIndex,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index, writeInstanceToGpu); - - index++; - - - } - - - - - - - - - - b3Vector4 colors[4] = - { - b3MakeVector4(1,0,0,1), - b3MakeVector4(0,1,0,1), - b3MakeVector4(0,1,1,1), - b3MakeVector4(1,1,0,1), - }; - - - - - - - - - - int curColor = 0; - float radius = 61; - //int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int colIndex = m_data->m_np->registerSphereShape(radius);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - int prevGraphicsShapeIndex = registerGraphicsSphereShape(ci,radius,false); - - //for (int i=0;iregisterGraphicsInstance(prevGraphicsShapeIndex,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(mass,position,orn,colIndex,index, writeInstanceToGpu); - - index++; - } - } - } - - - if (1) - { - int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - b3Vector4 scaling=b3MakeVector4(0.5,0.5,0.5,1);//1,1,1,1);//0.1,0.1,0.1,1); - int colIndex = m_data->m_np->registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector3 normal=b3MakeVector3(0,-1,0); - float constant=2; - - - for (int j=-10;j<10;j++) - for (int i=-10;i<10;i++) - for (int k=0;k<30;k++) - //int i=0;int j=0; - { - //int colIndex = m_data->m_np->registerPlaneShape(normal,constant);//>registerConvexHullShape(&cube_vertices[0],strideInBytes,numVertices, scaling); - b3Vector4 position=b3MakeVector4(2*i,70+k*2,2*j+8,0); - //b3Quaternion orn(0,0,0,1); - b3Quaternion orn(b3MakeVector3(1,0,0),0.3); - - b3Vector4 color=b3MakeVector4(0,0,1,1); - - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - int pid = m_data->m_rigidBodyPipeline->registerPhysicsInstance(1.f,position,orn,colIndex,index,false); - - index++; - } - } - - if (!writeInstanceToGpu) - { - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - } - - float camPos[4]={ci.arraySizeX,ci.arraySizeY/2,ci.arraySizeZ,0}; - //float camPos[4]={1,12.5,1.5,0}; - m_instancingRenderer->setCameraTargetPosition(camPos); - m_instancingRenderer->setCameraDistance(130); - - - char msg[1024]; - int numInstances = index; - sprintf(msg,"Num objects = %d",numInstances); - ci.m_gui->setStatusBarMessage(msg,true); -} diff --git a/Demos3/GpuDemos/rigidbody/GpuSphereScene.h b/Demos3/GpuDemos/rigidbody/GpuSphereScene.h deleted file mode 100644 index b3fcfbae1..000000000 --- a/Demos3/GpuDemos/rigidbody/GpuSphereScene.h +++ /dev/null @@ -1,27 +0,0 @@ -#ifndef GPU_SPHERE_SCENE_H -#define GPU_SPHERE_SCENE_H - -#include "GpuRigidBodyDemo.h" - -class GpuSphereScene : public GpuRigidBodyDemo -{ -public: - - GpuSphereScene(){} - virtual ~GpuSphereScene(){} - virtual const char* getName() - { - return "BoxOnSphere"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuSphereScene; - return demo; - } - - virtual void setupScene(const ConstructionInfo& ci); - -}; - -#endif //GPU_SPHERE_SCENE_H diff --git a/Demos3/GpuDemos/rigidbody/bunny.inl b/Demos3/GpuDemos/rigidbody/bunny.inl deleted file mode 100644 index fbdbfd3fb..000000000 --- a/Demos3/GpuDemos/rigidbody/bunny.inl +++ /dev/null @@ -1,4 +0,0 @@ -static const char* getNodes() { return( -"454 3 0 0\n"" 0 -2.0063499999999999 0.79804200000000003 0.373554\n"" 1 -2.1011299999999999 0.90212400000000004 -0.88661400000000001\n"" 2 -1.4052100000000001 2.0628700000000002 -1.0458400000000001\n"" 3 -1.2015499999999999 1.7112400000000001 0.56249400000000005\n"" 4 0.02112 2.8512499999999998 -0.95618999999999998\n"" 5 0.011136 2.5152199999999998 0.59149200000000002\n"" 6 -1.51681 0.56199600000000005 1.42523\n"" 7 -0.977406 1.4278999999999999 1.24143\n"" 8 0.0051900000000000002 1.9088499999999999 1.41222\n"" 9 -2.4877400000000001 0.98449799999999998 -1.6695199999999999\n"" 10 -1.57328 2.1440000000000001 -1.7594799999999999\n"" 11 0.027768000000000001 2.8961600000000001 -2.0317599999999998\n"" 12 -2.4129700000000001 0.80116799999999999 -2.6594799999999998\n"" 13 -1.46269 1.9456500000000001 -2.6205799999999999\n"" 14 0.031758000000000002 2.6255500000000001 -2.7499899999999999\n"" 15 -2.0392999999999999 -0.24690000000000001 -4.0092699999999999\n"" 16 -1.4902899999999999 1.53495 -3.7649599999999999\n"" 17 0.037566000000000002 2.2566199999999998 -3.78904\n"" 18 -1.29721 -0.760656 -5.3216200000000002\n"" 19 -1.0264500000000001 0.069264000000000006 -5.2883199999999997\n"" 20 -1.0864400000000001 0.58933800000000003 -4.8886700000000003\n"" 21 -0.71934600000000004 1.3127200000000001 -4.5609200000000003\n"" 22 -0.47337000000000001 1.6606799999999999 -4.4356900000000001\n"" 23 0.040806000000000002 1.86575 -4.4139699999999999\n"" 24 -1.01305 0.61432200000000003 -5.5222899999999999\n"" 25 -0.62443199999999999 1.0636699999999999 -5.7151800000000001\n"" 26 -0.77822400000000003 1.2710900000000001 -5.0200699999999996\n"" 27 -0.59924999999999995 1.8655900000000001 -4.7962899999999999\n"" 28 0.043422000000000002 2.1701199999999998 -4.7666300000000001\n"" 29 -0.467478 1.5525199999999999 -5.5298400000000001\n"" 30 0.047742 1.6934499999999999 -5.5900800000000004\n"" 31 -1.5133300000000001 -3.3024100000000001 -3.3468599999999999\n"" 32 -1.6057999999999999 -3.6205099999999999 -3.9312499999999999\n"" 33 -2.6810299999999998 -0.71110200000000001 -2.7969499999999998\n"" 34 -2.7569300000000001 -0.55810199999999999 -1.86805\n"" 35 -2.2238699999999998 -0.60064799999999996 -0.95672400000000002\n"" 36 -2.2319 -0.55194600000000005 -0.066264000000000003\n"" 37 -1.97367 -0.58961399999999997 0.53195400000000004\n"" 38 -1.6947099999999999 -0.11317199999999999 1.8690100000000001\n"" 39 -2.11442 -0.78804600000000002 0.86941199999999996\n"" 40 -2.1847599999999998 -1.2017899999999999 1.2143299999999999\n"" 41 -1.7037899999999999 -1.3912100000000001 0.142008\n"" 42 -1.79366 -0.93130800000000002 2.2183000000000002\n"" 43 -1.7627200000000001 -0.73113600000000001 2.51458\n"" 44 -1.74098 -1.74478 0.64694399999999996\n"" 45 -1.5849899999999999 -1.6370899999999999 0.218082\n"" 46 -1.3714 -2.2354400000000001 1.7418499999999999\n"" 47 -1.14259 -1.7219800000000001 2.5314999999999999\n"" 48 -1.1462300000000001 -1.44584 3.04271\n"" 49 -1.72363 -1.65859 -0.39266400000000001\n"" 50 -1.7740499999999999 -1.6849099999999999 -1.0451999999999999\n"" 51 -2.3972199999999999 -1.87879 -2.2570000000000001\n"" 52 -2.3559999999999999 -2.9314900000000002 -2.5649600000000001\n"" 53 -1.9900100000000001 -3.4211100000000001 -2.7963200000000001\n"" 54 -1.69374 -3.7088399999999999 -3.53532\n"" 55 -2.2454299999999998 -3.5692900000000001 -1.9397899999999999\n"" 56 -2.2864300000000002 -3.77834 -2.10466\n"" 57 -2.2926700000000002 -3.7443599999999999 -1.3294600000000001\n"" 58 -1.6362099999999999 -3.39913 1.55494\n"" 59 -1.5402100000000001 -3.9804400000000002 1.7164699999999999\n"" 60 -1.6856899999999999 -2.5701499999999999 0.33473999999999998\n"" 61 -1.1098399999999999 -3.0533600000000001 1.9575899999999999\n"" 62 -1.6798299999999999 -3.1615099999999998 2.3719100000000002\n"" 63 -1.6955899999999999 -3.9803600000000001 2.4744700000000002\n"" 64 -1.1299699999999999 -2.8505600000000002 2.5077199999999999\n"" 65 -1.5803 -3.9803799999999998 2.79962\n"" 66 -1.2543800000000001 -3.9803600000000001 3.05606\n"" 67 -0.012264000000000001 -1.91774 3.31847\n"" 68 -0.0075960000000000003 -2.22756 2.4797799999999999\n"" 69 -1.3185199999999999 -2.03857 -0.24552599999999999\n"" 70 -1.54192 -1.6950700000000001 -0.038094000000000003\n"" 71 -1.6302399999999999 -1.5652900000000001 0.010584\n"" 72 -0.54714600000000002 -2.5150999999999999 -0.27547199999999999\n"" 73 -0.68966400000000005 -2.5785100000000001 -0.74843400000000004\n"" 74 -0.68381999999999998 -2.29792 -1.13124\n"" 75 -1.45807 -2.78965 -1.4571000000000001\n"" 76 -1.88889 -3.03241 -1.94861\n"" 77 0.016643999999999999 -2.6251600000000002 -1.5766\n"" 78 -0.43575000000000003 -2.5064899999999999 -1.32864\n"" 79 -0.96067199999999997 -2.8615900000000001 -1.7606999999999999\n"" 80 0.023154000000000001 -2.7205499999999998 -2.6635\n"" 81 -0.72217799999999999 -3.4893999999999998 -2.6321300000000001\n"" 82 -0.54899399999999998 -3.50515 -1.7670699999999999\n"" 83 -0.69881400000000005 -3.59917 -1.12985\n"" 84 -1.2481899999999999 -3.0818400000000001 -0.807894\n"" 85 -1.41449 -3.6600999999999999 -0.24563399999999999\n"" 86 -2.0695000000000001 -3.7349199999999998 -0.51227999999999996\n"" 87 -2.0184099999999998 -3.1911800000000001 -1.27379\n"" 88 0.011766 -2.7572999999999999 -0.81328199999999995\n"" 89 -0.34977599999999998 -2.5832199999999998 -0.26063999999999998\n"" 90 0.0082679999999999993 -2.6970700000000001 -0.226572\n"" 91 -0.78081 -3.0613299999999999 0.47486400000000001\n"" 92 0.000852 -2.8652899999999999 0.942384\n"" 93 -0.68570399999999998 -2.7192400000000001 1.8263799999999999\n"" 94 -0.003552 -2.6613500000000001 1.71241\n"" 95 -0.33728999999999998 -3.98041 1.95644\n"" 96 -0.15748799999999999 -3.4080599999999999 1.63991\n"" 97 -0.295566 -3.1863800000000002 2.3391199999999999\n"" 98 -0.76257600000000003 -3.9803899999999999 2.8759000000000001\n"" 99 -0.350304 -3.98041 2.2373500000000002\n"" 100 -1.8237699999999999 0.32519399999999998 3.7555299999999998\n"" 101 -1.6115600000000001 1.16042 3.0165999999999999\n"" 102 -1.6629499999999999 0.75673800000000002 2.6597300000000001\n"" 103 -1.72563 -0.034332000000000001 3.1910599999999998\n"" 104 -1.3883799999999999 -0.72773399999999999 3.5243199999999999\n"" 105 -1.52085 -0.490782 4.53925\n"" 106 -1.1709799999999999 -0.82781400000000005 4.3680700000000003\n"" 107 -1.00604 -0.939438 3.6563300000000001\n"" 108 -0.875502 -1.01417 4.1856\n"" 109 -0.46665600000000002 -1.28548 3.7355200000000002\n"" 110 -0.46123799999999998 -1.28983 4.17781\n"" 111 -0.014045999999999999 -1.3988100000000001 3.7371500000000002\n"" 112 -0.016379999999999999 -1.2811600000000001 4.1475999999999997\n"" 113 -0.018815999999999999 -1.15577 4.57639\n"" 114 -0.336816 -1.20733 4.58284\n"" 115 -0.68753399999999998 -0.99715200000000004 4.6243400000000001\n"" 116 -0.93086999999999998 -0.77779200000000004 4.7504299999999997\n"" 117 -1.1016699999999999 -0.35222999999999999 5.0820699999999999\n"" 118 -0.99337200000000003 0.01188 5.0003200000000003\n"" 119 -1.3205 0.11948400000000001 4.6136100000000004\n"" 120 -1.5343800000000001 0.54183599999999998 4.0246899999999997\n"" 121 -1.53356 0.68299799999999999 3.9803299999999999\n"" 122 -1.3582799999999999 1.27593 3.7064400000000002\n"" 123 -0.020202000000000001 -1.17205 4.7980799999999997\n"" 124 -0.17845800000000001 -1.26305 4.9630799999999997\n"" 125 -0.022908000000000001 -1.1687000000000001 5.2418199999999997\n"" 126 -0.024695999999999999 -0.94744200000000001 5.5876099999999997\n"" 127 -0.18768000000000001 -1.1073299999999999 5.3368599999999997\n"" 128 -0.35931000000000002 -1.10669 5.0479799999999999\n"" 129 -0.811998 -0.98599199999999998 5.2691999999999997\n"" 130 -0.51344400000000001 -1.02569 5.55328\n"" 131 -0.98299800000000004 -0.56501999999999997 5.3826799999999997\n"" 132 -0.83066399999999996 -0.62549999999999994 5.6758499999999996\n"" 133 -0.50098200000000004 -0.50960399999999995 5.8776400000000004\n"" 134 -0.026598 -0.87985199999999997 5.9152300000000002\n"" 135 -0.90429000000000004 0.19589999999999999 5.3046699999999998\n"" 136 -0.81535199999999997 -0.21312 5.6727299999999996\n"" 137 -0.42367199999999999 0.22109400000000001 5.8544\n"" 138 -0.026748000000000001 -0.25515599999999999 6.0940200000000004\n"" 139 -0.025493999999999999 0.276252 6.0194400000000003\n"" 140 -0.521814 0.79934400000000005 5.6858000000000004\n"" 141 -0.023238000000000002 0.96962999999999999 5.8229899999999999\n"" 142 -0.75326400000000004 0.84007200000000004 5.5060700000000002\n"" 143 -0.75390599999999997 1.5014799999999999 5.1456099999999996\n"" 144 -0.018762000000000001 1.70442 5.2732200000000002\n"" 145 -0.955044 0.75435600000000003 5.3332699999999997\n"" 146 -1.10284 1.1818200000000001 5.0668800000000003\n"" 147 -0.95933999999999997 1.7504200000000001 4.3948799999999997\n"" 148 -1.1969700000000001 1.2433799999999999 4.6791799999999997\n"" 149 -1.23709 0.98764799999999997 4.1595399999999998\n"" 150 -1.1178900000000001 0.96413400000000005 4.9031599999999997\n"" 151 -1.15696 1.00024 4.6936299999999997\n"" 152 -1.05067 0.66004799999999997 5.1637300000000002\n"" 153 -0.96613199999999999 0.34451999999999999 5.1306700000000003\n"" 154 -1.0339100000000001 0.21693000000000001 4.8971299999999998\n"" 155 -1.14191 0.38449800000000001 4.5636299999999999\n"" 156 -1.1704300000000001 0.77507400000000004 4.3866199999999997\n"" 157 -1.2187600000000001 2.4617200000000001 4.0832199999999998\n"" 158 -1.30006 1.85564 3.8536299999999999\n"" 159 -1.44909 1.8689100000000001 3.5269900000000001\n"" 160 -0.013254 2.19998 4.49648\n"" 161 -0.52937999999999996 2.3775900000000001 4.0718100000000002\n"" 162 -1.02088 0.65710199999999996 5.0446999999999997\n"" 163 -0.96312600000000004 0.40659600000000001 4.9839000000000002\n"" 164 -1.08928 0.83882999999999996 4.8728800000000003\n"" 165 -1.08297 0.89140799999999998 4.6565200000000004\n"" 166 -1.0815300000000001 0.77475000000000005 4.4651500000000004\n"" 167 -1.1177900000000001 0.46984799999999999 4.6161099999999999\n"" 168 -1.00573 0.363234 4.8400499999999997\n"" 169 -1.1392599999999999 0.61656 4.8154899999999996\n"" 170 -0.65003999999999995 2.7326800000000002 3.9430399999999999\n"" 171 -1.4495100000000001 3.1655500000000001 4.0157800000000003\n"" 172 -1.59406 3.0802 3.8075600000000001\n"" 173 -1.21844 2.8713000000000002 3.48916\n"" 174 -1.60063 3.85398 3.6123699999999999\n"" 175 -1.3017700000000001 3.3890799999999999 3.2126100000000002\n"" 176 -1.21326 3.1529699999999998 2.8556599999999999\n"" 177 -1.16333 2.80755 3.12364\n"" 178 -1.5950200000000001 4.5435999999999996 3.0055999999999998\n"" 179 -1.44184 3.9206400000000001 2.77929\n"" 180 -1.8554299999999999 4.6612099999999996 1.82836\n"" 181 -1.62605 4.09856 2.2921100000000001\n"" 182 -1.8726700000000001 4.0265899999999997 1.7201200000000001\n"" 183 -1.6127499999999999 3.7460499999999999 2.2633899999999998\n"" 184 -1.81474 3.2039800000000001 2.1617299999999999\n"" 185 -1.5819399999999999 3.1758600000000001 2.4753799999999999\n"" 186 -1.69387 2.4910000000000001 2.6859999999999999\n"" 187 -1.4352100000000001 2.6525799999999999 2.9736199999999999\n"" 188 -1.32026 3.4141599999999999 2.6752600000000002\n"" 189 -0.0075779999999999997 2.3737900000000001 3.6121699999999999\n"" 190 -0.34406999999999999 2.6552099999999998 3.4333399999999998\n"" 191 -0.53356199999999998 3.0379999999999998 3.1746400000000001\n"" 192 -0.75442799999999999 3.2104599999999999 3.6774800000000001\n"" 193 -0.75750600000000001 3.4630200000000002 2.8989500000000001\n"" 194 -0.89756400000000003 3.6691199999999999 3.34639\n"" 195 -0.979128 3.96475 2.9464800000000002\n"" 196 -1.0348900000000001 3.9803199999999999 2.4925000000000002\n"" 197 -0.96278399999999997 3.5502600000000002 2.2239499999999999\n"" 198 -0.93867 3.2183799999999998 2.2698100000000001\n"" 199 -0.81897600000000004 2.66615 2.5513599999999999\n"" 200 -0.573384 2.24261 2.8419500000000002\n"" 201 -0.62487599999999999 1.89547 2.9886200000000001\n"" 202 -0.0029759999999999999 2.3051599999999999 2.8429000000000002\n"" 203 -0.001098 1.7866200000000001 2.4089200000000002\n"" 204 -0.77425200000000005 1.62087 2.60697\n"" 205 0.00059999999999999995 1.63778 2.09483\n"" 206 -0.67835999999999996 1.4218999999999999 2.31332\n"" 207 0.043560000000000001 0.097865999999999995 -5.3003799999999996\n"" 208 0.047190000000000003 0.73262400000000005 -5.7368199999999998\n"" 209 -0.197052 0.69169199999999997 -5.7195099999999996\n"" 210 -0.53469 0.65069399999999999 -5.7019000000000002\n"" 211 -0.28464 0.088373999999999994 -5.2965400000000002\n"" 212 -0.62674799999999997 0.078822000000000003 -5.2924199999999999\n"" 213 -0.51863400000000004 -3.5091999999999999 -3.6500599999999999\n"" 214 -0.69015599999999999 -3.9756300000000002 -2.62039\n"" 215 -0.43009799999999998 -3.9922300000000002 -3.6383100000000002\n"" 216 -1.5472999999999999 -3.9922900000000001 -3.9483100000000002\n"" 217 -1.6352500000000001 -3.9922900000000001 -3.5523799999999999\n"" 218 -2.2279300000000002 -3.9922900000000001 -2.1217199999999998\n"" 219 -2.2341700000000002 -3.9922900000000001 -1.3465199999999999\n"" 220 -2.0110000000000001 -3.9922800000000001 -0.47173799999999999\n"" 221 -1.35599 -3.9922499999999999 -0.23388600000000001\n"" 222 -0.64031400000000005 -3.9922399999999998 -1.1181099999999999\n"" 223 -0.49049399999999999 -3.9922300000000002 -1.75532\n"" 224 0.041658000000000001 -0.54903000000000002 -5.1501200000000003\n"" 225 0.036701999999999999 -1.68591 -4.6197999999999997\n"" 226 0.026970000000000001 -3.01416 -3.3587899999999999\n"" 227 -1.1918299999999999 -1.81281 -5.0749000000000004\n"" 228 -1.4243699999999999 -3.2552599999999998 -3.5231300000000001\n"" 229 -1.62001 -1.67693 -4.0191699999999999\n"" 230 -0.80728200000000006 -0.71911199999999997 -5.7540199999999997\n"" 231 -0.31252799999999997 -0.73477800000000004 -5.6672900000000004\n"" 232 -0.74677800000000005 -1.76105 -5.3974000000000002\n"" 233 -0.28569600000000001 -1.73786 -5.2757500000000004\n"" 234 -1.0115700000000001 -3.1747899999999998 -3.9295900000000001\n"" 235 -0.59875800000000001 -3.0943100000000001 -3.8752399999999998\n"" 236 -1.1170100000000001 -3.6316899999999999 -4.3481399999999999\n"" 237 -0.67781999999999998 -3.49858 -4.2448100000000002\n"" 238 -0.64891200000000004 -3.9922499999999999 -4.2024499999999998\n"" 239 -1.0981099999999999 -3.99227 -4.3057800000000004\n"" 240 -2.0971700000000002 -2.0067499999999998 -3.0719099999999999\n"" 241 -0.84709199999999996 -2.6262300000000001 -4.7891599999999999\n"" 242 -1.2760199999999999 -2.6923499999999998 -4.4246800000000004\n"" 243 -1.56667 -2.4896699999999998 -3.6830099999999999\n"" 244 -0.46418399999999999 -2.5888800000000001 -4.6686800000000002\n"" 245 0.031043999999999999 -2.55166 -3.9095499999999999\n"" 246 0.535416 -2.5903900000000002 -4.66256\n"" 247 1.6260399999999999 -2.4944899999999999 -3.6634600000000002\n"" 248 1.34389 -2.6962999999999999 -4.4086400000000001\n"" 249 0.91964999999999997 -2.6288999999999998 -4.7783499999999997\n"" 250 2.1504799999999999 -2.0131700000000001 -3.04589\n"" 251 1.1606000000000001 -3.9956800000000001 -4.2919499999999999\n"" 252 0.71017799999999998 -3.9943 -4.1941300000000004\n"" 253 0.74109000000000003 -3.5007199999999998 -4.2361199999999997\n"" 254 1.1811100000000001 -3.6351599999999999 -4.3340699999999996\n"" 255 0.65872799999999998 -3.0962100000000001 -3.86754\n"" 256 1.0719399999999999 -3.17794 -3.91682\n"" 257 0.36694199999999999 -1.7388399999999999 -5.2717599999999996\n"" 258 0.82940400000000003 -1.7634300000000001 -5.3877499999999996\n"" 259 0.40159800000000001 -0.73585800000000001 -5.6629199999999997\n"" 260 0.89742599999999995 -0.72168600000000005 -5.7435799999999997\n"" 261 1.6859299999999999 -1.6819299999999999 -3.99892\n"" 262 1.47949 -3.2596500000000002 -3.5053399999999999\n"" 263 1.2703199999999999 -1.8165199999999999 -5.0598200000000002\n"" 264 0.52179600000000004 -3.99376 -1.74912\n"" 265 0.66380399999999995 -3.9942099999999998 -1.1101300000000001\n"" 266 1.36859 -3.9963700000000002 -0.21720600000000001\n"" 267 2.0264600000000002 -3.99838 -0.44701800000000003\n"" 268 2.2603300000000002 -3.9990800000000002 -1.319\n"" 269 2.2635900000000002 -3.9990800000000002 -2.09422\n"" 270 1.6884699999999999 -3.9973000000000001 -3.5320200000000002\n"" 271 1.60538 -3.9970400000000001 -3.9289999999999998\n"" 272 0.48447000000000001 -3.9936099999999999 -3.6327099999999999\n"" 273 0.73209599999999997 -3.9777800000000001 -2.6116799999999998\n"" 274 0.57460199999999995 -3.51085 -3.64337\n"" 275 0.71366399999999997 0.076794000000000001 -5.2842099999999999\n"" 276 0.37166399999999999 0.087384000000000003 -5.2925199999999997\n"" 277 0.62834999999999996 0.64893599999999996 -5.6947799999999997\n"" 278 0.291078 0.69095399999999996 -5.71652\n"" 279 0.676176 1.4198599999999999 2.3216199999999998\n"" 280 0.76906200000000002 1.6185400000000001 2.6164299999999998\n"" 281 0.61585800000000002 1.8935999999999999 2.9962200000000001\n"" 282 0.56720999999999999 2.2408899999999998 2.8489399999999998\n"" 283 0.81762000000000001 2.6636799999999998 2.5613700000000001\n"" 284 0.94242599999999999 3.2155399999999998 2.2813300000000001\n"" 285 0.96809999999999996 3.5473400000000002 2.2357800000000001\n"" 286 1.0382100000000001 3.9771899999999998 2.5051899999999998\n"" 287 0.97684800000000005 3.9617900000000001 2.9584600000000001\n"" 288 0.88949999999999996 3.66642 3.3573300000000001\n"" 289 0.75431400000000004 3.4607399999999999 2.90821\n"" 290 0.74093399999999998 3.2081900000000001 3.6866400000000001\n"" 291 0.52572600000000003 3.0364 3.18113\n"" 292 0.331926 2.6541899999999998 3.4374899999999999\n"" 293 1.31962 3.4101699999999999 2.69143\n"" 294 1.42859 2.64825 2.9911699999999999\n"" 295 1.6902699999999999 2.4858899999999999 2.7067299999999999\n"" 296 1.583 3.1710799999999999 2.4947599999999999\n"" 297 1.8197000000000001 3.1984900000000001 2.1839900000000001\n"" 298 1.61812 3.7411699999999999 2.2831700000000001\n"" 299 1.8855299999999999 4.0209200000000003 1.7431399999999999\n"" 300 1.6321399999999999 4.0936399999999997 2.3120599999999998\n"" 301 1.8688800000000001 4.6555900000000001 1.8511599999999999\n"" 302 1.44143 3.91628 2.7969499999999998\n"" 303 1.59371 4.53878 3.0251199999999998\n"" 304 1.15537 2.8040500000000002 3.1378300000000001\n"" 305 1.20963 3.1493099999999998 2.8704999999999998\n"" 306 1.2944599999999999 3.3851599999999999 3.2284999999999999\n"" 307 1.5898099999999999 3.8491599999999999 3.6318999999999999\n"" 308 1.2061900000000001 2.8676400000000002 3.5040100000000001\n"" 309 1.5785199999999999 3.0754000000000001 3.8269899999999999\n"" 310 1.4316899999999999 3.1612 4.0334199999999996\n"" 311 0.63185400000000003 2.7307399999999999 3.9508899999999998\n"" 312 1.1039600000000001 0.61316999999999999 4.8292299999999999\n"" 313 0.96937799999999996 0.36025200000000002 4.85215\n"" 314 1.08449 0.46652399999999999 4.6295999999999999\n"" 315 1.05101 0.77152799999999999 4.4782099999999998\n"" 316 1.0504500000000001 0.88817999999999997 4.6695799999999998\n"" 317 1.0539499999999999 0.83559000000000005 4.8860000000000001\n"" 318 0.92514600000000002 0.40374599999999999 4.9954700000000001\n"" 319 0.982908 0.65407800000000005 5.0569800000000003\n"" 320 0.50856000000000001 2.37602 4.0781700000000001\n"" 321 1.43333 1.86456 3.5446499999999999\n"" 322 1.2802800000000001 1.85175 3.8694299999999999\n"" 323 1.198 2.4580700000000002 4.09802\n"" 324 1.14086 0.77158199999999999 4.4007800000000001\n"" 325 1.109 0.38109599999999999 4.5774100000000004\n"" 326 0.99641999999999997 0.213864 4.9095700000000004\n"" 327 0.92616600000000004 0.34165800000000002 5.1422499999999998\n"" 328 1.01125 0.65693400000000002 5.1763500000000002\n"" 329 1.12432 0.99678599999999995 4.7075899999999997\n"" 330 1.08257 0.96081000000000005 4.9166299999999996\n"" 331 1.2109399999999999 0.98394599999999999 4.1745400000000004\n"" 332 1.1652400000000001 1.2398100000000001 4.6936499999999999\n"" 333 0.93262800000000001 1.74756 4.4064699999999997\n"" 334 1.0661799999999999 1.1785399999999999 5.0801600000000002\n"" 335 0.91383000000000003 0.75153599999999998 5.3447199999999997\n"" 336 0.71727600000000002 1.49926 5.1546200000000004\n"" 337 0.71021400000000001 0.83785799999999999 5.5150399999999999\n"" 338 0.47645999999999999 0.79783800000000005 5.69191\n"" 339 0.37451400000000001 0.219888 5.85928\n"" 340 0.76708200000000004 -0.21551400000000001 5.6824199999999996\n"" 341 0.86174399999999995 0.19323599999999999 5.31548\n"" 342 0.44932800000000001 -0.51103799999999999 5.8834600000000004\n"" 343 0.78110400000000002 -0.62793600000000005 5.6857199999999999\n"" 344 0.93720599999999998 -0.56791800000000003 5.3944400000000003\n"" 345 0.464196 -1.0271600000000001 5.5592699999999997\n"" 346 0.76633200000000001 -0.98837399999999997 5.2788599999999999\n"" 347 0.31602000000000002 -1.10771 5.0521099999999999\n"" 348 0.14086199999999999 -1.1078300000000001 5.33887\n"" 349 0.13575599999999999 -1.26352 4.9649999999999999\n"" 350 1.33853 1.27186 3.72296\n"" 351 1.5086599999999999 0.67840199999999995 3.9989599999999998\n"" 352 1.50851 0.53724000000000005 4.0433199999999996\n"" 353 1.28616 0.115548 4.6295700000000002\n"" 354 0.95399400000000001 0.00894 5.0122400000000003\n"" 355 1.0601799999999999 -0.35549399999999998 5.0953099999999996\n"" 356 0.89217599999999997 -0.78054599999999996 4.76159\n"" 357 0.64973999999999998 -0.99916799999999995 4.63253\n"" 358 0.29892000000000002 -1.2082900000000001 4.5867199999999997\n"" 359 0.42804599999999998 -1.2911699999999999 4.1832500000000001\n"" 360 0.438888 -1.28685 3.7410600000000001\n"" 361 0.84301199999999998 -1.01677 4.1961199999999996\n"" 362 0.980244 -0.942438 3.6684999999999999\n"" 363 1.1368 -0.83130000000000004 4.3822000000000001\n"" 364 1.48556 -0.49532399999999999 4.5576600000000003\n"" 365 1.3648100000000001 -0.73189199999999999 3.5411800000000002\n"" 366 1.70821 -0.039516000000000003 3.2120799999999998\n"" 367 1.65445 0.751722 2.6800600000000001\n"" 368 1.5999000000000001 1.1555599999999999 3.03626\n"" 369 1.8005199999999999 0.31972200000000001 3.77772\n"" 370 0.3327 -3.9836100000000001 2.2503899999999999\n"" 371 0.737124 -3.9848300000000001 2.8939400000000002\n"" 372 0.27911999999999998 -3.1894300000000002 2.3515100000000002\n"" 373 0.14894399999999999 -3.4106999999999998 1.6506400000000001\n"" 374 0.32312999999999997 -3.98359 1.9693400000000001\n"" 375 0.67697399999999996 -2.7212900000000002 1.83473\n"" 376 0.78759000000000001 -3.0636999999999999 0.48447600000000002\n"" 377 0.36704399999999998 -2.5842999999999998 -0.25625999999999999\n"" 378 2.0461100000000001 -3.1973199999999999 -1.2488999999999999\n"" 379 2.08623 -3.7412000000000001 -0.48683399999999999\n"" 380 1.42824 -3.66439 -0.22822200000000001\n"" 381 1.27058 -3.0856400000000002 -0.79246799999999995\n"" 382 0.72363 -3.6013099999999998 -1.12114\n"" 383 0.58191000000000004 -3.5068600000000001 -1.76014\n"" 384 0.76572600000000002 -3.4916499999999999 -2.6230199999999999\n"" 385 0.99541199999999996 -2.8645499999999999 -1.7487200000000001\n"" 386 0.46632000000000001 -2.5078499999999999 -1.32311\n"" 387 1.9253499999999999 -3.0381800000000001 -1.9252400000000001\n"" 388 1.4892799999999999 -2.7940999999999998 -1.4390499999999999\n"" 389 0.712584 -2.30003 -1.1226799999999999\n"" 390 0.71289599999999997 -2.5806399999999998 -0.739842\n"" 391 0.56478600000000001 -2.5167799999999998 -0.26866200000000001\n"" 392 1.64716 -1.5702400000000001 0.03066\n"" 393 1.55905 -1.6997500000000001 -0.019109999999999999\n"" 394 1.33717 -2.0425900000000001 -0.22925999999999999\n"" 395 1.2266699999999999 -3.9862799999999998 3.08012\n"" 396 1.55572 -3.9872800000000002 2.82769\n"" 397 1.1124099999999999 -2.8561200000000002 2.5303100000000001\n"" 398 1.6749799999999999 -3.9876200000000002 2.5039699999999998\n"" 399 1.6629400000000001 -3.16873 2.4012500000000001\n"" 400 1.0984100000000001 -3.0588700000000002 1.97997\n"" 401 1.6955899999999999 -2.5752600000000001 0.35545199999999999\n"" 402 1.5288999999999999 -3.98725 1.7441199999999999\n"" 403 1.62862 -3.4062399999999999 1.5838000000000001\n"" 404 2.3193700000000002 -3.7513299999999998 -1.30122\n"" 405 2.3225199999999999 -3.7852999999999999 -2.0764399999999998\n"" 406 2.2801300000000002 -3.57613 -1.9120699999999999\n"" 407 1.7476100000000001 -3.7140399999999998 -3.51424\n"" 408 2.0356800000000002 -3.42719 -2.7716799999999999\n"" 409 2.4002699999999999 -2.9386700000000001 -2.5358399999999999\n"" 410 2.4409000000000001 -1.88609 -2.2273800000000001\n"" 411 1.8035300000000001 -1.69031 -1.02329\n"" 412 1.7452000000000001 -1.6638200000000001 -0.37142999999999998\n"" 413 1.1264099999999999 -1.4492700000000001 3.0566200000000001\n"" 414 1.12819 -1.7254100000000001 2.5453999999999999\n"" 415 1.3651199999999999 -2.2395700000000001 1.75861\n"" 416 1.5991599999999999 -1.6418999999999999 0.23758199999999999\n"" 417 1.7495499999999999 -1.7500599999999999 0.66831600000000002\n"" 418 1.7514799999999999 -0.73644600000000005 2.5360999999999998\n"" 419 1.7854399999999999 -0.93671400000000005 2.2402099999999998\n"" 420 1.7196199999999999 -1.39639 0.16297200000000001\n"" 421 2.18798 -1.2083900000000001 1.2411000000000001\n"" 422 2.1231300000000002 -0.79444800000000004 0.89536800000000005\n"" 423 1.6932499999999999 -0.11829000000000001 1.8897600000000001\n"" 424 1.98712 -0.59559600000000001 0.55620599999999998\n"" 425 2.25278 -0.55871999999999999 -0.038802000000000003\n"" 426 2.2555000000000001 -0.60741599999999996 -0.92929200000000001\n"" 427 2.7998099999999999 -0.566496 -1.8340099999999999\n"" 428 2.7348300000000001 -0.71928599999999998 -2.7637900000000002\n"" 429 1.66479 -3.6254499999999998 -3.9112300000000002\n"" 430 1.56613 -3.3070599999999999 -3.3279999999999998\n"" 431 0.56176199999999998 1.5509599999999999 -5.5235300000000001\n"" 432 0.68548799999999999 1.86365 -4.7884200000000003\n"" 433 0.86539200000000005 1.2685999999999999 -5.0100100000000003\n"" 434 0.71949600000000002 1.0616399999999999 -5.70695\n"" 435 1.1043700000000001 0.611124 -5.5093199999999998\n"" 436 0.55458600000000002 1.65913 -4.4293899999999997\n"" 437 0.80102399999999996 1.3104199999999999 -4.5516100000000002\n"" 438 1.1699200000000001 0.58592999999999995 -4.87486\n"" 439 1.1132500000000001 0.066030000000000005 -5.2752100000000004\n"" 440 1.3818900000000001 -0.76470000000000005 -5.3052099999999998\n"" 441 1.5628299999999999 1.53034 -3.74627\n"" 442 2.1093999999999999 -0.253164 -3.98386\n"" 443 1.5224500000000001 1.9411400000000001 -2.6023000000000001\n"" 444 2.4696699999999998 0.793794 -2.6295799999999998\n"" 445 1.6230800000000001 2.1391800000000001 -1.7399\n"" 446 2.53288 0.97691399999999995 -1.6387799999999999\n"" 447 0.988344 1.4249400000000001 1.2534700000000001\n"" 448 1.52284 0.55740000000000001 1.44384\n"" 449 1.2216499999999999 1.7075800000000001 0.57733800000000002\n"" 450 1.44604 2.0585599999999999 -1.0283800000000001\n"" 451 2.13646 0.89572799999999997 -0.86065800000000003\n"" 452 2.0259399999999999 0.79195199999999999 0.39824399999999999\n"" 453 -0.42761063083709772 1.6952470543869633 2.5510779406671853\n""# Generated by tetgen -YY bunny.smesh \n"); } -static const char* getElements() { return( -"1374 4 0\n"" 0 395 372 399 371\n"" 1 96 46 93 44\n"" 2 135 140 137 163\n"" 3 318 326 354 313\n"" 4 133 127 128 126\n"" 5 76 83 55 218\n"" 6 193 188 198 176\n"" 7 450 443 451 1\n"" 8 437 442 438 441\n"" 9 160 336 320 144\n"" 10 79 50 51 75\n"" 11 408 378 387 273\n"" 12 94 38 47 68\n"" 13 323 308 322 311\n"" 14 339 135 163 341\n"" 15 152 135 153 145\n"" 16 333 166 160 147\n"" 17 348 346 347 342\n"" 18 446 426 451 444\n"" 19 46 92 94 93\n"" 20 208 21 26 207\n"" 21 38 360 48 413\n"" 22 229 80 243 245\n"" 23 241 229 227 242\n"" 24 34 50 35 51\n"" 25 9 33 35 34\n"" 26 103 122 121 206\n"" 27 257 260 259 440\n"" 28 142 318 163 144\n"" 29 446 443 444 451\n"" 30 272 251 252 274\n"" 31 193 199 176 198\n"" 32 165 149 147 166\n"" 33 447 3 8 449\n"" 34 29 208 209 30\n"" 35 300 285 286 299\n"" 36 100 104 119 105\n"" 37 39 44 40 41\n"" 38 315 318 313 316\n"" 39 422 417 421 419\n"" 40 382 273 264 383\n"" 41 145 143 150 146\n"" 42 406 268 405 404\n"" 43 427 411 426 428\n"" 44 323 290 308 311\n"" 45 232 18 230 227\n"" 46 243 79 80 240\n"" 47 391 412 390 389\n"" 48 360 423 107 362\n"" 49 389 71 393 392\n"" 50 142 162 163 145\n"" 51 245 247 261 80\n"" 52 376 373 375 92\n"" 53 324 352 325 362\n"" 54 119 104 106 105\n"" 55 165 149 166 151\n"" 56 428 389 411 442\n"" 57 366 351 331 352\n"" 58 166 318 316 163\n"" 59 368 281 280 350\n"" 60 315 168 313 166\n"" 61 417 422 423 419\n"" 62 279 203 205 453\n"" 63 80 243 245 226\n"" 64 416 41 420 45\n"" 65 319 330 317 335\n"" 66 15 442 225 224\n"" 67 116 131 117 129\n"" 68 335 318 337 319\n"" 69 188 197 193 198\n"" 70 326 314 325 313\n"" 71 313 315 314 325\n"" 72 451 3 449 450\n"" 73 451 449 452 450\n"" 74 299 286 300 301\n"" 75 450 1 3 2\n"" 76 107 103 120 149\n"" 77 76 82 81 79\n"" 78 81 83 218 214\n"" 79 14 10 2 11\n"" 80 22 436 437 23\n"" 81 318 144 316 163\n"" 82 420 426 425 412\n"" 83 450 14 11 445\n"" 84 262 254 429 274\n"" 85 443 442 441 444\n"" 86 356 353 364 363\n"" 87 102 122 206 101\n"" 88 315 168 325 313\n"" 89 281 331 280 350\n"" 90 107 155 120 104\n"" 91 443 426 444 451\n"" 92 123 118 354 113\n"" 93 84 220 86 83\n"" 94 268 406 405 269\n"" 95 287 293 289 286\n"" 96 17 16 443 13\n"" 97 315 168 166 325\n"" 98 283 296 297 284\n"" 99 333 144 336 160\n"" 100 450 13 1 2\n"" 101 414 423 418 419\n"" 102 331 352 324 362\n"" 103 144 315 333 316\n"" 104 21 442 16 15\n"" 105 45 72 91 69\n"" 106 437 208 21 433\n"" 107 288 310 290 306\n"" 108 213 217 214 31\n"" 109 335 327 328 341\n"" 110 109 67 48 111\n"" 111 316 314 315 312\n"" 112 45 60 91 44\n"" 113 128 118 115 116\n"" 114 423 45 38 448\n"" 115 155 362 166 325\n"" 116 130 136 132 133\n"" 117 92 72 89 91\n"" 118 145 143 142 150\n"" 119 153 140 163 142\n"" 120 317 313 312 319\n"" 121 347 118 126 354\n"" 122 148 165 147 143\n"" 123 170 157 171 173\n"" 124 78 50 74 240\n"" 125 381 273 385 378\n"" 126 337 330 335 317\n"" 127 267 273 379 268\n"" 128 80 247 261 250\n"" 129 80 225 261 245\n"" 130 80 442 261 225\n"" 131 211 24 212 20\n"" 132 398 395 399 371\n"" 133 390 389 377 391\n"" 134 308 292 290 291\n"" 135 176 191 177 199\n"" 136 318 166 313 163\n"" 137 23 16 436 17\n"" 138 354 353 325 326\n"" 139 423 362 366 279\n"" 140 415 400 375 403\n"" 141 217 239 216 213\n"" 142 377 89 88 90\n"" 143 10 12 13 9\n"" 144 155 325 113 112\n"" 145 151 164 165 150\n"" 146 113 118 128 123\n"" 147 95 97 99 96\n"" 148 449 3 8 5\n"" 149 61 99 97 64\n"" 150 223 83 222 82\n"" 151 37 38 6 39\n"" 152 0 7 6 37\n"" 153 385 430 247 250\n"" 154 108 109 110 107\n"" 155 415 401 417 403\n"" 156 102 121 122 101\n"" 157 120 107 149 156\n"" 158 104 100 119 120\n"" 159 3 4 2 5\n"" 160 207 21 224 437\n"" 161 270 273 408 430\n"" 162 80 247 226 245\n"" 163 80 228 81 243\n"" 164 43 107 48 38\n"" 165 354 340 344 341\n"" 166 312 316 313 317\n"" 167 435 275 277 439\n"" 168 27 30 29 28\n"" 169 52 76 31 240\n"" 170 338 339 163 318\n"" 171 47 43 42 48\n"" 172 61 96 59 58\n"" 173 428 389 442 261\n"" 174 194 171 192 174\n"" 175 318 339 341 338\n"" 176 417 422 416 423\n"" 177 123 124 125 128\n"" 178 113 108 115 155\n"" 179 300 285 299 298\n"" 180 320 160 189 333\n"" 181 443 35 1 13\n"" 182 96 46 44 61\n"" 183 316 314 313 315\n"" 184 119 107 155 106\n"" 185 357 325 356 361\n"" 186 224 15 21 20\n"" 187 319 336 337 317\n"" 188 306 287 307 302\n"" 189 143 141 140 144\n"" 190 366 423 279 367\n"" 191 74 73 88 89\n"" 192 447 7 8 3\n"" 193 449 8 447 5\n"" 194 436 21 22 437\n"" 195 92 72 91 45\n"" 196 153 140 142 135\n"" 197 206 121 103 149\n"" 198 35 69 389 71\n"" 199 165 168 167 166\n"" 200 12 1 13 9\n"" 201 361 112 113 325\n"" 202 195 175 193 194\n"" 203 292 304 322 321\n"" 204 337 336 144 338\n"" 205 399 372 400 371\n"" 206 332 336 334 333\n"" 207 111 68 67 48\n"" 208 389 391 393 72\n"" 209 196 179 188 195\n"" 210 104 119 155 120\n"" 211 168 166 325 155\n"" 212 112 108 113 155\n"" 213 449 425 451 452\n"" 214 220 214 83 221\n"" 215 261 246 245 225\n"" 216 93 44 46 92\n"" 217 80 255 226 247\n"" 218 384 262 247 430\n"" 219 336 144 319 337\n"" 220 144 315 316 166\n"" 221 332 336 333 316\n"" 222 175 191 194 192\n"" 223 362 353 325 363\n"" 224 110 113 115 114\n"" 225 400 370 374 402\n"" 226 319 337 335 317\n"" 227 430 262 247 248\n"" 228 324 362 315 331\n"" 229 80 228 235 81\n"" 230 347 342 126 348\n"" 231 295 283 296 297\n"" 232 306 304 305 308\n"" 233 356 353 325 354\n"" 234 21 23 437 433\n"" 235 195 174 194 178\n"" 236 192 175 177 173\n"" 237 302 287 303 286\n"" 238 208 211 26 209\n"" 239 118 128 115 113\n"" 240 351 366 369 352\n"" 241 342 344 340 343\n"" 242 118 347 123 354\n"" 243 354 168 163 313\n"" 244 356 325 363 361\n"" 245 282 321 294 304\n"" 246 268 379 267 404\n"" 247 296 305 284 283\n"" 248 290 304 308 291\n"" 249 316 318 313 319\n"" 250 143 160 147 161\n"" 251 149 201 122 147\n"" 252 38 448 45 6\n"" 253 92 415 417 94\n"" 254 225 224 261 440\n"" 255 198 185 184 186\n"" 256 7 205 447 8\n"" 257 368 351 350 367\n"" 258 74 13 12 35\n"" 259 190 147 161 158\n"" 260 270 429 262 407\n"" 261 3 4 450 2\n"" 262 15 443 442 16\n"" 263 193 188 195 196\n"" 264 342 347 340 344\n"" 265 391 393 45 416\n"" 266 92 415 94 375\n"" 267 61 60 91 58\n"" 268 60 72 69 91\n"" 269 289 283 305 291\n"" 270 96 44 93 92\n"" 271 324 362 325 315\n"" 272 13 2 14 10\n"" 273 62 63 61 64\n"" 274 144 166 160 315\n"" 275 417 423 416 94\n"" 276 449 4 450 3\n"" 277 450 13 443 1\n"" 278 352 364 365 369\n"" 279 7 448 205 6\n"" 280 225 440 261 263\n"" 281 116 155 119 118\n"" 282 2 4 450 11\n"" 283 416 377 92 89\n"" 284 376 403 415 375\n"" 285 417 376 415 92\n"" 286 416 377 89 391\n"" 287 249 262 246 256\n"" 288 336 317 316 330\n"" 289 47 43 48 38\n"" 290 354 168 313 113\n"" 291 115 168 118 113\n"" 292 34 50 51 33\n"" 293 166 169 167 165\n"" 294 319 316 317 313\n"" 295 318 144 337 319\n"" 296 354 325 313 326\n"" 297 30 436 433 431\n"" 298 289 283 291 284\n"" 299 58 91 96 59\n"" 300 185 182 183 197\n"" 301 224 438 276 437\n"" 302 15 442 80 225\n"" 303 111 110 112 109\n"" 304 52 76 240 51\n"" 305 208 26 30 29\n"" 306 7 449 3 447\n"" 307 296 294 283 295\n"" 308 306 291 289 305\n"" 309 338 140 141 144\n"" 310 331 352 351 324\n"" 311 322 281 333 320\n"" 312 83 81 76 82\n"" 313 384 262 274 255\n"" 314 60 45 91 69\n"" 315 15 20 19 16\n"" 316 197 188 193 196\n"" 317 80 229 225 245\n"" 318 18 233 227 232\n"" 319 344 345 343 342\n"" 320 417 414 94 415\n"" 321 443 16 441 442\n"" 322 177 199 187 176\n"" 323 149 206 121 453\n"" 324 350 279 331 280\n"" 325 181 188 196 179\n"" 326 102 121 101 103\n"" 327 347 357 354 356\n"" 328 338 327 318 337\n"" 329 337 330 334 335\n"" 330 319 336 317 316\n"" 331 193 175 188 176\n"" 332 164 143 162 165\n"" 333 120 104 100 103\n"" 334 376 416 92 417\n"" 335 113 325 155 168\n"" 336 416 376 92 391\n"" 337 420 45 41 393\n"" 338 249 262 248 246\n"" 339 147 189 161 160\n"" 340 18 231 224 233\n"" 341 71 45 70 41\n"" 342 126 341 135 339\n"" 343 21 23 22 437\n"" 344 148 165 143 151\n"" 345 337 327 318 335\n"" 346 354 318 313 163\n"" 347 115 118 155 116\n"" 348 341 340 338 339\n"" 349 166 168 313 163\n"" 350 166 318 313 315\n"" 351 48 68 67 47\n"" 352 150 162 145 152\n"" 353 140 339 137 163\n"" 354 199 185 187 176\n"" 355 333 144 316 336\n"" 356 338 327 337 341\n"" 357 389 70 72 393\n"" 358 331 366 350 351\n"" 359 94 45 92 44\n"" 360 9 33 12 35\n"" 361 126 139 137 138\n"" 362 321 295 282 294\n"" 363 135 140 136 137\n"" 364 153 162 163 152\n"" 365 325 362 363 361\n"" 366 80 235 226 81\n"" 367 74 377 89 88\n"" 368 13 14 450 443\n"" 369 157 172 158 171\n"" 370 450 443 14 445\n"" 371 155 107 120 156\n"" 372 135 339 163 137\n"" 373 365 325 352 362\n"" 374 153 140 135 163\n"" 375 448 206 205 6\n"" 376 137 141 139 339\n"" 377 103 107 120 104\n"" 378 448 425 447 452\n"" 379 165 162 168 163\n"" 380 76 83 79 87\n"" 381 420 45 393 416\n"" 382 334 329 330 336\n"" 383 89 45 92 416\n"" 384 181 195 179 196\n"" 385 420 448 41 416\n"" 386 438 277 435 275\n"" 387 400 399 402 403\n"" 388 304 296 283 305\n"" 389 170 158 190 161\n"" 390 387 386 388 250\n"" 391 54 218 217 53\n"" 392 311 304 308 322\n"" 393 149 281 201 189\n"" 394 211 24 209 212\n"" 395 166 333 149 147\n"" 396 426 424 420 425\n"" 397 394 376 401 416\n"" 398 147 159 122 158\n"" 399 202 203 201 453\n"" 400 280 203 279 453\n"" 401 135 126 339 137\n"" 402 449 4 3 5\n"" 403 14 2 450 11\n"" 404 126 125 127 347\n"" 405 423 413 38 414\n"" 406 185 198 188 176\n"" 407 144 163 142 162\n"" 408 201 122 204 453\n"" 409 447 425 451 449\n"" 410 290 289 306 291\n"" 411 35 69 71 49\n"" 412 207 224 211 231\n"" 413 135 154 163 118\n"" 414 126 118 341 354\n"" 415 191 175 194 193\n"" 416 436 16 437 17\n"" 417 420 422 416 421\n"" 418 135 142 153 145\n"" 419 15 443 16 13\n"" 420 440 275 259 224\n"" 421 416 421 422 417\n"" 422 442 275 440 224\n"" 423 347 340 354 126\n"" 424 254 256 253 274\n"" 425 34 50 33 35\n"" 426 176 191 175 177\n"" 427 433 278 434 277\n"" 428 175 191 192 177\n"" 429 101 206 102 204\n"" 430 132 135 136 130\n"" 431 49 35 50 36\n"" 432 353 356 325 363\n"" 433 435 277 433 434\n"" 434 224 275 276 438\n"" 435 212 230 18 19\n"" 436 143 150 148 151\n"" 437 235 228 243 234\n"" 438 29 22 26 30\n"" 439 125 347 349 123\n"" 440 237 234 235 236\n"" 441 144 336 319 316\n"" 442 165 316 166 144\n"" 443 142 318 338 163\n"" 444 137 141 140 139\n"" 445 447 279 205 448\n"" 446 106 116 108 155\n"" 447 217 238 239 215\n"" 448 16 17 443 441\n"" 449 407 262 270 430\n"" 450 88 74 389 77\n"" 451 78 79 80 81\n"" 452 126 138 134 342\n"" 453 165 150 143 151\n"" 454 409 430 387 250\n"" 455 128 118 116 131\n"" 456 339 126 340 342\n"" 457 173 192 171 170\n"" 458 400 376 403 373\n"" 459 15 18 212 224\n"" 460 37 49 36 35\n"" 461 81 82 83 214\n"" 462 173 157 171 172\n"" 463 220 214 219 83\n"" 464 114 113 128 123\n"" 465 366 423 367 418\n"" 466 379 273 378 406\n"" 467 30 436 23 433\n"" 468 23 432 28 436\n"" 469 147 144 160 143\n"" 470 79 243 31 240\n"" 471 33 74 50 240\n"" 472 342 348 345 126\n"" 473 94 416 417 92\n"" 474 416 377 391 92\n"" 475 147 158 149 157\n"" 476 273 274 384 430\n"" 477 203 281 201 453\n"" 478 243 235 245 226\n"" 479 18 229 227 225\n"" 480 45 72 69 70\n"" 481 189 149 147 201\n"" 482 175 195 193 188\n"" 483 362 107 155 166\n"" 484 185 199 198 176\n"" 485 331 166 333 149\n"" 486 31 76 81 79\n"" 487 323 290 310 308\n"" 488 43 107 104 48\n"" 489 436 16 21 437\n"" 490 368 279 350 280\n"" 491 424 416 423 448\n"" 492 150 142 164 143\n"" 493 258 248 246 249\n"" 494 381 383 385 273\n"" 495 73 49 72 74\n"" 496 117 106 119 116\n"" 497 74 377 88 389\n"" 498 408 273 387 384\n"" 499 191 170 173 190\n"" 500 199 177 200 191\n"" 501 13 80 74 12\n"" 502 130 135 128 131\n"" 503 92 90 89 377\n"" 504 84 219 83 86\n"" 505 408 378 273 406\n"" 506 386 384 80 385\n"" 507 392 426 389 420\n"" 508 80 79 243 81\n"" 509 158 177 173 190\n"" 510 377 72 89 391\n"" 511 394 376 416 391\n"" 512 442 224 440 261\n"" 513 130 131 129 132\n"" 514 95 63 61 59\n"" 515 252 274 253 272\n"" 516 273 274 272 384\n"" 517 225 263 246 257\n"" 518 76 52 31 53\n"" 519 243 79 31 81\n"" 520 448 420 424 416\n"" 521 347 358 349 123\n"" 522 138 137 126 133\n"" 523 368 279 367 350\n"" 524 38 360 413 423\n"" 525 165 168 166 163\n"" 526 207 211 26 208\n"" 527 54 217 32 228\n"" 528 125 347 348 349\n"" 529 118 347 128 123\n"" 530 423 94 45 416\n"" 531 250 389 428 261\n"" 532 119 116 118 117\n"" 533 358 113 347 357\n"" 534 168 164 165 169\n"" 535 242 235 243 234\n"" 536 354 318 341 327\n"" 537 226 247 255 245\n"" 538 377 72 389 74\n"" 539 168 354 163 118\n"" 540 163 316 166 165\n"" 541 145 163 142 153\n"" 542 262 80 247 255\n"" 543 281 304 292 321\n"" 544 12 1 9 35\n"" 545 392 426 420 412\n"" 546 51 79 76 240\n"" 547 274 270 273 272\n"" 548 270 274 273 430\n"" 549 329 331 332 324\n"" 550 325 313 168 113\n"" 551 306 304 308 290\n"" 552 71 35 49 41\n"" 553 348 346 342 345\n"" 554 270 262 274 430\n"" 555 353 363 365 364\n"" 556 29 22 30 27\n"" 557 447 425 424 451\n"" 558 53 31 217 54\n"" 559 194 171 175 192\n"" 560 29 25 209 210\n"" 561 123 358 349 113\n"" 562 80 385 384 247\n"" 563 204 202 201 453\n"" 564 259 225 440 224\n"" 565 128 347 125 123\n"" 566 111 68 48 413\n"" 567 48 68 47 414\n"" 568 415 68 414 94\n"" 569 437 208 207 21\n"" 570 424 1 3 451\n"" 571 447 452 449 448\n"" 572 389 390 377 88\n"" 573 158 170 190 173\n"" 574 169 165 168 167\n"" 575 155 154 119 118\n"" 576 115 168 155 118\n"" 577 354 168 113 118\n"" 578 147 201 161 189\n"" 579 115 168 113 155\n"" 580 168 166 155 167\n"" 581 259 225 257 440\n"" 582 263 247 261 246\n"" 583 281 279 201 453\n"" 584 128 135 136 126\n"" 585 275 260 439 440\n"" 586 66 63 65 64\n"" 587 277 438 276 275\n"" 588 163 339 341 318\n"" 589 325 314 324 315\n"" 590 338 327 341 318\n"" 591 319 327 328 335\n"" 592 391 45 89 416\n"" 593 203 281 280 202\n"" 594 362 423 206 279\n"" 595 239 237 213 238\n"" 596 362 353 365 325\n"" 597 80 235 243 226\n"" 598 80 228 243 235\n"" 599 15 21 20 16\n"" 600 31 214 81 53\n"" 601 227 244 233 225\n"" 602 442 21 224 15\n"" 603 284 293 298 285\n"" 604 233 18 227 225\n"" 605 18 233 224 225\n"" 606 205 203 204 453\n"" 607 163 154 168 118\n"" 608 208 21 433 26\n"" 609 443 389 442 444\n"" 610 27 23 30 28\n"" 611 54 218 56 217\n"" 612 391 412 389 393\n"" 613 9 13 10 1\n"" 614 61 44 96 91\n"" 615 316 314 312 313\n"" 616 416 376 401 417\n"" 617 116 108 155 115\n"" 618 106 107 155 108\n"" 619 442 389 411 426\n"" 620 164 142 162 143\n"" 621 321 294 322 295\n"" 622 144 165 143 147\n"" 623 357 325 313 354\n"" 624 389 35 41 426\n"" 625 448 7 205 447\n"" 626 227 244 229 241\n"" 627 206 38 103 102\n"" 628 206 448 205 279\n"" 629 10 4 2 11\n"" 630 246 256 245 255\n"" 631 37 49 35 41\n"" 632 128 127 124 125\n"" 633 126 138 133 134\n"" 634 312 318 319 313\n"" 635 81 235 226 213\n"" 636 213 228 235 234\n"" 637 228 81 243 31\n"" 638 81 228 235 213\n"" 639 317 336 337 330\n"" 640 330 336 337 334\n"" 641 316 330 317 329\n"" 642 319 330 335 328\n"" 643 231 18 232 233\n"" 644 18 231 232 230\n"" 645 17 437 436 441\n"" 646 287 307 302 303\n"" 647 287 306 307 288\n"" 648 303 288 287 307\n"" 649 323 320 333 311\n"" 650 393 420 416 392\n"" 651 79 51 76 75\n"" 652 336 329 316 332\n"" 653 213 236 234 237\n"" 654 76 31 81 53\n"" 655 45 72 391 89\n"" 656 31 76 79 240\n"" 657 395 372 397 399\n"" 658 393 45 41 70\n"" 659 45 416 94 92\n"" 660 211 21 224 207\n"" 661 376 417 415 401\n"" 662 262 254 274 256\n"" 663 320 304 292 311\n"" 664 1 10 9 2\n"" 665 162 165 168 164\n"" 666 385 247 80 250\n"" 667 371 400 370 372\n"" 668 384 247 385 430\n"" 669 128 130 131 129\n"" 670 443 13 442 80\n"" 671 284 293 289 305\n"" 672 448 206 6 423\n"" 673 360 107 109 362\n"" 674 112 360 359 111\n"" 675 287 305 306 289\n"" 676 362 325 112 361\n"" 677 362 166 325 315\n"" 678 437 17 16 441\n"" 679 438 277 276 433\n"" 680 200 189 190 201\n"" 681 416 422 424 423\n"" 682 320 292 281 189\n"" 683 110 108 113 112\n"" 684 108 110 113 115\n"" 685 144 318 316 319\n"" 686 250 386 389 80\n"" 687 166 318 315 316\n"" 688 63 62 59 58\n"" 689 319 327 335 318\n"" 690 337 327 335 341\n"" 691 1 450 3 451\n"" 692 239 237 236 213\n"" 693 21 442 437 16\n"" 694 450 443 445 451\n"" 695 14 13 450 2\n"" 696 39 44 42 40\n"" 697 363 357 356 361\n"" 698 350 366 367 351\n"" 699 331 366 362 279\n"" 700 368 366 369 351\n"" 701 47 43 38 42\n"" 702 140 339 163 338\n"" 703 289 285 293 284\n"" 704 339 141 338 140\n"" 705 137 141 339 140\n"" 706 234 216 213 32\n"" 707 273 408 430 384\n"" 708 273 270 408 269\n"" 709 84 220 83 85\n"" 710 158 170 157 161\n"" 711 255 262 274 256\n"" 712 304 282 283 294\n"" 713 83 218 219 87\n"" 714 377 72 74 89\n"" 715 206 205 204 453\n"" 716 446 443 451 445\n"" 717 304 292 322 320\n"" 718 155 362 112 107\n"" 719 292 283 304 282\n"" 720 443 1 426 451\n"" 721 149 362 166 107\n"" 722 272 271 274 270\n"" 723 306 287 289 288\n"" 724 366 331 350 279\n"" 725 331 366 352 362\n"" 726 61 95 96 97\n"" 727 224 442 275 438\n"" 728 273 387 384 385\n"" 729 262 271 429 270\n"" 730 185 182 197 184\n"" 731 153 162 145 163\n"" 732 74 443 35 426\n"" 733 41 389 426 420\n"" 734 40 47 46 44\n"" 735 262 246 247 248\n"" 736 1 37 3 0\n"" 737 433 432 431 436\n"" 738 23 432 436 30\n"" 739 67 360 413 111\n"" 740 109 360 112 111\n"" 741 361 360 112 362\n"" 742 246 258 249 257\n"" 743 87 218 219 55\n"" 744 151 149 166 156\n"" 745 165 149 151 148\n"" 746 149 165 147 148\n"" 747 155 154 118 168\n"" 748 217 214 218 215\n"" 749 31 214 53 217\n"" 750 291 304 283 305\n"" 751 23 16 22 436\n"" 752 143 162 165 144\n"" 753 103 102 100 101\n"" 754 195 175 179 188\n"" 755 182 196 197 180\n"" 756 400 376 375 403\n"" 757 149 281 189 331\n"" 758 146 143 150 148\n"" 759 150 146 152 145\n"" 760 168 162 164 169\n"" 761 262 384 274 430\n"" 762 54 218 53 56\n"" 763 125 127 347 128\n"" 764 304 306 291 290\n"" 765 262 80 384 247\n"" 766 153 162 152 145\n"" 767 150 162 152 164\n"" 768 168 162 169 163\n"" 769 262 80 255 384\n"" 770 38 68 414 47\n"" 771 423 206 38 107\n"" 772 46 68 94 47\n"" 773 385 430 250 387\n"" 774 413 68 48 414\n"" 775 46 68 93 94\n"" 776 41 416 448 45\n"" 777 111 68 413 67\n"" 778 77 88 74 73\n"" 779 393 41 420 392\n"" 780 274 256 253 255\n"" 781 26 23 433 30\n"" 782 218 217 53 214\n"" 783 231 212 18 224\n"" 784 446 426 444 427\n"" 785 113 114 128 115\n"" 786 128 114 123 124\n"" 787 285 289 293 286\n"" 788 301 285 299 286\n"" 789 300 285 298 286\n"" 790 297 285 298 299\n"" 791 26 23 30 22\n"" 792 44 38 94 45\n"" 793 187 158 159 177\n"" 794 218 76 81 53\n"" 795 162 143 142 144\n"" 796 397 373 400 372\n"" 797 164 142 145 162\n"" 798 128 135 126 118\n"" 799 289 283 284 305\n"" 800 282 189 281 292\n"" 801 200 186 187 199\n"" 802 21 24 211 20\n"" 803 11 13 14 10\n"" 804 2 13 1 10\n"" 805 72 377 389 391\n"" 806 74 72 73 89\n"" 807 92 72 45 89\n"" 808 413 366 418 362\n"" 809 281 304 282 292\n"" 810 429 251 274 254\n"" 811 438 439 275 435\n"" 812 37 424 1 3\n"" 813 202 189 201 281\n"" 814 333 189 320 281\n"" 815 94 38 68 423\n"" 816 389 261 250 80\n"" 817 242 241 235 234\n"" 818 364 366 365 369\n"" 819 302 305 306 287\n"" 820 362 366 352 365\n"" 821 350 366 279 367\n"" 822 368 366 351 367\n"" 823 191 176 175 193\n"" 824 173 191 177 192\n"" 825 103 121 101 100\n"" 826 176 191 199 193\n"" 827 191 177 200 190\n"" 828 275 442 439 438\n"" 829 275 442 440 439\n"" 830 224 442 225 261\n"" 831 442 224 437 438\n"" 832 258 246 263 257\n"" 833 386 384 385 383\n"" 834 149 333 331 189\n"" 835 318 326 327 354\n"" 836 207 437 224 276\n"" 837 56 76 218 53\n"" 838 350 333 322 281\n"" 839 37 38 45 6\n"" 840 232 244 227 241\n"" 841 423 206 6 38\n"" 842 411 386 250 410\n"" 843 224 229 18 225\n"" 844 6 423 38 448\n"" 845 218 57 219 55\n"" 846 68 423 38 414\n"" 847 377 376 391 92\n"" 848 415 376 375 92\n"" 849 103 121 100 120\n"" 850 101 121 122 100\n"" 851 102 121 103 122\n"" 852 7 206 6 205\n"" 853 38 206 6 102\n"" 854 107 38 103 206\n"" 855 448 206 423 279\n"" 856 298 305 284 296\n"" 857 30 432 436 431\n"" 858 23 432 30 28\n"" 859 119 107 104 155\n"" 860 142 337 318 144\n"" 861 107 103 43 104\n"" 862 426 424 425 451\n"" 863 107 156 155 166\n"" 864 119 107 106 104\n"" 865 156 107 149 166\n"" 866 103 107 43 38\n"" 867 103 122 206 102\n"" 868 448 41 45 37\n"" 869 423 416 45 448\n"" 870 81 228 213 31\n"" 871 217 239 213 215\n"" 872 403 376 415 401\n"" 873 443 74 80 389\n"" 874 135 163 341 118\n"" 875 133 126 136 137\n"" 876 228 216 213 217\n"" 877 447 451 7 449\n"" 878 71 41 393 392\n"" 879 282 321 304 281\n"" 880 95 63 99 61\n"" 881 185 197 183 188\n"" 882 433 23 437 436\n"" 883 212 24 210 19\n"" 884 257 260 440 258\n"" 885 184 197 185 198\n"" 886 175 178 195 179\n"" 887 61 60 58 44\n"" 888 362 363 361 365\n"" 889 447 451 424 7\n"" 890 132 135 130 131\n"" 891 61 91 96 58\n"" 892 385 430 387 384\n"" 893 127 133 130 126\n"" 894 80 274 226 255\n"" 895 80 274 255 384\n"" 896 219 87 86 84\n"" 897 275 259 224 276\n"" 898 18 229 15 227\n"" 899 320 304 311 322\n"" 900 23 21 26 433\n"" 901 109 38 48 107\n"" 902 342 139 126 138\n"" 903 21 23 26 22\n"" 904 426 428 444 427\n"" 905 331 166 362 315\n"" 906 122 206 204 453\n"" 907 12 1 35 13\n"" 908 189 331 281 333\n"" 909 35 9 34 1\n"" 910 426 412 389 411\n"" 911 287 305 289 293\n"" 912 320 160 333 336\n"" 913 0 35 37 36\n"" 914 262 255 247 256\n"" 915 353 352 325 324\n"" 916 336 329 330 316\n"" 917 275 260 440 259\n"" 918 16 442 437 441\n"" 919 380 378 273 381\n"" 920 7 424 447 448\n"" 921 400 376 373 375\n"" 922 222 223 214 83\n"" 923 30 22 23 27\n"" 924 262 271 274 429\n"" 925 45 44 37 41\n"" 926 380 265 382 273\n"" 927 149 333 189 147\n"" 928 242 245 229 243\n"" 929 131 135 128 118\n"" 930 245 256 247 255\n"" 931 391 412 393 394\n"" 932 99 61 97 95\n"" 933 281 203 280 453\n"" 934 350 333 331 322\n"" 935 41 71 393 70\n"" 936 398 400 399 402\n"" 937 323 309 308 310\n"" 938 37 3 0 7\n"" 939 72 393 45 391\n"" 940 408 270 430 407\n"" 941 40 47 44 42\n"" 942 298 305 293 284\n"" 943 250 385 386 80\n"" 944 266 379 273 380\n"" 945 191 170 192 173\n"" 946 364 354 356 355\n"" 947 200 186 159 187\n"" 948 159 147 190 158\n"" 949 229 244 225 245\n"" 950 427 250 411 428\n"" 951 342 347 126 340\n"" 952 13 80 12 15\n"" 953 342 346 347 344\n"" 954 268 273 379 406\n"" 955 352 365 366 369\n"" 956 78 50 240 51\n"" 957 322 321 304 294\n"" 958 183 180 196 182\n"" 959 266 379 267 273\n"" 960 58 59 60 91\n"" 961 405 273 269 406\n"" 962 84 220 85 86\n"" 963 81 82 214 223\n"" 964 21 24 26 211\n"" 965 87 219 86 57\n"" 966 442 411 428 426\n"" 967 35 443 1 426\n"" 968 47 44 94 46\n"" 969 357 325 113 313\n"" 970 313 357 354 113\n"" 971 31 217 228 213\n"" 972 99 61 66 64\n"" 973 144 166 147 160\n"" 974 298 284 285 297\n"" 975 398 400 371 399\n"" 976 51 78 50 79\n"" 977 298 284 297 296\n"" 978 7 451 3 449\n"" 979 281 279 280 331\n"" 980 158 177 190 159\n"" 981 117 106 105 119\n"" 982 278 276 277 433\n"" 983 200 122 201 177\n"" 984 72 35 389 74\n"" 985 54 228 31 217\n"" 986 379 406 378 404\n"" 987 347 127 126 128\n"" 988 109 362 112 360\n"" 989 126 339 340 341\n"" 990 142 338 140 163\n"" 991 38 44 47 42\n"" 992 150 142 145 164\n"" 993 426 424 451 420\n"" 994 431 208 433 30\n"" 995 437 207 433 276\n"" 996 135 154 153 163\n"" 997 163 341 354 318\n"" 998 443 13 74 35\n"" 999 143 142 144 140\n"" 1000 320 322 323 333\n"" 1001 122 147 158 149\n"" 1002 112 359 361 113\n"" 1003 359 112 361 360\n"" 1004 149 121 201 453\n"" 1005 361 358 113 359\n"" 1006 361 113 357 325\n"" 1007 113 359 358 112\n"" 1008 409 388 410 250\n"" 1009 71 69 389 70\n"" 1010 430 409 387 408\n"" 1011 32 217 216 228\n"" 1012 400 374 372 373\n"" 1013 419 422 423 421\n"" 1014 51 78 79 240\n"" 1015 387 386 250 385\n"" 1016 48 360 109 111\n"" 1017 438 277 433 435\n"" 1018 316 331 329 315\n"" 1019 74 50 49 35\n"" 1020 302 305 287 293\n"" 1021 287 293 286 302\n"" 1022 258 440 257 263\n"" 1023 188 183 181 196\n"" 1024 1 426 41 35\n"" 1025 236 216 213 234\n"" 1026 292 283 291 304\n"" 1027 381 383 273 382\n"" 1028 50 15 33 35\n"" 1029 79 240 78 80\n"" 1030 177 122 201 190\n"" 1031 307 308 309 310\n"" 1032 229 240 33 243\n"" 1033 200 187 177 199\n"" 1034 31 214 213 81\n"" 1035 128 133 126 136\n"" 1036 37 424 448 41\n"" 1037 263 247 246 248\n"" 1038 444 389 442 426\n"" 1039 423 417 414 94\n"" 1040 177 190 191 173\n"" 1041 417 419 415 421\n"" 1042 300 293 302 286\n"" 1043 442 13 15 80\n"" 1044 121 103 149 120\n"" 1045 136 126 135 137\n"" 1046 201 122 121 149\n"" 1047 331 316 333 315\n"" 1048 18 19 15 212\n"" 1049 38 45 423 94\n"" 1050 113 347 354 123\n"" 1051 273 405 269 408\n"" 1052 26 208 30 433\n"" 1053 431 208 278 433\n"" 1054 429 251 271 274\n"" 1055 109 38 360 48\n"" 1056 400 398 371 370\n"" 1057 174 173 175 171\n"" 1058 149 362 107 206\n"" 1059 245 242 229 244\n"" 1060 417 423 414 419\n"" 1061 185 199 186 198\n"" 1062 158 170 173 157\n"" 1063 177 122 190 159\n"" 1064 308 292 311 290\n"" 1065 380 378 379 273\n"" 1066 218 81 214 53\n"" 1067 232 244 233 227\n"" 1068 72 49 35 74\n"" 1069 235 245 226 244\n"" 1070 234 243 242 228\n"" 1071 316 331 332 329\n"" 1072 451 41 424 1\n"" 1073 362 353 363 365\n"" 1074 224 20 21 211\n"" 1075 258 248 263 246\n"" 1076 393 389 392 412\n"" 1077 212 15 224 20\n"" 1078 342 346 344 345\n"" 1079 229 74 240 80\n"" 1080 302 301 300 286\n"" 1081 203 202 204 453\n"" 1082 216 234 236 32\n"" 1083 386 388 410 411\n"" 1084 144 163 165 316\n"" 1085 347 344 346 356\n"" 1086 21 442 224 437\n"" 1087 190 122 201 147\n"" 1088 6 424 7 448\n"" 1089 269 270 408 407\n"" 1090 126 125 347 348\n"" 1091 37 44 45 38\n"" 1092 393 72 45 70\n"" 1093 413 423 418 414\n"" 1094 31 32 54 53\n"" 1095 29 22 27 26\n"" 1096 403 376 401 402\n"" 1097 83 220 221 85\n"" 1098 433 207 278 276\n"" 1099 218 57 55 56\n"" 1100 155 116 119 106\n"" 1101 173 175 171 192\n"" 1102 244 225 245 233\n"" 1103 158 173 172 157\n"" 1104 281 203 201 202\n"" 1105 344 354 356 347\n"" 1106 315 144 333 160\n"" 1107 392 426 412 389\n"" 1108 87 83 79 84\n"" 1109 347 358 357 349\n"" 1110 342 139 339 126\n"" 1111 126 341 340 354\n"" 1112 37 424 3 7\n"" 1113 210 29 25 26\n"" 1114 261 389 442 80\n"" 1115 107 112 155 108\n"" 1116 389 250 428 411\n"" 1117 80 12 15 74\n"" 1118 380 265 273 266\n"" 1119 190 122 147 159\n"" 1120 142 338 144 140\n"" 1121 109 362 107 112\n"" 1122 362 423 366 418\n"" 1123 97 66 98 64\n"" 1124 300 293 286 298\n"" 1125 130 136 133 128\n"" 1126 389 77 80 386\n"" 1127 142 337 338 318\n"" 1128 56 76 55 218\n"" 1129 214 82 83 223\n"" 1130 246 261 263 225\n"" 1131 35 12 15 33\n"" 1132 420 1 451 426\n"" 1133 63 99 61 66\n"" 1134 96 44 92 91\n"" 1135 219 214 218 83\n"" 1136 323 308 309 322\n"" 1137 224 229 225 15\n"" 1138 38 413 48 414\n"" 1139 281 149 279 331\n"" 1140 183 188 197 196\n"" 1141 180 195 181 196\n"" 1142 50 15 35 74\n"" 1143 113 347 357 354\n"" 1144 331 166 315 333\n"" 1145 19 15 212 20\n"" 1146 69 389 70 72\n"" 1147 216 236 213 239\n"" 1148 6 424 448 37\n"" 1149 74 229 33 15\n"" 1150 185 199 187 186\n"" 1151 71 389 41 392\n"" 1152 195 174 175 194\n"" 1153 398 400 402 370\n"" 1154 282 283 294 295\n"" 1155 244 227 229 225\n"" 1156 308 310 306 290\n"" 1157 288 310 306 307\n"" 1158 307 308 310 306\n"" 1159 251 274 254 252\n"" 1160 55 219 87 57\n"" 1161 64 63 65 62\n"" 1162 15 13 16 12\n"" 1163 190 201 189 161\n"" 1164 316 331 333 332\n"" 1165 329 331 324 315\n"" 1166 364 354 353 356\n"" 1167 166 144 147 165\n"" 1168 334 329 336 332\n"" 1169 420 422 424 416\n"" 1170 350 333 281 331\n"" 1171 322 292 321 281\n"" 1172 209 24 210 212\n"" 1173 424 37 1 41\n"" 1174 269 407 408 405\n"" 1175 429 430 407 408\n"" 1176 15 443 13 442\n"" 1177 214 221 222 83\n"" 1178 13 17 16 14\n"" 1179 333 166 315 160\n"" 1180 224 20 211 212\n"" 1181 122 201 121 453\n"" 1182 246 247 245 256\n"" 1183 391 393 416 394\n"" 1184 37 44 38 39\n"" 1185 344 354 355 356\n"" 1186 189 147 333 160\n"" 1187 437 208 433 207\n"" 1188 181 195 178 179\n"" 1189 403 376 402 373\n"" 1190 183 180 181 196\n"" 1191 433 276 438 437\n"" 1192 380 273 382 381\n"" 1193 209 24 26 210\n"" 1194 379 406 404 268\n"" 1195 7 451 424 3\n"" 1196 400 402 373 403\n"" 1197 21 207 211 26\n"" 1198 451 41 1 420\n"" 1199 201 149 279 281\n"" 1200 347 344 354 340\n"" 1201 419 417 415 414\n"" 1202 344 345 346 343\n"" 1203 79 83 76 82\n"" 1204 128 133 130 127\n"" 1205 6 424 37 7\n"" 1206 190 147 201 161\n"" 1207 87 218 55 83\n"" 1208 39 44 41 37\n"" 1209 245 242 235 243\n"" 1210 389 41 392 420\n"" 1211 24 212 20 19\n"" 1212 451 41 420 424\n"" 1213 78 75 50 79\n"" 1214 440 257 263 225\n"" 1215 81 83 76 218\n"" 1216 385 378 387 381\n"" 1217 430 387 384 408\n"" 1218 329 315 324 316\n"" 1219 281 280 279 453\n"" 1220 279 205 206 453\n"" 1221 253 254 274 252\n"" 1222 325 357 356 354\n"" 1223 443 17 13 14\n"" 1224 322 292 281 320\n"" 1225 399 372 397 400\n"" 1226 56 76 53 55\n"" 1227 212 231 18 230\n"" 1228 24 26 211 209\n"" 1229 420 1 426 41\n"" 1230 182 196 183 197\n"" 1231 229 74 80 15\n"" 1232 118 347 126 128\n"" 1233 180 195 178 181\n"" 1234 361 358 357 113\n"" 1235 239 213 215 238\n"" 1236 224 229 15 18\n"" 1237 423 68 94 414\n"" 1238 6 45 37 448\n"" 1239 48 360 111 413\n"" 1240 302 301 286 303\n"" 1241 35 41 1 37\n"" 1242 431 278 434 433\n"" 1243 145 164 162 150\n"" 1244 174 173 171 172\n"" 1245 423 279 367 448\n"" 1246 362 423 107 206\n"" 1247 272 271 251 274\n"" 1248 273 385 378 387\n"" 1249 200 122 177 159\n"" 1250 452 425 447 449\n"" 1251 210 29 26 209\n"" 1252 130 135 136 128\n"" 1253 234 213 237 235\n"" 1254 216 54 217 32\n"" 1255 402 373 376 374\n"" 1256 164 143 165 150\n"" 1257 427 250 410 411\n"" 1258 386 388 250 410\n"" 1259 96 61 59 95\n"" 1260 159 200 187 177\n"" 1261 389 443 442 80\n"" 1262 398 395 396 399\n"" 1263 87 83 55 76\n"" 1264 389 77 74 80\n"" 1265 229 15 80 225\n"" 1266 207 433 278 208\n"" 1267 96 59 91 95\n"" 1268 341 126 135 118\n"" 1269 62 61 59 58\n"" 1270 206 149 279 453\n"" 1271 400 370 372 374\n"" 1272 389 35 426 74\n"" 1273 360 423 362 413\n"" 1274 54 228 32 31\n"" 1275 109 38 107 360\n"" 1276 87 83 84 219\n"" 1277 72 35 69 389\n"" 1278 246 262 247 256\n"" 1279 352 364 353 365\n"" 1280 268 273 406 269\n"" 1281 443 74 13 80\n"" 1282 242 244 241 229\n"" 1283 149 279 362 206\n"" 1284 99 64 66 97\n"" 1285 376 373 92 374\n"" 1286 26 29 25 27\n"" 1287 32 213 228 216\n"" 1288 118 163 341 354\n"" 1289 161 158 147 157\n"" 1290 61 60 44 91\n"" 1291 292 308 304 291\n"" 1292 163 144 165 162\n"" 1293 407 262 430 429\n"" 1294 63 62 61 59\n"" 1295 153 163 154 168\n"" 1296 350 281 322 321\n"" 1297 262 271 270 274\n"" 1298 442 426 428 444\n"" 1299 38 44 42 39\n"" 1300 80 240 229 243\n"" 1301 194 171 174 175\n"" 1302 155 362 325 112\n"" 1303 306 304 291 305\n"" 1304 77 78 74 80\n"" 1305 80 74 240 78\n"" 1306 38 44 94 47\n"" 1307 273 405 408 406\n"" 1308 293 298 285 286\n"" 1309 88 389 390 77\n"" 1310 311 304 292 308\n"" 1311 99 66 98 97\n"" 1312 26 210 24 25\n"" 1313 259 224 276 207\n"" 1314 61 62 64 58\n"" 1315 244 242 235 245\n"" 1316 244 241 235 242\n"" 1317 63 61 64 66\n"" 1318 149 201 279 453\n"" 1319 206 122 121 453\n"" 1320 413 366 362 365\n"" 1321 409 388 250 387\n"" 1322 423 362 413 418\n"" 1323 38 414 48 47\n"" 1324 38 360 423 107\n"" 1325 290 289 288 306\n"" 1326 333 322 323 331\n"" 1327 389 443 74 426\n"" 1328 35 71 389 41\n"" 1329 279 149 362 331\n"" 1330 74 12 15 35\n"" 1331 424 423 422 448\n"" 1332 190 201 177 200\n"" 1333 365 325 353 352\n"" 1334 385 383 384 273\n"" 1335 331 322 321 350\n"" 1336 71 70 389 393\n"" 1337 126 139 339 137\n"" 1338 44 45 92 91\n"" 1339 72 49 69 35\n"" 1340 175 178 174 195\n"" 1341 247 246 245 261\n"" 1342 41 424 448 420\n"" 1343 46 92 44 94\n"" 1344 402 400 373 374\n"" 1345 198 197 185 188\n"" 1346 304 296 294 283\n"" 1347 116 131 129 128\n"" 1348 50 15 74 33\n"" 1349 110 108 112 109\n"" 1350 448 425 424 447\n"" 1351 166 331 362 149\n"" 1352 206 149 103 107\n"" 1353 209 26 208 29\n"" 1354 211 231 224 212\n"" 1355 33 50 51 240\n"" 1356 32 213 234 228\n"" 1357 444 389 426 443\n"" 1358 107 112 108 109\n"" 1359 217 213 214 215\n"" 1360 16 22 436 21\n"" 1361 142 337 144 338\n"" 1362 323 311 322 320\n"" 1363 411 386 389 250\n"" 1364 265 273 264 382\n"" 1365 211 230 231 212\n"" 1366 295 296 294 297\n"" 1367 0 35 1 37\n"" 1368 229 74 33 240\n"" 1369 131 118 116 117\n"" 1370 122 204 101 201\n"" 1371 206 122 204 101\n"" 1372 83 220 86 219\n"" 1373 113 358 347 123\n""# Generated by tetgen -YY bunny.smesh \n"); } diff --git a/Demos3/GpuDemos/rigidbody/cube.inl b/Demos3/GpuDemos/rigidbody/cube.inl deleted file mode 100644 index 7015a23e6..000000000 --- a/Demos3/GpuDemos/rigidbody/cube.inl +++ /dev/null @@ -1,4 +0,0 @@ -static const char* getNodes() { return( -"400 3 0 0\n"" 0 1 1 -1\n"" 1 1 -1 -1\n"" 2 -1 -1 -1\n"" 3 1 1 1\n"" 4 -1 -1 1\n"" 5 -1 1 -1\n"" 6 1 -1 1\n"" 7 -1 1 1\n"" 8 -1 -1 -0.000116\n"" 9 0.00039500000000000006 -1 1\n"" 10 1 -1 -0.00065799999999999995\n"" 11 1 0.00061700000000000004 -1\n"" 12 0.00098999999999999999 1 -1\n"" 13 -1 1 0.00045400000000000008\n"" 14 0.00052800000000008396 1 1\n"" 15 1 1 -0.00038699999999991519\n"" 16 -1 -5.9999999999504894e-006 1\n"" 17 -1 0.00021000000000004349 -1\n"" 18 1 0.00067400000000006344 1\n"" 19 1.0863393114549872e-007 3.0682525964387253e-008 1\n"" 20 0.00097299999999989062 -1 -1\n"" 21 -1.4065544284846965e-008 1 5.0429866114086973e-008\n"" 22 1 -7.0792689266241382e-008 -4.4728299621228391e-008\n"" 23 8.4069120565846353e-008 3.8392827594879719e-007 -1\n"" 24 1 0.49980668112692161 -0.4996917965899465\n"" 25 1 0.50006700000000004 -1\n"" 26 1 1 -0.50034809999999996\n"" 27 1 1 0.50025040000000009\n"" 28 0.50020930000000008 1 1\n"" 29 -1 0.50010129999999997 1\n"" 30 -0.49958379999999991 1 1\n"" 31 -1 9.2038384777827427e-008 -1.100605984127867e-008\n"" 32 -0.5001201999999999 -1 1\n"" 33 1.0486788869007099e-007 -1 -3.3620911388254626e-008\n"" 34 -1 -1 0.50008699999999995\n"" 35 1 -0.50010220000000005 -1\n"" 36 1 -1 -0.49985400000000002\n"" 37 1 -0.4996526 1\n"" 38 1 -1 0.49990490000000004\n"" 39 -0.49930649999999999 1 -1\n"" 40 -1 1 -0.50002420000000003\n"" 41 1 -0.24974260000000004 -0.50015432157969908\n"" 42 0.50015422769290296 -0.24974260000000001 -1\n"" 43 0.50009680402228707 1 0.24993170000000009\n"" 44 1 0.50009675187018254 0.24993170000000009\n"" 45 0.24987467313200107 0.24987468273492527 -0.24987454967853764\n"" 46 0.50006970000000006 1 -1\n"" 47 -1 1 0.50062509999999982\n"" 48 -0.24952789999999991 1 0.50013191885453001\n"" 49 -0.24952789999999991 0.50013187836130635 1\n"" 50 -1 -0.50000239999999996 -1\n"" 51 -0.49917350000000005 -1 -1\n"" 52 -1 -0.37500110896930483 0.49999770999384097\n"" 53 -0.49999768418870116 -0.37500109958532857 1\n"" 54 0.50016842960649455 -0.24948929999999997 1\n"" 55 1 -0.24948929999999997 0.50016837821653382\n"" 56 -1 0.50011355427218929 -0.24978510000000004\n"" 57 -0.50011349993113807 1 -0.24978510000000009\n"" 58 0.49983560886453382 -1 -0.25025600000000003\n"" 59 1 -0.24959280000000006 -1\n"" 60 0.46861653427920624 0.31279234072878337 -1\n"" 61 0.46874721181012263 1 -0.31263609558485356\n"" 62 1 1 0.24986720000000007\n"" 63 1 0.50004500000000007 1\n"" 64 0.41666006216462159 0.41668749191836219 1\n"" 65 1 0.62492318088559184 0.62497446433589154\n"" 66 0.62493687874554793 1 0.62494713479954256\n"" 67 -0.32510780807963724 -0.32510780489834346 -0.32510793388507692\n"" 68 1 0.12495484505171366 -0.3748231366627352\n"" 69 -0.24915825000000003 0.50024732783000192 -1\n"" 70 1 0.74957571448653726 -0.74971600694021778\n"" 71 0.64874656072370729 1 -0.64882932411306993\n"" 72 0.6488668035834122 0.64886599996407779 -1\n"" 73 -1 0.41673079803079871 0.41664307505523179\n"" 74 -0.62468209179782908 1 0.62494186195929313\n"" 75 -0.62476903429567798 0.62489835940819183 1\n"" 76 -1 0.75020764999999989 1\n"" 77 0.12520010648567331 0.45856412436943739 0.37477910185628149\n"" 78 -0.24942439999999994 1 1\n"" 79 -0.37474797737976173 1 0.74996984889996166\n"" 80 -0.3748348177892612 0.74992638728967431 1\n"" 81 -1 -1 -0.49994339999999993\n"" 82 -0.50002894420427402 -1 0.24998549999999997\n"" 83 -1 -0.50045000000000006 1\n"" 84 -0.015617775048046156 -0.5000062299955631 1\n"" 85 -0.062520154989433377 -1 0.50002475010607028\n"" 86 0.50024029999999997 -1 1\n"" 87 1 -0.24929619999999997 1\n"" 88 0.37505270907528421 -0.3750526949043349 0.12522791934472338\n"" 89 -1 0.5001348000000001 -1\n"" 90 -1 1 -0.24999450000000001\n"" 91 1 -0.62477132796083668 -0.25025600000000003\n"" 92 0.50052129999999995 -1 -1\n"" 93 1 0.018238422269637886 -0.6785517711937521\n"" 94 0.750039598406532 -0.12448790000000004 -1\n"" 95 0.32367160517680327 0.022514689090561368 -0.65701963759824777\n"" 96 0.32369468988306127 0.65698780035674154 -0.022395524628340657\n"" 97 1 1 -0.25020424999999996\n"" 98 1 0.62501462613012171 -0.12492844204372336\n"" 99 0.16205966081319645 0.60689608104137205 -1\n"" 100 0.23307615322925276 1 -0.65509826790501591\n"" 101 0.6349049175761754 0.105723024682608 1\n"" 102 1 0.18290638148392097 0.59627500837254621\n"" 103 0.67708420758319754 0.67702605426027662 1\n"" 104 1 0.7498625000000001 1\n"" 105 0.75029925000000008 1 1\n"" 106 0.75006454389022692 1 0.37500606926950353\n"" 107 1 0.7500645207487896 0.37502882687227923\n"" 108 -0.39273716375981493 0.28664398202145958 -0.051638660454459806\n"" 109 -0.41671246738153483 -0.41657507574696978 -1\n"" 110 -0.24910025000000008 -1 -0.50024283860374685\n"" 111 -1 -0.50000177258228129 0.01562108247952367\n"" 112 -1 0.062713405747402015 -0.49998686350971472\n"" 113 -0.21672667787876426 1 -0.60296047487967241\n"" 114 1 0.7499052299192317 -0.37495181123207261\n"" 115 0.74540338978064358 1 -0.37527617499999999\n"" 116 0.52159008257288741 0.55923294709068649 -0.50062662770660094\n"" 117 0.75009235000000007 1 -1\n"" 118 -0.52928249862025711 0.10679011696853863 1\n"" 119 -1 0.034077217919757319 0.58381620432891879\n"" 120 -1 0.7383278941763165 0.25053954999999994\n"" 121 -0.70891631291249579 1 0.25053954999999989\n"" 122 -0.46050965421976553 0.49218708190674731 0.49218708126315491\n"" 123 -1 0.68039176952095026 0.65291562053589947\n"" 124 0.10567541850782136 0.6349221513724419 1\n"" 125 0.18288602711749127 1 0.59629803533945958\n"" 126 0.54298856425431818 0.54298737875163716 0.56762073808494473\n"" 127 -0.67702799351191578 -0.67732215502802495 -1\n"" 128 -0.74942264999999997 -1 -1\n"" 129 -1 -1 -0.74980449999999998\n"" 130 -1 -0.49218854513728494 -0.49218946358719012\n"" 131 -0.42414945787750447 -1 0.62500198796368489\n"" 132 -0.34611026252144428 -0.35284219355707647 0.34611025416343177\n"" 133 -1 -0.25018009999999996 1\n"" 134 1 -0.62478846817134759 0.62485153607962096\n"" 135 0.46873640237350567 -1 0.46875741869756882\n"" 136 0.62487945516234578 -0.62473271086601501 1\n"" 137 1 -1 0.75017445000000005\n"" 138 0.74996116568713633 -0.37481680473944939 1\n"" 139 1 -0.37487247538331225 0.74993327711783697\n"" 140 0.52037384429375466 0.13732055395658338 0.20134643019667742\n"" 141 0.15110486348630267 -0.58850137906978839 -0.32248691722782763\n"" 142 0.18460607304185575 -0.25601325165021294 0.59072519783751942\n"" 143 0.58280144730296801 -0.1236683742487249 -0.25429890766156527\n"" 144 -0.62459780071323356 0.62480472798869868 -1\n"" 145 -1 0.62491663124728913 -0.6248890159372763\n"" 146 -0.62484746422599169 1 -0.62502715932999464\n"" 147 -0.7093663193037405 1 -0.043380902757278066\n"" 148 -1 0.70881555044570888 -0.042280622034258974\n"" 149 1 -1 -0.25034290000000009\n"" 150 1 -0.40640338795560693 0.10958986646960317\n"" 151 0.62965348921187414 -1 0.11553823232370244\n"" 152 0.62491481284490769 -0.62481034920526324 -1\n"" 153 0.62518044398996542 -1 -0.62501367730297908\n"" 154 1 -0.63771354537448766 -0.63764519345816328\n"" 155 1 0.31875234539841601 -0.74994017167142224\n"" 156 1 0.25014510000000001 -1\n"" 157 0.74289722234692146 0.382058894292784 -1\n"" 158 0.32367160517680327 0.022514689090561313 -1\n"" 159 -0.16523027793533418 0.12134647368575949 -0.52708319267772263\n"" 160 0.66127538009577513 0.12758426427554953 -1\n"" 161 0.66190311587317174 -0.14472935797430672 -0.63288146125613987\n"" 162 0.32369468988306133 1 -0.022395524628340657\n"" 163 0.66678290425073372 1 -0.041514421404229618\n"" 164 0.25040265000000006 1 -1\n"" 165 0.0399620660587649 1 -0.35479393735090492\n"" 166 0.39507172571995386 0.7484116421252891 -1\n"" 167 1 -0.072369672334633761 0.72403943393322545\n"" 168 1 0.25022030000000006 1\n"" 169 -1 0.34715093732334323 0.069506853183406409\n"" 170 0.004224600474193374 -0.00030510666109673235 0.14430736392114327\n"" 171 -0.094962845556292308 0.5834952204256858 0.029410273259612763\n"" 172 -0.37516021595805987 -1 -0.12532788579913123\n"" 173 -0.24910025000000008 -0.73780528173239301 -1\n"" 174 -0.24899625000000003 -1 -1\n"" 175 -1 -0.68752594294730018 0.32233197415569781\n"" 176 -0.63898818329694262 -0.019780155017187176 -0.25640753531059018\n"" 177 -0.24918545000000003 1 -1\n"" 178 -0.090115044090208485 0.73312064098608642 -1\n"" 179 0.70087100707296945 0.7030864101348856 -0.70306291837965817\n"" 180 0.43929348327839085 1 -0.54468859277252801\n"" 181 0.24904127574612012 0.39074020564473289 -0.70186910867307939\n"" 182 1 0.37487410261969639 -0.24965440370335262\n"" 183 -1 0.25002235 1\n"" 184 -1 0.3834446703544917 0.71903607815447956\n"" 185 -0.1156880925075553 0.64434016438489528 0.64434017606689242\n"" 186 -0.49172745225271947 1 0.39835250767529351\n"" 187 -0.49767862299671706 0.38046779215689319 1\n"" 188 -0.71839703681869116 0.71780974657570373 0.44934935063382636\n"" 189 -0.51344827724776054 0.71469177745101886 0.71472798522876002\n"" 190 -0.23617534848477656 0.19448005635194549 1\n"" 191 0.10846459384596518 0.30820266021358389 1\n"" 192 0.25057285000000007 1 1\n"" 193 0.017230183845622971 1 0.32091029596366771\n"" 194 0.73101248242769623 0.7310147155780512 0.70877874225568527\n"" 195 0.31697048198150773 0.74665075980915008 0.4006579958540028\n"" 196 0.22826577744747956 0.47891948624469016 0.71004422740180217\n"" 197 1 0.41190390341165745 0.48757967789479273\n"" 198 0.39445308838583859 1 0.75656358081536812\n"" 199 0.37539107500000007 0.73916688955610543 1\n"" 200 1 0.37513265000000007 0.77169890914285255\n"" 201 0.73942011355234571 0.37513265000000007 1\n"" 202 0.63994038137069154 0.63994036678159205 0.2035446667438317\n"" 203 -0.46370016318896046 -0.62998103084618617 -0.61483850042635191\n"" 204 -1 -0.21786745446900305 -0.71882640763337879\n"" 205 -0.7381625142245487 -0.24989619999999996 -1\n"" 206 -1 -0.68409919087038817 -0.74320185410965045\n"" 207 -0.32233403971208485 -0.68753538843092254 1\n"" 208 -0.24999429999999997 -1 1\n"" 209 -1 -0.68747379665002328 0.68733786195201785\n"" 210 -1 -1 0.74993719999999997\n"" 211 -0.68734034505209507 -0.68746383783523624 1\n"" 212 0.012621642749083783 -0.62121055252239044 0.25549907282899653\n"" 213 -0.6302385799280833 -0.18856073836207951 0.63023858315073289\n"" 214 -1 -0.24375245663389172 0.20780956095073669\n"" 215 0.27457426263537876 -0.71671644193112283 1\n"" 216 0.25031765 -1 0.74826556642116959\n"" 217 0.67415846717387884 -1 0.72313083855082583\n"" 218 0.62503542334105555 -0.31221159888129457 0.62503541050290967\n"" 219 0.5971993096065894 0.14306806366195202 0.59872066564664705\n"" 220 1 0.017233350071975677 0.32090429254255515\n"" 221 0.26312362546126472 0.33468192363906535 0.084065768486193945\n"" 222 0.32197792152690552 -1 0.018797337932729474\n"" 223 0.18800195544968995 -1 -0.56289551925444881\n"" 224 0.57038729142869704 -0.57307887210152808 -0.20881754066389768\n"" 225 -0.0086896099297664228 -0.40801963637004723 -1\n"" 226 0.18460607304185569 -0.25601325165021294 1\n"" 227 -0.20780680948491165 -0.24375608761730455 1\n"" 228 0.16210795897650465 -0.16280891134401318 -0.30907215240469521\n"" 229 1 -0.26636148213032163 -0.17942676839456378\n"" 230 0.56446572384612781 0.1973176117738667 -0.43724659666019622\n"" 231 0.68853374013319157 -0.17744483013216472 0.09783510961497599\n"" 232 -1 0.25009230000000005 -1\n"" 233 -0.44245798368554617 0.091797696559903857 -1\n"" 234 -0.37472098690918887 0.74987909210814685 -1\n"" 235 -1 0.75000438735900432 -0.37495636858710685\n"" 236 -0.74996704638216471 1 -0.37508384505925174\n"" 237 -1 0.74990679999999998 -1\n"" 238 -0.54712707263607874 0.54712707774677038 -0.44245689687343565\n"" 239 -0.74990204999999999 1 -1\n"" 240 -0.72822316548562926 0.72874031845750664 0.1036085388532241\n"" 241 1 -0.71873547817891748 0.28112338497214717\n"" 242 1 -1 0.24972335000000001\n"" 243 0.75048264999999992 -1 -1\n"" 244 0.74989614566839657 -1 -0.37495931701899499\n"" 245 0.32778297288621805 -0.39528027615360428 -0.64821309452322518\n"" 246 1 -0.38051416654716286 -0.74727639147947866\n"" 247 0.75568696149005932 -0.39170758577960507 -1\n"" 248 0.67082477453227773 0.69774082076774491 -0.21670307025395311\n"" 249 0.25644629494787752 0.72897062001391455 -0.35498913750943906\n"" 250 -0.66044139980269567 0.12332997433814857 0.28570391360731856\n"" 251 -0.20800059812674501 0.28777064045558248 0.28593682199556314\n"" 252 0.29133599196527848 -0.095788071590640317 0.30648986161740821\n"" 253 -0.19340828105680374 -0.0068671095901119807 -0.17510149752792639\n"" 254 -0.21084753812463372 1 -0.20339622724796672\n"" 255 -0.098922382084248209 0.356624117376247 -0.256263439404529\n"" 256 -1 -0.74213790787259271 -0.24206983063972595\n"" 257 -0.72511478181115718 -1 -0.25002969999999997\n"" 258 -0.1250383368944159 -1 -0.24987830054645518\n"" 259 -0.5432409326212666 -0.58336779772250913 -0.0060938376146522089\n"" 260 -1 -1 0.25020549999999997\n"" 261 -0.69517902037783963 -1 0.48465629903462193\n"" 262 -1 0.19801494027267907 -0.22908951271298833\n"" 263 -1 -0.21170789004360985 -0.2804810168349573\n"" 264 0.12431896494966958 0.19380761445281547 -0.51506516411314296\n"" 265 0.016877018602808991 0.32057899216794972 -1\n"" 266 0.31815206866103007 0.69886802178230512 -0.69773364246572678\n"" 267 1 0.29452437620263039 0.03597223402760958\n"" 268 -0.23854616157962166 0.70039865549364788 0.32382827237146705\n"" 269 -0.072417036863037423 1 0.7240118059209224\n"" 270 -0.65715846697692126 0.26022065746019457 0.6943166148678479\n"" 271 0.032006652383344852 0.12877070459954792 0.60754383991332461\n"" 272 0.70679839053632465 0.35784100137989416 0.35408213575434944\n"" 273 1 0.75583880296190964 0.10796710954834202\n"" 274 -0.066417091587110066 -0.67493516441615642 -0.64835749920354258\n"" 275 -0.66000110931003353 -0.29732769674682547 -0.5356675566159671\n"" 276 -1 -0.7460956789293286 -0.49597432811515113\n"" 277 -0.63537062135554268 -1 -0.62487395000000001\n"" 278 -0.072189529852730625 -0.75207129129950046 1\n"" 279 -0.12479964999999998 -1 0.76180792382505302\n"" 280 -0.64633703603487636 -0.58450521092750218 0.50482020379778969\n"" 281 -0.19793040641595078 -1 0.22917284009874619\n"" 282 0.36430902573049584 -0.60319992435881997 0.46610302519244695\n"" 283 -0.014560432971481855 -0.28974170434477692 0.31899501601243035\n"" 284 -0.16677858939457951 -0.59736466720530357 0.62746423626615599\n"" 285 -0.70838149553417962 -0.14588171485233958 1\n"" 286 -1 -0.20773576611374234 0.72382280144202749\n"" 287 0.65401865792186442 -0.65865126715652123 0.6540215253821221\n"" 288 0.76868552550191671 -0.1162896631221611 1\n"" 289 0.39236022879703553 0.3070079448900544 0.42979647060190596\n"" 290 0.3368388593683827 0.015623435483033674 1\n"" 291 0.19283437348027005 -1 0.30983198636425424\n"" 292 0.23987671409711908 -0.66618838122351409 0.0008945936534150746\n"" 293 0.42213117252176491 -0.74712687995942406 -0.48458654817973601\n"" 294 1 -0.66026812967233972 0.017464640590841476\n"" 295 0.76163529643898698 -1 -0.11209435873849422\n"" 296 0.71607191560259942 -0.37037315933178871 -0.41086960011962592\n"" 297 -0.21716346053460103 -0.19947717862659675 -1\n"" 298 -0.066700914192858729 -0.25756978212559839 -0.62896708724727191\n"" 299 0.32965714090299714 -0.016623876027232615 -0.04345086208713933\n"" 300 0.3771146741942551 -0.33750921003054202 -0.17865283786030017\n"" 301 0.68867680851486557 0.35765454098697025 -0.68521532739244984\n"" 302 0.68683764447685003 -0.49596319168560488 0.30085803648362652\n"" 303 0.7090270874729655 -0.090415723473831255 0.40719961870896915\n"" 304 -0.71897798523587353 0.032300798531047246 -1\n"" 305 -0.78106895850102998 0.78106955040650416 -1\n"" 306 -1 1 -0.75022459999999991\n"" 307 -0.6917164744917017 0.69170418541265011 -0.69178840942223951\n"" 308 -0.44874465612278081 0.23033846865992608 -0.37975265656437374\n"" 309 -0.42791646676676653 1 -0.48213646482850109\n"" 310 -0.50093773209802361 0.36943796178744326 -1\n"" 311 -0.27376979380830829 0.64426231976101334 -0.66489790575084351\n"" 312 -1 0.35637030336560244 -0.50592472907968644\n"" 313 -0.67546025565396317 0.47435524682845248 -0.12755140965778172\n"" 314 1 -1 -0.74991180000000002\n"" 315 1 -0.75028080000000008 -1\n"" 316 0.75389683099717963 -0.68868788457723729 -0.44203141186583489\n"" 317 0.30599251534318156 -0.52261127269823027 -1\n"" 318 0.40047237565428867 -0.18178393484624253 -0.46933497457143036\n"" 319 0.59482353914036401 0.38624515090984007 -0.049897636224658731\n"" 320 -1 0.12332997433814856 0.2857039136073185\n"" 321 -1 -0.14689524813441618 0.42688908174824769\n"" 322 -0.66262979736993932 -0.22367581355790006 0.28652907305244368\n"" 323 -0.73506511384989526 0.43296210769478211 0.23284828493726362\n"" 324 -0.35917397776062404 -0.0011820981956873755 0.46134022362807492\n"" 325 -0.46329592253134338 -0.04321417701540118 0.047101266600350966\n"" 326 -0.27019578023748486 0.66094639539627242 -0.2626201492532621\n"" 327 -0.034393111593928383 0.28261880242562187 0.033764464745287937\n"" 328 0.18250360638285329 -1 -0.25535398043003921\n"" 329 -0.3030416241215706 -0.68638401151842854 -0.29392180366815041\n"" 330 -0.20024923856661142 -0.43390131265744347 0.010814269493628442\n"" 331 -0.70928533124789683 -1 0.043514240508664342\n"" 332 -0.66723744746271052 -0.6603325322519602 -0.32775579384930814\n"" 333 -0.75004930000000003 -1 1\n"" 334 -0.19527119007052851 0.17101403421852743 -1\n"" 335 0.035377884590221398 0.72616811699961958 0.38837547693302749\n"" 336 -0.3958963327893722 1 0.076655950240576198\n"" 337 -1 0.21457329427678187 0.47543850615348943\n"" 338 -0.7309823244201562 0.04824246580043276 0.53867561355267524\n"" 339 0.31731660817460328 0.019726050398274825 0.58867762989660533\n"" 340 -0.23374781763549932 0.32728908975345111 0.68606341552187544\n"" 341 -0.05707064185106852 -1 -0.71659883209883557\n"" 342 0.025895325626349025 -1 -0.41197380535174077\n"" 343 -0.63238580600180661 -0.3446250983839011 -0.21239475499198135\n"" 344 -1 -0.44899498782248648 -0.76904522126668295\n"" 345 -0.47299161220497166 -0.16458691872110107 -1\n"" 346 -0.71473237282422963 -0.73570249654826969 -0.71737349776128545\n"" 347 -0.74042724546706096 -1 0.74043153378626769\n"" 348 -0.75006482996996637 -0.43746254158362985 1\n"" 349 -1 -0.45163184813329721 0.75853196322407168\n"" 350 -0.50484417551448635 -0.72312317896459377 0.74770602252103513\n"" 351 -0.40758966352762416 -0.67845102844514626 0.2869272680702189\n"" 352 0.34674400209661604 -0.46348651949776365 1\n"" 353 -0.064367666161959269 -0.33637242545568102 0.74735946563471645\n"" 354 0.092602515587840606 -0.73476755239921543 0.53136369836931496\n"" 355 0.7405253302829875 -1 0.37931276242110001\n"" 356 0.72074474478028516 -0.071123657589263783 0.72858260191381197\n"" 357 -0.37493998320650845 -0.13123609584112483 -0.59370675998889832\n"" 358 -0.038352185780633007 -0.36921106178200458 -0.36036098843849301\n"" 359 -0.21058188105209746 -0.51336343843000509 -1\n"" 360 0.48755585676167218 -0.72413212665883209 0.19600157800093837\n"" 361 0.72678157399644117 -0.45646629587434373 0.011780680786240783\n"" 362 1 -0.2170765504241112 0.26033741814256661\n"" 363 -0.74541512030390267 -0.021189991595686748 -0.68170217165320612\n"" 364 -0.37387254482300358 0.32527982613660117 -0.69267828171913437\n"" 365 0.014913421017989981 0.548850834537849 -0.51262186425268497\n"" 366 -0.74537069514237131 0.2884463439624349 -1\n"" 367 -1 0.37511355000000007 -0.76842458715696027\n"" 368 -0.68532657097754035 0.18056419100293586 -0.02075972921423834\n"" 369 0.78133395148913365 -1 -0.78126287896225588\n"" 370 0.78115294817471781 -0.78112807555219699 -1\n"" 371 0.59082087507768066 -0.57000731366339108 -0.68829605397498683\n"" 372 0.062122976656860403 -0.70293283755163305 -1\n"" 373 0.71559274300689513 0.42281759201802555 -0.31813908171117911\n"" 374 0.7564597747876356 0.13217713297538497 -0.16417576007580004\n"" 375 0.40814884545639363 0.4915141193769953 -0.2436752542444009\n"" 376 -0.75696767061236314 -0.5164837362163468 0.21622587965261447\n"" 377 -0.452391830423859 0.55519361636450704 0.12429201972918034\n"" 378 -0.43481019055019038 -0.12925317405502307 1\n"" 379 -0.24742795067222612 -0.11366422696012682 0.2223275751188645\n"" 380 -0.006677616808027087 -0.21615237698969206 -0.065426614396930594\n"" 381 -0.062406752747729527 -0.70182414510247981 -0.087999792237402064\n"" 382 0.10306104864954116 0.76464771966531997 0.11700653142882178\n"" 383 0.27486783995540093 -0.12812237061584772 0.79536259891875982\n"" 384 -0.74059417471417499 -0.15757730258109431 0.00074049988054281091\n"" 385 -0.64002796579304344 -0.45394506207193958 -1\n"" 386 -0.42239397063762912 -0.42048979870740139 0.69490811148992537\n"" 387 -0.17195299402586212 -0.76346805360446235 0.40560748360163079\n"" 388 0.37676760090127209 -0.4417530820461561 0.70978247252690463\n"" 389 -0.20593363392839478 -0.044483242006169432 0.7439953909431003\n"" 390 -0.31521564832256066 -0.39420460209868968 -0.72065547292536469\n"" 391 -0.07315504595340451 0.34077703680706245 -0.71267230392230696\n"" 392 -0.0052948425242513517 1 -0.74523404665783877\n"" 393 -0.70127839101164502 0.30537699044254324 -0.64148488859352526\n"" 394 0.25061214999999992 -1 -1\n"" 395 0.40565131063307963 -0.76032995286218041 -1\n"" 396 0.38398614307047785 -1 -0.75304567260853106\n"" 397 0.23839244367761547 -0.68688896416028877 -0.73641430830181331\n"" 398 0.76674691103343318 0.57740125411814403 -0.50231823898754502\n"" 399 0.14110565781161721 -0.59279131304323562 0.77705687354697894\n""# Generated by tetgen -a0.01 cube.smesh \n"); } -static const char* getElements() { return( -"1580 4 0\n"" 0 120 148 13 240\n"" 1 77 251 185 268\n"" 2 126 194 66 198\n"" 3 297 298 159 357\n"" 4 13 148 147 240\n"" 5 219 272 102 303\n"" 6 134 137 37 136\n"" 7 302 360 88 361\n"" 8 23 264 95 391\n"" 9 307 311 238 364\n"" 10 57 309 254 326\n"" 11 345 357 233 363\n"" 12 176 343 325 384\n"" 13 275 332 67 343\n"" 14 141 245 228 318\n"" 15 108 368 323 377\n"" 16 7 47 74 123\n"" 17 73 188 184 270\n"" 18 56 235 148 313\n"" 19 46 72 117 179\n"" 20 66 105 28 194\n"" 21 205 275 204 344\n"" 22 66 194 28 198\n"" 23 96 221 45 375\n"" 24 93 160 94 161\n"" 25 225 317 245 397\n"" 26 121 186 74 188\n"" 27 213 280 52 322\n"" 28 52 322 280 376\n"" 29 96 195 77 221\n"" 30 8 257 256 331\n"" 31 358 380 330 381\n"" 32 99 181 166 266\n"" 33 120 123 73 188\n"" 34 122 189 187 340\n"" 35 141 292 224 300\n"" 36 313 326 240 377\n"" 37 203 274 173 390\n"" 38 140 299 221 319\n"" 39 44 197 107 272\n"" 40 171 326 108 377\n"" 41 71 166 46 179\n"" 42 69 364 334 391\n"" 43 26 114 97 115\n"" 44 228 253 159 358\n"" 45 221 272 202 289\n"" 46 123 184 73 188\n"" 47 22 220 140 231\n"" 48 250 324 322 325\n"" 49 270 324 213 338\n"" 50 147 240 57 336\n"" 51 69 265 178 391\n"" 52 100 249 165 365\n"" 53 296 316 224 371\n"" 54 74 188 186 189\n"" 55 21 171 165 249\n"" 56 23 297 225 298\n"" 57 191 196 64 290\n"" 58 87 139 138 288\n"" 59 126 198 196 199\n"" 60 223 328 141 342\n"" 61 293 371 153 396\n"" 62 238 308 108 313\n"" 63 49 187 80 189\n"" 64 143 300 224 361\n"" 65 111 256 130 343\n"" 66 62 107 106 273\n"" 67 64 196 126 219\n"" 68 314 154 315 369\n"" 69 50 205 204 344\n"" 70 0 70 26 71\n"" 71 95 158 23 265\n"" 72 37 138 87 139\n"" 73 125 193 43 195\n"" 74 56 312 238 313\n"" 75 257 259 172 332\n"" 76 25 70 0 72\n"" 77 141 300 228 358\n"" 78 32 207 208 350\n"" 79 101 201 200 219\n"" 80 13 147 121 240\n"" 81 67 275 176 357\n"" 82 116 249 180 266\n"" 83 197 219 200 272\n"" 84 152 247 42 371\n"" 85 95 158 60 160\n"" 86 45 230 116 375\n"" 87 88 282 142 283\n"" 88 96 162 61 249\n"" 89 209 280 211 350\n"" 90 84 353 226 399\n"" 91 33 258 172 381\n"" 92 118 285 213 378\n"" 93 196 271 77 289\n"" 94 282 287 218 388\n"" 95 196 198 125 199\n"" 96 74 7 76 30\n"" 97 95 230 181 264\n"" 98 297 359 225 390\n"" 99 280 347 261 350\n"" 100 253 299 170 380\n"" 101 125 269 193 335\n"" 102 245 293 224 300\n"" 103 41 143 68 161\n"" 104 58 295 244 316\n"" 105 83 348 211 349\n"" 106 75 29 76 123\n"" 107 171 249 96 255\n"" 108 124 196 125 199\n"" 109 61 248 96 249\n"" 110 221 255 45 327\n"" 111 254 326 171 336\n"" 112 194 198 126 199\n"" 113 208 278 9 279\n"" 114 94 93 11 160\n"" 115 275 357 345 363\n"" 116 127 173 109 203\n"" 117 134 139 55 218\n"" 118 45 255 253 327\n"" 119 154 35 315 370\n"" 120 283 284 142 353\n"" 121 186 336 268 377\n"" 122 59 93 11 94\n"" 123 110 203 51 277\n"" 124 59 246 94 247\n"" 125 116 248 61 249\n"" 126 41 229 143 296\n"" 127 91 154 36 316\n"" 128 71 179 116 180\n"" 129 45 299 221 327\n"" 130 319 373 182 374\n"" 131 64 219 101 290\n"" 132 116 301 179 398\n"" 133 122 323 188 377\n"" 134 182 373 68 374\n"" 135 97 115 114 248\n"" 136 60 158 95 181\n"" 137 185 268 48 335\n"" 138 66 125 43 195\n"" 139 86 215 136 287\n"" 140 106 202 163 273\n"" 141 43 106 66 195\n"" 142 271 324 283 389\n"" 143 95 158 42 245\n"" 144 186 188 122 189\n"" 145 25 179 157 301\n"" 146 173 274 110 341\n"" 147 136 138 37 287\n"" 148 244 293 58 316\n"" 149 107 197 65 272\n"" 150 42 160 158 161\n"" 151 28 105 103 194\n"" 152 200 201 126 219\n"" 153 147 235 90 236\n"" 154 224 292 141 293\n"" 155 220 272 140 303\n"" 156 4 209 83 211\n"" 157 207 278 208 279\n"" 158 296 300 143 318\n"" 159 226 352 84 399\n"" 160 104 65 63 194\n"" 161 212 282 88 283\n"" 162 255 308 238 364\n"" 163 150 229 91 361\n"" 164 43 163 106 202\n"" 165 126 219 196 289\n"" 166 48 185 79 189\n"" 167 257 329 110 332\n"" 168 170 299 252 380\n"" 169 30 74 75 76\n"" 170 30 79 78 80\n"" 171 39 234 146 307\n"" 172 218 252 142 339\n"" 173 185 251 77 340\n"" 174 102 200 197 219\n"" 175 49 189 185 340\n"" 176 213 348 286 349\n"" 177 133 286 285 348\n"" 178 65 197 126 272\n"" 179 187 189 49 340\n"" 180 213 285 53 378\n"" 181 63 194 65 200\n"" 182 131 279 85 387\n"" 183 120 169 148 323\n"" 184 197 200 126 272\n"" 185 46 166 72 179\n"" 186 15 248 98 273\n"" 187 98 114 24 373\n"" 188 46 180 100 266\n"" 189 22 231 140 374\n"" 190 171 335 77 382\n"" 191 27 106 62 107\n"" 192 255 264 159 391\n"" 193 132 325 322 379\n"" 194 240 323 313 377\n"" 195 155 160 93 301\n"" 196 221 299 170 327\n"" 197 158 160 95 161\n"" 198 79 80 30 189\n"" 199 178 365 311 391\n"" 200 16 285 133 286\n"" 201 249 255 171 365\n"" 202 188 270 73 323\n"" 203 162 165 61 249\n"" 204 107 126 65 194\n"" 205 155 156 93 160\n"" 206 219 303 102 356\n"" 207 259 330 132 351\n"" 208 224 293 141 300\n"" 209 77 271 170 289\n"" 210 231 252 140 299\n"" 211 147 240 148 313\n"" 212 152 370 153 395\n"" 213 154 246 35 247\n"" 214 291 354 212 387\n"" 215 211 348 280 349\n"" 216 144 234 39 307\n"" 217 212 292 33 381\n"" 218 133 348 83 349\n"" 219 119 337 270 338\n"" 220 120 188 73 323\n"" 221 211 280 209 349\n"" 222 209 211 333 347\n"" 223 251 325 108 379\n"" 224 236 238 146 309\n"" 225 274 329 110 342\n"" 226 39 305 144 307\n"" 227 144 305 89 307\n"" 228 96 249 248 375\n"" 229 113 178 177 392\n"" 230 91 294 224 295\n"" 231 94 160 42 161\n"" 232 165 171 21 326\n"" 233 170 324 251 379\n"" 234 211 347 209 350\n"" 235 116 179 115 398\n"" 236 214 263 31 384\n"" 237 70 117 71 0\n"" 238 43 195 96 202\n"" 239 90 235 40 236\n"" 240 134 136 37 287\n"" 241 67 253 159 357\n"" 242 33 328 258 381\n"" 243 71 116 115 180\n"" 244 55 241 134 302\n"" 245 155 301 24 398\n"" 246 275 345 205 363\n"" 247 52 209 175 280\n"" 248 287 302 241 355\n"" 249 79 185 48 269\n"" 250 45 181 116 230\n"" 251 68 182 24 373\n"" 252 106 126 66 195\n"" 253 170 299 253 327\n"" 254 228 298 245 358\n"" 255 275 357 67 390\n"" 256 126 195 77 196\n"" 257 176 275 67 343\n"" 258 17 363 232 367\n"" 259 248 249 116 375\n"" 260 251 324 250 325\n"" 261 122 251 185 340\n"" 262 238 311 309 326\n"" 263 157 160 155 301\n"" 264 60 181 99 265\n"" 265 98 248 114 373\n"" 266 34 261 209 347\n"" 267 132 330 212 351\n"" 268 245 274 141 358\n"" 269 190 191 19 271\n"" 270 236 238 57 313\n"" 271 105 104 103 194\n"" 272 94 246 161 247\n"" 273 35 246 59 247\n"" 274 140 319 267 374\n"" 275 212 281 33 291\n"" 276 117 71 46 179\n"" 277 70 117 72 179\n"" 278 159 253 228 264\n"" 279 80 185 49 189\n"" 280 209 333 4 210\n"" 281 2 128 127 206\n"" 282 100 164 46 166\n"" 283 74 76 7 123\n"" 284 80 187 75 189\n"" 285 103 194 63 201\n"" 286 171 326 249 365\n"" 287 136 6 137 37\n"" 288 216 291 85 354\n"" 289 47 120 13 121\n"" 290 101 288 54 356\n"" 291 130 263 111 343\n"" 292 168 200 101 201\n"" 293 68 143 41 229\n"" 294 282 291 135 354\n"" 295 49 191 190 340\n"" 296 184 189 75 270\n"" 297 202 272 126 289\n"" 298 218 356 339 383\n"" 299 352 388 215 399\n"" 300 124 192 125 269\n"" 301 70 117 0 72\n"" 302 136 218 138 287\n"" 303 108 255 171 327\n"" 304 223 293 153 396\n"" 305 25 156 155 157\n"" 306 115 116 61 180\n"" 307 320 321 250 338\n"" 308 60 166 99 181\n"" 309 228 245 141 358\n"" 310 127 346 203 385\n"" 311 96 249 171 382\n"" 312 219 272 140 289\n"" 313 112 275 204 363\n"" 314 126 197 65 200\n"" 315 270 337 250 338\n"" 316 42 158 95 161\n"" 317 183 187 118 270\n"" 318 212 283 132 284\n"" 319 204 275 205 363\n"" 320 165 180 61 249\n"" 321 67 275 203 332\n"" 322 14 185 80 269\n"" 323 224 296 91 316\n"" 324 209 261 175 280\n"" 325 290 339 219 383\n"" 326 193 269 48 335\n"" 327 106 195 43 202\n"" 328 176 357 275 363\n"" 329 77 251 170 271\n"" 330 44 267 220 272\n"" 331 75 189 187 270\n"" 332 65 194 126 200\n"" 333 68 267 182 374\n"" 334 125 195 66 198\n"" 335 17 204 50 205\n"" 336 250 325 322 384\n"" 337 66 195 126 198\n"" 338 79 185 80 189\n"" 339 159 298 67 357\n"" 340 218 302 88 303\n"" 341 78 80 79 269\n"" 342 77 221 170 327\n"" 343 90 147 13 148\n"" 344 319 373 230 375\n"" 345 126 200 194 201\n"" 346 143 161 41 296\n"" 347 297 357 345 390\n"" 348 126 195 106 202\n"" 349 64 196 124 199\n"" 350 209 333 211 4\n"" 351 44 202 107 273\n"" 352 195 196 125 335\n"" 353 284 353 84 399\n"" 354 125 196 195 198\n"" 355 64 126 103 201\n"" 356 63 200 168 201\n"" 357 278 279 207 284\n"" 358 175 209 34 261\n"" 359 224 294 91 361\n"" 360 274 298 225 390\n"" 361 258 329 172 381\n"" 362 293 316 153 371\n"" 363 37 139 134 287\n"" 364 200 219 126 272\n"" 365 110 277 257 332\n"" 366 158 225 42 245\n"" 367 191 271 190 340\n"" 368 6 86 136 217\n"" 369 96 163 43 202\n"" 370 41 246 154 296\n"" 371 2 127 50 206\n"" 372 120 240 188 323\n"" 373 171 268 77 335\n"" 374 257 277 276 332\n"" 375 308 313 238 393\n"" 376 98 248 202 273\n"" 377 167 303 55 356\n"" 378 136 137 6 217\n"" 379 88 283 252 380\n"" 380 188 323 240 377\n"" 381 140 272 267 319\n"" 382 121 188 120 240\n"" 383 323 368 313 377\n"" 384 172 258 110 329\n"" 385 192 198 28 199\n"" 386 284 354 85 387\n"" 387 155 157 156 160\n"" 388 143 230 45 299\n"" 389 173 341 20 372\n"" 390 248 319 96 375\n"" 391 242 241 151 355\n"" 392 30 80 75 189\n"" 393 51 173 127 203\n"" 394 81 256 8 257\n"" 395 187 270 122 340\n"" 396 38 241 242 355\n"" 397 141 293 245 300\n"" 398 93 156 11 160\n"" 399 88 252 218 303\n"" 400 29 123 75 184\n"" 401 159 334 297 357\n"" 402 206 344 130 346\n"" 403 185 269 125 335\n"" 404 151 294 10 295\n"" 405 105 66 27 194\n"" 406 150 302 55 362\n"" 407 261 280 209 347\n"" 408 312 367 145 393\n"" 409 194 200 63 201\n"" 410 176 275 112 363\n"" 411 334 357 159 364\n"" 412 231 302 88 361\n"" 413 57 238 236 309\n"" 414 88 300 292 380\n"" 415 192 124 125 199\n"" 416 148 240 120 323\n"" 417 126 194 103 201\n"" 418 259 331 82 351\n"" 419 119 184 183 270\n"" 420 150 241 55 302\n"" 421 126 272 219 289\n"" 422 230 301 116 373\n"" 423 123 188 74 189\n"" 424 74 186 79 189\n"" 425 92 369 243 370\n"" 426 131 280 261 350\n"" 427 143 299 228 300\n"" 428 220 303 231 362\n"" 429 277 332 203 346\n"" 430 256 257 81 276\n"" 431 154 314 36 369\n"" 432 100 180 165 249\n"" 433 149 294 91 295\n"" 434 274 329 141 358\n"" 435 126 201 64 219\n"" 436 64 201 101 219\n"" 437 207 211 53 350\n"" 438 283 330 132 379\n"" 439 243 369 1 370\n"" 440 24 373 114 398\n"" 441 143 230 161 318\n"" 442 161 296 245 371\n"" 443 110 257 172 329\n"" 444 96 162 43 163\n"" 445 248 373 319 375\n"" 446 171 221 77 327\n"" 447 21 254 171 336\n"" 448 306 5 239 305\n"" 449 197 220 102 272\n"" 450 82 281 172 351\n"" 451 113 146 39 234\n"" 452 143 229 68 374\n"" 453 68 93 41 161\n"" 454 172 351 281 381\n"" 455 112 204 17 363\n"" 456 124 191 185 196\n"" 457 215 216 9 278\n"" 458 19 383 353 389\n"" 459 185 189 122 340\n"" 460 137 38 287 134\n"" 461 122 270 250 324\n"" 462 126 202 107 272\n"" 463 70 71 117 179\n"" 464 84 227 226 353\n"" 465 109 173 390 203\n"" 466 13 121 120 240\n"" 467 53 285 213 348\n"" 468 228 358 300 380\n"" 469 14 80 78 269\n"" 470 55 302 218 303\n"" 471 285 286 213 348\n"" 472 107 202 106 273\n"" 473 307 367 366 393\n"" 474 147 148 90 235\n"" 475 94 161 42 247\n"" 476 276 332 277 346\n"" 477 141 293 223 397\n"" 478 51 203 127 346\n"" 479 22 229 150 231\n"" 480 163 202 96 248\n"" 481 48 269 185 335\n"" 482 162 163 96 248\n"" 483 141 274 245 397\n"" 484 115 163 61 248\n"" 485 147 236 57 313\n"" 486 158 181 60 265\n"" 487 311 365 364 391\n"" 488 193 195 125 335\n"" 489 125 185 124 269\n"" 490 224 296 245 300\n"" 491 49 185 124 191\n"" 492 132 280 213 322\n"" 493 96 202 195 221\n"" 494 233 357 334 364\n"" 495 99 166 164 266\n"" 496 245 293 141 397\n"" 497 36 244 149 316\n"" 498 74 79 30 189\n"" 499 30 75 74 189\n"" 500 12 178 99 392\n"" 501 322 325 259 384\n"" 502 195 196 126 198\n"" 503 57 313 238 326\n"" 504 48 268 186 336\n"" 505 91 296 154 316\n"" 506 14 192 124 269\n"" 507 259 332 111 343\n"" 508 238 311 255 364\n"" 509 45 230 95 264\n"" 510 140 252 221 299\n"" 511 176 262 112 263\n"" 512 32 211 207 350\n"" 513 261 376 351 82\n"" 514 19 227 190 389\n"" 515 2 129 128 206\n"" 516 102 220 167 303\n"" 517 181 249 116 266\n"" 518 170 271 251 324\n"" 519 186 188 121 240\n"" 520 213 321 286 338\n"" 521 124 185 14 269\n"" 522 91 295 224 316\n"" 523 143 299 231 374\n"" 524 159 364 255 391\n"" 525 310 334 69 364\n"" 526 170 283 271 379\n"" 527 229 231 143 361\n"" 528 241 287 134 302\n"" 529 70 72 25 179\n"" 530 72 157 25 179\n"" 531 26 71 70 179\n"" 532 70 114 26 179\n"" 533 287 388 282 399\n"" 534 68 229 22 374\n"" 535 61 180 116 249\n"" 536 115 116 71 179\n"" 537 143 296 229 361\n"" 538 142 354 282 399\n"" 539 25 155 70 179\n"" 540 139 288 167 356\n"" 541 114 115 26 179\n"" 542 26 115 71 179\n"" 543 116 180 179 266\n"" 544 164 166 100 266\n"" 545 100 166 46 266\n"" 546 171 255 221 327\n"" 547 132 330 325 379\n"" 548 140 289 252 339\n"" 549 24 182 98 373\n"" 550 180 249 100 266\n"" 551 320 321 214 322\n"" 552 213 285 270 338\n"" 553 214 321 52 322\n"" 554 122 188 186 268\n"" 555 271 289 196 339\n"" 556 108 251 250 325\n"" 557 153 293 244 316\n"" 558 43 193 162 382\n"" 559 80 124 49 185\n"" 560 159 67 358 253\n"" 561 142 282 212 283\n"" 562 14 124 80 185\n"" 563 110 174 173 341\n"" 564 187 189 122 270\n"" 565 252 299 88 380\n"" 566 55 218 139 356\n"" 567 227 378 190 389\n"" 568 33 292 222 328\n"" 569 47 121 74 188\n"" 570 74 123 47 188\n"" 571 120 121 47 188\n"" 572 47 123 120 188\n"" 573 55 303 218 356\n"" 574 167 288 18 356\n"" 575 58 224 151 295\n"" 576 18 167 87 288\n"" 577 116 230 181 301\n"" 578 161 246 41 296\n"" 579 91 244 149 295\n"" 580 33 281 212 381\n"" 581 23 225 158 245\n"" 582 79 186 48 189\n"" 583 75 184 123 189\n"" 584 74 75 76 189\n"" 585 75 123 76 189\n"" 586 76 123 74 189\n"" 587 67 357 298 390\n"" 588 124 185 125 196\n"" 589 186 240 121 336\n"" 590 64 191 124 196\n"" 591 209 210 34 347\n"" 592 80 185 79 269\n"" 593 63 103 104 194\n"" 594 27 107 65 194\n"" 595 9 278 216 279\n"" 596 66 126 106 194\n"" 597 104 27 65 194\n"" 598 66 106 27 194\n"" 599 106 107 27 194\n"" 600 27 3 105 194\n"" 601 105 3 104 194\n"" 602 104 3 27 194\n"" 603 77 335 195 382\n"" 604 136 217 86 287\n"" 605 226 290 54 383\n"" 606 290 356 54 383\n"" 607 218 339 142 383\n"" 608 21 268 193 336\n"" 609 193 268 48 336\n"" 610 171 268 21 336\n"" 611 103 194 126 199\n"" 612 28 198 194 199\n"" 613 125 198 192 199\n"" 614 28 194 103 199\n"" 615 106 163 62 273\n"" 616 98 202 44 273\n"" 617 221 252 170 299\n"" 618 141 300 245 318\n"" 619 185 196 77 335\n"" 620 244 295 91 316\n"" 621 62 163 15 273\n"" 622 231 299 143 300\n"" 623 317 371 245 397\n"" 624 126 196 64 199\n"" 625 103 126 64 199\n"" 626 93 94 59 246\n"" 627 127 344 206 346\n"" 628 224 292 222 360\n"" 629 225 359 274 390\n"" 630 221 319 45 375\n"" 631 25 157 155 301\n"" 632 19 271 191 290\n"" 633 110 341 274 342\n"" 634 163 248 15 273\n"" 635 132 283 212 330\n"" 636 119 321 320 338\n"" 637 186 189 122 268\n"" 638 106 194 126 202\n"" 639 126 194 107 202\n"" 640 107 194 106 202\n"" 641 141 358 329 381\n"" 642 88 302 282 360\n"" 643 263 275 176 343\n"" 644 173 203 110 274\n"" 645 260 175 34 261\n"" 646 250 270 122 323\n"" 647 21 165 162 249\n"" 648 193 335 268 382\n"" 649 130 332 275 343\n"" 650 204 275 130 344\n"" 651 51 110 174 203\n"" 652 110 173 174 203\n"" 653 174 173 51 203\n"" 654 70 155 24 398\n"" 655 177 113 39 234\n"" 656 218 252 88 282\n"" 657 352 383 54 388\n"" 658 112 263 204 275\n"" 659 54 352 226 383\n"" 660 134 287 241 355\n"" 661 238 307 146 309\n"" 662 224 295 58 316\n"" 663 325 343 259 384\n"" 664 259 329 67 330\n"" 665 88 292 224 360\n"" 666 9 215 86 216\n"" 667 221 299 45 319\n"" 668 245 296 161 318\n"" 669 136 134 137 287\n"" 670 83 211 209 349\n"" 671 132 324 283 379\n"" 672 84 284 207 353\n"" 673 138 139 37 287\n"" 674 140 252 231 303\n"" 675 219 289 140 339\n"" 676 181 230 45 264\n"" 677 228 300 299 380\n"" 678 85 279 216 354\n"" 679 169 320 250 323\n"" 680 68 230 143 374\n"" 681 207 227 84 353\n"" 682 240 313 57 326\n"" 683 49 190 187 340\n"" 684 286 348 133 349\n"" 685 52 280 213 349\n"" 686 263 343 176 384\n"" 687 51 277 203 346\n"" 688 220 267 140 272\n"" 689 137 217 136 287\n"" 690 203 329 274 390\n"" 691 31 320 250 368\n"" 692 224 316 293 371\n"" 693 231 252 88 303\n"" 694 252 271 170 283\n"" 695 253 358 228 380\n"" 696 256 276 130 332\n"" 697 19 353 227 389\n"" 698 219 339 303 356\n"" 699 170 252 221 289\n"" 700 142 271 252 283\n"" 701 209 347 280 350\n"" 702 142 252 88 283\n"" 703 251 324 271 340\n"" 704 95 264 181 391\n"" 705 171 251 77 268\n"" 706 98 319 248 373\n"" 707 331 351 259 376\n"" 708 41 154 91 296\n"" 709 10 241 151 242\n"" 710 330 380 292 381\n"" 711 132 284 283 353\n"" 712 140 272 221 289\n"" 713 126 196 77 289\n"" 714 152 371 317 395\n"" 715 36 149 91 316\n"" 716 108 253 176 308\n"" 717 255 365 264 391\n"" 718 202 248 163 273\n"" 719 224 300 88 361\n"" 720 65 126 107 272\n"" 721 67 159 358 298\n"" 722 88 300 231 361\n"" 723 153 223 58 293\n"" 724 146 238 236 307\n"" 725 202 248 98 319\n"" 726 141 328 292 381\n"" 727 42 161 95 245\n"" 728 176 253 108 325\n"" 729 10 294 149 295\n"" 730 155 179 25 301\n"" 731 68 161 143 230\n"" 732 264 365 181 391\n"" 733 225 274 245 298\n"" 734 225 245 23 298\n"" 735 41 161 93 246\n"" 736 97 163 115 248\n"" 737 93 161 94 246\n"" 738 45 255 96 375\n"" 739 212 291 282 354\n"" 740 148 313 323 169\n"" 741 224 292 88 300\n"" 742 142 283 212 354\n"" 743 61 162 96 248\n"" 744 97 114 98 248\n"" 745 185 189 48 268\n"" 746 205 345 275 385\n"" 747 48 268 193 335\n"" 748 24 155 68 301\n"" 749 60 160 157 301\n"" 750 159 357 308 364\n"" 751 297 345 109 390\n"" 752 61 163 162 248\n"" 753 61 116 115 248\n"" 754 230 299 143 374\n"" 755 140 267 22 374\n"" 756 102 303 167 356\n"" 757 134 287 218 302\n"" 758 218 282 88 302\n"" 759 93 161 68 230\n"" 760 357 363 308 364\n"" 761 224 295 294 361\n"" 762 153 244 36 316\n"" 763 303 339 218 356\n"" 764 294 302 150 361\n"" 765 153 371 152 395\n"" 766 57 326 254 336\n"" 767 48 189 186 268\n"" 768 238 308 255 326\n"" 769 214 322 52 376\n"" 770 132 322 259 376\n"" 771 111 331 259 376\n"" 772 121 240 147 336\n"" 773 253 379 330 380\n"" 774 223 274 141 397\n"" 775 176 308 262 313\n"" 776 31 262 176 263\n"" 777 334 364 159 391\n"" 778 255 311 238 326\n"" 779 110 274 203 329\n"" 780 315 369 154 370\n"" 781 146 234 113 311\n"" 782 363 366 232 367\n"" 783 159 298 228 358\n"" 784 292 328 33 381\n"" 785 68 301 230 373\n"" 786 271 340 324 389\n"" 787 176 263 112 275\n"" 788 1 369 315 370\n"" 789 159 308 255 364\n"" 790 253 255 159 308\n"" 791 262 312 56 313\n"" 792 19 290 226 383\n"" 793 84 352 215 399\n"" 794 23 158 95 245\n"" 795 145 235 56 238\n"" 796 132 322 213 324\n"" 797 77 268 185 335\n"" 798 175 214 52 376\n"" 799 108 255 253 308\n"" 800 56 238 235 313\n"" 801 111 175 8 331\n"" 802 52 286 213 321\n"" 803 149 244 91 316\n"" 804 237 5 306 305\n"" 805 165 326 113 365\n"" 806 58 293 224 316\n"" 807 204 263 130 275\n"" 808 222 292 58 328\n"" 809 175 261 260 331\n"" 810 45 253 228 299\n"" 811 250 321 320 322\n"" 812 102 272 220 303\n"" 813 182 267 98 319\n"" 814 170 379 253 380\n"" 815 151 241 10 294\n"" 816 52 321 213 322\n"" 817 215 278 84 399\n"" 818 282 354 216 399\n"" 819 22 267 68 374\n"" 820 230 373 319 374\n"" 821 97 98 15 248\n"" 822 274 341 223 342\n"" 823 15 163 97 248\n"" 824 153 316 36 369\n"" 825 132 351 212 387\n"" 826 185 251 122 268\n"" 827 122 189 185 268\n"" 828 250 324 270 338\n"" 829 233 345 297 357\n"" 830 129 277 128 346\n"" 831 165 249 171 326\n"" 832 122 268 251 377\n"" 833 259 329 172 332\n"" 834 255 364 311 365\n"" 835 140 220 22 267\n"" 836 142 282 218 388\n"" 837 108 326 313 377\n"" 838 221 252 140 289\n"" 839 77 196 195 335\n"" 840 251 271 77 340\n"" 841 250 251 122 324\n"" 842 238 309 57 326\n"" 843 227 386 378 389\n"" 844 171 255 108 326\n"" 845 256 259 111 331\n"" 846 178 365 266 392\n"" 847 178 311 69 391\n"" 848 102 219 197 272\n"" 849 172 259 257 331\n"" 850 258 342 329 381\n"" 851 143 296 224 300\n"" 852 88 299 231 300\n"" 853 182 319 98 373\n"" 854 44 220 197 272\n"" 855 107 202 44 272\n"" 856 333 210 209 347\n"" 857 299 300 88 380\n"" 858 67 253 176 325\n"" 859 212 354 284 387\n"" 860 203 110 332 277\n"" 861 171 251 108 327\n"" 862 96 221 171 255\n"" 863 45 221 96 255\n"" 864 58 293 223 328\n"" 865 148 235 147 313\n"" 866 36 316 154 369\n"" 867 92 395 394 396\n"" 868 132 351 280 376\n"" 869 253 299 45 327\n"" 870 233 334 310 364\n"" 871 195 335 193 382\n"" 872 193 268 21 382\n"" 873 223 293 141 328\n"" 874 292 293 58 328\n"" 875 38 137 287 217\n"" 876 315 1 314 369\n"" 877 141 274 223 342\n"" 878 188 268 122 377\n"" 879 141 293 292 328\n"" 880 235 236 147 313\n"" 881 235 238 236 313\n"" 882 57 240 147 313\n"" 883 88 282 212 292\n"" 884 23 297 159 334\n"" 885 259 325 132 330\n"" 886 23 334 159 391\n"" 887 283 324 132 389\n"" 888 205 345 304 363\n"" 889 253 325 67 330\n"" 890 43 162 96 382\n"" 891 257 331 259 332\n"" 892 256 331 257 332\n"" 893 172 329 257 332\n"" 894 54 356 218 383\n"" 895 259 331 256 332\n"" 896 208 131 32 350\n"" 897 280 348 213 349\n"" 898 118 270 213 285\n"" 899 16 270 118 285\n"" 900 253 308 159 357\n"" 901 81 276 257 277\n"" 902 228 253 45 264\n"" 903 31 262 169 368\n"" 904 262 313 169 368\n"" 905 108 313 308 368\n"" 906 159 255 253 264\n"" 907 253 255 45 264\n"" 908 95 181 158 265\n"" 909 45 264 255 365\n"" 910 113 311 178 392\n"" 911 177 178 12 392\n"" 912 100 365 165 392\n"" 913 369 370 92 395\n"" 914 72 179 166 266\n"" 915 150 294 241 302\n"" 916 134 218 55 302\n"" 917 166 179 71 266\n"" 918 179 180 71 266\n"" 919 46 166 71 266\n"" 920 71 180 46 266\n"" 921 308 364 363 393\n"" 922 238 313 312 393\n"" 923 238 364 308 393\n"" 924 366 367 363 393\n"" 925 218 287 282 302\n"" 926 72 166 60 266\n"" 927 166 181 60 266\n"" 928 116 373 301 398\n"" 929 225 372 317 397\n"" 930 226 388 352 399\n"" 931 145 238 56 312\n"" 932 176 325 108 368\n"" 933 152 35 154 370\n"" 934 108 327 251 379\n"" 935 135 291 216 354\n"" 936 283 324 271 379\n"" 937 213 324 322 338\n"" 938 284 351 132 387\n"" 939 321 322 250 338\n"" 940 73 323 270 337\n"" 941 270 323 250 337\n"" 942 286 321 119 338\n"" 943 250 323 320 337\n"" 944 320 323 73 337\n"" 945 213 322 321 338\n"" 946 122 189 188 270\n"" 947 183 184 29 270\n"" 948 29 187 183 270\n"" 949 16 183 118 270\n"" 950 119 183 16 270\n"" 951 252 271 142 339\n"" 952 196 289 219 339\n"" 953 69 311 310 364\n"" 954 185 191 49 340\n"" 955 29 184 75 270\n"" 956 75 187 29 270\n"" 957 184 188 123 270\n"" 958 188 189 123 270\n"" 959 123 189 184 270\n"" 960 255 308 108 326\n"" 961 108 308 238 326\n"" 962 245 298 274 358\n"" 963 111 332 256 343\n"" 964 53 227 207 386\n"" 965 58 244 153 293\n"" 966 91 296 224 361\n"" 967 268 336 171 377\n"" 968 162 249 96 382\n"" 969 141 329 274 342\n"" 970 259 322 132 325\n"" 971 213 348 280 386\n"" 972 130 275 263 343\n"" 973 161 230 95 318\n"" 974 95 230 45 318\n"" 975 228 298 95 318\n"" 976 302 303 55 362\n"" 977 45 230 143 318\n"" 978 95 245 161 318\n"" 979 77 251 171 327\n"" 980 233 363 357 364\n"" 981 213 280 132 386\n"" 982 173 109 390 359\n"" 983 159 297 23 298\n"" 984 213 286 52 349\n"" 985 108 251 171 377\n"" 986 209 280 52 349\n"" 987 252 289 271 339\n"" 988 84 278 207 284\n"" 989 142 252 218 282\n"" 990 88 252 142 282\n"" 991 190 271 19 389\n"" 992 257 276 256 332\n"" 993 251 268 171 377\n"" 994 122 270 188 323\n"" 995 138 218 139 287\n"" 996 226 383 352 388\n"" 997 73 169 120 323\n"" 998 73 320 169 323\n"" 999 324 325 251 379\n"" 1000 364 365 255 391\n"" 1001 228 300 141 318\n"" 1002 224 296 143 361\n"" 1003 87 167 139 288\n"" 1004 297 334 233 357\n"" 1005 85 284 279 354\n"" 1006 122 324 251 340\n"" 1007 170 221 77 289\n"" 1008 170 271 252 289\n"" 1009 77 195 126 289\n"" 1010 167 220 55 303\n"" 1011 139 218 134 287\n"" 1012 216 217 135 287\n"" 1013 135 282 216 287\n"" 1014 245 300 296 318\n"" 1015 58 292 224 293\n"" 1016 171 249 21 382\n"" 1017 172 259 82 351\n"" 1018 131 284 279 387\n"" 1019 134 241 38 355\n"" 1020 18 288 101 356\n"" 1021 38 287 134 355\n"" 1022 139 167 55 356\n"" 1023 139 218 138 356\n"" 1024 142 383 271 389\n"" 1025 216 282 135 354\n"" 1026 353 383 142 389\n"" 1027 271 283 142 389\n"" 1028 131 350 284 387\n"" 1029 274 358 298 390\n"" 1030 86 216 215 287\n"" 1031 86 217 216 287\n"" 1032 195 202 126 289\n"" 1033 195 221 202 289\n"" 1034 77 221 195 289\n"" 1035 140 272 219 303\n"" 1036 33 291 222 292\n"" 1037 212 291 33 292\n"" 1038 229 296 91 361\n"" 1039 140 231 220 303\n"" 1040 145 307 238 393\n"" 1041 222 224 58 292\n"" 1042 270 324 122 340\n"" 1043 96 319 221 375\n"" 1044 216 278 215 399\n"" 1045 274 341 173 372\n"" 1046 88 252 231 299\n"" 1047 216 279 278 399\n"" 1048 115 248 116 398\n"" 1049 274 359 225 372\n"" 1050 153 395 92 396\n"" 1051 245 298 228 318\n"" 1052 95 298 245 318\n"" 1053 143 300 228 318\n"" 1054 231 303 302 362\n"" 1055 91 229 41 296\n"" 1056 293 396 223 397\n"" 1057 249 255 45 375\n"" 1058 42 245 225 317\n"" 1059 304 345 233 363\n"" 1060 55 303 220 362\n"" 1061 231 302 150 362\n"" 1062 216 354 279 399\n"" 1063 361 224 151 360\n"" 1064 282 388 142 399\n"" 1065 96 255 249 375\n"" 1066 151 222 135 360\n"" 1067 222 292 291 360\n"" 1068 159 264 23 391\n"" 1069 127 206 128 346\n"" 1070 95 265 23 391\n"" 1071 69 334 265 391\n"" 1072 159 264 228 298\n"" 1073 228 264 95 298\n"" 1074 23 245 95 298\n"" 1075 282 292 88 360\n"" 1076 67 330 329 358\n"" 1077 23 264 159 298\n"" 1078 95 264 23 298\n"" 1079 229 231 22 374\n"" 1080 60 157 72 301\n"" 1081 157 179 72 301\n"" 1082 116 266 179 301\n"" 1083 95 160 60 301\n"" 1084 60 266 181 301\n"" 1085 181 266 116 301\n"" 1086 60 181 95 301\n"" 1087 181 230 95 301\n"" 1088 160 161 93 301\n"" 1089 161 230 93 301\n"" 1090 68 155 93 301\n"" 1091 93 230 68 301\n"" 1092 179 266 72 301\n"" 1093 72 266 60 301\n"" 1094 95 161 160 301\n"" 1095 95 230 161 301\n"" 1096 308 357 176 363\n"" 1097 255 326 171 365\n"" 1098 91 294 150 361\n"" 1099 294 360 302 361\n"" 1100 231 300 143 361\n"" 1101 88 302 231 303\n"" 1102 245 371 293 397\n"" 1103 146 236 40 307\n"" 1104 236 238 235 307\n"" 1105 235 238 145 307\n"" 1106 110 203 332 329\n"" 1107 177 234 178 311\n"" 1108 113 234 177 311\n"" 1109 169 262 56 313\n"" 1110 148 169 56 313\n"" 1111 89 237 145 307\n"" 1112 89 305 237 307\n"" 1113 306 40 145 307\n"" 1114 146 40 306 307\n"" 1115 237 306 145 307\n"" 1116 237 305 306 307\n"" 1117 306 239 146 307\n"" 1118 305 239 306 307\n"" 1119 146 239 39 307\n"" 1120 239 305 39 307\n"" 1121 40 235 145 307\n"" 1122 40 236 235 307\n"" 1123 177 178 113 311\n"" 1124 253 255 108 327\n"" 1125 307 309 238 311\n"" 1126 178 234 69 311\n"" 1127 170 251 77 327\n"" 1128 271 324 170 379\n"" 1129 146 307 234 311\n"" 1130 181 266 99 365\n"" 1131 69 234 144 311\n"" 1132 234 307 144 311\n"" 1133 228 299 253 380\n"" 1134 100 266 249 365\n"" 1135 178 266 99 392\n"" 1136 99 266 178 365\n"" 1137 113 365 311 392\n"" 1138 99 266 164 392\n"" 1139 108 308 176 368\n"" 1140 313 323 169 368\n"" 1141 45 255 249 365\n"" 1142 232 363 304 366\n"" 1143 308 313 176 368\n"" 1144 146 309 307 311\n"" 1145 113 309 146 311\n"" 1146 52 280 175 376\n"" 1147 144 310 69 311\n"" 1148 115 179 114 398\n"" 1149 114 248 115 398\n"" 1150 176 262 31 368\n"" 1151 212 284 132 387\n"" 1152 89 366 144 367\n"" 1153 153 370 369 395\n"" 1154 153 369 92 395\n"" 1155 301 373 24 398\n"" 1156 53 350 348 386\n"" 1157 108 325 250 368\n"" 1158 371 395 153 396\n"" 1159 24 301 68 373\n"" 1160 70 179 155 398\n"" 1161 161 296 143 318\n"" 1162 95 264 228 318\n"" 1163 228 264 45 318\n"" 1164 45 264 95 318\n"" 1165 45 299 228 318\n"" 1166 228 299 143 318\n"" 1167 143 299 45 318\n"" 1168 68 373 230 374\n"" 1169 267 319 182 374\n"" 1170 259 351 132 376\n"" 1171 202 272 221 319\n"" 1172 221 272 140 319\n"" 1173 202 221 96 319\n"" 1174 96 248 202 319\n"" 1175 116 373 248 375\n"" 1176 44 202 98 319\n"" 1177 98 267 44 319\n"" 1178 267 272 44 319\n"" 1179 44 272 202 319\n"" 1180 230 373 116 375\n"" 1181 143 231 229 374\n"" 1182 116 249 181 375\n"" 1183 45 319 230 375\n"" 1184 116 181 45 375\n"" 1185 175 331 111 376\n"" 1186 280 322 132 376\n"" 1187 171 336 326 377\n"" 1188 261 347 131 350\n"" 1189 131 347 32 350\n"" 1190 128 206 129 346\n"" 1191 238 313 108 326\n"" 1192 171 254 21 326\n"" 1193 329 358 330 381\n"" 1194 251 327 170 379\n"" 1195 325 330 253 379\n"" 1196 172 281 33 381\n"" 1197 212 282 142 354\n"" 1198 110 329 258 342\n"" 1199 205 344 50 385\n"" 1200 376 261 351 280\n"" 1201 173 174 20 341\n"" 1202 322 324 132 379\n"" 1203 322 325 324 379\n"" 1204 298 358 67 390\n"" 1205 67 329 203 390\n"" 1206 21 254 165 326\n"" 1207 184 270 119 337\n"" 1208 142 284 283 354\n"" 1209 73 270 184 337\n"" 1210 218 303 252 339\n"" 1211 250 323 108 368\n"" 1212 245 274 225 397\n"" 1213 165 254 113 326\n"" 1214 275 344 205 385\n"" 1215 254 309 113 326\n"" 1216 309 311 113 326\n"" 1217 96 221 77 382\n"" 1218 249 326 165 365\n"" 1219 125 196 185 335\n"" 1220 224 245 371 293\n"" 1221 203 329 67 332\n"" 1222 50 206 127 344\n"" 1223 162 193 21 382\n"" 1224 8 256 111 331\n"" 1225 82 259 172 331\n"" 1226 245 224 371 296\n"" 1227 260 8 175 331\n"" 1228 250 368 325 384\n"" 1229 219 356 290 383\n"" 1230 96 195 43 382\n"" 1231 271 339 290 383\n"" 1232 212 330 292 381\n"" 1233 265 334 23 391\n"" 1234 329 330 259 381\n"" 1235 329 342 141 381\n"" 1236 77 221 171 382\n"" 1237 43 195 193 382\n"" 1238 292 380 141 381\n"" 1239 141 380 358 381\n"" 1240 111 259 256 332\n"" 1241 135 355 151 360\n"" 1242 130 344 275 346\n"" 1243 206 276 129 346\n"" 1244 207 350 53 386\n"" 1245 128 277 51 346\n"" 1246 51 127 128 346\n"" 1247 353 386 227 389\n"" 1248 271 290 19 383\n"" 1249 339 356 219 383\n"" 1250 322 324 250 338\n"" 1251 250 337 320 338\n"" 1252 320 337 119 338\n"" 1253 119 270 16 338\n"" 1254 270 285 16 338\n"" 1255 213 286 285 338\n"" 1256 285 286 16 338\n"" 1257 16 286 119 338\n"" 1258 343 376 259 384\n"" 1259 250 320 31 384\n"" 1260 252 303 140 339\n"" 1261 140 303 219 339\n"" 1262 191 271 196 339\n"" 1263 191 290 271 339\n"" 1264 196 290 191 339\n"" 1265 196 219 64 339\n"" 1266 219 290 64 339\n"" 1267 64 290 196 339\n"" 1268 31 368 250 384\n"" 1269 31 263 176 384\n"" 1270 322 376 214 384\n"" 1271 185 196 191 340\n"" 1272 196 271 191 340\n"" 1273 203 275 67 390\n"" 1274 345 357 275 390\n"" 1275 77 196 185 340\n"" 1276 77 271 196 340\n"" 1277 187 190 118 340\n"" 1278 118 270 187 340\n"" 1279 256 332 130 343\n"" 1280 67 325 176 343\n"" 1281 67 329 259 343\n"" 1282 67 332 329 343\n"" 1283 329 332 259 343\n"" 1284 298 357 297 390\n"" 1285 227 353 207 386\n"" 1286 344 346 127 385\n"" 1287 203 346 275 385\n"" 1288 348 350 280 386\n"" 1289 67 330 325 343\n"" 1290 325 330 259 343\n"" 1291 259 330 67 343\n"" 1292 284 350 207 386\n"" 1293 280 350 284 386\n"" 1294 207 353 284 386\n"" 1295 130 276 206 346\n"" 1296 130 332 276 346\n"" 1297 129 276 81 346\n"" 1298 276 277 81 346\n"" 1299 81 277 129 346\n"" 1300 203 332 275 346\n"" 1301 275 332 130 346\n"" 1302 53 348 213 386\n"" 1303 284 353 132 386\n"" 1304 280 348 211 350\n"" 1305 211 348 53 350\n"" 1306 85 281 131 387\n"" 1307 207 284 279 350\n"" 1308 279 284 131 350\n"" 1309 207 279 208 350\n"" 1310 208 279 131 350\n"" 1311 333 211 32 350\n"" 1312 333 347 211 350\n"" 1313 32 347 333 350\n"" 1314 350 351 284 387\n"" 1315 85 291 281 387\n"" 1316 281 381 351 387\n"" 1317 240 336 186 377\n"" 1318 313 368 108 377\n"" 1319 21 268 171 382\n"" 1320 171 221 96 382\n"" 1321 268 335 171 382\n"" 1322 218 287 136 388\n"" 1323 54 383 218 388\n"" 1324 218 383 142 388\n"" 1325 142 383 226 388\n"" 1326 82 261 131 351\n"" 1327 261 280 131 351\n"" 1328 284 350 280 351\n"" 1329 280 350 131 351\n"" 1330 226 227 19 353\n"" 1331 85 354 291 387\n"" 1332 131 351 350 387\n"" 1333 150 231 229 361\n"" 1334 88 360 224 361\n"" 1335 279 284 85 387\n"" 1336 281 291 212 387\n"" 1337 135 287 217 355\n"" 1338 150 302 231 361\n"" 1339 217 287 38 355\n"" 1340 283 284 212 354\n"" 1341 132 353 283 389\n"" 1342 118 340 190 389\n"" 1343 190 340 271 389\n"" 1344 271 383 19 389\n"" 1345 138 288 139 356\n"" 1346 176 368 31 384\n"" 1347 102 167 168 356\n"" 1348 101 219 200 356\n"" 1349 200 219 102 356\n"" 1350 167 18 168 356\n"" 1351 168 18 101 356\n"" 1352 101 290 219 356\n"" 1353 54 290 101 356\n"" 1354 138 218 54 356\n"" 1355 54 288 138 356\n"" 1356 259 376 322 384\n"" 1357 325 368 176 384\n"" 1358 168 200 102 356\n"" 1359 101 200 168 356\n"" 1360 176 253 67 357\n"" 1361 176 308 253 357\n"" 1362 307 310 144 364\n"" 1363 266 365 100 392\n"" 1364 135 291 282 360\n"" 1365 222 291 135 360\n"" 1366 282 291 212 360\n"" 1367 291 292 212 360\n"" 1368 212 292 282 360\n"" 1369 58 222 151 360\n"" 1370 58 224 222 360\n"" 1371 151 224 58 360\n"" 1372 22 231 150 362\n"" 1373 220 231 22 362\n"" 1374 241 294 151 360\n"" 1375 241 302 294 360\n"" 1376 282 302 287 360\n"" 1377 302 355 287 360\n"" 1378 282 287 135 360\n"" 1379 287 355 135 360\n"" 1380 241 355 302 360\n"" 1381 151 355 241 360\n"" 1382 294 295 151 361\n"" 1383 151 360 294 361\n"" 1384 204 205 17 363\n"" 1385 205 304 17 363\n"" 1386 132 324 213 386\n"" 1387 17 304 232 363\n"" 1388 250 320 169 368\n"" 1389 113 326 311 365\n"" 1390 274 372 225 397\n"" 1391 238 312 145 393\n"" 1392 372 395 317 397\n"" 1393 144 307 89 367\n"" 1394 89 307 145 367\n"" 1395 181 264 45 365\n"" 1396 249 266 181 365\n"" 1397 311 326 255 365\n"" 1398 310 311 144 364\n"" 1399 144 311 307 364\n"" 1400 176 313 262 368\n"" 1401 169 320 31 368\n"" 1402 144 366 307 367\n"" 1403 169 323 250 368\n"" 1404 232 366 89 367\n"" 1405 112 363 17 367\n"" 1406 275 346 344 385\n"" 1407 317 395 371 397\n"" 1408 145 367 307 393\n"" 1409 363 364 233 393\n"" 1410 363 367 112 393\n"" 1411 164 266 100 392\n"" 1412 307 364 238 393\n"" 1413 112 367 312 393\n"" 1414 165 365 113 392\n"" 1415 311 365 178 392\n"" 1416 12 99 164 392\n"" 1417 173 359 274 372\n"" 1418 248 373 116 398\n"" 1419 245 317 42 371\n"" 1420 42 317 152 371\n"" 1421 161 245 42 371\n"" 1422 42 247 161 371\n"" 1423 161 247 246 371\n"" 1424 246 296 161 371\n"" 1425 154 296 246 371\n"" 1426 154 316 296 371\n"" 1427 246 247 154 371\n"" 1428 152 154 35 371\n"" 1429 154 247 35 371\n"" 1430 35 247 152 371\n"" 1431 152 370 154 371\n"" 1432 114 373 248 398\n"" 1433 179 301 155 398\n"" 1434 114 179 70 398\n"" 1435 24 114 70 398\n"" 1436 153 370 152 371\n"" 1437 154 369 316 371\n"" 1438 154 370 369 371\n"" 1439 316 369 153 371\n"" 1440 369 370 153 371\n"" 1441 215 388 287 399\n"" 1442 278 284 84 399\n"" 1443 231 299 140 374\n"" 1444 299 319 140 374\n"" 1445 45 299 230 374\n"" 1446 45 319 299 374\n"" 1447 230 319 45 374\n"" 1448 45 365 249 375\n"" 1449 249 365 181 375\n"" 1450 181 365 45 375\n"" 1451 311 364 69 391\n"" 1452 259 343 111 376\n"" 1453 111 214 175 376\n"" 1454 175 280 261 376\n"" 1455 224 361 151 295\n"" 1456 82 351 331 376\n"" 1457 127 203 109 385\n"" 1458 50 344 127 385\n"" 1459 82 331 261 376\n"" 1460 261 331 175 376\n"" 1461 250 251 108 377\n"" 1462 108 323 250 377\n"" 1463 122 251 250 377\n"" 1464 250 323 122 377\n"" 1465 188 240 186 377\n"" 1466 186 268 188 377\n"" 1467 240 326 57 377\n"" 1468 326 336 57 377\n"" 1469 57 336 240 377\n"" 1470 108 325 253 379\n"" 1471 170 327 253 379\n"" 1472 253 327 108 379\n"" 1473 252 283 170 380\n"" 1474 212 283 88 380\n"" 1475 212 330 283 380\n"" 1476 330 379 283 380\n"" 1477 283 379 170 380\n"" 1478 253 330 67 380\n"" 1479 330 358 67 380\n"" 1480 67 358 253 380\n"" 1481 21 249 162 382\n"" 1482 300 358 141 380\n"" 1483 292 300 141 380\n"" 1484 77 195 96 382\n"" 1485 88 292 212 380\n"" 1486 292 330 212 380\n"" 1487 330 351 259 381\n"" 1488 172 329 259 381\n"" 1489 259 351 172 381\n"" 1490 212 351 330 381\n"" 1491 141 342 328 381\n"" 1492 328 342 258 381\n"" 1493 142 353 226 383\n"" 1494 226 353 19 383\n"" 1495 142 339 271 383\n"" 1496 274 359 173 390\n"" 1497 225 298 297 390\n"" 1498 31 320 214 384\n"" 1499 250 322 320 384\n"" 1500 320 322 214 384\n"" 1501 111 376 343 384\n"" 1502 214 376 111 384\n"" 1503 111 263 214 384\n"" 1504 111 343 263 384\n"" 1505 53 378 227 386\n"" 1506 213 378 53 386\n"" 1507 203 385 275 390\n"" 1508 132 351 284 386\n"" 1509 284 351 280 386\n"" 1510 280 351 132 386\n"" 1511 109 385 203 390\n"" 1512 109 359 297 390\n"" 1513 351 381 212 387\n"" 1514 212 381 281 387\n"" 1515 131 281 82 387\n"" 1516 281 351 82 387\n"" 1517 82 351 131 387\n"" 1518 313 148 323 240\n"" 1519 136 287 215 388\n"" 1520 215 352 136 388\n"" 1521 136 352 54 388\n"" 1522 54 138 136 388\n"" 1523 54 218 138 388\n"" 1524 138 218 136 388\n"" 1525 283 353 142 389\n"" 1526 190 378 118 389\n"" 1527 324 340 270 389\n"" 1528 270 340 118 389\n"" 1529 378 386 213 389\n"" 1530 213 386 324 389\n"" 1531 132 386 353 389\n"" 1532 324 386 132 389\n"" 1533 118 378 213 389\n"" 1534 213 270 118 389\n"" 1535 213 324 270 389\n"" 1536 275 385 345 390\n"" 1537 345 385 109 390\n"" 1538 67 358 329 390\n"" 1539 329 358 274 390\n"" 1540 181 265 95 391\n"" 1541 99 265 181 391\n"" 1542 181 365 99 391\n"" 1543 178 265 99 391\n"" 1544 99 365 178 391\n"" 1545 233 364 310 393\n"" 1546 310 366 233 393\n"" 1547 304 363 233 393\n"" 1548 304 366 363 393\n"" 1549 233 366 304 393\n"" 1550 310 364 307 393\n"" 1551 308 363 176 393\n"" 1552 176 363 112 393\n"" 1553 312 313 262 393\n"" 1554 262 313 308 393\n"" 1555 144 310 307 393\n"" 1556 144 366 310 393\n"" 1557 307 366 144 393\n"" 1558 262 308 176 393\n"" 1559 112 262 176 393\n"" 1560 112 312 262 393\n"" 1561 223 341 274 397\n"" 1562 341 372 274 397\n"" 1563 223 396 341 397\n"" 1564 394 395 372 397\n"" 1565 394 396 395 397\n"" 1566 395 396 371 397\n"" 1567 371 396 293 397\n"" 1568 341 396 394 397\n"" 1569 341 394 20 397\n"" 1570 394 372 20 397\n"" 1571 20 372 341 397\n"" 1572 279 284 278 399\n"" 1573 279 354 284 399\n"" 1574 216 287 282 399\n"" 1575 215 287 216 399\n"" 1576 142 353 284 399\n"" 1577 284 354 142 399\n"" 1578 226 353 142 399\n"" 1579 142 388 226 399\n""# Generated by tetgen -a0.01 cube.smesh \n"); } diff --git a/Demos3/GpuDemos/shadows/ShadowMapDemo.cpp b/Demos3/GpuDemos/shadows/ShadowMapDemo.cpp deleted file mode 100644 index c831ed5d0..000000000 --- a/Demos3/GpuDemos/shadows/ShadowMapDemo.cpp +++ /dev/null @@ -1,310 +0,0 @@ -#if 0 -#include "ShadowMapDemo.h" -#include "ShadowMapDemoInternalData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GLPrimitiveRenderer.h" - -#include "OpenGLWindow/ShapeData.h" -#include "Bullet3Common/b3Quaternion.h" -#include - -ShadowMapDemo::ShadowMapDemo() -{ - m_shadowData = new ShadowMapDemoInternalData; -} - -ShadowMapDemo::~ShadowMapDemo() -{ - delete m_shadowData; -} - - -void ShadowMapDemo::initPhysics(const ConstructionInfo& ci) -{ - m_shadowData->m_instancingRenderer = ci.m_instancingRenderer; - m_shadowData->m_primitiveRenderer = ci.m_primRenderer; - - float pos[4]={0,3,0,0}; - float orn[4]={0,0,0,1}; - float color[4]={1,0,0,1}; - float scaling[4]={1,1,1,1}; - if (1) - { - ///create a sphere - int sphereShape = registerGraphicsSphereShape(ci,0.1,false); - ci.m_instancingRenderer->registerGraphicsInstance(sphereShape,pos,orn,color,scaling); - } - if (1) - { - //create a cube - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_vertices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - int boxShape = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - pos[1]=0.f; - scaling[0]=scaling[2]=50.f; - color[0]=1.f; - color[1]=1.f; - color[2]=1.f; - color[3]=1.f; - ci.m_instancingRenderer->registerGraphicsInstance(boxShape ,pos,orn,color,scaling); - } - - b3Vector3 shift(0,0,0); - if (0) - { - b3Vector3 scaling(1,1,1); - const char* filename="data/room_thickwalls.obj"; - this->createConcaveMesh(ci,filename,shift,scaling); - } - - { - b3Vector3 camPos(0, 2,5); - m_shadowData->m_instancingRenderer->setCameraTargetPosition(camPos); - m_shadowData->m_instancingRenderer->setCameraPitch(0); - m_shadowData->m_instancingRenderer->setCameraYaw(0); - - m_shadowData->m_instancingRenderer->setCameraDistance(15); - } - //m_shadowData->m_instancingRenderer->setCameraYaw(55); - ci.m_instancingRenderer->writeTransforms(); -} - -void ShadowMapDemo::exitPhysics() -{ -} - - -void ShadowMapDemo::clientMoveAndDisplay() -{ -} - -#include"../../Wavefront/objLoader.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" - -static GLInstanceGraphicsShape* createGraphicsShapeFromWavefrontObj(objLoader* obj) -{ - b3AlignedObjectArray* vertices = new b3AlignedObjectArray; - { -// int numVertices = obj->vertexCount; - // int numIndices = 0; - b3AlignedObjectArray* indicesPtr = new b3AlignedObjectArray; - /* - for (int v=0;vvertexCount;v++) - { - vtx.xyzw[0] = obj->vertexList[v]->e[0]; - vtx.xyzw[1] = obj->vertexList[v]->e[1]; - vtx.xyzw[2] = obj->vertexList[v]->e[2]; - b3Vector3 n(vtx.xyzw[0],vtx.xyzw[1],vtx.xyzw[2]); - if (n.length2()>B3_EPSILON) - { - n.normalize(); - vtx.normal[0] = n[0]; - vtx.normal[1] = n[1]; - vtx.normal[2] = n[2]; - - } else - { - vtx.normal[0] = 0; //todo - vtx.normal[1] = 1; - vtx.normal[2] = 0; - } - vtx.uv[0] = 0.5f;vtx.uv[1] = 0.5f; //todo - vertices->push_back(vtx); - } - */ - - for (int f=0;ffaceCount;f++) - { - obj_face* face = obj->faceList[f]; - //b3Vector3 normal(face.m_plane[0],face.m_plane[1],face.m_plane[2]); - if (face->vertex_count>=3) - { - b3Vector3 normal(0,1,0); - int vtxBaseIndex = vertices->size(); - - if (face->vertex_count<=4) - { - indicesPtr->push_back(vtxBaseIndex); - indicesPtr->push_back(vtxBaseIndex+1); - indicesPtr->push_back(vtxBaseIndex+2); - - GLInstanceVertex vtx0; - vtx0.xyzw[0] = obj->vertexList[face->vertex_index[0]]->e[0]; - vtx0.xyzw[1] = obj->vertexList[face->vertex_index[0]]->e[1]; - vtx0.xyzw[2] = obj->vertexList[face->vertex_index[0]]->e[2]; - vtx0.xyzw[3] = 0.f;//obj->vertexList[face->vertex_index[0]]->e[2]; - - vtx0.uv[0] = 0.5f;//obj->textureList[face->vertex_index[0]]->e[0]; - vtx0.uv[1] = 0.5f;//obj->textureList[face->vertex_index[0]]->e[1]; - - GLInstanceVertex vtx1; - vtx1.xyzw[0] = obj->vertexList[face->vertex_index[1]]->e[0]; - vtx1.xyzw[1] = obj->vertexList[face->vertex_index[1]]->e[1]; - vtx1.xyzw[2] = obj->vertexList[face->vertex_index[1]]->e[2]; - vtx1.xyzw[3]= 0.f; - vtx1.uv[0] = 0.5f;//obj->textureList[face->vertex_index[1]]->e[0]; - vtx1.uv[1] = 0.5f;//obj->textureList[face->vertex_index[1]]->e[1]; - - GLInstanceVertex vtx2; - vtx2.xyzw[0] = obj->vertexList[face->vertex_index[2]]->e[0]; - vtx2.xyzw[1] = obj->vertexList[face->vertex_index[2]]->e[1]; - vtx2.xyzw[2] = obj->vertexList[face->vertex_index[2]]->e[2]; - vtx2.xyzw[3] = 0.f; - vtx2.uv[0] = 0.5f;obj->textureList[face->vertex_index[2]]->e[0]; - vtx2.uv[1] = 0.5f;obj->textureList[face->vertex_index[2]]->e[1]; - - - b3Vector3 v0(vtx0.xyzw[0],vtx0.xyzw[1],vtx0.xyzw[2]); - b3Vector3 v1(vtx1.xyzw[0],vtx1.xyzw[1],vtx1.xyzw[2]); - b3Vector3 v2(vtx2.xyzw[0],vtx2.xyzw[1],vtx2.xyzw[2]); - - normal = (v1-v0).cross(v2-v0); - normal.normalize(); - vtx0.normal[0] = normal[0]; - vtx0.normal[1] = normal[1]; - vtx0.normal[2] = normal[2]; - vtx1.normal[0] = normal[0]; - vtx1.normal[1] = normal[1]; - vtx1.normal[2] = normal[2]; - vtx2.normal[0] = normal[0]; - vtx2.normal[1] = normal[1]; - vtx2.normal[2] = normal[2]; - vertices->push_back(vtx0); - vertices->push_back(vtx1); - vertices->push_back(vtx2); - } - if (face->vertex_count==4) - { - - indicesPtr->push_back(vtxBaseIndex); - indicesPtr->push_back(vtxBaseIndex+1); - indicesPtr->push_back(vtxBaseIndex+2); - indicesPtr->push_back(vtxBaseIndex+3); -// - GLInstanceVertex vtx3; - vtx3.xyzw[0] = obj->vertexList[face->vertex_index[3]]->e[0]; - vtx3.xyzw[1] = obj->vertexList[face->vertex_index[3]]->e[1]; - vtx3.xyzw[2] = obj->vertexList[face->vertex_index[3]]->e[2]; - vtx3.uv[0] = 0.5; - vtx3.uv[1] = 0.5; - - vtx3.normal[0] = normal[0]; - vtx3.normal[1] = normal[1]; - vtx3.normal[2] = normal[2]; - - vertices->push_back(vtx3); - - } - } - } - - - GLInstanceGraphicsShape* gfxShape = new GLInstanceGraphicsShape; - gfxShape->m_vertices = vertices; - gfxShape->m_numvertices = vertices->size(); - gfxShape->m_indices = indicesPtr; - gfxShape->m_numIndices = indicesPtr->size(); - for (int i=0;i<4;i++) - gfxShape->m_scaling[i] = 1;//bake the scaling into the vertices - return gfxShape; - } -} - - -void ShadowMapDemo::createConcaveMesh(const ConstructionInfo& ci, const char* fileName, const b3Vector3& shift, const b3Vector3& scaling) -{ - objLoader* objData = new objLoader(); - - FILE* f = 0; - - char relativeFileName[1024]; - { - const char* prefix[]={"./","../","../../","../../../","../../../../"}; - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;iload(relativeFileName); - int index=10; - - { - GLInstanceGraphicsShape* shape = createGraphicsShapeFromWavefrontObj(objData); - - - b3AlignedObjectArray verts; - for (int i=0;im_numvertices;i++) - { - for (int j=0;j<3;j++) - shape->m_vertices->at(i).xyzw[j] += shift[j]; - - b3Vector3 vtx(shape->m_vertices->at(i).xyzw[0], - shape->m_vertices->at(i).xyzw[1], - shape->m_vertices->at(i).xyzw[2]); - verts.push_back(vtx*scaling); - } - - - { - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - //int shapeId = ci.m_instancingRenderer->registerShape(&cube_vertices[0],numVertices,cube_indices,numIndices); - - - int shapeId = ci.m_instancingRenderer->registerShape(&shape->m_vertices->at(0).xyzw[0], shape->m_numvertices, &shape->m_indices->at(0), shape->m_numIndices); - b3Quaternion orn(0,0,0,1); - - b3Vector4 color(0.3,0.3,1,1.f);//0.5);//1.f - - - { - float mass = 0.f; - b3Vector3 position(0,0,0); - int id = ci.m_instancingRenderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - index++; - } - } - } - delete objData; -} - - - - -void ShadowMapDemo::renderScene() -{ - float color[4]={1,1,1,1}; - m_shadowData->m_instancingRenderer->renderScene(); - - m_shadowData->m_instancingRenderer->enableShadowMap(); - glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_NONE ); -// glTexParameteri( GL_TEXTURE_2D, GL_DEPTH_TEXTURE_MODE, GL_LUMINANCE ); - m_shadowData->m_primitiveRenderer->drawTexturedRect(10,10,90,90,color,0,0,1,1,true); - glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_COMPARE_REF_TO_TEXTURE); - - -} -#endif - - diff --git a/Demos3/GpuDemos/shadows/ShadowMapDemo.h b/Demos3/GpuDemos/shadows/ShadowMapDemo.h deleted file mode 100644 index 891005625..000000000 --- a/Demos3/GpuDemos/shadows/ShadowMapDemo.h +++ /dev/null @@ -1,40 +0,0 @@ -#ifndef SHADOW_MAP_DEMO_H -#define SHADOW_MAP_DEMO_H - -#include "../GpuDemo.h" -#include "Bullet3Common/b3Vector3.h" - -class ShadowMapDemo : public GpuDemo -{ - struct ShadowMapDemoInternalData* m_shadowData; - -public: - - ShadowMapDemo(); - virtual ~ShadowMapDemo(); - - virtual const char* getName() - { - return "ShadowMapDemo"; - } - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void exitPhysics(); - - virtual void renderScene(); - - void createConcaveMesh(const ConstructionInfo& ci, const char* fileName, const b3Vector3& shift, const b3Vector3& scaling); - - - virtual void clientMoveAndDisplay(); - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new ShadowMapDemo; - return demo; - } - -}; - -#endif //SHADOW_MAP_DEMO_H diff --git a/Demos3/GpuDemos/shadows/ShadowMapDemoInternalData.h b/Demos3/GpuDemos/shadows/ShadowMapDemoInternalData.h deleted file mode 100644 index d019bcb3b..000000000 --- a/Demos3/GpuDemos/shadows/ShadowMapDemoInternalData.h +++ /dev/null @@ -1,13 +0,0 @@ -#ifndef SHADOW_MAP_INTERNAL_DATA_H -#define SHADOW_MAP_INTERNAL_DATA_H - - -struct ShadowMapDemoInternalData -{ - class GLInstancingRenderer* m_instancingRenderer; - class GLPrimitiveRenderer* m_primitiveRenderer; - -}; - -#endif //SHADOW_MAP_INTERNAL_DATA_H - diff --git a/Demos3/GpuDemos/softbody/GpuSoftBodyDemo.cpp b/Demos3/GpuDemos/softbody/GpuSoftBodyDemo.cpp deleted file mode 100644 index 3eb54ceaf..000000000 --- a/Demos3/GpuDemos/softbody/GpuSoftBodyDemo.cpp +++ /dev/null @@ -1,419 +0,0 @@ - -#include "GpuSoftBodyDemo.h" -#define USE_BARREL_VERTICES -#include "OpenGLWindow/ShapeData.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "Bullet3Common/b3Quaternion.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "Bullet3OpenCL/BroadphaseCollision/b3GpuSapBroadphase.h" -#include "../GpuDemoInternalData.h" -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include "OpenGLWindow/GLInstanceRendererInternalData.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3LauncherCL.h" -#include "Bullet3OpenCL/RigidBody/b3GpuRigidBodyPipeline.h" -#include "Bullet3OpenCL/RigidBody/b3GpuNarrowPhase.h" -#include "Bullet3Collision/NarrowPhaseCollision/b3Config.h" -#include "GpuSoftBodyDemoInternalData.h" -#include "Bullet3Collision/BroadPhaseCollision/b3DynamicBvhBroadphase.h" - - -static b3KeyboardCallback oldCallback = 0; -extern bool gReset; - -#define MSTRINGIFY(A) #A - -static const char* s_rigidBodyKernelString = MSTRINGIFY( - -typedef struct -{ - float4 m_pos; - float4 m_quat; - float4 m_linVel; - float4 m_angVel; - unsigned int m_collidableIdx; - float m_invMass; - float m_restituitionCoeff; - float m_frictionCoeff; -} Body; - -__kernel void - copyTransformsToVBOKernel( __global Body* gBodies, __global float4* posOrnColor, const int numNodes) -{ - int nodeID = get_global_id(0); - if( nodeID < numNodes ) - { - posOrnColor[nodeID] = (float4) (gBodies[nodeID].m_pos.xyz,1.0); - posOrnColor[nodeID + numNodes] = gBodies[nodeID].m_quat; - } -} -); - - - - - -GpuSoftBodyDemo::GpuSoftBodyDemo() -:m_instancingRenderer(0), -m_window(0) -{ - m_data = new GpuSoftBodyDemoInternalData; -} -GpuSoftBodyDemo::~GpuSoftBodyDemo() -{ - - delete m_data; -} - - - - - - - -static void PairKeyboardCallback(int key, int state) -{ - if (key=='R' && state) - { - gReset = true; - } - - //b3DefaultKeyboardCallback(key,state); - oldCallback(key,state); -} - -void GpuSoftBodyDemo::setupScene(const ConstructionInfo& ci) -{ - -} - -void GpuSoftBodyDemo::initPhysics(const ConstructionInfo& ci) -{ - - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - if (ci.m_window) - { - m_window = ci.m_window; - oldCallback = ci.m_window->getKeyboardCallback(); - ci.m_window->setKeyboardCallback(PairKeyboardCallback); - - } - - m_instancingRenderer = ci.m_instancingRenderer; - - initCL(ci.preferredOpenCLDeviceIndex,ci.preferredOpenCLPlatformIndex); - - if (m_clData->m_clContext) - { - int errNum=0; - - cl_program rbProg=0; - m_data->m_copyTransformsToVBOKernel = b3OpenCLUtils::compileCLKernelFromString(m_clData->m_clContext,m_clData->m_clDevice,s_rigidBodyKernelString,"copyTransformsToVBOKernel",&errNum,rbProg); - - b3Config config; - b3GpuNarrowPhase* np = new b3GpuNarrowPhase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue,config); - b3GpuSapBroadphase* bp = new b3GpuSapBroadphase(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue); - m_data->m_np = np; - m_data->m_bp = bp; - b3DynamicBvhBroadphase* broadphaseDbvt = new b3DynamicBvhBroadphase(config.m_maxConvexBodies); - - m_data->m_rigidBodyPipeline = new b3GpuRigidBodyPipeline(m_clData->m_clContext,m_clData->m_clDevice,m_clData->m_clQueue, np, bp,broadphaseDbvt,config); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - - setupScene(ci); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - m_data->m_rigidBodyPipeline->writeAllInstancesToGpu(); - np->writeAllBodiesToGpu(); - bp->writeAabbsToGpu(); - - } - - - m_instancingRenderer->writeTransforms(); - - - -} - -void GpuSoftBodyDemo::exitPhysics() -{ - delete m_data->m_instancePosOrnColor; - delete m_data->m_rigidBodyPipeline; - - m_window->setKeyboardCallback(oldCallback); - - delete m_data->m_np; - m_data->m_np = 0; - delete m_data->m_bp; - m_data->m_bp = 0; - - exitCL(); -} - - - -struct GraphicsVertex -{ - float pos[4]; - float normal[3]; - float texcoord[2]; -}; - -void GpuSoftClothDemo::renderScene() -{ - if (m_data->m_clothShapeIndex>=0 && m_data->m_clothVertices) - { - GraphicsVertex* cpu_buffer = (GraphicsVertex*)m_data->m_clothVertices; - int width = 256; - int height=256; - static float shift = 0.f; - shift+=0.01; - if (shift>B3_2_PI) - shift-=B3_2_PI; - - int numVertices = 0; - // Initial test data for rendering - for(int y = 0; y < height; y++) - { - for(int x = 0; x < width; x++) - { - - double coord = b3Sin(x/5.0+shift)*0.01; - //coord = sin(y/); - - cpu_buffer[y*width+x].pos[0] = (x/((float)(width-1)))*1; - cpu_buffer[y*width+x].pos[1] = coord; - cpu_buffer[y*width+x].pos[2] = (y/((float)(height-1)))*1; - cpu_buffer[y*width+x].pos[3] = 0.f; - - cpu_buffer[y*width+x].normal[0] = 1; - cpu_buffer[y*width+x].normal[1] = 0; - cpu_buffer[y*width+x].normal[2] = 0; - cpu_buffer[y*width+x].texcoord[0] = 1*x/((float)(width-1)); - cpu_buffer[y*width+x].texcoord[1] = (1.f-4*y/((float)(height-1))); - numVertices++; - } - } - - m_instancingRenderer->updateShape(m_data->m_clothShapeIndex,m_data->m_clothVertices); - } - m_instancingRenderer->renderScene(); - -} -void GpuSoftBodyDemo::renderScene() -{ - m_instancingRenderer->renderScene(); -} - -void GpuSoftBodyDemo::clientMoveAndDisplay() -{ - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - bool animate=true; - int numObjects= m_data->m_rigidBodyPipeline->getNumBodies(); -//m_instancingRenderer->getInternalData()->m_totalNumInstances; - b3Vector4* positions = 0; - if (animate && numObjects) - { - B3_PROFILE("gl2cl"); - - if (!m_data->m_instancePosOrnColor) - { - GLuint vbo = m_instancingRenderer->getInternalData()->m_vbo; - int arraySizeInBytes = numObjects * (3)*sizeof(b3Vector4); - glBindBuffer(GL_ARRAY_BUFFER, vbo); - cl_bool blocking= CL_TRUE; - positions= (b3Vector4*)glMapBufferRange( GL_ARRAY_BUFFER,m_instancingRenderer->getMaxShapeCapacity(),arraySizeInBytes, GL_MAP_READ_BIT );//GL_READ_WRITE);//GL_WRITE_ONLY - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - m_data->m_instancePosOrnColor = new b3OpenCLArray(m_clData->m_clContext,m_clData->m_clQueue); - m_data->m_instancePosOrnColor->resize(3*numObjects); - m_data->m_instancePosOrnColor->copyFromHostPointer(positions,3*numObjects,0); - glUnmapBuffer( GL_ARRAY_BUFFER); - err = glGetError(); - assert(err==GL_NO_ERROR); - } - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - { - B3_PROFILE("stepSimulation"); - m_data->m_rigidBodyPipeline->stepSimulation(1./60.f); - } - - if (numObjects) - { - B3_PROFILE("cl2gl_convert"); - int ciErrNum = 0; - cl_mem bodies = m_data->m_rigidBodyPipeline->getBodyBuffer(); - b3LauncherCL launch(m_clData->m_clQueue,m_data->m_copyTransformsToVBOKernel,"m_copyTransformsToVBOKernel"); - launch.setBuffer(bodies); - launch.setBuffer(m_data->m_instancePosOrnColor->getBufferCL()); - launch.setConst(numObjects); - launch.launch1D(numObjects); - oclCHECKERROR(ciErrNum, CL_SUCCESS); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (animate && numObjects) - { - B3_PROFILE("cl2gl_upload"); - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - GLuint vbo = m_instancingRenderer->getInternalData()->m_vbo; - int arraySizeInBytes = numObjects * (3)*sizeof(b3Vector4); - glBindBuffer(GL_ARRAY_BUFFER, vbo); - cl_bool blocking= CL_TRUE; - positions= (b3Vector4*)glMapBufferRange( GL_ARRAY_BUFFER,m_instancingRenderer->getMaxShapeCapacity(),arraySizeInBytes, GL_MAP_WRITE_BIT );//GL_READ_WRITE);//GL_WRITE_ONLY - err = glGetError(); - assert(err==GL_NO_ERROR); - m_data->m_instancePosOrnColor->copyToHostPointer(positions,3*numObjects,0); - glUnmapBuffer( GL_ARRAY_BUFFER); - err = glGetError(); - assert(err==GL_NO_ERROR); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - -} - - -GpuSoftClothDemo::GpuSoftClothDemo() -{ -} -GpuSoftClothDemo::~GpuSoftClothDemo() -{ -} - - - -void GpuSoftClothDemo::setupScene(const ConstructionInfo& ci) -{ - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - - int width = 256; - int height = 256; - - GraphicsVertex* cpu_buffer = new GraphicsVertex[width*height]; - memset(cpu_buffer, 0, width*height*sizeof(GraphicsVertex)); - - - int numVertices = 0; - // Initial test data for rendering - for(int y = 0; y < height; y++) - { - for(int x = 0; x < width; x++) - { - double coord = b3Sin(x/5.0)*0.01; - //coord = sin(y/); - - cpu_buffer[y*width+x].pos[0] = (x/((float)(width-1)))*1; - cpu_buffer[y*width+x].pos[1] = coord; - cpu_buffer[y*width+x].pos[2] = (y/((float)(height-1)))*1; - cpu_buffer[y*width+x].pos[3] = 0.f; - - cpu_buffer[y*width+x].normal[0] = 1; - cpu_buffer[y*width+x].normal[1] = 0; - cpu_buffer[y*width+x].normal[2] = 0; - cpu_buffer[y*width+x].texcoord[0] = 1*x/((float)(width-1)); - cpu_buffer[y*width+x].texcoord[1] = (1.f-4*y/((float)(height-1))); - numVertices++; - } - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - int numIndices = 0; - - // Generate and fill index array for rendering - int* indices = new int[width*3*2+2 + height*width*3*2]; - - for(int y = 0; y < height-1; y++) - { - for(int x = 0; x < width-1; x++) - { - // *3 indices/triangle, *2 triangles/quad - int baseIndex = (x + y*(width-1))*3*2; - indices[baseIndex] = x + y*width; - indices[baseIndex+1] = x+1 + y*width; - indices[baseIndex+2] = x+width + y*width; - - - indices[baseIndex+3] = x + 1 + y*width; - indices[baseIndex+4] = x+(width+1) + y*width; - indices[baseIndex+5] = x+width + y*width; - numIndices++; - } - } - - - int num_barrel_vertices = sizeof(barrel_vertices)/(9*sizeof(float)); - int num_barrel_indices = sizeof(barrel_indices)/sizeof(int); - - int textureIndex = -1; - { - int width,height,n; - - const char* filename = "data/bullet_logo.png"; - const unsigned char* image=0; - - const char* prefix[]={"./","../","../../","../../../","../../../../"}; - int numprefix = sizeof(prefix)/sizeof(const char*); - - for (int i=0;!image && iregisterTexture(image,width,height); - } - } -// int shapeIndex = ci.m_instancingRenderer->registerShape(barrel_vertices,num_barrel_vertices,barrel_indices,num_barrel_indices); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - m_data->m_clothVertices = &cpu_buffer[0].pos[0]; - - int shapeIndex = ci.m_instancingRenderer->registerShape(&cpu_buffer[0].pos[0],numVertices,indices,numIndices,B3_GL_TRIANGLES,textureIndex); - m_data->m_clothShapeIndex = shapeIndex; - - err = glGetError(); - assert(err==GL_NO_ERROR); - - - float pos[4] = {0,0,0,0}; - float orn[4] = {0,0,0,1}; - float color[4] = {1,1,1,1}; - float scaling[4] = {10,10,10,1}; - - ci.m_instancingRenderer->registerGraphicsInstance(shapeIndex,pos,orn,color,scaling); - ci.m_instancingRenderer->setCameraDistance(4); - ci.m_instancingRenderer->setCameraTargetPosition(pos); - - err = glGetError(); - assert(err==GL_NO_ERROR); - -} diff --git a/Demos3/GpuDemos/softbody/GpuSoftBodyDemo.h b/Demos3/GpuDemos/softbody/GpuSoftBodyDemo.h deleted file mode 100644 index 4d26c39c5..000000000 --- a/Demos3/GpuDemos/softbody/GpuSoftBodyDemo.h +++ /dev/null @@ -1,70 +0,0 @@ -#ifndef GPU_SOFT_BODY_DEMO_H -#define GPU_SOFT_BODY_DEMO_H - -#include "../GpuDemo.h" - -class GpuSoftBodyDemo : public GpuDemo -{ -protected: - class GLInstancingRenderer* m_instancingRenderer; - class b3gWindowInterface* m_window; - - struct GpuSoftBodyDemoInternalData* m_data; - -public: - - GpuSoftBodyDemo(); - virtual ~GpuSoftBodyDemo(); - - virtual void initPhysics(const ConstructionInfo& ci); - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void destroyScene(){}; - - virtual void exitPhysics(); - - virtual const char* getName() - { - return "GPUSOFT"; - } - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuSoftBodyDemo; - return demo; - } - - virtual void renderScene(); - - virtual void clientMoveAndDisplay(); - - -}; - -class GpuSoftClothDemo : public GpuSoftBodyDemo -{ - - public: - GpuSoftClothDemo(); - virtual ~GpuSoftClothDemo(); - - - virtual void setupScene(const ConstructionInfo& ci); - - virtual void renderScene(); - - virtual const char* getName() - { - return "GpuSoftCloth"; - } - - static GpuDemo* MyCreateFunc() - { - GpuDemo* demo = new GpuSoftClothDemo; - return demo; - } - -}; - -#endif //GPU_SOFT_BODY_DEMO_H - diff --git a/Demos3/GpuDemos/softbody/GpuSoftBodyDemoInternalData.h b/Demos3/GpuDemos/softbody/GpuSoftBodyDemoInternalData.h deleted file mode 100644 index a5cc563b6..000000000 --- a/Demos3/GpuDemos/softbody/GpuSoftBodyDemoInternalData.h +++ /dev/null @@ -1,34 +0,0 @@ -#ifndef GPU_SOFTBODY_INTERNAL_DATA_H -#define GPU_SOFTBODY_INTERNAL_DATA_H - -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" -#include "Bullet3OpenCL/ParallelPrimitives/b3OpenCLArray.h" -#include "Bullet3Common/b3Vector3.h" - -struct GpuSoftBodyDemoInternalData -{ - - cl_kernel m_copyTransformsToVBOKernel; - - b3OpenCLArray* m_instancePosOrnColor; - - class b3GpuRigidBodyPipeline* m_rigidBodyPipeline; - - class b3GpuNarrowPhase* m_np; - class b3GpuSapBroadphase* m_bp; - int m_clothShapeIndex; - float* m_clothVertices; - - GpuSoftBodyDemoInternalData() - :m_instancePosOrnColor(0), - m_copyTransformsToVBOKernel(0), m_rigidBodyPipeline(0), - m_np(0), - m_bp(0), - m_clothShapeIndex(-1), - m_clothVertices(0) - { - } -}; - -#endif//GPU_SOFTBODY_INTERNAL_DATA_H - diff --git a/Demos3/GpuGuiInitialize/main.cpp b/Demos3/GpuGuiInitialize/main.cpp deleted file mode 100644 index 30a4c7289..000000000 --- a/Demos3/GpuGuiInitialize/main.cpp +++ /dev/null @@ -1,547 +0,0 @@ - - -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#elif defined _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#elif defined __linux -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif - -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -//#include "OpenGL3CoreRenderer.h" -//#include "b3GpuDynamicsWorld.h" -#include -#include -#include "OpenGLWindow/fontstash.h" -#include "OpenGLWindow/opengl_fontstashcallbacks.h" - -#include "OpenGLWindow/GwenOpenGL3CoreRenderer.h" -#include "../btgui/Bullet3AppSupport/b3Quickprof.h" - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Skins/Simple.h" -#include "Gwen/Renderers/OpenGL_DebugFont.h" -#include "Gwen/Controls/MenuStrip.h" -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/ListBox.h" -#include "Gwen/Controls/VerticalSlider.h" -#include "Gwen/Controls/HorizontalSlider.h" -#include "Gwen/Controls/GroupBox.h" -#include "Gwen/Controls/CheckBox.h" -#include "Gwen/Controls/TreeControl.h" - -b3gDefaultOpenGLWindow* window=0; - -GLPrimitiveRenderer* primRenderer = 0; -GwenOpenGL3CoreRenderer* pRenderer = 0; - -Gwen::Skin::Simple skin; -Gwen::Controls::Canvas* pCanvas =0; -class MyProfileWindow* prof = 0; - -int sGlutScreenWidth = 640; -int sGlutScreenHeight = 480; -int sLastmousepos[2] = {0,0}; - -#include "Bullet3OpenCL/Initialize/b3OpenCLUtils.h" - -cl_context g_cxMainContext; -cl_command_queue g_cqCommandQue; - - - -int droidRegular=0;//, droidItalic, droidBold, droidJapanese, dejavu; -extern char OpenSansData[]; -sth_stash* stash=0; - -sth_stash* initFont(GLPrimitiveRenderer* primRender) -{ - GLint err; - - struct sth_stash* stash = 0; - int datasize; - - float sx,sy,dx,dy,lh; - GLuint texture; - - OpenGL2RenderCallbacks* renderCallbacks = new OpenGL2RenderCallbacks(primRender); - - stash = sth_create(512,512,renderCallbacks);//256,256);//,1024);//512,512); - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (!stash) - { - fprintf(stderr, "Could not create stash.\n"); - return 0; - } - char* data2 = OpenSansData; - unsigned char* data = (unsigned char*) data2; - if (!(droidRegular = sth_add_font_from_memory(stash, data))) - { - b3Error("error!\n"); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - - return stash; -} - - - -class MyProfileWindow : public Gwen::Controls::WindowControl -{ - // Gwen::Controls::TabControl* m_TabControl; - Gwen::Controls::ListBox* m_TextOutput; - unsigned int m_iFrames; - float m_fLastSecond; - - Gwen::Controls::TreeNode* m_node; - Gwen::Controls::TreeControl* m_ctrl; - -protected: - - void onButtonA( Gwen::Controls::Base* pControl ) - { - // OpenTissue::glut::toggleIdle(); - } - - void SliderMoved(Gwen::Controls::Base* pControl ) - { - Gwen::Controls::Slider* pSlider = (Gwen::Controls::Slider*)pControl; - //this->m_app->scaleYoungModulus(pSlider->GetValue()); - // printf("Slider Value: %.2f", pSlider->GetValue() ); - } - - - void OnCheckChangedStiffnessWarping (Gwen::Controls::Base* pControl) - { - Gwen::Controls::CheckBox* labeled = (Gwen::Controls::CheckBox* )pControl; - bool checked = labeled->IsChecked(); - //m_app->m_stiffness_warp_on = checked; - } -public: - - void MenuItemSelect(Gwen::Controls::Base* pControl) - { - if (Hidden()) - { - SetHidden(false); - } else - { - SetHidden(true); - } - } - - - MyProfileWindow ( Gwen::Controls::Base* pParent) - : Gwen::Controls::WindowControl( pParent ) - { - - SetTitle( L"OpenCL info" ); - - SetSize( 550, 350 ); - this->SetPos(0,40); - -// this->Dock( Gwen::Pos::Bottom); - - - - { - m_ctrl = new Gwen::Controls::TreeControl( this ); - - int numPlatforms = b3OpenCLUtils::getNumPlatforms(); - for (int i=0;iAddNode(txt); - int numDev = b3OpenCLUtils::getNumDevices(context); - for (int j=0;jAddNode( txt ); - - cl_device_id device = b3OpenCLUtils::getDevice(context,j); - b3OpenCLDeviceInfo info; - b3OpenCLUtils::getDeviceInfo(device,&info); - - Gwen::Controls::TreeNode* node; - Gwen::UnicodeString strIn; - - - switch (info.m_deviceType) - { - case CL_DEVICE_TYPE_CPU: - { - txt = Gwen::Utility::Format( L"CL_DEVICE_TYPE_CPU"); - node = deviceNode->AddNode( txt ); - break; - } - case CL_DEVICE_TYPE_GPU: - { - txt = Gwen::Utility::Format( L"CL_DEVICE_TYPE_GPU"); - node = deviceNode->AddNode( txt ); - break; - } - case CL_DEVICE_TYPE_ACCELERATOR: - { - txt = Gwen::Utility::Format( L"CL_DEVICE_TYPE_ACCELERATOR"); - node = deviceNode->AddNode( txt ); - break; - } - - - default: - { - txt = Gwen::Utility::Format( L"Unknown device type"); - node = deviceNode->AddNode( txt ); - } - } - - strIn = Gwen::Utility::StringToUnicode(info.m_deviceName); - txt = Gwen::Utility::Format( L"CL_DEVICE_NAME: ")+strIn; - node = deviceNode->AddNode( txt ); - - strIn = Gwen::Utility::StringToUnicode(info.m_deviceVendor); - txt = Gwen::Utility::Format( L"CL_DEVICE_VENDOR: ")+strIn; - node = deviceNode->AddNode( txt ); - - strIn = Gwen::Utility::StringToUnicode(info.m_driverVersion); - txt = Gwen::Utility::Format( L"CL_DRIVER_VERSION: ")+strIn; - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_COMPUTE_UNITS:%u",info.m_computeUnits); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_WORK_ITEM_DIMENSIONS:%u",info.m_workitemDims); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_WORK_ITEM_SIZES:%u / %u / %u",info.m_workItemSize[0], info.m_workItemSize[1], info.m_workItemSize[2]); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_WORK_GROUP_SIZE:%u",info.m_workgroupSize); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_CLOCK_FREQUENCY:%u MHz",info.m_clockFrequency); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_ADDRESS_BITS:%u",info.m_addressBits); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_MEM_ALLOC_SIZE:%u MByte",(unsigned int)(info.m_maxMemAllocSize/ (1024 * 1024))); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_GLOBAL_MEM_SIZE:%u MByte",(unsigned int)(info.m_globalMemSize/ (1024 * 1024))); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_ERROR_CORRECTION_SUPPORT:%s",info.m_errorCorrectionSupport== CL_TRUE ? L"yes" : L"no"); - node = deviceNode->AddNode( txt ); - - - txt = Gwen::Utility::Format( L"CL_DEVICE_LOCAL_MEM_TYPE:%s",info.m_localMemType == 1 ? L"local" : L"global"); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_LOCAL_MEM_SIZE:%u KByte",(unsigned int)(info.m_localMemSize / 1024)); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_CONSTANT_BUFFER_SIZE:%u KByte",(unsigned int)(info.m_constantBufferSize / 1024)); - node = deviceNode->AddNode( txt ); - - if( info.m_queueProperties & CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE ) - { - txt = Gwen::Utility::Format( L"CL_DEVICE_QUEUE_PROPERTIES:\tCL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE"); - node = deviceNode->AddNode( txt ); - } - if( info.m_queueProperties & CL_QUEUE_PROFILING_ENABLE ) - { - txt = Gwen::Utility::Format( L"CL_DEVICE_QUEUE_PROPERTIES:\tCL_QUEUE_PROFILING_ENABLE"); - node = deviceNode->AddNode( txt ); - } - - txt = Gwen::Utility::Format( L"CL_DEVICE_IMAGE_SUPPORT:%u",info.m_imageSupport); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_READ_IMAGE_ARGS:%u",info.m_maxReadImageArgs); - node = deviceNode->AddNode( txt ); - - - txt = Gwen::Utility::Format( L"CL_DEVICE_MAX_WRITE_IMAGE_ARGS:%u",info.m_maxWriteImageArgs); - node = deviceNode->AddNode( txt ); - - txt = Gwen::Utility::Format( L"CL_DEVICE_EXTENSIONS"); - Gwen::Controls::TreeNode* extensionNode = deviceNode->AddNode( txt ); - - if (info.m_deviceExtensions) - { - Gwen::Utility::Strings::List outbits; - - Gwen::String str(info.m_deviceExtensions); - - Gwen::String sep(" "); - Gwen::Utility::Strings::Split(str,sep, outbits); - - - - for (int k=0;kAddNode( txt ); - } - } - } - } -/* - - - - printf("\n CL_DEVICE_IMAGE "); - printf("\t2D_MAX_WIDTH %u\n", info.m_image2dMaxWidth); - printf("\t2D_MAX_HEIGHT %u\n", info.m_image2dMaxHeight); - printf("\t3D_MAX_WIDTH %u\n", info.m_image3dMaxWidth); - printf("\t3D_MAX_HEIGHT %u\n", info.m_image3dMaxHeight); - printf("\t3D_MAX_DEPTH %u\n", info.m_image3dMaxDepth); - - printf(" CL_DEVICE_PREFERRED_VECTOR_WIDTH_"); - printf("CHAR %u, SHORT %u, INT %u,LONG %u, FLOAT %u, DOUBLE %u\n\n\n", - info.m_vecWidthChar, info.m_vecWidthShort, info.m_vecWidthInt, info.m_vecWidthLong,info.m_vecWidthFloat, info.m_vecWidthDouble); -*/ - - } - } - - m_ctrl->ExpandAll(); - m_ctrl->SetBounds( this->GetInnerBounds().x,this->GetInnerBounds().y,this->GetInnerBounds().w,this->GetInnerBounds().h); - } - - } - - - - void UpdateText() - { - static bool update=true; - m_ctrl->SetBounds(0,0,this->GetInnerBounds().w,this->GetInnerBounds().h); - } - -}; - - -struct MyTestMenuBar : public Gwen::Controls::MenuStrip -{ - MyProfileWindow* m_profileWindow; - - void MenuItemSelect(Gwen::Controls::Base* pControl) - { - } - - MyTestMenuBar(Gwen::Controls::Base* pParent, MyProfileWindow* prof) - :Gwen::Controls::MenuStrip(pParent), - m_profileWindow(prof) - { - { - Gwen::Controls::MenuItem* pRoot = AddItem( L"File" ); - - pRoot = AddItem( L"View" ); - pRoot->GetMenu()->AddItem( L"Platforms",prof,(Gwen::Event::Handler::Function)&MyProfileWindow::MenuItemSelect); - - } - } - -}; - - -float retinaScale = 1.f; - -void setupGUI(int width, int height) -{ - - primRenderer = new GLPrimitiveRenderer(width,height); - stash = initFont(primRenderer); - pRenderer = new GwenOpenGL3CoreRenderer(primRenderer,stash,width,height,retinaScale); - - - - skin.SetRender( pRenderer ); - - pCanvas = new Gwen::Controls::Canvas( &skin ); - pCanvas->SetSize( width,height); - pCanvas->SetDrawBackground( false); - pCanvas->SetBackgroundColor( Gwen::Color( 150, 170, 170, 255 ) ); - - //MyWindow* window = new MyWindow(pCanvas); - prof = new MyProfileWindow(pCanvas); - prof->UpdateText(); - - MyTestMenuBar* menubar = new MyTestMenuBar(pCanvas, prof); - - - -} - - - -static void MyResizeCallback(float w, float h) -{ - sGlutScreenWidth = w; - sGlutScreenHeight = h; - if (pRenderer) - pRenderer->resize(w,h); - if (primRenderer) - primRenderer->setScreenSize(w,h); - if (pCanvas) - { - pCanvas->SetSize(w,h); - } -} - - - -static void MouseButtonCallback(int button, int state, float x, float y) -{ - if (pCanvas) - { - bool handled = false; - if (pCanvas) - { - handled = pCanvas->InputMouseMoved(x,y,x, y); - - if (button>=0) - { - handled = pCanvas->InputMouseButton(button,state); - if (handled) - { - //if (!state) - // return false; - } - } - } - - if (handled) - { - sLastmousepos[0] = x; - sLastmousepos[1] = y; - } else - { - b3DefaultMouseButtonCallback(button,state,x,y); - } - } - -} - - -static void MouseMoveCallback(float x,float y) -{ - - bool handled = false; - - static int m_lastmousepos[2] = {0,0}; - static bool isInitialized = false; - if (pCanvas) - { - if (!isInitialized) - { - isInitialized = true; - m_lastmousepos[0] = x+1; - m_lastmousepos[1] = y+1; - } - handled = pCanvas->InputMouseMoved(x,y,m_lastmousepos[0],m_lastmousepos[1]); - } -} - - - - -int main(int argc, char* argv[]) -{ - - window = new b3gDefaultOpenGLWindow(); - - b3gWindowConstructionInfo wci(sGlutScreenWidth,sGlutScreenHeight); - - window->createWindow(wci); - window->setResizeCallback(MyResizeCallback); - window->setMouseMoveCallback(MouseMoveCallback); - window->setMouseButtonCallback(MouseButtonCallback); - //window->setKeyboardCallback(MyKeyboardCallback); - - window->setWindowTitle("Bullet 3.x GPU Rigid Body http://bulletphysics.org"); - printf("-----------------------------------------------------\n"); - - -#ifndef __APPLE__ - glewInit(); -#endif - - - setupGUI(sGlutScreenWidth,sGlutScreenHeight); - - do - { - b3ProfileManager::Reset(); - b3ProfileManager::Increment_Frame_Counter(); - - - window->startRendering(); - - glClearColor(0.6,0.6,0.6,1); - glClear(GL_COLOR_BUFFER_BIT| GL_DEPTH_BUFFER_BIT|GL_STENCIL_BUFFER_BIT); - glEnable(GL_DEPTH_TEST); - - - - // demo->clientMoveAndDisplay(); - - //saveOpenGLState(sGlutScreenWidth,sGlutScreenHeight); - - { - B3_PROFILE("gui->draw"); - //gui->draw(g_OpenGLWidth,g_OpenGLHeight); - - { - B3_PROFILE("UpdateText"); - if (prof) - prof->UpdateText(); - } - { - B3_PROFILE("RenderCanvas"); - pCanvas->RenderCanvas(); - } - - //restoreOpenGLState(); - } - { - B3_PROFILE("window->endRendering"); - window->endRendering(); - } - - - - - b3ProfileManager::dumpAll(); - - - - } while (!window->requestedExit()); - - - - - return 0; -} diff --git a/Demos3/GpuGuiInitialize/premake4.lua b/Demos3/GpuGuiInitialize/premake4.lua deleted file mode 100644 index 61a09a3ab..000000000 --- a/Demos3/GpuGuiInitialize/premake4.lua +++ /dev/null @@ -1,92 +0,0 @@ -function createProject(vendor) - - hasCL = findOpenCL(vendor) - - if (hasCL) then - - project ("OpenCL_GUI_Intialize_" .. vendor) - - initOpenCL(vendor) - - language "C++" - - kind "ConsoleApp" - targetdir "../../bin" - - includedirs { - "..", - "../../opencl", - "../../btgui", - "../../src", - } - - links { - "gwen" - } - - initOpenGL() - initGlew() - - files { - "main.cpp", - "../../src/Bullet3OpenCL/Initialize/b3OpenCLUtils.cpp", - "../../src/Bullet3OpenCL/Initialize/b3OpenCLUtils.h", - "../../btgui/OpenGLWindow/GLInstancingRenderer.cpp", - "../../btgui/OpenGLWindow/GLInstancingRenderer.h", - "../../btgui/OpenGLWindow/GLRenderToTexture.cpp", - "../../btgui/OpenGLWindow/GLRenderToTexture.h", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.h", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.cpp", - "../../btgui/OpenGLWindow/LoadShader.cpp", - "../../btgui/OpenGLWindow/LoadShader.h", - "../../btgui/OpenGLWindow/TwFonts.cpp", - "../../btgui/OpenGLWindow/TwFonts.h", - "../../btgui/OpenGLWindow/GwenOpenGL3CoreRenderer.h", - "../../btgui/OpenGLWindow/OpenSans.cpp", - "../../btgui/OpenGLWindow/fontstash.cpp", - "../../btgui/OpenGLWindow/fontstash.h", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.h", - "../../src/Bullet3Geometry/b3ConvexHullComputer.cpp", - "../../src/Bullet3Geometry/b3ConvexHullComputer.h", - "../../src/Bullet3Common/b3AlignedAllocator.cpp", - "../../src/Bullet3Common/b3Logging.cpp", - "../../src/Bullet3Common/b3Logging.h", - "../../btgui/Bullet3AppSupport/b3Quickprof.cpp", - "../../btgui/Bullet3AppSupport/b3Quickprof.h", - "../../btgui/Bullet3AppSupport/b3Clock.cpp", - "../../btgui/Bullet3AppSupport/b3Clock.h", - - } - - if os.is("Windows") then - files{ - "../../btgui/OpenGLWindow/Win32OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/Win32OpenGLWindow.h", - "../../btgui/OpenGLWindow/Win32Window.cpp", - "../../btgui/OpenGLWindow/Win32Window.h", - } - end - if os.is("Linux") then - links {"X11","pthread"} - files { - "../../btgui/OpenGLWindow/X11OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/X11OpenGLWindows.h" - } - end - if os.is("MacOSX") then - links {"Cocoa.framework"} - files { - "../../btgui/OpenGLWindow/MacOpenGLWindow.h", - "../../btgui/OpenGLWindow/MacOpenGLWindow.mm", - } - end - - end -end - -createProject("clew") -createProject("Apple") -createProject("AMD") -createProject("Intel") -createProject("NVIDIA") diff --git a/Demos3/ImplicitCloth/main.cpp b/Demos3/ImplicitCloth/main.cpp deleted file mode 100644 index e51062816..000000000 --- a/Demos3/ImplicitCloth/main.cpp +++ /dev/null @@ -1,87 +0,0 @@ -#include "stan/vecmath.h" -#include "stan/Cloth.h" -#include "Bullet3Common/b3Vector3.h" -#include "../../btgui/OpenGLWindow/SimpleOpenGL3App.h" - -Cloth* cloth = 0; - -int numX = 60, numY=60; -const size_t total_points = (numX)*(numY); - -void drawCloth(class GLInstancingRenderer* renderer) -{ - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - - err = glGetError(); - assert(err==GL_NO_ERROR); - - b3AlignedObjectArray indices; - - for (int i=0;isprings.count;i++) - { - indices.push_back(cloth->springs[i].a); - indices.push_back(cloth->springs[i].b); - } - float lineColor[4]={0.4,0.4,1.0,1}; - renderer->drawLines(&cloth->X[0].x,lineColor,total_points,sizeof(float3),&indices[0],indices.size(),1); - err = glGetError(); - assert(err==GL_NO_ERROR); - float pointColor[4]={1,0.4,0.4,1}; - - glDisable(GL_DEPTH_TEST); - renderer->drawPoints(&cloth->X[0].x,pointColor,total_points,sizeof(float3),3); - glEnable(GL_DEPTH_TEST); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - -} - -int main(int argc, char* argv[]) -{ - float size=10; - cloth = ClothCreate(numX,numY,size); - - float dt = 1./120.f; - - SimpleOpenGL3App* app = new SimpleOpenGL3App("title",1024,768); - app->m_instancingRenderer->setCameraDistance(13); - app->m_instancingRenderer->setCameraPitch(0); - app->m_instancingRenderer->setCameraTargetPosition(b3MakeVector3(0,0,0)); - - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - do - { - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - app->m_instancingRenderer->init(); - app->m_instancingRenderer->updateCamera(); - - app->drawGrid(); - app->drawText("Cloth simulation using implicit integration, by Stan Melax",10,10); - cloth->Simulate(dt); - cloth->cloth_gravity.y = -9.8;//-9.8;//-9.8;//-9.8;//0;//-9.8;//0;//-9.8;//0;//-9.8; - cloth->cloth_gravity.z =-9.8;//0;//-9.8;//0;//-9.8; - - cloth->spring_struct=10000000.0f; - cloth->spring_shear=10000000.0f; - - //cloth->spring_struct=1000000.0f; - //cloth->spring_shear=1000000.0f; - - cloth->spring_damp = 0;//100; - - drawCloth(app->m_instancingRenderer); - - app->swapBuffer(); - } while (!app->m_window->requestedExit()); - - delete cloth; - delete app; - return 0; -} diff --git a/Demos3/ImplicitCloth/premake4.lua b/Demos3/ImplicitCloth/premake4.lua deleted file mode 100644 index 93be4a3af..000000000 --- a/Demos3/ImplicitCloth/premake4.lua +++ /dev/null @@ -1,72 +0,0 @@ - - project "App_ImplicitCloth" - - language "C++" - - kind "ConsoleApp" - targetdir "../../bin" - - includedirs { - ".", - "../../src", - "../../btgui" - } - - initOpenGL() - initGlew() - - --links{"gwen"} - - files { - "**.cpp", - "**.h", - "../../btgui/OpenGLWindow/SimpleOpenGL3App.cpp", - "../../btgui/OpenGLWindow/SimpleOpenGL3App.h", - "../../btgui/OpenGLWindow/TwFonts.cpp", - "../../btgui/OpenGLWindow/TwFonts.h", - "../../btgui/OpenGLWindow/LoadShader.cpp", - "../../btgui/OpenGLWindow/LoadShader.h", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.cpp", - "../../btgui/OpenGLWindow/GLPrimitiveRenderer.h", - "../../btgui/OpenGLWindow/GwenOpenGL3CoreRenderer.h", - "../../btgui/OpenGLWindow/GLInstancingRenderer.cpp", - "../../btgui/OpenGLWindow/GLInstancingRenderer.h", - "../../btgui/OpenGLWindow/GLRenderToTexture.cpp", - "../../btgui/OpenGLWindow/GLRenderToTexture.h", - "../../btgui/OpenGLWindow/TwFonts.cpp", - "../../btgui/OpenGLWindow/TwFonts.h", - "../../btgui/OpenGLWindow/OpenSans.cpp", - "../../btgui/OpenGLWindow/fontstash.cpp", - "../../btgui/OpenGLWindow/fontstash.h", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp", - "../../btgui/OpenGLWindow/opengl_fontstashcallbacks.h", - "../../src/Bullet3Common/**.cpp", - "../../src/Bullet3Common/**.h", - "../../btgui/Bullet3AppSupport/b3Clock.cpp", - "../../btgui/Bullet3AppSupport/b3Clock.h" - - } - -if os.is("Windows") then - files { - "../../btgui/OpenGLWindow/Win32OpenGLWindow.cpp", - "../../btgui/OpenGLWindow/Win32OpenGLWindow.h", - "../../btgui/OpenGLWindow/Win32Window.cpp", - "../../btgui/OpenGLWindow/Win32Window.h", - } - end - if os.is("Linux") then - links ("X11") - files{ - "../../btgui/OpenGLWindow/X11OpenGLWindow.h", - "../../btgui/OpenGLWindow/X11OpenGLWindow.cpp" - } - links{"pthread"} - end - if os.is("MacOSX") then - links{"Cocoa.framework"} - files{ - "../../btgui/OpenGLWindow/MacOpenGLWindow.mm", - "../../btgui/OpenGLWindow/MacOpenGLWindow.h", - } - end diff --git a/Demos3/ImplicitCloth/stan/Cloth.cpp b/Demos3/ImplicitCloth/stan/Cloth.cpp deleted file mode 100644 index 35859e686..000000000 --- a/Demos3/ImplicitCloth/stan/Cloth.cpp +++ /dev/null @@ -1,96 +0,0 @@ - -//----------------------------------------------------------------------------------------------- -// -// The remainder of this file shows how to use the spring network class with backward integration -// in order to implement a cloth system within a 3D game environment. -// The cloth class extends the springnetwork class in order to provide -// import/export, rendering support, and hooks into the game. -// - -#include "Cloth.h" - -Array cloths; - -Cloth::Cloth(const char *_name,int _n):SpringNetwork(_n), - color(0,0.5f,1.0f) -{ - - cloths.Add(this); -} -Cloth::~Cloth() -{ - cloths.Remove(this); -} - -// -// I/O support for serialization of our springnetwork and cloth objects. -// - - - - -int cloth_showbbox = 0; // for debug visualization shows bounding box. -float cloth_showvert = 0.025f; // size of box to put around current vert selected, 0 turns off - - - -Cloth *ClothCreate(int w,int h,float size) -{ - // simple cloth generation routine that creates a typical square cloth. - // better to use a real pipeline to generate these, this is just for testing. - int i,j; - Cloth *cloth = new Cloth("cloth",w*h); - cloth->w=w; - cloth->h=h; // later for rendering. - for(i=0;iX[i*w+j] = (float3(-0.5f,-0.5f,0)+float3((float)j/(w-1.0f),1.0f-(float)i/(h-1.0f),0)) * size; - } - for(i=0;iCreateSpring(SPRING_STRUCT,i*w+j,(i+1)*w+j); // structural - if(jCreateSpring(SPRING_STRUCT,i*w+j,i*w+(j+1)); // structural - if(jCreateSpring(SPRING_SHEAR ,i*w+j,(i+1)*w+(j+1)); // shear - if(j>0 &&iCreateSpring(SPRING_SHEAR ,i*w+j,(i+1)*w+(j-1)); // shear - if(iCreateSpring(SPRING_BEND ,i*w+j,(i+2)*w+j); // benders - if(jCreateSpring(SPRING_BEND ,i*w+j,i*w+(j+2)); // benders - } - cloth->UpdateLimits(); - return cloth; -} - - -int cloth_tess = 20; -float3 cloth_spawnpoint(0,3,5.0f); - - -/* -static void ClothDrawSprings(Cloth *cloth) -{ - static const float3 color[3]={float3(1,1,0),float3(1,0,1),float3(0,1,1)}; - float3N &X = cloth->X; - for(int i=0;isprings.count;i++) - { - SpringNetwork::Spring &s = cloth->springs[i]; - extern void Line(const float3 &,const float3 &,const float3 &color_rgb); - Line(X[s.a],X[s.b],color[s.type]); - } -} -*/ -int cloth_showsprings=0; - -void DoCloths() -{ - int i; - for(i=0;iSimulate((cloth->cloth_step<0)?DeltaT:cloth->cloth_step); - //if(cloth_showsprings) - // ClothDrawSprings(cloth); // debug visualization - - } -} diff --git a/Demos3/ImplicitCloth/stan/Cloth.h b/Demos3/ImplicitCloth/stan/Cloth.h deleted file mode 100644 index 4a4ec9166..000000000 --- a/Demos3/ImplicitCloth/stan/Cloth.h +++ /dev/null @@ -1,18 +0,0 @@ -#ifndef STAN_CLOTH_H -#define STAN_CLOTH_H - -#include "SpringNetwork.h" - -class Cloth : public SpringNetwork -{ - public: - int w,h; - - float3 color; // for debug rendering - Cloth(const char* _name,int _n); - ~Cloth(); -}; - -Cloth *ClothCreate(int w,int h,float size); - -#endif //STAN_CLOTH_H diff --git a/Demos3/ImplicitCloth/stan/SpringNetwork.cpp b/Demos3/ImplicitCloth/stan/SpringNetwork.cpp deleted file mode 100644 index d9b2b29c4..000000000 --- a/Demos3/ImplicitCloth/stan/SpringNetwork.cpp +++ /dev/null @@ -1,198 +0,0 @@ -#include "vec3n.h" -//#include "console.h" - - -extern int numX; - - -// -// Cloth - Backward Integrated Spring Network -// -// (c) Stan Melax 2006 -// http://www.melax.com/cloth -// freeware demo and source -// Although its free software, I'll gaurantee and support this software as much as is reasonable. -// However, if you choose to use any of this code, then you agree that -// I assume no financial liability should the software not meet your expectations. -// But do feel free to send any feedback. -// -// The core backward integration functionality has all been extracted into the SpringNetwork class. -// This makes it easy for you if you just want to look at or use the math and the algorithms. -// The remainder of the code builds a cloth system with basic render support, I/O, and manipulators, -// so its possible to make use of the technology within a 3D application. -// This code is separated from the SpringNetwork class in order to avoid pushing a particular style -// and prevent any dependancies of the algorithms onto unrelated systems. -// Feel free to adapt any of this into your own 3D engine/environment. -// -// Instead of having unique Hooke force and damping coefficients on each spring, the SpringNetwork -// code uses a spring 'type' that indexes a short list of shared named coefficients. -// This was just more practical for the typical application of this technology. -// Over-designed systems that are too general can be slower for -// the next guy to understand and more painful to use. -// Editing/creation is easier when only 1 number needs to be changed. -// Nonetheless, feel free to adapt to your own needs. -// - -#include -#include - -#include "vec3n.h" -//#include "console.h" -//#include "manipulatori.h" -//#include "object.h" -//#include "xmlparse.h" - - - - -static const float3x3 I(1,0,0,0,1,0,0,0,1); - -inline float3x3 dfdx_spring(const float3 &dir,float length,float rest,float k) -{ - // dir is unit length direction, rest is spring's restlength, k is spring constant. - return ( (I-outerprod(dir,dir))*Min(1.0f,rest/length) - I) * -k; -} -inline float3x3 dfdx_damp(const float3 &dir,float length,const float3& vel,float rest,float damping) -{ - // inner spring damping vel is the relative velocity of the endpoints. - return (I-outerprod(dir,dir)) * (-damping * -(dot(dir,vel)/Max(length,rest))); -} -inline float3x3 dfdv_damp(const float3 &dir,float damping) -{ - // derivative of force wrt velocity. - return outerprod(dir,dir) * damping; -} - - - -#include "SpringNetwork.h" - - -SpringNetwork::SpringNetwork(int _n):X(_n),V(_n),F(_n),dV(_n),A(_n),dFdX(_n),dFdV(_n) -{ - assert(SPRING_STRUCT==0); - assert(&spring_shear == &spring_struct +SPRING_SHEAR); - assert(&spring_bend == &spring_struct +SPRING_BEND); - assert(&spring_struct== &spring_k[SPRING_STRUCT]); - assert(&spring_shear == &spring_k[SPRING_SHEAR ]); - assert(&spring_bend == &spring_k[SPRING_BEND ]); - // spring_struct=1000000.0f; - // spring_shear=1000000.0f; - - spring_struct=1000.0f; - spring_shear=100.0f; - - spring_bend=25.0f; - spring_damp=5.0f; - spring_air=1.0f; - spring_air=1.0f; - cloth_step = 0.25f; // delta time for cloth - cloth_gravity=float3(0,-10,0); - cloth_sleepthreshold = 0.001f; - cloth_sleepcount = 100; - awake = cloth_sleepcount; - - //fix/pin two points in worldspace - float3Nx3N::Block zero; - zero.m = float3x3(0,0,0,0,0,0,0,0,0); - zero.c = 0; - zero.r = 0; - S.blocks.Add(zero); - zero.r = numX-1; - S.blocks.Add(zero); - - - -} - - -SpringNetwork::Spring &SpringNetwork::AddBlocks(Spring &s) -{ - // Called during initial creation of springs in our spring network. - // Sets up the sparse matrices corresponding to connections. - // Note the indices (s.iab,s.iba) are also stored with spring to avoid looking them up each time a spring is applied - // All 3 matrices A,dFdX, and dFdV are contstructed identically so the block array layout will be the same for each. - s.iab = A.blocks.count; // added 'ab' blocks will have this index. - A.blocks.Add(float3Nx3N::Block(s.a,s.b)); - dFdX.blocks.Add(float3Nx3N::Block(s.a,s.b)); - dFdV.blocks.Add(float3Nx3N::Block(s.a,s.b)); - s.iba = A.blocks.count; // added 'ba' blocks will have this index. - A.blocks.Add(float3Nx3N::Block(s.b,s.a)); - dFdX.blocks.Add(float3Nx3N::Block(s.b,s.a)); - dFdV.blocks.Add(float3Nx3N::Block(s.b,s.a)); - return s; -} - -void SpringNetwork::PreSolveSpring(const SpringNetwork::Spring &s) -{ - // Adds this spring's contribution into force vector F and force derivitves dFdX and dFdV - // One optimization would be premultiply dfdx by dt*dt and F and dFdV by dt right here in this function. - // However, for educational purposes we wont do that now and intead just follow the paper directly. - //assert(dFdX.blocks[s.a].c==s.a); // delete this assert, no bugs here - //assert(dFdX.blocks[s.a].r==s.a); - float3 extent = X[s.b] - X[s.a]; - float length = magnitude(extent); - float3 dir = (length==0)?float3(0,0,0): extent * 1.0f/length; - float3 vel = V[s.b] - V[s.a]; - float k = spring_k[s.type]; - float3 f = dir * ((k * (length-s.restlen) ) + spring_damp * dot(vel,dir)); // spring force + damping force - F[s.a] += f; - F[s.b] -= f; - float3x3 dfdx = dfdx_spring(dir,length,s.restlen,k) + dfdx_damp(dir,length,vel,s.restlen,spring_damp); - dFdX.blocks[s.a].m -= dfdx; // diagonal chunk dFdX[a,a] - dFdX.blocks[s.b].m -= dfdx; // diagonal chunk dFdX[b,b] - dFdX.blocks[s.iab].m += dfdx; // off-diag chunk dFdX[a,b] - dFdX.blocks[s.iba].m += dfdx; // off-diag chunk dFdX[b,a] - float3x3 dfdv = dfdv_damp(dir,spring_damp); - dFdV.blocks[s.a].m -= dfdv; // diagonal chunk dFdV[a,a] - dFdV.blocks[s.b].m -= dfdv; // diagonal chunk dFdV[b,b] - dFdV.blocks[s.iab].m += dfdv; // off-diag chunk dFdV[a,b] - dFdV.blocks[s.iba].m += dfdv; // off-diag chunk dFdV[b,a] -} - - - - -void SpringNetwork::CalcForces() -{ - // Collect forces and derivatives: F,dFdX,dFdV - dFdX.Zero(); - dFdV.InitDiagonal(-spring_air); - F.Init(cloth_gravity); - - F.element[0]=float3(0,0,0); - F.element[numX-1]=float3(0,0,0); - - F -= V * spring_air; - for(int i=0;i springs; - float3N X; // positions of all points - float3N V; // velocities - float3N F; // force on each point - float3N dV; // change in velocity - float3Nx3N A; // big matrix we solve system with - float3Nx3N dFdX; // big matrix of derivative of force wrt position - float3Nx3N dFdV; // big matrix of derivative of force wrt velocity - float3Nx3N S; // used for our constraints - contains only some diagonal blocks as needed S[i,i] - int awake; - float3 bmin,bmax; - union - { - struct - { - float spring_struct; - float spring_shear; - float spring_bend; - }; - float spring_k[3]; - }; - float spring_damp; - float spring_air; - float cloth_step; // delta time for cloth - float3 cloth_gravity; - float cloth_sleepthreshold; - int cloth_sleepcount; - - SpringNetwork(int _n); - Spring &AddBlocks(Spring &s); - Spring &CreateSpring(int type,int a,int b,float restlen){return AddBlocks(springs.Add(Spring(type,a,b,restlen)));} - Spring &CreateSpring(int type,int a,int b){return CreateSpring(type,a,b,magnitude(X[b]-X[a]));} - void UpdateLimits() { BoxLimits(X.element,X.count,bmin,bmax);} - void Wake(){awake=cloth_sleepcount;} - void Simulate(float dt); - void PreSolveSpring(const Spring &s); - void CalcForces(); -}; - -#endif //STAN_SPRING_NETWORK_H diff --git a/Demos3/ImplicitCloth/stan/array.h b/Demos3/ImplicitCloth/stan/array.h deleted file mode 100644 index d55714698..000000000 --- a/Demos3/ImplicitCloth/stan/array.h +++ /dev/null @@ -1,284 +0,0 @@ -// -// Typical template dynamic array container class. -// By S Melax 1998 -// -// anyone is free to use, inspect, learn from, or ignore -// the code here as they see fit. -// -// A very simple template array class. -// Its easiest to understand this array -// class by seeing how it is used in code. -// -// For example: -// for(i=0;i -#include - -template class Array { - public: - Array(int s=0); - Array(Array &array); - ~Array(); - void allocate(int s); - void SetSize(int s); - void Pack(); - Type& Add(Type); - void AddUnique(Type); - int Contains(Type); - void Insert(Type,int); - int IndexOf(Type); - void Remove(Type); - void DelIndex(int i); - Type& DelIndexWithLast(int i); - Type * element; - int count; - int array_size; - const Type &operator[](int i) const { assert(i>=0 && i=0 && i ©(const Array &array); - Array &operator=(Array &array); -}; - - -template Array::Array(int s) -{ - if(s==-1) return; - count=0; - array_size = 0; - element = NULL; - if(s) - { - allocate(s); - } -} - - -template Array::Array(Array &array) -{ - count=0; - array_size = 0; - element = NULL; - *this = array; -} - - - - -template Array &Array::copy(const Array &array) -{ - assert(array.array_size>=0); - count=0; - for(int i=0;i Array &Array::operator=( Array &array) -{ - if(array.array_size<0) // negative number means steal the data buffer instead of copying - { - delete[] element; - element = array.element; - array_size = -array.array_size; - count = array.count; - array.count =array.array_size = 0; - array.element = NULL; - return *this; - } - count=0; - for(int i=0;i Array::~Array() -{ - if (element != NULL && array_size!=0) - { - delete[] element; - } - count=0;array_size=0;element=NULL; -} - -template void Array::allocate(int s) -{ - assert(s>0); - assert(s>=count); - if(s==array_size) return; - Type *old = element; - array_size =s; - element = new Type[array_size]; - assert(element); - for(int i=0;i void Array::SetSize(int s) -{ - if(s==0) - { - if(element) - { - delete[] element; - element = NULL; - } - array_size = s; - } - else - { - allocate(s); - } - count=s; -} - -template void Array::Pack() -{ - allocate(count); -} - -template Type& Array::Add(Type t) -{ - assert(count<=array_size); - if(count==array_size) - { - allocate((array_size)?array_size *2:16); - } - //int i; - //for(i=0;i int Array::Contains(Type t) -{ - int i; - int found=0; - for(i=0;i void Array::AddUnique(Type t) -{ - if(!Contains(t)) Add(t); -} - - -template void Array::DelIndex(int i) -{ - assert(i Type& Array::DelIndexWithLast(int i) -{ - assert(i void Array::Remove(Type t) -{ - int i; - for(i=0;i void Array::Insert(Type t,int k) -{ - int i=count; - Add(t); // to allocate space - while(i>k) - { - element[i]=element[i-1]; - i--; - } - assert(i==k); - element[k]=t; -} - - -template int Array::IndexOf(Type t) -{ - int i; - for(i=0;i - -#include "vec3n.h" - - -float conjgrad_lasterror; -float conjgrad_epsilon = 0.1f; -int conjgrad_loopcount; -int conjgrad_looplimit = 100; - -/*EXPORTVAR(conjgrad_lasterror); -EXPORTVAR(conjgrad_epsilon ); -EXPORTVAR(conjgrad_loopcount); -EXPORTVAR(conjgrad_looplimit); -*/ - -int ConjGradient(float3N &X, float3Nx3N &A, float3N &B) -{ - // Solves for unknown X in equation AX=B - conjgrad_loopcount=0; - int n=B.count; - float3N q(n),d(n),tmp(n),r(n); - r = B - Mul(tmp,A,X); // just use B if X known to be zero - d = r; - float s = dot(r,r); - float starget = s * squared(conjgrad_epsilon); - while( s>starget && conjgrad_loopcount++ < conjgrad_looplimit) - { - Mul(q,A,d); // q = A*d; - float a = s/dot(d,q); - X = X + d*a; - if(conjgrad_loopcount%50==0) - { - r = B - Mul(tmp,A,X); - } - else - { - r = r - q*a; - } - float s_prev = s; - s = dot(r,r); - d = r+d*(s/s_prev); - } - conjgrad_lasterror = s; - return conjgrad_loopcountstarget && conjgrad_loopcount++ < conjgrad_looplimit) - { - Mul(q,A,d); // q = A*d; - q[hack[0]] = q[hack[1]] = q[hack[2]] = float3(0,0,0); - float a = s/dot(d,q); - X = X + d*a; - if(conjgrad_loopcount%50==0) - { - r = B - Mul(tmp,A,X); - r[hack[0]] = r[hack[1]] = r[hack[2]] = float3(0,0,0); - } - else - { - r = r - q*a; - } - float s_prev = s; - s = dot(r,r); - d = r+d*(s/s_prev); - d[hack[0]] = d[hack[1]] = d[hack[2]] = float3(0,0,0); - } - conjgrad_lasterror = s; - return conjgrad_loopcountstarget && conjgrad_loopcount++ < conjgrad_looplimit) - { - Mul(q,A,d); // q = A*d; - filter(q,S); - float a = s/dot(d,q); - X = X + d*a; - if(conjgrad_loopcount%50==0) - { - r = B - Mul(tmp,A,X); - filter(r,S); - } - else - { - r = r - q*a; - } - float s_prev = s; - s = dot(r,r); - d = r+d*(s/s_prev); - filter(d,S); - } - conjgrad_lasterror = s; - return conjgrad_loopcount -//template void * vec4::operator new[](size_t n){ return _mm_malloc(n,64); } -//template void vec4::operator delete[](void *a) { _mm_free(a); } - - -struct HalfConstraint { - float3 n;int vi; - float s,t; - HalfConstraint(const float3& _n,int _vi,float _t):n(_n),vi(_vi),s(0),t(_t){} - HalfConstraint():vi(-1){} -}; - -class float3Nx3N -{ - public: - class Block - { - public: - - float3x3 m; - int r,c; - float unused[16]; - - - Block(){} - Block(short _r,short _c):r(_r),c(_c){m.x=m.y=m.z=float3(0,0,0);} - }; - Array blocks; // the first n blocks use as the diagonal. - int n; - void Zero(); - void InitDiagonal(float d); - void Identity(){InitDiagonal(1.0f);} - float3Nx3N():n(0){} - float3Nx3N(int _n):n(_n) {for(int i=0;i float3Nx3N &operator= (const E& expression) {expression.evalequals(*this);return *this;} - template float3Nx3N &operator+=(const E& expression) {expression.evalpluseq(*this);return *this;} - template float3Nx3N &operator-=(const E& expression) {expression.evalmnuseq(*this);return *this;} -}; - -class float3N: public Array -{ -public: - float3N(int _count=0) - { - SetSize(_count); - } - void Zero(); - void Init(const float3 &v); // sets each subvector to v - template float3N &operator= (const E& expression) {expression.evalequals(*this);return *this;} - template float3N &operator+=(const E& expression) {expression.evalpluseq(*this);return *this;} - template float3N &operator-=(const E& expression) {expression.evalmnuseq(*this);return *this;} - float3N &operator=( const float3N &V) { this->copy(V); return *this;} -}; - -int ConjGradient(float3N &X, float3Nx3N &A, float3N &B); -int ConjGradientFiltered(float3N &X, const float3Nx3N &A, const float3N &B,const float3Nx3N &S,Array &H); -int ConjGradientFiltered(float3N &X, const float3Nx3N &A, const float3N &B,const float3Nx3N &S); - -inline float3N& Mul(float3N &r,const float3Nx3N &m, const float3N &v) -{ - int i; - for(i=0;i // for memcpy -#include - -float squared(float a){return a*a;} -float clamp(float a,const float minval, const float maxval) {return Min(maxval,Max(minval,a));} -int clamp(int a,const int minval, const int maxval) {return Min(maxval,Max(minval,a));} - - -float Round(float a,float precision) -{ - return floorf(0.5f+a/precision)*precision; -} - - -float Interpolate(const float &f0,const float &f1,float alpha) -{ - return f0*(1-alpha) + f1*alpha; -} - - -int argmin(const float a[],int n) -{ - int r=0; - for(int i=1;ia[r]) - { - r = i; - } - } - return r; -} - - - -//------------ float3 (3D) -------------- - - - -float3 vabs(const float3 &v) -{ - return float3(fabsf(v.x),fabsf(v.y),fabsf(v.z)); -} - - - -float3 safenormalize(const float3 &v) -{ - if(magnitude(v)<=0.0f) - { - return float3(1,0,0); - } - return normalize(v); -} - -float3 Round(const float3 &a,float precision) -{ - return float3(Round(a.x,precision),Round(a.y,precision),Round(a.z,precision)); -} - - -float3 Interpolate(const float3 &v0,const float3 &v1,float alpha) -{ - return v0*(1-alpha) + v1*alpha; -} - -float3 Orth(const float3& v) -{ - float3 absv=vabs(v); - float3 u(1,1,1); - u[argmax(&absv[0],3)] =0.0f; - return normalize(cross(u,v)); -} - -void BoxLimits(const float3 *verts,int verts_count, float3 &bmin,float3 &bmax) -{ - bmin=float3( FLT_MAX, FLT_MAX, FLT_MAX); - bmax=float3(-FLT_MAX,-FLT_MAX,-FLT_MAX); - for(int i=0;ibmaxb[j]) return 0; - if(bminb[j]>bmaxa[j]) return 0; - } - return 1; -} - -// the statement v1*v2 is ambiguous since there are 3 types -// of vector multiplication -// - componantwise (for example combining colors) -// - dot product -// - cross product -// Therefore we never declare/implement this function. -// So we will never see: float3 operator*(float3 a,float3 b) - - - - -//------------ float3x3 --------------- -float Determinant(const float3x3 &m) -{ - return m.x.x*m.y.y*m.z.z + m.y.x*m.z.y*m.x.z + m.z.x*m.x.y*m.y.z - -m.x.x*m.z.y*m.y.z - m.y.x*m.x.y*m.z.z - m.z.x*m.y.y*m.x.z ; -} - -float3x3 Inverse(const float3x3 &a) -{ - float3x3 b; - float d=Determinant(a); - assert(d!=0); - for(int i=0;i<3;i++) - { - for(int j=0;j<3;j++) - { - int i1=(i+1)%3; - int i2=(i+2)%3; - int j1=(j+1)%3; - int j2=(j+2)%3; - // reverse indexs i&j to take transpose - b[j][i] = (a[i1][j1]*a[i2][j2]-a[i1][j2]*a[i2][j1])/d; - } - } - // Matrix check=a*b; // Matrix 'check' should be the identity (or close to it) - return b; -} - - -float3x3 Transpose( const float3x3& m ) -{ - return float3x3( float3(m.x.x,m.y.x,m.z.x), - float3(m.x.y,m.y.y,m.z.y), - float3(m.x.z,m.y.z,m.z.z)); -} - - -float3 operator*(const float3& v , const float3x3 &m ) { - return float3((m.x.x*v.x + m.y.x*v.y + m.z.x*v.z), - (m.x.y*v.x + m.y.y*v.y + m.z.y*v.z), - (m.x.z*v.x + m.y.z*v.y + m.z.z*v.z)); -} -float3 operator*(const float3x3 &m,const float3& v ) { - return float3(dot(m.x,v),dot(m.y,v),dot(m.z,v)); -} - - -float3x3 operator*( const float3x3& a, const float3x3& b ) -{ - return float3x3(a.x*b,a.y*b,a.z*b); -} - -float3x3 operator*( const float3x3& a, const float& s ) -{ - return float3x3(a.x*s, a.y*s ,a.z*s); -} -float3x3 operator/( const float3x3& a, const float& s ) -{ - float t=1/s; - return float3x3(a.x*t, a.y*t ,a.z*t); -} -float3x3 operator+( const float3x3& a, const float3x3& b ) -{ - return float3x3(a.x+b.x, a.y+b.y, a.z+b.z); -} -float3x3 operator-( const float3x3& a, const float3x3& b ) -{ - return float3x3(a.x-b.x, a.y-b.y, a.z-b.z); -} -float3x3 &operator+=( float3x3& a, const float3x3& b ) -{ - a.x+=b.x; - a.y+=b.y; - a.z+=b.z; - return a; -} -float3x3 &operator-=( float3x3& a, const float3x3& b ) -{ - a.x-=b.x; - a.y-=b.y; - a.z-=b.z; - return a; -} -float3x3 &operator*=( float3x3& a, const float& s ) -{ - a.x*=s; - a.y*=s; - a.z*=s; - return a; -} - -float3x3 outerprod(const float3& a,const float3& b) -{ - return float3x3(a.x*b,a.y*b,a.z*b); // a is a column vector b is a row vector -} - -//--------------- 4D ---------------- - -float4 operator*( const float4& v, const float4x4& m ) -{ - return v.x*m.x + v.y*m.y + v.z*m.z + v.w*m.w; // yes this actually works -} - - -// Dont implement m*v for now, since that might confuse us -// All our transforms are based on multiplying the "row" vector on the left -//float4 operator*(const float4x4& m , const float4& v ) -//{ -// return float4(dot(v,m.x),dot(v,m.y),dot(v,m.z),dot(v,m.w)); -//} - - -float4x4 operator*( const float4x4& a, const float4x4& b ) -{ - return float4x4(a.x*b,a.y*b,a.z*b,a.w*b); -} - -float4x4 MatrixTranspose(const float4x4 &m) -{ - return float4x4( - m.x.x, m.y.x, m.z.x, m.w.x, - m.x.y, m.y.y, m.z.y, m.w.y, - m.x.z, m.y.z, m.z.z, m.w.z, - m.x.w, m.y.w, m.z.w, m.w.w ); -} - -float4x4 MatrixRigidInverse(const float4x4 &m) -{ - float4x4 trans_inverse = MatrixTranslation(-m.w.xyz()); - float4x4 rot = m; - rot.w = float4(0,0,0,1); - return trans_inverse * MatrixTranspose(rot); -} - - -float4x4 MatrixPerspectiveFov(float fovy, float aspect, float zn, float zf ) -{ - float h = 1.0f/tanf(fovy/2.0f); // view space height - float w = h / aspect ; // view space width - return float4x4( - w, 0, 0 , 0, - 0, h, 0 , 0, - 0, 0, zf/(zn-zf) , -1, - 0, 0, zn*zf/(zn-zf) , 0 ); -} - - - -float4x4 MatrixLookAt(const float3& eye, const float3& at, const float3& up) -{ - float4x4 m; - m.w.w = 1.0f; - m.w.xyz() = eye; - m.z.xyz() = normalize(eye-at); - m.x.xyz() = normalize(cross(up,m.z.xyz())); - m.y.xyz() = cross(m.z.xyz(),m.x.xyz()); - return MatrixRigidInverse(m); -} - - -float4x4 MatrixTranslation(const float3 &t) -{ - return float4x4( - 1, 0, 0, 0, - 0, 1, 0, 0, - 0, 0, 1, 0, - t.x,t.y,t.z,1 ); -} - - -float4x4 MatrixRotationZ(const float angle_radians) -{ - float s = sinf(angle_radians); - float c = cosf(angle_radians); - return float4x4( - c, s, 0, 0, - -s, c, 0, 0, - 0, 0, 1, 0, - 0, 0, 0, 1 ); -} - - - -int operator==( const float4x4 &a, const float4x4 &b ) -{ - return (a.x==b.x && a.y==b.y && a.z==b.z && a.w==b.w); -} - - -float4x4 Inverse(const float4x4 &m) -{ - float4x4 d; - float *dst = &d.x.x; - float tmp[12]; /* temp array for pairs */ - float src[16]; /* array of transpose source matrix */ - float det; /* determinant */ - /* transpose matrix */ - for ( int i = 0; i < 4; i++) { - src[i] = m(i,0) ; - src[i + 4] = m(i,1); - src[i + 8] = m(i,2); - src[i + 12] = m(i,3); - } - /* calculate pairs for first 8 elements (cofactors) */ - tmp[0] = src[10] * src[15]; - tmp[1] = src[11] * src[14]; - tmp[2] = src[9] * src[15]; - tmp[3] = src[11] * src[13]; - tmp[4] = src[9] * src[14]; - tmp[5] = src[10] * src[13]; - tmp[6] = src[8] * src[15]; - tmp[7] = src[11] * src[12]; - tmp[8] = src[8] * src[14]; - tmp[9] = src[10] * src[12]; - tmp[10] = src[8] * src[13]; - tmp[11] = src[9] * src[12]; - /* calculate first 8 elements (cofactors) */ - dst[0] = tmp[0]*src[5] + tmp[3]*src[6] + tmp[4]*src[7]; - dst[0] -= tmp[1]*src[5] + tmp[2]*src[6] + tmp[5]*src[7]; - dst[1] = tmp[1]*src[4] + tmp[6]*src[6] + tmp[9]*src[7]; - dst[1] -= tmp[0]*src[4] + tmp[7]*src[6] + tmp[8]*src[7]; - dst[2] = tmp[2]*src[4] + tmp[7]*src[5] + tmp[10]*src[7]; - dst[2] -= tmp[3]*src[4] + tmp[6]*src[5] + tmp[11]*src[7]; - dst[3] = tmp[5]*src[4] + tmp[8]*src[5] + tmp[11]*src[6]; - dst[3] -= tmp[4]*src[4] + tmp[9]*src[5] + tmp[10]*src[6]; - dst[4] = tmp[1]*src[1] + tmp[2]*src[2] + tmp[5]*src[3]; - dst[4] -= tmp[0]*src[1] + tmp[3]*src[2] + tmp[4]*src[3]; - dst[5] = tmp[0]*src[0] + tmp[7]*src[2] + tmp[8]*src[3]; - dst[5] -= tmp[1]*src[0] + tmp[6]*src[2] + tmp[9]*src[3]; - dst[6] = tmp[3]*src[0] + tmp[6]*src[1] + tmp[11]*src[3]; - dst[6] -= tmp[2]*src[0] + tmp[7]*src[1] + tmp[10]*src[3]; - dst[7] = tmp[4]*src[0] + tmp[9]*src[1] + tmp[10]*src[2]; - dst[7] -= tmp[5]*src[0] + tmp[8]*src[1] + tmp[11]*src[2]; - /* calculate pairs for second 8 elements (cofactors) */ - tmp[0] = src[2]*src[7]; - tmp[1] = src[3]*src[6]; - tmp[2] = src[1]*src[7]; - tmp[3] = src[3]*src[5]; - tmp[4] = src[1]*src[6]; - tmp[5] = src[2]*src[5]; - tmp[6] = src[0]*src[7]; - tmp[7] = src[3]*src[4]; - tmp[8] = src[0]*src[6]; - tmp[9] = src[2]*src[4]; - tmp[10] = src[0]*src[5]; - tmp[11] = src[1]*src[4]; - /* calculate second 8 elements (cofactors) */ - dst[8] = tmp[0]*src[13] + tmp[3]*src[14] + tmp[4]*src[15]; - dst[8] -= tmp[1]*src[13] + tmp[2]*src[14] + tmp[5]*src[15]; - dst[9] = tmp[1]*src[12] + tmp[6]*src[14] + tmp[9]*src[15]; - dst[9] -= tmp[0]*src[12] + tmp[7]*src[14] + tmp[8]*src[15]; - dst[10] = tmp[2]*src[12] + tmp[7]*src[13] + tmp[10]*src[15]; - dst[10]-= tmp[3]*src[12] + tmp[6]*src[13] + tmp[11]*src[15]; - dst[11] = tmp[5]*src[12] + tmp[8]*src[13] + tmp[11]*src[14]; - dst[11]-= tmp[4]*src[12] + tmp[9]*src[13] + tmp[10]*src[14]; - dst[12] = tmp[2]*src[10] + tmp[5]*src[11] + tmp[1]*src[9]; - dst[12]-= tmp[4]*src[11] + tmp[0]*src[9] + tmp[3]*src[10]; - dst[13] = tmp[8]*src[11] + tmp[0]*src[8] + tmp[7]*src[10]; - dst[13]-= tmp[6]*src[10] + tmp[9]*src[11] + tmp[1]*src[8]; - dst[14] = tmp[6]*src[9] + tmp[11]*src[11] + tmp[3]*src[8]; - dst[14]-= tmp[10]*src[11] + tmp[2]*src[8] + tmp[7]*src[9]; - dst[15] = tmp[10]*src[10] + tmp[4]*src[8] + tmp[9]*src[9]; - dst[15]-= tmp[8]*src[9] + tmp[11]*src[10] + tmp[5]*src[8]; - /* calculate determinant */ - det=src[0]*dst[0]+src[1]*dst[1]+src[2]*dst[2]+src[3]*dst[3]; - /* calculate matrix inverse */ - det = 1/det; - for ( int j = 0; j < 16; j++) - dst[j] *= det; - return d; -} - - -//--------- Quaternion -------------- - -template<> void Quaternion::Normalize() -{ - float m = sqrtf(squared(w)+squared(x)+squared(y)+squared(z)); - if(m<0.000000001f) { - w=1.0f; - x=y=z=0.0f; - return; - } - (*this) *= (1.0f/m); -} - -float3 rotate( const Quaternion& q, const float3& v ) -{ - // The following is equivalent to: - //return (q.getmatrix() * v); - float qx2 = q.x*q.x; - float qy2 = q.y*q.y; - float qz2 = q.z*q.z; - - float qxqy = q.x*q.y; - float qxqz = q.x*q.z; - float qxqw = q.x*q.w; - float qyqz = q.y*q.z; - float qyqw = q.y*q.w; - float qzqw = q.z*q.w; - return float3( - (1-2*(qy2+qz2))*v.x + (2*(qxqy-qzqw))*v.y + (2*(qxqz+qyqw))*v.z , - (2*(qxqy+qzqw))*v.x + (1-2*(qx2+qz2))*v.y + (2*(qyqz-qxqw))*v.z , - (2*(qxqz-qyqw))*v.x + (2*(qyqz+qxqw))*v.y + (1-2*(qx2+qy2))*v.z ); -} - - -Quaternion slerp(const Quaternion &_a, const Quaternion& b, float interp ) -{ - Quaternion a=_a; - if(dot(a,b) <0.0) - { - a.w=-a.w; - a.x=-a.x; - a.y=-a.y; - a.z=-a.z; - } - float d = dot(a,b); - if(d>=1.0) { - return a; - } - float theta = acosf(d); - if(theta==0.0f) { return(a);} - return a*(sinf(theta-interp*theta)/sinf(theta)) + b*(sinf(interp*theta)/sinf(theta)); -} - - -Quaternion Interpolate(const Quaternion &q0,const Quaternion &q1,float alpha) { - return slerp(q0,q1,alpha); -} - - -Quaternion YawPitchRoll( float yaw, float pitch, float roll ) -{ - return QuatFromAxisAngle(float3(0.0f,0.0f,1.0f),DegToRad(yaw )) - * QuatFromAxisAngle(float3(1.0f,0.0f,0.0f),DegToRad(pitch)) - * QuatFromAxisAngle(float3(0.0f,1.0f,0.0f),DegToRad(roll )); -} - -float Yaw( const Quaternion& q ) -{ - static float3 v; - v=q.ydir(); - return (v.y==0.0&&v.x==0.0) ? 0.0f: RadToDeg(atan2f(-v.x,v.y)); -} - -float Pitch( const Quaternion& q ) -{ - static float3 v; - v=q.ydir(); - return RadToDeg(atan2f(v.z,sqrtf(squared(v.x)+squared(v.y)))); -} - -float Roll( const Quaternion &_q ) -{ - Quaternion q=_q; - q = QuatFromAxisAngle(float3(0.0f,0.0f,1.0f),-DegToRad(Yaw(q))) *q; - q = QuatFromAxisAngle(float3(1.0f,0.0f,0.0f),-DegToRad(Pitch(q))) *q; - return RadToDeg(atan2f(-q.xdir().z,q.xdir().x)); -} - -float Yaw( const float3& v ) -{ - return (v.y==0.0&&v.x==0.0) ? 0.0f: RadToDeg(atan2f(-v.x,v.y)); -} - -float Pitch( const float3& v ) -{ - return RadToDeg(atan2f(v.z,sqrtf(squared(v.x)+squared(v.y)))); -} - - - - - - -//--------- utility functions ------------- - -// RotationArc() -// Given two vectors v0 and v1 this function -// returns quaternion q where q*v0==v1. -// Routine taken from game programming gems. -Quaternion RotationArc(float3 v0,float3 v1){ - static Quaternion q; - v0 = normalize(v0); // Comment these two lines out if you know its not needed. - v1 = normalize(v1); // If vector is already unit length then why do it again? - float3 c = cross(v0,v1); - float d = dot(v0,v1); - if(d<=-1.0f) { float3 a=Orth(v0); return Quaternion(a.x,a.y,a.z,0);} // 180 about any orthogonal axis axis - float s = sqrtf((1+d)*2); - q.x = c.x / s; - q.y = c.y / s; - q.z = c.z / s; - q.w = s /2.0f; - return q; -} - - -float4x4 MatrixFromQuatVec(const Quaternion &q, const float3 &v) -{ - // builds a 4x4 transformation matrix based on orientation q and translation v - float qx2 = q.x*q.x; - float qy2 = q.y*q.y; - float qz2 = q.z*q.z; - - float qxqy = q.x*q.y; - float qxqz = q.x*q.z; - float qxqw = q.x*q.w; - float qyqz = q.y*q.z; - float qyqw = q.y*q.w; - float qzqw = q.z*q.w; - - return float4x4( - 1-2*(qy2+qz2), - 2*(qxqy+qzqw), - 2*(qxqz-qyqw), - 0 , - 2*(qxqy-qzqw), - 1-2*(qx2+qz2), - 2*(qyqz+qxqw), - 0 , - 2*(qxqz+qyqw), - 2*(qyqz-qxqw), - 1-2*(qx2+qy2), - 0 , - v.x , - v.y , - v.z , - 1.0f ); -} - - - -float3 PlaneLineIntersection(const float3 &normal,const float dist, const float3 &p0, const float3 &p1) -{ - // returns the point where the line p0-p1 intersects the plane n&d - float3 dif; - dif = p1-p0; - float dn= dot(normal,dif); - float t = -(dist+dot(normal,p0) )/dn; - return p0 + (dif*t); -} - -float3 LineProject(const float3 &p0, const float3 &p1, const float3 &a) -{ - // project point a on segment [p0,p1] - float3 d= p1-p0; - float t= dot(d,(a-p0)) / dot(d,d); - return p0+ d*t; -} - - -float LineProjectTime(const float3 &p0, const float3 &p1, const float3 &a) -{ - // project point a on segment [p0,p1] - float3 d= p1-p0; - float t= dot(d,(a-p0)) / dot(d,d); - return t; -} - - - -float3 TriNormal(const float3 &v0, const float3 &v1, const float3 &v2) -{ - // return the normal of the triangle - // inscribed by v0, v1, and v2 - float3 cp=cross(v1-v0,v2-v1); - float m=magnitude(cp); - if(m==0) return float3(1,0,0); - return cp*(1.0f/m); -} - - - -int BoxInside(const float3 &p, const float3 &bmin, const float3 &bmax) -{ - return (p.x >= bmin.x && p.x <=bmax.x && - p.y >= bmin.y && p.y <=bmax.y && - p.z >= bmin.z && p.z <=bmax.z ); -} - - -int BoxIntersect(const float3 &v0, const float3 &v1, const float3 &bmin, const float3 &bmax,float3 *impact) -{ - if(BoxInside(v0,bmin,bmax)) - { - *impact=v0; - return 1; - } - if(v0.x<=bmin.x && v1.x>=bmin.x) - { - float a = (bmin.x-v0.x)/(v1.x-v0.x); - //v.x = bmin.x; - float vy = (1-a) *v0.y + a*v1.y; - float vz = (1-a) *v0.z + a*v1.z; - if(vy>=bmin.y && vy<=bmax.y && vz>=bmin.z && vz<=bmax.z) - { - impact->x = bmin.x; - impact->y = vy; - impact->z = vz; - return 1; - } - } - else if(v0.x >= bmax.x && v1.x <= bmax.x) - { - float a = (bmax.x-v0.x)/(v1.x-v0.x); - //v.x = bmax.x; - float vy = (1-a) *v0.y + a*v1.y; - float vz = (1-a) *v0.z + a*v1.z; - if(vy>=bmin.y && vy<=bmax.y && vz>=bmin.z && vz<=bmax.z) - { - impact->x = bmax.x; - impact->y = vy; - impact->z = vz; - return 1; - } - } - if(v0.y<=bmin.y && v1.y>=bmin.y) - { - float a = (bmin.y-v0.y)/(v1.y-v0.y); - float vx = (1-a) *v0.x + a*v1.x; - //v.y = bmin.y; - float vz = (1-a) *v0.z + a*v1.z; - if(vx>=bmin.x && vx<=bmax.x && vz>=bmin.z && vz<=bmax.z) - { - impact->x = vx; - impact->y = bmin.y; - impact->z = vz; - return 1; - } - } - else if(v0.y >= bmax.y && v1.y <= bmax.y) - { - float a = (bmax.y-v0.y)/(v1.y-v0.y); - float vx = (1-a) *v0.x + a*v1.x; - // vy = bmax.y; - float vz = (1-a) *v0.z + a*v1.z; - if(vx>=bmin.x && vx<=bmax.x && vz>=bmin.z && vz<=bmax.z) - { - impact->x = vx; - impact->y = bmax.y; - impact->z = vz; - return 1; - } - } - if(v0.z<=bmin.z && v1.z>=bmin.z) - { - float a = (bmin.z-v0.z)/(v1.z-v0.z); - float vx = (1-a) *v0.x + a*v1.x; - float vy = (1-a) *v0.y + a*v1.y; - // v.z = bmin.z; - if(vy>=bmin.y && vy<=bmax.y && vx>=bmin.x && vx<=bmax.x) - { - impact->x = vx; - impact->y = vy; - impact->z = bmin.z; - return 1; - } - } - else if(v0.z >= bmax.z && v1.z <= bmax.z) - { - float a = (bmax.z-v0.z)/(v1.z-v0.z); - float vx = (1-a) *v0.x + a*v1.x; - float vy = (1-a) *v0.y + a*v1.y; - // v.z = bmax.z; - if(vy>=bmin.y && vy<=bmax.y && vx>=bmin.x && vx<=bmax.x) - { - impact->x = vx; - impact->y = vy; - impact->z = bmax.z; - return 1; - } - } - return 0; -} - - -float DistanceBetweenLines(const float3 &ustart, const float3 &udir, const float3 &vstart, const float3 &vdir, float3 *upoint, float3 *vpoint) -{ - static float3 cp; - cp = normalize(cross(udir,vdir)); - - float distu = -dot(cp,ustart); - float distv = -dot(cp,vstart); - float dist = (float)fabs(distu-distv); - if(upoint) - { - float3 normal = normalize(cross(vdir,cp)); - *upoint = PlaneLineIntersection(normal,-dot(normal,vstart),ustart,ustart+udir); - } - if(vpoint) - { - float3 normal = normalize(cross(udir,cp)); - *vpoint = PlaneLineIntersection(normal,-dot(normal,ustart),vstart,vstart+vdir); - } - return dist; -} - - -Quaternion VirtualTrackBall(const float3 &cop, const float3 &cor, const float3 &dir1, const float3 &dir2) -{ - // routine taken from game programming gems. - // Implement track ball functionality to spin stuf on the screen - // cop center of projection - // cor center of rotation - // dir1 old mouse direction - // dir2 new mouse direction - // pretend there is a sphere around cor. Then find the points - // where dir1 and dir2 intersect that sphere. Find the - // rotation that takes the first point to the second. - float m; - // compute plane - float3 nrml = cor - cop; - float fudgefactor = 1.0f/(magnitude(nrml) * 0.25f); // since trackball proportional to distance from cop - nrml = normalize(nrml); - float dist = -dot(nrml,cor); - float3 u= PlaneLineIntersection(nrml,dist,cop,cop+dir1); - u=u-cor; - u=u*fudgefactor; - m= magnitude(u); - if(m>1) - { - u/=m; - } - else - { - u=u - (nrml * sqrtf(1-m*m)); - } - float3 v= PlaneLineIntersection(nrml,dist,cop,cop+dir2); - v=v-cor; - v=v*fudgefactor; - m= magnitude(v); - if(m>1) - { - v/=m; - } - else - { - v=v - (nrml * sqrtf(1-m*m)); - } - return RotationArc(u,v); -} - - -int countpolyhit=0; -int HitCheckPoly(const float3 *vert, const int n, const float3 &v0, const float3 &v1, float3 *impact, float3 *normal) -{ - countpolyhit++; - int i; - float3 nrml(0,0,0); - for(i=0;i0) - { - return 0; - } - - static float3 the_point; - // By using the cached plane distances d0 and d1 - // we can optimize the following: - // the_point = planelineintersection(nrml,dist,v0,v1); - float a = d0/(d0-d1); - the_point = v0*(1-a) + v1*a; - - - int inside=1; - for(int j=0;inside && j= 0.0); - } - if(inside) - { - if(normal){*normal=nrml;} - if(impact){*impact=the_point;} - } - return inside; -} - -int SolveQuadratic(float a,float b,float c,float *ta,float *tb) // if true returns roots ta,tb where ta<=tb -{ - assert(ta); - assert(tb); - float d = b*b-4.0f*a*c; // discriminant - if(d<0.0f) return 0; - float sqd = sqrtf(d); - *ta = (-b-sqd) / (2.0f * a); - *tb = (-b+sqd) / (2.0f * a); - return 1; -} - -int HitCheckRaySphere(const float3& sphereposition,float radius, const float3& _v0, const float3& _v1, float3 *impact,float3 *normal) -{ - assert(impact); - assert(normal); - float3 dv = _v1-_v0; - float3 v0 = _v0 - sphereposition; // solve in coord system of the sphere - if(radius<=0.0f || _v0==_v1) return 0; // only true if point moves from outside to inside sphere. - float a = dot(dv,dv); - float b = 2.0f * dot(dv,v0); - float c = dot(v0,v0) - radius*radius; - if(c<0.0f) return 0; // we are already inside the sphere. - - float ta, tb; - int doesIntersect = SolveQuadratic(a, b, c, &ta, &tb); - - if (!doesIntersect) return 0; - - if (ta >= 0.0f && ta <= 1.0f && (ta <= tb || tb<=0.0f)) - { - *impact = _v0 + dv * ta; - *normal = (v0 + dv*ta)/radius; - return 1; - } - if (tb >= 0.0f && tb <= 1.0f) - { - assert(tb <= ta || ta <=0.0f); // tb must be better than ta - *impact = _v0 + dv * tb; - *normal = (v0 + dv*tb)/radius; - return 1; - } - return 0; -} - -int HitCheckRayCylinder(const float3 &p0,const float3 &p1,float radius,const float3& _v0,const float3& _v1, float3 *impact,float3 *normal) -{ - assert(impact); - assert(normal); - // only concerned about hitting the sides, not the caps for now - float3x3 m=RotationArc(p1-p0,float3(0,0,1.0f)).getmatrix(); - float h = ((p1-p0)*m ).z; - float3 v0 = (_v0-p0) *m; - float3 v1 = (_v1-p0) *m; - if(v0.z <= 0.0f && v1.z <= 0.0f) return 0; // entirely below cylinder - if(v0.z >= h && v1.z >= h ) return 0; // ray is above cylinder - if(v0.z <0.0f ) v0 = PlaneLineIntersection(float3(0,0,1.0f), 0,v0,v1); // crop to cylinder range - if(v1.z <0.0f ) v1 = PlaneLineIntersection(float3(0,0,1.0f), 0,v0,v1); - if(v0.z > h ) v0 = PlaneLineIntersection(float3(0,0,1.0f),-h,v0,v1); - if(v1.z > h ) v1 = PlaneLineIntersection(float3(0,0,1.0f),-h,v0,v1); - if(v0.x==v1.x && v0.y==v1.y) return 0; - float3 dv = v1-v0; - - float a = dv.x*dv.x+dv.y*dv.y; - float b = 2.0f * (dv.x*v0.x+dv.y*v0.y); - float c = (v0.x*v0.x+v0.y*v0.y) - radius*radius; - if(c<0.0f) return 0; // we are already inside the cylinder . - - float ta, tb; - int doesIntersect = SolveQuadratic(a, b, c, &ta, &tb); - - if (!doesIntersect) return 0; - - if (ta >= 0.0f && ta <= 1.0f && (ta <= tb || tb<=0.0f)) - { - *impact = (v0 + dv * ta)*Transpose(m) + p0; - *normal = (float3(v0.x,v0.y,0.0f) + float3(dv.x,dv.y,0) * ta) /radius * Transpose(m); - return 1; - } - if (tb >= 0.0f && tb <= 1.0f) - { - assert(tb <= ta || ta <=0.0f); // tb must be better than ta - *impact = (v0 + dv * tb)*Transpose(m) + p0; // compute intersection in original space - *normal = (float3(v0.x,v0.y,0.0f) + float3(dv.x,dv.y,0) * tb) /radius * Transpose(m); - return 1; - } - return 0; -} - -int HitCheckSweptSphereTri(const float3 &p0,const float3 &p1,const float3 &p2,float radius, const float3& v0,const float3& _v1, float3 *impact,float3 *normal) -{ - float3 unused; - if(!normal) normal=&unused; - float3 v1=_v1; // so we can update v1 after each sub intersection test if necessary - int hit=0; - float3 cp = cross(p1-p0,p2-p0); - if(dot(cp,v1-v0)>=0.0f) return 0; // coming from behind and/or moving away - float3 n = normalize(cp); - float3 tv[3]; - tv[0] = p0 + n*radius; - tv[1] = p1 + n*radius; - tv[2] = p2 + n*radius; - hit += HitCheckPoly(tv,3,v0,v1,&v1,normal); - hit += HitCheckRayCylinder(p0,p1,radius,v0,v1,&v1,normal); - hit += HitCheckRayCylinder(p1,p2,radius,v0,v1,&v1,normal); - hit += HitCheckRayCylinder(p2,p0,radius,v0,v1,&v1,normal); - hit += HitCheckRaySphere(p0,radius,v0,v1,&v1,normal); - hit += HitCheckRaySphere(p1,radius,v0,v1,&v1,normal); - hit += HitCheckRaySphere(p2,radius,v0,v1,&v1,normal); - if(hit && impact) *impact = v1 + *normal * 0.001f; - return hit; -} - - -float3 PlanesIntersection(const Plane &p0,const Plane &p1, const Plane &p2) -{ - float3x3 mp =Transpose(float3x3(p0.normal(),p1.normal(),p2.normal())); - float3x3 mi = Inverse(mp); - float3 b(p0.dist(),p1.dist(),p2.dist()); - return -b * mi; -} - - -float3 PlanesIntersection(const Plane *planes,int planes_count,const float3 &seed) -{ - int i; - float3x3 A; // gets initilized to 0 matrix - float3 b(0,0,0); - for(i=0;i= count+1 - assert(verts_out); - int n=0; - int prev_status = (dot(plane_normal,verts_in[count_in-1])+plane_dist > 0) ; - for(int i=0;i 0) ; - if(status != prev_status) - { - verts_out[n++] = PlaneLineIntersection(plane_normal,plane_dist,verts_in[(i==0)?count_in-1:i-1],verts_in[i]); - } - if(status==0) // under - { - verts_out[n++] = verts_in[i]; - } - } - assert(n<=count_in+1); // remove if intention to use this routine on convex polygons - return n; -} - -int ClipPolyPoly(const float3 &normal,const float3 *clipper,int clipper_count,const float3 *verts_in, int in_count,float3 *scratch) -{ - // clips polys against each other. - // requires sufficiently allocated temporary memory in scratch buffer - // function returns final number of vertices in clipped polygon. - // Resulting vertices are returned in the scratch buffer. - // if the arrays are the same &verts_in==&scratch the routine should still work anyways. - // the first argument (normal) is the normal of polygon clipper. - // its generally assumed both are convex polygons. - assert(scratch); // size should be >= 2*(clipper_count+in_count) - int i; - int bsize = clipper_count+in_count; - int count = in_count; - for(i=0;iom.y&&om.x>om.z)?0: (om.y>om.z)? 1 : 2; // index of largest element of offdiag - int k1 = (k+1)%3; - int k2 = (k+2)%3; - if(offdiag[k]==0.0f) break; // diagonal already - float thet = (D[k2][k2]-D[k1][k1])/(2.0f*offdiag[k]); - float sgn = (thet>0.0f)?1.0f:-1.0f; - thet *= sgn; // make it positive - float t = sgn /(thet +((thet<1.E6f)?sqrtf(squared(thet)+1.0f):thet)) ; // sign(T)/(|T|+sqrt(T^2+1)) - float c = 1.0f/sqrtf(squared(t)+1.0f); // c= 1/(t^2+1) , t=s/c - if(c==1.0f) break; // no room for improvement - reached machine precision. - Quaternion jr(0,0,0,0); // jacobi rotation for this iteration. - jr[k] = sgn*sqrtf((1.0f-c)/2.0f); // using 1/2 angle identity sin(a/2) = sqrt((1-cos(a))/2) - jr[k] *= -1.0f; // since our quat-to-matrix convention was for v*M instead of M*v - jr.w = sqrtf(1.0f - squared(jr[k])); - if(jr.w==1.0f) break; // reached limits of floating point precision - q = q*jr; - q.Normalize(); - } - return q; -} - -float3 Diagonal(const float3x3 &M) -{ - return float3(M[0][0],M[1][1],M[2][2]); -} diff --git a/Demos3/ImplicitCloth/stan/vecmath.h b/Demos3/ImplicitCloth/stan/vecmath.h deleted file mode 100644 index a83ed8cfb..000000000 --- a/Demos3/ImplicitCloth/stan/vecmath.h +++ /dev/null @@ -1,466 +0,0 @@ -// -// -// Typical 3d vector math code. -// By S Melax 1998-2008 -// -// - -#ifndef SM_VEC_MATH_H -#define SM_VEC_MATH_H - -#include -#include -#include -#include - -#define M_PIf (3.1415926535897932384626433832795f) - -inline float DegToRad(float angle_degrees) { return angle_degrees * M_PIf / 180.0f; } // returns Radians. -inline float RadToDeg(float angle_radians) { return angle_radians * 180.0f / M_PIf; } // returns Degrees. - -#define OFFSET(Class,Member) (((char*) (&(((Class*)NULL)-> Member )))- ((char*)NULL)) - - - - -int argmin(const float a[],int n); -int argmax(const float a[],int n); -float squared(float a); -float clamp(float a,const float minval=0.0f, const float maxval=1.0f); -int clamp(int a,const int minval,const int maxval) ; -float Round(float a,float precision); -float Interpolate(const float &f0,const float &f1,float alpha) ; - -template -void Swap(T &a,T &b) -{ - T tmp = a; - a=b; - b=tmp; -} - - - -template -T Max(const T &a,const T &b) -{ - return (a>b)?a:b; -} - -template -T Min(const T &a,const T &b) -{ - return (a -class vec2 -{ - public: - T x,y; - inline vec2(){x=0;y=0;} - inline vec2(const T &_x, const T &_y){x=_x;y=_y;} - inline T& operator[](int i) {return ((T*)this)[i];} - inline const T& operator[](int i) const {return ((T*)this)[i];} -}; - -typedef vec2 int2; -typedef vec2 float2; - - -template inline int operator ==(const vec2 &a,const vec2 &b) {return (a.x==b.x && a.y==b.y);} -template inline vec2 operator-( const vec2& a, const vec2& b ){return vec2(a.x-b.x,a.y-b.y);} -template inline vec2 operator+( const vec2& a, const vec2& b ){return float2(a.x+b.x,a.y+b.y);} - -//--------- 3D --------- - - - -template -class vec3 -{ - public: - T x,y,z; - inline vec3(){x=0;y=0;z=0;}; - inline vec3(const T &_x,const T &_y,const T &_z){x=_x;y=_y;z=_z;}; - inline T& operator[](int i) {return ((T*)this)[i];} - inline const T& operator[](int i) const {return ((T*)this)[i];} -}; - - -typedef vec3 int3; -typedef vec3 short3; -typedef vec3 float3; - -// due to ambiguity there is no overloaded operators for v3*v3 use dot,cross,outerprod,cmul -template inline int operator==(const vec3 &a,const vec3 &b) {return (a.x==b.x && a.y==b.y && a.z==b.z);} -template inline int operator!=(const vec3 &a,const vec3 &b) {return !(a==b);} -template inline vec3 operator+(const vec3& a, const vec3& b ){return vec3(a.x+b.x, a.y+b.y, a.z+b.z);} -template inline vec3 operator-(const vec3& a, const vec3& b ){return vec3(a.x-b.x, a.y-b.y, a.z-b.z);} -template inline vec3 operator-(const vec3& v){return vec3(-v.x,-v.y,-v.z );} -template inline vec3 operator*(const vec3& v, const T &s ){ return vec3( v.x*s, v.y*s, v.z*s );} -template inline vec3 operator*(T s, const vec3& v ){return v*s;} -template inline vec3 operator/(const vec3& v, T s ){return vec3( v.x/s, v.y/s, v.z/s );} -template inline T dot (const vec3& a, const vec3& b){return a.x*b.x + a.y*b.y + a.z*b.z;} -template inline vec3 cmul (const vec3& a, const vec3& b){return vec3(a.x*b.x, a.y*b.y, a.z*b.z);} -template inline vec3 cross(const vec3& a, const vec3& b){return vec3(a.y*b.z-a.z*b.y, a.z*b.x-a.x*b.z, a.x*b.y-a.y*b.x);} -template inline T magnitude( const vec3& v ){return squareroot(dot(v,v));} -template inline vec3 normalize( const vec3& v ){return v/magnitude(v);} -template inline vec3& operator+=(vec3& a, const vec3& b){a.x+=b.x;a.y+=b.y;a.z+=b.z;return a;} -template inline vec3& operator-=(vec3& a, const vec3& b){a.x-=b.x;a.y-=b.y;a.z-=b.z;return a;} -template inline vec3& operator*=(vec3& v, T s){v.x*=s;v.y*=s;v.z*= s;return v;} -template inline vec3& operator/=(vec3& v, T s){v.x/=s;v.y/=s;v.z/=s;return v;} - - -float3 safenormalize(const float3 &v); -float3 vabs(const float3 &v); -float3 Interpolate(const float3 &v0,const float3 &v1,float alpha); -float3 Round(const float3& a,float precision); -template inline vec3VectorMin(const vec3 &a,const vec3 &b) {return vec3(Min(a.x,b.x),Min(a.y,b.y),Min(a.z,b.z));} -template inline vec3VectorMax(const vec3 &a,const vec3 &b) {return vec3(Max(a.x,b.x),Max(a.y,b.y),Max(a.z,b.z));} -int overlap(const float3 &bmina,const float3 &bmaxa,const float3 &bminb,const float3 &bmaxb); - -template -class mat3x3 -{ - public: - vec3 x,y,z; // the 3 rows of the Matrix - inline mat3x3(){} - inline mat3x3(const T &xx,const T &xy,const T &xz,const T &yx,const T &yy,const T &yz,const T &zx,const T &zy,const T &zz):x(xx,xy,xz),y(yx,yy,yz),z(zx,zy,zz){} - inline mat3x3(const vec3 &_x,const vec3 &_y,const vec3 &_z):x(_x),y(_y),z(_z){} - inline vec3& operator[](int i) {return (&x)[i];} - inline const vec3& operator[](int i) const {return (&x)[i];} - inline T& operator()(int r, int c) {return ((&x)[r])[c];} - inline const T& operator()(int r, int c) const {return ((&x)[r])[c];} -}; -typedef mat3x3 float3x3; - -float3x3 Transpose( const float3x3& m ); -template vec3 operator*( const vec3& v , const mat3x3& m ) -{ - return vec3((m.x.x*v.x + m.y.x*v.y + m.z.x*v.z), - (m.x.y*v.x + m.y.y*v.y + m.z.y*v.z), - (m.x.z*v.x + m.y.z*v.y + m.z.z*v.z)); -} - -float3 operator*( const float3x3& m , const float3& v ); -float3x3 operator*( const float3x3& m , const float& s ); -float3x3 operator*( const float3x3& ma, const float3x3& mb ); -float3x3 operator/( const float3x3& a, const float& s ) ; -float3x3 operator+( const float3x3& a, const float3x3& b ); -float3x3 operator-( const float3x3& a, const float3x3& b ); -float3x3 &operator+=( float3x3& a, const float3x3& b ); -float3x3 &operator-=( float3x3& a, const float3x3& b ); -float3x3 &operator*=( float3x3& a, const float& s ); -float Determinant(const float3x3& m ); -float3x3 Inverse(const float3x3& a); // its just 3x3 so we simply do that cofactor method -float3x3 outerprod(const float3& a,const float3& b); - -//-------- 4D Math -------- - -template -class vec4 -{ -public: - T x,y,z,w; - inline vec4(){x=0;y=0;z=0;w=0;}; - inline vec4(const T &_x, const T &_y, const T &_z, const T &_w){x=_x;y=_y;z=_z;w=_w;} - inline vec4(const vec3 &v,const T &_w){x=v.x;y=v.y;z=v.z;w=_w;} - //operator float *() { return &x;}; - T& operator[](int i) {return ((T*)this)[i];} - const T& operator[](int i) const {return ((T*)this)[i];} - inline const vec3& xyz() const { return *((vec3*)this);} - inline vec3& xyz() { return *((vec3*)this);} -}; - - -typedef vec4 float4; -typedef vec4 int4; -typedef vec4 byte4; - - -template inline int operator==(const vec4 &a,const vec4 &b) {return (a.x==b.x && a.y==b.y && a.z==b.z && a.w==b.w);} -template inline int operator!=(const vec4 &a,const vec4 &b) {return !(a==b);} -template inline vec4 operator+(const vec4& a, const vec4& b ){return vec4(a.x+b.x,a.y+b.y,a.z+b.z,a.w+b.w);} -template inline vec4 operator-(const vec4& a, const vec4& b ){return vec4(a.x-b.x,a.y-b.y,a.z-b.z,a.w-b.w);} -template inline vec4 operator-(const vec4& v){return vec4(-v.x,-v.y,-v.z,-v.w);} -template inline vec4 operator*(const vec4& v, const T &s ){ return vec4( v.x*s, v.y*s, v.z*s,v.w*s);} -template inline vec4 operator*(T s, const vec4& v ){return v*s;} -template inline vec4 operator/(const vec4& v, T s ){return vec4( v.x/s, v.y/s, v.z/s,v.w/s );} -template inline T dot(const vec4& a, const vec4& b ){return a.x*b.x + a.y*b.y + a.z*b.z+a.w*b.w;} -template inline vec4 cmul(const vec4 &a, const vec4 &b) {return vec4(a.x*b.x, a.y*b.y, a.z*b.z,a.w*b.w);} -template inline vec4& operator+=(vec4& a, const vec4& b ){a.x+=b.x;a.y+=b.y;a.z+=b.z;a.w+=b.w;return a;} -template inline vec4& operator-=(vec4& a, const vec4& b ){a.x-=b.x;a.y-=b.y;a.z-=b.z;a.w-=b.w;return a;} -template inline vec4& operator*=(vec4& v, T s){v.x*=s;v.y*=s;v.z*=s;v.w*=s;return v;} -template inline vec4& operator/=(vec4& v, T s){v.x/=s;v.y/=s;v.z/=s;v.w/=s;return v;} -template inline T magnitude( const vec4& v ){return squareroot(dot(v,v));} -template inline vec4 normalize( const vec4& v ){return v/magnitude(v);} - - - -struct D3DXMATRIX; - -template -class mat4x4 -{ - public: - vec4 x,y,z,w; // the 4 rows - inline mat4x4(){} - inline mat4x4(const vec4 &_x, const vec4 &_y, const vec4 &_z, const vec4 &_w):x(_x),y(_y),z(_z),w(_w){} - inline mat4x4(const T& m00, const T& m01, const T& m02, const T& m03, - const T& m10, const T& m11, const T& m12, const T& m13, - const T& m20, const T& m21, const T& m22, const T& m23, - const T& m30, const T& m31, const T& m32, const T& m33 ) - :x(m00,m01,m02,m03),y(m10,m11,m12,m13),z(m20,m21,m22,m23),w(m30,m31,m32,m33){} - inline vec4& operator[](int i) {assert(i>=0&&i<4);return (&x)[i];} - inline const vec4& operator[](int i) const {assert(i>=0&&i<4);return (&x)[i];} - inline T& operator()(int r, int c) {assert(r>=0&&r<4&&c>=0&&c<4);return ((&x)[r])[c];} - inline const T& operator()(int r, int c) const {assert(r>=0&&r<4&&c>=0&&c<4);return ((&x)[r])[c];} - inline operator T* () {return &x.x;} - inline operator const T* () const {return &x.x;} - operator struct D3DXMATRIX* () { return (struct D3DXMATRIX*) this;} - operator const struct D3DXMATRIX* () const { return (struct D3DXMATRIX*) this;} -}; - -typedef mat4x4 float4x4; - - -float4x4 operator*( const float4x4& a, const float4x4& b ); -float4 operator*( const float4& v, const float4x4& m ); -float4x4 Inverse(const float4x4 &m); -float4x4 MatrixRigidInverse(const float4x4 &m); -float4x4 MatrixTranspose(const float4x4 &m); -float4x4 MatrixPerspectiveFov(float fovy, float Aspect, float zn, float zf ); -float4x4 MatrixTranslation(const float3 &t); -float4x4 MatrixRotationZ(const float angle_radians); -float4x4 MatrixLookAt(const float3& eye, const float3& at, const float3& up); -int operator==( const float4x4 &a, const float4x4 &b ); - - -//-------- Quaternion ------------ - -template -class quaternion : public vec4 -{ - public: - inline quaternion() { this->x = this->y = this->z = 0.0f; this->w = 1.0f; } - inline quaternion(const T &_x, const T &_y, const T &_z, const T &_w){this->x=_x;this->y=_y;this->z=_z;this->w=_w;} - inline explicit quaternion(const vec4 &v):vec4(v){} - T angle() const { return acosf(this->w)*2.0f; } - vec3 axis() const { vec3 a(this->x,this->y,this->z); if(fabsf(angle())<0.0000001f) return vec3(1,0,0); return a*(1/sinf(angle()/2.0f)); } - inline vec3 xdir() const { return vec3( 1-2*(this->y*this->y+this->z*this->z), 2*(this->x*this->y+this->w*this->z), - 2*(this->x*this->z-this->w*this->y) ); } - inline vec3 ydir() const { return vec3( 2*(this->x*this->y-this->w*this->z),1-2*(this->x*this->x+this->z*this->z), 2*(this->y*this->z+this->w*this->x) ); } - inline vec3 zdir() const { return vec3( 2*(this->x*this->z+this->w*this->y), - 2*(this->y*this->z-this->w*this->x),1- - 2*(this->x*this->x+this->y*this->y) ); } - inline mat3x3 getmatrix() const { return mat3x3( xdir(), ydir(), zdir() ); } - //operator float3x3() { return getmatrix(); } - void Normalize(); -}; - -template -inline quaternion quatfrommat(const mat3x3 &m) -{ - T magw = m[0 ][ 0] + m[1 ][ 1] + m[2 ][ 2]; - T magxy; - T magzw; - vec3 pre; - vec3 prexy; - vec3 prezw; - quaternion postxy; - quaternion postzw; - quaternion post; - int wvsz = (magw > m[2][2] ) ; - magzw = (wvsz) ? magw : m[2][2]; - prezw = (wvsz) ? vec3(1.0f,1.0f,1.0f) : vec3(-1.0f,-1.0f,1.0f) ; - postzw = (wvsz) ? quaternion(0.0f,0.0f,0.0f,1.0f): quaternion(0.0f,0.0f,1.0f,0.0f); - int xvsy = (m[0][0]>m[1][1]); - magxy = (xvsy) ? m[0][0] : m[1][1]; - prexy = (xvsy) ? vec3(1.0f,-1.0f,-1.0f) : vec3(-1.0f,1.0f,-1.0f) ; - postxy = (xvsy) ? quaternion(1.0f,0.0f,0.0f,0.0f): quaternion(0.0f,1.0f,0.0f,0.0f); - int zwvsxy = (magzw > magxy); - pre = (zwvsxy) ? prezw : prexy ; - post = (zwvsxy) ? postzw : postxy; - - T t = pre.x * m[0 ][ 0] + pre.y * m[1 ][ 1] + pre.z * m[2 ][ 2] + 1.0f; - T s = 1/sqrt(t) * 0.5f; - quaternion qp; - qp.x = ( pre.y * m[1][2] - pre.z * m[2][1] ) * s; - qp.y = ( pre.z * m[2][0] - pre.x * m[0][2] ) * s; - qp.z = ( pre.x * m[0][1] - pre.y * m[1][0] ) * s; - qp.w = t * s ; - return qp * post ; -} - -typedef quaternion Quaternion; - -inline Quaternion QuatFromAxisAngle(const float3 &_v, float angle_radians ) -{ - float3 v = normalize(_v)*sinf(angle_radians/2.0f); - return Quaternion(v.x,v.y,v.z,cosf(angle_radians/2.0f)); -} - -template inline quaternion Conjugate(const quaternion &q){return quaternion(-q.x,-q.y,-q.z,q.w);} -template inline quaternion Inverse(const quaternion &q){return Conjugate(q);} -template inline quaternion normalize( const quaternion & a ){return quaternion (normalize((vec4&)a));} -template inline quaternion& operator*=(quaternion& a, T s ){return (quaternion&)((vec4&)a *=s);} -template inline quaternion operator*( const quaternion& a, float s ){return quaternion((vec4&)a*s);} -template inline quaternion operator+( const quaternion& a, const quaternion& b){return quaternion((vec4&)a+(vec4&)b);} -template inline quaternion operator-( const quaternion& a, const quaternion& b){return quaternion((vec4&)a-(vec4&)b);} -template inline quaternion operator-( const quaternion& b){return quaternion(-(vec4&)b);} -template inline quaternion operator*( const quaternion& a, const quaternion& b) -{ - return quaternion( - a.w*b.x + a.x*b.w + a.y*b.z - a.z*b.y, //x - a.w*b.y - a.x*b.z + a.y*b.w + a.z*b.x, //y - a.w*b.z + a.x*b.y - a.y*b.x + a.z*b.w, //z - a.w*b.w - a.x*b.x - a.y*b.y - a.z*b.z ); //w -} - - -float3 rotate( const Quaternion& q, const float3& v ); -//float3 operator*( const Quaternion& q, const float3& v ); -//float3 operator*( const float3& v, const Quaternion& q ); - -Quaternion slerp(const Quaternion &a, const Quaternion& b, float t ); -Quaternion Interpolate(const Quaternion &q0,const Quaternion &q1,float t); -Quaternion RotationArc(float3 v0, float3 v1 ); // returns quat q where q*v0*q^-1=v1 -float4x4 MatrixFromQuatVec(const Quaternion &q, const float3 &v); - -inline Quaternion QuatFromMat(const float3 &t, const float3 &b, const float3 &n) -{ - return normalize(quatfrommat(float3x3(t,b,n))); -} - - -//---------------- Pose ------------------ - -class Pose -{ -public: - float3 position; - Quaternion orientation; - Pose(){} - Pose(const float3 &p,const Quaternion &q):position(p),orientation(q){} - Pose &pose(){return *this;} - const Pose &pose() const {return *this;} -}; - -inline float3 operator*(const Pose &a,const float3 &v) -{ - return a.position + rotate(a.orientation,v); -} - -inline Pose operator*(const Pose &a,const Pose &b) -{ - return Pose(a.position + rotate(a.orientation,b.position),a.orientation*b.orientation); -} - -inline Pose Inverse(const Pose &a) -{ - Quaternion q = Inverse(a.orientation); - return Pose(rotate(q,-a.position),q); -} - -inline Pose slerp(const Pose &p0,const Pose &p1,float t) -{ - return Pose(p0.position * (1.0f-t) + p1.position * t,slerp(p0.orientation,p1.orientation,t)); -} - -inline float4x4 MatrixFromPose(const Pose &pose) -{ - return MatrixFromQuatVec(pose.orientation,pose.position); -} - -//------ Euler Angle ----- - -Quaternion YawPitchRoll( float yaw, float pitch, float roll ); -float Yaw( const Quaternion& q ); -float Pitch( const Quaternion& q ); -float Roll( const Quaternion &q ); -float Yaw( const float3& v ); -float Pitch( const float3& v ); - -//------- Plane ---------- -class Plane : public float4 -{ - public: - float3& normal(){ return xyz(); } - const float3& normal() const { return xyz(); } - float& dist(){return w;} // distance below origin - the D from plane equasion Ax+By+Cz+D=0 - const float& dist() const{return w;} // distance below origin - the D from plane equasion Ax+By+Cz+D=0 - Plane(const float3 &n,float d):float4(n,d){} - Plane(){dist()=0;} - explicit Plane(const float4 &v):float4(v){} -}; - -Plane Transform(const Plane &p, const float3 &translation, const Quaternion &rotation); - -inline Plane PlaneFlip(const Plane &p){return Plane(-p.normal(),-p.dist());} -inline int operator==( const Plane &a, const Plane &b ) { return (a.normal()==b.normal() && a.dist()==b.dist()); } -inline int coplanar( const Plane &a, const Plane &b ) { return (a==b || a==PlaneFlip(b)); } - -float3 PlaneLineIntersection(const Plane &plane, const float3 &p0, const float3 &p1); -float3 PlaneProject(const Plane &plane, const float3 &point); -float3 PlanesIntersection(const Plane &p0,const Plane &p1, const Plane &p2); -float3 PlanesIntersection(const Plane *planes,int planes_count,const float3 &seed=float3(0,0,0)); - -int Clip(const Plane &p,const float3 *verts_in,int count,float* verts_out); // verts_out must be preallocated with sufficient size >= count+1 or more if concave -int ClipPolyPoly(const float3 &normal,const float3 *clipper,int clipper_count,const float3 *verts_in, int in_count,float3 *scratch); //scratch must be preallocated - - -//--------- Utility Functions ------ - -float3 PlaneLineIntersection(const float3 &normal,const float dist, const float3 &p0, const float3 &p1); -float3 LineProject(const float3 &p0, const float3 &p1, const float3 &a); // projects a onto infinite line p0p1 -float LineProjectTime(const float3 &p0, const float3 &p1, const float3 &a); -int BoxInside(const float3 &p,const float3 &bmin, const float3 &bmax) ; -int BoxIntersect(const float3 &v0, const float3 &v1, const float3 &bmin, const float3 &bmax, float3 *impact); -float DistanceBetweenLines(const float3 &ustart, const float3 &udir, const float3 &vstart, const float3 &vdir, float3 *upoint=NULL, float3 *vpoint=NULL); -float3 TriNormal(const float3 &v0, const float3 &v1, const float3 &v2); -float3 NormalOf(const float3 *vert, const int n); -Quaternion VirtualTrackBall(const float3 &cop, const float3 &cor, const float3 &dir0, const float3 &dir1); -int Clip(const float3 &plane_normal,float plane_dist,const float3 *verts_in,int count,float* verts_out); // verts_out must be preallocated with sufficient size >= count+1 or more if concave -int ClipPolyPoly(const float3 &normal,const float3 *clipper,int clipper_count,const float3 *verts_in, int in_count,float3 *scratch); //scratch must be preallocated -float3 Diagonal(const float3x3 &M); -Quaternion Diagonalizer(const float3x3 &A); -float3 Orth(const float3& v); -int SolveQuadratic(float a,float b,float c,float *ta,float *tb); // if true returns roots ta,tb where ta<=tb -int HitCheckPoly(const float3 *vert,const int n,const float3 &v0, const float3 &v1, float3 *impact=NULL, float3 *normal=NULL); -int HitCheckRaySphere(const float3& sphereposition,float radius, const float3& _v0, const float3& _v1, float3 *impact,float3 *normal); -int HitCheckRayCylinder(const float3 &p0,const float3 &p1,float radius,const float3& _v0,const float3& _v1, float3 *impact,float3 *normal); -int HitCheckSweptSphereTri(const float3 &p0,const float3 &p1,const float3 &p2,float radius, const float3& v0,const float3& _v1, float3 *impact,float3 *normal); -void BoxLimits(const float3 *verts,int verts_count, float3 &bmin_out,float3 &bmax_out); -void BoxLimits(const float4 *verts,int verts_count, float3 &bmin_out,float3 &bmax_out); - - -template -inline int maxdir(const T *p,int count,const T &dir) -{ - assert(count); - int m=0; - for(int i=1;idot(p[m],dir)) m=i; - } - return m; -} - -float3 CenterOfMass(const float3 *vertices, const int3 *tris, const int count) ; -float3x3 Inertia(const float3 *vertices, const int3 *tris, const int count, const float3& com=float3(0,0,0)) ; -float Volume(const float3 *vertices, const int3 *tris, const int count) ; -int calchull(float3 *verts,int verts_count, int3 *&tris_out, int &tris_count,int vlimit); // computes convex hull see hull.cpp - -#endif // VEC_MATH_H diff --git a/Demos3/ImportColladaDemo/ColladaGraphicsInstance.h b/Demos3/ImportColladaDemo/ColladaGraphicsInstance.h deleted file mode 100644 index 65f703760..000000000 --- a/Demos3/ImportColladaDemo/ColladaGraphicsInstance.h +++ /dev/null @@ -1,35 +0,0 @@ -/* -Bullet Collision Detection and Physics Library http://bulletphysics.org -This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -//original author: Erwin Coumans -*/ - -#ifndef COLLADA_GRAPHICS_INSTANCE_H -#define COLLADA_GRAPHICS_INSTANCE_H - -#include "btMatrix4x4.h" - -struct ColladaGraphicsInstance -{ - ColladaGraphicsInstance() - :m_shapeIndex(-1) - { - m_worldTransform.setIdentity(); - } - btMatrix4x4 m_worldTransform; - int m_shapeIndex;//could be index into array of GLInstanceGraphicsShape - float m_color[4]; -}; - -#endif //COLLADA_GRAPHICS_INSTANCE_H diff --git a/Demos3/ImportColladaDemo/ImportColladaSetup.cpp b/Demos3/ImportColladaDemo/ImportColladaSetup.cpp deleted file mode 100644 index da2f1a9d2..000000000 --- a/Demos3/ImportColladaDemo/ImportColladaSetup.cpp +++ /dev/null @@ -1,184 +0,0 @@ -/* -Bullet Collision Detection and Physics Library http://bulletphysics.org -This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -//original author: Erwin Coumans -*/ - - -#include "ImportColladaSetup.h" -#include -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include "btBulletDynamicsCommon.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "LoadMeshFromCollada.h" -#include "Bullet3Common/b3FileUtils.h" - -ImportColladaSetup::ImportColladaSetup(CommonGraphicsApp* app) -:m_app(app) -{ - -} - -ImportColladaSetup::~ImportColladaSetup() -{ - -} - -static int ColladaGraphicsInstanceSortfnc(const ColladaGraphicsInstance& a,const ColladaGraphicsInstance& b) -{ - if (a.m_shapeIndexb.m_shapeIndex) return -1; - return 0; -} - - -void ImportColladaSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - int upAxis=1; - gfxBridge.setUpAxis(upAxis); - this->createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawWireframe); - - static int fileIndex = 0; - - const char* fileNames[] = { - "duck.dae", - "seymourplane_triangulate.dae", - }; - const char* fileName = fileNames[fileIndex]; - int numFiles = sizeof(fileNames)/sizeof(const char*); - - char relativeFileName[1024]; - - b3FileUtils f; - if (!f.findFile(fileName,relativeFileName,1024)) - return; - - btVector3 shift(0,0,0); - btVector3 scaling(1,1,1); -// int index=10; - - - - - - - - { - - btAlignedObjectArray visualShapes; - btAlignedObjectArray visualShapeInstances; - - float unitMeterScaling(1); - btTransform upAxisTrans; - upAxisTrans.setIdentity(); - - btVector3 color(0,0,1); - -#ifdef COMPARE_WITH_ASSIMP - static int useAssimp = 0; - if (useAssimp) - { - - LoadMeshFromColladaAssimp(relativeFileName, visualShapes, visualShapeInstances,upAxisTrans,unitMeterScaling); - fileIndex++; - if (fileIndex>=numFiles) - { - fileIndex = 0; - } - color.setValue(1,0,0); - } - else - { - LoadMeshFromCollada(relativeFileName, visualShapes, visualShapeInstances,upAxisTrans,unitMeterScaling); - - } - useAssimp=1-useAssimp; -#else - fileIndex++; - if (fileIndex>=numFiles) - { - fileIndex = 0; - } - LoadMeshFromCollada(relativeFileName, visualShapes, visualShapeInstances,upAxisTrans,unitMeterScaling, upAxis); -#endif// COMPARE_WITH_ASSIMP - - - //at the moment our graphics engine requires instances that share the same visual shape to be added right after registering the shape - //so perform a sort, just to be sure - visualShapeInstances.quickSort(ColladaGraphicsInstanceSortfnc); - - for (int i=0;im_shapeIndex]; - btVector3 position(0,0,0);// = scaling*btVector3(instance->m_pos[0],instance->m_pos[1],instance->m_pos[2]); - btQuaternion orn(0,0,0,1);//instance->m_orn[0],instance->m_orn[1],instance->m_orn[2],instance->m_orn[3]); - - //sort the visualShapeInstances, then iterate etc - //void LoadMeshFromCollada(const char* relativeFileName, - //btAlignedObjectArray& visualShapes, - //btAlignedObjectArray visualShapeInstances); - - if (gfxShape) - { - //btTransform trans; - //trans.setIdentity(); - //trans.setRotation(btQuaternion(btVector3(1,0,0),SIMD_HALF_PI)); - - - - b3AlignedObjectArray verts; - verts.resize(gfxShape->m_vertices->size()); - - for (int i=0;im_vertices->size();i++) - { - verts[i].normal[0] = gfxShape->m_vertices->at(i).normal[0]; - verts[i].normal[1] = gfxShape->m_vertices->at(i).normal[1]; - verts[i].normal[2] = gfxShape->m_vertices->at(i).normal[2]; - verts[i].uv[0] = gfxShape->m_vertices->at(i).uv[0]; - verts[i].uv[1] = gfxShape->m_vertices->at(i).uv[1]; - verts[i].xyzw[0] = gfxShape->m_vertices->at(i).xyzw[0]; - verts[i].xyzw[1] = gfxShape->m_vertices->at(i).xyzw[1]; - verts[i].xyzw[2] = gfxShape->m_vertices->at(i).xyzw[2]; - verts[i].xyzw[3] = gfxShape->m_vertices->at(i).xyzw[3]; - } - - //compensate upAxisTrans and unitMeterScaling here - btMatrix4x4 upAxisMat; - upAxisMat.setPureRotation(upAxisTrans.getRotation()); - btMatrix4x4 unitMeterScalingMat; - unitMeterScalingMat.setPureScaling(btVector3(unitMeterScaling,unitMeterScaling,unitMeterScaling)); - btMatrix4x4 worldMat = unitMeterScalingMat*upAxisMat*instance->m_worldTransform; - //btMatrix4x4 worldMat = instance->m_worldTransform; - for(int v=0;vm_renderer->registerShape(&verts[0].xyzw[0], gfxShape->m_numvertices, &gfxShape->m_indices->at(0), gfxShape->m_numIndices); - - //btVector3 instanceScaling(instance->m_scaling[0],instance->m_scaling[1],instance->m_scaling[2]); - m_app->m_renderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - } - } - } - -} diff --git a/Demos3/ImportColladaDemo/ImportColladaSetup.h b/Demos3/ImportColladaDemo/ImportColladaSetup.h deleted file mode 100644 index d95a4b679..000000000 --- a/Demos3/ImportColladaDemo/ImportColladaSetup.h +++ /dev/null @@ -1,35 +0,0 @@ -/* -Bullet Collision Detection and Physics Library http://bulletphysics.org -This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -//original author: Erwin Coumans -*/ - - -#ifndef IMPORT_COLLADA_SETUP_H -#define IMPORT_COLLADA_SETUP_H - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -class ImportColladaSetup : public CommonRigidBodySetup -{ - struct CommonGraphicsApp* m_app; -public: - ImportColladaSetup(CommonGraphicsApp* app); - virtual ~ImportColladaSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); -}; - -#endif //IMPORT_COLLADA_SETUP_H diff --git a/Demos3/ImportColladaDemo/LoadMeshFromCollada.cpp b/Demos3/ImportColladaDemo/LoadMeshFromCollada.cpp deleted file mode 100644 index f5b345ec4..000000000 --- a/Demos3/ImportColladaDemo/LoadMeshFromCollada.cpp +++ /dev/null @@ -1,748 +0,0 @@ -/* -Bullet Collision Detection and Physics Library http://bulletphysics.org -This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -//original author: Erwin Coumans -*/ - - -#include "LoadMeshFromCollada.h" -#include //fopen -#include "Bullet3Common/b3AlignedObjectArray.h" -#include -#include "tinyxml/tinyxml.h" - -#include "Bullet3Common/b3FileUtils.h" -#include "LinearMath/btHashMap.h" -#include -#include "btMatrix4x4.h" - - - - -struct VertexSource -{ - std::string m_positionArrayId; - std::string m_normalArrayId; -}; - -struct TokenFloatArray -{ - btAlignedObjectArray& m_values; - TokenFloatArray(btAlignedObjectArray& floatArray) - :m_values(floatArray) { - } - inline void add(const char* token) - { - float v = atof(token); - m_values.push_back(v); - } -}; -struct TokenIntArray -{ - btAlignedObjectArray& m_values; - TokenIntArray(btAlignedObjectArray& intArray) - :m_values(intArray) { - } - inline void add(const char* token) - { - float v = atoi(token); - m_values.push_back(v); - } -}; - -template -void tokenize(const std::string& str, AddToken& tokenAdder, const std::string& delimiters = " ") -{ - std::string::size_type pos, lastPos = 0; - while(true) - { - pos = str.find_first_of(delimiters, lastPos); - if(pos == std::string::npos) - { - pos = str.length(); - if(pos != lastPos) - { - tokenAdder.add(str.data()+lastPos); - } - break; - } - else - { - if(pos != lastPos) - { - tokenAdder.add(str.data()+lastPos); - } - } - lastPos = pos + 1; - } -} - - -void readFloatArray(TiXmlElement* source, btAlignedObjectArray& floatArray, int& componentStride) -{ - int numVals, stride; - TiXmlElement* array = source->FirstChildElement("float_array"); - if(array) - { - componentStride = 1; - if (source->FirstChildElement("technique_common")->FirstChildElement("accessor")->QueryIntAttribute("stride", &stride)!= TIXML_NO_ATTRIBUTE) - { - componentStride = stride; - } - array->QueryIntAttribute("count", &numVals); - TokenFloatArray adder(floatArray); - floatArray.reserve(numVals); - tokenize(array->GetText(),adder); - assert(floatArray.size() == numVals); - } -} - -btVector3 getVector3FromXmlText(const char* text) -{ - btVector3 vec(0,0,0); - btAlignedObjectArray floatArray; - TokenFloatArray adder(floatArray); - floatArray.reserve(3); - tokenize(text,adder); - assert(floatArray.size() == 3); - if (floatArray.size()==3) - { - vec.setValue(floatArray[0],floatArray[1],floatArray[2]); - } - return vec; -} - -btVector4 getVector4FromXmlText(const char* text) -{ - btVector4 vec(0,0,0,0); - btAlignedObjectArray floatArray; - TokenFloatArray adder(floatArray); - floatArray.reserve(4); - tokenize(text,adder); - assert(floatArray.size() == 4); - if (floatArray.size()==4) - { - vec.setValue(floatArray[0],floatArray[1],floatArray[2],floatArray[3]); - } - return vec; -} - - -void readLibraryGeometries(TiXmlDocument& doc, btAlignedObjectArray& visualShapes, btHashMap& name2Shape, float extraScaling) -{ - btHashMap allSources; - btHashMap vertexSources; - for(TiXmlElement* geometry = doc.RootElement()->FirstChildElement("library_geometries")->FirstChildElement("geometry"); - geometry != NULL; geometry = geometry->NextSiblingElement("geometry")) - { - btAlignedObjectArray vertexPositions; - btAlignedObjectArray vertexNormals; - btAlignedObjectArray indices; - - const char* geometryName = geometry->Attribute("id"); - for (TiXmlElement* mesh = geometry->FirstChildElement("mesh");(mesh != NULL); mesh = mesh->NextSiblingElement("mesh")) - { - TiXmlElement* vertices2 = mesh->FirstChildElement("vertices"); - - for (TiXmlElement* source = mesh->FirstChildElement("source");source != NULL;source = source->NextSiblingElement("source")) - { - const char* srcId= source->Attribute("id"); -// printf("source id=%s\n",srcId); - allSources.insert(srcId,source); - } - const char* vertexId = vertices2->Attribute("id"); - //printf("vertices id=%s\n",vertexId); - VertexSource vs; - for(TiXmlElement* input = vertices2->FirstChildElement("input");input != NULL;input = input->NextSiblingElement("input")) - { - const char* sem = input->Attribute("semantic"); - std::string semName(sem); -// printf("sem=%s\n",sem); - const char* src = input->Attribute("source"); -// printf("src=%s\n",src); - const char* srcIdRef = input->Attribute("source"); - std::string source_name; - source_name = std::string(srcIdRef); - source_name = source_name.erase(0, 1); - if (semName=="POSITION") - { - vs.m_positionArrayId = source_name; - } - if (semName=="NORMAL") - { - vs.m_normalArrayId = source_name; - } - } - vertexSources.insert(vertexId,vs); - - for (TiXmlElement* primitive = mesh->FirstChildElement("triangles"); primitive; primitive = primitive->NextSiblingElement("triangles")) - { - std::string positionSourceName; - std::string normalSourceName; - int primitiveCount; - primitive->QueryIntAttribute("count", &primitiveCount); - bool positionAndNormalInVertex=false; - int indexStride=1; - int posOffset = 0; - int normalOffset = 0; - int numIndices = 0; - { - for (TiXmlElement* input = primitive->FirstChildElement("input");input != NULL;input = input->NextSiblingElement("input")) - { - const char* sem = input->Attribute("semantic"); - std::string semName(sem); - int offset = atoi(input->Attribute("offset")); - if ((offset+1)>indexStride) - indexStride=offset+1; - //printf("sem=%s\n",sem); - const char* src = input->Attribute("source"); - //printf("src=%s\n",src); - const char* srcIdRef = input->Attribute("source"); - std::string source_name; - source_name = std::string(srcIdRef); - source_name = source_name.erase(0, 1); - - if (semName=="VERTEX") - { - //now we have POSITION and possibly NORMAL too, using same index array (

) - VertexSource* vs = vertexSources[source_name.c_str()]; - if (vs->m_positionArrayId.length()) - { - positionSourceName = vs->m_positionArrayId; - posOffset = offset; - } - if (vs->m_normalArrayId.length()) - { - normalSourceName = vs->m_normalArrayId; - normalOffset = offset; - positionAndNormalInVertex = true; - } - } - if (semName=="NORMAL") - { - btAssert(normalSourceName.length()==0); - normalSourceName = source_name; - normalOffset = offset; - positionAndNormalInVertex = false; - } - } - numIndices = primitiveCount * 3; - } - btAlignedObjectArray positionFloatArray; - int posStride=1; - TiXmlElement** sourcePtr = allSources[positionSourceName.c_str()]; - if (sourcePtr) - { - readFloatArray(*sourcePtr,positionFloatArray, posStride); - } - btAlignedObjectArray normalFloatArray; - int normalStride=1; - sourcePtr = allSources[normalSourceName.c_str()]; - if (sourcePtr) - { - readFloatArray(*sourcePtr,normalFloatArray,normalStride); - } - btAlignedObjectArray curIndices; - curIndices.reserve(numIndices*indexStride); - TokenIntArray adder(curIndices); - tokenize(primitive->FirstChildElement("p")->GetText(),adder); - assert(curIndices.size() == numIndices*indexStride); - int indexOffset = vertexPositions.size(); - - for(int index=0; indexnormalIndex)) - { - vertexNormals.push_back(btVector3(normalFloatArray[normalIndex*3+0], - normalFloatArray[normalIndex*3+1], - normalFloatArray[normalIndex*3+2])); - } else - { - //add a dummy normal of length zero, so it is easy to detect that it is an invalid normal - vertexNormals.push_back(btVector3(0,0,0)); - } - } - int curNumIndices = indices.size(); - indices.resize(curNumIndices+numIndices); - for(int index=0; index; - visualShape.m_indices = new b3AlignedObjectArray; - int indexBase = 0; - - btAssert(vertexNormals.size()==vertexPositions.size()); - for (int v=0;vpush_back(vtx); - } - - for (int index=0;indexpush_back(indices[index]+indexBase); - } - - - printf(" index_count =%dand vertexPositions.size=%d\n",indices.size(), vertexPositions.size()); - indexBase=visualShape.m_vertices->size(); - visualShape.m_numIndices = visualShape.m_indices->size(); - visualShape.m_numvertices = visualShape.m_vertices->size(); - } - printf("geometry name=%s\n",geometryName); - name2Shape.insert(geometryName,shapeIndex); - - - }//for each geometry -} - -void readNodeHierarchy(TiXmlElement* node,btHashMap& name2Shape, btAlignedObjectArray& visualShapeInstances, const btMatrix4x4& parentTransMat) -{ - const char* nodeName = node->Attribute("id"); - printf("processing node %s\n", nodeName); - - - btMatrix4x4 nodeTrans; - nodeTrans.setIdentity(); - - ///todo(erwincoumans) we probably have to read the elements 'translate', 'scale', 'rotate' and 'matrix' in-order and accumulate them... - { - for (TiXmlElement* transElem = node->FirstChildElement("matrix");transElem;transElem=node->NextSiblingElement("matrix")) - { - if (transElem->GetText()) - { - btAlignedObjectArray floatArray; - TokenFloatArray adder(floatArray); - tokenize(transElem->GetText(),adder); - if (floatArray.size()==16) - { - btMatrix4x4 t(floatArray[0],floatArray[1],floatArray[2],floatArray[3], - floatArray[4],floatArray[5],floatArray[6],floatArray[7], - floatArray[8],floatArray[9],floatArray[10],floatArray[11], - floatArray[12],floatArray[13],floatArray[14],floatArray[15]); - - nodeTrans = nodeTrans*t; - } else - { - printf("Error: expected 16 elements in a element, skipping\n"); - } - } - } - } - - { - for (TiXmlElement* transElem = node->FirstChildElement("translate");transElem;transElem=node->NextSiblingElement("translate")) - { - if (transElem->GetText()) - { - btVector3 pos = getVector3FromXmlText(transElem->GetText()); - //nodePos+= unitScaling*parentScaling*pos; - btMatrix4x4 t; - t.setPureTranslation(pos); - nodeTrans = nodeTrans*t; - - } - } - } - { - for(TiXmlElement* scaleElem = node->FirstChildElement("scale"); - scaleElem!= NULL; scaleElem= node->NextSiblingElement("scale")) - { - if (scaleElem->GetText()) - { - btVector3 scaling = getVector3FromXmlText(scaleElem->GetText()); - btMatrix4x4 t; - t.setPureScaling(scaling); - nodeTrans = nodeTrans*t; - } - } - } - { - for(TiXmlElement* rotateElem = node->FirstChildElement("rotate"); - rotateElem!= NULL; rotateElem= node->NextSiblingElement("rotate")) - { - if (rotateElem->GetText()) - { - //accumulate orientation - btVector4 rotate = getVector4FromXmlText(rotateElem->GetText()); - btQuaternion orn(btVector3(rotate),btRadians(rotate[3]));//COLLADA DAE rotate is in degrees, convert to radians - btMatrix4x4 t; - t.setPureRotation(orn); - nodeTrans = nodeTrans*t; - } - } - } - - nodeTrans = parentTransMat*nodeTrans; - - for (TiXmlElement* instanceGeom = node->FirstChildElement("instance_geometry"); - instanceGeom!=0; - instanceGeom=instanceGeom->NextSiblingElement("instance_geometry")) - { - const char* geomUrl = instanceGeom->Attribute("url"); - printf("node referring to geom %s\n", geomUrl); - geomUrl++; - int* shapeIndexPtr = name2Shape[geomUrl]; - if (shapeIndexPtr) - { - int index = *shapeIndexPtr; - printf("found geom with index %d\n", *shapeIndexPtr); - ColladaGraphicsInstance& instance = visualShapeInstances.expand(); - instance.m_shapeIndex = *shapeIndexPtr; - instance.m_worldTransform = nodeTrans; - } else - { - printf("geom not found\n"); - } - } - - for(TiXmlElement* childNode = node->FirstChildElement("node"); - childNode!= NULL; childNode = childNode->NextSiblingElement("node")) - { - readNodeHierarchy(childNode,name2Shape,visualShapeInstances, nodeTrans); - } -} -void readVisualSceneInstanceGeometries(TiXmlDocument& doc, btHashMap& name2Shape, btAlignedObjectArray& visualShapeInstances) -{ - btHashMap allVisualScenes; - - TiXmlElement* libVisualScenes = doc.RootElement()->FirstChildElement("library_visual_scenes"); - if (libVisualScenes==0) - return; - - { - for(TiXmlElement* scene = libVisualScenes->FirstChildElement("visual_scene"); - scene != NULL; scene = scene->NextSiblingElement("visual_scene")) - { - const char* sceneName = scene->Attribute("id"); - allVisualScenes.insert(sceneName,scene); - } - } - - TiXmlElement* scene = 0; - { - TiXmlElement* scenes = doc.RootElement()->FirstChildElement("scene"); - if (scenes) - { - TiXmlElement* instanceSceneReference = scenes->FirstChildElement("instance_visual_scene"); - if (instanceSceneReference) - { - const char* instanceSceneUrl = instanceSceneReference->Attribute("url"); - TiXmlElement** sceneInstancePtr = allVisualScenes[instanceSceneUrl+1];//skip # - if (sceneInstancePtr) - { - scene = *sceneInstancePtr; - } - } - } - } - - if (scene) - { - for(TiXmlElement* node = scene->FirstChildElement("node"); - node != NULL; node = node->NextSiblingElement("node")) - { - btMatrix4x4 identity; - identity.setIdentity(); - btVector3 identScaling(1,1,1); - readNodeHierarchy(node,name2Shape,visualShapeInstances, identity); - - } - - } -} - -void getUnitMeterScalingAndUpAxisTransform(TiXmlDocument& doc, btTransform& tr, float& unitMeterScaling, int clientUpAxis) -{ - ///todo(erwincoumans) those up-axis transformations have been quickly coded without rigorous testing - - TiXmlElement* unitMeter = doc.RootElement()->FirstChildElement("asset")->FirstChildElement("unit"); - if (unitMeter) - { - const char* meterText = unitMeter->Attribute("meter"); - printf("meterText=%s\n", meterText); - unitMeterScaling = atof(meterText); - } - - TiXmlElement* upAxisElem = doc.RootElement()->FirstChildElement("asset")->FirstChildElement("up_axis"); - if (upAxisElem) - { - switch (clientUpAxis) - { - - case 1: - { - std::string upAxisTxt = upAxisElem->GetText(); - if (upAxisTxt == "X_UP") - { - btQuaternion x2y(btVector3(0,0,1),SIMD_HALF_PI); - tr.setRotation(x2y); - } - if (upAxisTxt == "Y_UP") - { - //assume Y_UP for now, to be compatible with assimp? - //client and COLLADA are both Z_UP so no transform needed (identity) - } - if (upAxisTxt == "Z_UP") - { - btQuaternion z2y(btVector3(1,0,0),-SIMD_HALF_PI); - tr.setRotation(z2y); - } - break; - } - case 2: - { - std::string upAxisTxt = upAxisElem->GetText(); - if (upAxisTxt == "X_UP") - { - btQuaternion x2z(btVector3(0,1,0),-SIMD_HALF_PI); - tr.setRotation(x2z); - } - if (upAxisTxt == "Y_UP") - { - btQuaternion y2z(btVector3(1,0,0),SIMD_HALF_PI); - tr.setRotation(y2z); - } - if (upAxisTxt == "Z_UP") - { - //client and COLLADA are both Z_UP so no transform needed (identity) - } - break; - } - case 0: - default: - { - //we don't support X or other up axis - btAssert(0); - } - }; - } -} - -void LoadMeshFromCollada(const char* relativeFileName, btAlignedObjectArray& visualShapes, btAlignedObjectArray& visualShapeInstances, btTransform& upAxisTransform, float& unitMeterScaling,int clientUpAxis) -{ - - GLInstanceGraphicsShape* instance = 0; - - //usually COLLADA files don't have that many visual geometries/shapes - visualShapes.reserve(32); - - float extraScaling = 1;//0.01; - btHashMap name2ShapeIndex; - b3FileUtils f; - char filename[1024]; - if (!f.findFile(relativeFileName,filename,1024)) - { - printf("File not found: %s\n", filename); - return; - } - - TiXmlDocument doc(filename); - if (!doc.LoadFile()) - return; - - //We need units to be in meter, so apply a scaling using the asset/units meter - unitMeterScaling=1; - upAxisTransform.setIdentity(); - - //Also we can optionally compensate all transforms using the asset/up_axis as well as unit meter scaling - getUnitMeterScalingAndUpAxisTransform(doc, upAxisTransform, unitMeterScaling,clientUpAxis); - - btMatrix4x4 ident; - ident.setIdentity(); - - readLibraryGeometries(doc, visualShapes, name2ShapeIndex, extraScaling); - - readVisualSceneInstanceGeometries(doc, name2ShapeIndex, visualShapeInstances); - -} - - - -#ifdef COMPARE_WITH_ASSIMP - -#include -#include -#include -#include - - -# include "assimp/ColladaLoader.h" -//# include "STLLoader.h" -# include "assimp/SortByPTypeProcess.h" -# include "assimp/LimitBoneWeightsProcess.h" -# include "assimp/TriangulateProcess.h" -# include "assimp/JoinVerticesProcess.h" -# include "assimp/RemoveVCProcess.h" - - -namespace Assimp { - // ------------------------------------------------------------------------------------------------ -void GetImporterInstanceList(std::vector< BaseImporter* >& out) - { - out.push_back( new ColladaLoader()); - } - // ------------------------------------------------------------------------------------------------ -void GetPostProcessingStepInstanceList(std::vector< BaseProcess* >& out) - { - out.push_back( new SortByPTypeProcess()); - out.push_back( new LimitBoneWeightsProcess()); - out.push_back( new TriangulateProcess()); - out.push_back( new JoinVerticesProcess()); - //out.push_back( new RemoveVCProcess()); - } - -} - -static void addMeshParts(const aiScene* scene, const aiNode* node, GLInstanceGraphicsShape* outverts, const aiMatrix4x4& parentTr) -{ - aiMatrix4x4 const& nodeTrans(node->mTransformation); - - aiMatrix4x4 trans; - trans = parentTr * nodeTrans; - - for (size_t i = 0; i < node->mNumMeshes; ++i) - { - aiMesh const* mesh = scene->mMeshes[node->mMeshes[i]]; - size_t num_vertices = mesh->mNumVertices; - if (mesh->mPrimitiveTypes==aiPrimitiveType_TRIANGLE) - { - int curVertexBase = outverts->m_vertices->size(); - - for (int v=0;vmNumVertices;v++) - { - GLInstanceVertex vtx; - aiVector3D vWorld = trans*mesh->mVertices[v]; - vtx.xyzw[0] = vWorld.x; - vtx.xyzw[1] = vWorld.y; - vtx.xyzw[2] = vWorld.z; - vtx.xyzw[3] = 1; - if (mesh->HasNormals()) - { - vtx.normal[0] = mesh->mNormals[v].x; - vtx.normal[1] = mesh->mNormals[v].y; - vtx.normal[2] = mesh->mNormals[v].z; - } else - { - vtx.normal[0] = 0; - vtx.normal[1] = 0; - vtx.normal[2] = 1; - } - if (mesh->HasTextureCoords(0)) - { - vtx.uv[0] = mesh->mTextureCoords[0][v].x; - vtx.uv[1] = mesh->mTextureCoords[0][v].y; - } else - { - vtx.uv[0]=0.5f; - vtx.uv[1]=0.5f; - } - outverts->m_vertices->push_back(vtx); - } - for (int f=0;fmNumFaces;f++) - { - b3Assert(mesh->mFaces[f].mNumIndices == 3); - int i0 = mesh->mFaces[f].mIndices[0]; - int i1 = mesh->mFaces[f].mIndices[1]; - int i2 = mesh->mFaces[f].mIndices[2]; - outverts->m_indices->push_back(i0+curVertexBase); - outverts->m_indices->push_back(i1+curVertexBase); - outverts->m_indices->push_back(i2+curVertexBase); - } - } - } - for (size_t i=0 ; imNumChildren ; ++i) { - addMeshParts(scene,node->mChildren[i], outverts, trans); - } -} - - -void LoadMeshFromColladaAssimp(const char* relativeFileName, btAlignedObjectArray& visualShapes, btAlignedObjectArray& visualShapeInstances,btTransform& upAxisTrans, float& unitMeterScaling) -{ - upAxisTrans.setIdentity(); - unitMeterScaling=1; - - GLInstanceGraphicsShape* shape = 0; - - - FILE* file = fopen(relativeFileName,"rb"); - if (file) - { - int size=0; - if (fseek(file, 0, SEEK_END) || (size = ftell(file)) == EOF || fseek(file, 0, SEEK_SET)) - { - printf("Error: Cannot access file to determine size of %s\n", relativeFileName); - } else - { - if (size) - { - printf("Open DAE file of %d bytes\n",size); - - Assimp::Importer importer; - //importer.SetPropertyInteger(AI_CONFIG_PP_RVC_FLAGS, aiComponent_NORMALS | aiComponent_COLORS); - importer.SetPropertyInteger(AI_CONFIG_PP_SBP_REMOVE, aiPrimitiveType_LINE | aiPrimitiveType_POINT); - // importer.SetPropertyInteger(AI_CONFIG_IMPORT_COLLADA_IGNORE_UP_DIRECTION, 1); - aiScene const* scene = importer.ReadFile(relativeFileName, - aiProcess_JoinIdenticalVertices | - //aiProcess_RemoveComponent | - aiProcess_SortByPType | - aiProcess_Triangulate); - if (scene) - { - shape = &visualShapes.expand(); - shape->m_scaling[0] = 1; - shape->m_scaling[1] = 1; - shape->m_scaling[2] = 1; - shape->m_scaling[3] = 1; - int index = 0; - shape->m_indices = new b3AlignedObjectArray(); - shape->m_vertices = new b3AlignedObjectArray(); - - aiMatrix4x4 ident; - addMeshParts(scene, scene->mRootNode, shape, ident); - shape->m_numIndices = shape->m_indices->size(); - shape->m_numvertices = shape->m_vertices->size(); - ColladaGraphicsInstance& instance = visualShapeInstances.expand(); - instance.m_shapeIndex = visualShapes.size()-1; - } - } - } - - } - -} - -#endif //COMPARE_WITH_ASSIMP \ No newline at end of file diff --git a/Demos3/ImportColladaDemo/LoadMeshFromCollada.h b/Demos3/ImportColladaDemo/LoadMeshFromCollada.h deleted file mode 100644 index 7e2d02bfd..000000000 --- a/Demos3/ImportColladaDemo/LoadMeshFromCollada.h +++ /dev/null @@ -1,45 +0,0 @@ -/* -Bullet Collision Detection and Physics Library http://bulletphysics.org -This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -//original author: Erwin Coumans -*/ - - -#ifndef LOAD_MESH_FROM_COLLADA_H -#define LOAD_MESH_FROM_COLLADA_H - -#include "LinearMath/btAlignedObjectArray.h" -#include "LinearMath/btTransform.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include "ColladaGraphicsInstance.h" - - -void LoadMeshFromCollada(const char* relativeFileName, - btAlignedObjectArray& visualShapes, - btAlignedObjectArray& visualShapeInstances, - btTransform& upAxisTrans, - float& unitMeterScaling, - int clientUpAxis); - -//#define COMPARE_WITH_ASSIMP -#ifdef COMPARE_WITH_ASSIMP -void LoadMeshFromColladaAssimp(const char* relativeFileName, - btAlignedObjectArray& visualShapes, - btAlignedObjectArray& visualShapeInstances, - btTransform& upAxisTrans, - float& unitMeterScaling - ); -#endif //COMPARE_WITH_ASSIMP - -#endif //LOAD_MESH_FROM_COLLADA_H diff --git a/Demos3/ImportColladaDemo/btMatrix4x4.h b/Demos3/ImportColladaDemo/btMatrix4x4.h deleted file mode 100644 index 5d6ec3a30..000000000 --- a/Demos3/ImportColladaDemo/btMatrix4x4.h +++ /dev/null @@ -1,156 +0,0 @@ -/* -Bullet Collision Detection and Physics Library http://bulletphysics.org -This file is Copyright (c) 2014 Google Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -//original author: Erwin Coumans -*/ - - -#ifndef MATRIX4x4_H -#define MATRIX4x4_H - -#include "LinearMath/btVector3.h" -#include "LinearMath/btQuaternion.h" - -///This 4x4 matrix class is extremely limited, just created for the purpose of accumulating transform matrices in COLLADA .dae files -ATTRIBUTE_ALIGNED16(class) btMatrix4x4 -{ - btVector4 m_el[4]; - public: - - btMatrix4x4() - { - } - btMatrix4x4(const btScalar& xx, const btScalar& xy, const btScalar& xz,const btScalar& xw, - const btScalar& yx, const btScalar& yy, const btScalar& yz,const btScalar& yw, - const btScalar& zx, const btScalar& zy, const btScalar& zz, const btScalar& zw, - const btScalar& wx, const btScalar& wy, const btScalar& wz, const btScalar& ww) - { - setValue(xx, xy, xz, xw, - yx, yy, yz, yw, - zx, zy, zz,zw, - wx, wy, wz,ww); - } - - ~btMatrix4x4() - { - } - - inline void setValue(const btScalar& xx, const btScalar& xy, const btScalar& xz,const btScalar& xw, - const btScalar& yx, const btScalar& yy, const btScalar& yz,const btScalar& yw, - const btScalar& zx, const btScalar& zy, const btScalar& zz, const btScalar& zw, - const btScalar& wx, const btScalar& wy, const btScalar& wz, const btScalar& ww) - { - m_el[0].setValue(xx,xy,xz,xw); - m_el[1].setValue(yx,yy,yz,yw); - m_el[2].setValue(zx,zy,zz,zw); - m_el[3].setValue(wx,wy,wz,ww); - } - - inline void setIdentity() - { - m_el[0].setValue(1,0,0,0); - m_el[1].setValue(0,1,0,0); - m_el[2].setValue(0,0,1,0); - m_el[3].setValue(0,0,0,1); - } - inline void setPureRotation(const btQuaternion& orn) - { - setIdentity(); - - btMatrix3x3 m3(orn); - for (int i=0;i<3;i++) - { - for (int j=0;j<3;j++) - { - m_el[i][j] = m3[i][j]; - } - } - } - - inline void setPureScaling(const btVector3& scale) - { - m_el[0].setValue(scale[0],0,0,0); - m_el[1].setValue(0,scale[1],0,0); - m_el[2].setValue(0,0,scale[2],0); - m_el[3].setValue(0,0,0,1); - } - - inline void setPureTranslation(const btVector3& pos) - { - m_el[0].setValue(1,0,0,pos[0]); - m_el[1].setValue(0,1,0,pos[1]); - m_el[2].setValue(0,0,1,pos[2]); - m_el[3].setValue(0,0,0,1); - - } - SIMD_FORCE_INLINE const btVector4& operator[](int i) const - { - btFullAssert(0 <= i && i < 3); - return m_el[i]; - } - - SIMD_FORCE_INLINE btScalar tdotx(const btVector4& v) const - { - return m_el[0].x() * v.x() + m_el[1].x() * v.y() + m_el[2].x() * v.z() + m_el[3].x()* v.w(); - } - SIMD_FORCE_INLINE btScalar tdoty(const btVector4& v) const - { - return m_el[0].y() * v.x() + m_el[1].y() * v.y() + m_el[2].y() * v.z() + m_el[3].y() * v.w(); - } - SIMD_FORCE_INLINE btScalar tdotz(const btVector4& v) const - { - return m_el[0].z() * v.x() + m_el[1].z() * v.y() + m_el[2].z() * v.z() + m_el[3].z() * v.w(); - } - SIMD_FORCE_INLINE btScalar tdotw(const btVector4& v) const - { - return m_el[0].w() * v.x() + m_el[1].w() * v.y() + m_el[2].w() * v.z() + m_el[3].w() * v.w(); - } - - SIMD_FORCE_INLINE btMatrix4x4 - operator*=(const btMatrix4x4& m) - { - setValue( - m.tdotx(m_el[0]), m.tdoty(m_el[0]), m.tdotz(m_el[0]),m.tdotw(m_el[0]), - m.tdotx(m_el[1]), m.tdoty(m_el[1]), m.tdotz(m_el[1]),m.tdotw(m_el[1]), - m.tdotx(m_el[2]), m.tdoty(m_el[2]), m.tdotz(m_el[2]),m.tdotw(m_el[2]), - m.tdotx(m_el[3]), m.tdoty(m_el[3]), m.tdotz(m_el[3]),m.tdotw(m_el[3])); - } - - - -}; - -inline btScalar btDot4(const btVector4& v0, const btVector4& v1) -{ - return v0.x()*v1.x()+v0.y()*v1.y()+v0.z()*v1.z()+v0.w()*v1.w(); -} -SIMD_FORCE_INLINE btVector3 -operator*(const btMatrix4x4& m, const btVector3& v1) -{ - btVector4 v(v1[0],v1[1],v1[2],1); - return btVector3(btDot4(m[0],v), btDot4(m[1],v), btDot4(m[2],v)); -} - -SIMD_FORCE_INLINE btMatrix4x4 - operator*(const btMatrix4x4& m1, btMatrix4x4& m2) - { - return btMatrix4x4( - m2.tdotx(m1[0]), m2.tdoty(m1[0]), m2.tdotz(m1[0]),m2.tdotw(m1[0]), - m2.tdotx(m1[1]), m2.tdoty(m1[1]), m2.tdotz(m1[1]),m2.tdotw(m1[1]), - m2.tdotx(m1[2]), m2.tdoty(m1[2]), m2.tdotz(m1[2]),m2.tdotw(m1[2]), - m2.tdotx(m1[3]), m2.tdoty(m1[3]), m2.tdotz(m1[3]),m2.tdotw(m1[3])); - } - - -#endif //MATRIX4x4_H diff --git a/Demos3/ImportObjDemo/ImportObjSetup.cpp b/Demos3/ImportObjDemo/ImportObjSetup.cpp deleted file mode 100644 index 51f7f9d2b..000000000 --- a/Demos3/ImportObjDemo/ImportObjSetup.cpp +++ /dev/null @@ -1,123 +0,0 @@ -#include "ImportObjSetup.h" -#include -#include "OpenGLWindow/GLInstancingRenderer.h" -#include"../Wavefront/tiny_obj_loader.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include "btBulletDynamicsCommon.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "Wavefront2GLInstanceGraphicsShape.h" - -ImportObjSetup::ImportObjSetup(CommonGraphicsApp* app) -:m_app(app) -{ - -} - -ImportObjSetup::~ImportObjSetup() -{ - -} - - - - - - - -void ImportObjSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - gfxBridge.setUpAxis(2); - this->createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawWireframe); - const char* fileName = "samurai_monastry.obj"; - char relativeFileName[1024]; - const char* prefix[]={"./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int prefixIndex=-1; - { - - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;i shapes; - std::string err = tinyobj::LoadObj(shapes, relativeFileName, prefix[prefixIndex]); - - GLInstanceGraphicsShape* gfxShape = btgCreateGraphicsShapeFromWavefrontObj(shapes); - - btTransform trans; - trans.setIdentity(); - trans.setRotation(btQuaternion(btVector3(1,0,0),SIMD_HALF_PI)); - - btVector3 position = trans.getOrigin(); - btQuaternion orn = trans.getRotation(); - - btVector3 color(0,0,1); - - int shapeId = m_app->m_renderer->registerShape(&gfxShape->m_vertices->at(0).xyzw[0], gfxShape->m_numvertices, &gfxShape->m_indices->at(0), gfxShape->m_numIndices); - - - //int id = - m_app->m_renderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - - /* - - btTriangleMesh* trimeshData = new btTriangleMesh(); - - for (int i=0;im_numvertices;i++) - { - for (int j=0;j<3;j++) - gfxShape->m_vertices->at(i).xyzw[j] += shift[j]; - } - - for (int i=0;im_numIndices;i+=3) - { - int index0 = gfxShape->m_indices->at(i); - int index1 = gfxShape->m_indices->at(i+1); - int index2 = gfxShape->m_indices->at(i+2); - - btVector3 v0(gfxShape->m_vertices->at(index0).xyzw[0], - gfxShape->m_vertices->at(index0).xyzw[1], - gfxShape->m_vertices->at(index0).xyzw[2]); - btVector3 v1(gfxShape->m_vertices->at(index1).xyzw[0], - gfxShape->m_vertices->at(index1).xyzw[1], - gfxShape->m_vertices->at(index1).xyzw[2]); - btVector3 v2(gfxShape->m_vertices->at(index2).xyzw[0], - gfxShape->m_vertices->at(index2).xyzw[1], - gfxShape->m_vertices->at(index2).xyzw[2]); - - trimeshData->addTriangle(v0,v1,v2); - } - - //btConvexHullShape* convexShape = new btConvexHullShape(&verts[0].x(),verts.size(),sizeof(btVector3)); - btBvhTriangleMeshShape* shape = new btBvhTriangleMeshShape(trimeshData,true);//meshInterface); - - btTransform startTrans;startTrans.setIdentity(); - btRigidBody* body = this->createRigidBody(0,startTrans,shape); - //gfxBridge.createCollisionShapeGraphicsObject(shape); - btVector3 color(0,0,1); - */ - //gfxBridge.createRigidBodyGraphicsObject(body,color); - } -} diff --git a/Demos3/ImportObjDemo/ImportObjSetup.h b/Demos3/ImportObjDemo/ImportObjSetup.h deleted file mode 100644 index 3a88523b7..000000000 --- a/Demos3/ImportObjDemo/ImportObjSetup.h +++ /dev/null @@ -1,17 +0,0 @@ -#ifndef IMPORT_OBJ_SETUP_H -#define IMPORT_OBJ_SETUP_H - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -class ImportObjSetup : public CommonRigidBodySetup -{ - struct CommonGraphicsApp* m_app; -public: - ImportObjSetup(CommonGraphicsApp* app); - virtual ~ImportObjSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); -}; - -#endif //IMPORT_OBJ_SETUP_H diff --git a/Demos3/ImportObjDemo/LoadMeshFromObj.cpp b/Demos3/ImportObjDemo/LoadMeshFromObj.cpp deleted file mode 100644 index f309c0f16..000000000 --- a/Demos3/ImportObjDemo/LoadMeshFromObj.cpp +++ /dev/null @@ -1,17 +0,0 @@ -#include "LoadMeshFromObj.h" -#include"../Wavefront/tiny_obj_loader.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include //fopen -#include "Bullet3Common/b3AlignedObjectArray.h" -#include -#include -#include "Wavefront2GLInstanceGraphicsShape.h" - -GLInstanceGraphicsShape* LoadMeshFromObj(const char* relativeFileName, const char* materialPrefixPath) -{ - std::vector shapes; - std::string err = tinyobj::LoadObj(shapes, relativeFileName, materialPrefixPath); - - GLInstanceGraphicsShape* gfxShape = btgCreateGraphicsShapeFromWavefrontObj(shapes); - return gfxShape; -} \ No newline at end of file diff --git a/Demos3/ImportObjDemo/LoadMeshFromObj.h b/Demos3/ImportObjDemo/LoadMeshFromObj.h deleted file mode 100644 index 72533dfd8..000000000 --- a/Demos3/ImportObjDemo/LoadMeshFromObj.h +++ /dev/null @@ -1,11 +0,0 @@ -#ifndef LOAD_MESH_FROM_OBJ_H -#define LOAD_MESH_FROM_OBJ_H - - -struct GLInstanceGraphicsShape; - - -GLInstanceGraphicsShape* LoadMeshFromObj(const char* relativeFileName, const char* materialPrefixPath); - -#endif //LOAD_MESH_FROM_OBJ_H - diff --git a/Demos3/ImportObjDemo/Wavefront2GLInstanceGraphicsShape.cpp b/Demos3/ImportObjDemo/Wavefront2GLInstanceGraphicsShape.cpp deleted file mode 100644 index f7d6d7d19..000000000 --- a/Demos3/ImportObjDemo/Wavefront2GLInstanceGraphicsShape.cpp +++ /dev/null @@ -1,109 +0,0 @@ -#include "Wavefront2GLInstanceGraphicsShape.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include "btBulletDynamicsCommon.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "Wavefront2GLInstanceGraphicsShape.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" - -GLInstanceGraphicsShape* btgCreateGraphicsShapeFromWavefrontObj(std::vector& shapes) -{ - - b3AlignedObjectArray* vertices = new b3AlignedObjectArray; - { - // int numVertices = obj->vertexCount; - // int numIndices = 0; - b3AlignedObjectArray* indicesPtr = new b3AlignedObjectArray; - - for (int s=0;s<(int)shapes.size();s++) - { - tinyobj::shape_t& shape = shapes[s]; - int faceCount = shape.mesh.indices.size(); - - - for (int f=0;fsize(); - - - - GLInstanceVertex vtx0; - vtx0.xyzw[0] = shape.mesh.positions[shape.mesh.indices[f]*3+0]; - vtx0.xyzw[1] = shape.mesh.positions[shape.mesh.indices[f]*3+1]; - vtx0.xyzw[2] = shape.mesh.positions[shape.mesh.indices[f]*3+2]; - vtx0.xyzw[3] = 0.f; - - vtx0.uv[0] = 0.5f;//shape.mesh.positions[shape.mesh.indices[f]*3+2];? - vtx0.uv[1] = 0.5f; - - GLInstanceVertex vtx1; - vtx1.xyzw[0] = shape.mesh.positions[shape.mesh.indices[f+1]*3+0]; - vtx1.xyzw[1] = shape.mesh.positions[shape.mesh.indices[f+1]*3+1]; - vtx1.xyzw[2] = shape.mesh.positions[shape.mesh.indices[f+1]*3+2]; - vtx1.xyzw[3]= 0.f; - vtx1.uv[0] = 0.5f;//obj->textureList[face->vertex_index[1]]->e[0]; - vtx1.uv[1] = 0.5f;//obj->textureList[face->vertex_index[1]]->e[1]; - - GLInstanceVertex vtx2; - vtx2.xyzw[0] = shape.mesh.positions[shape.mesh.indices[f+2]*3+0]; - vtx2.xyzw[1] = shape.mesh.positions[shape.mesh.indices[f+2]*3+1]; - vtx2.xyzw[2] = shape.mesh.positions[shape.mesh.indices[f+2]*3+2]; - vtx2.xyzw[3] = 0.f; - vtx2.uv[0] = 0.5f; - vtx2.uv[1] = 0.5f; - - - btVector3 v0(vtx0.xyzw[0],vtx0.xyzw[1],vtx0.xyzw[2]); - btVector3 v1(vtx1.xyzw[0],vtx1.xyzw[1],vtx1.xyzw[2]); - btVector3 v2(vtx2.xyzw[0],vtx2.xyzw[1],vtx2.xyzw[2]); - - normal = (v1-v0).cross(v2-v0); - btScalar len2 = normal.length2(); - //skip degenerate triangles - if (len2 > SIMD_EPSILON) - { - normal.normalize(); - } else - { - normal.setValue(0,0,0); - } - vtx0.normal[0] = normal[0]; - vtx0.normal[1] = normal[1]; - vtx0.normal[2] = normal[2]; - vtx1.normal[0] = normal[0]; - vtx1.normal[1] = normal[1]; - vtx1.normal[2] = normal[2]; - vtx2.normal[0] = normal[0]; - vtx2.normal[1] = normal[1]; - vtx2.normal[2] = normal[2]; - vertices->push_back(vtx0); - vertices->push_back(vtx1); - vertices->push_back(vtx2); - indicesPtr->push_back(vtxBaseIndex); - indicesPtr->push_back(vtxBaseIndex+1); - indicesPtr->push_back(vtxBaseIndex+2); - - - } - } - } - - - GLInstanceGraphicsShape* gfxShape = new GLInstanceGraphicsShape; - gfxShape->m_vertices = vertices; - gfxShape->m_numvertices = vertices->size(); - gfxShape->m_indices = indicesPtr; - gfxShape->m_numIndices = indicesPtr->size(); - for (int i=0;i<4;i++) - gfxShape->m_scaling[i] = 1;//bake the scaling into the vertices - return gfxShape; - } -} - diff --git a/Demos3/ImportObjDemo/Wavefront2GLInstanceGraphicsShape.h b/Demos3/ImportObjDemo/Wavefront2GLInstanceGraphicsShape.h deleted file mode 100644 index 09f0bf683..000000000 --- a/Demos3/ImportObjDemo/Wavefront2GLInstanceGraphicsShape.h +++ /dev/null @@ -1,9 +0,0 @@ -#ifndef WAVEFRONT2GRAPHICS_H -#define WAVEFRONT2GRAPHICS_H - -#include"../Wavefront/tiny_obj_loader.h" -#include - -struct GLInstanceGraphicsShape* btgCreateGraphicsShapeFromWavefrontObj(std::vector& shapes); - -#endif //WAVEFRONT2GRAPHICS_H diff --git a/Demos3/ImportSTLDemo/ImportSTLSetup.cpp b/Demos3/ImportSTLDemo/ImportSTLSetup.cpp deleted file mode 100644 index 37a1a1373..000000000 --- a/Demos3/ImportSTLDemo/ImportSTLSetup.cpp +++ /dev/null @@ -1,116 +0,0 @@ -#include "ImportSTLSetup.h" -#include -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include "btBulletDynamicsCommon.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "LoadMeshFromSTL.h" - -ImportSTLSetup::ImportSTLSetup(CommonGraphicsApp* app) -:m_app(app) -{ - -} - -ImportSTLSetup::~ImportSTLSetup() -{ - -} - - - -void ImportSTLSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - gfxBridge.setUpAxis(2); - this->createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawWireframe); - - const char* fileName = "l_finger_tip.stl"; - char relativeFileName[1024]; - const char* prefix[]={"./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int prefixIndex=-1; - { - - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;im_renderer->registerShape(&gfxShape->m_vertices->at(0).xyzw[0], gfxShape->m_numvertices, &gfxShape->m_indices->at(0), gfxShape->m_numIndices); - - - // int id = - m_app->m_renderer->registerGraphicsInstance(shapeId,position,orn,color,scaling); - - /* - - btTriangleMesh* trimeshData = new btTriangleMesh(); - - for (int i=0;im_numvertices;i++) - { - for (int j=0;j<3;j++) - gfxShape->m_vertices->at(i).xyzw[j] += shift[j]; - } - - for (int i=0;im_numIndices;i+=3) - { - int index0 = gfxShape->m_indices->at(i); - int index1 = gfxShape->m_indices->at(i+1); - int index2 = gfxShape->m_indices->at(i+2); - - btVector3 v0(gfxShape->m_vertices->at(index0).xyzw[0], - gfxShape->m_vertices->at(index0).xyzw[1], - gfxShape->m_vertices->at(index0).xyzw[2]); - btVector3 v1(gfxShape->m_vertices->at(index1).xyzw[0], - gfxShape->m_vertices->at(index1).xyzw[1], - gfxShape->m_vertices->at(index1).xyzw[2]); - btVector3 v2(gfxShape->m_vertices->at(index2).xyzw[0], - gfxShape->m_vertices->at(index2).xyzw[1], - gfxShape->m_vertices->at(index2).xyzw[2]); - - trimeshData->addTriangle(v0,v1,v2); - } - - //btConvexHullShape* convexShape = new btConvexHullShape(&verts[0].x(),verts.size(),sizeof(btVector3)); - btBvhTriangleMeshShape* shape = new btBvhTriangleMeshShape(trimeshData,true);//meshInterface); - - btTransform startTrans;startTrans.setIdentity(); - btRigidBody* body = this->createRigidBody(0,startTrans,shape); - //gfxBridge.createCollisionShapeGraphicsObject(shape); - btVector3 color(0,0,1); - */ - //gfxBridge.createRigidBodyGraphicsObject(body,color); - } -} diff --git a/Demos3/ImportSTLDemo/ImportSTLSetup.h b/Demos3/ImportSTLDemo/ImportSTLSetup.h deleted file mode 100644 index 40c9c2bdf..000000000 --- a/Demos3/ImportSTLDemo/ImportSTLSetup.h +++ /dev/null @@ -1,17 +0,0 @@ -#ifndef IMPORT_STL_SETUP_H -#define IMPORT_STL_SETUP_H - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -class ImportSTLSetup : public CommonRigidBodySetup -{ - struct CommonGraphicsApp* m_app; -public: - ImportSTLSetup(CommonGraphicsApp* app); - virtual ~ImportSTLSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); -}; - -#endif //IMPORT_OBJ_SETUP_H diff --git a/Demos3/ImportSTLDemo/LoadMeshFromSTL.h b/Demos3/ImportSTLDemo/LoadMeshFromSTL.h deleted file mode 100644 index d6f7fa01e..000000000 --- a/Demos3/ImportSTLDemo/LoadMeshFromSTL.h +++ /dev/null @@ -1,109 +0,0 @@ - -#ifndef LOAD_MESH_FROM_STL_H -#define LOAD_MESH_FROM_STL_H - -#include "OpenGLWindow/GLInstanceGraphicsShape.h" -#include //fopen -#include "Bullet3Common/b3AlignedObjectArray.h" - -struct MySTLTriangle -{ - float normal[3]; - float vertex0[3]; - float vertex1[3]; - float vertex2[3]; -}; - -static GLInstanceGraphicsShape* LoadMeshFromSTL(const char* relativeFileName) -{ - GLInstanceGraphicsShape* shape = 0; - - FILE* file = fopen(relativeFileName,"rb"); - if (file) - { - int size=0; - if (fseek(file, 0, SEEK_END) || (size = ftell(file)) == EOF || fseek(file, 0, SEEK_SET)) - { - printf("Error: Cannot access file to determine size of %s\n", relativeFileName); - } else - { - if (size) - { - printf("Open STL file of %d bytes\n",size); - char* memoryBuffer = new char[size+1]; - int actualBytesRead = fread(memoryBuffer,1,size,file); - if (actualBytesRead!=size) - { - printf("Error reading from file %s",relativeFileName); - } else - { - int numTriangles = *(int*)&memoryBuffer[80]; - - if (numTriangles) - { - { - //perform a sanity check instead of crashing on invalid triangles/STL files - int expectedBinaryFileSize = numTriangles* 50 + 84; - if (expectedBinaryFileSize != size) - { - return 0; - } - - } - shape = new GLInstanceGraphicsShape; -// b3AlignedObjectArray* m_vertices; -// int m_numvertices; -// b3AlignedObjectArray* m_indices; -// int m_numIndices; -// float m_scaling[4]; - shape->m_scaling[0] = 1; - shape->m_scaling[1] = 1; - shape->m_scaling[2] = 1; - shape->m_scaling[3] = 1; - int index = 0; - shape->m_indices = new b3AlignedObjectArray(); - shape->m_vertices = new b3AlignedObjectArray(); - for (int i=0;ivertex0[v]; - v1.xyzw[v] = tri->vertex1[v]; - v2.xyzw[v] = tri->vertex2[v]; - v0.normal[v] = v1.normal[v] = v2.normal[v] = tri->normal[v]; - } - v0.xyzw[3] = v1.xyzw[3] = v2.xyzw[3] = 0.f; - - shape->m_vertices->push_back(v0); - shape->m_vertices->push_back(v1); - shape->m_vertices->push_back(v2); - - shape->m_indices->push_back(index++); - shape->m_indices->push_back(index++); - shape->m_indices->push_back(index++); - - } - } - } - - delete[] memoryBuffer; - } - } - fclose(file); - } - shape->m_numIndices = shape->m_indices->size(); - shape->m_numvertices = shape->m_vertices->size(); - return shape; -} - -#endif //LOAD_MESH_FROM_STL_H diff --git a/Demos3/ImportURDFDemo/ConvertRigidBodies2MultiBody.h b/Demos3/ImportURDFDemo/ConvertRigidBodies2MultiBody.h deleted file mode 100644 index 895a8717f..000000000 --- a/Demos3/ImportURDFDemo/ConvertRigidBodies2MultiBody.h +++ /dev/null @@ -1,14 +0,0 @@ -#ifndef CONVERT_RIGIDBODIES_2_MULTIBODY_H -#define CONVERT_RIGIDBODIES_2_MULTIBODY_H - -struct ConvertRigidBodies2MultiBody -{ - btAlignedObjectArray m_bodies; - btAlignedObjectArray m_constraints; - - virtual void addRigidBody(btRigidBody* body); - virtual void addConstraint(btTypedConstraint* constraint, bool disableCollisionsBetweenLinkedBodies=false); - virtual btMultiBody* convertToMultiBody(); - -}; -#endif //CONVERT_RIGIDBODIES_2_MULTIBODY_H diff --git a/Demos3/ImportURDFDemo/ImportURDFSetup.cpp b/Demos3/ImportURDFDemo/ImportURDFSetup.cpp deleted file mode 100644 index a777bee40..000000000 --- a/Demos3/ImportURDFDemo/ImportURDFSetup.cpp +++ /dev/null @@ -1,1661 +0,0 @@ - -#include "ImportURDFSetup.h" -#include "BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h" -#include "Bullet3Common/b3FileUtils.h" -#include "../ImportObjDemo/LoadMeshFromObj.h" -#include "../ImportSTLDemo/LoadMeshFromSTL.h" -#include "../ImportColladaDemo/LoadMeshFromCollada.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "Bullet3Common/b3FileUtils.h" -#include "BulletCollision/CollisionShapes/btShapeHull.h"//to create a tesselation of a generic btConvexShape -#include "BulletDynamics/Featherstone/btMultiBodyJointMotor.h" - -static int bodyCollisionFilterGroup=btBroadphaseProxy::CharacterFilter; -static int bodyCollisionFilterMask=btBroadphaseProxy::AllFilter&(~btBroadphaseProxy::CharacterFilter); -static bool enableConstraints = true;//false; -#include "URDF2Bullet.h" - -#include "urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h" - -#include "urdf_samples.h" - -//#include "BulletCollision/CollisionShapes/btCylinderShape.h" -//#define USE_BARREL_VERTICES -//#include "OpenGLWindow/ShapeData.h" - -#include -#include -using namespace urdf; - -void convertURDFToVisualShape(const Visual* visual, const char* pathPrefix, const btTransform& visualTransform, btAlignedObjectArray& verticesOut, btAlignedObjectArray& indicesOut); -btCollisionShape* convertURDFToCollisionShape(const Collision* visual, const char* pathPrefix); - -class MyURDF2Bullet : public URDF2Bullet -{ - my_shared_ptr m_robot; - std::vector > m_links; - GraphicsPhysicsBridge& m_gfxBridge; - mutable btMultiBody* m_bulletMultiBody; - -public: - - mutable btAlignedObjectArray m_urdf2mbLink; - mutable btAlignedObjectArray m_mb2urdfLink; - - - MyURDF2Bullet(my_shared_ptr robot,GraphicsPhysicsBridge& gfxBridge) - :m_robot(robot), - m_gfxBridge(gfxBridge), - m_bulletMultiBody(0) - { - m_robot->getLinks(m_links); - - //initialize the 'index' of each link - for (int i=0;im_link_index = i; - } - - m_urdf2mbLink.resize(m_links.size(),-2); - m_mb2urdfLink.resize(m_links.size(),-2); - } - - virtual int getRootLinkIndex() const - { - if (m_links.size()) - { - int rootLinkIndex = m_robot->getRoot()->m_link_index; - // btAssert(m_links[0]->m_link_index == rootLinkIndex); - return rootLinkIndex; - } - return -1; - }; - - virtual void getLinkChildIndices(int linkIndex, btAlignedObjectArray& childLinkIndices) const - { - childLinkIndices.resize(0); - int numChildren = m_links[linkIndex]->child_links.size(); - - for (int i=0;ichild_links[i]->m_link_index; - childLinkIndices.push_back(childIndex); - } - } - virtual std::string getLinkName(int linkIndex) const - { - std::string n = m_links[linkIndex]->name; - return n; - } - - virtual std::string getJointName(int linkIndex) const - { - return m_links[linkIndex]->parent_joint->name; - } - - virtual void getMassAndInertia(int linkIndex, btScalar& mass,btVector3& localInertiaDiagonal, btTransform& inertialFrame) const - { - if ((*m_links[linkIndex]).inertial) - { - mass = (*m_links[linkIndex]).inertial->mass; - localInertiaDiagonal.setValue((*m_links[linkIndex]).inertial->ixx,(*m_links[linkIndex]).inertial->iyy,(*m_links[linkIndex]).inertial->izz); - inertialFrame.setOrigin(btVector3((*m_links[linkIndex]).inertial->origin.position.x,(*m_links[linkIndex]).inertial->origin.position.y,(*m_links[linkIndex]).inertial->origin.position.z)); - inertialFrame.setRotation(btQuaternion((*m_links[linkIndex]).inertial->origin.rotation.x,(*m_links[linkIndex]).inertial->origin.rotation.y,(*m_links[linkIndex]).inertial->origin.rotation.z,(*m_links[linkIndex]).inertial->origin.rotation.w)); - } else - { - mass = 1.f; - localInertiaDiagonal.setValue(1,1,1); - inertialFrame.setIdentity(); - } - } - - virtual bool getJointInfo(int urdfLinkIndex, btTransform& parent2joint, btVector3& jointAxisInJointSpace, int& jointType, btScalar& jointLowerLimit, btScalar& jointUpperLimit) const - { - jointLowerLimit = 0.f; - jointUpperLimit = 0.f; - - if ((*m_links[urdfLinkIndex]).parent_joint) - { - my_shared_ptr pj =(*m_links[urdfLinkIndex]).parent_joint; - - const urdf::Vector3 pos = pj->parent_to_joint_origin_transform.position; - const urdf::Rotation orn = pj->parent_to_joint_origin_transform.rotation; - - jointAxisInJointSpace.setValue(pj->axis.x,pj->axis.y,pj->axis.z); - parent2joint.setOrigin(btVector3(pos.x,pos.y,pos.z)); - parent2joint.setRotation(btQuaternion(orn.x,orn.y,orn.z,orn.w)); - - switch (pj->type) - { - case Joint::REVOLUTE: - jointType = URDF2Bullet::RevoluteJoint; - break; - case Joint::FIXED: - jointType = URDF2Bullet::FixedJoint; - break; - case Joint::PRISMATIC: - jointType = URDF2Bullet::PrismaticJoint; - break; - case Joint::PLANAR: - jointType = URDF2Bullet::PlanarJoint; - break; - case Joint::CONTINUOUS: - jointType = URDF2Bullet::ContinuousJoint; - break; - default: - { - printf("Error: unknown joint type %d\n", pj->type); - btAssert(0); - } - - }; - - if (pj->limits) - { - jointLowerLimit = pj->limits.get()->lower; - jointUpperLimit = pj->limits.get()->upper; - } - return true; - } else - { - parent2joint.setIdentity(); - return false; - } - } - - virtual int convertLinkVisualShapes(int linkIndex, const char* pathPrefix, const btTransform& inertialFrame) const - { - btAlignedObjectArray vertices; - btAlignedObjectArray indices; - btTransform startTrans; startTrans.setIdentity(); - int graphicsIndex = -1; - - for (int v = 0; v < (int)m_links[linkIndex]->visual_array.size(); v++) - { - const Visual* vis = m_links[linkIndex]->visual_array[v].get(); - btVector3 childPos(vis->origin.position.x, vis->origin.position.y, vis->origin.position.z); - btQuaternion childOrn(vis->origin.rotation.x, vis->origin.rotation.y, vis->origin.rotation.z, vis->origin.rotation.w); - btTransform childTrans; - childTrans.setOrigin(childPos); - childTrans.setRotation(childOrn); - - convertURDFToVisualShape(vis, pathPrefix, inertialFrame.inverse()*childTrans, vertices, indices); - - } - - if (vertices.size() && indices.size()) - { - graphicsIndex = m_gfxBridge.registerGraphicsShape(&vertices[0].xyzw[0], vertices.size(), &indices[0], indices.size()); - } - - return graphicsIndex; - - } - - virtual class btCompoundShape* convertLinkCollisionShapes(int linkIndex, const char* pathPrefix, const btTransform& localInertiaFrame) const - { - - btCompoundShape* compoundShape = new btCompoundShape(); - compoundShape->setMargin(0.001); - - for (int v=0;v<(int)m_links[linkIndex]->collision_array.size();v++) - { - const Collision* col = m_links[linkIndex]->collision_array[v].get(); - btCollisionShape* childShape = convertURDFToCollisionShape(col ,pathPrefix); - - if (childShape) - { - btVector3 childPos(col->origin.position.x, col->origin.position.y, col->origin.position.z); - btQuaternion childOrn(col->origin.rotation.x, col->origin.rotation.y, col->origin.rotation.z, col->origin.rotation.w); - btTransform childTrans; - childTrans.setOrigin(childPos); - childTrans.setRotation(childOrn); - compoundShape->addChildShape(localInertiaFrame.inverse()*childTrans,childShape); - - } - } - - return compoundShape; - } - - virtual class btMultiBody* allocateMultiBody(int /* urdfLinkIndex */, int totalNumJoints,btScalar mass, const btVector3& localInertiaDiagonal, bool isFixedBase, bool canSleep, bool multiDof) const - { - m_bulletMultiBody = new btMultiBody(totalNumJoints,mass,localInertiaDiagonal,isFixedBase,canSleep,multiDof); - return m_bulletMultiBody; - } - - virtual class btRigidBody* allocateRigidBody(int urdfLinkIndex, btScalar mass, const btVector3& localInertiaDiagonal, const btTransform& initialWorldTrans, class btCollisionShape* colShape) const - { - btRigidBody::btRigidBodyConstructionInfo rbci(mass, 0, colShape, localInertiaDiagonal); - rbci.m_startWorldTransform = initialWorldTrans; - btRigidBody* body = new btRigidBody(rbci); - return body; - } - - virtual class btMultiBodyLinkCollider* allocateMultiBodyLinkCollider(int /*urdfLinkIndex*/, int mbLinkIndex, btMultiBody* multiBody) const - { - btMultiBodyLinkCollider* mbCol= new btMultiBodyLinkCollider(multiBody, mbLinkIndex); - return mbCol; - } - - - virtual class btGeneric6DofSpring2Constraint* allocateGeneric6DofSpring2Constraint(int urdfLinkIndex, btRigidBody& rbA /*parent*/, btRigidBody& rbB, const btTransform& offsetInA, const btTransform& offsetInB, int rotateOrder) const - { - btGeneric6DofSpring2Constraint* c = new btGeneric6DofSpring2Constraint(rbA,rbB,offsetInA, offsetInB, (RotateOrder)rotateOrder); - return c; - } - - virtual void addLinkMapping(int urdfLinkIndex, int mbLinkIndex) const - { - m_urdf2mbLink[urdfLinkIndex] = mbLinkIndex; - m_mb2urdfLink[mbLinkIndex] = urdfLinkIndex; - } - - virtual void createRigidBodyGraphicsInstance(int linkIndex, btRigidBody* body, const btVector3& colorRgba, int graphicsIndex) const - { - - m_gfxBridge.createRigidBodyGraphicsObject(body, colorRgba); - } - - virtual void createCollisionObjectGraphicsInstance(int linkIndex, class btCollisionObject* colObj, const btVector3& colorRgba) const - { - m_gfxBridge.createCollisionObjectGraphicsObject(colObj,colorRgba); - } - - btMultiBody* getBulletMultiBody() - { - return m_bulletMultiBody; - } - -}; - - - -btAlignedObjectArray gFileNameArray; - - -#define MAX_NUM_MOTORS 1024 - -struct ImportUrdfInternalData -{ - ImportUrdfInternalData() - :m_numMotors(0) - { - } - - btScalar m_motorTargetVelocities[MAX_NUM_MOTORS]; - btMultiBodyJointMotor* m_jointMotors [MAX_NUM_MOTORS]; - int m_numMotors; -}; - - -ImportUrdfSetup::ImportUrdfSetup() -{ - static int count = 0; - gFileNameArray.clear(); - gFileNameArray.push_back("r2d2.urdf"); - - m_data = new ImportUrdfInternalData; - - //load additional urdf file names from file - - FILE* f = fopen("urdf_files.txt","r"); - if (f) - { - int result; - //warning: we don't avoid string buffer overflow in this basic example in fscanf - char fileName[1024]; - do - { - result = fscanf(f,"%s",fileName); - if (result==1) - { - gFileNameArray.push_back(fileName); - } - } while (result==1); - - fclose(f); - } - - int numFileNames = gFileNameArray.size(); - - if (count>=numFileNames) - { - count=0; - } - sprintf(m_fileName,gFileNameArray[count++].c_str()); -} - -ImportUrdfSetup::~ImportUrdfSetup() -{ - delete m_data; -} - -static btVector4 colors[4] = -{ - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), -}; - - -btVector3 selectColor() -{ - - static int curColor = 0; - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - return color; -} - -void ImportUrdfSetup::setFileName(const char* urdfFileName) -{ - memcpy(m_fileName,urdfFileName,strlen(urdfFileName)+1); -} - - - - - -void printTree(my_shared_ptr link,int level = 0) -{ - level+=2; - int count = 0; - for (std::vector >::const_iterator child = link->child_links.begin(); child != link->child_links.end(); child++) - { - if (*child) - { - for(int j=0;jname << std::endl; - // first grandchild - printTree(*child,level); - } - else - { - for(int j=0;jname << " has a null child!" << *child << std::endl; - } - } - -} - - -struct URDF_LinkInformation -{ - const Link* m_thisLink; - int m_linkIndex; - //int m_parentIndex; - - btTransform m_localInertialFrame; - //btTransform m_localVisualFrame; - btTransform m_bodyWorldTransform; - btVector3 m_localInertiaDiagonal; - btScalar m_mass; - - btCollisionShape* m_collisionShape; - btRigidBody* m_bulletRigidBody; - - URDF_LinkInformation() - :m_thisLink(0), - m_linkIndex(-2), - //m_parentIndex(-2), - m_collisionShape(0), - m_bulletRigidBody(0) - { - - } - virtual ~URDF_LinkInformation() - { - printf("~\n"); - } -}; - -struct URDF_JointInformation -{ - -}; - - -struct URDF2BulletMappings -{ - btHashMap m_link2rigidbody; - btAlignedObjectArray m_linkMasses; - - bool m_createMultiBody; - int m_totalNumJoints; - btMultiBody* m_bulletMultiBody; - - btAlignedObjectArray m_urdfLinkIndices2BulletLinkIndices; - URDF2BulletMappings() - :m_createMultiBody(false), - m_totalNumJoints(0), - m_bulletMultiBody(0) - { - } - -}; -enum MyFileType -{ - FILE_STL=1, - FILE_COLLADA=2, - FILE_OBJ=3, -}; - - - -void convertURDFToVisualShape(const Visual* visual, const char* pathPrefix, const btTransform& visualTransform, btAlignedObjectArray& verticesOut, btAlignedObjectArray& indicesOut) -{ - - - GLInstanceGraphicsShape* glmesh = 0; - - btConvexShape* convexColShape = 0; - - switch (visual->geometry->type) - { - case Geometry::CYLINDER: - { - printf("processing a cylinder\n"); - urdf::Cylinder* cyl = (urdf::Cylinder*)visual->geometry.get(); - btAlignedObjectArray vertices; - - //int numVerts = sizeof(barrel_vertices)/(9*sizeof(float)); - int numSteps = 32; - for (int i = 0; iradius*btSin(SIMD_2_PI*(float(i) / numSteps)), cyl->radius*btCos(SIMD_2_PI*(float(i) / numSteps)), cyl->length / 2.); - vertices.push_back(vert); - vert[2] = -cyl->length / 2.; - vertices.push_back(vert); - } - - btConvexHullShape* cylZShape = new btConvexHullShape(&vertices[0].x(), vertices.size(), sizeof(btVector3)); - cylZShape->setMargin(0.001); - convexColShape = cylZShape; - break; - } - case Geometry::BOX: - { - printf("processing a box\n"); - urdf::Box* box = (urdf::Box*)visual->geometry.get(); - btVector3 extents(box->dim.x, box->dim.y, box->dim.z); - btBoxShape* boxShape = new btBoxShape(extents*0.5f); - //btConvexShape* boxShape = new btConeShapeX(extents[2]*0.5,extents[0]*0.5); - convexColShape = boxShape; - convexColShape->setMargin(0.001); - break; - } - case Geometry::SPHERE: - { - printf("processing a sphere\n"); - urdf::Sphere* sphere = (urdf::Sphere*)visual->geometry.get(); - btScalar radius = sphere->radius; - btSphereShape* sphereShape = new btSphereShape(radius); - convexColShape = sphereShape; - convexColShape->setMargin(0.001); - break; - - break; - } - case Geometry::MESH: - { - if (visual->name.length()) - { - printf("visual->name=%s\n", visual->name.c_str()); - } - if (visual->geometry) - { - const urdf::Mesh* mesh = (const urdf::Mesh*) visual->geometry.get(); - if (mesh->filename.length()) - { - const char* filename = mesh->filename.c_str(); - printf("mesh->filename=%s\n", filename); - char fullPath[1024]; - int fileType = 0; - sprintf(fullPath, "%s%s", pathPrefix, filename); - b3FileUtils::toLower(fullPath); - if (strstr(fullPath, ".dae")) - { - fileType = FILE_COLLADA; - } - if (strstr(fullPath, ".stl")) - { - fileType = FILE_STL; - } - if (strstr(fullPath,".obj")) - { - fileType = FILE_OBJ; - } - - - sprintf(fullPath, "%s%s", pathPrefix, filename); - FILE* f = fopen(fullPath, "rb"); - if (f) - { - fclose(f); - - - - switch (fileType) - { - case FILE_OBJ: - { - glmesh = LoadMeshFromObj(fullPath,pathPrefix); - break; - } - - case FILE_STL: - { - glmesh = LoadMeshFromSTL(fullPath); - break; - } - case FILE_COLLADA: - { - - btAlignedObjectArray visualShapes; - btAlignedObjectArray visualShapeInstances; - btTransform upAxisTrans; upAxisTrans.setIdentity(); - float unitMeterScaling = 1; - int upAxis = 2; - - LoadMeshFromCollada(fullPath, - visualShapes, - visualShapeInstances, - upAxisTrans, - unitMeterScaling, - upAxis); - - glmesh = new GLInstanceGraphicsShape; - int index = 0; - glmesh->m_indices = new b3AlignedObjectArray(); - glmesh->m_vertices = new b3AlignedObjectArray(); - - for (int i = 0; im_shapeIndex]; - - b3AlignedObjectArray verts; - verts.resize(gfxShape->m_vertices->size()); - - int baseIndex = glmesh->m_vertices->size(); - - for (int i = 0; im_vertices->size(); i++) - { - verts[i].normal[0] = gfxShape->m_vertices->at(i).normal[0]; - verts[i].normal[1] = gfxShape->m_vertices->at(i).normal[1]; - verts[i].normal[2] = gfxShape->m_vertices->at(i).normal[2]; - verts[i].uv[0] = gfxShape->m_vertices->at(i).uv[0]; - verts[i].uv[1] = gfxShape->m_vertices->at(i).uv[1]; - verts[i].xyzw[0] = gfxShape->m_vertices->at(i).xyzw[0]; - verts[i].xyzw[1] = gfxShape->m_vertices->at(i).xyzw[1]; - verts[i].xyzw[2] = gfxShape->m_vertices->at(i).xyzw[2]; - verts[i].xyzw[3] = gfxShape->m_vertices->at(i).xyzw[3]; - - } - - int curNumIndices = glmesh->m_indices->size(); - int additionalIndices = gfxShape->m_indices->size(); - glmesh->m_indices->resize(curNumIndices + additionalIndices); - for (int k = 0; km_indices->at(curNumIndices + k) = gfxShape->m_indices->at(k) + baseIndex; - } - - //compensate upAxisTrans and unitMeterScaling here - btMatrix4x4 upAxisMat; - upAxisMat.setIdentity(); -// upAxisMat.setPureRotation(upAxisTrans.getRotation()); - btMatrix4x4 unitMeterScalingMat; - unitMeterScalingMat.setPureScaling(btVector3(unitMeterScaling, unitMeterScaling, unitMeterScaling)); - btMatrix4x4 worldMat = unitMeterScalingMat*upAxisMat*instance->m_worldTransform; - //btMatrix4x4 worldMat = instance->m_worldTransform; - int curNumVertices = glmesh->m_vertices->size(); - int additionalVertices = verts.size(); - glmesh->m_vertices->reserve(curNumVertices + additionalVertices); - - for (int v = 0; vm_vertices->push_back(verts[v]); - } - } - glmesh->m_numIndices = glmesh->m_indices->size(); - glmesh->m_numvertices = glmesh->m_vertices->size(); - //glmesh = LoadMeshFromCollada(fullPath); - - break; - } - default: - { - printf("Error: unsupported file type for Visual mesh: %s\n", fullPath); - btAssert(0); - } - } - - - if (glmesh && (glmesh->m_numvertices>0)) - { - } - else - { - printf("issue extracting mesh from COLLADA/STL file %s\n", fullPath); - } - - } - else - { - printf("mesh geometry not found %s\n", fullPath); - } - - - } - } - - - break; - } - default: - { - printf("Error: unknown visual geometry type\n"); - } - } - - //if we have a convex, tesselate into localVertices/localIndices - if (convexColShape) - { - btShapeHull* hull = new btShapeHull(convexColShape); - hull->buildHull(0.0); - { - // int strideInBytes = 9*sizeof(float); - int numVertices = hull->numVertices(); - int numIndices = hull->numIndices(); - - - glmesh = new GLInstanceGraphicsShape; - int index = 0; - glmesh->m_indices = new b3AlignedObjectArray(); - glmesh->m_vertices = new b3AlignedObjectArray(); - - - for (int i = 0; i < numVertices; i++) - { - GLInstanceVertex vtx; - btVector3 pos = hull->getVertexPointer()[i]; - vtx.xyzw[0] = pos.x(); - vtx.xyzw[1] = pos.y(); - vtx.xyzw[2] = pos.z(); - vtx.xyzw[3] = 1.f; - pos.normalize(); - vtx.normal[0] = pos.x(); - vtx.normal[1] = pos.y(); - vtx.normal[2] = pos.z(); - vtx.uv[0] = 0.5f; - vtx.uv[1] = 0.5f; - glmesh->m_vertices->push_back(vtx); - } - - btAlignedObjectArray indices; - for (int i = 0; i < numIndices; i++) - { - glmesh->m_indices->push_back(hull->getIndexPointer()[i]); - } - - glmesh->m_numvertices = glmesh->m_vertices->size(); - glmesh->m_numIndices = glmesh->m_indices->size(); - } - delete convexColShape; - convexColShape = 0; - - } - - if (glmesh && glmesh->m_numIndices>0 && glmesh->m_numvertices >0) - { - - int baseIndex = verticesOut.size(); - - - - for (int i = 0; i < glmesh->m_indices->size(); i++) - { - indicesOut.push_back(glmesh->m_indices->at(i) + baseIndex); - } - - for (int i = 0; i < glmesh->m_vertices->size(); i++) - { - GLInstanceVertex& v = glmesh->m_vertices->at(i); - btVector3 vert(v.xyzw[0],v.xyzw[1],v.xyzw[2]); - btVector3 vt = visualTransform*vert; - v.xyzw[0] = vt[0]; - v.xyzw[1] = vt[1]; - v.xyzw[2] = vt[2]; - btVector3 triNormal(v.normal[0],v.normal[1],v.normal[2]); - triNormal = visualTransform.getBasis()*triNormal; - v.normal[0] = triNormal[0]; - v.normal[1] = triNormal[1]; - v.normal[2] = triNormal[2]; - verticesOut.push_back(v); - } - } -} - -btCollisionShape* convertURDFToCollisionShape(const Collision* visual, const char* pathPrefix) -{ - btCollisionShape* shape = 0; - - switch (visual->geometry->type) - { - case Geometry::CYLINDER: - { - printf("processing a cylinder\n"); - urdf::Cylinder* cyl = (urdf::Cylinder*)visual->geometry.get(); - - btAlignedObjectArray vertices; - //int numVerts = sizeof(barrel_vertices)/(9*sizeof(float)); - int numSteps = 32; - for (int i=0;iradius*btSin(SIMD_2_PI*(float(i)/numSteps)),cyl->radius*btCos(SIMD_2_PI*(float(i)/numSteps)),cyl->length/2.); - vertices.push_back(vert); - vert[2] = -cyl->length/2.; - vertices.push_back(vert); - - } - btConvexHullShape* cylZShape = new btConvexHullShape(&vertices[0].x(), vertices.size(), sizeof(btVector3)); - cylZShape->setMargin(0.001); - cylZShape->initializePolyhedralFeatures(); - //btConvexShape* cylZShape = new btConeShapeZ(cyl->radius,cyl->length);//(vexHullShape(&vertices[0].x(), vertices.size(), sizeof(btVector3)); - - //btVector3 halfExtents(cyl->radius,cyl->radius,cyl->length/2.); - //btCylinderShapeZ* cylZShape = new btCylinderShapeZ(halfExtents); - - - shape = cylZShape; - break; - } - case Geometry::BOX: - { - printf("processing a box\n"); - urdf::Box* box = (urdf::Box*)visual->geometry.get(); - btVector3 extents(box->dim.x,box->dim.y,box->dim.z); - btBoxShape* boxShape = new btBoxShape(extents*0.5f); - //btConvexShape* boxShape = new btConeShapeX(extents[2]*0.5,extents[0]*0.5); - shape = boxShape; - shape ->setMargin(0.001); - break; - } - case Geometry::SPHERE: - { - printf("processing a sphere\n"); - urdf::Sphere* sphere = (urdf::Sphere*)visual->geometry.get(); - btScalar radius = sphere->radius; - btSphereShape* sphereShape = new btSphereShape(radius); - shape = sphereShape; - shape ->setMargin(0.001); - break; - - break; - } - case Geometry::MESH: - { - if (visual->name.length()) - { - printf("visual->name=%s\n",visual->name.c_str()); - } - if (visual->geometry) - { - const urdf::Mesh* mesh = (const urdf::Mesh*) visual->geometry.get(); - if (mesh->filename.length()) - { - const char* filename = mesh->filename.c_str(); - printf("mesh->filename=%s\n",filename); - char fullPath[1024]; - int fileType = 0; - sprintf(fullPath,"%s%s",pathPrefix,filename); - b3FileUtils::toLower(fullPath); - if (strstr(fullPath,".dae")) - { - fileType = FILE_COLLADA; - } - if (strstr(fullPath,".stl")) - { - fileType = FILE_STL; - } - if (strstr(fullPath,".obj")) - { - fileType = FILE_OBJ; - } - - sprintf(fullPath,"%s%s",pathPrefix,filename); - FILE* f = fopen(fullPath,"rb"); - if (f) - { - fclose(f); - GLInstanceGraphicsShape* glmesh = 0; - - - switch (fileType) - { - case FILE_OBJ: - { - glmesh = LoadMeshFromObj(fullPath,pathPrefix); - break; - } - case FILE_STL: - { - glmesh = LoadMeshFromSTL(fullPath); - break; - } - case FILE_COLLADA: - { - - btAlignedObjectArray visualShapes; - btAlignedObjectArray visualShapeInstances; - btTransform upAxisTrans;upAxisTrans.setIdentity(); - float unitMeterScaling=1; - int upAxis = 2; - LoadMeshFromCollada(fullPath, - visualShapes, - visualShapeInstances, - upAxisTrans, - unitMeterScaling, - upAxis ); - - glmesh = new GLInstanceGraphicsShape; - int index = 0; - glmesh->m_indices = new b3AlignedObjectArray(); - glmesh->m_vertices = new b3AlignedObjectArray(); - - for (int i=0;im_shapeIndex]; - - b3AlignedObjectArray verts; - verts.resize(gfxShape->m_vertices->size()); - - int baseIndex = glmesh->m_vertices->size(); - - for (int i=0;im_vertices->size();i++) - { - verts[i].normal[0] = gfxShape->m_vertices->at(i).normal[0]; - verts[i].normal[1] = gfxShape->m_vertices->at(i).normal[1]; - verts[i].normal[2] = gfxShape->m_vertices->at(i).normal[2]; - verts[i].uv[0] = gfxShape->m_vertices->at(i).uv[0]; - verts[i].uv[1] = gfxShape->m_vertices->at(i).uv[1]; - verts[i].xyzw[0] = gfxShape->m_vertices->at(i).xyzw[0]; - verts[i].xyzw[1] = gfxShape->m_vertices->at(i).xyzw[1]; - verts[i].xyzw[2] = gfxShape->m_vertices->at(i).xyzw[2]; - verts[i].xyzw[3] = gfxShape->m_vertices->at(i).xyzw[3]; - - } - - int curNumIndices = glmesh->m_indices->size(); - int additionalIndices = gfxShape->m_indices->size(); - glmesh->m_indices->resize(curNumIndices+additionalIndices); - for (int k=0;km_indices->at(curNumIndices+k)=gfxShape->m_indices->at(k)+baseIndex; - } - - //compensate upAxisTrans and unitMeterScaling here - btMatrix4x4 upAxisMat; - upAxisMat.setPureRotation(upAxisTrans.getRotation()); - btMatrix4x4 unitMeterScalingMat; - unitMeterScalingMat.setPureScaling(btVector3(unitMeterScaling,unitMeterScaling,unitMeterScaling)); - btMatrix4x4 worldMat = unitMeterScalingMat*instance->m_worldTransform*upAxisMat; - //btMatrix4x4 worldMat = instance->m_worldTransform; - int curNumVertices = glmesh->m_vertices->size(); - int additionalVertices = verts.size(); - glmesh->m_vertices->reserve(curNumVertices+additionalVertices); - - for(int v=0;vm_vertices->push_back(verts[v]); - } - } - glmesh->m_numIndices = glmesh->m_indices->size(); - glmesh->m_numvertices = glmesh->m_vertices->size(); - //glmesh = LoadMeshFromCollada(fullPath); - - break; - } - default: - { - printf("Unsupported file type in Collision: %s\n",fullPath); - btAssert(0); - } - } - - - if (glmesh && (glmesh->m_numvertices>0)) - { - printf("extracted %d verticed from STL file %s\n", glmesh->m_numvertices,fullPath); - //int shapeId = m_glApp->m_instancingRenderer->registerShape(&gvertices[0].pos[0],gvertices.size(),&indices[0],indices.size()); - //convex->setUserIndex(shapeId); - btAlignedObjectArray convertedVerts; - convertedVerts.reserve(glmesh->m_numvertices); - for (int i=0;im_numvertices;i++) - { - convertedVerts.push_back(btVector3(glmesh->m_vertices->at(i).xyzw[0],glmesh->m_vertices->at(i).xyzw[1],glmesh->m_vertices->at(i).xyzw[2])); - } - //btConvexHullShape* cylZShape = new btConvexHullShape(&glmesh->m_vertices->at(0).xyzw[0], glmesh->m_numvertices, sizeof(GLInstanceVertex)); - btConvexHullShape* cylZShape = new btConvexHullShape(&convertedVerts[0].getX(), convertedVerts.size(), sizeof(btVector3)); - //cylZShape->initializePolyhedralFeatures(); - //btVector3 halfExtents(cyl->radius,cyl->radius,cyl->length/2.); - //btCylinderShapeZ* cylZShape = new btCylinderShapeZ(halfExtents); - cylZShape->setMargin(0.001); - shape = cylZShape; - } else - { - printf("issue extracting mesh from STL file %s\n", fullPath); - } - - } else - { - printf("mesh geometry not found %s\n",fullPath); - } - - - } - } - - - break; - } - default: - { - printf("Error: unknown visual geometry type\n"); - } - } - return shape; -} -void URDFvisual2BulletCollisionShape(my_shared_ptr link, GraphicsPhysicsBridge& gfxBridge, const btTransform& parentTransformInWorldSpace, btMultiBodyDynamicsWorld* world1, URDF2BulletMappings& mappings, const char* pathPrefix) -{ - //btCollisionShape* shape = 0; - - btTransform linkTransformInWorldSpace; - linkTransformInWorldSpace.setIdentity(); - - btScalar mass = 0; - btTransform inertialFrame; - inertialFrame.setIdentity(); - const Link* parentLink = (*link).getParent(); - URDF_LinkInformation* pp = 0; - - int linkIndex = mappings.m_linkMasses.size();//assuming root == 0, child links use contiguous numbering > 0 - - btVector3 localInertiaDiagonal(0,0,0); - - int parentIndex = -1; - - - if (parentLink) - { - parentIndex = mappings.m_urdfLinkIndices2BulletLinkIndices[parentLink->m_link_index]; - - btAssert(parentIndex>=0); - } - - { - URDF_LinkInformation** ppRigidBody = mappings.m_link2rigidbody.find(parentLink); - if (ppRigidBody) - { - pp = (*ppRigidBody); - btTransform tr = pp->m_bodyWorldTransform; - printf("rigidbody origin (COM) of link(%s) parent(%s): %f,%f,%f\n",(*link).name.c_str(), parentLink->name.c_str(), tr.getOrigin().x(), tr.getOrigin().y(), tr.getOrigin().z()); - } - } - - mappings.m_urdfLinkIndices2BulletLinkIndices[(*link).m_link_index] = linkIndex; - - if ((*link).inertial) - { - mass = (*link).inertial->mass; - localInertiaDiagonal.setValue((*link).inertial->ixx,(*link).inertial->iyy,(*link).inertial->izz); - inertialFrame.setOrigin(btVector3((*link).inertial->origin.position.x,(*link).inertial->origin.position.y,(*link).inertial->origin.position.z)); - inertialFrame.setRotation(btQuaternion((*link).inertial->origin.rotation.x,(*link).inertial->origin.rotation.y,(*link).inertial->origin.rotation.z,(*link).inertial->origin.rotation.w)); - } - - - btTransform parent2joint; - parent2joint.setIdentity(); - - if ((*link).parent_joint) - { - - const urdf::Vector3 pos = (*link).parent_joint->parent_to_joint_origin_transform.position; - const urdf::Rotation orn = (*link).parent_joint->parent_to_joint_origin_transform.rotation; - - parent2joint.setOrigin(btVector3(pos.x,pos.y,pos.z)); - parent2joint.setRotation(btQuaternion(orn.x,orn.y,orn.z,orn.w)); - linkTransformInWorldSpace =parentTransformInWorldSpace*parent2joint; - } else - { - linkTransformInWorldSpace = parentTransformInWorldSpace; - - - - } - - - { - printf("converting visuals of link %s", link->name.c_str()); - - - - { - - - - btAlignedObjectArray vertices; - btAlignedObjectArray indices; - btTransform startTrans; startTrans.setIdentity(); - int graphicsIndex = -1; - - for (int v = 0; v < (int)link->visual_array.size(); v++) - { - const Visual* vis = link->visual_array[v].get(); - btVector3 childPos(vis->origin.position.x, vis->origin.position.y, vis->origin.position.z); - btQuaternion childOrn(vis->origin.rotation.x, vis->origin.rotation.y, vis->origin.rotation.z, vis->origin.rotation.w); - btTransform childTrans; - childTrans.setOrigin(childPos); - childTrans.setRotation(childOrn); - - convertURDFToVisualShape(vis, pathPrefix, inertialFrame.inverse()*childTrans, vertices, indices); - - } - - if (vertices.size() && indices.size()) - { - graphicsIndex = gfxBridge.registerGraphicsShape(&vertices[0].xyzw[0], vertices.size(), &indices[0], indices.size()); - } - - - - btCompoundShape* compoundShape = new btCompoundShape(); - compoundShape->setMargin(0.001); - for (int v=0;v<(int)link->collision_array.size();v++) - { - const Collision* col = link->collision_array[v].get(); - btCollisionShape* childShape = convertURDFToCollisionShape(col ,pathPrefix); - if (childShape) - { - btVector3 childPos(col->origin.position.x, col->origin.position.y, col->origin.position.z); - btQuaternion childOrn(col->origin.rotation.x, col->origin.rotation.y, col->origin.rotation.z, col->origin.rotation.w); - btTransform childTrans; - childTrans.setOrigin(childPos); - childTrans.setRotation(childOrn); - compoundShape->addChildShape(inertialFrame.inverse()*childTrans,childShape); - - } - } - - - - - - if (compoundShape) - { - - - btVector3 color = selectColor(); - /* if (visual->material.get()) - { - color.setValue(visual->material->color.r,visual->material->color.g,visual->material->color.b);//,visual->material->color.a); - } - */ - //btVector3 localInertiaDiagonal(0, 0, 0); - //if (mass) - //{ - // shape->calculateLocalInertia(mass, localInertiaDiagonal); - //} - - - //btTransform visualFrameInWorldSpace = linkTransformInWorldSpace*visual_frame; - btTransform inertialFrameInWorldSpace = linkTransformInWorldSpace*inertialFrame; - URDF_LinkInformation* linkInfo = new URDF_LinkInformation; - - if (!mappings.m_createMultiBody) - { - btRigidBody::btRigidBodyConstructionInfo rbci(mass, 0, compoundShape, localInertiaDiagonal); - rbci.m_startWorldTransform = inertialFrameInWorldSpace; - linkInfo->m_bodyWorldTransform = inertialFrameInWorldSpace;//visualFrameInWorldSpace - //rbci.m_startWorldTransform = inertialFrameInWorldSpace;//linkCenterOfMass; - btRigidBody* body = new btRigidBody(rbci); - world1->addRigidBody(body, bodyCollisionFilterGroup, bodyCollisionFilterMask); - - compoundShape->setUserIndex(graphicsIndex); - - gfxBridge.createRigidBodyGraphicsObject(body, color); - linkInfo->m_bulletRigidBody = body; - } else - { - if (mappings.m_bulletMultiBody==0) - { - bool multiDof = true; - bool canSleep = false; - bool isFixedBase = (mass==0);//todo: figure out when base is fixed - int totalNumJoints = mappings.m_totalNumJoints; - mappings.m_bulletMultiBody = new btMultiBody(totalNumJoints,mass, localInertiaDiagonal, isFixedBase, canSleep, multiDof); - } - - } - - - linkInfo->m_collisionShape = compoundShape; - linkInfo->m_localInertiaDiagonal = localInertiaDiagonal; - linkInfo->m_mass = mass; - //linkInfo->m_localVisualFrame =visual_frame; - linkInfo->m_localInertialFrame =inertialFrame; - linkInfo->m_thisLink = link.get(); - const Link* p = link.get(); - mappings.m_link2rigidbody.insert(p, linkInfo); - - //create a joint if necessary - if ((*link).parent_joint && pp) - { - btAssert(pp); - - - - const Joint* pj = (*link).parent_joint.get(); - btTransform offsetInA,offsetInB; - static bool once = true; - - offsetInA.setIdentity(); - static bool toggle=false; - - //offsetInA = pp->m_localVisualFrame.inverse()*parent2joint; - offsetInA = pp->m_localInertialFrame.inverse()*parent2joint; - - offsetInB.setIdentity(); - //offsetInB = visual_frame.inverse(); - offsetInB = inertialFrame.inverse(); - - - bool disableParentCollision = true; - btVector3 jointAxis(pj->axis.x,pj->axis.y,pj->axis.z); - switch (pj->type) - { - case Joint::FIXED: - { - if (mappings.m_createMultiBody) - { - //todo: adjust the center of mass transform and pivot axis properly - - printf("Fixed joint (btMultiBody)\n"); - //btVector3 dVec = quatRotate(parentComToThisCom.getRotation(),offsetInB.inverse().getOrigin()); - btQuaternion rot = offsetInA.inverse().getRotation();//parent2joint.inverse().getRotation(); - //toggle=!toggle; - //mappings.m_bulletMultiBody->setupFixed(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - // rot, parent2joint.getOrigin(), btVector3(0,0,0),disableParentCollision); - mappings.m_bulletMultiBody->setupFixed(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - rot*offsetInB.getRotation(), offsetInA.getOrigin(),-offsetInB.getOrigin(),disableParentCollision); - - /* - mappings.m_bulletMultiBody->setupRevolute(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - parent2joint.inverse().getRotation(), jointAxis, offsetInA.getOrigin(),//parent2joint.getOrigin(), - -offsetInB.getOrigin(), - disableParentCollision); - */ - - btMatrix3x3 rm(rot); - btScalar y,p,r; - rm.getEulerZYX(y,p,r); - //parent2joint.inverse().getRotation(), offsetInA.getOrigin(), -offsetInB.getOrigin(), disableParentCollision); - //linkInfo->m_localVisualFrame.setIdentity(); - printf("y=%f,p=%f,r=%f\n", y,p,r); - - - - } else - { - printf("Fixed joint\n"); - - btMatrix3x3 rm(offsetInA.getBasis()); - btScalar y,p,r; - rm.getEulerZYX(y,p,r); - //parent2joint.inverse().getRotation(), offsetInA.getOrigin(), -offsetInB.getOrigin(), disableParentCollision); - //linkInfo->m_localVisualFrame.setIdentity(); - printf("y=%f,p=%f,r=%f\n", y,p,r); - - btGeneric6DofSpring2Constraint* dof6 = new btGeneric6DofSpring2Constraint(*pp->m_bulletRigidBody, *linkInfo->m_bulletRigidBody, offsetInA, offsetInB); - // btVector3 bulletAxis(pj->axis.x,pj->axis.y,pj->axis.z); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularLowerLimit(btVector3(0,0,0)); - dof6->setAngularUpperLimit(btVector3(0,0,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - - // btFixedConstraint* fixed = new btFixedConstraint(*parentBody, *body,offsetInA,offsetInB); - // world->addConstraint(fixed,true); - } - break; - } - case Joint::CONTINUOUS: - case Joint::REVOLUTE: - { - if (mappings.m_createMultiBody) - { - //todo: adjust the center of mass transform and pivot axis properly - /*mappings.m_bulletMultiBody->setupRevolute( - linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - - parent2joint.inverse().getRotation(), jointAxis, parent2joint.getOrigin(), - btVector3(0,0,0),//offsetInB.getOrigin(), - disableParentCollision); - */ - - - mappings.m_bulletMultiBody->setupRevolute(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - //parent2joint.inverse().getRotation(), jointAxis, offsetInA.getOrigin(),//parent2joint.getOrigin(), - offsetInA.inverse().getRotation()*offsetInB.getRotation(), quatRotate(offsetInB.inverse().getRotation(),jointAxis), offsetInA.getOrigin(),//parent2joint.getOrigin(), - - -offsetInB.getOrigin(), - disableParentCollision); - //linkInfo->m_localVisualFrame.setIdentity(); - - } else - { - //only handle principle axis at the moment, - //@todo(erwincoumans) orient the constraint for non-principal axis - btVector3 axis(pj->axis.x,pj->axis.y,pj->axis.z); - int principleAxis = axis.closestAxis(); - switch (principleAxis) - { - case 0: - { - btGeneric6DofSpring2Constraint* dof6 = new btGeneric6DofSpring2Constraint(*pp->m_bulletRigidBody, *linkInfo->m_bulletRigidBody, offsetInA, offsetInB,RO_ZYX); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularUpperLimit(btVector3(-1,0,0)); - dof6->setAngularLowerLimit(btVector3(1,0,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - break; - } - case 1: - { - btGeneric6DofSpring2Constraint* dof6 = new btGeneric6DofSpring2Constraint(*pp->m_bulletRigidBody, *linkInfo->m_bulletRigidBody, offsetInA, offsetInB,RO_XZY); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularUpperLimit(btVector3(0,-1,0)); - dof6->setAngularLowerLimit(btVector3(0,1,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - break; - } - case 2: - default: - { - btGeneric6DofSpring2Constraint* dof6 = new btGeneric6DofSpring2Constraint(*pp->m_bulletRigidBody, *linkInfo->m_bulletRigidBody, offsetInA, offsetInB,RO_XYZ); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularUpperLimit(btVector3(0,0,-1)); - dof6->setAngularLowerLimit(btVector3(0,0,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - } - }; - printf("Revolute/Continuous joint\n"); - } - break; - } - case Joint::PRISMATIC: - { - if (mappings.m_createMultiBody) - { - //mappings.m_bulletMultiBody->setupPrismatic(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - // parent2joint.inverse().getRotation(),jointAxis,parent2joint.getOrigin(),disableParentCollision); - - //mappings.m_bulletMultiBody->setupPrismatic(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - // parent2joint.inverse().getRotation(),jointAxis,parent2joint.getOrigin(),disableParentCollision); - - mappings.m_bulletMultiBody->setupPrismatic(linkIndex - 1, mass, localInertiaDiagonal, parentIndex - 1, - offsetInA.inverse().getRotation()*offsetInB.getRotation(), quatRotate(offsetInB.inverse().getRotation(),jointAxis), offsetInA.getOrigin(),//parent2joint.getOrigin(), - -offsetInB.getOrigin(), - disableParentCollision); - - - - } else - { - - btGeneric6DofSpring2Constraint* dof6 = new btGeneric6DofSpring2Constraint(*pp->m_bulletRigidBody, *linkInfo->m_bulletRigidBody, offsetInA, offsetInB); - //todo(erwincoumans) for now, we only support principle axis along X, Y or Z - btVector3 axis(pj->axis.x,pj->axis.y,pj->axis.z); - int principleAxis = axis.closestAxis(); - switch (principleAxis) - { - case 0: - { - dof6->setLinearLowerLimit(btVector3(pj->limits->lower,0,0)); - dof6->setLinearUpperLimit(btVector3(pj->limits->upper,0,0)); - break; - } - case 1: - { - dof6->setLinearLowerLimit(btVector3(0,pj->limits->lower,0)); - dof6->setLinearUpperLimit(btVector3(0,pj->limits->upper,0)); - break; - } - case 2: - default: - { - dof6->setLinearLowerLimit(btVector3(0,0,pj->limits->lower)); - dof6->setLinearUpperLimit(btVector3(0,0,pj->limits->upper)); - } - }; - - dof6->setAngularLowerLimit(btVector3(0,0,0)); - dof6->setAngularUpperLimit(btVector3(0,0,0)); - if (enableConstraints) - world1->addConstraint(dof6,true); - - printf("Prismatic\n"); - } - break; - } - default: - { - printf("Error: unsupported joint type in URDF (%d)\n", pj->type); - } - } - - } - - if (mappings.m_createMultiBody) - { - if (compoundShape->getNumChildShapes()>0) - { - btMultiBodyLinkCollider* col= new btMultiBodyLinkCollider(mappings.m_bulletMultiBody, linkIndex-1); - - //btCompoundShape* comp = new btCompoundShape(); - //comp->addChildShape(linkInfo->m_localVisualFrame,shape); - - compoundShape->setUserIndex(graphicsIndex); - - col->setCollisionShape(compoundShape); - - btTransform tr; - tr.setIdentity(); - tr = linkTransformInWorldSpace; - //if we don't set the initial pose of the btCollisionObject, the simulator will do this - //when syncing the btMultiBody link transforms to the btMultiBodyLinkCollider - - //tr.setOrigin(local_origin[0]); - //tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - - bool isDynamic = true; - short collisionFilterGroup = isDynamic? short(btBroadphaseProxy::DefaultFilter) : short(btBroadphaseProxy::StaticFilter); - short collisionFilterMask = isDynamic? short(btBroadphaseProxy::AllFilter) : short(btBroadphaseProxy::AllFilter ^ btBroadphaseProxy::StaticFilter); - - world1->addCollisionObject(col,collisionFilterGroup,collisionFilterMask); - - btVector3 color = selectColor();//(0.0,0.0,0.5); - - gfxBridge.createCollisionObjectGraphicsObject(col,color); - btScalar friction = 0.5f; - - col->setFriction(friction); - - if (parentIndex>=0) - { - mappings.m_bulletMultiBody->getLink(linkIndex-1).m_collider=col; - } else - { - mappings.m_bulletMultiBody->setBaseCollider(col); - } - } - } - - //mappings.m_linkLocalDiagonalInertiaTensors.push_back(localInertiaDiagonal); - //mappings.m_linkLocalInertiaTransforms.push_back(localInertialTransform); - } - - - } - } - - mappings.m_linkMasses.push_back(mass); - - for (std::vector >::const_iterator child = link->child_links.begin(); child != link->child_links.end(); child++) - { - if (*child) - { - URDFvisual2BulletCollisionShape(*child,gfxBridge, linkTransformInWorldSpace, world1,mappings,pathPrefix); - - } - else - { - std::cout << "root link: " << link->name << " has a null child!" << *child << std::endl; - } - } - - - - -} - - -void ImportUrdfSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - - int upAxis = 2; - gfxBridge.setUpAxis(2); - - this->createEmptyDynamicsWorld(); - //m_dynamicsWorld->getSolverInfo().m_numIterations = 100; - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode( - btIDebugDraw::DBG_DrawConstraints - +btIDebugDraw::DBG_DrawContactPoints - +btIDebugDraw::DBG_DrawAabb - );//+btIDebugDraw::DBG_DrawConstraintLimits); - - - btVector3 gravity(0,0,0); - gravity[upAxis]=-9.8; - - m_dynamicsWorld->setGravity(gravity); - //int argc=0; - char relativeFileName[1024]; - - b3FileUtils fu; - printf("m_fileName=%s\n", m_fileName); - bool fileFound = fu.findFile(m_fileName, relativeFileName, 1024); - - - - std::string xml_string; - char pathPrefix[1024]; - pathPrefix[0] = 0; - - if (!fileFound){ - std::cerr << "URDF file not found, using a dummy test URDF" << std::endl; - xml_string = std::string(urdf_char); - - } else - { - - int maxPathLen = 1024; - fu.extractPath(relativeFileName,pathPrefix,maxPathLen); - - - std::fstream xml_file(relativeFileName, std::fstream::in); - while ( xml_file.good() ) - { - std::string line; - std::getline( xml_file, line); - xml_string += (line + "\n"); - } - xml_file.close(); - } - - my_shared_ptr robot = parseURDF(xml_string); - if (!robot){ - std::cerr << "ERROR: Model Parsing the xml failed" << std::endl; - return ; - } - std::cout << "robot name is: " << robot->getName() << std::endl; - - // get info from parser - std::cout << "---------- Successfully Parsed XML ---------------" << std::endl; - // get root link - my_shared_ptr root_link=robot->getRoot(); - if (!root_link) return ; - - std::cout << "root Link: " << root_link->name << " has " << root_link->child_links.size() << " child(ren)" << std::endl; - - // print entire tree - printTree(root_link); - printf("now using new interface\n"); - std::cout << "root Link: " << root_link->name << " has " << root_link->child_links.size() << " child(ren)" << std::endl; - - //now print the tree using the new interface - MyURDF2Bullet u2b(robot,gfxBridge); - printTree(u2b, 0,0); - - btTransform identityTrans; - identityTrans.setIdentity(); - - int numJoints = (*robot).m_numJoints; - - static bool useFeatherstone = true; - bool useUrdfInterfaceClass = true; - - { - URDF2BulletMappings mappings; - - btMultiBody* mb = 0; - - if (!useUrdfInterfaceClass) - { - mappings.m_createMultiBody = useFeatherstone; - mappings.m_totalNumJoints = numJoints; - mappings.m_urdfLinkIndices2BulletLinkIndices.resize(numJoints+1,-2);//root and child links (=1+numJoints) - URDFvisual2BulletCollisionShape(root_link, gfxBridge, identityTrans,m_dynamicsWorld,mappings,pathPrefix); - mb = mappings.m_bulletMultiBody; - if (useFeatherstone) - { - mb->setHasSelfCollision(false); - mb->finalizeMultiDof(); - m_dynamicsWorld->addMultiBody(mb); - } - } else - { - - - //todo: move these internal API called inside the 'ConvertURDF2Bullet' call, hidden from the user - int rootLinkIndex = u2b.getRootLinkIndex(); - printf("urdf root link index = %d\n",rootLinkIndex); - ConvertURDF2Bullet(u2b,identityTrans,m_dynamicsWorld,useFeatherstone,pathPrefix); - mb = u2b.getBulletMultiBody(); - - if (useFeatherstone) - { - mb->setHasSelfCollision(false); - mb->finalizeMultiDof(); - m_dynamicsWorld->addMultiBody(mb); - - - //create motors for each joint - - for (int i=0;igetNumLinks();i++) - { - int mbLinkIndex = i; - if (mb->getLink(mbLinkIndex).m_jointType==btMultibodyLink::eRevolute) - { - if (m_data->m_numMotorsm_motorTargetVelocities[m_data->m_numMotors]; - *motorVel = 0.f; - SliderParams slider(motorName,motorVel); - slider.m_minVal=-4; - slider.m_maxVal=4; - gfxBridge.getParameterInterface()->registerSliderFloatParameter(slider); - float maxMotorImpulse = 0.1f; - btMultiBodyJointMotor* motor = new btMultiBodyJointMotor(mb,mbLinkIndex,0,0,maxMotorImpulse); - m_data->m_jointMotors[m_data->m_numMotors]=motor; - m_dynamicsWorld->addMultiBodyConstraint(motor); - m_data->m_numMotors++; - } - } - - } - } - } - - } - - //the btMultiBody support is work-in-progress :-) - - //useFeatherstone = !useFeatherstone; - printf("numJoints/DOFS = %d\n", numJoints); - - bool createGround=true; - if (createGround) - { - btVector3 groundHalfExtents(20,20,20); - groundHalfExtents[upAxis]=1.f; - btBoxShape* box = new btBoxShape(groundHalfExtents); - box->initializePolyhedralFeatures(); - - gfxBridge.createCollisionShapeGraphicsObject(box); - btTransform start; start.setIdentity(); - btVector3 groundOrigin(0,0,0); - groundOrigin[upAxis]=-2;//.5; - start.setOrigin(groundOrigin); - btRigidBody* body = createRigidBody(0,start,box); - //m_dynamicsWorld->removeRigidBody(body); - // m_dynamicsWorld->addRigidBody(body,2,1); - btVector3 color(0.5,0.5,0.5); - gfxBridge.createRigidBodyGraphicsObject(body,color); - } - - ///this extra stepSimulation call makes sure that all the btMultibody transforms are properly propagates. - m_dynamicsWorld->stepSimulation(1. / 240., 0);// 1., 10, 1. / 240.); -} - -void ImportUrdfSetup::stepSimulation(float deltaTime) -{ - if (m_dynamicsWorld) - { - for (int i=0;im_numMotors;i++) - { - m_data->m_jointMotors[i]->setVelocityTarget(m_data->m_motorTargetVelocities[i]); - } - - //the maximal coordinates/iterative MLCP solver requires a smallish timestep to converge - m_dynamicsWorld->stepSimulation(deltaTime,10,1./240.); - } -} diff --git a/Demos3/ImportURDFDemo/ImportURDFSetup.h b/Demos3/ImportURDFDemo/ImportURDFSetup.h deleted file mode 100644 index 093079bbb..000000000 --- a/Demos3/ImportURDFDemo/ImportURDFSetup.h +++ /dev/null @@ -1,23 +0,0 @@ -#ifndef IMPORT_URDF_SETUP_H -#define IMPORT_URDF_SETUP_H - - -#include "Bullet3AppSupport/CommonMultiBodySetup.h" - -class ImportUrdfSetup : public CommonMultiBodySetup -{ - char m_fileName[1024]; - - struct ImportUrdfInternalData* m_data; - -public: - ImportUrdfSetup(); - virtual ~ImportUrdfSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - virtual void stepSimulation(float deltaTime); - - void setFileName(const char* urdfFileName); -}; - -#endif //IMPORT_URDF_SETUP_H diff --git a/Demos3/ImportURDFDemo/URDF2Bullet.cpp b/Demos3/ImportURDFDemo/URDF2Bullet.cpp deleted file mode 100644 index 510fe9915..000000000 --- a/Demos3/ImportURDFDemo/URDF2Bullet.cpp +++ /dev/null @@ -1,507 +0,0 @@ -#include "URDF2Bullet.h" -#include -#include "LinearMath/btTransform.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletCollision/CollisionShapes/btCompoundShape.h" -#include "BulletDynamics/Dynamics/btRigidBody.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h" - -static int bodyCollisionFilterGroup=btBroadphaseProxy::CharacterFilter; -static int bodyCollisionFilterMask=btBroadphaseProxy::AllFilter&(~btBroadphaseProxy::CharacterFilter); -static bool enableConstraints = true; - -static btVector4 colors[4] = -{ - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), -}; - - -static btVector3 selectColor2() -{ - - static int curColor = 0; - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - return color; -} - -void printTree(const URDF2Bullet& u2b, int linkIndex, int indentationLevel) -{ - btAlignedObjectArray childIndices; - u2b.getLinkChildIndices(linkIndex,childIndices); - - int numChildren = childIndices.size(); - - indentationLevel+=2; - int count = 0; - for (int i=0;i m_urdfLinkParentIndices; - btAlignedObjectArray m_urdfLinkIndices2BulletLinkIndices; - btAlignedObjectArray m_urdfLink2rigidBodies; - btAlignedObjectArray m_urdfLinkLocalInertialFrames; - - int m_currentMultiBodyLinkIndex; - - class btMultiBody* m_bulletMultiBody; - - //this will be initialized in the constructor - int m_totalNumJoints1; - int getParentUrdfIndex(int linkIndex) const - { - return m_urdfLinkParentIndices[linkIndex]; - } - int getMbIndexFromUrdfIndex(int urdfIndex) const - { - if (urdfIndex==-2) - return -2; - return m_urdfLinkIndices2BulletLinkIndices[urdfIndex]; - } - - - void registerMultiBody( int urdfLinkIndex, class btMultiBody* body, const btTransform& worldTransform, btScalar mass, const btVector3& localInertiaDiagonal, const class btCompoundShape* compound, const btTransform& localInertialFrame) - { - m_urdfLinkLocalInertialFrames[urdfLinkIndex] = localInertialFrame; - } - - class btRigidBody* getRigidBodyFromLink(int urdfLinkIndex) - { - return m_urdfLink2rigidBodies[urdfLinkIndex]; - } - - void registerRigidBody( int urdfLinkIndex, class btRigidBody* body, const btTransform& worldTransform, btScalar mass, const btVector3& localInertiaDiagonal, const class btCompoundShape* compound, const btTransform& localInertialFrame) - { - btAssert(m_urdfLink2rigidBodies[urdfLinkIndex]==0); - - m_urdfLink2rigidBodies[urdfLinkIndex] = body; - m_urdfLinkLocalInertialFrames[urdfLinkIndex] = localInertialFrame; - } - -}; - -void ComputeTotalNumberOfJoints(const URDF2Bullet& u2b, URDF2BulletCachedData& cache, int linkIndex) -{ - btAlignedObjectArray childIndices; - u2b.getLinkChildIndices(linkIndex,childIndices); - printf("link %s has %d children\n", u2b.getLinkName(linkIndex).c_str(),childIndices.size()); - for (int i=0;i childIndices; - u2b.getLinkChildIndices(urdfLinkIndex,childIndices); - for (int i=0;i=0) - { - ComputeTotalNumberOfJoints(u2b,cache,rootLinkIndex); - int numTotalLinksIncludingBase = 1+cache.m_totalNumJoints1; - - cache.m_urdfLinkParentIndices.resize(numTotalLinksIncludingBase); - cache.m_urdfLinkIndices2BulletLinkIndices.resize(numTotalLinksIncludingBase); - cache.m_urdfLink2rigidBodies.resize(numTotalLinksIncludingBase); - cache.m_urdfLinkLocalInertialFrames.resize(numTotalLinksIncludingBase); - - cache.m_currentMultiBodyLinkIndex = -1;//multi body base has 'link' index -1 - ComputeParentIndices(u2b,cache,rootLinkIndex,-2); - } - -} - -void ConvertURDF2BulletInternal(const URDF2Bullet& u2b, URDF2BulletCachedData& cache, int urdfLinkIndex, const btTransform& parentTransformInWorldSpace, btMultiBodyDynamicsWorld* world1,bool createMultiBody, const char* pathPrefix) -{ - printf("start converting/extracting data from URDF interface\n"); - - btTransform linkTransformInWorldSpace; - linkTransformInWorldSpace.setIdentity(); - - - int mbLinkIndex =cache.getMbIndexFromUrdfIndex(urdfLinkIndex); - - int urdfParentIndex = cache.getParentUrdfIndex(urdfLinkIndex); - int mbParentIndex = cache.getMbIndexFromUrdfIndex(urdfParentIndex); - btRigidBody* parentRigidBody = 0; - - std::string name = u2b.getLinkName(urdfLinkIndex); - printf("link name=%s urdf link index=%d\n",name.c_str(),urdfLinkIndex); - printf("mb link index = %d\n",mbLinkIndex); - - btTransform parentLocalInertialFrame; - parentLocalInertialFrame.setIdentity(); - btScalar parentMass(1); - btVector3 parentLocalInertiaDiagonal(1,1,1); - - if (urdfParentIndex==-2) - { - printf("root link has no parent\n"); - } else - { - printf("urdf parent index = %d\n",urdfParentIndex); - printf("mb parent index = %d\n",mbParentIndex); - parentRigidBody = cache.getRigidBodyFromLink(urdfParentIndex); - u2b.getMassAndInertia(urdfParentIndex, parentMass,parentLocalInertiaDiagonal,parentLocalInertialFrame); - - } - - btScalar mass = 0; - btTransform localInertialFrame; - localInertialFrame.setIdentity(); - btVector3 localInertiaDiagonal(0,0,0); - u2b.getMassAndInertia(urdfLinkIndex, mass,localInertiaDiagonal,localInertialFrame); - - - - - - btTransform parent2joint; - parent2joint.setIdentity(); - - int jointType; - btVector3 jointAxisInJointSpace; - btScalar jointLowerLimit; - btScalar jointUpperLimit; - - - bool hasParentJoint = u2b.getJointInfo(urdfLinkIndex, parent2joint, jointAxisInJointSpace, jointType,jointLowerLimit,jointUpperLimit); - - - linkTransformInWorldSpace =parentTransformInWorldSpace*parent2joint; - - int graphicsIndex = u2b.convertLinkVisualShapes(urdfLinkIndex,pathPrefix,localInertialFrame); - - btCompoundShape* compoundShape = u2b.convertLinkCollisionShapes(urdfLinkIndex,pathPrefix,localInertialFrame); - - if (compoundShape) - { - - - btVector3 color = selectColor2(); - /* - if (visual->material.get()) - { - color.setValue(visual->material->color.r,visual->material->color.g,visual->material->color.b);//,visual->material->color.a); - } - */ - //btVector3 localInertiaDiagonal(0, 0, 0); - //if (mass) - //{ - // shape->calculateLocalInertia(mass, localInertiaDiagonal); - //} - - btRigidBody* linkRigidBody = 0; - btTransform inertialFrameInWorldSpace = linkTransformInWorldSpace*localInertialFrame; - - if (!createMultiBody) - { - btRigidBody* body = u2b.allocateRigidBody(urdfLinkIndex, mass, localInertiaDiagonal, inertialFrameInWorldSpace, compoundShape); - linkRigidBody = body; - - world1->addRigidBody(body, bodyCollisionFilterGroup, bodyCollisionFilterMask); - - compoundShape->setUserIndex(graphicsIndex); - - u2b.createRigidBodyGraphicsInstance(urdfLinkIndex, body, color, graphicsIndex); - cache.registerRigidBody(urdfLinkIndex, body, inertialFrameInWorldSpace, mass, localInertiaDiagonal, compoundShape, localInertialFrame); - } else - { - if (cache.m_bulletMultiBody==0) - { - bool multiDof = true; - bool canSleep = false; - bool isFixedBase = (mass==0);//todo: figure out when base is fixed - int totalNumJoints = cache.m_totalNumJoints1; - cache.m_bulletMultiBody = u2b.allocateMultiBody(urdfLinkIndex, totalNumJoints,mass, localInertiaDiagonal, isFixedBase, canSleep, multiDof); - - cache.registerMultiBody(urdfLinkIndex, cache.m_bulletMultiBody, inertialFrameInWorldSpace, mass, localInertiaDiagonal, compoundShape, localInertialFrame); - } - - } - - //create a joint if necessary - if (hasParentJoint) { - - btTransform offsetInA,offsetInB; - offsetInA = parentLocalInertialFrame.inverse()*parent2joint; - offsetInB = localInertialFrame.inverse(); - - bool disableParentCollision = true; - switch (jointType) - { - case URDF2Bullet::FixedJoint: - { - if (createMultiBody) - { - //todo: adjust the center of mass transform and pivot axis properly - - printf("Fixed joint (btMultiBody)\n"); - btQuaternion rot = offsetInA.inverse().getRotation();//parent2joint.inverse().getRotation(); - cache.m_bulletMultiBody->setupFixed(mbLinkIndex, mass, localInertiaDiagonal, mbParentIndex, - rot*offsetInB.getRotation(), offsetInA.getOrigin(),-offsetInB.getOrigin(),disableParentCollision); - u2b.addLinkMapping(urdfLinkIndex,mbLinkIndex); - - btMatrix3x3 rm(rot); - btScalar y,p,r; - rm.getEulerZYX(y,p,r); - printf("y=%f,p=%f,r=%f\n", y,p,r); - - } else - { - printf("Fixed joint\n"); - - btMatrix3x3 rm(offsetInA.getBasis()); - btScalar y,p,r; - rm.getEulerZYX(y,p,r); - printf("y=%f,p=%f,r=%f\n", y,p,r); - - //we could also use btFixedConstraint but it has some issues - btGeneric6DofSpring2Constraint* dof6 = u2b.allocateGeneric6DofSpring2Constraint(urdfLinkIndex, *parentRigidBody, *linkRigidBody, offsetInA, offsetInB); - - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularLowerLimit(btVector3(0,0,0)); - dof6->setAngularUpperLimit(btVector3(0,0,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - } - break; - } - case URDF2Bullet::ContinuousJoint: - case URDF2Bullet::RevoluteJoint: - { - if (createMultiBody) - { - - - cache.m_bulletMultiBody->setupRevolute(mbLinkIndex, mass, localInertiaDiagonal, mbParentIndex, - offsetInA.inverse().getRotation()*offsetInB.getRotation(), quatRotate(offsetInB.inverse().getRotation(),jointAxisInJointSpace), offsetInA.getOrigin(),//parent2joint.getOrigin(), - -offsetInB.getOrigin(), - disableParentCollision); - u2b.addLinkMapping(urdfLinkIndex,mbLinkIndex); - - } else - { - //only handle principle axis at the moment, - //@todo(erwincoumans) orient the constraint for non-principal axis - int principleAxis = jointAxisInJointSpace.closestAxis(); - switch (principleAxis) - { - case 0: - { - btGeneric6DofSpring2Constraint* dof6 = u2b.allocateGeneric6DofSpring2Constraint(urdfLinkIndex,*parentRigidBody, *linkRigidBody, offsetInA, offsetInB,RO_ZYX); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularUpperLimit(btVector3(-1,0,0)); - dof6->setAngularLowerLimit(btVector3(1,0,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - break; - } - case 1: - { - btGeneric6DofSpring2Constraint* dof6 = u2b.allocateGeneric6DofSpring2Constraint(urdfLinkIndex,*parentRigidBody, *linkRigidBody, offsetInA, offsetInB,RO_XZY); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularUpperLimit(btVector3(0,-1,0)); - dof6->setAngularLowerLimit(btVector3(0,1,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - break; - } - case 2: - default: - { - btGeneric6DofSpring2Constraint* dof6 = u2b.allocateGeneric6DofSpring2Constraint(urdfLinkIndex,*parentRigidBody, *linkRigidBody, offsetInA, offsetInB,RO_XYZ); - dof6->setLinearLowerLimit(btVector3(0,0,0)); - dof6->setLinearUpperLimit(btVector3(0,0,0)); - - dof6->setAngularUpperLimit(btVector3(0,0,-1)); - dof6->setAngularLowerLimit(btVector3(0,0,0)); - - if (enableConstraints) - world1->addConstraint(dof6,true); - } - }; - printf("Revolute/Continuous joint\n"); - } - break; - } - case URDF2Bullet::PrismaticJoint: - { - if (createMultiBody) - { - - cache.m_bulletMultiBody->setupPrismatic(mbLinkIndex, mass, localInertiaDiagonal, mbParentIndex, - offsetInA.inverse().getRotation()*offsetInB.getRotation(), quatRotate(offsetInB.inverse().getRotation(),jointAxisInJointSpace), offsetInA.getOrigin(),//parent2joint.getOrigin(), - -offsetInB.getOrigin(), - disableParentCollision); - - u2b.addLinkMapping(urdfLinkIndex,mbLinkIndex); - - } else - { - btGeneric6DofSpring2Constraint* dof6 = u2b.allocateGeneric6DofSpring2Constraint(urdfLinkIndex,*parentRigidBody, *linkRigidBody, offsetInA, offsetInB); - //todo(erwincoumans) for now, we only support principle axis along X, Y or Z - int principleAxis = jointAxisInJointSpace.closestAxis(); - switch (principleAxis) - { - case 0: - { - dof6->setLinearLowerLimit(btVector3(jointLowerLimit,0,0)); - dof6->setLinearUpperLimit(btVector3(jointUpperLimit,0,0)); - break; - } - case 1: - { - dof6->setLinearLowerLimit(btVector3(0,jointLowerLimit,0)); - dof6->setLinearUpperLimit(btVector3(0,jointUpperLimit,0)); - break; - } - case 2: - default: - { - dof6->setLinearLowerLimit(btVector3(0,0,jointLowerLimit)); - dof6->setLinearUpperLimit(btVector3(0,0,jointUpperLimit)); - } - }; - - dof6->setAngularLowerLimit(btVector3(0,0,0)); - dof6->setAngularUpperLimit(btVector3(0,0,0)); - if (enableConstraints) - world1->addConstraint(dof6,true); - - printf("Prismatic\n"); - } - break; - } - default: - { - printf("Error: unsupported joint type in URDF (%d)\n", jointType); - btAssert(0); - } - } - - } - - if (createMultiBody) - { - if (compoundShape->getNumChildShapes()>0) - { - btMultiBodyLinkCollider* col= u2b.allocateMultiBodyLinkCollider(urdfLinkIndex, mbLinkIndex, cache.m_bulletMultiBody); - - compoundShape->setUserIndex(graphicsIndex); - - col->setCollisionShape(compoundShape); - - btTransform tr; - tr.setIdentity(); - tr = linkTransformInWorldSpace; - //if we don't set the initial pose of the btCollisionObject, the simulator will do this - //when syncing the btMultiBody link transforms to the btMultiBodyLinkCollider - - col->setWorldTransform(tr); - - bool isDynamic = true; - short collisionFilterGroup = isDynamic? short(btBroadphaseProxy::DefaultFilter) : short(btBroadphaseProxy::StaticFilter); - short collisionFilterMask = isDynamic? short(btBroadphaseProxy::AllFilter) : short(btBroadphaseProxy::AllFilter ^ btBroadphaseProxy::StaticFilter); - - world1->addCollisionObject(col,collisionFilterGroup,collisionFilterMask); - - btVector3 color = selectColor2();//(0.0,0.0,0.5); - - u2b.createCollisionObjectGraphicsInstance(urdfLinkIndex,col,color); - - btScalar friction = 0.5f; - - col->setFriction(friction); - - if (mbLinkIndex>=0) //???? double-check +/- 1 - { - cache.m_bulletMultiBody->getLink(mbLinkIndex).m_collider=col; - } else - { - cache.m_bulletMultiBody->setBaseCollider(col); - } - } - } - } - - - btAlignedObjectArray urdfChildIndices; - u2b.getLinkChildIndices(urdfLinkIndex,urdfChildIndices); - - int numChildren = urdfChildIndices.size(); - - for (int i=0;i -class btVector3; -class btTransform; -class btMultiBodyDynamicsWorld; -class btTransform; - -class URDF2Bullet -{ - -public: - - enum { - RevoluteJoint=1, - PrismaticJoint, - ContinuousJoint, - FloatingJoint, - PlanarJoint, - FixedJoint, - }; - - ///return >=0 for the root link index, -1 if there is no root link - virtual int getRootLinkIndex() const = 0; - - ///pure virtual interfaces, precondition is a valid linkIndex (you can assert/terminate if the linkIndex is out of range) - virtual std::string getLinkName(int linkIndex) const =0; - - virtual std::string getJointName(int linkIndex) const = 0; - - //fill mass and inertial data. If inertial data is missing, please initialize mass, inertia to sensitive values, and inertialFrame to identity. - virtual void getMassAndInertia(int urdfLinkIndex, btScalar& mass,btVector3& localInertiaDiagonal, btTransform& inertialFrame) const =0; - - ///fill an array of child link indices for this link, btAlignedObjectArray behaves like a std::vector so just use push_back and resize(0) if needed - virtual void getLinkChildIndices(int urdfLinkIndex, btAlignedObjectArray& childLinkIndices) const =0; - - virtual bool getJointInfo(int urdfLinkIndex, btTransform& parent2joint, btVector3& jointAxisInJointSpace, int& jointType, btScalar& jointLowerLimit, btScalar& jointUpperLimit) const =0; - - virtual int convertLinkVisualShapes(int linkIndex, const char* pathPrefix, const btTransform& localInertialFrame) const=0; - - ///create Bullet collision shapes from URDF 'Collision' objects, specified in inertial frame of the link. - virtual class btCompoundShape* convertLinkCollisionShapes(int linkIndex, const char* pathPrefix, const btTransform& localInertiaFrame) const = 0; - - virtual void createRigidBodyGraphicsInstance(int linkIndex, class btRigidBody* body, const btVector3& colorRgba, int graphicsIndex) const = 0; - - ///optionally create some graphical representation from a collision object, usually for visual debugging purposes. - virtual void createCollisionObjectGraphicsInstance(int linkIndex, class btCollisionObject* col, const btVector3& colorRgba) const = 0; - - virtual class btMultiBody* allocateMultiBody(int urdfLinkIndex, int totalNumJoints,btScalar mass, const btVector3& localInertiaDiagonal, bool isFixedBase, bool canSleep, bool multiDof) const =0; - - virtual class btRigidBody* allocateRigidBody(int urdfLinkIndex, btScalar mass, const btVector3& localInertiaDiagonal, const btTransform& initialWorldTrans, class btCollisionShape* colShape) const = 0; - - virtual class btGeneric6DofSpring2Constraint* allocateGeneric6DofSpring2Constraint(int urdfLinkIndex, btRigidBody& rbA /*parent*/, btRigidBody& rbB, const btTransform& offsetInA, const btTransform& offsetInB, int rotateOrder=0) const = 0; - - virtual class btMultiBodyLinkCollider* allocateMultiBodyLinkCollider(int urdfLinkIndex, int mbLinkIndex, btMultiBody* body) const = 0; - - virtual void addLinkMapping(int urdfLinkIndex, int mbLinkIndex) const = 0; -}; - - -void printTree(const URDF2Bullet& u2b, int linkIndex, int identationLevel=0); - - - -void ConvertURDF2Bullet(const URDF2Bullet& u2b, const btTransform& rootTransformInWorldSpace, btMultiBodyDynamicsWorld* world,bool createMultiBody, const char* pathPrefix); - - -#endif //_URDF2BULLET_H - diff --git a/Demos3/ImportURDFDemo/urdf_samples.h b/Demos3/ImportURDFDemo/urdf_samples.h deleted file mode 100644 index 24d4d2c0c..000000000 --- a/Demos3/ImportURDFDemo/urdf_samples.h +++ /dev/null @@ -1,825 +0,0 @@ -#ifndef URDF_SAMPLES_H -#define URDF_SAMPLES_H - -#define MSTRINGIFY(A) #A - - -const char* urdf_char2 = MSTRINGIFY( - - - - - - - - - - - - - - - - - - - - - ); - -const char* urdf_char1 = MSTRINGIFY( - - - - - - - - - - - ); - -const char* urdf_char3 = MSTRINGIFY( - - - - - - - - - - - - - - - - - - - - - - - ); - -const char* urdf_char4 = MSTRINGIFY( - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -); - -const char* urdf_char_r2d2 = MSTRINGIFY( - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -); - -const char* urdf_char = MSTRINGIFY( - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -); - -#endif //URDF_SAMPLES_H - diff --git a/Demos3/SimpleOpenGL3/CMakeLists.txt b/Demos3/SimpleOpenGL3/CMakeLists.txt deleted file mode 100644 index 7931eee85..000000000 --- a/Demos3/SimpleOpenGL3/CMakeLists.txt +++ /dev/null @@ -1,52 +0,0 @@ - - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ${BULLET_PHYSICS_SOURCE_DIR}/btgui -) - - -SET(AppSimpleOpenGL3_SRCS - main.cpp - ${BULLET_PHYSICS_SOURCE_DIR}/build3/bullet.rc -) - -LINK_LIBRARIES( - gwen OpenGLWindow Bullet3Common ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY} -) - -IF (WIN32) - SET(AppSimpleOpenGL3_SRCS ${AppSimpleOpenGL3_SRCS} ${AppSimpleOpenGL3_Common_SRCS}) - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/OpenGLWindow/GlewWindows - ) - ADD_DEFINITIONS(-DGLEW_STATIC) -ELSE(WIN32) - IF(APPLE) - find_library(COCOA NAMES Cocoa) - MESSAGE(${COCOA}) - link_libraries(${COCOA}) - ELSE(APPLE) - - INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/btgui/OpenGLWindow/GlewWindows - ) - ADD_DEFINITIONS("-DGLEW_INIT_OPENGL11_FUNCTIONS=1") - ADD_DEFINITIONS("-DGLEW_STATIC") - ADD_DEFINITIONS("-DGLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS=1") - - LINK_LIBRARIES( X11 pthread dl Xext) - ENDIF(APPLE) -ENDIF(WIN32) - - -ADD_EXECUTABLE(AppSimpleOpenGL3 - ${AppSimpleOpenGL3_SRCS} -) - - -IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) - SET_TARGET_PROPERTIES(AppSimpleOpenGL3 PROPERTIES DEBUG_POSTFIX "_Debug") - SET_TARGET_PROPERTIES(AppSimpleOpenGL3 PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel") - SET_TARGET_PROPERTIES(AppSimpleOpenGL3 PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo") -ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES) diff --git a/Demos3/SimpleOpenGL3/main.cpp b/Demos3/SimpleOpenGL3/main.cpp deleted file mode 100644 index 3003a0978..000000000 --- a/Demos3/SimpleOpenGL3/main.cpp +++ /dev/null @@ -1,57 +0,0 @@ -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "Bullet3Common/b3Vector3.h" -#include "Bullet3Common/b3CommandLineArgs.h" -#include "assert.h" -#include -#include "OpenGLWindow/OpenGLInclude.h" - -char* gVideoFileName = 0; -char* gPngFileName = 0; - -int main(int argc, char* argv[]) -{ - b3CommandLineArgs myArgs(argc,argv); - - - SimpleOpenGL3App* app = new SimpleOpenGL3App("SimpleOpenGL3App",1024,768); - app->m_instancingRenderer->setCameraDistance(13); - app->m_instancingRenderer->setCameraPitch(0); - app->m_instancingRenderer->setCameraTargetPosition(b3MakeVector3(0,0,0)); - - assert(glGetError()==GL_NO_ERROR); - - myArgs.GetCmdLineArgument("mp4_file",gVideoFileName); - if (gVideoFileName) - app->dumpFramesToVideo(gVideoFileName); - - myArgs.GetCmdLineArgument("png_file",gPngFileName); - char fileName[1024]; - - do - { - static int frameCount = 0; - frameCount++; - if (gPngFileName) - { - printf("gPngFileName=%s\n",gPngFileName); - - sprintf(fileName,"%s%d.png",gPngFileName,frameCount++); - app->dumpNextFrameToPng(fileName); - } - - assert(glGetError()==GL_NO_ERROR); - app->m_instancingRenderer->init(); - app->m_instancingRenderer->updateCamera(); - - app->drawGrid(); - char bla[1024]; - sprintf(bla,"Simple test frame %d", frameCount); - - app->drawText(bla,10,10); - app->swapBuffer(); - } while (!app->m_window->requestedExit()); - - - delete app; - return 0; -} diff --git a/Demos3/SimpleOpenGL3/premake4.lua b/Demos3/SimpleOpenGL3/premake4.lua deleted file mode 100644 index bc35d9a4e..000000000 --- a/Demos3/SimpleOpenGL3/premake4.lua +++ /dev/null @@ -1,28 +0,0 @@ - - project "App_SimpleOpenGL3" - - language "C++" - - kind "ConsoleApp" - - includedirs { - ".", - "../../src", - "../../btgui" - } - - - links{ "OpenGL_Window","Bullet3Common"} - initOpenGL() - initGlew() - - files { - "*.cpp", - "*.h", - } - -if os.is("Linux") then initX11() end - -if os.is("MacOSX") then - links{"Cocoa.framework"} -end diff --git a/Demos3/Wavefront/README.md b/Demos3/Wavefront/README.md deleted file mode 100644 index 6f911e523..000000000 --- a/Demos3/Wavefront/README.md +++ /dev/null @@ -1,88 +0,0 @@ -tinyobjloader -============= - -http://syoyo.github.io/tinyobjloader/ - -Tiny but poweful single file wavefront obj loader written in C++. No dependency except for C++ STL. It can parse 10M over polygons with moderate memory and time. - -Good for embedding .obj loader to your (global illumination) renderer ;-) - - -Example -------- - -![Rungholt](https://github.com/syoyo/tinyobjloader/blob/master/images/rungholt.jpg?raw=true) - -tinyobjloader can successfully load 6M triangles Rungholt scene. -http://graphics.cs.williams.edu/data/meshes.xml - -Features --------- - -* Group -* Vertex -* Texcoord -* Normal -* Material - * Unknown material attributes are treated as key-value. - -Notes ------ - -Polygon is converted into triangle. - -License -------- - -Licensed under 2 clause BSD. - -Usage ------ - - std::string inputfile = "cornell_box.obj"; - std::vector shapes; - - std::string err = tinyobj::LoadObj(shapes, inputfile.c_str()); - - if (!err.empty()) { - std::cerr << err << std::endl; - exit(1); - } - - std::cout << "# of shapes : " << shapes.size() << std::endl; - - for (size_t i = 0; i < shapes.size(); i++) { - printf("shape[%ld].name = %s\n", i, shapes[i].name.c_str()); - printf("shape[%ld].indices: %ld\n", i, shapes[i].mesh.indices.size()); - assert((shapes[i].mesh.indices.size() % 3) == 0); - for (size_t f = 0; f < shapes[i].mesh.indices.size(); f++) { - printf(" idx[%ld] = %d\n", f, shapes[i].mesh.indices[f]); - } - - printf("shape[%ld].vertices: %ld\n", i, shapes[i].mesh.positions.size()); - assert((shapes[i].mesh.positions.size() % 3) == 0); - for (size_t v = 0; v < shapes[i].mesh.positions.size() / 3; v++) { - printf(" v[%ld] = (%f, %f, %f)\n", v, - shapes[i].mesh.positions[3*v+0], - shapes[i].mesh.positions[3*v+1], - shapes[i].mesh.positions[3*v+2]); - } - - printf("shape[%ld].material.name = %s\n", i, shapes[i].material.name.c_str()); - printf(" material.Ka = (%f, %f ,%f)\n", shapes[i].material.ambient[0], shapes[i].material.ambient[1], shapes[i].material.ambient[2]); - printf(" material.Kd = (%f, %f ,%f)\n", shapes[i].material.diffuse[0], shapes[i].material.diffuse[1], shapes[i].material.diffuse[2]); - printf(" material.Ks = (%f, %f ,%f)\n", shapes[i].material.specular[0], shapes[i].material.specular[1], shapes[i].material.specular[2]); - printf(" material.Tr = (%f, %f ,%f)\n", shapes[i].material.transmittance[0], shapes[i].material.transmittance[1], shapes[i].material.transmittance[2]); - printf(" material.Ke = (%f, %f ,%f)\n", shapes[i].material.emission[0], shapes[i].material.emission[1], shapes[i].material.emission[2]); - printf(" material.Ns = %f\n", shapes[i].material.shininess); - printf(" material.map_Ka = %s\n", shapes[i].material.ambient_texname.c_str()); - printf(" material.map_Kd = %s\n", shapes[i].material.diffuse_texname.c_str()); - printf(" material.map_Ks = %s\n", shapes[i].material.specular_texname.c_str()); - printf(" material.map_Ns = %s\n", shapes[i].material.normal_texname.c_str()); - std::map::iterator it(shapes[i].material.unknown_parameter.begin()); - std::map::iterator itEnd(shapes[i].material.unknown_parameter.end()); - for (; it != itEnd; it++) { - printf(" material.%s = %s\n", it->first.c_str(), it->second.c_str()); - } - printf("\n"); - } diff --git a/Demos3/Wavefront/main.cpp b/Demos3/Wavefront/main.cpp deleted file mode 100644 index acfb27eb3..000000000 --- a/Demos3/Wavefront/main.cpp +++ /dev/null @@ -1,107 +0,0 @@ -#include "tiny_obj_loader.h" - -#include -#include -#include -#include - -static bool - TestLoadObj( - const char* fileName, - bool verbose - ) -{ - - - const char* prefix[]={"./data/","../data/","../../data/","../../../data/","../../../../data/"}; - char fullPath[1024]; - int index=-1; - { - - int numPrefixes = sizeof(prefix)/sizeof(char*); - - for (int i=0;i shapes; - std::string err = tinyobj::LoadObj(shapes, fullPath, prefix[index]); - - if (!err.empty()) { - std::cerr << err << std::endl; - return false; - } - - std::cout << "# of shapes : " << shapes.size() << std::endl; - - if (verbose) - { - for (size_t i = 0; i < shapes.size(); i++) { - printf("shape[%ld].name = %s\n", i, shapes[i].name.c_str()); - printf("shape[%ld].indices: %ld\n", i, shapes[i].mesh.indices.size()); - assert((shapes[i].mesh.indices.size() % 3) == 0); - for (size_t f = 0; f < shapes[i].mesh.indices.size(); f++) { - printf(" idx[%ld] = %d\n", f, shapes[i].mesh.indices[f]); - } - - printf("shape[%ld].vertices: %ld\n", i, shapes[i].mesh.positions.size()); - assert((shapes[i].mesh.positions.size() % 3) == 0); - for (size_t v = 0; v < shapes[i].mesh.positions.size() / 3; v++) { - printf(" v[%ld] = (%f, %f, %f)\n", v, - shapes[i].mesh.positions[3*v+0], - shapes[i].mesh.positions[3*v+1], - shapes[i].mesh.positions[3*v+2]); - } - - printf("shape[%ld].material.name = %s\n", i, shapes[i].material.name.c_str()); - printf(" material.Ka = (%f, %f ,%f)\n", shapes[i].material.ambient[0], shapes[i].material.ambient[1], shapes[i].material.ambient[2]); - printf(" material.Kd = (%f, %f ,%f)\n", shapes[i].material.diffuse[0], shapes[i].material.diffuse[1], shapes[i].material.diffuse[2]); - printf(" material.Ks = (%f, %f ,%f)\n", shapes[i].material.specular[0], shapes[i].material.specular[1], shapes[i].material.specular[2]); - printf(" material.Tr = (%f, %f ,%f)\n", shapes[i].material.transmittance[0], shapes[i].material.transmittance[1], shapes[i].material.transmittance[2]); - printf(" material.Ke = (%f, %f ,%f)\n", shapes[i].material.emission[0], shapes[i].material.emission[1], shapes[i].material.emission[2]); - printf(" material.Ns = %f\n", shapes[i].material.shininess); - printf(" material.map_Ka = %s\n", shapes[i].material.ambient_texname.c_str()); - printf(" material.map_Kd = %s\n", shapes[i].material.diffuse_texname.c_str()); - printf(" material.map_Ks = %s\n", shapes[i].material.specular_texname.c_str()); - printf(" material.map_Ns = %s\n", shapes[i].material.normal_texname.c_str()); - std::map::iterator it(shapes[i].material.unknown_parameter.begin()); - std::map::iterator itEnd(shapes[i].material.unknown_parameter.end()); - for (; it != itEnd; it++) { - printf(" material.%s = %s\n", it->first.c_str(), it->second.c_str()); - } - printf("\n"); - } - } - - return true; -} - - -int main( int argc, char **argv) -{ -// assert(true == TestLoadObj("cornell_box.obj",true)); -// assert(true == TestLoadObj("cube.obj",true)); - assert(true==TestLoadObj("samurai_monastry.obj",false)); - assert(true==TestLoadObj("teddy2_VHACD_CHs.obj",true)); - return 0; -} diff --git a/Demos3/Wavefront/premake4.lua b/Demos3/Wavefront/premake4.lua deleted file mode 100644 index e5cf97c34..000000000 --- a/Demos3/Wavefront/premake4.lua +++ /dev/null @@ -1,23 +0,0 @@ - - project "App_WavefrontObjLoader" - - kind "ConsoleApp" - --- defines { } - - targetdir "../../bin" - - includedirs - { - ".","../../src" - } - - - links { "Bullet3Common" } - - - files { - "**.cpp", - "**.h" - } - diff --git a/Demos3/Wavefront/tiny_obj_loader.cpp b/Demos3/Wavefront/tiny_obj_loader.cpp deleted file mode 100644 index c96010493..000000000 --- a/Demos3/Wavefront/tiny_obj_loader.cpp +++ /dev/null @@ -1,682 +0,0 @@ -// -// Copyright 2012-2013, Syoyo Fujita. -// -// Licensed under 2-clause BSD liecense. -// - -// Erwin Coumans: improved performance, especially in debug mode on Visual Studio (25sec -> 4sec) -// -// version 0.9.5: Parse multiple group name. -// Add support of specifying the base path to load material file. -// version 0.9.4: Initial suupport of group tag(g) -// version 0.9.3: Fix parsing triple 'x/y/z' -// version 0.9.2: Add more .mtl load support -// version 0.9.1: Add initial .mtl load support -// version 0.9.0: Initial -// - - -#include -#include -#include - -#include -#include -#include -#include -#include - -#include "tiny_obj_loader.h" - -namespace tinyobj { - -struct vertex_index { - int v_idx, vt_idx, vn_idx, dummy; -}; -struct MyIndices -{ - int m_offset; - int m_numIndices; -}; - - -// for std::map -static inline bool operator<(const vertex_index& a, const vertex_index& b) -{ - if (a.v_idx != b.v_idx) return (a.v_idx < b.v_idx); - if (a.vn_idx != b.vn_idx) return (a.vn_idx < b.vn_idx); - if (a.vt_idx != b.vt_idx) return (a.vt_idx < b.vt_idx); - - return false; -} - - -static inline bool isSpace(const char c) { - return (c == ' ') || (c == '\t'); -} - -static inline bool isNewLine(const char c) { - return (c == '\r') || (c == '\n') || (c == '\0'); -} - -// Make index zero-base, and also support relative index. -static inline int fixIndex(int idx, int n) -{ - int i; - - if (idx > 0) { - i = idx - 1; - } else if (idx == 0) { - i = 0; - } else { // negative value = relative - i = n + idx; - } - return i; -} - -static inline std::string parseString(const char*& token) -{ - std::string s; - int b = strspn(token, " \t"); - int e = strcspn(token, " \t\r"); - s = std::string(&token[b], &token[e]); - - token += (e - b); - return s; -} - -static inline float parseFloat(const char*& token) -{ - token += strspn(token, " \t"); - float f = (float)atof(token); - token += strcspn(token, " \t\r"); - return f; -} - -static inline void parseFloat2( - float& x, float& y, - const char*& token) -{ - x = parseFloat(token); - y = parseFloat(token); -} - -static inline void parseFloat3( - float& x, float& y, float& z, - const char*& token) -{ - x = parseFloat(token); - y = parseFloat(token); - z = parseFloat(token); -} - - -// Parse triples: i, i/j/k, i//k, i/j -static vertex_index parseTriple( - const char* &token, - int vsize, - int vnsize, - int vtsize) -{ - vertex_index vi; - vi.vn_idx = -1; - vi.vt_idx = -1; - vi.v_idx= -1; - - vi.v_idx = fixIndex(atoi(token), vsize); - token += strcspn(token, "/ \t\r"); - if (token[0] != '/') { - return vi; - } - token++; - - // i//k - if (token[0] == '/') { - token++; - vi.vn_idx = fixIndex(atoi(token), vnsize); - token += strcspn(token, "/ \t\r"); - return vi; - } - - // i/j/k or i/j - vi.vt_idx = fixIndex(atoi(token), vtsize); - token += strcspn(token, "/ \t\r"); - if (token[0] != '/') { - return vi; - } - - // i/j/k - token++; // skip '/' - vi.vn_idx = fixIndex(atoi(token), vnsize); - token += strcspn(token, "/ \t\r"); - return vi; -} - - -static unsigned int -updateVertex( - std::map& vertexCache, - std::vector& positions, - std::vector& normals, - std::vector& texcoords, - const std::vector& in_positions, - const std::vector& in_normals, - const std::vector& in_texcoords, - const vertex_index& i) -{ - const std::map::iterator it = vertexCache.find(i); - - if (it != vertexCache.end()) { - // found cache - return it->second; - } - - assert(in_positions.size() > (3*i.v_idx+2)); - - positions.push_back(in_positions[3*i.v_idx+0]); - positions.push_back(in_positions[3*i.v_idx+1]); - positions.push_back(in_positions[3*i.v_idx+2]); - - if (i.vn_idx >= 0) { - normals.push_back(in_normals[3*i.vn_idx+0]); - normals.push_back(in_normals[3*i.vn_idx+1]); - normals.push_back(in_normals[3*i.vn_idx+2]); - } - - if (i.vt_idx >= 0) { - texcoords.push_back(in_texcoords[2*i.vt_idx+0]); - texcoords.push_back(in_texcoords[2*i.vt_idx+1]); - } - - unsigned int idx = positions.size() / 3 - 1; - vertexCache[i] = idx; - - return idx; -} - - -static bool -exportFaceGroupToShape( - shape_t& shape, - const std::vector& in_positions, - const std::vector& in_normals, - const std::vector& in_texcoords, - const std::vector& faceGroup, - const material_t material, - const std::string name, - std::vector& allIndices - ) -{ - if (faceGroup.empty()) { - return false; - } - - // Flattened version of vertex data - std::vector positions; - std::vector normals; - std::vector texcoords; - std::map vertexCache; - std::vector indices; - - // Flatten vertices and indices - for (size_t i = 0; i < faceGroup.size(); i++) - { - - const MyIndices& face = faceGroup[i]; - - vertex_index i0 = allIndices[face.m_offset]; - vertex_index i1; - i1.vn_idx = -1; - i1.vt_idx = -1; - i1.v_idx= -1; - vertex_index i2 = allIndices[face.m_offset+1]; - - size_t npolys = face.m_numIndices;//.size(); - - - { - // Polygon -> triangle fan conversion - for (size_t k = 2; k < npolys; k++) - { - i1 = i2; - i2 = allIndices[face.m_offset+k]; - - unsigned int v0 = updateVertex(vertexCache, positions, normals, texcoords, in_positions, in_normals, in_texcoords, i0); - unsigned int v1 = updateVertex(vertexCache, positions, normals, texcoords, in_positions, in_normals, in_texcoords, i1); - unsigned int v2 = updateVertex(vertexCache, positions, normals, texcoords, in_positions, in_normals, in_texcoords, i2); - - indices.push_back(v0); - indices.push_back(v1); - indices.push_back(v2); - } - } - - } - - // - // Construct shape. - // - shape.name = name; - shape.mesh.positions.swap(positions); - shape.mesh.normals.swap(normals); - shape.mesh.texcoords.swap(texcoords); - shape.mesh.indices.swap(indices); - - shape.material = material; - - return true; - -} - - - -void InitMaterial(material_t& material) { - material.name = ""; - material.ambient_texname = ""; - material.diffuse_texname = ""; - material.specular_texname = ""; - material.normal_texname = ""; - for (int i = 0; i < 3; i ++) { - material.ambient[i] = 0.f; - material.diffuse[i] = 0.f; - material.specular[i] = 0.f; - material.transmittance[i] = 0.f; - material.emission[i] = 0.f; - } - material.shininess = 1.f; -} - -std::string LoadMtl ( - std::map& material_map, - const char* filename, - const char* mtl_basepath) -{ - material_map.clear(); - std::stringstream err; - - std::string filepath; - - if (mtl_basepath) { - filepath = std::string(mtl_basepath) + std::string(filename); - } else { - filepath = std::string(filename); - } - - std::ifstream ifs(filepath.c_str()); - if (!ifs) { - err << "Cannot open file [" << filepath << "]" << std::endl; - return err.str(); - } - - material_t material; - - int maxchars = 8192; // Alloc enough size. - std::vector buf(maxchars); // Alloc enough size. - while (ifs.peek() != -1) { - ifs.getline(&buf[0], maxchars); - - std::string linebuf(&buf[0]); - - // Trim newline '\r\n' or '\r' - if (linebuf.size() > 0) { - if (linebuf[linebuf.size()-1] == '\n') linebuf.erase(linebuf.size()-1); - } - if (linebuf.size() > 0) { - if (linebuf[linebuf.size()-1] == '\n') linebuf.erase(linebuf.size()-1); - } - - // Skip if empty line. - if (linebuf.empty()) { - continue; - } - - // Skip leading space. - const char* token = linebuf.c_str(); - token += strspn(token, " \t"); - - assert(token); - if (token[0] == '\0') continue; // empty line - - if (token[0] == '#') continue; // comment line - - // new mtl - if ((0 == strncmp(token, "newmtl", 6)) && isSpace((token[6]))) { - // flush previous material. - material_map.insert(std::pair(material.name, material)); - - // initial temporary material - InitMaterial(material); - - // set new mtl name - char namebuf[4096]; - token += 7; - sscanf(token, "%s", namebuf); - material.name = namebuf; - continue; - } - - // ambient - if (token[0] == 'K' && token[1] == 'a' && isSpace((token[2]))) { - token += 2; - float r, g, b; - parseFloat3(r, g, b, token); - material.ambient[0] = r; - material.ambient[1] = g; - material.ambient[2] = b; - continue; - } - - // diffuse - if (token[0] == 'K' && token[1] == 'd' && isSpace((token[2]))) { - token += 2; - float r, g, b; - parseFloat3(r, g, b, token); - material.diffuse[0] = r; - material.diffuse[1] = g; - material.diffuse[2] = b; - continue; - } - - // specular - if (token[0] == 'K' && token[1] == 's' && isSpace((token[2]))) { - token += 2; - float r, g, b; - parseFloat3(r, g, b, token); - material.specular[0] = r; - material.specular[1] = g; - material.specular[2] = b; - continue; - } - - // specular - if (token[0] == 'K' && token[1] == 't' && isSpace((token[2]))) { - token += 2; - float r, g, b; - parseFloat3(r, g, b, token); - material.specular[0] = r; - material.specular[1] = g; - material.specular[2] = b; - continue; - } - - // emission - if(token[0] == 'K' && token[1] == 'e' && isSpace(token[2])) { - token += 2; - float r, g, b; - parseFloat3(r, g, b, token); - material.emission[0] = r; - material.emission[1] = g; - material.emission[2] = b; - continue; - } - - // shininess - if(token[0] == 'N' && token[1] == 's' && isSpace(token[2])) { - token += 2; - material.shininess = parseFloat(token); - continue; - } - - // ambient texture - if ((0 == strncmp(token, "map_Ka", 6)) && isSpace(token[6])) { - token += 7; - material.ambient_texname = token; - continue; - } - - // diffuse texture - if ((0 == strncmp(token, "map_Kd", 6)) && isSpace(token[6])) { - token += 7; - material.diffuse_texname = token; - continue; - } - - // specular texture - if ((0 == strncmp(token, "map_Ks", 6)) && isSpace(token[6])) { - token += 7; - material.specular_texname = token; - continue; - } - - // normal texture - if ((0 == strncmp(token, "map_Ns", 6)) && isSpace(token[6])) { - token += 7; - material.normal_texname = token; - continue; - } - - // unknown parameter - const char* _space = strchr(token, ' '); - if(!_space) { - _space = strchr(token, '\t'); - } - if(_space) { - int len = _space - token; - std::string key(token, len); - std::string value = _space + 1; - material.unknown_parameter.insert(std::pair(key, value)); - } - } - // flush last material. - material_map.insert(std::pair(material.name, material)); - - return err.str(); -} - -std::string -LoadObj( - std::vector& shapes, - const char* filename, - const char* mtl_basepath) -{ - - shapes.resize(0); - std::vector allIndices; - allIndices.reserve(1024*1024); - - MyIndices face; - - std::stringstream err; - - std::ifstream ifs(filename); - if (!ifs) { - err << "Cannot open file [" << filename << "]" << std::endl; - return err.str(); - } - - std::vector v; - v.reserve(1024*1024); - std::vector vn; - vn.reserve(1024*1024); - std::vector vt; - vt.reserve(1024*1024); - //std::vector > faceGroup; - std::vector faceGroup; - faceGroup.reserve(1024*1024); - std::string name; - - // material - std::map material_map; - material_t material; - - int maxchars = 8192; // Alloc enough size. - std::vector buf(maxchars); // Alloc enough size. - while (ifs.peek() != -1) { - ifs.getline(&buf[0], maxchars); - - std::string linebuf(&buf[0]); - - // Trim newline '\r\n' or '\r' - if (linebuf.size() > 0) { - if (linebuf[linebuf.size()-1] == '\n') linebuf.erase(linebuf.size()-1); - } - if (linebuf.size() > 0) { - if (linebuf[linebuf.size()-1] == '\n') linebuf.erase(linebuf.size()-1); - } - - // Skip if empty line. - if (linebuf.empty()) { - continue; - } - - // Skip leading space. - const char* token = linebuf.c_str(); - token += strspn(token, " \t"); - - assert(token); - if (token[0] == '\0') continue; // empty line - - if (token[0] == '#') continue; // comment line - - // vertex - if (token[0] == 'v' && isSpace((token[1]))) { - token += 2; - float x, y, z; - parseFloat3(x, y, z, token); - v.push_back(x); - v.push_back(y); - v.push_back(z); - continue; - } - - // normal - if (token[0] == 'v' && token[1] == 'n' && isSpace((token[2]))) { - token += 3; - float x, y, z; - parseFloat3(x, y, z, token); - vn.push_back(x); - vn.push_back(y); - vn.push_back(z); - continue; - } - - // texcoord - if (token[0] == 'v' && token[1] == 't' && isSpace((token[2]))) { - token += 3; - float x, y; - parseFloat2(x, y, token); - vt.push_back(x); - vt.push_back(y); - continue; - } - - // face - if (token[0] == 'f' && isSpace((token[1]))) { - token += 2; - token += strspn(token, " \t"); - - face.m_offset = allIndices.size(); - face.m_numIndices = 0; - - while (!isNewLine(token[0])) { - vertex_index vi = parseTriple(token, v.size() / 3, vn.size() / 3, vt.size() / 2); - allIndices.push_back(vi); - face.m_numIndices++; - int n = strspn(token, " \t\r"); - token += n; - } - - faceGroup.push_back(face); - - continue; - } - - // use mtl - if ((0 == strncmp(token, "usemtl", 6)) && isSpace((token[6]))) { - - char namebuf[4096]; - token += 7; - sscanf(token, "%s", namebuf); - - if (material_map.find(namebuf) != material_map.end()) { - material = material_map[namebuf]; - } else { - // { error!! material not found } - InitMaterial(material); - } - continue; - - } - - // load mtl - if ((0 == strncmp(token, "mtllib", 6)) && isSpace((token[6]))) { - char namebuf[4096]; - token += 7; - sscanf(token, "%s", namebuf); - - std::string err_mtl = LoadMtl(material_map, namebuf, mtl_basepath); - if (!err_mtl.empty()) { - faceGroup.resize(0); // for safety - return err_mtl; - } - continue; - } - - // group name - if (token[0] == 'g' && isSpace((token[1]))) { - - // flush previous face group. - shape_t shape; - bool ret = exportFaceGroupToShape(shape, v, vn, vt, faceGroup, material, name,allIndices); - if (ret) { - shapes.push_back(shape); - } - - faceGroup.resize(0); - - std::vector names; - while (!isNewLine(token[0])) { - std::string str = parseString(token); - names.push_back(str); - token += strspn(token, " \t\r"); // skip tag - } - - assert(names.size() > 0); - - // names[0] must be 'g', so skipt 0th element. - if (names.size() > 1) { - name = names[1]; - } else { - name = ""; - } - - continue; - } - - // object name - if (token[0] == 'o' && isSpace((token[1]))) { - - // flush previous face group. - shape_t shape; - bool ret = exportFaceGroupToShape(shape, v, vn, vt, faceGroup, material, name,allIndices); - if (ret) { - shapes.push_back(shape); - } - - faceGroup.resize(0); - - // @todo { multiple object name? } - char namebuf[4096]; - token += 2; - sscanf(token, "%s", namebuf); - name = std::string(namebuf); - - - continue; - } - - // Ignore unknown command. - } - - shape_t shape; - bool ret = exportFaceGroupToShape(shape, v, vn, vt, faceGroup, material, name,allIndices); - if (ret) { - shapes.push_back(shape); - } - faceGroup.resize(0); // for safety - - return err.str(); -} - - -}; diff --git a/Demos3/Wavefront/tiny_obj_loader.h b/Demos3/Wavefront/tiny_obj_loader.h deleted file mode 100644 index bc3ad2eb7..000000000 --- a/Demos3/Wavefront/tiny_obj_loader.h +++ /dev/null @@ -1,60 +0,0 @@ -// -// Copyright 2012-2013, Syoyo Fujita. -// -// Licensed under 2-clause BSD liecense. -// -#ifndef _TINY_OBJ_LOADER_H -#define _TINY_OBJ_LOADER_H - -#include -#include -#include - -namespace tinyobj { - -typedef struct -{ - std::string name; - - float ambient[3]; - float diffuse[3]; - float specular[3]; - float transmittance[3]; - float emission[3]; - float shininess; - - std::string ambient_texname; - std::string diffuse_texname; - std::string specular_texname; - std::string normal_texname; - std::map unknown_parameter; -} material_t; - -typedef struct -{ - std::vector positions; - std::vector normals; - std::vector texcoords; - std::vector indices; -} mesh_t; - -typedef struct -{ - std::string name; - material_t material; - mesh_t mesh; -} shape_t; - -/// Loads .obj from a file. -/// 'shapes' will be filled with parsed shape data -/// The function returns error string. -/// Returns empty string when loading .obj success. -/// 'mtl_basepath' is optional, and used for base path for .mtl file. -std::string LoadObj( - std::vector& shapes, // [output] - const char* filename, - const char* mtl_basepath = NULL); - -}; - -#endif // _TINY_OBJ_LOADER_H diff --git a/Demos3/bullet2/BasicConcepts/CoordinateSystemDemo.h b/Demos3/bullet2/BasicConcepts/CoordinateSystemDemo.h deleted file mode 100644 index 7c772aebb..000000000 --- a/Demos3/bullet2/BasicConcepts/CoordinateSystemDemo.h +++ /dev/null @@ -1,146 +0,0 @@ -#ifndef COORDINATE_SYSTEM_DEMO_H -#define COORDINATE_SYSTEM_DEMO_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "OpenGLWindow/CommonGraphicsApp.h" - - -///quick demo showing the right-handed coordinate system and positive rotations around each axis -class CoordinateSystemDemo : public BulletDemoInterface -{ - CommonGraphicsApp* m_app; - float m_x; - float m_y; - float m_z; - -public: - - CoordinateSystemDemo(CommonGraphicsApp* app) - :m_app(app), - m_x(0), - m_y(0), - m_z(0) - { - m_app->setUpAxis(2); - - { - int boxId = m_app->registerCubeShape(0.1,0.1,0.1); - btVector3 pos(0,0,0); - btQuaternion orn(0,0,0,1); - btVector4 color(0.3,0.3,0.3,1); - btVector3 scaling(1,1,1); - m_app->m_renderer->registerGraphicsInstance(boxId,pos,orn,color,scaling); - } - - m_app->m_renderer->writeTransforms(); - } - virtual ~CoordinateSystemDemo() - { - m_app->m_renderer->enableBlend(false); - } - static BulletDemoInterface* CreateFunc(CommonGraphicsApp* app) - { - return new CoordinateSystemDemo(app); - } - - virtual void initPhysics() - { - } - virtual void exitPhysics() - { - - } - virtual void stepSimulation(float deltaTime) - { - m_x+=0.01f; - m_y+=0.01f; - m_z+=0.01f; - - } - virtual void renderScene() - { - m_app->m_renderer->renderScene(); - m_app->drawText3D("X",1,0,0,1); - m_app->drawText3D("Y",0,1,0,1); - m_app->drawText3D("Z",0,0,1,1); - } - - virtual void drawArc(const btVector3& center, const btVector3& normal, const btVector3& axis, btScalar radiusA, btScalar radiusB, btScalar minAngle, btScalar maxAngle, - const btVector3& color, bool drawSect, btScalar stepDegrees = btScalar(10.f)) - { - btScalar lineWidth = 3; - const btVector3& vx = axis; - btVector3 vy = normal.cross(axis); - btScalar step = stepDegrees * SIMD_RADS_PER_DEG; - int nSteps = (int)btFabs((maxAngle - minAngle) / step); - if(!nSteps) nSteps = 1; - btVector3 prev = center + radiusA * vx * btCos(minAngle) + radiusB * vy * btSin(minAngle); - if(drawSect) - { - m_app->m_renderer->drawLine(center, prev, color,lineWidth); - } - for(int i = 1; i <= nSteps; i++) - { - btScalar angle = minAngle + (maxAngle - minAngle) * btScalar(i) / btScalar(nSteps); - btVector3 next = center + radiusA * vx * btCos(angle) + radiusB * vy * btSin(angle); - m_app->m_renderer->drawLine(prev, next, color,lineWidth); - prev = next; - } - if(drawSect) - { - m_app->m_renderer->drawLine(center, prev, color,lineWidth); - } - } - - virtual void physicsDebugDraw(int debugDrawFlags) - { - - btVector3 xUnit(1,0,0); - btVector3 yUnit(0,1,0); - btVector3 zUnit(0,0,1); - - btScalar lineWidth=3; - - btQuaternion rotAroundX(xUnit,m_x); - btQuaternion rotAroundY(yUnit,m_y); - btQuaternion rotAroundZ(zUnit,m_z); - - btScalar radius=0.5; - btVector3 toX=radius*quatRotate(rotAroundX,yUnit); - btVector3 toY=radius*quatRotate(rotAroundY,xUnit); - btVector3 toZ=radius*quatRotate(rotAroundZ,xUnit); - - m_app->m_renderer->drawLine(xUnit+toX+quatRotate(rotAroundX,btVector3(0,0.1,-0.2)),xUnit+toX,xUnit,lineWidth); - m_app->m_renderer->drawLine(xUnit+toX+quatRotate(rotAroundX,btVector3(0,-0.2,-0.2)),xUnit+toX,xUnit,lineWidth); - //draw the letter 'x' on the x-axis - //m_app->m_renderer->drawLine(xUnit-0.1*zUnit+0.1*yUnit,xUnit+0.1*zUnit-0.1*yUnit,xUnit,lineWidth); - //m_app->m_renderer->drawLine(xUnit+0.1*zUnit+0.1*yUnit,xUnit-0.1*zUnit-0.1*yUnit,xUnit,lineWidth); - - m_app->m_renderer->drawLine(xUnit+toX+quatRotate(rotAroundX,btVector3(0,-0.2,-0.2)),xUnit+toX,xUnit,lineWidth); - - m_app->m_renderer->drawLine(yUnit+toY+quatRotate(rotAroundY,btVector3(-0.2,0,0.2)),yUnit+toY,yUnit,lineWidth); - m_app->m_renderer->drawLine(yUnit+toY+quatRotate(rotAroundY,btVector3(0.1,0,0.2)),yUnit+toY,yUnit,lineWidth); - m_app->m_renderer->drawLine(zUnit+toZ+quatRotate(rotAroundZ,btVector3(0.1,-0.2,0)),zUnit+toZ,zUnit,lineWidth); - m_app->m_renderer->drawLine(zUnit+toZ+quatRotate(rotAroundZ,btVector3(-0.2,-0.2,0)),zUnit+toZ,zUnit,lineWidth); - - - drawArc(xUnit,xUnit,toX.normalized(),radius,radius,0.4,SIMD_2_PI,xUnit,false); - drawArc(yUnit,yUnit,toY.normalized(),radius,radius,0.4,SIMD_2_PI,yUnit,false); - drawArc(zUnit,zUnit,toZ.normalized(),radius,radius,0.4,SIMD_2_PI,zUnit,false); - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - -}; -#endif //COORDINATE_SYSTEM_DEMO_H - diff --git a/Demos3/bullet2/BasicDemo/BasicDemo.cpp b/Demos3/bullet2/BasicDemo/BasicDemo.cpp deleted file mode 100644 index 2de7f2c77..000000000 --- a/Demos3/bullet2/BasicDemo/BasicDemo.cpp +++ /dev/null @@ -1,31 +0,0 @@ -#include "BasicDemo.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btVector3.h" - -#include "BulletDynamics/ConstraintSolver/btNNCGConstraintSolver.h" - - - - -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 - -static const float scaling=0.35f; - -BasicDemo::BasicDemo(CommonGraphicsApp* app, CommonPhysicsSetup* physicsSetup) -:Bullet2RigidBodyDemo(app,physicsSetup) -{ -} - -BasicDemo::~BasicDemo() -{ -} - -void BasicDemo::createGround(int cubeShapeId) -{ -} - - - diff --git a/Demos3/bullet2/BasicDemo/BasicDemo.h b/Demos3/bullet2/BasicDemo/BasicDemo.h deleted file mode 100644 index 4a9fe45e8..000000000 --- a/Demos3/bullet2/BasicDemo/BasicDemo.h +++ /dev/null @@ -1,33 +0,0 @@ -#ifndef BASIC_DEMO_H -#define BASIC_DEMO_H - -#include "LinearMath/btVector3.h" -#include "Bullet3AppSupport/Bullet2RigidBodyDemo.h" - -#include "../../../Demos/BasicDemo/BasicDemoPhysicsSetup.h" - - - - -class BasicDemo : public Bullet2RigidBodyDemo -{ - - - -public: - - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - CommonPhysicsSetup* physicsSetup = new BasicDemoPhysicsSetup(); - return new BasicDemo(app, physicsSetup); - } - - BasicDemo(CommonGraphicsApp* app, CommonPhysicsSetup* physicsSetup); - virtual ~BasicDemo(); - - void createGround(int cubeShapeId); - -}; - - -#endif //BASIC_DEMO_H diff --git a/Demos3/bullet2/BasicDemo/HingeDemo.cpp b/Demos3/bullet2/BasicDemo/HingeDemo.cpp deleted file mode 100644 index 57f2950d3..000000000 --- a/Demos3/bullet2/BasicDemo/HingeDemo.cpp +++ /dev/null @@ -1,492 +0,0 @@ - -#include "HingeDemo.h" - -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "MyDebugDrawer.h" - -#include "btBulletDynamicsCommon.h" - -#include "BulletDynamics/MLCPSolvers/btDantzigSolver.h" -#include "BulletDynamics/MLCPSolvers/btLemkeSolver.h" -#include "BulletDynamics/MLCPSolvers/btSolveProjectedGaussSeidel.h" -#include "BulletDynamics/MLCPSolvers/btMLCPSolver.h" - -#include "BulletDynamics/Featherstone/btMultiBody.h" -#include "BulletDynamics/Featherstone/btMultiBodyConstraintSolver.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/Featherstone/btMultiBodyLink.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointLimitConstraint.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointMotor.h" -#include "BulletDynamics/Featherstone/btMultiBodyPoint2Point.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "BulletCollision/CollisionShapes/btShapeHull.h" - -static float scaling = 1.f; -static float friction = 1.f; - -struct GraphicsVertex -{ - float pos[4]; - float normal[3]; - float texcoord[2]; -}; - -static btVector4 colors[4] = -{ - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), -}; - - -HingeDemo::HingeDemo(SimpleOpenGL3App* app, HINGE_CREATION_METHOD hingeMethod) - :BasicDemo(app), - m_hingeMethod(hingeMethod) -{ -} - -struct btMultiBodySettings2 -{ - btMultiBodySettings2() - { - m_numLinks = 0; - m_basePosition.setZero(); - m_isFixedBase = true; - m_usePrismatic = false; - m_canSleep = true; - m_createConstraints = false; - m_disableParentCollision = false; - } - int m_numLinks; - btVector3 m_basePosition; - bool m_isFixedBase; - bool m_usePrismatic; - bool m_canSleep; - bool m_createConstraints; - bool m_disableParentCollision; -}; - - -btMultiBody* HingeDemo::createFeatherstoneHinge(class btMultiBodyDynamicsWorld* world, const btMultiBodySettings2& settings) -{ - int curColor=0; - - - int cubeShapeId = m_glApp->registerCubeShape(); - - int n_links = settings.m_numLinks; - float mass = 1; - btVector3 inertia; - btVector3 halfExtents(1,1,1); - btCollisionShape* box = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])*scaling); - box->calculateLocalInertia(mass,inertia); - - bool isMultiDof = false; - btMultiBody * bod = new btMultiBody(n_links, mass, inertia, settings.m_isFixedBase, settings.m_canSleep, isMultiDof); -// bod->setHasSelfCollision(false); - - //btQuaternion orn(btVector3(0,0,1),-0.25*SIMD_HALF_PI);//0,0,0,1); - btQuaternion orn(0,0,0,1); - bod->setBasePos(settings.m_basePosition); - bod->setWorldToBaseRot(orn); - btVector3 vel(0,0,0); - bod->setBaseVel(vel); - - { - - btVector3 joint_axis_hinge(0,1,0); - btVector3 joint_axis_prismatic(2,0,2); - btQuaternion parent_to_child = orn.inverse(); - btVector3 joint_axis_child_prismatic = quatRotate(parent_to_child ,joint_axis_prismatic); - btVector3 joint_axis_child_hinge = quatRotate(parent_to_child , joint_axis_hinge); - - int this_link_num = -1; - int link_num_counter = 0; - - - - btVector3 pos = btVector3 (0,0,0);//.0500002)*scaling; - - btVector3 joint_axis_position = btVector3 (1,0,1);//-2)*scaling; - - for (int i=0;i0) -// initial_joint_angle = -0.06f; - - const int child_link_num = link_num_counter++; - - - - if (settings.m_usePrismatic)// && i==(n_links-1)) - { - bod->setupPrismatic(child_link_num, mass, inertia, this_link_num, - parent_to_child, joint_axis_child_prismatic, quatRotate(parent_to_child , pos),settings.m_disableParentCollision); - - } else - { - bod->setupRevolute(child_link_num, mass, inertia, this_link_num,parent_to_child, joint_axis_child_hinge, - joint_axis_position,quatRotate(parent_to_child , (pos - joint_axis_position)),settings.m_disableParentCollision); - } - bod->setJointPos(child_link_num, initial_joint_angle); - this_link_num = i; -#if 0 - if (0)//!useGroundShape && i==4) - { - btVector3 pivotInAworld(0,20,46); - btVector3 pivotInAlocal = bod->worldPosToLocal(i, pivotInAworld); - btVector3 pivotInBworld = pivotInAworld; - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(bod,i,&btTypedConstraint::getFixedBody(),pivotInAlocal,pivotInBworld); - world->addMultiBodyConstraint(p2p); - } - //add some constraint limit - if (settings.m_usePrismatic) - { - // btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,n_links-1,2,3); - - if (settings.m_createConstraints) - { - btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,i,-1,1); - world->addMultiBodyConstraint(con); - } - - } else - { - if (settings.m_createConstraints) - { - if (1) - { - btMultiBodyJointMotor* con = new btMultiBodyJointMotor(bod,i,0,0,500000); - world->addMultiBodyConstraint(con); - } - - btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,i,-1,1); - world->addMultiBodyConstraint(con); - } - - } -#endif - - } - } - - //add a collider for the base - { - - btAlignedObjectArray world_to_local; - world_to_local.resize(n_links+1); - - btAlignedObjectArray local_origin; - local_origin.resize(n_links+1); - world_to_local[0] = bod->getWorldToBaseRot(); - local_origin[0] = bod->getBasePos(); - //float halfExtents[3]={7.5,0.05,4.5}; - - { - - float pos[4]={local_origin[0].x(),local_origin[0].y(),local_origin[0].z(),1}; - float quat[4]={-world_to_local[0].x(),-world_to_local[0].y(),-world_to_local[0].z(),world_to_local[0].w()}; - - - if (0) - { - - btMultiBodyLinkCollider* col= new btMultiBodyLinkCollider(bod,-1); - - col->setCollisionShape(box); - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(local_origin[0]); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - - btVector4 color = colors[curColor++]; - curColor&=3; - - int index = m_glApp->m_instancingRenderer->registerGraphicsInstance(cubeShapeId,tr.getOrigin(),tr.getRotation(),color,halfExtents*scaling); - col->setUserIndex(index); - - - - - world->addCollisionObject(col,short(btBroadphaseProxy::DefaultFilter),short(btBroadphaseProxy::AllFilter)); - col->setFriction(friction); - bod->setBaseCollider(col); - - } - } - - - for (int i=0;igetNumLinks();i++) - { - const int parent = bod->getParent(i); - world_to_local[i+1] = bod->getParentToLocalRot(i) * world_to_local[parent+1]; - local_origin[i+1] = local_origin[parent+1] + (quatRotate(world_to_local[i+1].inverse() , bod->getRVector(i))); - } - - - for (int i=0;igetNumLinks();i++) - { - - btVector3 posr = local_origin[i+1]; - float pos[4]={posr.x(),posr.y(),posr.z(),1}; - - float quat[4]={-world_to_local[i+1].x(),-world_to_local[i+1].y(),-world_to_local[i+1].z(),world_to_local[i+1].w()}; - - btCollisionShape* box = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])*scaling); - btMultiBodyLinkCollider* col = new btMultiBodyLinkCollider(bod,i); - - col->setCollisionShape(box); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(posr); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - col->setFriction(friction); - - - btVector4 color = colors[curColor++]; - curColor&=3; - - int index = m_glApp->m_instancingRenderer->registerGraphicsInstance(cubeShapeId,tr.getOrigin(),tr.getRotation(),color,halfExtents*scaling); - col->setUserIndex(index); - - - - world->addCollisionObject(col,short(btBroadphaseProxy::DefaultFilter),short(btBroadphaseProxy::AllFilter)); - - bod->getLink(i).m_collider=col; - //app->drawBox(halfExtents, pos,quat); - } - - } - world->addMultiBody(bod); - - return bod; -} - -void HingeDemo::initPhysics() -{ - m_config = new btDefaultCollisionConfiguration; - m_dispatcher = new btCollisionDispatcher(m_config); - m_bp = new btDbvtBroadphase(); - - - switch (m_hingeMethod) - { - case FEATHERSTONE_HINGE: - { - btMultiBodyConstraintSolver* solver = new btMultiBodyConstraintSolver(); - btMultiBodyDynamicsWorld* world = new btMultiBodyDynamicsWorld(m_dispatcher,m_bp,solver,m_config); - m_dynamicsWorld = world; - btMultiBodySettings2 settings; - settings.m_basePosition.setValue(0,0,0); - settings.m_numLinks = 1; - btMultiBody* multibody = createFeatherstoneHinge(world, settings); - - break; - } - case DANTZIG_HINGE: - { - btDantzigSolver* mlcp = new btDantzigSolver(); - m_solver = new btMLCPSolver(mlcp); - break; - } - case LEMKE_HINGE: - { - btLemkeSolver* mlcp = new btLemkeSolver(); - m_solver = new btMLCPSolver(mlcp); - - break; - } - - case PGS_HINGE: - { - btSolveProjectedGaussSeidel* mlcp = new btSolveProjectedGaussSeidel; - m_solver = new btMLCPSolver(mlcp); - break; - } - case SI_HINGE: - { - m_solver = new btSequentialImpulseConstraintSolver(); - break; - } - case INERTIA_HINGE: - { - m_solver = new btSequentialImpulseConstraintSolver(); - break; - } - default: - { - - } - } - - int cubeShapeId = m_glApp->registerCubeShape(); - - - if (m_hingeMethod!=FEATHERSTONE_HINGE) - { - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_bp,m_solver,m_config); - - - - m_dynamicsWorld->setDebugDrawer(new MyDebugDrawer(m_glApp)); - - - - - if (1) - { - btVector4 color(0,1,0,1); - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,0,0)); - - //startTransform.setRotation(btQuaternion(btVector3(0,1,0),0.2*SIMD_HALF_PI)); - btVector3 halfExtents(1,1,1); - int index = m_glApp->m_instancingRenderer->registerGraphicsInstance(cubeShapeId,startTransform.getOrigin(),startTransform.getRotation(),color,halfExtents); - btBoxShape* box1 = new btBoxShape(halfExtents); - btCompoundShape* box = new btCompoundShape(); - btTransform shiftTrans;shiftTrans.setIdentity(); - btVector3 centerOfMassShift(0,0,0);//1.5,1.5,1.5); - - if (m_hingeMethod==INERTIA_HINGE) - { - centerOfMassShift.setValue(-1,1,-1); - } - - shiftTrans.setOrigin(centerOfMassShift); - // shiftTrans.setRotation(btQuaternion(btVector3(0,1,0),0.2*SIMD_HALF_PI)); - box->addChildShape(shiftTrans,box1); - - float mass = 1.f; - btVector3 localInertia; - box->calculateLocalInertia(mass,localInertia); - - if (m_hingeMethod==INERTIA_HINGE) - { - //localInertia[0] = 0; - //localInertia[1] = 0; - } - - btDefaultMotionState* motionState = new btDefaultMotionState(); - startTransform.setOrigin(-centerOfMassShift); - - motionState->m_centerOfMassOffset = shiftTrans; - motionState->setWorldTransform(startTransform); - - btRigidBody* body = new btRigidBody(mass,motionState,box,localInertia); - body->setUserIndex(index); - m_dynamicsWorld->addRigidBody(body); - m_dynamicsWorld->getSolverInfo().m_splitImpulse = false;//true; - // m_dynamicsWorld->getSolverInfo().m_erp2 = 1; - // m_dynamicsWorld->getSolverInfo().m_erp = 1; - m_dynamicsWorld->getSolverInfo().m_numIterations = 10; - - if (m_hingeMethod!=INERTIA_HINGE) - { - btVector3 pivotInA(1,0,1); - btVector3 axisInA(0,1,0); - btHingeConstraint* hinge = new btHingeConstraint(*body,pivotInA,axisInA); - hinge->setOverrideNumSolverIterations(10); - m_dynamicsWorld->addConstraint(hinge); - } else - { - body->setLinearFactor(btVector3(0,0,0)); - - btVector3 ax = btVector3(0,1,0); - - body->setAngularFactor(ax); - - } - } - - - } - - - if (1) - { - btVector4 color(0,0,1,1); - btTransform startTransform; - startTransform.setIdentity(); - startTransform.setOrigin(btVector3(0,2,0)); - btVector3 halfExtents(1,1,1); - int index = m_glApp->m_instancingRenderer->registerGraphicsInstance(cubeShapeId,startTransform.getOrigin(),startTransform.getRotation(),color,halfExtents); - btBoxShape* box = new btBoxShape(halfExtents); - - float mass = 1.f; - btVector3 localInertia; - box->calculateLocalInertia(mass,localInertia); - btRigidBody* body = new btRigidBody(mass,0,box,localInertia); - body->getMotionState(); - body->setWorldTransform(startTransform); - body->setUserIndex(index); - body->setAngularVelocity(btVector3(0,1,0)); - body->setActivationState(DISABLE_DEACTIVATION); - m_dynamicsWorld->addRigidBody(body); - } - - - m_glApp->m_instancingRenderer->writeTransforms(); -} - - -void HingeDemo::renderScene() -{ -// m_glApp->drawGrid(); -// m_glApp->drawText("test",10,10); - //sync graphics -> physics world transforms - - { - - for (int i=0;igetNumCollisionObjects();i++) - { - btRigidBody* body = btRigidBody::upcast(m_dynamicsWorld->getCollisionObjectArray()[i]); - const btDefaultMotionState* state = (btDefaultMotionState*)(body ? body->getMotionState() : 0); - - if (state) - { - btTransform tr = state->m_graphicsWorldTrans; - - btVector3 pos = tr.getOrigin(); - btQuaternion orn = tr.getRotation(); - m_glApp->m_instancingRenderer->writeSingleInstanceTransformToCPU(pos,orn,i); - - } else - { - btVector3 pos = m_dynamicsWorld->getCollisionObjectArray()[i]->getWorldTransform().getOrigin(); - btQuaternion orn = m_dynamicsWorld->getCollisionObjectArray()[i]->getWorldTransform().getRotation(); - m_glApp->m_instancingRenderer->writeSingleInstanceTransformToCPU(pos,orn,i); - } - } - m_glApp->m_instancingRenderer->writeTransforms(); - } - - - static bool debugRender = false; - { - m_dynamicsWorld->debugDrawWorld(); - } - debugRender = !debugRender ; - { - m_glApp->m_instancingRenderer->renderScene(); - } - -// if (debugRender) - -// else - -} - -void HingeDemo::exitPhysics() -{ - Bullet2RigidBodyDemo::exitPhysics(); - -} \ No newline at end of file diff --git a/Demos3/bullet2/BasicDemo/HingeDemo.h b/Demos3/bullet2/BasicDemo/HingeDemo.h deleted file mode 100644 index 3f9f43906..000000000 --- a/Demos3/bullet2/BasicDemo/HingeDemo.h +++ /dev/null @@ -1,63 +0,0 @@ - -#ifndef HINGE_DEMO_H -#define HINGE_DEMO_H - -#include "BasicDemo.h" - -enum HINGE_CREATION_METHOD -{ - FEATHERSTONE_HINGE=1, - DANTZIG_HINGE, - LEMKE_HINGE, - PGS_HINGE, - SI_HINGE, - INERTIA_HINGE -}; - -class HingeDemo : public BasicDemo -{ - int m_hingeMethod; - -public: - static BulletDemoInterface* FeatherstoneCreateFunc(CommonGraphicsApp* app) - { - return new HingeDemo(app, FEATHERSTONE_HINGE); - } - static BulletDemoInterface* DantzigCreateFunc(CommonGraphicsApp* app) - { - return new HingeDemo(app, DANTZIG_HINGE); - } - static BulletDemoInterface* LemkeCreateFunc(CommonGraphicsApp* app) - { - return new HingeDemo(app, LEMKE_HINGE); - } - static BulletDemoInterface* PGSCreateFunc(CommonGraphicsApp* app) - { - return new HingeDemo(app, PGS_HINGE); - } - - static BulletDemoInterface* SICreateFunc(CommonGraphicsApp* app) - { - return new HingeDemo(app, SI_HINGE); - } - - - static BulletDemoInterface* InertiaCreateFunc(CommonGraphicsApp* app) - { - return new HingeDemo(app, INERTIA_HINGE); - } - - HingeDemo(CommonGraphicsApp* app, HINGE_CREATION_METHOD hingeMethod); - - class btMultiBody* createFeatherstoneHinge(class btMultiBodyDynamicsWorld* world, const struct btMultiBodySettings2& settings); - - - virtual void initPhysics(); - virtual void exitPhysics(); - - virtual void renderScene(); - -}; - -#endif //HINGE_DEMO_H - diff --git a/Demos3/bullet2/ChainDemo/ChainDemo.cpp b/Demos3/bullet2/ChainDemo/ChainDemo.cpp deleted file mode 100644 index 71032cb7c..000000000 --- a/Demos3/bullet2/ChainDemo/ChainDemo.cpp +++ /dev/null @@ -1,201 +0,0 @@ -#include "ChainDemo.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btVector3.h" - -#include "BulletDynamics/ConstraintSolver/btNNCGConstraintSolver.h" -#include "BulletDynamics/MLCPSolvers/btDantzigSolver.h" -#include "BulletDynamics/MLCPSolvers/btLemkeSolver.h" -#include "BulletDynamics/MLCPSolvers/btSolveProjectedGaussSeidel.h" -#include "BulletDynamics/MLCPSolvers/btMLCPSolver.h" - - -#define NUM_SPHERES 10 - -static const float scaling=0.35f; - -ChainDemo::ChainDemo(SimpleOpenGL3App* app) -:Bullet2RigidBodyDemo(app) -{ -} - -ChainDemo::~ChainDemo() -{ -} - -void ChainDemo::createGround(int cubeShapeId) -{ - { - btVector4 color(0.3,0.3,1,1); - btVector4 halfExtents(50,1,50,1); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-5,0)); - m_glApp->m_instancingRenderer->registerGraphicsInstance(cubeShapeId,groundTransform.getOrigin(),groundTransform.getRotation(),color,halfExtents); - btBoxShape* groundShape = new btBoxShape(btVector3(btScalar(halfExtents[0]),btScalar(halfExtents[1]),btScalar(halfExtents[2]))); - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - body->setActivationState(DISABLE_DEACTIVATION); - } - } -} -void ChainDemo::initPhysics() -{ -// Bullet2RigidBodyDemo::initPhysics(); - - m_config = new btDefaultCollisionConfiguration; - m_dispatcher = new btCollisionDispatcher(m_config); - m_bp = new btDbvtBroadphase(); - //m_solver = new btNNCGConstraintSolver(); - m_solver = new btSequentialImpulseConstraintSolver(); -// btDantzigSolver* mlcp = new btDantzigSolver(); - //btLemkeSolver* mlcp = new btLemkeSolver(); - //m_solver = new btMLCPSolver(mlcp); -// m_solver = new btSequentialImpulseConstraintSolver(); - //btMultiBodyConstraintSolver* solver = new btMultiBodyConstraintSolver(); - //m_solver = solver; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_bp,m_solver,m_config); - m_dynamicsWorld->getSolverInfo().m_numIterations = 1000; - m_dynamicsWorld->getSolverInfo().m_splitImpulse = false; - - int curColor=0; - //create ground - btScalar radius=scaling; - int unitCubeShapeId = m_glApp->registerCubeShape(); - - float pos[]={0,0,0}; - float orn[]={0,0,0,1}; - - - //eateGround(unitCubeShapeId); - - int sphereShapeId = m_glApp->registerGraphicsSphereShape(radius,false); - - { - btVector4 halfExtents(scaling,scaling,scaling,1); - btVector4 colors[4] = - { - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), - }; - - - - btTransform startTransform; - startTransform.setIdentity(); - - - btCollisionShape* colShape = new btSphereShape(scaling); - - btScalar largeMass[]={1000,10,100,1000}; - for (int i=0;i<1;i++) - { - - btAlignedObjectArray bodies; - for (int k=0;kcalculateLocalInertia(mass,localInertia); - - btVector4 color = colors[curColor]; - - startTransform.setOrigin(btVector3( - btScalar(7.5+-i*5), - btScalar(6.*scaling+2.0*scaling*k), - btScalar(0))); - - m_glApp->m_instancingRenderer->registerGraphicsInstance(sphereShapeId,startTransform.getOrigin(),startTransform.getRotation(),color,halfExtents); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,colShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - bodies.push_back(body); - body->setActivationState(DISABLE_DEACTIVATION); - - m_dynamicsWorld->addRigidBody(body); - } - - //add constraints - btVector3 pivotInA(0,radius,0); - btVector3 pivotInB(0,-radius,0); - for (int k=0;kaddConstraint(p2p,true); - } - } - } - - m_glApp->m_instancingRenderer->writeTransforms(); -} -void ChainDemo::exitPhysics() -{ - - Bullet2RigidBodyDemo::exitPhysics(); -} -void ChainDemo::renderScene() -{ - //sync graphics -> physics world transforms - { - for (int i=0;igetNumCollisionObjects();i++) - { - btVector3 pos = m_dynamicsWorld->getCollisionObjectArray()[i]->getWorldTransform().getOrigin(); - btQuaternion orn = m_dynamicsWorld->getCollisionObjectArray()[i]->getWorldTransform().getRotation(); - m_glApp->m_instancingRenderer->writeSingleInstanceTransformToCPU(pos,orn,i); - } - m_glApp->m_instancingRenderer->writeTransforms(); - } - - m_glApp->m_instancingRenderer->renderScene(); -} - - -void ChainDemo::stepSimulation(float dt) -{ - m_dynamicsWorld->stepSimulation(dt,10,1./240.); - //m_dynamicsWorld->stepSimulation(dt,10,1./60.); -} - - - diff --git a/Demos3/bullet2/ChainDemo/ChainDemo.h b/Demos3/bullet2/ChainDemo/ChainDemo.h deleted file mode 100644 index 03f2d44ef..000000000 --- a/Demos3/bullet2/ChainDemo/ChainDemo.h +++ /dev/null @@ -1,31 +0,0 @@ -#ifndef CHAIN_DEMO_H -#define CHAIN_DEMO_H - -#include "LinearMath/btVector3.h" -#include "Bullet3AppSupport/Bullet2RigidBodyDemo.h" - - - -class ChainDemo : public Bullet2RigidBodyDemo -{ - -public: - - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - return new ChainDemo(app); - } - - ChainDemo(CommonGraphicsApp* app); - virtual ~ChainDemo(); - - void createGround(int cubeShapeId); - - virtual void initPhysics(); - virtual void exitPhysics(); - virtual void renderScene(); - virtual void stepSimulation(float dt); -}; - - -#endif //CHAIN_DEMO_H diff --git a/Demos3/bullet2/CollisionDetection/SupportFuncDemo.h b/Demos3/bullet2/CollisionDetection/SupportFuncDemo.h deleted file mode 100644 index d6e5f0354..000000000 --- a/Demos3/bullet2/CollisionDetection/SupportFuncDemo.h +++ /dev/null @@ -1,115 +0,0 @@ -#ifndef SUPPORT_FUNC_DEMO_H -#define SUPPORT_FUNC_DEMO_H - -#include "Bullet3AppSupport/BulletDemoInterface.h" -#include "OpenGLWindow/CommonGraphicsApp.h" -#include "BulletCollision/CollisionShapes/btSphereShape.h" - - -///quick demo showing the support map function (localGetSupportingVertex) -class MySupportFuncDemo : public BulletDemoInterface -{ - CommonGraphicsApp* m_app; - btSphereShape* m_sphere; - float m_x; - float m_y; - - -public: - - MySupportFuncDemo(CommonGraphicsApp* app) - :m_app(app), - m_x(0), - m_y(0) - { - m_app->setUpAxis(1); - m_sphere = new btSphereShape(1); - { - int boxId = m_app->registerCubeShape(10,0.1,10); - btVector3 pos(0,-2,0); - btQuaternion orn(0,0,0,1); - btVector4 color(0.3,0.3,0.3,1); - - btVector3 scaling(1,1,1); - m_app->m_renderer->registerGraphicsInstance(boxId,pos,orn,color,scaling); - } - - { - int sphereId = m_app->registerGraphicsSphereShape(1,false,0,0); - btVector3 pos(0,0,0); - btQuaternion orn(0,0,0,1); - btVector4 color(0,1,0,0.6); - - btVector3 scaling(1,1,1); - m_app->m_renderer->registerGraphicsInstance(sphereId,pos,orn,color,scaling); - } - m_app->m_renderer->writeTransforms(); - m_app->m_renderer->enableBlend(true); - } - virtual ~MySupportFuncDemo() - { - m_app->m_renderer->enableBlend(false); - delete m_sphere; - } - static BulletDemoInterface* CreateFunc(CommonGraphicsApp* app) - { - return new MySupportFuncDemo(app); - } - - virtual void initPhysics() - { - } - virtual void exitPhysics() - { - - } - virtual void stepSimulation(float deltaTime) - { - m_x+=0.01f; - m_y+=0.02f; - - } - virtual void renderScene() - { - m_app->m_renderer->renderScene(); - - } - virtual void physicsDebugDraw(int debugDrawFlags) - { - int width=3; - btVector3 from(0,0,0); - btVector3 to(10.*btSin(m_x),10.*btCos(m_x),10.*btSin(m_y)); - - - { - btVector3 color(1,0,0); - m_app->m_renderer->drawLine(from,to,color,width); - } - btVector3 dir(to-from); - btVector3 sup = m_sphere->btConvexInternalShape::localGetSupportingVertex(dir); - btVector3 orth0,orth1; - btPlaneSpace1(dir,orth0,orth1); - btVector3 color(0,0,1); - orth0.normalize(); - orth1.normalize(); - - m_app->m_renderer->drawLine(sup,sup+orth0*0.4,color,3); - m_app->m_renderer->drawLine(sup,sup+orth1*0.4,color,3); - - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } - -}; -#endif //SUPPORT_FUNC_DEMO - diff --git a/Demos3/bullet2/ConstraintDemo/ConstraintPhysicsSetup.cpp b/Demos3/bullet2/ConstraintDemo/ConstraintPhysicsSetup.cpp deleted file mode 100644 index 003ad00ae..000000000 --- a/Demos3/bullet2/ConstraintDemo/ConstraintPhysicsSetup.cpp +++ /dev/null @@ -1,128 +0,0 @@ -#include "ConstraintPhysicsSetup.h" - -ConstraintPhysicsSetup::ConstraintPhysicsSetup() -{ -} -ConstraintPhysicsSetup::~ConstraintPhysicsSetup() -{ -} - -static btScalar val; -static btScalar targetVel=0; -static btScalar maxImpulse=10000; -static btHingeAccumulatedAngleConstraint* spDoorHinge=0; -static btScalar actualHingeVelocity=0.f; - -static btVector3 btAxisA(0,1,0); - -void ConstraintPhysicsSetup::stepSimulation(float deltaTime) -{ - val=spDoorHinge->getAccumulatedHingeAngle()*SIMD_DEGS_PER_RAD; - if (m_dynamicsWorld) - { - spDoorHinge->enableAngularMotor(true,targetVel,maxImpulse); - - m_dynamicsWorld->stepSimulation(deltaTime,10,1./240.); - - - btHingeConstraint* hinge = spDoorHinge; - - if (hinge) - { - - const btRigidBody& bodyA = hinge->getRigidBodyA(); - const btRigidBody& bodyB = hinge->getRigidBodyB(); - - - btTransform trA = bodyA.getWorldTransform(); - btVector3 angVelA = bodyA.getAngularVelocity(); - btVector3 angVelB = bodyB.getAngularVelocity(); - - { - btVector3 ax1 = trA.getBasis()*hinge->getFrameOffsetA().getBasis().getColumn(2); - btScalar vel = angVelA.dot(ax1); - vel -= angVelB.dot(ax1); - printf("hinge velocity (q) = %f\n", vel); - actualHingeVelocity=vel; - } - btVector3 ortho0,ortho1; - btPlaneSpace1(btAxisA,ortho0,ortho1); - { - - btScalar vel2 = angVelA.dot(ortho0); - vel2 -= angVelB.dot(ortho0); - printf("hinge orthogonal1 velocity (q) = %f\n", vel2); - } - { - - btScalar vel0 = angVelA.dot(ortho1); - vel0 -= angVelB.dot(ortho1); - printf("hinge orthogonal0 velocity (q) = %f\n", vel0); - } - } - } -} - - - -void ConstraintPhysicsSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - gfxBridge.setUpAxis(1); - - createEmptyDynamicsWorld(); - - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - int mode = btIDebugDraw::DBG_DrawWireframe - +btIDebugDraw::DBG_DrawConstraints - +btIDebugDraw::DBG_DrawConstraintLimits; - m_dynamicsWorld->getDebugDrawer()->setDebugMode(mode); - - - { - SliderParams slider("target vel",&targetVel); - slider.m_minVal=-4; - slider.m_maxVal=4; - gfxBridge.getParameterInterface()->registerSliderFloatParameter(slider); - } - - { - SliderParams slider("max impulse",&maxImpulse); - slider.m_minVal=0; - slider.m_maxVal=1000; - gfxBridge.getParameterInterface()->registerSliderFloatParameter(slider); - } - - { - SliderParams slider("actual vel",&actualHingeVelocity); - slider.m_minVal=-4; - slider.m_maxVal=4; - gfxBridge.getParameterInterface()->registerSliderFloatParameter(slider); - } - - val=1.f; - { - SliderParams slider("angle",&val); - slider.m_minVal=-720; - slider.m_maxVal=720; - gfxBridge.getParameterInterface()->registerSliderFloatParameter(slider); - } - - { // create a door using hinge constraint attached to the world - btCollisionShape* pDoorShape = new btBoxShape(btVector3(2.0f, 5.0f, 0.2f)); - m_collisionShapes.push_back(pDoorShape); - btTransform doorTrans; - doorTrans.setIdentity(); - doorTrans.setOrigin(btVector3(-5.0f, -2.0f, 0.0f)); - btRigidBody* pDoorBody = createRigidBody( 1.0, doorTrans, pDoorShape); - pDoorBody->setActivationState(DISABLE_DEACTIVATION); - const btVector3 btPivotA(10.f + 2.1f, -2.0f, 0.0f ); // right next to the door slightly outside - - spDoorHinge = new btHingeAccumulatedAngleConstraint( *pDoorBody, btPivotA, btAxisA ); - - m_dynamicsWorld->addConstraint(spDoorHinge); - - spDoorHinge->setDbgDrawSize(btScalar(5.f)); - } - - gfxBridge.autogenerateGraphicsObjects(m_dynamicsWorld); -} diff --git a/Demos3/bullet2/ConstraintDemo/ConstraintPhysicsSetup.h b/Demos3/bullet2/ConstraintDemo/ConstraintPhysicsSetup.h deleted file mode 100644 index ec1267622..000000000 --- a/Demos3/bullet2/ConstraintDemo/ConstraintPhysicsSetup.h +++ /dev/null @@ -1,16 +0,0 @@ -#ifndef CONSTAINT_PHYSICS_SETUP_H -#define CONSTAINT_PHYSICS_SETUP_H - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -struct ConstraintPhysicsSetup : public CommonRigidBodySetup -{ - ConstraintPhysicsSetup(); - virtual ~ConstraintPhysicsSetup(); - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void stepSimulation(float deltaTime); - -}; - -#endif //CONSTAINT_PHYSICS_SETUP_H diff --git a/Demos3/bullet2/ConstraintDemo/Dof6Spring2Setup.cpp b/Demos3/bullet2/ConstraintDemo/Dof6Spring2Setup.cpp deleted file mode 100644 index 78b8ebeac..000000000 --- a/Demos3/bullet2/ConstraintDemo/Dof6Spring2Setup.cpp +++ /dev/null @@ -1,453 +0,0 @@ -#include "Dof6Spring2Setup.h" - -#include "btBulletDynamicsCommon.h" -#include "BulletDynamics/ConstraintSolver/btNNCGConstraintSolver.h" -#include "BulletDynamics/MLCPSolvers/btMLCPSolver.h" -#include "BulletDynamics/MLCPSolvers/btSolveProjectedGaussSeidel.h" -#include "BulletDynamics/MLCPSolvers/btLemkeSolver.h" -#include "BulletDynamics/MLCPSolvers/btDantzigSolver.h" - -#include "BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h" - - -#ifndef M_PI -#define M_PI 3.14159265358979323846 -#endif - -#ifndef M_PI_2 -#define M_PI_2 1.57079632679489661923 -#endif - -#ifndef M_PI_4 -#define M_PI_4 0.785398163397448309616 -#endif - - -extern float g_additionalBodyMass; - -//comment this out to compare with original spring constraint -#define USE_6DOF2 -#ifdef USE_6DOF2 - #define CONSTRAINT_TYPE btGeneric6DofSpring2Constraint - #define EXTRAPARAMS -#else - #define CONSTRAINT_TYPE btGeneric6DofSpringConstraint - #define EXTRAPARAMS ,true -#endif - -struct Dof6Spring2SetupInternalData -{ - btRigidBody* m_TranslateSpringBody; - btRigidBody* m_TranslateSpringBody2; - btRigidBody* m_RotateSpringBody; - btRigidBody* m_RotateSpringBody2; - btRigidBody* m_BouncingTranslateBody; - btRigidBody* m_MotorBody; - btRigidBody* m_ServoMotorBody; - btRigidBody* m_ChainLeftBody; - btRigidBody* m_ChainRightBody; - CONSTRAINT_TYPE* m_ServoMotorConstraint; - CONSTRAINT_TYPE* m_ChainLeftConstraint; - CONSTRAINT_TYPE* m_ChainRightConstraint; - - - float mDt; - - unsigned int frameID; - Dof6Spring2SetupInternalData() - : mDt(1./60.),frameID(0) - { - } -}; - -Dof6Spring2Setup::Dof6Spring2Setup() -{ - m_data = new Dof6Spring2SetupInternalData; -} -Dof6Spring2Setup::~Dof6Spring2Setup() -{ - exitPhysics(); - delete m_data; -} -void Dof6Spring2Setup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - // Setup the basic world - - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - btVector3 worldAabbMin(-10000,-10000,-10000); - btVector3 worldAabbMax(10000,10000,10000); - m_broadphase = new btAxisSweep3 (worldAabbMin, worldAabbMax); - -/////// uncomment the corresponding line to test a solver. - //m_solver = new btSequentialImpulseConstraintSolver; - m_solver = new btNNCGConstraintSolver; - //m_solver = new btMLCPSolver(new btSolveProjectedGaussSeidel()); - //m_solver = new btMLCPSolver(new btDantzigSolver()); - //m_solver = new btMLCPSolver(new btLemkeSolver()); - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); - m_dynamicsWorld->getDispatchInfo().m_useContinuous = true; - - m_dynamicsWorld->setGravity(btVector3(0,0,0)); - - // Setup a big ground box - { - btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(200.),btScalar(5.),btScalar(200.))); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-10,0)); -#define CREATE_GROUND_COLLISION_OBJECT 1 -#ifdef CREATE_GROUND_COLLISION_OBJECT - btCollisionObject* fixedGround = new btCollisionObject(); - fixedGround->setCollisionShape(groundShape); - fixedGround->setWorldTransform(groundTransform); - m_dynamicsWorld->addCollisionObject(fixedGround); -#else - localCreateRigidBody(btScalar(0.),groundTransform,groundShape); -#endif //CREATE_GROUND_COLLISION_OBJECT - } - - m_dynamicsWorld->getSolverInfo().m_numIterations = 100; - - btCollisionShape* shape; - btVector3 localInertia(0,0,0); - btDefaultMotionState* motionState; - btTransform bodyTransform; - btScalar mass; - btTransform localA; - btTransform localB; - CONSTRAINT_TYPE* constraint; - - //static body centered in the origo - mass = 0.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - localInertia = btVector3(0,0,0); - bodyTransform.setIdentity(); - motionState = new btDefaultMotionState(bodyTransform); - btRigidBody* staticBody = new btRigidBody(mass,motionState,shape,localInertia); - -/////////// box with undamped translate spring attached to static body -/////////// the box should oscillate left-to-right forever - { - mass = 1.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - shape->calculateLocalInertia(mass,localInertia); - bodyTransform.setIdentity(); - bodyTransform.setOrigin(btVector3(-2,0,-5)); - motionState = new btDefaultMotionState(bodyTransform); - m_data->m_TranslateSpringBody = new btRigidBody(mass,motionState,shape,localInertia); - m_data->m_TranslateSpringBody->setActivationState(DISABLE_DEACTIVATION); - m_dynamicsWorld->addRigidBody(m_data->m_TranslateSpringBody); - localA.setIdentity();localA.getOrigin() = btVector3(0,0,-5); - localB.setIdentity(); - constraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_TranslateSpringBody, localA, localB EXTRAPARAMS); - constraint->setLimit(0, 1,-1); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, 0, 0); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 0, 0); - constraint->enableSpring(0, true); - constraint->setStiffness(0, 100); - #ifdef USE_6DOF2 - constraint->setDamping(0, 0); - #else - constraint->setDamping(0, 1); - #endif - constraint->setEquilibriumPoint(0, 0); - m_dynamicsWorld->addConstraint(constraint, true); - } - -/////////// box with rotate spring, attached to static body -/////////// box should swing (rotate) left-to-right forever - { - mass = 1.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - shape->calculateLocalInertia(mass,localInertia); - bodyTransform.setIdentity(); - bodyTransform.getBasis().setEulerZYX(0,0,M_PI_2); - motionState = new btDefaultMotionState(bodyTransform); - m_data->m_RotateSpringBody = new btRigidBody(mass,motionState,shape,localInertia); - m_data->m_RotateSpringBody->setActivationState(DISABLE_DEACTIVATION); - m_dynamicsWorld->addRigidBody(m_data->m_RotateSpringBody); - localA.setIdentity();localA.getOrigin() = btVector3(0,0,0); - localB.setIdentity();localB.setOrigin(btVector3(0,0.5,0)); - constraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_RotateSpringBody, localA, localB EXTRAPARAMS); - constraint->setLimit(0, 0, 0); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, 0, 0); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 1, -1); - constraint->enableSpring(5, true); - constraint->setStiffness(5, 100); - #ifdef USE_6DOF2 - constraint->setDamping(5, 0); - #else - constraint->setDamping(5, 1); - #endif - constraint->setEquilibriumPoint(0, 0); - m_dynamicsWorld->addConstraint(constraint, true); - } - -/////////// box with bouncing constraint, translation is bounced at the positive x limit, but not at the negative limit -/////////// bouncing can not be set independently at low and high limits, so two constraints will be created: one that defines the low (non bouncing) limit, and one that defines the high (bouncing) limit -/////////// the box should move to the left (as an impulse will be applied to it periodically) until it reaches its limit, then bounce back - { - mass = 1.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - shape->calculateLocalInertia(mass,localInertia); - bodyTransform.setIdentity(); - bodyTransform.setOrigin(btVector3(0,0,-3)); - motionState = new btDefaultMotionState(bodyTransform); - m_data->m_BouncingTranslateBody = new btRigidBody(mass,motionState,shape,localInertia); - m_data->m_BouncingTranslateBody->setActivationState(DISABLE_DEACTIVATION); - m_data->m_BouncingTranslateBody->setDeactivationTime(btScalar(20000000)); - m_dynamicsWorld->addRigidBody(m_data->m_BouncingTranslateBody); - localA.setIdentity();localA.getOrigin() = btVector3(0,0,0); - localB.setIdentity(); - constraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_BouncingTranslateBody, localA, localB EXTRAPARAMS); - constraint->setLimit(0, -2, SIMD_INFINITY); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, -3, -3); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 0, 0); - #ifdef USE_6DOF2 - constraint->setBounce(0,0); - #else //bounce is named restitution in 6dofspring, but not implemented for translational limit motor, so the following line has no effect - constraint->getTranslationalLimitMotor()->m_restitution = 0.0; - #endif - constraint->setParam(BT_CONSTRAINT_STOP_ERP,0.995,0); - constraint->setParam(BT_CONSTRAINT_STOP_CFM,0.0,0); - m_dynamicsWorld->addConstraint(constraint, true); - constraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_BouncingTranslateBody, localA, localB EXTRAPARAMS); - constraint->setLimit(0, -SIMD_INFINITY, 2); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, -3, -3); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 0, 0); - #ifdef USE_6DOF2 - constraint->setBounce(0,1); - #else //bounce is named restitution in 6dofspring, but not implemented for translational limit motor, so the following line has no effect - constraint->getTranslationalLimitMotor()->m_restitution = 1.0; - #endif - constraint->setParam(BT_CONSTRAINT_STOP_ERP,0.995,0); - constraint->setParam(BT_CONSTRAINT_STOP_CFM,0.0,0); - m_dynamicsWorld->addConstraint(constraint, true); - } - -/////////// box with rotational motor, attached to static body -/////////// the box should rotate around the y axis - { - mass = 1.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - shape->calculateLocalInertia(mass,localInertia); - bodyTransform.setIdentity(); - bodyTransform.setOrigin(btVector3(4,0,0)); - motionState = new btDefaultMotionState(bodyTransform); - m_data->m_MotorBody = new btRigidBody(mass,motionState,shape,localInertia); - m_data->m_MotorBody->setActivationState(DISABLE_DEACTIVATION); - m_dynamicsWorld->addRigidBody(m_data->m_MotorBody); - localA.setIdentity();localA.getOrigin() = btVector3(4,0,0); - localB.setIdentity(); - constraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_MotorBody, localA, localB EXTRAPARAMS); - constraint->setLimit(0, 0, 0); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, 0, 0); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 1,-1); - #ifdef USE_6DOF2 - constraint->enableMotor(5,true); - constraint->setTargetVelocity(5,3.f); - constraint->setMaxMotorForce(5,10.f); - #else - constraint->getRotationalLimitMotor(2)->m_enableMotor = true; - constraint->getRotationalLimitMotor(2)->m_targetVelocity = 3.f; - constraint->getRotationalLimitMotor(2)->m_maxMotorForce = 10; - #endif - m_dynamicsWorld->addConstraint(constraint, true); - } - -/////////// box with rotational servo motor, attached to static body -/////////// the box should rotate around the y axis until it reaches its target -/////////// the target will be negated periodically - { - mass = 1.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - shape->calculateLocalInertia(mass,localInertia); - bodyTransform.setIdentity(); - bodyTransform.setOrigin(btVector3(7,0,0)); - motionState = new btDefaultMotionState(bodyTransform); - m_data->m_ServoMotorBody = new btRigidBody(mass,motionState,shape,localInertia); - m_data->m_ServoMotorBody->setActivationState(DISABLE_DEACTIVATION); - m_dynamicsWorld->addRigidBody(m_data->m_ServoMotorBody); - localA.setIdentity();localA.getOrigin() = btVector3(7,0,0); - localB.setIdentity(); - constraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_ServoMotorBody, localA, localB EXTRAPARAMS); - constraint->setLimit(0, 0, 0); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, 0, 0); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 1,-1); - #ifdef USE_6DOF2 - constraint->enableMotor(5,true); - constraint->setTargetVelocity(5,3.f); - constraint->setMaxMotorForce(5,10.f); - constraint->setServo(5,true); - constraint->setServoTarget(5, M_PI_2); - #else - constraint->getRotationalLimitMotor(2)->m_enableMotor = true; - constraint->getRotationalLimitMotor(2)->m_targetVelocity = 3.f; - constraint->getRotationalLimitMotor(2)->m_maxMotorForce = 10; - //servo motor is not implemented in 6dofspring constraint - #endif - m_dynamicsWorld->addConstraint(constraint, true); - m_data->m_ServoMotorConstraint = constraint; - } - -////////// chain of boxes linked together with fully limited rotational and translational constraints -////////// the chain will be pulled to the left and to the right periodically. They should strictly stick together. - { - btScalar limitConstraintStrength = 0.6; - int bodycount = 10; - btRigidBody* prevBody = 0; - for(int i = 0; i < bodycount; ++i) - { - mass = 1.0; - shape= new btBoxShape(btVector3(0.5,0.5,0.5)); - shape->calculateLocalInertia(mass,localInertia); - bodyTransform.setIdentity(); - bodyTransform.setOrigin(btVector3(- i,0,3)); - motionState = new btDefaultMotionState(bodyTransform); - btRigidBody* body = new btRigidBody(mass,motionState,shape,localInertia); - body->setActivationState(DISABLE_DEACTIVATION); - m_dynamicsWorld->addRigidBody(body); - if(prevBody != 0) - { - localB.setIdentity(); - localB.setOrigin(btVector3(0.5,0,0)); - btTransform localA; - localA.setIdentity(); - localA.setOrigin(btVector3(-0.5,0,0)); - CONSTRAINT_TYPE* constraint = new CONSTRAINT_TYPE(*prevBody, *body, localA, localB EXTRAPARAMS); - constraint->setLimit(0, -0.01, 0.01); - constraint->setLimit(1, 0, 0); - constraint->setLimit(2, 0, 0); - constraint->setLimit(3, 0, 0); - constraint->setLimit(4, 0, 0); - constraint->setLimit(5, 0, 0); - for(int a = 0; a < 6; ++a) - { - constraint->setParam(BT_CONSTRAINT_STOP_ERP,0.9,a); - constraint->setParam(BT_CONSTRAINT_STOP_CFM,0.0,a); - } - m_dynamicsWorld->addConstraint(constraint, true); - - if(i < bodycount - 1) - { - localA.setIdentity();localA.getOrigin() = btVector3(0,0,3); - localB.setIdentity(); - CONSTRAINT_TYPE* constraintZY = new CONSTRAINT_TYPE(*staticBody, *body, localA, localB EXTRAPARAMS); - constraintZY->setLimit(0, 1, -1); - m_dynamicsWorld->addConstraint(constraintZY, true); - } - } - else - { - localA.setIdentity();localA.getOrigin() = btVector3(bodycount,0,3); - localB.setIdentity(); - localB.setOrigin(btVector3(0,0,0)); - m_data->m_ChainLeftBody = body; - m_data->m_ChainLeftConstraint = new CONSTRAINT_TYPE(*staticBody, *body, localA, localB EXTRAPARAMS); - m_data->m_ChainLeftConstraint->setLimit(3,0,0); - m_data->m_ChainLeftConstraint->setLimit(4,0,0); - m_data->m_ChainLeftConstraint->setLimit(5,0,0); - for(int a = 0; a < 6; ++a) - { - m_data->m_ChainLeftConstraint->setParam(BT_CONSTRAINT_STOP_ERP,limitConstraintStrength,a); - m_data->m_ChainLeftConstraint->setParam(BT_CONSTRAINT_STOP_CFM,0.0,a); - } - m_dynamicsWorld->addConstraint(m_data->m_ChainLeftConstraint, true); - } - prevBody = body; - } - m_data->m_ChainRightBody = prevBody; - localA.setIdentity();localA.getOrigin() = btVector3(-bodycount,0,3); - localB.setIdentity(); - localB.setOrigin(btVector3(0,0,0)); - m_data->m_ChainRightConstraint = new CONSTRAINT_TYPE(*staticBody, *m_data->m_ChainRightBody, localA, localB EXTRAPARAMS); - m_data->m_ChainRightConstraint->setLimit(3,0,0); - m_data->m_ChainRightConstraint->setLimit(4,0,0); - m_data->m_ChainRightConstraint->setLimit(5,0,0); - for(int a = 0; a < 6; ++a) - { - m_data->m_ChainRightConstraint->setParam(BT_CONSTRAINT_STOP_ERP,limitConstraintStrength,a); - m_data->m_ChainRightConstraint->setParam(BT_CONSTRAINT_STOP_CFM,0.0,a); - } - } - gfxBridge.autogenerateGraphicsObjects(m_dynamicsWorld); -} - - -void Dof6Spring2Setup::animate() -{ - -/////// servo motor: flip its target periodically -#ifdef USE_6DOF2 - static float servoNextFrame = -1; - btScalar pos = m_data->m_ServoMotorConstraint->getRotationalLimitMotor(2)->m_currentPosition; - btScalar target = m_data->m_ServoMotorConstraint->getRotationalLimitMotor(2)->m_servoTarget; - if(servoNextFrame < 0) - { - m_data->m_ServoMotorConstraint->getRotationalLimitMotor(2)->m_servoTarget *= -1; - servoNextFrame = 3.0; - } - servoNextFrame -= m_data->mDt; -#endif - -/////// constraint chain: pull the chain left and right periodically - static float chainNextFrame = -1; - static bool left = true; - if(chainNextFrame < 0) - { - if(!left) - { - m_data->m_ChainRightBody->setActivationState(ACTIVE_TAG); - m_dynamicsWorld->removeConstraint(m_data->m_ChainRightConstraint); - m_dynamicsWorld->addConstraint(m_data->m_ChainLeftConstraint, true); - } - else - { - m_data->m_ChainLeftBody->setActivationState(ACTIVE_TAG); - m_dynamicsWorld->removeConstraint(m_data->m_ChainLeftConstraint); - m_dynamicsWorld->addConstraint(m_data->m_ChainRightConstraint, true); - } - chainNextFrame = 3.0; - left = !left; - } - chainNextFrame -= m_data->mDt; - -/////// bouncing constraint: push the box periodically - m_data->m_BouncingTranslateBody->setActivationState(ACTIVE_TAG); - static float bounceNextFrame = -1; - if(bounceNextFrame < 0) - { - m_data->m_BouncingTranslateBody->applyCentralImpulse(btVector3(10,0,0)); - bounceNextFrame = 3.0; - } - bounceNextFrame -= m_data->mDt; - - m_data->frameID++; -} - - -void Dof6Spring2Setup::stepSimulation(float deltaTime) -{ - animate(); - m_dynamicsWorld->stepSimulation(deltaTime); -} diff --git a/Demos3/bullet2/ConstraintDemo/Dof6Spring2Setup.h b/Demos3/bullet2/ConstraintDemo/Dof6Spring2Setup.h deleted file mode 100644 index 00980c500..000000000 --- a/Demos3/bullet2/ConstraintDemo/Dof6Spring2Setup.h +++ /dev/null @@ -1,19 +0,0 @@ -#ifndef GENERIC_6DOF_SPRING2_CONSTRAINT_DEMO_H -#define GENERIC_6DOF_SPRING2_CONSTRAINT_DEMO_H - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -struct Dof6Spring2Setup : public CommonRigidBodySetup -{ - struct Dof6Spring2SetupInternalData* m_data; - - Dof6Spring2Setup(); - virtual ~Dof6Spring2Setup(); - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void stepSimulation(float deltaTime); - - void animate(); -}; - -#endif //GENERIC_6DOF_SPRING2_CONSTRAINT_DEMO_H diff --git a/Demos3/bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.cpp b/Demos3/bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.cpp deleted file mode 100644 index 48693b90a..000000000 --- a/Demos3/bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.cpp +++ /dev/null @@ -1,91 +0,0 @@ - - -#include "CoordinateFrameDemoPhysicsSetup.h" -#include "btBulletDynamicsCommon.h" -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Z 5 - - -bool showRigidBodyCenterOfMass = true; - -void CoordinateFrameDemoPhysicsSetup::debugDraw() -{ - /* - for (int i=0;igetCollisionObjectArray().size();i++) - { - const btCollisionObject* colObj = m_dynamicsWorld->getCollisionObjectArray()[i]; - if (showRigidBodyCenterOfMass) - { - m_dynamicsWorld->getDebugDrawer()->drawTransform(colObj->getWorldTransform(),1); - } - } - */ - - m_dynamicsWorld->debugDrawWorld(); -} - -void CoordinateFrameDemoPhysicsSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - createEmptyDynamicsWorld(); - m_dynamicsWorld->setGravity(btVector3(0,0,0)); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawWireframe+btIDebugDraw::DBG_DrawContactPoints); - - m_dynamicsWorld->getDebugDrawer()->setDebugMode(m_dynamicsWorld->getDebugDrawer()->getDebugMode() + btIDebugDraw::DBG_DrawFrames); - - btScalar sqr2 = btSqrt(2); - btVector3 tetraVerts[] = { - btVector3(1.f, 0.f, -1/sqr2), - btVector3(-1.f, 0.f, -1/sqr2), - btVector3(0, 1.f, 1/sqr2), - btVector3(0, -1.f, 1/sqr2), - }; - - - - { - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - btCompoundShape* hull = new btCompoundShape(); - btConvexHullShape* childHull = new btConvexHullShape(&tetraVerts[0].getX(),sizeof(tetraVerts)/sizeof(btVector3),sizeof(btVector3)); - - childHull->initializePolyhedralFeatures(); - btTransform childTrans; - childTrans.setIdentity(); - childTrans.setOrigin(btVector3(2,0,0)); - hull->addChildShape(childTrans,childHull); - gfxBridge.createCollisionShapeGraphicsObject(hull); - m_collisionShapes.push_back(hull); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - hull->calculateLocalInertia(mass,localInertia); - - - startTransform.setOrigin(btVector3(0,0,0)); - - btRigidBody* body = createRigidBody(mass,startTransform,hull); - gfxBridge.createRigidBodyGraphicsObject(body, btVector3(1, 1, 0)); - } - -} - - - - - - - - - - diff --git a/Demos3/bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.h b/Demos3/bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.h deleted file mode 100644 index 2e13e5232..000000000 --- a/Demos3/bullet2/CoordinateFrameDemo/CoordinateFrameDemoPhysicsSetup.h +++ /dev/null @@ -1,28 +0,0 @@ -#ifndef COORDINATE_FRAME_DEMO_PHYSICS_SETUP_H -#define COORDINATE_FRAME_DEMO_PHYSICS_SETUP_H - -class btRigidBody; -class btCollisionShape; -class btBroadphaseInterface; -class btConstraintSolver; -class btCollisionDispatcher; -class btDefaultCollisionConfiguration; -class btDiscreteDynamicsWorld; -class btTransform; -class btVector3; -class btBoxShape; -#include "LinearMath/btVector3.h" - -#include "LinearMath/btAlignedObjectArray.h" - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" - -struct CoordinateFrameDemoPhysicsSetup : public CommonRigidBodySetup -{ - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - virtual void debugDraw(); -}; - -#endif //COORDINATE_FRAME_DEMO_PHYSICS_SETUP_H diff --git a/Demos3/bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.cpp b/Demos3/bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.cpp deleted file mode 100644 index f2b9b0625..000000000 --- a/Demos3/bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.cpp +++ /dev/null @@ -1,1040 +0,0 @@ - - -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 -static float scaling = 1.f; -static float friction = 1.; - -#include "BulletMultiBodyDemos.h" - - -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "Bullet3Common/b3Vector3.h" -#include "assert.h" -#include - -#include "btBulletDynamicsCommon.h" - -#include "BulletDynamics/Featherstone/btMultiBody.h" -#include "BulletDynamics/Featherstone/btMultiBodyConstraintSolver.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/Featherstone/btMultiBodyLink.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointLimitConstraint.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointMotor.h" -#include "BulletDynamics/Featherstone/btMultiBodyPoint2Point.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "BulletCollision/CollisionShapes/btShapeHull.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" - -#define CONSTRAINT_DEBUG_SIZE 0.2f -static bool prevCanSleep = false; - - -static btVector4 colors[4] = -{ - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), -}; - - - -Bullet2MultiBodyDemo::Bullet2MultiBodyDemo(CommonGraphicsApp* app) -:m_glApp(app), -m_pickedBody(0), -m_pickedConstraint(0), -m_pickingMultiBodyPoint2Point(0) - -{ - app->setUpAxis(1); - m_collisionConfiguration = 0; - m_dispatcher = 0; - m_broadphase = 0; - m_solver = 0; - m_dynamicsWorld = 0; -} -void Bullet2MultiBodyDemo::initPhysics() -{ - m_collisionConfiguration = new btDefaultCollisionConfiguration; - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - m_broadphase = new btDbvtBroadphase(); - m_solver = new btMultiBodyConstraintSolver(); - m_dynamicsWorld = new btMultiBodyDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration); -} - -void Bullet2MultiBodyDemo::exitPhysics() -{ - delete m_dynamicsWorld; - m_dynamicsWorld=0; - delete m_solver; - m_solver=0; - delete m_broadphase; - m_broadphase=0; - delete m_dispatcher; - m_dispatcher=0; - delete m_collisionConfiguration; - m_collisionConfiguration=0; -} - -Bullet2MultiBodyDemo::~Bullet2MultiBodyDemo() -{ - btAssert(m_collisionConfiguration == 0); - btAssert(m_dispatcher == 0); - btAssert(m_broadphase == 0); - btAssert(m_solver == 0); - btAssert(m_dynamicsWorld == 0); -} - - - -btVector3 Bullet2MultiBodyDemo::getRayTo(int x,int y) -{ - if (!m_glApp->m_renderer) - { - btAssert(0); - return btVector3(0,0,0); - } - - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float tanFov = (top-bottom)*0.5f / nearPlane; - float fov = b3Scalar(2.0) * b3Atan(tanFov); - - btVector3 camPos,camTarget; - m_glApp->m_renderer->getCameraPosition(camPos); - m_glApp->m_renderer->getCameraTargetPosition(camTarget); - - btVector3 rayFrom = camPos; - btVector3 rayForward = (camTarget-camPos); - rayForward.normalize(); - float farPlane = 10000.f; - rayForward*= farPlane; - - btVector3 rightOffset; - btVector3 m_cameraUp=btVector3(0,1,0); - btVector3 vertical = m_cameraUp; - - btVector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - b3Scalar aspect; - float width = m_glApp->m_renderer->getScreenWidth(); - float height = m_glApp->m_renderer->getScreenHeight(); - - aspect = width / height; - - hor*=aspect; - - - btVector3 rayToCenter = rayFrom + rayForward; - btVector3 dHor = hor * 1.f/width; - btVector3 dVert = vertical * 1.f/height; - - - btVector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += btScalar(x) * dHor; - rayTo -= btScalar(y) * dVert; - return rayTo; -} - - -bool Bullet2MultiBodyDemo::mouseMoveCallback(float x,float y) -{ -// if (m_data->m_altPressed!=0 || m_data->m_controlPressed!=0) -// return false; - - if (m_pickedBody && m_pickedConstraint) - { - btPoint2PointConstraint* pickCon = static_cast(m_pickedConstraint); - if (pickCon) - { - //keep it at the same picking distance - btVector3 newRayTo = getRayTo(x,y); - btVector3 rayFrom; -// btVector3 oldPivotInB = pickCon->getPivotInB(); - btVector3 newPivotB; - m_glApp->m_renderer->getCameraPosition(rayFrom); - btVector3 dir = newRayTo-rayFrom; - dir.normalize(); - dir *= m_oldPickingDist; - - newPivotB = rayFrom + dir; - pickCon->setPivotB(newPivotB); - } - } - if (m_pickingMultiBodyPoint2Point) - { - //keep it at the same picking distance - - btVector3 newRayTo = getRayTo(x,y); - btVector3 rayFrom; - // btVector3 oldPivotInB = m_pickingMultiBodyPoint2Point->getPivotInB(); - btVector3 newPivotB; - btVector3 camPos; - m_glApp->m_renderer->getCameraPosition(camPos); - rayFrom = camPos; - btVector3 dir = newRayTo-rayFrom; - dir.normalize(); - dir *= m_oldPickingDist; - - newPivotB = rayFrom + dir; - - m_pickingMultiBodyPoint2Point->setPivotInB(newPivotB); - } - - return false; -} -bool Bullet2MultiBodyDemo::mouseButtonCallback(int button, int state, float x, float y) -{ - - if (state==1) - { - if(button==0)// && (m_data->m_altPressed==0 && m_data->m_controlPressed==0)) - { - btVector3 camPos; - m_glApp->m_renderer->getCameraPosition(camPos); - - btVector3 rayFrom = camPos; - btVector3 rayTo = getRayTo(x,y); - - btCollisionWorld::ClosestRayResultCallback rayCallback(rayFrom,rayTo); - m_dynamicsWorld->rayTest(rayFrom,rayTo,rayCallback); - if (rayCallback.hasHit()) - { - - btVector3 pickPos = rayCallback.m_hitPointWorld; - btRigidBody* body = (btRigidBody*)btRigidBody::upcast(rayCallback.m_collisionObject); - if (body) - { - //other exclusions? - if (!(body->isStaticObject() || body->isKinematicObject())) - { - m_pickedBody = body; - m_pickedBody->setActivationState(DISABLE_DEACTIVATION); - //printf("pickPos=%f,%f,%f\n",pickPos.getX(),pickPos.getY(),pickPos.getZ()); - btVector3 localPivot = body->getCenterOfMassTransform().inverse() * pickPos; - btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*body,localPivot); - m_dynamicsWorld->addConstraint(p2p,true); - m_pickedConstraint = p2p; - btScalar mousePickClamping = 10.f; - p2p->m_setting.m_impulseClamp = mousePickClamping; - //very weak constraint for picking - p2p->m_setting.m_tau = 0.001f; - } - } else - { - btMultiBodyLinkCollider* multiCol = (btMultiBodyLinkCollider*)btMultiBodyLinkCollider::upcast(rayCallback.m_collisionObject); - if (multiCol && multiCol->m_multiBody) - { - - prevCanSleep = multiCol->m_multiBody->getCanSleep(); - multiCol->m_multiBody->setCanSleep(false); - - btVector3 pivotInA = multiCol->m_multiBody->worldPosToLocal(multiCol->m_link, pickPos); - - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(multiCol->m_multiBody,multiCol->m_link,0,pivotInA,pickPos); - //if you add too much energy to the system, causing high angular velocities, simulation 'explodes' - //see also http://www.bulletphysics.org/Bullet/phpBB3/viewtopic.php?f=4&t=949 - //so we try to avoid it by clamping the maximum impulse (force) that the mouse pick can apply - //it is not satisfying, hopefully we find a better solution (higher order integrator, using joint friction using a zero-velocity target motor with limited force etc?) - - p2p->setMaxAppliedImpulse(2*scaling); - - btMultiBodyDynamicsWorld* world = (btMultiBodyDynamicsWorld*) m_dynamicsWorld; - world->addMultiBodyConstraint(p2p); - m_pickingMultiBodyPoint2Point =p2p; - } - } - - -// pickObject(pickPos, rayCallback.m_collisionObject); - m_oldPickingPos = rayTo; - m_hitPos = pickPos; - m_oldPickingDist = (pickPos-rayFrom).length(); -// printf("hit !\n"); - //add p2p - } - - } - } else - { - if (button==0) - { - if (m_pickedConstraint) - { - m_dynamicsWorld->removeConstraint(m_pickedConstraint); - delete m_pickedConstraint; - m_pickedConstraint=0; - m_pickedBody = 0; - } - - if (m_pickingMultiBodyPoint2Point) - { - m_pickingMultiBodyPoint2Point->getMultiBodyA()->setCanSleep(prevCanSleep); - btMultiBodyDynamicsWorld* world = (btMultiBodyDynamicsWorld*) m_dynamicsWorld; - world->removeMultiBodyConstraint(m_pickingMultiBodyPoint2Point); - delete m_pickingMultiBodyPoint2Point; - m_pickingMultiBodyPoint2Point = 0; - } - //remove p2p - } - } - - //printf("button=%d, state=%d\n",button,state); - return false; -} - - - - - - - - - - - - - -FeatherstoneDemo1::FeatherstoneDemo1(CommonGraphicsApp* app) -:Bullet2MultiBodyDemo(app) -{ -} -FeatherstoneDemo1::~FeatherstoneDemo1() -{ -} - - - -btMultiBody* FeatherstoneDemo1::createFeatherstoneMultiBody(class btMultiBodyDynamicsWorld* world, const btMultiBodySettings& settings) -{ - int curColor=0; - - - int cubeShapeId = m_glApp->registerCubeShape(1,1,1); - - int n_links = settings.m_numLinks; - float mass = 13.5*scaling; - btVector3 inertia = btVector3 (91,344,253)*scaling*scaling; - - - bool isMultiDof = false; - btMultiBody * bod = new btMultiBody(n_links, mass, inertia, settings.m_isFixedBase, settings.m_canSleep, isMultiDof); -// bod->setHasSelfCollision(false); - - //btQuaternion orn(btVector3(0,0,1),-0.25*SIMD_HALF_PI);//0,0,0,1); - btQuaternion orn(0,0,0,1); - bod->setBasePos(settings.m_basePosition); - bod->setWorldToBaseRot(orn); - btVector3 vel(0,0,0); - bod->setBaseVel(vel); - - { - - btVector3 joint_axis_hinge(1,0,0); - btVector3 joint_axis_prismatic(0,0,1); - btQuaternion parent_to_child = orn.inverse(); - btVector3 joint_axis_child_prismatic = quatRotate(parent_to_child ,joint_axis_prismatic); - btVector3 joint_axis_child_hinge = quatRotate(parent_to_child , joint_axis_hinge); - - int this_link_num = -1; - int link_num_counter = 0; - - - - btVector3 pos = btVector3 (0,0,9.0500002)*scaling; - - btVector3 joint_axis_position = btVector3 (0,0,4.5250001)*scaling; - - for (int i=0;i0) - initial_joint_angle = -0.06f; - - const int child_link_num = link_num_counter++; - - - - if (settings.m_usePrismatic)// && i==(n_links-1)) - { - bod->setupPrismatic(child_link_num, mass, inertia, this_link_num, - parent_to_child, joint_axis_child_prismatic, quatRotate(parent_to_child , pos),btVector3(0,0,0),settings.m_disableParentCollision); - - } else - { - bod->setupRevolute(child_link_num, mass, inertia, this_link_num,parent_to_child, joint_axis_child_hinge, - joint_axis_position,quatRotate(parent_to_child , (pos - joint_axis_position)),settings.m_disableParentCollision); - } - bod->setJointPos(child_link_num, initial_joint_angle); - this_link_num = i; - - if (0)//!useGroundShape && i==4) - { - btVector3 pivotInAworld(0,20,46); - btVector3 pivotInAlocal = bod->worldPosToLocal(i, pivotInAworld); - btVector3 pivotInBworld = pivotInAworld; - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(bod,i,&btTypedConstraint::getFixedBody(),pivotInAlocal,pivotInBworld); - world->addMultiBodyConstraint(p2p); - } - //add some constraint limit - if (settings.m_usePrismatic) - { - // btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,n_links-1,2,3); - - if (settings.m_createConstraints) - { - btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,i,-1,1); - world->addMultiBodyConstraint(con); - } - - } else - { - if (settings.m_createConstraints) - { - if (1) - { - btMultiBodyJointMotor* con = new btMultiBodyJointMotor(bod,i,0,0,500000); - world->addMultiBodyConstraint(con); - } - - btMultiBodyConstraint* con = new btMultiBodyJointLimitConstraint(bod,i,-1,1); - world->addMultiBodyConstraint(con); - } - - } - } - } - - //add a collider for the base - { - - btAlignedObjectArray world_to_local; - world_to_local.resize(n_links+1); - - btAlignedObjectArray local_origin; - local_origin.resize(n_links+1); - world_to_local[0] = bod->getWorldToBaseRot(); - local_origin[0] = bod->getBasePos(); - //float halfExtents[3]={7.5,0.05,4.5}; - btVector4 halfExtents(7.5,0.45,4.5,1); - { - - // float pos[4]={local_origin[0].x(),local_origin[0].y(),local_origin[0].z(),1}; - float quat[4]={-world_to_local[0].x(),-world_to_local[0].y(),-world_to_local[0].z(),world_to_local[0].w()}; - - - if (1) - { - btCollisionShape* box = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])*scaling); - btMultiBodyLinkCollider* col= new btMultiBodyLinkCollider(bod,-1); - - col->setCollisionShape(box); - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(local_origin[0]); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - - btVector4 color = colors[curColor++]; - curColor&=3; - - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,tr.getOrigin(),tr.getRotation(),color,halfExtents); - col->setUserIndex(index); - - - - - world->addCollisionObject(col,short(btBroadphaseProxy::DefaultFilter),short(btBroadphaseProxy::AllFilter)); - col->setFriction(friction); - bod->setBaseCollider(col); - - } - } - - - for (int i=0;igetNumLinks();i++) - { - const int parent = bod->getParent(i); - world_to_local[i+1] = bod->getParentToLocalRot(i) * world_to_local[parent+1]; - local_origin[i+1] = local_origin[parent+1] + (quatRotate(world_to_local[i+1].inverse() , bod->getRVector(i))); - } - - - for (int i=0;igetNumLinks();i++) - { - - btVector3 posr = local_origin[i+1]; - //float pos[4]={posr.x(),posr.y(),posr.z(),1}; - - float quat[4]={-world_to_local[i+1].x(),-world_to_local[i+1].y(),-world_to_local[i+1].z(),world_to_local[i+1].w()}; - - btCollisionShape* box = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])*scaling); - btMultiBodyLinkCollider* col = new btMultiBodyLinkCollider(bod,i); - - col->setCollisionShape(box); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(posr); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - col->setFriction(friction); - - - btVector4 color = colors[curColor++]; - curColor&=3; - - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,tr.getOrigin(),tr.getRotation(),color,halfExtents); - col->setUserIndex(index); - - - - world->addCollisionObject(col,short(btBroadphaseProxy::DefaultFilter),short(btBroadphaseProxy::AllFilter)); - - bod->getLink(i).m_collider=col; - //app->drawBox(halfExtents, pos,quat); - } - - } - world->addMultiBody(bod); - - return bod; -} - -void FeatherstoneDemo1::addColliders_testMultiDof(btMultiBody *pMultiBody, btMultiBodyDynamicsWorld *pWorld, const btVector3 &baseHalfExtents, const btVector3 &linkHalfExtents) -{ -} -void FeatherstoneDemo1::addBoxes_testMultiDof() -{ -} - -void FeatherstoneDemo1::createGround() -{ - //create ground - int cubeShapeId = m_glApp->registerCubeShape(1,1,1); - //float pos[]={0,0,0}; - //float orn[]={0,0,0,1}; - - - { - btVector4 color(0.3,0.3,1,1); - btVector4 halfExtents(50,50,50,1); - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,0)); - btBoxShape* groundShape = new btBoxShape(btVector3(btScalar(halfExtents[0]),btScalar(halfExtents[1]),btScalar(halfExtents[2]))); - //We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here: - { - btScalar mass(0.); - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,groundTransform.getOrigin(),groundTransform.getRotation(),color,halfExtents); - body ->setUserIndex(index); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body); - } - } -} - -void FeatherstoneDemo1::initPhysics() -{ - - Bullet2MultiBodyDemo::initPhysics(); - - createGround(); - - btMultiBodySettings settings; - settings.m_isFixedBase = false; - settings.m_basePosition.setValue(0,10,0); - settings.m_numLinks = 10; - //btMultiBody* mb = - createFeatherstoneMultiBody(m_dynamicsWorld,settings); - - - m_glApp->m_renderer->writeTransforms(); -} - - - -void FeatherstoneDemo1::exitPhysics() -{ - Bullet2MultiBodyDemo::exitPhysics(); -} - -void FeatherstoneDemo1::renderScene() -{ - //sync graphics -> physics world transforms - { - for (int i=0;igetNumCollisionObjects();i++) - { - btCollisionObject* col = m_dynamicsWorld->getCollisionObjectArray()[i]; - - btVector3 pos = col->getWorldTransform().getOrigin(); - btQuaternion orn = col->getWorldTransform().getRotation(); - int index = col->getUserIndex(); - if (index>=0) - { - m_glApp->m_renderer->writeSingleInstanceTransformToCPU(pos,orn,index); - } - } - m_glApp->m_renderer->writeTransforms(); - } - - m_glApp->m_renderer->renderScene(); -} - -void FeatherstoneDemo1::physicsDebugDraw(int debugDrawFlags) -{ - if (m_dynamicsWorld) - { - if (m_dynamicsWorld->getDebugDrawer()) - m_dynamicsWorld->getDebugDrawer()->setDebugMode(debugDrawFlags); - m_dynamicsWorld->debugDrawWorld(); - } -} - -void FeatherstoneDemo1::stepSimulation(float deltaTime) -{ - m_dynamicsWorld->stepSimulation(deltaTime);//,0); -// CProfileManager::dumpAll(); - /* - for (int i=0;igetDispatcher()->getNumManifolds();i++) - { - btPersistentManifold* contact = m_dynamicsWorld->getDispatcher()->getManifoldByIndexInternal(i); - for (int c=0;cgetNumContacts();c++) - { - btManifoldPoint& pt = contact->getContactPoint(c); - btScalar dist = pt.getDistance(); - if (dist< contact->getContactProcessingThreshold()) - { - printf("normalImpulse[%d.%d] = %f\n",i,c,pt.m_appliedImpulse); - - } else - { - printf("?\n"); - } - } - } - */ -} - - - -FeatherstoneDemo2::FeatherstoneDemo2(CommonGraphicsApp* app) -:FeatherstoneDemo1(app) -{ -} - -FeatherstoneDemo2::~FeatherstoneDemo2() -{ -} - - - -class RagDoll2 -{ - enum - { - BODYPART_PELVIS = 0, - BODYPART_SPINE, - BODYPART_HEAD, - - BODYPART_LEFT_UPPER_LEG, - BODYPART_LEFT_LOWER_LEG, - - BODYPART_RIGHT_UPPER_LEG, - BODYPART_RIGHT_LOWER_LEG, - - BODYPART_LEFT_UPPER_ARM, - BODYPART_LEFT_LOWER_ARM, - - BODYPART_RIGHT_UPPER_ARM, - BODYPART_RIGHT_LOWER_ARM, - - BODYPART_COUNT - }; - - enum - { - JOINT_PELVIS_SPINE = 0, - JOINT_SPINE_HEAD, - - JOINT_LEFT_HIP, - JOINT_LEFT_KNEE, - - JOINT_RIGHT_HIP, - JOINT_RIGHT_KNEE, - - JOINT_LEFT_SHOULDER, - JOINT_LEFT_ELBOW, - - JOINT_RIGHT_SHOULDER, - JOINT_RIGHT_ELBOW, - - JOINT_COUNT - }; - - btDynamicsWorld* m_ownerWorld; - btConvexShape* m_shapes[BODYPART_COUNT]; - btRigidBody* m_bodies[BODYPART_COUNT]; - btTypedConstraint* m_joints[JOINT_COUNT]; - SimpleOpenGL3App* m_app;//used to create graphics shapes - - btRigidBody* localCreateRigidBody (btScalar mass, const btTransform& startTransform, btConvexShape* shape, const btVector3& color=btVector3(1,0,0) ) - { - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,shape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - m_ownerWorld->addRigidBody(body); - - - btVector3 scaling(1,1,1); - - btShapeHull* hull = new btShapeHull(shape); - hull->buildHull(0.01); - - { - // int strideInBytes = 9*sizeof(float); - int numVertices = hull->numVertices(); - int numIndices =hull->numIndices(); - - btAlignedObjectArray gvertices; - - for (int i=0;igetVertexPointer()[i]; - vtx.xyzw[0] = pos.x(); - vtx.xyzw[1] = pos.y(); - vtx.xyzw[2] = pos.z(); - vtx.xyzw[3] = 1.f; - pos.normalize(); - vtx.normal[0] =pos.x(); - vtx.normal[1] =pos.y(); - vtx.normal[2] =pos.z(); - vtx.uv[0] = 0.5f; - vtx.uv[1] = 0.5f; - gvertices.push_back(vtx); - } - - btAlignedObjectArray indices; - for (int i=0;igetIndexPointer()[i]); - - int shapeId = m_app->m_instancingRenderer->registerShape(&gvertices[0].xyzw[0],numVertices,&indices[0],numIndices); - - int index = m_app->m_instancingRenderer->registerGraphicsInstance(shapeId,body->getWorldTransform().getOrigin(),body->getWorldTransform().getRotation(),color,scaling); - body ->setUserIndex(index); - } - delete hull; - - - - return body; - } - -public: - RagDoll2 (btDynamicsWorld* ownerWorld, const btVector3& positionOffset,SimpleOpenGL3App* app) - : m_ownerWorld (ownerWorld), - m_app(app) - { - - // Setup the geometry - m_shapes[BODYPART_PELVIS] = new btCapsuleShape(btScalar(0.15), btScalar(0.20)); - m_shapes[BODYPART_SPINE] = new btCapsuleShape(btScalar(0.15), btScalar(0.28)); - m_shapes[BODYPART_HEAD] = new btCapsuleShape(btScalar(0.10), btScalar(0.05)); - m_shapes[BODYPART_LEFT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07), btScalar(0.45)); - m_shapes[BODYPART_LEFT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05), btScalar(0.37)); - m_shapes[BODYPART_RIGHT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07), btScalar(0.45)); - m_shapes[BODYPART_RIGHT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05), btScalar(0.37)); - m_shapes[BODYPART_LEFT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05), btScalar(0.33)); - m_shapes[BODYPART_LEFT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04), btScalar(0.25)); - m_shapes[BODYPART_RIGHT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05), btScalar(0.33)); - m_shapes[BODYPART_RIGHT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04), btScalar(0.25)); - - - // Setup all the rigid bodies - btTransform offset; offset.setIdentity(); - offset.setOrigin(positionOffset); - - btTransform transform; - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.), btScalar(0.))); - //m_bodies[BODYPART_PELVIS] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_PELVIS], btVector3(0,1,0)); - - // btMultiBody * bod = new btMultiBody(n_links, mass, inertia, settings.m_isFixedBase, settings.m_canSleep); - int n_links = 0; - float mass = 1.f; - btVector3 localInertia; - m_shapes[BODYPART_PELVIS]->calculateLocalInertia(mass,localInertia); - - bool isFixedBase = true; - bool canSleep = true; - bool isMultiDof = false; - btMultiBody * bod = new btMultiBody(n_links, mass, localInertia, isFixedBase, canSleep, isMultiDof); - - btTransform tr; - tr = offset*transform; - - - bod->setBasePos(tr.getOrigin()); - bod->setWorldToBaseRot(tr.getRotation()); - btVector3 vel(0,0,0); - bod->setBaseVel(vel); - -#if 0 - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.2), btScalar(0.))); - m_bodies[BODYPART_SPINE] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_SPINE],btVector3(0,0,1)); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.6), btScalar(0.))); - m_bodies[BODYPART_HEAD] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_HEAD]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_LEFT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_LEFT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_RIGHT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_RIGHT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,M_PI_2); - m_bodies[BODYPART_LEFT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,M_PI_2); - m_bodies[BODYPART_LEFT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-M_PI_2); - m_bodies[BODYPART_RIGHT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-M_PI_2); - m_bodies[BODYPART_RIGHT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_ARM]); - - // Setup some damping on the m_bodies - for (int i = 0; i < BODYPART_COUNT; ++i) - { - m_bodies[i]->setDamping(0.05, 0.85); - m_bodies[i]->setDeactivationTime(0.8); - m_bodies[i]->setSleepingThresholds(1.6, 2.5); - } -#endif -#if 0 - // Now setup the constraints - btHingeConstraint* hingeC; - btConeTwistConstraint* coneC; - - btTransform localA, localB; - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.15), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_SPINE], localA, localB); - hingeC->setLimit(btScalar(-M_PI_4), btScalar(M_PI_2)); - m_joints[JOINT_PELVIS_SPINE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_PELVIS_SPINE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI_2); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.30), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_HEAD], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, M_PI_2); - m_joints[JOINT_SPINE_HEAD] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_SPINE_HEAD], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,-M_PI_4*5); localA.setOrigin(btVector3(btScalar(-0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,-M_PI_4*5); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_LEFT_UPPER_LEG], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, 0); - m_joints[JOINT_LEFT_HIP] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_LEG], *m_bodies[BODYPART_LEFT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_LEFT_KNEE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI_4); localA.setOrigin(btVector3(btScalar(0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_4); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_RIGHT_UPPER_LEG], localA, localB); - coneC->setLimit(M_PI_4, M_PI_4, 0); - m_joints[JOINT_RIGHT_HIP] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_LEG], *m_bodies[BODYPART_RIGHT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_RIGHT_KNEE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,M_PI); localA.setOrigin(btVector3(btScalar(-0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_LEFT_UPPER_ARM], localA, localB); - coneC->setLimit(M_PI_2, M_PI_2, 0); - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_joints[JOINT_LEFT_SHOULDER] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_ARM], *m_bodies[BODYPART_LEFT_LOWER_ARM], localA, localB); - // hingeC->setLimit(btScalar(-M_PI_2), btScalar(0)); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_LEFT_ELBOW] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_ELBOW], true); - - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,0); localA.setOrigin(btVector3(btScalar(0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,M_PI_2); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_RIGHT_UPPER_ARM], localA, localB); - coneC->setLimit(M_PI_2, M_PI_2, 0); - m_joints[JOINT_RIGHT_SHOULDER] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,M_PI_2,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,M_PI_2,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_ARM], *m_bodies[BODYPART_RIGHT_LOWER_ARM], localA, localB); - // hingeC->setLimit(btScalar(-M_PI_2), btScalar(0)); - hingeC->setLimit(btScalar(0), btScalar(M_PI_2)); - m_joints[JOINT_RIGHT_ELBOW] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_ELBOW], true); -#endif - - } - - virtual ~RagDoll2 () - { - //int i; - /* - // Remove all constraints - for ( i = 0; i < JOINT_COUNT; ++i) - { - m_ownerWorld->removeConstraint(m_joints[i]); - delete m_joints[i]; m_joints[i] = 0; - } - */ - /* - // Remove all bodies and shapes - for ( i = 0; i < BODYPART_COUNT; ++i) - { - m_ownerWorld->removeRigidBody(m_bodies[i]); - - delete m_bodies[i]->getMotionState(); - - delete m_bodies[i]; m_bodies[i] = 0; - delete m_shapes[i]; m_shapes[i] = 0; - } - */ - } -}; - - - -void FeatherstoneDemo2::initPhysics() -{ - Bullet2MultiBodyDemo::initPhysics(); - - createGround(); - -/* btMultiBodySettings settings; - settings.m_isFixedBase = false; - settings.m_basePosition.setValue(0,20,0); - settings.m_numLinks = 3; - settings.m_usePrismatic = true; - btMultiBody* mb = createFeatherstoneMultiBody(m_dynamicsWorld,settings); -*/ -// btVector3 offset(0,2,0); - //RagDoll2* doll = new RagDoll2(m_dynamicsWorld,offset,m_glApp); - - - m_glApp->m_renderer->writeTransforms(); -} - - - - - - diff --git a/Demos3/bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.h b/Demos3/bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.h deleted file mode 100644 index eb3a6aba7..000000000 --- a/Demos3/bullet2/FeatherstoneMultiBodyDemo/BulletMultiBodyDemos.h +++ /dev/null @@ -1,117 +0,0 @@ - -#ifndef BULLET_MULTI_BODY_DEMOS_H -#define BULLET_MULTI_BODY_DEMOS_H - -#include "LinearMath/btVector3.h" - -#include "Bullet3AppSupport/BulletDemoInterface.h" - -#include "LinearMath/btAlignedObjectArray.h" - -struct btMultiBodySettings -{ - btMultiBodySettings() - { - m_numLinks = 0; - m_basePosition.setZero(); - m_isFixedBase = true; - m_usePrismatic = false; - m_canSleep = true; - m_createConstraints = false; - m_disableParentCollision = false; - } - int m_numLinks; - btVector3 m_basePosition; - bool m_isFixedBase; - bool m_usePrismatic; - bool m_canSleep; - bool m_createConstraints; - bool m_disableParentCollision; -}; - -class Bullet2MultiBodyDemo : public BulletDemoInterface -{ -protected: - - CommonGraphicsApp* m_glApp; - - class btRigidBody* m_pickedBody; - class btTypedConstraint* m_pickedConstraint; - btVector3 m_oldPickingPos; - btVector3 m_hitPos; - btScalar m_oldPickingDist; - - class btMultiBodyPoint2Point* m_pickingMultiBodyPoint2Point; - - class btMultiBodyDynamicsWorld* m_dynamicsWorld; - class btCollisionDispatcher* m_dispatcher; - class btBroadphaseInterface* m_broadphase; - class btCollisionConfiguration* m_collisionConfiguration; - class btMultiBodyConstraintSolver* m_solver; - - btAlignedObjectArray m_collisionShapes; - //btAlignedObjectArray m_linkColliders; - -public: - Bullet2MultiBodyDemo(CommonGraphicsApp* app); - virtual void initPhysics(); - virtual void exitPhysics(); - virtual ~Bullet2MultiBodyDemo(); - btVector3 getRayTo(int x,int y); - virtual bool mouseMoveCallback(float x,float y); - virtual bool mouseButtonCallback(int button, int state, float x, float y); - virtual bool keyboardCallback(int key, int state) - { - return false; - } -}; - -class FeatherstoneDemo1 : public Bullet2MultiBodyDemo -{ - -public: - - FeatherstoneDemo1(CommonGraphicsApp* app); - virtual ~FeatherstoneDemo1(); - - - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - return new FeatherstoneDemo1(app); - } - - class btMultiBody* createFeatherstoneMultiBody(class btMultiBodyDynamicsWorld* world, const btMultiBodySettings& settings); - - void addColliders_testMultiDof(btMultiBody *pMultiBody, btMultiBodyDynamicsWorld *pWorld, const btVector3 &baseHalfExtents, const btVector3 &linkHalfExtents); - void addBoxes_testMultiDof(); - - void createGround(); - virtual void initPhysics(); - virtual void exitPhysics(); - virtual void renderScene(); - virtual void physicsDebugDraw(int debugDrawFlags); - - virtual void stepSimulation(float deltaTime); -}; - - -class FeatherstoneDemo2 : public FeatherstoneDemo1 -{ - -public: - - FeatherstoneDemo2(CommonGraphicsApp* app); - virtual ~FeatherstoneDemo2(); - - - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - return new FeatherstoneDemo2(app); - } - - virtual void initPhysics(); -}; - - -#endif //BULLET_MULTI_BODY_DEMOS_H - diff --git a/Demos3/bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.cpp b/Demos3/bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.cpp deleted file mode 100644 index db813c25e..000000000 --- a/Demos3/bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.cpp +++ /dev/null @@ -1,422 +0,0 @@ -#include "MultiDofDemo.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "btBulletDynamicsCommon.h" - -#include "BulletDynamics/Featherstone/btMultiBody.h" -#include "BulletDynamics/Featherstone/btMultiBodyConstraintSolver.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/Featherstone/btMultiBodyLink.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointLimitConstraint.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointMotor.h" -#include "BulletDynamics/Featherstone/btMultiBodyPoint2Point.h" - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "BulletCollision/CollisionShapes/btShapeHull.h" - -static bool g_firstInit = true; -static float scaling = 0.4f; -static float friction = 1.; -#define ARRAY_SIZE_X 5 -#define ARRAY_SIZE_Y 5 -#define ARRAY_SIZE_Z 5 - -//maximum number of objects (and allow user to shoot additional boxes) -#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024) - - -#define START_POS_X -5 -//#define START_POS_Y 12 -#define START_POS_Y 2 -#define START_POS_Z -3 - - - -MultiDofDemo::MultiDofDemo(CommonGraphicsApp* app) -:FeatherstoneDemo1(app) -{ - app->setUpAxis(1); -} -MultiDofDemo::~MultiDofDemo() -{ -} - -void MultiDofDemo::stepSimulation(float deltaTime) -{ - //use a smaller internal timestep, there are stability issues - float internalTimeStep = 1./240.f; - m_dynamicsWorld->stepSimulation(deltaTime,10,internalTimeStep); -// CProfileManager::dumpAll(); - /* - for (int i=0;igetDispatcher()->getNumManifolds();i++) - { - btPersistentManifold* contact = m_dynamicsWorld->getDispatcher()->getManifoldByIndexInternal(i); - for (int c=0;cgetNumContacts();c++) - { - btManifoldPoint& pt = contact->getContactPoint(c); - btScalar dist = pt.getDistance(); - if (dist< contact->getContactProcessingThreshold()) - { - printf("normalImpulse[%d.%d] = %f\n",i,c,pt.m_appliedImpulse); - - } else - { - printf("?\n"); - } - } - } - */ -} - - -void MultiDofDemo::initPhysics() -{ - - - - if(g_firstInit) - { - this->m_glApp->m_renderer->setCameraDistance(btScalar(10.*scaling)); - this->m_glApp->m_renderer->setCameraPitch(50); - g_firstInit = false; - } - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - //Use the btMultiBodyConstraintSolver for Featherstone btMultiBody support - btMultiBodyConstraintSolver* sol = new btMultiBodyConstraintSolver; - m_solver = sol; - - //use btMultiBodyDynamicsWorld for Featherstone btMultiBody support - btMultiBodyDynamicsWorld* world = new btMultiBodyDynamicsWorld(m_dispatcher,m_broadphase,sol,m_collisionConfiguration); - m_dynamicsWorld = world; -// m_dynamicsWorld->setDebugDrawer(&gDebugDraw); - - m_dynamicsWorld->setGravity(btVector3(0,-10,0)); - - ///create a few basic rigid bodies - btVector3 groundHalfExtents(50,50,50); - btCollisionShape* groundShape = new btBoxShape(groundHalfExtents); - //groundShape->initializePolyhedralFeatures(); -// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50); - - m_collisionShapes.push_back(groundShape); - - btTransform groundTransform; - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,-50,00)); - - ///////////////////////////////////////////////////////////////// - ///////////////////////////////////////////////////////////////// - bool floating = false; - bool damping = true; - bool gyro = true; - int numLinks = 5; - bool spherical = true; //set it ot false -to use 1DoF hinges instead of 3DoF sphericals - bool multibodyOnly = false; - bool canSleep = true; - bool selfCollide = false; - btVector3 linkHalfExtents(0.05, 0.37, 0.1); - btVector3 baseHalfExtents(0.05, 0.37, 0.1); - - btMultiBody* mbC = createFeatherstoneMultiBody_testMultiDof(world, numLinks, btVector3(-0.4f, 3.f, 0.f), linkHalfExtents, baseHalfExtents, spherical, floating); - //mbC->forceMultiDof(); //if !spherical, you can comment this line to check the 1DoF algorithm - - mbC->setCanSleep(canSleep); - mbC->setHasSelfCollision(selfCollide); - mbC->setUseGyroTerm(gyro); - // - if(!damping) - { - mbC->setLinearDamping(0.f); - mbC->setAngularDamping(0.f); - }else - { mbC->setLinearDamping(0.1f); - mbC->setAngularDamping(0.9f); - } - // - m_dynamicsWorld->setGravity(btVector3(0, -9.81 ,0)); - ////////////////////////////////////////////// - if(numLinks > 0) - { - btScalar q0 = 45.f * SIMD_PI/ 180.f; - if(!spherical) - if(mbC->isMultiDof()) - mbC->setJointPosMultiDof(0, &q0); - else - mbC->setJointPos(0, q0); - else - { - btQuaternion quat0(btVector3(1, 1, 0).normalized(), q0); - quat0.normalize(); - mbC->setJointPosMultiDof(0, quat0); - } - } - /// - addColliders_testMultiDof(mbC, world, baseHalfExtents, linkHalfExtents); - - int cubeShapeId = m_glApp->registerCubeShape(1,1,1); - ///////////////////////////////////////////////////////////////// - btScalar groundHeight = -51.55; - if (!multibodyOnly) - { - btScalar mass(0.); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - groundShape->calculateLocalInertia(mass,localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - groundTransform.setIdentity(); - groundTransform.setOrigin(btVector3(0,groundHeight,0)); - btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - //add the body to the dynamics world - m_dynamicsWorld->addRigidBody(body,1,1+2);//,1,1+2); - - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,groundTransform.getOrigin(),groundTransform.getRotation(),btVector4(0,1,0,1),groundHalfExtents); - body->setUserIndex(index); - - - - } - ///////////////////////////////////////////////////////////////// - if(!multibodyOnly) - { - btVector3 halfExtents(.5,.5,.5); - btBoxShape* colShape = new btBoxShape(halfExtents); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - startTransform.setOrigin(btVector3( - btScalar(0.0), - -0.95, - btScalar(0.0))); - - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,colShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - m_dynamicsWorld->addRigidBody(body);//,1,1+2); - - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,startTransform.getOrigin(),startTransform.getRotation(),btVector4(1,1,0,1),halfExtents); - body->setUserIndex(index); - - } - - m_glApp->m_renderer->writeTransforms(); - ///////////////////////////////////////////////////////////////// -} - - -btMultiBody* MultiDofDemo::createFeatherstoneMultiBody_testMultiDof(btMultiBodyDynamicsWorld *pWorld, int numLinks, const btVector3 &basePosition, const btVector3 &baseHalfExtents, const btVector3 &linkHalfExtents, bool spherical, bool floating) -{ - //init the base - btVector3 baseInertiaDiag(0.f, 0.f, 0.f); - float baseMass = 1.f; - - if(baseMass) - { - btCollisionShape *pTempBox = new btBoxShape(btVector3(baseHalfExtents[0], baseHalfExtents[1], baseHalfExtents[2])); - pTempBox->calculateLocalInertia(baseMass, baseInertiaDiag); - delete pTempBox; - } - - bool canSleep = false; - bool isMultiDof = true; - btMultiBody *pMultiBody = new btMultiBody(numLinks, baseMass, baseInertiaDiag, !floating, canSleep, isMultiDof); - - btQuaternion baseOriQuat(0.f, 0.f, 0.f, 1.f); - pMultiBody->setBasePos(basePosition); - pMultiBody->setWorldToBaseRot(baseOriQuat); - btVector3 vel(0, 0, 0); -// pMultiBody->setBaseVel(vel); - - //init the links - btVector3 hingeJointAxis(1, 0, 0); - float linkMass = 1.f; - btVector3 linkInertiaDiag(0.f, 0.f, 0.f); - - btCollisionShape *pTempBox = new btBoxShape(btVector3(linkHalfExtents[0], linkHalfExtents[1], linkHalfExtents[2])); - pTempBox->calculateLocalInertia(linkMass, linkInertiaDiag); - delete pTempBox; - - //y-axis assumed up - btVector3 parentComToCurrentCom(0, -linkHalfExtents[1] * 2.f, 0); //par body's COM to cur body's COM offset - btVector3 currentPivotToCurrentCom(0, -linkHalfExtents[1], 0); //cur body's COM to cur body's PIV offset - btVector3 parentComToCurrentPivot = parentComToCurrentCom - currentPivotToCurrentCom; //par body's COM to cur body's PIV offset - - ////// - btScalar q0 = 0.f * SIMD_PI/ 180.f; - btQuaternion quat0(btVector3(0, 1, 0).normalized(), q0); - quat0.normalize(); - ///// - - for(int i = 0; i < numLinks; ++i) - { - if(!spherical) - pMultiBody->setupRevolute(i, linkMass, linkInertiaDiag, i - 1, btQuaternion(0.f, 0.f, 0.f, 1.f), hingeJointAxis, parentComToCurrentPivot, currentPivotToCurrentCom, false); - else - //pMultiBody->setupPlanar(i, linkMass, linkInertiaDiag, i - 1, btQuaternion(0.f, 0.f, 0.f, 1.f)/*quat0*/, btVector3(1, 0, 0), parentComToCurrentPivot*2, false); - pMultiBody->setupSpherical(i, linkMass, linkInertiaDiag, i - 1, btQuaternion(0.f, 0.f, 0.f, 1.f), parentComToCurrentPivot, currentPivotToCurrentCom, false); - } - - pMultiBody->finalizeMultiDof(); - - /// - pWorld->addMultiBody(pMultiBody); - /// - return pMultiBody; -} - -void MultiDofDemo::addColliders_testMultiDof(btMultiBody *pMultiBody, btMultiBodyDynamicsWorld *pWorld, const btVector3 &baseHalfExtents, const btVector3 &linkHalfExtents) -{ - int cubeShapeId = m_glApp->registerCubeShape(1,1,1); - - btAlignedObjectArray world_to_local; - world_to_local.resize(pMultiBody->getNumLinks() + 1); - - btAlignedObjectArray local_origin; - local_origin.resize(pMultiBody->getNumLinks() + 1); - world_to_local[0] = pMultiBody->getWorldToBaseRot(); - local_origin[0] = pMultiBody->getBasePos(); - - { - - // float pos[4]={local_origin[0].x(),local_origin[0].y(),local_origin[0].z(),1}; - float quat[4]={-world_to_local[0].x(),-world_to_local[0].y(),-world_to_local[0].z(),world_to_local[0].w()}; - - - if (1) - { - btCollisionShape* box = new btBoxShape(baseHalfExtents); - btMultiBodyLinkCollider* col= new btMultiBodyLinkCollider(pMultiBody, -1); - col->setCollisionShape(box); - - btTransform tr; - tr.setIdentity(); - tr.setOrigin(local_origin[0]); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - - pWorld->addCollisionObject(col, 2,1+2); - - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,tr.getOrigin(),tr.getRotation(),btVector4(0,0,1,1),baseHalfExtents); - col->setUserIndex(index); - - - col->setFriction(friction); - pMultiBody->setBaseCollider(col); - - } - } - - - for (int i=0; i < pMultiBody->getNumLinks(); ++i) - { - const int parent = pMultiBody->getParent(i); - world_to_local[i+1] = pMultiBody->getParentToLocalRot(i) * world_to_local[parent+1]; - local_origin[i+1] = local_origin[parent+1] + (quatRotate(world_to_local[i+1].inverse() , pMultiBody->getRVector(i))); - } - - - for (int i=0; i < pMultiBody->getNumLinks(); ++i) - { - - btVector3 posr = local_origin[i+1]; - // float pos[4]={posr.x(),posr.y(),posr.z(),1}; - - float quat[4]={-world_to_local[i+1].x(),-world_to_local[i+1].y(),-world_to_local[i+1].z(),world_to_local[i+1].w()}; - - btCollisionShape* box = new btBoxShape(linkHalfExtents); - btMultiBodyLinkCollider* col = new btMultiBodyLinkCollider(pMultiBody, i); - - col->setCollisionShape(box); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(posr); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - col->setFriction(friction); - pWorld->addCollisionObject(col,2,1+2); - int index = m_glApp->m_renderer->registerGraphicsInstance(cubeShapeId,tr.getOrigin(),tr.getRotation(),btVector4(0,0,1,1),linkHalfExtents); - col->setUserIndex(index); - - - pMultiBody->getLink(i).m_collider=col; - } -} - -void MultiDofDemo::addBoxes_testMultiDof() -{ - //create a few dynamic rigidbodies - // Re-using the same collision is better for memory usage and performance - - btBoxShape* colShape = new btBoxShape(btVector3(1,1,1)); - //btCollisionShape* colShape = new btSphereShape(btScalar(1.)); - m_collisionShapes.push_back(colShape); - - /// Create Dynamic Objects - btTransform startTransform; - startTransform.setIdentity(); - - btScalar mass(1.f); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - colShape->calculateLocalInertia(mass,localInertia); - - float start_x = START_POS_X - ARRAY_SIZE_X/2; - float start_y = START_POS_Y; - float start_z = START_POS_Z - ARRAY_SIZE_Z/2; - - for (int k=0;kaddRigidBody(body);//,1,1+2); - } - } - } -} diff --git a/Demos3/bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.h b/Demos3/bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.h deleted file mode 100644 index 24ece22e7..000000000 --- a/Demos3/bullet2/FeatherstoneMultiBodyDemo/MultiDofDemo.h +++ /dev/null @@ -1,34 +0,0 @@ - -#ifndef MULTI_DOF_DEMO_H -#define MULTI_DOF_DEMO_H - -#include "BulletMultiBodyDemos.h" - -class MultiDofDemo : public FeatherstoneDemo1 -{ - -public: - - MultiDofDemo(CommonGraphicsApp* app); - virtual ~MultiDofDemo(); - - - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - return new MultiDofDemo(app); - } - - virtual void initPhysics(); - - virtual void stepSimulation(float deltaTime); - - - btMultiBody* createFeatherstoneMultiBody_testMultiDof(class btMultiBodyDynamicsWorld* world, int numLinks, const btVector3& basePosition, const btVector3 &baseHalfExtents, const btVector3 &linkHalfExtents, bool spherical = false, bool floating = false); - void addColliders_testMultiDof(btMultiBody *pMultiBody, btMultiBodyDynamicsWorld *pWorld, const btVector3 &baseHalfExtents, const btVector3 &linkHalfExtents); - void addBoxes_testMultiDof(); - - -}; - -#endif //MULTI_DOF_DEMO_H - diff --git a/Demos3/bullet2/LuaDemo/LuaDemo.cpp b/Demos3/bullet2/LuaDemo/LuaDemo.cpp deleted file mode 100644 index 584542796..000000000 --- a/Demos3/bullet2/LuaDemo/LuaDemo.cpp +++ /dev/null @@ -1,499 +0,0 @@ -#include "LuaDemo.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btVector3.h" -#include - -#include "BulletDynamics/ConstraintSolver/btNNCGConstraintSolver.h" - -extern "C" { - #include "lua.h" - #include "lualib.h" -#include "lauxlib.h" -} - - -char* sLuaFileName = "init_physics.lua"; - -static const float scaling=0.35f; -static LuaDemo* sLuaDemo = 0; - -static btVector4 colors[4] = -{ - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), -}; - -//todo: allow to create solver, broadphase, multiple worlds etc. -static int createDefaultDynamicsWorld(lua_State *L) -{ - sLuaDemo->m_config = new btDefaultCollisionConfiguration; - sLuaDemo->m_dispatcher = new btCollisionDispatcher(sLuaDemo->m_config); - sLuaDemo->m_bp = new btDbvtBroadphase(); - sLuaDemo->m_solver = new btNNCGConstraintSolver(); - sLuaDemo->m_dynamicsWorld = new btDiscreteDynamicsWorld(sLuaDemo->m_dispatcher,sLuaDemo->m_bp,sLuaDemo->m_solver,sLuaDemo->m_config); - lua_pushlightuserdata (L, sLuaDemo->m_dynamicsWorld); - return 1; -} - - -static int deleteDynamicsWorld(lua_State *L) -{ - return 0; -} - -ATTRIBUTE_ALIGNED16(struct) CustomShapeData -{ - btVector3 m_localScaling; - int m_shapeIndex; - - -}; - - -ATTRIBUTE_ALIGNED16(struct) CustomRigidBodyData -{ - int m_graphicsInstanceIndex; -}; - -static int createCubeShape(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==4) - { - btVector3 halfExtents(1,1,1); - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument to createCubeShape should be world"; - return 0; - } - //expect userdata = sLuaDemo->m_dynamicsWorld - halfExtents = btVector3(lua_tonumber(L,2),lua_tonumber(L,3),lua_tonumber(L,4)); - btCollisionShape* colShape = new btBoxShape(halfExtents); - - CustomShapeData* shapeData = new CustomShapeData(); - shapeData->m_shapeIndex = sLuaDemo->m_glApp->registerCubeShape(); - shapeData->m_localScaling = halfExtents; - - colShape->setUserPointer(shapeData); - lua_pushlightuserdata (L, colShape); - return 1; - } else - { - std::cerr << "Error: invalid number of arguments to createCubeShape, expected 4 (world,halfExtentsX,halfExtentsY,halfExtentsX) but got " << argc; - } - return 0; -} - -static int createSphereShape(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==2) - { - btVector3 halfExtents(1,1,1); - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument to createSphereShape should be world"; - return 0; - } - //expect userdata = sLuaDemo->m_dynamicsWorld - btScalar radius = lua_tonumber(L,2); - btCollisionShape* colShape = new btSphereShape(radius); - - CustomShapeData* shapeData = new CustomShapeData(); - shapeData->m_shapeIndex = sLuaDemo->m_glApp->registerGraphicsSphereShape(radius,false,100,0.5); - shapeData->m_localScaling = halfExtents; - - colShape->setUserPointer(shapeData); - lua_pushlightuserdata (L, colShape); - return 1; - } else - { - std::cerr << "Error: invalid number of arguments to createSphereShape, expected 2 (world,radius) but got " << argc; - } - return 0; -} - -int luaL_returnlen(lua_State* L, int index) -{ - lua_len(L, index); - int len = lua_tointeger(L,-1); - lua_pop(L, 1); - return len; -} - -btVector3 getLuaVectorArg(lua_State* L, int index) -{ - btVector3 pos(0,0,0); - - int sz = luaL_returnlen(L, index); // get size of table - { - lua_rawgeti(L, index, 1); // push t[i] - pos[0] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 2); // push t[i] - pos[1] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 3); // push t[i] - pos[2] = lua_tonumber(L,-1); - lua_pop(L, 1); - } - return pos; -} - -btQuaternion getLuaQuaternionArg(lua_State* L, int index) -{ - btQuaternion orn(0,0,0,1); - - int sz = luaL_returnlen(L, index); // get size of table - { - lua_rawgeti(L, index, 1); // push t[i] - orn[0] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 2); // push t[i] - orn[1] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 3); // push t[i] - orn[2] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 4); // push t[i] - orn[3] = lua_tonumber(L,-1); - lua_pop(L, 1); - } - return orn; -} - - - - -static int createRigidBody (lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==5) - { - - btTransform startTransform; - startTransform.setIdentity(); - - - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument to b3CreateRigidbody should be world"; - return 0; - } - btDiscreteDynamicsWorld* world = (btDiscreteDynamicsWorld*) lua_touserdata(L,1); - if (world != sLuaDemo->m_dynamicsWorld) - { - std::cerr << "error: first argument expected to be a world"; - return 0; - } - - if (!lua_isuserdata(L,2)) - { - std::cerr << "error: second argument to b3CreateRigidbody should be world"; - return 0; - } - - btScalar mass = lua_tonumber(L,3); - - luaL_checktype(L,4, LUA_TTABLE); - - btVector3 pos = getLuaVectorArg(L,4); - - btQuaternion orn = getLuaQuaternionArg(L,5); - - btCollisionShape* colShape = (btCollisionShape* )lua_touserdata(L,2); - //expect userdata = sLuaDemo->m_dynamicsWorld - - btVector3 inertia(0,0,0); - if (mass) - { - colShape->calculateLocalInertia(mass,inertia); - } - - - - btRigidBody* body = new btRigidBody(mass,0,colShape,inertia); - body->getWorldTransform().setOrigin(pos); - body->getWorldTransform().setRotation(orn); - - - CustomShapeData* shapeData = (CustomShapeData*)colShape->getUserPointer(); - if (shapeData) - { - CustomRigidBodyData* rbd = new CustomRigidBodyData; - static int curColor = 0; - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - - CustomShapeData* shapeData = (CustomShapeData*)body->getCollisionShape()->getUserPointer(); - if (shapeData) - { - - rbd ->m_graphicsInstanceIndex = sLuaDemo->m_glApp->m_instancingRenderer->registerGraphicsInstance(shapeData->m_shapeIndex,startTransform.getOrigin(),startTransform.getRotation(),color,shapeData->m_localScaling); - body->setUserPointer(rbd); - } - } - - world->addRigidBody(body); - lua_pushlightuserdata (L, body); - return 1; - } else - { - std::cerr << "Error: invalid number of arguments to createRigidBody, expected 5 (world,shape,mass,pos,orn) but got " << argc; - } - return 0; -} - -static int setBodyPosition(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==3) - { - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument needs to be a world"; - return 0; - } - if (!lua_isuserdata(L,2)) - { - std::cerr << "error: second argument needs to be a body"; - return 0; - } - btRigidBody* body = (btRigidBody*)lua_touserdata(L,2); - btVector3 pos = getLuaVectorArg(L,3); - - btTransform& tr = body ->getWorldTransform(); - tr.setOrigin(pos); - body->setWorldTransform(tr); - } else - { - std::cerr << "error: setBodyPosition expects 6 arguments like setBodyPosition(world,body,0,1,0)"; - } - return 0; -} - -static int setBodyOrientation(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==3) - { - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument needs to be a world"; - return 0; - } - if (!lua_isuserdata(L,2)) - { - std::cerr << "error: second argument needs to be a body"; - return 0; - } - btRigidBody* body = (btRigidBody*)lua_touserdata(L,2); - btQuaternion orn = getLuaQuaternionArg(L,3); - btTransform& tr = body ->getWorldTransform(); - tr.setRotation(orn); - body->setWorldTransform(tr); - } else - { - std::cerr << "error: setBodyOrientation expects 3 arguments like setBodyOrientation(world,body,orn)"; - } - return 0; -} - -//b3CreateConvexShape(world, points) - -//b3CreateHingeConstraint(world,bodyA,bodyB,...) - - - - - -LuaDemo::LuaDemo(SimpleOpenGL3App* app) -:Bullet2RigidBodyDemo(app) -{ - sLuaDemo = this; -} - -LuaDemo::~LuaDemo() -{ - sLuaDemo = 0; -} - -static void report_errors(lua_State *L, int status) -{ - if ( status!=0 ) { - std::cerr << "-- " << lua_tostring(L, -1) << std::endl; - lua_pop(L, 1); // remove error message - } -} - - -void LuaDemo::initPhysics() -{ - - - const char* prefix[]={"./","./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - FILE* f=0; - int result = 0; - - for (int i=0;!f && iregisterCubeShape(); - float pos[]={0,0,0}; - float orn[]={0,0,0,1}; - - - - - { - float halfExtents[]={scaling,scaling,scaling,1}; - btVector4 colors[4] = - { - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), - }; - - - - btTransform startTransform; - startTransform.setIdentity(); - btScalar mass = 1.f; - btVector3 localInertia; - btBoxShape* colShape = new btBoxShape(btVector3(halfExtents[0],halfExtents[1],halfExtents[2])); - colShape ->calculateLocalInertia(mass,localInertia); - - for (int k=0;k<3;k++) - { - for (int i=0;i<3;i++) - { - for(int j = 0;j<3;j++) - { - - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - startTransform.setOrigin(btVector3( - btScalar(2.0*scaling*i), - btScalar(2.*scaling+2.0*scaling*k), - btScalar(2.0*scaling*j))); - - m_glApp->m_instancingRenderer->registerGraphicsInstance(cubeShapeId,startTransform.getOrigin(),startTransform.getRotation(),color,halfExtents); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,colShape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - - m_dynamicsWorld->addRigidBody(body); - } - } - } - } -#endif - - m_glApp->m_instancingRenderer->writeTransforms(); -} -void LuaDemo::exitPhysics() -{ - //todo: delete bodies, shapes, constraints - - if (m_dynamicsWorld) - { - delete m_dynamicsWorld; - m_dynamicsWorld=0; - delete m_solver; - m_solver=0; - delete m_bp; - m_bp=0; - delete m_dispatcher; - m_dispatcher=0; - delete m_config; - m_config=0; - } -} -void LuaDemo::renderScene() -{ - //sync graphics -> physics world transforms - if (m_dynamicsWorld) - { - for (int i=0;igetNumCollisionObjects();i++) - { - btVector3 pos = m_dynamicsWorld->getCollisionObjectArray()[i]->getWorldTransform().getOrigin(); - btQuaternion orn = m_dynamicsWorld->getCollisionObjectArray()[i]->getWorldTransform().getRotation(); - if (m_dynamicsWorld->getCollisionObjectArray()[i]->getUserPointer()) - { - CustomRigidBodyData* rbd = (CustomRigidBodyData*)m_dynamicsWorld->getCollisionObjectArray()[i]->getUserPointer(); - - - m_glApp->m_instancingRenderer->writeSingleInstanceTransformToCPU(pos,orn,rbd->m_graphicsInstanceIndex); - } - } - m_glApp->m_instancingRenderer->writeTransforms(); - } - - m_glApp->m_instancingRenderer->renderScene(); -} - - -void LuaDemo::stepSimulation(float dt) -{ - if (m_dynamicsWorld) - m_dynamicsWorld->stepSimulation(dt); -} - - - diff --git a/Demos3/bullet2/LuaDemo/LuaDemo.h b/Demos3/bullet2/LuaDemo/LuaDemo.h deleted file mode 100644 index f3f03d096..000000000 --- a/Demos3/bullet2/LuaDemo/LuaDemo.h +++ /dev/null @@ -1,29 +0,0 @@ -#ifndef LUA_DEMO_H -#define LUA_DEMO_H - -#include "LinearMath/btVector3.h" -#include "../BasicDemo/Bullet2RigidBodyDemo.h" - - -//We use a struct instead of class, to make it easier to interface with Lua -struct LuaDemo : public Bullet2RigidBodyDemo -{ - -public: - - static BulletDemoInterface* MyCreateFunc(SimpleOpenGL3App* app) - { - return new LuaDemo(app); - } - - LuaDemo(SimpleOpenGL3App* app); - virtual ~LuaDemo(); - - virtual void initPhysics(); - virtual void exitPhysics(); - virtual void renderScene(); - virtual void stepSimulation(float dt); -}; - - -#endif //BASIC_DEMO_H diff --git a/Demos3/bullet2/LuaDemo/LuaPhysicsSetup.cpp b/Demos3/bullet2/LuaDemo/LuaPhysicsSetup.cpp deleted file mode 100644 index 5b3a756e6..000000000 --- a/Demos3/bullet2/LuaDemo/LuaPhysicsSetup.cpp +++ /dev/null @@ -1,474 +0,0 @@ -#include "LuaPhysicsSetup.h" - -#include "OpenGLWindow/SimpleOpenGL3App.h"//?? -#include "btBulletDynamicsCommon.h" -#include "LinearMath/btVector3.h" -#include - -#include "BulletDynamics/ConstraintSolver/btNNCGConstraintSolver.h" - -extern "C" { - #include "lua.h" - #include "lualib.h" -#include "lauxlib.h" -} - - -const char* sLuaFileName = "init_physics.lua"; - -static const float scaling=0.35f; -static LuaPhysicsSetup* sLuaDemo = 0; - -static btVector4 colors[4] = -{ - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), -}; - -LuaPhysicsSetup::LuaPhysicsSetup(struct CommonGraphicsApp* app) -:m_glApp(app), -m_config(0), -m_dispatcher(0), -m_bp(0), -m_solver(0), -m_dynamicsWorld(0) -{ - app->setUpAxis(1); - sLuaDemo = this; -} - -LuaPhysicsSetup::~LuaPhysicsSetup() -{ - sLuaDemo = 0; -} - - - -//todo: allow to create solver, broadphase, multiple worlds etc. -static int gCreateDefaultDynamicsWorld(lua_State *L) -{ - sLuaDemo->m_config = new btDefaultCollisionConfiguration; - sLuaDemo->m_dispatcher = new btCollisionDispatcher(sLuaDemo->m_config); - sLuaDemo->m_bp = new btDbvtBroadphase(); - sLuaDemo->m_solver = new btNNCGConstraintSolver(); - sLuaDemo->m_dynamicsWorld = new btDiscreteDynamicsWorld(sLuaDemo->m_dispatcher,sLuaDemo->m_bp,sLuaDemo->m_solver,sLuaDemo->m_config); - lua_pushlightuserdata (L, sLuaDemo->m_dynamicsWorld); - return 1; -} - - -static int gDeleteDynamicsWorld(lua_State *L) -{ - return 0; -} - -ATTRIBUTE_ALIGNED16(struct) CustomShapeData -{ - btVector3 m_localScaling; - int m_shapeIndex; - - -}; - - -ATTRIBUTE_ALIGNED16(struct) CustomRigidBodyData -{ - int m_graphicsInstanceIndex; -}; - -static int gCreateCubeShape(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==4) - { - btVector3 halfExtents(1,1,1); - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument to createCubeShape should be world"; - return 0; - } - //expect userdata = sLuaDemo->m_dynamicsWorld - halfExtents = btVector3(lua_tonumber(L,2),lua_tonumber(L,3),lua_tonumber(L,4)); - btCollisionShape* colShape = new btBoxShape(halfExtents); - - CustomShapeData* shapeData = new CustomShapeData(); - shapeData->m_shapeIndex = sLuaDemo->m_glApp->registerCubeShape(1,1,1); - shapeData->m_localScaling = halfExtents; - - colShape->setUserPointer(shapeData); - lua_pushlightuserdata (L, colShape); - return 1; - } else - { - std::cerr << "Error: invalid number of arguments to createCubeShape, expected 4 (world,halfExtentsX,halfExtentsY,halfExtentsX) but got " << argc; - } - return 0; -} - -static int gCreateSphereShape(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==2) - { - btVector3 halfExtents(1,1,1); - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument to createSphereShape should be world"; - return 0; - } - //expect userdata = sLuaDemo->m_dynamicsWorld - btScalar radius = lua_tonumber(L,2); - btCollisionShape* colShape = new btSphereShape(radius); - - CustomShapeData* shapeData = new CustomShapeData(); - shapeData->m_shapeIndex = sLuaDemo->m_glApp->registerGraphicsSphereShape(radius,false,100,0.5); - shapeData->m_localScaling = halfExtents; - - colShape->setUserPointer(shapeData); - lua_pushlightuserdata (L, colShape); - return 1; - } else - { - std::cerr << "Error: invalid number of arguments to createSphereShape, expected 2 (world,radius) but got " << argc; - } - return 0; -} - -int luaL_returnlen(lua_State* L, int index) -{ - lua_len(L, index); - int len = lua_tointeger(L,-1); - lua_pop(L, 1); - return len; -} - -btVector3 getLuaVectorArg(lua_State* L, int index) -{ - btVector3 pos(0,0,0); - - int sz = luaL_returnlen(L, index); // get size of table - { - lua_rawgeti(L, index, 1); // push t[i] - pos[0] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 2); // push t[i] - pos[1] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 3); // push t[i] - pos[2] = lua_tonumber(L,-1); - lua_pop(L, 1); - } - return pos; -} - -btQuaternion getLuaQuaternionArg(lua_State* L, int index) -{ - btQuaternion orn(0,0,0,1); - - int sz = luaL_returnlen(L, index); // get size of table - { - lua_rawgeti(L, index, 1); // push t[i] - orn[0] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 2); // push t[i] - orn[1] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 3); // push t[i] - orn[2] = lua_tonumber(L,-1); - lua_pop(L, 1); - lua_rawgeti(L, index, 4); // push t[i] - orn[3] = lua_tonumber(L,-1); - lua_pop(L, 1); - } - return orn; -} - - - - -static int gCreateRigidBody (lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==5) - { - - btTransform startTransform; - startTransform.setIdentity(); - - - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument to b3CreateRigidbody should be world"; - return 0; - } - btDiscreteDynamicsWorld* world = (btDiscreteDynamicsWorld*) lua_touserdata(L,1); - if (world != sLuaDemo->m_dynamicsWorld) - { - std::cerr << "error: first argument expected to be a world"; - return 0; - } - - if (!lua_isuserdata(L,2)) - { - std::cerr << "error: second argument to b3CreateRigidbody should be world"; - return 0; - } - - btScalar mass = lua_tonumber(L,3); - - luaL_checktype(L,4, LUA_TTABLE); - - btVector3 pos = getLuaVectorArg(L,4); - - btQuaternion orn = getLuaQuaternionArg(L,5); - - btCollisionShape* colShape = (btCollisionShape* )lua_touserdata(L,2); - //expect userdata = sLuaDemo->m_dynamicsWorld - - btVector3 inertia(0,0,0); - if (mass) - { - colShape->calculateLocalInertia(mass,inertia); - } - - - - btRigidBody* body = new btRigidBody(mass,0,colShape,inertia); - body->getWorldTransform().setOrigin(pos); - body->getWorldTransform().setRotation(orn); - - - CustomShapeData* shapeData = (CustomShapeData*)colShape->getUserPointer(); - if (shapeData) - { - CustomRigidBodyData* rbd = new CustomRigidBodyData; - static int curColor = 0; - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - - CustomShapeData* shapeData = (CustomShapeData*)body->getCollisionShape()->getUserPointer(); - if (shapeData) - { - - rbd ->m_graphicsInstanceIndex = sLuaDemo->m_glApp->m_renderer->registerGraphicsInstance(shapeData->m_shapeIndex,startTransform.getOrigin(),startTransform.getRotation(),color,shapeData->m_localScaling); - body->setUserIndex(rbd->m_graphicsInstanceIndex); - } - } - - world->addRigidBody(body); - lua_pushlightuserdata (L, body); - return 1; - } else - { - std::cerr << "Error: invalid number of arguments to createRigidBody, expected 5 (world,shape,mass,pos,orn) but got " << argc; - } - return 0; -} - -static int gSetBodyPosition(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==3) - { - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument needs to be a world"; - return 0; - } - if (!lua_isuserdata(L,2)) - { - std::cerr << "error: second argument needs to be a body"; - return 0; - } - btRigidBody* body = (btRigidBody*)lua_touserdata(L,2); - btVector3 pos = getLuaVectorArg(L,3); - - btTransform& tr = body ->getWorldTransform(); - tr.setOrigin(pos); - body->setWorldTransform(tr); - } else - { - std::cerr << "error: setBodyPosition expects 6 arguments like setBodyPosition(world,body,0,1,0)"; - } - return 0; -} - -static int gSetBodyOrientation(lua_State *L) -{ - int argc = lua_gettop(L); - if (argc==3) - { - if (!lua_isuserdata(L,1)) - { - std::cerr << "error: first argument needs to be a world"; - return 0; - } - if (!lua_isuserdata(L,2)) - { - std::cerr << "error: second argument needs to be a body"; - return 0; - } - btRigidBody* body = (btRigidBody*)lua_touserdata(L,2); - btQuaternion orn = getLuaQuaternionArg(L,3); - btTransform& tr = body ->getWorldTransform(); - tr.setRotation(orn); - body->setWorldTransform(tr); - } else - { - std::cerr << "error: setBodyOrientation expects 3 arguments like setBodyOrientation(world,body,orn)"; - } - return 0; -} - -//b3CreateConvexShape(world, points) - -//b3CreateHingeConstraint(world,bodyA,bodyB,...) - -static void report_errors(lua_State *L, int status) -{ - if ( status!=0 ) { - std::cerr << "-- " << lua_tostring(L, -1) << std::endl; - lua_pop(L, 1); // remove error message - } -} - - - -void LuaPhysicsSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - const char* prefix[]={"./","./data/","../data/","../../data/","../../../data/","../../../../data/"}; - int numPrefixes = sizeof(prefix)/sizeof(const char*); - char relativeFileName[1024]; - FILE* f=0; - int result = 0; - - for (int i=0;!f && im_renderer->writeTransforms(); -} - - -void LuaPhysicsSetup::exitPhysics() -{ - delete m_dynamicsWorld; - m_dynamicsWorld=0; - delete m_dispatcher; - m_dispatcher=0; - delete m_bp; - m_bp=0; - delete m_config; - m_config=0; -} - -void LuaPhysicsSetup::stepSimulation(float deltaTime) -{ - if (m_dynamicsWorld) - m_dynamicsWorld->stepSimulation(deltaTime); - -} - -void LuaPhysicsSetup::debugDraw(int debugDrawFlags) -{ - if (m_dynamicsWorld) - { - if (m_dynamicsWorld->getDebugDrawer()) - { - m_dynamicsWorld->getDebugDrawer()->setDebugMode(debugDrawFlags); - } - m_dynamicsWorld->debugDrawWorld(); - } - -} - -bool LuaPhysicsSetup::pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) -{ -//btAssert(0); -return false; -} -bool LuaPhysicsSetup::movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) -{ -//btAssert(0); -return false; - -} -void LuaPhysicsSetup::removePickingConstraint() -{ -//btAssert(0); - -} - -void LuaPhysicsSetup::syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge) -{ - int numCollisionObjects = m_dynamicsWorld->getNumCollisionObjects(); - for (int i = 0; igetCollisionObjectArray()[i]; - btVector3 pos = colObj->getWorldTransform().getOrigin(); - btQuaternion orn = colObj->getWorldTransform().getRotation(); - int index = colObj->getUserIndex(); - if (index >= 0) - { - m_glApp->m_renderer->writeSingleInstanceTransformToCPU(pos, orn, index); - } - } - m_glApp->m_renderer->writeTransforms(); -} - -btRigidBody* LuaPhysicsSetup::createRigidBody(float mass, const btTransform& startTransform,btCollisionShape* shape, const btVector4& color) -{ -btAssert(0); -return 0; - -} - -btBoxShape* LuaPhysicsSetup::createBoxShape(const btVector3& halfExtents) -{ -btAssert(0); -return 0; -} diff --git a/Demos3/bullet2/LuaDemo/LuaPhysicsSetup.h b/Demos3/bullet2/LuaDemo/LuaPhysicsSetup.h deleted file mode 100644 index 6bf152d1d..000000000 --- a/Demos3/bullet2/LuaDemo/LuaPhysicsSetup.h +++ /dev/null @@ -1,43 +0,0 @@ -#ifndef _LUA_PHYSICS_SETUP_H -#define _LUA_PHYSICS_SETUP_H - -#include "Bullet3AppSupport/CommonPhysicsSetup.h" - -//we don't derive from CommonRigidBodySetup because we -//create and own our own dynamics world (one or more) -//at run-time -struct LuaPhysicsSetup : public CommonPhysicsSetup -{ - - LuaPhysicsSetup(struct CommonGraphicsApp* app); - virtual ~LuaPhysicsSetup(); - - class btDefaultCollisionConfiguration* m_config; - class btCollisionDispatcher* m_dispatcher; - class btDbvtBroadphase* m_bp; - class btNNCGConstraintSolver* m_solver; - class btDiscreteDynamicsWorld* m_dynamicsWorld; - struct CommonGraphicsApp* m_glApp; - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void exitPhysics(); - - virtual void stepSimulation(float deltaTime); - - virtual void debugDraw(int debugDrawFlags); - - virtual bool pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld); - virtual bool movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld); - virtual void removePickingConstraint(); - - virtual void syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge); - - virtual btRigidBody* createRigidBody(float mass, const btTransform& startTransform,btCollisionShape* shape, const btVector4& color=btVector4(1,0,0,1)); - - virtual btBoxShape* createBoxShape(const btVector3& halfExtents); - -}; - - -#endif //_LUA_PHYSICS_SETUP_H diff --git a/Demos3/bullet2/MultiBodyDemo/MultiBodyVehicle.cpp b/Demos3/bullet2/MultiBodyDemo/MultiBodyVehicle.cpp deleted file mode 100644 index 7cb6eb744..000000000 --- a/Demos3/bullet2/MultiBodyDemo/MultiBodyVehicle.cpp +++ /dev/null @@ -1,234 +0,0 @@ -//test addJointTorque -#include "MultiBodyVehicle.h" - -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/Featherstone/btMultiBody.h" -#include "BulletDynamics/Featherstone/btMultiBodyConstraintSolver.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -#include "BulletDynamics/Featherstone/btMultiBodyLink.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointLimitConstraint.h" -#include "BulletDynamics/Featherstone/btMultiBodyJointMotor.h" -#include "BulletDynamics/Featherstone/btMultiBodyPoint2Point.h" -#include "BulletCollision/CollisionShapes/btBoxShape.h" - -btScalar gVehicleBaseMass = 100.f; -btScalar gVehicleWheelMass = 5.f; -float friction = 1.f; -btVector3 gVehicleBaseHalfExtents(1, 0.1, 2); -btVector3 gVehicleWheelHalfExtents(0.2, 0.2, 0.2); - -btVector3 gVehicleWheelOffset(0, 0, 0.5); -btVector3 wheelAttachmentPosInWorld[4] = { - btVector3(1, 0, 2.), - btVector3(-1, 0, 2.), - btVector3(1, 0, -2.), - btVector3(-1, 0, -2.) -}; - - -MultiBodyVehicleSetup::MultiBodyVehicleSetup() -{ -} - -MultiBodyVehicleSetup::~MultiBodyVehicleSetup() -{ - -} - - - -class btMultiBody* MultiBodyVehicleSetup::createMultiBodyVehicle() -{ - class btMultiBodyDynamicsWorld* world = m_dynamicsWorld; - int numWheels = 4; - - int totalLinks = numWheels;//number of body parts (links) (in)directly attached to the base, NOT including the base/root itself - - btCollisionShape* chassis = new btBoxShape(gVehicleBaseHalfExtents);//CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)); - m_collisionShapes.push_back(chassis); - btCollisionShape* wheel = new btCylinderShapeX(gVehicleWheelHalfExtents);//CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)); - m_collisionShapes.push_back(wheel); - - - btVector3 baseLocalInertia(0, 0, 0); - chassis->calculateLocalInertia(gVehicleBaseMass, baseLocalInertia); - - bool multiDof = false; - bool isFixedBase = false; - bool canSleep = false; - - btMultiBody * bod = new btMultiBody(totalLinks, gVehicleBaseMass, baseLocalInertia, isFixedBase, canSleep);// , multiDof); - bod->setHasSelfCollision(false); - - btQuaternion baseOrn(0, 0, 0, 1); - btVector3 basePos(0, 0, 0); - bod->setBasePos(basePos); - - bod->setWorldToBaseRot(baseOrn); - btVector3 vel(0, 0, 0); - bod->setBaseVel(vel); - - { - - - - - int linkNum = 0; - - - btVector3 wheelJointAxisWorld(1, 0, 0); - btQuaternion parent_to_child = baseOrn.inverse();//?? - for (int j = 0; j < numWheels; j++, linkNum++) - { - int parent_link_num = -1; - - float initial_joint_angle = 0.0; - - btVector3 localWheelInertia(0, 0, 0); - wheel->calculateLocalInertia(gVehicleWheelMass, localWheelInertia); - bool disableParentCollision = true; - btVector3 pivotToChildCOM(0, 0, 0.25); - btVector3 pivotToWheelCOM(0, 0, 0); - { - bod->setupRevolute(linkNum, gVehicleWheelMass, localWheelInertia, parent_link_num, parent_to_child, wheelJointAxisWorld, - wheelAttachmentPosInWorld[j], pivotToWheelCOM, disableParentCollision); - } - bod->setJointPos(linkNum, initial_joint_angle); - - if (j<2) -{ - btMultiBodyJointMotor* con = new btMultiBodyJointMotor(bod, linkNum, 1., 50); - world->addMultiBodyConstraint(con); -} - } - - - } - - //add a collider for the base - { - - btAlignedObjectArray world_to_local; - world_to_local.resize(totalLinks + 1); - - btAlignedObjectArray local_origin; - local_origin.resize(totalLinks + 1); - world_to_local[0] = bod->getWorldToBaseRot(); - local_origin[0] = bod->getBasePos(); - { - - float pos[4] = { local_origin[0].x(), local_origin[0].y(), local_origin[0].z(), 1 }; - float quat[4] = { -world_to_local[0].x(), -world_to_local[0].y(), -world_to_local[0].z(), world_to_local[0].w() }; - - - if (1) - { - - btMultiBodyLinkCollider* col = new btMultiBodyLinkCollider(bod, -1); - col->setCollisionShape(chassis); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(local_origin[0]); - tr.setRotation(btQuaternion(quat[0], quat[1], quat[2], quat[3])); - col->setWorldTransform(tr); - world->addCollisionObject(col, btBroadphaseProxy::DefaultFilter, btBroadphaseProxy::AllFilter);// 2, 1 + 2); - col->setFriction(friction); - bod->setBaseCollider(col); - } - } - - //initialize local coordinate frames, relative to parent - for (int i = 0; igetNumLinks(); i++) - { - const int parent = bod->getParent(i); - world_to_local[i + 1] = bod->getParentToLocalRot(i) * world_to_local[parent + 1]; - local_origin[i + 1] = local_origin[parent + 1] + (quatRotate(world_to_local[i + 1].inverse(), bod->getRVector(i))); - } - - int linkIndex = 0; - - - - for (int j = 0; jsetCollisionShape(wheel); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(posr); - tr.setRotation(btQuaternion(quat[0], quat[1], quat[2], quat[3])); - col->setWorldTransform(tr); - col->setFriction(friction); - world->addCollisionObject(col, btBroadphaseProxy::DefaultFilter, btBroadphaseProxy::AllFilter);// 2, 1 + 2); - bod->getLink(linkIndex).m_collider = col; - } - } - - - world->addMultiBody(bod); -// world->setGravity(btVector3(0,0,0)); - - return bod; -} - - -void MultiBodyVehicleSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - int upAxis = 1; - - btVector4 colors[4] = - { - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), - }; - int curColor = 0; - - - - gfxBridge.setUpAxis(upAxis); - - this->createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode( - //btIDebugDraw::DBG_DrawConstraints - +btIDebugDraw::DBG_DrawWireframe - +btIDebugDraw::DBG_DrawContactPoints - +btIDebugDraw::DBG_DrawAabb - );//+btIDebugDraw::DBG_DrawConstraintLimits); - - - createMultiBodyVehicle(); - - if (1) - { - btVector3 groundHalfExtents(20,20,20); - groundHalfExtents[upAxis]=1.f; - btBoxShape* box = new btBoxShape(groundHalfExtents); - box->initializePolyhedralFeatures(); - - - btTransform start; start.setIdentity(); - btVector3 groundOrigin(0,0,0); - groundOrigin[upAxis]=-1.5; - start.setOrigin(groundOrigin); - btRigidBody* body = createRigidBody(0,start,box); - - } - - gfxBridge.autogenerateGraphicsObjects(m_dynamicsWorld); -} - -void MultiBodyVehicleSetup::stepSimulation(float deltaTime) -{ - m_dynamicsWorld->stepSimulation(deltaTime); -} - diff --git a/Demos3/bullet2/MultiBodyDemo/MultiBodyVehicle.h b/Demos3/bullet2/MultiBodyDemo/MultiBodyVehicle.h deleted file mode 100644 index 115160c68..000000000 --- a/Demos3/bullet2/MultiBodyDemo/MultiBodyVehicle.h +++ /dev/null @@ -1,24 +0,0 @@ -#ifndef TEST_MULTIBODY_VEHICLE_SETUP_H -#define TEST_MULTIBODY_VEHICLE_SETUP_H - -#include "Bullet3AppSupport/CommonMultiBodySetup.h" - -struct MultiBodyVehicleSetup : public CommonMultiBodySetup -{ - btMultiBody* m_multiBody; - -public: - - MultiBodyVehicleSetup(); - virtual ~MultiBodyVehicleSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void stepSimulation(float deltaTime); - - class btMultiBody* createMultiBodyVehicle(); - - -}; -#endif //TEST_MULTIBODY_VEHICLE_SETUP_H - diff --git a/Demos3/bullet2/MultiBodyDemo/TestJointTorqueSetup.cpp b/Demos3/bullet2/MultiBodyDemo/TestJointTorqueSetup.cpp deleted file mode 100644 index f253d6f37..000000000 --- a/Demos3/bullet2/MultiBodyDemo/TestJointTorqueSetup.cpp +++ /dev/null @@ -1,251 +0,0 @@ -//test addJointTorque -#include "TestJointTorqueSetup.h" - -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" -TestJointTorqueSetup::TestJointTorqueSetup() -{ -} - -TestJointTorqueSetup::~TestJointTorqueSetup() -{ - -} - -void TestJointTorqueSetup::initPhysics(GraphicsPhysicsBridge& gfxBridge) -{ - int upAxis = 2; - - btVector4 colors[4] = - { - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - btVector4(1,1,0,1), - }; - int curColor = 0; - - - - gfxBridge.setUpAxis(upAxis); - - this->createEmptyDynamicsWorld(); - gfxBridge.createPhysicsDebugDrawer(m_dynamicsWorld); - m_dynamicsWorld->getDebugDrawer()->setDebugMode( - //btIDebugDraw::DBG_DrawConstraints - +btIDebugDraw::DBG_DrawWireframe - +btIDebugDraw::DBG_DrawContactPoints - +btIDebugDraw::DBG_DrawAabb - );//+btIDebugDraw::DBG_DrawConstraintLimits); - - //create a static ground object - if (0) - { - btVector3 groundHalfExtents(20,20,20); - groundHalfExtents[upAxis]=1.f; - btBoxShape* box = new btBoxShape(groundHalfExtents); - box->initializePolyhedralFeatures(); - - gfxBridge.createCollisionShapeGraphicsObject(box); - btTransform start; start.setIdentity(); - btVector3 groundOrigin(0,0,0); - groundOrigin[upAxis]=-1.5; - start.setOrigin(groundOrigin); - btRigidBody* body = createRigidBody(0,start,box); - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - gfxBridge.createRigidBodyGraphicsObject(body,color); - } - - { - bool floating = false; - bool damping = true; - bool gyro = true; - int numLinks = 5; - bool spherical = false; //set it ot false -to use 1DoF hinges instead of 3DoF sphericals - bool canSleep = false; - bool selfCollide = false; - btVector3 linkHalfExtents(0.05, 0.37, 0.1); - btVector3 baseHalfExtents(0.05, 0.37, 0.1); - - btVector3 basePosition = btVector3(-0.4f, 3.f, 0.f); - //mbC->forceMultiDof(); //if !spherical, you can comment this line to check the 1DoF algorithm - //init the base - btVector3 baseInertiaDiag(0.f, 0.f, 0.f); - float baseMass = 1.f; - - if(baseMass) - { - btCollisionShape *pTempBox = new btBoxShape(btVector3(baseHalfExtents[0], baseHalfExtents[1], baseHalfExtents[2])); - pTempBox->calculateLocalInertia(baseMass, baseInertiaDiag); - delete pTempBox; - } - - bool isMultiDof = false; - btMultiBody *pMultiBody = new btMultiBody(numLinks, baseMass, baseInertiaDiag, !floating, canSleep, isMultiDof); - m_multiBody = pMultiBody; - btQuaternion baseOriQuat(0.f, 0.f, 0.f, 1.f); - pMultiBody->setBasePos(basePosition); - pMultiBody->setWorldToBaseRot(baseOriQuat); - btVector3 vel(0, 0, 0); - // pMultiBody->setBaseVel(vel); - - //init the links - btVector3 hingeJointAxis(1, 0, 0); - float linkMass = 1.f; - btVector3 linkInertiaDiag(0.f, 0.f, 0.f); - - btCollisionShape *pTempBox = new btBoxShape(btVector3(linkHalfExtents[0], linkHalfExtents[1], linkHalfExtents[2])); - pTempBox->calculateLocalInertia(linkMass, linkInertiaDiag); - delete pTempBox; - - //y-axis assumed up - btVector3 parentComToCurrentCom(0, -linkHalfExtents[1] * 2.f, 0); //par body's COM to cur body's COM offset - btVector3 currentPivotToCurrentCom(0, -linkHalfExtents[1], 0); //cur body's COM to cur body's PIV offset - btVector3 parentComToCurrentPivot = parentComToCurrentCom - currentPivotToCurrentCom; //par body's COM to cur body's PIV offset - - ////// - btScalar q0 = 0.f * SIMD_PI/ 180.f; - btQuaternion quat0(btVector3(0, 1, 0).normalized(), q0); - quat0.normalize(); - ///// - - for(int i = 0; i < numLinks; ++i) - { - if(!spherical) - pMultiBody->setupRevolute(i, linkMass, linkInertiaDiag, i - 1, btQuaternion(0.f, 0.f, 0.f, 1.f), hingeJointAxis, parentComToCurrentPivot, currentPivotToCurrentCom, false); - else - //pMultiBody->setupPlanar(i, linkMass, linkInertiaDiag, i - 1, btQuaternion(0.f, 0.f, 0.f, 1.f)/*quat0*/, btVector3(1, 0, 0), parentComToCurrentPivot*2, false); - pMultiBody->setupSpherical(i, linkMass, linkInertiaDiag, i - 1, btQuaternion(0.f, 0.f, 0.f, 1.f), parentComToCurrentPivot, currentPivotToCurrentCom, false); - } - - //pMultiBody->finalizeMultiDof(); - - btMultiBodyDynamicsWorld* world = m_dynamicsWorld; - - /// - world->addMultiBody(pMultiBody); - btMultiBody* mbC = pMultiBody; - mbC->setCanSleep(canSleep); - mbC->setHasSelfCollision(selfCollide); - mbC->setUseGyroTerm(gyro); - // - if(!damping) - { - mbC->setLinearDamping(0.f); - mbC->setAngularDamping(0.f); - }else - { mbC->setLinearDamping(0.1f); - mbC->setAngularDamping(0.9f); - } - // - btVector3 gravity(0,0,0); - //gravity[upAxis] = -9.81; - m_dynamicsWorld->setGravity(gravity); - ////////////////////////////////////////////// - if(numLinks > 0) - { - btScalar q0 = 45.f * SIMD_PI/ 180.f; - if(!spherical) - if(mbC->isMultiDof()) - mbC->setJointPosMultiDof(0, &q0); - else - mbC->setJointPos(0, q0); - else - { - btQuaternion quat0(btVector3(1, 1, 0).normalized(), q0); - quat0.normalize(); - mbC->setJointPosMultiDof(0, quat0); - } - } - /// - - btAlignedObjectArray world_to_local; - world_to_local.resize(pMultiBody->getNumLinks() + 1); - - btAlignedObjectArray local_origin; - local_origin.resize(pMultiBody->getNumLinks() + 1); - world_to_local[0] = pMultiBody->getWorldToBaseRot(); - local_origin[0] = pMultiBody->getBasePos(); - double friction = 1; - { - - // float pos[4]={local_origin[0].x(),local_origin[0].y(),local_origin[0].z(),1}; - float quat[4]={-world_to_local[0].x(),-world_to_local[0].y(),-world_to_local[0].z(),world_to_local[0].w()}; - - - if (1) - { - btCollisionShape* box = new btBoxShape(baseHalfExtents); - gfxBridge.createCollisionShapeGraphicsObject(box); - - btMultiBodyLinkCollider* col= new btMultiBodyLinkCollider(pMultiBody, -1); - col->setCollisionShape(box); - - btTransform tr; - tr.setIdentity(); -//if we don't set the initial pose of the btCollisionObject, the simulator will do this - //when syncing the btMultiBody link transforms to the btMultiBodyLinkCollider - - tr.setOrigin(local_origin[0]); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - - world->addCollisionObject(col, 2,1+2); - - btVector3 color(0.0,0.0,0.5); - gfxBridge.createCollisionObjectGraphicsObject(col,color); - - col->setFriction(friction); - pMultiBody->setBaseCollider(col); - - } - } - - - for (int i=0; i < pMultiBody->getNumLinks(); ++i) - { - const int parent = pMultiBody->getParent(i); - world_to_local[i+1] = pMultiBody->getParentToLocalRot(i) * world_to_local[parent+1]; - local_origin[i+1] = local_origin[parent+1] + (quatRotate(world_to_local[i+1].inverse() , pMultiBody->getRVector(i))); - } - - - for (int i=0; i < pMultiBody->getNumLinks(); ++i) - { - - btVector3 posr = local_origin[i+1]; - // float pos[4]={posr.x(),posr.y(),posr.z(),1}; - - float quat[4]={-world_to_local[i+1].x(),-world_to_local[i+1].y(),-world_to_local[i+1].z(),world_to_local[i+1].w()}; - - btCollisionShape* box = new btBoxShape(linkHalfExtents); - gfxBridge.createCollisionShapeGraphicsObject(box); - btMultiBodyLinkCollider* col = new btMultiBodyLinkCollider(pMultiBody, i); - - col->setCollisionShape(box); - btTransform tr; - tr.setIdentity(); - tr.setOrigin(posr); - tr.setRotation(btQuaternion(quat[0],quat[1],quat[2],quat[3])); - col->setWorldTransform(tr); - col->setFriction(friction); - world->addCollisionObject(col,2,1+2); - btVector4 color = colors[curColor]; - curColor++; - curColor&=3; - gfxBridge.createCollisionObjectGraphicsObject(col,color); - - - pMultiBody->getLink(i).m_collider=col; - } - } - -} - -void TestJointTorqueSetup::stepSimulation(float deltaTime) -{ - m_multiBody->addJointTorque(0, 10.0); - m_dynamicsWorld->stepSimulation(deltaTime); -} - diff --git a/Demos3/bullet2/MultiBodyDemo/TestJointTorqueSetup.h b/Demos3/bullet2/MultiBodyDemo/TestJointTorqueSetup.h deleted file mode 100644 index 23a635d80..000000000 --- a/Demos3/bullet2/MultiBodyDemo/TestJointTorqueSetup.h +++ /dev/null @@ -1,21 +0,0 @@ -#ifndef TEST_JOINT_TORQUE_SETUP_H -#define TEST_JOINT_TORQUE_SETUP_H - -#include "Bullet3AppSupport/CommonMultiBodySetup.h" - -struct TestJointTorqueSetup : public CommonMultiBodySetup -{ - btMultiBody* m_multiBody; - -public: - - TestJointTorqueSetup(); - virtual ~TestJointTorqueSetup(); - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge); - - virtual void stepSimulation(float deltaTime); - -}; -#endif //TEST_JOINT_TORQUE_SETUP_H - diff --git a/Demos3/bullet2/RagdollDemo/RagdollDemo.cpp b/Demos3/bullet2/RagdollDemo/RagdollDemo.cpp deleted file mode 100644 index 155d84dd4..000000000 --- a/Demos3/bullet2/RagdollDemo/RagdollDemo.cpp +++ /dev/null @@ -1,366 +0,0 @@ -#include "btBulletDynamicsCommon.h" -#include "RagdollDemo.h" -#include "OpenGLWindow/SimpleOpenGL3App.h" -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "BulletCollision/CollisionShapes/btShapeHull.h" - -#define CONSTRAINT_DEBUG_SIZE 0.2f - -struct GraphicsVertex -{ - float pos[4]; - float normal[3]; - float texcoord[2]; -}; - -class RagDoll -{ - enum - { - BODYPART_PELVIS = 0, - BODYPART_SPINE, - BODYPART_HEAD, - - BODYPART_LEFT_UPPER_LEG, - BODYPART_LEFT_LOWER_LEG, - - BODYPART_RIGHT_UPPER_LEG, - BODYPART_RIGHT_LOWER_LEG, - - BODYPART_LEFT_UPPER_ARM, - BODYPART_LEFT_LOWER_ARM, - - BODYPART_RIGHT_UPPER_ARM, - BODYPART_RIGHT_LOWER_ARM, - - BODYPART_COUNT - }; - - enum - { - JOINT_PELVIS_SPINE = 0, - JOINT_SPINE_HEAD, - - JOINT_LEFT_HIP, - JOINT_LEFT_KNEE, - - JOINT_RIGHT_HIP, - JOINT_RIGHT_KNEE, - - JOINT_LEFT_SHOULDER, - JOINT_LEFT_ELBOW, - - JOINT_RIGHT_SHOULDER, - JOINT_RIGHT_ELBOW, - - JOINT_COUNT - }; - - btDynamicsWorld* m_ownerWorld; - btConvexShape* m_shapes[BODYPART_COUNT]; - btRigidBody* m_bodies[BODYPART_COUNT]; - btTypedConstraint* m_joints[JOINT_COUNT]; - SimpleOpenGL3App* m_app;//used to create graphics shapes - - btRigidBody* localCreateRigidBody (btScalar mass, const btTransform& startTransform, btConvexShape* shape) - { - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0,0,0); - if (isDynamic) - shape->calculateLocalInertia(mass,localInertia); - - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,shape,localInertia); - btRigidBody* body = new btRigidBody(rbInfo); - - m_ownerWorld->addRigidBody(body); - - btVector3 color(1,0,0); - btVector3 scaling(1,1,1); - - btShapeHull* hull = new btShapeHull(shape); - hull->buildHull(0.01); - - { - int strideInBytes = 9*sizeof(float); - int numVertices = hull->numVertices(); - int numIndices =hull->numIndices(); - - btAlignedObjectArray gvertices; - - for (int i=0;igetVertexPointer()[i]; - vtx.pos[0] = pos.x(); - vtx.pos[1] = pos.y(); - vtx.pos[2] = pos.z(); - vtx.pos[3] = 1.f; - pos.normalize(); - vtx.normal[0] =pos.x(); - vtx.normal[1] =pos.y(); - vtx.normal[2] =pos.z(); - vtx.texcoord[0] = 0.5f; - vtx.texcoord[1] = 0.5f; - gvertices.push_back(vtx); - } - - btAlignedObjectArray indices; - for (int i=0;igetIndexPointer()[i]); - - int shapeId = m_app->m_instancingRenderer->registerShape(&gvertices[0].pos[0],numVertices,&indices[0],numIndices); - - m_app->m_instancingRenderer->registerGraphicsInstance(shapeId,body->getWorldTransform().getOrigin(),body->getWorldTransform().getRotation(),color,scaling); - - } - delete hull; - - - - return body; - } - -public: - RagDoll (btDynamicsWorld* ownerWorld, const btVector3& positionOffset,SimpleOpenGL3App* app) - : m_ownerWorld (ownerWorld), - m_app(app) - { - // Setup the geometry - m_shapes[BODYPART_PELVIS] = new btCapsuleShape(btScalar(0.15), btScalar(0.20)); - m_shapes[BODYPART_SPINE] = new btCapsuleShape(btScalar(0.15), btScalar(0.28)); - m_shapes[BODYPART_HEAD] = new btCapsuleShape(btScalar(0.10), btScalar(0.05)); - m_shapes[BODYPART_LEFT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07), btScalar(0.45)); - m_shapes[BODYPART_LEFT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05), btScalar(0.37)); - m_shapes[BODYPART_RIGHT_UPPER_LEG] = new btCapsuleShape(btScalar(0.07), btScalar(0.45)); - m_shapes[BODYPART_RIGHT_LOWER_LEG] = new btCapsuleShape(btScalar(0.05), btScalar(0.37)); - m_shapes[BODYPART_LEFT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05), btScalar(0.33)); - m_shapes[BODYPART_LEFT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04), btScalar(0.25)); - m_shapes[BODYPART_RIGHT_UPPER_ARM] = new btCapsuleShape(btScalar(0.05), btScalar(0.33)); - m_shapes[BODYPART_RIGHT_LOWER_ARM] = new btCapsuleShape(btScalar(0.04), btScalar(0.25)); - - // Setup all the rigid bodies - btTransform offset; offset.setIdentity(); - offset.setOrigin(positionOffset); - - btTransform transform; - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.), btScalar(0.))); - m_bodies[BODYPART_PELVIS] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_PELVIS]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.2), btScalar(0.))); - m_bodies[BODYPART_SPINE] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_SPINE]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.), btScalar(1.6), btScalar(0.))); - m_bodies[BODYPART_HEAD] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_HEAD]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_LEFT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_LEFT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18), btScalar(0.65), btScalar(0.))); - m_bodies[BODYPART_RIGHT_UPPER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.18), btScalar(0.2), btScalar(0.))); - m_bodies[BODYPART_RIGHT_LOWER_LEG] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_LEG]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); - m_bodies[BODYPART_LEFT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(-0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); - m_bodies[BODYPART_LEFT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_LEFT_LOWER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.35), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-SIMD_HALF_PI); - m_bodies[BODYPART_RIGHT_UPPER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_UPPER_ARM]); - - transform.setIdentity(); - transform.setOrigin(btVector3(btScalar(0.7), btScalar(1.45), btScalar(0.))); - transform.getBasis().setEulerZYX(0,0,-SIMD_HALF_PI); - m_bodies[BODYPART_RIGHT_LOWER_ARM] = localCreateRigidBody(btScalar(1.), offset*transform, m_shapes[BODYPART_RIGHT_LOWER_ARM]); - - // Setup some damping on the m_bodies - for (int i = 0; i < BODYPART_COUNT; ++i) - { - m_bodies[i]->setDamping(0.05, 0.85); - m_bodies[i]->setDeactivationTime(0.8); - m_bodies[i]->setSleepingThresholds(1.6, 2.5); - } - - // Now setup the constraints - btHingeConstraint* hingeC; - btConeTwistConstraint* coneC; - - btTransform localA, localB; - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.15), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_SPINE], localA, localB); - hingeC->setLimit(btScalar(-0.5f*SIMD_HALF_PI), btScalar(SIMD_HALF_PI)); - m_joints[JOINT_PELVIS_SPINE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_PELVIS_SPINE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.30), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_HEAD], localA, localB); - coneC->setLimit(0.5f*SIMD_HALF_PI, 0.5f*SIMD_HALF_PI, SIMD_HALF_PI); - m_joints[JOINT_SPINE_HEAD] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_SPINE_HEAD], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,-0.5f*SIMD_HALF_PI*5); localA.setOrigin(btVector3(btScalar(-0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,-0.5f*SIMD_HALF_PI*5); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_LEFT_UPPER_LEG], localA, localB); - coneC->setLimit(0.5f*SIMD_HALF_PI, 0.5f*SIMD_HALF_PI, 0); - m_joints[JOINT_LEFT_HIP] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_LEG], *m_bodies[BODYPART_LEFT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(SIMD_HALF_PI)); - m_joints[JOINT_LEFT_KNEE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,0.5f*SIMD_HALF_PI); localA.setOrigin(btVector3(btScalar(0.18), btScalar(-0.10), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,0.5f*SIMD_HALF_PI); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.225), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_PELVIS], *m_bodies[BODYPART_RIGHT_UPPER_LEG], localA, localB); - coneC->setLimit(0.5f*SIMD_HALF_PI, 0.5f*SIMD_HALF_PI, 0); - m_joints[JOINT_RIGHT_HIP] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_HIP], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(-0.225), btScalar(0.))); - localB.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(0.185), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_LEG], *m_bodies[BODYPART_RIGHT_LOWER_LEG], localA, localB); - hingeC->setLimit(btScalar(0), btScalar(SIMD_HALF_PI)); - m_joints[JOINT_RIGHT_KNEE] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_KNEE], true); - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,SIMD_PI); localA.setOrigin(btVector3(btScalar(-0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_LEFT_UPPER_ARM], localA, localB); - coneC->setLimit(SIMD_HALF_PI, SIMD_HALF_PI, 0); - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_joints[JOINT_LEFT_SHOULDER] = coneC; - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_LEFT_UPPER_ARM], *m_bodies[BODYPART_LEFT_LOWER_ARM], localA, localB); -// hingeC->setLimit(btScalar(-SIMD_HALF_PI), btScalar(0)); - hingeC->setLimit(btScalar(0), btScalar(SIMD_HALF_PI)); - m_joints[JOINT_LEFT_ELBOW] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_LEFT_ELBOW], true); - - - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,0,0); localA.setOrigin(btVector3(btScalar(0.2), btScalar(0.15), btScalar(0.))); - localB.getBasis().setEulerZYX(0,0,SIMD_HALF_PI); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.18), btScalar(0.))); - coneC = new btConeTwistConstraint(*m_bodies[BODYPART_SPINE], *m_bodies[BODYPART_RIGHT_UPPER_ARM], localA, localB); - coneC->setLimit(SIMD_HALF_PI, SIMD_HALF_PI, 0); - m_joints[JOINT_RIGHT_SHOULDER] = coneC; - coneC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_SHOULDER], true); - - localA.setIdentity(); localB.setIdentity(); - localA.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localA.setOrigin(btVector3(btScalar(0.), btScalar(0.18), btScalar(0.))); - localB.getBasis().setEulerZYX(0,SIMD_HALF_PI,0); localB.setOrigin(btVector3(btScalar(0.), btScalar(-0.14), btScalar(0.))); - hingeC = new btHingeConstraint(*m_bodies[BODYPART_RIGHT_UPPER_ARM], *m_bodies[BODYPART_RIGHT_LOWER_ARM], localA, localB); -// hingeC->setLimit(btScalar(-SIMD_HALF_PI), btScalar(0)); - hingeC->setLimit(btScalar(0), btScalar(SIMD_HALF_PI)); - m_joints[JOINT_RIGHT_ELBOW] = hingeC; - hingeC->setDbgDrawSize(CONSTRAINT_DEBUG_SIZE); - - m_ownerWorld->addConstraint(m_joints[JOINT_RIGHT_ELBOW], true); - } - - virtual ~RagDoll () - { - int i; - - // Remove all constraints - for ( i = 0; i < JOINT_COUNT; ++i) - { - m_ownerWorld->removeConstraint(m_joints[i]); - delete m_joints[i]; m_joints[i] = 0; - } - - // Remove all bodies and shapes - for ( i = 0; i < BODYPART_COUNT; ++i) - { - m_ownerWorld->removeRigidBody(m_bodies[i]); - - delete m_bodies[i]->getMotionState(); - - delete m_bodies[i]; m_bodies[i] = 0; - delete m_shapes[i]; m_shapes[i] = 0; - } - } -}; - - - - - -void RagDollDemo::initPhysics() -{ - Bullet2RigidBodyDemo::initPhysics(); - int cubeShapeId = m_glApp->registerCubeShape(); - - createGround(cubeShapeId); - - btVector3 offset(0,3,0); - - RagDoll* doll = new RagDoll(this->m_dynamicsWorld,offset,m_glApp); - offset.setValue(0,6,0); - doll = new RagDoll(this->m_dynamicsWorld,offset,m_glApp); - - m_glApp->m_instancingRenderer->writeTransforms(); - -} - - - diff --git a/Demos3/bullet2/RagdollDemo/RagdollDemo.h b/Demos3/bullet2/RagdollDemo/RagdollDemo.h deleted file mode 100644 index 6f5325ece..000000000 --- a/Demos3/bullet2/RagdollDemo/RagdollDemo.h +++ /dev/null @@ -1,27 +0,0 @@ -#ifndef RAGDOLL_DEMO_H -#define RAGDOLL_DEMO_H - - -#include "Bullet3AppSupport/CommonRigidBodySetup.h" -#include "../BasicDemo/BasicDemo.h" - -struct BulletDemoInterface; -struct CommonGraphicsApp; - -class RagDollSetup : public CommonRigidBodySetup -{ -public: - - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - CommonPhysicsSetup* physicsSetup = new RagDollSetup(); - return new BasicDemo(app, physicsSetup); - - } - - void initPhysics(GraphicsPhysicsBridge& gfxBridge); - -}; - -#endif //RAGDOLL_DEMO_H - diff --git a/Demos3/premake4.lua b/Demos3/premake4.lua deleted file mode 100644 index 087ad9ac0..000000000 --- a/Demos3/premake4.lua +++ /dev/null @@ -1,139 +0,0 @@ - - - -function createDemos( demos, incdirs, linknames) - for _, name in ipairs(demos) do - - project ( "App_" .. name ) - - kind "ConsoleApp" - targetdir ".." - - includedirs {incdirs} - - configuration { "Windows" } - defines { "GLEW_STATIC"} - links { "opengl32","glu32","gdi32","winmm", "user32" } - includedirs{ "../ObsoleteDemos/Glut" } - libdirs {"../ObsoleteDemos/Glut"} - files { "../build3/bullet.rc" } - - configuration {"Windows", "x32"} - links {"glew32s","glut32"} - configuration {"Windows", "x64"} - links {"glew64s", "glut64"} - - configuration {"MacOSX"} - --print "hello" - linkoptions { "-framework Carbon -framework OpenGL -framework AGL -framework Glut" } - - configuration {"not Windows", "not MacOSX"} - links {"GL","GLU","glut"} - configuration{} - - links { - linknames - } - - files { - "./" .. name .. "/*.cpp" , - "./" .. name .. "/*.h" - } - end -end - - -function createGpuDemos( demos, incdirs, linknames, vendor) - - hasCL = findOpenCL(vendor) - - if (hasCL) then - - for _, name in ipairs(demos) do - - project ( "App_" .. name .. "_" .. vendor) - - initOpenCL(vendor) - - kind "ConsoleApp" - targetdir "../bin" - - links {"Bullet3OpenCL_" .. vendor } - - includedirs {incdirs} - - configuration { "Windows" } - defines { "GLEW_STATIC"} - links { "opengl32" ,"glu32","gdi32","winmm", "user32"} - includedirs{ "../ObsoleteDemos/Glut" } - libdirs {"../ObsoleteDemos/Glut"} - files { "../build3/bullet.rc" } - - configuration {"Windows", "x32"} - links {"glew32s","glut32"} - configuration {"Windows", "x64"} - links {"glew64s", "glut64"} - - configuration {"MacOSX"} - --print "hello" - linkoptions { "-framework Carbon -framework OpenGL -framework AGL -framework Glut" } - - configuration {"not Windows", "not MacOSX"} - links {"GL","GLU","glut"} - configuration{} - - links { - linknames - } - - files { - "./" .. name .. "/*.cpp" , - "./" .. name .. "/*.h" - } - end - end -end - --- "CharacterDemo", fixme: it includes BspDemo files - - local localdemos = { - "BasicDemo", - } - - local localgpudemos = { - "BasicGpuDemo", - } - --- the following demos require custom include or link settings - --- createDemos({"HelloWorld"},{"../src"},{"BulletDynamics","BulletCollision","LinearMath"}) - - createDemos(localdemos,{"../src","../ObsoleteDemos/OpenGL"},{"OpenGLSupport","BulletDynamics", "BulletCollision", "LinearMath"}) - createGpuDemos(localgpudemos,{"../src","../ObsoleteDemos/OpenGL"},{"OpenGLSupport", - "Bullet3Dynamics","Bullet3Collision","Bullet3Geometry","Bullet3Common", - "BulletDynamics", "BulletCollision", "LinearMath"}, - "NVIDIA") - -createGpuDemos(localgpudemos,{"../src","../ObsoleteDemos/OpenGL"},{"OpenGLSupport", - "Bullet3Dynamics","Bullet3Collision","Bullet3Geometry","Bullet3Common", - "BulletDynamics", "BulletCollision", "LinearMath"}, - "clew") - -createGpuDemos(localgpudemos,{"../src","../ObsoleteDemos/OpenGL"},{"OpenGLSupport", - "Bullet3Dynamics","Bullet3Collision","Bullet3Geometry","Bullet3Common", - "BulletDynamics", "BulletCollision", "LinearMath"}, - "AMD") - -createGpuDemos(localgpudemos,{"../src","../ObsoleteDemos/OpenGL"},{"OpenGLSupport", - "Bullet3Dynamics","Bullet3Collision","Bullet3Geometry","Bullet3Common", - "BulletDynamics", "BulletCollision", "LinearMath"}, - "Intel") - -createGpuDemos(localgpudemos,{"../src","../ObsoleteDemos/OpenGL"},{"OpenGLSupport", - "Bullet3Dynamics","Bullet3Collision","Bullet3Geometry","Bullet3Common", - "BulletDynamics", "BulletCollision", "LinearMath"}, - "Apple") - -include "../ObsoleteDemos/OpenGL" - - diff --git a/btgui/Bullet3AppSupport/Bullet2RigidBodyDemo.cpp b/btgui/Bullet3AppSupport/Bullet2RigidBodyDemo.cpp deleted file mode 100644 index 33d25ed03..000000000 --- a/btgui/Bullet3AppSupport/Bullet2RigidBodyDemo.cpp +++ /dev/null @@ -1,444 +0,0 @@ -#include "Bullet2RigidBodyDemo.h" -#include "btBulletDynamicsCommon.h" - -#include "OpenGLWindow/CommonGraphicsApp.h" -#include "OpenGLWindow/CommonRenderInterface.h" -#include "Bullet3Common/b3Scalar.h" - -#include "BulletCollision/CollisionShapes/btShapeHull.h"//to create a tesselation of a generic btConvexShape -#include "MyDebugDrawer.h" -#include "OpenGLWindow/GLInstanceGraphicsShape.h" - -static btVector4 sColors[4] = -{ - btVector4(0.3,0.3,1,1), - btVector4(1,0,0,1), - btVector4(0,1,0,1), - btVector4(0,1,1,1), - //btVector4(1,1,0,1), -}; - - - -struct MyGraphicsPhysicsBridge : public GraphicsPhysicsBridge -{ - CommonGraphicsApp* m_glApp; - MyDebugDrawer* m_debugDraw; - int m_curColor; - - MyGraphicsPhysicsBridge(CommonGraphicsApp* glApp) - :m_glApp(glApp), m_debugDraw(0), m_curColor(0) - { - } - - virtual struct CommonRenderInterface* getRenderInterface() - { - return m_glApp->m_renderer; - } - - virtual void createRigidBodyGraphicsObject(btRigidBody* body, const btVector3& color) - { - createCollisionObjectGraphicsObject(body,color); - } - virtual void createCollisionObjectGraphicsObject(btCollisionObject* body, const btVector3& color) - { - btCollisionShape* shape = body->getCollisionShape(); - btTransform startTransform = body->getWorldTransform(); - int graphicsShapeId = shape->getUserIndex(); - if (graphicsShapeId>=0) - { - // btAssert(graphicsShapeId >= 0); - btVector3 localScaling = shape->getLocalScaling(); - int graphicsInstanceId = m_glApp->m_renderer->registerGraphicsInstance(graphicsShapeId, startTransform.getOrigin(), startTransform.getRotation(), color, localScaling); - body->setUserIndex(graphicsInstanceId); - } - } - - virtual int registerGraphicsShape(const float* vertices, int numvertices, const int* indices, int numIndices) - { - int shapeId = m_glApp->m_renderer->registerShape(vertices, numvertices,indices,numIndices); - return shapeId; - } - - virtual int registerGraphicsInstance(int shapeIndex, const float* position, const float* quaternion, const float* color, const float* scaling) - { - return m_glApp->m_renderer->registerGraphicsInstance(shapeIndex,position,quaternion,color,scaling); - } - - virtual void createCollisionShapeGraphicsObject(btCollisionShape* collisionShape, const btTransform& parentTransform, btAlignedObjectArray& verticesOut, btAlignedObjectArray& indicesOut) - { - //todo: support all collision shape types - switch (collisionShape->getShapeType()) - { - case STATIC_PLANE_PROXYTYPE: - { - //draw a box, oriented along the plane normal - const btStaticPlaneShape* staticPlaneShape = static_cast(collisionShape); - btScalar planeConst = staticPlaneShape->getPlaneConstant(); - const btVector3& planeNormal = staticPlaneShape->getPlaneNormal(); - btVector3 planeOrigin = planeNormal * planeConst; - btVector3 vec0,vec1; - btPlaneSpace1(planeNormal,vec0,vec1); - btScalar vecLen = 100.f; - btVector3 verts[4]; - - verts[0] = planeOrigin + vec0*vecLen + vec1*vecLen; - verts[1] = planeOrigin - vec0*vecLen + vec1*vecLen; - verts[2] = planeOrigin - vec0*vecLen - vec1*vecLen; - verts[3] = planeOrigin + vec0*vecLen - vec1*vecLen; - - int startIndex = verticesOut.size(); - indicesOut.push_back(startIndex+0); - indicesOut.push_back(startIndex+1); - indicesOut.push_back(startIndex+2); - indicesOut.push_back(startIndex+0); - indicesOut.push_back(startIndex+2); - indicesOut.push_back(startIndex+3); - - btVector3 triNormal = parentTransform.getBasis()*planeNormal; - - - for (int i=0;i<4;i++) - { - GLInstanceVertex vtx; - btVector3 pos =parentTransform*verts[i]; - vtx.xyzw[0] = pos.x(); - vtx.xyzw[1] = pos.y(); - vtx.xyzw[2] = pos.z(); - vtx.xyzw[3] = 0.f; - - vtx.normal[0] =triNormal.x(); - vtx.normal[1] =triNormal.y(); - vtx.normal[2] =triNormal.z(); - - vtx.uv[0] = 0.5f; - vtx.uv[1] = 0.5f; - verticesOut.push_back(vtx); - } - break; - } - case TRIANGLE_MESH_SHAPE_PROXYTYPE: - { - btAssert(0); - break; - } - default: - { - if (collisionShape->isConvex()) - { - btConvexShape* convex = (btConvexShape*)collisionShape; - { - btShapeHull* hull = new btShapeHull(convex); - hull->buildHull(0.0); - - { - //int strideInBytes = 9*sizeof(float); - //int numVertices = hull->numVertices(); - //int numIndices =hull->numIndices(); - - for (int t=0;tnumTriangles();t++) - { - - btVector3 triNormal; - - int index0 = hull->getIndexPointer()[t*3+0]; - int index1 = hull->getIndexPointer()[t*3+1]; - int index2 = hull->getIndexPointer()[t*3+2]; - btVector3 pos0 =parentTransform*hull->getVertexPointer()[index0]; - btVector3 pos1 =parentTransform*hull->getVertexPointer()[index1]; - btVector3 pos2 =parentTransform*hull->getVertexPointer()[index2]; - triNormal = (pos1-pos0).cross(pos2-pos0); - triNormal.normalize(); - - for (int v=0;v<3;v++) - { - int index = hull->getIndexPointer()[t*3+v]; - GLInstanceVertex vtx; - btVector3 pos =parentTransform*hull->getVertexPointer()[index]; - vtx.xyzw[0] = pos.x(); - vtx.xyzw[1] = pos.y(); - vtx.xyzw[2] = pos.z(); - vtx.xyzw[3] = 0.f; - - vtx.normal[0] =triNormal.x(); - vtx.normal[1] =triNormal.y(); - vtx.normal[2] =triNormal.z(); - - vtx.uv[0] = 0.5f; - vtx.uv[1] = 0.5f; - - indicesOut.push_back(verticesOut.size()); - verticesOut.push_back(vtx); - } - } - } - } - } else - { - if (collisionShape->isCompound()) - { - btCompoundShape* compound = (btCompoundShape*) collisionShape; - for (int i=0;igetNumChildShapes();i++) - { - - btTransform childWorldTrans = parentTransform * compound->getChildTransform(i); - createCollisionShapeGraphicsObject(compound->getChildShape(i),childWorldTrans,verticesOut,indicesOut); - } - } else - { - btAssert(0); - } - - } - } - }; - } - - virtual void createCollisionShapeGraphicsObject(btCollisionShape* collisionShape) - { - //already has a graphics object? - if (collisionShape->getUserIndex()>=0) - return; - - btAlignedObjectArray vertices; - btAlignedObjectArray indices; - btTransform startTrans;startTrans.setIdentity(); - - createCollisionShapeGraphicsObject(collisionShape,startTrans,vertices,indices); - - if (vertices.size() && indices.size()) - { - int shapeId = m_glApp->m_renderer->registerShape(&vertices[0].xyzw[0],vertices.size(),&indices[0],indices.size()); - collisionShape->setUserIndex(shapeId); - } - - } - virtual void syncPhysicsToGraphics(const btDiscreteDynamicsWorld* rbWorld) - { - int numCollisionObjects = rbWorld->getNumCollisionObjects(); - for (int i = 0; igetCollisionObjectArray()[i]; - btVector3 pos = colObj->getWorldTransform().getOrigin(); - btQuaternion orn = colObj->getWorldTransform().getRotation(); - int index = colObj->getUserIndex(); - if (index >= 0) - { - m_glApp->m_renderer->writeSingleInstanceTransformToCPU(pos, orn, index); - } - } - m_glApp->m_renderer->writeTransforms(); - } - - virtual void createPhysicsDebugDrawer(btDiscreteDynamicsWorld* rbWorld) - { - btAssert(rbWorld); - m_debugDraw = new MyDebugDrawer(m_glApp); - rbWorld->setDebugDrawer(m_debugDraw ); - - - m_debugDraw->setDebugMode( - btIDebugDraw::DBG_DrawWireframe - +btIDebugDraw::DBG_DrawAabb - //btIDebugDraw::DBG_DrawContactPoints - ); - - } - - virtual struct Common2dCanvasInterface* get2dCanvasInterface() - { - return m_glApp->m_2dCanvasInterface; - } - virtual CommonParameterInterface* getParameterInterface() - { - return m_glApp->m_parameterInterface; - } - - virtual void setUpAxis(int axis) - { - m_glApp->setUpAxis(axis); - } - - - btVector3 selectColor() - { - btVector4 color = sColors[m_curColor]; - m_curColor++; - m_curColor&=3; - return color; - } - - virtual void autogenerateGraphicsObjects(btDiscreteDynamicsWorld* rbWorld) - { - for (int i=0;igetNumCollisionObjects();i++) - { - btCollisionObject* colObj = rbWorld->getCollisionObjectArray()[i]; - //btRigidBody* body = btRigidBody::upcast(colObj); - //does this also work for btMultiBody/btMultiBodyLinkCollider? - createCollisionShapeGraphicsObject(colObj->getCollisionShape()); - btVector3 color= selectColor(); - createCollisionObjectGraphicsObject(colObj,color); - - } - } - - virtual void drawText3D( const char* txt, float posX, float posY, float posZ, float size) - { - btAssert(m_glApp); - m_glApp->drawText3D(txt,posX,posY,posZ,size); - } -}; - -Bullet2RigidBodyDemo::Bullet2RigidBodyDemo(CommonGraphicsApp* app, CommonPhysicsSetup* physicsSetup) - : m_physicsSetup(physicsSetup), - m_controlPressed(false), - m_altPressed(false), - m_glApp(app) -{ - -} -void Bullet2RigidBodyDemo::initPhysics() -{ - MyGraphicsPhysicsBridge glBridge(m_glApp); - glBridge.setUpAxis(1); - m_physicsSetup->initPhysics(glBridge); - m_glApp->m_renderer->writeTransforms(); - -} - -void Bullet2RigidBodyDemo::exitPhysics() -{ - - m_physicsSetup->exitPhysics(); - -} - -void Bullet2RigidBodyDemo::stepSimulation(float deltaTime) -{ - m_physicsSetup->stepSimulation(deltaTime); - -} - -void Bullet2RigidBodyDemo::renderScene() -{ - //sync graphics -> physics world transforms - - MyGraphicsPhysicsBridge glBridge(m_glApp); - m_physicsSetup->syncPhysicsToGraphics(glBridge); - m_glApp->m_renderer->renderScene(); - - m_physicsSetup->renderScene(glBridge); - -} - -void Bullet2RigidBodyDemo::physicsDebugDraw(int debugDrawFlags) -{ - m_physicsSetup->debugDraw(debugDrawFlags); -} - -Bullet2RigidBodyDemo::~Bullet2RigidBodyDemo() -{ -} - -btVector3 Bullet2RigidBodyDemo::getRayTo(int x,int y) -{ - if (!m_glApp->m_renderer) - { - btAssert(0); - return btVector3(0,0,0); - } - - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float tanFov = (top-bottom)*0.5f / nearPlane; - float fov = b3Scalar(2.0) * b3Atan(tanFov); - - btVector3 camPos,camTarget; - m_glApp->m_renderer->getCameraPosition(camPos); - m_glApp->m_renderer->getCameraTargetPosition(camTarget); - - btVector3 rayFrom = camPos; - btVector3 rayForward = (camTarget-camPos); - rayForward.normalize(); - float farPlane = 10000.f; - rayForward*= farPlane; - - btVector3 rightOffset; - btVector3 cameraUp=btVector3(0,0,0); - cameraUp[m_glApp->getUpAxis()]=1; - - btVector3 vertical = cameraUp; - - btVector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - b3Scalar aspect; - float width = m_glApp->m_renderer->getScreenWidth(); - float height = m_glApp->m_renderer->getScreenHeight(); - - aspect = width / height; - - hor*=aspect; - - - btVector3 rayToCenter = rayFrom + rayForward; - btVector3 dHor = hor * 1.f/width; - btVector3 dVert = vertical * 1.f/height; - - - btVector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += btScalar(x) * dHor; - rayTo -= btScalar(y) * dVert; - return rayTo; -} - - -bool Bullet2RigidBodyDemo::mouseMoveCallback(float x,float y) -{ - btVector3 rayTo = getRayTo(x, y); - btVector3 rayFrom; - m_glApp->m_renderer->getCameraPosition(rayFrom); - m_physicsSetup->movePickedBody(rayFrom,rayTo); - - return false; -} - -bool Bullet2RigidBodyDemo::mouseButtonCallback(int button, int state, float x, float y) -{ - - if (state==1) - { - if(button==0 && (!m_altPressed && !m_controlPressed)) - { - btVector3 camPos; - m_glApp->m_renderer->getCameraPosition(camPos); - - btVector3 rayFrom = camPos; - btVector3 rayTo = getRayTo(x,y); - - m_physicsSetup->pickBody(rayFrom, rayTo); - - - } - } else - { - if (button==0) - { - m_physicsSetup->removePickingConstraint(); - //remove p2p - } - } - - //printf("button=%d, state=%d\n",button,state); - return false; -} diff --git a/btgui/Bullet3AppSupport/Bullet2RigidBodyDemo.h b/btgui/Bullet3AppSupport/Bullet2RigidBodyDemo.h deleted file mode 100644 index 5c881c33c..000000000 --- a/btgui/Bullet3AppSupport/Bullet2RigidBodyDemo.h +++ /dev/null @@ -1,55 +0,0 @@ -#ifndef BULLET2_RIGIDBODY_DEMO_H -#define BULLET2_RIGIDBODY_DEMO_H - -#include "LinearMath/btVector3.h" - -#include "BulletDemoInterface.h" -#include "OpenGLWindow/b3gWindowInterface.h" -#include "CommonPhysicsSetup.h" - - -class Bullet2RigidBodyDemo : public BulletDemoInterface -{ - CommonPhysicsSetup* m_physicsSetup; - -public: - - bool m_controlPressed; - bool m_altPressed; - -public: - - struct CommonGraphicsApp* m_glApp; - - Bullet2RigidBodyDemo(CommonGraphicsApp* app, CommonPhysicsSetup* physicsSetup); - virtual void initPhysics(); - virtual void exitPhysics(); - virtual void renderScene(); - virtual void physicsDebugDraw(int debugDrawFlags); - virtual void stepSimulation(float dt); - virtual CommonPhysicsSetup* getPhysicsSetup() - { - return m_physicsSetup; - } - - virtual ~Bullet2RigidBodyDemo(); - btVector3 getRayTo(int x,int y); - virtual bool mouseMoveCallback(float x,float y); - virtual bool mouseButtonCallback(int button, int state, float x, float y); - virtual bool keyboardCallback(int key, int state) - { - if (key==B3G_CONTROL) - { - m_controlPressed = (state==1); - } - if (key==B3G_ALT) - { - m_altPressed = (state==1); - } - return false; - } - - -}; - -#endif //BULLET2_RIGIDBODY_DEMO_H diff --git a/btgui/Bullet3AppSupport/BulletDemoInterface.h b/btgui/Bullet3AppSupport/BulletDemoInterface.h deleted file mode 100644 index 41e6169c9..000000000 --- a/btgui/Bullet3AppSupport/BulletDemoInterface.h +++ /dev/null @@ -1,67 +0,0 @@ -#ifndef DEMO_INTERFACE_H -#define DEMO_INTERFACE_H - -struct CommonGraphicsApp; - - -class BulletDemoInterface -{ -public: - - typedef class BulletDemoInterface* (CreateFunc)(CommonGraphicsApp* app); - - virtual ~BulletDemoInterface() - { - } - - virtual void initPhysics()=0; - virtual void exitPhysics()=0; - virtual void stepSimulation(float deltaTime)=0; - virtual void renderScene()=0; - virtual void physicsDebugDraw(int debugFlags)=0;//for now we reuse the flags in Bullet/src/LinearMath/btIDebugDraw.h - virtual bool mouseMoveCallback(float x,float y)=0; - virtual bool mouseButtonCallback(int button, int state, float x, float y)=0; - virtual bool keyboardCallback(int key, int state)=0; - -}; - -class EmptyBulletDemo : public BulletDemoInterface -{ -public: - static BulletDemoInterface* MyCreateFunc(CommonGraphicsApp* app) - { - return new EmptyBulletDemo(); - } - - virtual void initPhysics() - { - } - virtual void exitPhysics() - { - } - virtual void stepSimulation(float deltaTime) - { - } - virtual void renderScene() - { - } - virtual void physicsDebugDraw(int debugFlags) - { - } - virtual bool mouseMoveCallback(float x,float y) - { - return false; - } - virtual bool mouseButtonCallback(int button, int state, float x, float y) - { - return false; - } - virtual bool keyboardCallback(int key, int state) - { - return false; - } -}; - - -#endif //DEMO_INTERFACE_H - diff --git a/btgui/Bullet3AppSupport/CMakeLists.txt b/btgui/Bullet3AppSupport/CMakeLists.txt deleted file mode 100644 index da529f22a..000000000 --- a/btgui/Bullet3AppSupport/CMakeLists.txt +++ /dev/null @@ -1,29 +0,0 @@ - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ${BULLET_PHYSICS_SOURCE_DIR}/btgui -) - -FILE(GLOB Bullet3AppSupport_HDRS "*.h" ) -FILE(GLOB Bullet3AppSupport_SRCS "*.cpp" ) - -IF (WIN32) - ADD_DEFINITIONS(-DGLEW_STATIC) -ENDIF(WIN32) -IF(NOT WIN32 AND NOT APPLE) - ADD_DEFINITIONS(-DGLEW_STATIC) - ADD_DEFINITIONS("-DGLEW_INIT_OPENGL11_FUNCTIONS=1") - ADD_DEFINITIONS("-DGLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS=1") -ENDIF() - -ADD_LIBRARY(Bullet3AppSupport ${Bullet3AppSupport_SRCS} ${Bullet3AppSupport_HDRS}) -if (UNIX AND NOT APPLE) - target_link_libraries(Bullet3AppSupport X11) -elseif (APPLE) - target_link_libraries(Bullet3AppSupport ${COCOA_LIBRARY}) -endif () - -if (BUILD_SHARED_LIBS) - target_link_libraries(Bullet3AppSupport gwen OpenGLWindow ${OPENGL_gl_LIBRARY} BulletCollision LinearMath Bullet3Common) -endif() - diff --git a/btgui/Bullet3AppSupport/Common2dCanvasInterface.h b/btgui/Bullet3AppSupport/Common2dCanvasInterface.h deleted file mode 100644 index 3fcfc40f2..000000000 --- a/btgui/Bullet3AppSupport/Common2dCanvasInterface.h +++ /dev/null @@ -1,15 +0,0 @@ -#ifndef COMMON_2D_CANVAS_INTERFACE_H -#define COMMON_2D_CANVAS_INTERFACE_H - -struct Common2dCanvasInterface -{ - virtual ~Common2dCanvasInterface() {} - virtual int createCanvas(const char* canvasName, int width, int height)=0; - virtual void destroyCanvas(int canvasId)=0; - virtual void setPixel(int canvasId, int x, int y, unsigned char red, unsigned char green,unsigned char blue, unsigned char alpha)=0; - virtual void refreshImageData(int canvasId)=0; - -}; - -#endif //COMMON_2D_CANVAS_INTERFACE_H - diff --git a/btgui/Bullet3AppSupport/CommonMultiBodySetup.h b/btgui/Bullet3AppSupport/CommonMultiBodySetup.h deleted file mode 100644 index 53fc8156e..000000000 --- a/btgui/Bullet3AppSupport/CommonMultiBodySetup.h +++ /dev/null @@ -1,302 +0,0 @@ - -#ifndef COMMON_MULTI_BODY_SETUP_H -#define COMMON_MULTI_BODY_SETUP_H - -//todo: replace this 'btBulletDynamicsCommon.h' header with specific used header files -#include "btBulletDynamicsCommon.h" -#include "CommonPhysicsSetup.h" -#include "BulletDynamics/Featherstone/btMultiBodyDynamicsWorld.h" -#include "BulletDynamics/Featherstone/btMultiBodyConstraintSolver.h" -#include "BulletDynamics/Featherstone/btMultiBodyPoint2Point.h" -#include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h" - -struct CommonMultiBodySetup : public CommonPhysicsSetup -{ - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - btBroadphaseInterface* m_broadphase; - btCollisionDispatcher* m_dispatcher; - btMultiBodyConstraintSolver* m_solver; - btDefaultCollisionConfiguration* m_collisionConfiguration; - btMultiBodyDynamicsWorld* m_dynamicsWorld; - - //data for picking objects - class btRigidBody* m_pickedBody; - class btTypedConstraint* m_pickedConstraint; - class btMultiBodyPoint2Point* m_pickingMultiBodyPoint2Point; - - btVector3 m_oldPickingPos; - btVector3 m_hitPos; - btScalar m_oldPickingDist; - bool m_prevCanSleep; - - CommonMultiBodySetup() - :m_broadphase(0), - m_dispatcher(0), - m_solver(0), - m_collisionConfiguration(0), - m_dynamicsWorld(0), - m_pickedBody(0), - m_pickedConstraint(0), - m_pickingMultiBodyPoint2Point(0), - m_prevCanSleep(false) - { - } - - virtual void createEmptyDynamicsWorld() - { - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - m_solver = new btMultiBodyConstraintSolver; - - m_dynamicsWorld = new btMultiBodyDynamicsWorld(m_dispatcher, m_broadphase, m_solver, m_collisionConfiguration); - - m_dynamicsWorld->setGravity(btVector3(0, -10, 0)); - } - - - virtual void stepSimulation(float deltaTime) - { - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(deltaTime); - } - } - - - virtual void exitPhysics() - { - removePickingConstraint(); - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - - if (m_dynamicsWorld) - { - - int i; - for (i = m_dynamicsWorld->getNumConstraints() - 1; i >= 0; i--) - { - m_dynamicsWorld->removeConstraint(m_dynamicsWorld->getConstraint(i)); - } - for (i = m_dynamicsWorld->getNumCollisionObjects() - 1; i >= 0; i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject(obj); - delete obj; - } - } - //delete collision shapes - for (int j = 0; jgetDebugDrawer()) - { - m_dynamicsWorld->getDebugDrawer()->setDebugMode(debugDrawFlags); - } - m_dynamicsWorld->debugDrawWorld(); - } - - } - - virtual bool pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) - { - if (m_dynamicsWorld==0) - return false; - - btCollisionWorld::ClosestRayResultCallback rayCallback(rayFromWorld, rayToWorld); - - m_dynamicsWorld->rayTest(rayFromWorld, rayToWorld, rayCallback); - if (rayCallback.hasHit()) - { - - btVector3 pickPos = rayCallback.m_hitPointWorld; - btRigidBody* body = (btRigidBody*)btRigidBody::upcast(rayCallback.m_collisionObject); - if (body) - { - //other exclusions? - if (!(body->isStaticObject() || body->isKinematicObject())) - { - m_pickedBody = body; - m_pickedBody->setActivationState(DISABLE_DEACTIVATION); - //printf("pickPos=%f,%f,%f\n",pickPos.getX(),pickPos.getY(),pickPos.getZ()); - btVector3 localPivot = body->getCenterOfMassTransform().inverse() * pickPos; - btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*body, localPivot); - m_dynamicsWorld->addConstraint(p2p, true); - m_pickedConstraint = p2p; - btScalar mousePickClamping = 30.f; - p2p->m_setting.m_impulseClamp = mousePickClamping; - //very weak constraint for picking - p2p->m_setting.m_tau = 0.001f; - } - } else - { - btMultiBodyLinkCollider* multiCol = (btMultiBodyLinkCollider*)btMultiBodyLinkCollider::upcast(rayCallback.m_collisionObject); - if (multiCol && multiCol->m_multiBody) - { - - m_prevCanSleep = multiCol->m_multiBody->getCanSleep(); - multiCol->m_multiBody->setCanSleep(false); - - btVector3 pivotInA = multiCol->m_multiBody->worldPosToLocal(multiCol->m_link, pickPos); - - btMultiBodyPoint2Point* p2p = new btMultiBodyPoint2Point(multiCol->m_multiBody,multiCol->m_link,0,pivotInA,pickPos); - //if you add too much energy to the system, causing high angular velocities, simulation 'explodes' - //see also http://www.bulletphysics.org/Bullet/phpBB3/viewtopic.php?f=4&t=949 - //so we try to avoid it by clamping the maximum impulse (force) that the mouse pick can apply - //it is not satisfying, hopefully we find a better solution (higher order integrator, using joint friction using a zero-velocity target motor with limited force etc?) - btScalar scaling=1; - p2p->setMaxAppliedImpulse(2*scaling); - - btMultiBodyDynamicsWorld* world = (btMultiBodyDynamicsWorld*) m_dynamicsWorld; - world->addMultiBodyConstraint(p2p); - m_pickingMultiBodyPoint2Point =p2p; - } - } - - - - // pickObject(pickPos, rayCallback.m_collisionObject); - m_oldPickingPos = rayToWorld; - m_hitPos = pickPos; - m_oldPickingDist = (pickPos - rayFromWorld).length(); - // printf("hit !\n"); - //add p2p - } - return false; - } - virtual bool movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) - { - if (m_pickedBody && m_pickedConstraint) - { - btPoint2PointConstraint* pickCon = static_cast(m_pickedConstraint); - if (pickCon) - { - //keep it at the same picking distance - - btVector3 dir = rayToWorld-rayFromWorld; - dir.normalize(); - dir *= m_oldPickingDist; - - btVector3 newPivotB = rayFromWorld + dir; - pickCon->setPivotB(newPivotB); - } - } - - if (m_pickingMultiBodyPoint2Point) - { - //keep it at the same picking distance - - - btVector3 dir = rayToWorld-rayFromWorld; - dir.normalize(); - dir *= m_oldPickingDist; - - btVector3 newPivotB = rayFromWorld + dir; - - m_pickingMultiBodyPoint2Point->setPivotInB(newPivotB); - } - - return false; - } - virtual void removePickingConstraint() - { - if (m_pickedConstraint) - { - m_dynamicsWorld->removeConstraint(m_pickedConstraint); - delete m_pickedConstraint; - m_pickedConstraint = 0; - m_pickedBody = 0; - } - if (m_pickingMultiBodyPoint2Point) - { - m_pickingMultiBodyPoint2Point->getMultiBodyA()->setCanSleep(m_prevCanSleep); - btMultiBodyDynamicsWorld* world = (btMultiBodyDynamicsWorld*) m_dynamicsWorld; - world->removeMultiBodyConstraint(m_pickingMultiBodyPoint2Point); - delete m_pickingMultiBodyPoint2Point; - m_pickingMultiBodyPoint2Point = 0; - } - } - - - - btBoxShape* createBoxShape(const btVector3& halfExtents) - { - btBoxShape* box = new btBoxShape(halfExtents); - return box; - } - - btRigidBody* createRigidBody(float mass, const btTransform& startTransform, btCollisionShape* shape, const btVector4& color = btVector4(1, 0, 0, 1)) - { - btAssert((!shape || shape->getShapeType() != INVALID_SHAPE_PROXYTYPE)); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0, 0, 0); - if (isDynamic) - shape->calculateLocalInertia(mass, localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - -#define USE_MOTIONSTATE 1 -#ifdef USE_MOTIONSTATE - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo cInfo(mass, myMotionState, shape, localInertia); - - btRigidBody* body = new btRigidBody(cInfo); - //body->setContactProcessingThreshold(m_defaultContactProcessingThreshold); - -#else - btRigidBody* body = new btRigidBody(mass, 0, shape, localInertia); - body->setWorldTransform(startTransform); -#endif// - - body->setUserIndex(-1); - m_dynamicsWorld->addRigidBody(body); - return body; - } -}; - -#endif //COMMON_MULTI_BODY_SETUP_H - diff --git a/btgui/Bullet3AppSupport/CommonParameterInterface.h b/btgui/Bullet3AppSupport/CommonParameterInterface.h deleted file mode 100644 index 85d138d59..000000000 --- a/btgui/Bullet3AppSupport/CommonParameterInterface.h +++ /dev/null @@ -1,47 +0,0 @@ - -#ifndef PARAM_INTERFACE_H -#define PARAM_INTERFACE_H - -#pragma once - -typedef void (*SliderParamChangedCallback) (float newVal); -#include "LinearMath/btScalar.h" - -struct SliderParams -{ - const char* m_name; - float m_minVal; - float m_maxVal; - SliderParamChangedCallback m_callback; - btScalar* m_paramValuePointer; - void* m_userPointer; - bool m_clampToNotches; - bool m_showValues; - - SliderParams(const char* name, btScalar* targetValuePointer) - :m_name(name), - m_minVal(-100), - m_maxVal(100), - m_callback(0), - m_paramValuePointer(targetValuePointer), - m_userPointer(0), - m_clampToNotches(false), - m_showValues(true) - { - } - -}; - - -struct CommonParameterInterface -{ - - virtual ~CommonParameterInterface() {} - virtual void registerSliderFloatParameter(SliderParams& params)=0; - virtual void syncParameters()=0; - virtual void removeAllParameters()=0; - virtual void setSliderValue(int sliderIndex, double sliderValue)=0; - -}; - -#endif //PARAM_INTERFACE_H diff --git a/btgui/Bullet3AppSupport/CommonPhysicsSetup.h b/btgui/Bullet3AppSupport/CommonPhysicsSetup.h deleted file mode 100644 index 616e352de..000000000 --- a/btgui/Bullet3AppSupport/CommonPhysicsSetup.h +++ /dev/null @@ -1,102 +0,0 @@ - -#ifndef COMMON_PHYSICS_SETUP_H -#define COMMON_PHYSICS_SETUP_H - -class btRigidBody; -class btCollisionObject; -class btBoxShape; -class btTransform; -class btCollisionShape; -#include "LinearMath/btVector3.h" -#include "CommonParameterInterface.h" - -class btDiscreteDynamicsWorld; - -///The Bullet 2 GraphicsPhysicsBridge let's the graphics engine create graphics representation and synchronize -struct GraphicsPhysicsBridge -{ - virtual ~GraphicsPhysicsBridge() {} - - virtual void createRigidBodyGraphicsObject(btRigidBody* body,const btVector3& color) - { - } - - virtual void createCollisionObjectGraphicsObject(btCollisionObject* obj,const btVector3& color) - { - } - virtual void createCollisionShapeGraphicsObject(btCollisionShape* collisionShape) - { - } - virtual void syncPhysicsToGraphics(const btDiscreteDynamicsWorld* rbWorld) - { - } - virtual void createPhysicsDebugDrawer( btDiscreteDynamicsWorld* rbWorld) - { - } - - virtual int registerGraphicsShape(const float* vertices, int numvertices, const int* indices, int numIndices) { return -1; }//, int primitiveType = B3_GL_TRIANGLES, int textureIndex = -1); - - virtual int registerGraphicsInstance(int shapeIndex, const float* position, const float* quaternion, const float* color, const float* scaling) { return -1;} - - virtual struct Common2dCanvasInterface* get2dCanvasInterface() - { - return 0; - } - - virtual CommonParameterInterface* getParameterInterface() - { - return 0; - } - - virtual struct CommonRenderInterface* getRenderInterface() - { - return 0; - } - virtual void setUpAxis(int axis) - { - } - - virtual void autogenerateGraphicsObjects(btDiscreteDynamicsWorld* rbWorld) - { - } - - virtual void drawText3D( const char* txt, float posX, float posZY, float posZ, float size) - { - - } -}; - -///Bullet 2 specific physics setup, that allows to share code between old and new demo frameworks -struct CommonPhysicsSetup -{ -public: - - virtual ~CommonPhysicsSetup() {} - - virtual void initPhysics(GraphicsPhysicsBridge& gfxBridge) = 0; - - virtual void exitPhysics()=0; - - virtual void stepSimulation(float deltaTime)=0; - - virtual void debugDraw(int debugDrawFlags)=0; - - virtual void renderScene(GraphicsPhysicsBridge& gfxBridge){}; - - virtual bool pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) = 0; - virtual bool movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld)=0; - virtual void removePickingConstraint() = 0; - - virtual void syncPhysicsToGraphics(GraphicsPhysicsBridge& gfxBridge) = 0; -/* - virtual btRigidBody* createRigidBody(float mass, const btTransform& startTransform,btCollisionShape* shape, const btVector4& color=btVector4(1,0,0,1))=0; - - virtual btBoxShape* createBoxShape(const btVector3& halfExtents)=0; - */ -}; - - - -#endif //COMMON_PHYSICS_SETUP_H - - diff --git a/btgui/Bullet3AppSupport/CommonRigidBodySetup.h b/btgui/Bullet3AppSupport/CommonRigidBodySetup.h deleted file mode 100644 index 239bd13f3..000000000 --- a/btgui/Bullet3AppSupport/CommonRigidBodySetup.h +++ /dev/null @@ -1,251 +0,0 @@ - -#ifndef COMMON_RIGID_BODY_SETUP_H -#define COMMON_RIGID_BODY_SETUP_H - -//todo: replace this 'btBulletDynamicsCommon.h' header with specific used header files -#include "btBulletDynamicsCommon.h" -#include "CommonPhysicsSetup.h" - -struct CommonRigidBodySetup : public CommonPhysicsSetup -{ - //keep the collision shapes, for deletion/cleanup - btAlignedObjectArray m_collisionShapes; - btBroadphaseInterface* m_broadphase; - btCollisionDispatcher* m_dispatcher; - btConstraintSolver* m_solver; - btDefaultCollisionConfiguration* m_collisionConfiguration; - btDiscreteDynamicsWorld* m_dynamicsWorld; - - //data for picking objects - class btRigidBody* m_pickedBody; - class btTypedConstraint* m_pickedConstraint; - btVector3 m_oldPickingPos; - btVector3 m_hitPos; - btScalar m_oldPickingDist; - - CommonRigidBodySetup() - :m_broadphase(0), - m_dispatcher(0), - m_solver(0), - m_collisionConfiguration(0), - m_dynamicsWorld(0), - m_pickedBody(0), - m_pickedConstraint(0) - { - } - - virtual void createEmptyDynamicsWorld() - { - ///collision configuration contains default setup for memory, collision setup - m_collisionConfiguration = new btDefaultCollisionConfiguration(); - //m_collisionConfiguration->setConvexConvexMultipointIterations(); - - ///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded) - m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration); - - m_broadphase = new btDbvtBroadphase(); - - ///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded) - btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver; - m_solver = sol; - - m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher, m_broadphase, m_solver, m_collisionConfiguration); - - m_dynamicsWorld->setGravity(btVector3(0, -10, 0)); - } - - - virtual void stepSimulation(float deltaTime) - { - if (m_dynamicsWorld) - { - m_dynamicsWorld->stepSimulation(deltaTime); - } - } - - - virtual void exitPhysics() - { - removePickingConstraint(); - //cleanup in the reverse order of creation/initialization - - //remove the rigidbodies from the dynamics world and delete them - - if (m_dynamicsWorld) - { - - int i; - for (i = m_dynamicsWorld->getNumConstraints() - 1; i >= 0; i--) - { - m_dynamicsWorld->removeConstraint(m_dynamicsWorld->getConstraint(i)); - } - for (i = m_dynamicsWorld->getNumCollisionObjects() - 1; i >= 0; i--) - { - btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i]; - btRigidBody* body = btRigidBody::upcast(obj); - if (body && body->getMotionState()) - { - delete body->getMotionState(); - } - m_dynamicsWorld->removeCollisionObject(obj); - delete obj; - } - } - //delete collision shapes - for (int j = 0; jgetDebugDrawer()) - { - m_dynamicsWorld->getDebugDrawer()->setDebugMode(debugDrawFlags); - } - m_dynamicsWorld->debugDrawWorld(); - } - - } - - virtual bool pickBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) - { - if (m_dynamicsWorld==0) - return false; - - btCollisionWorld::ClosestRayResultCallback rayCallback(rayFromWorld, rayToWorld); - - m_dynamicsWorld->rayTest(rayFromWorld, rayToWorld, rayCallback); - if (rayCallback.hasHit()) - { - - btVector3 pickPos = rayCallback.m_hitPointWorld; - btRigidBody* body = (btRigidBody*)btRigidBody::upcast(rayCallback.m_collisionObject); - if (body) - { - //other exclusions? - if (!(body->isStaticObject() || body->isKinematicObject())) - { - m_pickedBody = body; - m_pickedBody->setActivationState(DISABLE_DEACTIVATION); - //printf("pickPos=%f,%f,%f\n",pickPos.getX(),pickPos.getY(),pickPos.getZ()); - btVector3 localPivot = body->getCenterOfMassTransform().inverse() * pickPos; - btPoint2PointConstraint* p2p = new btPoint2PointConstraint(*body, localPivot); - m_dynamicsWorld->addConstraint(p2p, true); - m_pickedConstraint = p2p; - btScalar mousePickClamping = 30.f; - p2p->m_setting.m_impulseClamp = mousePickClamping; - //very weak constraint for picking - p2p->m_setting.m_tau = 0.001f; - } - } - - - // pickObject(pickPos, rayCallback.m_collisionObject); - m_oldPickingPos = rayToWorld; - m_hitPos = pickPos; - m_oldPickingDist = (pickPos - rayFromWorld).length(); - // printf("hit !\n"); - //add p2p - } - return false; - } - virtual bool movePickedBody(const btVector3& rayFromWorld, const btVector3& rayToWorld) - { - if (m_pickedBody && m_pickedConstraint) - { - btPoint2PointConstraint* pickCon = static_cast(m_pickedConstraint); - if (pickCon) - { - //keep it at the same picking distance - - btVector3 newPivotB; - - btVector3 dir = rayToWorld - rayFromWorld; - dir.normalize(); - dir *= m_oldPickingDist; - - newPivotB = rayFromWorld + dir; - pickCon->setPivotB(newPivotB); - return true; - } - } - return false; - } - virtual void removePickingConstraint() - { - if (m_pickedConstraint) - { - m_dynamicsWorld->removeConstraint(m_pickedConstraint); - delete m_pickedConstraint; - m_pickedConstraint = 0; - m_pickedBody = 0; - } - } - - - - btBoxShape* createBoxShape(const btVector3& halfExtents) - { - btBoxShape* box = new btBoxShape(halfExtents); - return box; - } - - btRigidBody* createRigidBody(float mass, const btTransform& startTransform, btCollisionShape* shape, const btVector4& color = btVector4(1, 0, 0, 1)) - { - btAssert((!shape || shape->getShapeType() != INVALID_SHAPE_PROXYTYPE)); - - //rigidbody is dynamic if and only if mass is non zero, otherwise static - bool isDynamic = (mass != 0.f); - - btVector3 localInertia(0, 0, 0); - if (isDynamic) - shape->calculateLocalInertia(mass, localInertia); - - //using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects - -#define USE_MOTIONSTATE 1 -#ifdef USE_MOTIONSTATE - btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform); - - btRigidBody::btRigidBodyConstructionInfo cInfo(mass, myMotionState, shape, localInertia); - - btRigidBody* body = new btRigidBody(cInfo); - //body->setContactProcessingThreshold(m_defaultContactProcessingThreshold); - -#else - btRigidBody* body = new btRigidBody(mass, 0, shape, localInertia); - body->setWorldTransform(startTransform); -#endif// - - body->setUserIndex(-1); - m_dynamicsWorld->addRigidBody(body); - return body; - } -}; - -#endif //COMMON_RIGID_BODY_SETUP_H - diff --git a/btgui/Bullet3AppSupport/GraphingTexture.cpp b/btgui/Bullet3AppSupport/GraphingTexture.cpp deleted file mode 100644 index 19eac1ff8..000000000 --- a/btgui/Bullet3AppSupport/GraphingTexture.cpp +++ /dev/null @@ -1,189 +0,0 @@ -#include "GraphingTexture.h" -#include "OpenGLWindow/OpenGLInclude.h" -#include - -GraphingTexture::GraphingTexture() -:m_textureId(0), -m_width(0), -m_height(0) -{ -} - -GraphingTexture::~GraphingTexture() -{ - destroy(); -} - -void GraphingTexture::destroy() -{ - //TODO(erwincoumans) release memory etc... - m_width = 0; - m_height=0; - glDeleteTextures(1,(GLuint*)&m_textureId); - m_textureId=0; -} - -bool GraphingTexture::create(int texWidth, int texHeight) -{ - m_width = texWidth; - m_height = texHeight; - glActiveTexture(GL_TEXTURE0); - - m_imageData.resize(texWidth*texHeight*4); - for(int y=0;y>5; - GLubyte* pi=&m_imageData[y*texWidth*4]; - for(int x=0;x=y)//x<2||y<2||x>253||y>253) - { - pi[0]=0; - pi[1]=0; - pi[2]=255; - pi[3]=255; - } else - { - pi[0]=255; - pi[1]=0; - pi[2]=0; - pi[3]=255; - } - - pi+=4; - } - } - - - glGenTextures(1,(GLuint*)&m_textureId); - - uploadImageData(); - return true; -} - -void GraphingTexture::uploadImageData() -{ - glBindTexture(GL_TEXTURE_2D,m_textureId); - assert(glGetError()==GL_NO_ERROR); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, m_width,m_height,0,GL_RGBA,GL_UNSIGNED_BYTE,&m_imageData[0]); - glGenerateMipmap(GL_TEXTURE_2D); - - assert(glGetError()==GL_NO_ERROR); - - -} - -#if 0 -//shift the image one pixel -for(int y=0;y>5; - for(int x=1;x m_imageData; - int m_width; - int m_height; - - GraphingTexture(); - virtual ~GraphingTexture(); - - bool create(int texWidth, int texHeight); - void destroy(); - - void setPixel(int x, int y, unsigned char red, unsigned char green, unsigned char blue, unsigned char alpha) - { - m_imageData[x*4+y*4*m_width+0] = red; - m_imageData[x*4+y*4*m_width+1] = green; - m_imageData[x*4+y*4*m_width+2] = blue; - m_imageData[x*4+y*4*m_width+3] = alpha; - } - - void uploadImageData(); - - int getTextureId() - { - return m_textureId; - } -}; - -#endif //GRAPHING_TEXTURE_H - diff --git a/btgui/Bullet3AppSupport/GwenParameterInterface.cpp b/btgui/Bullet3AppSupport/GwenParameterInterface.cpp deleted file mode 100644 index 8c38528b3..000000000 --- a/btgui/Bullet3AppSupport/GwenParameterInterface.cpp +++ /dev/null @@ -1,167 +0,0 @@ -#include "GwenParameterInterface.h" -#include "gwenInternalData.h" - - - -template -struct MySliderEventHandler : public Gwen::Event::Handler -{ - Gwen::Controls::TextBox* m_label; - Gwen::Controls::Slider* m_pSlider; - char m_variableName[1024]; - T* m_targetValue; - bool m_showValue; - - MySliderEventHandler(const char* varName, Gwen::Controls::TextBox* label, Gwen::Controls::Slider* pSlider,T* target) - :m_label(label), - m_pSlider(pSlider), - m_targetValue(target), - m_showValue(true) - { - memcpy(m_variableName,varName,strlen(varName)+1); - } - - - void SliderMoved( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::Slider* pSlider = (Gwen::Controls::Slider*)pControl; - //printf("value = %f\n", pSlider->GetValue());//UnitPrint( Utility::Format( L"Slider Value: %.2f", pSlider->GetValue() ) ); - float bla = pSlider->GetValue(); - T v = T(bla); - SetValue(v); - - } - - void SetValue(T v) - { - if (v < m_pSlider->GetRangeMin()) - { - printf("?\n"); - } - - if (v > m_pSlider->GetRangeMax()) - { - printf("?\n"); - - } - m_pSlider->SetValue(v,true); - (*m_targetValue) = v; - float val = float(v);//todo: specialize on template type - if (m_showValue) - { - char txt[1024]; - sprintf(txt,"%s : %.3f", m_variableName,val); - m_label->SetText(txt); - } - - } -}; - - -struct GwenParameters -{ - b3AlignedObjectArray*> m_sliderEventHandlers; - b3AlignedObjectArray m_sliders; - b3AlignedObjectArray m_textLabels; - int m_savedYposition; -}; - -GwenParameterInterface::GwenParameterInterface(GwenInternalData* gwenInternalData) -:m_gwenInternalData(gwenInternalData) -{ - m_paramInternalData = new GwenParameters; - m_paramInternalData->m_savedYposition = m_gwenInternalData->m_curYposition; - -} - -GwenParameterInterface::~GwenParameterInterface() -{ - - removeAllParameters(); - delete m_paramInternalData; -} - - -void GwenParameterInterface::setSliderValue(int sliderIndex, double sliderValue) -{ - int sliderCapped = sliderValue+4; - sliderCapped /= 8; - sliderCapped *= 8; - - if (sliderIndex>=0 && sliderIndexm_sliders.size()) - { - m_paramInternalData->m_sliders[sliderIndex]->GetRangeMin(); - - m_paramInternalData->m_sliders[sliderIndex]->GetRangeMax(); - float mappedValue =m_paramInternalData->m_sliders[sliderIndex]->GetRangeMin()+ - (m_paramInternalData->m_sliders[sliderIndex]->GetRangeMax()- - m_paramInternalData->m_sliders[sliderIndex]->GetRangeMin())*sliderCapped/128.f; - printf("mappedValue = %f\n",mappedValue); - m_paramInternalData->m_sliders[sliderIndex]->SetValue(mappedValue); - } -} - -#include -void GwenParameterInterface::registerSliderFloatParameter(SliderParams& params) -{ - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox(m_gwenInternalData->m_demoPage->GetPage()); - m_paramInternalData->m_textLabels.push_back(label); - //m_data->m_myControls.push_back(label); - label->SetText( params.m_name); - label->SetPos( 10, 10 + 25 ); - label->SetWidth(110); - label->SetPos(10,m_gwenInternalData->m_curYposition); - m_gwenInternalData->m_curYposition+=22; - - Gwen::Controls::HorizontalSlider* pSlider = new Gwen::Controls::HorizontalSlider( m_gwenInternalData->m_demoPage->GetPage()); - m_paramInternalData->m_sliders.push_back(pSlider); - //m_data->m_myControls.push_back(pSlider); - pSlider->SetPos( 10, m_gwenInternalData->m_curYposition ); - pSlider->SetSize( 100, 20 ); - pSlider->SetRange( params.m_minVal, params.m_maxVal); - pSlider->SetNotchCount(128);//float(params.m_maxVal-params.m_minVal)/100.f); - pSlider->SetClampToNotches( params.m_clampToNotches ); - pSlider->SetValue( *params.m_paramValuePointer);//dimensions[i] ); - char labelName[1024]; - sprintf(labelName,"%s",params.m_name);//axisNames[0]); - MySliderEventHandler* handler = new MySliderEventHandler(labelName,label,pSlider,params.m_paramValuePointer); - handler->m_showValue = params.m_showValues; - m_paramInternalData->m_sliderEventHandlers.push_back(handler); - - pSlider->onValueChanged.Add( handler, &MySliderEventHandler::SliderMoved ); - handler->SliderMoved(pSlider); -// float v = pSlider->GetValue(); - m_gwenInternalData->m_curYposition+=22; -} - -void GwenParameterInterface::syncParameters() -{ - for (int i=0;im_sliderEventHandlers.size();i++) - { - MySliderEventHandler* handler = m_paramInternalData->m_sliderEventHandlers[i]; - handler->m_pSlider->SetValue(*handler->m_targetValue,true); - } -} - -void GwenParameterInterface::removeAllParameters() -{ - for (int i=0;im_sliders.size();i++) - { - delete m_paramInternalData->m_sliders[i]; - } - m_paramInternalData->m_sliders.clear(); - - for (int i=0;im_sliderEventHandlers.size();i++) - { - delete m_paramInternalData->m_sliderEventHandlers[i]; - } - m_paramInternalData->m_sliderEventHandlers.clear(); - - for (int i=0;im_textLabels.size();i++) - { - delete m_paramInternalData->m_textLabels[i]; - } - m_paramInternalData->m_textLabels.clear(); - - m_gwenInternalData->m_curYposition = this->m_paramInternalData->m_savedYposition; -} \ No newline at end of file diff --git a/btgui/Bullet3AppSupport/GwenParameterInterface.h b/btgui/Bullet3AppSupport/GwenParameterInterface.h deleted file mode 100644 index a78ec20cb..000000000 --- a/btgui/Bullet3AppSupport/GwenParameterInterface.h +++ /dev/null @@ -1,21 +0,0 @@ -#ifndef GWEN_PARAMETER_INTERFACE_H -#define GWEN_PARAMETER_INTERFACE_H - -#include "CommonParameterInterface.h" - -struct GwenParameterInterface : public CommonParameterInterface -{ - struct GwenInternalData* m_gwenInternalData; - - struct GwenParameters* m_paramInternalData; - - GwenParameterInterface(struct GwenInternalData* gwenInternalData); - virtual ~GwenParameterInterface(); - virtual void registerSliderFloatParameter(SliderParams& params); - virtual void setSliderValue(int sliderIndex, double sliderValue); - virtual void syncParameters(); - virtual void removeAllParameters(); - -}; - -#endif//GWEN_PARAMETER_INTERFACE_H diff --git a/btgui/Bullet3AppSupport/GwenProfileWindow.cpp b/btgui/Bullet3AppSupport/GwenProfileWindow.cpp deleted file mode 100644 index b10db3ef0..000000000 --- a/btgui/Bullet3AppSupport/GwenProfileWindow.cpp +++ /dev/null @@ -1,292 +0,0 @@ -#include "GwenProfileWindow.h" -#include "gwenUserInterface.h" -#include "gwenInternalData.h" -#include "LinearMath/btQuickprof.h" - - - - - -class MyProfileWindow : public Gwen::Controls::WindowControl -{ - - // Gwen::Controls::TabControl* m_TabControl; - //Gwen::Controls::ListBox* m_TextOutput; - unsigned int m_iFrames; - float m_fLastSecond; - - Gwen::Controls::TreeNode* m_node; - Gwen::Controls::TreeControl* m_ctrl; - - -protected: - - void onButtonA( Gwen::Controls::Base* pControl ) - { - // OpenTissue::glut::toggleIdle(); - } - - void SliderMoved(Gwen::Controls::Base* pControl ) - { - // Gwen::Controls::Slider* pSlider = (Gwen::Controls::Slider*)pControl; - //this->m_app->scaleYoungModulus(pSlider->GetValue()); - // printf("Slider Value: %.2f", pSlider->GetValue() ); - } - - - void OnCheckChangedStiffnessWarping (Gwen::Controls::Base* pControl) - { - // Gwen::Controls::CheckBox* labeled = (Gwen::Controls::CheckBox* )pControl; -// bool checked = labeled->IsChecked(); - //m_app->m_stiffness_warp_on = checked; - } -public: - - - CProfileIterator* profIter; - - MyProfileWindow ( Gwen::Controls::Base* pParent) - : Gwen::Controls::WindowControl( pParent ), - profIter(0) - { - SetTitle( L"Time Profiler" ); - - SetSize( 450, 450 ); - this->SetPos(10,400); - - // this->Dock( Gwen::Pos::Bottom); - - - - { - m_ctrl = new Gwen::Controls::TreeControl( this ); - m_node = m_ctrl->AddNode( L"Total Parent Time" ); - - - //Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - //pNode->AddNode( L"Node Two Inside" ); - //pNode->AddNode( L"Eyes" ); - //pNode->AddNode( L"Brown" )->AddNode( L"Node Two Inside" )->AddNode( L"Eyes" )->AddNode( L"Brown" ); - //Gwen::Controls::TreeNode* node = ctrl->AddNode( L"Node Three" ); - - - - //m_ctrl->Dock(Gwen::Pos::Bottom); - - m_ctrl->ExpandAll(); - m_ctrl->SetKeyboardInputEnabled(true); - m_ctrl->SetBounds( this->GetInnerBounds().x,this->GetInnerBounds().y,this->GetInnerBounds().w,this->GetInnerBounds().h); - - } - - - - } - - - float dumpRecursive(CProfileIterator* profileIterator, Gwen::Controls::TreeNode* parentNode) - { - profileIterator->First(); - if (profileIterator->Is_Done()) - return 0.f; - - float accumulated_time=0,parent_time = profileIterator->Is_Root() ? CProfileManager::Get_Time_Since_Reset() : profileIterator->Get_Current_Parent_Total_Time(); - int i; - int frames_since_reset = CProfileManager::Get_Frame_Count_Since_Reset(); - - //printf("Profiling: %s (total running time: %.3f ms) ---\n", profileIterator->Get_Current_Parent_Name(), parent_time ); - float totalTime = 0.f; - - - int numChildren = 0; - Gwen::UnicodeString txt; - std::vector nodes; - - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - numChildren++; - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - double fraction = parent_time > SIMD_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - - Gwen::String name(profileIterator->Get_Current_Name()); -#ifdef _WIN32 - Gwen::UnicodeString uname = Gwen::Utility::StringToUnicode(name); - - txt = Gwen::Utility::Format(L"%s (%.2f %%) :: %.3f ms / frame (%d calls)",uname.c_str(), fraction,(current_total_time / (double)frames_since_reset),profileIterator->Get_Current_Total_Calls()); - -#else - txt = Gwen::Utility::Format(L"%s (%.2f %%) :: %.3f ms / frame (%d calls)",name.c_str(), fraction,(current_total_time / (double)frames_since_reset),profileIterator->Get_Current_Total_Calls()); - -#endif - - Gwen::Controls::TreeNode* childNode = (Gwen::Controls::TreeNode*)profileIterator->Get_Current_UserPointer(); - if (!childNode) - { - childNode = parentNode->AddNode(L""); - profileIterator->Set_Current_UserPointer(childNode); - } - childNode->SetText(txt); - nodes.push_back(childNode); - - totalTime += current_total_time; - //recurse into children - } - - for (i=0;iEnter_Child(i); - Gwen::Controls::TreeNode* curNode = nodes[i]; - - dumpRecursive(profileIterator, curNode); - - profileIterator->Enter_Parent(); - } - return accumulated_time; - - } - - void UpdateText(CProfileIterator* profileIterator, bool idle) - { - - // static bool update=true; - - m_ctrl->SetBounds(0,0,this->GetInnerBounds().w,this->GetInnerBounds().h); - - // if (!update) - // return; - // update=false; - - - static int test = 1; - test++; - - static double time_since_reset = 0.f; - if (!idle) - { - time_since_reset = CProfileManager::Get_Time_Since_Reset(); - } - - //Gwen::UnicodeString txt = Gwen::Utility::Format( L"FEM Settings %i fps", test ); - { - //recompute profiling data, and store profile strings - - // char blockTime[128]; - - // double totalTime = 0; - - // int frames_since_reset = CProfileManager::Get_Frame_Count_Since_Reset(); - - profileIterator->First(); - - double parent_time = profileIterator->Is_Root() ? time_since_reset : profileIterator->Get_Current_Parent_Total_Time(); - - - // Gwen::Controls::TreeNode* curParent = m_node; - - double accumulated_time = dumpRecursive(profileIterator,m_node); - - const char* name = profileIterator->Get_Current_Parent_Name(); -#ifdef _WIN32 - Gwen::UnicodeString uname = Gwen::Utility::StringToUnicode(name); - Gwen::UnicodeString txt = Gwen::Utility::Format( L"Profiling: %s total time: %.3f ms, unaccounted %.3f %% :: %.3f ms", uname.c_str(), parent_time , - parent_time > SIMD_EPSILON ? ((parent_time - accumulated_time) / parent_time) * 100 : 0.f, parent_time - accumulated_time); -#else - Gwen::UnicodeString txt = Gwen::Utility::Format( L"Profiling: %s total time: %.3f ms, unaccounted %.3f %% :: %.3f ms", name, parent_time , - parent_time > SIMD_EPSILON ? ((parent_time - accumulated_time) / parent_time) * 100 : 0.f, parent_time - accumulated_time); -#endif - //sprintf(blockTime,"--- Profiling: %s (total running time: %.3f ms) ---", profileIterator->Get_Current_Parent_Name(), parent_time ); - //displayProfileString(xOffset,yStart,blockTime); - m_node->SetText(txt); - - - //printf("%s (%.3f %%) :: %.3f ms\n", "Unaccounted:",); - - - } - - static int counter=10; - if (counter) - { - counter--; - m_ctrl->ExpandAll(); - } - - } - void PrintText( const Gwen::UnicodeString& str ) - { - - } - - void Render( Gwen::Skin::Base* skin ) - { - m_iFrames++; - - if ( m_fLastSecond < Gwen::Platform::GetTimeInSeconds() ) - { - SetTitle( Gwen::Utility::Format( L"Profiler %i fps", m_iFrames ) ); - - m_fLastSecond = Gwen::Platform::GetTimeInSeconds() + 1.0f; - m_iFrames = 0; - } - - Gwen::Controls::WindowControl::Render( skin ); - - } - - -}; - -class MyMenuItems : public Gwen::Controls::Base -{ - -public: - - class MyProfileWindow* m_profWindow; - MyMenuItems() :Gwen::Controls::Base(0) - { - } - - void MenuItemSelect(Gwen::Controls::Base* pControl) - { - if (m_profWindow->Hidden()) - { - m_profWindow->SetHidden(false); - } else - { - m_profWindow->SetHidden(true); - } - - } -}; - - -MyProfileWindow* setupProfileWindow(GwenInternalData* data) -{ - MyMenuItems* menuItems = new MyMenuItems; - MyProfileWindow* profWindow = new MyProfileWindow(data->pCanvas); - //profWindow->SetHidden(true); - profWindow->profIter = CProfileManager::Get_Iterator(); - data->m_viewMenu->GetMenu()->AddItem( L"Profiler", menuItems,(Gwen::Event::Handler::Function)&MyMenuItems::MenuItemSelect); - menuItems->m_profWindow = profWindow; - return profWindow; -} - - -void processProfileData( MyProfileWindow* profWindow, bool idle) -{ - if (profWindow) - { - - profWindow->UpdateText(profWindow->profIter, idle); - } -} - -void profileWindowSetVisible(MyProfileWindow* window, bool visible) -{ - window->SetHidden(!visible); -} -void destroyProfileWindow(MyProfileWindow* window) -{ - delete window; -} diff --git a/btgui/Bullet3AppSupport/GwenProfileWindow.h b/btgui/Bullet3AppSupport/GwenProfileWindow.h deleted file mode 100644 index 16058e6f5..000000000 --- a/btgui/Bullet3AppSupport/GwenProfileWindow.h +++ /dev/null @@ -1,11 +0,0 @@ -#ifndef GWEN_PROFILE_WINDOW_H -#define GWEN_PROFILE_WINDOW_H - -class MyProfileWindow* setupProfileWindow(struct GwenInternalData* data); -void processProfileData(MyProfileWindow* window, bool idle); -void profileWindowSetVisible(MyProfileWindow* window, bool visible); -void destroyProfileWindow(MyProfileWindow* window); - -#endif//GWEN_PROFILE_WINDOW_H - - diff --git a/btgui/Bullet3AppSupport/GwenTextureWindow.cpp b/btgui/Bullet3AppSupport/GwenTextureWindow.cpp deleted file mode 100644 index 477553f25..000000000 --- a/btgui/Bullet3AppSupport/GwenTextureWindow.cpp +++ /dev/null @@ -1,100 +0,0 @@ -#include "GwenTextureWindow.h" -#include "gwenUserInterface.h" -#include "gwenInternalData.h" -#include "Gwen/Controls/ImagePanel.h" - - - -class MyGraphWindow : public Gwen::Controls::WindowControl -{ - Gwen::Controls::ImagePanel* m_imgPanel; - -public: - - class MyMenuItems2* m_menuItems; - - MyGraphWindow ( const MyGraphInput& input) - : Gwen::Controls::WindowControl( input.m_data->pCanvas ), - m_menuItems(0) - { - Gwen::UnicodeString str = Gwen::Utility::StringToUnicode(input.m_name); - SetTitle( str ); - - - SetPos(input.m_xPos,input.m_yPos); - SetSize( 12+input.m_width+2*input.m_borderWidth, 30+input.m_height+2*input.m_borderWidth ); - - m_imgPanel = new Gwen::Controls::ImagePanel( this ); - if (input.m_texName) - { - Gwen::UnicodeString texName = Gwen::Utility::StringToUnicode(input.m_texName); - m_imgPanel->SetImage( texName ); - } - m_imgPanel->SetBounds( input.m_borderWidth, input.m_borderWidth, - input.m_width, - input.m_height ); - // this->Dock( Gwen::Pos::Bottom); - } - virtual ~MyGraphWindow() - { - delete m_imgPanel; - } - - -}; - -class MyMenuItems2 : public Gwen::Controls::Base -{ - MyGraphWindow* m_graphWindow; - -public: - - Gwen::Controls::MenuItem* m_item; - - MyMenuItems2(MyGraphWindow* graphWindow) - :Gwen::Controls::Base(0), - m_graphWindow(graphWindow), - m_item(0) - { - } - - void MenuItemSelect(Gwen::Controls::Base* pControl) - { - if (m_graphWindow->Hidden()) - { - m_graphWindow->SetHidden(false); - //@TODO(erwincoumans) setCheck/SetCheckable drawing is broken, need to see what's wrong -// if (m_item) -// m_item->SetCheck(false); - - } else - { - m_graphWindow->SetHidden(true); -// if (m_item) -// m_item->SetCheck(true); - - } - - } -}; - -MyGraphWindow* setupTextureWindow(const MyGraphInput& input) -{ - MyGraphWindow* graphWindow = new MyGraphWindow(input); - MyMenuItems2* menuItems = new MyMenuItems2(graphWindow); - graphWindow->m_menuItems = menuItems; - - Gwen::UnicodeString str = Gwen::Utility::StringToUnicode(input.m_name); - menuItems->m_item = input.m_data->m_viewMenu->GetMenu()->AddItem( str, menuItems,(Gwen::Event::Handler::Function)&MyMenuItems2::MenuItemSelect); -// menuItems->m_item->SetCheckable(true); - - return graphWindow; - -} - -void destroyTextureWindow(MyGraphWindow* window) -{ - delete window->m_menuItems->m_item; - delete window->m_menuItems; - delete window; -} diff --git a/btgui/Bullet3AppSupport/GwenTextureWindow.h b/btgui/Bullet3AppSupport/GwenTextureWindow.h deleted file mode 100644 index da06dc55b..000000000 --- a/btgui/Bullet3AppSupport/GwenTextureWindow.h +++ /dev/null @@ -1,32 +0,0 @@ - - -#ifndef GWEN_TEXTURE_WINDOW_H -#define GWEN_TEXTURE_WINDOW_H - -struct MyGraphInput -{ - struct GwenInternalData* m_data; - int m_xPos; - int m_yPos; - int m_width; - int m_height; - int m_borderWidth; - const char* m_name; - const char* m_texName; - MyGraphInput(struct GwenInternalData* data) - :m_data(data), - m_xPos(0), - m_yPos(0), - m_width(400), - m_height(400), - m_borderWidth(0), - m_name("GraphWindow"), - m_texName(0) - { - } -}; -class MyGraphWindow* setupTextureWindow(const MyGraphInput& input); -void destroyTextureWindow(MyGraphWindow* window); - - -#endif //GWEN_TEXTURE_WINDOW_H diff --git a/btgui/Bullet3AppSupport/MyDebugDrawer.h b/btgui/Bullet3AppSupport/MyDebugDrawer.h deleted file mode 100644 index ee9b3a04d..000000000 --- a/btgui/Bullet3AppSupport/MyDebugDrawer.h +++ /dev/null @@ -1,109 +0,0 @@ -#ifndef MY_DEBUG_DRAWER_H -#define MY_DEBUG_DRAWER_H - -#include "LinearMath/btIDebugDraw.h" -#include "LinearMath/btAlignedObjectArray.h" -#include "OpenGLWindow/CommonGraphicsApp.h" - -#define BT_LINE_BATCH_SIZE 512 - -struct MyDebugVec3 -{ - MyDebugVec3(const btVector3& org) - :x(org.x()), - y(org.y()), - z(org.z()) - { - } - - float x; - float y; - float z; -}; -class MyDebugDrawer : public btIDebugDraw -{ - CommonGraphicsApp* m_glApp; - int m_debugMode; - - btAlignedObjectArray m_linePoints; - btAlignedObjectArray m_lineIndices; - btVector3 m_currentLineColor; - -public: - - MyDebugDrawer(CommonGraphicsApp* app) - : m_glApp(app) - ,m_debugMode(btIDebugDraw::DBG_DrawWireframe|btIDebugDraw::DBG_DrawAabb), - m_currentLineColor(-1,-1,-1) - { - - } - virtual void drawLine(const btVector3& from1,const btVector3& to1,const btVector3& color1) - { - //float from[4] = {from1[0],from1[1],from1[2],from1[3]}; - //float to[4] = {to1[0],to1[1],to1[2],to1[3]}; - //float color[4] = {color1[0],color1[1],color1[2],color1[3]}; - //m_glApp->m_instancingRenderer->drawLine(from,to,color); - if (m_currentLineColor!=color1 || m_linePoints.size() >= BT_LINE_BATCH_SIZE) - { - flushLines(); - m_currentLineColor = color1; - } - MyDebugVec3 from(from1); - MyDebugVec3 to(to1); - - m_linePoints.push_back(from); - m_linePoints.push_back(to); - - m_lineIndices.push_back(m_lineIndices.size()); - m_lineIndices.push_back(m_lineIndices.size()); - - } - - virtual void drawContactPoint(const btVector3& PointOnB,const btVector3& normalOnB,btScalar distance,int lifeTime,const btVector3& color) - { - drawLine(PointOnB,PointOnB+normalOnB,color); - } - - - virtual void reportErrorWarning(const char* warningString) - { - } - - virtual void draw3dText(const btVector3& location,const char* textString) - { - } - - virtual void setDebugMode(int debugMode) - { - m_debugMode = debugMode; - } - - virtual int getDebugMode() const - { - return m_debugMode; - } - - virtual void flushLines() - { - int sz = m_linePoints.size(); - if (sz) - { - float debugColor[4]; - debugColor[0] = m_currentLineColor.x(); - debugColor[1] = m_currentLineColor.y(); - debugColor[2] = m_currentLineColor.z(); - debugColor[3] = 1.f; - m_glApp->m_renderer->drawLines(&m_linePoints[0].x,debugColor, - m_linePoints.size(),sizeof(MyDebugVec3), - &m_lineIndices[0], - m_lineIndices.size(), - 1); - m_linePoints.clear(); - m_lineIndices.clear(); - } - } - -}; - -#endif //MY_DEBUG_DRAWER_H diff --git a/btgui/Bullet3AppSupport/b3Clock.cpp b/btgui/Bullet3AppSupport/b3Clock.cpp deleted file mode 100644 index 53a82dee0..000000000 --- a/btgui/Bullet3AppSupport/b3Clock.cpp +++ /dev/null @@ -1,223 +0,0 @@ -#include "b3Clock.h" - -template -const T& b3ClockMin(const T& a, const T& b) -{ - return a < b ? a : b ; -} - - -#ifdef __CELLOS_LV2__ -#include -#include -#include -#endif - -#if defined (SUNOS) || defined (__SUNOS__) -#include -#endif - -#if defined(WIN32) || defined(_WIN32) - -#define B3_USE_WINDOWS_TIMERS -#define WIN32_LEAN_AND_MEAN -#define NOWINRES -#define NOMCX -#define NOIME - -#ifdef _XBOX - #include -#else //_XBOX - #include -#endif //_XBOX - -#include - - -#else //_WIN32 -#include -#endif //_WIN32 - - - -struct b3ClockData -{ - -#ifdef B3_USE_WINDOWS_TIMERS - LARGE_INTEGER mClockFrequency; - DWORD mStartTick; - LONGLONG mPrevElapsedTime; - LARGE_INTEGER mStartTime; -#else -#ifdef __CELLOS_LV2__ - uint64_t mStartTime; -#else - struct timeval mStartTime; -#endif -#endif //__CELLOS_LV2__ - -}; - -///The b3Clock is a portable basic clock that measures accurate time in seconds, use for profiling. -b3Clock::b3Clock() -{ - m_data = new b3ClockData; -#ifdef B3_USE_WINDOWS_TIMERS - QueryPerformanceFrequency(&m_data->mClockFrequency); -#endif - reset(); -} - -b3Clock::~b3Clock() -{ - delete m_data; -} - -b3Clock::b3Clock(const b3Clock& other) -{ - m_data = new b3ClockData; - *m_data = *other.m_data; -} - -b3Clock& b3Clock::operator=(const b3Clock& other) -{ - *m_data = *other.m_data; - return *this; -} - - - /// Resets the initial reference time. -void b3Clock::reset() -{ -#ifdef B3_USE_WINDOWS_TIMERS - QueryPerformanceCounter(&m_data->mStartTime); - m_data->mStartTick = GetTickCount(); - m_data->mPrevElapsedTime = 0; -#else -#ifdef __CELLOS_LV2__ - - typedef uint64_t ClockSize; - ClockSize newTime; - //__asm __volatile__( "mftb %0" : "=r" (newTime) : : "memory"); - SYS_TIMEBASE_GET( newTime ); - m_data->mStartTime = newTime; -#else - gettimeofday(&m_data->mStartTime, 0); -#endif -#endif -} - -/// Returns the time in ms since the last call to reset or since -/// the b3Clock was created. -unsigned long int b3Clock::getTimeMilliseconds() -{ -#ifdef B3_USE_WINDOWS_TIMERS - LARGE_INTEGER currentTime; - QueryPerformanceCounter(¤tTime); - LONGLONG elapsedTime = currentTime.QuadPart - - m_data->mStartTime.QuadPart; - // Compute the number of millisecond ticks elapsed. - unsigned long msecTicks = (unsigned long)(1000 * elapsedTime / - m_data->mClockFrequency.QuadPart); - // Check for unexpected leaps in the Win32 performance counter. - // (This is caused by unexpected data across the PCI to ISA - // bridge, aka south bridge. See Microsoft KB274323.) - unsigned long elapsedTicks = GetTickCount() - m_data->mStartTick; - signed long msecOff = (signed long)(msecTicks - elapsedTicks); - if (msecOff < -100 || msecOff > 100) - { - // Adjust the starting time forwards. - LONGLONG msecAdjustment = b3ClockMin(msecOff * - m_data->mClockFrequency.QuadPart / 1000, elapsedTime - - m_data->mPrevElapsedTime); - m_data->mStartTime.QuadPart += msecAdjustment; - elapsedTime -= msecAdjustment; - - // Recompute the number of millisecond ticks elapsed. - msecTicks = (unsigned long)(1000 * elapsedTime / - m_data->mClockFrequency.QuadPart); - } - - // Store the current elapsed time for adjustments next time. - m_data->mPrevElapsedTime = elapsedTime; - - return msecTicks; -#else - -#ifdef __CELLOS_LV2__ - uint64_t freq=sys_time_get_timebase_frequency(); - double dFreq=((double) freq) / 1000.0; - typedef uint64_t ClockSize; - ClockSize newTime; - SYS_TIMEBASE_GET( newTime ); - //__asm __volatile__( "mftb %0" : "=r" (newTime) : : "memory"); - - return (unsigned long int)((double(newTime-m_data->mStartTime)) / dFreq); -#else - - struct timeval currentTime; - gettimeofday(¤tTime, 0); - return (currentTime.tv_sec - m_data->mStartTime.tv_sec) * 1000 + - (currentTime.tv_usec - m_data->mStartTime.tv_usec) / 1000; -#endif //__CELLOS_LV2__ -#endif -} - - /// Returns the time in us since the last call to reset or since - /// the Clock was created. -unsigned long int b3Clock::getTimeMicroseconds() -{ -#ifdef B3_USE_WINDOWS_TIMERS - LARGE_INTEGER currentTime; - QueryPerformanceCounter(¤tTime); - LONGLONG elapsedTime = currentTime.QuadPart - - m_data->mStartTime.QuadPart; - - // Compute the number of millisecond ticks elapsed. - unsigned long msecTicks = (unsigned long)(1000 * elapsedTime / - m_data->mClockFrequency.QuadPart); - - // Check for unexpected leaps in the Win32 performance counter. - // (This is caused by unexpected data across the PCI to ISA - // bridge, aka south bridge. See Microsoft KB274323.) - unsigned long elapsedTicks = GetTickCount() - m_data->mStartTick; - signed long msecOff = (signed long)(msecTicks - elapsedTicks); - if (msecOff < -100 || msecOff > 100) - { - // Adjust the starting time forwards. - LONGLONG msecAdjustment = b3ClockMin(msecOff * - m_data->mClockFrequency.QuadPart / 1000, elapsedTime - - m_data->mPrevElapsedTime); - m_data->mStartTime.QuadPart += msecAdjustment; - elapsedTime -= msecAdjustment; - } - - // Store the current elapsed time for adjustments next time. - m_data->mPrevElapsedTime = elapsedTime; - - // Convert to microseconds. - unsigned long usecTicks = (unsigned long)(1000000 * elapsedTime / - m_data->mClockFrequency.QuadPart); - - return usecTicks; -#else - -#ifdef __CELLOS_LV2__ - uint64_t freq=sys_time_get_timebase_frequency(); - double dFreq=((double) freq)/ 1000000.0; - typedef uint64_t ClockSize; - ClockSize newTime; - //__asm __volatile__( "mftb %0" : "=r" (newTime) : : "memory"); - SYS_TIMEBASE_GET( newTime ); - - return (unsigned long int)((double(newTime-m_data->mStartTime)) / dFreq); -#else - - struct timeval currentTime; - gettimeofday(¤tTime, 0); - return (currentTime.tv_sec - m_data->mStartTime.tv_sec) * 1000000 + - (currentTime.tv_usec - m_data->mStartTime.tv_usec); -#endif//__CELLOS_LV2__ -#endif -} - diff --git a/btgui/Bullet3AppSupport/b3Clock.h b/btgui/Bullet3AppSupport/b3Clock.h deleted file mode 100644 index d30c615a3..000000000 --- a/btgui/Bullet3AppSupport/b3Clock.h +++ /dev/null @@ -1,31 +0,0 @@ -#ifndef B3_CLOCK_H -#define B3_CLOCK_H - - -///The b3Clock is a portable basic clock that measures accurate time in seconds, use for profiling. -class b3Clock -{ -public: - b3Clock(); - - b3Clock(const b3Clock& other); - b3Clock& operator=(const b3Clock& other); - - ~b3Clock(); - - /// Resets the initial reference time. - void reset(); - - /// Returns the time in ms since the last call to reset or since - /// the b3Clock was created. - unsigned long int getTimeMilliseconds(); - - /// Returns the time in us since the last call to reset or since - /// the Clock was created. - unsigned long int getTimeMicroseconds(); -private: - struct b3ClockData* m_data; -}; - - -#endif //B3_CLOCK_H diff --git a/btgui/Bullet3AppSupport/b3Quickprof.cpp b/btgui/Bullet3AppSupport/b3Quickprof.cpp deleted file mode 100644 index 4ba9158dd..000000000 --- a/btgui/Bullet3AppSupport/b3Quickprof.cpp +++ /dev/null @@ -1,430 +0,0 @@ -/* -Copyright (c) 2003-2013 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/* - -*************************************************************************************************** -** -** profile.cpp -** -** Real-Time Hierarchical Profiling for Game Programming Gems 3 -** -** by Greg Hjelstrom & Byon Garrabrant -** -***************************************************************************************************/ - -// Credits: The Clock class was inspired by the Timer classes in -// Ogre (www.ogre3d.org). - -#include "Bullet3Common/b3MinMax.h" -#include "b3Quickprof.h" - - -#ifndef B3_NO_PROFILE - - -static b3Clock b3s_profileClock; - - - - - - -inline void b3Profile_Get_Ticks(unsigned long int * ticks) -{ - *ticks = b3s_profileClock.getTimeMicroseconds(); -} - -inline float b3Profile_Get_Tick_Rate(void) -{ -// return 1000000.f; - return 1000.f; - -} - - - -/*************************************************************************************************** -** -** b3ProfileNode -** -***************************************************************************************************/ - -/*********************************************************************************************** - * INPUT: * - * name - pointer to a static string which is the name of this profile node * - * parent - parent pointer * - * * - * WARNINGS: * - * The name is assumed to be a static pointer, only the pointer is stored and compared for * - * efficiency reasons. * - *=============================================================================================*/ -b3ProfileNode::b3ProfileNode( const char * name, b3ProfileNode * parent ) : - Name( name ), - TotalCalls( 0 ), - TotalTime( 0 ), - StartTime( 0 ), - RecursionCounter( 0 ), - Parent( parent ), - Child( NULL ), - Sibling( NULL ), - m_userPtr(0) -{ - Reset(); -} - - -void b3ProfileNode::CleanupMemory() -{ - delete ( Child); - Child = NULL; - delete ( Sibling); - Sibling = NULL; -} - -b3ProfileNode::~b3ProfileNode( void ) -{ - delete ( Child); - delete ( Sibling); -} - - -/*********************************************************************************************** - * INPUT: * - * name - static string pointer to the name of the node we are searching for * - * * - * WARNINGS: * - * All profile names are assumed to be static strings so this function uses pointer compares * - * to find the named node. * - *=============================================================================================*/ -b3ProfileNode * b3ProfileNode::Get_Sub_Node( const char * name ) -{ - // Try to find this sub node - b3ProfileNode * child = Child; - while ( child ) { - if ( child->Name == name ) { - return child; - } - child = child->Sibling; - } - - // We didn't find it, so add it - - b3ProfileNode * node = new b3ProfileNode( name, this ); - node->Sibling = Child; - Child = node; - return node; -} - - -void b3ProfileNode::Reset( void ) -{ - TotalCalls = 0; - TotalTime = 0.0f; - - - if ( Child ) { - Child->Reset(); - } - if ( Sibling ) { - Sibling->Reset(); - } -} - - -void b3ProfileNode::Call( void ) -{ - TotalCalls++; - if (RecursionCounter++ == 0) { - b3Profile_Get_Ticks(&StartTime); - } -} - - -bool b3ProfileNode::Return( void ) -{ - if ( --RecursionCounter == 0 && TotalCalls != 0 ) { - unsigned long int time; - b3Profile_Get_Ticks(&time); - time-=StartTime; - TotalTime += (float)time / b3Profile_Get_Tick_Rate(); - } - return ( RecursionCounter == 0 ); -} - - -/*************************************************************************************************** -** -** b3ProfileIterator -** -***************************************************************************************************/ -b3ProfileIterator::b3ProfileIterator( b3ProfileNode * start ) -{ - CurrentParent = start; - CurrentChild = CurrentParent->Get_Child(); -} - - -void b3ProfileIterator::First(void) -{ - CurrentChild = CurrentParent->Get_Child(); -} - - -void b3ProfileIterator::Next(void) -{ - CurrentChild = CurrentChild->Get_Sibling(); -} - - -bool b3ProfileIterator::Is_Done(void) -{ - return CurrentChild == NULL; -} - - -void b3ProfileIterator::Enter_Child( int index ) -{ - CurrentChild = CurrentParent->Get_Child(); - while ( (CurrentChild != NULL) && (index != 0) ) { - index--; - CurrentChild = CurrentChild->Get_Sibling(); - } - - if ( CurrentChild != NULL ) { - CurrentParent = CurrentChild; - CurrentChild = CurrentParent->Get_Child(); - } -} - - -void b3ProfileIterator::Enter_Parent( void ) -{ - if ( CurrentParent->Get_Parent() != NULL ) { - CurrentParent = CurrentParent->Get_Parent(); - } - CurrentChild = CurrentParent->Get_Child(); -} - - -/*************************************************************************************************** -** -** b3ProfileManager -** -***************************************************************************************************/ - -b3ProfileNode b3ProfileManager::Root( "Root", NULL ); -b3ProfileNode * b3ProfileManager::CurrentNode = &b3ProfileManager::Root; -int b3ProfileManager::FrameCounter = 0; -unsigned long int b3ProfileManager::ResetTime = 0; - - -/*********************************************************************************************** - * b3ProfileManager::Start_Profile -- Begin a named profile * - * * - * Steps one level deeper into the tree, if a child already exists with the specified name * - * then it accumulates the profiling; otherwise a new child node is added to the profile tree. * - * * - * INPUT: * - * name - name of this profiling record * - * * - * WARNINGS: * - * The string used is assumed to be a static string; pointer compares are used throughout * - * the profiling code for efficiency. * - *=============================================================================================*/ -void b3ProfileManager::Start_Profile( const char * name ) -{ - if (name != CurrentNode->Get_Name()) { - CurrentNode = CurrentNode->Get_Sub_Node( name ); - } - - CurrentNode->Call(); -} - - -/*********************************************************************************************** - * b3ProfileManager::Stop_Profile -- Stop timing and record the results. * - *=============================================================================================*/ -void b3ProfileManager::Stop_Profile( void ) -{ - // Return will indicate whether we should back up to our parent (we may - // be profiling a recursive function) - if (CurrentNode->Return()) { - CurrentNode = CurrentNode->Get_Parent(); - } -} - - -/*********************************************************************************************** - * b3ProfileManager::Reset -- Reset the contents of the profiling system * - * * - * This resets everything except for the tree structure. All of the timing data is reset. * - *=============================================================================================*/ -void b3ProfileManager::Reset( void ) -{ - b3s_profileClock.reset(); - Root.Reset(); - Root.Call(); - FrameCounter = 0; - b3Profile_Get_Ticks(&ResetTime); -} - - -/*********************************************************************************************** - * b3ProfileManager::Increment_Frame_Counter -- Increment the frame counter * - *=============================================================================================*/ -void b3ProfileManager::Increment_Frame_Counter( void ) -{ - FrameCounter++; -} - - -/*********************************************************************************************** - * b3ProfileManager::Get_Time_Since_Reset -- returns the elapsed time since last reset * - *=============================================================================================*/ -float b3ProfileManager::Get_Time_Since_Reset( void ) -{ - unsigned long int time; - b3Profile_Get_Ticks(&time); - time -= ResetTime; - return (float)time / b3Profile_Get_Tick_Rate(); -} - -#include - -void b3ProfileManager::dumpRecursive(b3ProfileIterator* profileIterator, int spacing) -{ - profileIterator->First(); - if (profileIterator->Is_Done()) - return; - - float accumulated_time=0,parent_time = profileIterator->Is_Root() ? b3ProfileManager::Get_Time_Since_Reset() : profileIterator->Get_Current_Parent_Total_Time(); - int i; - int frames_since_reset = b3ProfileManager::Get_Frame_Count_Since_Reset(); - for (i=0;iGet_Current_Parent_Name(), parent_time ); - float totalTime = 0.f; - - - int numChildren = 0; - - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - numChildren++; - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - float fraction = parent_time > B3_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - { - int i; for (i=0;iGet_Current_Name(), fraction,(current_total_time / (double)frames_since_reset),profileIterator->Get_Current_Total_Calls()); - totalTime += current_total_time; - //recurse into children - } - - if (parent_time < accumulated_time) - { - b3Printf("what's wrong\n"); - } - for (i=0;i B3_EPSILON ? ((parent_time - accumulated_time) / parent_time) * 100 : 0.f, parent_time - accumulated_time); - - for (i=0;iEnter_Child(i); - dumpRecursive(profileIterator,spacing+3); - profileIterator->Enter_Parent(); - } -} - - - - -void b3ProfileManager::dumpAll() -{ - b3ProfileIterator* profileIterator = 0; - profileIterator = b3ProfileManager::Get_Iterator(); - - dumpRecursive(profileIterator,0); - - b3ProfileManager::Release_Iterator(profileIterator); -} - - -void b3ProfileManager::dumpRecursive(FILE* f, b3ProfileIterator* profileIterator, int spacing) -{ - profileIterator->First(); - if (profileIterator->Is_Done()) - return; - - float accumulated_time=0,parent_time = profileIterator->Is_Root() ? b3ProfileManager::Get_Time_Since_Reset() : profileIterator->Get_Current_Parent_Total_Time(); - int i; - int frames_since_reset = b3ProfileManager::Get_Frame_Count_Since_Reset(); - for (i=0;iGet_Current_Parent_Name(), parent_time ); - float totalTime = 0.f; - - - int numChildren = 0; - - for (i = 0; !profileIterator->Is_Done(); i++,profileIterator->Next()) - { - numChildren++; - float current_total_time = profileIterator->Get_Current_Total_Time(); - accumulated_time += current_total_time; - float fraction = parent_time > B3_EPSILON ? (current_total_time / parent_time) * 100 : 0.f; - { - int i; for (i=0;iGet_Current_Name(), fraction,(current_total_time / (double)frames_since_reset),profileIterator->Get_Current_Total_Calls()); - totalTime += current_total_time; - //recurse into children - } - - if (parent_time < accumulated_time) - { - fprintf(f,"what's wrong\n"); - } - for (i=0;i B3_EPSILON ? ((parent_time - accumulated_time) / parent_time) * 100 : 0.f, parent_time - accumulated_time); - - for (i=0;iEnter_Child(i); - dumpRecursive(f,profileIterator,spacing+3); - profileIterator->Enter_Parent(); - } -} - - - - -void b3ProfileManager::dumpAll(FILE* f) -{ - b3ProfileIterator* profileIterator = 0; - profileIterator = b3ProfileManager::Get_Iterator(); - - dumpRecursive(f, profileIterator,0); - - b3ProfileManager::Release_Iterator(profileIterator); -} - - - -#endif //B3_NO_PROFILE diff --git a/btgui/Bullet3AppSupport/b3Quickprof.h b/btgui/Bullet3AppSupport/b3Quickprof.h deleted file mode 100644 index 44824baae..000000000 --- a/btgui/Bullet3AppSupport/b3Quickprof.h +++ /dev/null @@ -1,173 +0,0 @@ -/* -Copyright (c) 2003-2013 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/*************************************************************************************************** -** -** Real-Time Hierarchical Profiling for Game Programming Gems 3 -** -** by Greg Hjelstrom & Byon Garrabrant -** -***************************************************************************************************/ - -// Credits: The Clock class was inspired by the Timer classes in -// Ogre (www.ogre3d.org). - - - -#ifndef B3_QUICK_PROF_H -#define B3_QUICK_PROF_H - -//To disable built-in profiling, please comment out next line -//#define B3_NO_PROFILE 1 -#ifndef B3_NO_PROFILE -#include //@todo remove this, backwards compatibility -#include "Bullet3Common/b3Scalar.h" -#include "Bullet3Common/b3AlignedAllocator.h" -#include - - - - -#include "b3Clock.h" - - - - -///A node in the Profile Hierarchy Tree -class b3ProfileNode { - -public: - b3ProfileNode( const char * name, b3ProfileNode * parent ); - ~b3ProfileNode( void ); - - b3ProfileNode * Get_Sub_Node( const char * name ); - - b3ProfileNode * Get_Parent( void ) { return Parent; } - b3ProfileNode * Get_Sibling( void ) { return Sibling; } - b3ProfileNode * Get_Child( void ) { return Child; } - - void CleanupMemory(); - void Reset( void ); - void Call( void ); - bool Return( void ); - - const char * Get_Name( void ) { return Name; } - int Get_Total_Calls( void ) { return TotalCalls; } - float Get_Total_Time( void ) { return TotalTime; } - void* GetUserPointer() const {return m_userPtr;} - void SetUserPointer(void* ptr) { m_userPtr = ptr;} -protected: - - const char * Name; - int TotalCalls; - float TotalTime; - unsigned long int StartTime; - int RecursionCounter; - - b3ProfileNode * Parent; - b3ProfileNode * Child; - b3ProfileNode * Sibling; - void* m_userPtr; -}; - -///An iterator to navigate through the tree -class b3ProfileIterator -{ -public: - // Access all the children of the current parent - void First(void); - void Next(void); - bool Is_Done(void); - bool Is_Root(void) { return (CurrentParent->Get_Parent() == 0); } - - void Enter_Child( int index ); // Make the given child the new parent - void Enter_Largest_Child( void ); // Make the largest child the new parent - void Enter_Parent( void ); // Make the current parent's parent the new parent - - // Access the current child - const char * Get_Current_Name( void ) { return CurrentChild->Get_Name(); } - int Get_Current_Total_Calls( void ) { return CurrentChild->Get_Total_Calls(); } - float Get_Current_Total_Time( void ) { return CurrentChild->Get_Total_Time(); } - - void* Get_Current_UserPointer( void ) { return CurrentChild->GetUserPointer(); } - void Set_Current_UserPointer(void* ptr) {CurrentChild->SetUserPointer(ptr);} - // Access the current parent - const char * Get_Current_Parent_Name( void ) { return CurrentParent->Get_Name(); } - int Get_Current_Parent_Total_Calls( void ) { return CurrentParent->Get_Total_Calls(); } - float Get_Current_Parent_Total_Time( void ) { return CurrentParent->Get_Total_Time(); } - - - -protected: - - b3ProfileNode * CurrentParent; - b3ProfileNode * CurrentChild; - - - b3ProfileIterator( b3ProfileNode * start ); - friend class b3ProfileManager; -}; - - -///The Manager for the Profile system -class b3ProfileManager { -public: - static void Start_Profile( const char * name ); - static void Stop_Profile( void ); - - static void CleanupMemory(void) - { - Root.CleanupMemory(); - } - - static void Reset( void ); - static void Increment_Frame_Counter( void ); - static int Get_Frame_Count_Since_Reset( void ) { return FrameCounter; } - static float Get_Time_Since_Reset( void ); - - static b3ProfileIterator * Get_Iterator( void ) - { - - return new b3ProfileIterator( &Root ); - } - static void Release_Iterator( b3ProfileIterator * iterator ) { delete ( iterator); } - - static void dumpRecursive(b3ProfileIterator* profileIterator, int spacing); - static void dumpAll(); - - static void dumpRecursive(FILE* f, b3ProfileIterator* profileIterator, int spacing); - static void dumpAll(FILE* f); - -private: - static b3ProfileNode Root; - static b3ProfileNode * CurrentNode; - static int FrameCounter; - static unsigned long int ResetTime; -}; - - - - - -#else - - - -#endif //#ifndef B3_NO_PROFILE - - - -#endif //B3_QUICK_PROF_H - - diff --git a/btgui/Bullet3AppSupport/gwenInternalData.h b/btgui/Bullet3AppSupport/gwenInternalData.h deleted file mode 100644 index a78553ff8..000000000 --- a/btgui/Bullet3AppSupport/gwenInternalData.h +++ /dev/null @@ -1,57 +0,0 @@ -#ifndef GWEN_INTERNAL_DATA_H -#define GWEN_INTERNAL_DATA_H - -#include "OpenGLWindow/GwenOpenGL3CoreRenderer.h" -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "Gwen/Platform.h" -#include "Gwen/Controls/TreeControl.h" -#include "Gwen/Controls/RadioButtonController.h" -#include "Gwen/Controls/VerticalSlider.h" -#include "Gwen/Controls/HorizontalSlider.h" -#include "Gwen/Controls/GroupBox.h" -#include "Gwen/Controls/CheckBox.h" -#include "Gwen/Controls/StatusBar.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/ComboBox.h" -#include "Gwen/Controls/MenuStrip.h" -#include "Gwen/Controls/Slider.h" -#include "Gwen/Controls/Property/Text.h" -#include "Gwen/Controls/SplitterBar.h" -#include "Bullet3Common/b3AlignedObjectArray.h" -#include "Gwen/Gwen.h" -#include "Gwen/Align.h" -#include "Gwen/Utility.h" -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/ListBox.h" -#include "Gwen/Skins/Simple.h" -//#include "Gwen/Skins/TexturedBase.h" -#include "gwenUserInterface.h" - - -struct GwenInternalData -{ - //struct sth_stash; - //class GwenOpenGL3CoreRenderer* pRenderer; - Gwen::Renderer::Base* pRenderer; - Gwen::Skin::Simple skin; - Gwen::Controls::Canvas* pCanvas; - //GLPrimitiveRenderer* m_primRenderer; - Gwen::Controls::TabButton* m_demoPage; - Gwen::Controls::TabButton* m_explorerPage; - Gwen::Controls::TreeControl* m_explorerTreeCtrl; - Gwen::Controls::MenuItem* m_viewMenu; - class MyMenuItems* m_menuItems; - - int m_curYposition; - - Gwen::Controls::Label* m_rightStatusBar; - Gwen::Controls::Label* m_leftStatusBar; - b3AlignedObjectArray m_handlers; - b3ToggleButtonCallback m_toggleButtonCallback; - b3ComboBoxCallback m_comboBoxCallback; - - -}; - -#endif//GWEN_INTERNAL_DATA_H diff --git a/btgui/Bullet3AppSupport/gwenUserInterface.cpp b/btgui/Bullet3AppSupport/gwenUserInterface.cpp deleted file mode 100644 index 8100c57d2..000000000 --- a/btgui/Bullet3AppSupport/gwenUserInterface.cpp +++ /dev/null @@ -1,463 +0,0 @@ - -#include "gwenUserInterface.h" -#include "gwenInternalData.h" -#include "Gwen/Controls/ImagePanel.h" - -class MyGraphWindow* graphWindow = 0; - - - -GwenUserInterface::GwenUserInterface() -{ - m_data = new GwenInternalData(); - m_data->m_toggleButtonCallback = 0; - m_data->m_comboBoxCallback = 0; - -} - -GwenUserInterface::~GwenUserInterface() -{ - for (int i=0;im_handlers.size();i++) - { - delete m_data->m_handlers[i]; - } - - m_data->m_handlers.clear(); - - - delete m_data->pCanvas; - - - delete m_data; - - - -} - - - - -class MyMenuItems : public Gwen::Controls::Base -{ -public: - - b3FileOpenCallback m_fileOpenCallback; - - MyMenuItems() :Gwen::Controls::Base(0),m_fileOpenCallback(0) - { - } - void myQuitApp( Gwen::Controls::Base* pControl ) - { - exit(0); - } - void fileOpen( Gwen::Controls::Base* pControl ) - { - if (m_fileOpenCallback) - { - (*m_fileOpenCallback)(); - } - } - -}; - -struct MyTestMenuBar : public Gwen::Controls::MenuStrip -{ - - Gwen::Controls::MenuItem* m_fileMenu; - Gwen::Controls::MenuItem* m_viewMenu; - MyMenuItems* m_menuItems; - - MyTestMenuBar(Gwen::Controls::Base* pParent) - :Gwen::Controls::MenuStrip(pParent) - { -// Gwen::Controls::MenuStrip* menu = new Gwen::Controls::MenuStrip( pParent ); - { - m_menuItems = new MyMenuItems(); - m_menuItems->m_fileOpenCallback = 0; - - m_fileMenu = AddItem( L"File" ); - - m_fileMenu->GetMenu()->AddItem(L"Open",m_menuItems,(Gwen::Event::Handler::Function)&MyMenuItems::fileOpen); - m_fileMenu->GetMenu()->AddItem(L"Quit",m_menuItems,(Gwen::Event::Handler::Function)&MyMenuItems::myQuitApp); - m_viewMenu = AddItem( L"View" ); - - } - } - -}; - -void GwenUserInterface::resize(int width, int height) -{ - m_data->pCanvas->SetSize(width,height); -} - - -struct MyComboBoxHander :public Gwen::Event::Handler -{ - GwenInternalData* m_data; - int m_buttonId; - - MyComboBoxHander (GwenInternalData* data, int buttonId) - :m_data(data), - m_buttonId(buttonId) - { - } - - void onSelect( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::ComboBox* but = (Gwen::Controls::ComboBox*) pControl; - - - - Gwen::String str = Gwen::Utility::UnicodeToString( but->GetSelectedItem()->GetText()); - - if (m_data->m_comboBoxCallback) - (*m_data->m_comboBoxCallback)(m_buttonId,str.c_str()); - } - -}; - -struct MyButtonHander :public Gwen::Event::Handler -{ - GwenInternalData* m_data; - int m_buttonId; - - MyButtonHander (GwenInternalData* data, int buttonId) - :m_data(data), - m_buttonId(buttonId) - { - } - - void onButtonA( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::Button* but = (Gwen::Controls::Button*) pControl; -// int dep = but->IsDepressed(); - int tog = but->GetToggleState(); - if (m_data->m_toggleButtonCallback) - (*m_data->m_toggleButtonCallback)(m_buttonId,tog); - } - -}; - - -void GwenUserInterface::setStatusBarMessage(const char* message, bool isLeft) -{ - Gwen::UnicodeString msg = Gwen::Utility::StringToUnicode(message); - if (isLeft) - { - m_data->m_leftStatusBar->SetText( msg); - } else - { - m_data->m_rightStatusBar->SetText( msg); - - } -} - -void GwenUserInterface::registerFileOpenCallback(b3FileOpenCallback callback) -{ - m_data->m_menuItems->m_fileOpenCallback = callback; -} - -void GwenUserInterface::init(int width, int height,Gwen::Renderer::Base* renderer,float retinaScale) -{ - m_data->m_curYposition = 20; - //m_data->m_primRenderer = new GLPrimitiveRenderer(width,height); - m_data->pRenderer = renderer;//new GwenOpenGL3CoreRenderer(m_data->m_primRenderer,stash,width,height,retinaScale); - - m_data->skin.SetRender( m_data->pRenderer ); - - m_data->pCanvas= new Gwen::Controls::Canvas( &m_data->skin ); - m_data->pCanvas->SetSize( width,height); - m_data->pCanvas->SetDrawBackground( false); - m_data->pCanvas->SetBackgroundColor( Gwen::Color( 150, 170, 170, 255 ) ); - - MyTestMenuBar* menubar = new MyTestMenuBar(m_data->pCanvas); - m_data->m_viewMenu = menubar->m_viewMenu; - m_data->m_menuItems = menubar->m_menuItems; - - - - Gwen::Controls::StatusBar* bar = new Gwen::Controls::StatusBar(m_data->pCanvas); - m_data->m_rightStatusBar = new Gwen::Controls::Label( bar ); - m_data->m_rightStatusBar->SetWidth(width/2); - //m_data->m_rightStatusBar->SetText( L"Label Added to Right" ); - bar->AddControl( m_data->m_rightStatusBar, true ); - - m_data->m_leftStatusBar = new Gwen::Controls::Label( bar ); - //m_data->m_leftStatusBar->SetText( L"Label Added to Left" ); - m_data->m_leftStatusBar->SetWidth(width/2); - bar->AddControl( m_data->m_leftStatusBar,false); - //Gwen::KeyboardFocus - /*Gwen::Controls::GroupBox* box = new Gwen::Controls::GroupBox(m_data->pCanvas); - box->SetText("text"); - box->SetName("name"); - box->SetHeight(500); - */ - Gwen::Controls::ScrollControl* windowRight= new Gwen::Controls::ScrollControl(m_data->pCanvas); - windowRight->Dock(Gwen::Pos::Right); - windowRight->SetWidth(150); - windowRight->SetHeight(250); - windowRight->SetScroll(false,true); - - - - //windowLeft->SetSkin( - Gwen::Controls::TabControl* tab = new Gwen::Controls::TabControl(windowRight); - - //tab->SetHeight(300); - tab->SetWidth(140); - tab->SetHeight(250); - //tab->Dock(Gwen::Pos::Left); - tab->Dock( Gwen::Pos::Fill ); - //tab->SetMargin( Gwen::Margin( 2, 2, 2, 2 ) ); - - Gwen::UnicodeString str1(L"Params"); - m_data->m_demoPage = tab->AddPage(str1); - - - - -// Gwen::UnicodeString str2(L"OpenCL"); -// tab->AddPage(str2); - //Gwen::UnicodeString str3(L"page3"); -// tab->AddPage(str3); - - - - //but->onPress.Add(handler, &MyHander::onButtonA); - - - - //box->Dock(Gwen::Pos::Left); - - /*Gwen::Controls::WindowControl* windowBottom = new Gwen::Controls::WindowControl(m_data->pCanvas); - windowBottom->SetHeight(100); - windowBottom->Dock(Gwen::Pos::Bottom); - windowBottom->SetTitle("bottom"); - */ -// Gwen::Controls::Property::Text* prop = new Gwen::Controls::Property::Text(m_data->pCanvas); - //prop->Dock(Gwen::Pos::Bottom); - /*Gwen::Controls::SplitterBar* split = new Gwen::Controls::SplitterBar(m_data->pCanvas); - split->Dock(Gwen::Pos::Center); - split->SetHeight(300); - split->SetWidth(300); - */ - /* - - - */ - - Gwen::Controls::ScrollControl* windowLeft = new Gwen::Controls::ScrollControl(m_data->pCanvas); - windowLeft->Dock(Gwen::Pos::Left); - // windowLeft->SetTitle("title"); - windowLeft->SetScroll(false, false); - windowLeft->SetWidth(250); - windowLeft->SetPos(50, 50); - windowLeft->SetHeight(500); - //windowLeft->SetClosable(false); - // windowLeft->SetShouldDrawBackground(true); - windowLeft->SetTabable(true); - - Gwen::Controls::TabControl* explorerTab = new Gwen::Controls::TabControl(windowLeft); - - //tab->SetHeight(300); -// explorerTab->SetWidth(230); - explorerTab->SetHeight(250); - //tab->Dock(Gwen::Pos::Left); - explorerTab->Dock(Gwen::Pos::Fill); - - Gwen::UnicodeString explorerStr1(L"Explorer"); - m_data->m_explorerPage = explorerTab->AddPage(explorerStr1); - Gwen::UnicodeString shapesStr1(L"Shapes"); - explorerTab->AddPage(shapesStr1); - Gwen::UnicodeString testStr1(L"Test"); - explorerTab->AddPage(testStr1); - - Gwen::Controls::TreeControl* ctrl = new Gwen::Controls::TreeControl(m_data->m_explorerPage->GetPage()); - m_data->m_explorerTreeCtrl = ctrl; - ctrl->SetKeyboardInputEnabled(true); - ctrl->Focus(); - ctrl->SetBounds(2, 10, 236, 400); - - -} - -void GwenUserInterface::forceUpdateScrollBars() -{ - b3Assert(m_data); - b3Assert(m_data->m_explorerTreeCtrl); - if (m_data && m_data->m_explorerTreeCtrl) - { - m_data->m_explorerTreeCtrl->ForceUpdateScrollBars(); - } -} - -void GwenUserInterface::setFocus() -{ - b3Assert(m_data); - b3Assert(m_data->m_explorerTreeCtrl); - if (m_data && m_data->m_explorerTreeCtrl) - { - m_data->m_explorerTreeCtrl->Focus(); - } -} - -b3ToggleButtonCallback GwenUserInterface::getToggleButtonCallback() -{ - return m_data->m_toggleButtonCallback; -} - -void GwenUserInterface::setToggleButtonCallback(b3ToggleButtonCallback callback) -{ - m_data->m_toggleButtonCallback = callback; -} -void GwenUserInterface::registerToggleButton(int buttonId, const char* name) -{ - assert(m_data); - assert(m_data->m_demoPage); - - Gwen::Controls::Button* but = new Gwen::Controls::Button(m_data->m_demoPage->GetPage()); - - ///some heuristic to find the button location - int ypos = m_data->m_curYposition; - but->SetPos(10, ypos ); - but->SetWidth( 100 ); - //but->SetBounds( 200, 30, 300, 200 ); - - MyButtonHander* handler = new MyButtonHander(m_data, buttonId); - m_data->m_handlers.push_back(handler); - m_data->m_curYposition+=22; - but->onToggle.Add(handler, &MyButtonHander::onButtonA); - but->SetIsToggle(true); - but->SetToggleState(false); - but->SetText(name); - -} - -void GwenUserInterface::setComboBoxCallback(b3ComboBoxCallback callback) -{ - m_data->m_comboBoxCallback = callback; -} - -b3ComboBoxCallback GwenUserInterface::getComboBoxCallback() -{ - return m_data->m_comboBoxCallback; -} -void GwenUserInterface::registerComboBox(int comboboxId, int numItems, const char** items, int startItem) -{ - Gwen::Controls::ComboBox* combobox = new Gwen::Controls::ComboBox(m_data->m_demoPage->GetPage()); - MyComboBoxHander* handler = new MyComboBoxHander(m_data, comboboxId); - m_data->m_handlers.push_back(handler); - - combobox->onSelection.Add(handler,&MyComboBoxHander::onSelect); - int ypos = m_data->m_curYposition; - combobox->SetPos(10, ypos ); - combobox->SetWidth( 100 ); - //box->SetPos(120,130); - for (int i=0;iAddItem(Gwen::Utility::StringToUnicode(items[i])); - if (i==startItem) - combobox->OnItemSelected(item); - } - - m_data->m_curYposition+=22; - - - -} - -void GwenUserInterface::draw(int width, int height) -{ - -// printf("width = %d, height=%d\n", width,height); - if (m_data->pCanvas) - { - m_data->pCanvas->SetSize(width,height); - //m_data->m_primRenderer->setScreenSize(width,height); - m_data->pRenderer->Resize(width,height); - m_data->pCanvas->RenderCanvas(); - //restoreOpenGLState(); - } - -} - -bool GwenUserInterface::mouseMoveCallback( float x, float y) -{ - bool handled = false; - - static int m_lastmousepos[2] = {0,0}; - static bool isInitialized = false; - if (m_data->pCanvas) - { - if (!isInitialized) - { - isInitialized = true; - m_lastmousepos[0] = x+1; - m_lastmousepos[1] = y+1; - } - handled = m_data->pCanvas->InputMouseMoved(x,y,m_lastmousepos[0],m_lastmousepos[1]); - } - return handled; - -} -#include "OpenGLWindow/b3gWindowInterface.h" - -bool GwenUserInterface::keyboardCallback(int bulletKey, int state) -{ - int key = -1; - if (m_data->pCanvas) - { - //convert 'Bullet' keys into 'Gwen' keys - switch (bulletKey) - { - case B3G_RETURN: - { - key = Gwen::Key::Return; - break; - } - case B3G_LEFT_ARROW: - key = Gwen::Key::Left; - break; - case B3G_RIGHT_ARROW: - key = Gwen::Key::Right; - break; - - case B3G_UP_ARROW: - key = Gwen::Key::Up; - break; - case B3G_DOWN_ARROW: - key = Gwen::Key::Down; - break; - default: - { - - } - }; - bool bDown = (state == 1); - - return m_data->pCanvas->InputKey(key, bDown); - } - return false; -} - - -bool GwenUserInterface::mouseButtonCallback(int button, int state, float x, float y) -{ - bool handled = false; - if (m_data->pCanvas) - { - handled = m_data->pCanvas->InputMouseMoved(x,y,x, y); - - if (button>=0) - { - handled = m_data->pCanvas->InputMouseButton(button,(bool)state); - if (handled) - { - //if (!state) - // return false; - } - } - } - return handled; -} diff --git a/btgui/Bullet3AppSupport/gwenUserInterface.h b/btgui/Bullet3AppSupport/gwenUserInterface.h deleted file mode 100644 index 4b7fac785..000000000 --- a/btgui/Bullet3AppSupport/gwenUserInterface.h +++ /dev/null @@ -1,63 +0,0 @@ -#ifndef _GWEN_USER_INTERFACE_H -#define _GWEN_USER_INTERFACE_H - -struct GwenInternalData; - -typedef void (*b3ComboBoxCallback) (int combobox, const char* item); -typedef void (*b3ToggleButtonCallback)(int button, int state); -typedef void (*b3FileOpenCallback)(); - -namespace Gwen -{ - namespace Renderer - { - class Base; - }; -}; -class GwenUserInterface -{ - GwenInternalData* m_data; - - public: - - GwenUserInterface(); - - virtual ~GwenUserInterface(); - - void init(int width, int height,Gwen::Renderer::Base* gwenRenderer,float retinaScale); - void setFocus(); - void forceUpdateScrollBars(); - - void draw(int width, int height); - - void resize(int width, int height); - - bool mouseMoveCallback( float x, float y); - bool mouseButtonCallback(int button, int state, float x, float y); - bool keyboardCallback(int key, int state); - - - void setToggleButtonCallback(b3ToggleButtonCallback callback); - b3ToggleButtonCallback getToggleButtonCallback(); - - void registerToggleButton(int buttonId, const char* name); - - void setComboBoxCallback(b3ComboBoxCallback callback); - b3ComboBoxCallback getComboBoxCallback(); - void registerComboBox(int buttonId, int numItems, const char** items, int startItem = 0); - - void setStatusBarMessage(const char* message, bool isLeft=true); - - void registerFileOpenCallback(b3FileOpenCallback callback); - - GwenInternalData* getInternalData() - { - return m_data; - } - -}; - - - -#endif //_GWEN_USER_INTERFACE_H - diff --git a/btgui/Bullet3AppSupport/premake4.lua b/btgui/Bullet3AppSupport/premake4.lua deleted file mode 100644 index b8752a165..000000000 --- a/btgui/Bullet3AppSupport/premake4.lua +++ /dev/null @@ -1,26 +0,0 @@ - - project "Bullet3AppSupport" - - language "C++" - - kind "StaticLib" - - initOpenGL() - initGlew() - - includedirs { - "..", - "../../src", - } - - --links { - --} - - files { - "*.cpp", - "*.h", - } - - if os.is("Linux") then - initX11() - end diff --git a/btgui/CMakeLists.txt b/btgui/CMakeLists.txt deleted file mode 100644 index be213d89f..000000000 --- a/btgui/CMakeLists.txt +++ /dev/null @@ -1,3 +0,0 @@ -if (OPENGL_FOUND) -SUBDIRS( Bullet3AppSupport Gwen OpenGLWindow lua-5.2.3) -endif(OPENGL_FOUND) diff --git a/btgui/FontFiles/DroidSansJapanese.ttf b/btgui/FontFiles/DroidSansJapanese.ttf deleted file mode 100644 index 412fa3de0..000000000 Binary files a/btgui/FontFiles/DroidSansJapanese.ttf and /dev/null differ diff --git a/btgui/FontFiles/DroidSerif-Bold.ttf b/btgui/FontFiles/DroidSerif-Bold.ttf deleted file mode 100644 index 838d25588..000000000 Binary files a/btgui/FontFiles/DroidSerif-Bold.ttf and /dev/null differ diff --git a/btgui/FontFiles/DroidSerif-Italic.ttf b/btgui/FontFiles/DroidSerif-Italic.ttf deleted file mode 100644 index 2972809da..000000000 Binary files a/btgui/FontFiles/DroidSerif-Italic.ttf and /dev/null differ diff --git a/btgui/FontFiles/DroidSerif-Regular.ttf b/btgui/FontFiles/DroidSerif-Regular.ttf deleted file mode 100644 index 5b4fe815d..000000000 Binary files a/btgui/FontFiles/DroidSerif-Regular.ttf and /dev/null differ diff --git a/btgui/Gwen/Align.h b/btgui/Gwen/Align.h deleted file mode 100644 index e2a3d1698..000000000 --- a/btgui/Gwen/Align.h +++ /dev/null @@ -1,79 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_ALIGN_H -#define GWEN_ALIGN_H -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Align - { - inline void Center( Controls::Base* ctrl ) - { - Controls::Base* parent = ctrl->GetParent(); - if ( !parent ) return; - - ctrl->SetPos( parent->GetPadding().left + (((parent->Width()-parent->GetPadding().left-parent->GetPadding().right) - ctrl->Width()) / 2), - (parent->Height() - ctrl->Height()) / 2 ); - } - - inline void AlignLeft( Controls::Base* ctrl ) - { - Controls::Base* parent = ctrl->GetParent(); - if ( !parent ) return; - - ctrl->SetPos( parent->GetPadding().left, ctrl->Y() ); - } - - inline void CenterHorizontally( Controls::Base* ctrl ) - { - Controls::Base* parent = ctrl->GetParent(); - if ( !parent ) return; - - - ctrl->SetPos( parent->GetPadding().left + (((parent->Width()-parent->GetPadding().left-parent->GetPadding().right) - ctrl->Width()) / 2), ctrl->Y() ); - } - - inline void AlignRight( Controls::Base* ctrl ) - { - Controls::Base* parent = ctrl->GetParent(); - if ( !parent ) return; - - - ctrl->SetPos( parent->Width() - ctrl->Width() - parent->GetPadding().right, ctrl->Y() ); - } - - inline void AlignTop( Controls::Base* ctrl ) - { - ctrl->SetPos( ctrl->X(), 0 ); - } - - inline void CenterVertically( Controls::Base* ctrl ) - { - Controls::Base* parent = ctrl->GetParent(); - if ( !parent ) return; - - ctrl->SetPos( ctrl->X(), (parent->Height() - ctrl->Height()) / 2 ); - } - - inline void AlignBottom( Controls::Base* ctrl ) - { - Controls::Base* parent = ctrl->GetParent(); - if ( !parent ) return; - - ctrl->SetPos( ctrl->X(), parent->Height() - ctrl->Height() ); - } - - inline void PlaceBelow( Controls::Base* ctrl, Controls::Base* below, int iBorder = 0 ) - { - ctrl->SetPos( ctrl->X(), below->Bottom() + iBorder ); - } - - } -} -#endif diff --git a/btgui/Gwen/Anim.cpp b/btgui/Gwen/Anim.cpp deleted file mode 100644 index 16c8ff929..000000000 --- a/btgui/Gwen/Anim.cpp +++ /dev/null @@ -1,142 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Anim.h" -#include "Gwen/Utility.h" -#include - -using namespace Gwen; - -#ifndef GWEN_NO_ANIMATION - -static Gwen::Anim::Animation::List g_Animations; -static Gwen::Anim::Animation::ChildList g_AnimationsListed; - -void Gwen::Anim::Add( Gwen::Controls::Base* control, Animation* animation ) -{ - animation->m_Control = control; - - g_Animations[control].push_back( animation ); -} - -void Gwen::Anim::Cancel( Gwen::Controls::Base* control ) -{ - /* cannot use std::list iterator with algoryhtmns based on pointers - struct AnimDeletePredicate - { - AnimDeletePredicate( Gwen::Controls::Base* control ) - { - this->control = control; - } - - bool operator() ( Gwen::Anim::Animation* anim ) - { - return anim->m_Control == control; - } - - Gwen::Controls::Base* control; - }; - - std::remove_if ( g_Animations.begin(), g_Animations.end(), AnimDeletePredicate( control ) ); - */ - Gwen::Anim::Animation::List::iterator iAnimations; - if ((iAnimations = g_Animations.find(control)) != g_Animations.end()) - { - Gwen::Anim::Animation::ChildList &ChildAnimationsForControl = iAnimations->second; - Gwen::Anim::Animation::ChildList::iterator iAnimationChild = ChildAnimationsForControl.begin(); - if (iAnimationChild != ChildAnimationsForControl.end()) - { - do - { - delete (*iAnimationChild); - }while(++iAnimationChild != ChildAnimationsForControl.end()); - } - g_Animations.erase(iAnimations); - } -} - -void Gwen::Anim::Think() -{ - Gwen::Anim::Animation::List::iterator it = g_Animations.begin(); - - if ( it != g_Animations.end() ) - { - Gwen::Anim::Animation::ChildList::iterator itChild; - - Gwen::Anim::Animation* anim; - - do - { - if ((itChild = it->second.begin()) != it->second.end()) - { - do - { - anim = *itChild; - - anim->Think(); - - if ( anim->Finished() ) - { - itChild = it->second.erase( itChild ); - - delete anim; - } - else - { - ++itChild; - } - - }while(itChild != it->second.end()); - } - - }while(++it != g_Animations.end()); - } - -} - -Gwen::Anim::TimedAnimation::TimedAnimation( float fLength, float fDelay, float fEase ) -{ - m_fStart = Platform::GetTimeInSeconds() + fDelay; - m_fEnd = m_fStart + fLength; - m_fEase = fEase; - m_bStarted = false; - m_bFinished = false; -} - -void Gwen::Anim::TimedAnimation::Think() -{ - if ( m_bFinished ) return; - - float fCurrent = Platform::GetTimeInSeconds(); - float fSecondsIn = fCurrent - m_fStart; - if ( fSecondsIn < 0.0f ) return; - - if ( !m_bStarted ) - { - m_bStarted = true; - OnStart(); - } - - float fDelta = fSecondsIn / ( m_fEnd - m_fStart ); - if ( fDelta < 0.0f ) fDelta = 0.0f; - if ( fDelta > 1.0f ) fDelta = 1.0f; - - Run( pow( fDelta, m_fEase ) ); - - if ( fDelta == 1.0f ) - { - m_bFinished = true; - OnFinish(); - } -} - -bool Gwen::Anim::TimedAnimation::Finished() -{ - return m_bFinished; -} - -#endif \ No newline at end of file diff --git a/btgui/Gwen/Anim.h b/btgui/Gwen/Anim.h deleted file mode 100644 index ac9da16e1..000000000 --- a/btgui/Gwen/Anim.h +++ /dev/null @@ -1,130 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_ANIM_H -#define GWEN_ANIM_H -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Platform.h" - -#ifndef GWEN_NO_ANIMATION - -namespace Gwen -{ - namespace Anim - { - class GWEN_EXPORT Animation - { - public: - - typedef std::list ChildList; - typedef std::map< Gwen::Controls::Base *, ChildList > List; - - virtual void Think() = 0; - virtual bool Finished() = 0; - - virtual ~Animation() {} - - Gwen::Controls::Base* m_Control; - }; - - GWEN_EXPORT void Add( Gwen::Controls::Base* control, Animation* animation ); - GWEN_EXPORT void Cancel( Gwen::Controls::Base* control ); - GWEN_EXPORT void Think(); - - // - // Timed animation. Provides a useful base for animations. - // - class GWEN_EXPORT TimedAnimation : public Animation - { - public: - - TimedAnimation( float fLength, float fDelay = 0.0f, float fEase = 1.0f ); - - virtual void Think(); - virtual bool Finished(); - - // - // These are the magic functions you should be overriding - // - virtual void OnStart(){} - virtual void Run( float /*delta*/ ){} - virtual void OnFinish(){} - - protected: - - bool m_bStarted; - bool m_bFinished; - float m_fStart; - float m_fEnd; - float m_fEase; - }; - - namespace Size - { - class GWEN_EXPORT Height : public TimedAnimation - { - public: - - Height( int iStartSize, int iEndSize, float fLength, bool bHide = false, float fDelay = 0.0f, float fEase = 1.0f ) : TimedAnimation( fLength, fDelay, fEase ) - { - m_iStartSize = iStartSize; - m_iDelta = iEndSize - m_iStartSize; - m_bHide = bHide; - } - - virtual void OnStart(){ m_Control->SetHeight( m_iStartSize ); } - virtual void Run( float delta ){ m_Control->SetHeight( m_iStartSize + (((float)m_iDelta) * delta) ); } - virtual void OnFinish(){ m_Control->SetHeight( m_iStartSize + m_iDelta ); m_Control->SetHidden( m_bHide ); } - - protected: - - int m_iStartSize; - int m_iDelta; - bool m_bHide; - }; - - class Width : public TimedAnimation - { - public: - - Width( int iStartSize, int iEndSize, float fLength, bool bHide = false, float fDelay = 0.0f, float fEase = 1.0f ) : TimedAnimation( fLength, fDelay, fEase ) - { - m_iStartSize = iStartSize; - m_iDelta = iEndSize - m_iStartSize; - m_bHide = bHide; - } - - virtual void OnStart(){ m_Control->SetWidth( m_iStartSize ); } - virtual void Run( float delta ){ m_Control->SetWidth( m_iStartSize + (((float)m_iDelta) * delta) ); } - virtual void OnFinish(){ m_Control->SetWidth( m_iStartSize + m_iDelta ); m_Control->SetHidden( m_bHide ); } - - protected: - - int m_iStartSize; - int m_iDelta; - bool m_bHide; - }; - } - - namespace Tools - { - class Remove : public TimedAnimation - { - public: - - Remove( float fDelay = 0.0f ) : TimedAnimation( 0.0f, fDelay ){} - virtual void OnFinish(){ m_Control->DelayedDelete(); } - }; - } - - - } -} - -#endif -#endif diff --git a/btgui/Gwen/BaseRender.cpp b/btgui/Gwen/BaseRender.cpp deleted file mode 100644 index 6ad4b6d25..000000000 --- a/btgui/Gwen/BaseRender.cpp +++ /dev/null @@ -1,221 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" -#include "Gwen/Utility.h" -#include "Gwen/Platform.h" - -#include - -namespace Gwen -{ - namespace Renderer - { - - Base::Base() - { - m_RenderOffset = Gwen::Point( 0, 0 ); - m_fScale = 1.0f; - } - - Base::~Base() - { - if ( GetCTT() ) - GetCTT()->ShutDown(); - } - - void Base::RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::String& text ) - { - Gwen::UnicodeString str = Gwen::Utility::StringToUnicode( text ); - RenderText( pFont, pos, str ); - } - - Gwen::Point Base::MeasureText( Gwen::Font* pFont, const Gwen::String& text ) - { - Gwen::UnicodeString str = Gwen::Utility::StringToUnicode( text ); - return MeasureText( pFont, str ); - } - - void Base::DrawLinedRect( Gwen::Rect rect ) - { - DrawFilledRect( Gwen::Rect( rect.x, rect.y, rect.w, 1 ) ); - DrawFilledRect( Gwen::Rect( rect.x, rect.y + rect.h-1, rect.w, 1 ) ); - - DrawFilledRect( Gwen::Rect( rect.x, rect.y, 1, rect.h ) ); - DrawFilledRect( Gwen::Rect( rect.x + rect.w-1, rect.y, 1, rect.h ) ); - }; - - void Base::DrawPixel( int x, int y ) - { - DrawFilledRect( Gwen::Rect( x, y, 1, 1 ) ); - } - - void Base::DrawShavedCornerRect( Gwen::Rect rect, bool bSlight ) - { - // Draw INSIDE the w/h. - rect.w -= 1; - rect.h -= 1; - - if ( bSlight ) - { - DrawFilledRect( Gwen::Rect( rect.x+1, rect.y, rect.w-1, 1 ) ); - DrawFilledRect( Gwen::Rect( rect.x+1, rect.y + rect.h, rect.w-1, 1 ) ); - - DrawFilledRect( Gwen::Rect( rect.x, rect.y+1, 1, rect.h-1 ) ); - DrawFilledRect( Gwen::Rect( rect.x + rect.w, rect.y+1, 1, rect.h-1 ) ); - return; - } - - DrawPixel( rect.x+1, rect.y+1 ); - DrawPixel( rect.x+rect.w-1, rect.y+1 ); - - DrawPixel( rect.x+1, rect.y+rect.h-1 ); - DrawPixel( rect.x+rect.w-1, rect.y+rect.h-1 ); - - DrawFilledRect( Gwen::Rect( rect.x+2, rect.y, rect.w-3, 1 ) ); - DrawFilledRect( Gwen::Rect( rect.x+2, rect.y + rect.h, rect.w-3, 1 ) ); - - DrawFilledRect( Gwen::Rect( rect.x, rect.y+2, 1, rect.h-3 ) ); - DrawFilledRect( Gwen::Rect( rect.x + rect.w, rect.y+2, 1, rect.h-3 ) ); - } - - void Base::Translate( int& x, int& y ) - { - x += m_RenderOffset.x; - y += m_RenderOffset.y; - - x = ceil( ((float) x ) * m_fScale ); - y = ceil( ((float) y ) * m_fScale ); - } - - void Base::Translate( Gwen::Rect& rect ) - { - Translate( rect.x, rect.y ); - - rect.w = ceil(((float) rect.w ) * m_fScale); - rect.h = ceil(((float) rect.h ) * m_fScale); - } - - void Gwen::Renderer::Base::SetClipRegion( Gwen::Rect rect ) - { - m_rectClipRegion = rect; - } - - void Base::AddClipRegion( Gwen::Rect rect ) - { - rect.x = m_RenderOffset.x; - rect.y = m_RenderOffset.y; - - Gwen::Rect out = rect; - if ( rect.x < m_rectClipRegion.x ) - { - out.w -= ( m_rectClipRegion.x - out.x ); - out.x = m_rectClipRegion.x; - } - - if ( rect.y < m_rectClipRegion.y ) - { - out.h -= ( m_rectClipRegion.y - out.y ); - out.y = m_rectClipRegion.y; - } - - if ( rect.x + rect.w > m_rectClipRegion.x + m_rectClipRegion.w ) - { - out.w = (m_rectClipRegion.x + m_rectClipRegion.w) - out.x; - } - - if ( rect.y + rect.h > m_rectClipRegion.y + m_rectClipRegion.h ) - { - out.h = (m_rectClipRegion.y + m_rectClipRegion.h) - out.y; - } - - m_rectClipRegion = out; - } - - const Gwen::Rect& Base::ClipRegion() const - { - return m_rectClipRegion; - } - - bool Base::ClipRegionVisible() - { - if ( m_rectClipRegion.w <= 0 || m_rectClipRegion.h <= 0 ) - return false; - - return true; - } - - void Base::DrawMissingImage( Gwen::Rect pTargetRect ) - { - SetDrawColor( Colors::Red ); - DrawFilledRect( pTargetRect ); - } - - - /* - If they haven't defined these font functions in their renderer code - we just draw some rects where the letters would be to give them an idea. - */ - - void Base::RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ) - { - float fSize = pFont->size * Scale(); - - for ( float i=0; i= 'a' && chr <= 'z' ) - { - r.y += fSize * 0.5f; - r.h -= fSize * 0.4f; - } - else if ( chr == '.' || chr == ',' ) - { - r.x += 2; - r.y += r.h - 2; - r.w = 2; - r.h = 2; - } - else if ( chr == '\'' || chr == '`' || chr == '"' ) - { - r.x += 3; - r.w = 2; - r.h = 2; - } - - - if ( chr == 'o' || chr == 'O' || chr == '0' ) - DrawLinedRect( r ); - else - DrawFilledRect( r ); - } - } - - Gwen::Point Base::MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ) - { - Gwen::Point p; - p.x = pFont->size * Scale() * (float)text.length() * 0.4; - p.y = pFont->size * Scale(); - - return p; - } - } -} \ No newline at end of file diff --git a/btgui/Gwen/BaseRender.h b/btgui/Gwen/BaseRender.h deleted file mode 100644 index 80daaa375..000000000 --- a/btgui/Gwen/BaseRender.h +++ /dev/null @@ -1,120 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_BASERENDER_H -#define GWEN_BASERENDER_H - -#include "Gwen/Structures.h" - -namespace Gwen -{ - struct Font; - struct Texture; - - namespace Renderer - { - class Base; - - class ICacheToTexture - { - - public: - virtual void Initialize() = 0; - virtual void ShutDown() = 0; - virtual void SetupCacheTexture( Gwen::Controls::Base* control ) = 0; - virtual void FinishCacheTexture( Gwen::Controls::Base* control ) = 0; - virtual void DrawCachedControlTexture( Gwen::Controls::Base* control ) = 0; - virtual void CreateControlCacheTexture( Gwen::Controls::Base* control ) = 0; - virtual void UpdateControlCacheTexture( Gwen::Controls::Base* control ) = 0; - virtual void SetRenderer( Gwen::Renderer::Base* renderer ) = 0; - - }; - - class GWEN_EXPORT Base - { - public: - - Base(); - virtual ~Base(); - - virtual void Begin(){}; - virtual void End(){}; - - virtual void SetDrawColor( Color color ){}; - - virtual void DrawLine( int x, int y, int a, int b ){}; - virtual void DrawFilledRect( Gwen::Rect rect ){};; - - virtual void StartClip(){}; - virtual void EndClip(){}; - - virtual void LoadTexture( Gwen::Texture* pTexture ){}; - virtual void FreeTexture( Gwen::Texture* pTexture ){}; - virtual void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect pTargetRect, float u1=0.0f, float v1=0.0f, float u2=1.0f, float v2=1.0f ){}; - virtual void DrawMissingImage( Gwen::Rect pTargetRect ); - - virtual ICacheToTexture* GetCTT() { return NULL; } - - virtual void LoadFont( Gwen::Font* pFont ){}; - virtual void FreeFont( Gwen::Font* pFont ){}; - virtual void RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ); - virtual Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ); - - // - // No need to implement these functions in your derived class, but if - // you can do them faster than the default implementation it's a good idea to. - // - virtual void DrawLinedRect( Gwen::Rect rect ); - virtual void DrawPixel( int x, int y ); - virtual void DrawShavedCornerRect( Gwen::Rect rect, bool bSlight = false ); - virtual Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::String& text ); - virtual void RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::String& text ); - - virtual void Resize(int width, int height)=0; - public: - - // - // Translate a panel's local drawing coordinate - // into view space, taking Offset's into account. - // - void Translate( int& x, int& y ); - void Translate( Gwen::Rect& rect ); - - // - // Set the rendering offset. You shouldn't have to - // touch these, ever. - // - void SetRenderOffset( const Gwen::Point& offset ){ m_RenderOffset = offset; } - void AddRenderOffset( const Gwen::Rect& offset ){ m_RenderOffset.x += offset.x; m_RenderOffset.y += offset.y; } - const Gwen::Point& GetRenderOffset() const { return m_RenderOffset; } - - private: - - Gwen::Point m_RenderOffset; - - public: - - void SetClipRegion( Gwen::Rect rect ); - void AddClipRegion( Gwen::Rect rect ); - bool ClipRegionVisible(); - const Gwen::Rect& ClipRegion() const; - - private: - - Gwen::Rect m_rectClipRegion; - ICacheToTexture* m_RTT; - - public: - - void SetScale( float fScale ){ m_fScale = fScale; } - float Scale() const { return m_fScale; } - - float m_fScale; - }; - } -} -#endif diff --git a/btgui/Gwen/CMakeLists.txt b/btgui/Gwen/CMakeLists.txt deleted file mode 100644 index 6ab8afd74..000000000 --- a/btgui/Gwen/CMakeLists.txt +++ /dev/null @@ -1,15 +0,0 @@ - -INCLUDE_DIRECTORIES( - ${BULLET_PHYSICS_SOURCE_DIR}/src - ${BULLET_PHYSICS_SOURCE_DIR}/btgui -) - -ADD_DEFINITIONS( -DGWEN_COMPILE_STATIC -D_HAS_EXCEPTIONS=0 -D_STATIC_CPPLIB ) - -FILE(GLOB gwen_SRCS "*.cpp" "Controls/*.cpp" "Controls/Dialog/*.cpp" "Controls/Dialogs/*.cpp" "Controls/Layout/*.cpp" "Controls/Property/*.cpp" "Input/*.cpp" "Platforms/*.cpp" "Renderers/*.cpp" "Skins/*.cpp") -FILE(GLOB gwen_HDRS "*.h" "Controls/*.h" "Controls/Dialog/*.h" "Controls/Dialogs/*.h" "Controls/Layout/*.h" "Controls/Property/*.h" "Input/*.h" "Platforms/*.h" "Renderers/*.h" "Skins/*.h") - -ADD_LIBRARY(gwen ${gwen_SRCS} ${gwen_HDRS}) -if (BUILD_SHARED_LIBS) - target_link_libraries(gwen ${OPENGL_gl_LIBRARY}) -endif() diff --git a/btgui/Gwen/Config.h b/btgui/Gwen/Config.h deleted file mode 100644 index f46ce385f..000000000 --- a/btgui/Gwen/Config.h +++ /dev/null @@ -1,16 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONFIG_H -#define GWEN_CONFIG_H - -// -// Disables animation functions. -// -//#define GWEN_NO_ANIMATION - -#endif diff --git a/btgui/Gwen/Controls.h b/btgui/Gwen/Controls.h deleted file mode 100644 index 8c0d8dbbd..000000000 --- a/btgui/Gwen/Controls.h +++ /dev/null @@ -1,10 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_H -#define GWEN_CONTROLS_H - -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/TextBox.h" - -#include "Gwen/Anim.h" - -#endif diff --git a/btgui/Gwen/Controls/Base.cpp b/btgui/Gwen/Controls/Base.cpp deleted file mode 100644 index 5e90f1d49..000000000 --- a/btgui/Gwen/Controls/Base.cpp +++ /dev/null @@ -1,1111 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" -#include "Gwen/Skin.h" -#include "Gwen/Platform.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/ToolTip.h" -#include "Gwen/Utility.h" -#include - -#ifndef GWEN_NO_ANIMATION -#include "Gwen/Anim.h" -#endif - -using namespace Gwen; -using namespace Controls; - -Base::Base( Base* pParent ) -{ - m_Parent = NULL; - m_ActualParent = NULL; - m_InnerPanel = NULL; - m_Skin = NULL; - - SetParent( pParent ); - - m_bHidden = false; - m_Bounds = Gwen::Rect(0,0,10,10); - m_Padding = Padding( 0, 0, 0, 0 ); - m_Margin = Margin( 0, 0, 0, 0 ); - - m_iDock = 0; - m_DragAndDrop_Package = NULL; - m_pUserData = NULL; - - RestrictToParent( false ); - - SetMouseInputEnabled( true ); - SetKeyboardInputEnabled( false ); - - Invalidate(); - SetCursor( Gwen::CursorType::Normal ); - SetToolTip( NULL ); - SetTabable( false ); - SetShouldDrawBackground( true ); - m_bDisabled = false; - m_bCacheTextureDirty = true; - m_bCacheToTexture = false; - -} - -Base::~Base() -{ - { - Canvas* canvas = GetCanvas(); - if ( canvas ) - canvas->PreDelete( this ); - } - - Base::List::iterator iter = Children.begin(); - while ( iter != Children.end() ) - { - Base* pChild = *iter; - iter = Children.erase( iter ); - delete pChild; - } - - for ( AccelMap::iterator accelIt = m_Accelerators.begin(); accelIt != m_Accelerators.end(); ++accelIt ) - { - delete accelIt->second; - } - m_Accelerators.clear(); - - SetParent( NULL ); - - if ( Gwen::HoveredControl == this ) - Gwen::HoveredControl = NULL; - if ( Gwen::KeyboardFocus == this ) - Gwen::KeyboardFocus = NULL; - if ( Gwen::MouseFocus == this ) Gwen::MouseFocus = NULL; - - DragAndDrop::ControlDeleted( this ); - ToolTip::ControlDeleted( this ); - - #ifndef GWEN_NO_ANIMATION - Anim::Cancel( this ); - #endif - - if ( m_DragAndDrop_Package ) - { - delete m_DragAndDrop_Package; - m_DragAndDrop_Package = NULL; - } -} - - extern int avoidUpdate; - - -void Base::Invalidate() -{ - - - - m_bNeedsLayout = true; - m_bCacheTextureDirty = true; - - avoidUpdate = -3; -} - -void Base::DelayedDelete() -{ - Canvas* canvas = GetCanvas(); - canvas->AddDelayedDelete( this ); -} - -Canvas* Base::GetCanvas() -{ - Base* pCanvas = m_Parent; - if ( !pCanvas ) return NULL; - - return pCanvas->GetCanvas(); -} - -void Base::SetParent(Base* pParent) -{ - if ( m_Parent == pParent ) return; - - if ( m_Parent ) - { - m_Parent->RemoveChild( this ); - } - - m_Parent = pParent; - m_ActualParent = NULL; - - if ( m_Parent ) - { - m_Parent->AddChild( this ); - } -} - -void Base::Dock( int iDock ) -{ - if ( m_iDock == iDock ) return; - - m_iDock = iDock; - - Invalidate(); - InvalidateParent(); -} - -int Base::GetDock() -{ - return m_iDock; -} - -bool Base::Hidden() const -{ - return m_bHidden; -} - -bool Base::Visible() const -{ - if ( Hidden() ) return false; - if ( GetParent() ) - { - return GetParent()->Visible(); - } - - return true; -} - -void Base::InvalidateChildren( bool bRecursive ) -{ - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - (*it)->Invalidate(); - - if ( bRecursive ) - (*it)->InvalidateChildren( bRecursive ); - } - - if ( m_InnerPanel ) - { - for ( Base::List::iterator it = m_InnerPanel->Children.begin(); it != m_InnerPanel->Children.end(); ++it ) - { - (*it)->Invalidate(); - - if ( bRecursive ) - (*it)->InvalidateChildren( bRecursive ); - } - } -} - -void Base::Position( int pos, int xpadding, int ypadding ) -{ - int w = GetParent()->Width(); - int h = GetParent()->Height(); - const Padding& padding = GetParent()->GetPadding(); - - int x = X(); - int y = Y(); - - if ( pos & Pos::Left ) x = padding.left + xpadding; - if ( pos & Pos::Right ) x = w - Width() - padding.right - xpadding; - if ( pos & Pos::CenterH ) x = padding.left + xpadding + (w - Width() - padding.left - padding.right) * 0.5; - - if ( pos & Pos::Top ) y = padding.top + ypadding; - if ( pos & Pos::Bottom ) y = h - Height() - padding.bottom - ypadding; - if ( pos & Pos::CenterV ) y = padding.top + ypadding + (h - Height() - padding.bottom - padding.top) * 0.5; - - SetPos( x, y ); -} - - -void Base::SendToBack() -{ - if ( !m_Parent ) return; - if ( m_Parent->Children.front() == this ) return; - - m_Parent->Children.remove( this ); - m_Parent->Children.push_front( this ); - - InvalidateParent(); -} - -void Base::BringToFront() -{ - if ( !m_Parent ) return; - if ( m_Parent->Children.back() == this ) return; - - m_Parent->Children.remove( this ); - m_Parent->Children.push_back( this ); - InvalidateParent(); -} - -Controls::Base* Base::FindChildByName( const Gwen::String& name, bool bRecursive ) -{ - Base::List::iterator iter; - for (iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - if ( pChild->GetName() == name ) - return pChild; - - if ( bRecursive ) - { - Controls::Base* pSubChild = pChild->FindChildByName( name, true ); - - if ( pSubChild ) - return pSubChild; - } - } - - return NULL; -} - -void Base::BringNextToControl( Controls::Base* pChild, bool bBehind ) -{ - if ( !m_Parent ) return; - - m_Parent->Children.remove( this ); - - Base::List::iterator it = std::find( m_Parent->Children.begin(), m_Parent->Children.end(), pChild ); - if ( it == m_Parent->Children.end() ) - return BringToFront(); - - if ( bBehind ) - { - ++it; - - if ( it == m_Parent->Children.end() ) - return BringToFront(); - } - - m_Parent->Children.insert( it, this ); - InvalidateParent(); -} - -void Base::AddChild(Base* pChild) -{ - if ( m_InnerPanel ) - { - m_InnerPanel->AddChild( pChild ); - return; - } - - Children.push_back( pChild ); - OnChildAdded(pChild); - - pChild->m_ActualParent = this; - -} -void Base::RemoveChild(Base* pChild) -{ - // If we removed our innerpanel - // remove our pointer to it - if ( m_InnerPanel == pChild ) - { - m_InnerPanel = NULL; - } - - if ( m_InnerPanel ) - { - m_InnerPanel->RemoveChild( pChild ); - } - - Children.remove( pChild ); - OnChildRemoved(pChild); -} - -void Base::RemoveAllChildren() -{ - while ( Children.size() > 0 ) - { - RemoveChild( *Children.begin() ); - } -} - -int Base::NumChildren() -{ - // Include m_InnerPanel's children here? - - return Children.size(); -} - -void Base::OnChildAdded(Base* /*pChild*/) -{ - Invalidate(); -} - -void Base::OnChildRemoved(Base* /*pChild*/) -{ - Invalidate(); -} - -Skin::Base* Base::GetSkin( void ) -{ - if ( m_Skin ) return m_Skin; - if ( m_Parent ) return m_Parent->GetSkin(); - - Debug::AssertCheck( 0, "Base::GetSkin Returning NULL!\n" ); - return NULL; -} - -void Base::MoveBy( int x, int y ) -{ - SetBounds( X() + x, Y() + y, Width(), Height() ); -} - -void Base::MoveTo( int x, int y ) -{ - if ( m_bRestrictToParent && GetParent() ) - { - Base* pParent = GetParent(); - if ( x - GetPadding().left < pParent->GetMargin().left ) x = pParent->GetMargin().left + GetPadding().left; - if ( y - GetPadding().top < pParent->GetMargin().top ) y = pParent->GetMargin().top + GetPadding().top; - if ( x + Width() + GetPadding().right > pParent->Width() - pParent->GetMargin().right ) x = pParent->Width() - pParent->GetMargin().right - Width() - GetPadding().right; - if ( y + Height() + GetPadding().bottom > pParent->Height() - pParent->GetMargin().bottom ) y = pParent->Height() - pParent->GetMargin().bottom - Height() - GetPadding().bottom; - } - - SetBounds(x, y, Width(), Height()); -} - -void Base::SetPos( int x, int y ) -{ - SetBounds( x, y, Width(), Height() ); -} - -bool Base::SetSize( int w, int h ) -{ - return SetBounds( X(), Y(), w, h ); -} - -bool Base::SetBounds( const Gwen::Rect& bounds ) -{ - return SetBounds( bounds.x, bounds.y, bounds.w, bounds.h ); -} - -bool Base::SetBounds( int x, int y, int w, int h ) -{ - if ( m_Bounds.x == x && - m_Bounds.y == y && - m_Bounds.w == w && - m_Bounds.h == h ) - return false; - - Gwen::Rect oldBounds = GetBounds(); - - m_Bounds.x = x; - m_Bounds.y = y; - - m_Bounds.w = w; - m_Bounds.h = h; - - OnBoundsChanged( oldBounds ); - - return true; -} - -void Base::OnBoundsChanged(Gwen::Rect oldBounds) -{ - //Anything that needs to update on size changes - //Iterate my children and tell them I've changed - // - - - - if ( m_Bounds.w != oldBounds.w || m_Bounds.h != oldBounds.h ) - { - if ( GetParent() ) - GetParent()->OnChildBoundsChanged( oldBounds, this ); - Invalidate(); - } - - Redraw(); - UpdateRenderBounds(); -} - -void Base::OnScaleChanged() -{ - for ( Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter ) - { - (*iter)->OnScaleChanged(); - } -} - -void Base::OnChildBoundsChanged( Gwen::Rect /*oldChildBounds*/, Base* /*pChild*/ ) -{ - -} - -void Base::Render( Gwen::Skin::Base* /*skin*/ ) -{ -} - -void Base::DoCacheRender( Gwen::Skin::Base* skin, Gwen::Controls::Base* pMaster ) -{ - Gwen::Renderer::Base* render = skin->GetRender(); - Gwen::Renderer::ICacheToTexture* cache = render->GetCTT(); - - if ( !cache ) return; - - Gwen::Point pOldRenderOffset = render->GetRenderOffset(); - - Gwen::Rect rOldRegion = render->ClipRegion(); - - if ( this != pMaster ) - { - render->AddRenderOffset( GetBounds() ); - render->AddClipRegion( GetBounds() ); - } - else - { - render->SetRenderOffset( Gwen::Point( 0, 0 ) ); - render->SetClipRegion( GetBounds() ); - } - - if ( m_bCacheTextureDirty && render->ClipRegionVisible() ) - { - render->StartClip(); - - if ( ShouldCacheToTexture() ) - cache->SetupCacheTexture( this ); - - //Render myself first - Render( skin ); - - if ( !Children.empty() ) - { - //Now render my kids - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - if ( pChild->Hidden() ) continue; - - pChild->DoCacheRender( skin, pMaster ); - } - } - - if ( ShouldCacheToTexture() ) - { - cache->FinishCacheTexture( this ); - m_bCacheTextureDirty = false; - } - } - - render->SetClipRegion( rOldRegion ); - render->StartClip(); - render->SetRenderOffset( pOldRenderOffset ); - cache->DrawCachedControlTexture( this ); -} - -void Base::DoRender( Gwen::Skin::Base* skin ) -{ - // If this control has a different skin, - // then so does its children. - if ( m_Skin ) - skin = m_Skin; - - // Do think - Think(); - - Gwen::Renderer::Base* render = skin->GetRender(); - - if ( render->GetCTT() && ShouldCacheToTexture() ) - { - DoCacheRender( skin, this ); - return; - } - - Gwen::Point pOldRenderOffset = render->GetRenderOffset(); - - render->AddRenderOffset( GetBounds() ); - - RenderUnder( skin ); - - Gwen::Rect rOldRegion = render->ClipRegion(); - render->AddClipRegion( GetBounds() ); - - if ( render->ClipRegionVisible() ) - { - render->StartClip(); - - //Render myself first - Render( skin ); - - if ( !Children.empty() ) - { - //Now render my kids - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - if ( pChild->Hidden() ) continue; - - pChild->DoRender( skin ); - } - } - - render->SetClipRegion( rOldRegion ); - render->StartClip(); - - RenderOver( skin ); - } - else - { - render->SetClipRegion( rOldRegion ); - } - - RenderFocus( skin ); - - render->SetRenderOffset( pOldRenderOffset ); -} - -void Base::SetSkin( Skin::Base* skin, bool doChildren ) -{ - if ( m_Skin == skin ) return; - m_Skin = skin; - Invalidate(); - Redraw(); - OnSkinChanged( skin ); - - if ( doChildren ) - { - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - (*it)->SetSkin( skin, true); - } - } -} - -void Base::OnSkinChanged( Skin::Base* /*skin*/ ) -{ - //Do something -} - -bool Base::OnMouseWheeled( int iDelta ) -{ - if ( m_ActualParent ) - return m_ActualParent->OnMouseWheeled( iDelta ); - - return false; -} - -void Base::OnMouseMoved( int /*x*/, int /*y*/, int /*deltaX*/, int /*deltaY*/ ) -{ -} - -void Base::OnMouseEnter() -{ - onHoverEnter.Call( this ); - - if ( GetToolTip() ) - ToolTip::Enable( this ); - else if ( GetParent() && GetParent()->GetToolTip() ) - ToolTip::Enable( GetParent() ); -} - -void Base::OnMouseLeave() -{ - onHoverLeave.Call( this ); - if ( GetToolTip() ) - ToolTip::Disable( this ); -} - - -bool Base::IsHovered() -{ - return Gwen::HoveredControl == this; -} - -bool Base::ShouldDrawHover() -{ - return Gwen::MouseFocus == this || Gwen::MouseFocus == NULL; -} - -bool Base::HasFocus() -{ - return Gwen::KeyboardFocus == this; -} - -void Base::Focus() -{ - if ( Gwen::KeyboardFocus == this ) return; - - if ( Gwen::KeyboardFocus ) - Gwen::KeyboardFocus->OnLostKeyboardFocus(); - - Gwen::KeyboardFocus = this; - - OnKeyboardFocus(); - Redraw(); -} - -void Base::Blur() -{ - if ( Gwen::KeyboardFocus != this ) return; - - Gwen::KeyboardFocus = NULL; - OnLostKeyboardFocus(); - - Redraw(); -} - -bool Base::IsOnTop() -{ - Base::List::iterator iter = GetParent()->Children.begin(); - Base* pChild = *iter; - - if ( pChild == this ) - return true; - - return false; -} - - -void Base::Touch() -{ - if ( GetParent() ) - GetParent()->OnChildTouched( this ); -} - -void Base::OnChildTouched( Controls::Base* /*pChild*/ ) -{ - Touch(); -} - -Base* Base::GetControlAt( int x, int y ) -{ - if ( Hidden() ) - return NULL; - - if ( x < 0 || y < 0 || x >= Width() || y >= Height() ) - return NULL; - - Base::List::reverse_iterator iter; - for (iter = Children.rbegin(); iter != Children.rend(); ++iter) - { - Base* pChild = *iter; - Base* pFound = NULL; - pFound = pChild->GetControlAt( x - pChild->X(), y - pChild->Y() ); - if ( pFound ) return pFound; - } - - if ( !GetMouseInputEnabled() ) - return NULL; - - return this; -} - - -void Base::Layout( Skin::Base* skin ) -{ - if ( skin->GetRender()->GetCTT() && ShouldCacheToTexture() ) - skin->GetRender()->GetCTT()->CreateControlCacheTexture( this ); -} - -int avoidUpdate = -15; - -void Base::RecurseLayout( Skin::Base* skin ) -{ - if ( m_Skin ) skin = m_Skin; - if ( Hidden() ) return; - - if ( NeedsLayout() ) - { - m_bNeedsLayout = false; - Layout( skin ); - } - - - if (avoidUpdate>0) - return; - - Gwen::Rect rBounds = GetRenderBounds(); - - // Adjust bounds for padding - rBounds.x += m_Padding.left; - rBounds.w -= m_Padding.left + m_Padding.right; - rBounds.y += m_Padding.top; - rBounds.h -= m_Padding.top + m_Padding.bottom; - - int sz = Children.size(); - if (sz>100) - { -// printf("!\n"); - - } - int curChild = 0; - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - curChild++; - if ( pChild->Hidden() ) - continue; - - - int iDock = pChild->GetDock(); - - if ( iDock & Pos::Fill ) - continue; - - if ( iDock & Pos::Top ) - { - const Margin& margin = pChild->GetMargin(); - - pChild->SetBounds( rBounds.x + margin.left, rBounds.y + margin.top, rBounds.w - margin.left - margin.right, pChild->Height() ); - - int iHeight = margin.top + margin.bottom + pChild->Height(); - rBounds.y += iHeight; - rBounds.h -= iHeight; - } - - if ( iDock & Pos::Left ) - { - const Margin& margin = pChild->GetMargin(); - - pChild->SetBounds( rBounds.x + margin.left, rBounds.y + margin.top, pChild->Width(), rBounds.h - margin.top - margin.bottom ); - - int iWidth = margin.left + margin.right + pChild->Width(); - rBounds.x += iWidth; - rBounds.w -= iWidth; - } - - if ( iDock & Pos::Right ) - { - // TODO: THIS MARGIN CODE MIGHT NOT BE FULLY FUNCTIONAL - const Margin& margin = pChild->GetMargin(); - - pChild->SetBounds( (rBounds.x+rBounds.w)-pChild->Width()-margin.right, rBounds.y + margin.top, pChild->Width(), rBounds.h - margin.top - margin.bottom ); - - int iWidth = margin.left + margin.right + pChild->Width(); - rBounds.w -= iWidth; - } - - if ( iDock & Pos::Bottom ) - { - // TODO: THIS MARGIN CODE MIGHT NOT BE FULLY FUNCTIONAL - const Margin& margin = pChild->GetMargin(); - - pChild->SetBounds( rBounds.x + margin.left, (rBounds.y+rBounds.h)-pChild->Height()-margin.bottom, rBounds.w - margin.left - margin.right, pChild->Height() ); - rBounds.h -= pChild->Height() + margin.bottom + margin.top; - } - - pChild->RecurseLayout( skin ); - - } - - m_InnerBounds = rBounds; - - curChild = 0; - // - // Fill uses the left over space, so do that now. - // - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - int iDock = pChild->GetDock(); - curChild++; - if ( !(iDock & Pos::Fill) ) - continue; - - - - const Margin& margin = pChild->GetMargin(); - - pChild->SetBounds( rBounds.x + margin.left, rBounds.y + margin.top, rBounds.w - margin.left - margin.right, rBounds.h - margin.top - margin.bottom ); - pChild->RecurseLayout( skin ); - } - - PostLayout( skin ); - - if ( IsTabable() ) - { - if ( !GetCanvas()->FirstTab ) GetCanvas()->FirstTab = this; - if ( !GetCanvas()->NextTab ) GetCanvas()->NextTab = this; - } - - if ( Gwen::KeyboardFocus == this ) - { - GetCanvas()->NextTab = NULL; - } -} - -bool Base::IsChild( Controls::Base* pChild ) -{ - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - if ( pChild == (*iter) ) return true; - } - - return false; -} - -Gwen::Point Base::LocalPosToCanvas( const Gwen::Point& pnt ) -{ - if ( m_Parent ) - { - int x = pnt.x + X(); - int y = pnt.y + Y(); - - // If our parent has an innerpanel and we're a child of it - // add its offset onto us. - // - if ( m_Parent->m_InnerPanel && m_Parent->m_InnerPanel->IsChild( this ) ) - { - x += m_Parent->m_InnerPanel->X(); - y += m_Parent->m_InnerPanel->Y(); - } - - return m_Parent->LocalPosToCanvas( Gwen::Point( x, y ) ); - } - - return pnt; -} - -Gwen::Point Base::CanvasPosToLocal( const Gwen::Point& pnt ) -{ - if ( m_Parent ) - { - int x = pnt.x - X(); - int y = pnt.y - Y(); - - // If our parent has an innerpanel and we're a child of it - // add its offset onto us. - // - if ( m_Parent->m_InnerPanel && m_Parent->m_InnerPanel->IsChild( this ) ) - { - x -= m_Parent->m_InnerPanel->X(); - y -= m_Parent->m_InnerPanel->Y(); - } - - - return m_Parent->CanvasPosToLocal( Gwen::Point( x, y ) ); - } - - return pnt; -} - -bool Base::IsMenuComponent() -{ - if ( !m_Parent ) return false; - return m_Parent->IsMenuComponent(); -} - -void Base::CloseMenus() -{ - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - (*it)->CloseMenus(); - } -} - -void Base::UpdateRenderBounds() -{ - m_RenderBounds.x = 0; - m_RenderBounds.x = 0; - - m_RenderBounds.w = m_Bounds.w; - m_RenderBounds.h = m_Bounds.h; -} - -void Base::UpdateCursor() -{ - Platform::SetCursor( m_Cursor ); -} - -DragAndDrop::Package* Base::DragAndDrop_GetPackage( int /*x*/, int /*y*/ ) -{ - return m_DragAndDrop_Package; -} - -bool Base::DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ ) -{ - DragAndDrop::SourceControl->SetParent( this ); - return true; -} - -bool Base::DragAndDrop_Draggable() -{ - if ( !m_DragAndDrop_Package ) return false; - - return m_DragAndDrop_Package->draggable; -} - -void Base::DragAndDrop_SetPackage( bool bDraggable, const String& strName, void* pUserData ) -{ - if ( !m_DragAndDrop_Package ) - { - m_DragAndDrop_Package = new Gwen::DragAndDrop::Package(); - } - - m_DragAndDrop_Package->draggable = bDraggable; - m_DragAndDrop_Package->name = strName; - m_DragAndDrop_Package->userdata = pUserData; -} - -void Base::DragAndDrop_StartDragging( Gwen::DragAndDrop::Package* pPackage, int x, int y ) -{ - pPackage->holdoffset = CanvasPosToLocal( Gwen::Point( x, y ) ); - pPackage->drawcontrol = this; -} - -bool Base::SizeToChildren( bool w, bool h ) -{ - Gwen::Point size = ChildrenSize(); - return SetSize( w ? size.x : Width(), h ? size.y : Height() ); -} - -Gwen::Point Base::ChildrenSize() -{ - Gwen::Point size; - - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - if ( pChild->Hidden() ) continue; - - size.x = GwenUtil_Max( size.x, pChild->Right() ); - size.y = GwenUtil_Max( size.y, pChild->Bottom() ); - } - - return size; -} - -void Base::SetPadding( const Padding& padding ) -{ - if ( m_Padding.left == padding.left && - m_Padding.top == padding.top && - m_Padding.right == padding.right && - m_Padding.bottom == padding.bottom ) - return; - - m_Padding = padding; - Invalidate(); - InvalidateParent(); -} - -void Base::SetMargin( const Margin& margin ) -{ - if ( m_Margin.top == margin.top && - m_Margin.left == margin.left && - m_Margin.bottom == margin.bottom && - m_Margin.right == margin.right ) - return; - - m_Margin = margin; - Invalidate(); - InvalidateParent(); -} - -bool Base::HandleAccelerator( Gwen::UnicodeString& accelerator ) -{ - if ( Gwen::KeyboardFocus == this || !AccelOnlyFocus() ) - { - AccelMap::iterator iter = m_Accelerators.find( accelerator ); - if ( iter != m_Accelerators.end() ) - { - iter->second->Call( this ); - return true; - } - } - - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - if ( (*it)->HandleAccelerator( accelerator ) ) - return true; - } - return false; -} - -bool Base::OnKeyPress( int iKey, bool bPress ) -{ - bool bHandled = false; - switch ( iKey ) - { - case Key::Tab: bHandled = OnKeyTab( bPress ); break; - case Key::Space: bHandled = OnKeySpace( bPress ); break; - case Key::Home: bHandled = OnKeyHome( bPress ); break; - case Key::End: bHandled = OnKeyEnd( bPress ); break; - case Key::Return: bHandled = OnKeyReturn( bPress ); break; - case Key::Backspace: bHandled = OnKeyBackspace( bPress ); break; - case Key::Delete: bHandled = OnKeyDelete( bPress ); break; - case Key::Right: bHandled = OnKeyRight( bPress ); break; - case Key::Left: bHandled = OnKeyLeft( bPress ); break; - case Key::Up: bHandled = OnKeyUp( bPress ); break; - case Key::Down: bHandled = OnKeyDown( bPress ); break; - case Key::Escape: bHandled = OnKeyEscape( bPress ); break; - - default: break; - } - - if ( !bHandled && GetParent() ) - GetParent()->OnKeyPress( iKey, bPress ); - - return bHandled; -} - -bool Base::OnKeyRelease( int iKey ) -{ - return OnKeyPress( iKey, false ); -} - -bool Base::OnKeyTab( bool bDown ) -{ - if ( !bDown ) return true; - - if ( GetCanvas()->NextTab ) - { - GetCanvas()->NextTab->Focus(); - Redraw(); - } - - return true; -} - -void Base::RenderFocus( Gwen::Skin::Base* skin ) -{ - if ( Gwen::KeyboardFocus != this ) return; - if ( !IsTabable() ) return; - - skin->DrawKeyboardHighlight( this, GetRenderBounds(), 3 ); -} - -void Base::SetToolTip( const String& strText ) -{ - SetToolTip( Gwen::Utility::StringToUnicode( strText ) ); -} - -void Base::SetToolTip( const UnicodeString& strText ) -{ - Label* tooltip = new Label( this ); - tooltip->SetText( strText ); - tooltip->SizeToContents(); - - SetToolTip( tooltip ); -} - -#ifndef GWEN_NO_ANIMATION - -void Base::Anim_WidthIn( float fLength, float fDelay, float fEase ) -{ - Gwen::Anim::Add( this, new Gwen::Anim::Size::Width( 0, Width(), fLength, false, fDelay, fEase ) ); - SetWidth( 0 ); -} - -void Base::Anim_HeightIn( float fLength, float fDelay, float fEase ) -{ - Gwen::Anim::Add( this, new Gwen::Anim::Size::Height( 0, Height(), fLength, false, fDelay, fEase ) ); - SetHeight( 0 ); -} - -void Base::Anim_WidthOut( float fLength, bool bHide, float fDelay, float fEase ) -{ - Gwen::Anim::Add( this, new Gwen::Anim::Size::Width( Width(), 0, fLength, bHide, fDelay, fEase ) ); -} - -void Base::Anim_HeightOut( float fLength, bool bHide, float fDelay, float fEase ) -{ - Gwen::Anim::Add( this, new Gwen::Anim::Size::Height( Height(), 0, fLength, bHide, fDelay, fEase ) ); -} - -#endif \ No newline at end of file diff --git a/btgui/Gwen/Controls/Base.h b/btgui/Gwen/Controls/Base.h deleted file mode 100644 index 011a9e7bf..000000000 --- a/btgui/Gwen/Controls/Base.h +++ /dev/null @@ -1,534 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_BASE_H -#define GWEN_CONTROLS_BASE_H - -#include "Gwen/Exports.h" -#include "Gwen/Structures.h" -#include "Gwen/BaseRender.h" -#include "Gwen/Events.h" -#include -#include - -#define GWEN_DECLARE_CAST(T)\ -virtual class T* DynamicCast##T() { return 0;}\ -virtual const class T* DynamicCast##T() const { return 0;}\ - -#define GWEN_IMPLEMENT_CAST(T)\ -virtual class T* DynamicCast##T() { return (T*)this;}\ -virtual const class T* DynamicCast##T() const { return (T*)this;}\ - - -namespace Gwen -{ - namespace ControlsInternal - { - class ColorDisplay; - class Resizer; - - }; - - namespace Pos - { - enum - { - None = 0, - Left = (1 << 1), - Right = (1 << 2), - Top = (1 << 3), - Bottom = (1 << 4), - CenterV = (1 << 5), - CenterH = (1 << 6), - Fill = (1 << 7), - Center = CenterV | CenterH, - }; - } - - namespace Skin - { - class Base; - } - - namespace Controls - { - class Canvas; - - namespace Layout - { - class TableRow; - }; - - - - - class GWEN_EXPORT Base : public Event::Handler - { - public: - - GWEN_DECLARE_CAST(TabButton) - GWEN_DECLARE_CAST(DockedTabControl) - virtual class Layout::TableRow* DynamicCastLayoutTableRow() { return 0;} - virtual const class Layout::TableRow* DynamicCastLayoutTableRow() const { return 0;} - - - - GWEN_DECLARE_CAST(TextBoxNumeric) - GWEN_DECLARE_CAST(HorizontalSlider) - GWEN_DECLARE_CAST(DockBase) - GWEN_DECLARE_CAST(MenuItem) - GWEN_DECLARE_CAST(PropertyRow) - GWEN_DECLARE_CAST(WindowControl) - - GWEN_DECLARE_CAST(TreeControl) - GWEN_DECLARE_CAST(TreeNode) - GWEN_DECLARE_CAST(HSVColorPicker) - GWEN_DECLARE_CAST(TabControl) - - GWEN_DECLARE_CAST(TabControlInner) - GWEN_DECLARE_CAST(GroupBox) - GWEN_DECLARE_CAST(Properties) - GWEN_DECLARE_CAST(RadioButton) - GWEN_DECLARE_CAST(LabeledRadioButton) - - - - virtual class ::Gwen::ControlsInternal::Resizer* DynamicCastResizer() { return 0;} - virtual const class ::Gwen::ControlsInternal::Resizer* DynamicCastResizer() const { return 0;} - - - virtual class ::Gwen::ControlsInternal::ColorDisplay* DynamicCastColorDisplay() { return 0;} - virtual const class ::Gwen::ControlsInternal::ColorDisplay* DynamicCastColorDisplay() const { return 0;} - - - - - - typedef std::list List; - - typedef std::map AccelMap; - - Base( Base* pParent ); - virtual ~Base(); - - virtual void DelayedDelete(); - - virtual void SetParent( Controls::Base* pParent ); - virtual Controls::Base* GetParent() const { return m_Parent; } - virtual Controls::Canvas* GetCanvas(); - - virtual Base::List& GetChildren(){ if ( m_InnerPanel ) return m_InnerPanel->GetChildren(); return Children; } - virtual bool IsChild( Controls::Base* pChild ); - virtual int NumChildren(); - virtual bool SizeToChildren( bool w = true, bool h = true ); - virtual Gwen::Point ChildrenSize(); - virtual Controls::Base* FindChildByName( const Gwen::String& name, bool bRecursive = false ); - - virtual void SetName(Gwen::String name) { m_Name = name; } - virtual const Gwen::String& GetName() { return m_Name; } - - virtual void Think(){} - virtual void ExpandAll(){} - virtual void SizeToContents(){} - virtual bool IsActive() { return false;} - - - virtual void AddChild( Controls::Base* pChild ); - - virtual void RemoveChild( Controls::Base* pParent ); - protected: - - - - virtual void OnChildAdded( Controls::Base* pChild ); - virtual void OnChildRemoved( Controls::Base* pChild ); - - public: - - virtual void RemoveAllChildren(); - - virtual void SendToBack( void ); - virtual void BringToFront( void ); - virtual void BringNextToControl( Controls::Base* pChild, bool bBehind ); - - virtual Gwen::Point LocalPosToCanvas( const Gwen::Point& in ); - virtual Gwen::Point CanvasPosToLocal( const Gwen::Point& in ); - - virtual void Dock( int iDock ); - virtual int GetDock(); - - virtual void RestrictToParent( bool restrict ) { m_bRestrictToParent = restrict; } - virtual bool ShouldRestrictToParent() { return m_bRestrictToParent; } - - virtual int X() const - { - return m_Bounds.x; - } - virtual int Y() const - { - return m_Bounds.y; - } - virtual int Width() const - { - return m_Bounds.w; - } - virtual int Height() const - { - return m_Bounds.h; - } - virtual int Bottom() const - { - return m_Bounds.y + m_Bounds.h + m_Margin.bottom; - } - virtual int Right() const - { - return m_Bounds.x + m_Bounds.w + m_Margin.right; - } - - virtual const Margin& GetMargin() const { return m_Margin; } - virtual const Padding& GetPadding() const { return m_Padding; } - - virtual void SetPos( int x, int y ); - virtual void SetWidth( int w ) - { - SetSize( w, Height()); - } - virtual void SetHeight( int h ) - { -SetSize( Width(), h); - } - virtual bool SetSize( int w, int h ); - virtual bool SetBounds( int x, int y, int w, int h ); - virtual bool SetBounds( const Gwen::Rect& bounds ); - - virtual void SetPadding( const Padding& padding ); - virtual void SetMargin( const Margin& margin ); - - // MoveTo is identical to SetPos except it uses ShouldRestrictToParent() - virtual void MoveTo (int x, int y ); - virtual void MoveBy (int x, int y ); - - virtual const Gwen::Rect& GetBounds() const - { - return m_Bounds; - } - - virtual Controls::Base* GetControlAt( int x, int y ); - - - - - protected: - - virtual void OnBoundsChanged( Gwen::Rect oldBounds ); - virtual void OnChildBoundsChanged( Gwen::Rect oldChildBounds, Base* pChild ); - - virtual void OnScaleChanged(); - - public: - - // Innerbounds is the area inside the control that - // doesn't have child controls docked to it. - virtual const Gwen::Rect& GetInnerBounds() const { return m_InnerBounds; } - - protected: - - Gwen::Rect m_InnerBounds; - - public: - - virtual const Gwen::Rect& GetRenderBounds() const{ return m_RenderBounds; } - - protected: - - virtual void UpdateRenderBounds(); - - public: - - virtual void DoRender( Gwen::Skin::Base* skin ); - virtual void DoCacheRender( Gwen::Skin::Base* skin, Gwen::Controls::Base* pMaster ); - - protected: - - virtual void Render( Gwen::Skin::Base* skin ); - virtual void RenderUnder( Gwen::Skin::Base* /*skin*/ ){}; - virtual void RenderOver( Gwen::Skin::Base* /*skin*/ ){}; - virtual void RenderFocus( Gwen::Skin::Base* /*skin*/ ); - - public: - - virtual void SetHidden( bool hidden ) - { - if ( m_bHidden == hidden ) - return; - m_bHidden = hidden; - Invalidate(); - } - virtual bool Hidden() const; // Returns true only if this control is hidden - virtual bool Visible() const; // Returns false if this control or its parents are hidden - virtual void Hide(){ SetHidden( true ); } - virtual void Show(){ SetHidden( false ); } - - //Skin - virtual void SetSkin( Skin::Base* skin, bool doChildren = false ); - virtual Gwen::Skin::Base* GetSkin( void ); - - // Background drawing - virtual bool ShouldDrawBackground(){ return m_bDrawBackground; } - virtual void SetShouldDrawBackground( bool b ){ m_bDrawBackground =b; } - - protected: - - virtual void OnSkinChanged( Gwen::Skin::Base* newSkin ); - - public: - - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - virtual bool OnMouseWheeled( int iDelta ); - virtual void OnMouseClickLeft( int /*x*/, int /*y*/, bool /*bDown*/ ){}; - virtual void OnMouseClickRight( int /*x*/, int /*y*/, bool /*bDown*/ ){} - virtual void OnMouseDoubleClickLeft( int x, int y ){ OnMouseClickLeft( x, y, true ); }; - virtual void OnMouseDoubleClickRight( int x, int y ){ OnMouseClickRight( x, y, true ); }; - virtual void OnLostKeyboardFocus(){} - virtual void OnKeyboardFocus(){} - - virtual void SetMouseInputEnabled( bool b ) { m_bMouseInputEnabled = b; } - virtual bool GetMouseInputEnabled() { return m_bMouseInputEnabled; } - - virtual void SetKeyboardInputEnabled( bool b ){ m_bKeyboardInputEnabled = b; } - virtual bool GetKeyboardInputEnabled() const { return m_bKeyboardInputEnabled; } - virtual bool NeedsInputChars(){ return false; } - - virtual bool OnChar( Gwen::UnicodeChar /*c*/ ){ return false; } - - virtual bool OnKeyPress( int iKey, bool bPress = true ); - virtual bool OnKeyRelease( int iKey ); - - virtual void OnPaste(Controls::Base* /*pFrom*/){} - virtual void OnCopy(Controls::Base* /*pFrom*/){} - virtual void OnCut(Controls::Base* /*pFrom*/){} - virtual void OnSelectAll(Controls::Base* /*pFrom*/){} - - virtual bool OnKeyTab( bool bDown ); - virtual bool OnKeySpace( bool /*bDown*/ ){ return false; } - virtual bool OnKeyReturn( bool /*bDown*/ ){ return false; } - virtual bool OnKeyBackspace( bool /*bDown*/ ){ return false; } - virtual bool OnKeyDelete( bool /*bDown*/ ){ return false; } - virtual bool OnKeyRight( bool /*bDown*/ ){ return false; } - virtual bool OnKeyLeft( bool /*bDown*/ ){ return false; } - virtual bool OnKeyHome( bool /*bDown*/ ){ return false; } - virtual bool OnKeyEnd( bool /*bDown*/ ){ return false; } - virtual bool OnKeyUp( bool /*bDown*/ ){ return false; } - virtual bool OnKeyDown( bool /*bDown*/ ){ return false; } - virtual bool OnKeyEscape( bool /*bDown*/ ) { return false; } - - virtual void OnMouseEnter(); - virtual void OnMouseLeave(); - virtual bool IsHovered(); - virtual bool ShouldDrawHover(); - - virtual void Touch(); - virtual void OnChildTouched( Controls::Base* pChild ); - - virtual bool IsOnTop(); - - virtual bool HasFocus(); - virtual void Focus(); - virtual void Blur(); - - //Other - virtual void SetDisabled( bool active ) { m_bDisabled = active; } - virtual bool IsDisabled(){ return m_bDisabled; } - - virtual void Redraw(){ m_bCacheTextureDirty = true; if ( m_Parent ) m_Parent->Redraw(); } - virtual void SetCacheToTexture() { m_bCacheToTexture = true; } - virtual bool ShouldCacheToTexture() { return m_bCacheToTexture; } - - virtual void SetCursor( unsigned char c ){ m_Cursor = c; } - virtual void UpdateCursor(); - - virtual Gwen::Point GetMinimumSize(){ return Gwen::Point( 1, 1 ); } - virtual Gwen::Point GetMaximumSize(){ return Gwen::Point( 4096, 4096 ); } - - virtual void SetToolTip( const String& strText ); - virtual void SetToolTip( const UnicodeString& strText ); - virtual void SetToolTip( Base* tooltip ) { m_ToolTip = tooltip; if ( m_ToolTip ){ m_ToolTip->SetParent( this ); m_ToolTip->SetHidden( true ); } } - virtual Base* GetToolTip() { return m_ToolTip; } - - virtual bool IsMenuComponent(); - virtual void CloseMenus(); - - virtual bool IsTabable() { return m_Tabable; } - virtual void SetTabable( bool isTabable ) { m_Tabable = isTabable; } - - - - - //Accelerator functionality - void DefaultAccel( Gwen::Controls::Base* /*pCtrl*/ ) { AcceleratePressed(); } - virtual void AcceleratePressed() {}; - virtual bool AccelOnlyFocus() { return false; } - virtual bool HandleAccelerator( Gwen::UnicodeString& accelerator ); - - template - void AddAccelerator( Gwen::UnicodeString accelerator, T func, Gwen::Event::Handler* handler = NULL ) - { - if ( handler == NULL ) - handler = this; - Gwen::Event::Caller* caller = new Gwen::Event::Caller(); - caller->Add( handler, func ); - m_Accelerators[ accelerator ] = caller; - } - - void AddAccelerator( Gwen::UnicodeString accelerator ) - { - AddAccelerator( accelerator, &Base::DefaultAccel, this ); - } - - AccelMap m_Accelerators; - - // Default Events - - Gwen::Event::Caller onHoverEnter; - Gwen::Event::Caller onHoverLeave; - - // Childrens List - - Base::List Children; - - protected: - - // The logical parent - // It's usually what you expect, the control you've parented it to. - Base* m_Parent; - - // If the innerpanel exists our children will automatically - // become children of that instead of us - allowing us to move - // them all around by moving that panel (useful for scrolling etc) - Base* m_InnerPanel; - - // This is the panel's actual parent - most likely the logical - // parent's InnerPanel (if it has one). You should rarely need this. - Base* m_ActualParent; - - Base* m_ToolTip; - - Skin::Base* m_Skin; - - Gwen::Rect m_Bounds; - Gwen::Rect m_RenderBounds; - Padding m_Padding; - Margin m_Margin; - - Gwen::String m_Name; - - - bool m_bRestrictToParent; - bool m_bDisabled; - bool m_bHidden; - bool m_bMouseInputEnabled; - bool m_bKeyboardInputEnabled; - bool m_bDrawBackground; - - int m_iDock; - - unsigned char m_Cursor; - - bool m_Tabable; - - public: - - bool NeedsLayout(){ return m_bNeedsLayout; } - void Invalidate(); - void InvalidateParent(){ if ( m_Parent ){ m_Parent->Invalidate(); } } - void InvalidateChildren( bool bRecursive = false ); - void Position( int pos, int xpadding = 0, int ypadding = 0 ); - - - protected: - - virtual void RecurseLayout( Skin::Base* skin ); - virtual void Layout( Skin::Base* skin ); - virtual void PostLayout( Skin::Base* /*skin*/ ){}; - - bool m_bNeedsLayout; - bool m_bCacheTextureDirty; - bool m_bCacheToTexture; - - // - // Drag + Drop - public: - - // Giver - - virtual void DragAndDrop_SetPackage( bool bDraggable, const String& strName = "", void* pUserData = NULL ); - virtual bool DragAndDrop_Draggable(); - virtual bool DragAndDrop_ShouldStartDrag(){ return true; } - virtual void DragAndDrop_StartDragging( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual Gwen::DragAndDrop::Package* DragAndDrop_GetPackage( int x, int y ); - virtual void DragAndDrop_EndDragging( bool /*bSuccess*/, int /*x*/, int /*y*/ ){}; - - protected: - - DragAndDrop::Package* m_DragAndDrop_Package; - - public: - - // Receiver - virtual void DragAndDrop_HoverEnter( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ ){ } - virtual void DragAndDrop_HoverLeave( Gwen::DragAndDrop::Package* /*pPackage*/ ){ } - virtual void DragAndDrop_Hover( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ ){}; - virtual bool DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual bool DragAndDrop_CanAcceptPackage( Gwen::DragAndDrop::Package* /*pPackage*/ ){ return false; } - - - // - // This is to be used by the client implementation - // NOT HOOKS ETC. - // - public: - - void* GetUserData(){ return m_pUserData; } - void SetUserData( void* pData ){ m_pUserData = pData; } - - private: - - void* m_pUserData; - - // - // Useful anim shortcuts - // - public: - #ifndef GWEN_NO_ANIMATION - - virtual void Anim_WidthIn( float fLength, float fDelay = 0.0f, float fEase = 1.0f ); - virtual void Anim_HeightIn( float fLength, float fDelay = 0.0f, float fEase = 1.0f ); - virtual void Anim_WidthOut( float fLength, bool bHide = true, float fDelay = 0.0f, float fEase = 1.0f ); - virtual void Anim_HeightOut( float fLength, bool bHide = true, float fDelay = 0.0f, float fEase = 1.0f ); - - #endif - - }; - - } -} - -// To be placed in the controls .h definition. -#define GWEN_CONTROL( ThisName, BaseName )\ - public:\ - typedef BaseName BaseClass;\ - typedef ThisName ThisClass;\ - GWEN_IMPLEMENT_CAST(ThisName);\ - ThisName( Gwen::Controls::Base* pParent ) - -#define GWEN_CONTROL_INLINE( ThisName, BaseName )\ - GWEN_CONTROL( ThisName, BaseName ) : BaseClass( pParent ) - -#define GWEN_CONTROL_CONSTRUCTOR( ThisName )\ - ThisName::ThisName( Gwen::Controls::Base* pParent ) : BaseClass( pParent ) - -#endif diff --git a/btgui/Gwen/Controls/Button.cpp b/btgui/Gwen/Controls/Button.cpp deleted file mode 100644 index 702e0c3d0..000000000 --- a/btgui/Gwen/Controls/Button.cpp +++ /dev/null @@ -1,169 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/ImagePanel.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( Button ) -{ - m_Image = NULL; - m_bDepressed = false; - m_bCenterImage = false; - - SetSize( 100, 20 ); - SetMouseInputEnabled( true ); - SetIsToggle( false ); - SetAlignment( Gwen::Pos::Center ); - SetTextPadding( Padding( 3, 0, 3, 0 ) ); - m_bToggleStatus = false; - SetKeyboardInputEnabled( false ); - SetTabable( false ); -} - -void Button::Render( Skin::Base* skin ) -{ - if ( ShouldDrawBackground() ) - { - bool bDrawDepressed = IsDepressed() && IsHovered(); - if ( IsToggle() ) bDrawDepressed = bDrawDepressed || GetToggleState(); - - bool bDrawHovered = IsHovered() && ShouldDrawHover(); - - skin->DrawButton( this, bDrawDepressed, bDrawHovered ); - } -} - -void Button::OnMouseClickLeft( int /*x*/, int /*y*/, bool bDown ) -{ - if ( bDown ) - { - m_bDepressed = true; - Gwen::MouseFocus = this; - onDown.Call( this ); - } - else - { - if ( IsHovered() && m_bDepressed ) - { - OnPress(); - } - - m_bDepressed = false; - Gwen::MouseFocus = NULL; - onUp.Call( this ); - } - - Redraw(); -} - -void Button::OnPress() -{ - if ( IsToggle() ) - { - SetToggleState( !GetToggleState() ); - } - - onPress.Call( this ); -} - - -void Button::SetImage( const TextObject& strName, bool bCenter ) -{ - if ( strName.GetUnicode() == L"" ) - { - if ( m_Image ) - { - delete m_Image; - m_Image= NULL; - } - - return; - } - - if ( !m_Image ) - { - m_Image = new ImagePanel( this ); - } - - m_Image->SetImage( strName ); - m_Image->SizeToContents(); - m_Image->SetPos( m_Padding.left, 2 ); - m_bCenterImage = bCenter; - - int IdealTextPadding = m_Image->Right() + m_Padding.left + 4; - if ( m_rTextPadding.left < IdealTextPadding ) - { - m_rTextPadding.left = IdealTextPadding; - } -} - -void Button::SetToggleState( bool b ) -{ - if ( m_bToggleStatus == b ) return; - - m_bToggleStatus = b; - - onToggle.Call( this ); - - if ( m_bToggleStatus ) - { - onToggleOn.Call( this ); - } - else - { - onToggleOff.Call( this ); - } -} - -void Button::SizeToContents() -{ - BaseClass::SizeToContents(); - - if ( m_Image ) - { - int height = m_Image->Height() + 4; - if ( Height() < height ) - { - SetHeight( height ); - } - } -} - -bool Button::OnKeySpace( bool bDown ) -{ - OnMouseClickLeft( 0, 0, bDown ); - return true; -} - -void Button::AcceleratePressed() -{ - OnPress(); -} - -void Button::Layout( Skin::Base* pSkin ) -{ - BaseClass::Layout( pSkin ); - if ( m_Image ) - { - Gwen::Align::CenterVertically( m_Image ); - - if ( m_bCenterImage ) - Gwen::Align::CenterHorizontally( m_Image ); - } -} - -void Button::OnMouseDoubleClickLeft( int x, int y ) -{ - OnMouseClickLeft( x, y, true ); - onDoubleClick.Call( this ); -}; \ No newline at end of file diff --git a/btgui/Gwen/Controls/Button.h b/btgui/Gwen/Controls/Button.h deleted file mode 100644 index 4e9d3358e..000000000 --- a/btgui/Gwen/Controls/Button.h +++ /dev/null @@ -1,90 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_BUTTON_H -#define GWEN_CONTROLS_BUTTON_H - -#include "Gwen/TextObject.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" - -namespace Gwen -{ - namespace Controls - { - class ImagePanel; - - class GWEN_EXPORT Button : public Label - { - public: - - GWEN_CONTROL( Button, Label ); - - virtual void Render( Skin::Base* skin ); - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - virtual void OnMouseDoubleClickLeft( int x, int y ); - virtual bool OnKeySpace( bool bDown ); - - virtual void OnPress(); - - virtual void AcceleratePressed(); - - virtual bool IsDepressed() const { return m_bDepressed; } - - // - // Buttons can be toggle type, which means that it is - // toggled on and off. Its toggle status is in IsDepressed. - // - virtual void SetIsToggle( bool b ){ m_bToggle = b; } - virtual bool IsToggle() const { return m_bToggle; } - virtual bool GetToggleState() const { return m_bToggleStatus; } - virtual void SetToggleState( bool b ); - virtual void Toggle(){ SetToggleState( !GetToggleState() ); } - - - virtual void SetImage( const TextObject& strName, bool bCenter = false ); - - // You can use this to trigger OnPress directly from other controls using GWEN_CALL_EX - virtual void ReceiveEventPress( Base* /*pControl*/ ) - { - OnPress(); - } - - virtual void SizeToContents(); - virtual void Layout( Skin::Base* pSkin ); - - virtual bool OnKeyReturn(bool bDown) - { - onKeyboardReturn.Call(this); - return true; - } - - public: - - Gwen::Event::Caller onPress; - Gwen::Event::Caller onDown; - Gwen::Event::Caller onUp; - Gwen::Event::Caller onDoubleClick; - Gwen::Event::Caller onKeyboardReturn; - - Gwen::Event::Caller onToggle; - Gwen::Event::Caller onToggleOn; - Gwen::Event::Caller onToggleOff; - - protected: - - ImagePanel* m_Image; - - bool m_bDepressed; - bool m_bToggle; - bool m_bToggleStatus; - - bool m_bCenterImage; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Canvas.cpp b/btgui/Gwen/Controls/Canvas.cpp deleted file mode 100644 index 777228c6f..000000000 --- a/btgui/Gwen/Controls/Canvas.cpp +++ /dev/null @@ -1,233 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Canvas.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Menu.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/ToolTip.h" - -#ifndef GWEN_NO_ANIMATION -#include "Gwen/Anim.h" -#endif - -using namespace Gwen::Controls; - - -Canvas::Canvas( Gwen::Skin::Base* pSkin ) : BaseClass( NULL ), m_bAnyDelete( false ),m_fScale(-1) -{ - SetBounds( 0, 0, 10000, 10000 ); - SetSkin( pSkin ); - SetScale( 1.0f ); - SetBackgroundColor( Color( 255, 255, 255, 255 ) ); - SetDrawBackground( false ); -} - -void Canvas::RenderCanvas() -{ - DoThink(); - - Gwen::Renderer::Base* render = m_Skin->GetRender(); - render->Begin(); - - - RecurseLayout( m_Skin ); - - render->SetClipRegion( GetBounds() ); - render->SetRenderOffset( Gwen::Point( 0, 0 ) ); - render->SetScale( Scale() ); - - if ( m_bDrawBackground ) - { - render->SetDrawColor( m_BackgroundColor ); - render->DrawFilledRect( GetRenderBounds() ); - } - - DoRender( m_Skin ); - - DragAndDrop::RenderOverlay( this, m_Skin ); - - ToolTip::RenderToolTip( m_Skin ); - - render->EndClip(); - - render->End(); - ProcessDelayedDeletes(); - -} - -void Canvas::Render( Gwen::Skin::Base* /*pRender*/ ) -{ - m_bNeedsRedraw = false; -} - -void Canvas::OnBoundsChanged( Gwen::Rect oldBounds ) -{ - BaseClass::OnBoundsChanged( oldBounds ); - InvalidateChildren( true ); -} - - -void Canvas::DoThink() -{ - if ( Hidden() ) return; - - #ifndef GWEN_NO_ANIMATION - Gwen::Anim::Think(); - #endif - - // Reset tabbing - { - NextTab = NULL; - FirstTab = NULL; - } - - ProcessDelayedDeletes(); - // Check has focus etc.. - RecurseLayout( m_Skin ); - - // If we didn't have a next tab, cycle to the start. - if ( NextTab == NULL ) - NextTab = FirstTab; - - Gwen::Input::OnCanvasThink( this ); - -} - -void Canvas::SetScale( float f ) -{ - if ( m_fScale == f ) return; - - m_fScale = f; - - if ( m_Skin && m_Skin->GetRender() ) - m_Skin->GetRender()->SetScale( m_fScale ); - - OnScaleChanged(); - Redraw(); -} - -void Canvas::AddDelayedDelete( Gwen::Controls::Base* pControl ) -{ - if ( !m_bAnyDelete || m_DeleteSet.find( pControl ) == m_DeleteSet.end() ) - { - m_bAnyDelete = true; - m_DeleteSet.insert( pControl ); - m_DeleteList.push_back( pControl ); - } -} - -void Canvas::PreDelete( Controls::Base * pControl ) -{ - if ( m_bAnyDelete ) - { - std::set< Controls::Base * >::iterator itFind; - if ( ( itFind = m_DeleteSet.find( pControl ) ) != m_DeleteSet.end() ) - { - m_DeleteList.remove( pControl ); - m_DeleteSet.erase( pControl ); - m_bAnyDelete = !m_DeleteSet.empty(); - } - } -} - -void Canvas::ProcessDelayedDeletes() -{ - while( m_bAnyDelete ) - { - m_bAnyDelete = false; - - Controls::Base::List deleteList = m_DeleteList; - - m_DeleteList.clear(); - m_DeleteSet.clear(); - - for ( Gwen::Controls::Base::List::iterator it = deleteList.begin(); it != deleteList.end(); ++it ) - { - Gwen::Controls::Base* pControl = *it; - delete pControl; - } - } -} - -void Canvas::Release() -{ - Base::List::iterator iter = Children.begin(); - while ( iter != Children.end() ) - { - Base* pChild = *iter; - iter = Children.erase( iter ); - delete pChild; - } - - delete this; -} - -bool Canvas::InputMouseMoved( int x, int y, int deltaX, int deltaY ) -{ - if ( Hidden() ) return false; - - // Todo: Handle scaling here.. - //float fScale = 1.0f / Scale(); - - Gwen::Input::OnMouseMoved( this, x, y, deltaX, deltaY ); - - if ( !Gwen::HoveredControl ) return false; - if ( Gwen::HoveredControl == this ) return false; - if ( Gwen::HoveredControl->GetCanvas() != this ) return false; - - Gwen::HoveredControl->OnMouseMoved( x, y, deltaX, deltaY ); - Gwen::HoveredControl->UpdateCursor(); - - DragAndDrop::OnMouseMoved( Gwen::HoveredControl, x, y ); - return true; -} - -bool Canvas::InputMouseButton( int iButton, bool bDown ) -{ - if ( Hidden() ) return false; - - return Gwen::Input::OnMouseClicked( this, iButton, bDown ); -} - -bool Canvas::InputKey( int iKey, bool bDown ) -{ - if ( Hidden() ) return false; - if ( iKey <= Gwen::Key::Invalid ) return false; - if ( iKey >= Gwen::Key::Count ) return false; - - return Gwen::Input::OnKeyEvent( this, iKey, bDown ); -} - -bool Canvas::InputCharacter( Gwen::UnicodeChar chr ) -{ - if ( Hidden() ) return false; - if ( !iswprint( chr ) ) return false; - - //Handle Accelerators - if ( Gwen::Input::HandleAccelerator( this, chr ) ) - return true; - - //Handle characters - if ( !Gwen::KeyboardFocus ) return false; - if ( Gwen::KeyboardFocus->GetCanvas() != this ) return false; - if ( !Gwen::KeyboardFocus->Visible() ) return false; - if ( Gwen::Input::IsControlDown() ) return false; - - return KeyboardFocus->OnChar( chr ); -} - -bool Canvas::InputMouseWheel( int val ) -{ - if ( Hidden() ) return false; - if ( !Gwen::HoveredControl ) return false; - if ( Gwen::HoveredControl == this ) return false; - if ( Gwen::HoveredControl->GetCanvas() != this ) return false; - - return Gwen::HoveredControl->OnMouseWheeled( val ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Canvas.h b/btgui/Gwen/Controls/Canvas.h deleted file mode 100644 index 6523d64e5..000000000 --- a/btgui/Gwen/Controls/Canvas.h +++ /dev/null @@ -1,107 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_CANVAS_H -#define GWEN_CONTROLS_CANVAS_H - -#include -#include "Gwen/Controls/Base.h" -#include "Gwen/InputHandler.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT Canvas : public Base - { - public: - - typedef Controls::Base BaseClass; - - Canvas( Skin::Base* pSkin ); - - // - // For additional initialization - // (which is sometimes not appropriate in the constructor) - // - virtual void Initialize(){}; - - // - // You should call this to render your canvas. - // - virtual void RenderCanvas(); - - // - // Call this whenever you want to process input. This - // is usually once a frame.. - // - virtual void DoThink(); - - // - // In most situations you will be rendering the canvas - // every frame. But in some situations you will only want - // to render when there have been changes. You can do this - // by checking NeedsRedraw(). - // - virtual bool NeedsRedraw(){ return m_bNeedsRedraw; } - virtual void Redraw(){ m_bNeedsRedraw = true; } - - // Internal. Do not call directly. - virtual void Render( Skin::Base* pRender ); - - // Childpanels call parent->GetCanvas() until they get to - // this top level function. - virtual Controls::Canvas* GetCanvas(){ return this; } - - virtual void SetScale( float f ); - virtual float Scale() const { return m_fScale; } - - virtual void OnBoundsChanged( Gwen::Rect oldBounds ); - - // - // Call this to delete the canvas, and its children - // in the right order. - // - virtual void Release(); - - // Delayed deletes - virtual void AddDelayedDelete( Controls::Base* pControl ); - virtual void ProcessDelayedDeletes(); - - Controls::Base* FirstTab; - Controls::Base* NextTab; - - // Input - virtual bool InputMouseMoved( int x, int y, int deltaX, int deltaY ); - virtual bool InputMouseButton( int iButton, bool bDown ); - virtual bool InputKey( int iKey, bool bDown ); - virtual bool InputCharacter( Gwen::UnicodeChar chr ); - virtual bool InputMouseWheel( int val ); - - // Background - virtual void SetBackgroundColor( const Gwen::Color& color ){ m_BackgroundColor = color; } - virtual void SetDrawBackground( bool bShouldDraw ){ m_bDrawBackground = bShouldDraw; } - - private: - - bool m_bNeedsRedraw; - bool m_bAnyDelete; - float m_fScale; - - Controls::Base::List m_DeleteList; - std::set< Controls::Base* > m_DeleteSet; - friend class Controls::Base; - void PreDelete( Controls::Base * ); - - bool m_bDrawBackground; - Gwen::Color m_BackgroundColor; - - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/CheckBox.cpp b/btgui/Gwen/Controls/CheckBox.cpp deleted file mode 100644 index ab25a832d..000000000 --- a/btgui/Gwen/Controls/CheckBox.cpp +++ /dev/null @@ -1,57 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/CheckBox.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - - -GWEN_CONTROL_CONSTRUCTOR( CheckBox ) -{ - SetSize( 13, 13 ); - - m_bChecked = true; - Toggle(); -} - - -void CheckBox::Render( Skin::Base* skin ) -{ - skin->DrawCheckBox( this, m_bChecked, IsDepressed() ); -} - -void CheckBox::OnPress() -{ - if ( IsChecked() && !AllowUncheck() ) - return; - - Toggle(); -} - -void CheckBox::OnCheckStatusChanged() -{ - if ( IsChecked() ) - { - onChecked.Call( this ); - } - else - { - onUnChecked.Call( this ); - } - - onCheckChanged.Call( this ); -} - -void CheckBox::SetChecked( bool bChecked ) -{ - if ( m_bChecked == bChecked ) return; - - m_bChecked = bChecked; - OnCheckStatusChanged(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/CheckBox.h b/btgui/Gwen/Controls/CheckBox.h deleted file mode 100644 index e4fba1ec3..000000000 --- a/btgui/Gwen/Controls/CheckBox.h +++ /dev/null @@ -1,82 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_CHECKBOX_H -#define GWEN_CONTROLS_CHECKBOX_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Symbol.h" -#include "Gwen/Controls/LabelClickable.h" - -namespace Gwen -{ - namespace Controls - { - - class GWEN_EXPORT CheckBox : public Button - { - public: - - GWEN_CONTROL( CheckBox, Button ); - - virtual void Render( Skin::Base* skin ); - virtual void OnPress(); - - virtual void SetChecked( bool Checked ); - virtual void Toggle() { SetChecked( !IsChecked() ); } - virtual bool IsChecked() { return m_bChecked; } - - Gwen::Event::Caller onChecked; - Gwen::Event::Caller onUnChecked; - Gwen::Event::Caller onCheckChanged; - - private: - - // For derived controls - virtual bool AllowUncheck(){ return true; } - - void OnCheckStatusChanged(); - - bool m_bChecked; - }; - - class GWEN_EXPORT CheckBoxWithLabel : public Base - { - public: - - GWEN_CONTROL_INLINE( CheckBoxWithLabel, Base ) - { - SetSize( 200, 19 ); - - m_Checkbox = new CheckBox( this ); - m_Checkbox->Dock( Pos::Left ); - m_Checkbox->SetMargin( Margin( 0, 3, 3, 3 ) ); - m_Checkbox->SetTabable( false ); - - m_Label = new LabelClickable( this ); - m_Label->Dock( Pos::Fill ); - m_Label->onPress.Add( m_Checkbox, &CheckBox::ReceiveEventPress ); - m_Label->SetTabable( false ); - - SetTabable( false ); - } - - virtual CheckBox* Checkbox() { return m_Checkbox; } - virtual LabelClickable* Label() { return m_Label; } - virtual bool OnKeySpace( bool bDown ) { if ( bDown ) m_Checkbox->SetChecked( !m_Checkbox->IsChecked() ); return true; } - - private: - - CheckBox* m_Checkbox; - LabelClickable* m_Label; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ColorControls.cpp b/btgui/Gwen/Controls/ColorControls.cpp deleted file mode 100644 index 532b3ed14..000000000 --- a/btgui/Gwen/Controls/ColorControls.cpp +++ /dev/null @@ -1,326 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Utility.h" -#include "Gwen/Controls/ColorControls.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -//Find a place to put these... -Color HSVToColor( float h, float s, float v ) -{ - if (h < 0.0f) h += 360.0f; - if (h > 360.0f) h -= 360.0f; - - s *= 255.0f; - v *= 255.0f; - - float r, g, b; - - if (!h && !s) - { - r = g = b = v; - } - double min,max,delta,hue; - - max = v; - delta = (max * s)/255.0; - min = max - delta; - - hue = h; - if (h > 300 || h <= 60) - { - r = (int)max; - if (h > 300) - { - g = (int)min; - hue = (hue - 360.0)/60.0; - b = (int)((hue * delta - min) * -1); - } - else - { - b = (int)min; - hue = hue / 60.0; - g = (int)(hue * delta + min); - } - } - else if (h > 60 && h < 180) - { - g = (int)max; - if (h < 120) - { - b = (int)min; - hue = (hue/60.0 - 2.0 ) * delta; - r = (int)(min - hue); - } - else - { - r = (int)min; - hue = (hue/60 - 2.0) * delta; - b = (int)(min + hue); - } - } - else - { - b = (int)max; - if (h < 240) - { - r = (int)min; - hue = (hue/60.0 - 4.0 ) * delta; - g = (int)(min - hue); - } - else - { - g = (int)min; - hue = (hue/60 - 4.0) * delta; - r = (int)(min + hue); - } - } - - return Color( r, g, b, 255); -} - -HSV RGBtoHSV( int r, int g, int b ) -{ - double min,max,delta,temp; - min = GwenUtil_Min(r,GwenUtil_Min(g,b)); - max = GwenUtil_Max(r,GwenUtil_Max(g,b)); - delta = max - min; - - HSV hsv; - hsv.v = (int)max; - if (!delta) - { - hsv.h = hsv.s = 0; - } - else - { - temp = delta/max; - hsv.s = (int)(temp*255); - - if (r == (int)max) - { - temp = (double)(g-b)/delta; - } - else - if (g == (int)max) - { - temp = 2.0 + ((double)(b-r)/delta); - } - else - { - temp = 4.0 + ((double)(r-g)/delta); - } - temp *= 60; - if (temp < 0) - { - temp+=360; - } - if (temp == 360) - { - temp = 0; - } - hsv.h = (int)temp; - } - - - hsv.s /= 255.0f; - hsv.v /= 255.0f; - - return hsv; -} - - -GWEN_CONTROL_CONSTRUCTOR( ColorLerpBox ) -{ - SetColor( Gwen::Color(255, 128, 0, 255) ); - SetSize( 128, 128 ); - SetMouseInputEnabled( true ); - m_bDepressed = false; -} - -//Find a place to put this? color member? -Gwen::Color LerpColor( Gwen::Color &toColor, Gwen::Color &fromColor, float amount ) -{ - Gwen::Color colorDelta = toColor - fromColor; - - colorDelta.r *= amount; - colorDelta.g *= amount; - colorDelta.b *= amount; - - Gwen::Color newColor = fromColor + colorDelta; - return newColor; -} - -Gwen::Color ColorLerpBox::GetSelectedColor() -{ - return GetColorAtPos( cursorPos.x, cursorPos.y ); -} - -void ColorLerpBox::SetColor( Gwen::Color color, bool onlyHue ) -{ - HSV hsv = RGBtoHSV(color.r, color.g, color.b); - m_Hue = hsv.h; - if ( !onlyHue ) - { - cursorPos.x = hsv.s * Width(); - cursorPos.y = (1 - hsv.v) * Height(); - } - - onSelectionChanged.Call( this ); -} - -void ColorLerpBox::OnMouseMoved( int x, int y, int /*deltaX*/, int /*deltaY*/ ) -{ - if ( m_bDepressed ) - { - cursorPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - //Do we have clamp? - if ( cursorPos.x < 0) - cursorPos.x = 0; - if (cursorPos.x > Width()) - cursorPos.x = Width(); - - if (cursorPos.y < 0) - cursorPos.y = 0; - if (cursorPos.y > Height()) - cursorPos.y = Height(); - - onSelectionChanged.Call( this ); - } -} - -void ColorLerpBox::OnMouseClickLeft( int x, int y, bool bDown ) -{ - m_bDepressed = bDown; - if ( bDown ) - Gwen::MouseFocus = this; - else - Gwen::MouseFocus = NULL; - - OnMouseMoved( x, y, 0, 0); -} - -Gwen::Color ColorLerpBox::GetColorAtPos( int x, int y ) -{ - float xPercent = ( (float)x / (float)Width() ); - float yPercent = 1 - ( (float)y / (float)Height() ); - - Gwen::Color result = HSVToColor( m_Hue, xPercent, yPercent ); - - result.a = 255; - - return result; -} -void ColorLerpBox::Render( Gwen::Skin::Base* skin ) -{ - //Is there any way to move this into skin? Not for now, no idea how we'll "actually" render these - BaseClass::Render( skin ); - for ( int x = 0; xGetRender()->SetDrawColor( GetColorAtPos( x, y ) ); - skin->GetRender()->DrawPixel( x, y ); - } - } - - skin->GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - skin->GetRender()->DrawLinedRect( GetRenderBounds() ); - - Gwen::Color selected = GetSelectedColor(); - if ( (selected.r + selected.g + selected.b) / 3 < 170 ) - skin->GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 255 ) ); - else - skin->GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - - Gwen::Rect testRect = Gwen::Rect( cursorPos.x -3, cursorPos.y -3, 6, 6); - - skin->GetRender()->DrawShavedCornerRect( testRect ); -} - - - - - -GWEN_CONTROL_CONSTRUCTOR( ColorSlider ) -{ - SetSize( 32, 128 ); - SetMouseInputEnabled( true ); - m_bDepressed = false; -} - -void ColorSlider::Render( Gwen::Skin::Base* skin ) -{ - //Is there any way to move this into skin? Not for now, no idea how we'll "actually" render these - int y = 0; - for ( y = 0; y < Height(); y++) - { - float yPercent = (float)y / (float)Height(); - skin->GetRender()->SetDrawColor( HSVToColor( yPercent * 360, 1, 1 ) ); - skin->GetRender()->DrawFilledRect( Gwen::Rect( 5, y, Width() - 10, 1 ) ); - } - - int drawHeight = m_iSelectedDist - 3; - - //Draw our selectors - skin->GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 )); - skin->GetRender()->DrawFilledRect( Gwen::Rect( 0, drawHeight + 2, Width(), 1)); - skin->GetRender()->DrawFilledRect( Gwen::Rect( 0, drawHeight, 5, 5) ); - skin->GetRender()->DrawFilledRect( Gwen::Rect( Width() - 5, drawHeight, 5, 5) ); - skin->GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 255 ) ); - skin->GetRender()->DrawFilledRect( Gwen::Rect( 1, drawHeight + 1, 3, 3 ) ); - skin->GetRender()->DrawFilledRect( Gwen::Rect( Width() - 4, drawHeight + 1, 3, 3 ) ); -} - -void ColorSlider::OnMouseClickLeft( int x, int y, bool bDown ) -{ - m_bDepressed = bDown; - if ( bDown) - Gwen::MouseFocus = this; - else - Gwen::MouseFocus = NULL; - - OnMouseMoved(x, y, 0, 0); -} - -Gwen::Color ColorSlider::GetColorAtHeight( int y ) -{ - float yPercent = (float)y / (float)Height(); - return HSVToColor( yPercent * 360, 1, 1); - -} -void ColorSlider::OnMouseMoved( int x, int y, int /*deltaX*/, int /*deltaY*/ ) -{ - if ( m_bDepressed ) - { - Gwen::Point cursorPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - - if (cursorPos.y < 0) - cursorPos.y = 0; - if (cursorPos.y > Height()) - cursorPos.y = Height(); - - m_iSelectedDist = cursorPos.y; - onSelectionChanged.Call( this ); - } -} - -void ColorSlider::SetColor( Gwen::Color color) -{ - HSV hsv = RGBtoHSV( color.r, color.g, color.b ); - - m_iSelectedDist = hsv.h / 360 * Height(); - - onSelectionChanged.Call( this ); -} - -Gwen::Color ColorSlider::GetSelectedColor() -{ - return GetColorAtHeight( m_iSelectedDist ); -} diff --git a/btgui/Gwen/Controls/ColorControls.h b/btgui/Gwen/Controls/ColorControls.h deleted file mode 100644 index c0a565509..000000000 --- a/btgui/Gwen/Controls/ColorControls.h +++ /dev/null @@ -1,61 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_COLORCONTROLS_H -#define GWEN_CONTROLS_COLORCONTROLS_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace Controls - { - - class GWEN_EXPORT ColorLerpBox : public Controls::Base - { - public: - GWEN_CONTROL( ColorLerpBox, Controls::Base ); - virtual void Render( Gwen::Skin::Base* skin ); - Gwen::Color GetColorAtPos(int x, int y ); - void SetColor( Gwen::Color color, bool onlyHue = true ); - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - Gwen::Color GetSelectedColor(); - - Event::Caller onSelectionChanged; - protected: - Gwen::Point cursorPos; - bool m_bDepressed; - int m_Hue; - - }; - - class GWEN_EXPORT ColorSlider : public Controls::Base - { - public: - GWEN_CONTROL( ColorSlider, Controls::Base ); - virtual void Render( Gwen::Skin::Base* skin ); - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - Gwen::Color GetSelectedColor(); - Gwen::Color GetColorAtHeight(int y ); - void SetColor( Gwen::Color color ); - - Event::Caller onSelectionChanged; - - protected: - int m_iSelectedDist; - bool m_bDepressed; - - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/ColorPicker.cpp b/btgui/Gwen/Controls/ColorPicker.cpp deleted file mode 100644 index 8ba03da72..000000000 --- a/btgui/Gwen/Controls/ColorPicker.cpp +++ /dev/null @@ -1,222 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ColorPicker.h" -#include "Gwen/Controls/HorizontalSlider.h" -#include "Gwen/Controls/GroupBox.h" -#include "Gwen/Controls/TextBox.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -GWEN_CONTROL_CONSTRUCTOR( ColorPicker ) -{ - SetMouseInputEnabled( true ); - - SetSize( 256, 150 ); - CreateControls(); - SetColor( Gwen::Color( 50, 60, 70, 255 ) ); -} - -void ColorPicker::CreateColorControl( Gwen::String name, int y ) -{ - int colorSize = 12; - - GroupBox* colorGroup = new GroupBox( this ); - colorGroup->SetPos( 10, y ); - colorGroup->SetText( name ); - colorGroup->SetSize( 160, 35 ); - colorGroup->SetName( name + "groupbox" ); - - ColorDisplay* disp = new ColorDisplay( colorGroup ); - disp->SetName(name); - disp->SetBounds( 0 , 10, colorSize, colorSize ); - - TextBoxNumeric* numeric = new TextBoxNumeric( colorGroup ); - numeric->SetName( name + "Box" ); - numeric->SetPos( 105, 7 ); - numeric->SetSize( 26, 16 ); - numeric->SetSelectAllOnFocus( true ); - numeric->onTextChanged.Add( this, &ColorPicker::NumericTyped ); - - HorizontalSlider* slider = new HorizontalSlider( colorGroup ); - slider->SetPos( colorSize + 5 , 10 ); - slider->SetRange( 0, 255 ); - slider->SetSize( 80, colorSize ); - slider->SetName( name + "Slider"); - slider->onValueChanged.Add( this, &ColorPicker::SlidersMoved ); -} - -void ColorPicker::NumericTyped( Gwen::Controls::Base* control ) -{ - if (!control) - return; - - TextBoxNumeric* box = control->DynamicCastTextBoxNumeric(); - if (!box) - return; - - if ( box->GetText() == L"") - return; - - int textValue = atoi( Utility::UnicodeToString( box->GetText()).c_str() ); - if ( textValue < 0) textValue = 0; - if ( textValue > 255) textValue = 255; - - if ( box->GetName().find("Red") != Gwen::String::npos ) - SetRed( textValue ); - - if ( box->GetName().find("Green") != Gwen::String::npos ) - SetGreen( textValue ); - - if ( box->GetName().find("Blue") != Gwen::String::npos ) - SetBlue( textValue ); - - if ( box->GetName().find("Alpha") != Gwen::String::npos ) - SetAlpha( textValue ); - - UpdateControls(); -} - -void ColorPicker::SetColor( Gwen::Color color ) -{ - m_Color = color; - UpdateControls(); -} - -void ColorPicker::CreateControls() -{ - int startY = 5; - int height = 35; - - CreateColorControl( "Red", startY ); - CreateColorControl( "Green", startY + height ); - CreateColorControl( "Blue", startY + height * 2 ); - CreateColorControl( "Alpha", startY + height * 3 ); - - GroupBox* finalGroup = new GroupBox( this ); - finalGroup->SetPos( 180, 40 ); - finalGroup->SetSize( 60, 60 ); - finalGroup->SetText( "Result" ); - finalGroup->SetName( "ResultGroupBox" ); - - - ColorDisplay* disp = new ColorDisplay( finalGroup ); - disp->SetName( "Result" ); - disp->SetBounds( 0 , 10, 32, 32 ); - disp->SetDrawCheckers( true ); - - //UpdateControls(); -} - -void ColorPicker::UpdateColorControls( Gwen::String name, Gwen::Color col, int sliderVal ) -{ - Base* el = FindChildByName( name, true ); - - ColorDisplay* disp = el ? el->DynamicCastColorDisplay() : 0; - disp->SetColor( col ); - - HorizontalSlider* slider = FindChildByName( name + "Slider", true )->DynamicCastHorizontalSlider(); - slider->SetValue( sliderVal ); - - TextBoxNumeric* box = FindChildByName( name + "Box", true )->DynamicCastTextBoxNumeric(); - box->SetText( Gwen::Utility::ToString( sliderVal ) ); -} - -void ColorPicker::UpdateControls() -{ - - //This is a little weird, but whatever for now - UpdateColorControls( "Red", Color( GetColor().r, 0, 0, 255 ), GetColor().r ); - UpdateColorControls( "Green", Color( 0, GetColor().g, 0, 255 ), GetColor().g ); - UpdateColorControls( "Blue", Color( 0, 0, GetColor().b, 255 ), GetColor().b ); - UpdateColorControls( "Alpha", Color( 255, 255, 255, GetColor().a ), GetColor().a ); - - ColorDisplay* disp = FindChildByName( "Result", true )->DynamicCastColorDisplay(); - disp->SetColor( Color( GetColor().r, GetColor().g, GetColor().b, GetColor().a ) ); - - onColorChanged.Call( this ); -} -void ColorPicker::SlidersMoved( Gwen::Controls::Base* control ) -{ - - HorizontalSlider* slider = control->DynamicCastHorizontalSlider(); - if (slider) - SetColorByName( GetColorFromName( slider->GetName() ), slider->GetValue() ); - - UpdateControls(); - //SetColor( Gwen::Color( redSlider->GetValue(), greenSlider->GetValue(), blueSlider->GetValue(), alphaSlider->GetValue() ) ); -} - -void ColorPicker::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - - SizeToChildren( false, true ); - SetSize( Width(), Height() + 5 ); - - GroupBox* groupBox = FindChildByName( "ResultGroupBox", true )->DynamicCastGroupBox(); - if ( groupBox ) - groupBox->SetPos( groupBox->X(), Height() * 0.5f - groupBox->Height() * 0.5f ); - - UpdateControls(); -} - - -void ColorPicker::Render( Skin::Base* skin ) -{ - skin->DrawBackground( this ); -} - -int ColorPicker::GetColorByName( Gwen::String colorName ) -{ - if ( colorName == "Red") - return GetColor().r; - else if ( colorName == "Green") - return GetColor().g; - else if ( colorName == "Blue") - return GetColor().b; - else if ( colorName == "Alpha") - return GetColor().a; - else - return 0; -} - -Gwen::String ColorPicker::GetColorFromName( Gwen::String name ) -{ - if ( name.find("Red") != Gwen::String::npos ) - return "Red"; - if ( name.find("Green") != Gwen::String::npos ) - return "Green"; - if ( name.find("Blue") != Gwen::String::npos ) - return "Blue"; - if ( name.find("Alpha") != Gwen::String::npos ) - return "Alpha"; - else - return ""; -} - -void ColorPicker::SetColorByName( Gwen::String colorName, int colorValue ) -{ - if ( colorName == "Red") - SetRed( colorValue ); - else if ( colorName == "Green") - SetGreen( colorValue ); - else if ( colorName == "Blue") - SetBlue( colorValue ); - else if ( colorName == "Alpha") - SetAlpha( colorValue ); -} - -void ColorPicker::SetAlphaVisible( bool visible ) -{ - GroupBox* groupBox = FindChildByName( "Alphagroupbox", true )->DynamicCastGroupBox(); - groupBox->SetHidden( !visible ); - Invalidate(); -} diff --git a/btgui/Gwen/Controls/ColorPicker.h b/btgui/Gwen/Controls/ColorPicker.h deleted file mode 100644 index a66811901..000000000 --- a/btgui/Gwen/Controls/ColorPicker.h +++ /dev/null @@ -1,89 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_COLORPICKER_H -#define GWEN_CONTROLS_COLORPICKER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT ColorDisplay : public Controls::Base - { - public: - GWEN_CONTROL_INLINE( ColorDisplay, Controls::Base ) - { - SetSize( 32, 32 ); - m_Color = Color( 255, 0, 0, 255 ); - m_DrawCheckers = true; - } - - virtual void Render( Gwen::Skin::Base* skin ) - { - skin->DrawColorDisplay( this, m_Color ); - } - - virtual void SetColor( Gwen::Color color ) { m_Color = color; } - virtual Gwen::Color GetColor() { return m_Color; } - - virtual void SetRed( int red ) { m_Color.r = red; } - virtual void SetGreen( int green ) { m_Color.g = green;} - virtual void SetBlue( int blue ) { m_Color.b = blue; } - virtual void SetAlpha( int alpha ) { m_Color.a = alpha;} - - virtual void SetDrawCheckers( bool should ) { m_DrawCheckers = should; } - - protected: - Gwen::Color m_Color; - bool m_DrawCheckers; - }; - } - namespace Controls - { - - class GWEN_EXPORT ColorPicker : public Base - { - public: - - GWEN_CONTROL( ColorPicker, Base ); - - virtual void Render( Skin::Base* skin ); - virtual void Layout( Skin::Base* skin ); - virtual void CreateControls(); - virtual void SlidersMoved( Gwen::Controls::Base* control ); - virtual void NumericTyped( Gwen::Controls::Base* control ); - virtual void UpdateControls(); - virtual void UpdateColorControls( Gwen::String name, Gwen::Color col, int sliderVal ); - virtual void CreateColorControl( Gwen::String name, int y ); - - virtual void SetColor( Gwen::Color color ); - virtual Gwen::Color GetColor() { return m_Color; } - - int GetColorByName( Gwen::String colorName ); - void SetColorByName( Gwen::String colorName, int colorValue ); - Gwen::String GetColorFromName( Gwen::String name ); - virtual void SetAlphaVisible( bool visible ); - - virtual void SetRed( int red ) { m_Color.r = red; } - virtual void SetGreen( int green ) { m_Color.g = green;} - virtual void SetBlue( int blue ) { m_Color.b = blue; } - virtual void SetAlpha( int alpha ) { m_Color.a = alpha;} - - Event::Caller onColorChanged; - - protected: - Gwen::Color m_Color; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ComboBox.cpp b/btgui/Gwen/Controls/ComboBox.cpp deleted file mode 100644 index 447a595d6..000000000 --- a/btgui/Gwen/Controls/ComboBox.cpp +++ /dev/null @@ -1,208 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ComboBox.h" -#include "Gwen/Controls/Menu.h" - - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -class GWEN_EXPORT DownArrow : public Controls::Base -{ - public: - - GWEN_CONTROL_INLINE( DownArrow, Controls::Base ) - { - SetMouseInputEnabled( true ); - SetSize( 15, 15 ); - - } - - void Render( Skin::Base* skin ) - { - skin->DrawArrowDown(this->m_Bounds); - } - - void SetComboBox( ComboBox* p ){ m_ComboBox = p; } - - protected: - - ComboBox* m_ComboBox; -}; - -GWEN_CONTROL_CONSTRUCTOR( ComboBox ) -{ - SetSize( 100, 20 ); - SetMouseInputEnabled( true ); - - m_Menu = new Menu( this ); - m_Menu->SetHidden( true ); - m_Menu->SetDisableIconMargin( true ); - m_Menu->SetTabable( false ); - - ComboBoxButton* m_OpenButton = new ComboBoxButton( this ); - - m_OpenButton->onDown.Add( this, &ComboBox::OpenButtonPressed ); - - m_OpenButton->Dock( Pos::Right ); - m_OpenButton->SetMargin( Margin( 2, 2, 2, 2 ) ); - m_OpenButton->SetWidth( 16 ); - m_OpenButton->SetTabable( false ); - - - m_SelectedItem = NULL; - - SetAlignment( Gwen::Pos::Left | Gwen::Pos::CenterV ); - SetText( L"" ); - SetMargin( Margin( 3, 0, 0, 0 ) ); - - SetTabable( true ); - -} - -MenuItem* ComboBox::AddItem( const UnicodeString& strLabel, const String& strName, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::Function fn ) -{ - MenuItem* pItem = m_Menu->AddItem( strLabel, L"", pHandler, fn ); - pItem->SetName( strName ); - - pItem->onMenuItemSelected.Add( this, &ComboBox::OnItemSelected ); - - //Default - if ( m_SelectedItem == NULL ) - OnItemSelected( pItem ); - - return pItem; -} - -void ComboBox::Render( Skin::Base* skin ) -{ - skin->DrawComboBox( this ); -} - - -void ComboBox::OpenButtonPressed( Controls::Base* /*pControl*/ ) -{ - OnPress(); -} - -void ComboBox::OnPress() -{ - bool bWasMenuHidden = m_Menu->Hidden(); - - GetCanvas()->CloseMenus(); - - if ( bWasMenuHidden ) - { - OpenList(); - } - else - { - m_Menu->SetHidden( true ); - } -} - -void ComboBox::ClearItems() -{ - if ( m_Menu ) - { - m_Menu->ClearItems(); - } -} -void ComboBox::OnItemSelected( Controls::Base* pControl ) -{ - //Convert selected to a menu item - MenuItem* pItem = pControl->DynamicCastMenuItem(); - if ( !pItem ) return; - - m_SelectedItem = pItem; - SetText( m_SelectedItem->GetText() ); - m_Menu->SetHidden( true ); - - onSelection.Call( this ); - - Focus(); - Invalidate(); -} - -void ComboBox::OnLostKeyboardFocus() -{ - SetTextColor( Color( 0, 0, 0, 255 ) ); -} - - -void ComboBox::OnKeyboardFocus() -{ - //Until we add the blue highlighting again - SetTextColor( Color( 0, 0, 0, 255 ) ); - //m_SelectedText->SetTextColor( Color( 255, 255, 255, 255 ) ); -} - -Gwen::Controls::Label* ComboBox::GetSelectedItem() -{ - return m_SelectedItem; -} - -bool ComboBox::IsMenuOpen() -{ - return m_Menu && !m_Menu->Hidden(); -} - -void ComboBox::OpenList() -{ - if ( !m_Menu ) return; - - m_Menu->SetParent( GetCanvas() ); - m_Menu->SetHidden( false ); - m_Menu->BringToFront(); - - Gwen::Point p = LocalPosToCanvas( Gwen::Point( 0, 0 ) ); - - m_Menu->SetBounds( Gwen::Rect ( p.x, p.y + Height(), Width(), m_Menu->Height()) ); -} - -void ComboBox::CloseList() -{ - -} - - -bool ComboBox::OnKeyUp( bool bDown ) -{ - if ( bDown ) - { - Base::List & children = m_Menu->GetChildren(); - Base::List::reverse_iterator it = std::find( children.rbegin(), children.rend(), m_SelectedItem ); - - if ( it != children.rend() && ( ++it != children.rend() ) ) - { - Base* pUpElement = *it; - OnItemSelected( pUpElement ); - } - } - return true; -} -bool ComboBox::OnKeyDown( bool bDown ) -{ - if ( bDown ) - { - Base::List & children = m_Menu->GetChildren(); - Base::List::iterator it = std::find( children.begin(), children.end(), m_SelectedItem ); - - if ( it != children.end() && ( ++it != children.end() ) ) - { - Base* pDownElement = *it; - OnItemSelected( pDownElement ); - } - } - return true; -} - -void ComboBox::RenderFocus( Gwen::Skin::Base* /*skin*/ ) -{ -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ComboBox.h b/btgui/Gwen/Controls/ComboBox.h deleted file mode 100644 index 88ea969c6..000000000 --- a/btgui/Gwen/Controls/ComboBox.h +++ /dev/null @@ -1,87 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_COMBOBOX_H -#define GWEN_CONTROLS_COMBOBOX_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/TextBox.h" -#include "Gwen/Controls/Menu.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT ComboBoxButton : public Button - { - GWEN_CONTROL_INLINE( ComboBoxButton, Button ){} - - virtual void Render( Skin::Base* skin ) - { - skin->DrawComboBoxButton( this, m_bDepressed ); - } - }; - - class GWEN_EXPORT ComboBox : public Button - { - public: - - GWEN_CONTROL( ComboBox, Button ); - - virtual void Render( Skin::Base* skin ); - - virtual Gwen::Controls::Label* GetSelectedItem(); - - virtual void OnPress(); - void OpenButtonPressed( Controls::Base* /*pControl*/ ); - - virtual void OnItemSelected( Controls::Base* pControl ); - virtual void OpenList(); - virtual void CloseList(); - - virtual Controls::Base* GetControlAt( int x, int y ) - { - if ( x < 0 || y < 0 || x >= Width() || y >= Height() ) - return NULL; - - return this; - } - virtual bool IsMenuComponent() - { - return true; - } - - virtual void ClearItems(); - - virtual MenuItem* AddItem( const UnicodeString& strLabel, const String& strName = "", Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::Function fn = NULL ); - virtual bool OnKeyUp( bool bDown ); - virtual bool OnKeyDown( bool bDown ); - - virtual void RenderFocus( Gwen::Skin::Base* skin ); - virtual void OnLostKeyboardFocus(); - virtual void OnKeyboardFocus(); - - virtual bool IsMenuOpen(); - - Gwen::Event::Caller onSelection; - - protected: - - Menu* m_Menu; - MenuItem* m_SelectedItem; - - Controls::Base* m_Button; - - }; - - } -} -#endif diff --git a/btgui/Gwen/Controls/CrossSplitter.cpp b/btgui/Gwen/Controls/CrossSplitter.cpp deleted file mode 100644 index f80c7255d..000000000 --- a/btgui/Gwen/Controls/CrossSplitter.cpp +++ /dev/null @@ -1,183 +0,0 @@ - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/CrossSplitter.h" -#include "Gwen/Controls/Button.h" - -using namespace Gwen; -using namespace Controls; - -GWEN_CONTROL_CONSTRUCTOR( CrossSplitter ) -{ - m_VSplitter = new SplitterBar( this ); - m_VSplitter->SetPos( 0, 128 ); - m_VSplitter->onDragged.Add( this, &CrossSplitter::OnVerticalMoved ); - m_VSplitter->SetCursor( Gwen::CursorType::SizeNS ); - - m_HSplitter = new SplitterBar( this ); - m_HSplitter->SetPos( 128, 0 ); - m_HSplitter->onDragged.Add( this, &CrossSplitter::OnHorizontalMoved ); - m_HSplitter->SetCursor( Gwen::CursorType::SizeWE ); - - m_CSplitter = new SplitterBar( this ); - m_CSplitter->SetPos( 128, 128 ); - m_CSplitter->onDragged.Add( this, &CrossSplitter::OnCenterMoved ); - m_CSplitter->SetCursor( Gwen::CursorType::SizeAll ); - - m_fHVal = 0.5f; - m_fVVal = 0.5f; - - SetPanel( 0, NULL ); - SetPanel( 1, NULL ); - SetPanel( 2, NULL ); - SetPanel( 3, NULL ); - - SetSplitterSize( 5 ); - SetSplittersVisible( false ); - - m_iZoomedSection = -1; -} - -void CrossSplitter::UpdateVSplitter() -{ - m_VSplitter->MoveTo( m_VSplitter->X(), ( Height() - m_VSplitter->Height() ) * ( m_fVVal )); -} -void CrossSplitter::UpdateHSplitter() -{ - m_HSplitter->MoveTo( ( Width() - m_HSplitter->Width() ) * ( m_fHVal ), m_HSplitter->Y() ); -} - -void CrossSplitter::OnCenterMoved( Controls::Base * /*control*/ ) -{ - //Move the other two bars into position - CalculateValueCenter(); - Invalidate(); -} - -void CrossSplitter::UpdateCSplitter() -{ - m_CSplitter->MoveTo( ( Width() - m_CSplitter->Width() ) * ( m_fHVal ), ( Height() - m_CSplitter->Height() ) * ( m_fVVal )); -} - -void CrossSplitter::OnHorizontalMoved( Controls::Base * /*control*/ ) -{ - m_fHVal = CalculateValueHorizontal(); - Invalidate(); -} -void CrossSplitter::OnVerticalMoved( Controls::Base * /*control*/ ) -{ - m_fVVal = CalculateValueVertical(); - Invalidate(); -} - -void CrossSplitter::CalculateValueCenter() -{ - m_fHVal = (float)m_CSplitter->X() / (float)( Width() - m_CSplitter->Width() ); - m_fVVal = (float)m_CSplitter->Y() / (float)( Height() - m_CSplitter->Height() ); -} - -float CrossSplitter::CalculateValueHorizontal() -{ - return (float)m_HSplitter->X() / (float)( Width() - m_HSplitter->Width() ); -} - -float CrossSplitter::CalculateValueVertical() -{ - return (float)m_VSplitter->Y() / (float)( Height() - m_VSplitter->Height() ); -} - -void CrossSplitter::Layout( Skin::Base* /*skin*/ ) -{ - m_VSplitter->SetSize( Width(), m_fBarSize ); - m_HSplitter->SetSize( m_fBarSize, Height() ); - m_CSplitter->SetSize( m_fBarSize, m_fBarSize ); - - UpdateVSplitter(); - UpdateHSplitter(); - UpdateCSplitter(); - - if ( m_iZoomedSection == -1 ) - { - if ( m_Sections[0] ) - m_Sections[0]->SetBounds( 0, 0, m_HSplitter->X(), m_VSplitter->Y() ); - - if ( m_Sections[1] ) - m_Sections[1]->SetBounds( m_HSplitter->X() + m_fBarSize, 0, Width() - ( m_HSplitter->X() + m_fBarSize ), m_VSplitter->Y() ); - - if ( m_Sections[2] ) - m_Sections[2]->SetBounds( 0, m_VSplitter->Y() + m_fBarSize, m_HSplitter->X(), Height() - ( m_VSplitter->Y() + m_fBarSize ) ); - - if ( m_Sections[3] ) - m_Sections[3]->SetBounds( m_HSplitter->X() + m_fBarSize, m_VSplitter->Y() + m_fBarSize, Width() - ( m_HSplitter->X() + m_fBarSize ), Height() - ( m_VSplitter->Y() + m_fBarSize ) ); - } - else - { - //This should probably use Fill docking instead - m_Sections[(int)m_iZoomedSection]->SetBounds( 0, 0, Width(), Height() ); - } -} - -void CrossSplitter::SetPanel( int index, Controls::Base* pPanel) -{ - Debug::AssertCheck( index >= 0 && index <= 3, "CrossSplitter::SetPanel out of range" ); - - m_Sections[index] = pPanel; - - if ( pPanel ) - { - pPanel->Dock( Pos::None ); - pPanel->SetParent( this ); - } - - Invalidate(); -} - -Controls::Base* CrossSplitter::GetPanel( int i ) -{ - return m_Sections[i]; -} - - -void CrossSplitter::ZoomChanged() -{ - onZoomChange.Call( this ); - if ( m_iZoomedSection == -1 ) - { - onUnZoomed.Call( this ); - } - else - { - onZoomed.Call( this ); - } -} - -void CrossSplitter::Zoom( int section ) -{ - UnZoom(); - - if ( m_Sections[section] ) - { - for (int i = 0; i < 4; i++) - { - if ( i != section && m_Sections[i] ) - m_Sections[i]->SetHidden( true ); - } - m_iZoomedSection = section; - - Invalidate(); - } - ZoomChanged(); -} - -void CrossSplitter::UnZoom() -{ - m_iZoomedSection = -1; - - for ( int i = 0; i < 4; i++ ) - { - if ( m_Sections[i] ) - m_Sections[i]->SetHidden( false ); - } - - Invalidate(); - ZoomChanged(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/CrossSplitter.h b/btgui/Gwen/Controls/CrossSplitter.h deleted file mode 100644 index f5840e5cf..000000000 --- a/btgui/Gwen/Controls/CrossSplitter.h +++ /dev/null @@ -1,63 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_CROSSSPLITTER_H -#define GWEN_CONTROLS_CROSSSPLITTER_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/SplitterBar.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT CrossSplitter : public Controls::Base - { - public: - - GWEN_CONTROL( CrossSplitter, Controls::Base ); - - void Layout( Skin::Base* skin ); - - virtual float CalculateValueVertical(); - virtual float CalculateValueHorizontal(); - virtual void CalculateValueCenter(); - virtual void UpdateHSplitter(); - virtual void UpdateVSplitter(); - virtual void UpdateCSplitter(); - virtual void OnVerticalMoved( Controls::Base * control ); - virtual void OnHorizontalMoved( Controls::Base * control ); - virtual void OnCenterMoved( Controls::Base * control ); - - virtual void SetPanel( int i, Controls::Base* pPanel ); - virtual Controls::Base* GetPanel( int i ); - - virtual bool IsZoomed(){ return m_iZoomedSection != -1; } - virtual void Zoom( int section ); - virtual void UnZoom(); - virtual void ZoomChanged(); - virtual void CenterPanels() { m_fHVal = 0.5f; m_fVVal = 0.5f; Invalidate(); } - - virtual void SetSplittersVisible( bool b ){ m_VSplitter->SetShouldDrawBackground( b ); m_HSplitter->SetShouldDrawBackground( b ); m_CSplitter->SetShouldDrawBackground( b ); } - virtual void SetSplitterSize( int size ) { m_fBarSize = size; } - - private: - - SplitterBar* m_VSplitter; - SplitterBar* m_HSplitter; - SplitterBar* m_CSplitter; - - Controls::Base* m_Sections[4]; - - float m_fHVal; - float m_fVVal; - int m_fBarSize; - - char m_iZoomedSection; - - Gwen::Event::Caller onZoomed; - Gwen::Event::Caller onUnZoomed; - Gwen::Event::Caller onZoomChange; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Dialog/FileOpen.cpp b/btgui/Gwen/Controls/Dialog/FileOpen.cpp deleted file mode 100644 index 0db499854..000000000 --- a/btgui/Gwen/Controls/Dialog/FileOpen.cpp +++ /dev/null @@ -1,24 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#include "Gwen/Gwen.h" -#include "Gwen/Platform.h" -#include "Gwen/Controls/Dialogs/FileOpen.h" - -using namespace Gwen; -using namespace Gwen::Dialogs; - -void Gwen::Dialogs::FileOpenEx( bool bUseSystem, const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::FunctionStr fnCallback ) -{ - if ( bUseSystem && Gwen::Platform::FileOpen( Name, StartPath, Extension, pHandler, fnCallback ) ) - { - return; - } - - // - // TODO: SHOW GWEN FILE SELECTION DIALOG - // -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Dialog/FileSave.cpp b/btgui/Gwen/Controls/Dialog/FileSave.cpp deleted file mode 100644 index 1b9aba284..000000000 --- a/btgui/Gwen/Controls/Dialog/FileSave.cpp +++ /dev/null @@ -1,24 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#include "Gwen/Gwen.h" -#include "Gwen/Platform.h" -#include "Gwen/Controls/Dialogs/FileSave.h" - -using namespace Gwen; -using namespace Gwen::Dialogs; - -void Gwen::Dialogs::FileSaveEx( bool bUseSystem, const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::FunctionStr fnCallback ) -{ - if ( bUseSystem && Gwen::Platform::FileSave( Name, StartPath, Extension, pHandler, fnCallback ) ) - { - return; - } - - // - // TODO: SHOW GWEN FILE SELECTION DIALOG - // -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Dialog/Query.cpp b/btgui/Gwen/Controls/Dialog/Query.cpp deleted file mode 100644 index 9e339301f..000000000 --- a/btgui/Gwen/Controls/Dialog/Query.cpp +++ /dev/null @@ -1,12 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Dialogs/Query.h" - -using namespace Gwen; -using namespace Gwen::Controls; - diff --git a/btgui/Gwen/Controls/Dialogs/FileOpen.h b/btgui/Gwen/Controls/Dialogs/FileOpen.h deleted file mode 100644 index c8635d532..000000000 --- a/btgui/Gwen/Controls/Dialogs/FileOpen.h +++ /dev/null @@ -1,35 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_DIALOGS_FILEOPEN_H -#define GWEN_CONTROLS_DIALOGS_FILEOPEN_H - -#include "Gwen/Gwen.h" - -namespace Gwen -{ - namespace Dialogs - { - // Usage: - // - // Gwen::Dialogs::FileOpen( true, "Open Map", "C:\my\folder\", "My Map Format|*.bmf", this, &MyClass::OpenFilename ); - // - - // - // The REAL function. - // If bUseSystem is used, it may use the system's modal dialog - which - // will steal focus and pause the rest of GWEN until it's continued. - // - void GWEN_EXPORT FileOpenEx( bool bUseSystem, const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::FunctionStr fnCallback = NULL ); - - // - // Templated function simply to avoid having to manually cast the callback function. - // - template< typename A> - void FileOpen( bool bUseSystem, const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler = NULL, A fnCallback = NULL ) - { - FileOpenEx( bUseSystem, Name, StartPath, Extension, pHandler, (Gwen::Event::Handler::FunctionStr)fnCallback ); - } - - - } -} -#endif diff --git a/btgui/Gwen/Controls/Dialogs/FileSave.h b/btgui/Gwen/Controls/Dialogs/FileSave.h deleted file mode 100644 index 922036bf3..000000000 --- a/btgui/Gwen/Controls/Dialogs/FileSave.h +++ /dev/null @@ -1,40 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_DIALOGS_FILESAVE_H -#define GWEN_CONTROLS_DIALOGS_FILESAVE_H - -#include "Gwen/Gwen.h" - -namespace Gwen -{ - namespace Dialogs - { - // Usage: - // - // Gwen::Dialogs::FileOpen( true, "Open Map", "C:\my\folder\", "My Map Format|*.bmf", this, &MyClass::OpenFilename ); - // - - // - // Callback function, for success - // - typedef void (Event::Handler::*FileSaveSuccessCallback)( const String& filename ); - - // - // The REAL function. - // If bUseSystem is used, it may use the system's modal dialog - which - // will steal focus and pause the rest of GWEN until it's continued. - // - void GWEN_EXPORT FileSaveEx( bool bUseSystem, const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::FunctionStr fnCallback = NULL ); - - // - // Templated function simply to avoid having to manually cast the callback function. - // - template< typename A> - void FileSave( bool bUseSystem, const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler = NULL, A fnCallback = NULL ) - { - FileSaveEx( bUseSystem, Name, StartPath, Extension, pHandler, (Gwen::Event::Handler::FunctionStr)fnCallback ); - } - - - } -} -#endif diff --git a/btgui/Gwen/Controls/Dialogs/Query.h b/btgui/Gwen/Controls/Dialogs/Query.h deleted file mode 100644 index 007750791..000000000 --- a/btgui/Gwen/Controls/Dialogs/Query.h +++ /dev/null @@ -1,14 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_DIALOGS_QUERY_H -#define GWEN_CONTROLS_DIALOGS_QUERY_H - -#include "Gwen/Gwen.h" - -namespace Gwen -{ - namespace Dialogs - { - //TODO. YesNo, Ok etc - } -} -#endif diff --git a/btgui/Gwen/Controls/DockBase.cpp b/btgui/Gwen/Controls/DockBase.cpp deleted file mode 100644 index 0774b1db2..000000000 --- a/btgui/Gwen/Controls/DockBase.cpp +++ /dev/null @@ -1,343 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/DockBase.h" -#include "Gwen/Controls/DockedTabControl.h" -#include "Gwen/Controls/Highlight.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Controls/Resizer.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( DockBase ) -{ - SetPadding( Padding( 1, 1, 1, 1 ) ); - SetSize( 200, 200 ); - - m_DockedTabControl = NULL; - m_Left = NULL; - m_Right = NULL; - m_Top = NULL; - m_Bottom = NULL; - - m_bDrawHover = false; -} - -TabControl* DockBase::GetTabControl() -{ - return m_DockedTabControl; -} - -void DockBase::SetupChildDock( int iPos ) -{ - if ( !m_DockedTabControl ) - { - m_DockedTabControl = new DockedTabControl( this ); - m_DockedTabControl->onLoseTab.Add( this, &DockBase::OnTabRemoved ); - m_DockedTabControl->SetTabStripPosition( Pos::Bottom ); - m_DockedTabControl->SetShowTitlebar( true ); - } - - Dock( iPos ); - - int iSizeDirection = Pos::Left; - if ( iPos == Pos::Left ) iSizeDirection = Pos::Right; - if ( iPos == Pos::Top ) iSizeDirection = Pos::Bottom; - if ( iPos == Pos::Bottom ) iSizeDirection = Pos::Top; - - ControlsInternal::Resizer* sizer = new ControlsInternal::Resizer( this ); - sizer->Dock( iSizeDirection ); - sizer->SetResizeDir( iSizeDirection ); - sizer->SetSize( 2, 2 ); - sizer->SetTarget( this ); -} - -void DockBase::Render( Skin::Base* /*skin*/ ) -{ - //Gwen::Render->SetDrawColor( Colors::Black ); - //Gwen::Render->DrawLinedRect( GetRenderBounds() ); -} - -DockBase** DockBase::GetChildDockPtr( int iPos ) -{ - if ( iPos == Pos::Left ) return &m_Left; - if ( iPos == Pos::Right ) return &m_Right; - if ( iPos == Pos::Top ) return &m_Top; - if ( iPos == Pos::Bottom ) return &m_Bottom; - - return NULL; -} - -DockBase* DockBase::GetChildDock( int iPos ) -{ - DockBase** pDock = GetChildDockPtr( iPos ); - - if ( !(*pDock) ) - { - (*pDock) = new DockBase( this ); - (*pDock)->SetupChildDock( iPos ); - } - else - { - (*pDock)->SetHidden( false ); - } - - return *pDock; -} - -int DockBase::GetDroppedTabDirection( int x, int y ) -{ - int w = Width(); - int h = Height(); - - float top = (float)y / (float) h; - float left = (float)x / (float) w; - float right = (float)(w - x) /(float) w; - float bottom = (float)(h - y) / (float) h; - - float minimum = GwenUtil_Min( GwenUtil_Min( GwenUtil_Min( top, left ), right ), bottom ); - m_bDropFar = ( minimum < 0.2f ); - if ( minimum > 0.3 ) return Pos::Fill; - - if ( top == minimum && (!m_Top || m_Top->Hidden()) ) return Pos::Top; - if ( left == minimum && (!m_Left || m_Left->Hidden()) ) return Pos::Left; - if ( right == minimum && (!m_Right || m_Right->Hidden()) ) return Pos::Right; - if ( bottom == minimum && (!m_Bottom || m_Bottom->Hidden()) ) return Pos::Bottom; - - return Pos::Fill; -} - -bool DockBase::DragAndDrop_CanAcceptPackage( Gwen::DragAndDrop::Package* pPackage ) -{ - // A TAB button dropped - if ( pPackage->name == "TabButtonMove" ) - return true; - - // a TAB window dropped - if ( pPackage->name == "TabWindowMove" ) - return true; - - return false; -} - -void AddTabToDock( TabButton* pTabButton, DockedTabControl* pControl ) -{ - pControl->AddPage( pTabButton ); -} - -bool DockBase::DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* pPackage, int x, int y ) -{ - Gwen::Point pPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - int dir = GetDroppedTabDirection( pPos.x, pPos.y ); - - DockedTabControl* pAddTo = m_DockedTabControl; - if ( dir == Pos::Fill && pAddTo == NULL ) return false; - - if ( dir != Pos::Fill ) - { - DockBase* pDock = GetChildDock( dir ); - pAddTo = pDock->m_DockedTabControl; - - if ( !m_bDropFar ) pDock->BringToFront(); - else pDock->SendToBack(); - } - - if ( pPackage->name == "TabButtonMove" ) - { - TabButton* pTabButton = DragAndDrop::SourceControl->DynamicCastTabButton(); - if ( !pTabButton ) return false; - - AddTabToDock( pTabButton, pAddTo ); - } - - if ( pPackage->name == "TabWindowMove" ) - { - DockedTabControl* pTabControl = DragAndDrop::SourceControl->DynamicCastDockedTabControl(); - if ( !pTabControl ) return false; - if ( pTabControl == pAddTo ) return false; - - pTabControl->MoveTabsTo( pAddTo ); - } - - Invalidate(); - - return true; -} - -bool DockBase::IsEmpty() -{ - if ( m_DockedTabControl && m_DockedTabControl->TabCount() > 0 ) return false; - - if ( m_Left && !m_Left->IsEmpty() ) return false; - if ( m_Right && !m_Right->IsEmpty() ) return false; - if ( m_Top && !m_Top->IsEmpty() ) return false; - if ( m_Bottom && !m_Bottom->IsEmpty() ) return false; - - return true; -} - -void DockBase::OnTabRemoved( Gwen::Controls::Base* /*pControl*/ ) -{ - DoRedundancyCheck(); - DoConsolidateCheck(); -} - -void DockBase::DoRedundancyCheck() -{ - if ( !IsEmpty() ) return; - - DockBase* pDockParent = GetParent()->DynamicCastDockBase(); - if ( !pDockParent ) return; - - pDockParent->OnRedundantChildDock( this ); -} - -void DockBase::DoConsolidateCheck() -{ - if ( IsEmpty() ) return; - if ( !m_DockedTabControl ) return; - if ( m_DockedTabControl->TabCount() > 0 ) return; - - if ( m_Bottom && !m_Bottom->IsEmpty() ) - { - m_Bottom->m_DockedTabControl->MoveTabsTo( m_DockedTabControl ); - return; - } - - if ( m_Top && !m_Top->IsEmpty() ) - { - m_Top->m_DockedTabControl->MoveTabsTo( m_DockedTabControl ); - return; - } - - if ( m_Left && !m_Left->IsEmpty() ) - { - m_Left->m_DockedTabControl->MoveTabsTo( m_DockedTabControl ); - return; - } - - if ( m_Right && !m_Right->IsEmpty() ) - { - m_Right->m_DockedTabControl->MoveTabsTo( m_DockedTabControl ); - return; - } -} - -void DockBase::OnRedundantChildDock( DockBase* pDockBase ) -{ - pDockBase->SetHidden( true ); - DoRedundancyCheck(); - DoConsolidateCheck(); -} - -void DockBase::DragAndDrop_HoverEnter( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ ) -{ - m_bDrawHover = true; -} - -void DockBase::DragAndDrop_HoverLeave( Gwen::DragAndDrop::Package* /*pPackage*/ ) -{ - m_bDrawHover = false; -} - -void DockBase::DragAndDrop_Hover( Gwen::DragAndDrop::Package* /*pPackage*/, int x, int y ) -{ - Gwen::Point pPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - int dir = GetDroppedTabDirection( pPos.x, pPos.y ); - - if ( dir == Pos::Fill ) - { - if ( !m_DockedTabControl ) - { - m_HoverRect = Gwen::Rect( 0, 0, 0, 0 ); - return; - } - - m_HoverRect = GetInnerBounds(); - return; - } - - m_HoverRect = GetRenderBounds(); - - int HelpBarWidth = 0; - - if ( dir == Pos::Left ) - { - HelpBarWidth = m_HoverRect.w * 0.25f; - m_HoverRect.w = HelpBarWidth; - } - - if ( dir == Pos::Right ) - { - HelpBarWidth = m_HoverRect.w * 0.25f; - m_HoverRect.x = m_HoverRect.w - HelpBarWidth; - m_HoverRect.w = HelpBarWidth; - } - - if ( dir == Pos::Top ) - { - HelpBarWidth = m_HoverRect.h * 0.25f; - m_HoverRect.h = HelpBarWidth; - } - - if ( dir == Pos::Bottom ) - { - HelpBarWidth = m_HoverRect.h * 0.25f; - m_HoverRect.y = m_HoverRect.h - HelpBarWidth; - m_HoverRect.h = HelpBarWidth; - } - - if ( (dir == Pos::Top || dir == Pos::Bottom ) && !m_bDropFar ) - { - if ( m_Left && m_Left->Visible() ) - { - m_HoverRect.x += m_Left->Width(); - m_HoverRect.w -= m_Left->Width(); - } - - if ( m_Right && m_Right->Visible() ) - { - m_HoverRect.w -= m_Right->Width(); - } - } - - if ( (dir == Pos::Left || dir == Pos::Right ) && !m_bDropFar ) - { - if ( m_Top && m_Top->Visible() ) - { - m_HoverRect.y += m_Top->Height(); - m_HoverRect.h -= m_Top->Height(); - } - - if ( m_Bottom && m_Bottom->Visible() ) - { - m_HoverRect.h -= m_Bottom->Height(); - } - } -} - -void DockBase::RenderOver( Skin::Base* skin ) -{ - if ( !m_bDrawHover ) return; - - Gwen::Renderer::Base* render = skin->GetRender(); - - render->SetDrawColor( Gwen::Color( 255, 100, 255, 20 ) ); - render->DrawFilledRect( GetRenderBounds() ); - - if ( m_HoverRect.w == 0 ) return; - - render->SetDrawColor( Gwen::Color( 255, 100, 255, 100 ) ); - render->DrawFilledRect( m_HoverRect ); - - render->SetDrawColor( Gwen::Color( 255, 100, 255, 200 ) ); - render->DrawLinedRect( m_HoverRect ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/DockBase.h b/btgui/Gwen/Controls/DockBase.h deleted file mode 100644 index 0c07c9cd0..000000000 --- a/btgui/Gwen/Controls/DockBase.h +++ /dev/null @@ -1,77 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_DOCKBASE_H -#define GWEN_CONTROLS_DOCKBASE_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" - -namespace Gwen -{ - namespace Controls - { - class DockedTabControl; - class TabControl; - - class GWEN_EXPORT DockBase : public Base - { - public: - - GWEN_CONTROL( DockBase, Base ); - - virtual void Render( Skin::Base* skin ); - virtual void RenderOver( Skin::Base* skin ); - virtual bool IsEmpty(); - - virtual TabControl* GetTabControl(); - - virtual DockBase* GetRight(){ return GetChildDock( Pos::Right ); } - virtual DockBase* GetLeft(){ return GetChildDock( Pos::Left ); } - virtual DockBase* GetTop(){ return GetChildDock( Pos::Top ); } - virtual DockBase* GetBottom(){ return GetChildDock( Pos::Bottom ); } - - // No action on space (default button action is to press) - virtual bool OnKeySpace( bool /*bDown*/ ){ return false; } - - private: - - // Drag n Drop - virtual bool DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual bool DragAndDrop_CanAcceptPackage( Gwen::DragAndDrop::Package* pPackage ); - virtual void DragAndDrop_HoverEnter( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual void DragAndDrop_HoverLeave( Gwen::DragAndDrop::Package* pPackage ); - virtual void DragAndDrop_Hover( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - - virtual void SetupChildDock( int iPos ); - - virtual void DoRedundancyCheck(); - virtual void DoConsolidateCheck(); - virtual void OnRedundantChildDock( DockBase* pDockBase ); - - virtual int GetDroppedTabDirection( int x, int y ); - virtual void OnTabRemoved( Gwen::Controls::Base* pControl ); - - DockBase* GetChildDock( int iPos ); - DockBase** GetChildDockPtr( int iPos ); - - DockBase* m_Left; - DockBase* m_Right; - DockBase* m_Top; - DockBase* m_Bottom; - - // Only CHILD dockpanels have a tabcontrol. - DockedTabControl* m_DockedTabControl; - - bool m_bDrawHover; - bool m_bDropFar; - Gwen::Rect m_HoverRect; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/DockedTabControl.cpp b/btgui/Gwen/Controls/DockedTabControl.cpp deleted file mode 100644 index 45f96417f..000000000 --- a/btgui/Gwen/Controls/DockedTabControl.cpp +++ /dev/null @@ -1,92 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/DockedTabControl.h" -#include "Gwen/Controls/Highlight.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Controls/WindowControl.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( DockedTabControl ) -{ - m_WindowControl = NULL; - - Dock( Pos::Fill ); - - m_pTitleBar = new TabTitleBar( this ); - m_pTitleBar->Dock( Pos::Top ); - m_pTitleBar->SetHidden( true ); - -} - -void DockedTabControl::Layout( Skin::Base* skin ) -{ - GetTabStrip()->SetHidden( TabCount() <= 1 ); - UpdateTitleBar(); - BaseClass::Layout( skin ); -} - -void DockedTabControl::UpdateTitleBar() -{ - if ( !GetCurrentButton() ) return; - - m_pTitleBar->UpdateFromTab( GetCurrentButton() ); -} - -void DockedTabControl::DragAndDrop_StartDragging( Gwen::DragAndDrop::Package* pPackage, int x, int y ) -{ - BaseClass::DragAndDrop_StartDragging( pPackage, x, y ); - - SetHidden( true ); - // This hiding our parent thing is kind of lousy. - GetParent()->SetHidden( true ); -} - -void DockedTabControl::DragAndDrop_EndDragging( bool bSuccess, int /*x*/, int /*y*/ ) -{ - SetHidden( false ); - - if ( !bSuccess ) - { - GetParent()->SetHidden( false ); - } - -/* - if ( !bSuccess ) - { - // Create our window control - if ( !m_WindowControl ) - { - m_WindowControl = new WindowControl( GetCanvas() ); - m_WindowControl->SetBounds( x, y, Width(), Height() ); - } - - m_WindowControl->SetPosition( x, y ); - SetParent( m_WindowControl ); - SetPosition( 0, 0 ); - Dock( Pos::Fill ); - } - */ -} - -void DockedTabControl::MoveTabsTo( DockedTabControl* pTarget ) -{ - Base::List Children = GetTabStrip()->Children; - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - TabButton* pButton = (*iter)->DynamicCastTabButton(); - if ( !pButton ) continue; - - pTarget->AddPage( pButton ); - } - - Invalidate(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/DockedTabControl.h b/btgui/Gwen/Controls/DockedTabControl.h deleted file mode 100644 index a42076684..000000000 --- a/btgui/Gwen/Controls/DockedTabControl.h +++ /dev/null @@ -1,42 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_DOCKEDTABCONTROL_H -#define GWEN_CONTROLS_DOCKEDTABCONTROL_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/TabControl.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT DockedTabControl : public TabControl - { - public: - - GWEN_CONTROL( DockedTabControl, TabControl ); - - void SetShowTitlebar( bool bShow ){ m_pTitleBar->SetHidden( !bShow ); } - - void Layout( Skin::Base* skin ); - void UpdateTitleBar(); - - virtual void DragAndDrop_StartDragging( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual void DragAndDrop_EndDragging( bool bSuccess, int x, int y ); - - void MoveTabsTo( DockedTabControl* pTarget ); - - private: - - TabTitleBar* m_pTitleBar; - Base* m_WindowControl; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Dragger.cpp b/btgui/Gwen/Controls/Dragger.cpp deleted file mode 100644 index 2b89e344c..000000000 --- a/btgui/Gwen/Controls/Dragger.cpp +++ /dev/null @@ -1,59 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/Dragger.h" - -using namespace Gwen; -using namespace Gwen::ControlsInternal; - - - -GWEN_CONTROL_CONSTRUCTOR( Dragger ) -{ - m_pTarget = NULL; - SetMouseInputEnabled( true ); - m_bDepressed = false; -} - -void Dragger::OnMouseClickLeft( int x, int y, bool bDown ) -{ - if ( !m_pTarget ) return; - - if ( bDown ) - { - m_bDepressed = true; - m_HoldPos = m_pTarget->CanvasPosToLocal( Gwen::Point( x, y ) ); - Gwen::MouseFocus = this; - } - else - { - m_bDepressed = false; - - Gwen::MouseFocus = NULL; - } -} - -void Dragger::OnMouseMoved( int x, int y, int /*deltaX*/, int /*deltaY*/ ) -{ - if ( !m_pTarget ) return; - if ( !m_bDepressed ) return; - - Gwen::Point p = Gwen::Point( x - m_HoldPos.x, y - m_HoldPos.y ); - - // Translate to parent - if ( m_pTarget->GetParent() ) - p = m_pTarget->GetParent()->CanvasPosToLocal( p ); - - //m_pTarget->SetPosition( p.x, p.y ); - m_pTarget->MoveTo( p.x, p.y ); - onDragged.Call( this ); -} - -void Dragger::Render( Skin::Base* /*skin*/ ) -{ - //skin->DrawButton(this,false,false); -} diff --git a/btgui/Gwen/Controls/Dragger.h b/btgui/Gwen/Controls/Dragger.h deleted file mode 100644 index 165d96c0b..000000000 --- a/btgui/Gwen/Controls/Dragger.h +++ /dev/null @@ -1,43 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_DRAGGER_H -#define GWEN_CONTROLS_DRAGGER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT Dragger : public Controls::Base - { - public: - - GWEN_CONTROL( Dragger, Controls::Base ); - - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - virtual void Render( Skin::Base* skin ); - - virtual void SetTarget( Controls::Base* pBase ){ m_pTarget = pBase; } - - Gwen::Event::Caller onDragged; - - protected: - - bool m_bDepressed; - Gwen::Point m_HoldPos; - Controls::Base* m_pTarget; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/GroupBox.cpp b/btgui/Gwen/Controls/GroupBox.cpp deleted file mode 100644 index 3e9f60def..000000000 --- a/btgui/Gwen/Controls/GroupBox.cpp +++ /dev/null @@ -1,42 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/GroupBox.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( GroupBox ) -{ - // Set to true, because it's likely that our - // children will want mouse input, and they - // can't get it without us.. - SetMouseInputEnabled( true ); - - SetTextPadding( Padding( 10, 0, 0, 0 ) ); - - SetAlignment( Pos::Top | Pos::Left ); - Invalidate(); - - m_InnerPanel = new Base( this ); - m_InnerPanel->Dock( Pos::Fill ); - -} - -void GroupBox::Layout( Skin::Base* skin ) -{ - m_InnerPanel->SetMargin( Margin( TextHeight() + 3, 6, 6, 6 ) ); - - BaseClass::Layout( skin ); -} - - -void GroupBox::Render( Skin::Base* skin ) -{ - skin->DrawGroupBox( this, TextX(), TextHeight(), TextWidth() ); -} diff --git a/btgui/Gwen/Controls/GroupBox.h b/btgui/Gwen/Controls/GroupBox.h deleted file mode 100644 index 0453523ae..000000000 --- a/btgui/Gwen/Controls/GroupBox.h +++ /dev/null @@ -1,34 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_GROUPBOX_H -#define GWEN_CONTROLS_GROUPBOX_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace Controls - { - - class GWEN_EXPORT GroupBox : public Label - { - public: - - GWEN_CONTROL( GroupBox, Label ); - - virtual void Render( Skin::Base* skin ); - virtual void Layout( Skin::Base* skin ); - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/HSVColorPicker.cpp b/btgui/Gwen/Controls/HSVColorPicker.cpp deleted file mode 100644 index 994e915c3..000000000 --- a/btgui/Gwen/Controls/HSVColorPicker.cpp +++ /dev/null @@ -1,172 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/HSVColorPicker.h" -#include "Gwen/Controls/ColorControls.h" -#include "Gwen/Controls/ColorPicker.h" -#include "Gwen/Controls/TextBox.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/PanelListPanel.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( HSVColorPicker ) -{ - SetMouseInputEnabled( true ); - SetSize( 256, 128 ); - SetCacheToTexture(); - - m_LerpBox = new Gwen::Controls::ColorLerpBox( this ); - m_LerpBox->onSelectionChanged.Add( this, &HSVColorPicker::ColorBoxChanged ); - m_LerpBox->SetPos( 5, 5 ); - - m_ColorSlider = new Gwen::Controls::ColorSlider( this ); - m_ColorSlider->SetPos( m_LerpBox->Width() + 15, 5 ); - m_ColorSlider->onSelectionChanged.Add( this, &HSVColorPicker::ColorSliderChanged ); - - m_After = new Gwen::ControlsInternal::ColorDisplay( this ); - m_After->SetSize( 48, 24 ); - m_After->SetPos( m_ColorSlider->X() + m_ColorSlider->Width() + 15, 5 ); - - m_Before = new Gwen::ControlsInternal::ColorDisplay( this ); - m_Before->SetSize( 48, 24 ); - m_Before->SetPos( m_After->X(), 28 ); - - int x = m_Before->X(); - int y = m_Before->Y() + 30; - - - { - Label* label = new Label( this ); - label->SetText(L"R:"); - label->SizeToContents(); - label->SetPos( x, y ); - - TextBoxNumeric* numeric = new TextBoxNumeric( this ); - numeric->SetName( "RedBox" ); - numeric->SetPos( x + 15, y -1 ); - numeric->SetSize( 26, 16 ); - numeric->SetSelectAllOnFocus( true ); - numeric->onTextChanged.Add( this, &HSVColorPicker::NumericTyped ); - - } - - y+= 20; - - { - Label* label = new Label( this ); - label->SetText(L"G:"); - label->SizeToContents(); - label->SetPos( x, y ); - - - TextBoxNumeric* numeric = new TextBoxNumeric( this ); - numeric->SetName( "GreenBox" ); - numeric->SetPos( x + 15, y -1 ); - numeric->SetSize( 26, 16 ); - numeric->SetSelectAllOnFocus( true ); - numeric->onTextChanged.Add( this, &HSVColorPicker::NumericTyped ); - } - - y+= 20; - - { - Label* label = new Label( this ); - label->SetText(L"B:"); - label->SizeToContents(); - label->SetPos( x, y ); - - - TextBoxNumeric* numeric = new TextBoxNumeric( this ); - numeric->SetName( "BlueBox" ); - numeric->SetPos( x + 15, y -1 ); - numeric->SetSize( 26, 16 ); - numeric->SetSelectAllOnFocus( true ); - numeric->onTextChanged.Add( this, &HSVColorPicker::NumericTyped ); - } -} - -void HSVColorPicker::NumericTyped( Gwen::Controls::Base* control ) -{ - TextBoxNumeric* box = control->DynamicCastTextBoxNumeric(); - if ( !box ) return; - - if ( box->GetText() == L"" ) return; - - int textValue = atoi( Gwen::Utility::UnicodeToString( box->GetText()).c_str() ); - if ( textValue < 0 ) textValue = 0; - if ( textValue > 255 ) textValue = 255; - - Gwen::Color newColor = GetColor(); - - if ( box->GetName().find( "Red" ) != Gwen::String::npos ) - { - newColor.r = textValue; - } - else if ( box->GetName().find( "Green" ) != Gwen::String::npos ) - { - newColor.g = textValue; - } - else if ( box->GetName().find( "Blue" ) != Gwen::String::npos ) - { - newColor.b = textValue; - } - else if ( box->GetName().find( "Alpha" ) != Gwen::String::npos ) - { - newColor.a = textValue; - } - - SetColor( newColor ); -} - -void HSVColorPicker::UpdateControls(Gwen::Color color) -{ - TextBoxNumeric* redBox = FindChildByName( "RedBox", false )->DynamicCastTextBoxNumeric(); - if ( redBox ) redBox->SetText( Gwen::Utility::ToString( (int)color.r), false ); - - TextBoxNumeric* greenBox = FindChildByName( "GreenBox", false )->DynamicCastTextBoxNumeric(); - if ( greenBox ) greenBox->SetText( Gwen::Utility::ToString( (int)color.g ), false ); - - TextBoxNumeric* blueBox = FindChildByName( "BlueBox", false )->DynamicCastTextBoxNumeric(); - if ( blueBox ) blueBox->SetText( Gwen::Utility::ToString( (int)color.b ), false ); - - m_After->SetColor( color ); -} -void HSVColorPicker::SetColor( Gwen::Color color, bool onlyHue, bool reset ) -{ - - UpdateControls( color ); - - - if ( reset ) - m_Before->SetColor( color ); - - m_ColorSlider->SetColor( color ); - m_LerpBox->SetColor( color, onlyHue ); - m_After->SetColor( color ); -} - -Gwen::Color HSVColorPicker::GetColor() -{ - return m_LerpBox->GetSelectedColor(); -} - -void HSVColorPicker::ColorBoxChanged( Gwen::Controls::Base* /*pControl*/ ) -{ - onColorChanged.Call( this ); - UpdateControls( GetColor() ); - Invalidate(); -} -void HSVColorPicker::ColorSliderChanged( Gwen::Controls::Base* /*pControl*/ ) -{ - if ( m_LerpBox ) - m_LerpBox->SetColor( m_ColorSlider->GetSelectedColor(), true ); - Invalidate(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/HSVColorPicker.h b/btgui/Gwen/Controls/HSVColorPicker.h deleted file mode 100644 index ac5e1c410..000000000 --- a/btgui/Gwen/Controls/HSVColorPicker.h +++ /dev/null @@ -1,47 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_HSVCOLORPICKER_H -#define GWEN_CONTROLS_HSVCOLORPICKER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/ColorControls.h" -#include "Gwen/Controls/ColorPicker.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT HSVColorPicker : public Controls::Base - { - public: - GWEN_CONTROL( HSVColorPicker, Controls::Base ); - - Gwen::Color GetColor(); - Gwen::Color GetDefaultColor() { return m_Before->GetColor(); } - void SetColor( Gwen::Color color, bool onlyHue = false, bool reset = false ); - - void ColorBoxChanged( Gwen::Controls::Base* pControl ); - void ColorSliderChanged( Gwen::Controls::Base* pControl ); - void NumericTyped( Gwen::Controls::Base* control ); - - void UpdateControls( Gwen::Color newColor ); - - Event::Caller onColorChanged; - - protected: - ColorLerpBox* m_LerpBox; - ColorSlider* m_ColorSlider; - ControlsInternal::ColorDisplay* m_Before; - ControlsInternal::ColorDisplay* m_After; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Highlight.h b/btgui/Gwen/Controls/Highlight.h deleted file mode 100644 index 01c25d340..000000000 --- a/btgui/Gwen/Controls/Highlight.h +++ /dev/null @@ -1,36 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_HIGHLIGHT_H -#define GWEN_CONTROLS_HIGHLIGHT_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT Highlight : public Controls::Base - { - public: - - GWEN_CONTROL_INLINE( Highlight, Controls::Base ) - { - - } - - void Render( Skin::Base* skin ) - { - skin->DrawHighlight( this ); - } - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/HorizontalScrollBar.cpp b/btgui/Gwen/Controls/HorizontalScrollBar.cpp deleted file mode 100644 index 323f2af5e..000000000 --- a/btgui/Gwen/Controls/HorizontalScrollBar.cpp +++ /dev/null @@ -1,136 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/HorizontalScrollBar.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( HorizontalScrollBar ) -{ - m_Bar->SetHorizontal(); - - m_ScrollButton[SCROLL_BUTTON_LEFT]->SetDirectionLeft(); - m_ScrollButton[SCROLL_BUTTON_LEFT]->onPress.Add( this, &HorizontalScrollBar::NudgeLeft ); - - m_ScrollButton[SCROLL_BUTTON_RIGHT]->SetDirectionRight(); - m_ScrollButton[SCROLL_BUTTON_RIGHT]->onPress.Add( this, &HorizontalScrollBar::NudgeRight ); - - m_Bar->onDragged.Add( this, &HorizontalScrollBar::OnBarMoved ); -} - -void HorizontalScrollBar::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - - m_ScrollButton[SCROLL_BUTTON_LEFT]->SetWidth( Height() ); - m_ScrollButton[SCROLL_BUTTON_LEFT]->Dock(Pos::Left); - - m_ScrollButton[SCROLL_BUTTON_RIGHT]->SetWidth( Height() ); - m_ScrollButton[SCROLL_BUTTON_RIGHT]->Dock(Pos::Right); - - m_Bar->SetHeight( GetButtonSize() ); - m_Bar->SetPadding( Padding( GetButtonSize(), 0, GetButtonSize(), 0 ) ); - - float barWidth = (m_fViewableContentSize / m_fContentSize) * (Width() - (GetButtonSize() * 2)); - - if ( barWidth < GetButtonSize() * 0.5 ) - barWidth = GetButtonSize() * 0.5; - - m_Bar->SetWidth(barWidth); - m_Bar->SetHidden( Width() - (GetButtonSize() * 2) <= barWidth ); - - //Based on our last scroll amount, produce a position for the bar - if ( !m_Bar->IsDepressed() ) - { - SetScrolledAmount( GetScrolledAmount(), true ); - } -} - -void HorizontalScrollBar::NudgeLeft( Base* /*control*/ ) -{ - if ( !IsDisabled() ) - SetScrolledAmount( GetScrolledAmount() - GetNudgeAmount(), true); -} - -void HorizontalScrollBar::NudgeRight( Base* /*control*/ ) -{ - if ( !IsDisabled() ) - SetScrolledAmount( GetScrolledAmount() + GetNudgeAmount(), true); -} - -void HorizontalScrollBar::ScrollToLeft() -{ - SetScrolledAmount( 0, true); -} -void HorizontalScrollBar::ScrollToRight() -{ - SetScrolledAmount( 1, true); -} - -float HorizontalScrollBar::GetNudgeAmount() -{ - if ( m_bDepressed ) - return m_fViewableContentSize / m_fContentSize; - else - return BaseClass::GetNudgeAmount(); -} - - - -void HorizontalScrollBar::OnMouseClickLeft( int x, int y, bool bDown ) -{ - if ( bDown ) - { - m_bDepressed = true; - Gwen::MouseFocus = this; - } - else - { - Gwen::Point clickPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - if ( clickPos.x < m_Bar->X() ) - NudgeLeft( this ); - else if ( clickPos.x > m_Bar->X() + m_Bar->Width() ) - NudgeRight( this ); - - m_bDepressed = false; - Gwen::MouseFocus = NULL; - } -} - -float HorizontalScrollBar::CalculateScrolledAmount() -{ - return (float)(m_Bar->X() - GetButtonSize()) / (float)(Width() - m_Bar->Width() - (GetButtonSize() * 2 )); -} - -bool HorizontalScrollBar::SetScrolledAmount( float amount, bool forceUpdate ) -{ - amount = Gwen::Clamp( amount, 0, 1 ); - - if ( !BaseClass::SetScrolledAmount( amount, forceUpdate ) ) - return false; - - if ( forceUpdate ) - { - int newX = GetButtonSize() + (amount * ((Width() - m_Bar->Width()) - (GetButtonSize()*2))); - m_Bar->MoveTo( newX, m_Bar->Y() ); - } - - return true; -} - -void HorizontalScrollBar::OnBarMoved( Controls::Base* control ) -{ - if ( m_Bar->IsDepressed() ) - { - SetScrolledAmount( CalculateScrolledAmount(), false ); - BaseClass::OnBarMoved(control); - } - else - InvalidateParent(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/HorizontalScrollBar.h b/btgui/Gwen/Controls/HorizontalScrollBar.h deleted file mode 100644 index b431b0182..000000000 --- a/btgui/Gwen/Controls/HorizontalScrollBar.h +++ /dev/null @@ -1,49 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_HORIZONTALSCROLLBAR_H -#define GWEN_CONTROLS_HORIZONTALSCROLLBAR_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Controls/ScrollBar.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT HorizontalScrollBar : public BaseScrollBar - { - public: - - GWEN_CONTROL( HorizontalScrollBar, BaseScrollBar ); - - virtual void Layout( Skin::Base* skin ); - - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - virtual void OnBarMoved( Controls::Base* control ); - - virtual int GetBarSize() { return m_Bar->Width(); } - virtual int GetBarPos() { return m_Bar->X() - Height(); } - virtual void SetBarSize( int size ) { m_Bar->SetWidth( size ); } - virtual int GetButtonSize() { return Height(); } - - virtual void ScrollToLeft(); - virtual void ScrollToRight(); - virtual void NudgeLeft( Base* control ); - virtual void NudgeRight( Base* control ); - virtual float GetNudgeAmount(); - - virtual float CalculateScrolledAmount(); - virtual bool SetScrolledAmount(float amount, bool forceUpdate); - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/HorizontalSlider.cpp b/btgui/Gwen/Controls/HorizontalSlider.cpp deleted file mode 100644 index 5cb0ffd73..000000000 --- a/btgui/Gwen/Controls/HorizontalSlider.cpp +++ /dev/null @@ -1,45 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/Slider.h" -#include "Gwen/Controls/HorizontalSlider.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - - -GWEN_CONTROL_CONSTRUCTOR( HorizontalSlider ) -{ -} - -float HorizontalSlider::CalculateValue() -{ - return (float)m_SliderBar->X() / (float)( Width() - m_SliderBar->Width() ); -} - -void HorizontalSlider::UpdateBarFromValue() -{ - m_SliderBar->MoveTo( ( Width() - m_SliderBar->Width() ) * ( m_fValue ), m_SliderBar->Y() ); -} - -void HorizontalSlider::OnMouseClickLeft( int x, int y, bool bDown ) -{ - m_SliderBar->MoveTo( CanvasPosToLocal( Gwen::Point( x, y ) ).x - m_SliderBar->Width() * 0.5, m_SliderBar->Y() ); - m_SliderBar->OnMouseClickLeft( x, y, bDown ); - OnMoved( m_SliderBar ); -} - -void HorizontalSlider::Layout(Skin::Base* /*skin*/) -{ - m_SliderBar->SetSize( 10, Height() ); -} - -void HorizontalSlider::Render( Skin::Base* skin ) -{ - skin->DrawSlider( this, true, m_bClampToNotches ? m_iNumNotches : 0, m_SliderBar->Width() ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/HorizontalSlider.h b/btgui/Gwen/Controls/HorizontalSlider.h deleted file mode 100644 index af3da74db..000000000 --- a/btgui/Gwen/Controls/HorizontalSlider.h +++ /dev/null @@ -1,35 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_HORIZONTALSLIDER_H -#define GWEN_CONTROLS_HORIZONTALSLIDER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Slider.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT HorizontalSlider : public Slider - { - GWEN_CONTROL( HorizontalSlider, Slider ); - - virtual void Layout( Skin::Base* skin ); - virtual void Render( Skin::Base* skin ); - - virtual float CalculateValue(); - virtual void UpdateBarFromValue(); - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ImagePanel.cpp b/btgui/Gwen/Controls/ImagePanel.cpp deleted file mode 100644 index a84a18c14..000000000 --- a/btgui/Gwen/Controls/ImagePanel.cpp +++ /dev/null @@ -1,8 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ImagePanel.h" \ No newline at end of file diff --git a/btgui/Gwen/Controls/ImagePanel.h b/btgui/Gwen/Controls/ImagePanel.h deleted file mode 100644 index e29bfa090..000000000 --- a/btgui/Gwen/Controls/ImagePanel.h +++ /dev/null @@ -1,78 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_IMAGEPANEL_H -#define GWEN_CONTROLS_IMAGEPANEL_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/BaseRender.h" -#include "Gwen/Texture.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT ImagePanel : public Controls::Base - { - public: - - GWEN_CONTROL_INLINE( ImagePanel, Controls::Base ) - { - SetUV( 0, 0, 1, 1 ); - SetMouseInputEnabled( false ); - m_DrawColor = Colors::White; - } - - virtual ~ImagePanel() - { - m_Texture.Release( GetSkin()->GetRender() ); - } - - - virtual void SetUV( float u1, float v1, float u2, float v2 ) - { - m_uv[0] = u1; - m_uv[1] = v1; - m_uv[2] = u2; - m_uv[3] = v2; - } - - virtual void SetImage( const TextObject& imageName ) - { - m_Texture.Load( imageName, GetSkin()->GetRender() ); - } - - virtual const TextObject& GetImageName() - { - return m_Texture.name; - } - - virtual void Render( Skin::Base* skin ) - { - skin->GetRender()->SetDrawColor( m_DrawColor ); - skin->GetRender()->DrawTexturedRect( &m_Texture, GetRenderBounds(), m_uv[0], m_uv[1], m_uv[2], m_uv[3] ); - } - - virtual void SizeToContents() - { - SetSize( m_Texture.width, m_Texture.height ); - } - - virtual void SetDrawColor( Gwen::Color& color ) - { - m_DrawColor = color; - } - - Texture m_Texture; - float m_uv[4]; - Gwen::Color m_DrawColor; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Label.cpp b/btgui/Gwen/Controls/Label.cpp deleted file mode 100644 index 54ca15843..000000000 --- a/btgui/Gwen/Controls/Label.cpp +++ /dev/null @@ -1,75 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( Label ) -{ - m_Text = new ControlsInternal::Text( this ); - m_Text->SetFont( GetSkin()->GetDefaultFont() ); - - SetMouseInputEnabled( false ); - SetBounds( 0, 0, 100, 10 ); - SetAlignment( Gwen::Pos::Left | Gwen::Pos::Top ); -} - -void Label::Layout( Skin::Base* /*skin*/ ) -{ - - int iAlign = m_iAlign; - - int x = m_rTextPadding.left + m_Padding.left; - int y = m_rTextPadding.top + m_Padding.top; - - if ( iAlign & Pos::Right ) x = Width() - m_Text->Width() - m_rTextPadding.right - m_Padding.right; - if ( iAlign & Pos::CenterH ) x = (m_rTextPadding.left + m_Padding.left) + ((Width() - m_Text->Width() ) * 0.5f) - m_rTextPadding.right - m_Padding.right; - - if ( iAlign & Pos::CenterV ) y = (m_rTextPadding.top + m_Padding.top) + ((Height() - m_Text->Height()) * 0.5f) - m_rTextPadding.bottom - m_Padding.bottom; - if ( iAlign & Pos::Bottom ) y = Height() - m_Text->Height() - m_rTextPadding.bottom - m_Padding.bottom; - - m_Text->SetPos( x, y ); - -} - -void Label::SetText( const UnicodeString& str, bool bDoEvents ) -{ - if ( m_Text->GetText() == str ) return; - - m_Text->SetString( str ); - Redraw(); - - if ( bDoEvents ) - OnTextChanged(); -} - -void Label::SetText( const String& str, bool bDoEvents ) -{ - SetText( Gwen::Utility::StringToUnicode( str ), bDoEvents ); -} - -void Label::SizeToContents() -{ - m_Text->SetPos( m_rTextPadding.left + m_Padding.left, m_rTextPadding.top + m_Padding.top ); - m_Text->RefreshSize(); - - SetSize( m_Text->Width() + m_Padding.left + m_Padding.right + m_rTextPadding.left + m_rTextPadding.right, m_Text->Height() + m_Padding.top + m_Padding.bottom + m_rTextPadding.top + m_rTextPadding.bottom ); - -} - -Gwen::Point Label::GetCharacterPosition( int iChar ) -{ - Gwen::Point p = m_Text->GetCharacterPosition( iChar ); - p.x += m_Text->X(); - p.y += m_Text->Y(); - - return p; -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Label.h b/btgui/Gwen/Controls/Label.h deleted file mode 100644 index f9d55d7dd..000000000 --- a/btgui/Gwen/Controls/Label.h +++ /dev/null @@ -1,70 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_LABEL_H -#define GWEN_CONTROLS_LABEL_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Text.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT Label : public Controls::Base - { - public: - - GWEN_CONTROL( Label, Controls::Base ); - - virtual void SetText( const UnicodeString& str, bool bDoEvents = true ); - virtual void SetText( const String& str, bool bDoEvents = true ); - - virtual const UnicodeString& GetText() const { return m_Text->GetText(); } - - virtual void Render( Skin::Base* /*skin*/ ){} - - virtual void Layout( Skin::Base* skin ); - - virtual void SizeToContents(); - - virtual void SetAlignment( int iAlign ){ m_iAlign = iAlign; } - - virtual void SetFont( Gwen::Font* pFont ){ m_Text->SetFont( pFont ); } - virtual Gwen::Font* GetFont(){ return m_Text->GetFont(); } - virtual void SetTextColor( const Gwen::Color& col ){ m_Text->SetTextColor( col ); } - inline const Gwen::Color &TextColor() const { return m_Text->TextColor(); } - - virtual int TextWidth() { return m_Text->Width(); } - virtual int TextRight() { return m_Text->Right(); } - virtual int TextHeight() { return m_Text->Height(); } - virtual int TextX() { return m_Text->X(); } - virtual int TextY() { return m_Text->Y(); } - virtual int TextLength() { return m_Text->Length(); } - - Gwen::Point GetCharacterPosition( int iChar ); - - virtual void SetTextPadding( const Padding& padding ){ m_rTextPadding = padding; Invalidate(); InvalidateParent(); } - virtual const Padding& GetTextPadding(){ return m_rTextPadding; } - - virtual Gwen::UnicodeString GetText() { return m_Text->GetText(); } - - inline int Alignment() const { return m_iAlign; } - protected: - - virtual void OnTextChanged(){}; - - Padding m_rTextPadding; - ControlsInternal::Text* m_Text; - int m_iAlign; - - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/LabelClickable.cpp b/btgui/Gwen/Controls/LabelClickable.cpp deleted file mode 100644 index b497d7d49..000000000 --- a/btgui/Gwen/Controls/LabelClickable.cpp +++ /dev/null @@ -1,25 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/LabelClickable.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( LabelClickable ) -{ - SetIsToggle( false ); - - SetAlignment( Gwen::Pos::Left | Gwen::Pos::CenterV ); -} - -void LabelClickable::Render( Skin::Base* /*skin*/ ) -{ - //skin->DrawButton( this, IsDepressed(), IsToggle() && GetToggleState() ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/LabelClickable.h b/btgui/Gwen/Controls/LabelClickable.h deleted file mode 100644 index 123797bf7..000000000 --- a/btgui/Gwen/Controls/LabelClickable.h +++ /dev/null @@ -1,29 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_LABELCLICKABLE_H -#define GWEN_CONTROLS_LABELCLICKABLE_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT LabelClickable : public Button - { - public: - - GWEN_CONTROL( LabelClickable, Button ); - - virtual void Render( Skin::Base* skin ); - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Layout/Splitter (2).h b/btgui/Gwen/Controls/Layout/Splitter (2).h deleted file mode 100644 index 847f65ce8..000000000 --- a/btgui/Gwen/Controls/Layout/Splitter (2).h +++ /dev/null @@ -1,83 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#pragma once -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Controls - { - namespace Layout - { - - class Splitter : public Base - { - public: - - typedef Base BaseClass; - - Splitter( Base* pParent ) : BaseClass( pParent ) - { - for ( int i=0; i<2; i++ ) - m_pPanel[i] = NULL; - } - - void SetPanel( int i, Base* pPanel ) - { - if ( i < 0 || i > 1 ) return; - - m_pPanel[i] = pPanel; - - if ( m_pPanel[i] ) - { - m_pPanel[i] ->SetParent( this ); - } - } - - Base* GetPanel( int i ) const - { - if ( i < 0 || i > 1 ) return NULL; - return m_pPanel[i]; - } - - void Layout( Skin::Base* skin ) - { - LayoutVertical( skin ); - } - - private: - - void LayoutVertical( Skin::Base* skin ) - { - int w = Width(); - int h = Height(); - - if ( m_pPanel[0] ) - { - const Margin& m = m_pPanel[0]->GetMargin(); - m_pPanel[0]->SetBounds( m.left, m.top, w-m.left-m.right, (h * 0.5) - m.top - m.bottom ); - } - - if ( m_pPanel[1] ) - { - const Margin& m = m_pPanel[1]->GetMargin(); - m_pPanel[1]->SetBounds( m.left, m.top + (h * 0.5f), w-m.left-m.right, (h * 0.5f) - m.top - m.bottom ); - } - } - - void LayoutHorizontal( Skin::Base* skin ) - { - // Todo. - } - - Base* m_pPanel[2]; - - }; - } - } -} diff --git a/btgui/Gwen/Controls/Layout/Splitter - Copy.h b/btgui/Gwen/Controls/Layout/Splitter - Copy.h deleted file mode 100644 index f72b19663..000000000 --- a/btgui/Gwen/Controls/Layout/Splitter - Copy.h +++ /dev/null @@ -1,87 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#pragma once -#ifndef GWEN_CONTROLS_LAYOUT_SPLITTER_H -#define GWEN_CONTROLS_LAYOUT_SPLITTER_H - -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Controls - { - namespace Layout - { - - class GWEN_EXPORT Splitter : public Base - { - public: - - typedef Base BaseClass; - - Splitter( Base* pParent ) : BaseClass( pParent ) - { - for ( int i=0; i<2; i++ ) - m_pPanel[i] = NULL; - } - - void SetPanel( int i, Base* pPanel ) - { - if ( i < 0 || i > 1 ) return; - - m_pPanel[i] = pPanel; - - if ( m_pPanel[i] ) - { - m_pPanel[i] ->SetParent( this ); - } - } - - Base* GetPanel( int i ) const - { - if ( i < 0 || i > 1 ) return NULL; - return m_pPanel[i]; - } - - void Layout( Skin::Base* skin ) - { - LayoutVertical( skin ); - } - - private: - - void LayoutVertical( Skin::Base* /*skin*/ ) - { - int w = Width(); - int h = Height(); - - if ( m_pPanel[0] ) - { - const Margin& m = m_pPanel[0]->GetMargin(); - m_pPanel[0]->SetBounds( m.left, m.top, w-m.left-m.right, (h * 0.5) - m.top - m.bottom ); - } - - if ( m_pPanel[1] ) - { - const Margin& m = m_pPanel[1]->GetMargin(); - m_pPanel[1]->SetBounds( m.left, m.top + (h * 0.5f), w-m.left-m.right, (h * 0.5f) - m.top - m.bottom ); - } - } - - void LayoutHorizontal( Skin::Base* /*skin*/ ) - { - // Todo. - } - - Base* m_pPanel[2]; - - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/Layout/Splitter.h b/btgui/Gwen/Controls/Layout/Splitter.h deleted file mode 100644 index f72b19663..000000000 --- a/btgui/Gwen/Controls/Layout/Splitter.h +++ /dev/null @@ -1,87 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#pragma once -#ifndef GWEN_CONTROLS_LAYOUT_SPLITTER_H -#define GWEN_CONTROLS_LAYOUT_SPLITTER_H - -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Controls - { - namespace Layout - { - - class GWEN_EXPORT Splitter : public Base - { - public: - - typedef Base BaseClass; - - Splitter( Base* pParent ) : BaseClass( pParent ) - { - for ( int i=0; i<2; i++ ) - m_pPanel[i] = NULL; - } - - void SetPanel( int i, Base* pPanel ) - { - if ( i < 0 || i > 1 ) return; - - m_pPanel[i] = pPanel; - - if ( m_pPanel[i] ) - { - m_pPanel[i] ->SetParent( this ); - } - } - - Base* GetPanel( int i ) const - { - if ( i < 0 || i > 1 ) return NULL; - return m_pPanel[i]; - } - - void Layout( Skin::Base* skin ) - { - LayoutVertical( skin ); - } - - private: - - void LayoutVertical( Skin::Base* /*skin*/ ) - { - int w = Width(); - int h = Height(); - - if ( m_pPanel[0] ) - { - const Margin& m = m_pPanel[0]->GetMargin(); - m_pPanel[0]->SetBounds( m.left, m.top, w-m.left-m.right, (h * 0.5) - m.top - m.bottom ); - } - - if ( m_pPanel[1] ) - { - const Margin& m = m_pPanel[1]->GetMargin(); - m_pPanel[1]->SetBounds( m.left, m.top + (h * 0.5f), w-m.left-m.right, (h * 0.5f) - m.top - m.bottom ); - } - } - - void LayoutHorizontal( Skin::Base* /*skin*/ ) - { - // Todo. - } - - Base* m_pPanel[2]; - - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/Layout/Table (2).h b/btgui/Gwen/Controls/Layout/Table (2).h deleted file mode 100644 index 43dd667c7..000000000 --- a/btgui/Gwen/Controls/Layout/Table (2).h +++ /dev/null @@ -1,264 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#pragma once -#include "Gwen/Controls/Label.h" - -namespace Gwen -{ - namespace Controls - { - namespace Layout - { - class Table; - - class TableRow : public Base - { - static const int MaxColumns = 5; - - GWEN_CONTROL_INLINE( TableRow, Base ) - { - for ( int i=0; i= MaxColumns ) - m_ColumnCount = MaxColumns; - - for ( int i=0; iDock( Pos::Left ); - m_Columns[i]->SetTextPadding( Gwen::Rect( 3, 3, 3, 3 ) ); - } - } - else if ( m_Columns[i] ) - { - m_Columns[i]->DelayedDelete(); - m_Columns[i] = NULL; - } - - m_ColumnCount = iCount; - } - } - - void SetColumnWidth( int i, int iWidth ) - { - if ( !m_Columns[i] ) return; - if ( m_Columns[i]->Width() == iWidth ) return; - - m_Columns[i]->SetWidth( iWidth ); - } - - template - void SetCellText( int i, const T& strString ) - { - if ( !m_Columns[i] ) return; - m_Columns[i]->SetText( strString ); - } - - void SetCellContents( int i, Base* pControl, bool bEnableMouseInput = false ) - { - if ( !m_Columns[i] ) return; - pControl->SetParent( m_Columns[i] ); - - m_Columns[i]->SetMouseInputEnabled( bEnableMouseInput ); - } - - Label* GetCellContents( int i ) - { - return m_Columns[i]; - } - - void SizeToContents() - { - int iHeight = 0; - - for ( int i=0; iNumChildren() > 1 ) - { - m_Columns[i]->SizeToChildren(); - } - else - { - m_Columns[i]->SizeToContents(); - } - - iHeight = max( iHeight, m_Columns[i]->Height() ); - } - - SetHeight( iHeight ); - } - - void SetTextColor( const Gwen::Color& color ) - { - for ( int i=0; iSetTextColor( color ); - } - } - - //You might hate this. Actually I know you will - virtual UnicodeString GetText( int i ) - { - return m_Columns[i]->GetText(); - } - virtual void SetSelected( bool b ) {} - - private: - - int m_ColumnCount; - Label* m_Columns[MaxColumns]; - - friend class Table; - - - }; - - class Table : public Base - { - public: - - GWEN_CONTROL_INLINE( Table, Base ) - { - m_iColumnCount = 1; - m_iDefaultRowHeight = 22; - - for (int i=0; igetType()!=TypeTableRow) - continue; - - TableRow* pRow = static_cast(*it); - - pRow->SetColumnCount( i ); - } - - m_iColumnCount = i; - } - - void SetColumnWidth( int i, int iWidth ) - { - if ( m_ColumnWidth[i] == iWidth ) return; - - m_ColumnWidth[i] = iWidth; - Invalidate(); - } - - TableRow* AddRow() - { - TableRow* row = new TableRow( this ); - row->SetColumnCount( m_iColumnCount ); - row->SetHeight( m_iDefaultRowHeight ); - row->Dock( Pos::Top ); - return row; - } - - void AddRow( TableRow* pRow ) - { - pRow->SetParent( this ); - pRow->SetColumnCount( m_iColumnCount ); - pRow->SetHeight( m_iDefaultRowHeight ); - pRow->Dock( Pos::Top ); - } - - void Layout( Skin::Base* skin ) - { - Debug::Msg( "TABLE LAYOUT\n" ); - BaseClass::Layout( skin ); - - if ( m_bSizeToContents ) - { - DoSizeToContents(); - m_bSizeToContents = false; - } - - for ( Base::List::iterator it = m_Children.begin(); it != m_Children.end(); ++it ) - { - TableRow* pRow = static_cast(*it); - if ( !pRow ) continue; - - for (int i=0; iSetColumnWidth( i, m_ColumnWidth[i] ); - } - } - } - - void SizeToContents() - { - m_bSizeToContents = true; - Invalidate(); - } - - void DoSizeToContents() - { - for (int i=0; i(*it); - if ( !pRow ) continue; - - pRow->SizeToContents(); - - for (int i=0; im_Columns[i] ) - { - m_ColumnWidth[i] = max( m_ColumnWidth[i], pRow->m_Columns[i]->Width() ); - } - } - } - - Invalidate(); - } - - private: - - bool m_bSizeToContents; - int m_iColumnCount; - int m_iDefaultRowHeight; - - int m_ColumnWidth[ TableRow::MaxColumns ]; - }; - } - } -} diff --git a/btgui/Gwen/Controls/Layout/Table - Copy.h b/btgui/Gwen/Controls/Layout/Table - Copy.h deleted file mode 100644 index 6fee90d59..000000000 --- a/btgui/Gwen/Controls/Layout/Table - Copy.h +++ /dev/null @@ -1,294 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_LAYOUT_TABLE_H -#define GWEN_CONTROLS_LAYOUT_TABLE_H - -#include "Gwen/Controls/Label.h" -#include "Gwen/Utility.h" - - -namespace Gwen -{ - namespace Controls - { - namespace Layout - { - class Table; - - class GWEN_EXPORT TableRow : public Base - { - static const int MaxColumns = 5; - - GWEN_CONTROL_INLINE( TableRow, Base ) - { - for ( int i=0; i= MaxColumns ) - m_ColumnCount = MaxColumns; - - for ( int i=0; iDock( Pos::Left ); - m_Columns[i]->SetPadding( Padding( 3, 3, 3, 3 ) ); - } - } - else if ( m_Columns[i] ) - { - m_Columns[i]->DelayedDelete(); - m_Columns[i] = NULL; - } - - m_ColumnCount = iCount; - } - } - - void SetColumnWidth( int i, int iWidth ) - { - if ( !m_Columns[i] ) return; - if ( m_Columns[i]->Width() == iWidth ) return; - - m_Columns[i]->SetWidth( iWidth ); - } - - template - void SetCellText( int i, const T& strString ) - { - if ( !m_Columns[i] ) return; - m_Columns[i]->SetText( strString ); - } - - void SetCellContents( int i, Base* pControl, bool bEnableMouseInput = false ) - { - if ( !m_Columns[i] ) return; - pControl->SetParent( m_Columns[i] ); - - m_Columns[i]->SetMouseInputEnabled( bEnableMouseInput ); - } - - Label* GetCellContents( int i ) - { - return m_Columns[i]; - } - - void SizeToContents() - { - int iHeight = 0; - - for ( int i=0; iNumChildren() > 1 ) - { - m_Columns[i]->SizeToChildren(); - } - else - { - m_Columns[i]->SizeToContents(); - } - - iHeight = Utility::Max( iHeight, m_Columns[i]->Height() ); - } - - SetHeight( iHeight ); - } - - void SetTextColor( const Gwen::Color& color ) - { - for ( int i=0; iSetTextColor( color ); - } - } - - //You might hate this. Actually I know you will - virtual UnicodeString GetText( int i ) - { - return m_Columns[i]->GetText(); - } - virtual void SetSelected( bool /*b*/ ) {} - - // - // This is sometimes called by derivatives. - // - Gwen::Event::Caller onRowSelected; - - private: - - int m_ColumnCount; - Label* m_Columns[MaxColumns]; - - friend class Table; - - - }; - - class GWEN_EXPORT Table : public Base - { - public: - - GWEN_CONTROL_INLINE( Table, Base ) - { - m_iColumnCount = 1; - m_iDefaultRowHeight = 22; - - for (int i=0; i(*it); - if ( !pRow ) continue; - - pRow->SetColumnCount( i ); - } - - m_iColumnCount = i; - } - - void SetColumnWidth( int i, int iWidth ) - { - if ( m_ColumnWidth[i] == iWidth ) return; - - m_ColumnWidth[i] = iWidth; - Invalidate(); - } - - TableRow* AddRow() - { - TableRow* row = new TableRow( this ); - row->SetColumnCount( m_iColumnCount ); - row->SetHeight( m_iDefaultRowHeight ); - row->Dock( Pos::Top ); - return row; - } - - void AddRow( TableRow* pRow ) - { - pRow->SetParent( this ); - pRow->SetColumnCount( m_iColumnCount ); - pRow->SetHeight( m_iDefaultRowHeight ); - pRow->Dock( Pos::Top ); - } - - void Remove( TableRow* pRow ) - { - pRow->DelayedDelete(); - } - - void Clear() - { - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - TableRow* pRow = static_cast(*it); - if ( !pRow ) continue; - Remove( pRow ); - } - } - - void Layout( Skin::Base* skin ) - { - BaseClass::Layout( skin ); - - if ( m_bSizeToContents ) - { - DoSizeToContents(); - } - - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - TableRow* pRow = static_cast(*it); - if ( !pRow ) continue; - - for (int i=0; iSetColumnWidth( i, m_ColumnWidth[i] ); - } - } - } - - void PostLayout( Skin::Base* /*skin*/ ) - { - if ( m_bSizeToContents ) - { - SizeToChildren(); - m_bSizeToContents = false; - } - } - - void SizeToContents() - { - m_bSizeToContents = true; - Invalidate(); - } - - void DoSizeToContents() - { - for (int i=0; i(*it); - if ( !pRow ) continue; - - pRow->SizeToContents(); - - for (int i=0; im_Columns[i] ) - { - m_ColumnWidth[i] = Utility::Max( m_ColumnWidth[i], pRow->m_Columns[i]->Width() ); - } - } - //iBottom += pRow->Height(); - } - - InvalidateParent(); - } - - private: - - bool m_bSizeToContents; - int m_iColumnCount; - int m_iDefaultRowHeight; - - int m_ColumnWidth[ TableRow::MaxColumns ]; - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/Layout/Table.h b/btgui/Gwen/Controls/Layout/Table.h deleted file mode 100644 index bbc1c8f9c..000000000 --- a/btgui/Gwen/Controls/Layout/Table.h +++ /dev/null @@ -1,317 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_LAYOUT_TABLE_H -#define GWEN_CONTROLS_LAYOUT_TABLE_H - -#include "Gwen/Controls/Label.h" -#include "Gwen/Utility.h" - - -namespace Gwen -{ - namespace Controls - { - namespace Layout - { - class Table; - - class GWEN_EXPORT TableRow : public Base - { - static const int MaxColumns = 5; - - GWEN_CONTROL_INLINE( TableRow, Base ) - { - for ( int i=0; i= MaxColumns ) - m_ColumnCount = MaxColumns; - - for ( int i=0; iDock( Pos::Left ); - m_Columns[i]->SetPadding( Padding( 3, 3, 3, 3 ) ); - } - } - else if ( m_Columns[i] ) - { - m_Columns[i]->DelayedDelete(); - m_Columns[i] = NULL; - } - - m_ColumnCount = iCount; - } - } - - void SetColumnWidth( int i, int iWidth ) - { - if ( !m_Columns[i] ) return; - if ( m_Columns[i]->Width() == iWidth ) return; - - m_Columns[i]->SetWidth( iWidth ); - } - - template - void SetCellText( int i, const T& strString ) - { - if ( !m_Columns[i] ) return; - m_Columns[i]->SetText( strString ); - } - - void SetCellContents( int i, Base* pControl, bool bEnableMouseInput = false ) - { - if ( !m_Columns[i] ) return; - pControl->SetParent( m_Columns[i] ); - - m_Columns[i]->SetMouseInputEnabled( bEnableMouseInput ); - } - - Label* GetCellContents( int i ) - { - return m_Columns[i]; - } - - void SizeToContents() - { - int iHeight = 0; - - for ( int i=0; iNumChildren() > 1 ) - { - m_Columns[i]->SizeToChildren(); - } - else - { - m_Columns[i]->SizeToContents(); - } - - iHeight = Utility::Max( iHeight, m_Columns[i]->Height() ); - } - - SetHeight( iHeight ); - } - - void SetTextColor( const Gwen::Color& color ) - { - for ( int i=0; iSetTextColor( color ); - } - } - - //You might hate this. Actually I know you will - virtual UnicodeString GetText( int i ) - { - return m_Columns[i]->GetText(); - } - virtual void SetSelected( bool /*b*/ ) {} - - // - // This is sometimes called by derivatives. - // - Gwen::Event::Caller onRowSelected; - - private: - - int m_ColumnCount; - Label* m_Columns[MaxColumns]; - - friend class Table; - - - }; - - class GWEN_EXPORT Table : public Base - { - public: - - GWEN_CONTROL_INLINE( Table, Base ) - { - m_iColumnCount = 1; - m_iDefaultRowHeight = 22; - - for (int i=0; iDynamicCastLayoutTableRow(); - if ( !pRow ) continue; - - pRow->SetColumnCount( i ); - } - - m_iColumnCount = i; - } - - void SetColumnWidth( int i, int iWidth ) - { - if ( m_ColumnWidth[i] == iWidth ) return; - - m_ColumnWidth[i] = iWidth; - Invalidate(); - } - - TableRow* AddRow() - { - TableRow* row = new TableRow( this ); - row->SetColumnCount( m_iColumnCount ); - row->SetHeight( m_iDefaultRowHeight ); - row->Dock( Pos::Top ); - return row; - } - - void AddRow( TableRow* pRow ) - { - pRow->SetParent( this ); - pRow->SetColumnCount( m_iColumnCount ); - pRow->SetHeight( m_iDefaultRowHeight ); - pRow->Dock( Pos::Top ); - } - - void Remove( TableRow* pRow ) - { - pRow->DelayedDelete(); - } - - void Clear() - { - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - if (!(*it)) - continue; - - TableRow* pRow = (*it)->DynamicCastLayoutTableRow(); - - if ( !pRow ) continue; - Remove( pRow ); - } - } - - void Layout( Skin::Base* skin ) - { - BaseClass::Layout( skin ); - - if ( m_bSizeToContents ) - { - DoSizeToContents(); - } - - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - if (!*it) - continue; - - TableRow* pRow = (*it)->DynamicCastLayoutTableRow(); - if ( !pRow ) continue; - - for (int i=0; iSetColumnWidth( i, m_ColumnWidth[i] ); - } - } - } - - void PostLayout( Skin::Base* /*skin*/ ) - { - if ( m_bSizeToContents ) - { - SizeToChildren(); - m_bSizeToContents = false; - } - } - - void SizeToContents() - { - m_bSizeToContents = true; - Invalidate(); - } - - void DoSizeToContents() - { - for (int i=0; iDynamicCastLayoutTableRow(); - if ( !pRow ) continue; - - pRow->SizeToContents(); - - for (int i=0; im_Columns[i] ) - { - m_ColumnWidth[i] = Utility::Max( m_ColumnWidth[i], pRow->m_Columns[i]->Width() ); - } - } - //iBottom += pRow->Height(); - } - - InvalidateParent(); - } - - private: - - bool m_bSizeToContents; - int m_iColumnCount; - int m_iDefaultRowHeight; - - int m_ColumnWidth[ TableRow::MaxColumns ]; - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/ListBox.cpp b/btgui/Gwen/Controls/ListBox.cpp deleted file mode 100644 index 137b2aeb4..000000000 --- a/btgui/Gwen/Controls/ListBox.cpp +++ /dev/null @@ -1,143 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ListBox.h" -#include "Gwen/Controls/ScrollControl.h" -#include "Gwen/InputHandler.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -class ListBoxRow : public Layout::TableRow -{ - GWEN_CONTROL_INLINE( ListBoxRow, Layout::TableRow ) - { - SetMouseInputEnabled( true ); - SetSelected( false ); - } - - void Render( Skin::Base* skin ) - { - skin->DrawListBoxLine( this, IsSelected() ); - } - - bool IsSelected() const - { - return m_bSelected; - } - - void OnMouseClickLeft( int /*x*/, int /*y*/, bool bDown ) - { - if ( bDown && !m_bSelected ) - { - SetSelected( true ); - onRowSelected.Call( this ); - } - } - - void SetSelected( bool b ) - { - m_bSelected = b; - - // TODO: Get these values from the skin. - if ( b ) - SetTextColor( Gwen::Colors::White ); - else - SetTextColor( Gwen::Colors::Black ); - } - - private: - - bool m_bSelected; - -}; - -GWEN_CONTROL_CONSTRUCTOR( ListBox ) -{ - m_ScrollControl = new ScrollControl( this ); - m_ScrollControl->Dock( Pos::Fill ); - m_ScrollControl->SetScroll( false, true ); - m_ScrollControl->SetAutoHideBars( true ); - m_ScrollControl->SetMargin( Margin( 1, 1, 1, 1 ) ); - - m_InnerPanel = m_ScrollControl; - - m_Table = new Controls::Layout::Table( this ); - m_Table->Dock( Pos::Top ); - m_Table->SetColumnCount( 1 ); - - m_bMultiSelect = false; -} - -void ListBox::OnChildBoundsChanged( Gwen::Rect /*oldChildBounds*/, Base* /*pChild*/ ) -{ - m_ScrollControl->UpdateScrollBars(); -} - -Layout::TableRow* ListBox::AddItem( const String& strLabel, const String& strName ) -{ - return AddItem( Utility::StringToUnicode( strLabel ), strName ); -} - -Layout::TableRow* ListBox::AddItem( const UnicodeString& strLabel, const String& strName ) -{ - ListBoxRow* pRow = new ListBoxRow( this ); - m_Table->AddRow( pRow ); - - pRow->SetCellText( 0, strLabel ); - pRow->SetName( strName ); - - pRow->onRowSelected.Add( this, &ListBox::OnRowSelected ); - - m_Table->SizeToContents(); - - return pRow; -} - -void ListBox::Render( Skin::Base* skin ) -{ - skin->DrawListBox( this ); -} - -void ListBox::UnselectAll() -{ - std::list::iterator it = m_SelectedRows.begin(); - while ( it != m_SelectedRows.end() ) - { - ListBoxRow* pRow = static_cast(*it); - it = m_SelectedRows.erase( it ); - - pRow->SetSelected( false ); - } -} - -void ListBox::OnRowSelected( Base* pControl ) -{ - ListBoxRow* pRow = static_cast(pControl); - - if ( !AllowMultiSelect() || !Gwen::Input::IsShiftDown() ) - { - UnselectAll(); - } - - m_SelectedRows.push_back( pRow ); - - onRowSelected.Call( this ); -} - -Layout::TableRow* ListBox::GetSelectedRow() -{ - if ( m_SelectedRows.empty() ) return NULL; - - return *m_SelectedRows.begin(); -} - -void ListBox::Clear() -{ - UnselectAll(); - m_Table->Clear(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ListBox.h b/btgui/Gwen/Controls/ListBox.h deleted file mode 100644 index c54ca62fd..000000000 --- a/btgui/Gwen/Controls/ListBox.h +++ /dev/null @@ -1,67 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_LISTBOX_H -#define GWEN_CONTROLS_LISTBOX_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Layout/Table.h" -#include "Gwen/Controls/ScrollControl.h" - - -namespace Gwen -{ - namespace Controls - { - class ScrollControl; - - class GWEN_EXPORT ListBox : public Base - { - public: - - GWEN_CONTROL( ListBox, Base ); - - typedef std::list Rows; - - Layout::TableRow* AddItem( const String& strLabel, const String& strName = "" ); - Layout::TableRow* AddItem( const UnicodeString& strLabel, const String& strName = "" ); - - void Render( Skin::Base* skin ); - - void UnselectAll(); - - void SetColumnCount( int iCount ) { m_Table->SetColumnCount( iCount ); } - - void SetAllowMultiSelect( bool bMultiSelect ){ m_bMultiSelect = bMultiSelect; } - bool AllowMultiSelect() const { return m_bMultiSelect; } - - const ListBox::Rows& GetSelectedRows(){ return m_SelectedRows; } - Layout::TableRow* GetSelectedRow(); - - Gwen::Controls::ScrollControl* Scroller() { return m_ScrollControl; } - - void OnChildBoundsChanged( Gwen::Rect oldChildBounds, Base* pChild ); - - Gwen::Event::Caller onRowSelected; - - Controls::Layout::Table* GetTable() { return m_Table; } - virtual void Clear(); - - protected: - - - void OnRowSelected( Base* pControl ); - - Controls::Layout::Table* m_Table; - ListBox::Rows m_SelectedRows; - Controls::ScrollControl* m_ScrollControl; - - bool m_bMultiSelect; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Menu.cpp b/btgui/Gwen/Controls/Menu.cpp deleted file mode 100644 index 989be4ef4..000000000 --- a/btgui/Gwen/Controls/Menu.cpp +++ /dev/null @@ -1,172 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Menu.h" -#include "Gwen/Skin.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - - - -GWEN_CONTROL_CONSTRUCTOR( Menu ) -{ - SetBounds( 0, 0, 10, 10 ); - SetPadding( Padding( 2, 2, 2, 2 ) ); - - SetDisableIconMargin( false ); - - SetAutoHideBars( true ); - SetScroll( false, true ); -} - - -void Menu::Render( Skin::Base* skin ) -{ - skin->DrawMenu( this, IconMarginDisabled() ); -} - -void Menu::RenderUnder( Skin::Base* skin ) -{ - BaseClass::RenderUnder( skin ); - skin->DrawShadow( this ); -} - -void Menu::Layout( Skin::Base* skin ) -{ - int childrenHeight = 0; - for ( Base::List::iterator it = m_InnerPanel->Children.begin(); it != m_InnerPanel->Children.end(); ++it ) - { - Base* pChild = (*it); - if ( !pChild ) - continue; - - childrenHeight += pChild->Height(); - } - - if ( Y() + childrenHeight > GetCanvas()->Height() ) - childrenHeight = GetCanvas()->Height() - Y(); - - SetSize( Width(), childrenHeight ); - - BaseClass::Layout( skin ); -} - -MenuItem* Menu::AddItem( const Gwen::UnicodeString& strName, const UnicodeString& strIconName, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::Function fn ) -{ - MenuItem* pItem = new MenuItem( this ); - pItem->SetText( strName ); - pItem->SetImage( strIconName ); - - if ( fn && pHandler ) - { - pItem->onMenuItemSelected.Add( pHandler, fn ); - } - - OnAddItem( pItem ); - - return pItem; -} - -void Menu::OnAddItem( MenuItem* item ) -{ - item->Dock( Pos::Top ); - item->SetTextPadding( Padding( IconMarginDisabled() ? 0 : 24, 0, 16, 0 ) ); - item->SetPadding( Padding( 4, 4, 4, 4 ) ); - item->SizeToContents(); - item->SetAlignment( Pos::CenterV | Pos::Left ); - item->onHoverEnter.Add( this, &Menu::OnHoverItem ); - - // Do this here - after Top Docking these values mean nothing in layout - int w = item->Width() + 10 + 32; - if ( w < Width() ) w = Width(); - SetSize( w, Height() ); -} - -void Menu::ClearItems() -{ - for ( Base::List::iterator it = m_InnerPanel->Children.begin(); it != m_InnerPanel->Children.end(); ++it ) - { - Base* pChild = *it; - - if ( !pChild ) continue; - pChild->DelayedDelete(); - } -} - -MenuItem* Menu::AddItem( const Gwen::String& strName, const String& strIconName, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::Function fn ) -{ - return AddItem( Gwen::Utility::StringToUnicode( strName ), Gwen::Utility::StringToUnicode( strIconName ), pHandler, fn ); -} - - -void Menu::CloseAll() -{ - for ( Base::List::iterator it = m_InnerPanel->Children.begin(); it != m_InnerPanel->Children.end(); ++it ) - { - Base* pChild = *it; - MenuItem* pItem = pChild->DynamicCastMenuItem(); - if ( !pItem ) continue; - - pItem->CloseMenu(); - } -} - -bool Menu::IsMenuOpen() -{ - for ( Base::List::iterator it = m_InnerPanel->Children.begin(); it != m_InnerPanel->Children.end(); ++it ) - { - Base* pChild = *it; - MenuItem* pItem = pChild->DynamicCastMenuItem(); - if ( !pItem ) continue; - - if ( pItem->IsMenuOpen() ) - return true; - } - - return false; -} - -void Menu::OnHoverItem( Gwen::Controls::Base* pControl ) -{ - if ( !ShouldHoverOpenMenu() ) return; - - MenuItem* pItem = pControl->DynamicCastMenuItem(); - if (!pItem) return; - if ( pItem->IsMenuOpen() ) return; - - CloseAll(); - pItem->OpenMenu(); -} - -void Menu::Close() -{ - SetHidden( true ); -} - -void Menu::CloseMenus() -{ - BaseClass::CloseMenus(); - - CloseAll(); - Close(); -} - -void Menu::AddDivider() -{ - MenuDivider* divider = new MenuDivider( this ); - divider->Dock( Pos::Top ); - divider->SetMargin( Margin( IconMarginDisabled() ? 0 : 24, 0, 4, 0 ) ); -} - -void MenuDivider::Render( Gwen::Skin::Base* skin ) -{ - skin->DrawMenuDivider( this ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Menu.h b/btgui/Gwen/Controls/Menu.h deleted file mode 100644 index 67e514dde..000000000 --- a/btgui/Gwen/Controls/Menu.h +++ /dev/null @@ -1,86 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_MENU_H -#define GWEN_CONTROLS_MENU_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/MenuItem.h" -#include "Gwen/Controls/ScrollControl.h" - -namespace Gwen -{ - namespace Controls - { - class MenuItem; - - class GWEN_EXPORT Menu : public ScrollControl - { - public: - - GWEN_CONTROL( Menu, ScrollControl ); - - virtual void Render( Skin::Base* skin ); - virtual void RenderUnder( Skin::Base* skin ); - - virtual void Layout( Skin::Base* skin ); - - virtual MenuItem* AddItem( const Gwen::UnicodeString& strName, const UnicodeString& strIconName, Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::Function fn = NULL ); - - virtual MenuItem* AddItem( const Gwen::UnicodeString& strName, Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::Function fn = NULL ) - { - return AddItem( strName, L"", pHandler, fn ); - } - - virtual MenuItem* AddItem( const Gwen::String& strName, const String& strIconName, Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::Function fn = NULL ); - - virtual MenuItem* AddItem( const Gwen::String& strName, Gwen::Event::Handler* pHandler = NULL, Gwen::Event::Handler::Function fn = NULL ) - { - return AddItem( strName, "", pHandler, fn ); - } - - virtual void AddDivider(); - - void OnHoverItem( Gwen::Controls::Base* pControl ); - void CloseAll(); - bool IsMenuOpen(); - void ClearItems(); - - virtual void Close(); - - virtual bool IsMenuComponent(){ return true; } - virtual void CloseMenus(); - - bool IconMarginDisabled() { return m_bDisableIconMargin; } - void SetDisableIconMargin( bool bDisable ) { m_bDisableIconMargin = bDisable; } - - virtual bool ShouldClip(){ return false; } - - protected: - - virtual bool ShouldHoverOpenMenu(){ return true; } - virtual void OnAddItem( MenuItem* item ); - - bool m_bDisableIconMargin; - }; - - class GWEN_EXPORT MenuDivider : public Base - { - public: - - GWEN_CONTROL_INLINE( MenuDivider, Base ) - { - SetHeight( 1 ); - } - - void Render( Gwen::Skin::Base* skin ); - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/MenuItem.cpp b/btgui/Gwen/Controls/MenuItem.cpp deleted file mode 100644 index 8eeeab6c2..000000000 --- a/btgui/Gwen/Controls/MenuItem.cpp +++ /dev/null @@ -1,137 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/MenuItem.h" -#include "Gwen/Skin.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( MenuItem ) -{ - m_Menu = NULL; - m_bOnStrip = false; - m_SubmenuArrow = NULL; - SetTabable( false ); - SetCheckable( false ); - SetCheck( false ); -} - -MenuItem::~MenuItem() -{ - -} - -void MenuItem::Render( Skin::Base* skin ) -{ - skin->DrawMenuItem( this, IsMenuOpen(), m_bCheckable ? m_bChecked : false ); -} - -void MenuItem::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - -} - -Menu* MenuItem::GetMenu() -{ - if ( !m_Menu ) - { - m_Menu = new Menu( GetCanvas() ); - m_Menu->SetHidden( true ); - - if ( !m_bOnStrip ) - { - m_SubmenuArrow = new Symbol::Arrow( this ); - m_SubmenuArrow->Dock( Pos::Right ); - m_SubmenuArrow->SetSize( 20, 20 ); - } - - Invalidate(); - } - - return m_Menu; -} - -void MenuItem::SetCheck( bool bCheck ) -{ - if ( bCheck == m_bChecked) - return; - - m_bChecked = bCheck; - - onCheckChange.Call( this ); - - if ( bCheck ) - onChecked.Call( this ); - else - onUnChecked.Call( this ); -} - -void MenuItem::OnPress() -{ - if ( m_Menu ) - { - ToggleMenu(); - } - else if ( !m_bOnStrip ) - { - SetCheck( !GetChecked() ); - onMenuItemSelected.Call( this ); - GetCanvas()->CloseMenus(); - } - - BaseClass::OnPress(); -} - -void MenuItem::ToggleMenu() -{ - if ( IsMenuOpen() ) CloseMenu(); - else OpenMenu(); -} - -bool MenuItem::IsMenuOpen() -{ - if ( !m_Menu ) return false; - - return !m_Menu->Hidden(); -} - -void MenuItem::OpenMenu() -{ - if ( !m_Menu ) return; - - m_Menu->SetHidden( false ); - m_Menu->BringToFront(); - - Gwen::Point p = LocalPosToCanvas( Gwen::Point( 0, 0 ) ); - - // Strip menus open downwards - if ( m_bOnStrip ) - { - m_Menu->SetPos( p.x, p.y + Height() + 1 ); - } - // Submenus open sidewards - else - { - m_Menu->SetPos( p.x + Width(), p.y); - } - - // TODO: Option this. - // TODO: Make sure on screen, open the other side of the - // parent if it's better... - - -} - -void MenuItem::CloseMenu() -{ - if ( !m_Menu ) return; - m_Menu->Close(); - m_Menu->CloseAll(); -} diff --git a/btgui/Gwen/Controls/MenuItem.h b/btgui/Gwen/Controls/MenuItem.h deleted file mode 100644 index df45a6466..000000000 --- a/btgui/Gwen/Controls/MenuItem.h +++ /dev/null @@ -1,69 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_MENUITEM_H -#define GWEN_CONTROLS_MENUITEM_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/Menu.h" -#include "Gwen/Controls/Symbol.h" - -namespace Gwen -{ - namespace Controls - { - class Menu; - - class GWEN_EXPORT MenuItem : public Button - { - public: - - GWEN_CONTROL( MenuItem, Button ); - - virtual ~MenuItem(); - - virtual void Render( Skin::Base* skin ); - virtual void Layout( Skin::Base* skin ); - - virtual void OnPress(); - - Menu* GetMenu(); - - bool IsMenuOpen(); - void OpenMenu(); - void CloseMenu(); - void ToggleMenu(); - - void SetOnStrip( bool b ){ m_bOnStrip = b;} - bool OnStrip(){ return m_bOnStrip; } - - virtual void SetCheckable( bool bCheck ) { m_bCheckable = bCheck; } - virtual void SetCheck( bool bCheck ); - virtual bool GetChecked() { return m_bChecked; } - - Gwen::Event::Caller onMenuItemSelected; - Gwen::Event::Caller onChecked; - Gwen::Event::Caller onUnChecked; - Gwen::Event::Caller onCheckChange; - - private: - - Menu* m_Menu; - bool m_bOnStrip; - bool m_bCheckable; - bool m_bChecked; - - - - Symbol::Arrow * m_SubmenuArrow; - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/MenuStrip.cpp b/btgui/Gwen/Controls/MenuStrip.cpp deleted file mode 100644 index 3c99511bf..000000000 --- a/btgui/Gwen/Controls/MenuStrip.cpp +++ /dev/null @@ -1,44 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/MenuStrip.h" -#include "Gwen/Skin.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( MenuStrip ) -{ - SetBounds( 0, 0, 200, 22 ); - Dock( Pos::Top ); - m_InnerPanel->SetPadding( Padding( 5, 2, 2, 2 ) ); -} - -void MenuStrip::Render( Skin::Base* skin ) -{ - skin->DrawMenuStrip( this ); -} - -void MenuStrip::Layout( Skin::Base* /*skin*/ ) -{ - //TODO: We don't want to do vertical sizing the same as Menu, do nothing for now -} - -void MenuStrip::OnAddItem( MenuItem* item ) -{ - item->Dock( Pos::Left ); - item->SetPadding( Padding( 5, 0, 5, 0 ) ); - item->SizeToContents(); - item->SetOnStrip( true ); - item->onHoverEnter.Add( this, &Menu::OnHoverItem ); -} - -bool MenuStrip::ShouldHoverOpenMenu() -{ - return IsMenuOpen(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/MenuStrip.h b/btgui/Gwen/Controls/MenuStrip.h deleted file mode 100644 index 57d03fdbe..000000000 --- a/btgui/Gwen/Controls/MenuStrip.h +++ /dev/null @@ -1,39 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_MENUSTRIP_H -#define GWEN_CONTROLS_MENUSTRIP_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Menu.h" -#include "Gwen/Controls/MenuItem.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT MenuStrip : public Menu - { - GWEN_CONTROL( MenuStrip, Menu ); - - virtual void Render( Skin::Base* skin ); - virtual void RenderUnder( Skin::Base* /*skin*/ ){} - virtual void Layout( Skin::Base* skin ); - - protected: - - virtual void OnAddItem( MenuItem* item ); - virtual bool ShouldHoverOpenMenu(); - virtual void Close() {} - - - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/Modal.h b/btgui/Gwen/Controls/Modal.h deleted file mode 100644 index d0c3081d3..000000000 --- a/btgui/Gwen/Controls/Modal.h +++ /dev/null @@ -1,37 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_MODAL_H -#define GWEN_CONTROLS_MODAL_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace ControlsInternal - { - class Modal : public Controls::Base - { - GWEN_CONTROL_INLINE( Modal, Controls::Base ) - { - SetKeyboardInputEnabled( true ); - SetMouseInputEnabled( true ); - SetShouldDrawBackground( true ); - } - - virtual void Layout( Skin::Base* /*skin*/ ) - { - SetBounds( 0, 0, GetCanvas()->Width(), GetCanvas()->Height() ); - } - - virtual void Render( Skin::Base* skin ) - { - if ( !ShouldDrawBackground() ) return; - - skin->DrawModalControl( this ); - } - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/NumericUpDown.cpp b/btgui/Gwen/Controls/NumericUpDown.cpp deleted file mode 100644 index 1e02016ae..000000000 --- a/btgui/Gwen/Controls/NumericUpDown.cpp +++ /dev/null @@ -1,117 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Utility.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/NumericUpDown.h" -#include "Gwen/Controls/Layout/Splitter.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - - -GWEN_CONTROL_CONSTRUCTOR( NumericUpDown ) -{ - SetSize( 100, 20 ); - - Layout::Splitter* pSplitter = new Layout::Splitter( this ); - pSplitter->Dock( Pos::Right ); - pSplitter->SetSize( 13, 13 ); - - NumericUpDownButton_Up* pButtonUp = new NumericUpDownButton_Up( pSplitter ); - pButtonUp->onPress.Add( this, &NumericUpDown::OnButtonUp ); - pButtonUp->SetTabable( false ); - - pSplitter->SetPanel( 0, pButtonUp ); - - - NumericUpDownButton_Down* pButtonDown = new NumericUpDownButton_Down( pSplitter ); - pButtonDown->onPress.Add( this, &NumericUpDown::OnButtonDown ); - pButtonDown->SetTabable( false ); - pButtonUp->SetPadding( Padding( 0, 1, 1, 0 ) ); - - pSplitter->SetPanel( 1, pButtonDown ); - - m_iMax = 100; - m_iMin = 0; - m_iNumber = 0; - SetText( "0" ); -} - -void NumericUpDown::OnButtonUp( Base* /*control*/ ) -{ - SyncNumberFromText(); - SetValue( m_iNumber + 1 ); -} - -void NumericUpDown::OnButtonDown( Base* /*control*/ ) -{ - SyncNumberFromText(); - SetValue( m_iNumber - 1 ); -} - - -void NumericUpDown::SyncTextFromNumber() -{ - SetText( Utility::ToString( m_iNumber ) ); -} - -void NumericUpDown::SyncNumberFromText() -{ - SetValue( (int) GetFloatFromText() ); -} - -void NumericUpDown::SetMin( int i ) -{ - m_iMin = i; -} - -void NumericUpDown::SetMax( int i ) -{ - m_iMax = i; -} - -void NumericUpDown::SetValue( int i ) -{ - if ( i > m_iMax ) i = m_iMax; - if ( i < m_iMin ) i = m_iMin; - - if ( m_iNumber == i ) - { - return; - } - - m_iNumber = i; - - // Don't update the text if we're typing in it.. - if ( !HasFocus() ) - { - SyncTextFromNumber(); - } - - OnChange(); -} - -void NumericUpDown::OnChange() -{ - onChanged.Call( this ); -} - -void NumericUpDown::OnTextChanged() -{ - BaseClass::OnTextChanged(); - - SyncNumberFromText(); -} - -void NumericUpDown::OnEnter() -{ - SyncNumberFromText(); - SyncTextFromNumber(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/NumericUpDown.h b/btgui/Gwen/Controls/NumericUpDown.h deleted file mode 100644 index b09b574cc..000000000 --- a/btgui/Gwen/Controls/NumericUpDown.h +++ /dev/null @@ -1,75 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_NUMERICUPDOWN_H -#define GWEN_CONTROLS_NUMERICUPDOWN_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/TextBox.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT NumericUpDownButton_Up : public Button - { - GWEN_CONTROL_INLINE( NumericUpDownButton_Up, Button ){} - - virtual void Render( Skin::Base* skin ) - { - skin->DrawNumericUpDownButton( this, m_bDepressed, true ); - } - }; - - class GWEN_EXPORT NumericUpDownButton_Down : public Button - { - GWEN_CONTROL_INLINE( NumericUpDownButton_Down, Button ){} - - virtual void Render( Skin::Base* skin ) - { - skin->DrawNumericUpDownButton( this, m_bDepressed, false ); - } - }; - - class GWEN_EXPORT NumericUpDown : public TextBoxNumeric - { - public: - - GWEN_CONTROL( NumericUpDown, TextBoxNumeric ); - - virtual void SetMin( int i ); - virtual void SetMax( int i ); - virtual void SetValue( int i ); - - Event::Caller onChanged; - - private: - - virtual void OnEnter(); - virtual void OnChange(); - virtual void OnTextChanged(); - - virtual void OnButtonUp( Base* control ); - virtual void OnButtonDown( Base* control ); - - virtual bool OnKeyUp( bool bDown ) { if ( bDown ) OnButtonUp( NULL ); return true; } - virtual bool OnKeyDown( bool bDown ){ if ( bDown ) OnButtonDown( NULL ); return true; } - - virtual void SyncTextFromNumber(); - virtual void SyncNumberFromText(); - - - - int m_iNumber; - int m_iMax; - int m_iMin; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/PanelListPanel.cpp b/btgui/Gwen/Controls/PanelListPanel.cpp deleted file mode 100644 index 017ebddac..000000000 --- a/btgui/Gwen/Controls/PanelListPanel.cpp +++ /dev/null @@ -1,124 +0,0 @@ - -#include "Gwen/Controls/PanelListPanel.h" - -using namespace Gwen; -using namespace Controls; - -GWEN_CONTROL_CONSTRUCTOR( PanelListPanel ) -{ - m_bVertical = false; - m_bSizeToChildren = true; - m_iControlSpacing = 5; - m_iLineSpacing = 5; - m_bWrapping = true; -} - -void PanelListPanel::Render( Gwen::Skin::Base* /*skin*/ ) -{ -} - -Gwen::Point PanelListPanel::GetBiggestChildSize() -{ - int width = 0; - int height = 0; - - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - Controls::Base* pChild = *it; - if ( pChild->Width() > width ) - width = pChild->Width(); - - if ( pChild->Height() > height ) - height = pChild->Height(); - } - - return Gwen::Point( width, height ); -} - -void PanelListPanel::DoVerticalLayout() -{ - int panelWidth = 0; - int panelX = GetPadding().left; - int panelY = GetPadding().top; - int lastPanelY = panelY; - int testWrap = 0; - - Gwen::Point childSize = GetBiggestChildSize(); - //Lay my children out accordingly - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - Controls::Base* pChild = *it; - testWrap = lastPanelY + m_iControlSpacing + childSize.y; - if ( m_bWrapping && testWrap > Height() - GetPadding().bottom ) - { - panelY = GetPadding().top; - panelX = GetPadding().left + panelWidth + m_iLineSpacing; - lastPanelY = panelY + m_iControlSpacing + childSize.y; - } - else - { - panelY = lastPanelY; - lastPanelY = testWrap; - } - - pChild->SetPos( panelX, panelY ); - - if (pChild->X() + childSize.x > panelWidth ) - panelWidth = pChild->X() + childSize.x; - } - - if ( m_bSizeToChildren ) - { - Gwen::Point childrenSizeTotal = ChildrenSize(); - SetSize( childrenSizeTotal.x, Height()); - } -} - -void PanelListPanel::DoHorizontalLayout() -{ - int panelHeight = 0; - int panelX = GetPadding().left; - int panelY = GetPadding().top; - int lastPanelX = panelX; - int testWrap = 0; - - Gwen::Point childSize = GetBiggestChildSize(); - - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - Controls::Base* pChild = *it; - - testWrap = lastPanelX + m_iControlSpacing + childSize.x; - if ( m_bWrapping && testWrap > Width() - GetPadding().right ) - { - panelX = GetPadding().left; - panelY = GetPadding().top + panelHeight + m_iLineSpacing; - lastPanelX = panelX + m_iControlSpacing + childSize.x; - } - else - { - panelX = lastPanelX; - lastPanelX = testWrap; - } - - pChild->SetPos( panelX, panelY ); - - if (pChild->Y() + childSize.y > panelHeight ) - panelHeight = pChild->Y() + childSize.y; - } - - if ( m_bSizeToChildren ) - { - Gwen::Point childrenSizeTotal = ChildrenSize(); - SetSize( Width(), childrenSizeTotal.y); - } -} - -void PanelListPanel::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - if ( IsHorizontalLayout() ) - DoHorizontalLayout(); - else - DoVerticalLayout(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/PanelListPanel.h b/btgui/Gwen/Controls/PanelListPanel.h deleted file mode 100644 index 27db1e75e..000000000 --- a/btgui/Gwen/Controls/PanelListPanel.h +++ /dev/null @@ -1,46 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_PANELLISTPANEL_H -#define GWEN_CONTROLS_PANELLISTPANEL_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT PanelListPanel : public Controls::Base - { - public: - - GWEN_CONTROL( PanelListPanel, Controls::Base ); - - void Render( Gwen::Skin::Base* skin ); - void Layout( Skin::Base* skin ); - - void DoHorizontalLayout(); - void DoVerticalLayout(); - - bool IsVerticalLayout() { return m_bVertical; } - bool IsHorizontalLayout() { return !m_bVertical; } - void SetVertical() { m_bVertical = true; Invalidate(); } - void SetHorizontal() { m_bVertical = false; Invalidate(); } - - void SetSizeToChildren( bool bShould ) { m_bSizeToChildren = bShould; } - void SetControlSpacing( int spacing ) { m_iControlSpacing = spacing; } - void SetLineSpacing( int spacing ) { m_iLineSpacing = spacing; } - void SetWrapping( bool wrap ) { m_bWrapping = wrap; } - - Gwen::Point GetBiggestChildSize(); - - protected: - - bool m_bVertical; - bool m_bSizeToChildren; - int m_iControlSpacing; - int m_iLineSpacing; - bool m_bWrapping; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ProgressBar.cpp b/btgui/Gwen/Controls/ProgressBar.cpp deleted file mode 100644 index 403b35942..000000000 --- a/btgui/Gwen/Controls/ProgressBar.cpp +++ /dev/null @@ -1,49 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollControl.h" -#include "Gwen/Controls/ProgressBar.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( ProgressBar ) -{ - SetMouseInputEnabled( true ); - SetBounds( Gwen::Rect( 0, 0, 128, 32 ) ); - SetTextPadding( Padding( 3, 3, 3, 3 ) ); - SetHorizontal(); - - SetAlignment( Gwen::Pos::Center ); - - m_fProgress = 0.0f; - m_bAutoLabel = true; -} - -void ProgressBar::SetValue(float val) -{ - if ( val < 0 ) - val = 0; - - if ( val > 1 ) - val = 1; - - m_fProgress = val; - - if ( m_bAutoLabel ) - { - int displayVal = m_fProgress * 100; - SetText( Utility::ToString( displayVal ) + "%" ); - } -} - -void ProgressBar::Render( Skin::Base* skin ) -{ - skin->DrawProgressBar( this, m_bHorizontal, m_fProgress); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ProgressBar.h b/btgui/Gwen/Controls/ProgressBar.h deleted file mode 100644 index 9d1bb94aa..000000000 --- a/btgui/Gwen/Controls/ProgressBar.h +++ /dev/null @@ -1,45 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_PROGRESSBAR_H -#define GWEN_CONTROLS_PROGRESSBAR_H -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT ProgressBar : public Label - { - public: - - GWEN_CONTROL( ProgressBar, Label ); - - virtual void Render( Skin::Base* skin ); - - virtual void SetVertical() { m_bHorizontal = false; } - virtual void SetHorizontal(){ m_bHorizontal = true; } - - virtual void SetValue( float val ); - virtual float GetValue() const { return m_fProgress; } - - virtual void SetAutoLabel( bool b ){ m_bAutoLabel = b; } - - protected: - - float m_fProgress; - - bool m_bHorizontal; - bool m_bAutoLabel; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Properties.cpp b/btgui/Gwen/Controls/Properties.cpp deleted file mode 100644 index e06b89374..000000000 --- a/btgui/Gwen/Controls/Properties.cpp +++ /dev/null @@ -1,125 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Properties.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( Properties ) -{ - m_SplitterBar = new SplitterBar( this ); - m_SplitterBar->SetPos( 80, 0 ); - m_SplitterBar->SetCursor( Gwen::CursorType::SizeWE ); - m_SplitterBar->onDragged.Add( this, &Properties::OnSplitterMoved ); - m_SplitterBar->SetShouldDrawBackground( false ); -} - -void Properties::PostLayout( Gwen::Skin::Base* /*skin*/ ) -{ - m_SplitterBar->SetHeight( 0 ); - - if ( SizeToChildren( false, true ) ) - { - InvalidateParent(); - } - - m_SplitterBar->SetSize( 3, Height() ); -} - -void Properties::OnSplitterMoved( Controls::Base * /*control*/ ) -{ - InvalidateChildren(); -} - -int Properties::GetSplitWidth() -{ - return m_SplitterBar->X(); -} - -PropertyRow* Properties::Add( const UnicodeString& text, const UnicodeString& value ) -{ - Property::Base* pProp = new Property::Text( this ); - pProp->SetPropertyValue( value ); - - return Add( text, pProp ); -} - -PropertyRow* Properties::Add( const String& text, const String& value ) -{ - return Add( Gwen::Utility::StringToUnicode( text ), Gwen::Utility::StringToUnicode( value ) ); -} - -PropertyRow* Properties::Add( const UnicodeString& text, Property::Base* pProp ) -{ - PropertyRow* row = new PropertyRow( this ); - row->Dock( Pos::Top ); - row->GetLabel()->SetText( text ); - row->SetProperty( pProp ); - - m_SplitterBar->BringToFront(); - return row; -} - -PropertyRow* Properties::Add( const String& text, Property::Base* pProp ) -{ - return Add( Gwen::Utility::StringToUnicode( text ), pProp ); -} - -void Properties::Clear() -{ - Base::List ChildListCopy = Children; - for ( Base::List::iterator it = ChildListCopy.begin(); it != ChildListCopy.end(); ++it ) - { - PropertyRow* row = (*it)->DynamicCastPropertyRow(); - if ( !row ) continue; - - row->DelayedDelete(); - } -} - - -GWEN_CONTROL_CONSTRUCTOR( PropertyRow ) -{ - m_Property = NULL; - - m_Label = new Label( this ); - m_Label->SetAlignment( Pos::CenterV | Pos::Left ); - m_Label->Dock( Pos::Left ); - m_Label->SetMargin( Margin( 2, 0, 0, 0 ) ); - - SetHeight( 16 ); -} - -void PropertyRow::Render( Gwen::Skin::Base* skin ) -{ - skin->DrawPropertyRow( this, m_Label->Right(), m_Property->IsEditing() ); -} - -void PropertyRow::Layout( Gwen::Skin::Base* /*skin*/ ) -{ - Properties* pParent = GetParent()->DynamicCastProperties(); - if ( !pParent ) return; - - m_Label->SetWidth( pParent->GetSplitWidth() ); -} - -void PropertyRow::SetProperty( Property::Base* prop ) -{ - m_Property = prop; - m_Property->SetParent( this ); - m_Property->Dock( Pos::Fill ); - m_Property->onChange.Add( this, &ThisClass::OnPropertyValueChanged ); -} - -void PropertyRow::OnPropertyValueChanged( Gwen::Controls::Base* /*control*/ ) -{ - onChange.Call( this ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Properties.h b/btgui/Gwen/Controls/Properties.h deleted file mode 100644 index c48dd0384..000000000 --- a/btgui/Gwen/Controls/Properties.h +++ /dev/null @@ -1,77 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_PROPERTIES_H -#define GWEN_CONTROLS_PROPERTIES_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/Property/BaseProperty.h" -#include "Gwen/Controls/Property/Text.h" -#include "Gwen/Controls/SplitterBar.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace Controls - { - - class PropertyRow; - - class GWEN_EXPORT Properties : public Base - { - public: - - GWEN_CONTROL( Properties, Base ); - - virtual void PostLayout( Gwen::Skin::Base* skin ); - - PropertyRow* Add( const UnicodeString& text, const UnicodeString& value = L"" ); - PropertyRow* Add( const String& text, const String& value = "" ); - PropertyRow* Add( const UnicodeString& text, Property::Base* pProp ); - PropertyRow* Add( const String& text, Property::Base* pProp ); - - virtual int GetSplitWidth(); - - virtual void Clear(); - - protected: - - virtual void OnSplitterMoved( Controls::Base * control ); - - Controls::SplitterBar* m_SplitterBar; - - }; - - class GWEN_EXPORT PropertyRow : public Base - { - public: - - GWEN_CONTROL( PropertyRow, Base ); - - virtual Label* GetLabel(){ return m_Label; } - virtual void SetProperty( Property::Base* prop ); - virtual Property::Base* GetProperty(){ return m_Property; } - - virtual void Layout( Gwen::Skin::Base* skin ); - virtual void Render( Gwen::Skin::Base* skin ); - - Event::Caller onChange; - - protected: - - void OnPropertyValueChanged( Gwen::Controls::Base* control ); - - Label* m_Label; - Property::Base* m_Property; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Property/BaseProperty.h b/btgui/Gwen/Controls/Property/BaseProperty.h deleted file mode 100644 index fb0ce900f..000000000 --- a/btgui/Gwen/Controls/Property/BaseProperty.h +++ /dev/null @@ -1,60 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_PROPERTY_BASEPROPERTY_H -#define GWEN_CONTROLS_PROPERTY_BASEPROPERTY_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Utility.h" - - -namespace Gwen -{ - namespace Controls - { - namespace Property - { - class GWEN_EXPORT Base : public Gwen::Controls::Base - { - public: - - GWEN_CONTROL_INLINE( Base, Gwen::Controls::Base ){} - - virtual String GetPropertyValueAnsi() - { - return Gwen::Utility::UnicodeToString( GetPropertyValue() ); - } - - virtual void SetPropertyValue( const String& v, bool bFireChangeEvents = false ) - { - SetPropertyValue( Gwen::Utility::StringToUnicode( v ), bFireChangeEvents ); - } - - virtual UnicodeString GetPropertyValue() = 0; - - virtual void SetPropertyValue( const UnicodeString& v, bool bFireChangeEvents = false ) = 0; - - virtual bool IsEditing() = 0; - - virtual void DoChanged() - { - onChange.Call( this ); - } - - virtual void OnPropertyValueChanged( Gwen::Controls::Base* /*control*/ ) - { - DoChanged(); - } - - Event::Caller onChange; - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/Property/ColorSelector.h b/btgui/Gwen/Controls/Property/ColorSelector.h deleted file mode 100644 index 5f6a78cad..000000000 --- a/btgui/Gwen/Controls/Property/ColorSelector.h +++ /dev/null @@ -1,80 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_PROPERTY_COLORSELECTOR_H -#define GWEN_CONTROLS_PROPERTY_COLORSELECTOR_H - -#include "Gwen/Controls/Properties.h" -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/HSVColorPicker.h" - -namespace Gwen -{ - namespace Controls - { - namespace Property - { - class ColorSelector : public Property::Text - { - public: - - GWEN_CONTROL_INLINE( ColorSelector, Property::Text ) - { - m_Button = new Button( this ); - m_Button->Dock( Pos::Right ); - m_Button->SetWidth( 20 ); - m_Button->onPress.Add( this, &ThisClass::OnButtonPress ); - } - - void OnButtonPress( Controls::Base* control ) - { - Gwen::Controls::WindowControl* wind = new Gwen::Controls::WindowControl( GetCanvas() ); - wind->SetTitle( L"Color Selection" ); - wind->SetSize( 256, 180 ); - wind->SetPos( GetCanvas()->Width() * 0.5 - 128, GetCanvas()->Height()* 0.5 - 128 ); - wind->SetDeleteOnClose( true ); - wind->DisableResizing(); - wind->MakeModal( true ); - - Gwen::Controls::HSVColorPicker* picker = new Gwen::Controls::HSVColorPicker( wind ); - picker->SetName( "picker" ); - - float defaultColor[3]; - Gwen::Utility::Strings::To::Floats( Gwen::Utility::UnicodeToString( m_TextBox->GetText() ), defaultColor, 3); - - picker->SetColor( Gwen::Color( defaultColor[0], defaultColor[1], defaultColor[2], 255 ), false, true ); - picker->onColorChanged.Add( this, &ThisClass::ColorChanged ); - } - - void ColorChanged( Controls::Base* control ) - { - Gwen::Controls::HSVColorPicker* picker = control->DynamicCastHSVColorPicker(); - - Gwen::String colorStr; - colorStr += Gwen::Utility::ToString( ( int )picker->GetColor().r ) + " "; - colorStr += Gwen::Utility::ToString( ( int )picker->GetColor().g ) + " "; - colorStr += Gwen::Utility::ToString( ( int )picker->GetColor().b ); - - m_TextBox->SetText( colorStr ); - DoChanged(); - } - - virtual UnicodeString GetPropertyValue() - { - return m_TextBox->GetText(); - } - - virtual void SetPropertyValue( const UnicodeString& v, bool bFireChangeEvents ) - { - m_TextBox->SetText( v, bFireChangeEvents ); - } - - virtual bool IsEditing() - { - return m_TextBox == Gwen::KeyboardFocus; - } - - Button* m_Button; - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/Property/Text.h b/btgui/Gwen/Controls/Property/Text.h deleted file mode 100644 index e02efe121..000000000 --- a/btgui/Gwen/Controls/Property/Text.h +++ /dev/null @@ -1,52 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_PROPERTY_TEXT_H -#define GWEN_CONTROLS_PROPERTY_TEXT_H - -#include "Gwen/Controls/Property/BaseProperty.h" -#include "Gwen/Controls/TextBox.h" - -namespace Gwen -{ - namespace Controls - { - namespace Property - { - class GWEN_EXPORT Text : public Property::Base - { - public: - - GWEN_CONTROL_INLINE( Text, Property::Base ) - { - m_TextBox = new TextBox( this ); - m_TextBox->Dock( Pos::Fill ); - m_TextBox->SetShouldDrawBackground( false ); - m_TextBox->onTextChanged.Add( this, &BaseClass::OnPropertyValueChanged ); - } - - virtual UnicodeString GetPropertyValue() - { - return m_TextBox->GetText(); - } - - virtual void SetPropertyValue( const UnicodeString& v, bool bFireChangeEvents ) - { - m_TextBox->SetText( v, bFireChangeEvents ); - } - - virtual bool IsEditing() - { - return m_TextBox->HasFocus(); - } - - TextBox* m_TextBox; - }; - } - } -} -#endif diff --git a/btgui/Gwen/Controls/PropertyTree.h b/btgui/Gwen/Controls/PropertyTree.h deleted file mode 100644 index 0465542b1..000000000 --- a/btgui/Gwen/Controls/PropertyTree.h +++ /dev/null @@ -1,62 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_PROPERTYTREE_H -#define GWEN_CONTROLS_PROPERTYTREE_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/TreeControl.h" -#include "Gwen/Controls/Properties.h" - - -namespace Gwen -{ - namespace Controls - { - class PropertyTreeNode : public TreeNode - { - public: - - GWEN_CONTROL_INLINE( PropertyTreeNode, TreeNode ) - { - } - - virtual void Render( Skin::Base* skin ) - { - skin->DrawPropertyTreeNode( this, m_InnerPanel->X(), m_InnerPanel->Y() ); - } - - }; - - class PropertyTree : public TreeControl - { - public: - - GWEN_CONTROL_INLINE( PropertyTree, TreeControl ) - { - - } - - Properties* Add( const UnicodeString& text ) - { - TreeNode* node = new PropertyTreeNode( this ); - node->SetText( text ); - node->Dock( Pos::Top ); - - Properties* props = new Properties( node ); - props->Dock( Pos::Top ); - - return props; - } - }; - - } -} -#endif diff --git a/btgui/Gwen/Controls/RadioButton.cpp b/btgui/Gwen/Controls/RadioButton.cpp deleted file mode 100644 index 1d923d8f4..000000000 --- a/btgui/Gwen/Controls/RadioButton.cpp +++ /dev/null @@ -1,24 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/RadioButton.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( RadioButton ) -{ - SetSize( 11, 11 ); - SetMouseInputEnabled( true ); - SetTabable( false ); -} - -void RadioButton::Render( Skin::Base* skin ) -{ - skin->DrawRadioButton( this, IsChecked(), IsDepressed() ); -} - diff --git a/btgui/Gwen/Controls/RadioButton.h b/btgui/Gwen/Controls/RadioButton.h deleted file mode 100644 index 90df7c09d..000000000 --- a/btgui/Gwen/Controls/RadioButton.h +++ /dev/null @@ -1,78 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_RADIOBUTTON_H -#define GWEN_CONTROLS_RADIOBUTTON_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/CheckBox.h" -#include "Gwen/Controls/LabelClickable.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT RadioButton : public CheckBox - { - GWEN_CONTROL( RadioButton, CheckBox ); - virtual void Render( Skin::Base* skin ); - - private: - - // From CheckBox - virtual bool AllowUncheck(){ return false; } - }; - - class GWEN_EXPORT LabeledRadioButton : public Base - { - public: - - GWEN_CONTROL_INLINE( LabeledRadioButton, Base ) - { - SetSize( 200, 19 ); - - m_RadioButton = new RadioButton( this ); - m_RadioButton->Dock( Pos::Left ); - m_RadioButton->SetMargin( Margin( 0, 4, 2, 4 ) ); - m_RadioButton->SetTabable( false ); - m_RadioButton->SetKeyboardInputEnabled( false ); - - m_Label = new LabelClickable( this ); - m_Label->SetAlignment( Pos::CenterV | Pos::Left ); - m_Label->SetText( "Radio Button" ); - m_Label->Dock( Pos::Fill ); - m_Label->onPress.Add( m_RadioButton, &CheckBox::ReceiveEventPress ); - m_Label->SetTabable( false ); - m_Label->SetKeyboardInputEnabled( false ); - } - - void RenderFocus( Gwen::Skin::Base* skin ) - { - if ( Gwen::KeyboardFocus != this ) return; - if ( !IsTabable() ) return; - - skin->DrawKeyboardHighlight( this, GetRenderBounds(), 0 ); - } - - virtual RadioButton* GetRadioButton() { return m_RadioButton; } - virtual LabelClickable* GetLabel(){ return m_Label; } - virtual bool OnKeySpace(bool bDown) { if ( bDown ) m_RadioButton->SetChecked( !m_RadioButton->IsChecked() ); return true; } - - virtual void Select(){ m_RadioButton->SetChecked( true ); } - - private: - - RadioButton* m_RadioButton; - LabelClickable* m_Label; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/RadioButtonController.cpp b/btgui/Gwen/Controls/RadioButtonController.cpp deleted file mode 100644 index c1825fd96..000000000 --- a/btgui/Gwen/Controls/RadioButtonController.cpp +++ /dev/null @@ -1,74 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/RadioButtonController.h" -#include "Gwen/Controls/RadioButton.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( RadioButtonController ) -{ - m_Selected = NULL; - SetTabable( false ); - SetKeyboardInputEnabled( false ); -} - -void RadioButtonController::OnRadioClicked( Gwen::Controls::Base* pFromPanel ) -{ - RadioButton* pCheckedRadioButton = pFromPanel->DynamicCastRadioButton(); - - //Iterate through all other buttons and set them to false; - for (Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter) - { - Base* pChild = *iter; - LabeledRadioButton* pLRB = pChild->DynamicCastLabeledRadioButton(); - if ( pLRB ) - { - RadioButton* pChildRadioButton = pLRB->GetRadioButton(); - if ( pChildRadioButton == pCheckedRadioButton ) - { - m_Selected = pLRB; - } - else - { - pLRB->GetRadioButton()->SetChecked( false ); - } - } - } - - OnChange(); -} - -void RadioButtonController::OnChange() -{ - onSelectionChange.Call( this ); -} - -LabeledRadioButton* RadioButtonController::AddOption( const Gwen::String& strText, const Gwen::String& strOptionName ) -{ - return AddOption( Gwen::Utility::StringToUnicode( strText ), strOptionName ); -} - -LabeledRadioButton* RadioButtonController::AddOption( const Gwen::UnicodeString& strText, const Gwen::String& strOptionName ) -{ - LabeledRadioButton* lrb = new LabeledRadioButton( this ); - - lrb->SetName( strOptionName ); - lrb->GetLabel()->SetText( strText ); - lrb->GetRadioButton()->onChecked.Add( this, &RadioButtonController::OnRadioClicked ); - lrb->Dock( Pos::Top ); - lrb->SetMargin( Margin( 0, 1, 0, 1 ) ); - lrb->SetKeyboardInputEnabled( false ); - lrb->SetTabable( false ); - - Invalidate(); - - return lrb; -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/RadioButtonController.h b/btgui/Gwen/Controls/RadioButtonController.h deleted file mode 100644 index 82581d219..000000000 --- a/btgui/Gwen/Controls/RadioButtonController.h +++ /dev/null @@ -1,48 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_RADIOBOTTONCONTROLLER_H -#define GWEN_CONTROLS_RADIOBOTTONCONTROLLER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/RadioButton.h" - - -namespace Gwen -{ - namespace Controls - { - - class GWEN_EXPORT RadioButtonController : public Base - { - public: - - GWEN_CONTROL( RadioButtonController, Base ); - - virtual void Render( Skin::Base* /*skin*/ ){}; - virtual void OnRadioClicked( Base* pFromPanel ); - - virtual void OnChange(); - - virtual LabeledRadioButton* AddOption( const Gwen::String& strText, const Gwen::String& strOptionName = "" ); - virtual LabeledRadioButton* AddOption( const Gwen::UnicodeString& strText, const Gwen::String& strOptionName = "" ); - - virtual LabeledRadioButton* GetSelected(){ return m_Selected; } - - virtual String GetSelectedName(){ return m_Selected->GetName(); } - virtual UnicodeString GetSelectedLabel(){ return m_Selected->GetLabel()->GetText(); } - - Event::Caller onSelectionChange; - - private: - - LabeledRadioButton* m_Selected; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ResizableControl.cpp b/btgui/Gwen/Controls/ResizableControl.cpp deleted file mode 100644 index a02b5c1f7..000000000 --- a/btgui/Gwen/Controls/ResizableControl.cpp +++ /dev/null @@ -1,110 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ImagePanel.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/Resizer.h" -#include "Gwen/Controls/ResizableControl.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -GWEN_CONTROL_CONSTRUCTOR( ResizableControl ) -{ - m_bResizable = true; - m_MinimumSize = Gwen::Point( 5, 5 ); - m_bClampMovement = false; - - Resizer* resizerBottom = new Resizer (this ); - resizerBottom->Dock( Pos::Bottom ); - resizerBottom->SetResizeDir( Pos::Bottom ); - resizerBottom->SetTarget( this ); - resizerBottom->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerBottomLeft = new Resizer( resizerBottom ); - resizerBottomLeft->Dock( Pos::Left ); - resizerBottomLeft->SetResizeDir( Pos::Bottom | Pos::Left ); - resizerBottomLeft->SetTarget(this ); - resizerBottomLeft->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerBottomRight = new Resizer( resizerBottom ); - resizerBottomRight->Dock( Pos::Right); - resizerBottomRight->SetResizeDir( Pos::Bottom | Pos::Right ); - resizerBottomRight->SetTarget( this ); - resizerBottomRight->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerTop = new Resizer( this ); - resizerTop->Dock( Pos::Top ); - resizerTop->SetResizeDir( Pos::Top ); - resizerTop->SetTarget( this ); - resizerTop->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerTopLeft = new Resizer( resizerTop ); - resizerTopLeft->Dock( Pos::Left ); - resizerTopLeft->SetResizeDir( Pos::Top | Pos::Left ); - resizerTopLeft->SetTarget( this ); - resizerTopLeft->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerTopRight = new Resizer( resizerTop ); - resizerTopRight->Dock( Pos::Right ); - resizerTopRight->SetResizeDir( Pos::Top| Pos::Right ); - resizerTopRight->SetTarget( this ); - resizerTopRight->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerLeft = new Resizer( this ); - resizerLeft->Dock( Pos::Left ); - resizerLeft->SetResizeDir( Pos::Left ); - resizerLeft->SetTarget( this ); - resizerLeft->onResize.Add( this, &ResizableControl::OnResizedInternal ); - - Resizer* resizerRight = new Resizer( this ); - resizerRight->Dock( Pos::Right ); - resizerRight->SetResizeDir( Pos::Right ); - resizerRight->SetTarget( this ); - resizerRight->onResize.Add( this, &ResizableControl::OnResizedInternal ); -} - -void ResizableControl::DisableResizing() -{ - for ( Base::List::iterator it = Children.begin(); it != Children.end(); ++it ) - { - Resizer* resizer = (*it)->DynamicCastResizer(); - if ( !resizer ) continue; - - resizer->SetMouseInputEnabled( false ); - resizer->SetHidden( true ); - SetPadding( Padding( resizer->Width(), resizer->Width(), resizer->Width(), resizer->Width() ) ); - } -} - -bool ResizableControl::SetBounds( int x, int y, int w, int h ) -{ - Gwen::Point minSize = GetMinimumSize(); - - // Clamp Minimum Size - if ( w < minSize.x ) w = minSize.x; - if ( h < minSize.y ) h = minSize.y; - - // Clamp to parent's window - Base* pParent = GetParent(); - if ( pParent && m_bClampMovement ) - { - if ( x + w > pParent->Width() ) x = pParent->Width() - w; - if ( x < 0 ) x = 0; - if ( y + h > pParent->Height() ) y = pParent->Height() - h; - if ( y < 0 ) y = 0; - } - - return BaseClass::SetBounds( x, y, w, h ); -} - -void ResizableControl::OnResizedInternal( Controls::Base* /*pControl*/ ) -{ - onResize.Call( this ); - OnResized(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ResizableControl.h b/btgui/Gwen/Controls/ResizableControl.h deleted file mode 100644 index c2c5b7648..000000000 --- a/btgui/Gwen/Controls/ResizableControl.h +++ /dev/null @@ -1,55 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_RESIZABLECONTROL_H -#define GWEN_CONTROLS_RESIZABLECONTROL_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT ResizableControl : public Base - { - public: - - GWEN_CONTROL( ResizableControl, Base ); - - virtual void SetClampMovement( bool shouldClamp ) { m_bClampMovement = shouldClamp; } - virtual bool GetClampMovement() { return m_bClampMovement; } - - virtual void SetMinimumSize( const Gwen::Point& minSize ) { m_MinimumSize = minSize; } - virtual Gwen::Point GetMinimumSize() { return m_MinimumSize; } - - virtual void DisableResizing(); - - virtual bool SetBounds( int x, int y, int w, int h ); - - virtual void OnResized(){}; - - Event::Caller onResize; - - protected: - - void OnResizedInternal( Controls::Base* pControl ); - - Gwen::Point m_MinimumSize; - bool m_bClampMovement; - bool m_bResizable; - - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Resizer.cpp b/btgui/Gwen/Controls/Resizer.cpp deleted file mode 100644 index b3506f849..000000000 --- a/btgui/Gwen/Controls/Resizer.cpp +++ /dev/null @@ -1,120 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/Resizer.h" - -using namespace Gwen; -using namespace Gwen::ControlsInternal; - - -GWEN_CONTROL_CONSTRUCTOR( Resizer ) -{ - m_iResizeDir = Pos::Left; - SetMouseInputEnabled( true ); - SetSize( 6, 6 ); -} - -void Resizer::OnMouseMoved( int x, int y, int /*deltaX*/, int /*deltaY*/ ) -{ - if ( !m_pTarget ) return; - if ( !m_bDepressed ) return; - -// Gwen::Rect oldBounds = m_pTarget->GetBounds(); - Gwen::Rect pBounds = m_pTarget->GetBounds(); - - Gwen::Point pntMin = m_pTarget->GetMinimumSize(); - - Gwen::Point pCursorPos = m_pTarget->CanvasPosToLocal( Gwen::Point( x, y ) ); - - Gwen::Point pDelta = m_pTarget->LocalPosToCanvas( m_HoldPos ); - pDelta.x -= x; - pDelta.y -= y; - - if ( m_iResizeDir & Pos::Left ) - { - pBounds.x -= pDelta.x; - pBounds.w += pDelta.x; - - // Conform to minimum size here so we don't - // go all weird when we snap it in the base conrt - - if ( pBounds.w < pntMin.x ) - { - int diff = pntMin.x - pBounds.w; - pBounds.w += diff; - pBounds.x -= diff; - } - - } - - if ( m_iResizeDir & Pos::Top ) - { - pBounds.y -= pDelta.y; - pBounds.h += pDelta.y; - - // Conform to minimum size here so we don't - // go all weird when we snap it in the base conrt - - if ( pBounds.h < pntMin.y ) - { - int diff = pntMin.y - pBounds.h; - pBounds.h += diff; - pBounds.y -= diff; - } - - } - - if ( m_iResizeDir & Pos::Right ) - { - // This is complicated. - // Basically we want to use the HoldPos, so it doesn't snap to the edge of the control - // But we need to move the HoldPos with the window movement. Yikes. - // I actually think this might be a big hack around the way this control works with regards - // to the holdpos being on the parent panel. - - int woff = pBounds.w - m_HoldPos.x; - int diff = pBounds.w; - pBounds.w = pCursorPos.x + woff; - if ( pBounds.w < pntMin.x ) pBounds.w = pntMin.x; - diff -= pBounds.w; - - m_HoldPos.x -= diff; - } - - if ( m_iResizeDir & Pos::Bottom ) - { - int hoff = pBounds.h - m_HoldPos.y; - int diff = pBounds.h; - pBounds.h = pCursorPos.y + hoff; - if ( pBounds.h < pntMin.y ) pBounds.h = pntMin.y; - diff -= pBounds.h; - - m_HoldPos.y -= diff; - } - - m_pTarget->SetBounds( pBounds ); - - onResize.Call( this ); -} - -void Resizer::SetResizeDir( int dir ) -{ - m_iResizeDir = dir; - - if ( (dir & Pos::Left && dir & Pos::Top) || (dir & Pos::Right && dir & Pos::Bottom) ) - return SetCursor( Gwen::CursorType::SizeNWSE ); - - if ( (dir & Pos::Right && dir & Pos::Top) || (dir & Pos::Left && dir & Pos::Bottom) ) - return SetCursor( Gwen::CursorType::SizeNESW ); - - if ( dir & Pos::Right || dir & Pos::Left ) - return SetCursor( Gwen::CursorType::SizeWE ); - - if ( dir & Pos::Top || dir & Pos::Bottom ) - return SetCursor( Gwen::CursorType::SizeNS ); - -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Resizer.h b/btgui/Gwen/Controls/Resizer.h deleted file mode 100644 index 30281bee6..000000000 --- a/btgui/Gwen/Controls/Resizer.h +++ /dev/null @@ -1,39 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_RESIZER_H -#define GWEN_CONTROLS_RESIZER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Dragger.h" - - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT Resizer : public Dragger - { - public: - - GWEN_CONTROL( Resizer, Dragger ); - - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - virtual void SetResizeDir( int dir ); - - Event::Caller onResize; - - protected: - - int m_iResizeDir; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/RichLabel.cpp b/btgui/Gwen/Controls/RichLabel.cpp deleted file mode 100644 index 0c3468c34..000000000 --- a/btgui/Gwen/Controls/RichLabel.cpp +++ /dev/null @@ -1,209 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/RichLabel.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -const unsigned char Type_Text = 0; -const unsigned char Type_Newline = 1; - -GWEN_CONTROL_CONSTRUCTOR( RichLabel ) -{ - m_bNeedsRebuild = false; -} - -void RichLabel::AddLineBreak() -{ - DividedText t; - t.type = Type_Newline; - - m_TextBlocks.push_back( t ); -} - -void RichLabel::AddText( const Gwen::TextObject& text, Gwen::Color color, Gwen::Font* font ) -{ - if ( text.m_Data.size() == 0 ) return; - - Gwen::Utility::Strings::UnicodeList lst; - Gwen::Utility::Strings::Split( text.GetUnicode(), L"\n", lst, false ); - - for (size_t i=0; i 0 ) AddLineBreak(); - - DividedText t; - t.type = Type_Text; - t.text = lst[i]; - t.color = color; - t.font = font; - - m_TextBlocks.push_back( t ); - m_bNeedsRebuild = true; - Invalidate(); - } -} - -bool RichLabel::SizeToChildren( bool w, bool h ) -{ - Rebuild(); - return BaseClass::SizeToChildren( w, h ); -} - -void RichLabel::SplitLabel( const Gwen::UnicodeString& text, Gwen::Font* pFont, const DividedText& txt, int& x, int& y, int& lineheight ) -{ - Gwen::Utility::Strings::UnicodeList lst; - Gwen::Utility::Strings::Split( text, L" ", lst, true ); - if ( lst.size() == 0 ) return; - - int iSpaceLeft = Width() - x; - - // Does the whole word fit in? - { - Gwen::Point StringSize = GetSkin()->GetRender()->MeasureText( pFont, text ); - if ( iSpaceLeft > StringSize.x ) - { - return CreateLabel( text, txt, x, y, lineheight, true ); - } - } - - // If the first word is bigger than the line, just give up. - { - Gwen::Point WordSize = GetSkin()->GetRender()->MeasureText( pFont, lst[0] ); - if ( WordSize.x >= iSpaceLeft ) - { - CreateLabel( lst[0], txt, x, y, lineheight, true ); - if ( lst[0].size() >= text.size() ) return; - - Gwen::UnicodeString LeftOver = text.substr( lst[0].size() + 1 ); - return SplitLabel( LeftOver, pFont, txt, x, y, lineheight ); - } - } - - Gwen::UnicodeString strNewString = L""; - for ( size_t i=0; iGetRender()->MeasureText( pFont, strNewString + lst[i] ); - if ( WordSize.x > iSpaceLeft ) - { - CreateLabel( strNewString, txt, x, y, lineheight, true ); - x = 0; - y += lineheight; - break;; - } - - strNewString += lst[i]; - } - - Gwen::UnicodeString LeftOver = text.substr( strNewString.size() + 1 ); - return SplitLabel( LeftOver, pFont, txt, x, y, lineheight ); -} - -void RichLabel::CreateLabel( const Gwen::UnicodeString& text, const DividedText& txt, int& x, int& y, int& lineheight, bool NoSplit ) -{ - - // - // Use default font or is one set? - // - Gwen::Font* pFont = GetSkin()->GetDefaultFont(); - if ( txt.font ) pFont = txt.font; - - // - // This string is too long for us, split it up. - // - Gwen::Point p = GetSkin()->GetRender()->MeasureText( pFont, text ); - - if ( lineheight == -1 ) - { - lineheight = p.y; - } - - if ( !NoSplit ) - { - if ( x + p.x > Width() ) - { - return SplitLabel( text, pFont, txt, x, y, lineheight ); - } - } - - // - // Wrap - // - if ( x + p.x >= Width() ) - { - CreateNewline( x, y, lineheight ); - } - - Gwen::Controls::Label* pLabel = new Gwen::Controls::Label( this ); - pLabel->SetText( x == 0 ? Gwen::Utility::Strings::TrimLeft( text, L" " ) : text ); - pLabel->SetTextColor( txt.color ); - pLabel->SetFont( pFont ); - pLabel->SizeToContents(); - pLabel->SetPos( x, y ); - - //lineheight = (lineheight + pLabel->Height()) / 2; - - x += pLabel->Width(); - - if ( x >= Width() ) - { - CreateNewline( x, y, lineheight ); - } -} - -void RichLabel::CreateNewline( int& x, int& y, int& lineheight ) -{ - x = 0; - y += lineheight; -} - -void RichLabel::Rebuild() -{ - RemoveAllChildren(); - - int x = 0; - int y = 0; - int lineheight = -1; - for ( DividedText::List::iterator it = m_TextBlocks.begin(); it != m_TextBlocks.end(); ++it ) - { - if ( it->type == Type_Newline ) - { - CreateNewline( x, y, lineheight ); - continue; - } - - if ( it->type == Type_Text ) - { - CreateLabel( (*it).text, *it, x, y, lineheight, false ); - continue; - } - - } - - m_bNeedsRebuild = false; -} - -void RichLabel::OnBoundsChanged( Gwen::Rect oldBounds ) -{ - BaseClass::OnBoundsChanged( oldBounds ); - - Rebuild(); -} - -void RichLabel::Layout( Gwen::Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - - if ( m_bNeedsRebuild ) - { - Rebuild(); - } -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/RichLabel.h b/btgui/Gwen/Controls/RichLabel.h deleted file mode 100644 index 12c8f4275..000000000 --- a/btgui/Gwen/Controls/RichLabel.h +++ /dev/null @@ -1,62 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_RICHLABEL_H -#define GWEN_CONTROLS_RICHLABEL_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Text.h" -#include "Gwen/TextObject.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT RichLabel : public Controls::Base - { - public: - - GWEN_CONTROL( RichLabel, Gwen::Controls::Base ); - - void AddLineBreak(); - void AddText( const Gwen::TextObject& text, Gwen::Color color, Gwen::Font* font = NULL ); - - virtual bool SizeToChildren( bool w = true, bool h = true ); - - protected: - - struct DividedText - { - typedef std::list List; - DividedText() - { - type = 0; - font = NULL; - } - - unsigned char type; - Gwen::UnicodeString text; - Gwen::Color color; - Gwen::Font* font; - }; - - void Layout( Gwen::Skin::Base* skin ); - void SplitLabel( const Gwen::UnicodeString& text, Gwen::Font* pFont, const DividedText& txt, int& x, int& y, int& lineheight ); - void CreateNewline( int& x, int& y, int& lineheight ); - void CreateLabel( const Gwen::UnicodeString& text, const DividedText& txt, int& x, int& y, int& lineheight, bool NoSplit ); - void Rebuild(); - - void OnBoundsChanged( Gwen::Rect oldBounds ); - - DividedText::List m_TextBlocks; - bool m_bNeedsRebuild; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ScrollBar.cpp b/btgui/Gwen/Controls/ScrollBar.cpp deleted file mode 100644 index cf3cb0216..000000000 --- a/btgui/Gwen/Controls/ScrollBar.cpp +++ /dev/null @@ -1,83 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/ScrollBarButton.h" -#include "Gwen/Controls/ScrollBarBar.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - - -GWEN_CONTROL_CONSTRUCTOR( BaseScrollBar ) -{ - for (int i = 0; i < 2; i++) - { - m_ScrollButton[i] = new ScrollBarButton( this ); - } - - m_Bar = new ScrollBarBar( this ); - - SetBounds( 0, 0, 15, 15 ); - m_bDepressed = false; - - m_fScrolledAmount = 0; - m_fContentSize = 0; - m_fViewableContentSize = 0; - - SetNudgeAmount( 20 ); -} - -void BaseScrollBar::Render( Skin::Base* skin ) -{ - skin->DrawScrollBar( this, false, m_bDepressed ); -} - -void BaseScrollBar::OnBarMoved( Controls::Base* /*control*/ ) -{ - onBarMoved.Call( this ); -} - -void BaseScrollBar::BarMovedNotification() -{ - OnBarMoved( this ); -} - -void BaseScrollBar::SetContentSize( float size ) -{ - if ( m_fContentSize != size ) - { - Invalidate(); - } - - m_fContentSize = size; - -} -void BaseScrollBar::SetViewableContentSize( float size ) -{ - if ( m_fViewableContentSize != size ) - Invalidate(); - - m_fViewableContentSize = size; -} - -bool BaseScrollBar::SetScrolledAmount( float amount, bool /*forceUpdate*/ ) -{ - if ( m_fScrolledAmount == amount ) return false; - - m_fScrolledAmount = amount; - Invalidate(); - BarMovedNotification(); - return true; -} - - - - - - diff --git a/btgui/Gwen/Controls/ScrollBar.h b/btgui/Gwen/Controls/ScrollBar.h deleted file mode 100644 index a0cd02c42..000000000 --- a/btgui/Gwen/Controls/ScrollBar.h +++ /dev/null @@ -1,87 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_SCROLLBAR_H -#define GWEN_CONTROLS_SCROLLBAR_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/ScrollBarBar.h" -#include "Gwen/Controls/ScrollBarButton.h" -#include "Gwen/Gwen.h" - - -#define SCROLL_BUTTON_UP 0 -#define SCROLL_BUTTON_LEFT 0 -#define SCROLL_BUTTON_DOWN 1 -#define SCROLL_BUTTON_RIGHT 1 -#define NUDGE_DIST 10 - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT BaseScrollBar : public Base - { - public: - - GWEN_CONTROL( BaseScrollBar, Base ); - - virtual void Render( Skin::Base* skin ); - - virtual void SetBarSize(int size) = 0; - virtual int GetBarSize() = 0; - virtual int GetBarPos() = 0; - - virtual void OnBarMoved( Controls::Base* control); - virtual void OnMouseClickLeft( int /*x*/, int /*y*/, bool /*bDown*/ ){} - - virtual void ScrollToLeft(){} - virtual void ScrollToRight(){} - virtual void ScrollToTop(){} - virtual void ScrollToBottom(){} - - virtual float GetNudgeAmount() { return m_fNudgeAmount / m_fContentSize; } - virtual void SetNudgeAmount( float nudge ) { m_fNudgeAmount = nudge; } - - virtual void BarMovedNotification(); - - virtual float CalculateScrolledAmount() { return 0; } - virtual int CalculateBarSize() { return 0; } - virtual bool SetScrolledAmount(float amount, bool forceUpdate); - - virtual void SetContentSize(float size); - virtual void SetViewableContentSize(float size); - - virtual int GetButtonSize() { return 0; } - virtual float GetScrolledAmount() { return m_fScrolledAmount; } - - Gwen::Event::Caller onBarMoved; - - float getContentSize() - { - return m_fContentSize; - } - float getViewableContentSize() const - { - - return m_fViewableContentSize; - } - - protected: - - ControlsInternal::ScrollBarButton* m_ScrollButton[2]; - ControlsInternal::ScrollBarBar * m_Bar; - - bool m_bDepressed; - float m_fScrolledAmount; - float m_fContentSize; - float m_fViewableContentSize; - float m_fNudgeAmount; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ScrollBarBar.cpp b/btgui/Gwen/Controls/ScrollBarBar.cpp deleted file mode 100644 index cad1f88e7..000000000 --- a/btgui/Gwen/Controls/ScrollBarBar.cpp +++ /dev/null @@ -1,57 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/ScrollBarBar.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -//Actual bar representing height of parent - -GWEN_CONTROL_CONSTRUCTOR( ScrollBarBar ) -{ - RestrictToParent( true ); - SetTarget( this ); -} - -void ScrollBarBar::Render( Skin::Base* skin ) -{ - skin->DrawScrollBarBar(this, m_bDepressed, IsHovered(), m_bHorizontal ); - BaseClass::Render( skin ); -} - -void ScrollBarBar::OnMouseMoved( int x, int y, int deltaX, int deltaY ) -{ - BaseClass::OnMouseMoved( x, y, deltaX, deltaY ); - - if ( !m_bDepressed ) - return; - - InvalidateParent(); -} - -void ScrollBarBar::OnMouseClickLeft( int x, int y, bool bDown ) -{ - BaseClass::OnMouseClickLeft( x, y, bDown ); - InvalidateParent(); -} - -void ScrollBarBar::Layout( Skin::Base* /*skin*/ ) -{ - if ( !GetParent() ) - return; - - //Move to our current position to force clamping - is this a hack? - MoveTo( X(), Y() ); -} - -void ScrollBarBar::MoveTo( int x, int y ) -{ - BaseClass::MoveTo( x, y ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ScrollBarBar.h b/btgui/Gwen/Controls/ScrollBarBar.h deleted file mode 100644 index 9bcf0a203..000000000 --- a/btgui/Gwen/Controls/ScrollBarBar.h +++ /dev/null @@ -1,46 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_SCROLLBARBAR_H -#define GWEN_CONTROLS_SCROLLBARBAR_H - -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT ScrollBarBar : public ControlsInternal::Dragger - { - public: - - GWEN_CONTROL( ScrollBarBar, ControlsInternal::Dragger ); - - virtual void Render( Skin::Base* skin ); - virtual void Layout( Skin::Base* skin ); - - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - - virtual void MoveTo(int x, int y); - - virtual void SetHorizontal() { m_bHorizontal = true; } - virtual void SetVertical() { m_bHorizontal = false; } - virtual bool IsVertical() { return !m_bHorizontal; } - virtual bool IsHorizontal() { return m_bHorizontal; } - virtual bool IsDepressed() { return m_bDepressed; } - - protected: - - bool m_bHorizontal; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ScrollBarButton.cpp b/btgui/Gwen/Controls/ScrollBarButton.cpp deleted file mode 100644 index f65727237..000000000 --- a/btgui/Gwen/Controls/ScrollBarButton.cpp +++ /dev/null @@ -1,45 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/ScrollBarButton.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - - -GWEN_CONTROL_CONSTRUCTOR( ScrollBarButton ) -{ - m_iDirection = 0; - SetBounds(0,0,0,0); -} - -void ScrollBarButton::SetDirectionUp() -{ - m_iDirection = Pos::Top; -} - -void ScrollBarButton::SetDirectionDown() -{ - m_iDirection = Pos::Bottom; -} - -void ScrollBarButton::SetDirectionLeft() -{ - m_iDirection = Pos::Left; -} - -void ScrollBarButton::SetDirectionRight() -{ - m_iDirection = Pos::Right; -} - -void ScrollBarButton::Render( Skin::Base* skin ) -{ - skin->DrawScrollButton( this, m_iDirection, m_bDepressed ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ScrollBarButton.h b/btgui/Gwen/Controls/ScrollBarButton.h deleted file mode 100644 index 78c924682..000000000 --- a/btgui/Gwen/Controls/ScrollBarButton.h +++ /dev/null @@ -1,36 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_SCROLLBARBOTTON_H -#define GWEN_CONTROLS_SCROLLBARBOTTON_H - -#include "Gwen/Controls/Button.h" - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT ScrollBarButton : public Controls::Button - { - public: - - GWEN_CONTROL( ScrollBarButton, Controls::Button ); - - void Render( Skin::Base* skin ); - - void SetDirectionUp(); - void SetDirectionDown(); - void SetDirectionLeft(); - void SetDirectionRight(); - - protected: - - int m_iDirection; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/ScrollControl.cpp b/btgui/Gwen/Controls/ScrollControl.cpp deleted file mode 100644 index 4a0a95231..000000000 --- a/btgui/Gwen/Controls/ScrollControl.cpp +++ /dev/null @@ -1,248 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollControl.h" -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/VerticalScrollBar.h" -#include "Gwen/Controls/HorizontalScrollBar.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -GWEN_CONTROL_CONSTRUCTOR( ScrollControl ) -{ - SetMouseInputEnabled( false ); - - m_VerticalScrollBar = new VerticalScrollBar( this ); - m_VerticalScrollBar->Dock(Pos::Right); - m_VerticalScrollBar->onBarMoved.Add( this, &ScrollControl::VBarMoved ); - m_VerticalScrollBar->SetNudgeAmount( 30 ); - m_bCanScrollV = true; - - m_HorizontalScrollBar = new HorizontalScrollBar( this ); - m_HorizontalScrollBar->Dock( Pos::Bottom ); - m_HorizontalScrollBar->onBarMoved.Add( this, &ScrollControl::HBarMoved ); - m_bCanScrollH = true; - m_HorizontalScrollBar->SetNudgeAmount( 30 ); - - m_InnerPanel = new Base( this ); - m_InnerPanel->SetPos(0, 0); - m_InnerPanel->SetMargin( Margin(5,5,5,5)); - m_InnerPanel->SendToBack(); - m_InnerPanel->SetMouseInputEnabled( false ); - - m_bAutoHideBars = false; -} - -void ScrollControl::SetScroll( bool h, bool v ) -{ - m_bCanScrollV = v; - m_bCanScrollH = h; - m_VerticalScrollBar->SetHidden( !m_bCanScrollV ); - m_HorizontalScrollBar->SetHidden( !m_bCanScrollH ); -} - -void ScrollControl::SetInnerSize( int w, int h ) -{ - m_InnerPanel->SetSize( w, h ); -} - -void ScrollControl::VBarMoved( Controls::Base * /*control*/ ) -{ - Invalidate(); -} - -void ScrollControl::HBarMoved( Controls::Base * /*control*/ ) -{ - Invalidate(); -} - -void ScrollControl::OnChildBoundsChanged( Gwen::Rect /*oldChildBounds*/, Base* /*pChild*/ ) -{ - UpdateScrollBars(); -} - -void ScrollControl::Layout( Skin::Base* skin ) -{ - UpdateScrollBars(); - BaseClass::Layout(skin); -} - -bool ScrollControl::OnMouseWheeled( int iDelta ) -{ - if ( CanScrollV() && m_VerticalScrollBar->Visible() ) - { - if ( m_VerticalScrollBar->SetScrolledAmount( m_VerticalScrollBar->GetScrolledAmount() - m_VerticalScrollBar->GetNudgeAmount() * ( (float)iDelta / 60.0f ), true) ) - return true; - } - - if ( CanScrollH() && m_HorizontalScrollBar->Visible() ) - { - if ( m_HorizontalScrollBar->SetScrolledAmount( m_HorizontalScrollBar->GetScrolledAmount() - m_HorizontalScrollBar->GetNudgeAmount() * ( (float)iDelta / 60.0f ), true) ) - return true; - } - - return false; -} -void ScrollControl::Render( Skin::Base* skin ) -{ - -#if 0 - - // Debug render - this shouldn't render ANYTHING REALLY - it should be up to the parent! - - Gwen::Rect rect = GetRenderBounds(); - Gwen::Renderer::Base* render = skin->GetRender(); - - render->SetDrawColor( Gwen::Color( 255, 255, 0, 100 ) ); - render->DrawFilledRect( rect ); - - render->SetDrawColor( Gwen::Color( 255, 0, 0, 100 ) ); - render->DrawFilledRect( m_InnerPanel->GetBounds() ); - - render->RenderText( skin->GetDefaultFont(), Gwen::Point( 0, 0 ), Utility::Format( L"Offset: %i %i", m_InnerPanel->X(), m_InnerPanel->Y() ) ); - -#else //0 - - (void)skin; - -#endif //0 -} - -void ScrollControl::UpdateScrollBars() -{ - if ( !m_InnerPanel ) - return; - - int childrenWidth = 0; - int childrenHeight = 0; - - //Get the max size of all our children together - for ( Base::List::iterator iter = m_InnerPanel->Children.begin(); iter != m_InnerPanel->Children.end(); ++iter ) - { - Base* pChild = *iter; - - childrenWidth = Utility::Max( childrenWidth, pChild->Right() ); - childrenHeight = Utility::Max( childrenHeight, pChild->Bottom() ); - } - - m_InnerPanel->SetSize( Utility::Max(Width(), childrenWidth), Utility::Max(Height(), childrenHeight)); - - float hg = (float)(childrenWidth + (m_VerticalScrollBar->Hidden() ? 0 : m_VerticalScrollBar->Width())); - if (hg==0.f) - hg = 0.00001f; - float wPercent = (float)Width() / hg; - hg = (float)(childrenHeight + (m_HorizontalScrollBar->Hidden() ? 0 : m_HorizontalScrollBar->Height())); - if (hg==0.f) - hg = 0.00001f; - float hPercent = (float)Height() / hg; - - if ( m_bCanScrollV ) - SetVScrollRequired( hPercent >= 1 ); - else - m_VerticalScrollBar->SetHidden( true ); - - if ( m_bCanScrollH ) - SetHScrollRequired( wPercent >= 1 ); - else - m_HorizontalScrollBar->SetHidden( true ); - - - m_VerticalScrollBar->SetContentSize( m_InnerPanel->Height() ); - m_VerticalScrollBar->SetViewableContentSize( Height() - (m_HorizontalScrollBar->Hidden() ? 0 : m_HorizontalScrollBar->Height())); - - - m_HorizontalScrollBar->SetContentSize( m_InnerPanel->Width() ); - m_HorizontalScrollBar->SetViewableContentSize( Width() - (m_VerticalScrollBar->Hidden() ? 0 : m_VerticalScrollBar->Width()) ); - - int newInnerPanelPosX = 0; - int newInnerPanelPosY = 0; - - if ( CanScrollV() && !m_VerticalScrollBar->Hidden() ) - { - newInnerPanelPosY = -( ( m_InnerPanel->Height() ) - Height() + (m_HorizontalScrollBar->Hidden() ? 0 : m_HorizontalScrollBar->Height()) ) * m_VerticalScrollBar->GetScrolledAmount(); - } - if ( CanScrollH() && !m_HorizontalScrollBar->Hidden() ) - { - newInnerPanelPosX = - ( ( m_InnerPanel->Width() ) - Width() + (m_VerticalScrollBar->Hidden() ? 0 : m_VerticalScrollBar->Width())) * m_HorizontalScrollBar->GetScrolledAmount(); - } - - m_InnerPanel->SetPos( newInnerPanelPosX , newInnerPanelPosY ); -} - -void ScrollControl::SetVScrollRequired(bool req) -{ - if ( req ) - { - m_VerticalScrollBar->SetScrolledAmount( 0, true ); - m_VerticalScrollBar->SetDisabled( true ); - - if ( m_bAutoHideBars ) - m_VerticalScrollBar->SetHidden( true ); - } - else - { - m_VerticalScrollBar->SetHidden( false ); - m_VerticalScrollBar->SetDisabled( false ); - } -} - -void ScrollControl::SetHScrollRequired(bool req) -{ - if ( req ) - { - m_HorizontalScrollBar->SetScrolledAmount( 0, true ); - m_HorizontalScrollBar->SetDisabled( true ); - if ( m_bAutoHideBars ) - m_HorizontalScrollBar->SetHidden( true ); - } - else - { - m_HorizontalScrollBar->SetHidden( false ); - m_HorizontalScrollBar->SetDisabled( true ); - } -} - -void ScrollControl::ScrollToBottom() -{ - if ( CanScrollV() ) - { - UpdateScrollBars(); - m_VerticalScrollBar->ScrollToBottom(); - } -} -void ScrollControl::ScrollToTop() -{ - if ( CanScrollV() ) - { - UpdateScrollBars(); - m_VerticalScrollBar->ScrollToTop(); - } -} -void ScrollControl::ScrollToLeft() -{ - if ( CanScrollH() ) - { - UpdateScrollBars(); - m_HorizontalScrollBar->ScrollToLeft(); - } -} -void ScrollControl::ScrollToRight() -{ - if ( CanScrollH() ) - { - UpdateScrollBars(); - m_HorizontalScrollBar->ScrollToRight(); - } -} - -void ScrollControl::Clear() -{ - m_InnerPanel->RemoveAllChildren(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ScrollControl.h b/btgui/Gwen/Controls/ScrollControl.h deleted file mode 100644 index 187f8a49f..000000000 --- a/btgui/Gwen/Controls/ScrollControl.h +++ /dev/null @@ -1,70 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_SCROLLCONTROL_H -#define GWEN_CONTROLS_SCROLLCONTROL_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/VerticalScrollBar.h" -#include "Gwen/Controls/HorizontalScrollBar.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT ScrollControl : public Base - { - public: - - GWEN_CONTROL( ScrollControl, Base ); - - virtual void Layout( Skin::Base* skin ); - virtual void Render( Skin::Base* skin ); - - virtual void SetScroll( bool h, bool v ); - virtual void SetAutoHideBars(bool should) { m_bAutoHideBars = should; } - virtual bool CanScrollH() { return m_bCanScrollH; } - virtual bool CanScrollV() { return m_bCanScrollV; } - virtual void OnChildBoundsChanged( Gwen::Rect oldChildBounds, Base* pChild ); - virtual void UpdateScrollBars(); - - virtual void SetVScrollRequired(bool req); - virtual void SetHScrollRequired(bool req); - - virtual void SetInnerSize( int w, int h ); - - virtual void VBarMoved(Controls::Base * control); - virtual void HBarMoved(Controls::Base * control); - - virtual bool OnMouseWheeled( int iDelta ); - - virtual void ScrollToBottom(); - virtual void ScrollToTop(); - virtual void ScrollToLeft(); - virtual void ScrollToRight(); - - virtual void Clear(); - - protected: - - bool m_bCanScrollH; - bool m_bCanScrollV; - - bool m_bAutoHideBars; - - public: - Controls::BaseScrollBar* m_VerticalScrollBar; - Controls::BaseScrollBar* m_HorizontalScrollBar; - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Slider.cpp b/btgui/Gwen/Controls/Slider.cpp deleted file mode 100644 index 849da49a3..000000000 --- a/btgui/Gwen/Controls/Slider.cpp +++ /dev/null @@ -1,104 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include -#include "Gwen/Controls/Slider.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -GWEN_CONTROL_CONSTRUCTOR( SliderBar ) -{ - SetTarget( this ); - RestrictToParent( true ); -} - -void SliderBar::Render( Skin::Base* skin ) -{ - skin->DrawButton( this, m_bDepressed, IsHovered() ); -} - - -Slider::Slider( Controls::Base* pParent ) : BaseClass( pParent ) -{ - SetBounds( Gwen::Rect( 0, 0, 32, 128) ); - - m_SliderBar = new SliderBar( this ); - m_SliderBar->onDragged.Add( this, &Slider::OnMoved ); - - m_fMin = 0.0f; - m_fMax = 1.0f; - - m_bClampToNotches = false; - m_iNumNotches = 5; - m_fValue = 0.0f; - - SetTabable( true ); - -} - -void Slider::OnMoved( Controls::Base * /*control*/ ) -{ - SetValueInternal( CalculateValue() ); -} - -void Slider::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); -} - -float Slider::CalculateValue() -{ - return 0; -} - -void Slider::SetValue( float val, bool /*forceUpdate*/ ) -{ - if (val < m_fMin) val = m_fMin; - if (val > m_fMax) val = m_fMax; - // Normalize Value - val = (val - m_fMin) / (m_fMax - m_fMin); - SetValueInternal( val ); - Redraw(); -} - -void Slider::SetValueInternal( float val ) -{ - if ( m_bClampToNotches ) - { - val = floor( (val * (float)m_iNumNotches) + 0.5f ); - val /= (float) m_iNumNotches; - } - - if ( m_fValue != val ) - { - m_fValue = val; - onValueChanged.Call( this ); - } - - UpdateBarFromValue(); -} - -float Slider::GetValue() -{ - return m_fMin + (m_fValue * (m_fMax - m_fMin)); -} - -void Slider::SetRange( float fMin, float fMax ) -{ - m_fMin = fMin; - m_fMax = fMax; -} - -void Slider::RenderFocus( Gwen::Skin::Base* skin ) -{ - if ( Gwen::KeyboardFocus != this ) return; - if ( !IsTabable() ) return; - - skin->DrawKeyboardHighlight( this, GetRenderBounds(), 0 ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Slider.h b/btgui/Gwen/Controls/Slider.h deleted file mode 100644 index 40523b7a0..000000000 --- a/btgui/Gwen/Controls/Slider.h +++ /dev/null @@ -1,88 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_SLIDER_H -#define GWEN_CONTROLS_SLIDER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT SliderBar : public ControlsInternal::Dragger - { - GWEN_CONTROL( SliderBar, ControlsInternal::Dragger ); - - virtual void Render( Skin::Base* skin ); - }; - } - - namespace Controls - { - - class GWEN_EXPORT Slider : public Base - { - GWEN_CONTROL( Slider, Base ); - - virtual void Render( Skin::Base* skin ) = 0; - virtual void Layout( Skin::Base* skin ); - - virtual void SetClampToNotches( bool bClamp ) { m_bClampToNotches = bClamp; } - - virtual void SetNotchCount( int num ) { m_iNumNotches = num; } - virtual int GetNotchCount() { return m_iNumNotches; } - - virtual void SetRange( float fMin, float fMax ); - virtual float GetRangeMin() const - { - return m_fMin; - } - virtual float GetRangeMax() const - { - return m_fMax; - } - virtual float GetValue(); - virtual void SetValue( float val, bool forceUpdate = true ); - - virtual float CalculateValue(); - virtual void OnMoved( Controls::Base * control ); - - virtual void OnMouseClickLeft( int /*x*/, int /*y*/, bool /*bDown*/ ){}; - - virtual bool OnKeyRight( bool bDown ) { if ( bDown ) SetValue( GetValue() + 1, true ); return true; } - virtual bool OnKeyLeft( bool bDown ) { if ( bDown ) SetValue( GetValue() - 1, true ); return true; } - virtual bool OnKeyUp( bool bDown ) { if ( bDown ) SetValue( GetValue() + 1, true ); return true; } - virtual bool OnKeyDown( bool bDown ) { if ( bDown ) SetValue( GetValue() - 1, true ); return true; } - - virtual void RenderFocus( Gwen::Skin::Base* skin); - - Gwen::Event::Caller onValueChanged; - - protected: - - virtual void SetValueInternal( float fVal ); - virtual void UpdateBarFromValue() = 0; - - ControlsInternal::SliderBar * m_SliderBar; - bool m_bClampToNotches; - int m_iNumNotches; - float m_fValue; - - float m_fMin; - float m_fMax; - - }; - } - - -} -#endif diff --git a/btgui/Gwen/Controls/SplitterBar.cpp b/btgui/Gwen/Controls/SplitterBar.cpp deleted file mode 100644 index 15876d1c4..000000000 --- a/btgui/Gwen/Controls/SplitterBar.cpp +++ /dev/null @@ -1,23 +0,0 @@ - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/SplitterBar.h" - -using namespace Gwen; -using namespace Controls; - -GWEN_CONTROL_CONSTRUCTOR( SplitterBar ) -{ - SetTarget( this ); - RestrictToParent( true ); -} - -void SplitterBar::Render( Skin::Base* skin ) -{ - if ( ShouldDrawBackground() ) - skin->DrawButton( this, true, false ); -} - -void SplitterBar::Layout( Skin::Base* /*skin*/ ) -{ - MoveTo( X(), Y() ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/SplitterBar.h b/btgui/Gwen/Controls/SplitterBar.h deleted file mode 100644 index 950853468..000000000 --- a/btgui/Gwen/Controls/SplitterBar.h +++ /dev/null @@ -1,24 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_SPLITTERBAR_H -#define GWEN_CONTROLS_SPLITTERBAR_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Dragger.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT SplitterBar : public ControlsInternal::Dragger - { - public: - - GWEN_CONTROL( SplitterBar, ControlsInternal::Dragger ); - - void Render( Skin::Base* skin ); - void Layout( Skin::Base* skin ); - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/StatusBar.h b/btgui/Gwen/Controls/StatusBar.h deleted file mode 100644 index cd798f567..000000000 --- a/btgui/Gwen/Controls/StatusBar.h +++ /dev/null @@ -1,36 +0,0 @@ -#pragma once -#ifndef GWEN_CONTROLS_STATUSBAR_H -#define GWEN_CONTROLS_STATUSBAR_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Controls - { - class StatusBar : public Controls::Base - { - public: - - GWEN_CONTROL_INLINE( StatusBar, Controls::Base ) - { - SetBounds( 0, 0, 200, 22 ); - Dock( Pos::Bottom ); - SetPadding( Padding( 2, 2, 2, 2 ) ); - } - - virtual void AddControl( Controls::Base* pCtrl, bool bRight) - { - pCtrl->SetParent( this ); - pCtrl->Dock( bRight ? Pos::Right : Pos::Left ); - } - - virtual void Render( Skin::Base* skin ) - { - skin->DrawStatusBar( this ); - } - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Symbol.h b/btgui/Gwen/Controls/Symbol.h deleted file mode 100644 index 397778e83..000000000 --- a/btgui/Gwen/Controls/Symbol.h +++ /dev/null @@ -1,53 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_SYMBOL_H -#define GWEN_CONTROLS_SYMBOL_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace Controls - { - - namespace Symbol - { - class GWEN_EXPORT Base : public Controls::Base - { - public: - - GWEN_CONTROL_INLINE( Base, Controls::Base ) - { - SetMouseInputEnabled( false ); - } - - }; - - class GWEN_EXPORT Arrow : public Base - { - public: - - Arrow( Gwen::Controls::Base* pnl ) : Base( pnl ) - { - } - - virtual void Render( Gwen::Skin::Base* pSkin ) - { - Gwen::Rect r( Width() / 2 - 2, Height() / 2 - 2, 5, 5 ); - pSkin->DrawArrowRight( r ); - } - - }; - - } - } - -} -#endif diff --git a/btgui/Gwen/Controls/TabButton.cpp b/btgui/Gwen/Controls/TabButton.cpp deleted file mode 100644 index aa49cc14b..000000000 --- a/btgui/Gwen/Controls/TabButton.cpp +++ /dev/null @@ -1,98 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/TabButton.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/Highlight.h" -#include "Gwen/DragAndDrop.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( TabButton ) -{ - m_Page = NULL; - m_Control = NULL; - - SetPadding( Padding( 2, 2, 2, 2 ) ); - - DragAndDrop_SetPackage( true, "TabButtonMove" ); - SetAlignment( Pos::Top | Pos::Left ); - SetTextPadding( Padding( 5, 3, 3, 3 ) ); -} - - -void TabButton::Render( Skin::Base* skin ) -{ - skin->DrawTabButton( this, m_Page && m_Page->Visible() ); -} - - -void TabButton::SetTabControl( TabControl* ctrl ) -{ - if ( m_Control == ctrl ) return; - - if ( m_Control ) - { - m_Control->OnLoseTab( this ); - } - - m_Control = ctrl; -} - -bool TabButton::DragAndDrop_ShouldStartDrag() -{ - return m_Control->DoesAllowDrag(); -} - - -bool TabButton::OnKeyUp( bool bDown ) -{ - OnKeyLeft( bDown ); - return true; -} -bool TabButton::OnKeyDown( bool bDown ) -{ - OnKeyRight( bDown ); - return true; -} - -bool TabButton::OnKeyLeft( bool bDown ) -{ - if ( bDown ) - { - Base::List::reverse_iterator it = std::find( m_Parent->Children.rbegin(), m_Parent->Children.rend(), this ); - if ( it != m_Parent->Children.rend() && (++it != m_Parent->Children.rend()) ) - { - Base* pNextTab = *it; - GetTabControl()->OnTabPressed( pNextTab ); - Gwen::KeyboardFocus = pNextTab; - } - } - - return true; -} -bool TabButton::OnKeyRight( bool bDown ) -{ - if ( bDown ) - { - Base::List::iterator it = std::find( m_Parent->Children.begin(), m_Parent->Children.end(), this ); - if ( it != m_Parent->Children.end() && (++it != m_Parent->Children.end()) ) - { - Base* pNextTab = *it; - GetTabControl()->OnTabPressed( pNextTab ); - Gwen::KeyboardFocus = pNextTab; - } - } - - return true; -} - - diff --git a/btgui/Gwen/Controls/TabButton.h b/btgui/Gwen/Controls/TabButton.h deleted file mode 100644 index ab35664e4..000000000 --- a/btgui/Gwen/Controls/TabButton.h +++ /dev/null @@ -1,54 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TABBUTTON_H -#define GWEN_CONTROLS_TABBUTTON_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" - -namespace Gwen -{ - namespace Controls - { - class TabControl; - - class GWEN_EXPORT TabButton : public Button - { - public: - - GWEN_CONTROL( TabButton, Button ); - virtual void Render( Skin::Base* skin ); - - void SetPage( Base* page ){ m_Page = page; } - Base* GetPage(){ return m_Page; } - - void SetTabControl( TabControl* ctrl ); - TabControl* GetTabControl(){ return m_Control; } - - bool IsActive() { return m_Page && m_Page->Visible(); } - - virtual bool DragAndDrop_ShouldStartDrag(); - virtual void DragAndDrop_StartDragging( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ ){ SetHidden( true ); } - virtual void DragAndDrop_EndDragging( bool /*bSuccess*/, int /*x*/, int /*y*/ ){ SetHidden( false ); } - - virtual bool OnKeyLeft( bool bDown ); - virtual bool OnKeyRight( bool bDown ); - virtual bool OnKeyUp( bool bDown ); - virtual bool OnKeyDown( bool bDown ); - - - private: - - Base* m_Page; - TabControl* m_Control; - - }; - - } -} -#endif diff --git a/btgui/Gwen/Controls/TabControl.cpp b/btgui/Gwen/Controls/TabControl.cpp deleted file mode 100644 index 2a3c48b72..000000000 --- a/btgui/Gwen/Controls/TabControl.cpp +++ /dev/null @@ -1,249 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/Highlight.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/ScrollBarButton.h" - - -namespace Gwen -{ - namespace Controls - { - class TabControlInner : public Base - { - public: - - GWEN_CONTROL_INLINE( TabControlInner, Base ) - { - m_ButtonRect = Gwen::Rect( 0, 0, 0, 0 ); - } - - void Render( Skin::Base* skin ) - { - skin->DrawTabControl( this, m_ButtonRect ); - } - - void UpdateCurrentButton( Gwen::Rect rct ) - { - m_ButtonRect = rct; - } - - Gwen::Rect m_ButtonRect; - }; - }; -}; - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( TabControl ) -{ - m_iScrollOffset = 0; - - m_pCurrentButton = NULL; - - m_TabStrip = new TabStrip( this ); - m_TabStrip->Dock( Pos::Top ); - m_TabStrip->SetWidth( 100 ); - m_TabStrip->SetHeight( 20 ); - - // Make this some special control? - m_pScroll[0] = new ControlsInternal::ScrollBarButton( this ); - m_pScroll[0]->SetDirectionLeft(); - m_pScroll[0]->onPress.Add( this, &TabControl::ScrollPressLeft ); - m_pScroll[0]->SetSize( 14, 16 ); - - m_pScroll[1] = new ControlsInternal::ScrollBarButton( this ); - m_pScroll[1]->SetDirectionRight(); - m_pScroll[1]->onPress.Add( this, &TabControl::ScrollPressRight ); - m_pScroll[1]->SetSize( 14, 16 ); - - m_InnerPanel = new TabControlInner( this ); - m_InnerPanel->Dock( Pos::Fill ); - - SetTabable( false ); -} - - - -TabButton* TabControl::AddPage( const UnicodeString& strText, Controls::Base* pPage ) -{ - if ( !pPage ) - { - pPage = new Base( this ); - } - else - { - pPage->SetParent( this ); - } - - TabButton* pButton = new TabButton( m_TabStrip ); - pButton->SetText( strText ); - pButton->SetPage( pPage ); - pButton->SetTabable( false ); - - AddPage( pButton ); - return pButton; -} - -void TabControl::AddPage( TabButton* pButton ) -{ - Base* pPage = pButton->GetPage(); - pPage->SetParent( this ); - pPage->SetHidden( true ); - pPage->SetMargin( Margin( 6, 6, 6, 6 ) ); - pPage->Dock( Pos::Fill ); - - pButton->SetParent( m_TabStrip ); - pButton->Dock( Pos::Left ); - pButton->SizeToContents(); - if ( pButton->GetTabControl() ) pButton->onPress.RemoveHandler( pButton->GetTabControl() ); - pButton->SetTabControl( this ); - pButton->onPress.Add( this, &TabControl::OnTabPressed ); - - - - if ( !m_pCurrentButton ) - { - pButton->OnPress(); - } - - onAddTab.Call( this ); - - Invalidate(); -} - -void TabControl::OnTabPressed( Controls::Base* control ) -{ - if (!control) - return; - - TabButton* pButton = control->DynamicCastTabButton(); - if ( !pButton ) return; - - Base* pPage = pButton->GetPage(); - if ( !pPage ) return; - - if ( m_pCurrentButton == pButton) - return; - - if ( m_pCurrentButton ) - { - Base* pPage = m_pCurrentButton->GetPage(); - if ( pPage ) - { - pPage->SetHidden( true ); - } - m_pCurrentButton = NULL; - } - - m_pCurrentButton = pButton; - - pPage->SetHidden( false ); - - m_TabStrip->Invalidate(); - Invalidate(); -} - -void TabControl::PostLayout( Skin::Base* skin ) -{ - BaseClass::PostLayout( skin ); - - HandleOverflow(); - - if ( m_TabStrip->Hidden() ) - { - m_InnerPanel->DynamicCastTabControlInner()->UpdateCurrentButton( Gwen::Rect( 0, 0, 0, 0 ) ); - } - else if ( m_pCurrentButton ) - { - Gwen::Rect rct; - - Gwen::Point p = m_pCurrentButton->LocalPosToCanvas( Gwen::Point( 0, 0 ) ); - p = m_InnerPanel->CanvasPosToLocal( p ); - - rct = Gwen::Rect( p.x+1, p.y+1, m_pCurrentButton->Width()-2, m_pCurrentButton->Height()-2 ); - m_InnerPanel->DynamicCastTabControlInner()->UpdateCurrentButton( rct ); - } - -} - -void TabControl::OnLoseTab( TabButton* pButton ) -{ - if ( m_pCurrentButton == pButton ) - m_pCurrentButton = NULL; - - //TODO: Select a tab if any exist. - - onLoseTab.Call( this ); - - Invalidate(); -} - -int TabControl::TabCount( void ) -{ - return m_TabStrip->NumChildren(); -} - -void TabControl::SetTabStripPosition( int iDock ) -{ - m_TabStrip->SetTabPosition( iDock ); -} - -bool TabControl::DoesAllowDrag() -{ - return m_TabStrip->AllowsTabReorder(); -} - -void TabControl::HandleOverflow() -{ - Gwen::Point TabsSize = m_TabStrip->ChildrenSize(); - - // Only enable the scrollers if the tabs are at the top. - // This is a limitation we should explore. - // Really TabControl should have derivitives for tabs placed elsewhere where we could specialize - // some functions like this for each direction. - bool bNeeded = TabsSize.x > Width() && m_TabStrip->GetDock() == Pos::Top; - - m_pScroll[0]->SetHidden( !bNeeded ); - m_pScroll[1]->SetHidden( !bNeeded ); - - if ( !bNeeded ) return; - - m_iScrollOffset = Gwen::Clamp( m_iScrollOffset, 0, TabsSize.x - Width() + 32 ); - - #if 0 - // - // This isn't frame rate independent. - // Could be better. Get rid of m_iScrollOffset and just use m_TabStrip->GetMargin().left ? - // Then get a margin animation type and do it properly! - // TODO! - // - m_TabStrip->SetMargin( Margin( Gwen::Approach( m_TabStrip->GetMargin().left, m_iScrollOffset * -1, 2 ), 0, 0, 0 ) ); - InvalidateParent(); - #else - m_TabStrip->SetMargin( Margin( m_iScrollOffset * -1, 0, 0, 0 ) ); - #endif - - m_pScroll[0]->SetPos( Width() - 30 , 5 ); - m_pScroll[1]->SetPos( m_pScroll[0]->Right(), 5 ); -} - -void TabControl::ScrollPressLeft( Base* pFrom ) -{ - m_iScrollOffset -= 120; -} - -void TabControl::ScrollPressRight( Base* pFrom ) -{ - m_iScrollOffset += 120; -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/TabControl.h b/btgui/Gwen/Controls/TabControl.h deleted file mode 100644 index 82aff58f4..000000000 --- a/btgui/Gwen/Controls/TabControl.h +++ /dev/null @@ -1,67 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TABCONTROL_H -#define GWEN_CONTROLS_TABCONTROL_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/TabButton.h" -#include "Gwen/Controls/TabStrip.h" -#include "Gwen/Controls/TabTitleBar.h" - -namespace Gwen -{ - namespace ControlsInternal - { - class ScrollBarButton; - } - - namespace Controls - { - class GWEN_EXPORT TabControl : public Base - { - GWEN_CONTROL( TabControl, Base ); - - virtual TabButton* AddPage( const UnicodeString& strText, Controls::Base* pPage = NULL ); - virtual void AddPage( TabButton* pButton ); - - virtual void OnTabPressed( Controls::Base* control ); - virtual void OnLoseTab( TabButton* pButton ); - - virtual int TabCount( void ); - virtual TabButton* GetCurrentButton(){ return m_pCurrentButton; } - virtual TabStrip* GetTabStrip(){ return m_TabStrip; } - - virtual void SetTabStripPosition( int iDock ); - - virtual bool DoesAllowDrag(); - - virtual void SetAllowReorder( bool b ){ GetTabStrip()->SetAllowReorder( b ); } - - Gwen::Event::Caller onLoseTab; - Gwen::Event::Caller onAddTab; - - private: - - virtual void PostLayout( Skin::Base* skin ); - void HandleOverflow(); - - void ScrollPressLeft( Base* pFrom ); - void ScrollPressRight( Base* pFrom ); - - TabStrip* m_TabStrip; - TabButton* m_pCurrentButton; - - ControlsInternal::ScrollBarButton* m_pScroll[2]; - int m_iScrollOffset; - - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/TabStrip.cpp b/btgui/Gwen/Controls/TabStrip.cpp deleted file mode 100644 index 61afa5eb7..000000000 --- a/btgui/Gwen/Controls/TabStrip.cpp +++ /dev/null @@ -1,181 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/TabStrip.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/Highlight.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - - -GWEN_CONTROL_CONSTRUCTOR( TabStrip ) -{ - m_TabDragControl = NULL; - m_bAllowReorder = false; -} - -bool TabStrip::DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* /*pPackage*/, int x, int y ) -{ - Gwen::Point LocalPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - - Base* el = DragAndDrop::SourceControl; - - TabButton* pButton = el? el->DynamicCastTabButton() : 0; - TabControl* pTabControl = GetParent()? GetParent()->DynamicCastTabControl() : 0; - if ( pTabControl && pButton ) - { - if ( pButton->GetTabControl() != pTabControl ) - { - // We've moved tab controls! - pTabControl->AddPage( pButton ); - } - } - - Base* DroppedOn = GetControlAt( LocalPos.x, LocalPos.y ); - if ( DroppedOn ) - { - Gwen::Point DropPos = DroppedOn->CanvasPosToLocal( Gwen::Point( x, y ) ); - DragAndDrop::SourceControl->BringNextToControl( DroppedOn, DropPos.x > DroppedOn->Width() / 2 ); - } - else - { - DragAndDrop::SourceControl->BringToFront(); - } - return true; -} - -bool TabStrip::DragAndDrop_CanAcceptPackage( Gwen::DragAndDrop::Package* pPackage ) -{ - if ( !m_bAllowReorder ) - return false; - - if ( pPackage->name == "TabButtonMove" ) - return true; - - return false; -} - -void TabStrip::Layout( Skin::Base* skin ) -{ - Gwen::Point pLargestTab( 5, 5 ); - - int iNum = 0; - for ( Base::List::iterator iter = Children.begin(); iter != Children.end(); ++iter ) - { - if (!*iter) - continue; - - TabButton* pButton = (*iter)->DynamicCastTabButton(); - if ( !pButton ) continue; - - pButton->SizeToContents(); - - Margin m; - int iActive = pButton->IsActive() ? 0 : 2; - int iNotFirst = iNum > 0 ? -1 : 0; - int iControlOverhang = -3; - - if ( m_iDock == Pos::Top ) - { - m.top = iActive; - m.left = iNotFirst; - m.bottom = iControlOverhang; - pButton->Dock( Pos::Left ); - } - - if ( m_iDock == Pos::Left ) - { - m.left = iActive * 2; - m.right = iControlOverhang; - m.top = iNotFirst; - pButton->Dock( Pos::Top ); - } - - if ( m_iDock == Pos::Right ) - { - m.right = iActive * 2; - m.left = iControlOverhang; - m.top = iNotFirst; - pButton->Dock( Pos::Top ); - } - - if ( m_iDock == Pos::Bottom ) - { - m.bottom = iActive; - m.left = iNotFirst; - m.top = iControlOverhang; - pButton->Dock( Pos::Left ); - } - - pLargestTab.x = Utility::Max( pLargestTab.x, pButton->Width() ); - pLargestTab.y = Utility::Max( pLargestTab.y, pButton->Height() ); - - pButton->SetMargin( m ); - iNum++; - } - - if ( m_iDock == Pos::Top || m_iDock == Pos::Bottom ) - SetSize( Width(), pLargestTab.y ); - - if ( m_iDock == Pos::Left || m_iDock == Pos::Right ) - SetSize( pLargestTab.x, Height() ); - - BaseClass::Layout( skin ); -} - -void TabStrip::DragAndDrop_HoverEnter( Gwen::DragAndDrop::Package* /*pPackage*/, int /*x*/, int /*y*/ ) -{ - if ( m_TabDragControl ) - { - Debug::Msg( "ERROR! TabStrip::DragAndDrop_HoverEnter\n" ); - } - - m_TabDragControl = new ControlsInternal::Highlight( this ); - m_TabDragControl->SetMouseInputEnabled( false ); - m_TabDragControl->SetSize( 3, Height() ); -} - -void TabStrip::DragAndDrop_HoverLeave( Gwen::DragAndDrop::Package* /*pPackage*/ ) -{ - delete m_TabDragControl; - m_TabDragControl = NULL; -} - -void TabStrip::DragAndDrop_Hover( Gwen::DragAndDrop::Package* /*pPackage*/, int x, int y ) -{ - Gwen::Point LocalPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - - Base* DroppedOn = GetControlAt( LocalPos.x, LocalPos.y ); - if ( DroppedOn && DroppedOn != this ) - { - Gwen::Point DropPos = DroppedOn->CanvasPosToLocal( Gwen::Point( x, y ) ); - m_TabDragControl->SetBounds( Gwen::Rect( 0, 0, 3, Height() ) ); - m_TabDragControl->BringToFront(); - m_TabDragControl->SetPos( DroppedOn->X() - 1, 0 ); - - if ( DropPos.x > DroppedOn->Width() / 2 ) - { - m_TabDragControl->MoveBy( DroppedOn->Width()-1, 0 ); - } - m_TabDragControl->Dock( Pos::None ); - } - else - { - m_TabDragControl->Dock( Pos::Left ); - m_TabDragControl->BringToFront(); - } -} - -void TabStrip::SetTabPosition( int iPos ) -{ - Dock( iPos ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/TabStrip.h b/btgui/Gwen/Controls/TabStrip.h deleted file mode 100644 index 40c751cc4..000000000 --- a/btgui/Gwen/Controls/TabStrip.h +++ /dev/null @@ -1,49 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TABSTRIP_H -#define GWEN_CONTROLS_TABSTRIP_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/TabButton.h" - -namespace Gwen -{ - namespace Controls - { - //class TabControl; - - class GWEN_EXPORT TabStrip : public Base - { - public: - - GWEN_CONTROL( TabStrip, Base ); - - virtual void Layout( Skin::Base* skin ); - - virtual bool DragAndDrop_HandleDrop( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual bool DragAndDrop_CanAcceptPackage( Gwen::DragAndDrop::Package* pPackage ); - - virtual void DragAndDrop_HoverEnter( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - virtual void DragAndDrop_HoverLeave( Gwen::DragAndDrop::Package* pPackage ); - virtual void DragAndDrop_Hover( Gwen::DragAndDrop::Package* pPackage, int x, int y ); - - virtual void SetTabPosition( int iPos ); - - virtual void SetAllowReorder( bool b ){ m_bAllowReorder = b; } - virtual bool AllowsTabReorder() { return m_bAllowReorder; } - - private: - - Base* m_TabDragControl; - bool m_bAllowReorder; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/TabTitleBar.h b/btgui/Gwen/Controls/TabTitleBar.h deleted file mode 100644 index f953854aa..000000000 --- a/btgui/Gwen/Controls/TabTitleBar.h +++ /dev/null @@ -1,56 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TABTITLEBAR_H -#define GWEN_CONTROLS_TABTITLEBAR_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/TabButton.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT TabTitleBar : public Label - { - public: - - GWEN_CONTROL_INLINE( TabTitleBar, Label ) - { - SetMouseInputEnabled( true ); - SetTextPadding( Gwen::Padding( 5, 2, 5, 2 ) ); - SetPadding( Gwen::Padding( 1, 2, 1, 2 ) ); - - DragAndDrop_SetPackage( true, "TabWindowMove" ); - } - - void Render( Skin::Base* skin ) - { - skin->DrawTabTitleBar( this ); - } - - void DragAndDrop_StartDragging( Gwen::DragAndDrop::Package* pPackage, int x, int y ) - { - DragAndDrop::SourceControl = GetParent(); - DragAndDrop::SourceControl->DragAndDrop_StartDragging( pPackage, x, y ); - } - - void UpdateFromTab( TabButton* pButton ) - { - SetText( pButton->GetText() ); - SizeToContents(); - } - - private: - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/Text.cpp b/btgui/Gwen/Controls/Text.cpp deleted file mode 100644 index fe9fa8e08..000000000 --- a/btgui/Gwen/Controls/Text.cpp +++ /dev/null @@ -1,114 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Text.h" -#include "Gwen/Skin.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::ControlsInternal; - -GWEN_CONTROL_CONSTRUCTOR( Text ) -{ - m_Font = NULL; - m_Color = Gwen::Colors::Black; // TODO: From skin somehow.. - SetMouseInputEnabled( false ); -} - -Text::~Text() -{ - // NOTE: This font doesn't need to be released - // Because it's a pointer to another font somewhere. -} - -void Text::RefreshSize() -{ - if ( !GetFont() ) - { - Debug::AssertCheck( 0, "Text::RefreshSize() - No Font!!\n" ); - return; - } - - Gwen::Point p( 1, GetFont()->size ); - - if ( Length() > 0 ) - { - p = GetSkin()->GetRender()->MeasureText( GetFont(), m_String ); - } - - if ( p.x == Width() && p.y == Height() ) - return; - - SetSize( p.x, p.y ); - InvalidateParent(); - Invalidate(); -} - - - -Gwen::Font* Text::GetFont() -{ - return m_Font; -} - - -void Text::SetString( const UnicodeString& str ){ m_String = str; Invalidate(); } -void Text::SetString( const String& str ){ SetString( Gwen::Utility::StringToUnicode( str ) ); } - -void Text::Render( Skin::Base* skin ) -{ - if ( Length() == 0 || !GetFont() ) return; - - skin->GetRender()->SetDrawColor( m_Color ); - skin->GetRender()->RenderText( GetFont(), Gwen::Point( 0, 0 ), m_String ); -} - -void Text::Layout( Skin::Base* /*skin*/ ) -{ - RefreshSize(); -} - -Gwen::Point Text::GetCharacterPosition( int iChar ) -{ - if ( Length() == 0 || iChar == 0 ) - { - return Gwen::Point( 1, 0 ); - } - - UnicodeString sub = m_String.substr( 0, iChar ); - Gwen::Point p = GetSkin()->GetRender()->MeasureText( GetFont(), sub ); - - if ( p.y >= m_Font->size ) - p.y -= m_Font->size; - - return p; -} - -int Text::GetClosestCharacter( Gwen::Point p ) -{ - int iDistance = 4096; - int iChar = 0; - - for ( size_t i=0; i iDistance ) continue; - - iDistance = iDist; - iChar = i; - } - - return iChar; -} - -void Text::OnScaleChanged() -{ - Invalidate(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/Text.h b/btgui/Gwen/Controls/Text.h deleted file mode 100644 index ac36acd94..000000000 --- a/btgui/Gwen/Controls/Text.h +++ /dev/null @@ -1,59 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TEXT_H -#define GWEN_CONTROLS_TEXT_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace ControlsInternal - { - class GWEN_EXPORT Text : public Controls::Base - { - public: - - GWEN_CONTROL( Text, Controls::Base ); - - virtual ~Text(); - Gwen::Font* GetFont(); - - void SetString( const UnicodeString& str ); - void SetString( const String& str ); - - void Render( Skin::Base* skin ); - void Layout( Skin::Base* skin ); - - void RefreshSize(); - - void SetFont( Gwen::Font* pFont ){ m_Font = pFont; } - - const UnicodeString& GetText() const { return m_String; } - - Gwen::Point GetCharacterPosition( int iChar ); - int GetClosestCharacter( Gwen::Point p ); - - int Length() const { return (int)m_String.size(); } - - virtual void SetTextColor( const Gwen::Color& col ){ m_Color = col; } - - virtual void OnScaleChanged(); - - inline const Gwen::Color &TextColor() const { return m_Color; } - - private: - - Gwen::UnicodeString m_String; - Gwen::Font* m_Font; - Gwen::Color m_Color; - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/TextBox.cpp b/btgui/Gwen/Controls/TextBox.cpp deleted file mode 100644 index 1825bc4c7..000000000 --- a/btgui/Gwen/Controls/TextBox.cpp +++ /dev/null @@ -1,411 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/TextBox.h" -#include "Gwen/Skin.h" -#include "Gwen/Utility.h" -#include "Gwen/Platform.h" - -#include - - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( TextBox ) -{ - SetSize( 200, 20 ); - - SetMouseInputEnabled( true ); - SetKeyboardInputEnabled( true ); - - SetAlignment( Pos::Left | Pos::CenterV ); - SetTextPadding( Padding( 4, 2, 4, 2 ) ); - - m_iCursorPos = 0; - m_iCursorEnd = 0; - m_bSelectAll = false; - - SetTextColor( Gwen::Color( 50, 50, 50, 255 ) ); // TODO: From Skin - - SetTabable( true ); - - AddAccelerator( L"Ctrl + c", &TextBox::OnCopy ); - AddAccelerator( L"Ctrl + x", &TextBox::OnCut ); - AddAccelerator( L"Ctrl + v", &TextBox::OnPaste ); - AddAccelerator( L"Ctrl + a", &TextBox::OnSelectAll ); -} - -bool TextBox::OnChar( Gwen::UnicodeChar c ) -{ - if ( c == '\t' ) return false; - - Gwen::UnicodeString str; - str += c; - - InsertText( str ); - return true; -} - -void TextBox::InsertText( const Gwen::UnicodeString& strInsert ) -{ - // TODO: Make sure fits (implement maxlength) - - if ( HasSelection() ) - { - EraseSelection(); - } - - if ( m_iCursorPos > TextLength() ) m_iCursorPos = TextLength(); - - if ( !IsTextAllowed( strInsert, m_iCursorPos ) ) - return; - - UnicodeString str = GetText(); - str.insert( m_iCursorPos, strInsert ); - SetText( str ); - - m_iCursorPos += (int) strInsert.size(); - m_iCursorEnd = m_iCursorPos; - - RefreshCursorBounds(); -} - -void TextBox::Render( Skin::Base* skin ) -{ - if ( ShouldDrawBackground() ) - skin->DrawTextBox( this ); - - - if ( !HasFocus() ) return; - - // Draw selection.. if selected.. - if ( m_iCursorPos != m_iCursorEnd ) - { - skin->GetRender()->SetDrawColor( Gwen::Color( 50, 170, 255, 200 ) ); - skin->GetRender()->DrawFilledRect( m_rectSelectionBounds ); - } - - // Draw caret - if ( fmod( Gwen::Platform::GetTimeInSeconds()-m_fLastInputTime, 1.0f ) > 0.5f ) - skin->GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 255 ) ); - else - skin->GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - - skin->GetRender()->DrawFilledRect( m_rectCaretBounds ); -} - -void TextBox::RefreshCursorBounds() -{ - m_fLastInputTime = Gwen::Platform::GetTimeInSeconds(); - - MakeCaratVisible(); - - Gwen::Point pA = GetCharacterPosition( m_iCursorPos ); - Gwen::Point pB = GetCharacterPosition( m_iCursorEnd ); - - m_rectSelectionBounds.x = Utility::Min( pA.x, pB.x ); - m_rectSelectionBounds.y = m_Text->Y() - 1; - m_rectSelectionBounds.w = Utility::Max( pA.x, pB.x ) - m_rectSelectionBounds.x; - m_rectSelectionBounds.h = m_Text->Height() + 2; - - m_rectCaretBounds.x = pA.x; - m_rectCaretBounds.y = m_Text->Y() - 1; - m_rectCaretBounds.w = 1; - m_rectCaretBounds.h = m_Text->Height() + 2; - - Redraw(); -} - - -void TextBox::OnPaste( Gwen::Controls::Base* /*pCtrl*/ ) -{ - InsertText( Platform::GetClipboardText() ); -} - -void TextBox::OnCopy( Gwen::Controls::Base* /*pCtrl*/ ) -{ - if ( !HasSelection() ) return; - - Platform::SetClipboardText( GetSelection() ); -} - -void TextBox::OnCut( Gwen::Controls::Base* /*pCtrl*/ ) -{ - if ( !HasSelection() ) return; - - Platform::SetClipboardText( GetSelection() ); - EraseSelection(); -} - -void TextBox::OnSelectAll( Gwen::Controls::Base* /*pCtrl*/ ) -{ - m_iCursorEnd = 0; - m_iCursorPos = TextLength(); - - RefreshCursorBounds(); -} - -void TextBox::OnMouseDoubleClickLeft( int /*x*/, int /*y*/ ) -{ - OnSelectAll( this ); -} - -UnicodeString TextBox::GetSelection() -{ - if ( !HasSelection() ) return L""; - - int iStart = Utility::Min( m_iCursorPos, m_iCursorEnd ); - int iEnd = Utility::Max( m_iCursorPos, m_iCursorEnd ); - - const UnicodeString& str = GetText(); - return str.substr( iStart, iEnd - iStart ); -} - -bool TextBox::OnKeyReturn( bool bDown ) -{ - if ( bDown ) return true; - - OnEnter(); - - // Try to move to the next control, as if tab had been pressed - OnKeyTab( true ); - - // If we still have focus, blur it. - if ( HasFocus() ) - { - Blur(); - } - - return true; -} - -bool TextBox::OnKeyBackspace( bool bDown ) -{ - if ( !bDown ) return true; - if ( HasSelection() ) - { - EraseSelection(); - return true; - } - - if ( m_iCursorPos == 0 ) return true; - - DeleteText( m_iCursorPos-1, 1 ); - - return true; -} - -bool TextBox::OnKeyDelete( bool bDown ) -{ - if ( !bDown ) return true; - if ( HasSelection() ) - { - EraseSelection(); - return true; - } - - if ( m_iCursorPos >= TextLength() ) return true; - - DeleteText( m_iCursorPos, 1 ); - - return true; -} - -bool TextBox::OnKeyLeft( bool bDown ) -{ - if ( !bDown ) return true; - - if ( m_iCursorPos > 0 ) - m_iCursorPos--; - - if ( !Gwen::Input::IsShiftDown() ) - { - m_iCursorEnd = m_iCursorPos; - } - - RefreshCursorBounds(); - return true; -} - -bool TextBox::OnKeyRight( bool bDown ) -{ - if ( !bDown ) return true; - - if ( m_iCursorPos < TextLength() ) - m_iCursorPos++; - - if ( !Gwen::Input::IsShiftDown() ) - { - m_iCursorEnd = m_iCursorPos; - } - - RefreshCursorBounds(); - return true; -} - -bool TextBox::OnKeyHome( bool bDown ) -{ - if ( !bDown ) return true; - m_iCursorPos = 0; - - if ( !Gwen::Input::IsShiftDown() ) - { - m_iCursorEnd = m_iCursorPos; - } - - RefreshCursorBounds(); - return true; -} - -bool TextBox::OnKeyEnd( bool /*bDown*/ ) -{ - m_iCursorPos = TextLength(); - - if ( !Gwen::Input::IsShiftDown() ) - { - m_iCursorEnd = m_iCursorPos; - } - - RefreshCursorBounds(); - return true; -} - -void TextBox::SetCursorPos( int i ) -{ - if ( m_iCursorPos == i ) return; - - m_iCursorPos = i; - RefreshCursorBounds(); -} - -void TextBox::SetCursorEnd( int i ) -{ - if ( m_iCursorEnd == i ) return; - - m_iCursorEnd = i; - RefreshCursorBounds(); -} - - -void TextBox::DeleteText( int iStartPos, int iLength ) -{ - UnicodeString str = GetText(); - str.erase( iStartPos, iLength ); - SetText( str ); - - if ( m_iCursorPos > iStartPos ) - { - SetCursorPos( m_iCursorPos - iLength ); - } - - SetCursorEnd( m_iCursorPos ); -} - -bool TextBox::HasSelection() -{ - return m_iCursorPos != m_iCursorEnd; -} - -void TextBox::EraseSelection() -{ - int iStart = Utility::Min( m_iCursorPos, m_iCursorEnd ); - int iEnd = Utility::Max( m_iCursorPos, m_iCursorEnd ); - - DeleteText( iStart, iEnd - iStart ); - - // Move the cursor to the start of the selection, - // since the end is probably outside of the string now. - m_iCursorPos = iStart; - m_iCursorEnd = iStart; -} - -void TextBox::OnMouseClickLeft( int x, int y, bool bDown ) -{ - if ( m_bSelectAll ) - { - OnSelectAll( this ); - m_bSelectAll = false; - return; - } - - int iChar = m_Text->GetClosestCharacter( m_Text->CanvasPosToLocal( Gwen::Point( x, y ) ) ); - - if ( bDown ) - { - SetCursorPos( iChar ); - - if ( !Gwen::Input::IsShiftDown() ) - SetCursorEnd( iChar ); - - Gwen::MouseFocus = this; - } - else - { - if ( Gwen::MouseFocus == this ) - { - SetCursorPos( iChar ); - Gwen::MouseFocus = NULL; - } - } -} - -void TextBox::OnMouseMoved( int x, int y, int /*deltaX*/, int /*deltaY*/ ) -{ - if ( Gwen::MouseFocus != this ) return; - - int iChar = m_Text->GetClosestCharacter( m_Text->CanvasPosToLocal( Gwen::Point( x, y ) ) ); - - SetCursorPos( iChar ); -} - -void TextBox::MakeCaratVisible() -{ - int iCaratPos = m_Text->GetCharacterPosition( m_iCursorPos ).x; - - // If the carat is already in a semi-good position, leave it. - { - int iRealCaratPos = iCaratPos + m_Text->X(); - if ( iRealCaratPos > Width() * 0.1f && iRealCaratPos < Width() * 0.9f ) - return; - } - - // The ideal position is for the carat to be right in the middle - int idealx = -iCaratPos + Width() * 0.5f;; - - // Don't show too much whitespace to the right - if ( idealx + m_Text->Width() < Width() - m_rTextPadding.right ) - idealx = -m_Text->Width() + (Width() - m_rTextPadding.right ); - - // Or the left - if ( idealx > m_rTextPadding.left ) - idealx = m_rTextPadding.left; - - m_Text->SetPos( idealx, m_Text->Y() ); - -} - -void TextBox::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - - RefreshCursorBounds(); -} - -void TextBox::OnTextChanged() -{ - if ( m_iCursorPos > TextLength() ) m_iCursorPos = TextLength(); - if ( m_iCursorEnd > TextLength() ) m_iCursorEnd = TextLength(); - - onTextChanged.Call( this ); -} - -void TextBox::OnEnter() -{ - onReturnPressed.Call( this ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/TextBox.h b/btgui/Gwen/Controls/TextBox.h deleted file mode 100644 index 2d3e6f1a3..000000000 --- a/btgui/Gwen/Controls/TextBox.h +++ /dev/null @@ -1,104 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TEXTBOX_H -#define GWEN_CONTROLS_TEXTOBX_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/ScrollControl.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT TextBox : public Label - { - GWEN_CONTROL( TextBox, Label ); - - virtual void Render( Skin::Base* skin ); - virtual void RenderFocus( Gwen::Skin::Base* /*skin*/){}; - virtual void Layout( Skin::Base* skin ); - - virtual bool OnChar( Gwen::UnicodeChar c ); - - virtual void InsertText( const Gwen::UnicodeString& str ); - virtual void DeleteText( int iStartPos, int iLength ); - - virtual void RefreshCursorBounds(); - - virtual bool OnKeyReturn( bool bDown ); - virtual bool OnKeyBackspace( bool bDown ); - virtual bool OnKeyDelete( bool bDown ); - virtual bool OnKeyRight( bool bDown ); - virtual bool OnKeyLeft( bool bDown ); - virtual bool OnKeyHome( bool bDown ); - virtual bool OnKeyEnd( bool bDown ); - - virtual bool AccelOnlyFocus() { return true; } - - virtual void OnPaste( Gwen::Controls::Base* pCtrl ); - virtual void OnCopy( Gwen::Controls::Base* pCtrl ); - virtual void OnCut( Gwen::Controls::Base* pCtrl ); - virtual void OnSelectAll( Gwen::Controls::Base* pCtrl ); - - virtual void OnMouseDoubleClickLeft( int x, int y ); - - virtual void EraseSelection(); - virtual bool HasSelection(); - virtual UnicodeString GetSelection(); - - virtual void SetCursorPos( int i ); - virtual void SetCursorEnd( int i ); - - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - virtual void OnMouseMoved( int x, int y, int deltaX, int deltaY ); - - virtual void SetSelectAllOnFocus( bool b ){ m_bSelectAll = b; if ( b ) OnSelectAll( this ); } - - virtual void MakeCaratVisible(); - - virtual void OnEnter(); - - virtual bool NeedsInputChars(){ return true; } - - Event::Caller onTextChanged; - Event::Caller onReturnPressed; - - protected: - - virtual void OnTextChanged(); - virtual bool IsTextAllowed( const Gwen::UnicodeString& /*str*/, int /*iPos*/ ){ return true; } - - bool m_bSelectAll; - - int m_iCursorPos; - int m_iCursorEnd; - - Gwen::Rect m_rectSelectionBounds; - Gwen::Rect m_rectCaretBounds; - - float m_fLastInputTime; - }; - - class GWEN_EXPORT TextBoxNumeric : public TextBox - { - public: - - GWEN_CONTROL( TextBoxNumeric, TextBox ); - - virtual float GetFloatFromText(); - - private: - - virtual bool IsTextAllowed( const Gwen::UnicodeString& str, int iPos ); - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/TextBoxNumeric.cpp b/btgui/Gwen/Controls/TextBoxNumeric.cpp deleted file mode 100644 index f9e8d824f..000000000 --- a/btgui/Gwen/Controls/TextBoxNumeric.cpp +++ /dev/null @@ -1,75 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/TextBox.h" -#include "Gwen/Skin.h" -#include "Gwen/Utility.h" -#include "Gwen/Platform.h" - - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( TextBoxNumeric ) -{ - SetText( L"0" ); -} - -bool TextBoxNumeric::IsTextAllowed( const Gwen::UnicodeString& str, int iPos ) -{ - const UnicodeString& strString = GetText(); - - if ( str.length() == 0 ) - return true; - - for (size_t i=0; i 0 ) - return false; - - continue; - } - - if ( str[i] == L'0' ) continue; - if ( str[i] == L'1' ) continue; - if ( str[i] == L'2' ) continue; - if ( str[i] == L'3' ) continue; - if ( str[i] == L'4' ) continue; - if ( str[i] == L'5' ) continue; - if ( str[i] == L'6' ) continue; - if ( str[i] == L'7' ) continue; - if ( str[i] == L'8' ) continue; - if ( str[i] == L'9' ) continue; - - if ( str[i] == L'.' ) - { - // Already a fullstop - if ( std::count( strString.begin(), strString.end(), L'.' ) > 0 ) - return false; - - continue; - } - - return false; - } - - return true; -} - -float TextBoxNumeric::GetFloatFromText() -{ - double temp = GwenUtil_WideStringToFloat( GetText().c_str() ); - return temp; -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/ToolBar.h b/btgui/Gwen/Controls/ToolBar.h deleted file mode 100644 index e36ee015b..000000000 --- a/btgui/Gwen/Controls/ToolBar.h +++ /dev/null @@ -1,51 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TOOLBAR_H -#define GWEN_CONTROLS_TOOLBAR_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace Controls - { - /* - - TODO! - - */ - - class ToolBarStrip : public Base - { - GWEN_CONTROL_INLINE( ToolBarStrip, Base ) - { - SetPadding( Padding( 2, 2, 2, 2 ) ); - } - - virtual void Render( Skin::Base* skin ) - { - skin->DrawMenuStrip( this ); - } - - virtual void RenderUnder( Skin::Base* skin ) - { - - } - - virtual void Layout( Skin::Base* skin ) - { - - } - - }; - } - -} -#endif diff --git a/btgui/Gwen/Controls/TreeControl.cpp b/btgui/Gwen/Controls/TreeControl.cpp deleted file mode 100644 index d89f9ce1a..000000000 --- a/btgui/Gwen/Controls/TreeControl.cpp +++ /dev/null @@ -1,318 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/TreeControl.h" -#include "Gwen/Controls/ScrollControl.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( TreeControl ) -{ - m_TreeControl = this; - m_bUpdateScrollBar = 2; - m_ToggleButton->DelayedDelete(); - m_ToggleButton = NULL; - m_Title->DelayedDelete(); - m_Title = NULL; - m_InnerPanel->DelayedDelete(); - m_InnerPanel = NULL; - - m_bAllowMultipleSelection = false; - - m_ScrollControl = new ScrollControl( this ); - m_ScrollControl->Dock( Pos::Fill ); - m_ScrollControl->SetScroll( false, true ); - m_ScrollControl->SetAutoHideBars( true ); - m_ScrollControl->SetMargin( Margin( 1, 1, 1, 1 ) ); - - m_InnerPanel = m_ScrollControl; - - m_ScrollControl->SetInnerSize( 1000, 1000 ); -} - -void TreeControl::Render( Skin::Base* skin ) -{ - if ( ShouldDrawBackground() ) - skin->DrawTreeControl( this ); -} - -void TreeControl::ForceUpdateScrollBars() -{ - m_ScrollControl->UpdateScrollBars(); -} - -void TreeControl::OnChildBoundsChanged( Gwen::Rect /*oldChildBounds*/, Base* /*pChild*/ ) -{ - -} - -void TreeControl::Clear() -{ - m_ScrollControl->Clear(); -} - -void TreeControl::Layout( Skin::Base* skin ) -{ - BaseClass::BaseClass::Layout( skin ); -} - -void TreeControl::PostLayout( Skin::Base* skin ) -{ - BaseClass::BaseClass::PostLayout( skin ); -} - -void TreeControl::OnNodeAdded( TreeNode* pNode ) -{ - pNode->onNamePress.Add( this, &TreeControl::OnNodeSelection ); -} - - -void TreeControl::OnNodeSelection( Controls::Base* /*control*/ ) -{ - //printf("TreeControl::OnNodeSelection\n"); - if ( !m_bAllowMultipleSelection || !Gwen::Input::IsKeyDown( Key::Control ) ) - DeselectAll(); -} - - -void TreeControl::iterate(int action, int* maxItem, int* curItem) -{ - - Base::List& children = m_InnerPanel->GetChildren(); - for ( Base::List::iterator iter = children.begin(); iter != children.end(); ++iter ) - { - TreeNode* pChild = (*iter)->DynamicCastTreeNode(); - if ( !pChild ) - continue; - pChild->iterate(action ,maxItem, curItem); - } - -} - - -bool TreeControl::OnKeyUp( bool bDown ) -{ - if (bDown) - { - -// int maxIndex = 0; - int newIndex = 0; - int maxItem=0; - int curItem=-1; - iterate(ITERATE_ACTION_FIND_SELECTED_INDEX,&maxItem,&curItem); - // maxIndex = maxItem; - int targetItem = curItem; - if (curItem>0) - { - maxItem=0; - int deselectIndex = targetItem; - targetItem--; - newIndex = targetItem; - iterate(ITERATE_ACTION_SELECT,&maxItem,&targetItem); - if (targetItem<0) - { - maxItem=0; - iterate(ITERATE_ACTION_DESELECT_INDEX,&maxItem,&deselectIndex); - } - curItem = newIndex; - // float amount = float(newIndex)/float(maxIndex); - float viewSize = m_ScrollControl->m_VerticalScrollBar->getViewableContentSize(); - float contSize = m_ScrollControl->m_VerticalScrollBar->getContentSize(); - - float curAmount = m_ScrollControl->m_VerticalScrollBar->GetScrolledAmount(); - // float minCoordViewableWindow = curAmount*contSize; - //float maxCoordViewableWindow = minCoordViewableWindow+viewSize; - float minCoordSelectedItem = curItem*16.f; - // float maxCoordSelectedItem = (curItem+1)*16.f; - if (contSize!=viewSize) - { - { - float newAmount = float(minCoordSelectedItem)/(contSize-viewSize); - if (newAmountm_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - { - int numItems = (viewSize)/16-1; - float newAmount = float((curItem-numItems)*16)/(contSize-viewSize); - - if (newAmount>curAmount) - { - m_ScrollControl->m_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - } - } - } - ForceUpdateScrollBars(); - return true; -} - - -bool TreeControl::OnKeyDown( bool bDown ) -{ - if (bDown) - { - - // int maxIndex = 0; - int newIndex = 0; - int maxItem=0; - int curItem=-1; - iterate(ITERATE_ACTION_FIND_SELECTED_INDEX,&maxItem,&curItem); - // maxIndex = maxItem; - int targetItem = curItem; - if (curItem>=0) - { - maxItem=0; - int deselectIndex = targetItem; - targetItem++; - newIndex = targetItem; - iterate(ITERATE_ACTION_SELECT,&maxItem,&targetItem); - if (targetItem<0) - { - maxItem=0; - iterate(ITERATE_ACTION_DESELECT_INDEX,&maxItem,&deselectIndex); - } - curItem= newIndex; - // float amount = (int)float(newIndex)/float(maxIndex); - float viewSize = m_ScrollControl->m_VerticalScrollBar->getViewableContentSize(); - float contSize = m_ScrollControl->m_VerticalScrollBar->getContentSize(); - - float curAmount = m_ScrollControl->m_VerticalScrollBar->GetScrolledAmount(); - // float minCoordViewableWindow = curAmount*contSize; - //float maxCoordViewableWindow = minCoordViewableWindow+viewSize; - float minCoordSelectedItem = curItem*16.f; - //float maxCoordSelectedItem = (curItem+1)*16.f; - if (contSize!=viewSize) - { - { - float newAmount = float(minCoordSelectedItem)/(contSize-viewSize); - if (newAmountm_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - { - int numItems = (viewSize)/16-1; - float newAmount = float((curItem-numItems)*16)/(contSize-viewSize); - - if (newAmount>curAmount) - { - m_ScrollControl->m_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - } - } - } - ForceUpdateScrollBars(); - return true; -} -extern int avoidUpdate; - -bool TreeControl::OnKeyRight( bool bDown ) -{ - if (bDown) - { - - avoidUpdate = -3; - - iterate(ITERATE_ACTION_OPEN,0,0); - int maxItem=0; - int curItem=0; - iterate(ITERATE_ACTION_FIND_SELECTED_INDEX,&maxItem,&curItem); - // float amount = float(curItem)/float(maxItem); - float viewSize = m_ScrollControl->m_VerticalScrollBar->getViewableContentSize(); - float contSize = m_ScrollControl->m_VerticalScrollBar->getContentSize(); - - float curAmount = m_ScrollControl->m_VerticalScrollBar->GetScrolledAmount(); - // float minCoordViewableWindow = curAmount*contSize; -// float maxCoordViewableWindow = minCoordViewableWindow+viewSize; - float minCoordSelectedItem = curItem*16.f; - // float maxCoordSelectedItem = (curItem+1)*16.f; - if (contSize!=viewSize) - { - { - float newAmount = float(minCoordSelectedItem)/(contSize-viewSize); - if (newAmountm_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - { - int numItems = (viewSize)/16-1; - float newAmount = float((curItem-numItems)*16)/(contSize-viewSize); - - if (newAmount>curAmount) - { - m_ScrollControl->m_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - } - Invalidate(); - } - ForceUpdateScrollBars(); - return true; -} -bool TreeControl::OnKeyLeft( bool bDown ) -{ - if (bDown) - { - - avoidUpdate = -3; - - - - iterate(ITERATE_ACTION_CLOSE,0,0); - - int maxItems=0; - int curItem=0; - iterate(ITERATE_ACTION_FIND_SELECTED_INDEX,&maxItems,&curItem); - // float amount = float(curItem)/float(maxItems); - - // m_ScrollControl->m_VerticalScrollBar->SetScrolledAmount(amount,true); - float viewSize = m_ScrollControl->m_VerticalScrollBar->getViewableContentSize(); - float contSize = m_ScrollControl->m_VerticalScrollBar->getContentSize(); - - float curAmount = m_ScrollControl->m_VerticalScrollBar->GetScrolledAmount(); - // float minCoordViewableWindow = curAmount*contSize; - // float maxCoordViewableWindow = minCoordViewableWindow+viewSize; - float minCoordSelectedItem = curItem*16.f; - // float maxCoordSelectedItem = (curItem+1)*16.f; - if (contSize!=viewSize) - { - { - float newAmount = float(minCoordSelectedItem)/(contSize-viewSize); - if (newAmountm_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - } - { - int numItems = (viewSize)/16-1; - float newAmount = float((curItem-numItems)*16)/(contSize-viewSize); - - if (newAmount>curAmount) - { - m_ScrollControl->m_VerticalScrollBar->SetScrolledAmount(newAmount,true); - } - Invalidate(); - } - } - //viewSize/contSize - - //printf("!\n"); - - //this->Layout(0); - - - } - ForceUpdateScrollBars(); - return true; -} diff --git a/btgui/Gwen/Controls/TreeControl.h b/btgui/Gwen/Controls/TreeControl.h deleted file mode 100644 index 79de3e9ff..000000000 --- a/btgui/Gwen/Controls/TreeControl.h +++ /dev/null @@ -1,59 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TREECONTROL_H -#define GWEN_CONTROLS_TREECONTROL_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/TreeNode.h" - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT TreeControl : public TreeNode - { - public: - - GWEN_CONTROL( TreeControl, TreeNode ); - - virtual void Render( Skin::Base* skin ); - - virtual void OnChildBoundsChanged( Gwen::Rect oldChildBounds, Base* pChild ); - - ScrollControl* Scroller() { return m_ScrollControl; } - - virtual void Clear(); - - virtual void Layout( Skin::Base* skin ); - virtual void PostLayout( Skin::Base* skin ); - - virtual void AllowMultiSelect( bool b ){ m_bAllowMultipleSelection = b; } - - virtual void OnNodeAdded( TreeNode* pNode ); - - virtual bool OnKeyUp( bool bDown ); - virtual bool OnKeyDown( bool bDown ); - virtual bool OnKeyRight( bool bDown ); - virtual bool OnKeyLeft( bool bDown ); - - virtual void iterate(int action,int* curIndex, int* resultIndex); - - virtual void ForceUpdateScrollBars(); - - - private: - - void OnNodeSelection( Controls::Base* control ); - - ScrollControl* m_ScrollControl; - bool m_bAllowMultipleSelection; - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/TreeNode.cpp b/btgui/Gwen/Controls/TreeNode.cpp deleted file mode 100644 index 0877c8a46..000000000 --- a/btgui/Gwen/Controls/TreeNode.cpp +++ /dev/null @@ -1,350 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/TreeNode.h" -#include "Gwen/Controls/TreeControl.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -class OpenToggleButton : public Button -{ - GWEN_CONTROL_INLINE ( OpenToggleButton, Button ) - { - SetIsToggle( true ); - SetTabable( false ); - - } - - virtual void RenderFocus( Skin::Base* /*skin*/ ) {} - - virtual void Render( Skin::Base* skin ) - { - skin->DrawTreeButton( this, GetToggleState() ); - } -}; - -const int TreeIndentation = 14; -const int BranchLength = 16; - -GWEN_CONTROL_CONSTRUCTOR( TreeNode ) -{ - m_TreeControl = NULL; - - m_ToggleButton = new OpenToggleButton( this ); - m_ToggleButton->SetBounds( 2, 2, 13, 13 ); - m_ToggleButton->onToggle.Add( this, &TreeNode::OnToggleButtonPress ); - - m_Title = new Button( this ); - m_Title->Dock( Pos::Top ); - m_Title->SetMargin( Margin( BranchLength, 0, 0, 0 ) ); - m_Title->SetAlignment( Pos::Left | Pos::CenterV ); - m_Title->SetShouldDrawBackground( false ); - m_Title->onDoubleClick.Add( this, &TreeNode::OnDoubleClickName ); - m_Title->onDown.Add( this, &TreeNode::OnClickName ); - m_Title->SetHeight( 16 ); - - m_InnerPanel = new Base( this ); - m_InnerPanel->Dock( Pos::Top ); - m_InnerPanel->SetHeight( 100 ); - m_InnerPanel->SetMargin( Margin( TreeIndentation, 1, 0, 0 ) ); - m_InnerPanel->Hide(); - - m_bRoot = false; - m_bSelected = false; - m_bSelectable = true; -} - -void TreeNode::Render( Skin::Base* skin ) -{ - int iBottom = 0; - if ( m_InnerPanel->Children.size() > 0 ) - { - iBottom = m_InnerPanel->Children.back()->Y() + m_InnerPanel->Y(); - } - - skin->DrawTreeNode( this, m_InnerPanel->Visible(), IsSelected(), m_Title->Height(), m_Title->TextRight(), m_ToggleButton->Y() + m_ToggleButton->Height() * 0.5, iBottom, GetParent() == m_TreeControl ); -} - -TreeNode* TreeNode::AddNode( const UnicodeString& strLabel ) -{ -// int sz = sizeof(TreeNode); - TreeNode* node = new TreeNode( this ); - node->SetText( strLabel ); - node->Dock( Pos::Top ); - node->SetRoot( this->DynamicCastTreeControl() != NULL ); - node->SetTreeControl( m_TreeControl ); - - if ( m_TreeControl ) - { - m_TreeControl->OnNodeAdded( node ); - } - - return node; -} - -TreeNode* TreeNode::AddNode( const String& strLabel ) -{ - return AddNode( Utility::StringToUnicode( strLabel ) ); -} - - -void TreeNode::Layout( Skin::Base* skin ) -{ - if ( m_ToggleButton ) - { - if ( m_InnerPanel->NumChildren() == 0 ) - { - m_ToggleButton->Hide(); - m_ToggleButton->SetToggleState( false ); - m_InnerPanel->Hide(); - } - else - { - m_ToggleButton->Show(); - m_InnerPanel->SizeToChildren( false, true ); - } - } - - BaseClass::Layout( skin ); -} -//too many calls to PostLayout... -//int numCalls = 0xfd; -void TreeNode::PostLayout( Skin::Base* /*skin*/ ) -{ - - //int bla = numCalls&0xffff; - //if (bla==0) - // printf("TreeNode::PostLayout numCalls = %d\n", numCalls); - - //numCalls++; - if ( SizeToChildren( false, true ) ) - { - InvalidateParent(); - } -} - -void TreeNode::SetText( const UnicodeString& text ){ m_Title->SetText( text ); }; -void TreeNode::SetText( const String& text ){ m_Title->SetText( text ); }; - -UnicodeString TreeNode::GetText() const -{ - UnicodeString bla = m_Title->GetText(); - return bla; -} - - -void TreeNode::Open() -{ - m_InnerPanel->Show(); - if ( m_ToggleButton ) m_ToggleButton->SetToggleState( true ); - Invalidate(); - m_TreeControl->ForceUpdateScrollBars(); -} - -void TreeNode::Close() -{ - m_InnerPanel->Hide(); - if ( m_ToggleButton ) m_ToggleButton->SetToggleState( false ); - - Invalidate(); - m_TreeControl->ForceUpdateScrollBars(); -} - -void TreeNode::ExpandAll() -{ - Open(); - - Base::List& children = m_InnerPanel->GetChildren(); - for ( Base::List::iterator iter = children.begin(); iter != children.end(); ++iter ) - { - TreeNode* pChild = (*iter)->DynamicCastTreeNode(); - if ( !pChild ) continue; - - pChild->ExpandAll(); - } -} - -Button* TreeNode::GetButton(){ return m_Title; } - - -void TreeNode::OnToggleButtonPress( Base* /*control*/ ) -{ - if ( m_ToggleButton->GetToggleState() ) - { - Open(); - } - else - { - Close(); - } -} - -void TreeNode::OnDoubleClickName( Base* /*control*/ ) -{ - if ( !m_ToggleButton->Visible() ) return; - - m_ToggleButton->Toggle(); -} - -void TreeNode::OnClickName( Base* /*control*/ ) -{ - onNamePress.Call( this ); - - SetSelected( !IsSelected() ); -} - -void TreeNode::SetSelected( bool b ) -{ - if ( !m_bSelectable ) return; - if ( m_bSelected == b ) return; - - m_bSelected = b; - - onSelectChange.Call( this ); - - if ( m_bSelected ) - onSelect.Call( this ); - else - onUnselect.Call( this ); -} - -void TreeNode::DeselectAll() -{ - m_bSelected = false; - - Base::List& children = m_InnerPanel->GetChildren(); - for ( Base::List::iterator iter = children.begin(); iter != children.end(); ++iter ) - { - TreeNode* pChild = (*iter)->DynamicCastTreeNode(); - if ( !pChild ) continue; - - pChild->DeselectAll( ); - } -} - - -void TreeNode::iterate(int action, int* curIndex, int* targetIndex) -{ - - Gwen::String name = Gwen::Utility::UnicodeToString(m_Title->GetText()); - -// int actualIndex = curIndex? *curIndex : -1; - //printf("iterated over item %d with name = %s\n", actualIndex, name.c_str()); - - if (action==ITERATE_ACTION_SELECT) - { - if (curIndex && targetIndex) - { - if ((*curIndex)==(*targetIndex)) - { - SetSelected(true); - - *targetIndex=-1; - } - } - } - - if (IsSelected()) - { - //printf("current selected: name = %s\n", name.c_str()); - switch (action) - { - case ITERATE_ACTION_DESELECT_INDEX: - { - if (targetIndex && curIndex) - { - if (*targetIndex == *curIndex) - SetSelected(false); - } - break; - } - case ITERATE_ACTION_FIND_SELECTED_INDEX: - { - if (targetIndex && curIndex) - { - *targetIndex = *curIndex; - } - break; - } - case ITERATE_ACTION_OPEN: - { - Open(); - - - break; - } - case ITERATE_ACTION_CLOSE: - { - //either close or select parent - if (this->GetChildren().size()) - { - if (m_ToggleButton && m_ToggleButton->GetToggleState()) - { - Close(); - } else - { - - TreeNode* pChild = (GetParent())->DynamicCastTreeNode(); - TreeControl* pChild2 = (GetParent())->DynamicCastTreeControl(); - if (pChild && !pChild2) - { - SetSelected(false); - pChild->SetSelected(true); - } - } - } - else - { - - TreeNode* pChild = (GetParent())->DynamicCastTreeNode(); - TreeControl* pChild2 = (GetParent())->DynamicCastTreeControl(); - if (pChild && !pChild2) - { - SetSelected(false); - pChild->SetSelected(true); - } - } - - break; - } - default: - { - } - }; - } - - if (curIndex) - (*curIndex)++; - - bool needsRecursion = true; - - if (action == ITERATE_ACTION_FIND_SELECTED_INDEX || action==ITERATE_ACTION_SELECT || action==ITERATE_ACTION_DESELECT_INDEX) - { - if (m_ToggleButton && !m_ToggleButton->GetToggleState()) - { - needsRecursion=false; - } - } - - if (needsRecursion) - { - Base::List& children = m_InnerPanel->GetChildren(); - for ( Base::List::iterator iter = children.begin(); iter != children.end(); ++iter ) - { - TreeNode* pChild = (*iter)->DynamicCastTreeNode(); - if ( !pChild ) - continue; - - pChild->iterate(action , curIndex, targetIndex); - } - } - - - -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/TreeNode.h b/btgui/Gwen/Controls/TreeNode.h deleted file mode 100644 index 5cbbcc4bd..000000000 --- a/btgui/Gwen/Controls/TreeNode.h +++ /dev/null @@ -1,103 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_TREENODE_H -#define GWEN_CONTROLS_TREENODE_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/ScrollControl.h" - -enum -{ - ITERATE_ACTION_OPEN=1, - ITERATE_ACTION_CLOSE, - ITERATE_ACTION_FIND_SELECTED_INDEX, - ITERATE_ACTION_DESELECT_INDEX, - ITERATE_ACTION_SELECT, -}; - -namespace Gwen -{ - namespace Controls - { - class TreeControl; - - class GWEN_EXPORT TreeNode : public Base - { - public: - - GWEN_CONTROL( TreeNode, Base ); - - virtual TreeNode* AddNode( const UnicodeString& strLabel ); - virtual TreeNode* AddNode( const String& strLabel ); - - virtual void SetText( const UnicodeString& text ); - virtual void SetText( const String& text ); - UnicodeString GetText() const; - - virtual void Open(); - virtual void Close(); - - virtual void ExpandAll(); - - virtual Button* GetButton(); - - virtual void Render( Skin::Base* skin ); - virtual void Layout( Skin::Base* skin ); - virtual void PostLayout( Skin::Base* skin ); - - virtual void SetRoot( bool b ){ m_bRoot = b; } - virtual void SetTreeControl( TreeControl* pCtrl ){ m_TreeControl = pCtrl; } - - virtual void SetSelectable( bool b ){ m_bSelectable = b; } - virtual bool IsSelected(){ return m_bSelected; } - virtual void SetSelected( bool b ); - - virtual void DeselectAll(); - - virtual void iterate(int action, int* curIndex, int* resultIndex); - virtual bool OnKeyReturn(bool bDown) - { - static bool prevDown = false; - if (!prevDown && bDown) - { - onReturnKeyDown.Call(this); - } - prevDown = bDown; - return Base::OnKeyReturn(bDown); - } - - Event::Caller onReturnKeyDown; - - Event::Caller onNamePress; - Event::Caller onSelectChange; - Event::Caller onSelect; - Event::Caller onUnselect; - - protected: - - void OnToggleButtonPress( Base* control ); - void OnDoubleClickName( Base* control ); - void OnClickName( Base* control ); - - - - TreeControl* m_TreeControl; - Button* m_ToggleButton; - Button* m_Title; - - bool m_bRoot; - bool m_bSelected; - bool m_bSelectable; - int m_bUpdateScrollBar; - - }; - - } -} -#endif diff --git a/btgui/Gwen/Controls/VerticalScrollBar.cpp b/btgui/Gwen/Controls/VerticalScrollBar.cpp deleted file mode 100644 index 62042325e..000000000 --- a/btgui/Gwen/Controls/VerticalScrollBar.cpp +++ /dev/null @@ -1,138 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Controls/VerticalScrollBar.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -GWEN_CONTROL_CONSTRUCTOR( VerticalScrollBar ) -{ - m_Bar->SetVertical(); - - m_ScrollButton[SCROLL_BUTTON_UP]->SetDirectionUp(); - m_ScrollButton[SCROLL_BUTTON_UP]->onPress.Add( this, &VerticalScrollBar::NudgeUp ); - - m_ScrollButton[SCROLL_BUTTON_DOWN]->SetDirectionDown(); - m_ScrollButton[SCROLL_BUTTON_DOWN]->onPress.Add( this, &VerticalScrollBar::NudgeDown ); - - m_Bar->onDragged.Add( this, &VerticalScrollBar::OnBarMoved ); -} - -void VerticalScrollBar::Layout( Skin::Base* skin ) -{ - BaseClass::Layout( skin ); - - m_ScrollButton[SCROLL_BUTTON_UP]->Dock(Pos::Top); - m_ScrollButton[SCROLL_BUTTON_UP]->SetHeight( Width() ); - - m_ScrollButton[SCROLL_BUTTON_DOWN]->Dock(Pos::Bottom); - m_ScrollButton[SCROLL_BUTTON_DOWN]->SetHeight( Width() ); - - m_Bar->SetWidth( GetButtonSize() ); - //Add padding - m_Bar->SetPadding( Padding(0, GetButtonSize(), 0, GetButtonSize() ) ); - - //Calculate bar sizes - float barHeight = (m_fViewableContentSize / m_fContentSize) * (Height() - (GetButtonSize() * 2)); - - if ( barHeight < GetButtonSize() * 0.5 ) - barHeight = GetButtonSize() * 0.5; - - m_Bar->SetHeight(barHeight); - m_Bar->SetHidden( Height() - (GetButtonSize() * 2) <= barHeight ); - - if ( Hidden() ) - SetScrolledAmount(0, true); - - //Based on our last scroll amount, produce a position for the bar - if ( !m_Bar->IsDepressed() ) - { - SetScrolledAmount( GetScrolledAmount(), true ); - } -} - -void VerticalScrollBar::ScrollToTop() -{ - SetScrolledAmount(0, true); -} -void VerticalScrollBar::ScrollToBottom() -{ - SetScrolledAmount(1, true); -} -void VerticalScrollBar::NudgeUp( Base* /*control*/ ) -{ - if ( !IsDisabled() ) - SetScrolledAmount(GetScrolledAmount() - GetNudgeAmount(), true); -} - -void VerticalScrollBar::NudgeDown( Base* /*control*/ ) -{ - if ( !IsDisabled() ) - SetScrolledAmount(GetScrolledAmount() + GetNudgeAmount(), true); -} - -float VerticalScrollBar::GetNudgeAmount() -{ - if ( m_bDepressed ) - return m_fViewableContentSize / m_fContentSize; - else - return BaseClass::GetNudgeAmount(); -} - -void VerticalScrollBar::OnMouseClickLeft( int x, int y, bool bDown ) -{ - if ( bDown ) - { - m_bDepressed = true; - Gwen::MouseFocus = this; - } - else - { - Gwen::Point clickPos = CanvasPosToLocal( Gwen::Point( x, y ) ); - if ( clickPos.y < m_Bar->Y() ) - NudgeUp( this ); - else if ( clickPos.y > m_Bar->Y() + m_Bar->Height() ) - NudgeDown( this ); - - m_bDepressed = false; - Gwen::MouseFocus = NULL; - } -} - -float VerticalScrollBar::CalculateScrolledAmount() -{ - return (float)(m_Bar->Y() - GetButtonSize()) / (float)(Height() - m_Bar->Height() - (GetButtonSize() * 2 )); -} - -bool VerticalScrollBar::SetScrolledAmount(float amount, bool forceUpdate) -{ - amount = Gwen::Clamp( amount, 0, 1 ); - - if ( !BaseClass::SetScrolledAmount( amount, forceUpdate ) ) - return false; - - if ( forceUpdate ) - { - int newY = GetButtonSize() + (amount * ((Height() - m_Bar->Height()) - (GetButtonSize()*2))); - m_Bar->MoveTo( m_Bar->X(), newY); - } - - return true; -} - -void VerticalScrollBar::OnBarMoved( Controls::Base* control ) -{ - if ( m_Bar->IsDepressed() ) - { - SetScrolledAmount( CalculateScrolledAmount(), false ); - BaseClass::OnBarMoved(control); - } - else - InvalidateParent(); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/VerticalScrollBar.h b/btgui/Gwen/Controls/VerticalScrollBar.h deleted file mode 100644 index f86a1f9e0..000000000 --- a/btgui/Gwen/Controls/VerticalScrollBar.h +++ /dev/null @@ -1,47 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_VERTICALSCROLLBAR_H -#define GWEN_CONTROLS_VERTICALSCROLLBAR_H -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/ScrollBar.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - -namespace Gwen -{ - namespace Controls - { - - class GWEN_EXPORT VerticalScrollBar : public BaseScrollBar - { - - GWEN_CONTROL( VerticalScrollBar, BaseScrollBar ); - - virtual void Layout( Skin::Base* skin ); - - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - virtual void OnBarMoved( Controls::Base* control ); - - virtual int GetBarSize() { return m_Bar->Height(); } - virtual int GetBarPos() { return m_Bar->Y() - Width(); } - virtual void SetBarSize( int size ) { m_Bar->SetHeight( size ); } - virtual int GetButtonSize() { return Width(); } - - virtual void ScrollToTop(); - virtual void ScrollToBottom(); - virtual void NudgeUp( Base* control ); - virtual void NudgeDown( Base* control ); - virtual float GetNudgeAmount(); - - virtual float CalculateScrolledAmount(); - virtual bool SetScrolledAmount(float amount, bool forceUpdate); - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/VerticalSlider.cpp b/btgui/Gwen/Controls/VerticalSlider.cpp deleted file mode 100644 index 24881bcf3..000000000 --- a/btgui/Gwen/Controls/VerticalSlider.cpp +++ /dev/null @@ -1,48 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/Slider.h" -#include "Gwen/Controls/VerticalSlider.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - - -GWEN_CONTROL_CONSTRUCTOR( VerticalSlider ) -{ -} - -float VerticalSlider::CalculateValue() -{ - return 1 - (float)m_SliderBar->Y() / (float)( Height() - m_SliderBar->Height() ); -} - -void VerticalSlider::UpdateBarFromValue() -{ - m_SliderBar->MoveTo( m_SliderBar->X(), ( Height() - m_SliderBar->Height() ) * ( 1 - m_fValue )); -} - - -void VerticalSlider::OnMouseClickLeft( int x, int y, bool bDown ) -{ - m_SliderBar->MoveTo( m_SliderBar->X(), CanvasPosToLocal( Gwen::Point( x, y ) ).y - m_SliderBar->Height() * 0.5 ); - m_SliderBar->OnMouseClickLeft( x, y, bDown ); - OnMoved( m_SliderBar ); -} - - -void VerticalSlider::Layout(Skin::Base* /*skin*/) -{ - m_SliderBar->SetSize( Width(), 10 ); -} - - -void VerticalSlider::Render( Skin::Base* skin ) -{ - skin->DrawSlider( this, false, m_bClampToNotches ? m_iNumNotches : 0, m_SliderBar->Height() ); -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/VerticalSlider.h b/btgui/Gwen/Controls/VerticalSlider.h deleted file mode 100644 index 89ade9a91..000000000 --- a/btgui/Gwen/Controls/VerticalSlider.h +++ /dev/null @@ -1,37 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_VERTICALSLIDER_H -#define GWEN_CONTROLS_VERTICALSLIDER_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Slider.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT VerticalSlider : public Slider - { - GWEN_CONTROL( VerticalSlider, Slider ); - - virtual void Layout( Skin::Base* skin ); - virtual void Render( Skin::Base* skin ); - - virtual float CalculateValue(); - virtual void UpdateBarFromValue(); - virtual void OnMouseClickLeft( int x, int y, bool bDown ); - - }; - } -} -#endif diff --git a/btgui/Gwen/Controls/WindowControl.cpp b/btgui/Gwen/Controls/WindowControl.cpp deleted file mode 100644 index d45a01b43..000000000 --- a/btgui/Gwen/Controls/WindowControl.cpp +++ /dev/null @@ -1,150 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/ImagePanel.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/Modal.h" - -using namespace Gwen; -using namespace Gwen::Controls; -using namespace Gwen::ControlsInternal; - -GWEN_CONTROL_CONSTRUCTOR( WindowControl ) -{ - m_Modal = NULL; - m_bInFocus = false; - m_bDeleteOnClose = false; - - m_TitleBar = new Dragger( this ); - m_TitleBar->Dock( Pos::Top ); - m_TitleBar->SetHeight( 18 ); - m_TitleBar->SetPadding( Padding( 0, 0, 0, 5 ) ); - m_TitleBar->SetTarget( this ); - - m_Title = new Label( m_TitleBar ); - m_Title->SetAlignment( Pos::Center ); - m_Title->SetText( "Window" ); - m_Title->SetTextColor(Gwen::Colors::White); - m_Title->Dock( Pos::Fill ); - - m_CloseButton = new Button( m_TitleBar ); - m_CloseButton->SetText( "" ); - m_CloseButton->SetSize( m_TitleBar->Height(), m_TitleBar->Height() ); - m_CloseButton->Dock(Pos::Right); - m_CloseButton->onPress.Add( this, &WindowControl::CloseButtonPressed ); - m_CloseButton->SetTabable( false ); - m_CloseButton->SetName( "closeButton" ); - - //Create a blank content control, dock it to the top - Should this be a ScrollControl? - m_InnerPanel = new Base( this ); - m_InnerPanel->Dock( Pos::Fill ); - - BringToFront(); - - SetTabable( false ); - Focus(); - - SetMinimumSize( Gwen::Point( 100, 40 ) ); - SetClampMovement( true ); - SetKeyboardInputEnabled( false ); -} - - -WindowControl::~WindowControl() -{ - if ( m_Modal ) - { - m_Modal->DelayedDelete(); - } -} - -void WindowControl::MakeModal( bool invisible ) -{ - if ( m_Modal ) return; - - m_Modal = new ControlsInternal::Modal( GetCanvas() ); - SetParent( m_Modal ); - - if ( invisible ) - { - m_Modal->SetShouldDrawBackground( false ); - } -} - -bool WindowControl::IsOnTop() -{ - for (Base::List::reverse_iterator iter = GetParent()->Children.rbegin(); iter != GetParent()->Children.rend(); ++iter) - { - if (!*iter) - continue; - - WindowControl* pWindow = (*iter)->DynamicCastWindowControl(); - - if ( !pWindow ) - continue; - - if ( pWindow == this ) - return true; - - return false; - } - - return false; - -} - -void WindowControl::Render( Skin::Base* skin ) -{ - //This should use m_bInFocus but I need to figure out best way to make layout happen - skin->DrawWindow( this, m_TitleBar->Bottom(), IsOnTop() ); -} - -void WindowControl::RenderUnder( Skin::Base* skin ) -{ - BaseClass::RenderUnder( skin ); - skin->DrawShadow( this ); -} - -void WindowControl::SetTitle(Gwen::UnicodeString title) -{ - m_Title->SetText( title ); -} -void WindowControl::SetClosable(bool closeable) -{ - m_CloseButton->SetHidden( !closeable ); -} - -void WindowControl::SetHidden(bool hidden) -{ - if ( !hidden ) - BringToFront(); - - BaseClass::SetHidden(hidden); -} - -void WindowControl::Touch() -{ - BaseClass::Touch(); - BringToFront(); - m_bInFocus = IsOnTop(); - //If Keyboard focus isn't one of our children, make it us -} - -void WindowControl::CloseButtonPressed( Gwen::Controls::Base* /*pFromPanel*/ ) -{ - SetHidden( true ); - - if ( m_bDeleteOnClose ) - DelayedDelete(); -} - - -void WindowControl::RenderFocus( Gwen::Skin::Base* /*skin*/ ) -{ - -} \ No newline at end of file diff --git a/btgui/Gwen/Controls/WindowControl.h b/btgui/Gwen/Controls/WindowControl.h deleted file mode 100644 index a9e0fbc84..000000000 --- a/btgui/Gwen/Controls/WindowControl.h +++ /dev/null @@ -1,63 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_CONTROLS_WINDOWCONTROL_H -#define GWEN_CONTROLS_WINDOWCONTROL_H - -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/Button.h" -#include "Gwen/Controls/Dragger.h" -#include "Gwen/Controls/Label.h" -#include "Gwen/Controls/ResizableControl.h" -#include "Gwen/Controls/Modal.h" -#include "Gwen/Skin.h" - - -namespace Gwen -{ - namespace Controls - { - class GWEN_EXPORT WindowControl : public ResizableControl - { - public: - - GWEN_CONTROL( WindowControl, ResizableControl ); - - virtual ~WindowControl(); - virtual void Render( Skin::Base* skin ); - virtual void RenderUnder( Skin::Base* skin ); - - virtual void SetTitle( Gwen::UnicodeString title ); - virtual void SetTitle( Gwen::String title ){ SetTitle( Gwen::Utility::StringToUnicode( title ) ); } - virtual void SetClosable(bool closeable); - - virtual void Touch(); - bool IsOnTop(); - - virtual void SetHidden(bool hidden); - - void CloseButtonPressed( Gwen::Controls::Base* pFromPanel ); - void RenderFocus( Gwen::Skin::Base* skin ); - void SetDeleteOnClose( bool b ){ m_bDeleteOnClose = b; } - void MakeModal(bool invisible = false); - - protected: - - ControlsInternal::Dragger* m_TitleBar; - Label* m_Title; - Button* m_CloseButton; - - bool m_bInFocus; - bool m_bDeleteOnClose; - - ControlsInternal::Modal* m_Modal; - }; - } -} -#endif diff --git a/btgui/Gwen/DragAndDrop.cpp b/btgui/Gwen/DragAndDrop.cpp deleted file mode 100644 index 94193d7a2..000000000 --- a/btgui/Gwen/DragAndDrop.cpp +++ /dev/null @@ -1,238 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Utility.h" -#include "Gwen/Platform.h" - -using namespace Gwen; -using namespace Gwen::DragAndDrop; - -DragAndDrop::Package* DragAndDrop::CurrentPackage = NULL; -Gwen::Controls::Base* DragAndDrop::HoveredControl = NULL; -Gwen::Controls::Base* DragAndDrop::SourceControl = NULL; - -static Gwen::Controls::Base* LastPressedControl = NULL; -static Gwen::Controls::Base* NewHoveredControl = NULL; -static Gwen::Point LastPressedPos; - -void DragAndDrop::ControlDeleted( Gwen::Controls::Base* pControl ) -{ - if ( SourceControl == pControl ) - { - SourceControl = NULL; - CurrentPackage = NULL; - HoveredControl = NULL; - LastPressedControl = NULL; - } - - if ( LastPressedControl == pControl ) - LastPressedControl = NULL; - - if ( HoveredControl == pControl ) - HoveredControl = NULL; - - if ( NewHoveredControl == pControl ) - NewHoveredControl = NULL; -} - -static int m_iMouseX = 0; -static int m_iMouseY = 0; - -bool DragAndDrop::Start( Gwen::Controls::Base* pControl, Package* pPackage ) -{ - if ( CurrentPackage ) - { - return false; - } - - CurrentPackage = pPackage; - SourceControl = pControl; - return true; -} - -bool OnDrop( int x, int y ) -{ - bool bSuccess = false; - - if ( DragAndDrop::HoveredControl ) - { - DragAndDrop::HoveredControl->DragAndDrop_HoverLeave( DragAndDrop::CurrentPackage ); - bSuccess = DragAndDrop::HoveredControl->DragAndDrop_HandleDrop( DragAndDrop::CurrentPackage, x, y ); - } - - // Report back to the source control, to tell it if we've been successful. - DragAndDrop::SourceControl->DragAndDrop_EndDragging( bSuccess, x, y ); - - DragAndDrop::CurrentPackage = NULL; - DragAndDrop::SourceControl = NULL; - - return true; -} - -bool DragAndDrop::OnMouseButton( Gwen::Controls::Base* pHoveredControl, int x, int y, bool bDown ) -{ - if ( !bDown ) - { - LastPressedControl = NULL; - - // Not carrying anything, allow normal actions - if ( !CurrentPackage ) - return false; - - // We were carrying something, drop it. - OnDrop( x, y ); - return true; - } - - if ( !pHoveredControl ) return false; - if ( !pHoveredControl->DragAndDrop_Draggable() ) return false; - - // Store the last clicked on control. Don't do anything yet, - // we'll check it in OnMouseMoved, and if it moves further than - // x pixels with the mouse down, we'll start to drag. - LastPressedPos = Gwen::Point( x, y ); - LastPressedControl = pHoveredControl; - - return false; -} - -bool ShouldStartDraggingControl( int x, int y ) -{ - // We're not holding a control down.. - if ( !LastPressedControl ) return false; - - // Not been dragged far enough - int iLength = abs( x - LastPressedPos.x ) + abs( y - LastPressedPos.y ); - if ( iLength < 5 ) return false; - - // Create the dragging package - - DragAndDrop::CurrentPackage = LastPressedControl->DragAndDrop_GetPackage( LastPressedPos.x, LastPressedPos.y ); - - // We didn't create a package! - if ( !DragAndDrop::CurrentPackage ) - { - LastPressedControl = NULL; - DragAndDrop::SourceControl = NULL; - return false; - } - - - - // Now we're dragging something! - DragAndDrop::SourceControl = LastPressedControl; - Gwen::MouseFocus = NULL; - LastPressedControl = NULL; - DragAndDrop::CurrentPackage->drawcontrol = NULL; - - // Some controls will want to decide whether they should be dragged at that moment. - // This function is for them (it defaults to true) - if ( !DragAndDrop::SourceControl->DragAndDrop_ShouldStartDrag() ) - { - DragAndDrop::SourceControl = NULL; - DragAndDrop::CurrentPackage = NULL; - return false; - } - - DragAndDrop::SourceControl->DragAndDrop_StartDragging( DragAndDrop::CurrentPackage, LastPressedPos.x, LastPressedPos.y ); - - return true; - -} - -void UpdateHoveredControl( Gwen::Controls::Base* pCtrl, int x, int y ) -{ - // - // We use this global variable to represent our hovered control - // That way, if the new hovered control gets deleted in one of the - // Hover callbacks, we won't be left with a hanging pointer. - // This isn't ideal - but it's minimal. - // - NewHoveredControl = pCtrl; - - // Nothing to change.. - if ( DragAndDrop::HoveredControl == NewHoveredControl ) return; - - // We changed - tell the old hovered control that it's no longer hovered. - if ( DragAndDrop::HoveredControl && DragAndDrop::HoveredControl != NewHoveredControl ) - DragAndDrop::HoveredControl->DragAndDrop_HoverLeave( DragAndDrop::CurrentPackage ); - - // If we're hovering where the control came from, just forget it. - // By changing it to NULL here we're not going to show any error cursors - // it will just do nothing if you drop it. - if ( NewHoveredControl == DragAndDrop::SourceControl ) - NewHoveredControl = NULL; - - // Check to see if the new potential control can accept this type of package. - // If not, ignore it and show an error cursor. - while ( NewHoveredControl && !NewHoveredControl->DragAndDrop_CanAcceptPackage( DragAndDrop::CurrentPackage ) ) - { - // We can't drop on this control, so lets try to drop - // onto its parent.. - NewHoveredControl = NewHoveredControl->GetParent(); - - // Its parents are dead. We can't drop it here. - // Show the NO WAY cursor. - if ( !NewHoveredControl ) - { - Platform::SetCursor( CursorType::No ); - } - } - - // Become out new hovered control - DragAndDrop::HoveredControl = NewHoveredControl; - - // If we exist, tell us that we've started hovering. - if ( DragAndDrop::HoveredControl ) - { - DragAndDrop::HoveredControl->DragAndDrop_HoverEnter( DragAndDrop::CurrentPackage, x, y ); - } - - NewHoveredControl = NULL; -} - -void DragAndDrop::OnMouseMoved( Gwen::Controls::Base* pHoveredControl, int x, int y ) -{ - // Always keep these up to date, they're used to draw the dragged control. - m_iMouseX = x; - m_iMouseY = y; - - // If we're not carrying anything, then check to see if we should - // pick up from a control that we're holding down. If not, then forget it. - if ( !CurrentPackage && !ShouldStartDraggingControl( x, y ) ) - return; - - // Swap to this new hovered control and notify them of the change. - UpdateHoveredControl( pHoveredControl, x, y ); - - if ( !HoveredControl ) return; - - // Update the hovered control every mouse move, so it can show where - // the dropped control will land etc.. - HoveredControl->DragAndDrop_Hover( CurrentPackage, x, y ); - - // Override the cursor - since it might have been set my underlying controls - // Ideally this would show the 'being dragged' control. TODO - Platform::SetCursor( CursorType::Normal ); - - pHoveredControl->Redraw(); -} - -void DragAndDrop::RenderOverlay( Gwen::Controls::Canvas* /*pCanvas*/, Skin::Base* skin ) -{ - if ( !CurrentPackage ) return; - if ( !CurrentPackage->drawcontrol ) return; - - Gwen::Point pntOld = skin->GetRender()->GetRenderOffset(); - - skin->GetRender()->AddRenderOffset( Gwen::Rect( m_iMouseX - SourceControl->X() - CurrentPackage->holdoffset.x, m_iMouseY - SourceControl->Y() - CurrentPackage->holdoffset.y, 0, 0 ) ); - CurrentPackage->drawcontrol->DoRender( skin ); - - skin->GetRender()->SetRenderOffset( pntOld ); -} \ No newline at end of file diff --git a/btgui/Gwen/DragAndDrop.h b/btgui/Gwen/DragAndDrop.h deleted file mode 100644 index cdbd9074e..000000000 --- a/btgui/Gwen/DragAndDrop.h +++ /dev/null @@ -1,35 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_DRAGANDDROP_H -#define GWEN_DRAGANDDROP_H - -#include - -#include "Gwen/Skin.h" -#include "Gwen/Structures.h" - -namespace Gwen -{ - namespace DragAndDrop - { - extern GWEN_EXPORT Package* CurrentPackage; - extern GWEN_EXPORT Gwen::Controls::Base* SourceControl; - extern GWEN_EXPORT Gwen::Controls::Base* HoveredControl; - - bool GWEN_EXPORT Start( Gwen::Controls::Base* pControl, Package* pPackage ); - - bool GWEN_EXPORT OnMouseButton( Gwen::Controls::Base* pHoveredControl, int x, int y, bool bDown ); - void GWEN_EXPORT OnMouseMoved( Gwen::Controls::Base* pHoveredControl, int x, int y ); - - void GWEN_EXPORT RenderOverlay( Gwen::Controls::Canvas* pCanvas, Skin::Base* skin ); - - void GWEN_EXPORT ControlDeleted( Gwen::Controls::Base* pControl ); - } - -} -#endif diff --git a/btgui/Gwen/Events.h b/btgui/Gwen/Events.h deleted file mode 100644 index 4f8eb4438..000000000 --- a/btgui/Gwen/Events.h +++ /dev/null @@ -1,92 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_EVENTS_H -#define GWEN_EVENTS_H - -#include -#include "Gwen/Exports.h" -#include "Gwen/Structures.h" - -// TODO: REMOVE THIS - IT SUCKS. Template the function instead. -#define GWEN_MCALL( fnc ) this, (Gwen::Event::Handler::Function)&fnc - -namespace Gwen -{ - namespace Controls - { - class Base; - } - - namespace Event - { - - class Caller; - - // A class must be derived from this - class GWEN_EXPORT Handler - { - public: - - Handler(); - virtual ~Handler(); - - void RegisterCaller( Caller* ); - void UnRegisterCaller( Caller* ); - - protected: - - void CleanLinks(); - std::list m_Callers; - - public: - - typedef void (Handler::*Function)( Gwen::Controls::Base* pFromPanel ); - typedef void (Handler::*FunctionStr)( const Gwen::String& string ); - - }; - - - - // - // - // - class GWEN_EXPORT Caller - { - public: - - Caller(); - ~Caller(); - - void Call( Controls::Base* pThis ); - - template - void Add( Event::Handler* ob, T f ) - { - AddInternal( ob, static_cast(f) ); - } - - void RemoveHandler( Event::Handler* pObject ); - - protected: - - void CleanLinks(); - void AddInternal( Event::Handler* pObject, Handler::Function pFunction ); - - struct handler - { - Handler::Function fnFunction; - Event::Handler* pObject; - }; - - std::list m_Handlers; - }; - - } - -} -#endif diff --git a/btgui/Gwen/Exports.h b/btgui/Gwen/Exports.h deleted file mode 100644 index afa8d7271..000000000 --- a/btgui/Gwen/Exports.h +++ /dev/null @@ -1,32 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_EXPORTS_H -#define GWEN_EXPORTS_H - - - -#define GWEN_EXPORT - - -#ifdef _MSC_VER - - #define GWEN_FINLINE __forceinline - #define GWEN_PURE_INTERFACE __declspec(novtable) - -#elif defined(__GNUC__) - - #define GWEN_FINLINE __attribute__((always_inline)) inline - #define GWEN_PUREINTERFACE - -#else - - #define GWEN_FINLINE inline - #define GWEN_PUREINTERFACE - -#endif -#endif diff --git a/btgui/Gwen/Font.h b/btgui/Gwen/Font.h deleted file mode 100644 index 6579742b8..000000000 --- a/btgui/Gwen/Font.h +++ /dev/null @@ -1,52 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_FONT_H -#define GWEN_FONT_H - -#include -#include - -#include "Gwen/BaseRender.h" - -namespace Gwen -{ - - struct Font - { - typedef std::list List; - - Font() - { - data = NULL; - - facename = L"Arial"; - size = 10; - - dropshadow = false; - bold = false; - - } - - UnicodeString facename; - float size; - bool bold; - bool dropshadow; - - // This should be set by the renderer - // if it tries to use a font where it's - // NULL. - void* data; - - // This is the real font size, after it's - // been scaled by Render->Scale() - float realsize; - - }; - -} //namespace Gwen -#endif diff --git a/btgui/Gwen/Gwen.cpp b/btgui/Gwen/Gwen.cpp deleted file mode 100644 index 9836bde4a..000000000 --- a/btgui/Gwen/Gwen.cpp +++ /dev/null @@ -1,52 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" - - -namespace Gwen -{ - // Globals - GWEN_EXPORT Controls::Base* HoveredControl = NULL; - GWEN_EXPORT Controls::Base* KeyboardFocus = NULL; - GWEN_EXPORT Controls::Base* MouseFocus = NULL; - - namespace Debug - { - void Msg( const char* str, ... ) - { - char strOut[1024]; - va_list s; - va_start( s, str ); - GwenUtil_VSNPrintFSafe( strOut, sizeof(strOut), _TRUNCATE, str, s ); - va_end(s); - GwenUtil_OutputDebugCharString( strOut ); - } -#ifdef UNICODE - void Msg( const wchar_t* str, ... ) - { - wchar_t strOut[1024]; - va_list s; - va_start( s, str ); - GwenUtil_VSWPrintFSafeSized( strOut, str, s ); - va_end(s); - GwenUtil_OutputDebugWideString( strOut ); - } -#endif - void AssertCheck( bool b, const char* strMsg ) - { - if ( b ) return; -#ifdef WINDOWS - MessageBoxA( NULL, strMsg, "Assert", MB_ICONEXCLAMATION | MB_OK ); - _asm { int 3 } -#else - (void)strMsg; // unused param -#endif - } - } - -} diff --git a/btgui/Gwen/Gwen.h b/btgui/Gwen/Gwen.h deleted file mode 100644 index 244db70b9..000000000 --- a/btgui/Gwen/Gwen.h +++ /dev/null @@ -1,86 +0,0 @@ -/* - GWEN - - Copyright (c) 2010 Facepunch Studios - - MIT License - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. -*/ - -#pragma once -#ifndef GWEN_GWEN_H -#define GWEN_GWEN_H - -#include "Gwen/Macros.h" -#include "Gwen/Config.h" -#include "Gwen/Exports.h" -#include "Gwen/Structures.h" -#include "Gwen/Skin.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Controls/Canvas.h" -#include "Gwen/Align.h" -#include "Gwen/TextObject.h" - -// Enable the hook system (se Hook.h) -#define GWEN_HOOKSYSTEM - -namespace Gwen -{ - namespace Controls - { - class Base; - class Canvas; - } - - namespace Renderer - { - class Base; - } - - namespace Debug - { - void GWEN_EXPORT Msg( const wchar_t* str, ... ); - void GWEN_EXPORT Msg( const char* str, ... ); - void GWEN_EXPORT AssertCheck( bool b, const char* strMsg ); - } - - - namespace Colors - { - static const Color Black ( 0, 0, 0, 255 ); - static const Color Red ( 255, 0, 0, 255 ); - static const Color Yellow ( 255, 255, 0, 255 ); - static const Color White ( 255, 255, 255, 255 ); - static const Color Blue ( 0, 0, 255, 255 ); - static const Color Green ( 0, 255, 0, 255 ); - static const Color Grey ( 200, 200, 200, 255 ); - static const Color GreyLight( 230, 230, 230, 255 ); - static const Color GwenPink ( 255, 65, 199, 255 ); - - - }; - - extern GWEN_EXPORT Controls::Base* HoveredControl; - extern GWEN_EXPORT Controls::Base* KeyboardFocus; - extern GWEN_EXPORT Controls::Base* MouseFocus; - -} //namespace Gwen - -#endif diff --git a/btgui/Gwen/Hook.cpp b/btgui/Gwen/Hook.cpp deleted file mode 100644 index 6d28798d4..000000000 --- a/btgui/Gwen/Hook.cpp +++ /dev/null @@ -1,32 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Hook.h" - -#ifdef GWEN_HOOKSYSTEM - -using namespace Gwen; -using namespace Gwen::Hook; - -std::list g_HookList; - -void Gwen::Hook::AddHook( BaseHook* pHook ) -{ - g_HookList.push_back( pHook ); -} - -void Gwen::Hook::RemoveHook( BaseHook* pHook ) -{ - g_HookList.remove( pHook ); -} - -HookList& Gwen::Hook::GetHookList() -{ - return g_HookList; -} - -#endif \ No newline at end of file diff --git a/btgui/Gwen/Hook.h b/btgui/Gwen/Hook.h deleted file mode 100644 index e42814cd8..000000000 --- a/btgui/Gwen/Hook.h +++ /dev/null @@ -1,82 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_HOOK_H -#define GWEN_HOOK_H - -#include "Gwen/Gwen.h" -#include - -#ifdef GWEN_HOOKSYSTEM - -namespace Gwen -{ - namespace Hook - { - class GWEN_EXPORT BaseHook - { - public: - - virtual bool OnControlClicked( Gwen::Controls::Base*, int /*iMouseX*/, int /*iMouseY*/ ){ return false; }; - }; - - typedef std::list HookList; - - GWEN_EXPORT HookList& GetHookList(); - - GWEN_EXPORT void AddHook( BaseHook* pHook ); - GWEN_EXPORT void RemoveHook( BaseHook* pHook ); - - template< typename fnc > - bool CallHook( fnc f ) - { - for ( HookList::iterator it = GetHookList().begin(); it != GetHookList().end(); ++it ) - { - if ( ((*it)->*f)() ) return true; - } - - return false; - } - - template< typename fnc, typename AA > - bool CallHook( fnc f, AA a ) - { - for ( HookList::iterator it = GetHookList().begin(); it != GetHookList().end(); ++it ) - { - if ( ((*it)->*f)( a ) ) return true; - } - - return false; - } - - template< typename fnc, typename AA, typename AB > - bool CallHook( fnc f, AA a, AB b ) - { - for ( HookList::iterator it = GetHookList().begin(); it != GetHookList().end(); ++it ) - { - if ( ((*it)->*f)( a, b ) ) return true; - } - - return false; - } - - template< typename fnc, typename AA, typename AB, typename AC > - bool CallHook( fnc f, AA a, AB b, AC c ) - { - for ( HookList::iterator it = GetHookList().begin(); it != GetHookList().end(); ++it ) - { - if ( ((*it)->*f)( a, b, c ) ) return true; - } - - return false; - } - } - -} - -#endif -#endif diff --git a/btgui/Gwen/Input/SDL13.h b/btgui/Gwen/Input/SDL13.h deleted file mode 100644 index 0052809b1..000000000 --- a/btgui/Gwen/Input/SDL13.h +++ /dev/null @@ -1,117 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ -#ifndef GWEN_INPUT_SDL13_H -#define GWEN_INPUT_SDL13_H - -#include "Gwen/InputHandler.h" -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Canvas.h" - -#ifdef _WIN32 -#define UCS_STRING "UCS-2" -#else -#define UCS_STRING "UCS-4" -#endif - -namespace Gwen -{ - namespace Input - { - class SDL13 - { - public: - - SDL13() - { - m_Canvas = NULL; - } - - void Initialize( Gwen::Controls::Canvas* c ) - { - m_Canvas = c; - } - - bool ProcessEvent( SDL_Event* Event ) - { - if (!m_Canvas) return false; - - switch(Event->type) - { - case SDL_KEYUP: - case SDL_KEYDOWN: - { - SDL_KeyboardEvent* E = &Event->key; - int iKey = -1; - SDL_scancode scancode = E->keysym.scancode; - switch (scancode) { - case SDL_SCANCODE_RETURN: iKey = Gwen::Key::Return; break; - case SDL_SCANCODE_BACKSPACE: iKey = Gwen::Key::Backspace; break; - case SDL_SCANCODE_DELETE: iKey = Gwen::Key::Delete; break; - case SDL_SCANCODE_LEFT: iKey = Gwen::Key::Left; break; - case SDL_SCANCODE_RIGHT: iKey = Gwen::Key::Right; break; - case SDL_SCANCODE_LSHIFT: iKey = Gwen::Key::Shift; break; - case SDL_SCANCODE_RSHIFT: iKey = Gwen::Key::Shift; break; - case SDL_SCANCODE_TAB: iKey = Gwen::Key::Tab; break; - case SDL_SCANCODE_SPACE: iKey = Gwen::Key::Space; break; - case SDL_SCANCODE_HOME: iKey = Gwen::Key::Home; break; - case SDL_SCANCODE_END: iKey = Gwen::Key::End; break; - case SDL_SCANCODE_LCTRL: iKey = Gwen::Key::Control; break; - case SDL_SCANCODE_RCTRL: iKey = Gwen::Key::Control; break; - case SDL_SCANCODE_UP: iKey = Gwen::Key::Up; break; - case SDL_SCANCODE_DOWN: iKey = Gwen::Key::Down; break; - case SDL_SCANCODE_ESCAPE: iKey = Gwen::Key::Escape; break; - case SDL_SCANCODE_LALT: iKey = Gwen::Key::Alt; break; - case SDL_SCANCODE_RALT: iKey = Gwen::Key::Alt; break; - default: return false; - } - return m_Canvas->InputKey(iKey, E->state); - } - case SDL_TEXTINPUT: - { - SDL_TextInputEvent* E = &Event->text; - wchar_t* widechar = (wchar_t*)SDL_iconv_string(UCS_STRING, "UTF-8", E->text, SDL_strlen(E->text)+1); - bool ret = m_Canvas->InputCharacter(*widechar); - SDL_free(widechar); - return ret; - } - case SDL_MOUSEMOTION: - { - SDL_MouseMotionEvent* E = &Event->motion; - return m_Canvas->InputMouseMoved(E->x, E->y, E->xrel, E->yrel); - } - case SDL_MOUSEBUTTONDOWN: - case SDL_MOUSEBUTTONUP: - { - SDL_MouseButtonEvent* E = &Event->button; - int Button = -1; - switch (E->button) { - case SDL_BUTTON_LEFT: Button = 0; break; - case SDL_BUTTON_MIDDLE: Button = 2; break; - case SDL_BUTTON_RIGHT: Button = 1; break; - default: return false; - } - return m_Canvas->InputMouseButton(Button, E->state); - } - case SDL_MOUSEWHEEL: - { - SDL_MouseWheelEvent* E = &Event->wheel; - return m_Canvas->InputMouseWheel(E->y); - } - default: - { - return false; - } - } - } - - protected: - - Gwen::Controls::Canvas* m_Canvas; - - }; - } -} -#endif diff --git a/btgui/Gwen/Input/SFML.h b/btgui/Gwen/Input/SFML.h deleted file mode 100644 index 78625ba88..000000000 --- a/btgui/Gwen/Input/SFML.h +++ /dev/null @@ -1,148 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_INPUT_SFML_H -#define GWEN_INPUT_SFML_H - -#include "Gwen/InputHandler.h" -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Canvas.h" - -#include - -namespace Gwen -{ - namespace Input - { - class SFML - { - public: - - SFML() - { - m_Canvas = NULL; - m_MouseX = 0; - m_MouseY = 0; - } - - void Initialize( Gwen::Controls::Canvas* c ) - { - m_Canvas = c; - } - - unsigned char TranslateKeyCode( int iKeyCode ) - { - switch ( iKeyCode ) - { -#if SFML_VERSION_MAJOR == 2 - case sf::Keyboard::Back: return Gwen::Key::Backspace; - case sf::Keyboard::Return: return Gwen::Key::Return; - case sf::Keyboard::Escape: return Gwen::Key::Escape; - case sf::Keyboard::Tab: return Gwen::Key::Tab; - case sf::Keyboard::Space: return Gwen::Key::Space; - case sf::Keyboard::Up: return Gwen::Key::Up; - case sf::Keyboard::Down: return Gwen::Key::Down; - case sf::Keyboard::Left: return Gwen::Key::Left; - case sf::Keyboard::Right: return Gwen::Key::Right; - case sf::Keyboard::Home: return Gwen::Key::Home; - case sf::Keyboard::End: return Gwen::Key::End; - case sf::Keyboard::Delete: return Gwen::Key::Delete; - case sf::Keyboard::LControl: return Gwen::Key::Control; - case sf::Keyboard::LAlt: return Gwen::Key::Alt; - case sf::Keyboard::LShift: return Gwen::Key::Shift; - case sf::Keyboard::RControl: return Gwen::Key::Control; - case sf::Keyboard::RAlt: return Gwen::Key::Alt; - case sf::Keyboard::RShift: return Gwen::Key::Shift; -#else - case sf::Key::Back: return Gwen::Key::Backspace; - case sf::Key::Return: return Gwen::Key::Return; - case sf::Key::Escape: return Gwen::Key::Escape; - case sf::Key::Tab: return Gwen::Key::Tab; - case sf::Key::Space: return Gwen::Key::Space; - case sf::Key::Up: return Gwen::Key::Up; - case sf::Key::Down: return Gwen::Key::Down; - case sf::Key::Left: return Gwen::Key::Left; - case sf::Key::Right: return Gwen::Key::Right; - case sf::Key::Home: return Gwen::Key::Home; - case sf::Key::End: return Gwen::Key::End; - case sf::Key::Delete: return Gwen::Key::Delete; - case sf::Key::LControl: return Gwen::Key::Control; - case sf::Key::LAlt: return Gwen::Key::Alt; - case sf::Key::LShift: return Gwen::Key::Shift; - case sf::Key::RControl: return Gwen::Key::Control; - case sf::Key::RAlt: return Gwen::Key::Alt; - case sf::Key::RShift: return Gwen::Key::Shift; -#endif - } - - return Gwen::Key::Invalid; - } - - bool ProcessMessage( sf::Event& event ) - { - if ( !m_Canvas ) return false; - - switch(event.Type) - { - case sf::Event::MouseMoved: - { - int dx = event.MouseMove.X - m_MouseX; - int dy = event.MouseMove.Y - m_MouseY; - - m_MouseX = event.MouseMove.X; - m_MouseY = event.MouseMove.Y; - - return m_Canvas->InputMouseMoved( m_MouseX, m_MouseY, dx, dy ); - } - - - case sf::Event::MouseButtonPressed: - case sf::Event::MouseButtonReleased: - { - return m_Canvas->InputMouseButton( event.MouseButton.Button, event.Type == sf::Event::MouseButtonPressed ); - } - - case sf::Event::MouseWheelMoved: - { - return m_Canvas->InputMouseWheel( event.MouseWheel.Delta * 60 ); - } - - case sf::Event::TextEntered: - { - return m_Canvas->InputCharacter( event.Text.Unicode ); - } - - case sf::Event::KeyPressed: - case sf::Event::KeyReleased: - { - bool bPressed = (event.Type == sf::Event::KeyPressed); - - if ( event.Key.Control && bPressed && event.Key.Code >= 'a' && event.Key.Code <= 'z' ) - { - return m_Canvas->InputCharacter( event.Key.Code ); - } - - unsigned char iKey = TranslateKeyCode( event.Key.Code ); - - return m_Canvas->InputKey( iKey, bPressed ); - - } - } - - return false; - } - - protected: - - Gwen::Controls::Canvas* m_Canvas; - int m_MouseX; - int m_MouseY; - - }; - } -} -#endif diff --git a/btgui/Gwen/Input/Windows.h b/btgui/Gwen/Input/Windows.h deleted file mode 100644 index 09ce2b4b5..000000000 --- a/btgui/Gwen/Input/Windows.h +++ /dev/null @@ -1,164 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ -#ifndef GWEN_INPUT_WINDOWS_H -#define GWEN_INPUT_WINDOWS_H - -#include "Gwen/InputHandler.h" -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Canvas.h" - -#include - -namespace Gwen -{ - namespace Input - { - class Windows - { - public: - - Windows() - { - m_Canvas = NULL; - m_MouseX = 0; - m_MouseY = 0; - } - - void Initialize( Gwen::Controls::Canvas* c ) - { - m_Canvas = c; - } - - bool ProcessMessage( MSG msg ) - { - if ( !m_Canvas ) return false; - - switch ( msg.message ) - { - case WM_MOUSEMOVE: - { - int x = (signed short)LOWORD( msg.lParam ); - int y = (signed short)HIWORD( msg.lParam ); - int dx = x - m_MouseX; - int dy = y - m_MouseY; - - m_MouseX = x; - m_MouseY = y; - - return m_Canvas->InputMouseMoved( x, y, dx, dy ); - } - - case WM_CHAR: - { - Gwen::UnicodeChar chr = (Gwen::UnicodeChar)msg.wParam; - return m_Canvas->InputCharacter( chr ); - } - - case WM_MOUSEWHEEL: - { - return m_Canvas->InputMouseWheel( (short)HIWORD( msg.wParam ) ); - } - - case WM_LBUTTONDOWN: - { - SetCapture( msg.hwnd ); - return m_Canvas->InputMouseButton( 0, true ); - } - - case WM_LBUTTONUP: - { - ReleaseCapture(); - return m_Canvas->InputMouseButton( 0, false ); - } - - case WM_RBUTTONDOWN: - { - SetCapture( msg.hwnd ); - return m_Canvas->InputMouseButton( 1, true ); - } - - case WM_RBUTTONUP: - { - ReleaseCapture(); - return m_Canvas->InputMouseButton( 1, false ); - } - - case WM_MBUTTONDOWN: - { - SetCapture( msg.hwnd ); - return m_Canvas->InputMouseButton( 2, true ); - } - - case WM_MBUTTONUP: - { - ReleaseCapture(); - return m_Canvas->InputMouseButton( 2, true ); - } - - case WM_LBUTTONDBLCLK: - case WM_RBUTTONDBLCLK: - case WM_MBUTTONDBLCLK: - { - // Filter out those events from the application - return true; - } - - case WM_KEYDOWN: - case WM_KEYUP: - { - bool bDown = msg.message == WM_KEYDOWN; - int iKey = -1; - - // These aren't sent by WM_CHAR when CTRL is down - but we need - // them internally for copy and paste etc.. - if ( bDown && GetKeyState( VK_CONTROL ) & 0x80 && msg.wParam >= 'A' && msg.wParam <= 'Z' ) - { - Gwen::UnicodeChar chr = (Gwen::UnicodeChar)msg.wParam; - return m_Canvas->InputCharacter( chr ); - } - - if ( msg.wParam == VK_SHIFT ) iKey = Gwen::Key::Shift; - else if ( msg.wParam == VK_RETURN ) iKey = Gwen::Key::Return; - else if ( msg.wParam == VK_BACK ) iKey = Gwen::Key::Backspace; - else if ( msg.wParam == VK_DELETE ) iKey = Gwen::Key::Delete; - else if ( msg.wParam == VK_LEFT ) iKey = Gwen::Key::Left; - else if ( msg.wParam == VK_RIGHT ) iKey = Gwen::Key::Right; - else if ( msg.wParam == VK_TAB ) iKey = Gwen::Key::Tab; - else if ( msg.wParam == VK_SPACE ) iKey = Gwen::Key::Space; - else if ( msg.wParam == VK_HOME ) iKey = Gwen::Key::Home; - else if ( msg.wParam == VK_END ) iKey = Gwen::Key::End; - else if ( msg.wParam == VK_CONTROL ) iKey = Gwen::Key::Control; - else if ( msg.wParam == VK_SPACE ) iKey = Gwen::Key::Space; - else if ( msg.wParam == VK_UP ) iKey = Gwen::Key::Up; - else if ( msg.wParam == VK_DOWN ) iKey = Gwen::Key::Down; - - if ( iKey != -1 ) - { - return m_Canvas->InputKey( iKey, bDown ); - } - - break; - } - - default: - { - break; - } - } - - return false; - } - - protected: - - Gwen::Controls::Canvas* m_Canvas; - int m_MouseX; - int m_MouseY; - - }; - } -} -#endif diff --git a/btgui/Gwen/InputHandler.h b/btgui/Gwen/InputHandler.h deleted file mode 100644 index ee97f55ef..000000000 --- a/btgui/Gwen/InputHandler.h +++ /dev/null @@ -1,82 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_INPUTHANDLER_H -#define GWEN_INPUTHANDLER_H - -#include -#include "Gwen/Gwen.h" - -namespace Gwen -{ - namespace Controls - { - class Base; - } - - namespace Key - { - const unsigned char Invalid = 0; - const unsigned char Return = 1; - const unsigned char Backspace = 2; - const unsigned char Delete = 3; - const unsigned char Left = 4; - const unsigned char Right = 5; - const unsigned char Shift = 6; - const unsigned char Tab = 7; - const unsigned char Space = 8; - const unsigned char Home = 9; - const unsigned char End = 10; - const unsigned char Control = 11; - const unsigned char Up = 12; - const unsigned char Down = 13; - const unsigned char Escape = 14; - const unsigned char Alt = 15; - - const unsigned char Count = 16; - } - - namespace Input - { - namespace Message - { - enum - { - Copy, - Paste, - Cut, - Undo, - Redo, - SelectAll - }; - }; - - - - // For use in panels - bool GWEN_EXPORT IsKeyDown( int iKey ); - bool GWEN_EXPORT IsLeftMouseDown(); - bool GWEN_EXPORT IsRightMouseDown(); - Gwen::Point GWEN_EXPORT GetMousePosition(); - - inline bool IsShiftDown(){ return IsKeyDown( Gwen::Key::Shift ); } - inline bool IsControlDown(){ return IsKeyDown( Gwen::Key::Control ); } - - // Does copy, paste etc - bool GWEN_EXPORT DoSpecialKeys( Controls::Base* pCanvas, Gwen::UnicodeChar chr ); - bool GWEN_EXPORT HandleAccelerator( Controls::Base* pCanvas, Gwen::UnicodeChar chr ); - - // Send input to canvas for study - void GWEN_EXPORT OnMouseMoved( Controls::Base* pCanvas, int x, int y, int deltaX, int deltaY ); - bool GWEN_EXPORT OnMouseClicked( Controls::Base* pCanvas, int iButton, bool bDown ); - bool GWEN_EXPORT OnKeyEvent( Controls::Base* pCanvas, int iKey, bool bDown ); - void GWEN_EXPORT OnCanvasThink( Controls::Base* pControl ); - - - }; -} -#endif diff --git a/btgui/Gwen/Macros.h b/btgui/Gwen/Macros.h deleted file mode 100644 index 5204a2b0f..000000000 --- a/btgui/Gwen/Macros.h +++ /dev/null @@ -1,84 +0,0 @@ - -// C RunTime Header Files -#ifndef GWEN_MACROS_H -#define GWEN_MACROS_H -#include -#include -#ifndef __APPLE__ -#include -#endif //__APPLE__ -#include -#include - -// Not tied to platform api. -#define GwenUtil_Min( a, b ) ( ( (a) < (b) ) ? (a) : (b) ) -#define GwenUtil_Max( a, b ) ( ( (a) > (b) ) ? (a) : (b) ) -#define GwenUtil_VSWPrintFSafeSized( _DstBuf_ARRAY_, _Format, _ArgList ) GwenUtil_VSWPrintFSafe( _DstBuf_ARRAY_, sizeof( _DstBuf_ARRAY_ ) / sizeof( wchar_t ), _Format, _ArgList ) - -#ifdef _WIN32 - - #ifndef NOMINMAX - #define NOMINMAX - #endif - #include - - #define GwenUtil_VSNPrintFSafe( _DstBuf, _DstSize, _MaxCount, _Format, _ArgList ) vsnprintf_s( _DstBuf, _DstSize, _MaxCount, _Format, _ArgList ) - #define GwenUtil_VSWPrintFSafe( _DstBuf, _SizeInWords, _Format, _ArgList ) vswprintf_s( _DstBuf, _SizeInWords, _Format, _ArgList ) - #define GwenUtil_OutputDebugCharString( lpOutputString ) OutputDebugStringA( lpOutputString ) - #define GwenUtil_OutputDebugWideString( lpOutputString ) OutputDebugStringW( lpOutputString ) - #define GwenUtil_WideStringToFloat( _Str ) _wtof( _Str ) - -#elif defined(__APPLE__) - - #include - - #define GwenUtil_VSNPrintFSafe( _DstBuf, _DstSize, _MaxCount, _Format, _ArgList ) vsnprintf( _DstBuf, _DstSize, _Format, _ArgList ) - #define GwenUtil_VSWPrintFSafe( _DstBuf, _SizeInWords, _Format, _ArgList ) vswprintf( _DstBuf, _SizeInWords, _Format, _ArgList ) - #define GwenUtil_OutputDebugCharString( lpOutputString ) //printf( lpOutputString ) - #define GwenUtil_OutputDebugWideString( lpOutputString ) //wprintf( lpOutputString ) - #define GwenUtil_WideStringToFloat( _Str ) wcstof(_Str, NULL) - -#elif defined(__linux__) - - #define GwenUtil_VSNPrintFSafe( _DstBuf, _DstSize, _MaxCount, _Format, _ArgList ) vsnprintf( _DstBuf, _DstSize, _Format, _ArgList ) - #define GwenUtil_VSWPrintFSafe( _DstBuf, _SizeInWords, _Format, _ArgList ) vswprintf( _DstBuf, _SizeInWords, _Format, _ArgList ) - #define GwenUtil_OutputDebugCharString( lpOutputString ) //printf( lpOutputString ) - #define GwenUtil_OutputDebugWideString( lpOutputString ) //wprintf( lpOutputString ) - #define GwenUtil_WideStringToFloat( _Str ) wcstof(_Str, NULL) - -#else - - #error MUST_IMPLEMENT_PLATFORM - -#endif - - -namespace Gwen -{ - template - T1 Clamp( T1 current, T2 vmin, T3 vmax ) - { - if ( current > vmax ) return (T1)vmax; - if ( current < vmin ) return (T1)vmin; - return current; - } - - template - inline T Approach( T fCurrent, T fTarget, T2 fDelta ) - { - if ( fCurrent < fTarget ) - { - fCurrent += fDelta; - if ( fCurrent > fTarget ) return fTarget; - } - else if ( fCurrent > fTarget ) - { - fCurrent -= fDelta; - if ( fCurrent < fTarget ) return fTarget; - } - - return fCurrent; - } -} - -#endif diff --git a/btgui/Gwen/Platform.h b/btgui/Gwen/Platform.h deleted file mode 100644 index d6ed301b5..000000000 --- a/btgui/Gwen/Platform.h +++ /dev/null @@ -1,43 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_PLATFORM_H -#define GWEN_PLATFORM_H - -#include "Gwen/Structures.h" -#include "Gwen/Events.h" - -namespace Gwen -{ - namespace Platform - { - // - // Set the system cursor to iCursor - // Cursors are defined in Structures.h - // - void GWEN_EXPORT SetCursor( unsigned char iCursor ); - - // - // Used by copy/paste - // - UnicodeString GWEN_EXPORT GetClipboardText(); - bool GWEN_EXPORT SetClipboardText( const UnicodeString& str ); - - // - // Needed for things like double click - // - float GWEN_EXPORT GetTimeInSeconds(); - - // - // System Dialogs ( Can return false if unhandled ) - // - bool GWEN_EXPORT FileOpen( const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Event::Handler::FunctionStr fnCallback ); - bool GWEN_EXPORT FileSave( const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Event::Handler::FunctionStr fnCallback ); - } - -} -#endif diff --git a/btgui/Gwen/Platforms/Null.cpp b/btgui/Gwen/Platforms/Null.cpp deleted file mode 100644 index e2205c4cc..000000000 --- a/btgui/Gwen/Platforms/Null.cpp +++ /dev/null @@ -1,54 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#include "Gwen/Macros.h" -#include "Gwen/Platform.h" - -#ifndef _WIN32 - -#include - -static Gwen::UnicodeString gs_ClipboardEmulator; - -void Gwen::Platform::SetCursor( unsigned char iCursor ) -{ - // No platform independent way to do this -} - -Gwen::UnicodeString Gwen::Platform::GetClipboardText() -{ - return gs_ClipboardEmulator; -} - -bool Gwen::Platform::SetClipboardText( const Gwen::UnicodeString& str ) -{ - gs_ClipboardEmulator = str; - return true; -} - -float Gwen::Platform::GetTimeInSeconds() -{ - float fSeconds = (float) clock() / (float)CLOCKS_PER_SEC; - return fSeconds; -} - -bool Gwen::Platform::FileOpen( const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Event::Handler::FunctionStr fnCallback ) -{ - // No platform independent way to do this. - // Ideally you would open a system dialog here - - return false; -} - -bool Gwen::Platform::FileSave( const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::FunctionStr fnCallback ) -{ - // No platform independent way to do this. - // Ideally you would open a system dialog here - - return false; -} - -#endif // ndef WIN32 \ No newline at end of file diff --git a/btgui/Gwen/Platforms/Windows.cpp b/btgui/Gwen/Platforms/Windows.cpp deleted file mode 100644 index 9f4800c0f..000000000 --- a/btgui/Gwen/Platforms/Windows.cpp +++ /dev/null @@ -1,236 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#include "Gwen/Macros.h" -#include "Gwen/Platform.h" - -#ifdef _WIN32 - - -#include - -#include -#pragma comment( lib, "winmm.lib" ) - -using namespace Gwen; -using namespace Gwen::Platform; - -#ifdef UNICODE -static LPWSTR iCursorConvertion[] = -#else -static LPSTR iCursorConvertion[] = -#endif -{ - IDC_ARROW, - IDC_IBEAM, - IDC_SIZENS, - IDC_SIZEWE, - IDC_SIZENWSE, - IDC_SIZENESW, - IDC_SIZEALL, - IDC_NO, - IDC_WAIT, - IDC_HAND -}; - -void Gwen::Platform::SetCursor( unsigned char iCursor ) -{ - // Todo.. Properly. - ::SetCursor( LoadCursor( NULL, iCursorConvertion[iCursor] ) ); -} - -Gwen::UnicodeString Gwen::Platform::GetClipboardText() -{ - if ( !OpenClipboard( NULL ) ) return L""; - - HANDLE hData = GetClipboardData( CF_UNICODETEXT ); - - if ( hData == NULL ) - { - CloseClipboard(); - return L""; - } - - wchar_t* buffer = (wchar_t *)GlobalLock( hData ); - UnicodeString str = buffer; - GlobalUnlock( hData ); - CloseClipboard(); - return str; -} - -bool Gwen::Platform::SetClipboardText( const Gwen::UnicodeString& str ) -{ - if ( !OpenClipboard( NULL ) ) return false; - - EmptyClipboard(); - - // Create a buffer to hold the string - size_t iDataSize = (str.length()+1) * sizeof(wchar_t); - HGLOBAL clipbuffer = GlobalAlloc( GMEM_DDESHARE, iDataSize ); - - // Copy the string into the buffer - wchar_t* buffer = (wchar_t*) GlobalLock( clipbuffer ); - wcscpy_s( buffer, iDataSize, str.c_str() ); - GlobalUnlock(clipbuffer); - - // Place it on the clipboard - SetClipboardData( CF_UNICODETEXT, clipbuffer ); - - CloseClipboard(); - return true; -} - -double GetPerformanceFrequency() -{ - static double Frequency = 0.0f; - - if ( Frequency == 0.0f ) - { - __int64 perfFreq; - QueryPerformanceFrequency( (LARGE_INTEGER*)&perfFreq ); - Frequency = 1.0 / (double)perfFreq; - } - - return Frequency; -} - -float Gwen::Platform::GetTimeInSeconds() -{ -#if 1 - - static float fCurrentTime = 0.0f; - static __int64 iLastTime = 0; - - __int64 thistime; - QueryPerformanceCounter( (LARGE_INTEGER*)&thistime ); - - float fSecondsDifference = (double)( thistime - iLastTime ) * GetPerformanceFrequency(); - if ( fSecondsDifference > 0.1f ) fSecondsDifference = 0.1f; - - fCurrentTime += fSecondsDifference; - - iLastTime = thistime; - - return fCurrentTime; - -#else - - return timeGetTime() / 1000.0; - -#endif -} - -bool Gwen::Platform::FileOpen( const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Event::Handler::FunctionStr fnCallback ) -{ - char Filestring[256]; - String returnstring; - - char FilterBuffer[512]; - { - memset( FilterBuffer, 0, sizeof(FilterBuffer) ); - memcpy( FilterBuffer, Extension.c_str(), GwenUtil_Min( Extension.size(), 512 ) ); - for (int i=0; i<512; i++) - { - if ( FilterBuffer[i] == '|' ) - FilterBuffer[i] = 0; - } - } - - OPENFILENAMEA opf; - opf.hwndOwner = 0; - opf.lpstrFilter = FilterBuffer; - opf.lpstrCustomFilter = 0; - opf.nMaxCustFilter = 0L; - opf.nFilterIndex = 1L; - opf.lpstrFile = Filestring; - opf.lpstrFile[0] = '\0'; - opf.nMaxFile = 256; - opf.lpstrFileTitle = 0; - opf.nMaxFileTitle=50; - opf.lpstrInitialDir = StartPath.c_str(); - opf.lpstrTitle = Name.c_str(); - opf.nFileOffset = 0; - opf.nFileExtension = 0; - opf.lpstrDefExt = "*.*"; - opf.lpfnHook = NULL; - opf.lCustData = 0; - opf.Flags = (OFN_PATHMUSTEXIST | OFN_OVERWRITEPROMPT | OFN_NOCHANGEDIR) & ~OFN_ALLOWMULTISELECT; - opf.lStructSize = sizeof(OPENFILENAME); - - if ( GetOpenFileNameA( &opf ) ) - { - if ( pHandler && fnCallback ) - { - (pHandler->*fnCallback)( opf.lpstrFile ); - } - } - else - { - if ( pHandler && fnCallback ) - { - (pHandler->*fnCallback)( "" ); - } - } - - return true; -} - -bool Gwen::Platform::FileSave( const String& Name, const String& StartPath, const String& Extension, Gwen::Event::Handler* pHandler, Gwen::Event::Handler::FunctionStr fnCallback ) -{ - char Filestring[256]; - String returnstring; - - char FilterBuffer[512]; - { - memset( FilterBuffer, 0, sizeof(FilterBuffer) ); - memcpy( FilterBuffer, Extension.c_str(), GwenUtil_Min( Extension.size(), 512 ) ); - for (int i=0; i<512; i++) - { - if ( FilterBuffer[i] == '|' ) - FilterBuffer[i] = 0; - } - } - - OPENFILENAMEA opf; - opf.hwndOwner = 0; - opf.lpstrFilter = FilterBuffer; - opf.lpstrCustomFilter = 0; - opf.nMaxCustFilter = 0L; - opf.nFilterIndex = 1L; - opf.lpstrFile = Filestring; - opf.lpstrFile[0] = '\0'; - opf.nMaxFile = 256; - opf.lpstrFileTitle = 0; - opf.nMaxFileTitle=50; - opf.lpstrInitialDir = StartPath.c_str(); - opf.lpstrTitle = Name.c_str(); - opf.nFileOffset = 0; - opf.nFileExtension = 0; - opf.lpstrDefExt = "*.*"; - opf.lpfnHook = NULL; - opf.lCustData = 0; - opf.Flags = (OFN_PATHMUSTEXIST | OFN_OVERWRITEPROMPT | OFN_NOCHANGEDIR) & ~OFN_ALLOWMULTISELECT; - opf.lStructSize = sizeof(OPENFILENAME); - - if ( GetSaveFileNameA( &opf ) ) - { - if ( pHandler && fnCallback ) - { - (pHandler->*fnCallback)( opf.lpstrFile ); - } - } - else - { - if ( pHandler && fnCallback ) - { - (pHandler->*fnCallback)( "" ); - } - } - - return true; -} - -#endif // WIN32 \ No newline at end of file diff --git a/btgui/Gwen/Renderers/DirectX9.h b/btgui/Gwen/Renderers/DirectX9.h deleted file mode 100644 index 2c07a7ac2..000000000 --- a/btgui/Gwen/Renderers/DirectX9.h +++ /dev/null @@ -1,74 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#ifndef GWEN_RENDERERS_DIRECTX9_H -#define GWEN_RENDERERS_DIRECTX9_H -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" - -struct VERTEXFORMAT2D -{ - FLOAT x, y, z, rhw; - DWORD color; - float u, v; -}; - -#define D3DFVF_VERTEXFORMAT2D ( D3DFVF_XYZRHW | D3DFVF_DIFFUSE | D3DFVF_TEX1 ) - -namespace Gwen -{ - namespace Renderer - { - - class GWEN_EXPORT DirectX9 : public Gwen::Renderer::Base - { - public: - - DirectX9( IDirect3DDevice9* pDevice ); - ~DirectX9(); - - virtual void Begin(); - virtual void End(); - virtual void Release(); - - virtual void SetDrawColor(Gwen::Color color); - - virtual void DrawLine( int x, int y, int a, int b ); - virtual void DrawFilledRect( Gwen::Rect rect ); - - virtual void LoadFont( Gwen::Font* pFont ); - virtual void FreeFont( Gwen::Font* pFont ); - virtual void RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ); - virtual Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ); - - void StartClip(); - void EndClip(); - - void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect pTargetRect, float u1=0.0f, float v1=0.0f, float u2=1.0f, float v2=1.0f ); - void LoadTexture( Gwen::Texture* pTexture ); - void FreeTexture( Gwen::Texture* pTexture ); - - protected: - - void* m_pCurrentTexture; - IDirect3DDevice9* m_pDevice; - DWORD m_Color; - - void Flush(); - void AddVert( int x, int y ); - void AddVert( int x, int y, float u, float v ); - - static const int MaxVerts = 1024; - VERTEXFORMAT2D m_pVerts[MaxVerts]; - int m_iVertNum; - - Gwen::Font::List m_FontList; - - }; - - } -} -#endif diff --git a/btgui/Gwen/Renderers/FontData.h b/btgui/Gwen/Renderers/FontData.h deleted file mode 100644 index 4a2792109..000000000 --- a/btgui/Gwen/Renderers/FontData.h +++ /dev/null @@ -1,265 +0,0 @@ - -unsigned char sGwenFontData[] = -{ - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,255,0,255,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0, - 255,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 255,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 255,0,255,0,0,0,255,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,255,0,0,255,255,0,255,0,255,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,255,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,255,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 255,255,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 -}; - -static const char sGwenDebugFontSpacing[]= -{ - 0,0,0,0,0,0,0,0,0,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,3,4,6,6,9,8,3,4,4,4,6,3,7,3,3,6,6,6,6,6,6,6,6,6,6,3,3,6,5,6,6,11,7,7,8,8,7,6,8,8,3,5,7,6,9,8,8,7,8,7,7,5,8,7,9,7,7,7,3,3,3,6,6,3,5,6,5,6,5,4,6,6,2,2,5,2,8,6,6,6,6,4,5,4,5,6,8,6,5,5,3,3,3,7,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,3,6,6,5,6,3,6,3,9,4,6,7,4,9,3,4,6,3,3,3,5,6,3,3,3,4,6,9,9,9,6,7,7,7,7,7,7,10,8,7,7,7,7,3,3,3,3,8,8,8,8,8,8,8,6,8,8,8,8,8,7,7,5,5,5,5,5,5,5,8,5,5,5,5,5,2,2,2,2,6,5,6,6,6,6,6,6,6,5,5,5,5,5,6,5,116,112,61,0,0,0,0,-96,-48,96,80,-64,0,64,-96,16,0,0,0,98,99,0,16,0,-96,-48,96,80,-64,0,-16,-128,16,98,99,0,-80,32,16,-16,16,112,-64,-64,-32,-16,-48,16,-48,0,64,-128,-64,32,-48,-64,-48,-16,96,32,64,96,96,32,32,-96,-64,-96,80,64,-80,16,-48,16,-80,-16,48,112,80,-80,-16,64,80,-112,-48,16,80,48,96,16,16,16,-112,-16,-16,0,96,48,48,-112,112,-80,-32,-48,-96,-112,16,80,80,48,-64,-80,-112,96,80,64,96,48,80,73,65,32,84,82,84,0,92,103,32,101,120,92,114,102,105,108,117,32,92,105,117,120,108,0,115,114,32,114,114,116,101,110,0,92,103,32,101,120,92,114,102,105,108,117,32,92,105,117,108,0,92,103,32,101,120,92,114,102,105,108,117,32,92,105,117,120,101,110,105,114,101,0,100,84,60,115,116,95,116,97,60,115,119,58,116,115,97,42,114,32,58,115,108,32,110,111,111,58,101,44,115,116,97,99,114,97,71,58,110,108,66,32,48,58,110,105,97,58,101,111,61,83,100,32,32,114,101,110,105,114,101,44,0,112,116,101,111,105,109,105,0,115,110,116,101,111,117,100,97,0,115,111,64,80,-112,34,32,114,101,0,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,112,116,42,83,100,32,32,114,101,117,102,110,44,0,115,116,116,110,100,102,110,108,0,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,112,116,43,0,115,116,116,110,105,101,116,101,60,108,0,112,116,97,105,97,32,115,32,103,0,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,67,97,108,32,114,114,110,112,98,0,100,84,60,115,116,95,116,97,60,115,119,58,116,115,97,42,114,32,58,115,108,32,110,111,111,58,101,44,115,116,97,99,114,97,71,58,110,108,66,32,48,58,110,105,97,58,101,0,112,116,101,111,111,101,109,97,0,100,84,60,115,116,95,116,97,60,115,119,58,116,115,97,42,114,32,58,115,108,32,110,111,111,58,101,44,115,116,97,99,114,97,71,58,110,108,66,32,48,58,110,105,97,58,110,0,112,116,101,111,111,110,109,97,0,118,100,101,111,16,-26,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,112,116,45,0,115,116,116,110,100,101,116,101,97,111,0,0,0,0,97,111,48,48,-96,-112,-48,16,-64,0,-16,-128,16,0,-103,97,111,58,110,105,33,-128,32,-64,-16,16,112,-64,-64,-32,-16,-48,16,-48,0,64,-128,-64,32,-48,-64,-48,-16,96,32,112,96,96,32,-96,-96,-64,-96,80,64,-80,16,-48,16,-80,-16,48,112,80,-80,-16,64,80,-112,-48,16,80,48,96,16,16,16,-112,32,-16,0,96,48,48,-112,112,-80,-32,-48,-96,-112,16,80,80,48,-64,-124,-96,-112,64,-110,-128,0,80,112,0,100,84,60,115,116,95,112,97,60,115,116,98,99,114,60,97,44,117,115,58,114,97,60,97,62,97,115,58,111,111,99,95,62,97,71,58,101,58,108,42,114,32,58,115,108,32,58,115,115,110,99,95,116,116,100,104,116,116,99,95,99,115,100,108,97,60,97,62,62,97,115,58,111,111,116,116,100,97,99,115,100,97,95,105,119,114,115,99,116,99,95,105,119,114,44,115,116,97,99,114,104,116,32,115,99,115,101,69,116,97,114,32,62,58,115,116,116,58,114,114,0,100,84,60,115,116,95,112,97,60,115,116,98,99,114,60,97,44,117,115,58,114,97,60,97,62,97,115,58,111,111,99,95,62,97,71,58,101,58,108,42,114,32,58,115,108,32,58,115,115,110,99,95,116,116,100,104,116,116,99,95,99,115,100,108,97,60,97,62,62,97,115,58,111,111,116,116,100,97,99,115,100,97,95,105,119,114,115,99,116,99,95,105,119,114,44,115,116,97,99,114,104,116,32,115,99,115,101,69,116,97,114,32,62,58,115,116,116,58,114,114,0,112,116,101,111,111,101,101,99,101,100,84,60,115,116,95,112,97,60,115,116,98,99,114,60,97,44,117,115,58,114,97,60,97,62,97,115,58,111,111,99,95,62,97,71,58,101,58,108,42,114,32,58,115,108,32,58,115,115,110,99,95,116,116,100,104,116,116,99,95,99,115,100,108,97,60,97,62,62,97,115,58,111,111,116,116,100,97,99,115,100,97,95,105,119,114,115,99,116,99,95,105,119,114,44,115,116,97,99,114,104,116,32,115,99,115,101,69,116,97,114,32,62,58,115,116,116,58,99,92,103,32,101,120,92,114,102,105,108,117,32,92,105,117,97,114,109,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,73,97,60,58,101,100,101,111,115,110,111,97,0,116,45,97,99,97,114,97,34,41,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,112,116,42,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,112,116,43,0,100,105,99,115,101,67,114,58,115,44,115,116,97,99,114,97,71,58,110,108,66,32,62,67,116,101,111,62,67,97,98,99,98,99,98,99,-113,67,32,83,116,0,100,105,99,115,101,72,58,115,111,44,115,116,97,99,114,97,71,58,111,66,72,32,62,67,116,101,111,62,112,116,42,100,105,99,115,101,72,58,115,111,44,115,116,97,99,114,97,71,58,111,66,72,32,62,67,116,101,111,62,112,116,43,0,100,105,99,115,101,72,58,115,111,44,115,116,97,99,114,97,71,58,111,66,72,32,62,67,116,101,111,62,67,97,98,99,-92,-96,64,-128,112,116,115,32,114,114,116,101,110,0,100,84,60,115,116,95,112,97,60,115,119,58,116,115,97,42,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32,62,114,32,58,115,108,32,110,111,111,58,101,44,115,116,97,99,114,114,32,58,105,108,32,110,111,111,58,101,99,116,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32,62,62,32,99,116,101,111,111,97,32,0,100,105,99,115,101,65,58,105,105,42,97,115,58,111,111,108,32,110,110,58,109,111,62,58,110,105,97,60,58,114,114,0,100,105,99,115,101,65,58,105,105,42,97,115,58,111,111,108,32,110,110,58,109,111,62,58,110,105,97,60,58,114,114,0,100,84,60,115,116,95,112,97,60,115,119,58,116,115,97,42,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32,62,114,32,58,115,108,32,110,111,111,58,101,44,115,116,97,99,114,114,32,58,105,108,32,110,111,111,58,101,99,116,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32,62,62,32,99,116,101,111,111,97,32,0,100,84,60,115,116,95,112,97,60,115,119,58,116,115,97,42,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32,62,114,32,58,115,108,32,110,111,111,58,101,44,115,116,97,99,114,114,32,58,105,108,32,110,111,111,58,101,99,116,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32,62,62,32,99,116,101,111,95,0,100,105,99,115,101,65,58,105,105,42,97,115,58,111,111,108,32,110,110,58,109,111,62,58,110,105,97,60,58,109,0,100,84,60,115,116,95,112,97,60,115,119,58,116,115,97,42,97,115,58,116,97,71,58,105,65,97,110,99,115,100,108,97,60,115,119,58,109,110,116,32 -}; diff --git a/btgui/Gwen/Renderers/GDIPlus.h b/btgui/Gwen/Renderers/GDIPlus.h deleted file mode 100644 index 1e5f7fa33..000000000 --- a/btgui/Gwen/Renderers/GDIPlus.h +++ /dev/null @@ -1,95 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#ifndef GWEN_RENDERERS_GDIPLUS_H -#define GWEN_RENDERERS_GDIPLUS_H - -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" - - -/* - - GDI(plus) is pretty slow for rendering GWEN, because we're - re-rendering everything on redraw. - - Therefore its usage should be as a test - rather than production. - - // Note: For this to work you should be including - - #include - - // Which we don't do in the header, for the sake of usability - -*/ - -namespace Gwen -{ - namespace Renderer - { - - class GDIPlus : public Gwen::Renderer::Base - { - public: - - GDIPlus( HWND pHWND ); - ~GDIPlus(); - - virtual void Begin(); - virtual void End(); - - virtual void SetDrawColor(Gwen::Color color); - - virtual void DrawLine( int x, int y, int a, int b ); - virtual void DrawFilledRect( Gwen::Rect rect ); - - virtual void LoadFont( Gwen::Font* pFont ); - virtual void FreeFont( Gwen::Font* pFont ); - virtual void RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ); - virtual Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ); - - void StartClip(); - void EndClip(); - - void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect pTargetRect, float u1=0.0f, float v1=0.0f, float u2=1.0f, float v2=1.0f ); - void LoadTexture( Gwen::Texture* pTexture ); - void FreeTexture( Gwen::Texture* pTexture ); - - protected: - - int m_iWidth; - int m_iHeight; - - Gdiplus::Color m_Colour; - - HWND m_HWND; - HDC m_hDC; - ULONG_PTR m_gdiplusToken; - - Gdiplus::Graphics* graphics; - }; - - class GDIPlusBuffered : public GDIPlus - { - public: - - GDIPlusBuffered( HWND pHWND ); - ~GDIPlusBuffered(); - - virtual void Begin(); - virtual void End(); - - private: - - void CreateBackbuffer(); - void DestroyBackbuffer(); - - Gdiplus::Bitmap* m_Bitmap; - - }; - } -} -#endif diff --git a/btgui/Gwen/Renderers/OpenGL.h b/btgui/Gwen/Renderers/OpenGL.h deleted file mode 100644 index e0a611c2f..000000000 --- a/btgui/Gwen/Renderers/OpenGL.h +++ /dev/null @@ -1,60 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#ifndef GWEN_RENDERERS_OPENGL_H -#define GWEN_RENDERERS_OPENGL_H - -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" - -namespace Gwen -{ - namespace Renderer - { - - class OpenGL : public Gwen::Renderer::Base - { - public: - - struct Vertex - { - float x, y, z; - float u, v; - unsigned char r, g, b, a; - }; - - OpenGL(); - ~OpenGL(); - - virtual void Begin(); - virtual void End(); - - virtual void SetDrawColor( Gwen::Color color ); - virtual void DrawFilledRect( Gwen::Rect rect ); - - void StartClip(); - void EndClip(); - - void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect pTargetRect, float u1=0.0f, float v1=0.0f, float u2=1.0f, float v2=1.0f ); - void LoadTexture( Gwen::Texture* pTexture ); - void FreeTexture( Gwen::Texture* pTexture ); - - protected: - - static const int MaxVerts = 1024; - - - void Flush(); - void AddVert( int x, int y, float u = 0.0f , float v = 0.0f ); - - Gwen::Color m_Color; - int m_iVertNum; - Vertex m_Vertices[ MaxVerts ]; - }; - - } -} -#endif diff --git a/btgui/Gwen/Renderers/OpenGL_DebugFont.cpp b/btgui/Gwen/Renderers/OpenGL_DebugFont.cpp deleted file mode 100644 index c8c351b06..000000000 --- a/btgui/Gwen/Renderers/OpenGL_DebugFont.cpp +++ /dev/null @@ -1,405 +0,0 @@ - -#include "OpenGL_DebugFont.h" -#include "Gwen/Utility.h" -#include "Gwen/Font.h" -#include "Gwen/Texture.h" - -#include -#include "OpenGLWindow/GlewWindows/GL/glew.h" - -#include "FontData.h" - - //saved OpenGL settings - GLfloat m_PrevLineWidth; - GLint m_PrevTexEnv; - GLint m_PrevPolygonMode[2]; - GLint m_MaxClipPlanes; - GLint m_PrevTexture; - GLint m_PrevArrayBufferARB; - GLint m_PrevElementArrayBufferARB; - GLboolean m_PrevVertexProgramARB; - GLboolean m_PrevFragmentProgramARB; - GLuint m_PrevProgramObjectARB; - GLboolean m_PrevTexture3D; - GLboolean m_PrevActiveTexture1D[32]; - GLboolean m_PrevActiveTexture2D[32]; - GLboolean m_PrevActiveTexture3D[32]; - GLint m_PrevActiveTextureARB; - bool m_SupportTexRect; - GLboolean m_PrevTexRectARB; - GLint m_PrevBlendEquation; - GLint m_PrevBlendEquationRGB; - GLint m_PrevBlendEquationAlpha; - GLint m_PrevBlendSrcRGB; - GLint m_PrevBlendDstRGB; - GLint m_PrevBlendSrcAlpha; - GLint m_PrevBlendDstAlpha; - GLint m_ViewportInit[4]; - GLfloat m_ProjMatrixInit[16]; - GLboolean m_texGenS; - GLboolean m_texGenT; - GLboolean m_texGenR; - - - - void restoreOpenGLState() - { - glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, m_PrevTexEnv); - glLineWidth(m_PrevLineWidth); - glMatrixMode(GL_PROJECTION); - glPopMatrix(); - glMatrixMode(GL_MODELVIEW); - glPopMatrix(); - glMatrixMode(GL_TEXTURE); - glPopMatrix(); - glPopClientAttrib(); - glPopAttrib(); - if (m_texGenS) - glEnable(GL_TEXTURE_GEN_S); - else - glDisable(GL_TEXTURE_GEN_S); - - if (m_texGenT) - glEnable(GL_TEXTURE_GEN_T); - else - glDisable(GL_TEXTURE_GEN_T); - - if (m_texGenR) - glEnable(GL_TEXTURE_GEN_R); - else - glDisable(GL_TEXTURE_GEN_R); - - - - } - - void saveOpenGLState(int screenWidth, int screenHeight) - { - glPushAttrib(GL_ALL_ATTRIB_BITS); - glPushClientAttrib(GL_CLIENT_ALL_ATTRIB_BITS); - - glMatrixMode(GL_TEXTURE); - glPushMatrix(); - glLoadIdentity(); - glMatrixMode(GL_MODELVIEW); - glPushMatrix(); - glLoadIdentity(); - glMatrixMode(GL_PROJECTION); - glPushMatrix(); - GLint Vp[4]; - glGetIntegerv(GL_VIEWPORT, Vp); - if (screenWidth>0 && screenHeight>0) - { - Vp[0] = 0; - Vp[1] = 0; - Vp[2] = screenWidth-1; - Vp[3] = screenHeight-1; - glViewport(Vp[0], Vp[1], Vp[2], Vp[3]); - } - glLoadIdentity(); - glOrtho(Vp[0], Vp[0]+Vp[2], Vp[1]+Vp[3], Vp[1], -1, 1); - glGetIntegerv(GL_VIEWPORT, m_ViewportInit); - glGetFloatv(GL_PROJECTION_MATRIX, m_ProjMatrixInit); - - glGetFloatv(GL_LINE_WIDTH, &m_PrevLineWidth); - // glDisable(GL_POLYGON_STIPPLE); - glLineWidth(1); - - glGetBooleanv(GL_TEXTURE_GEN_S,&m_texGenS); - glGetBooleanv(GL_TEXTURE_GEN_T,&m_texGenT); - glGetBooleanv(GL_TEXTURE_GEN_R,&m_texGenR); - - glDisable(GL_TEXTURE_GEN_S); - glDisable(GL_TEXTURE_GEN_T); - glDisable(GL_TEXTURE_GEN_R); - - glDisable(GL_LINE_SMOOTH); - // glDisable(GL_LINE_STIPPLE); - glDisable(GL_CULL_FACE); - glDisable(GL_DEPTH_TEST); - glDisable(GL_LIGHTING); - glEnable(GL_BLEND); - - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glGetTexEnviv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, &m_PrevTexEnv); - glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); - glDisable(GL_TEXTURE_2D); - - } - - -namespace Gwen -{ - namespace Renderer - { - OpenGL_DebugFont::OpenGL_DebugFont() - { - m_iVertNum = 0; - - for ( int i=0; idata = pglTexture; - m_pFontTexture->width = 256; - m_pFontTexture->height = 256; - - - // Create the opengl texture - glGenTextures( 1, pglTexture ); - glBindTexture( GL_TEXTURE_2D, *pglTexture ); - //glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR ); - //glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR ); - glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - - //GLenum format = GL_RGB; - unsigned char* texdata = new unsigned char[256*256*4]; - for (int i=0;i<256*256;i++) - { - texdata[i*4] = sGwenFontData[i]; - texdata[i*4+1] = sGwenFontData[i]; - texdata[i*4+2] = sGwenFontData[i]; - texdata[i*4+3] = sGwenFontData[i]; - } - glTexImage2D( GL_TEXTURE_2D, 0, GL_RGBA, m_pFontTexture->width, m_pFontTexture->height, 0, GL_RGBA, GL_UNSIGNED_BYTE, (const GLvoid*)texdata ); - delete[]texdata; - } - - OpenGL_DebugFont::~OpenGL_DebugFont() - { - FreeTexture( m_pFontTexture ); - delete m_pFontTexture; - } - - - - - - void OpenGL_DebugFont::Begin() - { - glBlendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA ); - glAlphaFunc( GL_GREATER, 1.0f ); - glEnable ( GL_BLEND ); - } - - void OpenGL_DebugFont::End() - { - if ( m_iVertNum == 0 ) return; - - glVertexPointer( 3, GL_FLOAT, sizeof(Vertex), (void*) &m_Vertices[0].x ); - glEnableClientState( GL_VERTEX_ARRAY ); - - glColorPointer( 4, GL_UNSIGNED_BYTE, sizeof(Vertex), (void*)&m_Vertices[0].r ); - glEnableClientState( GL_COLOR_ARRAY ); - - glTexCoordPointer( 2, GL_FLOAT, sizeof(Vertex), (void*) &m_Vertices[0].u ); - glEnableClientState( GL_TEXTURE_COORD_ARRAY ); - - glDrawArrays( GL_TRIANGLES, 0, (GLsizei) m_iVertNum ); - - m_iVertNum = 0; - glFlush(); - } - - void OpenGL_DebugFont::Flush() - { - if ( m_iVertNum == 0 ) return; - - glVertexPointer( 3, GL_FLOAT, sizeof(Vertex), (void*) &m_Vertices[0].x ); - glEnableClientState( GL_VERTEX_ARRAY ); - - glColorPointer( 4, GL_UNSIGNED_BYTE, sizeof(Vertex), (void*)&m_Vertices[0].r ); - glEnableClientState( GL_COLOR_ARRAY ); - - glTexCoordPointer( 2, GL_FLOAT, sizeof(Vertex), (void*) &m_Vertices[0].u ); - glEnableClientState( GL_TEXTURE_COORD_ARRAY ); - - glDrawArrays( GL_TRIANGLES, 0, (GLsizei) m_iVertNum ); - - m_iVertNum = 0; - glFlush(); - } - - void OpenGL_DebugFont::AddVert( int x, int y, float u, float v ) - { - if ( m_iVertNum >= MaxVerts-1 ) - { - Flush(); - } - - m_Vertices[ m_iVertNum ].x = (float)x; - m_Vertices[ m_iVertNum ].y = (float)y; - m_Vertices[ m_iVertNum ].u = u; - m_Vertices[ m_iVertNum ].v = v; - - m_Vertices[ m_iVertNum ].r = m_Color.r; - m_Vertices[ m_iVertNum ].g = m_Color.g; - m_Vertices[ m_iVertNum ].b = m_Color.b; - m_Vertices[ m_iVertNum ].a = m_Color.a; - - m_iVertNum++; - } - - void OpenGL_DebugFont::DrawFilledRect( Gwen::Rect rect ) - { - GLboolean texturesOn; - - glGetBooleanv(GL_TEXTURE_2D, &texturesOn); - if ( texturesOn ) - { - Flush(); - glDisable(GL_TEXTURE_2D); - } - - Translate( rect ); - - AddVert( rect.x, rect.y ); - AddVert( rect.x+rect.w, rect.y ); - AddVert( rect.x, rect.y + rect.h ); - - AddVert( rect.x+rect.w, rect.y ); - AddVert( rect.x+rect.w, rect.y+rect.h ); - AddVert( rect.x, rect.y + rect.h ); - } - - void OpenGL_DebugFont::SetDrawColor(Gwen::Color color) - { - glColor4ubv( (GLubyte*)&color ); - m_Color = color; - } - - void OpenGL_DebugFont::StartClip() - { - Flush(); - Gwen::Rect rect = ClipRegion(); - - // OpenGL's coords are from the bottom left - // so we need to translate them here. - { - GLint view[4]; - glGetIntegerv( GL_VIEWPORT, &view[0] ); - rect.y = view[3] - (rect.y + rect.h); - } - - glScissor( rect.x * Scale(), rect.y * Scale(), rect.w * Scale(), rect.h * Scale() ); - glEnable( GL_SCISSOR_TEST ); - }; - - void OpenGL_DebugFont::EndClip() - { - - Flush(); - glDisable( GL_SCISSOR_TEST ); - - }; - - void OpenGL_DebugFont::RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ) - { - - float fSize = pFont->size * Scale(); - - if ( !text.length() ) - return; - - Gwen::String converted_string = Gwen::Utility::UnicodeToString( text ); - - float yOffset=0.0f; - for ( int i=0; i<(int)text.length(); i++ ) - { - // wchar_t chr = text[i]; - char ch = converted_string[i]; - float curSpacing = sGwenDebugFontSpacing[(int)ch] * m_fLetterSpacing * fSize * m_fFontScale[0]; - Gwen::Rect r( pos.x + yOffset, pos.y-fSize*0.2f, (fSize * m_fFontScale[0]), fSize * m_fFontScale[1] ); - - if ( m_pFontTexture ) - { - float uv_texcoords[8]={0.,0.,1.,1.}; - - if ( ch >= 0 ) - { - float cx= (ch%16)/16.0; - float cy= (ch/16)/16.0; - uv_texcoords[0] = cx; - uv_texcoords[1] = cy; - uv_texcoords[4] = float(cx+1.0f/16.0f); - uv_texcoords[5] = float(cy+1.0f/16.0f); - } - - DrawTexturedRect( m_pFontTexture, r, uv_texcoords[0], uv_texcoords[5], uv_texcoords[4], uv_texcoords[1] ); - yOffset+=curSpacing; - } - else - { - DrawFilledRect( r ); - yOffset+=curSpacing; - - } - } - - } - - void OpenGL_DebugFont::DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect rect, float u1, float v1, float u2, float v2 ) - { - GLuint* tex = (GLuint*)pTexture->data; - - // Missing image, not loaded properly? - if ( !tex ) - { - return DrawMissingImage( rect ); - } - - Translate( rect ); - GLuint boundtex; - - GLboolean texturesOn; - glGetBooleanv(GL_TEXTURE_2D, &texturesOn); - glGetIntegerv(GL_TEXTURE_BINDING_2D, (GLint *)&boundtex); - if ( !texturesOn || *tex != boundtex ) - { - Flush(); - glBindTexture( GL_TEXTURE_2D, *tex ); - glEnable(GL_TEXTURE_2D); - } - - AddVert( rect.x, rect.y, u1, v1 ); - AddVert( rect.x+rect.w, rect.y, u2, v1 ); - AddVert( rect.x, rect.y + rect.h, u1, v2 ); - - AddVert( rect.x+rect.w, rect.y, u2, v1 ); - AddVert( rect.x+rect.w, rect.y+rect.h, u2, v2 ); - AddVert( rect.x, rect.y + rect.h, u1, v2 ); - } - - Gwen::Point OpenGL_DebugFont::MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ) - { - Gwen::Point p; - float fSize = pFont->size * Scale(); - - Gwen::String converted_string = Gwen::Utility::UnicodeToString( text ); - float spacing = 0.0f; - - for ( int i=0; i<(int)text.length(); i++ ) - { - char ch = converted_string[i]; - spacing += sGwenDebugFontSpacing[(int)ch]; - } - - p.x = spacing*m_fLetterSpacing*fSize * m_fFontScale[0]; - p.y = pFont->size * Scale() * m_fFontScale[1]; - return p; - } - - } -} \ No newline at end of file diff --git a/btgui/Gwen/Renderers/OpenGL_DebugFont.h b/btgui/Gwen/Renderers/OpenGL_DebugFont.h deleted file mode 100644 index fa625a30a..000000000 --- a/btgui/Gwen/Renderers/OpenGL_DebugFont.h +++ /dev/null @@ -1,74 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#ifndef GWEN_RENDERERS_OPENGL_DEBUGFONT_H -#define GWEN_RENDERERS_OPENGL_DEBUGFONT_H - -#include "Gwen/Gwen.h" -#include "Gwen/Renderers/OpenGL.h" - -void restoreOpenGLState(); -void saveOpenGLState(int screenWidth, int screenHeight); - - -namespace Gwen -{ - namespace Renderer - { - - class OpenGL_DebugFont : public Gwen::Renderer::Base - { - public: - - struct Vertex - { - float x, y, z; - float u, v; - unsigned char r, g, b, a; - }; - - - static const int MaxVerts = 1024; - - OpenGL_DebugFont(); - ~OpenGL_DebugFont(); - - void RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ); - Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ); - - virtual void Begin(); - virtual void End(); - - virtual void SetDrawColor( Gwen::Color color ); - virtual void DrawFilledRect( Gwen::Rect rect ); - void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect rect, float u1, float v1, float u2, float v2 ); - - - void StartClip(); - void EndClip(); - - void Flush(); - void AddVert( int x, int y, float u = 0.0f , float v = 0.0f ); - - virtual void Resize(int width, int height) {} - - - protected: - - Gwen::Texture* m_pFontTexture; - float m_fFontScale[2]; - float m_fLetterSpacing; - - - Gwen::Color m_Color; - int m_iVertNum; - Vertex m_Vertices[ MaxVerts ]; - - }; - - } -} -#endif diff --git a/btgui/Gwen/Renderers/SFML.h b/btgui/Gwen/Renderers/SFML.h deleted file mode 100644 index 9583cde90..000000000 --- a/btgui/Gwen/Renderers/SFML.h +++ /dev/null @@ -1,51 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_RENDERERS_SFML_H -#define GWEN_RENDERERS_SFML_H -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" -#include - -namespace Gwen -{ - namespace Renderer - { - - class SFML : public Gwen::Renderer::Base - { - public: - - SFML( sf::RenderTarget& target ); - ~SFML(); - - virtual void SetDrawColor(Gwen::Color color); - - virtual void DrawLine( int x, int y, int a, int b ); - virtual void DrawFilledRect( Gwen::Rect rect ); - - virtual void LoadFont( Gwen::Font* pFont ); - virtual void FreeFont( Gwen::Font* pFont ); - virtual void RenderText( Gwen::Font* pFont, Gwen::Point pos, const Gwen::UnicodeString& text ); - virtual Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ); - - void StartClip(); - void EndClip(); - - void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect pTargetRect, float u1=0.0f, float v1=0.0f, float u2=1.0f, float v2=1.0f ); - void LoadTexture( Gwen::Texture* pTexture ); - void FreeTexture( Gwen::Texture* pTexture ); - - protected: - - sf::RenderTarget& m_Target; - sf::Color m_Color; - - }; - } -} -#endif diff --git a/btgui/Gwen/Skin.cpp b/btgui/Gwen/Skin.cpp deleted file mode 100644 index 700521336..000000000 --- a/btgui/Gwen/Skin.cpp +++ /dev/null @@ -1,85 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Gwen.h" -#include - -namespace Gwen -{ - namespace Skin - { - /* - - Here we're drawing a few symbols such as the directional arrows and the checkbox check - - Texture'd skins don't generally use these - but the Simple skin does. We did originally - use the marlett font to draw these.. but since that's a Windows font it wasn't a very - good cross platform solution. - - */ - - void Base::DrawArrowDown( Gwen::Rect rect ) - { - float x = (rect.w / 5.0f); - float y = (rect.h / 5.0f); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*0.0f, rect.y + y*1.0f, x, y*1.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*1.0f, x, y*2.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*2.0f, rect.y + y*1.0f, x, y*3.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*3.0f, rect.y + y*1.0f, x, y*2.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*4.0f, rect.y + y*1.0f, x, y*1.0f ) ); - } - - void Base::DrawArrowUp( Gwen::Rect rect ) - { - float x = (rect.w / 5.0f); - float y = (rect.h / 5.0f); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*0.0f, rect.y + y*3.0f, x, y*1.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*2.0f, x, y*2.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*2.0f, rect.y + y*1.0f, x, y*3.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*3.0f, rect.y + y*2.0f, x, y*2.0f ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*4.0f, rect.y + y*3.0f, x, y*1.0f ) ); - } - - void Base::DrawArrowLeft( Gwen::Rect rect ) - { - float x = (rect.w / 5.0f); - float y = (rect.h / 5.0f); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*3.0f, rect.y + y*0.0f, x*1.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*2.0f, rect.y + y*1.0f, x*2.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*2.0f, x*3.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*2.0f, rect.y + y*3.0f, x*2.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*3.0f, rect.y + y*4.0f, x*1.0f, y ) ); - } - - void Base::DrawArrowRight( Gwen::Rect rect ) - { - float x = (rect.w / 5.0f); - float y = (rect.h / 5.0f); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*0.0f, x*1.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*1.0f, x*2.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*2.0f, x*3.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*3.0f, x*2.0f, y ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*4.0f, x*1.0f, y ) ); - } - - void Base::DrawCheck( Gwen::Rect rect ) - { - float x = (rect.w / 5.0f); - float y = (rect.h / 5.0f); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*0.0f, rect.y + y*3.0f, x*2, y*2 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*1.0f, rect.y + y*4.0f, x*2, y*2 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*2.0f, rect.y + y*3.0f, x*2, y*2 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*3.0f, rect.y + y*1.0f, x*2, y*2 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + x*4.0f, rect.y + y*0.0f, x*2, y*2 ) ); - } - } -} diff --git a/btgui/Gwen/Skin.h b/btgui/Gwen/Skin.h deleted file mode 100644 index 4dfc8cecf..000000000 --- a/btgui/Gwen/Skin.h +++ /dev/null @@ -1,138 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_SKIN_H -#define GWEN_SKIN_H - -#include "Gwen/BaseRender.h" -#include "Gwen/Font.h" - -namespace Gwen -{ - namespace Controls - { - class Base; - } - - namespace Skin - { - namespace Symbol - { - const unsigned char None = 0; - const unsigned char ArrowRight = 1; - const unsigned char Check = 2; - const unsigned char Dot = 3; - } - - class GWEN_EXPORT Base - { - public: - - Base() - { - m_DefaultFont.facename = L"Arial"; - m_DefaultFont.size = 10.0f; - m_Render = NULL; - } - - virtual ~Base() - { - ReleaseFont( &m_DefaultFont ); - } - - virtual void ReleaseFont( Gwen::Font* fnt ) - { - if ( !fnt ) return; - if ( !m_Render ) return; - - m_Render->FreeFont( fnt ); - } - - virtual void DrawButton( Controls::Base* control, bool bDepressed, bool bHovered ) = 0; - virtual void DrawTabButton( Controls::Base* control, bool bActive ) = 0; - virtual void DrawTabControl( Controls::Base* control, Gwen::Rect CurrentButtonRect ) = 0; - virtual void DrawTabTitleBar( Controls::Base* control ) = 0; - - virtual void DrawMenuItem( Controls::Base* control, bool bSubmenuOpen, bool bChecked ) = 0; - virtual void DrawMenuStrip( Controls::Base* control ) = 0; - virtual void DrawMenu( Controls::Base* control, bool bPaddingDisabled ) = 0; - virtual void DrawRadioButton(Controls::Base* control, bool bSelected, bool bDepressed) = 0; - virtual void DrawCheckBox( Controls::Base* control, bool bSelected, bool bDepressed ) = 0; - virtual void DrawGroupBox( Controls::Base* control, int textStart, int textHeight, int textWidth ) = 0; - virtual void DrawTextBox( Controls::Base* control ) = 0; - virtual void DrawWindow( Controls::Base* control, int topHeight, bool inFocus ) = 0; - virtual void DrawHighlight( Controls::Base* control ) = 0; - virtual void DrawBackground( Controls::Base* control ) = 0; - virtual void DrawStatusBar( Controls::Base* control ) = 0; - - virtual void DrawShadow( Controls::Base* control ) = 0; - virtual void DrawScrollBarBar( Controls::Base* control, bool bDepressed, bool isHovered, bool isHorizontal ) = 0; - virtual void DrawScrollBar( Controls::Base* control, bool isHorizontal, bool bDepressed ) = 0; - virtual void DrawScrollButton( Controls::Base* control, int iDirection, bool bDepressed ) = 0; - virtual void DrawProgressBar( Controls::Base* control, bool isHorizontal, float progress) = 0; - - virtual void DrawListBox( Controls::Base* control ) = 0; - virtual void DrawListBoxLine( Controls::Base* control, bool bSelected ) = 0; - - virtual void DrawSlider( Controls::Base* control, bool bIsHorizontal, int numNotches, int barSize) = 0; - virtual void DrawComboBox( Controls::Base* control ) = 0; - virtual void DrawComboBoxButton( Controls::Base* control, bool bDepressed ) = 0; - virtual void DrawKeyboardHighlight( Controls::Base* control, const Gwen::Rect& rect, int offset ) = 0; - //virtual void DrawComboBoxKeyboardHighlight( Controls::Base* control ); - virtual void DrawToolTip( Controls::Base* control ) = 0; - - virtual void DrawNumericUpDownButton( Controls::Base* control, bool bDepressed, bool bUp ) = 0; - - virtual void DrawTreeButton( Controls::Base* control, bool bOpen ) = 0; - virtual void DrawTreeControl( Controls::Base* control ) = 0; - virtual void DrawTreeNode( Controls::Base* ctrl, bool bOpen, bool bSelected, int iLabelHeight, int iLabelWidth, int iHalfWay, int iLastBranch, bool bIsRoot ) = 0; - - virtual void DrawPropertyRow( Controls::Base* control, int iWidth, bool bBeingEdited ) = 0; - virtual void DrawPropertyTreeNode( Controls::Base* control, int BorderLeft, int BorderTop ) = 0; - virtual void DrawColorDisplay( Controls::Base* control, Gwen::Color color ) = 0; - virtual void DrawModalControl( Controls::Base* control ) = 0; - virtual void DrawMenuDivider( Controls::Base* control ) = 0; - - - virtual void SetRender( Gwen::Renderer::Base* renderer ) - { - m_Render = renderer; - } - virtual Gwen::Renderer::Base* GetRender() - { - return m_Render; - } - - virtual void DrawArrowDown( Gwen::Rect rect ); - virtual void DrawArrowUp( Gwen::Rect rect ); - virtual void DrawArrowLeft( Gwen::Rect rect ); - virtual void DrawArrowRight( Gwen::Rect rect ); - virtual void DrawCheck( Gwen::Rect rect ); - - - public: - - virtual Gwen::Font* GetDefaultFont() - { - return &m_DefaultFont; - } - - virtual void SetDefaultFont( const Gwen::UnicodeString& strFacename, float fSize = 10.0f ) - { - m_DefaultFont.facename = strFacename; - m_DefaultFont.size = fSize; - } - - protected: - - Gwen::Font m_DefaultFont; - Gwen::Renderer::Base* m_Render; - - }; - }; -} -#endif diff --git a/btgui/Gwen/Skins/Simple.h b/btgui/Gwen/Skins/Simple.h deleted file mode 100644 index 58bddd8ca..000000000 --- a/btgui/Gwen/Skins/Simple.h +++ /dev/null @@ -1,750 +0,0 @@ -#pragma once -#ifndef GWEN_SKINS_SIMPLE_H -#define GWEN_SKINS_SIMPLE_H - -#include "Gwen/Skin.h" -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" - -namespace Gwen -{ - namespace Skin - { - class Simple : public Gwen::Skin::Base - { - public: - - Gwen::Color m_colBorderColor; - Gwen::Color m_colControlOutlineLight; - Gwen::Color m_colControlOutlineLighter; - Gwen::Color m_colBG; - Gwen::Color m_colBGDark; - Gwen::Color m_colControl; - Gwen::Color m_colControlBorderHighlight; - Gwen::Color m_colControlDarker; - Gwen::Color m_colControlOutlineNormal; - Gwen::Color m_colControlBright; - Gwen::Color m_colControlDark; - Gwen::Color m_colHighlightBG; - Gwen::Color m_colHighlightBorder; - Gwen::Color m_colToolTipBackground; - Gwen::Color m_colToolTipBorder; - Gwen::Color m_colModal; - - Simple() - { - m_colBorderColor = Gwen::Color( 80, 80, 80, 255 ); - m_colBG = Gwen::Color( 248, 248, 248, 255 ); - m_colBGDark = Gwen::Color( 235, 235, 235, 255 ); - - m_colControl = Gwen::Color( 240, 240, 240, 255 ); - m_colControlBright = Gwen::Color( 255, 255, 255, 255 ); - m_colControlDark = Gwen::Color( 214, 214, 214, 255 ); - m_colControlDarker = Gwen::Color( 180, 180, 180, 255 ); - - m_colControlOutlineNormal = Gwen::Color( 112, 112, 112, 255 ); - m_colControlOutlineLight = Gwen::Color( 144, 144, 144, 255 ); - m_colControlOutlineLighter = Gwen::Color( 210, 210, 210, 255 ); - - m_colHighlightBG = Gwen::Color( 192, 221, 252, 255 ); - m_colHighlightBorder = Gwen::Color( 51, 153, 255, 255 ); - - m_colToolTipBackground = Gwen::Color( 255, 255, 225, 255 ); - m_colToolTipBorder = Gwen::Color( 0, 0, 0, 255 ); - - m_colModal = Gwen::Color( 25, 25, 25, 150 ); - - m_DefaultFont.facename = L"Microsoft Sans Serif"; - m_DefaultFont.size = 11; - } - - - virtual void DrawButton( Gwen::Controls::Base* control, bool bDepressed, bool bHovered ) - { - int w = control->Width(); - int h = control->Height(); - - DrawButton( w, h, bDepressed, bHovered ); - } - - virtual void DrawMenuItem( Gwen::Controls::Base* control, bool bSubmenuOpen, bool bChecked ) - { - if ( bSubmenuOpen || control->IsHovered() ) - { - m_Render->SetDrawColor( m_colHighlightBG ); - m_Render->DrawFilledRect( control->GetRenderBounds() ); - - m_Render->SetDrawColor( m_colHighlightBorder ); - m_Render->DrawLinedRect( control->GetRenderBounds() ); - } - - // Gwen::Rect rect = control->GetRenderBounds(); - if ( bChecked ) - { - m_Render->SetDrawColor( Color( 0, 0, 0, 255) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - DrawCheck( r ); - } - } - - virtual void DrawMenuStrip( Gwen::Controls::Base* control ) - { - int w = control->Width(); - int h = control->Height(); - - m_Render->SetDrawColor( Gwen::Color( 246, 248, 252, 255 ) ); - m_Render->DrawFilledRect( Gwen::Rect( 0, 0, w, h ) ); - - m_Render->SetDrawColor( Gwen::Color( 218, 224, 241, 150 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( 0, h*0.4f, w, h*0.6f ) ); - m_Render->DrawFilledRect( Gwen::Rect( 0, h*0.5f, w, h*0.5f ) ); - - } - - virtual void DrawMenu( Gwen::Controls::Base* control, bool bPaddingDisabled ) - { - int w = control->Width(); - int h = control->Height(); - - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawFilledRect( Gwen::Rect( 0, 0, w, h ) ); - - if ( !bPaddingDisabled ) - { - m_Render->SetDrawColor( m_colControl ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 0, 22, h ) ); - } - - m_Render->SetDrawColor( m_colControlOutlineNormal ); - m_Render->DrawLinedRect( Gwen::Rect( 0, 0, w, h ) ); - } - - virtual void DrawShadow( Gwen::Controls::Base* control ) - { - int w = control->Width(); - int h = control->Height(); - - int x = 4; - int y = 6; - - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 10 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( x, y, w, h ) ); - x+=2; - m_Render->DrawFilledRect( Gwen::Rect( x, y, w, h ) ); - y+=2; - m_Render->DrawFilledRect( Gwen::Rect( x, y, w, h ) ); - - } - - virtual void DrawButton( int w, int h, bool bDepressed, bool bHovered, bool bSquared = false ) - { - if ( bDepressed ) m_Render->SetDrawColor( m_colControlDark ); - else if ( bHovered )m_Render->SetDrawColor( m_colControlBright ); - else m_Render->SetDrawColor( m_colControl ); - - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, w-2, h-2 ) ); - - if ( bDepressed ) m_Render->SetDrawColor( m_colControlDark ); - else if ( bHovered )m_Render->SetDrawColor( m_colControl ); - else m_Render->SetDrawColor( m_colControlDark ); - - m_Render->DrawFilledRect( Gwen::Rect( 1, h*0.5, w-2, h*0.5-2 ) ); - - if ( !bDepressed ) - { - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawShavedCornerRect( Gwen::Rect( 1, 1, w-2, h-2 ), bSquared ); - } - else - { - m_Render->SetDrawColor( m_colControlDarker ); - m_Render->DrawShavedCornerRect( Gwen::Rect( 1, 1, w-2, h-2 ), bSquared ); - } - - // Border - m_Render->SetDrawColor( m_colControlOutlineNormal ); - m_Render->DrawShavedCornerRect( Gwen::Rect( 0, 0, w, h ), bSquared ); - } - - virtual void DrawRadioButton( Gwen::Controls::Base* control, bool bSelected, bool bDepressed) - { - Gwen::Rect rect = control->GetRenderBounds(); - - // Inside colour - if ( control->IsHovered() ) m_Render->SetDrawColor( Gwen::Color( 220, 242, 254, 255 ) ); - else m_Render->SetDrawColor( m_colControlBright ); - - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - // Border - if ( control->IsHovered() ) m_Render->SetDrawColor( Gwen::Color( 85, 130, 164, 255 ) ); - else m_Render->SetDrawColor( m_colControlOutlineLight ); - - m_Render->DrawShavedCornerRect( rect ); - - m_Render->SetDrawColor( Gwen::Color( 0, 50, 60, 15 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w-4, rect.h-4 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w*0.3f, rect.h-4 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w-4, rect.h*0.3f ) ); - - if ( control->IsHovered() ) m_Render->SetDrawColor( Gwen::Color( 121, 198, 249, 255 ) ); - else m_Render->SetDrawColor( Gwen::Color( 0, 50, 60, 50 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+3, 1, rect.h-5 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+3, rect.y+2, rect.w-5, 1 ) ); - - - if ( bSelected ) - { - m_Render->SetDrawColor( Gwen::Color( 40, 230, 30, 255 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w -4, rect.h-4 ) ); - } - } - - - virtual void DrawCheckBox( Gwen::Controls::Base* control, bool bSelected, bool bDepressed) - { - Gwen::Rect rect = control->GetRenderBounds(); - - // Inside colour - if ( control->IsHovered() ) m_Render->SetDrawColor( Gwen::Color( 220, 242, 254, 255 ) ); - else m_Render->SetDrawColor( m_colControlBright ); - - m_Render->DrawFilledRect( rect ); - - // Border - if ( control->IsHovered() ) m_Render->SetDrawColor( Gwen::Color( 85, 130, 164, 255 ) ); - else m_Render->SetDrawColor( m_colControlOutlineLight ); - - m_Render->DrawLinedRect( rect ); - - m_Render->SetDrawColor( Gwen::Color( 0, 50, 60, 15 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w-4, rect.h-4 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w*0.3f, rect.h-4 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w-4, rect.h*0.3f ) ); - - if ( control->IsHovered() ) m_Render->SetDrawColor( Gwen::Color( 121, 198, 249, 255 ) ); - else m_Render->SetDrawColor( Gwen::Color( 0, 50, 60, 50 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, 1, rect.h-4 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+2, rect.y+2, rect.w-4, 1 ) ); - - - - if ( bDepressed ) - { - m_Render->SetDrawColor( Color( 100, 100, 100, 255) ); - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - DrawCheck( r ); - } - else if ( bSelected ) - { - m_Render->SetDrawColor( Color( 0, 0, 0, 255) ); - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - DrawCheck( r ); - } - } - - virtual void DrawGroupBox( Gwen::Controls::Base* control, int textStart, int textHeight, int textWidth ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - rect.y += textHeight * 0.5f; - rect.h -= textHeight * 0.5f; - - Gwen::Color m_colDarker = Gwen::Color( 0, 50, 60, 50 ); - Gwen::Color m_colLighter = Gwen::Color( 255, 255, 255, 150 ); - - m_Render->SetDrawColor( m_colLighter ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+1, textStart-3, 1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1+textStart+textWidth, rect.y+1, rect.w-textStart+textWidth-2, 1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, (rect.y + rect.h)-1, rect.w-2, 1 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+1, 1, rect.h ) ); - m_Render->DrawFilledRect( Gwen::Rect( (rect.x + rect.w)-2, rect.y+1, 1, rect.h-1 ) ); - - m_Render->SetDrawColor( m_colDarker ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y, textStart-3, 1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1+textStart+textWidth, rect.y, rect.w-textStart-textWidth-2, 1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, (rect.y + rect.h) -1, rect.w-2, 1 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x, rect.y+1, 1, rect.h-1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( (rect.x + rect.w)-1, rect.y+1, 1, rect.h-1 ) ); - } - - virtual void DrawTextBox( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - bool bHasFocus = control->HasFocus(); - - // Box inside - m_Render->SetDrawColor( Gwen::Color( 255, 255, 255, 255 ) ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - m_Render->SetDrawColor( m_colControlOutlineLight ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y, rect.w-2, 1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x, rect.y+1, 1, rect.h-2 ) ); - - m_Render->SetDrawColor( m_colControlOutlineLighter ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, (rect.y + rect.h)-1, rect.w-2, 1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( (rect.x + rect.w)-1, rect.y+1, 1, rect.h-2 ) ); - - if ( bHasFocus ) - { - m_Render->SetDrawColor( Gwen::Color( 50, 200, 255, 150 ) ); - m_Render->DrawLinedRect( rect ); - } - } - - virtual void DrawTabButton( Gwen::Controls::Base* control, bool bActive ) - { - Gwen::Rect rect = control->GetRenderBounds(); - bool bHovered = control->IsHovered(); - - if ( bActive ) - { - m_Render->SetDrawColor( m_colControl ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+1, rect.w-2, rect.h-1 ) ); - } - else - { - if ( bHovered )m_Render->SetDrawColor( m_colControlBright ); - else m_Render->SetDrawColor( m_colControl ); - - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-1 ) ); - - if ( bHovered )m_Render->SetDrawColor( m_colControl ); - else m_Render->SetDrawColor( m_colControlDark ); - - m_Render->DrawFilledRect( Gwen::Rect( 1, rect.h*0.5, rect.w-2, rect.h*0.5-1 ) ); - - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawShavedCornerRect( Gwen::Rect( 1, 1, rect.w-2, rect.h ) ); - } - - m_Render->SetDrawColor( m_colBorderColor ); - - m_Render->DrawShavedCornerRect( Gwen::Rect( 0, 0, rect.w, rect.h ) ); - } - - virtual void DrawTabControl( Gwen::Controls::Base* control, Gwen::Rect CurrentButtonRect ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - m_Render->SetDrawColor( m_colControl ); - m_Render->DrawFilledRect( rect ); - - m_Render->SetDrawColor( m_colBorderColor ); - m_Render->DrawLinedRect( rect ); - - m_Render->SetDrawColor( m_colControl ); - m_Render->DrawFilledRect( CurrentButtonRect ); - } - - virtual void DrawWindow( Gwen::Controls::Base* control, int topHeight, bool inFocus ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - // Titlebar - if ( inFocus ) - m_Render->SetDrawColor( Gwen::Color( 87, 164, 232, 230 ) ); - else - m_Render->SetDrawColor( Gwen::Color( 87*0.70, 164*0.70, 232*0.70, 230 ) ); - - int iBorderSize = 5; - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+1, rect.w-2, topHeight-1 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+topHeight-1, iBorderSize, rect.h-2-topHeight ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+rect.w-iBorderSize, rect.y+topHeight-1, iBorderSize, rect.h-2-topHeight ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+rect.h-iBorderSize, rect.w-2, iBorderSize ) ); - - // Main inner - m_Render->SetDrawColor( Gwen::Color( m_colControlDark.r, m_colControlDark.g, m_colControlDark.b, 230 ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x+iBorderSize+1, rect.y+topHeight, rect.w-iBorderSize*2-2, rect.h-topHeight-iBorderSize-1 ) ); - - // Light inner border - m_Render->SetDrawColor( Gwen::Color( 255, 255, 255, 100 ) ); - m_Render->DrawShavedCornerRect( Gwen::Rect( rect.x+1, rect.y+1, rect.w-2, rect.h-2 ) ); - - // Dark line between titlebar and main - m_Render->SetDrawColor( m_colBorderColor ); - - // Inside border - m_Render->SetDrawColor( m_colControlOutlineNormal ); - m_Render->DrawLinedRect( Gwen::Rect( rect.x+iBorderSize, rect.y+topHeight-1, rect.w - 10, rect.h - topHeight - (iBorderSize - 1) ) ); - - // Dark outer border - m_Render->SetDrawColor( m_colBorderColor ); - m_Render->DrawShavedCornerRect( Gwen::Rect( rect.x, rect.y, rect.w, rect.h ) ); - } - - virtual void DrawHighlight( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - m_Render->SetDrawColor( Gwen::Color( 255, 100, 255, 255 ) ); - m_Render->DrawFilledRect( rect ); - } - - virtual void DrawScrollBar( Gwen::Controls::Base* control, bool isHorizontal, bool bDepressed ) - { - Gwen::Rect rect = control->GetRenderBounds(); - if (bDepressed) - m_Render->SetDrawColor( m_colControlDarker ); - else - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawFilledRect( rect ); - } - - virtual void DrawScrollBarBar( Controls::Base* control, bool bDepressed, bool isHovered, bool isHorizontal ) - { - //TODO: something specialized - DrawButton( control, bDepressed, isHovered ); - } - - virtual void DrawTabTitleBar( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - m_Render->SetDrawColor( Gwen::Color( 177, 193, 214, 255 ) ); - m_Render->DrawFilledRect( rect ); - - m_Render->SetDrawColor( m_colBorderColor ); - rect.h += 1; - m_Render->DrawLinedRect( rect ); - } - - virtual void DrawProgressBar( Gwen::Controls::Base* control, bool isHorizontal, float progress) - { - Gwen::Rect rect = control->GetRenderBounds(); - Gwen::Color FillColour( 0, 211, 40, 255 ); - - if ( isHorizontal ) - { - //Background - m_Render->SetDrawColor( m_colControlDark ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - //Right half - m_Render->SetDrawColor( FillColour ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w*progress-2, rect.h-2 ) ); - - m_Render->SetDrawColor( Gwen::Color( 255, 255, 255, 150 ) ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h*0.45f ) ); - } - else - { - //Background - m_Render->SetDrawColor( m_colControlDark ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - //Top half - m_Render->SetDrawColor( FillColour ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1 + (rect.h * (1 - progress)), rect.w-2, rect.h * progress - 2 ) ); - - m_Render->SetDrawColor( Gwen::Color( 255, 255, 255, 150 ) ); - m_Render->DrawFilledRect( Gwen::Rect( 1, 1, rect.w*0.45f, rect.h-2 ) ); - } - - m_Render->SetDrawColor( Gwen::Color( 255, 255, 255, 150 ) ); - m_Render->DrawShavedCornerRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - m_Render->SetDrawColor( Gwen::Color( 255, 255, 255, 70 ) ); - m_Render->DrawShavedCornerRect( Gwen::Rect( 2, 2, rect.w-4, rect.h-4 ) ); - - m_Render->SetDrawColor( m_colBorderColor ); - m_Render->DrawShavedCornerRect( rect ); - } - - virtual void DrawListBox( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawFilledRect( rect ); - - m_Render->SetDrawColor( m_colBorderColor ); - m_Render->DrawLinedRect( rect ); - } - - virtual void DrawListBoxLine( Gwen::Controls::Base* control, bool bSelected ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - if ( bSelected ) - { - m_Render->SetDrawColor( m_colHighlightBorder ); - m_Render->DrawFilledRect( rect ); - } - else if ( control->IsHovered() ) - { - m_Render->SetDrawColor( m_colHighlightBG ); - m_Render->DrawFilledRect( rect ); - } - } - - - virtual void DrawSlider( Gwen::Controls::Base* control, bool bIsHorizontal, int numNotches, int barSize) - { - Gwen::Rect rect = control->GetRenderBounds(); -// Gwen::Rect notchRect = rect; - - if ( bIsHorizontal ) - { - rect.y += rect.h * 0.4; - rect.h -= rect.h * 0.8; - } - else - { - rect.x += rect.w * 0.4; - rect.w -= rect.w * 0.8; - } - - m_Render->SetDrawColor( m_colBGDark ); - m_Render->DrawFilledRect( rect ); - - m_Render->SetDrawColor( m_colControlDarker ); - m_Render->DrawLinedRect( rect ); - } - - virtual void DrawComboBox( Gwen::Controls::Base* control ) - { - DrawTextBox( control ); - } - - - virtual void DrawBackground( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - m_Render->SetDrawColor( m_colBGDark ); - m_Render->DrawFilledRect( rect ); - m_Render->SetDrawColor( m_colControlDarker); - m_Render->DrawLinedRect( rect ); - } - - virtual void DrawKeyboardHighlight( Gwen::Controls::Base* control, const Gwen::Rect& r, int iOffset ) - { - Gwen::Rect rect = r; - - rect.x += iOffset; - rect.y += iOffset; - rect.w -= iOffset*2; - rect.h -= iOffset*2; - - //draw the top and bottom - bool skip = true; - for(int i=0; i< rect.w*0.5; i++) - { - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - if (!skip) - { - m_Render->DrawPixel(rect.x + (i*2), rect.y); - m_Render->DrawPixel(rect.x + (i*2), rect.y+rect.h-1); - } - else - skip = !skip; - } - skip = false; - for(int i=0; i< rect.h*0.5; i++) - { - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - if (!skip) - { - m_Render->DrawPixel(rect.x , rect.y +i*2); - m_Render->DrawPixel(rect.x +rect.w-1, rect.y +i*2 ); - } - else - skip = !skip; - } - } - - virtual void DrawToolTip( Gwen::Controls::Base* control ) - { - Gwen::Rect rct = control->GetRenderBounds(); - rct.x -= 3; - rct.y -= 3; - rct.w += 6; - rct.h += 6; - - m_Render->SetDrawColor( m_colToolTipBackground ); - m_Render->DrawFilledRect( rct ); - - m_Render->SetDrawColor( m_colToolTipBorder ); - m_Render->DrawLinedRect( rct ); - } - - virtual void DrawScrollButton( Gwen::Controls::Base* control, int iDirection, bool bDepressed ) - { - DrawButton( control, bDepressed, false ); - - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 240 ) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - - if ( iDirection == Gwen::Pos::Top ) DrawArrowUp( r ); - else if ( iDirection == Gwen::Pos::Bottom ) DrawArrowDown( r ); - else if ( iDirection == Gwen::Pos::Left ) DrawArrowLeft( r ); - else DrawArrowRight( r ); - } - - virtual void DrawComboBoxButton( Gwen::Controls::Base* control, bool bDepressed ) - { - //DrawButton( control->Width(), control->Height(), bDepressed, false, true ); - - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 240 ) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - DrawArrowDown( r ); - } - - virtual void DrawNumericUpDownButton( Gwen::Controls::Base* control, bool bDepressed, bool bUp ) - { - //DrawButton( control->Width(), control->Height(), bDepressed, false, true ); - - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 240 ) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - - if ( bUp ) DrawArrowUp( r ); - else DrawArrowDown( r ); - - } - - virtual void DrawTreeButton( Controls::Base* control, bool bOpen ) - { - Gwen::Rect rect = control->GetRenderBounds(); - rect.x += 2; - rect.y += 2; - rect.w -= 4; - rect.h -= 4; - - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawFilledRect( rect ); - - m_Render->SetDrawColor( m_colBorderColor ); - m_Render->DrawLinedRect( rect ); - - m_Render->SetDrawColor( m_colBorderColor ); - - if ( !bOpen ) // ! because the button shows intention, not the current state - m_Render->DrawFilledRect( Gwen::Rect( rect.x + rect.w/2, rect.y + 2, 1, rect.h - 4 ) ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x +2, rect.y + rect.h/2, rect.w-4, 1 ) ); - - } - - virtual void DrawTreeControl( Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - m_Render->SetDrawColor( m_colControlBright ); - m_Render->DrawFilledRect( rect ); - - m_Render->SetDrawColor( m_colBorderColor ); - m_Render->DrawLinedRect( rect ); - } - - void DrawTreeNode( Controls::Base* ctrl, bool bOpen, bool bSelected, int iLabelHeight, int iLabelWidth, int iHalfWay, int iLastBranch, bool bIsRoot ) - { - if ( bSelected ) - { - m_Render->SetDrawColor( Color( 0, 150, 255, 100 ) ); - m_Render->DrawFilledRect( Gwen::Rect( 17, 0, iLabelWidth + 2, iLabelHeight-1 ) ); - m_Render->SetDrawColor( Color( 0, 150, 255, 200 ) ); - m_Render->DrawLinedRect( Gwen::Rect( 17, 0, iLabelWidth + 2, iLabelHeight-1 ) ); - } - - m_Render->SetDrawColor( Color( 0, 0, 0, 50 ) ); - - if ( !bIsRoot ) - m_Render->DrawFilledRect( Gwen::Rect( 9, iHalfWay, 16-9, 1 ) ); - - if ( !bOpen ) return; - - m_Render->DrawFilledRect( Gwen::Rect( 14 + 8, iLabelHeight, 1, iLastBranch + iHalfWay - iLabelHeight ) ); - } - - virtual void DrawStatusBar( Controls::Base* control ) - { - DrawBackground( control ); - } - - virtual void DrawPropertyRow( Controls::Base* control, int iWidth, bool bBeingEdited ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - - if ( bBeingEdited ) - { - m_Render->SetDrawColor( m_colHighlightBG ); - m_Render->DrawFilledRect( Gwen::Rect( 0, rect.y, iWidth, rect.h ) ); - } - - m_Render->SetDrawColor( m_colControlOutlineLighter ); - - m_Render->DrawFilledRect( Gwen::Rect( iWidth, rect.y, 1, rect.h ) ); - - rect.y += rect.h-1; - rect.h = 1; - - - m_Render->DrawFilledRect( rect ); - } - - virtual void DrawPropertyTreeNode( Controls::Base* control, int BorderLeft, int BorderTop ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - m_Render->SetDrawColor( m_colControlOutlineLighter ); - - m_Render->DrawFilledRect( Gwen::Rect( rect.x, rect.y, BorderLeft, rect.h ) ); - m_Render->DrawFilledRect( Gwen::Rect( rect.x + BorderLeft, rect.y, rect.w - BorderLeft, BorderTop ) ); - } - - void DrawColorDisplay( Controls::Base* control, Gwen::Color color ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - if ( color.a != 255 ) - { - GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 255 ) ); - GetRender()->DrawFilledRect( rect ); - - GetRender()->SetDrawColor( Gwen::Color( 128, 128, 128, 128 ) ); - - GetRender()->DrawFilledRect( Gwen::Rect( 0, 0, rect.w * 0.5, rect.h * 0.5) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.w * 0.5, rect.h * 0.5, rect.w * 0.5,rect.h * 0.5) ); - } - - GetRender()->SetDrawColor( color ); - GetRender()->DrawFilledRect( rect ); - - GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - GetRender()->DrawLinedRect( rect ); - } - - virtual void DrawModalControl( Controls::Base* control ) - { - if ( control->ShouldDrawBackground() ) - { - Gwen::Rect rect = control->GetRenderBounds(); - GetRender()->SetDrawColor( m_colModal ); - GetRender()->DrawFilledRect( rect ); - } - } - - virtual void DrawMenuDivider( Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - GetRender()->SetDrawColor( m_colBGDark ); - GetRender()->DrawFilledRect( rect ); - GetRender()->SetDrawColor( m_colControlDarker); - GetRender()->DrawLinedRect( rect ); - } - }; - } -} -#endif diff --git a/btgui/Gwen/Skins/TexturedBase.h b/btgui/Gwen/Skins/TexturedBase.h deleted file mode 100644 index a342413d1..000000000 --- a/btgui/Gwen/Skins/TexturedBase.h +++ /dev/null @@ -1,625 +0,0 @@ -#pragma once -#ifndef GWEN_SKINS_TEXTUREDBASE_H -#define GWEN_SKINS_TEXTUREDBASE_H - -#include "Gwen/Skin.h" -#include "Gwen/Gwen.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/Texture.h" -#include "Gwen/Skins/Texturing.h" - -namespace Gwen -{ - namespace Skin - { - class TexturedBase : public Gwen::Skin::Base - { - public: - - Gwen::Color m_colBorderColor; - Gwen::Color m_colControlOutlineLight; - Gwen::Color m_colControlOutlineLighter; - Gwen::Color m_colBG; - Gwen::Color m_colBGDark; - Gwen::Color m_colControl; - Gwen::Color m_colControlBorderHighlight; - Gwen::Color m_colControlDarker; - Gwen::Color m_colControlOutlineNormal; - Gwen::Color m_colControlBright; - Gwen::Color m_colControlDark; - Gwen::Color m_colHighlightBG; - Gwen::Color m_colHighlightBorder; - Gwen::Color m_colToolTipBackground; - Gwen::Color m_colToolTipBorder; - Gwen::Color m_colModal; - - Texture m_Texture; - - Texturing::Bordered m_texButton; - Texturing::Bordered m_texButton_Hovered; - Texturing::Bordered m_texButton_Pressed; - - Texturing::Bordered m_texMenu_Strip, m_texMenu_Panel, m_texMenu_Panel_Border; - Texturing::Bordered m_texMenu_Hover; - Texturing::Bordered m_texShadow; - - Texturing::Bordered m_texTextBox, m_texTextBox_Focus; - - Texturing::Bordered m_texTab_Control, m_texTab, m_texTab_Inactive, m_texTab_Gap, m_texTabBar; - - Texturing::Bordered m_texWindow, m_texWindow_Inactive; - Texturing::Bordered m_texTreeBG; - - Texturing::Single m_Checkbox, m_Checkbox_Checked; - Texturing::Single m_RadioButton, m_RadioButton_Checked; - - Texturing::Single m_CheckMark; - - - Texturing::Single m_TreeMinus, m_TreePlus; - - virtual void Init( const TextObject& TextureName ) - { - m_colBorderColor = Gwen::Color( 80, 80, 80, 255 ); - m_colBG = Gwen::Color( 248, 248, 248, 255 ); - m_colBGDark = Gwen::Color( 235, 235, 235, 255 ); - - m_colControl = Gwen::Color( 240, 240, 240, 255 ); - m_colControlBright = Gwen::Color( 255, 255, 255, 255 ); - m_colControlDark = Gwen::Color( 214, 214, 214, 255 ); - m_colControlDarker = Gwen::Color( 180, 180, 180, 255 ); - - m_colControlOutlineNormal = Gwen::Color( 112, 112, 112, 255 ); - m_colControlOutlineLight = Gwen::Color( 144, 144, 144, 255 ); - m_colControlOutlineLighter = Gwen::Color( 210, 210, 210, 255 ); - - m_colHighlightBG = Gwen::Color( 192, 221, 252, 255 ); - m_colHighlightBorder = Gwen::Color( 51, 153, 255, 255 ); - - m_colToolTipBackground = Gwen::Color( 255, 255, 225, 255 ); - m_colToolTipBorder = Gwen::Color( 0, 0, 0, 255 ); - - m_colModal = Gwen::Color( 25, 25, 25, 150 ); - - m_DefaultFont.facename = L"Microsoft Sans Serif"; - m_DefaultFont.size = 11; - - m_Texture.Load( TextureName, GetRender() ); - - m_texButton.Init( &m_Texture, 194, 0, 24, 24, Margin( 8, 8, 8, 8 ) ); - m_texButton_Hovered.Init( &m_Texture, 194, 25, 24, 24, Margin( 8, 8, 8, 8 ) ); - m_texButton_Pressed.Init( &m_Texture, 194, 50, 24, 24, Margin( 8, 8, 8, 8 ) ); - - m_texMenu_Strip.Init( &m_Texture, 194, 75, 62, 21, Margin( 8, 8, 8, 8 ) ); - m_texMenu_Panel.Init( &m_Texture, 194, 130, 62, 32, Margin( 8, 8, 8, 8 ) ); - m_texMenu_Panel_Border.Init( &m_Texture, 194, 97, 62, 32, Margin( 24, 8, 8, 8 ) ); - m_texMenu_Hover.Init( &m_Texture, 219, 50, 24, 24, Margin( 8, 8, 8, 8 ) ); - - m_texShadow.Init( &m_Texture, 223, 0, 32, 32, Margin( 8, 8, 8, 8 ) ); - - m_texTextBox.Init( &m_Texture, 0, 122, 24, 24, Margin( 8, 8, 8, 8 ) ); - m_texTextBox_Focus.Init( &m_Texture, 25, 122, 24, 24, Margin( 8, 8, 8, 8 ) ); - - m_texTab.Init( &m_Texture, 0, 97, 24, 24, Margin( 8, 8, 8, 8 ) ); - m_texTab_Inactive.Init( &m_Texture, 25, 97, 24, 24, Margin( 8, 8, 8, 8 ) ); - m_texTab_Control.Init( &m_Texture, 50, 97, 24, 24, Margin( 8, 8, 8, 8 ) ); - m_texTab_Gap.Init( &m_Texture, 50+8, 97+8, 8, 8, Margin( 8, 8, 8, 8 ) ); - m_texTabBar.Init( &m_Texture, 0, 147, 74, 16, Margin( 4, 4, 4, 4 ) ); - - - m_texWindow.Init( &m_Texture, 0, 0, 96, 96, Margin( 16, 32, 16, 16 ) ); - m_texWindow_Inactive.Init( &m_Texture, 97, 0, 96, 96, Margin( 16, 32, 16, 16 ) ); - - m_Checkbox.Init( &m_Texture, 75, 97, 16, 16 ); - m_Checkbox_Checked.Init( &m_Texture, 93, 97, 16, 16 ); - - m_RadioButton.Init( &m_Texture, 110, 97, 16, 16 ); - m_RadioButton_Checked.Init( &m_Texture, 127, 97, 16, 16 ); - - - m_CheckMark.Init( &m_Texture, 145, 97, 16, 16 ); - m_TreeMinus.Init( &m_Texture, 75, 115, 11, 11 ); - m_TreePlus.Init( &m_Texture, 93, 115, 11, 11 ); - - m_texTreeBG.Init( &m_Texture, 0, 164, 49, 49, Margin( 16, 16, 16, 16 ) ); - } - - - virtual void DrawButton( Gwen::Controls::Base* control, bool bDepressed, bool bHovered ) - { - if ( bDepressed ) - m_texButton_Pressed.Draw( GetRender(), control->GetRenderBounds() ); - else - m_texButton.Draw( GetRender(), control->GetRenderBounds() ); - - if ( bHovered ) - m_texButton_Hovered.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawMenuItem( Gwen::Controls::Base* control, bool bSubmenuOpen, bool bChecked ) - { - if ( bSubmenuOpen || control->IsHovered() ) - m_texMenu_Hover.Draw( GetRender(), control->GetRenderBounds() ); - - if ( bChecked ) - m_CheckMark.Draw( GetRender(), Gwen::Rect( control->GetRenderBounds().x+2, control->GetRenderBounds().y+2, 16, 16 )); - } - - virtual void DrawMenuStrip( Gwen::Controls::Base* control ) - { - m_texMenu_Strip.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawMenu( Gwen::Controls::Base* control, bool bPaddingDisabled ) - { - if ( !bPaddingDisabled ) - { - return m_texMenu_Panel_Border.Draw( GetRender(), control->GetRenderBounds() ); - } - - m_texMenu_Panel.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawShadow( Gwen::Controls::Base* control ) - { - Gwen::Rect r = control->GetRenderBounds(); - r.x -= 8; - r.y -= 8; - r.w += 16; - r.h += 16; - // m_texShadow.Draw( r ); - } - - virtual void DrawRadioButton( Gwen::Controls::Base* control, bool bSelected, bool bDepressed) - { - if ( bSelected ) - m_RadioButton_Checked.Draw( GetRender(), control->GetRenderBounds() ); - else - m_RadioButton.Draw( GetRender(), control->GetRenderBounds() ); - } - - - virtual void DrawCheckBox( Gwen::Controls::Base* control, bool bSelected, bool bDepressed) - { - if ( bSelected ) - m_Checkbox_Checked.Draw( GetRender(), control->GetRenderBounds() ); - else - m_Checkbox.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawGroupBox( Gwen::Controls::Base* control, int textStart, int textHeight, int textWidth ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - rect.y += textHeight * 0.5f; - rect.h -= textHeight * 0.5f; - - Gwen::Color m_colDarker = Gwen::Color( 0, 50, 60, 50 ); - Gwen::Color m_colLighter = Gwen::Color( 255, 255, 255, 150 ); - - GetRender()->SetDrawColor( m_colLighter ); - - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+1, textStart-3, 1 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1+textStart+textWidth, rect.y+1, rect.w-textStart+textWidth-2, 1 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1, (rect.y + rect.h)-1, rect.x+rect.w-2, 1 ) ); - - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y+1, 1, rect.h ) ); - GetRender()->DrawFilledRect( Gwen::Rect( (rect.x + rect.w)-2, rect.y+1, 1, rect.h-1 ) ); - - GetRender()->SetDrawColor( m_colDarker ); - - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1, rect.y, textStart-3, 1 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1+textStart+textWidth, rect.y, rect.w-textStart-textWidth-2, 1 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.x+1, (rect.y + rect.h)-1, rect.x+rect.w-2, 1 ) ); - - GetRender()->DrawFilledRect( Gwen::Rect( rect.x, rect.y+1, 1, rect.h-1 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( (rect.x + rect.w)-1, rect.y+1, 1, rect.h-1 ) ); - } - - virtual void DrawTextBox( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - bool bHasFocus = control->HasFocus(); - - if ( bHasFocus ) - m_texTextBox_Focus.Draw( GetRender(), control->GetRenderBounds() ); - else - m_texTextBox.Draw( GetRender(), control->GetRenderBounds() ); - - - //I dunno what this is for yet - /* - if ( CursorRect.w == 1 ) - { - if ( bHasFocus ) - { - GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 200 ) ); - GetRender()->DrawFilledRect( CursorRect ); - } - } - else - { - if ( bHasFocus ) - { - GetRender()->SetDrawColor( Gwen::Color( 50, 150, 255, 250 ) ); - GetRender()->DrawFilledRect( CursorRect ); - } - } - */ - } - - virtual void DrawTabButton( Gwen::Controls::Base* control, bool bActive ) - { - if ( bActive ) - m_texTab.Draw( GetRender(), control->GetRenderBounds() ); - else - m_texTab_Inactive.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawTabControl( Gwen::Controls::Base* control, Gwen::Rect CurrentButtonRect ) - { - m_texTab_Control.Draw( GetRender(), control->GetRenderBounds() ); - - if ( CurrentButtonRect.w > 0 && CurrentButtonRect.h > 0 ) - m_texTab_Gap.Draw( GetRender(), CurrentButtonRect ); - } - - virtual void DrawTabTitleBar( Gwen::Controls::Base* control ) - { - m_texTabBar.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawWindow( Gwen::Controls::Base* control, int topHeight, bool inFocus ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - if ( inFocus ) m_texWindow.Draw( GetRender(), control->GetRenderBounds() ); - else m_texWindow_Inactive.Draw( GetRender(), control->GetRenderBounds() ); - } - - virtual void DrawHighlight( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - GetRender()->SetDrawColor( Gwen::Color( 255, 100, 255, 255 ) ); - GetRender()->DrawFilledRect( rect ); - } - - virtual void DrawScrollBar( Gwen::Controls::Base* control, bool isHorizontal, bool bDepressed ) - { - Gwen::Rect rect = control->GetRenderBounds(); - if (bDepressed) - GetRender()->SetDrawColor( m_colControlDarker ); - else - GetRender()->SetDrawColor( m_colControlBright ); - GetRender()->DrawFilledRect( rect ); - } - - virtual void DrawScrollBarBar( Controls::Base* control, bool bDepressed, bool isHovered, bool isHorizontal ) - { - //TODO: something specialized - DrawButton( control, bDepressed, isHovered ); - } - - - - virtual void DrawProgressBar( Gwen::Controls::Base* control, bool isHorizontal, float progress) - { - Gwen::Rect rect = control->GetRenderBounds(); - Gwen::Color FillColour( 0, 211, 40, 255 ); - - if ( isHorizontal ) - { - //Background - GetRender()->SetDrawColor( m_colControlDark ); - GetRender()->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - //Right half - GetRender()->SetDrawColor( FillColour ); - GetRender()->DrawFilledRect( Gwen::Rect( 1, 1, rect.w*progress-2, rect.h-2 ) ); - - GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 150 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h*0.45f ) ); - } - else - { - //Background - GetRender()->SetDrawColor( m_colControlDark ); - GetRender()->DrawFilledRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - //Top half - GetRender()->SetDrawColor( FillColour ); - GetRender()->DrawFilledRect( Gwen::Rect( 1, 1 + (rect.h * (1 - progress)), rect.w-2, rect.h * progress - 2 ) ); - - GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 150 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( 1, 1, rect.w*0.45f, rect.h-2 ) ); - } - - GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 150 ) ); - GetRender()->DrawShavedCornerRect( Gwen::Rect( 1, 1, rect.w-2, rect.h-2 ) ); - - GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 70 ) ); - GetRender()->DrawShavedCornerRect( Gwen::Rect( 2, 2, rect.w-4, rect.h-4 ) ); - - GetRender()->SetDrawColor( m_colBorderColor ); - GetRender()->DrawShavedCornerRect( rect ); - } - - virtual void DrawListBox( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - GetRender()->SetDrawColor( m_colControlBright ); - GetRender()->DrawFilledRect( rect ); - - GetRender()->SetDrawColor( m_colBorderColor ); - GetRender()->DrawLinedRect( rect ); - } - - virtual void DrawListBoxLine( Gwen::Controls::Base* control, bool bSelected ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - if ( bSelected ) - { - GetRender()->SetDrawColor( m_colHighlightBorder ); - GetRender()->DrawFilledRect( rect ); - } - else if ( control->IsHovered() ) - { - GetRender()->SetDrawColor( m_colHighlightBG ); - GetRender()->DrawFilledRect( rect ); - } - } - - - virtual void DrawSlider( Gwen::Controls::Base* control, bool bIsHorizontal, int numNotches, int barSize) - { - Gwen::Rect rect = control->GetRenderBounds(); - Gwen::Rect notchRect = rect; - - if ( bIsHorizontal ) - { - rect.y += rect.h * 0.4; - rect.h -= rect.h * 0.8; - } - else - { - rect.x += rect.w * 0.4; - rect.w -= rect.w * 0.8; - } - - GetRender()->SetDrawColor( m_colBGDark ); - GetRender()->DrawFilledRect( rect ); - - GetRender()->SetDrawColor( m_colControlDarker ); - GetRender()->DrawLinedRect( rect ); - } - - virtual void DrawComboBox( Gwen::Controls::Base* control ) - { - DrawTextBox( control ); - } - - virtual void DrawKeyboardHighlight( Gwen::Controls::Base* control, const Gwen::Rect& r, int iOffset ) - { - Gwen::Rect rect = r; - - rect.x += iOffset; - rect.y += iOffset; - rect.w -= iOffset*2; - rect.h -= iOffset*2; - - //draw the top and bottom - bool skip = true; - for(int i=0; i< rect.w*0.5; i++) - { - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - if (!skip) - { - GetRender()->DrawPixel(rect.x + (i*2), rect.y); - GetRender()->DrawPixel(rect.x + (i*2), rect.y+rect.h-1); - } - else - skip = !skip; - } - skip = false; - for(int i=0; i< rect.h*0.5; i++) - { - GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - if (!skip) - { - GetRender()->DrawPixel(rect.x , rect.y +i*2); - GetRender()->DrawPixel(rect.x +rect.w-1, rect.y +i*2 ); - } - else - skip = !skip; - } - } - - virtual void DrawToolTip( Gwen::Controls::Base* control ) - { - Gwen::Rect rct = control->GetRenderBounds(); - rct.x -= 3; - rct.y -= 3; - rct.w += 6; - rct.h += 6; - - GetRender()->SetDrawColor( m_colToolTipBackground ); - GetRender()->DrawFilledRect( rct ); - - GetRender()->SetDrawColor( m_colToolTipBorder ); - GetRender()->DrawLinedRect( rct ); - } - - virtual void DrawScrollButton( Gwen::Controls::Base* control, int iDirection, bool bDepressed ) - { - DrawButton( control, bDepressed, false ); - - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 240 ) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - - if ( iDirection == Gwen::Pos::Top ) DrawArrowUp( r ); - else if ( iDirection == Gwen::Pos::Bottom ) DrawArrowDown( r ); - else if ( iDirection == Gwen::Pos::Left ) DrawArrowLeft( r ); - else DrawArrowRight( r ); - } - - virtual void DrawComboBoxButton( Gwen::Controls::Base* control, bool bDepressed ) - { - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 240 ) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - DrawArrowDown( r ); - } - - virtual void DrawNumericUpDownButton( Gwen::Controls::Base* control, bool bDepressed, bool bUp ) - { - // DrawButton( control->Width(), control->Height(), bDepressed, false, true ); - - m_Render->SetDrawColor( Gwen::Color( 0, 0, 0, 240 ) ); - - Gwen::Rect r( control->Width() / 2 - 2, control->Height() / 2 - 2, 5, 5 ); - - if ( bUp ) DrawArrowUp( r ); - else DrawArrowDown( r ); - } - - virtual void DrawStatusBar( Controls::Base* control ) - { - DrawBackground( control ); - } - - - virtual void DrawBackground( Gwen::Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - m_Render->SetDrawColor( m_colBGDark ); - m_Render->DrawFilledRect( rect ); - m_Render->SetDrawColor( m_colControlDarker); - m_Render->DrawLinedRect( rect ); - } - - virtual void DrawTreeButton( Controls::Base* control, bool bOpen ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - rect.x += 2; - rect.y += 2; - rect.w -= 2; - rect.h -= 2; - if ( bOpen ) - { - m_TreeMinus.Draw( GetRender(), rect ); - } - else - m_TreePlus.Draw( GetRender(), rect ); - } - - virtual void DrawTreeControl( Controls::Base* control ) - { - m_texTreeBG.Draw( GetRender(), control->GetRenderBounds() ); - } - - - - virtual void DrawPropertyRow( Controls::Base* control, int iWidth, bool bBeingEdited ) - { - - Gwen::Rect rect = control->GetRenderBounds(); - - - if ( bBeingEdited ) - { - GetRender()->SetDrawColor( m_colHighlightBG ); - GetRender()->DrawFilledRect( Gwen::Rect( 0, rect.y, iWidth, rect.h ) ); - } - - GetRender()->SetDrawColor( m_colControlOutlineLighter ); - - GetRender()->DrawFilledRect( Gwen::Rect( iWidth, rect.y, 1, rect.h ) ); - - rect.y += rect.h-1; - rect.h = 1; - - - GetRender()->DrawFilledRect( rect ); - - } - - virtual void DrawPropertyTreeNode( Controls::Base* control, int BorderLeft, int BorderTop ) - { - - Gwen::Rect rect = control->GetRenderBounds(); - - GetRender()->SetDrawColor( m_colControlOutlineLighter ); - - GetRender()->DrawFilledRect( Gwen::Rect( rect.x, rect.y, BorderLeft, rect.h ) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.x + BorderLeft, rect.y, rect.w - BorderLeft, BorderTop ) ); - - } - - void DrawTreeNode( Controls::Base* ctrl, bool bOpen, bool bSelected, int iLabelHeight, int iLabelWidth, int iHalfWay, int iLastBranch, bool bIsRoot ) - { - if ( bSelected ) - { - GetRender()->SetDrawColor( Color( 0, 150, 255, 100 ) ); - GetRender()->DrawFilledRect( Gwen::Rect( 17, 0, iLabelWidth + 2, iLabelHeight-1 ) ); - GetRender()->SetDrawColor( Color( 0, 150, 255, 200 ) ); - GetRender()->DrawLinedRect( Gwen::Rect( 17, 0, iLabelWidth + 2, iLabelHeight-1 ) ); - } - - GetRender()->SetDrawColor( Color( 0, 0, 0, 50 ) ); - - if ( !bIsRoot ) - GetRender()->DrawFilledRect( Gwen::Rect( 9, iHalfWay, 16-9, 1 ) ); - - if ( !bOpen ) return; - - GetRender()->DrawFilledRect( Gwen::Rect( 14 + 8, iLabelHeight, 1, iLastBranch + iHalfWay - iLabelHeight ) ); - } - - void DrawColorDisplay( Controls::Base* control, Gwen::Color color ) - { - Gwen::Rect rect = control->GetRenderBounds(); - - if ( color.a != 255) - { - GetRender()->SetDrawColor( Gwen::Color( 255, 255, 255, 255 ) ); - GetRender()->DrawFilledRect( rect ); - - GetRender()->SetDrawColor( Gwen::Color( 128, 128, 128, 128 ) ); - - GetRender()->DrawFilledRect( Gwen::Rect( 0, 0, rect.w * 0.5, rect.h * 0.5) ); - GetRender()->DrawFilledRect( Gwen::Rect( rect.w * 0.5, rect.h * 0.5, rect.w * 0.5,rect.h * 0.5) ); - } - - GetRender()->SetDrawColor( color ); - GetRender()->DrawFilledRect( rect ); - - GetRender()->SetDrawColor( Gwen::Color( 0, 0, 0, 255 ) ); - GetRender()->DrawLinedRect( rect ); - } - - virtual void DrawModalControl( Controls::Base* control ) - { - if ( control->ShouldDrawBackground() ) - { - Gwen::Rect rect = control->GetRenderBounds(); - GetRender()->SetDrawColor( m_colModal ); - GetRender()->DrawFilledRect( rect ); - } - } - - virtual void DrawMenuDivider( Controls::Base* control ) - { - Gwen::Rect rect = control->GetRenderBounds(); - GetRender()->SetDrawColor( m_colBGDark ); - GetRender()->DrawFilledRect( rect ); - GetRender()->SetDrawColor( m_colControlDarker); - GetRender()->DrawLinedRect( rect ); - } - }; - } -} -#endif diff --git a/btgui/Gwen/Skins/Texturing.h b/btgui/Gwen/Skins/Texturing.h deleted file mode 100644 index 3792aba09..000000000 --- a/btgui/Gwen/Skins/Texturing.h +++ /dev/null @@ -1,147 +0,0 @@ -#pragma once -#ifndef GWEN_SKINS_TEXTURING_H -#define GWEN_SKINS_TEXTURING_H - -#include "Gwen/Gwen.h" -#include "Gwen/Texture.h" - -namespace Gwen -{ - namespace Skin - { - namespace Texturing - { - struct Single - { - Single() - { - texture = NULL; - } - - void Init( Texture* pTexture, float x, float y, float w, float h ) - { - texture = pTexture; - - float texw = texture->width; - float texh = texture->height; - - uv[0] = x / texw; - uv[1] = y / texh; - uv[2] = (x+w) / texw; - uv[3] = (y+h) / texh; - } - - void Draw( Gwen::Renderer::Base* render, Gwen::Rect r, const Gwen::Color& col = Gwen::Colors::White ) - { - render->SetDrawColor( col ); - - render->DrawTexturedRect( texture, r, uv[0], uv[1],uv[2], uv[3] ); - } - - Texture* texture; - float uv[4]; - }; - - struct Bordered - { - Bordered() - { - texture = NULL; - } - - void Init( Texture* pTexture, float x, float y, float w, float h, Margin in_margin, float DrawMarginScale = 1.0f ) - { - texture = pTexture; - - margin = in_margin; - - SetRect( 0, x, y, margin.left, margin.top ); - SetRect( 1, x+margin.left, y, w - margin.left - margin.right - 1, margin.top ); - SetRect( 2, (x + w) - margin.right, y, margin.right, margin.top ); - - SetRect( 3, x, y+margin.top, margin.left, h - margin.top - margin.bottom - 1 ); - SetRect( 4, x+margin.left, y+margin.top, w - margin.left - margin.right - 1, h - margin.top - margin.bottom - 1 ); - SetRect( 5, (x + w) - margin.right, y+margin.top, margin.right, h - margin.top - margin.bottom - 1 ); - - SetRect( 6, x, (y+h)-margin.bottom, margin.left, margin.bottom ); - SetRect( 7, x+margin.left, (y+h)-margin.bottom, w - margin.left - margin.right - 1, margin.bottom ); - SetRect( 8, (x + w) - margin.right, (y+h)-margin.bottom, margin.right, margin.bottom ); - - margin.left *= DrawMarginScale; - margin.right *= DrawMarginScale; - margin.top *= DrawMarginScale; - margin.bottom *= DrawMarginScale; - - width = w - x; - height = h - y; - } - - void SetRect( int iNum, float x, float y, float w, float h ) - { - float texw = texture->width; - float texh = texture->height; - - //x -= 1.0f; - //y -= 1.0f; - - - - rects[iNum].uv[0] = x / texw; - rects[iNum].uv[1] = y / texh; - - rects[iNum].uv[2] = (x+w) / texw; - rects[iNum].uv[3] = (y+h) / texh; - - // rects[iNum].uv[0] += 1.0f / texture->width; - // rects[iNum].uv[1] += 1.0f / texture->width; - } - - void Draw( Gwen::Renderer::Base* render, Gwen::Rect r, const Gwen::Color& col = Gwen::Colors::White ) - { - render->SetDrawColor( col ); - - if ( r.w < width && r.h < height ) - { - render->DrawTexturedRect( texture, - r, - rects[0].uv[0], rects[0].uv[1], rects[8].uv[2], rects[8].uv[3] ); - return; - } - - DrawRect( render, 0, r.x, r.y, margin.left, margin.top ); - DrawRect( render, 1, r.x + margin.left, r.y, r.w - margin.left - margin.right, margin.top ); - DrawRect( render, 2, (r.x + r.w) - margin.right, r.y, margin.right, margin.top ); - - DrawRect( render, 3, r.x, r.y+margin.top, margin.left, r.h - margin.top - margin.bottom ); - DrawRect( render, 4, r.x + margin.left, r.y+margin.top, r.w - margin.left - margin.right, r.h - margin.top - margin.bottom ); - DrawRect( render, 5, (r.x + r.w) - margin.right, r.y+margin.top, margin.right, r.h - margin.top - margin.bottom ); - - DrawRect( render, 6, r.x, (r.y+r.h) - margin.bottom, margin.left, margin.bottom ); - DrawRect( render, 7, r.x + margin.left, (r.y+r.h) - margin.bottom, r.w - margin.left - margin.right, margin.bottom ); - DrawRect( render, 8, (r.x + r.w) - margin.right, (r.y+r.h) - margin.bottom, margin.right, margin.bottom ); - } - - void DrawRect( Gwen::Renderer::Base* render, int i, int x, int y, int w, int h ) - { - render->DrawTexturedRect( texture, - Gwen::Rect( x, y, w, h ), - rects[i].uv[0], rects[i].uv[1], rects[i].uv[2], rects[i].uv[3] ); - } - - Texture* texture; - - struct SubRect - { - float uv[4]; - }; - - SubRect rects[9]; - Margin margin; - - float width; - float height; - }; - } - } -} -#endif diff --git a/btgui/Gwen/Structures.h b/btgui/Gwen/Structures.h deleted file mode 100644 index 500f2e9c9..000000000 --- a/btgui/Gwen/Structures.h +++ /dev/null @@ -1,200 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifdef _MSC_VER -#pragma warning( disable : 4244 ) -#pragma warning( disable : 4251 ) -#endif -#ifndef GWEN_STRUCTURES_H -#define GWEN_STRUCTURES_H - -#include "Gwen/Exports.h" -#include - -namespace Gwen -{ - namespace Controls - { - class Base; - class Canvas; - } - - namespace CursorType - { - static const unsigned char Normal = 0; - static const unsigned char Beam = 1; - static const unsigned char SizeNS = 2; - static const unsigned char SizeWE = 3; - static const unsigned char SizeNWSE = 4; - static const unsigned char SizeNESW = 5; - static const unsigned char SizeAll = 6; - static const unsigned char No = 7; - static const unsigned char Wait = 8; - static const unsigned char Finger = 9; - - static const unsigned char Count = 10; - } - - typedef std::wstring UnicodeString; - typedef std::string String; - typedef wchar_t UnicodeChar; // Portability?? - - struct GWEN_EXPORT Margin - { - Margin( int left = 0, int top = 0, int right = 0, int bottom = 0 ) - { - this->top = top; - this->bottom = bottom; - this->left = left; - this->right = right; - } - - int top, bottom, left, right; - }; - - - typedef Margin Padding; - - - struct GWEN_EXPORT Rect - { - Rect( int x = 0, int y = 0, int w = 0, int h = 0 ) - { - this->x = x; - this->y = y; - this->w = w; - this->h = h; - } - - int x, y, w, h; - }; - - - struct GWEN_EXPORT Point - { - Point(int x = 0, int y = 0) - { - this->x = x; - this->y = y; - } - - int x, y; - }; - - struct GWEN_EXPORT HSV - { - float h; - float s; - float v; - }; - - - struct GWEN_EXPORT Color - { - Color( unsigned char r = 255, unsigned char g = 255, unsigned char b = 255, unsigned char a = 255 ) - { - this->r = r; - this->g = g; - this->b = b; - this->a = a; - } - - void operator = ( Color c ) - { - this->r = c.r; - this->g = c.g; - this->b = c.b; - this->a = c.a; - } - - void operator += ( Color c ) - { - this->r += c.r; - this->g += c.g; - this->b += c.b; - this->a += c.a; - } - - void operator -= ( Color c ) - { - this->r -= c.r; - this->g -= c.g; - this->b -= c.b; - this->a -= c.a; - } - - void operator *= ( float f ) - { - this->r *= f; - this->g *= f; - this->b *= f; - this->a *= f; - } - - Color operator *( float f ) - { - return Color( - (float)this->r*f, - (float)this->g*f, - (float)this->b*f, - (float)this->a*f - ); - } - - Color operator - ( Color c ) - { - return Color( - this->r - c.r, - this->g - c.g, - this->b - c.b, - this->a - c.a - ); - } - - Color operator + ( Color c ) - { - return Color( - this->r + c.r, - this->g + c.g, - this->b + c.b, - this->a + c.a - ); - } - - bool operator ==( const Color& c ) const - { - return c.r==r && c.g==g && c.b==b && c.a==a; - } - - - unsigned char r, g, b, a; - }; - - - namespace DragAndDrop - { - struct GWEN_EXPORT Package - { - Package() - { - userdata = NULL; - draggable = false; - drawcontrol = NULL; - holdoffset = Gwen::Point( 0, 0 ); - } - - String name; - void* userdata; - bool draggable; - - Gwen::Controls::Base* drawcontrol; - Gwen::Point holdoffset; - }; - } - -} -#endif diff --git a/btgui/Gwen/TextObject.h b/btgui/Gwen/TextObject.h deleted file mode 100644 index 20f8db9c9..000000000 --- a/btgui/Gwen/TextObject.h +++ /dev/null @@ -1,65 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_TEXTOBJECT_H -#define GWEN_TEXTOBJECT_H - -#include "Gwen/Gwen.h" -#include "Gwen/Utility.h" - -namespace Gwen -{ - class TextObject - { - public: - - TextObject(){} - - TextObject( const Gwen::String& text ) - { - *this = text; - } - - TextObject( const char* text ) - { - *this = Gwen::String( text ); - } - - TextObject( const wchar_t* text ) - { - *this = Gwen::UnicodeString( text ); - } - - TextObject( const Gwen::UnicodeString& unicode ) - { - *this = unicode; - } - - void operator = ( const Gwen::String& str ) - { - m_Data = Gwen::Utility::StringToUnicode( str ); - } - - void operator = ( const Gwen::UnicodeString& unicodeStr ) - { - m_Data = unicodeStr; - } - - Gwen::String Get() const - { - return Gwen::Utility::UnicodeToString( m_Data ); - } - - const Gwen::UnicodeString& GetUnicode() const - { - return m_Data; - } - - Gwen::UnicodeString m_Data; - }; -} -#endif diff --git a/btgui/Gwen/Texture.h b/btgui/Gwen/Texture.h deleted file mode 100644 index aac95d4c3..000000000 --- a/btgui/Gwen/Texture.h +++ /dev/null @@ -1,57 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#pragma once -#ifndef GWEN_TEXTURE_H -#define GWEN_TEXTURE_H - -#include - -#include "Gwen/BaseRender.h" -#include "Gwen/TextObject.h" - -namespace Gwen -{ - // - // Texture - // - struct Texture - { - TextObject name; - void* data; - int m_intData; - - bool failed; - int width; - int height; - - Texture() - { - data = NULL; - m_intData = 0; - width = 4; - height = 4; - failed = false; - } - - ~Texture() - { - } - - void Load( const TextObject& str, Gwen::Renderer::Base* render ) - { - name = str; - render->LoadTexture( this ); - } - - void Release( Gwen::Renderer::Base* render ) - { - render->FreeTexture( this ); - } - }; - -} -#endif diff --git a/btgui/Gwen/ToolTip.cpp b/btgui/Gwen/ToolTip.cpp deleted file mode 100644 index 60e552650..000000000 --- a/btgui/Gwen/ToolTip.cpp +++ /dev/null @@ -1,61 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/ToolTip.h" -#include "Gwen/Utility.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -namespace ToolTip -{ - Base* g_ToolTip = NULL; - - void Enable( Controls::Base* pControl ) - { - if ( !pControl->GetToolTip() ) - return; - - g_ToolTip = pControl; - } - - void Disable( Controls::Base* pControl ) - { - if ( g_ToolTip == pControl ) - { - g_ToolTip = NULL; - } - } - - void RenderToolTip( Skin::Base* skin ) - { - if ( !g_ToolTip ) return; - - Gwen::Renderer::Base* render = skin->GetRender(); - - Gwen::Point pOldRenderOffset = render->GetRenderOffset(); - Gwen::Point MousePos = Input::GetMousePosition(); - Gwen::Rect Bounds = g_ToolTip->GetToolTip()->GetBounds(); - - Gwen::Rect rOffset = Gwen::Rect( MousePos.x - Bounds.w * 0.5f, MousePos.y - Bounds.h - 10, Bounds.w, Bounds.h ); - rOffset = Utility::ClampRectToRect( rOffset, g_ToolTip->GetCanvas()->GetBounds() ); - - //Calculate offset on screen bounds - render->AddRenderOffset( rOffset ); - render->EndClip(); - - skin->DrawToolTip( g_ToolTip->GetToolTip() ); - g_ToolTip->GetToolTip()->DoRender( skin ); - - render->SetRenderOffset( pOldRenderOffset ); - } - - void ControlDeleted( Controls::Base* pControl ) - { - Disable( pControl ); - } -} diff --git a/btgui/Gwen/ToolTip.h b/btgui/Gwen/ToolTip.h deleted file mode 100644 index c263887a8..000000000 --- a/btgui/Gwen/ToolTip.h +++ /dev/null @@ -1,29 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#pragma once -#ifndef GWEN_TOOLTIP_H -#define GWEN_TOOLTIP_H - -#include "Gwen/Controls/Base.h" -#include "Gwen/Gwen.h" -#include "Gwen/Skin.h" - -using namespace Gwen; -using namespace Gwen::Controls; - -namespace ToolTip -{ - GWEN_EXPORT void Enable ( Controls::Base* pControl ); - GWEN_EXPORT void Disable ( Controls::Base* pControl ); - - GWEN_EXPORT void ControlDeleted ( Controls::Base* pControl ); - - GWEN_EXPORT void RenderToolTip ( Skin::Base* skin ); -} - -#endif diff --git a/btgui/Gwen/UnitTest/UnitTest.h b/btgui/Gwen/UnitTest/UnitTest.h deleted file mode 100644 index 7d8f76f7f..000000000 --- a/btgui/Gwen/UnitTest/UnitTest.h +++ /dev/null @@ -1,64 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - - -#pragma once -#ifndef GWEN_UNITTEST_UNITTEST_H -#define GWEN_UNITTEST_UNITTEST_H - -#include "Gwen/Gwen.h" -#include "Gwen/Align.h" -#include "Gwen/Utility.h" -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/ListBox.h" - -class UnitTest; - - - -class GUnit : public Gwen::Controls::Base -{ - public: - - GWEN_CONTROL_INLINE( GUnit, Gwen::Controls::Base ) - { - m_pUnitTest = NULL; - } - - void SetUnitTest( UnitTest* u ){ m_pUnitTest = u; } - - void UnitPrint( const Gwen::UnicodeString& str ); - void UnitPrint( const Gwen::String& str ); - - - - - UnitTest* m_pUnitTest; -}; - -class UnitTest : public Gwen::Controls::WindowControl -{ - public: - - GWEN_CONTROL( UnitTest, Gwen::Controls::WindowControl ); - - void PrintText( const Gwen::UnicodeString& str ); - - void Render( Gwen::Skin::Base* skin ); - - - private: - - Gwen::Controls::TabControl* m_TabControl; - Gwen::Controls::ListBox* m_TextOutput; - unsigned int m_iFrames; - float m_fLastSecond; - -}; - -#define DEFINE_UNIT_TEST( name, displayname ) GUnit* RegisterUnitTest_##name( Gwen::Controls::TabControl* tab ){ GUnit* u = new name( tab ); tab->AddPage( displayname, u ); return u; } -#endif diff --git a/btgui/Gwen/Utility.cpp b/btgui/Gwen/Utility.cpp deleted file mode 100644 index 2da302d1b..000000000 --- a/btgui/Gwen/Utility.cpp +++ /dev/null @@ -1,111 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/ToolTip.h" -#include "Gwen/Utility.h" - -using namespace Gwen; - -#ifdef _MSC_VER - #pragma warning(disable:4267)// conversion from 'size_t' to 'int', possible loss of data -#endif - -UnicodeString Gwen::Utility::Format( const wchar_t* fmt, ... ) -{ - wchar_t strOut[ 4096 ]; - - va_list s; - va_start( s, fmt ); - GwenUtil_VSWPrintFSafeSized( strOut, fmt, s ); - va_end(s); - - UnicodeString str = strOut; - return str; -} - - - -void Gwen::Utility::Strings::Split( const Gwen::String& str, const Gwen::String& seperator, Strings::List& outbits, bool bLeave ) -{ - int iOffset = 0; - int iLength = str.length(); - int iSepLen = seperator.length(); - - size_t i = str.find( seperator, 0 ); - while ( i != std::string::npos ) - { - outbits.push_back( str.substr( iOffset, i-iOffset ) ); - iOffset = i + iSepLen; - - i = str.find( seperator, iOffset ); - if ( bLeave ) iOffset -= iSepLen; - } - - outbits.push_back( str.substr( iOffset, iLength-iOffset ) ); -} - -void Gwen::Utility::Strings::Split( const Gwen::UnicodeString& str, const Gwen::UnicodeString& seperator, Strings::UnicodeList& outbits, bool bLeave ) -{ - int iOffset = 0; - int iLength = str.length(); - int iSepLen = seperator.length(); - - size_t i = str.find( seperator, 0 ); - while ( i != std::wstring::npos ) - { - outbits.push_back( str.substr( iOffset, i-iOffset ) ); - iOffset = i + iSepLen; - - i = str.find( seperator, iOffset ); - if ( bLeave ) iOffset -= iSepLen; - } - - outbits.push_back( str.substr( iOffset, iLength-iOffset ) ); -} - -int Gwen::Utility::Strings::To::Int( const Gwen::String& str ) -{ - if ( str == "" ) return 0; - return atoi( str.c_str() ); -} - -float Gwen::Utility::Strings::To::Float( const Gwen::String& str ) -{ - if ( str == "" ) return 0.0f; - return (float)atof( str.c_str() ); -} - -bool Gwen::Utility::Strings::To::Bool( const Gwen::String& str ) -{ - if ( str.size() == 0 ) return false; - if ( str[0] == 'T' || str[0] == 't' || str[0] == 'y' || str[0] == 'Y' ) return true; - if ( str[0] == 'F' || str[0] == 'f' || str[0] == 'n' || str[0] == 'N' ) return false; - if ( str[0] == '0' ) return false; - return true; -} - -bool Gwen::Utility::Strings::To::Floats( const Gwen::String& str, float* f, size_t iCount ) -{ - Strings::List lst; - Strings::Split( str, " ", lst ); - if ( lst.size() != iCount ) return false; - - for ( size_t i=0; i -#include -#include "Gwen/Structures.h" - -namespace Gwen -{ - namespace Utility - { - template - const T& Max( const T& x, const T& y ) - { - if ( y < x ) return x; - return y; - } - - template - const T& Min( const T& x, const T& y ) - { - if ( y > x ) return x; - return y; - } - -#ifdef _MSC_VER - #pragma warning( push ) - #pragma warning( disable : 4996 ) -#endif - - inline String UnicodeToString( const UnicodeString& strIn ) - { - if ( !strIn.length() ) return ""; - - String temp(strIn.length(), (char)0); - - std::use_facet< std::ctype >(std::locale()). \ - narrow(&strIn[0], &strIn[0]+strIn.length(), ' ', &temp[0]); - - return temp; - } - - inline UnicodeString StringToUnicode( const String& strIn ) - { - if ( !strIn.length() ) return L""; - - UnicodeString temp(strIn.length(), (wchar_t)0); - - std::use_facet< std::ctype >(std::locale()). \ - widen(&strIn[0], &strIn[0]+strIn.length(), &temp[0]); - - return temp; - } - -#ifdef _MSC_VER - #pragma warning( pop ) -#endif - - template - String ToString( const T& object ) - { - std::ostringstream os; - os << object; - return os.str(); - } - - inline Gwen::Rect ClampRectToRect( Gwen::Rect inside, Gwen::Rect outside, bool clampSize = false ) - { - if ( inside.x < outside.x ) - inside.x = outside.x; - - if ( inside.y < outside.y ) - inside.y = outside.y; - - if ( inside.x + inside.w > outside.x + outside.w ) - { - if ( clampSize ) - inside.w = outside.w; - else - inside.x = outside.x + outside.w - inside.w; - } - if ( inside.y + inside.h > outside.y + outside.h ) - { - if ( clampSize ) - inside.h = outside.h; - else - inside.y = outside.w + outside.h - inside.h; - } - - return inside; - } - - GWEN_EXPORT UnicodeString Format( const wchar_t* fmt, ... ); - - namespace Strings - { - typedef std::vector List; - typedef std::vector UnicodeList; - - GWEN_EXPORT void Split( const Gwen::String& str, const Gwen::String& seperator, Strings::List& outbits, bool bLeaveSeperators = false ); - GWEN_EXPORT void Split( const Gwen::UnicodeString& str, const Gwen::UnicodeString& seperator, Strings::UnicodeList& outbits, bool bLeaveSeperators = false ); - - template - T TrimLeft( const T& str, const T& strChars ) - { - T outstr = str; - outstr.erase( 0, outstr.find_first_not_of( strChars ) ); - return outstr; - } - - namespace To - { - GWEN_EXPORT bool Bool( const Gwen::String& str ); - GWEN_EXPORT int Int( const Gwen::String& str ); - GWEN_EXPORT float Float( const Gwen::String& str ); - GWEN_EXPORT bool Floats( const Gwen::String& str, float* f, size_t iCount ); - } - } - } - - - -} -#endif diff --git a/btgui/Gwen/events.cpp b/btgui/Gwen/events.cpp deleted file mode 100644 index ae6c65105..000000000 --- a/btgui/Gwen/events.cpp +++ /dev/null @@ -1,111 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/Events.h" - -using namespace Gwen; -using namespace Gwen::Event; - - -Handler::Handler() -{ - -} - -Handler::~Handler() -{ - CleanLinks(); -} - -void Handler::CleanLinks() -{ - // Tell all the callers that we're dead - std::list::iterator iter = m_Callers.begin(); - while ( iter != m_Callers.end() ) - { - Caller* pCaller = *iter; - UnRegisterCaller( pCaller ); - pCaller->RemoveHandler( this ); - iter = m_Callers.begin(); - } -} - -void Handler::RegisterCaller( Caller* pCaller ) -{ - m_Callers.push_back( pCaller ); -} - -void Handler::UnRegisterCaller( Caller* pCaller ) -{ - m_Callers.remove( pCaller ); -} - - -Caller::Caller() -{ - -} - -Caller::~Caller() -{ - CleanLinks(); -} - -void Caller::CleanLinks() -{ - std::list::iterator iter; - for (iter = m_Handlers.begin(); iter != m_Handlers.end(); ++iter) - { - handler& h = *iter; - h.pObject->UnRegisterCaller( this ); - } - - m_Handlers.clear(); -} - -void Caller::Call( Controls::Base* pThis ) -{ - std::list::iterator iter; - for (iter = m_Handlers.begin(); iter != m_Handlers.end(); ++iter) - { - handler& h = *iter; - (h.pObject->*h.fnFunction)( pThis ); - } -} - -void Caller::AddInternal( Event::Handler* pObject, Event::Handler::Function pFunction ) -{ - handler h; - h.fnFunction = pFunction; - h.pObject = pObject; - - m_Handlers.push_back( h ); - - pObject->RegisterCaller( this ); -} - -void Caller::RemoveHandler( Event::Handler* pObject ) -{ - pObject->UnRegisterCaller( this ); - - std::list::iterator iter = m_Handlers.begin(); - - while ( iter != m_Handlers.end() ) - { - handler& h = *iter; - - if ( h.pObject == pObject ) - { - iter = m_Handlers.erase( iter ); - } - else - { - ++iter; - } - } - -} \ No newline at end of file diff --git a/btgui/Gwen/inputhandler.cpp b/btgui/Gwen/inputhandler.cpp deleted file mode 100644 index 43b09d415..000000000 --- a/btgui/Gwen/inputhandler.cpp +++ /dev/null @@ -1,362 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - - -#include "Gwen/InputHandler.h" -#include "Gwen/Controls/Base.h" -#include "Gwen/DragAndDrop.h" -#include "Gwen/Hook.h" -#include "Gwen/Platform.h" - -#define DOUBLE_CLICK_SPEED 0.5f -#define MAX_MOUSE_BUTTONS 5 - -using namespace Gwen; - - -struct Action -{ - unsigned char type; - - int x, y; - Gwen::UnicodeChar chr; -}; - -static const float KeyRepeatRate = 0.03f; -static const float KeyRepeatDelay = 0.3f; - -struct t_KeyData -{ - t_KeyData() - { - for ( int i=0; iGetControlAt( MousePosition.x, MousePosition.y ); - - if ( Gwen::HoveredControl && pHovered != Gwen::HoveredControl ) - { - Gwen::HoveredControl->OnMouseLeave(); - - pInCanvas->Redraw(); - } - - if ( pHovered != Gwen::HoveredControl ) - { - Gwen::HoveredControl = pHovered; - - if ( Gwen::HoveredControl ) - Gwen::HoveredControl->OnMouseEnter(); - - pInCanvas->Redraw(); - } - - if ( Gwen::MouseFocus && Gwen::MouseFocus->GetCanvas() == pInCanvas ) - { - Gwen::HoveredControl = Gwen::MouseFocus; - } - -} - -void FindKeyboardFocus( Controls::Base* pControl ) -{ - if ( !pControl ) return; - if ( pControl->GetKeyboardInputEnabled() ) - { - //Make sure none of our children have keyboard focus first - todo recursive - for (Controls::Base::List::iterator iter = pControl->Children.begin(); iter != pControl->Children.end(); ++iter) - { - Controls::Base* pChild = *iter; - if ( pChild == Gwen::KeyboardFocus ) - return; - } - - pControl->Focus(); - return; - } - - return FindKeyboardFocus( pControl->GetParent() ); -} - -Gwen::Point Gwen::Input::GetMousePosition() -{ - return MousePosition; -} - -void Gwen::Input::OnCanvasThink( Controls::Base* pControl ) -{ - if ( Gwen::MouseFocus && !Gwen::MouseFocus->Visible() ) - Gwen::MouseFocus = NULL; - - if (Gwen::KeyboardFocus ) - { - bool isVisible = Gwen::KeyboardFocus->Visible(); - bool isEnabled = KeyboardFocus->GetKeyboardInputEnabled(); - - if ( !isVisible || !isEnabled ) - Gwen::KeyboardFocus = NULL; - } - - if ( !KeyboardFocus ) return; - if ( KeyboardFocus->GetCanvas() != pControl ) return; - - float fTime = Gwen::Platform::GetTimeInSeconds(); - - // - // Simulate Key-Repeats - // - for ( int i=0; i KeyData.NextRepeat[i] ) - { - KeyData.NextRepeat[i] = Gwen::Platform::GetTimeInSeconds() + KeyRepeatRate; - - if ( KeyboardFocus ) - { - KeyboardFocus->OnKeyPress( i ); - } - } - } -} - -bool Gwen::Input::IsKeyDown( int iKey ) -{ - return KeyData.KeyState[ iKey ]; -} - -bool Gwen::Input::IsLeftMouseDown() -{ - return KeyData.LeftMouseDown; -} - -bool Gwen::Input::IsRightMouseDown() -{ - return KeyData.RightMouseDown; -} - -void Gwen::Input::OnMouseMoved( Controls::Base* pCanvas, int x, int y, int /*deltaX*/, int /*deltaY*/ ) -{ - MousePosition.x = x; - MousePosition.y = y; - - UpdateHoveredControl( pCanvas ); -} - -bool Gwen::Input::OnMouseClicked( Controls::Base* pCanvas, int iMouseButton, bool bDown ) -{ - // If we click on a control that isn't a menu we want to close - // all the open menus. Menus are children of the canvas. - if ( bDown && (!Gwen::HoveredControl || !Gwen::HoveredControl->IsMenuComponent()) ) - { - pCanvas->CloseMenus(); - } - - if ( !Gwen::HoveredControl ) return false; - if ( Gwen::HoveredControl->GetCanvas() != pCanvas ) return false; - if ( !Gwen::HoveredControl->Visible() ) return false; - if ( Gwen::HoveredControl == pCanvas ) return false; - - if ( iMouseButton > MAX_MOUSE_BUTTONS ) - return false; - - if ( iMouseButton == 0 ) KeyData.LeftMouseDown = bDown; - else if ( iMouseButton == 1 ) KeyData.RightMouseDown = bDown; - - // Double click. - // Todo: Shouldn't double click if mouse has moved significantly - bool bIsDoubleClick = false; - - if ( bDown && - g_pntLastClickPos.x == MousePosition.x && - g_pntLastClickPos.y == MousePosition.y && - ( Gwen::Platform::GetTimeInSeconds() - g_fLastClickTime[ iMouseButton ] ) < DOUBLE_CLICK_SPEED ) - { - bIsDoubleClick = true; - } - - if ( bDown && !bIsDoubleClick ) - { - g_fLastClickTime[ iMouseButton ] = Gwen::Platform::GetTimeInSeconds(); - g_pntLastClickPos = MousePosition; - } - - if ( bDown ) - { - FindKeyboardFocus( Gwen::HoveredControl ); - } - - Gwen::HoveredControl->UpdateCursor(); - - // This tells the child it has been touched, which - // in turn tells its parents, who tell their parents. - // This is basically so that Windows can pop themselves - // to the top when one of their children have been clicked. - if ( bDown ) - Gwen::HoveredControl->Touch(); - -#ifdef GWEN_HOOKSYSTEM - if ( bDown ) - { - if ( Hook::CallHook( &Hook::BaseHook::OnControlClicked, Gwen::HoveredControl, MousePosition.x, MousePosition.y ) ) - return true; - } -#endif - - switch ( iMouseButton ) - { - case 0: - { - if ( DragAndDrop::OnMouseButton( Gwen::HoveredControl, MousePosition.x, MousePosition.y, bDown ) ) - return true; - - if ( bIsDoubleClick ) Gwen::HoveredControl->OnMouseDoubleClickLeft( MousePosition.x, MousePosition.y ); - else Gwen::HoveredControl->OnMouseClickLeft( MousePosition.x, MousePosition.y, bDown ); - return true; - } - - case 1: - { - if ( bIsDoubleClick ) Gwen::HoveredControl->OnMouseDoubleClickRight( MousePosition.x, MousePosition.y ); - else Gwen::HoveredControl->OnMouseClickRight( MousePosition.x, MousePosition.y, bDown ); - return true; - } - } - - return false; -} - -bool Gwen::Input::HandleAccelerator( Controls::Base* pCanvas, Gwen::UnicodeChar chr ) -{ - //Build the accelerator search string - Gwen::UnicodeString accelString; - if ( Gwen::Input::IsControlDown() ) - accelString += L"Ctrl + "; - if ( Gwen::Input::IsShiftDown() ) - accelString += L"Shift + "; - - accelString += chr; - - //Debug::Msg("Accelerator string :%S\n", accelString.c_str()); - - if ( Gwen::KeyboardFocus && Gwen::KeyboardFocus->HandleAccelerator( accelString ) ) - return true; - - if ( Gwen::MouseFocus && Gwen::MouseFocus->HandleAccelerator( accelString ) ) - return true; - - if ( pCanvas->HandleAccelerator( accelString ) ) - return true; - - return false; -} - -bool Gwen::Input::DoSpecialKeys( Controls::Base* pCanvas, Gwen::UnicodeChar chr ) -{ - if ( !Gwen::KeyboardFocus ) return false; - if ( Gwen::KeyboardFocus->GetCanvas() != pCanvas ) return false; - if ( !Gwen::KeyboardFocus->Visible() ) return false; - if ( !Gwen::Input::IsControlDown() ) return false; - - if ( chr == L'C' || chr == L'c' ) - { - Gwen::KeyboardFocus->OnCopy(NULL); - return true; - } - - if ( chr == L'V' || chr == L'v' ) - { - Gwen::KeyboardFocus->OnPaste(NULL); - return true; - } - - if ( chr == L'X' || chr == L'x' ) - { - Gwen::KeyboardFocus->OnCut(NULL); - return true; - } - - if ( chr == L'A' || chr == L'a' ) - { - Gwen::KeyboardFocus->OnSelectAll(NULL); - return true; - } - - return false; -} - -bool Gwen::Input::OnKeyEvent( Controls::Base* pCanvas, int iKey, bool bDown ) -{ - if ( !Gwen::KeyboardFocus ) return false; - if ( Gwen::KeyboardFocus->GetCanvas() != pCanvas ) return false; - if ( !Gwen::KeyboardFocus->Visible() ) return false; - - if ( bDown ) - { - if ( !KeyData.KeyState[ iKey ] ) - { - KeyData.KeyState[ iKey ] = true; - KeyData.NextRepeat[ iKey ] = Gwen::Platform::GetTimeInSeconds() + KeyRepeatDelay; - KeyData.Target = KeyboardFocus; - - return KeyboardFocus->OnKeyPress( iKey ); - } - } - else - { - if ( KeyData.KeyState[ iKey ] ) - { - KeyData.KeyState[ iKey ] = false; - - // BUG BUG. This causes shift left arrow in textboxes - // to not work. What is disabling it here breaking? - //KeyData.Target = NULL; - - return KeyboardFocus->OnKeyRelease( iKey ); - } - } - - return false; -} \ No newline at end of file diff --git a/btgui/Gwen/premake4.lua b/btgui/Gwen/premake4.lua deleted file mode 100644 index 74d16aac9..000000000 --- a/btgui/Gwen/premake4.lua +++ /dev/null @@ -1,31 +0,0 @@ - project "gwen" - - kind "StaticLib" - - --flags {"Unicode"} -initOpenGL() -initGlew() -if os.is("Linux") then - initX11() -end - - defines { "GWEN_COMPILE_STATIC" } - defines { "DONT_USE_GLUT"} - includedirs { - ".",".." - } - files { - "*.cpp", - "*.h", - "Controls/*.cpp", - "Controls/*.h", - "Controls/Dialog/*.cpp", - "Controls/Dialogs/*.h", - "Controls/Layout/*.h", - "Controls/Property/*.h", - "Input/*.h", - "Platforms/*.cpp", - "Renderers/*.cpp", - "Skins/*.cpp", - "Skins/*.h" - } diff --git a/btgui/GwenOpenGLTest/Button.cpp b/btgui/GwenOpenGLTest/Button.cpp deleted file mode 100644 index 727670ed2..000000000 --- a/btgui/GwenOpenGLTest/Button.cpp +++ /dev/null @@ -1,75 +0,0 @@ -#include "UnitTest.h" - -using namespace Gwen; - -class Button : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( Button, GUnit ) - { - // Normal button - Controls::Button* pButtonA = new Controls::Button( this ); - pButtonA->SetText( L"Event Tester" ); - pButtonA->onPress.Add( this, &Button::onButtonA ); - - { - Controls::Button* pButtonA = new Controls::Button( this ); - pButtonA->SetBounds( 200, 30, 300, 200 ); - pButtonA->SetText( L"Event Tester" ); - pButtonA->onPress.Add( this, &Button::onButtonA ); - } - - // Unicode test - Controls::Button* pButtonB = new Controls::Button( this ); - pButtonB->SetText( L"\u0417\u0430\u043C\u0435\u0436\u043D\u0430\u044F \u043C\u043E\u0432\u0430" ); - Gwen::Align::PlaceBelow( pButtonB, pButtonA, 10 ); - - // Image with text - Controls::Button* pButtonC = new Controls::Button( this ); - pButtonC->SetText( L"Image Button" ); - pButtonC->SetImage( L"test16.png" ); - Gwen::Align::PlaceBelow( pButtonC, pButtonB, 10 ); - - // Just image - Controls::Button* pButtonD = new Controls::Button( this ); - pButtonD->SetText( L"" ); - pButtonD->SetImage( L"test16.png" ); - pButtonD->SetSize( 20, 20 ); - Gwen::Align::PlaceBelow( pButtonD, pButtonC, 10 ); - - // Toggle button - Controls::Button* pButtonE = new Controls::Button( this ); - pButtonE->SetText( L"Toggle Me" ); - pButtonE->SetIsToggle( true ); - pButtonE->onToggle.Add( this, &Button::OnToggle ); - pButtonE->onToggleOn.Add( this, &Button::OnToggleOn ); - pButtonE->onToggleOff.Add( this, &Button::OnToggleOff ); - Gwen::Align::PlaceBelow( pButtonE, pButtonD, 10 ); - } - - void onButtonA( Controls::Base* pControl ) - { - UnitPrint( L"Button Pressed (using 'OnPress' event)" ); - } - - void OnToggle( Controls::Base* pControl ) - { - UnitPrint( L"Button Toggled (using 'OnToggle' event)" ); - } - - void OnToggleOn( Controls::Base* pControl ) - { - UnitPrint( L"Button Toggled ON (using 'OnToggleOn' event)" ); - } - - void OnToggleOff( Controls::Base* pControl ) - { - UnitPrint( L"Button Toggled Off (using 'OnToggleOff' event)" ); - } - -}; - - - -DEFINE_UNIT_TEST( Button, L"Button" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/Checkbox.cpp b/btgui/GwenOpenGLTest/Checkbox.cpp deleted file mode 100644 index b46a84b37..000000000 --- a/btgui/GwenOpenGLTest/Checkbox.cpp +++ /dev/null @@ -1,48 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/CheckBox.h" - -using namespace Gwen; - -class Checkbox : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( Checkbox, GUnit ) - { - Gwen::Controls::CheckBox* check = new Gwen::Controls::CheckBox( this ); - check->SetPos( 10, 10 ); - check->onChecked.Add( this, &Checkbox::OnChecked ); - check->onUnChecked.Add( this, &Checkbox::OnUnchecked ); - check->onCheckChanged.Add( this, &Checkbox::OnCheckChanged ); - - - Gwen::Controls::CheckBoxWithLabel* labeled = new Gwen::Controls::CheckBoxWithLabel( this ); - labeled->SetPos( 10, 10 ); - labeled->Label()->SetText( "Labeled CheckBox" ); - labeled->Checkbox()->onChecked.Add( this, &Checkbox::OnChecked ); - labeled->Checkbox()->onUnChecked.Add( this, &Checkbox::OnUnchecked ); - labeled->Checkbox()->onCheckChanged.Add( this, &Checkbox::OnCheckChanged ); - Gwen::Align::PlaceBelow( labeled, check, 10 ); - - } - - void OnChecked( Controls::Base* pControl ) - { - UnitPrint( L"Checkbox Checked (using 'OnChecked' event)" ); - } - - void OnUnchecked( Controls::Base* pControl ) - { - UnitPrint( L"Checkbox Unchecked (using 'OnUnchecked' event)" ); - } - - void OnCheckChanged( Controls::Base* pControl ) - { - UnitPrint( L"Checkbox CheckChanged (using 'OnCheckChanged' event)" ); - } - -}; - - - -DEFINE_UNIT_TEST( Checkbox, L"Checkbox" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/ComboBox.cpp b/btgui/GwenOpenGLTest/ComboBox.cpp deleted file mode 100644 index 3ae13cb09..000000000 --- a/btgui/GwenOpenGLTest/ComboBox.cpp +++ /dev/null @@ -1,58 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/ComboBox.h" - -using namespace Gwen; - -class ComboBox : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( ComboBox, GUnit ) - { - - { - Gwen::Controls::ComboBox* combo = new Gwen::Controls::ComboBox( this ); - combo->SetKeyboardInputEnabled(true); - combo->SetPos( 50, 50 ); - combo->SetWidth( 200 ); - - - combo->AddItem( L"Option One", "one" ); - combo->AddItem( L"Number Two", "two" ); - combo->AddItem( L"Door Three", "three" ); - combo->AddItem( L"Four Legs", "four" ); - combo->AddItem( L"Five Birds", "five" ); - - combo->onSelection.Add( this, &ComboBox::OnComboSelect ); - } - - { - // Empty.. - Gwen::Controls::ComboBox* combo = new Gwen::Controls::ComboBox( this ); - combo->SetPos( 50, 80 ); - combo->SetWidth( 200 ); - } - - { - // Empty.. - Gwen::Controls::ComboBox* combo = new Gwen::Controls::ComboBox( this ); - combo->SetPos( 50, 110 ); - combo->SetWidth( 200 ); - - for (int i=0; i<500; i++ ) - combo->AddItem( L"Lots Of Options" ); - } - - } - - void OnComboSelect( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::ComboBox* combo = (Gwen::Controls::ComboBox*)pControl; - - UnitPrint( Utility::Format( L"Combo Changed: %s", combo->GetSelectedItem()->GetText().c_str() ) ); - } -}; - - - -DEFINE_UNIT_TEST( ComboBox, L"ComboBox" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/CrossSplitter.cpp b/btgui/GwenOpenGLTest/CrossSplitter.cpp deleted file mode 100644 index dea72d466..000000000 --- a/btgui/GwenOpenGLTest/CrossSplitter.cpp +++ /dev/null @@ -1,115 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/CrossSplitter.h" -#include "Gwen/Controls/StatusBar.h" -#include "Gwen/Controls/Button.h" - -using namespace Gwen; - -class CrossSplitter : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( CrossSplitter, GUnit ) - { - - m_bSplittersVisible = false; - m_iCurZoom = 0; - - m_Splitter = new Gwen::Controls::CrossSplitter( this ); - m_Splitter->SetPos(0, 0); - m_Splitter->Dock( Pos::Fill ); - - { - Gwen::Controls::Button* testButton = new Gwen::Controls::Button( m_Splitter ); - testButton->SetText( "TOPLEFT"); - m_Splitter->SetPanel( 0, testButton ); - } - - { - Gwen::Controls::Button* testButton = new Gwen::Controls::Button( m_Splitter ); - testButton->SetText( "TOPRIGHT"); - m_Splitter->SetPanel( 1, testButton ); - } - - { - Gwen::Controls::Button* testButton = new Gwen::Controls::Button( m_Splitter ); - testButton->SetText( "BOTTOMRIGHT"); - m_Splitter->SetPanel( 2, testButton ); - } - - { - Gwen::Controls::Button* testButton = new Gwen::Controls::Button( m_Splitter ); - testButton->SetText( "BOTTOMLEFT"); - m_Splitter->SetPanel( 3, testButton ); - } - - - //Status bar to hold unit testing buttons - Gwen::Controls::StatusBar* pStatus = new Gwen::Controls::StatusBar( this ); - pStatus->Dock( Pos::Bottom ); - - - { - Gwen::Controls::Button* pButton = new Gwen::Controls::Button( pStatus ); - pButton->SetText( "Zoom" ); - pButton->onPress.Add( this, &CrossSplitter::ZoomTest ); - pStatus->AddControl( pButton, false ); - } - - { - Gwen::Controls::Button* pButton = new Gwen::Controls::Button( pStatus ); - pButton->SetText( "UnZoom" ); - pButton->onPress.Add( this, &CrossSplitter::UnZoomTest ); - pStatus->AddControl( pButton, false ); - } - - { - Gwen::Controls::Button* pButton = new Gwen::Controls::Button( pStatus ); - pButton->SetText( "CenterPanels" ); - pButton->onPress.Add( this, &CrossSplitter::CenterPanels ); - pStatus->AddControl( pButton, true ); - } - - { - Gwen::Controls::Button* pButton = new Gwen::Controls::Button( pStatus ); - pButton->SetText( "Splitters" ); - pButton->onPress.Add( this, &CrossSplitter::ToggleSplitters ); - pStatus->AddControl( pButton, true ); - } - } - - void ZoomTest( Gwen::Controls::Base* pFromPanel ) - { - m_Splitter->Zoom(m_iCurZoom); - m_iCurZoom++; - if (m_iCurZoom == 4) - m_iCurZoom = 0; - } - - void UnZoomTest( Gwen::Controls::Base* pFromPanel ) - { - m_Splitter->UnZoom(); - } - - void CenterPanels( Gwen::Controls::Base* pFromPanel ) - { - m_Splitter->CenterPanels(); - m_Splitter->UnZoom(); - } - - void ToggleSplitters( Gwen::Controls::Base* pFromPanel ) - { - m_Splitter->SetSplittersVisible( !m_bSplittersVisible ); - m_bSplittersVisible = !m_bSplittersVisible; - } - - - bool m_bSplittersVisible; - int m_iCurZoom; - Controls::CrossSplitter* m_Splitter; - -}; - - - -DEFINE_UNIT_TEST( CrossSplitter, L"CrossSplitter" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/GroupBox.cpp b/btgui/GwenOpenGLTest/GroupBox.cpp deleted file mode 100644 index f0a490162..000000000 --- a/btgui/GwenOpenGLTest/GroupBox.cpp +++ /dev/null @@ -1,21 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/GroupBox.h" - -using namespace Gwen; - -class GroupBox2 : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( GroupBox2, GUnit ) - { - Gwen::Controls::GroupBox* pGroup = new Gwen::Controls::GroupBox( this ); - pGroup->Dock( Pos::Fill ); - pGroup->SetText( "Group Box" ); - } -}; - - - - -DEFINE_UNIT_TEST( GroupBox2, L"GroupBox" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/ImagePanel.cpp b/btgui/GwenOpenGLTest/ImagePanel.cpp deleted file mode 100644 index 015cfb307..000000000 --- a/btgui/GwenOpenGLTest/ImagePanel.cpp +++ /dev/null @@ -1,32 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/ImagePanel.h" - -using namespace Gwen; - -class ImagePanel : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( ImagePanel, GUnit ) - { - // Normal - { - Controls::ImagePanel* img = new Controls::ImagePanel( this ); - img->SetImage( L"gwen.png" ); - img->SetBounds( 10, 10, 100, 100 ); - } - - // Missing - { - Controls::ImagePanel* img = new Controls::ImagePanel( this ); - img->SetImage( L"missingimage.png" ); - img->SetBounds( 120, 10, 100, 100 ); - } - - } - -}; - - - -DEFINE_UNIT_TEST( ImagePanel, L"ImagePanel" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/Label.cpp b/btgui/GwenOpenGLTest/Label.cpp deleted file mode 100644 index a2301f1f2..000000000 --- a/btgui/GwenOpenGLTest/Label.cpp +++ /dev/null @@ -1,99 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/Label.h" - -using namespace Gwen; - -class Label : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( Label, GUnit ) - { - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( "Garry's Normal Label" ); - label->SizeToContents(); - label->SetPos( 10, 10 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Chinese: \u4E45\u6709\u5F52\u5929\u613F \u7EC8\u8FC7\u9B3C\u95E8\u5173" ); - label->SizeToContents(); - label->SetPos( 10, 30 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Japanese: \u751F\u3080\u304E\u3000\u751F\u3054\u3081\u3000\u751F\u305F\u307E\u3054" ); - label->SizeToContents(); - label->SetPos( 10, 50 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Korean: \uADF9\uC9C0\uD0D0\uD5D8\u3000\uD611\uD68C\uACB0\uC131\u3000\uCCB4\uACC4\uC801\u3000\uC5F0\uAD6C" ); - label->SizeToContents(); - label->SetPos( 10, 70 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Hindi: \u092F\u0947 \u0905\u0928\u0941\u091A\u094D\u091B\u0947\u0926 \u0939\u093F\u0928\u094D\u0926\u0940 \u092E\u0947\u0902 \u0939\u0948\u0964" ); - label->SizeToContents(); - label->SetPos( 10, 90 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Arabic: \u0627\u0644\u0622\u0646 \u0644\u062D\u0636\u0648\u0631 \u0627\u0644\u0645\u0624\u062A\u0645\u0631 \u0627\u0644\u062F\u0648\u0644\u064A" ); - label->SizeToContents(); - label->SetPos( 10, 110 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Wow, Coloured Text" ); - label->SetTextColor( Gwen::Color( 0, 0, 255, 255 ) ); - label->SizeToContents(); - label->SetPos( 10, 130 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Coloured Text With Alpha" ); - label->SetTextColor( Gwen::Color( 0, 0, 255, 100 ) ); - label->SizeToContents(); - label->SetPos( 10, 150 ); - } - - { - // - // Note that when using a custom font, this font object has to stick around - // for the lifetime of the label. Rethink, or is that ideal? - // - m_Font.facename = L"Comic Sans MS"; - m_Font.size = 25; - - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Custom Font (Comic Sans 25)" ); - label->SetFont( &m_Font ); - label->SizeToContents(); - label->SetPos( 10, 170 ); - } - - { - Gwen::Controls::Label* label = new Gwen::Controls::Label( this ); - label->SetText( L"Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.\n\nLorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua." ); - label->SizeToContents(); - label->SetBounds( 300, 10, 150, 500 ); - } - - } - - Gwen::Font m_Font; -}; - - - -DEFINE_UNIT_TEST( Label, L"Label" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/ListBox.cpp b/btgui/GwenOpenGLTest/ListBox.cpp deleted file mode 100644 index 7072f89b2..000000000 --- a/btgui/GwenOpenGLTest/ListBox.cpp +++ /dev/null @@ -1,71 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/ListBox.h" - -using namespace Gwen; - -class ListBox : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( ListBox, GUnit ) - { - { - Gwen::Controls::ListBox* ctrl = new Gwen::Controls::ListBox( this ); - ctrl->SetBounds( 10, 10, 100, 200 ); - - ctrl->AddItem( L"First" ); - ctrl->AddItem( L"Blue" ); - ctrl->AddItem( L"Yellow" ); - ctrl->AddItem( L"Orange" ); - ctrl->AddItem( L"Brown" ); - ctrl->AddItem( L"Green" ); - ctrl->AddItem( L"Dog" ); - ctrl->AddItem( L"Cat" ); - ctrl->AddItem( L"Shoes" ); - ctrl->AddItem( L"Chair" ); - ctrl->AddItem( L"Last" ); - - ctrl->onRowSelected.Add( this, &ThisClass::RowSelected ); - } - - { - Gwen::Controls::ListBox* ctrl = new Gwen::Controls::ListBox( this ); - ctrl->SetBounds( 120, 10, 200, 200 ); - ctrl->SetColumnCount( 3 ); - ctrl->SetAllowMultiSelect( true ); - ctrl->onRowSelected.Add( this, &ThisClass::RowSelected ); - - - { - Gwen::Controls::Layout::TableRow* pRow = ctrl->AddItem( L"Baked Beans" ); - pRow->SetCellText( 1, L"Heinz" ); - pRow->SetCellText( 2, L"£3.50" ); - } - - { - Gwen::Controls::Layout::TableRow* pRow = ctrl->AddItem( L"Bananas" ); - pRow->SetCellText( 1, L"Trees" ); - pRow->SetCellText( 2, L"£1.27" ); - } - - { - Gwen::Controls::Layout::TableRow* pRow = ctrl->AddItem( L"Chicken" ); - pRow->SetCellText( 1, L"\u5355\u5143\u6D4B\u8BD5" ); - pRow->SetCellText( 2, L"£8.95" ); - } - } - } - - void RowSelected( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::ListBox* ctrl = (Gwen::Controls::ListBox*)pControl; - - UnitPrint( Utility::Format( L"Listbox Item Selected: %s", ctrl->GetSelectedRow()->GetText( 0 ).c_str() ) ); - } - - Gwen::Font m_Font; -}; - - - -DEFINE_UNIT_TEST( ListBox, L"ListBox" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/MenuStrip.cpp b/btgui/GwenOpenGLTest/MenuStrip.cpp deleted file mode 100644 index 14a8a1457..000000000 --- a/btgui/GwenOpenGLTest/MenuStrip.cpp +++ /dev/null @@ -1,105 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/MenuStrip.h" - -using namespace Gwen; - -class MenuStrip : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( MenuStrip, GUnit ) - { - Gwen::Controls::MenuStrip* menu = new Gwen::Controls::MenuStrip( this ); - - { - Gwen::Controls::MenuItem* pRoot = menu->AddItem( L"File" ); - pRoot->GetMenu()->AddItem( L"New", L"test16.png", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - pRoot->GetMenu()->AddItem( L"Load", L"test16.png", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - pRoot->GetMenu()->AddItem( L"Save", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - pRoot->GetMenu()->AddItem( L"Save As..", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - pRoot->GetMenu()->AddItem( L"Quit", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - } - - { - Gwen::Controls::MenuItem* pRoot = menu->AddItem( L"\u043F\u0438\u0440\u0430\u0442\u0441\u0442\u0432\u043E" ); - pRoot->GetMenu()->AddItem( L"\u5355\u5143\u6D4B\u8BD5", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - pRoot->GetMenu()->AddItem( L"\u0111\u01A1n v\u1ECB th\u1EED nghi\u1EC7m", L"test16.png", GWEN_MCALL( ThisClass::MenuItemSelect ) ); - } - - { - Gwen::Controls::MenuItem* pRoot = menu->AddItem( L"Submenu" ); - - pRoot->GetMenu()->AddItem( "One" )->SetCheckable( true ); - - { - Gwen::Controls::MenuItem* pRootB = pRoot->GetMenu()->AddItem( "Two" ); - pRootB->GetMenu()->AddItem( "Two.One" ); - pRootB->GetMenu()->AddItem( "Two.Two" ); - pRootB->GetMenu()->AddItem( "Two.Three" ); - pRootB->GetMenu()->AddItem( "Two.Four" ); - pRootB->GetMenu()->AddItem( "Two.Five" ); - pRootB->GetMenu()->AddItem( "Two.Six" ); - pRootB->GetMenu()->AddItem( "Two.Seven" ); - pRootB->GetMenu()->AddItem( "Two.Eight" ); - pRootB->GetMenu()->AddItem( "Two.Nine", "test16.png" ); - } - - pRoot->GetMenu()->AddItem( "Three" ); - pRoot->GetMenu()->AddItem( "Four" ); - pRoot->GetMenu()->AddItem( "Five" ); - - { - Gwen::Controls::MenuItem* pRootB = pRoot->GetMenu()->AddItem( "Six" ); - pRootB->GetMenu()->AddItem( "Six.One" ); - pRootB->GetMenu()->AddItem( "Six.Two" ); - pRootB->GetMenu()->AddItem( "Six.Three" ); - pRootB->GetMenu()->AddItem( "Six.Four" ); - pRootB->GetMenu()->AddItem( "Six.Five", "test16.png" ); - - { - Gwen::Controls::MenuItem* pRootC = pRootB->GetMenu()->AddItem( "Six.Six" ); - pRootC->GetMenu()->AddItem( "Sheep" ); - pRootC->GetMenu()->AddItem( "Goose" ); - { - Gwen::Controls::MenuItem* pRootD = pRootC->GetMenu()->AddItem( "Camel" ); - pRootD->GetMenu()->AddItem( "Eyes" ); - pRootD->GetMenu()->AddItem( "Nose" ); - { - Gwen::Controls::MenuItem* pRootE = pRootD->GetMenu()->AddItem( "Hair" ); - pRootE->GetMenu()->AddItem( "Blonde" ); - pRootE->GetMenu()->AddItem( "Black" ); - { - Gwen::Controls::MenuItem* pRootF = pRootE->GetMenu()->AddItem( "Red" ); - pRootF->GetMenu()->AddItem( "Light" ); - pRootF->GetMenu()->AddItem( "Medium" ); - pRootF->GetMenu()->AddItem( "Dark" ); - } - pRootE->GetMenu()->AddItem( "Brown" ); - } - pRootD->GetMenu()->AddItem( "Ears" ); - } - pRootC->GetMenu()->AddItem( "Duck" ); - } - - pRootB->GetMenu()->AddItem( "Six.Seven" ); - pRootB->GetMenu()->AddItem( "Six.Eight" ); - pRootB->GetMenu()->AddItem( "Six.Nine" ); - } - - pRoot->GetMenu()->AddItem( "Seven" ); - - } - } - - void MenuItemSelect( Base* pControl ) - { - Gwen::Controls::MenuItem* pMenuItem = (Gwen::Controls::MenuItem*)pControl; - - UnitPrint( Utility::Format( L"Menu Selected: %s", pMenuItem->GetText().c_str() ) ); - } - -}; - - - -DEFINE_UNIT_TEST( MenuStrip, L"MenuStrip" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/Numeric.cpp b/btgui/GwenOpenGLTest/Numeric.cpp deleted file mode 100644 index f7a1c85eb..000000000 --- a/btgui/GwenOpenGLTest/Numeric.cpp +++ /dev/null @@ -1,31 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/NumericUpDown.h" - -using namespace Gwen; - -class Numeric : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( Numeric, GUnit ) - { - - Controls::NumericUpDown* pCtrl = new Controls::NumericUpDown( this ); - pCtrl->SetBounds( 10, 10, 50, 20 ); - pCtrl->SetValue( 50 ); - pCtrl->SetMax( 1000 ); - pCtrl->SetMin( -1000 ); - - // pCtrl->onPress.Add( this, &ThisClass::onButtonA ); - } - - void onButtonA( Controls::Base* pControl ) - { - // UnitPrint( L"Button Pressed (using 'OnPress' event)" ); - } - -}; - - - -DEFINE_UNIT_TEST( Numeric, L"Numeric" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/OpenGLSample.cpp b/btgui/GwenOpenGLTest/OpenGLSample.cpp deleted file mode 100644 index 53f16e24f..000000000 --- a/btgui/GwenOpenGLTest/OpenGLSample.cpp +++ /dev/null @@ -1,534 +0,0 @@ - - -#include "Gwen/Gwen.h" -#include "Gwen/Skins/Simple.h" - -#include "UnitTest.h" - -extern char OpenSansData[]; - -#include "Gwen/Renderers/OpenGL_DebugFont.h" -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#else - -#include "GL/glew.h" -#ifdef _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#else -//let's cross the fingers it is Linux/X11 -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif //_WIN32 -#endif//__APPLE__ - -#include "OpenGLWindow/opengl_fontstashcallbacks.h" - -#include "OpenGLWindow/GwenOpenGL3CoreRenderer.h" -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include - -Gwen::Controls::Canvas* pCanvas = NULL; -Gwen::Skin::Simple skin; - -void MyMouseMoveCallback( float x, float y) -{ - //b3DefaultMouseCallback(button,state,x,y); - - static int m_lastmousepos[2] = {0,0}; - static bool isInitialized = false; - if (pCanvas) - { - if (!isInitialized) - { - isInitialized = true; - m_lastmousepos[0] = x+1; - m_lastmousepos[1] = y+1; - } - bool handled = pCanvas->InputMouseMoved(x,y,m_lastmousepos[0],m_lastmousepos[1]); - } -} - -void MyMouseButtonCallback(int button, int state, float x, float y) -{ - //b3DefaultMouseCallback(button,state,x,y); - - if (pCanvas) - { - bool handled = pCanvas->InputMouseMoved(x,y,x, y); - - if (button>=0) - { - handled = pCanvas->InputMouseButton(button,state); - if (handled) - { - if (!state) - return; - } - } - } -} - -int sWidth = 800;//1050; -int sHeight = 600;//768; -GLPrimitiveRenderer* primRenderer=0; -//GwenOpenGL3CoreRenderer* gwenRenderer=0; -Gwen::Renderer::Base* gwenRenderer =0; - -static void MyResizeCallback( float width, float height) -{ - sWidth = width; - sHeight = height; -// printf("resize(%d,%d)\n",sWidth,sHeight); - if (primRenderer) - { - primRenderer->setScreenSize(width,height); - } - if (gwenRenderer) - { - gwenRenderer->Resize(width,height); - } - if (pCanvas) - { - pCanvas->SetSize( sWidth, sHeight); - } - -} - - - int droidRegular;//, droidItalic, droidBold, droidJapanese, dejavu; - -sth_stash* initFont(GLPrimitiveRenderer* primRenderer) -{ - GLint err; - - struct sth_stash* stash = 0; - OpenGL2RenderCallbacks* renderCallbacks = new OpenGL2RenderCallbacks(primRenderer); - - stash = sth_create(512,512,renderCallbacks);//256,256);//,1024);//512,512); - err = glGetError(); - assert(err==GL_NO_ERROR); - - if (!stash) - { - fprintf(stderr, "Could not create stash.\n"); - return 0; - } - - -#ifdef LOAD_FONTS_FROM_FILE - int datasize; - unsigned char* data; - float sx,sy,dx,dy,lh; - GLuint texture; - - - - const char* fontPaths[]={ - "./", - "../../bin/", - "../bin/", - "bin/" - }; - - int numPaths=sizeof(fontPaths)/sizeof(char*); - - // Load the first truetype font from memory (just because we can). - - FILE* fp = 0; - const char* fontPath ="./"; - char fullFontFileName[1024]; - - for (int i=0;iInputKey(key,value==1); - - - int gwenKey = -1; - - switch (key) - { - case B3G_LEFT_ARROW: - { - gwenKey = Gwen::Key::Left; - break; - } - case B3G_RIGHT_ARROW: - { - gwenKey = Gwen::Key::Right; - break; - } - case B3G_UP_ARROW: - { - gwenKey = Gwen::Key::Up; - break; - } - case B3G_DOWN_ARROW: - { - gwenKey = Gwen::Key::Down; - break; - } - case B3G_BACKSPACE: - { - gwenKey = Gwen::Key::Backspace; - break; - } - case B3G_DELETE: - { - gwenKey = Gwen::Key::Delete; - break; - } - case B3G_HOME: - { - gwenKey = Gwen::Key::Home; - break; - } - case B3G_END: - { - gwenKey = Gwen::Key::End; - break; - } - case B3G_SHIFT: - { - gwenKey = Gwen::Key::Shift; - break; - } - case B3G_CONTROL: - { - gwenKey = Gwen::Key::Control; - break; - } - - - - default: - { - - } - }; - - if (gwenKey>=0) - { - pCanvas->InputKey(gwenKey,value==1); - } else - { - if (key<256 && value) - { - Gwen::UnicodeChar c = ( Gwen::UnicodeChar ) key; - pCanvas->InputCharacter(c); - } - } -} - -extern int avoidUpdate; - -int main() -{ - - b3gDefaultOpenGLWindow* window = new b3gDefaultOpenGLWindow(); - window->setKeyboardCallback(keyCallback); - b3gWindowConstructionInfo wci; - wci.m_openglVersion = 2; - wci.m_width = sWidth; - wci.m_height = sHeight; - // wci.m_resizeCallback = MyResizeCallback; - - window->createWindow(wci); - window->setResizeCallback(MyResizeCallback); - - - int majorGlVersion, minorGlVersion; - - if (!sscanf((const char*)glGetString(GL_VERSION), "%d.%d", &majorGlVersion, &minorGlVersion)==2) - { - printf("Exit: Error cannot extract OpenGL version from GL_VERSION string\n"); - exit(0); - } - char title[1024]; - if (wci.m_openglVersion>2) - { - sprintf(title,"Gwen with OpenGL %d.%d\n",majorGlVersion,minorGlVersion); - } else - { - sprintf(title,"Gwen with OpenGL %d\n",wci.m_openglVersion); - } - window->setWindowTitle(title); - - if (majorGlVersion>=3 && wci.m_openglVersion>=3) - { - float retinaScale = 1.f; - -#ifndef __APPLE__ -#ifndef _WIN32 - //we need glewExperimental on Linux - glewExperimental = GL_TRUE; -#endif // _WIN32 - glewInit(); -#endif - - //we ned to call glGetError twice, because of some Ubuntu/Intel/OpenGL issue - - GLuint err = glGetError(); - err = glGetError(); - assert(err==GL_NO_ERROR); - - - retinaScale = window->getRetinaScale(); - - primRenderer = new GLPrimitiveRenderer(sWidth,sHeight); - - sth_stash* font = initFont(primRenderer ); - - - gwenRenderer = new GwenOpenGL3CoreRenderer(primRenderer,font,sWidth,sHeight,retinaScale); - - } else - { - //OpenGL 2.x - gwenRenderer = new Gwen::Renderer::OpenGL_DebugFont(); - - - skin.SetRender( gwenRenderer ); - - - - glClearColor(1,0,0,1); - - } - - - - // - // Create a GWEN OpenGL Renderer - // -// Gwen::Renderer::OpenGL_DebugFont * pRenderer = new Gwen::Renderer::OpenGL_DebugFont(); - - // - // Create a GWEN skin - // - - -#ifdef USE_TEXTURED_SKIN - Gwen::Skin::TexturedBase skin; - skin.SetRender( pRenderer ); - skin.Init("DefaultSkin.png"); -#else - skin.SetRender( gwenRenderer ); -#endif - - - // - // Create a Canvas (it's root, on which all other GWEN panels are created) - // - pCanvas = new Gwen::Controls::Canvas( &skin ); - pCanvas->SetSize( sWidth, sHeight); - pCanvas->SetDrawBackground( true ); - pCanvas->SetBackgroundColor( Gwen::Color( 150, 170, 170, 255 ) ); - - window->setMouseButtonCallback(MyMouseButtonCallback); - window->setMouseMoveCallback(MyMouseMoveCallback); - - - // - // Create our unittest control (which is a Window with controls in it) - // - UnitTest* pUnit = new UnitTest( pCanvas ); - pUnit->SetPos( 10, 10 ); - - // - // Create a Windows Control helper - // (Processes Windows MSG's and fires input at GWEN) - // - //Gwen::Input::Windows GwenInput; - //GwenInput.Initialize( pCanvas ); - - // - // Begin the main game loop - // -// MSG msg; - while( !window->requestedExit() ) - { - if (majorGlVersion<3 || wci.m_openglVersion<3) - { - saveOpenGLState(sWidth,sHeight); - } - - // Skip out if the window is closed - //if ( !IsWindowVisible( g_pHWND ) ) - //break; - - // If we have a message from windows.. - // if ( PeekMessage( &msg, NULL, 0, 0, PM_REMOVE ) ) - { - - // .. give it to the input handler to process - // GwenInput.ProcessMessage( msg ); - - // if it's QUIT then quit.. - // if ( msg.message == WM_QUIT ) - // break; - - // Handle the regular window stuff.. - // TranslateMessage(&msg); - // DispatchMessage(&msg); - - } - - window->startRendering(); - - // Main OpenGL Render Loop - { - glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT ); - - glEnable(GL_BLEND); - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - glDisable(GL_DEPTH_TEST); - err = glGetError(); - assert(err==GL_NO_ERROR); - - //glColor4ub(255,0,0,255); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - - err = glGetError(); - assert(err==GL_NO_ERROR); - glBlendFunc(GL_SRC_ALPHA,GL_ONE_MINUS_SRC_ALPHA); - - // saveOpenGLState(width,height);//m_glutScreenWidth,m_glutScreenHeight); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - - err = glGetError(); - assert(err==GL_NO_ERROR); - - glDisable(GL_CULL_FACE); - - glDisable(GL_DEPTH_TEST); - err = glGetError(); - assert(err==GL_NO_ERROR); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - glEnable(GL_BLEND); - - - err = glGetError(); - assert(err==GL_NO_ERROR); - - - - pCanvas->RenderCanvas(); - - if (avoidUpdate<=0) - avoidUpdate++; - - // SwapBuffers( GetDC( g_pHWND ) ); - } - window->endRendering(); - - if (majorGlVersion<3 || wci.m_openglVersion<3) - { - restoreOpenGLState(); - } - } - - window->closeWindow(); - delete window; - - -} diff --git a/btgui/GwenOpenGLTest/PanelListPanel.cpp b/btgui/GwenOpenGLTest/PanelListPanel.cpp deleted file mode 100644 index fcf1ae316..000000000 --- a/btgui/GwenOpenGLTest/PanelListPanel.cpp +++ /dev/null @@ -1,61 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/PanelListPanel.h" -#include "Gwen/Controls/StatusBar.h" -#include "Gwen/Utility.h" - -using namespace Gwen; - -class PanelListPanel : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( PanelListPanel, GUnit ) - { - m_PLP = new Gwen::Controls::PanelListPanel( this ); - m_PLP->Dock( Pos::Fill ); - m_PLP->SetPadding( Gwen::Padding( 10, 10 )); - m_PLP->SetVertical(); - m_PLP->SetSizeToChildren( false ); - - for ( int i = 0; i < 16; i++) - { - Gwen::String testName = "TEST" + Utility::ToString( i ); - Gwen::Controls::Button* testButton = new Gwen::Controls::Button( m_PLP ); - testButton->SetText( testName ); - } - - Gwen::Controls::StatusBar* pStatus = new Gwen::Controls::StatusBar( this ); - pStatus->Dock( Pos::Bottom ); - - { - Gwen::Controls::Button* pButton = new Gwen::Controls::Button( pStatus ); - pButton->SetText( "Horizontal" ); - pButton->onPress.Add( this, &PanelListPanel::GoHorizontal ); - pStatus->AddControl( pButton, false ); - } - - { - Gwen::Controls::Button* pButton = new Gwen::Controls::Button( pStatus ); - pButton->SetText( "Vertical" ); - pButton->onPress.Add( this, &PanelListPanel::GoVertical ); - pStatus->AddControl( pButton, true ); - } - } - - - void GoVertical( Gwen::Controls::Base* pFromPanel ) - { - m_PLP->SetVertical(); - } - - void GoHorizontal( Gwen::Controls::Base* pFromPanel ) - { - m_PLP->SetHorizontal(); - } - - Gwen::Controls::PanelListPanel* m_PLP; -}; - - - -DEFINE_UNIT_TEST( PanelListPanel, L"PanelListPanel" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/ProgressBar.cpp b/btgui/GwenOpenGLTest/ProgressBar.cpp deleted file mode 100644 index ed72c3e19..000000000 --- a/btgui/GwenOpenGLTest/ProgressBar.cpp +++ /dev/null @@ -1,93 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/RadioButtonController.h" -#include "Gwen/Controls/ProgressBar.h" - -using namespace Gwen; - -class ProgressBar : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( ProgressBar, GUnit ) - { - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 20, 200, 20 ) ); - pb->SetValue( 0.27f ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 50, 200, 20 ) ); - pb->SetValue( 0.66f ); - pb->SetAlignment( Pos::Right | Pos::CenterV ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 80, 200, 20 ) ); - pb->SetValue( 0.88f ); - pb->SetAlignment( Pos::Left | Pos::CenterV ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 110, 200, 20 ) ); - pb->SetAutoLabel( false ); - pb->SetValue( 0.20f ); - pb->SetAlignment( Pos::Right | Pos::CenterV ); - pb->SetText( L"40,245 MB" ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 140, 200, 20 ) ); - pb->SetAutoLabel( false ); - pb->SetValue( 1.00f ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 170, 200, 20 ) ); - pb->SetAutoLabel( false ); - pb->SetValue( 0.00f ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 110, 200, 200, 20 ) ); - pb->SetAutoLabel( false ); - pb->SetValue( 0.50f ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 20, 20, 25, 200 ) ); - pb->SetVertical(); - pb->SetValue( 0.25f ); - pb->SetAlignment( Pos::Top | Pos::CenterH ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 50, 20, 25, 200 ) ); - pb->SetVertical(); - pb->SetValue( 0.40f ); - } - - { - Gwen::Controls::ProgressBar* pb = new Gwen::Controls::ProgressBar( this ); - pb->SetBounds( Gwen::Rect( 80, 20, 25, 200 ) ); - pb->SetVertical(); - pb->SetAlignment( Pos::Bottom | Pos::CenterH ); - pb->SetValue( 0.65f ); - } - - } - -}; - - - -DEFINE_UNIT_TEST( ProgressBar, L"ProgressBar" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/Properties.cpp b/btgui/GwenOpenGLTest/Properties.cpp deleted file mode 100644 index c909db388..000000000 --- a/btgui/GwenOpenGLTest/Properties.cpp +++ /dev/null @@ -1,63 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/Properties.h" -#include "Gwen/Controls/PropertyTree.h" - -using namespace Gwen; - -class Properties2 : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( Properties2, GUnit ) - { - { - Gwen::Controls::Properties* props = new Gwen::Controls::Properties( this ); - - props->SetBounds( 10, 10, 150, 300 ); - - { - { - Gwen::Controls::PropertyRow* pRow = props->Add( L"First Name" ); - pRow->onChange.Add( this, &Properties2::OnFirstNameChanged ); - } - - props->Add( L"Middle Name" ); - props->Add( L"Last Name" ); - } - - } - - { - Gwen::Controls::PropertyTree* ptree = new Gwen::Controls::PropertyTree( this ); - ptree->SetBounds( 200, 10, 200, 200 ); - - { - Gwen::Controls::Properties* props = ptree->Add( L"Item One" ); - props->Add( L"Middle Name" ); - props->Add( L"Last Name" ); - props->Add( L"Four" ); - } - - { - Gwen::Controls::Properties* props = ptree->Add( L"Item Two" ); - props->Add( L"More Items" ); - props->Add( L"To Fill" ); - props->Add( L"Out Here" ); - } - - ptree->ExpandAll(); - - } - } - - void OnFirstNameChanged( Controls::Base* pControl ) - { - Gwen::Controls::PropertyRow* pRow = (Gwen::Controls::PropertyRow*) pControl; - UnitPrint( Utility::Format( L"First Name Changed: %s", pRow->GetProperty()->GetPropertyValue().c_str() ) ); - } - -}; - - - -DEFINE_UNIT_TEST( Properties2, L"Properties" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/RadioButton.cpp b/btgui/GwenOpenGLTest/RadioButton.cpp deleted file mode 100644 index 5d4948dd0..000000000 --- a/btgui/GwenOpenGLTest/RadioButton.cpp +++ /dev/null @@ -1,38 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/RadioButtonController.h" - -using namespace Gwen; - -class RadioButton2 : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( RadioButton2, GUnit ) - { - - Gwen::Controls::RadioButtonController* rc = new Gwen::Controls::RadioButtonController( this ); - - rc->AddOption( "Option 1" ); - rc->AddOption( "Option 2" ); - rc->AddOption( "Option 3" ); - rc->AddOption( L"\u0627\u0644\u0622\u0646 \u0644\u062D\u0636\u0648\u0631" ); - - rc->SetBounds( 30, 30, 200, 200 ); - - rc->onSelectionChange.Add( this, &RadioButton2::OnChange ); - - - } - - void OnChange( Controls::Base* pControl ) - { - Gwen::Controls::RadioButtonController* rc = (Gwen::Controls::RadioButtonController*) pControl; - Gwen::Controls::LabeledRadioButton* pSelected = rc->GetSelected(); - - UnitPrint( Utility::Format( L"RadioButton changed (using 'OnChange' event)\n Chosen Item: '%s'", pSelected->GetLabel()->GetText().c_str() ) ); - } -}; - - - -DEFINE_UNIT_TEST( RadioButton2, L"RadioButton" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/ScrollControl.cpp b/btgui/GwenOpenGLTest/ScrollControl.cpp deleted file mode 100644 index c21a2080a..000000000 --- a/btgui/GwenOpenGLTest/ScrollControl.cpp +++ /dev/null @@ -1,138 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/ScrollControl.h" - -using namespace Gwen; - -class ScrollControl : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( ScrollControl, GUnit ) - { - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 10, 10, 100, 100 ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Twice As Big" ); - pTestButton->SetBounds( 0, 0, 200, 200 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 110, 10, 100, 100 ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Same Size" ); - pTestButton->SetBounds( 0, 0, 100, 100 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 210, 10, 100, 100 ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Wide" ); - pTestButton->SetBounds( 0, 0, 200, 50 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 310, 10, 100, 100 ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Tall" ); - pTestButton->SetBounds( 0, 0, 50, 200 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 410, 10, 100, 100 ); - pCtrl->SetScroll( false, true ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Vertical" ); - pTestButton->SetBounds( 0, 0, 200, 200 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 510, 10, 100, 100 ); - pCtrl->SetScroll( true, false ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Horinzontal" ); - pTestButton->SetBounds( 0, 0, 200, 200 ); - } - - // Bottom Row - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 10, 110, 100, 100 ); - pCtrl->SetAutoHideBars( true ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Twice As Big" ); - pTestButton->SetBounds( 0, 0, 200, 200 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 110, 110, 100, 100 ); - pCtrl->SetAutoHideBars( true ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Same Size" ); - pTestButton->SetBounds( 0, 0, 100, 100 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 210, 110, 100, 100 ); - pCtrl->SetAutoHideBars( true ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Wide" ); - pTestButton->SetBounds( 0, 0, 200, 50 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 310, 110, 100, 100 ); - pCtrl->SetAutoHideBars( true ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Tall" ); - pTestButton->SetBounds( 0, 0, 50, 200 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 410, 110, 100, 100 ); - pCtrl->SetAutoHideBars( true ); - pCtrl->SetScroll( false, true ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Vertical" ); - pTestButton->SetBounds( 0, 0, 200, 200 ); - } - - { - Gwen::Controls::ScrollControl* pCtrl = new Gwen::Controls::ScrollControl( this ); - pCtrl->SetBounds( 510, 110, 100, 100 ); - pCtrl->SetAutoHideBars( true ); - pCtrl->SetScroll( true, false ); - - Controls::Button* pTestButton = new Controls::Button( pCtrl ); - pTestButton->SetText( L"Horinzontal" ); - pTestButton->SetBounds( 0, 0, 200, 200 ); - } - } - -}; - - - -DEFINE_UNIT_TEST( ScrollControl, L"Scroll" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/Slider.cpp b/btgui/GwenOpenGLTest/Slider.cpp deleted file mode 100644 index cf002fa86..000000000 --- a/btgui/GwenOpenGLTest/Slider.cpp +++ /dev/null @@ -1,66 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/RadioButtonController.h" -#include "Gwen/Controls/VerticalSlider.h" -#include "Gwen/Controls/HorizontalSlider.h" - -using namespace Gwen; - -class Slider : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( Slider, GUnit ) - { - { - Gwen::Controls::HorizontalSlider* pSlider = new Gwen::Controls::HorizontalSlider( this ); - pSlider->SetPos( 10, 10 ); - pSlider->SetSize( 150, 20 ); - pSlider->SetRange( 0, 100 ); - pSlider->SetValue( 25 ); - pSlider->onValueChanged.Add( this, &Slider::SliderMoved ); - } - - { - Gwen::Controls::HorizontalSlider* pSlider = new Gwen::Controls::HorizontalSlider( this ); - pSlider->SetPos( 10, 40 ); - pSlider->SetSize( 150, 20 ); - pSlider->SetRange( 0, 100 ); - pSlider->SetValue( 25 ); - pSlider->SetNotchCount( 10 ); - pSlider->SetClampToNotches( true ); - pSlider->onValueChanged.Add( this, &Slider::SliderMoved ); - } - - { - Gwen::Controls::VerticalSlider* pSlider = new Gwen::Controls::VerticalSlider( this ); - pSlider->SetPos( 160, 10 ); - pSlider->SetSize( 20, 200 ); - pSlider->SetRange( 0, 100 ); - pSlider->SetValue( 25 ); - pSlider->onValueChanged.Add( this, &Slider::SliderMoved ); - } - - { - Gwen::Controls::VerticalSlider* pSlider = new Gwen::Controls::VerticalSlider( this ); - pSlider->SetPos( 190, 10 ); - pSlider->SetSize( 20, 200 ); - pSlider->SetRange( 0, 100 ); - pSlider->SetValue( 25 ); - pSlider->SetNotchCount( 10 ); - pSlider->SetClampToNotches( true ); - pSlider->onValueChanged.Add( this, &Slider::SliderMoved ); - } - } - - void SliderMoved( Base* pControl ) - { - Gwen::Controls::Slider* pSlider = (Gwen::Controls::Slider*)pControl; - - UnitPrint( Utility::Format( L"Slider Value: %.2f", pSlider->GetValue() ) ); - } - -}; - - - -DEFINE_UNIT_TEST( Slider, L"Slider" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/StatusBar.cpp b/btgui/GwenOpenGLTest/StatusBar.cpp deleted file mode 100644 index 902553739..000000000 --- a/btgui/GwenOpenGLTest/StatusBar.cpp +++ /dev/null @@ -1,28 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/StatusBar.h" -#include "Gwen/Controls/Label.h" - -using namespace Gwen; - -class StatusBar : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( StatusBar, GUnit ) - { - Gwen::Controls::StatusBar* pStatus = new Gwen::Controls::StatusBar( this ); - pStatus->Dock( Pos::Bottom ); - - Gwen::Controls::Label* pLeft = new Gwen::Controls::Label( pStatus ); - pLeft->SetText(L"Label Added to left"); - pStatus->AddControl( pLeft, false ); - - Gwen::Controls::Label* pRight = new Gwen::Controls::Label( pStatus ); - pRight->SetText(L"Label Added to Right"); - pStatus->AddControl( pRight, true ); - } -}; - - - -DEFINE_UNIT_TEST( StatusBar, L"StatusBar" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/TabControl.cpp b/btgui/GwenOpenGLTest/TabControl.cpp deleted file mode 100644 index 8ed2b2ba6..000000000 --- a/btgui/GwenOpenGLTest/TabControl.cpp +++ /dev/null @@ -1,71 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/RadioButtonController.h" - -using namespace Gwen; - -class TabControl2 : public GUnit -{ - public: - - Controls::TabControl* m_pDockControlLeft; - - GWEN_CONTROL_INLINE( TabControl2, GUnit ) - { - { - m_pDockControlLeft = new Controls::TabControl( this ); - m_pDockControlLeft->SetBounds( 10, 10, 200, 200 ); - - { - Controls::TabButton* pButton = m_pDockControlLeft->AddPage( L"Controls" ); - Base* pPage = pButton->GetPage(); - - { - Controls::RadioButtonController* pRadio = new Controls::RadioButtonController( pPage ); - pRadio->SetBounds( 10, 10, 100, 100 ); - - pRadio->AddOption( "Top" )->Select(); - pRadio->AddOption( "Bottom" ); - pRadio->AddOption( "Left" ); - pRadio->AddOption( "Right" ); - - pRadio->onSelectionChange.Add( this, &ThisClass::OnDockChange ); - - } - } - - m_pDockControlLeft->AddPage( L"Red" ); - m_pDockControlLeft->AddPage( L"Green" ); - m_pDockControlLeft->AddPage( L"Blue" ); - } - - { - Controls::TabControl* pDragMe = new Controls::TabControl( this ); - pDragMe->SetBounds( 220, 10, 200, 200 ); - - pDragMe->AddPage( L"You" ); - pDragMe->AddPage( L"Can" ); - pDragMe->AddPage( L"Reorder" )->SetImage( L"test16.png" ); - pDragMe->AddPage( L"These" ); - pDragMe->AddPage( L"Tabs" ); - - pDragMe->SetAllowReorder( true ); - } - } - - void OnDockChange( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::RadioButtonController* rc = (Gwen::Controls::RadioButtonController*) pControl; - - if ( rc->GetSelectedLabel() == L"Top" ) m_pDockControlLeft->SetTabStripPosition( Pos::Top ); - if ( rc->GetSelectedLabel() == L"Bottom" ) m_pDockControlLeft->SetTabStripPosition( Pos::Bottom ); - if ( rc->GetSelectedLabel() == L"Left" ) m_pDockControlLeft->SetTabStripPosition( Pos::Left ); - if ( rc->GetSelectedLabel() == L"Right" ) m_pDockControlLeft->SetTabStripPosition( Pos::Right ); - } - - Gwen::Font m_Font; -}; - - - -DEFINE_UNIT_TEST( TabControl2, L"TabControl" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/TextBox.cpp b/btgui/GwenOpenGLTest/TextBox.cpp deleted file mode 100644 index 72b49adc9..000000000 --- a/btgui/GwenOpenGLTest/TextBox.cpp +++ /dev/null @@ -1,79 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/TextBox.h" - -using namespace Gwen; - -class TextBox : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( TextBox, GUnit ) - { - { - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox( this ); - label->SetText( "" ); - label->SetPos( 10, 10 ); - label->onTextChanged.Add( this, &ThisClass::OnEdit ); - label->onReturnPressed.Add( this, &ThisClass::OnSubmit ); - - } - - { - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox( this ); - label->SetText( "Normal Everyday Label" ); - label->SetPos( 10, 10 + 25 ); - } - - { - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox( this ); - label->SetText( "Select All Text On Focus" ); - label->SetPos( 10, 10 + 25 * 2 ); - label->SetSelectAllOnFocus( true ); - } - - { - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox( this ); - label->SetText( L"Different Coloured Text, for some reason" ); - label->SetTextColor( Gwen::Color( 255, 0, 255, 255 ) ); - label->SetPos( 10, 10 + 25 * 3 ); - } - - { - Gwen::Controls::TextBoxNumeric* label = new Gwen::Controls::TextBoxNumeric( this ); - label->SetText( L"2004" ); - label->SetTextColor( Gwen::Color( 255, 0, 255, 255 ) ); - label->SetPos( 10, 10 + 25 * 4 ); - } - - { - m_Font.facename = L"Impact"; - m_Font.size = 50; - - Gwen::Controls::TextBox* label = new Gwen::Controls::TextBox( this ); - label->SetText( L"Different Font" ); - label->SetPos( 10, 10 + 25 * 5 ); - label->SetFont( &m_Font ); - label->SetSize( 200, 55 ); - } - - - } - - void OnEdit( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::TextBox* textbox = (Gwen::Controls::TextBox*) (pControl); - UnitPrint( Utility::Format( L"Textbox Edit: [%s]\n", textbox->GetText().c_str() ) ); - } - - void OnSubmit( Gwen::Controls::Base* pControl ) - { - Gwen::Controls::TextBox* textbox = (Gwen::Controls::TextBox*) (pControl); - UnitPrint( Utility::Format( L"Textbox Submit: [%s]\n", textbox->GetText().c_str() ) ); - } - - Gwen::Font m_Font; -}; - - - -DEFINE_UNIT_TEST( TextBox, L"TextBox" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/TreeControl.cpp b/btgui/GwenOpenGLTest/TreeControl.cpp deleted file mode 100644 index 87924ce7e..000000000 --- a/btgui/GwenOpenGLTest/TreeControl.cpp +++ /dev/null @@ -1,61 +0,0 @@ -#include "UnitTest.h" -#include "Gwen/Controls/TreeControl.h" - -using namespace Gwen; - -using namespace Gwen::Controls; - - -class TreeControl2 : public GUnit -{ - public: - - GWEN_CONTROL_INLINE( TreeControl2, GUnit ) - { - { - Gwen::Controls::TreeControl* ctrl = new Gwen::Controls::TreeControl( this ); - - ctrl->SetKeyboardInputEnabled(true); - ctrl->AddNode( L"Node One" ); - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - pNode->SetSelected(true); - - pNode->AddNode( L"Brown" )->AddNode( L"Node Two Inside" )->AddNode( L"Eyes" )->AddNode( L"Brown" ); - ctrl->AddNode( L"Node Three" ); - ctrl->Focus(); - ctrl->SetKeyboardInputEnabled(true); - - ctrl->SetBounds( 30, 30, 200, 200 ); - ctrl->ExpandAll(); - } - - { - Gwen::Controls::TreeControl* ctrl = new Gwen::Controls::TreeControl( this ); - - ctrl->AllowMultiSelect( true ); - - ctrl->AddNode( L"Node One" ); - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - Gwen::Controls::TreeNode* pNodeTwo = pNode->AddNode( L"Brown" )->AddNode( L"Node Two Inside" )->AddNode( L"Eyes" ); - pNodeTwo->AddNode( L"Brown" ); - pNodeTwo->AddNode( L"Green" ); - pNodeTwo->AddNode( L"Slime" ); - pNodeTwo->AddNode( L"Grass" ); - pNodeTwo->AddNode( L"Pipe" ); - - ctrl->AddNode( L"Node Three" ); - - ctrl->SetBounds( 240, 30, 200, 200 ); - ctrl->ExpandAll(); - } - } - -}; - - - -DEFINE_UNIT_TEST( TreeControl2, L"TreeControl" ); \ No newline at end of file diff --git a/btgui/GwenOpenGLTest/UnitTest.cpp b/btgui/GwenOpenGLTest/UnitTest.cpp deleted file mode 100644 index 9886c6eb3..000000000 --- a/btgui/GwenOpenGLTest/UnitTest.cpp +++ /dev/null @@ -1,179 +0,0 @@ -/* - GWEN - Copyright (c) 2010 Facepunch Studios - See license in Gwen.h -*/ - -#include "UnitTest.h" -#include "Gwen/Platform.h" -#include "Gwen/Controls/TreeControl.h" - -using namespace Gwen; - -#define ADD_UNIT_TEST( name )\ - GUnit* RegisterUnitTest_##name( Gwen::Controls::TabControl* tab );\ - RegisterUnitTest_##name( m_TabControl )->SetUnitTest( this ); - -GWEN_CONTROL_CONSTRUCTOR( UnitTest ) -{ - SetTitle( L"GWEN Unit Test" ); - - SetSize( 600, 450 ); - - - m_TabControl = new Controls::TabControl( this ); - m_TabControl->Dock( Pos::Fill ); - m_TabControl->SetMargin( Margin( 2, 2, 2, 2 ) ); - - m_TextOutput = new Controls::ListBox( this ); - m_TextOutput->Dock( Pos::Bottom ); - m_TextOutput->SetHeight( 100 ); - - - ADD_UNIT_TEST( ImagePanel ); - - //ADD_UNIT_TEST( MenuStrip ); - - Gwen::UnicodeString str1(L"testje"); - Gwen::Controls::TabButton* tab = m_TabControl->AddPage(str1); - - Gwen::Controls::TreeControl* ctrl=0; - - { - ctrl = new Gwen::Controls::TreeControl(tab->GetPage()); - - ctrl->SetKeyboardInputEnabled(true); - ctrl->AddNode( L"Node One" ); - { - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - - } - { - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - - } - { - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - - } - { - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - - } - { - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - - } - { - Gwen::Controls::TreeNode* pNode = ctrl->AddNode( L"Node Two" ); - pNode->AddNode( L"Node Two Inside" ); - pNode->AddNode( L"Eyes" ); - pNode->SetSelected(true); - - - pNode->AddNode( L"Brown" )->AddNode( L"Node Two Inside" )->AddNode( L"Eyes" )->AddNode( L"Brown" ); - } - ctrl->AddNode( L"Node Three" ); - ctrl->Focus(); - ctrl->SetKeyboardInputEnabled(true); - - ctrl->SetBounds( 30, 30, 200, 30+16*10 ); - //ctrl->ExpandAll(); - ctrl->ForceUpdateScrollBars(); - ctrl->OnKeyDown(true); - - - } - - - //GUnit* u = new TreeControl2(m_TabControl);..Gwen::Controls::TreeControl2( m_TabControl ); - //GUnit* RegisterUnitTest_TreeControl2( Gwen::Controls::TabControl* tab );\ - //RegisterUnitTest_TreeControl2( m_TabControl )->SetUnitTest( this ); - - - //#define DEFINE_UNIT_TEST( name, displayname ) - //GUnit* RegisterUnitTest_TreeControl2( Gwen::Controls::TabControl* tab ) - //{ - // GUnit* u = new TreeControl2( tab ); - // tab->AddPage( displayname, u ); - // return u; - //} - - //ADD_UNIT_TEST( TreeControl2 ); - - ADD_UNIT_TEST( Properties2 ); - - - ADD_UNIT_TEST( TabControl2 ); - ADD_UNIT_TEST( ScrollControl ); - ADD_UNIT_TEST( MenuStrip ); - ADD_UNIT_TEST( Numeric ); - ADD_UNIT_TEST( ComboBox ); - ADD_UNIT_TEST( TextBox ); - ADD_UNIT_TEST( ListBox ); - ADD_UNIT_TEST( Slider ); - ADD_UNIT_TEST( ProgressBar ); - ADD_UNIT_TEST( RadioButton2 ); - - ADD_UNIT_TEST( Label ); - ADD_UNIT_TEST( Checkbox ); - ADD_UNIT_TEST( Button ); - - ADD_UNIT_TEST( CrossSplitter ); - - ADD_UNIT_TEST( PanelListPanel ); - ADD_UNIT_TEST( GroupBox2 ); - - ADD_UNIT_TEST( StatusBar ); - - - ctrl->Focus(); - PrintText( L"Unit Test Started.\n" ); - - m_fLastSecond = Gwen::Platform::GetTimeInSeconds(); - m_iFrames = 0; -} - - -void UnitTest::PrintText( const Gwen::UnicodeString& str ) -{ - m_TextOutput->AddItem( str ); - m_TextOutput->Scroller()->ScrollToBottom(); -} - -void UnitTest::Render( Gwen::Skin::Base* skin ) -{ - m_iFrames++; - - if ( m_fLastSecond < Gwen::Platform::GetTimeInSeconds() ) - { - SetTitle( Gwen::Utility::Format( L"GWEN Unit Test - %i fps", m_iFrames ) ); - - m_fLastSecond = Gwen::Platform::GetTimeInSeconds() + 1.0f; - m_iFrames = 0; - } - - BaseClass::Render( skin ); - -} - -void GUnit::UnitPrint( const Gwen::UnicodeString& str ) -{ - m_pUnitTest->PrintText( str ); -} - -void GUnit::UnitPrint( const Gwen::String& str ) -{ - UnitPrint( Utility::StringToUnicode( str ) ); -} - diff --git a/btgui/GwenOpenGLTest/UnitTest.h b/btgui/GwenOpenGLTest/UnitTest.h deleted file mode 100644 index 7d8f76f7f..000000000 --- a/btgui/GwenOpenGLTest/UnitTest.h +++ /dev/null @@ -1,64 +0,0 @@ -/* - GWEN - Copyright (c) 2011 Facepunch Studios - See license in Gwen.h -*/ - - -#pragma once -#ifndef GWEN_UNITTEST_UNITTEST_H -#define GWEN_UNITTEST_UNITTEST_H - -#include "Gwen/Gwen.h" -#include "Gwen/Align.h" -#include "Gwen/Utility.h" -#include "Gwen/Controls/WindowControl.h" -#include "Gwen/Controls/TabControl.h" -#include "Gwen/Controls/ListBox.h" - -class UnitTest; - - - -class GUnit : public Gwen::Controls::Base -{ - public: - - GWEN_CONTROL_INLINE( GUnit, Gwen::Controls::Base ) - { - m_pUnitTest = NULL; - } - - void SetUnitTest( UnitTest* u ){ m_pUnitTest = u; } - - void UnitPrint( const Gwen::UnicodeString& str ); - void UnitPrint( const Gwen::String& str ); - - - - - UnitTest* m_pUnitTest; -}; - -class UnitTest : public Gwen::Controls::WindowControl -{ - public: - - GWEN_CONTROL( UnitTest, Gwen::Controls::WindowControl ); - - void PrintText( const Gwen::UnicodeString& str ); - - void Render( Gwen::Skin::Base* skin ); - - - private: - - Gwen::Controls::TabControl* m_TabControl; - Gwen::Controls::ListBox* m_TextOutput; - unsigned int m_iFrames; - float m_fLastSecond; - -}; - -#define DEFINE_UNIT_TEST( name, displayname ) GUnit* RegisterUnitTest_##name( Gwen::Controls::TabControl* tab ){ GUnit* u = new name( tab ); tab->AddPage( displayname, u ); return u; } -#endif diff --git a/btgui/GwenOpenGLTest/premake4.lua b/btgui/GwenOpenGLTest/premake4.lua deleted file mode 100644 index 076fea3de..000000000 --- a/btgui/GwenOpenGLTest/premake4.lua +++ /dev/null @@ -1,68 +0,0 @@ - - project "Test_Gwen_OpenGL" - - kind "ConsoleApp" - flags {"Unicode"} - - defines { "GWEN_COMPILE_STATIC" , "_HAS_EXCEPTIONS=0", "_STATIC_CPPLIB" } - defines { "DONT_USE_GLUT"} - - targetdir "../../bin" - - includedirs - { - - "..", - ".", - } - - initOpenGL() - initGlew() - - links { - "gwen", - } - - - files { - "../OpenGLWindow/OpenSans.cpp", - "../OpenGLWindow/TwFonts.cpp", - "../OpenGLWindow/TwFonts.h", - "../OpenGLWindow/LoadShader.cpp", - "../OpenGLWindow/LoadShader.h", - "../OpenGLWindow/GLPrimitiveRenderer.cpp", - "../OpenGLWindow/GLPrimitiveRenderer.h", - "../OpenGLWindow/GwenOpenGL3CoreRenderer.h", - "../OpenGLWindow/fontstash.cpp", - "../OpenGLWindow/fontstash.h", - "../OpenGLWindow/opengl_fontstashcallbacks.cpp", - "../OpenGLWindow/opengl_fontstashcallbacks.h", - "../Bullet3AppSupport/b3Clock.cpp", - "../Bullet3AppSupport/b3Clock.h", - "**.cpp", - "**.h", - } - if os.is("Windows") then - files { - "../OpenGLWindow/Win32OpenGLWindow.cpp", - "../OpenGLWindow/Win32OpenGLWindow.h", - "../OpenGLWindow/Win32Window.cpp", - "../OpenGLWindow/Win32Window.h", - } - end - if os.is("Linux") then - initX11() - files{ - "../OpenGLWindow/X11OpenGLWindow.h", - "../OpenGLWindow/X11OpenGLWindow.cpp" - } - links{"pthread"} - end - if os.is("MacOSX") then - links{"Cocoa.framework"} -print("hello!") - files{ - "../OpenGLWindow/MacOpenGLWindow.mm", - "../OpenGLWindow/MacOpenGLWindow.h", - } - end diff --git a/btgui/MidiTest/LICENSE.txt b/btgui/MidiTest/LICENSE.txt deleted file mode 100644 index 5b85f871c..000000000 --- a/btgui/MidiTest/LICENSE.txt +++ /dev/null @@ -1,29 +0,0 @@ - RtMidi WWW site: http://music.mcgill.ca/~gary/rtmidi/ - - RtMidi: realtime MIDI i/o C++ classes - Copyright (c) 2003-2012 Gary P. Scavone - - Permission is hereby granted, free of charge, to any person - obtaining a copy of this software and associated documentation files - (the "Software"), to deal in the Software without restriction, - including without limitation the rights to use, copy, modify, merge, - publish, distribute, sublicense, and/or sell copies of the Software, - and to permit persons to whom the Software is furnished to do so, - subject to the following conditions: - - The above copyright notice and this permission notice shall be - included in all copies or substantial portions of the Software. - - Any person wishing to distribute modifications to the Software is - asked to send the modifications to the original developer so that - they can be incorporated into the canonical version. This is, - however, not a binding provision of this license. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -*/ \ No newline at end of file diff --git a/btgui/MidiTest/RtError.h b/btgui/MidiTest/RtError.h deleted file mode 100644 index a64f43430..000000000 --- a/btgui/MidiTest/RtError.h +++ /dev/null @@ -1,60 +0,0 @@ -/************************************************************************/ -/*! \class RtError - \brief Exception handling class for RtAudio & RtMidi. - - The RtError class is quite simple but it does allow errors to be - "caught" by RtError::Type. See the RtAudio and RtMidi - documentation to know which methods can throw an RtError. - -*/ -/************************************************************************/ - -#ifndef RTERROR_H -#define RTERROR_H - -#include -#include -#include - -class RtError : public std::exception -{ - public: - //! Defined RtError types. - enum Type { - WARNING, /*!< A non-critical error. */ - DEBUG_WARNING, /*!< A non-critical error which might be useful for debugging. */ - UNSPECIFIED, /*!< The default, unspecified error type. */ - NO_DEVICES_FOUND, /*!< No devices found on system. */ - INVALID_DEVICE, /*!< An invalid device ID was specified. */ - MEMORY_ERROR, /*!< An error occured during memory allocation. */ - INVALID_PARAMETER, /*!< An invalid parameter was specified to a function. */ - INVALID_USE, /*!< The function was called incorrectly. */ - DRIVER_ERROR, /*!< A system driver error occured. */ - SYSTEM_ERROR, /*!< A system error occured. */ - THREAD_ERROR /*!< A thread error occured. */ - }; - - //! The constructor. - RtError( const std::string& message, Type type = RtError::UNSPECIFIED ) throw() : message_(message), type_(type) {} - - //! The destructor. - virtual ~RtError( void ) throw() {} - - //! Prints thrown error message to stderr. - virtual void printMessage( void ) const throw() { std::cerr << '\n' << message_ << "\n\n"; } - - //! Returns the thrown error message type. - virtual const Type& getType(void) const throw() { return type_; } - - //! Returns the thrown error message string. - virtual const std::string& getMessage(void) const throw() { return message_; } - - //! Returns the thrown error message as a c-style string. - virtual const char* what( void ) const throw() { return message_.c_str(); } - - protected: - std::string message_; - Type type_; -}; - -#endif diff --git a/btgui/MidiTest/RtMidi.cpp b/btgui/MidiTest/RtMidi.cpp deleted file mode 100644 index 0789d4d66..000000000 --- a/btgui/MidiTest/RtMidi.cpp +++ /dev/null @@ -1,3803 +0,0 @@ -/**********************************************************************/ -/*! \class RtMidi - \brief An abstract base class for realtime MIDI input/output. - - This class implements some common functionality for the realtime - MIDI input/output subclasses RtMidiIn and RtMidiOut. - - RtMidi WWW site: http://music.mcgill.ca/~gary/rtmidi/ - - RtMidi: realtime MIDI i/o C++ classes - Copyright (c) 2003-2012 Gary P. Scavone - - Permission is hereby granted, free of charge, to any person - obtaining a copy of this software and associated documentation files - (the "Software"), to deal in the Software without restriction, - including without limitation the rights to use, copy, modify, merge, - publish, distribute, sublicense, and/or sell copies of the Software, - and to permit persons to whom the Software is furnished to do so, - subject to the following conditions: - - The above copyright notice and this permission notice shall be - included in all copies or substantial portions of the Software. - - Any person wishing to distribute modifications to the Software is - asked to send the modifications to the original developer so that - they can be incorporated into the canonical version. This is, - however, not a binding provision of this license. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -*/ -/**********************************************************************/ - -// RtMidi: Version 2.0.1 - -#include "RtMidi.h" -#include -#include //exit - -//*********************************************************************// -// RtMidi Definitions -//*********************************************************************// - -void RtMidi :: getCompiledApi( std::vector &apis ) -{ - apis.clear(); - - // The order here will control the order of RtMidi's API search in - // the constructor. -#if defined(__MACOSX_CORE__) - apis.push_back( MACOSX_CORE ); -#endif -#if defined(__LINUX_ALSA__) - apis.push_back( LINUX_ALSA ); -#endif -#if defined(__UNIX_JACK__) - apis.push_back( UNIX_JACK ); -#endif -#if defined(__WINDOWS_MM__) - apis.push_back( WINDOWS_MM ); -#endif -#if defined(__WINDOWS_KS__) - apis.push_back( WINDOWS_KS ); -#endif -#if defined(__RTMIDI_DUMMY__) - apis.push_back( RTMIDI_DUMMY ); -#endif - -} - -void RtMidi :: error( RtError::Type type, std::string errorString ) -{ - if (type == RtError::WARNING) { - std::cerr << '\n' << errorString << "\n\n"; - } - else if (type == RtError::DEBUG_WARNING) { -#if defined(__RTMIDI_DEBUG__) - std::cerr << '\n' << errorString << "\n\n"; -#endif - } - else { - std::cerr << '\n' << errorString << "\n\n"; - exit(0); - } -} - -//*********************************************************************// -// RtMidiIn Definitions -//*********************************************************************// - -void RtMidiIn :: openMidiApi( RtMidi::Api api, const std::string clientName, unsigned int queueSizeLimit ) -{ - if ( rtapi_ ) - delete rtapi_; - rtapi_ = 0; - -#if defined(__UNIX_JACK__) - if ( api == UNIX_JACK ) - rtapi_ = new MidiInJack( clientName, queueSizeLimit ); -#endif -#if defined(__LINUX_ALSA__) - if ( api == LINUX_ALSA ) - rtapi_ = new MidiInAlsa( clientName, queueSizeLimit ); -#endif -#if defined(__WINDOWS_MM__) - if ( api == WINDOWS_MM ) - rtapi_ = new MidiInWinMM( clientName, queueSizeLimit ); -#endif -#if defined(__WINDOWS_KS__) - if ( api == WINDOWS_KS ) - rtapi_ = new MidiInWinKS( clientName, queueSizeLimit ); -#endif -#if defined(__MACOSX_CORE__) - if ( api == MACOSX_CORE ) - rtapi_ = new MidiInCore( clientName, queueSizeLimit ); -#endif -#if defined(__RTMIDI_DUMMY__) - if ( api == RTMIDI_DUMMY ) - rtapi_ = new MidiInDummy( clientName, queueSizeLimit ); -#endif -} - -RtMidiIn :: RtMidiIn( RtMidi::Api api, const std::string clientName, unsigned int queueSizeLimit ) -{ - rtapi_ = 0; - - if ( api != UNSPECIFIED ) { - // Attempt to open the specified API. - openMidiApi( api, clientName, queueSizeLimit ); - if ( rtapi_ ) return; - - // No compiled support for specified API value. Issue a debug - // warning and continue as if no API was specified. - RtMidi::error( RtError::WARNING, "RtMidiIn: no compiled support for specified API argument!" ); - } - - // Iterate through the compiled APIs and return as soon as we find - // one with at least one port or we reach the end of the list. - std::vector< RtMidi::Api > apis; - getCompiledApi( apis ); - for ( unsigned int i=0; igetPortCount() ) break; - } - - if ( rtapi_ ) return; - - // It should not be possible to get here because the preprocessor - // definition __RTMIDI_DUMMY__ is automatically defined if no - // API-specific definitions are passed to the compiler. But just in - // case something weird happens, we'll print out an error message. - RtMidi::error( RtError::WARNING, "RtMidiIn: no compiled API support found ... critical error!!" ); -} - -RtMidiIn :: ~RtMidiIn() -{ - delete rtapi_; -} - - -//*********************************************************************// -// RtMidiOut Definitions -//*********************************************************************// - -void RtMidiOut :: openMidiApi( RtMidi::Api api, const std::string clientName ) -{ - if ( rtapi_ ) - delete rtapi_; - rtapi_ = 0; - -#if defined(__UNIX_JACK__) - if ( api == UNIX_JACK ) - rtapi_ = new MidiOutJack( clientName ); -#endif -#if defined(__LINUX_ALSA__) - if ( api == LINUX_ALSA ) - rtapi_ = new MidiOutAlsa( clientName ); -#endif -#if defined(__WINDOWS_MM__) - if ( api == WINDOWS_MM ) - rtapi_ = new MidiOutWinMM( clientName ); -#endif -#if defined(__WINDOWS_KS__) - if ( api == WINDOWS_KS ) - rtapi_ = new MidiOutWinKS( clientName ); -#endif -#if defined(__MACOSX_CORE__) - if ( api == MACOSX_CORE ) - rtapi_ = new MidiOutCore( clientName ); -#endif -#if defined(__RTMIDI_DUMMY__) - if ( api == RTMIDI_DUMMY ) - rtapi_ = new MidiOutDummy( clientName ); -#endif -} - -RtMidiOut :: RtMidiOut( RtMidi::Api api, const std::string clientName ) -{ - rtapi_ = 0; - - if ( api != UNSPECIFIED ) { - // Attempt to open the specified API. - openMidiApi( api, clientName ); - if ( rtapi_ ) return; - - // No compiled support for specified API value. Issue a debug - // warning and continue as if no API was specified. - RtMidi::error( RtError::WARNING, "RtMidiOut: no compiled support for specified API argument!" ); - } - - // Iterate through the compiled APIs and return as soon as we find - // one with at least one port or we reach the end of the list. - std::vector< RtMidi::Api > apis; - getCompiledApi( apis ); - for ( unsigned int i=0; igetPortCount() ) break; - } - - if ( rtapi_ ) return; - - // It should not be possible to get here because the preprocessor - // definition __RTMIDI_DUMMY__ is automatically defined if no - // API-specific definitions are passed to the compiler. But just in - // case something weird happens, we'll print out an error message. - RtMidi::error( RtError::WARNING, "RtMidiOut: no compiled API support found ... critical error!!" ); -} - -RtMidiOut :: ~RtMidiOut() -{ - delete rtapi_; -} - -//*********************************************************************// -// Common MidiInApi Definitions -//*********************************************************************// - -MidiInApi :: MidiInApi( unsigned int queueSizeLimit ) - : apiData_( 0 ), connected_( false ) -{ - // Allocate the MIDI queue. - inputData_.queue.ringSize = queueSizeLimit; - if ( inputData_.queue.ringSize > 0 ) - inputData_.queue.ring = new MidiMessage[ inputData_.queue.ringSize ]; -} - -MidiInApi :: ~MidiInApi( void ) -{ - // Delete the MIDI queue. - if ( inputData_.queue.ringSize > 0 ) delete [] inputData_.queue.ring; -} - -void MidiInApi :: setCallback( RtMidiIn::RtMidiCallback callback, void *userData ) -{ - if ( inputData_.usingCallback ) { - errorString_ = "MidiInApi::setCallback: a callback function is already set!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - if ( !callback ) { - errorString_ = "RtMidiIn::setCallback: callback function value is invalid!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - inputData_.userCallback = (void *) callback; - inputData_.userData = userData; - inputData_.usingCallback = true; -} - -void MidiInApi :: cancelCallback() -{ - if ( !inputData_.usingCallback ) { - errorString_ = "RtMidiIn::cancelCallback: no callback function was set!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - inputData_.userCallback = 0; - inputData_.userData = 0; - inputData_.usingCallback = false; -} - -void MidiInApi :: ignoreTypes( bool midiSysex, bool midiTime, bool midiSense ) -{ - inputData_.ignoreFlags = 0; - if ( midiSysex ) inputData_.ignoreFlags = 0x01; - if ( midiTime ) inputData_.ignoreFlags |= 0x02; - if ( midiSense ) inputData_.ignoreFlags |= 0x04; -} - -double MidiInApi :: getMessage( std::vector *message ) -{ - message->clear(); - - if ( inputData_.usingCallback ) { - errorString_ = "RtMidiIn::getNextMessage: a user callback is currently set for this port."; - RtMidi::error( RtError::WARNING, errorString_ ); - return 0.0; - } - - if ( inputData_.queue.size == 0 ) return 0.0; - - // Copy queued message to the vector pointer argument and then "pop" it. - std::vector *bytes = &(inputData_.queue.ring[inputData_.queue.front].bytes); - message->assign( bytes->begin(), bytes->end() ); - double deltaTime = inputData_.queue.ring[inputData_.queue.front].timeStamp; - inputData_.queue.size--; - inputData_.queue.front++; - if ( inputData_.queue.front == inputData_.queue.ringSize ) - inputData_.queue.front = 0; - - return deltaTime; -} - -//*********************************************************************// -// Common MidiOutApi Definitions -//*********************************************************************// - -MidiOutApi :: MidiOutApi( void ) - : apiData_( 0 ), connected_( false ) -{ -} - -MidiOutApi :: ~MidiOutApi( void ) -{ -} - -// *************************************************** // -// -// OS/API-specific methods. -// -// *************************************************** // - -#if defined(__MACOSX_CORE__) - -// The CoreMIDI API is based on the use of a callback function for -// MIDI input. We convert the system specific time stamps to delta -// time values. - -// OS-X CoreMIDI header files. -#include -#include -#include - -// A structure to hold variables related to the CoreMIDI API -// implementation. -struct CoreMidiData { - MIDIClientRef client; - MIDIPortRef port; - MIDIEndpointRef endpoint; - MIDIEndpointRef destinationId; - unsigned long long lastTime; - MIDISysexSendRequest sysexreq; -}; - -//*********************************************************************// -// API: OS-X -// Class Definitions: MidiInCore -//*********************************************************************// - -void midiInputCallback( const MIDIPacketList *list, void *procRef, void *srcRef ) -{ - MidiInApi::RtMidiInData *data = static_cast (procRef); - CoreMidiData *apiData = static_cast (data->apiData); - - unsigned char status; - unsigned short nBytes, iByte, size; - unsigned long long time; - - bool& continueSysex = data->continueSysex; - MidiInApi::MidiMessage& message = data->message; - - const MIDIPacket *packet = &list->packet[0]; - for ( unsigned int i=0; inumPackets; ++i ) { - - // My interpretation of the CoreMIDI documentation: all message - // types, except sysex, are complete within a packet and there may - // be several of them in a single packet. Sysex messages can be - // broken across multiple packets and PacketLists but are bundled - // alone within each packet (these packets do not contain other - // message types). If sysex messages are split across multiple - // MIDIPacketLists, they must be handled by multiple calls to this - // function. - - nBytes = packet->length; - if ( nBytes == 0 ) continue; - - // Calculate time stamp. - - if ( data->firstMessage ) { - message.timeStamp = 0.0; - data->firstMessage = false; - } - else { - time = packet->timeStamp; - if ( time == 0 ) { // this happens when receiving asynchronous sysex messages - time = AudioGetCurrentHostTime(); - } - time -= apiData->lastTime; - time = AudioConvertHostTimeToNanos( time ); - if ( !continueSysex ) - message.timeStamp = time * 0.000000001; - } - apiData->lastTime = packet->timeStamp; - if ( apiData->lastTime == 0 ) { // this happens when receiving asynchronous sysex messages - apiData->lastTime = AudioGetCurrentHostTime(); - } - //std::cout << "TimeStamp = " << packet->timeStamp << std::endl; - - iByte = 0; - if ( continueSysex ) { - // We have a continuing, segmented sysex message. - if ( !( data->ignoreFlags & 0x01 ) ) { - // If we're not ignoring sysex messages, copy the entire packet. - for ( unsigned int j=0; jdata[j] ); - } - continueSysex = packet->data[nBytes-1] != 0xF7; - - if ( !continueSysex ) { - // If not a continuing sysex message, invoke the user callback function or queue the message. - if ( data->usingCallback ) { - RtMidiIn::RtMidiCallback callback = (RtMidiIn::RtMidiCallback) data->userCallback; - callback( message.timeStamp, &message.bytes, data->userData ); - } - else { - // As long as we haven't reached our queue size limit, push the message. - if ( data->queue.size < data->queue.ringSize ) { - data->queue.ring[data->queue.back++] = message; - if ( data->queue.back == data->queue.ringSize ) - data->queue.back = 0; - data->queue.size++; - } - else - std::cerr << "\nMidiInCore: message queue limit reached!!\n\n"; - } - message.bytes.clear(); - } - } - else { - while ( iByte < nBytes ) { - size = 0; - // We are expecting that the next byte in the packet is a status byte. - status = packet->data[iByte]; - if ( !(status & 0x80) ) break; - // Determine the number of bytes in the MIDI message. - if ( status < 0xC0 ) size = 3; - else if ( status < 0xE0 ) size = 2; - else if ( status < 0xF0 ) size = 3; - else if ( status == 0xF0 ) { - // A MIDI sysex - if ( data->ignoreFlags & 0x01 ) { - size = 0; - iByte = nBytes; - } - else size = nBytes - iByte; - continueSysex = packet->data[nBytes-1] != 0xF7; - } - else if ( status == 0xF1 ) { - // A MIDI time code message - if ( data->ignoreFlags & 0x02 ) { - size = 0; - iByte += 2; - } - else size = 2; - } - else if ( status == 0xF2 ) size = 3; - else if ( status == 0xF3 ) size = 2; - else if ( status == 0xF8 && ( data->ignoreFlags & 0x02 ) ) { - // A MIDI timing tick message and we're ignoring it. - size = 0; - iByte += 1; - } - else if ( status == 0xFE && ( data->ignoreFlags & 0x04 ) ) { - // A MIDI active sensing message and we're ignoring it. - size = 0; - iByte += 1; - } - else size = 1; - - // Copy the MIDI data to our vector. - if ( size ) { - message.bytes.assign( &packet->data[iByte], &packet->data[iByte+size] ); - if ( !continueSysex ) { - // If not a continuing sysex message, invoke the user callback function or queue the message. - if ( data->usingCallback ) { - RtMidiIn::RtMidiCallback callback = (RtMidiIn::RtMidiCallback) data->userCallback; - callback( message.timeStamp, &message.bytes, data->userData ); - } - else { - // As long as we haven't reached our queue size limit, push the message. - if ( data->queue.size < data->queue.ringSize ) { - data->queue.ring[data->queue.back++] = message; - if ( data->queue.back == data->queue.ringSize ) - data->queue.back = 0; - data->queue.size++; - } - else - std::cerr << "\nMidiInCore: message queue limit reached!!\n\n"; - } - message.bytes.clear(); - } - iByte += size; - } - } - } - packet = MIDIPacketNext(packet); - } -} - -MidiInCore :: MidiInCore( const std::string clientName, unsigned int queueSizeLimit ) : MidiInApi( queueSizeLimit ) -{ - initialize( clientName ); -} - -MidiInCore :: ~MidiInCore( void ) -{ - // Close a connection if it exists. - closePort(); - - // Cleanup. - CoreMidiData *data = static_cast (apiData_); - MIDIClientDispose( data->client ); - if ( data->endpoint ) MIDIEndpointDispose( data->endpoint ); - delete data; -} - -void MidiInCore :: initialize( const std::string& clientName ) -{ - // Set up our client. - MIDIClientRef client; - OSStatus result = MIDIClientCreate( CFStringCreateWithCString( NULL, clientName.c_str(), kCFStringEncodingASCII ), NULL, NULL, &client ); - if ( result != noErr ) { - errorString_ = "MidiInCore::initialize: error creating OS-X MIDI client object."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - CoreMidiData *data = (CoreMidiData *) new CoreMidiData; - data->client = client; - data->endpoint = 0; - apiData_ = (void *) data; - inputData_.apiData = (void *) data; -} - -void MidiInCore :: openPort( unsigned int portNumber, const std::string portName ) -{ - if ( connected_ ) { - errorString_ = "MidiInCore::openPort: a valid connection already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - unsigned int nSrc = MIDIGetNumberOfSources(); - if (nSrc < 1) { - errorString_ = "MidiInCore::openPort: no MIDI input sources found!"; - RtMidi::error( RtError::NO_DEVICES_FOUND, errorString_ ); - } - - std::ostringstream ost; - if ( portNumber >= nSrc ) { - ost << "MidiInCore::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - MIDIPortRef port; - CoreMidiData *data = static_cast (apiData_); - OSStatus result = MIDIInputPortCreate( data->client, - CFStringCreateWithCString( NULL, portName.c_str(), kCFStringEncodingASCII ), - midiInputCallback, (void *)&inputData_, &port ); - if ( result != noErr ) { - MIDIClientDispose( data->client ); - errorString_ = "MidiInCore::openPort: error creating OS-X MIDI input port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Get the desired input source identifier. - MIDIEndpointRef endpoint = MIDIGetSource( portNumber ); - if ( endpoint == 0 ) { - MIDIPortDispose( port ); - MIDIClientDispose( data->client ); - errorString_ = "MidiInCore::openPort: error getting MIDI input source reference."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Make the connection. - result = MIDIPortConnectSource( port, endpoint, NULL ); - if ( result != noErr ) { - MIDIPortDispose( port ); - MIDIClientDispose( data->client ); - errorString_ = "MidiInCore::openPort: error connecting OS-X MIDI input port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific port information. - data->port = port; - - connected_ = true; -} - -void MidiInCore :: openVirtualPort( const std::string portName ) -{ - CoreMidiData *data = static_cast (apiData_); - - // Create a virtual MIDI input destination. - MIDIEndpointRef endpoint; - OSStatus result = MIDIDestinationCreate( data->client, - CFStringCreateWithCString( NULL, portName.c_str(), kCFStringEncodingASCII ), - midiInputCallback, (void *)&inputData_, &endpoint ); - if ( result != noErr ) { - errorString_ = "MidiInCore::openVirtualPort: error creating virtual OS-X MIDI destination."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - data->endpoint = endpoint; -} - -void MidiInCore :: closePort( void ) -{ - if ( connected_ ) { - CoreMidiData *data = static_cast (apiData_); - MIDIPortDispose( data->port ); - connected_ = false; - } -} - -unsigned int MidiInCore :: getPortCount() -{ - return MIDIGetNumberOfSources(); -} - -// This function was submitted by Douglas Casey Tucker and apparently -// derived largely from PortMidi. -CFStringRef EndpointName( MIDIEndpointRef endpoint, bool isExternal ) -{ - CFMutableStringRef result = CFStringCreateMutable( NULL, 0 ); - CFStringRef str; - - // Begin with the endpoint's name. - str = NULL; - MIDIObjectGetStringProperty( endpoint, kMIDIPropertyName, &str ); - if ( str != NULL ) { - CFStringAppend( result, str ); - CFRelease( str ); - } - - MIDIEntityRef entity = NULL; - MIDIEndpointGetEntity( endpoint, &entity ); - if ( entity == 0 ) - // probably virtual - return result; - - if ( CFStringGetLength( result ) == 0 ) { - // endpoint name has zero length -- try the entity - str = NULL; - MIDIObjectGetStringProperty( entity, kMIDIPropertyName, &str ); - if ( str != NULL ) { - CFStringAppend( result, str ); - CFRelease( str ); - } - } - // now consider the device's name - MIDIDeviceRef device = 0; - MIDIEntityGetDevice( entity, &device ); - if ( device == 0 ) - return result; - - str = NULL; - MIDIObjectGetStringProperty( device, kMIDIPropertyName, &str ); - if ( CFStringGetLength( result ) == 0 ) { - CFRelease( result ); - return str; - } - if ( str != NULL ) { - // if an external device has only one entity, throw away - // the endpoint name and just use the device name - if ( isExternal && MIDIDeviceGetNumberOfEntities( device ) < 2 ) { - CFRelease( result ); - return str; - } else { - if ( CFStringGetLength( str ) == 0 ) { - CFRelease( str ); - return result; - } - // does the entity name already start with the device name? - // (some drivers do this though they shouldn't) - // if so, do not prepend - if ( CFStringCompareWithOptions( result, /* endpoint name */ - str /* device name */, - CFRangeMake(0, CFStringGetLength( str ) ), 0 ) != kCFCompareEqualTo ) { - // prepend the device name to the entity name - if ( CFStringGetLength( result ) > 0 ) - CFStringInsert( result, 0, CFSTR(" ") ); - CFStringInsert( result, 0, str ); - } - CFRelease( str ); - } - } - return result; -} - -// This function was submitted by Douglas Casey Tucker and apparently -// derived largely from PortMidi. -static CFStringRef ConnectedEndpointName( MIDIEndpointRef endpoint ) -{ - CFMutableStringRef result = CFStringCreateMutable( NULL, 0 ); - CFStringRef str; - OSStatus err; - int i; - - // Does the endpoint have connections? - CFDataRef connections = NULL; - int nConnected = 0; - bool anyStrings = false; - err = MIDIObjectGetDataProperty( endpoint, kMIDIPropertyConnectionUniqueID, &connections ); - if ( connections != NULL ) { - // It has connections, follow them - // Concatenate the names of all connected devices - nConnected = CFDataGetLength( connections ) / sizeof(MIDIUniqueID); - if ( nConnected ) { - const SInt32 *pid = (const SInt32 *)(CFDataGetBytePtr(connections)); - for ( i=0; i= MIDIGetNumberOfSources() ) { - ost << "MidiInCore::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - //RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - return stringName; - } - - portRef = MIDIGetSource( portNumber ); - nameRef = ConnectedEndpointName(portRef); - CFStringGetCString( nameRef, name, sizeof(name), 0); - CFRelease( nameRef ); - - return stringName = name; -} - -//*********************************************************************// -// API: OS-X -// Class Definitions: MidiOutCore -//*********************************************************************// - -MidiOutCore :: MidiOutCore( const std::string clientName ) : MidiOutApi() -{ - initialize( clientName ); -} - -MidiOutCore :: ~MidiOutCore( void ) -{ - // Close a connection if it exists. - closePort(); - - // Cleanup. - CoreMidiData *data = static_cast (apiData_); - MIDIClientDispose( data->client ); - if ( data->endpoint ) MIDIEndpointDispose( data->endpoint ); - delete data; -} - -void MidiOutCore :: initialize( const std::string& clientName ) -{ - // Set up our client. - MIDIClientRef client; - OSStatus result = MIDIClientCreate( CFStringCreateWithCString( NULL, clientName.c_str(), kCFStringEncodingASCII ), NULL, NULL, &client ); - if ( result != noErr ) { - errorString_ = "MidiOutCore::initialize: error creating OS-X MIDI client object."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - CoreMidiData *data = (CoreMidiData *) new CoreMidiData; - data->client = client; - data->endpoint = 0; - apiData_ = (void *) data; -} - -unsigned int MidiOutCore :: getPortCount() -{ - return MIDIGetNumberOfDestinations(); -} - -std::string MidiOutCore :: getPortName( unsigned int portNumber ) -{ - CFStringRef nameRef; - MIDIEndpointRef portRef; - std::ostringstream ost; - char name[128]; - - std::string stringName; - if ( portNumber >= MIDIGetNumberOfDestinations() ) { - ost << "MidiOutCore::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - return stringName; - //RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - portRef = MIDIGetDestination( portNumber ); - nameRef = ConnectedEndpointName(portRef); - CFStringGetCString( nameRef, name, sizeof(name), 0); - CFRelease( nameRef ); - - return stringName = name; -} - -void MidiOutCore :: openPort( unsigned int portNumber, const std::string portName ) -{ - if ( connected_ ) { - errorString_ = "MidiOutCore::openPort: a valid connection already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - unsigned int nDest = MIDIGetNumberOfDestinations(); - if (nDest < 1) { - errorString_ = "MidiOutCore::openPort: no MIDI output destinations found!"; - RtMidi::error( RtError::NO_DEVICES_FOUND, errorString_ ); - } - - std::ostringstream ost; - if ( portNumber >= nDest ) { - ost << "MidiOutCore::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - MIDIPortRef port; - CoreMidiData *data = static_cast (apiData_); - OSStatus result = MIDIOutputPortCreate( data->client, - CFStringCreateWithCString( NULL, portName.c_str(), kCFStringEncodingASCII ), - &port ); - if ( result != noErr ) { - MIDIClientDispose( data->client ); - errorString_ = "MidiOutCore::openPort: error creating OS-X MIDI output port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Get the desired output port identifier. - MIDIEndpointRef destination = MIDIGetDestination( portNumber ); - if ( destination == 0 ) { - MIDIPortDispose( port ); - MIDIClientDispose( data->client ); - errorString_ = "MidiOutCore::openPort: error getting MIDI output destination reference."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - data->port = port; - data->destinationId = destination; - connected_ = true; -} - -void MidiOutCore :: closePort( void ) -{ - if ( connected_ ) { - CoreMidiData *data = static_cast (apiData_); - MIDIPortDispose( data->port ); - connected_ = false; - } -} - -void MidiOutCore :: openVirtualPort( std::string portName ) -{ - CoreMidiData *data = static_cast (apiData_); - - if ( data->endpoint ) { - errorString_ = "MidiOutCore::openVirtualPort: a virtual output port already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - // Create a virtual MIDI output source. - MIDIEndpointRef endpoint; - OSStatus result = MIDISourceCreate( data->client, - CFStringCreateWithCString( NULL, portName.c_str(), kCFStringEncodingASCII ), - &endpoint ); - if ( result != noErr ) { - errorString_ = "MidiOutCore::initialize: error creating OS-X virtual MIDI source."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - data->endpoint = endpoint; -} - -char *sysexBuffer = 0; - -void sysexCompletionProc( MIDISysexSendRequest * sreq ) -{ - //std::cout << "Completed SysEx send\n"; - delete sysexBuffer; - sysexBuffer = 0; -} - -void MidiOutCore :: sendMessage( std::vector *message ) -{ - // We use the MIDISendSysex() function to asynchronously send sysex - // messages. Otherwise, we use a single CoreMidi MIDIPacket. - unsigned int nBytes = message->size(); - if ( nBytes == 0 ) { - errorString_ = "MidiOutCore::sendMessage: no data in message argument!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - // unsigned int packetBytes, bytesLeft = nBytes; - // unsigned int messageIndex = 0; - MIDITimeStamp timeStamp = AudioGetCurrentHostTime(); - CoreMidiData *data = static_cast (apiData_); - OSStatus result; - - if ( message->at(0) == 0xF0 ) { - - while ( sysexBuffer != 0 ) usleep( 1000 ); // sleep 1 ms - - sysexBuffer = new char[nBytes]; - if ( sysexBuffer == NULL ) { - errorString_ = "MidiOutCore::sendMessage: error allocating sysex message memory!"; - RtMidi::error( RtError::MEMORY_ERROR, errorString_ ); - } - - // Copy data to buffer. - for ( unsigned int i=0; iat(i); - - data->sysexreq.destination = data->destinationId; - data->sysexreq.data = (Byte *)sysexBuffer; - data->sysexreq.bytesToSend = nBytes; - data->sysexreq.complete = 0; - data->sysexreq.completionProc = sysexCompletionProc; - data->sysexreq.completionRefCon = &(data->sysexreq); - - result = MIDISendSysex( &(data->sysexreq) ); - if ( result != noErr ) { - errorString_ = "MidiOutCore::sendMessage: error sending MIDI to virtual destinations."; - RtMidi::error( RtError::WARNING, errorString_ ); - } - return; - } - else if ( nBytes > 3 ) { - errorString_ = "MidiOutCore::sendMessage: message format problem ... not sysex but > 3 bytes?"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - MIDIPacketList packetList; - MIDIPacket *packet = MIDIPacketListInit( &packetList ); - packet = MIDIPacketListAdd( &packetList, sizeof(packetList), packet, timeStamp, nBytes, (const Byte *) &message->at( 0 ) ); - if ( !packet ) { - errorString_ = "MidiOutCore::sendMessage: could not allocate packet list"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Send to any destinations that may have connected to us. - if ( data->endpoint ) { - result = MIDIReceived( data->endpoint, &packetList ); - if ( result != noErr ) { - errorString_ = "MidiOutCore::sendMessage: error sending MIDI to virtual destinations."; - RtMidi::error( RtError::WARNING, errorString_ ); - } - } - - // And send to an explicit destination port if we're connected. - if ( connected_ ) { - result = MIDISend( data->port, data->destinationId, &packetList ); - if ( result != noErr ) { - errorString_ = "MidiOutCore::sendMessage: error sending MIDI message to port."; - RtMidi::error( RtError::WARNING, errorString_ ); - } - } - -} - -#endif // __MACOSX_CORE__ - - -//*********************************************************************// -// API: LINUX ALSA SEQUENCER -//*********************************************************************// - -// API information found at: -// - http://www.alsa-project.org/documentation.php#Library - -#if defined(__LINUX_ALSA__) - -// The ALSA Sequencer API is based on the use of a callback function for -// MIDI input. -// -// Thanks to Pedro Lopez-Cabanillas for help with the ALSA sequencer -// time stamps and other assorted fixes!!! - -// If you don't need timestamping for incoming MIDI events, define the -// preprocessor definition AVOID_TIMESTAMPING to save resources -// associated with the ALSA sequencer queues. - -#include -#include - -// ALSA header file. -#include - -// Global sequencer instance created when first In/Out object is -// created, then destroyed when last In/Out is deleted. -static snd_seq_t *s_seq = NULL; - -// Variable to keep track of how many ports are open. -static unsigned int s_numPorts = 0; - -// The client name to use when creating the sequencer, which is -// currently set on the first call to createSequencer. -static std::string s_clientName = "RtMidi Client"; - -// A structure to hold variables related to the ALSA API -// implementation. -struct AlsaMidiData { - snd_seq_t *seq; - unsigned int portNum; - int vport; - snd_seq_port_subscribe_t *subscription; - snd_midi_event_t *coder; - unsigned int bufferSize; - unsigned char *buffer; - pthread_t thread; - pthread_t dummy_thread_id; - unsigned long long lastTime; - int queue_id; // an input queue is needed to get timestamped events - int trigger_fds[2]; -}; - -#define PORT_TYPE( pinfo, bits ) ((snd_seq_port_info_get_capability(pinfo) & (bits)) == (bits)) - -snd_seq_t* createSequencer( const std::string& clientName ) -{ - // Set up the ALSA sequencer client. - if ( s_seq == NULL ) { - int result = snd_seq_open(&s_seq, "default", SND_SEQ_OPEN_DUPLEX, SND_SEQ_NONBLOCK); - if ( result < 0 ) { - s_seq = NULL; - } - else { - // Set client name, use current name if given string is empty. - if ( clientName != "" ) { - s_clientName = clientName; - } - snd_seq_set_client_name( s_seq, s_clientName.c_str() ); - } - } - - // Increment port count. - s_numPorts++; - - return s_seq; -} - -void freeSequencer ( void ) -{ - s_numPorts--; - if ( s_numPorts == 0 && s_seq != NULL ) { - snd_seq_close( s_seq ); - s_seq = NULL; - } -} - -//*********************************************************************// -// API: LINUX ALSA -// Class Definitions: MidiInAlsa -//*********************************************************************// - -extern "C" void *alsaMidiHandler( void *ptr ) -{ - MidiInApi::RtMidiInData *data = static_cast (ptr); - AlsaMidiData *apiData = static_cast (data->apiData); - - long nBytes; - unsigned long long time, lastTime; - bool continueSysex = false; - bool doDecode = false; - MidiInApi::MidiMessage message; - int poll_fd_count; - struct pollfd *poll_fds; - - snd_seq_event_t *ev; - int result; - apiData->bufferSize = 32; - result = snd_midi_event_new( 0, &apiData->coder ); - if ( result < 0 ) { - data->doInput = false; - std::cerr << "\nMidiInAlsa::alsaMidiHandler: error initializing MIDI event parser!\n\n"; - return 0; - } - unsigned char *buffer = (unsigned char *) malloc( apiData->bufferSize ); - if ( buffer == NULL ) { - data->doInput = false; - snd_midi_event_free( apiData->coder ); - apiData->coder = 0; - std::cerr << "\nMidiInAlsa::alsaMidiHandler: error initializing buffer memory!\n\n"; - return 0; - } - snd_midi_event_init( apiData->coder ); - snd_midi_event_no_status( apiData->coder, 1 ); // suppress running status messages - - poll_fd_count = snd_seq_poll_descriptors_count( apiData->seq, POLLIN ) + 1; - poll_fds = (struct pollfd*)alloca( poll_fd_count * sizeof( struct pollfd )); - snd_seq_poll_descriptors( apiData->seq, poll_fds + 1, poll_fd_count - 1, POLLIN ); - poll_fds[0].fd = apiData->trigger_fds[0]; - poll_fds[0].events = POLLIN; - - while ( data->doInput ) { - - if ( snd_seq_event_input_pending( apiData->seq, 1 ) == 0 ) { - // No data pending - if ( poll( poll_fds, poll_fd_count, -1) >= 0 ) { - if ( poll_fds[0].revents & POLLIN ) { - bool dummy; - int res = read( poll_fds[0].fd, &dummy, sizeof(dummy) ); - (void) res; - } - } - continue; - } - - // If here, there should be data. - result = snd_seq_event_input( apiData->seq, &ev ); - if ( result == -ENOSPC ) { - std::cerr << "\nMidiInAlsa::alsaMidiHandler: MIDI input buffer overrun!\n\n"; - continue; - } - else if ( result <= 0 ) { - std::cerr << "MidiInAlsa::alsaMidiHandler: unknown MIDI input error!\n"; - continue; - } - - // This is a bit weird, but we now have to decode an ALSA MIDI - // event (back) into MIDI bytes. We'll ignore non-MIDI types. - if ( !continueSysex ) message.bytes.clear(); - - doDecode = false; - switch ( ev->type ) { - - case SND_SEQ_EVENT_PORT_SUBSCRIBED: -#if defined(__RTMIDI_DEBUG__) - std::cout << "MidiInAlsa::alsaMidiHandler: port connection made!\n"; -#endif - break; - - case SND_SEQ_EVENT_PORT_UNSUBSCRIBED: -#if defined(__RTMIDI_DEBUG__) - std::cerr << "MidiInAlsa::alsaMidiHandler: port connection has closed!\n"; - std::cout << "sender = " << (int) ev->data.connect.sender.client << ":" - << (int) ev->data.connect.sender.port - << ", dest = " << (int) ev->data.connect.dest.client << ":" - << (int) ev->data.connect.dest.port - << std::endl; -#endif - break; - - case SND_SEQ_EVENT_QFRAME: // MIDI time code - if ( !( data->ignoreFlags & 0x02 ) ) doDecode = true; - break; - - case SND_SEQ_EVENT_TICK: // MIDI timing tick - if ( !( data->ignoreFlags & 0x02 ) ) doDecode = true; - break; - - case SND_SEQ_EVENT_SENSING: // Active sensing - if ( !( data->ignoreFlags & 0x04 ) ) doDecode = true; - break; - - case SND_SEQ_EVENT_SYSEX: - if ( (data->ignoreFlags & 0x01) ) break; - if ( ev->data.ext.len > apiData->bufferSize ) { - apiData->bufferSize = ev->data.ext.len; - free( buffer ); - buffer = (unsigned char *) malloc( apiData->bufferSize ); - if ( buffer == NULL ) { - data->doInput = false; - std::cerr << "\nMidiInAlsa::alsaMidiHandler: error resizing buffer memory!\n\n"; - break; - } - } - - default: - doDecode = true; - } - - if ( doDecode ) { - - nBytes = snd_midi_event_decode( apiData->coder, buffer, apiData->bufferSize, ev ); - if ( nBytes > 0 ) { - // The ALSA sequencer has a maximum buffer size for MIDI sysex - // events of 256 bytes. If a device sends sysex messages larger - // than this, they are segmented into 256 byte chunks. So, - // we'll watch for this and concatenate sysex chunks into a - // single sysex message if necessary. - if ( !continueSysex ) - message.bytes.assign( buffer, &buffer[nBytes] ); - else - message.bytes.insert( message.bytes.end(), buffer, &buffer[nBytes] ); - - continueSysex = ( ( ev->type == SND_SEQ_EVENT_SYSEX ) && ( message.bytes.back() != 0xF7 ) ); - if ( !continueSysex ) { - - // Calculate the time stamp: - message.timeStamp = 0.0; - - // Method 1: Use the system time. - //(void)gettimeofday(&tv, (struct timezone *)NULL); - //time = (tv.tv_sec * 1000000) + tv.tv_usec; - - // Method 2: Use the ALSA sequencer event time data. - // (thanks to Pedro Lopez-Cabanillas!). - time = ( ev->time.time.tv_sec * 1000000 ) + ( ev->time.time.tv_nsec/1000 ); - lastTime = time; - time -= apiData->lastTime; - apiData->lastTime = lastTime; - if ( data->firstMessage == true ) - data->firstMessage = false; - else - message.timeStamp = time * 0.000001; - } - else { -#if defined(__RTMIDI_DEBUG__) - std::cerr << "\nMidiInAlsa::alsaMidiHandler: event parsing error or not a MIDI event!\n\n"; -#endif - } - } - } - - snd_seq_free_event( ev ); - if ( message.bytes.size() == 0 || continueSysex ) continue; - - if ( data->usingCallback ) { - RtMidiIn::RtMidiCallback callback = (RtMidiIn::RtMidiCallback) data->userCallback; - callback( message.timeStamp, &message.bytes, data->userData ); - } - else { - // As long as we haven't reached our queue size limit, push the message. - if ( data->queue.size < data->queue.ringSize ) { - data->queue.ring[data->queue.back++] = message; - if ( data->queue.back == data->queue.ringSize ) - data->queue.back = 0; - data->queue.size++; - } - else - std::cerr << "\nMidiInAlsa: message queue limit reached!!\n\n"; - } - } - - if ( buffer ) free( buffer ); - snd_midi_event_free( apiData->coder ); - apiData->coder = 0; - apiData->thread = apiData->dummy_thread_id; - return 0; -} - -MidiInAlsa :: MidiInAlsa( const std::string clientName, unsigned int queueSizeLimit ) : MidiInApi( queueSizeLimit ) -{ - initialize( clientName ); -} - -MidiInAlsa :: ~MidiInAlsa() -{ - // Close a connection if it exists. - closePort(); - - // Shutdown the input thread. - AlsaMidiData *data = static_cast (apiData_); - if ( inputData_.doInput ) { - inputData_.doInput = false; - int res = write( data->trigger_fds[1], &inputData_.doInput, sizeof(inputData_.doInput) ); - (void) res; - if ( !pthread_equal(data->thread, data->dummy_thread_id) ) - pthread_join( data->thread, NULL ); - } - - // Cleanup. - close ( data->trigger_fds[0] ); - close ( data->trigger_fds[1] ); - if ( data->vport >= 0 ) snd_seq_delete_port( data->seq, data->vport ); -#ifndef AVOID_TIMESTAMPING - snd_seq_free_queue( data->seq, data->queue_id ); -#endif - freeSequencer(); - delete data; -} - -void MidiInAlsa :: initialize( const std::string& clientName ) -{ - snd_seq_t* seq = createSequencer( clientName ); - if ( seq == NULL ) { - s_seq = NULL; - errorString_ = "MidiInAlsa::initialize: error creating ALSA sequencer client object."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - AlsaMidiData *data = (AlsaMidiData *) new AlsaMidiData; - data->seq = seq; - data->portNum = -1; - data->vport = -1; - data->subscription = 0; - data->dummy_thread_id = pthread_self(); - data->thread = data->dummy_thread_id; - data->trigger_fds[0] = -1; - data->trigger_fds[1] = -1; - apiData_ = (void *) data; - inputData_.apiData = (void *) data; - - if ( pipe(data->trigger_fds) == -1 ) { - errorString_ = "MidiInAlsa::initialize: error creating pipe objects."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Create the input queue -#ifndef AVOID_TIMESTAMPING - data->queue_id = snd_seq_alloc_named_queue(s_seq, "RtMidi Queue"); - // Set arbitrary tempo (mm=100) and resolution (240) - snd_seq_queue_tempo_t *qtempo; - snd_seq_queue_tempo_alloca(&qtempo); - snd_seq_queue_tempo_set_tempo(qtempo, 600000); - snd_seq_queue_tempo_set_ppq(qtempo, 240); - snd_seq_set_queue_tempo(data->seq, data->queue_id, qtempo); - snd_seq_drain_output(data->seq); -#endif -} - -// This function is used to count or get the pinfo structure for a given port number. -unsigned int portInfo( snd_seq_t *seq, snd_seq_port_info_t *pinfo, unsigned int type, int portNumber ) -{ - snd_seq_client_info_t *cinfo; - int client; - int count = 0; - snd_seq_client_info_alloca( &cinfo ); - - snd_seq_client_info_set_client( cinfo, -1 ); - while ( snd_seq_query_next_client( seq, cinfo ) >= 0 ) { - client = snd_seq_client_info_get_client( cinfo ); - if ( client == 0 ) continue; - // Reset query info - snd_seq_port_info_set_client( pinfo, client ); - snd_seq_port_info_set_port( pinfo, -1 ); - while ( snd_seq_query_next_port( seq, pinfo ) >= 0 ) { - unsigned int atyp = snd_seq_port_info_get_type( pinfo ); - if ( ( atyp & SND_SEQ_PORT_TYPE_MIDI_GENERIC ) == 0 ) continue; - unsigned int caps = snd_seq_port_info_get_capability( pinfo ); - if ( ( caps & type ) != type ) continue; - if ( count == portNumber ) return 1; - ++count; - } - } - - // If a negative portNumber was used, return the port count. - if ( portNumber < 0 ) return count; - return 0; -} - -unsigned int MidiInAlsa :: getPortCount() -{ - snd_seq_port_info_t *pinfo; - snd_seq_port_info_alloca( &pinfo ); - - AlsaMidiData *data = static_cast (apiData_); - return portInfo( data->seq, pinfo, SND_SEQ_PORT_CAP_READ|SND_SEQ_PORT_CAP_SUBS_READ, -1 ); -} - -std::string MidiInAlsa :: getPortName( unsigned int portNumber ) -{ - snd_seq_client_info_t *cinfo; - snd_seq_port_info_t *pinfo; - snd_seq_client_info_alloca( &cinfo ); - snd_seq_port_info_alloca( &pinfo ); - - std::string stringName; - AlsaMidiData *data = static_cast (apiData_); - if ( portInfo( data->seq, pinfo, SND_SEQ_PORT_CAP_READ|SND_SEQ_PORT_CAP_SUBS_READ, (int) portNumber ) ) { - int cnum = snd_seq_port_info_get_client( pinfo ); - snd_seq_get_any_client_info( data->seq, cnum, cinfo ); - std::ostringstream os; - os << snd_seq_client_info_get_name( cinfo ); - os << " "; // GO: These lines added to make sure devices are listed - os << snd_seq_port_info_get_client( pinfo ); // GO: with full portnames added to ensure individual device names - os << ":"; - os << snd_seq_port_info_get_port( pinfo ); - stringName = os.str(); - return stringName; - } - - // If we get here, we didn't find a match. - errorString_ = "MidiInAlsa::getPortName: error looking for port name!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return stringName; - //RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); -} - -void MidiInAlsa :: openPort( unsigned int portNumber, const std::string portName ) -{ - if ( connected_ ) { - errorString_ = "MidiInAlsa::openPort: a valid connection already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - unsigned int nSrc = this->getPortCount(); - if (nSrc < 1) { - errorString_ = "MidiInAlsa::openPort: no MIDI input sources found!"; - RtMidi::error( RtError::NO_DEVICES_FOUND, errorString_ ); - } - - snd_seq_port_info_t *pinfo; - snd_seq_port_info_alloca( &pinfo ); - std::ostringstream ost; - AlsaMidiData *data = static_cast (apiData_); - if ( portInfo( data->seq, pinfo, SND_SEQ_PORT_CAP_READ|SND_SEQ_PORT_CAP_SUBS_READ, (int) portNumber ) == 0 ) { - ost << "MidiInAlsa::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - - snd_seq_addr_t sender, receiver; - sender.client = snd_seq_port_info_get_client( pinfo ); - sender.port = snd_seq_port_info_get_port( pinfo ); - receiver.client = snd_seq_client_id( data->seq ); - if ( data->vport < 0 ) { - snd_seq_port_info_set_client( pinfo, 0 ); - snd_seq_port_info_set_port( pinfo, 0 ); - snd_seq_port_info_set_capability( pinfo, - SND_SEQ_PORT_CAP_WRITE | - SND_SEQ_PORT_CAP_SUBS_WRITE ); - snd_seq_port_info_set_type( pinfo, - SND_SEQ_PORT_TYPE_MIDI_GENERIC | - SND_SEQ_PORT_TYPE_APPLICATION ); - snd_seq_port_info_set_midi_channels(pinfo, 16); -#ifndef AVOID_TIMESTAMPING - snd_seq_port_info_set_timestamping(pinfo, 1); - snd_seq_port_info_set_timestamp_real(pinfo, 1); - snd_seq_port_info_set_timestamp_queue(pinfo, data->queue_id); -#endif - snd_seq_port_info_set_name(pinfo, portName.c_str() ); - data->vport = snd_seq_create_port(data->seq, pinfo); - - if ( data->vport < 0 ) { - errorString_ = "MidiInAlsa::openPort: ALSA error creating input port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } - - receiver.port = data->vport; - - if ( !data->subscription ) { - // Make subscription - if (snd_seq_port_subscribe_malloc( &data->subscription ) < 0) { - errorString_ = "MidiInAlsa::openPort: ALSA error allocation port subscription."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - snd_seq_port_subscribe_set_sender(data->subscription, &sender); - snd_seq_port_subscribe_set_dest(data->subscription, &receiver); - if ( snd_seq_subscribe_port(data->seq, data->subscription) ) { - snd_seq_port_subscribe_free( data->subscription ); - data->subscription = 0; - errorString_ = "MidiInAlsa::openPort: ALSA error making port connection."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } - - if ( inputData_.doInput == false ) { - // Start the input queue -#ifndef AVOID_TIMESTAMPING - snd_seq_start_queue( data->seq, data->queue_id, NULL ); - snd_seq_drain_output( data->seq ); -#endif - // Start our MIDI input thread. - pthread_attr_t attr; - pthread_attr_init(&attr); - pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE); - pthread_attr_setschedpolicy(&attr, SCHED_OTHER); - - inputData_.doInput = true; - int err = pthread_create(&data->thread, &attr, alsaMidiHandler, &inputData_); - pthread_attr_destroy(&attr); - if ( err ) { - snd_seq_unsubscribe_port( data->seq, data->subscription ); - snd_seq_port_subscribe_free( data->subscription ); - data->subscription = 0; - inputData_.doInput = false; - errorString_ = "MidiInAlsa::openPort: error starting MIDI input thread!"; - RtMidi::error( RtError::THREAD_ERROR, errorString_ ); - } - } - - connected_ = true; -} - -void MidiInAlsa :: openVirtualPort( std::string portName ) -{ - AlsaMidiData *data = static_cast (apiData_); - if ( data->vport < 0 ) { - snd_seq_port_info_t *pinfo; - snd_seq_port_info_alloca( &pinfo ); - snd_seq_port_info_set_capability( pinfo, - SND_SEQ_PORT_CAP_WRITE | - SND_SEQ_PORT_CAP_SUBS_WRITE ); - snd_seq_port_info_set_type( pinfo, - SND_SEQ_PORT_TYPE_MIDI_GENERIC | - SND_SEQ_PORT_TYPE_APPLICATION ); - snd_seq_port_info_set_midi_channels(pinfo, 16); -#ifndef AVOID_TIMESTAMPING - snd_seq_port_info_set_timestamping(pinfo, 1); - snd_seq_port_info_set_timestamp_real(pinfo, 1); - snd_seq_port_info_set_timestamp_queue(pinfo, data->queue_id); -#endif - snd_seq_port_info_set_name(pinfo, portName.c_str()); - data->vport = snd_seq_create_port(data->seq, pinfo); - - if ( data->vport < 0 ) { - errorString_ = "MidiInAlsa::openVirtualPort: ALSA error creating virtual port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } - - if ( inputData_.doInput == false ) { - // Wait for old thread to stop, if still running - if ( !pthread_equal(data->thread, data->dummy_thread_id) ) - pthread_join( data->thread, NULL ); - - // Start the input queue -#ifndef AVOID_TIMESTAMPING - snd_seq_start_queue( data->seq, data->queue_id, NULL ); - snd_seq_drain_output( data->seq ); -#endif - // Start our MIDI input thread. - pthread_attr_t attr; - pthread_attr_init(&attr); - pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE); - pthread_attr_setschedpolicy(&attr, SCHED_OTHER); - - inputData_.doInput = true; - int err = pthread_create(&data->thread, &attr, alsaMidiHandler, &inputData_); - pthread_attr_destroy(&attr); - if ( err ) { - if ( data->subscription ) { - snd_seq_unsubscribe_port( data->seq, data->subscription ); - snd_seq_port_subscribe_free( data->subscription ); - data->subscription = 0; - } - inputData_.doInput = false; - errorString_ = "MidiInAlsa::openPort: error starting MIDI input thread!"; - RtMidi::error( RtError::THREAD_ERROR, errorString_ ); - } - } -} - -void MidiInAlsa :: closePort( void ) -{ - AlsaMidiData *data = static_cast (apiData_); - - if ( connected_ ) { - if ( data->subscription ) { - snd_seq_unsubscribe_port( data->seq, data->subscription ); - snd_seq_port_subscribe_free( data->subscription ); - data->subscription = 0; - } - // Stop the input queue -#ifndef AVOID_TIMESTAMPING - snd_seq_stop_queue( data->seq, data->queue_id, NULL ); - snd_seq_drain_output( data->seq ); -#endif - connected_ = false; - } - - // Stop thread to avoid triggering the callback, while the port is intended to be closed - if ( inputData_.doInput ) { - inputData_.doInput = false; - int res = write( data->trigger_fds[1], &inputData_.doInput, sizeof(inputData_.doInput) ); - (void) res; - if ( !pthread_equal(data->thread, data->dummy_thread_id) ) - pthread_join( data->thread, NULL ); - } -} - -//*********************************************************************// -// API: LINUX ALSA -// Class Definitions: MidiOutAlsa -//*********************************************************************// - -MidiOutAlsa :: MidiOutAlsa( const std::string clientName ) : MidiOutApi() -{ - initialize( clientName ); -} - -MidiOutAlsa :: ~MidiOutAlsa() -{ - // Close a connection if it exists. - closePort(); - - // Cleanup. - AlsaMidiData *data = static_cast (apiData_); - if ( data->vport >= 0 ) snd_seq_delete_port( data->seq, data->vport ); - if ( data->coder ) snd_midi_event_free( data->coder ); - if ( data->buffer ) free( data->buffer ); - freeSequencer(); - delete data; -} - -void MidiOutAlsa :: initialize( const std::string& clientName ) -{ - snd_seq_t* seq = createSequencer( clientName ); - if ( seq == NULL ) { - s_seq = NULL; - errorString_ = "MidiOutAlsa::initialize: error creating ALSA sequencer client object."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Save our api-specific connection information. - AlsaMidiData *data = (AlsaMidiData *) new AlsaMidiData; - data->seq = seq; - data->portNum = -1; - data->vport = -1; - data->bufferSize = 32; - data->coder = 0; - data->buffer = 0; - int result = snd_midi_event_new( data->bufferSize, &data->coder ); - if ( result < 0 ) { - delete data; - errorString_ = "MidiOutAlsa::initialize: error initializing MIDI event parser!\n\n"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - data->buffer = (unsigned char *) malloc( data->bufferSize ); - if ( data->buffer == NULL ) { - delete data; - errorString_ = "MidiOutAlsa::initialize: error allocating buffer memory!\n\n"; - RtMidi::error( RtError::MEMORY_ERROR, errorString_ ); - } - snd_midi_event_init( data->coder ); - apiData_ = (void *) data; -} - -unsigned int MidiOutAlsa :: getPortCount() -{ - snd_seq_port_info_t *pinfo; - snd_seq_port_info_alloca( &pinfo ); - - AlsaMidiData *data = static_cast (apiData_); - return portInfo( data->seq, pinfo, SND_SEQ_PORT_CAP_WRITE|SND_SEQ_PORT_CAP_SUBS_WRITE, -1 ); -} - -std::string MidiOutAlsa :: getPortName( unsigned int portNumber ) -{ - snd_seq_client_info_t *cinfo; - snd_seq_port_info_t *pinfo; - snd_seq_client_info_alloca( &cinfo ); - snd_seq_port_info_alloca( &pinfo ); - - std::string stringName; - AlsaMidiData *data = static_cast (apiData_); - if ( portInfo( data->seq, pinfo, SND_SEQ_PORT_CAP_WRITE|SND_SEQ_PORT_CAP_SUBS_WRITE, (int) portNumber ) ) { - int cnum = snd_seq_port_info_get_client(pinfo); - snd_seq_get_any_client_info( data->seq, cnum, cinfo ); - std::ostringstream os; - os << snd_seq_client_info_get_name(cinfo); - os << ":"; - os << snd_seq_port_info_get_port(pinfo); - stringName = os.str(); - return stringName; - } - - // If we get here, we didn't find a match. - errorString_ = "MidiOutAlsa::getPortName: error looking for port name!"; - //RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - RtMidi::error( RtError::WARNING, errorString_ ); - return stringName; -} - -void MidiOutAlsa :: openPort( unsigned int portNumber, const std::string portName ) -{ - if ( connected_ ) { - errorString_ = "MidiOutAlsa::openPort: a valid connection already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - unsigned int nSrc = this->getPortCount(); - if (nSrc < 1) { - errorString_ = "MidiOutAlsa::openPort: no MIDI output sources found!"; - RtMidi::error( RtError::NO_DEVICES_FOUND, errorString_ ); - } - - snd_seq_port_info_t *pinfo; - snd_seq_port_info_alloca( &pinfo ); - std::ostringstream ost; - AlsaMidiData *data = static_cast (apiData_); - if ( portInfo( data->seq, pinfo, SND_SEQ_PORT_CAP_WRITE|SND_SEQ_PORT_CAP_SUBS_WRITE, (int) portNumber ) == 0 ) { - ost << "MidiOutAlsa::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - snd_seq_addr_t sender, receiver; - receiver.client = snd_seq_port_info_get_client( pinfo ); - receiver.port = snd_seq_port_info_get_port( pinfo ); - sender.client = snd_seq_client_id( data->seq ); - - if ( data->vport < 0 ) { - data->vport = snd_seq_create_simple_port( data->seq, portName.c_str(), - SND_SEQ_PORT_CAP_READ|SND_SEQ_PORT_CAP_SUBS_READ, - SND_SEQ_PORT_TYPE_MIDI_GENERIC|SND_SEQ_PORT_TYPE_APPLICATION ); - if ( data->vport < 0 ) { - errorString_ = "MidiOutAlsa::openPort: ALSA error creating output port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } - - sender.port = data->vport; - - // Make subscription - if (snd_seq_port_subscribe_malloc( &data->subscription ) < 0) { - snd_seq_port_subscribe_free( data->subscription ); - errorString_ = "MidiOutAlsa::openPort: error allocation port subscribtion."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - snd_seq_port_subscribe_set_sender(data->subscription, &sender); - snd_seq_port_subscribe_set_dest(data->subscription, &receiver); - snd_seq_port_subscribe_set_time_update(data->subscription, 1); - snd_seq_port_subscribe_set_time_real(data->subscription, 1); - if ( snd_seq_subscribe_port(data->seq, data->subscription) ) { - snd_seq_port_subscribe_free( data->subscription ); - errorString_ = "MidiOutAlsa::openPort: ALSA error making port connection."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - connected_ = true; -} - -void MidiOutAlsa :: closePort( void ) -{ - if ( connected_ ) { - AlsaMidiData *data = static_cast (apiData_); - snd_seq_unsubscribe_port( data->seq, data->subscription ); - snd_seq_port_subscribe_free( data->subscription ); - connected_ = false; - } -} - -void MidiOutAlsa :: openVirtualPort( std::string portName ) -{ - AlsaMidiData *data = static_cast (apiData_); - if ( data->vport < 0 ) { - data->vport = snd_seq_create_simple_port( data->seq, portName.c_str(), - SND_SEQ_PORT_CAP_READ|SND_SEQ_PORT_CAP_SUBS_READ, - SND_SEQ_PORT_TYPE_MIDI_GENERIC|SND_SEQ_PORT_TYPE_APPLICATION ); - - if ( data->vport < 0 ) { - errorString_ = "MidiOutAlsa::openVirtualPort: ALSA error creating virtual port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } -} - -void MidiOutAlsa :: sendMessage( std::vector *message ) -{ - int result; - AlsaMidiData *data = static_cast (apiData_); - unsigned int nBytes = message->size(); - if ( nBytes > data->bufferSize ) { - data->bufferSize = nBytes; - result = snd_midi_event_resize_buffer ( data->coder, nBytes); - if ( result != 0 ) { - errorString_ = "MidiOutAlsa::sendMessage: ALSA error resizing MIDI event buffer."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - free (data->buffer); - data->buffer = (unsigned char *) malloc( data->bufferSize ); - if ( data->buffer == NULL ) { - errorString_ = "MidiOutAlsa::initialize: error allocating buffer memory!\n\n"; - RtMidi::error( RtError::MEMORY_ERROR, errorString_ ); - } - } - - snd_seq_event_t ev; - snd_seq_ev_clear(&ev); - snd_seq_ev_set_source(&ev, data->vport); - snd_seq_ev_set_subs(&ev); - snd_seq_ev_set_direct(&ev); - for ( unsigned int i=0; ibuffer[i] = message->at(i); - result = snd_midi_event_encode( data->coder, data->buffer, (long)nBytes, &ev ); - if ( result < (int)nBytes ) { - errorString_ = "MidiOutAlsa::sendMessage: event parsing error!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - // Send the event. - result = snd_seq_event_output(data->seq, &ev); - if ( result < 0 ) { - errorString_ = "MidiOutAlsa::sendMessage: error sending MIDI message to port."; - RtMidi::error( RtError::WARNING, errorString_ ); - } - snd_seq_drain_output(data->seq); -} - -#endif // __LINUX_ALSA__ - - -//*********************************************************************// -// API: Windows Multimedia Library (MM) -//*********************************************************************// - -// API information deciphered from: -// - http://msdn.microsoft.com/library/default.asp?url=/library/en-us/multimed/htm/_win32_midi_reference.asp - -// Thanks to Jean-Baptiste Berruchon for the sysex code. - -#if defined(__WINDOWS_MM__) - -// The Windows MM API is based on the use of a callback function for -// MIDI input. We convert the system specific time stamps to delta -// time values. - -// Windows MM MIDI header files. -#include -#include - -#define RT_SYSEX_BUFFER_SIZE 1024 -#define RT_SYSEX_BUFFER_COUNT 4 - -// A structure to hold variables related to the CoreMIDI API -// implementation. -struct WinMidiData { - HMIDIIN inHandle; // Handle to Midi Input Device - HMIDIOUT outHandle; // Handle to Midi Output Device - DWORD lastTime; - MidiInApi::MidiMessage message; - LPMIDIHDR sysexBuffer[RT_SYSEX_BUFFER_COUNT]; -}; - -//*********************************************************************// -// API: Windows MM -// Class Definitions: MidiInWinMM -//*********************************************************************// - -static void CALLBACK midiInputCallback( HMIDIIN hmin, - UINT inputStatus, - DWORD_PTR instancePtr, - DWORD_PTR midiMessage, - DWORD timestamp ) -{ - if ( inputStatus != MIM_DATA && inputStatus != MIM_LONGDATA && inputStatus != MIM_LONGERROR ) return; - - //MidiInApi::RtMidiInData *data = static_cast (instancePtr); - MidiInApi::RtMidiInData *data = (MidiInApi::RtMidiInData *)instancePtr; - WinMidiData *apiData = static_cast (data->apiData); - - // Calculate time stamp. - if ( data->firstMessage == true ) { - apiData->message.timeStamp = 0.0; - data->firstMessage = false; - } - else apiData->message.timeStamp = (double) ( timestamp - apiData->lastTime ) * 0.001; - apiData->lastTime = timestamp; - - if ( inputStatus == MIM_DATA ) { // Channel or system message - - // Make sure the first byte is a status byte. - unsigned char status = (unsigned char) (midiMessage & 0x000000FF); - if ( !(status & 0x80) ) return; - - // Determine the number of bytes in the MIDI message. - unsigned short nBytes = 1; - if ( status < 0xC0 ) nBytes = 3; - else if ( status < 0xE0 ) nBytes = 2; - else if ( status < 0xF0 ) nBytes = 3; - else if ( status == 0xF1 ) { - if ( data->ignoreFlags & 0x02 ) return; - else nBytes = 2; - } - else if ( status == 0xF2 ) nBytes = 3; - else if ( status == 0xF3 ) nBytes = 2; - else if ( status == 0xF8 && (data->ignoreFlags & 0x02) ) { - // A MIDI timing tick message and we're ignoring it. - return; - } - else if ( status == 0xFE && (data->ignoreFlags & 0x04) ) { - // A MIDI active sensing message and we're ignoring it. - return; - } - - // Copy bytes to our MIDI message. - unsigned char *ptr = (unsigned char *) &midiMessage; - for ( int i=0; imessage.bytes.push_back( *ptr++ ); - } - else { // Sysex message ( MIM_LONGDATA or MIM_LONGERROR ) - MIDIHDR *sysex = ( MIDIHDR *) midiMessage; - if ( !( data->ignoreFlags & 0x01 ) && inputStatus != MIM_LONGERROR ) { - // Sysex message and we're not ignoring it - for ( int i=0; i<(int)sysex->dwBytesRecorded; ++i ) - apiData->message.bytes.push_back( sysex->lpData[i] ); - } - - // The WinMM API requires that the sysex buffer be requeued after - // input of each sysex message. Even if we are ignoring sysex - // messages, we still need to requeue the buffer in case the user - // decides to not ignore sysex messages in the future. However, - // it seems that WinMM calls this function with an empty sysex - // buffer when an application closes and in this case, we should - // avoid requeueing it, else the computer suddenly reboots after - // one or two minutes. - if ( apiData->sysexBuffer[sysex->dwUser]->dwBytesRecorded > 0 ) { - //if ( sysex->dwBytesRecorded > 0 ) { - MMRESULT result = midiInAddBuffer( apiData->inHandle, apiData->sysexBuffer[sysex->dwUser], sizeof(MIDIHDR) ); - if ( result != MMSYSERR_NOERROR ) - std::cerr << "\nRtMidiIn::midiInputCallback: error sending sysex to Midi device!!\n\n"; - - if ( data->ignoreFlags & 0x01 ) return; - } - else return; - } - - if ( data->usingCallback ) { - RtMidiIn::RtMidiCallback callback = (RtMidiIn::RtMidiCallback) data->userCallback; - callback( apiData->message.timeStamp, &apiData->message.bytes, data->userData ); - } - else { - // As long as we haven't reached our queue size limit, push the message. - if ( data->queue.size < data->queue.ringSize ) { - data->queue.ring[data->queue.back++] = apiData->message; - if ( data->queue.back == data->queue.ringSize ) - data->queue.back = 0; - data->queue.size++; - } - else - std::cerr << "\nRtMidiIn: message queue limit reached!!\n\n"; - } - - // Clear the vector for the next input message. - apiData->message.bytes.clear(); -} - -MidiInWinMM :: MidiInWinMM( const std::string clientName, unsigned int queueSizeLimit ) : MidiInApi( queueSizeLimit ) -{ - initialize( clientName ); -} - -MidiInWinMM :: ~MidiInWinMM() -{ - // Close a connection if it exists. - closePort(); - - // Cleanup. - WinMidiData *data = static_cast (apiData_); - delete data; -} - -void MidiInWinMM :: initialize( const std::string& /*clientName*/ ) -{ - // We'll issue a warning here if no devices are available but not - // throw an error since the user can plugin something later. - unsigned int nDevices = midiInGetNumDevs(); - if ( nDevices == 0 ) { - errorString_ = "MidiInWinMM::initialize: no MIDI input devices currently available."; - RtMidi::error( RtError::WARNING, errorString_ ); - } - - // Save our api-specific connection information. - WinMidiData *data = (WinMidiData *) new WinMidiData; - apiData_ = (void *) data; - inputData_.apiData = (void *) data; - data->message.bytes.clear(); // needs to be empty for first input message -} - -void MidiInWinMM :: openPort( unsigned int portNumber, const std::string /*portName*/ ) -{ - if ( connected_ ) { - errorString_ = "MidiInWinMM::openPort: a valid connection already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - unsigned int nDevices = midiInGetNumDevs(); - if (nDevices == 0) { - errorString_ = "MidiInWinMM::openPort: no MIDI input sources found!"; - RtMidi::error( RtError::NO_DEVICES_FOUND, errorString_ ); - } - - std::ostringstream ost; - if ( portNumber >= nDevices ) { - ost << "MidiInWinMM::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - WinMidiData *data = static_cast (apiData_); - MMRESULT result = midiInOpen( &data->inHandle, - portNumber, - (DWORD_PTR)&midiInputCallback, - (DWORD_PTR)&inputData_, - CALLBACK_FUNCTION ); - if ( result != MMSYSERR_NOERROR ) { - errorString_ = "MidiInWinMM::openPort: error creating Windows MM MIDI input port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Allocate and init the sysex buffers. - for ( int i=0; isysexBuffer[i] = (MIDIHDR*) new char[ sizeof(MIDIHDR) ]; - data->sysexBuffer[i]->lpData = new char[ RT_SYSEX_BUFFER_SIZE ]; - data->sysexBuffer[i]->dwBufferLength = RT_SYSEX_BUFFER_SIZE; - data->sysexBuffer[i]->dwUser = i; // We use the dwUser parameter as buffer indicator - data->sysexBuffer[i]->dwFlags = 0; - - result = midiInPrepareHeader( data->inHandle, data->sysexBuffer[i], sizeof(MIDIHDR) ); - if ( result != MMSYSERR_NOERROR ) { - midiInClose( data->inHandle ); - errorString_ = "MidiInWinMM::openPort: error starting Windows MM MIDI input port (PrepareHeader)."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Register the buffer. - result = midiInAddBuffer( data->inHandle, data->sysexBuffer[i], sizeof(MIDIHDR) ); - if ( result != MMSYSERR_NOERROR ) { - midiInClose( data->inHandle ); - errorString_ = "MidiInWinMM::openPort: error starting Windows MM MIDI input port (AddBuffer)."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } - - result = midiInStart( data->inHandle ); - if ( result != MMSYSERR_NOERROR ) { - midiInClose( data->inHandle ); - errorString_ = "MidiInWinMM::openPort: error starting Windows MM MIDI input port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - connected_ = true; -} - -void MidiInWinMM :: openVirtualPort( std::string portName ) -{ - // This function cannot be implemented for the Windows MM MIDI API. - errorString_ = "MidiInWinMM::openVirtualPort: cannot be implemented in Windows MM MIDI API!"; - RtMidi::error( RtError::WARNING, errorString_ ); -} - -void MidiInWinMM :: closePort( void ) -{ - if ( connected_ ) { - WinMidiData *data = static_cast (apiData_); - midiInReset( data->inHandle ); - midiInStop( data->inHandle ); - - for ( int i=0; iinHandle, data->sysexBuffer[i], sizeof(MIDIHDR)); - delete [] data->sysexBuffer[i]->lpData; - delete [] data->sysexBuffer[i]; - if ( result != MMSYSERR_NOERROR ) { - midiInClose( data->inHandle ); - errorString_ = "MidiInWinMM::openPort: error closing Windows MM MIDI input port (midiInUnprepareHeader)."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } - - midiInClose( data->inHandle ); - connected_ = false; - } -} - -unsigned int MidiInWinMM :: getPortCount() -{ - return midiInGetNumDevs(); -} - -std::string MidiInWinMM :: getPortName( unsigned int portNumber ) -{ - std::string stringName; - unsigned int nDevices = midiInGetNumDevs(); - if ( portNumber >= nDevices ) { - std::ostringstream ost; - ost << "MidiInWinMM::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - //RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - RtMidi::error( RtError::WARNING, errorString_ ); - return stringName; - } - - MIDIINCAPS deviceCaps; - midiInGetDevCaps( portNumber, &deviceCaps, sizeof(MIDIINCAPS)); - -#if defined( UNICODE ) || defined( _UNICODE ) - int length = WideCharToMultiByte(CP_UTF8, 0, deviceCaps.szPname, -1, NULL, 0, NULL, NULL); - stringName.assign( length, 0 ); - length = WideCharToMultiByte(CP_UTF8, 0, deviceCaps.szPname, wcslen(deviceCaps.szPname), &stringName[0], length, NULL, NULL); -#else - stringName = std::string( deviceCaps.szPname ); -#endif - - // Next lines added to add the portNumber to the name so that - // the device's names are sure to be listed with individual names - // even when they have the same brand name - std::ostringstream os; - os << " "; - os << portNumber; - stringName += os.str(); - - return stringName; -} - -//*********************************************************************// -// API: Windows MM -// Class Definitions: MidiOutWinMM -//*********************************************************************// - -MidiOutWinMM :: MidiOutWinMM( const std::string clientName ) : MidiOutApi() -{ - initialize( clientName ); -} - -MidiOutWinMM :: ~MidiOutWinMM() -{ - // Close a connection if it exists. - closePort(); - - // Cleanup. - WinMidiData *data = static_cast (apiData_); - delete data; -} - -void MidiOutWinMM :: initialize( const std::string& /*clientName*/ ) -{ - // We'll issue a warning here if no devices are available but not - // throw an error since the user can plug something in later. - unsigned int nDevices = midiOutGetNumDevs(); - if ( nDevices == 0 ) { - errorString_ = "MidiOutWinMM::initialize: no MIDI output devices currently available."; - RtMidi::error( RtError::WARNING, errorString_ ); - } - - // Save our api-specific connection information. - WinMidiData *data = (WinMidiData *) new WinMidiData; - apiData_ = (void *) data; -} - -unsigned int MidiOutWinMM :: getPortCount() -{ - return midiOutGetNumDevs(); -} - -std::string MidiOutWinMM :: getPortName( unsigned int portNumber ) -{ - std::string stringName; - unsigned int nDevices = midiOutGetNumDevs(); - if ( portNumber >= nDevices ) { - std::ostringstream ost; - ost << "MidiOutWinMM::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - //RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - RtMidi::error( RtError::WARNING, errorString_ ); - return stringName; - } - - MIDIOUTCAPS deviceCaps; - midiOutGetDevCaps( portNumber, &deviceCaps, sizeof(MIDIOUTCAPS)); - -#if defined( UNICODE ) || defined( _UNICODE ) - int length = WideCharToMultiByte(CP_UTF8, 0, deviceCaps.szPname, -1, NULL, 0, NULL, NULL); - stringName.assign( length, 0 ); - length = WideCharToMultiByte(CP_UTF8, 0, deviceCaps.szPname, wcslen(deviceCaps.szPname), &stringName[0], length, NULL, NULL); -#else - stringName = std::string( deviceCaps.szPname ); -#endif - - return stringName; -} - -void MidiOutWinMM :: openPort( unsigned int portNumber, const std::string /*portName*/ ) -{ - if ( connected_ ) { - errorString_ = "MidiOutWinMM::openPort: a valid connection already exists!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - unsigned int nDevices = midiOutGetNumDevs(); - if (nDevices < 1) { - errorString_ = "MidiOutWinMM::openPort: no MIDI output destinations found!"; - RtMidi::error( RtError::NO_DEVICES_FOUND, errorString_ ); - } - - std::ostringstream ost; - if ( portNumber >= nDevices ) { - ost << "MidiOutWinMM::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::INVALID_PARAMETER, errorString_ ); - } - - WinMidiData *data = static_cast (apiData_); - MMRESULT result = midiOutOpen( &data->outHandle, - portNumber, - (DWORD)NULL, - (DWORD)NULL, - CALLBACK_NULL ); - if ( result != MMSYSERR_NOERROR ) { - errorString_ = "MidiOutWinMM::openPort: error creating Windows MM MIDI output port."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - connected_ = true; -} - -void MidiOutWinMM :: closePort( void ) -{ - if ( connected_ ) { - WinMidiData *data = static_cast (apiData_); - midiOutReset( data->outHandle ); - midiOutClose( data->outHandle ); - connected_ = false; - } -} - -void MidiOutWinMM :: openVirtualPort( std::string portName ) -{ - // This function cannot be implemented for the Windows MM MIDI API. - errorString_ = "MidiOutWinMM::openVirtualPort: cannot be implemented in Windows MM MIDI API!"; - RtMidi::error( RtError::WARNING, errorString_ ); -} - -void MidiOutWinMM :: sendMessage( std::vector *message ) -{ - unsigned int nBytes = static_cast(message->size()); - if ( nBytes == 0 ) { - errorString_ = "MidiOutWinMM::sendMessage: message argument is empty!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - MMRESULT result; - WinMidiData *data = static_cast (apiData_); - if ( message->at(0) == 0xF0 ) { // Sysex message - - // Allocate buffer for sysex data. - char *buffer = (char *) malloc( nBytes ); - if ( buffer == NULL ) { - errorString_ = "MidiOutWinMM::sendMessage: error allocating sysex message memory!"; - RtMidi::error( RtError::MEMORY_ERROR, errorString_ ); - } - - // Copy data to buffer. - for ( unsigned int i=0; iat(i); - - // Create and prepare MIDIHDR structure. - MIDIHDR sysex; - sysex.lpData = (LPSTR) buffer; - sysex.dwBufferLength = nBytes; - sysex.dwFlags = 0; - result = midiOutPrepareHeader( data->outHandle, &sysex, sizeof(MIDIHDR) ); - if ( result != MMSYSERR_NOERROR ) { - free( buffer ); - errorString_ = "MidiOutWinMM::sendMessage: error preparing sysex header."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Send the message. - result = midiOutLongMsg( data->outHandle, &sysex, sizeof(MIDIHDR) ); - if ( result != MMSYSERR_NOERROR ) { - free( buffer ); - errorString_ = "MidiOutWinMM::sendMessage: error sending sysex message."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Unprepare the buffer and MIDIHDR. - while ( MIDIERR_STILLPLAYING == midiOutUnprepareHeader( data->outHandle, &sysex, sizeof (MIDIHDR) ) ) Sleep( 1 ); - free( buffer ); - - } - else { // Channel or system message. - - // Make sure the message size isn't too big. - if ( nBytes > 3 ) { - errorString_ = "MidiOutWinMM::sendMessage: message size is greater than 3 bytes (and not sysex)!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return; - } - - // Pack MIDI bytes into double word. - DWORD packet; - unsigned char *ptr = (unsigned char *) &packet; - for ( unsigned int i=0; iat(i); - ++ptr; - } - - // Send the message immediately. - result = midiOutShortMsg( data->outHandle, packet ); - if ( result != MMSYSERR_NOERROR ) { - errorString_ = "MidiOutWinMM::sendMessage: error sending MIDI message."; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - } -} - -#endif // __WINDOWS_MM__ - -// *********************************************************************// -// API: WINDOWS Kernel Streaming -// -// Written by Sebastien Alaiwan, 2012. -// -// NOTE BY GARY: much of the KS-specific code below probably should go in a separate file. -// -// *********************************************************************// - -#if defined(__WINDOWS_KS__) - -#include -#include -#include -#include -#include -#include -#include -#include - -#include "ks.h" -#include "ksmedia.h" - -#define INSTANTIATE_GUID(a) GUID const a = { STATIC_ ## a } - -INSTANTIATE_GUID(GUID_NULL); -INSTANTIATE_GUID(KSPROPSETID_Pin); -INSTANTIATE_GUID(KSPROPSETID_Connection); -INSTANTIATE_GUID(KSPROPSETID_Topology); -INSTANTIATE_GUID(KSINTERFACESETID_Standard); -INSTANTIATE_GUID(KSMEDIUMSETID_Standard); -INSTANTIATE_GUID(KSDATAFORMAT_TYPE_MUSIC); -INSTANTIATE_GUID(KSDATAFORMAT_SUBTYPE_MIDI); -INSTANTIATE_GUID(KSDATAFORMAT_SPECIFIER_NONE); - -#undef INSTANTIATE_GUID - -typedef std::basic_string tstring; - -inline bool IsValid(HANDLE handle) -{ - return handle != NULL && handle != INVALID_HANDLE_VALUE; -} - -class ComException : public std::runtime_error -{ -private: - static std::string MakeString(std::string const& s, HRESULT hr) - { - std::stringstream ss; - ss << "(error 0x" << std::hex << hr << ")"; - return s + ss.str(); - } - -public: - ComException(std::string const& s, HRESULT hr) : - std::runtime_error(MakeString(s, hr)) - { - } -}; - -template -class CKsEnumFilters -{ -public: - ~CKsEnumFilters() - { - DestroyLists(); - } - - void EnumFilters(GUID const* categories, size_t numCategories) - { - DestroyLists(); - - if (categories == 0) - { - printf ("Error: CKsEnumFilters: invalid argument\n"); - assert(0); - } - // Get a handle to the device set specified by the guid - HDEVINFO hDevInfo = ::SetupDiGetClassDevs(&categories[0], NULL, NULL, DIGCF_PRESENT | DIGCF_DEVICEINTERFACE); - if (!IsValid(hDevInfo)) - { - printf ("Error: CKsEnumFilters: no devices found"); - assert (0); - } - - // Loop through members of the set and get details for each - for (int iClassMember=0;;iClassMember++) { - { - SP_DEVICE_INTERFACE_DATA DID; - DID.cbSize = sizeof(DID); - DID.Reserved = 0; - - bool fRes = ::SetupDiEnumDeviceInterfaces(hDevInfo, NULL, &categories[0], iClassMember, &DID); - if (!fRes) - break; - - // Get filter friendly name - HKEY hRegKey = ::SetupDiOpenDeviceInterfaceRegKey(hDevInfo, &DID, 0, KEY_READ); - if (hRegKey == INVALID_HANDLE_VALUE) - { - assert(0); - printf "CKsEnumFilters: interface has no registry\n"); - } - char friendlyName[256]; - DWORD dwSize = sizeof friendlyName; - LONG lval = ::RegQueryValueEx(hRegKey, TEXT("FriendlyName"), NULL, NULL, (LPBYTE)friendlyName, &dwSize); - ::RegCloseKey(hRegKey); - if (lval != ERROR_SUCCESS) - { - assert(0); - printf ("CKsEnumFilters: interface has no friendly name"); - } - // Get details for the device registered in this class - DWORD const cbItfDetails = sizeof(SP_DEVICE_INTERFACE_DETAIL_DATA) + MAX_PATH * sizeof(WCHAR); - std::vector buffer(cbItfDetails); - - SP_DEVICE_INTERFACE_DETAIL_DATA* pDevInterfaceDetails = reinterpret_cast(&buffer[0]); - pDevInterfaceDetails->cbSize = sizeof(*pDevInterfaceDetails); - - SP_DEVINFO_DATA DevInfoData; - DevInfoData.cbSize = sizeof(DevInfoData); - DevInfoData.Reserved = 0; - - fRes = ::SetupDiGetDeviceInterfaceDetail(hDevInfo, &DID, pDevInterfaceDetails, cbItfDetails, NULL, &DevInfoData); - if (!fRes) - { - printf("CKsEnumFilters: could not get interface details"); - assert(0); - } - // check additional category guids which may (or may not) have been supplied - for (size_t i=1; i < numCategories; ++i) { - SP_DEVICE_INTERFACE_DATA DIDAlias; - DIDAlias.cbSize = sizeof(DIDAlias); - DIDAlias.Reserved = 0; - - fRes = ::SetupDiGetDeviceInterfaceAlias(hDevInfo, &DID, &categories[i], &DIDAlias); - if (!fRes) - { - printf("CKsEnumFilters: could not get interface alias"); - assert(0); - } - // Check if the this interface alias is enabled. - if (!DIDAlias.Flags || (DIDAlias.Flags & SPINT_REMOVED)) - { - printf("CKsEnumFilters: interface alias is not enabled"); - assert(0); - } - } - - std::auto_ptr pFilter(new TFilterType(pDevInterfaceDetails->DevicePath, friendlyName)); - - pFilter->Instantiate(); - pFilter->FindMidiPins(); - pFilter->Validate(); - - m_Filters.push_back(pFilter.release()); - } - } - - ::SetupDiDestroyDeviceInfoList(hDevInfo); - } - -private: - void DestroyLists() - { - for (size_t i=0;i < m_Filters.size();++i) - delete m_Filters[i]; - m_Filters.clear(); - } - -public: - // TODO: make this private. - std::vector m_Filters; -}; - -class CKsObject -{ -public: - CKsObject(HANDLE handle) : m_handle(handle) - { - } - -protected: - HANDLE m_handle; - - void SetProperty(REFGUID guidPropertySet, ULONG nProperty, void* pvValue, ULONG cbValue) - { - KSPROPERTY ksProperty; - memset(&ksProperty, 0, sizeof ksProperty); - ksProperty.Set = guidPropertySet; - ksProperty.Id = nProperty; - ksProperty.Flags = KSPROPERTY_TYPE_SET; - - HRESULT hr = DeviceIoControlKsProperty(ksProperty, pvValue, cbValue); - if (FAILED(hr)) - { - printf("CKsObject::SetProperty: could not set property"); - exit(0); - } - } - -private: - - HRESULT DeviceIoControlKsProperty(KSPROPERTY& ksProperty, void* pvValue, ULONG cbValue) - { - ULONG ulReturned; - return ::DeviceIoControl( - m_handle, - IOCTL_KS_PROPERTY, - &ksProperty, - sizeof(ksProperty), - pvValue, - cbValue, - &ulReturned, - NULL); - } -}; - -class CKsPin; - -class CKsFilter : public CKsObject -{ - friend class CKsPin; - -public: - CKsFilter(tstring const& name, std::string const& sFriendlyName); - virtual ~CKsFilter(); - - virtual void Instantiate(); - - template - T GetPinProperty(ULONG nPinId, ULONG nProperty) - { - ULONG ulReturned = 0; - T value; - - KSP_PIN ksPProp; - ksPProp.Property.Set = KSPROPSETID_Pin; - ksPProp.Property.Id = nProperty; - ksPProp.Property.Flags = KSPROPERTY_TYPE_GET; - ksPProp.PinId = nPinId; - ksPProp.Reserved = 0; - - HRESULT hr = ::DeviceIoControl( - m_handle, - IOCTL_KS_PROPERTY, - &ksPProp, - sizeof(KSP_PIN), - &value, - sizeof(value), - &ulReturned, - NULL); - if (FAILED(hr)) - { - printf("CKsFilter::GetPinProperty: failed to retrieve property"); - exit(0); - } - - return value; - } - - void GetPinPropertyMulti(ULONG nPinId, REFGUID guidPropertySet, ULONG nProperty, PKSMULTIPLE_ITEM* ppKsMultipleItem) - { - HRESULT hr; - - KSP_PIN ksPProp; - ksPProp.Property.Set = guidPropertySet; - ksPProp.Property.Id = nProperty; - ksPProp.Property.Flags = KSPROPERTY_TYPE_GET; - ksPProp.PinId = nPinId; - ksPProp.Reserved = 0; - - ULONG cbMultipleItem = 0; - hr = ::DeviceIoControl(m_handle, - IOCTL_KS_PROPERTY, - &ksPProp.Property, - sizeof(KSP_PIN), - NULL, - 0, - &cbMultipleItem, - NULL); - if (FAILED(hr)) - { - printf("CKsFilter::GetPinPropertyMulti: cannot get property"); - exit(0); - } - - *ppKsMultipleItem = (PKSMULTIPLE_ITEM) new BYTE[cbMultipleItem]; - - ULONG ulReturned = 0; - hr = ::DeviceIoControl( - m_handle, - IOCTL_KS_PROPERTY, - &ksPProp, - sizeof(KSP_PIN), - (PVOID)*ppKsMultipleItem, - cbMultipleItem, - &ulReturned, - NULL); - if (FAILED(hr)) - { - printf("CKsFilter::GetPinPropertyMulti: cannot get property"); - exit(0); - } - } - - std::string const& GetFriendlyName() const - { - return m_sFriendlyName; - } - -protected: - - std::vector m_Pins; // this list owns the pins. - - std::vector m_RenderPins; - std::vector m_CapturePins; - -private: - std::string const m_sFriendlyName; // friendly name eg "Virus TI Synth" - tstring const m_sName; // Filter path, eg "\\?\usb#vid_133e&pid_0815...\vtimidi02" -}; - -class CKsPin : public CKsObject -{ -public: - CKsPin(CKsFilter* pFilter, ULONG nId); - virtual ~CKsPin(); - - virtual void Instantiate(); - - void ClosePin(); - - void SetState(KSSTATE ksState); - - void WriteData(KSSTREAM_HEADER* pKSSTREAM_HEADER, OVERLAPPED* pOVERLAPPED); - void ReadData(KSSTREAM_HEADER* pKSSTREAM_HEADER, OVERLAPPED* pOVERLAPPED); - - KSPIN_DATAFLOW GetDataFlow() const - { - return m_DataFlow; - } - - bool IsSink() const - { - return m_Communication == KSPIN_COMMUNICATION_SINK - || m_Communication == KSPIN_COMMUNICATION_BOTH; - } - - -protected: - PKSPIN_CONNECT m_pKsPinConnect; // creation parameters of pin - CKsFilter* const m_pFilter; - - ULONG m_cInterfaces; - PKSIDENTIFIER m_pInterfaces; - PKSMULTIPLE_ITEM m_pmiInterfaces; - - ULONG m_cMediums; - PKSIDENTIFIER m_pMediums; - PKSMULTIPLE_ITEM m_pmiMediums; - - ULONG m_cDataRanges; - PKSDATARANGE m_pDataRanges; - PKSMULTIPLE_ITEM m_pmiDataRanges; - - KSPIN_DATAFLOW m_DataFlow; - KSPIN_COMMUNICATION m_Communication; -}; - -CKsFilter::CKsFilter(tstring const& sName, std::string const& sFriendlyName) : - CKsObject(INVALID_HANDLE_VALUE), - m_sFriendlyName(sFriendlyName), - m_sName(sName) -{ - if (sName.empty()) - { - printf("CKsFilter::CKsFilter: name can't be empty"); - assert(0); - } -} - -CKsFilter::~CKsFilter() -{ - for (size_t i=0;i < m_Pins.size();++i) - delete m_Pins[i]; - - if (IsValid(m_handle)) - ::CloseHandle(m_handle); -} - -void CKsFilter::Instantiate() -{ - m_handle = CreateFile( - m_sName.c_str(), - GENERIC_READ | GENERIC_WRITE, - 0, - NULL, - OPEN_EXISTING, - FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED, - NULL); - - if (!IsValid(m_handle)) - { - DWORD const dwError = GetLastError(); - throw ComException("CKsFilter::Instantiate: can't open driver", HRESULT_FROM_WIN32(dwError)); - } -} - -CKsPin::CKsPin(CKsFilter* pFilter, ULONG PinId) : - CKsObject(INVALID_HANDLE_VALUE), - m_pKsPinConnect(NULL), - m_pFilter(pFilter) -{ - m_Communication = m_pFilter->GetPinProperty(PinId, KSPROPERTY_PIN_COMMUNICATION); - m_DataFlow = m_pFilter->GetPinProperty(PinId, KSPROPERTY_PIN_DATAFLOW); - - // Interfaces - m_pFilter->GetPinPropertyMulti( - PinId, - KSPROPSETID_Pin, - KSPROPERTY_PIN_INTERFACES, - &m_pmiInterfaces); - - m_cInterfaces = m_pmiInterfaces->Count; - m_pInterfaces = (PKSPIN_INTERFACE)(m_pmiInterfaces + 1); - - // Mediums - m_pFilter->GetPinPropertyMulti( - PinId, - KSPROPSETID_Pin, - KSPROPERTY_PIN_MEDIUMS, - &m_pmiMediums); - - m_cMediums = m_pmiMediums->Count; - m_pMediums = (PKSPIN_MEDIUM)(m_pmiMediums + 1); - - // Data ranges - m_pFilter->GetPinPropertyMulti( - PinId, - KSPROPSETID_Pin, - KSPROPERTY_PIN_DATARANGES, - &m_pmiDataRanges); - - m_cDataRanges = m_pmiDataRanges->Count; - m_pDataRanges = (PKSDATARANGE)(m_pmiDataRanges + 1); -} - -CKsPin::~CKsPin() -{ - ClosePin(); - - delete[] (BYTE*)m_pKsPinConnect; - delete[] (BYTE*)m_pmiDataRanges; - delete[] (BYTE*)m_pmiInterfaces; - delete[] (BYTE*)m_pmiMediums; -} - -void CKsPin::ClosePin() -{ - if (IsValid(m_handle)) { - SetState(KSSTATE_STOP); - ::CloseHandle(m_handle); - } - m_handle = INVALID_HANDLE_VALUE; -} - -void CKsPin::SetState(KSSTATE ksState) -{ - SetProperty(KSPROPSETID_Connection, KSPROPERTY_CONNECTION_STATE, &ksState, sizeof(ksState)); -} - -void CKsPin::Instantiate() -{ - if (!m_pKsPinConnect) - { - printf("CKsPin::Instanciate: abstract pin"); - assert(0); - } - DWORD const dwResult = KsCreatePin(m_pFilter->m_handle, m_pKsPinConnect, GENERIC_WRITE | GENERIC_READ, &m_handle); - if (dwResult != ERROR_SUCCESS) - throw ComException("CKsMidiCapFilter::CreateRenderPin: Pin instanciation failed", HRESULT_FROM_WIN32(dwResult)); -} - -void CKsPin::WriteData(KSSTREAM_HEADER* pKSSTREAM_HEADER, OVERLAPPED* pOVERLAPPED) -{ - DWORD cbWritten; - BOOL fRes = ::DeviceIoControl( - m_handle, - IOCTL_KS_WRITE_STREAM, - NULL, - 0, - pKSSTREAM_HEADER, - pKSSTREAM_HEADER->Size, - &cbWritten, - pOVERLAPPED); - if (!fRes) { - DWORD const dwError = GetLastError(); - if (dwError != ERROR_IO_PENDING) - throw ComException("CKsPin::WriteData: DeviceIoControl failed", HRESULT_FROM_WIN32(dwError)); - } -} - -void CKsPin::ReadData(KSSTREAM_HEADER* pKSSTREAM_HEADER, OVERLAPPED* pOVERLAPPED) -{ - DWORD cbReturned; - BOOL fRes = ::DeviceIoControl( - m_handle, - IOCTL_KS_READ_STREAM, - NULL, - 0, - pKSSTREAM_HEADER, - pKSSTREAM_HEADER->Size, - &cbReturned, - pOVERLAPPED); - if (!fRes) { - DWORD const dwError = GetLastError(); - if (dwError != ERROR_IO_PENDING) - throw ComException("CKsPin::ReadData: DeviceIoControl failed", HRESULT_FROM_WIN32(dwError)); - } -} - -class CKsMidiFilter : public CKsFilter -{ -public: - void FindMidiPins(); - -protected: - CKsMidiFilter(tstring const& sPath, std::string const& sFriendlyName); -}; - -class CKsMidiPin : public CKsPin -{ -public: - CKsMidiPin(CKsFilter* pFilter, ULONG nId); -}; - -class CKsMidiRenFilter : public CKsMidiFilter -{ -public: - CKsMidiRenFilter(tstring const& sPath, std::string const& sFriendlyName); - CKsMidiPin* CreateRenderPin(); - - void Validate() - { - if (m_RenderPins.empty()) - { - printf("Could not find a MIDI render pin"); - assert(0); - } - } -}; - -class CKsMidiCapFilter : public CKsMidiFilter -{ -public: - CKsMidiCapFilter(tstring const& sPath, std::string const& sFriendlyName); - CKsMidiPin* CreateCapturePin(); - - void Validate() - { - if (m_CapturePins.empty()) - { - assert(0); - printf("Could not find a MIDI capture pin"); - } - } -}; - -CKsMidiFilter::CKsMidiFilter(tstring const& sPath, std::string const& sFriendlyName) : - CKsFilter(sPath, sFriendlyName) -{ -} - -void CKsMidiFilter::FindMidiPins() -{ - ULONG numPins = GetPinProperty(0, KSPROPERTY_PIN_CTYPES); - - for (ULONG iPin = 0; iPin < numPins; ++iPin) { - { - KSPIN_COMMUNICATION com = GetPinProperty(iPin, KSPROPERTY_PIN_COMMUNICATION); - if (com != KSPIN_COMMUNICATION_SINK && com != KSPIN_COMMUNICATION_BOTH) - { - printf("Unknown pin communication value"); - assert(0); - } - - m_Pins.push_back(new CKsMidiPin(this, iPin)); - } - - } - - m_RenderPins.clear(); - m_CapturePins.clear(); - - for (size_t i = 0; i < m_Pins.size(); ++i) { - CKsPin* const pPin = m_Pins[i]; - - if (pPin->IsSink()) { - if (pPin->GetDataFlow() == KSPIN_DATAFLOW_IN) - m_RenderPins.push_back(pPin); - else - m_CapturePins.push_back(pPin); - } - } - - if (m_RenderPins.empty() && m_CapturePins.empty()) - { - printf("No valid pins found on the filter."); - assert(0); - - } -} - -CKsMidiRenFilter::CKsMidiRenFilter(tstring const& sPath, std::string const& sFriendlyName) : - CKsMidiFilter(sPath, sFriendlyName) -{ -} - -CKsMidiPin* CKsMidiRenFilter::CreateRenderPin() -{ - if (m_RenderPins.empty()) - { - printf("Could not find a MIDI render pin"); - assert(0); - } - - CKsMidiPin* pPin = (CKsMidiPin*)m_RenderPins[0]; - pPin->Instantiate(); - return pPin; -} - -CKsMidiCapFilter::CKsMidiCapFilter(tstring const& sPath, std::string const& sFriendlyName) : - CKsMidiFilter(sPath, sFriendlyName) -{ -} - -CKsMidiPin* CKsMidiCapFilter::CreateCapturePin() -{ - if (m_CapturePins.empty()) - { - printf("Could not find a MIDI capture pin"); - assert(0); - } - CKsMidiPin* pPin = (CKsMidiPin*)m_CapturePins[0]; - pPin->Instantiate(); - return pPin; -} - -CKsMidiPin::CKsMidiPin(CKsFilter* pFilter, ULONG nId) : - CKsPin(pFilter, nId) -{ - DWORD const cbPinCreateSize = sizeof(KSPIN_CONNECT) + sizeof(KSDATAFORMAT); - m_pKsPinConnect = (PKSPIN_CONNECT) new BYTE[cbPinCreateSize]; - - m_pKsPinConnect->Interface.Set = KSINTERFACESETID_Standard; - m_pKsPinConnect->Interface.Id = KSINTERFACE_STANDARD_STREAMING; - m_pKsPinConnect->Interface.Flags = 0; - m_pKsPinConnect->Medium.Set = KSMEDIUMSETID_Standard; - m_pKsPinConnect->Medium.Id = KSMEDIUM_TYPE_ANYINSTANCE; - m_pKsPinConnect->Medium.Flags = 0; - m_pKsPinConnect->PinId = nId; - m_pKsPinConnect->PinToHandle = NULL; - m_pKsPinConnect->Priority.PriorityClass = KSPRIORITY_NORMAL; - m_pKsPinConnect->Priority.PrioritySubClass = 1; - - // point m_pDataFormat to just after the pConnect struct - KSDATAFORMAT* m_pDataFormat = (KSDATAFORMAT*)(m_pKsPinConnect + 1); - m_pDataFormat->FormatSize = sizeof(KSDATAFORMAT); - m_pDataFormat->Flags = 0; - m_pDataFormat->SampleSize = 0; - m_pDataFormat->Reserved = 0; - m_pDataFormat->MajorFormat = GUID(KSDATAFORMAT_TYPE_MUSIC); - m_pDataFormat->SubFormat = GUID(KSDATAFORMAT_SUBTYPE_MIDI); - m_pDataFormat->Specifier = GUID(KSDATAFORMAT_SPECIFIER_NONE); - - bool hasStdStreamingInterface = false; - bool hasStdStreamingMedium = false; - - for ( ULONG i = 0; i < m_cInterfaces; i++ ) { - if (m_pInterfaces[i].Set == KSINTERFACESETID_Standard - && m_pInterfaces[i].Id == KSINTERFACE_STANDARD_STREAMING) - hasStdStreamingInterface = true; - } - - for (ULONG i = 0; i < m_cMediums; i++) { - if (m_pMediums[i].Set == KSMEDIUMSETID_Standard - && m_pMediums[i].Id == KSMEDIUM_STANDARD_DEVIO) - hasStdStreamingMedium = true; - } - - if (!hasStdStreamingInterface) // No standard streaming interfaces on the pin - { - printf("CKsMidiPin::CKsMidiPin: no standard streaming interface"); - assert(0); - } - - if (!hasStdStreamingMedium) // No standard streaming mediums on the pin - { - printf("CKsMidiPin::CKsMidiPin: no standard streaming medium") - assert(0); - }; - - bool hasMidiDataRange = false; - - BYTE const* pDataRangePtr = reinterpret_cast(m_pDataRanges); - - for (ULONG i = 0; i < m_cDataRanges; ++i) { - KSDATARANGE const* pDataRange = reinterpret_cast(pDataRangePtr); - - if (pDataRange->SubFormat == KSDATAFORMAT_SUBTYPE_MIDI) { - hasMidiDataRange = true; - break; - } - - pDataRangePtr += pDataRange->FormatSize; - } - - if (!hasMidiDataRange) // No MIDI dataranges on the pin - { - printf("CKsMidiPin::CKsMidiPin: no MIDI datarange"); - assert(0); - } -} - - -struct WindowsKsData -{ - WindowsKsData() : m_pPin(NULL), m_Buffer(1024), m_hInputThread(NULL) - { - memset(&overlapped, 0, sizeof(OVERLAPPED)); - m_hExitEvent = ::CreateEvent(NULL, FALSE, FALSE, NULL); - overlapped.hEvent = ::CreateEvent(NULL, FALSE, FALSE, NULL); - m_hInputThread = NULL; - } - - ~WindowsKsData() - { - ::CloseHandle(overlapped.hEvent); - ::CloseHandle(m_hExitEvent); - } - - OVERLAPPED overlapped; - CKsPin* m_pPin; - std::vector m_Buffer; - std::auto_ptr > m_pCaptureEnum; - std::auto_ptr > m_pRenderEnum; - HANDLE m_hInputThread; - HANDLE m_hExitEvent; -}; - -// *********************************************************************// -// API: WINDOWS Kernel Streaming -// Class Definitions: MidiInWinKS -// *********************************************************************// - -DWORD WINAPI midiKsInputThread(VOID* pUser) -{ - MidiInApi::RtMidiInData* data = static_cast(pUser); - WindowsKsData* apiData = static_cast(data->apiData); - - HANDLE hEvents[] = { apiData->overlapped.hEvent, apiData->m_hExitEvent }; - - while ( true ) { - KSSTREAM_HEADER packet; - memset(&packet, 0, sizeof packet); - packet.Size = sizeof(KSSTREAM_HEADER); - packet.PresentationTime.Time = 0; - packet.PresentationTime.Numerator = 1; - packet.PresentationTime.Denominator = 1; - packet.Data = &apiData->m_Buffer[0]; - packet.DataUsed = 0; - packet.FrameExtent = apiData->m_Buffer.size(); - apiData->m_pPin->ReadData(&packet, &apiData->overlapped); - - DWORD dwRet = ::WaitForMultipleObjects(2, hEvents, FALSE, INFINITE); - - if ( dwRet == WAIT_OBJECT_0 ) { - // parse packet - unsigned char* pData = (unsigned char*)packet.Data; - unsigned int iOffset = 0; - - while ( iOffset < packet.DataUsed ) { - KSMUSICFORMAT* pMusic = (KSMUSICFORMAT*)&pData[iOffset]; - iOffset += sizeof(KSMUSICFORMAT); - - MidiInApi::MidiMessage message; - message.timeStamp = 0; - for(size_t i=0;i < pMusic->ByteCount;++i) - message.bytes.push_back(pData[iOffset+i]); - - if ( data->usingCallback ) { - RtMidiIn::RtMidiCallback callback = (RtMidiIn::RtMidiCallback)data->userCallback; - callback(message.timeStamp, &message.bytes, data->userData); - } - else { - // As long as we haven't reached our queue size limit, push the message. - if ( data->queue.size < data->queue.ringSize ) { - data->queue.ring[data->queue.back++] = message; - if(data->queue.back == data->queue.ringSize) - data->queue.back = 0; - data->queue.size++; - } - else - std::cerr << "\nRtMidiIn: message queue limit reached!!\n\n"; - } - - iOffset += pMusic->ByteCount; - - // re-align on 32 bits - if ( iOffset % 4 != 0 ) - iOffset += (4 - iOffset % 4); - } - } - else - break; - } - return 0; -} - -MidiInWinKS :: MidiInWinKS( const std::string clientName, unsigned int queueSizeLimit ) : MidiInApi( queueSizeLimit ) -{ - initialize( clientName ); -} - -void MidiInWinKS :: initialize( const std::string& clientName ) -{ - WindowsKsData* data = new WindowsKsData; - apiData_ = (void*)data; - inputData_.apiData = data; - - GUID const aguidEnumCats[] = - { - { STATIC_KSCATEGORY_AUDIO }, { STATIC_KSCATEGORY_CAPTURE } - }; - data->m_pCaptureEnum.reset(new CKsEnumFilters ); - data->m_pCaptureEnum->EnumFilters(aguidEnumCats, 2); -} - -MidiInWinKS :: ~MidiInWinKS() -{ - WindowsKsData* data = static_cast(apiData_); - { - if ( data->m_pPin ) - closePort(); - } - - delete data; -} - -void MidiInWinKS :: openPort( unsigned int portNumber, const std::string portName ) -{ - WindowsKsData* data = static_cast(apiData_); - - if ( portNumber < 0 || portNumber >= data->m_pCaptureEnum->m_Filters.size() ) { - std::stringstream ost; - ost << "MidiInWinKS::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - CKsMidiCapFilter* pFilter = data->m_pCaptureEnum->m_Filters[portNumber]; - data->m_pPin = pFilter->CreateCapturePin(); - - if ( data->m_pPin == NULL ) { - std::stringstream ost; - ost << "MidiInWinKS::openPort: KS error opening port (could not create pin)"; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - data->m_pPin->SetState(KSSTATE_RUN); - - DWORD threadId; - data->m_hInputThread = ::CreateThread(NULL, 0, &midiKsInputThread, &inputData_, 0, &threadId); - if ( data->m_hInputThread == NULL ) { - std::stringstream ost; - ost << "MidiInWinKS::initialize: Could not create input thread : Windows error " << GetLastError() << std::endl;; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - connected_ = true; -} - -void MidiInWinKS :: openVirtualPort( const std::string portName ) -{ - // This function cannot be implemented for the Windows KS MIDI API. - errorString_ = "MidiInWinKS::openVirtualPort: cannot be implemented in Windows KS MIDI API!"; - RtMidi::error( RtError::WARNING, errorString_ ); -} - -unsigned int MidiInWinKS :: getPortCount() -{ - WindowsKsData* data = static_cast(apiData_); - return (unsigned int)data->m_pCaptureEnum->m_Filters.size(); -} - -std::string MidiInWinKS :: getPortName(unsigned int portNumber) -{ - WindowsKsData* data = static_cast(apiData_); - - if(portNumber < 0 || portNumber >= data->m_pCaptureEnum->m_Filters.size()) { - std::stringstream ost; - ost << "MidiInWinKS::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - CKsMidiCapFilter* pFilter = data->m_pCaptureEnum->m_Filters[portNumber]; - return pFilter->GetFriendlyName(); -} - -void MidiInWinKS :: closePort() -{ - WindowsKsData* data = static_cast(apiData_); - connected_ = false; - - if(data->m_hInputThread) { - ::SignalObjectAndWait(data->m_hExitEvent, data->m_hInputThread, INFINITE, FALSE); - ::CloseHandle(data->m_hInputThread); - } - - if(data->m_pPin) { - data->m_pPin->SetState(KSSTATE_PAUSE); - data->m_pPin->SetState(KSSTATE_STOP); - data->m_pPin->ClosePin(); - data->m_pPin = NULL; - } -} - -// *********************************************************************// -// API: WINDOWS Kernel Streaming -// Class Definitions: MidiOutWinKS -// *********************************************************************// - -MidiOutWinKS :: MidiOutWinKS( const std::string clientName ) : MidiOutApi() -{ - initialize( clientName ); -} - -void MidiOutWinKS :: initialize( const std::string& clientName ) -{ - WindowsKsData* data = new WindowsKsData; - - data->m_pPin = NULL; - data->m_pRenderEnum.reset(new CKsEnumFilters ); - GUID const aguidEnumCats[] = - { - { STATIC_KSCATEGORY_AUDIO }, { STATIC_KSCATEGORY_RENDER } - }; - data->m_pRenderEnum->EnumFilters(aguidEnumCats, 2); - - apiData_ = (void*)data; -} - -MidiOutWinKS :: ~MidiOutWinKS() -{ - // Close a connection if it exists. - closePort(); - - // Cleanup. - WindowsKsData* data = static_cast(apiData_); - delete data; -} - -void MidiOutWinKS :: openPort( unsigned int portNumber, const std::string portName ) -{ - WindowsKsData* data = static_cast(apiData_); - - if(portNumber < 0 || portNumber >= data->m_pRenderEnum->m_Filters.size()) { - std::stringstream ost; - ost << "MidiOutWinKS::openPort: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - CKsMidiRenFilter* pFilter = data->m_pRenderEnum->m_Filters[portNumber]; - data->m_pPin = pFilter->CreateRenderPin(); - - if(data->m_pPin == NULL) { - std::stringstream ost; - ost << "MidiOutWinKS::openPort: KS error opening port (could not create pin)"; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - data->m_pPin->SetState(KSSTATE_RUN); - connected_ = true; -} - -void MidiOutWinKS :: openVirtualPort( const std::string portName ) -{ - // This function cannot be implemented for the Windows KS MIDI API. - errorString_ = "MidiOutWinKS::openVirtualPort: cannot be implemented in Windows KS MIDI API!"; - RtMidi::error( RtError::WARNING, errorString_ ); -} - -unsigned int MidiOutWinKS :: getPortCount() -{ - WindowsKsData* data = static_cast(apiData_); - - return (unsigned int)data->m_pRenderEnum->m_Filters.size(); -} - -std::string MidiOutWinKS :: getPortName( unsigned int portNumber ) -{ - WindowsKsData* data = static_cast(apiData_); - - if ( portNumber < 0 || portNumber >= data->m_pRenderEnum->m_Filters.size() ) { - std::stringstream ost; - ost << "MidiOutWinKS::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - CKsMidiRenFilter* pFilter = data->m_pRenderEnum->m_Filters[portNumber]; - return pFilter->GetFriendlyName(); -} - -void MidiOutWinKS :: closePort() -{ - WindowsKsData* data = static_cast(apiData_); - connected_ = false; - - if ( data->m_pPin ) { - data->m_pPin->SetState(KSSTATE_PAUSE); - data->m_pPin->SetState(KSSTATE_STOP); - data->m_pPin->ClosePin(); - data->m_pPin = NULL; - } -} - -void MidiOutWinKS :: sendMessage(std::vector* pMessage) -{ - std::vector const& msg = *pMessage; - WindowsKsData* data = static_cast(apiData_); - size_t iNumMidiBytes = msg.size(); - size_t pos = 0; - - // write header - KSMUSICFORMAT* pKsMusicFormat = reinterpret_cast(&data->m_Buffer[pos]); - pKsMusicFormat->TimeDeltaMs = 0; - pKsMusicFormat->ByteCount = iNumMidiBytes; - pos += sizeof(KSMUSICFORMAT); - - // write MIDI bytes - if ( pos + iNumMidiBytes > data->m_Buffer.size() ) { - std::stringstream ost; - ost << "KsMidiInput::Write: MIDI buffer too small. Required " << pos + iNumMidiBytes << " bytes, only has " << data->m_Buffer.size(); - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - if ( data->m_pPin == NULL ) { - std::stringstream ost; - ost << "MidiOutWinKS::sendMessage: port is not open"; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - - memcpy(&data->m_Buffer[pos], &msg[0], iNumMidiBytes); - pos += iNumMidiBytes; - - KSSTREAM_HEADER packet; - memset(&packet, 0, sizeof packet); - packet.Size = sizeof(packet); - packet.PresentationTime.Time = 0; - packet.PresentationTime.Numerator = 1; - packet.PresentationTime.Denominator = 1; - packet.Data = const_cast(&data->m_Buffer[0]); - packet.DataUsed = ((pos+3)/4)*4; - packet.FrameExtent = data->m_Buffer.size(); - - data->m_pPin->WriteData(&packet, NULL); -} - -#endif // __WINDOWS_KS__ - -//*********************************************************************// -// API: UNIX JACK -// -// Written primarily by Alexander Svetalkin, with updates for delta -// time by Gary Scavone, April 2011. -// -// *********************************************************************// - -#if defined(__UNIX_JACK__) - -// JACK header files -#include -#include -#include - -#define JACK_RINGBUFFER_SIZE 16384 // Default size for ringbuffer - -struct JackMidiData { - jack_client_t *client; - jack_port_t *port; - jack_ringbuffer_t *buffSize; - jack_ringbuffer_t *buffMessage; - jack_time_t lastTime; - MidiInApi :: RtMidiInData *rtMidiIn; - }; - -//*********************************************************************// -// API: JACK -// Class Definitions: MidiInJack -//*********************************************************************// - -int jackProcessIn( jack_nframes_t nframes, void *arg ) -{ - JackMidiData *jData = (JackMidiData *) arg; - MidiInApi :: RtMidiInData *rtData = jData->rtMidiIn; - jack_midi_event_t event; - jack_time_t long long time; - - // Is port created? - if ( jData->port == NULL ) return 0; - void *buff = jack_port_get_buffer( jData->port, nframes ); - - // We have midi events in buffer - int evCount = jack_midi_get_event_count( buff ); - if ( evCount > 0 ) { - MidiInApi::MidiMessage message; - message.bytes.clear(); - - jack_midi_event_get( &event, buff, 0 ); - - for (unsigned int i = 0; i < event.size; i++ ) - message.bytes.push_back( event.buffer[i] ); - - // Compute the delta time. - time = jack_get_time(); - if ( rtData->firstMessage == true ) - rtData->firstMessage = false; - else - message.timeStamp = ( time - jData->lastTime ) * 0.000001; - - jData->lastTime = time; - - if ( !rtData->continueSysex ) { - if ( rtData->usingCallback ) { - RtMidiIn::RtMidiCallback callback = (RtMidiIn::RtMidiCallback) rtData->userCallback; - callback( message.timeStamp, &message.bytes, rtData->userData ); - } - else { - // As long as we haven't reached our queue size limit, push the message. - if ( rtData->queue.size < rtData->queue.ringSize ) { - rtData->queue.ring[rtData->queue.back++] = message; - if ( rtData->queue.back == rtData->queue.ringSize ) - rtData->queue.back = 0; - rtData->queue.size++; - } - else - std::cerr << "\nMidiInJack: message queue limit reached!!\n\n"; - } - } - } - - return 0; -} - -MidiInJack :: MidiInJack( const std::string clientName, unsigned int queueSizeLimit ) : MidiInApi( queueSizeLimit ) -{ - initialize( clientName ); -} - -void MidiInJack :: initialize( const std::string& clientName ) -{ - JackMidiData *data = new JackMidiData; - apiData_ = (void *) data; - - // Initialize JACK client - if (( data->client = jack_client_open( clientName.c_str(), JackNullOption, NULL )) == 0) { - errorString_ = "MidiInJack::initialize: JACK server not running?"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - return; - } - - data->rtMidiIn = &inputData_; - data->port = NULL; - - jack_set_process_callback( data->client, jackProcessIn, data ); - jack_activate( data->client ); -} - -MidiInJack :: ~MidiInJack() -{ - JackMidiData *data = static_cast (apiData_); - closePort(); - - jack_client_close( data->client ); -} - -void MidiInJack :: openPort( unsigned int portNumber, const std::string portName ) -{ - JackMidiData *data = static_cast (apiData_); - - // Creating new port - if ( data->port == NULL) - data->port = jack_port_register( data->client, portName.c_str(), - JACK_DEFAULT_MIDI_TYPE, JackPortIsInput, 0 ); - - if ( data->port == NULL) { - errorString_ = "MidiInJack::openVirtualPort: JACK error creating virtual port"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Connecting to the output - std::string name = getPortName( portNumber ); - jack_connect( data->client, name.c_str(), jack_port_name( data->port ) ); -} - -void MidiInJack :: openVirtualPort( const std::string portName ) -{ - JackMidiData *data = static_cast (apiData_); - - if ( data->port == NULL ) - data->port = jack_port_register( data->client, portName.c_str(), - JACK_DEFAULT_MIDI_TYPE, JackPortIsInput, 0 ); - - if ( data->port == NULL ) { - errorString_ = "MidiInJack::openVirtualPort: JACK error creating virtual port"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } -} - -unsigned int MidiInJack :: getPortCount() -{ - int count = 0; - JackMidiData *data = static_cast (apiData_); - - // List of available ports - const char **ports = jack_get_ports( data->client, NULL, JACK_DEFAULT_MIDI_TYPE, JackPortIsOutput ); - - if ( ports == NULL ) return 0; - while ( ports[count] != NULL ) - count++; - - free( ports ); - - return count; -} - -std::string MidiInJack :: getPortName( unsigned int portNumber ) -{ - JackMidiData *data = static_cast (apiData_); - std::ostringstream ost; - std::string retStr(""); - - // List of available ports - const char **ports = jack_get_ports( data->client, NULL, - JACK_DEFAULT_MIDI_TYPE, JackPortIsOutput ); - - // Check port validity - if ( ports == NULL ) { - errorString_ = "MidiInJack::getPortName: no ports available!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return retStr; - } - - if ( ports[portNumber] == NULL ) { - ost << "MidiInJack::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - else retStr.assign( ports[portNumber] ); - - free( ports ); - - return retStr; -} - -void MidiInJack :: closePort() -{ - JackMidiData *data = static_cast (apiData_); - - if ( data->port == NULL ) return; - jack_port_unregister( data->client, data->port ); - data->port = NULL; -} - -//*********************************************************************// -// API: JACK -// Class Definitions: MidiOutJack -//*********************************************************************// - -// Jack process callback -int jackProcessOut( jack_nframes_t nframes, void *arg ) -{ - JackMidiData *data = (JackMidiData *) arg; - jack_midi_data_t *midiData; - int space; - - // Is port created? - if ( data->port == NULL ) return 0; - - void *buff = jack_port_get_buffer( data->port, nframes ); - jack_midi_clear_buffer( buff ); - - while ( jack_ringbuffer_read_space( data->buffSize ) > 0 ) { - jack_ringbuffer_read( data->buffSize, (char *) &space, (size_t) sizeof(space) ); - midiData = jack_midi_event_reserve( buff, 0, space ); - - jack_ringbuffer_read( data->buffMessage, (char *) midiData, (size_t) space ); - } - - return 0; -} - -MidiOutJack :: MidiOutJack( const std::string clientName ) : MidiOutApi() -{ - initialize( clientName ); -} - -void MidiOutJack :: initialize( const std::string& clientName ) -{ - JackMidiData *data = new JackMidiData; - - data->port = NULL; - - // Initialize JACK client - if (( data->client = jack_client_open( clientName.c_str(), JackNullOption, NULL )) == 0) { - errorString_ = "MidiOutJack::initialize: JACK server not running?"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - return; - } - - jack_set_process_callback( data->client, jackProcessOut, data ); - data->buffSize = jack_ringbuffer_create( JACK_RINGBUFFER_SIZE ); - data->buffMessage = jack_ringbuffer_create( JACK_RINGBUFFER_SIZE ); - jack_activate( data->client ); - - apiData_ = (void *) data; -} - -MidiOutJack :: ~MidiOutJack() -{ - JackMidiData *data = static_cast (apiData_); - closePort(); - - // Cleanup - jack_client_close( data->client ); - jack_ringbuffer_free( data->buffSize ); - jack_ringbuffer_free( data->buffMessage ); - - delete data; -} - -void MidiOutJack :: openPort( unsigned int portNumber, const std::string portName ) -{ - JackMidiData *data = static_cast (apiData_); - - // Creating new port - if ( data->port == NULL ) - data->port = jack_port_register( data->client, portName.c_str(), - JACK_DEFAULT_MIDI_TYPE, JackPortIsOutput, 0 ); - - if ( data->port == NULL ) { - errorString_ = "MidiOutJack::openVirtualPort: JACK error creating virtual port"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } - - // Connecting to the output - std::string name = getPortName( portNumber ); - jack_connect( data->client, jack_port_name( data->port ), name.c_str() ); -} - -void MidiOutJack :: openVirtualPort( const std::string portName ) -{ - JackMidiData *data = static_cast (apiData_); - - if ( data->port == NULL ) - data->port = jack_port_register( data->client, portName.c_str(), - JACK_DEFAULT_MIDI_TYPE, JackPortIsOutput, 0 ); - - if ( data->port == NULL ) { - errorString_ = "MidiOutJack::openVirtualPort: JACK error creating virtual port"; - RtMidi::error( RtError::DRIVER_ERROR, errorString_ ); - } -} - -unsigned int MidiOutJack :: getPortCount() -{ - int count = 0; - JackMidiData *data = static_cast (apiData_); - - // List of available ports - const char **ports = jack_get_ports( data->client, NULL, - JACK_DEFAULT_MIDI_TYPE, JackPortIsInput ); - - if ( ports == NULL ) return 0; - while ( ports[count] != NULL ) - count++; - - free( ports ); - - return count; -} - -std::string MidiOutJack :: getPortName( unsigned int portNumber ) -{ - JackMidiData *data = static_cast (apiData_); - std::ostringstream ost; - std::string retStr(""); - - // List of available ports - const char **ports = jack_get_ports( data->client, NULL, - JACK_DEFAULT_MIDI_TYPE, JackPortIsInput ); - - // Check port validity - if ( ports == NULL) { - errorString_ = "MidiOutJack::getPortName: no ports available!"; - RtMidi::error( RtError::WARNING, errorString_ ); - return retStr; - } - - if ( ports[portNumber] == NULL) { - ost << "MidiOutJack::getPortName: the 'portNumber' argument (" << portNumber << ") is invalid."; - errorString_ = ost.str(); - RtMidi::error( RtError::WARNING, errorString_ ); - } - else retStr.assign( ports[portNumber] ); - - free( ports ); - - return retStr; -} - -void MidiOutJack :: closePort() -{ - JackMidiData *data = static_cast (apiData_); - - if ( data->port == NULL ) return; - jack_port_unregister( data->client, data->port ); - data->port = NULL; -} - -void MidiOutJack :: sendMessage( std::vector *message ) -{ - int nBytes = message->size(); - JackMidiData *data = static_cast (apiData_); - - // Write full message to buffer - jack_ringbuffer_write( data->buffMessage, ( const char * ) &( *message )[0], - message->size() ); - jack_ringbuffer_write( data->buffSize, ( char * ) &nBytes, sizeof( nBytes ) ); -} - -#endif // __UNIX_JACK__ diff --git a/btgui/MidiTest/RtMidi.h b/btgui/MidiTest/RtMidi.h deleted file mode 100644 index 878c129d6..000000000 --- a/btgui/MidiTest/RtMidi.h +++ /dev/null @@ -1,675 +0,0 @@ -/**********************************************************************/ -/*! \class RtMidi - \brief An abstract base class for realtime MIDI input/output. - - This class implements some common functionality for the realtime - MIDI input/output subclasses RtMidiIn and RtMidiOut. - - RtMidi WWW site: http://music.mcgill.ca/~gary/rtmidi/ - - RtMidi: realtime MIDI i/o C++ classes - Copyright (c) 2003-2012 Gary P. Scavone - - Permission is hereby granted, free of charge, to any person - obtaining a copy of this software and associated documentation files - (the "Software"), to deal in the Software without restriction, - including without limitation the rights to use, copy, modify, merge, - publish, distribute, sublicense, and/or sell copies of the Software, - and to permit persons to whom the Software is furnished to do so, - subject to the following conditions: - - The above copyright notice and this permission notice shall be - included in all copies or substantial portions of the Software. - - Any person wishing to distribute modifications to the Software is - asked to send the modifications to the original developer so that - they can be incorporated into the canonical version. This is, - however, not a binding provision of this license. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR - ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF - CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -*/ -/**********************************************************************/ - -/*! - \file RtMidi.h - */ - -// RtMidi: Version 2.0.1 - -#ifndef RTMIDI_H -#define RTMIDI_H - -#include "RtError.h" -#include -#include - -class RtMidi -{ - public: - - //! MIDI API specifier arguments. - enum Api { - UNSPECIFIED, /*!< Search for a working compiled API. */ - MACOSX_CORE, /*!< Macintosh OS-X Core Midi API. */ - LINUX_ALSA, /*!< The Advanced Linux Sound Architecture API. */ - UNIX_JACK, /*!< The Jack Low-Latency MIDI Server API. */ - WINDOWS_MM, /*!< The Microsoft Multimedia MIDI API. */ - WINDOWS_KS, /*!< The Microsoft Kernel Streaming MIDI API. */ - RTMIDI_DUMMY /*!< A compilable but non-functional API. */ - }; - - //! A static function to determine the available compiled MIDI APIs. - /*! - The values returned in the std::vector can be compared against - the enumerated list values. Note that there can be more than one - API compiled for certain operating systems. - */ - static void getCompiledApi( std::vector &apis ); - - //! Pure virtual openPort() function. - virtual void openPort( unsigned int portNumber = 0, const std::string portName = std::string( "RtMidi" ) ) = 0; - - //! Pure virtual openVirtualPort() function. - virtual void openVirtualPort( const std::string portName = std::string( "RtMidi" ) ) = 0; - - //! Pure virtual getPortCount() function. - virtual unsigned int getPortCount() = 0; - - //! Pure virtual getPortName() function. - virtual std::string getPortName( unsigned int portNumber = 0 ) = 0; - - //! Pure virtual closePort() function. - virtual void closePort( void ) = 0; - - //! A basic error reporting function for RtMidi classes. - static void error( RtError::Type type, std::string errorString ); - - protected: - - RtMidi() {}; - virtual ~RtMidi() {}; -}; - -/**********************************************************************/ -/*! \class RtMidiIn - \brief A realtime MIDI input class. - - This class provides a common, platform-independent API for - realtime MIDI input. It allows access to a single MIDI input - port. Incoming MIDI messages are either saved to a queue for - retrieval using the getMessage() function or immediately passed to - a user-specified callback function. Create multiple instances of - this class to connect to more than one MIDI device at the same - time. With the OS-X and Linux ALSA MIDI APIs, it is also possible - to open a virtual input port to which other MIDI software clients - can connect. - - by Gary P. Scavone, 2003-2012. -*/ -/**********************************************************************/ - -// **************************************************************** // -// -// RtMidiIn and RtMidiOut class declarations. -// -// RtMidiIn / RtMidiOut are "controllers" used to select an available -// MIDI input or output interface. They present common APIs for the -// user to call but all functionality is implemented by the classes -// MidiInApi, MidiOutApi and their subclasses. RtMidiIn and RtMidiOut -// each create an instance of a MidiInApi or MidiOutApi subclass based -// on the user's API choice. If no choice is made, they attempt to -// make a "logical" API selection. -// -// **************************************************************** // - -class MidiInApi; -class MidiOutApi; - -class RtMidiIn : public RtMidi -{ - public: - - //! User callback function type definition. - typedef void (*RtMidiCallback)( double timeStamp, std::vector *message, void *userData); - - //! Default constructor that allows an optional api, client name and queue size. - /*! - An assert will be fired if a MIDI system initialization - error occurs. The queue size defines the maximum number of - messages that can be held in the MIDI queue (when not using a - callback function). If the queue size limit is reached, - incoming messages will be ignored. - - If no API argument is specified and multiple API support has been - compiled, the default order of use is JACK, ALSA (Linux) and CORE, - Jack (OS-X). - */ - RtMidiIn( RtMidi::Api api=UNSPECIFIED, - const std::string clientName = std::string( "RtMidi Input Client"), - unsigned int queueSizeLimit = 100 ); - - //! If a MIDI connection is still open, it will be closed by the destructor. - ~RtMidiIn ( void ); - - //! Returns the MIDI API specifier for the current instance of RtMidiIn. - RtMidi::Api getCurrentApi( void ); - - //! Open a MIDI input connection. - /*! - An optional port number greater than 0 can be specified. - Otherwise, the default or first port found is opened. - */ - void openPort( unsigned int portNumber = 0, const std::string portName = std::string( "RtMidi Input" ) ); - - //! Create a virtual input port, with optional name, to allow software connections (OS X and ALSA only). - /*! - This function creates a virtual MIDI input port to which other - software applications can connect. This type of functionality - is currently only supported by the Macintosh OS-X and Linux ALSA - APIs (the function does nothing for the other APIs). - */ - void openVirtualPort( const std::string portName = std::string( "RtMidi Input" ) ); - - //! Set a callback function to be invoked for incoming MIDI messages. - /*! - The callback function will be called whenever an incoming MIDI - message is received. While not absolutely necessary, it is best - to set the callback function before opening a MIDI port to avoid - leaving some messages in the queue. - */ - void setCallback( RtMidiCallback callback, void *userData = 0 ); - - //! Cancel use of the current callback function (if one exists). - /*! - Subsequent incoming MIDI messages will be written to the queue - and can be retrieved with the \e getMessage function. - */ - void cancelCallback(); - - //! Close an open MIDI connection (if one exists). - void closePort( void ); - - //! Return the number of available MIDI input ports. - unsigned int getPortCount(); - - //! Return a string identifier for the specified MIDI input port number. - /*! - An empty string is returned if an invalid port specifier is provided. - */ - std::string getPortName( unsigned int portNumber = 0 ); - - //! Specify whether certain MIDI message types should be queued or ignored during input. - /*! - o By default, MIDI timing and active sensing messages are ignored - during message input because of their relative high data rates. - MIDI sysex messages are ignored by default as well. Variable - values of "true" imply that the respective message type will be - ignored. - */ - void ignoreTypes( bool midiSysex = true, bool midiTime = true, bool midiSense = true ); - - //! Fill the user-provided vector with the data bytes for the next available MIDI message in the input queue and return the event delta-time in seconds. - /*! - This function returns immediately whether a new message is - available or not. A valid message is indicated by a non-zero - vector size. An assert is fired if an error occurs during - message retrieval or an input connection was not previously - established. - */ - double getMessage( std::vector *message ); - - protected: - void openMidiApi( RtMidi::Api api, const std::string clientName, unsigned int queueSizeLimit ); - MidiInApi *rtapi_; - -}; - -/**********************************************************************/ -/*! \class RtMidiOut - \brief A realtime MIDI output class. - - This class provides a common, platform-independent API for MIDI - output. It allows one to probe available MIDI output ports, to - connect to one such port, and to send MIDI bytes immediately over - the connection. Create multiple instances of this class to - connect to more than one MIDI device at the same time. With the - OS-X and Linux ALSA MIDI APIs, it is also possible to open a - virtual port to which other MIDI software clients can connect. - - by Gary P. Scavone, 2003-2012. -*/ -/**********************************************************************/ - -class RtMidiOut : public RtMidi -{ - public: - - //! Default constructor that allows an optional client name. - /*! - An exception will be thrown if a MIDI system initialization error occurs. - - If no API argument is specified and multiple API support has been - compiled, the default order of use is JACK, ALSA (Linux) and CORE, - Jack (OS-X). - */ - RtMidiOut( RtMidi::Api api=UNSPECIFIED, - const std::string clientName = std::string( "RtMidi Output Client") ); - - //! The destructor closes any open MIDI connections. - ~RtMidiOut( void ); - - //! Returns the MIDI API specifier for the current instance of RtMidiOut. - RtMidi::Api getCurrentApi( void ); - - //! Open a MIDI output connection. - /*! - An optional port number greater than 0 can be specified. - Otherwise, the default or first port found is opened. An - exception is thrown if an error occurs while attempting to make - the port connection. - */ - void openPort( unsigned int portNumber = 0, const std::string portName = std::string( "RtMidi Output" ) ); - - //! Close an open MIDI connection (if one exists). - void closePort( void ); - - //! Create a virtual output port, with optional name, to allow software connections (OS X and ALSA only). - /*! - This function creates a virtual MIDI output port to which other - software applications can connect. This type of functionality - is currently only supported by the Macintosh OS-X and Linux ALSA - APIs (the function does nothing with the other APIs). An - exception is thrown if an error occurs while attempting to create - the virtual port. - */ - void openVirtualPort( const std::string portName = std::string( "RtMidi Output" ) ); - - //! Return the number of available MIDI output ports. - unsigned int getPortCount( void ); - - //! Return a string identifier for the specified MIDI port type and number. - /*! - An empty string is returned if an invalid port specifier is provided. - */ - std::string getPortName( unsigned int portNumber = 0 ); - - //! Immediately send a single message out an open MIDI output port. - /*! - An exception is thrown if an error occurs during output or an - output connection was not previously established. - */ - void sendMessage( std::vector *message ); - - protected: - void openMidiApi( RtMidi::Api api, const std::string clientName ); - MidiOutApi *rtapi_; -}; - - -// **************************************************************** // -// -// MidiInApi / MidiOutApi class declarations. -// -// Subclasses of MidiInApi and MidiOutApi contain all API- and -// OS-specific code necessary to fully implement the RtMidi API. -// -// Note that MidiInApi and MidiOutApi are abstract base classes and -// cannot be explicitly instantiated. RtMidiIn and RtMidiOut will -// create instances of a MidiInApi or MidiOutApi subclass. -// -// **************************************************************** // - -class MidiInApi -{ - public: - - MidiInApi( unsigned int queueSizeLimit ); - virtual ~MidiInApi( void ); - virtual RtMidi::Api getCurrentApi( void ) = 0; - virtual void openPort( unsigned int portNumber, const std::string portName ) = 0; - virtual void openVirtualPort( const std::string portName ) = 0; - virtual void closePort( void ) = 0; - void setCallback( RtMidiIn::RtMidiCallback callback, void *userData ); - void cancelCallback( void ); - virtual unsigned int getPortCount( void ) = 0; - virtual std::string getPortName( unsigned int portNumber ) = 0; - virtual void ignoreTypes( bool midiSysex, bool midiTime, bool midiSense ); - double getMessage( std::vector *message ); - - // A MIDI structure used internally by the class to store incoming - // messages. Each message represents one and only one MIDI message. - struct MidiMessage { - std::vector bytes; - double timeStamp; - - // Default constructor. - MidiMessage() - :bytes(0), timeStamp(0.0) {} - }; - - struct MidiQueue { - unsigned int front; - unsigned int back; - unsigned int size; - unsigned int ringSize; - MidiMessage *ring; - - // Default constructor. - MidiQueue() - :front(0), back(0), size(0), ringSize(0) {} - }; - - // The RtMidiInData structure is used to pass private class data to - // the MIDI input handling function or thread. - struct RtMidiInData { - MidiQueue queue; - MidiMessage message; - unsigned char ignoreFlags; - bool doInput; - bool firstMessage; - void *apiData; - bool usingCallback; - void *userCallback; - void *userData; - bool continueSysex; - - // Default constructor. - RtMidiInData() - : ignoreFlags(7), doInput(false), firstMessage(true), - apiData(0), usingCallback(false), userCallback(0), userData(0), - continueSysex(false) {} - }; - - protected: - virtual void initialize( const std::string& clientName ) = 0; - RtMidiInData inputData_; - - void *apiData_; - bool connected_; - std::string errorString_; -}; - -class MidiOutApi -{ - public: - - MidiOutApi( void ); - virtual ~MidiOutApi( void ); - virtual RtMidi::Api getCurrentApi( void ) = 0; - virtual void openPort( unsigned int portNumber, const std::string portName ) = 0; - virtual void openVirtualPort( const std::string portName ) = 0; - virtual void closePort( void ) = 0; - virtual unsigned int getPortCount( void ) = 0; - virtual std::string getPortName( unsigned int portNumber ) = 0; - virtual void sendMessage( std::vector *message ) = 0; - - protected: - virtual void initialize( const std::string& clientName ) = 0; - - void *apiData_; - bool connected_; - std::string errorString_; -}; - -// **************************************************************** // -// -// Inline RtMidiIn and RtMidiOut definitions. -// -// **************************************************************** // - -inline RtMidi::Api RtMidiIn :: getCurrentApi( void ) { return rtapi_->getCurrentApi(); } -inline void RtMidiIn :: openPort( unsigned int portNumber, const std::string portName ) { return rtapi_->openPort( portNumber, portName ); } -inline void RtMidiIn :: openVirtualPort( const std::string portName ) { return rtapi_->openVirtualPort( portName ); } -inline void RtMidiIn :: closePort( void ) { return rtapi_->closePort(); } -inline void RtMidiIn :: setCallback( RtMidiCallback callback, void *userData ) { return rtapi_->setCallback( callback, userData ); } -inline void RtMidiIn :: cancelCallback( void ) { return rtapi_->cancelCallback(); } -inline unsigned int RtMidiIn :: getPortCount( void ) { return rtapi_->getPortCount(); } -inline std::string RtMidiIn :: getPortName( unsigned int portNumber ) { return rtapi_->getPortName( portNumber ); } -inline void RtMidiIn :: ignoreTypes( bool midiSysex, bool midiTime, bool midiSense ) { return rtapi_->ignoreTypes( midiSysex, midiTime, midiSense ); } -inline double RtMidiIn :: getMessage( std::vector *message ) { return rtapi_->getMessage( message ); } - -inline RtMidi::Api RtMidiOut :: getCurrentApi( void ) { return rtapi_->getCurrentApi(); } -inline void RtMidiOut :: openPort( unsigned int portNumber, const std::string portName ) { return rtapi_->openPort( portNumber, portName ); } -inline void RtMidiOut :: openVirtualPort( const std::string portName ) { return rtapi_->openVirtualPort( portName ); } -inline void RtMidiOut :: closePort( void ) { return rtapi_->closePort(); } -inline unsigned int RtMidiOut :: getPortCount( void ) { return rtapi_->getPortCount(); } -inline std::string RtMidiOut :: getPortName( unsigned int portNumber ) { return rtapi_->getPortName( portNumber ); } -inline void RtMidiOut :: sendMessage( std::vector *message ) { return rtapi_->sendMessage( message ); } - -// **************************************************************** // -// -// MidiInApi and MidiOutApi subclass prototypes. -// -// **************************************************************** // - -#if !defined(__LINUX_ALSA__) && !defined(__UNIX_JACK__) && !defined(__MACOSX_CORE__) && !defined(__WINDOWS_MM__) && !defined(__WINDOWS_KS__) - #define __RTMIDI_DUMMY__ -#endif - -#if defined(__MACOSX_CORE__) - -class MidiInCore: public MidiInApi -{ - public: - MidiInCore( const std::string clientName, unsigned int queueSizeLimit ); - ~MidiInCore( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::MACOSX_CORE; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - - protected: - void initialize( const std::string& clientName ); -}; - -class MidiOutCore: public MidiOutApi -{ - public: - MidiOutCore( const std::string clientName ); - ~MidiOutCore( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::MACOSX_CORE; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - void sendMessage( std::vector *message ); - - protected: - void initialize( const std::string& clientName ); -}; - -#endif - -#if defined(__UNIX_JACK__) - -class MidiInJack: public MidiInApi -{ - public: - MidiInJack( const std::string clientName, unsigned int queueSizeLimit ); - ~MidiInJack( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::UNIX_JACK; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - - protected: - void initialize( const std::string& clientName ); -}; - -class MidiOutJack: public MidiOutApi -{ - public: - MidiOutJack( const std::string clientName ); - ~MidiOutJack( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::UNIX_JACK; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - void sendMessage( std::vector *message ); - - protected: - void initialize( const std::string& clientName ); -}; - -#endif - -#if defined(__LINUX_ALSA__) - -class MidiInAlsa: public MidiInApi -{ - public: - MidiInAlsa( const std::string clientName, unsigned int queueSizeLimit ); - ~MidiInAlsa( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::LINUX_ALSA; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - - protected: - void initialize( const std::string& clientName ); -}; - -class MidiOutAlsa: public MidiOutApi -{ - public: - MidiOutAlsa( const std::string clientName ); - ~MidiOutAlsa( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::LINUX_ALSA; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - void sendMessage( std::vector *message ); - - protected: - void initialize( const std::string& clientName ); -}; - -#endif - -#if defined(__WINDOWS_MM__) - -class MidiInWinMM: public MidiInApi -{ - public: - MidiInWinMM( const std::string clientName, unsigned int queueSizeLimit ); - ~MidiInWinMM( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::WINDOWS_MM; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - - protected: - void initialize( const std::string& clientName ); -}; - -class MidiOutWinMM: public MidiOutApi -{ - public: - MidiOutWinMM( const std::string clientName ); - ~MidiOutWinMM( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::WINDOWS_MM; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - void sendMessage( std::vector *message ); - - protected: - void initialize( const std::string& clientName ); -}; - -#endif - -#if defined(__WINDOWS_KS__) - -class MidiInWinKS: public MidiInApi -{ - public: - MidiInWinKS( const std::string clientName, unsigned int queueSizeLimit ); - ~MidiInWinKS( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::WINDOWS_KS; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - - protected: - void initialize( const std::string& clientName ); -}; - -class MidiOutWinKS: public MidiOutApi -{ - public: - MidiOutWinKS( const std::string clientName ); - ~MidiOutWinKS( void ); - RtMidi::Api getCurrentApi( void ) { return RtMidi::WINDOWS_KS; }; - void openPort( unsigned int portNumber, const std::string portName ); - void openVirtualPort( const std::string portName ); - void closePort( void ); - unsigned int getPortCount( void ); - std::string getPortName( unsigned int portNumber ); - void sendMessage( std::vector *message ); - - protected: - void initialize( const std::string& clientName ); -}; - -#endif - -#if defined(__RTMIDI_DUMMY__) - -class MidiInDummy: public MidiInApi -{ - public: - MidiInDummy( const std::string clientName, unsigned int queueSizeLimit ) : MidiInApi( queueSizeLimit ) { errorString_ = "MidiInDummy: This class provides no functionality."; RtMidi::error( RtError::WARNING, errorString_ ); }; - RtMidi::Api getCurrentApi( void ) { return RtMidi::RTMIDI_DUMMY; }; - void openPort( unsigned int portNumber, const std::string portName ) {}; - void openVirtualPort( const std::string portName ) {}; - void closePort( void ) {}; - unsigned int getPortCount( void ) { return 0; }; - std::string getPortName( unsigned int portNumber ) { return ""; }; - - protected: - void initialize( const std::string& clientName ) {}; -}; - -class MidiOutDummy: public MidiOutApi -{ - public: - MidiOutDummy( const std::string clientName ) { errorString_ = "MidiOutDummy: This class provides no functionality."; RtMidi::error( RtError::WARNING, errorString_ ); }; - RtMidi::Api getCurrentApi( void ) { return RtMidi::RTMIDI_DUMMY; }; - void openPort( unsigned int portNumber, const std::string portName ) {}; - void openVirtualPort( const std::string portName ) {}; - void closePort( void ) {}; - unsigned int getPortCount( void ) { return 0; }; - std::string getPortName( unsigned int portNumber ) { return ""; }; - void sendMessage( std::vector *message ) {}; - - protected: - void initialize( const std::string& clientName ) {}; -}; - -#endif - -#endif diff --git a/btgui/MidiTest/cmidiin.cpp b/btgui/MidiTest/cmidiin.cpp deleted file mode 100644 index 9de7ab83c..000000000 --- a/btgui/MidiTest/cmidiin.cpp +++ /dev/null @@ -1,112 +0,0 @@ -//*****************************************// -// cmidiin.cpp -// by Gary Scavone, 2003-2004. -// -// Simple program to test MIDI input and -// use of a user callback function. -// -//*****************************************// - -#include -#include -#include "RtMidi.h" - -void usage( void ) { - // Error function in case of incorrect command-line - // argument specifications. - std::cout << "\nuseage: cmidiin \n"; - std::cout << " where port = the device to use (default = 0).\n\n"; - exit( 0 ); -} - -void mycallback( double deltatime, std::vector< unsigned char > *message, void *userData ) -{ - unsigned int nBytes = message->size(); - for ( unsigned int i=0; i 0 ) - std::cout << "stamp = " << deltatime << std::endl; -} - -// This function should be embedded in a try/catch block in case of -// an exception. It offers the user a choice of MIDI ports to open. -// It returns false if there are no ports available. -bool chooseMidiPort( RtMidiIn *rtmidi ); - -int main( int argc, char *argv[] ) -{ - RtMidiIn *midiin = 0; - - // Minimal command-line check. - if ( argc > 2 ) usage(); - - - // RtMidiIn constructor - midiin = new RtMidiIn(); - - // Call function to select port. - if ( chooseMidiPort( midiin ) == false ) goto cleanup; - - // Set our callback function. This should be done immediately after - // opening the port to avoid having incoming messages written to the - // queue instead of sent to the callback function. - midiin->setCallback( &mycallback ); - - // Don't ignore sysex, timing, or active sensing messages. - midiin->ignoreTypes( false, false, false ); - - std::cout << "\nReading MIDI input ... press to quit.\n"; - char input; - std::cin.get(input); - std::cin.get(input); - - - - cleanup: - - delete midiin; - - return 0; -} - -bool chooseMidiPort( RtMidiIn *rtmidi ) -{ - /* - - std::cout << "\nWould you like to open a virtual input port? [y/N] "; - - std::string keyHit; - std::getline( std::cin, keyHit ); - if ( keyHit == "y" ) { - rtmidi->openVirtualPort(); - return true; - } - */ - - std::string portName; - unsigned int i = 0, nPorts = rtmidi->getPortCount(); - if ( nPorts == 0 ) { - std::cout << "No input ports available!" << std::endl; - return false; - } - - if ( nPorts == 1 ) { - std::cout << "\nOpening " << rtmidi->getPortName() << std::endl; - } - else { - for ( i=0; igetPortName(i); - std::cout << " Input port #" << i << ": " << portName << '\n'; - } - - do { - std::cout << "\nChoose a port number: "; - std::cin >> i; - } while ( i >= nPorts ); - } - -// std::getline( std::cin, keyHit ); // used to clear out stdin - rtmidi->openPort( i ); - - return true; -} diff --git a/btgui/MidiTest/premake4.lua b/btgui/MidiTest/premake4.lua deleted file mode 100644 index e09468e6a..000000000 --- a/btgui/MidiTest/premake4.lua +++ /dev/null @@ -1,37 +0,0 @@ - - project "rtMidiTest" - - kind "ConsoleApp" - --- defines { } - - targetdir "../../bin" - - includedirs - { - ".", - } - - --- links { } - - - files { - "**.cpp", - "**.h" - } - if os.is("Windows") then - links {"winmm"} - defines {"__WINDOWS_MM__", "WIN32"} - end - - if os.is("Linux") then - defines {"__LINUX_ALSA__"} - links {"asound","pthread"} - end - - if os.is("MacOSX") then - links{"CoreAudio.framework", "coreMIDI.framework", "Cocoa.framework"} - defines {"__MACOSX_CORE__"} - print ("hi!") - end diff --git a/btgui/MultiThreading/b3PosixThreadSupport.cpp b/btgui/MultiThreading/b3PosixThreadSupport.cpp deleted file mode 100644 index 705e297ce..000000000 --- a/btgui/MultiThreading/b3PosixThreadSupport.cpp +++ /dev/null @@ -1,436 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include -#include "b3PosixThreadSupport.h" -#include -#include - - -#define checkPThreadFunction(returnValue) \ - if(0 != returnValue) { \ - printf("PThread problem at line %i in file %s: %i %d\n", __LINE__, __FILE__, returnValue, errno); \ - } - -// The number of threads should be equal to the number of available cores -// Todo: each worker should be linked to a single core, using SetThreadIdealProcessor. - - -b3PosixThreadSupport::b3PosixThreadSupport(ThreadConstructionInfo& threadConstructionInfo) -{ - startThreads(threadConstructionInfo); -} - -// cleanup/shutdown Libspe2 -b3PosixThreadSupport::~b3PosixThreadSupport() -{ - stopThreads(); -} - -#if (defined (__APPLE__)) -#define NAMED_SEMAPHORES -#endif - -// this semaphore will signal, if and how many threads are finished with their work -static sem_t* mainSemaphore=0; - -static sem_t* createSem(const char* baseName) -{ - static int semCount = 0; -#ifdef NAMED_SEMAPHORES - /// Named semaphore begin - char name[32]; - snprintf(name, 32, "/%s-%d-%4.4d", baseName, getpid(), semCount++); - sem_t* tempSem = sem_open(name, O_CREAT, 0600, 0); - - if (tempSem != reinterpret_cast(SEM_FAILED)) - { -// printf("Created \"%s\" Semaphore %p\n", name, tempSem); - } - else - { - //printf("Error creating Semaphore %d\n", errno); - exit(-1); - } - /// Named semaphore end -#else - sem_t* tempSem = new sem_t; - checkPThreadFunction(sem_init(tempSem, 0, 0)); -#endif - return tempSem; -} - -static void destroySem(sem_t* semaphore) -{ -#ifdef NAMED_SEMAPHORES - checkPThreadFunction(sem_close(semaphore)); -#else - checkPThreadFunction(sem_destroy(semaphore)); - delete semaphore; -#endif -} - -static void *threadFunction(void *argument) -{ - - b3PosixThreadSupport::b3ThreadStatus* status = (b3PosixThreadSupport::b3ThreadStatus*)argument; - - - while (1) - { - checkPThreadFunction(sem_wait(status->startSemaphore)); - - void* userPtr = status->m_userPtr; - - if (userPtr) - { - b3Assert(status->m_status); - status->m_userThreadFunc(userPtr,status->m_lsMemory); - status->m_status = 2; - checkPThreadFunction(sem_post(mainSemaphore)); - status->threadUsed++; - } else { - //exit Thread - status->m_status = 3; - checkPThreadFunction(sem_post(mainSemaphore)); - printf("Thread with taskId %i exiting\n",status->m_taskId); - break; - } - - } - - printf("Thread TERMINATED\n"); - return 0; - -} - -///send messages to SPUs -void b3PosixThreadSupport::sendRequest(int uiCommand, void* uiArgument0, int taskId) -{ - /// gMidphaseSPU.sendRequest(CMD_GATHER_AND_PROCESS_PAIRLIST, (int) &taskDesc); - - ///we should spawn an SPU task here, and in 'waitForResponse' it should wait for response of the (one of) the first tasks that finished - - - - switch (uiCommand) - { - case B3_THREAD_SCHEDULE_TASK: - { - b3ThreadStatus& spuStatus = m_activeThreadStatus[taskId]; - b3Assert(taskId >= 0); - b3Assert(taskId < m_activeThreadStatus.size()); - - spuStatus.m_commandId = uiCommand; - spuStatus.m_status = 1; - spuStatus.m_userPtr = (void*)uiArgument0; - - // fire event to start new task - checkPThreadFunction(sem_post(spuStatus.startSemaphore)); - break; - } - default: - { - ///not implemented - b3Assert(0); - } - - }; - - -} - -///non-blocking test if a task is completed. First implement all versions, and then enable this API -bool b3PosixThreadSupport::isTaskCompleted(int *puiArgument0, int *puiArgument1, int timeOutInMilliseconds) -{ - - b3Assert(m_activeThreadStatus.size()); - - // wait for any of the threads to finish - int result = sem_trywait(mainSemaphore); - if (result==0) - { - // get at least one thread which has finished - size_t last = -1; - - for(size_t t=0; t < size_t(m_activeThreadStatus.size()); ++t) { - if(2 == m_activeThreadStatus[t].m_status) { - last = t; - break; - } - } - - b3ThreadStatus& spuStatus = m_activeThreadStatus[last]; - - b3Assert(spuStatus.m_status > 1); - spuStatus.m_status = 0; - - // need to find an active spu - b3Assert(last >= 0); - - *puiArgument0 = spuStatus.m_taskId; - *puiArgument1 = spuStatus.m_status; - return true; - } - return false; -} - - -///check for messages from SPUs -void b3PosixThreadSupport::waitForResponse( int *puiArgument0, int *puiArgument1) -{ - ///We should wait for (one of) the first tasks to finish (or other SPU messages), and report its response - - ///A possible response can be 'yes, SPU handled it', or 'no, please do a PPU fallback' - - - b3Assert(m_activeThreadStatus.size()); - - // wait for any of the threads to finish - checkPThreadFunction(sem_wait(mainSemaphore)); - - // get at least one thread which has finished - size_t last = -1; - - for(size_t t=0; t < size_t(m_activeThreadStatus.size()); ++t) { - if(2 == m_activeThreadStatus[t].m_status) { - last = t; - break; - } - } - - b3ThreadStatus& spuStatus = m_activeThreadStatus[last]; - - b3Assert(spuStatus.m_status > 1); - spuStatus.m_status = 0; - - // need to find an active spu - b3Assert(last >= 0); - - *puiArgument0 = spuStatus.m_taskId; - *puiArgument1 = spuStatus.m_status; -} - - - -void b3PosixThreadSupport::startThreads(ThreadConstructionInfo& threadConstructionInfo) -{ - printf("%s creating %i threads.\n", __FUNCTION__, threadConstructionInfo.m_numThreads); - m_activeThreadStatus.resize(threadConstructionInfo.m_numThreads); - - mainSemaphore = createSem("main"); - //checkPThreadFunction(sem_wait(mainSemaphore)); - - for (int i=0;i < threadConstructionInfo.m_numThreads;i++) - { - printf("starting thread %d\n",i); - - b3ThreadStatus& spuStatus = m_activeThreadStatus[i]; - - spuStatus.startSemaphore = createSem("threadLocal"); - - checkPThreadFunction(pthread_create(&spuStatus.thread, NULL, &threadFunction, (void*)&spuStatus)); - - spuStatus.m_userPtr=0; - - spuStatus.m_taskId = i; - spuStatus.m_commandId = 0; - spuStatus.m_status = 0; - spuStatus.m_lsMemory = threadConstructionInfo.m_lsMemoryFunc(); - spuStatus.m_userThreadFunc = threadConstructionInfo.m_userThreadFunc; - spuStatus.threadUsed = 0; - - printf("started thread %d \n",i); - - } - -} - - - -///tell the task scheduler we are done with the SPU tasks -void b3PosixThreadSupport::stopThreads() -{ - for(size_t t=0; t < size_t(m_activeThreadStatus.size()); ++t) - { - b3ThreadStatus& spuStatus = m_activeThreadStatus[t]; - printf("%s: Thread %i used: %ld\n", __FUNCTION__, int(t), spuStatus.threadUsed); - - spuStatus.m_userPtr = 0; - checkPThreadFunction(sem_post(spuStatus.startSemaphore)); - checkPThreadFunction(sem_wait(mainSemaphore)); - - printf("destroy semaphore\n"); - destroySem(spuStatus.startSemaphore); - printf("semaphore destroyed\n"); - checkPThreadFunction(pthread_join(spuStatus.thread,0)); - - } - printf("destroy main semaphore\n"); - destroySem(mainSemaphore); - printf("main semaphore destroyed\n"); - m_activeThreadStatus.clear(); -} - -class b3PosixCriticalSection : public b3CriticalSection -{ - pthread_mutex_t m_mutex; - -public: - b3PosixCriticalSection() - { - pthread_mutex_init(&m_mutex, NULL); - } - virtual ~b3PosixCriticalSection() - { - pthread_mutex_destroy(&m_mutex); - } - - B3_ATTRIBUTE_ALIGNED16(unsigned int mCommonBuff[32]); - - virtual unsigned int getSharedParam(int i) - { - return mCommonBuff[i]; - } - virtual void setSharedParam(int i,unsigned int p) - { - mCommonBuff[i] = p; - } - - virtual void lock() - { - pthread_mutex_lock(&m_mutex); - } - virtual void unlock() - { - pthread_mutex_unlock(&m_mutex); - } -}; - - -#if defined(_POSIX_BARRIERS) && (_POSIX_BARRIERS - 20012L) >= 0 -/* OK to use barriers on this platform */ -class b3PosixBarrier : public b3Barrier -{ - pthread_barrier_t m_barr; - int m_numThreads; -public: - b3PosixBarrier() - :m_numThreads(0) { } - virtual ~b3PosixBarrier() { - pthread_barrier_destroy(&m_barr); - } - - virtual void sync() - { - int rc = pthread_barrier_wait(&m_barr); - if(rc != 0 && rc != PTHREAD_BARRIER_SERIAL_THREAD) - { - printf("Could not wait on barrier\n"); - exit(-1); - } - } - virtual void setMaxCount(int numThreads) - { - int result = pthread_barrier_init(&m_barr, NULL, numThreads); - m_numThreads = numThreads; - b3Assert(result==0); - } - virtual int getMaxCount() - { - return m_numThreads; - } -}; -#else -/* Not OK to use barriers on this platform - insert alternate code here */ -class b3PosixBarrier : public b3Barrier -{ - pthread_mutex_t m_mutex; - pthread_cond_t m_cond; - - int m_numThreads; - int m_called; - -public: - b3PosixBarrier() - :m_numThreads(0) - { - } - virtual ~b3PosixBarrier() - { - if (m_numThreads>0) - { - pthread_mutex_destroy(&m_mutex); - pthread_cond_destroy(&m_cond); - } - } - - virtual void sync() - { - pthread_mutex_lock(&m_mutex); - m_called++; - if (m_called == m_numThreads) { - m_called = 0; - pthread_cond_broadcast(&m_cond); - } else { - pthread_cond_wait(&m_cond,&m_mutex); - } - pthread_mutex_unlock(&m_mutex); - - } - virtual void setMaxCount(int numThreads) - { - if (m_numThreads>0) - { - pthread_mutex_destroy(&m_mutex); - pthread_cond_destroy(&m_cond); - } - m_called = 0; - pthread_mutex_init(&m_mutex,NULL); - pthread_cond_init(&m_cond,NULL); - m_numThreads = numThreads; - } - virtual int getMaxCount() - { - return m_numThreads; - } -}; - -#endif//_POSIX_BARRIERS - - - -b3Barrier* b3PosixThreadSupport::createBarrier() -{ - b3PosixBarrier* barrier = new b3PosixBarrier(); - barrier->setMaxCount(getNumTasks()); - return barrier; -} - -b3CriticalSection* b3PosixThreadSupport::createCriticalSection() -{ - return new b3PosixCriticalSection(); -} - -void b3PosixThreadSupport::deleteBarrier(b3Barrier* barrier) -{ - delete barrier; -} - -void b3PosixThreadSupport::deleteCriticalSection(b3CriticalSection* cs) -{ - delete cs; -} - diff --git a/btgui/MultiThreading/b3PosixThreadSupport.h b/btgui/MultiThreading/b3PosixThreadSupport.h deleted file mode 100644 index 17dde8d60..000000000 --- a/btgui/MultiThreading/b3PosixThreadSupport.h +++ /dev/null @@ -1,144 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef B3_POSIX_THREAD_SUPPORT_H -#define B3_POSIX_THREAD_SUPPORT_H - - -#include "Bullet3Common/b3Scalar.h" - - -#ifndef _XOPEN_SOURCE -#define _XOPEN_SOURCE 600 //for definition of pthread_barrier_t, see http://pages.cs.wisc.edu/~travitch/pthreads_primer.html -#endif //_XOPEN_SOURCE -#include -#include - - - -#include "Bullet3Common/b3AlignedObjectArray.h" - -#include "b3ThreadSupportInterface.h" - - -typedef void (*b3PosixThreadFunc)(void* userPtr,void* lsMemory); -typedef void* (*b3PosixlsMemorySetupFunc)(); - -// b3PosixThreadSupport helps to initialize/shutdown libspe2, start/stop SPU tasks and communication -class b3PosixThreadSupport : public b3ThreadSupportInterface -{ -public: - typedef enum sStatus { - STATUS_BUSY, - STATUS_READY, - STATUS_FINISHED - } Status; - - // placeholder, until libspe2 support is there - struct b3ThreadStatus - { - int m_taskId; - int m_commandId; - int m_status; - - b3PosixThreadFunc m_userThreadFunc; - void* m_userPtr; //for taskDesc etc - void* m_lsMemory; //initialized using PosixLocalStoreMemorySetupFunc - - pthread_t thread; - sem_t* startSemaphore; - - unsigned long threadUsed; - }; -private: - - b3AlignedObjectArray m_activeThreadStatus; -public: - ///Setup and initialize SPU/CELL/Libspe2 - - - - struct ThreadConstructionInfo - { - ThreadConstructionInfo(const char* uniqueName, - b3PosixThreadFunc userThreadFunc, - b3PosixlsMemorySetupFunc lsMemoryFunc, - int numThreads=1, - int threadStackSize=65535 - ) - :m_uniqueName(uniqueName), - m_userThreadFunc(userThreadFunc), - m_lsMemoryFunc(lsMemoryFunc), - m_numThreads(numThreads), - m_threadStackSize(threadStackSize) - { - - } - - const char* m_uniqueName; - b3PosixThreadFunc m_userThreadFunc; - b3PosixlsMemorySetupFunc m_lsMemoryFunc; - int m_numThreads; - int m_threadStackSize; - - }; - - b3PosixThreadSupport(ThreadConstructionInfo& threadConstructionInfo); - -///cleanup/shutdown Libspe2 - virtual ~b3PosixThreadSupport(); - - void startThreads(ThreadConstructionInfo& threadInfo); - - - virtual void sendRequest(int uiCommand, void* uiArgument0, int uiArgument1); - - virtual void waitForResponse(int *puiArgument0, int *puiArgument1); - - -///tell the task scheduler we are done with the SPU tasks - virtual void stopThreads(); - - virtual void setNumTasks(int numTasks) {} - - virtual int getNumTasks() const - { - return m_activeThreadStatus.size(); - } - - ///non-blocking test if a task is completed. First implement all versions, and then enable this API - virtual bool isTaskCompleted(int *puiArgument0, int *puiArgument1, int timeOutInMilliseconds); - - - virtual b3Barrier* createBarrier(); - - virtual b3CriticalSection* createCriticalSection(); - - virtual void deleteBarrier(b3Barrier* barrier); - - virtual void deleteCriticalSection(b3CriticalSection* criticalSection); - - - virtual void* getThreadLocalMemory(int taskId) - { - return m_activeThreadStatus[taskId].m_lsMemory; - } - -}; - - -#endif // B3_POSIX_THREAD_SUPPORT_H - - diff --git a/btgui/MultiThreading/b3ThreadSupportInterface.cpp b/btgui/MultiThreading/b3ThreadSupportInterface.cpp deleted file mode 100644 index 430242113..000000000 --- a/btgui/MultiThreading/b3ThreadSupportInterface.cpp +++ /dev/null @@ -1,22 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "b3ThreadSupportInterface.h" - -b3ThreadSupportInterface::~b3ThreadSupportInterface() -{ - -} - diff --git a/btgui/MultiThreading/b3ThreadSupportInterface.h b/btgui/MultiThreading/b3ThreadSupportInterface.h deleted file mode 100644 index d53209abd..000000000 --- a/btgui/MultiThreading/b3ThreadSupportInterface.h +++ /dev/null @@ -1,90 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef B3_THREAD_SUPPORT_INTERFACE_H -#define B3_THREAD_SUPPORT_INTERFACE_H - -enum -{ - B3_THREAD_SCHEDULE_TASK=1, -}; - -#include "Bullet3Common/b3Scalar.h" //for B3_ATTRIBUTE_ALIGNED16 -//#include "PlatformDefinitions.h" -//#include "PpuAddressSpace.h" - -class b3Barrier { -public: - b3Barrier() {} - virtual ~b3Barrier() {} - - virtual void sync() = 0; - virtual void setMaxCount(int n) = 0; - virtual int getMaxCount() = 0; -}; - -class b3CriticalSection { -public: - b3CriticalSection() {} - virtual ~b3CriticalSection() {} - - B3_ATTRIBUTE_ALIGNED16(unsigned int mCommonBuff[32]); - - virtual unsigned int getSharedParam(int i) = 0; - virtual void setSharedParam(int i,unsigned int p) = 0; - - virtual void lock() = 0; - virtual void unlock() = 0; -}; - - -class b3ThreadSupportInterface -{ -public: - - virtual ~b3ThreadSupportInterface(); - - - virtual void sendRequest(int uiCommand, void* uiArgument0, int uiArgument1) =0; - - - virtual void waitForResponse(int *puiArgument0, int *puiArgument1) =0; - - - ///non-blocking test if a task is completed. First implement all versions, and then enable this API - virtual bool isTaskCompleted(int *puiArgument0, int *puiArgument1, int timeOutInMilliseconds)=0; - - - virtual void stopThreads()=0; - - ///tell the task scheduler to use no more than numTasks tasks - virtual void setNumTasks(int numTasks)=0; - - virtual int getNumTasks() const = 0; - - virtual b3Barrier* createBarrier() = 0; - - virtual b3CriticalSection* createCriticalSection() = 0; - - virtual void deleteBarrier(b3Barrier* barrier)=0; - - virtual void deleteCriticalSection(b3CriticalSection* criticalSection)=0; - - virtual void* getThreadLocalMemory(int taskId) { return 0; } - -}; - -#endif //B3_THREAD_SUPPORT_INTERFACE_H - diff --git a/btgui/MultiThreading/b3Win32ThreadSupport.cpp b/btgui/MultiThreading/b3Win32ThreadSupport.cpp deleted file mode 100644 index 7eae9b1a3..000000000 --- a/btgui/MultiThreading/b3Win32ThreadSupport.cpp +++ /dev/null @@ -1,454 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "b3Win32ThreadSupport.h" - - -#include - - - - -///The number of threads should be equal to the number of available cores -///@todo: each worker should be linked to a single core, using SetThreadIdealProcessor. - -///b3Win32ThreadSupport helps to initialize/shutdown libspe2, start/stop SPU tasks and communication -///Setup and initialize SPU/CELL/Libspe2 -b3Win32ThreadSupport::b3Win32ThreadSupport(const Win32ThreadConstructionInfo & threadConstructionInfo) -{ - m_maxNumTasks = threadConstructionInfo.m_numThreads; - startThreads(threadConstructionInfo); -} - -///cleanup/shutdown Libspe2 -b3Win32ThreadSupport::~b3Win32ThreadSupport() -{ - stopThreads(); -} - - - - -#include - -DWORD WINAPI Thread_no_1( LPVOID lpParam ) -{ - - b3Win32ThreadSupport::b3ThreadStatus* status = (b3Win32ThreadSupport::b3ThreadStatus*)lpParam; - - - while (1) - { - WaitForSingleObject(status->m_eventStartHandle,INFINITE); - - void* userPtr = status->m_userPtr; - - if (userPtr) - { - b3Assert(status->m_status); - status->m_userThreadFunc(userPtr,status->m_lsMemory); - status->m_status = 2; - SetEvent(status->m_eventCompletetHandle); - } else - { - //exit Thread - status->m_status = 3; - printf("Thread with taskId %i with handle %p exiting\n",status->m_taskId, status->m_threadHandle); - SetEvent(status->m_eventCompletetHandle); - break; - } - - } - - printf("Thread TERMINATED\n"); - return 0; - -} - -///send messages to SPUs -void b3Win32ThreadSupport::sendRequest(int uiCommand, void* uiArgument0, int taskId) -{ - /// gMidphaseSPU.sendRequest(CMD_GATHER_AND_PROCESS_PAIRLIST, (void*) &taskDesc); - - ///we should spawn an SPU task here, and in 'waitForResponse' it should wait for response of the (one of) the first tasks that finished - - - - switch (uiCommand) - { - case B3_THREAD_SCHEDULE_TASK: - { - - -//#define SINGLE_THREADED 1 -#ifdef SINGLE_THREADED - - b3ThreadStatus& threadStatus = m_activeThreadStatus[0]; - threadStatus.m_userPtr=(void*)uiArgument0; - threadStatus.m_userThreadFunc(threadStatus.m_userPtr,threadStatus.m_lsMemory); - HANDLE handle =0; -#else - - - b3ThreadStatus& threadStatus = m_activeThreadStatus[taskId]; - b3Assert(taskId>=0); - b3Assert(int(taskId) 1); - threadStatus.m_status = 0; - - ///need to find an active spu - b3Assert(last>=0); - -#else - last=0; - b3ThreadStatus& threadStatus = m_activeThreadStatus[last]; -#endif //SINGLE_THREADED - - - - *puiArgument0 = threadStatus.m_taskId; - *puiArgument1 = threadStatus.m_status; - - -} - - -///check for messages from SPUs -bool b3Win32ThreadSupport::isTaskCompleted(int *puiArgument0, int *puiArgument1, int timeOutInMilliseconds) -{ - ///We should wait for (one of) the first tasks to finish (or other SPU messages), and report its response - - ///A possible response can be 'yes, SPU handled it', or 'no, please do a PPU fallback' - - - b3Assert(m_activeThreadStatus.size()); - - int last = -1; -#ifndef SINGLE_THREADED - DWORD res = WaitForMultipleObjects(m_completeHandles.size(), &m_completeHandles[0], FALSE, timeOutInMilliseconds); - - if ((res != STATUS_TIMEOUT) && (res != WAIT_FAILED)) - { - - b3Assert(res != WAIT_FAILED); - last = res - WAIT_OBJECT_0; - - b3ThreadStatus& threadStatus = m_activeThreadStatus[last]; - b3Assert(threadStatus.m_threadHandle); - b3Assert(threadStatus.m_eventCompletetHandle); - - //WaitForSingleObject(threadStatus.m_eventCompletetHandle, INFINITE); - b3Assert(threadStatus.m_status > 1); - threadStatus.m_status = 0; - - ///need to find an active spu - b3Assert(last>=0); - - #else - last=0; - b3ThreadStatus& threadStatus = m_activeThreadStatus[last]; - #endif //SINGLE_THREADED - - - - *puiArgument0 = threadStatus.m_taskId; - *puiArgument1 = threadStatus.m_status; - - return true; - } - - return false; -} - - -void b3Win32ThreadSupport::startThreads(const Win32ThreadConstructionInfo& threadConstructionInfo) -{ - - m_activeThreadStatus.resize(threadConstructionInfo.m_numThreads); - m_completeHandles.resize(threadConstructionInfo.m_numThreads); - - m_maxNumTasks = threadConstructionInfo.m_numThreads; - - for (int i=0;i0) - { - WaitForSingleObject(threadStatus.m_eventCompletetHandle, INFINITE); - } - - - threadStatus.m_userPtr = 0; - SetEvent(threadStatus.m_eventStartHandle); - WaitForSingleObject(threadStatus.m_eventCompletetHandle, INFINITE); - - CloseHandle(threadStatus.m_eventCompletetHandle); - CloseHandle(threadStatus.m_eventStartHandle); - CloseHandle(threadStatus.m_threadHandle); - - } - - m_activeThreadStatus.clear(); - m_completeHandles.clear(); - -} - - - -class b3Win32Barrier : public b3Barrier -{ -private: - CRITICAL_SECTION mExternalCriticalSection; - CRITICAL_SECTION mLocalCriticalSection; - HANDLE mRunEvent,mNotifyEvent; - int mCounter,mEnableCounter; - int mMaxCount; - -public: - b3Win32Barrier() - { - mCounter = 0; - mMaxCount = 1; - mEnableCounter = 0; - InitializeCriticalSection(&mExternalCriticalSection); - InitializeCriticalSection(&mLocalCriticalSection); - mRunEvent = CreateEvent(NULL,TRUE,FALSE,NULL); - mNotifyEvent = CreateEvent(NULL,TRUE,FALSE,NULL); - } - - virtual ~b3Win32Barrier() - { - DeleteCriticalSection(&mExternalCriticalSection); - DeleteCriticalSection(&mLocalCriticalSection); - CloseHandle(mRunEvent); - CloseHandle(mNotifyEvent); - } - - void sync() - { - int eventId; - - EnterCriticalSection(&mExternalCriticalSection); - - //PFX_PRINTF("enter taskId %d count %d stage %d phase %d mEnableCounter %d\n",taskId,mCounter,debug&0xff,debug>>16,mEnableCounter); - - if(mEnableCounter > 0) { - ResetEvent(mNotifyEvent); - LeaveCriticalSection(&mExternalCriticalSection); - WaitForSingleObject(mNotifyEvent,INFINITE); - EnterCriticalSection(&mExternalCriticalSection); - } - - eventId = mCounter; - mCounter++; - - if(eventId == mMaxCount-1) { - SetEvent(mRunEvent); - - mEnableCounter = mCounter-1; - mCounter = 0; - } - else { - ResetEvent(mRunEvent); - LeaveCriticalSection(&mExternalCriticalSection); - WaitForSingleObject(mRunEvent,INFINITE); - EnterCriticalSection(&mExternalCriticalSection); - mEnableCounter--; - } - - if(mEnableCounter == 0) { - SetEvent(mNotifyEvent); - } - - //PFX_PRINTF("leave taskId %d count %d stage %d phase %d mEnableCounter %d\n",taskId,mCounter,debug&0xff,debug>>16,mEnableCounter); - - LeaveCriticalSection(&mExternalCriticalSection); - } - - virtual void setMaxCount(int n) {mMaxCount = n;} - virtual int getMaxCount() {return mMaxCount;} -}; - -class b3Win32CriticalSection : public b3CriticalSection -{ -private: - CRITICAL_SECTION mCriticalSection; - -public: - b3Win32CriticalSection() - { - InitializeCriticalSection(&mCriticalSection); - } - - ~b3Win32CriticalSection() - { - DeleteCriticalSection(&mCriticalSection); - } - - unsigned int getSharedParam(int i) - { - b3Assert(i>=0&&i<31); - return mCommonBuff[i+1]; - } - - void setSharedParam(int i,unsigned int p) - { - b3Assert(i>=0&&i<31); - mCommonBuff[i+1] = p; - } - - void lock() - { - EnterCriticalSection(&mCriticalSection); - mCommonBuff[0] = 1; - } - - void unlock() - { - mCommonBuff[0] = 0; - LeaveCriticalSection(&mCriticalSection); - } -}; - - -b3Barrier* b3Win32ThreadSupport::createBarrier() -{ - unsigned char* mem = (unsigned char*)b3AlignedAlloc(sizeof(b3Win32Barrier),16); - b3Win32Barrier* barrier = new(mem) b3Win32Barrier(); - barrier->setMaxCount(getNumTasks()); - return barrier; -} - -b3CriticalSection* b3Win32ThreadSupport::createCriticalSection() -{ - unsigned char* mem = (unsigned char*) b3AlignedAlloc(sizeof(b3Win32CriticalSection),16); - b3Win32CriticalSection* cs = new(mem) b3Win32CriticalSection(); - return cs; -} - -void b3Win32ThreadSupport::deleteBarrier(b3Barrier* barrier) -{ - barrier->~b3Barrier(); - b3AlignedFree(barrier); -} - -void b3Win32ThreadSupport::deleteCriticalSection(b3CriticalSection* criticalSection) -{ - criticalSection->~b3CriticalSection(); - b3AlignedFree(criticalSection); -} - - - - - diff --git a/btgui/MultiThreading/b3Win32ThreadSupport.h b/btgui/MultiThreading/b3Win32ThreadSupport.h deleted file mode 100644 index 41cd96e3b..000000000 --- a/btgui/MultiThreading/b3Win32ThreadSupport.h +++ /dev/null @@ -1,139 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2003-2007 Erwin Coumans http://bulletphysics.com - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -#include "Bullet3Common/b3Scalar.h" - - -#ifndef BT_WIN32_THREAD_SUPPORT_H -#define BT_WIN32_THREAD_SUPPORT_H - -#include "Bullet3Common/b3AlignedObjectArray.h" - -#include "b3ThreadSupportInterface.h" - - -typedef void (*b3Win32ThreadFunc)(void* userPtr,void* lsMemory); -typedef void* (*b3Win32lsMemorySetupFunc)(); - - -///b3Win32ThreadSupport helps to initialize/shutdown libspe2, start/stop SPU tasks and communication -class b3Win32ThreadSupport : public b3ThreadSupportInterface -{ -public: - ///placeholder, until libspe2 support is there - struct b3ThreadStatus - { - int m_taskId; - int m_commandId; - int m_status; - - b3Win32ThreadFunc m_userThreadFunc; - void* m_userPtr; //for taskDesc etc - void* m_lsMemory; //initialized using Win32LocalStoreMemorySetupFunc - - void* m_threadHandle; //this one is calling 'Win32ThreadFunc' - - void* m_eventStartHandle; - char m_eventStartHandleName[32]; - - void* m_eventCompletetHandle; - char m_eventCompletetHandleName[32]; - - - }; -private: - - b3AlignedObjectArray m_activeThreadStatus; - b3AlignedObjectArray m_completeHandles; - - int m_maxNumTasks; -public: - ///Setup and initialize SPU/CELL/Libspe2 - - struct Win32ThreadConstructionInfo - { - Win32ThreadConstructionInfo(const char* uniqueName, - b3Win32ThreadFunc userThreadFunc, - b3Win32lsMemorySetupFunc lsMemoryFunc, - int numThreads=1, - int threadStackSize=65535 - ) - :m_uniqueName(uniqueName), - m_userThreadFunc(userThreadFunc), - m_lsMemoryFunc(lsMemoryFunc), - m_numThreads(numThreads), - m_threadStackSize(threadStackSize) - { - - } - - const char* m_uniqueName; - b3Win32ThreadFunc m_userThreadFunc; - b3Win32lsMemorySetupFunc m_lsMemoryFunc; - int m_numThreads; - int m_threadStackSize; - - }; - - - - b3Win32ThreadSupport(const Win32ThreadConstructionInfo& threadConstructionInfo); - -///cleanup/shutdown Libspe2 - virtual ~b3Win32ThreadSupport(); - - void startThreads(const Win32ThreadConstructionInfo& threadInfo); - - -///send messages to SPUs - virtual void sendRequest(int uiCommand, void* uiArgument0, int uiArgument1); - -///check for messages from SPUs - virtual void waitForResponse(int *puiArgument0, int *puiArgument1); - - virtual bool isTaskCompleted(int *puiArgument0, int *puiArgument1, int timeOutInMilliseconds); - -///start the spus (can be called at the beginning of each frame, to make sure that the right SPU program is loaded) - virtual void startThreads(); - -///tell the task scheduler we are done with the SPU tasks - virtual void stopThreads(); - - virtual void setNumTasks(int numTasks) - { - m_maxNumTasks = numTasks; - } - - virtual int getNumTasks() const - { - return m_maxNumTasks; - } - - virtual void* getThreadLocalMemory(int taskId) - { - return m_activeThreadStatus[taskId].m_lsMemory; - } - virtual b3Barrier* createBarrier(); - - virtual b3CriticalSection* createCriticalSection(); - - virtual void deleteBarrier(b3Barrier* barrier); - - virtual void deleteCriticalSection(b3CriticalSection* criticalSection); -}; - -#endif //BT_WIN32_THREAD_SUPPORT_H - - diff --git a/btgui/MultiThreading/main.cpp b/btgui/MultiThreading/main.cpp deleted file mode 100644 index 88d0d11be..000000000 --- a/btgui/MultiThreading/main.cpp +++ /dev/null @@ -1,177 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library -Copyright (c) 2010 Erwin Coumans http://bulletphysics.org - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ - -/// ThreadingDemo shows how to use the cross platform thread support interface. -/// You can start threads and perform a blocking wait for completion -/// Under Windows it uses Win32 Threads. On Mac and Linux it uses pthreads. On PlayStation 3 Cell SPU it uses SPURS. - -/// June 2010 -/// New: critical section/barriers and non-blocking pollingn for completion, currently Windows only - -void SampleThreadFunc(void* userPtr,void* lsMemory); -void* SamplelsMemoryFunc(); - -#include -//#include "BulletMultiThreaded/PlatformDefinitions.h" - -#ifndef _WIN32 -#include "b3PosixThreadSupport.h" - -b3ThreadSupportInterface* createThreadSupport(int numThreads) -{ - b3PosixThreadSupport::ThreadConstructionInfo constructionInfo("testThreads", - SampleThreadFunc, - SamplelsMemoryFunc, - numThreads); - b3ThreadSupportInterface* threadSupport = new b3PosixThreadSupport(constructionInfo); - - return threadSupport; - -} - - -#elif defined( _WIN32) -#include "b3Win32ThreadSupport.h" - -b3ThreadSupportInterface* createThreadSupport(int numThreads) -{ - b3Win32ThreadSupport::Win32ThreadConstructionInfo threadConstructionInfo("testThreads",SampleThreadFunc,SamplelsMemoryFunc,numThreads); - b3Win32ThreadSupport* threadSupport = new b3Win32ThreadSupport(threadConstructionInfo); - return threadSupport; - -} -#endif - - - -struct SampleArgs -{ - SampleArgs() - :m_fakeWork(1) - { - } - b3CriticalSection* m_cs; - float m_fakeWork; -}; - -struct SampleThreadLocalStorage -{ - int threadId; -}; - - -void SampleThreadFunc(void* userPtr,void* lsMemory) -{ - printf("thread started\n"); - - SampleThreadLocalStorage* localStorage = (SampleThreadLocalStorage*) lsMemory; - - SampleArgs* args = (SampleArgs*) userPtr; - int workLeft = true; - while (workLeft) - { - args->m_cs->lock(); - int count = args->m_cs->getSharedParam(0); - args->m_cs->setSharedParam(0,count-1); - args->m_cs->unlock(); - if (count>0) - { - printf("thread %d processed number %d\n",localStorage->threadId, count); - } - //do some fake work - for (int i=0;i<1000000;i++) - args->m_fakeWork = b3Scalar(1.21)*args->m_fakeWork; - workLeft = count>0; - } - printf("finished\n"); - //do nothing -} - - -void* SamplelsMemoryFunc() -{ - //don't create local store memory, just return 0 - return new SampleThreadLocalStorage; -} - - - - - - - - - - -int main(int argc,char** argv) -{ - int numThreads = 8; - - b3ThreadSupportInterface* threadSupport = createThreadSupport(numThreads); - - - - for (int i=0;igetNumTasks();i++) - { - SampleThreadLocalStorage* storage = (SampleThreadLocalStorage*)threadSupport->getThreadLocalMemory(i); - b3Assert(storage); - storage->threadId = i; - } - - - SampleArgs args; - args.m_cs = threadSupport->createCriticalSection(); - args.m_cs->setSharedParam(0,100); - - - int arg0,arg1; - int i; - for (i=0;isendRequest(B3_THREAD_SCHEDULE_TASK, (void*) &args, i); - } - - bool blockingWait =false; - if (blockingWait) - { - for (i=0;iwaitForResponse(&arg0,&arg1); - printf("finished waiting for response: %d %d\n", arg0,arg1); - } - } else - { - int numActiveThreads = numThreads; - while (numActiveThreads) - { - if (threadSupport->isTaskCompleted(&arg0,&arg1,0)) - { - numActiveThreads--; - printf("numActiveThreads = %d\n",numActiveThreads); - - } else - { -// printf("polling.."); - } - }; - } - -printf("stopping threads\n"); - - delete threadSupport; - printf("Press ENTER to quit\n"); - getchar(); - return 0; -} diff --git a/btgui/MultiThreading/premake4.lua b/btgui/MultiThreading/premake4.lua deleted file mode 100644 index 5ed0339b5..000000000 --- a/btgui/MultiThreading/premake4.lua +++ /dev/null @@ -1,52 +0,0 @@ - - project "App_ThreadingTest" - - kind "ConsoleApp" - --- defines { } - - targetdir "../../bin" - - includedirs - { - ".","../../src" - } - - - links { "Bullet3Common" } - - - files { - "b3ThreadSupportInterface.cpp", - "main.cpp", - "b3ThreadSupportInterface.h" - } - if os.is("Windows") then - - files { - "b3Win32ThreadSupport.cpp", - "b3Win32ThreadSupport.h" - } - --links {"winmm"} - --defines {"__WINDOWS_MM__", "WIN32"} - end - - if os.is("Linux") then - files { - "b3PosixThreadSupport.cpp", - "b3PosixThreadSupport.h" - } - - links {"pthread"} - end - - if os.is("MacOSX") then - files { - "b3PosixThreadSupport.cpp", - "b3PosixThreadSupport.h" - } - - links {"pthread"} - --links{"CoreAudio.framework", "coreMIDI.framework", "Cocoa.framework"} - --defines {"__MACOSX_CORE__"} - end diff --git a/btgui/OpenGLWindow/CMakeLists.txt b/btgui/OpenGLWindow/CMakeLists.txt deleted file mode 100644 index f552958bb..000000000 --- a/btgui/OpenGLWindow/CMakeLists.txt +++ /dev/null @@ -1,65 +0,0 @@ - -INCLUDE_DIRECTORIES( - .. - ../../src -) - -FILE(GLOB OpenGLWindow_HDRS "*.h" ) - -FILE(GLOB OpenGLWindowMac_CPP "Mac*.mm") -FILE(GLOB OpenGLWindowWin32_CPP "Win32*.cpp") -FILE(GLOB OpenGLWindowLinux_CPP "X11*.cpp") - -FILE(GLOB OpenGLWindowCommon_CPP "*.cpp" ) - -LIST(REMOVE_ITEM OpenGLWindowCommon_CPP ${OpenGLWindowMac_CPP} ) -LIST(REMOVE_ITEM OpenGLWindowCommon_CPP ${OpenGLWindowWin32_CPP} ) -LIST(REMOVE_ITEM OpenGLWindowCommon_CPP ${OpenGLWindowLinux_CPP} ) -LIST(REMOVE_ITEM OpenGLWindowCommon_CPP X11OpenGLWindow.cpp ) -#MESSAGE (${OpenGLWindowCommon_CPP}) - -IF (WIN32) - SET(OpenGLWindow_SRCS GlewWindows/glew.c ${OpenGLWindowWin32_CPP} ${OpenGLWindowCommon_CPP}) - INCLUDE_DIRECTORIES( - GlewWindows - ) - ADD_DEFINITIONS(-DGLEW_STATIC) -ENDIF(WIN32) - -IF (APPLE) - SET(OpenGLWindow_SRCS ${OpenGLWindowMac_CPP} ${OpenGLWindowCommon_CPP} ) -ENDIF(APPLE) - -#no Linux detection? -IF(NOT WIN32 AND NOT APPLE) - INCLUDE_DIRECTORIES( - GlewWindows - ) - ADD_DEFINITIONS(-DGLEW_STATIC) - ADD_DEFINITIONS("-DGLEW_INIT_OPENGL11_FUNCTIONS=1") - ADD_DEFINITIONS("-DGLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS=1") - - SET(OpenGLWindow_SRCS ${OpenGLWindowLinux_CPP} GlewWindows/glew.c ${OpenGLWindowCommon_CPP} ) -ENDIF() - - - -ADD_LIBRARY(OpenGLWindow ${OpenGLWindow_SRCS} ${OpenGLWindow_HDRS}) -if (UNIX AND NOT APPLE) - target_link_libraries(OpenGLWindow X11) -elseif (APPLE) - target_link_libraries(OpenGLWindow ${COCOA_LIBRARY}) -endif () - -if (BUILD_SHARED_LIBS) - target_link_libraries(OpenGLWindow Bullet3Common) - if (WIN32 OR APPLE) - target_link_libraries(OpenGLWindow ${OPENGL_gl_LIBRARY}) - else() - set (CMAKE_THREAD_PREFER_PTHREAD TRUE) - FIND_PACKAGE(Threads) - target_link_libraries(OpenGLWindow ${CMAKE_THREAD_LIBS_INIT}) - endif() -endif() - -#target_link_libraries(OpenGLWindow ${OPENGL_gl_LIBRARY}) diff --git a/btgui/OpenGLWindow/CommonGraphicsApp.h b/btgui/OpenGLWindow/CommonGraphicsApp.h deleted file mode 100644 index 4a722c31d..000000000 --- a/btgui/OpenGLWindow/CommonGraphicsApp.h +++ /dev/null @@ -1,54 +0,0 @@ -#ifndef COMMON_GRAPHICS_APP_H -#define COMMON_GRAPHICS_APP_H - -struct DrawGridData -{ - int gridSize; - float upOffset; - int upAxis; - float gridColor[4]; - - DrawGridData() - :gridSize(10), - upOffset(0.001f), - upAxis(1) - { - gridColor[0] = 0.6f; - gridColor[1] = 0.6f; - gridColor[2] = 0.6f; - gridColor[3] = 1.f; - } -}; - -struct CommonGraphicsApp -{ - CommonGraphicsApp() - :m_window(0), - m_renderer(0), - m_parameterInterface(0), - m_2dCanvasInterface(0) - { - } - virtual ~CommonGraphicsApp() - { - } - - class b3gWindowInterface* m_window; - struct CommonRenderInterface* m_renderer; - struct CommonParameterInterface* m_parameterInterface; - struct Common2dCanvasInterface* m_2dCanvasInterface; - - virtual void drawGrid(DrawGridData data=DrawGridData()) = 0; - virtual void setUpAxis(int axis) = 0; - virtual int getUpAxis() const = 0; - - virtual void swapBuffer() = 0; - virtual void drawText( const char* txt, int posX, int posY) = 0; - virtual void drawText3D( const char* txt, float posX, float posZY, float posZ, float size)=0; - virtual int registerCubeShape(float halfExtentsX,float halfExtentsY, float halfExtentsZ)=0; - virtual int registerGraphicsSphereShape(float radius, bool usePointSprites=true, int largeSphereThreshold=100, int mediumSphereThreshold=10)=0; - virtual void registerGrid(int xres, int yres, float color0[4], float color1[4])=0; -}; - - -#endif //COMMON_GRAPHICS_APP_H diff --git a/btgui/OpenGLWindow/CommonRenderInterface.h b/btgui/OpenGLWindow/CommonRenderInterface.h deleted file mode 100644 index a6aa7181c..000000000 --- a/btgui/OpenGLWindow/CommonRenderInterface.h +++ /dev/null @@ -1,111 +0,0 @@ -#ifndef COMMON_RENDER_INTERFACE_H -#define COMMON_RENDER_INTERFACE_H - -enum -{ - B3_GL_TRIANGLES = 1, - B3_GL_POINTS -}; - -enum -{ - B3_DEFAULT_RENDERMODE=1, - //B3_WIREFRAME_RENDERMODE, - B3_CREATE_SHADOWMAP_RENDERMODE, - B3_USE_SHADOWMAP_RENDERMODE, -}; - -struct CommonRenderInterface -{ - virtual void init()=0; - virtual void updateCamera(int upAxis)=0; - virtual void removeAllInstances() = 0; - virtual void setCameraDistance(float dist) = 0; - virtual void setCameraPitch(float pitch) = 0; - virtual void setCameraTargetPosition(float x, float y, float z)=0; - - - virtual void getCameraPosition(float cameraPos[4])=0; - virtual void getCameraPosition(double cameraPos[4])=0; - - virtual void setCameraTargetPosition(float cameraPos[4])=0; - virtual void getCameraTargetPosition(float cameraPos[4]) const=0; - virtual void getCameraTargetPosition(double cameraPos[4]) const=0; - - virtual void getCameraViewMatrix(float viewMat[16]) const=0; - virtual void getCameraProjectionMatrix(float projMat[16]) const=0; - - virtual void renderScene()=0; - - virtual int getScreenWidth() = 0; - virtual int getScreenHeight() = 0; - - virtual int registerGraphicsInstance(int shapeIndex, const float* position, const float* quaternion, const float* color, const float* scaling)=0; - virtual int registerGraphicsInstance(int shapeIndex, const double* position, const double* quaternion, const double* color, const double* scaling)=0; - virtual void drawLines(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, const unsigned int* indices, int numIndices, float pointDrawSize)=0; - virtual void drawLine(const float from[4], const float to[4], const float color[4], float lineWidth) = 0; - virtual void drawLine(const double from[4], const double to[4], const double color[4], double lineWidth) = 0; - virtual void drawPoint(const float* position, const float color[4], float pointDrawSize)=0; - virtual void drawPoint(const double* position, const double color[4], double pointDrawSize)=0; - virtual int registerShape(const float* vertices, int numvertices, const int* indices, int numIndices,int primitiveType=B3_GL_TRIANGLES, int textureIndex=-1)=0; - virtual void updateShape(int shapeIndex, const float* vertices)=0; - - virtual void writeSingleInstanceTransformToCPU(const float* position, const float* orientation, int srcIndex)=0; - virtual void writeSingleInstanceTransformToCPU(const double* position, const double* orientation, int srcIndex)=0; - virtual void writeSingleInstanceColorToCPU(float* color, int srcIndex)=0; - virtual void writeSingleInstanceColorToCPU(double* color, int srcIndex)=0; - - virtual void writeTransforms()=0; - virtual void enableBlend(bool blend)=0; -}; - -template -inline int projectWorldCoordToScreen(T objx, T objy, T objz, - const T modelMatrix[16], - const T projMatrix[16], - const int viewport[4], - T *winx, T *winy, T *winz) -{ - int i; - T in2[4]; - T tmp[4]; - - in2[0]=objx; - in2[1]=objy; - in2[2]=objz; - in2[3]=T(1.0); - - for (i=0; i<4; i++) - { - tmp[i] = in2[0] * modelMatrix[0*4+i] + in2[1] * modelMatrix[1*4+i] + - in2[2] * modelMatrix[2*4+i] + in2[3] * modelMatrix[3*4+i]; - } - - T out[4]; - for (i=0; i<4; i++) - { - out[i] = tmp[0] * projMatrix[0*4+i] + tmp[1] * projMatrix[1*4+i] + tmp[2] * projMatrix[2*4+i] + tmp[3] * projMatrix[3*4+i]; - } - - if (out[3] == T(0.0)) - return 0; - out[0] /= out[3]; - out[1] /= out[3]; - out[2] /= out[3]; - /* Map x, y and z to range 0-1 */ - out[0] = out[0] * T(0.5) + T(0.5); - out[1] = out[1] * T(0.5) + T(0.5); - out[2] = out[2] * T(0.5) + T(0.5); - - /* Map x,y to viewport */ - out[0] = out[0] * viewport[2] + viewport[0]; - out[1] = out[1] * viewport[3] + viewport[1]; - - *winx=out[0]; - *winy=out[1]; - *winz=out[2]; - return 1; -} - -#endif//COMMON_RENDER_INTERFACE_H - diff --git a/btgui/OpenGLWindow/GLInstanceGraphicsShape.h b/btgui/OpenGLWindow/GLInstanceGraphicsShape.h deleted file mode 100644 index 84aef93d3..000000000 --- a/btgui/OpenGLWindow/GLInstanceGraphicsShape.h +++ /dev/null @@ -1,22 +0,0 @@ -#ifndef GL_INSTANCE_GRAPHICS_SHAPE_H -#define GL_INSTANCE_GRAPHICS_SHAPE_H - -#include "Bullet3Common/b3AlignedObjectArray.h" - -struct GLInstanceVertex -{ - float xyzw[4]; - float normal[3]; - float uv[2]; -}; -struct GLInstanceGraphicsShape -{ - b3AlignedObjectArray* m_vertices; - int m_numvertices; - b3AlignedObjectArray* m_indices; - int m_numIndices; - float m_scaling[4]; -}; - -#endif //GL_INSTANCE_GRAPHICS_SHAPE_H - diff --git a/btgui/OpenGLWindow/GLInstanceRendererInternalData.h b/btgui/OpenGLWindow/GLInstanceRendererInternalData.h deleted file mode 100644 index 3cc24b47f..000000000 --- a/btgui/OpenGLWindow/GLInstanceRendererInternalData.h +++ /dev/null @@ -1,20 +0,0 @@ -#ifndef GL_INSTANCE_RENDERER_INTERNAL_DATA_H -#define GL_INSTANCE_RENDERER_INTERNAL_DATA_H - -#include "OpenGLInclude.h" -#include "Bullet3Common/b3AlignedObjectArray.h" - -struct GLInstanceRendererInternalData -{ - - b3AlignedObjectArray m_instance_positions_ptr; - b3AlignedObjectArray m_instance_quaternion_ptr; - b3AlignedObjectArray m_instance_colors_ptr; - b3AlignedObjectArray m_instance_scale_ptr; - - int m_vboSize; - GLuint m_vbo; - int m_totalNumInstances; -}; - -#endif //GL_INSTANCE_RENDERER_INTERNAL_DATA_H diff --git a/btgui/OpenGLWindow/GLInstancingRenderer.cpp b/btgui/OpenGLWindow/GLInstancingRenderer.cpp deleted file mode 100644 index ec2d21921..000000000 --- a/btgui/OpenGLWindow/GLInstancingRenderer.cpp +++ /dev/null @@ -1,1929 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -///todo: make this configurable in the gui -bool useShadowMap=true;//false;//true; -int shadowMapWidth=8192; -int shadowMapHeight=8192; -float shadowMapWorldSize=100; -float WHEEL_MULTIPLIER=0.01f; -float MOUSE_MOVE_MULTIPLIER = 0.4f; -#define MAX_POINTS_IN_BATCH 1024 -#define MAX_LINES_IN_BATCH 1024 - - -#include "OpenGLInclude.h" -#include "b3gWindowInterface.h" -//#include "Bullet3Common/b3MinMax.h" - -#ifndef __APPLE__ -#ifndef glVertexAttribDivisor -#define glVertexAttribDivisor glVertexAttribDivisorARB -#endif //glVertexAttribDivisor -#ifndef GL_COMPARE_REF_TO_TEXTURE -#define GL_COMPARE_REF_TO_TEXTURE GL_COMPARE_R_TO_TEXTURE -#endif //GL_COMPARE_REF_TO_TEXTURE -#ifndef glDrawElementsInstanced -#define glDrawElementsInstanced glDrawElementsInstancedARB -#endif -#endif //__APPLE__ -#include "GLInstancingRenderer.h" - -#include -//#include "DemoSettings.h" -#include - -#include "Bullet3Common/b3Vector3.h" -#include "Bullet3Common/b3Quaternion.h" -#include "Bullet3Common/b3Matrix3x3.h" -#include "LoadShader.h" - -#include "GLInstanceRendererInternalData.h" - -//GLSL shader strings, embedded using build3/stringify -#include "OpenGLWindow/Shaders/pointSpriteVS.h" -#include "OpenGLWindow/Shaders/pointSpritePS.h" -#include "OpenGLWindow/Shaders/instancingVS.h" -#include "OpenGLWindow/Shaders/instancingPS.h" -#include "OpenGLWindow/Shaders/createShadowMapInstancingVS.h" -#include "OpenGLWindow/Shaders/createShadowMapInstancingPS.h" -#include "OpenGLWindow/Shaders/useShadowMapInstancingVS.h" -#include "OpenGLWindow/Shaders/useShadowMapInstancingPS.h" -#include "OpenGLWindow/Shaders/linesPS.h" -#include "OpenGLWindow/Shaders/linesVS.h" - -#include "OpenGLWindow/GLRenderToTexture.h" - - - - -//#include "../../opencl/gpu_rigidbody_pipeline/b3GpuNarrowphaseAndSolver.h"//for m_maxNumObjectCapacity - -static InternalDataRenderer* sData2; - -GLint lineWidthRange[2]={1,1}; -static b3Vector3 gLightPos=b3MakeVector3(-5,200,-40); - -struct b3GraphicsInstance -{ - GLuint m_cube_vao; - GLuint m_index_vbo; - GLuint m_texturehandle; - - int m_numIndices; - int m_numVertices; - - int m_numGraphicsInstances; - - int m_instanceOffset; - int m_vertexArrayOffset; - int m_primitiveType; - - b3GraphicsInstance() - :m_cube_vao(-1), - m_index_vbo(-1), - m_texturehandle(0), - m_numIndices(-1), - m_numVertices(-1), - m_numGraphicsInstances(0), - m_instanceOffset(0), - m_vertexArrayOffset(0), - m_primitiveType(B3_GL_TRIANGLES) - { - } - -}; - - - - -bool m_ortho = false; - - - -//static GLfloat depthLightModelviewMatrix[16]; - -static void checkError(const char *functionName) -{ - GLenum error; - while (( error = glGetError() ) != GL_NO_ERROR) - { - fprintf (stderr, "GL error 0x%X detected in %s\n", error, functionName); - } -} - - - -extern int gShapeIndex; - - - - - - - - - - -struct InternalDataRenderer : public GLInstanceRendererInternalData -{ - - - b3Vector3 m_cameraPosition; - b3Vector3 m_cameraTargetPosition; - float m_cameraDistance; - b3Vector3 m_cameraUp; - float m_azi; - float m_ele; - - float m_mouseXpos; - float m_mouseYpos; - bool m_mouseInitialized; - int m_leftMouseButton; - int m_middleMouseButton; - int m_rightMouseButton; - - GLfloat m_projectionMatrix[16]; - GLfloat m_viewMatrix[16]; - - - GLuint m_defaultTexturehandle; - b3AlignedObjectArray m_textureHandles; - - GLRenderToTexture* m_shadowMap; - GLuint m_shadowTexture; - int m_altPressed; - int m_controlPressed; - - InternalDataRenderer() : - m_cameraPosition(b3MakeVector3(0,0,0)), - m_cameraTargetPosition(b3MakeVector3(15,2,-24)), - m_cameraDistance(150), - m_cameraUp(b3MakeVector3(0,1,0)), - m_azi(100.f),//135.f), - //m_ele(25.f), - m_ele(25.f), - m_mouseInitialized(false), - m_leftMouseButton(0), - m_middleMouseButton(0), - m_rightMouseButton(0), - m_shadowMap(0), - m_shadowTexture(0), - m_altPressed(0), - m_controlPressed(0) - { - //clear to zero to make it obvious if the matrix is used uninitialized - for (int i=0;i<16;i++) - { - m_projectionMatrix[i]=0; - m_viewMatrix[i]=0; - } - - } - - void wheelCallback( float deltax, float deltay) - { - if (!m_leftMouseButton) - { - - if (deltay<0 || m_cameraDistance>1) - { - m_cameraDistance -= deltay*0.1f; - if (m_cameraDistance<1) - m_cameraDistance=1; - } else - { - b3Vector3 fwd = m_cameraTargetPosition-m_cameraPosition; - fwd.normalize(); - m_cameraTargetPosition += fwd*deltay*WHEEL_MULTIPLIER; - } - } else - { - if (b3Fabs(deltax)>b3Fabs(deltay)) - { - b3Vector3 fwd = m_cameraTargetPosition-m_cameraPosition; - b3Vector3 side = m_cameraUp.cross(fwd); - side.normalize(); - m_cameraTargetPosition += side * deltax*WHEEL_MULTIPLIER; - - } else - { - m_cameraTargetPosition -= m_cameraUp * deltay*WHEEL_MULTIPLIER; - - } - } - } - - void mouseMoveCallback(float x, float y) - { -// printf("moved to %f,%f\n",x,y); - if (m_altPressed || m_controlPressed) - { - float xDelta = x-m_mouseXpos; - float yDelta = y-m_mouseYpos; - - if (m_leftMouseButton) - { - // if (b3Fabs(xDelta)>b3Fabs(yDelta)) - // { - m_azi -= xDelta*MOUSE_MOVE_MULTIPLIER; - // } else - // { - m_ele += yDelta*MOUSE_MOVE_MULTIPLIER; - // } - } - if (m_middleMouseButton) - { - m_cameraTargetPosition += m_cameraUp * yDelta*0.01; - - - b3Vector3 fwd = m_cameraTargetPosition-m_cameraPosition; - b3Vector3 side = m_cameraUp.cross(fwd); - side.normalize(); - m_cameraTargetPosition += side * xDelta*0.01; - - } - if (m_rightMouseButton) - { - m_cameraDistance -= xDelta*0.01f; - m_cameraDistance -= yDelta*0.01f; - if (m_cameraDistance<1) - m_cameraDistance=1; - if (m_cameraDistance>1000) - m_cameraDistance=1000; - } - } - - //printf("m_azi/pitch = %f\n", m_azi); -// printf("m_ele/yaw = %f\n", m_ele); - - m_mouseXpos = x; - m_mouseYpos = y; - m_mouseInitialized = true; - } - - void mouseButtonCallback(int button, int state, float x, float y) - { - - if (button==0) - m_leftMouseButton=state; - if (button==1) - m_middleMouseButton=state; - - if (button==2) - m_rightMouseButton=state; - - m_mouseXpos = x; - m_mouseYpos = y; - m_mouseInitialized = true; - } - void keyboardCallback(int key, int state) - { - if (key==B3G_CONTROL) - { - m_controlPressed=state; - } - if (key==B3G_ALT) - { - m_altPressed = state; - } - } - -}; - -struct GLInstanceRendererInternalData* GLInstancingRenderer::getInternalData() -{ - return m_data; -} - -void b3DefaultWheelCallback(float deltax, float deltay) -{ - if (sData2) - sData2->wheelCallback(deltax,deltay); -} -void b3DefaultMouseButtonCallback(int button, int state, float x, float y) -{ - if (sData2) - sData2->mouseButtonCallback(button, state, x, y); -} -void b3DefaultMouseMoveCallback( float x, float y) -{ - if (sData2) - sData2->mouseMoveCallback( x, y); -} - -void b3DefaultKeyboardCallback(int key, int state) -{ - if (sData2) - sData2->keyboardCallback(key,state); -} - - -static GLuint linesShader; // The line renderer -static GLuint useShadowMapInstancingShader; // The shadow instancing renderer -static GLuint createShadowMapInstancingShader; // The shadow instancing renderer -static GLuint instancingShader; // The instancing renderer -static GLuint instancingShaderPointSprite; // The point sprite instancing renderer - - - - -//static bool done = false; - -static GLint lines_ModelViewMatrix=0; -static GLint lines_ProjectionMatrix=0; -static GLint lines_position=0; -static GLint lines_colour=0; -GLuint lineVertexBufferObject=0; -GLuint lineVertexArrayObject=0; -GLuint lineIndexVbo = 0; - -GLuint linesVertexBufferObject=0; -GLuint linesVertexArrayObject=0; -GLuint linesIndexVbo = 0; - - -static GLint useShadow_ModelViewMatrix=0; -static GLint useShadow_MVP=0; -static GLint useShadow_lightDirIn=0; - -static GLint useShadow_ProjectionMatrix=0; -static GLint useShadow_DepthBiasModelViewMatrix=0; -static GLint useShadow_uniform_texture_diffuse = 0; -static GLint useShadow_shadowMap = 0; - -static GLint createShadow_depthMVP=0; - -static GLint ModelViewMatrix=0; -static GLint ProjectionMatrix=0; - -static GLint uniform_texture_diffuse = 0; - -static GLint screenWidthPointSprite=0; -static GLint ModelViewMatrixPointSprite=0; -static GLint ProjectionMatrixPointSprite=0; -//static GLint uniform_texture_diffusePointSprite= 0; - - - -GLInstancingRenderer::GLInstancingRenderer(int maxNumObjectCapacity, int maxShapeCapacityInBytes) - :m_maxNumObjectCapacity(maxNumObjectCapacity), - m_maxShapeCapacityInBytes(maxShapeCapacityInBytes), - m_textureenabled(true), - m_textureinitialized(false), - m_screenWidth(0), - m_screenHeight(0), - m_upAxis(1), - m_enableBlend(false) -{ - - m_data = new InternalDataRenderer; - m_data->m_totalNumInstances = 0; - - sData2 = m_data; - - m_data->m_instance_positions_ptr.resize(m_maxNumObjectCapacity*4); - m_data->m_instance_quaternion_ptr.resize(m_maxNumObjectCapacity*4); - m_data->m_instance_colors_ptr.resize(m_maxNumObjectCapacity*4); - m_data->m_instance_scale_ptr.resize(m_maxNumObjectCapacity*3); - -} - -void GLInstancingRenderer::removeAllInstances() -{ - for (int i=0;im_index_vbo) - { - glDeleteBuffers(1,&m_graphicsInstances[i]->m_index_vbo); - } - if (m_graphicsInstances[i]->m_cube_vao) - { - glDeleteVertexArrays(1,&m_graphicsInstances[i]->m_cube_vao); - } - delete m_graphicsInstances[i]; - } - m_graphicsInstances.clear(); -} - -GLInstancingRenderer::~GLInstancingRenderer() -{ - delete m_data->m_shadowMap; - glDeleteTextures(1,&m_data->m_shadowTexture); - glDeleteTextures(1,&m_data->m_defaultTexturehandle); - - removeAllInstances(); - - sData2=0; - - if (m_data) - { - if (m_data->m_vbo) - glDeleteBuffers(1,&m_data->m_vbo); - } - delete m_data; -} - - - - - - - - - -void GLInstancingRenderer::writeSingleInstanceTransformToCPU(const float* position, const float* orientation, int srcIndex) -{ - b3Assert(srcIndexm_totalNumInstances); - b3Assert(srcIndex>=0); - m_data->m_instance_positions_ptr[srcIndex*4+0]=position[0]; - m_data->m_instance_positions_ptr[srcIndex*4+1]=position[1]; - m_data->m_instance_positions_ptr[srcIndex*4+2]=position[2]; - m_data->m_instance_positions_ptr[srcIndex*4+3]=1; - - m_data->m_instance_quaternion_ptr[srcIndex*4+0]=orientation[0]; - m_data->m_instance_quaternion_ptr[srcIndex*4+1]=orientation[1]; - m_data->m_instance_quaternion_ptr[srcIndex*4+2]=orientation[2]; - m_data->m_instance_quaternion_ptr[srcIndex*4+3]=orientation[3]; - -/* m_data->m_instance_colors_ptr[srcIndex*4+0]=color[0]; - m_data->m_instance_colors_ptr[srcIndex*4+1]=color[1]; - m_data->m_instance_colors_ptr[srcIndex*4+2]=color[2]; - m_data->m_instance_colors_ptr[srcIndex*4+3]=color[3]; - */ -} - -void GLInstancingRenderer::writeSingleInstanceColorToCPU(double* color, int srcIndex) -{ - m_data->m_instance_colors_ptr[srcIndex*4+0]=float(color[0]); - m_data->m_instance_colors_ptr[srcIndex*4+1]=float(color[1]); - m_data->m_instance_colors_ptr[srcIndex*4+2]=float(color[2]); - m_data->m_instance_colors_ptr[srcIndex*4+3]=float(color[3]); -} - -void GLInstancingRenderer::writeSingleInstanceColorToCPU(float* color, int srcIndex) -{ - - m_data->m_instance_colors_ptr[srcIndex*4+0]=color[0]; - m_data->m_instance_colors_ptr[srcIndex*4+1]=color[1]; - m_data->m_instance_colors_ptr[srcIndex*4+2]=color[2]; - m_data->m_instance_colors_ptr[srcIndex*4+3]=color[3]; -} - - - -void GLInstancingRenderer::writeSingleInstanceTransformToGPU(float* position, float* orientation, int objectIndex) -{ - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - glFlush(); - - char* orgBase = (char*)glMapBuffer( GL_ARRAY_BUFFER,GL_READ_WRITE); - //b3GraphicsInstance* gfxObj = m_graphicsInstances[k]; - int totalNumInstances= 0; - for (int k=0;km_numGraphicsInstances; - } - - int POSITION_BUFFER_SIZE = (totalNumInstances*sizeof(float)*4); - - char* base = orgBase; - - float* positions = (float*)(base+m_maxShapeCapacityInBytes); - float* orientations = (float*)(base+m_maxShapeCapacityInBytes + POSITION_BUFFER_SIZE); - - - positions[objectIndex*4] = position[0]; - positions[objectIndex*4+1] = position[1]; - positions[objectIndex*4+2] = position[2]; - positions[objectIndex*4+3] = position[3]; - - orientations [objectIndex*4] = orientation[0]; - orientations [objectIndex*4+1] = orientation[1]; - orientations [objectIndex*4+2] = orientation[2]; - orientations [objectIndex*4+3] = orientation[3]; - - glUnmapBuffer( GL_ARRAY_BUFFER); - glFlush(); -} - - -void GLInstancingRenderer::writeTransforms() -{ - - b3Assert(glGetError() ==GL_NO_ERROR); - - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - glFlush(); - - b3Assert(glGetError() ==GL_NO_ERROR); - - - char* orgBase = (char*)glMapBuffer( GL_ARRAY_BUFFER,GL_READ_WRITE); - if (orgBase) - { - - - int totalNumInstances= 0; - - for (int k=0;km_numGraphicsInstances; - } - - m_data->m_totalNumInstances = totalNumInstances; - - for (int k=0;km_numGraphicsInstances;i++) - { - - int srcIndex=i+gfxObj->m_instanceOffset; - - positions[srcIndex*4] = m_data->m_instance_positions_ptr[srcIndex*4]; - positions[srcIndex*4+1] = m_data->m_instance_positions_ptr[srcIndex*4+1]; - positions[srcIndex*4+2] = m_data->m_instance_positions_ptr[srcIndex*4+2]; - positions[srcIndex*4+3] = m_data->m_instance_positions_ptr[srcIndex*4+3]; - - orientations[srcIndex*4]=m_data->m_instance_quaternion_ptr[srcIndex*4]; - orientations[srcIndex*4+1]=m_data->m_instance_quaternion_ptr[srcIndex*4+1]; - orientations[srcIndex*4+2]=m_data->m_instance_quaternion_ptr[srcIndex*4+2]; - orientations[srcIndex*4+3]=m_data->m_instance_quaternion_ptr[srcIndex*4+3]; - - colors[srcIndex*4]=m_data->m_instance_colors_ptr[srcIndex*4]; - colors[srcIndex*4+1]=m_data->m_instance_colors_ptr[srcIndex*4+1]; - colors[srcIndex*4+2]=m_data->m_instance_colors_ptr[srcIndex*4+2]; - colors[srcIndex*4+3]=m_data->m_instance_colors_ptr[srcIndex*4+3]; - - scaling[srcIndex*3]=m_data->m_instance_scale_ptr[srcIndex*3]; - scaling[srcIndex*3+1]=m_data->m_instance_scale_ptr[srcIndex*3+1]; - scaling[srcIndex*3+2]=m_data->m_instance_scale_ptr[srcIndex*3+2]; - - } - } - } else - { - b3Error("ERROR glMapBuffer failed\n"); - } - b3Assert(glGetError() ==GL_NO_ERROR); - - glUnmapBuffer( GL_ARRAY_BUFFER); - //if this glFinish is removed, the animation is not always working/blocks - //@todo: figure out why - glFlush(); - glBindBuffer(GL_ARRAY_BUFFER, 0);//m_data->m_vbo); - - b3Assert(glGetError() ==GL_NO_ERROR); - -} - -int GLInstancingRenderer::registerGraphicsInstance(int shapeIndex, const double* pos1, const double* orn1, const double* color1, const double* scaling1) -{ - float pos[4] = {(float)pos1[0],(float)pos1[1],(float)pos1[2],(float)pos1[3]}; - float orn[4] = {(float)orn1[0],(float)orn1[1],(float)orn1[2],(float)orn1[3]}; - float color[4] = {(float)color1[0],(float)color1[1],(float)color1[2],(float)color1[3]}; - float scaling[4] = {(float)scaling1[0],(float)scaling1[1],(float)scaling1[2],(float)scaling1[3]}; - return registerGraphicsInstance(shapeIndex,pos,orn,color,scaling); -} - - -int GLInstancingRenderer::registerGraphicsInstance(int shapeIndex, const float* position, const float* quaternion, const float* color, const float* scaling) -{ - b3Assert(shapeIndex == (m_graphicsInstances.size()-1)); - b3Assert(m_graphicsInstances.size()m_numGraphicsInstances + gfxObj->m_instanceOffset; - - int maxElements = m_data->m_instance_positions_ptr.size(); - if (index*4m_instance_positions_ptr[index*4]=position[0]; - m_data->m_instance_positions_ptr[index*4+1]=position[1]; - m_data->m_instance_positions_ptr[index*4+2]=position[2]; - m_data->m_instance_positions_ptr[index*4+3]=1; - - m_data->m_instance_quaternion_ptr[index*4]=quaternion[0]; - m_data->m_instance_quaternion_ptr[index*4+1]=quaternion[1]; - m_data->m_instance_quaternion_ptr[index*4+2]=quaternion[2]; - m_data->m_instance_quaternion_ptr[index*4+3]=quaternion[3]; - - m_data->m_instance_colors_ptr[index*4]=color[0]; - m_data->m_instance_colors_ptr[index*4+1]=color[1]; - m_data->m_instance_colors_ptr[index*4+2]=color[2]; - m_data->m_instance_colors_ptr[index*4+3]=color[3]; - - m_data->m_instance_scale_ptr[index*3] = scaling[0]; - m_data->m_instance_scale_ptr[index*3+1] = scaling[1]; - m_data->m_instance_scale_ptr[index*3+2] = scaling[2]; - - gfxObj->m_numGraphicsInstances++; - m_data->m_totalNumInstances++; - } else - { - b3Error("registerGraphicsInstance out of range, %d\n", maxElements); - return -1; - } - return index;//gfxObj->m_numGraphicsInstances; -} - - -int GLInstancingRenderer::registerTexture(const unsigned char* texels, int width, int height) -{ - b3Assert(glGetError() ==GL_NO_ERROR); - - int textureIndex = m_data->m_textureHandles.size(); - const GLubyte* image= (const GLubyte*)texels; - GLuint textureHandle; - glGenTextures(1,(GLuint*)&textureHandle); - glBindTexture(GL_TEXTURE_2D,textureHandle); - - b3Assert(glGetError() ==GL_NO_ERROR); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width,height,0,GL_RGB,GL_UNSIGNED_BYTE,image); - - - b3Assert(glGetError() ==GL_NO_ERROR); - - glGenerateMipmap(GL_TEXTURE_2D); - b3Assert(glGetError() ==GL_NO_ERROR); - - - m_data->m_textureHandles.push_back(textureHandle); - return textureIndex; -} - -void GLInstancingRenderer::updateShape(int shapeIndex, const float* vertices) -{ - b3GraphicsInstance* gfxObj = m_graphicsInstances[shapeIndex]; - int numvertices = gfxObj->m_numVertices; - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - char* dest= (char*)glMapBuffer( GL_ARRAY_BUFFER,GL_WRITE_ONLY);//GL_WRITE_ONLY - int vertexStrideInBytes = 9*sizeof(float); - int sz = numvertices*vertexStrideInBytes; - memcpy(dest+vertexStrideInBytes*gfxObj->m_vertexArrayOffset,vertices,sz); - glUnmapBuffer( GL_ARRAY_BUFFER); -} - -int GLInstancingRenderer::registerShape(const float* vertices, int numvertices, const int* indices, int numIndices,int primitiveType, int textureId) -{ - b3GraphicsInstance* gfxObj = new b3GraphicsInstance; - - if (textureId>=0) - { - gfxObj->m_texturehandle = m_data->m_textureHandles[textureId]; - } - - gfxObj->m_primitiveType = primitiveType; - - if (m_graphicsInstances.size()) - { - b3GraphicsInstance* prevObj = m_graphicsInstances[m_graphicsInstances.size()-1]; - gfxObj->m_instanceOffset = prevObj->m_instanceOffset + prevObj->m_numGraphicsInstances; - gfxObj->m_vertexArrayOffset = prevObj->m_vertexArrayOffset + prevObj->m_numVertices; - } else - { - gfxObj->m_instanceOffset = 0; - } - - m_graphicsInstances.push_back(gfxObj); - gfxObj->m_numIndices = numIndices; - gfxObj->m_numVertices = numvertices; - - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - char* dest= (char*)glMapBuffer( GL_ARRAY_BUFFER,GL_WRITE_ONLY);//GL_WRITE_ONLY - int vertexStrideInBytes = 9*sizeof(float); - int sz = numvertices*vertexStrideInBytes; -#ifdef B3_DEBUG - int totalUsed = vertexStrideInBytes*gfxObj->m_vertexArrayOffset+sz; - b3Assert(totalUsedm_maxShapeCapacityInBytes); -#endif//B3_DEBUG - - memcpy(dest+vertexStrideInBytes*gfxObj->m_vertexArrayOffset,vertices,sz); - glUnmapBuffer( GL_ARRAY_BUFFER); - - glGenBuffers(1, &gfxObj->m_index_vbo); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, gfxObj->m_index_vbo); - int indexBufferSizeInBytes = gfxObj->m_numIndices*sizeof(int); - - glBufferData(GL_ELEMENT_ARRAY_BUFFER, indexBufferSizeInBytes, NULL, GL_STATIC_DRAW); - glBufferSubData(GL_ELEMENT_ARRAY_BUFFER,0,indexBufferSizeInBytes,indices); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - - glGenVertexArrays(1, &gfxObj->m_cube_vao); - glBindVertexArray(gfxObj->m_cube_vao); - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - glBindVertexArray(0); - glBindBuffer(GL_ARRAY_BUFFER,0); - glBindVertexArray(0); - - - return m_graphicsInstances.size()-1; -} - - - - -void GLInstancingRenderer::InitShaders() -{ - - int POSITION_BUFFER_SIZE = (m_maxNumObjectCapacity*sizeof(float)*4); - int ORIENTATION_BUFFER_SIZE = (m_maxNumObjectCapacity*sizeof(float)*4); - int COLOR_BUFFER_SIZE = (m_maxNumObjectCapacity*sizeof(float)*4); - int SCALE_BUFFER_SIZE = (m_maxNumObjectCapacity*sizeof(float)*3); - - linesShader = gltLoadShaderPair(linesVertexShader,linesFragmentShader); - lines_ModelViewMatrix = glGetUniformLocation(linesShader, "ModelViewMatrix"); - lines_ProjectionMatrix = glGetUniformLocation(linesShader, "ProjectionMatrix"); - lines_colour=glGetUniformLocation(linesShader, "colour"); - lines_position=glGetAttribLocation(linesShader, "position"); - glLinkProgram(linesShader); - glUseProgram(linesShader); - - { - glGenVertexArrays(1, &linesVertexArrayObject); - glBindVertexArray(linesVertexArrayObject); - - glGenBuffers(1, &linesVertexBufferObject); - glGenBuffers(1, &linesIndexVbo); - - int sz = MAX_LINES_IN_BATCH*sizeof(b3Vector3); - glBindVertexArray(linesVertexArrayObject); - glBindBuffer(GL_ARRAY_BUFFER, linesVertexBufferObject); - glBufferData(GL_ARRAY_BUFFER, sz, 0, GL_DYNAMIC_DRAW); - - glBindVertexArray(0); - } - { - glGenVertexArrays(1, &lineVertexArrayObject); - glBindVertexArray(lineVertexArrayObject); - - glGenBuffers(1, &lineVertexBufferObject); - glGenBuffers(1, &lineIndexVbo); - - int sz = MAX_POINTS_IN_BATCH*sizeof(b3Vector3); - glBindVertexArray(lineVertexArrayObject); - glBindBuffer(GL_ARRAY_BUFFER, lineVertexBufferObject); - glBufferData(GL_ARRAY_BUFFER, sz, 0, GL_DYNAMIC_DRAW); - - glBindVertexArray(0); - } - - //glGetIntegerv(GL_ALIASED_LINE_WIDTH_RANGE, range); - glGetIntegerv(GL_SMOOTH_LINE_WIDTH_RANGE, lineWidthRange); - - - - - useShadowMapInstancingShader = gltLoadShaderPair(useShadowMapInstancingVertexShader,useShadowMapInstancingFragmentShader); - - glLinkProgram(useShadowMapInstancingShader); - glUseProgram(useShadowMapInstancingShader); - useShadow_ModelViewMatrix = glGetUniformLocation(useShadowMapInstancingShader, "ModelViewMatrix"); - useShadow_MVP = glGetUniformLocation(useShadowMapInstancingShader, "MVP"); - useShadow_ProjectionMatrix = glGetUniformLocation(useShadowMapInstancingShader, "ProjectionMatrix"); - useShadow_DepthBiasModelViewMatrix = glGetUniformLocation(useShadowMapInstancingShader, "DepthBiasModelViewProjectionMatrix"); - useShadow_uniform_texture_diffuse = glGetUniformLocation(useShadowMapInstancingShader, "Diffuse"); - useShadow_shadowMap = glGetUniformLocation(useShadowMapInstancingShader,"shadowMap"); - useShadow_lightDirIn = glGetUniformLocation(useShadowMapInstancingShader,"lightDirIn"); - - createShadowMapInstancingShader = gltLoadShaderPair(createShadowMapInstancingVertexShader,createShadowMapInstancingFragmentShader); - glLinkProgram(createShadowMapInstancingShader); - glUseProgram(createShadowMapInstancingShader); - createShadow_depthMVP = glGetUniformLocation(createShadowMapInstancingShader, "depthMVP"); - - glUseProgram(0); - - instancingShader = gltLoadShaderPair(instancingVertexShader,instancingFragmentShader); - glLinkProgram(instancingShader); - glUseProgram(instancingShader); - ModelViewMatrix = glGetUniformLocation(instancingShader, "ModelViewMatrix"); - ProjectionMatrix = glGetUniformLocation(instancingShader, "ProjectionMatrix"); - uniform_texture_diffuse = glGetUniformLocation(instancingShader, "Diffuse"); - glUseProgram(0); - - instancingShaderPointSprite = gltLoadShaderPair(pointSpriteVertexShader,pointSpriteFragmentShader); - glUseProgram(instancingShaderPointSprite); - ModelViewMatrixPointSprite = glGetUniformLocation(instancingShaderPointSprite, "ModelViewMatrix"); - ProjectionMatrixPointSprite = glGetUniformLocation(instancingShaderPointSprite, "ProjectionMatrix"); - screenWidthPointSprite = glGetUniformLocation(instancingShaderPointSprite, "screenWidth"); - - glUseProgram(0); - - //GLuint offset = 0; - - glGenBuffers(1, &m_data->m_vbo); - checkError("glGenBuffers"); - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - - - int size = m_maxShapeCapacityInBytes + POSITION_BUFFER_SIZE+ORIENTATION_BUFFER_SIZE+COLOR_BUFFER_SIZE+SCALE_BUFFER_SIZE; - m_data->m_vboSize = size; - - glBufferData(GL_ARRAY_BUFFER, size, 0, GL_DYNAMIC_DRAW);//GL_STATIC_DRAW); - - glBindBuffer(GL_ARRAY_BUFFER,0); - glBindVertexArray(0); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - - -} - - - - -void GLInstancingRenderer::init() -{ - b3Assert(glGetError() ==GL_NO_ERROR); - - - glEnable(GL_DEPTH_TEST); - glDepthFunc(GL_LESS); - - b3Assert(glGetError() ==GL_NO_ERROR); - -// glClearColor(float(0.),float(0.),float(0.4),float(0)); - - b3Assert(glGetError() ==GL_NO_ERROR); - - - b3Assert(glGetError() ==GL_NO_ERROR); - - { - B3_PROFILE("texture"); - if(m_textureenabled) - { - if(!m_textureinitialized) - { - glActiveTexture(GL_TEXTURE0); - - GLubyte* image=new GLubyte[256*256*3]; - for(int y=0;y<256;++y) - { -// const int t=y>>5; - GLubyte* pi=image+y*256*3; - for(int x=0;x<256;++x) - { - if (x<2||y<2||x>253||y>253) - { - pi[0]=255;//0; - pi[1]=255;//0; - pi[2]=255;//0; - } else - { - pi[0]=255; - pi[1]=255; - pi[2]=255; - } - - /* - const int s=x>>5; - const GLubyte b=180; - GLubyte c=b+((s+t&1)&1)*(255-b); - pi[0]=c; - pi[1]=c; - pi[2]=c; - */ - - pi+=3; - } - } - - glGenTextures(1,(GLuint*)&m_data->m_defaultTexturehandle); - glBindTexture(GL_TEXTURE_2D,m_data->m_defaultTexturehandle); - b3Assert(glGetError() ==GL_NO_ERROR); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 256,256,0,GL_RGB,GL_UNSIGNED_BYTE,image); - glGenerateMipmap(GL_TEXTURE_2D); - - b3Assert(glGetError() ==GL_NO_ERROR); - - delete[] image; - m_textureinitialized=true; - } - - b3Assert(glGetError() ==GL_NO_ERROR); - - glBindTexture(GL_TEXTURE_2D,m_data->m_defaultTexturehandle); - b3Assert(glGetError() ==GL_NO_ERROR); - - - } else - { - glDisable(GL_TEXTURE_2D); - b3Assert(glGetError() ==GL_NO_ERROR); - } - } - //glEnable(GL_COLOR_MATERIAL); - - b3Assert(glGetError() ==GL_NO_ERROR); - - // glEnable(GL_CULL_FACE); - // glCullFace(GL_BACK); -} - - -static void b3CreateFrustum( - float left, - float right, - float bottom, - float top, - float nearVal, - float farVal, - float frustum[16]) -{ - - frustum[0*4+0] = (float(2) * nearVal) / (right - left); - frustum[0*4+1] = float(0); - frustum[0*4+2] = float(0); - frustum[0*4+3] = float(0); - - frustum[1*4+0] = float(0); - frustum[1*4+1] = (float(2) * nearVal) / (top - bottom); - frustum[1*4+2] = float(0); - frustum[1*4+3] = float(0); - - frustum[2*4+0] = (right + left) / (right - left); - frustum[2*4+1] = (top + bottom) / (top - bottom); - frustum[2*4+2] = -(farVal + nearVal) / (farVal - nearVal); - frustum[2*4+3] = float(-1); - - frustum[3*4+0] = float(0); - frustum[3*4+1] = float(0); - frustum[3*4+2] = -(float(2) * farVal * nearVal) / (farVal - nearVal); - frustum[3*4+3] = float(0); - -} - - -static void b3Matrix4x4Mul(GLfloat aIn[4][4], GLfloat bIn[4][4], GLfloat result[4][4]) -{ - for (int j=0;j<4;j++) - for (int i=0;i<4;i++) - result[j][i] = aIn[0][i] * bIn[j][0] + aIn[1][i] * bIn[j][1] + aIn[2][i] * bIn[j][2] + aIn[3][i] * bIn[j][3]; -} - -static void b3Matrix4x4Mul16(GLfloat aIn[16], GLfloat bIn[16], GLfloat result[16]) -{ - for (int j=0;j<4;j++) - for (int i=0;i<4;i++) - result[j*4+i] = aIn[0*4+i] * bIn[j*4+0] + aIn[1*4+i] * bIn[j*4+1] + aIn[2*4+i] * bIn[j*4+2] + aIn[3*4+i] * bIn[j*4+3]; -} - - -static void b3CreateDiagonalMatrix(GLfloat value, GLfloat result[4][4]) -{ - for (int i=0;i<4;i++) - { - for (int j=0;j<4;j++) - { - if (i==j) - { - result[i][j] = value; - } else - { - result[i][j] = 0.f; - } - } - } -} - -static void b3CreateOrtho(GLfloat left, GLfloat right, GLfloat bottom, GLfloat top, GLfloat zNear, GLfloat zFar, GLfloat result[4][4]) -{ - b3CreateDiagonalMatrix(1.f,result); - - result[0][0] = 2.f / (right - left); - result[1][1] = 2.f / (top - bottom); - result[2][2] = - 2.f / (zFar - zNear); - result[3][0] = - (right + left) / (right - left); - result[3][1] = - (top + bottom) / (top - bottom); - result[3][2] = - (zFar + zNear) / (zFar - zNear); -} - -static void b3CreateLookAt(const b3Vector3& eye, const b3Vector3& center,const b3Vector3& up, GLfloat result[16]) -{ - b3Vector3 f = (center - eye).normalized(); - b3Vector3 u = up.normalized(); - b3Vector3 s = (f.cross(u)).normalized(); - u = s.cross(f); - - result[0*4+0] = s.x; - result[1*4+0] = s.y; - result[2*4+0] = s.z; - - result[0*4+1] = u.x; - result[1*4+1] = u.y; - result[2*4+1] = u.z; - - result[0*4+2] =-f.x; - result[1*4+2] =-f.y; - result[2*4+2] =-f.z; - - result[0*4+3] = 0.f; - result[1*4+3] = 0.f; - result[2*4+3] = 0.f; - - result[3*4+0] = -s.dot(eye); - result[3*4+1] = -u.dot(eye); - result[3*4+2] = f.dot(eye); - result[3*4+3] = 1.f; -} - - -void GLInstancingRenderer::resize(int width, int height) -{ - m_screenWidth = width; - m_screenHeight = height; -} - -void GLInstancingRenderer::updateCamera(int upAxis) -{ - - b3Assert(glGetError() ==GL_NO_ERROR); - - m_upAxis = upAxis; - int m_forwardAxis(-1); - switch (upAxis) - { - case 1: - m_forwardAxis = 2; - m_data->m_cameraUp = b3MakeVector3(0,1,0); - gLightPos = b3MakeVector3(-50.f,100,30); - break; - case 2: - m_forwardAxis = 1; - m_data->m_cameraUp = b3MakeVector3(0,0,1); - gLightPos = b3MakeVector3(-50.f,30,100); - break; - default: - b3Assert(0); - }; - - - float m_frustumZNear=0.01; - float m_frustumZFar=1000.f; - - -// m_azi=m_azi+0.01; - b3Scalar rele = m_data->m_ele * b3Scalar(0.01745329251994329547);// rads per deg - b3Scalar razi = m_data->m_azi * b3Scalar(0.01745329251994329547);// rads per deg - - - b3Quaternion rot(m_data->m_cameraUp,razi); - - b3Vector3 eyePos = b3MakeVector3(0,0,0); - eyePos[m_forwardAxis] = -m_data->m_cameraDistance; - - b3Vector3 forward = b3MakeVector3(eyePos[0],eyePos[1],eyePos[2]); - if (forward.length2() < B3_EPSILON) - { - forward.setValue(1.f,0.f,0.f); - } - b3Vector3 right = m_data->m_cameraUp.cross(forward); - b3Quaternion roll(right,-rele); - - eyePos = b3Matrix3x3(rot) * b3Matrix3x3(roll) * eyePos; - - m_data->m_cameraPosition[0] = eyePos.x; - m_data->m_cameraPosition[1] = eyePos.y; - m_data->m_cameraPosition[2] = eyePos.z; - m_data->m_cameraPosition += m_data->m_cameraTargetPosition; - - if (m_screenWidth == 0 && m_screenHeight == 0) - return; - - b3Scalar aspect; - b3Vector3 extents; - - aspect = m_screenWidth / (b3Scalar)m_screenHeight; - extents.setValue(aspect * 1.0f, 1.0f,0); - - - if (m_screenWidth > m_screenHeight) - { - b3CreateFrustum(-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar,m_data->m_projectionMatrix); - } else - { - b3CreateFrustum(-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar,m_data->m_projectionMatrix); - } - - b3CreateLookAt(m_data->m_cameraPosition,m_data->m_cameraTargetPosition,m_data->m_cameraUp,m_data->m_viewMatrix); - - -} - - -void GLInstancingRenderer::getCameraPosition(float cameraPos[4]) -{ - cameraPos[0] = m_data->m_cameraPosition[0]; - cameraPos[1] = m_data->m_cameraPosition[1]; - cameraPos[2] = m_data->m_cameraPosition[2]; - cameraPos[3] = 1.f; -} - -void GLInstancingRenderer::setCameraDistance(float dist) -{ - m_data->m_cameraDistance = dist; -} - -void GLInstancingRenderer::setCameraYaw(float yaw) -{ - m_data->m_ele = yaw; -} -void GLInstancingRenderer::setCameraPitch(float pitch) -{ - m_data->m_azi = pitch; -} - -float GLInstancingRenderer::getCameraYaw() const -{ - return m_data->m_ele; -} -float GLInstancingRenderer::getCameraPitch() const -{ - return m_data->m_azi; -} - -void GLInstancingRenderer::setCameraTargetPosition(float x, float y, float z) -{ - m_data->m_cameraTargetPosition = b3MakeVector3(x,y,z); -} -void GLInstancingRenderer::setCameraTargetPosition(float cameraPos[4]) -{ - setCameraTargetPosition(cameraPos[0],cameraPos[1],cameraPos[2]); -} - -void GLInstancingRenderer::getCameraTargetPosition(float cameraPos[4]) const -{ - cameraPos[0] = m_data->m_cameraTargetPosition.x; - cameraPos[1] = m_data->m_cameraTargetPosition.y; - cameraPos[2] = m_data->m_cameraTargetPosition.z; -} - - -float GLInstancingRenderer::getCameraDistance() const -{ - return m_data->m_cameraDistance; -} - - -void GLInstancingRenderer::getMouseDirection(float* dir, int x, int y) -{ - float top = 1.f; - float bottom = -1.f; - float nearPlane = 1.f; - float tanFov = (top-bottom)*0.5f / nearPlane; - float fov = b3Scalar(2.0) * b3Atan(tanFov); - - b3Vector3 rayFrom = m_data->m_cameraPosition; - b3Vector3 rayForward = (m_data->m_cameraTargetPosition-m_data->m_cameraPosition); - rayForward.normalize(); - float farPlane = 10000.f; - rayForward*= farPlane; - -// b3Vector3 rightOffset; - b3Vector3 vertical = m_data->m_cameraUp; - - b3Vector3 hor; - hor = rayForward.cross(vertical); - hor.normalize(); - vertical = hor.cross(rayForward); - vertical.normalize(); - - float tanfov = tanf(0.5f*fov); - - - hor *= 2.f * farPlane * tanfov; - vertical *= 2.f * farPlane * tanfov; - - b3Scalar aspect; - - aspect = m_screenWidth / (b3Scalar)m_screenHeight; - - hor*=aspect; - - - b3Vector3 rayToCenter = rayFrom + rayForward; - b3Vector3 dHor = hor * 1.f/float(m_screenWidth); - b3Vector3 dVert = vertical * 1.f/float(m_screenHeight); - - - b3Vector3 rayTo = rayToCenter - 0.5f * hor + 0.5f * vertical; - rayTo += b3Scalar(x) * dHor; - rayTo -= b3Scalar(y) * dVert; - - dir[0] = rayTo[0]; - dir[1] = rayTo[1]; - dir[2] = rayTo[2]; - -} - - - -//#define STB_IMAGE_WRITE_IMPLEMENTATION -#include "stb_image_write.h" -void writeTextureToPng(int textureWidth, int textureHeight, const char* fileName, int numComponents) -{ - - b3Assert(glGetError() ==GL_NO_ERROR); - glPixelStorei(GL_PACK_ALIGNMENT,4); - - glReadBuffer(GL_NONE); - float* orgPixels = (float*)malloc(textureWidth*textureHeight*numComponents*4); - char* pixels = (char*)malloc(textureWidth*textureHeight*numComponents*4); - glReadPixels(0,0,textureWidth, textureHeight, GL_DEPTH_COMPONENT, GL_FLOAT, orgPixels); - b3Assert(glGetError() ==GL_NO_ERROR); - for (int j=0;jm_projectionMatrix[0]); - glUniformMatrix4fv(lines_ModelViewMatrix, 1, false, &m_data->m_viewMatrix[0]); - glUniform4f(lines_colour,color[0],color[1],color[2],color[3]); - - glPointSize(pointDrawSize); - glBindVertexArray(lineVertexArrayObject); - - glBindBuffer(GL_ARRAY_BUFFER, lineVertexBufferObject); - - int maxPointsInBatch = MAX_POINTS_IN_BATCH; - int remainingPoints = numPoints; - int offsetNumPoints= 0; - while (1) - { - int curPointsInBatch = b3Min(maxPointsInBatch, remainingPoints); - if (curPointsInBatch) - { - - glBufferSubData(GL_ARRAY_BUFFER, 0, curPointsInBatch*pointStrideInBytes, positions + offsetNumPoints*(pointStrideInBytes / sizeof(float))); - glEnableVertexAttribArray(0); - int numFloats = 3;// pointStrideInBytes / sizeof(float); - glVertexAttribPointer(0, numFloats, GL_FLOAT, GL_FALSE, pointStrideInBytes, 0); - glDrawArrays(GL_POINTS, 0, curPointsInBatch); - remainingPoints -= curPointsInBatch; - offsetNumPoints += curPointsInBatch; - } - else - { - break; - } - } - - glBindVertexArray(0); - glPointSize(1); - glUseProgram(0); -} - -void GLInstancingRenderer::drawLines(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, const unsigned int* indices, int numIndices, float lineWidthIn) -{ - float lineWidth = lineWidthIn; - b3Clamp(lineWidth,(float)lineWidthRange[0],(float)lineWidthRange[1]); - glLineWidth(lineWidth); - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - b3Assert(glGetError() ==GL_NO_ERROR); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - - glActiveTexture(GL_TEXTURE0); - glBindTexture(GL_TEXTURE_2D,0); - - b3Assert(glGetError() ==GL_NO_ERROR); - glUseProgram(linesShader); - glUniformMatrix4fv(lines_ProjectionMatrix, 1, false, &m_data->m_projectionMatrix[0]); - glUniformMatrix4fv(lines_ModelViewMatrix, 1, false, &m_data->m_viewMatrix[0]); - glUniform4f(lines_colour,color[0],color[1],color[2],color[3]); - -// glPointSize(pointDrawSize); - glBindVertexArray(linesVertexArrayObject); - - b3Assert(glGetError() ==GL_NO_ERROR); - glBindBuffer(GL_ARRAY_BUFFER, linesVertexBufferObject); - - { - - glBufferData(GL_ARRAY_BUFFER, numPoints*pointStrideInBytes, 0,GL_DYNAMIC_DRAW); - - glBufferSubData(GL_ARRAY_BUFFER, 0, numPoints*pointStrideInBytes, positions); - b3Assert(glGetError() ==GL_NO_ERROR); - glBindBuffer(GL_ARRAY_BUFFER, 0); - glBindBuffer(GL_ARRAY_BUFFER, linesVertexBufferObject); - glEnableVertexAttribArray(0); - - b3Assert(glGetError() ==GL_NO_ERROR); - int numFloats = 3; - glVertexAttribPointer(0, numFloats, GL_FLOAT, GL_FALSE, pointStrideInBytes, 0); - b3Assert(glGetError() ==GL_NO_ERROR); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, linesIndexVbo); - int indexBufferSizeInBytes = numIndices*sizeof(int); - - glBufferData(GL_ELEMENT_ARRAY_BUFFER, indexBufferSizeInBytes, NULL, GL_DYNAMIC_DRAW); - glBufferSubData(GL_ELEMENT_ARRAY_BUFFER, 0, indexBufferSizeInBytes, indices); - - glDrawElements(GL_LINES, numIndices, GL_UNSIGNED_INT, 0); - } - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - glBindBuffer(GL_ARRAY_BUFFER, 0); -// for (int i=0;im_projectionMatrix[0]); - glUniformMatrix4fv(lines_ModelViewMatrix, 1, false, &m_data->m_viewMatrix[0]); - glUniform4f(lines_colour,color[0],color[1],color[2],color[3]); - - - b3Assert(glGetError() ==GL_NO_ERROR); - - const float vertexPositions[] = { - from[0],from[1],from[2],1, - to[0],to[1],to[2],1 - }; - int sz = sizeof(vertexPositions); - b3Assert(glGetError() ==GL_NO_ERROR); - - - b3Clamp(lineWidth,(float)lineWidthRange[0],(float)lineWidthRange[1]); - glLineWidth(lineWidth); - - b3Assert(glGetError() ==GL_NO_ERROR); - - glBindVertexArray(lineVertexArrayObject); - b3Assert(glGetError() ==GL_NO_ERROR); - - glBindBuffer(GL_ARRAY_BUFFER, lineVertexBufferObject); - - b3Assert(glGetError() ==GL_NO_ERROR); - - - { - glBufferSubData(GL_ARRAY_BUFFER, 0,sz, vertexPositions); - } - - - b3Assert(glGetError() ==GL_NO_ERROR); - - glBindBuffer(GL_ARRAY_BUFFER, 0); - glBindBuffer(GL_ARRAY_BUFFER, lineVertexBufferObject); - b3Assert(glGetError() ==GL_NO_ERROR); - - glEnableVertexAttribArray(0); - glVertexAttribPointer(0, 4, GL_FLOAT, GL_FALSE, 0, 0); - b3Assert(glGetError() ==GL_NO_ERROR); - - glDrawArrays(GL_LINES, 0, 2); - b3Assert(glGetError() ==GL_NO_ERROR); - - - glBindVertexArray(0); - glLineWidth(1); - - b3Assert(glGetError() ==GL_NO_ERROR); - glUseProgram(0); -} - -struct PointerCaster -{ - union { - int m_baseIndex; - GLvoid* m_pointer; - }; - - PointerCaster() - :m_pointer(0) - { - } - - -}; -void GLInstancingRenderer::renderSceneInternal(int renderMode) -{ - -// glEnable(GL_DEPTH_TEST); - - GLint dims[4]; - glGetIntegerv(GL_VIEWPORT, dims); - //we need to get the viewport dims, because on Apple Retina the viewport dimension is different from screenWidth - //printf("dims=%d,%d,%d,%d\n",dims[0],dims[1],dims[2],dims[3]); - // Accept fragment if it closer to the camera than the former one - //glDepthFunc(GL_LESS); - - // Cull triangles which normal is not towards the camera - //glEnable(GL_CULL_FACE); - - - - B3_PROFILE("GLInstancingRenderer::RenderScene"); - - { - B3_PROFILE("init"); - init(); - } - - - b3Assert(glGetError() ==GL_NO_ERROR); - - float depthProjectionMatrix[4][4]; - GLfloat depthModelViewMatrix[4][4]; - //GLfloat depthModelViewMatrix2[4][4]; - - // Compute the MVP matrix from the light's point of view - if (renderMode==B3_CREATE_SHADOWMAP_RENDERMODE) - { - glEnable(GL_CULL_FACE); - glCullFace(GL_FRONT); - - if (!m_data->m_shadowMap) - { - glActiveTexture(GL_TEXTURE0); - - glGenTextures(1,&m_data->m_shadowTexture); - glBindTexture(GL_TEXTURE_2D,m_data->m_shadowTexture); - //glTexImage2D(GL_TEXTURE_2D,0,GL_DEPTH_COMPONENT16,m_screenWidth,m_screenHeight,0,GL_DEPTH_COMPONENT,GL_FLOAT,0); - //glTexImage2D(GL_TEXTURE_2D,0,GL_DEPTH_COMPONENT32,m_screenWidth,m_screenHeight,0,GL_DEPTH_COMPONENT,GL_FLOAT,0); - glTexImage2D(GL_TEXTURE_2D, 0,GL_DEPTH_COMPONENT16, shadowMapWidth, shadowMapHeight, 0,GL_DEPTH_COMPONENT, GL_FLOAT, 0); - - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - - float l_ClampColor[] = {1.0, 1.0, 1.0, 1.0}; - glTexParameterfv(GL_TEXTURE_2D, GL_TEXTURE_BORDER_COLOR, l_ClampColor); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_BORDER); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_BORDER); -// glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); -// glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_COMPARE_FUNC, GL_LEQUAL); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_COMPARE_REF_TO_TEXTURE); - - m_data->m_shadowMap=new GLRenderToTexture(); - m_data->m_shadowMap->init(shadowMapWidth, shadowMapHeight,m_data->m_shadowTexture,RENDERTEXTURE_DEPTH); - } - m_data->m_shadowMap->enable(); - glViewport(0,0,shadowMapWidth,shadowMapHeight); - //glClearColor(1,1,1,1); - glClear(GL_DEPTH_BUFFER_BIT); - //glClearColor(0.3,0.3,0.3,1); - -// m_data->m_shadowMap->disable(); - // return; - glEnable(GL_CULL_FACE); - glCullFace(GL_BACK); // Cull back-facing triangles -> draw only front-facing triangles - - b3Assert(glGetError() ==GL_NO_ERROR); - } else - { - //glDisable(GL_CULL_FACE); - glCullFace(GL_BACK); - - } - - b3CreateOrtho(-shadowMapWorldSize,shadowMapWorldSize,-shadowMapWorldSize,shadowMapWorldSize,1,300,depthProjectionMatrix);//-14,14,-14,14,1,200, depthProjectionMatrix); - float depthViewMatrix[4][4]; - b3Vector3 center = b3MakeVector3(0,0,0); - b3Vector3 up =b3MakeVector3(0,1,0); - b3CreateLookAt(gLightPos,center,up,&depthViewMatrix[0][0]); - //b3CreateLookAt(lightPos,m_data->m_cameraTargetPosition,b3Vector3(0,1,0),(float*)depthModelViewMatrix2); - - GLfloat depthModelMatrix[4][4]; - b3CreateDiagonalMatrix(1.f,depthModelMatrix); - - b3Matrix4x4Mul(depthViewMatrix, depthModelMatrix, depthModelViewMatrix); - - GLfloat depthMVP[4][4]; - b3Matrix4x4Mul(depthProjectionMatrix,depthModelViewMatrix,depthMVP); - - GLfloat biasMatrix[4][4]={ - 0.5, 0.0, 0.0, 0.0, - 0.0, 0.5, 0.0, 0.0, - 0.0, 0.0, 0.5, 0.0, - 0.5, 0.5, 0.5, 1.0 - }; - - GLfloat depthBiasMVP[4][4]; - b3Matrix4x4Mul(biasMatrix,depthMVP,depthBiasMVP); - - - //float m_frustumZNear=0.1; - //float m_frustumZFar=100.f; - - - - //b3CreateFrustum(-m_frustumZNear, m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar,(float*)depthProjectionMatrix); - - - //b3CreateLookAt(lightPos,m_data->m_cameraTargetPosition,b3Vector3(0,0,1),(float*)depthModelViewMatrix); - - { - B3_PROFILE("updateCamera"); - // updateCamera(); - } - -b3Assert(glGetError() ==GL_NO_ERROR); - - - // glBindBuffer(GL_ARRAY_BUFFER, 0); - { - B3_PROFILE("glFlush2"); - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vbo); - glFlush(); - } -b3Assert(glGetError() ==GL_NO_ERROR); - - int totalNumInstances = 0; - - for (int i=0;im_numGraphicsInstances; - } - - int curOffset = 0; - //GLuint lastBindTexture = 0; - - - for (int i=0;im_numGraphicsInstances) - { - glActiveTexture(GL_TEXTURE0); - GLuint curBindTexture = 0; - if (gfxObj->m_texturehandle) - curBindTexture = gfxObj->m_texturehandle; - else - curBindTexture = m_data->m_defaultTexturehandle; - -//disable lazy evaluation, it just leads to bugs - //if (lastBindTexture != curBindTexture) - { - glBindTexture(GL_TEXTURE_2D,curBindTexture); - } - //lastBindTexture = curBindTexture; - -b3Assert(glGetError() ==GL_NO_ERROR); - // int myOffset = gfxObj->m_instanceOffset*4*sizeof(float); - - int POSITION_BUFFER_SIZE = (totalNumInstances*sizeof(float)*4); - int ORIENTATION_BUFFER_SIZE = (totalNumInstances*sizeof(float)*4); - int COLOR_BUFFER_SIZE = (totalNumInstances*sizeof(float)*4); -// int SCALE_BUFFER_SIZE = (totalNumInstances*sizeof(float)*3); - - glBindVertexArray(gfxObj->m_cube_vao); - - - int vertexStride = 9*sizeof(float); - PointerCaster vertex; - vertex.m_baseIndex = gfxObj->m_vertexArrayOffset*vertexStride; - - - glVertexAttribPointer(0, 4, GL_FLOAT, GL_FALSE, 9*sizeof(float), vertex.m_pointer); - glVertexAttribPointer(1, 4, GL_FLOAT, GL_FALSE, 0, (GLvoid *)(curOffset*4*sizeof(float)+m_maxShapeCapacityInBytes)); - glVertexAttribPointer(2, 4, GL_FLOAT, GL_FALSE, 0, (GLvoid *)(curOffset*4*sizeof(float)+m_maxShapeCapacityInBytes+POSITION_BUFFER_SIZE)); - - PointerCaster uv; - uv.m_baseIndex = 7*sizeof(float)+vertex.m_baseIndex; - - PointerCaster normal; - normal.m_baseIndex = 4*sizeof(float)+vertex.m_baseIndex; - - glVertexAttribPointer(3, 2, GL_FLOAT, GL_FALSE, 9*sizeof(float), uv.m_pointer); - glVertexAttribPointer(4, 3, GL_FLOAT, GL_FALSE, 9*sizeof(float), normal.m_pointer); - glVertexAttribPointer(5, 4, GL_FLOAT, GL_FALSE, 0, (GLvoid *)(curOffset*4*sizeof(float)+m_maxShapeCapacityInBytes+POSITION_BUFFER_SIZE+ORIENTATION_BUFFER_SIZE)); - glVertexAttribPointer(6, 3, GL_FLOAT, GL_FALSE, 0, (GLvoid *)(curOffset*3*sizeof(float)+m_maxShapeCapacityInBytes+POSITION_BUFFER_SIZE+ORIENTATION_BUFFER_SIZE+COLOR_BUFFER_SIZE)); - - glEnableVertexAttribArray(0); - glEnableVertexAttribArray(1); - glEnableVertexAttribArray(2); - glEnableVertexAttribArray(3); - glEnableVertexAttribArray(4); - glEnableVertexAttribArray(5); - glEnableVertexAttribArray(6); - glVertexAttribDivisor(0, 0); - glVertexAttribDivisor(1, 1); - glVertexAttribDivisor(2, 1); - glVertexAttribDivisor(3, 0); - glVertexAttribDivisor(4, 0); - glVertexAttribDivisor(5, 1); - glVertexAttribDivisor(6, 1); - - - - - - - int indexCount = gfxObj->m_numIndices; - GLvoid* indexOffset = 0; - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, gfxObj->m_index_vbo); - { - B3_PROFILE("glDrawElementsInstanced"); - - if (gfxObj->m_primitiveType==B3_GL_POINTS) - { - glUseProgram(instancingShaderPointSprite); - glUniformMatrix4fv(ProjectionMatrixPointSprite, 1, false, &m_data->m_projectionMatrix[0]); - glUniformMatrix4fv(ModelViewMatrixPointSprite, 1, false, &m_data->m_viewMatrix[0]); - glUniform1f(screenWidthPointSprite,float(m_screenWidth)); - - //glUniform1i(uniform_texture_diffusePointSprite, 0); - b3Assert(glGetError() ==GL_NO_ERROR); - glPointSize(20); - -#ifndef __APPLE__ - glEnable(GL_POINT_SPRITE_ARB); -// glTexEnvi(GL_POINT_SPRITE_ARB, GL_COORD_REPLACE_ARB, GL_TRUE); -#endif - - glEnable(GL_VERTEX_PROGRAM_POINT_SIZE); - glDrawElementsInstanced(GL_POINTS, indexCount, GL_UNSIGNED_INT, indexOffset, gfxObj->m_numGraphicsInstances); - } else - { - switch (renderMode) - { - - case B3_DEFAULT_RENDERMODE: - { - glUseProgram(instancingShader); - glUniformMatrix4fv(ProjectionMatrix, 1, false, &m_data->m_projectionMatrix[0]); - glUniformMatrix4fv(ModelViewMatrix, 1, false, &m_data->m_viewMatrix[0]); - glUniform1i(uniform_texture_diffuse, 0); - glDrawElementsInstanced(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, indexOffset, gfxObj->m_numGraphicsInstances); - break; - } - case B3_CREATE_SHADOWMAP_RENDERMODE: - { - /*printf("createShadowMapInstancingShader=%d\n",createShadowMapInstancingShader); - printf("createShadow_depthMVP=%d\n",createShadow_depthMVP); - printf("indexOffset=%d\n",indexOffset); - printf("gfxObj->m_numGraphicsInstances=%d\n",gfxObj->m_numGraphicsInstances); - printf("indexCount=%d\n",indexCount); - */ - glUseProgram(createShadowMapInstancingShader); - glUniformMatrix4fv(createShadow_depthMVP, 1, false, &depthMVP[0][0]); - glDrawElementsInstanced(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, indexOffset, gfxObj->m_numGraphicsInstances); - break; - } - - case B3_USE_SHADOWMAP_RENDERMODE: - { - if (m_enableBlend) - { - glEnable (GL_BLEND); - glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - } - - glUseProgram(useShadowMapInstancingShader); - glUniformMatrix4fv(useShadow_ProjectionMatrix, 1, false, &m_data->m_projectionMatrix[0]); - glUniformMatrix4fv(useShadow_ModelViewMatrix, 1, false, &m_data->m_viewMatrix[0]); - float MVP[16]; - b3Matrix4x4Mul16(m_data->m_projectionMatrix,m_data->m_viewMatrix,MVP); - glUniformMatrix4fv(useShadow_MVP, 1, false, &MVP[0]); - b3Vector3 gLightDir = gLightPos; - gLightDir.normalize(); - glUniform3f(useShadow_lightDirIn,gLightDir[0],gLightDir[1],gLightDir[2]); - glUniformMatrix4fv(useShadow_DepthBiasModelViewMatrix, 1, false, &depthBiasMVP[0][0]); - glActiveTexture(GL_TEXTURE1); - glBindTexture(GL_TEXTURE_2D, m_data->m_shadowTexture); - glUniform1i(useShadow_shadowMap,1); - glDrawElementsInstanced(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, indexOffset, gfxObj->m_numGraphicsInstances); - if (m_enableBlend) - { - glDisable (GL_BLEND); - } - - break; - } - default: - { - // b3Assert(0); - } - }; - } - - - //glDrawElementsInstanced(GL_LINE_LOOP, indexCount, GL_UNSIGNED_INT, (void*)indexOffset, gfxObj->m_numGraphicsInstances); - } - } - curOffset+= gfxObj->m_numGraphicsInstances; - } - - { - B3_PROFILE("glFlush"); - glFlush(); - } - if (renderMode==B3_CREATE_SHADOWMAP_RENDERMODE) - { - // writeTextureToPng(shadowMapWidth,shadowMapHeight,"shadowmap.png",4); - m_data->m_shadowMap->disable(); - glViewport(dims[0],dims[1],dims[2],dims[3]); - - } - - b3Assert(glGetError() ==GL_NO_ERROR); - { - B3_PROFILE("glUseProgram(0);"); - glUseProgram(0); - glBindBuffer(GL_ARRAY_BUFFER,0); - glBindVertexArray(0); - } - - - - glDisable(GL_CULL_FACE); - b3Assert(glGetError() ==GL_NO_ERROR); -} - - -void GLInstancingRenderer::CleanupShaders() -{ -} - -void GLInstancingRenderer::enableShadowMap() -{ - glActiveTexture(GL_TEXTURE0); - //glEnable(GL_TEXTURE_2D); - glBindTexture(GL_TEXTURE_2D, m_data->m_shadowTexture); - //glBindTexture(GL_TEXTURE_2D, m_data->m_defaultTexturehandle); - -} - -void GLInstancingRenderer::getCameraViewMatrix(float viewMat[16]) const -{ - for (int i=0;i<16;i++) - { - viewMat[i] = m_data->m_viewMatrix[i]; - } - -} -void GLInstancingRenderer::getCameraProjectionMatrix(float projMat[16]) const -{ - for (int i=0;i<16;i++) - { - projMat[i] = m_data->m_projectionMatrix[i]; - } -} diff --git a/btgui/OpenGLWindow/GLInstancingRenderer.h b/btgui/OpenGLWindow/GLInstancingRenderer.h deleted file mode 100644 index e02b937d8..000000000 --- a/btgui/OpenGLWindow/GLInstancingRenderer.h +++ /dev/null @@ -1,174 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - -#ifndef GL_INSTANCING_RENDERER_H -#define GL_INSTANCING_RENDERER_H - -#include "Bullet3Common/b3AlignedObjectArray.h" -#include "OpenGLWindow/CommonRenderInterface.h" - - -void b3DefaultMouseButtonCallback( int button, int state, float x, float y); -void b3DefaultMouseMoveCallback( float x, float y); -void b3DefaultKeyboardCallback(int key, int state); -void b3DefaultWheelCallback( float deltax, float deltay); - - - -class GLInstancingRenderer : public CommonRenderInterface -{ - - b3AlignedObjectArray m_graphicsInstances; - - int m_maxNumObjectCapacity; - int m_maxShapeCapacityInBytes; - struct InternalDataRenderer* m_data; - - bool m_textureenabled; - bool m_textureinitialized; - - int m_screenWidth; - int m_screenHeight; - - int m_upAxis; - bool m_enableBlend; - - void renderSceneInternal(int renderMode=B3_DEFAULT_RENDERMODE); - - -public: - GLInstancingRenderer(int m_maxObjectCapacity, int maxShapeCapacityInBytes = 56*1024*1024); - virtual ~GLInstancingRenderer(); - - virtual void init(); - - virtual void renderScene(); - - void InitShaders(); - void CleanupShaders(); - void removeAllInstances(); - - virtual void updateShape(int shapeIndex, const float* vertices); - - ///vertices must be in the format x,y,z, nx,ny,nz, u,v - virtual int registerShape(const float* vertices, int numvertices, const int* indices, int numIndices, int primitiveType=B3_GL_TRIANGLES, int textureIndex=-1); - - virtual int registerTexture(const unsigned char* texels, int width, int height); - - ///position x,y,z, quaternion x,y,z,w, color r,g,b,a, scaling x,y,z - virtual int registerGraphicsInstance(int shapeIndex, const float* position, const float* quaternion, const float* color, const float* scaling); - virtual int registerGraphicsInstance(int shapeIndex, const double* position, const double* quaternion, const double* color, const double* scaling); - - void writeTransforms(); - - virtual void writeSingleInstanceTransformToCPU(const float* position, const float* orientation, int srcIndex); - virtual void writeSingleInstanceTransformToCPU(const double* position, const double* orientation, int srcIndex) - { - float pos[4]; - float orn[4]; - pos[0] = (float)position[0]; - pos[1] = (float)position[1]; - pos[2] = (float)position[2]; - pos[3] = (float)position[3]; - orn[0] =(float)orientation[0]; - orn[1] =(float)orientation[1]; - orn[2] =(float)orientation[2]; - orn[3] =(float)orientation[3]; - writeSingleInstanceTransformToCPU(pos,orn,srcIndex); - - } - - virtual void writeSingleInstanceTransformToGPU(float* position, float* orientation, int srcIndex); - - virtual void writeSingleInstanceColorToCPU(float* color, int srcIndex); - virtual void writeSingleInstanceColorToCPU(double* color, int srcIndex); - - virtual void getMouseDirection(float* dir, int mouseX, int mouseY); - - struct GLInstanceRendererInternalData* getInternalData(); - - virtual void drawLine(const float from[4], const float to[4], const float color[4], float lineWidth=1); - virtual void drawLine(const double from[4], const double to[4], const double color[4], double lineWidth=1); - virtual void drawLines(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, const unsigned int* indices, int numIndices, float pointDrawSize); - virtual void drawPoints(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, float pointDrawSize); - virtual void drawPoint(const float* position, const float color[4], float pointSize=1); - virtual void drawPoint(const double* position, const double color[4], double pointDrawSize=1); - virtual void updateCamera(int upAxis=1); - - virtual void getCameraPosition(float cameraPos[4]); - virtual void getCameraPosition(double cameraPos[4]) - { - float campos[4]; - getCameraPosition(campos); - cameraPos[0] = campos[0]; - cameraPos[1] = campos[1]; - cameraPos[2] = campos[2]; - cameraPos[3] = campos[3]; - } - - virtual void setCameraDistance(float dist); - virtual float getCameraDistance() const; - - //set the camera 'target' - virtual void setCameraTargetPosition(float x, float y, float z); - virtual void setCameraTargetPosition(float cameraPos[4]); - virtual void getCameraTargetPosition(float cameraPos[4]) const; - virtual void getCameraTargetPosition(double cameraPos[4]) const - { - float campos[4]; - getCameraTargetPosition(campos); - cameraPos[0] = campos[0]; - cameraPos[1] = campos[1]; - cameraPos[2] = campos[2]; - cameraPos[3] = campos[3]; - - } - - virtual void setCameraYaw(float yaw); - virtual void setCameraPitch(float pitch); - virtual float getCameraYaw() const; - virtual float getCameraPitch() const; - - virtual void getCameraViewMatrix(float viewMat[16]) const; - virtual void getCameraProjectionMatrix(float projMat[16]) const; - - - virtual void resize(int width, int height); - virtual int getScreenWidth() - { - return m_screenWidth; - } - virtual int getScreenHeight() - { - return m_screenHeight; - } - - virtual int getMaxShapeCapacity() const - { - return m_maxShapeCapacityInBytes; - } - virtual int getInstanceCapacity() const - { - return m_maxNumObjectCapacity; - } - virtual void enableShadowMap(); - virtual void enableBlend(bool blend) - { - m_enableBlend = blend; - } - -}; - -#endif //GL_INSTANCING_RENDERER_H diff --git a/btgui/OpenGLWindow/GLPrimInternalData.h b/btgui/OpenGLWindow/GLPrimInternalData.h deleted file mode 100644 index 5fdc62991..000000000 --- a/btgui/OpenGLWindow/GLPrimInternalData.h +++ /dev/null @@ -1,21 +0,0 @@ -#ifndef PRIM_INTERNAL_DATA -#define PRIM_INTERNAL_DATA - -#include "OpenGLInclude.h" - -struct PrimInternalData -{ - GLuint m_shaderProg; - GLint m_viewmatUniform; - GLint m_projMatUniform; - GLint m_positionUniform; - GLint m_colourAttribute; - GLint m_positionAttribute; - GLint m_textureAttribute; - GLuint m_vertexBuffer; - GLuint m_vertexArrayObject; - GLuint m_indexBuffer; - GLuint m_texturehandle; -}; - -#endif //PRIM_INTERNAL_DATA diff --git a/btgui/OpenGLWindow/GLPrimitiveRenderer.cpp b/btgui/OpenGLWindow/GLPrimitiveRenderer.cpp deleted file mode 100644 index cff4bd52e..000000000 --- a/btgui/OpenGLWindow/GLPrimitiveRenderer.cpp +++ /dev/null @@ -1,322 +0,0 @@ -#include "GLPrimitiveRenderer.h" -#include "GLPrimInternalData.h" - -#include "LoadShader.h" - -#include - -static const char* vertexShader3D= \ -"#version 150 \n" -"\n" -"uniform mat4 viewMatrix, projMatrix;\n" -"in vec4 position;\n" -"in vec4 colour;\n" -"out vec4 colourV;\n" -"\n" -"in vec2 texuv;\n" -"out vec2 texuvV;\n" -"\n" -"\n" -"void main (void)\n" -"{\n" -" colourV = colour;\n" -" gl_Position = projMatrix * viewMatrix * position ;\n" -" texuvV=texuv;\n" -"}\n"; - -static const char* fragmentShader3D= \ -"#version 150\n" -"\n" -"uniform vec2 p;\n" -"in vec4 colourV;\n" -"out vec4 fragColour;\n" -"in vec2 texuvV;\n" -"\n" -"uniform sampler2D Diffuse;\n" -"\n" -"void main(void)\n" -"{\n" -" vec4 texcolor = texture(Diffuse,texuvV);\n" -" if (p.x==0.f)\n" -" {\n" -" texcolor = vec4(1,1,1,texcolor.x);\n" -" }\n" -" fragColour = colourV*texcolor;\n" -"}\n"; - - - -static unsigned int s_indexData[6] = {0,1,2,0,2,3}; - - - - - -GLPrimitiveRenderer::GLPrimitiveRenderer(int screenWidth, int screenHeight) -:m_screenWidth(screenWidth), -m_screenHeight(screenHeight) -{ - - m_data = new PrimInternalData; - - m_data->m_shaderProg = gltLoadShaderPair(vertexShader3D,fragmentShader3D); - - m_data->m_viewmatUniform = glGetUniformLocation(m_data->m_shaderProg,"viewMatrix"); - if (m_data->m_viewmatUniform < 0) { - assert(0); - } - m_data->m_projMatUniform = glGetUniformLocation(m_data->m_shaderProg,"projMatrix"); - if (m_data->m_projMatUniform < 0) { - assert(0); - } - m_data->m_positionUniform = glGetUniformLocation(m_data->m_shaderProg, "p"); - if (m_data->m_positionUniform < 0) { - assert(0); - } - m_data->m_colourAttribute = glGetAttribLocation(m_data->m_shaderProg, "colour"); - if (m_data->m_colourAttribute < 0) { - assert(0); - } - m_data->m_positionAttribute = glGetAttribLocation(m_data->m_shaderProg, "position"); - if (m_data->m_positionAttribute < 0) { - assert(0); - } - m_data->m_textureAttribute = glGetAttribLocation(m_data->m_shaderProg,"texuv"); - if (m_data->m_textureAttribute < 0) { - assert(0); - } - - loadBufferData(); - -} - -void GLPrimitiveRenderer::loadBufferData() -{ - - PrimVertex vertexData[4] = { - { PrimVec4(-1, -1, 0.0, 1.0 ), PrimVec4( 1.0, 0.0, 0.0, 1.0 ) ,PrimVec2(0,0)}, - { PrimVec4(-1, 1, 0.0, 1.0 ), PrimVec4( 0.0, 1.0, 0.0, 1.0 ) ,PrimVec2(0,1)}, - { PrimVec4( 1, 1, 0.0, 1.0 ), PrimVec4( 0.0, 0.0, 1.0, 1.0 ) ,PrimVec2(1,1)}, - { PrimVec4( 1, -1, 0.0, 1.0 ), PrimVec4( 1.0, 1.0, 1.0, 1.0 ) ,PrimVec2(1,0)} - }; - - - glGenVertexArrays(1, &m_data->m_vertexArrayObject); - glBindVertexArray(m_data->m_vertexArrayObject); - - glGenBuffers(1, &m_data->m_vertexBuffer); - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vertexBuffer); - glBufferData(GL_ARRAY_BUFFER, 4 * sizeof(PrimVertex), vertexData, GL_DYNAMIC_DRAW); - - assert(glGetError()==GL_NO_ERROR); - - - - glGenBuffers(1, &m_data->m_indexBuffer); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_data->m_indexBuffer); - glBufferData(GL_ELEMENT_ARRAY_BUFFER,6*sizeof(int), s_indexData,GL_STATIC_DRAW); - - glEnableVertexAttribArray(m_data->m_positionAttribute); - glEnableVertexAttribArray(m_data->m_colourAttribute); - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(m_data->m_textureAttribute); - - glVertexAttribPointer(m_data->m_positionAttribute, 4, GL_FLOAT, GL_FALSE, sizeof(PrimVertex), (const GLvoid *)0); - glVertexAttribPointer(m_data->m_colourAttribute , 4, GL_FLOAT, GL_FALSE, sizeof(PrimVertex), (const GLvoid *)sizeof(PrimVec4)); - glVertexAttribPointer(m_data->m_textureAttribute , 2, GL_FLOAT, GL_FALSE, sizeof(PrimVertex), (const GLvoid *)(sizeof(PrimVec4)+sizeof(PrimVec4))); - assert(glGetError()==GL_NO_ERROR); - - - - - - - - glActiveTexture(GL_TEXTURE0); - - GLubyte* image=new GLubyte[256*256*3]; - for(int y=0;y<256;++y) - { - // const int t=y>>5; - GLubyte* pi=image+y*256*3; - for(int x=0;x<256;++x) - { - if (x253||y>253) - { - pi[0]=255; - pi[1]=0; - pi[2]=0; - } else - - { - pi[0]=255; - pi[1]=255; - pi[2]=255; - } - - pi+=3; - } - } - - glGenTextures(1,(GLuint*)&m_data->m_texturehandle); - glBindTexture(GL_TEXTURE_2D,m_data->m_texturehandle); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 256,256,0,GL_RGB,GL_UNSIGNED_BYTE,image); - glGenerateMipmap(GL_TEXTURE_2D); - - assert(glGetError()==GL_NO_ERROR); - - delete[] image; - - -} - - - -GLPrimitiveRenderer::~GLPrimitiveRenderer() -{ - glBindTexture(GL_TEXTURE_2D,0); - glUseProgram(0); - glBindTexture(GL_TEXTURE_2D,0); - glDeleteProgram(m_data->m_shaderProg); - delete m_data; -} - -void GLPrimitiveRenderer::drawLine() -{ - -} - -void GLPrimitiveRenderer::drawRect(float x0, float y0, float x1, float y1, float color[4]) -{ - assert(glGetError()==GL_NO_ERROR); - glActiveTexture(GL_TEXTURE0); - assert(glGetError()==GL_NO_ERROR); - - glBindTexture(GL_TEXTURE_2D,m_data->m_texturehandle); - assert(glGetError()==GL_NO_ERROR); - drawTexturedRect(x0,y0,x1,y1,color,0,0,1,1); - assert(glGetError()==GL_NO_ERROR); - -} - - -void GLPrimitiveRenderer::drawTexturedRect3D(const PrimVertex& v0,const PrimVertex& v1,const PrimVertex& v2,const PrimVertex& v3,float viewMat[16],float projMat[16], bool useRGBA) -{ - - assert(glGetError()==GL_NO_ERROR); - - - glUseProgram(m_data->m_shaderProg); - - glUniformMatrix4fv(m_data->m_viewmatUniform, 1, false, viewMat); - glUniformMatrix4fv(m_data->m_projMatUniform, 1, false, projMat); - - assert(glGetError()==GL_NO_ERROR); - - glBindBuffer(GL_ARRAY_BUFFER, m_data->m_vertexBuffer); - glBindVertexArray(m_data->m_vertexArrayObject); - - bool useFiltering = false; - if (useFiltering) - { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); - } else - { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - } - - PrimVertex vertexData[4] = { - v0,v1,v2,v3 - }; - - glBufferSubData(GL_ARRAY_BUFFER, 0,4 * sizeof(PrimVertex), vertexData); - - - - - - - assert(glGetError()==GL_NO_ERROR); - - PrimVec2 p( 0.f,0.f);//?b?0.5f * sinf(timeValue), 0.5f * cosf(timeValue) ); - if (useRGBA) - { - p.p[0] = 1.f; - p.p[1] = 1.f; - } - - glUniform2fv(m_data->m_positionUniform, 1, (const GLfloat *)&p); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(m_data->m_positionAttribute); - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(m_data->m_colourAttribute); - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(m_data->m_textureAttribute); - - glVertexAttribPointer(m_data->m_positionAttribute, 4, GL_FLOAT, GL_FALSE, sizeof(PrimVertex), (const GLvoid *)0); - glVertexAttribPointer(m_data->m_colourAttribute , 4, GL_FLOAT, GL_FALSE, sizeof(PrimVertex), (const GLvoid *)sizeof(PrimVec4)); - glVertexAttribPointer(m_data->m_textureAttribute , 2, GL_FLOAT, GL_FALSE, sizeof(PrimVertex), (const GLvoid *)(sizeof(PrimVec4)+sizeof(PrimVec4))); - assert(glGetError()==GL_NO_ERROR); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_data->m_indexBuffer); - - //glDrawArrays(GL_TRIANGLE_FAN, 0, 4); - int indexCount = 6; - assert(glGetError()==GL_NO_ERROR); - - - glDrawElements(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, 0); - assert(glGetError()==GL_NO_ERROR); - - - glBindVertexArray(0); - assert(glGetError()==GL_NO_ERROR); - - glBindBuffer(GL_ARRAY_BUFFER, 0); - assert(glGetError()==GL_NO_ERROR); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - assert(glGetError()==GL_NO_ERROR); - - //glDisableVertexAttribArray(m_data->m_textureAttribute); - assert(glGetError()==GL_NO_ERROR); - - glUseProgram(0); - - assert(glGetError()==GL_NO_ERROR); - -} - - -void GLPrimitiveRenderer::drawTexturedRect(float x0, float y0, float x1, float y1, float color[4], float u0,float v0, float u1, float v1, int useRGBA) -{ - float identity[16]={1,0,0,0, - 0,1,0,0, - 0,0,1,0, - 0,0,0,1}; - PrimVertex vertexData[4] = { - { PrimVec4(-1.f+2.f*x0/float(m_screenWidth), 1.f-2.f*y0/float(m_screenHeight), 0.f, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u0,v0)}, - { PrimVec4(-1.f+2.f*x0/float(m_screenWidth), 1.f-2.f*y1/float(m_screenHeight), 0.f, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u0,v1)}, - { PrimVec4( -1.f+2.f*x1/float(m_screenWidth), 1.f-2.f*y1/float(m_screenHeight), 0.f, 1.f ), PrimVec4(color[0], color[1], color[2], color[3]) ,PrimVec2(u1,v1)}, - { PrimVec4( -1.f+2.f*x1/float(m_screenWidth), 1.f-2.f*y0/float(m_screenHeight), 0.f, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u1,v0)} - }; - - drawTexturedRect3D(vertexData[0],vertexData[1],vertexData[2],vertexData[3],identity,identity,useRGBA); -} - -void GLPrimitiveRenderer::setScreenSize(int width, int height) -{ - m_screenWidth = width; - m_screenHeight = height; - -} \ No newline at end of file diff --git a/btgui/OpenGLWindow/GLPrimitiveRenderer.h b/btgui/OpenGLWindow/GLPrimitiveRenderer.h deleted file mode 100644 index 1c4f2e3f3..000000000 --- a/btgui/OpenGLWindow/GLPrimitiveRenderer.h +++ /dev/null @@ -1,67 +0,0 @@ -#ifndef _GL_PRIMITIVE_RENDERER_H -#define _GL_PRIMITIVE_RENDERER_H - -//#include "OpenGLInclude.h" - -struct PrimVec2 -{ - PrimVec2(float x, float y) - { - p[0] = x; - p[1] = y; - } - float p[2]; -}; - -struct PrimVec4 -{ - PrimVec4() {} - PrimVec4(float x,float y, float z, float w) - { - p[0] = x; - p[1] = y; - p[2] = z; - p[3] = w; - - } - - float p[4]; -}; - -typedef struct -{ - PrimVec4 position; - PrimVec4 colour; - PrimVec2 uv; -} PrimVertex; - - -class GLPrimitiveRenderer -{ - int m_screenWidth; - int m_screenHeight; - - struct PrimInternalData* m_data; - - void loadBufferData(); - -public: - - GLPrimitiveRenderer(int screenWidth, int screenHeight); - virtual ~GLPrimitiveRenderer(); - - void drawRect(float x0, float y0, float x1, float y1, float color[4]); - void drawTexturedRect(float x0, float y0, float x1, float y1, float color[4], float u0,float v0, float u1, float v1, int useRGBA=0); - void drawTexturedRect3D(const PrimVertex& v0,const PrimVertex& v1,const PrimVertex& v2,const PrimVertex& v3,float viewMat[16],float projMat[16], bool useRGBA = true); - void drawLine();//float from[4], float to[4], float color[4]); - void setScreenSize(int width, int height); - - PrimInternalData* getData() - { - return m_data; - } - -}; - -#endif//_GL_PRIMITIVE_RENDERER_H - diff --git a/btgui/OpenGLWindow/GLRenderToTexture.cpp b/btgui/OpenGLWindow/GLRenderToTexture.cpp deleted file mode 100644 index 3ca338eba..000000000 --- a/btgui/OpenGLWindow/GLRenderToTexture.cpp +++ /dev/null @@ -1,135 +0,0 @@ - -///See http://www.opengl-tutorial.org/intermediate-tutorials/tutorial-14-render-to-texture/ - - -#include "GLRenderToTexture.h" -#include "Bullet3Common/b3Scalar.h" // for b3Assert -#include -#include - -bool gIntelLinuxglDrawBufferWorkaround=false; - -GLRenderToTexture::GLRenderToTexture() -:m_framebufferName(0) -{ -#if !defined(_WIN32) && !defined(__APPLE__) - const GLubyte* ven = glGetString(GL_VENDOR); - printf("ven = %s\n",ven); - - if (strncmp((const char*)ven,"Intel",5)==0) - { - printf("Workaround for some crash in the Intel OpenGL driver on Linux/Ubuntu\n"); - gIntelLinuxglDrawBufferWorkaround=true; - } -#endif//!defined(_WIN32) && !defined(__APPLE__) - -} - -void GLRenderToTexture::init(int width, int height, GLuint textureId, int renderTextureType) -{ - m_renderTextureType = renderTextureType; - - glGenFramebuffers(1, &m_framebufferName); - glBindFramebuffer(GL_FRAMEBUFFER, m_framebufferName); - - - - // The depth buffer -// glGenRenderbuffers(1, &m_depthrenderbuffer); - -// glBindRenderbuffer(GL_RENDERBUFFER, m_depthrenderbuffer); -// glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH_COMPONENT, width, height); -// glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, m_depthrenderbuffer); - - switch (m_renderTextureType) - { - case RENDERTEXTURE_COLOR: - { - glFramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, textureId, 0); - break; - } - case RENDERTEXTURE_DEPTH: - { - glFramebufferTexture(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, textureId, 0); - break; - } - default: - { - b3Assert(0); - } - }; - - - glBindFramebuffer( GL_FRAMEBUFFER, 0 ); - - -} - -bool GLRenderToTexture::enable() -{ - bool status = false; - - glBindFramebuffer(GL_FRAMEBUFFER, m_framebufferName); - - - switch (m_renderTextureType) - { - case RENDERTEXTURE_COLOR: - { - // Set the list of draw buffers. - GLenum drawBuffers[2] = {GL_COLOR_ATTACHMENT0,0}; - glDrawBuffers(1, drawBuffers); - break; - } - case RENDERTEXTURE_DEPTH: - { - //Intel OpenGL driver crashes when using GL_NONE for glDrawBuffer on Linux, so use a workaround - if (gIntelLinuxglDrawBufferWorkaround) - { - GLenum drawBuffers[2] = { GL_COLOR_ATTACHMENT0,0}; - glDrawBuffers(1, drawBuffers); - } else - { - glDrawBuffer(GL_NONE); - } - break; - } - default: - { - b3Assert(0); - } - }; - - - // Always check that our framebuffer is ok - if(glCheckFramebufferStatus(GL_FRAMEBUFFER) == GL_FRAMEBUFFER_COMPLETE) - { - status = true; - } - - - return status; - -} - -void GLRenderToTexture::disable() -{ - glBindFramebuffer( GL_FRAMEBUFFER, 0 ); -} - -GLRenderToTexture::~GLRenderToTexture() -{ - glBindFramebuffer( GL_FRAMEBUFFER, 0 ); - - if (m_depthrenderbuffer) - { - glDeleteRenderbuffers(1,&m_depthrenderbuffer); - } - - - if( m_framebufferName) - { - glDeleteFramebuffers(1, &m_framebufferName); - } -} - diff --git a/btgui/OpenGLWindow/GLRenderToTexture.h b/btgui/OpenGLWindow/GLRenderToTexture.h deleted file mode 100644 index d1c913e95..000000000 --- a/btgui/OpenGLWindow/GLRenderToTexture.h +++ /dev/null @@ -1,32 +0,0 @@ - -#ifndef GL_RENDER_TO_TEXTURE_H -#define GL_RENDER_TO_TEXTURE_H - -///See http://www.opengl-tutorial.org/intermediate-tutorials/tutorial-14-render-to-texture/ -#include "OpenGLInclude.h" - -enum -{ - RENDERTEXTURE_COLOR=1, - RENDERTEXTURE_DEPTH, -}; -struct GLRenderToTexture -{ - GLuint m_framebufferName; - GLuint m_depthrenderbuffer; - bool m_initialized; - int m_renderTextureType; -public: - GLRenderToTexture(); - - void init(int width, int height, GLuint textureId, int renderTextureType=RENDERTEXTURE_COLOR); - bool enable(); - void disable(); - - virtual ~GLRenderToTexture(); - -}; - - -#endif //GL_RENDER_TO_TEXTURE_H - diff --git a/btgui/OpenGLWindow/GlewWindows/GL/glew.h b/btgui/OpenGLWindow/GlewWindows/GL/glew.h deleted file mode 100644 index f33e7d458..000000000 --- a/btgui/OpenGLWindow/GlewWindows/GL/glew.h +++ /dev/null @@ -1,19093 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#define GLEW_NO_GLU -//#define GLEW_INIT_OPENGL11_FUNCTIONS 1 -//#define GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS 1 - -/* - * Mesa 3-D graphics library - * Version: 7.0 - * - * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* -** Copyright (c) 2007 The Khronos Group Inc. -** -** Permission is hereby granted, free of charge, to any person obtaining a -** copy of this software and/or associated documentation files (the -** "Materials"), to deal in the Materials without restriction, including -** without limitation the rights to use, copy, modify, merge, publish, -** distribute, sublicense, and/or sell copies of the Materials, and to -** permit persons to whom the Materials are furnished to do so, subject to -** the following conditions: -** -** The above copyright notice and this permission notice shall be included -** in all copies or substantial portions of the Materials. -** -** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. -*/ - -#ifndef __glew_h__ -#define __glew_h__ -#define __GLEW_H__ - -#if defined(__gl_h_) || defined(__GL_H__) || defined(__X_GL_H) -#error gl.h included before glew.h -#endif -#if defined(__gl2_h_) -#error gl2.h included before glew.h -#endif -#if defined(__gltypes_h_) -#error gltypes.h included before glew.h -#endif -#if defined(__REGAL_H__) -#error Regal.h included before glew.h -#endif -#if defined(__glext_h_) || defined(__GLEXT_H_) -#error glext.h included before glew.h -#endif -#if defined(__gl_ATI_h_) -#error glATI.h included before glew.h -#endif - -#define __gl_h_ -#define __gl2_h_ -#define __GL_H__ -#define __gltypes_h_ -#define __REGAL_H__ -#define __X_GL_H -#define __glext_h_ -#define __GLEXT_H_ -#define __gl_ATI_h_ - -#if defined(_WIN32) - -/* - * GLEW does not include to avoid name space pollution. - * GL needs GLAPI and GLAPIENTRY, GLU needs APIENTRY, CALLBACK, and wchar_t - * defined properly. - */ -/* */ -#ifndef APIENTRY -#define GLEW_APIENTRY_DEFINED -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define APIENTRY __stdcall -# elif (_MSC_VER >= 800) || defined(_STDCALL_SUPPORTED) || defined(__BORLANDC__) -# define APIENTRY __stdcall -# else -# define APIENTRY -# endif -#endif -#ifndef GLAPI -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define GLAPI extern -# endif -#endif -/* */ -#ifndef CALLBACK -#define GLEW_CALLBACK_DEFINED -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define CALLBACK __attribute__ ((__stdcall__)) -# elif (defined(_M_MRX000) || defined(_M_IX86) || defined(_M_ALPHA) || defined(_M_PPC)) && !defined(MIDL_PASS) -# define CALLBACK __stdcall -# else -# define CALLBACK -# endif -#endif -/* and */ -#ifndef WINGDIAPI -#define GLEW_WINGDIAPI_DEFINED -#define WINGDIAPI __declspec(dllimport) -#endif -/* */ -#if (defined(_MSC_VER) || defined(__BORLANDC__)) && !defined(_WCHAR_T_DEFINED) -typedef unsigned short wchar_t; -# define _WCHAR_T_DEFINED -#endif -/* */ -#if !defined(_W64) -# if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && defined(_MSC_VER) && _MSC_VER >= 1300 -# define _W64 __w64 -# else -# define _W64 -# endif -#endif -#if !defined(_PTRDIFF_T_DEFINED) && !defined(_PTRDIFF_T_) && !defined(__MINGW64__) -# ifdef _WIN64 -typedef __int64 ptrdiff_t; -# else -typedef _W64 int ptrdiff_t; -# endif -# define _PTRDIFF_T_DEFINED -# define _PTRDIFF_T_ -#endif - -#ifndef GLAPI -# if defined(__MINGW32__) || defined(__CYGWIN__) -# define GLAPI extern -# else -# define GLAPI WINGDIAPI -# endif -#endif - -#ifndef GLAPIENTRY -#define GLAPIENTRY APIENTRY -#endif - -#ifndef GLEWAPIENTRY -#define GLEWAPIENTRY APIENTRY -#endif - -/* - * GLEW_STATIC is defined for static library. - * GLEW_BUILD is defined for building the DLL library. - */ - -#ifdef GLEW_STATIC -# define GLEWAPI extern -#else -# ifdef GLEW_BUILD -# define GLEWAPI extern __declspec(dllexport) -# else -# define GLEWAPI extern __declspec(dllimport) -# endif -#endif - -#else /* _UNIX */ - -/* - * Needed for ptrdiff_t in turn needed by VBO. This is defined by ISO - * C. On my system, this amounts to _3 lines_ of included code, all of - * them pretty much harmless. If you know of a way of detecting 32 vs - * 64 _targets_ at compile time you are free to replace this with - * something that's portable. For now, _this_ is the portable solution. - * (mem, 2004-01-04) - */ - -#include - -/* SGI MIPSPro doesn't like stdint.h in C++ mode */ -/* ID: 3376260 Solaris 9 has inttypes.h, but not stdint.h */ - -#if (defined(__sgi) || defined(__sun)) && !defined(__GNUC__) -#include -#else -#include -#endif - -#define GLEW_APIENTRY_DEFINED -#define APIENTRY - -/* - * GLEW_STATIC is defined for static library. - */ - -#ifdef GLEW_STATIC -# define GLEWAPI extern -#else -# if defined(__GNUC__) && __GNUC__>=4 -# define GLEWAPI extern __attribute__ ((visibility("default"))) -# elif defined(__SUNPRO_C) || defined(__SUNPRO_CC) -# define GLEWAPI extern __global -# else -# define GLEWAPI extern -# endif -#endif - -/* */ -#ifndef GLAPI -#define GLAPI extern -#endif - -#ifndef GLAPIENTRY -#define GLAPIENTRY -#endif - -#ifndef GLEWAPIENTRY -#define GLEWAPIENTRY -#endif - -#endif /* _WIN32 */ - -#ifdef __cplusplus -extern "C" { -#endif - -/* ----------------------------- GL_VERSION_1_1 ---------------------------- */ - -#ifndef GL_VERSION_1_1 -#define GL_VERSION_1_1 1 - -typedef unsigned int GLenum; -typedef unsigned int GLbitfield; -typedef unsigned int GLuint; -typedef int GLint; -typedef int GLsizei; -typedef unsigned char GLboolean; -typedef signed char GLbyte; -typedef short GLshort; -typedef unsigned char GLubyte; -typedef unsigned short GLushort; -typedef unsigned long GLulong; -typedef float GLfloat; -typedef float GLclampf; -typedef double GLdouble; -typedef double GLclampd; -typedef void GLvoid; -#if defined(_MSC_VER) && _MSC_VER < 1400 -typedef __int64 GLint64EXT; -typedef unsigned __int64 GLuint64EXT; -#elif defined(_MSC_VER) || defined(__BORLANDC__) -typedef signed long long GLint64EXT; -typedef unsigned long long GLuint64EXT; -#else -# if defined(__MINGW32__) || defined(__CYGWIN__) -#include -# endif -typedef int64_t GLint64EXT; -typedef uint64_t GLuint64EXT; -#endif -typedef GLint64EXT GLint64; -typedef GLuint64EXT GLuint64; -typedef struct __GLsync *GLsync; - -typedef char GLchar; - -#define GL_ZERO 0 -#define GL_FALSE 0 -#define GL_LOGIC_OP 0x0BF1 -#define GL_NONE 0 -#define GL_TEXTURE_COMPONENTS 0x1003 -#define GL_NO_ERROR 0 -#define GL_POINTS 0x0000 -#define GL_CURRENT_BIT 0x00000001 -#define GL_TRUE 1 -#define GL_ONE 1 -#define GL_CLIENT_PIXEL_STORE_BIT 0x00000001 -#define GL_LINES 0x0001 -#define GL_LINE_LOOP 0x0002 -#define GL_POINT_BIT 0x00000002 -#define GL_CLIENT_VERTEX_ARRAY_BIT 0x00000002 -#define GL_LINE_STRIP 0x0003 -#define GL_LINE_BIT 0x00000004 -#define GL_TRIANGLES 0x0004 -#define GL_TRIANGLE_STRIP 0x0005 -#define GL_TRIANGLE_FAN 0x0006 -#define GL_QUADS 0x0007 -#define GL_QUAD_STRIP 0x0008 -#define GL_POLYGON_BIT 0x00000008 -#define GL_POLYGON 0x0009 -#define GL_POLYGON_STIPPLE_BIT 0x00000010 -#define GL_PIXEL_MODE_BIT 0x00000020 -#define GL_LIGHTING_BIT 0x00000040 -#define GL_FOG_BIT 0x00000080 -#define GL_DEPTH_BUFFER_BIT 0x00000100 -#define GL_ACCUM 0x0100 -#define GL_LOAD 0x0101 -#define GL_RETURN 0x0102 -#define GL_MULT 0x0103 -#define GL_ADD 0x0104 -#define GL_NEVER 0x0200 -#define GL_ACCUM_BUFFER_BIT 0x00000200 -#define GL_LESS 0x0201 -#define GL_EQUAL 0x0202 -#define GL_LEQUAL 0x0203 -#define GL_GREATER 0x0204 -#define GL_NOTEQUAL 0x0205 -#define GL_GEQUAL 0x0206 -#define GL_ALWAYS 0x0207 -#define GL_SRC_COLOR 0x0300 -#define GL_ONE_MINUS_SRC_COLOR 0x0301 -#define GL_SRC_ALPHA 0x0302 -#define GL_ONE_MINUS_SRC_ALPHA 0x0303 -#define GL_DST_ALPHA 0x0304 -#define GL_ONE_MINUS_DST_ALPHA 0x0305 -#define GL_DST_COLOR 0x0306 -#define GL_ONE_MINUS_DST_COLOR 0x0307 -#define GL_SRC_ALPHA_SATURATE 0x0308 -#define GL_STENCIL_BUFFER_BIT 0x00000400 -#define GL_FRONT_LEFT 0x0400 -#define GL_FRONT_RIGHT 0x0401 -#define GL_BACK_LEFT 0x0402 -#define GL_BACK_RIGHT 0x0403 -#define GL_FRONT 0x0404 -#define GL_BACK 0x0405 -#define GL_LEFT 0x0406 -#define GL_RIGHT 0x0407 -#define GL_FRONT_AND_BACK 0x0408 -#define GL_AUX0 0x0409 -#define GL_AUX1 0x040A -#define GL_AUX2 0x040B -#define GL_AUX3 0x040C -#define GL_INVALID_ENUM 0x0500 -#define GL_INVALID_VALUE 0x0501 -#define GL_INVALID_OPERATION 0x0502 -#define GL_STACK_OVERFLOW 0x0503 -#define GL_STACK_UNDERFLOW 0x0504 -#define GL_OUT_OF_MEMORY 0x0505 -#define GL_2D 0x0600 -#define GL_3D 0x0601 -#define GL_3D_COLOR 0x0602 -#define GL_3D_COLOR_TEXTURE 0x0603 -#define GL_4D_COLOR_TEXTURE 0x0604 -#define GL_PASS_THROUGH_TOKEN 0x0700 -#define GL_POINT_TOKEN 0x0701 -#define GL_LINE_TOKEN 0x0702 -#define GL_POLYGON_TOKEN 0x0703 -#define GL_BITMAP_TOKEN 0x0704 -#define GL_DRAW_PIXEL_TOKEN 0x0705 -#define GL_COPY_PIXEL_TOKEN 0x0706 -#define GL_LINE_RESET_TOKEN 0x0707 -#define GL_EXP 0x0800 -#define GL_VIEWPORT_BIT 0x00000800 -#define GL_EXP2 0x0801 -#define GL_CW 0x0900 -#define GL_CCW 0x0901 -#define GL_COEFF 0x0A00 -#define GL_ORDER 0x0A01 -#define GL_DOMAIN 0x0A02 -#define GL_CURRENT_COLOR 0x0B00 -#define GL_CURRENT_INDEX 0x0B01 -#define GL_CURRENT_NORMAL 0x0B02 -#define GL_CURRENT_TEXTURE_COORDS 0x0B03 -#define GL_CURRENT_RASTER_COLOR 0x0B04 -#define GL_CURRENT_RASTER_INDEX 0x0B05 -#define GL_CURRENT_RASTER_TEXTURE_COORDS 0x0B06 -#define GL_CURRENT_RASTER_POSITION 0x0B07 -#define GL_CURRENT_RASTER_POSITION_VALID 0x0B08 -#define GL_CURRENT_RASTER_DISTANCE 0x0B09 -#define GL_POINT_SMOOTH 0x0B10 -#define GL_POINT_SIZE 0x0B11 -#define GL_POINT_SIZE_RANGE 0x0B12 -#define GL_POINT_SIZE_GRANULARITY 0x0B13 -#define GL_LINE_SMOOTH 0x0B20 -#define GL_LINE_WIDTH 0x0B21 -#define GL_LINE_WIDTH_RANGE 0x0B22 -#define GL_LINE_WIDTH_GRANULARITY 0x0B23 -#define GL_LINE_STIPPLE 0x0B24 -#define GL_LINE_STIPPLE_PATTERN 0x0B25 -#define GL_LINE_STIPPLE_REPEAT 0x0B26 -#define GL_LIST_MODE 0x0B30 -#define GL_MAX_LIST_NESTING 0x0B31 -#define GL_LIST_BASE 0x0B32 -#define GL_LIST_INDEX 0x0B33 -#define GL_POLYGON_MODE 0x0B40 -#define GL_POLYGON_SMOOTH 0x0B41 -#define GL_POLYGON_STIPPLE 0x0B42 -#define GL_EDGE_FLAG 0x0B43 -#define GL_CULL_FACE 0x0B44 -#define GL_CULL_FACE_MODE 0x0B45 -#define GL_FRONT_FACE 0x0B46 -#define GL_LIGHTING 0x0B50 -#define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51 -#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52 -#define GL_LIGHT_MODEL_AMBIENT 0x0B53 -#define GL_SHADE_MODEL 0x0B54 -#define GL_COLOR_MATERIAL_FACE 0x0B55 -#define GL_COLOR_MATERIAL_PARAMETER 0x0B56 -#define GL_COLOR_MATERIAL 0x0B57 -#define GL_FOG 0x0B60 -#define GL_FOG_INDEX 0x0B61 -#define GL_FOG_DENSITY 0x0B62 -#define GL_FOG_START 0x0B63 -#define GL_FOG_END 0x0B64 -#define GL_FOG_MODE 0x0B65 -#define GL_FOG_COLOR 0x0B66 -#define GL_DEPTH_RANGE 0x0B70 -#define GL_DEPTH_TEST 0x0B71 -#define GL_DEPTH_WRITEMASK 0x0B72 -#define GL_DEPTH_CLEAR_VALUE 0x0B73 -#define GL_DEPTH_FUNC 0x0B74 -#define GL_ACCUM_CLEAR_VALUE 0x0B80 -#define GL_STENCIL_TEST 0x0B90 -#define GL_STENCIL_CLEAR_VALUE 0x0B91 -#define GL_STENCIL_FUNC 0x0B92 -#define GL_STENCIL_VALUE_MASK 0x0B93 -#define GL_STENCIL_FAIL 0x0B94 -#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95 -#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96 -#define GL_STENCIL_REF 0x0B97 -#define GL_STENCIL_WRITEMASK 0x0B98 -#define GL_MATRIX_MODE 0x0BA0 -#define GL_NORMALIZE 0x0BA1 -#define GL_VIEWPORT 0x0BA2 -#define GL_MODELVIEW_STACK_DEPTH 0x0BA3 -#define GL_PROJECTION_STACK_DEPTH 0x0BA4 -#define GL_TEXTURE_STACK_DEPTH 0x0BA5 -#define GL_MODELVIEW_MATRIX 0x0BA6 -#define GL_PROJECTION_MATRIX 0x0BA7 -#define GL_TEXTURE_MATRIX 0x0BA8 -#define GL_ATTRIB_STACK_DEPTH 0x0BB0 -#define GL_CLIENT_ATTRIB_STACK_DEPTH 0x0BB1 -#define GL_ALPHA_TEST 0x0BC0 -#define GL_ALPHA_TEST_FUNC 0x0BC1 -#define GL_ALPHA_TEST_REF 0x0BC2 -#define GL_DITHER 0x0BD0 -#define GL_BLEND_DST 0x0BE0 -#define GL_BLEND_SRC 0x0BE1 -#define GL_BLEND 0x0BE2 -#define GL_LOGIC_OP_MODE 0x0BF0 -#define GL_INDEX_LOGIC_OP 0x0BF1 -#define GL_COLOR_LOGIC_OP 0x0BF2 -#define GL_AUX_BUFFERS 0x0C00 -#define GL_DRAW_BUFFER 0x0C01 -#define GL_READ_BUFFER 0x0C02 -#define GL_SCISSOR_BOX 0x0C10 -#define GL_SCISSOR_TEST 0x0C11 -#define GL_INDEX_CLEAR_VALUE 0x0C20 -#define GL_INDEX_WRITEMASK 0x0C21 -#define GL_COLOR_CLEAR_VALUE 0x0C22 -#define GL_COLOR_WRITEMASK 0x0C23 -#define GL_INDEX_MODE 0x0C30 -#define GL_RGBA_MODE 0x0C31 -#define GL_DOUBLEBUFFER 0x0C32 -#define GL_STEREO 0x0C33 -#define GL_RENDER_MODE 0x0C40 -#define GL_PERSPECTIVE_CORRECTION_HINT 0x0C50 -#define GL_POINT_SMOOTH_HINT 0x0C51 -#define GL_LINE_SMOOTH_HINT 0x0C52 -#define GL_POLYGON_SMOOTH_HINT 0x0C53 -#define GL_FOG_HINT 0x0C54 -#define GL_TEXTURE_GEN_S 0x0C60 -#define GL_TEXTURE_GEN_T 0x0C61 -#define GL_TEXTURE_GEN_R 0x0C62 -#define GL_TEXTURE_GEN_Q 0x0C63 -#define GL_PIXEL_MAP_I_TO_I 0x0C70 -#define GL_PIXEL_MAP_S_TO_S 0x0C71 -#define GL_PIXEL_MAP_I_TO_R 0x0C72 -#define GL_PIXEL_MAP_I_TO_G 0x0C73 -#define GL_PIXEL_MAP_I_TO_B 0x0C74 -#define GL_PIXEL_MAP_I_TO_A 0x0C75 -#define GL_PIXEL_MAP_R_TO_R 0x0C76 -#define GL_PIXEL_MAP_G_TO_G 0x0C77 -#define GL_PIXEL_MAP_B_TO_B 0x0C78 -#define GL_PIXEL_MAP_A_TO_A 0x0C79 -#define GL_PIXEL_MAP_I_TO_I_SIZE 0x0CB0 -#define GL_PIXEL_MAP_S_TO_S_SIZE 0x0CB1 -#define GL_PIXEL_MAP_I_TO_R_SIZE 0x0CB2 -#define GL_PIXEL_MAP_I_TO_G_SIZE 0x0CB3 -#define GL_PIXEL_MAP_I_TO_B_SIZE 0x0CB4 -#define GL_PIXEL_MAP_I_TO_A_SIZE 0x0CB5 -#define GL_PIXEL_MAP_R_TO_R_SIZE 0x0CB6 -#define GL_PIXEL_MAP_G_TO_G_SIZE 0x0CB7 -#define GL_PIXEL_MAP_B_TO_B_SIZE 0x0CB8 -#define GL_PIXEL_MAP_A_TO_A_SIZE 0x0CB9 -#define GL_UNPACK_SWAP_BYTES 0x0CF0 -#define GL_UNPACK_LSB_FIRST 0x0CF1 -#define GL_UNPACK_ROW_LENGTH 0x0CF2 -#define GL_UNPACK_SKIP_ROWS 0x0CF3 -#define GL_UNPACK_SKIP_PIXELS 0x0CF4 -#define GL_UNPACK_ALIGNMENT 0x0CF5 -#define GL_PACK_SWAP_BYTES 0x0D00 -#define GL_PACK_LSB_FIRST 0x0D01 -#define GL_PACK_ROW_LENGTH 0x0D02 -#define GL_PACK_SKIP_ROWS 0x0D03 -#define GL_PACK_SKIP_PIXELS 0x0D04 -#define GL_PACK_ALIGNMENT 0x0D05 -#define GL_MAP_COLOR 0x0D10 -#define GL_MAP_STENCIL 0x0D11 -#define GL_INDEX_SHIFT 0x0D12 -#define GL_INDEX_OFFSET 0x0D13 -#define GL_RED_SCALE 0x0D14 -#define GL_RED_BIAS 0x0D15 -#define GL_ZOOM_X 0x0D16 -#define GL_ZOOM_Y 0x0D17 -#define GL_GREEN_SCALE 0x0D18 -#define GL_GREEN_BIAS 0x0D19 -#define GL_BLUE_SCALE 0x0D1A -#define GL_BLUE_BIAS 0x0D1B -#define GL_ALPHA_SCALE 0x0D1C -#define GL_ALPHA_BIAS 0x0D1D -#define GL_DEPTH_SCALE 0x0D1E -#define GL_DEPTH_BIAS 0x0D1F -#define GL_MAX_EVAL_ORDER 0x0D30 -#define GL_MAX_LIGHTS 0x0D31 -#define GL_MAX_CLIP_PLANES 0x0D32 -#define GL_MAX_TEXTURE_SIZE 0x0D33 -#define GL_MAX_PIXEL_MAP_TABLE 0x0D34 -#define GL_MAX_ATTRIB_STACK_DEPTH 0x0D35 -#define GL_MAX_MODELVIEW_STACK_DEPTH 0x0D36 -#define GL_MAX_NAME_STACK_DEPTH 0x0D37 -#define GL_MAX_PROJECTION_STACK_DEPTH 0x0D38 -#define GL_MAX_TEXTURE_STACK_DEPTH 0x0D39 -#define GL_MAX_VIEWPORT_DIMS 0x0D3A -#define GL_MAX_CLIENT_ATTRIB_STACK_DEPTH 0x0D3B -#define GL_SUBPIXEL_BITS 0x0D50 -#define GL_INDEX_BITS 0x0D51 -#define GL_RED_BITS 0x0D52 -#define GL_GREEN_BITS 0x0D53 -#define GL_BLUE_BITS 0x0D54 -#define GL_ALPHA_BITS 0x0D55 -#define GL_DEPTH_BITS 0x0D56 -#define GL_STENCIL_BITS 0x0D57 -#define GL_ACCUM_RED_BITS 0x0D58 -#define GL_ACCUM_GREEN_BITS 0x0D59 -#define GL_ACCUM_BLUE_BITS 0x0D5A -#define GL_ACCUM_ALPHA_BITS 0x0D5B -#define GL_NAME_STACK_DEPTH 0x0D70 -#define GL_AUTO_NORMAL 0x0D80 -#define GL_MAP1_COLOR_4 0x0D90 -#define GL_MAP1_INDEX 0x0D91 -#define GL_MAP1_NORMAL 0x0D92 -#define GL_MAP1_TEXTURE_COORD_1 0x0D93 -#define GL_MAP1_TEXTURE_COORD_2 0x0D94 -#define GL_MAP1_TEXTURE_COORD_3 0x0D95 -#define GL_MAP1_TEXTURE_COORD_4 0x0D96 -#define GL_MAP1_VERTEX_3 0x0D97 -#define GL_MAP1_VERTEX_4 0x0D98 -#define GL_MAP2_COLOR_4 0x0DB0 -#define GL_MAP2_INDEX 0x0DB1 -#define GL_MAP2_NORMAL 0x0DB2 -#define GL_MAP2_TEXTURE_COORD_1 0x0DB3 -#define GL_MAP2_TEXTURE_COORD_2 0x0DB4 -#define GL_MAP2_TEXTURE_COORD_3 0x0DB5 -#define GL_MAP2_TEXTURE_COORD_4 0x0DB6 -#define GL_MAP2_VERTEX_3 0x0DB7 -#define GL_MAP2_VERTEX_4 0x0DB8 -#define GL_MAP1_GRID_DOMAIN 0x0DD0 -#define GL_MAP1_GRID_SEGMENTS 0x0DD1 -#define GL_MAP2_GRID_DOMAIN 0x0DD2 -#define GL_MAP2_GRID_SEGMENTS 0x0DD3 -#define GL_TEXTURE_1D 0x0DE0 -#define GL_TEXTURE_2D 0x0DE1 -#define GL_FEEDBACK_BUFFER_POINTER 0x0DF0 -#define GL_FEEDBACK_BUFFER_SIZE 0x0DF1 -#define GL_FEEDBACK_BUFFER_TYPE 0x0DF2 -#define GL_SELECTION_BUFFER_POINTER 0x0DF3 -#define GL_SELECTION_BUFFER_SIZE 0x0DF4 -#define GL_TEXTURE_WIDTH 0x1000 -#define GL_TRANSFORM_BIT 0x00001000 -#define GL_TEXTURE_HEIGHT 0x1001 -#define GL_TEXTURE_INTERNAL_FORMAT 0x1003 -#define GL_TEXTURE_BORDER_COLOR 0x1004 -#define GL_TEXTURE_BORDER 0x1005 -#define GL_DONT_CARE 0x1100 -#define GL_FASTEST 0x1101 -#define GL_NICEST 0x1102 -#define GL_AMBIENT 0x1200 -#define GL_DIFFUSE 0x1201 -#define GL_SPECULAR 0x1202 -#define GL_POSITION 0x1203 -#define GL_SPOT_DIRECTION 0x1204 -#define GL_SPOT_EXPONENT 0x1205 -#define GL_SPOT_CUTOFF 0x1206 -#define GL_CONSTANT_ATTENUATION 0x1207 -#define GL_LINEAR_ATTENUATION 0x1208 -#define GL_QUADRATIC_ATTENUATION 0x1209 -#define GL_COMPILE 0x1300 -#define GL_COMPILE_AND_EXECUTE 0x1301 -#define GL_BYTE 0x1400 -#define GL_UNSIGNED_BYTE 0x1401 -#define GL_SHORT 0x1402 -#define GL_UNSIGNED_SHORT 0x1403 -#define GL_INT 0x1404 -#define GL_UNSIGNED_INT 0x1405 -#define GL_FLOAT 0x1406 -#define GL_2_BYTES 0x1407 -#define GL_3_BYTES 0x1408 -#define GL_4_BYTES 0x1409 -#define GL_DOUBLE 0x140A -#define GL_CLEAR 0x1500 -#define GL_AND 0x1501 -#define GL_AND_REVERSE 0x1502 -#define GL_COPY 0x1503 -#define GL_AND_INVERTED 0x1504 -#define GL_NOOP 0x1505 -#define GL_XOR 0x1506 -#define GL_OR 0x1507 -#define GL_NOR 0x1508 -#define GL_EQUIV 0x1509 -#define GL_INVERT 0x150A -#define GL_OR_REVERSE 0x150B -#define GL_COPY_INVERTED 0x150C -#define GL_OR_INVERTED 0x150D -#define GL_NAND 0x150E -#define GL_SET 0x150F -#define GL_EMISSION 0x1600 -#define GL_SHININESS 0x1601 -#define GL_AMBIENT_AND_DIFFUSE 0x1602 -#define GL_COLOR_INDEXES 0x1603 -#define GL_MODELVIEW 0x1700 -#define GL_PROJECTION 0x1701 -#define GL_TEXTURE 0x1702 -#define GL_COLOR 0x1800 -#define GL_DEPTH 0x1801 -#define GL_STENCIL 0x1802 -#define GL_COLOR_INDEX 0x1900 -#define GL_STENCIL_INDEX 0x1901 -#define GL_DEPTH_COMPONENT 0x1902 -#define GL_RED 0x1903 -#define GL_GREEN 0x1904 -#define GL_BLUE 0x1905 -#define GL_ALPHA 0x1906 -#define GL_RGB 0x1907 -#define GL_RGBA 0x1908 -#define GL_LUMINANCE 0x1909 -#define GL_LUMINANCE_ALPHA 0x190A -#define GL_BITMAP 0x1A00 -#define GL_POINT 0x1B00 -#define GL_LINE 0x1B01 -#define GL_FILL 0x1B02 -#define GL_RENDER 0x1C00 -#define GL_FEEDBACK 0x1C01 -#define GL_SELECT 0x1C02 -#define GL_FLAT 0x1D00 -#define GL_SMOOTH 0x1D01 -#define GL_KEEP 0x1E00 -#define GL_REPLACE 0x1E01 -#define GL_INCR 0x1E02 -#define GL_DECR 0x1E03 -#define GL_VENDOR 0x1F00 -#define GL_RENDERER 0x1F01 -#define GL_VERSION 0x1F02 -#define GL_EXTENSIONS 0x1F03 -#define GL_S 0x2000 -#define GL_ENABLE_BIT 0x00002000 -#define GL_T 0x2001 -#define GL_R 0x2002 -#define GL_Q 0x2003 -#define GL_MODULATE 0x2100 -#define GL_DECAL 0x2101 -#define GL_TEXTURE_ENV_MODE 0x2200 -#define GL_TEXTURE_ENV_COLOR 0x2201 -#define GL_TEXTURE_ENV 0x2300 -#define GL_EYE_LINEAR 0x2400 -#define GL_OBJECT_LINEAR 0x2401 -#define GL_SPHERE_MAP 0x2402 -#define GL_TEXTURE_GEN_MODE 0x2500 -#define GL_OBJECT_PLANE 0x2501 -#define GL_EYE_PLANE 0x2502 -#define GL_NEAREST 0x2600 -#define GL_LINEAR 0x2601 -#define GL_NEAREST_MIPMAP_NEAREST 0x2700 -#define GL_LINEAR_MIPMAP_NEAREST 0x2701 -#define GL_NEAREST_MIPMAP_LINEAR 0x2702 -#define GL_LINEAR_MIPMAP_LINEAR 0x2703 -#define GL_TEXTURE_MAG_FILTER 0x2800 -#define GL_TEXTURE_MIN_FILTER 0x2801 -#define GL_TEXTURE_WRAP_S 0x2802 -#define GL_TEXTURE_WRAP_T 0x2803 -#define GL_CLAMP 0x2900 -#define GL_REPEAT 0x2901 -#define GL_POLYGON_OFFSET_UNITS 0x2A00 -#define GL_POLYGON_OFFSET_POINT 0x2A01 -#define GL_POLYGON_OFFSET_LINE 0x2A02 -#define GL_R3_G3_B2 0x2A10 -#define GL_V2F 0x2A20 -#define GL_V3F 0x2A21 -#define GL_C4UB_V2F 0x2A22 -#define GL_C4UB_V3F 0x2A23 -#define GL_C3F_V3F 0x2A24 -#define GL_N3F_V3F 0x2A25 -#define GL_C4F_N3F_V3F 0x2A26 -#define GL_T2F_V3F 0x2A27 -#define GL_T4F_V4F 0x2A28 -#define GL_T2F_C4UB_V3F 0x2A29 -#define GL_T2F_C3F_V3F 0x2A2A -#define GL_T2F_N3F_V3F 0x2A2B -#define GL_T2F_C4F_N3F_V3F 0x2A2C -#define GL_T4F_C4F_N3F_V4F 0x2A2D -#define GL_CLIP_PLANE0 0x3000 -#define GL_CLIP_PLANE1 0x3001 -#define GL_CLIP_PLANE2 0x3002 -#define GL_CLIP_PLANE3 0x3003 -#define GL_CLIP_PLANE4 0x3004 -#define GL_CLIP_PLANE5 0x3005 -#define GL_LIGHT0 0x4000 -#define GL_COLOR_BUFFER_BIT 0x00004000 -#define GL_LIGHT1 0x4001 -#define GL_LIGHT2 0x4002 -#define GL_LIGHT3 0x4003 -#define GL_LIGHT4 0x4004 -#define GL_LIGHT5 0x4005 -#define GL_LIGHT6 0x4006 -#define GL_LIGHT7 0x4007 -#define GL_HINT_BIT 0x00008000 -#define GL_POLYGON_OFFSET_FILL 0x8037 -#define GL_POLYGON_OFFSET_FACTOR 0x8038 -#define GL_ALPHA4 0x803B -#define GL_ALPHA8 0x803C -#define GL_ALPHA12 0x803D -#define GL_ALPHA16 0x803E -#define GL_LUMINANCE4 0x803F -#define GL_LUMINANCE8 0x8040 -#define GL_LUMINANCE12 0x8041 -#define GL_LUMINANCE16 0x8042 -#define GL_LUMINANCE4_ALPHA4 0x8043 -#define GL_LUMINANCE6_ALPHA2 0x8044 -#define GL_LUMINANCE8_ALPHA8 0x8045 -#define GL_LUMINANCE12_ALPHA4 0x8046 -#define GL_LUMINANCE12_ALPHA12 0x8047 -#define GL_LUMINANCE16_ALPHA16 0x8048 -#define GL_INTENSITY 0x8049 -#define GL_INTENSITY4 0x804A -#define GL_INTENSITY8 0x804B -#define GL_INTENSITY12 0x804C -#define GL_INTENSITY16 0x804D -#define GL_RGB4 0x804F -#define GL_RGB5 0x8050 -#define GL_RGB8 0x8051 -#define GL_RGB10 0x8052 -#define GL_RGB12 0x8053 -#define GL_RGB16 0x8054 -#define GL_RGBA2 0x8055 -#define GL_RGBA4 0x8056 -#define GL_RGB5_A1 0x8057 -#define GL_RGBA8 0x8058 -#define GL_RGB10_A2 0x8059 -#define GL_RGBA12 0x805A -#define GL_RGBA16 0x805B -#define GL_TEXTURE_RED_SIZE 0x805C -#define GL_TEXTURE_GREEN_SIZE 0x805D -#define GL_TEXTURE_BLUE_SIZE 0x805E -#define GL_TEXTURE_ALPHA_SIZE 0x805F -#define GL_TEXTURE_LUMINANCE_SIZE 0x8060 -#define GL_TEXTURE_INTENSITY_SIZE 0x8061 -#define GL_PROXY_TEXTURE_1D 0x8063 -#define GL_PROXY_TEXTURE_2D 0x8064 -#define GL_TEXTURE_PRIORITY 0x8066 -#define GL_TEXTURE_RESIDENT 0x8067 -#define GL_TEXTURE_BINDING_1D 0x8068 -#define GL_TEXTURE_BINDING_2D 0x8069 -#define GL_VERTEX_ARRAY 0x8074 -#define GL_NORMAL_ARRAY 0x8075 -#define GL_COLOR_ARRAY 0x8076 -#define GL_INDEX_ARRAY 0x8077 -#define GL_TEXTURE_COORD_ARRAY 0x8078 -#define GL_EDGE_FLAG_ARRAY 0x8079 -#define GL_VERTEX_ARRAY_SIZE 0x807A -#define GL_VERTEX_ARRAY_TYPE 0x807B -#define GL_VERTEX_ARRAY_STRIDE 0x807C -#define GL_NORMAL_ARRAY_TYPE 0x807E -#define GL_NORMAL_ARRAY_STRIDE 0x807F -#define GL_COLOR_ARRAY_SIZE 0x8081 -#define GL_COLOR_ARRAY_TYPE 0x8082 -#define GL_COLOR_ARRAY_STRIDE 0x8083 -#define GL_INDEX_ARRAY_TYPE 0x8085 -#define GL_INDEX_ARRAY_STRIDE 0x8086 -#define GL_TEXTURE_COORD_ARRAY_SIZE 0x8088 -#define GL_TEXTURE_COORD_ARRAY_TYPE 0x8089 -#define GL_TEXTURE_COORD_ARRAY_STRIDE 0x808A -#define GL_EDGE_FLAG_ARRAY_STRIDE 0x808C -#define GL_VERTEX_ARRAY_POINTER 0x808E -#define GL_NORMAL_ARRAY_POINTER 0x808F -#define GL_COLOR_ARRAY_POINTER 0x8090 -#define GL_INDEX_ARRAY_POINTER 0x8091 -#define GL_TEXTURE_COORD_ARRAY_POINTER 0x8092 -#define GL_EDGE_FLAG_ARRAY_POINTER 0x8093 -#define GL_COLOR_INDEX1_EXT 0x80E2 -#define GL_COLOR_INDEX2_EXT 0x80E3 -#define GL_COLOR_INDEX4_EXT 0x80E4 -#define GL_COLOR_INDEX8_EXT 0x80E5 -#define GL_COLOR_INDEX12_EXT 0x80E6 -#define GL_COLOR_INDEX16_EXT 0x80E7 -#define GL_EVAL_BIT 0x00010000 -#define GL_LIST_BIT 0x00020000 -#define GL_TEXTURE_BIT 0x00040000 -#define GL_SCISSOR_BIT 0x00080000 -#define GL_ALL_ATTRIB_BITS 0x000fffff -#define GL_CLIENT_ALL_ATTRIB_BITS 0xffffffff - -#ifdef GLEW_INIT_OPENGL11_FUNCTIONS - -typedef void (GLAPIENTRY * PFNGLACCUMPROC) (GLenum op, GLfloat value); -typedef void (GLAPIENTRY * PFNGLALPHAFUNCPROC) (GLenum func, GLclampf ref); -typedef GLboolean (GLAPIENTRY * PFNGLARETEXTURESRESIDENTPROC) (GLsizei n, const GLuint *textures, GLboolean *residences); -typedef void (GLAPIENTRY * PFNGLARRAYELEMENTPROC) (GLint i); -typedef void (GLAPIENTRY * PFNGLBEGINPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLBINDTEXTUREPROC) (GLenum target, GLuint texture); -typedef void (GLAPIENTRY * PFNGLBITMAPPROC) (GLsizei width, GLsizei height, GLfloat xorig, GLfloat yorig, GLfloat xmove, GLfloat ymove, const GLubyte *bitmap); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCPROC) (GLenum sfactor, GLenum dfactor); -typedef void (GLAPIENTRY * PFNGLCALLLISTPROC) (GLuint list); -typedef void (GLAPIENTRY * PFNGLCALLLISTSPROC) (GLsizei n, GLenum type, const GLvoid *lists); -typedef void (GLAPIENTRY * PFNGLCLEARPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLCLEARACCUMPROC) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); -typedef void (GLAPIENTRY * PFNGLCLEARCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHPROC) (GLclampd depth); -typedef void (GLAPIENTRY * PFNGLCLEARINDEXPROC) (GLfloat c); -typedef void (GLAPIENTRY * PFNGLCLEARSTENCILPROC) (GLint s); -typedef void (GLAPIENTRY * PFNGLCLIPPLANEPROC) (GLenum plane, const GLdouble *equation); -typedef void (GLAPIENTRY * PFNGLCOLOR3BPROC) (GLbyte red, GLbyte green, GLbyte blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3BVPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3DPROC) (GLdouble red, GLdouble green, GLdouble blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3FPROC) (GLfloat red, GLfloat green, GLfloat blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3IPROC) (GLint red, GLint green, GLint blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3SPROC) (GLshort red, GLshort green, GLshort blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3UBPROC) (GLubyte red, GLubyte green, GLubyte blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3UBVPROC) (const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3UIPROC) (GLuint red, GLuint green, GLuint blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3UIVPROC) (const GLuint *v); -typedef void (GLAPIENTRY * PFNGLCOLOR3USPROC) (GLushort red, GLushort green, GLushort blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3USVPROC) (const GLushort *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4BPROC) (GLbyte red, GLbyte green, GLbyte blue, GLbyte alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4BVPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4DPROC) (GLdouble red, GLdouble green, GLdouble blue, GLdouble alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4FPROC) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4IPROC) (GLint red, GLint green, GLint blue, GLint alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4SPROC) (GLshort red, GLshort green, GLshort blue, GLshort alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBPROC) (GLubyte red, GLubyte green, GLubyte blue, GLubyte alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVPROC) (const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4UIPROC) (GLuint red, GLuint green, GLuint blue, GLuint alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4UIVPROC) (const GLuint *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4USPROC) (GLushort red, GLushort green, GLushort blue, GLushort alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4USVPROC) (const GLushort *v); -typedef void (GLAPIENTRY * PFNGLCOLORMASKPROC) (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); -typedef void (GLAPIENTRY * PFNGLCOLORMATERIALPROC) (GLenum face, GLenum mode); -typedef void (GLAPIENTRY * PFNGLCOLORPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLCOPYPIXELSPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum type); -typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCULLFACEPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLDELETELISTSPROC) (GLuint list, GLsizei range); -typedef void (GLAPIENTRY * PFNGLDELETETEXTURESPROC) (GLsizei n, const GLuint *textures); -typedef void (GLAPIENTRY * PFNGLDEPTHFUNCPROC) (GLenum func); -typedef void (GLAPIENTRY * PFNGLDEPTHMASKPROC) (GLboolean flag); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEPROC) (GLclampd zNear, GLclampd zFar); -typedef void (GLAPIENTRY * PFNGLDISABLEPROC) (GLenum cap); -typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEPROC) (GLenum array); -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSPROC) (GLenum mode, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices); -typedef void (GLAPIENTRY * PFNGLDRAWPIXELSPROC) (GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGPROC) (GLboolean flag); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTERPROC) (GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGVPROC) (const GLboolean *flag); -typedef void (GLAPIENTRY * PFNGLENABLEPROC) (GLenum cap); -typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEPROC) (GLenum array); -typedef void (GLAPIENTRY * PFNGLENDPROC) (void); -typedef void (GLAPIENTRY * PFNGLENDLISTPROC) (void); -typedef void (GLAPIENTRY * PFNGLEVALCOORD1DPROC) (GLdouble u); -typedef void (GLAPIENTRY * PFNGLEVALCOORD1DVPROC) (const GLdouble *u); -typedef void (GLAPIENTRY * PFNGLEVALCOORD1FPROC) (GLfloat u); -typedef void (GLAPIENTRY * PFNGLEVALCOORD1FVPROC) (const GLfloat *u); -typedef void (GLAPIENTRY * PFNGLEVALCOORD2DPROC) (GLdouble u, GLdouble v); -typedef void (GLAPIENTRY * PFNGLEVALCOORD2DVPROC) (const GLdouble *u); -typedef void (GLAPIENTRY * PFNGLEVALCOORD2FPROC) (GLfloat u, GLfloat v); -typedef void (GLAPIENTRY * PFNGLEVALCOORD2FVPROC) (const GLfloat *u); -typedef void (GLAPIENTRY * PFNGLEVALMESH1PROC) (GLenum mode, GLint i1, GLint i2); -typedef void (GLAPIENTRY * PFNGLEVALMESH2PROC) (GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2); -typedef void (GLAPIENTRY * PFNGLEVALPOINT1PROC) (GLint i); -typedef void (GLAPIENTRY * PFNGLEVALPOINT2PROC) (GLint i, GLint j); -typedef void (GLAPIENTRY * PFNGLFEEDBACKBUFFERPROC) (GLsizei size, GLenum type, GLfloat *buffer); -typedef void (GLAPIENTRY * PFNGLFINISHPROC) (void); -typedef void (GLAPIENTRY * PFNGLFLUSHPROC) (void); -typedef void (GLAPIENTRY * PFNGLFOGFPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFOGFVPROC) (GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLFOGIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFOGIVPROC) (GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLFRONTFACEPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRUSTUMPROC) (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); -typedef GLuint (GLAPIENTRY * PFNGLGENLISTSPROC) (GLsizei range); -typedef void (GLAPIENTRY * PFNGLGENTEXTURESPROC) (GLsizei n, GLuint *textures); -typedef void (GLAPIENTRY * PFNGLGETBOOLEANVPROC) (GLenum pname, GLboolean *params); -typedef void (GLAPIENTRY * PFNGLGETCLIPPLANEPROC) (GLenum plane, GLdouble *equation); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEVPROC) (GLenum pname, GLdouble *params); -typedef GLenum (GLAPIENTRY * PFNGLGETERRORPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETFLOATVPROC) (GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETINTEGERVPROC) (GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETLIGHTFVPROC) (GLenum light, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETLIGHTIVPROC) (GLenum light, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETMAPDVPROC) (GLenum target, GLenum query, GLdouble *v); -typedef void (GLAPIENTRY * PFNGLGETMAPFVPROC) (GLenum target, GLenum query, GLfloat *v); -typedef void (GLAPIENTRY * PFNGLGETMAPIVPROC) (GLenum target, GLenum query, GLint *v); -typedef void (GLAPIENTRY * PFNGLGETMATERIALFVPROC) (GLenum face, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETMATERIALIVPROC) (GLenum face, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETPIXELMAPFVPROC) (GLenum map, GLfloat *values); -typedef void (GLAPIENTRY * PFNGLGETPIXELMAPUIVPROC) (GLenum map, GLuint *values); -typedef void (GLAPIENTRY * PFNGLGETPIXELMAPUSVPROC) (GLenum map, GLushort *values); -typedef void (GLAPIENTRY * PFNGLGETPOINTERVPROC) (GLenum pname, GLvoid* *params); -typedef void (GLAPIENTRY * PFNGLGETPOLYGONSTIPPLEPROC) (GLubyte *mask); -typedef GLubyte* (GLAPIENTRY * PFNGLGETSTRINGPROC) (GLenum s); -typedef void (GLAPIENTRY * PFNGLGETTEXENVFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETTEXENVIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETTEXGENDVPROC) (GLenum coord, GLenum pname, GLdouble *params); -typedef void (GLAPIENTRY * PFNGLGETTEXGENFVPROC) (GLenum coord, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETTEXGENIVPROC) (GLenum coord, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETTEXIMAGEPROC) (GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLGETTEXLEVELPARAMETERFVPROC) (GLenum target, GLint level, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETTEXLEVELPARAMETERIVPROC) (GLenum target, GLint level, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLHINTPROC) (GLenum target, GLenum mode); -typedef void (GLAPIENTRY * PFNGLINDEXMASKPROC) (GLuint mask); -typedef void (GLAPIENTRY * PFNGLINDEXPOINTERPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLINDEXDPROC) (GLdouble c); -typedef void (GLAPIENTRY * PFNGLINDEXDVPROC) (const GLdouble *c); -typedef void (GLAPIENTRY * PFNGLINDEXFPROC) (GLfloat c); -typedef void (GLAPIENTRY * PFNGLINDEXFVPROC) (const GLfloat *c); -typedef void (GLAPIENTRY * PFNGLINDEXIPROC) (GLint c); -typedef void (GLAPIENTRY * PFNGLINDEXIVPROC) (const GLint *c); -typedef void (GLAPIENTRY * PFNGLINDEXSPROC) (GLshort c); -typedef void (GLAPIENTRY * PFNGLINDEXSVPROC) (const GLshort *c); -typedef void (GLAPIENTRY * PFNGLINDEXUBPROC) (GLubyte c); -typedef void (GLAPIENTRY * PFNGLINDEXUBVPROC) (const GLubyte *c); -typedef void (GLAPIENTRY * PFNGLINITNAMESPROC) (void); -typedef void (GLAPIENTRY * PFNGLINTERLEAVEDARRAYSPROC) (GLenum format, GLsizei stride, const GLvoid *pointer); -typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDPROC) (GLenum cap); -typedef GLboolean (GLAPIENTRY * PFNGLISLISTPROC) (GLuint list); -typedef GLboolean (GLAPIENTRY * PFNGLISTEXTUREPROC) (GLuint texture); -typedef void (GLAPIENTRY * PFNGLLIGHTMODELFPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLLIGHTMODELFVPROC) (GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLLIGHTMODELIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLLIGHTMODELIVPROC) (GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLLIGHTFPROC) (GLenum light, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLLIGHTFVPROC) (GLenum light, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLLIGHTIPROC) (GLenum light, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLLIGHTIVPROC) (GLenum light, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLLINESTIPPLEPROC) (GLint factor, GLushort pattern); -typedef void (GLAPIENTRY * PFNGLLINEWIDTHPROC) (GLfloat width); -typedef void (GLAPIENTRY * PFNGLLISTBASEPROC) (GLuint base); -typedef void (GLAPIENTRY * PFNGLLOADIDENTITYPROC) (void); -typedef void (GLAPIENTRY * PFNGLLOADMATRIXDPROC) (const GLdouble *m); -typedef void (GLAPIENTRY * PFNGLLOADMATRIXFPROC) (const GLfloat *m); -typedef void (GLAPIENTRY * PFNGLLOADNAMEPROC) (GLuint name); -typedef void (GLAPIENTRY * PFNGLLOGICOPPROC) (GLenum opcode); -typedef void (GLAPIENTRY * PFNGLMAP1DPROC) (GLenum target, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); -typedef void (GLAPIENTRY * PFNGLMAP1FPROC) (GLenum target, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); -typedef void (GLAPIENTRY * PFNGLMAP2DPROC) (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); -typedef void (GLAPIENTRY * PFNGLMAP2FPROC) (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); -typedef void (GLAPIENTRY * PFNGLMAPGRID1DPROC) (GLint un, GLdouble u1, GLdouble u2); -typedef void (GLAPIENTRY * PFNGLMAPGRID1FPROC) (GLint un, GLfloat u1, GLfloat u2); -typedef void (GLAPIENTRY * PFNGLMAPGRID2DPROC) (GLint un, GLdouble u1, GLdouble u2, GLint vn, GLdouble v1, GLdouble v2); -typedef void (GLAPIENTRY * PFNGLMAPGRID2FPROC) (GLint un, GLfloat u1, GLfloat u2, GLint vn, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLMATERIALFPROC) (GLenum face, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMATERIALFVPROC) (GLenum face, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLMATERIALIPROC) (GLenum face, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMATERIALIVPROC) (GLenum face, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLMATRIXMODEPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLMULTMATRIXDPROC) (const GLdouble *m); -typedef void (GLAPIENTRY * PFNGLMULTMATRIXFPROC) (const GLfloat *m); -typedef void (GLAPIENTRY * PFNGLNEWLISTPROC) (GLuint list, GLenum mode); -typedef void (GLAPIENTRY * PFNGLNORMAL3BPROC) (GLbyte nx, GLbyte ny, GLbyte nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3BVPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLNORMAL3DPROC) (GLdouble nx, GLdouble ny, GLdouble nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLNORMAL3FPROC) (GLfloat nx, GLfloat ny, GLfloat nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLNORMAL3IPROC) (GLint nx, GLint ny, GLint nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLNORMAL3SPROC) (GLshort nx, GLshort ny, GLshort nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTERPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLORTHOPROC) (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); -typedef void (GLAPIENTRY * PFNGLPASSTHROUGHPROC) (GLfloat token); -typedef void (GLAPIENTRY * PFNGLPIXELMAPFVPROC) (GLenum map, GLsizei mapsize, const GLfloat *values); -typedef void (GLAPIENTRY * PFNGLPIXELMAPUIVPROC) (GLenum map, GLsizei mapsize, const GLuint *values); -typedef void (GLAPIENTRY * PFNGLPIXELMAPUSVPROC) (GLenum map, GLsizei mapsize, const GLushort *values); -typedef void (GLAPIENTRY * PFNGLPIXELSTOREFPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPIXELSTOREIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFERFPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFERIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLPIXELZOOMPROC) (GLfloat xfactor, GLfloat yfactor); -typedef void (GLAPIENTRY * PFNGLPOINTSIZEPROC) (GLfloat size); -typedef void (GLAPIENTRY * PFNGLPOLYGONMODEPROC) (GLenum face, GLenum mode); -typedef void (GLAPIENTRY * PFNGLPOLYGONOFFSETPROC) (GLfloat factor, GLfloat units); -typedef void (GLAPIENTRY * PFNGLPOLYGONSTIPPLEPROC) (const GLubyte *mask); -typedef void (GLAPIENTRY * PFNGLPOPATTRIBPROC) (void); -typedef void (GLAPIENTRY * PFNGLPOPCLIENTATTRIBPROC) (void); -typedef void (GLAPIENTRY * PFNGLPOPMATRIXPROC) (void); -typedef void (GLAPIENTRY * PFNGLPOPNAMEPROC) (void); -typedef void (GLAPIENTRY * PFNGLPRIORITIZETEXTURESPROC) (GLsizei n, const GLuint *textures, const GLclampf *priorities); -typedef void (GLAPIENTRY * PFNGLPUSHATTRIBPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLPUSHCLIENTATTRIBPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLPUSHMATRIXPROC) (void); -typedef void (GLAPIENTRY * PFNGLPUSHNAMEPROC) (GLuint name); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2DPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2FPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2IPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2SPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLRASTERPOS2SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3DPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3FPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3IPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3SPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLRASTERPOS3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4DPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4FPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4IPROC) (GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4SPROC) (GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLRASTERPOS4SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLREADBUFFERPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLREADPIXELSPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLRECTDPROC) (GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2); -typedef void (GLAPIENTRY * PFNGLRECTDVPROC) (const GLdouble *v1, const GLdouble *v2); -typedef void (GLAPIENTRY * PFNGLRECTFPROC) (GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2); -typedef void (GLAPIENTRY * PFNGLRECTFVPROC) (const GLfloat *v1, const GLfloat *v2); -typedef void (GLAPIENTRY * PFNGLRECTIPROC) (GLint x1, GLint y1, GLint x2, GLint y2); -typedef void (GLAPIENTRY * PFNGLRECTIVPROC) (const GLint *v1, const GLint *v2); -typedef void (GLAPIENTRY * PFNGLRECTSPROC) (GLshort x1, GLshort y1, GLshort x2, GLshort y2); -typedef void (GLAPIENTRY * PFNGLRECTSVPROC) (const GLshort *v1, const GLshort *v2); -typedef GLint (GLAPIENTRY * PFNGLRENDERMODEPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLROTATEDPROC) (GLdouble angle, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLROTATEFPROC) (GLfloat angle, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLSCALEDPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLSCALEFPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLSCISSORPROC) (GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLSELECTBUFFERPROC) (GLsizei size, GLuint *buffer); -typedef void (GLAPIENTRY * PFNGLSHADEMODELPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLSTENCILFUNCPROC) (GLenum func, GLint ref, GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILMASKPROC) (GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILOPPROC) (GLenum fail, GLenum zfail, GLenum zpass); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1DPROC) (GLdouble s); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1FPROC) (GLfloat s); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1IPROC) (GLint s); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1SPROC) (GLshort s); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2DPROC) (GLdouble s, GLdouble t); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FPROC) (GLfloat s, GLfloat t); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2IPROC) (GLint s, GLint t); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2SPROC) (GLshort s, GLshort t); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3DPROC) (GLdouble s, GLdouble t, GLdouble r); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3FPROC) (GLfloat s, GLfloat t, GLfloat r); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3IPROC) (GLint s, GLint t, GLint r); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3SPROC) (GLshort s, GLshort t, GLshort r); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4DPROC) (GLdouble s, GLdouble t, GLdouble r, GLdouble q); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat q); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4IPROC) (GLint s, GLint t, GLint r, GLint q); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4SPROC) (GLshort s, GLshort t, GLshort r, GLshort q); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLTEXENVFPROC) (GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLTEXENVFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLTEXENVIPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLTEXENVIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLTEXGENDPROC) (GLenum coord, GLenum pname, GLdouble param); -typedef void (GLAPIENTRY * PFNGLTEXGENDVPROC) (GLenum coord, GLenum pname, const GLdouble *params); -typedef void (GLAPIENTRY * PFNGLTEXGENFPROC) (GLenum coord, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLTEXGENFVPROC) (GLenum coord, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLTEXGENIPROC) (GLenum coord, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLTEXGENIVPROC) (GLenum coord, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE1DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE2DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTRANSLATEDPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLTRANSLATEFPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEX2DPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEX2DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLVERTEX2FPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEX2FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLVERTEX2IPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLVERTEX2IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEX2SPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEX2SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEX3DPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEX3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLVERTEX3FPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEX3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLVERTEX3IPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLVERTEX3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEX3SPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEX3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEX4DPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEX4DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLVERTEX4FPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEX4FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLVERTEX4IPROC) (GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLVERTEX4IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEX4SPROC) (GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEX4SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLVIEWPORTPROC) (GLint x, GLint y, GLsizei width, GLsizei height); - -#define glAccum GLEW_GET_FUN(__glewAccum) -#define glAlphaFunc GLEW_GET_FUN(__glewAlphaFunc) -#define glAreTexturesResident GLEW_GET_FUN(__glewAreTexturesResident) -#define glArrayElement GLEW_GET_FUN(__glewArrayElement) -#define glBegin GLEW_GET_FUN(__glewBegin) -#define glBindTexture GLEW_GET_FUN(__glewBindTexture) -#define glBitmap GLEW_GET_FUN(__glewBitmap) -#define glBlendFunc GLEW_GET_FUN(__glewBlendFunc) -#define glCallList GLEW_GET_FUN(__glewCallList) -#define glCallLists GLEW_GET_FUN(__glewCallLists) -#define glClear GLEW_GET_FUN(__glewClear) -#define glClearAccum GLEW_GET_FUN(__glewClearAccum) -#define glClearColor GLEW_GET_FUN(__glewClearColor) -#define glClearDepth GLEW_GET_FUN(__glewClearDepth) -#define glClearIndex GLEW_GET_FUN(__glewClearIndex) -#define glClearStencil GLEW_GET_FUN(__glewClearStencil) -#define glClipPlane GLEW_GET_FUN(__glewClipPlane) -#define glColor3b GLEW_GET_FUN(__glewColor3b) -#define glColor3bv GLEW_GET_FUN(__glewColor3bv) -#define glColor3d GLEW_GET_FUN(__glewColor3d) -#define glColor3dv GLEW_GET_FUN(__glewColor3dv) -#define glColor3f GLEW_GET_FUN(__glewColor3f) -#define glColor3fv GLEW_GET_FUN(__glewColor3fv) -#define glColor3i GLEW_GET_FUN(__glewColor3i) -#define glColor3iv GLEW_GET_FUN(__glewColor3iv) -#define glColor3s GLEW_GET_FUN(__glewColor3s) -#define glColor3sv GLEW_GET_FUN(__glewColor3sv) -#define glColor3ub GLEW_GET_FUN(__glewColor3ub) -#define glColor3ubv GLEW_GET_FUN(__glewColor3ubv) -#define glColor3ui GLEW_GET_FUN(__glewColor3ui) -#define glColor3uiv GLEW_GET_FUN(__glewColor3uiv) -#define glColor3us GLEW_GET_FUN(__glewColor3us) -#define glColor3usv GLEW_GET_FUN(__glewColor3usv) -#define glColor4b GLEW_GET_FUN(__glewColor4b) -#define glColor4bv GLEW_GET_FUN(__glewColor4bv) -#define glColor4d GLEW_GET_FUN(__glewColor4d) -#define glColor4dv GLEW_GET_FUN(__glewColor4dv) -#define glColor4f GLEW_GET_FUN(__glewColor4f) -#define glColor4fv GLEW_GET_FUN(__glewColor4fv) -#define glColor4i GLEW_GET_FUN(__glewColor4i) -#define glColor4iv GLEW_GET_FUN(__glewColor4iv) -#define glColor4s GLEW_GET_FUN(__glewColor4s) -#define glColor4sv GLEW_GET_FUN(__glewColor4sv) -#define glColor4ub GLEW_GET_FUN(__glewColor4ub) -#define glColor4ubv GLEW_GET_FUN(__glewColor4ubv) -#define glColor4ui GLEW_GET_FUN(__glewColor4ui) -#define glColor4uiv GLEW_GET_FUN(__glewColor4uiv) -#define glColor4us GLEW_GET_FUN(__glewColor4us) -#define glColor4usv GLEW_GET_FUN(__glewColor4usv) -#define glColorMask GLEW_GET_FUN(__glewColorMask) -#define glColorMaterial GLEW_GET_FUN(__glewColorMaterial) -#define glColorPointer GLEW_GET_FUN(__glewColorPointer) -#define glCopyPixels GLEW_GET_FUN(__glewCopyPixels) -#define glCopyTexImage1D GLEW_GET_FUN(__glewCopyTexImage1D) -#define glCopyTexImage2D GLEW_GET_FUN(__glewCopyTexImage2D) -#define glCopyTexSubImage1D GLEW_GET_FUN(__glewCopyTexSubImage1D) -#define glCopyTexSubImage2D GLEW_GET_FUN(__glewCopyTexSubImage2D) -#define glCullFace GLEW_GET_FUN(__glewCullFace) -#define glDeleteLists GLEW_GET_FUN(__glewDeleteLists) -#define glDeleteTextures GLEW_GET_FUN(__glewDeleteTextures) -#define glDepthFunc GLEW_GET_FUN(__glewDepthFunc) -#define glDepthMask GLEW_GET_FUN(__glewDepthMask) -#define glDepthRange GLEW_GET_FUN(__glewDepthRange) -#define glDisable GLEW_GET_FUN(__glewDisable) -#define glDisableClientState GLEW_GET_FUN(__glewDisableClientState) -#define glDrawArrays GLEW_GET_FUN(__glewDrawArrays) -#define glDrawBuffer GLEW_GET_FUN(__glewDrawBuffer) -#define glDrawElements GLEW_GET_FUN(__glewDrawElements) -#define glDrawPixels GLEW_GET_FUN(__glewDrawPixels) -#define glEdgeFlag GLEW_GET_FUN(__glewEdgeFlag) -#define glEdgeFlagPointer GLEW_GET_FUN(__glewEdgeFlagPointer) -#define glEdgeFlagv GLEW_GET_FUN(__glewEdgeFlagv) -#define glEnable GLEW_GET_FUN(__glewEnable) -#define glEnableClientState GLEW_GET_FUN(__glewEnableClientState) -#define glEnd GLEW_GET_FUN(__glewEnd) -#define glEndList GLEW_GET_FUN(__glewEndList) -#define glEvalCoord1d GLEW_GET_FUN(__glewEvalCoord1d) -#define glEvalCoord1dv GLEW_GET_FUN(__glewEvalCoord1dv) -#define glEvalCoord1f GLEW_GET_FUN(__glewEvalCoord1f) -#define glEvalCoord1fv GLEW_GET_FUN(__glewEvalCoord1fv) -#define glEvalCoord2d GLEW_GET_FUN(__glewEvalCoord2d) -#define glEvalCoord2dv GLEW_GET_FUN(__glewEvalCoord2dv) -#define glEvalCoord2f GLEW_GET_FUN(__glewEvalCoord2f) -#define glEvalCoord2fv GLEW_GET_FUN(__glewEvalCoord2fv) -#define glEvalMesh1 GLEW_GET_FUN(__glewEvalMesh1) -#define glEvalMesh2 GLEW_GET_FUN(__glewEvalMesh2) -#define glEvalPoint1 GLEW_GET_FUN(__glewEvalPoint1) -#define glEvalPoint2 GLEW_GET_FUN(__glewEvalPoint2) -#define glFeedbackBuffer GLEW_GET_FUN(__glewFeedbackBuffer) -#define glFinish GLEW_GET_FUN(__glewFinish) -#define glFlush GLEW_GET_FUN(__glewFlush) -#define glFogf GLEW_GET_FUN(__glewFogf) -#define glFogfv GLEW_GET_FUN(__glewFogfv) -#define glFogi GLEW_GET_FUN(__glewFogi) -#define glFogiv GLEW_GET_FUN(__glewFogiv) -#define glFrontFace GLEW_GET_FUN(__glewFrontFace) -#define glFrustum GLEW_GET_FUN(__glewFrustum) -#define glGenLists GLEW_GET_FUN(__glewGenLists) -#define glGenTextures GLEW_GET_FUN(__glewGenTextures) -#define glGetBooleanv GLEW_GET_FUN(__glewGetBooleanv) -#define glGetClipPlane GLEW_GET_FUN(__glewGetClipPlane) -#define glGetDoublev GLEW_GET_FUN(__glewGetDoublev) -#define glGetError GLEW_GET_FUN(__glewGetError) -#define glGetFloatv GLEW_GET_FUN(__glewGetFloatv) -#define glGetIntegerv GLEW_GET_FUN(__glewGetIntegerv) -#define glGetLightfv GLEW_GET_FUN(__glewGetLightfv) -#define glGetLightiv GLEW_GET_FUN(__glewGetLightiv) -#define glGetMapdv GLEW_GET_FUN(__glewGetMapdv) -#define glGetMapfv GLEW_GET_FUN(__glewGetMapfv) -#define glGetMapiv GLEW_GET_FUN(__glewGetMapiv) -#define glGetMaterialfv GLEW_GET_FUN(__glewGetMaterialfv) -#define glGetMaterialiv GLEW_GET_FUN(__glewGetMaterialiv) -#define glGetPixelMapfv GLEW_GET_FUN(__glewGetPixelMapfv) -#define glGetPixelMapuiv GLEW_GET_FUN(__glewGetPixelMapuiv) -#define glGetPixelMapusv GLEW_GET_FUN(__glewGetPixelMapusv) -#define glGetPointerv GLEW_GET_FUN(__glewGetPointerv) -#define glGetPolygonStipple GLEW_GET_FUN(__glewGetPolygonStipple) -#define glGetString GLEW_GET_FUN(__glewGetString) -#define glGetTexEnvfv GLEW_GET_FUN(__glewGetTexEnvfv) -#define glGetTexEnviv GLEW_GET_FUN(__glewGetTexEnviv) -#define glGetTexGendv GLEW_GET_FUN(__glewGetTexGendv) -#define glGetTexGenfv GLEW_GET_FUN(__glewGetTexGenfv) -#define glGetTexGeniv GLEW_GET_FUN(__glewGetTexGeniv) -#define glGetTexImage GLEW_GET_FUN(__glewGetTexImage) -#define glGetTexLevelParameterfv GLEW_GET_FUN(__glewGetTexLevelParameterfv) -#define glGetTexLevelParameteriv GLEW_GET_FUN(__glewGetTexLevelParameteriv) -#define glGetTexParameterfv GLEW_GET_FUN(__glewGetTexParameterfv) -#define glGetTexParameteriv GLEW_GET_FUN(__glewGetTexParameteriv) -#define glHint GLEW_GET_FUN(__glewHint) -#define glIndexMask GLEW_GET_FUN(__glewIndexMask) -#define glIndexPointer GLEW_GET_FUN(__glewIndexPointer) -#define glIndexd GLEW_GET_FUN(__glewIndexd) -#define glIndexdv GLEW_GET_FUN(__glewIndexdv) -#define glIndexf GLEW_GET_FUN(__glewIndexf) -#define glIndexfv GLEW_GET_FUN(__glewIndexfv) -#define glIndexi GLEW_GET_FUN(__glewIndexi) -#define glIndexiv GLEW_GET_FUN(__glewIndexiv) -#define glIndexs GLEW_GET_FUN(__glewIndexs) -#define glIndexsv GLEW_GET_FUN(__glewIndexsv) -#define glIndexub GLEW_GET_FUN(__glewIndexub) -#define glIndexubv GLEW_GET_FUN(__glewIndexubv) -#define glInitNames GLEW_GET_FUN(__glewInitNames) -#define glInterleavedArrays GLEW_GET_FUN(__glewInterleavedArrays) -#define glIsEnabled GLEW_GET_FUN(__glewIsEnabled) -#define glIsList GLEW_GET_FUN(__glewIsList) -#define glIsTexture GLEW_GET_FUN(__glewIsTexture) -#define glLightModelf GLEW_GET_FUN(__glewLightModelf) -#define glLightModelfv GLEW_GET_FUN(__glewLightModelfv) -#define glLightModeli GLEW_GET_FUN(__glewLightModeli) -#define glLightModeliv GLEW_GET_FUN(__glewLightModeliv) -#define glLightf GLEW_GET_FUN(__glewLightf) -#define glLightfv GLEW_GET_FUN(__glewLightfv) -#define glLighti GLEW_GET_FUN(__glewLighti) -#define glLightiv GLEW_GET_FUN(__glewLightiv) -#define glLineStipple GLEW_GET_FUN(__glewLineStipple) -#define glLineWidth GLEW_GET_FUN(__glewLineWidth) -#define glListBase GLEW_GET_FUN(__glewListBase) -#define glLoadIdentity GLEW_GET_FUN(__glewLoadIdentity) -#define glLoadMatrixd GLEW_GET_FUN(__glewLoadMatrixd) -#define glLoadMatrixf GLEW_GET_FUN(__glewLoadMatrixf) -#define glLoadName GLEW_GET_FUN(__glewLoadName) -#define glLogicOp GLEW_GET_FUN(__glewLogicOp) -#define glMap1d GLEW_GET_FUN(__glewMap1d) -#define glMap1f GLEW_GET_FUN(__glewMap1f) -#define glMap2d GLEW_GET_FUN(__glewMap2d) -#define glMap2f GLEW_GET_FUN(__glewMap2f) -#define glMapGrid1d GLEW_GET_FUN(__glewMapGrid1d) -#define glMapGrid1f GLEW_GET_FUN(__glewMapGrid1f) -#define glMapGrid2d GLEW_GET_FUN(__glewMapGrid2d) -#define glMapGrid2f GLEW_GET_FUN(__glewMapGrid2f) -#define glMaterialf GLEW_GET_FUN(__glewMaterialf) -#define glMaterialfv GLEW_GET_FUN(__glewMaterialfv) -#define glMateriali GLEW_GET_FUN(__glewMateriali) -#define glMaterialiv GLEW_GET_FUN(__glewMaterialiv) -#define glMatrixMode GLEW_GET_FUN(__glewMatrixMode) -#define glMultMatrixd GLEW_GET_FUN(__glewMultMatrixd) -#define glMultMatrixf GLEW_GET_FUN(__glewMultMatrixf) -#define glNewList GLEW_GET_FUN(__glewNewList) -#define glNormal3b GLEW_GET_FUN(__glewNormal3b) -#define glNormal3bv GLEW_GET_FUN(__glewNormal3bv) -#define glNormal3d GLEW_GET_FUN(__glewNormal3d) -#define glNormal3dv GLEW_GET_FUN(__glewNormal3dv) -#define glNormal3f GLEW_GET_FUN(__glewNormal3f) -#define glNormal3fv GLEW_GET_FUN(__glewNormal3fv) -#define glNormal3i GLEW_GET_FUN(__glewNormal3i) -#define glNormal3iv GLEW_GET_FUN(__glewNormal3iv) -#define glNormal3s GLEW_GET_FUN(__glewNormal3s) -#define glNormal3sv GLEW_GET_FUN(__glewNormal3sv) -#define glNormalPointer GLEW_GET_FUN(__glewNormalPointer) -#define glOrtho GLEW_GET_FUN(__glewOrtho) -#define glPassThrough GLEW_GET_FUN(__glewPassThrough) -#define glPixelMapfv GLEW_GET_FUN(__glewPixelMapfv) -#define glPixelMapuiv GLEW_GET_FUN(__glewPixelMapuiv) -#define glPixelMapusv GLEW_GET_FUN(__glewPixelMapusv) -#define glPixelStoref GLEW_GET_FUN(__glewPixelStoref) -#define glPixelStorei GLEW_GET_FUN(__glewPixelStorei) -#define glPixelTransferf GLEW_GET_FUN(__glewPixelTransferf) -#define glPixelTransferi GLEW_GET_FUN(__glewPixelTransferi) -#define glPixelZoom GLEW_GET_FUN(__glewPixelZoom) -#define glPointSize GLEW_GET_FUN(__glewPointSize) -#define glPolygonMode GLEW_GET_FUN(__glewPolygonMode) -#define glPolygonOffset GLEW_GET_FUN(__glewPolygonOffset) -#define glPolygonStipple GLEW_GET_FUN(__glewPolygonStipple) -#define glPopAttrib GLEW_GET_FUN(__glewPopAttrib) -#define glPopClientAttrib GLEW_GET_FUN(__glewPopClientAttrib) -#define glPopMatrix GLEW_GET_FUN(__glewPopMatrix) -#define glPopName GLEW_GET_FUN(__glewPopName) -#define glPrioritizeTextures GLEW_GET_FUN(__glewPrioritizeTextures) -#define glPushAttrib GLEW_GET_FUN(__glewPushAttrib) -#define glPushClientAttrib GLEW_GET_FUN(__glewPushClientAttrib) -#define glPushMatrix GLEW_GET_FUN(__glewPushMatrix) -#define glPushName GLEW_GET_FUN(__glewPushName) -#define glRasterPos2d GLEW_GET_FUN(__glewRasterPos2d) -#define glRasterPos2dv GLEW_GET_FUN(__glewRasterPos2dv) -#define glRasterPos2f GLEW_GET_FUN(__glewRasterPos2f) -#define glRasterPos2fv GLEW_GET_FUN(__glewRasterPos2fv) -#define glRasterPos2i GLEW_GET_FUN(__glewRasterPos2i) -#define glRasterPos2iv GLEW_GET_FUN(__glewRasterPos2iv) -#define glRasterPos2s GLEW_GET_FUN(__glewRasterPos2s) -#define glRasterPos2sv GLEW_GET_FUN(__glewRasterPos2sv) -#define glRasterPos3d GLEW_GET_FUN(__glewRasterPos3d) -#define glRasterPos3dv GLEW_GET_FUN(__glewRasterPos3dv) -#define glRasterPos3f GLEW_GET_FUN(__glewRasterPos3f) -#define glRasterPos3fv GLEW_GET_FUN(__glewRasterPos3fv) -#define glRasterPos3i GLEW_GET_FUN(__glewRasterPos3i) -#define glRasterPos3iv GLEW_GET_FUN(__glewRasterPos3iv) -#define glRasterPos3s GLEW_GET_FUN(__glewRasterPos3s) -#define glRasterPos3sv GLEW_GET_FUN(__glewRasterPos3sv) -#define glRasterPos4d GLEW_GET_FUN(__glewRasterPos4d) -#define glRasterPos4dv GLEW_GET_FUN(__glewRasterPos4dv) -#define glRasterPos4f GLEW_GET_FUN(__glewRasterPos4f) -#define glRasterPos4fv GLEW_GET_FUN(__glewRasterPos4fv) -#define glRasterPos4i GLEW_GET_FUN(__glewRasterPos4i) -#define glRasterPos4iv GLEW_GET_FUN(__glewRasterPos4iv) -#define glRasterPos4s GLEW_GET_FUN(__glewRasterPos4s) -#define glRasterPos4sv GLEW_GET_FUN(__glewRasterPos4sv) -#define glReadBuffer GLEW_GET_FUN(__glewReadBuffer) -#define glReadPixels GLEW_GET_FUN(__glewReadPixels) -#define glRectd GLEW_GET_FUN(__glewRectd) -#define glRectdv GLEW_GET_FUN(__glewRectdv) -#define glRectf GLEW_GET_FUN(__glewRectf) -#define glRectfv GLEW_GET_FUN(__glewRectfv) -#define glRecti GLEW_GET_FUN(__glewRecti) -#define glRectiv GLEW_GET_FUN(__glewRectiv) -#define glRects GLEW_GET_FUN(__glewRects) -#define glRectsv GLEW_GET_FUN(__glewRectsv) -#define glRenderMode GLEW_GET_FUN(__glewRenderMode) -#define glRotated GLEW_GET_FUN(__glewRotated) -#define glRotatef GLEW_GET_FUN(__glewRotatef) -#define glScaled GLEW_GET_FUN(__glewScaled) -#define glScalef GLEW_GET_FUN(__glewScalef) -#define glScissor GLEW_GET_FUN(__glewScissor) -#define glSelectBuffer GLEW_GET_FUN(__glewSelectBuffer) -#define glShadeModel GLEW_GET_FUN(__glewShadeModel) -#define glStencilFunc GLEW_GET_FUN(__glewStencilFunc) -#define glStencilMask GLEW_GET_FUN(__glewStencilMask) -#define glStencilOp GLEW_GET_FUN(__glewStencilOp) -#define glTexCoord1d GLEW_GET_FUN(__glewTexCoord1d) -#define glTexCoord1dv GLEW_GET_FUN(__glewTexCoord1dv) -#define glTexCoord1f GLEW_GET_FUN(__glewTexCoord1f) -#define glTexCoord1fv GLEW_GET_FUN(__glewTexCoord1fv) -#define glTexCoord1i GLEW_GET_FUN(__glewTexCoord1i) -#define glTexCoord1iv GLEW_GET_FUN(__glewTexCoord1iv) -#define glTexCoord1s GLEW_GET_FUN(__glewTexCoord1s) -#define glTexCoord1sv GLEW_GET_FUN(__glewTexCoord1sv) -#define glTexCoord2d GLEW_GET_FUN(__glewTexCoord2d) -#define glTexCoord2dv GLEW_GET_FUN(__glewTexCoord2dv) -#define glTexCoord2f GLEW_GET_FUN(__glewTexCoord2f) -#define glTexCoord2fv GLEW_GET_FUN(__glewTexCoord2fv) -#define glTexCoord2i GLEW_GET_FUN(__glewTexCoord2i) -#define glTexCoord2iv GLEW_GET_FUN(__glewTexCoord2iv) -#define glTexCoord2s GLEW_GET_FUN(__glewTexCoord2s) -#define glTexCoord2sv GLEW_GET_FUN(__glewTexCoord2sv) -#define glTexCoord3d GLEW_GET_FUN(__glewTexCoord3d) -#define glTexCoord3dv GLEW_GET_FUN(__glewTexCoord3dv) -#define glTexCoord3f GLEW_GET_FUN(__glewTexCoord3f) -#define glTexCoord3fv GLEW_GET_FUN(__glewTexCoord3fv) -#define glTexCoord3i GLEW_GET_FUN(__glewTexCoord3i) -#define glTexCoord3iv GLEW_GET_FUN(__glewTexCoord3iv) -#define glTexCoord3s GLEW_GET_FUN(__glewTexCoord3s) -#define glTexCoord3sv GLEW_GET_FUN(__glewTexCoord3sv) -#define glTexCoord4d GLEW_GET_FUN(__glewTexCoord4d) -#define glTexCoord4dv GLEW_GET_FUN(__glewTexCoord4dv) -#define glTexCoord4f GLEW_GET_FUN(__glewTexCoord4f) -#define glTexCoord4fv GLEW_GET_FUN(__glewTexCoord4fv) -#define glTexCoord4i GLEW_GET_FUN(__glewTexCoord4i) -#define glTexCoord4iv GLEW_GET_FUN(__glewTexCoord4iv) -#define glTexCoord4s GLEW_GET_FUN(__glewTexCoord4s) -#define glTexCoord4sv GLEW_GET_FUN(__glewTexCoord4sv) -#define glTexCoordPointer GLEW_GET_FUN(__glewTexCoordPointer) -#define glTexEnvf GLEW_GET_FUN(__glewTexEnvf) -#define glTexEnvfv GLEW_GET_FUN(__glewTexEnvfv) -#define glTexEnvi GLEW_GET_FUN(__glewTexEnvi) -#define glTexEnviv GLEW_GET_FUN(__glewTexEnviv) -#define glTexGend GLEW_GET_FUN(__glewTexGend) -#define glTexGendv GLEW_GET_FUN(__glewTexGendv) -#define glTexGenf GLEW_GET_FUN(__glewTexGenf) -#define glTexGenfv GLEW_GET_FUN(__glewTexGenfv) -#define glTexGeni GLEW_GET_FUN(__glewTexGeni) -#define glTexGeniv GLEW_GET_FUN(__glewTexGeniv) -#define glTexImage1D GLEW_GET_FUN(__glewTexImage1D) -#define glTexImage2D GLEW_GET_FUN(__glewTexImage2D) -#define glTexParameterf GLEW_GET_FUN(__glewTexParameterf) -#define glTexParameterfv GLEW_GET_FUN(__glewTexParameterfv) -#define glTexParameteri GLEW_GET_FUN(__glewTexParameteri) -#define glTexParameteriv GLEW_GET_FUN(__glewTexParameteriv) -#define glTexSubImage1D GLEW_GET_FUN(__glewTexSubImage1D) -#define glTexSubImage2D GLEW_GET_FUN(__glewTexSubImage2D) -#define glTranslated GLEW_GET_FUN(__glewTranslated) -#define glTranslatef GLEW_GET_FUN(__glewTranslatef) -#define glVertex2d GLEW_GET_FUN(__glewVertex2d) -#define glVertex2dv GLEW_GET_FUN(__glewVertex2dv) -#define glVertex2f GLEW_GET_FUN(__glewVertex2f) -#define glVertex2fv GLEW_GET_FUN(__glewVertex2fv) -#define glVertex2i GLEW_GET_FUN(__glewVertex2i) -#define glVertex2iv GLEW_GET_FUN(__glewVertex2iv) -#define glVertex2s GLEW_GET_FUN(__glewVertex2s) -#define glVertex2sv GLEW_GET_FUN(__glewVertex2sv) -#define glVertex3d GLEW_GET_FUN(__glewVertex3d) -#define glVertex3dv GLEW_GET_FUN(__glewVertex3dv) -#define glVertex3f GLEW_GET_FUN(__glewVertex3f) -#define glVertex3fv GLEW_GET_FUN(__glewVertex3fv) -#define glVertex3i GLEW_GET_FUN(__glewVertex3i) -#define glVertex3iv GLEW_GET_FUN(__glewVertex3iv) -#define glVertex3s GLEW_GET_FUN(__glewVertex3s) -#define glVertex3sv GLEW_GET_FUN(__glewVertex3sv) -#define glVertex4d GLEW_GET_FUN(__glewVertex4d) -#define glVertex4dv GLEW_GET_FUN(__glewVertex4dv) -#define glVertex4f GLEW_GET_FUN(__glewVertex4f) -#define glVertex4fv GLEW_GET_FUN(__glewVertex4fv) -#define glVertex4i GLEW_GET_FUN(__glewVertex4i) -#define glVertex4iv GLEW_GET_FUN(__glewVertex4iv) -#define glVertex4s GLEW_GET_FUN(__glewVertex4s) -#define glVertex4sv GLEW_GET_FUN(__glewVertex4sv) -#define glVertexPointer GLEW_GET_FUN(__glewVertexPointer) -#define glViewport GLEW_GET_FUN(__glewViewport) - - -#else //GLEW_INIT_OPENGL11_FUNCTIONS - -GLAPI void GLAPIENTRY glAccum (GLenum op, GLfloat value); -GLAPI void GLAPIENTRY glAlphaFunc (GLenum func, GLclampf ref); -GLAPI GLboolean GLAPIENTRY glAreTexturesResident (GLsizei n, const GLuint *textures, GLboolean *residences); -GLAPI void GLAPIENTRY glArrayElement (GLint i); -GLAPI void GLAPIENTRY glBegin (GLenum mode); -GLAPI void GLAPIENTRY glBindTexture (GLenum target, GLuint texture); -GLAPI void GLAPIENTRY glBitmap (GLsizei width, GLsizei height, GLfloat xorig, GLfloat yorig, GLfloat xmove, GLfloat ymove, const GLubyte *bitmap); -GLAPI void GLAPIENTRY glBlendFunc (GLenum sfactor, GLenum dfactor); -GLAPI void GLAPIENTRY glCallList (GLuint list); -GLAPI void GLAPIENTRY glCallLists (GLsizei n, GLenum type, const GLvoid *lists); -GLAPI void GLAPIENTRY glClear (GLbitfield mask); -GLAPI void GLAPIENTRY glClearAccum (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); -GLAPI void GLAPIENTRY glClearColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -GLAPI void GLAPIENTRY glClearDepth (GLclampd depth); -GLAPI void GLAPIENTRY glClearIndex (GLfloat c); -GLAPI void GLAPIENTRY glClearStencil (GLint s); -GLAPI void GLAPIENTRY glClipPlane (GLenum plane, const GLdouble *equation); -GLAPI void GLAPIENTRY glColor3b (GLbyte red, GLbyte green, GLbyte blue); -GLAPI void GLAPIENTRY glColor3bv (const GLbyte *v); -GLAPI void GLAPIENTRY glColor3d (GLdouble red, GLdouble green, GLdouble blue); -GLAPI void GLAPIENTRY glColor3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glColor3f (GLfloat red, GLfloat green, GLfloat blue); -GLAPI void GLAPIENTRY glColor3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glColor3i (GLint red, GLint green, GLint blue); -GLAPI void GLAPIENTRY glColor3iv (const GLint *v); -GLAPI void GLAPIENTRY glColor3s (GLshort red, GLshort green, GLshort blue); -GLAPI void GLAPIENTRY glColor3sv (const GLshort *v); -GLAPI void GLAPIENTRY glColor3ub (GLubyte red, GLubyte green, GLubyte blue); -GLAPI void GLAPIENTRY glColor3ubv (const GLubyte *v); -GLAPI void GLAPIENTRY glColor3ui (GLuint red, GLuint green, GLuint blue); -GLAPI void GLAPIENTRY glColor3uiv (const GLuint *v); -GLAPI void GLAPIENTRY glColor3us (GLushort red, GLushort green, GLushort blue); -GLAPI void GLAPIENTRY glColor3usv (const GLushort *v); -GLAPI void GLAPIENTRY glColor4b (GLbyte red, GLbyte green, GLbyte blue, GLbyte alpha); -GLAPI void GLAPIENTRY glColor4bv (const GLbyte *v); -GLAPI void GLAPIENTRY glColor4d (GLdouble red, GLdouble green, GLdouble blue, GLdouble alpha); -GLAPI void GLAPIENTRY glColor4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glColor4f (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); -GLAPI void GLAPIENTRY glColor4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glColor4i (GLint red, GLint green, GLint blue, GLint alpha); -GLAPI void GLAPIENTRY glColor4iv (const GLint *v); -GLAPI void GLAPIENTRY glColor4s (GLshort red, GLshort green, GLshort blue, GLshort alpha); -GLAPI void GLAPIENTRY glColor4sv (const GLshort *v); -GLAPI void GLAPIENTRY glColor4ub (GLubyte red, GLubyte green, GLubyte blue, GLubyte alpha); -GLAPI void GLAPIENTRY glColor4ubv (const GLubyte *v); -GLAPI void GLAPIENTRY glColor4ui (GLuint red, GLuint green, GLuint blue, GLuint alpha); -GLAPI void GLAPIENTRY glColor4uiv (const GLuint *v); -GLAPI void GLAPIENTRY glColor4us (GLushort red, GLushort green, GLushort blue, GLushort alpha); -GLAPI void GLAPIENTRY glColor4usv (const GLushort *v); -GLAPI void GLAPIENTRY glColorMask (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); -GLAPI void GLAPIENTRY glColorMaterial (GLenum face, GLenum mode); -GLAPI void GLAPIENTRY glColorPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glCopyPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum type); -GLAPI void GLAPIENTRY glCopyTexImage1D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLint border); -GLAPI void GLAPIENTRY glCopyTexImage2D (GLenum target, GLint level, GLenum internalFormat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -GLAPI void GLAPIENTRY glCopyTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -GLAPI void GLAPIENTRY glCopyTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -GLAPI void GLAPIENTRY glCullFace (GLenum mode); -GLAPI void GLAPIENTRY glDeleteLists (GLuint list, GLsizei range); -GLAPI void GLAPIENTRY glDeleteTextures (GLsizei n, const GLuint *textures); -GLAPI void GLAPIENTRY glDepthFunc (GLenum func); -GLAPI void GLAPIENTRY glDepthMask (GLboolean flag); -GLAPI void GLAPIENTRY glDepthRange (GLclampd zNear, GLclampd zFar); -GLAPI void GLAPIENTRY glDisable (GLenum cap); -GLAPI void GLAPIENTRY glDisableClientState (GLenum array); -GLAPI void GLAPIENTRY glDrawArrays (GLenum mode, GLint first, GLsizei count); -GLAPI void GLAPIENTRY glDrawBuffer (GLenum mode); -GLAPI void GLAPIENTRY glDrawElements (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices); -GLAPI void GLAPIENTRY glDrawPixels (GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glEdgeFlag (GLboolean flag); -GLAPI void GLAPIENTRY glEdgeFlagPointer (GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glEdgeFlagv (const GLboolean *flag); -GLAPI void GLAPIENTRY glEnable (GLenum cap); -GLAPI void GLAPIENTRY glEnableClientState (GLenum array); -GLAPI void GLAPIENTRY glEnd (void); -GLAPI void GLAPIENTRY glEndList (void); -GLAPI void GLAPIENTRY glEvalCoord1d (GLdouble u); -GLAPI void GLAPIENTRY glEvalCoord1dv (const GLdouble *u); -GLAPI void GLAPIENTRY glEvalCoord1f (GLfloat u); -GLAPI void GLAPIENTRY glEvalCoord1fv (const GLfloat *u); -GLAPI void GLAPIENTRY glEvalCoord2d (GLdouble u, GLdouble v); -GLAPI void GLAPIENTRY glEvalCoord2dv (const GLdouble *u); -GLAPI void GLAPIENTRY glEvalCoord2f (GLfloat u, GLfloat v); -GLAPI void GLAPIENTRY glEvalCoord2fv (const GLfloat *u); -GLAPI void GLAPIENTRY glEvalMesh1 (GLenum mode, GLint i1, GLint i2); -GLAPI void GLAPIENTRY glEvalMesh2 (GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2); -GLAPI void GLAPIENTRY glEvalPoint1 (GLint i); -GLAPI void GLAPIENTRY glEvalPoint2 (GLint i, GLint j); -GLAPI void GLAPIENTRY glFeedbackBuffer (GLsizei size, GLenum type, GLfloat *buffer); -GLAPI void GLAPIENTRY glFinish (void); -GLAPI void GLAPIENTRY glFlush (void); -GLAPI void GLAPIENTRY glFogf (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glFogfv (GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glFogi (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glFogiv (GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glFrontFace (GLenum mode); -GLAPI void GLAPIENTRY glFrustum (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); -GLAPI GLuint GLAPIENTRY glGenLists (GLsizei range); -GLAPI void GLAPIENTRY glGenTextures (GLsizei n, GLuint *textures); -GLAPI void GLAPIENTRY glGetBooleanv (GLenum pname, GLboolean *params); -GLAPI void GLAPIENTRY glGetClipPlane (GLenum plane, GLdouble *equation); -GLAPI void GLAPIENTRY glGetDoublev (GLenum pname, GLdouble *params); -GLAPI GLenum GLAPIENTRY glGetError (void); -GLAPI void GLAPIENTRY glGetFloatv (GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetIntegerv (GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetLightfv (GLenum light, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetLightiv (GLenum light, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetMapdv (GLenum target, GLenum query, GLdouble *v); -GLAPI void GLAPIENTRY glGetMapfv (GLenum target, GLenum query, GLfloat *v); -GLAPI void GLAPIENTRY glGetMapiv (GLenum target, GLenum query, GLint *v); -GLAPI void GLAPIENTRY glGetMaterialfv (GLenum face, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetMaterialiv (GLenum face, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetPixelMapfv (GLenum map, GLfloat *values); -GLAPI void GLAPIENTRY glGetPixelMapuiv (GLenum map, GLuint *values); -GLAPI void GLAPIENTRY glGetPixelMapusv (GLenum map, GLushort *values); -GLAPI void GLAPIENTRY glGetPointerv (GLenum pname, GLvoid* *params); -GLAPI void GLAPIENTRY glGetPolygonStipple (GLubyte *mask); -GLAPI const GLubyte * GLAPIENTRY glGetString (GLenum name); -GLAPI void GLAPIENTRY glGetTexEnvfv (GLenum target, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexEnviv (GLenum target, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetTexGendv (GLenum coord, GLenum pname, GLdouble *params); -GLAPI void GLAPIENTRY glGetTexGenfv (GLenum coord, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexGeniv (GLenum coord, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetTexImage (GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); -GLAPI void GLAPIENTRY glGetTexLevelParameterfv (GLenum target, GLint level, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexLevelParameteriv (GLenum target, GLint level, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glGetTexParameterfv (GLenum target, GLenum pname, GLfloat *params); -GLAPI void GLAPIENTRY glGetTexParameteriv (GLenum target, GLenum pname, GLint *params); -GLAPI void GLAPIENTRY glHint (GLenum target, GLenum mode); -GLAPI void GLAPIENTRY glIndexMask (GLuint mask); -GLAPI void GLAPIENTRY glIndexPointer (GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glIndexd (GLdouble c); -GLAPI void GLAPIENTRY glIndexdv (const GLdouble *c); -GLAPI void GLAPIENTRY glIndexf (GLfloat c); -GLAPI void GLAPIENTRY glIndexfv (const GLfloat *c); -GLAPI void GLAPIENTRY glIndexi (GLint c); -GLAPI void GLAPIENTRY glIndexiv (const GLint *c); -GLAPI void GLAPIENTRY glIndexs (GLshort c); -GLAPI void GLAPIENTRY glIndexsv (const GLshort *c); -GLAPI void GLAPIENTRY glIndexub (GLubyte c); -GLAPI void GLAPIENTRY glIndexubv (const GLubyte *c); -GLAPI void GLAPIENTRY glInitNames (void); -GLAPI void GLAPIENTRY glInterleavedArrays (GLenum format, GLsizei stride, const GLvoid *pointer); -GLAPI GLboolean GLAPIENTRY glIsEnabled (GLenum cap); -GLAPI GLboolean GLAPIENTRY glIsList (GLuint list); -GLAPI GLboolean GLAPIENTRY glIsTexture (GLuint texture); -GLAPI void GLAPIENTRY glLightModelf (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glLightModelfv (GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glLightModeli (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glLightModeliv (GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glLightf (GLenum light, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glLightfv (GLenum light, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glLighti (GLenum light, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glLightiv (GLenum light, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glLineStipple (GLint factor, GLushort pattern); -GLAPI void GLAPIENTRY glLineWidth (GLfloat width); -GLAPI void GLAPIENTRY glListBase (GLuint base); -GLAPI void GLAPIENTRY glLoadIdentity (void); -GLAPI void GLAPIENTRY glLoadMatrixd (const GLdouble *m); -GLAPI void GLAPIENTRY glLoadMatrixf (const GLfloat *m); -GLAPI void GLAPIENTRY glLoadName (GLuint name); -GLAPI void GLAPIENTRY glLogicOp (GLenum opcode); -GLAPI void GLAPIENTRY glMap1d (GLenum target, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); -GLAPI void GLAPIENTRY glMap1f (GLenum target, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); -GLAPI void GLAPIENTRY glMap2d (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); -GLAPI void GLAPIENTRY glMap2f (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); -GLAPI void GLAPIENTRY glMapGrid1d (GLint un, GLdouble u1, GLdouble u2); -GLAPI void GLAPIENTRY glMapGrid1f (GLint un, GLfloat u1, GLfloat u2); -GLAPI void GLAPIENTRY glMapGrid2d (GLint un, GLdouble u1, GLdouble u2, GLint vn, GLdouble v1, GLdouble v2); -GLAPI void GLAPIENTRY glMapGrid2f (GLint un, GLfloat u1, GLfloat u2, GLint vn, GLfloat v1, GLfloat v2); -GLAPI void GLAPIENTRY glMaterialf (GLenum face, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glMaterialfv (GLenum face, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glMateriali (GLenum face, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glMaterialiv (GLenum face, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glMatrixMode (GLenum mode); -GLAPI void GLAPIENTRY glMultMatrixd (const GLdouble *m); -GLAPI void GLAPIENTRY glMultMatrixf (const GLfloat *m); -GLAPI void GLAPIENTRY glNewList (GLuint list, GLenum mode); -GLAPI void GLAPIENTRY glNormal3b (GLbyte nx, GLbyte ny, GLbyte nz); -GLAPI void GLAPIENTRY glNormal3bv (const GLbyte *v); -GLAPI void GLAPIENTRY glNormal3d (GLdouble nx, GLdouble ny, GLdouble nz); -GLAPI void GLAPIENTRY glNormal3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glNormal3f (GLfloat nx, GLfloat ny, GLfloat nz); -GLAPI void GLAPIENTRY glNormal3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glNormal3i (GLint nx, GLint ny, GLint nz); -GLAPI void GLAPIENTRY glNormal3iv (const GLint *v); -GLAPI void GLAPIENTRY glNormal3s (GLshort nx, GLshort ny, GLshort nz); -GLAPI void GLAPIENTRY glNormal3sv (const GLshort *v); -GLAPI void GLAPIENTRY glNormalPointer (GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glOrtho (GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); -GLAPI void GLAPIENTRY glPassThrough (GLfloat token); -GLAPI void GLAPIENTRY glPixelMapfv (GLenum map, GLsizei mapsize, const GLfloat *values); -GLAPI void GLAPIENTRY glPixelMapuiv (GLenum map, GLsizei mapsize, const GLuint *values); -GLAPI void GLAPIENTRY glPixelMapusv (GLenum map, GLsizei mapsize, const GLushort *values); -GLAPI void GLAPIENTRY glPixelStoref (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glPixelStorei (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glPixelTransferf (GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glPixelTransferi (GLenum pname, GLint param); -GLAPI void GLAPIENTRY glPixelZoom (GLfloat xfactor, GLfloat yfactor); -GLAPI void GLAPIENTRY glPointSize (GLfloat size); -GLAPI void GLAPIENTRY glPolygonMode (GLenum face, GLenum mode); -GLAPI void GLAPIENTRY glPolygonOffset (GLfloat factor, GLfloat units); -GLAPI void GLAPIENTRY glPolygonStipple (const GLubyte *mask); -GLAPI void GLAPIENTRY glPopAttrib (void); -GLAPI void GLAPIENTRY glPopClientAttrib (void); -GLAPI void GLAPIENTRY glPopMatrix (void); -GLAPI void GLAPIENTRY glPopName (void); -GLAPI void GLAPIENTRY glPrioritizeTextures (GLsizei n, const GLuint *textures, const GLclampf *priorities); -GLAPI void GLAPIENTRY glPushAttrib (GLbitfield mask); -GLAPI void GLAPIENTRY glPushClientAttrib (GLbitfield mask); -GLAPI void GLAPIENTRY glPushMatrix (void); -GLAPI void GLAPIENTRY glPushName (GLuint name); -GLAPI void GLAPIENTRY glRasterPos2d (GLdouble x, GLdouble y); -GLAPI void GLAPIENTRY glRasterPos2dv (const GLdouble *v); -GLAPI void GLAPIENTRY glRasterPos2f (GLfloat x, GLfloat y); -GLAPI void GLAPIENTRY glRasterPos2fv (const GLfloat *v); -GLAPI void GLAPIENTRY glRasterPos2i (GLint x, GLint y); -GLAPI void GLAPIENTRY glRasterPos2iv (const GLint *v); -GLAPI void GLAPIENTRY glRasterPos2s (GLshort x, GLshort y); -GLAPI void GLAPIENTRY glRasterPos2sv (const GLshort *v); -GLAPI void GLAPIENTRY glRasterPos3d (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glRasterPos3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glRasterPos3f (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glRasterPos3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glRasterPos3i (GLint x, GLint y, GLint z); -GLAPI void GLAPIENTRY glRasterPos3iv (const GLint *v); -GLAPI void GLAPIENTRY glRasterPos3s (GLshort x, GLshort y, GLshort z); -GLAPI void GLAPIENTRY glRasterPos3sv (const GLshort *v); -GLAPI void GLAPIENTRY glRasterPos4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -GLAPI void GLAPIENTRY glRasterPos4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glRasterPos4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -GLAPI void GLAPIENTRY glRasterPos4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glRasterPos4i (GLint x, GLint y, GLint z, GLint w); -GLAPI void GLAPIENTRY glRasterPos4iv (const GLint *v); -GLAPI void GLAPIENTRY glRasterPos4s (GLshort x, GLshort y, GLshort z, GLshort w); -GLAPI void GLAPIENTRY glRasterPos4sv (const GLshort *v); -GLAPI void GLAPIENTRY glReadBuffer (GLenum mode); -GLAPI void GLAPIENTRY glReadPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid *pixels); -GLAPI void GLAPIENTRY glRectd (GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2); -GLAPI void GLAPIENTRY glRectdv (const GLdouble *v1, const GLdouble *v2); -GLAPI void GLAPIENTRY glRectf (GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2); -GLAPI void GLAPIENTRY glRectfv (const GLfloat *v1, const GLfloat *v2); -GLAPI void GLAPIENTRY glRecti (GLint x1, GLint y1, GLint x2, GLint y2); -GLAPI void GLAPIENTRY glRectiv (const GLint *v1, const GLint *v2); -GLAPI void GLAPIENTRY glRects (GLshort x1, GLshort y1, GLshort x2, GLshort y2); -GLAPI void GLAPIENTRY glRectsv (const GLshort *v1, const GLshort *v2); -GLAPI GLint GLAPIENTRY glRenderMode (GLenum mode); -GLAPI void GLAPIENTRY glRotated (GLdouble angle, GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glRotatef (GLfloat angle, GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glScaled (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glScalef (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glScissor (GLint x, GLint y, GLsizei width, GLsizei height); -GLAPI void GLAPIENTRY glSelectBuffer (GLsizei size, GLuint *buffer); -GLAPI void GLAPIENTRY glShadeModel (GLenum mode); -GLAPI void GLAPIENTRY glStencilFunc (GLenum func, GLint ref, GLuint mask); -GLAPI void GLAPIENTRY glStencilMask (GLuint mask); -GLAPI void GLAPIENTRY glStencilOp (GLenum fail, GLenum zfail, GLenum zpass); -GLAPI void GLAPIENTRY glTexCoord1d (GLdouble s); -GLAPI void GLAPIENTRY glTexCoord1dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord1f (GLfloat s); -GLAPI void GLAPIENTRY glTexCoord1fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord1i (GLint s); -GLAPI void GLAPIENTRY glTexCoord1iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord1s (GLshort s); -GLAPI void GLAPIENTRY glTexCoord1sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoord2d (GLdouble s, GLdouble t); -GLAPI void GLAPIENTRY glTexCoord2dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord2f (GLfloat s, GLfloat t); -GLAPI void GLAPIENTRY glTexCoord2fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord2i (GLint s, GLint t); -GLAPI void GLAPIENTRY glTexCoord2iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord2s (GLshort s, GLshort t); -GLAPI void GLAPIENTRY glTexCoord2sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoord3d (GLdouble s, GLdouble t, GLdouble r); -GLAPI void GLAPIENTRY glTexCoord3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord3f (GLfloat s, GLfloat t, GLfloat r); -GLAPI void GLAPIENTRY glTexCoord3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord3i (GLint s, GLint t, GLint r); -GLAPI void GLAPIENTRY glTexCoord3iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord3s (GLshort s, GLshort t, GLshort r); -GLAPI void GLAPIENTRY glTexCoord3sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoord4d (GLdouble s, GLdouble t, GLdouble r, GLdouble q); -GLAPI void GLAPIENTRY glTexCoord4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glTexCoord4f (GLfloat s, GLfloat t, GLfloat r, GLfloat q); -GLAPI void GLAPIENTRY glTexCoord4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glTexCoord4i (GLint s, GLint t, GLint r, GLint q); -GLAPI void GLAPIENTRY glTexCoord4iv (const GLint *v); -GLAPI void GLAPIENTRY glTexCoord4s (GLshort s, GLshort t, GLshort r, GLshort q); -GLAPI void GLAPIENTRY glTexCoord4sv (const GLshort *v); -GLAPI void GLAPIENTRY glTexCoordPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glTexEnvf (GLenum target, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glTexEnvfv (GLenum target, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glTexEnvi (GLenum target, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glTexEnviv (GLenum target, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glTexGend (GLenum coord, GLenum pname, GLdouble param); -GLAPI void GLAPIENTRY glTexGendv (GLenum coord, GLenum pname, const GLdouble *params); -GLAPI void GLAPIENTRY glTexGenf (GLenum coord, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glTexGenfv (GLenum coord, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glTexGeni (GLenum coord, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glTexGeniv (GLenum coord, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glTexImage1D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTexImage2D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTexParameterf (GLenum target, GLenum pname, GLfloat param); -GLAPI void GLAPIENTRY glTexParameterfv (GLenum target, GLenum pname, const GLfloat *params); -GLAPI void GLAPIENTRY glTexParameteri (GLenum target, GLenum pname, GLint param); -GLAPI void GLAPIENTRY glTexParameteriv (GLenum target, GLenum pname, const GLint *params); -GLAPI void GLAPIENTRY glTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -GLAPI void GLAPIENTRY glTranslated (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glTranslatef (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glVertex2d (GLdouble x, GLdouble y); -GLAPI void GLAPIENTRY glVertex2dv (const GLdouble *v); -GLAPI void GLAPIENTRY glVertex2f (GLfloat x, GLfloat y); -GLAPI void GLAPIENTRY glVertex2fv (const GLfloat *v); -GLAPI void GLAPIENTRY glVertex2i (GLint x, GLint y); -GLAPI void GLAPIENTRY glVertex2iv (const GLint *v); -GLAPI void GLAPIENTRY glVertex2s (GLshort x, GLshort y); -GLAPI void GLAPIENTRY glVertex2sv (const GLshort *v); -GLAPI void GLAPIENTRY glVertex3d (GLdouble x, GLdouble y, GLdouble z); -GLAPI void GLAPIENTRY glVertex3dv (const GLdouble *v); -GLAPI void GLAPIENTRY glVertex3f (GLfloat x, GLfloat y, GLfloat z); -GLAPI void GLAPIENTRY glVertex3fv (const GLfloat *v); -GLAPI void GLAPIENTRY glVertex3i (GLint x, GLint y, GLint z); -GLAPI void GLAPIENTRY glVertex3iv (const GLint *v); -GLAPI void GLAPIENTRY glVertex3s (GLshort x, GLshort y, GLshort z); -GLAPI void GLAPIENTRY glVertex3sv (const GLshort *v); -GLAPI void GLAPIENTRY glVertex4d (GLdouble x, GLdouble y, GLdouble z, GLdouble w); -GLAPI void GLAPIENTRY glVertex4dv (const GLdouble *v); -GLAPI void GLAPIENTRY glVertex4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -GLAPI void GLAPIENTRY glVertex4fv (const GLfloat *v); -GLAPI void GLAPIENTRY glVertex4i (GLint x, GLint y, GLint z, GLint w); -GLAPI void GLAPIENTRY glVertex4iv (const GLint *v); -GLAPI void GLAPIENTRY glVertex4s (GLshort x, GLshort y, GLshort z, GLshort w); -GLAPI void GLAPIENTRY glVertex4sv (const GLshort *v); -GLAPI void GLAPIENTRY glVertexPointer (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -GLAPI void GLAPIENTRY glViewport (GLint x, GLint y, GLsizei width, GLsizei height); -#endif //GLEW_INIT_OPENGL11_FUNCTIONS -#define GLEW_VERSION_1_1 GLEW_GET_VAR(__GLEW_VERSION_1_1) - -#endif /* GL_VERSION_1_1 */ - -/* ---------------------------------- GLU ---------------------------------- */ - -#ifndef GLEW_NO_GLU -/* this is where we can safely include GLU */ -# if defined(__APPLE__) && defined(__MACH__) -# include -# else -# include -# endif -#endif - -/* ----------------------------- GL_VERSION_1_2 ---------------------------- */ - -#ifndef GL_VERSION_1_2 -#define GL_VERSION_1_2 1 - -#define GL_SMOOTH_POINT_SIZE_RANGE 0x0B12 -#define GL_SMOOTH_POINT_SIZE_GRANULARITY 0x0B13 -#define GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22 -#define GL_SMOOTH_LINE_WIDTH_GRANULARITY 0x0B23 -#define GL_UNSIGNED_BYTE_3_3_2 0x8032 -#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 -#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 -#define GL_UNSIGNED_INT_8_8_8_8 0x8035 -#define GL_UNSIGNED_INT_10_10_10_2 0x8036 -#define GL_RESCALE_NORMAL 0x803A -#define GL_TEXTURE_BINDING_3D 0x806A -#define GL_PACK_SKIP_IMAGES 0x806B -#define GL_PACK_IMAGE_HEIGHT 0x806C -#define GL_UNPACK_SKIP_IMAGES 0x806D -#define GL_UNPACK_IMAGE_HEIGHT 0x806E -#define GL_TEXTURE_3D 0x806F -#define GL_PROXY_TEXTURE_3D 0x8070 -#define GL_TEXTURE_DEPTH 0x8071 -#define GL_TEXTURE_WRAP_R 0x8072 -#define GL_MAX_3D_TEXTURE_SIZE 0x8073 -#define GL_BGR 0x80E0 -#define GL_BGRA 0x80E1 -#define GL_MAX_ELEMENTS_VERTICES 0x80E8 -#define GL_MAX_ELEMENTS_INDICES 0x80E9 -#define GL_CLAMP_TO_EDGE 0x812F -#define GL_TEXTURE_MIN_LOD 0x813A -#define GL_TEXTURE_MAX_LOD 0x813B -#define GL_TEXTURE_BASE_LEVEL 0x813C -#define GL_TEXTURE_MAX_LEVEL 0x813D -#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 -#define GL_SINGLE_COLOR 0x81F9 -#define GL_SEPARATE_SPECULAR_COLOR 0x81FA -#define GL_UNSIGNED_BYTE_2_3_3_REV 0x8362 -#define GL_UNSIGNED_SHORT_5_6_5 0x8363 -#define GL_UNSIGNED_SHORT_5_6_5_REV 0x8364 -#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 -#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 -#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 -#define GL_ALIASED_POINT_SIZE_RANGE 0x846D -#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E - -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); - -#define glCopyTexSubImage3D GLEW_GET_FUN(__glewCopyTexSubImage3D) -#define glDrawRangeElements GLEW_GET_FUN(__glewDrawRangeElements) -#define glTexImage3D GLEW_GET_FUN(__glewTexImage3D) -#define glTexSubImage3D GLEW_GET_FUN(__glewTexSubImage3D) - -#define GLEW_VERSION_1_2 GLEW_GET_VAR(__GLEW_VERSION_1_2) - -#endif /* GL_VERSION_1_2 */ - -/* ---------------------------- GL_VERSION_1_2_1 --------------------------- */ - -#ifndef GL_VERSION_1_2_1 -#define GL_VERSION_1_2_1 1 - -#define GLEW_VERSION_1_2_1 GLEW_GET_VAR(__GLEW_VERSION_1_2_1) - -#endif /* GL_VERSION_1_2_1 */ - -/* ----------------------------- GL_VERSION_1_3 ---------------------------- */ - -#ifndef GL_VERSION_1_3 -#define GL_VERSION_1_3 1 - -#define GL_MULTISAMPLE 0x809D -#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE 0x809F -#define GL_SAMPLE_COVERAGE 0x80A0 -#define GL_SAMPLE_BUFFERS 0x80A8 -#define GL_SAMPLES 0x80A9 -#define GL_SAMPLE_COVERAGE_VALUE 0x80AA -#define GL_SAMPLE_COVERAGE_INVERT 0x80AB -#define GL_CLAMP_TO_BORDER 0x812D -#define GL_TEXTURE0 0x84C0 -#define GL_TEXTURE1 0x84C1 -#define GL_TEXTURE2 0x84C2 -#define GL_TEXTURE3 0x84C3 -#define GL_TEXTURE4 0x84C4 -#define GL_TEXTURE5 0x84C5 -#define GL_TEXTURE6 0x84C6 -#define GL_TEXTURE7 0x84C7 -#define GL_TEXTURE8 0x84C8 -#define GL_TEXTURE9 0x84C9 -#define GL_TEXTURE10 0x84CA -#define GL_TEXTURE11 0x84CB -#define GL_TEXTURE12 0x84CC -#define GL_TEXTURE13 0x84CD -#define GL_TEXTURE14 0x84CE -#define GL_TEXTURE15 0x84CF -#define GL_TEXTURE16 0x84D0 -#define GL_TEXTURE17 0x84D1 -#define GL_TEXTURE18 0x84D2 -#define GL_TEXTURE19 0x84D3 -#define GL_TEXTURE20 0x84D4 -#define GL_TEXTURE21 0x84D5 -#define GL_TEXTURE22 0x84D6 -#define GL_TEXTURE23 0x84D7 -#define GL_TEXTURE24 0x84D8 -#define GL_TEXTURE25 0x84D9 -#define GL_TEXTURE26 0x84DA -#define GL_TEXTURE27 0x84DB -#define GL_TEXTURE28 0x84DC -#define GL_TEXTURE29 0x84DD -#define GL_TEXTURE30 0x84DE -#define GL_TEXTURE31 0x84DF -#define GL_ACTIVE_TEXTURE 0x84E0 -#define GL_CLIENT_ACTIVE_TEXTURE 0x84E1 -#define GL_MAX_TEXTURE_UNITS 0x84E2 -#define GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 -#define GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 -#define GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 -#define GL_TRANSPOSE_COLOR_MATRIX 0x84E6 -#define GL_SUBTRACT 0x84E7 -#define GL_COMPRESSED_ALPHA 0x84E9 -#define GL_COMPRESSED_LUMINANCE 0x84EA -#define GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB -#define GL_COMPRESSED_INTENSITY 0x84EC -#define GL_COMPRESSED_RGB 0x84ED -#define GL_COMPRESSED_RGBA 0x84EE -#define GL_TEXTURE_COMPRESSION_HINT 0x84EF -#define GL_NORMAL_MAP 0x8511 -#define GL_REFLECTION_MAP 0x8512 -#define GL_TEXTURE_CUBE_MAP 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C -#define GL_COMBINE 0x8570 -#define GL_COMBINE_RGB 0x8571 -#define GL_COMBINE_ALPHA 0x8572 -#define GL_RGB_SCALE 0x8573 -#define GL_ADD_SIGNED 0x8574 -#define GL_INTERPOLATE 0x8575 -#define GL_CONSTANT 0x8576 -#define GL_PRIMARY_COLOR 0x8577 -#define GL_PREVIOUS 0x8578 -#define GL_SOURCE0_RGB 0x8580 -#define GL_SOURCE1_RGB 0x8581 -#define GL_SOURCE2_RGB 0x8582 -#define GL_SOURCE0_ALPHA 0x8588 -#define GL_SOURCE1_ALPHA 0x8589 -#define GL_SOURCE2_ALPHA 0x858A -#define GL_OPERAND0_RGB 0x8590 -#define GL_OPERAND1_RGB 0x8591 -#define GL_OPERAND2_RGB 0x8592 -#define GL_OPERAND0_ALPHA 0x8598 -#define GL_OPERAND1_ALPHA 0x8599 -#define GL_OPERAND2_ALPHA 0x859A -#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 -#define GL_TEXTURE_COMPRESSED 0x86A1 -#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 -#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 -#define GL_DOT3_RGB 0x86AE -#define GL_DOT3_RGBA 0x86AF -#define GL_MULTISAMPLE_BIT 0x20000000 - -typedef void (GLAPIENTRY * PFNGLACTIVETEXTUREPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLCLIENTACTIVETEXTUREPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEPROC) (GLenum target, GLint lod, GLvoid *img); -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXDPROC) (const GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXFPROC) (const GLfloat m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXDPROC) (const GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXFPROC) (const GLfloat m[16]); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DPROC) (GLenum target, GLdouble s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FPROC) (GLenum target, GLfloat s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IPROC) (GLenum target, GLint s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SPROC) (GLenum target, GLshort s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DPROC) (GLenum target, GLdouble s, GLdouble t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FPROC) (GLenum target, GLfloat s, GLfloat t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IPROC) (GLenum target, GLint s, GLint t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SPROC) (GLenum target, GLshort s, GLshort t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IPROC) (GLenum target, GLint s, GLint t, GLint r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SPROC) (GLenum target, GLshort s, GLshort t, GLshort r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DVPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FVPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IVPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SVPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEPROC) (GLclampf value, GLboolean invert); - -#define glActiveTexture GLEW_GET_FUN(__glewActiveTexture) -#define glClientActiveTexture GLEW_GET_FUN(__glewClientActiveTexture) -#define glCompressedTexImage1D GLEW_GET_FUN(__glewCompressedTexImage1D) -#define glCompressedTexImage2D GLEW_GET_FUN(__glewCompressedTexImage2D) -#define glCompressedTexImage3D GLEW_GET_FUN(__glewCompressedTexImage3D) -#define glCompressedTexSubImage1D GLEW_GET_FUN(__glewCompressedTexSubImage1D) -#define glCompressedTexSubImage2D GLEW_GET_FUN(__glewCompressedTexSubImage2D) -#define glCompressedTexSubImage3D GLEW_GET_FUN(__glewCompressedTexSubImage3D) -#define glGetCompressedTexImage GLEW_GET_FUN(__glewGetCompressedTexImage) -#define glLoadTransposeMatrixd GLEW_GET_FUN(__glewLoadTransposeMatrixd) -#define glLoadTransposeMatrixf GLEW_GET_FUN(__glewLoadTransposeMatrixf) -#define glMultTransposeMatrixd GLEW_GET_FUN(__glewMultTransposeMatrixd) -#define glMultTransposeMatrixf GLEW_GET_FUN(__glewMultTransposeMatrixf) -#define glMultiTexCoord1d GLEW_GET_FUN(__glewMultiTexCoord1d) -#define glMultiTexCoord1dv GLEW_GET_FUN(__glewMultiTexCoord1dv) -#define glMultiTexCoord1f GLEW_GET_FUN(__glewMultiTexCoord1f) -#define glMultiTexCoord1fv GLEW_GET_FUN(__glewMultiTexCoord1fv) -#define glMultiTexCoord1i GLEW_GET_FUN(__glewMultiTexCoord1i) -#define glMultiTexCoord1iv GLEW_GET_FUN(__glewMultiTexCoord1iv) -#define glMultiTexCoord1s GLEW_GET_FUN(__glewMultiTexCoord1s) -#define glMultiTexCoord1sv GLEW_GET_FUN(__glewMultiTexCoord1sv) -#define glMultiTexCoord2d GLEW_GET_FUN(__glewMultiTexCoord2d) -#define glMultiTexCoord2dv GLEW_GET_FUN(__glewMultiTexCoord2dv) -#define glMultiTexCoord2f GLEW_GET_FUN(__glewMultiTexCoord2f) -#define glMultiTexCoord2fv GLEW_GET_FUN(__glewMultiTexCoord2fv) -#define glMultiTexCoord2i GLEW_GET_FUN(__glewMultiTexCoord2i) -#define glMultiTexCoord2iv GLEW_GET_FUN(__glewMultiTexCoord2iv) -#define glMultiTexCoord2s GLEW_GET_FUN(__glewMultiTexCoord2s) -#define glMultiTexCoord2sv GLEW_GET_FUN(__glewMultiTexCoord2sv) -#define glMultiTexCoord3d GLEW_GET_FUN(__glewMultiTexCoord3d) -#define glMultiTexCoord3dv GLEW_GET_FUN(__glewMultiTexCoord3dv) -#define glMultiTexCoord3f GLEW_GET_FUN(__glewMultiTexCoord3f) -#define glMultiTexCoord3fv GLEW_GET_FUN(__glewMultiTexCoord3fv) -#define glMultiTexCoord3i GLEW_GET_FUN(__glewMultiTexCoord3i) -#define glMultiTexCoord3iv GLEW_GET_FUN(__glewMultiTexCoord3iv) -#define glMultiTexCoord3s GLEW_GET_FUN(__glewMultiTexCoord3s) -#define glMultiTexCoord3sv GLEW_GET_FUN(__glewMultiTexCoord3sv) -#define glMultiTexCoord4d GLEW_GET_FUN(__glewMultiTexCoord4d) -#define glMultiTexCoord4dv GLEW_GET_FUN(__glewMultiTexCoord4dv) -#define glMultiTexCoord4f GLEW_GET_FUN(__glewMultiTexCoord4f) -#define glMultiTexCoord4fv GLEW_GET_FUN(__glewMultiTexCoord4fv) -#define glMultiTexCoord4i GLEW_GET_FUN(__glewMultiTexCoord4i) -#define glMultiTexCoord4iv GLEW_GET_FUN(__glewMultiTexCoord4iv) -#define glMultiTexCoord4s GLEW_GET_FUN(__glewMultiTexCoord4s) -#define glMultiTexCoord4sv GLEW_GET_FUN(__glewMultiTexCoord4sv) -#define glSampleCoverage GLEW_GET_FUN(__glewSampleCoverage) - -#define GLEW_VERSION_1_3 GLEW_GET_VAR(__GLEW_VERSION_1_3) - -#endif /* GL_VERSION_1_3 */ - -/* ----------------------------- GL_VERSION_1_4 ---------------------------- */ - -#ifndef GL_VERSION_1_4 -#define GL_VERSION_1_4 1 - -#define GL_BLEND_DST_RGB 0x80C8 -#define GL_BLEND_SRC_RGB 0x80C9 -#define GL_BLEND_DST_ALPHA 0x80CA -#define GL_BLEND_SRC_ALPHA 0x80CB -#define GL_POINT_SIZE_MIN 0x8126 -#define GL_POINT_SIZE_MAX 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE 0x8128 -#define GL_POINT_DISTANCE_ATTENUATION 0x8129 -#define GL_GENERATE_MIPMAP 0x8191 -#define GL_GENERATE_MIPMAP_HINT 0x8192 -#define GL_DEPTH_COMPONENT16 0x81A5 -#define GL_DEPTH_COMPONENT24 0x81A6 -#define GL_DEPTH_COMPONENT32 0x81A7 -#define GL_MIRRORED_REPEAT 0x8370 -#define GL_FOG_COORDINATE_SOURCE 0x8450 -#define GL_FOG_COORDINATE 0x8451 -#define GL_FRAGMENT_DEPTH 0x8452 -#define GL_CURRENT_FOG_COORDINATE 0x8453 -#define GL_FOG_COORDINATE_ARRAY_TYPE 0x8454 -#define GL_FOG_COORDINATE_ARRAY_STRIDE 0x8455 -#define GL_FOG_COORDINATE_ARRAY_POINTER 0x8456 -#define GL_FOG_COORDINATE_ARRAY 0x8457 -#define GL_COLOR_SUM 0x8458 -#define GL_CURRENT_SECONDARY_COLOR 0x8459 -#define GL_SECONDARY_COLOR_ARRAY_SIZE 0x845A -#define GL_SECONDARY_COLOR_ARRAY_TYPE 0x845B -#define GL_SECONDARY_COLOR_ARRAY_STRIDE 0x845C -#define GL_SECONDARY_COLOR_ARRAY_POINTER 0x845D -#define GL_SECONDARY_COLOR_ARRAY 0x845E -#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD -#define GL_TEXTURE_FILTER_CONTROL 0x8500 -#define GL_TEXTURE_LOD_BIAS 0x8501 -#define GL_INCR_WRAP 0x8507 -#define GL_DECR_WRAP 0x8508 -#define GL_TEXTURE_DEPTH_SIZE 0x884A -#define GL_DEPTH_TEXTURE_MODE 0x884B -#define GL_TEXTURE_COMPARE_MODE 0x884C -#define GL_TEXTURE_COMPARE_FUNC 0x884D -#define GL_COMPARE_R_TO_TEXTURE 0x884E - -typedef void (GLAPIENTRY * PFNGLBLENDCOLORPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); -typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTERPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDPROC) (GLdouble coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDVPROC) (const GLdouble *coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFPROC) (GLfloat coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFVPROC) (const GLfloat *coord); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei drawcount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid **indices, GLsizei drawcount); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVPROC) (GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIVPROC) (GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BPROC) (GLbyte red, GLbyte green, GLbyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BVPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DPROC) (GLdouble red, GLdouble green, GLdouble blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DVPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FPROC) (GLfloat red, GLfloat green, GLfloat blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FVPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IPROC) (GLint red, GLint green, GLint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IVPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SPROC) (GLshort red, GLshort green, GLshort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SVPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBPROC) (GLubyte red, GLubyte green, GLubyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBVPROC) (const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIPROC) (GLuint red, GLuint green, GLuint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIVPROC) (const GLuint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USPROC) (GLushort red, GLushort green, GLushort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USVPROC) (const GLushort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVPROC) (const GLdouble *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVPROC) (const GLfloat *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVPROC) (const GLint *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVPROC) (const GLshort *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVPROC) (const GLdouble *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVPROC) (const GLfloat *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVPROC) (const GLint *p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVPROC) (const GLshort *p); - -#define glBlendColor GLEW_GET_FUN(__glewBlendColor) -#define glBlendEquation GLEW_GET_FUN(__glewBlendEquation) -#define glBlendFuncSeparate GLEW_GET_FUN(__glewBlendFuncSeparate) -#define glFogCoordPointer GLEW_GET_FUN(__glewFogCoordPointer) -#define glFogCoordd GLEW_GET_FUN(__glewFogCoordd) -#define glFogCoorddv GLEW_GET_FUN(__glewFogCoorddv) -#define glFogCoordf GLEW_GET_FUN(__glewFogCoordf) -#define glFogCoordfv GLEW_GET_FUN(__glewFogCoordfv) -#define glMultiDrawArrays GLEW_GET_FUN(__glewMultiDrawArrays) -#define glMultiDrawElements GLEW_GET_FUN(__glewMultiDrawElements) -#define glPointParameterf GLEW_GET_FUN(__glewPointParameterf) -#define glPointParameterfv GLEW_GET_FUN(__glewPointParameterfv) -#define glPointParameteri GLEW_GET_FUN(__glewPointParameteri) -#define glPointParameteriv GLEW_GET_FUN(__glewPointParameteriv) -#define glSecondaryColor3b GLEW_GET_FUN(__glewSecondaryColor3b) -#define glSecondaryColor3bv GLEW_GET_FUN(__glewSecondaryColor3bv) -#define glSecondaryColor3d GLEW_GET_FUN(__glewSecondaryColor3d) -#define glSecondaryColor3dv GLEW_GET_FUN(__glewSecondaryColor3dv) -#define glSecondaryColor3f GLEW_GET_FUN(__glewSecondaryColor3f) -#define glSecondaryColor3fv GLEW_GET_FUN(__glewSecondaryColor3fv) -#define glSecondaryColor3i GLEW_GET_FUN(__glewSecondaryColor3i) -#define glSecondaryColor3iv GLEW_GET_FUN(__glewSecondaryColor3iv) -#define glSecondaryColor3s GLEW_GET_FUN(__glewSecondaryColor3s) -#define glSecondaryColor3sv GLEW_GET_FUN(__glewSecondaryColor3sv) -#define glSecondaryColor3ub GLEW_GET_FUN(__glewSecondaryColor3ub) -#define glSecondaryColor3ubv GLEW_GET_FUN(__glewSecondaryColor3ubv) -#define glSecondaryColor3ui GLEW_GET_FUN(__glewSecondaryColor3ui) -#define glSecondaryColor3uiv GLEW_GET_FUN(__glewSecondaryColor3uiv) -#define glSecondaryColor3us GLEW_GET_FUN(__glewSecondaryColor3us) -#define glSecondaryColor3usv GLEW_GET_FUN(__glewSecondaryColor3usv) -#define glSecondaryColorPointer GLEW_GET_FUN(__glewSecondaryColorPointer) -#define glWindowPos2d GLEW_GET_FUN(__glewWindowPos2d) -#define glWindowPos2dv GLEW_GET_FUN(__glewWindowPos2dv) -#define glWindowPos2f GLEW_GET_FUN(__glewWindowPos2f) -#define glWindowPos2fv GLEW_GET_FUN(__glewWindowPos2fv) -#define glWindowPos2i GLEW_GET_FUN(__glewWindowPos2i) -#define glWindowPos2iv GLEW_GET_FUN(__glewWindowPos2iv) -#define glWindowPos2s GLEW_GET_FUN(__glewWindowPos2s) -#define glWindowPos2sv GLEW_GET_FUN(__glewWindowPos2sv) -#define glWindowPos3d GLEW_GET_FUN(__glewWindowPos3d) -#define glWindowPos3dv GLEW_GET_FUN(__glewWindowPos3dv) -#define glWindowPos3f GLEW_GET_FUN(__glewWindowPos3f) -#define glWindowPos3fv GLEW_GET_FUN(__glewWindowPos3fv) -#define glWindowPos3i GLEW_GET_FUN(__glewWindowPos3i) -#define glWindowPos3iv GLEW_GET_FUN(__glewWindowPos3iv) -#define glWindowPos3s GLEW_GET_FUN(__glewWindowPos3s) -#define glWindowPos3sv GLEW_GET_FUN(__glewWindowPos3sv) - -#define GLEW_VERSION_1_4 GLEW_GET_VAR(__GLEW_VERSION_1_4) - -#endif /* GL_VERSION_1_4 */ - -/* ----------------------------- GL_VERSION_1_5 ---------------------------- */ - -#ifndef GL_VERSION_1_5 -#define GL_VERSION_1_5 1 - -#define GL_FOG_COORD_SRC GL_FOG_COORDINATE_SOURCE -#define GL_FOG_COORD GL_FOG_COORDINATE -#define GL_FOG_COORD_ARRAY GL_FOG_COORDINATE_ARRAY -#define GL_SRC0_RGB GL_SOURCE0_RGB -#define GL_FOG_COORD_ARRAY_POINTER GL_FOG_COORDINATE_ARRAY_POINTER -#define GL_FOG_COORD_ARRAY_TYPE GL_FOG_COORDINATE_ARRAY_TYPE -#define GL_SRC1_ALPHA GL_SOURCE1_ALPHA -#define GL_CURRENT_FOG_COORD GL_CURRENT_FOG_COORDINATE -#define GL_FOG_COORD_ARRAY_STRIDE GL_FOG_COORDINATE_ARRAY_STRIDE -#define GL_SRC0_ALPHA GL_SOURCE0_ALPHA -#define GL_SRC1_RGB GL_SOURCE1_RGB -#define GL_FOG_COORD_ARRAY_BUFFER_BINDING GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING -#define GL_SRC2_ALPHA GL_SOURCE2_ALPHA -#define GL_SRC2_RGB GL_SOURCE2_RGB -#define GL_BUFFER_SIZE 0x8764 -#define GL_BUFFER_USAGE 0x8765 -#define GL_QUERY_COUNTER_BITS 0x8864 -#define GL_CURRENT_QUERY 0x8865 -#define GL_QUERY_RESULT 0x8866 -#define GL_QUERY_RESULT_AVAILABLE 0x8867 -#define GL_ARRAY_BUFFER 0x8892 -#define GL_ELEMENT_ARRAY_BUFFER 0x8893 -#define GL_ARRAY_BUFFER_BINDING 0x8894 -#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895 -#define GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896 -#define GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897 -#define GL_COLOR_ARRAY_BUFFER_BINDING 0x8898 -#define GL_INDEX_ARRAY_BUFFER_BINDING 0x8899 -#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A -#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING 0x889B -#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING 0x889C -#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING 0x889D -#define GL_WEIGHT_ARRAY_BUFFER_BINDING 0x889E -#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F -#define GL_READ_ONLY 0x88B8 -#define GL_WRITE_ONLY 0x88B9 -#define GL_READ_WRITE 0x88BA -#define GL_BUFFER_ACCESS 0x88BB -#define GL_BUFFER_MAPPED 0x88BC -#define GL_BUFFER_MAP_POINTER 0x88BD -#define GL_STREAM_DRAW 0x88E0 -#define GL_STREAM_READ 0x88E1 -#define GL_STREAM_COPY 0x88E2 -#define GL_STATIC_DRAW 0x88E4 -#define GL_STATIC_READ 0x88E5 -#define GL_STATIC_COPY 0x88E6 -#define GL_DYNAMIC_DRAW 0x88E8 -#define GL_DYNAMIC_READ 0x88E9 -#define GL_DYNAMIC_COPY 0x88EA -#define GL_SAMPLES_PASSED 0x8914 - -typedef ptrdiff_t GLintptr; -typedef ptrdiff_t GLsizeiptr; - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERPROC) (GLenum target, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBUFFERDATAPROC) (GLenum target, GLsizeiptr size, const GLvoid* data, GLenum usage); -typedef void (GLAPIENTRY * PFNGLBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLDELETEBUFFERSPROC) (GLsizei n, const GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLDELETEQUERIESPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDQUERYPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGENBUFFERSPROC) (GLsizei n, GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLGENQUERIESPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPOINTERVPROC) (GLenum target, GLenum pname, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, GLvoid* data); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVPROC) (GLuint id, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERPROC) (GLuint buffer); -typedef GLboolean (GLAPIENTRY * PFNGLISQUERYPROC) (GLuint id); -typedef GLvoid* (GLAPIENTRY * PFNGLMAPBUFFERPROC) (GLenum target, GLenum access); -typedef GLboolean (GLAPIENTRY * PFNGLUNMAPBUFFERPROC) (GLenum target); - -#define glBeginQuery GLEW_GET_FUN(__glewBeginQuery) -#define glBindBuffer GLEW_GET_FUN(__glewBindBuffer) -#define glBufferData GLEW_GET_FUN(__glewBufferData) -#define glBufferSubData GLEW_GET_FUN(__glewBufferSubData) -#define glDeleteBuffers GLEW_GET_FUN(__glewDeleteBuffers) -#define glDeleteQueries GLEW_GET_FUN(__glewDeleteQueries) -#define glEndQuery GLEW_GET_FUN(__glewEndQuery) -#define glGenBuffers GLEW_GET_FUN(__glewGenBuffers) -#define glGenQueries GLEW_GET_FUN(__glewGenQueries) -#define glGetBufferParameteriv GLEW_GET_FUN(__glewGetBufferParameteriv) -#define glGetBufferPointerv GLEW_GET_FUN(__glewGetBufferPointerv) -#define glGetBufferSubData GLEW_GET_FUN(__glewGetBufferSubData) -#define glGetQueryObjectiv GLEW_GET_FUN(__glewGetQueryObjectiv) -#define glGetQueryObjectuiv GLEW_GET_FUN(__glewGetQueryObjectuiv) -#define glGetQueryiv GLEW_GET_FUN(__glewGetQueryiv) -#define glIsBuffer GLEW_GET_FUN(__glewIsBuffer) -#define glIsQuery GLEW_GET_FUN(__glewIsQuery) -#define glMapBuffer GLEW_GET_FUN(__glewMapBuffer) -#define glUnmapBuffer GLEW_GET_FUN(__glewUnmapBuffer) - -#define GLEW_VERSION_1_5 GLEW_GET_VAR(__GLEW_VERSION_1_5) - -#endif /* GL_VERSION_1_5 */ - -/* ----------------------------- GL_VERSION_2_0 ---------------------------- */ - -#ifndef GL_VERSION_2_0 -#define GL_VERSION_2_0 1 - -#define GL_BLEND_EQUATION_RGB GL_BLEND_EQUATION -#define GL_VERTEX_ATTRIB_ARRAY_ENABLED 0x8622 -#define GL_VERTEX_ATTRIB_ARRAY_SIZE 0x8623 -#define GL_VERTEX_ATTRIB_ARRAY_STRIDE 0x8624 -#define GL_VERTEX_ATTRIB_ARRAY_TYPE 0x8625 -#define GL_CURRENT_VERTEX_ATTRIB 0x8626 -#define GL_VERTEX_PROGRAM_POINT_SIZE 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 -#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 -#define GL_STENCIL_BACK_FUNC 0x8800 -#define GL_STENCIL_BACK_FAIL 0x8801 -#define GL_STENCIL_BACK_PASS_DEPTH_FAIL 0x8802 -#define GL_STENCIL_BACK_PASS_DEPTH_PASS 0x8803 -#define GL_MAX_DRAW_BUFFERS 0x8824 -#define GL_DRAW_BUFFER0 0x8825 -#define GL_DRAW_BUFFER1 0x8826 -#define GL_DRAW_BUFFER2 0x8827 -#define GL_DRAW_BUFFER3 0x8828 -#define GL_DRAW_BUFFER4 0x8829 -#define GL_DRAW_BUFFER5 0x882A -#define GL_DRAW_BUFFER6 0x882B -#define GL_DRAW_BUFFER7 0x882C -#define GL_DRAW_BUFFER8 0x882D -#define GL_DRAW_BUFFER9 0x882E -#define GL_DRAW_BUFFER10 0x882F -#define GL_DRAW_BUFFER11 0x8830 -#define GL_DRAW_BUFFER12 0x8831 -#define GL_DRAW_BUFFER13 0x8832 -#define GL_DRAW_BUFFER14 0x8833 -#define GL_DRAW_BUFFER15 0x8834 -#define GL_BLEND_EQUATION_ALPHA 0x883D -#define GL_POINT_SPRITE 0x8861 -#define GL_COORD_REPLACE 0x8862 -#define GL_MAX_VERTEX_ATTRIBS 0x8869 -#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A -#define GL_MAX_TEXTURE_COORDS 0x8871 -#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 -#define GL_FRAGMENT_SHADER 0x8B30 -#define GL_VERTEX_SHADER 0x8B31 -#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49 -#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A -#define GL_MAX_VARYING_FLOATS 0x8B4B -#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C -#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D -#define GL_SHADER_TYPE 0x8B4F -#define GL_FLOAT_VEC2 0x8B50 -#define GL_FLOAT_VEC3 0x8B51 -#define GL_FLOAT_VEC4 0x8B52 -#define GL_INT_VEC2 0x8B53 -#define GL_INT_VEC3 0x8B54 -#define GL_INT_VEC4 0x8B55 -#define GL_BOOL 0x8B56 -#define GL_BOOL_VEC2 0x8B57 -#define GL_BOOL_VEC3 0x8B58 -#define GL_BOOL_VEC4 0x8B59 -#define GL_FLOAT_MAT2 0x8B5A -#define GL_FLOAT_MAT3 0x8B5B -#define GL_FLOAT_MAT4 0x8B5C -#define GL_SAMPLER_1D 0x8B5D -#define GL_SAMPLER_2D 0x8B5E -#define GL_SAMPLER_3D 0x8B5F -#define GL_SAMPLER_CUBE 0x8B60 -#define GL_SAMPLER_1D_SHADOW 0x8B61 -#define GL_SAMPLER_2D_SHADOW 0x8B62 -#define GL_DELETE_STATUS 0x8B80 -#define GL_COMPILE_STATUS 0x8B81 -#define GL_LINK_STATUS 0x8B82 -#define GL_VALIDATE_STATUS 0x8B83 -#define GL_INFO_LOG_LENGTH 0x8B84 -#define GL_ATTACHED_SHADERS 0x8B85 -#define GL_ACTIVE_UNIFORMS 0x8B86 -#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 -#define GL_SHADER_SOURCE_LENGTH 0x8B88 -#define GL_ACTIVE_ATTRIBUTES 0x8B89 -#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A -#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B -#define GL_SHADING_LANGUAGE_VERSION 0x8B8C -#define GL_CURRENT_PROGRAM 0x8B8D -#define GL_POINT_SPRITE_COORD_ORIGIN 0x8CA0 -#define GL_LOWER_LEFT 0x8CA1 -#define GL_UPPER_LEFT 0x8CA2 -#define GL_STENCIL_BACK_REF 0x8CA3 -#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4 -#define GL_STENCIL_BACK_WRITEMASK 0x8CA5 - -typedef void (GLAPIENTRY * PFNGLATTACHSHADERPROC) (GLuint program, GLuint shader); -typedef void (GLAPIENTRY * PFNGLBINDATTRIBLOCATIONPROC) (GLuint program, GLuint index, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEPROC) (GLenum, GLenum); -typedef void (GLAPIENTRY * PFNGLCOMPILESHADERPROC) (GLuint shader); -typedef GLuint (GLAPIENTRY * PFNGLCREATEPROGRAMPROC) (void); -typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROC) (GLenum type); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLDELETESHADERPROC) (GLuint shader); -typedef void (GLAPIENTRY * PFNGLDETACHSHADERPROC) (GLuint program, GLuint shader); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBARRAYPROC) (GLuint); -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSPROC) (GLsizei n, const GLenum* bufs); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBARRAYPROC) (GLuint); -typedef void (GLAPIENTRY * PFNGLGETACTIVEATTRIBPROC) (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMPROC) (GLuint program, GLuint index, GLsizei maxLength, GLsizei* length, GLint* size, GLenum* type, GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETATTACHEDSHADERSPROC) (GLuint program, GLsizei maxCount, GLsizei* count, GLuint* shaders); -typedef GLint (GLAPIENTRY * PFNGLGETATTRIBLOCATIONPROC) (GLuint program, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMINFOLOGPROC) (GLuint program, GLsizei bufSize, GLsizei* length, GLchar* infoLog); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVPROC) (GLuint program, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETSHADERINFOLOGPROC) (GLuint shader, GLsizei bufSize, GLsizei* length, GLchar* infoLog); -typedef void (GLAPIENTRY * PFNGLGETSHADERSOURCEPROC) (GLuint obj, GLsizei maxLength, GLsizei* length, GLchar* source); -typedef void (GLAPIENTRY * PFNGLGETSHADERIVPROC) (GLuint shader, GLenum pname, GLint* param); -typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMLOCATIONPROC) (GLuint program, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMFVPROC) (GLuint program, GLint location, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMIVPROC) (GLuint program, GLint location, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVPROC) (GLuint, GLenum, GLvoid**); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVPROC) (GLuint, GLenum, GLdouble*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVPROC) (GLuint, GLenum, GLfloat*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVPROC) (GLuint, GLenum, GLint*); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMPROC) (GLuint program); -typedef GLboolean (GLAPIENTRY * PFNGLISSHADERPROC) (GLuint shader); -typedef void (GLAPIENTRY * PFNGLLINKPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar** strings, const GLint* lengths); -typedef void (GLAPIENTRY * PFNGLSTENCILFUNCSEPARATEPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILMASKSEPARATEPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLSTENCILOPSEPARATEPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FPROC) (GLint location, GLfloat v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IPROC) (GLint location, GLint v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FPROC) (GLint location, GLfloat v0, GLfloat v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IPROC) (GLint location, GLint v0, GLint v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IPROC) (GLint location, GLint v0, GLint v1, GLint v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FVPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IVPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUSEPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FPROC) (GLuint index, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SPROC) (GLuint index, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SPROC) (GLuint index, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NBVPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NIVPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NSVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBVPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUIVPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUSVPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4BVPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4IVPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UIVPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4USVPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid* pointer); - -#define glAttachShader GLEW_GET_FUN(__glewAttachShader) -#define glBindAttribLocation GLEW_GET_FUN(__glewBindAttribLocation) -#define glBlendEquationSeparate GLEW_GET_FUN(__glewBlendEquationSeparate) -#define glCompileShader GLEW_GET_FUN(__glewCompileShader) -#define glCreateProgram GLEW_GET_FUN(__glewCreateProgram) -#define glCreateShader GLEW_GET_FUN(__glewCreateShader) -#define glDeleteProgram GLEW_GET_FUN(__glewDeleteProgram) -#define glDeleteShader GLEW_GET_FUN(__glewDeleteShader) -#define glDetachShader GLEW_GET_FUN(__glewDetachShader) -#define glDisableVertexAttribArray GLEW_GET_FUN(__glewDisableVertexAttribArray) -#define glDrawBuffers GLEW_GET_FUN(__glewDrawBuffers) -#define glEnableVertexAttribArray GLEW_GET_FUN(__glewEnableVertexAttribArray) -#define glGetActiveAttrib GLEW_GET_FUN(__glewGetActiveAttrib) -#define glGetActiveUniform GLEW_GET_FUN(__glewGetActiveUniform) -#define glGetAttachedShaders GLEW_GET_FUN(__glewGetAttachedShaders) -#define glGetAttribLocation GLEW_GET_FUN(__glewGetAttribLocation) -#define glGetProgramInfoLog GLEW_GET_FUN(__glewGetProgramInfoLog) -#define glGetProgramiv GLEW_GET_FUN(__glewGetProgramiv) -#define glGetShaderInfoLog GLEW_GET_FUN(__glewGetShaderInfoLog) -#define glGetShaderSource GLEW_GET_FUN(__glewGetShaderSource) -#define glGetShaderiv GLEW_GET_FUN(__glewGetShaderiv) -#define glGetUniformLocation GLEW_GET_FUN(__glewGetUniformLocation) -#define glGetUniformfv GLEW_GET_FUN(__glewGetUniformfv) -#define glGetUniformiv GLEW_GET_FUN(__glewGetUniformiv) -#define glGetVertexAttribPointerv GLEW_GET_FUN(__glewGetVertexAttribPointerv) -#define glGetVertexAttribdv GLEW_GET_FUN(__glewGetVertexAttribdv) -#define glGetVertexAttribfv GLEW_GET_FUN(__glewGetVertexAttribfv) -#define glGetVertexAttribiv GLEW_GET_FUN(__glewGetVertexAttribiv) -#define glIsProgram GLEW_GET_FUN(__glewIsProgram) -#define glIsShader GLEW_GET_FUN(__glewIsShader) -#define glLinkProgram GLEW_GET_FUN(__glewLinkProgram) -#define glShaderSource GLEW_GET_FUN(__glewShaderSource) -#define glStencilFuncSeparate GLEW_GET_FUN(__glewStencilFuncSeparate) -#define glStencilMaskSeparate GLEW_GET_FUN(__glewStencilMaskSeparate) -#define glStencilOpSeparate GLEW_GET_FUN(__glewStencilOpSeparate) -#define glUniform1f GLEW_GET_FUN(__glewUniform1f) -#define glUniform1fv GLEW_GET_FUN(__glewUniform1fv) -#define glUniform1i GLEW_GET_FUN(__glewUniform1i) -#define glUniform1iv GLEW_GET_FUN(__glewUniform1iv) -#define glUniform2f GLEW_GET_FUN(__glewUniform2f) -#define glUniform2fv GLEW_GET_FUN(__glewUniform2fv) -#define glUniform2i GLEW_GET_FUN(__glewUniform2i) -#define glUniform2iv GLEW_GET_FUN(__glewUniform2iv) -#define glUniform3f GLEW_GET_FUN(__glewUniform3f) -#define glUniform3fv GLEW_GET_FUN(__glewUniform3fv) -#define glUniform3i GLEW_GET_FUN(__glewUniform3i) -#define glUniform3iv GLEW_GET_FUN(__glewUniform3iv) -#define glUniform4f GLEW_GET_FUN(__glewUniform4f) -#define glUniform4fv GLEW_GET_FUN(__glewUniform4fv) -#define glUniform4i GLEW_GET_FUN(__glewUniform4i) -#define glUniform4iv GLEW_GET_FUN(__glewUniform4iv) -#define glUniformMatrix2fv GLEW_GET_FUN(__glewUniformMatrix2fv) -#define glUniformMatrix3fv GLEW_GET_FUN(__glewUniformMatrix3fv) -#define glUniformMatrix4fv GLEW_GET_FUN(__glewUniformMatrix4fv) -#define glUseProgram GLEW_GET_FUN(__glewUseProgram) -#define glValidateProgram GLEW_GET_FUN(__glewValidateProgram) -#define glVertexAttrib1d GLEW_GET_FUN(__glewVertexAttrib1d) -#define glVertexAttrib1dv GLEW_GET_FUN(__glewVertexAttrib1dv) -#define glVertexAttrib1f GLEW_GET_FUN(__glewVertexAttrib1f) -#define glVertexAttrib1fv GLEW_GET_FUN(__glewVertexAttrib1fv) -#define glVertexAttrib1s GLEW_GET_FUN(__glewVertexAttrib1s) -#define glVertexAttrib1sv GLEW_GET_FUN(__glewVertexAttrib1sv) -#define glVertexAttrib2d GLEW_GET_FUN(__glewVertexAttrib2d) -#define glVertexAttrib2dv GLEW_GET_FUN(__glewVertexAttrib2dv) -#define glVertexAttrib2f GLEW_GET_FUN(__glewVertexAttrib2f) -#define glVertexAttrib2fv GLEW_GET_FUN(__glewVertexAttrib2fv) -#define glVertexAttrib2s GLEW_GET_FUN(__glewVertexAttrib2s) -#define glVertexAttrib2sv GLEW_GET_FUN(__glewVertexAttrib2sv) -#define glVertexAttrib3d GLEW_GET_FUN(__glewVertexAttrib3d) -#define glVertexAttrib3dv GLEW_GET_FUN(__glewVertexAttrib3dv) -#define glVertexAttrib3f GLEW_GET_FUN(__glewVertexAttrib3f) -#define glVertexAttrib3fv GLEW_GET_FUN(__glewVertexAttrib3fv) -#define glVertexAttrib3s GLEW_GET_FUN(__glewVertexAttrib3s) -#define glVertexAttrib3sv GLEW_GET_FUN(__glewVertexAttrib3sv) -#define glVertexAttrib4Nbv GLEW_GET_FUN(__glewVertexAttrib4Nbv) -#define glVertexAttrib4Niv GLEW_GET_FUN(__glewVertexAttrib4Niv) -#define glVertexAttrib4Nsv GLEW_GET_FUN(__glewVertexAttrib4Nsv) -#define glVertexAttrib4Nub GLEW_GET_FUN(__glewVertexAttrib4Nub) -#define glVertexAttrib4Nubv GLEW_GET_FUN(__glewVertexAttrib4Nubv) -#define glVertexAttrib4Nuiv GLEW_GET_FUN(__glewVertexAttrib4Nuiv) -#define glVertexAttrib4Nusv GLEW_GET_FUN(__glewVertexAttrib4Nusv) -#define glVertexAttrib4bv GLEW_GET_FUN(__glewVertexAttrib4bv) -#define glVertexAttrib4d GLEW_GET_FUN(__glewVertexAttrib4d) -#define glVertexAttrib4dv GLEW_GET_FUN(__glewVertexAttrib4dv) -#define glVertexAttrib4f GLEW_GET_FUN(__glewVertexAttrib4f) -#define glVertexAttrib4fv GLEW_GET_FUN(__glewVertexAttrib4fv) -#define glVertexAttrib4iv GLEW_GET_FUN(__glewVertexAttrib4iv) -#define glVertexAttrib4s GLEW_GET_FUN(__glewVertexAttrib4s) -#define glVertexAttrib4sv GLEW_GET_FUN(__glewVertexAttrib4sv) -#define glVertexAttrib4ubv GLEW_GET_FUN(__glewVertexAttrib4ubv) -#define glVertexAttrib4uiv GLEW_GET_FUN(__glewVertexAttrib4uiv) -#define glVertexAttrib4usv GLEW_GET_FUN(__glewVertexAttrib4usv) -#define glVertexAttribPointer GLEW_GET_FUN(__glewVertexAttribPointer) - -#define GLEW_VERSION_2_0 GLEW_GET_VAR(__GLEW_VERSION_2_0) - -#endif /* GL_VERSION_2_0 */ - -/* ----------------------------- GL_VERSION_2_1 ---------------------------- */ - -#ifndef GL_VERSION_2_1 -#define GL_VERSION_2_1 1 - -#define GL_CURRENT_RASTER_SECONDARY_COLOR 0x845F -#define GL_PIXEL_PACK_BUFFER 0x88EB -#define GL_PIXEL_UNPACK_BUFFER 0x88EC -#define GL_PIXEL_PACK_BUFFER_BINDING 0x88ED -#define GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF -#define GL_FLOAT_MAT2x3 0x8B65 -#define GL_FLOAT_MAT2x4 0x8B66 -#define GL_FLOAT_MAT3x2 0x8B67 -#define GL_FLOAT_MAT3x4 0x8B68 -#define GL_FLOAT_MAT4x2 0x8B69 -#define GL_FLOAT_MAT4x3 0x8B6A -#define GL_SRGB 0x8C40 -#define GL_SRGB8 0x8C41 -#define GL_SRGB_ALPHA 0x8C42 -#define GL_SRGB8_ALPHA8 0x8C43 -#define GL_SLUMINANCE_ALPHA 0x8C44 -#define GL_SLUMINANCE8_ALPHA8 0x8C45 -#define GL_SLUMINANCE 0x8C46 -#define GL_SLUMINANCE8 0x8C47 -#define GL_COMPRESSED_SRGB 0x8C48 -#define GL_COMPRESSED_SRGB_ALPHA 0x8C49 -#define GL_COMPRESSED_SLUMINANCE 0x8C4A -#define GL_COMPRESSED_SLUMINANCE_ALPHA 0x8C4B - -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); - -#define glUniformMatrix2x3fv GLEW_GET_FUN(__glewUniformMatrix2x3fv) -#define glUniformMatrix2x4fv GLEW_GET_FUN(__glewUniformMatrix2x4fv) -#define glUniformMatrix3x2fv GLEW_GET_FUN(__glewUniformMatrix3x2fv) -#define glUniformMatrix3x4fv GLEW_GET_FUN(__glewUniformMatrix3x4fv) -#define glUniformMatrix4x2fv GLEW_GET_FUN(__glewUniformMatrix4x2fv) -#define glUniformMatrix4x3fv GLEW_GET_FUN(__glewUniformMatrix4x3fv) - -#define GLEW_VERSION_2_1 GLEW_GET_VAR(__GLEW_VERSION_2_1) - -#endif /* GL_VERSION_2_1 */ - -/* ----------------------------- GL_VERSION_3_0 ---------------------------- */ - -#ifndef GL_VERSION_3_0 -#define GL_VERSION_3_0 1 - -#define GL_MAX_CLIP_DISTANCES GL_MAX_CLIP_PLANES -#define GL_CLIP_DISTANCE5 GL_CLIP_PLANE5 -#define GL_CLIP_DISTANCE1 GL_CLIP_PLANE1 -#define GL_CLIP_DISTANCE3 GL_CLIP_PLANE3 -#define GL_COMPARE_REF_TO_TEXTURE GL_COMPARE_R_TO_TEXTURE_ARB -#define GL_CLIP_DISTANCE0 GL_CLIP_PLANE0 -#define GL_CLIP_DISTANCE4 GL_CLIP_PLANE4 -#define GL_CLIP_DISTANCE2 GL_CLIP_PLANE2 -#define GL_MAX_VARYING_COMPONENTS GL_MAX_VARYING_FLOATS -#define GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x0001 -#define GL_MAJOR_VERSION 0x821B -#define GL_MINOR_VERSION 0x821C -#define GL_NUM_EXTENSIONS 0x821D -#define GL_CONTEXT_FLAGS 0x821E -#define GL_DEPTH_BUFFER 0x8223 -#define GL_STENCIL_BUFFER 0x8224 -#define GL_RGBA32F 0x8814 -#define GL_RGB32F 0x8815 -#define GL_RGBA16F 0x881A -#define GL_RGB16F 0x881B -#define GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD -#define GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF -#define GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904 -#define GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905 -#define GL_CLAMP_VERTEX_COLOR 0x891A -#define GL_CLAMP_FRAGMENT_COLOR 0x891B -#define GL_CLAMP_READ_COLOR 0x891C -#define GL_FIXED_ONLY 0x891D -#define GL_TEXTURE_RED_TYPE 0x8C10 -#define GL_TEXTURE_GREEN_TYPE 0x8C11 -#define GL_TEXTURE_BLUE_TYPE 0x8C12 -#define GL_TEXTURE_ALPHA_TYPE 0x8C13 -#define GL_TEXTURE_LUMINANCE_TYPE 0x8C14 -#define GL_TEXTURE_INTENSITY_TYPE 0x8C15 -#define GL_TEXTURE_DEPTH_TYPE 0x8C16 -#define GL_TEXTURE_1D_ARRAY 0x8C18 -#define GL_PROXY_TEXTURE_1D_ARRAY 0x8C19 -#define GL_TEXTURE_2D_ARRAY 0x8C1A -#define GL_PROXY_TEXTURE_2D_ARRAY 0x8C1B -#define GL_TEXTURE_BINDING_1D_ARRAY 0x8C1C -#define GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D -#define GL_R11F_G11F_B10F 0x8C3A -#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B -#define GL_RGB9_E5 0x8C3D -#define GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E -#define GL_TEXTURE_SHARED_SIZE 0x8C3F -#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76 -#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80 -#define GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83 -#define GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84 -#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85 -#define GL_PRIMITIVES_GENERATED 0x8C87 -#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88 -#define GL_RASTERIZER_DISCARD 0x8C89 -#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B -#define GL_INTERLEAVED_ATTRIBS 0x8C8C -#define GL_SEPARATE_ATTRIBS 0x8C8D -#define GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E -#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F -#define GL_RGBA32UI 0x8D70 -#define GL_RGB32UI 0x8D71 -#define GL_RGBA16UI 0x8D76 -#define GL_RGB16UI 0x8D77 -#define GL_RGBA8UI 0x8D7C -#define GL_RGB8UI 0x8D7D -#define GL_RGBA32I 0x8D82 -#define GL_RGB32I 0x8D83 -#define GL_RGBA16I 0x8D88 -#define GL_RGB16I 0x8D89 -#define GL_RGBA8I 0x8D8E -#define GL_RGB8I 0x8D8F -#define GL_RED_INTEGER 0x8D94 -#define GL_GREEN_INTEGER 0x8D95 -#define GL_BLUE_INTEGER 0x8D96 -#define GL_ALPHA_INTEGER 0x8D97 -#define GL_RGB_INTEGER 0x8D98 -#define GL_RGBA_INTEGER 0x8D99 -#define GL_BGR_INTEGER 0x8D9A -#define GL_BGRA_INTEGER 0x8D9B -#define GL_SAMPLER_1D_ARRAY 0x8DC0 -#define GL_SAMPLER_2D_ARRAY 0x8DC1 -#define GL_SAMPLER_1D_ARRAY_SHADOW 0x8DC3 -#define GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4 -#define GL_SAMPLER_CUBE_SHADOW 0x8DC5 -#define GL_UNSIGNED_INT_VEC2 0x8DC6 -#define GL_UNSIGNED_INT_VEC3 0x8DC7 -#define GL_UNSIGNED_INT_VEC4 0x8DC8 -#define GL_INT_SAMPLER_1D 0x8DC9 -#define GL_INT_SAMPLER_2D 0x8DCA -#define GL_INT_SAMPLER_3D 0x8DCB -#define GL_INT_SAMPLER_CUBE 0x8DCC -#define GL_INT_SAMPLER_1D_ARRAY 0x8DCE -#define GL_INT_SAMPLER_2D_ARRAY 0x8DCF -#define GL_UNSIGNED_INT_SAMPLER_1D 0x8DD1 -#define GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2 -#define GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3 -#define GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4 -#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY 0x8DD6 -#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7 -#define GL_QUERY_WAIT 0x8E13 -#define GL_QUERY_NO_WAIT 0x8E14 -#define GL_QUERY_BY_REGION_WAIT 0x8E15 -#define GL_QUERY_BY_REGION_NO_WAIT 0x8E16 - -typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERPROC) (GLuint, GLenum); -typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKPROC) (GLenum); -typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONPROC) (GLuint, GLuint, const GLchar*); -typedef void (GLAPIENTRY * PFNGLCLAMPCOLORPROC) (GLenum, GLenum); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERFIPROC) (GLenum, GLint, GLfloat, GLint); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERFVPROC) (GLenum, GLint, const GLfloat*); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERIVPROC) (GLenum, GLint, const GLint*); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERUIVPROC) (GLenum, GLint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLCOLORMASKIPROC) (GLuint, GLboolean, GLboolean, GLboolean, GLboolean); -typedef void (GLAPIENTRY * PFNGLDISABLEIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLENABLEIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERPROC) (void); -typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETBOOLEANI_VPROC) (GLenum, GLuint, GLboolean*); -typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATALOCATIONPROC) (GLuint, const GLchar*); -typedef const GLubyte* (GLAPIENTRY * PFNGLGETSTRINGIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIIVPROC) (GLenum, GLenum, GLint*); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIUIVPROC) (GLenum, GLenum, GLuint*); -typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGPROC) (GLuint, GLuint, GLsizei, GLsizei *, GLsizei *, GLenum *, GLchar *); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMUIVPROC) (GLuint, GLint, GLuint*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIIVPROC) (GLuint, GLenum, GLint*); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIUIVPROC) (GLuint, GLenum, GLuint*); -typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDIPROC) (GLenum, GLuint); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIIVPROC) (GLenum, GLenum, const GLint*); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIUIVPROC) (GLenum, GLenum, const GLuint*); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSPROC) (GLuint, GLsizei, const GLchar **, GLenum); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIPROC) (GLint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIPROC) (GLint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIPROC) (GLint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIPROC) (GLint, GLuint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIVPROC) (GLint, GLsizei, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IPROC) (GLuint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIPROC) (GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IPROC) (GLuint, GLint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIPROC) (GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IPROC) (GLuint, GLint, GLint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIPROC) (GLuint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4BVPROC) (GLuint, const GLbyte*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IPROC) (GLuint, GLint, GLint, GLint, GLint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IVPROC) (GLuint, const GLint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4SVPROC) (GLuint, const GLshort*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UBVPROC) (GLuint, const GLubyte*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIPROC) (GLuint, GLuint, GLuint, GLuint, GLuint); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIVPROC) (GLuint, const GLuint*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4USVPROC) (GLuint, const GLushort*); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIPOINTERPROC) (GLuint, GLint, GLenum, GLsizei, const GLvoid*); - -#define glBeginConditionalRender GLEW_GET_FUN(__glewBeginConditionalRender) -#define glBeginTransformFeedback GLEW_GET_FUN(__glewBeginTransformFeedback) -#define glBindFragDataLocation GLEW_GET_FUN(__glewBindFragDataLocation) -#define glClampColor GLEW_GET_FUN(__glewClampColor) -#define glClearBufferfi GLEW_GET_FUN(__glewClearBufferfi) -#define glClearBufferfv GLEW_GET_FUN(__glewClearBufferfv) -#define glClearBufferiv GLEW_GET_FUN(__glewClearBufferiv) -#define glClearBufferuiv GLEW_GET_FUN(__glewClearBufferuiv) -#define glColorMaski GLEW_GET_FUN(__glewColorMaski) -#define glDisablei GLEW_GET_FUN(__glewDisablei) -#define glEnablei GLEW_GET_FUN(__glewEnablei) -#define glEndConditionalRender GLEW_GET_FUN(__glewEndConditionalRender) -#define glEndTransformFeedback GLEW_GET_FUN(__glewEndTransformFeedback) -#define glGetBooleani_v GLEW_GET_FUN(__glewGetBooleani_v) -#define glGetFragDataLocation GLEW_GET_FUN(__glewGetFragDataLocation) -#define glGetStringi GLEW_GET_FUN(__glewGetStringi) -#define glGetTexParameterIiv GLEW_GET_FUN(__glewGetTexParameterIiv) -#define glGetTexParameterIuiv GLEW_GET_FUN(__glewGetTexParameterIuiv) -#define glGetTransformFeedbackVarying GLEW_GET_FUN(__glewGetTransformFeedbackVarying) -#define glGetUniformuiv GLEW_GET_FUN(__glewGetUniformuiv) -#define glGetVertexAttribIiv GLEW_GET_FUN(__glewGetVertexAttribIiv) -#define glGetVertexAttribIuiv GLEW_GET_FUN(__glewGetVertexAttribIuiv) -#define glIsEnabledi GLEW_GET_FUN(__glewIsEnabledi) -#define glTexParameterIiv GLEW_GET_FUN(__glewTexParameterIiv) -#define glTexParameterIuiv GLEW_GET_FUN(__glewTexParameterIuiv) -#define glTransformFeedbackVaryings GLEW_GET_FUN(__glewTransformFeedbackVaryings) -#define glUniform1ui GLEW_GET_FUN(__glewUniform1ui) -#define glUniform1uiv GLEW_GET_FUN(__glewUniform1uiv) -#define glUniform2ui GLEW_GET_FUN(__glewUniform2ui) -#define glUniform2uiv GLEW_GET_FUN(__glewUniform2uiv) -#define glUniform3ui GLEW_GET_FUN(__glewUniform3ui) -#define glUniform3uiv GLEW_GET_FUN(__glewUniform3uiv) -#define glUniform4ui GLEW_GET_FUN(__glewUniform4ui) -#define glUniform4uiv GLEW_GET_FUN(__glewUniform4uiv) -#define glVertexAttribI1i GLEW_GET_FUN(__glewVertexAttribI1i) -#define glVertexAttribI1iv GLEW_GET_FUN(__glewVertexAttribI1iv) -#define glVertexAttribI1ui GLEW_GET_FUN(__glewVertexAttribI1ui) -#define glVertexAttribI1uiv GLEW_GET_FUN(__glewVertexAttribI1uiv) -#define glVertexAttribI2i GLEW_GET_FUN(__glewVertexAttribI2i) -#define glVertexAttribI2iv GLEW_GET_FUN(__glewVertexAttribI2iv) -#define glVertexAttribI2ui GLEW_GET_FUN(__glewVertexAttribI2ui) -#define glVertexAttribI2uiv GLEW_GET_FUN(__glewVertexAttribI2uiv) -#define glVertexAttribI3i GLEW_GET_FUN(__glewVertexAttribI3i) -#define glVertexAttribI3iv GLEW_GET_FUN(__glewVertexAttribI3iv) -#define glVertexAttribI3ui GLEW_GET_FUN(__glewVertexAttribI3ui) -#define glVertexAttribI3uiv GLEW_GET_FUN(__glewVertexAttribI3uiv) -#define glVertexAttribI4bv GLEW_GET_FUN(__glewVertexAttribI4bv) -#define glVertexAttribI4i GLEW_GET_FUN(__glewVertexAttribI4i) -#define glVertexAttribI4iv GLEW_GET_FUN(__glewVertexAttribI4iv) -#define glVertexAttribI4sv GLEW_GET_FUN(__glewVertexAttribI4sv) -#define glVertexAttribI4ubv GLEW_GET_FUN(__glewVertexAttribI4ubv) -#define glVertexAttribI4ui GLEW_GET_FUN(__glewVertexAttribI4ui) -#define glVertexAttribI4uiv GLEW_GET_FUN(__glewVertexAttribI4uiv) -#define glVertexAttribI4usv GLEW_GET_FUN(__glewVertexAttribI4usv) -#define glVertexAttribIPointer GLEW_GET_FUN(__glewVertexAttribIPointer) - -#define GLEW_VERSION_3_0 GLEW_GET_VAR(__GLEW_VERSION_3_0) - -#endif /* GL_VERSION_3_0 */ - -/* ----------------------------- GL_VERSION_3_1 ---------------------------- */ - -#ifndef GL_VERSION_3_1 -#define GL_VERSION_3_1 1 - -#define GL_TEXTURE_RECTANGLE 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE 0x84F8 -#define GL_SAMPLER_2D_RECT 0x8B63 -#define GL_SAMPLER_2D_RECT_SHADOW 0x8B64 -#define GL_TEXTURE_BUFFER 0x8C2A -#define GL_MAX_TEXTURE_BUFFER_SIZE 0x8C2B -#define GL_TEXTURE_BINDING_BUFFER 0x8C2C -#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING 0x8C2D -#define GL_TEXTURE_BUFFER_FORMAT 0x8C2E -#define GL_SAMPLER_BUFFER 0x8DC2 -#define GL_INT_SAMPLER_2D_RECT 0x8DCD -#define GL_INT_SAMPLER_BUFFER 0x8DD0 -#define GL_UNSIGNED_INT_SAMPLER_2D_RECT 0x8DD5 -#define GL_UNSIGNED_INT_SAMPLER_BUFFER 0x8DD8 -#define GL_RED_SNORM 0x8F90 -#define GL_RG_SNORM 0x8F91 -#define GL_RGB_SNORM 0x8F92 -#define GL_RGBA_SNORM 0x8F93 -#define GL_R8_SNORM 0x8F94 -#define GL_RG8_SNORM 0x8F95 -#define GL_RGB8_SNORM 0x8F96 -#define GL_RGBA8_SNORM 0x8F97 -#define GL_R16_SNORM 0x8F98 -#define GL_RG16_SNORM 0x8F99 -#define GL_RGB16_SNORM 0x8F9A -#define GL_RGBA16_SNORM 0x8F9B -#define GL_SIGNED_NORMALIZED 0x8F9C -#define GL_PRIMITIVE_RESTART 0x8F9D -#define GL_PRIMITIVE_RESTART_INDEX 0x8F9E -#define GL_BUFFER_ACCESS_FLAGS 0x911F -#define GL_BUFFER_MAP_LENGTH 0x9120 -#define GL_BUFFER_MAP_OFFSET 0x9121 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDPROC) (GLenum, GLint, GLsizei, GLsizei); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDPROC) (GLenum, GLsizei, GLenum, const GLvoid*, GLsizei); -typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTINDEXPROC) (GLuint); -typedef void (GLAPIENTRY * PFNGLTEXBUFFERPROC) (GLenum, GLenum, GLuint); - -#define glDrawArraysInstanced GLEW_GET_FUN(__glewDrawArraysInstanced) -#define glDrawElementsInstanced GLEW_GET_FUN(__glewDrawElementsInstanced) -#define glPrimitiveRestartIndex GLEW_GET_FUN(__glewPrimitiveRestartIndex) -#define glTexBuffer GLEW_GET_FUN(__glewTexBuffer) - -#define GLEW_VERSION_3_1 GLEW_GET_VAR(__GLEW_VERSION_3_1) - -#endif /* GL_VERSION_3_1 */ - -/* ----------------------------- GL_VERSION_3_2 ---------------------------- */ - -#ifndef GL_VERSION_3_2 -#define GL_VERSION_3_2 1 - -#define GL_CONTEXT_CORE_PROFILE_BIT 0x00000001 -#define GL_CONTEXT_COMPATIBILITY_PROFILE_BIT 0x00000002 -#define GL_LINES_ADJACENCY 0x000A -#define GL_LINE_STRIP_ADJACENCY 0x000B -#define GL_TRIANGLES_ADJACENCY 0x000C -#define GL_TRIANGLE_STRIP_ADJACENCY 0x000D -#define GL_PROGRAM_POINT_SIZE 0x8642 -#define GL_GEOMETRY_VERTICES_OUT 0x8916 -#define GL_GEOMETRY_INPUT_TYPE 0x8917 -#define GL_GEOMETRY_OUTPUT_TYPE 0x8918 -#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS 0x8C29 -#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED 0x8DA7 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS 0x8DA8 -#define GL_GEOMETRY_SHADER 0x8DD9 -#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS 0x8DDF -#define GL_MAX_GEOMETRY_OUTPUT_VERTICES 0x8DE0 -#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS 0x8DE1 -#define GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122 -#define GL_MAX_GEOMETRY_INPUT_COMPONENTS 0x9123 -#define GL_MAX_GEOMETRY_OUTPUT_COMPONENTS 0x9124 -#define GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125 -#define GL_CONTEXT_PROFILE_MASK 0x9126 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREPROC) (GLenum, GLenum, GLuint, GLint); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERI64VPROC) (GLenum, GLenum, GLint64 *); -typedef void (GLAPIENTRY * PFNGLGETINTEGER64I_VPROC) (GLenum, GLuint, GLint64 *); - -#define glFramebufferTexture GLEW_GET_FUN(__glewFramebufferTexture) -#define glGetBufferParameteri64v GLEW_GET_FUN(__glewGetBufferParameteri64v) -#define glGetInteger64i_v GLEW_GET_FUN(__glewGetInteger64i_v) - -#define GLEW_VERSION_3_2 GLEW_GET_VAR(__GLEW_VERSION_3_2) - -#endif /* GL_VERSION_3_2 */ - -/* ----------------------------- GL_VERSION_3_3 ---------------------------- */ - -#ifndef GL_VERSION_3_3 -#define GL_VERSION_3_3 1 - -#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE -#define GL_RGB10_A2UI 0x906F - -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBDIVISORPROC) (GLuint index, GLuint divisor); - -#define glVertexAttribDivisor GLEW_GET_FUN(__glewVertexAttribDivisor) - -#define GLEW_VERSION_3_3 GLEW_GET_VAR(__GLEW_VERSION_3_3) - -#endif /* GL_VERSION_3_3 */ - -/* ----------------------------- GL_VERSION_4_0 ---------------------------- */ - -#ifndef GL_VERSION_4_0 -#define GL_VERSION_4_0 1 - -#define GL_SAMPLE_SHADING 0x8C36 -#define GL_MIN_SAMPLE_SHADING_VALUE 0x8C37 -#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5E -#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET 0x8E5F -#define GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS 0x8F9F -#define GL_TEXTURE_CUBE_MAP_ARRAY 0x9009 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARRAY 0x900A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARRAY 0x900B -#define GL_SAMPLER_CUBE_MAP_ARRAY 0x900C -#define GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW 0x900D -#define GL_INT_SAMPLER_CUBE_MAP_ARRAY 0x900E -#define GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY 0x900F - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEIPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONIPROC) (GLuint buf, GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEIPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCIPROC) (GLuint buf, GLenum src, GLenum dst); -typedef void (GLAPIENTRY * PFNGLMINSAMPLESHADINGPROC) (GLclampf value); - -#define glBlendEquationSeparatei GLEW_GET_FUN(__glewBlendEquationSeparatei) -#define glBlendEquationi GLEW_GET_FUN(__glewBlendEquationi) -#define glBlendFuncSeparatei GLEW_GET_FUN(__glewBlendFuncSeparatei) -#define glBlendFunci GLEW_GET_FUN(__glewBlendFunci) -#define glMinSampleShading GLEW_GET_FUN(__glewMinSampleShading) - -#define GLEW_VERSION_4_0 GLEW_GET_VAR(__GLEW_VERSION_4_0) - -#endif /* GL_VERSION_4_0 */ - -/* ----------------------------- GL_VERSION_4_1 ---------------------------- */ - -#ifndef GL_VERSION_4_1 -#define GL_VERSION_4_1 1 - -#define GLEW_VERSION_4_1 GLEW_GET_VAR(__GLEW_VERSION_4_1) - -#endif /* GL_VERSION_4_1 */ - -/* ----------------------------- GL_VERSION_4_2 ---------------------------- */ - -#ifndef GL_VERSION_4_2 -#define GL_VERSION_4_2 1 - -#define GL_COMPRESSED_RGBA_BPTC_UNORM 0x8E8C -#define GL_COMPRESSED_SRGB_ALPHA_BPTC_UNORM 0x8E8D -#define GL_COMPRESSED_RGB_BPTC_SIGNED_FLOAT 0x8E8E -#define GL_COMPRESSED_RGB_BPTC_UNSIGNED_FLOAT 0x8E8F - -#define GLEW_VERSION_4_2 GLEW_GET_VAR(__GLEW_VERSION_4_2) - -#endif /* GL_VERSION_4_2 */ - -/* ----------------------------- GL_VERSION_4_3 ---------------------------- */ - -#ifndef GL_VERSION_4_3 -#define GL_VERSION_4_3 1 - -#define GL_NUM_SHADING_LANGUAGE_VERSIONS 0x82E9 -#define GL_VERTEX_ATTRIB_ARRAY_LONG 0x874E - -#define GLEW_VERSION_4_3 GLEW_GET_VAR(__GLEW_VERSION_4_3) - -#endif /* GL_VERSION_4_3 */ - -/* ----------------------------- GL_VERSION_4_4 ---------------------------- */ - -#ifndef GL_VERSION_4_4 -#define GL_VERSION_4_4 1 - -#define GL_MAX_VERTEX_ATTRIB_STRIDE 0x82E5 - -#define GLEW_VERSION_4_4 GLEW_GET_VAR(__GLEW_VERSION_4_4) - -#endif /* GL_VERSION_4_4 */ - -/* -------------------------- GL_3DFX_multisample -------------------------- */ - -#ifndef GL_3DFX_multisample -#define GL_3DFX_multisample 1 - -#define GL_MULTISAMPLE_3DFX 0x86B2 -#define GL_SAMPLE_BUFFERS_3DFX 0x86B3 -#define GL_SAMPLES_3DFX 0x86B4 -#define GL_MULTISAMPLE_BIT_3DFX 0x20000000 - -#define GLEW_3DFX_multisample GLEW_GET_VAR(__GLEW_3DFX_multisample) - -#endif /* GL_3DFX_multisample */ - -/* ---------------------------- GL_3DFX_tbuffer ---------------------------- */ - -#ifndef GL_3DFX_tbuffer -#define GL_3DFX_tbuffer 1 - -typedef void (GLAPIENTRY * PFNGLTBUFFERMASK3DFXPROC) (GLuint mask); - -#define glTbufferMask3DFX GLEW_GET_FUN(__glewTbufferMask3DFX) - -#define GLEW_3DFX_tbuffer GLEW_GET_VAR(__GLEW_3DFX_tbuffer) - -#endif /* GL_3DFX_tbuffer */ - -/* -------------------- GL_3DFX_texture_compression_FXT1 ------------------- */ - -#ifndef GL_3DFX_texture_compression_FXT1 -#define GL_3DFX_texture_compression_FXT1 1 - -#define GL_COMPRESSED_RGB_FXT1_3DFX 0x86B0 -#define GL_COMPRESSED_RGBA_FXT1_3DFX 0x86B1 - -#define GLEW_3DFX_texture_compression_FXT1 GLEW_GET_VAR(__GLEW_3DFX_texture_compression_FXT1) - -#endif /* GL_3DFX_texture_compression_FXT1 */ - -/* ----------------------- GL_AMD_blend_minmax_factor ---------------------- */ - -#ifndef GL_AMD_blend_minmax_factor -#define GL_AMD_blend_minmax_factor 1 - -#define GL_FACTOR_MIN_AMD 0x901C -#define GL_FACTOR_MAX_AMD 0x901D - -#define GLEW_AMD_blend_minmax_factor GLEW_GET_VAR(__GLEW_AMD_blend_minmax_factor) - -#endif /* GL_AMD_blend_minmax_factor */ - -/* ----------------------- GL_AMD_conservative_depth ----------------------- */ - -#ifndef GL_AMD_conservative_depth -#define GL_AMD_conservative_depth 1 - -#define GLEW_AMD_conservative_depth GLEW_GET_VAR(__GLEW_AMD_conservative_depth) - -#endif /* GL_AMD_conservative_depth */ - -/* -------------------------- GL_AMD_debug_output -------------------------- */ - -#ifndef GL_AMD_debug_output -#define GL_AMD_debug_output 1 - -#define GL_MAX_DEBUG_MESSAGE_LENGTH_AMD 0x9143 -#define GL_MAX_DEBUG_LOGGED_MESSAGES_AMD 0x9144 -#define GL_DEBUG_LOGGED_MESSAGES_AMD 0x9145 -#define GL_DEBUG_SEVERITY_HIGH_AMD 0x9146 -#define GL_DEBUG_SEVERITY_MEDIUM_AMD 0x9147 -#define GL_DEBUG_SEVERITY_LOW_AMD 0x9148 -#define GL_DEBUG_CATEGORY_API_ERROR_AMD 0x9149 -#define GL_DEBUG_CATEGORY_WINDOW_SYSTEM_AMD 0x914A -#define GL_DEBUG_CATEGORY_DEPRECATION_AMD 0x914B -#define GL_DEBUG_CATEGORY_UNDEFINED_BEHAVIOR_AMD 0x914C -#define GL_DEBUG_CATEGORY_PERFORMANCE_AMD 0x914D -#define GL_DEBUG_CATEGORY_SHADER_COMPILER_AMD 0x914E -#define GL_DEBUG_CATEGORY_APPLICATION_AMD 0x914F -#define GL_DEBUG_CATEGORY_OTHER_AMD 0x9150 - -typedef void (APIENTRY *GLDEBUGPROCAMD)(GLuint id, GLenum category, GLenum severity, GLsizei length, const GLchar* message, GLvoid* userParam); - -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECALLBACKAMDPROC) (GLDEBUGPROCAMD callback, GLvoid *userParam); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEENABLEAMDPROC) (GLenum category, GLenum severity, GLsizei count, const GLuint* ids, GLboolean enabled); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEINSERTAMDPROC) (GLenum category, GLenum severity, GLuint id, GLsizei length, const GLchar* buf); -typedef GLuint (GLAPIENTRY * PFNGLGETDEBUGMESSAGELOGAMDPROC) (GLuint count, GLsizei bufsize, GLenum* categories, GLuint* severities, GLuint* ids, GLsizei* lengths, GLchar* message); - -#define glDebugMessageCallbackAMD GLEW_GET_FUN(__glewDebugMessageCallbackAMD) -#define glDebugMessageEnableAMD GLEW_GET_FUN(__glewDebugMessageEnableAMD) -#define glDebugMessageInsertAMD GLEW_GET_FUN(__glewDebugMessageInsertAMD) -#define glGetDebugMessageLogAMD GLEW_GET_FUN(__glewGetDebugMessageLogAMD) - -#define GLEW_AMD_debug_output GLEW_GET_VAR(__GLEW_AMD_debug_output) - -#endif /* GL_AMD_debug_output */ - -/* ---------------------- GL_AMD_depth_clamp_separate ---------------------- */ - -#ifndef GL_AMD_depth_clamp_separate -#define GL_AMD_depth_clamp_separate 1 - -#define GL_DEPTH_CLAMP_NEAR_AMD 0x901E -#define GL_DEPTH_CLAMP_FAR_AMD 0x901F - -#define GLEW_AMD_depth_clamp_separate GLEW_GET_VAR(__GLEW_AMD_depth_clamp_separate) - -#endif /* GL_AMD_depth_clamp_separate */ - -/* ----------------------- GL_AMD_draw_buffers_blend ----------------------- */ - -#ifndef GL_AMD_draw_buffers_blend -#define GL_AMD_draw_buffers_blend 1 - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONINDEXEDAMDPROC) (GLuint buf, GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCINDEXEDAMDPROC) (GLuint buf, GLenum src, GLenum dst); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); - -#define glBlendEquationIndexedAMD GLEW_GET_FUN(__glewBlendEquationIndexedAMD) -#define glBlendEquationSeparateIndexedAMD GLEW_GET_FUN(__glewBlendEquationSeparateIndexedAMD) -#define glBlendFuncIndexedAMD GLEW_GET_FUN(__glewBlendFuncIndexedAMD) -#define glBlendFuncSeparateIndexedAMD GLEW_GET_FUN(__glewBlendFuncSeparateIndexedAMD) - -#define GLEW_AMD_draw_buffers_blend GLEW_GET_VAR(__GLEW_AMD_draw_buffers_blend) - -#endif /* GL_AMD_draw_buffers_blend */ - -/* ---------------------- GL_AMD_interleaved_elements ---------------------- */ - -#ifndef GL_AMD_interleaved_elements -#define GL_AMD_interleaved_elements 1 - -#define GL_RED 0x1903 -#define GL_GREEN 0x1904 -#define GL_BLUE 0x1905 -#define GL_ALPHA 0x1906 -#define GL_RG8UI 0x8238 -#define GL_RG16UI 0x823A -#define GL_RGBA8UI 0x8D7C -#define GL_VERTEX_ELEMENT_SWIZZLE_AMD 0x91A4 -#define GL_VERTEX_ID_SWIZZLE_AMD 0x91A5 - -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPARAMETERIAMDPROC) (GLuint index, GLenum pname, GLint param); - -#define glVertexAttribParameteriAMD GLEW_GET_FUN(__glewVertexAttribParameteriAMD) - -#define GLEW_AMD_interleaved_elements GLEW_GET_VAR(__GLEW_AMD_interleaved_elements) - -#endif /* GL_AMD_interleaved_elements */ - -/* ----------------------- GL_AMD_multi_draw_indirect ---------------------- */ - -#ifndef GL_AMD_multi_draw_indirect -#define GL_AMD_multi_draw_indirect 1 - -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSINDIRECTAMDPROC) (GLenum mode, const GLvoid *indirect, GLsizei primcount, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSINDIRECTAMDPROC) (GLenum mode, GLenum type, const GLvoid *indirect, GLsizei primcount, GLsizei stride); - -#define glMultiDrawArraysIndirectAMD GLEW_GET_FUN(__glewMultiDrawArraysIndirectAMD) -#define glMultiDrawElementsIndirectAMD GLEW_GET_FUN(__glewMultiDrawElementsIndirectAMD) - -#define GLEW_AMD_multi_draw_indirect GLEW_GET_VAR(__GLEW_AMD_multi_draw_indirect) - -#endif /* GL_AMD_multi_draw_indirect */ - -/* ------------------------- GL_AMD_name_gen_delete ------------------------ */ - -#ifndef GL_AMD_name_gen_delete -#define GL_AMD_name_gen_delete 1 - -#define GL_DATA_BUFFER_AMD 0x9151 -#define GL_PERFORMANCE_MONITOR_AMD 0x9152 -#define GL_QUERY_OBJECT_AMD 0x9153 -#define GL_VERTEX_ARRAY_OBJECT_AMD 0x9154 -#define GL_SAMPLER_OBJECT_AMD 0x9155 - -typedef void (GLAPIENTRY * PFNGLDELETENAMESAMDPROC) (GLenum identifier, GLuint num, const GLuint* names); -typedef void (GLAPIENTRY * PFNGLGENNAMESAMDPROC) (GLenum identifier, GLuint num, GLuint* names); -typedef GLboolean (GLAPIENTRY * PFNGLISNAMEAMDPROC) (GLenum identifier, GLuint name); - -#define glDeleteNamesAMD GLEW_GET_FUN(__glewDeleteNamesAMD) -#define glGenNamesAMD GLEW_GET_FUN(__glewGenNamesAMD) -#define glIsNameAMD GLEW_GET_FUN(__glewIsNameAMD) - -#define GLEW_AMD_name_gen_delete GLEW_GET_VAR(__GLEW_AMD_name_gen_delete) - -#endif /* GL_AMD_name_gen_delete */ - -/* ----------------------- GL_AMD_performance_monitor ---------------------- */ - -#ifndef GL_AMD_performance_monitor -#define GL_AMD_performance_monitor 1 - -#define GL_COUNTER_TYPE_AMD 0x8BC0 -#define GL_COUNTER_RANGE_AMD 0x8BC1 -#define GL_UNSIGNED_INT64_AMD 0x8BC2 -#define GL_PERCENTAGE_AMD 0x8BC3 -#define GL_PERFMON_RESULT_AVAILABLE_AMD 0x8BC4 -#define GL_PERFMON_RESULT_SIZE_AMD 0x8BC5 -#define GL_PERFMON_RESULT_AMD 0x8BC6 - -typedef void (GLAPIENTRY * PFNGLBEGINPERFMONITORAMDPROC) (GLuint monitor); -typedef void (GLAPIENTRY * PFNGLDELETEPERFMONITORSAMDPROC) (GLsizei n, GLuint* monitors); -typedef void (GLAPIENTRY * PFNGLENDPERFMONITORAMDPROC) (GLuint monitor); -typedef void (GLAPIENTRY * PFNGLGENPERFMONITORSAMDPROC) (GLsizei n, GLuint* monitors); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERDATAAMDPROC) (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint* data, GLint *bytesWritten); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERINFOAMDPROC) (GLuint group, GLuint counter, GLenum pname, GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC) (GLuint group, GLuint counter, GLsizei bufSize, GLsizei* length, GLchar *counterString); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORCOUNTERSAMDPROC) (GLuint group, GLint* numCounters, GLint *maxActiveCounters, GLsizei countersSize, GLuint *counters); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORGROUPSTRINGAMDPROC) (GLuint group, GLsizei bufSize, GLsizei* length, GLchar *groupString); -typedef void (GLAPIENTRY * PFNGLGETPERFMONITORGROUPSAMDPROC) (GLint* numGroups, GLsizei groupsSize, GLuint *groups); -typedef void (GLAPIENTRY * PFNGLSELECTPERFMONITORCOUNTERSAMDPROC) (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint* counterList); - -#define glBeginPerfMonitorAMD GLEW_GET_FUN(__glewBeginPerfMonitorAMD) -#define glDeletePerfMonitorsAMD GLEW_GET_FUN(__glewDeletePerfMonitorsAMD) -#define glEndPerfMonitorAMD GLEW_GET_FUN(__glewEndPerfMonitorAMD) -#define glGenPerfMonitorsAMD GLEW_GET_FUN(__glewGenPerfMonitorsAMD) -#define glGetPerfMonitorCounterDataAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterDataAMD) -#define glGetPerfMonitorCounterInfoAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterInfoAMD) -#define glGetPerfMonitorCounterStringAMD GLEW_GET_FUN(__glewGetPerfMonitorCounterStringAMD) -#define glGetPerfMonitorCountersAMD GLEW_GET_FUN(__glewGetPerfMonitorCountersAMD) -#define glGetPerfMonitorGroupStringAMD GLEW_GET_FUN(__glewGetPerfMonitorGroupStringAMD) -#define glGetPerfMonitorGroupsAMD GLEW_GET_FUN(__glewGetPerfMonitorGroupsAMD) -#define glSelectPerfMonitorCountersAMD GLEW_GET_FUN(__glewSelectPerfMonitorCountersAMD) - -#define GLEW_AMD_performance_monitor GLEW_GET_VAR(__GLEW_AMD_performance_monitor) - -#endif /* GL_AMD_performance_monitor */ - -/* -------------------------- GL_AMD_pinned_memory ------------------------- */ - -#ifndef GL_AMD_pinned_memory -#define GL_AMD_pinned_memory 1 - -#define GL_EXTERNAL_VIRTUAL_MEMORY_BUFFER_AMD 0x9160 - -#define GLEW_AMD_pinned_memory GLEW_GET_VAR(__GLEW_AMD_pinned_memory) - -#endif /* GL_AMD_pinned_memory */ - -/* ----------------------- GL_AMD_query_buffer_object ---------------------- */ - -#ifndef GL_AMD_query_buffer_object -#define GL_AMD_query_buffer_object 1 - -#define GL_QUERY_BUFFER_AMD 0x9192 -#define GL_QUERY_BUFFER_BINDING_AMD 0x9193 -#define GL_QUERY_RESULT_NO_WAIT_AMD 0x9194 - -#define GLEW_AMD_query_buffer_object GLEW_GET_VAR(__GLEW_AMD_query_buffer_object) - -#endif /* GL_AMD_query_buffer_object */ - -/* ------------------------ GL_AMD_sample_positions ------------------------ */ - -#ifndef GL_AMD_sample_positions -#define GL_AMD_sample_positions 1 - -#define GL_SUBSAMPLE_DISTANCE_AMD 0x883F - -typedef void (GLAPIENTRY * PFNGLSETMULTISAMPLEFVAMDPROC) (GLenum pname, GLuint index, const GLfloat* val); - -#define glSetMultisamplefvAMD GLEW_GET_FUN(__glewSetMultisamplefvAMD) - -#define GLEW_AMD_sample_positions GLEW_GET_VAR(__GLEW_AMD_sample_positions) - -#endif /* GL_AMD_sample_positions */ - -/* ------------------ GL_AMD_seamless_cubemap_per_texture ------------------ */ - -#ifndef GL_AMD_seamless_cubemap_per_texture -#define GL_AMD_seamless_cubemap_per_texture 1 - -#define GL_TEXTURE_CUBE_MAP_SEAMLESS_ARB 0x884F - -#define GLEW_AMD_seamless_cubemap_per_texture GLEW_GET_VAR(__GLEW_AMD_seamless_cubemap_per_texture) - -#endif /* GL_AMD_seamless_cubemap_per_texture */ - -/* ---------------------- GL_AMD_shader_stencil_export --------------------- */ - -#ifndef GL_AMD_shader_stencil_export -#define GL_AMD_shader_stencil_export 1 - -#define GLEW_AMD_shader_stencil_export GLEW_GET_VAR(__GLEW_AMD_shader_stencil_export) - -#endif /* GL_AMD_shader_stencil_export */ - -/* ---------------------- GL_AMD_shader_trinary_minmax --------------------- */ - -#ifndef GL_AMD_shader_trinary_minmax -#define GL_AMD_shader_trinary_minmax 1 - -#define GLEW_AMD_shader_trinary_minmax GLEW_GET_VAR(__GLEW_AMD_shader_trinary_minmax) - -#endif /* GL_AMD_shader_trinary_minmax */ - -/* ------------------------- GL_AMD_sparse_texture ------------------------- */ - -#ifndef GL_AMD_sparse_texture -#define GL_AMD_sparse_texture 1 - -#define GL_TEXTURE_STORAGE_SPARSE_BIT_AMD 0x00000001 -#define GL_VIRTUAL_PAGE_SIZE_X_AMD 0x9195 -#define GL_VIRTUAL_PAGE_SIZE_Y_AMD 0x9196 -#define GL_VIRTUAL_PAGE_SIZE_Z_AMD 0x9197 -#define GL_MAX_SPARSE_TEXTURE_SIZE_AMD 0x9198 -#define GL_MAX_SPARSE_3D_TEXTURE_SIZE_AMD 0x9199 -#define GL_MAX_SPARSE_ARRAY_TEXTURE_LAYERS 0x919A -#define GL_MIN_SPARSE_LEVEL_AMD 0x919B -#define GL_MIN_LOD_WARNING_AMD 0x919C - -typedef void (GLAPIENTRY * PFNGLTEXSTORAGESPARSEAMDPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLsizei layers, GLbitfield flags); -typedef void (GLAPIENTRY * PFNGLTEXTURESTORAGESPARSEAMDPROC) (GLuint texture, GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLsizei layers, GLbitfield flags); - -#define glTexStorageSparseAMD GLEW_GET_FUN(__glewTexStorageSparseAMD) -#define glTextureStorageSparseAMD GLEW_GET_FUN(__glewTextureStorageSparseAMD) - -#define GLEW_AMD_sparse_texture GLEW_GET_VAR(__GLEW_AMD_sparse_texture) - -#endif /* GL_AMD_sparse_texture */ - -/* ------------------- GL_AMD_stencil_operation_extended ------------------- */ - -#ifndef GL_AMD_stencil_operation_extended -#define GL_AMD_stencil_operation_extended 1 - -#define GL_SET_AMD 0x874A -#define GL_REPLACE_VALUE_AMD 0x874B -#define GL_STENCIL_OP_VALUE_AMD 0x874C -#define GL_STENCIL_BACK_OP_VALUE_AMD 0x874D - -typedef void (GLAPIENTRY * PFNGLSTENCILOPVALUEAMDPROC) (GLenum face, GLuint value); - -#define glStencilOpValueAMD GLEW_GET_FUN(__glewStencilOpValueAMD) - -#define GLEW_AMD_stencil_operation_extended GLEW_GET_VAR(__GLEW_AMD_stencil_operation_extended) - -#endif /* GL_AMD_stencil_operation_extended */ - -/* ------------------------ GL_AMD_texture_texture4 ------------------------ */ - -#ifndef GL_AMD_texture_texture4 -#define GL_AMD_texture_texture4 1 - -#define GLEW_AMD_texture_texture4 GLEW_GET_VAR(__GLEW_AMD_texture_texture4) - -#endif /* GL_AMD_texture_texture4 */ - -/* --------------- GL_AMD_transform_feedback3_lines_triangles -------------- */ - -#ifndef GL_AMD_transform_feedback3_lines_triangles -#define GL_AMD_transform_feedback3_lines_triangles 1 - -#define GLEW_AMD_transform_feedback3_lines_triangles GLEW_GET_VAR(__GLEW_AMD_transform_feedback3_lines_triangles) - -#endif /* GL_AMD_transform_feedback3_lines_triangles */ - -/* ----------------------- GL_AMD_vertex_shader_layer ---------------------- */ - -#ifndef GL_AMD_vertex_shader_layer -#define GL_AMD_vertex_shader_layer 1 - -#define GLEW_AMD_vertex_shader_layer GLEW_GET_VAR(__GLEW_AMD_vertex_shader_layer) - -#endif /* GL_AMD_vertex_shader_layer */ - -/* -------------------- GL_AMD_vertex_shader_tessellator ------------------- */ - -#ifndef GL_AMD_vertex_shader_tessellator -#define GL_AMD_vertex_shader_tessellator 1 - -#define GL_SAMPLER_BUFFER_AMD 0x9001 -#define GL_INT_SAMPLER_BUFFER_AMD 0x9002 -#define GL_UNSIGNED_INT_SAMPLER_BUFFER_AMD 0x9003 -#define GL_TESSELLATION_MODE_AMD 0x9004 -#define GL_TESSELLATION_FACTOR_AMD 0x9005 -#define GL_DISCRETE_AMD 0x9006 -#define GL_CONTINUOUS_AMD 0x9007 - -typedef void (GLAPIENTRY * PFNGLTESSELLATIONFACTORAMDPROC) (GLfloat factor); -typedef void (GLAPIENTRY * PFNGLTESSELLATIONMODEAMDPROC) (GLenum mode); - -#define glTessellationFactorAMD GLEW_GET_FUN(__glewTessellationFactorAMD) -#define glTessellationModeAMD GLEW_GET_FUN(__glewTessellationModeAMD) - -#define GLEW_AMD_vertex_shader_tessellator GLEW_GET_VAR(__GLEW_AMD_vertex_shader_tessellator) - -#endif /* GL_AMD_vertex_shader_tessellator */ - -/* ------------------ GL_AMD_vertex_shader_viewport_index ------------------ */ - -#ifndef GL_AMD_vertex_shader_viewport_index -#define GL_AMD_vertex_shader_viewport_index 1 - -#define GLEW_AMD_vertex_shader_viewport_index GLEW_GET_VAR(__GLEW_AMD_vertex_shader_viewport_index) - -#endif /* GL_AMD_vertex_shader_viewport_index */ - -/* ------------------------- GL_ANGLE_depth_texture ------------------------ */ - -#ifndef GL_ANGLE_depth_texture -#define GL_ANGLE_depth_texture 1 - -#define GLEW_ANGLE_depth_texture GLEW_GET_VAR(__GLEW_ANGLE_depth_texture) - -#endif /* GL_ANGLE_depth_texture */ - -/* ----------------------- GL_ANGLE_framebuffer_blit ----------------------- */ - -#ifndef GL_ANGLE_framebuffer_blit -#define GL_ANGLE_framebuffer_blit 1 - -#define GL_DRAW_FRAMEBUFFER_BINDING_ANGLE 0x8CA6 -#define GL_READ_FRAMEBUFFER_ANGLE 0x8CA8 -#define GL_DRAW_FRAMEBUFFER_ANGLE 0x8CA9 -#define GL_READ_FRAMEBUFFER_BINDING_ANGLE 0x8CAA - -typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFERANGLEPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); - -#define glBlitFramebufferANGLE GLEW_GET_FUN(__glewBlitFramebufferANGLE) - -#define GLEW_ANGLE_framebuffer_blit GLEW_GET_VAR(__GLEW_ANGLE_framebuffer_blit) - -#endif /* GL_ANGLE_framebuffer_blit */ - -/* -------------------- GL_ANGLE_framebuffer_multisample ------------------- */ - -#ifndef GL_ANGLE_framebuffer_multisample -#define GL_ANGLE_framebuffer_multisample 1 - -#define GL_RENDERBUFFER_SAMPLES_ANGLE 0x8CAB -#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_ANGLE 0x8D56 -#define GL_MAX_SAMPLES_ANGLE 0x8D57 - -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEANGLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glRenderbufferStorageMultisampleANGLE GLEW_GET_FUN(__glewRenderbufferStorageMultisampleANGLE) - -#define GLEW_ANGLE_framebuffer_multisample GLEW_GET_VAR(__GLEW_ANGLE_framebuffer_multisample) - -#endif /* GL_ANGLE_framebuffer_multisample */ - -/* ----------------------- GL_ANGLE_instanced_arrays ----------------------- */ - -#ifndef GL_ANGLE_instanced_arrays -#define GL_ANGLE_instanced_arrays 1 - -#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE 0x88FE - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDANGLEPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDANGLEPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBDIVISORANGLEPROC) (GLuint index, GLuint divisor); - -#define glDrawArraysInstancedANGLE GLEW_GET_FUN(__glewDrawArraysInstancedANGLE) -#define glDrawElementsInstancedANGLE GLEW_GET_FUN(__glewDrawElementsInstancedANGLE) -#define glVertexAttribDivisorANGLE GLEW_GET_FUN(__glewVertexAttribDivisorANGLE) - -#define GLEW_ANGLE_instanced_arrays GLEW_GET_VAR(__GLEW_ANGLE_instanced_arrays) - -#endif /* GL_ANGLE_instanced_arrays */ - -/* -------------------- GL_ANGLE_pack_reverse_row_order -------------------- */ - -#ifndef GL_ANGLE_pack_reverse_row_order -#define GL_ANGLE_pack_reverse_row_order 1 - -#define GL_PACK_REVERSE_ROW_ORDER_ANGLE 0x93A4 - -#define GLEW_ANGLE_pack_reverse_row_order GLEW_GET_VAR(__GLEW_ANGLE_pack_reverse_row_order) - -#endif /* GL_ANGLE_pack_reverse_row_order */ - -/* ------------------------ GL_ANGLE_program_binary ------------------------ */ - -#ifndef GL_ANGLE_program_binary -#define GL_ANGLE_program_binary 1 - -#define GL_PROGRAM_BINARY_ANGLE 0x93A6 - -#define GLEW_ANGLE_program_binary GLEW_GET_VAR(__GLEW_ANGLE_program_binary) - -#endif /* GL_ANGLE_program_binary */ - -/* ------------------- GL_ANGLE_texture_compression_dxt1 ------------------- */ - -#ifndef GL_ANGLE_texture_compression_dxt1 -#define GL_ANGLE_texture_compression_dxt1 1 - -#define GL_COMPRESSED_RGB_S3TC_DXT1_ANGLE 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_ANGLE 0x83F1 -#define GL_COMPRESSED_RGBA_S3TC_DXT3_ANGLE 0x83F2 -#define GL_COMPRESSED_RGBA_S3TC_DXT5_ANGLE 0x83F3 - -#define GLEW_ANGLE_texture_compression_dxt1 GLEW_GET_VAR(__GLEW_ANGLE_texture_compression_dxt1) - -#endif /* GL_ANGLE_texture_compression_dxt1 */ - -/* ------------------- GL_ANGLE_texture_compression_dxt3 ------------------- */ - -#ifndef GL_ANGLE_texture_compression_dxt3 -#define GL_ANGLE_texture_compression_dxt3 1 - -#define GL_COMPRESSED_RGB_S3TC_DXT1_ANGLE 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_ANGLE 0x83F1 -#define GL_COMPRESSED_RGBA_S3TC_DXT3_ANGLE 0x83F2 -#define GL_COMPRESSED_RGBA_S3TC_DXT5_ANGLE 0x83F3 - -#define GLEW_ANGLE_texture_compression_dxt3 GLEW_GET_VAR(__GLEW_ANGLE_texture_compression_dxt3) - -#endif /* GL_ANGLE_texture_compression_dxt3 */ - -/* ------------------- GL_ANGLE_texture_compression_dxt5 ------------------- */ - -#ifndef GL_ANGLE_texture_compression_dxt5 -#define GL_ANGLE_texture_compression_dxt5 1 - -#define GL_COMPRESSED_RGB_S3TC_DXT1_ANGLE 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_ANGLE 0x83F1 -#define GL_COMPRESSED_RGBA_S3TC_DXT3_ANGLE 0x83F2 -#define GL_COMPRESSED_RGBA_S3TC_DXT5_ANGLE 0x83F3 - -#define GLEW_ANGLE_texture_compression_dxt5 GLEW_GET_VAR(__GLEW_ANGLE_texture_compression_dxt5) - -#endif /* GL_ANGLE_texture_compression_dxt5 */ - -/* ------------------------- GL_ANGLE_texture_usage ------------------------ */ - -#ifndef GL_ANGLE_texture_usage -#define GL_ANGLE_texture_usage 1 - -#define GL_TEXTURE_USAGE_ANGLE 0x93A2 -#define GL_FRAMEBUFFER_ATTACHMENT_ANGLE 0x93A3 - -#define GLEW_ANGLE_texture_usage GLEW_GET_VAR(__GLEW_ANGLE_texture_usage) - -#endif /* GL_ANGLE_texture_usage */ - -/* -------------------------- GL_ANGLE_timer_query ------------------------- */ - -#ifndef GL_ANGLE_timer_query -#define GL_ANGLE_timer_query 1 - -#define GL_QUERY_COUNTER_BITS_ANGLE 0x8864 -#define GL_CURRENT_QUERY_ANGLE 0x8865 -#define GL_QUERY_RESULT_ANGLE 0x8866 -#define GL_QUERY_RESULT_AVAILABLE_ANGLE 0x8867 -#define GL_TIME_ELAPSED_ANGLE 0x88BF -#define GL_TIMESTAMP_ANGLE 0x8E28 - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYANGLEPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEQUERIESANGLEPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDQUERYANGLEPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGENQUERIESANGLEPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VANGLEPROC) (GLuint id, GLenum pname, GLint64* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVANGLEPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VANGLEPROC) (GLuint id, GLenum pname, GLuint64* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVANGLEPROC) (GLuint id, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYIVANGLEPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISQUERYANGLEPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLQUERYCOUNTERANGLEPROC) (GLuint id, GLenum target); - -#define glBeginQueryANGLE GLEW_GET_FUN(__glewBeginQueryANGLE) -#define glDeleteQueriesANGLE GLEW_GET_FUN(__glewDeleteQueriesANGLE) -#define glEndQueryANGLE GLEW_GET_FUN(__glewEndQueryANGLE) -#define glGenQueriesANGLE GLEW_GET_FUN(__glewGenQueriesANGLE) -#define glGetQueryObjecti64vANGLE GLEW_GET_FUN(__glewGetQueryObjecti64vANGLE) -#define glGetQueryObjectivANGLE GLEW_GET_FUN(__glewGetQueryObjectivANGLE) -#define glGetQueryObjectui64vANGLE GLEW_GET_FUN(__glewGetQueryObjectui64vANGLE) -#define glGetQueryObjectuivANGLE GLEW_GET_FUN(__glewGetQueryObjectuivANGLE) -#define glGetQueryivANGLE GLEW_GET_FUN(__glewGetQueryivANGLE) -#define glIsQueryANGLE GLEW_GET_FUN(__glewIsQueryANGLE) -#define glQueryCounterANGLE GLEW_GET_FUN(__glewQueryCounterANGLE) - -#define GLEW_ANGLE_timer_query GLEW_GET_VAR(__GLEW_ANGLE_timer_query) - -#endif /* GL_ANGLE_timer_query */ - -/* ------------------- GL_ANGLE_translated_shader_source ------------------- */ - -#ifndef GL_ANGLE_translated_shader_source -#define GL_ANGLE_translated_shader_source 1 - -#define GL_TRANSLATED_SHADER_SOURCE_LENGTH_ANGLE 0x93A0 - -typedef void (GLAPIENTRY * PFNGLGETTRANSLATEDSHADERSOURCEANGLEPROC) (GLuint shader, GLsizei bufsize, GLsizei* length, GLchar* source); - -#define glGetTranslatedShaderSourceANGLE GLEW_GET_FUN(__glewGetTranslatedShaderSourceANGLE) - -#define GLEW_ANGLE_translated_shader_source GLEW_GET_VAR(__GLEW_ANGLE_translated_shader_source) - -#endif /* GL_ANGLE_translated_shader_source */ - -/* ----------------------- GL_APPLE_aux_depth_stencil ---------------------- */ - -#ifndef GL_APPLE_aux_depth_stencil -#define GL_APPLE_aux_depth_stencil 1 - -#define GL_AUX_DEPTH_STENCIL_APPLE 0x8A14 - -#define GLEW_APPLE_aux_depth_stencil GLEW_GET_VAR(__GLEW_APPLE_aux_depth_stencil) - -#endif /* GL_APPLE_aux_depth_stencil */ - -/* ------------------------ GL_APPLE_client_storage ------------------------ */ - -#ifndef GL_APPLE_client_storage -#define GL_APPLE_client_storage 1 - -#define GL_UNPACK_CLIENT_STORAGE_APPLE 0x85B2 - -#define GLEW_APPLE_client_storage GLEW_GET_VAR(__GLEW_APPLE_client_storage) - -#endif /* GL_APPLE_client_storage */ - -/* ------------------------- GL_APPLE_element_array ------------------------ */ - -#ifndef GL_APPLE_element_array -#define GL_APPLE_element_array 1 - -#define GL_ELEMENT_ARRAY_APPLE 0x8A0C -#define GL_ELEMENT_ARRAY_TYPE_APPLE 0x8A0D -#define GL_ELEMENT_ARRAY_POINTER_APPLE 0x8A0E - -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLELEMENTPOINTERAPPLEPROC) (GLenum type, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, const GLint* first, const GLsizei *count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, const GLint* first, const GLsizei *count, GLsizei primcount); - -#define glDrawElementArrayAPPLE GLEW_GET_FUN(__glewDrawElementArrayAPPLE) -#define glDrawRangeElementArrayAPPLE GLEW_GET_FUN(__glewDrawRangeElementArrayAPPLE) -#define glElementPointerAPPLE GLEW_GET_FUN(__glewElementPointerAPPLE) -#define glMultiDrawElementArrayAPPLE GLEW_GET_FUN(__glewMultiDrawElementArrayAPPLE) -#define glMultiDrawRangeElementArrayAPPLE GLEW_GET_FUN(__glewMultiDrawRangeElementArrayAPPLE) - -#define GLEW_APPLE_element_array GLEW_GET_VAR(__GLEW_APPLE_element_array) - -#endif /* GL_APPLE_element_array */ - -/* ----------------------------- GL_APPLE_fence ---------------------------- */ - -#ifndef GL_APPLE_fence -#define GL_APPLE_fence 1 - -#define GL_DRAW_PIXELS_APPLE 0x8A0A -#define GL_FENCE_APPLE 0x8A0B - -typedef void (GLAPIENTRY * PFNGLDELETEFENCESAPPLEPROC) (GLsizei n, const GLuint* fences); -typedef void (GLAPIENTRY * PFNGLFINISHFENCEAPPLEPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLFINISHOBJECTAPPLEPROC) (GLenum object, GLint name); -typedef void (GLAPIENTRY * PFNGLGENFENCESAPPLEPROC) (GLsizei n, GLuint* fences); -typedef GLboolean (GLAPIENTRY * PFNGLISFENCEAPPLEPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLSETFENCEAPPLEPROC) (GLuint fence); -typedef GLboolean (GLAPIENTRY * PFNGLTESTFENCEAPPLEPROC) (GLuint fence); -typedef GLboolean (GLAPIENTRY * PFNGLTESTOBJECTAPPLEPROC) (GLenum object, GLuint name); - -#define glDeleteFencesAPPLE GLEW_GET_FUN(__glewDeleteFencesAPPLE) -#define glFinishFenceAPPLE GLEW_GET_FUN(__glewFinishFenceAPPLE) -#define glFinishObjectAPPLE GLEW_GET_FUN(__glewFinishObjectAPPLE) -#define glGenFencesAPPLE GLEW_GET_FUN(__glewGenFencesAPPLE) -#define glIsFenceAPPLE GLEW_GET_FUN(__glewIsFenceAPPLE) -#define glSetFenceAPPLE GLEW_GET_FUN(__glewSetFenceAPPLE) -#define glTestFenceAPPLE GLEW_GET_FUN(__glewTestFenceAPPLE) -#define glTestObjectAPPLE GLEW_GET_FUN(__glewTestObjectAPPLE) - -#define GLEW_APPLE_fence GLEW_GET_VAR(__GLEW_APPLE_fence) - -#endif /* GL_APPLE_fence */ - -/* ------------------------- GL_APPLE_float_pixels ------------------------- */ - -#ifndef GL_APPLE_float_pixels -#define GL_APPLE_float_pixels 1 - -#define GL_HALF_APPLE 0x140B -#define GL_RGBA_FLOAT32_APPLE 0x8814 -#define GL_RGB_FLOAT32_APPLE 0x8815 -#define GL_ALPHA_FLOAT32_APPLE 0x8816 -#define GL_INTENSITY_FLOAT32_APPLE 0x8817 -#define GL_LUMINANCE_FLOAT32_APPLE 0x8818 -#define GL_LUMINANCE_ALPHA_FLOAT32_APPLE 0x8819 -#define GL_RGBA_FLOAT16_APPLE 0x881A -#define GL_RGB_FLOAT16_APPLE 0x881B -#define GL_ALPHA_FLOAT16_APPLE 0x881C -#define GL_INTENSITY_FLOAT16_APPLE 0x881D -#define GL_LUMINANCE_FLOAT16_APPLE 0x881E -#define GL_LUMINANCE_ALPHA_FLOAT16_APPLE 0x881F -#define GL_COLOR_FLOAT_APPLE 0x8A0F - -#define GLEW_APPLE_float_pixels GLEW_GET_VAR(__GLEW_APPLE_float_pixels) - -#endif /* GL_APPLE_float_pixels */ - -/* ---------------------- GL_APPLE_flush_buffer_range ---------------------- */ - -#ifndef GL_APPLE_flush_buffer_range -#define GL_APPLE_flush_buffer_range 1 - -#define GL_BUFFER_SERIALIZED_MODIFY_APPLE 0x8A12 -#define GL_BUFFER_FLUSHING_UNMAP_APPLE 0x8A13 - -typedef void (GLAPIENTRY * PFNGLBUFFERPARAMETERIAPPLEPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC) (GLenum target, GLintptr offset, GLsizeiptr size); - -#define glBufferParameteriAPPLE GLEW_GET_FUN(__glewBufferParameteriAPPLE) -#define glFlushMappedBufferRangeAPPLE GLEW_GET_FUN(__glewFlushMappedBufferRangeAPPLE) - -#define GLEW_APPLE_flush_buffer_range GLEW_GET_VAR(__GLEW_APPLE_flush_buffer_range) - -#endif /* GL_APPLE_flush_buffer_range */ - -/* ----------------------- GL_APPLE_object_purgeable ----------------------- */ - -#ifndef GL_APPLE_object_purgeable -#define GL_APPLE_object_purgeable 1 - -#define GL_BUFFER_OBJECT_APPLE 0x85B3 -#define GL_RELEASED_APPLE 0x8A19 -#define GL_VOLATILE_APPLE 0x8A1A -#define GL_RETAINED_APPLE 0x8A1B -#define GL_UNDEFINED_APPLE 0x8A1C -#define GL_PURGEABLE_APPLE 0x8A1D - -typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERIVAPPLEPROC) (GLenum objectType, GLuint name, GLenum pname, GLint* params); -typedef GLenum (GLAPIENTRY * PFNGLOBJECTPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); -typedef GLenum (GLAPIENTRY * PFNGLOBJECTUNPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); - -#define glGetObjectParameterivAPPLE GLEW_GET_FUN(__glewGetObjectParameterivAPPLE) -#define glObjectPurgeableAPPLE GLEW_GET_FUN(__glewObjectPurgeableAPPLE) -#define glObjectUnpurgeableAPPLE GLEW_GET_FUN(__glewObjectUnpurgeableAPPLE) - -#define GLEW_APPLE_object_purgeable GLEW_GET_VAR(__GLEW_APPLE_object_purgeable) - -#endif /* GL_APPLE_object_purgeable */ - -/* ------------------------- GL_APPLE_pixel_buffer ------------------------- */ - -#ifndef GL_APPLE_pixel_buffer -#define GL_APPLE_pixel_buffer 1 - -#define GL_MIN_PBUFFER_VIEWPORT_DIMS_APPLE 0x8A10 - -#define GLEW_APPLE_pixel_buffer GLEW_GET_VAR(__GLEW_APPLE_pixel_buffer) - -#endif /* GL_APPLE_pixel_buffer */ - -/* ---------------------------- GL_APPLE_rgb_422 --------------------------- */ - -#ifndef GL_APPLE_rgb_422 -#define GL_APPLE_rgb_422 1 - -#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA -#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB -#define GL_RGB_422_APPLE 0x8A1F - -#define GLEW_APPLE_rgb_422 GLEW_GET_VAR(__GLEW_APPLE_rgb_422) - -#endif /* GL_APPLE_rgb_422 */ - -/* --------------------------- GL_APPLE_row_bytes -------------------------- */ - -#ifndef GL_APPLE_row_bytes -#define GL_APPLE_row_bytes 1 - -#define GL_PACK_ROW_BYTES_APPLE 0x8A15 -#define GL_UNPACK_ROW_BYTES_APPLE 0x8A16 - -#define GLEW_APPLE_row_bytes GLEW_GET_VAR(__GLEW_APPLE_row_bytes) - -#endif /* GL_APPLE_row_bytes */ - -/* ------------------------ GL_APPLE_specular_vector ----------------------- */ - -#ifndef GL_APPLE_specular_vector -#define GL_APPLE_specular_vector 1 - -#define GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 - -#define GLEW_APPLE_specular_vector GLEW_GET_VAR(__GLEW_APPLE_specular_vector) - -#endif /* GL_APPLE_specular_vector */ - -/* ------------------------- GL_APPLE_texture_range ------------------------ */ - -#ifndef GL_APPLE_texture_range -#define GL_APPLE_texture_range 1 - -#define GL_TEXTURE_RANGE_LENGTH_APPLE 0x85B7 -#define GL_TEXTURE_RANGE_POINTER_APPLE 0x85B8 -#define GL_TEXTURE_STORAGE_HINT_APPLE 0x85BC -#define GL_STORAGE_PRIVATE_APPLE 0x85BD -#define GL_STORAGE_CACHED_APPLE 0x85BE -#define GL_STORAGE_SHARED_APPLE 0x85BF - -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC) (GLenum target, GLenum pname, GLvoid **params); -typedef void (GLAPIENTRY * PFNGLTEXTURERANGEAPPLEPROC) (GLenum target, GLsizei length, GLvoid *pointer); - -#define glGetTexParameterPointervAPPLE GLEW_GET_FUN(__glewGetTexParameterPointervAPPLE) -#define glTextureRangeAPPLE GLEW_GET_FUN(__glewTextureRangeAPPLE) - -#define GLEW_APPLE_texture_range GLEW_GET_VAR(__GLEW_APPLE_texture_range) - -#endif /* GL_APPLE_texture_range */ - -/* ------------------------ GL_APPLE_transform_hint ------------------------ */ - -#ifndef GL_APPLE_transform_hint -#define GL_APPLE_transform_hint 1 - -#define GL_TRANSFORM_HINT_APPLE 0x85B1 - -#define GLEW_APPLE_transform_hint GLEW_GET_VAR(__GLEW_APPLE_transform_hint) - -#endif /* GL_APPLE_transform_hint */ - -/* ---------------------- GL_APPLE_vertex_array_object --------------------- */ - -#ifndef GL_APPLE_vertex_array_object -#define GL_APPLE_vertex_array_object 1 - -#define GL_VERTEX_ARRAY_BINDING_APPLE 0x85B5 - -typedef void (GLAPIENTRY * PFNGLBINDVERTEXARRAYAPPLEPROC) (GLuint array); -typedef void (GLAPIENTRY * PFNGLDELETEVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint* arrays); -typedef void (GLAPIENTRY * PFNGLGENVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint* arrays); -typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXARRAYAPPLEPROC) (GLuint array); - -#define glBindVertexArrayAPPLE GLEW_GET_FUN(__glewBindVertexArrayAPPLE) -#define glDeleteVertexArraysAPPLE GLEW_GET_FUN(__glewDeleteVertexArraysAPPLE) -#define glGenVertexArraysAPPLE GLEW_GET_FUN(__glewGenVertexArraysAPPLE) -#define glIsVertexArrayAPPLE GLEW_GET_FUN(__glewIsVertexArrayAPPLE) - -#define GLEW_APPLE_vertex_array_object GLEW_GET_VAR(__GLEW_APPLE_vertex_array_object) - -#endif /* GL_APPLE_vertex_array_object */ - -/* ---------------------- GL_APPLE_vertex_array_range ---------------------- */ - -#ifndef GL_APPLE_vertex_array_range -#define GL_APPLE_vertex_array_range 1 - -#define GL_VERTEX_ARRAY_RANGE_APPLE 0x851D -#define GL_VERTEX_ARRAY_RANGE_LENGTH_APPLE 0x851E -#define GL_VERTEX_ARRAY_STORAGE_HINT_APPLE 0x851F -#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_APPLE 0x8520 -#define GL_VERTEX_ARRAY_RANGE_POINTER_APPLE 0x8521 -#define GL_STORAGE_CLIENT_APPLE 0x85B4 -#define GL_STORAGE_CACHED_APPLE 0x85BE -#define GL_STORAGE_SHARED_APPLE 0x85BF - -typedef void (GLAPIENTRY * PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYPARAMETERIAPPLEPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, GLvoid *pointer); - -#define glFlushVertexArrayRangeAPPLE GLEW_GET_FUN(__glewFlushVertexArrayRangeAPPLE) -#define glVertexArrayParameteriAPPLE GLEW_GET_FUN(__glewVertexArrayParameteriAPPLE) -#define glVertexArrayRangeAPPLE GLEW_GET_FUN(__glewVertexArrayRangeAPPLE) - -#define GLEW_APPLE_vertex_array_range GLEW_GET_VAR(__GLEW_APPLE_vertex_array_range) - -#endif /* GL_APPLE_vertex_array_range */ - -/* ------------------- GL_APPLE_vertex_program_evaluators ------------------ */ - -#ifndef GL_APPLE_vertex_program_evaluators -#define GL_APPLE_vertex_program_evaluators 1 - -#define GL_VERTEX_ATTRIB_MAP1_APPLE 0x8A00 -#define GL_VERTEX_ATTRIB_MAP2_APPLE 0x8A01 -#define GL_VERTEX_ATTRIB_MAP1_SIZE_APPLE 0x8A02 -#define GL_VERTEX_ATTRIB_MAP1_COEFF_APPLE 0x8A03 -#define GL_VERTEX_ATTRIB_MAP1_ORDER_APPLE 0x8A04 -#define GL_VERTEX_ATTRIB_MAP1_DOMAIN_APPLE 0x8A05 -#define GL_VERTEX_ATTRIB_MAP2_SIZE_APPLE 0x8A06 -#define GL_VERTEX_ATTRIB_MAP2_COEFF_APPLE 0x8A07 -#define GL_VERTEX_ATTRIB_MAP2_ORDER_APPLE 0x8A08 -#define GL_VERTEX_ATTRIB_MAP2_DOMAIN_APPLE 0x8A09 - -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); -typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXATTRIBENABLEDAPPLEPROC) (GLuint index, GLenum pname); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB1DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble* points); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB1FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat* points); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB2DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble* points); -typedef void (GLAPIENTRY * PFNGLMAPVERTEXATTRIB2FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat* points); - -#define glDisableVertexAttribAPPLE GLEW_GET_FUN(__glewDisableVertexAttribAPPLE) -#define glEnableVertexAttribAPPLE GLEW_GET_FUN(__glewEnableVertexAttribAPPLE) -#define glIsVertexAttribEnabledAPPLE GLEW_GET_FUN(__glewIsVertexAttribEnabledAPPLE) -#define glMapVertexAttrib1dAPPLE GLEW_GET_FUN(__glewMapVertexAttrib1dAPPLE) -#define glMapVertexAttrib1fAPPLE GLEW_GET_FUN(__glewMapVertexAttrib1fAPPLE) -#define glMapVertexAttrib2dAPPLE GLEW_GET_FUN(__glewMapVertexAttrib2dAPPLE) -#define glMapVertexAttrib2fAPPLE GLEW_GET_FUN(__glewMapVertexAttrib2fAPPLE) - -#define GLEW_APPLE_vertex_program_evaluators GLEW_GET_VAR(__GLEW_APPLE_vertex_program_evaluators) - -#endif /* GL_APPLE_vertex_program_evaluators */ - -/* --------------------------- GL_APPLE_ycbcr_422 -------------------------- */ - -#ifndef GL_APPLE_ycbcr_422 -#define GL_APPLE_ycbcr_422 1 - -#define GL_YCBCR_422_APPLE 0x85B9 - -#define GLEW_APPLE_ycbcr_422 GLEW_GET_VAR(__GLEW_APPLE_ycbcr_422) - -#endif /* GL_APPLE_ycbcr_422 */ - -/* ------------------------ GL_ARB_ES2_compatibility ----------------------- */ - -#ifndef GL_ARB_ES2_compatibility -#define GL_ARB_ES2_compatibility 1 - -#define GL_FIXED 0x140C -#define GL_IMPLEMENTATION_COLOR_READ_TYPE 0x8B9A -#define GL_IMPLEMENTATION_COLOR_READ_FORMAT 0x8B9B -#define GL_RGB565 0x8D62 -#define GL_LOW_FLOAT 0x8DF0 -#define GL_MEDIUM_FLOAT 0x8DF1 -#define GL_HIGH_FLOAT 0x8DF2 -#define GL_LOW_INT 0x8DF3 -#define GL_MEDIUM_INT 0x8DF4 -#define GL_HIGH_INT 0x8DF5 -#define GL_SHADER_BINARY_FORMATS 0x8DF8 -#define GL_NUM_SHADER_BINARY_FORMATS 0x8DF9 -#define GL_SHADER_COMPILER 0x8DFA -#define GL_MAX_VERTEX_UNIFORM_VECTORS 0x8DFB -#define GL_MAX_VARYING_VECTORS 0x8DFC -#define GL_MAX_FRAGMENT_UNIFORM_VECTORS 0x8DFD - -typedef int GLfixed; - -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHFPROC) (GLclampf d); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEFPROC) (GLclampf n, GLclampf f); -typedef void (GLAPIENTRY * PFNGLGETSHADERPRECISIONFORMATPROC) (GLenum shadertype, GLenum precisiontype, GLint* range, GLint *precision); -typedef void (GLAPIENTRY * PFNGLRELEASESHADERCOMPILERPROC) (void); -typedef void (GLAPIENTRY * PFNGLSHADERBINARYPROC) (GLsizei count, const GLuint* shaders, GLenum binaryformat, const GLvoid*binary, GLsizei length); - -#define glClearDepthf GLEW_GET_FUN(__glewClearDepthf) -#define glDepthRangef GLEW_GET_FUN(__glewDepthRangef) -#define glGetShaderPrecisionFormat GLEW_GET_FUN(__glewGetShaderPrecisionFormat) -#define glReleaseShaderCompiler GLEW_GET_FUN(__glewReleaseShaderCompiler) -#define glShaderBinary GLEW_GET_FUN(__glewShaderBinary) - -#define GLEW_ARB_ES2_compatibility GLEW_GET_VAR(__GLEW_ARB_ES2_compatibility) - -#endif /* GL_ARB_ES2_compatibility */ - -/* ------------------------ GL_ARB_ES3_compatibility ----------------------- */ - -#ifndef GL_ARB_ES3_compatibility -#define GL_ARB_ES3_compatibility 1 - -#define GL_TEXTURE_IMMUTABLE_LEVELS 0x82DF -#define GL_PRIMITIVE_RESTART_FIXED_INDEX 0x8D69 -#define GL_ANY_SAMPLES_PASSED_CONSERVATIVE 0x8D6A -#define GL_MAX_ELEMENT_INDEX 0x8D6B -#define GL_COMPRESSED_R11_EAC 0x9270 -#define GL_COMPRESSED_SIGNED_R11_EAC 0x9271 -#define GL_COMPRESSED_RG11_EAC 0x9272 -#define GL_COMPRESSED_SIGNED_RG11_EAC 0x9273 -#define GL_COMPRESSED_RGB8_ETC2 0x9274 -#define GL_COMPRESSED_SRGB8_ETC2 0x9275 -#define GL_COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2 0x9276 -#define GL_COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2 0x9277 -#define GL_COMPRESSED_RGBA8_ETC2_EAC 0x9278 -#define GL_COMPRESSED_SRGB8_ALPHA8_ETC2_EAC 0x9279 - -#define GLEW_ARB_ES3_compatibility GLEW_GET_VAR(__GLEW_ARB_ES3_compatibility) - -#endif /* GL_ARB_ES3_compatibility */ - -/* ------------------------ GL_ARB_arrays_of_arrays ------------------------ */ - -#ifndef GL_ARB_arrays_of_arrays -#define GL_ARB_arrays_of_arrays 1 - -#define GLEW_ARB_arrays_of_arrays GLEW_GET_VAR(__GLEW_ARB_arrays_of_arrays) - -#endif /* GL_ARB_arrays_of_arrays */ - -/* -------------------------- GL_ARB_base_instance ------------------------- */ - -#ifndef GL_ARB_base_instance -#define GL_ARB_base_instance 1 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDBASEINSTANCEPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount, GLuint baseinstance); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDBASEINSTANCEPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount, GLuint baseinstance); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXBASEINSTANCEPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount, GLint basevertex, GLuint baseinstance); - -#define glDrawArraysInstancedBaseInstance GLEW_GET_FUN(__glewDrawArraysInstancedBaseInstance) -#define glDrawElementsInstancedBaseInstance GLEW_GET_FUN(__glewDrawElementsInstancedBaseInstance) -#define glDrawElementsInstancedBaseVertexBaseInstance GLEW_GET_FUN(__glewDrawElementsInstancedBaseVertexBaseInstance) - -#define GLEW_ARB_base_instance GLEW_GET_VAR(__GLEW_ARB_base_instance) - -#endif /* GL_ARB_base_instance */ - -/* ------------------------ GL_ARB_bindless_texture ------------------------ */ - -#ifndef GL_ARB_bindless_texture -#define GL_ARB_bindless_texture 1 - -#define GL_UNSIGNED_INT64_ARB 0x140F - -typedef GLuint64 (GLAPIENTRY * PFNGLGETIMAGEHANDLEARBPROC) (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); -typedef GLuint64 (GLAPIENTRY * PFNGLGETTEXTUREHANDLEARBPROC) (GLuint texture); -typedef GLuint64 (GLAPIENTRY * PFNGLGETTEXTURESAMPLERHANDLEARBPROC) (GLuint texture, GLuint sampler); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLUI64VARBPROC) (GLuint index, GLenum pname, GLuint64EXT* params); -typedef GLboolean (GLAPIENTRY * PFNGLISIMAGEHANDLERESIDENTARBPROC) (GLuint64 handle); -typedef GLboolean (GLAPIENTRY * PFNGLISTEXTUREHANDLERESIDENTARBPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLMAKEIMAGEHANDLENONRESIDENTARBPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLMAKEIMAGEHANDLERESIDENTARBPROC) (GLuint64 handle, GLenum access); -typedef void (GLAPIENTRY * PFNGLMAKETEXTUREHANDLENONRESIDENTARBPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLMAKETEXTUREHANDLERESIDENTARBPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMHANDLEUI64ARBPROC) (GLuint program, GLint location, GLuint64 value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMHANDLEUI64VARBPROC) (GLuint program, GLint location, GLsizei count, const GLuint64* values); -typedef void (GLAPIENTRY * PFNGLUNIFORMHANDLEUI64ARBPROC) (GLint location, GLuint64 value); -typedef void (GLAPIENTRY * PFNGLUNIFORMHANDLEUI64VARBPROC) (GLint location, GLsizei count, const GLuint64* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64ARBPROC) (GLuint index, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64VARBPROC) (GLuint index, const GLuint64EXT* v); - -#define glGetImageHandleARB GLEW_GET_FUN(__glewGetImageHandleARB) -#define glGetTextureHandleARB GLEW_GET_FUN(__glewGetTextureHandleARB) -#define glGetTextureSamplerHandleARB GLEW_GET_FUN(__glewGetTextureSamplerHandleARB) -#define glGetVertexAttribLui64vARB GLEW_GET_FUN(__glewGetVertexAttribLui64vARB) -#define glIsImageHandleResidentARB GLEW_GET_FUN(__glewIsImageHandleResidentARB) -#define glIsTextureHandleResidentARB GLEW_GET_FUN(__glewIsTextureHandleResidentARB) -#define glMakeImageHandleNonResidentARB GLEW_GET_FUN(__glewMakeImageHandleNonResidentARB) -#define glMakeImageHandleResidentARB GLEW_GET_FUN(__glewMakeImageHandleResidentARB) -#define glMakeTextureHandleNonResidentARB GLEW_GET_FUN(__glewMakeTextureHandleNonResidentARB) -#define glMakeTextureHandleResidentARB GLEW_GET_FUN(__glewMakeTextureHandleResidentARB) -#define glProgramUniformHandleui64ARB GLEW_GET_FUN(__glewProgramUniformHandleui64ARB) -#define glProgramUniformHandleui64vARB GLEW_GET_FUN(__glewProgramUniformHandleui64vARB) -#define glUniformHandleui64ARB GLEW_GET_FUN(__glewUniformHandleui64ARB) -#define glUniformHandleui64vARB GLEW_GET_FUN(__glewUniformHandleui64vARB) -#define glVertexAttribL1ui64ARB GLEW_GET_FUN(__glewVertexAttribL1ui64ARB) -#define glVertexAttribL1ui64vARB GLEW_GET_FUN(__glewVertexAttribL1ui64vARB) - -#define GLEW_ARB_bindless_texture GLEW_GET_VAR(__GLEW_ARB_bindless_texture) - -#endif /* GL_ARB_bindless_texture */ - -/* ----------------------- GL_ARB_blend_func_extended ---------------------- */ - -#ifndef GL_ARB_blend_func_extended -#define GL_ARB_blend_func_extended 1 - -#define GL_SRC1_COLOR 0x88F9 -#define GL_ONE_MINUS_SRC1_COLOR 0x88FA -#define GL_ONE_MINUS_SRC1_ALPHA 0x88FB -#define GL_MAX_DUAL_SOURCE_DRAW_BUFFERS 0x88FC - -typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONINDEXEDPROC) (GLuint program, GLuint colorNumber, GLuint index, const GLchar * name); -typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATAINDEXPROC) (GLuint program, const GLchar * name); - -#define glBindFragDataLocationIndexed GLEW_GET_FUN(__glewBindFragDataLocationIndexed) -#define glGetFragDataIndex GLEW_GET_FUN(__glewGetFragDataIndex) - -#define GLEW_ARB_blend_func_extended GLEW_GET_VAR(__GLEW_ARB_blend_func_extended) - -#endif /* GL_ARB_blend_func_extended */ - -/* ------------------------- GL_ARB_buffer_storage ------------------------- */ - -#ifndef GL_ARB_buffer_storage -#define GL_ARB_buffer_storage 1 - -#define GL_MAP_READ_BIT 0x0001 -#define GL_MAP_WRITE_BIT 0x0002 -#define GL_MAP_PERSISTENT_BIT 0x00000040 -#define GL_MAP_COHERENT_BIT 0x00000080 -#define GL_DYNAMIC_STORAGE_BIT 0x0100 -#define GL_CLIENT_STORAGE_BIT 0x0200 -#define GL_CLIENT_MAPPED_BUFFER_BARRIER_BIT 0x00004000 -#define GL_BUFFER_IMMUTABLE_STORAGE 0x821F -#define GL_BUFFER_STORAGE_FLAGS 0x8220 - -typedef void (GLAPIENTRY * PFNGLBUFFERSTORAGEPROC) (GLenum target, GLsizeiptr size, const GLvoid* data, GLbitfield flags); -typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERSTORAGEEXTPROC) (GLuint buffer, GLsizeiptr size, const GLvoid* data, GLbitfield flags); - -#define glBufferStorage GLEW_GET_FUN(__glewBufferStorage) -#define glNamedBufferStorageEXT GLEW_GET_FUN(__glewNamedBufferStorageEXT) - -#define GLEW_ARB_buffer_storage GLEW_GET_VAR(__GLEW_ARB_buffer_storage) - -#endif /* GL_ARB_buffer_storage */ - -/* ---------------------------- GL_ARB_cl_event ---------------------------- */ - -#ifndef GL_ARB_cl_event -#define GL_ARB_cl_event 1 - -#define GL_SYNC_CL_EVENT_ARB 0x8240 -#define GL_SYNC_CL_EVENT_COMPLETE_ARB 0x8241 - -typedef struct _cl_context *cl_context; -typedef struct _cl_event *cl_event; - -typedef GLsync (GLAPIENTRY * PFNGLCREATESYNCFROMCLEVENTARBPROC) (cl_context context, cl_event event, GLbitfield flags); - -#define glCreateSyncFromCLeventARB GLEW_GET_FUN(__glewCreateSyncFromCLeventARB) - -#define GLEW_ARB_cl_event GLEW_GET_VAR(__GLEW_ARB_cl_event) - -#endif /* GL_ARB_cl_event */ - -/* ----------------------- GL_ARB_clear_buffer_object ---------------------- */ - -#ifndef GL_ARB_clear_buffer_object -#define GL_ARB_clear_buffer_object 1 - -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERDATAPROC) (GLenum target, GLenum internalformat, GLenum format, GLenum type, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLCLEARBUFFERSUBDATAPROC) (GLenum target, GLenum internalformat, GLintptr offset, GLsizeiptr size, GLenum format, GLenum type, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLCLEARNAMEDBUFFERDATAEXTPROC) (GLuint buffer, GLenum internalformat, GLenum format, GLenum type, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLCLEARNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLenum internalformat, GLintptr offset, GLsizeiptr size, GLenum format, GLenum type, const GLvoid* data); - -#define glClearBufferData GLEW_GET_FUN(__glewClearBufferData) -#define glClearBufferSubData GLEW_GET_FUN(__glewClearBufferSubData) -#define glClearNamedBufferDataEXT GLEW_GET_FUN(__glewClearNamedBufferDataEXT) -#define glClearNamedBufferSubDataEXT GLEW_GET_FUN(__glewClearNamedBufferSubDataEXT) - -#define GLEW_ARB_clear_buffer_object GLEW_GET_VAR(__GLEW_ARB_clear_buffer_object) - -#endif /* GL_ARB_clear_buffer_object */ - -/* -------------------------- GL_ARB_clear_texture ------------------------- */ - -#ifndef GL_ARB_clear_texture -#define GL_ARB_clear_texture 1 - -#define GL_CLEAR_TEXTURE 0x9365 - -typedef void (GLAPIENTRY * PFNGLCLEARTEXIMAGEPROC) (GLuint texture, GLint level, GLenum format, GLenum type, const GLvoid* data); -typedef void (GLAPIENTRY * PFNGLCLEARTEXSUBIMAGEPROC) (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid* data); - -#define glClearTexImage GLEW_GET_FUN(__glewClearTexImage) -#define glClearTexSubImage GLEW_GET_FUN(__glewClearTexSubImage) - -#define GLEW_ARB_clear_texture GLEW_GET_VAR(__GLEW_ARB_clear_texture) - -#endif /* GL_ARB_clear_texture */ - -/* ----------------------- GL_ARB_color_buffer_float ----------------------- */ - -#ifndef GL_ARB_color_buffer_float -#define GL_ARB_color_buffer_float 1 - -#define GL_RGBA_FLOAT_MODE_ARB 0x8820 -#define GL_CLAMP_VERTEX_COLOR_ARB 0x891A -#define GL_CLAMP_FRAGMENT_COLOR_ARB 0x891B -#define GL_CLAMP_READ_COLOR_ARB 0x891C -#define GL_FIXED_ONLY_ARB 0x891D - -typedef void (GLAPIENTRY * PFNGLCLAMPCOLORARBPROC) (GLenum target, GLenum clamp); - -#define glClampColorARB GLEW_GET_FUN(__glewClampColorARB) - -#define GLEW_ARB_color_buffer_float GLEW_GET_VAR(__GLEW_ARB_color_buffer_float) - -#endif /* GL_ARB_color_buffer_float */ - -/* -------------------------- GL_ARB_compatibility ------------------------- */ - -#ifndef GL_ARB_compatibility -#define GL_ARB_compatibility 1 - -#define GLEW_ARB_compatibility GLEW_GET_VAR(__GLEW_ARB_compatibility) - -#endif /* GL_ARB_compatibility */ - -/* ---------------- GL_ARB_compressed_texture_pixel_storage ---------------- */ - -#ifndef GL_ARB_compressed_texture_pixel_storage -#define GL_ARB_compressed_texture_pixel_storage 1 - -#define GL_UNPACK_COMPRESSED_BLOCK_WIDTH 0x9127 -#define GL_UNPACK_COMPRESSED_BLOCK_HEIGHT 0x9128 -#define GL_UNPACK_COMPRESSED_BLOCK_DEPTH 0x9129 -#define GL_UNPACK_COMPRESSED_BLOCK_SIZE 0x912A -#define GL_PACK_COMPRESSED_BLOCK_WIDTH 0x912B -#define GL_PACK_COMPRESSED_BLOCK_HEIGHT 0x912C -#define GL_PACK_COMPRESSED_BLOCK_DEPTH 0x912D -#define GL_PACK_COMPRESSED_BLOCK_SIZE 0x912E - -#define GLEW_ARB_compressed_texture_pixel_storage GLEW_GET_VAR(__GLEW_ARB_compressed_texture_pixel_storage) - -#endif /* GL_ARB_compressed_texture_pixel_storage */ - -/* ------------------------- GL_ARB_compute_shader ------------------------- */ - -#ifndef GL_ARB_compute_shader -#define GL_ARB_compute_shader 1 - -#define GL_COMPUTE_SHADER_BIT 0x00000020 -#define GL_MAX_COMPUTE_SHARED_MEMORY_SIZE 0x8262 -#define GL_MAX_COMPUTE_UNIFORM_COMPONENTS 0x8263 -#define GL_MAX_COMPUTE_ATOMIC_COUNTER_BUFFERS 0x8264 -#define GL_MAX_COMPUTE_ATOMIC_COUNTERS 0x8265 -#define GL_MAX_COMBINED_COMPUTE_UNIFORM_COMPONENTS 0x8266 -#define GL_COMPUTE_WORK_GROUP_SIZE 0x8267 -#define GL_MAX_COMPUTE_WORK_GROUP_INVOCATIONS 0x90EB -#define GL_UNIFORM_BLOCK_REFERENCED_BY_COMPUTE_SHADER 0x90EC -#define GL_ATOMIC_COUNTER_BUFFER_REFERENCED_BY_COMPUTE_SHADER 0x90ED -#define GL_DISPATCH_INDIRECT_BUFFER 0x90EE -#define GL_DISPATCH_INDIRECT_BUFFER_BINDING 0x90EF -#define GL_COMPUTE_SHADER 0x91B9 -#define GL_MAX_COMPUTE_UNIFORM_BLOCKS 0x91BB -#define GL_MAX_COMPUTE_TEXTURE_IMAGE_UNITS 0x91BC -#define GL_MAX_COMPUTE_IMAGE_UNIFORMS 0x91BD -#define GL_MAX_COMPUTE_WORK_GROUP_COUNT 0x91BE -#define GL_MAX_COMPUTE_WORK_GROUP_SIZE 0x91BF - -typedef void (GLAPIENTRY * PFNGLDISPATCHCOMPUTEPROC) (GLuint num_groups_x, GLuint num_groups_y, GLuint num_groups_z); -typedef void (GLAPIENTRY * PFNGLDISPATCHCOMPUTEINDIRECTPROC) (GLintptr indirect); - -#define glDispatchCompute GLEW_GET_FUN(__glewDispatchCompute) -#define glDispatchComputeIndirect GLEW_GET_FUN(__glewDispatchComputeIndirect) - -#define GLEW_ARB_compute_shader GLEW_GET_VAR(__GLEW_ARB_compute_shader) - -#endif /* GL_ARB_compute_shader */ - -/* ------------------- GL_ARB_compute_variable_group_size ------------------ */ - -#ifndef GL_ARB_compute_variable_group_size -#define GL_ARB_compute_variable_group_size 1 - -#define GL_MAX_COMPUTE_FIXED_GROUP_INVOCATIONS_ARB 0x90EB -#define GL_MAX_COMPUTE_FIXED_GROUP_SIZE_ARB 0x91BF -#define GL_MAX_COMPUTE_VARIABLE_GROUP_INVOCATIONS_ARB 0x9344 -#define GL_MAX_COMPUTE_VARIABLE_GROUP_SIZE_ARB 0x9345 - -typedef void (GLAPIENTRY * PFNGLDISPATCHCOMPUTEGROUPSIZEARBPROC) (GLuint num_groups_x, GLuint num_groups_y, GLuint num_groups_z, GLuint group_size_x, GLuint group_size_y, GLuint group_size_z); - -#define glDispatchComputeGroupSizeARB GLEW_GET_FUN(__glewDispatchComputeGroupSizeARB) - -#define GLEW_ARB_compute_variable_group_size GLEW_GET_VAR(__GLEW_ARB_compute_variable_group_size) - -#endif /* GL_ARB_compute_variable_group_size */ - -/* ----------------------- GL_ARB_conservative_depth ----------------------- */ - -#ifndef GL_ARB_conservative_depth -#define GL_ARB_conservative_depth 1 - -#define GLEW_ARB_conservative_depth GLEW_GET_VAR(__GLEW_ARB_conservative_depth) - -#endif /* GL_ARB_conservative_depth */ - -/* --------------------------- GL_ARB_copy_buffer -------------------------- */ - -#ifndef GL_ARB_copy_buffer -#define GL_ARB_copy_buffer 1 - -#define GL_COPY_READ_BUFFER 0x8F36 -#define GL_COPY_WRITE_BUFFER 0x8F37 - -typedef void (GLAPIENTRY * PFNGLCOPYBUFFERSUBDATAPROC) (GLenum readtarget, GLenum writetarget, GLintptr readoffset, GLintptr writeoffset, GLsizeiptr size); - -#define glCopyBufferSubData GLEW_GET_FUN(__glewCopyBufferSubData) - -#define GLEW_ARB_copy_buffer GLEW_GET_VAR(__GLEW_ARB_copy_buffer) - -#endif /* GL_ARB_copy_buffer */ - -/* --------------------------- GL_ARB_copy_image --------------------------- */ - -#ifndef GL_ARB_copy_image -#define GL_ARB_copy_image 1 - -typedef void (GLAPIENTRY * PFNGLCOPYIMAGESUBDATAPROC) (GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei srcWidth, GLsizei srcHeight, GLsizei srcDepth); - -#define glCopyImageSubData GLEW_GET_FUN(__glewCopyImageSubData) - -#define GLEW_ARB_copy_image GLEW_GET_VAR(__GLEW_ARB_copy_image) - -#endif /* GL_ARB_copy_image */ - -/* -------------------------- GL_ARB_debug_output -------------------------- */ - -#ifndef GL_ARB_debug_output -#define GL_ARB_debug_output 1 - -#define GL_DEBUG_OUTPUT_SYNCHRONOUS_ARB 0x8242 -#define GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH_ARB 0x8243 -#define GL_DEBUG_CALLBACK_FUNCTION_ARB 0x8244 -#define GL_DEBUG_CALLBACK_USER_PARAM_ARB 0x8245 -#define GL_DEBUG_SOURCE_API_ARB 0x8246 -#define GL_DEBUG_SOURCE_WINDOW_SYSTEM_ARB 0x8247 -#define GL_DEBUG_SOURCE_SHADER_COMPILER_ARB 0x8248 -#define GL_DEBUG_SOURCE_THIRD_PARTY_ARB 0x8249 -#define GL_DEBUG_SOURCE_APPLICATION_ARB 0x824A -#define GL_DEBUG_SOURCE_OTHER_ARB 0x824B -#define GL_DEBUG_TYPE_ERROR_ARB 0x824C -#define GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR_ARB 0x824D -#define GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR_ARB 0x824E -#define GL_DEBUG_TYPE_PORTABILITY_ARB 0x824F -#define GL_DEBUG_TYPE_PERFORMANCE_ARB 0x8250 -#define GL_DEBUG_TYPE_OTHER_ARB 0x8251 -#define GL_MAX_DEBUG_MESSAGE_LENGTH_ARB 0x9143 -#define GL_MAX_DEBUG_LOGGED_MESSAGES_ARB 0x9144 -#define GL_DEBUG_LOGGED_MESSAGES_ARB 0x9145 -#define GL_DEBUG_SEVERITY_HIGH_ARB 0x9146 -#define GL_DEBUG_SEVERITY_MEDIUM_ARB 0x9147 -#define GL_DEBUG_SEVERITY_LOW_ARB 0x9148 - -typedef void (APIENTRY *GLDEBUGPROCARB)(GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* message, GLvoid* userParam); - -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECALLBACKARBPROC) (GLDEBUGPROCARB callback, const GLvoid *userParam); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECONTROLARBPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint* ids, GLboolean enabled); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEINSERTARBPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* buf); -typedef GLuint (GLAPIENTRY * PFNGLGETDEBUGMESSAGELOGARBPROC) (GLuint count, GLsizei bufsize, GLenum* sources, GLenum* types, GLuint* ids, GLenum* severities, GLsizei* lengths, GLchar* messageLog); - -#define glDebugMessageCallbackARB GLEW_GET_FUN(__glewDebugMessageCallbackARB) -#define glDebugMessageControlARB GLEW_GET_FUN(__glewDebugMessageControlARB) -#define glDebugMessageInsertARB GLEW_GET_FUN(__glewDebugMessageInsertARB) -#define glGetDebugMessageLogARB GLEW_GET_FUN(__glewGetDebugMessageLogARB) - -#define GLEW_ARB_debug_output GLEW_GET_VAR(__GLEW_ARB_debug_output) - -#endif /* GL_ARB_debug_output */ - -/* ----------------------- GL_ARB_depth_buffer_float ----------------------- */ - -#ifndef GL_ARB_depth_buffer_float -#define GL_ARB_depth_buffer_float 1 - -#define GL_DEPTH_COMPONENT32F 0x8CAC -#define GL_DEPTH32F_STENCIL8 0x8CAD -#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD - -#define GLEW_ARB_depth_buffer_float GLEW_GET_VAR(__GLEW_ARB_depth_buffer_float) - -#endif /* GL_ARB_depth_buffer_float */ - -/* --------------------------- GL_ARB_depth_clamp -------------------------- */ - -#ifndef GL_ARB_depth_clamp -#define GL_ARB_depth_clamp 1 - -#define GL_DEPTH_CLAMP 0x864F - -#define GLEW_ARB_depth_clamp GLEW_GET_VAR(__GLEW_ARB_depth_clamp) - -#endif /* GL_ARB_depth_clamp */ - -/* -------------------------- GL_ARB_depth_texture ------------------------- */ - -#ifndef GL_ARB_depth_texture -#define GL_ARB_depth_texture 1 - -#define GL_DEPTH_COMPONENT16_ARB 0x81A5 -#define GL_DEPTH_COMPONENT24_ARB 0x81A6 -#define GL_DEPTH_COMPONENT32_ARB 0x81A7 -#define GL_TEXTURE_DEPTH_SIZE_ARB 0x884A -#define GL_DEPTH_TEXTURE_MODE_ARB 0x884B - -#define GLEW_ARB_depth_texture GLEW_GET_VAR(__GLEW_ARB_depth_texture) - -#endif /* GL_ARB_depth_texture */ - -/* -------------------------- GL_ARB_draw_buffers -------------------------- */ - -#ifndef GL_ARB_draw_buffers -#define GL_ARB_draw_buffers 1 - -#define GL_MAX_DRAW_BUFFERS_ARB 0x8824 -#define GL_DRAW_BUFFER0_ARB 0x8825 -#define GL_DRAW_BUFFER1_ARB 0x8826 -#define GL_DRAW_BUFFER2_ARB 0x8827 -#define GL_DRAW_BUFFER3_ARB 0x8828 -#define GL_DRAW_BUFFER4_ARB 0x8829 -#define GL_DRAW_BUFFER5_ARB 0x882A -#define GL_DRAW_BUFFER6_ARB 0x882B -#define GL_DRAW_BUFFER7_ARB 0x882C -#define GL_DRAW_BUFFER8_ARB 0x882D -#define GL_DRAW_BUFFER9_ARB 0x882E -#define GL_DRAW_BUFFER10_ARB 0x882F -#define GL_DRAW_BUFFER11_ARB 0x8830 -#define GL_DRAW_BUFFER12_ARB 0x8831 -#define GL_DRAW_BUFFER13_ARB 0x8832 -#define GL_DRAW_BUFFER14_ARB 0x8833 -#define GL_DRAW_BUFFER15_ARB 0x8834 - -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSARBPROC) (GLsizei n, const GLenum* bufs); - -#define glDrawBuffersARB GLEW_GET_FUN(__glewDrawBuffersARB) - -#define GLEW_ARB_draw_buffers GLEW_GET_VAR(__GLEW_ARB_draw_buffers) - -#endif /* GL_ARB_draw_buffers */ - -/* ----------------------- GL_ARB_draw_buffers_blend ----------------------- */ - -#ifndef GL_ARB_draw_buffers_blend -#define GL_ARB_draw_buffers_blend 1 - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEIARBPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONIARBPROC) (GLuint buf, GLenum mode); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEIARBPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); -typedef void (GLAPIENTRY * PFNGLBLENDFUNCIARBPROC) (GLuint buf, GLenum src, GLenum dst); - -#define glBlendEquationSeparateiARB GLEW_GET_FUN(__glewBlendEquationSeparateiARB) -#define glBlendEquationiARB GLEW_GET_FUN(__glewBlendEquationiARB) -#define glBlendFuncSeparateiARB GLEW_GET_FUN(__glewBlendFuncSeparateiARB) -#define glBlendFunciARB GLEW_GET_FUN(__glewBlendFunciARB) - -#define GLEW_ARB_draw_buffers_blend GLEW_GET_VAR(__GLEW_ARB_draw_buffers_blend) - -#endif /* GL_ARB_draw_buffers_blend */ - -/* -------------------- GL_ARB_draw_elements_base_vertex ------------------- */ - -#ifndef GL_ARB_draw_elements_base_vertex -#define GL_ARB_draw_elements_base_vertex 1 - -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLint basevertex); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount, GLint basevertex); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices, GLint basevertex); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, const GLsizei* count, GLenum type, const GLvoid* const *indices, GLsizei primcount, const GLint *basevertex); - -#define glDrawElementsBaseVertex GLEW_GET_FUN(__glewDrawElementsBaseVertex) -#define glDrawElementsInstancedBaseVertex GLEW_GET_FUN(__glewDrawElementsInstancedBaseVertex) -#define glDrawRangeElementsBaseVertex GLEW_GET_FUN(__glewDrawRangeElementsBaseVertex) -#define glMultiDrawElementsBaseVertex GLEW_GET_FUN(__glewMultiDrawElementsBaseVertex) - -#define GLEW_ARB_draw_elements_base_vertex GLEW_GET_VAR(__GLEW_ARB_draw_elements_base_vertex) - -#endif /* GL_ARB_draw_elements_base_vertex */ - -/* -------------------------- GL_ARB_draw_indirect ------------------------- */ - -#ifndef GL_ARB_draw_indirect -#define GL_ARB_draw_indirect 1 - -#define GL_DRAW_INDIRECT_BUFFER 0x8F3F -#define GL_DRAW_INDIRECT_BUFFER_BINDING 0x8F43 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINDIRECTPROC) (GLenum mode, const GLvoid *indirect); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINDIRECTPROC) (GLenum mode, GLenum type, const GLvoid *indirect); - -#define glDrawArraysIndirect GLEW_GET_FUN(__glewDrawArraysIndirect) -#define glDrawElementsIndirect GLEW_GET_FUN(__glewDrawElementsIndirect) - -#define GLEW_ARB_draw_indirect GLEW_GET_VAR(__GLEW_ARB_draw_indirect) - -#endif /* GL_ARB_draw_indirect */ - -/* ------------------------- GL_ARB_draw_instanced ------------------------- */ - -#ifndef GL_ARB_draw_instanced -#define GL_ARB_draw_instanced 1 - -#define GLEW_ARB_draw_instanced GLEW_GET_VAR(__GLEW_ARB_draw_instanced) - -#endif /* GL_ARB_draw_instanced */ - -/* ------------------------ GL_ARB_enhanced_layouts ------------------------ */ - -#ifndef GL_ARB_enhanced_layouts -#define GL_ARB_enhanced_layouts 1 - -#define GL_LOCATION_COMPONENT 0x934A -#define GL_TRANSFORM_FEEDBACK_BUFFER_INDEX 0x934B -#define GL_TRANSFORM_FEEDBACK_BUFFER_STRIDE 0x934C - -#define GLEW_ARB_enhanced_layouts GLEW_GET_VAR(__GLEW_ARB_enhanced_layouts) - -#endif /* GL_ARB_enhanced_layouts */ - -/* -------------------- GL_ARB_explicit_attrib_location -------------------- */ - -#ifndef GL_ARB_explicit_attrib_location -#define GL_ARB_explicit_attrib_location 1 - -#define GLEW_ARB_explicit_attrib_location GLEW_GET_VAR(__GLEW_ARB_explicit_attrib_location) - -#endif /* GL_ARB_explicit_attrib_location */ - -/* -------------------- GL_ARB_explicit_uniform_location ------------------- */ - -#ifndef GL_ARB_explicit_uniform_location -#define GL_ARB_explicit_uniform_location 1 - -#define GL_MAX_UNIFORM_LOCATIONS 0x826E - -#define GLEW_ARB_explicit_uniform_location GLEW_GET_VAR(__GLEW_ARB_explicit_uniform_location) - -#endif /* GL_ARB_explicit_uniform_location */ - -/* ------------------- GL_ARB_fragment_coord_conventions ------------------- */ - -#ifndef GL_ARB_fragment_coord_conventions -#define GL_ARB_fragment_coord_conventions 1 - -#define GLEW_ARB_fragment_coord_conventions GLEW_GET_VAR(__GLEW_ARB_fragment_coord_conventions) - -#endif /* GL_ARB_fragment_coord_conventions */ - -/* --------------------- GL_ARB_fragment_layer_viewport -------------------- */ - -#ifndef GL_ARB_fragment_layer_viewport -#define GL_ARB_fragment_layer_viewport 1 - -#define GLEW_ARB_fragment_layer_viewport GLEW_GET_VAR(__GLEW_ARB_fragment_layer_viewport) - -#endif /* GL_ARB_fragment_layer_viewport */ - -/* ------------------------ GL_ARB_fragment_program ------------------------ */ - -#ifndef GL_ARB_fragment_program -#define GL_ARB_fragment_program 1 - -#define GL_FRAGMENT_PROGRAM_ARB 0x8804 -#define GL_PROGRAM_ALU_INSTRUCTIONS_ARB 0x8805 -#define GL_PROGRAM_TEX_INSTRUCTIONS_ARB 0x8806 -#define GL_PROGRAM_TEX_INDIRECTIONS_ARB 0x8807 -#define GL_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x8808 -#define GL_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x8809 -#define GL_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x880A -#define GL_MAX_PROGRAM_ALU_INSTRUCTIONS_ARB 0x880B -#define GL_MAX_PROGRAM_TEX_INSTRUCTIONS_ARB 0x880C -#define GL_MAX_PROGRAM_TEX_INDIRECTIONS_ARB 0x880D -#define GL_MAX_PROGRAM_NATIVE_ALU_INSTRUCTIONS_ARB 0x880E -#define GL_MAX_PROGRAM_NATIVE_TEX_INSTRUCTIONS_ARB 0x880F -#define GL_MAX_PROGRAM_NATIVE_TEX_INDIRECTIONS_ARB 0x8810 -#define GL_MAX_TEXTURE_COORDS_ARB 0x8871 -#define GL_MAX_TEXTURE_IMAGE_UNITS_ARB 0x8872 - -#define GLEW_ARB_fragment_program GLEW_GET_VAR(__GLEW_ARB_fragment_program) - -#endif /* GL_ARB_fragment_program */ - -/* --------------------- GL_ARB_fragment_program_shadow -------------------- */ - -#ifndef GL_ARB_fragment_program_shadow -#define GL_ARB_fragment_program_shadow 1 - -#define GLEW_ARB_fragment_program_shadow GLEW_GET_VAR(__GLEW_ARB_fragment_program_shadow) - -#endif /* GL_ARB_fragment_program_shadow */ - -/* ------------------------- GL_ARB_fragment_shader ------------------------ */ - -#ifndef GL_ARB_fragment_shader -#define GL_ARB_fragment_shader 1 - -#define GL_FRAGMENT_SHADER_ARB 0x8B30 -#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS_ARB 0x8B49 -#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT_ARB 0x8B8B - -#define GLEW_ARB_fragment_shader GLEW_GET_VAR(__GLEW_ARB_fragment_shader) - -#endif /* GL_ARB_fragment_shader */ - -/* ------------------- GL_ARB_framebuffer_no_attachments ------------------- */ - -#ifndef GL_ARB_framebuffer_no_attachments -#define GL_ARB_framebuffer_no_attachments 1 - -#define GL_FRAMEBUFFER_DEFAULT_WIDTH 0x9310 -#define GL_FRAMEBUFFER_DEFAULT_HEIGHT 0x9311 -#define GL_FRAMEBUFFER_DEFAULT_LAYERS 0x9312 -#define GL_FRAMEBUFFER_DEFAULT_SAMPLES 0x9313 -#define GL_FRAMEBUFFER_DEFAULT_FIXED_SAMPLE_LOCATIONS 0x9314 -#define GL_MAX_FRAMEBUFFER_WIDTH 0x9315 -#define GL_MAX_FRAMEBUFFER_HEIGHT 0x9316 -#define GL_MAX_FRAMEBUFFER_LAYERS 0x9317 -#define GL_MAX_FRAMEBUFFER_SAMPLES 0x9318 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERPARAMETERIPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDFRAMEBUFFERPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERPARAMETERIEXTPROC) (GLuint framebuffer, GLenum pname, GLint param); - -#define glFramebufferParameteri GLEW_GET_FUN(__glewFramebufferParameteri) -#define glGetFramebufferParameteriv GLEW_GET_FUN(__glewGetFramebufferParameteriv) -#define glGetNamedFramebufferParameterivEXT GLEW_GET_FUN(__glewGetNamedFramebufferParameterivEXT) -#define glNamedFramebufferParameteriEXT GLEW_GET_FUN(__glewNamedFramebufferParameteriEXT) - -#define GLEW_ARB_framebuffer_no_attachments GLEW_GET_VAR(__GLEW_ARB_framebuffer_no_attachments) - -#endif /* GL_ARB_framebuffer_no_attachments */ - -/* ----------------------- GL_ARB_framebuffer_object ----------------------- */ - -#ifndef GL_ARB_framebuffer_object -#define GL_ARB_framebuffer_object 1 - -#define GL_INVALID_FRAMEBUFFER_OPERATION 0x0506 -#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210 -#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211 -#define GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212 -#define GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213 -#define GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214 -#define GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215 -#define GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216 -#define GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217 -#define GL_FRAMEBUFFER_DEFAULT 0x8218 -#define GL_FRAMEBUFFER_UNDEFINED 0x8219 -#define GL_DEPTH_STENCIL_ATTACHMENT 0x821A -#define GL_INDEX 0x8222 -#define GL_MAX_RENDERBUFFER_SIZE 0x84E8 -#define GL_DEPTH_STENCIL 0x84F9 -#define GL_UNSIGNED_INT_24_8 0x84FA -#define GL_DEPTH24_STENCIL8 0x88F0 -#define GL_TEXTURE_STENCIL_SIZE 0x88F1 -#define GL_UNSIGNED_NORMALIZED 0x8C17 -#define GL_SRGB 0x8C40 -#define GL_DRAW_FRAMEBUFFER_BINDING 0x8CA6 -#define GL_FRAMEBUFFER_BINDING 0x8CA6 -#define GL_RENDERBUFFER_BINDING 0x8CA7 -#define GL_READ_FRAMEBUFFER 0x8CA8 -#define GL_DRAW_FRAMEBUFFER 0x8CA9 -#define GL_READ_FRAMEBUFFER_BINDING 0x8CAA -#define GL_RENDERBUFFER_SAMPLES 0x8CAB -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE 0x8CD0 -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME 0x8CD1 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL 0x8CD2 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE 0x8CD3 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 -#define GL_FRAMEBUFFER_COMPLETE 0x8CD5 -#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6 -#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7 -#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER 0x8CDB -#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER 0x8CDC -#define GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD -#define GL_MAX_COLOR_ATTACHMENTS 0x8CDF -#define GL_COLOR_ATTACHMENT0 0x8CE0 -#define GL_COLOR_ATTACHMENT1 0x8CE1 -#define GL_COLOR_ATTACHMENT2 0x8CE2 -#define GL_COLOR_ATTACHMENT3 0x8CE3 -#define GL_COLOR_ATTACHMENT4 0x8CE4 -#define GL_COLOR_ATTACHMENT5 0x8CE5 -#define GL_COLOR_ATTACHMENT6 0x8CE6 -#define GL_COLOR_ATTACHMENT7 0x8CE7 -#define GL_COLOR_ATTACHMENT8 0x8CE8 -#define GL_COLOR_ATTACHMENT9 0x8CE9 -#define GL_COLOR_ATTACHMENT10 0x8CEA -#define GL_COLOR_ATTACHMENT11 0x8CEB -#define GL_COLOR_ATTACHMENT12 0x8CEC -#define GL_COLOR_ATTACHMENT13 0x8CED -#define GL_COLOR_ATTACHMENT14 0x8CEE -#define GL_COLOR_ATTACHMENT15 0x8CEF -#define GL_DEPTH_ATTACHMENT 0x8D00 -#define GL_STENCIL_ATTACHMENT 0x8D20 -#define GL_FRAMEBUFFER 0x8D40 -#define GL_RENDERBUFFER 0x8D41 -#define GL_RENDERBUFFER_WIDTH 0x8D42 -#define GL_RENDERBUFFER_HEIGHT 0x8D43 -#define GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44 -#define GL_STENCIL_INDEX1 0x8D46 -#define GL_STENCIL_INDEX4 0x8D47 -#define GL_STENCIL_INDEX8 0x8D48 -#define GL_STENCIL_INDEX16 0x8D49 -#define GL_RENDERBUFFER_RED_SIZE 0x8D50 -#define GL_RENDERBUFFER_GREEN_SIZE 0x8D51 -#define GL_RENDERBUFFER_BLUE_SIZE 0x8D52 -#define GL_RENDERBUFFER_ALPHA_SIZE 0x8D53 -#define GL_RENDERBUFFER_DEPTH_SIZE 0x8D54 -#define GL_RENDERBUFFER_STENCIL_SIZE 0x8D55 -#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56 -#define GL_MAX_SAMPLES 0x8D57 - -typedef void (GLAPIENTRY * PFNGLBINDFRAMEBUFFERPROC) (GLenum target, GLuint framebuffer); -typedef void (GLAPIENTRY * PFNGLBINDRENDERBUFFERPROC) (GLenum target, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFERPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); -typedef GLenum (GLAPIENTRY * PFNGLCHECKFRAMEBUFFERSTATUSPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLDELETEFRAMEBUFFERSPROC) (GLsizei n, const GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLDELETERENDERBUFFERSPROC) (GLsizei n, const GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERRENDERBUFFERPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE1DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE2DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE3DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint layer); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYERPROC) (GLenum target,GLenum attachment, GLuint texture,GLint level,GLint layer); -typedef void (GLAPIENTRY * PFNGLGENFRAMEBUFFERSPROC) (GLsizei n, GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLGENRENDERBUFFERSPROC) (GLsizei n, GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLGENERATEMIPMAPPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC) (GLenum target, GLenum attachment, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETRENDERBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISFRAMEBUFFERPROC) (GLuint framebuffer); -typedef GLboolean (GLAPIENTRY * PFNGLISRENDERBUFFERPROC) (GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glBindFramebuffer GLEW_GET_FUN(__glewBindFramebuffer) -#define glBindRenderbuffer GLEW_GET_FUN(__glewBindRenderbuffer) -#define glBlitFramebuffer GLEW_GET_FUN(__glewBlitFramebuffer) -#define glCheckFramebufferStatus GLEW_GET_FUN(__glewCheckFramebufferStatus) -#define glDeleteFramebuffers GLEW_GET_FUN(__glewDeleteFramebuffers) -#define glDeleteRenderbuffers GLEW_GET_FUN(__glewDeleteRenderbuffers) -#define glFramebufferRenderbuffer GLEW_GET_FUN(__glewFramebufferRenderbuffer) -#define glFramebufferTexture1D GLEW_GET_FUN(__glewFramebufferTexture1D) -#define glFramebufferTexture2D GLEW_GET_FUN(__glewFramebufferTexture2D) -#define glFramebufferTexture3D GLEW_GET_FUN(__glewFramebufferTexture3D) -#define glFramebufferTextureLayer GLEW_GET_FUN(__glewFramebufferTextureLayer) -#define glGenFramebuffers GLEW_GET_FUN(__glewGenFramebuffers) -#define glGenRenderbuffers GLEW_GET_FUN(__glewGenRenderbuffers) -#define glGenerateMipmap GLEW_GET_FUN(__glewGenerateMipmap) -#define glGetFramebufferAttachmentParameteriv GLEW_GET_FUN(__glewGetFramebufferAttachmentParameteriv) -#define glGetRenderbufferParameteriv GLEW_GET_FUN(__glewGetRenderbufferParameteriv) -#define glIsFramebuffer GLEW_GET_FUN(__glewIsFramebuffer) -#define glIsRenderbuffer GLEW_GET_FUN(__glewIsRenderbuffer) -#define glRenderbufferStorage GLEW_GET_FUN(__glewRenderbufferStorage) -#define glRenderbufferStorageMultisample GLEW_GET_FUN(__glewRenderbufferStorageMultisample) - -#define GLEW_ARB_framebuffer_object GLEW_GET_VAR(__GLEW_ARB_framebuffer_object) - -#endif /* GL_ARB_framebuffer_object */ - -/* ------------------------ GL_ARB_framebuffer_sRGB ------------------------ */ - -#ifndef GL_ARB_framebuffer_sRGB -#define GL_ARB_framebuffer_sRGB 1 - -#define GL_FRAMEBUFFER_SRGB 0x8DB9 - -#define GLEW_ARB_framebuffer_sRGB GLEW_GET_VAR(__GLEW_ARB_framebuffer_sRGB) - -#endif /* GL_ARB_framebuffer_sRGB */ - -/* ------------------------ GL_ARB_geometry_shader4 ------------------------ */ - -#ifndef GL_ARB_geometry_shader4 -#define GL_ARB_geometry_shader4 1 - -#define GL_LINES_ADJACENCY_ARB 0xA -#define GL_LINE_STRIP_ADJACENCY_ARB 0xB -#define GL_TRIANGLES_ADJACENCY_ARB 0xC -#define GL_TRIANGLE_STRIP_ADJACENCY_ARB 0xD -#define GL_PROGRAM_POINT_SIZE_ARB 0x8642 -#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_ARB 0x8C29 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4 -#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_ARB 0x8DA7 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_ARB 0x8DA8 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_ARB 0x8DA9 -#define GL_GEOMETRY_SHADER_ARB 0x8DD9 -#define GL_GEOMETRY_VERTICES_OUT_ARB 0x8DDA -#define GL_GEOMETRY_INPUT_TYPE_ARB 0x8DDB -#define GL_GEOMETRY_OUTPUT_TYPE_ARB 0x8DDC -#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_ARB 0x8DDD -#define GL_MAX_VERTEX_VARYING_COMPONENTS_ARB 0x8DDE -#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_ARB 0x8DDF -#define GL_MAX_GEOMETRY_OUTPUT_VERTICES_ARB 0x8DE0 -#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_ARB 0x8DE1 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREFACEARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYERARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIARBPROC) (GLuint program, GLenum pname, GLint value); - -#define glFramebufferTextureARB GLEW_GET_FUN(__glewFramebufferTextureARB) -#define glFramebufferTextureFaceARB GLEW_GET_FUN(__glewFramebufferTextureFaceARB) -#define glFramebufferTextureLayerARB GLEW_GET_FUN(__glewFramebufferTextureLayerARB) -#define glProgramParameteriARB GLEW_GET_FUN(__glewProgramParameteriARB) - -#define GLEW_ARB_geometry_shader4 GLEW_GET_VAR(__GLEW_ARB_geometry_shader4) - -#endif /* GL_ARB_geometry_shader4 */ - -/* ----------------------- GL_ARB_get_program_binary ----------------------- */ - -#ifndef GL_ARB_get_program_binary -#define GL_ARB_get_program_binary 1 - -#define GL_PROGRAM_BINARY_RETRIEVABLE_HINT 0x8257 -#define GL_PROGRAM_BINARY_LENGTH 0x8741 -#define GL_NUM_PROGRAM_BINARY_FORMATS 0x87FE -#define GL_PROGRAM_BINARY_FORMATS 0x87FF - -typedef void (GLAPIENTRY * PFNGLGETPROGRAMBINARYPROC) (GLuint program, GLsizei bufSize, GLsizei* length, GLenum *binaryFormat, GLvoid*binary); -typedef void (GLAPIENTRY * PFNGLPROGRAMBINARYPROC) (GLuint program, GLenum binaryFormat, const GLvoid *binary, GLsizei length); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIPROC) (GLuint program, GLenum pname, GLint value); - -#define glGetProgramBinary GLEW_GET_FUN(__glewGetProgramBinary) -#define glProgramBinary GLEW_GET_FUN(__glewProgramBinary) -#define glProgramParameteri GLEW_GET_FUN(__glewProgramParameteri) - -#define GLEW_ARB_get_program_binary GLEW_GET_VAR(__GLEW_ARB_get_program_binary) - -#endif /* GL_ARB_get_program_binary */ - -/* --------------------------- GL_ARB_gpu_shader5 -------------------------- */ - -#ifndef GL_ARB_gpu_shader5 -#define GL_ARB_gpu_shader5 1 - -#define GL_GEOMETRY_SHADER_INVOCATIONS 0x887F -#define GL_MAX_GEOMETRY_SHADER_INVOCATIONS 0x8E5A -#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET 0x8E5B -#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET 0x8E5C -#define GL_FRAGMENT_INTERPOLATION_OFFSET_BITS 0x8E5D -#define GL_MAX_VERTEX_STREAMS 0x8E71 - -#define GLEW_ARB_gpu_shader5 GLEW_GET_VAR(__GLEW_ARB_gpu_shader5) - -#endif /* GL_ARB_gpu_shader5 */ - -/* ------------------------- GL_ARB_gpu_shader_fp64 ------------------------ */ - -#ifndef GL_ARB_gpu_shader_fp64 -#define GL_ARB_gpu_shader_fp64 1 - -#define GL_DOUBLE_MAT2 0x8F46 -#define GL_DOUBLE_MAT3 0x8F47 -#define GL_DOUBLE_MAT4 0x8F48 -#define GL_DOUBLE_MAT2x3 0x8F49 -#define GL_DOUBLE_MAT2x4 0x8F4A -#define GL_DOUBLE_MAT3x2 0x8F4B -#define GL_DOUBLE_MAT3x4 0x8F4C -#define GL_DOUBLE_MAT4x2 0x8F4D -#define GL_DOUBLE_MAT4x3 0x8F4E -#define GL_DOUBLE_VEC2 0x8FFC -#define GL_DOUBLE_VEC3 0x8FFD -#define GL_DOUBLE_VEC4 0x8FFE - -typedef void (GLAPIENTRY * PFNGLGETUNIFORMDVPROC) (GLuint program, GLint location, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLUNIFORM1DPROC) (GLint location, GLdouble x); -typedef void (GLAPIENTRY * PFNGLUNIFORM1DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2DPROC) (GLint location, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLUNIFORM2DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3DPROC) (GLint location, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLUNIFORM3DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4DPROC) (GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLUNIFORM4DVPROC) (GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2X4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3X4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4X3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); - -#define glGetUniformdv GLEW_GET_FUN(__glewGetUniformdv) -#define glUniform1d GLEW_GET_FUN(__glewUniform1d) -#define glUniform1dv GLEW_GET_FUN(__glewUniform1dv) -#define glUniform2d GLEW_GET_FUN(__glewUniform2d) -#define glUniform2dv GLEW_GET_FUN(__glewUniform2dv) -#define glUniform3d GLEW_GET_FUN(__glewUniform3d) -#define glUniform3dv GLEW_GET_FUN(__glewUniform3dv) -#define glUniform4d GLEW_GET_FUN(__glewUniform4d) -#define glUniform4dv GLEW_GET_FUN(__glewUniform4dv) -#define glUniformMatrix2dv GLEW_GET_FUN(__glewUniformMatrix2dv) -#define glUniformMatrix2x3dv GLEW_GET_FUN(__glewUniformMatrix2x3dv) -#define glUniformMatrix2x4dv GLEW_GET_FUN(__glewUniformMatrix2x4dv) -#define glUniformMatrix3dv GLEW_GET_FUN(__glewUniformMatrix3dv) -#define glUniformMatrix3x2dv GLEW_GET_FUN(__glewUniformMatrix3x2dv) -#define glUniformMatrix3x4dv GLEW_GET_FUN(__glewUniformMatrix3x4dv) -#define glUniformMatrix4dv GLEW_GET_FUN(__glewUniformMatrix4dv) -#define glUniformMatrix4x2dv GLEW_GET_FUN(__glewUniformMatrix4x2dv) -#define glUniformMatrix4x3dv GLEW_GET_FUN(__glewUniformMatrix4x3dv) - -#define GLEW_ARB_gpu_shader_fp64 GLEW_GET_VAR(__GLEW_ARB_gpu_shader_fp64) - -#endif /* GL_ARB_gpu_shader_fp64 */ - -/* ------------------------ GL_ARB_half_float_pixel ------------------------ */ - -#ifndef GL_ARB_half_float_pixel -#define GL_ARB_half_float_pixel 1 - -#define GL_HALF_FLOAT_ARB 0x140B - -#define GLEW_ARB_half_float_pixel GLEW_GET_VAR(__GLEW_ARB_half_float_pixel) - -#endif /* GL_ARB_half_float_pixel */ - -/* ------------------------ GL_ARB_half_float_vertex ----------------------- */ - -#ifndef GL_ARB_half_float_vertex -#define GL_ARB_half_float_vertex 1 - -#define GL_HALF_FLOAT 0x140B - -#define GLEW_ARB_half_float_vertex GLEW_GET_VAR(__GLEW_ARB_half_float_vertex) - -#endif /* GL_ARB_half_float_vertex */ - -/* ----------------------------- GL_ARB_imaging ---------------------------- */ - -#ifndef GL_ARB_imaging -#define GL_ARB_imaging 1 - -#define GL_CONSTANT_COLOR 0x8001 -#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 -#define GL_CONSTANT_ALPHA 0x8003 -#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 -#define GL_BLEND_COLOR 0x8005 -#define GL_FUNC_ADD 0x8006 -#define GL_MIN 0x8007 -#define GL_MAX 0x8008 -#define GL_BLEND_EQUATION 0x8009 -#define GL_FUNC_SUBTRACT 0x800A -#define GL_FUNC_REVERSE_SUBTRACT 0x800B -#define GL_CONVOLUTION_1D 0x8010 -#define GL_CONVOLUTION_2D 0x8011 -#define GL_SEPARABLE_2D 0x8012 -#define GL_CONVOLUTION_BORDER_MODE 0x8013 -#define GL_CONVOLUTION_FILTER_SCALE 0x8014 -#define GL_CONVOLUTION_FILTER_BIAS 0x8015 -#define GL_REDUCE 0x8016 -#define GL_CONVOLUTION_FORMAT 0x8017 -#define GL_CONVOLUTION_WIDTH 0x8018 -#define GL_CONVOLUTION_HEIGHT 0x8019 -#define GL_MAX_CONVOLUTION_WIDTH 0x801A -#define GL_MAX_CONVOLUTION_HEIGHT 0x801B -#define GL_POST_CONVOLUTION_RED_SCALE 0x801C -#define GL_POST_CONVOLUTION_GREEN_SCALE 0x801D -#define GL_POST_CONVOLUTION_BLUE_SCALE 0x801E -#define GL_POST_CONVOLUTION_ALPHA_SCALE 0x801F -#define GL_POST_CONVOLUTION_RED_BIAS 0x8020 -#define GL_POST_CONVOLUTION_GREEN_BIAS 0x8021 -#define GL_POST_CONVOLUTION_BLUE_BIAS 0x8022 -#define GL_POST_CONVOLUTION_ALPHA_BIAS 0x8023 -#define GL_HISTOGRAM 0x8024 -#define GL_PROXY_HISTOGRAM 0x8025 -#define GL_HISTOGRAM_WIDTH 0x8026 -#define GL_HISTOGRAM_FORMAT 0x8027 -#define GL_HISTOGRAM_RED_SIZE 0x8028 -#define GL_HISTOGRAM_GREEN_SIZE 0x8029 -#define GL_HISTOGRAM_BLUE_SIZE 0x802A -#define GL_HISTOGRAM_ALPHA_SIZE 0x802B -#define GL_HISTOGRAM_LUMINANCE_SIZE 0x802C -#define GL_HISTOGRAM_SINK 0x802D -#define GL_MINMAX 0x802E -#define GL_MINMAX_FORMAT 0x802F -#define GL_MINMAX_SINK 0x8030 -#define GL_TABLE_TOO_LARGE 0x8031 -#define GL_COLOR_MATRIX 0x80B1 -#define GL_COLOR_MATRIX_STACK_DEPTH 0x80B2 -#define GL_MAX_COLOR_MATRIX_STACK_DEPTH 0x80B3 -#define GL_POST_COLOR_MATRIX_RED_SCALE 0x80B4 -#define GL_POST_COLOR_MATRIX_GREEN_SCALE 0x80B5 -#define GL_POST_COLOR_MATRIX_BLUE_SCALE 0x80B6 -#define GL_POST_COLOR_MATRIX_ALPHA_SCALE 0x80B7 -#define GL_POST_COLOR_MATRIX_RED_BIAS 0x80B8 -#define GL_POST_COLOR_MATRIX_GREEN_BIAS 0x80B9 -#define GL_POST_COLOR_MATRIX_BLUE_BIAS 0x80BA -#define GL_POST_COLOR_MATRIX_ALPHA_BIAS 0x80BB -#define GL_COLOR_TABLE 0x80D0 -#define GL_POST_CONVOLUTION_COLOR_TABLE 0x80D1 -#define GL_POST_COLOR_MATRIX_COLOR_TABLE 0x80D2 -#define GL_PROXY_COLOR_TABLE 0x80D3 -#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE 0x80D4 -#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE 0x80D5 -#define GL_COLOR_TABLE_SCALE 0x80D6 -#define GL_COLOR_TABLE_BIAS 0x80D7 -#define GL_COLOR_TABLE_FORMAT 0x80D8 -#define GL_COLOR_TABLE_WIDTH 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE 0x80DF -#define GL_IGNORE_BORDER 0x8150 -#define GL_CONSTANT_BORDER 0x8151 -#define GL_WRAP_BORDER 0x8152 -#define GL_REPLICATE_BORDER 0x8153 -#define GL_CONVOLUTION_BORDER_COLOR 0x8154 - -typedef void (GLAPIENTRY * PFNGLCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIPROC) (GLenum target, GLenum pname, GLint params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPROC) (GLenum target, GLboolean reset, GLenum format, GLenum types, GLvoid *values); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETSEPARABLEFILTERPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); -typedef void (GLAPIENTRY * PFNGLHISTOGRAMPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLMINMAXPROC) (GLenum target, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLRESETHISTOGRAMPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLRESETMINMAXPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLSEPARABLEFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); - -#define glColorSubTable GLEW_GET_FUN(__glewColorSubTable) -#define glColorTable GLEW_GET_FUN(__glewColorTable) -#define glColorTableParameterfv GLEW_GET_FUN(__glewColorTableParameterfv) -#define glColorTableParameteriv GLEW_GET_FUN(__glewColorTableParameteriv) -#define glConvolutionFilter1D GLEW_GET_FUN(__glewConvolutionFilter1D) -#define glConvolutionFilter2D GLEW_GET_FUN(__glewConvolutionFilter2D) -#define glConvolutionParameterf GLEW_GET_FUN(__glewConvolutionParameterf) -#define glConvolutionParameterfv GLEW_GET_FUN(__glewConvolutionParameterfv) -#define glConvolutionParameteri GLEW_GET_FUN(__glewConvolutionParameteri) -#define glConvolutionParameteriv GLEW_GET_FUN(__glewConvolutionParameteriv) -#define glCopyColorSubTable GLEW_GET_FUN(__glewCopyColorSubTable) -#define glCopyColorTable GLEW_GET_FUN(__glewCopyColorTable) -#define glCopyConvolutionFilter1D GLEW_GET_FUN(__glewCopyConvolutionFilter1D) -#define glCopyConvolutionFilter2D GLEW_GET_FUN(__glewCopyConvolutionFilter2D) -#define glGetColorTable GLEW_GET_FUN(__glewGetColorTable) -#define glGetColorTableParameterfv GLEW_GET_FUN(__glewGetColorTableParameterfv) -#define glGetColorTableParameteriv GLEW_GET_FUN(__glewGetColorTableParameteriv) -#define glGetConvolutionFilter GLEW_GET_FUN(__glewGetConvolutionFilter) -#define glGetConvolutionParameterfv GLEW_GET_FUN(__glewGetConvolutionParameterfv) -#define glGetConvolutionParameteriv GLEW_GET_FUN(__glewGetConvolutionParameteriv) -#define glGetHistogram GLEW_GET_FUN(__glewGetHistogram) -#define glGetHistogramParameterfv GLEW_GET_FUN(__glewGetHistogramParameterfv) -#define glGetHistogramParameteriv GLEW_GET_FUN(__glewGetHistogramParameteriv) -#define glGetMinmax GLEW_GET_FUN(__glewGetMinmax) -#define glGetMinmaxParameterfv GLEW_GET_FUN(__glewGetMinmaxParameterfv) -#define glGetMinmaxParameteriv GLEW_GET_FUN(__glewGetMinmaxParameteriv) -#define glGetSeparableFilter GLEW_GET_FUN(__glewGetSeparableFilter) -#define glHistogram GLEW_GET_FUN(__glewHistogram) -#define glMinmax GLEW_GET_FUN(__glewMinmax) -#define glResetHistogram GLEW_GET_FUN(__glewResetHistogram) -#define glResetMinmax GLEW_GET_FUN(__glewResetMinmax) -#define glSeparableFilter2D GLEW_GET_FUN(__glewSeparableFilter2D) - -#define GLEW_ARB_imaging GLEW_GET_VAR(__GLEW_ARB_imaging) - -#endif /* GL_ARB_imaging */ - -/* ----------------------- GL_ARB_indirect_parameters ---------------------- */ - -#ifndef GL_ARB_indirect_parameters -#define GL_ARB_indirect_parameters 1 - -#define GL_PARAMETER_BUFFER_ARB 0x80EE -#define GL_PARAMETER_BUFFER_BINDING_ARB 0x80EF - -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSINDIRECTCOUNTARBPROC) (GLenum mode, const GLvoid *indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTARBPROC) (GLenum mode, GLenum type, const GLvoid *indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride); - -#define glMultiDrawArraysIndirectCountARB GLEW_GET_FUN(__glewMultiDrawArraysIndirectCountARB) -#define glMultiDrawElementsIndirectCountARB GLEW_GET_FUN(__glewMultiDrawElementsIndirectCountARB) - -#define GLEW_ARB_indirect_parameters GLEW_GET_VAR(__GLEW_ARB_indirect_parameters) - -#endif /* GL_ARB_indirect_parameters */ - -/* ------------------------ GL_ARB_instanced_arrays ------------------------ */ - -#ifndef GL_ARB_instanced_arrays -#define GL_ARB_instanced_arrays 1 - -#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ARB 0x88FE - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDARBPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDARBPROC) (GLenum mode, GLsizei count, GLenum type, const void* indices, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBDIVISORARBPROC) (GLuint index, GLuint divisor); - -#define glDrawArraysInstancedARB GLEW_GET_FUN(__glewDrawArraysInstancedARB) -#define glDrawElementsInstancedARB GLEW_GET_FUN(__glewDrawElementsInstancedARB) -#define glVertexAttribDivisorARB GLEW_GET_FUN(__glewVertexAttribDivisorARB) - -#define GLEW_ARB_instanced_arrays GLEW_GET_VAR(__GLEW_ARB_instanced_arrays) - -#endif /* GL_ARB_instanced_arrays */ - -/* ---------------------- GL_ARB_internalformat_query ---------------------- */ - -#ifndef GL_ARB_internalformat_query -#define GL_ARB_internalformat_query 1 - -#define GL_NUM_SAMPLE_COUNTS 0x9380 - -typedef void (GLAPIENTRY * PFNGLGETINTERNALFORMATIVPROC) (GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize, GLint* params); - -#define glGetInternalformativ GLEW_GET_FUN(__glewGetInternalformativ) - -#define GLEW_ARB_internalformat_query GLEW_GET_VAR(__GLEW_ARB_internalformat_query) - -#endif /* GL_ARB_internalformat_query */ - -/* ---------------------- GL_ARB_internalformat_query2 --------------------- */ - -#ifndef GL_ARB_internalformat_query2 -#define GL_ARB_internalformat_query2 1 - -#define GL_INTERNALFORMAT_SUPPORTED 0x826F -#define GL_INTERNALFORMAT_PREFERRED 0x8270 -#define GL_INTERNALFORMAT_RED_SIZE 0x8271 -#define GL_INTERNALFORMAT_GREEN_SIZE 0x8272 -#define GL_INTERNALFORMAT_BLUE_SIZE 0x8273 -#define GL_INTERNALFORMAT_ALPHA_SIZE 0x8274 -#define GL_INTERNALFORMAT_DEPTH_SIZE 0x8275 -#define GL_INTERNALFORMAT_STENCIL_SIZE 0x8276 -#define GL_INTERNALFORMAT_SHARED_SIZE 0x8277 -#define GL_INTERNALFORMAT_RED_TYPE 0x8278 -#define GL_INTERNALFORMAT_GREEN_TYPE 0x8279 -#define GL_INTERNALFORMAT_BLUE_TYPE 0x827A -#define GL_INTERNALFORMAT_ALPHA_TYPE 0x827B -#define GL_INTERNALFORMAT_DEPTH_TYPE 0x827C -#define GL_INTERNALFORMAT_STENCIL_TYPE 0x827D -#define GL_MAX_WIDTH 0x827E -#define GL_MAX_HEIGHT 0x827F -#define GL_MAX_DEPTH 0x8280 -#define GL_MAX_LAYERS 0x8281 -#define GL_MAX_COMBINED_DIMENSIONS 0x8282 -#define GL_COLOR_COMPONENTS 0x8283 -#define GL_DEPTH_COMPONENTS 0x8284 -#define GL_STENCIL_COMPONENTS 0x8285 -#define GL_COLOR_RENDERABLE 0x8286 -#define GL_DEPTH_RENDERABLE 0x8287 -#define GL_STENCIL_RENDERABLE 0x8288 -#define GL_FRAMEBUFFER_RENDERABLE 0x8289 -#define GL_FRAMEBUFFER_RENDERABLE_LAYERED 0x828A -#define GL_FRAMEBUFFER_BLEND 0x828B -#define GL_READ_PIXELS 0x828C -#define GL_READ_PIXELS_FORMAT 0x828D -#define GL_READ_PIXELS_TYPE 0x828E -#define GL_TEXTURE_IMAGE_FORMAT 0x828F -#define GL_TEXTURE_IMAGE_TYPE 0x8290 -#define GL_GET_TEXTURE_IMAGE_FORMAT 0x8291 -#define GL_GET_TEXTURE_IMAGE_TYPE 0x8292 -#define GL_MIPMAP 0x8293 -#define GL_MANUAL_GENERATE_MIPMAP 0x8294 -#define GL_AUTO_GENERATE_MIPMAP 0x8295 -#define GL_COLOR_ENCODING 0x8296 -#define GL_SRGB_READ 0x8297 -#define GL_SRGB_WRITE 0x8298 -#define GL_SRGB_DECODE_ARB 0x8299 -#define GL_FILTER 0x829A -#define GL_VERTEX_TEXTURE 0x829B -#define GL_TESS_CONTROL_TEXTURE 0x829C -#define GL_TESS_EVALUATION_TEXTURE 0x829D -#define GL_GEOMETRY_TEXTURE 0x829E -#define GL_FRAGMENT_TEXTURE 0x829F -#define GL_COMPUTE_TEXTURE 0x82A0 -#define GL_TEXTURE_SHADOW 0x82A1 -#define GL_TEXTURE_GATHER 0x82A2 -#define GL_TEXTURE_GATHER_SHADOW 0x82A3 -#define GL_SHADER_IMAGE_LOAD 0x82A4 -#define GL_SHADER_IMAGE_STORE 0x82A5 -#define GL_SHADER_IMAGE_ATOMIC 0x82A6 -#define GL_IMAGE_TEXEL_SIZE 0x82A7 -#define GL_IMAGE_COMPATIBILITY_CLASS 0x82A8 -#define GL_IMAGE_PIXEL_FORMAT 0x82A9 -#define GL_IMAGE_PIXEL_TYPE 0x82AA -#define GL_SIMULTANEOUS_TEXTURE_AND_DEPTH_TEST 0x82AC -#define GL_SIMULTANEOUS_TEXTURE_AND_STENCIL_TEST 0x82AD -#define GL_SIMULTANEOUS_TEXTURE_AND_DEPTH_WRITE 0x82AE -#define GL_SIMULTANEOUS_TEXTURE_AND_STENCIL_WRITE 0x82AF -#define GL_TEXTURE_COMPRESSED_BLOCK_WIDTH 0x82B1 -#define GL_TEXTURE_COMPRESSED_BLOCK_HEIGHT 0x82B2 -#define GL_TEXTURE_COMPRESSED_BLOCK_SIZE 0x82B3 -#define GL_CLEAR_BUFFER 0x82B4 -#define GL_TEXTURE_VIEW 0x82B5 -#define GL_VIEW_COMPATIBILITY_CLASS 0x82B6 -#define GL_FULL_SUPPORT 0x82B7 -#define GL_CAVEAT_SUPPORT 0x82B8 -#define GL_IMAGE_CLASS_4_X_32 0x82B9 -#define GL_IMAGE_CLASS_2_X_32 0x82BA -#define GL_IMAGE_CLASS_1_X_32 0x82BB -#define GL_IMAGE_CLASS_4_X_16 0x82BC -#define GL_IMAGE_CLASS_2_X_16 0x82BD -#define GL_IMAGE_CLASS_1_X_16 0x82BE -#define GL_IMAGE_CLASS_4_X_8 0x82BF -#define GL_IMAGE_CLASS_2_X_8 0x82C0 -#define GL_IMAGE_CLASS_1_X_8 0x82C1 -#define GL_IMAGE_CLASS_11_11_10 0x82C2 -#define GL_IMAGE_CLASS_10_10_10_2 0x82C3 -#define GL_VIEW_CLASS_128_BITS 0x82C4 -#define GL_VIEW_CLASS_96_BITS 0x82C5 -#define GL_VIEW_CLASS_64_BITS 0x82C6 -#define GL_VIEW_CLASS_48_BITS 0x82C7 -#define GL_VIEW_CLASS_32_BITS 0x82C8 -#define GL_VIEW_CLASS_24_BITS 0x82C9 -#define GL_VIEW_CLASS_16_BITS 0x82CA -#define GL_VIEW_CLASS_8_BITS 0x82CB -#define GL_VIEW_CLASS_S3TC_DXT1_RGB 0x82CC -#define GL_VIEW_CLASS_S3TC_DXT1_RGBA 0x82CD -#define GL_VIEW_CLASS_S3TC_DXT3_RGBA 0x82CE -#define GL_VIEW_CLASS_S3TC_DXT5_RGBA 0x82CF -#define GL_VIEW_CLASS_RGTC1_RED 0x82D0 -#define GL_VIEW_CLASS_RGTC2_RG 0x82D1 -#define GL_VIEW_CLASS_BPTC_UNORM 0x82D2 -#define GL_VIEW_CLASS_BPTC_FLOAT 0x82D3 - -typedef void (GLAPIENTRY * PFNGLGETINTERNALFORMATI64VPROC) (GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize, GLint64* params); - -#define glGetInternalformati64v GLEW_GET_FUN(__glewGetInternalformati64v) - -#define GLEW_ARB_internalformat_query2 GLEW_GET_VAR(__GLEW_ARB_internalformat_query2) - -#endif /* GL_ARB_internalformat_query2 */ - -/* ----------------------- GL_ARB_invalidate_subdata ----------------------- */ - -#ifndef GL_ARB_invalidate_subdata -#define GL_ARB_invalidate_subdata 1 - -typedef void (GLAPIENTRY * PFNGLINVALIDATEBUFFERDATAPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLINVALIDATEBUFFERSUBDATAPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length); -typedef void (GLAPIENTRY * PFNGLINVALIDATEFRAMEBUFFERPROC) (GLenum target, GLsizei numAttachments, const GLenum* attachments); -typedef void (GLAPIENTRY * PFNGLINVALIDATESUBFRAMEBUFFERPROC) (GLenum target, GLsizei numAttachments, const GLenum* attachments, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLINVALIDATETEXIMAGEPROC) (GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLINVALIDATETEXSUBIMAGEPROC) (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth); - -#define glInvalidateBufferData GLEW_GET_FUN(__glewInvalidateBufferData) -#define glInvalidateBufferSubData GLEW_GET_FUN(__glewInvalidateBufferSubData) -#define glInvalidateFramebuffer GLEW_GET_FUN(__glewInvalidateFramebuffer) -#define glInvalidateSubFramebuffer GLEW_GET_FUN(__glewInvalidateSubFramebuffer) -#define glInvalidateTexImage GLEW_GET_FUN(__glewInvalidateTexImage) -#define glInvalidateTexSubImage GLEW_GET_FUN(__glewInvalidateTexSubImage) - -#define GLEW_ARB_invalidate_subdata GLEW_GET_VAR(__GLEW_ARB_invalidate_subdata) - -#endif /* GL_ARB_invalidate_subdata */ - -/* ---------------------- GL_ARB_map_buffer_alignment ---------------------- */ - -#ifndef GL_ARB_map_buffer_alignment -#define GL_ARB_map_buffer_alignment 1 - -#define GL_MIN_MAP_BUFFER_ALIGNMENT 0x90BC - -#define GLEW_ARB_map_buffer_alignment GLEW_GET_VAR(__GLEW_ARB_map_buffer_alignment) - -#endif /* GL_ARB_map_buffer_alignment */ - -/* ------------------------ GL_ARB_map_buffer_range ------------------------ */ - -#ifndef GL_ARB_map_buffer_range -#define GL_ARB_map_buffer_range 1 - -#define GL_MAP_READ_BIT 0x0001 -#define GL_MAP_WRITE_BIT 0x0002 -#define GL_MAP_INVALIDATE_RANGE_BIT 0x0004 -#define GL_MAP_INVALIDATE_BUFFER_BIT 0x0008 -#define GL_MAP_FLUSH_EXPLICIT_BIT 0x0010 -#define GL_MAP_UNSYNCHRONIZED_BIT 0x0020 - -typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); - -#define glFlushMappedBufferRange GLEW_GET_FUN(__glewFlushMappedBufferRange) -#define glMapBufferRange GLEW_GET_FUN(__glewMapBufferRange) - -#define GLEW_ARB_map_buffer_range GLEW_GET_VAR(__GLEW_ARB_map_buffer_range) - -#endif /* GL_ARB_map_buffer_range */ - -/* ------------------------- GL_ARB_matrix_palette ------------------------- */ - -#ifndef GL_ARB_matrix_palette -#define GL_ARB_matrix_palette 1 - -#define GL_MATRIX_PALETTE_ARB 0x8840 -#define GL_MAX_MATRIX_PALETTE_STACK_DEPTH_ARB 0x8841 -#define GL_MAX_PALETTE_MATRICES_ARB 0x8842 -#define GL_CURRENT_PALETTE_MATRIX_ARB 0x8843 -#define GL_MATRIX_INDEX_ARRAY_ARB 0x8844 -#define GL_CURRENT_MATRIX_INDEX_ARB 0x8845 -#define GL_MATRIX_INDEX_ARRAY_SIZE_ARB 0x8846 -#define GL_MATRIX_INDEX_ARRAY_TYPE_ARB 0x8847 -#define GL_MATRIX_INDEX_ARRAY_STRIDE_ARB 0x8848 -#define GL_MATRIX_INDEX_ARRAY_POINTER_ARB 0x8849 - -typedef void (GLAPIENTRY * PFNGLCURRENTPALETTEMATRIXARBPROC) (GLint index); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUBVARBPROC) (GLint size, GLubyte *indices); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUIVARBPROC) (GLint size, GLuint *indices); -typedef void (GLAPIENTRY * PFNGLMATRIXINDEXUSVARBPROC) (GLint size, GLushort *indices); - -#define glCurrentPaletteMatrixARB GLEW_GET_FUN(__glewCurrentPaletteMatrixARB) -#define glMatrixIndexPointerARB GLEW_GET_FUN(__glewMatrixIndexPointerARB) -#define glMatrixIndexubvARB GLEW_GET_FUN(__glewMatrixIndexubvARB) -#define glMatrixIndexuivARB GLEW_GET_FUN(__glewMatrixIndexuivARB) -#define glMatrixIndexusvARB GLEW_GET_FUN(__glewMatrixIndexusvARB) - -#define GLEW_ARB_matrix_palette GLEW_GET_VAR(__GLEW_ARB_matrix_palette) - -#endif /* GL_ARB_matrix_palette */ - -/* --------------------------- GL_ARB_multi_bind --------------------------- */ - -#ifndef GL_ARB_multi_bind -#define GL_ARB_multi_bind 1 - -typedef void (GLAPIENTRY * PFNGLBINDBUFFERSBASEPROC) (GLenum target, GLuint first, GLsizei count, const GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERSRANGEPROC) (GLenum target, GLuint first, GLsizei count, const GLuint* buffers, const GLintptr *offsets, const GLsizeiptr *sizes); -typedef void (GLAPIENTRY * PFNGLBINDIMAGETEXTURESPROC) (GLuint first, GLsizei count, const GLuint* textures); -typedef void (GLAPIENTRY * PFNGLBINDSAMPLERSPROC) (GLuint first, GLsizei count, const GLuint* samplers); -typedef void (GLAPIENTRY * PFNGLBINDTEXTURESPROC) (GLuint first, GLsizei count, const GLuint* textures); -typedef void (GLAPIENTRY * PFNGLBINDVERTEXBUFFERSPROC) (GLuint first, GLsizei count, const GLuint* buffers, const GLintptr *offsets, const GLsizei *strides); - -#define glBindBuffersBase GLEW_GET_FUN(__glewBindBuffersBase) -#define glBindBuffersRange GLEW_GET_FUN(__glewBindBuffersRange) -#define glBindImageTextures GLEW_GET_FUN(__glewBindImageTextures) -#define glBindSamplers GLEW_GET_FUN(__glewBindSamplers) -#define glBindTextures GLEW_GET_FUN(__glewBindTextures) -#define glBindVertexBuffers GLEW_GET_FUN(__glewBindVertexBuffers) - -#define GLEW_ARB_multi_bind GLEW_GET_VAR(__GLEW_ARB_multi_bind) - -#endif /* GL_ARB_multi_bind */ - -/* ----------------------- GL_ARB_multi_draw_indirect ---------------------- */ - -#ifndef GL_ARB_multi_draw_indirect -#define GL_ARB_multi_draw_indirect 1 - -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSINDIRECTPROC) (GLenum mode, const GLvoid *indirect, GLsizei primcount, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSINDIRECTPROC) (GLenum mode, GLenum type, const GLvoid *indirect, GLsizei primcount, GLsizei stride); - -#define glMultiDrawArraysIndirect GLEW_GET_FUN(__glewMultiDrawArraysIndirect) -#define glMultiDrawElementsIndirect GLEW_GET_FUN(__glewMultiDrawElementsIndirect) - -#define GLEW_ARB_multi_draw_indirect GLEW_GET_VAR(__GLEW_ARB_multi_draw_indirect) - -#endif /* GL_ARB_multi_draw_indirect */ - -/* --------------------------- GL_ARB_multisample -------------------------- */ - -#ifndef GL_ARB_multisample -#define GL_ARB_multisample 1 - -#define GL_MULTISAMPLE_ARB 0x809D -#define GL_SAMPLE_ALPHA_TO_COVERAGE_ARB 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_ARB 0x809F -#define GL_SAMPLE_COVERAGE_ARB 0x80A0 -#define GL_SAMPLE_BUFFERS_ARB 0x80A8 -#define GL_SAMPLES_ARB 0x80A9 -#define GL_SAMPLE_COVERAGE_VALUE_ARB 0x80AA -#define GL_SAMPLE_COVERAGE_INVERT_ARB 0x80AB -#define GL_MULTISAMPLE_BIT_ARB 0x20000000 - -typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEARBPROC) (GLclampf value, GLboolean invert); - -#define glSampleCoverageARB GLEW_GET_FUN(__glewSampleCoverageARB) - -#define GLEW_ARB_multisample GLEW_GET_VAR(__GLEW_ARB_multisample) - -#endif /* GL_ARB_multisample */ - -/* -------------------------- GL_ARB_multitexture -------------------------- */ - -#ifndef GL_ARB_multitexture -#define GL_ARB_multitexture 1 - -#define GL_TEXTURE0_ARB 0x84C0 -#define GL_TEXTURE1_ARB 0x84C1 -#define GL_TEXTURE2_ARB 0x84C2 -#define GL_TEXTURE3_ARB 0x84C3 -#define GL_TEXTURE4_ARB 0x84C4 -#define GL_TEXTURE5_ARB 0x84C5 -#define GL_TEXTURE6_ARB 0x84C6 -#define GL_TEXTURE7_ARB 0x84C7 -#define GL_TEXTURE8_ARB 0x84C8 -#define GL_TEXTURE9_ARB 0x84C9 -#define GL_TEXTURE10_ARB 0x84CA -#define GL_TEXTURE11_ARB 0x84CB -#define GL_TEXTURE12_ARB 0x84CC -#define GL_TEXTURE13_ARB 0x84CD -#define GL_TEXTURE14_ARB 0x84CE -#define GL_TEXTURE15_ARB 0x84CF -#define GL_TEXTURE16_ARB 0x84D0 -#define GL_TEXTURE17_ARB 0x84D1 -#define GL_TEXTURE18_ARB 0x84D2 -#define GL_TEXTURE19_ARB 0x84D3 -#define GL_TEXTURE20_ARB 0x84D4 -#define GL_TEXTURE21_ARB 0x84D5 -#define GL_TEXTURE22_ARB 0x84D6 -#define GL_TEXTURE23_ARB 0x84D7 -#define GL_TEXTURE24_ARB 0x84D8 -#define GL_TEXTURE25_ARB 0x84D9 -#define GL_TEXTURE26_ARB 0x84DA -#define GL_TEXTURE27_ARB 0x84DB -#define GL_TEXTURE28_ARB 0x84DC -#define GL_TEXTURE29_ARB 0x84DD -#define GL_TEXTURE30_ARB 0x84DE -#define GL_TEXTURE31_ARB 0x84DF -#define GL_ACTIVE_TEXTURE_ARB 0x84E0 -#define GL_CLIENT_ACTIVE_TEXTURE_ARB 0x84E1 -#define GL_MAX_TEXTURE_UNITS_ARB 0x84E2 - -typedef void (GLAPIENTRY * PFNGLACTIVETEXTUREARBPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); - -#define glActiveTextureARB GLEW_GET_FUN(__glewActiveTextureARB) -#define glClientActiveTextureARB GLEW_GET_FUN(__glewClientActiveTextureARB) -#define glMultiTexCoord1dARB GLEW_GET_FUN(__glewMultiTexCoord1dARB) -#define glMultiTexCoord1dvARB GLEW_GET_FUN(__glewMultiTexCoord1dvARB) -#define glMultiTexCoord1fARB GLEW_GET_FUN(__glewMultiTexCoord1fARB) -#define glMultiTexCoord1fvARB GLEW_GET_FUN(__glewMultiTexCoord1fvARB) -#define glMultiTexCoord1iARB GLEW_GET_FUN(__glewMultiTexCoord1iARB) -#define glMultiTexCoord1ivARB GLEW_GET_FUN(__glewMultiTexCoord1ivARB) -#define glMultiTexCoord1sARB GLEW_GET_FUN(__glewMultiTexCoord1sARB) -#define glMultiTexCoord1svARB GLEW_GET_FUN(__glewMultiTexCoord1svARB) -#define glMultiTexCoord2dARB GLEW_GET_FUN(__glewMultiTexCoord2dARB) -#define glMultiTexCoord2dvARB GLEW_GET_FUN(__glewMultiTexCoord2dvARB) -#define glMultiTexCoord2fARB GLEW_GET_FUN(__glewMultiTexCoord2fARB) -#define glMultiTexCoord2fvARB GLEW_GET_FUN(__glewMultiTexCoord2fvARB) -#define glMultiTexCoord2iARB GLEW_GET_FUN(__glewMultiTexCoord2iARB) -#define glMultiTexCoord2ivARB GLEW_GET_FUN(__glewMultiTexCoord2ivARB) -#define glMultiTexCoord2sARB GLEW_GET_FUN(__glewMultiTexCoord2sARB) -#define glMultiTexCoord2svARB GLEW_GET_FUN(__glewMultiTexCoord2svARB) -#define glMultiTexCoord3dARB GLEW_GET_FUN(__glewMultiTexCoord3dARB) -#define glMultiTexCoord3dvARB GLEW_GET_FUN(__glewMultiTexCoord3dvARB) -#define glMultiTexCoord3fARB GLEW_GET_FUN(__glewMultiTexCoord3fARB) -#define glMultiTexCoord3fvARB GLEW_GET_FUN(__glewMultiTexCoord3fvARB) -#define glMultiTexCoord3iARB GLEW_GET_FUN(__glewMultiTexCoord3iARB) -#define glMultiTexCoord3ivARB GLEW_GET_FUN(__glewMultiTexCoord3ivARB) -#define glMultiTexCoord3sARB GLEW_GET_FUN(__glewMultiTexCoord3sARB) -#define glMultiTexCoord3svARB GLEW_GET_FUN(__glewMultiTexCoord3svARB) -#define glMultiTexCoord4dARB GLEW_GET_FUN(__glewMultiTexCoord4dARB) -#define glMultiTexCoord4dvARB GLEW_GET_FUN(__glewMultiTexCoord4dvARB) -#define glMultiTexCoord4fARB GLEW_GET_FUN(__glewMultiTexCoord4fARB) -#define glMultiTexCoord4fvARB GLEW_GET_FUN(__glewMultiTexCoord4fvARB) -#define glMultiTexCoord4iARB GLEW_GET_FUN(__glewMultiTexCoord4iARB) -#define glMultiTexCoord4ivARB GLEW_GET_FUN(__glewMultiTexCoord4ivARB) -#define glMultiTexCoord4sARB GLEW_GET_FUN(__glewMultiTexCoord4sARB) -#define glMultiTexCoord4svARB GLEW_GET_FUN(__glewMultiTexCoord4svARB) - -#define GLEW_ARB_multitexture GLEW_GET_VAR(__GLEW_ARB_multitexture) - -#endif /* GL_ARB_multitexture */ - -/* ------------------------- GL_ARB_occlusion_query ------------------------ */ - -#ifndef GL_ARB_occlusion_query -#define GL_ARB_occlusion_query 1 - -#define GL_QUERY_COUNTER_BITS_ARB 0x8864 -#define GL_CURRENT_QUERY_ARB 0x8865 -#define GL_QUERY_RESULT_ARB 0x8866 -#define GL_QUERY_RESULT_AVAILABLE_ARB 0x8867 -#define GL_SAMPLES_PASSED_ARB 0x8914 - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYARBPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEQUERIESARBPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDQUERYARBPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGENQUERIESARBPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTIVARBPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUIVARBPROC) (GLuint id, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYIVARBPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISQUERYARBPROC) (GLuint id); - -#define glBeginQueryARB GLEW_GET_FUN(__glewBeginQueryARB) -#define glDeleteQueriesARB GLEW_GET_FUN(__glewDeleteQueriesARB) -#define glEndQueryARB GLEW_GET_FUN(__glewEndQueryARB) -#define glGenQueriesARB GLEW_GET_FUN(__glewGenQueriesARB) -#define glGetQueryObjectivARB GLEW_GET_FUN(__glewGetQueryObjectivARB) -#define glGetQueryObjectuivARB GLEW_GET_FUN(__glewGetQueryObjectuivARB) -#define glGetQueryivARB GLEW_GET_FUN(__glewGetQueryivARB) -#define glIsQueryARB GLEW_GET_FUN(__glewIsQueryARB) - -#define GLEW_ARB_occlusion_query GLEW_GET_VAR(__GLEW_ARB_occlusion_query) - -#endif /* GL_ARB_occlusion_query */ - -/* ------------------------ GL_ARB_occlusion_query2 ------------------------ */ - -#ifndef GL_ARB_occlusion_query2 -#define GL_ARB_occlusion_query2 1 - -#define GL_ANY_SAMPLES_PASSED 0x8C2F - -#define GLEW_ARB_occlusion_query2 GLEW_GET_VAR(__GLEW_ARB_occlusion_query2) - -#endif /* GL_ARB_occlusion_query2 */ - -/* ----------------------- GL_ARB_pixel_buffer_object ---------------------- */ - -#ifndef GL_ARB_pixel_buffer_object -#define GL_ARB_pixel_buffer_object 1 - -#define GL_PIXEL_PACK_BUFFER_ARB 0x88EB -#define GL_PIXEL_UNPACK_BUFFER_ARB 0x88EC -#define GL_PIXEL_PACK_BUFFER_BINDING_ARB 0x88ED -#define GL_PIXEL_UNPACK_BUFFER_BINDING_ARB 0x88EF - -#define GLEW_ARB_pixel_buffer_object GLEW_GET_VAR(__GLEW_ARB_pixel_buffer_object) - -#endif /* GL_ARB_pixel_buffer_object */ - -/* ------------------------ GL_ARB_point_parameters ------------------------ */ - -#ifndef GL_ARB_point_parameters -#define GL_ARB_point_parameters 1 - -#define GL_POINT_SIZE_MIN_ARB 0x8126 -#define GL_POINT_SIZE_MAX_ARB 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE_ARB 0x8128 -#define GL_POINT_DISTANCE_ATTENUATION_ARB 0x8129 - -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFARBPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVARBPROC) (GLenum pname, const GLfloat* params); - -#define glPointParameterfARB GLEW_GET_FUN(__glewPointParameterfARB) -#define glPointParameterfvARB GLEW_GET_FUN(__glewPointParameterfvARB) - -#define GLEW_ARB_point_parameters GLEW_GET_VAR(__GLEW_ARB_point_parameters) - -#endif /* GL_ARB_point_parameters */ - -/* -------------------------- GL_ARB_point_sprite -------------------------- */ - -#ifndef GL_ARB_point_sprite -#define GL_ARB_point_sprite 1 - -#define GL_POINT_SPRITE_ARB 0x8861 -#define GL_COORD_REPLACE_ARB 0x8862 - -#define GLEW_ARB_point_sprite GLEW_GET_VAR(__GLEW_ARB_point_sprite) - -#endif /* GL_ARB_point_sprite */ - -/* --------------------- GL_ARB_program_interface_query -------------------- */ - -#ifndef GL_ARB_program_interface_query -#define GL_ARB_program_interface_query 1 - -#define GL_UNIFORM 0x92E1 -#define GL_UNIFORM_BLOCK 0x92E2 -#define GL_PROGRAM_INPUT 0x92E3 -#define GL_PROGRAM_OUTPUT 0x92E4 -#define GL_BUFFER_VARIABLE 0x92E5 -#define GL_SHADER_STORAGE_BLOCK 0x92E6 -#define GL_IS_PER_PATCH 0x92E7 -#define GL_VERTEX_SUBROUTINE 0x92E8 -#define GL_TESS_CONTROL_SUBROUTINE 0x92E9 -#define GL_TESS_EVALUATION_SUBROUTINE 0x92EA -#define GL_GEOMETRY_SUBROUTINE 0x92EB -#define GL_FRAGMENT_SUBROUTINE 0x92EC -#define GL_COMPUTE_SUBROUTINE 0x92ED -#define GL_VERTEX_SUBROUTINE_UNIFORM 0x92EE -#define GL_TESS_CONTROL_SUBROUTINE_UNIFORM 0x92EF -#define GL_TESS_EVALUATION_SUBROUTINE_UNIFORM 0x92F0 -#define GL_GEOMETRY_SUBROUTINE_UNIFORM 0x92F1 -#define GL_FRAGMENT_SUBROUTINE_UNIFORM 0x92F2 -#define GL_COMPUTE_SUBROUTINE_UNIFORM 0x92F3 -#define GL_TRANSFORM_FEEDBACK_VARYING 0x92F4 -#define GL_ACTIVE_RESOURCES 0x92F5 -#define GL_MAX_NAME_LENGTH 0x92F6 -#define GL_MAX_NUM_ACTIVE_VARIABLES 0x92F7 -#define GL_MAX_NUM_COMPATIBLE_SUBROUTINES 0x92F8 -#define GL_NAME_LENGTH 0x92F9 -#define GL_TYPE 0x92FA -#define GL_ARRAY_SIZE 0x92FB -#define GL_OFFSET 0x92FC -#define GL_BLOCK_INDEX 0x92FD -#define GL_ARRAY_STRIDE 0x92FE -#define GL_MATRIX_STRIDE 0x92FF -#define GL_IS_ROW_MAJOR 0x9300 -#define GL_ATOMIC_COUNTER_BUFFER_INDEX 0x9301 -#define GL_BUFFER_BINDING 0x9302 -#define GL_BUFFER_DATA_SIZE 0x9303 -#define GL_NUM_ACTIVE_VARIABLES 0x9304 -#define GL_ACTIVE_VARIABLES 0x9305 -#define GL_REFERENCED_BY_VERTEX_SHADER 0x9306 -#define GL_REFERENCED_BY_TESS_CONTROL_SHADER 0x9307 -#define GL_REFERENCED_BY_TESS_EVALUATION_SHADER 0x9308 -#define GL_REFERENCED_BY_GEOMETRY_SHADER 0x9309 -#define GL_REFERENCED_BY_FRAGMENT_SHADER 0x930A -#define GL_REFERENCED_BY_COMPUTE_SHADER 0x930B -#define GL_TOP_LEVEL_ARRAY_SIZE 0x930C -#define GL_TOP_LEVEL_ARRAY_STRIDE 0x930D -#define GL_LOCATION 0x930E -#define GL_LOCATION_INDEX 0x930F - -typedef void (GLAPIENTRY * PFNGLGETPROGRAMINTERFACEIVPROC) (GLuint program, GLenum programInterface, GLenum pname, GLint* params); -typedef GLuint (GLAPIENTRY * PFNGLGETPROGRAMRESOURCEINDEXPROC) (GLuint program, GLenum programInterface, const GLchar* name); -typedef GLint (GLAPIENTRY * PFNGLGETPROGRAMRESOURCELOCATIONPROC) (GLuint program, GLenum programInterface, const GLchar* name); -typedef GLint (GLAPIENTRY * PFNGLGETPROGRAMRESOURCELOCATIONINDEXPROC) (GLuint program, GLenum programInterface, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMRESOURCENAMEPROC) (GLuint program, GLenum programInterface, GLuint index, GLsizei bufSize, GLsizei* length, GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMRESOURCEIVPROC) (GLuint program, GLenum programInterface, GLuint index, GLsizei propCount, const GLenum* props, GLsizei bufSize, GLsizei *length, GLint *params); - -#define glGetProgramInterfaceiv GLEW_GET_FUN(__glewGetProgramInterfaceiv) -#define glGetProgramResourceIndex GLEW_GET_FUN(__glewGetProgramResourceIndex) -#define glGetProgramResourceLocation GLEW_GET_FUN(__glewGetProgramResourceLocation) -#define glGetProgramResourceLocationIndex GLEW_GET_FUN(__glewGetProgramResourceLocationIndex) -#define glGetProgramResourceName GLEW_GET_FUN(__glewGetProgramResourceName) -#define glGetProgramResourceiv GLEW_GET_FUN(__glewGetProgramResourceiv) - -#define GLEW_ARB_program_interface_query GLEW_GET_VAR(__GLEW_ARB_program_interface_query) - -#endif /* GL_ARB_program_interface_query */ - -/* ------------------------ GL_ARB_provoking_vertex ------------------------ */ - -#ifndef GL_ARB_provoking_vertex -#define GL_ARB_provoking_vertex 1 - -#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION 0x8E4C -#define GL_FIRST_VERTEX_CONVENTION 0x8E4D -#define GL_LAST_VERTEX_CONVENTION 0x8E4E -#define GL_PROVOKING_VERTEX 0x8E4F - -typedef void (GLAPIENTRY * PFNGLPROVOKINGVERTEXPROC) (GLenum mode); - -#define glProvokingVertex GLEW_GET_FUN(__glewProvokingVertex) - -#define GLEW_ARB_provoking_vertex GLEW_GET_VAR(__GLEW_ARB_provoking_vertex) - -#endif /* GL_ARB_provoking_vertex */ - -/* ----------------------- GL_ARB_query_buffer_object ---------------------- */ - -#ifndef GL_ARB_query_buffer_object -#define GL_ARB_query_buffer_object 1 - -#define GL_QUERY_BUFFER_BARRIER_BIT 0x00008000 -#define GL_QUERY_BUFFER 0x9192 -#define GL_QUERY_BUFFER_BINDING 0x9193 -#define GL_QUERY_RESULT_NO_WAIT 0x9194 - -#define GLEW_ARB_query_buffer_object GLEW_GET_VAR(__GLEW_ARB_query_buffer_object) - -#endif /* GL_ARB_query_buffer_object */ - -/* ------------------ GL_ARB_robust_buffer_access_behavior ----------------- */ - -#ifndef GL_ARB_robust_buffer_access_behavior -#define GL_ARB_robust_buffer_access_behavior 1 - -#define GLEW_ARB_robust_buffer_access_behavior GLEW_GET_VAR(__GLEW_ARB_robust_buffer_access_behavior) - -#endif /* GL_ARB_robust_buffer_access_behavior */ - -/* --------------------------- GL_ARB_robustness --------------------------- */ - -#ifndef GL_ARB_robustness -#define GL_ARB_robustness 1 - -#define GL_CONTEXT_FLAG_ROBUST_ACCESS_BIT_ARB 0x00000004 -#define GL_LOSE_CONTEXT_ON_RESET_ARB 0x8252 -#define GL_GUILTY_CONTEXT_RESET_ARB 0x8253 -#define GL_INNOCENT_CONTEXT_RESET_ARB 0x8254 -#define GL_UNKNOWN_CONTEXT_RESET_ARB 0x8255 -#define GL_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 -#define GL_NO_RESET_NOTIFICATION_ARB 0x8261 - -typedef GLenum (GLAPIENTRY * PFNGLGETGRAPHICSRESETSTATUSARBPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETNCOLORTABLEARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void* table); -typedef void (GLAPIENTRY * PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint lod, GLsizei bufSize, void* img); -typedef void (GLAPIENTRY * PFNGLGETNCONVOLUTIONFILTERARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void* image); -typedef void (GLAPIENTRY * PFNGLGETNHISTOGRAMARBPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void* values); -typedef void (GLAPIENTRY * PFNGLGETNMAPDVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLdouble* v); -typedef void (GLAPIENTRY * PFNGLGETNMAPFVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLfloat* v); -typedef void (GLAPIENTRY * PFNGLGETNMAPIVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLint* v); -typedef void (GLAPIENTRY * PFNGLGETNMINMAXARBPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void* values); -typedef void (GLAPIENTRY * PFNGLGETNPIXELMAPFVARBPROC) (GLenum map, GLsizei bufSize, GLfloat* values); -typedef void (GLAPIENTRY * PFNGLGETNPIXELMAPUIVARBPROC) (GLenum map, GLsizei bufSize, GLuint* values); -typedef void (GLAPIENTRY * PFNGLGETNPIXELMAPUSVARBPROC) (GLenum map, GLsizei bufSize, GLushort* values); -typedef void (GLAPIENTRY * PFNGLGETNPOLYGONSTIPPLEARBPROC) (GLsizei bufSize, GLubyte* pattern); -typedef void (GLAPIENTRY * PFNGLGETNSEPARABLEFILTERARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei rowBufSize, void* row, GLsizei columnBufSize, GLvoid*column, GLvoid*span); -typedef void (GLAPIENTRY * PFNGLGETNTEXIMAGEARBPROC) (GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void* img); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMDVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMFVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMIVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNUNIFORMUIVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLuint* params); -typedef void (GLAPIENTRY * PFNGLREADNPIXELSARBPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, void* data); - -#define glGetGraphicsResetStatusARB GLEW_GET_FUN(__glewGetGraphicsResetStatusARB) -#define glGetnColorTableARB GLEW_GET_FUN(__glewGetnColorTableARB) -#define glGetnCompressedTexImageARB GLEW_GET_FUN(__glewGetnCompressedTexImageARB) -#define glGetnConvolutionFilterARB GLEW_GET_FUN(__glewGetnConvolutionFilterARB) -#define glGetnHistogramARB GLEW_GET_FUN(__glewGetnHistogramARB) -#define glGetnMapdvARB GLEW_GET_FUN(__glewGetnMapdvARB) -#define glGetnMapfvARB GLEW_GET_FUN(__glewGetnMapfvARB) -#define glGetnMapivARB GLEW_GET_FUN(__glewGetnMapivARB) -#define glGetnMinmaxARB GLEW_GET_FUN(__glewGetnMinmaxARB) -#define glGetnPixelMapfvARB GLEW_GET_FUN(__glewGetnPixelMapfvARB) -#define glGetnPixelMapuivARB GLEW_GET_FUN(__glewGetnPixelMapuivARB) -#define glGetnPixelMapusvARB GLEW_GET_FUN(__glewGetnPixelMapusvARB) -#define glGetnPolygonStippleARB GLEW_GET_FUN(__glewGetnPolygonStippleARB) -#define glGetnSeparableFilterARB GLEW_GET_FUN(__glewGetnSeparableFilterARB) -#define glGetnTexImageARB GLEW_GET_FUN(__glewGetnTexImageARB) -#define glGetnUniformdvARB GLEW_GET_FUN(__glewGetnUniformdvARB) -#define glGetnUniformfvARB GLEW_GET_FUN(__glewGetnUniformfvARB) -#define glGetnUniformivARB GLEW_GET_FUN(__glewGetnUniformivARB) -#define glGetnUniformuivARB GLEW_GET_FUN(__glewGetnUniformuivARB) -#define glReadnPixelsARB GLEW_GET_FUN(__glewReadnPixelsARB) - -#define GLEW_ARB_robustness GLEW_GET_VAR(__GLEW_ARB_robustness) - -#endif /* GL_ARB_robustness */ - -/* ---------------- GL_ARB_robustness_application_isolation ---------------- */ - -#ifndef GL_ARB_robustness_application_isolation -#define GL_ARB_robustness_application_isolation 1 - -#define GLEW_ARB_robustness_application_isolation GLEW_GET_VAR(__GLEW_ARB_robustness_application_isolation) - -#endif /* GL_ARB_robustness_application_isolation */ - -/* ---------------- GL_ARB_robustness_share_group_isolation ---------------- */ - -#ifndef GL_ARB_robustness_share_group_isolation -#define GL_ARB_robustness_share_group_isolation 1 - -#define GLEW_ARB_robustness_share_group_isolation GLEW_GET_VAR(__GLEW_ARB_robustness_share_group_isolation) - -#endif /* GL_ARB_robustness_share_group_isolation */ - -/* ------------------------- GL_ARB_sample_shading ------------------------- */ - -#ifndef GL_ARB_sample_shading -#define GL_ARB_sample_shading 1 - -#define GL_SAMPLE_SHADING_ARB 0x8C36 -#define GL_MIN_SAMPLE_SHADING_VALUE_ARB 0x8C37 - -typedef void (GLAPIENTRY * PFNGLMINSAMPLESHADINGARBPROC) (GLclampf value); - -#define glMinSampleShadingARB GLEW_GET_FUN(__glewMinSampleShadingARB) - -#define GLEW_ARB_sample_shading GLEW_GET_VAR(__GLEW_ARB_sample_shading) - -#endif /* GL_ARB_sample_shading */ - -/* ------------------------- GL_ARB_sampler_objects ------------------------ */ - -#ifndef GL_ARB_sampler_objects -#define GL_ARB_sampler_objects 1 - -#define GL_SAMPLER_BINDING 0x8919 - -typedef void (GLAPIENTRY * PFNGLBINDSAMPLERPROC) (GLuint unit, GLuint sampler); -typedef void (GLAPIENTRY * PFNGLDELETESAMPLERSPROC) (GLsizei count, const GLuint * samplers); -typedef void (GLAPIENTRY * PFNGLGENSAMPLERSPROC) (GLsizei count, GLuint* samplers); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISSAMPLERPROC) (GLuint sampler); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERFPROC) (GLuint sampler, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIPROC) (GLuint sampler, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, const GLint* params); - -#define glBindSampler GLEW_GET_FUN(__glewBindSampler) -#define glDeleteSamplers GLEW_GET_FUN(__glewDeleteSamplers) -#define glGenSamplers GLEW_GET_FUN(__glewGenSamplers) -#define glGetSamplerParameterIiv GLEW_GET_FUN(__glewGetSamplerParameterIiv) -#define glGetSamplerParameterIuiv GLEW_GET_FUN(__glewGetSamplerParameterIuiv) -#define glGetSamplerParameterfv GLEW_GET_FUN(__glewGetSamplerParameterfv) -#define glGetSamplerParameteriv GLEW_GET_FUN(__glewGetSamplerParameteriv) -#define glIsSampler GLEW_GET_FUN(__glewIsSampler) -#define glSamplerParameterIiv GLEW_GET_FUN(__glewSamplerParameterIiv) -#define glSamplerParameterIuiv GLEW_GET_FUN(__glewSamplerParameterIuiv) -#define glSamplerParameterf GLEW_GET_FUN(__glewSamplerParameterf) -#define glSamplerParameterfv GLEW_GET_FUN(__glewSamplerParameterfv) -#define glSamplerParameteri GLEW_GET_FUN(__glewSamplerParameteri) -#define glSamplerParameteriv GLEW_GET_FUN(__glewSamplerParameteriv) - -#define GLEW_ARB_sampler_objects GLEW_GET_VAR(__GLEW_ARB_sampler_objects) - -#endif /* GL_ARB_sampler_objects */ - -/* ------------------------ GL_ARB_seamless_cube_map ----------------------- */ - -#ifndef GL_ARB_seamless_cube_map -#define GL_ARB_seamless_cube_map 1 - -#define GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F - -#define GLEW_ARB_seamless_cube_map GLEW_GET_VAR(__GLEW_ARB_seamless_cube_map) - -#endif /* GL_ARB_seamless_cube_map */ - -/* ------------------ GL_ARB_seamless_cubemap_per_texture ------------------ */ - -#ifndef GL_ARB_seamless_cubemap_per_texture -#define GL_ARB_seamless_cubemap_per_texture 1 - -#define GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F - -#define GLEW_ARB_seamless_cubemap_per_texture GLEW_GET_VAR(__GLEW_ARB_seamless_cubemap_per_texture) - -#endif /* GL_ARB_seamless_cubemap_per_texture */ - -/* --------------------- GL_ARB_separate_shader_objects -------------------- */ - -#ifndef GL_ARB_separate_shader_objects -#define GL_ARB_separate_shader_objects 1 - -#define GL_VERTEX_SHADER_BIT 0x00000001 -#define GL_FRAGMENT_SHADER_BIT 0x00000002 -#define GL_GEOMETRY_SHADER_BIT 0x00000004 -#define GL_TESS_CONTROL_SHADER_BIT 0x00000008 -#define GL_TESS_EVALUATION_SHADER_BIT 0x00000010 -#define GL_PROGRAM_SEPARABLE 0x8258 -#define GL_ACTIVE_PROGRAM 0x8259 -#define GL_PROGRAM_PIPELINE_BINDING 0x825A -#define GL_ALL_SHADER_BITS 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLACTIVESHADERPROGRAMPROC) (GLuint pipeline, GLuint program); -typedef void (GLAPIENTRY * PFNGLBINDPROGRAMPIPELINEPROC) (GLuint pipeline); -typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROGRAMVPROC) (GLenum type, GLsizei count, const GLchar ** strings); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMPIPELINESPROC) (GLsizei n, const GLuint* pipelines); -typedef void (GLAPIENTRY * PFNGLGENPROGRAMPIPELINESPROC) (GLsizei n, GLuint* pipelines); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPIPELINEINFOLOGPROC) (GLuint pipeline, GLsizei bufSize, GLsizei* length, GLchar *infoLog); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPIPELINEIVPROC) (GLuint pipeline, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMPIPELINEPROC) (GLuint pipeline); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1DPROC) (GLuint program, GLint location, GLdouble x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FPROC) (GLuint program, GLint location, GLfloat x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IPROC) (GLuint program, GLint location, GLint x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIPROC) (GLuint program, GLint location, GLuint x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2DPROC) (GLuint program, GLint location, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FPROC) (GLuint program, GLint location, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IPROC) (GLuint program, GLint location, GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIPROC) (GLuint program, GLint location, GLuint x, GLuint y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3DPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FPROC) (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IPROC) (GLuint program, GLint location, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIPROC) (GLuint program, GLint location, GLuint x, GLuint y, GLuint z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4DPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FPROC) (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IPROC) (GLuint program, GLint location, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IVPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIPROC) (GLuint program, GLint location, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUSEPROGRAMSTAGESPROC) (GLuint pipeline, GLbitfield stages, GLuint program); -typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMPIPELINEPROC) (GLuint pipeline); - -#define glActiveShaderProgram GLEW_GET_FUN(__glewActiveShaderProgram) -#define glBindProgramPipeline GLEW_GET_FUN(__glewBindProgramPipeline) -#define glCreateShaderProgramv GLEW_GET_FUN(__glewCreateShaderProgramv) -#define glDeleteProgramPipelines GLEW_GET_FUN(__glewDeleteProgramPipelines) -#define glGenProgramPipelines GLEW_GET_FUN(__glewGenProgramPipelines) -#define glGetProgramPipelineInfoLog GLEW_GET_FUN(__glewGetProgramPipelineInfoLog) -#define glGetProgramPipelineiv GLEW_GET_FUN(__glewGetProgramPipelineiv) -#define glIsProgramPipeline GLEW_GET_FUN(__glewIsProgramPipeline) -#define glProgramUniform1d GLEW_GET_FUN(__glewProgramUniform1d) -#define glProgramUniform1dv GLEW_GET_FUN(__glewProgramUniform1dv) -#define glProgramUniform1f GLEW_GET_FUN(__glewProgramUniform1f) -#define glProgramUniform1fv GLEW_GET_FUN(__glewProgramUniform1fv) -#define glProgramUniform1i GLEW_GET_FUN(__glewProgramUniform1i) -#define glProgramUniform1iv GLEW_GET_FUN(__glewProgramUniform1iv) -#define glProgramUniform1ui GLEW_GET_FUN(__glewProgramUniform1ui) -#define glProgramUniform1uiv GLEW_GET_FUN(__glewProgramUniform1uiv) -#define glProgramUniform2d GLEW_GET_FUN(__glewProgramUniform2d) -#define glProgramUniform2dv GLEW_GET_FUN(__glewProgramUniform2dv) -#define glProgramUniform2f GLEW_GET_FUN(__glewProgramUniform2f) -#define glProgramUniform2fv GLEW_GET_FUN(__glewProgramUniform2fv) -#define glProgramUniform2i GLEW_GET_FUN(__glewProgramUniform2i) -#define glProgramUniform2iv GLEW_GET_FUN(__glewProgramUniform2iv) -#define glProgramUniform2ui GLEW_GET_FUN(__glewProgramUniform2ui) -#define glProgramUniform2uiv GLEW_GET_FUN(__glewProgramUniform2uiv) -#define glProgramUniform3d GLEW_GET_FUN(__glewProgramUniform3d) -#define glProgramUniform3dv GLEW_GET_FUN(__glewProgramUniform3dv) -#define glProgramUniform3f GLEW_GET_FUN(__glewProgramUniform3f) -#define glProgramUniform3fv GLEW_GET_FUN(__glewProgramUniform3fv) -#define glProgramUniform3i GLEW_GET_FUN(__glewProgramUniform3i) -#define glProgramUniform3iv GLEW_GET_FUN(__glewProgramUniform3iv) -#define glProgramUniform3ui GLEW_GET_FUN(__glewProgramUniform3ui) -#define glProgramUniform3uiv GLEW_GET_FUN(__glewProgramUniform3uiv) -#define glProgramUniform4d GLEW_GET_FUN(__glewProgramUniform4d) -#define glProgramUniform4dv GLEW_GET_FUN(__glewProgramUniform4dv) -#define glProgramUniform4f GLEW_GET_FUN(__glewProgramUniform4f) -#define glProgramUniform4fv GLEW_GET_FUN(__glewProgramUniform4fv) -#define glProgramUniform4i GLEW_GET_FUN(__glewProgramUniform4i) -#define glProgramUniform4iv GLEW_GET_FUN(__glewProgramUniform4iv) -#define glProgramUniform4ui GLEW_GET_FUN(__glewProgramUniform4ui) -#define glProgramUniform4uiv GLEW_GET_FUN(__glewProgramUniform4uiv) -#define glProgramUniformMatrix2dv GLEW_GET_FUN(__glewProgramUniformMatrix2dv) -#define glProgramUniformMatrix2fv GLEW_GET_FUN(__glewProgramUniformMatrix2fv) -#define glProgramUniformMatrix2x3dv GLEW_GET_FUN(__glewProgramUniformMatrix2x3dv) -#define glProgramUniformMatrix2x3fv GLEW_GET_FUN(__glewProgramUniformMatrix2x3fv) -#define glProgramUniformMatrix2x4dv GLEW_GET_FUN(__glewProgramUniformMatrix2x4dv) -#define glProgramUniformMatrix2x4fv GLEW_GET_FUN(__glewProgramUniformMatrix2x4fv) -#define glProgramUniformMatrix3dv GLEW_GET_FUN(__glewProgramUniformMatrix3dv) -#define glProgramUniformMatrix3fv GLEW_GET_FUN(__glewProgramUniformMatrix3fv) -#define glProgramUniformMatrix3x2dv GLEW_GET_FUN(__glewProgramUniformMatrix3x2dv) -#define glProgramUniformMatrix3x2fv GLEW_GET_FUN(__glewProgramUniformMatrix3x2fv) -#define glProgramUniformMatrix3x4dv GLEW_GET_FUN(__glewProgramUniformMatrix3x4dv) -#define glProgramUniformMatrix3x4fv GLEW_GET_FUN(__glewProgramUniformMatrix3x4fv) -#define glProgramUniformMatrix4dv GLEW_GET_FUN(__glewProgramUniformMatrix4dv) -#define glProgramUniformMatrix4fv GLEW_GET_FUN(__glewProgramUniformMatrix4fv) -#define glProgramUniformMatrix4x2dv GLEW_GET_FUN(__glewProgramUniformMatrix4x2dv) -#define glProgramUniformMatrix4x2fv GLEW_GET_FUN(__glewProgramUniformMatrix4x2fv) -#define glProgramUniformMatrix4x3dv GLEW_GET_FUN(__glewProgramUniformMatrix4x3dv) -#define glProgramUniformMatrix4x3fv GLEW_GET_FUN(__glewProgramUniformMatrix4x3fv) -#define glUseProgramStages GLEW_GET_FUN(__glewUseProgramStages) -#define glValidateProgramPipeline GLEW_GET_FUN(__glewValidateProgramPipeline) - -#define GLEW_ARB_separate_shader_objects GLEW_GET_VAR(__GLEW_ARB_separate_shader_objects) - -#endif /* GL_ARB_separate_shader_objects */ - -/* --------------------- GL_ARB_shader_atomic_counters --------------------- */ - -#ifndef GL_ARB_shader_atomic_counters -#define GL_ARB_shader_atomic_counters 1 - -#define GL_ATOMIC_COUNTER_BUFFER 0x92C0 -#define GL_ATOMIC_COUNTER_BUFFER_BINDING 0x92C1 -#define GL_ATOMIC_COUNTER_BUFFER_START 0x92C2 -#define GL_ATOMIC_COUNTER_BUFFER_SIZE 0x92C3 -#define GL_ATOMIC_COUNTER_BUFFER_DATA_SIZE 0x92C4 -#define GL_ATOMIC_COUNTER_BUFFER_ACTIVE_ATOMIC_COUNTERS 0x92C5 -#define GL_ATOMIC_COUNTER_BUFFER_ACTIVE_ATOMIC_COUNTER_INDICES 0x92C6 -#define GL_ATOMIC_COUNTER_BUFFER_REFERENCED_BY_VERTEX_SHADER 0x92C7 -#define GL_ATOMIC_COUNTER_BUFFER_REFERENCED_BY_TESS_CONTROL_SHADER 0x92C8 -#define GL_ATOMIC_COUNTER_BUFFER_REFERENCED_BY_TESS_EVALUATION_SHADER 0x92C9 -#define GL_ATOMIC_COUNTER_BUFFER_REFERENCED_BY_GEOMETRY_SHADER 0x92CA -#define GL_ATOMIC_COUNTER_BUFFER_REFERENCED_BY_FRAGMENT_SHADER 0x92CB -#define GL_MAX_VERTEX_ATOMIC_COUNTER_BUFFERS 0x92CC -#define GL_MAX_TESS_CONTROL_ATOMIC_COUNTER_BUFFERS 0x92CD -#define GL_MAX_TESS_EVALUATION_ATOMIC_COUNTER_BUFFERS 0x92CE -#define GL_MAX_GEOMETRY_ATOMIC_COUNTER_BUFFERS 0x92CF -#define GL_MAX_FRAGMENT_ATOMIC_COUNTER_BUFFERS 0x92D0 -#define GL_MAX_COMBINED_ATOMIC_COUNTER_BUFFERS 0x92D1 -#define GL_MAX_VERTEX_ATOMIC_COUNTERS 0x92D2 -#define GL_MAX_TESS_CONTROL_ATOMIC_COUNTERS 0x92D3 -#define GL_MAX_TESS_EVALUATION_ATOMIC_COUNTERS 0x92D4 -#define GL_MAX_GEOMETRY_ATOMIC_COUNTERS 0x92D5 -#define GL_MAX_FRAGMENT_ATOMIC_COUNTERS 0x92D6 -#define GL_MAX_COMBINED_ATOMIC_COUNTERS 0x92D7 -#define GL_MAX_ATOMIC_COUNTER_BUFFER_SIZE 0x92D8 -#define GL_ACTIVE_ATOMIC_COUNTER_BUFFERS 0x92D9 -#define GL_UNIFORM_ATOMIC_COUNTER_BUFFER_INDEX 0x92DA -#define GL_UNSIGNED_INT_ATOMIC_COUNTER 0x92DB -#define GL_MAX_ATOMIC_COUNTER_BUFFER_BINDINGS 0x92DC - -typedef void (GLAPIENTRY * PFNGLGETACTIVEATOMICCOUNTERBUFFERIVPROC) (GLuint program, GLuint bufferIndex, GLenum pname, GLint* params); - -#define glGetActiveAtomicCounterBufferiv GLEW_GET_FUN(__glewGetActiveAtomicCounterBufferiv) - -#define GLEW_ARB_shader_atomic_counters GLEW_GET_VAR(__GLEW_ARB_shader_atomic_counters) - -#endif /* GL_ARB_shader_atomic_counters */ - -/* ----------------------- GL_ARB_shader_bit_encoding ---------------------- */ - -#ifndef GL_ARB_shader_bit_encoding -#define GL_ARB_shader_bit_encoding 1 - -#define GLEW_ARB_shader_bit_encoding GLEW_GET_VAR(__GLEW_ARB_shader_bit_encoding) - -#endif /* GL_ARB_shader_bit_encoding */ - -/* --------------------- GL_ARB_shader_draw_parameters --------------------- */ - -#ifndef GL_ARB_shader_draw_parameters -#define GL_ARB_shader_draw_parameters 1 - -#define GLEW_ARB_shader_draw_parameters GLEW_GET_VAR(__GLEW_ARB_shader_draw_parameters) - -#endif /* GL_ARB_shader_draw_parameters */ - -/* ------------------------ GL_ARB_shader_group_vote ----------------------- */ - -#ifndef GL_ARB_shader_group_vote -#define GL_ARB_shader_group_vote 1 - -#define GLEW_ARB_shader_group_vote GLEW_GET_VAR(__GLEW_ARB_shader_group_vote) - -#endif /* GL_ARB_shader_group_vote */ - -/* --------------------- GL_ARB_shader_image_load_store -------------------- */ - -#ifndef GL_ARB_shader_image_load_store -#define GL_ARB_shader_image_load_store 1 - -#define GL_VERTEX_ATTRIB_ARRAY_BARRIER_BIT 0x00000001 -#define GL_ELEMENT_ARRAY_BARRIER_BIT 0x00000002 -#define GL_UNIFORM_BARRIER_BIT 0x00000004 -#define GL_TEXTURE_FETCH_BARRIER_BIT 0x00000008 -#define GL_SHADER_IMAGE_ACCESS_BARRIER_BIT 0x00000020 -#define GL_COMMAND_BARRIER_BIT 0x00000040 -#define GL_PIXEL_BUFFER_BARRIER_BIT 0x00000080 -#define GL_TEXTURE_UPDATE_BARRIER_BIT 0x00000100 -#define GL_BUFFER_UPDATE_BARRIER_BIT 0x00000200 -#define GL_FRAMEBUFFER_BARRIER_BIT 0x00000400 -#define GL_TRANSFORM_FEEDBACK_BARRIER_BIT 0x00000800 -#define GL_ATOMIC_COUNTER_BARRIER_BIT 0x00001000 -#define GL_MAX_IMAGE_UNITS 0x8F38 -#define GL_MAX_COMBINED_IMAGE_UNITS_AND_FRAGMENT_OUTPUTS 0x8F39 -#define GL_IMAGE_BINDING_NAME 0x8F3A -#define GL_IMAGE_BINDING_LEVEL 0x8F3B -#define GL_IMAGE_BINDING_LAYERED 0x8F3C -#define GL_IMAGE_BINDING_LAYER 0x8F3D -#define GL_IMAGE_BINDING_ACCESS 0x8F3E -#define GL_IMAGE_1D 0x904C -#define GL_IMAGE_2D 0x904D -#define GL_IMAGE_3D 0x904E -#define GL_IMAGE_2D_RECT 0x904F -#define GL_IMAGE_CUBE 0x9050 -#define GL_IMAGE_BUFFER 0x9051 -#define GL_IMAGE_1D_ARRAY 0x9052 -#define GL_IMAGE_2D_ARRAY 0x9053 -#define GL_IMAGE_CUBE_MAP_ARRAY 0x9054 -#define GL_IMAGE_2D_MULTISAMPLE 0x9055 -#define GL_IMAGE_2D_MULTISAMPLE_ARRAY 0x9056 -#define GL_INT_IMAGE_1D 0x9057 -#define GL_INT_IMAGE_2D 0x9058 -#define GL_INT_IMAGE_3D 0x9059 -#define GL_INT_IMAGE_2D_RECT 0x905A -#define GL_INT_IMAGE_CUBE 0x905B -#define GL_INT_IMAGE_BUFFER 0x905C -#define GL_INT_IMAGE_1D_ARRAY 0x905D -#define GL_INT_IMAGE_2D_ARRAY 0x905E -#define GL_INT_IMAGE_CUBE_MAP_ARRAY 0x905F -#define GL_INT_IMAGE_2D_MULTISAMPLE 0x9060 -#define GL_INT_IMAGE_2D_MULTISAMPLE_ARRAY 0x9061 -#define GL_UNSIGNED_INT_IMAGE_1D 0x9062 -#define GL_UNSIGNED_INT_IMAGE_2D 0x9063 -#define GL_UNSIGNED_INT_IMAGE_3D 0x9064 -#define GL_UNSIGNED_INT_IMAGE_2D_RECT 0x9065 -#define GL_UNSIGNED_INT_IMAGE_CUBE 0x9066 -#define GL_UNSIGNED_INT_IMAGE_BUFFER 0x9067 -#define GL_UNSIGNED_INT_IMAGE_1D_ARRAY 0x9068 -#define GL_UNSIGNED_INT_IMAGE_2D_ARRAY 0x9069 -#define GL_UNSIGNED_INT_IMAGE_CUBE_MAP_ARRAY 0x906A -#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE 0x906B -#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_ARRAY 0x906C -#define GL_MAX_IMAGE_SAMPLES 0x906D -#define GL_IMAGE_BINDING_FORMAT 0x906E -#define GL_IMAGE_FORMAT_COMPATIBILITY_TYPE 0x90C7 -#define GL_IMAGE_FORMAT_COMPATIBILITY_BY_SIZE 0x90C8 -#define GL_IMAGE_FORMAT_COMPATIBILITY_BY_CLASS 0x90C9 -#define GL_MAX_VERTEX_IMAGE_UNIFORMS 0x90CA -#define GL_MAX_TESS_CONTROL_IMAGE_UNIFORMS 0x90CB -#define GL_MAX_TESS_EVALUATION_IMAGE_UNIFORMS 0x90CC -#define GL_MAX_GEOMETRY_IMAGE_UNIFORMS 0x90CD -#define GL_MAX_FRAGMENT_IMAGE_UNIFORMS 0x90CE -#define GL_MAX_COMBINED_IMAGE_UNIFORMS 0x90CF -#define GL_ALL_BARRIER_BITS 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLBINDIMAGETEXTUREPROC) (GLuint unit, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLenum format); -typedef void (GLAPIENTRY * PFNGLMEMORYBARRIERPROC) (GLbitfield barriers); - -#define glBindImageTexture GLEW_GET_FUN(__glewBindImageTexture) -#define glMemoryBarrier GLEW_GET_FUN(__glewMemoryBarrier) - -#define GLEW_ARB_shader_image_load_store GLEW_GET_VAR(__GLEW_ARB_shader_image_load_store) - -#endif /* GL_ARB_shader_image_load_store */ - -/* ------------------------ GL_ARB_shader_image_size ----------------------- */ - -#ifndef GL_ARB_shader_image_size -#define GL_ARB_shader_image_size 1 - -#define GLEW_ARB_shader_image_size GLEW_GET_VAR(__GLEW_ARB_shader_image_size) - -#endif /* GL_ARB_shader_image_size */ - -/* ------------------------- GL_ARB_shader_objects ------------------------- */ - -#ifndef GL_ARB_shader_objects -#define GL_ARB_shader_objects 1 - -#define GL_PROGRAM_OBJECT_ARB 0x8B40 -#define GL_SHADER_OBJECT_ARB 0x8B48 -#define GL_OBJECT_TYPE_ARB 0x8B4E -#define GL_OBJECT_SUBTYPE_ARB 0x8B4F -#define GL_FLOAT_VEC2_ARB 0x8B50 -#define GL_FLOAT_VEC3_ARB 0x8B51 -#define GL_FLOAT_VEC4_ARB 0x8B52 -#define GL_INT_VEC2_ARB 0x8B53 -#define GL_INT_VEC3_ARB 0x8B54 -#define GL_INT_VEC4_ARB 0x8B55 -#define GL_BOOL_ARB 0x8B56 -#define GL_BOOL_VEC2_ARB 0x8B57 -#define GL_BOOL_VEC3_ARB 0x8B58 -#define GL_BOOL_VEC4_ARB 0x8B59 -#define GL_FLOAT_MAT2_ARB 0x8B5A -#define GL_FLOAT_MAT3_ARB 0x8B5B -#define GL_FLOAT_MAT4_ARB 0x8B5C -#define GL_SAMPLER_1D_ARB 0x8B5D -#define GL_SAMPLER_2D_ARB 0x8B5E -#define GL_SAMPLER_3D_ARB 0x8B5F -#define GL_SAMPLER_CUBE_ARB 0x8B60 -#define GL_SAMPLER_1D_SHADOW_ARB 0x8B61 -#define GL_SAMPLER_2D_SHADOW_ARB 0x8B62 -#define GL_SAMPLER_2D_RECT_ARB 0x8B63 -#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 -#define GL_OBJECT_DELETE_STATUS_ARB 0x8B80 -#define GL_OBJECT_COMPILE_STATUS_ARB 0x8B81 -#define GL_OBJECT_LINK_STATUS_ARB 0x8B82 -#define GL_OBJECT_VALIDATE_STATUS_ARB 0x8B83 -#define GL_OBJECT_INFO_LOG_LENGTH_ARB 0x8B84 -#define GL_OBJECT_ATTACHED_OBJECTS_ARB 0x8B85 -#define GL_OBJECT_ACTIVE_UNIFORMS_ARB 0x8B86 -#define GL_OBJECT_ACTIVE_UNIFORM_MAX_LENGTH_ARB 0x8B87 -#define GL_OBJECT_SHADER_SOURCE_LENGTH_ARB 0x8B88 - -typedef char GLcharARB; -typedef unsigned int GLhandleARB; - -typedef void (GLAPIENTRY * PFNGLATTACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB obj); -typedef void (GLAPIENTRY * PFNGLCOMPILESHADERARBPROC) (GLhandleARB shaderObj); -typedef GLhandleARB (GLAPIENTRY * PFNGLCREATEPROGRAMOBJECTARBPROC) (void); -typedef GLhandleARB (GLAPIENTRY * PFNGLCREATESHADEROBJECTARBPROC) (GLenum shaderType); -typedef void (GLAPIENTRY * PFNGLDELETEOBJECTARBPROC) (GLhandleARB obj); -typedef void (GLAPIENTRY * PFNGLDETACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB attachedObj); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name); -typedef void (GLAPIENTRY * PFNGLGETATTACHEDOBJECTSARBPROC) (GLhandleARB containerObj, GLsizei maxCount, GLsizei* count, GLhandleARB *obj); -typedef GLhandleARB (GLAPIENTRY * PFNGLGETHANDLEARBPROC) (GLenum pname); -typedef void (GLAPIENTRY * PFNGLGETINFOLOGARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *infoLog); -typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERFVARBPROC) (GLhandleARB obj, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETOBJECTPARAMETERIVARBPROC) (GLhandleARB obj, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETSHADERSOURCEARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei* length, GLcharARB *source); -typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB* name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMFVARBPROC) (GLhandleARB programObj, GLint location, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMIVARBPROC) (GLhandleARB programObj, GLint location, GLint* params); -typedef void (GLAPIENTRY * PFNGLLINKPROGRAMARBPROC) (GLhandleARB programObj); -typedef void (GLAPIENTRY * PFNGLSHADERSOURCEARBPROC) (GLhandleARB shaderObj, GLsizei count, const GLcharARB ** string, const GLint *length); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FARBPROC) (GLint location, GLfloat v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IARBPROC) (GLint location, GLint v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FARBPROC) (GLint location, GLfloat v0, GLfloat v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IARBPROC) (GLint location, GLint v0, GLint v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4FVARBPROC) (GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4IVARBPROC) (GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX2FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX3FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMMATRIX4FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLUSEPROGRAMOBJECTARBPROC) (GLhandleARB programObj); -typedef void (GLAPIENTRY * PFNGLVALIDATEPROGRAMARBPROC) (GLhandleARB programObj); - -#define glAttachObjectARB GLEW_GET_FUN(__glewAttachObjectARB) -#define glCompileShaderARB GLEW_GET_FUN(__glewCompileShaderARB) -#define glCreateProgramObjectARB GLEW_GET_FUN(__glewCreateProgramObjectARB) -#define glCreateShaderObjectARB GLEW_GET_FUN(__glewCreateShaderObjectARB) -#define glDeleteObjectARB GLEW_GET_FUN(__glewDeleteObjectARB) -#define glDetachObjectARB GLEW_GET_FUN(__glewDetachObjectARB) -#define glGetActiveUniformARB GLEW_GET_FUN(__glewGetActiveUniformARB) -#define glGetAttachedObjectsARB GLEW_GET_FUN(__glewGetAttachedObjectsARB) -#define glGetHandleARB GLEW_GET_FUN(__glewGetHandleARB) -#define glGetInfoLogARB GLEW_GET_FUN(__glewGetInfoLogARB) -#define glGetObjectParameterfvARB GLEW_GET_FUN(__glewGetObjectParameterfvARB) -#define glGetObjectParameterivARB GLEW_GET_FUN(__glewGetObjectParameterivARB) -#define glGetShaderSourceARB GLEW_GET_FUN(__glewGetShaderSourceARB) -#define glGetUniformLocationARB GLEW_GET_FUN(__glewGetUniformLocationARB) -#define glGetUniformfvARB GLEW_GET_FUN(__glewGetUniformfvARB) -#define glGetUniformivARB GLEW_GET_FUN(__glewGetUniformivARB) -#define glLinkProgramARB GLEW_GET_FUN(__glewLinkProgramARB) -#define glShaderSourceARB GLEW_GET_FUN(__glewShaderSourceARB) -#define glUniform1fARB GLEW_GET_FUN(__glewUniform1fARB) -#define glUniform1fvARB GLEW_GET_FUN(__glewUniform1fvARB) -#define glUniform1iARB GLEW_GET_FUN(__glewUniform1iARB) -#define glUniform1ivARB GLEW_GET_FUN(__glewUniform1ivARB) -#define glUniform2fARB GLEW_GET_FUN(__glewUniform2fARB) -#define glUniform2fvARB GLEW_GET_FUN(__glewUniform2fvARB) -#define glUniform2iARB GLEW_GET_FUN(__glewUniform2iARB) -#define glUniform2ivARB GLEW_GET_FUN(__glewUniform2ivARB) -#define glUniform3fARB GLEW_GET_FUN(__glewUniform3fARB) -#define glUniform3fvARB GLEW_GET_FUN(__glewUniform3fvARB) -#define glUniform3iARB GLEW_GET_FUN(__glewUniform3iARB) -#define glUniform3ivARB GLEW_GET_FUN(__glewUniform3ivARB) -#define glUniform4fARB GLEW_GET_FUN(__glewUniform4fARB) -#define glUniform4fvARB GLEW_GET_FUN(__glewUniform4fvARB) -#define glUniform4iARB GLEW_GET_FUN(__glewUniform4iARB) -#define glUniform4ivARB GLEW_GET_FUN(__glewUniform4ivARB) -#define glUniformMatrix2fvARB GLEW_GET_FUN(__glewUniformMatrix2fvARB) -#define glUniformMatrix3fvARB GLEW_GET_FUN(__glewUniformMatrix3fvARB) -#define glUniformMatrix4fvARB GLEW_GET_FUN(__glewUniformMatrix4fvARB) -#define glUseProgramObjectARB GLEW_GET_FUN(__glewUseProgramObjectARB) -#define glValidateProgramARB GLEW_GET_FUN(__glewValidateProgramARB) - -#define GLEW_ARB_shader_objects GLEW_GET_VAR(__GLEW_ARB_shader_objects) - -#endif /* GL_ARB_shader_objects */ - -/* ------------------------ GL_ARB_shader_precision ------------------------ */ - -#ifndef GL_ARB_shader_precision -#define GL_ARB_shader_precision 1 - -#define GLEW_ARB_shader_precision GLEW_GET_VAR(__GLEW_ARB_shader_precision) - -#endif /* GL_ARB_shader_precision */ - -/* ---------------------- GL_ARB_shader_stencil_export --------------------- */ - -#ifndef GL_ARB_shader_stencil_export -#define GL_ARB_shader_stencil_export 1 - -#define GLEW_ARB_shader_stencil_export GLEW_GET_VAR(__GLEW_ARB_shader_stencil_export) - -#endif /* GL_ARB_shader_stencil_export */ - -/* ------------------ GL_ARB_shader_storage_buffer_object ------------------ */ - -#ifndef GL_ARB_shader_storage_buffer_object -#define GL_ARB_shader_storage_buffer_object 1 - -#define GL_SHADER_STORAGE_BARRIER_BIT 0x2000 -#define GL_MAX_COMBINED_SHADER_OUTPUT_RESOURCES 0x8F39 -#define GL_SHADER_STORAGE_BUFFER 0x90D2 -#define GL_SHADER_STORAGE_BUFFER_BINDING 0x90D3 -#define GL_SHADER_STORAGE_BUFFER_START 0x90D4 -#define GL_SHADER_STORAGE_BUFFER_SIZE 0x90D5 -#define GL_MAX_VERTEX_SHADER_STORAGE_BLOCKS 0x90D6 -#define GL_MAX_GEOMETRY_SHADER_STORAGE_BLOCKS 0x90D7 -#define GL_MAX_TESS_CONTROL_SHADER_STORAGE_BLOCKS 0x90D8 -#define GL_MAX_TESS_EVALUATION_SHADER_STORAGE_BLOCKS 0x90D9 -#define GL_MAX_FRAGMENT_SHADER_STORAGE_BLOCKS 0x90DA -#define GL_MAX_COMPUTE_SHADER_STORAGE_BLOCKS 0x90DB -#define GL_MAX_COMBINED_SHADER_STORAGE_BLOCKS 0x90DC -#define GL_MAX_SHADER_STORAGE_BUFFER_BINDINGS 0x90DD -#define GL_MAX_SHADER_STORAGE_BLOCK_SIZE 0x90DE -#define GL_SHADER_STORAGE_BUFFER_OFFSET_ALIGNMENT 0x90DF - -typedef void (GLAPIENTRY * PFNGLSHADERSTORAGEBLOCKBINDINGPROC) (GLuint program, GLuint storageBlockIndex, GLuint storageBlockBinding); - -#define glShaderStorageBlockBinding GLEW_GET_FUN(__glewShaderStorageBlockBinding) - -#define GLEW_ARB_shader_storage_buffer_object GLEW_GET_VAR(__GLEW_ARB_shader_storage_buffer_object) - -#endif /* GL_ARB_shader_storage_buffer_object */ - -/* ------------------------ GL_ARB_shader_subroutine ----------------------- */ - -#ifndef GL_ARB_shader_subroutine -#define GL_ARB_shader_subroutine 1 - -#define GL_ACTIVE_SUBROUTINES 0x8DE5 -#define GL_ACTIVE_SUBROUTINE_UNIFORMS 0x8DE6 -#define GL_MAX_SUBROUTINES 0x8DE7 -#define GL_MAX_SUBROUTINE_UNIFORM_LOCATIONS 0x8DE8 -#define GL_ACTIVE_SUBROUTINE_UNIFORM_LOCATIONS 0x8E47 -#define GL_ACTIVE_SUBROUTINE_MAX_LENGTH 0x8E48 -#define GL_ACTIVE_SUBROUTINE_UNIFORM_MAX_LENGTH 0x8E49 -#define GL_NUM_COMPATIBLE_SUBROUTINES 0x8E4A -#define GL_COMPATIBLE_SUBROUTINES 0x8E4B - -typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINENAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei* length, GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC) (GLuint program, GLenum shadertype, GLuint index, GLenum pname, GLint* values); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTAGEIVPROC) (GLuint program, GLenum shadertype, GLenum pname, GLint* values); -typedef GLuint (GLAPIENTRY * PFNGLGETSUBROUTINEINDEXPROC) (GLuint program, GLenum shadertype, const GLchar* name); -typedef GLint (GLAPIENTRY * PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC) (GLuint program, GLenum shadertype, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMSUBROUTINEUIVPROC) (GLenum shadertype, GLint location, GLuint* params); -typedef void (GLAPIENTRY * PFNGLUNIFORMSUBROUTINESUIVPROC) (GLenum shadertype, GLsizei count, const GLuint* indices); - -#define glGetActiveSubroutineName GLEW_GET_FUN(__glewGetActiveSubroutineName) -#define glGetActiveSubroutineUniformName GLEW_GET_FUN(__glewGetActiveSubroutineUniformName) -#define glGetActiveSubroutineUniformiv GLEW_GET_FUN(__glewGetActiveSubroutineUniformiv) -#define glGetProgramStageiv GLEW_GET_FUN(__glewGetProgramStageiv) -#define glGetSubroutineIndex GLEW_GET_FUN(__glewGetSubroutineIndex) -#define glGetSubroutineUniformLocation GLEW_GET_FUN(__glewGetSubroutineUniformLocation) -#define glGetUniformSubroutineuiv GLEW_GET_FUN(__glewGetUniformSubroutineuiv) -#define glUniformSubroutinesuiv GLEW_GET_FUN(__glewUniformSubroutinesuiv) - -#define GLEW_ARB_shader_subroutine GLEW_GET_VAR(__GLEW_ARB_shader_subroutine) - -#endif /* GL_ARB_shader_subroutine */ - -/* ----------------------- GL_ARB_shader_texture_lod ----------------------- */ - -#ifndef GL_ARB_shader_texture_lod -#define GL_ARB_shader_texture_lod 1 - -#define GLEW_ARB_shader_texture_lod GLEW_GET_VAR(__GLEW_ARB_shader_texture_lod) - -#endif /* GL_ARB_shader_texture_lod */ - -/* ---------------------- GL_ARB_shading_language_100 ---------------------- */ - -#ifndef GL_ARB_shading_language_100 -#define GL_ARB_shading_language_100 1 - -#define GL_SHADING_LANGUAGE_VERSION_ARB 0x8B8C - -#define GLEW_ARB_shading_language_100 GLEW_GET_VAR(__GLEW_ARB_shading_language_100) - -#endif /* GL_ARB_shading_language_100 */ - -/* -------------------- GL_ARB_shading_language_420pack -------------------- */ - -#ifndef GL_ARB_shading_language_420pack -#define GL_ARB_shading_language_420pack 1 - -#define GLEW_ARB_shading_language_420pack GLEW_GET_VAR(__GLEW_ARB_shading_language_420pack) - -#endif /* GL_ARB_shading_language_420pack */ - -/* -------------------- GL_ARB_shading_language_include -------------------- */ - -#ifndef GL_ARB_shading_language_include -#define GL_ARB_shading_language_include 1 - -#define GL_SHADER_INCLUDE_ARB 0x8DAE -#define GL_NAMED_STRING_LENGTH_ARB 0x8DE9 -#define GL_NAMED_STRING_TYPE_ARB 0x8DEA - -typedef void (GLAPIENTRY * PFNGLCOMPILESHADERINCLUDEARBPROC) (GLuint shader, GLsizei count, const GLchar* const *path, const GLint *length); -typedef void (GLAPIENTRY * PFNGLDELETENAMEDSTRINGARBPROC) (GLint namelen, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLGETNAMEDSTRINGARBPROC) (GLint namelen, const GLchar* name, GLsizei bufSize, GLint *stringlen, GLchar *string); -typedef void (GLAPIENTRY * PFNGLGETNAMEDSTRINGIVARBPROC) (GLint namelen, const GLchar* name, GLenum pname, GLint *params); -typedef GLboolean (GLAPIENTRY * PFNGLISNAMEDSTRINGARBPROC) (GLint namelen, const GLchar* name); -typedef void (GLAPIENTRY * PFNGLNAMEDSTRINGARBPROC) (GLenum type, GLint namelen, const GLchar* name, GLint stringlen, const GLchar *string); - -#define glCompileShaderIncludeARB GLEW_GET_FUN(__glewCompileShaderIncludeARB) -#define glDeleteNamedStringARB GLEW_GET_FUN(__glewDeleteNamedStringARB) -#define glGetNamedStringARB GLEW_GET_FUN(__glewGetNamedStringARB) -#define glGetNamedStringivARB GLEW_GET_FUN(__glewGetNamedStringivARB) -#define glIsNamedStringARB GLEW_GET_FUN(__glewIsNamedStringARB) -#define glNamedStringARB GLEW_GET_FUN(__glewNamedStringARB) - -#define GLEW_ARB_shading_language_include GLEW_GET_VAR(__GLEW_ARB_shading_language_include) - -#endif /* GL_ARB_shading_language_include */ - -/* -------------------- GL_ARB_shading_language_packing -------------------- */ - -#ifndef GL_ARB_shading_language_packing -#define GL_ARB_shading_language_packing 1 - -#define GLEW_ARB_shading_language_packing GLEW_GET_VAR(__GLEW_ARB_shading_language_packing) - -#endif /* GL_ARB_shading_language_packing */ - -/* ----------------------------- GL_ARB_shadow ----------------------------- */ - -#ifndef GL_ARB_shadow -#define GL_ARB_shadow 1 - -#define GL_TEXTURE_COMPARE_MODE_ARB 0x884C -#define GL_TEXTURE_COMPARE_FUNC_ARB 0x884D -#define GL_COMPARE_R_TO_TEXTURE_ARB 0x884E - -#define GLEW_ARB_shadow GLEW_GET_VAR(__GLEW_ARB_shadow) - -#endif /* GL_ARB_shadow */ - -/* ------------------------- GL_ARB_shadow_ambient ------------------------- */ - -#ifndef GL_ARB_shadow_ambient -#define GL_ARB_shadow_ambient 1 - -#define GL_TEXTURE_COMPARE_FAIL_VALUE_ARB 0x80BF - -#define GLEW_ARB_shadow_ambient GLEW_GET_VAR(__GLEW_ARB_shadow_ambient) - -#endif /* GL_ARB_shadow_ambient */ - -/* ------------------------- GL_ARB_sparse_texture ------------------------- */ - -#ifndef GL_ARB_sparse_texture -#define GL_ARB_sparse_texture 1 - -#define GL_VIRTUAL_PAGE_SIZE_X_ARB 0x9195 -#define GL_VIRTUAL_PAGE_SIZE_Y_ARB 0x9196 -#define GL_VIRTUAL_PAGE_SIZE_Z_ARB 0x9197 -#define GL_MAX_SPARSE_TEXTURE_SIZE_ARB 0x9198 -#define GL_MAX_SPARSE_3D_TEXTURE_SIZE_ARB 0x9199 -#define GL_MAX_SPARSE_ARRAY_TEXTURE_LAYERS_ARB 0x919A -#define GL_TEXTURE_SPARSE_ARB 0x91A6 -#define GL_VIRTUAL_PAGE_SIZE_INDEX_ARB 0x91A7 -#define GL_NUM_VIRTUAL_PAGE_SIZES_ARB 0x91A8 -#define GL_SPARSE_TEXTURE_FULL_ARRAY_CUBE_MIPMAPS_ARB 0x91A9 -#define GL_NUM_SPARSE_LEVELS_ARB 0x91AA - -typedef void (GLAPIENTRY * PFNGLTEXPAGECOMMITMENTARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLboolean commit); -typedef void (GLAPIENTRY * PFNGLTEXTUREPAGECOMMITMENTEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLboolean commit); - -#define glTexPageCommitmentARB GLEW_GET_FUN(__glewTexPageCommitmentARB) -#define glTexturePageCommitmentEXT GLEW_GET_FUN(__glewTexturePageCommitmentEXT) - -#define GLEW_ARB_sparse_texture GLEW_GET_VAR(__GLEW_ARB_sparse_texture) - -#endif /* GL_ARB_sparse_texture */ - -/* ------------------------ GL_ARB_stencil_texturing ----------------------- */ - -#ifndef GL_ARB_stencil_texturing -#define GL_ARB_stencil_texturing 1 - -#define GL_DEPTH_STENCIL_TEXTURE_MODE 0x90EA - -#define GLEW_ARB_stencil_texturing GLEW_GET_VAR(__GLEW_ARB_stencil_texturing) - -#endif /* GL_ARB_stencil_texturing */ - -/* ------------------------------ GL_ARB_sync ------------------------------ */ - -#ifndef GL_ARB_sync -#define GL_ARB_sync 1 - -#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001 -#define GL_MAX_SERVER_WAIT_TIMEOUT 0x9111 -#define GL_OBJECT_TYPE 0x9112 -#define GL_SYNC_CONDITION 0x9113 -#define GL_SYNC_STATUS 0x9114 -#define GL_SYNC_FLAGS 0x9115 -#define GL_SYNC_FENCE 0x9116 -#define GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117 -#define GL_UNSIGNALED 0x9118 -#define GL_SIGNALED 0x9119 -#define GL_ALREADY_SIGNALED 0x911A -#define GL_TIMEOUT_EXPIRED 0x911B -#define GL_CONDITION_SATISFIED 0x911C -#define GL_WAIT_FAILED 0x911D -#define GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFF - -typedef GLenum (GLAPIENTRY * PFNGLCLIENTWAITSYNCPROC) (GLsync GLsync,GLbitfield flags,GLuint64 timeout); -typedef void (GLAPIENTRY * PFNGLDELETESYNCPROC) (GLsync GLsync); -typedef GLsync (GLAPIENTRY * PFNGLFENCESYNCPROC) (GLenum condition,GLbitfield flags); -typedef void (GLAPIENTRY * PFNGLGETINTEGER64VPROC) (GLenum pname, GLint64* params); -typedef void (GLAPIENTRY * PFNGLGETSYNCIVPROC) (GLsync GLsync,GLenum pname,GLsizei bufSize,GLsizei* length, GLint *values); -typedef GLboolean (GLAPIENTRY * PFNGLISSYNCPROC) (GLsync GLsync); -typedef void (GLAPIENTRY * PFNGLWAITSYNCPROC) (GLsync GLsync,GLbitfield flags,GLuint64 timeout); - -#define glClientWaitSync GLEW_GET_FUN(__glewClientWaitSync) -#define glDeleteSync GLEW_GET_FUN(__glewDeleteSync) -#define glFenceSync GLEW_GET_FUN(__glewFenceSync) -#define glGetInteger64v GLEW_GET_FUN(__glewGetInteger64v) -#define glGetSynciv GLEW_GET_FUN(__glewGetSynciv) -#define glIsSync GLEW_GET_FUN(__glewIsSync) -#define glWaitSync GLEW_GET_FUN(__glewWaitSync) - -#define GLEW_ARB_sync GLEW_GET_VAR(__GLEW_ARB_sync) - -#endif /* GL_ARB_sync */ - -/* ----------------------- GL_ARB_tessellation_shader ---------------------- */ - -#ifndef GL_ARB_tessellation_shader -#define GL_ARB_tessellation_shader 1 - -#define GL_PATCHES 0xE -#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_CONTROL_SHADER 0x84F0 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_EVALUATION_SHADER 0x84F1 -#define GL_MAX_TESS_CONTROL_INPUT_COMPONENTS 0x886C -#define GL_MAX_TESS_EVALUATION_INPUT_COMPONENTS 0x886D -#define GL_MAX_COMBINED_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E1E -#define GL_MAX_COMBINED_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E1F -#define GL_PATCH_VERTICES 0x8E72 -#define GL_PATCH_DEFAULT_INNER_LEVEL 0x8E73 -#define GL_PATCH_DEFAULT_OUTER_LEVEL 0x8E74 -#define GL_TESS_CONTROL_OUTPUT_VERTICES 0x8E75 -#define GL_TESS_GEN_MODE 0x8E76 -#define GL_TESS_GEN_SPACING 0x8E77 -#define GL_TESS_GEN_VERTEX_ORDER 0x8E78 -#define GL_TESS_GEN_POINT_MODE 0x8E79 -#define GL_ISOLINES 0x8E7A -#define GL_FRACTIONAL_ODD 0x8E7B -#define GL_FRACTIONAL_EVEN 0x8E7C -#define GL_MAX_PATCH_VERTICES 0x8E7D -#define GL_MAX_TESS_GEN_LEVEL 0x8E7E -#define GL_MAX_TESS_CONTROL_UNIFORM_COMPONENTS 0x8E7F -#define GL_MAX_TESS_EVALUATION_UNIFORM_COMPONENTS 0x8E80 -#define GL_MAX_TESS_CONTROL_TEXTURE_IMAGE_UNITS 0x8E81 -#define GL_MAX_TESS_EVALUATION_TEXTURE_IMAGE_UNITS 0x8E82 -#define GL_MAX_TESS_CONTROL_OUTPUT_COMPONENTS 0x8E83 -#define GL_MAX_TESS_PATCH_COMPONENTS 0x8E84 -#define GL_MAX_TESS_CONTROL_TOTAL_OUTPUT_COMPONENTS 0x8E85 -#define GL_MAX_TESS_EVALUATION_OUTPUT_COMPONENTS 0x8E86 -#define GL_TESS_EVALUATION_SHADER 0x8E87 -#define GL_TESS_CONTROL_SHADER 0x8E88 -#define GL_MAX_TESS_CONTROL_UNIFORM_BLOCKS 0x8E89 -#define GL_MAX_TESS_EVALUATION_UNIFORM_BLOCKS 0x8E8A - -typedef void (GLAPIENTRY * PFNGLPATCHPARAMETERFVPROC) (GLenum pname, const GLfloat* values); -typedef void (GLAPIENTRY * PFNGLPATCHPARAMETERIPROC) (GLenum pname, GLint value); - -#define glPatchParameterfv GLEW_GET_FUN(__glewPatchParameterfv) -#define glPatchParameteri GLEW_GET_FUN(__glewPatchParameteri) - -#define GLEW_ARB_tessellation_shader GLEW_GET_VAR(__GLEW_ARB_tessellation_shader) - -#endif /* GL_ARB_tessellation_shader */ - -/* ---------------------- GL_ARB_texture_border_clamp ---------------------- */ - -#ifndef GL_ARB_texture_border_clamp -#define GL_ARB_texture_border_clamp 1 - -#define GL_CLAMP_TO_BORDER_ARB 0x812D - -#define GLEW_ARB_texture_border_clamp GLEW_GET_VAR(__GLEW_ARB_texture_border_clamp) - -#endif /* GL_ARB_texture_border_clamp */ - -/* ---------------------- GL_ARB_texture_buffer_object --------------------- */ - -#ifndef GL_ARB_texture_buffer_object -#define GL_ARB_texture_buffer_object 1 - -#define GL_TEXTURE_BUFFER_ARB 0x8C2A -#define GL_MAX_TEXTURE_BUFFER_SIZE_ARB 0x8C2B -#define GL_TEXTURE_BINDING_BUFFER_ARB 0x8C2C -#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING_ARB 0x8C2D -#define GL_TEXTURE_BUFFER_FORMAT_ARB 0x8C2E - -typedef void (GLAPIENTRY * PFNGLTEXBUFFERARBPROC) (GLenum target, GLenum internalformat, GLuint buffer); - -#define glTexBufferARB GLEW_GET_FUN(__glewTexBufferARB) - -#define GLEW_ARB_texture_buffer_object GLEW_GET_VAR(__GLEW_ARB_texture_buffer_object) - -#endif /* GL_ARB_texture_buffer_object */ - -/* ------------------- GL_ARB_texture_buffer_object_rgb32 ------------------ */ - -#ifndef GL_ARB_texture_buffer_object_rgb32 -#define GL_ARB_texture_buffer_object_rgb32 1 - -#define GLEW_ARB_texture_buffer_object_rgb32 GLEW_GET_VAR(__GLEW_ARB_texture_buffer_object_rgb32) - -#endif /* GL_ARB_texture_buffer_object_rgb32 */ - -/* ---------------------- GL_ARB_texture_buffer_range ---------------------- */ - -#ifndef GL_ARB_texture_buffer_range -#define GL_ARB_texture_buffer_range 1 - -#define GL_TEXTURE_BUFFER_OFFSET 0x919D -#define GL_TEXTURE_BUFFER_SIZE 0x919E -#define GL_TEXTURE_BUFFER_OFFSET_ALIGNMENT 0x919F - -typedef void (GLAPIENTRY * PFNGLTEXBUFFERRANGEPROC) (GLenum target, GLenum internalformat, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLTEXTUREBUFFERRANGEEXTPROC) (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer, GLintptr offset, GLsizeiptr size); - -#define glTexBufferRange GLEW_GET_FUN(__glewTexBufferRange) -#define glTextureBufferRangeEXT GLEW_GET_FUN(__glewTextureBufferRangeEXT) - -#define GLEW_ARB_texture_buffer_range GLEW_GET_VAR(__GLEW_ARB_texture_buffer_range) - -#endif /* GL_ARB_texture_buffer_range */ - -/* ----------------------- GL_ARB_texture_compression ---------------------- */ - -#ifndef GL_ARB_texture_compression -#define GL_ARB_texture_compression 1 - -#define GL_COMPRESSED_ALPHA_ARB 0x84E9 -#define GL_COMPRESSED_LUMINANCE_ARB 0x84EA -#define GL_COMPRESSED_LUMINANCE_ALPHA_ARB 0x84EB -#define GL_COMPRESSED_INTENSITY_ARB 0x84EC -#define GL_COMPRESSED_RGB_ARB 0x84ED -#define GL_COMPRESSED_RGBA_ARB 0x84EE -#define GL_TEXTURE_COMPRESSION_HINT_ARB 0x84EF -#define GL_TEXTURE_COMPRESSED_IMAGE_SIZE_ARB 0x86A0 -#define GL_TEXTURE_COMPRESSED_ARB 0x86A1 -#define GL_NUM_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A2 -#define GL_COMPRESSED_TEXTURE_FORMATS_ARB 0x86A3 - -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE1DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE2DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXIMAGE3DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint lod, GLvoid *img); - -#define glCompressedTexImage1DARB GLEW_GET_FUN(__glewCompressedTexImage1DARB) -#define glCompressedTexImage2DARB GLEW_GET_FUN(__glewCompressedTexImage2DARB) -#define glCompressedTexImage3DARB GLEW_GET_FUN(__glewCompressedTexImage3DARB) -#define glCompressedTexSubImage1DARB GLEW_GET_FUN(__glewCompressedTexSubImage1DARB) -#define glCompressedTexSubImage2DARB GLEW_GET_FUN(__glewCompressedTexSubImage2DARB) -#define glCompressedTexSubImage3DARB GLEW_GET_FUN(__glewCompressedTexSubImage3DARB) -#define glGetCompressedTexImageARB GLEW_GET_FUN(__glewGetCompressedTexImageARB) - -#define GLEW_ARB_texture_compression GLEW_GET_VAR(__GLEW_ARB_texture_compression) - -#endif /* GL_ARB_texture_compression */ - -/* -------------------- GL_ARB_texture_compression_bptc -------------------- */ - -#ifndef GL_ARB_texture_compression_bptc -#define GL_ARB_texture_compression_bptc 1 - -#define GL_COMPRESSED_RGBA_BPTC_UNORM_ARB 0x8E8C -#define GL_COMPRESSED_SRGB_ALPHA_BPTC_UNORM_ARB 0x8E8D -#define GL_COMPRESSED_RGB_BPTC_SIGNED_FLOAT_ARB 0x8E8E -#define GL_COMPRESSED_RGB_BPTC_UNSIGNED_FLOAT_ARB 0x8E8F - -#define GLEW_ARB_texture_compression_bptc GLEW_GET_VAR(__GLEW_ARB_texture_compression_bptc) - -#endif /* GL_ARB_texture_compression_bptc */ - -/* -------------------- GL_ARB_texture_compression_rgtc -------------------- */ - -#ifndef GL_ARB_texture_compression_rgtc -#define GL_ARB_texture_compression_rgtc 1 - -#define GL_COMPRESSED_RED_RGTC1 0x8DBB -#define GL_COMPRESSED_SIGNED_RED_RGTC1 0x8DBC -#define GL_COMPRESSED_RG_RGTC2 0x8DBD -#define GL_COMPRESSED_SIGNED_RG_RGTC2 0x8DBE - -#define GLEW_ARB_texture_compression_rgtc GLEW_GET_VAR(__GLEW_ARB_texture_compression_rgtc) - -#endif /* GL_ARB_texture_compression_rgtc */ - -/* ------------------------ GL_ARB_texture_cube_map ------------------------ */ - -#ifndef GL_ARB_texture_cube_map -#define GL_ARB_texture_cube_map 1 - -#define GL_NORMAL_MAP_ARB 0x8511 -#define GL_REFLECTION_MAP_ARB 0x8512 -#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARB 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_ARB 0x851C - -#define GLEW_ARB_texture_cube_map GLEW_GET_VAR(__GLEW_ARB_texture_cube_map) - -#endif /* GL_ARB_texture_cube_map */ - -/* --------------------- GL_ARB_texture_cube_map_array --------------------- */ - -#ifndef GL_ARB_texture_cube_map_array -#define GL_ARB_texture_cube_map_array 1 - -#define GL_TEXTURE_CUBE_MAP_ARRAY_ARB 0x9009 -#define GL_TEXTURE_BINDING_CUBE_MAP_ARRAY_ARB 0x900A -#define GL_PROXY_TEXTURE_CUBE_MAP_ARRAY_ARB 0x900B -#define GL_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900C -#define GL_SAMPLER_CUBE_MAP_ARRAY_SHADOW_ARB 0x900D -#define GL_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900E -#define GL_UNSIGNED_INT_SAMPLER_CUBE_MAP_ARRAY_ARB 0x900F - -#define GLEW_ARB_texture_cube_map_array GLEW_GET_VAR(__GLEW_ARB_texture_cube_map_array) - -#endif /* GL_ARB_texture_cube_map_array */ - -/* ------------------------- GL_ARB_texture_env_add ------------------------ */ - -#ifndef GL_ARB_texture_env_add -#define GL_ARB_texture_env_add 1 - -#define GLEW_ARB_texture_env_add GLEW_GET_VAR(__GLEW_ARB_texture_env_add) - -#endif /* GL_ARB_texture_env_add */ - -/* ----------------------- GL_ARB_texture_env_combine ---------------------- */ - -#ifndef GL_ARB_texture_env_combine -#define GL_ARB_texture_env_combine 1 - -#define GL_SUBTRACT_ARB 0x84E7 -#define GL_COMBINE_ARB 0x8570 -#define GL_COMBINE_RGB_ARB 0x8571 -#define GL_COMBINE_ALPHA_ARB 0x8572 -#define GL_RGB_SCALE_ARB 0x8573 -#define GL_ADD_SIGNED_ARB 0x8574 -#define GL_INTERPOLATE_ARB 0x8575 -#define GL_CONSTANT_ARB 0x8576 -#define GL_PRIMARY_COLOR_ARB 0x8577 -#define GL_PREVIOUS_ARB 0x8578 -#define GL_SOURCE0_RGB_ARB 0x8580 -#define GL_SOURCE1_RGB_ARB 0x8581 -#define GL_SOURCE2_RGB_ARB 0x8582 -#define GL_SOURCE0_ALPHA_ARB 0x8588 -#define GL_SOURCE1_ALPHA_ARB 0x8589 -#define GL_SOURCE2_ALPHA_ARB 0x858A -#define GL_OPERAND0_RGB_ARB 0x8590 -#define GL_OPERAND1_RGB_ARB 0x8591 -#define GL_OPERAND2_RGB_ARB 0x8592 -#define GL_OPERAND0_ALPHA_ARB 0x8598 -#define GL_OPERAND1_ALPHA_ARB 0x8599 -#define GL_OPERAND2_ALPHA_ARB 0x859A - -#define GLEW_ARB_texture_env_combine GLEW_GET_VAR(__GLEW_ARB_texture_env_combine) - -#endif /* GL_ARB_texture_env_combine */ - -/* ---------------------- GL_ARB_texture_env_crossbar ---------------------- */ - -#ifndef GL_ARB_texture_env_crossbar -#define GL_ARB_texture_env_crossbar 1 - -#define GLEW_ARB_texture_env_crossbar GLEW_GET_VAR(__GLEW_ARB_texture_env_crossbar) - -#endif /* GL_ARB_texture_env_crossbar */ - -/* ------------------------ GL_ARB_texture_env_dot3 ------------------------ */ - -#ifndef GL_ARB_texture_env_dot3 -#define GL_ARB_texture_env_dot3 1 - -#define GL_DOT3_RGB_ARB 0x86AE -#define GL_DOT3_RGBA_ARB 0x86AF - -#define GLEW_ARB_texture_env_dot3 GLEW_GET_VAR(__GLEW_ARB_texture_env_dot3) - -#endif /* GL_ARB_texture_env_dot3 */ - -/* -------------------------- GL_ARB_texture_float ------------------------- */ - -#ifndef GL_ARB_texture_float -#define GL_ARB_texture_float 1 - -#define GL_RGBA32F_ARB 0x8814 -#define GL_RGB32F_ARB 0x8815 -#define GL_ALPHA32F_ARB 0x8816 -#define GL_INTENSITY32F_ARB 0x8817 -#define GL_LUMINANCE32F_ARB 0x8818 -#define GL_LUMINANCE_ALPHA32F_ARB 0x8819 -#define GL_RGBA16F_ARB 0x881A -#define GL_RGB16F_ARB 0x881B -#define GL_ALPHA16F_ARB 0x881C -#define GL_INTENSITY16F_ARB 0x881D -#define GL_LUMINANCE16F_ARB 0x881E -#define GL_LUMINANCE_ALPHA16F_ARB 0x881F -#define GL_TEXTURE_RED_TYPE_ARB 0x8C10 -#define GL_TEXTURE_GREEN_TYPE_ARB 0x8C11 -#define GL_TEXTURE_BLUE_TYPE_ARB 0x8C12 -#define GL_TEXTURE_ALPHA_TYPE_ARB 0x8C13 -#define GL_TEXTURE_LUMINANCE_TYPE_ARB 0x8C14 -#define GL_TEXTURE_INTENSITY_TYPE_ARB 0x8C15 -#define GL_TEXTURE_DEPTH_TYPE_ARB 0x8C16 -#define GL_UNSIGNED_NORMALIZED_ARB 0x8C17 - -#define GLEW_ARB_texture_float GLEW_GET_VAR(__GLEW_ARB_texture_float) - -#endif /* GL_ARB_texture_float */ - -/* ------------------------- GL_ARB_texture_gather ------------------------- */ - -#ifndef GL_ARB_texture_gather -#define GL_ARB_texture_gather 1 - -#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5E -#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_ARB 0x8E5F -#define GL_MAX_PROGRAM_TEXTURE_GATHER_COMPONENTS_ARB 0x8F9F - -#define GLEW_ARB_texture_gather GLEW_GET_VAR(__GLEW_ARB_texture_gather) - -#endif /* GL_ARB_texture_gather */ - -/* ------------------ GL_ARB_texture_mirror_clamp_to_edge ------------------ */ - -#ifndef GL_ARB_texture_mirror_clamp_to_edge -#define GL_ARB_texture_mirror_clamp_to_edge 1 - -#define GL_MIRROR_CLAMP_TO_EDGE 0x8743 - -#define GLEW_ARB_texture_mirror_clamp_to_edge GLEW_GET_VAR(__GLEW_ARB_texture_mirror_clamp_to_edge) - -#endif /* GL_ARB_texture_mirror_clamp_to_edge */ - -/* --------------------- GL_ARB_texture_mirrored_repeat -------------------- */ - -#ifndef GL_ARB_texture_mirrored_repeat -#define GL_ARB_texture_mirrored_repeat 1 - -#define GL_MIRRORED_REPEAT_ARB 0x8370 - -#define GLEW_ARB_texture_mirrored_repeat GLEW_GET_VAR(__GLEW_ARB_texture_mirrored_repeat) - -#endif /* GL_ARB_texture_mirrored_repeat */ - -/* ----------------------- GL_ARB_texture_multisample ---------------------- */ - -#ifndef GL_ARB_texture_multisample -#define GL_ARB_texture_multisample 1 - -#define GL_SAMPLE_POSITION 0x8E50 -#define GL_SAMPLE_MASK 0x8E51 -#define GL_SAMPLE_MASK_VALUE 0x8E52 -#define GL_MAX_SAMPLE_MASK_WORDS 0x8E59 -#define GL_TEXTURE_2D_MULTISAMPLE 0x9100 -#define GL_PROXY_TEXTURE_2D_MULTISAMPLE 0x9101 -#define GL_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9102 -#define GL_PROXY_TEXTURE_2D_MULTISAMPLE_ARRAY 0x9103 -#define GL_TEXTURE_BINDING_2D_MULTISAMPLE 0x9104 -#define GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY 0x9105 -#define GL_TEXTURE_SAMPLES 0x9106 -#define GL_TEXTURE_FIXED_SAMPLE_LOCATIONS 0x9107 -#define GL_SAMPLER_2D_MULTISAMPLE 0x9108 -#define GL_INT_SAMPLER_2D_MULTISAMPLE 0x9109 -#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE 0x910A -#define GL_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910B -#define GL_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910C -#define GL_UNSIGNED_INT_SAMPLER_2D_MULTISAMPLE_ARRAY 0x910D -#define GL_MAX_COLOR_TEXTURE_SAMPLES 0x910E -#define GL_MAX_DEPTH_TEXTURE_SAMPLES 0x910F -#define GL_MAX_INTEGER_SAMPLES 0x9110 - -typedef void (GLAPIENTRY * PFNGLGETMULTISAMPLEFVPROC) (GLenum pname, GLuint index, GLfloat* val); -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKIPROC) (GLuint index, GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE2DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); - -#define glGetMultisamplefv GLEW_GET_FUN(__glewGetMultisamplefv) -#define glSampleMaski GLEW_GET_FUN(__glewSampleMaski) -#define glTexImage2DMultisample GLEW_GET_FUN(__glewTexImage2DMultisample) -#define glTexImage3DMultisample GLEW_GET_FUN(__glewTexImage3DMultisample) - -#define GLEW_ARB_texture_multisample GLEW_GET_VAR(__GLEW_ARB_texture_multisample) - -#endif /* GL_ARB_texture_multisample */ - -/* -------------------- GL_ARB_texture_non_power_of_two -------------------- */ - -#ifndef GL_ARB_texture_non_power_of_two -#define GL_ARB_texture_non_power_of_two 1 - -#define GLEW_ARB_texture_non_power_of_two GLEW_GET_VAR(__GLEW_ARB_texture_non_power_of_two) - -#endif /* GL_ARB_texture_non_power_of_two */ - -/* ---------------------- GL_ARB_texture_query_levels ---------------------- */ - -#ifndef GL_ARB_texture_query_levels -#define GL_ARB_texture_query_levels 1 - -#define GLEW_ARB_texture_query_levels GLEW_GET_VAR(__GLEW_ARB_texture_query_levels) - -#endif /* GL_ARB_texture_query_levels */ - -/* ------------------------ GL_ARB_texture_query_lod ----------------------- */ - -#ifndef GL_ARB_texture_query_lod -#define GL_ARB_texture_query_lod 1 - -#define GLEW_ARB_texture_query_lod GLEW_GET_VAR(__GLEW_ARB_texture_query_lod) - -#endif /* GL_ARB_texture_query_lod */ - -/* ------------------------ GL_ARB_texture_rectangle ----------------------- */ - -#ifndef GL_ARB_texture_rectangle -#define GL_ARB_texture_rectangle 1 - -#define GL_TEXTURE_RECTANGLE_ARB 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_ARB 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_ARB 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_ARB 0x84F8 -#define GL_SAMPLER_2D_RECT_ARB 0x8B63 -#define GL_SAMPLER_2D_RECT_SHADOW_ARB 0x8B64 - -#define GLEW_ARB_texture_rectangle GLEW_GET_VAR(__GLEW_ARB_texture_rectangle) - -#endif /* GL_ARB_texture_rectangle */ - -/* --------------------------- GL_ARB_texture_rg --------------------------- */ - -#ifndef GL_ARB_texture_rg -#define GL_ARB_texture_rg 1 - -#define GL_COMPRESSED_RED 0x8225 -#define GL_COMPRESSED_RG 0x8226 -#define GL_RG 0x8227 -#define GL_RG_INTEGER 0x8228 -#define GL_R8 0x8229 -#define GL_R16 0x822A -#define GL_RG8 0x822B -#define GL_RG16 0x822C -#define GL_R16F 0x822D -#define GL_R32F 0x822E -#define GL_RG16F 0x822F -#define GL_RG32F 0x8230 -#define GL_R8I 0x8231 -#define GL_R8UI 0x8232 -#define GL_R16I 0x8233 -#define GL_R16UI 0x8234 -#define GL_R32I 0x8235 -#define GL_R32UI 0x8236 -#define GL_RG8I 0x8237 -#define GL_RG8UI 0x8238 -#define GL_RG16I 0x8239 -#define GL_RG16UI 0x823A -#define GL_RG32I 0x823B -#define GL_RG32UI 0x823C - -#define GLEW_ARB_texture_rg GLEW_GET_VAR(__GLEW_ARB_texture_rg) - -#endif /* GL_ARB_texture_rg */ - -/* ----------------------- GL_ARB_texture_rgb10_a2ui ----------------------- */ - -#ifndef GL_ARB_texture_rgb10_a2ui -#define GL_ARB_texture_rgb10_a2ui 1 - -#define GL_RGB10_A2UI 0x906F - -#define GLEW_ARB_texture_rgb10_a2ui GLEW_GET_VAR(__GLEW_ARB_texture_rgb10_a2ui) - -#endif /* GL_ARB_texture_rgb10_a2ui */ - -/* ------------------------ GL_ARB_texture_stencil8 ------------------------ */ - -#ifndef GL_ARB_texture_stencil8 -#define GL_ARB_texture_stencil8 1 - -#define GL_STENCIL_INDEX 0x1901 -#define GL_STENCIL_INDEX8 0x8D48 - -#define GLEW_ARB_texture_stencil8 GLEW_GET_VAR(__GLEW_ARB_texture_stencil8) - -#endif /* GL_ARB_texture_stencil8 */ - -/* ------------------------- GL_ARB_texture_storage ------------------------ */ - -#ifndef GL_ARB_texture_storage -#define GL_ARB_texture_storage 1 - -#define GL_TEXTURE_IMMUTABLE_FORMAT 0x912F - -typedef void (GLAPIENTRY * PFNGLTEXSTORAGE1DPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); -typedef void (GLAPIENTRY * PFNGLTEXSTORAGE2DPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLTEXSTORAGE3DPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); -typedef void (GLAPIENTRY * PFNGLTEXTURESTORAGE1DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); -typedef void (GLAPIENTRY * PFNGLTEXTURESTORAGE2DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLTEXTURESTORAGE3DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); - -#define glTexStorage1D GLEW_GET_FUN(__glewTexStorage1D) -#define glTexStorage2D GLEW_GET_FUN(__glewTexStorage2D) -#define glTexStorage3D GLEW_GET_FUN(__glewTexStorage3D) -#define glTextureStorage1DEXT GLEW_GET_FUN(__glewTextureStorage1DEXT) -#define glTextureStorage2DEXT GLEW_GET_FUN(__glewTextureStorage2DEXT) -#define glTextureStorage3DEXT GLEW_GET_FUN(__glewTextureStorage3DEXT) - -#define GLEW_ARB_texture_storage GLEW_GET_VAR(__GLEW_ARB_texture_storage) - -#endif /* GL_ARB_texture_storage */ - -/* ------------------- GL_ARB_texture_storage_multisample ------------------ */ - -#ifndef GL_ARB_texture_storage_multisample -#define GL_ARB_texture_storage_multisample 1 - -typedef void (GLAPIENTRY * PFNGLTEXSTORAGE2DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); -typedef void (GLAPIENTRY * PFNGLTEXSTORAGE3DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); -typedef void (GLAPIENTRY * PFNGLTEXTURESTORAGE2DMULTISAMPLEEXTPROC) (GLuint texture, GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); -typedef void (GLAPIENTRY * PFNGLTEXTURESTORAGE3DMULTISAMPLEEXTPROC) (GLuint texture, GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); - -#define glTexStorage2DMultisample GLEW_GET_FUN(__glewTexStorage2DMultisample) -#define glTexStorage3DMultisample GLEW_GET_FUN(__glewTexStorage3DMultisample) -#define glTextureStorage2DMultisampleEXT GLEW_GET_FUN(__glewTextureStorage2DMultisampleEXT) -#define glTextureStorage3DMultisampleEXT GLEW_GET_FUN(__glewTextureStorage3DMultisampleEXT) - -#define GLEW_ARB_texture_storage_multisample GLEW_GET_VAR(__GLEW_ARB_texture_storage_multisample) - -#endif /* GL_ARB_texture_storage_multisample */ - -/* ------------------------- GL_ARB_texture_swizzle ------------------------ */ - -#ifndef GL_ARB_texture_swizzle -#define GL_ARB_texture_swizzle 1 - -#define GL_TEXTURE_SWIZZLE_R 0x8E42 -#define GL_TEXTURE_SWIZZLE_G 0x8E43 -#define GL_TEXTURE_SWIZZLE_B 0x8E44 -#define GL_TEXTURE_SWIZZLE_A 0x8E45 -#define GL_TEXTURE_SWIZZLE_RGBA 0x8E46 - -#define GLEW_ARB_texture_swizzle GLEW_GET_VAR(__GLEW_ARB_texture_swizzle) - -#endif /* GL_ARB_texture_swizzle */ - -/* -------------------------- GL_ARB_texture_view -------------------------- */ - -#ifndef GL_ARB_texture_view -#define GL_ARB_texture_view 1 - -#define GL_TEXTURE_VIEW_MIN_LEVEL 0x82DB -#define GL_TEXTURE_VIEW_NUM_LEVELS 0x82DC -#define GL_TEXTURE_VIEW_MIN_LAYER 0x82DD -#define GL_TEXTURE_VIEW_NUM_LAYERS 0x82DE -#define GL_TEXTURE_IMMUTABLE_LEVELS 0x82DF - -typedef void (GLAPIENTRY * PFNGLTEXTUREVIEWPROC) (GLuint texture, GLenum target, GLuint origtexture, GLenum internalformat, GLuint minlevel, GLuint numlevels, GLuint minlayer, GLuint numlayers); - -#define glTextureView GLEW_GET_FUN(__glewTextureView) - -#define GLEW_ARB_texture_view GLEW_GET_VAR(__GLEW_ARB_texture_view) - -#endif /* GL_ARB_texture_view */ - -/* --------------------------- GL_ARB_timer_query -------------------------- */ - -#ifndef GL_ARB_timer_query -#define GL_ARB_timer_query 1 - -#define GL_TIME_ELAPSED 0x88BF -#define GL_TIMESTAMP 0x8E28 - -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VPROC) (GLuint id, GLenum pname, GLint64* params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VPROC) (GLuint id, GLenum pname, GLuint64* params); -typedef void (GLAPIENTRY * PFNGLQUERYCOUNTERPROC) (GLuint id, GLenum target); - -#define glGetQueryObjecti64v GLEW_GET_FUN(__glewGetQueryObjecti64v) -#define glGetQueryObjectui64v GLEW_GET_FUN(__glewGetQueryObjectui64v) -#define glQueryCounter GLEW_GET_FUN(__glewQueryCounter) - -#define GLEW_ARB_timer_query GLEW_GET_VAR(__GLEW_ARB_timer_query) - -#endif /* GL_ARB_timer_query */ - -/* ----------------------- GL_ARB_transform_feedback2 ---------------------- */ - -#ifndef GL_ARB_transform_feedback2 -#define GL_ARB_transform_feedback2 1 - -#define GL_TRANSFORM_FEEDBACK 0x8E22 -#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED 0x8E23 -#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE 0x8E24 -#define GL_TRANSFORM_FEEDBACK_BINDING 0x8E25 - -typedef void (GLAPIENTRY * PFNGLBINDTRANSFORMFEEDBACKPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETETRANSFORMFEEDBACKSPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKPROC) (GLenum mode, GLuint id); -typedef void (GLAPIENTRY * PFNGLGENTRANSFORMFEEDBACKSPROC) (GLsizei n, GLuint* ids); -typedef GLboolean (GLAPIENTRY * PFNGLISTRANSFORMFEEDBACKPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLPAUSETRANSFORMFEEDBACKPROC) (void); -typedef void (GLAPIENTRY * PFNGLRESUMETRANSFORMFEEDBACKPROC) (void); - -#define glBindTransformFeedback GLEW_GET_FUN(__glewBindTransformFeedback) -#define glDeleteTransformFeedbacks GLEW_GET_FUN(__glewDeleteTransformFeedbacks) -#define glDrawTransformFeedback GLEW_GET_FUN(__glewDrawTransformFeedback) -#define glGenTransformFeedbacks GLEW_GET_FUN(__glewGenTransformFeedbacks) -#define glIsTransformFeedback GLEW_GET_FUN(__glewIsTransformFeedback) -#define glPauseTransformFeedback GLEW_GET_FUN(__glewPauseTransformFeedback) -#define glResumeTransformFeedback GLEW_GET_FUN(__glewResumeTransformFeedback) - -#define GLEW_ARB_transform_feedback2 GLEW_GET_VAR(__GLEW_ARB_transform_feedback2) - -#endif /* GL_ARB_transform_feedback2 */ - -/* ----------------------- GL_ARB_transform_feedback3 ---------------------- */ - -#ifndef GL_ARB_transform_feedback3 -#define GL_ARB_transform_feedback3 1 - -#define GL_MAX_TRANSFORM_FEEDBACK_BUFFERS 0x8E70 -#define GL_MAX_VERTEX_STREAMS 0x8E71 - -typedef void (GLAPIENTRY * PFNGLBEGINQUERYINDEXEDPROC) (GLenum target, GLuint index, GLuint id); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC) (GLenum mode, GLuint id, GLuint stream); -typedef void (GLAPIENTRY * PFNGLENDQUERYINDEXEDPROC) (GLenum target, GLuint index); -typedef void (GLAPIENTRY * PFNGLGETQUERYINDEXEDIVPROC) (GLenum target, GLuint index, GLenum pname, GLint* params); - -#define glBeginQueryIndexed GLEW_GET_FUN(__glewBeginQueryIndexed) -#define glDrawTransformFeedbackStream GLEW_GET_FUN(__glewDrawTransformFeedbackStream) -#define glEndQueryIndexed GLEW_GET_FUN(__glewEndQueryIndexed) -#define glGetQueryIndexediv GLEW_GET_FUN(__glewGetQueryIndexediv) - -#define GLEW_ARB_transform_feedback3 GLEW_GET_VAR(__GLEW_ARB_transform_feedback3) - -#endif /* GL_ARB_transform_feedback3 */ - -/* ------------------ GL_ARB_transform_feedback_instanced ------------------ */ - -#ifndef GL_ARB_transform_feedback_instanced -#define GL_ARB_transform_feedback_instanced 1 - -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKINSTANCEDPROC) (GLenum mode, GLuint id, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKSTREAMINSTANCEDPROC) (GLenum mode, GLuint id, GLuint stream, GLsizei primcount); - -#define glDrawTransformFeedbackInstanced GLEW_GET_FUN(__glewDrawTransformFeedbackInstanced) -#define glDrawTransformFeedbackStreamInstanced GLEW_GET_FUN(__glewDrawTransformFeedbackStreamInstanced) - -#define GLEW_ARB_transform_feedback_instanced GLEW_GET_VAR(__GLEW_ARB_transform_feedback_instanced) - -#endif /* GL_ARB_transform_feedback_instanced */ - -/* ------------------------ GL_ARB_transpose_matrix ------------------------ */ - -#ifndef GL_ARB_transpose_matrix -#define GL_ARB_transpose_matrix 1 - -#define GL_TRANSPOSE_MODELVIEW_MATRIX_ARB 0x84E3 -#define GL_TRANSPOSE_PROJECTION_MATRIX_ARB 0x84E4 -#define GL_TRANSPOSE_TEXTURE_MATRIX_ARB 0x84E5 -#define GL_TRANSPOSE_COLOR_MATRIX_ARB 0x84E6 - -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXDARBPROC) (GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLLOADTRANSPOSEMATRIXFARBPROC) (GLfloat m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXDARBPROC) (GLdouble m[16]); -typedef void (GLAPIENTRY * PFNGLMULTTRANSPOSEMATRIXFARBPROC) (GLfloat m[16]); - -#define glLoadTransposeMatrixdARB GLEW_GET_FUN(__glewLoadTransposeMatrixdARB) -#define glLoadTransposeMatrixfARB GLEW_GET_FUN(__glewLoadTransposeMatrixfARB) -#define glMultTransposeMatrixdARB GLEW_GET_FUN(__glewMultTransposeMatrixdARB) -#define glMultTransposeMatrixfARB GLEW_GET_FUN(__glewMultTransposeMatrixfARB) - -#define GLEW_ARB_transpose_matrix GLEW_GET_VAR(__GLEW_ARB_transpose_matrix) - -#endif /* GL_ARB_transpose_matrix */ - -/* ---------------------- GL_ARB_uniform_buffer_object --------------------- */ - -#ifndef GL_ARB_uniform_buffer_object -#define GL_ARB_uniform_buffer_object 1 - -#define GL_UNIFORM_BUFFER 0x8A11 -#define GL_UNIFORM_BUFFER_BINDING 0x8A28 -#define GL_UNIFORM_BUFFER_START 0x8A29 -#define GL_UNIFORM_BUFFER_SIZE 0x8A2A -#define GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B -#define GL_MAX_GEOMETRY_UNIFORM_BLOCKS 0x8A2C -#define GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D -#define GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E -#define GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F -#define GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30 -#define GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31 -#define GL_MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS 0x8A32 -#define GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33 -#define GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34 -#define GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35 -#define GL_ACTIVE_UNIFORM_BLOCKS 0x8A36 -#define GL_UNIFORM_TYPE 0x8A37 -#define GL_UNIFORM_SIZE 0x8A38 -#define GL_UNIFORM_NAME_LENGTH 0x8A39 -#define GL_UNIFORM_BLOCK_INDEX 0x8A3A -#define GL_UNIFORM_OFFSET 0x8A3B -#define GL_UNIFORM_ARRAY_STRIDE 0x8A3C -#define GL_UNIFORM_MATRIX_STRIDE 0x8A3D -#define GL_UNIFORM_IS_ROW_MAJOR 0x8A3E -#define GL_UNIFORM_BLOCK_BINDING 0x8A3F -#define GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40 -#define GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41 -#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42 -#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_GEOMETRY_SHADER 0x8A45 -#define GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46 -#define GL_INVALID_INDEX 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASEPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGEPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC) (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei* length, GLchar* uniformBlockName); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMBLOCKIVPROC) (GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMNAMEPROC) (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei* length, GLchar* uniformName); -typedef void (GLAPIENTRY * PFNGLGETACTIVEUNIFORMSIVPROC) (GLuint program, GLsizei uniformCount, const GLuint* uniformIndices, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETINTEGERI_VPROC) (GLenum target, GLuint index, GLint* data); -typedef GLuint (GLAPIENTRY * PFNGLGETUNIFORMBLOCKINDEXPROC) (GLuint program, const GLchar* uniformBlockName); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMINDICESPROC) (GLuint program, GLsizei uniformCount, const GLchar** uniformNames, GLuint* uniformIndices); -typedef void (GLAPIENTRY * PFNGLUNIFORMBLOCKBINDINGPROC) (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); - -#define glBindBufferBase GLEW_GET_FUN(__glewBindBufferBase) -#define glBindBufferRange GLEW_GET_FUN(__glewBindBufferRange) -#define glGetActiveUniformBlockName GLEW_GET_FUN(__glewGetActiveUniformBlockName) -#define glGetActiveUniformBlockiv GLEW_GET_FUN(__glewGetActiveUniformBlockiv) -#define glGetActiveUniformName GLEW_GET_FUN(__glewGetActiveUniformName) -#define glGetActiveUniformsiv GLEW_GET_FUN(__glewGetActiveUniformsiv) -#define glGetIntegeri_v GLEW_GET_FUN(__glewGetIntegeri_v) -#define glGetUniformBlockIndex GLEW_GET_FUN(__glewGetUniformBlockIndex) -#define glGetUniformIndices GLEW_GET_FUN(__glewGetUniformIndices) -#define glUniformBlockBinding GLEW_GET_FUN(__glewUniformBlockBinding) - -#define GLEW_ARB_uniform_buffer_object GLEW_GET_VAR(__GLEW_ARB_uniform_buffer_object) - -#endif /* GL_ARB_uniform_buffer_object */ - -/* ------------------------ GL_ARB_vertex_array_bgra ----------------------- */ - -#ifndef GL_ARB_vertex_array_bgra -#define GL_ARB_vertex_array_bgra 1 - -#define GL_BGRA 0x80E1 - -#define GLEW_ARB_vertex_array_bgra GLEW_GET_VAR(__GLEW_ARB_vertex_array_bgra) - -#endif /* GL_ARB_vertex_array_bgra */ - -/* ----------------------- GL_ARB_vertex_array_object ---------------------- */ - -#ifndef GL_ARB_vertex_array_object -#define GL_ARB_vertex_array_object 1 - -#define GL_VERTEX_ARRAY_BINDING 0x85B5 - -typedef void (GLAPIENTRY * PFNGLBINDVERTEXARRAYPROC) (GLuint array); -typedef void (GLAPIENTRY * PFNGLDELETEVERTEXARRAYSPROC) (GLsizei n, const GLuint* arrays); -typedef void (GLAPIENTRY * PFNGLGENVERTEXARRAYSPROC) (GLsizei n, GLuint* arrays); -typedef GLboolean (GLAPIENTRY * PFNGLISVERTEXARRAYPROC) (GLuint array); - -#define glBindVertexArray GLEW_GET_FUN(__glewBindVertexArray) -#define glDeleteVertexArrays GLEW_GET_FUN(__glewDeleteVertexArrays) -#define glGenVertexArrays GLEW_GET_FUN(__glewGenVertexArrays) -#define glIsVertexArray GLEW_GET_FUN(__glewIsVertexArray) - -#define GLEW_ARB_vertex_array_object GLEW_GET_VAR(__GLEW_ARB_vertex_array_object) - -#endif /* GL_ARB_vertex_array_object */ - -/* ----------------------- GL_ARB_vertex_attrib_64bit ---------------------- */ - -#ifndef GL_ARB_vertex_attrib_64bit -#define GL_ARB_vertex_attrib_64bit 1 - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLDVPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLPOINTERPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void* pointer); - -#define glGetVertexAttribLdv GLEW_GET_FUN(__glewGetVertexAttribLdv) -#define glVertexAttribL1d GLEW_GET_FUN(__glewVertexAttribL1d) -#define glVertexAttribL1dv GLEW_GET_FUN(__glewVertexAttribL1dv) -#define glVertexAttribL2d GLEW_GET_FUN(__glewVertexAttribL2d) -#define glVertexAttribL2dv GLEW_GET_FUN(__glewVertexAttribL2dv) -#define glVertexAttribL3d GLEW_GET_FUN(__glewVertexAttribL3d) -#define glVertexAttribL3dv GLEW_GET_FUN(__glewVertexAttribL3dv) -#define glVertexAttribL4d GLEW_GET_FUN(__glewVertexAttribL4d) -#define glVertexAttribL4dv GLEW_GET_FUN(__glewVertexAttribL4dv) -#define glVertexAttribLPointer GLEW_GET_FUN(__glewVertexAttribLPointer) - -#define GLEW_ARB_vertex_attrib_64bit GLEW_GET_VAR(__GLEW_ARB_vertex_attrib_64bit) - -#endif /* GL_ARB_vertex_attrib_64bit */ - -/* ---------------------- GL_ARB_vertex_attrib_binding --------------------- */ - -#ifndef GL_ARB_vertex_attrib_binding -#define GL_ARB_vertex_attrib_binding 1 - -#define GL_VERTEX_ATTRIB_BINDING 0x82D4 -#define GL_VERTEX_ATTRIB_RELATIVE_OFFSET 0x82D5 -#define GL_VERTEX_BINDING_DIVISOR 0x82D6 -#define GL_VERTEX_BINDING_OFFSET 0x82D7 -#define GL_VERTEX_BINDING_STRIDE 0x82D8 -#define GL_MAX_VERTEX_ATTRIB_RELATIVE_OFFSET 0x82D9 -#define GL_MAX_VERTEX_ATTRIB_BINDINGS 0x82DA - -typedef void (GLAPIENTRY * PFNGLBINDVERTEXBUFFERPROC) (GLuint bindingindex, GLuint buffer, GLintptr offset, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBBINDINGPROC) (GLuint attribindex, GLuint bindingindex); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBFORMATPROC) (GLuint attribindex, GLint size, GLenum type, GLboolean normalized, GLuint relativeoffset); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIFORMATPROC) (GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLFORMATPROC) (GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); -typedef void (GLAPIENTRY * PFNGLVERTEXBINDINGDIVISORPROC) (GLuint bindingindex, GLuint divisor); - -#define glBindVertexBuffer GLEW_GET_FUN(__glewBindVertexBuffer) -#define glVertexAttribBinding GLEW_GET_FUN(__glewVertexAttribBinding) -#define glVertexAttribFormat GLEW_GET_FUN(__glewVertexAttribFormat) -#define glVertexAttribIFormat GLEW_GET_FUN(__glewVertexAttribIFormat) -#define glVertexAttribLFormat GLEW_GET_FUN(__glewVertexAttribLFormat) -#define glVertexBindingDivisor GLEW_GET_FUN(__glewVertexBindingDivisor) - -#define GLEW_ARB_vertex_attrib_binding GLEW_GET_VAR(__GLEW_ARB_vertex_attrib_binding) - -#endif /* GL_ARB_vertex_attrib_binding */ - -/* -------------------------- GL_ARB_vertex_blend -------------------------- */ - -#ifndef GL_ARB_vertex_blend -#define GL_ARB_vertex_blend 1 - -#define GL_MODELVIEW0_ARB 0x1700 -#define GL_MODELVIEW1_ARB 0x850A -#define GL_MAX_VERTEX_UNITS_ARB 0x86A4 -#define GL_ACTIVE_VERTEX_UNITS_ARB 0x86A5 -#define GL_WEIGHT_SUM_UNITY_ARB 0x86A6 -#define GL_VERTEX_BLEND_ARB 0x86A7 -#define GL_CURRENT_WEIGHT_ARB 0x86A8 -#define GL_WEIGHT_ARRAY_TYPE_ARB 0x86A9 -#define GL_WEIGHT_ARRAY_STRIDE_ARB 0x86AA -#define GL_WEIGHT_ARRAY_SIZE_ARB 0x86AB -#define GL_WEIGHT_ARRAY_POINTER_ARB 0x86AC -#define GL_WEIGHT_ARRAY_ARB 0x86AD -#define GL_MODELVIEW2_ARB 0x8722 -#define GL_MODELVIEW3_ARB 0x8723 -#define GL_MODELVIEW4_ARB 0x8724 -#define GL_MODELVIEW5_ARB 0x8725 -#define GL_MODELVIEW6_ARB 0x8726 -#define GL_MODELVIEW7_ARB 0x8727 -#define GL_MODELVIEW8_ARB 0x8728 -#define GL_MODELVIEW9_ARB 0x8729 -#define GL_MODELVIEW10_ARB 0x872A -#define GL_MODELVIEW11_ARB 0x872B -#define GL_MODELVIEW12_ARB 0x872C -#define GL_MODELVIEW13_ARB 0x872D -#define GL_MODELVIEW14_ARB 0x872E -#define GL_MODELVIEW15_ARB 0x872F -#define GL_MODELVIEW16_ARB 0x8730 -#define GL_MODELVIEW17_ARB 0x8731 -#define GL_MODELVIEW18_ARB 0x8732 -#define GL_MODELVIEW19_ARB 0x8733 -#define GL_MODELVIEW20_ARB 0x8734 -#define GL_MODELVIEW21_ARB 0x8735 -#define GL_MODELVIEW22_ARB 0x8736 -#define GL_MODELVIEW23_ARB 0x8737 -#define GL_MODELVIEW24_ARB 0x8738 -#define GL_MODELVIEW25_ARB 0x8739 -#define GL_MODELVIEW26_ARB 0x873A -#define GL_MODELVIEW27_ARB 0x873B -#define GL_MODELVIEW28_ARB 0x873C -#define GL_MODELVIEW29_ARB 0x873D -#define GL_MODELVIEW30_ARB 0x873E -#define GL_MODELVIEW31_ARB 0x873F - -typedef void (GLAPIENTRY * PFNGLVERTEXBLENDARBPROC) (GLint count); -typedef void (GLAPIENTRY * PFNGLWEIGHTPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLWEIGHTBVARBPROC) (GLint size, GLbyte *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTDVARBPROC) (GLint size, GLdouble *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTFVARBPROC) (GLint size, GLfloat *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTIVARBPROC) (GLint size, GLint *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTSVARBPROC) (GLint size, GLshort *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTUBVARBPROC) (GLint size, GLubyte *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTUIVARBPROC) (GLint size, GLuint *weights); -typedef void (GLAPIENTRY * PFNGLWEIGHTUSVARBPROC) (GLint size, GLushort *weights); - -#define glVertexBlendARB GLEW_GET_FUN(__glewVertexBlendARB) -#define glWeightPointerARB GLEW_GET_FUN(__glewWeightPointerARB) -#define glWeightbvARB GLEW_GET_FUN(__glewWeightbvARB) -#define glWeightdvARB GLEW_GET_FUN(__glewWeightdvARB) -#define glWeightfvARB GLEW_GET_FUN(__glewWeightfvARB) -#define glWeightivARB GLEW_GET_FUN(__glewWeightivARB) -#define glWeightsvARB GLEW_GET_FUN(__glewWeightsvARB) -#define glWeightubvARB GLEW_GET_FUN(__glewWeightubvARB) -#define glWeightuivARB GLEW_GET_FUN(__glewWeightuivARB) -#define glWeightusvARB GLEW_GET_FUN(__glewWeightusvARB) - -#define GLEW_ARB_vertex_blend GLEW_GET_VAR(__GLEW_ARB_vertex_blend) - -#endif /* GL_ARB_vertex_blend */ - -/* ---------------------- GL_ARB_vertex_buffer_object ---------------------- */ - -#ifndef GL_ARB_vertex_buffer_object -#define GL_ARB_vertex_buffer_object 1 - -#define GL_BUFFER_SIZE_ARB 0x8764 -#define GL_BUFFER_USAGE_ARB 0x8765 -#define GL_ARRAY_BUFFER_ARB 0x8892 -#define GL_ELEMENT_ARRAY_BUFFER_ARB 0x8893 -#define GL_ARRAY_BUFFER_BINDING_ARB 0x8894 -#define GL_ELEMENT_ARRAY_BUFFER_BINDING_ARB 0x8895 -#define GL_VERTEX_ARRAY_BUFFER_BINDING_ARB 0x8896 -#define GL_NORMAL_ARRAY_BUFFER_BINDING_ARB 0x8897 -#define GL_COLOR_ARRAY_BUFFER_BINDING_ARB 0x8898 -#define GL_INDEX_ARRAY_BUFFER_BINDING_ARB 0x8899 -#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING_ARB 0x889A -#define GL_EDGE_FLAG_ARRAY_BUFFER_BINDING_ARB 0x889B -#define GL_SECONDARY_COLOR_ARRAY_BUFFER_BINDING_ARB 0x889C -#define GL_FOG_COORDINATE_ARRAY_BUFFER_BINDING_ARB 0x889D -#define GL_WEIGHT_ARRAY_BUFFER_BINDING_ARB 0x889E -#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING_ARB 0x889F -#define GL_READ_ONLY_ARB 0x88B8 -#define GL_WRITE_ONLY_ARB 0x88B9 -#define GL_READ_WRITE_ARB 0x88BA -#define GL_BUFFER_ACCESS_ARB 0x88BB -#define GL_BUFFER_MAPPED_ARB 0x88BC -#define GL_BUFFER_MAP_POINTER_ARB 0x88BD -#define GL_STREAM_DRAW_ARB 0x88E0 -#define GL_STREAM_READ_ARB 0x88E1 -#define GL_STREAM_COPY_ARB 0x88E2 -#define GL_STATIC_DRAW_ARB 0x88E4 -#define GL_STATIC_READ_ARB 0x88E5 -#define GL_STATIC_COPY_ARB 0x88E6 -#define GL_DYNAMIC_DRAW_ARB 0x88E8 -#define GL_DYNAMIC_READ_ARB 0x88E9 -#define GL_DYNAMIC_COPY_ARB 0x88EA - -typedef ptrdiff_t GLintptrARB; -typedef ptrdiff_t GLsizeiptrARB; - -typedef void (GLAPIENTRY * PFNGLBINDBUFFERARBPROC) (GLenum target, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBUFFERDATAARBPROC) (GLenum target, GLsizeiptrARB size, const GLvoid *data, GLenum usage); -typedef void (GLAPIENTRY * PFNGLBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLDELETEBUFFERSARBPROC) (GLsizei n, const GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLGENBUFFERSARBPROC) (GLsizei n, GLuint* buffers); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERIVARBPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERPOINTERVARBPROC) (GLenum target, GLenum pname, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, GLvoid *data); -typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERARBPROC) (GLuint buffer); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPBUFFERARBPROC) (GLenum target, GLenum access); -typedef GLboolean (GLAPIENTRY * PFNGLUNMAPBUFFERARBPROC) (GLenum target); - -#define glBindBufferARB GLEW_GET_FUN(__glewBindBufferARB) -#define glBufferDataARB GLEW_GET_FUN(__glewBufferDataARB) -#define glBufferSubDataARB GLEW_GET_FUN(__glewBufferSubDataARB) -#define glDeleteBuffersARB GLEW_GET_FUN(__glewDeleteBuffersARB) -#define glGenBuffersARB GLEW_GET_FUN(__glewGenBuffersARB) -#define glGetBufferParameterivARB GLEW_GET_FUN(__glewGetBufferParameterivARB) -#define glGetBufferPointervARB GLEW_GET_FUN(__glewGetBufferPointervARB) -#define glGetBufferSubDataARB GLEW_GET_FUN(__glewGetBufferSubDataARB) -#define glIsBufferARB GLEW_GET_FUN(__glewIsBufferARB) -#define glMapBufferARB GLEW_GET_FUN(__glewMapBufferARB) -#define glUnmapBufferARB GLEW_GET_FUN(__glewUnmapBufferARB) - -#define GLEW_ARB_vertex_buffer_object GLEW_GET_VAR(__GLEW_ARB_vertex_buffer_object) - -#endif /* GL_ARB_vertex_buffer_object */ - -/* ------------------------- GL_ARB_vertex_program ------------------------- */ - -#ifndef GL_ARB_vertex_program -#define GL_ARB_vertex_program 1 - -#define GL_COLOR_SUM_ARB 0x8458 -#define GL_VERTEX_PROGRAM_ARB 0x8620 -#define GL_VERTEX_ATTRIB_ARRAY_ENABLED_ARB 0x8622 -#define GL_VERTEX_ATTRIB_ARRAY_SIZE_ARB 0x8623 -#define GL_VERTEX_ATTRIB_ARRAY_STRIDE_ARB 0x8624 -#define GL_VERTEX_ATTRIB_ARRAY_TYPE_ARB 0x8625 -#define GL_CURRENT_VERTEX_ATTRIB_ARB 0x8626 -#define GL_PROGRAM_LENGTH_ARB 0x8627 -#define GL_PROGRAM_STRING_ARB 0x8628 -#define GL_MAX_PROGRAM_MATRIX_STACK_DEPTH_ARB 0x862E -#define GL_MAX_PROGRAM_MATRICES_ARB 0x862F -#define GL_CURRENT_MATRIX_STACK_DEPTH_ARB 0x8640 -#define GL_CURRENT_MATRIX_ARB 0x8641 -#define GL_VERTEX_PROGRAM_POINT_SIZE_ARB 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE_ARB 0x8643 -#define GL_VERTEX_ATTRIB_ARRAY_POINTER_ARB 0x8645 -#define GL_PROGRAM_ERROR_POSITION_ARB 0x864B -#define GL_PROGRAM_BINDING_ARB 0x8677 -#define GL_MAX_VERTEX_ATTRIBS_ARB 0x8869 -#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED_ARB 0x886A -#define GL_PROGRAM_ERROR_STRING_ARB 0x8874 -#define GL_PROGRAM_FORMAT_ASCII_ARB 0x8875 -#define GL_PROGRAM_FORMAT_ARB 0x8876 -#define GL_PROGRAM_INSTRUCTIONS_ARB 0x88A0 -#define GL_MAX_PROGRAM_INSTRUCTIONS_ARB 0x88A1 -#define GL_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A2 -#define GL_MAX_PROGRAM_NATIVE_INSTRUCTIONS_ARB 0x88A3 -#define GL_PROGRAM_TEMPORARIES_ARB 0x88A4 -#define GL_MAX_PROGRAM_TEMPORARIES_ARB 0x88A5 -#define GL_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A6 -#define GL_MAX_PROGRAM_NATIVE_TEMPORARIES_ARB 0x88A7 -#define GL_PROGRAM_PARAMETERS_ARB 0x88A8 -#define GL_MAX_PROGRAM_PARAMETERS_ARB 0x88A9 -#define GL_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AA -#define GL_MAX_PROGRAM_NATIVE_PARAMETERS_ARB 0x88AB -#define GL_PROGRAM_ATTRIBS_ARB 0x88AC -#define GL_MAX_PROGRAM_ATTRIBS_ARB 0x88AD -#define GL_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AE -#define GL_MAX_PROGRAM_NATIVE_ATTRIBS_ARB 0x88AF -#define GL_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B0 -#define GL_MAX_PROGRAM_ADDRESS_REGISTERS_ARB 0x88B1 -#define GL_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B2 -#define GL_MAX_PROGRAM_NATIVE_ADDRESS_REGISTERS_ARB 0x88B3 -#define GL_MAX_PROGRAM_LOCAL_PARAMETERS_ARB 0x88B4 -#define GL_MAX_PROGRAM_ENV_PARAMETERS_ARB 0x88B5 -#define GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB 0x88B6 -#define GL_TRANSPOSE_CURRENT_MATRIX_ARB 0x88B7 -#define GL_MATRIX0_ARB 0x88C0 -#define GL_MATRIX1_ARB 0x88C1 -#define GL_MATRIX2_ARB 0x88C2 -#define GL_MATRIX3_ARB 0x88C3 -#define GL_MATRIX4_ARB 0x88C4 -#define GL_MATRIX5_ARB 0x88C5 -#define GL_MATRIX6_ARB 0x88C6 -#define GL_MATRIX7_ARB 0x88C7 -#define GL_MATRIX8_ARB 0x88C8 -#define GL_MATRIX9_ARB 0x88C9 -#define GL_MATRIX10_ARB 0x88CA -#define GL_MATRIX11_ARB 0x88CB -#define GL_MATRIX12_ARB 0x88CC -#define GL_MATRIX13_ARB 0x88CD -#define GL_MATRIX14_ARB 0x88CE -#define GL_MATRIX15_ARB 0x88CF -#define GL_MATRIX16_ARB 0x88D0 -#define GL_MATRIX17_ARB 0x88D1 -#define GL_MATRIX18_ARB 0x88D2 -#define GL_MATRIX19_ARB 0x88D3 -#define GL_MATRIX20_ARB 0x88D4 -#define GL_MATRIX21_ARB 0x88D5 -#define GL_MATRIX22_ARB 0x88D6 -#define GL_MATRIX23_ARB 0x88D7 -#define GL_MATRIX24_ARB 0x88D8 -#define GL_MATRIX25_ARB 0x88D9 -#define GL_MATRIX26_ARB 0x88DA -#define GL_MATRIX27_ARB 0x88DB -#define GL_MATRIX28_ARB 0x88DC -#define GL_MATRIX29_ARB 0x88DD -#define GL_MATRIX30_ARB 0x88DE -#define GL_MATRIX31_ARB 0x88DF - -typedef void (GLAPIENTRY * PFNGLBINDPROGRAMARBPROC) (GLenum target, GLuint program); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMSARBPROC) (GLsizei n, const GLuint* programs); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); -typedef void (GLAPIENTRY * PFNGLGENPROGRAMSARBPROC) (GLsizei n, GLuint* programs); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMENVPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMENVPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTRINGARBPROC) (GLenum target, GLenum pname, GLvoid *string); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVARBPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVARBPROC) (GLuint index, GLenum pname, GLvoid** pointer); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVARBPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVARBPROC) (GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVARBPROC) (GLuint index, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMARBPROC) (GLuint program); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMSTRINGARBPROC) (GLenum target, GLenum format, GLsizei len, const GLvoid *string); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DARBPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FARBPROC) (GLuint index, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SARBPROC) (GLuint index, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DARBPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FARBPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SARBPROC) (GLuint index, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NBVARBPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NIVARBPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NSVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBARBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUBVARBPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUIVARBPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4NUSVARBPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4BVARBPROC) (GLuint index, const GLbyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVARBPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVARBPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4IVARBPROC) (GLuint index, const GLint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVARBPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVARBPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UIVARBPROC) (GLuint index, const GLuint* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4USVARBPROC) (GLuint index, const GLushort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERARBPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid *pointer); - -#define glBindProgramARB GLEW_GET_FUN(__glewBindProgramARB) -#define glDeleteProgramsARB GLEW_GET_FUN(__glewDeleteProgramsARB) -#define glDisableVertexAttribArrayARB GLEW_GET_FUN(__glewDisableVertexAttribArrayARB) -#define glEnableVertexAttribArrayARB GLEW_GET_FUN(__glewEnableVertexAttribArrayARB) -#define glGenProgramsARB GLEW_GET_FUN(__glewGenProgramsARB) -#define glGetProgramEnvParameterdvARB GLEW_GET_FUN(__glewGetProgramEnvParameterdvARB) -#define glGetProgramEnvParameterfvARB GLEW_GET_FUN(__glewGetProgramEnvParameterfvARB) -#define glGetProgramLocalParameterdvARB GLEW_GET_FUN(__glewGetProgramLocalParameterdvARB) -#define glGetProgramLocalParameterfvARB GLEW_GET_FUN(__glewGetProgramLocalParameterfvARB) -#define glGetProgramStringARB GLEW_GET_FUN(__glewGetProgramStringARB) -#define glGetProgramivARB GLEW_GET_FUN(__glewGetProgramivARB) -#define glGetVertexAttribPointervARB GLEW_GET_FUN(__glewGetVertexAttribPointervARB) -#define glGetVertexAttribdvARB GLEW_GET_FUN(__glewGetVertexAttribdvARB) -#define glGetVertexAttribfvARB GLEW_GET_FUN(__glewGetVertexAttribfvARB) -#define glGetVertexAttribivARB GLEW_GET_FUN(__glewGetVertexAttribivARB) -#define glIsProgramARB GLEW_GET_FUN(__glewIsProgramARB) -#define glProgramEnvParameter4dARB GLEW_GET_FUN(__glewProgramEnvParameter4dARB) -#define glProgramEnvParameter4dvARB GLEW_GET_FUN(__glewProgramEnvParameter4dvARB) -#define glProgramEnvParameter4fARB GLEW_GET_FUN(__glewProgramEnvParameter4fARB) -#define glProgramEnvParameter4fvARB GLEW_GET_FUN(__glewProgramEnvParameter4fvARB) -#define glProgramLocalParameter4dARB GLEW_GET_FUN(__glewProgramLocalParameter4dARB) -#define glProgramLocalParameter4dvARB GLEW_GET_FUN(__glewProgramLocalParameter4dvARB) -#define glProgramLocalParameter4fARB GLEW_GET_FUN(__glewProgramLocalParameter4fARB) -#define glProgramLocalParameter4fvARB GLEW_GET_FUN(__glewProgramLocalParameter4fvARB) -#define glProgramStringARB GLEW_GET_FUN(__glewProgramStringARB) -#define glVertexAttrib1dARB GLEW_GET_FUN(__glewVertexAttrib1dARB) -#define glVertexAttrib1dvARB GLEW_GET_FUN(__glewVertexAttrib1dvARB) -#define glVertexAttrib1fARB GLEW_GET_FUN(__glewVertexAttrib1fARB) -#define glVertexAttrib1fvARB GLEW_GET_FUN(__glewVertexAttrib1fvARB) -#define glVertexAttrib1sARB GLEW_GET_FUN(__glewVertexAttrib1sARB) -#define glVertexAttrib1svARB GLEW_GET_FUN(__glewVertexAttrib1svARB) -#define glVertexAttrib2dARB GLEW_GET_FUN(__glewVertexAttrib2dARB) -#define glVertexAttrib2dvARB GLEW_GET_FUN(__glewVertexAttrib2dvARB) -#define glVertexAttrib2fARB GLEW_GET_FUN(__glewVertexAttrib2fARB) -#define glVertexAttrib2fvARB GLEW_GET_FUN(__glewVertexAttrib2fvARB) -#define glVertexAttrib2sARB GLEW_GET_FUN(__glewVertexAttrib2sARB) -#define glVertexAttrib2svARB GLEW_GET_FUN(__glewVertexAttrib2svARB) -#define glVertexAttrib3dARB GLEW_GET_FUN(__glewVertexAttrib3dARB) -#define glVertexAttrib3dvARB GLEW_GET_FUN(__glewVertexAttrib3dvARB) -#define glVertexAttrib3fARB GLEW_GET_FUN(__glewVertexAttrib3fARB) -#define glVertexAttrib3fvARB GLEW_GET_FUN(__glewVertexAttrib3fvARB) -#define glVertexAttrib3sARB GLEW_GET_FUN(__glewVertexAttrib3sARB) -#define glVertexAttrib3svARB GLEW_GET_FUN(__glewVertexAttrib3svARB) -#define glVertexAttrib4NbvARB GLEW_GET_FUN(__glewVertexAttrib4NbvARB) -#define glVertexAttrib4NivARB GLEW_GET_FUN(__glewVertexAttrib4NivARB) -#define glVertexAttrib4NsvARB GLEW_GET_FUN(__glewVertexAttrib4NsvARB) -#define glVertexAttrib4NubARB GLEW_GET_FUN(__glewVertexAttrib4NubARB) -#define glVertexAttrib4NubvARB GLEW_GET_FUN(__glewVertexAttrib4NubvARB) -#define glVertexAttrib4NuivARB GLEW_GET_FUN(__glewVertexAttrib4NuivARB) -#define glVertexAttrib4NusvARB GLEW_GET_FUN(__glewVertexAttrib4NusvARB) -#define glVertexAttrib4bvARB GLEW_GET_FUN(__glewVertexAttrib4bvARB) -#define glVertexAttrib4dARB GLEW_GET_FUN(__glewVertexAttrib4dARB) -#define glVertexAttrib4dvARB GLEW_GET_FUN(__glewVertexAttrib4dvARB) -#define glVertexAttrib4fARB GLEW_GET_FUN(__glewVertexAttrib4fARB) -#define glVertexAttrib4fvARB GLEW_GET_FUN(__glewVertexAttrib4fvARB) -#define glVertexAttrib4ivARB GLEW_GET_FUN(__glewVertexAttrib4ivARB) -#define glVertexAttrib4sARB GLEW_GET_FUN(__glewVertexAttrib4sARB) -#define glVertexAttrib4svARB GLEW_GET_FUN(__glewVertexAttrib4svARB) -#define glVertexAttrib4ubvARB GLEW_GET_FUN(__glewVertexAttrib4ubvARB) -#define glVertexAttrib4uivARB GLEW_GET_FUN(__glewVertexAttrib4uivARB) -#define glVertexAttrib4usvARB GLEW_GET_FUN(__glewVertexAttrib4usvARB) -#define glVertexAttribPointerARB GLEW_GET_FUN(__glewVertexAttribPointerARB) - -#define GLEW_ARB_vertex_program GLEW_GET_VAR(__GLEW_ARB_vertex_program) - -#endif /* GL_ARB_vertex_program */ - -/* -------------------------- GL_ARB_vertex_shader ------------------------- */ - -#ifndef GL_ARB_vertex_shader -#define GL_ARB_vertex_shader 1 - -#define GL_VERTEX_SHADER_ARB 0x8B31 -#define GL_MAX_VERTEX_UNIFORM_COMPONENTS_ARB 0x8B4A -#define GL_MAX_VARYING_FLOATS_ARB 0x8B4B -#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C -#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS_ARB 0x8B4D -#define GL_OBJECT_ACTIVE_ATTRIBUTES_ARB 0x8B89 -#define GL_OBJECT_ACTIVE_ATTRIBUTE_MAX_LENGTH_ARB 0x8B8A - -typedef void (GLAPIENTRY * PFNGLBINDATTRIBLOCATIONARBPROC) (GLhandleARB programObj, GLuint index, const GLcharARB* name); -typedef void (GLAPIENTRY * PFNGLGETACTIVEATTRIBARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei* length, GLint *size, GLenum *type, GLcharARB *name); -typedef GLint (GLAPIENTRY * PFNGLGETATTRIBLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB* name); - -#define glBindAttribLocationARB GLEW_GET_FUN(__glewBindAttribLocationARB) -#define glGetActiveAttribARB GLEW_GET_FUN(__glewGetActiveAttribARB) -#define glGetAttribLocationARB GLEW_GET_FUN(__glewGetAttribLocationARB) - -#define GLEW_ARB_vertex_shader GLEW_GET_VAR(__GLEW_ARB_vertex_shader) - -#endif /* GL_ARB_vertex_shader */ - -/* ------------------- GL_ARB_vertex_type_10f_11f_11f_rev ------------------ */ - -#ifndef GL_ARB_vertex_type_10f_11f_11f_rev -#define GL_ARB_vertex_type_10f_11f_11f_rev 1 - -#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B - -#define GLEW_ARB_vertex_type_10f_11f_11f_rev GLEW_GET_VAR(__GLEW_ARB_vertex_type_10f_11f_11f_rev) - -#endif /* GL_ARB_vertex_type_10f_11f_11f_rev */ - -/* ------------------- GL_ARB_vertex_type_2_10_10_10_rev ------------------- */ - -#ifndef GL_ARB_vertex_type_2_10_10_10_rev -#define GL_ARB_vertex_type_2_10_10_10_rev 1 - -#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 -#define GL_INT_2_10_10_10_REV 0x8D9F - -typedef void (GLAPIENTRY * PFNGLCOLORP3UIPROC) (GLenum type, GLuint color); -typedef void (GLAPIENTRY * PFNGLCOLORP3UIVPROC) (GLenum type, const GLuint* color); -typedef void (GLAPIENTRY * PFNGLCOLORP4UIPROC) (GLenum type, GLuint color); -typedef void (GLAPIENTRY * PFNGLCOLORP4UIVPROC) (GLenum type, const GLuint* color); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP1UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP1UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP2UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP2UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP3UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP3UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP4UIPROC) (GLenum texture, GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDP4UIVPROC) (GLenum texture, GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLNORMALP3UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLNORMALP3UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORP3UIPROC) (GLenum type, GLuint color); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORP3UIVPROC) (GLenum type, const GLuint* color); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP1UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP1UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP2UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP2UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP3UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP3UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP4UIPROC) (GLenum type, GLuint coords); -typedef void (GLAPIENTRY * PFNGLTEXCOORDP4UIVPROC) (GLenum type, const GLuint* coords); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP1UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP1UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP2UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP2UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP3UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP3UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP4UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBP4UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXP2UIPROC) (GLenum type, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXP2UIVPROC) (GLenum type, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXP3UIPROC) (GLenum type, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXP3UIVPROC) (GLenum type, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLVERTEXP4UIPROC) (GLenum type, GLuint value); -typedef void (GLAPIENTRY * PFNGLVERTEXP4UIVPROC) (GLenum type, const GLuint* value); - -#define glColorP3ui GLEW_GET_FUN(__glewColorP3ui) -#define glColorP3uiv GLEW_GET_FUN(__glewColorP3uiv) -#define glColorP4ui GLEW_GET_FUN(__glewColorP4ui) -#define glColorP4uiv GLEW_GET_FUN(__glewColorP4uiv) -#define glMultiTexCoordP1ui GLEW_GET_FUN(__glewMultiTexCoordP1ui) -#define glMultiTexCoordP1uiv GLEW_GET_FUN(__glewMultiTexCoordP1uiv) -#define glMultiTexCoordP2ui GLEW_GET_FUN(__glewMultiTexCoordP2ui) -#define glMultiTexCoordP2uiv GLEW_GET_FUN(__glewMultiTexCoordP2uiv) -#define glMultiTexCoordP3ui GLEW_GET_FUN(__glewMultiTexCoordP3ui) -#define glMultiTexCoordP3uiv GLEW_GET_FUN(__glewMultiTexCoordP3uiv) -#define glMultiTexCoordP4ui GLEW_GET_FUN(__glewMultiTexCoordP4ui) -#define glMultiTexCoordP4uiv GLEW_GET_FUN(__glewMultiTexCoordP4uiv) -#define glNormalP3ui GLEW_GET_FUN(__glewNormalP3ui) -#define glNormalP3uiv GLEW_GET_FUN(__glewNormalP3uiv) -#define glSecondaryColorP3ui GLEW_GET_FUN(__glewSecondaryColorP3ui) -#define glSecondaryColorP3uiv GLEW_GET_FUN(__glewSecondaryColorP3uiv) -#define glTexCoordP1ui GLEW_GET_FUN(__glewTexCoordP1ui) -#define glTexCoordP1uiv GLEW_GET_FUN(__glewTexCoordP1uiv) -#define glTexCoordP2ui GLEW_GET_FUN(__glewTexCoordP2ui) -#define glTexCoordP2uiv GLEW_GET_FUN(__glewTexCoordP2uiv) -#define glTexCoordP3ui GLEW_GET_FUN(__glewTexCoordP3ui) -#define glTexCoordP3uiv GLEW_GET_FUN(__glewTexCoordP3uiv) -#define glTexCoordP4ui GLEW_GET_FUN(__glewTexCoordP4ui) -#define glTexCoordP4uiv GLEW_GET_FUN(__glewTexCoordP4uiv) -#define glVertexAttribP1ui GLEW_GET_FUN(__glewVertexAttribP1ui) -#define glVertexAttribP1uiv GLEW_GET_FUN(__glewVertexAttribP1uiv) -#define glVertexAttribP2ui GLEW_GET_FUN(__glewVertexAttribP2ui) -#define glVertexAttribP2uiv GLEW_GET_FUN(__glewVertexAttribP2uiv) -#define glVertexAttribP3ui GLEW_GET_FUN(__glewVertexAttribP3ui) -#define glVertexAttribP3uiv GLEW_GET_FUN(__glewVertexAttribP3uiv) -#define glVertexAttribP4ui GLEW_GET_FUN(__glewVertexAttribP4ui) -#define glVertexAttribP4uiv GLEW_GET_FUN(__glewVertexAttribP4uiv) -#define glVertexP2ui GLEW_GET_FUN(__glewVertexP2ui) -#define glVertexP2uiv GLEW_GET_FUN(__glewVertexP2uiv) -#define glVertexP3ui GLEW_GET_FUN(__glewVertexP3ui) -#define glVertexP3uiv GLEW_GET_FUN(__glewVertexP3uiv) -#define glVertexP4ui GLEW_GET_FUN(__glewVertexP4ui) -#define glVertexP4uiv GLEW_GET_FUN(__glewVertexP4uiv) - -#define GLEW_ARB_vertex_type_2_10_10_10_rev GLEW_GET_VAR(__GLEW_ARB_vertex_type_2_10_10_10_rev) - -#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ - -/* ------------------------- GL_ARB_viewport_array ------------------------- */ - -#ifndef GL_ARB_viewport_array -#define GL_ARB_viewport_array 1 - -#define GL_DEPTH_RANGE 0x0B70 -#define GL_VIEWPORT 0x0BA2 -#define GL_SCISSOR_BOX 0x0C10 -#define GL_SCISSOR_TEST 0x0C11 -#define GL_MAX_VIEWPORTS 0x825B -#define GL_VIEWPORT_SUBPIXEL_BITS 0x825C -#define GL_VIEWPORT_BOUNDS_RANGE 0x825D -#define GL_LAYER_PROVOKING_VERTEX 0x825E -#define GL_VIEWPORT_INDEX_PROVOKING_VERTEX 0x825F -#define GL_UNDEFINED_VERTEX 0x8260 -#define GL_FIRST_VERTEX_CONVENTION 0x8E4D -#define GL_LAST_VERTEX_CONVENTION 0x8E4E -#define GL_PROVOKING_VERTEX 0x8E4F - -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEARRAYVPROC) (GLuint first, GLsizei count, const GLclampd * v); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEINDEXEDPROC) (GLuint index, GLclampd n, GLclampd f); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEI_VPROC) (GLenum target, GLuint index, GLdouble* data); -typedef void (GLAPIENTRY * PFNGLGETFLOATI_VPROC) (GLenum target, GLuint index, GLfloat* data); -typedef void (GLAPIENTRY * PFNGLSCISSORARRAYVPROC) (GLuint first, GLsizei count, const GLint * v); -typedef void (GLAPIENTRY * PFNGLSCISSORINDEXEDPROC) (GLuint index, GLint left, GLint bottom, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLSCISSORINDEXEDVPROC) (GLuint index, const GLint * v); -typedef void (GLAPIENTRY * PFNGLVIEWPORTARRAYVPROC) (GLuint first, GLsizei count, const GLfloat * v); -typedef void (GLAPIENTRY * PFNGLVIEWPORTINDEXEDFPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat w, GLfloat h); -typedef void (GLAPIENTRY * PFNGLVIEWPORTINDEXEDFVPROC) (GLuint index, const GLfloat * v); - -#define glDepthRangeArrayv GLEW_GET_FUN(__glewDepthRangeArrayv) -#define glDepthRangeIndexed GLEW_GET_FUN(__glewDepthRangeIndexed) -#define glGetDoublei_v GLEW_GET_FUN(__glewGetDoublei_v) -#define glGetFloati_v GLEW_GET_FUN(__glewGetFloati_v) -#define glScissorArrayv GLEW_GET_FUN(__glewScissorArrayv) -#define glScissorIndexed GLEW_GET_FUN(__glewScissorIndexed) -#define glScissorIndexedv GLEW_GET_FUN(__glewScissorIndexedv) -#define glViewportArrayv GLEW_GET_FUN(__glewViewportArrayv) -#define glViewportIndexedf GLEW_GET_FUN(__glewViewportIndexedf) -#define glViewportIndexedfv GLEW_GET_FUN(__glewViewportIndexedfv) - -#define GLEW_ARB_viewport_array GLEW_GET_VAR(__GLEW_ARB_viewport_array) - -#endif /* GL_ARB_viewport_array */ - -/* --------------------------- GL_ARB_window_pos --------------------------- */ - -#ifndef GL_ARB_window_pos -#define GL_ARB_window_pos 1 - -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DARBPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVARBPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FARBPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVARBPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IARBPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVARBPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SARBPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVARBPROC) (const GLshort* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DARBPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVARBPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FARBPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVARBPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IARBPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVARBPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SARBPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVARBPROC) (const GLshort* p); - -#define glWindowPos2dARB GLEW_GET_FUN(__glewWindowPos2dARB) -#define glWindowPos2dvARB GLEW_GET_FUN(__glewWindowPos2dvARB) -#define glWindowPos2fARB GLEW_GET_FUN(__glewWindowPos2fARB) -#define glWindowPos2fvARB GLEW_GET_FUN(__glewWindowPos2fvARB) -#define glWindowPos2iARB GLEW_GET_FUN(__glewWindowPos2iARB) -#define glWindowPos2ivARB GLEW_GET_FUN(__glewWindowPos2ivARB) -#define glWindowPos2sARB GLEW_GET_FUN(__glewWindowPos2sARB) -#define glWindowPos2svARB GLEW_GET_FUN(__glewWindowPos2svARB) -#define glWindowPos3dARB GLEW_GET_FUN(__glewWindowPos3dARB) -#define glWindowPos3dvARB GLEW_GET_FUN(__glewWindowPos3dvARB) -#define glWindowPos3fARB GLEW_GET_FUN(__glewWindowPos3fARB) -#define glWindowPos3fvARB GLEW_GET_FUN(__glewWindowPos3fvARB) -#define glWindowPos3iARB GLEW_GET_FUN(__glewWindowPos3iARB) -#define glWindowPos3ivARB GLEW_GET_FUN(__glewWindowPos3ivARB) -#define glWindowPos3sARB GLEW_GET_FUN(__glewWindowPos3sARB) -#define glWindowPos3svARB GLEW_GET_FUN(__glewWindowPos3svARB) - -#define GLEW_ARB_window_pos GLEW_GET_VAR(__GLEW_ARB_window_pos) - -#endif /* GL_ARB_window_pos */ - -/* ------------------------- GL_ATIX_point_sprites ------------------------- */ - -#ifndef GL_ATIX_point_sprites -#define GL_ATIX_point_sprites 1 - -#define GL_TEXTURE_POINT_MODE_ATIX 0x60B0 -#define GL_TEXTURE_POINT_ONE_COORD_ATIX 0x60B1 -#define GL_TEXTURE_POINT_SPRITE_ATIX 0x60B2 -#define GL_POINT_SPRITE_CULL_MODE_ATIX 0x60B3 -#define GL_POINT_SPRITE_CULL_CENTER_ATIX 0x60B4 -#define GL_POINT_SPRITE_CULL_CLIP_ATIX 0x60B5 - -#define GLEW_ATIX_point_sprites GLEW_GET_VAR(__GLEW_ATIX_point_sprites) - -#endif /* GL_ATIX_point_sprites */ - -/* ---------------------- GL_ATIX_texture_env_combine3 --------------------- */ - -#ifndef GL_ATIX_texture_env_combine3 -#define GL_ATIX_texture_env_combine3 1 - -#define GL_MODULATE_ADD_ATIX 0x8744 -#define GL_MODULATE_SIGNED_ADD_ATIX 0x8745 -#define GL_MODULATE_SUBTRACT_ATIX 0x8746 - -#define GLEW_ATIX_texture_env_combine3 GLEW_GET_VAR(__GLEW_ATIX_texture_env_combine3) - -#endif /* GL_ATIX_texture_env_combine3 */ - -/* ----------------------- GL_ATIX_texture_env_route ----------------------- */ - -#ifndef GL_ATIX_texture_env_route -#define GL_ATIX_texture_env_route 1 - -#define GL_SECONDARY_COLOR_ATIX 0x8747 -#define GL_TEXTURE_OUTPUT_RGB_ATIX 0x8748 -#define GL_TEXTURE_OUTPUT_ALPHA_ATIX 0x8749 - -#define GLEW_ATIX_texture_env_route GLEW_GET_VAR(__GLEW_ATIX_texture_env_route) - -#endif /* GL_ATIX_texture_env_route */ - -/* ---------------- GL_ATIX_vertex_shader_output_point_size ---------------- */ - -#ifndef GL_ATIX_vertex_shader_output_point_size -#define GL_ATIX_vertex_shader_output_point_size 1 - -#define GL_OUTPUT_POINT_SIZE_ATIX 0x610E - -#define GLEW_ATIX_vertex_shader_output_point_size GLEW_GET_VAR(__GLEW_ATIX_vertex_shader_output_point_size) - -#endif /* GL_ATIX_vertex_shader_output_point_size */ - -/* -------------------------- GL_ATI_draw_buffers -------------------------- */ - -#ifndef GL_ATI_draw_buffers -#define GL_ATI_draw_buffers 1 - -#define GL_MAX_DRAW_BUFFERS_ATI 0x8824 -#define GL_DRAW_BUFFER0_ATI 0x8825 -#define GL_DRAW_BUFFER1_ATI 0x8826 -#define GL_DRAW_BUFFER2_ATI 0x8827 -#define GL_DRAW_BUFFER3_ATI 0x8828 -#define GL_DRAW_BUFFER4_ATI 0x8829 -#define GL_DRAW_BUFFER5_ATI 0x882A -#define GL_DRAW_BUFFER6_ATI 0x882B -#define GL_DRAW_BUFFER7_ATI 0x882C -#define GL_DRAW_BUFFER8_ATI 0x882D -#define GL_DRAW_BUFFER9_ATI 0x882E -#define GL_DRAW_BUFFER10_ATI 0x882F -#define GL_DRAW_BUFFER11_ATI 0x8830 -#define GL_DRAW_BUFFER12_ATI 0x8831 -#define GL_DRAW_BUFFER13_ATI 0x8832 -#define GL_DRAW_BUFFER14_ATI 0x8833 -#define GL_DRAW_BUFFER15_ATI 0x8834 - -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERSATIPROC) (GLsizei n, const GLenum* bufs); - -#define glDrawBuffersATI GLEW_GET_FUN(__glewDrawBuffersATI) - -#define GLEW_ATI_draw_buffers GLEW_GET_VAR(__GLEW_ATI_draw_buffers) - -#endif /* GL_ATI_draw_buffers */ - -/* -------------------------- GL_ATI_element_array ------------------------- */ - -#ifndef GL_ATI_element_array -#define GL_ATI_element_array 1 - -#define GL_ELEMENT_ARRAY_ATI 0x8768 -#define GL_ELEMENT_ARRAY_TYPE_ATI 0x8769 -#define GL_ELEMENT_ARRAY_POINTER_ATI 0x876A - -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTARRAYATIPROC) (GLenum mode, GLsizei count); -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTARRAYATIPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count); -typedef void (GLAPIENTRY * PFNGLELEMENTPOINTERATIPROC) (GLenum type, const GLvoid *pointer); - -#define glDrawElementArrayATI GLEW_GET_FUN(__glewDrawElementArrayATI) -#define glDrawRangeElementArrayATI GLEW_GET_FUN(__glewDrawRangeElementArrayATI) -#define glElementPointerATI GLEW_GET_FUN(__glewElementPointerATI) - -#define GLEW_ATI_element_array GLEW_GET_VAR(__GLEW_ATI_element_array) - -#endif /* GL_ATI_element_array */ - -/* ------------------------- GL_ATI_envmap_bumpmap ------------------------- */ - -#ifndef GL_ATI_envmap_bumpmap -#define GL_ATI_envmap_bumpmap 1 - -#define GL_BUMP_ROT_MATRIX_ATI 0x8775 -#define GL_BUMP_ROT_MATRIX_SIZE_ATI 0x8776 -#define GL_BUMP_NUM_TEX_UNITS_ATI 0x8777 -#define GL_BUMP_TEX_UNITS_ATI 0x8778 -#define GL_DUDV_ATI 0x8779 -#define GL_DU8DV8_ATI 0x877A -#define GL_BUMP_ENVMAP_ATI 0x877B -#define GL_BUMP_TARGET_ATI 0x877C - -typedef void (GLAPIENTRY * PFNGLGETTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); -typedef void (GLAPIENTRY * PFNGLGETTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); -typedef void (GLAPIENTRY * PFNGLTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); -typedef void (GLAPIENTRY * PFNGLTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); - -#define glGetTexBumpParameterfvATI GLEW_GET_FUN(__glewGetTexBumpParameterfvATI) -#define glGetTexBumpParameterivATI GLEW_GET_FUN(__glewGetTexBumpParameterivATI) -#define glTexBumpParameterfvATI GLEW_GET_FUN(__glewTexBumpParameterfvATI) -#define glTexBumpParameterivATI GLEW_GET_FUN(__glewTexBumpParameterivATI) - -#define GLEW_ATI_envmap_bumpmap GLEW_GET_VAR(__GLEW_ATI_envmap_bumpmap) - -#endif /* GL_ATI_envmap_bumpmap */ - -/* ------------------------- GL_ATI_fragment_shader ------------------------ */ - -#ifndef GL_ATI_fragment_shader -#define GL_ATI_fragment_shader 1 - -#define GL_RED_BIT_ATI 0x00000001 -#define GL_2X_BIT_ATI 0x00000001 -#define GL_4X_BIT_ATI 0x00000002 -#define GL_GREEN_BIT_ATI 0x00000002 -#define GL_COMP_BIT_ATI 0x00000002 -#define GL_BLUE_BIT_ATI 0x00000004 -#define GL_8X_BIT_ATI 0x00000004 -#define GL_NEGATE_BIT_ATI 0x00000004 -#define GL_BIAS_BIT_ATI 0x00000008 -#define GL_HALF_BIT_ATI 0x00000008 -#define GL_QUARTER_BIT_ATI 0x00000010 -#define GL_EIGHTH_BIT_ATI 0x00000020 -#define GL_SATURATE_BIT_ATI 0x00000040 -#define GL_FRAGMENT_SHADER_ATI 0x8920 -#define GL_REG_0_ATI 0x8921 -#define GL_REG_1_ATI 0x8922 -#define GL_REG_2_ATI 0x8923 -#define GL_REG_3_ATI 0x8924 -#define GL_REG_4_ATI 0x8925 -#define GL_REG_5_ATI 0x8926 -#define GL_CON_0_ATI 0x8941 -#define GL_CON_1_ATI 0x8942 -#define GL_CON_2_ATI 0x8943 -#define GL_CON_3_ATI 0x8944 -#define GL_CON_4_ATI 0x8945 -#define GL_CON_5_ATI 0x8946 -#define GL_CON_6_ATI 0x8947 -#define GL_CON_7_ATI 0x8948 -#define GL_MOV_ATI 0x8961 -#define GL_ADD_ATI 0x8963 -#define GL_MUL_ATI 0x8964 -#define GL_SUB_ATI 0x8965 -#define GL_DOT3_ATI 0x8966 -#define GL_DOT4_ATI 0x8967 -#define GL_MAD_ATI 0x8968 -#define GL_LERP_ATI 0x8969 -#define GL_CND_ATI 0x896A -#define GL_CND0_ATI 0x896B -#define GL_DOT2_ADD_ATI 0x896C -#define GL_SECONDARY_INTERPOLATOR_ATI 0x896D -#define GL_NUM_FRAGMENT_REGISTERS_ATI 0x896E -#define GL_NUM_FRAGMENT_CONSTANTS_ATI 0x896F -#define GL_NUM_PASSES_ATI 0x8970 -#define GL_NUM_INSTRUCTIONS_PER_PASS_ATI 0x8971 -#define GL_NUM_INSTRUCTIONS_TOTAL_ATI 0x8972 -#define GL_NUM_INPUT_INTERPOLATOR_COMPONENTS_ATI 0x8973 -#define GL_NUM_LOOPBACK_COMPONENTS_ATI 0x8974 -#define GL_COLOR_ALPHA_PAIRING_ATI 0x8975 -#define GL_SWIZZLE_STR_ATI 0x8976 -#define GL_SWIZZLE_STQ_ATI 0x8977 -#define GL_SWIZZLE_STR_DR_ATI 0x8978 -#define GL_SWIZZLE_STQ_DQ_ATI 0x8979 -#define GL_SWIZZLE_STRQ_ATI 0x897A -#define GL_SWIZZLE_STRQ_DQ_ATI 0x897B - -typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); -typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); -typedef void (GLAPIENTRY * PFNGLALPHAFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); -typedef void (GLAPIENTRY * PFNGLBEGINFRAGMENTSHADERATIPROC) (void); -typedef void (GLAPIENTRY * PFNGLBINDFRAGMENTSHADERATIPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); -typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); -typedef void (GLAPIENTRY * PFNGLCOLORFRAGMENTOP3ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); -typedef void (GLAPIENTRY * PFNGLDELETEFRAGMENTSHADERATIPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENDFRAGMENTSHADERATIPROC) (void); -typedef GLuint (GLAPIENTRY * PFNGLGENFRAGMENTSHADERSATIPROC) (GLuint range); -typedef void (GLAPIENTRY * PFNGLPASSTEXCOORDATIPROC) (GLuint dst, GLuint coord, GLenum swizzle); -typedef void (GLAPIENTRY * PFNGLSAMPLEMAPATIPROC) (GLuint dst, GLuint interp, GLenum swizzle); -typedef void (GLAPIENTRY * PFNGLSETFRAGMENTSHADERCONSTANTATIPROC) (GLuint dst, const GLfloat* value); - -#define glAlphaFragmentOp1ATI GLEW_GET_FUN(__glewAlphaFragmentOp1ATI) -#define glAlphaFragmentOp2ATI GLEW_GET_FUN(__glewAlphaFragmentOp2ATI) -#define glAlphaFragmentOp3ATI GLEW_GET_FUN(__glewAlphaFragmentOp3ATI) -#define glBeginFragmentShaderATI GLEW_GET_FUN(__glewBeginFragmentShaderATI) -#define glBindFragmentShaderATI GLEW_GET_FUN(__glewBindFragmentShaderATI) -#define glColorFragmentOp1ATI GLEW_GET_FUN(__glewColorFragmentOp1ATI) -#define glColorFragmentOp2ATI GLEW_GET_FUN(__glewColorFragmentOp2ATI) -#define glColorFragmentOp3ATI GLEW_GET_FUN(__glewColorFragmentOp3ATI) -#define glDeleteFragmentShaderATI GLEW_GET_FUN(__glewDeleteFragmentShaderATI) -#define glEndFragmentShaderATI GLEW_GET_FUN(__glewEndFragmentShaderATI) -#define glGenFragmentShadersATI GLEW_GET_FUN(__glewGenFragmentShadersATI) -#define glPassTexCoordATI GLEW_GET_FUN(__glewPassTexCoordATI) -#define glSampleMapATI GLEW_GET_FUN(__glewSampleMapATI) -#define glSetFragmentShaderConstantATI GLEW_GET_FUN(__glewSetFragmentShaderConstantATI) - -#define GLEW_ATI_fragment_shader GLEW_GET_VAR(__GLEW_ATI_fragment_shader) - -#endif /* GL_ATI_fragment_shader */ - -/* ------------------------ GL_ATI_map_object_buffer ----------------------- */ - -#ifndef GL_ATI_map_object_buffer -#define GL_ATI_map_object_buffer 1 - -typedef GLvoid * (GLAPIENTRY * PFNGLMAPOBJECTBUFFERATIPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLUNMAPOBJECTBUFFERATIPROC) (GLuint buffer); - -#define glMapObjectBufferATI GLEW_GET_FUN(__glewMapObjectBufferATI) -#define glUnmapObjectBufferATI GLEW_GET_FUN(__glewUnmapObjectBufferATI) - -#define GLEW_ATI_map_object_buffer GLEW_GET_VAR(__GLEW_ATI_map_object_buffer) - -#endif /* GL_ATI_map_object_buffer */ - -/* ----------------------------- GL_ATI_meminfo ---------------------------- */ - -#ifndef GL_ATI_meminfo -#define GL_ATI_meminfo 1 - -#define GL_VBO_FREE_MEMORY_ATI 0x87FB -#define GL_TEXTURE_FREE_MEMORY_ATI 0x87FC -#define GL_RENDERBUFFER_FREE_MEMORY_ATI 0x87FD - -#define GLEW_ATI_meminfo GLEW_GET_VAR(__GLEW_ATI_meminfo) - -#endif /* GL_ATI_meminfo */ - -/* -------------------------- GL_ATI_pn_triangles -------------------------- */ - -#ifndef GL_ATI_pn_triangles -#define GL_ATI_pn_triangles 1 - -#define GL_PN_TRIANGLES_ATI 0x87F0 -#define GL_MAX_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F1 -#define GL_PN_TRIANGLES_POINT_MODE_ATI 0x87F2 -#define GL_PN_TRIANGLES_NORMAL_MODE_ATI 0x87F3 -#define GL_PN_TRIANGLES_TESSELATION_LEVEL_ATI 0x87F4 -#define GL_PN_TRIANGLES_POINT_MODE_LINEAR_ATI 0x87F5 -#define GL_PN_TRIANGLES_POINT_MODE_CUBIC_ATI 0x87F6 -#define GL_PN_TRIANGLES_NORMAL_MODE_LINEAR_ATI 0x87F7 -#define GL_PN_TRIANGLES_NORMAL_MODE_QUADRATIC_ATI 0x87F8 - -typedef void (GLAPIENTRY * PFNGLPNTRIANGLESFATIPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPNTRIANGLESIATIPROC) (GLenum pname, GLint param); - -#define glPNTrianglesfATI GLEW_GET_FUN(__glewPNTrianglesfATI) -#define glPNTrianglesiATI GLEW_GET_FUN(__glewPNTrianglesiATI) - -#define GLEW_ATI_pn_triangles GLEW_GET_VAR(__GLEW_ATI_pn_triangles) - -#endif /* GL_ATI_pn_triangles */ - -/* ------------------------ GL_ATI_separate_stencil ------------------------ */ - -#ifndef GL_ATI_separate_stencil -#define GL_ATI_separate_stencil 1 - -#define GL_STENCIL_BACK_FUNC_ATI 0x8800 -#define GL_STENCIL_BACK_FAIL_ATI 0x8801 -#define GL_STENCIL_BACK_PASS_DEPTH_FAIL_ATI 0x8802 -#define GL_STENCIL_BACK_PASS_DEPTH_PASS_ATI 0x8803 - -typedef void (GLAPIENTRY * PFNGLSTENCILFUNCSEPARATEATIPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILOPSEPARATEATIPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); - -#define glStencilFuncSeparateATI GLEW_GET_FUN(__glewStencilFuncSeparateATI) -#define glStencilOpSeparateATI GLEW_GET_FUN(__glewStencilOpSeparateATI) - -#define GLEW_ATI_separate_stencil GLEW_GET_VAR(__GLEW_ATI_separate_stencil) - -#endif /* GL_ATI_separate_stencil */ - -/* ----------------------- GL_ATI_shader_texture_lod ----------------------- */ - -#ifndef GL_ATI_shader_texture_lod -#define GL_ATI_shader_texture_lod 1 - -#define GLEW_ATI_shader_texture_lod GLEW_GET_VAR(__GLEW_ATI_shader_texture_lod) - -#endif /* GL_ATI_shader_texture_lod */ - -/* ---------------------- GL_ATI_text_fragment_shader ---------------------- */ - -#ifndef GL_ATI_text_fragment_shader -#define GL_ATI_text_fragment_shader 1 - -#define GL_TEXT_FRAGMENT_SHADER_ATI 0x8200 - -#define GLEW_ATI_text_fragment_shader GLEW_GET_VAR(__GLEW_ATI_text_fragment_shader) - -#endif /* GL_ATI_text_fragment_shader */ - -/* --------------------- GL_ATI_texture_compression_3dc -------------------- */ - -#ifndef GL_ATI_texture_compression_3dc -#define GL_ATI_texture_compression_3dc 1 - -#define GL_COMPRESSED_LUMINANCE_ALPHA_3DC_ATI 0x8837 - -#define GLEW_ATI_texture_compression_3dc GLEW_GET_VAR(__GLEW_ATI_texture_compression_3dc) - -#endif /* GL_ATI_texture_compression_3dc */ - -/* ---------------------- GL_ATI_texture_env_combine3 ---------------------- */ - -#ifndef GL_ATI_texture_env_combine3 -#define GL_ATI_texture_env_combine3 1 - -#define GL_MODULATE_ADD_ATI 0x8744 -#define GL_MODULATE_SIGNED_ADD_ATI 0x8745 -#define GL_MODULATE_SUBTRACT_ATI 0x8746 - -#define GLEW_ATI_texture_env_combine3 GLEW_GET_VAR(__GLEW_ATI_texture_env_combine3) - -#endif /* GL_ATI_texture_env_combine3 */ - -/* -------------------------- GL_ATI_texture_float ------------------------- */ - -#ifndef GL_ATI_texture_float -#define GL_ATI_texture_float 1 - -#define GL_RGBA_FLOAT32_ATI 0x8814 -#define GL_RGB_FLOAT32_ATI 0x8815 -#define GL_ALPHA_FLOAT32_ATI 0x8816 -#define GL_INTENSITY_FLOAT32_ATI 0x8817 -#define GL_LUMINANCE_FLOAT32_ATI 0x8818 -#define GL_LUMINANCE_ALPHA_FLOAT32_ATI 0x8819 -#define GL_RGBA_FLOAT16_ATI 0x881A -#define GL_RGB_FLOAT16_ATI 0x881B -#define GL_ALPHA_FLOAT16_ATI 0x881C -#define GL_INTENSITY_FLOAT16_ATI 0x881D -#define GL_LUMINANCE_FLOAT16_ATI 0x881E -#define GL_LUMINANCE_ALPHA_FLOAT16_ATI 0x881F - -#define GLEW_ATI_texture_float GLEW_GET_VAR(__GLEW_ATI_texture_float) - -#endif /* GL_ATI_texture_float */ - -/* ----------------------- GL_ATI_texture_mirror_once ---------------------- */ - -#ifndef GL_ATI_texture_mirror_once -#define GL_ATI_texture_mirror_once 1 - -#define GL_MIRROR_CLAMP_ATI 0x8742 -#define GL_MIRROR_CLAMP_TO_EDGE_ATI 0x8743 - -#define GLEW_ATI_texture_mirror_once GLEW_GET_VAR(__GLEW_ATI_texture_mirror_once) - -#endif /* GL_ATI_texture_mirror_once */ - -/* ----------------------- GL_ATI_vertex_array_object ---------------------- */ - -#ifndef GL_ATI_vertex_array_object -#define GL_ATI_vertex_array_object 1 - -#define GL_STATIC_ATI 0x8760 -#define GL_DYNAMIC_ATI 0x8761 -#define GL_PRESERVE_ATI 0x8762 -#define GL_DISCARD_ATI 0x8763 -#define GL_OBJECT_BUFFER_SIZE_ATI 0x8764 -#define GL_OBJECT_BUFFER_USAGE_ATI 0x8765 -#define GL_ARRAY_OBJECT_BUFFER_ATI 0x8766 -#define GL_ARRAY_OBJECT_OFFSET_ATI 0x8767 - -typedef void (GLAPIENTRY * PFNGLARRAYOBJECTATIPROC) (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); -typedef void (GLAPIENTRY * PFNGLFREEOBJECTBUFFERATIPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLGETARRAYOBJECTFVATIPROC) (GLenum array, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETARRAYOBJECTIVATIPROC) (GLenum array, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETOBJECTBUFFERFVATIPROC) (GLuint buffer, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETOBJECTBUFFERIVATIPROC) (GLuint buffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVARIANTARRAYOBJECTFVATIPROC) (GLuint id, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVARIANTARRAYOBJECTIVATIPROC) (GLuint id, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISOBJECTBUFFERATIPROC) (GLuint buffer); -typedef GLuint (GLAPIENTRY * PFNGLNEWOBJECTBUFFERATIPROC) (GLsizei size, const GLvoid *pointer, GLenum usage); -typedef void (GLAPIENTRY * PFNGLUPDATEOBJECTBUFFERATIPROC) (GLuint buffer, GLuint offset, GLsizei size, const GLvoid *pointer, GLenum preserve); -typedef void (GLAPIENTRY * PFNGLVARIANTARRAYOBJECTATIPROC) (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); - -#define glArrayObjectATI GLEW_GET_FUN(__glewArrayObjectATI) -#define glFreeObjectBufferATI GLEW_GET_FUN(__glewFreeObjectBufferATI) -#define glGetArrayObjectfvATI GLEW_GET_FUN(__glewGetArrayObjectfvATI) -#define glGetArrayObjectivATI GLEW_GET_FUN(__glewGetArrayObjectivATI) -#define glGetObjectBufferfvATI GLEW_GET_FUN(__glewGetObjectBufferfvATI) -#define glGetObjectBufferivATI GLEW_GET_FUN(__glewGetObjectBufferivATI) -#define glGetVariantArrayObjectfvATI GLEW_GET_FUN(__glewGetVariantArrayObjectfvATI) -#define glGetVariantArrayObjectivATI GLEW_GET_FUN(__glewGetVariantArrayObjectivATI) -#define glIsObjectBufferATI GLEW_GET_FUN(__glewIsObjectBufferATI) -#define glNewObjectBufferATI GLEW_GET_FUN(__glewNewObjectBufferATI) -#define glUpdateObjectBufferATI GLEW_GET_FUN(__glewUpdateObjectBufferATI) -#define glVariantArrayObjectATI GLEW_GET_FUN(__glewVariantArrayObjectATI) - -#define GLEW_ATI_vertex_array_object GLEW_GET_VAR(__GLEW_ATI_vertex_array_object) - -#endif /* GL_ATI_vertex_array_object */ - -/* ------------------- GL_ATI_vertex_attrib_array_object ------------------- */ - -#ifndef GL_ATI_vertex_attrib_array_object -#define GL_ATI_vertex_attrib_array_object 1 - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC) (GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC) (GLuint index, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBARRAYOBJECTATIPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset); - -#define glGetVertexAttribArrayObjectfvATI GLEW_GET_FUN(__glewGetVertexAttribArrayObjectfvATI) -#define glGetVertexAttribArrayObjectivATI GLEW_GET_FUN(__glewGetVertexAttribArrayObjectivATI) -#define glVertexAttribArrayObjectATI GLEW_GET_FUN(__glewVertexAttribArrayObjectATI) - -#define GLEW_ATI_vertex_attrib_array_object GLEW_GET_VAR(__GLEW_ATI_vertex_attrib_array_object) - -#endif /* GL_ATI_vertex_attrib_array_object */ - -/* ------------------------- GL_ATI_vertex_streams ------------------------- */ - -#ifndef GL_ATI_vertex_streams -#define GL_ATI_vertex_streams 1 - -#define GL_MAX_VERTEX_STREAMS_ATI 0x876B -#define GL_VERTEX_SOURCE_ATI 0x876C -#define GL_VERTEX_STREAM0_ATI 0x876D -#define GL_VERTEX_STREAM1_ATI 0x876E -#define GL_VERTEX_STREAM2_ATI 0x876F -#define GL_VERTEX_STREAM3_ATI 0x8770 -#define GL_VERTEX_STREAM4_ATI 0x8771 -#define GL_VERTEX_STREAM5_ATI 0x8772 -#define GL_VERTEX_STREAM6_ATI 0x8773 -#define GL_VERTEX_STREAM7_ATI 0x8774 - -typedef void (GLAPIENTRY * PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC) (GLenum stream); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3BATIPROC) (GLenum stream, GLbyte x, GLbyte y, GLbyte z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3BVATIPROC) (GLenum stream, const GLbyte *coords); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3DVATIPROC) (GLenum stream, const GLdouble *coords); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3FVATIPROC) (GLenum stream, const GLfloat *coords); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3IVATIPROC) (GLenum stream, const GLint *coords); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLNORMALSTREAM3SVATIPROC) (GLenum stream, const GLshort *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXBLENDENVFATIPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLVERTEXBLENDENVIATIPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1DATIPROC) (GLenum stream, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1DVATIPROC) (GLenum stream, const GLdouble *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1FATIPROC) (GLenum stream, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1FVATIPROC) (GLenum stream, const GLfloat *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1IATIPROC) (GLenum stream, GLint x); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1IVATIPROC) (GLenum stream, const GLint *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1SATIPROC) (GLenum stream, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM1SVATIPROC) (GLenum stream, const GLshort *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2DATIPROC) (GLenum stream, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2DVATIPROC) (GLenum stream, const GLdouble *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2FATIPROC) (GLenum stream, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2FVATIPROC) (GLenum stream, const GLfloat *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2IATIPROC) (GLenum stream, GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2IVATIPROC) (GLenum stream, const GLint *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2SATIPROC) (GLenum stream, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM2SVATIPROC) (GLenum stream, const GLshort *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3DVATIPROC) (GLenum stream, const GLdouble *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3FVATIPROC) (GLenum stream, const GLfloat *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3IVATIPROC) (GLenum stream, const GLint *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM3SVATIPROC) (GLenum stream, const GLshort *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4DVATIPROC) (GLenum stream, const GLdouble *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4FVATIPROC) (GLenum stream, const GLfloat *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4IATIPROC) (GLenum stream, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4IVATIPROC) (GLenum stream, const GLint *coords); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXSTREAM4SVATIPROC) (GLenum stream, const GLshort *coords); - -#define glClientActiveVertexStreamATI GLEW_GET_FUN(__glewClientActiveVertexStreamATI) -#define glNormalStream3bATI GLEW_GET_FUN(__glewNormalStream3bATI) -#define glNormalStream3bvATI GLEW_GET_FUN(__glewNormalStream3bvATI) -#define glNormalStream3dATI GLEW_GET_FUN(__glewNormalStream3dATI) -#define glNormalStream3dvATI GLEW_GET_FUN(__glewNormalStream3dvATI) -#define glNormalStream3fATI GLEW_GET_FUN(__glewNormalStream3fATI) -#define glNormalStream3fvATI GLEW_GET_FUN(__glewNormalStream3fvATI) -#define glNormalStream3iATI GLEW_GET_FUN(__glewNormalStream3iATI) -#define glNormalStream3ivATI GLEW_GET_FUN(__glewNormalStream3ivATI) -#define glNormalStream3sATI GLEW_GET_FUN(__glewNormalStream3sATI) -#define glNormalStream3svATI GLEW_GET_FUN(__glewNormalStream3svATI) -#define glVertexBlendEnvfATI GLEW_GET_FUN(__glewVertexBlendEnvfATI) -#define glVertexBlendEnviATI GLEW_GET_FUN(__glewVertexBlendEnviATI) -#define glVertexStream1dATI GLEW_GET_FUN(__glewVertexStream1dATI) -#define glVertexStream1dvATI GLEW_GET_FUN(__glewVertexStream1dvATI) -#define glVertexStream1fATI GLEW_GET_FUN(__glewVertexStream1fATI) -#define glVertexStream1fvATI GLEW_GET_FUN(__glewVertexStream1fvATI) -#define glVertexStream1iATI GLEW_GET_FUN(__glewVertexStream1iATI) -#define glVertexStream1ivATI GLEW_GET_FUN(__glewVertexStream1ivATI) -#define glVertexStream1sATI GLEW_GET_FUN(__glewVertexStream1sATI) -#define glVertexStream1svATI GLEW_GET_FUN(__glewVertexStream1svATI) -#define glVertexStream2dATI GLEW_GET_FUN(__glewVertexStream2dATI) -#define glVertexStream2dvATI GLEW_GET_FUN(__glewVertexStream2dvATI) -#define glVertexStream2fATI GLEW_GET_FUN(__glewVertexStream2fATI) -#define glVertexStream2fvATI GLEW_GET_FUN(__glewVertexStream2fvATI) -#define glVertexStream2iATI GLEW_GET_FUN(__glewVertexStream2iATI) -#define glVertexStream2ivATI GLEW_GET_FUN(__glewVertexStream2ivATI) -#define glVertexStream2sATI GLEW_GET_FUN(__glewVertexStream2sATI) -#define glVertexStream2svATI GLEW_GET_FUN(__glewVertexStream2svATI) -#define glVertexStream3dATI GLEW_GET_FUN(__glewVertexStream3dATI) -#define glVertexStream3dvATI GLEW_GET_FUN(__glewVertexStream3dvATI) -#define glVertexStream3fATI GLEW_GET_FUN(__glewVertexStream3fATI) -#define glVertexStream3fvATI GLEW_GET_FUN(__glewVertexStream3fvATI) -#define glVertexStream3iATI GLEW_GET_FUN(__glewVertexStream3iATI) -#define glVertexStream3ivATI GLEW_GET_FUN(__glewVertexStream3ivATI) -#define glVertexStream3sATI GLEW_GET_FUN(__glewVertexStream3sATI) -#define glVertexStream3svATI GLEW_GET_FUN(__glewVertexStream3svATI) -#define glVertexStream4dATI GLEW_GET_FUN(__glewVertexStream4dATI) -#define glVertexStream4dvATI GLEW_GET_FUN(__glewVertexStream4dvATI) -#define glVertexStream4fATI GLEW_GET_FUN(__glewVertexStream4fATI) -#define glVertexStream4fvATI GLEW_GET_FUN(__glewVertexStream4fvATI) -#define glVertexStream4iATI GLEW_GET_FUN(__glewVertexStream4iATI) -#define glVertexStream4ivATI GLEW_GET_FUN(__glewVertexStream4ivATI) -#define glVertexStream4sATI GLEW_GET_FUN(__glewVertexStream4sATI) -#define glVertexStream4svATI GLEW_GET_FUN(__glewVertexStream4svATI) - -#define GLEW_ATI_vertex_streams GLEW_GET_VAR(__GLEW_ATI_vertex_streams) - -#endif /* GL_ATI_vertex_streams */ - -/* --------------------------- GL_EXT_422_pixels --------------------------- */ - -#ifndef GL_EXT_422_pixels -#define GL_EXT_422_pixels 1 - -#define GL_422_EXT 0x80CC -#define GL_422_REV_EXT 0x80CD -#define GL_422_AVERAGE_EXT 0x80CE -#define GL_422_REV_AVERAGE_EXT 0x80CF - -#define GLEW_EXT_422_pixels GLEW_GET_VAR(__GLEW_EXT_422_pixels) - -#endif /* GL_EXT_422_pixels */ - -/* ---------------------------- GL_EXT_Cg_shader --------------------------- */ - -#ifndef GL_EXT_Cg_shader -#define GL_EXT_Cg_shader 1 - -#define GL_CG_VERTEX_SHADER_EXT 0x890E -#define GL_CG_FRAGMENT_SHADER_EXT 0x890F - -#define GLEW_EXT_Cg_shader GLEW_GET_VAR(__GLEW_EXT_Cg_shader) - -#endif /* GL_EXT_Cg_shader */ - -/* ------------------------------ GL_EXT_abgr ------------------------------ */ - -#ifndef GL_EXT_abgr -#define GL_EXT_abgr 1 - -#define GL_ABGR_EXT 0x8000 - -#define GLEW_EXT_abgr GLEW_GET_VAR(__GLEW_EXT_abgr) - -#endif /* GL_EXT_abgr */ - -/* ------------------------------ GL_EXT_bgra ------------------------------ */ - -#ifndef GL_EXT_bgra -#define GL_EXT_bgra 1 - -#define GL_BGR_EXT 0x80E0 -#define GL_BGRA_EXT 0x80E1 - -#define GLEW_EXT_bgra GLEW_GET_VAR(__GLEW_EXT_bgra) - -#endif /* GL_EXT_bgra */ - -/* ------------------------ GL_EXT_bindable_uniform ------------------------ */ - -#ifndef GL_EXT_bindable_uniform -#define GL_EXT_bindable_uniform 1 - -#define GL_MAX_VERTEX_BINDABLE_UNIFORMS_EXT 0x8DE2 -#define GL_MAX_FRAGMENT_BINDABLE_UNIFORMS_EXT 0x8DE3 -#define GL_MAX_GEOMETRY_BINDABLE_UNIFORMS_EXT 0x8DE4 -#define GL_MAX_BINDABLE_UNIFORM_SIZE_EXT 0x8DED -#define GL_UNIFORM_BUFFER_EXT 0x8DEE -#define GL_UNIFORM_BUFFER_BINDING_EXT 0x8DEF - -typedef GLint (GLAPIENTRY * PFNGLGETUNIFORMBUFFERSIZEEXTPROC) (GLuint program, GLint location); -typedef GLintptr (GLAPIENTRY * PFNGLGETUNIFORMOFFSETEXTPROC) (GLuint program, GLint location); -typedef void (GLAPIENTRY * PFNGLUNIFORMBUFFEREXTPROC) (GLuint program, GLint location, GLuint buffer); - -#define glGetUniformBufferSizeEXT GLEW_GET_FUN(__glewGetUniformBufferSizeEXT) -#define glGetUniformOffsetEXT GLEW_GET_FUN(__glewGetUniformOffsetEXT) -#define glUniformBufferEXT GLEW_GET_FUN(__glewUniformBufferEXT) - -#define GLEW_EXT_bindable_uniform GLEW_GET_VAR(__GLEW_EXT_bindable_uniform) - -#endif /* GL_EXT_bindable_uniform */ - -/* --------------------------- GL_EXT_blend_color -------------------------- */ - -#ifndef GL_EXT_blend_color -#define GL_EXT_blend_color 1 - -#define GL_CONSTANT_COLOR_EXT 0x8001 -#define GL_ONE_MINUS_CONSTANT_COLOR_EXT 0x8002 -#define GL_CONSTANT_ALPHA_EXT 0x8003 -#define GL_ONE_MINUS_CONSTANT_ALPHA_EXT 0x8004 -#define GL_BLEND_COLOR_EXT 0x8005 - -typedef void (GLAPIENTRY * PFNGLBLENDCOLOREXTPROC) (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); - -#define glBlendColorEXT GLEW_GET_FUN(__glewBlendColorEXT) - -#define GLEW_EXT_blend_color GLEW_GET_VAR(__GLEW_EXT_blend_color) - -#endif /* GL_EXT_blend_color */ - -/* --------------------- GL_EXT_blend_equation_separate -------------------- */ - -#ifndef GL_EXT_blend_equation_separate -#define GL_EXT_blend_equation_separate 1 - -#define GL_BLEND_EQUATION_RGB_EXT 0x8009 -#define GL_BLEND_EQUATION_ALPHA_EXT 0x883D - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONSEPARATEEXTPROC) (GLenum modeRGB, GLenum modeAlpha); - -#define glBlendEquationSeparateEXT GLEW_GET_FUN(__glewBlendEquationSeparateEXT) - -#define GLEW_EXT_blend_equation_separate GLEW_GET_VAR(__GLEW_EXT_blend_equation_separate) - -#endif /* GL_EXT_blend_equation_separate */ - -/* ----------------------- GL_EXT_blend_func_separate ---------------------- */ - -#ifndef GL_EXT_blend_func_separate -#define GL_EXT_blend_func_separate 1 - -#define GL_BLEND_DST_RGB_EXT 0x80C8 -#define GL_BLEND_SRC_RGB_EXT 0x80C9 -#define GL_BLEND_DST_ALPHA_EXT 0x80CA -#define GL_BLEND_SRC_ALPHA_EXT 0x80CB - -typedef void (GLAPIENTRY * PFNGLBLENDFUNCSEPARATEEXTPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); - -#define glBlendFuncSeparateEXT GLEW_GET_FUN(__glewBlendFuncSeparateEXT) - -#define GLEW_EXT_blend_func_separate GLEW_GET_VAR(__GLEW_EXT_blend_func_separate) - -#endif /* GL_EXT_blend_func_separate */ - -/* ------------------------- GL_EXT_blend_logic_op ------------------------- */ - -#ifndef GL_EXT_blend_logic_op -#define GL_EXT_blend_logic_op 1 - -#define GLEW_EXT_blend_logic_op GLEW_GET_VAR(__GLEW_EXT_blend_logic_op) - -#endif /* GL_EXT_blend_logic_op */ - -/* -------------------------- GL_EXT_blend_minmax -------------------------- */ - -#ifndef GL_EXT_blend_minmax -#define GL_EXT_blend_minmax 1 - -#define GL_FUNC_ADD_EXT 0x8006 -#define GL_MIN_EXT 0x8007 -#define GL_MAX_EXT 0x8008 -#define GL_BLEND_EQUATION_EXT 0x8009 - -typedef void (GLAPIENTRY * PFNGLBLENDEQUATIONEXTPROC) (GLenum mode); - -#define glBlendEquationEXT GLEW_GET_FUN(__glewBlendEquationEXT) - -#define GLEW_EXT_blend_minmax GLEW_GET_VAR(__GLEW_EXT_blend_minmax) - -#endif /* GL_EXT_blend_minmax */ - -/* ------------------------- GL_EXT_blend_subtract ------------------------- */ - -#ifndef GL_EXT_blend_subtract -#define GL_EXT_blend_subtract 1 - -#define GL_FUNC_SUBTRACT_EXT 0x800A -#define GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B - -#define GLEW_EXT_blend_subtract GLEW_GET_VAR(__GLEW_EXT_blend_subtract) - -#endif /* GL_EXT_blend_subtract */ - -/* ------------------------ GL_EXT_clip_volume_hint ------------------------ */ - -#ifndef GL_EXT_clip_volume_hint -#define GL_EXT_clip_volume_hint 1 - -#define GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 - -#define GLEW_EXT_clip_volume_hint GLEW_GET_VAR(__GLEW_EXT_clip_volume_hint) - -#endif /* GL_EXT_clip_volume_hint */ - -/* ------------------------------ GL_EXT_cmyka ----------------------------- */ - -#ifndef GL_EXT_cmyka -#define GL_EXT_cmyka 1 - -#define GL_CMYK_EXT 0x800C -#define GL_CMYKA_EXT 0x800D -#define GL_PACK_CMYK_HINT_EXT 0x800E -#define GL_UNPACK_CMYK_HINT_EXT 0x800F - -#define GLEW_EXT_cmyka GLEW_GET_VAR(__GLEW_EXT_cmyka) - -#endif /* GL_EXT_cmyka */ - -/* ------------------------- GL_EXT_color_subtable ------------------------- */ - -#ifndef GL_EXT_color_subtable -#define GL_EXT_color_subtable 1 - -typedef void (GLAPIENTRY * PFNGLCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); - -#define glColorSubTableEXT GLEW_GET_FUN(__glewColorSubTableEXT) -#define glCopyColorSubTableEXT GLEW_GET_FUN(__glewCopyColorSubTableEXT) - -#define GLEW_EXT_color_subtable GLEW_GET_VAR(__GLEW_EXT_color_subtable) - -#endif /* GL_EXT_color_subtable */ - -/* ---------------------- GL_EXT_compiled_vertex_array --------------------- */ - -#ifndef GL_EXT_compiled_vertex_array -#define GL_EXT_compiled_vertex_array 1 - -#define GL_ARRAY_ELEMENT_LOCK_FIRST_EXT 0x81A8 -#define GL_ARRAY_ELEMENT_LOCK_COUNT_EXT 0x81A9 - -typedef void (GLAPIENTRY * PFNGLLOCKARRAYSEXTPROC) (GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLUNLOCKARRAYSEXTPROC) (void); - -#define glLockArraysEXT GLEW_GET_FUN(__glewLockArraysEXT) -#define glUnlockArraysEXT GLEW_GET_FUN(__glewUnlockArraysEXT) - -#define GLEW_EXT_compiled_vertex_array GLEW_GET_VAR(__GLEW_EXT_compiled_vertex_array) - -#endif /* GL_EXT_compiled_vertex_array */ - -/* --------------------------- GL_EXT_convolution -------------------------- */ - -#ifndef GL_EXT_convolution -#define GL_EXT_convolution 1 - -#define GL_CONVOLUTION_1D_EXT 0x8010 -#define GL_CONVOLUTION_2D_EXT 0x8011 -#define GL_SEPARABLE_2D_EXT 0x8012 -#define GL_CONVOLUTION_BORDER_MODE_EXT 0x8013 -#define GL_CONVOLUTION_FILTER_SCALE_EXT 0x8014 -#define GL_CONVOLUTION_FILTER_BIAS_EXT 0x8015 -#define GL_REDUCE_EXT 0x8016 -#define GL_CONVOLUTION_FORMAT_EXT 0x8017 -#define GL_CONVOLUTION_WIDTH_EXT 0x8018 -#define GL_CONVOLUTION_HEIGHT_EXT 0x8019 -#define GL_MAX_CONVOLUTION_WIDTH_EXT 0x801A -#define GL_MAX_CONVOLUTION_HEIGHT_EXT 0x801B -#define GL_POST_CONVOLUTION_RED_SCALE_EXT 0x801C -#define GL_POST_CONVOLUTION_GREEN_SCALE_EXT 0x801D -#define GL_POST_CONVOLUTION_BLUE_SCALE_EXT 0x801E -#define GL_POST_CONVOLUTION_ALPHA_SCALE_EXT 0x801F -#define GL_POST_CONVOLUTION_RED_BIAS_EXT 0x8020 -#define GL_POST_CONVOLUTION_GREEN_BIAS_EXT 0x8021 -#define GL_POST_CONVOLUTION_BLUE_BIAS_EXT 0x8022 -#define GL_POST_CONVOLUTION_ALPHA_BIAS_EXT 0x8023 - -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *image); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *image); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETSEPARABLEFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *row, GLvoid *column, GLvoid *span); -typedef void (GLAPIENTRY * PFNGLSEPARABLEFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *row, const GLvoid *column); - -#define glConvolutionFilter1DEXT GLEW_GET_FUN(__glewConvolutionFilter1DEXT) -#define glConvolutionFilter2DEXT GLEW_GET_FUN(__glewConvolutionFilter2DEXT) -#define glConvolutionParameterfEXT GLEW_GET_FUN(__glewConvolutionParameterfEXT) -#define glConvolutionParameterfvEXT GLEW_GET_FUN(__glewConvolutionParameterfvEXT) -#define glConvolutionParameteriEXT GLEW_GET_FUN(__glewConvolutionParameteriEXT) -#define glConvolutionParameterivEXT GLEW_GET_FUN(__glewConvolutionParameterivEXT) -#define glCopyConvolutionFilter1DEXT GLEW_GET_FUN(__glewCopyConvolutionFilter1DEXT) -#define glCopyConvolutionFilter2DEXT GLEW_GET_FUN(__glewCopyConvolutionFilter2DEXT) -#define glGetConvolutionFilterEXT GLEW_GET_FUN(__glewGetConvolutionFilterEXT) -#define glGetConvolutionParameterfvEXT GLEW_GET_FUN(__glewGetConvolutionParameterfvEXT) -#define glGetConvolutionParameterivEXT GLEW_GET_FUN(__glewGetConvolutionParameterivEXT) -#define glGetSeparableFilterEXT GLEW_GET_FUN(__glewGetSeparableFilterEXT) -#define glSeparableFilter2DEXT GLEW_GET_FUN(__glewSeparableFilter2DEXT) - -#define GLEW_EXT_convolution GLEW_GET_VAR(__GLEW_EXT_convolution) - -#endif /* GL_EXT_convolution */ - -/* ------------------------ GL_EXT_coordinate_frame ------------------------ */ - -#ifndef GL_EXT_coordinate_frame -#define GL_EXT_coordinate_frame 1 - -#define GL_TANGENT_ARRAY_EXT 0x8439 -#define GL_BINORMAL_ARRAY_EXT 0x843A -#define GL_CURRENT_TANGENT_EXT 0x843B -#define GL_CURRENT_BINORMAL_EXT 0x843C -#define GL_TANGENT_ARRAY_TYPE_EXT 0x843E -#define GL_TANGENT_ARRAY_STRIDE_EXT 0x843F -#define GL_BINORMAL_ARRAY_TYPE_EXT 0x8440 -#define GL_BINORMAL_ARRAY_STRIDE_EXT 0x8441 -#define GL_TANGENT_ARRAY_POINTER_EXT 0x8442 -#define GL_BINORMAL_ARRAY_POINTER_EXT 0x8443 -#define GL_MAP1_TANGENT_EXT 0x8444 -#define GL_MAP2_TANGENT_EXT 0x8445 -#define GL_MAP1_BINORMAL_EXT 0x8446 -#define GL_MAP2_BINORMAL_EXT 0x8447 - -typedef void (GLAPIENTRY * PFNGLBINORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLTANGENTPOINTEREXTPROC) (GLenum type, GLsizei stride, GLvoid *pointer); - -#define glBinormalPointerEXT GLEW_GET_FUN(__glewBinormalPointerEXT) -#define glTangentPointerEXT GLEW_GET_FUN(__glewTangentPointerEXT) - -#define GLEW_EXT_coordinate_frame GLEW_GET_VAR(__GLEW_EXT_coordinate_frame) - -#endif /* GL_EXT_coordinate_frame */ - -/* -------------------------- GL_EXT_copy_texture -------------------------- */ - -#ifndef GL_EXT_copy_texture -#define GL_EXT_copy_texture 1 - -typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE1DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXIMAGE2DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); - -#define glCopyTexImage1DEXT GLEW_GET_FUN(__glewCopyTexImage1DEXT) -#define glCopyTexImage2DEXT GLEW_GET_FUN(__glewCopyTexImage2DEXT) -#define glCopyTexSubImage1DEXT GLEW_GET_FUN(__glewCopyTexSubImage1DEXT) -#define glCopyTexSubImage2DEXT GLEW_GET_FUN(__glewCopyTexSubImage2DEXT) -#define glCopyTexSubImage3DEXT GLEW_GET_FUN(__glewCopyTexSubImage3DEXT) - -#define GLEW_EXT_copy_texture GLEW_GET_VAR(__GLEW_EXT_copy_texture) - -#endif /* GL_EXT_copy_texture */ - -/* --------------------------- GL_EXT_cull_vertex -------------------------- */ - -#ifndef GL_EXT_cull_vertex -#define GL_EXT_cull_vertex 1 - -#define GL_CULL_VERTEX_EXT 0x81AA -#define GL_CULL_VERTEX_EYE_POSITION_EXT 0x81AB -#define GL_CULL_VERTEX_OBJECT_POSITION_EXT 0x81AC - -typedef void (GLAPIENTRY * PFNGLCULLPARAMETERDVEXTPROC) (GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLCULLPARAMETERFVEXTPROC) (GLenum pname, GLfloat* params); - -#define glCullParameterdvEXT GLEW_GET_FUN(__glewCullParameterdvEXT) -#define glCullParameterfvEXT GLEW_GET_FUN(__glewCullParameterfvEXT) - -#define GLEW_EXT_cull_vertex GLEW_GET_VAR(__GLEW_EXT_cull_vertex) - -#endif /* GL_EXT_cull_vertex */ - -/* -------------------------- GL_EXT_debug_marker -------------------------- */ - -#ifndef GL_EXT_debug_marker -#define GL_EXT_debug_marker 1 - -typedef void (GLAPIENTRY * PFNGLINSERTEVENTMARKEREXTPROC) (GLsizei length, const GLchar* marker); -typedef void (GLAPIENTRY * PFNGLPOPGROUPMARKEREXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLPUSHGROUPMARKEREXTPROC) (GLsizei length, const GLchar* marker); - -#define glInsertEventMarkerEXT GLEW_GET_FUN(__glewInsertEventMarkerEXT) -#define glPopGroupMarkerEXT GLEW_GET_FUN(__glewPopGroupMarkerEXT) -#define glPushGroupMarkerEXT GLEW_GET_FUN(__glewPushGroupMarkerEXT) - -#define GLEW_EXT_debug_marker GLEW_GET_VAR(__GLEW_EXT_debug_marker) - -#endif /* GL_EXT_debug_marker */ - -/* ------------------------ GL_EXT_depth_bounds_test ----------------------- */ - -#ifndef GL_EXT_depth_bounds_test -#define GL_EXT_depth_bounds_test 1 - -#define GL_DEPTH_BOUNDS_TEST_EXT 0x8890 -#define GL_DEPTH_BOUNDS_EXT 0x8891 - -typedef void (GLAPIENTRY * PFNGLDEPTHBOUNDSEXTPROC) (GLclampd zmin, GLclampd zmax); - -#define glDepthBoundsEXT GLEW_GET_FUN(__glewDepthBoundsEXT) - -#define GLEW_EXT_depth_bounds_test GLEW_GET_VAR(__GLEW_EXT_depth_bounds_test) - -#endif /* GL_EXT_depth_bounds_test */ - -/* ----------------------- GL_EXT_direct_state_access ---------------------- */ - -#ifndef GL_EXT_direct_state_access -#define GL_EXT_direct_state_access 1 - -#define GL_PROGRAM_MATRIX_EXT 0x8E2D -#define GL_TRANSPOSE_PROGRAM_MATRIX_EXT 0x8E2E -#define GL_PROGRAM_MATRIX_STACK_DEPTH_EXT 0x8E2F - -typedef void (GLAPIENTRY * PFNGLBINDMULTITEXTUREEXTPROC) (GLenum texunit, GLenum target, GLuint texture); -typedef GLenum (GLAPIENTRY * PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC) (GLuint framebuffer, GLenum target); -typedef void (GLAPIENTRY * PFNGLCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLDISABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); -typedef void (GLAPIENTRY * PFNGLDISABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); -typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); -typedef void (GLAPIENTRY * PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC) (GLuint framebuffer, GLsizei n, const GLenum* bufs); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERREADBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); -typedef void (GLAPIENTRY * PFNGLGENERATEMULTITEXMIPMAPEXTPROC) (GLenum texunit, GLenum target); -typedef void (GLAPIENTRY * PFNGLGENERATETEXTUREMIPMAPEXTPROC) (GLuint texture, GLenum target); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, GLvoid *img); -typedef void (GLAPIENTRY * PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, GLvoid *img); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEINDEXEDVEXTPROC) (GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETDOUBLEI_VEXTPROC) (GLenum pname, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETFLOATINDEXEDVEXTPROC) (GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFLOATI_VEXTPROC) (GLenum pname, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC) (GLuint buffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPOINTERVEXTPROC) (GLuint buffer, GLenum pname, void** params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum pname, GLvoid *string); -typedef void (GLAPIENTRY * PFNGLGETNAMEDPROGRAMIVEXTPROC) (GLuint program, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC) (GLuint renderbuffer, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETPOINTERINDEXEDVEXTPROC) (GLenum target, GLuint index, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETPOINTERI_VEXTPROC) (GLenum pname, GLuint index, GLvoid** params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYINTEGERVEXTPROC) (GLuint vaobj, GLenum pname, GLint* param); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLvoid** param); -typedef void (GLAPIENTRY * PFNGLGETVERTEXARRAYPOINTERVEXTPROC) (GLuint vaobj, GLenum pname, GLvoid** param); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPNAMEDBUFFEREXTPROC) (GLuint buffer, GLenum access); -typedef GLvoid * (GLAPIENTRY * PFNGLMAPNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length, GLbitfield access); -typedef void (GLAPIENTRY * PFNGLMATRIXFRUSTUMEXTPROC) (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADIDENTITYEXTPROC) (GLenum matrixMode); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADTRANSPOSEDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADTRANSPOSEFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXLOADFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTTRANSPOSEDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTTRANSPOSEFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTDEXTPROC) (GLenum matrixMode, const GLdouble* m); -typedef void (GLAPIENTRY * PFNGLMATRIXMULTFEXTPROC) (GLenum matrixMode, const GLfloat* m); -typedef void (GLAPIENTRY * PFNGLMATRIXORTHOEXTPROC) (GLenum matrixMode, GLdouble l, GLdouble r, GLdouble b, GLdouble t, GLdouble n, GLdouble f); -typedef void (GLAPIENTRY * PFNGLMATRIXPOPEXTPROC) (GLenum matrixMode); -typedef void (GLAPIENTRY * PFNGLMATRIXPUSHEXTPROC) (GLenum matrixMode); -typedef void (GLAPIENTRY * PFNGLMATRIXROTATEDEXTPROC) (GLenum matrixMode, GLdouble angle, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLMATRIXROTATEFEXTPROC) (GLenum matrixMode, GLfloat angle, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLMATRIXSCALEDEXTPROC) (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLMATRIXSCALEFEXTPROC) (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLMATRIXTRANSLATEDEXTPROC) (GLenum matrixMode, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLMATRIXTRANSLATEFEXTPROC) (GLenum matrixMode, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLMULTITEXBUFFEREXTPROC) (GLenum texunit, GLenum target, GLenum internalformat, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORDPOINTEREXTPROC) (GLenum texunit, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENDEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble param); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENFEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENIEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat* param); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint* param); -typedef void (GLAPIENTRY * PFNGLMULTITEXRENDERBUFFEREXTPROC) (GLenum texunit, GLenum target, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERDATAEXTPROC) (GLuint buffer, GLsizeiptr size, const GLvoid *data, GLenum usage); -typedef void (GLAPIENTRY * PFNGLNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC) (GLuint readBuffer, GLuint writeBuffer, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC) (GLuint framebuffer, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLenum face); -typedef void (GLAPIENTRY * PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLint layer); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC) (GLuint program, GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum format, GLsizei len, const GLvoid *string); -typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC) (GLuint renderbuffer, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC) (GLuint renderbuffer, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLuint renderbuffer, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FEXTPROC) (GLuint program, GLint location, GLfloat v0); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IEXTPROC) (GLuint program, GLint location, GLint v0); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIEXTPROC) (GLuint program, GLint location, GLuint v0); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLTEXTUREBUFFEREXTPROC) (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLuint* params); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERFEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLfloat* param); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint* param); -typedef void (GLAPIENTRY * PFNGLTEXTURERENDERBUFFEREXTPROC) (GLuint texture, GLenum target, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); -typedef GLboolean (GLAPIENTRY * PFNGLUNMAPNAMEDBUFFEREXTPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYINDEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum texunit, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYNORMALOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); - -#define glBindMultiTextureEXT GLEW_GET_FUN(__glewBindMultiTextureEXT) -#define glCheckNamedFramebufferStatusEXT GLEW_GET_FUN(__glewCheckNamedFramebufferStatusEXT) -#define glClientAttribDefaultEXT GLEW_GET_FUN(__glewClientAttribDefaultEXT) -#define glCompressedMultiTexImage1DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage1DEXT) -#define glCompressedMultiTexImage2DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage2DEXT) -#define glCompressedMultiTexImage3DEXT GLEW_GET_FUN(__glewCompressedMultiTexImage3DEXT) -#define glCompressedMultiTexSubImage1DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage1DEXT) -#define glCompressedMultiTexSubImage2DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage2DEXT) -#define glCompressedMultiTexSubImage3DEXT GLEW_GET_FUN(__glewCompressedMultiTexSubImage3DEXT) -#define glCompressedTextureImage1DEXT GLEW_GET_FUN(__glewCompressedTextureImage1DEXT) -#define glCompressedTextureImage2DEXT GLEW_GET_FUN(__glewCompressedTextureImage2DEXT) -#define glCompressedTextureImage3DEXT GLEW_GET_FUN(__glewCompressedTextureImage3DEXT) -#define glCompressedTextureSubImage1DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage1DEXT) -#define glCompressedTextureSubImage2DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage2DEXT) -#define glCompressedTextureSubImage3DEXT GLEW_GET_FUN(__glewCompressedTextureSubImage3DEXT) -#define glCopyMultiTexImage1DEXT GLEW_GET_FUN(__glewCopyMultiTexImage1DEXT) -#define glCopyMultiTexImage2DEXT GLEW_GET_FUN(__glewCopyMultiTexImage2DEXT) -#define glCopyMultiTexSubImage1DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage1DEXT) -#define glCopyMultiTexSubImage2DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage2DEXT) -#define glCopyMultiTexSubImage3DEXT GLEW_GET_FUN(__glewCopyMultiTexSubImage3DEXT) -#define glCopyTextureImage1DEXT GLEW_GET_FUN(__glewCopyTextureImage1DEXT) -#define glCopyTextureImage2DEXT GLEW_GET_FUN(__glewCopyTextureImage2DEXT) -#define glCopyTextureSubImage1DEXT GLEW_GET_FUN(__glewCopyTextureSubImage1DEXT) -#define glCopyTextureSubImage2DEXT GLEW_GET_FUN(__glewCopyTextureSubImage2DEXT) -#define glCopyTextureSubImage3DEXT GLEW_GET_FUN(__glewCopyTextureSubImage3DEXT) -#define glDisableClientStateIndexedEXT GLEW_GET_FUN(__glewDisableClientStateIndexedEXT) -#define glDisableClientStateiEXT GLEW_GET_FUN(__glewDisableClientStateiEXT) -#define glDisableVertexArrayAttribEXT GLEW_GET_FUN(__glewDisableVertexArrayAttribEXT) -#define glDisableVertexArrayEXT GLEW_GET_FUN(__glewDisableVertexArrayEXT) -#define glEnableClientStateIndexedEXT GLEW_GET_FUN(__glewEnableClientStateIndexedEXT) -#define glEnableClientStateiEXT GLEW_GET_FUN(__glewEnableClientStateiEXT) -#define glEnableVertexArrayAttribEXT GLEW_GET_FUN(__glewEnableVertexArrayAttribEXT) -#define glEnableVertexArrayEXT GLEW_GET_FUN(__glewEnableVertexArrayEXT) -#define glFlushMappedNamedBufferRangeEXT GLEW_GET_FUN(__glewFlushMappedNamedBufferRangeEXT) -#define glFramebufferDrawBufferEXT GLEW_GET_FUN(__glewFramebufferDrawBufferEXT) -#define glFramebufferDrawBuffersEXT GLEW_GET_FUN(__glewFramebufferDrawBuffersEXT) -#define glFramebufferReadBufferEXT GLEW_GET_FUN(__glewFramebufferReadBufferEXT) -#define glGenerateMultiTexMipmapEXT GLEW_GET_FUN(__glewGenerateMultiTexMipmapEXT) -#define glGenerateTextureMipmapEXT GLEW_GET_FUN(__glewGenerateTextureMipmapEXT) -#define glGetCompressedMultiTexImageEXT GLEW_GET_FUN(__glewGetCompressedMultiTexImageEXT) -#define glGetCompressedTextureImageEXT GLEW_GET_FUN(__glewGetCompressedTextureImageEXT) -#define glGetDoubleIndexedvEXT GLEW_GET_FUN(__glewGetDoubleIndexedvEXT) -#define glGetDoublei_vEXT GLEW_GET_FUN(__glewGetDoublei_vEXT) -#define glGetFloatIndexedvEXT GLEW_GET_FUN(__glewGetFloatIndexedvEXT) -#define glGetFloati_vEXT GLEW_GET_FUN(__glewGetFloati_vEXT) -#define glGetFramebufferParameterivEXT GLEW_GET_FUN(__glewGetFramebufferParameterivEXT) -#define glGetMultiTexEnvfvEXT GLEW_GET_FUN(__glewGetMultiTexEnvfvEXT) -#define glGetMultiTexEnvivEXT GLEW_GET_FUN(__glewGetMultiTexEnvivEXT) -#define glGetMultiTexGendvEXT GLEW_GET_FUN(__glewGetMultiTexGendvEXT) -#define glGetMultiTexGenfvEXT GLEW_GET_FUN(__glewGetMultiTexGenfvEXT) -#define glGetMultiTexGenivEXT GLEW_GET_FUN(__glewGetMultiTexGenivEXT) -#define glGetMultiTexImageEXT GLEW_GET_FUN(__glewGetMultiTexImageEXT) -#define glGetMultiTexLevelParameterfvEXT GLEW_GET_FUN(__glewGetMultiTexLevelParameterfvEXT) -#define glGetMultiTexLevelParameterivEXT GLEW_GET_FUN(__glewGetMultiTexLevelParameterivEXT) -#define glGetMultiTexParameterIivEXT GLEW_GET_FUN(__glewGetMultiTexParameterIivEXT) -#define glGetMultiTexParameterIuivEXT GLEW_GET_FUN(__glewGetMultiTexParameterIuivEXT) -#define glGetMultiTexParameterfvEXT GLEW_GET_FUN(__glewGetMultiTexParameterfvEXT) -#define glGetMultiTexParameterivEXT GLEW_GET_FUN(__glewGetMultiTexParameterivEXT) -#define glGetNamedBufferParameterivEXT GLEW_GET_FUN(__glewGetNamedBufferParameterivEXT) -#define glGetNamedBufferPointervEXT GLEW_GET_FUN(__glewGetNamedBufferPointervEXT) -#define glGetNamedBufferSubDataEXT GLEW_GET_FUN(__glewGetNamedBufferSubDataEXT) -#define glGetNamedFramebufferAttachmentParameterivEXT GLEW_GET_FUN(__glewGetNamedFramebufferAttachmentParameterivEXT) -#define glGetNamedProgramLocalParameterIivEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterIivEXT) -#define glGetNamedProgramLocalParameterIuivEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterIuivEXT) -#define glGetNamedProgramLocalParameterdvEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterdvEXT) -#define glGetNamedProgramLocalParameterfvEXT GLEW_GET_FUN(__glewGetNamedProgramLocalParameterfvEXT) -#define glGetNamedProgramStringEXT GLEW_GET_FUN(__glewGetNamedProgramStringEXT) -#define glGetNamedProgramivEXT GLEW_GET_FUN(__glewGetNamedProgramivEXT) -#define glGetNamedRenderbufferParameterivEXT GLEW_GET_FUN(__glewGetNamedRenderbufferParameterivEXT) -#define glGetPointerIndexedvEXT GLEW_GET_FUN(__glewGetPointerIndexedvEXT) -#define glGetPointeri_vEXT GLEW_GET_FUN(__glewGetPointeri_vEXT) -#define glGetTextureImageEXT GLEW_GET_FUN(__glewGetTextureImageEXT) -#define glGetTextureLevelParameterfvEXT GLEW_GET_FUN(__glewGetTextureLevelParameterfvEXT) -#define glGetTextureLevelParameterivEXT GLEW_GET_FUN(__glewGetTextureLevelParameterivEXT) -#define glGetTextureParameterIivEXT GLEW_GET_FUN(__glewGetTextureParameterIivEXT) -#define glGetTextureParameterIuivEXT GLEW_GET_FUN(__glewGetTextureParameterIuivEXT) -#define glGetTextureParameterfvEXT GLEW_GET_FUN(__glewGetTextureParameterfvEXT) -#define glGetTextureParameterivEXT GLEW_GET_FUN(__glewGetTextureParameterivEXT) -#define glGetVertexArrayIntegeri_vEXT GLEW_GET_FUN(__glewGetVertexArrayIntegeri_vEXT) -#define glGetVertexArrayIntegervEXT GLEW_GET_FUN(__glewGetVertexArrayIntegervEXT) -#define glGetVertexArrayPointeri_vEXT GLEW_GET_FUN(__glewGetVertexArrayPointeri_vEXT) -#define glGetVertexArrayPointervEXT GLEW_GET_FUN(__glewGetVertexArrayPointervEXT) -#define glMapNamedBufferEXT GLEW_GET_FUN(__glewMapNamedBufferEXT) -#define glMapNamedBufferRangeEXT GLEW_GET_FUN(__glewMapNamedBufferRangeEXT) -#define glMatrixFrustumEXT GLEW_GET_FUN(__glewMatrixFrustumEXT) -#define glMatrixLoadIdentityEXT GLEW_GET_FUN(__glewMatrixLoadIdentityEXT) -#define glMatrixLoadTransposedEXT GLEW_GET_FUN(__glewMatrixLoadTransposedEXT) -#define glMatrixLoadTransposefEXT GLEW_GET_FUN(__glewMatrixLoadTransposefEXT) -#define glMatrixLoaddEXT GLEW_GET_FUN(__glewMatrixLoaddEXT) -#define glMatrixLoadfEXT GLEW_GET_FUN(__glewMatrixLoadfEXT) -#define glMatrixMultTransposedEXT GLEW_GET_FUN(__glewMatrixMultTransposedEXT) -#define glMatrixMultTransposefEXT GLEW_GET_FUN(__glewMatrixMultTransposefEXT) -#define glMatrixMultdEXT GLEW_GET_FUN(__glewMatrixMultdEXT) -#define glMatrixMultfEXT GLEW_GET_FUN(__glewMatrixMultfEXT) -#define glMatrixOrthoEXT GLEW_GET_FUN(__glewMatrixOrthoEXT) -#define glMatrixPopEXT GLEW_GET_FUN(__glewMatrixPopEXT) -#define glMatrixPushEXT GLEW_GET_FUN(__glewMatrixPushEXT) -#define glMatrixRotatedEXT GLEW_GET_FUN(__glewMatrixRotatedEXT) -#define glMatrixRotatefEXT GLEW_GET_FUN(__glewMatrixRotatefEXT) -#define glMatrixScaledEXT GLEW_GET_FUN(__glewMatrixScaledEXT) -#define glMatrixScalefEXT GLEW_GET_FUN(__glewMatrixScalefEXT) -#define glMatrixTranslatedEXT GLEW_GET_FUN(__glewMatrixTranslatedEXT) -#define glMatrixTranslatefEXT GLEW_GET_FUN(__glewMatrixTranslatefEXT) -#define glMultiTexBufferEXT GLEW_GET_FUN(__glewMultiTexBufferEXT) -#define glMultiTexCoordPointerEXT GLEW_GET_FUN(__glewMultiTexCoordPointerEXT) -#define glMultiTexEnvfEXT GLEW_GET_FUN(__glewMultiTexEnvfEXT) -#define glMultiTexEnvfvEXT GLEW_GET_FUN(__glewMultiTexEnvfvEXT) -#define glMultiTexEnviEXT GLEW_GET_FUN(__glewMultiTexEnviEXT) -#define glMultiTexEnvivEXT GLEW_GET_FUN(__glewMultiTexEnvivEXT) -#define glMultiTexGendEXT GLEW_GET_FUN(__glewMultiTexGendEXT) -#define glMultiTexGendvEXT GLEW_GET_FUN(__glewMultiTexGendvEXT) -#define glMultiTexGenfEXT GLEW_GET_FUN(__glewMultiTexGenfEXT) -#define glMultiTexGenfvEXT GLEW_GET_FUN(__glewMultiTexGenfvEXT) -#define glMultiTexGeniEXT GLEW_GET_FUN(__glewMultiTexGeniEXT) -#define glMultiTexGenivEXT GLEW_GET_FUN(__glewMultiTexGenivEXT) -#define glMultiTexImage1DEXT GLEW_GET_FUN(__glewMultiTexImage1DEXT) -#define glMultiTexImage2DEXT GLEW_GET_FUN(__glewMultiTexImage2DEXT) -#define glMultiTexImage3DEXT GLEW_GET_FUN(__glewMultiTexImage3DEXT) -#define glMultiTexParameterIivEXT GLEW_GET_FUN(__glewMultiTexParameterIivEXT) -#define glMultiTexParameterIuivEXT GLEW_GET_FUN(__glewMultiTexParameterIuivEXT) -#define glMultiTexParameterfEXT GLEW_GET_FUN(__glewMultiTexParameterfEXT) -#define glMultiTexParameterfvEXT GLEW_GET_FUN(__glewMultiTexParameterfvEXT) -#define glMultiTexParameteriEXT GLEW_GET_FUN(__glewMultiTexParameteriEXT) -#define glMultiTexParameterivEXT GLEW_GET_FUN(__glewMultiTexParameterivEXT) -#define glMultiTexRenderbufferEXT GLEW_GET_FUN(__glewMultiTexRenderbufferEXT) -#define glMultiTexSubImage1DEXT GLEW_GET_FUN(__glewMultiTexSubImage1DEXT) -#define glMultiTexSubImage2DEXT GLEW_GET_FUN(__glewMultiTexSubImage2DEXT) -#define glMultiTexSubImage3DEXT GLEW_GET_FUN(__glewMultiTexSubImage3DEXT) -#define glNamedBufferDataEXT GLEW_GET_FUN(__glewNamedBufferDataEXT) -#define glNamedBufferSubDataEXT GLEW_GET_FUN(__glewNamedBufferSubDataEXT) -#define glNamedCopyBufferSubDataEXT GLEW_GET_FUN(__glewNamedCopyBufferSubDataEXT) -#define glNamedFramebufferRenderbufferEXT GLEW_GET_FUN(__glewNamedFramebufferRenderbufferEXT) -#define glNamedFramebufferTexture1DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture1DEXT) -#define glNamedFramebufferTexture2DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture2DEXT) -#define glNamedFramebufferTexture3DEXT GLEW_GET_FUN(__glewNamedFramebufferTexture3DEXT) -#define glNamedFramebufferTextureEXT GLEW_GET_FUN(__glewNamedFramebufferTextureEXT) -#define glNamedFramebufferTextureFaceEXT GLEW_GET_FUN(__glewNamedFramebufferTextureFaceEXT) -#define glNamedFramebufferTextureLayerEXT GLEW_GET_FUN(__glewNamedFramebufferTextureLayerEXT) -#define glNamedProgramLocalParameter4dEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4dEXT) -#define glNamedProgramLocalParameter4dvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4dvEXT) -#define glNamedProgramLocalParameter4fEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4fEXT) -#define glNamedProgramLocalParameter4fvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameter4fvEXT) -#define glNamedProgramLocalParameterI4iEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4iEXT) -#define glNamedProgramLocalParameterI4ivEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4ivEXT) -#define glNamedProgramLocalParameterI4uiEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4uiEXT) -#define glNamedProgramLocalParameterI4uivEXT GLEW_GET_FUN(__glewNamedProgramLocalParameterI4uivEXT) -#define glNamedProgramLocalParameters4fvEXT GLEW_GET_FUN(__glewNamedProgramLocalParameters4fvEXT) -#define glNamedProgramLocalParametersI4ivEXT GLEW_GET_FUN(__glewNamedProgramLocalParametersI4ivEXT) -#define glNamedProgramLocalParametersI4uivEXT GLEW_GET_FUN(__glewNamedProgramLocalParametersI4uivEXT) -#define glNamedProgramStringEXT GLEW_GET_FUN(__glewNamedProgramStringEXT) -#define glNamedRenderbufferStorageEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageEXT) -#define glNamedRenderbufferStorageMultisampleCoverageEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageMultisampleCoverageEXT) -#define glNamedRenderbufferStorageMultisampleEXT GLEW_GET_FUN(__glewNamedRenderbufferStorageMultisampleEXT) -#define glProgramUniform1fEXT GLEW_GET_FUN(__glewProgramUniform1fEXT) -#define glProgramUniform1fvEXT GLEW_GET_FUN(__glewProgramUniform1fvEXT) -#define glProgramUniform1iEXT GLEW_GET_FUN(__glewProgramUniform1iEXT) -#define glProgramUniform1ivEXT GLEW_GET_FUN(__glewProgramUniform1ivEXT) -#define glProgramUniform1uiEXT GLEW_GET_FUN(__glewProgramUniform1uiEXT) -#define glProgramUniform1uivEXT GLEW_GET_FUN(__glewProgramUniform1uivEXT) -#define glProgramUniform2fEXT GLEW_GET_FUN(__glewProgramUniform2fEXT) -#define glProgramUniform2fvEXT GLEW_GET_FUN(__glewProgramUniform2fvEXT) -#define glProgramUniform2iEXT GLEW_GET_FUN(__glewProgramUniform2iEXT) -#define glProgramUniform2ivEXT GLEW_GET_FUN(__glewProgramUniform2ivEXT) -#define glProgramUniform2uiEXT GLEW_GET_FUN(__glewProgramUniform2uiEXT) -#define glProgramUniform2uivEXT GLEW_GET_FUN(__glewProgramUniform2uivEXT) -#define glProgramUniform3fEXT GLEW_GET_FUN(__glewProgramUniform3fEXT) -#define glProgramUniform3fvEXT GLEW_GET_FUN(__glewProgramUniform3fvEXT) -#define glProgramUniform3iEXT GLEW_GET_FUN(__glewProgramUniform3iEXT) -#define glProgramUniform3ivEXT GLEW_GET_FUN(__glewProgramUniform3ivEXT) -#define glProgramUniform3uiEXT GLEW_GET_FUN(__glewProgramUniform3uiEXT) -#define glProgramUniform3uivEXT GLEW_GET_FUN(__glewProgramUniform3uivEXT) -#define glProgramUniform4fEXT GLEW_GET_FUN(__glewProgramUniform4fEXT) -#define glProgramUniform4fvEXT GLEW_GET_FUN(__glewProgramUniform4fvEXT) -#define glProgramUniform4iEXT GLEW_GET_FUN(__glewProgramUniform4iEXT) -#define glProgramUniform4ivEXT GLEW_GET_FUN(__glewProgramUniform4ivEXT) -#define glProgramUniform4uiEXT GLEW_GET_FUN(__glewProgramUniform4uiEXT) -#define glProgramUniform4uivEXT GLEW_GET_FUN(__glewProgramUniform4uivEXT) -#define glProgramUniformMatrix2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2fvEXT) -#define glProgramUniformMatrix2x3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x3fvEXT) -#define glProgramUniformMatrix2x4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix2x4fvEXT) -#define glProgramUniformMatrix3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3fvEXT) -#define glProgramUniformMatrix3x2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x2fvEXT) -#define glProgramUniformMatrix3x4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix3x4fvEXT) -#define glProgramUniformMatrix4fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4fvEXT) -#define glProgramUniformMatrix4x2fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x2fvEXT) -#define glProgramUniformMatrix4x3fvEXT GLEW_GET_FUN(__glewProgramUniformMatrix4x3fvEXT) -#define glPushClientAttribDefaultEXT GLEW_GET_FUN(__glewPushClientAttribDefaultEXT) -#define glTextureBufferEXT GLEW_GET_FUN(__glewTextureBufferEXT) -#define glTextureImage1DEXT GLEW_GET_FUN(__glewTextureImage1DEXT) -#define glTextureImage2DEXT GLEW_GET_FUN(__glewTextureImage2DEXT) -#define glTextureImage3DEXT GLEW_GET_FUN(__glewTextureImage3DEXT) -#define glTextureParameterIivEXT GLEW_GET_FUN(__glewTextureParameterIivEXT) -#define glTextureParameterIuivEXT GLEW_GET_FUN(__glewTextureParameterIuivEXT) -#define glTextureParameterfEXT GLEW_GET_FUN(__glewTextureParameterfEXT) -#define glTextureParameterfvEXT GLEW_GET_FUN(__glewTextureParameterfvEXT) -#define glTextureParameteriEXT GLEW_GET_FUN(__glewTextureParameteriEXT) -#define glTextureParameterivEXT GLEW_GET_FUN(__glewTextureParameterivEXT) -#define glTextureRenderbufferEXT GLEW_GET_FUN(__glewTextureRenderbufferEXT) -#define glTextureSubImage1DEXT GLEW_GET_FUN(__glewTextureSubImage1DEXT) -#define glTextureSubImage2DEXT GLEW_GET_FUN(__glewTextureSubImage2DEXT) -#define glTextureSubImage3DEXT GLEW_GET_FUN(__glewTextureSubImage3DEXT) -#define glUnmapNamedBufferEXT GLEW_GET_FUN(__glewUnmapNamedBufferEXT) -#define glVertexArrayColorOffsetEXT GLEW_GET_FUN(__glewVertexArrayColorOffsetEXT) -#define glVertexArrayEdgeFlagOffsetEXT GLEW_GET_FUN(__glewVertexArrayEdgeFlagOffsetEXT) -#define glVertexArrayFogCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayFogCoordOffsetEXT) -#define glVertexArrayIndexOffsetEXT GLEW_GET_FUN(__glewVertexArrayIndexOffsetEXT) -#define glVertexArrayMultiTexCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayMultiTexCoordOffsetEXT) -#define glVertexArrayNormalOffsetEXT GLEW_GET_FUN(__glewVertexArrayNormalOffsetEXT) -#define glVertexArraySecondaryColorOffsetEXT GLEW_GET_FUN(__glewVertexArraySecondaryColorOffsetEXT) -#define glVertexArrayTexCoordOffsetEXT GLEW_GET_FUN(__glewVertexArrayTexCoordOffsetEXT) -#define glVertexArrayVertexAttribIOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribIOffsetEXT) -#define glVertexArrayVertexAttribOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribOffsetEXT) -#define glVertexArrayVertexOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexOffsetEXT) - -#define GLEW_EXT_direct_state_access GLEW_GET_VAR(__GLEW_EXT_direct_state_access) - -#endif /* GL_EXT_direct_state_access */ - -/* -------------------------- GL_EXT_draw_buffers2 ------------------------- */ - -#ifndef GL_EXT_draw_buffers2 -#define GL_EXT_draw_buffers2 1 - -typedef void (GLAPIENTRY * PFNGLCOLORMASKINDEXEDEXTPROC) (GLuint buf, GLboolean r, GLboolean g, GLboolean b, GLboolean a); -typedef void (GLAPIENTRY * PFNGLDISABLEINDEXEDEXTPROC) (GLenum target, GLuint index); -typedef void (GLAPIENTRY * PFNGLENABLEINDEXEDEXTPROC) (GLenum target, GLuint index); -typedef void (GLAPIENTRY * PFNGLGETBOOLEANINDEXEDVEXTPROC) (GLenum value, GLuint index, GLboolean* data); -typedef void (GLAPIENTRY * PFNGLGETINTEGERINDEXEDVEXTPROC) (GLenum value, GLuint index, GLint* data); -typedef GLboolean (GLAPIENTRY * PFNGLISENABLEDINDEXEDEXTPROC) (GLenum target, GLuint index); - -#define glColorMaskIndexedEXT GLEW_GET_FUN(__glewColorMaskIndexedEXT) -#define glDisableIndexedEXT GLEW_GET_FUN(__glewDisableIndexedEXT) -#define glEnableIndexedEXT GLEW_GET_FUN(__glewEnableIndexedEXT) -#define glGetBooleanIndexedvEXT GLEW_GET_FUN(__glewGetBooleanIndexedvEXT) -#define glGetIntegerIndexedvEXT GLEW_GET_FUN(__glewGetIntegerIndexedvEXT) -#define glIsEnabledIndexedEXT GLEW_GET_FUN(__glewIsEnabledIndexedEXT) - -#define GLEW_EXT_draw_buffers2 GLEW_GET_VAR(__GLEW_EXT_draw_buffers2) - -#endif /* GL_EXT_draw_buffers2 */ - -/* ------------------------- GL_EXT_draw_instanced ------------------------- */ - -#ifndef GL_EXT_draw_instanced -#define GL_EXT_draw_instanced 1 - -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSINSTANCEDEXTPROC) (GLenum mode, GLint start, GLsizei count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLDRAWELEMENTSINSTANCEDEXTPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount); - -#define glDrawArraysInstancedEXT GLEW_GET_FUN(__glewDrawArraysInstancedEXT) -#define glDrawElementsInstancedEXT GLEW_GET_FUN(__glewDrawElementsInstancedEXT) - -#define GLEW_EXT_draw_instanced GLEW_GET_VAR(__GLEW_EXT_draw_instanced) - -#endif /* GL_EXT_draw_instanced */ - -/* ----------------------- GL_EXT_draw_range_elements ---------------------- */ - -#ifndef GL_EXT_draw_range_elements -#define GL_EXT_draw_range_elements 1 - -#define GL_MAX_ELEMENTS_VERTICES_EXT 0x80E8 -#define GL_MAX_ELEMENTS_INDICES_EXT 0x80E9 - -typedef void (GLAPIENTRY * PFNGLDRAWRANGEELEMENTSEXTPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); - -#define glDrawRangeElementsEXT GLEW_GET_FUN(__glewDrawRangeElementsEXT) - -#define GLEW_EXT_draw_range_elements GLEW_GET_VAR(__GLEW_EXT_draw_range_elements) - -#endif /* GL_EXT_draw_range_elements */ - -/* ---------------------------- GL_EXT_fog_coord --------------------------- */ - -#ifndef GL_EXT_fog_coord -#define GL_EXT_fog_coord 1 - -#define GL_FOG_COORDINATE_SOURCE_EXT 0x8450 -#define GL_FOG_COORDINATE_EXT 0x8451 -#define GL_FRAGMENT_DEPTH_EXT 0x8452 -#define GL_CURRENT_FOG_COORDINATE_EXT 0x8453 -#define GL_FOG_COORDINATE_ARRAY_TYPE_EXT 0x8454 -#define GL_FOG_COORDINATE_ARRAY_STRIDE_EXT 0x8455 -#define GL_FOG_COORDINATE_ARRAY_POINTER_EXT 0x8456 -#define GL_FOG_COORDINATE_ARRAY_EXT 0x8457 - -typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTEREXTPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDEXTPROC) (GLdouble coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDDVEXTPROC) (const GLdouble *coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFEXTPROC) (GLfloat coord); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFVEXTPROC) (const GLfloat *coord); - -#define glFogCoordPointerEXT GLEW_GET_FUN(__glewFogCoordPointerEXT) -#define glFogCoorddEXT GLEW_GET_FUN(__glewFogCoorddEXT) -#define glFogCoorddvEXT GLEW_GET_FUN(__glewFogCoorddvEXT) -#define glFogCoordfEXT GLEW_GET_FUN(__glewFogCoordfEXT) -#define glFogCoordfvEXT GLEW_GET_FUN(__glewFogCoordfvEXT) - -#define GLEW_EXT_fog_coord GLEW_GET_VAR(__GLEW_EXT_fog_coord) - -#endif /* GL_EXT_fog_coord */ - -/* ------------------------ GL_EXT_fragment_lighting ----------------------- */ - -#ifndef GL_EXT_fragment_lighting -#define GL_EXT_fragment_lighting 1 - -#define GL_FRAGMENT_LIGHTING_EXT 0x8400 -#define GL_FRAGMENT_COLOR_MATERIAL_EXT 0x8401 -#define GL_FRAGMENT_COLOR_MATERIAL_FACE_EXT 0x8402 -#define GL_FRAGMENT_COLOR_MATERIAL_PARAMETER_EXT 0x8403 -#define GL_MAX_FRAGMENT_LIGHTS_EXT 0x8404 -#define GL_MAX_ACTIVE_LIGHTS_EXT 0x8405 -#define GL_CURRENT_RASTER_NORMAL_EXT 0x8406 -#define GL_LIGHT_ENV_MODE_EXT 0x8407 -#define GL_FRAGMENT_LIGHT_MODEL_LOCAL_VIEWER_EXT 0x8408 -#define GL_FRAGMENT_LIGHT_MODEL_TWO_SIDE_EXT 0x8409 -#define GL_FRAGMENT_LIGHT_MODEL_AMBIENT_EXT 0x840A -#define GL_FRAGMENT_LIGHT_MODEL_NORMAL_INTERPOLATION_EXT 0x840B -#define GL_FRAGMENT_LIGHT0_EXT 0x840C -#define GL_FRAGMENT_LIGHT7_EXT 0x8413 - -typedef void (GLAPIENTRY * PFNGLFRAGMENTCOLORMATERIALEXTPROC) (GLenum face, GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFEXTPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFVEXTPROC) (GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIEXTPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIVEXTPROC) (GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFEXTPROC) (GLenum light, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFVEXTPROC) (GLenum light, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIEXTPROC) (GLenum light, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIVEXTPROC) (GLenum light, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFEXTPROC) (GLenum face, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFVEXTPROC) (GLenum face, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIEXTPROC) (GLenum face, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIVEXTPROC) (GLenum face, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTFVEXTPROC) (GLenum light, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTIVEXTPROC) (GLenum light, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALFVEXTPROC) (GLenum face, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALIVEXTPROC) (GLenum face, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLLIGHTENVIEXTPROC) (GLenum pname, GLint param); - -#define glFragmentColorMaterialEXT GLEW_GET_FUN(__glewFragmentColorMaterialEXT) -#define glFragmentLightModelfEXT GLEW_GET_FUN(__glewFragmentLightModelfEXT) -#define glFragmentLightModelfvEXT GLEW_GET_FUN(__glewFragmentLightModelfvEXT) -#define glFragmentLightModeliEXT GLEW_GET_FUN(__glewFragmentLightModeliEXT) -#define glFragmentLightModelivEXT GLEW_GET_FUN(__glewFragmentLightModelivEXT) -#define glFragmentLightfEXT GLEW_GET_FUN(__glewFragmentLightfEXT) -#define glFragmentLightfvEXT GLEW_GET_FUN(__glewFragmentLightfvEXT) -#define glFragmentLightiEXT GLEW_GET_FUN(__glewFragmentLightiEXT) -#define glFragmentLightivEXT GLEW_GET_FUN(__glewFragmentLightivEXT) -#define glFragmentMaterialfEXT GLEW_GET_FUN(__glewFragmentMaterialfEXT) -#define glFragmentMaterialfvEXT GLEW_GET_FUN(__glewFragmentMaterialfvEXT) -#define glFragmentMaterialiEXT GLEW_GET_FUN(__glewFragmentMaterialiEXT) -#define glFragmentMaterialivEXT GLEW_GET_FUN(__glewFragmentMaterialivEXT) -#define glGetFragmentLightfvEXT GLEW_GET_FUN(__glewGetFragmentLightfvEXT) -#define glGetFragmentLightivEXT GLEW_GET_FUN(__glewGetFragmentLightivEXT) -#define glGetFragmentMaterialfvEXT GLEW_GET_FUN(__glewGetFragmentMaterialfvEXT) -#define glGetFragmentMaterialivEXT GLEW_GET_FUN(__glewGetFragmentMaterialivEXT) -#define glLightEnviEXT GLEW_GET_FUN(__glewLightEnviEXT) - -#define GLEW_EXT_fragment_lighting GLEW_GET_VAR(__GLEW_EXT_fragment_lighting) - -#endif /* GL_EXT_fragment_lighting */ - -/* ------------------------ GL_EXT_framebuffer_blit ------------------------ */ - -#ifndef GL_EXT_framebuffer_blit -#define GL_EXT_framebuffer_blit 1 - -#define GL_DRAW_FRAMEBUFFER_BINDING_EXT 0x8CA6 -#define GL_READ_FRAMEBUFFER_EXT 0x8CA8 -#define GL_DRAW_FRAMEBUFFER_EXT 0x8CA9 -#define GL_READ_FRAMEBUFFER_BINDING_EXT 0x8CAA - -typedef void (GLAPIENTRY * PFNGLBLITFRAMEBUFFEREXTPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); - -#define glBlitFramebufferEXT GLEW_GET_FUN(__glewBlitFramebufferEXT) - -#define GLEW_EXT_framebuffer_blit GLEW_GET_VAR(__GLEW_EXT_framebuffer_blit) - -#endif /* GL_EXT_framebuffer_blit */ - -/* --------------------- GL_EXT_framebuffer_multisample -------------------- */ - -#ifndef GL_EXT_framebuffer_multisample -#define GL_EXT_framebuffer_multisample 1 - -#define GL_RENDERBUFFER_SAMPLES_EXT 0x8CAB -#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_EXT 0x8D56 -#define GL_MAX_SAMPLES_EXT 0x8D57 - -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glRenderbufferStorageMultisampleEXT GLEW_GET_FUN(__glewRenderbufferStorageMultisampleEXT) - -#define GLEW_EXT_framebuffer_multisample GLEW_GET_VAR(__GLEW_EXT_framebuffer_multisample) - -#endif /* GL_EXT_framebuffer_multisample */ - -/* --------------- GL_EXT_framebuffer_multisample_blit_scaled -------------- */ - -#ifndef GL_EXT_framebuffer_multisample_blit_scaled -#define GL_EXT_framebuffer_multisample_blit_scaled 1 - -#define GL_SCALED_RESOLVE_FASTEST_EXT 0x90BA -#define GL_SCALED_RESOLVE_NICEST_EXT 0x90BB - -#define GLEW_EXT_framebuffer_multisample_blit_scaled GLEW_GET_VAR(__GLEW_EXT_framebuffer_multisample_blit_scaled) - -#endif /* GL_EXT_framebuffer_multisample_blit_scaled */ - -/* ----------------------- GL_EXT_framebuffer_object ----------------------- */ - -#ifndef GL_EXT_framebuffer_object -#define GL_EXT_framebuffer_object 1 - -#define GL_INVALID_FRAMEBUFFER_OPERATION_EXT 0x0506 -#define GL_MAX_RENDERBUFFER_SIZE_EXT 0x84E8 -#define GL_FRAMEBUFFER_BINDING_EXT 0x8CA6 -#define GL_RENDERBUFFER_BINDING_EXT 0x8CA7 -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE_EXT 0x8CD0 -#define GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME_EXT 0x8CD1 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL_EXT 0x8CD2 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE_EXT 0x8CD3 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET_EXT 0x8CD4 -#define GL_FRAMEBUFFER_COMPLETE_EXT 0x8CD5 -#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT_EXT 0x8CD6 -#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT_EXT 0x8CD7 -#define GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS_EXT 0x8CD9 -#define GL_FRAMEBUFFER_INCOMPLETE_FORMATS_EXT 0x8CDA -#define GL_FRAMEBUFFER_INCOMPLETE_DRAW_BUFFER_EXT 0x8CDB -#define GL_FRAMEBUFFER_INCOMPLETE_READ_BUFFER_EXT 0x8CDC -#define GL_FRAMEBUFFER_UNSUPPORTED_EXT 0x8CDD -#define GL_MAX_COLOR_ATTACHMENTS_EXT 0x8CDF -#define GL_COLOR_ATTACHMENT0_EXT 0x8CE0 -#define GL_COLOR_ATTACHMENT1_EXT 0x8CE1 -#define GL_COLOR_ATTACHMENT2_EXT 0x8CE2 -#define GL_COLOR_ATTACHMENT3_EXT 0x8CE3 -#define GL_COLOR_ATTACHMENT4_EXT 0x8CE4 -#define GL_COLOR_ATTACHMENT5_EXT 0x8CE5 -#define GL_COLOR_ATTACHMENT6_EXT 0x8CE6 -#define GL_COLOR_ATTACHMENT7_EXT 0x8CE7 -#define GL_COLOR_ATTACHMENT8_EXT 0x8CE8 -#define GL_COLOR_ATTACHMENT9_EXT 0x8CE9 -#define GL_COLOR_ATTACHMENT10_EXT 0x8CEA -#define GL_COLOR_ATTACHMENT11_EXT 0x8CEB -#define GL_COLOR_ATTACHMENT12_EXT 0x8CEC -#define GL_COLOR_ATTACHMENT13_EXT 0x8CED -#define GL_COLOR_ATTACHMENT14_EXT 0x8CEE -#define GL_COLOR_ATTACHMENT15_EXT 0x8CEF -#define GL_DEPTH_ATTACHMENT_EXT 0x8D00 -#define GL_STENCIL_ATTACHMENT_EXT 0x8D20 -#define GL_FRAMEBUFFER_EXT 0x8D40 -#define GL_RENDERBUFFER_EXT 0x8D41 -#define GL_RENDERBUFFER_WIDTH_EXT 0x8D42 -#define GL_RENDERBUFFER_HEIGHT_EXT 0x8D43 -#define GL_RENDERBUFFER_INTERNAL_FORMAT_EXT 0x8D44 -#define GL_STENCIL_INDEX1_EXT 0x8D46 -#define GL_STENCIL_INDEX4_EXT 0x8D47 -#define GL_STENCIL_INDEX8_EXT 0x8D48 -#define GL_STENCIL_INDEX16_EXT 0x8D49 -#define GL_RENDERBUFFER_RED_SIZE_EXT 0x8D50 -#define GL_RENDERBUFFER_GREEN_SIZE_EXT 0x8D51 -#define GL_RENDERBUFFER_BLUE_SIZE_EXT 0x8D52 -#define GL_RENDERBUFFER_ALPHA_SIZE_EXT 0x8D53 -#define GL_RENDERBUFFER_DEPTH_SIZE_EXT 0x8D54 -#define GL_RENDERBUFFER_STENCIL_SIZE_EXT 0x8D55 - -typedef void (GLAPIENTRY * PFNGLBINDFRAMEBUFFEREXTPROC) (GLenum target, GLuint framebuffer); -typedef void (GLAPIENTRY * PFNGLBINDRENDERBUFFEREXTPROC) (GLenum target, GLuint renderbuffer); -typedef GLenum (GLAPIENTRY * PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLDELETEFRAMEBUFFERSEXTPROC) (GLsizei n, const GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLDELETERENDERBUFFERSEXTPROC) (GLsizei n, const GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE1DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE2DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURE3DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); -typedef void (GLAPIENTRY * PFNGLGENFRAMEBUFFERSEXTPROC) (GLsizei n, GLuint* framebuffers); -typedef void (GLAPIENTRY * PFNGLGENRENDERBUFFERSEXTPROC) (GLsizei n, GLuint* renderbuffers); -typedef void (GLAPIENTRY * PFNGLGENERATEMIPMAPEXTPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLenum target, GLenum attachment, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISFRAMEBUFFEREXTPROC) (GLuint framebuffer); -typedef GLboolean (GLAPIENTRY * PFNGLISRENDERBUFFEREXTPROC) (GLuint renderbuffer); -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); - -#define glBindFramebufferEXT GLEW_GET_FUN(__glewBindFramebufferEXT) -#define glBindRenderbufferEXT GLEW_GET_FUN(__glewBindRenderbufferEXT) -#define glCheckFramebufferStatusEXT GLEW_GET_FUN(__glewCheckFramebufferStatusEXT) -#define glDeleteFramebuffersEXT GLEW_GET_FUN(__glewDeleteFramebuffersEXT) -#define glDeleteRenderbuffersEXT GLEW_GET_FUN(__glewDeleteRenderbuffersEXT) -#define glFramebufferRenderbufferEXT GLEW_GET_FUN(__glewFramebufferRenderbufferEXT) -#define glFramebufferTexture1DEXT GLEW_GET_FUN(__glewFramebufferTexture1DEXT) -#define glFramebufferTexture2DEXT GLEW_GET_FUN(__glewFramebufferTexture2DEXT) -#define glFramebufferTexture3DEXT GLEW_GET_FUN(__glewFramebufferTexture3DEXT) -#define glGenFramebuffersEXT GLEW_GET_FUN(__glewGenFramebuffersEXT) -#define glGenRenderbuffersEXT GLEW_GET_FUN(__glewGenRenderbuffersEXT) -#define glGenerateMipmapEXT GLEW_GET_FUN(__glewGenerateMipmapEXT) -#define glGetFramebufferAttachmentParameterivEXT GLEW_GET_FUN(__glewGetFramebufferAttachmentParameterivEXT) -#define glGetRenderbufferParameterivEXT GLEW_GET_FUN(__glewGetRenderbufferParameterivEXT) -#define glIsFramebufferEXT GLEW_GET_FUN(__glewIsFramebufferEXT) -#define glIsRenderbufferEXT GLEW_GET_FUN(__glewIsRenderbufferEXT) -#define glRenderbufferStorageEXT GLEW_GET_FUN(__glewRenderbufferStorageEXT) - -#define GLEW_EXT_framebuffer_object GLEW_GET_VAR(__GLEW_EXT_framebuffer_object) - -#endif /* GL_EXT_framebuffer_object */ - -/* ------------------------ GL_EXT_framebuffer_sRGB ------------------------ */ - -#ifndef GL_EXT_framebuffer_sRGB -#define GL_EXT_framebuffer_sRGB 1 - -#define GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 -#define GL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x8DBA - -#define GLEW_EXT_framebuffer_sRGB GLEW_GET_VAR(__GLEW_EXT_framebuffer_sRGB) - -#endif /* GL_EXT_framebuffer_sRGB */ - -/* ------------------------ GL_EXT_geometry_shader4 ------------------------ */ - -#ifndef GL_EXT_geometry_shader4 -#define GL_EXT_geometry_shader4 1 - -#define GL_LINES_ADJACENCY_EXT 0xA -#define GL_LINE_STRIP_ADJACENCY_EXT 0xB -#define GL_TRIANGLES_ADJACENCY_EXT 0xC -#define GL_TRIANGLE_STRIP_ADJACENCY_EXT 0xD -#define GL_PROGRAM_POINT_SIZE_EXT 0x8642 -#define GL_MAX_VARYING_COMPONENTS_EXT 0x8B4B -#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_EXT 0x8C29 -#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER_EXT 0x8CD4 -#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_EXT 0x8DA7 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_EXT 0x8DA8 -#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_EXT 0x8DA9 -#define GL_GEOMETRY_SHADER_EXT 0x8DD9 -#define GL_GEOMETRY_VERTICES_OUT_EXT 0x8DDA -#define GL_GEOMETRY_INPUT_TYPE_EXT 0x8DDB -#define GL_GEOMETRY_OUTPUT_TYPE_EXT 0x8DDC -#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_EXT 0x8DDD -#define GL_MAX_VERTEX_VARYING_COMPONENTS_EXT 0x8DDE -#define GL_MAX_GEOMETRY_UNIFORM_COMPONENTS_EXT 0x8DDF -#define GL_MAX_GEOMETRY_OUTPUT_VERTICES_EXT 0x8DE0 -#define GL_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS_EXT 0x8DE1 - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERIEXTPROC) (GLuint program, GLenum pname, GLint value); - -#define glFramebufferTextureEXT GLEW_GET_FUN(__glewFramebufferTextureEXT) -#define glFramebufferTextureFaceEXT GLEW_GET_FUN(__glewFramebufferTextureFaceEXT) -#define glProgramParameteriEXT GLEW_GET_FUN(__glewProgramParameteriEXT) - -#define GLEW_EXT_geometry_shader4 GLEW_GET_VAR(__GLEW_EXT_geometry_shader4) - -#endif /* GL_EXT_geometry_shader4 */ - -/* --------------------- GL_EXT_gpu_program_parameters --------------------- */ - -#ifndef GL_EXT_gpu_program_parameters -#define GL_EXT_gpu_program_parameters 1 - -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat* params); - -#define glProgramEnvParameters4fvEXT GLEW_GET_FUN(__glewProgramEnvParameters4fvEXT) -#define glProgramLocalParameters4fvEXT GLEW_GET_FUN(__glewProgramLocalParameters4fvEXT) - -#define GLEW_EXT_gpu_program_parameters GLEW_GET_VAR(__GLEW_EXT_gpu_program_parameters) - -#endif /* GL_EXT_gpu_program_parameters */ - -/* --------------------------- GL_EXT_gpu_shader4 -------------------------- */ - -#ifndef GL_EXT_gpu_shader4 -#define GL_EXT_gpu_shader4 1 - -#define GL_VERTEX_ATTRIB_ARRAY_INTEGER_EXT 0x88FD -#define GL_SAMPLER_1D_ARRAY_EXT 0x8DC0 -#define GL_SAMPLER_2D_ARRAY_EXT 0x8DC1 -#define GL_SAMPLER_BUFFER_EXT 0x8DC2 -#define GL_SAMPLER_1D_ARRAY_SHADOW_EXT 0x8DC3 -#define GL_SAMPLER_2D_ARRAY_SHADOW_EXT 0x8DC4 -#define GL_SAMPLER_CUBE_SHADOW_EXT 0x8DC5 -#define GL_UNSIGNED_INT_VEC2_EXT 0x8DC6 -#define GL_UNSIGNED_INT_VEC3_EXT 0x8DC7 -#define GL_UNSIGNED_INT_VEC4_EXT 0x8DC8 -#define GL_INT_SAMPLER_1D_EXT 0x8DC9 -#define GL_INT_SAMPLER_2D_EXT 0x8DCA -#define GL_INT_SAMPLER_3D_EXT 0x8DCB -#define GL_INT_SAMPLER_CUBE_EXT 0x8DCC -#define GL_INT_SAMPLER_2D_RECT_EXT 0x8DCD -#define GL_INT_SAMPLER_1D_ARRAY_EXT 0x8DCE -#define GL_INT_SAMPLER_2D_ARRAY_EXT 0x8DCF -#define GL_INT_SAMPLER_BUFFER_EXT 0x8DD0 -#define GL_UNSIGNED_INT_SAMPLER_1D_EXT 0x8DD1 -#define GL_UNSIGNED_INT_SAMPLER_2D_EXT 0x8DD2 -#define GL_UNSIGNED_INT_SAMPLER_3D_EXT 0x8DD3 -#define GL_UNSIGNED_INT_SAMPLER_CUBE_EXT 0x8DD4 -#define GL_UNSIGNED_INT_SAMPLER_2D_RECT_EXT 0x8DD5 -#define GL_UNSIGNED_INT_SAMPLER_1D_ARRAY_EXT 0x8DD6 -#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY_EXT 0x8DD7 -#define GL_UNSIGNED_INT_SAMPLER_BUFFER_EXT 0x8DD8 - -typedef void (GLAPIENTRY * PFNGLBINDFRAGDATALOCATIONEXTPROC) (GLuint program, GLuint color, const GLchar *name); -typedef GLint (GLAPIENTRY * PFNGLGETFRAGDATALOCATIONEXTPROC) (GLuint program, const GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMUIVEXTPROC) (GLuint program, GLint location, GLuint *params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIIVEXTPROC) (GLuint index, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIUIVEXTPROC) (GLuint index, GLenum pname, GLuint *params); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIEXTPROC) (GLint location, GLuint v0); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIEXTPROC) (GLint location, GLuint v0, GLuint v1); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IEXTPROC) (GLuint index, GLint x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIEXTPROC) (GLuint index, GLuint x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI1UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IEXTPROC) (GLuint index, GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIEXTPROC) (GLuint index, GLuint x, GLuint y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI2UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IEXTPROC) (GLuint index, GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI3UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4BVEXTPROC) (GLuint index, const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IEXTPROC) (GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4IVEXTPROC) (GLuint index, const GLint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4SVEXTPROC) (GLuint index, const GLshort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UBVEXTPROC) (GLuint index, const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4UIVEXTPROC) (GLuint index, const GLuint *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBI4USVEXTPROC) (GLuint index, const GLushort *v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); - -#define glBindFragDataLocationEXT GLEW_GET_FUN(__glewBindFragDataLocationEXT) -#define glGetFragDataLocationEXT GLEW_GET_FUN(__glewGetFragDataLocationEXT) -#define glGetUniformuivEXT GLEW_GET_FUN(__glewGetUniformuivEXT) -#define glGetVertexAttribIivEXT GLEW_GET_FUN(__glewGetVertexAttribIivEXT) -#define glGetVertexAttribIuivEXT GLEW_GET_FUN(__glewGetVertexAttribIuivEXT) -#define glUniform1uiEXT GLEW_GET_FUN(__glewUniform1uiEXT) -#define glUniform1uivEXT GLEW_GET_FUN(__glewUniform1uivEXT) -#define glUniform2uiEXT GLEW_GET_FUN(__glewUniform2uiEXT) -#define glUniform2uivEXT GLEW_GET_FUN(__glewUniform2uivEXT) -#define glUniform3uiEXT GLEW_GET_FUN(__glewUniform3uiEXT) -#define glUniform3uivEXT GLEW_GET_FUN(__glewUniform3uivEXT) -#define glUniform4uiEXT GLEW_GET_FUN(__glewUniform4uiEXT) -#define glUniform4uivEXT GLEW_GET_FUN(__glewUniform4uivEXT) -#define glVertexAttribI1iEXT GLEW_GET_FUN(__glewVertexAttribI1iEXT) -#define glVertexAttribI1ivEXT GLEW_GET_FUN(__glewVertexAttribI1ivEXT) -#define glVertexAttribI1uiEXT GLEW_GET_FUN(__glewVertexAttribI1uiEXT) -#define glVertexAttribI1uivEXT GLEW_GET_FUN(__glewVertexAttribI1uivEXT) -#define glVertexAttribI2iEXT GLEW_GET_FUN(__glewVertexAttribI2iEXT) -#define glVertexAttribI2ivEXT GLEW_GET_FUN(__glewVertexAttribI2ivEXT) -#define glVertexAttribI2uiEXT GLEW_GET_FUN(__glewVertexAttribI2uiEXT) -#define glVertexAttribI2uivEXT GLEW_GET_FUN(__glewVertexAttribI2uivEXT) -#define glVertexAttribI3iEXT GLEW_GET_FUN(__glewVertexAttribI3iEXT) -#define glVertexAttribI3ivEXT GLEW_GET_FUN(__glewVertexAttribI3ivEXT) -#define glVertexAttribI3uiEXT GLEW_GET_FUN(__glewVertexAttribI3uiEXT) -#define glVertexAttribI3uivEXT GLEW_GET_FUN(__glewVertexAttribI3uivEXT) -#define glVertexAttribI4bvEXT GLEW_GET_FUN(__glewVertexAttribI4bvEXT) -#define glVertexAttribI4iEXT GLEW_GET_FUN(__glewVertexAttribI4iEXT) -#define glVertexAttribI4ivEXT GLEW_GET_FUN(__glewVertexAttribI4ivEXT) -#define glVertexAttribI4svEXT GLEW_GET_FUN(__glewVertexAttribI4svEXT) -#define glVertexAttribI4ubvEXT GLEW_GET_FUN(__glewVertexAttribI4ubvEXT) -#define glVertexAttribI4uiEXT GLEW_GET_FUN(__glewVertexAttribI4uiEXT) -#define glVertexAttribI4uivEXT GLEW_GET_FUN(__glewVertexAttribI4uivEXT) -#define glVertexAttribI4usvEXT GLEW_GET_FUN(__glewVertexAttribI4usvEXT) -#define glVertexAttribIPointerEXT GLEW_GET_FUN(__glewVertexAttribIPointerEXT) - -#define GLEW_EXT_gpu_shader4 GLEW_GET_VAR(__GLEW_EXT_gpu_shader4) - -#endif /* GL_EXT_gpu_shader4 */ - -/* ---------------------------- GL_EXT_histogram --------------------------- */ - -#ifndef GL_EXT_histogram -#define GL_EXT_histogram 1 - -#define GL_HISTOGRAM_EXT 0x8024 -#define GL_PROXY_HISTOGRAM_EXT 0x8025 -#define GL_HISTOGRAM_WIDTH_EXT 0x8026 -#define GL_HISTOGRAM_FORMAT_EXT 0x8027 -#define GL_HISTOGRAM_RED_SIZE_EXT 0x8028 -#define GL_HISTOGRAM_GREEN_SIZE_EXT 0x8029 -#define GL_HISTOGRAM_BLUE_SIZE_EXT 0x802A -#define GL_HISTOGRAM_ALPHA_SIZE_EXT 0x802B -#define GL_HISTOGRAM_LUMINANCE_SIZE_EXT 0x802C -#define GL_HISTOGRAM_SINK_EXT 0x802D -#define GL_MINMAX_EXT 0x802E -#define GL_MINMAX_FORMAT_EXT 0x802F -#define GL_MINMAX_SINK_EXT 0x8030 - -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETHISTOGRAMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLvoid *values); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMINMAXPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLHISTOGRAMEXTPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLMINMAXEXTPROC) (GLenum target, GLenum internalformat, GLboolean sink); -typedef void (GLAPIENTRY * PFNGLRESETHISTOGRAMEXTPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLRESETMINMAXEXTPROC) (GLenum target); - -#define glGetHistogramEXT GLEW_GET_FUN(__glewGetHistogramEXT) -#define glGetHistogramParameterfvEXT GLEW_GET_FUN(__glewGetHistogramParameterfvEXT) -#define glGetHistogramParameterivEXT GLEW_GET_FUN(__glewGetHistogramParameterivEXT) -#define glGetMinmaxEXT GLEW_GET_FUN(__glewGetMinmaxEXT) -#define glGetMinmaxParameterfvEXT GLEW_GET_FUN(__glewGetMinmaxParameterfvEXT) -#define glGetMinmaxParameterivEXT GLEW_GET_FUN(__glewGetMinmaxParameterivEXT) -#define glHistogramEXT GLEW_GET_FUN(__glewHistogramEXT) -#define glMinmaxEXT GLEW_GET_FUN(__glewMinmaxEXT) -#define glResetHistogramEXT GLEW_GET_FUN(__glewResetHistogramEXT) -#define glResetMinmaxEXT GLEW_GET_FUN(__glewResetMinmaxEXT) - -#define GLEW_EXT_histogram GLEW_GET_VAR(__GLEW_EXT_histogram) - -#endif /* GL_EXT_histogram */ - -/* ----------------------- GL_EXT_index_array_formats ---------------------- */ - -#ifndef GL_EXT_index_array_formats -#define GL_EXT_index_array_formats 1 - -#define GLEW_EXT_index_array_formats GLEW_GET_VAR(__GLEW_EXT_index_array_formats) - -#endif /* GL_EXT_index_array_formats */ - -/* --------------------------- GL_EXT_index_func --------------------------- */ - -#ifndef GL_EXT_index_func -#define GL_EXT_index_func 1 - -typedef void (GLAPIENTRY * PFNGLINDEXFUNCEXTPROC) (GLenum func, GLfloat ref); - -#define glIndexFuncEXT GLEW_GET_FUN(__glewIndexFuncEXT) - -#define GLEW_EXT_index_func GLEW_GET_VAR(__GLEW_EXT_index_func) - -#endif /* GL_EXT_index_func */ - -/* ------------------------- GL_EXT_index_material ------------------------- */ - -#ifndef GL_EXT_index_material -#define GL_EXT_index_material 1 - -typedef void (GLAPIENTRY * PFNGLINDEXMATERIALEXTPROC) (GLenum face, GLenum mode); - -#define glIndexMaterialEXT GLEW_GET_FUN(__glewIndexMaterialEXT) - -#define GLEW_EXT_index_material GLEW_GET_VAR(__GLEW_EXT_index_material) - -#endif /* GL_EXT_index_material */ - -/* -------------------------- GL_EXT_index_texture ------------------------- */ - -#ifndef GL_EXT_index_texture -#define GL_EXT_index_texture 1 - -#define GLEW_EXT_index_texture GLEW_GET_VAR(__GLEW_EXT_index_texture) - -#endif /* GL_EXT_index_texture */ - -/* -------------------------- GL_EXT_light_texture ------------------------- */ - -#ifndef GL_EXT_light_texture -#define GL_EXT_light_texture 1 - -#define GL_FRAGMENT_MATERIAL_EXT 0x8349 -#define GL_FRAGMENT_NORMAL_EXT 0x834A -#define GL_FRAGMENT_COLOR_EXT 0x834C -#define GL_ATTENUATION_EXT 0x834D -#define GL_SHADOW_ATTENUATION_EXT 0x834E -#define GL_TEXTURE_APPLICATION_MODE_EXT 0x834F -#define GL_TEXTURE_LIGHT_EXT 0x8350 -#define GL_TEXTURE_MATERIAL_FACE_EXT 0x8351 -#define GL_TEXTURE_MATERIAL_PARAMETER_EXT 0x8352 - -typedef void (GLAPIENTRY * PFNGLAPPLYTEXTUREEXTPROC) (GLenum mode); -typedef void (GLAPIENTRY * PFNGLTEXTURELIGHTEXTPROC) (GLenum pname); -typedef void (GLAPIENTRY * PFNGLTEXTUREMATERIALEXTPROC) (GLenum face, GLenum mode); - -#define glApplyTextureEXT GLEW_GET_FUN(__glewApplyTextureEXT) -#define glTextureLightEXT GLEW_GET_FUN(__glewTextureLightEXT) -#define glTextureMaterialEXT GLEW_GET_FUN(__glewTextureMaterialEXT) - -#define GLEW_EXT_light_texture GLEW_GET_VAR(__GLEW_EXT_light_texture) - -#endif /* GL_EXT_light_texture */ - -/* ------------------------- GL_EXT_misc_attribute ------------------------- */ - -#ifndef GL_EXT_misc_attribute -#define GL_EXT_misc_attribute 1 - -#define GLEW_EXT_misc_attribute GLEW_GET_VAR(__GLEW_EXT_misc_attribute) - -#endif /* GL_EXT_misc_attribute */ - -/* ------------------------ GL_EXT_multi_draw_arrays ----------------------- */ - -#ifndef GL_EXT_multi_draw_arrays -#define GL_EXT_multi_draw_arrays 1 - -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, const GLint* first, const GLsizei *count, GLsizei primcount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, GLsizei* count, GLenum type, const GLvoid * const *indices, GLsizei primcount); - -#define glMultiDrawArraysEXT GLEW_GET_FUN(__glewMultiDrawArraysEXT) -#define glMultiDrawElementsEXT GLEW_GET_FUN(__glewMultiDrawElementsEXT) - -#define GLEW_EXT_multi_draw_arrays GLEW_GET_VAR(__GLEW_EXT_multi_draw_arrays) - -#endif /* GL_EXT_multi_draw_arrays */ - -/* --------------------------- GL_EXT_multisample -------------------------- */ - -#ifndef GL_EXT_multisample -#define GL_EXT_multisample 1 - -#define GL_MULTISAMPLE_EXT 0x809D -#define GL_SAMPLE_ALPHA_TO_MASK_EXT 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_EXT 0x809F -#define GL_SAMPLE_MASK_EXT 0x80A0 -#define GL_1PASS_EXT 0x80A1 -#define GL_2PASS_0_EXT 0x80A2 -#define GL_2PASS_1_EXT 0x80A3 -#define GL_4PASS_0_EXT 0x80A4 -#define GL_4PASS_1_EXT 0x80A5 -#define GL_4PASS_2_EXT 0x80A6 -#define GL_4PASS_3_EXT 0x80A7 -#define GL_SAMPLE_BUFFERS_EXT 0x80A8 -#define GL_SAMPLES_EXT 0x80A9 -#define GL_SAMPLE_MASK_VALUE_EXT 0x80AA -#define GL_SAMPLE_MASK_INVERT_EXT 0x80AB -#define GL_SAMPLE_PATTERN_EXT 0x80AC -#define GL_MULTISAMPLE_BIT_EXT 0x20000000 - -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKEXTPROC) (GLclampf value, GLboolean invert); -typedef void (GLAPIENTRY * PFNGLSAMPLEPATTERNEXTPROC) (GLenum pattern); - -#define glSampleMaskEXT GLEW_GET_FUN(__glewSampleMaskEXT) -#define glSamplePatternEXT GLEW_GET_FUN(__glewSamplePatternEXT) - -#define GLEW_EXT_multisample GLEW_GET_VAR(__GLEW_EXT_multisample) - -#endif /* GL_EXT_multisample */ - -/* ---------------------- GL_EXT_packed_depth_stencil ---------------------- */ - -#ifndef GL_EXT_packed_depth_stencil -#define GL_EXT_packed_depth_stencil 1 - -#define GL_DEPTH_STENCIL_EXT 0x84F9 -#define GL_UNSIGNED_INT_24_8_EXT 0x84FA -#define GL_DEPTH24_STENCIL8_EXT 0x88F0 -#define GL_TEXTURE_STENCIL_SIZE_EXT 0x88F1 - -#define GLEW_EXT_packed_depth_stencil GLEW_GET_VAR(__GLEW_EXT_packed_depth_stencil) - -#endif /* GL_EXT_packed_depth_stencil */ - -/* -------------------------- GL_EXT_packed_float -------------------------- */ - -#ifndef GL_EXT_packed_float -#define GL_EXT_packed_float 1 - -#define GL_R11F_G11F_B10F_EXT 0x8C3A -#define GL_UNSIGNED_INT_10F_11F_11F_REV_EXT 0x8C3B -#define GL_RGBA_SIGNED_COMPONENTS_EXT 0x8C3C - -#define GLEW_EXT_packed_float GLEW_GET_VAR(__GLEW_EXT_packed_float) - -#endif /* GL_EXT_packed_float */ - -/* -------------------------- GL_EXT_packed_pixels ------------------------- */ - -#ifndef GL_EXT_packed_pixels -#define GL_EXT_packed_pixels 1 - -#define GL_UNSIGNED_BYTE_3_3_2_EXT 0x8032 -#define GL_UNSIGNED_SHORT_4_4_4_4_EXT 0x8033 -#define GL_UNSIGNED_SHORT_5_5_5_1_EXT 0x8034 -#define GL_UNSIGNED_INT_8_8_8_8_EXT 0x8035 -#define GL_UNSIGNED_INT_10_10_10_2_EXT 0x8036 - -#define GLEW_EXT_packed_pixels GLEW_GET_VAR(__GLEW_EXT_packed_pixels) - -#endif /* GL_EXT_packed_pixels */ - -/* ------------------------ GL_EXT_paletted_texture ------------------------ */ - -#ifndef GL_EXT_paletted_texture -#define GL_EXT_paletted_texture 1 - -#define GL_TEXTURE_1D 0x0DE0 -#define GL_TEXTURE_2D 0x0DE1 -#define GL_PROXY_TEXTURE_1D 0x8063 -#define GL_PROXY_TEXTURE_2D 0x8064 -#define GL_COLOR_TABLE_FORMAT_EXT 0x80D8 -#define GL_COLOR_TABLE_WIDTH_EXT 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE_EXT 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE_EXT 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE_EXT 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE_EXT 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE_EXT 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE_EXT 0x80DF -#define GL_COLOR_INDEX1_EXT 0x80E2 -#define GL_COLOR_INDEX2_EXT 0x80E3 -#define GL_COLOR_INDEX4_EXT 0x80E4 -#define GL_COLOR_INDEX8_EXT 0x80E5 -#define GL_COLOR_INDEX12_EXT 0x80E6 -#define GL_COLOR_INDEX16_EXT 0x80E7 -#define GL_TEXTURE_INDEX_SIZE_EXT 0x80ED -#define GL_TEXTURE_CUBE_MAP_ARB 0x8513 -#define GL_PROXY_TEXTURE_CUBE_MAP_ARB 0x851B - -typedef void (GLAPIENTRY * PFNGLCOLORTABLEEXTPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEEXTPROC) (GLenum target, GLenum format, GLenum type, GLvoid *data); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint* params); - -#define glColorTableEXT GLEW_GET_FUN(__glewColorTableEXT) -#define glGetColorTableEXT GLEW_GET_FUN(__glewGetColorTableEXT) -#define glGetColorTableParameterfvEXT GLEW_GET_FUN(__glewGetColorTableParameterfvEXT) -#define glGetColorTableParameterivEXT GLEW_GET_FUN(__glewGetColorTableParameterivEXT) - -#define GLEW_EXT_paletted_texture GLEW_GET_VAR(__GLEW_EXT_paletted_texture) - -#endif /* GL_EXT_paletted_texture */ - -/* ----------------------- GL_EXT_pixel_buffer_object ---------------------- */ - -#ifndef GL_EXT_pixel_buffer_object -#define GL_EXT_pixel_buffer_object 1 - -#define GL_PIXEL_PACK_BUFFER_EXT 0x88EB -#define GL_PIXEL_UNPACK_BUFFER_EXT 0x88EC -#define GL_PIXEL_PACK_BUFFER_BINDING_EXT 0x88ED -#define GL_PIXEL_UNPACK_BUFFER_BINDING_EXT 0x88EF - -#define GLEW_EXT_pixel_buffer_object GLEW_GET_VAR(__GLEW_EXT_pixel_buffer_object) - -#endif /* GL_EXT_pixel_buffer_object */ - -/* ------------------------- GL_EXT_pixel_transform ------------------------ */ - -#ifndef GL_EXT_pixel_transform -#define GL_EXT_pixel_transform 1 - -#define GL_PIXEL_TRANSFORM_2D_EXT 0x8330 -#define GL_PIXEL_MAG_FILTER_EXT 0x8331 -#define GL_PIXEL_MIN_FILTER_EXT 0x8332 -#define GL_PIXEL_CUBIC_WEIGHT_EXT 0x8333 -#define GL_CUBIC_EXT 0x8334 -#define GL_AVERAGE_EXT 0x8335 -#define GL_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8336 -#define GL_MAX_PIXEL_TRANSFORM_2D_STACK_DEPTH_EXT 0x8337 -#define GL_PIXEL_TRANSFORM_2D_MATRIX_EXT 0x8338 - -typedef void (GLAPIENTRY * PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERFEXTPROC) (GLenum target, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERIEXTPROC) (GLenum target, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint* params); - -#define glGetPixelTransformParameterfvEXT GLEW_GET_FUN(__glewGetPixelTransformParameterfvEXT) -#define glGetPixelTransformParameterivEXT GLEW_GET_FUN(__glewGetPixelTransformParameterivEXT) -#define glPixelTransformParameterfEXT GLEW_GET_FUN(__glewPixelTransformParameterfEXT) -#define glPixelTransformParameterfvEXT GLEW_GET_FUN(__glewPixelTransformParameterfvEXT) -#define glPixelTransformParameteriEXT GLEW_GET_FUN(__glewPixelTransformParameteriEXT) -#define glPixelTransformParameterivEXT GLEW_GET_FUN(__glewPixelTransformParameterivEXT) - -#define GLEW_EXT_pixel_transform GLEW_GET_VAR(__GLEW_EXT_pixel_transform) - -#endif /* GL_EXT_pixel_transform */ - -/* ------------------- GL_EXT_pixel_transform_color_table ------------------ */ - -#ifndef GL_EXT_pixel_transform_color_table -#define GL_EXT_pixel_transform_color_table 1 - -#define GLEW_EXT_pixel_transform_color_table GLEW_GET_VAR(__GLEW_EXT_pixel_transform_color_table) - -#endif /* GL_EXT_pixel_transform_color_table */ - -/* ------------------------ GL_EXT_point_parameters ------------------------ */ - -#ifndef GL_EXT_point_parameters -#define GL_EXT_point_parameters 1 - -#define GL_POINT_SIZE_MIN_EXT 0x8126 -#define GL_POINT_SIZE_MAX_EXT 0x8127 -#define GL_POINT_FADE_THRESHOLD_SIZE_EXT 0x8128 -#define GL_DISTANCE_ATTENUATION_EXT 0x8129 - -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFEXTPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERFVEXTPROC) (GLenum pname, const GLfloat* params); - -#define glPointParameterfEXT GLEW_GET_FUN(__glewPointParameterfEXT) -#define glPointParameterfvEXT GLEW_GET_FUN(__glewPointParameterfvEXT) - -#define GLEW_EXT_point_parameters GLEW_GET_VAR(__GLEW_EXT_point_parameters) - -#endif /* GL_EXT_point_parameters */ - -/* ------------------------- GL_EXT_polygon_offset ------------------------- */ - -#ifndef GL_EXT_polygon_offset -#define GL_EXT_polygon_offset 1 - -#define GL_POLYGON_OFFSET_EXT 0x8037 -#define GL_POLYGON_OFFSET_FACTOR_EXT 0x8038 -#define GL_POLYGON_OFFSET_BIAS_EXT 0x8039 - -typedef void (GLAPIENTRY * PFNGLPOLYGONOFFSETEXTPROC) (GLfloat factor, GLfloat bias); - -#define glPolygonOffsetEXT GLEW_GET_FUN(__glewPolygonOffsetEXT) - -#define GLEW_EXT_polygon_offset GLEW_GET_VAR(__GLEW_EXT_polygon_offset) - -#endif /* GL_EXT_polygon_offset */ - -/* ------------------------ GL_EXT_provoking_vertex ------------------------ */ - -#ifndef GL_EXT_provoking_vertex -#define GL_EXT_provoking_vertex 1 - -#define GL_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION_EXT 0x8E4C -#define GL_FIRST_VERTEX_CONVENTION_EXT 0x8E4D -#define GL_LAST_VERTEX_CONVENTION_EXT 0x8E4E -#define GL_PROVOKING_VERTEX_EXT 0x8E4F - -typedef void (GLAPIENTRY * PFNGLPROVOKINGVERTEXEXTPROC) (GLenum mode); - -#define glProvokingVertexEXT GLEW_GET_FUN(__glewProvokingVertexEXT) - -#define GLEW_EXT_provoking_vertex GLEW_GET_VAR(__GLEW_EXT_provoking_vertex) - -#endif /* GL_EXT_provoking_vertex */ - -/* ------------------------- GL_EXT_rescale_normal ------------------------- */ - -#ifndef GL_EXT_rescale_normal -#define GL_EXT_rescale_normal 1 - -#define GL_RESCALE_NORMAL_EXT 0x803A - -#define GLEW_EXT_rescale_normal GLEW_GET_VAR(__GLEW_EXT_rescale_normal) - -#endif /* GL_EXT_rescale_normal */ - -/* -------------------------- GL_EXT_scene_marker -------------------------- */ - -#ifndef GL_EXT_scene_marker -#define GL_EXT_scene_marker 1 - -typedef void (GLAPIENTRY * PFNGLBEGINSCENEEXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLENDSCENEEXTPROC) (void); - -#define glBeginSceneEXT GLEW_GET_FUN(__glewBeginSceneEXT) -#define glEndSceneEXT GLEW_GET_FUN(__glewEndSceneEXT) - -#define GLEW_EXT_scene_marker GLEW_GET_VAR(__GLEW_EXT_scene_marker) - -#endif /* GL_EXT_scene_marker */ - -/* ------------------------- GL_EXT_secondary_color ------------------------ */ - -#ifndef GL_EXT_secondary_color -#define GL_EXT_secondary_color 1 - -#define GL_COLOR_SUM_EXT 0x8458 -#define GL_CURRENT_SECONDARY_COLOR_EXT 0x8459 -#define GL_SECONDARY_COLOR_ARRAY_SIZE_EXT 0x845A -#define GL_SECONDARY_COLOR_ARRAY_TYPE_EXT 0x845B -#define GL_SECONDARY_COLOR_ARRAY_STRIDE_EXT 0x845C -#define GL_SECONDARY_COLOR_ARRAY_POINTER_EXT 0x845D -#define GL_SECONDARY_COLOR_ARRAY_EXT 0x845E - -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BEXTPROC) (GLbyte red, GLbyte green, GLbyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3BVEXTPROC) (const GLbyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DEXTPROC) (GLdouble red, GLdouble green, GLdouble blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3DVEXTPROC) (const GLdouble *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FEXTPROC) (GLfloat red, GLfloat green, GLfloat blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3FVEXTPROC) (const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IEXTPROC) (GLint red, GLint green, GLint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3IVEXTPROC) (const GLint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SEXTPROC) (GLshort red, GLshort green, GLshort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3SVEXTPROC) (const GLshort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBEXTPROC) (GLubyte red, GLubyte green, GLubyte blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UBVEXTPROC) (const GLubyte *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIEXTPROC) (GLuint red, GLuint green, GLuint blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3UIVEXTPROC) (const GLuint *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USEXTPROC) (GLushort red, GLushort green, GLushort blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3USVEXTPROC) (const GLushort *v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); - -#define glSecondaryColor3bEXT GLEW_GET_FUN(__glewSecondaryColor3bEXT) -#define glSecondaryColor3bvEXT GLEW_GET_FUN(__glewSecondaryColor3bvEXT) -#define glSecondaryColor3dEXT GLEW_GET_FUN(__glewSecondaryColor3dEXT) -#define glSecondaryColor3dvEXT GLEW_GET_FUN(__glewSecondaryColor3dvEXT) -#define glSecondaryColor3fEXT GLEW_GET_FUN(__glewSecondaryColor3fEXT) -#define glSecondaryColor3fvEXT GLEW_GET_FUN(__glewSecondaryColor3fvEXT) -#define glSecondaryColor3iEXT GLEW_GET_FUN(__glewSecondaryColor3iEXT) -#define glSecondaryColor3ivEXT GLEW_GET_FUN(__glewSecondaryColor3ivEXT) -#define glSecondaryColor3sEXT GLEW_GET_FUN(__glewSecondaryColor3sEXT) -#define glSecondaryColor3svEXT GLEW_GET_FUN(__glewSecondaryColor3svEXT) -#define glSecondaryColor3ubEXT GLEW_GET_FUN(__glewSecondaryColor3ubEXT) -#define glSecondaryColor3ubvEXT GLEW_GET_FUN(__glewSecondaryColor3ubvEXT) -#define glSecondaryColor3uiEXT GLEW_GET_FUN(__glewSecondaryColor3uiEXT) -#define glSecondaryColor3uivEXT GLEW_GET_FUN(__glewSecondaryColor3uivEXT) -#define glSecondaryColor3usEXT GLEW_GET_FUN(__glewSecondaryColor3usEXT) -#define glSecondaryColor3usvEXT GLEW_GET_FUN(__glewSecondaryColor3usvEXT) -#define glSecondaryColorPointerEXT GLEW_GET_FUN(__glewSecondaryColorPointerEXT) - -#define GLEW_EXT_secondary_color GLEW_GET_VAR(__GLEW_EXT_secondary_color) - -#endif /* GL_EXT_secondary_color */ - -/* --------------------- GL_EXT_separate_shader_objects -------------------- */ - -#ifndef GL_EXT_separate_shader_objects -#define GL_EXT_separate_shader_objects 1 - -#define GL_ACTIVE_PROGRAM_EXT 0x8B8D - -typedef void (GLAPIENTRY * PFNGLACTIVEPROGRAMEXTPROC) (GLuint program); -typedef GLuint (GLAPIENTRY * PFNGLCREATESHADERPROGRAMEXTPROC) (GLenum type, const GLchar* string); -typedef void (GLAPIENTRY * PFNGLUSESHADERPROGRAMEXTPROC) (GLenum type, GLuint program); - -#define glActiveProgramEXT GLEW_GET_FUN(__glewActiveProgramEXT) -#define glCreateShaderProgramEXT GLEW_GET_FUN(__glewCreateShaderProgramEXT) -#define glUseShaderProgramEXT GLEW_GET_FUN(__glewUseShaderProgramEXT) - -#define GLEW_EXT_separate_shader_objects GLEW_GET_VAR(__GLEW_EXT_separate_shader_objects) - -#endif /* GL_EXT_separate_shader_objects */ - -/* --------------------- GL_EXT_separate_specular_color -------------------- */ - -#ifndef GL_EXT_separate_specular_color -#define GL_EXT_separate_specular_color 1 - -#define GL_LIGHT_MODEL_COLOR_CONTROL_EXT 0x81F8 -#define GL_SINGLE_COLOR_EXT 0x81F9 -#define GL_SEPARATE_SPECULAR_COLOR_EXT 0x81FA - -#define GLEW_EXT_separate_specular_color GLEW_GET_VAR(__GLEW_EXT_separate_specular_color) - -#endif /* GL_EXT_separate_specular_color */ - -/* --------------------- GL_EXT_shader_image_load_store -------------------- */ - -#ifndef GL_EXT_shader_image_load_store -#define GL_EXT_shader_image_load_store 1 - -#define GL_VERTEX_ATTRIB_ARRAY_BARRIER_BIT_EXT 0x00000001 -#define GL_ELEMENT_ARRAY_BARRIER_BIT_EXT 0x00000002 -#define GL_UNIFORM_BARRIER_BIT_EXT 0x00000004 -#define GL_TEXTURE_FETCH_BARRIER_BIT_EXT 0x00000008 -#define GL_SHADER_IMAGE_ACCESS_BARRIER_BIT_EXT 0x00000020 -#define GL_COMMAND_BARRIER_BIT_EXT 0x00000040 -#define GL_PIXEL_BUFFER_BARRIER_BIT_EXT 0x00000080 -#define GL_TEXTURE_UPDATE_BARRIER_BIT_EXT 0x00000100 -#define GL_BUFFER_UPDATE_BARRIER_BIT_EXT 0x00000200 -#define GL_FRAMEBUFFER_BARRIER_BIT_EXT 0x00000400 -#define GL_TRANSFORM_FEEDBACK_BARRIER_BIT_EXT 0x00000800 -#define GL_ATOMIC_COUNTER_BARRIER_BIT_EXT 0x00001000 -#define GL_MAX_IMAGE_UNITS_EXT 0x8F38 -#define GL_MAX_COMBINED_IMAGE_UNITS_AND_FRAGMENT_OUTPUTS_EXT 0x8F39 -#define GL_IMAGE_BINDING_NAME_EXT 0x8F3A -#define GL_IMAGE_BINDING_LEVEL_EXT 0x8F3B -#define GL_IMAGE_BINDING_LAYERED_EXT 0x8F3C -#define GL_IMAGE_BINDING_LAYER_EXT 0x8F3D -#define GL_IMAGE_BINDING_ACCESS_EXT 0x8F3E -#define GL_IMAGE_1D_EXT 0x904C -#define GL_IMAGE_2D_EXT 0x904D -#define GL_IMAGE_3D_EXT 0x904E -#define GL_IMAGE_2D_RECT_EXT 0x904F -#define GL_IMAGE_CUBE_EXT 0x9050 -#define GL_IMAGE_BUFFER_EXT 0x9051 -#define GL_IMAGE_1D_ARRAY_EXT 0x9052 -#define GL_IMAGE_2D_ARRAY_EXT 0x9053 -#define GL_IMAGE_CUBE_MAP_ARRAY_EXT 0x9054 -#define GL_IMAGE_2D_MULTISAMPLE_EXT 0x9055 -#define GL_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9056 -#define GL_INT_IMAGE_1D_EXT 0x9057 -#define GL_INT_IMAGE_2D_EXT 0x9058 -#define GL_INT_IMAGE_3D_EXT 0x9059 -#define GL_INT_IMAGE_2D_RECT_EXT 0x905A -#define GL_INT_IMAGE_CUBE_EXT 0x905B -#define GL_INT_IMAGE_BUFFER_EXT 0x905C -#define GL_INT_IMAGE_1D_ARRAY_EXT 0x905D -#define GL_INT_IMAGE_2D_ARRAY_EXT 0x905E -#define GL_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x905F -#define GL_INT_IMAGE_2D_MULTISAMPLE_EXT 0x9060 -#define GL_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x9061 -#define GL_UNSIGNED_INT_IMAGE_1D_EXT 0x9062 -#define GL_UNSIGNED_INT_IMAGE_2D_EXT 0x9063 -#define GL_UNSIGNED_INT_IMAGE_3D_EXT 0x9064 -#define GL_UNSIGNED_INT_IMAGE_2D_RECT_EXT 0x9065 -#define GL_UNSIGNED_INT_IMAGE_CUBE_EXT 0x9066 -#define GL_UNSIGNED_INT_IMAGE_BUFFER_EXT 0x9067 -#define GL_UNSIGNED_INT_IMAGE_1D_ARRAY_EXT 0x9068 -#define GL_UNSIGNED_INT_IMAGE_2D_ARRAY_EXT 0x9069 -#define GL_UNSIGNED_INT_IMAGE_CUBE_MAP_ARRAY_EXT 0x906A -#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_EXT 0x906B -#define GL_UNSIGNED_INT_IMAGE_2D_MULTISAMPLE_ARRAY_EXT 0x906C -#define GL_MAX_IMAGE_SAMPLES_EXT 0x906D -#define GL_IMAGE_BINDING_FORMAT_EXT 0x906E -#define GL_ALL_BARRIER_BITS_EXT 0xFFFFFFFF - -typedef void (GLAPIENTRY * PFNGLBINDIMAGETEXTUREEXTPROC) (GLuint index, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLint format); -typedef void (GLAPIENTRY * PFNGLMEMORYBARRIEREXTPROC) (GLbitfield barriers); - -#define glBindImageTextureEXT GLEW_GET_FUN(__glewBindImageTextureEXT) -#define glMemoryBarrierEXT GLEW_GET_FUN(__glewMemoryBarrierEXT) - -#define GLEW_EXT_shader_image_load_store GLEW_GET_VAR(__GLEW_EXT_shader_image_load_store) - -#endif /* GL_EXT_shader_image_load_store */ - -/* -------------------------- GL_EXT_shadow_funcs -------------------------- */ - -#ifndef GL_EXT_shadow_funcs -#define GL_EXT_shadow_funcs 1 - -#define GLEW_EXT_shadow_funcs GLEW_GET_VAR(__GLEW_EXT_shadow_funcs) - -#endif /* GL_EXT_shadow_funcs */ - -/* --------------------- GL_EXT_shared_texture_palette --------------------- */ - -#ifndef GL_EXT_shared_texture_palette -#define GL_EXT_shared_texture_palette 1 - -#define GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB - -#define GLEW_EXT_shared_texture_palette GLEW_GET_VAR(__GLEW_EXT_shared_texture_palette) - -#endif /* GL_EXT_shared_texture_palette */ - -/* ------------------------ GL_EXT_stencil_clear_tag ----------------------- */ - -#ifndef GL_EXT_stencil_clear_tag -#define GL_EXT_stencil_clear_tag 1 - -#define GL_STENCIL_TAG_BITS_EXT 0x88F2 -#define GL_STENCIL_CLEAR_TAG_VALUE_EXT 0x88F3 - -#define GLEW_EXT_stencil_clear_tag GLEW_GET_VAR(__GLEW_EXT_stencil_clear_tag) - -#endif /* GL_EXT_stencil_clear_tag */ - -/* ------------------------ GL_EXT_stencil_two_side ------------------------ */ - -#ifndef GL_EXT_stencil_two_side -#define GL_EXT_stencil_two_side 1 - -#define GL_STENCIL_TEST_TWO_SIDE_EXT 0x8910 -#define GL_ACTIVE_STENCIL_FACE_EXT 0x8911 - -typedef void (GLAPIENTRY * PFNGLACTIVESTENCILFACEEXTPROC) (GLenum face); - -#define glActiveStencilFaceEXT GLEW_GET_FUN(__glewActiveStencilFaceEXT) - -#define GLEW_EXT_stencil_two_side GLEW_GET_VAR(__GLEW_EXT_stencil_two_side) - -#endif /* GL_EXT_stencil_two_side */ - -/* -------------------------- GL_EXT_stencil_wrap -------------------------- */ - -#ifndef GL_EXT_stencil_wrap -#define GL_EXT_stencil_wrap 1 - -#define GL_INCR_WRAP_EXT 0x8507 -#define GL_DECR_WRAP_EXT 0x8508 - -#define GLEW_EXT_stencil_wrap GLEW_GET_VAR(__GLEW_EXT_stencil_wrap) - -#endif /* GL_EXT_stencil_wrap */ - -/* --------------------------- GL_EXT_subtexture --------------------------- */ - -#ifndef GL_EXT_subtexture -#define GL_EXT_subtexture 1 - -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid *pixels); - -#define glTexSubImage1DEXT GLEW_GET_FUN(__glewTexSubImage1DEXT) -#define glTexSubImage2DEXT GLEW_GET_FUN(__glewTexSubImage2DEXT) -#define glTexSubImage3DEXT GLEW_GET_FUN(__glewTexSubImage3DEXT) - -#define GLEW_EXT_subtexture GLEW_GET_VAR(__GLEW_EXT_subtexture) - -#endif /* GL_EXT_subtexture */ - -/* ----------------------------- GL_EXT_texture ---------------------------- */ - -#ifndef GL_EXT_texture -#define GL_EXT_texture 1 - -#define GL_ALPHA4_EXT 0x803B -#define GL_ALPHA8_EXT 0x803C -#define GL_ALPHA12_EXT 0x803D -#define GL_ALPHA16_EXT 0x803E -#define GL_LUMINANCE4_EXT 0x803F -#define GL_LUMINANCE8_EXT 0x8040 -#define GL_LUMINANCE12_EXT 0x8041 -#define GL_LUMINANCE16_EXT 0x8042 -#define GL_LUMINANCE4_ALPHA4_EXT 0x8043 -#define GL_LUMINANCE6_ALPHA2_EXT 0x8044 -#define GL_LUMINANCE8_ALPHA8_EXT 0x8045 -#define GL_LUMINANCE12_ALPHA4_EXT 0x8046 -#define GL_LUMINANCE12_ALPHA12_EXT 0x8047 -#define GL_LUMINANCE16_ALPHA16_EXT 0x8048 -#define GL_INTENSITY_EXT 0x8049 -#define GL_INTENSITY4_EXT 0x804A -#define GL_INTENSITY8_EXT 0x804B -#define GL_INTENSITY12_EXT 0x804C -#define GL_INTENSITY16_EXT 0x804D -#define GL_RGB2_EXT 0x804E -#define GL_RGB4_EXT 0x804F -#define GL_RGB5_EXT 0x8050 -#define GL_RGB8_EXT 0x8051 -#define GL_RGB10_EXT 0x8052 -#define GL_RGB12_EXT 0x8053 -#define GL_RGB16_EXT 0x8054 -#define GL_RGBA2_EXT 0x8055 -#define GL_RGBA4_EXT 0x8056 -#define GL_RGB5_A1_EXT 0x8057 -#define GL_RGBA8_EXT 0x8058 -#define GL_RGB10_A2_EXT 0x8059 -#define GL_RGBA12_EXT 0x805A -#define GL_RGBA16_EXT 0x805B -#define GL_TEXTURE_RED_SIZE_EXT 0x805C -#define GL_TEXTURE_GREEN_SIZE_EXT 0x805D -#define GL_TEXTURE_BLUE_SIZE_EXT 0x805E -#define GL_TEXTURE_ALPHA_SIZE_EXT 0x805F -#define GL_TEXTURE_LUMINANCE_SIZE_EXT 0x8060 -#define GL_TEXTURE_INTENSITY_SIZE_EXT 0x8061 -#define GL_REPLACE_EXT 0x8062 -#define GL_PROXY_TEXTURE_1D_EXT 0x8063 -#define GL_PROXY_TEXTURE_2D_EXT 0x8064 - -#define GLEW_EXT_texture GLEW_GET_VAR(__GLEW_EXT_texture) - -#endif /* GL_EXT_texture */ - -/* ---------------------------- GL_EXT_texture3D --------------------------- */ - -#ifndef GL_EXT_texture3D -#define GL_EXT_texture3D 1 - -#define GL_PACK_SKIP_IMAGES_EXT 0x806B -#define GL_PACK_IMAGE_HEIGHT_EXT 0x806C -#define GL_UNPACK_SKIP_IMAGES_EXT 0x806D -#define GL_UNPACK_IMAGE_HEIGHT_EXT 0x806E -#define GL_TEXTURE_3D_EXT 0x806F -#define GL_PROXY_TEXTURE_3D_EXT 0x8070 -#define GL_TEXTURE_DEPTH_EXT 0x8071 -#define GL_TEXTURE_WRAP_R_EXT 0x8072 -#define GL_MAX_3D_TEXTURE_SIZE_EXT 0x8073 - -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); - -#define glTexImage3DEXT GLEW_GET_FUN(__glewTexImage3DEXT) - -#define GLEW_EXT_texture3D GLEW_GET_VAR(__GLEW_EXT_texture3D) - -#endif /* GL_EXT_texture3D */ - -/* -------------------------- GL_EXT_texture_array ------------------------- */ - -#ifndef GL_EXT_texture_array -#define GL_EXT_texture_array 1 - -#define GL_COMPARE_REF_DEPTH_TO_TEXTURE_EXT 0x884E -#define GL_MAX_ARRAY_TEXTURE_LAYERS_EXT 0x88FF -#define GL_TEXTURE_1D_ARRAY_EXT 0x8C18 -#define GL_PROXY_TEXTURE_1D_ARRAY_EXT 0x8C19 -#define GL_TEXTURE_2D_ARRAY_EXT 0x8C1A -#define GL_PROXY_TEXTURE_2D_ARRAY_EXT 0x8C1B -#define GL_TEXTURE_BINDING_1D_ARRAY_EXT 0x8C1C -#define GL_TEXTURE_BINDING_2D_ARRAY_EXT 0x8C1D - -typedef void (GLAPIENTRY * PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); - -#define glFramebufferTextureLayerEXT GLEW_GET_FUN(__glewFramebufferTextureLayerEXT) - -#define GLEW_EXT_texture_array GLEW_GET_VAR(__GLEW_EXT_texture_array) - -#endif /* GL_EXT_texture_array */ - -/* ---------------------- GL_EXT_texture_buffer_object --------------------- */ - -#ifndef GL_EXT_texture_buffer_object -#define GL_EXT_texture_buffer_object 1 - -#define GL_TEXTURE_BUFFER_EXT 0x8C2A -#define GL_MAX_TEXTURE_BUFFER_SIZE_EXT 0x8C2B -#define GL_TEXTURE_BINDING_BUFFER_EXT 0x8C2C -#define GL_TEXTURE_BUFFER_DATA_STORE_BINDING_EXT 0x8C2D -#define GL_TEXTURE_BUFFER_FORMAT_EXT 0x8C2E - -typedef void (GLAPIENTRY * PFNGLTEXBUFFEREXTPROC) (GLenum target, GLenum internalformat, GLuint buffer); - -#define glTexBufferEXT GLEW_GET_FUN(__glewTexBufferEXT) - -#define GLEW_EXT_texture_buffer_object GLEW_GET_VAR(__GLEW_EXT_texture_buffer_object) - -#endif /* GL_EXT_texture_buffer_object */ - -/* -------------------- GL_EXT_texture_compression_dxt1 -------------------- */ - -#ifndef GL_EXT_texture_compression_dxt1 -#define GL_EXT_texture_compression_dxt1 1 - -#define GLEW_EXT_texture_compression_dxt1 GLEW_GET_VAR(__GLEW_EXT_texture_compression_dxt1) - -#endif /* GL_EXT_texture_compression_dxt1 */ - -/* -------------------- GL_EXT_texture_compression_latc -------------------- */ - -#ifndef GL_EXT_texture_compression_latc -#define GL_EXT_texture_compression_latc 1 - -#define GL_COMPRESSED_LUMINANCE_LATC1_EXT 0x8C70 -#define GL_COMPRESSED_SIGNED_LUMINANCE_LATC1_EXT 0x8C71 -#define GL_COMPRESSED_LUMINANCE_ALPHA_LATC2_EXT 0x8C72 -#define GL_COMPRESSED_SIGNED_LUMINANCE_ALPHA_LATC2_EXT 0x8C73 - -#define GLEW_EXT_texture_compression_latc GLEW_GET_VAR(__GLEW_EXT_texture_compression_latc) - -#endif /* GL_EXT_texture_compression_latc */ - -/* -------------------- GL_EXT_texture_compression_rgtc -------------------- */ - -#ifndef GL_EXT_texture_compression_rgtc -#define GL_EXT_texture_compression_rgtc 1 - -#define GL_COMPRESSED_RED_RGTC1_EXT 0x8DBB -#define GL_COMPRESSED_SIGNED_RED_RGTC1_EXT 0x8DBC -#define GL_COMPRESSED_RED_GREEN_RGTC2_EXT 0x8DBD -#define GL_COMPRESSED_SIGNED_RED_GREEN_RGTC2_EXT 0x8DBE - -#define GLEW_EXT_texture_compression_rgtc GLEW_GET_VAR(__GLEW_EXT_texture_compression_rgtc) - -#endif /* GL_EXT_texture_compression_rgtc */ - -/* -------------------- GL_EXT_texture_compression_s3tc -------------------- */ - -#ifndef GL_EXT_texture_compression_s3tc -#define GL_EXT_texture_compression_s3tc 1 - -#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 -#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 -#define GL_COMPRESSED_RGBA_S3TC_DXT3_EXT 0x83F2 -#define GL_COMPRESSED_RGBA_S3TC_DXT5_EXT 0x83F3 - -#define GLEW_EXT_texture_compression_s3tc GLEW_GET_VAR(__GLEW_EXT_texture_compression_s3tc) - -#endif /* GL_EXT_texture_compression_s3tc */ - -/* ------------------------ GL_EXT_texture_cube_map ------------------------ */ - -#ifndef GL_EXT_texture_cube_map -#define GL_EXT_texture_cube_map 1 - -#define GL_NORMAL_MAP_EXT 0x8511 -#define GL_REFLECTION_MAP_EXT 0x8512 -#define GL_TEXTURE_CUBE_MAP_EXT 0x8513 -#define GL_TEXTURE_BINDING_CUBE_MAP_EXT 0x8514 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_X_EXT 0x8515 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_X_EXT 0x8516 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Y_EXT 0x8517 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_EXT 0x8518 -#define GL_TEXTURE_CUBE_MAP_POSITIVE_Z_EXT 0x8519 -#define GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_EXT 0x851A -#define GL_PROXY_TEXTURE_CUBE_MAP_EXT 0x851B -#define GL_MAX_CUBE_MAP_TEXTURE_SIZE_EXT 0x851C - -#define GLEW_EXT_texture_cube_map GLEW_GET_VAR(__GLEW_EXT_texture_cube_map) - -#endif /* GL_EXT_texture_cube_map */ - -/* ----------------------- GL_EXT_texture_edge_clamp ----------------------- */ - -#ifndef GL_EXT_texture_edge_clamp -#define GL_EXT_texture_edge_clamp 1 - -#define GL_CLAMP_TO_EDGE_EXT 0x812F - -#define GLEW_EXT_texture_edge_clamp GLEW_GET_VAR(__GLEW_EXT_texture_edge_clamp) - -#endif /* GL_EXT_texture_edge_clamp */ - -/* --------------------------- GL_EXT_texture_env -------------------------- */ - -#ifndef GL_EXT_texture_env -#define GL_EXT_texture_env 1 - -#define GLEW_EXT_texture_env GLEW_GET_VAR(__GLEW_EXT_texture_env) - -#endif /* GL_EXT_texture_env */ - -/* ------------------------- GL_EXT_texture_env_add ------------------------ */ - -#ifndef GL_EXT_texture_env_add -#define GL_EXT_texture_env_add 1 - -#define GLEW_EXT_texture_env_add GLEW_GET_VAR(__GLEW_EXT_texture_env_add) - -#endif /* GL_EXT_texture_env_add */ - -/* ----------------------- GL_EXT_texture_env_combine ---------------------- */ - -#ifndef GL_EXT_texture_env_combine -#define GL_EXT_texture_env_combine 1 - -#define GL_COMBINE_EXT 0x8570 -#define GL_COMBINE_RGB_EXT 0x8571 -#define GL_COMBINE_ALPHA_EXT 0x8572 -#define GL_RGB_SCALE_EXT 0x8573 -#define GL_ADD_SIGNED_EXT 0x8574 -#define GL_INTERPOLATE_EXT 0x8575 -#define GL_CONSTANT_EXT 0x8576 -#define GL_PRIMARY_COLOR_EXT 0x8577 -#define GL_PREVIOUS_EXT 0x8578 -#define GL_SOURCE0_RGB_EXT 0x8580 -#define GL_SOURCE1_RGB_EXT 0x8581 -#define GL_SOURCE2_RGB_EXT 0x8582 -#define GL_SOURCE0_ALPHA_EXT 0x8588 -#define GL_SOURCE1_ALPHA_EXT 0x8589 -#define GL_SOURCE2_ALPHA_EXT 0x858A -#define GL_OPERAND0_RGB_EXT 0x8590 -#define GL_OPERAND1_RGB_EXT 0x8591 -#define GL_OPERAND2_RGB_EXT 0x8592 -#define GL_OPERAND0_ALPHA_EXT 0x8598 -#define GL_OPERAND1_ALPHA_EXT 0x8599 -#define GL_OPERAND2_ALPHA_EXT 0x859A - -#define GLEW_EXT_texture_env_combine GLEW_GET_VAR(__GLEW_EXT_texture_env_combine) - -#endif /* GL_EXT_texture_env_combine */ - -/* ------------------------ GL_EXT_texture_env_dot3 ------------------------ */ - -#ifndef GL_EXT_texture_env_dot3 -#define GL_EXT_texture_env_dot3 1 - -#define GL_DOT3_RGB_EXT 0x8740 -#define GL_DOT3_RGBA_EXT 0x8741 - -#define GLEW_EXT_texture_env_dot3 GLEW_GET_VAR(__GLEW_EXT_texture_env_dot3) - -#endif /* GL_EXT_texture_env_dot3 */ - -/* ------------------- GL_EXT_texture_filter_anisotropic ------------------- */ - -#ifndef GL_EXT_texture_filter_anisotropic -#define GL_EXT_texture_filter_anisotropic 1 - -#define GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE -#define GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF - -#define GLEW_EXT_texture_filter_anisotropic GLEW_GET_VAR(__GLEW_EXT_texture_filter_anisotropic) - -#endif /* GL_EXT_texture_filter_anisotropic */ - -/* ------------------------- GL_EXT_texture_integer ------------------------ */ - -#ifndef GL_EXT_texture_integer -#define GL_EXT_texture_integer 1 - -#define GL_RGBA32UI_EXT 0x8D70 -#define GL_RGB32UI_EXT 0x8D71 -#define GL_ALPHA32UI_EXT 0x8D72 -#define GL_INTENSITY32UI_EXT 0x8D73 -#define GL_LUMINANCE32UI_EXT 0x8D74 -#define GL_LUMINANCE_ALPHA32UI_EXT 0x8D75 -#define GL_RGBA16UI_EXT 0x8D76 -#define GL_RGB16UI_EXT 0x8D77 -#define GL_ALPHA16UI_EXT 0x8D78 -#define GL_INTENSITY16UI_EXT 0x8D79 -#define GL_LUMINANCE16UI_EXT 0x8D7A -#define GL_LUMINANCE_ALPHA16UI_EXT 0x8D7B -#define GL_RGBA8UI_EXT 0x8D7C -#define GL_RGB8UI_EXT 0x8D7D -#define GL_ALPHA8UI_EXT 0x8D7E -#define GL_INTENSITY8UI_EXT 0x8D7F -#define GL_LUMINANCE8UI_EXT 0x8D80 -#define GL_LUMINANCE_ALPHA8UI_EXT 0x8D81 -#define GL_RGBA32I_EXT 0x8D82 -#define GL_RGB32I_EXT 0x8D83 -#define GL_ALPHA32I_EXT 0x8D84 -#define GL_INTENSITY32I_EXT 0x8D85 -#define GL_LUMINANCE32I_EXT 0x8D86 -#define GL_LUMINANCE_ALPHA32I_EXT 0x8D87 -#define GL_RGBA16I_EXT 0x8D88 -#define GL_RGB16I_EXT 0x8D89 -#define GL_ALPHA16I_EXT 0x8D8A -#define GL_INTENSITY16I_EXT 0x8D8B -#define GL_LUMINANCE16I_EXT 0x8D8C -#define GL_LUMINANCE_ALPHA16I_EXT 0x8D8D -#define GL_RGBA8I_EXT 0x8D8E -#define GL_RGB8I_EXT 0x8D8F -#define GL_ALPHA8I_EXT 0x8D90 -#define GL_INTENSITY8I_EXT 0x8D91 -#define GL_LUMINANCE8I_EXT 0x8D92 -#define GL_LUMINANCE_ALPHA8I_EXT 0x8D93 -#define GL_RED_INTEGER_EXT 0x8D94 -#define GL_GREEN_INTEGER_EXT 0x8D95 -#define GL_BLUE_INTEGER_EXT 0x8D96 -#define GL_ALPHA_INTEGER_EXT 0x8D97 -#define GL_RGB_INTEGER_EXT 0x8D98 -#define GL_RGBA_INTEGER_EXT 0x8D99 -#define GL_BGR_INTEGER_EXT 0x8D9A -#define GL_BGRA_INTEGER_EXT 0x8D9B -#define GL_LUMINANCE_INTEGER_EXT 0x8D9C -#define GL_LUMINANCE_ALPHA_INTEGER_EXT 0x8D9D -#define GL_RGBA_INTEGER_MODE_EXT 0x8D9E - -typedef void (GLAPIENTRY * PFNGLCLEARCOLORIIEXTPROC) (GLint red, GLint green, GLint blue, GLint alpha); -typedef void (GLAPIENTRY * PFNGLCLEARCOLORIUIEXTPROC) (GLuint red, GLuint green, GLuint blue, GLuint alpha); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, GLint *params); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, GLuint *params); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, const GLuint *params); - -#define glClearColorIiEXT GLEW_GET_FUN(__glewClearColorIiEXT) -#define glClearColorIuiEXT GLEW_GET_FUN(__glewClearColorIuiEXT) -#define glGetTexParameterIivEXT GLEW_GET_FUN(__glewGetTexParameterIivEXT) -#define glGetTexParameterIuivEXT GLEW_GET_FUN(__glewGetTexParameterIuivEXT) -#define glTexParameterIivEXT GLEW_GET_FUN(__glewTexParameterIivEXT) -#define glTexParameterIuivEXT GLEW_GET_FUN(__glewTexParameterIuivEXT) - -#define GLEW_EXT_texture_integer GLEW_GET_VAR(__GLEW_EXT_texture_integer) - -#endif /* GL_EXT_texture_integer */ - -/* ------------------------ GL_EXT_texture_lod_bias ------------------------ */ - -#ifndef GL_EXT_texture_lod_bias -#define GL_EXT_texture_lod_bias 1 - -#define GL_MAX_TEXTURE_LOD_BIAS_EXT 0x84FD -#define GL_TEXTURE_FILTER_CONTROL_EXT 0x8500 -#define GL_TEXTURE_LOD_BIAS_EXT 0x8501 - -#define GLEW_EXT_texture_lod_bias GLEW_GET_VAR(__GLEW_EXT_texture_lod_bias) - -#endif /* GL_EXT_texture_lod_bias */ - -/* ---------------------- GL_EXT_texture_mirror_clamp ---------------------- */ - -#ifndef GL_EXT_texture_mirror_clamp -#define GL_EXT_texture_mirror_clamp 1 - -#define GL_MIRROR_CLAMP_EXT 0x8742 -#define GL_MIRROR_CLAMP_TO_EDGE_EXT 0x8743 -#define GL_MIRROR_CLAMP_TO_BORDER_EXT 0x8912 - -#define GLEW_EXT_texture_mirror_clamp GLEW_GET_VAR(__GLEW_EXT_texture_mirror_clamp) - -#endif /* GL_EXT_texture_mirror_clamp */ - -/* ------------------------- GL_EXT_texture_object ------------------------- */ - -#ifndef GL_EXT_texture_object -#define GL_EXT_texture_object 1 - -#define GL_TEXTURE_PRIORITY_EXT 0x8066 -#define GL_TEXTURE_RESIDENT_EXT 0x8067 -#define GL_TEXTURE_1D_BINDING_EXT 0x8068 -#define GL_TEXTURE_2D_BINDING_EXT 0x8069 -#define GL_TEXTURE_3D_BINDING_EXT 0x806A - -typedef GLboolean (GLAPIENTRY * PFNGLARETEXTURESRESIDENTEXTPROC) (GLsizei n, const GLuint* textures, GLboolean* residences); -typedef void (GLAPIENTRY * PFNGLBINDTEXTUREEXTPROC) (GLenum target, GLuint texture); -typedef void (GLAPIENTRY * PFNGLDELETETEXTURESEXTPROC) (GLsizei n, const GLuint* textures); -typedef void (GLAPIENTRY * PFNGLGENTEXTURESEXTPROC) (GLsizei n, GLuint* textures); -typedef GLboolean (GLAPIENTRY * PFNGLISTEXTUREEXTPROC) (GLuint texture); -typedef void (GLAPIENTRY * PFNGLPRIORITIZETEXTURESEXTPROC) (GLsizei n, const GLuint* textures, const GLclampf* priorities); - -#define glAreTexturesResidentEXT GLEW_GET_FUN(__glewAreTexturesResidentEXT) -#define glBindTextureEXT GLEW_GET_FUN(__glewBindTextureEXT) -#define glDeleteTexturesEXT GLEW_GET_FUN(__glewDeleteTexturesEXT) -#define glGenTexturesEXT GLEW_GET_FUN(__glewGenTexturesEXT) -#define glIsTextureEXT GLEW_GET_FUN(__glewIsTextureEXT) -#define glPrioritizeTexturesEXT GLEW_GET_FUN(__glewPrioritizeTexturesEXT) - -#define GLEW_EXT_texture_object GLEW_GET_VAR(__GLEW_EXT_texture_object) - -#endif /* GL_EXT_texture_object */ - -/* --------------------- GL_EXT_texture_perturb_normal --------------------- */ - -#ifndef GL_EXT_texture_perturb_normal -#define GL_EXT_texture_perturb_normal 1 - -#define GL_PERTURB_EXT 0x85AE -#define GL_TEXTURE_NORMAL_EXT 0x85AF - -typedef void (GLAPIENTRY * PFNGLTEXTURENORMALEXTPROC) (GLenum mode); - -#define glTextureNormalEXT GLEW_GET_FUN(__glewTextureNormalEXT) - -#define GLEW_EXT_texture_perturb_normal GLEW_GET_VAR(__GLEW_EXT_texture_perturb_normal) - -#endif /* GL_EXT_texture_perturb_normal */ - -/* ------------------------ GL_EXT_texture_rectangle ----------------------- */ - -#ifndef GL_EXT_texture_rectangle -#define GL_EXT_texture_rectangle 1 - -#define GL_TEXTURE_RECTANGLE_EXT 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_EXT 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_EXT 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_EXT 0x84F8 - -#define GLEW_EXT_texture_rectangle GLEW_GET_VAR(__GLEW_EXT_texture_rectangle) - -#endif /* GL_EXT_texture_rectangle */ - -/* -------------------------- GL_EXT_texture_sRGB -------------------------- */ - -#ifndef GL_EXT_texture_sRGB -#define GL_EXT_texture_sRGB 1 - -#define GL_SRGB_EXT 0x8C40 -#define GL_SRGB8_EXT 0x8C41 -#define GL_SRGB_ALPHA_EXT 0x8C42 -#define GL_SRGB8_ALPHA8_EXT 0x8C43 -#define GL_SLUMINANCE_ALPHA_EXT 0x8C44 -#define GL_SLUMINANCE8_ALPHA8_EXT 0x8C45 -#define GL_SLUMINANCE_EXT 0x8C46 -#define GL_SLUMINANCE8_EXT 0x8C47 -#define GL_COMPRESSED_SRGB_EXT 0x8C48 -#define GL_COMPRESSED_SRGB_ALPHA_EXT 0x8C49 -#define GL_COMPRESSED_SLUMINANCE_EXT 0x8C4A -#define GL_COMPRESSED_SLUMINANCE_ALPHA_EXT 0x8C4B -#define GL_COMPRESSED_SRGB_S3TC_DXT1_EXT 0x8C4C -#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT 0x8C4D -#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT 0x8C4E -#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT 0x8C4F - -#define GLEW_EXT_texture_sRGB GLEW_GET_VAR(__GLEW_EXT_texture_sRGB) - -#endif /* GL_EXT_texture_sRGB */ - -/* ----------------------- GL_EXT_texture_sRGB_decode ---------------------- */ - -#ifndef GL_EXT_texture_sRGB_decode -#define GL_EXT_texture_sRGB_decode 1 - -#define GL_TEXTURE_SRGB_DECODE_EXT 0x8A48 -#define GL_DECODE_EXT 0x8A49 -#define GL_SKIP_DECODE_EXT 0x8A4A - -#define GLEW_EXT_texture_sRGB_decode GLEW_GET_VAR(__GLEW_EXT_texture_sRGB_decode) - -#endif /* GL_EXT_texture_sRGB_decode */ - -/* --------------------- GL_EXT_texture_shared_exponent -------------------- */ - -#ifndef GL_EXT_texture_shared_exponent -#define GL_EXT_texture_shared_exponent 1 - -#define GL_RGB9_E5_EXT 0x8C3D -#define GL_UNSIGNED_INT_5_9_9_9_REV_EXT 0x8C3E -#define GL_TEXTURE_SHARED_SIZE_EXT 0x8C3F - -#define GLEW_EXT_texture_shared_exponent GLEW_GET_VAR(__GLEW_EXT_texture_shared_exponent) - -#endif /* GL_EXT_texture_shared_exponent */ - -/* -------------------------- GL_EXT_texture_snorm ------------------------- */ - -#ifndef GL_EXT_texture_snorm -#define GL_EXT_texture_snorm 1 - -#define GL_RED_SNORM 0x8F90 -#define GL_RG_SNORM 0x8F91 -#define GL_RGB_SNORM 0x8F92 -#define GL_RGBA_SNORM 0x8F93 -#define GL_R8_SNORM 0x8F94 -#define GL_RG8_SNORM 0x8F95 -#define GL_RGB8_SNORM 0x8F96 -#define GL_RGBA8_SNORM 0x8F97 -#define GL_R16_SNORM 0x8F98 -#define GL_RG16_SNORM 0x8F99 -#define GL_RGB16_SNORM 0x8F9A -#define GL_RGBA16_SNORM 0x8F9B -#define GL_SIGNED_NORMALIZED 0x8F9C -#define GL_ALPHA_SNORM 0x9010 -#define GL_LUMINANCE_SNORM 0x9011 -#define GL_LUMINANCE_ALPHA_SNORM 0x9012 -#define GL_INTENSITY_SNORM 0x9013 -#define GL_ALPHA8_SNORM 0x9014 -#define GL_LUMINANCE8_SNORM 0x9015 -#define GL_LUMINANCE8_ALPHA8_SNORM 0x9016 -#define GL_INTENSITY8_SNORM 0x9017 -#define GL_ALPHA16_SNORM 0x9018 -#define GL_LUMINANCE16_SNORM 0x9019 -#define GL_LUMINANCE16_ALPHA16_SNORM 0x901A -#define GL_INTENSITY16_SNORM 0x901B - -#define GLEW_EXT_texture_snorm GLEW_GET_VAR(__GLEW_EXT_texture_snorm) - -#endif /* GL_EXT_texture_snorm */ - -/* ------------------------- GL_EXT_texture_swizzle ------------------------ */ - -#ifndef GL_EXT_texture_swizzle -#define GL_EXT_texture_swizzle 1 - -#define GL_TEXTURE_SWIZZLE_R_EXT 0x8E42 -#define GL_TEXTURE_SWIZZLE_G_EXT 0x8E43 -#define GL_TEXTURE_SWIZZLE_B_EXT 0x8E44 -#define GL_TEXTURE_SWIZZLE_A_EXT 0x8E45 -#define GL_TEXTURE_SWIZZLE_RGBA_EXT 0x8E46 - -#define GLEW_EXT_texture_swizzle GLEW_GET_VAR(__GLEW_EXT_texture_swizzle) - -#endif /* GL_EXT_texture_swizzle */ - -/* --------------------------- GL_EXT_timer_query -------------------------- */ - -#ifndef GL_EXT_timer_query -#define GL_EXT_timer_query 1 - -#define GL_TIME_ELAPSED_EXT 0x88BF - -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTI64VEXTPROC) (GLuint id, GLenum pname, GLint64EXT *params); -typedef void (GLAPIENTRY * PFNGLGETQUERYOBJECTUI64VEXTPROC) (GLuint id, GLenum pname, GLuint64EXT *params); - -#define glGetQueryObjecti64vEXT GLEW_GET_FUN(__glewGetQueryObjecti64vEXT) -#define glGetQueryObjectui64vEXT GLEW_GET_FUN(__glewGetQueryObjectui64vEXT) - -#define GLEW_EXT_timer_query GLEW_GET_VAR(__GLEW_EXT_timer_query) - -#endif /* GL_EXT_timer_query */ - -/* ----------------------- GL_EXT_transform_feedback ----------------------- */ - -#ifndef GL_EXT_transform_feedback -#define GL_EXT_transform_feedback 1 - -#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH_EXT 0x8C76 -#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_EXT 0x8C7F -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_EXT 0x8C80 -#define GL_TRANSFORM_FEEDBACK_VARYINGS_EXT 0x8C83 -#define GL_TRANSFORM_FEEDBACK_BUFFER_START_EXT 0x8C84 -#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_EXT 0x8C85 -#define GL_PRIMITIVES_GENERATED_EXT 0x8C87 -#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_EXT 0x8C88 -#define GL_RASTERIZER_DISCARD_EXT 0x8C89 -#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_EXT 0x8C8A -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_EXT 0x8C8B -#define GL_INTERLEAVED_ATTRIBS_EXT 0x8C8C -#define GL_SEPARATE_ATTRIBS_EXT 0x8C8D -#define GL_TRANSFORM_FEEDBACK_BUFFER_EXT 0x8C8E -#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_EXT 0x8C8F - -typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKEXTPROC) (GLenum primitiveMode); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASEEXTPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBINDBUFFEROFFSETEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGEEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKEXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei* length, GLsizei *size, GLenum *type, GLchar *name); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC) (GLuint program, GLsizei count, const GLchar * const* varyings, GLenum bufferMode); - -#define glBeginTransformFeedbackEXT GLEW_GET_FUN(__glewBeginTransformFeedbackEXT) -#define glBindBufferBaseEXT GLEW_GET_FUN(__glewBindBufferBaseEXT) -#define glBindBufferOffsetEXT GLEW_GET_FUN(__glewBindBufferOffsetEXT) -#define glBindBufferRangeEXT GLEW_GET_FUN(__glewBindBufferRangeEXT) -#define glEndTransformFeedbackEXT GLEW_GET_FUN(__glewEndTransformFeedbackEXT) -#define glGetTransformFeedbackVaryingEXT GLEW_GET_FUN(__glewGetTransformFeedbackVaryingEXT) -#define glTransformFeedbackVaryingsEXT GLEW_GET_FUN(__glewTransformFeedbackVaryingsEXT) - -#define GLEW_EXT_transform_feedback GLEW_GET_VAR(__GLEW_EXT_transform_feedback) - -#endif /* GL_EXT_transform_feedback */ - -/* -------------------------- GL_EXT_vertex_array -------------------------- */ - -#ifndef GL_EXT_vertex_array -#define GL_EXT_vertex_array 1 - -#define GL_DOUBLE_EXT 0x140A -#define GL_VERTEX_ARRAY_EXT 0x8074 -#define GL_NORMAL_ARRAY_EXT 0x8075 -#define GL_COLOR_ARRAY_EXT 0x8076 -#define GL_INDEX_ARRAY_EXT 0x8077 -#define GL_TEXTURE_COORD_ARRAY_EXT 0x8078 -#define GL_EDGE_FLAG_ARRAY_EXT 0x8079 -#define GL_VERTEX_ARRAY_SIZE_EXT 0x807A -#define GL_VERTEX_ARRAY_TYPE_EXT 0x807B -#define GL_VERTEX_ARRAY_STRIDE_EXT 0x807C -#define GL_VERTEX_ARRAY_COUNT_EXT 0x807D -#define GL_NORMAL_ARRAY_TYPE_EXT 0x807E -#define GL_NORMAL_ARRAY_STRIDE_EXT 0x807F -#define GL_NORMAL_ARRAY_COUNT_EXT 0x8080 -#define GL_COLOR_ARRAY_SIZE_EXT 0x8081 -#define GL_COLOR_ARRAY_TYPE_EXT 0x8082 -#define GL_COLOR_ARRAY_STRIDE_EXT 0x8083 -#define GL_COLOR_ARRAY_COUNT_EXT 0x8084 -#define GL_INDEX_ARRAY_TYPE_EXT 0x8085 -#define GL_INDEX_ARRAY_STRIDE_EXT 0x8086 -#define GL_INDEX_ARRAY_COUNT_EXT 0x8087 -#define GL_TEXTURE_COORD_ARRAY_SIZE_EXT 0x8088 -#define GL_TEXTURE_COORD_ARRAY_TYPE_EXT 0x8089 -#define GL_TEXTURE_COORD_ARRAY_STRIDE_EXT 0x808A -#define GL_TEXTURE_COORD_ARRAY_COUNT_EXT 0x808B -#define GL_EDGE_FLAG_ARRAY_STRIDE_EXT 0x808C -#define GL_EDGE_FLAG_ARRAY_COUNT_EXT 0x808D -#define GL_VERTEX_ARRAY_POINTER_EXT 0x808E -#define GL_NORMAL_ARRAY_POINTER_EXT 0x808F -#define GL_COLOR_ARRAY_POINTER_EXT 0x8090 -#define GL_INDEX_ARRAY_POINTER_EXT 0x8091 -#define GL_TEXTURE_COORD_ARRAY_POINTER_EXT 0x8092 -#define GL_EDGE_FLAG_ARRAY_POINTER_EXT 0x8093 - -typedef void (GLAPIENTRY * PFNGLARRAYELEMENTEXTPROC) (GLint i); -typedef void (GLAPIENTRY * PFNGLCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLDRAWARRAYSEXTPROC) (GLenum mode, GLint first, GLsizei count); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTEREXTPROC) (GLsizei stride, GLsizei count, const GLboolean* pointer); -typedef void (GLAPIENTRY * PFNGLINDEXPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const GLvoid *pointer); - -#define glArrayElementEXT GLEW_GET_FUN(__glewArrayElementEXT) -#define glColorPointerEXT GLEW_GET_FUN(__glewColorPointerEXT) -#define glDrawArraysEXT GLEW_GET_FUN(__glewDrawArraysEXT) -#define glEdgeFlagPointerEXT GLEW_GET_FUN(__glewEdgeFlagPointerEXT) -#define glIndexPointerEXT GLEW_GET_FUN(__glewIndexPointerEXT) -#define glNormalPointerEXT GLEW_GET_FUN(__glewNormalPointerEXT) -#define glTexCoordPointerEXT GLEW_GET_FUN(__glewTexCoordPointerEXT) -#define glVertexPointerEXT GLEW_GET_FUN(__glewVertexPointerEXT) - -#define GLEW_EXT_vertex_array GLEW_GET_VAR(__GLEW_EXT_vertex_array) - -#endif /* GL_EXT_vertex_array */ - -/* ------------------------ GL_EXT_vertex_array_bgra ----------------------- */ - -#ifndef GL_EXT_vertex_array_bgra -#define GL_EXT_vertex_array_bgra 1 - -#define GL_BGRA 0x80E1 - -#define GLEW_EXT_vertex_array_bgra GLEW_GET_VAR(__GLEW_EXT_vertex_array_bgra) - -#endif /* GL_EXT_vertex_array_bgra */ - -/* ----------------------- GL_EXT_vertex_attrib_64bit ---------------------- */ - -#ifndef GL_EXT_vertex_attrib_64bit -#define GL_EXT_vertex_attrib_64bit 1 - -#define GL_DOUBLE_MAT2_EXT 0x8F46 -#define GL_DOUBLE_MAT3_EXT 0x8F47 -#define GL_DOUBLE_MAT4_EXT 0x8F48 -#define GL_DOUBLE_MAT2x3_EXT 0x8F49 -#define GL_DOUBLE_MAT2x4_EXT 0x8F4A -#define GL_DOUBLE_MAT3x2_EXT 0x8F4B -#define GL_DOUBLE_MAT3x4_EXT 0x8F4C -#define GL_DOUBLE_MAT4x2_EXT 0x8F4D -#define GL_DOUBLE_MAT4x3_EXT 0x8F4E -#define GL_DOUBLE_VEC2_EXT 0x8FFC -#define GL_DOUBLE_VEC3_EXT 0x8FFD -#define GL_DOUBLE_VEC4_EXT 0x8FFE - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLDVEXTPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DEXTPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DEXTPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4DVEXTPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); - -#define glGetVertexAttribLdvEXT GLEW_GET_FUN(__glewGetVertexAttribLdvEXT) -#define glVertexArrayVertexAttribLOffsetEXT GLEW_GET_FUN(__glewVertexArrayVertexAttribLOffsetEXT) -#define glVertexAttribL1dEXT GLEW_GET_FUN(__glewVertexAttribL1dEXT) -#define glVertexAttribL1dvEXT GLEW_GET_FUN(__glewVertexAttribL1dvEXT) -#define glVertexAttribL2dEXT GLEW_GET_FUN(__glewVertexAttribL2dEXT) -#define glVertexAttribL2dvEXT GLEW_GET_FUN(__glewVertexAttribL2dvEXT) -#define glVertexAttribL3dEXT GLEW_GET_FUN(__glewVertexAttribL3dEXT) -#define glVertexAttribL3dvEXT GLEW_GET_FUN(__glewVertexAttribL3dvEXT) -#define glVertexAttribL4dEXT GLEW_GET_FUN(__glewVertexAttribL4dEXT) -#define glVertexAttribL4dvEXT GLEW_GET_FUN(__glewVertexAttribL4dvEXT) -#define glVertexAttribLPointerEXT GLEW_GET_FUN(__glewVertexAttribLPointerEXT) - -#define GLEW_EXT_vertex_attrib_64bit GLEW_GET_VAR(__GLEW_EXT_vertex_attrib_64bit) - -#endif /* GL_EXT_vertex_attrib_64bit */ - -/* -------------------------- GL_EXT_vertex_shader ------------------------- */ - -#ifndef GL_EXT_vertex_shader -#define GL_EXT_vertex_shader 1 - -#define GL_VERTEX_SHADER_EXT 0x8780 -#define GL_VERTEX_SHADER_BINDING_EXT 0x8781 -#define GL_OP_INDEX_EXT 0x8782 -#define GL_OP_NEGATE_EXT 0x8783 -#define GL_OP_DOT3_EXT 0x8784 -#define GL_OP_DOT4_EXT 0x8785 -#define GL_OP_MUL_EXT 0x8786 -#define GL_OP_ADD_EXT 0x8787 -#define GL_OP_MADD_EXT 0x8788 -#define GL_OP_FRAC_EXT 0x8789 -#define GL_OP_MAX_EXT 0x878A -#define GL_OP_MIN_EXT 0x878B -#define GL_OP_SET_GE_EXT 0x878C -#define GL_OP_SET_LT_EXT 0x878D -#define GL_OP_CLAMP_EXT 0x878E -#define GL_OP_FLOOR_EXT 0x878F -#define GL_OP_ROUND_EXT 0x8790 -#define GL_OP_EXP_BASE_2_EXT 0x8791 -#define GL_OP_LOG_BASE_2_EXT 0x8792 -#define GL_OP_POWER_EXT 0x8793 -#define GL_OP_RECIP_EXT 0x8794 -#define GL_OP_RECIP_SQRT_EXT 0x8795 -#define GL_OP_SUB_EXT 0x8796 -#define GL_OP_CROSS_PRODUCT_EXT 0x8797 -#define GL_OP_MULTIPLY_MATRIX_EXT 0x8798 -#define GL_OP_MOV_EXT 0x8799 -#define GL_OUTPUT_VERTEX_EXT 0x879A -#define GL_OUTPUT_COLOR0_EXT 0x879B -#define GL_OUTPUT_COLOR1_EXT 0x879C -#define GL_OUTPUT_TEXTURE_COORD0_EXT 0x879D -#define GL_OUTPUT_TEXTURE_COORD1_EXT 0x879E -#define GL_OUTPUT_TEXTURE_COORD2_EXT 0x879F -#define GL_OUTPUT_TEXTURE_COORD3_EXT 0x87A0 -#define GL_OUTPUT_TEXTURE_COORD4_EXT 0x87A1 -#define GL_OUTPUT_TEXTURE_COORD5_EXT 0x87A2 -#define GL_OUTPUT_TEXTURE_COORD6_EXT 0x87A3 -#define GL_OUTPUT_TEXTURE_COORD7_EXT 0x87A4 -#define GL_OUTPUT_TEXTURE_COORD8_EXT 0x87A5 -#define GL_OUTPUT_TEXTURE_COORD9_EXT 0x87A6 -#define GL_OUTPUT_TEXTURE_COORD10_EXT 0x87A7 -#define GL_OUTPUT_TEXTURE_COORD11_EXT 0x87A8 -#define GL_OUTPUT_TEXTURE_COORD12_EXT 0x87A9 -#define GL_OUTPUT_TEXTURE_COORD13_EXT 0x87AA -#define GL_OUTPUT_TEXTURE_COORD14_EXT 0x87AB -#define GL_OUTPUT_TEXTURE_COORD15_EXT 0x87AC -#define GL_OUTPUT_TEXTURE_COORD16_EXT 0x87AD -#define GL_OUTPUT_TEXTURE_COORD17_EXT 0x87AE -#define GL_OUTPUT_TEXTURE_COORD18_EXT 0x87AF -#define GL_OUTPUT_TEXTURE_COORD19_EXT 0x87B0 -#define GL_OUTPUT_TEXTURE_COORD20_EXT 0x87B1 -#define GL_OUTPUT_TEXTURE_COORD21_EXT 0x87B2 -#define GL_OUTPUT_TEXTURE_COORD22_EXT 0x87B3 -#define GL_OUTPUT_TEXTURE_COORD23_EXT 0x87B4 -#define GL_OUTPUT_TEXTURE_COORD24_EXT 0x87B5 -#define GL_OUTPUT_TEXTURE_COORD25_EXT 0x87B6 -#define GL_OUTPUT_TEXTURE_COORD26_EXT 0x87B7 -#define GL_OUTPUT_TEXTURE_COORD27_EXT 0x87B8 -#define GL_OUTPUT_TEXTURE_COORD28_EXT 0x87B9 -#define GL_OUTPUT_TEXTURE_COORD29_EXT 0x87BA -#define GL_OUTPUT_TEXTURE_COORD30_EXT 0x87BB -#define GL_OUTPUT_TEXTURE_COORD31_EXT 0x87BC -#define GL_OUTPUT_FOG_EXT 0x87BD -#define GL_SCALAR_EXT 0x87BE -#define GL_VECTOR_EXT 0x87BF -#define GL_MATRIX_EXT 0x87C0 -#define GL_VARIANT_EXT 0x87C1 -#define GL_INVARIANT_EXT 0x87C2 -#define GL_LOCAL_CONSTANT_EXT 0x87C3 -#define GL_LOCAL_EXT 0x87C4 -#define GL_MAX_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87C5 -#define GL_MAX_VERTEX_SHADER_VARIANTS_EXT 0x87C6 -#define GL_MAX_VERTEX_SHADER_INVARIANTS_EXT 0x87C7 -#define GL_MAX_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87C8 -#define GL_MAX_VERTEX_SHADER_LOCALS_EXT 0x87C9 -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CA -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_VARIANTS_EXT 0x87CB -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_EXT 0x87CC -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87CD -#define GL_MAX_OPTIMIZED_VERTEX_SHADER_LOCALS_EXT 0x87CE -#define GL_VERTEX_SHADER_INSTRUCTIONS_EXT 0x87CF -#define GL_VERTEX_SHADER_VARIANTS_EXT 0x87D0 -#define GL_VERTEX_SHADER_INVARIANTS_EXT 0x87D1 -#define GL_VERTEX_SHADER_LOCAL_CONSTANTS_EXT 0x87D2 -#define GL_VERTEX_SHADER_LOCALS_EXT 0x87D3 -#define GL_VERTEX_SHADER_OPTIMIZED_EXT 0x87D4 -#define GL_X_EXT 0x87D5 -#define GL_Y_EXT 0x87D6 -#define GL_Z_EXT 0x87D7 -#define GL_W_EXT 0x87D8 -#define GL_NEGATIVE_X_EXT 0x87D9 -#define GL_NEGATIVE_Y_EXT 0x87DA -#define GL_NEGATIVE_Z_EXT 0x87DB -#define GL_NEGATIVE_W_EXT 0x87DC -#define GL_ZERO_EXT 0x87DD -#define GL_ONE_EXT 0x87DE -#define GL_NEGATIVE_ONE_EXT 0x87DF -#define GL_NORMALIZED_RANGE_EXT 0x87E0 -#define GL_FULL_RANGE_EXT 0x87E1 -#define GL_CURRENT_VERTEX_EXT 0x87E2 -#define GL_MVP_MATRIX_EXT 0x87E3 -#define GL_VARIANT_VALUE_EXT 0x87E4 -#define GL_VARIANT_DATATYPE_EXT 0x87E5 -#define GL_VARIANT_ARRAY_STRIDE_EXT 0x87E6 -#define GL_VARIANT_ARRAY_TYPE_EXT 0x87E7 -#define GL_VARIANT_ARRAY_EXT 0x87E8 -#define GL_VARIANT_ARRAY_POINTER_EXT 0x87E9 -#define GL_INVARIANT_VALUE_EXT 0x87EA -#define GL_INVARIANT_DATATYPE_EXT 0x87EB -#define GL_LOCAL_CONSTANT_VALUE_EXT 0x87EC -#define GL_LOCAL_CONSTANT_DATATYPE_EXT 0x87ED - -typedef void (GLAPIENTRY * PFNGLBEGINVERTEXSHADEREXTPROC) (void); -typedef GLuint (GLAPIENTRY * PFNGLBINDLIGHTPARAMETEREXTPROC) (GLenum light, GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDMATERIALPARAMETEREXTPROC) (GLenum face, GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDPARAMETEREXTPROC) (GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDTEXGENPARAMETEREXTPROC) (GLenum unit, GLenum coord, GLenum value); -typedef GLuint (GLAPIENTRY * PFNGLBINDTEXTUREUNITPARAMETEREXTPROC) (GLenum unit, GLenum value); -typedef void (GLAPIENTRY * PFNGLBINDVERTEXSHADEREXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEVERTEXSHADEREXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENDVERTEXSHADEREXTPROC) (void); -typedef void (GLAPIENTRY * PFNGLEXTRACTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); -typedef GLuint (GLAPIENTRY * PFNGLGENSYMBOLSEXTPROC) (GLenum dataType, GLenum storageType, GLenum range, GLuint components); -typedef GLuint (GLAPIENTRY * PFNGLGENVERTEXSHADERSEXTPROC) (GLuint range); -typedef void (GLAPIENTRY * PFNGLGETINVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); -typedef void (GLAPIENTRY * PFNGLGETINVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); -typedef void (GLAPIENTRY * PFNGLGETINVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); -typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); -typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); -typedef void (GLAPIENTRY * PFNGLGETLOCALCONSTANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); -typedef void (GLAPIENTRY * PFNGLGETVARIANTPOINTERVEXTPROC) (GLuint id, GLenum value, GLvoid **data); -typedef void (GLAPIENTRY * PFNGLINSERTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); -typedef GLboolean (GLAPIENTRY * PFNGLISVARIANTENABLEDEXTPROC) (GLuint id, GLenum cap); -typedef void (GLAPIENTRY * PFNGLSETINVARIANTEXTPROC) (GLuint id, GLenum type, GLvoid *addr); -typedef void (GLAPIENTRY * PFNGLSETLOCALCONSTANTEXTPROC) (GLuint id, GLenum type, GLvoid *addr); -typedef void (GLAPIENTRY * PFNGLSHADEROP1EXTPROC) (GLenum op, GLuint res, GLuint arg1); -typedef void (GLAPIENTRY * PFNGLSHADEROP2EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2); -typedef void (GLAPIENTRY * PFNGLSHADEROP3EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3); -typedef void (GLAPIENTRY * PFNGLSWIZZLEEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); -typedef void (GLAPIENTRY * PFNGLVARIANTPOINTEREXTPROC) (GLuint id, GLenum type, GLuint stride, GLvoid *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTBVEXTPROC) (GLuint id, GLbyte *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTDVEXTPROC) (GLuint id, GLdouble *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTFVEXTPROC) (GLuint id, GLfloat *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTIVEXTPROC) (GLuint id, GLint *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTSVEXTPROC) (GLuint id, GLshort *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTUBVEXTPROC) (GLuint id, GLubyte *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTUIVEXTPROC) (GLuint id, GLuint *addr); -typedef void (GLAPIENTRY * PFNGLVARIANTUSVEXTPROC) (GLuint id, GLushort *addr); -typedef void (GLAPIENTRY * PFNGLWRITEMASKEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); - -#define glBeginVertexShaderEXT GLEW_GET_FUN(__glewBeginVertexShaderEXT) -#define glBindLightParameterEXT GLEW_GET_FUN(__glewBindLightParameterEXT) -#define glBindMaterialParameterEXT GLEW_GET_FUN(__glewBindMaterialParameterEXT) -#define glBindParameterEXT GLEW_GET_FUN(__glewBindParameterEXT) -#define glBindTexGenParameterEXT GLEW_GET_FUN(__glewBindTexGenParameterEXT) -#define glBindTextureUnitParameterEXT GLEW_GET_FUN(__glewBindTextureUnitParameterEXT) -#define glBindVertexShaderEXT GLEW_GET_FUN(__glewBindVertexShaderEXT) -#define glDeleteVertexShaderEXT GLEW_GET_FUN(__glewDeleteVertexShaderEXT) -#define glDisableVariantClientStateEXT GLEW_GET_FUN(__glewDisableVariantClientStateEXT) -#define glEnableVariantClientStateEXT GLEW_GET_FUN(__glewEnableVariantClientStateEXT) -#define glEndVertexShaderEXT GLEW_GET_FUN(__glewEndVertexShaderEXT) -#define glExtractComponentEXT GLEW_GET_FUN(__glewExtractComponentEXT) -#define glGenSymbolsEXT GLEW_GET_FUN(__glewGenSymbolsEXT) -#define glGenVertexShadersEXT GLEW_GET_FUN(__glewGenVertexShadersEXT) -#define glGetInvariantBooleanvEXT GLEW_GET_FUN(__glewGetInvariantBooleanvEXT) -#define glGetInvariantFloatvEXT GLEW_GET_FUN(__glewGetInvariantFloatvEXT) -#define glGetInvariantIntegervEXT GLEW_GET_FUN(__glewGetInvariantIntegervEXT) -#define glGetLocalConstantBooleanvEXT GLEW_GET_FUN(__glewGetLocalConstantBooleanvEXT) -#define glGetLocalConstantFloatvEXT GLEW_GET_FUN(__glewGetLocalConstantFloatvEXT) -#define glGetLocalConstantIntegervEXT GLEW_GET_FUN(__glewGetLocalConstantIntegervEXT) -#define glGetVariantBooleanvEXT GLEW_GET_FUN(__glewGetVariantBooleanvEXT) -#define glGetVariantFloatvEXT GLEW_GET_FUN(__glewGetVariantFloatvEXT) -#define glGetVariantIntegervEXT GLEW_GET_FUN(__glewGetVariantIntegervEXT) -#define glGetVariantPointervEXT GLEW_GET_FUN(__glewGetVariantPointervEXT) -#define glInsertComponentEXT GLEW_GET_FUN(__glewInsertComponentEXT) -#define glIsVariantEnabledEXT GLEW_GET_FUN(__glewIsVariantEnabledEXT) -#define glSetInvariantEXT GLEW_GET_FUN(__glewSetInvariantEXT) -#define glSetLocalConstantEXT GLEW_GET_FUN(__glewSetLocalConstantEXT) -#define glShaderOp1EXT GLEW_GET_FUN(__glewShaderOp1EXT) -#define glShaderOp2EXT GLEW_GET_FUN(__glewShaderOp2EXT) -#define glShaderOp3EXT GLEW_GET_FUN(__glewShaderOp3EXT) -#define glSwizzleEXT GLEW_GET_FUN(__glewSwizzleEXT) -#define glVariantPointerEXT GLEW_GET_FUN(__glewVariantPointerEXT) -#define glVariantbvEXT GLEW_GET_FUN(__glewVariantbvEXT) -#define glVariantdvEXT GLEW_GET_FUN(__glewVariantdvEXT) -#define glVariantfvEXT GLEW_GET_FUN(__glewVariantfvEXT) -#define glVariantivEXT GLEW_GET_FUN(__glewVariantivEXT) -#define glVariantsvEXT GLEW_GET_FUN(__glewVariantsvEXT) -#define glVariantubvEXT GLEW_GET_FUN(__glewVariantubvEXT) -#define glVariantuivEXT GLEW_GET_FUN(__glewVariantuivEXT) -#define glVariantusvEXT GLEW_GET_FUN(__glewVariantusvEXT) -#define glWriteMaskEXT GLEW_GET_FUN(__glewWriteMaskEXT) - -#define GLEW_EXT_vertex_shader GLEW_GET_VAR(__GLEW_EXT_vertex_shader) - -#endif /* GL_EXT_vertex_shader */ - -/* ------------------------ GL_EXT_vertex_weighting ------------------------ */ - -#ifndef GL_EXT_vertex_weighting -#define GL_EXT_vertex_weighting 1 - -#define GL_MODELVIEW0_STACK_DEPTH_EXT 0x0BA3 -#define GL_MODELVIEW0_MATRIX_EXT 0x0BA6 -#define GL_MODELVIEW0_EXT 0x1700 -#define GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 -#define GL_MODELVIEW1_MATRIX_EXT 0x8506 -#define GL_VERTEX_WEIGHTING_EXT 0x8509 -#define GL_MODELVIEW1_EXT 0x850A -#define GL_CURRENT_VERTEX_WEIGHT_EXT 0x850B -#define GL_VERTEX_WEIGHT_ARRAY_EXT 0x850C -#define GL_VERTEX_WEIGHT_ARRAY_SIZE_EXT 0x850D -#define GL_VERTEX_WEIGHT_ARRAY_TYPE_EXT 0x850E -#define GL_VERTEX_WEIGHT_ARRAY_STRIDE_EXT 0x850F -#define GL_VERTEX_WEIGHT_ARRAY_POINTER_EXT 0x8510 - -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTFEXTPROC) (GLfloat weight); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTFVEXTPROC) (GLfloat* weight); - -#define glVertexWeightPointerEXT GLEW_GET_FUN(__glewVertexWeightPointerEXT) -#define glVertexWeightfEXT GLEW_GET_FUN(__glewVertexWeightfEXT) -#define glVertexWeightfvEXT GLEW_GET_FUN(__glewVertexWeightfvEXT) - -#define GLEW_EXT_vertex_weighting GLEW_GET_VAR(__GLEW_EXT_vertex_weighting) - -#endif /* GL_EXT_vertex_weighting */ - -/* ------------------------- GL_EXT_x11_sync_object ------------------------ */ - -#ifndef GL_EXT_x11_sync_object -#define GL_EXT_x11_sync_object 1 - -#define GL_SYNC_X11_FENCE_EXT 0x90E1 - -typedef GLsync (GLAPIENTRY * PFNGLIMPORTSYNCEXTPROC) (GLenum external_sync_type, GLintptr external_sync, GLbitfield flags); - -#define glImportSyncEXT GLEW_GET_FUN(__glewImportSyncEXT) - -#define GLEW_EXT_x11_sync_object GLEW_GET_VAR(__GLEW_EXT_x11_sync_object) - -#endif /* GL_EXT_x11_sync_object */ - -/* ---------------------- GL_GREMEDY_frame_terminator ---------------------- */ - -#ifndef GL_GREMEDY_frame_terminator -#define GL_GREMEDY_frame_terminator 1 - -typedef void (GLAPIENTRY * PFNGLFRAMETERMINATORGREMEDYPROC) (void); - -#define glFrameTerminatorGREMEDY GLEW_GET_FUN(__glewFrameTerminatorGREMEDY) - -#define GLEW_GREMEDY_frame_terminator GLEW_GET_VAR(__GLEW_GREMEDY_frame_terminator) - -#endif /* GL_GREMEDY_frame_terminator */ - -/* ------------------------ GL_GREMEDY_string_marker ----------------------- */ - -#ifndef GL_GREMEDY_string_marker -#define GL_GREMEDY_string_marker 1 - -typedef void (GLAPIENTRY * PFNGLSTRINGMARKERGREMEDYPROC) (GLsizei len, const GLvoid *string); - -#define glStringMarkerGREMEDY GLEW_GET_FUN(__glewStringMarkerGREMEDY) - -#define GLEW_GREMEDY_string_marker GLEW_GET_VAR(__GLEW_GREMEDY_string_marker) - -#endif /* GL_GREMEDY_string_marker */ - -/* --------------------- GL_HP_convolution_border_modes -------------------- */ - -#ifndef GL_HP_convolution_border_modes -#define GL_HP_convolution_border_modes 1 - -#define GLEW_HP_convolution_border_modes GLEW_GET_VAR(__GLEW_HP_convolution_border_modes) - -#endif /* GL_HP_convolution_border_modes */ - -/* ------------------------- GL_HP_image_transform ------------------------- */ - -#ifndef GL_HP_image_transform -#define GL_HP_image_transform 1 - -typedef void (GLAPIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERFHPPROC) (GLenum target, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERIHPPROC) (GLenum target, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint* params); - -#define glGetImageTransformParameterfvHP GLEW_GET_FUN(__glewGetImageTransformParameterfvHP) -#define glGetImageTransformParameterivHP GLEW_GET_FUN(__glewGetImageTransformParameterivHP) -#define glImageTransformParameterfHP GLEW_GET_FUN(__glewImageTransformParameterfHP) -#define glImageTransformParameterfvHP GLEW_GET_FUN(__glewImageTransformParameterfvHP) -#define glImageTransformParameteriHP GLEW_GET_FUN(__glewImageTransformParameteriHP) -#define glImageTransformParameterivHP GLEW_GET_FUN(__glewImageTransformParameterivHP) - -#define GLEW_HP_image_transform GLEW_GET_VAR(__GLEW_HP_image_transform) - -#endif /* GL_HP_image_transform */ - -/* -------------------------- GL_HP_occlusion_test ------------------------- */ - -#ifndef GL_HP_occlusion_test -#define GL_HP_occlusion_test 1 - -#define GLEW_HP_occlusion_test GLEW_GET_VAR(__GLEW_HP_occlusion_test) - -#endif /* GL_HP_occlusion_test */ - -/* ------------------------- GL_HP_texture_lighting ------------------------ */ - -#ifndef GL_HP_texture_lighting -#define GL_HP_texture_lighting 1 - -#define GLEW_HP_texture_lighting GLEW_GET_VAR(__GLEW_HP_texture_lighting) - -#endif /* GL_HP_texture_lighting */ - -/* --------------------------- GL_IBM_cull_vertex -------------------------- */ - -#ifndef GL_IBM_cull_vertex -#define GL_IBM_cull_vertex 1 - -#define GL_CULL_VERTEX_IBM 103050 - -#define GLEW_IBM_cull_vertex GLEW_GET_VAR(__GLEW_IBM_cull_vertex) - -#endif /* GL_IBM_cull_vertex */ - -/* ---------------------- GL_IBM_multimode_draw_arrays --------------------- */ - -#ifndef GL_IBM_multimode_draw_arrays -#define GL_IBM_multimode_draw_arrays 1 - -typedef void (GLAPIENTRY * PFNGLMULTIMODEDRAWARRAYSIBMPROC) (const GLenum* mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); -typedef void (GLAPIENTRY * PFNGLMULTIMODEDRAWELEMENTSIBMPROC) (const GLenum* mode, const GLsizei *count, GLenum type, const GLvoid * const *indices, GLsizei primcount, GLint modestride); - -#define glMultiModeDrawArraysIBM GLEW_GET_FUN(__glewMultiModeDrawArraysIBM) -#define glMultiModeDrawElementsIBM GLEW_GET_FUN(__glewMultiModeDrawElementsIBM) - -#define GLEW_IBM_multimode_draw_arrays GLEW_GET_VAR(__GLEW_IBM_multimode_draw_arrays) - -#endif /* GL_IBM_multimode_draw_arrays */ - -/* ------------------------- GL_IBM_rasterpos_clip ------------------------- */ - -#ifndef GL_IBM_rasterpos_clip -#define GL_IBM_rasterpos_clip 1 - -#define GL_RASTER_POSITION_UNCLIPPED_IBM 103010 - -#define GLEW_IBM_rasterpos_clip GLEW_GET_VAR(__GLEW_IBM_rasterpos_clip) - -#endif /* GL_IBM_rasterpos_clip */ - -/* --------------------------- GL_IBM_static_data -------------------------- */ - -#ifndef GL_IBM_static_data -#define GL_IBM_static_data 1 - -#define GL_ALL_STATIC_DATA_IBM 103060 -#define GL_STATIC_VERTEX_ARRAY_IBM 103061 - -#define GLEW_IBM_static_data GLEW_GET_VAR(__GLEW_IBM_static_data) - -#endif /* GL_IBM_static_data */ - -/* --------------------- GL_IBM_texture_mirrored_repeat -------------------- */ - -#ifndef GL_IBM_texture_mirrored_repeat -#define GL_IBM_texture_mirrored_repeat 1 - -#define GL_MIRRORED_REPEAT_IBM 0x8370 - -#define GLEW_IBM_texture_mirrored_repeat GLEW_GET_VAR(__GLEW_IBM_texture_mirrored_repeat) - -#endif /* GL_IBM_texture_mirrored_repeat */ - -/* ----------------------- GL_IBM_vertex_array_lists ----------------------- */ - -#ifndef GL_IBM_vertex_array_lists -#define GL_IBM_vertex_array_lists 1 - -#define GL_VERTEX_ARRAY_LIST_IBM 103070 -#define GL_NORMAL_ARRAY_LIST_IBM 103071 -#define GL_COLOR_ARRAY_LIST_IBM 103072 -#define GL_INDEX_ARRAY_LIST_IBM 103073 -#define GL_TEXTURE_COORD_ARRAY_LIST_IBM 103074 -#define GL_EDGE_FLAG_ARRAY_LIST_IBM 103075 -#define GL_FOG_COORDINATE_ARRAY_LIST_IBM 103076 -#define GL_SECONDARY_COLOR_ARRAY_LIST_IBM 103077 -#define GL_VERTEX_ARRAY_LIST_STRIDE_IBM 103080 -#define GL_NORMAL_ARRAY_LIST_STRIDE_IBM 103081 -#define GL_COLOR_ARRAY_LIST_STRIDE_IBM 103082 -#define GL_INDEX_ARRAY_LIST_STRIDE_IBM 103083 -#define GL_TEXTURE_COORD_ARRAY_LIST_STRIDE_IBM 103084 -#define GL_EDGE_FLAG_ARRAY_LIST_STRIDE_IBM 103085 -#define GL_FOG_COORDINATE_ARRAY_LIST_STRIDE_IBM 103086 -#define GL_SECONDARY_COLOR_ARRAY_LIST_STRIDE_IBM 103087 - -typedef void (GLAPIENTRY * PFNGLCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGPOINTERLISTIBMPROC) (GLint stride, const GLboolean ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLFOGCOORDPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLINDEXPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTERLISTIBMPROC) (GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const GLvoid ** pointer, GLint ptrstride); - -#define glColorPointerListIBM GLEW_GET_FUN(__glewColorPointerListIBM) -#define glEdgeFlagPointerListIBM GLEW_GET_FUN(__glewEdgeFlagPointerListIBM) -#define glFogCoordPointerListIBM GLEW_GET_FUN(__glewFogCoordPointerListIBM) -#define glIndexPointerListIBM GLEW_GET_FUN(__glewIndexPointerListIBM) -#define glNormalPointerListIBM GLEW_GET_FUN(__glewNormalPointerListIBM) -#define glSecondaryColorPointerListIBM GLEW_GET_FUN(__glewSecondaryColorPointerListIBM) -#define glTexCoordPointerListIBM GLEW_GET_FUN(__glewTexCoordPointerListIBM) -#define glVertexPointerListIBM GLEW_GET_FUN(__glewVertexPointerListIBM) - -#define GLEW_IBM_vertex_array_lists GLEW_GET_VAR(__GLEW_IBM_vertex_array_lists) - -#endif /* GL_IBM_vertex_array_lists */ - -/* -------------------------- GL_INGR_color_clamp -------------------------- */ - -#ifndef GL_INGR_color_clamp -#define GL_INGR_color_clamp 1 - -#define GL_RED_MIN_CLAMP_INGR 0x8560 -#define GL_GREEN_MIN_CLAMP_INGR 0x8561 -#define GL_BLUE_MIN_CLAMP_INGR 0x8562 -#define GL_ALPHA_MIN_CLAMP_INGR 0x8563 -#define GL_RED_MAX_CLAMP_INGR 0x8564 -#define GL_GREEN_MAX_CLAMP_INGR 0x8565 -#define GL_BLUE_MAX_CLAMP_INGR 0x8566 -#define GL_ALPHA_MAX_CLAMP_INGR 0x8567 - -#define GLEW_INGR_color_clamp GLEW_GET_VAR(__GLEW_INGR_color_clamp) - -#endif /* GL_INGR_color_clamp */ - -/* ------------------------- GL_INGR_interlace_read ------------------------ */ - -#ifndef GL_INGR_interlace_read -#define GL_INGR_interlace_read 1 - -#define GL_INTERLACE_READ_INGR 0x8568 - -#define GLEW_INGR_interlace_read GLEW_GET_VAR(__GLEW_INGR_interlace_read) - -#endif /* GL_INGR_interlace_read */ - -/* -------------------------- GL_INTEL_map_texture ------------------------- */ - -#ifndef GL_INTEL_map_texture -#define GL_INTEL_map_texture 1 - -#define GL_LAYOUT_DEFAULT_INTEL 0 -#define GL_LAYOUT_LINEAR_INTEL 1 -#define GL_LAYOUT_LINEAR_CPU_CACHED_INTEL 2 -#define GL_TEXTURE_MEMORY_LAYOUT_INTEL 0x83FF - -typedef GLvoid * (GLAPIENTRY * PFNGLMAPTEXTURE2DINTELPROC) (GLuint texture, GLint level, GLbitfield access, GLint* stride, GLenum *layout); -typedef void (GLAPIENTRY * PFNGLSYNCTEXTUREINTELPROC) (GLuint texture); -typedef void (GLAPIENTRY * PFNGLUNMAPTEXTURE2DINTELPROC) (GLuint texture, GLint level); - -#define glMapTexture2DINTEL GLEW_GET_FUN(__glewMapTexture2DINTEL) -#define glSyncTextureINTEL GLEW_GET_FUN(__glewSyncTextureINTEL) -#define glUnmapTexture2DINTEL GLEW_GET_FUN(__glewUnmapTexture2DINTEL) - -#define GLEW_INTEL_map_texture GLEW_GET_VAR(__GLEW_INTEL_map_texture) - -#endif /* GL_INTEL_map_texture */ - -/* ------------------------ GL_INTEL_parallel_arrays ----------------------- */ - -#ifndef GL_INTEL_parallel_arrays -#define GL_INTEL_parallel_arrays 1 - -#define GL_PARALLEL_ARRAYS_INTEL 0x83F4 -#define GL_VERTEX_ARRAY_PARALLEL_POINTERS_INTEL 0x83F5 -#define GL_NORMAL_ARRAY_PARALLEL_POINTERS_INTEL 0x83F6 -#define GL_COLOR_ARRAY_PARALLEL_POINTERS_INTEL 0x83F7 -#define GL_TEXTURE_COORD_ARRAY_PARALLEL_POINTERS_INTEL 0x83F8 - -typedef void (GLAPIENTRY * PFNGLCOLORPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); -typedef void (GLAPIENTRY * PFNGLNORMALPOINTERVINTELPROC) (GLenum type, const void** pointer); -typedef void (GLAPIENTRY * PFNGLTEXCOORDPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXPOINTERVINTELPROC) (GLint size, GLenum type, const void** pointer); - -#define glColorPointervINTEL GLEW_GET_FUN(__glewColorPointervINTEL) -#define glNormalPointervINTEL GLEW_GET_FUN(__glewNormalPointervINTEL) -#define glTexCoordPointervINTEL GLEW_GET_FUN(__glewTexCoordPointervINTEL) -#define glVertexPointervINTEL GLEW_GET_FUN(__glewVertexPointervINTEL) - -#define GLEW_INTEL_parallel_arrays GLEW_GET_VAR(__GLEW_INTEL_parallel_arrays) - -#endif /* GL_INTEL_parallel_arrays */ - -/* ------------------------ GL_INTEL_texture_scissor ----------------------- */ - -#ifndef GL_INTEL_texture_scissor -#define GL_INTEL_texture_scissor 1 - -typedef void (GLAPIENTRY * PFNGLTEXSCISSORFUNCINTELPROC) (GLenum target, GLenum lfunc, GLenum hfunc); -typedef void (GLAPIENTRY * PFNGLTEXSCISSORINTELPROC) (GLenum target, GLclampf tlow, GLclampf thigh); - -#define glTexScissorFuncINTEL GLEW_GET_FUN(__glewTexScissorFuncINTEL) -#define glTexScissorINTEL GLEW_GET_FUN(__glewTexScissorINTEL) - -#define GLEW_INTEL_texture_scissor GLEW_GET_VAR(__GLEW_INTEL_texture_scissor) - -#endif /* GL_INTEL_texture_scissor */ - -/* ------------------------------ GL_KHR_debug ----------------------------- */ - -#ifndef GL_KHR_debug -#define GL_KHR_debug 1 - -#define GL_CONTEXT_FLAG_DEBUG_BIT 0x00000002 -#define GL_STACK_OVERFLOW 0x0503 -#define GL_STACK_UNDERFLOW 0x0504 -#define GL_DEBUG_OUTPUT_SYNCHRONOUS 0x8242 -#define GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH 0x8243 -#define GL_DEBUG_CALLBACK_FUNCTION 0x8244 -#define GL_DEBUG_CALLBACK_USER_PARAM 0x8245 -#define GL_DEBUG_SOURCE_API 0x8246 -#define GL_DEBUG_SOURCE_WINDOW_SYSTEM 0x8247 -#define GL_DEBUG_SOURCE_SHADER_COMPILER 0x8248 -#define GL_DEBUG_SOURCE_THIRD_PARTY 0x8249 -#define GL_DEBUG_SOURCE_APPLICATION 0x824A -#define GL_DEBUG_SOURCE_OTHER 0x824B -#define GL_DEBUG_TYPE_ERROR 0x824C -#define GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR 0x824D -#define GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR 0x824E -#define GL_DEBUG_TYPE_PORTABILITY 0x824F -#define GL_DEBUG_TYPE_PERFORMANCE 0x8250 -#define GL_DEBUG_TYPE_OTHER 0x8251 -#define GL_DEBUG_TYPE_MARKER 0x8268 -#define GL_DEBUG_TYPE_PUSH_GROUP 0x8269 -#define GL_DEBUG_TYPE_POP_GROUP 0x826A -#define GL_DEBUG_SEVERITY_NOTIFICATION 0x826B -#define GL_MAX_DEBUG_GROUP_STACK_DEPTH 0x826C -#define GL_DEBUG_GROUP_STACK_DEPTH 0x826D -#define GL_BUFFER 0x82E0 -#define GL_SHADER 0x82E1 -#define GL_PROGRAM 0x82E2 -#define GL_QUERY 0x82E3 -#define GL_PROGRAM_PIPELINE 0x82E4 -#define GL_SAMPLER 0x82E6 -#define GL_DISPLAY_LIST 0x82E7 -#define GL_MAX_LABEL_LENGTH 0x82E8 -#define GL_MAX_DEBUG_MESSAGE_LENGTH 0x9143 -#define GL_MAX_DEBUG_LOGGED_MESSAGES 0x9144 -#define GL_DEBUG_LOGGED_MESSAGES 0x9145 -#define GL_DEBUG_SEVERITY_HIGH 0x9146 -#define GL_DEBUG_SEVERITY_MEDIUM 0x9147 -#define GL_DEBUG_SEVERITY_LOW 0x9148 -#define GL_DEBUG_OUTPUT 0x92E0 - -typedef void (APIENTRY *GLDEBUGPROC)(GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* message, GLvoid* userParam); - -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECALLBACKPROC) (GLDEBUGPROC callback, const GLvoid *userParam); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGECONTROLPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint* ids, GLboolean enabled); -typedef void (GLAPIENTRY * PFNGLDEBUGMESSAGEINSERTPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* buf); -typedef GLuint (GLAPIENTRY * PFNGLGETDEBUGMESSAGELOGPROC) (GLuint count, GLsizei bufsize, GLenum* sources, GLenum* types, GLuint* ids, GLenum* severities, GLsizei* lengths, GLchar* messageLog); -typedef void (GLAPIENTRY * PFNGLGETOBJECTLABELPROC) (GLenum identifier, GLuint name, GLsizei bufSize, GLsizei* length, GLchar *label); -typedef void (GLAPIENTRY * PFNGLGETOBJECTPTRLABELPROC) (void* ptr, GLsizei bufSize, GLsizei* length, GLchar *label); -typedef void (GLAPIENTRY * PFNGLOBJECTLABELPROC) (GLenum identifier, GLuint name, GLsizei length, const GLchar* label); -typedef void (GLAPIENTRY * PFNGLOBJECTPTRLABELPROC) (void* ptr, GLsizei length, const GLchar* label); -typedef void (GLAPIENTRY * PFNGLPOPDEBUGGROUPPROC) (void); -typedef void (GLAPIENTRY * PFNGLPUSHDEBUGGROUPPROC) (GLenum source, GLuint id, GLsizei length, const GLchar * message); - -#define glDebugMessageCallback GLEW_GET_FUN(__glewDebugMessageCallback) -#define glDebugMessageControl GLEW_GET_FUN(__glewDebugMessageControl) -#define glDebugMessageInsert GLEW_GET_FUN(__glewDebugMessageInsert) -#define glGetDebugMessageLog GLEW_GET_FUN(__glewGetDebugMessageLog) -#define glGetObjectLabel GLEW_GET_FUN(__glewGetObjectLabel) -#define glGetObjectPtrLabel GLEW_GET_FUN(__glewGetObjectPtrLabel) -#define glObjectLabel GLEW_GET_FUN(__glewObjectLabel) -#define glObjectPtrLabel GLEW_GET_FUN(__glewObjectPtrLabel) -#define glPopDebugGroup GLEW_GET_FUN(__glewPopDebugGroup) -#define glPushDebugGroup GLEW_GET_FUN(__glewPushDebugGroup) - -#define GLEW_KHR_debug GLEW_GET_VAR(__GLEW_KHR_debug) - -#endif /* GL_KHR_debug */ - -/* ------------------ GL_KHR_texture_compression_astc_ldr ------------------ */ - -#ifndef GL_KHR_texture_compression_astc_ldr -#define GL_KHR_texture_compression_astc_ldr 1 - -#define GL_COMPRESSED_RGBA_ASTC_4x4_KHR 0x93B0 -#define GL_COMPRESSED_RGBA_ASTC_5x4_KHR 0x93B1 -#define GL_COMPRESSED_RGBA_ASTC_5x5_KHR 0x93B2 -#define GL_COMPRESSED_RGBA_ASTC_6x5_KHR 0x93B3 -#define GL_COMPRESSED_RGBA_ASTC_6x6_KHR 0x93B4 -#define GL_COMPRESSED_RGBA_ASTC_8x5_KHR 0x93B5 -#define GL_COMPRESSED_RGBA_ASTC_8x6_KHR 0x93B6 -#define GL_COMPRESSED_RGBA_ASTC_8x8_KHR 0x93B7 -#define GL_COMPRESSED_RGBA_ASTC_10x5_KHR 0x93B8 -#define GL_COMPRESSED_RGBA_ASTC_10x6_KHR 0x93B9 -#define GL_COMPRESSED_RGBA_ASTC_10x8_KHR 0x93BA -#define GL_COMPRESSED_RGBA_ASTC_10x10_KHR 0x93BB -#define GL_COMPRESSED_RGBA_ASTC_12x10_KHR 0x93BC -#define GL_COMPRESSED_RGBA_ASTC_12x12_KHR 0x93BD -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_4x4_KHR 0x93D0 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_5x4_KHR 0x93D1 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_5x5_KHR 0x93D2 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_6x5_KHR 0x93D3 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_6x6_KHR 0x93D4 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_8x5_KHR 0x93D5 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_8x6_KHR 0x93D6 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_8x8_KHR 0x93D7 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_10x5_KHR 0x93D8 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_10x6_KHR 0x93D9 -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_10x8_KHR 0x93DA -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_10x10_KHR 0x93DB -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_12x10_KHR 0x93DC -#define GL_COMPRESSED_SRGB8_ALPHA8_ASTC_12x12_KHR 0x93DD - -#define GLEW_KHR_texture_compression_astc_ldr GLEW_GET_VAR(__GLEW_KHR_texture_compression_astc_ldr) - -#endif /* GL_KHR_texture_compression_astc_ldr */ - -/* -------------------------- GL_KTX_buffer_region ------------------------- */ - -#ifndef GL_KTX_buffer_region -#define GL_KTX_buffer_region 1 - -#define GL_KTX_FRONT_REGION 0x0 -#define GL_KTX_BACK_REGION 0x1 -#define GL_KTX_Z_REGION 0x2 -#define GL_KTX_STENCIL_REGION 0x3 - -typedef GLuint (GLAPIENTRY * PFNGLBUFFERREGIONENABLEDPROC) (void); -typedef void (GLAPIENTRY * PFNGLDELETEBUFFERREGIONPROC) (GLenum region); -typedef void (GLAPIENTRY * PFNGLDRAWBUFFERREGIONPROC) (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height, GLint xDest, GLint yDest); -typedef GLuint (GLAPIENTRY * PFNGLNEWBUFFERREGIONPROC) (GLenum region); -typedef void (GLAPIENTRY * PFNGLREADBUFFERREGIONPROC) (GLuint region, GLint x, GLint y, GLsizei width, GLsizei height); - -#define glBufferRegionEnabled GLEW_GET_FUN(__glewBufferRegionEnabled) -#define glDeleteBufferRegion GLEW_GET_FUN(__glewDeleteBufferRegion) -#define glDrawBufferRegion GLEW_GET_FUN(__glewDrawBufferRegion) -#define glNewBufferRegion GLEW_GET_FUN(__glewNewBufferRegion) -#define glReadBufferRegion GLEW_GET_FUN(__glewReadBufferRegion) - -#define GLEW_KTX_buffer_region GLEW_GET_VAR(__GLEW_KTX_buffer_region) - -#endif /* GL_KTX_buffer_region */ - -/* ------------------------- GL_MESAX_texture_stack ------------------------ */ - -#ifndef GL_MESAX_texture_stack -#define GL_MESAX_texture_stack 1 - -#define GL_TEXTURE_1D_STACK_MESAX 0x8759 -#define GL_TEXTURE_2D_STACK_MESAX 0x875A -#define GL_PROXY_TEXTURE_1D_STACK_MESAX 0x875B -#define GL_PROXY_TEXTURE_2D_STACK_MESAX 0x875C -#define GL_TEXTURE_1D_STACK_BINDING_MESAX 0x875D -#define GL_TEXTURE_2D_STACK_BINDING_MESAX 0x875E - -#define GLEW_MESAX_texture_stack GLEW_GET_VAR(__GLEW_MESAX_texture_stack) - -#endif /* GL_MESAX_texture_stack */ - -/* -------------------------- GL_MESA_pack_invert -------------------------- */ - -#ifndef GL_MESA_pack_invert -#define GL_MESA_pack_invert 1 - -#define GL_PACK_INVERT_MESA 0x8758 - -#define GLEW_MESA_pack_invert GLEW_GET_VAR(__GLEW_MESA_pack_invert) - -#endif /* GL_MESA_pack_invert */ - -/* ------------------------- GL_MESA_resize_buffers ------------------------ */ - -#ifndef GL_MESA_resize_buffers -#define GL_MESA_resize_buffers 1 - -typedef void (GLAPIENTRY * PFNGLRESIZEBUFFERSMESAPROC) (void); - -#define glResizeBuffersMESA GLEW_GET_FUN(__glewResizeBuffersMESA) - -#define GLEW_MESA_resize_buffers GLEW_GET_VAR(__GLEW_MESA_resize_buffers) - -#endif /* GL_MESA_resize_buffers */ - -/* --------------------------- GL_MESA_window_pos -------------------------- */ - -#ifndef GL_MESA_window_pos -#define GL_MESA_window_pos 1 - -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DMESAPROC) (GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2DVMESAPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FMESAPROC) (GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2FVMESAPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IMESAPROC) (GLint x, GLint y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2IVMESAPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SMESAPROC) (GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS2SVMESAPROC) (const GLshort* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DMESAPROC) (GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3DVMESAPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FMESAPROC) (GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3FVMESAPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IMESAPROC) (GLint x, GLint y, GLint z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3IVMESAPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SMESAPROC) (GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS3SVMESAPROC) (const GLshort* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4DMESAPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4DVMESAPROC) (const GLdouble* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4FMESAPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4FVMESAPROC) (const GLfloat* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4IMESAPROC) (GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4IVMESAPROC) (const GLint* p); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4SMESAPROC) (GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLWINDOWPOS4SVMESAPROC) (const GLshort* p); - -#define glWindowPos2dMESA GLEW_GET_FUN(__glewWindowPos2dMESA) -#define glWindowPos2dvMESA GLEW_GET_FUN(__glewWindowPos2dvMESA) -#define glWindowPos2fMESA GLEW_GET_FUN(__glewWindowPos2fMESA) -#define glWindowPos2fvMESA GLEW_GET_FUN(__glewWindowPos2fvMESA) -#define glWindowPos2iMESA GLEW_GET_FUN(__glewWindowPos2iMESA) -#define glWindowPos2ivMESA GLEW_GET_FUN(__glewWindowPos2ivMESA) -#define glWindowPos2sMESA GLEW_GET_FUN(__glewWindowPos2sMESA) -#define glWindowPos2svMESA GLEW_GET_FUN(__glewWindowPos2svMESA) -#define glWindowPos3dMESA GLEW_GET_FUN(__glewWindowPos3dMESA) -#define glWindowPos3dvMESA GLEW_GET_FUN(__glewWindowPos3dvMESA) -#define glWindowPos3fMESA GLEW_GET_FUN(__glewWindowPos3fMESA) -#define glWindowPos3fvMESA GLEW_GET_FUN(__glewWindowPos3fvMESA) -#define glWindowPos3iMESA GLEW_GET_FUN(__glewWindowPos3iMESA) -#define glWindowPos3ivMESA GLEW_GET_FUN(__glewWindowPos3ivMESA) -#define glWindowPos3sMESA GLEW_GET_FUN(__glewWindowPos3sMESA) -#define glWindowPos3svMESA GLEW_GET_FUN(__glewWindowPos3svMESA) -#define glWindowPos4dMESA GLEW_GET_FUN(__glewWindowPos4dMESA) -#define glWindowPos4dvMESA GLEW_GET_FUN(__glewWindowPos4dvMESA) -#define glWindowPos4fMESA GLEW_GET_FUN(__glewWindowPos4fMESA) -#define glWindowPos4fvMESA GLEW_GET_FUN(__glewWindowPos4fvMESA) -#define glWindowPos4iMESA GLEW_GET_FUN(__glewWindowPos4iMESA) -#define glWindowPos4ivMESA GLEW_GET_FUN(__glewWindowPos4ivMESA) -#define glWindowPos4sMESA GLEW_GET_FUN(__glewWindowPos4sMESA) -#define glWindowPos4svMESA GLEW_GET_FUN(__glewWindowPos4svMESA) - -#define GLEW_MESA_window_pos GLEW_GET_VAR(__GLEW_MESA_window_pos) - -#endif /* GL_MESA_window_pos */ - -/* ------------------------- GL_MESA_ycbcr_texture ------------------------- */ - -#ifndef GL_MESA_ycbcr_texture -#define GL_MESA_ycbcr_texture 1 - -#define GL_UNSIGNED_SHORT_8_8_MESA 0x85BA -#define GL_UNSIGNED_SHORT_8_8_REV_MESA 0x85BB -#define GL_YCBCR_MESA 0x8757 - -#define GLEW_MESA_ycbcr_texture GLEW_GET_VAR(__GLEW_MESA_ycbcr_texture) - -#endif /* GL_MESA_ycbcr_texture */ - -/* ----------------------- GL_NVX_conditional_render ----------------------- */ - -#ifndef GL_NVX_conditional_render -#define GL_NVX_conditional_render 1 - -typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERNVXPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERNVXPROC) (void); - -#define glBeginConditionalRenderNVX GLEW_GET_FUN(__glewBeginConditionalRenderNVX) -#define glEndConditionalRenderNVX GLEW_GET_FUN(__glewEndConditionalRenderNVX) - -#define GLEW_NVX_conditional_render GLEW_GET_VAR(__GLEW_NVX_conditional_render) - -#endif /* GL_NVX_conditional_render */ - -/* ------------------------- GL_NVX_gpu_memory_info ------------------------ */ - -#ifndef GL_NVX_gpu_memory_info -#define GL_NVX_gpu_memory_info 1 - -#define GL_GPU_MEMORY_INFO_DEDICATED_VIDMEM_NVX 0x9047 -#define GL_GPU_MEMORY_INFO_TOTAL_AVAILABLE_MEMORY_NVX 0x9048 -#define GL_GPU_MEMORY_INFO_CURRENT_AVAILABLE_VIDMEM_NVX 0x9049 -#define GL_GPU_MEMORY_INFO_EVICTION_COUNT_NVX 0x904A -#define GL_GPU_MEMORY_INFO_EVICTED_MEMORY_NVX 0x904B - -#define GLEW_NVX_gpu_memory_info GLEW_GET_VAR(__GLEW_NVX_gpu_memory_info) - -#endif /* GL_NVX_gpu_memory_info */ - -/* ------------------- GL_NV_bindless_multi_draw_indirect ------------------ */ - -#ifndef GL_NV_bindless_multi_draw_indirect -#define GL_NV_bindless_multi_draw_indirect 1 - -typedef void (GLAPIENTRY * PFNGLMULTIDRAWARRAYSINDIRECTBINDLESSNVPROC) (GLenum mode, const GLvoid *indirect, GLsizei drawCount, GLsizei stride, GLint vertexBufferCount); -typedef void (GLAPIENTRY * PFNGLMULTIDRAWELEMENTSINDIRECTBINDLESSNVPROC) (GLenum mode, GLenum type, const GLvoid *indirect, GLsizei drawCount, GLsizei stride, GLint vertexBufferCount); - -#define glMultiDrawArraysIndirectBindlessNV GLEW_GET_FUN(__glewMultiDrawArraysIndirectBindlessNV) -#define glMultiDrawElementsIndirectBindlessNV GLEW_GET_FUN(__glewMultiDrawElementsIndirectBindlessNV) - -#define GLEW_NV_bindless_multi_draw_indirect GLEW_GET_VAR(__GLEW_NV_bindless_multi_draw_indirect) - -#endif /* GL_NV_bindless_multi_draw_indirect */ - -/* ------------------------- GL_NV_bindless_texture ------------------------ */ - -#ifndef GL_NV_bindless_texture -#define GL_NV_bindless_texture 1 - -typedef GLuint64 (GLAPIENTRY * PFNGLGETIMAGEHANDLENVPROC) (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); -typedef GLuint64 (GLAPIENTRY * PFNGLGETTEXTUREHANDLENVPROC) (GLuint texture); -typedef GLuint64 (GLAPIENTRY * PFNGLGETTEXTURESAMPLERHANDLENVPROC) (GLuint texture, GLuint sampler); -typedef GLboolean (GLAPIENTRY * PFNGLISIMAGEHANDLERESIDENTNVPROC) (GLuint64 handle); -typedef GLboolean (GLAPIENTRY * PFNGLISTEXTUREHANDLERESIDENTNVPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLMAKEIMAGEHANDLENONRESIDENTNVPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLMAKEIMAGEHANDLERESIDENTNVPROC) (GLuint64 handle, GLenum access); -typedef void (GLAPIENTRY * PFNGLMAKETEXTUREHANDLENONRESIDENTNVPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLMAKETEXTUREHANDLERESIDENTNVPROC) (GLuint64 handle); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMHANDLEUI64NVPROC) (GLuint program, GLint location, GLuint64 value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMHANDLEUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64* values); -typedef void (GLAPIENTRY * PFNGLUNIFORMHANDLEUI64NVPROC) (GLint location, GLuint64 value); -typedef void (GLAPIENTRY * PFNGLUNIFORMHANDLEUI64VNVPROC) (GLint location, GLsizei count, const GLuint64* value); - -#define glGetImageHandleNV GLEW_GET_FUN(__glewGetImageHandleNV) -#define glGetTextureHandleNV GLEW_GET_FUN(__glewGetTextureHandleNV) -#define glGetTextureSamplerHandleNV GLEW_GET_FUN(__glewGetTextureSamplerHandleNV) -#define glIsImageHandleResidentNV GLEW_GET_FUN(__glewIsImageHandleResidentNV) -#define glIsTextureHandleResidentNV GLEW_GET_FUN(__glewIsTextureHandleResidentNV) -#define glMakeImageHandleNonResidentNV GLEW_GET_FUN(__glewMakeImageHandleNonResidentNV) -#define glMakeImageHandleResidentNV GLEW_GET_FUN(__glewMakeImageHandleResidentNV) -#define glMakeTextureHandleNonResidentNV GLEW_GET_FUN(__glewMakeTextureHandleNonResidentNV) -#define glMakeTextureHandleResidentNV GLEW_GET_FUN(__glewMakeTextureHandleResidentNV) -#define glProgramUniformHandleui64NV GLEW_GET_FUN(__glewProgramUniformHandleui64NV) -#define glProgramUniformHandleui64vNV GLEW_GET_FUN(__glewProgramUniformHandleui64vNV) -#define glUniformHandleui64NV GLEW_GET_FUN(__glewUniformHandleui64NV) -#define glUniformHandleui64vNV GLEW_GET_FUN(__glewUniformHandleui64vNV) - -#define GLEW_NV_bindless_texture GLEW_GET_VAR(__GLEW_NV_bindless_texture) - -#endif /* GL_NV_bindless_texture */ - -/* --------------------- GL_NV_blend_equation_advanced --------------------- */ - -#ifndef GL_NV_blend_equation_advanced -#define GL_NV_blend_equation_advanced 1 - -#define GL_BLEND_PREMULTIPLIED_SRC_NV 0x9280 -#define GL_BLEND_OVERLAP_NV 0x9281 -#define GL_UNCORRELATED_NV 0x9282 -#define GL_DISJOINT_NV 0x9283 -#define GL_CONJOINT_NV 0x9284 -#define GL_BLEND_ADVANCED_COHERENT_NV 0x9285 -#define GL_SRC_NV 0x9286 -#define GL_DST_NV 0x9287 -#define GL_SRC_OVER_NV 0x9288 -#define GL_DST_OVER_NV 0x9289 -#define GL_SRC_IN_NV 0x928A -#define GL_DST_IN_NV 0x928B -#define GL_SRC_OUT_NV 0x928C -#define GL_DST_OUT_NV 0x928D -#define GL_SRC_ATOP_NV 0x928E -#define GL_DST_ATOP_NV 0x928F -#define GL_PLUS_NV 0x9291 -#define GL_PLUS_DARKER_NV 0x9292 -#define GL_MULTIPLY_NV 0x9294 -#define GL_SCREEN_NV 0x9295 -#define GL_OVERLAY_NV 0x9296 -#define GL_DARKEN_NV 0x9297 -#define GL_LIGHTEN_NV 0x9298 -#define GL_COLORDODGE_NV 0x9299 -#define GL_COLORBURN_NV 0x929A -#define GL_HARDLIGHT_NV 0x929B -#define GL_SOFTLIGHT_NV 0x929C -#define GL_DIFFERENCE_NV 0x929E -#define GL_MINUS_NV 0x929F -#define GL_EXCLUSION_NV 0x92A0 -#define GL_CONTRAST_NV 0x92A1 -#define GL_INVERT_RGB_NV 0x92A3 -#define GL_LINEARDODGE_NV 0x92A4 -#define GL_LINEARBURN_NV 0x92A5 -#define GL_VIVIDLIGHT_NV 0x92A6 -#define GL_LINEARLIGHT_NV 0x92A7 -#define GL_PINLIGHT_NV 0x92A8 -#define GL_HARDMIX_NV 0x92A9 -#define GL_HSL_HUE_NV 0x92AD -#define GL_HSL_SATURATION_NV 0x92AE -#define GL_HSL_COLOR_NV 0x92AF -#define GL_HSL_LUMINOSITY_NV 0x92B0 -#define GL_PLUS_CLAMPED_NV 0x92B1 -#define GL_PLUS_CLAMPED_ALPHA_NV 0x92B2 -#define GL_MINUS_CLAMPED_NV 0x92B3 -#define GL_INVERT_OVG_NV 0x92B4 - -typedef void (GLAPIENTRY * PFNGLBLENDBARRIERNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLBLENDPARAMETERINVPROC) (GLenum pname, GLint value); - -#define glBlendBarrierNV GLEW_GET_FUN(__glewBlendBarrierNV) -#define glBlendParameteriNV GLEW_GET_FUN(__glewBlendParameteriNV) - -#define GLEW_NV_blend_equation_advanced GLEW_GET_VAR(__GLEW_NV_blend_equation_advanced) - -#endif /* GL_NV_blend_equation_advanced */ - -/* ----------------- GL_NV_blend_equation_advanced_coherent ---------------- */ - -#ifndef GL_NV_blend_equation_advanced_coherent -#define GL_NV_blend_equation_advanced_coherent 1 - -#define GLEW_NV_blend_equation_advanced_coherent GLEW_GET_VAR(__GLEW_NV_blend_equation_advanced_coherent) - -#endif /* GL_NV_blend_equation_advanced_coherent */ - -/* --------------------------- GL_NV_blend_square -------------------------- */ - -#ifndef GL_NV_blend_square -#define GL_NV_blend_square 1 - -#define GLEW_NV_blend_square GLEW_GET_VAR(__GLEW_NV_blend_square) - -#endif /* GL_NV_blend_square */ - -/* ------------------------- GL_NV_compute_program5 ------------------------ */ - -#ifndef GL_NV_compute_program5 -#define GL_NV_compute_program5 1 - -#define GL_COMPUTE_PROGRAM_NV 0x90FB -#define GL_COMPUTE_PROGRAM_PARAMETER_BUFFER_NV 0x90FC - -#define GLEW_NV_compute_program5 GLEW_GET_VAR(__GLEW_NV_compute_program5) - -#endif /* GL_NV_compute_program5 */ - -/* ------------------------ GL_NV_conditional_render ----------------------- */ - -#ifndef GL_NV_conditional_render -#define GL_NV_conditional_render 1 - -#define GL_QUERY_WAIT_NV 0x8E13 -#define GL_QUERY_NO_WAIT_NV 0x8E14 -#define GL_QUERY_BY_REGION_WAIT_NV 0x8E15 -#define GL_QUERY_BY_REGION_NO_WAIT_NV 0x8E16 - -typedef void (GLAPIENTRY * PFNGLBEGINCONDITIONALRENDERNVPROC) (GLuint id, GLenum mode); -typedef void (GLAPIENTRY * PFNGLENDCONDITIONALRENDERNVPROC) (void); - -#define glBeginConditionalRenderNV GLEW_GET_FUN(__glewBeginConditionalRenderNV) -#define glEndConditionalRenderNV GLEW_GET_FUN(__glewEndConditionalRenderNV) - -#define GLEW_NV_conditional_render GLEW_GET_VAR(__GLEW_NV_conditional_render) - -#endif /* GL_NV_conditional_render */ - -/* ----------------------- GL_NV_copy_depth_to_color ----------------------- */ - -#ifndef GL_NV_copy_depth_to_color -#define GL_NV_copy_depth_to_color 1 - -#define GL_DEPTH_STENCIL_TO_RGBA_NV 0x886E -#define GL_DEPTH_STENCIL_TO_BGRA_NV 0x886F - -#define GLEW_NV_copy_depth_to_color GLEW_GET_VAR(__GLEW_NV_copy_depth_to_color) - -#endif /* GL_NV_copy_depth_to_color */ - -/* ---------------------------- GL_NV_copy_image --------------------------- */ - -#ifndef GL_NV_copy_image -#define GL_NV_copy_image 1 - -typedef void (GLAPIENTRY * PFNGLCOPYIMAGESUBDATANVPROC) (GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); - -#define glCopyImageSubDataNV GLEW_GET_FUN(__glewCopyImageSubDataNV) - -#define GLEW_NV_copy_image GLEW_GET_VAR(__GLEW_NV_copy_image) - -#endif /* GL_NV_copy_image */ - -/* -------------------------- GL_NV_deep_texture3D ------------------------- */ - -#ifndef GL_NV_deep_texture3D -#define GL_NV_deep_texture3D 1 - -#define GL_MAX_DEEP_3D_TEXTURE_WIDTH_HEIGHT_NV 0x90D0 -#define GL_MAX_DEEP_3D_TEXTURE_DEPTH_NV 0x90D1 - -#define GLEW_NV_deep_texture3D GLEW_GET_VAR(__GLEW_NV_deep_texture3D) - -#endif /* GL_NV_deep_texture3D */ - -/* ------------------------ GL_NV_depth_buffer_float ----------------------- */ - -#ifndef GL_NV_depth_buffer_float -#define GL_NV_depth_buffer_float 1 - -#define GL_DEPTH_COMPONENT32F_NV 0x8DAB -#define GL_DEPTH32F_STENCIL8_NV 0x8DAC -#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV_NV 0x8DAD -#define GL_DEPTH_BUFFER_FLOAT_MODE_NV 0x8DAF - -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHDNVPROC) (GLdouble depth); -typedef void (GLAPIENTRY * PFNGLDEPTHBOUNDSDNVPROC) (GLdouble zmin, GLdouble zmax); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEDNVPROC) (GLdouble zNear, GLdouble zFar); - -#define glClearDepthdNV GLEW_GET_FUN(__glewClearDepthdNV) -#define glDepthBoundsdNV GLEW_GET_FUN(__glewDepthBoundsdNV) -#define glDepthRangedNV GLEW_GET_FUN(__glewDepthRangedNV) - -#define GLEW_NV_depth_buffer_float GLEW_GET_VAR(__GLEW_NV_depth_buffer_float) - -#endif /* GL_NV_depth_buffer_float */ - -/* --------------------------- GL_NV_depth_clamp --------------------------- */ - -#ifndef GL_NV_depth_clamp -#define GL_NV_depth_clamp 1 - -#define GL_DEPTH_CLAMP_NV 0x864F - -#define GLEW_NV_depth_clamp GLEW_GET_VAR(__GLEW_NV_depth_clamp) - -#endif /* GL_NV_depth_clamp */ - -/* ---------------------- GL_NV_depth_range_unclamped ---------------------- */ - -#ifndef GL_NV_depth_range_unclamped -#define GL_NV_depth_range_unclamped 1 - -#define GL_SAMPLE_COUNT_BITS_NV 0x8864 -#define GL_CURRENT_SAMPLE_COUNT_QUERY_NV 0x8865 -#define GL_QUERY_RESULT_NV 0x8866 -#define GL_QUERY_RESULT_AVAILABLE_NV 0x8867 -#define GL_SAMPLE_COUNT_NV 0x8914 - -#define GLEW_NV_depth_range_unclamped GLEW_GET_VAR(__GLEW_NV_depth_range_unclamped) - -#endif /* GL_NV_depth_range_unclamped */ - -/* --------------------------- GL_NV_draw_texture -------------------------- */ - -#ifndef GL_NV_draw_texture -#define GL_NV_draw_texture 1 - -typedef void (GLAPIENTRY * PFNGLDRAWTEXTURENVPROC) (GLuint texture, GLuint sampler, GLfloat x0, GLfloat y0, GLfloat x1, GLfloat y1, GLfloat z, GLfloat s0, GLfloat t0, GLfloat s1, GLfloat t1); - -#define glDrawTextureNV GLEW_GET_FUN(__glewDrawTextureNV) - -#define GLEW_NV_draw_texture GLEW_GET_VAR(__GLEW_NV_draw_texture) - -#endif /* GL_NV_draw_texture */ - -/* ---------------------------- GL_NV_evaluators --------------------------- */ - -#ifndef GL_NV_evaluators -#define GL_NV_evaluators 1 - -#define GL_EVAL_2D_NV 0x86C0 -#define GL_EVAL_TRIANGULAR_2D_NV 0x86C1 -#define GL_MAP_TESSELLATION_NV 0x86C2 -#define GL_MAP_ATTRIB_U_ORDER_NV 0x86C3 -#define GL_MAP_ATTRIB_V_ORDER_NV 0x86C4 -#define GL_EVAL_FRACTIONAL_TESSELLATION_NV 0x86C5 -#define GL_EVAL_VERTEX_ATTRIB0_NV 0x86C6 -#define GL_EVAL_VERTEX_ATTRIB1_NV 0x86C7 -#define GL_EVAL_VERTEX_ATTRIB2_NV 0x86C8 -#define GL_EVAL_VERTEX_ATTRIB3_NV 0x86C9 -#define GL_EVAL_VERTEX_ATTRIB4_NV 0x86CA -#define GL_EVAL_VERTEX_ATTRIB5_NV 0x86CB -#define GL_EVAL_VERTEX_ATTRIB6_NV 0x86CC -#define GL_EVAL_VERTEX_ATTRIB7_NV 0x86CD -#define GL_EVAL_VERTEX_ATTRIB8_NV 0x86CE -#define GL_EVAL_VERTEX_ATTRIB9_NV 0x86CF -#define GL_EVAL_VERTEX_ATTRIB10_NV 0x86D0 -#define GL_EVAL_VERTEX_ATTRIB11_NV 0x86D1 -#define GL_EVAL_VERTEX_ATTRIB12_NV 0x86D2 -#define GL_EVAL_VERTEX_ATTRIB13_NV 0x86D3 -#define GL_EVAL_VERTEX_ATTRIB14_NV 0x86D4 -#define GL_EVAL_VERTEX_ATTRIB15_NV 0x86D5 -#define GL_MAX_MAP_TESSELLATION_NV 0x86D6 -#define GL_MAX_RATIONAL_EVAL_ORDER_NV 0x86D7 - -typedef void (GLAPIENTRY * PFNGLEVALMAPSNVPROC) (GLenum target, GLenum mode); -typedef void (GLAPIENTRY * PFNGLGETMAPATTRIBPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMAPATTRIBPARAMETERIVNVPROC) (GLenum target, GLuint index, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, GLvoid *points); -typedef void (GLAPIENTRY * PFNGLGETMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const GLvoid *points); -typedef void (GLAPIENTRY * PFNGLMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, const GLint* params); - -#define glEvalMapsNV GLEW_GET_FUN(__glewEvalMapsNV) -#define glGetMapAttribParameterfvNV GLEW_GET_FUN(__glewGetMapAttribParameterfvNV) -#define glGetMapAttribParameterivNV GLEW_GET_FUN(__glewGetMapAttribParameterivNV) -#define glGetMapControlPointsNV GLEW_GET_FUN(__glewGetMapControlPointsNV) -#define glGetMapParameterfvNV GLEW_GET_FUN(__glewGetMapParameterfvNV) -#define glGetMapParameterivNV GLEW_GET_FUN(__glewGetMapParameterivNV) -#define glMapControlPointsNV GLEW_GET_FUN(__glewMapControlPointsNV) -#define glMapParameterfvNV GLEW_GET_FUN(__glewMapParameterfvNV) -#define glMapParameterivNV GLEW_GET_FUN(__glewMapParameterivNV) - -#define GLEW_NV_evaluators GLEW_GET_VAR(__GLEW_NV_evaluators) - -#endif /* GL_NV_evaluators */ - -/* ----------------------- GL_NV_explicit_multisample ---------------------- */ - -#ifndef GL_NV_explicit_multisample -#define GL_NV_explicit_multisample 1 - -#define GL_SAMPLE_POSITION_NV 0x8E50 -#define GL_SAMPLE_MASK_NV 0x8E51 -#define GL_SAMPLE_MASK_VALUE_NV 0x8E52 -#define GL_TEXTURE_BINDING_RENDERBUFFER_NV 0x8E53 -#define GL_TEXTURE_RENDERBUFFER_DATA_STORE_BINDING_NV 0x8E54 -#define GL_TEXTURE_RENDERBUFFER_NV 0x8E55 -#define GL_SAMPLER_RENDERBUFFER_NV 0x8E56 -#define GL_INT_SAMPLER_RENDERBUFFER_NV 0x8E57 -#define GL_UNSIGNED_INT_SAMPLER_RENDERBUFFER_NV 0x8E58 -#define GL_MAX_SAMPLE_MASK_WORDS_NV 0x8E59 - -typedef void (GLAPIENTRY * PFNGLGETMULTISAMPLEFVNVPROC) (GLenum pname, GLuint index, GLfloat* val); -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKINDEXEDNVPROC) (GLuint index, GLbitfield mask); -typedef void (GLAPIENTRY * PFNGLTEXRENDERBUFFERNVPROC) (GLenum target, GLuint renderbuffer); - -#define glGetMultisamplefvNV GLEW_GET_FUN(__glewGetMultisamplefvNV) -#define glSampleMaskIndexedNV GLEW_GET_FUN(__glewSampleMaskIndexedNV) -#define glTexRenderbufferNV GLEW_GET_FUN(__glewTexRenderbufferNV) - -#define GLEW_NV_explicit_multisample GLEW_GET_VAR(__GLEW_NV_explicit_multisample) - -#endif /* GL_NV_explicit_multisample */ - -/* ------------------------------ GL_NV_fence ------------------------------ */ - -#ifndef GL_NV_fence -#define GL_NV_fence 1 - -#define GL_ALL_COMPLETED_NV 0x84F2 -#define GL_FENCE_STATUS_NV 0x84F3 -#define GL_FENCE_CONDITION_NV 0x84F4 - -typedef void (GLAPIENTRY * PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint* fences); -typedef void (GLAPIENTRY * PFNGLFINISHFENCENVPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLGENFENCESNVPROC) (GLsizei n, GLuint* fences); -typedef void (GLAPIENTRY * PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISFENCENVPROC) (GLuint fence); -typedef void (GLAPIENTRY * PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); -typedef GLboolean (GLAPIENTRY * PFNGLTESTFENCENVPROC) (GLuint fence); - -#define glDeleteFencesNV GLEW_GET_FUN(__glewDeleteFencesNV) -#define glFinishFenceNV GLEW_GET_FUN(__glewFinishFenceNV) -#define glGenFencesNV GLEW_GET_FUN(__glewGenFencesNV) -#define glGetFenceivNV GLEW_GET_FUN(__glewGetFenceivNV) -#define glIsFenceNV GLEW_GET_FUN(__glewIsFenceNV) -#define glSetFenceNV GLEW_GET_FUN(__glewSetFenceNV) -#define glTestFenceNV GLEW_GET_FUN(__glewTestFenceNV) - -#define GLEW_NV_fence GLEW_GET_VAR(__GLEW_NV_fence) - -#endif /* GL_NV_fence */ - -/* --------------------------- GL_NV_float_buffer -------------------------- */ - -#ifndef GL_NV_float_buffer -#define GL_NV_float_buffer 1 - -#define GL_FLOAT_R_NV 0x8880 -#define GL_FLOAT_RG_NV 0x8881 -#define GL_FLOAT_RGB_NV 0x8882 -#define GL_FLOAT_RGBA_NV 0x8883 -#define GL_FLOAT_R16_NV 0x8884 -#define GL_FLOAT_R32_NV 0x8885 -#define GL_FLOAT_RG16_NV 0x8886 -#define GL_FLOAT_RG32_NV 0x8887 -#define GL_FLOAT_RGB16_NV 0x8888 -#define GL_FLOAT_RGB32_NV 0x8889 -#define GL_FLOAT_RGBA16_NV 0x888A -#define GL_FLOAT_RGBA32_NV 0x888B -#define GL_TEXTURE_FLOAT_COMPONENTS_NV 0x888C -#define GL_FLOAT_CLEAR_COLOR_VALUE_NV 0x888D -#define GL_FLOAT_RGBA_MODE_NV 0x888E - -#define GLEW_NV_float_buffer GLEW_GET_VAR(__GLEW_NV_float_buffer) - -#endif /* GL_NV_float_buffer */ - -/* --------------------------- GL_NV_fog_distance -------------------------- */ - -#ifndef GL_NV_fog_distance -#define GL_NV_fog_distance 1 - -#define GL_FOG_DISTANCE_MODE_NV 0x855A -#define GL_EYE_RADIAL_NV 0x855B -#define GL_EYE_PLANE_ABSOLUTE_NV 0x855C - -#define GLEW_NV_fog_distance GLEW_GET_VAR(__GLEW_NV_fog_distance) - -#endif /* GL_NV_fog_distance */ - -/* ------------------------- GL_NV_fragment_program ------------------------ */ - -#ifndef GL_NV_fragment_program -#define GL_NV_fragment_program 1 - -#define GL_MAX_FRAGMENT_PROGRAM_LOCAL_PARAMETERS_NV 0x8868 -#define GL_FRAGMENT_PROGRAM_NV 0x8870 -#define GL_MAX_TEXTURE_COORDS_NV 0x8871 -#define GL_MAX_TEXTURE_IMAGE_UNITS_NV 0x8872 -#define GL_FRAGMENT_PROGRAM_BINDING_NV 0x8873 -#define GL_PROGRAM_ERROR_STRING_NV 0x8874 - -typedef void (GLAPIENTRY * PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLdouble *params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLfloat *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4DNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, const GLdouble v[]); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4FNVPROC) (GLuint id, GLsizei len, const GLubyte* name, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC) (GLuint id, GLsizei len, const GLubyte* name, const GLfloat v[]); - -#define glGetProgramNamedParameterdvNV GLEW_GET_FUN(__glewGetProgramNamedParameterdvNV) -#define glGetProgramNamedParameterfvNV GLEW_GET_FUN(__glewGetProgramNamedParameterfvNV) -#define glProgramNamedParameter4dNV GLEW_GET_FUN(__glewProgramNamedParameter4dNV) -#define glProgramNamedParameter4dvNV GLEW_GET_FUN(__glewProgramNamedParameter4dvNV) -#define glProgramNamedParameter4fNV GLEW_GET_FUN(__glewProgramNamedParameter4fNV) -#define glProgramNamedParameter4fvNV GLEW_GET_FUN(__glewProgramNamedParameter4fvNV) - -#define GLEW_NV_fragment_program GLEW_GET_VAR(__GLEW_NV_fragment_program) - -#endif /* GL_NV_fragment_program */ - -/* ------------------------ GL_NV_fragment_program2 ------------------------ */ - -#ifndef GL_NV_fragment_program2 -#define GL_NV_fragment_program2 1 - -#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 -#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 -#define GL_MAX_PROGRAM_IF_DEPTH_NV 0x88F6 -#define GL_MAX_PROGRAM_LOOP_DEPTH_NV 0x88F7 -#define GL_MAX_PROGRAM_LOOP_COUNT_NV 0x88F8 - -#define GLEW_NV_fragment_program2 GLEW_GET_VAR(__GLEW_NV_fragment_program2) - -#endif /* GL_NV_fragment_program2 */ - -/* ------------------------ GL_NV_fragment_program4 ------------------------ */ - -#ifndef GL_NV_fragment_program4 -#define GL_NV_fragment_program4 1 - -#define GLEW_NV_fragment_program4 GLEW_GET_VAR(__GLEW_NV_fragment_program4) - -#endif /* GL_NV_fragment_program4 */ - -/* --------------------- GL_NV_fragment_program_option --------------------- */ - -#ifndef GL_NV_fragment_program_option -#define GL_NV_fragment_program_option 1 - -#define GLEW_NV_fragment_program_option GLEW_GET_VAR(__GLEW_NV_fragment_program_option) - -#endif /* GL_NV_fragment_program_option */ - -/* ----------------- GL_NV_framebuffer_multisample_coverage ---------------- */ - -#ifndef GL_NV_framebuffer_multisample_coverage -#define GL_NV_framebuffer_multisample_coverage 1 - -#define GL_RENDERBUFFER_COVERAGE_SAMPLES_NV 0x8CAB -#define GL_RENDERBUFFER_COLOR_SAMPLES_NV 0x8E10 -#define GL_MAX_MULTISAMPLE_COVERAGE_MODES_NV 0x8E11 -#define GL_MULTISAMPLE_COVERAGE_MODES_NV 0x8E12 - -typedef void (GLAPIENTRY * PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); - -#define glRenderbufferStorageMultisampleCoverageNV GLEW_GET_FUN(__glewRenderbufferStorageMultisampleCoverageNV) - -#define GLEW_NV_framebuffer_multisample_coverage GLEW_GET_VAR(__GLEW_NV_framebuffer_multisample_coverage) - -#endif /* GL_NV_framebuffer_multisample_coverage */ - -/* ------------------------ GL_NV_geometry_program4 ------------------------ */ - -#ifndef GL_NV_geometry_program4 -#define GL_NV_geometry_program4 1 - -#define GL_GEOMETRY_PROGRAM_NV 0x8C26 -#define GL_MAX_PROGRAM_OUTPUT_VERTICES_NV 0x8C27 -#define GL_MAX_PROGRAM_TOTAL_OUTPUT_COMPONENTS_NV 0x8C28 - -typedef void (GLAPIENTRY * PFNGLPROGRAMVERTEXLIMITNVPROC) (GLenum target, GLint limit); - -#define glProgramVertexLimitNV GLEW_GET_FUN(__glewProgramVertexLimitNV) - -#define GLEW_NV_geometry_program4 GLEW_GET_VAR(__GLEW_NV_geometry_program4) - -#endif /* GL_NV_geometry_program4 */ - -/* ------------------------- GL_NV_geometry_shader4 ------------------------ */ - -#ifndef GL_NV_geometry_shader4 -#define GL_NV_geometry_shader4 1 - -#define GLEW_NV_geometry_shader4 GLEW_GET_VAR(__GLEW_NV_geometry_shader4) - -#endif /* GL_NV_geometry_shader4 */ - -/* --------------------------- GL_NV_gpu_program4 -------------------------- */ - -#ifndef GL_NV_gpu_program4 -#define GL_NV_gpu_program4 1 - -#define GL_MIN_PROGRAM_TEXEL_OFFSET_NV 0x8904 -#define GL_MAX_PROGRAM_TEXEL_OFFSET_NV 0x8905 -#define GL_PROGRAM_ATTRIB_COMPONENTS_NV 0x8906 -#define GL_PROGRAM_RESULT_COMPONENTS_NV 0x8907 -#define GL_MAX_PROGRAM_ATTRIB_COMPONENTS_NV 0x8908 -#define GL_MAX_PROGRAM_RESULT_COMPONENTS_NV 0x8909 -#define GL_MAX_PROGRAM_GENERIC_ATTRIBS_NV 0x8DA5 -#define GL_MAX_PROGRAM_GENERIC_RESULTS_NV 0x8DA6 - -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); - -#define glProgramEnvParameterI4iNV GLEW_GET_FUN(__glewProgramEnvParameterI4iNV) -#define glProgramEnvParameterI4ivNV GLEW_GET_FUN(__glewProgramEnvParameterI4ivNV) -#define glProgramEnvParameterI4uiNV GLEW_GET_FUN(__glewProgramEnvParameterI4uiNV) -#define glProgramEnvParameterI4uivNV GLEW_GET_FUN(__glewProgramEnvParameterI4uivNV) -#define glProgramEnvParametersI4ivNV GLEW_GET_FUN(__glewProgramEnvParametersI4ivNV) -#define glProgramEnvParametersI4uivNV GLEW_GET_FUN(__glewProgramEnvParametersI4uivNV) -#define glProgramLocalParameterI4iNV GLEW_GET_FUN(__glewProgramLocalParameterI4iNV) -#define glProgramLocalParameterI4ivNV GLEW_GET_FUN(__glewProgramLocalParameterI4ivNV) -#define glProgramLocalParameterI4uiNV GLEW_GET_FUN(__glewProgramLocalParameterI4uiNV) -#define glProgramLocalParameterI4uivNV GLEW_GET_FUN(__glewProgramLocalParameterI4uivNV) -#define glProgramLocalParametersI4ivNV GLEW_GET_FUN(__glewProgramLocalParametersI4ivNV) -#define glProgramLocalParametersI4uivNV GLEW_GET_FUN(__glewProgramLocalParametersI4uivNV) - -#define GLEW_NV_gpu_program4 GLEW_GET_VAR(__GLEW_NV_gpu_program4) - -#endif /* GL_NV_gpu_program4 */ - -/* --------------------------- GL_NV_gpu_program5 -------------------------- */ - -#ifndef GL_NV_gpu_program5 -#define GL_NV_gpu_program5 1 - -#define GL_MAX_GEOMETRY_PROGRAM_INVOCATIONS_NV 0x8E5A -#define GL_MIN_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5B -#define GL_MAX_FRAGMENT_INTERPOLATION_OFFSET_NV 0x8E5C -#define GL_FRAGMENT_PROGRAM_INTERPOLATION_OFFSET_BITS_NV 0x8E5D -#define GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_NV 0x8E5E -#define GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_NV 0x8E5F - -#define GLEW_NV_gpu_program5 GLEW_GET_VAR(__GLEW_NV_gpu_program5) - -#endif /* GL_NV_gpu_program5 */ - -/* -------------------- GL_NV_gpu_program5_mem_extended -------------------- */ - -#ifndef GL_NV_gpu_program5_mem_extended -#define GL_NV_gpu_program5_mem_extended 1 - -#define GLEW_NV_gpu_program5_mem_extended GLEW_GET_VAR(__GLEW_NV_gpu_program5_mem_extended) - -#endif /* GL_NV_gpu_program5_mem_extended */ - -/* ------------------------- GL_NV_gpu_program_fp64 ------------------------ */ - -#ifndef GL_NV_gpu_program_fp64 -#define GL_NV_gpu_program_fp64 1 - -#define GLEW_NV_gpu_program_fp64 GLEW_GET_VAR(__GLEW_NV_gpu_program_fp64) - -#endif /* GL_NV_gpu_program_fp64 */ - -/* --------------------------- GL_NV_gpu_shader5 --------------------------- */ - -#ifndef GL_NV_gpu_shader5 -#define GL_NV_gpu_shader5 1 - -#define GL_INT64_NV 0x140E -#define GL_UNSIGNED_INT64_NV 0x140F -#define GL_INT8_NV 0x8FE0 -#define GL_INT8_VEC2_NV 0x8FE1 -#define GL_INT8_VEC3_NV 0x8FE2 -#define GL_INT8_VEC4_NV 0x8FE3 -#define GL_INT16_NV 0x8FE4 -#define GL_INT16_VEC2_NV 0x8FE5 -#define GL_INT16_VEC3_NV 0x8FE6 -#define GL_INT16_VEC4_NV 0x8FE7 -#define GL_INT64_VEC2_NV 0x8FE9 -#define GL_INT64_VEC3_NV 0x8FEA -#define GL_INT64_VEC4_NV 0x8FEB -#define GL_UNSIGNED_INT8_NV 0x8FEC -#define GL_UNSIGNED_INT8_VEC2_NV 0x8FED -#define GL_UNSIGNED_INT8_VEC3_NV 0x8FEE -#define GL_UNSIGNED_INT8_VEC4_NV 0x8FEF -#define GL_UNSIGNED_INT16_NV 0x8FF0 -#define GL_UNSIGNED_INT16_VEC2_NV 0x8FF1 -#define GL_UNSIGNED_INT16_VEC3_NV 0x8FF2 -#define GL_UNSIGNED_INT16_VEC4_NV 0x8FF3 -#define GL_UNSIGNED_INT64_VEC2_NV 0x8FF5 -#define GL_UNSIGNED_INT64_VEC3_NV 0x8FF6 -#define GL_UNSIGNED_INT64_VEC4_NV 0x8FF7 -#define GL_FLOAT16_NV 0x8FF8 -#define GL_FLOAT16_VEC2_NV 0x8FF9 -#define GL_FLOAT16_VEC3_NV 0x8FFA -#define GL_FLOAT16_VEC4_NV 0x8FFB - -typedef void (GLAPIENTRY * PFNGLGETUNIFORMI64VNVPROC) (GLuint program, GLint location, GLint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1I64NVPROC) (GLuint program, GLint location, GLint64EXT x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM1UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM2UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM3UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORM4UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1I64NVPROC) (GLint location, GLint64EXT x); -typedef void (GLAPIENTRY * PFNGLUNIFORM1I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UI64NVPROC) (GLint location, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLUNIFORM1UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y); -typedef void (GLAPIENTRY * PFNGLUNIFORM2I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y); -typedef void (GLAPIENTRY * PFNGLUNIFORM2UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); -typedef void (GLAPIENTRY * PFNGLUNIFORM3I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); -typedef void (GLAPIENTRY * PFNGLUNIFORM3UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); -typedef void (GLAPIENTRY * PFNGLUNIFORM4I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); -typedef void (GLAPIENTRY * PFNGLUNIFORM4UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); - -#define glGetUniformi64vNV GLEW_GET_FUN(__glewGetUniformi64vNV) -#define glGetUniformui64vNV GLEW_GET_FUN(__glewGetUniformui64vNV) -#define glProgramUniform1i64NV GLEW_GET_FUN(__glewProgramUniform1i64NV) -#define glProgramUniform1i64vNV GLEW_GET_FUN(__glewProgramUniform1i64vNV) -#define glProgramUniform1ui64NV GLEW_GET_FUN(__glewProgramUniform1ui64NV) -#define glProgramUniform1ui64vNV GLEW_GET_FUN(__glewProgramUniform1ui64vNV) -#define glProgramUniform2i64NV GLEW_GET_FUN(__glewProgramUniform2i64NV) -#define glProgramUniform2i64vNV GLEW_GET_FUN(__glewProgramUniform2i64vNV) -#define glProgramUniform2ui64NV GLEW_GET_FUN(__glewProgramUniform2ui64NV) -#define glProgramUniform2ui64vNV GLEW_GET_FUN(__glewProgramUniform2ui64vNV) -#define glProgramUniform3i64NV GLEW_GET_FUN(__glewProgramUniform3i64NV) -#define glProgramUniform3i64vNV GLEW_GET_FUN(__glewProgramUniform3i64vNV) -#define glProgramUniform3ui64NV GLEW_GET_FUN(__glewProgramUniform3ui64NV) -#define glProgramUniform3ui64vNV GLEW_GET_FUN(__glewProgramUniform3ui64vNV) -#define glProgramUniform4i64NV GLEW_GET_FUN(__glewProgramUniform4i64NV) -#define glProgramUniform4i64vNV GLEW_GET_FUN(__glewProgramUniform4i64vNV) -#define glProgramUniform4ui64NV GLEW_GET_FUN(__glewProgramUniform4ui64NV) -#define glProgramUniform4ui64vNV GLEW_GET_FUN(__glewProgramUniform4ui64vNV) -#define glUniform1i64NV GLEW_GET_FUN(__glewUniform1i64NV) -#define glUniform1i64vNV GLEW_GET_FUN(__glewUniform1i64vNV) -#define glUniform1ui64NV GLEW_GET_FUN(__glewUniform1ui64NV) -#define glUniform1ui64vNV GLEW_GET_FUN(__glewUniform1ui64vNV) -#define glUniform2i64NV GLEW_GET_FUN(__glewUniform2i64NV) -#define glUniform2i64vNV GLEW_GET_FUN(__glewUniform2i64vNV) -#define glUniform2ui64NV GLEW_GET_FUN(__glewUniform2ui64NV) -#define glUniform2ui64vNV GLEW_GET_FUN(__glewUniform2ui64vNV) -#define glUniform3i64NV GLEW_GET_FUN(__glewUniform3i64NV) -#define glUniform3i64vNV GLEW_GET_FUN(__glewUniform3i64vNV) -#define glUniform3ui64NV GLEW_GET_FUN(__glewUniform3ui64NV) -#define glUniform3ui64vNV GLEW_GET_FUN(__glewUniform3ui64vNV) -#define glUniform4i64NV GLEW_GET_FUN(__glewUniform4i64NV) -#define glUniform4i64vNV GLEW_GET_FUN(__glewUniform4i64vNV) -#define glUniform4ui64NV GLEW_GET_FUN(__glewUniform4ui64NV) -#define glUniform4ui64vNV GLEW_GET_FUN(__glewUniform4ui64vNV) - -#define GLEW_NV_gpu_shader5 GLEW_GET_VAR(__GLEW_NV_gpu_shader5) - -#endif /* GL_NV_gpu_shader5 */ - -/* ---------------------------- GL_NV_half_float --------------------------- */ - -#ifndef GL_NV_half_float -#define GL_NV_half_float 1 - -#define GL_HALF_FLOAT_NV 0x140B - -typedef unsigned short GLhalf; - -typedef void (GLAPIENTRY * PFNGLCOLOR3HNVPROC) (GLhalf red, GLhalf green, GLhalf blue); -typedef void (GLAPIENTRY * PFNGLCOLOR3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLCOLOR4HNVPROC) (GLhalf red, GLhalf green, GLhalf blue, GLhalf alpha); -typedef void (GLAPIENTRY * PFNGLCOLOR4HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLFOGCOORDHNVPROC) (GLhalf fog); -typedef void (GLAPIENTRY * PFNGLFOGCOORDHVNVPROC) (const GLhalf* fog); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1HNVPROC) (GLenum target, GLhalf s); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD1HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2HNVPROC) (GLenum target, GLhalf s, GLhalf t); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD2HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3HNVPROC) (GLenum target, GLhalf s, GLhalf t, GLhalf r); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD3HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4HNVPROC) (GLenum target, GLhalf s, GLhalf t, GLhalf r, GLhalf q); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4HVNVPROC) (GLenum target, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLNORMAL3HNVPROC) (GLhalf nx, GLhalf ny, GLhalf nz); -typedef void (GLAPIENTRY * PFNGLNORMAL3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3HNVPROC) (GLhalf red, GLhalf green, GLhalf blue); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLOR3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1HNVPROC) (GLhalf s); -typedef void (GLAPIENTRY * PFNGLTEXCOORD1HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2HNVPROC) (GLhalf s, GLhalf t); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3HNVPROC) (GLhalf s, GLhalf t, GLhalf r); -typedef void (GLAPIENTRY * PFNGLTEXCOORD3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4HNVPROC) (GLhalf s, GLhalf t, GLhalf r, GLhalf q); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEX2HNVPROC) (GLhalf x, GLhalf y); -typedef void (GLAPIENTRY * PFNGLVERTEX2HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEX3HNVPROC) (GLhalf x, GLhalf y, GLhalf z); -typedef void (GLAPIENTRY * PFNGLVERTEX3HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEX4HNVPROC) (GLhalf x, GLhalf y, GLhalf z, GLhalf w); -typedef void (GLAPIENTRY * PFNGLVERTEX4HVNVPROC) (const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1HNVPROC) (GLuint index, GLhalf x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2HNVPROC) (GLuint index, GLhalf x, GLhalf y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3HNVPROC) (GLuint index, GLhalf x, GLhalf y, GLhalf z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4HNVPROC) (GLuint index, GLhalf x, GLhalf y, GLhalf z, GLhalf w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4HVNVPROC) (GLuint index, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4HVNVPROC) (GLuint index, GLsizei n, const GLhalf* v); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTHNVPROC) (GLhalf weight); -typedef void (GLAPIENTRY * PFNGLVERTEXWEIGHTHVNVPROC) (const GLhalf* weight); - -#define glColor3hNV GLEW_GET_FUN(__glewColor3hNV) -#define glColor3hvNV GLEW_GET_FUN(__glewColor3hvNV) -#define glColor4hNV GLEW_GET_FUN(__glewColor4hNV) -#define glColor4hvNV GLEW_GET_FUN(__glewColor4hvNV) -#define glFogCoordhNV GLEW_GET_FUN(__glewFogCoordhNV) -#define glFogCoordhvNV GLEW_GET_FUN(__glewFogCoordhvNV) -#define glMultiTexCoord1hNV GLEW_GET_FUN(__glewMultiTexCoord1hNV) -#define glMultiTexCoord1hvNV GLEW_GET_FUN(__glewMultiTexCoord1hvNV) -#define glMultiTexCoord2hNV GLEW_GET_FUN(__glewMultiTexCoord2hNV) -#define glMultiTexCoord2hvNV GLEW_GET_FUN(__glewMultiTexCoord2hvNV) -#define glMultiTexCoord3hNV GLEW_GET_FUN(__glewMultiTexCoord3hNV) -#define glMultiTexCoord3hvNV GLEW_GET_FUN(__glewMultiTexCoord3hvNV) -#define glMultiTexCoord4hNV GLEW_GET_FUN(__glewMultiTexCoord4hNV) -#define glMultiTexCoord4hvNV GLEW_GET_FUN(__glewMultiTexCoord4hvNV) -#define glNormal3hNV GLEW_GET_FUN(__glewNormal3hNV) -#define glNormal3hvNV GLEW_GET_FUN(__glewNormal3hvNV) -#define glSecondaryColor3hNV GLEW_GET_FUN(__glewSecondaryColor3hNV) -#define glSecondaryColor3hvNV GLEW_GET_FUN(__glewSecondaryColor3hvNV) -#define glTexCoord1hNV GLEW_GET_FUN(__glewTexCoord1hNV) -#define glTexCoord1hvNV GLEW_GET_FUN(__glewTexCoord1hvNV) -#define glTexCoord2hNV GLEW_GET_FUN(__glewTexCoord2hNV) -#define glTexCoord2hvNV GLEW_GET_FUN(__glewTexCoord2hvNV) -#define glTexCoord3hNV GLEW_GET_FUN(__glewTexCoord3hNV) -#define glTexCoord3hvNV GLEW_GET_FUN(__glewTexCoord3hvNV) -#define glTexCoord4hNV GLEW_GET_FUN(__glewTexCoord4hNV) -#define glTexCoord4hvNV GLEW_GET_FUN(__glewTexCoord4hvNV) -#define glVertex2hNV GLEW_GET_FUN(__glewVertex2hNV) -#define glVertex2hvNV GLEW_GET_FUN(__glewVertex2hvNV) -#define glVertex3hNV GLEW_GET_FUN(__glewVertex3hNV) -#define glVertex3hvNV GLEW_GET_FUN(__glewVertex3hvNV) -#define glVertex4hNV GLEW_GET_FUN(__glewVertex4hNV) -#define glVertex4hvNV GLEW_GET_FUN(__glewVertex4hvNV) -#define glVertexAttrib1hNV GLEW_GET_FUN(__glewVertexAttrib1hNV) -#define glVertexAttrib1hvNV GLEW_GET_FUN(__glewVertexAttrib1hvNV) -#define glVertexAttrib2hNV GLEW_GET_FUN(__glewVertexAttrib2hNV) -#define glVertexAttrib2hvNV GLEW_GET_FUN(__glewVertexAttrib2hvNV) -#define glVertexAttrib3hNV GLEW_GET_FUN(__glewVertexAttrib3hNV) -#define glVertexAttrib3hvNV GLEW_GET_FUN(__glewVertexAttrib3hvNV) -#define glVertexAttrib4hNV GLEW_GET_FUN(__glewVertexAttrib4hNV) -#define glVertexAttrib4hvNV GLEW_GET_FUN(__glewVertexAttrib4hvNV) -#define glVertexAttribs1hvNV GLEW_GET_FUN(__glewVertexAttribs1hvNV) -#define glVertexAttribs2hvNV GLEW_GET_FUN(__glewVertexAttribs2hvNV) -#define glVertexAttribs3hvNV GLEW_GET_FUN(__glewVertexAttribs3hvNV) -#define glVertexAttribs4hvNV GLEW_GET_FUN(__glewVertexAttribs4hvNV) -#define glVertexWeighthNV GLEW_GET_FUN(__glewVertexWeighthNV) -#define glVertexWeighthvNV GLEW_GET_FUN(__glewVertexWeighthvNV) - -#define GLEW_NV_half_float GLEW_GET_VAR(__GLEW_NV_half_float) - -#endif /* GL_NV_half_float */ - -/* ------------------------ GL_NV_light_max_exponent ----------------------- */ - -#ifndef GL_NV_light_max_exponent -#define GL_NV_light_max_exponent 1 - -#define GL_MAX_SHININESS_NV 0x8504 -#define GL_MAX_SPOT_EXPONENT_NV 0x8505 - -#define GLEW_NV_light_max_exponent GLEW_GET_VAR(__GLEW_NV_light_max_exponent) - -#endif /* GL_NV_light_max_exponent */ - -/* ----------------------- GL_NV_multisample_coverage ---------------------- */ - -#ifndef GL_NV_multisample_coverage -#define GL_NV_multisample_coverage 1 - -#define GL_COLOR_SAMPLES_NV 0x8E20 - -#define GLEW_NV_multisample_coverage GLEW_GET_VAR(__GLEW_NV_multisample_coverage) - -#endif /* GL_NV_multisample_coverage */ - -/* --------------------- GL_NV_multisample_filter_hint --------------------- */ - -#ifndef GL_NV_multisample_filter_hint -#define GL_NV_multisample_filter_hint 1 - -#define GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 - -#define GLEW_NV_multisample_filter_hint GLEW_GET_VAR(__GLEW_NV_multisample_filter_hint) - -#endif /* GL_NV_multisample_filter_hint */ - -/* ------------------------- GL_NV_occlusion_query ------------------------- */ - -#ifndef GL_NV_occlusion_query -#define GL_NV_occlusion_query 1 - -#define GL_PIXEL_COUNTER_BITS_NV 0x8864 -#define GL_CURRENT_OCCLUSION_QUERY_ID_NV 0x8865 -#define GL_PIXEL_COUNT_NV 0x8866 -#define GL_PIXEL_COUNT_AVAILABLE_NV 0x8867 - -typedef void (GLAPIENTRY * PFNGLBEGINOCCLUSIONQUERYNVPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEOCCLUSIONQUERIESNVPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLENDOCCLUSIONQUERYNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLGENOCCLUSIONQUERIESNVPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETOCCLUSIONQUERYIVNVPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETOCCLUSIONQUERYUIVNVPROC) (GLuint id, GLenum pname, GLuint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISOCCLUSIONQUERYNVPROC) (GLuint id); - -#define glBeginOcclusionQueryNV GLEW_GET_FUN(__glewBeginOcclusionQueryNV) -#define glDeleteOcclusionQueriesNV GLEW_GET_FUN(__glewDeleteOcclusionQueriesNV) -#define glEndOcclusionQueryNV GLEW_GET_FUN(__glewEndOcclusionQueryNV) -#define glGenOcclusionQueriesNV GLEW_GET_FUN(__glewGenOcclusionQueriesNV) -#define glGetOcclusionQueryivNV GLEW_GET_FUN(__glewGetOcclusionQueryivNV) -#define glGetOcclusionQueryuivNV GLEW_GET_FUN(__glewGetOcclusionQueryuivNV) -#define glIsOcclusionQueryNV GLEW_GET_FUN(__glewIsOcclusionQueryNV) - -#define GLEW_NV_occlusion_query GLEW_GET_VAR(__GLEW_NV_occlusion_query) - -#endif /* GL_NV_occlusion_query */ - -/* ----------------------- GL_NV_packed_depth_stencil ---------------------- */ - -#ifndef GL_NV_packed_depth_stencil -#define GL_NV_packed_depth_stencil 1 - -#define GL_DEPTH_STENCIL_NV 0x84F9 -#define GL_UNSIGNED_INT_24_8_NV 0x84FA - -#define GLEW_NV_packed_depth_stencil GLEW_GET_VAR(__GLEW_NV_packed_depth_stencil) - -#endif /* GL_NV_packed_depth_stencil */ - -/* --------------------- GL_NV_parameter_buffer_object --------------------- */ - -#ifndef GL_NV_parameter_buffer_object -#define GL_NV_parameter_buffer_object 1 - -#define GL_MAX_PROGRAM_PARAMETER_BUFFER_BINDINGS_NV 0x8DA0 -#define GL_MAX_PROGRAM_PARAMETER_BUFFER_SIZE_NV 0x8DA1 -#define GL_VERTEX_PROGRAM_PARAMETER_BUFFER_NV 0x8DA2 -#define GL_GEOMETRY_PROGRAM_PARAMETER_BUFFER_NV 0x8DA3 -#define GL_FRAGMENT_PROGRAM_PARAMETER_BUFFER_NV 0x8DA4 - -typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLuint *params); -typedef void (GLAPIENTRY * PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC) (GLenum target, GLuint buffer, GLuint index, GLsizei count, const GLfloat *params); - -#define glProgramBufferParametersIivNV GLEW_GET_FUN(__glewProgramBufferParametersIivNV) -#define glProgramBufferParametersIuivNV GLEW_GET_FUN(__glewProgramBufferParametersIuivNV) -#define glProgramBufferParametersfvNV GLEW_GET_FUN(__glewProgramBufferParametersfvNV) - -#define GLEW_NV_parameter_buffer_object GLEW_GET_VAR(__GLEW_NV_parameter_buffer_object) - -#endif /* GL_NV_parameter_buffer_object */ - -/* --------------------- GL_NV_parameter_buffer_object2 -------------------- */ - -#ifndef GL_NV_parameter_buffer_object2 -#define GL_NV_parameter_buffer_object2 1 - -#define GLEW_NV_parameter_buffer_object2 GLEW_GET_VAR(__GLEW_NV_parameter_buffer_object2) - -#endif /* GL_NV_parameter_buffer_object2 */ - -/* -------------------------- GL_NV_path_rendering ------------------------- */ - -#ifndef GL_NV_path_rendering -#define GL_NV_path_rendering 1 - -#define GL_CLOSE_PATH_NV 0x00 -#define GL_BOLD_BIT_NV 0x01 -#define GL_GLYPH_WIDTH_BIT_NV 0x01 -#define GL_GLYPH_HEIGHT_BIT_NV 0x02 -#define GL_ITALIC_BIT_NV 0x02 -#define GL_MOVE_TO_NV 0x02 -#define GL_RELATIVE_MOVE_TO_NV 0x03 -#define GL_LINE_TO_NV 0x04 -#define GL_GLYPH_HORIZONTAL_BEARING_X_BIT_NV 0x04 -#define GL_RELATIVE_LINE_TO_NV 0x05 -#define GL_HORIZONTAL_LINE_TO_NV 0x06 -#define GL_RELATIVE_HORIZONTAL_LINE_TO_NV 0x07 -#define GL_GLYPH_HORIZONTAL_BEARING_Y_BIT_NV 0x08 -#define GL_VERTICAL_LINE_TO_NV 0x08 -#define GL_RELATIVE_VERTICAL_LINE_TO_NV 0x09 -#define GL_QUADRATIC_CURVE_TO_NV 0x0A -#define GL_RELATIVE_QUADRATIC_CURVE_TO_NV 0x0B -#define GL_CUBIC_CURVE_TO_NV 0x0C -#define GL_RELATIVE_CUBIC_CURVE_TO_NV 0x0D -#define GL_SMOOTH_QUADRATIC_CURVE_TO_NV 0x0E -#define GL_RELATIVE_SMOOTH_QUADRATIC_CURVE_TO_NV 0x0F -#define GL_GLYPH_HORIZONTAL_BEARING_ADVANCE_BIT_NV 0x10 -#define GL_SMOOTH_CUBIC_CURVE_TO_NV 0x10 -#define GL_RELATIVE_SMOOTH_CUBIC_CURVE_TO_NV 0x11 -#define GL_SMALL_CCW_ARC_TO_NV 0x12 -#define GL_RELATIVE_SMALL_CCW_ARC_TO_NV 0x13 -#define GL_SMALL_CW_ARC_TO_NV 0x14 -#define GL_RELATIVE_SMALL_CW_ARC_TO_NV 0x15 -#define GL_LARGE_CCW_ARC_TO_NV 0x16 -#define GL_RELATIVE_LARGE_CCW_ARC_TO_NV 0x17 -#define GL_LARGE_CW_ARC_TO_NV 0x18 -#define GL_RELATIVE_LARGE_CW_ARC_TO_NV 0x19 -#define GL_GLYPH_VERTICAL_BEARING_X_BIT_NV 0x20 -#define GL_GLYPH_VERTICAL_BEARING_Y_BIT_NV 0x40 -#define GL_GLYPH_VERTICAL_BEARING_ADVANCE_BIT_NV 0x80 -#define GL_RESTART_PATH_NV 0xF0 -#define GL_DUP_FIRST_CUBIC_CURVE_TO_NV 0xF2 -#define GL_DUP_LAST_CUBIC_CURVE_TO_NV 0xF4 -#define GL_RECT_NV 0xF6 -#define GL_CIRCULAR_CCW_ARC_TO_NV 0xF8 -#define GL_CIRCULAR_CW_ARC_TO_NV 0xFA -#define GL_CIRCULAR_TANGENT_ARC_TO_NV 0xFC -#define GL_ARC_TO_NV 0xFE -#define GL_RELATIVE_ARC_TO_NV 0xFF -#define GL_GLYPH_HAS_KERNING_BIT_NV 0x100 -#define GL_PRIMARY_COLOR 0x8577 -#define GL_PATH_FORMAT_SVG_NV 0x9070 -#define GL_PATH_FORMAT_PS_NV 0x9071 -#define GL_STANDARD_FONT_NAME_NV 0x9072 -#define GL_SYSTEM_FONT_NAME_NV 0x9073 -#define GL_FILE_NAME_NV 0x9074 -#define GL_PATH_STROKE_WIDTH_NV 0x9075 -#define GL_PATH_END_CAPS_NV 0x9076 -#define GL_PATH_INITIAL_END_CAP_NV 0x9077 -#define GL_PATH_TERMINAL_END_CAP_NV 0x9078 -#define GL_PATH_JOIN_STYLE_NV 0x9079 -#define GL_PATH_MITER_LIMIT_NV 0x907A -#define GL_PATH_DASH_CAPS_NV 0x907B -#define GL_PATH_INITIAL_DASH_CAP_NV 0x907C -#define GL_PATH_TERMINAL_DASH_CAP_NV 0x907D -#define GL_PATH_DASH_OFFSET_NV 0x907E -#define GL_PATH_CLIENT_LENGTH_NV 0x907F -#define GL_PATH_FILL_MODE_NV 0x9080 -#define GL_PATH_FILL_MASK_NV 0x9081 -#define GL_PATH_FILL_COVER_MODE_NV 0x9082 -#define GL_PATH_STROKE_COVER_MODE_NV 0x9083 -#define GL_PATH_STROKE_MASK_NV 0x9084 -#define GL_COUNT_UP_NV 0x9088 -#define GL_COUNT_DOWN_NV 0x9089 -#define GL_PATH_OBJECT_BOUNDING_BOX_NV 0x908A -#define GL_CONVEX_HULL_NV 0x908B -#define GL_BOUNDING_BOX_NV 0x908D -#define GL_TRANSLATE_X_NV 0x908E -#define GL_TRANSLATE_Y_NV 0x908F -#define GL_TRANSLATE_2D_NV 0x9090 -#define GL_TRANSLATE_3D_NV 0x9091 -#define GL_AFFINE_2D_NV 0x9092 -#define GL_AFFINE_3D_NV 0x9094 -#define GL_TRANSPOSE_AFFINE_2D_NV 0x9096 -#define GL_TRANSPOSE_AFFINE_3D_NV 0x9098 -#define GL_UTF8_NV 0x909A -#define GL_UTF16_NV 0x909B -#define GL_BOUNDING_BOX_OF_BOUNDING_BOXES_NV 0x909C -#define GL_PATH_COMMAND_COUNT_NV 0x909D -#define GL_PATH_COORD_COUNT_NV 0x909E -#define GL_PATH_DASH_ARRAY_COUNT_NV 0x909F -#define GL_PATH_COMPUTED_LENGTH_NV 0x90A0 -#define GL_PATH_FILL_BOUNDING_BOX_NV 0x90A1 -#define GL_PATH_STROKE_BOUNDING_BOX_NV 0x90A2 -#define GL_SQUARE_NV 0x90A3 -#define GL_ROUND_NV 0x90A4 -#define GL_TRIANGULAR_NV 0x90A5 -#define GL_BEVEL_NV 0x90A6 -#define GL_MITER_REVERT_NV 0x90A7 -#define GL_MITER_TRUNCATE_NV 0x90A8 -#define GL_SKIP_MISSING_GLYPH_NV 0x90A9 -#define GL_USE_MISSING_GLYPH_NV 0x90AA -#define GL_PATH_ERROR_POSITION_NV 0x90AB -#define GL_PATH_FOG_GEN_MODE_NV 0x90AC -#define GL_ACCUM_ADJACENT_PAIRS_NV 0x90AD -#define GL_ADJACENT_PAIRS_NV 0x90AE -#define GL_FIRST_TO_REST_NV 0x90AF -#define GL_PATH_GEN_MODE_NV 0x90B0 -#define GL_PATH_GEN_COEFF_NV 0x90B1 -#define GL_PATH_GEN_COLOR_FORMAT_NV 0x90B2 -#define GL_PATH_GEN_COMPONENTS_NV 0x90B3 -#define GL_PATH_DASH_OFFSET_RESET_NV 0x90B4 -#define GL_MOVE_TO_RESETS_NV 0x90B5 -#define GL_MOVE_TO_CONTINUES_NV 0x90B6 -#define GL_PATH_STENCIL_FUNC_NV 0x90B7 -#define GL_PATH_STENCIL_REF_NV 0x90B8 -#define GL_PATH_STENCIL_VALUE_MASK_NV 0x90B9 -#define GL_PATH_STENCIL_DEPTH_OFFSET_FACTOR_NV 0x90BD -#define GL_PATH_STENCIL_DEPTH_OFFSET_UNITS_NV 0x90BE -#define GL_PATH_COVER_DEPTH_FUNC_NV 0x90BF -#define GL_FONT_X_MIN_BOUNDS_BIT_NV 0x00010000 -#define GL_FONT_Y_MIN_BOUNDS_BIT_NV 0x00020000 -#define GL_FONT_X_MAX_BOUNDS_BIT_NV 0x00040000 -#define GL_FONT_Y_MAX_BOUNDS_BIT_NV 0x00080000 -#define GL_FONT_UNITS_PER_EM_BIT_NV 0x00100000 -#define GL_FONT_ASCENDER_BIT_NV 0x00200000 -#define GL_FONT_DESCENDER_BIT_NV 0x00400000 -#define GL_FONT_HEIGHT_BIT_NV 0x00800000 -#define GL_FONT_MAX_ADVANCE_WIDTH_BIT_NV 0x01000000 -#define GL_FONT_MAX_ADVANCE_HEIGHT_BIT_NV 0x02000000 -#define GL_FONT_UNDERLINE_POSITION_BIT_NV 0x04000000 -#define GL_FONT_UNDERLINE_THICKNESS_BIT_NV 0x08000000 -#define GL_FONT_HAS_KERNING_BIT_NV 0x10000000 - -typedef void (GLAPIENTRY * PFNGLCOPYPATHNVPROC) (GLuint resultPath, GLuint srcPath); -typedef void (GLAPIENTRY * PFNGLCOVERFILLPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void* paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); -typedef void (GLAPIENTRY * PFNGLCOVERFILLPATHNVPROC) (GLuint path, GLenum coverMode); -typedef void (GLAPIENTRY * PFNGLCOVERSTROKEPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void* paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); -typedef void (GLAPIENTRY * PFNGLCOVERSTROKEPATHNVPROC) (GLuint name, GLenum coverMode); -typedef void (GLAPIENTRY * PFNGLDELETEPATHSNVPROC) (GLuint path, GLsizei range); -typedef GLuint (GLAPIENTRY * PFNGLGENPATHSNVPROC) (GLsizei range); -typedef void (GLAPIENTRY * PFNGLGETPATHCOLORGENFVNVPROC) (GLenum color, GLenum pname, GLfloat* value); -typedef void (GLAPIENTRY * PFNGLGETPATHCOLORGENIVNVPROC) (GLenum color, GLenum pname, GLint* value); -typedef void (GLAPIENTRY * PFNGLGETPATHCOMMANDSNVPROC) (GLuint name, GLubyte* commands); -typedef void (GLAPIENTRY * PFNGLGETPATHCOORDSNVPROC) (GLuint name, GLfloat* coords); -typedef void (GLAPIENTRY * PFNGLGETPATHDASHARRAYNVPROC) (GLuint name, GLfloat* dashArray); -typedef GLfloat (GLAPIENTRY * PFNGLGETPATHLENGTHNVPROC) (GLuint path, GLsizei startSegment, GLsizei numSegments); -typedef void (GLAPIENTRY * PFNGLGETPATHMETRICRANGENVPROC) (GLbitfield metricQueryMask, GLuint fistPathName, GLsizei numPaths, GLsizei stride, GLfloat* metrics); -typedef void (GLAPIENTRY * PFNGLGETPATHMETRICSNVPROC) (GLbitfield metricQueryMask, GLsizei numPaths, GLenum pathNameType, const void* paths, GLuint pathBase, GLsizei stride, GLfloat *metrics); -typedef void (GLAPIENTRY * PFNGLGETPATHPARAMETERFVNVPROC) (GLuint name, GLenum param, GLfloat* value); -typedef void (GLAPIENTRY * PFNGLGETPATHPARAMETERIVNVPROC) (GLuint name, GLenum param, GLint* value); -typedef void (GLAPIENTRY * PFNGLGETPATHSPACINGNVPROC) (GLenum pathListMode, GLsizei numPaths, GLenum pathNameType, const void* paths, GLuint pathBase, GLfloat advanceScale, GLfloat kerningScale, GLenum transformType, GLfloat *returnedSpacing); -typedef void (GLAPIENTRY * PFNGLGETPATHTEXGENFVNVPROC) (GLenum texCoordSet, GLenum pname, GLfloat* value); -typedef void (GLAPIENTRY * PFNGLGETPATHTEXGENIVNVPROC) (GLenum texCoordSet, GLenum pname, GLint* value); -typedef void (GLAPIENTRY * PFNGLINTERPOLATEPATHSNVPROC) (GLuint resultPath, GLuint pathA, GLuint pathB, GLfloat weight); -typedef GLboolean (GLAPIENTRY * PFNGLISPATHNVPROC) (GLuint path); -typedef GLboolean (GLAPIENTRY * PFNGLISPOINTINFILLPATHNVPROC) (GLuint path, GLuint mask, GLfloat x, GLfloat y); -typedef GLboolean (GLAPIENTRY * PFNGLISPOINTINSTROKEPATHNVPROC) (GLuint path, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLPATHCOLORGENNVPROC) (GLenum color, GLenum genMode, GLenum colorFormat, const GLfloat* coeffs); -typedef void (GLAPIENTRY * PFNGLPATHCOMMANDSNVPROC) (GLuint path, GLsizei numCommands, const GLubyte* commands, GLsizei numCoords, GLenum coordType, const GLvoid*coords); -typedef void (GLAPIENTRY * PFNGLPATHCOORDSNVPROC) (GLuint path, GLsizei numCoords, GLenum coordType, const void* coords); -typedef void (GLAPIENTRY * PFNGLPATHCOVERDEPTHFUNCNVPROC) (GLenum zfunc); -typedef void (GLAPIENTRY * PFNGLPATHDASHARRAYNVPROC) (GLuint path, GLsizei dashCount, const GLfloat* dashArray); -typedef void (GLAPIENTRY * PFNGLPATHFOGGENNVPROC) (GLenum genMode); -typedef void (GLAPIENTRY * PFNGLPATHGLYPHRANGENVPROC) (GLuint firstPathName, GLenum fontTarget, const void* fontName, GLbitfield fontStyle, GLuint firstGlyph, GLsizei numGlyphs, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); -typedef void (GLAPIENTRY * PFNGLPATHGLYPHSNVPROC) (GLuint firstPathName, GLenum fontTarget, const void* fontName, GLbitfield fontStyle, GLsizei numGlyphs, GLenum type, const GLvoid*charcodes, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); -typedef void (GLAPIENTRY * PFNGLPATHPARAMETERFNVPROC) (GLuint path, GLenum pname, GLfloat value); -typedef void (GLAPIENTRY * PFNGLPATHPARAMETERFVNVPROC) (GLuint path, GLenum pname, const GLfloat* value); -typedef void (GLAPIENTRY * PFNGLPATHPARAMETERINVPROC) (GLuint path, GLenum pname, GLint value); -typedef void (GLAPIENTRY * PFNGLPATHPARAMETERIVNVPROC) (GLuint path, GLenum pname, const GLint* value); -typedef void (GLAPIENTRY * PFNGLPATHSTENCILDEPTHOFFSETNVPROC) (GLfloat factor, GLfloat units); -typedef void (GLAPIENTRY * PFNGLPATHSTENCILFUNCNVPROC) (GLenum func, GLint ref, GLuint mask); -typedef void (GLAPIENTRY * PFNGLPATHSTRINGNVPROC) (GLuint path, GLenum format, GLsizei length, const void* pathString); -typedef void (GLAPIENTRY * PFNGLPATHSUBCOMMANDSNVPROC) (GLuint path, GLsizei commandStart, GLsizei commandsToDelete, GLsizei numCommands, const GLubyte* commands, GLsizei numCoords, GLenum coordType, const GLvoid*coords); -typedef void (GLAPIENTRY * PFNGLPATHSUBCOORDSNVPROC) (GLuint path, GLsizei coordStart, GLsizei numCoords, GLenum coordType, const void* coords); -typedef void (GLAPIENTRY * PFNGLPATHTEXGENNVPROC) (GLenum texCoordSet, GLenum genMode, GLint components, const GLfloat* coeffs); -typedef GLboolean (GLAPIENTRY * PFNGLPOINTALONGPATHNVPROC) (GLuint path, GLsizei startSegment, GLsizei numSegments, GLfloat distance, GLfloat* x, GLfloat *y, GLfloat *tangentX, GLfloat *tangentY); -typedef void (GLAPIENTRY * PFNGLSTENCILFILLPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void* paths, GLuint pathBase, GLenum fillMode, GLuint mask, GLenum transformType, const GLfloat *transformValues); -typedef void (GLAPIENTRY * PFNGLSTENCILFILLPATHNVPROC) (GLuint path, GLenum fillMode, GLuint mask); -typedef void (GLAPIENTRY * PFNGLSTENCILSTROKEPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void* paths, GLuint pathBase, GLint reference, GLuint mask, GLenum transformType, const GLfloat *transformValues); -typedef void (GLAPIENTRY * PFNGLSTENCILSTROKEPATHNVPROC) (GLuint path, GLint reference, GLuint mask); -typedef void (GLAPIENTRY * PFNGLTRANSFORMPATHNVPROC) (GLuint resultPath, GLuint srcPath, GLenum transformType, const GLfloat* transformValues); -typedef void (GLAPIENTRY * PFNGLWEIGHTPATHSNVPROC) (GLuint resultPath, GLsizei numPaths, const GLuint paths[], const GLfloat weights[]); - -#define glCopyPathNV GLEW_GET_FUN(__glewCopyPathNV) -#define glCoverFillPathInstancedNV GLEW_GET_FUN(__glewCoverFillPathInstancedNV) -#define glCoverFillPathNV GLEW_GET_FUN(__glewCoverFillPathNV) -#define glCoverStrokePathInstancedNV GLEW_GET_FUN(__glewCoverStrokePathInstancedNV) -#define glCoverStrokePathNV GLEW_GET_FUN(__glewCoverStrokePathNV) -#define glDeletePathsNV GLEW_GET_FUN(__glewDeletePathsNV) -#define glGenPathsNV GLEW_GET_FUN(__glewGenPathsNV) -#define glGetPathColorGenfvNV GLEW_GET_FUN(__glewGetPathColorGenfvNV) -#define glGetPathColorGenivNV GLEW_GET_FUN(__glewGetPathColorGenivNV) -#define glGetPathCommandsNV GLEW_GET_FUN(__glewGetPathCommandsNV) -#define glGetPathCoordsNV GLEW_GET_FUN(__glewGetPathCoordsNV) -#define glGetPathDashArrayNV GLEW_GET_FUN(__glewGetPathDashArrayNV) -#define glGetPathLengthNV GLEW_GET_FUN(__glewGetPathLengthNV) -#define glGetPathMetricRangeNV GLEW_GET_FUN(__glewGetPathMetricRangeNV) -#define glGetPathMetricsNV GLEW_GET_FUN(__glewGetPathMetricsNV) -#define glGetPathParameterfvNV GLEW_GET_FUN(__glewGetPathParameterfvNV) -#define glGetPathParameterivNV GLEW_GET_FUN(__glewGetPathParameterivNV) -#define glGetPathSpacingNV GLEW_GET_FUN(__glewGetPathSpacingNV) -#define glGetPathTexGenfvNV GLEW_GET_FUN(__glewGetPathTexGenfvNV) -#define glGetPathTexGenivNV GLEW_GET_FUN(__glewGetPathTexGenivNV) -#define glInterpolatePathsNV GLEW_GET_FUN(__glewInterpolatePathsNV) -#define glIsPathNV GLEW_GET_FUN(__glewIsPathNV) -#define glIsPointInFillPathNV GLEW_GET_FUN(__glewIsPointInFillPathNV) -#define glIsPointInStrokePathNV GLEW_GET_FUN(__glewIsPointInStrokePathNV) -#define glPathColorGenNV GLEW_GET_FUN(__glewPathColorGenNV) -#define glPathCommandsNV GLEW_GET_FUN(__glewPathCommandsNV) -#define glPathCoordsNV GLEW_GET_FUN(__glewPathCoordsNV) -#define glPathCoverDepthFuncNV GLEW_GET_FUN(__glewPathCoverDepthFuncNV) -#define glPathDashArrayNV GLEW_GET_FUN(__glewPathDashArrayNV) -#define glPathFogGenNV GLEW_GET_FUN(__glewPathFogGenNV) -#define glPathGlyphRangeNV GLEW_GET_FUN(__glewPathGlyphRangeNV) -#define glPathGlyphsNV GLEW_GET_FUN(__glewPathGlyphsNV) -#define glPathParameterfNV GLEW_GET_FUN(__glewPathParameterfNV) -#define glPathParameterfvNV GLEW_GET_FUN(__glewPathParameterfvNV) -#define glPathParameteriNV GLEW_GET_FUN(__glewPathParameteriNV) -#define glPathParameterivNV GLEW_GET_FUN(__glewPathParameterivNV) -#define glPathStencilDepthOffsetNV GLEW_GET_FUN(__glewPathStencilDepthOffsetNV) -#define glPathStencilFuncNV GLEW_GET_FUN(__glewPathStencilFuncNV) -#define glPathStringNV GLEW_GET_FUN(__glewPathStringNV) -#define glPathSubCommandsNV GLEW_GET_FUN(__glewPathSubCommandsNV) -#define glPathSubCoordsNV GLEW_GET_FUN(__glewPathSubCoordsNV) -#define glPathTexGenNV GLEW_GET_FUN(__glewPathTexGenNV) -#define glPointAlongPathNV GLEW_GET_FUN(__glewPointAlongPathNV) -#define glStencilFillPathInstancedNV GLEW_GET_FUN(__glewStencilFillPathInstancedNV) -#define glStencilFillPathNV GLEW_GET_FUN(__glewStencilFillPathNV) -#define glStencilStrokePathInstancedNV GLEW_GET_FUN(__glewStencilStrokePathInstancedNV) -#define glStencilStrokePathNV GLEW_GET_FUN(__glewStencilStrokePathNV) -#define glTransformPathNV GLEW_GET_FUN(__glewTransformPathNV) -#define glWeightPathsNV GLEW_GET_FUN(__glewWeightPathsNV) - -#define GLEW_NV_path_rendering GLEW_GET_VAR(__GLEW_NV_path_rendering) - -#endif /* GL_NV_path_rendering */ - -/* ------------------------- GL_NV_pixel_data_range ------------------------ */ - -#ifndef GL_NV_pixel_data_range -#define GL_NV_pixel_data_range 1 - -#define GL_WRITE_PIXEL_DATA_RANGE_NV 0x8878 -#define GL_READ_PIXEL_DATA_RANGE_NV 0x8879 -#define GL_WRITE_PIXEL_DATA_RANGE_LENGTH_NV 0x887A -#define GL_READ_PIXEL_DATA_RANGE_LENGTH_NV 0x887B -#define GL_WRITE_PIXEL_DATA_RANGE_POINTER_NV 0x887C -#define GL_READ_PIXEL_DATA_RANGE_POINTER_NV 0x887D - -typedef void (GLAPIENTRY * PFNGLFLUSHPIXELDATARANGENVPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLPIXELDATARANGENVPROC) (GLenum target, GLsizei length, GLvoid *pointer); - -#define glFlushPixelDataRangeNV GLEW_GET_FUN(__glewFlushPixelDataRangeNV) -#define glPixelDataRangeNV GLEW_GET_FUN(__glewPixelDataRangeNV) - -#define GLEW_NV_pixel_data_range GLEW_GET_VAR(__GLEW_NV_pixel_data_range) - -#endif /* GL_NV_pixel_data_range */ - -/* --------------------------- GL_NV_point_sprite -------------------------- */ - -#ifndef GL_NV_point_sprite -#define GL_NV_point_sprite 1 - -#define GL_POINT_SPRITE_NV 0x8861 -#define GL_COORD_REPLACE_NV 0x8862 -#define GL_POINT_SPRITE_R_MODE_NV 0x8863 - -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERINVPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERIVNVPROC) (GLenum pname, const GLint* params); - -#define glPointParameteriNV GLEW_GET_FUN(__glewPointParameteriNV) -#define glPointParameterivNV GLEW_GET_FUN(__glewPointParameterivNV) - -#define GLEW_NV_point_sprite GLEW_GET_VAR(__GLEW_NV_point_sprite) - -#endif /* GL_NV_point_sprite */ - -/* -------------------------- GL_NV_present_video -------------------------- */ - -#ifndef GL_NV_present_video -#define GL_NV_present_video 1 - -#define GL_FRAME_NV 0x8E26 -#define GL_FIELDS_NV 0x8E27 -#define GL_CURRENT_TIME_NV 0x8E28 -#define GL_NUM_FILL_STREAMS_NV 0x8E29 -#define GL_PRESENT_TIME_NV 0x8E2A -#define GL_PRESENT_DURATION_NV 0x8E2B - -typedef void (GLAPIENTRY * PFNGLGETVIDEOI64VNVPROC) (GLuint video_slot, GLenum pname, GLint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOIVNVPROC) (GLuint video_slot, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOUI64VNVPROC) (GLuint video_slot, GLenum pname, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOUIVNVPROC) (GLuint video_slot, GLenum pname, GLuint* params); -typedef void (GLAPIENTRY * PFNGLPRESENTFRAMEDUALFILLNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLenum target1, GLuint fill1, GLenum target2, GLuint fill2, GLenum target3, GLuint fill3); -typedef void (GLAPIENTRY * PFNGLPRESENTFRAMEKEYEDNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1); - -#define glGetVideoi64vNV GLEW_GET_FUN(__glewGetVideoi64vNV) -#define glGetVideoivNV GLEW_GET_FUN(__glewGetVideoivNV) -#define glGetVideoui64vNV GLEW_GET_FUN(__glewGetVideoui64vNV) -#define glGetVideouivNV GLEW_GET_FUN(__glewGetVideouivNV) -#define glPresentFrameDualFillNV GLEW_GET_FUN(__glewPresentFrameDualFillNV) -#define glPresentFrameKeyedNV GLEW_GET_FUN(__glewPresentFrameKeyedNV) - -#define GLEW_NV_present_video GLEW_GET_VAR(__GLEW_NV_present_video) - -#endif /* GL_NV_present_video */ - -/* ------------------------ GL_NV_primitive_restart ------------------------ */ - -#ifndef GL_NV_primitive_restart -#define GL_NV_primitive_restart 1 - -#define GL_PRIMITIVE_RESTART_NV 0x8558 -#define GL_PRIMITIVE_RESTART_INDEX_NV 0x8559 - -typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTINDEXNVPROC) (GLuint index); -typedef void (GLAPIENTRY * PFNGLPRIMITIVERESTARTNVPROC) (void); - -#define glPrimitiveRestartIndexNV GLEW_GET_FUN(__glewPrimitiveRestartIndexNV) -#define glPrimitiveRestartNV GLEW_GET_FUN(__glewPrimitiveRestartNV) - -#define GLEW_NV_primitive_restart GLEW_GET_VAR(__GLEW_NV_primitive_restart) - -#endif /* GL_NV_primitive_restart */ - -/* ------------------------ GL_NV_register_combiners ----------------------- */ - -#ifndef GL_NV_register_combiners -#define GL_NV_register_combiners 1 - -#define GL_REGISTER_COMBINERS_NV 0x8522 -#define GL_VARIABLE_A_NV 0x8523 -#define GL_VARIABLE_B_NV 0x8524 -#define GL_VARIABLE_C_NV 0x8525 -#define GL_VARIABLE_D_NV 0x8526 -#define GL_VARIABLE_E_NV 0x8527 -#define GL_VARIABLE_F_NV 0x8528 -#define GL_VARIABLE_G_NV 0x8529 -#define GL_CONSTANT_COLOR0_NV 0x852A -#define GL_CONSTANT_COLOR1_NV 0x852B -#define GL_PRIMARY_COLOR_NV 0x852C -#define GL_SECONDARY_COLOR_NV 0x852D -#define GL_SPARE0_NV 0x852E -#define GL_SPARE1_NV 0x852F -#define GL_DISCARD_NV 0x8530 -#define GL_E_TIMES_F_NV 0x8531 -#define GL_SPARE0_PLUS_SECONDARY_COLOR_NV 0x8532 -#define GL_UNSIGNED_IDENTITY_NV 0x8536 -#define GL_UNSIGNED_INVERT_NV 0x8537 -#define GL_EXPAND_NORMAL_NV 0x8538 -#define GL_EXPAND_NEGATE_NV 0x8539 -#define GL_HALF_BIAS_NORMAL_NV 0x853A -#define GL_HALF_BIAS_NEGATE_NV 0x853B -#define GL_SIGNED_IDENTITY_NV 0x853C -#define GL_SIGNED_NEGATE_NV 0x853D -#define GL_SCALE_BY_TWO_NV 0x853E -#define GL_SCALE_BY_FOUR_NV 0x853F -#define GL_SCALE_BY_ONE_HALF_NV 0x8540 -#define GL_BIAS_BY_NEGATIVE_ONE_HALF_NV 0x8541 -#define GL_COMBINER_INPUT_NV 0x8542 -#define GL_COMBINER_MAPPING_NV 0x8543 -#define GL_COMBINER_COMPONENT_USAGE_NV 0x8544 -#define GL_COMBINER_AB_DOT_PRODUCT_NV 0x8545 -#define GL_COMBINER_CD_DOT_PRODUCT_NV 0x8546 -#define GL_COMBINER_MUX_SUM_NV 0x8547 -#define GL_COMBINER_SCALE_NV 0x8548 -#define GL_COMBINER_BIAS_NV 0x8549 -#define GL_COMBINER_AB_OUTPUT_NV 0x854A -#define GL_COMBINER_CD_OUTPUT_NV 0x854B -#define GL_COMBINER_SUM_OUTPUT_NV 0x854C -#define GL_MAX_GENERAL_COMBINERS_NV 0x854D -#define GL_NUM_GENERAL_COMBINERS_NV 0x854E -#define GL_COLOR_SUM_CLAMP_NV 0x854F -#define GL_COMBINER0_NV 0x8550 -#define GL_COMBINER1_NV 0x8551 -#define GL_COMBINER2_NV 0x8552 -#define GL_COMBINER3_NV 0x8553 -#define GL_COMBINER4_NV 0x8554 -#define GL_COMBINER5_NV 0x8555 -#define GL_COMBINER6_NV 0x8556 -#define GL_COMBINER7_NV 0x8557 - -typedef void (GLAPIENTRY * PFNGLCOMBINERINPUTNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); -typedef void (GLAPIENTRY * PFNGLCOMBINEROUTPUTNVPROC) (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERFNVPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERFVNVPROC) (GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERINVPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLCOMBINERPARAMETERIVNVPROC) (GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLFINALCOMBINERINPUTNVPROC) (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); -typedef void (GLAPIENTRY * PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC) (GLenum variable, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC) (GLenum variable, GLenum pname, GLint* params); - -#define glCombinerInputNV GLEW_GET_FUN(__glewCombinerInputNV) -#define glCombinerOutputNV GLEW_GET_FUN(__glewCombinerOutputNV) -#define glCombinerParameterfNV GLEW_GET_FUN(__glewCombinerParameterfNV) -#define glCombinerParameterfvNV GLEW_GET_FUN(__glewCombinerParameterfvNV) -#define glCombinerParameteriNV GLEW_GET_FUN(__glewCombinerParameteriNV) -#define glCombinerParameterivNV GLEW_GET_FUN(__glewCombinerParameterivNV) -#define glFinalCombinerInputNV GLEW_GET_FUN(__glewFinalCombinerInputNV) -#define glGetCombinerInputParameterfvNV GLEW_GET_FUN(__glewGetCombinerInputParameterfvNV) -#define glGetCombinerInputParameterivNV GLEW_GET_FUN(__glewGetCombinerInputParameterivNV) -#define glGetCombinerOutputParameterfvNV GLEW_GET_FUN(__glewGetCombinerOutputParameterfvNV) -#define glGetCombinerOutputParameterivNV GLEW_GET_FUN(__glewGetCombinerOutputParameterivNV) -#define glGetFinalCombinerInputParameterfvNV GLEW_GET_FUN(__glewGetFinalCombinerInputParameterfvNV) -#define glGetFinalCombinerInputParameterivNV GLEW_GET_FUN(__glewGetFinalCombinerInputParameterivNV) - -#define GLEW_NV_register_combiners GLEW_GET_VAR(__GLEW_NV_register_combiners) - -#endif /* GL_NV_register_combiners */ - -/* ----------------------- GL_NV_register_combiners2 ----------------------- */ - -#ifndef GL_NV_register_combiners2 -#define GL_NV_register_combiners2 1 - -#define GL_PER_STAGE_CONSTANTS_NV 0x8535 - -typedef void (GLAPIENTRY * PFNGLCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, GLfloat* params); - -#define glCombinerStageParameterfvNV GLEW_GET_FUN(__glewCombinerStageParameterfvNV) -#define glGetCombinerStageParameterfvNV GLEW_GET_FUN(__glewGetCombinerStageParameterfvNV) - -#define GLEW_NV_register_combiners2 GLEW_GET_VAR(__GLEW_NV_register_combiners2) - -#endif /* GL_NV_register_combiners2 */ - -/* ---------------------- GL_NV_shader_atomic_counters --------------------- */ - -#ifndef GL_NV_shader_atomic_counters -#define GL_NV_shader_atomic_counters 1 - -#define GLEW_NV_shader_atomic_counters GLEW_GET_VAR(__GLEW_NV_shader_atomic_counters) - -#endif /* GL_NV_shader_atomic_counters */ - -/* ----------------------- GL_NV_shader_atomic_float ----------------------- */ - -#ifndef GL_NV_shader_atomic_float -#define GL_NV_shader_atomic_float 1 - -#define GLEW_NV_shader_atomic_float GLEW_GET_VAR(__GLEW_NV_shader_atomic_float) - -#endif /* GL_NV_shader_atomic_float */ - -/* ------------------------ GL_NV_shader_buffer_load ----------------------- */ - -#ifndef GL_NV_shader_buffer_load -#define GL_NV_shader_buffer_load 1 - -#define GL_BUFFER_GPU_ADDRESS_NV 0x8F1D -#define GL_GPU_ADDRESS_NV 0x8F34 -#define GL_MAX_SHADER_BUFFER_ADDRESS_NV 0x8F35 - -typedef void (GLAPIENTRY * PFNGLGETBUFFERPARAMETERUI64VNVPROC) (GLenum target, GLenum pname, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETINTEGERUI64VNVPROC) (GLenum value, GLuint64EXT* result); -typedef void (GLAPIENTRY * PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC) (GLuint buffer, GLenum pname, GLuint64EXT* params); -typedef GLboolean (GLAPIENTRY * PFNGLISBUFFERRESIDENTNVPROC) (GLenum target); -typedef GLboolean (GLAPIENTRY * PFNGLISNAMEDBUFFERRESIDENTNVPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLMAKEBUFFERNONRESIDENTNVPROC) (GLenum target); -typedef void (GLAPIENTRY * PFNGLMAKEBUFFERRESIDENTNVPROC) (GLenum target, GLenum access); -typedef void (GLAPIENTRY * PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC) (GLuint buffer); -typedef void (GLAPIENTRY * PFNGLMAKENAMEDBUFFERRESIDENTNVPROC) (GLuint buffer, GLenum access); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMUI64NVPROC) (GLuint program, GLint location, GLuint64EXT value); -typedef void (GLAPIENTRY * PFNGLPROGRAMUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT* value); -typedef void (GLAPIENTRY * PFNGLUNIFORMUI64NVPROC) (GLint location, GLuint64EXT value); -typedef void (GLAPIENTRY * PFNGLUNIFORMUI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT* value); - -#define glGetBufferParameterui64vNV GLEW_GET_FUN(__glewGetBufferParameterui64vNV) -#define glGetIntegerui64vNV GLEW_GET_FUN(__glewGetIntegerui64vNV) -#define glGetNamedBufferParameterui64vNV GLEW_GET_FUN(__glewGetNamedBufferParameterui64vNV) -#define glIsBufferResidentNV GLEW_GET_FUN(__glewIsBufferResidentNV) -#define glIsNamedBufferResidentNV GLEW_GET_FUN(__glewIsNamedBufferResidentNV) -#define glMakeBufferNonResidentNV GLEW_GET_FUN(__glewMakeBufferNonResidentNV) -#define glMakeBufferResidentNV GLEW_GET_FUN(__glewMakeBufferResidentNV) -#define glMakeNamedBufferNonResidentNV GLEW_GET_FUN(__glewMakeNamedBufferNonResidentNV) -#define glMakeNamedBufferResidentNV GLEW_GET_FUN(__glewMakeNamedBufferResidentNV) -#define glProgramUniformui64NV GLEW_GET_FUN(__glewProgramUniformui64NV) -#define glProgramUniformui64vNV GLEW_GET_FUN(__glewProgramUniformui64vNV) -#define glUniformui64NV GLEW_GET_FUN(__glewUniformui64NV) -#define glUniformui64vNV GLEW_GET_FUN(__glewUniformui64vNV) - -#define GLEW_NV_shader_buffer_load GLEW_GET_VAR(__GLEW_NV_shader_buffer_load) - -#endif /* GL_NV_shader_buffer_load */ - -/* ------------------- GL_NV_shader_storage_buffer_object ------------------ */ - -#ifndef GL_NV_shader_storage_buffer_object -#define GL_NV_shader_storage_buffer_object 1 - -#define GLEW_NV_shader_storage_buffer_object GLEW_GET_VAR(__GLEW_NV_shader_storage_buffer_object) - -#endif /* GL_NV_shader_storage_buffer_object */ - -/* ---------------------- GL_NV_tessellation_program5 ---------------------- */ - -#ifndef GL_NV_tessellation_program5 -#define GL_NV_tessellation_program5 1 - -#define GL_MAX_PROGRAM_PATCH_ATTRIBS_NV 0x86D8 -#define GL_TESS_CONTROL_PROGRAM_NV 0x891E -#define GL_TESS_EVALUATION_PROGRAM_NV 0x891F -#define GL_TESS_CONTROL_PROGRAM_PARAMETER_BUFFER_NV 0x8C74 -#define GL_TESS_EVALUATION_PROGRAM_PARAMETER_BUFFER_NV 0x8C75 - -#define GLEW_NV_tessellation_program5 GLEW_GET_VAR(__GLEW_NV_tessellation_program5) - -#endif /* GL_NV_tessellation_program5 */ - -/* -------------------------- GL_NV_texgen_emboss -------------------------- */ - -#ifndef GL_NV_texgen_emboss -#define GL_NV_texgen_emboss 1 - -#define GL_EMBOSS_LIGHT_NV 0x855D -#define GL_EMBOSS_CONSTANT_NV 0x855E -#define GL_EMBOSS_MAP_NV 0x855F - -#define GLEW_NV_texgen_emboss GLEW_GET_VAR(__GLEW_NV_texgen_emboss) - -#endif /* GL_NV_texgen_emboss */ - -/* ------------------------ GL_NV_texgen_reflection ------------------------ */ - -#ifndef GL_NV_texgen_reflection -#define GL_NV_texgen_reflection 1 - -#define GL_NORMAL_MAP_NV 0x8511 -#define GL_REFLECTION_MAP_NV 0x8512 - -#define GLEW_NV_texgen_reflection GLEW_GET_VAR(__GLEW_NV_texgen_reflection) - -#endif /* GL_NV_texgen_reflection */ - -/* ------------------------- GL_NV_texture_barrier ------------------------- */ - -#ifndef GL_NV_texture_barrier -#define GL_NV_texture_barrier 1 - -typedef void (GLAPIENTRY * PFNGLTEXTUREBARRIERNVPROC) (void); - -#define glTextureBarrierNV GLEW_GET_FUN(__glewTextureBarrierNV) - -#define GLEW_NV_texture_barrier GLEW_GET_VAR(__GLEW_NV_texture_barrier) - -#endif /* GL_NV_texture_barrier */ - -/* --------------------- GL_NV_texture_compression_vtc --------------------- */ - -#ifndef GL_NV_texture_compression_vtc -#define GL_NV_texture_compression_vtc 1 - -#define GLEW_NV_texture_compression_vtc GLEW_GET_VAR(__GLEW_NV_texture_compression_vtc) - -#endif /* GL_NV_texture_compression_vtc */ - -/* ----------------------- GL_NV_texture_env_combine4 ---------------------- */ - -#ifndef GL_NV_texture_env_combine4 -#define GL_NV_texture_env_combine4 1 - -#define GL_COMBINE4_NV 0x8503 -#define GL_SOURCE3_RGB_NV 0x8583 -#define GL_SOURCE3_ALPHA_NV 0x858B -#define GL_OPERAND3_RGB_NV 0x8593 -#define GL_OPERAND3_ALPHA_NV 0x859B - -#define GLEW_NV_texture_env_combine4 GLEW_GET_VAR(__GLEW_NV_texture_env_combine4) - -#endif /* GL_NV_texture_env_combine4 */ - -/* ---------------------- GL_NV_texture_expand_normal ---------------------- */ - -#ifndef GL_NV_texture_expand_normal -#define GL_NV_texture_expand_normal 1 - -#define GL_TEXTURE_UNSIGNED_REMAP_MODE_NV 0x888F - -#define GLEW_NV_texture_expand_normal GLEW_GET_VAR(__GLEW_NV_texture_expand_normal) - -#endif /* GL_NV_texture_expand_normal */ - -/* ----------------------- GL_NV_texture_multisample ----------------------- */ - -#ifndef GL_NV_texture_multisample -#define GL_NV_texture_multisample 1 - -#define GL_TEXTURE_COVERAGE_SAMPLES_NV 0x9045 -#define GL_TEXTURE_COLOR_SAMPLES_NV 0x9046 - -typedef void (GLAPIENTRY * PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC) (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC) (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC) (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); -typedef void (GLAPIENTRY * PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC) (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); - -#define glTexImage2DMultisampleCoverageNV GLEW_GET_FUN(__glewTexImage2DMultisampleCoverageNV) -#define glTexImage3DMultisampleCoverageNV GLEW_GET_FUN(__glewTexImage3DMultisampleCoverageNV) -#define glTextureImage2DMultisampleCoverageNV GLEW_GET_FUN(__glewTextureImage2DMultisampleCoverageNV) -#define glTextureImage2DMultisampleNV GLEW_GET_FUN(__glewTextureImage2DMultisampleNV) -#define glTextureImage3DMultisampleCoverageNV GLEW_GET_FUN(__glewTextureImage3DMultisampleCoverageNV) -#define glTextureImage3DMultisampleNV GLEW_GET_FUN(__glewTextureImage3DMultisampleNV) - -#define GLEW_NV_texture_multisample GLEW_GET_VAR(__GLEW_NV_texture_multisample) - -#endif /* GL_NV_texture_multisample */ - -/* ------------------------ GL_NV_texture_rectangle ------------------------ */ - -#ifndef GL_NV_texture_rectangle -#define GL_NV_texture_rectangle 1 - -#define GL_TEXTURE_RECTANGLE_NV 0x84F5 -#define GL_TEXTURE_BINDING_RECTANGLE_NV 0x84F6 -#define GL_PROXY_TEXTURE_RECTANGLE_NV 0x84F7 -#define GL_MAX_RECTANGLE_TEXTURE_SIZE_NV 0x84F8 - -#define GLEW_NV_texture_rectangle GLEW_GET_VAR(__GLEW_NV_texture_rectangle) - -#endif /* GL_NV_texture_rectangle */ - -/* -------------------------- GL_NV_texture_shader ------------------------- */ - -#ifndef GL_NV_texture_shader -#define GL_NV_texture_shader 1 - -#define GL_OFFSET_TEXTURE_RECTANGLE_NV 0x864C -#define GL_OFFSET_TEXTURE_RECTANGLE_SCALE_NV 0x864D -#define GL_DOT_PRODUCT_TEXTURE_RECTANGLE_NV 0x864E -#define GL_RGBA_UNSIGNED_DOT_PRODUCT_MAPPING_NV 0x86D9 -#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA -#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB -#define GL_DSDT_MAG_INTENSITY_NV 0x86DC -#define GL_SHADER_CONSISTENT_NV 0x86DD -#define GL_TEXTURE_SHADER_NV 0x86DE -#define GL_SHADER_OPERATION_NV 0x86DF -#define GL_CULL_MODES_NV 0x86E0 -#define GL_OFFSET_TEXTURE_2D_MATRIX_NV 0x86E1 -#define GL_OFFSET_TEXTURE_MATRIX_NV 0x86E1 -#define GL_OFFSET_TEXTURE_2D_SCALE_NV 0x86E2 -#define GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 -#define GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 -#define GL_OFFSET_TEXTURE_2D_BIAS_NV 0x86E3 -#define GL_PREVIOUS_TEXTURE_INPUT_NV 0x86E4 -#define GL_CONST_EYE_NV 0x86E5 -#define GL_PASS_THROUGH_NV 0x86E6 -#define GL_CULL_FRAGMENT_NV 0x86E7 -#define GL_OFFSET_TEXTURE_2D_NV 0x86E8 -#define GL_DEPENDENT_AR_TEXTURE_2D_NV 0x86E9 -#define GL_DEPENDENT_GB_TEXTURE_2D_NV 0x86EA -#define GL_DOT_PRODUCT_NV 0x86EC -#define GL_DOT_PRODUCT_DEPTH_REPLACE_NV 0x86ED -#define GL_DOT_PRODUCT_TEXTURE_2D_NV 0x86EE -#define GL_DOT_PRODUCT_TEXTURE_CUBE_MAP_NV 0x86F0 -#define GL_DOT_PRODUCT_DIFFUSE_CUBE_MAP_NV 0x86F1 -#define GL_DOT_PRODUCT_REFLECT_CUBE_MAP_NV 0x86F2 -#define GL_DOT_PRODUCT_CONST_EYE_REFLECT_CUBE_MAP_NV 0x86F3 -#define GL_HILO_NV 0x86F4 -#define GL_DSDT_NV 0x86F5 -#define GL_DSDT_MAG_NV 0x86F6 -#define GL_DSDT_MAG_VIB_NV 0x86F7 -#define GL_HILO16_NV 0x86F8 -#define GL_SIGNED_HILO_NV 0x86F9 -#define GL_SIGNED_HILO16_NV 0x86FA -#define GL_SIGNED_RGBA_NV 0x86FB -#define GL_SIGNED_RGBA8_NV 0x86FC -#define GL_SIGNED_RGB_NV 0x86FE -#define GL_SIGNED_RGB8_NV 0x86FF -#define GL_SIGNED_LUMINANCE_NV 0x8701 -#define GL_SIGNED_LUMINANCE8_NV 0x8702 -#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 -#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 -#define GL_SIGNED_ALPHA_NV 0x8705 -#define GL_SIGNED_ALPHA8_NV 0x8706 -#define GL_SIGNED_INTENSITY_NV 0x8707 -#define GL_SIGNED_INTENSITY8_NV 0x8708 -#define GL_DSDT8_NV 0x8709 -#define GL_DSDT8_MAG8_NV 0x870A -#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B -#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C -#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D -#define GL_HI_SCALE_NV 0x870E -#define GL_LO_SCALE_NV 0x870F -#define GL_DS_SCALE_NV 0x8710 -#define GL_DT_SCALE_NV 0x8711 -#define GL_MAGNITUDE_SCALE_NV 0x8712 -#define GL_VIBRANCE_SCALE_NV 0x8713 -#define GL_HI_BIAS_NV 0x8714 -#define GL_LO_BIAS_NV 0x8715 -#define GL_DS_BIAS_NV 0x8716 -#define GL_DT_BIAS_NV 0x8717 -#define GL_MAGNITUDE_BIAS_NV 0x8718 -#define GL_VIBRANCE_BIAS_NV 0x8719 -#define GL_TEXTURE_BORDER_VALUES_NV 0x871A -#define GL_TEXTURE_HI_SIZE_NV 0x871B -#define GL_TEXTURE_LO_SIZE_NV 0x871C -#define GL_TEXTURE_DS_SIZE_NV 0x871D -#define GL_TEXTURE_DT_SIZE_NV 0x871E -#define GL_TEXTURE_MAG_SIZE_NV 0x871F - -#define GLEW_NV_texture_shader GLEW_GET_VAR(__GLEW_NV_texture_shader) - -#endif /* GL_NV_texture_shader */ - -/* ------------------------- GL_NV_texture_shader2 ------------------------- */ - -#ifndef GL_NV_texture_shader2 -#define GL_NV_texture_shader2 1 - -#define GL_UNSIGNED_INT_S8_S8_8_8_NV 0x86DA -#define GL_UNSIGNED_INT_8_8_S8_S8_REV_NV 0x86DB -#define GL_DSDT_MAG_INTENSITY_NV 0x86DC -#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF -#define GL_HILO_NV 0x86F4 -#define GL_DSDT_NV 0x86F5 -#define GL_DSDT_MAG_NV 0x86F6 -#define GL_DSDT_MAG_VIB_NV 0x86F7 -#define GL_HILO16_NV 0x86F8 -#define GL_SIGNED_HILO_NV 0x86F9 -#define GL_SIGNED_HILO16_NV 0x86FA -#define GL_SIGNED_RGBA_NV 0x86FB -#define GL_SIGNED_RGBA8_NV 0x86FC -#define GL_SIGNED_RGB_NV 0x86FE -#define GL_SIGNED_RGB8_NV 0x86FF -#define GL_SIGNED_LUMINANCE_NV 0x8701 -#define GL_SIGNED_LUMINANCE8_NV 0x8702 -#define GL_SIGNED_LUMINANCE_ALPHA_NV 0x8703 -#define GL_SIGNED_LUMINANCE8_ALPHA8_NV 0x8704 -#define GL_SIGNED_ALPHA_NV 0x8705 -#define GL_SIGNED_ALPHA8_NV 0x8706 -#define GL_SIGNED_INTENSITY_NV 0x8707 -#define GL_SIGNED_INTENSITY8_NV 0x8708 -#define GL_DSDT8_NV 0x8709 -#define GL_DSDT8_MAG8_NV 0x870A -#define GL_DSDT8_MAG8_INTENSITY8_NV 0x870B -#define GL_SIGNED_RGB_UNSIGNED_ALPHA_NV 0x870C -#define GL_SIGNED_RGB8_UNSIGNED_ALPHA8_NV 0x870D - -#define GLEW_NV_texture_shader2 GLEW_GET_VAR(__GLEW_NV_texture_shader2) - -#endif /* GL_NV_texture_shader2 */ - -/* ------------------------- GL_NV_texture_shader3 ------------------------- */ - -#ifndef GL_NV_texture_shader3 -#define GL_NV_texture_shader3 1 - -#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_NV 0x8850 -#define GL_OFFSET_PROJECTIVE_TEXTURE_2D_SCALE_NV 0x8851 -#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8852 -#define GL_OFFSET_PROJECTIVE_TEXTURE_RECTANGLE_SCALE_NV 0x8853 -#define GL_OFFSET_HILO_TEXTURE_2D_NV 0x8854 -#define GL_OFFSET_HILO_TEXTURE_RECTANGLE_NV 0x8855 -#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_2D_NV 0x8856 -#define GL_OFFSET_HILO_PROJECTIVE_TEXTURE_RECTANGLE_NV 0x8857 -#define GL_DEPENDENT_HILO_TEXTURE_2D_NV 0x8858 -#define GL_DEPENDENT_RGB_TEXTURE_3D_NV 0x8859 -#define GL_DEPENDENT_RGB_TEXTURE_CUBE_MAP_NV 0x885A -#define GL_DOT_PRODUCT_PASS_THROUGH_NV 0x885B -#define GL_DOT_PRODUCT_TEXTURE_1D_NV 0x885C -#define GL_DOT_PRODUCT_AFFINE_DEPTH_REPLACE_NV 0x885D -#define GL_HILO8_NV 0x885E -#define GL_SIGNED_HILO8_NV 0x885F -#define GL_FORCE_BLUE_TO_ONE_NV 0x8860 - -#define GLEW_NV_texture_shader3 GLEW_GET_VAR(__GLEW_NV_texture_shader3) - -#endif /* GL_NV_texture_shader3 */ - -/* ------------------------ GL_NV_transform_feedback ----------------------- */ - -#ifndef GL_NV_transform_feedback -#define GL_NV_transform_feedback 1 - -#define GL_BACK_PRIMARY_COLOR_NV 0x8C77 -#define GL_BACK_SECONDARY_COLOR_NV 0x8C78 -#define GL_TEXTURE_COORD_NV 0x8C79 -#define GL_CLIP_DISTANCE_NV 0x8C7A -#define GL_VERTEX_ID_NV 0x8C7B -#define GL_PRIMITIVE_ID_NV 0x8C7C -#define GL_GENERIC_ATTRIB_NV 0x8C7D -#define GL_TRANSFORM_FEEDBACK_ATTRIBS_NV 0x8C7E -#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_NV 0x8C7F -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_NV 0x8C80 -#define GL_ACTIVE_VARYINGS_NV 0x8C81 -#define GL_ACTIVE_VARYING_MAX_LENGTH_NV 0x8C82 -#define GL_TRANSFORM_FEEDBACK_VARYINGS_NV 0x8C83 -#define GL_TRANSFORM_FEEDBACK_BUFFER_START_NV 0x8C84 -#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_NV 0x8C85 -#define GL_TRANSFORM_FEEDBACK_RECORD_NV 0x8C86 -#define GL_PRIMITIVES_GENERATED_NV 0x8C87 -#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN_NV 0x8C88 -#define GL_RASTERIZER_DISCARD_NV 0x8C89 -#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS_NV 0x8C8A -#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS_NV 0x8C8B -#define GL_INTERLEAVED_ATTRIBS_NV 0x8C8C -#define GL_SEPARATE_ATTRIBS_NV 0x8C8D -#define GL_TRANSFORM_FEEDBACK_BUFFER_NV 0x8C8E -#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_NV 0x8C8F - -typedef void (GLAPIENTRY * PFNGLACTIVEVARYINGNVPROC) (GLuint program, const GLchar *name); -typedef void (GLAPIENTRY * PFNGLBEGINTRANSFORMFEEDBACKNVPROC) (GLenum primitiveMode); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERBASENVPROC) (GLenum target, GLuint index, GLuint buffer); -typedef void (GLAPIENTRY * PFNGLBINDBUFFEROFFSETNVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); -typedef void (GLAPIENTRY * PFNGLBINDBUFFERRANGENVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); -typedef void (GLAPIENTRY * PFNGLENDTRANSFORMFEEDBACKNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLGETACTIVEVARYINGNVPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); -typedef void (GLAPIENTRY * PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC) (GLuint program, GLuint index, GLint *location); -typedef GLint (GLAPIENTRY * PFNGLGETVARYINGLOCATIONNVPROC) (GLuint program, const GLchar *name); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC) (GLuint count, const GLint *attribs, GLenum bufferMode); -typedef void (GLAPIENTRY * PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC) (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode); - -#define glActiveVaryingNV GLEW_GET_FUN(__glewActiveVaryingNV) -#define glBeginTransformFeedbackNV GLEW_GET_FUN(__glewBeginTransformFeedbackNV) -#define glBindBufferBaseNV GLEW_GET_FUN(__glewBindBufferBaseNV) -#define glBindBufferOffsetNV GLEW_GET_FUN(__glewBindBufferOffsetNV) -#define glBindBufferRangeNV GLEW_GET_FUN(__glewBindBufferRangeNV) -#define glEndTransformFeedbackNV GLEW_GET_FUN(__glewEndTransformFeedbackNV) -#define glGetActiveVaryingNV GLEW_GET_FUN(__glewGetActiveVaryingNV) -#define glGetTransformFeedbackVaryingNV GLEW_GET_FUN(__glewGetTransformFeedbackVaryingNV) -#define glGetVaryingLocationNV GLEW_GET_FUN(__glewGetVaryingLocationNV) -#define glTransformFeedbackAttribsNV GLEW_GET_FUN(__glewTransformFeedbackAttribsNV) -#define glTransformFeedbackVaryingsNV GLEW_GET_FUN(__glewTransformFeedbackVaryingsNV) - -#define GLEW_NV_transform_feedback GLEW_GET_VAR(__GLEW_NV_transform_feedback) - -#endif /* GL_NV_transform_feedback */ - -/* ----------------------- GL_NV_transform_feedback2 ----------------------- */ - -#ifndef GL_NV_transform_feedback2 -#define GL_NV_transform_feedback2 1 - -#define GL_TRANSFORM_FEEDBACK_NV 0x8E22 -#define GL_TRANSFORM_FEEDBACK_BUFFER_PAUSED_NV 0x8E23 -#define GL_TRANSFORM_FEEDBACK_BUFFER_ACTIVE_NV 0x8E24 -#define GL_TRANSFORM_FEEDBACK_BINDING_NV 0x8E25 - -typedef void (GLAPIENTRY * PFNGLBINDTRANSFORMFEEDBACKNVPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETETRANSFORMFEEDBACKSNVPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLDRAWTRANSFORMFEEDBACKNVPROC) (GLenum mode, GLuint id); -typedef void (GLAPIENTRY * PFNGLGENTRANSFORMFEEDBACKSNVPROC) (GLsizei n, GLuint* ids); -typedef GLboolean (GLAPIENTRY * PFNGLISTRANSFORMFEEDBACKNVPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLPAUSETRANSFORMFEEDBACKNVPROC) (void); -typedef void (GLAPIENTRY * PFNGLRESUMETRANSFORMFEEDBACKNVPROC) (void); - -#define glBindTransformFeedbackNV GLEW_GET_FUN(__glewBindTransformFeedbackNV) -#define glDeleteTransformFeedbacksNV GLEW_GET_FUN(__glewDeleteTransformFeedbacksNV) -#define glDrawTransformFeedbackNV GLEW_GET_FUN(__glewDrawTransformFeedbackNV) -#define glGenTransformFeedbacksNV GLEW_GET_FUN(__glewGenTransformFeedbacksNV) -#define glIsTransformFeedbackNV GLEW_GET_FUN(__glewIsTransformFeedbackNV) -#define glPauseTransformFeedbackNV GLEW_GET_FUN(__glewPauseTransformFeedbackNV) -#define glResumeTransformFeedbackNV GLEW_GET_FUN(__glewResumeTransformFeedbackNV) - -#define GLEW_NV_transform_feedback2 GLEW_GET_VAR(__GLEW_NV_transform_feedback2) - -#endif /* GL_NV_transform_feedback2 */ - -/* -------------------------- GL_NV_vdpau_interop -------------------------- */ - -#ifndef GL_NV_vdpau_interop -#define GL_NV_vdpau_interop 1 - -#define GL_SURFACE_STATE_NV 0x86EB -#define GL_SURFACE_REGISTERED_NV 0x86FD -#define GL_SURFACE_MAPPED_NV 0x8700 -#define GL_WRITE_DISCARD_NV 0x88BE - -typedef GLintptr GLvdpauSurfaceNV; - -typedef void (GLAPIENTRY * PFNGLVDPAUFININVPROC) (void); -typedef void (GLAPIENTRY * PFNGLVDPAUGETSURFACEIVNVPROC) (GLvdpauSurfaceNV surface, GLenum pname, GLsizei bufSize, GLsizei* length, GLint *values); -typedef void (GLAPIENTRY * PFNGLVDPAUINITNVPROC) (const void* vdpDevice, const GLvoid*getProcAddress); -typedef void (GLAPIENTRY * PFNGLVDPAUISSURFACENVPROC) (GLvdpauSurfaceNV surface); -typedef void (GLAPIENTRY * PFNGLVDPAUMAPSURFACESNVPROC) (GLsizei numSurfaces, const GLvdpauSurfaceNV* surfaces); -typedef GLvdpauSurfaceNV (GLAPIENTRY * PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC) (const void* vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); -typedef GLvdpauSurfaceNV (GLAPIENTRY * PFNGLVDPAUREGISTERVIDEOSURFACENVPROC) (const void* vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); -typedef void (GLAPIENTRY * PFNGLVDPAUSURFACEACCESSNVPROC) (GLvdpauSurfaceNV surface, GLenum access); -typedef void (GLAPIENTRY * PFNGLVDPAUUNMAPSURFACESNVPROC) (GLsizei numSurface, const GLvdpauSurfaceNV* surfaces); -typedef void (GLAPIENTRY * PFNGLVDPAUUNREGISTERSURFACENVPROC) (GLvdpauSurfaceNV surface); - -#define glVDPAUFiniNV GLEW_GET_FUN(__glewVDPAUFiniNV) -#define glVDPAUGetSurfaceivNV GLEW_GET_FUN(__glewVDPAUGetSurfaceivNV) -#define glVDPAUInitNV GLEW_GET_FUN(__glewVDPAUInitNV) -#define glVDPAUIsSurfaceNV GLEW_GET_FUN(__glewVDPAUIsSurfaceNV) -#define glVDPAUMapSurfacesNV GLEW_GET_FUN(__glewVDPAUMapSurfacesNV) -#define glVDPAURegisterOutputSurfaceNV GLEW_GET_FUN(__glewVDPAURegisterOutputSurfaceNV) -#define glVDPAURegisterVideoSurfaceNV GLEW_GET_FUN(__glewVDPAURegisterVideoSurfaceNV) -#define glVDPAUSurfaceAccessNV GLEW_GET_FUN(__glewVDPAUSurfaceAccessNV) -#define glVDPAUUnmapSurfacesNV GLEW_GET_FUN(__glewVDPAUUnmapSurfacesNV) -#define glVDPAUUnregisterSurfaceNV GLEW_GET_FUN(__glewVDPAUUnregisterSurfaceNV) - -#define GLEW_NV_vdpau_interop GLEW_GET_VAR(__GLEW_NV_vdpau_interop) - -#endif /* GL_NV_vdpau_interop */ - -/* ------------------------ GL_NV_vertex_array_range ----------------------- */ - -#ifndef GL_NV_vertex_array_range -#define GL_NV_vertex_array_range 1 - -#define GL_VERTEX_ARRAY_RANGE_NV 0x851D -#define GL_VERTEX_ARRAY_RANGE_LENGTH_NV 0x851E -#define GL_VERTEX_ARRAY_RANGE_VALID_NV 0x851F -#define GL_MAX_VERTEX_ARRAY_RANGE_ELEMENT_NV 0x8520 -#define GL_VERTEX_ARRAY_RANGE_POINTER_NV 0x8521 - -typedef void (GLAPIENTRY * PFNGLFLUSHVERTEXARRAYRANGENVPROC) (void); -typedef void (GLAPIENTRY * PFNGLVERTEXARRAYRANGENVPROC) (GLsizei length, GLvoid *pointer); - -#define glFlushVertexArrayRangeNV GLEW_GET_FUN(__glewFlushVertexArrayRangeNV) -#define glVertexArrayRangeNV GLEW_GET_FUN(__glewVertexArrayRangeNV) - -#define GLEW_NV_vertex_array_range GLEW_GET_VAR(__GLEW_NV_vertex_array_range) - -#endif /* GL_NV_vertex_array_range */ - -/* ----------------------- GL_NV_vertex_array_range2 ----------------------- */ - -#ifndef GL_NV_vertex_array_range2 -#define GL_NV_vertex_array_range2 1 - -#define GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 - -#define GLEW_NV_vertex_array_range2 GLEW_GET_VAR(__GLEW_NV_vertex_array_range2) - -#endif /* GL_NV_vertex_array_range2 */ - -/* ------------------- GL_NV_vertex_attrib_integer_64bit ------------------- */ - -#ifndef GL_NV_vertex_attrib_integer_64bit -#define GL_NV_vertex_attrib_integer_64bit 1 - -#define GL_INT64_NV 0x140E -#define GL_UNSIGNED_INT64_NV 0x140F - -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLI64VNVPROC) (GLuint index, GLenum pname, GLint64EXT* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBLUI64VNVPROC) (GLuint index, GLenum pname, GLuint64EXT* params); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1I64NVPROC) (GLuint index, GLint64EXT x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64NVPROC) (GLuint index, GLuint64EXT x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL1UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL2UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL3UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4I64VNVPROC) (GLuint index, const GLint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBL4UI64VNVPROC) (GLuint index, const GLuint64EXT* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBLFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); - -#define glGetVertexAttribLi64vNV GLEW_GET_FUN(__glewGetVertexAttribLi64vNV) -#define glGetVertexAttribLui64vNV GLEW_GET_FUN(__glewGetVertexAttribLui64vNV) -#define glVertexAttribL1i64NV GLEW_GET_FUN(__glewVertexAttribL1i64NV) -#define glVertexAttribL1i64vNV GLEW_GET_FUN(__glewVertexAttribL1i64vNV) -#define glVertexAttribL1ui64NV GLEW_GET_FUN(__glewVertexAttribL1ui64NV) -#define glVertexAttribL1ui64vNV GLEW_GET_FUN(__glewVertexAttribL1ui64vNV) -#define glVertexAttribL2i64NV GLEW_GET_FUN(__glewVertexAttribL2i64NV) -#define glVertexAttribL2i64vNV GLEW_GET_FUN(__glewVertexAttribL2i64vNV) -#define glVertexAttribL2ui64NV GLEW_GET_FUN(__glewVertexAttribL2ui64NV) -#define glVertexAttribL2ui64vNV GLEW_GET_FUN(__glewVertexAttribL2ui64vNV) -#define glVertexAttribL3i64NV GLEW_GET_FUN(__glewVertexAttribL3i64NV) -#define glVertexAttribL3i64vNV GLEW_GET_FUN(__glewVertexAttribL3i64vNV) -#define glVertexAttribL3ui64NV GLEW_GET_FUN(__glewVertexAttribL3ui64NV) -#define glVertexAttribL3ui64vNV GLEW_GET_FUN(__glewVertexAttribL3ui64vNV) -#define glVertexAttribL4i64NV GLEW_GET_FUN(__glewVertexAttribL4i64NV) -#define glVertexAttribL4i64vNV GLEW_GET_FUN(__glewVertexAttribL4i64vNV) -#define glVertexAttribL4ui64NV GLEW_GET_FUN(__glewVertexAttribL4ui64NV) -#define glVertexAttribL4ui64vNV GLEW_GET_FUN(__glewVertexAttribL4ui64vNV) -#define glVertexAttribLFormatNV GLEW_GET_FUN(__glewVertexAttribLFormatNV) - -#define GLEW_NV_vertex_attrib_integer_64bit GLEW_GET_VAR(__GLEW_NV_vertex_attrib_integer_64bit) - -#endif /* GL_NV_vertex_attrib_integer_64bit */ - -/* ------------------- GL_NV_vertex_buffer_unified_memory ------------------ */ - -#ifndef GL_NV_vertex_buffer_unified_memory -#define GL_NV_vertex_buffer_unified_memory 1 - -#define GL_VERTEX_ATTRIB_ARRAY_UNIFIED_NV 0x8F1E -#define GL_ELEMENT_ARRAY_UNIFIED_NV 0x8F1F -#define GL_VERTEX_ATTRIB_ARRAY_ADDRESS_NV 0x8F20 -#define GL_VERTEX_ARRAY_ADDRESS_NV 0x8F21 -#define GL_NORMAL_ARRAY_ADDRESS_NV 0x8F22 -#define GL_COLOR_ARRAY_ADDRESS_NV 0x8F23 -#define GL_INDEX_ARRAY_ADDRESS_NV 0x8F24 -#define GL_TEXTURE_COORD_ARRAY_ADDRESS_NV 0x8F25 -#define GL_EDGE_FLAG_ARRAY_ADDRESS_NV 0x8F26 -#define GL_SECONDARY_COLOR_ARRAY_ADDRESS_NV 0x8F27 -#define GL_FOG_COORD_ARRAY_ADDRESS_NV 0x8F28 -#define GL_ELEMENT_ARRAY_ADDRESS_NV 0x8F29 -#define GL_VERTEX_ATTRIB_ARRAY_LENGTH_NV 0x8F2A -#define GL_VERTEX_ARRAY_LENGTH_NV 0x8F2B -#define GL_NORMAL_ARRAY_LENGTH_NV 0x8F2C -#define GL_COLOR_ARRAY_LENGTH_NV 0x8F2D -#define GL_INDEX_ARRAY_LENGTH_NV 0x8F2E -#define GL_TEXTURE_COORD_ARRAY_LENGTH_NV 0x8F2F -#define GL_EDGE_FLAG_ARRAY_LENGTH_NV 0x8F30 -#define GL_SECONDARY_COLOR_ARRAY_LENGTH_NV 0x8F31 -#define GL_FOG_COORD_ARRAY_LENGTH_NV 0x8F32 -#define GL_ELEMENT_ARRAY_LENGTH_NV 0x8F33 -#define GL_DRAW_INDIRECT_UNIFIED_NV 0x8F40 -#define GL_DRAW_INDIRECT_ADDRESS_NV 0x8F41 -#define GL_DRAW_INDIRECT_LENGTH_NV 0x8F42 - -typedef void (GLAPIENTRY * PFNGLBUFFERADDRESSRANGENVPROC) (GLenum pname, GLuint index, GLuint64EXT address, GLsizeiptr length); -typedef void (GLAPIENTRY * PFNGLCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLEDGEFLAGFORMATNVPROC) (GLsizei stride); -typedef void (GLAPIENTRY * PFNGLFOGCOORDFORMATNVPROC) (GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLGETINTEGERUI64I_VNVPROC) (GLenum value, GLuint index, GLuint64EXT result[]); -typedef void (GLAPIENTRY * PFNGLINDEXFORMATNVPROC) (GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLNORMALFORMATNVPROC) (GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLSECONDARYCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLTEXCOORDFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBIFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); -typedef void (GLAPIENTRY * PFNGLVERTEXFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); - -#define glBufferAddressRangeNV GLEW_GET_FUN(__glewBufferAddressRangeNV) -#define glColorFormatNV GLEW_GET_FUN(__glewColorFormatNV) -#define glEdgeFlagFormatNV GLEW_GET_FUN(__glewEdgeFlagFormatNV) -#define glFogCoordFormatNV GLEW_GET_FUN(__glewFogCoordFormatNV) -#define glGetIntegerui64i_vNV GLEW_GET_FUN(__glewGetIntegerui64i_vNV) -#define glIndexFormatNV GLEW_GET_FUN(__glewIndexFormatNV) -#define glNormalFormatNV GLEW_GET_FUN(__glewNormalFormatNV) -#define glSecondaryColorFormatNV GLEW_GET_FUN(__glewSecondaryColorFormatNV) -#define glTexCoordFormatNV GLEW_GET_FUN(__glewTexCoordFormatNV) -#define glVertexAttribFormatNV GLEW_GET_FUN(__glewVertexAttribFormatNV) -#define glVertexAttribIFormatNV GLEW_GET_FUN(__glewVertexAttribIFormatNV) -#define glVertexFormatNV GLEW_GET_FUN(__glewVertexFormatNV) - -#define GLEW_NV_vertex_buffer_unified_memory GLEW_GET_VAR(__GLEW_NV_vertex_buffer_unified_memory) - -#endif /* GL_NV_vertex_buffer_unified_memory */ - -/* -------------------------- GL_NV_vertex_program ------------------------- */ - -#ifndef GL_NV_vertex_program -#define GL_NV_vertex_program 1 - -#define GL_VERTEX_PROGRAM_NV 0x8620 -#define GL_VERTEX_STATE_PROGRAM_NV 0x8621 -#define GL_ATTRIB_ARRAY_SIZE_NV 0x8623 -#define GL_ATTRIB_ARRAY_STRIDE_NV 0x8624 -#define GL_ATTRIB_ARRAY_TYPE_NV 0x8625 -#define GL_CURRENT_ATTRIB_NV 0x8626 -#define GL_PROGRAM_LENGTH_NV 0x8627 -#define GL_PROGRAM_STRING_NV 0x8628 -#define GL_MODELVIEW_PROJECTION_NV 0x8629 -#define GL_IDENTITY_NV 0x862A -#define GL_INVERSE_NV 0x862B -#define GL_TRANSPOSE_NV 0x862C -#define GL_INVERSE_TRANSPOSE_NV 0x862D -#define GL_MAX_TRACK_MATRIX_STACK_DEPTH_NV 0x862E -#define GL_MAX_TRACK_MATRICES_NV 0x862F -#define GL_MATRIX0_NV 0x8630 -#define GL_MATRIX1_NV 0x8631 -#define GL_MATRIX2_NV 0x8632 -#define GL_MATRIX3_NV 0x8633 -#define GL_MATRIX4_NV 0x8634 -#define GL_MATRIX5_NV 0x8635 -#define GL_MATRIX6_NV 0x8636 -#define GL_MATRIX7_NV 0x8637 -#define GL_CURRENT_MATRIX_STACK_DEPTH_NV 0x8640 -#define GL_CURRENT_MATRIX_NV 0x8641 -#define GL_VERTEX_PROGRAM_POINT_SIZE_NV 0x8642 -#define GL_VERTEX_PROGRAM_TWO_SIDE_NV 0x8643 -#define GL_PROGRAM_PARAMETER_NV 0x8644 -#define GL_ATTRIB_ARRAY_POINTER_NV 0x8645 -#define GL_PROGRAM_TARGET_NV 0x8646 -#define GL_PROGRAM_RESIDENT_NV 0x8647 -#define GL_TRACK_MATRIX_NV 0x8648 -#define GL_TRACK_MATRIX_TRANSFORM_NV 0x8649 -#define GL_VERTEX_PROGRAM_BINDING_NV 0x864A -#define GL_PROGRAM_ERROR_POSITION_NV 0x864B -#define GL_VERTEX_ATTRIB_ARRAY0_NV 0x8650 -#define GL_VERTEX_ATTRIB_ARRAY1_NV 0x8651 -#define GL_VERTEX_ATTRIB_ARRAY2_NV 0x8652 -#define GL_VERTEX_ATTRIB_ARRAY3_NV 0x8653 -#define GL_VERTEX_ATTRIB_ARRAY4_NV 0x8654 -#define GL_VERTEX_ATTRIB_ARRAY5_NV 0x8655 -#define GL_VERTEX_ATTRIB_ARRAY6_NV 0x8656 -#define GL_VERTEX_ATTRIB_ARRAY7_NV 0x8657 -#define GL_VERTEX_ATTRIB_ARRAY8_NV 0x8658 -#define GL_VERTEX_ATTRIB_ARRAY9_NV 0x8659 -#define GL_VERTEX_ATTRIB_ARRAY10_NV 0x865A -#define GL_VERTEX_ATTRIB_ARRAY11_NV 0x865B -#define GL_VERTEX_ATTRIB_ARRAY12_NV 0x865C -#define GL_VERTEX_ATTRIB_ARRAY13_NV 0x865D -#define GL_VERTEX_ATTRIB_ARRAY14_NV 0x865E -#define GL_VERTEX_ATTRIB_ARRAY15_NV 0x865F -#define GL_MAP1_VERTEX_ATTRIB0_4_NV 0x8660 -#define GL_MAP1_VERTEX_ATTRIB1_4_NV 0x8661 -#define GL_MAP1_VERTEX_ATTRIB2_4_NV 0x8662 -#define GL_MAP1_VERTEX_ATTRIB3_4_NV 0x8663 -#define GL_MAP1_VERTEX_ATTRIB4_4_NV 0x8664 -#define GL_MAP1_VERTEX_ATTRIB5_4_NV 0x8665 -#define GL_MAP1_VERTEX_ATTRIB6_4_NV 0x8666 -#define GL_MAP1_VERTEX_ATTRIB7_4_NV 0x8667 -#define GL_MAP1_VERTEX_ATTRIB8_4_NV 0x8668 -#define GL_MAP1_VERTEX_ATTRIB9_4_NV 0x8669 -#define GL_MAP1_VERTEX_ATTRIB10_4_NV 0x866A -#define GL_MAP1_VERTEX_ATTRIB11_4_NV 0x866B -#define GL_MAP1_VERTEX_ATTRIB12_4_NV 0x866C -#define GL_MAP1_VERTEX_ATTRIB13_4_NV 0x866D -#define GL_MAP1_VERTEX_ATTRIB14_4_NV 0x866E -#define GL_MAP1_VERTEX_ATTRIB15_4_NV 0x866F -#define GL_MAP2_VERTEX_ATTRIB0_4_NV 0x8670 -#define GL_MAP2_VERTEX_ATTRIB1_4_NV 0x8671 -#define GL_MAP2_VERTEX_ATTRIB2_4_NV 0x8672 -#define GL_MAP2_VERTEX_ATTRIB3_4_NV 0x8673 -#define GL_MAP2_VERTEX_ATTRIB4_4_NV 0x8674 -#define GL_MAP2_VERTEX_ATTRIB5_4_NV 0x8675 -#define GL_MAP2_VERTEX_ATTRIB6_4_NV 0x8676 -#define GL_MAP2_VERTEX_ATTRIB7_4_NV 0x8677 -#define GL_MAP2_VERTEX_ATTRIB8_4_NV 0x8678 -#define GL_MAP2_VERTEX_ATTRIB9_4_NV 0x8679 -#define GL_MAP2_VERTEX_ATTRIB10_4_NV 0x867A -#define GL_MAP2_VERTEX_ATTRIB11_4_NV 0x867B -#define GL_MAP2_VERTEX_ATTRIB12_4_NV 0x867C -#define GL_MAP2_VERTEX_ATTRIB13_4_NV 0x867D -#define GL_MAP2_VERTEX_ATTRIB14_4_NV 0x867E -#define GL_MAP2_VERTEX_ATTRIB15_4_NV 0x867F - -typedef GLboolean (GLAPIENTRY * PFNGLAREPROGRAMSRESIDENTNVPROC) (GLsizei n, const GLuint* ids, GLboolean *residences); -typedef void (GLAPIENTRY * PFNGLBINDPROGRAMNVPROC) (GLenum target, GLuint id); -typedef void (GLAPIENTRY * PFNGLDELETEPROGRAMSNVPROC) (GLsizei n, const GLuint* ids); -typedef void (GLAPIENTRY * PFNGLEXECUTEPROGRAMNVPROC) (GLenum target, GLuint id, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGENPROGRAMSNVPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPARAMETERDVNVPROC) (GLenum target, GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMSTRINGNVPROC) (GLuint id, GLenum pname, GLubyte* program); -typedef void (GLAPIENTRY * PFNGLGETPROGRAMIVNVPROC) (GLuint id, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETTRACKMATRIXIVNVPROC) (GLenum target, GLuint address, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBPOINTERVNVPROC) (GLuint index, GLenum pname, GLvoid** pointer); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBDVNVPROC) (GLuint index, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBFVNVPROC) (GLuint index, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVERTEXATTRIBIVNVPROC) (GLuint index, GLenum pname, GLint* params); -typedef GLboolean (GLAPIENTRY * PFNGLISPROGRAMNVPROC) (GLuint id); -typedef void (GLAPIENTRY * PFNGLLOADPROGRAMNVPROC) (GLenum target, GLuint id, GLsizei len, const GLubyte* program); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4DNVPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4DVNVPROC) (GLenum target, GLuint index, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4FNVPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETER4FVNVPROC) (GLenum target, GLuint index, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERS4DVNVPROC) (GLenum target, GLuint index, GLsizei num, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLPROGRAMPARAMETERS4FVNVPROC) (GLenum target, GLuint index, GLsizei num, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLREQUESTRESIDENTPROGRAMSNVPROC) (GLsizei n, GLuint* ids); -typedef void (GLAPIENTRY * PFNGLTRACKMATRIXNVPROC) (GLenum target, GLuint address, GLenum matrix, GLenum transform); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DNVPROC) (GLuint index, GLdouble x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FNVPROC) (GLuint index, GLfloat x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SNVPROC) (GLuint index, GLshort x); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB1SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DNVPROC) (GLuint index, GLdouble x, GLdouble y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FNVPROC) (GLuint index, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SNVPROC) (GLuint index, GLshort x, GLshort y); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB2SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB3SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4DVNVPROC) (GLuint index, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4FVNVPROC) (GLuint index, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4SVNVPROC) (GLuint index, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBNVPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIB4UBVNVPROC) (GLuint index, const GLubyte* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBPOINTERNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS1SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS2SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS3SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4DVNVPROC) (GLuint index, GLsizei n, const GLdouble* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4FVNVPROC) (GLuint index, GLsizei n, const GLfloat* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4SVNVPROC) (GLuint index, GLsizei n, const GLshort* v); -typedef void (GLAPIENTRY * PFNGLVERTEXATTRIBS4UBVNVPROC) (GLuint index, GLsizei n, const GLubyte* v); - -#define glAreProgramsResidentNV GLEW_GET_FUN(__glewAreProgramsResidentNV) -#define glBindProgramNV GLEW_GET_FUN(__glewBindProgramNV) -#define glDeleteProgramsNV GLEW_GET_FUN(__glewDeleteProgramsNV) -#define glExecuteProgramNV GLEW_GET_FUN(__glewExecuteProgramNV) -#define glGenProgramsNV GLEW_GET_FUN(__glewGenProgramsNV) -#define glGetProgramParameterdvNV GLEW_GET_FUN(__glewGetProgramParameterdvNV) -#define glGetProgramParameterfvNV GLEW_GET_FUN(__glewGetProgramParameterfvNV) -#define glGetProgramStringNV GLEW_GET_FUN(__glewGetProgramStringNV) -#define glGetProgramivNV GLEW_GET_FUN(__glewGetProgramivNV) -#define glGetTrackMatrixivNV GLEW_GET_FUN(__glewGetTrackMatrixivNV) -#define glGetVertexAttribPointervNV GLEW_GET_FUN(__glewGetVertexAttribPointervNV) -#define glGetVertexAttribdvNV GLEW_GET_FUN(__glewGetVertexAttribdvNV) -#define glGetVertexAttribfvNV GLEW_GET_FUN(__glewGetVertexAttribfvNV) -#define glGetVertexAttribivNV GLEW_GET_FUN(__glewGetVertexAttribivNV) -#define glIsProgramNV GLEW_GET_FUN(__glewIsProgramNV) -#define glLoadProgramNV GLEW_GET_FUN(__glewLoadProgramNV) -#define glProgramParameter4dNV GLEW_GET_FUN(__glewProgramParameter4dNV) -#define glProgramParameter4dvNV GLEW_GET_FUN(__glewProgramParameter4dvNV) -#define glProgramParameter4fNV GLEW_GET_FUN(__glewProgramParameter4fNV) -#define glProgramParameter4fvNV GLEW_GET_FUN(__glewProgramParameter4fvNV) -#define glProgramParameters4dvNV GLEW_GET_FUN(__glewProgramParameters4dvNV) -#define glProgramParameters4fvNV GLEW_GET_FUN(__glewProgramParameters4fvNV) -#define glRequestResidentProgramsNV GLEW_GET_FUN(__glewRequestResidentProgramsNV) -#define glTrackMatrixNV GLEW_GET_FUN(__glewTrackMatrixNV) -#define glVertexAttrib1dNV GLEW_GET_FUN(__glewVertexAttrib1dNV) -#define glVertexAttrib1dvNV GLEW_GET_FUN(__glewVertexAttrib1dvNV) -#define glVertexAttrib1fNV GLEW_GET_FUN(__glewVertexAttrib1fNV) -#define glVertexAttrib1fvNV GLEW_GET_FUN(__glewVertexAttrib1fvNV) -#define glVertexAttrib1sNV GLEW_GET_FUN(__glewVertexAttrib1sNV) -#define glVertexAttrib1svNV GLEW_GET_FUN(__glewVertexAttrib1svNV) -#define glVertexAttrib2dNV GLEW_GET_FUN(__glewVertexAttrib2dNV) -#define glVertexAttrib2dvNV GLEW_GET_FUN(__glewVertexAttrib2dvNV) -#define glVertexAttrib2fNV GLEW_GET_FUN(__glewVertexAttrib2fNV) -#define glVertexAttrib2fvNV GLEW_GET_FUN(__glewVertexAttrib2fvNV) -#define glVertexAttrib2sNV GLEW_GET_FUN(__glewVertexAttrib2sNV) -#define glVertexAttrib2svNV GLEW_GET_FUN(__glewVertexAttrib2svNV) -#define glVertexAttrib3dNV GLEW_GET_FUN(__glewVertexAttrib3dNV) -#define glVertexAttrib3dvNV GLEW_GET_FUN(__glewVertexAttrib3dvNV) -#define glVertexAttrib3fNV GLEW_GET_FUN(__glewVertexAttrib3fNV) -#define glVertexAttrib3fvNV GLEW_GET_FUN(__glewVertexAttrib3fvNV) -#define glVertexAttrib3sNV GLEW_GET_FUN(__glewVertexAttrib3sNV) -#define glVertexAttrib3svNV GLEW_GET_FUN(__glewVertexAttrib3svNV) -#define glVertexAttrib4dNV GLEW_GET_FUN(__glewVertexAttrib4dNV) -#define glVertexAttrib4dvNV GLEW_GET_FUN(__glewVertexAttrib4dvNV) -#define glVertexAttrib4fNV GLEW_GET_FUN(__glewVertexAttrib4fNV) -#define glVertexAttrib4fvNV GLEW_GET_FUN(__glewVertexAttrib4fvNV) -#define glVertexAttrib4sNV GLEW_GET_FUN(__glewVertexAttrib4sNV) -#define glVertexAttrib4svNV GLEW_GET_FUN(__glewVertexAttrib4svNV) -#define glVertexAttrib4ubNV GLEW_GET_FUN(__glewVertexAttrib4ubNV) -#define glVertexAttrib4ubvNV GLEW_GET_FUN(__glewVertexAttrib4ubvNV) -#define glVertexAttribPointerNV GLEW_GET_FUN(__glewVertexAttribPointerNV) -#define glVertexAttribs1dvNV GLEW_GET_FUN(__glewVertexAttribs1dvNV) -#define glVertexAttribs1fvNV GLEW_GET_FUN(__glewVertexAttribs1fvNV) -#define glVertexAttribs1svNV GLEW_GET_FUN(__glewVertexAttribs1svNV) -#define glVertexAttribs2dvNV GLEW_GET_FUN(__glewVertexAttribs2dvNV) -#define glVertexAttribs2fvNV GLEW_GET_FUN(__glewVertexAttribs2fvNV) -#define glVertexAttribs2svNV GLEW_GET_FUN(__glewVertexAttribs2svNV) -#define glVertexAttribs3dvNV GLEW_GET_FUN(__glewVertexAttribs3dvNV) -#define glVertexAttribs3fvNV GLEW_GET_FUN(__glewVertexAttribs3fvNV) -#define glVertexAttribs3svNV GLEW_GET_FUN(__glewVertexAttribs3svNV) -#define glVertexAttribs4dvNV GLEW_GET_FUN(__glewVertexAttribs4dvNV) -#define glVertexAttribs4fvNV GLEW_GET_FUN(__glewVertexAttribs4fvNV) -#define glVertexAttribs4svNV GLEW_GET_FUN(__glewVertexAttribs4svNV) -#define glVertexAttribs4ubvNV GLEW_GET_FUN(__glewVertexAttribs4ubvNV) - -#define GLEW_NV_vertex_program GLEW_GET_VAR(__GLEW_NV_vertex_program) - -#endif /* GL_NV_vertex_program */ - -/* ------------------------ GL_NV_vertex_program1_1 ------------------------ */ - -#ifndef GL_NV_vertex_program1_1 -#define GL_NV_vertex_program1_1 1 - -#define GLEW_NV_vertex_program1_1 GLEW_GET_VAR(__GLEW_NV_vertex_program1_1) - -#endif /* GL_NV_vertex_program1_1 */ - -/* ------------------------- GL_NV_vertex_program2 ------------------------- */ - -#ifndef GL_NV_vertex_program2 -#define GL_NV_vertex_program2 1 - -#define GLEW_NV_vertex_program2 GLEW_GET_VAR(__GLEW_NV_vertex_program2) - -#endif /* GL_NV_vertex_program2 */ - -/* ---------------------- GL_NV_vertex_program2_option --------------------- */ - -#ifndef GL_NV_vertex_program2_option -#define GL_NV_vertex_program2_option 1 - -#define GL_MAX_PROGRAM_EXEC_INSTRUCTIONS_NV 0x88F4 -#define GL_MAX_PROGRAM_CALL_DEPTH_NV 0x88F5 - -#define GLEW_NV_vertex_program2_option GLEW_GET_VAR(__GLEW_NV_vertex_program2_option) - -#endif /* GL_NV_vertex_program2_option */ - -/* ------------------------- GL_NV_vertex_program3 ------------------------- */ - -#ifndef GL_NV_vertex_program3 -#define GL_NV_vertex_program3 1 - -#define MAX_VERTEX_TEXTURE_IMAGE_UNITS_ARB 0x8B4C - -#define GLEW_NV_vertex_program3 GLEW_GET_VAR(__GLEW_NV_vertex_program3) - -#endif /* GL_NV_vertex_program3 */ - -/* ------------------------- GL_NV_vertex_program4 ------------------------- */ - -#ifndef GL_NV_vertex_program4 -#define GL_NV_vertex_program4 1 - -#define GL_VERTEX_ATTRIB_ARRAY_INTEGER_NV 0x88FD - -#define GLEW_NV_vertex_program4 GLEW_GET_VAR(__GLEW_NV_vertex_program4) - -#endif /* GL_NV_vertex_program4 */ - -/* -------------------------- GL_NV_video_capture -------------------------- */ - -#ifndef GL_NV_video_capture -#define GL_NV_video_capture 1 - -#define GL_VIDEO_BUFFER_NV 0x9020 -#define GL_VIDEO_BUFFER_BINDING_NV 0x9021 -#define GL_FIELD_UPPER_NV 0x9022 -#define GL_FIELD_LOWER_NV 0x9023 -#define GL_NUM_VIDEO_CAPTURE_STREAMS_NV 0x9024 -#define GL_NEXT_VIDEO_CAPTURE_BUFFER_STATUS_NV 0x9025 -#define GL_VIDEO_CAPTURE_TO_422_SUPPORTED_NV 0x9026 -#define GL_LAST_VIDEO_CAPTURE_STATUS_NV 0x9027 -#define GL_VIDEO_BUFFER_PITCH_NV 0x9028 -#define GL_VIDEO_COLOR_CONVERSION_MATRIX_NV 0x9029 -#define GL_VIDEO_COLOR_CONVERSION_MAX_NV 0x902A -#define GL_VIDEO_COLOR_CONVERSION_MIN_NV 0x902B -#define GL_VIDEO_COLOR_CONVERSION_OFFSET_NV 0x902C -#define GL_VIDEO_BUFFER_INTERNAL_FORMAT_NV 0x902D -#define GL_PARTIAL_SUCCESS_NV 0x902E -#define GL_SUCCESS_NV 0x902F -#define GL_FAILURE_NV 0x9030 -#define GL_YCBYCR8_422_NV 0x9031 -#define GL_YCBAYCR8A_4224_NV 0x9032 -#define GL_Z6Y10Z6CB10Z6Y10Z6CR10_422_NV 0x9033 -#define GL_Z6Y10Z6CB10Z6A10Z6Y10Z6CR10Z6A10_4224_NV 0x9034 -#define GL_Z4Y12Z4CB12Z4Y12Z4CR12_422_NV 0x9035 -#define GL_Z4Y12Z4CB12Z4A12Z4Y12Z4CR12Z4A12_4224_NV 0x9036 -#define GL_Z4Y12Z4CB12Z4CR12_444_NV 0x9037 -#define GL_VIDEO_CAPTURE_FRAME_WIDTH_NV 0x9038 -#define GL_VIDEO_CAPTURE_FRAME_HEIGHT_NV 0x9039 -#define GL_VIDEO_CAPTURE_FIELD_UPPER_HEIGHT_NV 0x903A -#define GL_VIDEO_CAPTURE_FIELD_LOWER_HEIGHT_NV 0x903B -#define GL_VIDEO_CAPTURE_SURFACE_ORIGIN_NV 0x903C - -typedef void (GLAPIENTRY * PFNGLBEGINVIDEOCAPTURENVPROC) (GLuint video_capture_slot); -typedef void (GLAPIENTRY * PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLintptrARB offset); -typedef void (GLAPIENTRY * PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC) (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLenum target, GLuint texture); -typedef void (GLAPIENTRY * PFNGLENDVIDEOCAPTURENVPROC) (GLuint video_capture_slot); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTURESTREAMDVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLdouble* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTURESTREAMFVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTURESTREAMIVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETVIDEOCAPTUREIVNVPROC) (GLuint video_capture_slot, GLenum pname, GLint* params); -typedef GLenum (GLAPIENTRY * PFNGLVIDEOCAPTURENVPROC) (GLuint video_capture_slot, GLuint* sequence_num, GLuint64EXT *capture_time); -typedef void (GLAPIENTRY * PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLdouble* params); -typedef void (GLAPIENTRY * PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLint* params); - -#define glBeginVideoCaptureNV GLEW_GET_FUN(__glewBeginVideoCaptureNV) -#define glBindVideoCaptureStreamBufferNV GLEW_GET_FUN(__glewBindVideoCaptureStreamBufferNV) -#define glBindVideoCaptureStreamTextureNV GLEW_GET_FUN(__glewBindVideoCaptureStreamTextureNV) -#define glEndVideoCaptureNV GLEW_GET_FUN(__glewEndVideoCaptureNV) -#define glGetVideoCaptureStreamdvNV GLEW_GET_FUN(__glewGetVideoCaptureStreamdvNV) -#define glGetVideoCaptureStreamfvNV GLEW_GET_FUN(__glewGetVideoCaptureStreamfvNV) -#define glGetVideoCaptureStreamivNV GLEW_GET_FUN(__glewGetVideoCaptureStreamivNV) -#define glGetVideoCaptureivNV GLEW_GET_FUN(__glewGetVideoCaptureivNV) -#define glVideoCaptureNV GLEW_GET_FUN(__glewVideoCaptureNV) -#define glVideoCaptureStreamParameterdvNV GLEW_GET_FUN(__glewVideoCaptureStreamParameterdvNV) -#define glVideoCaptureStreamParameterfvNV GLEW_GET_FUN(__glewVideoCaptureStreamParameterfvNV) -#define glVideoCaptureStreamParameterivNV GLEW_GET_FUN(__glewVideoCaptureStreamParameterivNV) - -#define GLEW_NV_video_capture GLEW_GET_VAR(__GLEW_NV_video_capture) - -#endif /* GL_NV_video_capture */ - -/* ------------------------ GL_OES_byte_coordinates ------------------------ */ - -#ifndef GL_OES_byte_coordinates -#define GL_OES_byte_coordinates 1 - -#define GLEW_OES_byte_coordinates GLEW_GET_VAR(__GLEW_OES_byte_coordinates) - -#endif /* GL_OES_byte_coordinates */ - -/* ------------------- GL_OES_compressed_paletted_texture ------------------ */ - -#ifndef GL_OES_compressed_paletted_texture -#define GL_OES_compressed_paletted_texture 1 - -#define GL_PALETTE4_RGB8_OES 0x8B90 -#define GL_PALETTE4_RGBA8_OES 0x8B91 -#define GL_PALETTE4_R5_G6_B5_OES 0x8B92 -#define GL_PALETTE4_RGBA4_OES 0x8B93 -#define GL_PALETTE4_RGB5_A1_OES 0x8B94 -#define GL_PALETTE8_RGB8_OES 0x8B95 -#define GL_PALETTE8_RGBA8_OES 0x8B96 -#define GL_PALETTE8_R5_G6_B5_OES 0x8B97 -#define GL_PALETTE8_RGBA4_OES 0x8B98 -#define GL_PALETTE8_RGB5_A1_OES 0x8B99 - -#define GLEW_OES_compressed_paletted_texture GLEW_GET_VAR(__GLEW_OES_compressed_paletted_texture) - -#endif /* GL_OES_compressed_paletted_texture */ - -/* --------------------------- GL_OES_read_format -------------------------- */ - -#ifndef GL_OES_read_format -#define GL_OES_read_format 1 - -#define GL_IMPLEMENTATION_COLOR_READ_TYPE_OES 0x8B9A -#define GL_IMPLEMENTATION_COLOR_READ_FORMAT_OES 0x8B9B - -#define GLEW_OES_read_format GLEW_GET_VAR(__GLEW_OES_read_format) - -#endif /* GL_OES_read_format */ - -/* ------------------------ GL_OES_single_precision ------------------------ */ - -#ifndef GL_OES_single_precision -#define GL_OES_single_precision 1 - -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHFOESPROC) (GLclampd depth); -typedef void (GLAPIENTRY * PFNGLCLIPPLANEFOESPROC) (GLenum plane, const GLfloat* equation); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEFOESPROC) (GLclampf n, GLclampf f); -typedef void (GLAPIENTRY * PFNGLFRUSTUMFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); -typedef void (GLAPIENTRY * PFNGLGETCLIPPLANEFOESPROC) (GLenum plane, GLfloat* equation); -typedef void (GLAPIENTRY * PFNGLORTHOFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); - -#define glClearDepthfOES GLEW_GET_FUN(__glewClearDepthfOES) -#define glClipPlanefOES GLEW_GET_FUN(__glewClipPlanefOES) -#define glDepthRangefOES GLEW_GET_FUN(__glewDepthRangefOES) -#define glFrustumfOES GLEW_GET_FUN(__glewFrustumfOES) -#define glGetClipPlanefOES GLEW_GET_FUN(__glewGetClipPlanefOES) -#define glOrthofOES GLEW_GET_FUN(__glewOrthofOES) - -#define GLEW_OES_single_precision GLEW_GET_VAR(__GLEW_OES_single_precision) - -#endif /* GL_OES_single_precision */ - -/* ---------------------------- GL_OML_interlace --------------------------- */ - -#ifndef GL_OML_interlace -#define GL_OML_interlace 1 - -#define GL_INTERLACE_OML 0x8980 -#define GL_INTERLACE_READ_OML 0x8981 - -#define GLEW_OML_interlace GLEW_GET_VAR(__GLEW_OML_interlace) - -#endif /* GL_OML_interlace */ - -/* ---------------------------- GL_OML_resample ---------------------------- */ - -#ifndef GL_OML_resample -#define GL_OML_resample 1 - -#define GL_PACK_RESAMPLE_OML 0x8984 -#define GL_UNPACK_RESAMPLE_OML 0x8985 -#define GL_RESAMPLE_REPLICATE_OML 0x8986 -#define GL_RESAMPLE_ZERO_FILL_OML 0x8987 -#define GL_RESAMPLE_AVERAGE_OML 0x8988 -#define GL_RESAMPLE_DECIMATE_OML 0x8989 - -#define GLEW_OML_resample GLEW_GET_VAR(__GLEW_OML_resample) - -#endif /* GL_OML_resample */ - -/* ---------------------------- GL_OML_subsample --------------------------- */ - -#ifndef GL_OML_subsample -#define GL_OML_subsample 1 - -#define GL_FORMAT_SUBSAMPLE_24_24_OML 0x8982 -#define GL_FORMAT_SUBSAMPLE_244_244_OML 0x8983 - -#define GLEW_OML_subsample GLEW_GET_VAR(__GLEW_OML_subsample) - -#endif /* GL_OML_subsample */ - -/* --------------------------- GL_PGI_misc_hints --------------------------- */ - -#ifndef GL_PGI_misc_hints -#define GL_PGI_misc_hints 1 - -#define GL_PREFER_DOUBLEBUFFER_HINT_PGI 107000 -#define GL_CONSERVE_MEMORY_HINT_PGI 107005 -#define GL_RECLAIM_MEMORY_HINT_PGI 107006 -#define GL_NATIVE_GRAPHICS_HANDLE_PGI 107010 -#define GL_NATIVE_GRAPHICS_BEGIN_HINT_PGI 107011 -#define GL_NATIVE_GRAPHICS_END_HINT_PGI 107012 -#define GL_ALWAYS_FAST_HINT_PGI 107020 -#define GL_ALWAYS_SOFT_HINT_PGI 107021 -#define GL_ALLOW_DRAW_OBJ_HINT_PGI 107022 -#define GL_ALLOW_DRAW_WIN_HINT_PGI 107023 -#define GL_ALLOW_DRAW_FRG_HINT_PGI 107024 -#define GL_ALLOW_DRAW_MEM_HINT_PGI 107025 -#define GL_STRICT_DEPTHFUNC_HINT_PGI 107030 -#define GL_STRICT_LIGHTING_HINT_PGI 107031 -#define GL_STRICT_SCISSOR_HINT_PGI 107032 -#define GL_FULL_STIPPLE_HINT_PGI 107033 -#define GL_CLIP_NEAR_HINT_PGI 107040 -#define GL_CLIP_FAR_HINT_PGI 107041 -#define GL_WIDE_LINE_HINT_PGI 107042 -#define GL_BACK_NORMALS_HINT_PGI 107043 - -#define GLEW_PGI_misc_hints GLEW_GET_VAR(__GLEW_PGI_misc_hints) - -#endif /* GL_PGI_misc_hints */ - -/* -------------------------- GL_PGI_vertex_hints -------------------------- */ - -#ifndef GL_PGI_vertex_hints -#define GL_PGI_vertex_hints 1 - -#define GL_VERTEX23_BIT_PGI 0x00000004 -#define GL_VERTEX4_BIT_PGI 0x00000008 -#define GL_COLOR3_BIT_PGI 0x00010000 -#define GL_COLOR4_BIT_PGI 0x00020000 -#define GL_EDGEFLAG_BIT_PGI 0x00040000 -#define GL_INDEX_BIT_PGI 0x00080000 -#define GL_MAT_AMBIENT_BIT_PGI 0x00100000 -#define GL_VERTEX_DATA_HINT_PGI 107050 -#define GL_VERTEX_CONSISTENT_HINT_PGI 107051 -#define GL_MATERIAL_SIDE_HINT_PGI 107052 -#define GL_MAX_VERTEX_HINT_PGI 107053 -#define GL_MAT_AMBIENT_AND_DIFFUSE_BIT_PGI 0x00200000 -#define GL_MAT_DIFFUSE_BIT_PGI 0x00400000 -#define GL_MAT_EMISSION_BIT_PGI 0x00800000 -#define GL_MAT_COLOR_INDEXES_BIT_PGI 0x01000000 -#define GL_MAT_SHININESS_BIT_PGI 0x02000000 -#define GL_MAT_SPECULAR_BIT_PGI 0x04000000 -#define GL_NORMAL_BIT_PGI 0x08000000 -#define GL_TEXCOORD1_BIT_PGI 0x10000000 -#define GL_TEXCOORD2_BIT_PGI 0x20000000 -#define GL_TEXCOORD3_BIT_PGI 0x40000000 -#define GL_TEXCOORD4_BIT_PGI 0x80000000 - -#define GLEW_PGI_vertex_hints GLEW_GET_VAR(__GLEW_PGI_vertex_hints) - -#endif /* GL_PGI_vertex_hints */ - -/* ---------------------- GL_REGAL_ES1_0_compatibility --------------------- */ - -#ifndef GL_REGAL_ES1_0_compatibility -#define GL_REGAL_ES1_0_compatibility 1 - -typedef int GLclampx; - -typedef void (GLAPIENTRY * PFNGLALPHAFUNCXPROC) (GLenum func, GLclampx ref); -typedef void (GLAPIENTRY * PFNGLCLEARCOLORXPROC) (GLclampx red, GLclampx green, GLclampx blue, GLclampx alpha); -typedef void (GLAPIENTRY * PFNGLCLEARDEPTHXPROC) (GLclampx depth); -typedef void (GLAPIENTRY * PFNGLCOLOR4XPROC) (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); -typedef void (GLAPIENTRY * PFNGLDEPTHRANGEXPROC) (GLclampx zNear, GLclampx zFar); -typedef void (GLAPIENTRY * PFNGLFOGXPROC) (GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLFOGXVPROC) (GLenum pname, const GLfixed* params); -typedef void (GLAPIENTRY * PFNGLFRUSTUMFPROC) (GLfloat left, GLfloat right, GLfloat bottom, GLfloat top, GLfloat zNear, GLfloat zFar); -typedef void (GLAPIENTRY * PFNGLFRUSTUMXPROC) (GLfixed left, GLfixed right, GLfixed bottom, GLfixed top, GLfixed zNear, GLfixed zFar); -typedef void (GLAPIENTRY * PFNGLLIGHTMODELXPROC) (GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLLIGHTMODELXVPROC) (GLenum pname, const GLfixed* params); -typedef void (GLAPIENTRY * PFNGLLIGHTXPROC) (GLenum light, GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLLIGHTXVPROC) (GLenum light, GLenum pname, const GLfixed* params); -typedef void (GLAPIENTRY * PFNGLLINEWIDTHXPROC) (GLfixed width); -typedef void (GLAPIENTRY * PFNGLLOADMATRIXXPROC) (const GLfixed* m); -typedef void (GLAPIENTRY * PFNGLMATERIALXPROC) (GLenum face, GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLMATERIALXVPROC) (GLenum face, GLenum pname, const GLfixed* params); -typedef void (GLAPIENTRY * PFNGLMULTMATRIXXPROC) (const GLfixed* m); -typedef void (GLAPIENTRY * PFNGLMULTITEXCOORD4XPROC) (GLenum target, GLfixed s, GLfixed t, GLfixed r, GLfixed q); -typedef void (GLAPIENTRY * PFNGLNORMAL3XPROC) (GLfixed nx, GLfixed ny, GLfixed nz); -typedef void (GLAPIENTRY * PFNGLORTHOFPROC) (GLfloat left, GLfloat right, GLfloat bottom, GLfloat top, GLfloat zNear, GLfloat zFar); -typedef void (GLAPIENTRY * PFNGLORTHOXPROC) (GLfixed left, GLfixed right, GLfixed bottom, GLfixed top, GLfixed zNear, GLfixed zFar); -typedef void (GLAPIENTRY * PFNGLPOINTSIZEXPROC) (GLfixed size); -typedef void (GLAPIENTRY * PFNGLPOLYGONOFFSETXPROC) (GLfixed factor, GLfixed units); -typedef void (GLAPIENTRY * PFNGLROTATEXPROC) (GLfixed angle, GLfixed x, GLfixed y, GLfixed z); -typedef void (GLAPIENTRY * PFNGLSAMPLECOVERAGEXPROC) (GLclampx value, GLboolean invert); -typedef void (GLAPIENTRY * PFNGLSCALEXPROC) (GLfixed x, GLfixed y, GLfixed z); -typedef void (GLAPIENTRY * PFNGLTEXENVXPROC) (GLenum target, GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLTEXENVXVPROC) (GLenum target, GLenum pname, const GLfixed* params); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERXPROC) (GLenum target, GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLTRANSLATEXPROC) (GLfixed x, GLfixed y, GLfixed z); - -#define glAlphaFuncx GLEW_GET_FUN(__glewAlphaFuncx) -#define glClearColorx GLEW_GET_FUN(__glewClearColorx) -#define glClearDepthx GLEW_GET_FUN(__glewClearDepthx) -#define glColor4x GLEW_GET_FUN(__glewColor4x) -#define glDepthRangex GLEW_GET_FUN(__glewDepthRangex) -#define glFogx GLEW_GET_FUN(__glewFogx) -#define glFogxv GLEW_GET_FUN(__glewFogxv) -#define glFrustumf GLEW_GET_FUN(__glewFrustumf) -#define glFrustumx GLEW_GET_FUN(__glewFrustumx) -#define glLightModelx GLEW_GET_FUN(__glewLightModelx) -#define glLightModelxv GLEW_GET_FUN(__glewLightModelxv) -#define glLightx GLEW_GET_FUN(__glewLightx) -#define glLightxv GLEW_GET_FUN(__glewLightxv) -#define glLineWidthx GLEW_GET_FUN(__glewLineWidthx) -#define glLoadMatrixx GLEW_GET_FUN(__glewLoadMatrixx) -#define glMaterialx GLEW_GET_FUN(__glewMaterialx) -#define glMaterialxv GLEW_GET_FUN(__glewMaterialxv) -#define glMultMatrixx GLEW_GET_FUN(__glewMultMatrixx) -#define glMultiTexCoord4x GLEW_GET_FUN(__glewMultiTexCoord4x) -#define glNormal3x GLEW_GET_FUN(__glewNormal3x) -#define glOrthof GLEW_GET_FUN(__glewOrthof) -#define glOrthox GLEW_GET_FUN(__glewOrthox) -#define glPointSizex GLEW_GET_FUN(__glewPointSizex) -#define glPolygonOffsetx GLEW_GET_FUN(__glewPolygonOffsetx) -#define glRotatex GLEW_GET_FUN(__glewRotatex) -#define glSampleCoveragex GLEW_GET_FUN(__glewSampleCoveragex) -#define glScalex GLEW_GET_FUN(__glewScalex) -#define glTexEnvx GLEW_GET_FUN(__glewTexEnvx) -#define glTexEnvxv GLEW_GET_FUN(__glewTexEnvxv) -#define glTexParameterx GLEW_GET_FUN(__glewTexParameterx) -#define glTranslatex GLEW_GET_FUN(__glewTranslatex) - -#define GLEW_REGAL_ES1_0_compatibility GLEW_GET_VAR(__GLEW_REGAL_ES1_0_compatibility) - -#endif /* GL_REGAL_ES1_0_compatibility */ - -/* ---------------------- GL_REGAL_ES1_1_compatibility --------------------- */ - -#ifndef GL_REGAL_ES1_1_compatibility -#define GL_REGAL_ES1_1_compatibility 1 - -typedef void (GLAPIENTRY * PFNGLCLIPPLANEFPROC) (GLenum plane, const GLfloat* equation); -typedef void (GLAPIENTRY * PFNGLCLIPPLANEXPROC) (GLenum plane, const GLfixed* equation); -typedef void (GLAPIENTRY * PFNGLGETCLIPPLANEFPROC) (GLenum pname, GLfloat eqn[4]); -typedef void (GLAPIENTRY * PFNGLGETCLIPPLANEXPROC) (GLenum pname, GLfixed eqn[4]); -typedef void (GLAPIENTRY * PFNGLGETFIXEDVPROC) (GLenum pname, GLfixed* params); -typedef void (GLAPIENTRY * PFNGLGETLIGHTXVPROC) (GLenum light, GLenum pname, GLfixed* params); -typedef void (GLAPIENTRY * PFNGLGETMATERIALXVPROC) (GLenum face, GLenum pname, GLfixed* params); -typedef void (GLAPIENTRY * PFNGLGETTEXENVXVPROC) (GLenum env, GLenum pname, GLfixed* params); -typedef void (GLAPIENTRY * PFNGLGETTEXPARAMETERXVPROC) (GLenum target, GLenum pname, GLfixed* params); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERXPROC) (GLenum pname, GLfixed param); -typedef void (GLAPIENTRY * PFNGLPOINTPARAMETERXVPROC) (GLenum pname, const GLfixed* params); -typedef void (GLAPIENTRY * PFNGLPOINTSIZEPOINTEROESPROC) (GLenum type, GLsizei stride, const GLvoid* pointer); -typedef void (GLAPIENTRY * PFNGLTEXPARAMETERXVPROC) (GLenum target, GLenum pname, const GLfixed* params); - -#define glClipPlanef GLEW_GET_FUN(__glewClipPlanef) -#define glClipPlanex GLEW_GET_FUN(__glewClipPlanex) -#define glGetClipPlanef GLEW_GET_FUN(__glewGetClipPlanef) -#define glGetClipPlanex GLEW_GET_FUN(__glewGetClipPlanex) -#define glGetFixedv GLEW_GET_FUN(__glewGetFixedv) -#define glGetLightxv GLEW_GET_FUN(__glewGetLightxv) -#define glGetMaterialxv GLEW_GET_FUN(__glewGetMaterialxv) -#define glGetTexEnvxv GLEW_GET_FUN(__glewGetTexEnvxv) -#define glGetTexParameterxv GLEW_GET_FUN(__glewGetTexParameterxv) -#define glPointParameterx GLEW_GET_FUN(__glewPointParameterx) -#define glPointParameterxv GLEW_GET_FUN(__glewPointParameterxv) -#define glPointSizePointerOES GLEW_GET_FUN(__glewPointSizePointerOES) -#define glTexParameterxv GLEW_GET_FUN(__glewTexParameterxv) - -#define GLEW_REGAL_ES1_1_compatibility GLEW_GET_VAR(__GLEW_REGAL_ES1_1_compatibility) - -#endif /* GL_REGAL_ES1_1_compatibility */ - -/* ---------------------------- GL_REGAL_enable ---------------------------- */ - -#ifndef GL_REGAL_enable -#define GL_REGAL_enable 1 - -#define GL_ERROR_REGAL 0x9322 -#define GL_DEBUG_REGAL 0x9323 -#define GL_LOG_REGAL 0x9324 -#define GL_EMULATION_REGAL 0x9325 -#define GL_DRIVER_REGAL 0x9326 -#define GL_MISSING_REGAL 0x9360 -#define GL_TRACE_REGAL 0x9361 -#define GL_CACHE_REGAL 0x9362 -#define GL_CODE_REGAL 0x9363 -#define GL_STATISTICS_REGAL 0x9364 - -#define GLEW_REGAL_enable GLEW_GET_VAR(__GLEW_REGAL_enable) - -#endif /* GL_REGAL_enable */ - -/* ------------------------- GL_REGAL_error_string ------------------------- */ - -#ifndef GL_REGAL_error_string -#define GL_REGAL_error_string 1 - -typedef const GLchar* (GLAPIENTRY * PFNGLERRORSTRINGREGALPROC) (GLenum error); - -#define glErrorStringREGAL GLEW_GET_FUN(__glewErrorStringREGAL) - -#define GLEW_REGAL_error_string GLEW_GET_VAR(__GLEW_REGAL_error_string) - -#endif /* GL_REGAL_error_string */ - -/* ------------------------ GL_REGAL_extension_query ----------------------- */ - -#ifndef GL_REGAL_extension_query -#define GL_REGAL_extension_query 1 - -typedef GLboolean (GLAPIENTRY * PFNGLGETEXTENSIONREGALPROC) (const GLchar* ext); -typedef GLboolean (GLAPIENTRY * PFNGLISSUPPORTEDREGALPROC) (const GLchar* ext); - -#define glGetExtensionREGAL GLEW_GET_FUN(__glewGetExtensionREGAL) -#define glIsSupportedREGAL GLEW_GET_FUN(__glewIsSupportedREGAL) - -#define GLEW_REGAL_extension_query GLEW_GET_VAR(__GLEW_REGAL_extension_query) - -#endif /* GL_REGAL_extension_query */ - -/* ------------------------------ GL_REGAL_log ----------------------------- */ - -#ifndef GL_REGAL_log -#define GL_REGAL_log 1 - -#define GL_LOG_ERROR_REGAL 0x9319 -#define GL_LOG_WARNING_REGAL 0x931A -#define GL_LOG_INFO_REGAL 0x931B -#define GL_LOG_APP_REGAL 0x931C -#define GL_LOG_DRIVER_REGAL 0x931D -#define GL_LOG_INTERNAL_REGAL 0x931E -#define GL_LOG_DEBUG_REGAL 0x931F -#define GL_LOG_STATUS_REGAL 0x9320 -#define GL_LOG_HTTP_REGAL 0x9321 - -typedef void (APIENTRY *GLLOGPROCREGAL)(GLenum stream, GLsizei length, const GLchar *message, GLvoid *context); - -typedef void (GLAPIENTRY * PFNGLLOGMESSAGECALLBACKREGALPROC) (GLLOGPROCREGAL callback); - -#define glLogMessageCallbackREGAL GLEW_GET_FUN(__glewLogMessageCallbackREGAL) - -#define GLEW_REGAL_log GLEW_GET_VAR(__GLEW_REGAL_log) - -#endif /* GL_REGAL_log */ - -/* ----------------------- GL_REND_screen_coordinates ---------------------- */ - -#ifndef GL_REND_screen_coordinates -#define GL_REND_screen_coordinates 1 - -#define GL_SCREEN_COORDINATES_REND 0x8490 -#define GL_INVERTED_SCREEN_W_REND 0x8491 - -#define GLEW_REND_screen_coordinates GLEW_GET_VAR(__GLEW_REND_screen_coordinates) - -#endif /* GL_REND_screen_coordinates */ - -/* ------------------------------- GL_S3_s3tc ------------------------------ */ - -#ifndef GL_S3_s3tc -#define GL_S3_s3tc 1 - -#define GL_RGB_S3TC 0x83A0 -#define GL_RGB4_S3TC 0x83A1 -#define GL_RGBA_S3TC 0x83A2 -#define GL_RGBA4_S3TC 0x83A3 -#define GL_RGBA_DXT5_S3TC 0x83A4 -#define GL_RGBA4_DXT5_S3TC 0x83A5 - -#define GLEW_S3_s3tc GLEW_GET_VAR(__GLEW_S3_s3tc) - -#endif /* GL_S3_s3tc */ - -/* -------------------------- GL_SGIS_color_range -------------------------- */ - -#ifndef GL_SGIS_color_range -#define GL_SGIS_color_range 1 - -#define GL_EXTENDED_RANGE_SGIS 0x85A5 -#define GL_MIN_RED_SGIS 0x85A6 -#define GL_MAX_RED_SGIS 0x85A7 -#define GL_MIN_GREEN_SGIS 0x85A8 -#define GL_MAX_GREEN_SGIS 0x85A9 -#define GL_MIN_BLUE_SGIS 0x85AA -#define GL_MAX_BLUE_SGIS 0x85AB -#define GL_MIN_ALPHA_SGIS 0x85AC -#define GL_MAX_ALPHA_SGIS 0x85AD - -#define GLEW_SGIS_color_range GLEW_GET_VAR(__GLEW_SGIS_color_range) - -#endif /* GL_SGIS_color_range */ - -/* ------------------------- GL_SGIS_detail_texture ------------------------ */ - -#ifndef GL_SGIS_detail_texture -#define GL_SGIS_detail_texture 1 - -typedef void (GLAPIENTRY * PFNGLDETAILTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat* points); -typedef void (GLAPIENTRY * PFNGLGETDETAILTEXFUNCSGISPROC) (GLenum target, GLfloat* points); - -#define glDetailTexFuncSGIS GLEW_GET_FUN(__glewDetailTexFuncSGIS) -#define glGetDetailTexFuncSGIS GLEW_GET_FUN(__glewGetDetailTexFuncSGIS) - -#define GLEW_SGIS_detail_texture GLEW_GET_VAR(__GLEW_SGIS_detail_texture) - -#endif /* GL_SGIS_detail_texture */ - -/* -------------------------- GL_SGIS_fog_function ------------------------- */ - -#ifndef GL_SGIS_fog_function -#define GL_SGIS_fog_function 1 - -typedef void (GLAPIENTRY * PFNGLFOGFUNCSGISPROC) (GLsizei n, const GLfloat* points); -typedef void (GLAPIENTRY * PFNGLGETFOGFUNCSGISPROC) (GLfloat* points); - -#define glFogFuncSGIS GLEW_GET_FUN(__glewFogFuncSGIS) -#define glGetFogFuncSGIS GLEW_GET_FUN(__glewGetFogFuncSGIS) - -#define GLEW_SGIS_fog_function GLEW_GET_VAR(__GLEW_SGIS_fog_function) - -#endif /* GL_SGIS_fog_function */ - -/* ------------------------ GL_SGIS_generate_mipmap ------------------------ */ - -#ifndef GL_SGIS_generate_mipmap -#define GL_SGIS_generate_mipmap 1 - -#define GL_GENERATE_MIPMAP_SGIS 0x8191 -#define GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 - -#define GLEW_SGIS_generate_mipmap GLEW_GET_VAR(__GLEW_SGIS_generate_mipmap) - -#endif /* GL_SGIS_generate_mipmap */ - -/* -------------------------- GL_SGIS_multisample -------------------------- */ - -#ifndef GL_SGIS_multisample -#define GL_SGIS_multisample 1 - -#define GL_MULTISAMPLE_SGIS 0x809D -#define GL_SAMPLE_ALPHA_TO_MASK_SGIS 0x809E -#define GL_SAMPLE_ALPHA_TO_ONE_SGIS 0x809F -#define GL_SAMPLE_MASK_SGIS 0x80A0 -#define GL_1PASS_SGIS 0x80A1 -#define GL_2PASS_0_SGIS 0x80A2 -#define GL_2PASS_1_SGIS 0x80A3 -#define GL_4PASS_0_SGIS 0x80A4 -#define GL_4PASS_1_SGIS 0x80A5 -#define GL_4PASS_2_SGIS 0x80A6 -#define GL_4PASS_3_SGIS 0x80A7 -#define GL_SAMPLE_BUFFERS_SGIS 0x80A8 -#define GL_SAMPLES_SGIS 0x80A9 -#define GL_SAMPLE_MASK_VALUE_SGIS 0x80AA -#define GL_SAMPLE_MASK_INVERT_SGIS 0x80AB -#define GL_SAMPLE_PATTERN_SGIS 0x80AC - -typedef void (GLAPIENTRY * PFNGLSAMPLEMASKSGISPROC) (GLclampf value, GLboolean invert); -typedef void (GLAPIENTRY * PFNGLSAMPLEPATTERNSGISPROC) (GLenum pattern); - -#define glSampleMaskSGIS GLEW_GET_FUN(__glewSampleMaskSGIS) -#define glSamplePatternSGIS GLEW_GET_FUN(__glewSamplePatternSGIS) - -#define GLEW_SGIS_multisample GLEW_GET_VAR(__GLEW_SGIS_multisample) - -#endif /* GL_SGIS_multisample */ - -/* ------------------------- GL_SGIS_pixel_texture ------------------------- */ - -#ifndef GL_SGIS_pixel_texture -#define GL_SGIS_pixel_texture 1 - -#define GLEW_SGIS_pixel_texture GLEW_GET_VAR(__GLEW_SGIS_pixel_texture) - -#endif /* GL_SGIS_pixel_texture */ - -/* ----------------------- GL_SGIS_point_line_texgen ----------------------- */ - -#ifndef GL_SGIS_point_line_texgen -#define GL_SGIS_point_line_texgen 1 - -#define GL_EYE_DISTANCE_TO_POINT_SGIS 0x81F0 -#define GL_OBJECT_DISTANCE_TO_POINT_SGIS 0x81F1 -#define GL_EYE_DISTANCE_TO_LINE_SGIS 0x81F2 -#define GL_OBJECT_DISTANCE_TO_LINE_SGIS 0x81F3 -#define GL_EYE_POINT_SGIS 0x81F4 -#define GL_OBJECT_POINT_SGIS 0x81F5 -#define GL_EYE_LINE_SGIS 0x81F6 -#define GL_OBJECT_LINE_SGIS 0x81F7 - -#define GLEW_SGIS_point_line_texgen GLEW_GET_VAR(__GLEW_SGIS_point_line_texgen) - -#endif /* GL_SGIS_point_line_texgen */ - -/* ------------------------ GL_SGIS_sharpen_texture ------------------------ */ - -#ifndef GL_SGIS_sharpen_texture -#define GL_SGIS_sharpen_texture 1 - -typedef void (GLAPIENTRY * PFNGLGETSHARPENTEXFUNCSGISPROC) (GLenum target, GLfloat* points); -typedef void (GLAPIENTRY * PFNGLSHARPENTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat* points); - -#define glGetSharpenTexFuncSGIS GLEW_GET_FUN(__glewGetSharpenTexFuncSGIS) -#define glSharpenTexFuncSGIS GLEW_GET_FUN(__glewSharpenTexFuncSGIS) - -#define GLEW_SGIS_sharpen_texture GLEW_GET_VAR(__GLEW_SGIS_sharpen_texture) - -#endif /* GL_SGIS_sharpen_texture */ - -/* --------------------------- GL_SGIS_texture4D --------------------------- */ - -#ifndef GL_SGIS_texture4D -#define GL_SGIS_texture4D 1 - -typedef void (GLAPIENTRY * PFNGLTEXIMAGE4DSGISPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLint border, GLenum format, GLenum type, const GLvoid *pixels); -typedef void (GLAPIENTRY * PFNGLTEXSUBIMAGE4DSGISPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint woffset, GLsizei width, GLsizei height, GLsizei depth, GLsizei extent, GLenum format, GLenum type, const GLvoid *pixels); - -#define glTexImage4DSGIS GLEW_GET_FUN(__glewTexImage4DSGIS) -#define glTexSubImage4DSGIS GLEW_GET_FUN(__glewTexSubImage4DSGIS) - -#define GLEW_SGIS_texture4D GLEW_GET_VAR(__GLEW_SGIS_texture4D) - -#endif /* GL_SGIS_texture4D */ - -/* ---------------------- GL_SGIS_texture_border_clamp --------------------- */ - -#ifndef GL_SGIS_texture_border_clamp -#define GL_SGIS_texture_border_clamp 1 - -#define GL_CLAMP_TO_BORDER_SGIS 0x812D - -#define GLEW_SGIS_texture_border_clamp GLEW_GET_VAR(__GLEW_SGIS_texture_border_clamp) - -#endif /* GL_SGIS_texture_border_clamp */ - -/* ----------------------- GL_SGIS_texture_edge_clamp ---------------------- */ - -#ifndef GL_SGIS_texture_edge_clamp -#define GL_SGIS_texture_edge_clamp 1 - -#define GL_CLAMP_TO_EDGE_SGIS 0x812F - -#define GLEW_SGIS_texture_edge_clamp GLEW_GET_VAR(__GLEW_SGIS_texture_edge_clamp) - -#endif /* GL_SGIS_texture_edge_clamp */ - -/* ------------------------ GL_SGIS_texture_filter4 ------------------------ */ - -#ifndef GL_SGIS_texture_filter4 -#define GL_SGIS_texture_filter4 1 - -typedef void (GLAPIENTRY * PFNGLGETTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLfloat* weights); -typedef void (GLAPIENTRY * PFNGLTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLsizei n, const GLfloat* weights); - -#define glGetTexFilterFuncSGIS GLEW_GET_FUN(__glewGetTexFilterFuncSGIS) -#define glTexFilterFuncSGIS GLEW_GET_FUN(__glewTexFilterFuncSGIS) - -#define GLEW_SGIS_texture_filter4 GLEW_GET_VAR(__GLEW_SGIS_texture_filter4) - -#endif /* GL_SGIS_texture_filter4 */ - -/* -------------------------- GL_SGIS_texture_lod -------------------------- */ - -#ifndef GL_SGIS_texture_lod -#define GL_SGIS_texture_lod 1 - -#define GL_TEXTURE_MIN_LOD_SGIS 0x813A -#define GL_TEXTURE_MAX_LOD_SGIS 0x813B -#define GL_TEXTURE_BASE_LEVEL_SGIS 0x813C -#define GL_TEXTURE_MAX_LEVEL_SGIS 0x813D - -#define GLEW_SGIS_texture_lod GLEW_GET_VAR(__GLEW_SGIS_texture_lod) - -#endif /* GL_SGIS_texture_lod */ - -/* ------------------------- GL_SGIS_texture_select ------------------------ */ - -#ifndef GL_SGIS_texture_select -#define GL_SGIS_texture_select 1 - -#define GLEW_SGIS_texture_select GLEW_GET_VAR(__GLEW_SGIS_texture_select) - -#endif /* GL_SGIS_texture_select */ - -/* ----------------------------- GL_SGIX_async ----------------------------- */ - -#ifndef GL_SGIX_async -#define GL_SGIX_async 1 - -#define GL_ASYNC_MARKER_SGIX 0x8329 - -typedef void (GLAPIENTRY * PFNGLASYNCMARKERSGIXPROC) (GLuint marker); -typedef void (GLAPIENTRY * PFNGLDELETEASYNCMARKERSSGIXPROC) (GLuint marker, GLsizei range); -typedef GLint (GLAPIENTRY * PFNGLFINISHASYNCSGIXPROC) (GLuint* markerp); -typedef GLuint (GLAPIENTRY * PFNGLGENASYNCMARKERSSGIXPROC) (GLsizei range); -typedef GLboolean (GLAPIENTRY * PFNGLISASYNCMARKERSGIXPROC) (GLuint marker); -typedef GLint (GLAPIENTRY * PFNGLPOLLASYNCSGIXPROC) (GLuint* markerp); - -#define glAsyncMarkerSGIX GLEW_GET_FUN(__glewAsyncMarkerSGIX) -#define glDeleteAsyncMarkersSGIX GLEW_GET_FUN(__glewDeleteAsyncMarkersSGIX) -#define glFinishAsyncSGIX GLEW_GET_FUN(__glewFinishAsyncSGIX) -#define glGenAsyncMarkersSGIX GLEW_GET_FUN(__glewGenAsyncMarkersSGIX) -#define glIsAsyncMarkerSGIX GLEW_GET_FUN(__glewIsAsyncMarkerSGIX) -#define glPollAsyncSGIX GLEW_GET_FUN(__glewPollAsyncSGIX) - -#define GLEW_SGIX_async GLEW_GET_VAR(__GLEW_SGIX_async) - -#endif /* GL_SGIX_async */ - -/* ------------------------ GL_SGIX_async_histogram ------------------------ */ - -#ifndef GL_SGIX_async_histogram -#define GL_SGIX_async_histogram 1 - -#define GL_ASYNC_HISTOGRAM_SGIX 0x832C -#define GL_MAX_ASYNC_HISTOGRAM_SGIX 0x832D - -#define GLEW_SGIX_async_histogram GLEW_GET_VAR(__GLEW_SGIX_async_histogram) - -#endif /* GL_SGIX_async_histogram */ - -/* -------------------------- GL_SGIX_async_pixel -------------------------- */ - -#ifndef GL_SGIX_async_pixel -#define GL_SGIX_async_pixel 1 - -#define GL_ASYNC_TEX_IMAGE_SGIX 0x835C -#define GL_ASYNC_DRAW_PIXELS_SGIX 0x835D -#define GL_ASYNC_READ_PIXELS_SGIX 0x835E -#define GL_MAX_ASYNC_TEX_IMAGE_SGIX 0x835F -#define GL_MAX_ASYNC_DRAW_PIXELS_SGIX 0x8360 -#define GL_MAX_ASYNC_READ_PIXELS_SGIX 0x8361 - -#define GLEW_SGIX_async_pixel GLEW_GET_VAR(__GLEW_SGIX_async_pixel) - -#endif /* GL_SGIX_async_pixel */ - -/* ----------------------- GL_SGIX_blend_alpha_minmax ---------------------- */ - -#ifndef GL_SGIX_blend_alpha_minmax -#define GL_SGIX_blend_alpha_minmax 1 - -#define GL_ALPHA_MIN_SGIX 0x8320 -#define GL_ALPHA_MAX_SGIX 0x8321 - -#define GLEW_SGIX_blend_alpha_minmax GLEW_GET_VAR(__GLEW_SGIX_blend_alpha_minmax) - -#endif /* GL_SGIX_blend_alpha_minmax */ - -/* ---------------------------- GL_SGIX_clipmap ---------------------------- */ - -#ifndef GL_SGIX_clipmap -#define GL_SGIX_clipmap 1 - -#define GLEW_SGIX_clipmap GLEW_GET_VAR(__GLEW_SGIX_clipmap) - -#endif /* GL_SGIX_clipmap */ - -/* ---------------------- GL_SGIX_convolution_accuracy --------------------- */ - -#ifndef GL_SGIX_convolution_accuracy -#define GL_SGIX_convolution_accuracy 1 - -#define GL_CONVOLUTION_HINT_SGIX 0x8316 - -#define GLEW_SGIX_convolution_accuracy GLEW_GET_VAR(__GLEW_SGIX_convolution_accuracy) - -#endif /* GL_SGIX_convolution_accuracy */ - -/* ------------------------- GL_SGIX_depth_texture ------------------------- */ - -#ifndef GL_SGIX_depth_texture -#define GL_SGIX_depth_texture 1 - -#define GL_DEPTH_COMPONENT16_SGIX 0x81A5 -#define GL_DEPTH_COMPONENT24_SGIX 0x81A6 -#define GL_DEPTH_COMPONENT32_SGIX 0x81A7 - -#define GLEW_SGIX_depth_texture GLEW_GET_VAR(__GLEW_SGIX_depth_texture) - -#endif /* GL_SGIX_depth_texture */ - -/* -------------------------- GL_SGIX_flush_raster ------------------------- */ - -#ifndef GL_SGIX_flush_raster -#define GL_SGIX_flush_raster 1 - -typedef void (GLAPIENTRY * PFNGLFLUSHRASTERSGIXPROC) (void); - -#define glFlushRasterSGIX GLEW_GET_FUN(__glewFlushRasterSGIX) - -#define GLEW_SGIX_flush_raster GLEW_GET_VAR(__GLEW_SGIX_flush_raster) - -#endif /* GL_SGIX_flush_raster */ - -/* --------------------------- GL_SGIX_fog_offset -------------------------- */ - -#ifndef GL_SGIX_fog_offset -#define GL_SGIX_fog_offset 1 - -#define GL_FOG_OFFSET_SGIX 0x8198 -#define GL_FOG_OFFSET_VALUE_SGIX 0x8199 - -#define GLEW_SGIX_fog_offset GLEW_GET_VAR(__GLEW_SGIX_fog_offset) - -#endif /* GL_SGIX_fog_offset */ - -/* -------------------------- GL_SGIX_fog_texture -------------------------- */ - -#ifndef GL_SGIX_fog_texture -#define GL_SGIX_fog_texture 1 - -#define GL_TEXTURE_FOG_SGIX 0 -#define GL_FOG_PATCHY_FACTOR_SGIX 0 -#define GL_FRAGMENT_FOG_SGIX 0 - -typedef void (GLAPIENTRY * PFNGLTEXTUREFOGSGIXPROC) (GLenum pname); - -#define glTextureFogSGIX GLEW_GET_FUN(__glewTextureFogSGIX) - -#define GLEW_SGIX_fog_texture GLEW_GET_VAR(__GLEW_SGIX_fog_texture) - -#endif /* GL_SGIX_fog_texture */ - -/* ------------------- GL_SGIX_fragment_specular_lighting ------------------ */ - -#ifndef GL_SGIX_fragment_specular_lighting -#define GL_SGIX_fragment_specular_lighting 1 - -typedef void (GLAPIENTRY * PFNGLFRAGMENTCOLORMATERIALSGIXPROC) (GLenum face, GLenum mode); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFSGIXPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELFVSGIXPROC) (GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELISGIXPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTMODELIVSGIXPROC) (GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFSGIXPROC) (GLenum light, GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTISGIXPROC) (GLenum light, GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFSGIXPROC) (GLenum face, GLenum pname, const GLfloat param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALISGIXPROC) (GLenum face, GLenum pname, const GLint param); -typedef void (GLAPIENTRY * PFNGLFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum value, GLfloat* data); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum value, GLint* data); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat* data); -typedef void (GLAPIENTRY * PFNGLGETFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint* data); - -#define glFragmentColorMaterialSGIX GLEW_GET_FUN(__glewFragmentColorMaterialSGIX) -#define glFragmentLightModelfSGIX GLEW_GET_FUN(__glewFragmentLightModelfSGIX) -#define glFragmentLightModelfvSGIX GLEW_GET_FUN(__glewFragmentLightModelfvSGIX) -#define glFragmentLightModeliSGIX GLEW_GET_FUN(__glewFragmentLightModeliSGIX) -#define glFragmentLightModelivSGIX GLEW_GET_FUN(__glewFragmentLightModelivSGIX) -#define glFragmentLightfSGIX GLEW_GET_FUN(__glewFragmentLightfSGIX) -#define glFragmentLightfvSGIX GLEW_GET_FUN(__glewFragmentLightfvSGIX) -#define glFragmentLightiSGIX GLEW_GET_FUN(__glewFragmentLightiSGIX) -#define glFragmentLightivSGIX GLEW_GET_FUN(__glewFragmentLightivSGIX) -#define glFragmentMaterialfSGIX GLEW_GET_FUN(__glewFragmentMaterialfSGIX) -#define glFragmentMaterialfvSGIX GLEW_GET_FUN(__glewFragmentMaterialfvSGIX) -#define glFragmentMaterialiSGIX GLEW_GET_FUN(__glewFragmentMaterialiSGIX) -#define glFragmentMaterialivSGIX GLEW_GET_FUN(__glewFragmentMaterialivSGIX) -#define glGetFragmentLightfvSGIX GLEW_GET_FUN(__glewGetFragmentLightfvSGIX) -#define glGetFragmentLightivSGIX GLEW_GET_FUN(__glewGetFragmentLightivSGIX) -#define glGetFragmentMaterialfvSGIX GLEW_GET_FUN(__glewGetFragmentMaterialfvSGIX) -#define glGetFragmentMaterialivSGIX GLEW_GET_FUN(__glewGetFragmentMaterialivSGIX) - -#define GLEW_SGIX_fragment_specular_lighting GLEW_GET_VAR(__GLEW_SGIX_fragment_specular_lighting) - -#endif /* GL_SGIX_fragment_specular_lighting */ - -/* --------------------------- GL_SGIX_framezoom --------------------------- */ - -#ifndef GL_SGIX_framezoom -#define GL_SGIX_framezoom 1 - -typedef void (GLAPIENTRY * PFNGLFRAMEZOOMSGIXPROC) (GLint factor); - -#define glFrameZoomSGIX GLEW_GET_FUN(__glewFrameZoomSGIX) - -#define GLEW_SGIX_framezoom GLEW_GET_VAR(__GLEW_SGIX_framezoom) - -#endif /* GL_SGIX_framezoom */ - -/* --------------------------- GL_SGIX_interlace --------------------------- */ - -#ifndef GL_SGIX_interlace -#define GL_SGIX_interlace 1 - -#define GL_INTERLACE_SGIX 0x8094 - -#define GLEW_SGIX_interlace GLEW_GET_VAR(__GLEW_SGIX_interlace) - -#endif /* GL_SGIX_interlace */ - -/* ------------------------- GL_SGIX_ir_instrument1 ------------------------ */ - -#ifndef GL_SGIX_ir_instrument1 -#define GL_SGIX_ir_instrument1 1 - -#define GLEW_SGIX_ir_instrument1 GLEW_GET_VAR(__GLEW_SGIX_ir_instrument1) - -#endif /* GL_SGIX_ir_instrument1 */ - -/* ------------------------- GL_SGIX_list_priority ------------------------- */ - -#ifndef GL_SGIX_list_priority -#define GL_SGIX_list_priority 1 - -#define GLEW_SGIX_list_priority GLEW_GET_VAR(__GLEW_SGIX_list_priority) - -#endif /* GL_SGIX_list_priority */ - -/* ------------------------- GL_SGIX_pixel_texture ------------------------- */ - -#ifndef GL_SGIX_pixel_texture -#define GL_SGIX_pixel_texture 1 - -typedef void (GLAPIENTRY * PFNGLPIXELTEXGENSGIXPROC) (GLenum mode); - -#define glPixelTexGenSGIX GLEW_GET_FUN(__glewPixelTexGenSGIX) - -#define GLEW_SGIX_pixel_texture GLEW_GET_VAR(__GLEW_SGIX_pixel_texture) - -#endif /* GL_SGIX_pixel_texture */ - -/* ----------------------- GL_SGIX_pixel_texture_bits ---------------------- */ - -#ifndef GL_SGIX_pixel_texture_bits -#define GL_SGIX_pixel_texture_bits 1 - -#define GLEW_SGIX_pixel_texture_bits GLEW_GET_VAR(__GLEW_SGIX_pixel_texture_bits) - -#endif /* GL_SGIX_pixel_texture_bits */ - -/* ------------------------ GL_SGIX_reference_plane ------------------------ */ - -#ifndef GL_SGIX_reference_plane -#define GL_SGIX_reference_plane 1 - -typedef void (GLAPIENTRY * PFNGLREFERENCEPLANESGIXPROC) (const GLdouble* equation); - -#define glReferencePlaneSGIX GLEW_GET_FUN(__glewReferencePlaneSGIX) - -#define GLEW_SGIX_reference_plane GLEW_GET_VAR(__GLEW_SGIX_reference_plane) - -#endif /* GL_SGIX_reference_plane */ - -/* ---------------------------- GL_SGIX_resample --------------------------- */ - -#ifndef GL_SGIX_resample -#define GL_SGIX_resample 1 - -#define GL_PACK_RESAMPLE_SGIX 0x842E -#define GL_UNPACK_RESAMPLE_SGIX 0x842F -#define GL_RESAMPLE_DECIMATE_SGIX 0x8430 -#define GL_RESAMPLE_REPLICATE_SGIX 0x8433 -#define GL_RESAMPLE_ZERO_FILL_SGIX 0x8434 - -#define GLEW_SGIX_resample GLEW_GET_VAR(__GLEW_SGIX_resample) - -#endif /* GL_SGIX_resample */ - -/* ----------------------------- GL_SGIX_shadow ---------------------------- */ - -#ifndef GL_SGIX_shadow -#define GL_SGIX_shadow 1 - -#define GL_TEXTURE_COMPARE_SGIX 0x819A -#define GL_TEXTURE_COMPARE_OPERATOR_SGIX 0x819B -#define GL_TEXTURE_LEQUAL_R_SGIX 0x819C -#define GL_TEXTURE_GEQUAL_R_SGIX 0x819D - -#define GLEW_SGIX_shadow GLEW_GET_VAR(__GLEW_SGIX_shadow) - -#endif /* GL_SGIX_shadow */ - -/* ------------------------- GL_SGIX_shadow_ambient ------------------------ */ - -#ifndef GL_SGIX_shadow_ambient -#define GL_SGIX_shadow_ambient 1 - -#define GL_SHADOW_AMBIENT_SGIX 0x80BF - -#define GLEW_SGIX_shadow_ambient GLEW_GET_VAR(__GLEW_SGIX_shadow_ambient) - -#endif /* GL_SGIX_shadow_ambient */ - -/* ----------------------------- GL_SGIX_sprite ---------------------------- */ - -#ifndef GL_SGIX_sprite -#define GL_SGIX_sprite 1 - -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERFSGIXPROC) (GLenum pname, GLfloat param); -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERFVSGIXPROC) (GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERISGIXPROC) (GLenum pname, GLint param); -typedef void (GLAPIENTRY * PFNGLSPRITEPARAMETERIVSGIXPROC) (GLenum pname, GLint* params); - -#define glSpriteParameterfSGIX GLEW_GET_FUN(__glewSpriteParameterfSGIX) -#define glSpriteParameterfvSGIX GLEW_GET_FUN(__glewSpriteParameterfvSGIX) -#define glSpriteParameteriSGIX GLEW_GET_FUN(__glewSpriteParameteriSGIX) -#define glSpriteParameterivSGIX GLEW_GET_FUN(__glewSpriteParameterivSGIX) - -#define GLEW_SGIX_sprite GLEW_GET_VAR(__GLEW_SGIX_sprite) - -#endif /* GL_SGIX_sprite */ - -/* ----------------------- GL_SGIX_tag_sample_buffer ----------------------- */ - -#ifndef GL_SGIX_tag_sample_buffer -#define GL_SGIX_tag_sample_buffer 1 - -typedef void (GLAPIENTRY * PFNGLTAGSAMPLEBUFFERSGIXPROC) (void); - -#define glTagSampleBufferSGIX GLEW_GET_FUN(__glewTagSampleBufferSGIX) - -#define GLEW_SGIX_tag_sample_buffer GLEW_GET_VAR(__GLEW_SGIX_tag_sample_buffer) - -#endif /* GL_SGIX_tag_sample_buffer */ - -/* ------------------------ GL_SGIX_texture_add_env ------------------------ */ - -#ifndef GL_SGIX_texture_add_env -#define GL_SGIX_texture_add_env 1 - -#define GLEW_SGIX_texture_add_env GLEW_GET_VAR(__GLEW_SGIX_texture_add_env) - -#endif /* GL_SGIX_texture_add_env */ - -/* -------------------- GL_SGIX_texture_coordinate_clamp ------------------- */ - -#ifndef GL_SGIX_texture_coordinate_clamp -#define GL_SGIX_texture_coordinate_clamp 1 - -#define GL_TEXTURE_MAX_CLAMP_S_SGIX 0x8369 -#define GL_TEXTURE_MAX_CLAMP_T_SGIX 0x836A -#define GL_TEXTURE_MAX_CLAMP_R_SGIX 0x836B - -#define GLEW_SGIX_texture_coordinate_clamp GLEW_GET_VAR(__GLEW_SGIX_texture_coordinate_clamp) - -#endif /* GL_SGIX_texture_coordinate_clamp */ - -/* ------------------------ GL_SGIX_texture_lod_bias ----------------------- */ - -#ifndef GL_SGIX_texture_lod_bias -#define GL_SGIX_texture_lod_bias 1 - -#define GLEW_SGIX_texture_lod_bias GLEW_GET_VAR(__GLEW_SGIX_texture_lod_bias) - -#endif /* GL_SGIX_texture_lod_bias */ - -/* ---------------------- GL_SGIX_texture_multi_buffer --------------------- */ - -#ifndef GL_SGIX_texture_multi_buffer -#define GL_SGIX_texture_multi_buffer 1 - -#define GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E - -#define GLEW_SGIX_texture_multi_buffer GLEW_GET_VAR(__GLEW_SGIX_texture_multi_buffer) - -#endif /* GL_SGIX_texture_multi_buffer */ - -/* ------------------------- GL_SGIX_texture_range ------------------------- */ - -#ifndef GL_SGIX_texture_range -#define GL_SGIX_texture_range 1 - -#define GL_RGB_SIGNED_SGIX 0x85E0 -#define GL_RGBA_SIGNED_SGIX 0x85E1 -#define GL_ALPHA_SIGNED_SGIX 0x85E2 -#define GL_LUMINANCE_SIGNED_SGIX 0x85E3 -#define GL_INTENSITY_SIGNED_SGIX 0x85E4 -#define GL_LUMINANCE_ALPHA_SIGNED_SGIX 0x85E5 -#define GL_RGB16_SIGNED_SGIX 0x85E6 -#define GL_RGBA16_SIGNED_SGIX 0x85E7 -#define GL_ALPHA16_SIGNED_SGIX 0x85E8 -#define GL_LUMINANCE16_SIGNED_SGIX 0x85E9 -#define GL_INTENSITY16_SIGNED_SGIX 0x85EA -#define GL_LUMINANCE16_ALPHA16_SIGNED_SGIX 0x85EB -#define GL_RGB_EXTENDED_RANGE_SGIX 0x85EC -#define GL_RGBA_EXTENDED_RANGE_SGIX 0x85ED -#define GL_ALPHA_EXTENDED_RANGE_SGIX 0x85EE -#define GL_LUMINANCE_EXTENDED_RANGE_SGIX 0x85EF -#define GL_INTENSITY_EXTENDED_RANGE_SGIX 0x85F0 -#define GL_LUMINANCE_ALPHA_EXTENDED_RANGE_SGIX 0x85F1 -#define GL_RGB16_EXTENDED_RANGE_SGIX 0x85F2 -#define GL_RGBA16_EXTENDED_RANGE_SGIX 0x85F3 -#define GL_ALPHA16_EXTENDED_RANGE_SGIX 0x85F4 -#define GL_LUMINANCE16_EXTENDED_RANGE_SGIX 0x85F5 -#define GL_INTENSITY16_EXTENDED_RANGE_SGIX 0x85F6 -#define GL_LUMINANCE16_ALPHA16_EXTENDED_RANGE_SGIX 0x85F7 -#define GL_MIN_LUMINANCE_SGIS 0x85F8 -#define GL_MAX_LUMINANCE_SGIS 0x85F9 -#define GL_MIN_INTENSITY_SGIS 0x85FA -#define GL_MAX_INTENSITY_SGIS 0x85FB - -#define GLEW_SGIX_texture_range GLEW_GET_VAR(__GLEW_SGIX_texture_range) - -#endif /* GL_SGIX_texture_range */ - -/* ----------------------- GL_SGIX_texture_scale_bias ---------------------- */ - -#ifndef GL_SGIX_texture_scale_bias -#define GL_SGIX_texture_scale_bias 1 - -#define GL_POST_TEXTURE_FILTER_BIAS_SGIX 0x8179 -#define GL_POST_TEXTURE_FILTER_SCALE_SGIX 0x817A -#define GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX 0x817B -#define GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX 0x817C - -#define GLEW_SGIX_texture_scale_bias GLEW_GET_VAR(__GLEW_SGIX_texture_scale_bias) - -#endif /* GL_SGIX_texture_scale_bias */ - -/* ------------------------- GL_SGIX_vertex_preclip ------------------------ */ - -#ifndef GL_SGIX_vertex_preclip -#define GL_SGIX_vertex_preclip 1 - -#define GL_VERTEX_PRECLIP_SGIX 0x83EE -#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF - -#define GLEW_SGIX_vertex_preclip GLEW_GET_VAR(__GLEW_SGIX_vertex_preclip) - -#endif /* GL_SGIX_vertex_preclip */ - -/* ---------------------- GL_SGIX_vertex_preclip_hint ---------------------- */ - -#ifndef GL_SGIX_vertex_preclip_hint -#define GL_SGIX_vertex_preclip_hint 1 - -#define GL_VERTEX_PRECLIP_SGIX 0x83EE -#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF - -#define GLEW_SGIX_vertex_preclip_hint GLEW_GET_VAR(__GLEW_SGIX_vertex_preclip_hint) - -#endif /* GL_SGIX_vertex_preclip_hint */ - -/* ----------------------------- GL_SGIX_ycrcb ----------------------------- */ - -#ifndef GL_SGIX_ycrcb -#define GL_SGIX_ycrcb 1 - -#define GLEW_SGIX_ycrcb GLEW_GET_VAR(__GLEW_SGIX_ycrcb) - -#endif /* GL_SGIX_ycrcb */ - -/* -------------------------- GL_SGI_color_matrix -------------------------- */ - -#ifndef GL_SGI_color_matrix -#define GL_SGI_color_matrix 1 - -#define GL_COLOR_MATRIX_SGI 0x80B1 -#define GL_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B2 -#define GL_MAX_COLOR_MATRIX_STACK_DEPTH_SGI 0x80B3 -#define GL_POST_COLOR_MATRIX_RED_SCALE_SGI 0x80B4 -#define GL_POST_COLOR_MATRIX_GREEN_SCALE_SGI 0x80B5 -#define GL_POST_COLOR_MATRIX_BLUE_SCALE_SGI 0x80B6 -#define GL_POST_COLOR_MATRIX_ALPHA_SCALE_SGI 0x80B7 -#define GL_POST_COLOR_MATRIX_RED_BIAS_SGI 0x80B8 -#define GL_POST_COLOR_MATRIX_GREEN_BIAS_SGI 0x80B9 -#define GL_POST_COLOR_MATRIX_BLUE_BIAS_SGI 0x80BA -#define GL_POST_COLOR_MATRIX_ALPHA_BIAS_SGI 0x80BB - -#define GLEW_SGI_color_matrix GLEW_GET_VAR(__GLEW_SGI_color_matrix) - -#endif /* GL_SGI_color_matrix */ - -/* --------------------------- GL_SGI_color_table -------------------------- */ - -#ifndef GL_SGI_color_table -#define GL_SGI_color_table 1 - -#define GL_COLOR_TABLE_SGI 0x80D0 -#define GL_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D1 -#define GL_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D2 -#define GL_PROXY_COLOR_TABLE_SGI 0x80D3 -#define GL_PROXY_POST_CONVOLUTION_COLOR_TABLE_SGI 0x80D4 -#define GL_PROXY_POST_COLOR_MATRIX_COLOR_TABLE_SGI 0x80D5 -#define GL_COLOR_TABLE_SCALE_SGI 0x80D6 -#define GL_COLOR_TABLE_BIAS_SGI 0x80D7 -#define GL_COLOR_TABLE_FORMAT_SGI 0x80D8 -#define GL_COLOR_TABLE_WIDTH_SGI 0x80D9 -#define GL_COLOR_TABLE_RED_SIZE_SGI 0x80DA -#define GL_COLOR_TABLE_GREEN_SIZE_SGI 0x80DB -#define GL_COLOR_TABLE_BLUE_SIZE_SGI 0x80DC -#define GL_COLOR_TABLE_ALPHA_SIZE_SGI 0x80DD -#define GL_COLOR_TABLE_LUMINANCE_SIZE_SGI 0x80DE -#define GL_COLOR_TABLE_INTENSITY_SIZE_SGI 0x80DF - -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, const GLfloat* params); -typedef void (GLAPIENTRY * PFNGLCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, const GLint* params); -typedef void (GLAPIENTRY * PFNGLCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const GLvoid *table); -typedef void (GLAPIENTRY * PFNGLCOPYCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, GLfloat* params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, GLint* params); -typedef void (GLAPIENTRY * PFNGLGETCOLORTABLESGIPROC) (GLenum target, GLenum format, GLenum type, GLvoid *table); - -#define glColorTableParameterfvSGI GLEW_GET_FUN(__glewColorTableParameterfvSGI) -#define glColorTableParameterivSGI GLEW_GET_FUN(__glewColorTableParameterivSGI) -#define glColorTableSGI GLEW_GET_FUN(__glewColorTableSGI) -#define glCopyColorTableSGI GLEW_GET_FUN(__glewCopyColorTableSGI) -#define glGetColorTableParameterfvSGI GLEW_GET_FUN(__glewGetColorTableParameterfvSGI) -#define glGetColorTableParameterivSGI GLEW_GET_FUN(__glewGetColorTableParameterivSGI) -#define glGetColorTableSGI GLEW_GET_FUN(__glewGetColorTableSGI) - -#define GLEW_SGI_color_table GLEW_GET_VAR(__GLEW_SGI_color_table) - -#endif /* GL_SGI_color_table */ - -/* ----------------------- GL_SGI_texture_color_table ---------------------- */ - -#ifndef GL_SGI_texture_color_table -#define GL_SGI_texture_color_table 1 - -#define GL_TEXTURE_COLOR_TABLE_SGI 0x80BC -#define GL_PROXY_TEXTURE_COLOR_TABLE_SGI 0x80BD - -#define GLEW_SGI_texture_color_table GLEW_GET_VAR(__GLEW_SGI_texture_color_table) - -#endif /* GL_SGI_texture_color_table */ - -/* ------------------------- GL_SUNX_constant_data ------------------------- */ - -#ifndef GL_SUNX_constant_data -#define GL_SUNX_constant_data 1 - -#define GL_UNPACK_CONSTANT_DATA_SUNX 0x81D5 -#define GL_TEXTURE_CONSTANT_DATA_SUNX 0x81D6 - -typedef void (GLAPIENTRY * PFNGLFINISHTEXTURESUNXPROC) (void); - -#define glFinishTextureSUNX GLEW_GET_FUN(__glewFinishTextureSUNX) - -#define GLEW_SUNX_constant_data GLEW_GET_VAR(__GLEW_SUNX_constant_data) - -#endif /* GL_SUNX_constant_data */ - -/* -------------------- GL_SUN_convolution_border_modes -------------------- */ - -#ifndef GL_SUN_convolution_border_modes -#define GL_SUN_convolution_border_modes 1 - -#define GL_WRAP_BORDER_SUN 0x81D4 - -#define GLEW_SUN_convolution_border_modes GLEW_GET_VAR(__GLEW_SUN_convolution_border_modes) - -#endif /* GL_SUN_convolution_border_modes */ - -/* -------------------------- GL_SUN_global_alpha -------------------------- */ - -#ifndef GL_SUN_global_alpha -#define GL_SUN_global_alpha 1 - -#define GL_GLOBAL_ALPHA_SUN 0x81D9 -#define GL_GLOBAL_ALPHA_FACTOR_SUN 0x81DA - -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORBSUNPROC) (GLbyte factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORDSUNPROC) (GLdouble factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORFSUNPROC) (GLfloat factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORISUNPROC) (GLint factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORSSUNPROC) (GLshort factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUBSUNPROC) (GLubyte factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUISUNPROC) (GLuint factor); -typedef void (GLAPIENTRY * PFNGLGLOBALALPHAFACTORUSSUNPROC) (GLushort factor); - -#define glGlobalAlphaFactorbSUN GLEW_GET_FUN(__glewGlobalAlphaFactorbSUN) -#define glGlobalAlphaFactordSUN GLEW_GET_FUN(__glewGlobalAlphaFactordSUN) -#define glGlobalAlphaFactorfSUN GLEW_GET_FUN(__glewGlobalAlphaFactorfSUN) -#define glGlobalAlphaFactoriSUN GLEW_GET_FUN(__glewGlobalAlphaFactoriSUN) -#define glGlobalAlphaFactorsSUN GLEW_GET_FUN(__glewGlobalAlphaFactorsSUN) -#define glGlobalAlphaFactorubSUN GLEW_GET_FUN(__glewGlobalAlphaFactorubSUN) -#define glGlobalAlphaFactoruiSUN GLEW_GET_FUN(__glewGlobalAlphaFactoruiSUN) -#define glGlobalAlphaFactorusSUN GLEW_GET_FUN(__glewGlobalAlphaFactorusSUN) - -#define GLEW_SUN_global_alpha GLEW_GET_VAR(__GLEW_SUN_global_alpha) - -#endif /* GL_SUN_global_alpha */ - -/* --------------------------- GL_SUN_mesh_array --------------------------- */ - -#ifndef GL_SUN_mesh_array -#define GL_SUN_mesh_array 1 - -#define GL_QUAD_MESH_SUN 0x8614 -#define GL_TRIANGLE_MESH_SUN 0x8615 - -#define GLEW_SUN_mesh_array GLEW_GET_VAR(__GLEW_SUN_mesh_array) - -#endif /* GL_SUN_mesh_array */ - -/* ------------------------ GL_SUN_read_video_pixels ----------------------- */ - -#ifndef GL_SUN_read_video_pixels -#define GL_SUN_read_video_pixels 1 - -typedef void (GLAPIENTRY * PFNGLREADVIDEOPIXELSSUNPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid* pixels); - -#define glReadVideoPixelsSUN GLEW_GET_FUN(__glewReadVideoPixelsSUN) - -#define GLEW_SUN_read_video_pixels GLEW_GET_VAR(__GLEW_SUN_read_video_pixels) - -#endif /* GL_SUN_read_video_pixels */ - -/* --------------------------- GL_SUN_slice_accum -------------------------- */ - -#ifndef GL_SUN_slice_accum -#define GL_SUN_slice_accum 1 - -#define GL_SLICE_ACCUM_SUN 0x85CC - -#define GLEW_SUN_slice_accum GLEW_GET_VAR(__GLEW_SUN_slice_accum) - -#endif /* GL_SUN_slice_accum */ - -/* -------------------------- GL_SUN_triangle_list ------------------------- */ - -#ifndef GL_SUN_triangle_list -#define GL_SUN_triangle_list 1 - -#define GL_RESTART_SUN 0x01 -#define GL_REPLACE_MIDDLE_SUN 0x02 -#define GL_REPLACE_OLDEST_SUN 0x03 -#define GL_TRIANGLE_LIST_SUN 0x81D7 -#define GL_REPLACEMENT_CODE_SUN 0x81D8 -#define GL_REPLACEMENT_CODE_ARRAY_SUN 0x85C0 -#define GL_REPLACEMENT_CODE_ARRAY_TYPE_SUN 0x85C1 -#define GL_REPLACEMENT_CODE_ARRAY_STRIDE_SUN 0x85C2 -#define GL_REPLACEMENT_CODE_ARRAY_POINTER_SUN 0x85C3 -#define GL_R1UI_V3F_SUN 0x85C4 -#define GL_R1UI_C4UB_V3F_SUN 0x85C5 -#define GL_R1UI_C3F_V3F_SUN 0x85C6 -#define GL_R1UI_N3F_V3F_SUN 0x85C7 -#define GL_R1UI_C4F_N3F_V3F_SUN 0x85C8 -#define GL_R1UI_T2F_V3F_SUN 0x85C9 -#define GL_R1UI_T2F_N3F_V3F_SUN 0x85CA -#define GL_R1UI_T2F_C4F_N3F_V3F_SUN 0x85CB - -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEPOINTERSUNPROC) (GLenum type, GLsizei stride, const GLvoid *pointer); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUBSUNPROC) (GLubyte code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUBVSUNPROC) (const GLubyte* code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUISUNPROC) (GLuint code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVSUNPROC) (const GLuint* code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUSSUNPROC) (GLushort code); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUSVSUNPROC) (const GLushort* code); - -#define glReplacementCodePointerSUN GLEW_GET_FUN(__glewReplacementCodePointerSUN) -#define glReplacementCodeubSUN GLEW_GET_FUN(__glewReplacementCodeubSUN) -#define glReplacementCodeubvSUN GLEW_GET_FUN(__glewReplacementCodeubvSUN) -#define glReplacementCodeuiSUN GLEW_GET_FUN(__glewReplacementCodeuiSUN) -#define glReplacementCodeuivSUN GLEW_GET_FUN(__glewReplacementCodeuivSUN) -#define glReplacementCodeusSUN GLEW_GET_FUN(__glewReplacementCodeusSUN) -#define glReplacementCodeusvSUN GLEW_GET_FUN(__glewReplacementCodeusvSUN) - -#define GLEW_SUN_triangle_list GLEW_GET_VAR(__GLEW_SUN_triangle_list) - -#endif /* GL_SUN_triangle_list */ - -/* ----------------------------- GL_SUN_vertex ----------------------------- */ - -#ifndef GL_SUN_vertex -#define GL_SUN_vertex 1 - -typedef void (GLAPIENTRY * PFNGLCOLOR3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLCOLOR3FVERTEX3FVSUNPROC) (const GLfloat* c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX2FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX2FVSUNPROC) (const GLubyte* c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX3FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLCOLOR4UBVERTEX3FVSUNPROC) (const GLubyte* c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLNORMAL3FVERTEX3FSUNPROC) (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC) (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC) (const GLuint* rc, const GLubyte *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *tc, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC) (GLuint rc, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC) (const GLuint* rc, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC) (const GLfloat* tc, const GLubyte *c, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); -typedef void (GLAPIENTRY * PFNGLTEXCOORD2FVERTEX3FVSUNPROC) (const GLfloat* tc, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC) (const GLfloat* tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); -typedef void (GLAPIENTRY * PFNGLTEXCOORD4FVERTEX4FVSUNPROC) (const GLfloat* tc, const GLfloat *v); - -#define glColor3fVertex3fSUN GLEW_GET_FUN(__glewColor3fVertex3fSUN) -#define glColor3fVertex3fvSUN GLEW_GET_FUN(__glewColor3fVertex3fvSUN) -#define glColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewColor4fNormal3fVertex3fSUN) -#define glColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewColor4fNormal3fVertex3fvSUN) -#define glColor4ubVertex2fSUN GLEW_GET_FUN(__glewColor4ubVertex2fSUN) -#define glColor4ubVertex2fvSUN GLEW_GET_FUN(__glewColor4ubVertex2fvSUN) -#define glColor4ubVertex3fSUN GLEW_GET_FUN(__glewColor4ubVertex3fSUN) -#define glColor4ubVertex3fvSUN GLEW_GET_FUN(__glewColor4ubVertex3fvSUN) -#define glNormal3fVertex3fSUN GLEW_GET_FUN(__glewNormal3fVertex3fSUN) -#define glNormal3fVertex3fvSUN GLEW_GET_FUN(__glewNormal3fVertex3fvSUN) -#define glReplacementCodeuiColor3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor3fVertex3fSUN) -#define glReplacementCodeuiColor3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor3fVertex3fvSUN) -#define glReplacementCodeuiColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4fNormal3fVertex3fSUN) -#define glReplacementCodeuiColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4fNormal3fVertex3fvSUN) -#define glReplacementCodeuiColor4ubVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4ubVertex3fSUN) -#define glReplacementCodeuiColor4ubVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiColor4ubVertex3fvSUN) -#define glReplacementCodeuiNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiNormal3fVertex3fSUN) -#define glReplacementCodeuiNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiNormal3fVertex3fvSUN) -#define glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN) -#define glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN) -#define glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN) -#define glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN) -#define glReplacementCodeuiTexCoord2fVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fVertex3fSUN) -#define glReplacementCodeuiTexCoord2fVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiTexCoord2fVertex3fvSUN) -#define glReplacementCodeuiVertex3fSUN GLEW_GET_FUN(__glewReplacementCodeuiVertex3fSUN) -#define glReplacementCodeuiVertex3fvSUN GLEW_GET_FUN(__glewReplacementCodeuiVertex3fvSUN) -#define glTexCoord2fColor3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor3fVertex3fSUN) -#define glTexCoord2fColor3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor3fVertex3fvSUN) -#define glTexCoord2fColor4fNormal3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor4fNormal3fVertex3fSUN) -#define glTexCoord2fColor4fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor4fNormal3fVertex3fvSUN) -#define glTexCoord2fColor4ubVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fColor4ubVertex3fSUN) -#define glTexCoord2fColor4ubVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fColor4ubVertex3fvSUN) -#define glTexCoord2fNormal3fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fNormal3fVertex3fSUN) -#define glTexCoord2fNormal3fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fNormal3fVertex3fvSUN) -#define glTexCoord2fVertex3fSUN GLEW_GET_FUN(__glewTexCoord2fVertex3fSUN) -#define glTexCoord2fVertex3fvSUN GLEW_GET_FUN(__glewTexCoord2fVertex3fvSUN) -#define glTexCoord4fColor4fNormal3fVertex4fSUN GLEW_GET_FUN(__glewTexCoord4fColor4fNormal3fVertex4fSUN) -#define glTexCoord4fColor4fNormal3fVertex4fvSUN GLEW_GET_FUN(__glewTexCoord4fColor4fNormal3fVertex4fvSUN) -#define glTexCoord4fVertex4fSUN GLEW_GET_FUN(__glewTexCoord4fVertex4fSUN) -#define glTexCoord4fVertex4fvSUN GLEW_GET_FUN(__glewTexCoord4fVertex4fvSUN) - -#define GLEW_SUN_vertex GLEW_GET_VAR(__GLEW_SUN_vertex) - -#endif /* GL_SUN_vertex */ - -/* -------------------------- GL_WIN_phong_shading ------------------------- */ - -#ifndef GL_WIN_phong_shading -#define GL_WIN_phong_shading 1 - -#define GL_PHONG_WIN 0x80EA -#define GL_PHONG_HINT_WIN 0x80EB - -#define GLEW_WIN_phong_shading GLEW_GET_VAR(__GLEW_WIN_phong_shading) - -#endif /* GL_WIN_phong_shading */ - -/* -------------------------- GL_WIN_specular_fog -------------------------- */ - -#ifndef GL_WIN_specular_fog -#define GL_WIN_specular_fog 1 - -#define GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC - -#define GLEW_WIN_specular_fog GLEW_GET_VAR(__GLEW_WIN_specular_fog) - -#endif /* GL_WIN_specular_fog */ - -/* ---------------------------- GL_WIN_swap_hint --------------------------- */ - -#ifndef GL_WIN_swap_hint -#define GL_WIN_swap_hint 1 - -typedef void (GLAPIENTRY * PFNGLADDSWAPHINTRECTWINPROC) (GLint x, GLint y, GLsizei width, GLsizei height); - -#define glAddSwapHintRectWIN GLEW_GET_FUN(__glewAddSwapHintRectWIN) - -#define GLEW_WIN_swap_hint GLEW_GET_VAR(__GLEW_WIN_swap_hint) - -#endif /* GL_WIN_swap_hint */ - -/* ------------------------------------------------------------------------- */ - -#if defined(GLEW_MX) && defined(_WIN32) -#define GLEW_FUN_EXPORT -#else -#define GLEW_FUN_EXPORT GLEWAPI -#endif /* GLEW_MX */ - -#if defined(GLEW_MX) -#define GLEW_VAR_EXPORT -#else -#define GLEW_VAR_EXPORT GLEWAPI -#endif /* GLEW_MX */ - -#if defined(GLEW_MX) && defined(_WIN32) -struct GLEWContextStruct -{ -#endif /* GLEW_MX */ - -#ifdef GLEW_INIT_OPENGL11_FUNCTIONS - -GLEW_FUN_EXPORT PFNGLACCUMPROC __glewAccum; -GLEW_FUN_EXPORT PFNGLALPHAFUNCPROC __glewAlphaFunc; -GLEW_FUN_EXPORT PFNGLARETEXTURESRESIDENTPROC __glewAreTexturesResident; -GLEW_FUN_EXPORT PFNGLARRAYELEMENTPROC __glewArrayElement; -GLEW_FUN_EXPORT PFNGLBEGINPROC __glewBegin; -GLEW_FUN_EXPORT PFNGLBINDTEXTUREPROC __glewBindTexture; -GLEW_FUN_EXPORT PFNGLBITMAPPROC __glewBitmap; -GLEW_FUN_EXPORT PFNGLBLENDFUNCPROC __glewBlendFunc; -GLEW_FUN_EXPORT PFNGLCALLLISTPROC __glewCallList; -GLEW_FUN_EXPORT PFNGLCALLLISTSPROC __glewCallLists; -GLEW_FUN_EXPORT PFNGLCLEARPROC __glewClear; -GLEW_FUN_EXPORT PFNGLCLEARACCUMPROC __glewClearAccum; -GLEW_FUN_EXPORT PFNGLCLEARCOLORPROC __glewClearColor; -GLEW_FUN_EXPORT PFNGLCLEARDEPTHPROC __glewClearDepth; -GLEW_FUN_EXPORT PFNGLCLEARINDEXPROC __glewClearIndex; -GLEW_FUN_EXPORT PFNGLCLEARSTENCILPROC __glewClearStencil; -GLEW_FUN_EXPORT PFNGLCLIPPLANEPROC __glewClipPlane; -GLEW_FUN_EXPORT PFNGLCOLOR3BPROC __glewColor3b; -GLEW_FUN_EXPORT PFNGLCOLOR3BVPROC __glewColor3bv; -GLEW_FUN_EXPORT PFNGLCOLOR3DPROC __glewColor3d; -GLEW_FUN_EXPORT PFNGLCOLOR3DVPROC __glewColor3dv; -GLEW_FUN_EXPORT PFNGLCOLOR3FPROC __glewColor3f; -GLEW_FUN_EXPORT PFNGLCOLOR3FVPROC __glewColor3fv; -GLEW_FUN_EXPORT PFNGLCOLOR3IPROC __glewColor3i; -GLEW_FUN_EXPORT PFNGLCOLOR3IVPROC __glewColor3iv; -GLEW_FUN_EXPORT PFNGLCOLOR3SPROC __glewColor3s; -GLEW_FUN_EXPORT PFNGLCOLOR3SVPROC __glewColor3sv; -GLEW_FUN_EXPORT PFNGLCOLOR3UBPROC __glewColor3ub; -GLEW_FUN_EXPORT PFNGLCOLOR3UBVPROC __glewColor3ubv; -GLEW_FUN_EXPORT PFNGLCOLOR3UIPROC __glewColor3ui; -GLEW_FUN_EXPORT PFNGLCOLOR3UIVPROC __glewColor3uiv; -GLEW_FUN_EXPORT PFNGLCOLOR3USPROC __glewColor3us; -GLEW_FUN_EXPORT PFNGLCOLOR3USVPROC __glewColor3usv; -GLEW_FUN_EXPORT PFNGLCOLOR4BPROC __glewColor4b; -GLEW_FUN_EXPORT PFNGLCOLOR4BVPROC __glewColor4bv; -GLEW_FUN_EXPORT PFNGLCOLOR4DPROC __glewColor4d; -GLEW_FUN_EXPORT PFNGLCOLOR4DVPROC __glewColor4dv; -GLEW_FUN_EXPORT PFNGLCOLOR4FPROC __glewColor4f; -GLEW_FUN_EXPORT PFNGLCOLOR4FVPROC __glewColor4fv; -GLEW_FUN_EXPORT PFNGLCOLOR4IPROC __glewColor4i; -GLEW_FUN_EXPORT PFNGLCOLOR4IVPROC __glewColor4iv; -GLEW_FUN_EXPORT PFNGLCOLOR4SPROC __glewColor4s; -GLEW_FUN_EXPORT PFNGLCOLOR4SVPROC __glewColor4sv; -GLEW_FUN_EXPORT PFNGLCOLOR4UBPROC __glewColor4ub; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVPROC __glewColor4ubv; -GLEW_FUN_EXPORT PFNGLCOLOR4UIPROC __glewColor4ui; -GLEW_FUN_EXPORT PFNGLCOLOR4UIVPROC __glewColor4uiv; -GLEW_FUN_EXPORT PFNGLCOLOR4USPROC __glewColor4us; -GLEW_FUN_EXPORT PFNGLCOLOR4USVPROC __glewColor4usv; -GLEW_FUN_EXPORT PFNGLCOLORMASKPROC __glewColorMask; -GLEW_FUN_EXPORT PFNGLCOLORMATERIALPROC __glewColorMaterial; -GLEW_FUN_EXPORT PFNGLCOLORPOINTERPROC __glewColorPointer; -GLEW_FUN_EXPORT PFNGLCOPYPIXELSPROC __glewCopyPixels; -GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE1DPROC __glewCopyTexImage1D; -GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE2DPROC __glewCopyTexImage2D; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE1DPROC __glewCopyTexSubImage1D; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE2DPROC __glewCopyTexSubImage2D; -GLEW_FUN_EXPORT PFNGLCULLFACEPROC __glewCullFace; -GLEW_FUN_EXPORT PFNGLDELETELISTSPROC __glewDeleteLists; -GLEW_FUN_EXPORT PFNGLDELETETEXTURESPROC __glewDeleteTextures; -GLEW_FUN_EXPORT PFNGLDEPTHFUNCPROC __glewDepthFunc; -GLEW_FUN_EXPORT PFNGLDEPTHMASKPROC __glewDepthMask; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEPROC __glewDepthRange; -GLEW_FUN_EXPORT PFNGLDISABLEPROC __glewDisable; -GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEPROC __glewDisableClientState; -GLEW_FUN_EXPORT PFNGLDRAWARRAYSPROC __glewDrawArrays; -GLEW_FUN_EXPORT PFNGLDRAWBUFFERPROC __glewDrawBuffer; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSPROC __glewDrawElements; -GLEW_FUN_EXPORT PFNGLDRAWPIXELSPROC __glewDrawPixels; -GLEW_FUN_EXPORT PFNGLEDGEFLAGPROC __glewEdgeFlag; -GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTERPROC __glewEdgeFlagPointer; -GLEW_FUN_EXPORT PFNGLEDGEFLAGVPROC __glewEdgeFlagv; -GLEW_FUN_EXPORT PFNGLENABLEPROC __glewEnable; -GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEPROC __glewEnableClientState; -GLEW_FUN_EXPORT PFNGLENDPROC __glewEnd; -GLEW_FUN_EXPORT PFNGLENDLISTPROC __glewEndList; -GLEW_FUN_EXPORT PFNGLEVALCOORD1DPROC __glewEvalCoord1d; -GLEW_FUN_EXPORT PFNGLEVALCOORD1DVPROC __glewEvalCoord1dv; -GLEW_FUN_EXPORT PFNGLEVALCOORD1FPROC __glewEvalCoord1f; -GLEW_FUN_EXPORT PFNGLEVALCOORD1FVPROC __glewEvalCoord1fv; -GLEW_FUN_EXPORT PFNGLEVALCOORD2DPROC __glewEvalCoord2d; -GLEW_FUN_EXPORT PFNGLEVALCOORD2DVPROC __glewEvalCoord2dv; -GLEW_FUN_EXPORT PFNGLEVALCOORD2FPROC __glewEvalCoord2f; -GLEW_FUN_EXPORT PFNGLEVALCOORD2FVPROC __glewEvalCoord2fv; -GLEW_FUN_EXPORT PFNGLEVALMESH1PROC __glewEvalMesh1; -GLEW_FUN_EXPORT PFNGLEVALMESH2PROC __glewEvalMesh2; -GLEW_FUN_EXPORT PFNGLEVALPOINT1PROC __glewEvalPoint1; -GLEW_FUN_EXPORT PFNGLEVALPOINT2PROC __glewEvalPoint2; -GLEW_FUN_EXPORT PFNGLFEEDBACKBUFFERPROC __glewFeedbackBuffer; -GLEW_FUN_EXPORT PFNGLFINISHPROC __glewFinish; -GLEW_FUN_EXPORT PFNGLFLUSHPROC __glewFlush; -GLEW_FUN_EXPORT PFNGLFOGFPROC __glewFogf; -GLEW_FUN_EXPORT PFNGLFOGFVPROC __glewFogfv; -GLEW_FUN_EXPORT PFNGLFOGIPROC __glewFogi; -GLEW_FUN_EXPORT PFNGLFOGIVPROC __glewFogiv; -GLEW_FUN_EXPORT PFNGLFRONTFACEPROC __glewFrontFace; -GLEW_FUN_EXPORT PFNGLFRUSTUMPROC __glewFrustum; -GLEW_FUN_EXPORT PFNGLGENLISTSPROC __glewGenLists; -GLEW_FUN_EXPORT PFNGLGENTEXTURESPROC __glewGenTextures; -GLEW_FUN_EXPORT PFNGLGETBOOLEANVPROC __glewGetBooleanv; -GLEW_FUN_EXPORT PFNGLGETCLIPPLANEPROC __glewGetClipPlane; -GLEW_FUN_EXPORT PFNGLGETDOUBLEVPROC __glewGetDoublev; -GLEW_FUN_EXPORT PFNGLGETERRORPROC __glewGetError; -GLEW_FUN_EXPORT PFNGLGETFLOATVPROC __glewGetFloatv; -GLEW_FUN_EXPORT PFNGLGETINTEGERVPROC __glewGetIntegerv; -GLEW_FUN_EXPORT PFNGLGETLIGHTFVPROC __glewGetLightfv; -GLEW_FUN_EXPORT PFNGLGETLIGHTIVPROC __glewGetLightiv; -GLEW_FUN_EXPORT PFNGLGETMAPDVPROC __glewGetMapdv; -GLEW_FUN_EXPORT PFNGLGETMAPFVPROC __glewGetMapfv; -GLEW_FUN_EXPORT PFNGLGETMAPIVPROC __glewGetMapiv; -GLEW_FUN_EXPORT PFNGLGETMATERIALFVPROC __glewGetMaterialfv; -GLEW_FUN_EXPORT PFNGLGETMATERIALIVPROC __glewGetMaterialiv; -GLEW_FUN_EXPORT PFNGLGETPIXELMAPFVPROC __glewGetPixelMapfv; -GLEW_FUN_EXPORT PFNGLGETPIXELMAPUIVPROC __glewGetPixelMapuiv; -GLEW_FUN_EXPORT PFNGLGETPIXELMAPUSVPROC __glewGetPixelMapusv; -GLEW_FUN_EXPORT PFNGLGETPOINTERVPROC __glewGetPointerv; -GLEW_FUN_EXPORT PFNGLGETPOLYGONSTIPPLEPROC __glewGetPolygonStipple; -GLEW_FUN_EXPORT PFNGLGETSTRINGPROC __glewGetString; -GLEW_FUN_EXPORT PFNGLGETTEXENVFVPROC __glewGetTexEnvfv; -GLEW_FUN_EXPORT PFNGLGETTEXENVIVPROC __glewGetTexEnviv; -GLEW_FUN_EXPORT PFNGLGETTEXGENDVPROC __glewGetTexGendv; -GLEW_FUN_EXPORT PFNGLGETTEXGENFVPROC __glewGetTexGenfv; -GLEW_FUN_EXPORT PFNGLGETTEXGENIVPROC __glewGetTexGeniv; -GLEW_FUN_EXPORT PFNGLGETTEXIMAGEPROC __glewGetTexImage; -GLEW_FUN_EXPORT PFNGLGETTEXLEVELPARAMETERFVPROC __glewGetTexLevelParameterfv; -GLEW_FUN_EXPORT PFNGLGETTEXLEVELPARAMETERIVPROC __glewGetTexLevelParameteriv; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERFVPROC __glewGetTexParameterfv; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIVPROC __glewGetTexParameteriv; -GLEW_FUN_EXPORT PFNGLHINTPROC __glewHint; -GLEW_FUN_EXPORT PFNGLINDEXMASKPROC __glewIndexMask; -GLEW_FUN_EXPORT PFNGLINDEXPOINTERPROC __glewIndexPointer; -GLEW_FUN_EXPORT PFNGLINDEXDPROC __glewIndexd; -GLEW_FUN_EXPORT PFNGLINDEXDVPROC __glewIndexdv; -GLEW_FUN_EXPORT PFNGLINDEXFPROC __glewIndexf; -GLEW_FUN_EXPORT PFNGLINDEXFVPROC __glewIndexfv; -GLEW_FUN_EXPORT PFNGLINDEXIPROC __glewIndexi; -GLEW_FUN_EXPORT PFNGLINDEXIVPROC __glewIndexiv; -GLEW_FUN_EXPORT PFNGLINDEXSPROC __glewIndexs; -GLEW_FUN_EXPORT PFNGLINDEXSVPROC __glewIndexsv; -GLEW_FUN_EXPORT PFNGLINDEXUBPROC __glewIndexub; -GLEW_FUN_EXPORT PFNGLINDEXUBVPROC __glewIndexubv; -GLEW_FUN_EXPORT PFNGLINITNAMESPROC __glewInitNames; -GLEW_FUN_EXPORT PFNGLINTERLEAVEDARRAYSPROC __glewInterleavedArrays; -GLEW_FUN_EXPORT PFNGLISENABLEDPROC __glewIsEnabled; -GLEW_FUN_EXPORT PFNGLISLISTPROC __glewIsList; -GLEW_FUN_EXPORT PFNGLISTEXTUREPROC __glewIsTexture; -GLEW_FUN_EXPORT PFNGLLIGHTMODELFPROC __glewLightModelf; -GLEW_FUN_EXPORT PFNGLLIGHTMODELFVPROC __glewLightModelfv; -GLEW_FUN_EXPORT PFNGLLIGHTMODELIPROC __glewLightModeli; -GLEW_FUN_EXPORT PFNGLLIGHTMODELIVPROC __glewLightModeliv; -GLEW_FUN_EXPORT PFNGLLIGHTFPROC __glewLightf; -GLEW_FUN_EXPORT PFNGLLIGHTFVPROC __glewLightfv; -GLEW_FUN_EXPORT PFNGLLIGHTIPROC __glewLighti; -GLEW_FUN_EXPORT PFNGLLIGHTIVPROC __glewLightiv; -GLEW_FUN_EXPORT PFNGLLINESTIPPLEPROC __glewLineStipple; -GLEW_FUN_EXPORT PFNGLLINEWIDTHPROC __glewLineWidth; -GLEW_FUN_EXPORT PFNGLLISTBASEPROC __glewListBase; -GLEW_FUN_EXPORT PFNGLLOADIDENTITYPROC __glewLoadIdentity; -GLEW_FUN_EXPORT PFNGLLOADMATRIXDPROC __glewLoadMatrixd; -GLEW_FUN_EXPORT PFNGLLOADMATRIXFPROC __glewLoadMatrixf; -GLEW_FUN_EXPORT PFNGLLOADNAMEPROC __glewLoadName; -GLEW_FUN_EXPORT PFNGLLOGICOPPROC __glewLogicOp; -GLEW_FUN_EXPORT PFNGLMAP1DPROC __glewMap1d; -GLEW_FUN_EXPORT PFNGLMAP1FPROC __glewMap1f; -GLEW_FUN_EXPORT PFNGLMAP2DPROC __glewMap2d; -GLEW_FUN_EXPORT PFNGLMAP2FPROC __glewMap2f; -GLEW_FUN_EXPORT PFNGLMAPGRID1DPROC __glewMapGrid1d; -GLEW_FUN_EXPORT PFNGLMAPGRID1FPROC __glewMapGrid1f; -GLEW_FUN_EXPORT PFNGLMAPGRID2DPROC __glewMapGrid2d; -GLEW_FUN_EXPORT PFNGLMAPGRID2FPROC __glewMapGrid2f; -GLEW_FUN_EXPORT PFNGLMATERIALFPROC __glewMaterialf; -GLEW_FUN_EXPORT PFNGLMATERIALFVPROC __glewMaterialfv; -GLEW_FUN_EXPORT PFNGLMATERIALIPROC __glewMateriali; -GLEW_FUN_EXPORT PFNGLMATERIALIVPROC __glewMaterialiv; -GLEW_FUN_EXPORT PFNGLMATRIXMODEPROC __glewMatrixMode; -GLEW_FUN_EXPORT PFNGLMULTMATRIXDPROC __glewMultMatrixd; -GLEW_FUN_EXPORT PFNGLMULTMATRIXFPROC __glewMultMatrixf; -GLEW_FUN_EXPORT PFNGLNEWLISTPROC __glewNewList; -GLEW_FUN_EXPORT PFNGLNORMAL3BPROC __glewNormal3b; -GLEW_FUN_EXPORT PFNGLNORMAL3BVPROC __glewNormal3bv; -GLEW_FUN_EXPORT PFNGLNORMAL3DPROC __glewNormal3d; -GLEW_FUN_EXPORT PFNGLNORMAL3DVPROC __glewNormal3dv; -GLEW_FUN_EXPORT PFNGLNORMAL3FPROC __glewNormal3f; -GLEW_FUN_EXPORT PFNGLNORMAL3FVPROC __glewNormal3fv; -GLEW_FUN_EXPORT PFNGLNORMAL3IPROC __glewNormal3i; -GLEW_FUN_EXPORT PFNGLNORMAL3IVPROC __glewNormal3iv; -GLEW_FUN_EXPORT PFNGLNORMAL3SPROC __glewNormal3s; -GLEW_FUN_EXPORT PFNGLNORMAL3SVPROC __glewNormal3sv; -GLEW_FUN_EXPORT PFNGLNORMALPOINTERPROC __glewNormalPointer; -GLEW_FUN_EXPORT PFNGLORTHOPROC __glewOrtho; -GLEW_FUN_EXPORT PFNGLPASSTHROUGHPROC __glewPassThrough; -GLEW_FUN_EXPORT PFNGLPIXELMAPFVPROC __glewPixelMapfv; -GLEW_FUN_EXPORT PFNGLPIXELMAPUIVPROC __glewPixelMapuiv; -GLEW_FUN_EXPORT PFNGLPIXELMAPUSVPROC __glewPixelMapusv; -GLEW_FUN_EXPORT PFNGLPIXELSTOREFPROC __glewPixelStoref; -GLEW_FUN_EXPORT PFNGLPIXELSTOREIPROC __glewPixelStorei; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFERFPROC __glewPixelTransferf; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFERIPROC __glewPixelTransferi; -GLEW_FUN_EXPORT PFNGLPIXELZOOMPROC __glewPixelZoom; -GLEW_FUN_EXPORT PFNGLPOINTSIZEPROC __glewPointSize; -GLEW_FUN_EXPORT PFNGLPOLYGONMODEPROC __glewPolygonMode; -GLEW_FUN_EXPORT PFNGLPOLYGONOFFSETPROC __glewPolygonOffset; -GLEW_FUN_EXPORT PFNGLPOLYGONSTIPPLEPROC __glewPolygonStipple; -GLEW_FUN_EXPORT PFNGLPOPATTRIBPROC __glewPopAttrib; -GLEW_FUN_EXPORT PFNGLPOPCLIENTATTRIBPROC __glewPopClientAttrib; -GLEW_FUN_EXPORT PFNGLPOPMATRIXPROC __glewPopMatrix; -GLEW_FUN_EXPORT PFNGLPOPNAMEPROC __glewPopName; -GLEW_FUN_EXPORT PFNGLPRIORITIZETEXTURESPROC __glewPrioritizeTextures; -GLEW_FUN_EXPORT PFNGLPUSHATTRIBPROC __glewPushAttrib; -GLEW_FUN_EXPORT PFNGLPUSHCLIENTATTRIBPROC __glewPushClientAttrib; -GLEW_FUN_EXPORT PFNGLPUSHMATRIXPROC __glewPushMatrix; -GLEW_FUN_EXPORT PFNGLPUSHNAMEPROC __glewPushName; -GLEW_FUN_EXPORT PFNGLRASTERPOS2DPROC __glewRasterPos2d; -GLEW_FUN_EXPORT PFNGLRASTERPOS2DVPROC __glewRasterPos2dv; -GLEW_FUN_EXPORT PFNGLRASTERPOS2FPROC __glewRasterPos2f; -GLEW_FUN_EXPORT PFNGLRASTERPOS2FVPROC __glewRasterPos2fv; -GLEW_FUN_EXPORT PFNGLRASTERPOS2IPROC __glewRasterPos2i; -GLEW_FUN_EXPORT PFNGLRASTERPOS2IVPROC __glewRasterPos2iv; -GLEW_FUN_EXPORT PFNGLRASTERPOS2SPROC __glewRasterPos2s; -GLEW_FUN_EXPORT PFNGLRASTERPOS2SVPROC __glewRasterPos2sv; -GLEW_FUN_EXPORT PFNGLRASTERPOS3DPROC __glewRasterPos3d; -GLEW_FUN_EXPORT PFNGLRASTERPOS3DVPROC __glewRasterPos3dv; -GLEW_FUN_EXPORT PFNGLRASTERPOS3FPROC __glewRasterPos3f; -GLEW_FUN_EXPORT PFNGLRASTERPOS3FVPROC __glewRasterPos3fv; -GLEW_FUN_EXPORT PFNGLRASTERPOS3IPROC __glewRasterPos3i; -GLEW_FUN_EXPORT PFNGLRASTERPOS3IVPROC __glewRasterPos3iv; -GLEW_FUN_EXPORT PFNGLRASTERPOS3SPROC __glewRasterPos3s; -GLEW_FUN_EXPORT PFNGLRASTERPOS3SVPROC __glewRasterPos3sv; -GLEW_FUN_EXPORT PFNGLRASTERPOS4DPROC __glewRasterPos4d; -GLEW_FUN_EXPORT PFNGLRASTERPOS4DVPROC __glewRasterPos4dv; -GLEW_FUN_EXPORT PFNGLRASTERPOS4FPROC __glewRasterPos4f; -GLEW_FUN_EXPORT PFNGLRASTERPOS4FVPROC __glewRasterPos4fv; -GLEW_FUN_EXPORT PFNGLRASTERPOS4IPROC __glewRasterPos4i; -GLEW_FUN_EXPORT PFNGLRASTERPOS4IVPROC __glewRasterPos4iv; -GLEW_FUN_EXPORT PFNGLRASTERPOS4SPROC __glewRasterPos4s; -GLEW_FUN_EXPORT PFNGLRASTERPOS4SVPROC __glewRasterPos4sv; -GLEW_FUN_EXPORT PFNGLREADBUFFERPROC __glewReadBuffer; -GLEW_FUN_EXPORT PFNGLREADPIXELSPROC __glewReadPixels; -GLEW_FUN_EXPORT PFNGLRECTDPROC __glewRectd; -GLEW_FUN_EXPORT PFNGLRECTDVPROC __glewRectdv; -GLEW_FUN_EXPORT PFNGLRECTFPROC __glewRectf; -GLEW_FUN_EXPORT PFNGLRECTFVPROC __glewRectfv; -GLEW_FUN_EXPORT PFNGLRECTIPROC __glewRecti; -GLEW_FUN_EXPORT PFNGLRECTIVPROC __glewRectiv; -GLEW_FUN_EXPORT PFNGLRECTSPROC __glewRects; -GLEW_FUN_EXPORT PFNGLRECTSVPROC __glewRectsv; -GLEW_FUN_EXPORT PFNGLRENDERMODEPROC __glewRenderMode; -GLEW_FUN_EXPORT PFNGLROTATEDPROC __glewRotated; -GLEW_FUN_EXPORT PFNGLROTATEFPROC __glewRotatef; -GLEW_FUN_EXPORT PFNGLSCALEDPROC __glewScaled; -GLEW_FUN_EXPORT PFNGLSCALEFPROC __glewScalef; -GLEW_FUN_EXPORT PFNGLSCISSORPROC __glewScissor; -GLEW_FUN_EXPORT PFNGLSELECTBUFFERPROC __glewSelectBuffer; -GLEW_FUN_EXPORT PFNGLSHADEMODELPROC __glewShadeModel; -GLEW_FUN_EXPORT PFNGLSTENCILFUNCPROC __glewStencilFunc; -GLEW_FUN_EXPORT PFNGLSTENCILMASKPROC __glewStencilMask; -GLEW_FUN_EXPORT PFNGLSTENCILOPPROC __glewStencilOp; -GLEW_FUN_EXPORT PFNGLTEXCOORD1DPROC __glewTexCoord1d; -GLEW_FUN_EXPORT PFNGLTEXCOORD1DVPROC __glewTexCoord1dv; -GLEW_FUN_EXPORT PFNGLTEXCOORD1FPROC __glewTexCoord1f; -GLEW_FUN_EXPORT PFNGLTEXCOORD1FVPROC __glewTexCoord1fv; -GLEW_FUN_EXPORT PFNGLTEXCOORD1IPROC __glewTexCoord1i; -GLEW_FUN_EXPORT PFNGLTEXCOORD1IVPROC __glewTexCoord1iv; -GLEW_FUN_EXPORT PFNGLTEXCOORD1SPROC __glewTexCoord1s; -GLEW_FUN_EXPORT PFNGLTEXCOORD1SVPROC __glewTexCoord1sv; -GLEW_FUN_EXPORT PFNGLTEXCOORD2DPROC __glewTexCoord2d; -GLEW_FUN_EXPORT PFNGLTEXCOORD2DVPROC __glewTexCoord2dv; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FPROC __glewTexCoord2f; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FVPROC __glewTexCoord2fv; -GLEW_FUN_EXPORT PFNGLTEXCOORD2IPROC __glewTexCoord2i; -GLEW_FUN_EXPORT PFNGLTEXCOORD2IVPROC __glewTexCoord2iv; -GLEW_FUN_EXPORT PFNGLTEXCOORD2SPROC __glewTexCoord2s; -GLEW_FUN_EXPORT PFNGLTEXCOORD2SVPROC __glewTexCoord2sv; -GLEW_FUN_EXPORT PFNGLTEXCOORD3DPROC __glewTexCoord3d; -GLEW_FUN_EXPORT PFNGLTEXCOORD3DVPROC __glewTexCoord3dv; -GLEW_FUN_EXPORT PFNGLTEXCOORD3FPROC __glewTexCoord3f; -GLEW_FUN_EXPORT PFNGLTEXCOORD3FVPROC __glewTexCoord3fv; -GLEW_FUN_EXPORT PFNGLTEXCOORD3IPROC __glewTexCoord3i; -GLEW_FUN_EXPORT PFNGLTEXCOORD3IVPROC __glewTexCoord3iv; -GLEW_FUN_EXPORT PFNGLTEXCOORD3SPROC __glewTexCoord3s; -GLEW_FUN_EXPORT PFNGLTEXCOORD3SVPROC __glewTexCoord3sv; -GLEW_FUN_EXPORT PFNGLTEXCOORD4DPROC __glewTexCoord4d; -GLEW_FUN_EXPORT PFNGLTEXCOORD4DVPROC __glewTexCoord4dv; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FPROC __glewTexCoord4f; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FVPROC __glewTexCoord4fv; -GLEW_FUN_EXPORT PFNGLTEXCOORD4IPROC __glewTexCoord4i; -GLEW_FUN_EXPORT PFNGLTEXCOORD4IVPROC __glewTexCoord4iv; -GLEW_FUN_EXPORT PFNGLTEXCOORD4SPROC __glewTexCoord4s; -GLEW_FUN_EXPORT PFNGLTEXCOORD4SVPROC __glewTexCoord4sv; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERPROC __glewTexCoordPointer; -GLEW_FUN_EXPORT PFNGLTEXENVFPROC __glewTexEnvf; -GLEW_FUN_EXPORT PFNGLTEXENVFVPROC __glewTexEnvfv; -GLEW_FUN_EXPORT PFNGLTEXENVIPROC __glewTexEnvi; -GLEW_FUN_EXPORT PFNGLTEXENVIVPROC __glewTexEnviv; -GLEW_FUN_EXPORT PFNGLTEXGENDPROC __glewTexGend; -GLEW_FUN_EXPORT PFNGLTEXGENDVPROC __glewTexGendv; -GLEW_FUN_EXPORT PFNGLTEXGENFPROC __glewTexGenf; -GLEW_FUN_EXPORT PFNGLTEXGENFVPROC __glewTexGenfv; -GLEW_FUN_EXPORT PFNGLTEXGENIPROC __glewTexGeni; -GLEW_FUN_EXPORT PFNGLTEXGENIVPROC __glewTexGeniv; -GLEW_FUN_EXPORT PFNGLTEXIMAGE1DPROC __glewTexImage1D; -GLEW_FUN_EXPORT PFNGLTEXIMAGE2DPROC __glewTexImage2D; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERFPROC __glewTexParameterf; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERFVPROC __glewTexParameterfv; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIPROC __glewTexParameteri; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIVPROC __glewTexParameteriv; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE1DPROC __glewTexSubImage1D; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE2DPROC __glewTexSubImage2D; -GLEW_FUN_EXPORT PFNGLTRANSLATEDPROC __glewTranslated; -GLEW_FUN_EXPORT PFNGLTRANSLATEFPROC __glewTranslatef; -GLEW_FUN_EXPORT PFNGLVERTEX2DPROC __glewVertex2d; -GLEW_FUN_EXPORT PFNGLVERTEX2DVPROC __glewVertex2dv; -GLEW_FUN_EXPORT PFNGLVERTEX2FPROC __glewVertex2f; -GLEW_FUN_EXPORT PFNGLVERTEX2FVPROC __glewVertex2fv; -GLEW_FUN_EXPORT PFNGLVERTEX2IPROC __glewVertex2i; -GLEW_FUN_EXPORT PFNGLVERTEX2IVPROC __glewVertex2iv; -GLEW_FUN_EXPORT PFNGLVERTEX2SPROC __glewVertex2s; -GLEW_FUN_EXPORT PFNGLVERTEX2SVPROC __glewVertex2sv; -GLEW_FUN_EXPORT PFNGLVERTEX3DPROC __glewVertex3d; -GLEW_FUN_EXPORT PFNGLVERTEX3DVPROC __glewVertex3dv; -GLEW_FUN_EXPORT PFNGLVERTEX3FPROC __glewVertex3f; -GLEW_FUN_EXPORT PFNGLVERTEX3FVPROC __glewVertex3fv; -GLEW_FUN_EXPORT PFNGLVERTEX3IPROC __glewVertex3i; -GLEW_FUN_EXPORT PFNGLVERTEX3IVPROC __glewVertex3iv; -GLEW_FUN_EXPORT PFNGLVERTEX3SPROC __glewVertex3s; -GLEW_FUN_EXPORT PFNGLVERTEX3SVPROC __glewVertex3sv; -GLEW_FUN_EXPORT PFNGLVERTEX4DPROC __glewVertex4d; -GLEW_FUN_EXPORT PFNGLVERTEX4DVPROC __glewVertex4dv; -GLEW_FUN_EXPORT PFNGLVERTEX4FPROC __glewVertex4f; -GLEW_FUN_EXPORT PFNGLVERTEX4FVPROC __glewVertex4fv; -GLEW_FUN_EXPORT PFNGLVERTEX4IPROC __glewVertex4i; -GLEW_FUN_EXPORT PFNGLVERTEX4IVPROC __glewVertex4iv; -GLEW_FUN_EXPORT PFNGLVERTEX4SPROC __glewVertex4s; -GLEW_FUN_EXPORT PFNGLVERTEX4SVPROC __glewVertex4sv; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTERPROC __glewVertexPointer; -GLEW_FUN_EXPORT PFNGLVIEWPORTPROC __glewViewport; -#endif //#ifdef GLEW_INIT_OPENGL11_FUNCTIONS - -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE3DPROC __glewCopyTexSubImage3D; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSPROC __glewDrawRangeElements; -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DPROC __glewTexImage3D; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE3DPROC __glewTexSubImage3D; - -GLEW_FUN_EXPORT PFNGLACTIVETEXTUREPROC __glewActiveTexture; -GLEW_FUN_EXPORT PFNGLCLIENTACTIVETEXTUREPROC __glewClientActiveTexture; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE1DPROC __glewCompressedTexImage1D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE2DPROC __glewCompressedTexImage2D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE3DPROC __glewCompressedTexImage3D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC __glewCompressedTexSubImage1D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC __glewCompressedTexSubImage2D; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC __glewCompressedTexSubImage3D; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXIMAGEPROC __glewGetCompressedTexImage; -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXDPROC __glewLoadTransposeMatrixd; -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXFPROC __glewLoadTransposeMatrixf; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXDPROC __glewMultTransposeMatrixd; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXFPROC __glewMultTransposeMatrixf; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DPROC __glewMultiTexCoord1d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DVPROC __glewMultiTexCoord1dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FPROC __glewMultiTexCoord1f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FVPROC __glewMultiTexCoord1fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IPROC __glewMultiTexCoord1i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IVPROC __glewMultiTexCoord1iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SPROC __glewMultiTexCoord1s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SVPROC __glewMultiTexCoord1sv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DPROC __glewMultiTexCoord2d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DVPROC __glewMultiTexCoord2dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FPROC __glewMultiTexCoord2f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FVPROC __glewMultiTexCoord2fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IPROC __glewMultiTexCoord2i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IVPROC __glewMultiTexCoord2iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SPROC __glewMultiTexCoord2s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SVPROC __glewMultiTexCoord2sv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DPROC __glewMultiTexCoord3d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DVPROC __glewMultiTexCoord3dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FPROC __glewMultiTexCoord3f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FVPROC __glewMultiTexCoord3fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IPROC __glewMultiTexCoord3i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IVPROC __glewMultiTexCoord3iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SPROC __glewMultiTexCoord3s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SVPROC __glewMultiTexCoord3sv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DPROC __glewMultiTexCoord4d; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DVPROC __glewMultiTexCoord4dv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FPROC __glewMultiTexCoord4f; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FVPROC __glewMultiTexCoord4fv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IPROC __glewMultiTexCoord4i; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IVPROC __glewMultiTexCoord4iv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SPROC __glewMultiTexCoord4s; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SVPROC __glewMultiTexCoord4sv; -GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEPROC __glewSampleCoverage; - -GLEW_FUN_EXPORT PFNGLBLENDCOLORPROC __glewBlendColor; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONPROC __glewBlendEquation; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEPROC __glewBlendFuncSeparate; -GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTERPROC __glewFogCoordPointer; -GLEW_FUN_EXPORT PFNGLFOGCOORDDPROC __glewFogCoordd; -GLEW_FUN_EXPORT PFNGLFOGCOORDDVPROC __glewFogCoorddv; -GLEW_FUN_EXPORT PFNGLFOGCOORDFPROC __glewFogCoordf; -GLEW_FUN_EXPORT PFNGLFOGCOORDFVPROC __glewFogCoordfv; -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSPROC __glewMultiDrawArrays; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSPROC __glewMultiDrawElements; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFPROC __glewPointParameterf; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVPROC __glewPointParameterfv; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIPROC __glewPointParameteri; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIVPROC __glewPointParameteriv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BPROC __glewSecondaryColor3b; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BVPROC __glewSecondaryColor3bv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DPROC __glewSecondaryColor3d; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DVPROC __glewSecondaryColor3dv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FPROC __glewSecondaryColor3f; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FVPROC __glewSecondaryColor3fv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IPROC __glewSecondaryColor3i; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IVPROC __glewSecondaryColor3iv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SPROC __glewSecondaryColor3s; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SVPROC __glewSecondaryColor3sv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBPROC __glewSecondaryColor3ub; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBVPROC __glewSecondaryColor3ubv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIPROC __glewSecondaryColor3ui; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIVPROC __glewSecondaryColor3uiv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USPROC __glewSecondaryColor3us; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USVPROC __glewSecondaryColor3usv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTERPROC __glewSecondaryColorPointer; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DPROC __glewWindowPos2d; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVPROC __glewWindowPos2dv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FPROC __glewWindowPos2f; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVPROC __glewWindowPos2fv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IPROC __glewWindowPos2i; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVPROC __glewWindowPos2iv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SPROC __glewWindowPos2s; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVPROC __glewWindowPos2sv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DPROC __glewWindowPos3d; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVPROC __glewWindowPos3dv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FPROC __glewWindowPos3f; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVPROC __glewWindowPos3fv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IPROC __glewWindowPos3i; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVPROC __glewWindowPos3iv; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SPROC __glewWindowPos3s; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVPROC __glewWindowPos3sv; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYPROC __glewBeginQuery; -GLEW_FUN_EXPORT PFNGLBINDBUFFERPROC __glewBindBuffer; -GLEW_FUN_EXPORT PFNGLBUFFERDATAPROC __glewBufferData; -GLEW_FUN_EXPORT PFNGLBUFFERSUBDATAPROC __glewBufferSubData; -GLEW_FUN_EXPORT PFNGLDELETEBUFFERSPROC __glewDeleteBuffers; -GLEW_FUN_EXPORT PFNGLDELETEQUERIESPROC __glewDeleteQueries; -GLEW_FUN_EXPORT PFNGLENDQUERYPROC __glewEndQuery; -GLEW_FUN_EXPORT PFNGLGENBUFFERSPROC __glewGenBuffers; -GLEW_FUN_EXPORT PFNGLGENQUERIESPROC __glewGenQueries; -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERIVPROC __glewGetBufferParameteriv; -GLEW_FUN_EXPORT PFNGLGETBUFFERPOINTERVPROC __glewGetBufferPointerv; -GLEW_FUN_EXPORT PFNGLGETBUFFERSUBDATAPROC __glewGetBufferSubData; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVPROC __glewGetQueryObjectiv; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVPROC __glewGetQueryObjectuiv; -GLEW_FUN_EXPORT PFNGLGETQUERYIVPROC __glewGetQueryiv; -GLEW_FUN_EXPORT PFNGLISBUFFERPROC __glewIsBuffer; -GLEW_FUN_EXPORT PFNGLISQUERYPROC __glewIsQuery; -GLEW_FUN_EXPORT PFNGLMAPBUFFERPROC __glewMapBuffer; -GLEW_FUN_EXPORT PFNGLUNMAPBUFFERPROC __glewUnmapBuffer; - -GLEW_FUN_EXPORT PFNGLATTACHSHADERPROC __glewAttachShader; -GLEW_FUN_EXPORT PFNGLBINDATTRIBLOCATIONPROC __glewBindAttribLocation; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEPROC __glewBlendEquationSeparate; -GLEW_FUN_EXPORT PFNGLCOMPILESHADERPROC __glewCompileShader; -GLEW_FUN_EXPORT PFNGLCREATEPROGRAMPROC __glewCreateProgram; -GLEW_FUN_EXPORT PFNGLCREATESHADERPROC __glewCreateShader; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMPROC __glewDeleteProgram; -GLEW_FUN_EXPORT PFNGLDELETESHADERPROC __glewDeleteShader; -GLEW_FUN_EXPORT PFNGLDETACHSHADERPROC __glewDetachShader; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBARRAYPROC __glewDisableVertexAttribArray; -GLEW_FUN_EXPORT PFNGLDRAWBUFFERSPROC __glewDrawBuffers; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBARRAYPROC __glewEnableVertexAttribArray; -GLEW_FUN_EXPORT PFNGLGETACTIVEATTRIBPROC __glewGetActiveAttrib; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMPROC __glewGetActiveUniform; -GLEW_FUN_EXPORT PFNGLGETATTACHEDSHADERSPROC __glewGetAttachedShaders; -GLEW_FUN_EXPORT PFNGLGETATTRIBLOCATIONPROC __glewGetAttribLocation; -GLEW_FUN_EXPORT PFNGLGETPROGRAMINFOLOGPROC __glewGetProgramInfoLog; -GLEW_FUN_EXPORT PFNGLGETPROGRAMIVPROC __glewGetProgramiv; -GLEW_FUN_EXPORT PFNGLGETSHADERINFOLOGPROC __glewGetShaderInfoLog; -GLEW_FUN_EXPORT PFNGLGETSHADERSOURCEPROC __glewGetShaderSource; -GLEW_FUN_EXPORT PFNGLGETSHADERIVPROC __glewGetShaderiv; -GLEW_FUN_EXPORT PFNGLGETUNIFORMLOCATIONPROC __glewGetUniformLocation; -GLEW_FUN_EXPORT PFNGLGETUNIFORMFVPROC __glewGetUniformfv; -GLEW_FUN_EXPORT PFNGLGETUNIFORMIVPROC __glewGetUniformiv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVPROC __glewGetVertexAttribPointerv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVPROC __glewGetVertexAttribdv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVPROC __glewGetVertexAttribfv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVPROC __glewGetVertexAttribiv; -GLEW_FUN_EXPORT PFNGLISPROGRAMPROC __glewIsProgram; -GLEW_FUN_EXPORT PFNGLISSHADERPROC __glewIsShader; -GLEW_FUN_EXPORT PFNGLLINKPROGRAMPROC __glewLinkProgram; -GLEW_FUN_EXPORT PFNGLSHADERSOURCEPROC __glewShaderSource; -GLEW_FUN_EXPORT PFNGLSTENCILFUNCSEPARATEPROC __glewStencilFuncSeparate; -GLEW_FUN_EXPORT PFNGLSTENCILMASKSEPARATEPROC __glewStencilMaskSeparate; -GLEW_FUN_EXPORT PFNGLSTENCILOPSEPARATEPROC __glewStencilOpSeparate; -GLEW_FUN_EXPORT PFNGLUNIFORM1FPROC __glewUniform1f; -GLEW_FUN_EXPORT PFNGLUNIFORM1FVPROC __glewUniform1fv; -GLEW_FUN_EXPORT PFNGLUNIFORM1IPROC __glewUniform1i; -GLEW_FUN_EXPORT PFNGLUNIFORM1IVPROC __glewUniform1iv; -GLEW_FUN_EXPORT PFNGLUNIFORM2FPROC __glewUniform2f; -GLEW_FUN_EXPORT PFNGLUNIFORM2FVPROC __glewUniform2fv; -GLEW_FUN_EXPORT PFNGLUNIFORM2IPROC __glewUniform2i; -GLEW_FUN_EXPORT PFNGLUNIFORM2IVPROC __glewUniform2iv; -GLEW_FUN_EXPORT PFNGLUNIFORM3FPROC __glewUniform3f; -GLEW_FUN_EXPORT PFNGLUNIFORM3FVPROC __glewUniform3fv; -GLEW_FUN_EXPORT PFNGLUNIFORM3IPROC __glewUniform3i; -GLEW_FUN_EXPORT PFNGLUNIFORM3IVPROC __glewUniform3iv; -GLEW_FUN_EXPORT PFNGLUNIFORM4FPROC __glewUniform4f; -GLEW_FUN_EXPORT PFNGLUNIFORM4FVPROC __glewUniform4fv; -GLEW_FUN_EXPORT PFNGLUNIFORM4IPROC __glewUniform4i; -GLEW_FUN_EXPORT PFNGLUNIFORM4IVPROC __glewUniform4iv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2FVPROC __glewUniformMatrix2fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3FVPROC __glewUniformMatrix3fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4FVPROC __glewUniformMatrix4fv; -GLEW_FUN_EXPORT PFNGLUSEPROGRAMPROC __glewUseProgram; -GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMPROC __glewValidateProgram; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DPROC __glewVertexAttrib1d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVPROC __glewVertexAttrib1dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FPROC __glewVertexAttrib1f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVPROC __glewVertexAttrib1fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SPROC __glewVertexAttrib1s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVPROC __glewVertexAttrib1sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DPROC __glewVertexAttrib2d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVPROC __glewVertexAttrib2dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FPROC __glewVertexAttrib2f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVPROC __glewVertexAttrib2fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SPROC __glewVertexAttrib2s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVPROC __glewVertexAttrib2sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DPROC __glewVertexAttrib3d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVPROC __glewVertexAttrib3dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FPROC __glewVertexAttrib3f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVPROC __glewVertexAttrib3fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SPROC __glewVertexAttrib3s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVPROC __glewVertexAttrib3sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NBVPROC __glewVertexAttrib4Nbv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NIVPROC __glewVertexAttrib4Niv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NSVPROC __glewVertexAttrib4Nsv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBPROC __glewVertexAttrib4Nub; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBVPROC __glewVertexAttrib4Nubv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUIVPROC __glewVertexAttrib4Nuiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUSVPROC __glewVertexAttrib4Nusv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4BVPROC __glewVertexAttrib4bv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DPROC __glewVertexAttrib4d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVPROC __glewVertexAttrib4dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FPROC __glewVertexAttrib4f; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVPROC __glewVertexAttrib4fv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4IVPROC __glewVertexAttrib4iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SPROC __glewVertexAttrib4s; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVPROC __glewVertexAttrib4sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVPROC __glewVertexAttrib4ubv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UIVPROC __glewVertexAttrib4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4USVPROC __glewVertexAttrib4usv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERPROC __glewVertexAttribPointer; - -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X3FVPROC __glewUniformMatrix2x3fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X4FVPROC __glewUniformMatrix2x4fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X2FVPROC __glewUniformMatrix3x2fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X4FVPROC __glewUniformMatrix3x4fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X2FVPROC __glewUniformMatrix4x2fv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X3FVPROC __glewUniformMatrix4x3fv; - -GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERPROC __glewBeginConditionalRender; -GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKPROC __glewBeginTransformFeedback; -GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONPROC __glewBindFragDataLocation; -GLEW_FUN_EXPORT PFNGLCLAMPCOLORPROC __glewClampColor; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERFIPROC __glewClearBufferfi; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERFVPROC __glewClearBufferfv; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERIVPROC __glewClearBufferiv; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERUIVPROC __glewClearBufferuiv; -GLEW_FUN_EXPORT PFNGLCOLORMASKIPROC __glewColorMaski; -GLEW_FUN_EXPORT PFNGLDISABLEIPROC __glewDisablei; -GLEW_FUN_EXPORT PFNGLENABLEIPROC __glewEnablei; -GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERPROC __glewEndConditionalRender; -GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKPROC __glewEndTransformFeedback; -GLEW_FUN_EXPORT PFNGLGETBOOLEANI_VPROC __glewGetBooleani_v; -GLEW_FUN_EXPORT PFNGLGETFRAGDATALOCATIONPROC __glewGetFragDataLocation; -GLEW_FUN_EXPORT PFNGLGETSTRINGIPROC __glewGetStringi; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIIVPROC __glewGetTexParameterIiv; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIUIVPROC __glewGetTexParameterIuiv; -GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGPROC __glewGetTransformFeedbackVarying; -GLEW_FUN_EXPORT PFNGLGETUNIFORMUIVPROC __glewGetUniformuiv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIIVPROC __glewGetVertexAttribIiv; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIUIVPROC __glewGetVertexAttribIuiv; -GLEW_FUN_EXPORT PFNGLISENABLEDIPROC __glewIsEnabledi; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIIVPROC __glewTexParameterIiv; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIUIVPROC __glewTexParameterIuiv; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSPROC __glewTransformFeedbackVaryings; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIPROC __glewUniform1ui; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIVPROC __glewUniform1uiv; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIPROC __glewUniform2ui; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIVPROC __glewUniform2uiv; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIPROC __glewUniform3ui; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIVPROC __glewUniform3uiv; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIPROC __glewUniform4ui; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIVPROC __glewUniform4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IPROC __glewVertexAttribI1i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IVPROC __glewVertexAttribI1iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIPROC __glewVertexAttribI1ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIVPROC __glewVertexAttribI1uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IPROC __glewVertexAttribI2i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IVPROC __glewVertexAttribI2iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIPROC __glewVertexAttribI2ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIVPROC __glewVertexAttribI2uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IPROC __glewVertexAttribI3i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IVPROC __glewVertexAttribI3iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIPROC __glewVertexAttribI3ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIVPROC __glewVertexAttribI3uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4BVPROC __glewVertexAttribI4bv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IPROC __glewVertexAttribI4i; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IVPROC __glewVertexAttribI4iv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4SVPROC __glewVertexAttribI4sv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UBVPROC __glewVertexAttribI4ubv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIPROC __glewVertexAttribI4ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIVPROC __glewVertexAttribI4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4USVPROC __glewVertexAttribI4usv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIPOINTERPROC __glewVertexAttribIPointer; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDPROC __glewDrawArraysInstanced; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDPROC __glewDrawElementsInstanced; -GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTINDEXPROC __glewPrimitiveRestartIndex; -GLEW_FUN_EXPORT PFNGLTEXBUFFERPROC __glewTexBuffer; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREPROC __glewFramebufferTexture; -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERI64VPROC __glewGetBufferParameteri64v; -GLEW_FUN_EXPORT PFNGLGETINTEGER64I_VPROC __glewGetInteger64i_v; - -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBDIVISORPROC __glewVertexAttribDivisor; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEIPROC __glewBlendEquationSeparatei; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONIPROC __glewBlendEquationi; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEIPROC __glewBlendFuncSeparatei; -GLEW_FUN_EXPORT PFNGLBLENDFUNCIPROC __glewBlendFunci; -GLEW_FUN_EXPORT PFNGLMINSAMPLESHADINGPROC __glewMinSampleShading; - -GLEW_FUN_EXPORT PFNGLTBUFFERMASK3DFXPROC __glewTbufferMask3DFX; - -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECALLBACKAMDPROC __glewDebugMessageCallbackAMD; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEENABLEAMDPROC __glewDebugMessageEnableAMD; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEINSERTAMDPROC __glewDebugMessageInsertAMD; -GLEW_FUN_EXPORT PFNGLGETDEBUGMESSAGELOGAMDPROC __glewGetDebugMessageLogAMD; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONINDEXEDAMDPROC __glewBlendEquationIndexedAMD; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC __glewBlendEquationSeparateIndexedAMD; -GLEW_FUN_EXPORT PFNGLBLENDFUNCINDEXEDAMDPROC __glewBlendFuncIndexedAMD; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC __glewBlendFuncSeparateIndexedAMD; - -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPARAMETERIAMDPROC __glewVertexAttribParameteriAMD; - -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSINDIRECTAMDPROC __glewMultiDrawArraysIndirectAMD; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSINDIRECTAMDPROC __glewMultiDrawElementsIndirectAMD; - -GLEW_FUN_EXPORT PFNGLDELETENAMESAMDPROC __glewDeleteNamesAMD; -GLEW_FUN_EXPORT PFNGLGENNAMESAMDPROC __glewGenNamesAMD; -GLEW_FUN_EXPORT PFNGLISNAMEAMDPROC __glewIsNameAMD; - -GLEW_FUN_EXPORT PFNGLBEGINPERFMONITORAMDPROC __glewBeginPerfMonitorAMD; -GLEW_FUN_EXPORT PFNGLDELETEPERFMONITORSAMDPROC __glewDeletePerfMonitorsAMD; -GLEW_FUN_EXPORT PFNGLENDPERFMONITORAMDPROC __glewEndPerfMonitorAMD; -GLEW_FUN_EXPORT PFNGLGENPERFMONITORSAMDPROC __glewGenPerfMonitorsAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERDATAAMDPROC __glewGetPerfMonitorCounterDataAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERINFOAMDPROC __glewGetPerfMonitorCounterInfoAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC __glewGetPerfMonitorCounterStringAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORCOUNTERSAMDPROC __glewGetPerfMonitorCountersAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORGROUPSTRINGAMDPROC __glewGetPerfMonitorGroupStringAMD; -GLEW_FUN_EXPORT PFNGLGETPERFMONITORGROUPSAMDPROC __glewGetPerfMonitorGroupsAMD; -GLEW_FUN_EXPORT PFNGLSELECTPERFMONITORCOUNTERSAMDPROC __glewSelectPerfMonitorCountersAMD; - -GLEW_FUN_EXPORT PFNGLSETMULTISAMPLEFVAMDPROC __glewSetMultisamplefvAMD; - -GLEW_FUN_EXPORT PFNGLTEXSTORAGESPARSEAMDPROC __glewTexStorageSparseAMD; -GLEW_FUN_EXPORT PFNGLTEXTURESTORAGESPARSEAMDPROC __glewTextureStorageSparseAMD; - -GLEW_FUN_EXPORT PFNGLSTENCILOPVALUEAMDPROC __glewStencilOpValueAMD; - -GLEW_FUN_EXPORT PFNGLTESSELLATIONFACTORAMDPROC __glewTessellationFactorAMD; -GLEW_FUN_EXPORT PFNGLTESSELLATIONMODEAMDPROC __glewTessellationModeAMD; - -GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFERANGLEPROC __glewBlitFramebufferANGLE; - -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEANGLEPROC __glewRenderbufferStorageMultisampleANGLE; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDANGLEPROC __glewDrawArraysInstancedANGLE; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDANGLEPROC __glewDrawElementsInstancedANGLE; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBDIVISORANGLEPROC __glewVertexAttribDivisorANGLE; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYANGLEPROC __glewBeginQueryANGLE; -GLEW_FUN_EXPORT PFNGLDELETEQUERIESANGLEPROC __glewDeleteQueriesANGLE; -GLEW_FUN_EXPORT PFNGLENDQUERYANGLEPROC __glewEndQueryANGLE; -GLEW_FUN_EXPORT PFNGLGENQUERIESANGLEPROC __glewGenQueriesANGLE; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VANGLEPROC __glewGetQueryObjecti64vANGLE; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVANGLEPROC __glewGetQueryObjectivANGLE; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VANGLEPROC __glewGetQueryObjectui64vANGLE; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVANGLEPROC __glewGetQueryObjectuivANGLE; -GLEW_FUN_EXPORT PFNGLGETQUERYIVANGLEPROC __glewGetQueryivANGLE; -GLEW_FUN_EXPORT PFNGLISQUERYANGLEPROC __glewIsQueryANGLE; -GLEW_FUN_EXPORT PFNGLQUERYCOUNTERANGLEPROC __glewQueryCounterANGLE; - -GLEW_FUN_EXPORT PFNGLGETTRANSLATEDSHADERSOURCEANGLEPROC __glewGetTranslatedShaderSourceANGLE; - -GLEW_FUN_EXPORT PFNGLDRAWELEMENTARRAYAPPLEPROC __glewDrawElementArrayAPPLE; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC __glewDrawRangeElementArrayAPPLE; -GLEW_FUN_EXPORT PFNGLELEMENTPOINTERAPPLEPROC __glewElementPointerAPPLE; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC __glewMultiDrawElementArrayAPPLE; -GLEW_FUN_EXPORT PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC __glewMultiDrawRangeElementArrayAPPLE; - -GLEW_FUN_EXPORT PFNGLDELETEFENCESAPPLEPROC __glewDeleteFencesAPPLE; -GLEW_FUN_EXPORT PFNGLFINISHFENCEAPPLEPROC __glewFinishFenceAPPLE; -GLEW_FUN_EXPORT PFNGLFINISHOBJECTAPPLEPROC __glewFinishObjectAPPLE; -GLEW_FUN_EXPORT PFNGLGENFENCESAPPLEPROC __glewGenFencesAPPLE; -GLEW_FUN_EXPORT PFNGLISFENCEAPPLEPROC __glewIsFenceAPPLE; -GLEW_FUN_EXPORT PFNGLSETFENCEAPPLEPROC __glewSetFenceAPPLE; -GLEW_FUN_EXPORT PFNGLTESTFENCEAPPLEPROC __glewTestFenceAPPLE; -GLEW_FUN_EXPORT PFNGLTESTOBJECTAPPLEPROC __glewTestObjectAPPLE; - -GLEW_FUN_EXPORT PFNGLBUFFERPARAMETERIAPPLEPROC __glewBufferParameteriAPPLE; -GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC __glewFlushMappedBufferRangeAPPLE; - -GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERIVAPPLEPROC __glewGetObjectParameterivAPPLE; -GLEW_FUN_EXPORT PFNGLOBJECTPURGEABLEAPPLEPROC __glewObjectPurgeableAPPLE; -GLEW_FUN_EXPORT PFNGLOBJECTUNPURGEABLEAPPLEPROC __glewObjectUnpurgeableAPPLE; - -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC __glewGetTexParameterPointervAPPLE; -GLEW_FUN_EXPORT PFNGLTEXTURERANGEAPPLEPROC __glewTextureRangeAPPLE; - -GLEW_FUN_EXPORT PFNGLBINDVERTEXARRAYAPPLEPROC __glewBindVertexArrayAPPLE; -GLEW_FUN_EXPORT PFNGLDELETEVERTEXARRAYSAPPLEPROC __glewDeleteVertexArraysAPPLE; -GLEW_FUN_EXPORT PFNGLGENVERTEXARRAYSAPPLEPROC __glewGenVertexArraysAPPLE; -GLEW_FUN_EXPORT PFNGLISVERTEXARRAYAPPLEPROC __glewIsVertexArrayAPPLE; - -GLEW_FUN_EXPORT PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC __glewFlushVertexArrayRangeAPPLE; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYPARAMETERIAPPLEPROC __glewVertexArrayParameteriAPPLE; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYRANGEAPPLEPROC __glewVertexArrayRangeAPPLE; - -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBAPPLEPROC __glewDisableVertexAttribAPPLE; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBAPPLEPROC __glewEnableVertexAttribAPPLE; -GLEW_FUN_EXPORT PFNGLISVERTEXATTRIBENABLEDAPPLEPROC __glewIsVertexAttribEnabledAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB1DAPPLEPROC __glewMapVertexAttrib1dAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB1FAPPLEPROC __glewMapVertexAttrib1fAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB2DAPPLEPROC __glewMapVertexAttrib2dAPPLE; -GLEW_FUN_EXPORT PFNGLMAPVERTEXATTRIB2FAPPLEPROC __glewMapVertexAttrib2fAPPLE; - -GLEW_FUN_EXPORT PFNGLCLEARDEPTHFPROC __glewClearDepthf; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEFPROC __glewDepthRangef; -GLEW_FUN_EXPORT PFNGLGETSHADERPRECISIONFORMATPROC __glewGetShaderPrecisionFormat; -GLEW_FUN_EXPORT PFNGLRELEASESHADERCOMPILERPROC __glewReleaseShaderCompiler; -GLEW_FUN_EXPORT PFNGLSHADERBINARYPROC __glewShaderBinary; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDBASEINSTANCEPROC __glewDrawArraysInstancedBaseInstance; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDBASEINSTANCEPROC __glewDrawElementsInstancedBaseInstance; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXBASEINSTANCEPROC __glewDrawElementsInstancedBaseVertexBaseInstance; - -GLEW_FUN_EXPORT PFNGLGETIMAGEHANDLEARBPROC __glewGetImageHandleARB; -GLEW_FUN_EXPORT PFNGLGETTEXTUREHANDLEARBPROC __glewGetTextureHandleARB; -GLEW_FUN_EXPORT PFNGLGETTEXTURESAMPLERHANDLEARBPROC __glewGetTextureSamplerHandleARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLUI64VARBPROC __glewGetVertexAttribLui64vARB; -GLEW_FUN_EXPORT PFNGLISIMAGEHANDLERESIDENTARBPROC __glewIsImageHandleResidentARB; -GLEW_FUN_EXPORT PFNGLISTEXTUREHANDLERESIDENTARBPROC __glewIsTextureHandleResidentARB; -GLEW_FUN_EXPORT PFNGLMAKEIMAGEHANDLENONRESIDENTARBPROC __glewMakeImageHandleNonResidentARB; -GLEW_FUN_EXPORT PFNGLMAKEIMAGEHANDLERESIDENTARBPROC __glewMakeImageHandleResidentARB; -GLEW_FUN_EXPORT PFNGLMAKETEXTUREHANDLENONRESIDENTARBPROC __glewMakeTextureHandleNonResidentARB; -GLEW_FUN_EXPORT PFNGLMAKETEXTUREHANDLERESIDENTARBPROC __glewMakeTextureHandleResidentARB; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMHANDLEUI64ARBPROC __glewProgramUniformHandleui64ARB; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMHANDLEUI64VARBPROC __glewProgramUniformHandleui64vARB; -GLEW_FUN_EXPORT PFNGLUNIFORMHANDLEUI64ARBPROC __glewUniformHandleui64ARB; -GLEW_FUN_EXPORT PFNGLUNIFORMHANDLEUI64VARBPROC __glewUniformHandleui64vARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64ARBPROC __glewVertexAttribL1ui64ARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64VARBPROC __glewVertexAttribL1ui64vARB; - -GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONINDEXEDPROC __glewBindFragDataLocationIndexed; -GLEW_FUN_EXPORT PFNGLGETFRAGDATAINDEXPROC __glewGetFragDataIndex; - -GLEW_FUN_EXPORT PFNGLBUFFERSTORAGEPROC __glewBufferStorage; -GLEW_FUN_EXPORT PFNGLNAMEDBUFFERSTORAGEEXTPROC __glewNamedBufferStorageEXT; - -GLEW_FUN_EXPORT PFNGLCREATESYNCFROMCLEVENTARBPROC __glewCreateSyncFromCLeventARB; - -GLEW_FUN_EXPORT PFNGLCLEARBUFFERDATAPROC __glewClearBufferData; -GLEW_FUN_EXPORT PFNGLCLEARBUFFERSUBDATAPROC __glewClearBufferSubData; -GLEW_FUN_EXPORT PFNGLCLEARNAMEDBUFFERDATAEXTPROC __glewClearNamedBufferDataEXT; -GLEW_FUN_EXPORT PFNGLCLEARNAMEDBUFFERSUBDATAEXTPROC __glewClearNamedBufferSubDataEXT; - -GLEW_FUN_EXPORT PFNGLCLEARTEXIMAGEPROC __glewClearTexImage; -GLEW_FUN_EXPORT PFNGLCLEARTEXSUBIMAGEPROC __glewClearTexSubImage; - -GLEW_FUN_EXPORT PFNGLCLAMPCOLORARBPROC __glewClampColorARB; - -GLEW_FUN_EXPORT PFNGLDISPATCHCOMPUTEPROC __glewDispatchCompute; -GLEW_FUN_EXPORT PFNGLDISPATCHCOMPUTEINDIRECTPROC __glewDispatchComputeIndirect; - -GLEW_FUN_EXPORT PFNGLDISPATCHCOMPUTEGROUPSIZEARBPROC __glewDispatchComputeGroupSizeARB; - -GLEW_FUN_EXPORT PFNGLCOPYBUFFERSUBDATAPROC __glewCopyBufferSubData; - -GLEW_FUN_EXPORT PFNGLCOPYIMAGESUBDATAPROC __glewCopyImageSubData; - -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECALLBACKARBPROC __glewDebugMessageCallbackARB; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECONTROLARBPROC __glewDebugMessageControlARB; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEINSERTARBPROC __glewDebugMessageInsertARB; -GLEW_FUN_EXPORT PFNGLGETDEBUGMESSAGELOGARBPROC __glewGetDebugMessageLogARB; - -GLEW_FUN_EXPORT PFNGLDRAWBUFFERSARBPROC __glewDrawBuffersARB; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEIARBPROC __glewBlendEquationSeparateiARB; -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONIARBPROC __glewBlendEquationiARB; -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEIARBPROC __glewBlendFuncSeparateiARB; -GLEW_FUN_EXPORT PFNGLBLENDFUNCIARBPROC __glewBlendFunciARB; - -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSBASEVERTEXPROC __glewDrawElementsBaseVertex; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC __glewDrawElementsInstancedBaseVertex; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC __glewDrawRangeElementsBaseVertex; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC __glewMultiDrawElementsBaseVertex; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINDIRECTPROC __glewDrawArraysIndirect; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINDIRECTPROC __glewDrawElementsIndirect; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERPARAMETERIPROC __glewFramebufferParameteri; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERPARAMETERIVPROC __glewGetFramebufferParameteriv; -GLEW_FUN_EXPORT PFNGLGETNAMEDFRAMEBUFFERPARAMETERIVEXTPROC __glewGetNamedFramebufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERPARAMETERIEXTPROC __glewNamedFramebufferParameteriEXT; - -GLEW_FUN_EXPORT PFNGLBINDFRAMEBUFFERPROC __glewBindFramebuffer; -GLEW_FUN_EXPORT PFNGLBINDRENDERBUFFERPROC __glewBindRenderbuffer; -GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFERPROC __glewBlitFramebuffer; -GLEW_FUN_EXPORT PFNGLCHECKFRAMEBUFFERSTATUSPROC __glewCheckFramebufferStatus; -GLEW_FUN_EXPORT PFNGLDELETEFRAMEBUFFERSPROC __glewDeleteFramebuffers; -GLEW_FUN_EXPORT PFNGLDELETERENDERBUFFERSPROC __glewDeleteRenderbuffers; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERRENDERBUFFERPROC __glewFramebufferRenderbuffer; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE1DPROC __glewFramebufferTexture1D; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE2DPROC __glewFramebufferTexture2D; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE3DPROC __glewFramebufferTexture3D; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYERPROC __glewFramebufferTextureLayer; -GLEW_FUN_EXPORT PFNGLGENFRAMEBUFFERSPROC __glewGenFramebuffers; -GLEW_FUN_EXPORT PFNGLGENRENDERBUFFERSPROC __glewGenRenderbuffers; -GLEW_FUN_EXPORT PFNGLGENERATEMIPMAPPROC __glewGenerateMipmap; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC __glewGetFramebufferAttachmentParameteriv; -GLEW_FUN_EXPORT PFNGLGETRENDERBUFFERPARAMETERIVPROC __glewGetRenderbufferParameteriv; -GLEW_FUN_EXPORT PFNGLISFRAMEBUFFERPROC __glewIsFramebuffer; -GLEW_FUN_EXPORT PFNGLISRENDERBUFFERPROC __glewIsRenderbuffer; -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEPROC __glewRenderbufferStorage; -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC __glewRenderbufferStorageMultisample; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREARBPROC __glewFramebufferTextureARB; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREFACEARBPROC __glewFramebufferTextureFaceARB; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYERARBPROC __glewFramebufferTextureLayerARB; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIARBPROC __glewProgramParameteriARB; - -GLEW_FUN_EXPORT PFNGLGETPROGRAMBINARYPROC __glewGetProgramBinary; -GLEW_FUN_EXPORT PFNGLPROGRAMBINARYPROC __glewProgramBinary; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIPROC __glewProgramParameteri; - -GLEW_FUN_EXPORT PFNGLGETUNIFORMDVPROC __glewGetUniformdv; -GLEW_FUN_EXPORT PFNGLUNIFORM1DPROC __glewUniform1d; -GLEW_FUN_EXPORT PFNGLUNIFORM1DVPROC __glewUniform1dv; -GLEW_FUN_EXPORT PFNGLUNIFORM2DPROC __glewUniform2d; -GLEW_FUN_EXPORT PFNGLUNIFORM2DVPROC __glewUniform2dv; -GLEW_FUN_EXPORT PFNGLUNIFORM3DPROC __glewUniform3d; -GLEW_FUN_EXPORT PFNGLUNIFORM3DVPROC __glewUniform3dv; -GLEW_FUN_EXPORT PFNGLUNIFORM4DPROC __glewUniform4d; -GLEW_FUN_EXPORT PFNGLUNIFORM4DVPROC __glewUniform4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2DVPROC __glewUniformMatrix2dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X3DVPROC __glewUniformMatrix2x3dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2X4DVPROC __glewUniformMatrix2x4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3DVPROC __glewUniformMatrix3dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X2DVPROC __glewUniformMatrix3x2dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3X4DVPROC __glewUniformMatrix3x4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4DVPROC __glewUniformMatrix4dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X2DVPROC __glewUniformMatrix4x2dv; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4X3DVPROC __glewUniformMatrix4x3dv; - -GLEW_FUN_EXPORT PFNGLCOLORSUBTABLEPROC __glewColorSubTable; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPROC __glewColorTable; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERFVPROC __glewColorTableParameterfv; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERIVPROC __glewColorTableParameteriv; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER1DPROC __glewConvolutionFilter1D; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER2DPROC __glewConvolutionFilter2D; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFPROC __glewConvolutionParameterf; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFVPROC __glewConvolutionParameterfv; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIPROC __glewConvolutionParameteri; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIVPROC __glewConvolutionParameteriv; -GLEW_FUN_EXPORT PFNGLCOPYCOLORSUBTABLEPROC __glewCopyColorSubTable; -GLEW_FUN_EXPORT PFNGLCOPYCOLORTABLEPROC __glewCopyColorTable; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER1DPROC __glewCopyConvolutionFilter1D; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER2DPROC __glewCopyConvolutionFilter2D; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPROC __glewGetColorTable; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVPROC __glewGetColorTableParameterfv; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVPROC __glewGetColorTableParameteriv; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONFILTERPROC __glewGetConvolutionFilter; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERFVPROC __glewGetConvolutionParameterfv; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERIVPROC __glewGetConvolutionParameteriv; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPROC __glewGetHistogram; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERFVPROC __glewGetHistogramParameterfv; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERIVPROC __glewGetHistogramParameteriv; -GLEW_FUN_EXPORT PFNGLGETMINMAXPROC __glewGetMinmax; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERFVPROC __glewGetMinmaxParameterfv; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERIVPROC __glewGetMinmaxParameteriv; -GLEW_FUN_EXPORT PFNGLGETSEPARABLEFILTERPROC __glewGetSeparableFilter; -GLEW_FUN_EXPORT PFNGLHISTOGRAMPROC __glewHistogram; -GLEW_FUN_EXPORT PFNGLMINMAXPROC __glewMinmax; -GLEW_FUN_EXPORT PFNGLRESETHISTOGRAMPROC __glewResetHistogram; -GLEW_FUN_EXPORT PFNGLRESETMINMAXPROC __glewResetMinmax; -GLEW_FUN_EXPORT PFNGLSEPARABLEFILTER2DPROC __glewSeparableFilter2D; - -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSINDIRECTCOUNTARBPROC __glewMultiDrawArraysIndirectCountARB; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTARBPROC __glewMultiDrawElementsIndirectCountARB; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDARBPROC __glewDrawArraysInstancedARB; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDARBPROC __glewDrawElementsInstancedARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBDIVISORARBPROC __glewVertexAttribDivisorARB; - -GLEW_FUN_EXPORT PFNGLGETINTERNALFORMATIVPROC __glewGetInternalformativ; - -GLEW_FUN_EXPORT PFNGLGETINTERNALFORMATI64VPROC __glewGetInternalformati64v; - -GLEW_FUN_EXPORT PFNGLINVALIDATEBUFFERDATAPROC __glewInvalidateBufferData; -GLEW_FUN_EXPORT PFNGLINVALIDATEBUFFERSUBDATAPROC __glewInvalidateBufferSubData; -GLEW_FUN_EXPORT PFNGLINVALIDATEFRAMEBUFFERPROC __glewInvalidateFramebuffer; -GLEW_FUN_EXPORT PFNGLINVALIDATESUBFRAMEBUFFERPROC __glewInvalidateSubFramebuffer; -GLEW_FUN_EXPORT PFNGLINVALIDATETEXIMAGEPROC __glewInvalidateTexImage; -GLEW_FUN_EXPORT PFNGLINVALIDATETEXSUBIMAGEPROC __glewInvalidateTexSubImage; - -GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDBUFFERRANGEPROC __glewFlushMappedBufferRange; -GLEW_FUN_EXPORT PFNGLMAPBUFFERRANGEPROC __glewMapBufferRange; - -GLEW_FUN_EXPORT PFNGLCURRENTPALETTEMATRIXARBPROC __glewCurrentPaletteMatrixARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXPOINTERARBPROC __glewMatrixIndexPointerARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXUBVARBPROC __glewMatrixIndexubvARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXUIVARBPROC __glewMatrixIndexuivARB; -GLEW_FUN_EXPORT PFNGLMATRIXINDEXUSVARBPROC __glewMatrixIndexusvARB; - -GLEW_FUN_EXPORT PFNGLBINDBUFFERSBASEPROC __glewBindBuffersBase; -GLEW_FUN_EXPORT PFNGLBINDBUFFERSRANGEPROC __glewBindBuffersRange; -GLEW_FUN_EXPORT PFNGLBINDIMAGETEXTURESPROC __glewBindImageTextures; -GLEW_FUN_EXPORT PFNGLBINDSAMPLERSPROC __glewBindSamplers; -GLEW_FUN_EXPORT PFNGLBINDTEXTURESPROC __glewBindTextures; -GLEW_FUN_EXPORT PFNGLBINDVERTEXBUFFERSPROC __glewBindVertexBuffers; - -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSINDIRECTPROC __glewMultiDrawArraysIndirect; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSINDIRECTPROC __glewMultiDrawElementsIndirect; - -GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEARBPROC __glewSampleCoverageARB; - -GLEW_FUN_EXPORT PFNGLACTIVETEXTUREARBPROC __glewActiveTextureARB; -GLEW_FUN_EXPORT PFNGLCLIENTACTIVETEXTUREARBPROC __glewClientActiveTextureARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DARBPROC __glewMultiTexCoord1dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1DVARBPROC __glewMultiTexCoord1dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FARBPROC __glewMultiTexCoord1fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1FVARBPROC __glewMultiTexCoord1fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IARBPROC __glewMultiTexCoord1iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1IVARBPROC __glewMultiTexCoord1ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SARBPROC __glewMultiTexCoord1sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1SVARBPROC __glewMultiTexCoord1svARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DARBPROC __glewMultiTexCoord2dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2DVARBPROC __glewMultiTexCoord2dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FARBPROC __glewMultiTexCoord2fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2FVARBPROC __glewMultiTexCoord2fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IARBPROC __glewMultiTexCoord2iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2IVARBPROC __glewMultiTexCoord2ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SARBPROC __glewMultiTexCoord2sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2SVARBPROC __glewMultiTexCoord2svARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DARBPROC __glewMultiTexCoord3dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3DVARBPROC __glewMultiTexCoord3dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FARBPROC __glewMultiTexCoord3fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3FVARBPROC __glewMultiTexCoord3fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IARBPROC __glewMultiTexCoord3iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3IVARBPROC __glewMultiTexCoord3ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SARBPROC __glewMultiTexCoord3sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3SVARBPROC __glewMultiTexCoord3svARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DARBPROC __glewMultiTexCoord4dARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4DVARBPROC __glewMultiTexCoord4dvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FARBPROC __glewMultiTexCoord4fARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4FVARBPROC __glewMultiTexCoord4fvARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IARBPROC __glewMultiTexCoord4iARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4IVARBPROC __glewMultiTexCoord4ivARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SARBPROC __glewMultiTexCoord4sARB; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4SVARBPROC __glewMultiTexCoord4svARB; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYARBPROC __glewBeginQueryARB; -GLEW_FUN_EXPORT PFNGLDELETEQUERIESARBPROC __glewDeleteQueriesARB; -GLEW_FUN_EXPORT PFNGLENDQUERYARBPROC __glewEndQueryARB; -GLEW_FUN_EXPORT PFNGLGENQUERIESARBPROC __glewGenQueriesARB; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTIVARBPROC __glewGetQueryObjectivARB; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUIVARBPROC __glewGetQueryObjectuivARB; -GLEW_FUN_EXPORT PFNGLGETQUERYIVARBPROC __glewGetQueryivARB; -GLEW_FUN_EXPORT PFNGLISQUERYARBPROC __glewIsQueryARB; - -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFARBPROC __glewPointParameterfARB; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVARBPROC __glewPointParameterfvARB; - -GLEW_FUN_EXPORT PFNGLGETPROGRAMINTERFACEIVPROC __glewGetProgramInterfaceiv; -GLEW_FUN_EXPORT PFNGLGETPROGRAMRESOURCEINDEXPROC __glewGetProgramResourceIndex; -GLEW_FUN_EXPORT PFNGLGETPROGRAMRESOURCELOCATIONPROC __glewGetProgramResourceLocation; -GLEW_FUN_EXPORT PFNGLGETPROGRAMRESOURCELOCATIONINDEXPROC __glewGetProgramResourceLocationIndex; -GLEW_FUN_EXPORT PFNGLGETPROGRAMRESOURCENAMEPROC __glewGetProgramResourceName; -GLEW_FUN_EXPORT PFNGLGETPROGRAMRESOURCEIVPROC __glewGetProgramResourceiv; - -GLEW_FUN_EXPORT PFNGLPROVOKINGVERTEXPROC __glewProvokingVertex; - -GLEW_FUN_EXPORT PFNGLGETGRAPHICSRESETSTATUSARBPROC __glewGetGraphicsResetStatusARB; -GLEW_FUN_EXPORT PFNGLGETNCOLORTABLEARBPROC __glewGetnColorTableARB; -GLEW_FUN_EXPORT PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC __glewGetnCompressedTexImageARB; -GLEW_FUN_EXPORT PFNGLGETNCONVOLUTIONFILTERARBPROC __glewGetnConvolutionFilterARB; -GLEW_FUN_EXPORT PFNGLGETNHISTOGRAMARBPROC __glewGetnHistogramARB; -GLEW_FUN_EXPORT PFNGLGETNMAPDVARBPROC __glewGetnMapdvARB; -GLEW_FUN_EXPORT PFNGLGETNMAPFVARBPROC __glewGetnMapfvARB; -GLEW_FUN_EXPORT PFNGLGETNMAPIVARBPROC __glewGetnMapivARB; -GLEW_FUN_EXPORT PFNGLGETNMINMAXARBPROC __glewGetnMinmaxARB; -GLEW_FUN_EXPORT PFNGLGETNPIXELMAPFVARBPROC __glewGetnPixelMapfvARB; -GLEW_FUN_EXPORT PFNGLGETNPIXELMAPUIVARBPROC __glewGetnPixelMapuivARB; -GLEW_FUN_EXPORT PFNGLGETNPIXELMAPUSVARBPROC __glewGetnPixelMapusvARB; -GLEW_FUN_EXPORT PFNGLGETNPOLYGONSTIPPLEARBPROC __glewGetnPolygonStippleARB; -GLEW_FUN_EXPORT PFNGLGETNSEPARABLEFILTERARBPROC __glewGetnSeparableFilterARB; -GLEW_FUN_EXPORT PFNGLGETNTEXIMAGEARBPROC __glewGetnTexImageARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMDVARBPROC __glewGetnUniformdvARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMFVARBPROC __glewGetnUniformfvARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMIVARBPROC __glewGetnUniformivARB; -GLEW_FUN_EXPORT PFNGLGETNUNIFORMUIVARBPROC __glewGetnUniformuivARB; -GLEW_FUN_EXPORT PFNGLREADNPIXELSARBPROC __glewReadnPixelsARB; - -GLEW_FUN_EXPORT PFNGLMINSAMPLESHADINGARBPROC __glewMinSampleShadingARB; - -GLEW_FUN_EXPORT PFNGLBINDSAMPLERPROC __glewBindSampler; -GLEW_FUN_EXPORT PFNGLDELETESAMPLERSPROC __glewDeleteSamplers; -GLEW_FUN_EXPORT PFNGLGENSAMPLERSPROC __glewGenSamplers; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIIVPROC __glewGetSamplerParameterIiv; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIUIVPROC __glewGetSamplerParameterIuiv; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERFVPROC __glewGetSamplerParameterfv; -GLEW_FUN_EXPORT PFNGLGETSAMPLERPARAMETERIVPROC __glewGetSamplerParameteriv; -GLEW_FUN_EXPORT PFNGLISSAMPLERPROC __glewIsSampler; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIIVPROC __glewSamplerParameterIiv; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIUIVPROC __glewSamplerParameterIuiv; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERFPROC __glewSamplerParameterf; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERFVPROC __glewSamplerParameterfv; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIPROC __glewSamplerParameteri; -GLEW_FUN_EXPORT PFNGLSAMPLERPARAMETERIVPROC __glewSamplerParameteriv; - -GLEW_FUN_EXPORT PFNGLACTIVESHADERPROGRAMPROC __glewActiveShaderProgram; -GLEW_FUN_EXPORT PFNGLBINDPROGRAMPIPELINEPROC __glewBindProgramPipeline; -GLEW_FUN_EXPORT PFNGLCREATESHADERPROGRAMVPROC __glewCreateShaderProgramv; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMPIPELINESPROC __glewDeleteProgramPipelines; -GLEW_FUN_EXPORT PFNGLGENPROGRAMPIPELINESPROC __glewGenProgramPipelines; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPIPELINEINFOLOGPROC __glewGetProgramPipelineInfoLog; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPIPELINEIVPROC __glewGetProgramPipelineiv; -GLEW_FUN_EXPORT PFNGLISPROGRAMPIPELINEPROC __glewIsProgramPipeline; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1DPROC __glewProgramUniform1d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1DVPROC __glewProgramUniform1dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FPROC __glewProgramUniform1f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FVPROC __glewProgramUniform1fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IPROC __glewProgramUniform1i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IVPROC __glewProgramUniform1iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIPROC __glewProgramUniform1ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIVPROC __glewProgramUniform1uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2DPROC __glewProgramUniform2d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2DVPROC __glewProgramUniform2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FPROC __glewProgramUniform2f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FVPROC __glewProgramUniform2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IPROC __glewProgramUniform2i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IVPROC __glewProgramUniform2iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIPROC __glewProgramUniform2ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIVPROC __glewProgramUniform2uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3DPROC __glewProgramUniform3d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3DVPROC __glewProgramUniform3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FPROC __glewProgramUniform3f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FVPROC __glewProgramUniform3fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IPROC __glewProgramUniform3i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IVPROC __glewProgramUniform3iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIPROC __glewProgramUniform3ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIVPROC __glewProgramUniform3uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4DPROC __glewProgramUniform4d; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4DVPROC __glewProgramUniform4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FPROC __glewProgramUniform4f; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FVPROC __glewProgramUniform4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IPROC __glewProgramUniform4i; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IVPROC __glewProgramUniform4iv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIPROC __glewProgramUniform4ui; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIVPROC __glewProgramUniform4uiv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2DVPROC __glewProgramUniformMatrix2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2FVPROC __glewProgramUniformMatrix2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC __glewProgramUniformMatrix2x3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC __glewProgramUniformMatrix2x3fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC __glewProgramUniformMatrix2x4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC __glewProgramUniformMatrix2x4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3DVPROC __glewProgramUniformMatrix3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3FVPROC __glewProgramUniformMatrix3fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC __glewProgramUniformMatrix3x2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC __glewProgramUniformMatrix3x2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC __glewProgramUniformMatrix3x4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC __glewProgramUniformMatrix3x4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4DVPROC __glewProgramUniformMatrix4dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4FVPROC __glewProgramUniformMatrix4fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC __glewProgramUniformMatrix4x2dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC __glewProgramUniformMatrix4x2fv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC __glewProgramUniformMatrix4x3dv; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC __glewProgramUniformMatrix4x3fv; -GLEW_FUN_EXPORT PFNGLUSEPROGRAMSTAGESPROC __glewUseProgramStages; -GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMPIPELINEPROC __glewValidateProgramPipeline; - -GLEW_FUN_EXPORT PFNGLGETACTIVEATOMICCOUNTERBUFFERIVPROC __glewGetActiveAtomicCounterBufferiv; - -GLEW_FUN_EXPORT PFNGLBINDIMAGETEXTUREPROC __glewBindImageTexture; -GLEW_FUN_EXPORT PFNGLMEMORYBARRIERPROC __glewMemoryBarrier; - -GLEW_FUN_EXPORT PFNGLATTACHOBJECTARBPROC __glewAttachObjectARB; -GLEW_FUN_EXPORT PFNGLCOMPILESHADERARBPROC __glewCompileShaderARB; -GLEW_FUN_EXPORT PFNGLCREATEPROGRAMOBJECTARBPROC __glewCreateProgramObjectARB; -GLEW_FUN_EXPORT PFNGLCREATESHADEROBJECTARBPROC __glewCreateShaderObjectARB; -GLEW_FUN_EXPORT PFNGLDELETEOBJECTARBPROC __glewDeleteObjectARB; -GLEW_FUN_EXPORT PFNGLDETACHOBJECTARBPROC __glewDetachObjectARB; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMARBPROC __glewGetActiveUniformARB; -GLEW_FUN_EXPORT PFNGLGETATTACHEDOBJECTSARBPROC __glewGetAttachedObjectsARB; -GLEW_FUN_EXPORT PFNGLGETHANDLEARBPROC __glewGetHandleARB; -GLEW_FUN_EXPORT PFNGLGETINFOLOGARBPROC __glewGetInfoLogARB; -GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERFVARBPROC __glewGetObjectParameterfvARB; -GLEW_FUN_EXPORT PFNGLGETOBJECTPARAMETERIVARBPROC __glewGetObjectParameterivARB; -GLEW_FUN_EXPORT PFNGLGETSHADERSOURCEARBPROC __glewGetShaderSourceARB; -GLEW_FUN_EXPORT PFNGLGETUNIFORMLOCATIONARBPROC __glewGetUniformLocationARB; -GLEW_FUN_EXPORT PFNGLGETUNIFORMFVARBPROC __glewGetUniformfvARB; -GLEW_FUN_EXPORT PFNGLGETUNIFORMIVARBPROC __glewGetUniformivARB; -GLEW_FUN_EXPORT PFNGLLINKPROGRAMARBPROC __glewLinkProgramARB; -GLEW_FUN_EXPORT PFNGLSHADERSOURCEARBPROC __glewShaderSourceARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1FARBPROC __glewUniform1fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1FVARBPROC __glewUniform1fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1IARBPROC __glewUniform1iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM1IVARBPROC __glewUniform1ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2FARBPROC __glewUniform2fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2FVARBPROC __glewUniform2fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2IARBPROC __glewUniform2iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM2IVARBPROC __glewUniform2ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3FARBPROC __glewUniform3fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3FVARBPROC __glewUniform3fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3IARBPROC __glewUniform3iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM3IVARBPROC __glewUniform3ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4FARBPROC __glewUniform4fARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4FVARBPROC __glewUniform4fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4IARBPROC __glewUniform4iARB; -GLEW_FUN_EXPORT PFNGLUNIFORM4IVARBPROC __glewUniform4ivARB; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX2FVARBPROC __glewUniformMatrix2fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX3FVARBPROC __glewUniformMatrix3fvARB; -GLEW_FUN_EXPORT PFNGLUNIFORMMATRIX4FVARBPROC __glewUniformMatrix4fvARB; -GLEW_FUN_EXPORT PFNGLUSEPROGRAMOBJECTARBPROC __glewUseProgramObjectARB; -GLEW_FUN_EXPORT PFNGLVALIDATEPROGRAMARBPROC __glewValidateProgramARB; - -GLEW_FUN_EXPORT PFNGLSHADERSTORAGEBLOCKBINDINGPROC __glewShaderStorageBlockBinding; - -GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINENAMEPROC __glewGetActiveSubroutineName; -GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC __glewGetActiveSubroutineUniformName; -GLEW_FUN_EXPORT PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC __glewGetActiveSubroutineUniformiv; -GLEW_FUN_EXPORT PFNGLGETPROGRAMSTAGEIVPROC __glewGetProgramStageiv; -GLEW_FUN_EXPORT PFNGLGETSUBROUTINEINDEXPROC __glewGetSubroutineIndex; -GLEW_FUN_EXPORT PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC __glewGetSubroutineUniformLocation; -GLEW_FUN_EXPORT PFNGLGETUNIFORMSUBROUTINEUIVPROC __glewGetUniformSubroutineuiv; -GLEW_FUN_EXPORT PFNGLUNIFORMSUBROUTINESUIVPROC __glewUniformSubroutinesuiv; - -GLEW_FUN_EXPORT PFNGLCOMPILESHADERINCLUDEARBPROC __glewCompileShaderIncludeARB; -GLEW_FUN_EXPORT PFNGLDELETENAMEDSTRINGARBPROC __glewDeleteNamedStringARB; -GLEW_FUN_EXPORT PFNGLGETNAMEDSTRINGARBPROC __glewGetNamedStringARB; -GLEW_FUN_EXPORT PFNGLGETNAMEDSTRINGIVARBPROC __glewGetNamedStringivARB; -GLEW_FUN_EXPORT PFNGLISNAMEDSTRINGARBPROC __glewIsNamedStringARB; -GLEW_FUN_EXPORT PFNGLNAMEDSTRINGARBPROC __glewNamedStringARB; - -GLEW_FUN_EXPORT PFNGLTEXPAGECOMMITMENTARBPROC __glewTexPageCommitmentARB; -GLEW_FUN_EXPORT PFNGLTEXTUREPAGECOMMITMENTEXTPROC __glewTexturePageCommitmentEXT; - -GLEW_FUN_EXPORT PFNGLCLIENTWAITSYNCPROC __glewClientWaitSync; -GLEW_FUN_EXPORT PFNGLDELETESYNCPROC __glewDeleteSync; -GLEW_FUN_EXPORT PFNGLFENCESYNCPROC __glewFenceSync; -GLEW_FUN_EXPORT PFNGLGETINTEGER64VPROC __glewGetInteger64v; -GLEW_FUN_EXPORT PFNGLGETSYNCIVPROC __glewGetSynciv; -GLEW_FUN_EXPORT PFNGLISSYNCPROC __glewIsSync; -GLEW_FUN_EXPORT PFNGLWAITSYNCPROC __glewWaitSync; - -GLEW_FUN_EXPORT PFNGLPATCHPARAMETERFVPROC __glewPatchParameterfv; -GLEW_FUN_EXPORT PFNGLPATCHPARAMETERIPROC __glewPatchParameteri; - -GLEW_FUN_EXPORT PFNGLTEXBUFFERARBPROC __glewTexBufferARB; - -GLEW_FUN_EXPORT PFNGLTEXBUFFERRANGEPROC __glewTexBufferRange; -GLEW_FUN_EXPORT PFNGLTEXTUREBUFFERRANGEEXTPROC __glewTextureBufferRangeEXT; - -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE1DARBPROC __glewCompressedTexImage1DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE2DARBPROC __glewCompressedTexImage2DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXIMAGE3DARBPROC __glewCompressedTexImage3DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC __glewCompressedTexSubImage1DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC __glewCompressedTexSubImage2DARB; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC __glewCompressedTexSubImage3DARB; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXIMAGEARBPROC __glewGetCompressedTexImageARB; - -GLEW_FUN_EXPORT PFNGLGETMULTISAMPLEFVPROC __glewGetMultisamplefv; -GLEW_FUN_EXPORT PFNGLSAMPLEMASKIPROC __glewSampleMaski; -GLEW_FUN_EXPORT PFNGLTEXIMAGE2DMULTISAMPLEPROC __glewTexImage2DMultisample; -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DMULTISAMPLEPROC __glewTexImage3DMultisample; - -GLEW_FUN_EXPORT PFNGLTEXSTORAGE1DPROC __glewTexStorage1D; -GLEW_FUN_EXPORT PFNGLTEXSTORAGE2DPROC __glewTexStorage2D; -GLEW_FUN_EXPORT PFNGLTEXSTORAGE3DPROC __glewTexStorage3D; -GLEW_FUN_EXPORT PFNGLTEXTURESTORAGE1DEXTPROC __glewTextureStorage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESTORAGE2DEXTPROC __glewTextureStorage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESTORAGE3DEXTPROC __glewTextureStorage3DEXT; - -GLEW_FUN_EXPORT PFNGLTEXSTORAGE2DMULTISAMPLEPROC __glewTexStorage2DMultisample; -GLEW_FUN_EXPORT PFNGLTEXSTORAGE3DMULTISAMPLEPROC __glewTexStorage3DMultisample; -GLEW_FUN_EXPORT PFNGLTEXTURESTORAGE2DMULTISAMPLEEXTPROC __glewTextureStorage2DMultisampleEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESTORAGE3DMULTISAMPLEEXTPROC __glewTextureStorage3DMultisampleEXT; - -GLEW_FUN_EXPORT PFNGLTEXTUREVIEWPROC __glewTextureView; - -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VPROC __glewGetQueryObjecti64v; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VPROC __glewGetQueryObjectui64v; -GLEW_FUN_EXPORT PFNGLQUERYCOUNTERPROC __glewQueryCounter; - -GLEW_FUN_EXPORT PFNGLBINDTRANSFORMFEEDBACKPROC __glewBindTransformFeedback; -GLEW_FUN_EXPORT PFNGLDELETETRANSFORMFEEDBACKSPROC __glewDeleteTransformFeedbacks; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKPROC __glewDrawTransformFeedback; -GLEW_FUN_EXPORT PFNGLGENTRANSFORMFEEDBACKSPROC __glewGenTransformFeedbacks; -GLEW_FUN_EXPORT PFNGLISTRANSFORMFEEDBACKPROC __glewIsTransformFeedback; -GLEW_FUN_EXPORT PFNGLPAUSETRANSFORMFEEDBACKPROC __glewPauseTransformFeedback; -GLEW_FUN_EXPORT PFNGLRESUMETRANSFORMFEEDBACKPROC __glewResumeTransformFeedback; - -GLEW_FUN_EXPORT PFNGLBEGINQUERYINDEXEDPROC __glewBeginQueryIndexed; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC __glewDrawTransformFeedbackStream; -GLEW_FUN_EXPORT PFNGLENDQUERYINDEXEDPROC __glewEndQueryIndexed; -GLEW_FUN_EXPORT PFNGLGETQUERYINDEXEDIVPROC __glewGetQueryIndexediv; - -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKINSTANCEDPROC __glewDrawTransformFeedbackInstanced; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKSTREAMINSTANCEDPROC __glewDrawTransformFeedbackStreamInstanced; - -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXDARBPROC __glewLoadTransposeMatrixdARB; -GLEW_FUN_EXPORT PFNGLLOADTRANSPOSEMATRIXFARBPROC __glewLoadTransposeMatrixfARB; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXDARBPROC __glewMultTransposeMatrixdARB; -GLEW_FUN_EXPORT PFNGLMULTTRANSPOSEMATRIXFARBPROC __glewMultTransposeMatrixfARB; - -GLEW_FUN_EXPORT PFNGLBINDBUFFERBASEPROC __glewBindBufferBase; -GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGEPROC __glewBindBufferRange; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC __glewGetActiveUniformBlockName; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMBLOCKIVPROC __glewGetActiveUniformBlockiv; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMNAMEPROC __glewGetActiveUniformName; -GLEW_FUN_EXPORT PFNGLGETACTIVEUNIFORMSIVPROC __glewGetActiveUniformsiv; -GLEW_FUN_EXPORT PFNGLGETINTEGERI_VPROC __glewGetIntegeri_v; -GLEW_FUN_EXPORT PFNGLGETUNIFORMBLOCKINDEXPROC __glewGetUniformBlockIndex; -GLEW_FUN_EXPORT PFNGLGETUNIFORMINDICESPROC __glewGetUniformIndices; -GLEW_FUN_EXPORT PFNGLUNIFORMBLOCKBINDINGPROC __glewUniformBlockBinding; - -GLEW_FUN_EXPORT PFNGLBINDVERTEXARRAYPROC __glewBindVertexArray; -GLEW_FUN_EXPORT PFNGLDELETEVERTEXARRAYSPROC __glewDeleteVertexArrays; -GLEW_FUN_EXPORT PFNGLGENVERTEXARRAYSPROC __glewGenVertexArrays; -GLEW_FUN_EXPORT PFNGLISVERTEXARRAYPROC __glewIsVertexArray; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLDVPROC __glewGetVertexAttribLdv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DPROC __glewVertexAttribL1d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DVPROC __glewVertexAttribL1dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DPROC __glewVertexAttribL2d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DVPROC __glewVertexAttribL2dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DPROC __glewVertexAttribL3d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DVPROC __glewVertexAttribL3dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DPROC __glewVertexAttribL4d; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DVPROC __glewVertexAttribL4dv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLPOINTERPROC __glewVertexAttribLPointer; - -GLEW_FUN_EXPORT PFNGLBINDVERTEXBUFFERPROC __glewBindVertexBuffer; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBBINDINGPROC __glewVertexAttribBinding; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBFORMATPROC __glewVertexAttribFormat; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIFORMATPROC __glewVertexAttribIFormat; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLFORMATPROC __glewVertexAttribLFormat; -GLEW_FUN_EXPORT PFNGLVERTEXBINDINGDIVISORPROC __glewVertexBindingDivisor; - -GLEW_FUN_EXPORT PFNGLVERTEXBLENDARBPROC __glewVertexBlendARB; -GLEW_FUN_EXPORT PFNGLWEIGHTPOINTERARBPROC __glewWeightPointerARB; -GLEW_FUN_EXPORT PFNGLWEIGHTBVARBPROC __glewWeightbvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTDVARBPROC __glewWeightdvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTFVARBPROC __glewWeightfvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTIVARBPROC __glewWeightivARB; -GLEW_FUN_EXPORT PFNGLWEIGHTSVARBPROC __glewWeightsvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTUBVARBPROC __glewWeightubvARB; -GLEW_FUN_EXPORT PFNGLWEIGHTUIVARBPROC __glewWeightuivARB; -GLEW_FUN_EXPORT PFNGLWEIGHTUSVARBPROC __glewWeightusvARB; - -GLEW_FUN_EXPORT PFNGLBINDBUFFERARBPROC __glewBindBufferARB; -GLEW_FUN_EXPORT PFNGLBUFFERDATAARBPROC __glewBufferDataARB; -GLEW_FUN_EXPORT PFNGLBUFFERSUBDATAARBPROC __glewBufferSubDataARB; -GLEW_FUN_EXPORT PFNGLDELETEBUFFERSARBPROC __glewDeleteBuffersARB; -GLEW_FUN_EXPORT PFNGLGENBUFFERSARBPROC __glewGenBuffersARB; -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERIVARBPROC __glewGetBufferParameterivARB; -GLEW_FUN_EXPORT PFNGLGETBUFFERPOINTERVARBPROC __glewGetBufferPointervARB; -GLEW_FUN_EXPORT PFNGLGETBUFFERSUBDATAARBPROC __glewGetBufferSubDataARB; -GLEW_FUN_EXPORT PFNGLISBUFFERARBPROC __glewIsBufferARB; -GLEW_FUN_EXPORT PFNGLMAPBUFFERARBPROC __glewMapBufferARB; -GLEW_FUN_EXPORT PFNGLUNMAPBUFFERARBPROC __glewUnmapBufferARB; - -GLEW_FUN_EXPORT PFNGLBINDPROGRAMARBPROC __glewBindProgramARB; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMSARBPROC __glewDeleteProgramsARB; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXATTRIBARRAYARBPROC __glewDisableVertexAttribArrayARB; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXATTRIBARRAYARBPROC __glewEnableVertexAttribArrayARB; -GLEW_FUN_EXPORT PFNGLGENPROGRAMSARBPROC __glewGenProgramsARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMENVPARAMETERDVARBPROC __glewGetProgramEnvParameterdvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMENVPARAMETERFVARBPROC __glewGetProgramEnvParameterfvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC __glewGetProgramLocalParameterdvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC __glewGetProgramLocalParameterfvARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMSTRINGARBPROC __glewGetProgramStringARB; -GLEW_FUN_EXPORT PFNGLGETPROGRAMIVARBPROC __glewGetProgramivARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVARBPROC __glewGetVertexAttribPointervARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVARBPROC __glewGetVertexAttribdvARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVARBPROC __glewGetVertexAttribfvARB; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVARBPROC __glewGetVertexAttribivARB; -GLEW_FUN_EXPORT PFNGLISPROGRAMARBPROC __glewIsProgramARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4DARBPROC __glewProgramEnvParameter4dARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4DVARBPROC __glewProgramEnvParameter4dvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4FARBPROC __glewProgramEnvParameter4fARB; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETER4FVARBPROC __glewProgramEnvParameter4fvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4DARBPROC __glewProgramLocalParameter4dARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4DVARBPROC __glewProgramLocalParameter4dvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4FARBPROC __glewProgramLocalParameter4fARB; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETER4FVARBPROC __glewProgramLocalParameter4fvARB; -GLEW_FUN_EXPORT PFNGLPROGRAMSTRINGARBPROC __glewProgramStringARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DARBPROC __glewVertexAttrib1dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVARBPROC __glewVertexAttrib1dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FARBPROC __glewVertexAttrib1fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVARBPROC __glewVertexAttrib1fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SARBPROC __glewVertexAttrib1sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVARBPROC __glewVertexAttrib1svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DARBPROC __glewVertexAttrib2dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVARBPROC __glewVertexAttrib2dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FARBPROC __glewVertexAttrib2fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVARBPROC __glewVertexAttrib2fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SARBPROC __glewVertexAttrib2sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVARBPROC __glewVertexAttrib2svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DARBPROC __glewVertexAttrib3dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVARBPROC __glewVertexAttrib3dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FARBPROC __glewVertexAttrib3fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVARBPROC __glewVertexAttrib3fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SARBPROC __glewVertexAttrib3sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVARBPROC __glewVertexAttrib3svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NBVARBPROC __glewVertexAttrib4NbvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NIVARBPROC __glewVertexAttrib4NivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NSVARBPROC __glewVertexAttrib4NsvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBARBPROC __glewVertexAttrib4NubARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUBVARBPROC __glewVertexAttrib4NubvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUIVARBPROC __glewVertexAttrib4NuivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4NUSVARBPROC __glewVertexAttrib4NusvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4BVARBPROC __glewVertexAttrib4bvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DARBPROC __glewVertexAttrib4dARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVARBPROC __glewVertexAttrib4dvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FARBPROC __glewVertexAttrib4fARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVARBPROC __glewVertexAttrib4fvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4IVARBPROC __glewVertexAttrib4ivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SARBPROC __glewVertexAttrib4sARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVARBPROC __glewVertexAttrib4svARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVARBPROC __glewVertexAttrib4ubvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UIVARBPROC __glewVertexAttrib4uivARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4USVARBPROC __glewVertexAttrib4usvARB; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERARBPROC __glewVertexAttribPointerARB; - -GLEW_FUN_EXPORT PFNGLBINDATTRIBLOCATIONARBPROC __glewBindAttribLocationARB; -GLEW_FUN_EXPORT PFNGLGETACTIVEATTRIBARBPROC __glewGetActiveAttribARB; -GLEW_FUN_EXPORT PFNGLGETATTRIBLOCATIONARBPROC __glewGetAttribLocationARB; - -GLEW_FUN_EXPORT PFNGLCOLORP3UIPROC __glewColorP3ui; -GLEW_FUN_EXPORT PFNGLCOLORP3UIVPROC __glewColorP3uiv; -GLEW_FUN_EXPORT PFNGLCOLORP4UIPROC __glewColorP4ui; -GLEW_FUN_EXPORT PFNGLCOLORP4UIVPROC __glewColorP4uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP1UIPROC __glewMultiTexCoordP1ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP1UIVPROC __glewMultiTexCoordP1uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP2UIPROC __glewMultiTexCoordP2ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP2UIVPROC __glewMultiTexCoordP2uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP3UIPROC __glewMultiTexCoordP3ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP3UIVPROC __glewMultiTexCoordP3uiv; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP4UIPROC __glewMultiTexCoordP4ui; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDP4UIVPROC __glewMultiTexCoordP4uiv; -GLEW_FUN_EXPORT PFNGLNORMALP3UIPROC __glewNormalP3ui; -GLEW_FUN_EXPORT PFNGLNORMALP3UIVPROC __glewNormalP3uiv; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORP3UIPROC __glewSecondaryColorP3ui; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORP3UIVPROC __glewSecondaryColorP3uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP1UIPROC __glewTexCoordP1ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP1UIVPROC __glewTexCoordP1uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP2UIPROC __glewTexCoordP2ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP2UIVPROC __glewTexCoordP2uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP3UIPROC __glewTexCoordP3ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP3UIVPROC __glewTexCoordP3uiv; -GLEW_FUN_EXPORT PFNGLTEXCOORDP4UIPROC __glewTexCoordP4ui; -GLEW_FUN_EXPORT PFNGLTEXCOORDP4UIVPROC __glewTexCoordP4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP1UIPROC __glewVertexAttribP1ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP1UIVPROC __glewVertexAttribP1uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP2UIPROC __glewVertexAttribP2ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP2UIVPROC __glewVertexAttribP2uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP3UIPROC __glewVertexAttribP3ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP3UIVPROC __glewVertexAttribP3uiv; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP4UIPROC __glewVertexAttribP4ui; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBP4UIVPROC __glewVertexAttribP4uiv; -GLEW_FUN_EXPORT PFNGLVERTEXP2UIPROC __glewVertexP2ui; -GLEW_FUN_EXPORT PFNGLVERTEXP2UIVPROC __glewVertexP2uiv; -GLEW_FUN_EXPORT PFNGLVERTEXP3UIPROC __glewVertexP3ui; -GLEW_FUN_EXPORT PFNGLVERTEXP3UIVPROC __glewVertexP3uiv; -GLEW_FUN_EXPORT PFNGLVERTEXP4UIPROC __glewVertexP4ui; -GLEW_FUN_EXPORT PFNGLVERTEXP4UIVPROC __glewVertexP4uiv; - -GLEW_FUN_EXPORT PFNGLDEPTHRANGEARRAYVPROC __glewDepthRangeArrayv; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEINDEXEDPROC __glewDepthRangeIndexed; -GLEW_FUN_EXPORT PFNGLGETDOUBLEI_VPROC __glewGetDoublei_v; -GLEW_FUN_EXPORT PFNGLGETFLOATI_VPROC __glewGetFloati_v; -GLEW_FUN_EXPORT PFNGLSCISSORARRAYVPROC __glewScissorArrayv; -GLEW_FUN_EXPORT PFNGLSCISSORINDEXEDPROC __glewScissorIndexed; -GLEW_FUN_EXPORT PFNGLSCISSORINDEXEDVPROC __glewScissorIndexedv; -GLEW_FUN_EXPORT PFNGLVIEWPORTARRAYVPROC __glewViewportArrayv; -GLEW_FUN_EXPORT PFNGLVIEWPORTINDEXEDFPROC __glewViewportIndexedf; -GLEW_FUN_EXPORT PFNGLVIEWPORTINDEXEDFVPROC __glewViewportIndexedfv; - -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DARBPROC __glewWindowPos2dARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVARBPROC __glewWindowPos2dvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FARBPROC __glewWindowPos2fARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVARBPROC __glewWindowPos2fvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IARBPROC __glewWindowPos2iARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVARBPROC __glewWindowPos2ivARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SARBPROC __glewWindowPos2sARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVARBPROC __glewWindowPos2svARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DARBPROC __glewWindowPos3dARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVARBPROC __glewWindowPos3dvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FARBPROC __glewWindowPos3fARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVARBPROC __glewWindowPos3fvARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IARBPROC __glewWindowPos3iARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVARBPROC __glewWindowPos3ivARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SARBPROC __glewWindowPos3sARB; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVARBPROC __glewWindowPos3svARB; - -GLEW_FUN_EXPORT PFNGLDRAWBUFFERSATIPROC __glewDrawBuffersATI; - -GLEW_FUN_EXPORT PFNGLDRAWELEMENTARRAYATIPROC __glewDrawElementArrayATI; -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTARRAYATIPROC __glewDrawRangeElementArrayATI; -GLEW_FUN_EXPORT PFNGLELEMENTPOINTERATIPROC __glewElementPointerATI; - -GLEW_FUN_EXPORT PFNGLGETTEXBUMPPARAMETERFVATIPROC __glewGetTexBumpParameterfvATI; -GLEW_FUN_EXPORT PFNGLGETTEXBUMPPARAMETERIVATIPROC __glewGetTexBumpParameterivATI; -GLEW_FUN_EXPORT PFNGLTEXBUMPPARAMETERFVATIPROC __glewTexBumpParameterfvATI; -GLEW_FUN_EXPORT PFNGLTEXBUMPPARAMETERIVATIPROC __glewTexBumpParameterivATI; - -GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP1ATIPROC __glewAlphaFragmentOp1ATI; -GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP2ATIPROC __glewAlphaFragmentOp2ATI; -GLEW_FUN_EXPORT PFNGLALPHAFRAGMENTOP3ATIPROC __glewAlphaFragmentOp3ATI; -GLEW_FUN_EXPORT PFNGLBEGINFRAGMENTSHADERATIPROC __glewBeginFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLBINDFRAGMENTSHADERATIPROC __glewBindFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP1ATIPROC __glewColorFragmentOp1ATI; -GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP2ATIPROC __glewColorFragmentOp2ATI; -GLEW_FUN_EXPORT PFNGLCOLORFRAGMENTOP3ATIPROC __glewColorFragmentOp3ATI; -GLEW_FUN_EXPORT PFNGLDELETEFRAGMENTSHADERATIPROC __glewDeleteFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLENDFRAGMENTSHADERATIPROC __glewEndFragmentShaderATI; -GLEW_FUN_EXPORT PFNGLGENFRAGMENTSHADERSATIPROC __glewGenFragmentShadersATI; -GLEW_FUN_EXPORT PFNGLPASSTEXCOORDATIPROC __glewPassTexCoordATI; -GLEW_FUN_EXPORT PFNGLSAMPLEMAPATIPROC __glewSampleMapATI; -GLEW_FUN_EXPORT PFNGLSETFRAGMENTSHADERCONSTANTATIPROC __glewSetFragmentShaderConstantATI; - -GLEW_FUN_EXPORT PFNGLMAPOBJECTBUFFERATIPROC __glewMapObjectBufferATI; -GLEW_FUN_EXPORT PFNGLUNMAPOBJECTBUFFERATIPROC __glewUnmapObjectBufferATI; - -GLEW_FUN_EXPORT PFNGLPNTRIANGLESFATIPROC __glewPNTrianglesfATI; -GLEW_FUN_EXPORT PFNGLPNTRIANGLESIATIPROC __glewPNTrianglesiATI; - -GLEW_FUN_EXPORT PFNGLSTENCILFUNCSEPARATEATIPROC __glewStencilFuncSeparateATI; -GLEW_FUN_EXPORT PFNGLSTENCILOPSEPARATEATIPROC __glewStencilOpSeparateATI; - -GLEW_FUN_EXPORT PFNGLARRAYOBJECTATIPROC __glewArrayObjectATI; -GLEW_FUN_EXPORT PFNGLFREEOBJECTBUFFERATIPROC __glewFreeObjectBufferATI; -GLEW_FUN_EXPORT PFNGLGETARRAYOBJECTFVATIPROC __glewGetArrayObjectfvATI; -GLEW_FUN_EXPORT PFNGLGETARRAYOBJECTIVATIPROC __glewGetArrayObjectivATI; -GLEW_FUN_EXPORT PFNGLGETOBJECTBUFFERFVATIPROC __glewGetObjectBufferfvATI; -GLEW_FUN_EXPORT PFNGLGETOBJECTBUFFERIVATIPROC __glewGetObjectBufferivATI; -GLEW_FUN_EXPORT PFNGLGETVARIANTARRAYOBJECTFVATIPROC __glewGetVariantArrayObjectfvATI; -GLEW_FUN_EXPORT PFNGLGETVARIANTARRAYOBJECTIVATIPROC __glewGetVariantArrayObjectivATI; -GLEW_FUN_EXPORT PFNGLISOBJECTBUFFERATIPROC __glewIsObjectBufferATI; -GLEW_FUN_EXPORT PFNGLNEWOBJECTBUFFERATIPROC __glewNewObjectBufferATI; -GLEW_FUN_EXPORT PFNGLUPDATEOBJECTBUFFERATIPROC __glewUpdateObjectBufferATI; -GLEW_FUN_EXPORT PFNGLVARIANTARRAYOBJECTATIPROC __glewVariantArrayObjectATI; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC __glewGetVertexAttribArrayObjectfvATI; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC __glewGetVertexAttribArrayObjectivATI; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBARRAYOBJECTATIPROC __glewVertexAttribArrayObjectATI; - -GLEW_FUN_EXPORT PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC __glewClientActiveVertexStreamATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3BATIPROC __glewNormalStream3bATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3BVATIPROC __glewNormalStream3bvATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3DATIPROC __glewNormalStream3dATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3DVATIPROC __glewNormalStream3dvATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3FATIPROC __glewNormalStream3fATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3FVATIPROC __glewNormalStream3fvATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3IATIPROC __glewNormalStream3iATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3IVATIPROC __glewNormalStream3ivATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3SATIPROC __glewNormalStream3sATI; -GLEW_FUN_EXPORT PFNGLNORMALSTREAM3SVATIPROC __glewNormalStream3svATI; -GLEW_FUN_EXPORT PFNGLVERTEXBLENDENVFATIPROC __glewVertexBlendEnvfATI; -GLEW_FUN_EXPORT PFNGLVERTEXBLENDENVIATIPROC __glewVertexBlendEnviATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1DATIPROC __glewVertexStream1dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1DVATIPROC __glewVertexStream1dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1FATIPROC __glewVertexStream1fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1FVATIPROC __glewVertexStream1fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1IATIPROC __glewVertexStream1iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1IVATIPROC __glewVertexStream1ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1SATIPROC __glewVertexStream1sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM1SVATIPROC __glewVertexStream1svATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2DATIPROC __glewVertexStream2dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2DVATIPROC __glewVertexStream2dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2FATIPROC __glewVertexStream2fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2FVATIPROC __glewVertexStream2fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2IATIPROC __glewVertexStream2iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2IVATIPROC __glewVertexStream2ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2SATIPROC __glewVertexStream2sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM2SVATIPROC __glewVertexStream2svATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3DATIPROC __glewVertexStream3dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3DVATIPROC __glewVertexStream3dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3FATIPROC __glewVertexStream3fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3FVATIPROC __glewVertexStream3fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3IATIPROC __glewVertexStream3iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3IVATIPROC __glewVertexStream3ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3SATIPROC __glewVertexStream3sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM3SVATIPROC __glewVertexStream3svATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4DATIPROC __glewVertexStream4dATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4DVATIPROC __glewVertexStream4dvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4FATIPROC __glewVertexStream4fATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4FVATIPROC __glewVertexStream4fvATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4IATIPROC __glewVertexStream4iATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4IVATIPROC __glewVertexStream4ivATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4SATIPROC __glewVertexStream4sATI; -GLEW_FUN_EXPORT PFNGLVERTEXSTREAM4SVATIPROC __glewVertexStream4svATI; - -GLEW_FUN_EXPORT PFNGLGETUNIFORMBUFFERSIZEEXTPROC __glewGetUniformBufferSizeEXT; -GLEW_FUN_EXPORT PFNGLGETUNIFORMOFFSETEXTPROC __glewGetUniformOffsetEXT; -GLEW_FUN_EXPORT PFNGLUNIFORMBUFFEREXTPROC __glewUniformBufferEXT; - -GLEW_FUN_EXPORT PFNGLBLENDCOLOREXTPROC __glewBlendColorEXT; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONSEPARATEEXTPROC __glewBlendEquationSeparateEXT; - -GLEW_FUN_EXPORT PFNGLBLENDFUNCSEPARATEEXTPROC __glewBlendFuncSeparateEXT; - -GLEW_FUN_EXPORT PFNGLBLENDEQUATIONEXTPROC __glewBlendEquationEXT; - -GLEW_FUN_EXPORT PFNGLCOLORSUBTABLEEXTPROC __glewColorSubTableEXT; -GLEW_FUN_EXPORT PFNGLCOPYCOLORSUBTABLEEXTPROC __glewCopyColorSubTableEXT; - -GLEW_FUN_EXPORT PFNGLLOCKARRAYSEXTPROC __glewLockArraysEXT; -GLEW_FUN_EXPORT PFNGLUNLOCKARRAYSEXTPROC __glewUnlockArraysEXT; - -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER1DEXTPROC __glewConvolutionFilter1DEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONFILTER2DEXTPROC __glewConvolutionFilter2DEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFEXTPROC __glewConvolutionParameterfEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERFVEXTPROC __glewConvolutionParameterfvEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIEXTPROC __glewConvolutionParameteriEXT; -GLEW_FUN_EXPORT PFNGLCONVOLUTIONPARAMETERIVEXTPROC __glewConvolutionParameterivEXT; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC __glewCopyConvolutionFilter1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC __glewCopyConvolutionFilter2DEXT; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONFILTEREXTPROC __glewGetConvolutionFilterEXT; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC __glewGetConvolutionParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC __glewGetConvolutionParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETSEPARABLEFILTEREXTPROC __glewGetSeparableFilterEXT; -GLEW_FUN_EXPORT PFNGLSEPARABLEFILTER2DEXTPROC __glewSeparableFilter2DEXT; - -GLEW_FUN_EXPORT PFNGLBINORMALPOINTEREXTPROC __glewBinormalPointerEXT; -GLEW_FUN_EXPORT PFNGLTANGENTPOINTEREXTPROC __glewTangentPointerEXT; - -GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE1DEXTPROC __glewCopyTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXIMAGE2DEXTPROC __glewCopyTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE1DEXTPROC __glewCopyTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE2DEXTPROC __glewCopyTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXSUBIMAGE3DEXTPROC __glewCopyTexSubImage3DEXT; - -GLEW_FUN_EXPORT PFNGLCULLPARAMETERDVEXTPROC __glewCullParameterdvEXT; -GLEW_FUN_EXPORT PFNGLCULLPARAMETERFVEXTPROC __glewCullParameterfvEXT; - -GLEW_FUN_EXPORT PFNGLINSERTEVENTMARKEREXTPROC __glewInsertEventMarkerEXT; -GLEW_FUN_EXPORT PFNGLPOPGROUPMARKEREXTPROC __glewPopGroupMarkerEXT; -GLEW_FUN_EXPORT PFNGLPUSHGROUPMARKEREXTPROC __glewPushGroupMarkerEXT; - -GLEW_FUN_EXPORT PFNGLDEPTHBOUNDSEXTPROC __glewDepthBoundsEXT; - -GLEW_FUN_EXPORT PFNGLBINDMULTITEXTUREEXTPROC __glewBindMultiTextureEXT; -GLEW_FUN_EXPORT PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC __glewCheckNamedFramebufferStatusEXT; -GLEW_FUN_EXPORT PFNGLCLIENTATTRIBDEFAULTEXTPROC __glewClientAttribDefaultEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC __glewCompressedMultiTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC __glewCompressedMultiTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC __glewCompressedMultiTexImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC __glewCompressedMultiTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC __glewCompressedMultiTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC __glewCompressedMultiTexSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC __glewCompressedTextureImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC __glewCompressedTextureImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC __glewCompressedTextureImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC __glewCompressedTextureSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC __glewCompressedTextureSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC __glewCompressedTextureSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXIMAGE1DEXTPROC __glewCopyMultiTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXIMAGE2DEXTPROC __glewCopyMultiTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC __glewCopyMultiTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC __glewCopyMultiTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC __glewCopyMultiTexSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTUREIMAGE1DEXTPROC __glewCopyTextureImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTUREIMAGE2DEXTPROC __glewCopyTextureImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC __glewCopyTextureSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC __glewCopyTextureSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC __glewCopyTextureSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC __glewDisableClientStateIndexedEXT; -GLEW_FUN_EXPORT PFNGLDISABLECLIENTSTATEIEXTPROC __glewDisableClientStateiEXT; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC __glewDisableVertexArrayAttribEXT; -GLEW_FUN_EXPORT PFNGLDISABLEVERTEXARRAYEXTPROC __glewDisableVertexArrayEXT; -GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEINDEXEDEXTPROC __glewEnableClientStateIndexedEXT; -GLEW_FUN_EXPORT PFNGLENABLECLIENTSTATEIEXTPROC __glewEnableClientStateiEXT; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXARRAYATTRIBEXTPROC __glewEnableVertexArrayAttribEXT; -GLEW_FUN_EXPORT PFNGLENABLEVERTEXARRAYEXTPROC __glewEnableVertexArrayEXT; -GLEW_FUN_EXPORT PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC __glewFlushMappedNamedBufferRangeEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC __glewFramebufferDrawBufferEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC __glewFramebufferDrawBuffersEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERREADBUFFEREXTPROC __glewFramebufferReadBufferEXT; -GLEW_FUN_EXPORT PFNGLGENERATEMULTITEXMIPMAPEXTPROC __glewGenerateMultiTexMipmapEXT; -GLEW_FUN_EXPORT PFNGLGENERATETEXTUREMIPMAPEXTPROC __glewGenerateTextureMipmapEXT; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC __glewGetCompressedMultiTexImageEXT; -GLEW_FUN_EXPORT PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC __glewGetCompressedTextureImageEXT; -GLEW_FUN_EXPORT PFNGLGETDOUBLEINDEXEDVEXTPROC __glewGetDoubleIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETDOUBLEI_VEXTPROC __glewGetDoublei_vEXT; -GLEW_FUN_EXPORT PFNGLGETFLOATINDEXEDVEXTPROC __glewGetFloatIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETFLOATI_VEXTPROC __glewGetFloati_vEXT; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC __glewGetFramebufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXENVFVEXTPROC __glewGetMultiTexEnvfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXENVIVEXTPROC __glewGetMultiTexEnvivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXGENDVEXTPROC __glewGetMultiTexGendvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXGENFVEXTPROC __glewGetMultiTexGenfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXGENIVEXTPROC __glewGetMultiTexGenivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXIMAGEEXTPROC __glewGetMultiTexImageEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC __glewGetMultiTexLevelParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC __glewGetMultiTexLevelParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIIVEXTPROC __glewGetMultiTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIUIVEXTPROC __glewGetMultiTexParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERFVEXTPROC __glewGetMultiTexParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETMULTITEXPARAMETERIVEXTPROC __glewGetMultiTexParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC __glewGetNamedBufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPOINTERVEXTPROC __glewGetNamedBufferPointervEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERSUBDATAEXTPROC __glewGetNamedBufferSubDataEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetNamedFramebufferAttachmentParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC __glewGetNamedProgramLocalParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC __glewGetNamedProgramLocalParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC __glewGetNamedProgramLocalParameterdvEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC __glewGetNamedProgramLocalParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMSTRINGEXTPROC __glewGetNamedProgramStringEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDPROGRAMIVEXTPROC __glewGetNamedProgramivEXT; -GLEW_FUN_EXPORT PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC __glewGetNamedRenderbufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETPOINTERINDEXEDVEXTPROC __glewGetPointerIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETPOINTERI_VEXTPROC __glewGetPointeri_vEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREIMAGEEXTPROC __glewGetTextureImageEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC __glewGetTextureLevelParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC __glewGetTextureLevelParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIIVEXTPROC __glewGetTextureParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIUIVEXTPROC __glewGetTextureParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERFVEXTPROC __glewGetTextureParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETTEXTUREPARAMETERIVEXTPROC __glewGetTextureParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC __glewGetVertexArrayIntegeri_vEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYINTEGERVEXTPROC __glewGetVertexArrayIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC __glewGetVertexArrayPointeri_vEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXARRAYPOINTERVEXTPROC __glewGetVertexArrayPointervEXT; -GLEW_FUN_EXPORT PFNGLMAPNAMEDBUFFEREXTPROC __glewMapNamedBufferEXT; -GLEW_FUN_EXPORT PFNGLMAPNAMEDBUFFERRANGEEXTPROC __glewMapNamedBufferRangeEXT; -GLEW_FUN_EXPORT PFNGLMATRIXFRUSTUMEXTPROC __glewMatrixFrustumEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADIDENTITYEXTPROC __glewMatrixLoadIdentityEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADTRANSPOSEDEXTPROC __glewMatrixLoadTransposedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADTRANSPOSEFEXTPROC __glewMatrixLoadTransposefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADDEXTPROC __glewMatrixLoaddEXT; -GLEW_FUN_EXPORT PFNGLMATRIXLOADFEXTPROC __glewMatrixLoadfEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTTRANSPOSEDEXTPROC __glewMatrixMultTransposedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTTRANSPOSEFEXTPROC __glewMatrixMultTransposefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTDEXTPROC __glewMatrixMultdEXT; -GLEW_FUN_EXPORT PFNGLMATRIXMULTFEXTPROC __glewMatrixMultfEXT; -GLEW_FUN_EXPORT PFNGLMATRIXORTHOEXTPROC __glewMatrixOrthoEXT; -GLEW_FUN_EXPORT PFNGLMATRIXPOPEXTPROC __glewMatrixPopEXT; -GLEW_FUN_EXPORT PFNGLMATRIXPUSHEXTPROC __glewMatrixPushEXT; -GLEW_FUN_EXPORT PFNGLMATRIXROTATEDEXTPROC __glewMatrixRotatedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXROTATEFEXTPROC __glewMatrixRotatefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXSCALEDEXTPROC __glewMatrixScaledEXT; -GLEW_FUN_EXPORT PFNGLMATRIXSCALEFEXTPROC __glewMatrixScalefEXT; -GLEW_FUN_EXPORT PFNGLMATRIXTRANSLATEDEXTPROC __glewMatrixTranslatedEXT; -GLEW_FUN_EXPORT PFNGLMATRIXTRANSLATEFEXTPROC __glewMatrixTranslatefEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXBUFFEREXTPROC __glewMultiTexBufferEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORDPOINTEREXTPROC __glewMultiTexCoordPointerEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVFEXTPROC __glewMultiTexEnvfEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVFVEXTPROC __glewMultiTexEnvfvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVIEXTPROC __glewMultiTexEnviEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXENVIVEXTPROC __glewMultiTexEnvivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENDEXTPROC __glewMultiTexGendEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENDVEXTPROC __glewMultiTexGendvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENFEXTPROC __glewMultiTexGenfEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENFVEXTPROC __glewMultiTexGenfvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENIEXTPROC __glewMultiTexGeniEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXGENIVEXTPROC __glewMultiTexGenivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE1DEXTPROC __glewMultiTexImage1DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE2DEXTPROC __glewMultiTexImage2DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXIMAGE3DEXTPROC __glewMultiTexImage3DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIIVEXTPROC __glewMultiTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIUIVEXTPROC __glewMultiTexParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERFEXTPROC __glewMultiTexParameterfEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERFVEXTPROC __glewMultiTexParameterfvEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIEXTPROC __glewMultiTexParameteriEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXPARAMETERIVEXTPROC __glewMultiTexParameterivEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXRENDERBUFFEREXTPROC __glewMultiTexRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE1DEXTPROC __glewMultiTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE2DEXTPROC __glewMultiTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLMULTITEXSUBIMAGE3DEXTPROC __glewMultiTexSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDBUFFERDATAEXTPROC __glewNamedBufferDataEXT; -GLEW_FUN_EXPORT PFNGLNAMEDBUFFERSUBDATAEXTPROC __glewNamedBufferSubDataEXT; -GLEW_FUN_EXPORT PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC __glewNamedCopyBufferSubDataEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC __glewNamedFramebufferRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC __glewNamedFramebufferTexture1DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC __glewNamedFramebufferTexture2DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC __glewNamedFramebufferTexture3DEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC __glewNamedFramebufferTextureEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC __glewNamedFramebufferTextureFaceEXT; -GLEW_FUN_EXPORT PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC __glewNamedFramebufferTextureLayerEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC __glewNamedProgramLocalParameter4dEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC __glewNamedProgramLocalParameter4dvEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC __glewNamedProgramLocalParameter4fEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC __glewNamedProgramLocalParameter4fvEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC __glewNamedProgramLocalParameterI4iEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC __glewNamedProgramLocalParameterI4ivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC __glewNamedProgramLocalParameterI4uiEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC __glewNamedProgramLocalParameterI4uivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC __glewNamedProgramLocalParameters4fvEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC __glewNamedProgramLocalParametersI4ivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC __glewNamedProgramLocalParametersI4uivEXT; -GLEW_FUN_EXPORT PFNGLNAMEDPROGRAMSTRINGEXTPROC __glewNamedProgramStringEXT; -GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC __glewNamedRenderbufferStorageEXT; -GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC __glewNamedRenderbufferStorageMultisampleCoverageEXT; -GLEW_FUN_EXPORT PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewNamedRenderbufferStorageMultisampleEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FEXTPROC __glewProgramUniform1fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1FVEXTPROC __glewProgramUniform1fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IEXTPROC __glewProgramUniform1iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1IVEXTPROC __glewProgramUniform1ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIEXTPROC __glewProgramUniform1uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UIVEXTPROC __glewProgramUniform1uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FEXTPROC __glewProgramUniform2fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2FVEXTPROC __glewProgramUniform2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IEXTPROC __glewProgramUniform2iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2IVEXTPROC __glewProgramUniform2ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIEXTPROC __glewProgramUniform2uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UIVEXTPROC __glewProgramUniform2uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FEXTPROC __glewProgramUniform3fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3FVEXTPROC __glewProgramUniform3fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IEXTPROC __glewProgramUniform3iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3IVEXTPROC __glewProgramUniform3ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIEXTPROC __glewProgramUniform3uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UIVEXTPROC __glewProgramUniform3uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FEXTPROC __glewProgramUniform4fEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4FVEXTPROC __glewProgramUniform4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IEXTPROC __glewProgramUniform4iEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4IVEXTPROC __glewProgramUniform4ivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIEXTPROC __glewProgramUniform4uiEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UIVEXTPROC __glewProgramUniform4uivEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC __glewProgramUniformMatrix2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC __glewProgramUniformMatrix2x3fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC __glewProgramUniformMatrix2x4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC __glewProgramUniformMatrix3fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC __glewProgramUniformMatrix3x2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC __glewProgramUniformMatrix3x4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC __glewProgramUniformMatrix4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC __glewProgramUniformMatrix4x2fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC __glewProgramUniformMatrix4x3fvEXT; -GLEW_FUN_EXPORT PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC __glewPushClientAttribDefaultEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREBUFFEREXTPROC __glewTextureBufferEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE1DEXTPROC __glewTextureImage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DEXTPROC __glewTextureImage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DEXTPROC __glewTextureImage3DEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIIVEXTPROC __glewTextureParameterIivEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIUIVEXTPROC __glewTextureParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERFEXTPROC __glewTextureParameterfEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERFVEXTPROC __glewTextureParameterfvEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIEXTPROC __glewTextureParameteriEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREPARAMETERIVEXTPROC __glewTextureParameterivEXT; -GLEW_FUN_EXPORT PFNGLTEXTURERENDERBUFFEREXTPROC __glewTextureRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE1DEXTPROC __glewTextureSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE2DEXTPROC __glewTextureSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXTURESUBIMAGE3DEXTPROC __glewTextureSubImage3DEXT; -GLEW_FUN_EXPORT PFNGLUNMAPNAMEDBUFFEREXTPROC __glewUnmapNamedBufferEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYCOLOROFFSETEXTPROC __glewVertexArrayColorOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC __glewVertexArrayEdgeFlagOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC __glewVertexArrayFogCoordOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYINDEXOFFSETEXTPROC __glewVertexArrayIndexOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC __glewVertexArrayMultiTexCoordOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYNORMALOFFSETEXTPROC __glewVertexArrayNormalOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC __glewVertexArraySecondaryColorOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC __glewVertexArrayTexCoordOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC __glewVertexArrayVertexAttribIOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC __glewVertexArrayVertexAttribOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC __glewVertexArrayVertexOffsetEXT; - -GLEW_FUN_EXPORT PFNGLCOLORMASKINDEXEDEXTPROC __glewColorMaskIndexedEXT; -GLEW_FUN_EXPORT PFNGLDISABLEINDEXEDEXTPROC __glewDisableIndexedEXT; -GLEW_FUN_EXPORT PFNGLENABLEINDEXEDEXTPROC __glewEnableIndexedEXT; -GLEW_FUN_EXPORT PFNGLGETBOOLEANINDEXEDVEXTPROC __glewGetBooleanIndexedvEXT; -GLEW_FUN_EXPORT PFNGLGETINTEGERINDEXEDVEXTPROC __glewGetIntegerIndexedvEXT; -GLEW_FUN_EXPORT PFNGLISENABLEDINDEXEDEXTPROC __glewIsEnabledIndexedEXT; - -GLEW_FUN_EXPORT PFNGLDRAWARRAYSINSTANCEDEXTPROC __glewDrawArraysInstancedEXT; -GLEW_FUN_EXPORT PFNGLDRAWELEMENTSINSTANCEDEXTPROC __glewDrawElementsInstancedEXT; - -GLEW_FUN_EXPORT PFNGLDRAWRANGEELEMENTSEXTPROC __glewDrawRangeElementsEXT; - -GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTEREXTPROC __glewFogCoordPointerEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDDEXTPROC __glewFogCoorddEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDDVEXTPROC __glewFogCoorddvEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDFEXTPROC __glewFogCoordfEXT; -GLEW_FUN_EXPORT PFNGLFOGCOORDFVEXTPROC __glewFogCoordfvEXT; - -GLEW_FUN_EXPORT PFNGLFRAGMENTCOLORMATERIALEXTPROC __glewFragmentColorMaterialEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFEXTPROC __glewFragmentLightModelfEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFVEXTPROC __glewFragmentLightModelfvEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIEXTPROC __glewFragmentLightModeliEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIVEXTPROC __glewFragmentLightModelivEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFEXTPROC __glewFragmentLightfEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFVEXTPROC __glewFragmentLightfvEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIEXTPROC __glewFragmentLightiEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIVEXTPROC __glewFragmentLightivEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFEXTPROC __glewFragmentMaterialfEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFVEXTPROC __glewFragmentMaterialfvEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIEXTPROC __glewFragmentMaterialiEXT; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIVEXTPROC __glewFragmentMaterialivEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTFVEXTPROC __glewGetFragmentLightfvEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTIVEXTPROC __glewGetFragmentLightivEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALFVEXTPROC __glewGetFragmentMaterialfvEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALIVEXTPROC __glewGetFragmentMaterialivEXT; -GLEW_FUN_EXPORT PFNGLLIGHTENVIEXTPROC __glewLightEnviEXT; - -GLEW_FUN_EXPORT PFNGLBLITFRAMEBUFFEREXTPROC __glewBlitFramebufferEXT; - -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewRenderbufferStorageMultisampleEXT; - -GLEW_FUN_EXPORT PFNGLBINDFRAMEBUFFEREXTPROC __glewBindFramebufferEXT; -GLEW_FUN_EXPORT PFNGLBINDRENDERBUFFEREXTPROC __glewBindRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC __glewCheckFramebufferStatusEXT; -GLEW_FUN_EXPORT PFNGLDELETEFRAMEBUFFERSEXTPROC __glewDeleteFramebuffersEXT; -GLEW_FUN_EXPORT PFNGLDELETERENDERBUFFERSEXTPROC __glewDeleteRenderbuffersEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC __glewFramebufferRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE1DEXTPROC __glewFramebufferTexture1DEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE2DEXTPROC __glewFramebufferTexture2DEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURE3DEXTPROC __glewFramebufferTexture3DEXT; -GLEW_FUN_EXPORT PFNGLGENFRAMEBUFFERSEXTPROC __glewGenFramebuffersEXT; -GLEW_FUN_EXPORT PFNGLGENRENDERBUFFERSEXTPROC __glewGenRenderbuffersEXT; -GLEW_FUN_EXPORT PFNGLGENERATEMIPMAPEXTPROC __glewGenerateMipmapEXT; -GLEW_FUN_EXPORT PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetFramebufferAttachmentParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC __glewGetRenderbufferParameterivEXT; -GLEW_FUN_EXPORT PFNGLISFRAMEBUFFEREXTPROC __glewIsFramebufferEXT; -GLEW_FUN_EXPORT PFNGLISRENDERBUFFEREXTPROC __glewIsRenderbufferEXT; -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEEXTPROC __glewRenderbufferStorageEXT; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREEXTPROC __glewFramebufferTextureEXT; -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC __glewFramebufferTextureFaceEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERIEXTPROC __glewProgramParameteriEXT; - -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERS4FVEXTPROC __glewProgramEnvParameters4fvEXT; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC __glewProgramLocalParameters4fvEXT; - -GLEW_FUN_EXPORT PFNGLBINDFRAGDATALOCATIONEXTPROC __glewBindFragDataLocationEXT; -GLEW_FUN_EXPORT PFNGLGETFRAGDATALOCATIONEXTPROC __glewGetFragDataLocationEXT; -GLEW_FUN_EXPORT PFNGLGETUNIFORMUIVEXTPROC __glewGetUniformuivEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIIVEXTPROC __glewGetVertexAttribIivEXT; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIUIVEXTPROC __glewGetVertexAttribIuivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIEXTPROC __glewUniform1uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM1UIVEXTPROC __glewUniform1uivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIEXTPROC __glewUniform2uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM2UIVEXTPROC __glewUniform2uivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIEXTPROC __glewUniform3uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM3UIVEXTPROC __glewUniform3uivEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIEXTPROC __glewUniform4uiEXT; -GLEW_FUN_EXPORT PFNGLUNIFORM4UIVEXTPROC __glewUniform4uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IEXTPROC __glewVertexAttribI1iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1IVEXTPROC __glewVertexAttribI1ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIEXTPROC __glewVertexAttribI1uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI1UIVEXTPROC __glewVertexAttribI1uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IEXTPROC __glewVertexAttribI2iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2IVEXTPROC __glewVertexAttribI2ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIEXTPROC __glewVertexAttribI2uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI2UIVEXTPROC __glewVertexAttribI2uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IEXTPROC __glewVertexAttribI3iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3IVEXTPROC __glewVertexAttribI3ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIEXTPROC __glewVertexAttribI3uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI3UIVEXTPROC __glewVertexAttribI3uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4BVEXTPROC __glewVertexAttribI4bvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IEXTPROC __glewVertexAttribI4iEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4IVEXTPROC __glewVertexAttribI4ivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4SVEXTPROC __glewVertexAttribI4svEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UBVEXTPROC __glewVertexAttribI4ubvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIEXTPROC __glewVertexAttribI4uiEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4UIVEXTPROC __glewVertexAttribI4uivEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBI4USVEXTPROC __glewVertexAttribI4usvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIPOINTEREXTPROC __glewVertexAttribIPointerEXT; - -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMEXTPROC __glewGetHistogramEXT; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERFVEXTPROC __glewGetHistogramParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETHISTOGRAMPARAMETERIVEXTPROC __glewGetHistogramParameterivEXT; -GLEW_FUN_EXPORT PFNGLGETMINMAXEXTPROC __glewGetMinmaxEXT; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERFVEXTPROC __glewGetMinmaxParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETMINMAXPARAMETERIVEXTPROC __glewGetMinmaxParameterivEXT; -GLEW_FUN_EXPORT PFNGLHISTOGRAMEXTPROC __glewHistogramEXT; -GLEW_FUN_EXPORT PFNGLMINMAXEXTPROC __glewMinmaxEXT; -GLEW_FUN_EXPORT PFNGLRESETHISTOGRAMEXTPROC __glewResetHistogramEXT; -GLEW_FUN_EXPORT PFNGLRESETMINMAXEXTPROC __glewResetMinmaxEXT; - -GLEW_FUN_EXPORT PFNGLINDEXFUNCEXTPROC __glewIndexFuncEXT; - -GLEW_FUN_EXPORT PFNGLINDEXMATERIALEXTPROC __glewIndexMaterialEXT; - -GLEW_FUN_EXPORT PFNGLAPPLYTEXTUREEXTPROC __glewApplyTextureEXT; -GLEW_FUN_EXPORT PFNGLTEXTURELIGHTEXTPROC __glewTextureLightEXT; -GLEW_FUN_EXPORT PFNGLTEXTUREMATERIALEXTPROC __glewTextureMaterialEXT; - -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSEXTPROC __glewMultiDrawArraysEXT; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSEXTPROC __glewMultiDrawElementsEXT; - -GLEW_FUN_EXPORT PFNGLSAMPLEMASKEXTPROC __glewSampleMaskEXT; -GLEW_FUN_EXPORT PFNGLSAMPLEPATTERNEXTPROC __glewSamplePatternEXT; - -GLEW_FUN_EXPORT PFNGLCOLORTABLEEXTPROC __glewColorTableEXT; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEEXTPROC __glewGetColorTableEXT; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVEXTPROC __glewGetColorTableParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVEXTPROC __glewGetColorTableParameterivEXT; - -GLEW_FUN_EXPORT PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC __glewGetPixelTransformParameterfvEXT; -GLEW_FUN_EXPORT PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC __glewGetPixelTransformParameterivEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERFEXTPROC __glewPixelTransformParameterfEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC __glewPixelTransformParameterfvEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERIEXTPROC __glewPixelTransformParameteriEXT; -GLEW_FUN_EXPORT PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC __glewPixelTransformParameterivEXT; - -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFEXTPROC __glewPointParameterfEXT; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERFVEXTPROC __glewPointParameterfvEXT; - -GLEW_FUN_EXPORT PFNGLPOLYGONOFFSETEXTPROC __glewPolygonOffsetEXT; - -GLEW_FUN_EXPORT PFNGLPROVOKINGVERTEXEXTPROC __glewProvokingVertexEXT; - -GLEW_FUN_EXPORT PFNGLBEGINSCENEEXTPROC __glewBeginSceneEXT; -GLEW_FUN_EXPORT PFNGLENDSCENEEXTPROC __glewEndSceneEXT; - -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BEXTPROC __glewSecondaryColor3bEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3BVEXTPROC __glewSecondaryColor3bvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DEXTPROC __glewSecondaryColor3dEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3DVEXTPROC __glewSecondaryColor3dvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FEXTPROC __glewSecondaryColor3fEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3FVEXTPROC __glewSecondaryColor3fvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IEXTPROC __glewSecondaryColor3iEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3IVEXTPROC __glewSecondaryColor3ivEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SEXTPROC __glewSecondaryColor3sEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3SVEXTPROC __glewSecondaryColor3svEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBEXTPROC __glewSecondaryColor3ubEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UBVEXTPROC __glewSecondaryColor3ubvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIEXTPROC __glewSecondaryColor3uiEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3UIVEXTPROC __glewSecondaryColor3uivEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USEXTPROC __glewSecondaryColor3usEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3USVEXTPROC __glewSecondaryColor3usvEXT; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTEREXTPROC __glewSecondaryColorPointerEXT; - -GLEW_FUN_EXPORT PFNGLACTIVEPROGRAMEXTPROC __glewActiveProgramEXT; -GLEW_FUN_EXPORT PFNGLCREATESHADERPROGRAMEXTPROC __glewCreateShaderProgramEXT; -GLEW_FUN_EXPORT PFNGLUSESHADERPROGRAMEXTPROC __glewUseShaderProgramEXT; - -GLEW_FUN_EXPORT PFNGLBINDIMAGETEXTUREEXTPROC __glewBindImageTextureEXT; -GLEW_FUN_EXPORT PFNGLMEMORYBARRIEREXTPROC __glewMemoryBarrierEXT; - -GLEW_FUN_EXPORT PFNGLACTIVESTENCILFACEEXTPROC __glewActiveStencilFaceEXT; - -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE1DEXTPROC __glewTexSubImage1DEXT; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE2DEXTPROC __glewTexSubImage2DEXT; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE3DEXTPROC __glewTexSubImage3DEXT; - -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DEXTPROC __glewTexImage3DEXT; - -GLEW_FUN_EXPORT PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC __glewFramebufferTextureLayerEXT; - -GLEW_FUN_EXPORT PFNGLTEXBUFFEREXTPROC __glewTexBufferEXT; - -GLEW_FUN_EXPORT PFNGLCLEARCOLORIIEXTPROC __glewClearColorIiEXT; -GLEW_FUN_EXPORT PFNGLCLEARCOLORIUIEXTPROC __glewClearColorIuiEXT; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIIVEXTPROC __glewGetTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERIUIVEXTPROC __glewGetTexParameterIuivEXT; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIIVEXTPROC __glewTexParameterIivEXT; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERIUIVEXTPROC __glewTexParameterIuivEXT; - -GLEW_FUN_EXPORT PFNGLARETEXTURESRESIDENTEXTPROC __glewAreTexturesResidentEXT; -GLEW_FUN_EXPORT PFNGLBINDTEXTUREEXTPROC __glewBindTextureEXT; -GLEW_FUN_EXPORT PFNGLDELETETEXTURESEXTPROC __glewDeleteTexturesEXT; -GLEW_FUN_EXPORT PFNGLGENTEXTURESEXTPROC __glewGenTexturesEXT; -GLEW_FUN_EXPORT PFNGLISTEXTUREEXTPROC __glewIsTextureEXT; -GLEW_FUN_EXPORT PFNGLPRIORITIZETEXTURESEXTPROC __glewPrioritizeTexturesEXT; - -GLEW_FUN_EXPORT PFNGLTEXTURENORMALEXTPROC __glewTextureNormalEXT; - -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTI64VEXTPROC __glewGetQueryObjecti64vEXT; -GLEW_FUN_EXPORT PFNGLGETQUERYOBJECTUI64VEXTPROC __glewGetQueryObjectui64vEXT; - -GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKEXTPROC __glewBeginTransformFeedbackEXT; -GLEW_FUN_EXPORT PFNGLBINDBUFFERBASEEXTPROC __glewBindBufferBaseEXT; -GLEW_FUN_EXPORT PFNGLBINDBUFFEROFFSETEXTPROC __glewBindBufferOffsetEXT; -GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGEEXTPROC __glewBindBufferRangeEXT; -GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKEXTPROC __glewEndTransformFeedbackEXT; -GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC __glewGetTransformFeedbackVaryingEXT; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC __glewTransformFeedbackVaryingsEXT; - -GLEW_FUN_EXPORT PFNGLARRAYELEMENTEXTPROC __glewArrayElementEXT; -GLEW_FUN_EXPORT PFNGLCOLORPOINTEREXTPROC __glewColorPointerEXT; -GLEW_FUN_EXPORT PFNGLDRAWARRAYSEXTPROC __glewDrawArraysEXT; -GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTEREXTPROC __glewEdgeFlagPointerEXT; -GLEW_FUN_EXPORT PFNGLINDEXPOINTEREXTPROC __glewIndexPointerEXT; -GLEW_FUN_EXPORT PFNGLNORMALPOINTEREXTPROC __glewNormalPointerEXT; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTEREXTPROC __glewTexCoordPointerEXT; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTEREXTPROC __glewVertexPointerEXT; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLDVEXTPROC __glewGetVertexAttribLdvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC __glewVertexArrayVertexAttribLOffsetEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DEXTPROC __glewVertexAttribL1dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1DVEXTPROC __glewVertexAttribL1dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DEXTPROC __glewVertexAttribL2dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2DVEXTPROC __glewVertexAttribL2dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DEXTPROC __glewVertexAttribL3dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3DVEXTPROC __glewVertexAttribL3dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DEXTPROC __glewVertexAttribL4dEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4DVEXTPROC __glewVertexAttribL4dvEXT; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLPOINTEREXTPROC __glewVertexAttribLPointerEXT; - -GLEW_FUN_EXPORT PFNGLBEGINVERTEXSHADEREXTPROC __glewBeginVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLBINDLIGHTPARAMETEREXTPROC __glewBindLightParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDMATERIALPARAMETEREXTPROC __glewBindMaterialParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDPARAMETEREXTPROC __glewBindParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDTEXGENPARAMETEREXTPROC __glewBindTexGenParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDTEXTUREUNITPARAMETEREXTPROC __glewBindTextureUnitParameterEXT; -GLEW_FUN_EXPORT PFNGLBINDVERTEXSHADEREXTPROC __glewBindVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLDELETEVERTEXSHADEREXTPROC __glewDeleteVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC __glewDisableVariantClientStateEXT; -GLEW_FUN_EXPORT PFNGLENABLEVARIANTCLIENTSTATEEXTPROC __glewEnableVariantClientStateEXT; -GLEW_FUN_EXPORT PFNGLENDVERTEXSHADEREXTPROC __glewEndVertexShaderEXT; -GLEW_FUN_EXPORT PFNGLEXTRACTCOMPONENTEXTPROC __glewExtractComponentEXT; -GLEW_FUN_EXPORT PFNGLGENSYMBOLSEXTPROC __glewGenSymbolsEXT; -GLEW_FUN_EXPORT PFNGLGENVERTEXSHADERSEXTPROC __glewGenVertexShadersEXT; -GLEW_FUN_EXPORT PFNGLGETINVARIANTBOOLEANVEXTPROC __glewGetInvariantBooleanvEXT; -GLEW_FUN_EXPORT PFNGLGETINVARIANTFLOATVEXTPROC __glewGetInvariantFloatvEXT; -GLEW_FUN_EXPORT PFNGLGETINVARIANTINTEGERVEXTPROC __glewGetInvariantIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC __glewGetLocalConstantBooleanvEXT; -GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTFLOATVEXTPROC __glewGetLocalConstantFloatvEXT; -GLEW_FUN_EXPORT PFNGLGETLOCALCONSTANTINTEGERVEXTPROC __glewGetLocalConstantIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTBOOLEANVEXTPROC __glewGetVariantBooleanvEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTFLOATVEXTPROC __glewGetVariantFloatvEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTINTEGERVEXTPROC __glewGetVariantIntegervEXT; -GLEW_FUN_EXPORT PFNGLGETVARIANTPOINTERVEXTPROC __glewGetVariantPointervEXT; -GLEW_FUN_EXPORT PFNGLINSERTCOMPONENTEXTPROC __glewInsertComponentEXT; -GLEW_FUN_EXPORT PFNGLISVARIANTENABLEDEXTPROC __glewIsVariantEnabledEXT; -GLEW_FUN_EXPORT PFNGLSETINVARIANTEXTPROC __glewSetInvariantEXT; -GLEW_FUN_EXPORT PFNGLSETLOCALCONSTANTEXTPROC __glewSetLocalConstantEXT; -GLEW_FUN_EXPORT PFNGLSHADEROP1EXTPROC __glewShaderOp1EXT; -GLEW_FUN_EXPORT PFNGLSHADEROP2EXTPROC __glewShaderOp2EXT; -GLEW_FUN_EXPORT PFNGLSHADEROP3EXTPROC __glewShaderOp3EXT; -GLEW_FUN_EXPORT PFNGLSWIZZLEEXTPROC __glewSwizzleEXT; -GLEW_FUN_EXPORT PFNGLVARIANTPOINTEREXTPROC __glewVariantPointerEXT; -GLEW_FUN_EXPORT PFNGLVARIANTBVEXTPROC __glewVariantbvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTDVEXTPROC __glewVariantdvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTFVEXTPROC __glewVariantfvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTIVEXTPROC __glewVariantivEXT; -GLEW_FUN_EXPORT PFNGLVARIANTSVEXTPROC __glewVariantsvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTUBVEXTPROC __glewVariantubvEXT; -GLEW_FUN_EXPORT PFNGLVARIANTUIVEXTPROC __glewVariantuivEXT; -GLEW_FUN_EXPORT PFNGLVARIANTUSVEXTPROC __glewVariantusvEXT; -GLEW_FUN_EXPORT PFNGLWRITEMASKEXTPROC __glewWriteMaskEXT; - -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTPOINTEREXTPROC __glewVertexWeightPointerEXT; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTFEXTPROC __glewVertexWeightfEXT; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTFVEXTPROC __glewVertexWeightfvEXT; - -GLEW_FUN_EXPORT PFNGLIMPORTSYNCEXTPROC __glewImportSyncEXT; - -GLEW_FUN_EXPORT PFNGLFRAMETERMINATORGREMEDYPROC __glewFrameTerminatorGREMEDY; - -GLEW_FUN_EXPORT PFNGLSTRINGMARKERGREMEDYPROC __glewStringMarkerGREMEDY; - -GLEW_FUN_EXPORT PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC __glewGetImageTransformParameterfvHP; -GLEW_FUN_EXPORT PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC __glewGetImageTransformParameterivHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERFHPPROC __glewImageTransformParameterfHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERFVHPPROC __glewImageTransformParameterfvHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERIHPPROC __glewImageTransformParameteriHP; -GLEW_FUN_EXPORT PFNGLIMAGETRANSFORMPARAMETERIVHPPROC __glewImageTransformParameterivHP; - -GLEW_FUN_EXPORT PFNGLMULTIMODEDRAWARRAYSIBMPROC __glewMultiModeDrawArraysIBM; -GLEW_FUN_EXPORT PFNGLMULTIMODEDRAWELEMENTSIBMPROC __glewMultiModeDrawElementsIBM; - -GLEW_FUN_EXPORT PFNGLCOLORPOINTERLISTIBMPROC __glewColorPointerListIBM; -GLEW_FUN_EXPORT PFNGLEDGEFLAGPOINTERLISTIBMPROC __glewEdgeFlagPointerListIBM; -GLEW_FUN_EXPORT PFNGLFOGCOORDPOINTERLISTIBMPROC __glewFogCoordPointerListIBM; -GLEW_FUN_EXPORT PFNGLINDEXPOINTERLISTIBMPROC __glewIndexPointerListIBM; -GLEW_FUN_EXPORT PFNGLNORMALPOINTERLISTIBMPROC __glewNormalPointerListIBM; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORPOINTERLISTIBMPROC __glewSecondaryColorPointerListIBM; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERLISTIBMPROC __glewTexCoordPointerListIBM; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTERLISTIBMPROC __glewVertexPointerListIBM; - -GLEW_FUN_EXPORT PFNGLMAPTEXTURE2DINTELPROC __glewMapTexture2DINTEL; -GLEW_FUN_EXPORT PFNGLSYNCTEXTUREINTELPROC __glewSyncTextureINTEL; -GLEW_FUN_EXPORT PFNGLUNMAPTEXTURE2DINTELPROC __glewUnmapTexture2DINTEL; - -GLEW_FUN_EXPORT PFNGLCOLORPOINTERVINTELPROC __glewColorPointervINTEL; -GLEW_FUN_EXPORT PFNGLNORMALPOINTERVINTELPROC __glewNormalPointervINTEL; -GLEW_FUN_EXPORT PFNGLTEXCOORDPOINTERVINTELPROC __glewTexCoordPointervINTEL; -GLEW_FUN_EXPORT PFNGLVERTEXPOINTERVINTELPROC __glewVertexPointervINTEL; - -GLEW_FUN_EXPORT PFNGLTEXSCISSORFUNCINTELPROC __glewTexScissorFuncINTEL; -GLEW_FUN_EXPORT PFNGLTEXSCISSORINTELPROC __glewTexScissorINTEL; - -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECALLBACKPROC __glewDebugMessageCallback; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGECONTROLPROC __glewDebugMessageControl; -GLEW_FUN_EXPORT PFNGLDEBUGMESSAGEINSERTPROC __glewDebugMessageInsert; -GLEW_FUN_EXPORT PFNGLGETDEBUGMESSAGELOGPROC __glewGetDebugMessageLog; -GLEW_FUN_EXPORT PFNGLGETOBJECTLABELPROC __glewGetObjectLabel; -GLEW_FUN_EXPORT PFNGLGETOBJECTPTRLABELPROC __glewGetObjectPtrLabel; -GLEW_FUN_EXPORT PFNGLOBJECTLABELPROC __glewObjectLabel; -GLEW_FUN_EXPORT PFNGLOBJECTPTRLABELPROC __glewObjectPtrLabel; -GLEW_FUN_EXPORT PFNGLPOPDEBUGGROUPPROC __glewPopDebugGroup; -GLEW_FUN_EXPORT PFNGLPUSHDEBUGGROUPPROC __glewPushDebugGroup; - -GLEW_FUN_EXPORT PFNGLBUFFERREGIONENABLEDPROC __glewBufferRegionEnabled; -GLEW_FUN_EXPORT PFNGLDELETEBUFFERREGIONPROC __glewDeleteBufferRegion; -GLEW_FUN_EXPORT PFNGLDRAWBUFFERREGIONPROC __glewDrawBufferRegion; -GLEW_FUN_EXPORT PFNGLNEWBUFFERREGIONPROC __glewNewBufferRegion; -GLEW_FUN_EXPORT PFNGLREADBUFFERREGIONPROC __glewReadBufferRegion; - -GLEW_FUN_EXPORT PFNGLRESIZEBUFFERSMESAPROC __glewResizeBuffersMESA; - -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DMESAPROC __glewWindowPos2dMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2DVMESAPROC __glewWindowPos2dvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FMESAPROC __glewWindowPos2fMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2FVMESAPROC __glewWindowPos2fvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IMESAPROC __glewWindowPos2iMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2IVMESAPROC __glewWindowPos2ivMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SMESAPROC __glewWindowPos2sMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS2SVMESAPROC __glewWindowPos2svMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DMESAPROC __glewWindowPos3dMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3DVMESAPROC __glewWindowPos3dvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FMESAPROC __glewWindowPos3fMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3FVMESAPROC __glewWindowPos3fvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IMESAPROC __glewWindowPos3iMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3IVMESAPROC __glewWindowPos3ivMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SMESAPROC __glewWindowPos3sMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS3SVMESAPROC __glewWindowPos3svMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4DMESAPROC __glewWindowPos4dMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4DVMESAPROC __glewWindowPos4dvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4FMESAPROC __glewWindowPos4fMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4FVMESAPROC __glewWindowPos4fvMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4IMESAPROC __glewWindowPos4iMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4IVMESAPROC __glewWindowPos4ivMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4SMESAPROC __glewWindowPos4sMESA; -GLEW_FUN_EXPORT PFNGLWINDOWPOS4SVMESAPROC __glewWindowPos4svMESA; - -GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERNVXPROC __glewBeginConditionalRenderNVX; -GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERNVXPROC __glewEndConditionalRenderNVX; - -GLEW_FUN_EXPORT PFNGLMULTIDRAWARRAYSINDIRECTBINDLESSNVPROC __glewMultiDrawArraysIndirectBindlessNV; -GLEW_FUN_EXPORT PFNGLMULTIDRAWELEMENTSINDIRECTBINDLESSNVPROC __glewMultiDrawElementsIndirectBindlessNV; - -GLEW_FUN_EXPORT PFNGLGETIMAGEHANDLENVPROC __glewGetImageHandleNV; -GLEW_FUN_EXPORT PFNGLGETTEXTUREHANDLENVPROC __glewGetTextureHandleNV; -GLEW_FUN_EXPORT PFNGLGETTEXTURESAMPLERHANDLENVPROC __glewGetTextureSamplerHandleNV; -GLEW_FUN_EXPORT PFNGLISIMAGEHANDLERESIDENTNVPROC __glewIsImageHandleResidentNV; -GLEW_FUN_EXPORT PFNGLISTEXTUREHANDLERESIDENTNVPROC __glewIsTextureHandleResidentNV; -GLEW_FUN_EXPORT PFNGLMAKEIMAGEHANDLENONRESIDENTNVPROC __glewMakeImageHandleNonResidentNV; -GLEW_FUN_EXPORT PFNGLMAKEIMAGEHANDLERESIDENTNVPROC __glewMakeImageHandleResidentNV; -GLEW_FUN_EXPORT PFNGLMAKETEXTUREHANDLENONRESIDENTNVPROC __glewMakeTextureHandleNonResidentNV; -GLEW_FUN_EXPORT PFNGLMAKETEXTUREHANDLERESIDENTNVPROC __glewMakeTextureHandleResidentNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMHANDLEUI64NVPROC __glewProgramUniformHandleui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMHANDLEUI64VNVPROC __glewProgramUniformHandleui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORMHANDLEUI64NVPROC __glewUniformHandleui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORMHANDLEUI64VNVPROC __glewUniformHandleui64vNV; - -GLEW_FUN_EXPORT PFNGLBLENDBARRIERNVPROC __glewBlendBarrierNV; -GLEW_FUN_EXPORT PFNGLBLENDPARAMETERINVPROC __glewBlendParameteriNV; - -GLEW_FUN_EXPORT PFNGLBEGINCONDITIONALRENDERNVPROC __glewBeginConditionalRenderNV; -GLEW_FUN_EXPORT PFNGLENDCONDITIONALRENDERNVPROC __glewEndConditionalRenderNV; - -GLEW_FUN_EXPORT PFNGLCOPYIMAGESUBDATANVPROC __glewCopyImageSubDataNV; - -GLEW_FUN_EXPORT PFNGLCLEARDEPTHDNVPROC __glewClearDepthdNV; -GLEW_FUN_EXPORT PFNGLDEPTHBOUNDSDNVPROC __glewDepthBoundsdNV; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEDNVPROC __glewDepthRangedNV; - -GLEW_FUN_EXPORT PFNGLDRAWTEXTURENVPROC __glewDrawTextureNV; - -GLEW_FUN_EXPORT PFNGLEVALMAPSNVPROC __glewEvalMapsNV; -GLEW_FUN_EXPORT PFNGLGETMAPATTRIBPARAMETERFVNVPROC __glewGetMapAttribParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETMAPATTRIBPARAMETERIVNVPROC __glewGetMapAttribParameterivNV; -GLEW_FUN_EXPORT PFNGLGETMAPCONTROLPOINTSNVPROC __glewGetMapControlPointsNV; -GLEW_FUN_EXPORT PFNGLGETMAPPARAMETERFVNVPROC __glewGetMapParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETMAPPARAMETERIVNVPROC __glewGetMapParameterivNV; -GLEW_FUN_EXPORT PFNGLMAPCONTROLPOINTSNVPROC __glewMapControlPointsNV; -GLEW_FUN_EXPORT PFNGLMAPPARAMETERFVNVPROC __glewMapParameterfvNV; -GLEW_FUN_EXPORT PFNGLMAPPARAMETERIVNVPROC __glewMapParameterivNV; - -GLEW_FUN_EXPORT PFNGLGETMULTISAMPLEFVNVPROC __glewGetMultisamplefvNV; -GLEW_FUN_EXPORT PFNGLSAMPLEMASKINDEXEDNVPROC __glewSampleMaskIndexedNV; -GLEW_FUN_EXPORT PFNGLTEXRENDERBUFFERNVPROC __glewTexRenderbufferNV; - -GLEW_FUN_EXPORT PFNGLDELETEFENCESNVPROC __glewDeleteFencesNV; -GLEW_FUN_EXPORT PFNGLFINISHFENCENVPROC __glewFinishFenceNV; -GLEW_FUN_EXPORT PFNGLGENFENCESNVPROC __glewGenFencesNV; -GLEW_FUN_EXPORT PFNGLGETFENCEIVNVPROC __glewGetFenceivNV; -GLEW_FUN_EXPORT PFNGLISFENCENVPROC __glewIsFenceNV; -GLEW_FUN_EXPORT PFNGLSETFENCENVPROC __glewSetFenceNV; -GLEW_FUN_EXPORT PFNGLTESTFENCENVPROC __glewTestFenceNV; - -GLEW_FUN_EXPORT PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC __glewGetProgramNamedParameterdvNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC __glewGetProgramNamedParameterfvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4DNVPROC __glewProgramNamedParameter4dNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC __glewProgramNamedParameter4dvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4FNVPROC __glewProgramNamedParameter4fNV; -GLEW_FUN_EXPORT PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC __glewProgramNamedParameter4fvNV; - -GLEW_FUN_EXPORT PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC __glewRenderbufferStorageMultisampleCoverageNV; - -GLEW_FUN_EXPORT PFNGLPROGRAMVERTEXLIMITNVPROC __glewProgramVertexLimitNV; - -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4INVPROC __glewProgramEnvParameterI4iNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4IVNVPROC __glewProgramEnvParameterI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4UINVPROC __glewProgramEnvParameterI4uiNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERI4UIVNVPROC __glewProgramEnvParameterI4uivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERSI4IVNVPROC __glewProgramEnvParametersI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC __glewProgramEnvParametersI4uivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4INVPROC __glewProgramLocalParameterI4iNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC __glewProgramLocalParameterI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4UINVPROC __glewProgramLocalParameterI4uiNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC __glewProgramLocalParameterI4uivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC __glewProgramLocalParametersI4ivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC __glewProgramLocalParametersI4uivNV; - -GLEW_FUN_EXPORT PFNGLGETUNIFORMI64VNVPROC __glewGetUniformi64vNV; -GLEW_FUN_EXPORT PFNGLGETUNIFORMUI64VNVPROC __glewGetUniformui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1I64NVPROC __glewProgramUniform1i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1I64VNVPROC __glewProgramUniform1i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UI64NVPROC __glewProgramUniform1ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM1UI64VNVPROC __glewProgramUniform1ui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2I64NVPROC __glewProgramUniform2i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2I64VNVPROC __glewProgramUniform2i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UI64NVPROC __glewProgramUniform2ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM2UI64VNVPROC __glewProgramUniform2ui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3I64NVPROC __glewProgramUniform3i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3I64VNVPROC __glewProgramUniform3i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UI64NVPROC __glewProgramUniform3ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM3UI64VNVPROC __glewProgramUniform3ui64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4I64NVPROC __glewProgramUniform4i64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4I64VNVPROC __glewProgramUniform4i64vNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UI64NVPROC __glewProgramUniform4ui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORM4UI64VNVPROC __glewProgramUniform4ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM1I64NVPROC __glewUniform1i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM1I64VNVPROC __glewUniform1i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM1UI64NVPROC __glewUniform1ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM1UI64VNVPROC __glewUniform1ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM2I64NVPROC __glewUniform2i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM2I64VNVPROC __glewUniform2i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM2UI64NVPROC __glewUniform2ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM2UI64VNVPROC __glewUniform2ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM3I64NVPROC __glewUniform3i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM3I64VNVPROC __glewUniform3i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM3UI64NVPROC __glewUniform3ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM3UI64VNVPROC __glewUniform3ui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM4I64NVPROC __glewUniform4i64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM4I64VNVPROC __glewUniform4i64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORM4UI64NVPROC __glewUniform4ui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORM4UI64VNVPROC __glewUniform4ui64vNV; - -GLEW_FUN_EXPORT PFNGLCOLOR3HNVPROC __glewColor3hNV; -GLEW_FUN_EXPORT PFNGLCOLOR3HVNVPROC __glewColor3hvNV; -GLEW_FUN_EXPORT PFNGLCOLOR4HNVPROC __glewColor4hNV; -GLEW_FUN_EXPORT PFNGLCOLOR4HVNVPROC __glewColor4hvNV; -GLEW_FUN_EXPORT PFNGLFOGCOORDHNVPROC __glewFogCoordhNV; -GLEW_FUN_EXPORT PFNGLFOGCOORDHVNVPROC __glewFogCoordhvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1HNVPROC __glewMultiTexCoord1hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD1HVNVPROC __glewMultiTexCoord1hvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2HNVPROC __glewMultiTexCoord2hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD2HVNVPROC __glewMultiTexCoord2hvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3HNVPROC __glewMultiTexCoord3hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD3HVNVPROC __glewMultiTexCoord3hvNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4HNVPROC __glewMultiTexCoord4hNV; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4HVNVPROC __glewMultiTexCoord4hvNV; -GLEW_FUN_EXPORT PFNGLNORMAL3HNVPROC __glewNormal3hNV; -GLEW_FUN_EXPORT PFNGLNORMAL3HVNVPROC __glewNormal3hvNV; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3HNVPROC __glewSecondaryColor3hNV; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLOR3HVNVPROC __glewSecondaryColor3hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD1HNVPROC __glewTexCoord1hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD1HVNVPROC __glewTexCoord1hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD2HNVPROC __glewTexCoord2hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD2HVNVPROC __glewTexCoord2hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD3HNVPROC __glewTexCoord3hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD3HVNVPROC __glewTexCoord3hvNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD4HNVPROC __glewTexCoord4hNV; -GLEW_FUN_EXPORT PFNGLTEXCOORD4HVNVPROC __glewTexCoord4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEX2HNVPROC __glewVertex2hNV; -GLEW_FUN_EXPORT PFNGLVERTEX2HVNVPROC __glewVertex2hvNV; -GLEW_FUN_EXPORT PFNGLVERTEX3HNVPROC __glewVertex3hNV; -GLEW_FUN_EXPORT PFNGLVERTEX3HVNVPROC __glewVertex3hvNV; -GLEW_FUN_EXPORT PFNGLVERTEX4HNVPROC __glewVertex4hNV; -GLEW_FUN_EXPORT PFNGLVERTEX4HVNVPROC __glewVertex4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1HNVPROC __glewVertexAttrib1hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1HVNVPROC __glewVertexAttrib1hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2HNVPROC __glewVertexAttrib2hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2HVNVPROC __glewVertexAttrib2hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3HNVPROC __glewVertexAttrib3hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3HVNVPROC __glewVertexAttrib3hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4HNVPROC __glewVertexAttrib4hNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4HVNVPROC __glewVertexAttrib4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1HVNVPROC __glewVertexAttribs1hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2HVNVPROC __glewVertexAttribs2hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3HVNVPROC __glewVertexAttribs3hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4HVNVPROC __glewVertexAttribs4hvNV; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTHNVPROC __glewVertexWeighthNV; -GLEW_FUN_EXPORT PFNGLVERTEXWEIGHTHVNVPROC __glewVertexWeighthvNV; - -GLEW_FUN_EXPORT PFNGLBEGINOCCLUSIONQUERYNVPROC __glewBeginOcclusionQueryNV; -GLEW_FUN_EXPORT PFNGLDELETEOCCLUSIONQUERIESNVPROC __glewDeleteOcclusionQueriesNV; -GLEW_FUN_EXPORT PFNGLENDOCCLUSIONQUERYNVPROC __glewEndOcclusionQueryNV; -GLEW_FUN_EXPORT PFNGLGENOCCLUSIONQUERIESNVPROC __glewGenOcclusionQueriesNV; -GLEW_FUN_EXPORT PFNGLGETOCCLUSIONQUERYIVNVPROC __glewGetOcclusionQueryivNV; -GLEW_FUN_EXPORT PFNGLGETOCCLUSIONQUERYUIVNVPROC __glewGetOcclusionQueryuivNV; -GLEW_FUN_EXPORT PFNGLISOCCLUSIONQUERYNVPROC __glewIsOcclusionQueryNV; - -GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC __glewProgramBufferParametersIivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC __glewProgramBufferParametersIuivNV; -GLEW_FUN_EXPORT PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC __glewProgramBufferParametersfvNV; - -GLEW_FUN_EXPORT PFNGLCOPYPATHNVPROC __glewCopyPathNV; -GLEW_FUN_EXPORT PFNGLCOVERFILLPATHINSTANCEDNVPROC __glewCoverFillPathInstancedNV; -GLEW_FUN_EXPORT PFNGLCOVERFILLPATHNVPROC __glewCoverFillPathNV; -GLEW_FUN_EXPORT PFNGLCOVERSTROKEPATHINSTANCEDNVPROC __glewCoverStrokePathInstancedNV; -GLEW_FUN_EXPORT PFNGLCOVERSTROKEPATHNVPROC __glewCoverStrokePathNV; -GLEW_FUN_EXPORT PFNGLDELETEPATHSNVPROC __glewDeletePathsNV; -GLEW_FUN_EXPORT PFNGLGENPATHSNVPROC __glewGenPathsNV; -GLEW_FUN_EXPORT PFNGLGETPATHCOLORGENFVNVPROC __glewGetPathColorGenfvNV; -GLEW_FUN_EXPORT PFNGLGETPATHCOLORGENIVNVPROC __glewGetPathColorGenivNV; -GLEW_FUN_EXPORT PFNGLGETPATHCOMMANDSNVPROC __glewGetPathCommandsNV; -GLEW_FUN_EXPORT PFNGLGETPATHCOORDSNVPROC __glewGetPathCoordsNV; -GLEW_FUN_EXPORT PFNGLGETPATHDASHARRAYNVPROC __glewGetPathDashArrayNV; -GLEW_FUN_EXPORT PFNGLGETPATHLENGTHNVPROC __glewGetPathLengthNV; -GLEW_FUN_EXPORT PFNGLGETPATHMETRICRANGENVPROC __glewGetPathMetricRangeNV; -GLEW_FUN_EXPORT PFNGLGETPATHMETRICSNVPROC __glewGetPathMetricsNV; -GLEW_FUN_EXPORT PFNGLGETPATHPARAMETERFVNVPROC __glewGetPathParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETPATHPARAMETERIVNVPROC __glewGetPathParameterivNV; -GLEW_FUN_EXPORT PFNGLGETPATHSPACINGNVPROC __glewGetPathSpacingNV; -GLEW_FUN_EXPORT PFNGLGETPATHTEXGENFVNVPROC __glewGetPathTexGenfvNV; -GLEW_FUN_EXPORT PFNGLGETPATHTEXGENIVNVPROC __glewGetPathTexGenivNV; -GLEW_FUN_EXPORT PFNGLINTERPOLATEPATHSNVPROC __glewInterpolatePathsNV; -GLEW_FUN_EXPORT PFNGLISPATHNVPROC __glewIsPathNV; -GLEW_FUN_EXPORT PFNGLISPOINTINFILLPATHNVPROC __glewIsPointInFillPathNV; -GLEW_FUN_EXPORT PFNGLISPOINTINSTROKEPATHNVPROC __glewIsPointInStrokePathNV; -GLEW_FUN_EXPORT PFNGLPATHCOLORGENNVPROC __glewPathColorGenNV; -GLEW_FUN_EXPORT PFNGLPATHCOMMANDSNVPROC __glewPathCommandsNV; -GLEW_FUN_EXPORT PFNGLPATHCOORDSNVPROC __glewPathCoordsNV; -GLEW_FUN_EXPORT PFNGLPATHCOVERDEPTHFUNCNVPROC __glewPathCoverDepthFuncNV; -GLEW_FUN_EXPORT PFNGLPATHDASHARRAYNVPROC __glewPathDashArrayNV; -GLEW_FUN_EXPORT PFNGLPATHFOGGENNVPROC __glewPathFogGenNV; -GLEW_FUN_EXPORT PFNGLPATHGLYPHRANGENVPROC __glewPathGlyphRangeNV; -GLEW_FUN_EXPORT PFNGLPATHGLYPHSNVPROC __glewPathGlyphsNV; -GLEW_FUN_EXPORT PFNGLPATHPARAMETERFNVPROC __glewPathParameterfNV; -GLEW_FUN_EXPORT PFNGLPATHPARAMETERFVNVPROC __glewPathParameterfvNV; -GLEW_FUN_EXPORT PFNGLPATHPARAMETERINVPROC __glewPathParameteriNV; -GLEW_FUN_EXPORT PFNGLPATHPARAMETERIVNVPROC __glewPathParameterivNV; -GLEW_FUN_EXPORT PFNGLPATHSTENCILDEPTHOFFSETNVPROC __glewPathStencilDepthOffsetNV; -GLEW_FUN_EXPORT PFNGLPATHSTENCILFUNCNVPROC __glewPathStencilFuncNV; -GLEW_FUN_EXPORT PFNGLPATHSTRINGNVPROC __glewPathStringNV; -GLEW_FUN_EXPORT PFNGLPATHSUBCOMMANDSNVPROC __glewPathSubCommandsNV; -GLEW_FUN_EXPORT PFNGLPATHSUBCOORDSNVPROC __glewPathSubCoordsNV; -GLEW_FUN_EXPORT PFNGLPATHTEXGENNVPROC __glewPathTexGenNV; -GLEW_FUN_EXPORT PFNGLPOINTALONGPATHNVPROC __glewPointAlongPathNV; -GLEW_FUN_EXPORT PFNGLSTENCILFILLPATHINSTANCEDNVPROC __glewStencilFillPathInstancedNV; -GLEW_FUN_EXPORT PFNGLSTENCILFILLPATHNVPROC __glewStencilFillPathNV; -GLEW_FUN_EXPORT PFNGLSTENCILSTROKEPATHINSTANCEDNVPROC __glewStencilStrokePathInstancedNV; -GLEW_FUN_EXPORT PFNGLSTENCILSTROKEPATHNVPROC __glewStencilStrokePathNV; -GLEW_FUN_EXPORT PFNGLTRANSFORMPATHNVPROC __glewTransformPathNV; -GLEW_FUN_EXPORT PFNGLWEIGHTPATHSNVPROC __glewWeightPathsNV; - -GLEW_FUN_EXPORT PFNGLFLUSHPIXELDATARANGENVPROC __glewFlushPixelDataRangeNV; -GLEW_FUN_EXPORT PFNGLPIXELDATARANGENVPROC __glewPixelDataRangeNV; - -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERINVPROC __glewPointParameteriNV; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERIVNVPROC __glewPointParameterivNV; - -GLEW_FUN_EXPORT PFNGLGETVIDEOI64VNVPROC __glewGetVideoi64vNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOIVNVPROC __glewGetVideoivNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOUI64VNVPROC __glewGetVideoui64vNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOUIVNVPROC __glewGetVideouivNV; -GLEW_FUN_EXPORT PFNGLPRESENTFRAMEDUALFILLNVPROC __glewPresentFrameDualFillNV; -GLEW_FUN_EXPORT PFNGLPRESENTFRAMEKEYEDNVPROC __glewPresentFrameKeyedNV; - -GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTINDEXNVPROC __glewPrimitiveRestartIndexNV; -GLEW_FUN_EXPORT PFNGLPRIMITIVERESTARTNVPROC __glewPrimitiveRestartNV; - -GLEW_FUN_EXPORT PFNGLCOMBINERINPUTNVPROC __glewCombinerInputNV; -GLEW_FUN_EXPORT PFNGLCOMBINEROUTPUTNVPROC __glewCombinerOutputNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERFNVPROC __glewCombinerParameterfNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERFVNVPROC __glewCombinerParameterfvNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERINVPROC __glewCombinerParameteriNV; -GLEW_FUN_EXPORT PFNGLCOMBINERPARAMETERIVNVPROC __glewCombinerParameterivNV; -GLEW_FUN_EXPORT PFNGLFINALCOMBINERINPUTNVPROC __glewFinalCombinerInputNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC __glewGetCombinerInputParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC __glewGetCombinerInputParameterivNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC __glewGetCombinerOutputParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC __glewGetCombinerOutputParameterivNV; -GLEW_FUN_EXPORT PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC __glewGetFinalCombinerInputParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC __glewGetFinalCombinerInputParameterivNV; - -GLEW_FUN_EXPORT PFNGLCOMBINERSTAGEPARAMETERFVNVPROC __glewCombinerStageParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC __glewGetCombinerStageParameterfvNV; - -GLEW_FUN_EXPORT PFNGLGETBUFFERPARAMETERUI64VNVPROC __glewGetBufferParameterui64vNV; -GLEW_FUN_EXPORT PFNGLGETINTEGERUI64VNVPROC __glewGetIntegerui64vNV; -GLEW_FUN_EXPORT PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC __glewGetNamedBufferParameterui64vNV; -GLEW_FUN_EXPORT PFNGLISBUFFERRESIDENTNVPROC __glewIsBufferResidentNV; -GLEW_FUN_EXPORT PFNGLISNAMEDBUFFERRESIDENTNVPROC __glewIsNamedBufferResidentNV; -GLEW_FUN_EXPORT PFNGLMAKEBUFFERNONRESIDENTNVPROC __glewMakeBufferNonResidentNV; -GLEW_FUN_EXPORT PFNGLMAKEBUFFERRESIDENTNVPROC __glewMakeBufferResidentNV; -GLEW_FUN_EXPORT PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC __glewMakeNamedBufferNonResidentNV; -GLEW_FUN_EXPORT PFNGLMAKENAMEDBUFFERRESIDENTNVPROC __glewMakeNamedBufferResidentNV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMUI64NVPROC __glewProgramUniformui64NV; -GLEW_FUN_EXPORT PFNGLPROGRAMUNIFORMUI64VNVPROC __glewProgramUniformui64vNV; -GLEW_FUN_EXPORT PFNGLUNIFORMUI64NVPROC __glewUniformui64NV; -GLEW_FUN_EXPORT PFNGLUNIFORMUI64VNVPROC __glewUniformui64vNV; - -GLEW_FUN_EXPORT PFNGLTEXTUREBARRIERNVPROC __glewTextureBarrierNV; - -GLEW_FUN_EXPORT PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC __glewTexImage2DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC __glewTexImage3DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC __glewTextureImage2DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC __glewTextureImage2DMultisampleNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC __glewTextureImage3DMultisampleCoverageNV; -GLEW_FUN_EXPORT PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC __glewTextureImage3DMultisampleNV; - -GLEW_FUN_EXPORT PFNGLACTIVEVARYINGNVPROC __glewActiveVaryingNV; -GLEW_FUN_EXPORT PFNGLBEGINTRANSFORMFEEDBACKNVPROC __glewBeginTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLBINDBUFFERBASENVPROC __glewBindBufferBaseNV; -GLEW_FUN_EXPORT PFNGLBINDBUFFEROFFSETNVPROC __glewBindBufferOffsetNV; -GLEW_FUN_EXPORT PFNGLBINDBUFFERRANGENVPROC __glewBindBufferRangeNV; -GLEW_FUN_EXPORT PFNGLENDTRANSFORMFEEDBACKNVPROC __glewEndTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLGETACTIVEVARYINGNVPROC __glewGetActiveVaryingNV; -GLEW_FUN_EXPORT PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC __glewGetTransformFeedbackVaryingNV; -GLEW_FUN_EXPORT PFNGLGETVARYINGLOCATIONNVPROC __glewGetVaryingLocationNV; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC __glewTransformFeedbackAttribsNV; -GLEW_FUN_EXPORT PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC __glewTransformFeedbackVaryingsNV; - -GLEW_FUN_EXPORT PFNGLBINDTRANSFORMFEEDBACKNVPROC __glewBindTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLDELETETRANSFORMFEEDBACKSNVPROC __glewDeleteTransformFeedbacksNV; -GLEW_FUN_EXPORT PFNGLDRAWTRANSFORMFEEDBACKNVPROC __glewDrawTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLGENTRANSFORMFEEDBACKSNVPROC __glewGenTransformFeedbacksNV; -GLEW_FUN_EXPORT PFNGLISTRANSFORMFEEDBACKNVPROC __glewIsTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLPAUSETRANSFORMFEEDBACKNVPROC __glewPauseTransformFeedbackNV; -GLEW_FUN_EXPORT PFNGLRESUMETRANSFORMFEEDBACKNVPROC __glewResumeTransformFeedbackNV; - -GLEW_FUN_EXPORT PFNGLVDPAUFININVPROC __glewVDPAUFiniNV; -GLEW_FUN_EXPORT PFNGLVDPAUGETSURFACEIVNVPROC __glewVDPAUGetSurfaceivNV; -GLEW_FUN_EXPORT PFNGLVDPAUINITNVPROC __glewVDPAUInitNV; -GLEW_FUN_EXPORT PFNGLVDPAUISSURFACENVPROC __glewVDPAUIsSurfaceNV; -GLEW_FUN_EXPORT PFNGLVDPAUMAPSURFACESNVPROC __glewVDPAUMapSurfacesNV; -GLEW_FUN_EXPORT PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC __glewVDPAURegisterOutputSurfaceNV; -GLEW_FUN_EXPORT PFNGLVDPAUREGISTERVIDEOSURFACENVPROC __glewVDPAURegisterVideoSurfaceNV; -GLEW_FUN_EXPORT PFNGLVDPAUSURFACEACCESSNVPROC __glewVDPAUSurfaceAccessNV; -GLEW_FUN_EXPORT PFNGLVDPAUUNMAPSURFACESNVPROC __glewVDPAUUnmapSurfacesNV; -GLEW_FUN_EXPORT PFNGLVDPAUUNREGISTERSURFACENVPROC __glewVDPAUUnregisterSurfaceNV; - -GLEW_FUN_EXPORT PFNGLFLUSHVERTEXARRAYRANGENVPROC __glewFlushVertexArrayRangeNV; -GLEW_FUN_EXPORT PFNGLVERTEXARRAYRANGENVPROC __glewVertexArrayRangeNV; - -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLI64VNVPROC __glewGetVertexAttribLi64vNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBLUI64VNVPROC __glewGetVertexAttribLui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1I64NVPROC __glewVertexAttribL1i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1I64VNVPROC __glewVertexAttribL1i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64NVPROC __glewVertexAttribL1ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL1UI64VNVPROC __glewVertexAttribL1ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2I64NVPROC __glewVertexAttribL2i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2I64VNVPROC __glewVertexAttribL2i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2UI64NVPROC __glewVertexAttribL2ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL2UI64VNVPROC __glewVertexAttribL2ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3I64NVPROC __glewVertexAttribL3i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3I64VNVPROC __glewVertexAttribL3i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3UI64NVPROC __glewVertexAttribL3ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL3UI64VNVPROC __glewVertexAttribL3ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4I64NVPROC __glewVertexAttribL4i64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4I64VNVPROC __glewVertexAttribL4i64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4UI64NVPROC __glewVertexAttribL4ui64NV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBL4UI64VNVPROC __glewVertexAttribL4ui64vNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBLFORMATNVPROC __glewVertexAttribLFormatNV; - -GLEW_FUN_EXPORT PFNGLBUFFERADDRESSRANGENVPROC __glewBufferAddressRangeNV; -GLEW_FUN_EXPORT PFNGLCOLORFORMATNVPROC __glewColorFormatNV; -GLEW_FUN_EXPORT PFNGLEDGEFLAGFORMATNVPROC __glewEdgeFlagFormatNV; -GLEW_FUN_EXPORT PFNGLFOGCOORDFORMATNVPROC __glewFogCoordFormatNV; -GLEW_FUN_EXPORT PFNGLGETINTEGERUI64I_VNVPROC __glewGetIntegerui64i_vNV; -GLEW_FUN_EXPORT PFNGLINDEXFORMATNVPROC __glewIndexFormatNV; -GLEW_FUN_EXPORT PFNGLNORMALFORMATNVPROC __glewNormalFormatNV; -GLEW_FUN_EXPORT PFNGLSECONDARYCOLORFORMATNVPROC __glewSecondaryColorFormatNV; -GLEW_FUN_EXPORT PFNGLTEXCOORDFORMATNVPROC __glewTexCoordFormatNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBFORMATNVPROC __glewVertexAttribFormatNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBIFORMATNVPROC __glewVertexAttribIFormatNV; -GLEW_FUN_EXPORT PFNGLVERTEXFORMATNVPROC __glewVertexFormatNV; - -GLEW_FUN_EXPORT PFNGLAREPROGRAMSRESIDENTNVPROC __glewAreProgramsResidentNV; -GLEW_FUN_EXPORT PFNGLBINDPROGRAMNVPROC __glewBindProgramNV; -GLEW_FUN_EXPORT PFNGLDELETEPROGRAMSNVPROC __glewDeleteProgramsNV; -GLEW_FUN_EXPORT PFNGLEXECUTEPROGRAMNVPROC __glewExecuteProgramNV; -GLEW_FUN_EXPORT PFNGLGENPROGRAMSNVPROC __glewGenProgramsNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPARAMETERDVNVPROC __glewGetProgramParameterdvNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMPARAMETERFVNVPROC __glewGetProgramParameterfvNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMSTRINGNVPROC __glewGetProgramStringNV; -GLEW_FUN_EXPORT PFNGLGETPROGRAMIVNVPROC __glewGetProgramivNV; -GLEW_FUN_EXPORT PFNGLGETTRACKMATRIXIVNVPROC __glewGetTrackMatrixivNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBPOINTERVNVPROC __glewGetVertexAttribPointervNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBDVNVPROC __glewGetVertexAttribdvNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBFVNVPROC __glewGetVertexAttribfvNV; -GLEW_FUN_EXPORT PFNGLGETVERTEXATTRIBIVNVPROC __glewGetVertexAttribivNV; -GLEW_FUN_EXPORT PFNGLISPROGRAMNVPROC __glewIsProgramNV; -GLEW_FUN_EXPORT PFNGLLOADPROGRAMNVPROC __glewLoadProgramNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4DNVPROC __glewProgramParameter4dNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4DVNVPROC __glewProgramParameter4dvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4FNVPROC __glewProgramParameter4fNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETER4FVNVPROC __glewProgramParameter4fvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERS4DVNVPROC __glewProgramParameters4dvNV; -GLEW_FUN_EXPORT PFNGLPROGRAMPARAMETERS4FVNVPROC __glewProgramParameters4fvNV; -GLEW_FUN_EXPORT PFNGLREQUESTRESIDENTPROGRAMSNVPROC __glewRequestResidentProgramsNV; -GLEW_FUN_EXPORT PFNGLTRACKMATRIXNVPROC __glewTrackMatrixNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DNVPROC __glewVertexAttrib1dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1DVNVPROC __glewVertexAttrib1dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FNVPROC __glewVertexAttrib1fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1FVNVPROC __glewVertexAttrib1fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SNVPROC __glewVertexAttrib1sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB1SVNVPROC __glewVertexAttrib1svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DNVPROC __glewVertexAttrib2dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2DVNVPROC __glewVertexAttrib2dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FNVPROC __glewVertexAttrib2fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2FVNVPROC __glewVertexAttrib2fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SNVPROC __glewVertexAttrib2sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB2SVNVPROC __glewVertexAttrib2svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DNVPROC __glewVertexAttrib3dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3DVNVPROC __glewVertexAttrib3dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FNVPROC __glewVertexAttrib3fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3FVNVPROC __glewVertexAttrib3fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SNVPROC __glewVertexAttrib3sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB3SVNVPROC __glewVertexAttrib3svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DNVPROC __glewVertexAttrib4dNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4DVNVPROC __glewVertexAttrib4dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FNVPROC __glewVertexAttrib4fNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4FVNVPROC __glewVertexAttrib4fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SNVPROC __glewVertexAttrib4sNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4SVNVPROC __glewVertexAttrib4svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBNVPROC __glewVertexAttrib4ubNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIB4UBVNVPROC __glewVertexAttrib4ubvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBPOINTERNVPROC __glewVertexAttribPointerNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1DVNVPROC __glewVertexAttribs1dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1FVNVPROC __glewVertexAttribs1fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS1SVNVPROC __glewVertexAttribs1svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2DVNVPROC __glewVertexAttribs2dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2FVNVPROC __glewVertexAttribs2fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS2SVNVPROC __glewVertexAttribs2svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3DVNVPROC __glewVertexAttribs3dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3FVNVPROC __glewVertexAttribs3fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS3SVNVPROC __glewVertexAttribs3svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4DVNVPROC __glewVertexAttribs4dvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4FVNVPROC __glewVertexAttribs4fvNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4SVNVPROC __glewVertexAttribs4svNV; -GLEW_FUN_EXPORT PFNGLVERTEXATTRIBS4UBVNVPROC __glewVertexAttribs4ubvNV; - -GLEW_FUN_EXPORT PFNGLBEGINVIDEOCAPTURENVPROC __glewBeginVideoCaptureNV; -GLEW_FUN_EXPORT PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC __glewBindVideoCaptureStreamBufferNV; -GLEW_FUN_EXPORT PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC __glewBindVideoCaptureStreamTextureNV; -GLEW_FUN_EXPORT PFNGLENDVIDEOCAPTURENVPROC __glewEndVideoCaptureNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTURESTREAMDVNVPROC __glewGetVideoCaptureStreamdvNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTURESTREAMFVNVPROC __glewGetVideoCaptureStreamfvNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTURESTREAMIVNVPROC __glewGetVideoCaptureStreamivNV; -GLEW_FUN_EXPORT PFNGLGETVIDEOCAPTUREIVNVPROC __glewGetVideoCaptureivNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURENVPROC __glewVideoCaptureNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC __glewVideoCaptureStreamParameterdvNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC __glewVideoCaptureStreamParameterfvNV; -GLEW_FUN_EXPORT PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC __glewVideoCaptureStreamParameterivNV; - -GLEW_FUN_EXPORT PFNGLCLEARDEPTHFOESPROC __glewClearDepthfOES; -GLEW_FUN_EXPORT PFNGLCLIPPLANEFOESPROC __glewClipPlanefOES; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEFOESPROC __glewDepthRangefOES; -GLEW_FUN_EXPORT PFNGLFRUSTUMFOESPROC __glewFrustumfOES; -GLEW_FUN_EXPORT PFNGLGETCLIPPLANEFOESPROC __glewGetClipPlanefOES; -GLEW_FUN_EXPORT PFNGLORTHOFOESPROC __glewOrthofOES; - -GLEW_FUN_EXPORT PFNGLALPHAFUNCXPROC __glewAlphaFuncx; -GLEW_FUN_EXPORT PFNGLCLEARCOLORXPROC __glewClearColorx; -GLEW_FUN_EXPORT PFNGLCLEARDEPTHXPROC __glewClearDepthx; -GLEW_FUN_EXPORT PFNGLCOLOR4XPROC __glewColor4x; -GLEW_FUN_EXPORT PFNGLDEPTHRANGEXPROC __glewDepthRangex; -GLEW_FUN_EXPORT PFNGLFOGXPROC __glewFogx; -GLEW_FUN_EXPORT PFNGLFOGXVPROC __glewFogxv; -GLEW_FUN_EXPORT PFNGLFRUSTUMFPROC __glewFrustumf; -GLEW_FUN_EXPORT PFNGLFRUSTUMXPROC __glewFrustumx; -GLEW_FUN_EXPORT PFNGLLIGHTMODELXPROC __glewLightModelx; -GLEW_FUN_EXPORT PFNGLLIGHTMODELXVPROC __glewLightModelxv; -GLEW_FUN_EXPORT PFNGLLIGHTXPROC __glewLightx; -GLEW_FUN_EXPORT PFNGLLIGHTXVPROC __glewLightxv; -GLEW_FUN_EXPORT PFNGLLINEWIDTHXPROC __glewLineWidthx; -GLEW_FUN_EXPORT PFNGLLOADMATRIXXPROC __glewLoadMatrixx; -GLEW_FUN_EXPORT PFNGLMATERIALXPROC __glewMaterialx; -GLEW_FUN_EXPORT PFNGLMATERIALXVPROC __glewMaterialxv; -GLEW_FUN_EXPORT PFNGLMULTMATRIXXPROC __glewMultMatrixx; -GLEW_FUN_EXPORT PFNGLMULTITEXCOORD4XPROC __glewMultiTexCoord4x; -GLEW_FUN_EXPORT PFNGLNORMAL3XPROC __glewNormal3x; -GLEW_FUN_EXPORT PFNGLORTHOFPROC __glewOrthof; -GLEW_FUN_EXPORT PFNGLORTHOXPROC __glewOrthox; -GLEW_FUN_EXPORT PFNGLPOINTSIZEXPROC __glewPointSizex; -GLEW_FUN_EXPORT PFNGLPOLYGONOFFSETXPROC __glewPolygonOffsetx; -GLEW_FUN_EXPORT PFNGLROTATEXPROC __glewRotatex; -GLEW_FUN_EXPORT PFNGLSAMPLECOVERAGEXPROC __glewSampleCoveragex; -GLEW_FUN_EXPORT PFNGLSCALEXPROC __glewScalex; -GLEW_FUN_EXPORT PFNGLTEXENVXPROC __glewTexEnvx; -GLEW_FUN_EXPORT PFNGLTEXENVXVPROC __glewTexEnvxv; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERXPROC __glewTexParameterx; -GLEW_FUN_EXPORT PFNGLTRANSLATEXPROC __glewTranslatex; - -GLEW_FUN_EXPORT PFNGLCLIPPLANEFPROC __glewClipPlanef; -GLEW_FUN_EXPORT PFNGLCLIPPLANEXPROC __glewClipPlanex; -GLEW_FUN_EXPORT PFNGLGETCLIPPLANEFPROC __glewGetClipPlanef; -GLEW_FUN_EXPORT PFNGLGETCLIPPLANEXPROC __glewGetClipPlanex; -GLEW_FUN_EXPORT PFNGLGETFIXEDVPROC __glewGetFixedv; -GLEW_FUN_EXPORT PFNGLGETLIGHTXVPROC __glewGetLightxv; -GLEW_FUN_EXPORT PFNGLGETMATERIALXVPROC __glewGetMaterialxv; -GLEW_FUN_EXPORT PFNGLGETTEXENVXVPROC __glewGetTexEnvxv; -GLEW_FUN_EXPORT PFNGLGETTEXPARAMETERXVPROC __glewGetTexParameterxv; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERXPROC __glewPointParameterx; -GLEW_FUN_EXPORT PFNGLPOINTPARAMETERXVPROC __glewPointParameterxv; -GLEW_FUN_EXPORT PFNGLPOINTSIZEPOINTEROESPROC __glewPointSizePointerOES; -GLEW_FUN_EXPORT PFNGLTEXPARAMETERXVPROC __glewTexParameterxv; - -GLEW_FUN_EXPORT PFNGLERRORSTRINGREGALPROC __glewErrorStringREGAL; - -GLEW_FUN_EXPORT PFNGLGETEXTENSIONREGALPROC __glewGetExtensionREGAL; -GLEW_FUN_EXPORT PFNGLISSUPPORTEDREGALPROC __glewIsSupportedREGAL; - -GLEW_FUN_EXPORT PFNGLLOGMESSAGECALLBACKREGALPROC __glewLogMessageCallbackREGAL; - -GLEW_FUN_EXPORT PFNGLDETAILTEXFUNCSGISPROC __glewDetailTexFuncSGIS; -GLEW_FUN_EXPORT PFNGLGETDETAILTEXFUNCSGISPROC __glewGetDetailTexFuncSGIS; - -GLEW_FUN_EXPORT PFNGLFOGFUNCSGISPROC __glewFogFuncSGIS; -GLEW_FUN_EXPORT PFNGLGETFOGFUNCSGISPROC __glewGetFogFuncSGIS; - -GLEW_FUN_EXPORT PFNGLSAMPLEMASKSGISPROC __glewSampleMaskSGIS; -GLEW_FUN_EXPORT PFNGLSAMPLEPATTERNSGISPROC __glewSamplePatternSGIS; - -GLEW_FUN_EXPORT PFNGLGETSHARPENTEXFUNCSGISPROC __glewGetSharpenTexFuncSGIS; -GLEW_FUN_EXPORT PFNGLSHARPENTEXFUNCSGISPROC __glewSharpenTexFuncSGIS; - -GLEW_FUN_EXPORT PFNGLTEXIMAGE4DSGISPROC __glewTexImage4DSGIS; -GLEW_FUN_EXPORT PFNGLTEXSUBIMAGE4DSGISPROC __glewTexSubImage4DSGIS; - -GLEW_FUN_EXPORT PFNGLGETTEXFILTERFUNCSGISPROC __glewGetTexFilterFuncSGIS; -GLEW_FUN_EXPORT PFNGLTEXFILTERFUNCSGISPROC __glewTexFilterFuncSGIS; - -GLEW_FUN_EXPORT PFNGLASYNCMARKERSGIXPROC __glewAsyncMarkerSGIX; -GLEW_FUN_EXPORT PFNGLDELETEASYNCMARKERSSGIXPROC __glewDeleteAsyncMarkersSGIX; -GLEW_FUN_EXPORT PFNGLFINISHASYNCSGIXPROC __glewFinishAsyncSGIX; -GLEW_FUN_EXPORT PFNGLGENASYNCMARKERSSGIXPROC __glewGenAsyncMarkersSGIX; -GLEW_FUN_EXPORT PFNGLISASYNCMARKERSGIXPROC __glewIsAsyncMarkerSGIX; -GLEW_FUN_EXPORT PFNGLPOLLASYNCSGIXPROC __glewPollAsyncSGIX; - -GLEW_FUN_EXPORT PFNGLFLUSHRASTERSGIXPROC __glewFlushRasterSGIX; - -GLEW_FUN_EXPORT PFNGLTEXTUREFOGSGIXPROC __glewTextureFogSGIX; - -GLEW_FUN_EXPORT PFNGLFRAGMENTCOLORMATERIALSGIXPROC __glewFragmentColorMaterialSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFSGIXPROC __glewFragmentLightModelfSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELFVSGIXPROC __glewFragmentLightModelfvSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELISGIXPROC __glewFragmentLightModeliSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTMODELIVSGIXPROC __glewFragmentLightModelivSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFSGIXPROC __glewFragmentLightfSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTFVSGIXPROC __glewFragmentLightfvSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTISGIXPROC __glewFragmentLightiSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTLIGHTIVSGIXPROC __glewFragmentLightivSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFSGIXPROC __glewFragmentMaterialfSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALFVSGIXPROC __glewFragmentMaterialfvSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALISGIXPROC __glewFragmentMaterialiSGIX; -GLEW_FUN_EXPORT PFNGLFRAGMENTMATERIALIVSGIXPROC __glewFragmentMaterialivSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTFVSGIXPROC __glewGetFragmentLightfvSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTLIGHTIVSGIXPROC __glewGetFragmentLightivSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALFVSGIXPROC __glewGetFragmentMaterialfvSGIX; -GLEW_FUN_EXPORT PFNGLGETFRAGMENTMATERIALIVSGIXPROC __glewGetFragmentMaterialivSGIX; - -GLEW_FUN_EXPORT PFNGLFRAMEZOOMSGIXPROC __glewFrameZoomSGIX; - -GLEW_FUN_EXPORT PFNGLPIXELTEXGENSGIXPROC __glewPixelTexGenSGIX; - -GLEW_FUN_EXPORT PFNGLREFERENCEPLANESGIXPROC __glewReferencePlaneSGIX; - -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERFSGIXPROC __glewSpriteParameterfSGIX; -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERFVSGIXPROC __glewSpriteParameterfvSGIX; -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERISGIXPROC __glewSpriteParameteriSGIX; -GLEW_FUN_EXPORT PFNGLSPRITEPARAMETERIVSGIXPROC __glewSpriteParameterivSGIX; - -GLEW_FUN_EXPORT PFNGLTAGSAMPLEBUFFERSGIXPROC __glewTagSampleBufferSGIX; - -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERFVSGIPROC __glewColorTableParameterfvSGI; -GLEW_FUN_EXPORT PFNGLCOLORTABLEPARAMETERIVSGIPROC __glewColorTableParameterivSGI; -GLEW_FUN_EXPORT PFNGLCOLORTABLESGIPROC __glewColorTableSGI; -GLEW_FUN_EXPORT PFNGLCOPYCOLORTABLESGIPROC __glewCopyColorTableSGI; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERFVSGIPROC __glewGetColorTableParameterfvSGI; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLEPARAMETERIVSGIPROC __glewGetColorTableParameterivSGI; -GLEW_FUN_EXPORT PFNGLGETCOLORTABLESGIPROC __glewGetColorTableSGI; - -GLEW_FUN_EXPORT PFNGLFINISHTEXTURESUNXPROC __glewFinishTextureSUNX; - -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORBSUNPROC __glewGlobalAlphaFactorbSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORDSUNPROC __glewGlobalAlphaFactordSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORFSUNPROC __glewGlobalAlphaFactorfSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORISUNPROC __glewGlobalAlphaFactoriSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORSSUNPROC __glewGlobalAlphaFactorsSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUBSUNPROC __glewGlobalAlphaFactorubSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUISUNPROC __glewGlobalAlphaFactoruiSUN; -GLEW_FUN_EXPORT PFNGLGLOBALALPHAFACTORUSSUNPROC __glewGlobalAlphaFactorusSUN; - -GLEW_FUN_EXPORT PFNGLREADVIDEOPIXELSSUNPROC __glewReadVideoPixelsSUN; - -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEPOINTERSUNPROC __glewReplacementCodePointerSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUBSUNPROC __glewReplacementCodeubSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUBVSUNPROC __glewReplacementCodeubvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUISUNPROC __glewReplacementCodeuiSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVSUNPROC __glewReplacementCodeuivSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUSSUNPROC __glewReplacementCodeusSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUSVSUNPROC __glewReplacementCodeusvSUN; - -GLEW_FUN_EXPORT PFNGLCOLOR3FVERTEX3FSUNPROC __glewColor3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR3FVERTEX3FVSUNPROC __glewColor3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX2FSUNPROC __glewColor4ubVertex2fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX2FVSUNPROC __glewColor4ubVertex2fvSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX3FSUNPROC __glewColor4ubVertex3fSUN; -GLEW_FUN_EXPORT PFNGLCOLOR4UBVERTEX3FVSUNPROC __glewColor4ubVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLNORMAL3FVERTEX3FSUNPROC __glewNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLNORMAL3FVERTEX3FVSUNPROC __glewNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC __glewReplacementCodeuiColor3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC __glewReplacementCodeuiColor4ubVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC __glewReplacementCodeuiColor4ubVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC __glewReplacementCodeuiVertex3fSUN; -GLEW_FUN_EXPORT PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC __glewReplacementCodeuiVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC __glewTexCoord2fColor3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC __glewTexCoord2fColor3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC __glewTexCoord2fColor4ubVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC __glewTexCoord2fColor4ubVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fNormal3fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fNormal3fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FVERTEX3FSUNPROC __glewTexCoord2fVertex3fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD2FVERTEX3FVSUNPROC __glewTexCoord2fVertex3fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fvSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FVERTEX4FSUNPROC __glewTexCoord4fVertex4fSUN; -GLEW_FUN_EXPORT PFNGLTEXCOORD4FVERTEX4FVSUNPROC __glewTexCoord4fVertex4fvSUN; - -GLEW_FUN_EXPORT PFNGLADDSWAPHINTRECTWINPROC __glewAddSwapHintRectWIN; - -#if defined(GLEW_MX) && !defined(_WIN32) -struct GLEWContextStruct -{ -#endif /* GLEW_MX */ - -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_2_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_3; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_4; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_1_5; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_2_0; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_2_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_0; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_2; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_3_3; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_0; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_1; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_2; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_3; -GLEW_VAR_EXPORT GLboolean __GLEW_VERSION_4_4; -GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_tbuffer; -GLEW_VAR_EXPORT GLboolean __GLEW_3DFX_texture_compression_FXT1; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_blend_minmax_factor; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_conservative_depth; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_debug_output; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_depth_clamp_separate; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_draw_buffers_blend; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_interleaved_elements; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_multi_draw_indirect; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_name_gen_delete; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_performance_monitor; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_pinned_memory; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_query_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_sample_positions; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_seamless_cubemap_per_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_shader_stencil_export; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_shader_trinary_minmax; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_sparse_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_stencil_operation_extended; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_texture_texture4; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_transform_feedback3_lines_triangles; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_vertex_shader_layer; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_vertex_shader_tessellator; -GLEW_VAR_EXPORT GLboolean __GLEW_AMD_vertex_shader_viewport_index; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_depth_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_framebuffer_blit; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_framebuffer_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_instanced_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_pack_reverse_row_order; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_program_binary; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_texture_compression_dxt1; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_texture_compression_dxt3; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_texture_compression_dxt5; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_texture_usage; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_timer_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ANGLE_translated_shader_source; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_aux_depth_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_client_storage; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_element_array; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_fence; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_float_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_flush_buffer_range; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_object_purgeable; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_pixel_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_rgb_422; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_row_bytes; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_specular_vector; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_texture_range; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_transform_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_array_range; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_vertex_program_evaluators; -GLEW_VAR_EXPORT GLboolean __GLEW_APPLE_ycbcr_422; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_ES2_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_ES3_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_arrays_of_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_base_instance; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_bindless_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_blend_func_extended; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_buffer_storage; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_cl_event; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_clear_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_clear_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_color_buffer_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_compressed_texture_pixel_storage; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_compute_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_compute_variable_group_size; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_conservative_depth; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_copy_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_copy_image; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_debug_output; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_buffer_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_depth_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_buffers; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_buffers_blend; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_elements_base_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_indirect; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_draw_instanced; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_enhanced_layouts; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_explicit_attrib_location; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_explicit_uniform_location; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_coord_conventions; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_layer_viewport; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_program; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_program_shadow; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_fragment_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_no_attachments; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_framebuffer_sRGB; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_geometry_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_get_program_binary; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_gpu_shader5; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_gpu_shader_fp64; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_half_float_pixel; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_half_float_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_imaging; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_indirect_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_instanced_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_internalformat_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_internalformat_query2; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_invalidate_subdata; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_map_buffer_alignment; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_map_buffer_range; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_matrix_palette; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multi_bind; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multi_draw_indirect; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_multitexture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_occlusion_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_occlusion_query2; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_pixel_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_point_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_point_sprite; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_program_interface_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_provoking_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_query_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_robust_buffer_access_behavior; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_robustness; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_robustness_application_isolation; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_robustness_share_group_isolation; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sample_shading; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sampler_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_seamless_cube_map; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_seamless_cubemap_per_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_separate_shader_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_atomic_counters; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_bit_encoding; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_draw_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_group_vote; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_image_load_store; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_image_size; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_precision; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_stencil_export; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_storage_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_subroutine; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shader_texture_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_100; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_420pack; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_include; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shading_language_packing; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shadow; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_shadow_ambient; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sparse_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_stencil_texturing; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_sync; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_tessellation_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_border_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_object_rgb32; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_buffer_range; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression_bptc; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_compression_rgtc; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_cube_map; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_cube_map_array; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_add; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_combine; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_crossbar; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_env_dot3; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_gather; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_mirror_clamp_to_edge; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_mirrored_repeat; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_non_power_of_two; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_query_levels; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_query_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rectangle; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rg; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_rgb10_a2ui; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_stencil8; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_storage; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_storage_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_swizzle; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_texture_view; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_timer_query; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback2; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback3; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transform_feedback_instanced; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_transpose_matrix; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_uniform_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_array_bgra; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_attrib_64bit; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_attrib_binding; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_blend; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_program; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_type_10f_11f_11f_rev; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_vertex_type_2_10_10_10_rev; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_viewport_array; -GLEW_VAR_EXPORT GLboolean __GLEW_ARB_window_pos; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_point_sprites; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_texture_env_combine3; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_texture_env_route; -GLEW_VAR_EXPORT GLboolean __GLEW_ATIX_vertex_shader_output_point_size; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_draw_buffers; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_element_array; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_envmap_bumpmap; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_fragment_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_map_object_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_meminfo; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_pn_triangles; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_separate_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_shader_texture_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_text_fragment_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_compression_3dc; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_env_combine3; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_float; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_texture_mirror_once; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_attrib_array_object; -GLEW_VAR_EXPORT GLboolean __GLEW_ATI_vertex_streams; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_422_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_Cg_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_abgr; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_bgra; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_bindable_uniform; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_color; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_equation_separate; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_func_separate; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_logic_op; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_minmax; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_blend_subtract; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_clip_volume_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_cmyka; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_color_subtable; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_compiled_vertex_array; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_convolution; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_coordinate_frame; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_copy_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_cull_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_debug_marker; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_depth_bounds_test; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_direct_state_access; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_buffers2; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_instanced; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_draw_range_elements; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_fog_coord; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_fragment_lighting; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_blit; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_multisample_blit_scaled; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_framebuffer_sRGB; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_geometry_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_gpu_program_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_gpu_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_histogram; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_array_formats; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_func; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_material; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_index_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_light_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_misc_attribute; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_multi_draw_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_depth_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_float; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_packed_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_paletted_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_transform; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_pixel_transform_color_table; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_point_parameters; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_polygon_offset; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_provoking_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_rescale_normal; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_scene_marker; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_secondary_color; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_separate_shader_objects; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_separate_specular_color; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shader_image_load_store; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shadow_funcs; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_shared_texture_palette; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_clear_tag; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_two_side; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_stencil_wrap; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_subtexture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture3D; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_array; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_dxt1; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_latc; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_rgtc; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_compression_s3tc; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_cube_map; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_edge_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_add; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_combine; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_env_dot3; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_filter_anisotropic; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_integer; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_lod_bias; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_mirror_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_object; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_perturb_normal; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_rectangle; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_sRGB; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_sRGB_decode; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_shared_exponent; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_snorm; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_texture_swizzle; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_timer_query; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_transform_feedback; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_array; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_array_bgra; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_attrib_64bit; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_vertex_weighting; -GLEW_VAR_EXPORT GLboolean __GLEW_EXT_x11_sync_object; -GLEW_VAR_EXPORT GLboolean __GLEW_GREMEDY_frame_terminator; -GLEW_VAR_EXPORT GLboolean __GLEW_GREMEDY_string_marker; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_convolution_border_modes; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_image_transform; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_occlusion_test; -GLEW_VAR_EXPORT GLboolean __GLEW_HP_texture_lighting; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_cull_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_multimode_draw_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_rasterpos_clip; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_static_data; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_texture_mirrored_repeat; -GLEW_VAR_EXPORT GLboolean __GLEW_IBM_vertex_array_lists; -GLEW_VAR_EXPORT GLboolean __GLEW_INGR_color_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_INGR_interlace_read; -GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_map_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_parallel_arrays; -GLEW_VAR_EXPORT GLboolean __GLEW_INTEL_texture_scissor; -GLEW_VAR_EXPORT GLboolean __GLEW_KHR_debug; -GLEW_VAR_EXPORT GLboolean __GLEW_KHR_texture_compression_astc_ldr; -GLEW_VAR_EXPORT GLboolean __GLEW_KTX_buffer_region; -GLEW_VAR_EXPORT GLboolean __GLEW_MESAX_texture_stack; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_pack_invert; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_resize_buffers; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_window_pos; -GLEW_VAR_EXPORT GLboolean __GLEW_MESA_ycbcr_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_NVX_conditional_render; -GLEW_VAR_EXPORT GLboolean __GLEW_NVX_gpu_memory_info; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_bindless_multi_draw_indirect; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_bindless_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_blend_equation_advanced; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_blend_equation_advanced_coherent; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_blend_square; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_compute_program5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_conditional_render; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_copy_depth_to_color; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_copy_image; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_deep_texture3D; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_buffer_float; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_depth_range_unclamped; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_draw_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_evaluators; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_explicit_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fence; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_float_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fog_distance; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_fragment_program_option; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_framebuffer_multisample_coverage; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_geometry_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_geometry_shader4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program5_mem_extended; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_program_fp64; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_gpu_shader5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_half_float; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_light_max_exponent; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_multisample_coverage; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_multisample_filter_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_occlusion_query; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_packed_depth_stencil; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_parameter_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_parameter_buffer_object2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_path_rendering; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_pixel_data_range; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_point_sprite; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_present_video; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_primitive_restart; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_register_combiners; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_register_combiners2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_shader_atomic_counters; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_shader_atomic_float; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_shader_buffer_load; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_shader_storage_buffer_object; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_tessellation_program5; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texgen_emboss; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texgen_reflection; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_barrier; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_compression_vtc; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_env_combine4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_expand_normal; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_rectangle; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_texture_shader3; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_transform_feedback; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_transform_feedback2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vdpau_interop; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_array_range; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_array_range2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_attrib_integer_64bit; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_buffer_unified_memory; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program1_1; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program2; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program2_option; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program3; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_vertex_program4; -GLEW_VAR_EXPORT GLboolean __GLEW_NV_video_capture; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_byte_coordinates; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_compressed_paletted_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_read_format; -GLEW_VAR_EXPORT GLboolean __GLEW_OES_single_precision; -GLEW_VAR_EXPORT GLboolean __GLEW_OML_interlace; -GLEW_VAR_EXPORT GLboolean __GLEW_OML_resample; -GLEW_VAR_EXPORT GLboolean __GLEW_OML_subsample; -GLEW_VAR_EXPORT GLboolean __GLEW_PGI_misc_hints; -GLEW_VAR_EXPORT GLboolean __GLEW_PGI_vertex_hints; -GLEW_VAR_EXPORT GLboolean __GLEW_REGAL_ES1_0_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_REGAL_ES1_1_compatibility; -GLEW_VAR_EXPORT GLboolean __GLEW_REGAL_enable; -GLEW_VAR_EXPORT GLboolean __GLEW_REGAL_error_string; -GLEW_VAR_EXPORT GLboolean __GLEW_REGAL_extension_query; -GLEW_VAR_EXPORT GLboolean __GLEW_REGAL_log; -GLEW_VAR_EXPORT GLboolean __GLEW_REND_screen_coordinates; -GLEW_VAR_EXPORT GLboolean __GLEW_S3_s3tc; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_color_range; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_detail_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_fog_function; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_generate_mipmap; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_multisample; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_pixel_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_point_line_texgen; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_sharpen_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture4D; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_border_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_edge_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_filter4; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_lod; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIS_texture_select; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async_histogram; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_async_pixel; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_blend_alpha_minmax; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_clipmap; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_convolution_accuracy; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_depth_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_flush_raster; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fog_offset; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fog_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_fragment_specular_lighting; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_framezoom; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_interlace; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_ir_instrument1; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_list_priority; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_pixel_texture; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_pixel_texture_bits; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_reference_plane; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_resample; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_shadow; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_shadow_ambient; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_sprite; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_tag_sample_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_add_env; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_coordinate_clamp; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_lod_bias; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_multi_buffer; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_range; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_texture_scale_bias; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_vertex_preclip; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_vertex_preclip_hint; -GLEW_VAR_EXPORT GLboolean __GLEW_SGIX_ycrcb; -GLEW_VAR_EXPORT GLboolean __GLEW_SGI_color_matrix; -GLEW_VAR_EXPORT GLboolean __GLEW_SGI_color_table; -GLEW_VAR_EXPORT GLboolean __GLEW_SGI_texture_color_table; -GLEW_VAR_EXPORT GLboolean __GLEW_SUNX_constant_data; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_convolution_border_modes; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_global_alpha; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_mesh_array; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_read_video_pixels; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_slice_accum; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_triangle_list; -GLEW_VAR_EXPORT GLboolean __GLEW_SUN_vertex; -GLEW_VAR_EXPORT GLboolean __GLEW_WIN_phong_shading; -GLEW_VAR_EXPORT GLboolean __GLEW_WIN_specular_fog; -GLEW_VAR_EXPORT GLboolean __GLEW_WIN_swap_hint; - -#ifdef GLEW_MX -}; /* GLEWContextStruct */ -#endif /* GLEW_MX */ - -/* ------------------------------------------------------------------------- */ - -/* error codes */ -#define GLEW_OK 0 -#define GLEW_NO_ERROR 0 -#define GLEW_ERROR_NO_GL_VERSION 1 /* missing GL version */ -#define GLEW_ERROR_GL_VERSION_10_ONLY 2 /* Need at least OpenGL 1.1 */ -#define GLEW_ERROR_GLX_VERSION_11_ONLY 3 /* Need at least GLX 1.2 */ - -/* string codes */ -#define GLEW_VERSION 1 -#define GLEW_VERSION_MAJOR 2 -#define GLEW_VERSION_MINOR 3 -#define GLEW_VERSION_MICRO 4 - -/* API */ -#ifdef GLEW_MX - -typedef struct GLEWContextStruct GLEWContext; -GLEWAPI GLenum GLEWAPIENTRY glewContextInit (GLEWContext *ctx); -GLEWAPI GLboolean GLEWAPIENTRY glewContextIsSupported (const GLEWContext *ctx, const char *name); - -#define glewInit() glewContextInit(glewGetContext()) -#define glewIsSupported(x) glewContextIsSupported(glewGetContext(), x) -#define glewIsExtensionSupported(x) glewIsSupported(x) - -#define GLEW_GET_VAR(x) (*(const GLboolean*)&(glewGetContext()->x)) -#ifdef _WIN32 -# define GLEW_GET_FUN(x) glewGetContext()->x -#else -# define GLEW_GET_FUN(x) x -#endif - -#else /* GLEW_MX */ - -GLEWAPI GLenum GLEWAPIENTRY glewInit (void); -GLEWAPI GLboolean GLEWAPIENTRY glewIsSupported (const char *name); -#define glewIsExtensionSupported(x) glewIsSupported(x) - -#define GLEW_GET_VAR(x) (*(const GLboolean*)&x) -#define GLEW_GET_FUN(x) x - -#endif /* GLEW_MX */ - -GLEWAPI GLboolean glewExperimental; -GLEWAPI GLboolean GLEWAPIENTRY glewGetExtension (const char *name); -GLEWAPI const GLubyte * GLEWAPIENTRY glewGetErrorString (GLenum error); -GLEWAPI const GLubyte * GLEWAPIENTRY glewGetString (GLenum name); - -#ifdef GLEW_INIT_OPENGL11_FUNCTIONS -GLEWAPI GLboolean GLEWAPIENTRY glewOpenGL11Init(void); -#endif //GLEW_INIT_OPENGL11_FUNCTIONS - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -GLEWAPI GLboolean GLEWAPIENTRY glewXInit(void); -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#ifdef __cplusplus -} -#endif - -#ifdef GLEW_APIENTRY_DEFINED -#undef GLEW_APIENTRY_DEFINED -#undef APIENTRY -#undef GLAPIENTRY -#define GLAPIENTRY -#endif - -#ifdef GLEW_CALLBACK_DEFINED -#undef GLEW_CALLBACK_DEFINED -#undef CALLBACK -#endif - -#ifdef GLEW_WINGDIAPI_DEFINED -#undef GLEW_WINGDIAPI_DEFINED -#undef WINGDIAPI -#endif - -#undef GLAPI -/* #undef GLEWAPI */ - -#endif /* __glew_h__ */ diff --git a/btgui/OpenGLWindow/GlewWindows/GL/glxew.h b/btgui/OpenGLWindow/GlewWindows/GL/glxew.h deleted file mode 100644 index 6115d611e..000000000 --- a/btgui/OpenGLWindow/GlewWindows/GL/glxew.h +++ /dev/null @@ -1,1750 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -/* - * Mesa 3-D graphics library - * Version: 7.0 - * - * Copyright (C) 1999-2007 Brian Paul All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* -** Copyright (c) 2007 The Khronos Group Inc. -** -** Permission is hereby granted, free of charge, to any person obtaining a -** copy of this software and/or associated documentation files (the -** "Materials"), to deal in the Materials without restriction, including -** without limitation the rights to use, copy, modify, merge, publish, -** distribute, sublicense, and/or sell copies of the Materials, and to -** permit persons to whom the Materials are furnished to do so, subject to -** the following conditions: -** -** The above copyright notice and this permission notice shall be included -** in all copies or substantial portions of the Materials. -** -** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. -*/ - -#ifndef __glxew_h__ -#define __glxew_h__ -#define __GLXEW_H__ - -#ifdef __glxext_h_ -#error glxext.h included before glxew.h -#endif - -#if defined(GLX_H) || defined(__GLX_glx_h__) || defined(__glx_h__) -#error glx.h included before glxew.h -#endif - -#define __glxext_h_ - -#define GLX_H -#define __GLX_glx_h__ -#define __glx_h__ - -#include -#include -#include -#include "glew.h" - -#ifdef __cplusplus -extern "C" { -#endif - -/* ---------------------------- GLX_VERSION_1_0 --------------------------- */ - -#ifndef GLX_VERSION_1_0 -#define GLX_VERSION_1_0 1 - -#define GLX_USE_GL 1 -#define GLX_BUFFER_SIZE 2 -#define GLX_LEVEL 3 -#define GLX_RGBA 4 -#define GLX_DOUBLEBUFFER 5 -#define GLX_STEREO 6 -#define GLX_AUX_BUFFERS 7 -#define GLX_RED_SIZE 8 -#define GLX_GREEN_SIZE 9 -#define GLX_BLUE_SIZE 10 -#define GLX_ALPHA_SIZE 11 -#define GLX_DEPTH_SIZE 12 -#define GLX_STENCIL_SIZE 13 -#define GLX_ACCUM_RED_SIZE 14 -#define GLX_ACCUM_GREEN_SIZE 15 -#define GLX_ACCUM_BLUE_SIZE 16 -#define GLX_ACCUM_ALPHA_SIZE 17 -#define GLX_BAD_SCREEN 1 -#define GLX_BAD_ATTRIBUTE 2 -#define GLX_NO_EXTENSION 3 -#define GLX_BAD_VISUAL 4 -#define GLX_BAD_CONTEXT 5 -#define GLX_BAD_VALUE 6 -#define GLX_BAD_ENUM 7 - -typedef XID GLXDrawable; -typedef XID GLXPixmap; -#ifdef __sun -typedef struct __glXContextRec *GLXContext; -#else -typedef struct __GLXcontextRec *GLXContext; -#endif - -typedef unsigned int GLXVideoDeviceNV; - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -typedef Bool (* PFNGLXQUERYEXTENSION) (Display *dpy, int *errorBase, int *eventBase); -#define glXQueryExtension GLXEW_GET_FUN(__glewXQueryExtension) - -typedef Bool (* PFNGLXQUERYVERSION) (Display *dpy, int *major, int *minor); -#define glXQueryVersion GLXEW_GET_FUN(__glewXQueryVersion) - -typedef int (* PFNGLXGETCONFIG) (Display *dpy, XVisualInfo *vis, int attrib, int *value); -#define glXGetConfig GLXEW_GET_FUN(__glewXGetConfig) - -typedef XVisualInfo* (* PFNGLXCHOOSEVISUAL) (Display *dpy, int screen, int *attribList); -#define glXChooseVisual GLXEW_GET_FUN(__glewXChooseVisual) - -//extern GLXPixmap glXCreateGLXPixmap (Display *dpy, XVisualInfo *vis, Pixmap pixmap); -//extern void glXDestroyGLXPixmap (Display *dpy, GLXPixmap pix); -typedef GLXContext (* PFNGLXCREATECONTEXT) (Display *dpy, XVisualInfo *vis, GLXContext shareList, Bool direct); -#define glXCreateContext GLXEW_GET_FUN(__glewXCreateContext) - - -typedef void (*PFNGLXDESTROYCONTEXT) (Display *dpy, GLXContext ctx); -#define glXDestroyContext GLXEW_GET_FUN(__glewXDestroyContext) - -typedef Bool (* PFNGLXISDIRECT) (Display *dpy, GLXContext ctx); -#define glXIsDirect GLXEW_GET_FUN(__glewXIsDirect) - - -//extern void glXCopyContext (Display *dpy, GLXContext src, GLXContext dst, GLulong mask); -typedef Bool (*PFNGLXMAKECURRENT) (Display *dpy, GLXDrawable drawable, GLXContext ctx); -#define glXMakeCurrent GLXEW_GET_FUN(__glewXMakeCurrent) - -//extern GLXContext glXGetCurrentContext (void); -//extern GLXDrawable glXGetCurrentDrawable (void); -//extern void glXWaitGL (void); -//extern void glXWaitX (void); -typedef void (*PFNGLXSWAPBUFFERS) (Display *dpy, GLXDrawable drawable); -#define glXSwapBuffers GLXEW_GET_FUN(__glewXSwapBuffers) - -//extern void glXUseXFont (Font font, int first, int count, int listBase); - - -#else//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -extern Bool glXQueryExtension (Display *dpy, int *errorBase, int *eventBase); -extern Bool glXQueryVersion (Display *dpy, int *major, int *minor); -extern int glXGetConfig (Display *dpy, XVisualInfo *vis, int attrib, int *value); -extern XVisualInfo* glXChooseVisual (Display *dpy, int screen, int *attribList); -extern GLXPixmap glXCreateGLXPixmap (Display *dpy, XVisualInfo *vis, Pixmap pixmap); -extern void glXDestroyGLXPixmap (Display *dpy, GLXPixmap pix); -extern GLXContext glXCreateContext (Display *dpy, XVisualInfo *vis, GLXContext shareList, Bool direct); -extern void glXDestroyContext (Display *dpy, GLXContext ctx); -extern Bool glXIsDirect (Display *dpy, GLXContext ctx); -extern void glXCopyContext (Display *dpy, GLXContext src, GLXContext dst, GLulong mask); -extern Bool glXMakeCurrent (Display *dpy, GLXDrawable drawable, GLXContext ctx); -extern GLXContext glXGetCurrentContext (void); -extern GLXDrawable glXGetCurrentDrawable (void); -extern void glXWaitGL (void); -extern void glXWaitX (void); -extern void glXSwapBuffers (Display *dpy, GLXDrawable drawable); -extern void glXUseXFont (Font font, int first, int count, int listBase); -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#define GLXEW_VERSION_1_0 GLXEW_GET_VAR(__GLXEW_VERSION_1_0) - -#endif /* GLX_VERSION_1_0 */ - -/* ---------------------------- GLX_VERSION_1_1 --------------------------- */ - -#ifndef GLX_VERSION_1_1 -#define GLX_VERSION_1_1 - -#define GLX_VENDOR 0x1 -#define GLX_VERSION 0x2 -#define GLX_EXTENSIONS 0x3 - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -typedef const char* (*PFNGLXQUERYEXTENSIONSSTRING) (Display *dpy, int screen); -#define glXQueryExtensionsString GLXEW_GET_FUN(__glewXQueryExtensionsString) - -typedef const char* (*PFNGLXGETCLIENTSTRING) (Display *dpy, int name); -#define glXGetClientString GLXEW_GET_FUN(__glewXGetClientString) - -typedef const char* (*PFNGLXQUERYSERVERSTRING) (Display *dpy, int screen, int name); -#define glXQueryServerString GLXEW_GET_FUN(__glewXQueryServerString) - -#else//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -extern const char* glXQueryExtensionsString (Display *dpy, int screen); -extern const char* glXGetClientString (Display *dpy, int name); -extern const char* glXQueryServerString (Display *dpy, int screen, int name); -#endif//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#define GLXEW_VERSION_1_1 GLXEW_GET_VAR(__GLXEW_VERSION_1_1) - -#endif /* GLX_VERSION_1_1 */ - -/* ---------------------------- GLX_VERSION_1_2 ---------------------------- */ - -#ifndef GLX_VERSION_1_2 -#define GLX_VERSION_1_2 1 - -typedef Display* ( * PFNGLXGETCURRENTDISPLAYPROC) (void); - -#define glXGetCurrentDisplay GLXEW_GET_FUN(__glewXGetCurrentDisplay) - -#define GLXEW_VERSION_1_2 GLXEW_GET_VAR(__GLXEW_VERSION_1_2) - -#endif /* GLX_VERSION_1_2 */ - -/* ---------------------------- GLX_VERSION_1_3 ---------------------------- */ - -#ifndef GLX_VERSION_1_3 -#define GLX_VERSION_1_3 1 - -#define GLX_RGBA_BIT 0x00000001 -#define GLX_FRONT_LEFT_BUFFER_BIT 0x00000001 -#define GLX_WINDOW_BIT 0x00000001 -#define GLX_COLOR_INDEX_BIT 0x00000002 -#define GLX_PIXMAP_BIT 0x00000002 -#define GLX_FRONT_RIGHT_BUFFER_BIT 0x00000002 -#define GLX_BACK_LEFT_BUFFER_BIT 0x00000004 -#define GLX_PBUFFER_BIT 0x00000004 -#define GLX_BACK_RIGHT_BUFFER_BIT 0x00000008 -#define GLX_AUX_BUFFERS_BIT 0x00000010 -#define GLX_CONFIG_CAVEAT 0x20 -#define GLX_DEPTH_BUFFER_BIT 0x00000020 -#define GLX_X_VISUAL_TYPE 0x22 -#define GLX_TRANSPARENT_TYPE 0x23 -#define GLX_TRANSPARENT_INDEX_VALUE 0x24 -#define GLX_TRANSPARENT_RED_VALUE 0x25 -#define GLX_TRANSPARENT_GREEN_VALUE 0x26 -#define GLX_TRANSPARENT_BLUE_VALUE 0x27 -#define GLX_TRANSPARENT_ALPHA_VALUE 0x28 -#define GLX_STENCIL_BUFFER_BIT 0x00000040 -#define GLX_ACCUM_BUFFER_BIT 0x00000080 -#define GLX_NONE 0x8000 -#define GLX_SLOW_CONFIG 0x8001 -#define GLX_TRUE_COLOR 0x8002 -#define GLX_DIRECT_COLOR 0x8003 -#define GLX_PSEUDO_COLOR 0x8004 -#define GLX_STATIC_COLOR 0x8005 -#define GLX_GRAY_SCALE 0x8006 -#define GLX_STATIC_GRAY 0x8007 -#define GLX_TRANSPARENT_RGB 0x8008 -#define GLX_TRANSPARENT_INDEX 0x8009 -#define GLX_VISUAL_ID 0x800B -#define GLX_SCREEN 0x800C -#define GLX_NON_CONFORMANT_CONFIG 0x800D -#define GLX_DRAWABLE_TYPE 0x8010 -#define GLX_RENDER_TYPE 0x8011 -#define GLX_X_RENDERABLE 0x8012 -#define GLX_FBCONFIG_ID 0x8013 -#define GLX_RGBA_TYPE 0x8014 -#define GLX_COLOR_INDEX_TYPE 0x8015 -#define GLX_MAX_PBUFFER_WIDTH 0x8016 -#define GLX_MAX_PBUFFER_HEIGHT 0x8017 -#define GLX_MAX_PBUFFER_PIXELS 0x8018 -#define GLX_PRESERVED_CONTENTS 0x801B -#define GLX_LARGEST_PBUFFER 0x801C -#define GLX_WIDTH 0x801D -#define GLX_HEIGHT 0x801E -#define GLX_EVENT_MASK 0x801F -#define GLX_DAMAGED 0x8020 -#define GLX_SAVED 0x8021 -#define GLX_WINDOW 0x8022 -#define GLX_PBUFFER 0x8023 -#define GLX_PBUFFER_HEIGHT 0x8040 -#define GLX_PBUFFER_WIDTH 0x8041 -#define GLX_PBUFFER_CLOBBER_MASK 0x08000000 -#define GLX_DONT_CARE 0xFFFFFFFF - -typedef XID GLXFBConfigID; -typedef XID GLXPbuffer; -typedef XID GLXWindow; -typedef struct __GLXFBConfigRec *GLXFBConfig; - -typedef struct { - int event_type; - int draw_type; - unsigned long serial; - Bool send_event; - Display *display; - GLXDrawable drawable; - unsigned int buffer_mask; - unsigned int aux_buffer; - int x, y; - int width, height; - int count; -} GLXPbufferClobberEvent; -typedef union __GLXEvent { - GLXPbufferClobberEvent glxpbufferclobber; - long pad[24]; -} GLXEvent; - -typedef GLXFBConfig* ( * PFNGLXCHOOSEFBCONFIGPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); -typedef GLXContext ( * PFNGLXCREATENEWCONTEXTPROC) (Display *dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); -typedef GLXPbuffer ( * PFNGLXCREATEPBUFFERPROC) (Display *dpy, GLXFBConfig config, const int *attrib_list); -typedef GLXPixmap ( * PFNGLXCREATEPIXMAPPROC) (Display *dpy, GLXFBConfig config, Pixmap pixmap, const int *attrib_list); -typedef GLXWindow ( * PFNGLXCREATEWINDOWPROC) (Display *dpy, GLXFBConfig config, Window win, const int *attrib_list); -typedef void ( * PFNGLXDESTROYPBUFFERPROC) (Display *dpy, GLXPbuffer pbuf); -typedef void ( * PFNGLXDESTROYPIXMAPPROC) (Display *dpy, GLXPixmap pixmap); -typedef void ( * PFNGLXDESTROYWINDOWPROC) (Display *dpy, GLXWindow win); -typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLEPROC) (void); -typedef int ( * PFNGLXGETFBCONFIGATTRIBPROC) (Display *dpy, GLXFBConfig config, int attribute, int *value); -typedef GLXFBConfig* ( * PFNGLXGETFBCONFIGSPROC) (Display *dpy, int screen, int *nelements); -typedef void ( * PFNGLXGETSELECTEDEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long *event_mask); -typedef XVisualInfo* ( * PFNGLXGETVISUALFROMFBCONFIGPROC) (Display *dpy, GLXFBConfig config); -typedef Bool ( * PFNGLXMAKECONTEXTCURRENTPROC) (Display *display, GLXDrawable draw, GLXDrawable read, GLXContext ctx); -typedef int ( * PFNGLXQUERYCONTEXTPROC) (Display *dpy, GLXContext ctx, int attribute, int *value); -typedef void ( * PFNGLXQUERYDRAWABLEPROC) (Display *dpy, GLXDrawable draw, int attribute, unsigned int *value); -typedef void ( * PFNGLXSELECTEVENTPROC) (Display *dpy, GLXDrawable draw, unsigned long event_mask); - -#define glXChooseFBConfig GLXEW_GET_FUN(__glewXChooseFBConfig) -#define glXCreateNewContext GLXEW_GET_FUN(__glewXCreateNewContext) -#define glXCreatePbuffer GLXEW_GET_FUN(__glewXCreatePbuffer) -#define glXCreatePixmap GLXEW_GET_FUN(__glewXCreatePixmap) -#define glXCreateWindow GLXEW_GET_FUN(__glewXCreateWindow) -#define glXDestroyPbuffer GLXEW_GET_FUN(__glewXDestroyPbuffer) -#define glXDestroyPixmap GLXEW_GET_FUN(__glewXDestroyPixmap) -#define glXDestroyWindow GLXEW_GET_FUN(__glewXDestroyWindow) -#define glXGetCurrentReadDrawable GLXEW_GET_FUN(__glewXGetCurrentReadDrawable) -#define glXGetFBConfigAttrib GLXEW_GET_FUN(__glewXGetFBConfigAttrib) -#define glXGetFBConfigs GLXEW_GET_FUN(__glewXGetFBConfigs) -#define glXGetSelectedEvent GLXEW_GET_FUN(__glewXGetSelectedEvent) -#define glXGetVisualFromFBConfig GLXEW_GET_FUN(__glewXGetVisualFromFBConfig) -#define glXMakeContextCurrent GLXEW_GET_FUN(__glewXMakeContextCurrent) -#define glXQueryContext GLXEW_GET_FUN(__glewXQueryContext) -#define glXQueryDrawable GLXEW_GET_FUN(__glewXQueryDrawable) -#define glXSelectEvent GLXEW_GET_FUN(__glewXSelectEvent) - -#define GLXEW_VERSION_1_3 GLXEW_GET_VAR(__GLXEW_VERSION_1_3) - -#endif /* GLX_VERSION_1_3 */ - -/* ---------------------------- GLX_VERSION_1_4 ---------------------------- */ - -#ifndef GLX_VERSION_1_4 -#define GLX_VERSION_1_4 1 - -#define GLX_SAMPLE_BUFFERS 100000 -#define GLX_SAMPLES 100001 - -extern void ( * glXGetProcAddress (const GLubyte *procName)) (void); - -#define GLXEW_VERSION_1_4 GLXEW_GET_VAR(__GLXEW_VERSION_1_4) - -#endif /* GLX_VERSION_1_4 */ - -/* -------------------------- GLX_3DFX_multisample ------------------------- */ - -#ifndef GLX_3DFX_multisample -#define GLX_3DFX_multisample 1 - -#define GLX_SAMPLE_BUFFERS_3DFX 0x8050 -#define GLX_SAMPLES_3DFX 0x8051 - -#define GLXEW_3DFX_multisample GLXEW_GET_VAR(__GLXEW_3DFX_multisample) - -#endif /* GLX_3DFX_multisample */ - -/* ------------------------ GLX_AMD_gpu_association ------------------------ */ - -#ifndef GLX_AMD_gpu_association -#define GLX_AMD_gpu_association 1 - -#define GLX_GPU_VENDOR_AMD 0x1F00 -#define GLX_GPU_RENDERER_STRING_AMD 0x1F01 -#define GLX_GPU_OPENGL_VERSION_STRING_AMD 0x1F02 -#define GLX_GPU_FASTEST_TARGET_GPUS_AMD 0x21A2 -#define GLX_GPU_RAM_AMD 0x21A3 -#define GLX_GPU_CLOCK_AMD 0x21A4 -#define GLX_GPU_NUM_PIPES_AMD 0x21A5 -#define GLX_GPU_NUM_SIMD_AMD 0x21A6 -#define GLX_GPU_NUM_RB_AMD 0x21A7 -#define GLX_GPU_NUM_SPI_AMD 0x21A8 - -typedef void ( * PFNGLXBLITCONTEXTFRAMEBUFFERAMDPROC) (GLXContext dstCtx, GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); -typedef GLXContext ( * PFNGLXCREATEASSOCIATEDCONTEXTAMDPROC) (unsigned int id, GLXContext share_list); -typedef GLXContext ( * PFNGLXCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC) (unsigned int id, GLXContext share_context, const int* attribList); -typedef Bool ( * PFNGLXDELETEASSOCIATEDCONTEXTAMDPROC) (GLXContext ctx); -typedef unsigned int ( * PFNGLXGETCONTEXTGPUIDAMDPROC) (GLXContext ctx); -typedef GLXContext ( * PFNGLXGETCURRENTASSOCIATEDCONTEXTAMDPROC) (void); -typedef unsigned int ( * PFNGLXGETGPUIDSAMDPROC) (unsigned int maxCount, unsigned int* ids); -typedef int ( * PFNGLXGETGPUINFOAMDPROC) (unsigned int id, int property, GLenum dataType, unsigned int size, void* data); -typedef Bool ( * PFNGLXMAKEASSOCIATEDCONTEXTCURRENTAMDPROC) (GLXContext ctx); - -#define glXBlitContextFramebufferAMD GLXEW_GET_FUN(__glewXBlitContextFramebufferAMD) -#define glXCreateAssociatedContextAMD GLXEW_GET_FUN(__glewXCreateAssociatedContextAMD) -#define glXCreateAssociatedContextAttribsAMD GLXEW_GET_FUN(__glewXCreateAssociatedContextAttribsAMD) -#define glXDeleteAssociatedContextAMD GLXEW_GET_FUN(__glewXDeleteAssociatedContextAMD) -#define glXGetContextGPUIDAMD GLXEW_GET_FUN(__glewXGetContextGPUIDAMD) -#define glXGetCurrentAssociatedContextAMD GLXEW_GET_FUN(__glewXGetCurrentAssociatedContextAMD) -#define glXGetGPUIDsAMD GLXEW_GET_FUN(__glewXGetGPUIDsAMD) -#define glXGetGPUInfoAMD GLXEW_GET_FUN(__glewXGetGPUInfoAMD) -#define glXMakeAssociatedContextCurrentAMD GLXEW_GET_FUN(__glewXMakeAssociatedContextCurrentAMD) - -#define GLXEW_AMD_gpu_association GLXEW_GET_VAR(__GLXEW_AMD_gpu_association) - -#endif /* GLX_AMD_gpu_association */ - -/* ------------------------- GLX_ARB_create_context ------------------------ */ - -#ifndef GLX_ARB_create_context -#define GLX_ARB_create_context 1 - -#define GLX_CONTEXT_DEBUG_BIT_ARB 0x0001 -#define GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 -#define GLX_CONTEXT_MAJOR_VERSION_ARB 0x2091 -#define GLX_CONTEXT_MINOR_VERSION_ARB 0x2092 -#define GLX_CONTEXT_FLAGS_ARB 0x2094 - -typedef GLXContext ( * PFNGLXCREATECONTEXTATTRIBSARBPROC) (Display* dpy, GLXFBConfig config, GLXContext share_context, Bool direct, const int *attrib_list); - -#define glXCreateContextAttribsARB GLXEW_GET_FUN(__glewXCreateContextAttribsARB) - -#define GLXEW_ARB_create_context GLXEW_GET_VAR(__GLXEW_ARB_create_context) - -#endif /* GLX_ARB_create_context */ - -/* --------------------- GLX_ARB_create_context_profile -------------------- */ - -#ifndef GLX_ARB_create_context_profile -#define GLX_ARB_create_context_profile 1 - -#define GLX_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 -#define GLX_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 -#define GLX_CONTEXT_PROFILE_MASK_ARB 0x9126 - -#define GLXEW_ARB_create_context_profile GLXEW_GET_VAR(__GLXEW_ARB_create_context_profile) - -#endif /* GLX_ARB_create_context_profile */ - -/* ------------------- GLX_ARB_create_context_robustness ------------------- */ - -#ifndef GLX_ARB_create_context_robustness -#define GLX_ARB_create_context_robustness 1 - -#define GLX_CONTEXT_ROBUST_ACCESS_BIT_ARB 0x00000004 -#define GLX_LOSE_CONTEXT_ON_RESET_ARB 0x8252 -#define GLX_CONTEXT_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 -#define GLX_NO_RESET_NOTIFICATION_ARB 0x8261 - -#define GLXEW_ARB_create_context_robustness GLXEW_GET_VAR(__GLXEW_ARB_create_context_robustness) - -#endif /* GLX_ARB_create_context_robustness */ - -/* ------------------------- GLX_ARB_fbconfig_float ------------------------ */ - -#ifndef GLX_ARB_fbconfig_float -#define GLX_ARB_fbconfig_float 1 - -#define GLX_RGBA_FLOAT_BIT 0x00000004 -#define GLX_RGBA_FLOAT_TYPE 0x20B9 - -#define GLXEW_ARB_fbconfig_float GLXEW_GET_VAR(__GLXEW_ARB_fbconfig_float) - -#endif /* GLX_ARB_fbconfig_float */ - -/* ------------------------ GLX_ARB_framebuffer_sRGB ----------------------- */ - -#ifndef GLX_ARB_framebuffer_sRGB -#define GLX_ARB_framebuffer_sRGB 1 - -#define GLX_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20B2 - -#define GLXEW_ARB_framebuffer_sRGB GLXEW_GET_VAR(__GLXEW_ARB_framebuffer_sRGB) - -#endif /* GLX_ARB_framebuffer_sRGB */ - -/* ------------------------ GLX_ARB_get_proc_address ----------------------- */ - -#ifndef GLX_ARB_get_proc_address -#define GLX_ARB_get_proc_address 1 - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -typedef void* ( * PFNGLXGETPROCADDRESSARBPROC) (const GLubyte *procName); -#define glXGetProcAddressARB GLXEW_GET_FUN(__glewXGetProcAddressARB) - -#else//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -extern void ( * glXGetProcAddressARB (const GLubyte *procName)) (void); -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#define GLXEW_ARB_get_proc_address GLXEW_GET_VAR(__GLXEW_ARB_get_proc_address) - -#endif /* GLX_ARB_get_proc_address */ - -/* -------------------------- GLX_ARB_multisample -------------------------- */ - -#ifndef GLX_ARB_multisample -#define GLX_ARB_multisample 1 - -#define GLX_SAMPLE_BUFFERS_ARB 100000 -#define GLX_SAMPLES_ARB 100001 - -#define GLXEW_ARB_multisample GLXEW_GET_VAR(__GLXEW_ARB_multisample) - -#endif /* GLX_ARB_multisample */ - -/* ---------------- GLX_ARB_robustness_application_isolation --------------- */ - -#ifndef GLX_ARB_robustness_application_isolation -#define GLX_ARB_robustness_application_isolation 1 - -#define GLX_CONTEXT_RESET_ISOLATION_BIT_ARB 0x00000008 - -#define GLXEW_ARB_robustness_application_isolation GLXEW_GET_VAR(__GLXEW_ARB_robustness_application_isolation) - -#endif /* GLX_ARB_robustness_application_isolation */ - -/* ---------------- GLX_ARB_robustness_share_group_isolation --------------- */ - -#ifndef GLX_ARB_robustness_share_group_isolation -#define GLX_ARB_robustness_share_group_isolation 1 - -#define GLX_CONTEXT_RESET_ISOLATION_BIT_ARB 0x00000008 - -#define GLXEW_ARB_robustness_share_group_isolation GLXEW_GET_VAR(__GLXEW_ARB_robustness_share_group_isolation) - -#endif /* GLX_ARB_robustness_share_group_isolation */ - -/* ---------------------- GLX_ARB_vertex_buffer_object --------------------- */ - -#ifndef GLX_ARB_vertex_buffer_object -#define GLX_ARB_vertex_buffer_object 1 - -#define GLX_CONTEXT_ALLOW_BUFFER_BYTE_ORDER_MISMATCH_ARB 0x2095 - -#define GLXEW_ARB_vertex_buffer_object GLXEW_GET_VAR(__GLXEW_ARB_vertex_buffer_object) - -#endif /* GLX_ARB_vertex_buffer_object */ - -/* ----------------------- GLX_ATI_pixel_format_float ---------------------- */ - -#ifndef GLX_ATI_pixel_format_float -#define GLX_ATI_pixel_format_float 1 - -#define GLX_RGBA_FLOAT_ATI_BIT 0x00000100 - -#define GLXEW_ATI_pixel_format_float GLXEW_GET_VAR(__GLXEW_ATI_pixel_format_float) - -#endif /* GLX_ATI_pixel_format_float */ - -/* ------------------------- GLX_ATI_render_texture ------------------------ */ - -#ifndef GLX_ATI_render_texture -#define GLX_ATI_render_texture 1 - -#define GLX_BIND_TO_TEXTURE_RGB_ATI 0x9800 -#define GLX_BIND_TO_TEXTURE_RGBA_ATI 0x9801 -#define GLX_TEXTURE_FORMAT_ATI 0x9802 -#define GLX_TEXTURE_TARGET_ATI 0x9803 -#define GLX_MIPMAP_TEXTURE_ATI 0x9804 -#define GLX_TEXTURE_RGB_ATI 0x9805 -#define GLX_TEXTURE_RGBA_ATI 0x9806 -#define GLX_NO_TEXTURE_ATI 0x9807 -#define GLX_TEXTURE_CUBE_MAP_ATI 0x9808 -#define GLX_TEXTURE_1D_ATI 0x9809 -#define GLX_TEXTURE_2D_ATI 0x980A -#define GLX_MIPMAP_LEVEL_ATI 0x980B -#define GLX_CUBE_MAP_FACE_ATI 0x980C -#define GLX_TEXTURE_CUBE_MAP_POSITIVE_X_ATI 0x980D -#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_X_ATI 0x980E -#define GLX_TEXTURE_CUBE_MAP_POSITIVE_Y_ATI 0x980F -#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_Y_ATI 0x9810 -#define GLX_TEXTURE_CUBE_MAP_POSITIVE_Z_ATI 0x9811 -#define GLX_TEXTURE_CUBE_MAP_NEGATIVE_Z_ATI 0x9812 -#define GLX_FRONT_LEFT_ATI 0x9813 -#define GLX_FRONT_RIGHT_ATI 0x9814 -#define GLX_BACK_LEFT_ATI 0x9815 -#define GLX_BACK_RIGHT_ATI 0x9816 -#define GLX_AUX0_ATI 0x9817 -#define GLX_AUX1_ATI 0x9818 -#define GLX_AUX2_ATI 0x9819 -#define GLX_AUX3_ATI 0x981A -#define GLX_AUX4_ATI 0x981B -#define GLX_AUX5_ATI 0x981C -#define GLX_AUX6_ATI 0x981D -#define GLX_AUX7_ATI 0x981E -#define GLX_AUX8_ATI 0x981F -#define GLX_AUX9_ATI 0x9820 -#define GLX_BIND_TO_TEXTURE_LUMINANCE_ATI 0x9821 -#define GLX_BIND_TO_TEXTURE_INTENSITY_ATI 0x9822 - -typedef void ( * PFNGLXBINDTEXIMAGEATIPROC) (Display *dpy, GLXPbuffer pbuf, int buffer); -typedef void ( * PFNGLXDRAWABLEATTRIBATIPROC) (Display *dpy, GLXDrawable draw, const int *attrib_list); -typedef void ( * PFNGLXRELEASETEXIMAGEATIPROC) (Display *dpy, GLXPbuffer pbuf, int buffer); - -#define glXBindTexImageATI GLXEW_GET_FUN(__glewXBindTexImageATI) -#define glXDrawableAttribATI GLXEW_GET_FUN(__glewXDrawableAttribATI) -#define glXReleaseTexImageATI GLXEW_GET_FUN(__glewXReleaseTexImageATI) - -#define GLXEW_ATI_render_texture GLXEW_GET_VAR(__GLXEW_ATI_render_texture) - -#endif /* GLX_ATI_render_texture */ - -/* --------------------------- GLX_EXT_buffer_age -------------------------- */ - -#ifndef GLX_EXT_buffer_age -#define GLX_EXT_buffer_age 1 - -#define GLX_BACK_BUFFER_AGE_EXT 0x20F4 - -#define GLXEW_EXT_buffer_age GLXEW_GET_VAR(__GLXEW_EXT_buffer_age) - -#endif /* GLX_EXT_buffer_age */ - -/* ------------------- GLX_EXT_create_context_es2_profile ------------------ */ - -#ifndef GLX_EXT_create_context_es2_profile -#define GLX_EXT_create_context_es2_profile 1 - -#define GLX_CONTEXT_ES2_PROFILE_BIT_EXT 0x00000004 - -#define GLXEW_EXT_create_context_es2_profile GLXEW_GET_VAR(__GLXEW_EXT_create_context_es2_profile) - -#endif /* GLX_EXT_create_context_es2_profile */ - -/* ------------------- GLX_EXT_create_context_es_profile ------------------- */ - -#ifndef GLX_EXT_create_context_es_profile -#define GLX_EXT_create_context_es_profile 1 - -#define GLX_CONTEXT_ES_PROFILE_BIT_EXT 0x00000004 - -#define GLXEW_EXT_create_context_es_profile GLXEW_GET_VAR(__GLXEW_EXT_create_context_es_profile) - -#endif /* GLX_EXT_create_context_es_profile */ - -/* --------------------- GLX_EXT_fbconfig_packed_float --------------------- */ - -#ifndef GLX_EXT_fbconfig_packed_float -#define GLX_EXT_fbconfig_packed_float 1 - -#define GLX_RGBA_UNSIGNED_FLOAT_BIT_EXT 0x00000008 -#define GLX_RGBA_UNSIGNED_FLOAT_TYPE_EXT 0x20B1 - -#define GLXEW_EXT_fbconfig_packed_float GLXEW_GET_VAR(__GLXEW_EXT_fbconfig_packed_float) - -#endif /* GLX_EXT_fbconfig_packed_float */ - -/* ------------------------ GLX_EXT_framebuffer_sRGB ----------------------- */ - -#ifndef GLX_EXT_framebuffer_sRGB -#define GLX_EXT_framebuffer_sRGB 1 - -#define GLX_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20B2 - -#define GLXEW_EXT_framebuffer_sRGB GLXEW_GET_VAR(__GLXEW_EXT_framebuffer_sRGB) - -#endif /* GLX_EXT_framebuffer_sRGB */ - -/* ------------------------- GLX_EXT_import_context ------------------------ */ - -#ifndef GLX_EXT_import_context -#define GLX_EXT_import_context 1 - -#define GLX_SHARE_CONTEXT_EXT 0x800A -#define GLX_VISUAL_ID_EXT 0x800B -#define GLX_SCREEN_EXT 0x800C - -typedef XID GLXContextID; - -typedef void ( * PFNGLXFREECONTEXTEXTPROC) (Display* dpy, GLXContext context); -typedef GLXContextID ( * PFNGLXGETCONTEXTIDEXTPROC) (const GLXContext context); -typedef GLXContext ( * PFNGLXIMPORTCONTEXTEXTPROC) (Display* dpy, GLXContextID contextID); -typedef int ( * PFNGLXQUERYCONTEXTINFOEXTPROC) (Display* dpy, GLXContext context, int attribute,int *value); - -#define glXFreeContextEXT GLXEW_GET_FUN(__glewXFreeContextEXT) -#define glXGetContextIDEXT GLXEW_GET_FUN(__glewXGetContextIDEXT) -#define glXImportContextEXT GLXEW_GET_FUN(__glewXImportContextEXT) -#define glXQueryContextInfoEXT GLXEW_GET_FUN(__glewXQueryContextInfoEXT) - -#define GLXEW_EXT_import_context GLXEW_GET_VAR(__GLXEW_EXT_import_context) - -#endif /* GLX_EXT_import_context */ - -/* -------------------------- GLX_EXT_scene_marker ------------------------- */ - -#ifndef GLX_EXT_scene_marker -#define GLX_EXT_scene_marker 1 - -#define GLXEW_EXT_scene_marker GLXEW_GET_VAR(__GLXEW_EXT_scene_marker) - -#endif /* GLX_EXT_scene_marker */ - -/* -------------------------- GLX_EXT_swap_control ------------------------- */ - -#ifndef GLX_EXT_swap_control -#define GLX_EXT_swap_control 1 - -#define GLX_SWAP_INTERVAL_EXT 0x20F1 -#define GLX_MAX_SWAP_INTERVAL_EXT 0x20F2 - -typedef void ( * PFNGLXSWAPINTERVALEXTPROC) (Display* dpy, GLXDrawable drawable, int interval); - -#define glXSwapIntervalEXT GLXEW_GET_FUN(__glewXSwapIntervalEXT) - -#define GLXEW_EXT_swap_control GLXEW_GET_VAR(__GLXEW_EXT_swap_control) - -#endif /* GLX_EXT_swap_control */ - -/* ----------------------- GLX_EXT_swap_control_tear ----------------------- */ - -#ifndef GLX_EXT_swap_control_tear -#define GLX_EXT_swap_control_tear 1 - -#define GLX_LATE_SWAPS_TEAR_EXT 0x20F3 - -#define GLXEW_EXT_swap_control_tear GLXEW_GET_VAR(__GLXEW_EXT_swap_control_tear) - -#endif /* GLX_EXT_swap_control_tear */ - -/* ---------------------- GLX_EXT_texture_from_pixmap ---------------------- */ - -#ifndef GLX_EXT_texture_from_pixmap -#define GLX_EXT_texture_from_pixmap 1 - -#define GLX_TEXTURE_1D_BIT_EXT 0x00000001 -#define GLX_TEXTURE_2D_BIT_EXT 0x00000002 -#define GLX_TEXTURE_RECTANGLE_BIT_EXT 0x00000004 -#define GLX_BIND_TO_TEXTURE_RGB_EXT 0x20D0 -#define GLX_BIND_TO_TEXTURE_RGBA_EXT 0x20D1 -#define GLX_BIND_TO_MIPMAP_TEXTURE_EXT 0x20D2 -#define GLX_BIND_TO_TEXTURE_TARGETS_EXT 0x20D3 -#define GLX_Y_INVERTED_EXT 0x20D4 -#define GLX_TEXTURE_FORMAT_EXT 0x20D5 -#define GLX_TEXTURE_TARGET_EXT 0x20D6 -#define GLX_MIPMAP_TEXTURE_EXT 0x20D7 -#define GLX_TEXTURE_FORMAT_NONE_EXT 0x20D8 -#define GLX_TEXTURE_FORMAT_RGB_EXT 0x20D9 -#define GLX_TEXTURE_FORMAT_RGBA_EXT 0x20DA -#define GLX_TEXTURE_1D_EXT 0x20DB -#define GLX_TEXTURE_2D_EXT 0x20DC -#define GLX_TEXTURE_RECTANGLE_EXT 0x20DD -#define GLX_FRONT_LEFT_EXT 0x20DE -#define GLX_FRONT_RIGHT_EXT 0x20DF -#define GLX_BACK_LEFT_EXT 0x20E0 -#define GLX_BACK_RIGHT_EXT 0x20E1 -#define GLX_AUX0_EXT 0x20E2 -#define GLX_AUX1_EXT 0x20E3 -#define GLX_AUX2_EXT 0x20E4 -#define GLX_AUX3_EXT 0x20E5 -#define GLX_AUX4_EXT 0x20E6 -#define GLX_AUX5_EXT 0x20E7 -#define GLX_AUX6_EXT 0x20E8 -#define GLX_AUX7_EXT 0x20E9 -#define GLX_AUX8_EXT 0x20EA -#define GLX_AUX9_EXT 0x20EB - -typedef void ( * PFNGLXBINDTEXIMAGEEXTPROC) (Display* display, GLXDrawable drawable, int buffer, const int *attrib_list); -typedef void ( * PFNGLXRELEASETEXIMAGEEXTPROC) (Display* display, GLXDrawable drawable, int buffer); - -#define glXBindTexImageEXT GLXEW_GET_FUN(__glewXBindTexImageEXT) -#define glXReleaseTexImageEXT GLXEW_GET_FUN(__glewXReleaseTexImageEXT) - -#define GLXEW_EXT_texture_from_pixmap GLXEW_GET_VAR(__GLXEW_EXT_texture_from_pixmap) - -#endif /* GLX_EXT_texture_from_pixmap */ - -/* -------------------------- GLX_EXT_visual_info -------------------------- */ - -#ifndef GLX_EXT_visual_info -#define GLX_EXT_visual_info 1 - -#define GLX_X_VISUAL_TYPE_EXT 0x22 -#define GLX_TRANSPARENT_TYPE_EXT 0x23 -#define GLX_TRANSPARENT_INDEX_VALUE_EXT 0x24 -#define GLX_TRANSPARENT_RED_VALUE_EXT 0x25 -#define GLX_TRANSPARENT_GREEN_VALUE_EXT 0x26 -#define GLX_TRANSPARENT_BLUE_VALUE_EXT 0x27 -#define GLX_TRANSPARENT_ALPHA_VALUE_EXT 0x28 -#define GLX_NONE_EXT 0x8000 -#define GLX_TRUE_COLOR_EXT 0x8002 -#define GLX_DIRECT_COLOR_EXT 0x8003 -#define GLX_PSEUDO_COLOR_EXT 0x8004 -#define GLX_STATIC_COLOR_EXT 0x8005 -#define GLX_GRAY_SCALE_EXT 0x8006 -#define GLX_STATIC_GRAY_EXT 0x8007 -#define GLX_TRANSPARENT_RGB_EXT 0x8008 -#define GLX_TRANSPARENT_INDEX_EXT 0x8009 - -#define GLXEW_EXT_visual_info GLXEW_GET_VAR(__GLXEW_EXT_visual_info) - -#endif /* GLX_EXT_visual_info */ - -/* ------------------------- GLX_EXT_visual_rating ------------------------- */ - -#ifndef GLX_EXT_visual_rating -#define GLX_EXT_visual_rating 1 - -#define GLX_VISUAL_CAVEAT_EXT 0x20 -#define GLX_SLOW_VISUAL_EXT 0x8001 -#define GLX_NON_CONFORMANT_VISUAL_EXT 0x800D - -#define GLXEW_EXT_visual_rating GLXEW_GET_VAR(__GLXEW_EXT_visual_rating) - -#endif /* GLX_EXT_visual_rating */ - -/* -------------------------- GLX_INTEL_swap_event ------------------------- */ - -#ifndef GLX_INTEL_swap_event -#define GLX_INTEL_swap_event 1 - -#define GLX_EXCHANGE_COMPLETE_INTEL 0x8180 -#define GLX_COPY_COMPLETE_INTEL 0x8181 -#define GLX_FLIP_COMPLETE_INTEL 0x8182 -#define GLX_BUFFER_SWAP_COMPLETE_INTEL_MASK 0x04000000 - -#define GLXEW_INTEL_swap_event GLXEW_GET_VAR(__GLXEW_INTEL_swap_event) - -#endif /* GLX_INTEL_swap_event */ - -/* -------------------------- GLX_MESA_agp_offset -------------------------- */ - -#ifndef GLX_MESA_agp_offset -#define GLX_MESA_agp_offset 1 - -typedef unsigned int ( * PFNGLXGETAGPOFFSETMESAPROC) (const void* pointer); - -#define glXGetAGPOffsetMESA GLXEW_GET_FUN(__glewXGetAGPOffsetMESA) - -#define GLXEW_MESA_agp_offset GLXEW_GET_VAR(__GLXEW_MESA_agp_offset) - -#endif /* GLX_MESA_agp_offset */ - -/* ------------------------ GLX_MESA_copy_sub_buffer ----------------------- */ - -#ifndef GLX_MESA_copy_sub_buffer -#define GLX_MESA_copy_sub_buffer 1 - -typedef void ( * PFNGLXCOPYSUBBUFFERMESAPROC) (Display* dpy, GLXDrawable drawable, int x, int y, int width, int height); - -#define glXCopySubBufferMESA GLXEW_GET_FUN(__glewXCopySubBufferMESA) - -#define GLXEW_MESA_copy_sub_buffer GLXEW_GET_VAR(__GLXEW_MESA_copy_sub_buffer) - -#endif /* GLX_MESA_copy_sub_buffer */ - -/* ------------------------ GLX_MESA_pixmap_colormap ----------------------- */ - -#ifndef GLX_MESA_pixmap_colormap -#define GLX_MESA_pixmap_colormap 1 - -typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPMESAPROC) (Display* dpy, XVisualInfo *visual, Pixmap pixmap, Colormap cmap); - -#define glXCreateGLXPixmapMESA GLXEW_GET_FUN(__glewXCreateGLXPixmapMESA) - -#define GLXEW_MESA_pixmap_colormap GLXEW_GET_VAR(__GLXEW_MESA_pixmap_colormap) - -#endif /* GLX_MESA_pixmap_colormap */ - -/* ------------------------ GLX_MESA_release_buffers ----------------------- */ - -#ifndef GLX_MESA_release_buffers -#define GLX_MESA_release_buffers 1 - -typedef Bool ( * PFNGLXRELEASEBUFFERSMESAPROC) (Display* dpy, GLXDrawable d); - -#define glXReleaseBuffersMESA GLXEW_GET_FUN(__glewXReleaseBuffersMESA) - -#define GLXEW_MESA_release_buffers GLXEW_GET_VAR(__GLXEW_MESA_release_buffers) - -#endif /* GLX_MESA_release_buffers */ - -/* ------------------------- GLX_MESA_set_3dfx_mode ------------------------ */ - -#ifndef GLX_MESA_set_3dfx_mode -#define GLX_MESA_set_3dfx_mode 1 - -#define GLX_3DFX_WINDOW_MODE_MESA 0x1 -#define GLX_3DFX_FULLSCREEN_MODE_MESA 0x2 - -typedef GLboolean ( * PFNGLXSET3DFXMODEMESAPROC) (GLint mode); - -#define glXSet3DfxModeMESA GLXEW_GET_FUN(__glewXSet3DfxModeMESA) - -#define GLXEW_MESA_set_3dfx_mode GLXEW_GET_VAR(__GLXEW_MESA_set_3dfx_mode) - -#endif /* GLX_MESA_set_3dfx_mode */ - -/* ------------------------- GLX_MESA_swap_control ------------------------- */ - -#ifndef GLX_MESA_swap_control -#define GLX_MESA_swap_control 1 - -typedef int ( * PFNGLXGETSWAPINTERVALMESAPROC) (void); -typedef int ( * PFNGLXSWAPINTERVALMESAPROC) (unsigned int interval); - -#define glXGetSwapIntervalMESA GLXEW_GET_FUN(__glewXGetSwapIntervalMESA) -#define glXSwapIntervalMESA GLXEW_GET_FUN(__glewXSwapIntervalMESA) - -#define GLXEW_MESA_swap_control GLXEW_GET_VAR(__GLXEW_MESA_swap_control) - -#endif /* GLX_MESA_swap_control */ - -/* --------------------------- GLX_NV_copy_image --------------------------- */ - -#ifndef GLX_NV_copy_image -#define GLX_NV_copy_image 1 - -typedef void ( * PFNGLXCOPYIMAGESUBDATANVPROC) (Display *dpy, GLXContext srcCtx, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, GLXContext dstCtx, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); - -#define glXCopyImageSubDataNV GLXEW_GET_FUN(__glewXCopyImageSubDataNV) - -#define GLXEW_NV_copy_image GLXEW_GET_VAR(__GLXEW_NV_copy_image) - -#endif /* GLX_NV_copy_image */ - -/* -------------------------- GLX_NV_float_buffer -------------------------- */ - -#ifndef GLX_NV_float_buffer -#define GLX_NV_float_buffer 1 - -#define GLX_FLOAT_COMPONENTS_NV 0x20B0 - -#define GLXEW_NV_float_buffer GLXEW_GET_VAR(__GLXEW_NV_float_buffer) - -#endif /* GLX_NV_float_buffer */ - -/* ---------------------- GLX_NV_multisample_coverage ---------------------- */ - -#ifndef GLX_NV_multisample_coverage -#define GLX_NV_multisample_coverage 1 - -#define GLX_COLOR_SAMPLES_NV 0x20B3 -#define GLX_COVERAGE_SAMPLES_NV 100001 - -#define GLXEW_NV_multisample_coverage GLXEW_GET_VAR(__GLXEW_NV_multisample_coverage) - -#endif /* GLX_NV_multisample_coverage */ - -/* -------------------------- GLX_NV_present_video ------------------------- */ - -#ifndef GLX_NV_present_video -#define GLX_NV_present_video 1 - -#define GLX_NUM_VIDEO_SLOTS_NV 0x20F0 - -typedef int ( * PFNGLXBINDVIDEODEVICENVPROC) (Display* dpy, unsigned int video_slot, unsigned int video_device, const int *attrib_list); -typedef unsigned int* ( * PFNGLXENUMERATEVIDEODEVICESNVPROC) (Display *dpy, int screen, int *nelements); - -#define glXBindVideoDeviceNV GLXEW_GET_FUN(__glewXBindVideoDeviceNV) -#define glXEnumerateVideoDevicesNV GLXEW_GET_FUN(__glewXEnumerateVideoDevicesNV) - -#define GLXEW_NV_present_video GLXEW_GET_VAR(__GLXEW_NV_present_video) - -#endif /* GLX_NV_present_video */ - -/* --------------------------- GLX_NV_swap_group --------------------------- */ - -#ifndef GLX_NV_swap_group -#define GLX_NV_swap_group 1 - -typedef Bool ( * PFNGLXBINDSWAPBARRIERNVPROC) (Display* dpy, GLuint group, GLuint barrier); -typedef Bool ( * PFNGLXJOINSWAPGROUPNVPROC) (Display* dpy, GLXDrawable drawable, GLuint group); -typedef Bool ( * PFNGLXQUERYFRAMECOUNTNVPROC) (Display* dpy, int screen, GLuint *count); -typedef Bool ( * PFNGLXQUERYMAXSWAPGROUPSNVPROC) (Display* dpy, int screen, GLuint *maxGroups, GLuint *maxBarriers); -typedef Bool ( * PFNGLXQUERYSWAPGROUPNVPROC) (Display* dpy, GLXDrawable drawable, GLuint *group, GLuint *barrier); -typedef Bool ( * PFNGLXRESETFRAMECOUNTNVPROC) (Display* dpy, int screen); - -#define glXBindSwapBarrierNV GLXEW_GET_FUN(__glewXBindSwapBarrierNV) -#define glXJoinSwapGroupNV GLXEW_GET_FUN(__glewXJoinSwapGroupNV) -#define glXQueryFrameCountNV GLXEW_GET_FUN(__glewXQueryFrameCountNV) -#define glXQueryMaxSwapGroupsNV GLXEW_GET_FUN(__glewXQueryMaxSwapGroupsNV) -#define glXQuerySwapGroupNV GLXEW_GET_FUN(__glewXQuerySwapGroupNV) -#define glXResetFrameCountNV GLXEW_GET_FUN(__glewXResetFrameCountNV) - -#define GLXEW_NV_swap_group GLXEW_GET_VAR(__GLXEW_NV_swap_group) - -#endif /* GLX_NV_swap_group */ - -/* ----------------------- GLX_NV_vertex_array_range ----------------------- */ - -#ifndef GLX_NV_vertex_array_range -#define GLX_NV_vertex_array_range 1 - -typedef void * ( * PFNGLXALLOCATEMEMORYNVPROC) (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority); -typedef void ( * PFNGLXFREEMEMORYNVPROC) (void *pointer); - -#define glXAllocateMemoryNV GLXEW_GET_FUN(__glewXAllocateMemoryNV) -#define glXFreeMemoryNV GLXEW_GET_FUN(__glewXFreeMemoryNV) - -#define GLXEW_NV_vertex_array_range GLXEW_GET_VAR(__GLXEW_NV_vertex_array_range) - -#endif /* GLX_NV_vertex_array_range */ - -/* -------------------------- GLX_NV_video_capture ------------------------- */ - -#ifndef GLX_NV_video_capture -#define GLX_NV_video_capture 1 - -#define GLX_DEVICE_ID_NV 0x20CD -#define GLX_UNIQUE_ID_NV 0x20CE -#define GLX_NUM_VIDEO_CAPTURE_SLOTS_NV 0x20CF - -typedef XID GLXVideoCaptureDeviceNV; - -typedef int ( * PFNGLXBINDVIDEOCAPTUREDEVICENVPROC) (Display* dpy, unsigned int video_capture_slot, GLXVideoCaptureDeviceNV device); -typedef GLXVideoCaptureDeviceNV * ( * PFNGLXENUMERATEVIDEOCAPTUREDEVICESNVPROC) (Display* dpy, int screen, int *nelements); -typedef void ( * PFNGLXLOCKVIDEOCAPTUREDEVICENVPROC) (Display* dpy, GLXVideoCaptureDeviceNV device); -typedef int ( * PFNGLXQUERYVIDEOCAPTUREDEVICENVPROC) (Display* dpy, GLXVideoCaptureDeviceNV device, int attribute, int *value); -typedef void ( * PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC) (Display* dpy, GLXVideoCaptureDeviceNV device); - -#define glXBindVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXBindVideoCaptureDeviceNV) -#define glXEnumerateVideoCaptureDevicesNV GLXEW_GET_FUN(__glewXEnumerateVideoCaptureDevicesNV) -#define glXLockVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXLockVideoCaptureDeviceNV) -#define glXQueryVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXQueryVideoCaptureDeviceNV) -#define glXReleaseVideoCaptureDeviceNV GLXEW_GET_FUN(__glewXReleaseVideoCaptureDeviceNV) - -#define GLXEW_NV_video_capture GLXEW_GET_VAR(__GLXEW_NV_video_capture) - -#endif /* GLX_NV_video_capture */ - -/* -------------------------- GLX_NV_video_output -------------------------- */ - -#ifndef GLX_NV_video_output -#define GLX_NV_video_output 1 - -#define GLX_VIDEO_OUT_COLOR_NV 0x20C3 -#define GLX_VIDEO_OUT_ALPHA_NV 0x20C4 -#define GLX_VIDEO_OUT_DEPTH_NV 0x20C5 -#define GLX_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 -#define GLX_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 -#define GLX_VIDEO_OUT_FRAME_NV 0x20C8 -#define GLX_VIDEO_OUT_FIELD_1_NV 0x20C9 -#define GLX_VIDEO_OUT_FIELD_2_NV 0x20CA -#define GLX_VIDEO_OUT_STACKED_FIELDS_1_2_NV 0x20CB -#define GLX_VIDEO_OUT_STACKED_FIELDS_2_1_NV 0x20CC - -typedef int ( * PFNGLXBINDVIDEOIMAGENVPROC) (Display* dpy, GLXVideoDeviceNV VideoDevice, GLXPbuffer pbuf, int iVideoBuffer); -typedef int ( * PFNGLXGETVIDEODEVICENVPROC) (Display* dpy, int screen, int numVideoDevices, GLXVideoDeviceNV *pVideoDevice); -typedef int ( * PFNGLXGETVIDEOINFONVPROC) (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice, unsigned long *pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo); -typedef int ( * PFNGLXRELEASEVIDEODEVICENVPROC) (Display* dpy, int screen, GLXVideoDeviceNV VideoDevice); -typedef int ( * PFNGLXRELEASEVIDEOIMAGENVPROC) (Display* dpy, GLXPbuffer pbuf); -typedef int ( * PFNGLXSENDPBUFFERTOVIDEONVPROC) (Display* dpy, GLXPbuffer pbuf, int iBufferType, unsigned long *pulCounterPbuffer, GLboolean bBlock); - -#define glXBindVideoImageNV GLXEW_GET_FUN(__glewXBindVideoImageNV) -#define glXGetVideoDeviceNV GLXEW_GET_FUN(__glewXGetVideoDeviceNV) -#define glXGetVideoInfoNV GLXEW_GET_FUN(__glewXGetVideoInfoNV) -#define glXReleaseVideoDeviceNV GLXEW_GET_FUN(__glewXReleaseVideoDeviceNV) -#define glXReleaseVideoImageNV GLXEW_GET_FUN(__glewXReleaseVideoImageNV) -#define glXSendPbufferToVideoNV GLXEW_GET_FUN(__glewXSendPbufferToVideoNV) - -#define GLXEW_NV_video_output GLXEW_GET_VAR(__GLXEW_NV_video_output) - -#endif /* GLX_NV_video_output */ - -/* -------------------------- GLX_OML_swap_method -------------------------- */ - -#ifndef GLX_OML_swap_method -#define GLX_OML_swap_method 1 - -#define GLX_SWAP_METHOD_OML 0x8060 -#define GLX_SWAP_EXCHANGE_OML 0x8061 -#define GLX_SWAP_COPY_OML 0x8062 -#define GLX_SWAP_UNDEFINED_OML 0x8063 - -#define GLXEW_OML_swap_method GLXEW_GET_VAR(__GLXEW_OML_swap_method) - -#endif /* GLX_OML_swap_method */ - -/* -------------------------- GLX_OML_sync_control ------------------------- */ - -#ifndef GLX_OML_sync_control -#define GLX_OML_sync_control 1 - -typedef Bool ( * PFNGLXGETMSCRATEOMLPROC) (Display* dpy, GLXDrawable drawable, int32_t* numerator, int32_t* denominator); -typedef Bool ( * PFNGLXGETSYNCVALUESOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t* ust, int64_t* msc, int64_t* sbc); -typedef int64_t ( * PFNGLXSWAPBUFFERSMSCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder); -typedef Bool ( * PFNGLXWAITFORMSCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_msc, int64_t divisor, int64_t remainder, int64_t* ust, int64_t* msc, int64_t* sbc); -typedef Bool ( * PFNGLXWAITFORSBCOMLPROC) (Display* dpy, GLXDrawable drawable, int64_t target_sbc, int64_t* ust, int64_t* msc, int64_t* sbc); - -#define glXGetMscRateOML GLXEW_GET_FUN(__glewXGetMscRateOML) -#define glXGetSyncValuesOML GLXEW_GET_FUN(__glewXGetSyncValuesOML) -#define glXSwapBuffersMscOML GLXEW_GET_FUN(__glewXSwapBuffersMscOML) -#define glXWaitForMscOML GLXEW_GET_FUN(__glewXWaitForMscOML) -#define glXWaitForSbcOML GLXEW_GET_FUN(__glewXWaitForSbcOML) - -#define GLXEW_OML_sync_control GLXEW_GET_VAR(__GLXEW_OML_sync_control) - -#endif /* GLX_OML_sync_control */ - -/* ------------------------ GLX_SGIS_blended_overlay ----------------------- */ - -#ifndef GLX_SGIS_blended_overlay -#define GLX_SGIS_blended_overlay 1 - -#define GLX_BLENDED_RGBA_SGIS 0x8025 - -#define GLXEW_SGIS_blended_overlay GLXEW_GET_VAR(__GLXEW_SGIS_blended_overlay) - -#endif /* GLX_SGIS_blended_overlay */ - -/* -------------------------- GLX_SGIS_color_range ------------------------- */ - -#ifndef GLX_SGIS_color_range -#define GLX_SGIS_color_range 1 - -#define GLXEW_SGIS_color_range GLXEW_GET_VAR(__GLXEW_SGIS_color_range) - -#endif /* GLX_SGIS_color_range */ - -/* -------------------------- GLX_SGIS_multisample ------------------------- */ - -#ifndef GLX_SGIS_multisample -#define GLX_SGIS_multisample 1 - -#define GLX_SAMPLE_BUFFERS_SGIS 100000 -#define GLX_SAMPLES_SGIS 100001 - -#define GLXEW_SGIS_multisample GLXEW_GET_VAR(__GLXEW_SGIS_multisample) - -#endif /* GLX_SGIS_multisample */ - -/* ---------------------- GLX_SGIS_shared_multisample ---------------------- */ - -#ifndef GLX_SGIS_shared_multisample -#define GLX_SGIS_shared_multisample 1 - -#define GLX_MULTISAMPLE_SUB_RECT_WIDTH_SGIS 0x8026 -#define GLX_MULTISAMPLE_SUB_RECT_HEIGHT_SGIS 0x8027 - -#define GLXEW_SGIS_shared_multisample GLXEW_GET_VAR(__GLXEW_SGIS_shared_multisample) - -#endif /* GLX_SGIS_shared_multisample */ - -/* --------------------------- GLX_SGIX_fbconfig --------------------------- */ - -#ifndef GLX_SGIX_fbconfig -#define GLX_SGIX_fbconfig 1 - -#define GLX_WINDOW_BIT_SGIX 0x00000001 -#define GLX_RGBA_BIT_SGIX 0x00000001 -#define GLX_PIXMAP_BIT_SGIX 0x00000002 -#define GLX_COLOR_INDEX_BIT_SGIX 0x00000002 -#define GLX_SCREEN_EXT 0x800C -#define GLX_DRAWABLE_TYPE_SGIX 0x8010 -#define GLX_RENDER_TYPE_SGIX 0x8011 -#define GLX_X_RENDERABLE_SGIX 0x8012 -#define GLX_FBCONFIG_ID_SGIX 0x8013 -#define GLX_RGBA_TYPE_SGIX 0x8014 -#define GLX_COLOR_INDEX_TYPE_SGIX 0x8015 - -typedef XID GLXFBConfigIDSGIX; -typedef struct __GLXFBConfigRec *GLXFBConfigSGIX; - -typedef GLXFBConfigSGIX* ( * PFNGLXCHOOSEFBCONFIGSGIXPROC) (Display *dpy, int screen, const int *attrib_list, int *nelements); -typedef GLXContext ( * PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC) (Display* dpy, GLXFBConfig config, int render_type, GLXContext share_list, Bool direct); -typedef GLXPixmap ( * PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC) (Display* dpy, GLXFBConfig config, Pixmap pixmap); -typedef int ( * PFNGLXGETFBCONFIGATTRIBSGIXPROC) (Display* dpy, GLXFBConfigSGIX config, int attribute, int *value); -typedef GLXFBConfigSGIX ( * PFNGLXGETFBCONFIGFROMVISUALSGIXPROC) (Display* dpy, XVisualInfo *vis); -typedef XVisualInfo* ( * PFNGLXGETVISUALFROMFBCONFIGSGIXPROC) (Display *dpy, GLXFBConfig config); - -#define glXChooseFBConfigSGIX GLXEW_GET_FUN(__glewXChooseFBConfigSGIX) -#define glXCreateContextWithConfigSGIX GLXEW_GET_FUN(__glewXCreateContextWithConfigSGIX) -#define glXCreateGLXPixmapWithConfigSGIX GLXEW_GET_FUN(__glewXCreateGLXPixmapWithConfigSGIX) -#define glXGetFBConfigAttribSGIX GLXEW_GET_FUN(__glewXGetFBConfigAttribSGIX) -#define glXGetFBConfigFromVisualSGIX GLXEW_GET_FUN(__glewXGetFBConfigFromVisualSGIX) -#define glXGetVisualFromFBConfigSGIX GLXEW_GET_FUN(__glewXGetVisualFromFBConfigSGIX) - -#define GLXEW_SGIX_fbconfig GLXEW_GET_VAR(__GLXEW_SGIX_fbconfig) - -#endif /* GLX_SGIX_fbconfig */ - -/* --------------------------- GLX_SGIX_hyperpipe -------------------------- */ - -#ifndef GLX_SGIX_hyperpipe -#define GLX_SGIX_hyperpipe 1 - -#define GLX_HYPERPIPE_DISPLAY_PIPE_SGIX 0x00000001 -#define GLX_PIPE_RECT_SGIX 0x00000001 -#define GLX_PIPE_RECT_LIMITS_SGIX 0x00000002 -#define GLX_HYPERPIPE_RENDER_PIPE_SGIX 0x00000002 -#define GLX_HYPERPIPE_STEREO_SGIX 0x00000003 -#define GLX_HYPERPIPE_PIXEL_AVERAGE_SGIX 0x00000004 -#define GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX 80 -#define GLX_BAD_HYPERPIPE_CONFIG_SGIX 91 -#define GLX_BAD_HYPERPIPE_SGIX 92 -#define GLX_HYPERPIPE_ID_SGIX 0x8030 - -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int networkId; -} GLXHyperpipeNetworkSGIX; -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int XOrigin; - int YOrigin; - int maxHeight; - int maxWidth; -} GLXPipeRectLimits; -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int channel; - unsigned int participationType; - int timeSlice; -} GLXHyperpipeConfigSGIX; -typedef struct { - char pipeName[GLX_HYPERPIPE_PIPE_NAME_LENGTH_SGIX]; - int srcXOrigin; - int srcYOrigin; - int srcWidth; - int srcHeight; - int destXOrigin; - int destYOrigin; - int destWidth; - int destHeight; -} GLXPipeRect; - -typedef int ( * PFNGLXBINDHYPERPIPESGIXPROC) (Display *dpy, int hpId); -typedef int ( * PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC) (Display *dpy, int hpId); -typedef int ( * PFNGLXHYPERPIPEATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *attribList); -typedef int ( * PFNGLXHYPERPIPECONFIGSGIXPROC) (Display *dpy, int networkId, int npipes, GLXHyperpipeConfigSGIX *cfg, int *hpId); -typedef int ( * PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *returnAttribList); -typedef int ( * PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC) (Display *dpy, int timeSlice, int attrib, int size, void *attribList, void *returnAttribList); -typedef GLXHyperpipeConfigSGIX * ( * PFNGLXQUERYHYPERPIPECONFIGSGIXPROC) (Display *dpy, int hpId, int *npipes); -typedef GLXHyperpipeNetworkSGIX * ( * PFNGLXQUERYHYPERPIPENETWORKSGIXPROC) (Display *dpy, int *npipes); - -#define glXBindHyperpipeSGIX GLXEW_GET_FUN(__glewXBindHyperpipeSGIX) -#define glXDestroyHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXDestroyHyperpipeConfigSGIX) -#define glXHyperpipeAttribSGIX GLXEW_GET_FUN(__glewXHyperpipeAttribSGIX) -#define glXHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXHyperpipeConfigSGIX) -#define glXQueryHyperpipeAttribSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeAttribSGIX) -#define glXQueryHyperpipeBestAttribSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeBestAttribSGIX) -#define glXQueryHyperpipeConfigSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeConfigSGIX) -#define glXQueryHyperpipeNetworkSGIX GLXEW_GET_FUN(__glewXQueryHyperpipeNetworkSGIX) - -#define GLXEW_SGIX_hyperpipe GLXEW_GET_VAR(__GLXEW_SGIX_hyperpipe) - -#endif /* GLX_SGIX_hyperpipe */ - -/* ---------------------------- GLX_SGIX_pbuffer --------------------------- */ - -#ifndef GLX_SGIX_pbuffer -#define GLX_SGIX_pbuffer 1 - -#define GLX_FRONT_LEFT_BUFFER_BIT_SGIX 0x00000001 -#define GLX_FRONT_RIGHT_BUFFER_BIT_SGIX 0x00000002 -#define GLX_PBUFFER_BIT_SGIX 0x00000004 -#define GLX_BACK_LEFT_BUFFER_BIT_SGIX 0x00000004 -#define GLX_BACK_RIGHT_BUFFER_BIT_SGIX 0x00000008 -#define GLX_AUX_BUFFERS_BIT_SGIX 0x00000010 -#define GLX_DEPTH_BUFFER_BIT_SGIX 0x00000020 -#define GLX_STENCIL_BUFFER_BIT_SGIX 0x00000040 -#define GLX_ACCUM_BUFFER_BIT_SGIX 0x00000080 -#define GLX_SAMPLE_BUFFERS_BIT_SGIX 0x00000100 -#define GLX_MAX_PBUFFER_WIDTH_SGIX 0x8016 -#define GLX_MAX_PBUFFER_HEIGHT_SGIX 0x8017 -#define GLX_MAX_PBUFFER_PIXELS_SGIX 0x8018 -#define GLX_OPTIMAL_PBUFFER_WIDTH_SGIX 0x8019 -#define GLX_OPTIMAL_PBUFFER_HEIGHT_SGIX 0x801A -#define GLX_PRESERVED_CONTENTS_SGIX 0x801B -#define GLX_LARGEST_PBUFFER_SGIX 0x801C -#define GLX_WIDTH_SGIX 0x801D -#define GLX_HEIGHT_SGIX 0x801E -#define GLX_EVENT_MASK_SGIX 0x801F -#define GLX_DAMAGED_SGIX 0x8020 -#define GLX_SAVED_SGIX 0x8021 -#define GLX_WINDOW_SGIX 0x8022 -#define GLX_PBUFFER_SGIX 0x8023 -#define GLX_BUFFER_CLOBBER_MASK_SGIX 0x08000000 - -typedef XID GLXPbufferSGIX; -typedef struct { int type; unsigned long serial; Bool send_event; Display *display; GLXDrawable drawable; int event_type; int draw_type; unsigned int mask; int x, y; int width, height; int count; } GLXBufferClobberEventSGIX; - -typedef GLXPbuffer ( * PFNGLXCREATEGLXPBUFFERSGIXPROC) (Display* dpy, GLXFBConfig config, unsigned int width, unsigned int height, int *attrib_list); -typedef void ( * PFNGLXDESTROYGLXPBUFFERSGIXPROC) (Display* dpy, GLXPbuffer pbuf); -typedef void ( * PFNGLXGETSELECTEDEVENTSGIXPROC) (Display* dpy, GLXDrawable drawable, unsigned long *mask); -typedef void ( * PFNGLXQUERYGLXPBUFFERSGIXPROC) (Display* dpy, GLXPbuffer pbuf, int attribute, unsigned int *value); -typedef void ( * PFNGLXSELECTEVENTSGIXPROC) (Display* dpy, GLXDrawable drawable, unsigned long mask); - -#define glXCreateGLXPbufferSGIX GLXEW_GET_FUN(__glewXCreateGLXPbufferSGIX) -#define glXDestroyGLXPbufferSGIX GLXEW_GET_FUN(__glewXDestroyGLXPbufferSGIX) -#define glXGetSelectedEventSGIX GLXEW_GET_FUN(__glewXGetSelectedEventSGIX) -#define glXQueryGLXPbufferSGIX GLXEW_GET_FUN(__glewXQueryGLXPbufferSGIX) -#define glXSelectEventSGIX GLXEW_GET_FUN(__glewXSelectEventSGIX) - -#define GLXEW_SGIX_pbuffer GLXEW_GET_VAR(__GLXEW_SGIX_pbuffer) - -#endif /* GLX_SGIX_pbuffer */ - -/* ------------------------- GLX_SGIX_swap_barrier ------------------------- */ - -#ifndef GLX_SGIX_swap_barrier -#define GLX_SGIX_swap_barrier 1 - -typedef void ( * PFNGLXBINDSWAPBARRIERSGIXPROC) (Display *dpy, GLXDrawable drawable, int barrier); -typedef Bool ( * PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC) (Display *dpy, int screen, int *max); - -#define glXBindSwapBarrierSGIX GLXEW_GET_FUN(__glewXBindSwapBarrierSGIX) -#define glXQueryMaxSwapBarriersSGIX GLXEW_GET_FUN(__glewXQueryMaxSwapBarriersSGIX) - -#define GLXEW_SGIX_swap_barrier GLXEW_GET_VAR(__GLXEW_SGIX_swap_barrier) - -#endif /* GLX_SGIX_swap_barrier */ - -/* -------------------------- GLX_SGIX_swap_group -------------------------- */ - -#ifndef GLX_SGIX_swap_group -#define GLX_SGIX_swap_group 1 - -typedef void ( * PFNGLXJOINSWAPGROUPSGIXPROC) (Display *dpy, GLXDrawable drawable, GLXDrawable member); - -#define glXJoinSwapGroupSGIX GLXEW_GET_FUN(__glewXJoinSwapGroupSGIX) - -#define GLXEW_SGIX_swap_group GLXEW_GET_VAR(__GLXEW_SGIX_swap_group) - -#endif /* GLX_SGIX_swap_group */ - -/* ------------------------- GLX_SGIX_video_resize ------------------------- */ - -#ifndef GLX_SGIX_video_resize -#define GLX_SGIX_video_resize 1 - -#define GLX_SYNC_FRAME_SGIX 0x00000000 -#define GLX_SYNC_SWAP_SGIX 0x00000001 - -typedef int ( * PFNGLXBINDCHANNELTOWINDOWSGIXPROC) (Display* display, int screen, int channel, Window window); -typedef int ( * PFNGLXCHANNELRECTSGIXPROC) (Display* display, int screen, int channel, int x, int y, int w, int h); -typedef int ( * PFNGLXCHANNELRECTSYNCSGIXPROC) (Display* display, int screen, int channel, GLenum synctype); -typedef int ( * PFNGLXQUERYCHANNELDELTASSGIXPROC) (Display* display, int screen, int channel, int *x, int *y, int *w, int *h); -typedef int ( * PFNGLXQUERYCHANNELRECTSGIXPROC) (Display* display, int screen, int channel, int *dx, int *dy, int *dw, int *dh); - -#define glXBindChannelToWindowSGIX GLXEW_GET_FUN(__glewXBindChannelToWindowSGIX) -#define glXChannelRectSGIX GLXEW_GET_FUN(__glewXChannelRectSGIX) -#define glXChannelRectSyncSGIX GLXEW_GET_FUN(__glewXChannelRectSyncSGIX) -#define glXQueryChannelDeltasSGIX GLXEW_GET_FUN(__glewXQueryChannelDeltasSGIX) -#define glXQueryChannelRectSGIX GLXEW_GET_FUN(__glewXQueryChannelRectSGIX) - -#define GLXEW_SGIX_video_resize GLXEW_GET_VAR(__GLXEW_SGIX_video_resize) - -#endif /* GLX_SGIX_video_resize */ - -/* ---------------------- GLX_SGIX_visual_select_group --------------------- */ - -#ifndef GLX_SGIX_visual_select_group -#define GLX_SGIX_visual_select_group 1 - -#define GLX_VISUAL_SELECT_GROUP_SGIX 0x8028 - -#define GLXEW_SGIX_visual_select_group GLXEW_GET_VAR(__GLXEW_SGIX_visual_select_group) - -#endif /* GLX_SGIX_visual_select_group */ - -/* ---------------------------- GLX_SGI_cushion ---------------------------- */ - -#ifndef GLX_SGI_cushion -#define GLX_SGI_cushion 1 - -typedef void ( * PFNGLXCUSHIONSGIPROC) (Display* dpy, Window window, float cushion); - -#define glXCushionSGI GLXEW_GET_FUN(__glewXCushionSGI) - -#define GLXEW_SGI_cushion GLXEW_GET_VAR(__GLXEW_SGI_cushion) - -#endif /* GLX_SGI_cushion */ - -/* ----------------------- GLX_SGI_make_current_read ----------------------- */ - -#ifndef GLX_SGI_make_current_read -#define GLX_SGI_make_current_read 1 - -typedef GLXDrawable ( * PFNGLXGETCURRENTREADDRAWABLESGIPROC) (void); -typedef Bool ( * PFNGLXMAKECURRENTREADSGIPROC) (Display* dpy, GLXDrawable draw, GLXDrawable read, GLXContext ctx); - -#define glXGetCurrentReadDrawableSGI GLXEW_GET_FUN(__glewXGetCurrentReadDrawableSGI) -#define glXMakeCurrentReadSGI GLXEW_GET_FUN(__glewXMakeCurrentReadSGI) - -#define GLXEW_SGI_make_current_read GLXEW_GET_VAR(__GLXEW_SGI_make_current_read) - -#endif /* GLX_SGI_make_current_read */ - -/* -------------------------- GLX_SGI_swap_control ------------------------- */ - -#ifndef GLX_SGI_swap_control -#define GLX_SGI_swap_control 1 - -typedef int ( * PFNGLXSWAPINTERVALSGIPROC) (int interval); - -#define glXSwapIntervalSGI GLXEW_GET_FUN(__glewXSwapIntervalSGI) - -#define GLXEW_SGI_swap_control GLXEW_GET_VAR(__GLXEW_SGI_swap_control) - -#endif /* GLX_SGI_swap_control */ - -/* --------------------------- GLX_SGI_video_sync -------------------------- */ - -#ifndef GLX_SGI_video_sync -#define GLX_SGI_video_sync 1 - -typedef int ( * PFNGLXGETVIDEOSYNCSGIPROC) (unsigned int* count); -typedef int ( * PFNGLXWAITVIDEOSYNCSGIPROC) (int divisor, int remainder, unsigned int* count); - -#define glXGetVideoSyncSGI GLXEW_GET_FUN(__glewXGetVideoSyncSGI) -#define glXWaitVideoSyncSGI GLXEW_GET_FUN(__glewXWaitVideoSyncSGI) - -#define GLXEW_SGI_video_sync GLXEW_GET_VAR(__GLXEW_SGI_video_sync) - -#endif /* GLX_SGI_video_sync */ - -/* --------------------- GLX_SUN_get_transparent_index --------------------- */ - -#ifndef GLX_SUN_get_transparent_index -#define GLX_SUN_get_transparent_index 1 - -typedef Status ( * PFNGLXGETTRANSPARENTINDEXSUNPROC) (Display* dpy, Window overlay, Window underlay, unsigned long *pTransparentIndex); - -#define glXGetTransparentIndexSUN GLXEW_GET_FUN(__glewXGetTransparentIndexSUN) - -#define GLXEW_SUN_get_transparent_index GLXEW_GET_VAR(__GLXEW_SUN_get_transparent_index) - -#endif /* GLX_SUN_get_transparent_index */ - -/* -------------------------- GLX_SUN_video_resize ------------------------- */ - -#ifndef GLX_SUN_video_resize -#define GLX_SUN_video_resize 1 - -#define GLX_VIDEO_RESIZE_SUN 0x8171 -#define GL_VIDEO_RESIZE_COMPENSATION_SUN 0x85CD - -typedef int ( * PFNGLXGETVIDEORESIZESUNPROC) (Display* display, GLXDrawable window, float* factor); -typedef int ( * PFNGLXVIDEORESIZESUNPROC) (Display* display, GLXDrawable window, float factor); - -#define glXGetVideoResizeSUN GLXEW_GET_FUN(__glewXGetVideoResizeSUN) -#define glXVideoResizeSUN GLXEW_GET_FUN(__glewXVideoResizeSUN) - -#define GLXEW_SUN_video_resize GLXEW_GET_VAR(__GLXEW_SUN_video_resize) - -#endif /* GLX_SUN_video_resize */ - -/* ------------------------------------------------------------------------- */ - -#ifdef GLEW_MX -#define GLXEW_FUN_EXPORT GLEW_FUN_EXPORT -#define GLXEW_VAR_EXPORT -#else -#define GLXEW_FUN_EXPORT GLEW_FUN_EXPORT -#define GLXEW_VAR_EXPORT GLEW_VAR_EXPORT -#endif /* GLEW_MX */ - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -GLXEW_FUN_EXPORT PFNGLXGETPROCADDRESSARBPROC __glewXGetProcAddressARB; -GLXEW_FUN_EXPORT PFNGLXQUERYEXTENSION __glewXQueryExtension; -GLXEW_FUN_EXPORT PFNGLXQUERYVERSION __glewXQueryVersion; -GLXEW_FUN_EXPORT PFNGLXGETCONFIG __glewXGetConfig; -GLXEW_FUN_EXPORT PFNGLXCHOOSEVISUAL __glewXChooseVisual; -GLXEW_FUN_EXPORT PFNGLXCREATECONTEXT __glewXCreateContext; -GLXEW_FUN_EXPORT PFNGLXDESTROYCONTEXT __glewXDestroyContext; -GLXEW_FUN_EXPORT PFNGLXISDIRECT __glewXIsDirect; -GLXEW_FUN_EXPORT PFNGLXMAKECURRENT __glewXMakeCurrent; -GLXEW_FUN_EXPORT PFNGLXQUERYEXTENSIONSSTRING __glewXQueryExtensionsString; -GLXEW_FUN_EXPORT PFNGLXGETCLIENTSTRING __glewXGetClientString; -GLXEW_FUN_EXPORT PFNGLXQUERYSERVERSTRING __glewXQueryServerString; -GLXEW_FUN_EXPORT PFNGLXSWAPBUFFERS __glewXSwapBuffers; - - -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -GLXEW_FUN_EXPORT PFNGLXGETCURRENTDISPLAYPROC __glewXGetCurrentDisplay; - -GLXEW_FUN_EXPORT PFNGLXCHOOSEFBCONFIGPROC __glewXChooseFBConfig; -GLXEW_FUN_EXPORT PFNGLXCREATENEWCONTEXTPROC __glewXCreateNewContext; -GLXEW_FUN_EXPORT PFNGLXCREATEPBUFFERPROC __glewXCreatePbuffer; -GLXEW_FUN_EXPORT PFNGLXCREATEPIXMAPPROC __glewXCreatePixmap; -GLXEW_FUN_EXPORT PFNGLXCREATEWINDOWPROC __glewXCreateWindow; -GLXEW_FUN_EXPORT PFNGLXDESTROYPBUFFERPROC __glewXDestroyPbuffer; -GLXEW_FUN_EXPORT PFNGLXDESTROYPIXMAPPROC __glewXDestroyPixmap; -GLXEW_FUN_EXPORT PFNGLXDESTROYWINDOWPROC __glewXDestroyWindow; -GLXEW_FUN_EXPORT PFNGLXGETCURRENTREADDRAWABLEPROC __glewXGetCurrentReadDrawable; -GLXEW_FUN_EXPORT PFNGLXGETFBCONFIGATTRIBPROC __glewXGetFBConfigAttrib; -GLXEW_FUN_EXPORT PFNGLXGETFBCONFIGSPROC __glewXGetFBConfigs; -GLXEW_FUN_EXPORT PFNGLXGETSELECTEDEVENTPROC __glewXGetSelectedEvent; -GLXEW_FUN_EXPORT PFNGLXGETVISUALFROMFBCONFIGPROC __glewXGetVisualFromFBConfig; -GLXEW_FUN_EXPORT PFNGLXMAKECONTEXTCURRENTPROC __glewXMakeContextCurrent; -GLXEW_FUN_EXPORT PFNGLXQUERYCONTEXTPROC __glewXQueryContext; -GLXEW_FUN_EXPORT PFNGLXQUERYDRAWABLEPROC __glewXQueryDrawable; -GLXEW_FUN_EXPORT PFNGLXSELECTEVENTPROC __glewXSelectEvent; - -GLXEW_FUN_EXPORT PFNGLXBLITCONTEXTFRAMEBUFFERAMDPROC __glewXBlitContextFramebufferAMD; -GLXEW_FUN_EXPORT PFNGLXCREATEASSOCIATEDCONTEXTAMDPROC __glewXCreateAssociatedContextAMD; -GLXEW_FUN_EXPORT PFNGLXCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __glewXCreateAssociatedContextAttribsAMD; -GLXEW_FUN_EXPORT PFNGLXDELETEASSOCIATEDCONTEXTAMDPROC __glewXDeleteAssociatedContextAMD; -GLXEW_FUN_EXPORT PFNGLXGETCONTEXTGPUIDAMDPROC __glewXGetContextGPUIDAMD; -GLXEW_FUN_EXPORT PFNGLXGETCURRENTASSOCIATEDCONTEXTAMDPROC __glewXGetCurrentAssociatedContextAMD; -GLXEW_FUN_EXPORT PFNGLXGETGPUIDSAMDPROC __glewXGetGPUIDsAMD; -GLXEW_FUN_EXPORT PFNGLXGETGPUINFOAMDPROC __glewXGetGPUInfoAMD; -GLXEW_FUN_EXPORT PFNGLXMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __glewXMakeAssociatedContextCurrentAMD; - -GLXEW_FUN_EXPORT PFNGLXCREATECONTEXTATTRIBSARBPROC __glewXCreateContextAttribsARB; - - -GLXEW_FUN_EXPORT PFNGLXBINDTEXIMAGEATIPROC __glewXBindTexImageATI; -GLXEW_FUN_EXPORT PFNGLXDRAWABLEATTRIBATIPROC __glewXDrawableAttribATI; -GLXEW_FUN_EXPORT PFNGLXRELEASETEXIMAGEATIPROC __glewXReleaseTexImageATI; - -GLXEW_FUN_EXPORT PFNGLXFREECONTEXTEXTPROC __glewXFreeContextEXT; -GLXEW_FUN_EXPORT PFNGLXGETCONTEXTIDEXTPROC __glewXGetContextIDEXT; -GLXEW_FUN_EXPORT PFNGLXIMPORTCONTEXTEXTPROC __glewXImportContextEXT; -GLXEW_FUN_EXPORT PFNGLXQUERYCONTEXTINFOEXTPROC __glewXQueryContextInfoEXT; - -GLXEW_FUN_EXPORT PFNGLXSWAPINTERVALEXTPROC __glewXSwapIntervalEXT; - -GLXEW_FUN_EXPORT PFNGLXBINDTEXIMAGEEXTPROC __glewXBindTexImageEXT; -GLXEW_FUN_EXPORT PFNGLXRELEASETEXIMAGEEXTPROC __glewXReleaseTexImageEXT; - -GLXEW_FUN_EXPORT PFNGLXGETAGPOFFSETMESAPROC __glewXGetAGPOffsetMESA; - -GLXEW_FUN_EXPORT PFNGLXCOPYSUBBUFFERMESAPROC __glewXCopySubBufferMESA; - -GLXEW_FUN_EXPORT PFNGLXCREATEGLXPIXMAPMESAPROC __glewXCreateGLXPixmapMESA; - -GLXEW_FUN_EXPORT PFNGLXRELEASEBUFFERSMESAPROC __glewXReleaseBuffersMESA; - -GLXEW_FUN_EXPORT PFNGLXSET3DFXMODEMESAPROC __glewXSet3DfxModeMESA; - -GLXEW_FUN_EXPORT PFNGLXGETSWAPINTERVALMESAPROC __glewXGetSwapIntervalMESA; -GLXEW_FUN_EXPORT PFNGLXSWAPINTERVALMESAPROC __glewXSwapIntervalMESA; - -GLXEW_FUN_EXPORT PFNGLXCOPYIMAGESUBDATANVPROC __glewXCopyImageSubDataNV; - -GLXEW_FUN_EXPORT PFNGLXBINDVIDEODEVICENVPROC __glewXBindVideoDeviceNV; -GLXEW_FUN_EXPORT PFNGLXENUMERATEVIDEODEVICESNVPROC __glewXEnumerateVideoDevicesNV; - -GLXEW_FUN_EXPORT PFNGLXBINDSWAPBARRIERNVPROC __glewXBindSwapBarrierNV; -GLXEW_FUN_EXPORT PFNGLXJOINSWAPGROUPNVPROC __glewXJoinSwapGroupNV; -GLXEW_FUN_EXPORT PFNGLXQUERYFRAMECOUNTNVPROC __glewXQueryFrameCountNV; -GLXEW_FUN_EXPORT PFNGLXQUERYMAXSWAPGROUPSNVPROC __glewXQueryMaxSwapGroupsNV; -GLXEW_FUN_EXPORT PFNGLXQUERYSWAPGROUPNVPROC __glewXQuerySwapGroupNV; -GLXEW_FUN_EXPORT PFNGLXRESETFRAMECOUNTNVPROC __glewXResetFrameCountNV; - -GLXEW_FUN_EXPORT PFNGLXALLOCATEMEMORYNVPROC __glewXAllocateMemoryNV; -GLXEW_FUN_EXPORT PFNGLXFREEMEMORYNVPROC __glewXFreeMemoryNV; - -GLXEW_FUN_EXPORT PFNGLXBINDVIDEOCAPTUREDEVICENVPROC __glewXBindVideoCaptureDeviceNV; -GLXEW_FUN_EXPORT PFNGLXENUMERATEVIDEOCAPTUREDEVICESNVPROC __glewXEnumerateVideoCaptureDevicesNV; -GLXEW_FUN_EXPORT PFNGLXLOCKVIDEOCAPTUREDEVICENVPROC __glewXLockVideoCaptureDeviceNV; -GLXEW_FUN_EXPORT PFNGLXQUERYVIDEOCAPTUREDEVICENVPROC __glewXQueryVideoCaptureDeviceNV; -GLXEW_FUN_EXPORT PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC __glewXReleaseVideoCaptureDeviceNV; - -GLXEW_FUN_EXPORT PFNGLXBINDVIDEOIMAGENVPROC __glewXBindVideoImageNV; -GLXEW_FUN_EXPORT PFNGLXGETVIDEODEVICENVPROC __glewXGetVideoDeviceNV; -GLXEW_FUN_EXPORT PFNGLXGETVIDEOINFONVPROC __glewXGetVideoInfoNV; -GLXEW_FUN_EXPORT PFNGLXRELEASEVIDEODEVICENVPROC __glewXReleaseVideoDeviceNV; -GLXEW_FUN_EXPORT PFNGLXRELEASEVIDEOIMAGENVPROC __glewXReleaseVideoImageNV; -GLXEW_FUN_EXPORT PFNGLXSENDPBUFFERTOVIDEONVPROC __glewXSendPbufferToVideoNV; - -GLXEW_FUN_EXPORT PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML; -GLXEW_FUN_EXPORT PFNGLXGETSYNCVALUESOMLPROC __glewXGetSyncValuesOML; -GLXEW_FUN_EXPORT PFNGLXSWAPBUFFERSMSCOMLPROC __glewXSwapBuffersMscOML; -GLXEW_FUN_EXPORT PFNGLXWAITFORMSCOMLPROC __glewXWaitForMscOML; -GLXEW_FUN_EXPORT PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML; - -GLXEW_FUN_EXPORT PFNGLXCHOOSEFBCONFIGSGIXPROC __glewXChooseFBConfigSGIX; -GLXEW_FUN_EXPORT PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC __glewXCreateContextWithConfigSGIX; -GLXEW_FUN_EXPORT PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC __glewXCreateGLXPixmapWithConfigSGIX; -GLXEW_FUN_EXPORT PFNGLXGETFBCONFIGATTRIBSGIXPROC __glewXGetFBConfigAttribSGIX; -GLXEW_FUN_EXPORT PFNGLXGETFBCONFIGFROMVISUALSGIXPROC __glewXGetFBConfigFromVisualSGIX; -GLXEW_FUN_EXPORT PFNGLXGETVISUALFROMFBCONFIGSGIXPROC __glewXGetVisualFromFBConfigSGIX; - -GLXEW_FUN_EXPORT PFNGLXBINDHYPERPIPESGIXPROC __glewXBindHyperpipeSGIX; -GLXEW_FUN_EXPORT PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC __glewXDestroyHyperpipeConfigSGIX; -GLXEW_FUN_EXPORT PFNGLXHYPERPIPEATTRIBSGIXPROC __glewXHyperpipeAttribSGIX; -GLXEW_FUN_EXPORT PFNGLXHYPERPIPECONFIGSGIXPROC __glewXHyperpipeConfigSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC __glewXQueryHyperpipeAttribSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC __glewXQueryHyperpipeBestAttribSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYHYPERPIPECONFIGSGIXPROC __glewXQueryHyperpipeConfigSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYHYPERPIPENETWORKSGIXPROC __glewXQueryHyperpipeNetworkSGIX; - -GLXEW_FUN_EXPORT PFNGLXCREATEGLXPBUFFERSGIXPROC __glewXCreateGLXPbufferSGIX; -GLXEW_FUN_EXPORT PFNGLXDESTROYGLXPBUFFERSGIXPROC __glewXDestroyGLXPbufferSGIX; -GLXEW_FUN_EXPORT PFNGLXGETSELECTEDEVENTSGIXPROC __glewXGetSelectedEventSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYGLXPBUFFERSGIXPROC __glewXQueryGLXPbufferSGIX; -GLXEW_FUN_EXPORT PFNGLXSELECTEVENTSGIXPROC __glewXSelectEventSGIX; - -GLXEW_FUN_EXPORT PFNGLXBINDSWAPBARRIERSGIXPROC __glewXBindSwapBarrierSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC __glewXQueryMaxSwapBarriersSGIX; - -GLXEW_FUN_EXPORT PFNGLXJOINSWAPGROUPSGIXPROC __glewXJoinSwapGroupSGIX; - -GLXEW_FUN_EXPORT PFNGLXBINDCHANNELTOWINDOWSGIXPROC __glewXBindChannelToWindowSGIX; -GLXEW_FUN_EXPORT PFNGLXCHANNELRECTSGIXPROC __glewXChannelRectSGIX; -GLXEW_FUN_EXPORT PFNGLXCHANNELRECTSYNCSGIXPROC __glewXChannelRectSyncSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYCHANNELDELTASSGIXPROC __glewXQueryChannelDeltasSGIX; -GLXEW_FUN_EXPORT PFNGLXQUERYCHANNELRECTSGIXPROC __glewXQueryChannelRectSGIX; - -GLXEW_FUN_EXPORT PFNGLXCUSHIONSGIPROC __glewXCushionSGI; - -GLXEW_FUN_EXPORT PFNGLXGETCURRENTREADDRAWABLESGIPROC __glewXGetCurrentReadDrawableSGI; -GLXEW_FUN_EXPORT PFNGLXMAKECURRENTREADSGIPROC __glewXMakeCurrentReadSGI; - -GLXEW_FUN_EXPORT PFNGLXSWAPINTERVALSGIPROC __glewXSwapIntervalSGI; - -GLXEW_FUN_EXPORT PFNGLXGETVIDEOSYNCSGIPROC __glewXGetVideoSyncSGI; -GLXEW_FUN_EXPORT PFNGLXWAITVIDEOSYNCSGIPROC __glewXWaitVideoSyncSGI; - -GLXEW_FUN_EXPORT PFNGLXGETTRANSPARENTINDEXSUNPROC __glewXGetTransparentIndexSUN; - -GLXEW_FUN_EXPORT PFNGLXGETVIDEORESIZESUNPROC __glewXGetVideoResizeSUN; -GLXEW_FUN_EXPORT PFNGLXVIDEORESIZESUNPROC __glewXVideoResizeSUN; - -#if defined(GLEW_MX) -struct GLXEWContextStruct -{ -#endif /* GLEW_MX */ - -GLXEW_VAR_EXPORT GLboolean __GLXEW_VERSION_1_0; -GLXEW_VAR_EXPORT GLboolean __GLXEW_VERSION_1_1; -GLXEW_VAR_EXPORT GLboolean __GLXEW_VERSION_1_2; -GLXEW_VAR_EXPORT GLboolean __GLXEW_VERSION_1_3; -GLXEW_VAR_EXPORT GLboolean __GLXEW_VERSION_1_4; -GLXEW_VAR_EXPORT GLboolean __GLXEW_3DFX_multisample; -GLXEW_VAR_EXPORT GLboolean __GLXEW_AMD_gpu_association; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_create_context; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_create_context_profile; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_create_context_robustness; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_fbconfig_float; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_framebuffer_sRGB; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_get_proc_address; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_multisample; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_robustness_application_isolation; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_robustness_share_group_isolation; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ARB_vertex_buffer_object; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ATI_pixel_format_float; -GLXEW_VAR_EXPORT GLboolean __GLXEW_ATI_render_texture; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_buffer_age; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_create_context_es2_profile; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_create_context_es_profile; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_fbconfig_packed_float; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_framebuffer_sRGB; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_import_context; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_scene_marker; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_swap_control; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_swap_control_tear; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_texture_from_pixmap; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_visual_info; -GLXEW_VAR_EXPORT GLboolean __GLXEW_EXT_visual_rating; -GLXEW_VAR_EXPORT GLboolean __GLXEW_INTEL_swap_event; -GLXEW_VAR_EXPORT GLboolean __GLXEW_MESA_agp_offset; -GLXEW_VAR_EXPORT GLboolean __GLXEW_MESA_copy_sub_buffer; -GLXEW_VAR_EXPORT GLboolean __GLXEW_MESA_pixmap_colormap; -GLXEW_VAR_EXPORT GLboolean __GLXEW_MESA_release_buffers; -GLXEW_VAR_EXPORT GLboolean __GLXEW_MESA_set_3dfx_mode; -GLXEW_VAR_EXPORT GLboolean __GLXEW_MESA_swap_control; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_copy_image; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_float_buffer; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_multisample_coverage; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_present_video; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_swap_group; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_vertex_array_range; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_video_capture; -GLXEW_VAR_EXPORT GLboolean __GLXEW_NV_video_output; -GLXEW_VAR_EXPORT GLboolean __GLXEW_OML_swap_method; -GLXEW_VAR_EXPORT GLboolean __GLXEW_OML_sync_control; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIS_blended_overlay; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIS_color_range; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIS_multisample; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIS_shared_multisample; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_fbconfig; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_hyperpipe; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_pbuffer; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_swap_barrier; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_swap_group; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_video_resize; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGIX_visual_select_group; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGI_cushion; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGI_make_current_read; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGI_swap_control; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SGI_video_sync; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SUN_get_transparent_index; -GLXEW_VAR_EXPORT GLboolean __GLXEW_SUN_video_resize; - -#ifdef GLEW_MX -}; /* GLXEWContextStruct */ -#endif /* GLEW_MX */ - -/* ------------------------------------------------------------------------ */ - -#ifdef GLEW_MX - -typedef struct GLXEWContextStruct GLXEWContext; -GLEWAPI GLenum GLEWAPIENTRY glxewContextInit (GLXEWContext *ctx); -GLEWAPI GLboolean GLEWAPIENTRY glxewContextIsSupported (const GLXEWContext *ctx, const char *name); - -#define glxewInit() glxewContextInit(glxewGetContext()) -#define glxewIsSupported(x) glxewContextIsSupported(glxewGetContext(), x) - -#define GLXEW_GET_VAR(x) (*(const GLboolean*)&(glxewGetContext()->x)) -#define GLXEW_GET_FUN(x) x - -#else /* GLEW_MX */ - -#define GLXEW_GET_VAR(x) (*(const GLboolean*)&x) -#define GLXEW_GET_FUN(x) x - -GLEWAPI GLboolean GLEWAPIENTRY glxewIsSupported (const char *name); - -#endif /* GLEW_MX */ - -GLEWAPI GLboolean GLEWAPIENTRY glxewGetExtension (const char *name); - -#ifdef __cplusplus -} -#endif - -#endif /* __glxew_h__ */ diff --git a/btgui/OpenGLWindow/GlewWindows/GL/wglew.h b/btgui/OpenGLWindow/GlewWindows/GL/wglew.h deleted file mode 100644 index 8659841d3..000000000 --- a/btgui/OpenGLWindow/GlewWindows/GL/wglew.h +++ /dev/null @@ -1,1421 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -/* -** Copyright (c) 2007 The Khronos Group Inc. -** -** Permission is hereby granted, free of charge, to any person obtaining a -** copy of this software and/or associated documentation files (the -** "Materials"), to deal in the Materials without restriction, including -** without limitation the rights to use, copy, modify, merge, publish, -** distribute, sublicense, and/or sell copies of the Materials, and to -** permit persons to whom the Materials are furnished to do so, subject to -** the following conditions: -** -** The above copyright notice and this permission notice shall be included -** in all copies or substantial portions of the Materials. -** -** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. -*/ - -#ifndef __wglew_h__ -#define __wglew_h__ -#define __WGLEW_H__ - -#ifdef __wglext_h_ -#error wglext.h included before wglew.h -#endif - -#define __wglext_h_ - -#if !defined(WINAPI) -# ifndef WIN32_LEAN_AND_MEAN -# define WIN32_LEAN_AND_MEAN 1 -# endif -#include -# undef WIN32_LEAN_AND_MEAN -#endif - -/* - * GLEW_STATIC needs to be set when using the static version. - * GLEW_BUILD is set when building the DLL version. - */ -#ifdef GLEW_STATIC -# define GLEWAPI extern -#else -# ifdef GLEW_BUILD -# define GLEWAPI extern __declspec(dllexport) -# else -# define GLEWAPI extern __declspec(dllimport) -# endif -#endif - -#ifdef __cplusplus -extern "C" { -#endif - -/* -------------------------- WGL_3DFX_multisample ------------------------- */ - -#ifndef WGL_3DFX_multisample -#define WGL_3DFX_multisample 1 - -#define WGL_SAMPLE_BUFFERS_3DFX 0x2060 -#define WGL_SAMPLES_3DFX 0x2061 - -#define WGLEW_3DFX_multisample WGLEW_GET_VAR(__WGLEW_3DFX_multisample) - -#endif /* WGL_3DFX_multisample */ - -/* ------------------------- WGL_3DL_stereo_control ------------------------ */ - -#ifndef WGL_3DL_stereo_control -#define WGL_3DL_stereo_control 1 - -#define WGL_STEREO_EMITTER_ENABLE_3DL 0x2055 -#define WGL_STEREO_EMITTER_DISABLE_3DL 0x2056 -#define WGL_STEREO_POLARITY_NORMAL_3DL 0x2057 -#define WGL_STEREO_POLARITY_INVERT_3DL 0x2058 - -typedef BOOL (WINAPI * PFNWGLSETSTEREOEMITTERSTATE3DLPROC) (HDC hDC, UINT uState); - -#define wglSetStereoEmitterState3DL WGLEW_GET_FUN(__wglewSetStereoEmitterState3DL) - -#define WGLEW_3DL_stereo_control WGLEW_GET_VAR(__WGLEW_3DL_stereo_control) - -#endif /* WGL_3DL_stereo_control */ - -/* ------------------------ WGL_AMD_gpu_association ------------------------ */ - -#ifndef WGL_AMD_gpu_association -#define WGL_AMD_gpu_association 1 - -#define WGL_GPU_VENDOR_AMD 0x1F00 -#define WGL_GPU_RENDERER_STRING_AMD 0x1F01 -#define WGL_GPU_OPENGL_VERSION_STRING_AMD 0x1F02 -#define WGL_GPU_FASTEST_TARGET_GPUS_AMD 0x21A2 -#define WGL_GPU_RAM_AMD 0x21A3 -#define WGL_GPU_CLOCK_AMD 0x21A4 -#define WGL_GPU_NUM_PIPES_AMD 0x21A5 -#define WGL_GPU_NUM_SIMD_AMD 0x21A6 -#define WGL_GPU_NUM_RB_AMD 0x21A7 -#define WGL_GPU_NUM_SPI_AMD 0x21A8 - -typedef VOID (WINAPI * PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC) (HGLRC dstCtx, GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); -typedef HGLRC (WINAPI * PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC) (UINT id); -typedef HGLRC (WINAPI * PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC) (UINT id, HGLRC hShareContext, const int* attribList); -typedef BOOL (WINAPI * PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC) (HGLRC hglrc); -typedef UINT (WINAPI * PFNWGLGETCONTEXTGPUIDAMDPROC) (HGLRC hglrc); -typedef HGLRC (WINAPI * PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC) (void); -typedef UINT (WINAPI * PFNWGLGETGPUIDSAMDPROC) (UINT maxCount, UINT* ids); -typedef INT (WINAPI * PFNWGLGETGPUINFOAMDPROC) (UINT id, INT property, GLenum dataType, UINT size, void* data); -typedef BOOL (WINAPI * PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC) (HGLRC hglrc); - -#define wglBlitContextFramebufferAMD WGLEW_GET_FUN(__wglewBlitContextFramebufferAMD) -#define wglCreateAssociatedContextAMD WGLEW_GET_FUN(__wglewCreateAssociatedContextAMD) -#define wglCreateAssociatedContextAttribsAMD WGLEW_GET_FUN(__wglewCreateAssociatedContextAttribsAMD) -#define wglDeleteAssociatedContextAMD WGLEW_GET_FUN(__wglewDeleteAssociatedContextAMD) -#define wglGetContextGPUIDAMD WGLEW_GET_FUN(__wglewGetContextGPUIDAMD) -#define wglGetCurrentAssociatedContextAMD WGLEW_GET_FUN(__wglewGetCurrentAssociatedContextAMD) -#define wglGetGPUIDsAMD WGLEW_GET_FUN(__wglewGetGPUIDsAMD) -#define wglGetGPUInfoAMD WGLEW_GET_FUN(__wglewGetGPUInfoAMD) -#define wglMakeAssociatedContextCurrentAMD WGLEW_GET_FUN(__wglewMakeAssociatedContextCurrentAMD) - -#define WGLEW_AMD_gpu_association WGLEW_GET_VAR(__WGLEW_AMD_gpu_association) - -#endif /* WGL_AMD_gpu_association */ - -/* ------------------------- WGL_ARB_buffer_region ------------------------- */ - -#ifndef WGL_ARB_buffer_region -#define WGL_ARB_buffer_region 1 - -#define WGL_FRONT_COLOR_BUFFER_BIT_ARB 0x00000001 -#define WGL_BACK_COLOR_BUFFER_BIT_ARB 0x00000002 -#define WGL_DEPTH_BUFFER_BIT_ARB 0x00000004 -#define WGL_STENCIL_BUFFER_BIT_ARB 0x00000008 - -typedef HANDLE (WINAPI * PFNWGLCREATEBUFFERREGIONARBPROC) (HDC hDC, int iLayerPlane, UINT uType); -typedef VOID (WINAPI * PFNWGLDELETEBUFFERREGIONARBPROC) (HANDLE hRegion); -typedef BOOL (WINAPI * PFNWGLRESTOREBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height, int xSrc, int ySrc); -typedef BOOL (WINAPI * PFNWGLSAVEBUFFERREGIONARBPROC) (HANDLE hRegion, int x, int y, int width, int height); - -#define wglCreateBufferRegionARB WGLEW_GET_FUN(__wglewCreateBufferRegionARB) -#define wglDeleteBufferRegionARB WGLEW_GET_FUN(__wglewDeleteBufferRegionARB) -#define wglRestoreBufferRegionARB WGLEW_GET_FUN(__wglewRestoreBufferRegionARB) -#define wglSaveBufferRegionARB WGLEW_GET_FUN(__wglewSaveBufferRegionARB) - -#define WGLEW_ARB_buffer_region WGLEW_GET_VAR(__WGLEW_ARB_buffer_region) - -#endif /* WGL_ARB_buffer_region */ - -/* ------------------------- WGL_ARB_create_context ------------------------ */ - -#ifndef WGL_ARB_create_context -#define WGL_ARB_create_context 1 - -#define WGL_CONTEXT_DEBUG_BIT_ARB 0x0001 -#define WGL_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB 0x0002 -#define WGL_CONTEXT_MAJOR_VERSION_ARB 0x2091 -#define WGL_CONTEXT_MINOR_VERSION_ARB 0x2092 -#define WGL_CONTEXT_LAYER_PLANE_ARB 0x2093 -#define WGL_CONTEXT_FLAGS_ARB 0x2094 -#define ERROR_INVALID_VERSION_ARB 0x2095 -#define ERROR_INVALID_PROFILE_ARB 0x2096 - -typedef HGLRC (WINAPI * PFNWGLCREATECONTEXTATTRIBSARBPROC) (HDC hDC, HGLRC hShareContext, const int* attribList); - -#define wglCreateContextAttribsARB WGLEW_GET_FUN(__wglewCreateContextAttribsARB) - -#define WGLEW_ARB_create_context WGLEW_GET_VAR(__WGLEW_ARB_create_context) - -#endif /* WGL_ARB_create_context */ - -/* --------------------- WGL_ARB_create_context_profile -------------------- */ - -#ifndef WGL_ARB_create_context_profile -#define WGL_ARB_create_context_profile 1 - -#define WGL_CONTEXT_CORE_PROFILE_BIT_ARB 0x00000001 -#define WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB 0x00000002 -#define WGL_CONTEXT_PROFILE_MASK_ARB 0x9126 - -#define WGLEW_ARB_create_context_profile WGLEW_GET_VAR(__WGLEW_ARB_create_context_profile) - -#endif /* WGL_ARB_create_context_profile */ - -/* ------------------- WGL_ARB_create_context_robustness ------------------- */ - -#ifndef WGL_ARB_create_context_robustness -#define WGL_ARB_create_context_robustness 1 - -#define WGL_CONTEXT_ROBUST_ACCESS_BIT_ARB 0x00000004 -#define WGL_LOSE_CONTEXT_ON_RESET_ARB 0x8252 -#define WGL_CONTEXT_RESET_NOTIFICATION_STRATEGY_ARB 0x8256 -#define WGL_NO_RESET_NOTIFICATION_ARB 0x8261 - -#define WGLEW_ARB_create_context_robustness WGLEW_GET_VAR(__WGLEW_ARB_create_context_robustness) - -#endif /* WGL_ARB_create_context_robustness */ - -/* ----------------------- WGL_ARB_extensions_string ----------------------- */ - -#ifndef WGL_ARB_extensions_string -#define WGL_ARB_extensions_string 1 - -typedef const char* (WINAPI * PFNWGLGETEXTENSIONSSTRINGARBPROC) (HDC hdc); - -#define wglGetExtensionsStringARB WGLEW_GET_FUN(__wglewGetExtensionsStringARB) - -#define WGLEW_ARB_extensions_string WGLEW_GET_VAR(__WGLEW_ARB_extensions_string) - -#endif /* WGL_ARB_extensions_string */ - -/* ------------------------ WGL_ARB_framebuffer_sRGB ----------------------- */ - -#ifndef WGL_ARB_framebuffer_sRGB -#define WGL_ARB_framebuffer_sRGB 1 - -#define WGL_FRAMEBUFFER_SRGB_CAPABLE_ARB 0x20A9 - -#define WGLEW_ARB_framebuffer_sRGB WGLEW_GET_VAR(__WGLEW_ARB_framebuffer_sRGB) - -#endif /* WGL_ARB_framebuffer_sRGB */ - -/* ----------------------- WGL_ARB_make_current_read ----------------------- */ - -#ifndef WGL_ARB_make_current_read -#define WGL_ARB_make_current_read 1 - -#define ERROR_INVALID_PIXEL_TYPE_ARB 0x2043 -#define ERROR_INCOMPATIBLE_DEVICE_CONTEXTS_ARB 0x2054 - -typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCARBPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTARBPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); - -#define wglGetCurrentReadDCARB WGLEW_GET_FUN(__wglewGetCurrentReadDCARB) -#define wglMakeContextCurrentARB WGLEW_GET_FUN(__wglewMakeContextCurrentARB) - -#define WGLEW_ARB_make_current_read WGLEW_GET_VAR(__WGLEW_ARB_make_current_read) - -#endif /* WGL_ARB_make_current_read */ - -/* -------------------------- WGL_ARB_multisample -------------------------- */ - -#ifndef WGL_ARB_multisample -#define WGL_ARB_multisample 1 - -#define WGL_SAMPLE_BUFFERS_ARB 0x2041 -#define WGL_SAMPLES_ARB 0x2042 - -#define WGLEW_ARB_multisample WGLEW_GET_VAR(__WGLEW_ARB_multisample) - -#endif /* WGL_ARB_multisample */ - -/* ---------------------------- WGL_ARB_pbuffer ---------------------------- */ - -#ifndef WGL_ARB_pbuffer -#define WGL_ARB_pbuffer 1 - -#define WGL_DRAW_TO_PBUFFER_ARB 0x202D -#define WGL_MAX_PBUFFER_PIXELS_ARB 0x202E -#define WGL_MAX_PBUFFER_WIDTH_ARB 0x202F -#define WGL_MAX_PBUFFER_HEIGHT_ARB 0x2030 -#define WGL_PBUFFER_LARGEST_ARB 0x2033 -#define WGL_PBUFFER_WIDTH_ARB 0x2034 -#define WGL_PBUFFER_HEIGHT_ARB 0x2035 -#define WGL_PBUFFER_LOST_ARB 0x2036 - -DECLARE_HANDLE(HPBUFFERARB); - -typedef HPBUFFERARB (WINAPI * PFNWGLCREATEPBUFFERARBPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList); -typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFERARBPROC) (HPBUFFERARB hPbuffer); -typedef HDC (WINAPI * PFNWGLGETPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer); -typedef BOOL (WINAPI * PFNWGLQUERYPBUFFERARBPROC) (HPBUFFERARB hPbuffer, int iAttribute, int* piValue); -typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCARBPROC) (HPBUFFERARB hPbuffer, HDC hDC); - -#define wglCreatePbufferARB WGLEW_GET_FUN(__wglewCreatePbufferARB) -#define wglDestroyPbufferARB WGLEW_GET_FUN(__wglewDestroyPbufferARB) -#define wglGetPbufferDCARB WGLEW_GET_FUN(__wglewGetPbufferDCARB) -#define wglQueryPbufferARB WGLEW_GET_FUN(__wglewQueryPbufferARB) -#define wglReleasePbufferDCARB WGLEW_GET_FUN(__wglewReleasePbufferDCARB) - -#define WGLEW_ARB_pbuffer WGLEW_GET_VAR(__WGLEW_ARB_pbuffer) - -#endif /* WGL_ARB_pbuffer */ - -/* -------------------------- WGL_ARB_pixel_format ------------------------- */ - -#ifndef WGL_ARB_pixel_format -#define WGL_ARB_pixel_format 1 - -#define WGL_NUMBER_PIXEL_FORMATS_ARB 0x2000 -#define WGL_DRAW_TO_WINDOW_ARB 0x2001 -#define WGL_DRAW_TO_BITMAP_ARB 0x2002 -#define WGL_ACCELERATION_ARB 0x2003 -#define WGL_NEED_PALETTE_ARB 0x2004 -#define WGL_NEED_SYSTEM_PALETTE_ARB 0x2005 -#define WGL_SWAP_LAYER_BUFFERS_ARB 0x2006 -#define WGL_SWAP_METHOD_ARB 0x2007 -#define WGL_NUMBER_OVERLAYS_ARB 0x2008 -#define WGL_NUMBER_UNDERLAYS_ARB 0x2009 -#define WGL_TRANSPARENT_ARB 0x200A -#define WGL_SHARE_DEPTH_ARB 0x200C -#define WGL_SHARE_STENCIL_ARB 0x200D -#define WGL_SHARE_ACCUM_ARB 0x200E -#define WGL_SUPPORT_GDI_ARB 0x200F -#define WGL_SUPPORT_OPENGL_ARB 0x2010 -#define WGL_DOUBLE_BUFFER_ARB 0x2011 -#define WGL_STEREO_ARB 0x2012 -#define WGL_PIXEL_TYPE_ARB 0x2013 -#define WGL_COLOR_BITS_ARB 0x2014 -#define WGL_RED_BITS_ARB 0x2015 -#define WGL_RED_SHIFT_ARB 0x2016 -#define WGL_GREEN_BITS_ARB 0x2017 -#define WGL_GREEN_SHIFT_ARB 0x2018 -#define WGL_BLUE_BITS_ARB 0x2019 -#define WGL_BLUE_SHIFT_ARB 0x201A -#define WGL_ALPHA_BITS_ARB 0x201B -#define WGL_ALPHA_SHIFT_ARB 0x201C -#define WGL_ACCUM_BITS_ARB 0x201D -#define WGL_ACCUM_RED_BITS_ARB 0x201E -#define WGL_ACCUM_GREEN_BITS_ARB 0x201F -#define WGL_ACCUM_BLUE_BITS_ARB 0x2020 -#define WGL_ACCUM_ALPHA_BITS_ARB 0x2021 -#define WGL_DEPTH_BITS_ARB 0x2022 -#define WGL_STENCIL_BITS_ARB 0x2023 -#define WGL_AUX_BUFFERS_ARB 0x2024 -#define WGL_NO_ACCELERATION_ARB 0x2025 -#define WGL_GENERIC_ACCELERATION_ARB 0x2026 -#define WGL_FULL_ACCELERATION_ARB 0x2027 -#define WGL_SWAP_EXCHANGE_ARB 0x2028 -#define WGL_SWAP_COPY_ARB 0x2029 -#define WGL_SWAP_UNDEFINED_ARB 0x202A -#define WGL_TYPE_RGBA_ARB 0x202B -#define WGL_TYPE_COLORINDEX_ARB 0x202C -#define WGL_TRANSPARENT_RED_VALUE_ARB 0x2037 -#define WGL_TRANSPARENT_GREEN_VALUE_ARB 0x2038 -#define WGL_TRANSPARENT_BLUE_VALUE_ARB 0x2039 -#define WGL_TRANSPARENT_ALPHA_VALUE_ARB 0x203A -#define WGL_TRANSPARENT_INDEX_VALUE_ARB 0x203B - -typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATARBPROC) (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, FLOAT *pfValues); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVARBPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, const int* piAttributes, int *piValues); - -#define wglChoosePixelFormatARB WGLEW_GET_FUN(__wglewChoosePixelFormatARB) -#define wglGetPixelFormatAttribfvARB WGLEW_GET_FUN(__wglewGetPixelFormatAttribfvARB) -#define wglGetPixelFormatAttribivARB WGLEW_GET_FUN(__wglewGetPixelFormatAttribivARB) - -#define WGLEW_ARB_pixel_format WGLEW_GET_VAR(__WGLEW_ARB_pixel_format) - -#endif /* WGL_ARB_pixel_format */ - -/* ----------------------- WGL_ARB_pixel_format_float ---------------------- */ - -#ifndef WGL_ARB_pixel_format_float -#define WGL_ARB_pixel_format_float 1 - -#define WGL_TYPE_RGBA_FLOAT_ARB 0x21A0 - -#define WGLEW_ARB_pixel_format_float WGLEW_GET_VAR(__WGLEW_ARB_pixel_format_float) - -#endif /* WGL_ARB_pixel_format_float */ - -/* ------------------------- WGL_ARB_render_texture ------------------------ */ - -#ifndef WGL_ARB_render_texture -#define WGL_ARB_render_texture 1 - -#define WGL_BIND_TO_TEXTURE_RGB_ARB 0x2070 -#define WGL_BIND_TO_TEXTURE_RGBA_ARB 0x2071 -#define WGL_TEXTURE_FORMAT_ARB 0x2072 -#define WGL_TEXTURE_TARGET_ARB 0x2073 -#define WGL_MIPMAP_TEXTURE_ARB 0x2074 -#define WGL_TEXTURE_RGB_ARB 0x2075 -#define WGL_TEXTURE_RGBA_ARB 0x2076 -#define WGL_NO_TEXTURE_ARB 0x2077 -#define WGL_TEXTURE_CUBE_MAP_ARB 0x2078 -#define WGL_TEXTURE_1D_ARB 0x2079 -#define WGL_TEXTURE_2D_ARB 0x207A -#define WGL_MIPMAP_LEVEL_ARB 0x207B -#define WGL_CUBE_MAP_FACE_ARB 0x207C -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB 0x207D -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_X_ARB 0x207E -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Y_ARB 0x207F -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Y_ARB 0x2080 -#define WGL_TEXTURE_CUBE_MAP_POSITIVE_Z_ARB 0x2081 -#define WGL_TEXTURE_CUBE_MAP_NEGATIVE_Z_ARB 0x2082 -#define WGL_FRONT_LEFT_ARB 0x2083 -#define WGL_FRONT_RIGHT_ARB 0x2084 -#define WGL_BACK_LEFT_ARB 0x2085 -#define WGL_BACK_RIGHT_ARB 0x2086 -#define WGL_AUX0_ARB 0x2087 -#define WGL_AUX1_ARB 0x2088 -#define WGL_AUX2_ARB 0x2089 -#define WGL_AUX3_ARB 0x208A -#define WGL_AUX4_ARB 0x208B -#define WGL_AUX5_ARB 0x208C -#define WGL_AUX6_ARB 0x208D -#define WGL_AUX7_ARB 0x208E -#define WGL_AUX8_ARB 0x208F -#define WGL_AUX9_ARB 0x2090 - -typedef BOOL (WINAPI * PFNWGLBINDTEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); -typedef BOOL (WINAPI * PFNWGLRELEASETEXIMAGEARBPROC) (HPBUFFERARB hPbuffer, int iBuffer); -typedef BOOL (WINAPI * PFNWGLSETPBUFFERATTRIBARBPROC) (HPBUFFERARB hPbuffer, const int* piAttribList); - -#define wglBindTexImageARB WGLEW_GET_FUN(__wglewBindTexImageARB) -#define wglReleaseTexImageARB WGLEW_GET_FUN(__wglewReleaseTexImageARB) -#define wglSetPbufferAttribARB WGLEW_GET_FUN(__wglewSetPbufferAttribARB) - -#define WGLEW_ARB_render_texture WGLEW_GET_VAR(__WGLEW_ARB_render_texture) - -#endif /* WGL_ARB_render_texture */ - -/* ---------------- WGL_ARB_robustness_application_isolation --------------- */ - -#ifndef WGL_ARB_robustness_application_isolation -#define WGL_ARB_robustness_application_isolation 1 - -#define WGL_CONTEXT_RESET_ISOLATION_BIT_ARB 0x00000008 - -#define WGLEW_ARB_robustness_application_isolation WGLEW_GET_VAR(__WGLEW_ARB_robustness_application_isolation) - -#endif /* WGL_ARB_robustness_application_isolation */ - -/* ---------------- WGL_ARB_robustness_share_group_isolation --------------- */ - -#ifndef WGL_ARB_robustness_share_group_isolation -#define WGL_ARB_robustness_share_group_isolation 1 - -#define WGL_CONTEXT_RESET_ISOLATION_BIT_ARB 0x00000008 - -#define WGLEW_ARB_robustness_share_group_isolation WGLEW_GET_VAR(__WGLEW_ARB_robustness_share_group_isolation) - -#endif /* WGL_ARB_robustness_share_group_isolation */ - -/* ----------------------- WGL_ATI_pixel_format_float ---------------------- */ - -#ifndef WGL_ATI_pixel_format_float -#define WGL_ATI_pixel_format_float 1 - -#define WGL_TYPE_RGBA_FLOAT_ATI 0x21A0 -#define GL_RGBA_FLOAT_MODE_ATI 0x8820 -#define GL_COLOR_CLEAR_UNCLAMPED_VALUE_ATI 0x8835 - -#define WGLEW_ATI_pixel_format_float WGLEW_GET_VAR(__WGLEW_ATI_pixel_format_float) - -#endif /* WGL_ATI_pixel_format_float */ - -/* -------------------- WGL_ATI_render_texture_rectangle ------------------- */ - -#ifndef WGL_ATI_render_texture_rectangle -#define WGL_ATI_render_texture_rectangle 1 - -#define WGL_TEXTURE_RECTANGLE_ATI 0x21A5 - -#define WGLEW_ATI_render_texture_rectangle WGLEW_GET_VAR(__WGLEW_ATI_render_texture_rectangle) - -#endif /* WGL_ATI_render_texture_rectangle */ - -/* ------------------- WGL_EXT_create_context_es2_profile ------------------ */ - -#ifndef WGL_EXT_create_context_es2_profile -#define WGL_EXT_create_context_es2_profile 1 - -#define WGL_CONTEXT_ES2_PROFILE_BIT_EXT 0x00000004 - -#define WGLEW_EXT_create_context_es2_profile WGLEW_GET_VAR(__WGLEW_EXT_create_context_es2_profile) - -#endif /* WGL_EXT_create_context_es2_profile */ - -/* ------------------- WGL_EXT_create_context_es_profile ------------------- */ - -#ifndef WGL_EXT_create_context_es_profile -#define WGL_EXT_create_context_es_profile 1 - -#define WGL_CONTEXT_ES_PROFILE_BIT_EXT 0x00000004 - -#define WGLEW_EXT_create_context_es_profile WGLEW_GET_VAR(__WGLEW_EXT_create_context_es_profile) - -#endif /* WGL_EXT_create_context_es_profile */ - -/* -------------------------- WGL_EXT_depth_float -------------------------- */ - -#ifndef WGL_EXT_depth_float -#define WGL_EXT_depth_float 1 - -#define WGL_DEPTH_FLOAT_EXT 0x2040 - -#define WGLEW_EXT_depth_float WGLEW_GET_VAR(__WGLEW_EXT_depth_float) - -#endif /* WGL_EXT_depth_float */ - -/* ---------------------- WGL_EXT_display_color_table ---------------------- */ - -#ifndef WGL_EXT_display_color_table -#define WGL_EXT_display_color_table 1 - -typedef GLboolean (WINAPI * PFNWGLBINDDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef GLboolean (WINAPI * PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef void (WINAPI * PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC) (GLushort id); -typedef GLboolean (WINAPI * PFNWGLLOADDISPLAYCOLORTABLEEXTPROC) (GLushort* table, GLuint length); - -#define wglBindDisplayColorTableEXT WGLEW_GET_FUN(__wglewBindDisplayColorTableEXT) -#define wglCreateDisplayColorTableEXT WGLEW_GET_FUN(__wglewCreateDisplayColorTableEXT) -#define wglDestroyDisplayColorTableEXT WGLEW_GET_FUN(__wglewDestroyDisplayColorTableEXT) -#define wglLoadDisplayColorTableEXT WGLEW_GET_FUN(__wglewLoadDisplayColorTableEXT) - -#define WGLEW_EXT_display_color_table WGLEW_GET_VAR(__WGLEW_EXT_display_color_table) - -#endif /* WGL_EXT_display_color_table */ - -/* ----------------------- WGL_EXT_extensions_string ----------------------- */ - -#ifndef WGL_EXT_extensions_string -#define WGL_EXT_extensions_string 1 - -typedef const char* (WINAPI * PFNWGLGETEXTENSIONSSTRINGEXTPROC) (void); - -#define wglGetExtensionsStringEXT WGLEW_GET_FUN(__wglewGetExtensionsStringEXT) - -#define WGLEW_EXT_extensions_string WGLEW_GET_VAR(__WGLEW_EXT_extensions_string) - -#endif /* WGL_EXT_extensions_string */ - -/* ------------------------ WGL_EXT_framebuffer_sRGB ----------------------- */ - -#ifndef WGL_EXT_framebuffer_sRGB -#define WGL_EXT_framebuffer_sRGB 1 - -#define WGL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x20A9 - -#define WGLEW_EXT_framebuffer_sRGB WGLEW_GET_VAR(__WGLEW_EXT_framebuffer_sRGB) - -#endif /* WGL_EXT_framebuffer_sRGB */ - -/* ----------------------- WGL_EXT_make_current_read ----------------------- */ - -#ifndef WGL_EXT_make_current_read -#define WGL_EXT_make_current_read 1 - -#define ERROR_INVALID_PIXEL_TYPE_EXT 0x2043 - -typedef HDC (WINAPI * PFNWGLGETCURRENTREADDCEXTPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLMAKECONTEXTCURRENTEXTPROC) (HDC hDrawDC, HDC hReadDC, HGLRC hglrc); - -#define wglGetCurrentReadDCEXT WGLEW_GET_FUN(__wglewGetCurrentReadDCEXT) -#define wglMakeContextCurrentEXT WGLEW_GET_FUN(__wglewMakeContextCurrentEXT) - -#define WGLEW_EXT_make_current_read WGLEW_GET_VAR(__WGLEW_EXT_make_current_read) - -#endif /* WGL_EXT_make_current_read */ - -/* -------------------------- WGL_EXT_multisample -------------------------- */ - -#ifndef WGL_EXT_multisample -#define WGL_EXT_multisample 1 - -#define WGL_SAMPLE_BUFFERS_EXT 0x2041 -#define WGL_SAMPLES_EXT 0x2042 - -#define WGLEW_EXT_multisample WGLEW_GET_VAR(__WGLEW_EXT_multisample) - -#endif /* WGL_EXT_multisample */ - -/* ---------------------------- WGL_EXT_pbuffer ---------------------------- */ - -#ifndef WGL_EXT_pbuffer -#define WGL_EXT_pbuffer 1 - -#define WGL_DRAW_TO_PBUFFER_EXT 0x202D -#define WGL_MAX_PBUFFER_PIXELS_EXT 0x202E -#define WGL_MAX_PBUFFER_WIDTH_EXT 0x202F -#define WGL_MAX_PBUFFER_HEIGHT_EXT 0x2030 -#define WGL_OPTIMAL_PBUFFER_WIDTH_EXT 0x2031 -#define WGL_OPTIMAL_PBUFFER_HEIGHT_EXT 0x2032 -#define WGL_PBUFFER_LARGEST_EXT 0x2033 -#define WGL_PBUFFER_WIDTH_EXT 0x2034 -#define WGL_PBUFFER_HEIGHT_EXT 0x2035 - -DECLARE_HANDLE(HPBUFFEREXT); - -typedef HPBUFFEREXT (WINAPI * PFNWGLCREATEPBUFFEREXTPROC) (HDC hDC, int iPixelFormat, int iWidth, int iHeight, const int* piAttribList); -typedef BOOL (WINAPI * PFNWGLDESTROYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer); -typedef HDC (WINAPI * PFNWGLGETPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer); -typedef BOOL (WINAPI * PFNWGLQUERYPBUFFEREXTPROC) (HPBUFFEREXT hPbuffer, int iAttribute, int* piValue); -typedef int (WINAPI * PFNWGLRELEASEPBUFFERDCEXTPROC) (HPBUFFEREXT hPbuffer, HDC hDC); - -#define wglCreatePbufferEXT WGLEW_GET_FUN(__wglewCreatePbufferEXT) -#define wglDestroyPbufferEXT WGLEW_GET_FUN(__wglewDestroyPbufferEXT) -#define wglGetPbufferDCEXT WGLEW_GET_FUN(__wglewGetPbufferDCEXT) -#define wglQueryPbufferEXT WGLEW_GET_FUN(__wglewQueryPbufferEXT) -#define wglReleasePbufferDCEXT WGLEW_GET_FUN(__wglewReleasePbufferDCEXT) - -#define WGLEW_EXT_pbuffer WGLEW_GET_VAR(__WGLEW_EXT_pbuffer) - -#endif /* WGL_EXT_pbuffer */ - -/* -------------------------- WGL_EXT_pixel_format ------------------------- */ - -#ifndef WGL_EXT_pixel_format -#define WGL_EXT_pixel_format 1 - -#define WGL_NUMBER_PIXEL_FORMATS_EXT 0x2000 -#define WGL_DRAW_TO_WINDOW_EXT 0x2001 -#define WGL_DRAW_TO_BITMAP_EXT 0x2002 -#define WGL_ACCELERATION_EXT 0x2003 -#define WGL_NEED_PALETTE_EXT 0x2004 -#define WGL_NEED_SYSTEM_PALETTE_EXT 0x2005 -#define WGL_SWAP_LAYER_BUFFERS_EXT 0x2006 -#define WGL_SWAP_METHOD_EXT 0x2007 -#define WGL_NUMBER_OVERLAYS_EXT 0x2008 -#define WGL_NUMBER_UNDERLAYS_EXT 0x2009 -#define WGL_TRANSPARENT_EXT 0x200A -#define WGL_TRANSPARENT_VALUE_EXT 0x200B -#define WGL_SHARE_DEPTH_EXT 0x200C -#define WGL_SHARE_STENCIL_EXT 0x200D -#define WGL_SHARE_ACCUM_EXT 0x200E -#define WGL_SUPPORT_GDI_EXT 0x200F -#define WGL_SUPPORT_OPENGL_EXT 0x2010 -#define WGL_DOUBLE_BUFFER_EXT 0x2011 -#define WGL_STEREO_EXT 0x2012 -#define WGL_PIXEL_TYPE_EXT 0x2013 -#define WGL_COLOR_BITS_EXT 0x2014 -#define WGL_RED_BITS_EXT 0x2015 -#define WGL_RED_SHIFT_EXT 0x2016 -#define WGL_GREEN_BITS_EXT 0x2017 -#define WGL_GREEN_SHIFT_EXT 0x2018 -#define WGL_BLUE_BITS_EXT 0x2019 -#define WGL_BLUE_SHIFT_EXT 0x201A -#define WGL_ALPHA_BITS_EXT 0x201B -#define WGL_ALPHA_SHIFT_EXT 0x201C -#define WGL_ACCUM_BITS_EXT 0x201D -#define WGL_ACCUM_RED_BITS_EXT 0x201E -#define WGL_ACCUM_GREEN_BITS_EXT 0x201F -#define WGL_ACCUM_BLUE_BITS_EXT 0x2020 -#define WGL_ACCUM_ALPHA_BITS_EXT 0x2021 -#define WGL_DEPTH_BITS_EXT 0x2022 -#define WGL_STENCIL_BITS_EXT 0x2023 -#define WGL_AUX_BUFFERS_EXT 0x2024 -#define WGL_NO_ACCELERATION_EXT 0x2025 -#define WGL_GENERIC_ACCELERATION_EXT 0x2026 -#define WGL_FULL_ACCELERATION_EXT 0x2027 -#define WGL_SWAP_EXCHANGE_EXT 0x2028 -#define WGL_SWAP_COPY_EXT 0x2029 -#define WGL_SWAP_UNDEFINED_EXT 0x202A -#define WGL_TYPE_RGBA_EXT 0x202B -#define WGL_TYPE_COLORINDEX_EXT 0x202C - -typedef BOOL (WINAPI * PFNWGLCHOOSEPIXELFORMATEXTPROC) (HDC hdc, const int* piAttribIList, const FLOAT *pfAttribFList, UINT nMaxFormats, int *piFormats, UINT *nNumFormats); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBFVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, FLOAT *pfValues); -typedef BOOL (WINAPI * PFNWGLGETPIXELFORMATATTRIBIVEXTPROC) (HDC hdc, int iPixelFormat, int iLayerPlane, UINT nAttributes, int* piAttributes, int *piValues); - -#define wglChoosePixelFormatEXT WGLEW_GET_FUN(__wglewChoosePixelFormatEXT) -#define wglGetPixelFormatAttribfvEXT WGLEW_GET_FUN(__wglewGetPixelFormatAttribfvEXT) -#define wglGetPixelFormatAttribivEXT WGLEW_GET_FUN(__wglewGetPixelFormatAttribivEXT) - -#define WGLEW_EXT_pixel_format WGLEW_GET_VAR(__WGLEW_EXT_pixel_format) - -#endif /* WGL_EXT_pixel_format */ - -/* ------------------- WGL_EXT_pixel_format_packed_float ------------------- */ - -#ifndef WGL_EXT_pixel_format_packed_float -#define WGL_EXT_pixel_format_packed_float 1 - -#define WGL_TYPE_RGBA_UNSIGNED_FLOAT_EXT 0x20A8 - -#define WGLEW_EXT_pixel_format_packed_float WGLEW_GET_VAR(__WGLEW_EXT_pixel_format_packed_float) - -#endif /* WGL_EXT_pixel_format_packed_float */ - -/* -------------------------- WGL_EXT_swap_control ------------------------- */ - -#ifndef WGL_EXT_swap_control -#define WGL_EXT_swap_control 1 - -typedef int (WINAPI * PFNWGLGETSWAPINTERVALEXTPROC) (void); -typedef BOOL (WINAPI * PFNWGLSWAPINTERVALEXTPROC) (int interval); - -#define wglGetSwapIntervalEXT WGLEW_GET_FUN(__wglewGetSwapIntervalEXT) -#define wglSwapIntervalEXT WGLEW_GET_FUN(__wglewSwapIntervalEXT) - -#define WGLEW_EXT_swap_control WGLEW_GET_VAR(__WGLEW_EXT_swap_control) - -#endif /* WGL_EXT_swap_control */ - -/* ----------------------- WGL_EXT_swap_control_tear ----------------------- */ - -#ifndef WGL_EXT_swap_control_tear -#define WGL_EXT_swap_control_tear 1 - -#define WGLEW_EXT_swap_control_tear WGLEW_GET_VAR(__WGLEW_EXT_swap_control_tear) - -#endif /* WGL_EXT_swap_control_tear */ - -/* --------------------- WGL_I3D_digital_video_control --------------------- */ - -#ifndef WGL_I3D_digital_video_control -#define WGL_I3D_digital_video_control 1 - -#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_FRAMEBUFFER_I3D 0x2050 -#define WGL_DIGITAL_VIDEO_CURSOR_ALPHA_VALUE_I3D 0x2051 -#define WGL_DIGITAL_VIDEO_CURSOR_INCLUDED_I3D 0x2052 -#define WGL_DIGITAL_VIDEO_GAMMA_CORRECTED_I3D 0x2053 - -typedef BOOL (WINAPI * PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC) (HDC hDC, int iAttribute, int* piValue); -typedef BOOL (WINAPI * PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC) (HDC hDC, int iAttribute, const int* piValue); - -#define wglGetDigitalVideoParametersI3D WGLEW_GET_FUN(__wglewGetDigitalVideoParametersI3D) -#define wglSetDigitalVideoParametersI3D WGLEW_GET_FUN(__wglewSetDigitalVideoParametersI3D) - -#define WGLEW_I3D_digital_video_control WGLEW_GET_VAR(__WGLEW_I3D_digital_video_control) - -#endif /* WGL_I3D_digital_video_control */ - -/* ----------------------------- WGL_I3D_gamma ----------------------------- */ - -#ifndef WGL_I3D_gamma -#define WGL_I3D_gamma 1 - -#define WGL_GAMMA_TABLE_SIZE_I3D 0x204E -#define WGL_GAMMA_EXCLUDE_DESKTOP_I3D 0x204F - -typedef BOOL (WINAPI * PFNWGLGETGAMMATABLEI3DPROC) (HDC hDC, int iEntries, USHORT* puRed, USHORT *puGreen, USHORT *puBlue); -typedef BOOL (WINAPI * PFNWGLGETGAMMATABLEPARAMETERSI3DPROC) (HDC hDC, int iAttribute, int* piValue); -typedef BOOL (WINAPI * PFNWGLSETGAMMATABLEI3DPROC) (HDC hDC, int iEntries, const USHORT* puRed, const USHORT *puGreen, const USHORT *puBlue); -typedef BOOL (WINAPI * PFNWGLSETGAMMATABLEPARAMETERSI3DPROC) (HDC hDC, int iAttribute, const int* piValue); - -#define wglGetGammaTableI3D WGLEW_GET_FUN(__wglewGetGammaTableI3D) -#define wglGetGammaTableParametersI3D WGLEW_GET_FUN(__wglewGetGammaTableParametersI3D) -#define wglSetGammaTableI3D WGLEW_GET_FUN(__wglewSetGammaTableI3D) -#define wglSetGammaTableParametersI3D WGLEW_GET_FUN(__wglewSetGammaTableParametersI3D) - -#define WGLEW_I3D_gamma WGLEW_GET_VAR(__WGLEW_I3D_gamma) - -#endif /* WGL_I3D_gamma */ - -/* ---------------------------- WGL_I3D_genlock ---------------------------- */ - -#ifndef WGL_I3D_genlock -#define WGL_I3D_genlock 1 - -#define WGL_GENLOCK_SOURCE_MULTIVIEW_I3D 0x2044 -#define WGL_GENLOCK_SOURCE_EXTERNAL_SYNC_I3D 0x2045 -#define WGL_GENLOCK_SOURCE_EXTERNAL_FIELD_I3D 0x2046 -#define WGL_GENLOCK_SOURCE_EXTERNAL_TTL_I3D 0x2047 -#define WGL_GENLOCK_SOURCE_DIGITAL_SYNC_I3D 0x2048 -#define WGL_GENLOCK_SOURCE_DIGITAL_FIELD_I3D 0x2049 -#define WGL_GENLOCK_SOURCE_EDGE_FALLING_I3D 0x204A -#define WGL_GENLOCK_SOURCE_EDGE_RISING_I3D 0x204B -#define WGL_GENLOCK_SOURCE_EDGE_BOTH_I3D 0x204C - -typedef BOOL (WINAPI * PFNWGLDISABLEGENLOCKI3DPROC) (HDC hDC); -typedef BOOL (WINAPI * PFNWGLENABLEGENLOCKI3DPROC) (HDC hDC); -typedef BOOL (WINAPI * PFNWGLGENLOCKSAMPLERATEI3DPROC) (HDC hDC, UINT uRate); -typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEDELAYI3DPROC) (HDC hDC, UINT uDelay); -typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEEDGEI3DPROC) (HDC hDC, UINT uEdge); -typedef BOOL (WINAPI * PFNWGLGENLOCKSOURCEI3DPROC) (HDC hDC, UINT uSource); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSAMPLERATEI3DPROC) (HDC hDC, UINT* uRate); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEDELAYI3DPROC) (HDC hDC, UINT* uDelay); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEEDGEI3DPROC) (HDC hDC, UINT* uEdge); -typedef BOOL (WINAPI * PFNWGLGETGENLOCKSOURCEI3DPROC) (HDC hDC, UINT* uSource); -typedef BOOL (WINAPI * PFNWGLISENABLEDGENLOCKI3DPROC) (HDC hDC, BOOL* pFlag); -typedef BOOL (WINAPI * PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC) (HDC hDC, UINT* uMaxLineDelay, UINT *uMaxPixelDelay); - -#define wglDisableGenlockI3D WGLEW_GET_FUN(__wglewDisableGenlockI3D) -#define wglEnableGenlockI3D WGLEW_GET_FUN(__wglewEnableGenlockI3D) -#define wglGenlockSampleRateI3D WGLEW_GET_FUN(__wglewGenlockSampleRateI3D) -#define wglGenlockSourceDelayI3D WGLEW_GET_FUN(__wglewGenlockSourceDelayI3D) -#define wglGenlockSourceEdgeI3D WGLEW_GET_FUN(__wglewGenlockSourceEdgeI3D) -#define wglGenlockSourceI3D WGLEW_GET_FUN(__wglewGenlockSourceI3D) -#define wglGetGenlockSampleRateI3D WGLEW_GET_FUN(__wglewGetGenlockSampleRateI3D) -#define wglGetGenlockSourceDelayI3D WGLEW_GET_FUN(__wglewGetGenlockSourceDelayI3D) -#define wglGetGenlockSourceEdgeI3D WGLEW_GET_FUN(__wglewGetGenlockSourceEdgeI3D) -#define wglGetGenlockSourceI3D WGLEW_GET_FUN(__wglewGetGenlockSourceI3D) -#define wglIsEnabledGenlockI3D WGLEW_GET_FUN(__wglewIsEnabledGenlockI3D) -#define wglQueryGenlockMaxSourceDelayI3D WGLEW_GET_FUN(__wglewQueryGenlockMaxSourceDelayI3D) - -#define WGLEW_I3D_genlock WGLEW_GET_VAR(__WGLEW_I3D_genlock) - -#endif /* WGL_I3D_genlock */ - -/* -------------------------- WGL_I3D_image_buffer ------------------------- */ - -#ifndef WGL_I3D_image_buffer -#define WGL_I3D_image_buffer 1 - -#define WGL_IMAGE_BUFFER_MIN_ACCESS_I3D 0x00000001 -#define WGL_IMAGE_BUFFER_LOCK_I3D 0x00000002 - -typedef BOOL (WINAPI * PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC) (HDC hdc, HANDLE* pEvent, LPVOID *pAddress, DWORD *pSize, UINT count); -typedef LPVOID (WINAPI * PFNWGLCREATEIMAGEBUFFERI3DPROC) (HDC hDC, DWORD dwSize, UINT uFlags); -typedef BOOL (WINAPI * PFNWGLDESTROYIMAGEBUFFERI3DPROC) (HDC hDC, LPVOID pAddress); -typedef BOOL (WINAPI * PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC) (HDC hdc, LPVOID* pAddress, UINT count); - -#define wglAssociateImageBufferEventsI3D WGLEW_GET_FUN(__wglewAssociateImageBufferEventsI3D) -#define wglCreateImageBufferI3D WGLEW_GET_FUN(__wglewCreateImageBufferI3D) -#define wglDestroyImageBufferI3D WGLEW_GET_FUN(__wglewDestroyImageBufferI3D) -#define wglReleaseImageBufferEventsI3D WGLEW_GET_FUN(__wglewReleaseImageBufferEventsI3D) - -#define WGLEW_I3D_image_buffer WGLEW_GET_VAR(__WGLEW_I3D_image_buffer) - -#endif /* WGL_I3D_image_buffer */ - -/* ------------------------ WGL_I3D_swap_frame_lock ------------------------ */ - -#ifndef WGL_I3D_swap_frame_lock -#define WGL_I3D_swap_frame_lock 1 - -typedef BOOL (WINAPI * PFNWGLDISABLEFRAMELOCKI3DPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLENABLEFRAMELOCKI3DPROC) (VOID); -typedef BOOL (WINAPI * PFNWGLISENABLEDFRAMELOCKI3DPROC) (BOOL* pFlag); -typedef BOOL (WINAPI * PFNWGLQUERYFRAMELOCKMASTERI3DPROC) (BOOL* pFlag); - -#define wglDisableFrameLockI3D WGLEW_GET_FUN(__wglewDisableFrameLockI3D) -#define wglEnableFrameLockI3D WGLEW_GET_FUN(__wglewEnableFrameLockI3D) -#define wglIsEnabledFrameLockI3D WGLEW_GET_FUN(__wglewIsEnabledFrameLockI3D) -#define wglQueryFrameLockMasterI3D WGLEW_GET_FUN(__wglewQueryFrameLockMasterI3D) - -#define WGLEW_I3D_swap_frame_lock WGLEW_GET_VAR(__WGLEW_I3D_swap_frame_lock) - -#endif /* WGL_I3D_swap_frame_lock */ - -/* ------------------------ WGL_I3D_swap_frame_usage ----------------------- */ - -#ifndef WGL_I3D_swap_frame_usage -#define WGL_I3D_swap_frame_usage 1 - -typedef BOOL (WINAPI * PFNWGLBEGINFRAMETRACKINGI3DPROC) (void); -typedef BOOL (WINAPI * PFNWGLENDFRAMETRACKINGI3DPROC) (void); -typedef BOOL (WINAPI * PFNWGLGETFRAMEUSAGEI3DPROC) (float* pUsage); -typedef BOOL (WINAPI * PFNWGLQUERYFRAMETRACKINGI3DPROC) (DWORD* pFrameCount, DWORD *pMissedFrames, float *pLastMissedUsage); - -#define wglBeginFrameTrackingI3D WGLEW_GET_FUN(__wglewBeginFrameTrackingI3D) -#define wglEndFrameTrackingI3D WGLEW_GET_FUN(__wglewEndFrameTrackingI3D) -#define wglGetFrameUsageI3D WGLEW_GET_FUN(__wglewGetFrameUsageI3D) -#define wglQueryFrameTrackingI3D WGLEW_GET_FUN(__wglewQueryFrameTrackingI3D) - -#define WGLEW_I3D_swap_frame_usage WGLEW_GET_VAR(__WGLEW_I3D_swap_frame_usage) - -#endif /* WGL_I3D_swap_frame_usage */ - -/* --------------------------- WGL_NV_DX_interop --------------------------- */ - -#ifndef WGL_NV_DX_interop -#define WGL_NV_DX_interop 1 - -#define WGL_ACCESS_READ_ONLY_NV 0x0000 -#define WGL_ACCESS_READ_WRITE_NV 0x0001 -#define WGL_ACCESS_WRITE_DISCARD_NV 0x0002 - -typedef BOOL (WINAPI * PFNWGLDXCLOSEDEVICENVPROC) (HANDLE hDevice); -typedef BOOL (WINAPI * PFNWGLDXLOCKOBJECTSNVPROC) (HANDLE hDevice, GLint count, HANDLE* hObjects); -typedef BOOL (WINAPI * PFNWGLDXOBJECTACCESSNVPROC) (HANDLE hObject, GLenum access); -typedef HANDLE (WINAPI * PFNWGLDXOPENDEVICENVPROC) (void* dxDevice); -typedef HANDLE (WINAPI * PFNWGLDXREGISTEROBJECTNVPROC) (HANDLE hDevice, void* dxObject, GLuint name, GLenum type, GLenum access); -typedef BOOL (WINAPI * PFNWGLDXSETRESOURCESHAREHANDLENVPROC) (void* dxObject, HANDLE shareHandle); -typedef BOOL (WINAPI * PFNWGLDXUNLOCKOBJECTSNVPROC) (HANDLE hDevice, GLint count, HANDLE* hObjects); -typedef BOOL (WINAPI * PFNWGLDXUNREGISTEROBJECTNVPROC) (HANDLE hDevice, HANDLE hObject); - -#define wglDXCloseDeviceNV WGLEW_GET_FUN(__wglewDXCloseDeviceNV) -#define wglDXLockObjectsNV WGLEW_GET_FUN(__wglewDXLockObjectsNV) -#define wglDXObjectAccessNV WGLEW_GET_FUN(__wglewDXObjectAccessNV) -#define wglDXOpenDeviceNV WGLEW_GET_FUN(__wglewDXOpenDeviceNV) -#define wglDXRegisterObjectNV WGLEW_GET_FUN(__wglewDXRegisterObjectNV) -#define wglDXSetResourceShareHandleNV WGLEW_GET_FUN(__wglewDXSetResourceShareHandleNV) -#define wglDXUnlockObjectsNV WGLEW_GET_FUN(__wglewDXUnlockObjectsNV) -#define wglDXUnregisterObjectNV WGLEW_GET_FUN(__wglewDXUnregisterObjectNV) - -#define WGLEW_NV_DX_interop WGLEW_GET_VAR(__WGLEW_NV_DX_interop) - -#endif /* WGL_NV_DX_interop */ - -/* --------------------------- WGL_NV_DX_interop2 -------------------------- */ - -#ifndef WGL_NV_DX_interop2 -#define WGL_NV_DX_interop2 1 - -#define WGLEW_NV_DX_interop2 WGLEW_GET_VAR(__WGLEW_NV_DX_interop2) - -#endif /* WGL_NV_DX_interop2 */ - -/* --------------------------- WGL_NV_copy_image --------------------------- */ - -#ifndef WGL_NV_copy_image -#define WGL_NV_copy_image 1 - -typedef BOOL (WINAPI * PFNWGLCOPYIMAGESUBDATANVPROC) (HGLRC hSrcRC, GLuint srcName, GLenum srcTarget, GLint srcLevel, GLint srcX, GLint srcY, GLint srcZ, HGLRC hDstRC, GLuint dstName, GLenum dstTarget, GLint dstLevel, GLint dstX, GLint dstY, GLint dstZ, GLsizei width, GLsizei height, GLsizei depth); - -#define wglCopyImageSubDataNV WGLEW_GET_FUN(__wglewCopyImageSubDataNV) - -#define WGLEW_NV_copy_image WGLEW_GET_VAR(__WGLEW_NV_copy_image) - -#endif /* WGL_NV_copy_image */ - -/* -------------------------- WGL_NV_float_buffer -------------------------- */ - -#ifndef WGL_NV_float_buffer -#define WGL_NV_float_buffer 1 - -#define WGL_FLOAT_COMPONENTS_NV 0x20B0 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_R_NV 0x20B1 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RG_NV 0x20B2 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGB_NV 0x20B3 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_FLOAT_RGBA_NV 0x20B4 -#define WGL_TEXTURE_FLOAT_R_NV 0x20B5 -#define WGL_TEXTURE_FLOAT_RG_NV 0x20B6 -#define WGL_TEXTURE_FLOAT_RGB_NV 0x20B7 -#define WGL_TEXTURE_FLOAT_RGBA_NV 0x20B8 - -#define WGLEW_NV_float_buffer WGLEW_GET_VAR(__WGLEW_NV_float_buffer) - -#endif /* WGL_NV_float_buffer */ - -/* -------------------------- WGL_NV_gpu_affinity -------------------------- */ - -#ifndef WGL_NV_gpu_affinity -#define WGL_NV_gpu_affinity 1 - -#define WGL_ERROR_INCOMPATIBLE_AFFINITY_MASKS_NV 0x20D0 -#define WGL_ERROR_MISSING_AFFINITY_MASK_NV 0x20D1 - -DECLARE_HANDLE(HGPUNV); -typedef struct _GPU_DEVICE { - DWORD cb; - CHAR DeviceName[32]; - CHAR DeviceString[128]; - DWORD Flags; - RECT rcVirtualScreen; -} GPU_DEVICE, *PGPU_DEVICE; - -typedef HDC (WINAPI * PFNWGLCREATEAFFINITYDCNVPROC) (const HGPUNV *phGpuList); -typedef BOOL (WINAPI * PFNWGLDELETEDCNVPROC) (HDC hdc); -typedef BOOL (WINAPI * PFNWGLENUMGPUDEVICESNVPROC) (HGPUNV hGpu, UINT iDeviceIndex, PGPU_DEVICE lpGpuDevice); -typedef BOOL (WINAPI * PFNWGLENUMGPUSFROMAFFINITYDCNVPROC) (HDC hAffinityDC, UINT iGpuIndex, HGPUNV *hGpu); -typedef BOOL (WINAPI * PFNWGLENUMGPUSNVPROC) (UINT iGpuIndex, HGPUNV *phGpu); - -#define wglCreateAffinityDCNV WGLEW_GET_FUN(__wglewCreateAffinityDCNV) -#define wglDeleteDCNV WGLEW_GET_FUN(__wglewDeleteDCNV) -#define wglEnumGpuDevicesNV WGLEW_GET_FUN(__wglewEnumGpuDevicesNV) -#define wglEnumGpusFromAffinityDCNV WGLEW_GET_FUN(__wglewEnumGpusFromAffinityDCNV) -#define wglEnumGpusNV WGLEW_GET_FUN(__wglewEnumGpusNV) - -#define WGLEW_NV_gpu_affinity WGLEW_GET_VAR(__WGLEW_NV_gpu_affinity) - -#endif /* WGL_NV_gpu_affinity */ - -/* ---------------------- WGL_NV_multisample_coverage ---------------------- */ - -#ifndef WGL_NV_multisample_coverage -#define WGL_NV_multisample_coverage 1 - -#define WGL_COVERAGE_SAMPLES_NV 0x2042 -#define WGL_COLOR_SAMPLES_NV 0x20B9 - -#define WGLEW_NV_multisample_coverage WGLEW_GET_VAR(__WGLEW_NV_multisample_coverage) - -#endif /* WGL_NV_multisample_coverage */ - -/* -------------------------- WGL_NV_present_video ------------------------- */ - -#ifndef WGL_NV_present_video -#define WGL_NV_present_video 1 - -#define WGL_NUM_VIDEO_SLOTS_NV 0x20F0 - -DECLARE_HANDLE(HVIDEOOUTPUTDEVICENV); - -typedef BOOL (WINAPI * PFNWGLBINDVIDEODEVICENVPROC) (HDC hDc, unsigned int uVideoSlot, HVIDEOOUTPUTDEVICENV hVideoDevice, const int* piAttribList); -typedef int (WINAPI * PFNWGLENUMERATEVIDEODEVICESNVPROC) (HDC hDc, HVIDEOOUTPUTDEVICENV* phDeviceList); -typedef BOOL (WINAPI * PFNWGLQUERYCURRENTCONTEXTNVPROC) (int iAttribute, int* piValue); - -#define wglBindVideoDeviceNV WGLEW_GET_FUN(__wglewBindVideoDeviceNV) -#define wglEnumerateVideoDevicesNV WGLEW_GET_FUN(__wglewEnumerateVideoDevicesNV) -#define wglQueryCurrentContextNV WGLEW_GET_FUN(__wglewQueryCurrentContextNV) - -#define WGLEW_NV_present_video WGLEW_GET_VAR(__WGLEW_NV_present_video) - -#endif /* WGL_NV_present_video */ - -/* ---------------------- WGL_NV_render_depth_texture ---------------------- */ - -#ifndef WGL_NV_render_depth_texture -#define WGL_NV_render_depth_texture 1 - -#define WGL_NO_TEXTURE_ARB 0x2077 -#define WGL_BIND_TO_TEXTURE_DEPTH_NV 0x20A3 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_DEPTH_NV 0x20A4 -#define WGL_DEPTH_TEXTURE_FORMAT_NV 0x20A5 -#define WGL_TEXTURE_DEPTH_COMPONENT_NV 0x20A6 -#define WGL_DEPTH_COMPONENT_NV 0x20A7 - -#define WGLEW_NV_render_depth_texture WGLEW_GET_VAR(__WGLEW_NV_render_depth_texture) - -#endif /* WGL_NV_render_depth_texture */ - -/* -------------------- WGL_NV_render_texture_rectangle -------------------- */ - -#ifndef WGL_NV_render_texture_rectangle -#define WGL_NV_render_texture_rectangle 1 - -#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGB_NV 0x20A0 -#define WGL_BIND_TO_TEXTURE_RECTANGLE_RGBA_NV 0x20A1 -#define WGL_TEXTURE_RECTANGLE_NV 0x20A2 - -#define WGLEW_NV_render_texture_rectangle WGLEW_GET_VAR(__WGLEW_NV_render_texture_rectangle) - -#endif /* WGL_NV_render_texture_rectangle */ - -/* --------------------------- WGL_NV_swap_group --------------------------- */ - -#ifndef WGL_NV_swap_group -#define WGL_NV_swap_group 1 - -typedef BOOL (WINAPI * PFNWGLBINDSWAPBARRIERNVPROC) (GLuint group, GLuint barrier); -typedef BOOL (WINAPI * PFNWGLJOINSWAPGROUPNVPROC) (HDC hDC, GLuint group); -typedef BOOL (WINAPI * PFNWGLQUERYFRAMECOUNTNVPROC) (HDC hDC, GLuint* count); -typedef BOOL (WINAPI * PFNWGLQUERYMAXSWAPGROUPSNVPROC) (HDC hDC, GLuint* maxGroups, GLuint *maxBarriers); -typedef BOOL (WINAPI * PFNWGLQUERYSWAPGROUPNVPROC) (HDC hDC, GLuint* group, GLuint *barrier); -typedef BOOL (WINAPI * PFNWGLRESETFRAMECOUNTNVPROC) (HDC hDC); - -#define wglBindSwapBarrierNV WGLEW_GET_FUN(__wglewBindSwapBarrierNV) -#define wglJoinSwapGroupNV WGLEW_GET_FUN(__wglewJoinSwapGroupNV) -#define wglQueryFrameCountNV WGLEW_GET_FUN(__wglewQueryFrameCountNV) -#define wglQueryMaxSwapGroupsNV WGLEW_GET_FUN(__wglewQueryMaxSwapGroupsNV) -#define wglQuerySwapGroupNV WGLEW_GET_FUN(__wglewQuerySwapGroupNV) -#define wglResetFrameCountNV WGLEW_GET_FUN(__wglewResetFrameCountNV) - -#define WGLEW_NV_swap_group WGLEW_GET_VAR(__WGLEW_NV_swap_group) - -#endif /* WGL_NV_swap_group */ - -/* ----------------------- WGL_NV_vertex_array_range ----------------------- */ - -#ifndef WGL_NV_vertex_array_range -#define WGL_NV_vertex_array_range 1 - -typedef void * (WINAPI * PFNWGLALLOCATEMEMORYNVPROC) (GLsizei size, GLfloat readFrequency, GLfloat writeFrequency, GLfloat priority); -typedef void (WINAPI * PFNWGLFREEMEMORYNVPROC) (void *pointer); - -#define wglAllocateMemoryNV WGLEW_GET_FUN(__wglewAllocateMemoryNV) -#define wglFreeMemoryNV WGLEW_GET_FUN(__wglewFreeMemoryNV) - -#define WGLEW_NV_vertex_array_range WGLEW_GET_VAR(__WGLEW_NV_vertex_array_range) - -#endif /* WGL_NV_vertex_array_range */ - -/* -------------------------- WGL_NV_video_capture ------------------------- */ - -#ifndef WGL_NV_video_capture -#define WGL_NV_video_capture 1 - -#define WGL_UNIQUE_ID_NV 0x20CE -#define WGL_NUM_VIDEO_CAPTURE_SLOTS_NV 0x20CF - -DECLARE_HANDLE(HVIDEOINPUTDEVICENV); - -typedef BOOL (WINAPI * PFNWGLBINDVIDEOCAPTUREDEVICENVPROC) (UINT uVideoSlot, HVIDEOINPUTDEVICENV hDevice); -typedef UINT (WINAPI * PFNWGLENUMERATEVIDEOCAPTUREDEVICESNVPROC) (HDC hDc, HVIDEOINPUTDEVICENV* phDeviceList); -typedef BOOL (WINAPI * PFNWGLLOCKVIDEOCAPTUREDEVICENVPROC) (HDC hDc, HVIDEOINPUTDEVICENV hDevice); -typedef BOOL (WINAPI * PFNWGLQUERYVIDEOCAPTUREDEVICENVPROC) (HDC hDc, HVIDEOINPUTDEVICENV hDevice, int iAttribute, int* piValue); -typedef BOOL (WINAPI * PFNWGLRELEASEVIDEOCAPTUREDEVICENVPROC) (HDC hDc, HVIDEOINPUTDEVICENV hDevice); - -#define wglBindVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewBindVideoCaptureDeviceNV) -#define wglEnumerateVideoCaptureDevicesNV WGLEW_GET_FUN(__wglewEnumerateVideoCaptureDevicesNV) -#define wglLockVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewLockVideoCaptureDeviceNV) -#define wglQueryVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewQueryVideoCaptureDeviceNV) -#define wglReleaseVideoCaptureDeviceNV WGLEW_GET_FUN(__wglewReleaseVideoCaptureDeviceNV) - -#define WGLEW_NV_video_capture WGLEW_GET_VAR(__WGLEW_NV_video_capture) - -#endif /* WGL_NV_video_capture */ - -/* -------------------------- WGL_NV_video_output -------------------------- */ - -#ifndef WGL_NV_video_output -#define WGL_NV_video_output 1 - -#define WGL_BIND_TO_VIDEO_RGB_NV 0x20C0 -#define WGL_BIND_TO_VIDEO_RGBA_NV 0x20C1 -#define WGL_BIND_TO_VIDEO_RGB_AND_DEPTH_NV 0x20C2 -#define WGL_VIDEO_OUT_COLOR_NV 0x20C3 -#define WGL_VIDEO_OUT_ALPHA_NV 0x20C4 -#define WGL_VIDEO_OUT_DEPTH_NV 0x20C5 -#define WGL_VIDEO_OUT_COLOR_AND_ALPHA_NV 0x20C6 -#define WGL_VIDEO_OUT_COLOR_AND_DEPTH_NV 0x20C7 -#define WGL_VIDEO_OUT_FRAME 0x20C8 -#define WGL_VIDEO_OUT_FIELD_1 0x20C9 -#define WGL_VIDEO_OUT_FIELD_2 0x20CA -#define WGL_VIDEO_OUT_STACKED_FIELDS_1_2 0x20CB -#define WGL_VIDEO_OUT_STACKED_FIELDS_2_1 0x20CC - -DECLARE_HANDLE(HPVIDEODEV); - -typedef BOOL (WINAPI * PFNWGLBINDVIDEOIMAGENVPROC) (HPVIDEODEV hVideoDevice, HPBUFFERARB hPbuffer, int iVideoBuffer); -typedef BOOL (WINAPI * PFNWGLGETVIDEODEVICENVPROC) (HDC hDC, int numDevices, HPVIDEODEV* hVideoDevice); -typedef BOOL (WINAPI * PFNWGLGETVIDEOINFONVPROC) (HPVIDEODEV hpVideoDevice, unsigned long* pulCounterOutputPbuffer, unsigned long *pulCounterOutputVideo); -typedef BOOL (WINAPI * PFNWGLRELEASEVIDEODEVICENVPROC) (HPVIDEODEV hVideoDevice); -typedef BOOL (WINAPI * PFNWGLRELEASEVIDEOIMAGENVPROC) (HPBUFFERARB hPbuffer, int iVideoBuffer); -typedef BOOL (WINAPI * PFNWGLSENDPBUFFERTOVIDEONVPROC) (HPBUFFERARB hPbuffer, int iBufferType, unsigned long* pulCounterPbuffer, BOOL bBlock); - -#define wglBindVideoImageNV WGLEW_GET_FUN(__wglewBindVideoImageNV) -#define wglGetVideoDeviceNV WGLEW_GET_FUN(__wglewGetVideoDeviceNV) -#define wglGetVideoInfoNV WGLEW_GET_FUN(__wglewGetVideoInfoNV) -#define wglReleaseVideoDeviceNV WGLEW_GET_FUN(__wglewReleaseVideoDeviceNV) -#define wglReleaseVideoImageNV WGLEW_GET_FUN(__wglewReleaseVideoImageNV) -#define wglSendPbufferToVideoNV WGLEW_GET_FUN(__wglewSendPbufferToVideoNV) - -#define WGLEW_NV_video_output WGLEW_GET_VAR(__WGLEW_NV_video_output) - -#endif /* WGL_NV_video_output */ - -/* -------------------------- WGL_OML_sync_control ------------------------- */ - -#ifndef WGL_OML_sync_control -#define WGL_OML_sync_control 1 - -typedef BOOL (WINAPI * PFNWGLGETMSCRATEOMLPROC) (HDC hdc, INT32* numerator, INT32 *denominator); -typedef BOOL (WINAPI * PFNWGLGETSYNCVALUESOMLPROC) (HDC hdc, INT64* ust, INT64 *msc, INT64 *sbc); -typedef INT64 (WINAPI * PFNWGLSWAPBUFFERSMSCOMLPROC) (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder); -typedef INT64 (WINAPI * PFNWGLSWAPLAYERBUFFERSMSCOMLPROC) (HDC hdc, INT fuPlanes, INT64 target_msc, INT64 divisor, INT64 remainder); -typedef BOOL (WINAPI * PFNWGLWAITFORMSCOMLPROC) (HDC hdc, INT64 target_msc, INT64 divisor, INT64 remainder, INT64* ust, INT64 *msc, INT64 *sbc); -typedef BOOL (WINAPI * PFNWGLWAITFORSBCOMLPROC) (HDC hdc, INT64 target_sbc, INT64* ust, INT64 *msc, INT64 *sbc); - -#define wglGetMscRateOML WGLEW_GET_FUN(__wglewGetMscRateOML) -#define wglGetSyncValuesOML WGLEW_GET_FUN(__wglewGetSyncValuesOML) -#define wglSwapBuffersMscOML WGLEW_GET_FUN(__wglewSwapBuffersMscOML) -#define wglSwapLayerBuffersMscOML WGLEW_GET_FUN(__wglewSwapLayerBuffersMscOML) -#define wglWaitForMscOML WGLEW_GET_FUN(__wglewWaitForMscOML) -#define wglWaitForSbcOML WGLEW_GET_FUN(__wglewWaitForSbcOML) - -#define WGLEW_OML_sync_control WGLEW_GET_VAR(__WGLEW_OML_sync_control) - -#endif /* WGL_OML_sync_control */ - -/* ------------------------------------------------------------------------- */ - -#ifdef GLEW_MX -#define WGLEW_FUN_EXPORT -#define WGLEW_VAR_EXPORT -#else -#define WGLEW_FUN_EXPORT GLEW_FUN_EXPORT -#define WGLEW_VAR_EXPORT GLEW_VAR_EXPORT -#endif /* GLEW_MX */ - -#ifdef GLEW_MX -struct WGLEWContextStruct -{ -#endif /* GLEW_MX */ - -WGLEW_FUN_EXPORT PFNWGLSETSTEREOEMITTERSTATE3DLPROC __wglewSetStereoEmitterState3DL; - -WGLEW_FUN_EXPORT PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC __wglewBlitContextFramebufferAMD; -WGLEW_FUN_EXPORT PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC __wglewCreateAssociatedContextAMD; -WGLEW_FUN_EXPORT PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __wglewCreateAssociatedContextAttribsAMD; -WGLEW_FUN_EXPORT PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC __wglewDeleteAssociatedContextAMD; -WGLEW_FUN_EXPORT PFNWGLGETCONTEXTGPUIDAMDPROC __wglewGetContextGPUIDAMD; -WGLEW_FUN_EXPORT PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC __wglewGetCurrentAssociatedContextAMD; -WGLEW_FUN_EXPORT PFNWGLGETGPUIDSAMDPROC __wglewGetGPUIDsAMD; -WGLEW_FUN_EXPORT PFNWGLGETGPUINFOAMDPROC __wglewGetGPUInfoAMD; -WGLEW_FUN_EXPORT PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __wglewMakeAssociatedContextCurrentAMD; - -WGLEW_FUN_EXPORT PFNWGLCREATEBUFFERREGIONARBPROC __wglewCreateBufferRegionARB; -WGLEW_FUN_EXPORT PFNWGLDELETEBUFFERREGIONARBPROC __wglewDeleteBufferRegionARB; -WGLEW_FUN_EXPORT PFNWGLRESTOREBUFFERREGIONARBPROC __wglewRestoreBufferRegionARB; -WGLEW_FUN_EXPORT PFNWGLSAVEBUFFERREGIONARBPROC __wglewSaveBufferRegionARB; - -WGLEW_FUN_EXPORT PFNWGLCREATECONTEXTATTRIBSARBPROC __wglewCreateContextAttribsARB; - -WGLEW_FUN_EXPORT PFNWGLGETEXTENSIONSSTRINGARBPROC __wglewGetExtensionsStringARB; - -WGLEW_FUN_EXPORT PFNWGLGETCURRENTREADDCARBPROC __wglewGetCurrentReadDCARB; -WGLEW_FUN_EXPORT PFNWGLMAKECONTEXTCURRENTARBPROC __wglewMakeContextCurrentARB; - -WGLEW_FUN_EXPORT PFNWGLCREATEPBUFFERARBPROC __wglewCreatePbufferARB; -WGLEW_FUN_EXPORT PFNWGLDESTROYPBUFFERARBPROC __wglewDestroyPbufferARB; -WGLEW_FUN_EXPORT PFNWGLGETPBUFFERDCARBPROC __wglewGetPbufferDCARB; -WGLEW_FUN_EXPORT PFNWGLQUERYPBUFFERARBPROC __wglewQueryPbufferARB; -WGLEW_FUN_EXPORT PFNWGLRELEASEPBUFFERDCARBPROC __wglewReleasePbufferDCARB; - -WGLEW_FUN_EXPORT PFNWGLCHOOSEPIXELFORMATARBPROC __wglewChoosePixelFormatARB; -WGLEW_FUN_EXPORT PFNWGLGETPIXELFORMATATTRIBFVARBPROC __wglewGetPixelFormatAttribfvARB; -WGLEW_FUN_EXPORT PFNWGLGETPIXELFORMATATTRIBIVARBPROC __wglewGetPixelFormatAttribivARB; - -WGLEW_FUN_EXPORT PFNWGLBINDTEXIMAGEARBPROC __wglewBindTexImageARB; -WGLEW_FUN_EXPORT PFNWGLRELEASETEXIMAGEARBPROC __wglewReleaseTexImageARB; -WGLEW_FUN_EXPORT PFNWGLSETPBUFFERATTRIBARBPROC __wglewSetPbufferAttribARB; - -WGLEW_FUN_EXPORT PFNWGLBINDDISPLAYCOLORTABLEEXTPROC __wglewBindDisplayColorTableEXT; -WGLEW_FUN_EXPORT PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC __wglewCreateDisplayColorTableEXT; -WGLEW_FUN_EXPORT PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC __wglewDestroyDisplayColorTableEXT; -WGLEW_FUN_EXPORT PFNWGLLOADDISPLAYCOLORTABLEEXTPROC __wglewLoadDisplayColorTableEXT; - -WGLEW_FUN_EXPORT PFNWGLGETEXTENSIONSSTRINGEXTPROC __wglewGetExtensionsStringEXT; - -WGLEW_FUN_EXPORT PFNWGLGETCURRENTREADDCEXTPROC __wglewGetCurrentReadDCEXT; -WGLEW_FUN_EXPORT PFNWGLMAKECONTEXTCURRENTEXTPROC __wglewMakeContextCurrentEXT; - -WGLEW_FUN_EXPORT PFNWGLCREATEPBUFFEREXTPROC __wglewCreatePbufferEXT; -WGLEW_FUN_EXPORT PFNWGLDESTROYPBUFFEREXTPROC __wglewDestroyPbufferEXT; -WGLEW_FUN_EXPORT PFNWGLGETPBUFFERDCEXTPROC __wglewGetPbufferDCEXT; -WGLEW_FUN_EXPORT PFNWGLQUERYPBUFFEREXTPROC __wglewQueryPbufferEXT; -WGLEW_FUN_EXPORT PFNWGLRELEASEPBUFFERDCEXTPROC __wglewReleasePbufferDCEXT; - -WGLEW_FUN_EXPORT PFNWGLCHOOSEPIXELFORMATEXTPROC __wglewChoosePixelFormatEXT; -WGLEW_FUN_EXPORT PFNWGLGETPIXELFORMATATTRIBFVEXTPROC __wglewGetPixelFormatAttribfvEXT; -WGLEW_FUN_EXPORT PFNWGLGETPIXELFORMATATTRIBIVEXTPROC __wglewGetPixelFormatAttribivEXT; - -WGLEW_FUN_EXPORT PFNWGLGETSWAPINTERVALEXTPROC __wglewGetSwapIntervalEXT; -WGLEW_FUN_EXPORT PFNWGLSWAPINTERVALEXTPROC __wglewSwapIntervalEXT; - -WGLEW_FUN_EXPORT PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC __wglewGetDigitalVideoParametersI3D; -WGLEW_FUN_EXPORT PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC __wglewSetDigitalVideoParametersI3D; - -WGLEW_FUN_EXPORT PFNWGLGETGAMMATABLEI3DPROC __wglewGetGammaTableI3D; -WGLEW_FUN_EXPORT PFNWGLGETGAMMATABLEPARAMETERSI3DPROC __wglewGetGammaTableParametersI3D; -WGLEW_FUN_EXPORT PFNWGLSETGAMMATABLEI3DPROC __wglewSetGammaTableI3D; -WGLEW_FUN_EXPORT PFNWGLSETGAMMATABLEPARAMETERSI3DPROC __wglewSetGammaTableParametersI3D; - -WGLEW_FUN_EXPORT PFNWGLDISABLEGENLOCKI3DPROC __wglewDisableGenlockI3D; -WGLEW_FUN_EXPORT PFNWGLENABLEGENLOCKI3DPROC __wglewEnableGenlockI3D; -WGLEW_FUN_EXPORT PFNWGLGENLOCKSAMPLERATEI3DPROC __wglewGenlockSampleRateI3D; -WGLEW_FUN_EXPORT PFNWGLGENLOCKSOURCEDELAYI3DPROC __wglewGenlockSourceDelayI3D; -WGLEW_FUN_EXPORT PFNWGLGENLOCKSOURCEEDGEI3DPROC __wglewGenlockSourceEdgeI3D; -WGLEW_FUN_EXPORT PFNWGLGENLOCKSOURCEI3DPROC __wglewGenlockSourceI3D; -WGLEW_FUN_EXPORT PFNWGLGETGENLOCKSAMPLERATEI3DPROC __wglewGetGenlockSampleRateI3D; -WGLEW_FUN_EXPORT PFNWGLGETGENLOCKSOURCEDELAYI3DPROC __wglewGetGenlockSourceDelayI3D; -WGLEW_FUN_EXPORT PFNWGLGETGENLOCKSOURCEEDGEI3DPROC __wglewGetGenlockSourceEdgeI3D; -WGLEW_FUN_EXPORT PFNWGLGETGENLOCKSOURCEI3DPROC __wglewGetGenlockSourceI3D; -WGLEW_FUN_EXPORT PFNWGLISENABLEDGENLOCKI3DPROC __wglewIsEnabledGenlockI3D; -WGLEW_FUN_EXPORT PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC __wglewQueryGenlockMaxSourceDelayI3D; - -WGLEW_FUN_EXPORT PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC __wglewAssociateImageBufferEventsI3D; -WGLEW_FUN_EXPORT PFNWGLCREATEIMAGEBUFFERI3DPROC __wglewCreateImageBufferI3D; -WGLEW_FUN_EXPORT PFNWGLDESTROYIMAGEBUFFERI3DPROC __wglewDestroyImageBufferI3D; -WGLEW_FUN_EXPORT PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC __wglewReleaseImageBufferEventsI3D; - -WGLEW_FUN_EXPORT PFNWGLDISABLEFRAMELOCKI3DPROC __wglewDisableFrameLockI3D; -WGLEW_FUN_EXPORT PFNWGLENABLEFRAMELOCKI3DPROC __wglewEnableFrameLockI3D; -WGLEW_FUN_EXPORT PFNWGLISENABLEDFRAMELOCKI3DPROC __wglewIsEnabledFrameLockI3D; -WGLEW_FUN_EXPORT PFNWGLQUERYFRAMELOCKMASTERI3DPROC __wglewQueryFrameLockMasterI3D; - -WGLEW_FUN_EXPORT PFNWGLBEGINFRAMETRACKINGI3DPROC __wglewBeginFrameTrackingI3D; -WGLEW_FUN_EXPORT PFNWGLENDFRAMETRACKINGI3DPROC __wglewEndFrameTrackingI3D; -WGLEW_FUN_EXPORT PFNWGLGETFRAMEUSAGEI3DPROC __wglewGetFrameUsageI3D; -WGLEW_FUN_EXPORT PFNWGLQUERYFRAMETRACKINGI3DPROC __wglewQueryFrameTrackingI3D; - -WGLEW_FUN_EXPORT PFNWGLDXCLOSEDEVICENVPROC __wglewDXCloseDeviceNV; -WGLEW_FUN_EXPORT PFNWGLDXLOCKOBJECTSNVPROC __wglewDXLockObjectsNV; -WGLEW_FUN_EXPORT PFNWGLDXOBJECTACCESSNVPROC __wglewDXObjectAccessNV; -WGLEW_FUN_EXPORT PFNWGLDXOPENDEVICENVPROC __wglewDXOpenDeviceNV; -WGLEW_FUN_EXPORT PFNWGLDXREGISTEROBJECTNVPROC __wglewDXRegisterObjectNV; -WGLEW_FUN_EXPORT PFNWGLDXSETRESOURCESHAREHANDLENVPROC __wglewDXSetResourceShareHandleNV; -WGLEW_FUN_EXPORT PFNWGLDXUNLOCKOBJECTSNVPROC __wglewDXUnlockObjectsNV; -WGLEW_FUN_EXPORT PFNWGLDXUNREGISTEROBJECTNVPROC __wglewDXUnregisterObjectNV; - -WGLEW_FUN_EXPORT PFNWGLCOPYIMAGESUBDATANVPROC __wglewCopyImageSubDataNV; - -WGLEW_FUN_EXPORT PFNWGLCREATEAFFINITYDCNVPROC __wglewCreateAffinityDCNV; -WGLEW_FUN_EXPORT PFNWGLDELETEDCNVPROC __wglewDeleteDCNV; -WGLEW_FUN_EXPORT PFNWGLENUMGPUDEVICESNVPROC __wglewEnumGpuDevicesNV; -WGLEW_FUN_EXPORT PFNWGLENUMGPUSFROMAFFINITYDCNVPROC __wglewEnumGpusFromAffinityDCNV; -WGLEW_FUN_EXPORT PFNWGLENUMGPUSNVPROC __wglewEnumGpusNV; - -WGLEW_FUN_EXPORT PFNWGLBINDVIDEODEVICENVPROC __wglewBindVideoDeviceNV; -WGLEW_FUN_EXPORT PFNWGLENUMERATEVIDEODEVICESNVPROC __wglewEnumerateVideoDevicesNV; -WGLEW_FUN_EXPORT PFNWGLQUERYCURRENTCONTEXTNVPROC __wglewQueryCurrentContextNV; - -WGLEW_FUN_EXPORT PFNWGLBINDSWAPBARRIERNVPROC __wglewBindSwapBarrierNV; -WGLEW_FUN_EXPORT PFNWGLJOINSWAPGROUPNVPROC __wglewJoinSwapGroupNV; -WGLEW_FUN_EXPORT PFNWGLQUERYFRAMECOUNTNVPROC __wglewQueryFrameCountNV; -WGLEW_FUN_EXPORT PFNWGLQUERYMAXSWAPGROUPSNVPROC __wglewQueryMaxSwapGroupsNV; -WGLEW_FUN_EXPORT PFNWGLQUERYSWAPGROUPNVPROC __wglewQuerySwapGroupNV; -WGLEW_FUN_EXPORT PFNWGLRESETFRAMECOUNTNVPROC __wglewResetFrameCountNV; - -WGLEW_FUN_EXPORT PFNWGLALLOCATEMEMORYNVPROC __wglewAllocateMemoryNV; -WGLEW_FUN_EXPORT PFNWGLFREEMEMORYNVPROC __wglewFreeMemoryNV; - -WGLEW_FUN_EXPORT PFNWGLBINDVIDEOCAPTUREDEVICENVPROC __wglewBindVideoCaptureDeviceNV; -WGLEW_FUN_EXPORT PFNWGLENUMERATEVIDEOCAPTUREDEVICESNVPROC __wglewEnumerateVideoCaptureDevicesNV; -WGLEW_FUN_EXPORT PFNWGLLOCKVIDEOCAPTUREDEVICENVPROC __wglewLockVideoCaptureDeviceNV; -WGLEW_FUN_EXPORT PFNWGLQUERYVIDEOCAPTUREDEVICENVPROC __wglewQueryVideoCaptureDeviceNV; -WGLEW_FUN_EXPORT PFNWGLRELEASEVIDEOCAPTUREDEVICENVPROC __wglewReleaseVideoCaptureDeviceNV; - -WGLEW_FUN_EXPORT PFNWGLBINDVIDEOIMAGENVPROC __wglewBindVideoImageNV; -WGLEW_FUN_EXPORT PFNWGLGETVIDEODEVICENVPROC __wglewGetVideoDeviceNV; -WGLEW_FUN_EXPORT PFNWGLGETVIDEOINFONVPROC __wglewGetVideoInfoNV; -WGLEW_FUN_EXPORT PFNWGLRELEASEVIDEODEVICENVPROC __wglewReleaseVideoDeviceNV; -WGLEW_FUN_EXPORT PFNWGLRELEASEVIDEOIMAGENVPROC __wglewReleaseVideoImageNV; -WGLEW_FUN_EXPORT PFNWGLSENDPBUFFERTOVIDEONVPROC __wglewSendPbufferToVideoNV; - -WGLEW_FUN_EXPORT PFNWGLGETMSCRATEOMLPROC __wglewGetMscRateOML; -WGLEW_FUN_EXPORT PFNWGLGETSYNCVALUESOMLPROC __wglewGetSyncValuesOML; -WGLEW_FUN_EXPORT PFNWGLSWAPBUFFERSMSCOMLPROC __wglewSwapBuffersMscOML; -WGLEW_FUN_EXPORT PFNWGLSWAPLAYERBUFFERSMSCOMLPROC __wglewSwapLayerBuffersMscOML; -WGLEW_FUN_EXPORT PFNWGLWAITFORMSCOMLPROC __wglewWaitForMscOML; -WGLEW_FUN_EXPORT PFNWGLWAITFORSBCOMLPROC __wglewWaitForSbcOML; -WGLEW_VAR_EXPORT GLboolean __WGLEW_3DFX_multisample; -WGLEW_VAR_EXPORT GLboolean __WGLEW_3DL_stereo_control; -WGLEW_VAR_EXPORT GLboolean __WGLEW_AMD_gpu_association; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_buffer_region; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_create_context; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_create_context_profile; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_create_context_robustness; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_extensions_string; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_framebuffer_sRGB; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_make_current_read; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_multisample; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_pbuffer; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_pixel_format; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_pixel_format_float; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_render_texture; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_robustness_application_isolation; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ARB_robustness_share_group_isolation; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ATI_pixel_format_float; -WGLEW_VAR_EXPORT GLboolean __WGLEW_ATI_render_texture_rectangle; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_create_context_es2_profile; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_create_context_es_profile; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_depth_float; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_display_color_table; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_extensions_string; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_framebuffer_sRGB; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_make_current_read; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_multisample; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_pbuffer; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_pixel_format; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_pixel_format_packed_float; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_swap_control; -WGLEW_VAR_EXPORT GLboolean __WGLEW_EXT_swap_control_tear; -WGLEW_VAR_EXPORT GLboolean __WGLEW_I3D_digital_video_control; -WGLEW_VAR_EXPORT GLboolean __WGLEW_I3D_gamma; -WGLEW_VAR_EXPORT GLboolean __WGLEW_I3D_genlock; -WGLEW_VAR_EXPORT GLboolean __WGLEW_I3D_image_buffer; -WGLEW_VAR_EXPORT GLboolean __WGLEW_I3D_swap_frame_lock; -WGLEW_VAR_EXPORT GLboolean __WGLEW_I3D_swap_frame_usage; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_DX_interop; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_DX_interop2; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_copy_image; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_float_buffer; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_gpu_affinity; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_multisample_coverage; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_present_video; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_render_depth_texture; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_render_texture_rectangle; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_swap_group; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_vertex_array_range; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_video_capture; -WGLEW_VAR_EXPORT GLboolean __WGLEW_NV_video_output; -WGLEW_VAR_EXPORT GLboolean __WGLEW_OML_sync_control; - -#ifdef GLEW_MX -}; /* WGLEWContextStruct */ -#endif /* GLEW_MX */ - -/* ------------------------------------------------------------------------- */ - -#ifdef GLEW_MX - -typedef struct WGLEWContextStruct WGLEWContext; -GLEWAPI GLenum GLEWAPIENTRY wglewContextInit (WGLEWContext *ctx); -GLEWAPI GLboolean GLEWAPIENTRY wglewContextIsSupported (const WGLEWContext *ctx, const char *name); - -#define wglewInit() wglewContextInit(wglewGetContext()) -#define wglewIsSupported(x) wglewContextIsSupported(wglewGetContext(), x) - -#define WGLEW_GET_VAR(x) (*(const GLboolean*)&(wglewGetContext()->x)) -#define WGLEW_GET_FUN(x) wglewGetContext()->x - -#else /* GLEW_MX */ - -#define WGLEW_GET_VAR(x) (*(const GLboolean*)&x) -#define WGLEW_GET_FUN(x) x - -GLEWAPI GLboolean GLEWAPIENTRY wglewIsSupported (const char *name); - -#endif /* GLEW_MX */ - -GLEWAPI GLboolean GLEWAPIENTRY wglewGetExtension (const char *name); - -#ifdef __cplusplus -} -#endif - -#undef GLEWAPI - -#endif /* __wglew_h__ */ diff --git a/btgui/OpenGLWindow/GlewWindows/glew.c b/btgui/OpenGLWindow/GlewWindows/glew.c deleted file mode 100644 index c90af794a..000000000 --- a/btgui/OpenGLWindow/GlewWindows/glew.c +++ /dev/null @@ -1,18897 +0,0 @@ -/* -** The OpenGL Extension Wrangler Library -** Copyright (C) 2002-2008, Milan Ikits -** Copyright (C) 2002-2008, Marcelo E. Magallon -** Copyright (C) 2002, Lev Povalahev -** All rights reserved. -** -** Redistribution and use in source and binary forms, with or without -** modification, are permitted provided that the following conditions are met: -** -** * Redistributions of source code must retain the above copyright notice, -** this list of conditions and the following disclaimer. -** * Redistributions in binary form must reproduce the above copyright notice, -** this list of conditions and the following disclaimer in the documentation -** and/or other materials provided with the distribution. -** * The name of the author may be used to endorse or promote products -** derived from this software without specific prior written permission. -** -** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE -** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR -** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF -** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS -** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN -** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) -** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF -** THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "GL/glew.h" - -#if defined(_WIN32) -# include -#elif !defined(__ANDROID__) && !defined(__native_client__) && (!defined(__APPLE__) || defined(GLEW_APPLE_GLX)) -# include "GL/glxew.h" - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#include -#include -#include - -void* dlglXGetProcAddressARB(const GLubyte* name) -{ - static void* h = NULL; - static void* gpa; - - if (h == NULL) - { - if ((h = dlopen("libGL.so.1", RTLD_LAZY | RTLD_LOCAL)) == NULL) - { - return NULL; - } - gpa = dlsym(h, "glXGetProcAddressARB"); - } - - if (gpa != NULL) - return ((void*(*)(const GLubyte*))gpa)(name); - else - return dlsym(h, (const char*)name); -} - - - -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#endif - -/* - * Define glewGetContext and related helper macros. - */ -#ifdef GLEW_MX -# define glewGetContext() ctx -# ifdef _WIN32 -# define GLEW_CONTEXT_ARG_DEF_INIT GLEWContext* ctx -# define GLEW_CONTEXT_ARG_VAR_INIT ctx -# define wglewGetContext() ctx -# define WGLEW_CONTEXT_ARG_DEF_INIT WGLEWContext* ctx -# define WGLEW_CONTEXT_ARG_DEF_LIST WGLEWContext* ctx -# else /* _WIN32 */ -# define GLEW_CONTEXT_ARG_DEF_INIT void -# define GLEW_CONTEXT_ARG_VAR_INIT -# define glxewGetContext() ctx -# define GLXEW_CONTEXT_ARG_DEF_INIT void -# define GLXEW_CONTEXT_ARG_DEF_LIST GLXEWContext* ctx -# endif /* _WIN32 */ -# define GLEW_CONTEXT_ARG_DEF_LIST GLEWContext* ctx -#else /* GLEW_MX */ -# define GLEW_CONTEXT_ARG_DEF_INIT void -# define GLEW_CONTEXT_ARG_VAR_INIT -# define GLEW_CONTEXT_ARG_DEF_LIST void -# define WGLEW_CONTEXT_ARG_DEF_INIT void -# define WGLEW_CONTEXT_ARG_DEF_LIST void -# define GLXEW_CONTEXT_ARG_DEF_INIT void -# define GLXEW_CONTEXT_ARG_DEF_LIST void -#endif /* GLEW_MX */ - -#if defined(__sgi) || defined (__sun) || defined(GLEW_APPLE_GLX) -#include -#include -#include - -void* dlGetProcAddress (const GLubyte* name) -{ - static void* h = NULL; - static void* gpa; - - if (h == NULL) - { - if ((h = dlopen(NULL, RTLD_LAZY | RTLD_LOCAL)) == NULL) return NULL; - gpa = dlsym(h, "glXGetProcAddress"); - } - - if (gpa != NULL) - return ((void*(*)(const GLubyte*))gpa)(name); - else - return dlsym(h, (const char*)name); -} -#endif /* __sgi || __sun || GLEW_APPLE_GLX */ - -#if defined(__APPLE__) -#include -#include -#include - -#ifdef MAC_OS_X_VERSION_10_3 - -#include - -void* NSGLGetProcAddress (const GLubyte *name) -{ - static void* image = NULL; - void* addr; - if (NULL == image) - { -#ifdef GLEW_REGAL - image = dlopen("libRegal.dylib", RTLD_LAZY); -#else - image = dlopen("/System/Library/Frameworks/OpenGL.framework/Versions/Current/OpenGL", RTLD_LAZY); -#endif - } - if( !image ) return NULL; - addr = dlsym(image, (const char*)name); - if( addr ) return addr; -#ifdef GLEW_APPLE_GLX - return dlGetProcAddress( name ); // try next for glx symbols -#else - return NULL; -#endif -} -#else - -#include - -void* NSGLGetProcAddress (const GLubyte *name) -{ - static const struct mach_header* image = NULL; - NSSymbol symbol; - char* symbolName; - if (NULL == image) - { -#ifdef GLEW_REGAL - image = NSAddImage("libRegal.dylib", NSADDIMAGE_OPTION_RETURN_ON_ERROR); -#else - image = NSAddImage("/System/Library/Frameworks/OpenGL.framework/Versions/Current/OpenGL", NSADDIMAGE_OPTION_RETURN_ON_ERROR); -#endif - } - /* prepend a '_' for the Unix C symbol mangling convention */ - symbolName = malloc(strlen((const char*)name) + 2); - strcpy(symbolName+1, (const char*)name); - symbolName[0] = '_'; - symbol = NULL; - /* if (NSIsSymbolNameDefined(symbolName)) - symbol = NSLookupAndBindSymbol(symbolName); */ - symbol = image ? NSLookupSymbolInImage(image, symbolName, NSLOOKUPSYMBOLINIMAGE_OPTION_BIND | NSLOOKUPSYMBOLINIMAGE_OPTION_RETURN_ON_ERROR) : NULL; - free(symbolName); - if( symbol ) return NSAddressOfSymbol(symbol); -#ifdef GLEW_APPLE_GLX - return dlGetProcAddress( name ); // try next for glx symbols -#else - return NULL; -#endif -} -#endif /* MAC_OS_X_VERSION_10_3 */ -#endif /* __APPLE__ */ - -/* - * Define glewGetProcAddress. - */ -#if defined(_WIN32) -# define glewGetProcAddress(name) wglGetProcAddress((LPCSTR)name) -#elif defined(__APPLE__) && !defined(GLEW_APPLE_GLX) -# define glewGetProcAddress(name) NSGLGetProcAddress(name) -#elif defined(__sgi) || defined(__sun) -# define glewGetProcAddress(name) dlGetProcAddress(name) -#elif defined(__ANDROID__) -# define glewGetProcAddress(name) NULL /* TODO */ -#elif defined(__native_client__) -# define glewGetProcAddress(name) NULL /* TODO */ -#else /* __linux */ -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -# define glewGetProcAddress(name) dlglXGetProcAddressARB(name) -#else//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -# define glewGetProcAddress(name) (*glXGetProcAddressARB)(name) -#endif//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -#endif - -/* - * Define GLboolean const cast. - */ -#define CONST_CAST(x) (*(GLboolean*)&x) - -/* - * GLEW, just like OpenGL or GLU, does not rely on the standard C library. - * These functions implement the functionality required in this file. - */ -static GLuint _glewStrLen (const GLubyte* s) -{ - GLuint i=0; - if (s == NULL) return 0; - while (s[i] != '\0') i++; - return i; -} - -static GLuint _glewStrCLen (const GLubyte* s, GLubyte c) -{ - GLuint i=0; - if (s == NULL) return 0; - while (s[i] != '\0' && s[i] != c) i++; - return (s[i] == '\0' || s[i] == c) ? i : 0; -} - -static GLboolean _glewStrSame (const GLubyte* a, const GLubyte* b, GLuint n) -{ - GLuint i=0; - if(a == NULL || b == NULL) - return (a == NULL && b == NULL && n == 0) ? GL_TRUE : GL_FALSE; - while (i < n && a[i] != '\0' && b[i] != '\0' && a[i] == b[i]) i++; - return i == n ? GL_TRUE : GL_FALSE; -} - -static GLboolean _glewStrSame1 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) -{ - while (*na > 0 && (**a == ' ' || **a == '\n' || **a == '\r' || **a == '\t')) - { - (*a)++; - (*na)--; - } - if(*na >= nb) - { - GLuint i=0; - while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; - if(i == nb) - { - *a = *a + nb; - *na = *na - nb; - return GL_TRUE; - } - } - return GL_FALSE; -} - -static GLboolean _glewStrSame2 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) -{ - if(*na >= nb) - { - GLuint i=0; - while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; - if(i == nb) - { - *a = *a + nb; - *na = *na - nb; - return GL_TRUE; - } - } - return GL_FALSE; -} - -static GLboolean _glewStrSame3 (GLubyte** a, GLuint* na, const GLubyte* b, GLuint nb) -{ - if(*na >= nb) - { - GLuint i=0; - while (i < nb && (*a)+i != NULL && b+i != NULL && (*a)[i] == b[i]) i++; - if (i == nb && (*na == nb || (*a)[i] == ' ' || (*a)[i] == '\n' || (*a)[i] == '\r' || (*a)[i] == '\t')) - { - *a = *a + nb; - *na = *na - nb; - return GL_TRUE; - } - } - return GL_FALSE; -} - -/* - * Search for name in the extensions string. Use of strstr() - * is not sufficient because extension names can be prefixes of - * other extension names. Could use strtok() but the constant - * string returned by glGetString might be in read-only memory. - */ -static GLboolean _glewSearchExtension (const char* name, const GLubyte *start, const GLubyte *end) -{ - const GLubyte* p; - GLuint len = _glewStrLen((const GLubyte*)name); - p = start; - while (p < end) - { - GLuint n = _glewStrCLen(p, ' '); - if (len == n && _glewStrSame((const GLubyte*)name, p, n)) return GL_TRUE; - p += n+1; - } - return GL_FALSE; -} - -#if !defined(_WIN32) || !defined(GLEW_MX) - -PFNGLCOPYTEXSUBIMAGE3DPROC __glewCopyTexSubImage3D = NULL; -PFNGLDRAWRANGEELEMENTSPROC __glewDrawRangeElements = NULL; -PFNGLTEXIMAGE3DPROC __glewTexImage3D = NULL; -PFNGLTEXSUBIMAGE3DPROC __glewTexSubImage3D = NULL; - -PFNGLACTIVETEXTUREPROC __glewActiveTexture = NULL; -PFNGLCLIENTACTIVETEXTUREPROC __glewClientActiveTexture = NULL; -PFNGLCOMPRESSEDTEXIMAGE1DPROC __glewCompressedTexImage1D = NULL; -PFNGLCOMPRESSEDTEXIMAGE2DPROC __glewCompressedTexImage2D = NULL; -PFNGLCOMPRESSEDTEXIMAGE3DPROC __glewCompressedTexImage3D = NULL; -PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC __glewCompressedTexSubImage1D = NULL; -PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC __glewCompressedTexSubImage2D = NULL; -PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC __glewCompressedTexSubImage3D = NULL; -PFNGLGETCOMPRESSEDTEXIMAGEPROC __glewGetCompressedTexImage = NULL; -PFNGLLOADTRANSPOSEMATRIXDPROC __glewLoadTransposeMatrixd = NULL; -PFNGLLOADTRANSPOSEMATRIXFPROC __glewLoadTransposeMatrixf = NULL; -PFNGLMULTTRANSPOSEMATRIXDPROC __glewMultTransposeMatrixd = NULL; -PFNGLMULTTRANSPOSEMATRIXFPROC __glewMultTransposeMatrixf = NULL; -PFNGLMULTITEXCOORD1DPROC __glewMultiTexCoord1d = NULL; -PFNGLMULTITEXCOORD1DVPROC __glewMultiTexCoord1dv = NULL; -PFNGLMULTITEXCOORD1FPROC __glewMultiTexCoord1f = NULL; -PFNGLMULTITEXCOORD1FVPROC __glewMultiTexCoord1fv = NULL; -PFNGLMULTITEXCOORD1IPROC __glewMultiTexCoord1i = NULL; -PFNGLMULTITEXCOORD1IVPROC __glewMultiTexCoord1iv = NULL; -PFNGLMULTITEXCOORD1SPROC __glewMultiTexCoord1s = NULL; -PFNGLMULTITEXCOORD1SVPROC __glewMultiTexCoord1sv = NULL; -PFNGLMULTITEXCOORD2DPROC __glewMultiTexCoord2d = NULL; -PFNGLMULTITEXCOORD2DVPROC __glewMultiTexCoord2dv = NULL; -PFNGLMULTITEXCOORD2FPROC __glewMultiTexCoord2f = NULL; -PFNGLMULTITEXCOORD2FVPROC __glewMultiTexCoord2fv = NULL; -PFNGLMULTITEXCOORD2IPROC __glewMultiTexCoord2i = NULL; -PFNGLMULTITEXCOORD2IVPROC __glewMultiTexCoord2iv = NULL; -PFNGLMULTITEXCOORD2SPROC __glewMultiTexCoord2s = NULL; -PFNGLMULTITEXCOORD2SVPROC __glewMultiTexCoord2sv = NULL; -PFNGLMULTITEXCOORD3DPROC __glewMultiTexCoord3d = NULL; -PFNGLMULTITEXCOORD3DVPROC __glewMultiTexCoord3dv = NULL; -PFNGLMULTITEXCOORD3FPROC __glewMultiTexCoord3f = NULL; -PFNGLMULTITEXCOORD3FVPROC __glewMultiTexCoord3fv = NULL; -PFNGLMULTITEXCOORD3IPROC __glewMultiTexCoord3i = NULL; -PFNGLMULTITEXCOORD3IVPROC __glewMultiTexCoord3iv = NULL; -PFNGLMULTITEXCOORD3SPROC __glewMultiTexCoord3s = NULL; -PFNGLMULTITEXCOORD3SVPROC __glewMultiTexCoord3sv = NULL; -PFNGLMULTITEXCOORD4DPROC __glewMultiTexCoord4d = NULL; -PFNGLMULTITEXCOORD4DVPROC __glewMultiTexCoord4dv = NULL; -PFNGLMULTITEXCOORD4FPROC __glewMultiTexCoord4f = NULL; -PFNGLMULTITEXCOORD4FVPROC __glewMultiTexCoord4fv = NULL; -PFNGLMULTITEXCOORD4IPROC __glewMultiTexCoord4i = NULL; -PFNGLMULTITEXCOORD4IVPROC __glewMultiTexCoord4iv = NULL; -PFNGLMULTITEXCOORD4SPROC __glewMultiTexCoord4s = NULL; -PFNGLMULTITEXCOORD4SVPROC __glewMultiTexCoord4sv = NULL; -PFNGLSAMPLECOVERAGEPROC __glewSampleCoverage = NULL; - -PFNGLBLENDCOLORPROC __glewBlendColor = NULL; -PFNGLBLENDEQUATIONPROC __glewBlendEquation = NULL; -PFNGLBLENDFUNCSEPARATEPROC __glewBlendFuncSeparate = NULL; -PFNGLFOGCOORDPOINTERPROC __glewFogCoordPointer = NULL; -PFNGLFOGCOORDDPROC __glewFogCoordd = NULL; -PFNGLFOGCOORDDVPROC __glewFogCoorddv = NULL; -PFNGLFOGCOORDFPROC __glewFogCoordf = NULL; -PFNGLFOGCOORDFVPROC __glewFogCoordfv = NULL; -PFNGLMULTIDRAWARRAYSPROC __glewMultiDrawArrays = NULL; -PFNGLMULTIDRAWELEMENTSPROC __glewMultiDrawElements = NULL; -PFNGLPOINTPARAMETERFPROC __glewPointParameterf = NULL; -PFNGLPOINTPARAMETERFVPROC __glewPointParameterfv = NULL; -PFNGLPOINTPARAMETERIPROC __glewPointParameteri = NULL; -PFNGLPOINTPARAMETERIVPROC __glewPointParameteriv = NULL; -PFNGLSECONDARYCOLOR3BPROC __glewSecondaryColor3b = NULL; -PFNGLSECONDARYCOLOR3BVPROC __glewSecondaryColor3bv = NULL; -PFNGLSECONDARYCOLOR3DPROC __glewSecondaryColor3d = NULL; -PFNGLSECONDARYCOLOR3DVPROC __glewSecondaryColor3dv = NULL; -PFNGLSECONDARYCOLOR3FPROC __glewSecondaryColor3f = NULL; -PFNGLSECONDARYCOLOR3FVPROC __glewSecondaryColor3fv = NULL; -PFNGLSECONDARYCOLOR3IPROC __glewSecondaryColor3i = NULL; -PFNGLSECONDARYCOLOR3IVPROC __glewSecondaryColor3iv = NULL; -PFNGLSECONDARYCOLOR3SPROC __glewSecondaryColor3s = NULL; -PFNGLSECONDARYCOLOR3SVPROC __glewSecondaryColor3sv = NULL; -PFNGLSECONDARYCOLOR3UBPROC __glewSecondaryColor3ub = NULL; -PFNGLSECONDARYCOLOR3UBVPROC __glewSecondaryColor3ubv = NULL; -PFNGLSECONDARYCOLOR3UIPROC __glewSecondaryColor3ui = NULL; -PFNGLSECONDARYCOLOR3UIVPROC __glewSecondaryColor3uiv = NULL; -PFNGLSECONDARYCOLOR3USPROC __glewSecondaryColor3us = NULL; -PFNGLSECONDARYCOLOR3USVPROC __glewSecondaryColor3usv = NULL; -PFNGLSECONDARYCOLORPOINTERPROC __glewSecondaryColorPointer = NULL; -PFNGLWINDOWPOS2DPROC __glewWindowPos2d = NULL; -PFNGLWINDOWPOS2DVPROC __glewWindowPos2dv = NULL; -PFNGLWINDOWPOS2FPROC __glewWindowPos2f = NULL; -PFNGLWINDOWPOS2FVPROC __glewWindowPos2fv = NULL; -PFNGLWINDOWPOS2IPROC __glewWindowPos2i = NULL; -PFNGLWINDOWPOS2IVPROC __glewWindowPos2iv = NULL; -PFNGLWINDOWPOS2SPROC __glewWindowPos2s = NULL; -PFNGLWINDOWPOS2SVPROC __glewWindowPos2sv = NULL; -PFNGLWINDOWPOS3DPROC __glewWindowPos3d = NULL; -PFNGLWINDOWPOS3DVPROC __glewWindowPos3dv = NULL; -PFNGLWINDOWPOS3FPROC __glewWindowPos3f = NULL; -PFNGLWINDOWPOS3FVPROC __glewWindowPos3fv = NULL; -PFNGLWINDOWPOS3IPROC __glewWindowPos3i = NULL; -PFNGLWINDOWPOS3IVPROC __glewWindowPos3iv = NULL; -PFNGLWINDOWPOS3SPROC __glewWindowPos3s = NULL; -PFNGLWINDOWPOS3SVPROC __glewWindowPos3sv = NULL; - -PFNGLBEGINQUERYPROC __glewBeginQuery = NULL; -PFNGLBINDBUFFERPROC __glewBindBuffer = NULL; -PFNGLBUFFERDATAPROC __glewBufferData = NULL; -PFNGLBUFFERSUBDATAPROC __glewBufferSubData = NULL; -PFNGLDELETEBUFFERSPROC __glewDeleteBuffers = NULL; -PFNGLDELETEQUERIESPROC __glewDeleteQueries = NULL; -PFNGLENDQUERYPROC __glewEndQuery = NULL; -PFNGLGENBUFFERSPROC __glewGenBuffers = NULL; -PFNGLGENQUERIESPROC __glewGenQueries = NULL; -PFNGLGETBUFFERPARAMETERIVPROC __glewGetBufferParameteriv = NULL; -PFNGLGETBUFFERPOINTERVPROC __glewGetBufferPointerv = NULL; -PFNGLGETBUFFERSUBDATAPROC __glewGetBufferSubData = NULL; -PFNGLGETQUERYOBJECTIVPROC __glewGetQueryObjectiv = NULL; -PFNGLGETQUERYOBJECTUIVPROC __glewGetQueryObjectuiv = NULL; -PFNGLGETQUERYIVPROC __glewGetQueryiv = NULL; -PFNGLISBUFFERPROC __glewIsBuffer = NULL; -PFNGLISQUERYPROC __glewIsQuery = NULL; -PFNGLMAPBUFFERPROC __glewMapBuffer = NULL; -PFNGLUNMAPBUFFERPROC __glewUnmapBuffer = NULL; - -PFNGLATTACHSHADERPROC __glewAttachShader = NULL; -PFNGLBINDATTRIBLOCATIONPROC __glewBindAttribLocation = NULL; -PFNGLBLENDEQUATIONSEPARATEPROC __glewBlendEquationSeparate = NULL; -PFNGLCOMPILESHADERPROC __glewCompileShader = NULL; -PFNGLCREATEPROGRAMPROC __glewCreateProgram = NULL; -PFNGLCREATESHADERPROC __glewCreateShader = NULL; -PFNGLDELETEPROGRAMPROC __glewDeleteProgram = NULL; -PFNGLDELETESHADERPROC __glewDeleteShader = NULL; -PFNGLDETACHSHADERPROC __glewDetachShader = NULL; -PFNGLDISABLEVERTEXATTRIBARRAYPROC __glewDisableVertexAttribArray = NULL; -PFNGLDRAWBUFFERSPROC __glewDrawBuffers = NULL; -PFNGLENABLEVERTEXATTRIBARRAYPROC __glewEnableVertexAttribArray = NULL; -PFNGLGETACTIVEATTRIBPROC __glewGetActiveAttrib = NULL; -PFNGLGETACTIVEUNIFORMPROC __glewGetActiveUniform = NULL; -PFNGLGETATTACHEDSHADERSPROC __glewGetAttachedShaders = NULL; -PFNGLGETATTRIBLOCATIONPROC __glewGetAttribLocation = NULL; -PFNGLGETPROGRAMINFOLOGPROC __glewGetProgramInfoLog = NULL; -PFNGLGETPROGRAMIVPROC __glewGetProgramiv = NULL; -PFNGLGETSHADERINFOLOGPROC __glewGetShaderInfoLog = NULL; -PFNGLGETSHADERSOURCEPROC __glewGetShaderSource = NULL; -PFNGLGETSHADERIVPROC __glewGetShaderiv = NULL; -PFNGLGETUNIFORMLOCATIONPROC __glewGetUniformLocation = NULL; -PFNGLGETUNIFORMFVPROC __glewGetUniformfv = NULL; -PFNGLGETUNIFORMIVPROC __glewGetUniformiv = NULL; -PFNGLGETVERTEXATTRIBPOINTERVPROC __glewGetVertexAttribPointerv = NULL; -PFNGLGETVERTEXATTRIBDVPROC __glewGetVertexAttribdv = NULL; -PFNGLGETVERTEXATTRIBFVPROC __glewGetVertexAttribfv = NULL; -PFNGLGETVERTEXATTRIBIVPROC __glewGetVertexAttribiv = NULL; -PFNGLISPROGRAMPROC __glewIsProgram = NULL; -PFNGLISSHADERPROC __glewIsShader = NULL; -PFNGLLINKPROGRAMPROC __glewLinkProgram = NULL; -PFNGLSHADERSOURCEPROC __glewShaderSource = NULL; -PFNGLSTENCILFUNCSEPARATEPROC __glewStencilFuncSeparate = NULL; -PFNGLSTENCILMASKSEPARATEPROC __glewStencilMaskSeparate = NULL; -PFNGLSTENCILOPSEPARATEPROC __glewStencilOpSeparate = NULL; -PFNGLUNIFORM1FPROC __glewUniform1f = NULL; -PFNGLUNIFORM1FVPROC __glewUniform1fv = NULL; -PFNGLUNIFORM1IPROC __glewUniform1i = NULL; -PFNGLUNIFORM1IVPROC __glewUniform1iv = NULL; -PFNGLUNIFORM2FPROC __glewUniform2f = NULL; -PFNGLUNIFORM2FVPROC __glewUniform2fv = NULL; -PFNGLUNIFORM2IPROC __glewUniform2i = NULL; -PFNGLUNIFORM2IVPROC __glewUniform2iv = NULL; -PFNGLUNIFORM3FPROC __glewUniform3f = NULL; -PFNGLUNIFORM3FVPROC __glewUniform3fv = NULL; -PFNGLUNIFORM3IPROC __glewUniform3i = NULL; -PFNGLUNIFORM3IVPROC __glewUniform3iv = NULL; -PFNGLUNIFORM4FPROC __glewUniform4f = NULL; -PFNGLUNIFORM4FVPROC __glewUniform4fv = NULL; -PFNGLUNIFORM4IPROC __glewUniform4i = NULL; -PFNGLUNIFORM4IVPROC __glewUniform4iv = NULL; -PFNGLUNIFORMMATRIX2FVPROC __glewUniformMatrix2fv = NULL; -PFNGLUNIFORMMATRIX3FVPROC __glewUniformMatrix3fv = NULL; -PFNGLUNIFORMMATRIX4FVPROC __glewUniformMatrix4fv = NULL; -PFNGLUSEPROGRAMPROC __glewUseProgram = NULL; -PFNGLVALIDATEPROGRAMPROC __glewValidateProgram = NULL; -PFNGLVERTEXATTRIB1DPROC __glewVertexAttrib1d = NULL; -PFNGLVERTEXATTRIB1DVPROC __glewVertexAttrib1dv = NULL; -PFNGLVERTEXATTRIB1FPROC __glewVertexAttrib1f = NULL; -PFNGLVERTEXATTRIB1FVPROC __glewVertexAttrib1fv = NULL; -PFNGLVERTEXATTRIB1SPROC __glewVertexAttrib1s = NULL; -PFNGLVERTEXATTRIB1SVPROC __glewVertexAttrib1sv = NULL; -PFNGLVERTEXATTRIB2DPROC __glewVertexAttrib2d = NULL; -PFNGLVERTEXATTRIB2DVPROC __glewVertexAttrib2dv = NULL; -PFNGLVERTEXATTRIB2FPROC __glewVertexAttrib2f = NULL; -PFNGLVERTEXATTRIB2FVPROC __glewVertexAttrib2fv = NULL; -PFNGLVERTEXATTRIB2SPROC __glewVertexAttrib2s = NULL; -PFNGLVERTEXATTRIB2SVPROC __glewVertexAttrib2sv = NULL; -PFNGLVERTEXATTRIB3DPROC __glewVertexAttrib3d = NULL; -PFNGLVERTEXATTRIB3DVPROC __glewVertexAttrib3dv = NULL; -PFNGLVERTEXATTRIB3FPROC __glewVertexAttrib3f = NULL; -PFNGLVERTEXATTRIB3FVPROC __glewVertexAttrib3fv = NULL; -PFNGLVERTEXATTRIB3SPROC __glewVertexAttrib3s = NULL; -PFNGLVERTEXATTRIB3SVPROC __glewVertexAttrib3sv = NULL; -PFNGLVERTEXATTRIB4NBVPROC __glewVertexAttrib4Nbv = NULL; -PFNGLVERTEXATTRIB4NIVPROC __glewVertexAttrib4Niv = NULL; -PFNGLVERTEXATTRIB4NSVPROC __glewVertexAttrib4Nsv = NULL; -PFNGLVERTEXATTRIB4NUBPROC __glewVertexAttrib4Nub = NULL; -PFNGLVERTEXATTRIB4NUBVPROC __glewVertexAttrib4Nubv = NULL; -PFNGLVERTEXATTRIB4NUIVPROC __glewVertexAttrib4Nuiv = NULL; -PFNGLVERTEXATTRIB4NUSVPROC __glewVertexAttrib4Nusv = NULL; -PFNGLVERTEXATTRIB4BVPROC __glewVertexAttrib4bv = NULL; -PFNGLVERTEXATTRIB4DPROC __glewVertexAttrib4d = NULL; -PFNGLVERTEXATTRIB4DVPROC __glewVertexAttrib4dv = NULL; -PFNGLVERTEXATTRIB4FPROC __glewVertexAttrib4f = NULL; -PFNGLVERTEXATTRIB4FVPROC __glewVertexAttrib4fv = NULL; -PFNGLVERTEXATTRIB4IVPROC __glewVertexAttrib4iv = NULL; -PFNGLVERTEXATTRIB4SPROC __glewVertexAttrib4s = NULL; -PFNGLVERTEXATTRIB4SVPROC __glewVertexAttrib4sv = NULL; -PFNGLVERTEXATTRIB4UBVPROC __glewVertexAttrib4ubv = NULL; -PFNGLVERTEXATTRIB4UIVPROC __glewVertexAttrib4uiv = NULL; -PFNGLVERTEXATTRIB4USVPROC __glewVertexAttrib4usv = NULL; -PFNGLVERTEXATTRIBPOINTERPROC __glewVertexAttribPointer = NULL; - -PFNGLUNIFORMMATRIX2X3FVPROC __glewUniformMatrix2x3fv = NULL; -PFNGLUNIFORMMATRIX2X4FVPROC __glewUniformMatrix2x4fv = NULL; -PFNGLUNIFORMMATRIX3X2FVPROC __glewUniformMatrix3x2fv = NULL; -PFNGLUNIFORMMATRIX3X4FVPROC __glewUniformMatrix3x4fv = NULL; -PFNGLUNIFORMMATRIX4X2FVPROC __glewUniformMatrix4x2fv = NULL; -PFNGLUNIFORMMATRIX4X3FVPROC __glewUniformMatrix4x3fv = NULL; - -PFNGLBEGINCONDITIONALRENDERPROC __glewBeginConditionalRender = NULL; -PFNGLBEGINTRANSFORMFEEDBACKPROC __glewBeginTransformFeedback = NULL; -PFNGLBINDFRAGDATALOCATIONPROC __glewBindFragDataLocation = NULL; -PFNGLCLAMPCOLORPROC __glewClampColor = NULL; -PFNGLCLEARBUFFERFIPROC __glewClearBufferfi = NULL; -PFNGLCLEARBUFFERFVPROC __glewClearBufferfv = NULL; -PFNGLCLEARBUFFERIVPROC __glewClearBufferiv = NULL; -PFNGLCLEARBUFFERUIVPROC __glewClearBufferuiv = NULL; -PFNGLCOLORMASKIPROC __glewColorMaski = NULL; -PFNGLDISABLEIPROC __glewDisablei = NULL; -PFNGLENABLEIPROC __glewEnablei = NULL; -PFNGLENDCONDITIONALRENDERPROC __glewEndConditionalRender = NULL; -PFNGLENDTRANSFORMFEEDBACKPROC __glewEndTransformFeedback = NULL; -PFNGLGETBOOLEANI_VPROC __glewGetBooleani_v = NULL; -PFNGLGETFRAGDATALOCATIONPROC __glewGetFragDataLocation = NULL; -PFNGLGETSTRINGIPROC __glewGetStringi = NULL; -PFNGLGETTEXPARAMETERIIVPROC __glewGetTexParameterIiv = NULL; -PFNGLGETTEXPARAMETERIUIVPROC __glewGetTexParameterIuiv = NULL; -PFNGLGETTRANSFORMFEEDBACKVARYINGPROC __glewGetTransformFeedbackVarying = NULL; -PFNGLGETUNIFORMUIVPROC __glewGetUniformuiv = NULL; -PFNGLGETVERTEXATTRIBIIVPROC __glewGetVertexAttribIiv = NULL; -PFNGLGETVERTEXATTRIBIUIVPROC __glewGetVertexAttribIuiv = NULL; -PFNGLISENABLEDIPROC __glewIsEnabledi = NULL; -PFNGLTEXPARAMETERIIVPROC __glewTexParameterIiv = NULL; -PFNGLTEXPARAMETERIUIVPROC __glewTexParameterIuiv = NULL; -PFNGLTRANSFORMFEEDBACKVARYINGSPROC __glewTransformFeedbackVaryings = NULL; -PFNGLUNIFORM1UIPROC __glewUniform1ui = NULL; -PFNGLUNIFORM1UIVPROC __glewUniform1uiv = NULL; -PFNGLUNIFORM2UIPROC __glewUniform2ui = NULL; -PFNGLUNIFORM2UIVPROC __glewUniform2uiv = NULL; -PFNGLUNIFORM3UIPROC __glewUniform3ui = NULL; -PFNGLUNIFORM3UIVPROC __glewUniform3uiv = NULL; -PFNGLUNIFORM4UIPROC __glewUniform4ui = NULL; -PFNGLUNIFORM4UIVPROC __glewUniform4uiv = NULL; -PFNGLVERTEXATTRIBI1IPROC __glewVertexAttribI1i = NULL; -PFNGLVERTEXATTRIBI1IVPROC __glewVertexAttribI1iv = NULL; -PFNGLVERTEXATTRIBI1UIPROC __glewVertexAttribI1ui = NULL; -PFNGLVERTEXATTRIBI1UIVPROC __glewVertexAttribI1uiv = NULL; -PFNGLVERTEXATTRIBI2IPROC __glewVertexAttribI2i = NULL; -PFNGLVERTEXATTRIBI2IVPROC __glewVertexAttribI2iv = NULL; -PFNGLVERTEXATTRIBI2UIPROC __glewVertexAttribI2ui = NULL; -PFNGLVERTEXATTRIBI2UIVPROC __glewVertexAttribI2uiv = NULL; -PFNGLVERTEXATTRIBI3IPROC __glewVertexAttribI3i = NULL; -PFNGLVERTEXATTRIBI3IVPROC __glewVertexAttribI3iv = NULL; -PFNGLVERTEXATTRIBI3UIPROC __glewVertexAttribI3ui = NULL; -PFNGLVERTEXATTRIBI3UIVPROC __glewVertexAttribI3uiv = NULL; -PFNGLVERTEXATTRIBI4BVPROC __glewVertexAttribI4bv = NULL; -PFNGLVERTEXATTRIBI4IPROC __glewVertexAttribI4i = NULL; -PFNGLVERTEXATTRIBI4IVPROC __glewVertexAttribI4iv = NULL; -PFNGLVERTEXATTRIBI4SVPROC __glewVertexAttribI4sv = NULL; -PFNGLVERTEXATTRIBI4UBVPROC __glewVertexAttribI4ubv = NULL; -PFNGLVERTEXATTRIBI4UIPROC __glewVertexAttribI4ui = NULL; -PFNGLVERTEXATTRIBI4UIVPROC __glewVertexAttribI4uiv = NULL; -PFNGLVERTEXATTRIBI4USVPROC __glewVertexAttribI4usv = NULL; -PFNGLVERTEXATTRIBIPOINTERPROC __glewVertexAttribIPointer = NULL; - -PFNGLDRAWARRAYSINSTANCEDPROC __glewDrawArraysInstanced = NULL; -PFNGLDRAWELEMENTSINSTANCEDPROC __glewDrawElementsInstanced = NULL; -PFNGLPRIMITIVERESTARTINDEXPROC __glewPrimitiveRestartIndex = NULL; -PFNGLTEXBUFFERPROC __glewTexBuffer = NULL; - -PFNGLFRAMEBUFFERTEXTUREPROC __glewFramebufferTexture = NULL; -PFNGLGETBUFFERPARAMETERI64VPROC __glewGetBufferParameteri64v = NULL; -PFNGLGETINTEGER64I_VPROC __glewGetInteger64i_v = NULL; - -PFNGLVERTEXATTRIBDIVISORPROC __glewVertexAttribDivisor = NULL; - -PFNGLBLENDEQUATIONSEPARATEIPROC __glewBlendEquationSeparatei = NULL; -PFNGLBLENDEQUATIONIPROC __glewBlendEquationi = NULL; -PFNGLBLENDFUNCSEPARATEIPROC __glewBlendFuncSeparatei = NULL; -PFNGLBLENDFUNCIPROC __glewBlendFunci = NULL; -PFNGLMINSAMPLESHADINGPROC __glewMinSampleShading = NULL; - -PFNGLTBUFFERMASK3DFXPROC __glewTbufferMask3DFX = NULL; - -PFNGLDEBUGMESSAGECALLBACKAMDPROC __glewDebugMessageCallbackAMD = NULL; -PFNGLDEBUGMESSAGEENABLEAMDPROC __glewDebugMessageEnableAMD = NULL; -PFNGLDEBUGMESSAGEINSERTAMDPROC __glewDebugMessageInsertAMD = NULL; -PFNGLGETDEBUGMESSAGELOGAMDPROC __glewGetDebugMessageLogAMD = NULL; - -PFNGLBLENDEQUATIONINDEXEDAMDPROC __glewBlendEquationIndexedAMD = NULL; -PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC __glewBlendEquationSeparateIndexedAMD = NULL; -PFNGLBLENDFUNCINDEXEDAMDPROC __glewBlendFuncIndexedAMD = NULL; -PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC __glewBlendFuncSeparateIndexedAMD = NULL; - -PFNGLVERTEXATTRIBPARAMETERIAMDPROC __glewVertexAttribParameteriAMD = NULL; - -PFNGLMULTIDRAWARRAYSINDIRECTAMDPROC __glewMultiDrawArraysIndirectAMD = NULL; -PFNGLMULTIDRAWELEMENTSINDIRECTAMDPROC __glewMultiDrawElementsIndirectAMD = NULL; - -PFNGLDELETENAMESAMDPROC __glewDeleteNamesAMD = NULL; -PFNGLGENNAMESAMDPROC __glewGenNamesAMD = NULL; -PFNGLISNAMEAMDPROC __glewIsNameAMD = NULL; - -PFNGLBEGINPERFMONITORAMDPROC __glewBeginPerfMonitorAMD = NULL; -PFNGLDELETEPERFMONITORSAMDPROC __glewDeletePerfMonitorsAMD = NULL; -PFNGLENDPERFMONITORAMDPROC __glewEndPerfMonitorAMD = NULL; -PFNGLGENPERFMONITORSAMDPROC __glewGenPerfMonitorsAMD = NULL; -PFNGLGETPERFMONITORCOUNTERDATAAMDPROC __glewGetPerfMonitorCounterDataAMD = NULL; -PFNGLGETPERFMONITORCOUNTERINFOAMDPROC __glewGetPerfMonitorCounterInfoAMD = NULL; -PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC __glewGetPerfMonitorCounterStringAMD = NULL; -PFNGLGETPERFMONITORCOUNTERSAMDPROC __glewGetPerfMonitorCountersAMD = NULL; -PFNGLGETPERFMONITORGROUPSTRINGAMDPROC __glewGetPerfMonitorGroupStringAMD = NULL; -PFNGLGETPERFMONITORGROUPSAMDPROC __glewGetPerfMonitorGroupsAMD = NULL; -PFNGLSELECTPERFMONITORCOUNTERSAMDPROC __glewSelectPerfMonitorCountersAMD = NULL; - -PFNGLSETMULTISAMPLEFVAMDPROC __glewSetMultisamplefvAMD = NULL; - -PFNGLTEXSTORAGESPARSEAMDPROC __glewTexStorageSparseAMD = NULL; -PFNGLTEXTURESTORAGESPARSEAMDPROC __glewTextureStorageSparseAMD = NULL; - -PFNGLSTENCILOPVALUEAMDPROC __glewStencilOpValueAMD = NULL; - -PFNGLTESSELLATIONFACTORAMDPROC __glewTessellationFactorAMD = NULL; -PFNGLTESSELLATIONMODEAMDPROC __glewTessellationModeAMD = NULL; - -PFNGLBLITFRAMEBUFFERANGLEPROC __glewBlitFramebufferANGLE = NULL; - -PFNGLRENDERBUFFERSTORAGEMULTISAMPLEANGLEPROC __glewRenderbufferStorageMultisampleANGLE = NULL; - -PFNGLDRAWARRAYSINSTANCEDANGLEPROC __glewDrawArraysInstancedANGLE = NULL; -PFNGLDRAWELEMENTSINSTANCEDANGLEPROC __glewDrawElementsInstancedANGLE = NULL; -PFNGLVERTEXATTRIBDIVISORANGLEPROC __glewVertexAttribDivisorANGLE = NULL; - -PFNGLBEGINQUERYANGLEPROC __glewBeginQueryANGLE = NULL; -PFNGLDELETEQUERIESANGLEPROC __glewDeleteQueriesANGLE = NULL; -PFNGLENDQUERYANGLEPROC __glewEndQueryANGLE = NULL; -PFNGLGENQUERIESANGLEPROC __glewGenQueriesANGLE = NULL; -PFNGLGETQUERYOBJECTI64VANGLEPROC __glewGetQueryObjecti64vANGLE = NULL; -PFNGLGETQUERYOBJECTIVANGLEPROC __glewGetQueryObjectivANGLE = NULL; -PFNGLGETQUERYOBJECTUI64VANGLEPROC __glewGetQueryObjectui64vANGLE = NULL; -PFNGLGETQUERYOBJECTUIVANGLEPROC __glewGetQueryObjectuivANGLE = NULL; -PFNGLGETQUERYIVANGLEPROC __glewGetQueryivANGLE = NULL; -PFNGLISQUERYANGLEPROC __glewIsQueryANGLE = NULL; -PFNGLQUERYCOUNTERANGLEPROC __glewQueryCounterANGLE = NULL; - -PFNGLGETTRANSLATEDSHADERSOURCEANGLEPROC __glewGetTranslatedShaderSourceANGLE = NULL; - -PFNGLDRAWELEMENTARRAYAPPLEPROC __glewDrawElementArrayAPPLE = NULL; -PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC __glewDrawRangeElementArrayAPPLE = NULL; -PFNGLELEMENTPOINTERAPPLEPROC __glewElementPointerAPPLE = NULL; -PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC __glewMultiDrawElementArrayAPPLE = NULL; -PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC __glewMultiDrawRangeElementArrayAPPLE = NULL; - -PFNGLDELETEFENCESAPPLEPROC __glewDeleteFencesAPPLE = NULL; -PFNGLFINISHFENCEAPPLEPROC __glewFinishFenceAPPLE = NULL; -PFNGLFINISHOBJECTAPPLEPROC __glewFinishObjectAPPLE = NULL; -PFNGLGENFENCESAPPLEPROC __glewGenFencesAPPLE = NULL; -PFNGLISFENCEAPPLEPROC __glewIsFenceAPPLE = NULL; -PFNGLSETFENCEAPPLEPROC __glewSetFenceAPPLE = NULL; -PFNGLTESTFENCEAPPLEPROC __glewTestFenceAPPLE = NULL; -PFNGLTESTOBJECTAPPLEPROC __glewTestObjectAPPLE = NULL; - -PFNGLBUFFERPARAMETERIAPPLEPROC __glewBufferParameteriAPPLE = NULL; -PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC __glewFlushMappedBufferRangeAPPLE = NULL; - -PFNGLGETOBJECTPARAMETERIVAPPLEPROC __glewGetObjectParameterivAPPLE = NULL; -PFNGLOBJECTPURGEABLEAPPLEPROC __glewObjectPurgeableAPPLE = NULL; -PFNGLOBJECTUNPURGEABLEAPPLEPROC __glewObjectUnpurgeableAPPLE = NULL; - -PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC __glewGetTexParameterPointervAPPLE = NULL; -PFNGLTEXTURERANGEAPPLEPROC __glewTextureRangeAPPLE = NULL; - -PFNGLBINDVERTEXARRAYAPPLEPROC __glewBindVertexArrayAPPLE = NULL; -PFNGLDELETEVERTEXARRAYSAPPLEPROC __glewDeleteVertexArraysAPPLE = NULL; -PFNGLGENVERTEXARRAYSAPPLEPROC __glewGenVertexArraysAPPLE = NULL; -PFNGLISVERTEXARRAYAPPLEPROC __glewIsVertexArrayAPPLE = NULL; - -PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC __glewFlushVertexArrayRangeAPPLE = NULL; -PFNGLVERTEXARRAYPARAMETERIAPPLEPROC __glewVertexArrayParameteriAPPLE = NULL; -PFNGLVERTEXARRAYRANGEAPPLEPROC __glewVertexArrayRangeAPPLE = NULL; - -PFNGLDISABLEVERTEXATTRIBAPPLEPROC __glewDisableVertexAttribAPPLE = NULL; -PFNGLENABLEVERTEXATTRIBAPPLEPROC __glewEnableVertexAttribAPPLE = NULL; -PFNGLISVERTEXATTRIBENABLEDAPPLEPROC __glewIsVertexAttribEnabledAPPLE = NULL; -PFNGLMAPVERTEXATTRIB1DAPPLEPROC __glewMapVertexAttrib1dAPPLE = NULL; -PFNGLMAPVERTEXATTRIB1FAPPLEPROC __glewMapVertexAttrib1fAPPLE = NULL; -PFNGLMAPVERTEXATTRIB2DAPPLEPROC __glewMapVertexAttrib2dAPPLE = NULL; -PFNGLMAPVERTEXATTRIB2FAPPLEPROC __glewMapVertexAttrib2fAPPLE = NULL; - -PFNGLCLEARDEPTHFPROC __glewClearDepthf = NULL; -PFNGLDEPTHRANGEFPROC __glewDepthRangef = NULL; -PFNGLGETSHADERPRECISIONFORMATPROC __glewGetShaderPrecisionFormat = NULL; -PFNGLRELEASESHADERCOMPILERPROC __glewReleaseShaderCompiler = NULL; -PFNGLSHADERBINARYPROC __glewShaderBinary = NULL; - -PFNGLDRAWARRAYSINSTANCEDBASEINSTANCEPROC __glewDrawArraysInstancedBaseInstance = NULL; -PFNGLDRAWELEMENTSINSTANCEDBASEINSTANCEPROC __glewDrawElementsInstancedBaseInstance = NULL; -PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXBASEINSTANCEPROC __glewDrawElementsInstancedBaseVertexBaseInstance = NULL; - -PFNGLGETIMAGEHANDLEARBPROC __glewGetImageHandleARB = NULL; -PFNGLGETTEXTUREHANDLEARBPROC __glewGetTextureHandleARB = NULL; -PFNGLGETTEXTURESAMPLERHANDLEARBPROC __glewGetTextureSamplerHandleARB = NULL; -PFNGLGETVERTEXATTRIBLUI64VARBPROC __glewGetVertexAttribLui64vARB = NULL; -PFNGLISIMAGEHANDLERESIDENTARBPROC __glewIsImageHandleResidentARB = NULL; -PFNGLISTEXTUREHANDLERESIDENTARBPROC __glewIsTextureHandleResidentARB = NULL; -PFNGLMAKEIMAGEHANDLENONRESIDENTARBPROC __glewMakeImageHandleNonResidentARB = NULL; -PFNGLMAKEIMAGEHANDLERESIDENTARBPROC __glewMakeImageHandleResidentARB = NULL; -PFNGLMAKETEXTUREHANDLENONRESIDENTARBPROC __glewMakeTextureHandleNonResidentARB = NULL; -PFNGLMAKETEXTUREHANDLERESIDENTARBPROC __glewMakeTextureHandleResidentARB = NULL; -PFNGLPROGRAMUNIFORMHANDLEUI64ARBPROC __glewProgramUniformHandleui64ARB = NULL; -PFNGLPROGRAMUNIFORMHANDLEUI64VARBPROC __glewProgramUniformHandleui64vARB = NULL; -PFNGLUNIFORMHANDLEUI64ARBPROC __glewUniformHandleui64ARB = NULL; -PFNGLUNIFORMHANDLEUI64VARBPROC __glewUniformHandleui64vARB = NULL; -PFNGLVERTEXATTRIBL1UI64ARBPROC __glewVertexAttribL1ui64ARB = NULL; -PFNGLVERTEXATTRIBL1UI64VARBPROC __glewVertexAttribL1ui64vARB = NULL; - -PFNGLBINDFRAGDATALOCATIONINDEXEDPROC __glewBindFragDataLocationIndexed = NULL; -PFNGLGETFRAGDATAINDEXPROC __glewGetFragDataIndex = NULL; - -PFNGLBUFFERSTORAGEPROC __glewBufferStorage = NULL; -PFNGLNAMEDBUFFERSTORAGEEXTPROC __glewNamedBufferStorageEXT = NULL; - -PFNGLCREATESYNCFROMCLEVENTARBPROC __glewCreateSyncFromCLeventARB = NULL; - -PFNGLCLEARBUFFERDATAPROC __glewClearBufferData = NULL; -PFNGLCLEARBUFFERSUBDATAPROC __glewClearBufferSubData = NULL; -PFNGLCLEARNAMEDBUFFERDATAEXTPROC __glewClearNamedBufferDataEXT = NULL; -PFNGLCLEARNAMEDBUFFERSUBDATAEXTPROC __glewClearNamedBufferSubDataEXT = NULL; - -PFNGLCLEARTEXIMAGEPROC __glewClearTexImage = NULL; -PFNGLCLEARTEXSUBIMAGEPROC __glewClearTexSubImage = NULL; - -PFNGLCLAMPCOLORARBPROC __glewClampColorARB = NULL; - -PFNGLDISPATCHCOMPUTEPROC __glewDispatchCompute = NULL; -PFNGLDISPATCHCOMPUTEINDIRECTPROC __glewDispatchComputeIndirect = NULL; - -PFNGLDISPATCHCOMPUTEGROUPSIZEARBPROC __glewDispatchComputeGroupSizeARB = NULL; - -PFNGLCOPYBUFFERSUBDATAPROC __glewCopyBufferSubData = NULL; - -PFNGLCOPYIMAGESUBDATAPROC __glewCopyImageSubData = NULL; - -PFNGLDEBUGMESSAGECALLBACKARBPROC __glewDebugMessageCallbackARB = NULL; -PFNGLDEBUGMESSAGECONTROLARBPROC __glewDebugMessageControlARB = NULL; -PFNGLDEBUGMESSAGEINSERTARBPROC __glewDebugMessageInsertARB = NULL; -PFNGLGETDEBUGMESSAGELOGARBPROC __glewGetDebugMessageLogARB = NULL; - -PFNGLDRAWBUFFERSARBPROC __glewDrawBuffersARB = NULL; - -PFNGLBLENDEQUATIONSEPARATEIARBPROC __glewBlendEquationSeparateiARB = NULL; -PFNGLBLENDEQUATIONIARBPROC __glewBlendEquationiARB = NULL; -PFNGLBLENDFUNCSEPARATEIARBPROC __glewBlendFuncSeparateiARB = NULL; -PFNGLBLENDFUNCIARBPROC __glewBlendFunciARB = NULL; - -PFNGLDRAWELEMENTSBASEVERTEXPROC __glewDrawElementsBaseVertex = NULL; -PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC __glewDrawElementsInstancedBaseVertex = NULL; -PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC __glewDrawRangeElementsBaseVertex = NULL; -PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC __glewMultiDrawElementsBaseVertex = NULL; - -PFNGLDRAWARRAYSINDIRECTPROC __glewDrawArraysIndirect = NULL; -PFNGLDRAWELEMENTSINDIRECTPROC __glewDrawElementsIndirect = NULL; - -PFNGLFRAMEBUFFERPARAMETERIPROC __glewFramebufferParameteri = NULL; -PFNGLGETFRAMEBUFFERPARAMETERIVPROC __glewGetFramebufferParameteriv = NULL; -PFNGLGETNAMEDFRAMEBUFFERPARAMETERIVEXTPROC __glewGetNamedFramebufferParameterivEXT = NULL; -PFNGLNAMEDFRAMEBUFFERPARAMETERIEXTPROC __glewNamedFramebufferParameteriEXT = NULL; - -PFNGLBINDFRAMEBUFFERPROC __glewBindFramebuffer = NULL; -PFNGLBINDRENDERBUFFERPROC __glewBindRenderbuffer = NULL; -PFNGLBLITFRAMEBUFFERPROC __glewBlitFramebuffer = NULL; -PFNGLCHECKFRAMEBUFFERSTATUSPROC __glewCheckFramebufferStatus = NULL; -PFNGLDELETEFRAMEBUFFERSPROC __glewDeleteFramebuffers = NULL; -PFNGLDELETERENDERBUFFERSPROC __glewDeleteRenderbuffers = NULL; -PFNGLFRAMEBUFFERRENDERBUFFERPROC __glewFramebufferRenderbuffer = NULL; -PFNGLFRAMEBUFFERTEXTURE1DPROC __glewFramebufferTexture1D = NULL; -PFNGLFRAMEBUFFERTEXTURE2DPROC __glewFramebufferTexture2D = NULL; -PFNGLFRAMEBUFFERTEXTURE3DPROC __glewFramebufferTexture3D = NULL; -PFNGLFRAMEBUFFERTEXTURELAYERPROC __glewFramebufferTextureLayer = NULL; -PFNGLGENFRAMEBUFFERSPROC __glewGenFramebuffers = NULL; -PFNGLGENRENDERBUFFERSPROC __glewGenRenderbuffers = NULL; -PFNGLGENERATEMIPMAPPROC __glewGenerateMipmap = NULL; -PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC __glewGetFramebufferAttachmentParameteriv = NULL; -PFNGLGETRENDERBUFFERPARAMETERIVPROC __glewGetRenderbufferParameteriv = NULL; -PFNGLISFRAMEBUFFERPROC __glewIsFramebuffer = NULL; -PFNGLISRENDERBUFFERPROC __glewIsRenderbuffer = NULL; -PFNGLRENDERBUFFERSTORAGEPROC __glewRenderbufferStorage = NULL; -PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC __glewRenderbufferStorageMultisample = NULL; - -PFNGLFRAMEBUFFERTEXTUREARBPROC __glewFramebufferTextureARB = NULL; -PFNGLFRAMEBUFFERTEXTUREFACEARBPROC __glewFramebufferTextureFaceARB = NULL; -PFNGLFRAMEBUFFERTEXTURELAYERARBPROC __glewFramebufferTextureLayerARB = NULL; -PFNGLPROGRAMPARAMETERIARBPROC __glewProgramParameteriARB = NULL; - -PFNGLGETPROGRAMBINARYPROC __glewGetProgramBinary = NULL; -PFNGLPROGRAMBINARYPROC __glewProgramBinary = NULL; -PFNGLPROGRAMPARAMETERIPROC __glewProgramParameteri = NULL; - -PFNGLGETUNIFORMDVPROC __glewGetUniformdv = NULL; -PFNGLUNIFORM1DPROC __glewUniform1d = NULL; -PFNGLUNIFORM1DVPROC __glewUniform1dv = NULL; -PFNGLUNIFORM2DPROC __glewUniform2d = NULL; -PFNGLUNIFORM2DVPROC __glewUniform2dv = NULL; -PFNGLUNIFORM3DPROC __glewUniform3d = NULL; -PFNGLUNIFORM3DVPROC __glewUniform3dv = NULL; -PFNGLUNIFORM4DPROC __glewUniform4d = NULL; -PFNGLUNIFORM4DVPROC __glewUniform4dv = NULL; -PFNGLUNIFORMMATRIX2DVPROC __glewUniformMatrix2dv = NULL; -PFNGLUNIFORMMATRIX2X3DVPROC __glewUniformMatrix2x3dv = NULL; -PFNGLUNIFORMMATRIX2X4DVPROC __glewUniformMatrix2x4dv = NULL; -PFNGLUNIFORMMATRIX3DVPROC __glewUniformMatrix3dv = NULL; -PFNGLUNIFORMMATRIX3X2DVPROC __glewUniformMatrix3x2dv = NULL; -PFNGLUNIFORMMATRIX3X4DVPROC __glewUniformMatrix3x4dv = NULL; -PFNGLUNIFORMMATRIX4DVPROC __glewUniformMatrix4dv = NULL; -PFNGLUNIFORMMATRIX4X2DVPROC __glewUniformMatrix4x2dv = NULL; -PFNGLUNIFORMMATRIX4X3DVPROC __glewUniformMatrix4x3dv = NULL; - -PFNGLCOLORSUBTABLEPROC __glewColorSubTable = NULL; -PFNGLCOLORTABLEPROC __glewColorTable = NULL; -PFNGLCOLORTABLEPARAMETERFVPROC __glewColorTableParameterfv = NULL; -PFNGLCOLORTABLEPARAMETERIVPROC __glewColorTableParameteriv = NULL; -PFNGLCONVOLUTIONFILTER1DPROC __glewConvolutionFilter1D = NULL; -PFNGLCONVOLUTIONFILTER2DPROC __glewConvolutionFilter2D = NULL; -PFNGLCONVOLUTIONPARAMETERFPROC __glewConvolutionParameterf = NULL; -PFNGLCONVOLUTIONPARAMETERFVPROC __glewConvolutionParameterfv = NULL; -PFNGLCONVOLUTIONPARAMETERIPROC __glewConvolutionParameteri = NULL; -PFNGLCONVOLUTIONPARAMETERIVPROC __glewConvolutionParameteriv = NULL; -PFNGLCOPYCOLORSUBTABLEPROC __glewCopyColorSubTable = NULL; -PFNGLCOPYCOLORTABLEPROC __glewCopyColorTable = NULL; -PFNGLCOPYCONVOLUTIONFILTER1DPROC __glewCopyConvolutionFilter1D = NULL; -PFNGLCOPYCONVOLUTIONFILTER2DPROC __glewCopyConvolutionFilter2D = NULL; -PFNGLGETCOLORTABLEPROC __glewGetColorTable = NULL; -PFNGLGETCOLORTABLEPARAMETERFVPROC __glewGetColorTableParameterfv = NULL; -PFNGLGETCOLORTABLEPARAMETERIVPROC __glewGetColorTableParameteriv = NULL; -PFNGLGETCONVOLUTIONFILTERPROC __glewGetConvolutionFilter = NULL; -PFNGLGETCONVOLUTIONPARAMETERFVPROC __glewGetConvolutionParameterfv = NULL; -PFNGLGETCONVOLUTIONPARAMETERIVPROC __glewGetConvolutionParameteriv = NULL; -PFNGLGETHISTOGRAMPROC __glewGetHistogram = NULL; -PFNGLGETHISTOGRAMPARAMETERFVPROC __glewGetHistogramParameterfv = NULL; -PFNGLGETHISTOGRAMPARAMETERIVPROC __glewGetHistogramParameteriv = NULL; -PFNGLGETMINMAXPROC __glewGetMinmax = NULL; -PFNGLGETMINMAXPARAMETERFVPROC __glewGetMinmaxParameterfv = NULL; -PFNGLGETMINMAXPARAMETERIVPROC __glewGetMinmaxParameteriv = NULL; -PFNGLGETSEPARABLEFILTERPROC __glewGetSeparableFilter = NULL; -PFNGLHISTOGRAMPROC __glewHistogram = NULL; -PFNGLMINMAXPROC __glewMinmax = NULL; -PFNGLRESETHISTOGRAMPROC __glewResetHistogram = NULL; -PFNGLRESETMINMAXPROC __glewResetMinmax = NULL; -PFNGLSEPARABLEFILTER2DPROC __glewSeparableFilter2D = NULL; - -PFNGLMULTIDRAWARRAYSINDIRECTCOUNTARBPROC __glewMultiDrawArraysIndirectCountARB = NULL; -PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTARBPROC __glewMultiDrawElementsIndirectCountARB = NULL; - -PFNGLDRAWARRAYSINSTANCEDARBPROC __glewDrawArraysInstancedARB = NULL; -PFNGLDRAWELEMENTSINSTANCEDARBPROC __glewDrawElementsInstancedARB = NULL; -PFNGLVERTEXATTRIBDIVISORARBPROC __glewVertexAttribDivisorARB = NULL; - -PFNGLGETINTERNALFORMATIVPROC __glewGetInternalformativ = NULL; - -PFNGLGETINTERNALFORMATI64VPROC __glewGetInternalformati64v = NULL; - -PFNGLINVALIDATEBUFFERDATAPROC __glewInvalidateBufferData = NULL; -PFNGLINVALIDATEBUFFERSUBDATAPROC __glewInvalidateBufferSubData = NULL; -PFNGLINVALIDATEFRAMEBUFFERPROC __glewInvalidateFramebuffer = NULL; -PFNGLINVALIDATESUBFRAMEBUFFERPROC __glewInvalidateSubFramebuffer = NULL; -PFNGLINVALIDATETEXIMAGEPROC __glewInvalidateTexImage = NULL; -PFNGLINVALIDATETEXSUBIMAGEPROC __glewInvalidateTexSubImage = NULL; - -PFNGLFLUSHMAPPEDBUFFERRANGEPROC __glewFlushMappedBufferRange = NULL; -PFNGLMAPBUFFERRANGEPROC __glewMapBufferRange = NULL; - -PFNGLCURRENTPALETTEMATRIXARBPROC __glewCurrentPaletteMatrixARB = NULL; -PFNGLMATRIXINDEXPOINTERARBPROC __glewMatrixIndexPointerARB = NULL; -PFNGLMATRIXINDEXUBVARBPROC __glewMatrixIndexubvARB = NULL; -PFNGLMATRIXINDEXUIVARBPROC __glewMatrixIndexuivARB = NULL; -PFNGLMATRIXINDEXUSVARBPROC __glewMatrixIndexusvARB = NULL; - -PFNGLBINDBUFFERSBASEPROC __glewBindBuffersBase = NULL; -PFNGLBINDBUFFERSRANGEPROC __glewBindBuffersRange = NULL; -PFNGLBINDIMAGETEXTURESPROC __glewBindImageTextures = NULL; -PFNGLBINDSAMPLERSPROC __glewBindSamplers = NULL; -PFNGLBINDTEXTURESPROC __glewBindTextures = NULL; -PFNGLBINDVERTEXBUFFERSPROC __glewBindVertexBuffers = NULL; - -PFNGLMULTIDRAWARRAYSINDIRECTPROC __glewMultiDrawArraysIndirect = NULL; -PFNGLMULTIDRAWELEMENTSINDIRECTPROC __glewMultiDrawElementsIndirect = NULL; - -PFNGLSAMPLECOVERAGEARBPROC __glewSampleCoverageARB = NULL; - -PFNGLACTIVETEXTUREARBPROC __glewActiveTextureARB = NULL; -PFNGLCLIENTACTIVETEXTUREARBPROC __glewClientActiveTextureARB = NULL; -PFNGLMULTITEXCOORD1DARBPROC __glewMultiTexCoord1dARB = NULL; -PFNGLMULTITEXCOORD1DVARBPROC __glewMultiTexCoord1dvARB = NULL; -PFNGLMULTITEXCOORD1FARBPROC __glewMultiTexCoord1fARB = NULL; -PFNGLMULTITEXCOORD1FVARBPROC __glewMultiTexCoord1fvARB = NULL; -PFNGLMULTITEXCOORD1IARBPROC __glewMultiTexCoord1iARB = NULL; -PFNGLMULTITEXCOORD1IVARBPROC __glewMultiTexCoord1ivARB = NULL; -PFNGLMULTITEXCOORD1SARBPROC __glewMultiTexCoord1sARB = NULL; -PFNGLMULTITEXCOORD1SVARBPROC __glewMultiTexCoord1svARB = NULL; -PFNGLMULTITEXCOORD2DARBPROC __glewMultiTexCoord2dARB = NULL; -PFNGLMULTITEXCOORD2DVARBPROC __glewMultiTexCoord2dvARB = NULL; -PFNGLMULTITEXCOORD2FARBPROC __glewMultiTexCoord2fARB = NULL; -PFNGLMULTITEXCOORD2FVARBPROC __glewMultiTexCoord2fvARB = NULL; -PFNGLMULTITEXCOORD2IARBPROC __glewMultiTexCoord2iARB = NULL; -PFNGLMULTITEXCOORD2IVARBPROC __glewMultiTexCoord2ivARB = NULL; -PFNGLMULTITEXCOORD2SARBPROC __glewMultiTexCoord2sARB = NULL; -PFNGLMULTITEXCOORD2SVARBPROC __glewMultiTexCoord2svARB = NULL; -PFNGLMULTITEXCOORD3DARBPROC __glewMultiTexCoord3dARB = NULL; -PFNGLMULTITEXCOORD3DVARBPROC __glewMultiTexCoord3dvARB = NULL; -PFNGLMULTITEXCOORD3FARBPROC __glewMultiTexCoord3fARB = NULL; -PFNGLMULTITEXCOORD3FVARBPROC __glewMultiTexCoord3fvARB = NULL; -PFNGLMULTITEXCOORD3IARBPROC __glewMultiTexCoord3iARB = NULL; -PFNGLMULTITEXCOORD3IVARBPROC __glewMultiTexCoord3ivARB = NULL; -PFNGLMULTITEXCOORD3SARBPROC __glewMultiTexCoord3sARB = NULL; -PFNGLMULTITEXCOORD3SVARBPROC __glewMultiTexCoord3svARB = NULL; -PFNGLMULTITEXCOORD4DARBPROC __glewMultiTexCoord4dARB = NULL; -PFNGLMULTITEXCOORD4DVARBPROC __glewMultiTexCoord4dvARB = NULL; -PFNGLMULTITEXCOORD4FARBPROC __glewMultiTexCoord4fARB = NULL; -PFNGLMULTITEXCOORD4FVARBPROC __glewMultiTexCoord4fvARB = NULL; -PFNGLMULTITEXCOORD4IARBPROC __glewMultiTexCoord4iARB = NULL; -PFNGLMULTITEXCOORD4IVARBPROC __glewMultiTexCoord4ivARB = NULL; -PFNGLMULTITEXCOORD4SARBPROC __glewMultiTexCoord4sARB = NULL; -PFNGLMULTITEXCOORD4SVARBPROC __glewMultiTexCoord4svARB = NULL; - -PFNGLBEGINQUERYARBPROC __glewBeginQueryARB = NULL; -PFNGLDELETEQUERIESARBPROC __glewDeleteQueriesARB = NULL; -PFNGLENDQUERYARBPROC __glewEndQueryARB = NULL; -PFNGLGENQUERIESARBPROC __glewGenQueriesARB = NULL; -PFNGLGETQUERYOBJECTIVARBPROC __glewGetQueryObjectivARB = NULL; -PFNGLGETQUERYOBJECTUIVARBPROC __glewGetQueryObjectuivARB = NULL; -PFNGLGETQUERYIVARBPROC __glewGetQueryivARB = NULL; -PFNGLISQUERYARBPROC __glewIsQueryARB = NULL; - -PFNGLPOINTPARAMETERFARBPROC __glewPointParameterfARB = NULL; -PFNGLPOINTPARAMETERFVARBPROC __glewPointParameterfvARB = NULL; - -PFNGLGETPROGRAMINTERFACEIVPROC __glewGetProgramInterfaceiv = NULL; -PFNGLGETPROGRAMRESOURCEINDEXPROC __glewGetProgramResourceIndex = NULL; -PFNGLGETPROGRAMRESOURCELOCATIONPROC __glewGetProgramResourceLocation = NULL; -PFNGLGETPROGRAMRESOURCELOCATIONINDEXPROC __glewGetProgramResourceLocationIndex = NULL; -PFNGLGETPROGRAMRESOURCENAMEPROC __glewGetProgramResourceName = NULL; -PFNGLGETPROGRAMRESOURCEIVPROC __glewGetProgramResourceiv = NULL; - -PFNGLPROVOKINGVERTEXPROC __glewProvokingVertex = NULL; - -PFNGLGETGRAPHICSRESETSTATUSARBPROC __glewGetGraphicsResetStatusARB = NULL; -PFNGLGETNCOLORTABLEARBPROC __glewGetnColorTableARB = NULL; -PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC __glewGetnCompressedTexImageARB = NULL; -PFNGLGETNCONVOLUTIONFILTERARBPROC __glewGetnConvolutionFilterARB = NULL; -PFNGLGETNHISTOGRAMARBPROC __glewGetnHistogramARB = NULL; -PFNGLGETNMAPDVARBPROC __glewGetnMapdvARB = NULL; -PFNGLGETNMAPFVARBPROC __glewGetnMapfvARB = NULL; -PFNGLGETNMAPIVARBPROC __glewGetnMapivARB = NULL; -PFNGLGETNMINMAXARBPROC __glewGetnMinmaxARB = NULL; -PFNGLGETNPIXELMAPFVARBPROC __glewGetnPixelMapfvARB = NULL; -PFNGLGETNPIXELMAPUIVARBPROC __glewGetnPixelMapuivARB = NULL; -PFNGLGETNPIXELMAPUSVARBPROC __glewGetnPixelMapusvARB = NULL; -PFNGLGETNPOLYGONSTIPPLEARBPROC __glewGetnPolygonStippleARB = NULL; -PFNGLGETNSEPARABLEFILTERARBPROC __glewGetnSeparableFilterARB = NULL; -PFNGLGETNTEXIMAGEARBPROC __glewGetnTexImageARB = NULL; -PFNGLGETNUNIFORMDVARBPROC __glewGetnUniformdvARB = NULL; -PFNGLGETNUNIFORMFVARBPROC __glewGetnUniformfvARB = NULL; -PFNGLGETNUNIFORMIVARBPROC __glewGetnUniformivARB = NULL; -PFNGLGETNUNIFORMUIVARBPROC __glewGetnUniformuivARB = NULL; -PFNGLREADNPIXELSARBPROC __glewReadnPixelsARB = NULL; - -PFNGLMINSAMPLESHADINGARBPROC __glewMinSampleShadingARB = NULL; - -PFNGLBINDSAMPLERPROC __glewBindSampler = NULL; -PFNGLDELETESAMPLERSPROC __glewDeleteSamplers = NULL; -PFNGLGENSAMPLERSPROC __glewGenSamplers = NULL; -PFNGLGETSAMPLERPARAMETERIIVPROC __glewGetSamplerParameterIiv = NULL; -PFNGLGETSAMPLERPARAMETERIUIVPROC __glewGetSamplerParameterIuiv = NULL; -PFNGLGETSAMPLERPARAMETERFVPROC __glewGetSamplerParameterfv = NULL; -PFNGLGETSAMPLERPARAMETERIVPROC __glewGetSamplerParameteriv = NULL; -PFNGLISSAMPLERPROC __glewIsSampler = NULL; -PFNGLSAMPLERPARAMETERIIVPROC __glewSamplerParameterIiv = NULL; -PFNGLSAMPLERPARAMETERIUIVPROC __glewSamplerParameterIuiv = NULL; -PFNGLSAMPLERPARAMETERFPROC __glewSamplerParameterf = NULL; -PFNGLSAMPLERPARAMETERFVPROC __glewSamplerParameterfv = NULL; -PFNGLSAMPLERPARAMETERIPROC __glewSamplerParameteri = NULL; -PFNGLSAMPLERPARAMETERIVPROC __glewSamplerParameteriv = NULL; - -PFNGLACTIVESHADERPROGRAMPROC __glewActiveShaderProgram = NULL; -PFNGLBINDPROGRAMPIPELINEPROC __glewBindProgramPipeline = NULL; -PFNGLCREATESHADERPROGRAMVPROC __glewCreateShaderProgramv = NULL; -PFNGLDELETEPROGRAMPIPELINESPROC __glewDeleteProgramPipelines = NULL; -PFNGLGENPROGRAMPIPELINESPROC __glewGenProgramPipelines = NULL; -PFNGLGETPROGRAMPIPELINEINFOLOGPROC __glewGetProgramPipelineInfoLog = NULL; -PFNGLGETPROGRAMPIPELINEIVPROC __glewGetProgramPipelineiv = NULL; -PFNGLISPROGRAMPIPELINEPROC __glewIsProgramPipeline = NULL; -PFNGLPROGRAMUNIFORM1DPROC __glewProgramUniform1d = NULL; -PFNGLPROGRAMUNIFORM1DVPROC __glewProgramUniform1dv = NULL; -PFNGLPROGRAMUNIFORM1FPROC __glewProgramUniform1f = NULL; -PFNGLPROGRAMUNIFORM1FVPROC __glewProgramUniform1fv = NULL; -PFNGLPROGRAMUNIFORM1IPROC __glewProgramUniform1i = NULL; -PFNGLPROGRAMUNIFORM1IVPROC __glewProgramUniform1iv = NULL; -PFNGLPROGRAMUNIFORM1UIPROC __glewProgramUniform1ui = NULL; -PFNGLPROGRAMUNIFORM1UIVPROC __glewProgramUniform1uiv = NULL; -PFNGLPROGRAMUNIFORM2DPROC __glewProgramUniform2d = NULL; -PFNGLPROGRAMUNIFORM2DVPROC __glewProgramUniform2dv = NULL; -PFNGLPROGRAMUNIFORM2FPROC __glewProgramUniform2f = NULL; -PFNGLPROGRAMUNIFORM2FVPROC __glewProgramUniform2fv = NULL; -PFNGLPROGRAMUNIFORM2IPROC __glewProgramUniform2i = NULL; -PFNGLPROGRAMUNIFORM2IVPROC __glewProgramUniform2iv = NULL; -PFNGLPROGRAMUNIFORM2UIPROC __glewProgramUniform2ui = NULL; -PFNGLPROGRAMUNIFORM2UIVPROC __glewProgramUniform2uiv = NULL; -PFNGLPROGRAMUNIFORM3DPROC __glewProgramUniform3d = NULL; -PFNGLPROGRAMUNIFORM3DVPROC __glewProgramUniform3dv = NULL; -PFNGLPROGRAMUNIFORM3FPROC __glewProgramUniform3f = NULL; -PFNGLPROGRAMUNIFORM3FVPROC __glewProgramUniform3fv = NULL; -PFNGLPROGRAMUNIFORM3IPROC __glewProgramUniform3i = NULL; -PFNGLPROGRAMUNIFORM3IVPROC __glewProgramUniform3iv = NULL; -PFNGLPROGRAMUNIFORM3UIPROC __glewProgramUniform3ui = NULL; -PFNGLPROGRAMUNIFORM3UIVPROC __glewProgramUniform3uiv = NULL; -PFNGLPROGRAMUNIFORM4DPROC __glewProgramUniform4d = NULL; -PFNGLPROGRAMUNIFORM4DVPROC __glewProgramUniform4dv = NULL; -PFNGLPROGRAMUNIFORM4FPROC __glewProgramUniform4f = NULL; -PFNGLPROGRAMUNIFORM4FVPROC __glewProgramUniform4fv = NULL; -PFNGLPROGRAMUNIFORM4IPROC __glewProgramUniform4i = NULL; -PFNGLPROGRAMUNIFORM4IVPROC __glewProgramUniform4iv = NULL; -PFNGLPROGRAMUNIFORM4UIPROC __glewProgramUniform4ui = NULL; -PFNGLPROGRAMUNIFORM4UIVPROC __glewProgramUniform4uiv = NULL; -PFNGLPROGRAMUNIFORMMATRIX2DVPROC __glewProgramUniformMatrix2dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX2FVPROC __glewProgramUniformMatrix2fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC __glewProgramUniformMatrix2x3dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC __glewProgramUniformMatrix2x3fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC __glewProgramUniformMatrix2x4dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC __glewProgramUniformMatrix2x4fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX3DVPROC __glewProgramUniformMatrix3dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX3FVPROC __glewProgramUniformMatrix3fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC __glewProgramUniformMatrix3x2dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC __glewProgramUniformMatrix3x2fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC __glewProgramUniformMatrix3x4dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC __glewProgramUniformMatrix3x4fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX4DVPROC __glewProgramUniformMatrix4dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX4FVPROC __glewProgramUniformMatrix4fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC __glewProgramUniformMatrix4x2dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC __glewProgramUniformMatrix4x2fv = NULL; -PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC __glewProgramUniformMatrix4x3dv = NULL; -PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC __glewProgramUniformMatrix4x3fv = NULL; -PFNGLUSEPROGRAMSTAGESPROC __glewUseProgramStages = NULL; -PFNGLVALIDATEPROGRAMPIPELINEPROC __glewValidateProgramPipeline = NULL; - -PFNGLGETACTIVEATOMICCOUNTERBUFFERIVPROC __glewGetActiveAtomicCounterBufferiv = NULL; - -PFNGLBINDIMAGETEXTUREPROC __glewBindImageTexture = NULL; -PFNGLMEMORYBARRIERPROC __glewMemoryBarrier = NULL; - -PFNGLATTACHOBJECTARBPROC __glewAttachObjectARB = NULL; -PFNGLCOMPILESHADERARBPROC __glewCompileShaderARB = NULL; -PFNGLCREATEPROGRAMOBJECTARBPROC __glewCreateProgramObjectARB = NULL; -PFNGLCREATESHADEROBJECTARBPROC __glewCreateShaderObjectARB = NULL; -PFNGLDELETEOBJECTARBPROC __glewDeleteObjectARB = NULL; -PFNGLDETACHOBJECTARBPROC __glewDetachObjectARB = NULL; -PFNGLGETACTIVEUNIFORMARBPROC __glewGetActiveUniformARB = NULL; -PFNGLGETATTACHEDOBJECTSARBPROC __glewGetAttachedObjectsARB = NULL; -PFNGLGETHANDLEARBPROC __glewGetHandleARB = NULL; -PFNGLGETINFOLOGARBPROC __glewGetInfoLogARB = NULL; -PFNGLGETOBJECTPARAMETERFVARBPROC __glewGetObjectParameterfvARB = NULL; -PFNGLGETOBJECTPARAMETERIVARBPROC __glewGetObjectParameterivARB = NULL; -PFNGLGETSHADERSOURCEARBPROC __glewGetShaderSourceARB = NULL; -PFNGLGETUNIFORMLOCATIONARBPROC __glewGetUniformLocationARB = NULL; -PFNGLGETUNIFORMFVARBPROC __glewGetUniformfvARB = NULL; -PFNGLGETUNIFORMIVARBPROC __glewGetUniformivARB = NULL; -PFNGLLINKPROGRAMARBPROC __glewLinkProgramARB = NULL; -PFNGLSHADERSOURCEARBPROC __glewShaderSourceARB = NULL; -PFNGLUNIFORM1FARBPROC __glewUniform1fARB = NULL; -PFNGLUNIFORM1FVARBPROC __glewUniform1fvARB = NULL; -PFNGLUNIFORM1IARBPROC __glewUniform1iARB = NULL; -PFNGLUNIFORM1IVARBPROC __glewUniform1ivARB = NULL; -PFNGLUNIFORM2FARBPROC __glewUniform2fARB = NULL; -PFNGLUNIFORM2FVARBPROC __glewUniform2fvARB = NULL; -PFNGLUNIFORM2IARBPROC __glewUniform2iARB = NULL; -PFNGLUNIFORM2IVARBPROC __glewUniform2ivARB = NULL; -PFNGLUNIFORM3FARBPROC __glewUniform3fARB = NULL; -PFNGLUNIFORM3FVARBPROC __glewUniform3fvARB = NULL; -PFNGLUNIFORM3IARBPROC __glewUniform3iARB = NULL; -PFNGLUNIFORM3IVARBPROC __glewUniform3ivARB = NULL; -PFNGLUNIFORM4FARBPROC __glewUniform4fARB = NULL; -PFNGLUNIFORM4FVARBPROC __glewUniform4fvARB = NULL; -PFNGLUNIFORM4IARBPROC __glewUniform4iARB = NULL; -PFNGLUNIFORM4IVARBPROC __glewUniform4ivARB = NULL; -PFNGLUNIFORMMATRIX2FVARBPROC __glewUniformMatrix2fvARB = NULL; -PFNGLUNIFORMMATRIX3FVARBPROC __glewUniformMatrix3fvARB = NULL; -PFNGLUNIFORMMATRIX4FVARBPROC __glewUniformMatrix4fvARB = NULL; -PFNGLUSEPROGRAMOBJECTARBPROC __glewUseProgramObjectARB = NULL; -PFNGLVALIDATEPROGRAMARBPROC __glewValidateProgramARB = NULL; - -PFNGLSHADERSTORAGEBLOCKBINDINGPROC __glewShaderStorageBlockBinding = NULL; - -PFNGLGETACTIVESUBROUTINENAMEPROC __glewGetActiveSubroutineName = NULL; -PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC __glewGetActiveSubroutineUniformName = NULL; -PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC __glewGetActiveSubroutineUniformiv = NULL; -PFNGLGETPROGRAMSTAGEIVPROC __glewGetProgramStageiv = NULL; -PFNGLGETSUBROUTINEINDEXPROC __glewGetSubroutineIndex = NULL; -PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC __glewGetSubroutineUniformLocation = NULL; -PFNGLGETUNIFORMSUBROUTINEUIVPROC __glewGetUniformSubroutineuiv = NULL; -PFNGLUNIFORMSUBROUTINESUIVPROC __glewUniformSubroutinesuiv = NULL; - -PFNGLCOMPILESHADERINCLUDEARBPROC __glewCompileShaderIncludeARB = NULL; -PFNGLDELETENAMEDSTRINGARBPROC __glewDeleteNamedStringARB = NULL; -PFNGLGETNAMEDSTRINGARBPROC __glewGetNamedStringARB = NULL; -PFNGLGETNAMEDSTRINGIVARBPROC __glewGetNamedStringivARB = NULL; -PFNGLISNAMEDSTRINGARBPROC __glewIsNamedStringARB = NULL; -PFNGLNAMEDSTRINGARBPROC __glewNamedStringARB = NULL; - -PFNGLTEXPAGECOMMITMENTARBPROC __glewTexPageCommitmentARB = NULL; -PFNGLTEXTUREPAGECOMMITMENTEXTPROC __glewTexturePageCommitmentEXT = NULL; - -PFNGLCLIENTWAITSYNCPROC __glewClientWaitSync = NULL; -PFNGLDELETESYNCPROC __glewDeleteSync = NULL; -PFNGLFENCESYNCPROC __glewFenceSync = NULL; -PFNGLGETINTEGER64VPROC __glewGetInteger64v = NULL; -PFNGLGETSYNCIVPROC __glewGetSynciv = NULL; -PFNGLISSYNCPROC __glewIsSync = NULL; -PFNGLWAITSYNCPROC __glewWaitSync = NULL; - -PFNGLPATCHPARAMETERFVPROC __glewPatchParameterfv = NULL; -PFNGLPATCHPARAMETERIPROC __glewPatchParameteri = NULL; - -PFNGLTEXBUFFERARBPROC __glewTexBufferARB = NULL; - -PFNGLTEXBUFFERRANGEPROC __glewTexBufferRange = NULL; -PFNGLTEXTUREBUFFERRANGEEXTPROC __glewTextureBufferRangeEXT = NULL; - -PFNGLCOMPRESSEDTEXIMAGE1DARBPROC __glewCompressedTexImage1DARB = NULL; -PFNGLCOMPRESSEDTEXIMAGE2DARBPROC __glewCompressedTexImage2DARB = NULL; -PFNGLCOMPRESSEDTEXIMAGE3DARBPROC __glewCompressedTexImage3DARB = NULL; -PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC __glewCompressedTexSubImage1DARB = NULL; -PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC __glewCompressedTexSubImage2DARB = NULL; -PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC __glewCompressedTexSubImage3DARB = NULL; -PFNGLGETCOMPRESSEDTEXIMAGEARBPROC __glewGetCompressedTexImageARB = NULL; - -PFNGLGETMULTISAMPLEFVPROC __glewGetMultisamplefv = NULL; -PFNGLSAMPLEMASKIPROC __glewSampleMaski = NULL; -PFNGLTEXIMAGE2DMULTISAMPLEPROC __glewTexImage2DMultisample = NULL; -PFNGLTEXIMAGE3DMULTISAMPLEPROC __glewTexImage3DMultisample = NULL; - -PFNGLTEXSTORAGE1DPROC __glewTexStorage1D = NULL; -PFNGLTEXSTORAGE2DPROC __glewTexStorage2D = NULL; -PFNGLTEXSTORAGE3DPROC __glewTexStorage3D = NULL; -PFNGLTEXTURESTORAGE1DEXTPROC __glewTextureStorage1DEXT = NULL; -PFNGLTEXTURESTORAGE2DEXTPROC __glewTextureStorage2DEXT = NULL; -PFNGLTEXTURESTORAGE3DEXTPROC __glewTextureStorage3DEXT = NULL; - -PFNGLTEXSTORAGE2DMULTISAMPLEPROC __glewTexStorage2DMultisample = NULL; -PFNGLTEXSTORAGE3DMULTISAMPLEPROC __glewTexStorage3DMultisample = NULL; -PFNGLTEXTURESTORAGE2DMULTISAMPLEEXTPROC __glewTextureStorage2DMultisampleEXT = NULL; -PFNGLTEXTURESTORAGE3DMULTISAMPLEEXTPROC __glewTextureStorage3DMultisampleEXT = NULL; - -PFNGLTEXTUREVIEWPROC __glewTextureView = NULL; - -PFNGLGETQUERYOBJECTI64VPROC __glewGetQueryObjecti64v = NULL; -PFNGLGETQUERYOBJECTUI64VPROC __glewGetQueryObjectui64v = NULL; -PFNGLQUERYCOUNTERPROC __glewQueryCounter = NULL; - -PFNGLBINDTRANSFORMFEEDBACKPROC __glewBindTransformFeedback = NULL; -PFNGLDELETETRANSFORMFEEDBACKSPROC __glewDeleteTransformFeedbacks = NULL; -PFNGLDRAWTRANSFORMFEEDBACKPROC __glewDrawTransformFeedback = NULL; -PFNGLGENTRANSFORMFEEDBACKSPROC __glewGenTransformFeedbacks = NULL; -PFNGLISTRANSFORMFEEDBACKPROC __glewIsTransformFeedback = NULL; -PFNGLPAUSETRANSFORMFEEDBACKPROC __glewPauseTransformFeedback = NULL; -PFNGLRESUMETRANSFORMFEEDBACKPROC __glewResumeTransformFeedback = NULL; - -PFNGLBEGINQUERYINDEXEDPROC __glewBeginQueryIndexed = NULL; -PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC __glewDrawTransformFeedbackStream = NULL; -PFNGLENDQUERYINDEXEDPROC __glewEndQueryIndexed = NULL; -PFNGLGETQUERYINDEXEDIVPROC __glewGetQueryIndexediv = NULL; - -PFNGLDRAWTRANSFORMFEEDBACKINSTANCEDPROC __glewDrawTransformFeedbackInstanced = NULL; -PFNGLDRAWTRANSFORMFEEDBACKSTREAMINSTANCEDPROC __glewDrawTransformFeedbackStreamInstanced = NULL; - -PFNGLLOADTRANSPOSEMATRIXDARBPROC __glewLoadTransposeMatrixdARB = NULL; -PFNGLLOADTRANSPOSEMATRIXFARBPROC __glewLoadTransposeMatrixfARB = NULL; -PFNGLMULTTRANSPOSEMATRIXDARBPROC __glewMultTransposeMatrixdARB = NULL; -PFNGLMULTTRANSPOSEMATRIXFARBPROC __glewMultTransposeMatrixfARB = NULL; - -PFNGLBINDBUFFERBASEPROC __glewBindBufferBase = NULL; -PFNGLBINDBUFFERRANGEPROC __glewBindBufferRange = NULL; -PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC __glewGetActiveUniformBlockName = NULL; -PFNGLGETACTIVEUNIFORMBLOCKIVPROC __glewGetActiveUniformBlockiv = NULL; -PFNGLGETACTIVEUNIFORMNAMEPROC __glewGetActiveUniformName = NULL; -PFNGLGETACTIVEUNIFORMSIVPROC __glewGetActiveUniformsiv = NULL; -PFNGLGETINTEGERI_VPROC __glewGetIntegeri_v = NULL; -PFNGLGETUNIFORMBLOCKINDEXPROC __glewGetUniformBlockIndex = NULL; -PFNGLGETUNIFORMINDICESPROC __glewGetUniformIndices = NULL; -PFNGLUNIFORMBLOCKBINDINGPROC __glewUniformBlockBinding = NULL; - -PFNGLBINDVERTEXARRAYPROC __glewBindVertexArray = NULL; -PFNGLDELETEVERTEXARRAYSPROC __glewDeleteVertexArrays = NULL; -PFNGLGENVERTEXARRAYSPROC __glewGenVertexArrays = NULL; -PFNGLISVERTEXARRAYPROC __glewIsVertexArray = NULL; - -PFNGLGETVERTEXATTRIBLDVPROC __glewGetVertexAttribLdv = NULL; -PFNGLVERTEXATTRIBL1DPROC __glewVertexAttribL1d = NULL; -PFNGLVERTEXATTRIBL1DVPROC __glewVertexAttribL1dv = NULL; -PFNGLVERTEXATTRIBL2DPROC __glewVertexAttribL2d = NULL; -PFNGLVERTEXATTRIBL2DVPROC __glewVertexAttribL2dv = NULL; -PFNGLVERTEXATTRIBL3DPROC __glewVertexAttribL3d = NULL; -PFNGLVERTEXATTRIBL3DVPROC __glewVertexAttribL3dv = NULL; -PFNGLVERTEXATTRIBL4DPROC __glewVertexAttribL4d = NULL; -PFNGLVERTEXATTRIBL4DVPROC __glewVertexAttribL4dv = NULL; -PFNGLVERTEXATTRIBLPOINTERPROC __glewVertexAttribLPointer = NULL; - -PFNGLBINDVERTEXBUFFERPROC __glewBindVertexBuffer = NULL; -PFNGLVERTEXATTRIBBINDINGPROC __glewVertexAttribBinding = NULL; -PFNGLVERTEXATTRIBFORMATPROC __glewVertexAttribFormat = NULL; -PFNGLVERTEXATTRIBIFORMATPROC __glewVertexAttribIFormat = NULL; -PFNGLVERTEXATTRIBLFORMATPROC __glewVertexAttribLFormat = NULL; -PFNGLVERTEXBINDINGDIVISORPROC __glewVertexBindingDivisor = NULL; - -PFNGLVERTEXBLENDARBPROC __glewVertexBlendARB = NULL; -PFNGLWEIGHTPOINTERARBPROC __glewWeightPointerARB = NULL; -PFNGLWEIGHTBVARBPROC __glewWeightbvARB = NULL; -PFNGLWEIGHTDVARBPROC __glewWeightdvARB = NULL; -PFNGLWEIGHTFVARBPROC __glewWeightfvARB = NULL; -PFNGLWEIGHTIVARBPROC __glewWeightivARB = NULL; -PFNGLWEIGHTSVARBPROC __glewWeightsvARB = NULL; -PFNGLWEIGHTUBVARBPROC __glewWeightubvARB = NULL; -PFNGLWEIGHTUIVARBPROC __glewWeightuivARB = NULL; -PFNGLWEIGHTUSVARBPROC __glewWeightusvARB = NULL; - -PFNGLBINDBUFFERARBPROC __glewBindBufferARB = NULL; -PFNGLBUFFERDATAARBPROC __glewBufferDataARB = NULL; -PFNGLBUFFERSUBDATAARBPROC __glewBufferSubDataARB = NULL; -PFNGLDELETEBUFFERSARBPROC __glewDeleteBuffersARB = NULL; -PFNGLGENBUFFERSARBPROC __glewGenBuffersARB = NULL; -PFNGLGETBUFFERPARAMETERIVARBPROC __glewGetBufferParameterivARB = NULL; -PFNGLGETBUFFERPOINTERVARBPROC __glewGetBufferPointervARB = NULL; -PFNGLGETBUFFERSUBDATAARBPROC __glewGetBufferSubDataARB = NULL; -PFNGLISBUFFERARBPROC __glewIsBufferARB = NULL; -PFNGLMAPBUFFERARBPROC __glewMapBufferARB = NULL; -PFNGLUNMAPBUFFERARBPROC __glewUnmapBufferARB = NULL; - -PFNGLBINDPROGRAMARBPROC __glewBindProgramARB = NULL; -PFNGLDELETEPROGRAMSARBPROC __glewDeleteProgramsARB = NULL; -PFNGLDISABLEVERTEXATTRIBARRAYARBPROC __glewDisableVertexAttribArrayARB = NULL; -PFNGLENABLEVERTEXATTRIBARRAYARBPROC __glewEnableVertexAttribArrayARB = NULL; -PFNGLGENPROGRAMSARBPROC __glewGenProgramsARB = NULL; -PFNGLGETPROGRAMENVPARAMETERDVARBPROC __glewGetProgramEnvParameterdvARB = NULL; -PFNGLGETPROGRAMENVPARAMETERFVARBPROC __glewGetProgramEnvParameterfvARB = NULL; -PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC __glewGetProgramLocalParameterdvARB = NULL; -PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC __glewGetProgramLocalParameterfvARB = NULL; -PFNGLGETPROGRAMSTRINGARBPROC __glewGetProgramStringARB = NULL; -PFNGLGETPROGRAMIVARBPROC __glewGetProgramivARB = NULL; -PFNGLGETVERTEXATTRIBPOINTERVARBPROC __glewGetVertexAttribPointervARB = NULL; -PFNGLGETVERTEXATTRIBDVARBPROC __glewGetVertexAttribdvARB = NULL; -PFNGLGETVERTEXATTRIBFVARBPROC __glewGetVertexAttribfvARB = NULL; -PFNGLGETVERTEXATTRIBIVARBPROC __glewGetVertexAttribivARB = NULL; -PFNGLISPROGRAMARBPROC __glewIsProgramARB = NULL; -PFNGLPROGRAMENVPARAMETER4DARBPROC __glewProgramEnvParameter4dARB = NULL; -PFNGLPROGRAMENVPARAMETER4DVARBPROC __glewProgramEnvParameter4dvARB = NULL; -PFNGLPROGRAMENVPARAMETER4FARBPROC __glewProgramEnvParameter4fARB = NULL; -PFNGLPROGRAMENVPARAMETER4FVARBPROC __glewProgramEnvParameter4fvARB = NULL; -PFNGLPROGRAMLOCALPARAMETER4DARBPROC __glewProgramLocalParameter4dARB = NULL; -PFNGLPROGRAMLOCALPARAMETER4DVARBPROC __glewProgramLocalParameter4dvARB = NULL; -PFNGLPROGRAMLOCALPARAMETER4FARBPROC __glewProgramLocalParameter4fARB = NULL; -PFNGLPROGRAMLOCALPARAMETER4FVARBPROC __glewProgramLocalParameter4fvARB = NULL; -PFNGLPROGRAMSTRINGARBPROC __glewProgramStringARB = NULL; -PFNGLVERTEXATTRIB1DARBPROC __glewVertexAttrib1dARB = NULL; -PFNGLVERTEXATTRIB1DVARBPROC __glewVertexAttrib1dvARB = NULL; -PFNGLVERTEXATTRIB1FARBPROC __glewVertexAttrib1fARB = NULL; -PFNGLVERTEXATTRIB1FVARBPROC __glewVertexAttrib1fvARB = NULL; -PFNGLVERTEXATTRIB1SARBPROC __glewVertexAttrib1sARB = NULL; -PFNGLVERTEXATTRIB1SVARBPROC __glewVertexAttrib1svARB = NULL; -PFNGLVERTEXATTRIB2DARBPROC __glewVertexAttrib2dARB = NULL; -PFNGLVERTEXATTRIB2DVARBPROC __glewVertexAttrib2dvARB = NULL; -PFNGLVERTEXATTRIB2FARBPROC __glewVertexAttrib2fARB = NULL; -PFNGLVERTEXATTRIB2FVARBPROC __glewVertexAttrib2fvARB = NULL; -PFNGLVERTEXATTRIB2SARBPROC __glewVertexAttrib2sARB = NULL; -PFNGLVERTEXATTRIB2SVARBPROC __glewVertexAttrib2svARB = NULL; -PFNGLVERTEXATTRIB3DARBPROC __glewVertexAttrib3dARB = NULL; -PFNGLVERTEXATTRIB3DVARBPROC __glewVertexAttrib3dvARB = NULL; -PFNGLVERTEXATTRIB3FARBPROC __glewVertexAttrib3fARB = NULL; -PFNGLVERTEXATTRIB3FVARBPROC __glewVertexAttrib3fvARB = NULL; -PFNGLVERTEXATTRIB3SARBPROC __glewVertexAttrib3sARB = NULL; -PFNGLVERTEXATTRIB3SVARBPROC __glewVertexAttrib3svARB = NULL; -PFNGLVERTEXATTRIB4NBVARBPROC __glewVertexAttrib4NbvARB = NULL; -PFNGLVERTEXATTRIB4NIVARBPROC __glewVertexAttrib4NivARB = NULL; -PFNGLVERTEXATTRIB4NSVARBPROC __glewVertexAttrib4NsvARB = NULL; -PFNGLVERTEXATTRIB4NUBARBPROC __glewVertexAttrib4NubARB = NULL; -PFNGLVERTEXATTRIB4NUBVARBPROC __glewVertexAttrib4NubvARB = NULL; -PFNGLVERTEXATTRIB4NUIVARBPROC __glewVertexAttrib4NuivARB = NULL; -PFNGLVERTEXATTRIB4NUSVARBPROC __glewVertexAttrib4NusvARB = NULL; -PFNGLVERTEXATTRIB4BVARBPROC __glewVertexAttrib4bvARB = NULL; -PFNGLVERTEXATTRIB4DARBPROC __glewVertexAttrib4dARB = NULL; -PFNGLVERTEXATTRIB4DVARBPROC __glewVertexAttrib4dvARB = NULL; -PFNGLVERTEXATTRIB4FARBPROC __glewVertexAttrib4fARB = NULL; -PFNGLVERTEXATTRIB4FVARBPROC __glewVertexAttrib4fvARB = NULL; -PFNGLVERTEXATTRIB4IVARBPROC __glewVertexAttrib4ivARB = NULL; -PFNGLVERTEXATTRIB4SARBPROC __glewVertexAttrib4sARB = NULL; -PFNGLVERTEXATTRIB4SVARBPROC __glewVertexAttrib4svARB = NULL; -PFNGLVERTEXATTRIB4UBVARBPROC __glewVertexAttrib4ubvARB = NULL; -PFNGLVERTEXATTRIB4UIVARBPROC __glewVertexAttrib4uivARB = NULL; -PFNGLVERTEXATTRIB4USVARBPROC __glewVertexAttrib4usvARB = NULL; -PFNGLVERTEXATTRIBPOINTERARBPROC __glewVertexAttribPointerARB = NULL; - -PFNGLBINDATTRIBLOCATIONARBPROC __glewBindAttribLocationARB = NULL; -PFNGLGETACTIVEATTRIBARBPROC __glewGetActiveAttribARB = NULL; -PFNGLGETATTRIBLOCATIONARBPROC __glewGetAttribLocationARB = NULL; - -PFNGLCOLORP3UIPROC __glewColorP3ui = NULL; -PFNGLCOLORP3UIVPROC __glewColorP3uiv = NULL; -PFNGLCOLORP4UIPROC __glewColorP4ui = NULL; -PFNGLCOLORP4UIVPROC __glewColorP4uiv = NULL; -PFNGLMULTITEXCOORDP1UIPROC __glewMultiTexCoordP1ui = NULL; -PFNGLMULTITEXCOORDP1UIVPROC __glewMultiTexCoordP1uiv = NULL; -PFNGLMULTITEXCOORDP2UIPROC __glewMultiTexCoordP2ui = NULL; -PFNGLMULTITEXCOORDP2UIVPROC __glewMultiTexCoordP2uiv = NULL; -PFNGLMULTITEXCOORDP3UIPROC __glewMultiTexCoordP3ui = NULL; -PFNGLMULTITEXCOORDP3UIVPROC __glewMultiTexCoordP3uiv = NULL; -PFNGLMULTITEXCOORDP4UIPROC __glewMultiTexCoordP4ui = NULL; -PFNGLMULTITEXCOORDP4UIVPROC __glewMultiTexCoordP4uiv = NULL; -PFNGLNORMALP3UIPROC __glewNormalP3ui = NULL; -PFNGLNORMALP3UIVPROC __glewNormalP3uiv = NULL; -PFNGLSECONDARYCOLORP3UIPROC __glewSecondaryColorP3ui = NULL; -PFNGLSECONDARYCOLORP3UIVPROC __glewSecondaryColorP3uiv = NULL; -PFNGLTEXCOORDP1UIPROC __glewTexCoordP1ui = NULL; -PFNGLTEXCOORDP1UIVPROC __glewTexCoordP1uiv = NULL; -PFNGLTEXCOORDP2UIPROC __glewTexCoordP2ui = NULL; -PFNGLTEXCOORDP2UIVPROC __glewTexCoordP2uiv = NULL; -PFNGLTEXCOORDP3UIPROC __glewTexCoordP3ui = NULL; -PFNGLTEXCOORDP3UIVPROC __glewTexCoordP3uiv = NULL; -PFNGLTEXCOORDP4UIPROC __glewTexCoordP4ui = NULL; -PFNGLTEXCOORDP4UIVPROC __glewTexCoordP4uiv = NULL; -PFNGLVERTEXATTRIBP1UIPROC __glewVertexAttribP1ui = NULL; -PFNGLVERTEXATTRIBP1UIVPROC __glewVertexAttribP1uiv = NULL; -PFNGLVERTEXATTRIBP2UIPROC __glewVertexAttribP2ui = NULL; -PFNGLVERTEXATTRIBP2UIVPROC __glewVertexAttribP2uiv = NULL; -PFNGLVERTEXATTRIBP3UIPROC __glewVertexAttribP3ui = NULL; -PFNGLVERTEXATTRIBP3UIVPROC __glewVertexAttribP3uiv = NULL; -PFNGLVERTEXATTRIBP4UIPROC __glewVertexAttribP4ui = NULL; -PFNGLVERTEXATTRIBP4UIVPROC __glewVertexAttribP4uiv = NULL; -PFNGLVERTEXP2UIPROC __glewVertexP2ui = NULL; -PFNGLVERTEXP2UIVPROC __glewVertexP2uiv = NULL; -PFNGLVERTEXP3UIPROC __glewVertexP3ui = NULL; -PFNGLVERTEXP3UIVPROC __glewVertexP3uiv = NULL; -PFNGLVERTEXP4UIPROC __glewVertexP4ui = NULL; -PFNGLVERTEXP4UIVPROC __glewVertexP4uiv = NULL; - -PFNGLDEPTHRANGEARRAYVPROC __glewDepthRangeArrayv = NULL; -PFNGLDEPTHRANGEINDEXEDPROC __glewDepthRangeIndexed = NULL; -PFNGLGETDOUBLEI_VPROC __glewGetDoublei_v = NULL; -PFNGLGETFLOATI_VPROC __glewGetFloati_v = NULL; -PFNGLSCISSORARRAYVPROC __glewScissorArrayv = NULL; -PFNGLSCISSORINDEXEDPROC __glewScissorIndexed = NULL; -PFNGLSCISSORINDEXEDVPROC __glewScissorIndexedv = NULL; -PFNGLVIEWPORTARRAYVPROC __glewViewportArrayv = NULL; -PFNGLVIEWPORTINDEXEDFPROC __glewViewportIndexedf = NULL; -PFNGLVIEWPORTINDEXEDFVPROC __glewViewportIndexedfv = NULL; - -PFNGLWINDOWPOS2DARBPROC __glewWindowPos2dARB = NULL; -PFNGLWINDOWPOS2DVARBPROC __glewWindowPos2dvARB = NULL; -PFNGLWINDOWPOS2FARBPROC __glewWindowPos2fARB = NULL; -PFNGLWINDOWPOS2FVARBPROC __glewWindowPos2fvARB = NULL; -PFNGLWINDOWPOS2IARBPROC __glewWindowPos2iARB = NULL; -PFNGLWINDOWPOS2IVARBPROC __glewWindowPos2ivARB = NULL; -PFNGLWINDOWPOS2SARBPROC __glewWindowPos2sARB = NULL; -PFNGLWINDOWPOS2SVARBPROC __glewWindowPos2svARB = NULL; -PFNGLWINDOWPOS3DARBPROC __glewWindowPos3dARB = NULL; -PFNGLWINDOWPOS3DVARBPROC __glewWindowPos3dvARB = NULL; -PFNGLWINDOWPOS3FARBPROC __glewWindowPos3fARB = NULL; -PFNGLWINDOWPOS3FVARBPROC __glewWindowPos3fvARB = NULL; -PFNGLWINDOWPOS3IARBPROC __glewWindowPos3iARB = NULL; -PFNGLWINDOWPOS3IVARBPROC __glewWindowPos3ivARB = NULL; -PFNGLWINDOWPOS3SARBPROC __glewWindowPos3sARB = NULL; -PFNGLWINDOWPOS3SVARBPROC __glewWindowPos3svARB = NULL; - -PFNGLDRAWBUFFERSATIPROC __glewDrawBuffersATI = NULL; - -PFNGLDRAWELEMENTARRAYATIPROC __glewDrawElementArrayATI = NULL; -PFNGLDRAWRANGEELEMENTARRAYATIPROC __glewDrawRangeElementArrayATI = NULL; -PFNGLELEMENTPOINTERATIPROC __glewElementPointerATI = NULL; - -PFNGLGETTEXBUMPPARAMETERFVATIPROC __glewGetTexBumpParameterfvATI = NULL; -PFNGLGETTEXBUMPPARAMETERIVATIPROC __glewGetTexBumpParameterivATI = NULL; -PFNGLTEXBUMPPARAMETERFVATIPROC __glewTexBumpParameterfvATI = NULL; -PFNGLTEXBUMPPARAMETERIVATIPROC __glewTexBumpParameterivATI = NULL; - -PFNGLALPHAFRAGMENTOP1ATIPROC __glewAlphaFragmentOp1ATI = NULL; -PFNGLALPHAFRAGMENTOP2ATIPROC __glewAlphaFragmentOp2ATI = NULL; -PFNGLALPHAFRAGMENTOP3ATIPROC __glewAlphaFragmentOp3ATI = NULL; -PFNGLBEGINFRAGMENTSHADERATIPROC __glewBeginFragmentShaderATI = NULL; -PFNGLBINDFRAGMENTSHADERATIPROC __glewBindFragmentShaderATI = NULL; -PFNGLCOLORFRAGMENTOP1ATIPROC __glewColorFragmentOp1ATI = NULL; -PFNGLCOLORFRAGMENTOP2ATIPROC __glewColorFragmentOp2ATI = NULL; -PFNGLCOLORFRAGMENTOP3ATIPROC __glewColorFragmentOp3ATI = NULL; -PFNGLDELETEFRAGMENTSHADERATIPROC __glewDeleteFragmentShaderATI = NULL; -PFNGLENDFRAGMENTSHADERATIPROC __glewEndFragmentShaderATI = NULL; -PFNGLGENFRAGMENTSHADERSATIPROC __glewGenFragmentShadersATI = NULL; -PFNGLPASSTEXCOORDATIPROC __glewPassTexCoordATI = NULL; -PFNGLSAMPLEMAPATIPROC __glewSampleMapATI = NULL; -PFNGLSETFRAGMENTSHADERCONSTANTATIPROC __glewSetFragmentShaderConstantATI = NULL; - -PFNGLMAPOBJECTBUFFERATIPROC __glewMapObjectBufferATI = NULL; -PFNGLUNMAPOBJECTBUFFERATIPROC __glewUnmapObjectBufferATI = NULL; - -PFNGLPNTRIANGLESFATIPROC __glewPNTrianglesfATI = NULL; -PFNGLPNTRIANGLESIATIPROC __glewPNTrianglesiATI = NULL; - -PFNGLSTENCILFUNCSEPARATEATIPROC __glewStencilFuncSeparateATI = NULL; -PFNGLSTENCILOPSEPARATEATIPROC __glewStencilOpSeparateATI = NULL; - -PFNGLARRAYOBJECTATIPROC __glewArrayObjectATI = NULL; -PFNGLFREEOBJECTBUFFERATIPROC __glewFreeObjectBufferATI = NULL; -PFNGLGETARRAYOBJECTFVATIPROC __glewGetArrayObjectfvATI = NULL; -PFNGLGETARRAYOBJECTIVATIPROC __glewGetArrayObjectivATI = NULL; -PFNGLGETOBJECTBUFFERFVATIPROC __glewGetObjectBufferfvATI = NULL; -PFNGLGETOBJECTBUFFERIVATIPROC __glewGetObjectBufferivATI = NULL; -PFNGLGETVARIANTARRAYOBJECTFVATIPROC __glewGetVariantArrayObjectfvATI = NULL; -PFNGLGETVARIANTARRAYOBJECTIVATIPROC __glewGetVariantArrayObjectivATI = NULL; -PFNGLISOBJECTBUFFERATIPROC __glewIsObjectBufferATI = NULL; -PFNGLNEWOBJECTBUFFERATIPROC __glewNewObjectBufferATI = NULL; -PFNGLUPDATEOBJECTBUFFERATIPROC __glewUpdateObjectBufferATI = NULL; -PFNGLVARIANTARRAYOBJECTATIPROC __glewVariantArrayObjectATI = NULL; - -PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC __glewGetVertexAttribArrayObjectfvATI = NULL; -PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC __glewGetVertexAttribArrayObjectivATI = NULL; -PFNGLVERTEXATTRIBARRAYOBJECTATIPROC __glewVertexAttribArrayObjectATI = NULL; - -PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC __glewClientActiveVertexStreamATI = NULL; -PFNGLNORMALSTREAM3BATIPROC __glewNormalStream3bATI = NULL; -PFNGLNORMALSTREAM3BVATIPROC __glewNormalStream3bvATI = NULL; -PFNGLNORMALSTREAM3DATIPROC __glewNormalStream3dATI = NULL; -PFNGLNORMALSTREAM3DVATIPROC __glewNormalStream3dvATI = NULL; -PFNGLNORMALSTREAM3FATIPROC __glewNormalStream3fATI = NULL; -PFNGLNORMALSTREAM3FVATIPROC __glewNormalStream3fvATI = NULL; -PFNGLNORMALSTREAM3IATIPROC __glewNormalStream3iATI = NULL; -PFNGLNORMALSTREAM3IVATIPROC __glewNormalStream3ivATI = NULL; -PFNGLNORMALSTREAM3SATIPROC __glewNormalStream3sATI = NULL; -PFNGLNORMALSTREAM3SVATIPROC __glewNormalStream3svATI = NULL; -PFNGLVERTEXBLENDENVFATIPROC __glewVertexBlendEnvfATI = NULL; -PFNGLVERTEXBLENDENVIATIPROC __glewVertexBlendEnviATI = NULL; -PFNGLVERTEXSTREAM1DATIPROC __glewVertexStream1dATI = NULL; -PFNGLVERTEXSTREAM1DVATIPROC __glewVertexStream1dvATI = NULL; -PFNGLVERTEXSTREAM1FATIPROC __glewVertexStream1fATI = NULL; -PFNGLVERTEXSTREAM1FVATIPROC __glewVertexStream1fvATI = NULL; -PFNGLVERTEXSTREAM1IATIPROC __glewVertexStream1iATI = NULL; -PFNGLVERTEXSTREAM1IVATIPROC __glewVertexStream1ivATI = NULL; -PFNGLVERTEXSTREAM1SATIPROC __glewVertexStream1sATI = NULL; -PFNGLVERTEXSTREAM1SVATIPROC __glewVertexStream1svATI = NULL; -PFNGLVERTEXSTREAM2DATIPROC __glewVertexStream2dATI = NULL; -PFNGLVERTEXSTREAM2DVATIPROC __glewVertexStream2dvATI = NULL; -PFNGLVERTEXSTREAM2FATIPROC __glewVertexStream2fATI = NULL; -PFNGLVERTEXSTREAM2FVATIPROC __glewVertexStream2fvATI = NULL; -PFNGLVERTEXSTREAM2IATIPROC __glewVertexStream2iATI = NULL; -PFNGLVERTEXSTREAM2IVATIPROC __glewVertexStream2ivATI = NULL; -PFNGLVERTEXSTREAM2SATIPROC __glewVertexStream2sATI = NULL; -PFNGLVERTEXSTREAM2SVATIPROC __glewVertexStream2svATI = NULL; -PFNGLVERTEXSTREAM3DATIPROC __glewVertexStream3dATI = NULL; -PFNGLVERTEXSTREAM3DVATIPROC __glewVertexStream3dvATI = NULL; -PFNGLVERTEXSTREAM3FATIPROC __glewVertexStream3fATI = NULL; -PFNGLVERTEXSTREAM3FVATIPROC __glewVertexStream3fvATI = NULL; -PFNGLVERTEXSTREAM3IATIPROC __glewVertexStream3iATI = NULL; -PFNGLVERTEXSTREAM3IVATIPROC __glewVertexStream3ivATI = NULL; -PFNGLVERTEXSTREAM3SATIPROC __glewVertexStream3sATI = NULL; -PFNGLVERTEXSTREAM3SVATIPROC __glewVertexStream3svATI = NULL; -PFNGLVERTEXSTREAM4DATIPROC __glewVertexStream4dATI = NULL; -PFNGLVERTEXSTREAM4DVATIPROC __glewVertexStream4dvATI = NULL; -PFNGLVERTEXSTREAM4FATIPROC __glewVertexStream4fATI = NULL; -PFNGLVERTEXSTREAM4FVATIPROC __glewVertexStream4fvATI = NULL; -PFNGLVERTEXSTREAM4IATIPROC __glewVertexStream4iATI = NULL; -PFNGLVERTEXSTREAM4IVATIPROC __glewVertexStream4ivATI = NULL; -PFNGLVERTEXSTREAM4SATIPROC __glewVertexStream4sATI = NULL; -PFNGLVERTEXSTREAM4SVATIPROC __glewVertexStream4svATI = NULL; - -PFNGLGETUNIFORMBUFFERSIZEEXTPROC __glewGetUniformBufferSizeEXT = NULL; -PFNGLGETUNIFORMOFFSETEXTPROC __glewGetUniformOffsetEXT = NULL; -PFNGLUNIFORMBUFFEREXTPROC __glewUniformBufferEXT = NULL; - -PFNGLBLENDCOLOREXTPROC __glewBlendColorEXT = NULL; - -PFNGLBLENDEQUATIONSEPARATEEXTPROC __glewBlendEquationSeparateEXT = NULL; - -PFNGLBLENDFUNCSEPARATEEXTPROC __glewBlendFuncSeparateEXT = NULL; - -PFNGLBLENDEQUATIONEXTPROC __glewBlendEquationEXT = NULL; - -PFNGLCOLORSUBTABLEEXTPROC __glewColorSubTableEXT = NULL; -PFNGLCOPYCOLORSUBTABLEEXTPROC __glewCopyColorSubTableEXT = NULL; - -PFNGLLOCKARRAYSEXTPROC __glewLockArraysEXT = NULL; -PFNGLUNLOCKARRAYSEXTPROC __glewUnlockArraysEXT = NULL; - -PFNGLCONVOLUTIONFILTER1DEXTPROC __glewConvolutionFilter1DEXT = NULL; -PFNGLCONVOLUTIONFILTER2DEXTPROC __glewConvolutionFilter2DEXT = NULL; -PFNGLCONVOLUTIONPARAMETERFEXTPROC __glewConvolutionParameterfEXT = NULL; -PFNGLCONVOLUTIONPARAMETERFVEXTPROC __glewConvolutionParameterfvEXT = NULL; -PFNGLCONVOLUTIONPARAMETERIEXTPROC __glewConvolutionParameteriEXT = NULL; -PFNGLCONVOLUTIONPARAMETERIVEXTPROC __glewConvolutionParameterivEXT = NULL; -PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC __glewCopyConvolutionFilter1DEXT = NULL; -PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC __glewCopyConvolutionFilter2DEXT = NULL; -PFNGLGETCONVOLUTIONFILTEREXTPROC __glewGetConvolutionFilterEXT = NULL; -PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC __glewGetConvolutionParameterfvEXT = NULL; -PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC __glewGetConvolutionParameterivEXT = NULL; -PFNGLGETSEPARABLEFILTEREXTPROC __glewGetSeparableFilterEXT = NULL; -PFNGLSEPARABLEFILTER2DEXTPROC __glewSeparableFilter2DEXT = NULL; - -PFNGLBINORMALPOINTEREXTPROC __glewBinormalPointerEXT = NULL; -PFNGLTANGENTPOINTEREXTPROC __glewTangentPointerEXT = NULL; - -PFNGLCOPYTEXIMAGE1DEXTPROC __glewCopyTexImage1DEXT = NULL; -PFNGLCOPYTEXIMAGE2DEXTPROC __glewCopyTexImage2DEXT = NULL; -PFNGLCOPYTEXSUBIMAGE1DEXTPROC __glewCopyTexSubImage1DEXT = NULL; -PFNGLCOPYTEXSUBIMAGE2DEXTPROC __glewCopyTexSubImage2DEXT = NULL; -PFNGLCOPYTEXSUBIMAGE3DEXTPROC __glewCopyTexSubImage3DEXT = NULL; - -PFNGLCULLPARAMETERDVEXTPROC __glewCullParameterdvEXT = NULL; -PFNGLCULLPARAMETERFVEXTPROC __glewCullParameterfvEXT = NULL; - -PFNGLINSERTEVENTMARKEREXTPROC __glewInsertEventMarkerEXT = NULL; -PFNGLPOPGROUPMARKEREXTPROC __glewPopGroupMarkerEXT = NULL; -PFNGLPUSHGROUPMARKEREXTPROC __glewPushGroupMarkerEXT = NULL; - -PFNGLDEPTHBOUNDSEXTPROC __glewDepthBoundsEXT = NULL; - -PFNGLBINDMULTITEXTUREEXTPROC __glewBindMultiTextureEXT = NULL; -PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC __glewCheckNamedFramebufferStatusEXT = NULL; -PFNGLCLIENTATTRIBDEFAULTEXTPROC __glewClientAttribDefaultEXT = NULL; -PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC __glewCompressedMultiTexImage1DEXT = NULL; -PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC __glewCompressedMultiTexImage2DEXT = NULL; -PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC __glewCompressedMultiTexImage3DEXT = NULL; -PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC __glewCompressedMultiTexSubImage1DEXT = NULL; -PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC __glewCompressedMultiTexSubImage2DEXT = NULL; -PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC __glewCompressedMultiTexSubImage3DEXT = NULL; -PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC __glewCompressedTextureImage1DEXT = NULL; -PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC __glewCompressedTextureImage2DEXT = NULL; -PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC __glewCompressedTextureImage3DEXT = NULL; -PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC __glewCompressedTextureSubImage1DEXT = NULL; -PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC __glewCompressedTextureSubImage2DEXT = NULL; -PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC __glewCompressedTextureSubImage3DEXT = NULL; -PFNGLCOPYMULTITEXIMAGE1DEXTPROC __glewCopyMultiTexImage1DEXT = NULL; -PFNGLCOPYMULTITEXIMAGE2DEXTPROC __glewCopyMultiTexImage2DEXT = NULL; -PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC __glewCopyMultiTexSubImage1DEXT = NULL; -PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC __glewCopyMultiTexSubImage2DEXT = NULL; -PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC __glewCopyMultiTexSubImage3DEXT = NULL; -PFNGLCOPYTEXTUREIMAGE1DEXTPROC __glewCopyTextureImage1DEXT = NULL; -PFNGLCOPYTEXTUREIMAGE2DEXTPROC __glewCopyTextureImage2DEXT = NULL; -PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC __glewCopyTextureSubImage1DEXT = NULL; -PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC __glewCopyTextureSubImage2DEXT = NULL; -PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC __glewCopyTextureSubImage3DEXT = NULL; -PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC __glewDisableClientStateIndexedEXT = NULL; -PFNGLDISABLECLIENTSTATEIEXTPROC __glewDisableClientStateiEXT = NULL; -PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC __glewDisableVertexArrayAttribEXT = NULL; -PFNGLDISABLEVERTEXARRAYEXTPROC __glewDisableVertexArrayEXT = NULL; -PFNGLENABLECLIENTSTATEINDEXEDEXTPROC __glewEnableClientStateIndexedEXT = NULL; -PFNGLENABLECLIENTSTATEIEXTPROC __glewEnableClientStateiEXT = NULL; -PFNGLENABLEVERTEXARRAYATTRIBEXTPROC __glewEnableVertexArrayAttribEXT = NULL; -PFNGLENABLEVERTEXARRAYEXTPROC __glewEnableVertexArrayEXT = NULL; -PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC __glewFlushMappedNamedBufferRangeEXT = NULL; -PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC __glewFramebufferDrawBufferEXT = NULL; -PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC __glewFramebufferDrawBuffersEXT = NULL; -PFNGLFRAMEBUFFERREADBUFFEREXTPROC __glewFramebufferReadBufferEXT = NULL; -PFNGLGENERATEMULTITEXMIPMAPEXTPROC __glewGenerateMultiTexMipmapEXT = NULL; -PFNGLGENERATETEXTUREMIPMAPEXTPROC __glewGenerateTextureMipmapEXT = NULL; -PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC __glewGetCompressedMultiTexImageEXT = NULL; -PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC __glewGetCompressedTextureImageEXT = NULL; -PFNGLGETDOUBLEINDEXEDVEXTPROC __glewGetDoubleIndexedvEXT = NULL; -PFNGLGETDOUBLEI_VEXTPROC __glewGetDoublei_vEXT = NULL; -PFNGLGETFLOATINDEXEDVEXTPROC __glewGetFloatIndexedvEXT = NULL; -PFNGLGETFLOATI_VEXTPROC __glewGetFloati_vEXT = NULL; -PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC __glewGetFramebufferParameterivEXT = NULL; -PFNGLGETMULTITEXENVFVEXTPROC __glewGetMultiTexEnvfvEXT = NULL; -PFNGLGETMULTITEXENVIVEXTPROC __glewGetMultiTexEnvivEXT = NULL; -PFNGLGETMULTITEXGENDVEXTPROC __glewGetMultiTexGendvEXT = NULL; -PFNGLGETMULTITEXGENFVEXTPROC __glewGetMultiTexGenfvEXT = NULL; -PFNGLGETMULTITEXGENIVEXTPROC __glewGetMultiTexGenivEXT = NULL; -PFNGLGETMULTITEXIMAGEEXTPROC __glewGetMultiTexImageEXT = NULL; -PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC __glewGetMultiTexLevelParameterfvEXT = NULL; -PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC __glewGetMultiTexLevelParameterivEXT = NULL; -PFNGLGETMULTITEXPARAMETERIIVEXTPROC __glewGetMultiTexParameterIivEXT = NULL; -PFNGLGETMULTITEXPARAMETERIUIVEXTPROC __glewGetMultiTexParameterIuivEXT = NULL; -PFNGLGETMULTITEXPARAMETERFVEXTPROC __glewGetMultiTexParameterfvEXT = NULL; -PFNGLGETMULTITEXPARAMETERIVEXTPROC __glewGetMultiTexParameterivEXT = NULL; -PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC __glewGetNamedBufferParameterivEXT = NULL; -PFNGLGETNAMEDBUFFERPOINTERVEXTPROC __glewGetNamedBufferPointervEXT = NULL; -PFNGLGETNAMEDBUFFERSUBDATAEXTPROC __glewGetNamedBufferSubDataEXT = NULL; -PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetNamedFramebufferAttachmentParameterivEXT = NULL; -PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC __glewGetNamedProgramLocalParameterIivEXT = NULL; -PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC __glewGetNamedProgramLocalParameterIuivEXT = NULL; -PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC __glewGetNamedProgramLocalParameterdvEXT = NULL; -PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC __glewGetNamedProgramLocalParameterfvEXT = NULL; -PFNGLGETNAMEDPROGRAMSTRINGEXTPROC __glewGetNamedProgramStringEXT = NULL; -PFNGLGETNAMEDPROGRAMIVEXTPROC __glewGetNamedProgramivEXT = NULL; -PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC __glewGetNamedRenderbufferParameterivEXT = NULL; -PFNGLGETPOINTERINDEXEDVEXTPROC __glewGetPointerIndexedvEXT = NULL; -PFNGLGETPOINTERI_VEXTPROC __glewGetPointeri_vEXT = NULL; -PFNGLGETTEXTUREIMAGEEXTPROC __glewGetTextureImageEXT = NULL; -PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC __glewGetTextureLevelParameterfvEXT = NULL; -PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC __glewGetTextureLevelParameterivEXT = NULL; -PFNGLGETTEXTUREPARAMETERIIVEXTPROC __glewGetTextureParameterIivEXT = NULL; -PFNGLGETTEXTUREPARAMETERIUIVEXTPROC __glewGetTextureParameterIuivEXT = NULL; -PFNGLGETTEXTUREPARAMETERFVEXTPROC __glewGetTextureParameterfvEXT = NULL; -PFNGLGETTEXTUREPARAMETERIVEXTPROC __glewGetTextureParameterivEXT = NULL; -PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC __glewGetVertexArrayIntegeri_vEXT = NULL; -PFNGLGETVERTEXARRAYINTEGERVEXTPROC __glewGetVertexArrayIntegervEXT = NULL; -PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC __glewGetVertexArrayPointeri_vEXT = NULL; -PFNGLGETVERTEXARRAYPOINTERVEXTPROC __glewGetVertexArrayPointervEXT = NULL; -PFNGLMAPNAMEDBUFFEREXTPROC __glewMapNamedBufferEXT = NULL; -PFNGLMAPNAMEDBUFFERRANGEEXTPROC __glewMapNamedBufferRangeEXT = NULL; -PFNGLMATRIXFRUSTUMEXTPROC __glewMatrixFrustumEXT = NULL; -PFNGLMATRIXLOADIDENTITYEXTPROC __glewMatrixLoadIdentityEXT = NULL; -PFNGLMATRIXLOADTRANSPOSEDEXTPROC __glewMatrixLoadTransposedEXT = NULL; -PFNGLMATRIXLOADTRANSPOSEFEXTPROC __glewMatrixLoadTransposefEXT = NULL; -PFNGLMATRIXLOADDEXTPROC __glewMatrixLoaddEXT = NULL; -PFNGLMATRIXLOADFEXTPROC __glewMatrixLoadfEXT = NULL; -PFNGLMATRIXMULTTRANSPOSEDEXTPROC __glewMatrixMultTransposedEXT = NULL; -PFNGLMATRIXMULTTRANSPOSEFEXTPROC __glewMatrixMultTransposefEXT = NULL; -PFNGLMATRIXMULTDEXTPROC __glewMatrixMultdEXT = NULL; -PFNGLMATRIXMULTFEXTPROC __glewMatrixMultfEXT = NULL; -PFNGLMATRIXORTHOEXTPROC __glewMatrixOrthoEXT = NULL; -PFNGLMATRIXPOPEXTPROC __glewMatrixPopEXT = NULL; -PFNGLMATRIXPUSHEXTPROC __glewMatrixPushEXT = NULL; -PFNGLMATRIXROTATEDEXTPROC __glewMatrixRotatedEXT = NULL; -PFNGLMATRIXROTATEFEXTPROC __glewMatrixRotatefEXT = NULL; -PFNGLMATRIXSCALEDEXTPROC __glewMatrixScaledEXT = NULL; -PFNGLMATRIXSCALEFEXTPROC __glewMatrixScalefEXT = NULL; -PFNGLMATRIXTRANSLATEDEXTPROC __glewMatrixTranslatedEXT = NULL; -PFNGLMATRIXTRANSLATEFEXTPROC __glewMatrixTranslatefEXT = NULL; -PFNGLMULTITEXBUFFEREXTPROC __glewMultiTexBufferEXT = NULL; -PFNGLMULTITEXCOORDPOINTEREXTPROC __glewMultiTexCoordPointerEXT = NULL; -PFNGLMULTITEXENVFEXTPROC __glewMultiTexEnvfEXT = NULL; -PFNGLMULTITEXENVFVEXTPROC __glewMultiTexEnvfvEXT = NULL; -PFNGLMULTITEXENVIEXTPROC __glewMultiTexEnviEXT = NULL; -PFNGLMULTITEXENVIVEXTPROC __glewMultiTexEnvivEXT = NULL; -PFNGLMULTITEXGENDEXTPROC __glewMultiTexGendEXT = NULL; -PFNGLMULTITEXGENDVEXTPROC __glewMultiTexGendvEXT = NULL; -PFNGLMULTITEXGENFEXTPROC __glewMultiTexGenfEXT = NULL; -PFNGLMULTITEXGENFVEXTPROC __glewMultiTexGenfvEXT = NULL; -PFNGLMULTITEXGENIEXTPROC __glewMultiTexGeniEXT = NULL; -PFNGLMULTITEXGENIVEXTPROC __glewMultiTexGenivEXT = NULL; -PFNGLMULTITEXIMAGE1DEXTPROC __glewMultiTexImage1DEXT = NULL; -PFNGLMULTITEXIMAGE2DEXTPROC __glewMultiTexImage2DEXT = NULL; -PFNGLMULTITEXIMAGE3DEXTPROC __glewMultiTexImage3DEXT = NULL; -PFNGLMULTITEXPARAMETERIIVEXTPROC __glewMultiTexParameterIivEXT = NULL; -PFNGLMULTITEXPARAMETERIUIVEXTPROC __glewMultiTexParameterIuivEXT = NULL; -PFNGLMULTITEXPARAMETERFEXTPROC __glewMultiTexParameterfEXT = NULL; -PFNGLMULTITEXPARAMETERFVEXTPROC __glewMultiTexParameterfvEXT = NULL; -PFNGLMULTITEXPARAMETERIEXTPROC __glewMultiTexParameteriEXT = NULL; -PFNGLMULTITEXPARAMETERIVEXTPROC __glewMultiTexParameterivEXT = NULL; -PFNGLMULTITEXRENDERBUFFEREXTPROC __glewMultiTexRenderbufferEXT = NULL; -PFNGLMULTITEXSUBIMAGE1DEXTPROC __glewMultiTexSubImage1DEXT = NULL; -PFNGLMULTITEXSUBIMAGE2DEXTPROC __glewMultiTexSubImage2DEXT = NULL; -PFNGLMULTITEXSUBIMAGE3DEXTPROC __glewMultiTexSubImage3DEXT = NULL; -PFNGLNAMEDBUFFERDATAEXTPROC __glewNamedBufferDataEXT = NULL; -PFNGLNAMEDBUFFERSUBDATAEXTPROC __glewNamedBufferSubDataEXT = NULL; -PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC __glewNamedCopyBufferSubDataEXT = NULL; -PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC __glewNamedFramebufferRenderbufferEXT = NULL; -PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC __glewNamedFramebufferTexture1DEXT = NULL; -PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC __glewNamedFramebufferTexture2DEXT = NULL; -PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC __glewNamedFramebufferTexture3DEXT = NULL; -PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC __glewNamedFramebufferTextureEXT = NULL; -PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC __glewNamedFramebufferTextureFaceEXT = NULL; -PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC __glewNamedFramebufferTextureLayerEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC __glewNamedProgramLocalParameter4dEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC __glewNamedProgramLocalParameter4dvEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC __glewNamedProgramLocalParameter4fEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC __glewNamedProgramLocalParameter4fvEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC __glewNamedProgramLocalParameterI4iEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC __glewNamedProgramLocalParameterI4ivEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC __glewNamedProgramLocalParameterI4uiEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC __glewNamedProgramLocalParameterI4uivEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC __glewNamedProgramLocalParameters4fvEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC __glewNamedProgramLocalParametersI4ivEXT = NULL; -PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC __glewNamedProgramLocalParametersI4uivEXT = NULL; -PFNGLNAMEDPROGRAMSTRINGEXTPROC __glewNamedProgramStringEXT = NULL; -PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC __glewNamedRenderbufferStorageEXT = NULL; -PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC __glewNamedRenderbufferStorageMultisampleCoverageEXT = NULL; -PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewNamedRenderbufferStorageMultisampleEXT = NULL; -PFNGLPROGRAMUNIFORM1FEXTPROC __glewProgramUniform1fEXT = NULL; -PFNGLPROGRAMUNIFORM1FVEXTPROC __glewProgramUniform1fvEXT = NULL; -PFNGLPROGRAMUNIFORM1IEXTPROC __glewProgramUniform1iEXT = NULL; -PFNGLPROGRAMUNIFORM1IVEXTPROC __glewProgramUniform1ivEXT = NULL; -PFNGLPROGRAMUNIFORM1UIEXTPROC __glewProgramUniform1uiEXT = NULL; -PFNGLPROGRAMUNIFORM1UIVEXTPROC __glewProgramUniform1uivEXT = NULL; -PFNGLPROGRAMUNIFORM2FEXTPROC __glewProgramUniform2fEXT = NULL; -PFNGLPROGRAMUNIFORM2FVEXTPROC __glewProgramUniform2fvEXT = NULL; -PFNGLPROGRAMUNIFORM2IEXTPROC __glewProgramUniform2iEXT = NULL; -PFNGLPROGRAMUNIFORM2IVEXTPROC __glewProgramUniform2ivEXT = NULL; -PFNGLPROGRAMUNIFORM2UIEXTPROC __glewProgramUniform2uiEXT = NULL; -PFNGLPROGRAMUNIFORM2UIVEXTPROC __glewProgramUniform2uivEXT = NULL; -PFNGLPROGRAMUNIFORM3FEXTPROC __glewProgramUniform3fEXT = NULL; -PFNGLPROGRAMUNIFORM3FVEXTPROC __glewProgramUniform3fvEXT = NULL; -PFNGLPROGRAMUNIFORM3IEXTPROC __glewProgramUniform3iEXT = NULL; -PFNGLPROGRAMUNIFORM3IVEXTPROC __glewProgramUniform3ivEXT = NULL; -PFNGLPROGRAMUNIFORM3UIEXTPROC __glewProgramUniform3uiEXT = NULL; -PFNGLPROGRAMUNIFORM3UIVEXTPROC __glewProgramUniform3uivEXT = NULL; -PFNGLPROGRAMUNIFORM4FEXTPROC __glewProgramUniform4fEXT = NULL; -PFNGLPROGRAMUNIFORM4FVEXTPROC __glewProgramUniform4fvEXT = NULL; -PFNGLPROGRAMUNIFORM4IEXTPROC __glewProgramUniform4iEXT = NULL; -PFNGLPROGRAMUNIFORM4IVEXTPROC __glewProgramUniform4ivEXT = NULL; -PFNGLPROGRAMUNIFORM4UIEXTPROC __glewProgramUniform4uiEXT = NULL; -PFNGLPROGRAMUNIFORM4UIVEXTPROC __glewProgramUniform4uivEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC __glewProgramUniformMatrix2fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC __glewProgramUniformMatrix2x3fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC __glewProgramUniformMatrix2x4fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC __glewProgramUniformMatrix3fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC __glewProgramUniformMatrix3x2fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC __glewProgramUniformMatrix3x4fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC __glewProgramUniformMatrix4fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC __glewProgramUniformMatrix4x2fvEXT = NULL; -PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC __glewProgramUniformMatrix4x3fvEXT = NULL; -PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC __glewPushClientAttribDefaultEXT = NULL; -PFNGLTEXTUREBUFFEREXTPROC __glewTextureBufferEXT = NULL; -PFNGLTEXTUREIMAGE1DEXTPROC __glewTextureImage1DEXT = NULL; -PFNGLTEXTUREIMAGE2DEXTPROC __glewTextureImage2DEXT = NULL; -PFNGLTEXTUREIMAGE3DEXTPROC __glewTextureImage3DEXT = NULL; -PFNGLTEXTUREPARAMETERIIVEXTPROC __glewTextureParameterIivEXT = NULL; -PFNGLTEXTUREPARAMETERIUIVEXTPROC __glewTextureParameterIuivEXT = NULL; -PFNGLTEXTUREPARAMETERFEXTPROC __glewTextureParameterfEXT = NULL; -PFNGLTEXTUREPARAMETERFVEXTPROC __glewTextureParameterfvEXT = NULL; -PFNGLTEXTUREPARAMETERIEXTPROC __glewTextureParameteriEXT = NULL; -PFNGLTEXTUREPARAMETERIVEXTPROC __glewTextureParameterivEXT = NULL; -PFNGLTEXTURERENDERBUFFEREXTPROC __glewTextureRenderbufferEXT = NULL; -PFNGLTEXTURESUBIMAGE1DEXTPROC __glewTextureSubImage1DEXT = NULL; -PFNGLTEXTURESUBIMAGE2DEXTPROC __glewTextureSubImage2DEXT = NULL; -PFNGLTEXTURESUBIMAGE3DEXTPROC __glewTextureSubImage3DEXT = NULL; -PFNGLUNMAPNAMEDBUFFEREXTPROC __glewUnmapNamedBufferEXT = NULL; -PFNGLVERTEXARRAYCOLOROFFSETEXTPROC __glewVertexArrayColorOffsetEXT = NULL; -PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC __glewVertexArrayEdgeFlagOffsetEXT = NULL; -PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC __glewVertexArrayFogCoordOffsetEXT = NULL; -PFNGLVERTEXARRAYINDEXOFFSETEXTPROC __glewVertexArrayIndexOffsetEXT = NULL; -PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC __glewVertexArrayMultiTexCoordOffsetEXT = NULL; -PFNGLVERTEXARRAYNORMALOFFSETEXTPROC __glewVertexArrayNormalOffsetEXT = NULL; -PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC __glewVertexArraySecondaryColorOffsetEXT = NULL; -PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC __glewVertexArrayTexCoordOffsetEXT = NULL; -PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC __glewVertexArrayVertexAttribIOffsetEXT = NULL; -PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC __glewVertexArrayVertexAttribOffsetEXT = NULL; -PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC __glewVertexArrayVertexOffsetEXT = NULL; - -PFNGLCOLORMASKINDEXEDEXTPROC __glewColorMaskIndexedEXT = NULL; -PFNGLDISABLEINDEXEDEXTPROC __glewDisableIndexedEXT = NULL; -PFNGLENABLEINDEXEDEXTPROC __glewEnableIndexedEXT = NULL; -PFNGLGETBOOLEANINDEXEDVEXTPROC __glewGetBooleanIndexedvEXT = NULL; -PFNGLGETINTEGERINDEXEDVEXTPROC __glewGetIntegerIndexedvEXT = NULL; -PFNGLISENABLEDINDEXEDEXTPROC __glewIsEnabledIndexedEXT = NULL; - -PFNGLDRAWARRAYSINSTANCEDEXTPROC __glewDrawArraysInstancedEXT = NULL; -PFNGLDRAWELEMENTSINSTANCEDEXTPROC __glewDrawElementsInstancedEXT = NULL; - -PFNGLDRAWRANGEELEMENTSEXTPROC __glewDrawRangeElementsEXT = NULL; - -PFNGLFOGCOORDPOINTEREXTPROC __glewFogCoordPointerEXT = NULL; -PFNGLFOGCOORDDEXTPROC __glewFogCoorddEXT = NULL; -PFNGLFOGCOORDDVEXTPROC __glewFogCoorddvEXT = NULL; -PFNGLFOGCOORDFEXTPROC __glewFogCoordfEXT = NULL; -PFNGLFOGCOORDFVEXTPROC __glewFogCoordfvEXT = NULL; - -PFNGLFRAGMENTCOLORMATERIALEXTPROC __glewFragmentColorMaterialEXT = NULL; -PFNGLFRAGMENTLIGHTMODELFEXTPROC __glewFragmentLightModelfEXT = NULL; -PFNGLFRAGMENTLIGHTMODELFVEXTPROC __glewFragmentLightModelfvEXT = NULL; -PFNGLFRAGMENTLIGHTMODELIEXTPROC __glewFragmentLightModeliEXT = NULL; -PFNGLFRAGMENTLIGHTMODELIVEXTPROC __glewFragmentLightModelivEXT = NULL; -PFNGLFRAGMENTLIGHTFEXTPROC __glewFragmentLightfEXT = NULL; -PFNGLFRAGMENTLIGHTFVEXTPROC __glewFragmentLightfvEXT = NULL; -PFNGLFRAGMENTLIGHTIEXTPROC __glewFragmentLightiEXT = NULL; -PFNGLFRAGMENTLIGHTIVEXTPROC __glewFragmentLightivEXT = NULL; -PFNGLFRAGMENTMATERIALFEXTPROC __glewFragmentMaterialfEXT = NULL; -PFNGLFRAGMENTMATERIALFVEXTPROC __glewFragmentMaterialfvEXT = NULL; -PFNGLFRAGMENTMATERIALIEXTPROC __glewFragmentMaterialiEXT = NULL; -PFNGLFRAGMENTMATERIALIVEXTPROC __glewFragmentMaterialivEXT = NULL; -PFNGLGETFRAGMENTLIGHTFVEXTPROC __glewGetFragmentLightfvEXT = NULL; -PFNGLGETFRAGMENTLIGHTIVEXTPROC __glewGetFragmentLightivEXT = NULL; -PFNGLGETFRAGMENTMATERIALFVEXTPROC __glewGetFragmentMaterialfvEXT = NULL; -PFNGLGETFRAGMENTMATERIALIVEXTPROC __glewGetFragmentMaterialivEXT = NULL; -PFNGLLIGHTENVIEXTPROC __glewLightEnviEXT = NULL; - -PFNGLBLITFRAMEBUFFEREXTPROC __glewBlitFramebufferEXT = NULL; - -PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC __glewRenderbufferStorageMultisampleEXT = NULL; - -PFNGLBINDFRAMEBUFFEREXTPROC __glewBindFramebufferEXT = NULL; -PFNGLBINDRENDERBUFFEREXTPROC __glewBindRenderbufferEXT = NULL; -PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC __glewCheckFramebufferStatusEXT = NULL; -PFNGLDELETEFRAMEBUFFERSEXTPROC __glewDeleteFramebuffersEXT = NULL; -PFNGLDELETERENDERBUFFERSEXTPROC __glewDeleteRenderbuffersEXT = NULL; -PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC __glewFramebufferRenderbufferEXT = NULL; -PFNGLFRAMEBUFFERTEXTURE1DEXTPROC __glewFramebufferTexture1DEXT = NULL; -PFNGLFRAMEBUFFERTEXTURE2DEXTPROC __glewFramebufferTexture2DEXT = NULL; -PFNGLFRAMEBUFFERTEXTURE3DEXTPROC __glewFramebufferTexture3DEXT = NULL; -PFNGLGENFRAMEBUFFERSEXTPROC __glewGenFramebuffersEXT = NULL; -PFNGLGENRENDERBUFFERSEXTPROC __glewGenRenderbuffersEXT = NULL; -PFNGLGENERATEMIPMAPEXTPROC __glewGenerateMipmapEXT = NULL; -PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC __glewGetFramebufferAttachmentParameterivEXT = NULL; -PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC __glewGetRenderbufferParameterivEXT = NULL; -PFNGLISFRAMEBUFFEREXTPROC __glewIsFramebufferEXT = NULL; -PFNGLISRENDERBUFFEREXTPROC __glewIsRenderbufferEXT = NULL; -PFNGLRENDERBUFFERSTORAGEEXTPROC __glewRenderbufferStorageEXT = NULL; - -PFNGLFRAMEBUFFERTEXTUREEXTPROC __glewFramebufferTextureEXT = NULL; -PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC __glewFramebufferTextureFaceEXT = NULL; -PFNGLPROGRAMPARAMETERIEXTPROC __glewProgramParameteriEXT = NULL; - -PFNGLPROGRAMENVPARAMETERS4FVEXTPROC __glewProgramEnvParameters4fvEXT = NULL; -PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC __glewProgramLocalParameters4fvEXT = NULL; - -PFNGLBINDFRAGDATALOCATIONEXTPROC __glewBindFragDataLocationEXT = NULL; -PFNGLGETFRAGDATALOCATIONEXTPROC __glewGetFragDataLocationEXT = NULL; -PFNGLGETUNIFORMUIVEXTPROC __glewGetUniformuivEXT = NULL; -PFNGLGETVERTEXATTRIBIIVEXTPROC __glewGetVertexAttribIivEXT = NULL; -PFNGLGETVERTEXATTRIBIUIVEXTPROC __glewGetVertexAttribIuivEXT = NULL; -PFNGLUNIFORM1UIEXTPROC __glewUniform1uiEXT = NULL; -PFNGLUNIFORM1UIVEXTPROC __glewUniform1uivEXT = NULL; -PFNGLUNIFORM2UIEXTPROC __glewUniform2uiEXT = NULL; -PFNGLUNIFORM2UIVEXTPROC __glewUniform2uivEXT = NULL; -PFNGLUNIFORM3UIEXTPROC __glewUniform3uiEXT = NULL; -PFNGLUNIFORM3UIVEXTPROC __glewUniform3uivEXT = NULL; -PFNGLUNIFORM4UIEXTPROC __glewUniform4uiEXT = NULL; -PFNGLUNIFORM4UIVEXTPROC __glewUniform4uivEXT = NULL; -PFNGLVERTEXATTRIBI1IEXTPROC __glewVertexAttribI1iEXT = NULL; -PFNGLVERTEXATTRIBI1IVEXTPROC __glewVertexAttribI1ivEXT = NULL; -PFNGLVERTEXATTRIBI1UIEXTPROC __glewVertexAttribI1uiEXT = NULL; -PFNGLVERTEXATTRIBI1UIVEXTPROC __glewVertexAttribI1uivEXT = NULL; -PFNGLVERTEXATTRIBI2IEXTPROC __glewVertexAttribI2iEXT = NULL; -PFNGLVERTEXATTRIBI2IVEXTPROC __glewVertexAttribI2ivEXT = NULL; -PFNGLVERTEXATTRIBI2UIEXTPROC __glewVertexAttribI2uiEXT = NULL; -PFNGLVERTEXATTRIBI2UIVEXTPROC __glewVertexAttribI2uivEXT = NULL; -PFNGLVERTEXATTRIBI3IEXTPROC __glewVertexAttribI3iEXT = NULL; -PFNGLVERTEXATTRIBI3IVEXTPROC __glewVertexAttribI3ivEXT = NULL; -PFNGLVERTEXATTRIBI3UIEXTPROC __glewVertexAttribI3uiEXT = NULL; -PFNGLVERTEXATTRIBI3UIVEXTPROC __glewVertexAttribI3uivEXT = NULL; -PFNGLVERTEXATTRIBI4BVEXTPROC __glewVertexAttribI4bvEXT = NULL; -PFNGLVERTEXATTRIBI4IEXTPROC __glewVertexAttribI4iEXT = NULL; -PFNGLVERTEXATTRIBI4IVEXTPROC __glewVertexAttribI4ivEXT = NULL; -PFNGLVERTEXATTRIBI4SVEXTPROC __glewVertexAttribI4svEXT = NULL; -PFNGLVERTEXATTRIBI4UBVEXTPROC __glewVertexAttribI4ubvEXT = NULL; -PFNGLVERTEXATTRIBI4UIEXTPROC __glewVertexAttribI4uiEXT = NULL; -PFNGLVERTEXATTRIBI4UIVEXTPROC __glewVertexAttribI4uivEXT = NULL; -PFNGLVERTEXATTRIBI4USVEXTPROC __glewVertexAttribI4usvEXT = NULL; -PFNGLVERTEXATTRIBIPOINTEREXTPROC __glewVertexAttribIPointerEXT = NULL; - -PFNGLGETHISTOGRAMEXTPROC __glewGetHistogramEXT = NULL; -PFNGLGETHISTOGRAMPARAMETERFVEXTPROC __glewGetHistogramParameterfvEXT = NULL; -PFNGLGETHISTOGRAMPARAMETERIVEXTPROC __glewGetHistogramParameterivEXT = NULL; -PFNGLGETMINMAXEXTPROC __glewGetMinmaxEXT = NULL; -PFNGLGETMINMAXPARAMETERFVEXTPROC __glewGetMinmaxParameterfvEXT = NULL; -PFNGLGETMINMAXPARAMETERIVEXTPROC __glewGetMinmaxParameterivEXT = NULL; -PFNGLHISTOGRAMEXTPROC __glewHistogramEXT = NULL; -PFNGLMINMAXEXTPROC __glewMinmaxEXT = NULL; -PFNGLRESETHISTOGRAMEXTPROC __glewResetHistogramEXT = NULL; -PFNGLRESETMINMAXEXTPROC __glewResetMinmaxEXT = NULL; - -PFNGLINDEXFUNCEXTPROC __glewIndexFuncEXT = NULL; - -PFNGLINDEXMATERIALEXTPROC __glewIndexMaterialEXT = NULL; - -PFNGLAPPLYTEXTUREEXTPROC __glewApplyTextureEXT = NULL; -PFNGLTEXTURELIGHTEXTPROC __glewTextureLightEXT = NULL; -PFNGLTEXTUREMATERIALEXTPROC __glewTextureMaterialEXT = NULL; - -PFNGLMULTIDRAWARRAYSEXTPROC __glewMultiDrawArraysEXT = NULL; -PFNGLMULTIDRAWELEMENTSEXTPROC __glewMultiDrawElementsEXT = NULL; - -PFNGLSAMPLEMASKEXTPROC __glewSampleMaskEXT = NULL; -PFNGLSAMPLEPATTERNEXTPROC __glewSamplePatternEXT = NULL; - -PFNGLCOLORTABLEEXTPROC __glewColorTableEXT = NULL; -PFNGLGETCOLORTABLEEXTPROC __glewGetColorTableEXT = NULL; -PFNGLGETCOLORTABLEPARAMETERFVEXTPROC __glewGetColorTableParameterfvEXT = NULL; -PFNGLGETCOLORTABLEPARAMETERIVEXTPROC __glewGetColorTableParameterivEXT = NULL; - -PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC __glewGetPixelTransformParameterfvEXT = NULL; -PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC __glewGetPixelTransformParameterivEXT = NULL; -PFNGLPIXELTRANSFORMPARAMETERFEXTPROC __glewPixelTransformParameterfEXT = NULL; -PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC __glewPixelTransformParameterfvEXT = NULL; -PFNGLPIXELTRANSFORMPARAMETERIEXTPROC __glewPixelTransformParameteriEXT = NULL; -PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC __glewPixelTransformParameterivEXT = NULL; - -PFNGLPOINTPARAMETERFEXTPROC __glewPointParameterfEXT = NULL; -PFNGLPOINTPARAMETERFVEXTPROC __glewPointParameterfvEXT = NULL; - -PFNGLPOLYGONOFFSETEXTPROC __glewPolygonOffsetEXT = NULL; - -PFNGLPROVOKINGVERTEXEXTPROC __glewProvokingVertexEXT = NULL; - -PFNGLBEGINSCENEEXTPROC __glewBeginSceneEXT = NULL; -PFNGLENDSCENEEXTPROC __glewEndSceneEXT = NULL; - -PFNGLSECONDARYCOLOR3BEXTPROC __glewSecondaryColor3bEXT = NULL; -PFNGLSECONDARYCOLOR3BVEXTPROC __glewSecondaryColor3bvEXT = NULL; -PFNGLSECONDARYCOLOR3DEXTPROC __glewSecondaryColor3dEXT = NULL; -PFNGLSECONDARYCOLOR3DVEXTPROC __glewSecondaryColor3dvEXT = NULL; -PFNGLSECONDARYCOLOR3FEXTPROC __glewSecondaryColor3fEXT = NULL; -PFNGLSECONDARYCOLOR3FVEXTPROC __glewSecondaryColor3fvEXT = NULL; -PFNGLSECONDARYCOLOR3IEXTPROC __glewSecondaryColor3iEXT = NULL; -PFNGLSECONDARYCOLOR3IVEXTPROC __glewSecondaryColor3ivEXT = NULL; -PFNGLSECONDARYCOLOR3SEXTPROC __glewSecondaryColor3sEXT = NULL; -PFNGLSECONDARYCOLOR3SVEXTPROC __glewSecondaryColor3svEXT = NULL; -PFNGLSECONDARYCOLOR3UBEXTPROC __glewSecondaryColor3ubEXT = NULL; -PFNGLSECONDARYCOLOR3UBVEXTPROC __glewSecondaryColor3ubvEXT = NULL; -PFNGLSECONDARYCOLOR3UIEXTPROC __glewSecondaryColor3uiEXT = NULL; -PFNGLSECONDARYCOLOR3UIVEXTPROC __glewSecondaryColor3uivEXT = NULL; -PFNGLSECONDARYCOLOR3USEXTPROC __glewSecondaryColor3usEXT = NULL; -PFNGLSECONDARYCOLOR3USVEXTPROC __glewSecondaryColor3usvEXT = NULL; -PFNGLSECONDARYCOLORPOINTEREXTPROC __glewSecondaryColorPointerEXT = NULL; - -PFNGLACTIVEPROGRAMEXTPROC __glewActiveProgramEXT = NULL; -PFNGLCREATESHADERPROGRAMEXTPROC __glewCreateShaderProgramEXT = NULL; -PFNGLUSESHADERPROGRAMEXTPROC __glewUseShaderProgramEXT = NULL; - -PFNGLBINDIMAGETEXTUREEXTPROC __glewBindImageTextureEXT = NULL; -PFNGLMEMORYBARRIEREXTPROC __glewMemoryBarrierEXT = NULL; - -PFNGLACTIVESTENCILFACEEXTPROC __glewActiveStencilFaceEXT = NULL; - -PFNGLTEXSUBIMAGE1DEXTPROC __glewTexSubImage1DEXT = NULL; -PFNGLTEXSUBIMAGE2DEXTPROC __glewTexSubImage2DEXT = NULL; -PFNGLTEXSUBIMAGE3DEXTPROC __glewTexSubImage3DEXT = NULL; - -PFNGLTEXIMAGE3DEXTPROC __glewTexImage3DEXT = NULL; - -PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC __glewFramebufferTextureLayerEXT = NULL; - -PFNGLTEXBUFFEREXTPROC __glewTexBufferEXT = NULL; - -PFNGLCLEARCOLORIIEXTPROC __glewClearColorIiEXT = NULL; -PFNGLCLEARCOLORIUIEXTPROC __glewClearColorIuiEXT = NULL; -PFNGLGETTEXPARAMETERIIVEXTPROC __glewGetTexParameterIivEXT = NULL; -PFNGLGETTEXPARAMETERIUIVEXTPROC __glewGetTexParameterIuivEXT = NULL; -PFNGLTEXPARAMETERIIVEXTPROC __glewTexParameterIivEXT = NULL; -PFNGLTEXPARAMETERIUIVEXTPROC __glewTexParameterIuivEXT = NULL; - -PFNGLARETEXTURESRESIDENTEXTPROC __glewAreTexturesResidentEXT = NULL; -PFNGLBINDTEXTUREEXTPROC __glewBindTextureEXT = NULL; -PFNGLDELETETEXTURESEXTPROC __glewDeleteTexturesEXT = NULL; -PFNGLGENTEXTURESEXTPROC __glewGenTexturesEXT = NULL; -PFNGLISTEXTUREEXTPROC __glewIsTextureEXT = NULL; -PFNGLPRIORITIZETEXTURESEXTPROC __glewPrioritizeTexturesEXT = NULL; - -PFNGLTEXTURENORMALEXTPROC __glewTextureNormalEXT = NULL; - -PFNGLGETQUERYOBJECTI64VEXTPROC __glewGetQueryObjecti64vEXT = NULL; -PFNGLGETQUERYOBJECTUI64VEXTPROC __glewGetQueryObjectui64vEXT = NULL; - -PFNGLBEGINTRANSFORMFEEDBACKEXTPROC __glewBeginTransformFeedbackEXT = NULL; -PFNGLBINDBUFFERBASEEXTPROC __glewBindBufferBaseEXT = NULL; -PFNGLBINDBUFFEROFFSETEXTPROC __glewBindBufferOffsetEXT = NULL; -PFNGLBINDBUFFERRANGEEXTPROC __glewBindBufferRangeEXT = NULL; -PFNGLENDTRANSFORMFEEDBACKEXTPROC __glewEndTransformFeedbackEXT = NULL; -PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC __glewGetTransformFeedbackVaryingEXT = NULL; -PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC __glewTransformFeedbackVaryingsEXT = NULL; - -PFNGLARRAYELEMENTEXTPROC __glewArrayElementEXT = NULL; -PFNGLCOLORPOINTEREXTPROC __glewColorPointerEXT = NULL; -PFNGLDRAWARRAYSEXTPROC __glewDrawArraysEXT = NULL; -PFNGLEDGEFLAGPOINTEREXTPROC __glewEdgeFlagPointerEXT = NULL; -PFNGLINDEXPOINTEREXTPROC __glewIndexPointerEXT = NULL; -PFNGLNORMALPOINTEREXTPROC __glewNormalPointerEXT = NULL; -PFNGLTEXCOORDPOINTEREXTPROC __glewTexCoordPointerEXT = NULL; -PFNGLVERTEXPOINTEREXTPROC __glewVertexPointerEXT = NULL; - -PFNGLGETVERTEXATTRIBLDVEXTPROC __glewGetVertexAttribLdvEXT = NULL; -PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC __glewVertexArrayVertexAttribLOffsetEXT = NULL; -PFNGLVERTEXATTRIBL1DEXTPROC __glewVertexAttribL1dEXT = NULL; -PFNGLVERTEXATTRIBL1DVEXTPROC __glewVertexAttribL1dvEXT = NULL; -PFNGLVERTEXATTRIBL2DEXTPROC __glewVertexAttribL2dEXT = NULL; -PFNGLVERTEXATTRIBL2DVEXTPROC __glewVertexAttribL2dvEXT = NULL; -PFNGLVERTEXATTRIBL3DEXTPROC __glewVertexAttribL3dEXT = NULL; -PFNGLVERTEXATTRIBL3DVEXTPROC __glewVertexAttribL3dvEXT = NULL; -PFNGLVERTEXATTRIBL4DEXTPROC __glewVertexAttribL4dEXT = NULL; -PFNGLVERTEXATTRIBL4DVEXTPROC __glewVertexAttribL4dvEXT = NULL; -PFNGLVERTEXATTRIBLPOINTEREXTPROC __glewVertexAttribLPointerEXT = NULL; - -PFNGLBEGINVERTEXSHADEREXTPROC __glewBeginVertexShaderEXT = NULL; -PFNGLBINDLIGHTPARAMETEREXTPROC __glewBindLightParameterEXT = NULL; -PFNGLBINDMATERIALPARAMETEREXTPROC __glewBindMaterialParameterEXT = NULL; -PFNGLBINDPARAMETEREXTPROC __glewBindParameterEXT = NULL; -PFNGLBINDTEXGENPARAMETEREXTPROC __glewBindTexGenParameterEXT = NULL; -PFNGLBINDTEXTUREUNITPARAMETEREXTPROC __glewBindTextureUnitParameterEXT = NULL; -PFNGLBINDVERTEXSHADEREXTPROC __glewBindVertexShaderEXT = NULL; -PFNGLDELETEVERTEXSHADEREXTPROC __glewDeleteVertexShaderEXT = NULL; -PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC __glewDisableVariantClientStateEXT = NULL; -PFNGLENABLEVARIANTCLIENTSTATEEXTPROC __glewEnableVariantClientStateEXT = NULL; -PFNGLENDVERTEXSHADEREXTPROC __glewEndVertexShaderEXT = NULL; -PFNGLEXTRACTCOMPONENTEXTPROC __glewExtractComponentEXT = NULL; -PFNGLGENSYMBOLSEXTPROC __glewGenSymbolsEXT = NULL; -PFNGLGENVERTEXSHADERSEXTPROC __glewGenVertexShadersEXT = NULL; -PFNGLGETINVARIANTBOOLEANVEXTPROC __glewGetInvariantBooleanvEXT = NULL; -PFNGLGETINVARIANTFLOATVEXTPROC __glewGetInvariantFloatvEXT = NULL; -PFNGLGETINVARIANTINTEGERVEXTPROC __glewGetInvariantIntegervEXT = NULL; -PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC __glewGetLocalConstantBooleanvEXT = NULL; -PFNGLGETLOCALCONSTANTFLOATVEXTPROC __glewGetLocalConstantFloatvEXT = NULL; -PFNGLGETLOCALCONSTANTINTEGERVEXTPROC __glewGetLocalConstantIntegervEXT = NULL; -PFNGLGETVARIANTBOOLEANVEXTPROC __glewGetVariantBooleanvEXT = NULL; -PFNGLGETVARIANTFLOATVEXTPROC __glewGetVariantFloatvEXT = NULL; -PFNGLGETVARIANTINTEGERVEXTPROC __glewGetVariantIntegervEXT = NULL; -PFNGLGETVARIANTPOINTERVEXTPROC __glewGetVariantPointervEXT = NULL; -PFNGLINSERTCOMPONENTEXTPROC __glewInsertComponentEXT = NULL; -PFNGLISVARIANTENABLEDEXTPROC __glewIsVariantEnabledEXT = NULL; -PFNGLSETINVARIANTEXTPROC __glewSetInvariantEXT = NULL; -PFNGLSETLOCALCONSTANTEXTPROC __glewSetLocalConstantEXT = NULL; -PFNGLSHADEROP1EXTPROC __glewShaderOp1EXT = NULL; -PFNGLSHADEROP2EXTPROC __glewShaderOp2EXT = NULL; -PFNGLSHADEROP3EXTPROC __glewShaderOp3EXT = NULL; -PFNGLSWIZZLEEXTPROC __glewSwizzleEXT = NULL; -PFNGLVARIANTPOINTEREXTPROC __glewVariantPointerEXT = NULL; -PFNGLVARIANTBVEXTPROC __glewVariantbvEXT = NULL; -PFNGLVARIANTDVEXTPROC __glewVariantdvEXT = NULL; -PFNGLVARIANTFVEXTPROC __glewVariantfvEXT = NULL; -PFNGLVARIANTIVEXTPROC __glewVariantivEXT = NULL; -PFNGLVARIANTSVEXTPROC __glewVariantsvEXT = NULL; -PFNGLVARIANTUBVEXTPROC __glewVariantubvEXT = NULL; -PFNGLVARIANTUIVEXTPROC __glewVariantuivEXT = NULL; -PFNGLVARIANTUSVEXTPROC __glewVariantusvEXT = NULL; -PFNGLWRITEMASKEXTPROC __glewWriteMaskEXT = NULL; - -PFNGLVERTEXWEIGHTPOINTEREXTPROC __glewVertexWeightPointerEXT = NULL; -PFNGLVERTEXWEIGHTFEXTPROC __glewVertexWeightfEXT = NULL; -PFNGLVERTEXWEIGHTFVEXTPROC __glewVertexWeightfvEXT = NULL; - -PFNGLIMPORTSYNCEXTPROC __glewImportSyncEXT = NULL; - -PFNGLFRAMETERMINATORGREMEDYPROC __glewFrameTerminatorGREMEDY = NULL; - -PFNGLSTRINGMARKERGREMEDYPROC __glewStringMarkerGREMEDY = NULL; - -PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC __glewGetImageTransformParameterfvHP = NULL; -PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC __glewGetImageTransformParameterivHP = NULL; -PFNGLIMAGETRANSFORMPARAMETERFHPPROC __glewImageTransformParameterfHP = NULL; -PFNGLIMAGETRANSFORMPARAMETERFVHPPROC __glewImageTransformParameterfvHP = NULL; -PFNGLIMAGETRANSFORMPARAMETERIHPPROC __glewImageTransformParameteriHP = NULL; -PFNGLIMAGETRANSFORMPARAMETERIVHPPROC __glewImageTransformParameterivHP = NULL; - -PFNGLMULTIMODEDRAWARRAYSIBMPROC __glewMultiModeDrawArraysIBM = NULL; -PFNGLMULTIMODEDRAWELEMENTSIBMPROC __glewMultiModeDrawElementsIBM = NULL; - -PFNGLCOLORPOINTERLISTIBMPROC __glewColorPointerListIBM = NULL; -PFNGLEDGEFLAGPOINTERLISTIBMPROC __glewEdgeFlagPointerListIBM = NULL; -PFNGLFOGCOORDPOINTERLISTIBMPROC __glewFogCoordPointerListIBM = NULL; -PFNGLINDEXPOINTERLISTIBMPROC __glewIndexPointerListIBM = NULL; -PFNGLNORMALPOINTERLISTIBMPROC __glewNormalPointerListIBM = NULL; -PFNGLSECONDARYCOLORPOINTERLISTIBMPROC __glewSecondaryColorPointerListIBM = NULL; -PFNGLTEXCOORDPOINTERLISTIBMPROC __glewTexCoordPointerListIBM = NULL; -PFNGLVERTEXPOINTERLISTIBMPROC __glewVertexPointerListIBM = NULL; - -PFNGLMAPTEXTURE2DINTELPROC __glewMapTexture2DINTEL = NULL; -PFNGLSYNCTEXTUREINTELPROC __glewSyncTextureINTEL = NULL; -PFNGLUNMAPTEXTURE2DINTELPROC __glewUnmapTexture2DINTEL = NULL; - -PFNGLCOLORPOINTERVINTELPROC __glewColorPointervINTEL = NULL; -PFNGLNORMALPOINTERVINTELPROC __glewNormalPointervINTEL = NULL; -PFNGLTEXCOORDPOINTERVINTELPROC __glewTexCoordPointervINTEL = NULL; -PFNGLVERTEXPOINTERVINTELPROC __glewVertexPointervINTEL = NULL; - -PFNGLTEXSCISSORFUNCINTELPROC __glewTexScissorFuncINTEL = NULL; -PFNGLTEXSCISSORINTELPROC __glewTexScissorINTEL = NULL; - -PFNGLDEBUGMESSAGECALLBACKPROC __glewDebugMessageCallback = NULL; -PFNGLDEBUGMESSAGECONTROLPROC __glewDebugMessageControl = NULL; -PFNGLDEBUGMESSAGEINSERTPROC __glewDebugMessageInsert = NULL; -PFNGLGETDEBUGMESSAGELOGPROC __glewGetDebugMessageLog = NULL; -PFNGLGETOBJECTLABELPROC __glewGetObjectLabel = NULL; -PFNGLGETOBJECTPTRLABELPROC __glewGetObjectPtrLabel = NULL; -PFNGLOBJECTLABELPROC __glewObjectLabel = NULL; -PFNGLOBJECTPTRLABELPROC __glewObjectPtrLabel = NULL; -PFNGLPOPDEBUGGROUPPROC __glewPopDebugGroup = NULL; -PFNGLPUSHDEBUGGROUPPROC __glewPushDebugGroup = NULL; - -PFNGLBUFFERREGIONENABLEDPROC __glewBufferRegionEnabled = NULL; -PFNGLDELETEBUFFERREGIONPROC __glewDeleteBufferRegion = NULL; -PFNGLDRAWBUFFERREGIONPROC __glewDrawBufferRegion = NULL; -PFNGLNEWBUFFERREGIONPROC __glewNewBufferRegion = NULL; -PFNGLREADBUFFERREGIONPROC __glewReadBufferRegion = NULL; - -PFNGLRESIZEBUFFERSMESAPROC __glewResizeBuffersMESA = NULL; - -PFNGLWINDOWPOS2DMESAPROC __glewWindowPos2dMESA = NULL; -PFNGLWINDOWPOS2DVMESAPROC __glewWindowPos2dvMESA = NULL; -PFNGLWINDOWPOS2FMESAPROC __glewWindowPos2fMESA = NULL; -PFNGLWINDOWPOS2FVMESAPROC __glewWindowPos2fvMESA = NULL; -PFNGLWINDOWPOS2IMESAPROC __glewWindowPos2iMESA = NULL; -PFNGLWINDOWPOS2IVMESAPROC __glewWindowPos2ivMESA = NULL; -PFNGLWINDOWPOS2SMESAPROC __glewWindowPos2sMESA = NULL; -PFNGLWINDOWPOS2SVMESAPROC __glewWindowPos2svMESA = NULL; -PFNGLWINDOWPOS3DMESAPROC __glewWindowPos3dMESA = NULL; -PFNGLWINDOWPOS3DVMESAPROC __glewWindowPos3dvMESA = NULL; -PFNGLWINDOWPOS3FMESAPROC __glewWindowPos3fMESA = NULL; -PFNGLWINDOWPOS3FVMESAPROC __glewWindowPos3fvMESA = NULL; -PFNGLWINDOWPOS3IMESAPROC __glewWindowPos3iMESA = NULL; -PFNGLWINDOWPOS3IVMESAPROC __glewWindowPos3ivMESA = NULL; -PFNGLWINDOWPOS3SMESAPROC __glewWindowPos3sMESA = NULL; -PFNGLWINDOWPOS3SVMESAPROC __glewWindowPos3svMESA = NULL; -PFNGLWINDOWPOS4DMESAPROC __glewWindowPos4dMESA = NULL; -PFNGLWINDOWPOS4DVMESAPROC __glewWindowPos4dvMESA = NULL; -PFNGLWINDOWPOS4FMESAPROC __glewWindowPos4fMESA = NULL; -PFNGLWINDOWPOS4FVMESAPROC __glewWindowPos4fvMESA = NULL; -PFNGLWINDOWPOS4IMESAPROC __glewWindowPos4iMESA = NULL; -PFNGLWINDOWPOS4IVMESAPROC __glewWindowPos4ivMESA = NULL; -PFNGLWINDOWPOS4SMESAPROC __glewWindowPos4sMESA = NULL; -PFNGLWINDOWPOS4SVMESAPROC __glewWindowPos4svMESA = NULL; - -PFNGLBEGINCONDITIONALRENDERNVXPROC __glewBeginConditionalRenderNVX = NULL; -PFNGLENDCONDITIONALRENDERNVXPROC __glewEndConditionalRenderNVX = NULL; - -PFNGLMULTIDRAWARRAYSINDIRECTBINDLESSNVPROC __glewMultiDrawArraysIndirectBindlessNV = NULL; -PFNGLMULTIDRAWELEMENTSINDIRECTBINDLESSNVPROC __glewMultiDrawElementsIndirectBindlessNV = NULL; - -PFNGLGETIMAGEHANDLENVPROC __glewGetImageHandleNV = NULL; -PFNGLGETTEXTUREHANDLENVPROC __glewGetTextureHandleNV = NULL; -PFNGLGETTEXTURESAMPLERHANDLENVPROC __glewGetTextureSamplerHandleNV = NULL; -PFNGLISIMAGEHANDLERESIDENTNVPROC __glewIsImageHandleResidentNV = NULL; -PFNGLISTEXTUREHANDLERESIDENTNVPROC __glewIsTextureHandleResidentNV = NULL; -PFNGLMAKEIMAGEHANDLENONRESIDENTNVPROC __glewMakeImageHandleNonResidentNV = NULL; -PFNGLMAKEIMAGEHANDLERESIDENTNVPROC __glewMakeImageHandleResidentNV = NULL; -PFNGLMAKETEXTUREHANDLENONRESIDENTNVPROC __glewMakeTextureHandleNonResidentNV = NULL; -PFNGLMAKETEXTUREHANDLERESIDENTNVPROC __glewMakeTextureHandleResidentNV = NULL; -PFNGLPROGRAMUNIFORMHANDLEUI64NVPROC __glewProgramUniformHandleui64NV = NULL; -PFNGLPROGRAMUNIFORMHANDLEUI64VNVPROC __glewProgramUniformHandleui64vNV = NULL; -PFNGLUNIFORMHANDLEUI64NVPROC __glewUniformHandleui64NV = NULL; -PFNGLUNIFORMHANDLEUI64VNVPROC __glewUniformHandleui64vNV = NULL; - -PFNGLBLENDBARRIERNVPROC __glewBlendBarrierNV = NULL; -PFNGLBLENDPARAMETERINVPROC __glewBlendParameteriNV = NULL; - -PFNGLBEGINCONDITIONALRENDERNVPROC __glewBeginConditionalRenderNV = NULL; -PFNGLENDCONDITIONALRENDERNVPROC __glewEndConditionalRenderNV = NULL; - -PFNGLCOPYIMAGESUBDATANVPROC __glewCopyImageSubDataNV = NULL; - -PFNGLCLEARDEPTHDNVPROC __glewClearDepthdNV = NULL; -PFNGLDEPTHBOUNDSDNVPROC __glewDepthBoundsdNV = NULL; -PFNGLDEPTHRANGEDNVPROC __glewDepthRangedNV = NULL; - -PFNGLDRAWTEXTURENVPROC __glewDrawTextureNV = NULL; - -PFNGLEVALMAPSNVPROC __glewEvalMapsNV = NULL; -PFNGLGETMAPATTRIBPARAMETERFVNVPROC __glewGetMapAttribParameterfvNV = NULL; -PFNGLGETMAPATTRIBPARAMETERIVNVPROC __glewGetMapAttribParameterivNV = NULL; -PFNGLGETMAPCONTROLPOINTSNVPROC __glewGetMapControlPointsNV = NULL; -PFNGLGETMAPPARAMETERFVNVPROC __glewGetMapParameterfvNV = NULL; -PFNGLGETMAPPARAMETERIVNVPROC __glewGetMapParameterivNV = NULL; -PFNGLMAPCONTROLPOINTSNVPROC __glewMapControlPointsNV = NULL; -PFNGLMAPPARAMETERFVNVPROC __glewMapParameterfvNV = NULL; -PFNGLMAPPARAMETERIVNVPROC __glewMapParameterivNV = NULL; - -PFNGLGETMULTISAMPLEFVNVPROC __glewGetMultisamplefvNV = NULL; -PFNGLSAMPLEMASKINDEXEDNVPROC __glewSampleMaskIndexedNV = NULL; -PFNGLTEXRENDERBUFFERNVPROC __glewTexRenderbufferNV = NULL; - -PFNGLDELETEFENCESNVPROC __glewDeleteFencesNV = NULL; -PFNGLFINISHFENCENVPROC __glewFinishFenceNV = NULL; -PFNGLGENFENCESNVPROC __glewGenFencesNV = NULL; -PFNGLGETFENCEIVNVPROC __glewGetFenceivNV = NULL; -PFNGLISFENCENVPROC __glewIsFenceNV = NULL; -PFNGLSETFENCENVPROC __glewSetFenceNV = NULL; -PFNGLTESTFENCENVPROC __glewTestFenceNV = NULL; - -PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC __glewGetProgramNamedParameterdvNV = NULL; -PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC __glewGetProgramNamedParameterfvNV = NULL; -PFNGLPROGRAMNAMEDPARAMETER4DNVPROC __glewProgramNamedParameter4dNV = NULL; -PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC __glewProgramNamedParameter4dvNV = NULL; -PFNGLPROGRAMNAMEDPARAMETER4FNVPROC __glewProgramNamedParameter4fNV = NULL; -PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC __glewProgramNamedParameter4fvNV = NULL; - -PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC __glewRenderbufferStorageMultisampleCoverageNV = NULL; - -PFNGLPROGRAMVERTEXLIMITNVPROC __glewProgramVertexLimitNV = NULL; - -PFNGLPROGRAMENVPARAMETERI4INVPROC __glewProgramEnvParameterI4iNV = NULL; -PFNGLPROGRAMENVPARAMETERI4IVNVPROC __glewProgramEnvParameterI4ivNV = NULL; -PFNGLPROGRAMENVPARAMETERI4UINVPROC __glewProgramEnvParameterI4uiNV = NULL; -PFNGLPROGRAMENVPARAMETERI4UIVNVPROC __glewProgramEnvParameterI4uivNV = NULL; -PFNGLPROGRAMENVPARAMETERSI4IVNVPROC __glewProgramEnvParametersI4ivNV = NULL; -PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC __glewProgramEnvParametersI4uivNV = NULL; -PFNGLPROGRAMLOCALPARAMETERI4INVPROC __glewProgramLocalParameterI4iNV = NULL; -PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC __glewProgramLocalParameterI4ivNV = NULL; -PFNGLPROGRAMLOCALPARAMETERI4UINVPROC __glewProgramLocalParameterI4uiNV = NULL; -PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC __glewProgramLocalParameterI4uivNV = NULL; -PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC __glewProgramLocalParametersI4ivNV = NULL; -PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC __glewProgramLocalParametersI4uivNV = NULL; - -PFNGLGETUNIFORMI64VNVPROC __glewGetUniformi64vNV = NULL; -PFNGLGETUNIFORMUI64VNVPROC __glewGetUniformui64vNV = NULL; -PFNGLPROGRAMUNIFORM1I64NVPROC __glewProgramUniform1i64NV = NULL; -PFNGLPROGRAMUNIFORM1I64VNVPROC __glewProgramUniform1i64vNV = NULL; -PFNGLPROGRAMUNIFORM1UI64NVPROC __glewProgramUniform1ui64NV = NULL; -PFNGLPROGRAMUNIFORM1UI64VNVPROC __glewProgramUniform1ui64vNV = NULL; -PFNGLPROGRAMUNIFORM2I64NVPROC __glewProgramUniform2i64NV = NULL; -PFNGLPROGRAMUNIFORM2I64VNVPROC __glewProgramUniform2i64vNV = NULL; -PFNGLPROGRAMUNIFORM2UI64NVPROC __glewProgramUniform2ui64NV = NULL; -PFNGLPROGRAMUNIFORM2UI64VNVPROC __glewProgramUniform2ui64vNV = NULL; -PFNGLPROGRAMUNIFORM3I64NVPROC __glewProgramUniform3i64NV = NULL; -PFNGLPROGRAMUNIFORM3I64VNVPROC __glewProgramUniform3i64vNV = NULL; -PFNGLPROGRAMUNIFORM3UI64NVPROC __glewProgramUniform3ui64NV = NULL; -PFNGLPROGRAMUNIFORM3UI64VNVPROC __glewProgramUniform3ui64vNV = NULL; -PFNGLPROGRAMUNIFORM4I64NVPROC __glewProgramUniform4i64NV = NULL; -PFNGLPROGRAMUNIFORM4I64VNVPROC __glewProgramUniform4i64vNV = NULL; -PFNGLPROGRAMUNIFORM4UI64NVPROC __glewProgramUniform4ui64NV = NULL; -PFNGLPROGRAMUNIFORM4UI64VNVPROC __glewProgramUniform4ui64vNV = NULL; -PFNGLUNIFORM1I64NVPROC __glewUniform1i64NV = NULL; -PFNGLUNIFORM1I64VNVPROC __glewUniform1i64vNV = NULL; -PFNGLUNIFORM1UI64NVPROC __glewUniform1ui64NV = NULL; -PFNGLUNIFORM1UI64VNVPROC __glewUniform1ui64vNV = NULL; -PFNGLUNIFORM2I64NVPROC __glewUniform2i64NV = NULL; -PFNGLUNIFORM2I64VNVPROC __glewUniform2i64vNV = NULL; -PFNGLUNIFORM2UI64NVPROC __glewUniform2ui64NV = NULL; -PFNGLUNIFORM2UI64VNVPROC __glewUniform2ui64vNV = NULL; -PFNGLUNIFORM3I64NVPROC __glewUniform3i64NV = NULL; -PFNGLUNIFORM3I64VNVPROC __glewUniform3i64vNV = NULL; -PFNGLUNIFORM3UI64NVPROC __glewUniform3ui64NV = NULL; -PFNGLUNIFORM3UI64VNVPROC __glewUniform3ui64vNV = NULL; -PFNGLUNIFORM4I64NVPROC __glewUniform4i64NV = NULL; -PFNGLUNIFORM4I64VNVPROC __glewUniform4i64vNV = NULL; -PFNGLUNIFORM4UI64NVPROC __glewUniform4ui64NV = NULL; -PFNGLUNIFORM4UI64VNVPROC __glewUniform4ui64vNV = NULL; - -PFNGLCOLOR3HNVPROC __glewColor3hNV = NULL; -PFNGLCOLOR3HVNVPROC __glewColor3hvNV = NULL; -PFNGLCOLOR4HNVPROC __glewColor4hNV = NULL; -PFNGLCOLOR4HVNVPROC __glewColor4hvNV = NULL; -PFNGLFOGCOORDHNVPROC __glewFogCoordhNV = NULL; -PFNGLFOGCOORDHVNVPROC __glewFogCoordhvNV = NULL; -PFNGLMULTITEXCOORD1HNVPROC __glewMultiTexCoord1hNV = NULL; -PFNGLMULTITEXCOORD1HVNVPROC __glewMultiTexCoord1hvNV = NULL; -PFNGLMULTITEXCOORD2HNVPROC __glewMultiTexCoord2hNV = NULL; -PFNGLMULTITEXCOORD2HVNVPROC __glewMultiTexCoord2hvNV = NULL; -PFNGLMULTITEXCOORD3HNVPROC __glewMultiTexCoord3hNV = NULL; -PFNGLMULTITEXCOORD3HVNVPROC __glewMultiTexCoord3hvNV = NULL; -PFNGLMULTITEXCOORD4HNVPROC __glewMultiTexCoord4hNV = NULL; -PFNGLMULTITEXCOORD4HVNVPROC __glewMultiTexCoord4hvNV = NULL; -PFNGLNORMAL3HNVPROC __glewNormal3hNV = NULL; -PFNGLNORMAL3HVNVPROC __glewNormal3hvNV = NULL; -PFNGLSECONDARYCOLOR3HNVPROC __glewSecondaryColor3hNV = NULL; -PFNGLSECONDARYCOLOR3HVNVPROC __glewSecondaryColor3hvNV = NULL; -PFNGLTEXCOORD1HNVPROC __glewTexCoord1hNV = NULL; -PFNGLTEXCOORD1HVNVPROC __glewTexCoord1hvNV = NULL; -PFNGLTEXCOORD2HNVPROC __glewTexCoord2hNV = NULL; -PFNGLTEXCOORD2HVNVPROC __glewTexCoord2hvNV = NULL; -PFNGLTEXCOORD3HNVPROC __glewTexCoord3hNV = NULL; -PFNGLTEXCOORD3HVNVPROC __glewTexCoord3hvNV = NULL; -PFNGLTEXCOORD4HNVPROC __glewTexCoord4hNV = NULL; -PFNGLTEXCOORD4HVNVPROC __glewTexCoord4hvNV = NULL; -PFNGLVERTEX2HNVPROC __glewVertex2hNV = NULL; -PFNGLVERTEX2HVNVPROC __glewVertex2hvNV = NULL; -PFNGLVERTEX3HNVPROC __glewVertex3hNV = NULL; -PFNGLVERTEX3HVNVPROC __glewVertex3hvNV = NULL; -PFNGLVERTEX4HNVPROC __glewVertex4hNV = NULL; -PFNGLVERTEX4HVNVPROC __glewVertex4hvNV = NULL; -PFNGLVERTEXATTRIB1HNVPROC __glewVertexAttrib1hNV = NULL; -PFNGLVERTEXATTRIB1HVNVPROC __glewVertexAttrib1hvNV = NULL; -PFNGLVERTEXATTRIB2HNVPROC __glewVertexAttrib2hNV = NULL; -PFNGLVERTEXATTRIB2HVNVPROC __glewVertexAttrib2hvNV = NULL; -PFNGLVERTEXATTRIB3HNVPROC __glewVertexAttrib3hNV = NULL; -PFNGLVERTEXATTRIB3HVNVPROC __glewVertexAttrib3hvNV = NULL; -PFNGLVERTEXATTRIB4HNVPROC __glewVertexAttrib4hNV = NULL; -PFNGLVERTEXATTRIB4HVNVPROC __glewVertexAttrib4hvNV = NULL; -PFNGLVERTEXATTRIBS1HVNVPROC __glewVertexAttribs1hvNV = NULL; -PFNGLVERTEXATTRIBS2HVNVPROC __glewVertexAttribs2hvNV = NULL; -PFNGLVERTEXATTRIBS3HVNVPROC __glewVertexAttribs3hvNV = NULL; -PFNGLVERTEXATTRIBS4HVNVPROC __glewVertexAttribs4hvNV = NULL; -PFNGLVERTEXWEIGHTHNVPROC __glewVertexWeighthNV = NULL; -PFNGLVERTEXWEIGHTHVNVPROC __glewVertexWeighthvNV = NULL; - -PFNGLBEGINOCCLUSIONQUERYNVPROC __glewBeginOcclusionQueryNV = NULL; -PFNGLDELETEOCCLUSIONQUERIESNVPROC __glewDeleteOcclusionQueriesNV = NULL; -PFNGLENDOCCLUSIONQUERYNVPROC __glewEndOcclusionQueryNV = NULL; -PFNGLGENOCCLUSIONQUERIESNVPROC __glewGenOcclusionQueriesNV = NULL; -PFNGLGETOCCLUSIONQUERYIVNVPROC __glewGetOcclusionQueryivNV = NULL; -PFNGLGETOCCLUSIONQUERYUIVNVPROC __glewGetOcclusionQueryuivNV = NULL; -PFNGLISOCCLUSIONQUERYNVPROC __glewIsOcclusionQueryNV = NULL; - -PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC __glewProgramBufferParametersIivNV = NULL; -PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC __glewProgramBufferParametersIuivNV = NULL; -PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC __glewProgramBufferParametersfvNV = NULL; - -PFNGLCOPYPATHNVPROC __glewCopyPathNV = NULL; -PFNGLCOVERFILLPATHINSTANCEDNVPROC __glewCoverFillPathInstancedNV = NULL; -PFNGLCOVERFILLPATHNVPROC __glewCoverFillPathNV = NULL; -PFNGLCOVERSTROKEPATHINSTANCEDNVPROC __glewCoverStrokePathInstancedNV = NULL; -PFNGLCOVERSTROKEPATHNVPROC __glewCoverStrokePathNV = NULL; -PFNGLDELETEPATHSNVPROC __glewDeletePathsNV = NULL; -PFNGLGENPATHSNVPROC __glewGenPathsNV = NULL; -PFNGLGETPATHCOLORGENFVNVPROC __glewGetPathColorGenfvNV = NULL; -PFNGLGETPATHCOLORGENIVNVPROC __glewGetPathColorGenivNV = NULL; -PFNGLGETPATHCOMMANDSNVPROC __glewGetPathCommandsNV = NULL; -PFNGLGETPATHCOORDSNVPROC __glewGetPathCoordsNV = NULL; -PFNGLGETPATHDASHARRAYNVPROC __glewGetPathDashArrayNV = NULL; -PFNGLGETPATHLENGTHNVPROC __glewGetPathLengthNV = NULL; -PFNGLGETPATHMETRICRANGENVPROC __glewGetPathMetricRangeNV = NULL; -PFNGLGETPATHMETRICSNVPROC __glewGetPathMetricsNV = NULL; -PFNGLGETPATHPARAMETERFVNVPROC __glewGetPathParameterfvNV = NULL; -PFNGLGETPATHPARAMETERIVNVPROC __glewGetPathParameterivNV = NULL; -PFNGLGETPATHSPACINGNVPROC __glewGetPathSpacingNV = NULL; -PFNGLGETPATHTEXGENFVNVPROC __glewGetPathTexGenfvNV = NULL; -PFNGLGETPATHTEXGENIVNVPROC __glewGetPathTexGenivNV = NULL; -PFNGLINTERPOLATEPATHSNVPROC __glewInterpolatePathsNV = NULL; -PFNGLISPATHNVPROC __glewIsPathNV = NULL; -PFNGLISPOINTINFILLPATHNVPROC __glewIsPointInFillPathNV = NULL; -PFNGLISPOINTINSTROKEPATHNVPROC __glewIsPointInStrokePathNV = NULL; -PFNGLPATHCOLORGENNVPROC __glewPathColorGenNV = NULL; -PFNGLPATHCOMMANDSNVPROC __glewPathCommandsNV = NULL; -PFNGLPATHCOORDSNVPROC __glewPathCoordsNV = NULL; -PFNGLPATHCOVERDEPTHFUNCNVPROC __glewPathCoverDepthFuncNV = NULL; -PFNGLPATHDASHARRAYNVPROC __glewPathDashArrayNV = NULL; -PFNGLPATHFOGGENNVPROC __glewPathFogGenNV = NULL; -PFNGLPATHGLYPHRANGENVPROC __glewPathGlyphRangeNV = NULL; -PFNGLPATHGLYPHSNVPROC __glewPathGlyphsNV = NULL; -PFNGLPATHPARAMETERFNVPROC __glewPathParameterfNV = NULL; -PFNGLPATHPARAMETERFVNVPROC __glewPathParameterfvNV = NULL; -PFNGLPATHPARAMETERINVPROC __glewPathParameteriNV = NULL; -PFNGLPATHPARAMETERIVNVPROC __glewPathParameterivNV = NULL; -PFNGLPATHSTENCILDEPTHOFFSETNVPROC __glewPathStencilDepthOffsetNV = NULL; -PFNGLPATHSTENCILFUNCNVPROC __glewPathStencilFuncNV = NULL; -PFNGLPATHSTRINGNVPROC __glewPathStringNV = NULL; -PFNGLPATHSUBCOMMANDSNVPROC __glewPathSubCommandsNV = NULL; -PFNGLPATHSUBCOORDSNVPROC __glewPathSubCoordsNV = NULL; -PFNGLPATHTEXGENNVPROC __glewPathTexGenNV = NULL; -PFNGLPOINTALONGPATHNVPROC __glewPointAlongPathNV = NULL; -PFNGLSTENCILFILLPATHINSTANCEDNVPROC __glewStencilFillPathInstancedNV = NULL; -PFNGLSTENCILFILLPATHNVPROC __glewStencilFillPathNV = NULL; -PFNGLSTENCILSTROKEPATHINSTANCEDNVPROC __glewStencilStrokePathInstancedNV = NULL; -PFNGLSTENCILSTROKEPATHNVPROC __glewStencilStrokePathNV = NULL; -PFNGLTRANSFORMPATHNVPROC __glewTransformPathNV = NULL; -PFNGLWEIGHTPATHSNVPROC __glewWeightPathsNV = NULL; - -PFNGLFLUSHPIXELDATARANGENVPROC __glewFlushPixelDataRangeNV = NULL; -PFNGLPIXELDATARANGENVPROC __glewPixelDataRangeNV = NULL; - -PFNGLPOINTPARAMETERINVPROC __glewPointParameteriNV = NULL; -PFNGLPOINTPARAMETERIVNVPROC __glewPointParameterivNV = NULL; - -PFNGLGETVIDEOI64VNVPROC __glewGetVideoi64vNV = NULL; -PFNGLGETVIDEOIVNVPROC __glewGetVideoivNV = NULL; -PFNGLGETVIDEOUI64VNVPROC __glewGetVideoui64vNV = NULL; -PFNGLGETVIDEOUIVNVPROC __glewGetVideouivNV = NULL; -PFNGLPRESENTFRAMEDUALFILLNVPROC __glewPresentFrameDualFillNV = NULL; -PFNGLPRESENTFRAMEKEYEDNVPROC __glewPresentFrameKeyedNV = NULL; - -PFNGLPRIMITIVERESTARTINDEXNVPROC __glewPrimitiveRestartIndexNV = NULL; -PFNGLPRIMITIVERESTARTNVPROC __glewPrimitiveRestartNV = NULL; - -PFNGLCOMBINERINPUTNVPROC __glewCombinerInputNV = NULL; -PFNGLCOMBINEROUTPUTNVPROC __glewCombinerOutputNV = NULL; -PFNGLCOMBINERPARAMETERFNVPROC __glewCombinerParameterfNV = NULL; -PFNGLCOMBINERPARAMETERFVNVPROC __glewCombinerParameterfvNV = NULL; -PFNGLCOMBINERPARAMETERINVPROC __glewCombinerParameteriNV = NULL; -PFNGLCOMBINERPARAMETERIVNVPROC __glewCombinerParameterivNV = NULL; -PFNGLFINALCOMBINERINPUTNVPROC __glewFinalCombinerInputNV = NULL; -PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC __glewGetCombinerInputParameterfvNV = NULL; -PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC __glewGetCombinerInputParameterivNV = NULL; -PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC __glewGetCombinerOutputParameterfvNV = NULL; -PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC __glewGetCombinerOutputParameterivNV = NULL; -PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC __glewGetFinalCombinerInputParameterfvNV = NULL; -PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC __glewGetFinalCombinerInputParameterivNV = NULL; - -PFNGLCOMBINERSTAGEPARAMETERFVNVPROC __glewCombinerStageParameterfvNV = NULL; -PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC __glewGetCombinerStageParameterfvNV = NULL; - -PFNGLGETBUFFERPARAMETERUI64VNVPROC __glewGetBufferParameterui64vNV = NULL; -PFNGLGETINTEGERUI64VNVPROC __glewGetIntegerui64vNV = NULL; -PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC __glewGetNamedBufferParameterui64vNV = NULL; -PFNGLISBUFFERRESIDENTNVPROC __glewIsBufferResidentNV = NULL; -PFNGLISNAMEDBUFFERRESIDENTNVPROC __glewIsNamedBufferResidentNV = NULL; -PFNGLMAKEBUFFERNONRESIDENTNVPROC __glewMakeBufferNonResidentNV = NULL; -PFNGLMAKEBUFFERRESIDENTNVPROC __glewMakeBufferResidentNV = NULL; -PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC __glewMakeNamedBufferNonResidentNV = NULL; -PFNGLMAKENAMEDBUFFERRESIDENTNVPROC __glewMakeNamedBufferResidentNV = NULL; -PFNGLPROGRAMUNIFORMUI64NVPROC __glewProgramUniformui64NV = NULL; -PFNGLPROGRAMUNIFORMUI64VNVPROC __glewProgramUniformui64vNV = NULL; -PFNGLUNIFORMUI64NVPROC __glewUniformui64NV = NULL; -PFNGLUNIFORMUI64VNVPROC __glewUniformui64vNV = NULL; - -PFNGLTEXTUREBARRIERNVPROC __glewTextureBarrierNV = NULL; - -PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC __glewTexImage2DMultisampleCoverageNV = NULL; -PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC __glewTexImage3DMultisampleCoverageNV = NULL; -PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC __glewTextureImage2DMultisampleCoverageNV = NULL; -PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC __glewTextureImage2DMultisampleNV = NULL; -PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC __glewTextureImage3DMultisampleCoverageNV = NULL; -PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC __glewTextureImage3DMultisampleNV = NULL; - -PFNGLACTIVEVARYINGNVPROC __glewActiveVaryingNV = NULL; -PFNGLBEGINTRANSFORMFEEDBACKNVPROC __glewBeginTransformFeedbackNV = NULL; -PFNGLBINDBUFFERBASENVPROC __glewBindBufferBaseNV = NULL; -PFNGLBINDBUFFEROFFSETNVPROC __glewBindBufferOffsetNV = NULL; -PFNGLBINDBUFFERRANGENVPROC __glewBindBufferRangeNV = NULL; -PFNGLENDTRANSFORMFEEDBACKNVPROC __glewEndTransformFeedbackNV = NULL; -PFNGLGETACTIVEVARYINGNVPROC __glewGetActiveVaryingNV = NULL; -PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC __glewGetTransformFeedbackVaryingNV = NULL; -PFNGLGETVARYINGLOCATIONNVPROC __glewGetVaryingLocationNV = NULL; -PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC __glewTransformFeedbackAttribsNV = NULL; -PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC __glewTransformFeedbackVaryingsNV = NULL; - -PFNGLBINDTRANSFORMFEEDBACKNVPROC __glewBindTransformFeedbackNV = NULL; -PFNGLDELETETRANSFORMFEEDBACKSNVPROC __glewDeleteTransformFeedbacksNV = NULL; -PFNGLDRAWTRANSFORMFEEDBACKNVPROC __glewDrawTransformFeedbackNV = NULL; -PFNGLGENTRANSFORMFEEDBACKSNVPROC __glewGenTransformFeedbacksNV = NULL; -PFNGLISTRANSFORMFEEDBACKNVPROC __glewIsTransformFeedbackNV = NULL; -PFNGLPAUSETRANSFORMFEEDBACKNVPROC __glewPauseTransformFeedbackNV = NULL; -PFNGLRESUMETRANSFORMFEEDBACKNVPROC __glewResumeTransformFeedbackNV = NULL; - -PFNGLVDPAUFININVPROC __glewVDPAUFiniNV = NULL; -PFNGLVDPAUGETSURFACEIVNVPROC __glewVDPAUGetSurfaceivNV = NULL; -PFNGLVDPAUINITNVPROC __glewVDPAUInitNV = NULL; -PFNGLVDPAUISSURFACENVPROC __glewVDPAUIsSurfaceNV = NULL; -PFNGLVDPAUMAPSURFACESNVPROC __glewVDPAUMapSurfacesNV = NULL; -PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC __glewVDPAURegisterOutputSurfaceNV = NULL; -PFNGLVDPAUREGISTERVIDEOSURFACENVPROC __glewVDPAURegisterVideoSurfaceNV = NULL; -PFNGLVDPAUSURFACEACCESSNVPROC __glewVDPAUSurfaceAccessNV = NULL; -PFNGLVDPAUUNMAPSURFACESNVPROC __glewVDPAUUnmapSurfacesNV = NULL; -PFNGLVDPAUUNREGISTERSURFACENVPROC __glewVDPAUUnregisterSurfaceNV = NULL; - -PFNGLFLUSHVERTEXARRAYRANGENVPROC __glewFlushVertexArrayRangeNV = NULL; -PFNGLVERTEXARRAYRANGENVPROC __glewVertexArrayRangeNV = NULL; - -PFNGLGETVERTEXATTRIBLI64VNVPROC __glewGetVertexAttribLi64vNV = NULL; -PFNGLGETVERTEXATTRIBLUI64VNVPROC __glewGetVertexAttribLui64vNV = NULL; -PFNGLVERTEXATTRIBL1I64NVPROC __glewVertexAttribL1i64NV = NULL; -PFNGLVERTEXATTRIBL1I64VNVPROC __glewVertexAttribL1i64vNV = NULL; -PFNGLVERTEXATTRIBL1UI64NVPROC __glewVertexAttribL1ui64NV = NULL; -PFNGLVERTEXATTRIBL1UI64VNVPROC __glewVertexAttribL1ui64vNV = NULL; -PFNGLVERTEXATTRIBL2I64NVPROC __glewVertexAttribL2i64NV = NULL; -PFNGLVERTEXATTRIBL2I64VNVPROC __glewVertexAttribL2i64vNV = NULL; -PFNGLVERTEXATTRIBL2UI64NVPROC __glewVertexAttribL2ui64NV = NULL; -PFNGLVERTEXATTRIBL2UI64VNVPROC __glewVertexAttribL2ui64vNV = NULL; -PFNGLVERTEXATTRIBL3I64NVPROC __glewVertexAttribL3i64NV = NULL; -PFNGLVERTEXATTRIBL3I64VNVPROC __glewVertexAttribL3i64vNV = NULL; -PFNGLVERTEXATTRIBL3UI64NVPROC __glewVertexAttribL3ui64NV = NULL; -PFNGLVERTEXATTRIBL3UI64VNVPROC __glewVertexAttribL3ui64vNV = NULL; -PFNGLVERTEXATTRIBL4I64NVPROC __glewVertexAttribL4i64NV = NULL; -PFNGLVERTEXATTRIBL4I64VNVPROC __glewVertexAttribL4i64vNV = NULL; -PFNGLVERTEXATTRIBL4UI64NVPROC __glewVertexAttribL4ui64NV = NULL; -PFNGLVERTEXATTRIBL4UI64VNVPROC __glewVertexAttribL4ui64vNV = NULL; -PFNGLVERTEXATTRIBLFORMATNVPROC __glewVertexAttribLFormatNV = NULL; - -PFNGLBUFFERADDRESSRANGENVPROC __glewBufferAddressRangeNV = NULL; -PFNGLCOLORFORMATNVPROC __glewColorFormatNV = NULL; -PFNGLEDGEFLAGFORMATNVPROC __glewEdgeFlagFormatNV = NULL; -PFNGLFOGCOORDFORMATNVPROC __glewFogCoordFormatNV = NULL; -PFNGLGETINTEGERUI64I_VNVPROC __glewGetIntegerui64i_vNV = NULL; -PFNGLINDEXFORMATNVPROC __glewIndexFormatNV = NULL; -PFNGLNORMALFORMATNVPROC __glewNormalFormatNV = NULL; -PFNGLSECONDARYCOLORFORMATNVPROC __glewSecondaryColorFormatNV = NULL; -PFNGLTEXCOORDFORMATNVPROC __glewTexCoordFormatNV = NULL; -PFNGLVERTEXATTRIBFORMATNVPROC __glewVertexAttribFormatNV = NULL; -PFNGLVERTEXATTRIBIFORMATNVPROC __glewVertexAttribIFormatNV = NULL; -PFNGLVERTEXFORMATNVPROC __glewVertexFormatNV = NULL; - -PFNGLAREPROGRAMSRESIDENTNVPROC __glewAreProgramsResidentNV = NULL; -PFNGLBINDPROGRAMNVPROC __glewBindProgramNV = NULL; -PFNGLDELETEPROGRAMSNVPROC __glewDeleteProgramsNV = NULL; -PFNGLEXECUTEPROGRAMNVPROC __glewExecuteProgramNV = NULL; -PFNGLGENPROGRAMSNVPROC __glewGenProgramsNV = NULL; -PFNGLGETPROGRAMPARAMETERDVNVPROC __glewGetProgramParameterdvNV = NULL; -PFNGLGETPROGRAMPARAMETERFVNVPROC __glewGetProgramParameterfvNV = NULL; -PFNGLGETPROGRAMSTRINGNVPROC __glewGetProgramStringNV = NULL; -PFNGLGETPROGRAMIVNVPROC __glewGetProgramivNV = NULL; -PFNGLGETTRACKMATRIXIVNVPROC __glewGetTrackMatrixivNV = NULL; -PFNGLGETVERTEXATTRIBPOINTERVNVPROC __glewGetVertexAttribPointervNV = NULL; -PFNGLGETVERTEXATTRIBDVNVPROC __glewGetVertexAttribdvNV = NULL; -PFNGLGETVERTEXATTRIBFVNVPROC __glewGetVertexAttribfvNV = NULL; -PFNGLGETVERTEXATTRIBIVNVPROC __glewGetVertexAttribivNV = NULL; -PFNGLISPROGRAMNVPROC __glewIsProgramNV = NULL; -PFNGLLOADPROGRAMNVPROC __glewLoadProgramNV = NULL; -PFNGLPROGRAMPARAMETER4DNVPROC __glewProgramParameter4dNV = NULL; -PFNGLPROGRAMPARAMETER4DVNVPROC __glewProgramParameter4dvNV = NULL; -PFNGLPROGRAMPARAMETER4FNVPROC __glewProgramParameter4fNV = NULL; -PFNGLPROGRAMPARAMETER4FVNVPROC __glewProgramParameter4fvNV = NULL; -PFNGLPROGRAMPARAMETERS4DVNVPROC __glewProgramParameters4dvNV = NULL; -PFNGLPROGRAMPARAMETERS4FVNVPROC __glewProgramParameters4fvNV = NULL; -PFNGLREQUESTRESIDENTPROGRAMSNVPROC __glewRequestResidentProgramsNV = NULL; -PFNGLTRACKMATRIXNVPROC __glewTrackMatrixNV = NULL; -PFNGLVERTEXATTRIB1DNVPROC __glewVertexAttrib1dNV = NULL; -PFNGLVERTEXATTRIB1DVNVPROC __glewVertexAttrib1dvNV = NULL; -PFNGLVERTEXATTRIB1FNVPROC __glewVertexAttrib1fNV = NULL; -PFNGLVERTEXATTRIB1FVNVPROC __glewVertexAttrib1fvNV = NULL; -PFNGLVERTEXATTRIB1SNVPROC __glewVertexAttrib1sNV = NULL; -PFNGLVERTEXATTRIB1SVNVPROC __glewVertexAttrib1svNV = NULL; -PFNGLVERTEXATTRIB2DNVPROC __glewVertexAttrib2dNV = NULL; -PFNGLVERTEXATTRIB2DVNVPROC __glewVertexAttrib2dvNV = NULL; -PFNGLVERTEXATTRIB2FNVPROC __glewVertexAttrib2fNV = NULL; -PFNGLVERTEXATTRIB2FVNVPROC __glewVertexAttrib2fvNV = NULL; -PFNGLVERTEXATTRIB2SNVPROC __glewVertexAttrib2sNV = NULL; -PFNGLVERTEXATTRIB2SVNVPROC __glewVertexAttrib2svNV = NULL; -PFNGLVERTEXATTRIB3DNVPROC __glewVertexAttrib3dNV = NULL; -PFNGLVERTEXATTRIB3DVNVPROC __glewVertexAttrib3dvNV = NULL; -PFNGLVERTEXATTRIB3FNVPROC __glewVertexAttrib3fNV = NULL; -PFNGLVERTEXATTRIB3FVNVPROC __glewVertexAttrib3fvNV = NULL; -PFNGLVERTEXATTRIB3SNVPROC __glewVertexAttrib3sNV = NULL; -PFNGLVERTEXATTRIB3SVNVPROC __glewVertexAttrib3svNV = NULL; -PFNGLVERTEXATTRIB4DNVPROC __glewVertexAttrib4dNV = NULL; -PFNGLVERTEXATTRIB4DVNVPROC __glewVertexAttrib4dvNV = NULL; -PFNGLVERTEXATTRIB4FNVPROC __glewVertexAttrib4fNV = NULL; -PFNGLVERTEXATTRIB4FVNVPROC __glewVertexAttrib4fvNV = NULL; -PFNGLVERTEXATTRIB4SNVPROC __glewVertexAttrib4sNV = NULL; -PFNGLVERTEXATTRIB4SVNVPROC __glewVertexAttrib4svNV = NULL; -PFNGLVERTEXATTRIB4UBNVPROC __glewVertexAttrib4ubNV = NULL; -PFNGLVERTEXATTRIB4UBVNVPROC __glewVertexAttrib4ubvNV = NULL; -PFNGLVERTEXATTRIBPOINTERNVPROC __glewVertexAttribPointerNV = NULL; -PFNGLVERTEXATTRIBS1DVNVPROC __glewVertexAttribs1dvNV = NULL; -PFNGLVERTEXATTRIBS1FVNVPROC __glewVertexAttribs1fvNV = NULL; -PFNGLVERTEXATTRIBS1SVNVPROC __glewVertexAttribs1svNV = NULL; -PFNGLVERTEXATTRIBS2DVNVPROC __glewVertexAttribs2dvNV = NULL; -PFNGLVERTEXATTRIBS2FVNVPROC __glewVertexAttribs2fvNV = NULL; -PFNGLVERTEXATTRIBS2SVNVPROC __glewVertexAttribs2svNV = NULL; -PFNGLVERTEXATTRIBS3DVNVPROC __glewVertexAttribs3dvNV = NULL; -PFNGLVERTEXATTRIBS3FVNVPROC __glewVertexAttribs3fvNV = NULL; -PFNGLVERTEXATTRIBS3SVNVPROC __glewVertexAttribs3svNV = NULL; -PFNGLVERTEXATTRIBS4DVNVPROC __glewVertexAttribs4dvNV = NULL; -PFNGLVERTEXATTRIBS4FVNVPROC __glewVertexAttribs4fvNV = NULL; -PFNGLVERTEXATTRIBS4SVNVPROC __glewVertexAttribs4svNV = NULL; -PFNGLVERTEXATTRIBS4UBVNVPROC __glewVertexAttribs4ubvNV = NULL; - -PFNGLBEGINVIDEOCAPTURENVPROC __glewBeginVideoCaptureNV = NULL; -PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC __glewBindVideoCaptureStreamBufferNV = NULL; -PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC __glewBindVideoCaptureStreamTextureNV = NULL; -PFNGLENDVIDEOCAPTURENVPROC __glewEndVideoCaptureNV = NULL; -PFNGLGETVIDEOCAPTURESTREAMDVNVPROC __glewGetVideoCaptureStreamdvNV = NULL; -PFNGLGETVIDEOCAPTURESTREAMFVNVPROC __glewGetVideoCaptureStreamfvNV = NULL; -PFNGLGETVIDEOCAPTURESTREAMIVNVPROC __glewGetVideoCaptureStreamivNV = NULL; -PFNGLGETVIDEOCAPTUREIVNVPROC __glewGetVideoCaptureivNV = NULL; -PFNGLVIDEOCAPTURENVPROC __glewVideoCaptureNV = NULL; -PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC __glewVideoCaptureStreamParameterdvNV = NULL; -PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC __glewVideoCaptureStreamParameterfvNV = NULL; -PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC __glewVideoCaptureStreamParameterivNV = NULL; - -PFNGLCLEARDEPTHFOESPROC __glewClearDepthfOES = NULL; -PFNGLCLIPPLANEFOESPROC __glewClipPlanefOES = NULL; -PFNGLDEPTHRANGEFOESPROC __glewDepthRangefOES = NULL; -PFNGLFRUSTUMFOESPROC __glewFrustumfOES = NULL; -PFNGLGETCLIPPLANEFOESPROC __glewGetClipPlanefOES = NULL; -PFNGLORTHOFOESPROC __glewOrthofOES = NULL; - -PFNGLALPHAFUNCXPROC __glewAlphaFuncx = NULL; -PFNGLCLEARCOLORXPROC __glewClearColorx = NULL; -PFNGLCLEARDEPTHXPROC __glewClearDepthx = NULL; -PFNGLCOLOR4XPROC __glewColor4x = NULL; -PFNGLDEPTHRANGEXPROC __glewDepthRangex = NULL; -PFNGLFOGXPROC __glewFogx = NULL; -PFNGLFOGXVPROC __glewFogxv = NULL; -PFNGLFRUSTUMFPROC __glewFrustumf = NULL; -PFNGLFRUSTUMXPROC __glewFrustumx = NULL; -PFNGLLIGHTMODELXPROC __glewLightModelx = NULL; -PFNGLLIGHTMODELXVPROC __glewLightModelxv = NULL; -PFNGLLIGHTXPROC __glewLightx = NULL; -PFNGLLIGHTXVPROC __glewLightxv = NULL; -PFNGLLINEWIDTHXPROC __glewLineWidthx = NULL; -PFNGLLOADMATRIXXPROC __glewLoadMatrixx = NULL; -PFNGLMATERIALXPROC __glewMaterialx = NULL; -PFNGLMATERIALXVPROC __glewMaterialxv = NULL; -PFNGLMULTMATRIXXPROC __glewMultMatrixx = NULL; -PFNGLMULTITEXCOORD4XPROC __glewMultiTexCoord4x = NULL; -PFNGLNORMAL3XPROC __glewNormal3x = NULL; -PFNGLORTHOFPROC __glewOrthof = NULL; -PFNGLORTHOXPROC __glewOrthox = NULL; -PFNGLPOINTSIZEXPROC __glewPointSizex = NULL; -PFNGLPOLYGONOFFSETXPROC __glewPolygonOffsetx = NULL; -PFNGLROTATEXPROC __glewRotatex = NULL; -PFNGLSAMPLECOVERAGEXPROC __glewSampleCoveragex = NULL; -PFNGLSCALEXPROC __glewScalex = NULL; -PFNGLTEXENVXPROC __glewTexEnvx = NULL; -PFNGLTEXENVXVPROC __glewTexEnvxv = NULL; -PFNGLTEXPARAMETERXPROC __glewTexParameterx = NULL; -PFNGLTRANSLATEXPROC __glewTranslatex = NULL; - -PFNGLCLIPPLANEFPROC __glewClipPlanef = NULL; -PFNGLCLIPPLANEXPROC __glewClipPlanex = NULL; -PFNGLGETCLIPPLANEFPROC __glewGetClipPlanef = NULL; -PFNGLGETCLIPPLANEXPROC __glewGetClipPlanex = NULL; -PFNGLGETFIXEDVPROC __glewGetFixedv = NULL; -PFNGLGETLIGHTXVPROC __glewGetLightxv = NULL; -PFNGLGETMATERIALXVPROC __glewGetMaterialxv = NULL; -PFNGLGETTEXENVXVPROC __glewGetTexEnvxv = NULL; -PFNGLGETTEXPARAMETERXVPROC __glewGetTexParameterxv = NULL; -PFNGLPOINTPARAMETERXPROC __glewPointParameterx = NULL; -PFNGLPOINTPARAMETERXVPROC __glewPointParameterxv = NULL; -PFNGLPOINTSIZEPOINTEROESPROC __glewPointSizePointerOES = NULL; -PFNGLTEXPARAMETERXVPROC __glewTexParameterxv = NULL; - -PFNGLERRORSTRINGREGALPROC __glewErrorStringREGAL = NULL; - -PFNGLGETEXTENSIONREGALPROC __glewGetExtensionREGAL = NULL; -PFNGLISSUPPORTEDREGALPROC __glewIsSupportedREGAL = NULL; - -PFNGLLOGMESSAGECALLBACKREGALPROC __glewLogMessageCallbackREGAL = NULL; - -PFNGLDETAILTEXFUNCSGISPROC __glewDetailTexFuncSGIS = NULL; -PFNGLGETDETAILTEXFUNCSGISPROC __glewGetDetailTexFuncSGIS = NULL; - -PFNGLFOGFUNCSGISPROC __glewFogFuncSGIS = NULL; -PFNGLGETFOGFUNCSGISPROC __glewGetFogFuncSGIS = NULL; - -PFNGLSAMPLEMASKSGISPROC __glewSampleMaskSGIS = NULL; -PFNGLSAMPLEPATTERNSGISPROC __glewSamplePatternSGIS = NULL; - -PFNGLGETSHARPENTEXFUNCSGISPROC __glewGetSharpenTexFuncSGIS = NULL; -PFNGLSHARPENTEXFUNCSGISPROC __glewSharpenTexFuncSGIS = NULL; - -PFNGLTEXIMAGE4DSGISPROC __glewTexImage4DSGIS = NULL; -PFNGLTEXSUBIMAGE4DSGISPROC __glewTexSubImage4DSGIS = NULL; - -PFNGLGETTEXFILTERFUNCSGISPROC __glewGetTexFilterFuncSGIS = NULL; -PFNGLTEXFILTERFUNCSGISPROC __glewTexFilterFuncSGIS = NULL; - -PFNGLASYNCMARKERSGIXPROC __glewAsyncMarkerSGIX = NULL; -PFNGLDELETEASYNCMARKERSSGIXPROC __glewDeleteAsyncMarkersSGIX = NULL; -PFNGLFINISHASYNCSGIXPROC __glewFinishAsyncSGIX = NULL; -PFNGLGENASYNCMARKERSSGIXPROC __glewGenAsyncMarkersSGIX = NULL; -PFNGLISASYNCMARKERSGIXPROC __glewIsAsyncMarkerSGIX = NULL; -PFNGLPOLLASYNCSGIXPROC __glewPollAsyncSGIX = NULL; - -PFNGLFLUSHRASTERSGIXPROC __glewFlushRasterSGIX = NULL; - -PFNGLTEXTUREFOGSGIXPROC __glewTextureFogSGIX = NULL; - -PFNGLFRAGMENTCOLORMATERIALSGIXPROC __glewFragmentColorMaterialSGIX = NULL; -PFNGLFRAGMENTLIGHTMODELFSGIXPROC __glewFragmentLightModelfSGIX = NULL; -PFNGLFRAGMENTLIGHTMODELFVSGIXPROC __glewFragmentLightModelfvSGIX = NULL; -PFNGLFRAGMENTLIGHTMODELISGIXPROC __glewFragmentLightModeliSGIX = NULL; -PFNGLFRAGMENTLIGHTMODELIVSGIXPROC __glewFragmentLightModelivSGIX = NULL; -PFNGLFRAGMENTLIGHTFSGIXPROC __glewFragmentLightfSGIX = NULL; -PFNGLFRAGMENTLIGHTFVSGIXPROC __glewFragmentLightfvSGIX = NULL; -PFNGLFRAGMENTLIGHTISGIXPROC __glewFragmentLightiSGIX = NULL; -PFNGLFRAGMENTLIGHTIVSGIXPROC __glewFragmentLightivSGIX = NULL; -PFNGLFRAGMENTMATERIALFSGIXPROC __glewFragmentMaterialfSGIX = NULL; -PFNGLFRAGMENTMATERIALFVSGIXPROC __glewFragmentMaterialfvSGIX = NULL; -PFNGLFRAGMENTMATERIALISGIXPROC __glewFragmentMaterialiSGIX = NULL; -PFNGLFRAGMENTMATERIALIVSGIXPROC __glewFragmentMaterialivSGIX = NULL; -PFNGLGETFRAGMENTLIGHTFVSGIXPROC __glewGetFragmentLightfvSGIX = NULL; -PFNGLGETFRAGMENTLIGHTIVSGIXPROC __glewGetFragmentLightivSGIX = NULL; -PFNGLGETFRAGMENTMATERIALFVSGIXPROC __glewGetFragmentMaterialfvSGIX = NULL; -PFNGLGETFRAGMENTMATERIALIVSGIXPROC __glewGetFragmentMaterialivSGIX = NULL; - -PFNGLFRAMEZOOMSGIXPROC __glewFrameZoomSGIX = NULL; - -PFNGLPIXELTEXGENSGIXPROC __glewPixelTexGenSGIX = NULL; - -PFNGLREFERENCEPLANESGIXPROC __glewReferencePlaneSGIX = NULL; - -PFNGLSPRITEPARAMETERFSGIXPROC __glewSpriteParameterfSGIX = NULL; -PFNGLSPRITEPARAMETERFVSGIXPROC __glewSpriteParameterfvSGIX = NULL; -PFNGLSPRITEPARAMETERISGIXPROC __glewSpriteParameteriSGIX = NULL; -PFNGLSPRITEPARAMETERIVSGIXPROC __glewSpriteParameterivSGIX = NULL; - -PFNGLTAGSAMPLEBUFFERSGIXPROC __glewTagSampleBufferSGIX = NULL; - -PFNGLCOLORTABLEPARAMETERFVSGIPROC __glewColorTableParameterfvSGI = NULL; -PFNGLCOLORTABLEPARAMETERIVSGIPROC __glewColorTableParameterivSGI = NULL; -PFNGLCOLORTABLESGIPROC __glewColorTableSGI = NULL; -PFNGLCOPYCOLORTABLESGIPROC __glewCopyColorTableSGI = NULL; -PFNGLGETCOLORTABLEPARAMETERFVSGIPROC __glewGetColorTableParameterfvSGI = NULL; -PFNGLGETCOLORTABLEPARAMETERIVSGIPROC __glewGetColorTableParameterivSGI = NULL; -PFNGLGETCOLORTABLESGIPROC __glewGetColorTableSGI = NULL; - -PFNGLFINISHTEXTURESUNXPROC __glewFinishTextureSUNX = NULL; - -PFNGLGLOBALALPHAFACTORBSUNPROC __glewGlobalAlphaFactorbSUN = NULL; -PFNGLGLOBALALPHAFACTORDSUNPROC __glewGlobalAlphaFactordSUN = NULL; -PFNGLGLOBALALPHAFACTORFSUNPROC __glewGlobalAlphaFactorfSUN = NULL; -PFNGLGLOBALALPHAFACTORISUNPROC __glewGlobalAlphaFactoriSUN = NULL; -PFNGLGLOBALALPHAFACTORSSUNPROC __glewGlobalAlphaFactorsSUN = NULL; -PFNGLGLOBALALPHAFACTORUBSUNPROC __glewGlobalAlphaFactorubSUN = NULL; -PFNGLGLOBALALPHAFACTORUISUNPROC __glewGlobalAlphaFactoruiSUN = NULL; -PFNGLGLOBALALPHAFACTORUSSUNPROC __glewGlobalAlphaFactorusSUN = NULL; - -PFNGLREADVIDEOPIXELSSUNPROC __glewReadVideoPixelsSUN = NULL; - -PFNGLREPLACEMENTCODEPOINTERSUNPROC __glewReplacementCodePointerSUN = NULL; -PFNGLREPLACEMENTCODEUBSUNPROC __glewReplacementCodeubSUN = NULL; -PFNGLREPLACEMENTCODEUBVSUNPROC __glewReplacementCodeubvSUN = NULL; -PFNGLREPLACEMENTCODEUISUNPROC __glewReplacementCodeuiSUN = NULL; -PFNGLREPLACEMENTCODEUIVSUNPROC __glewReplacementCodeuivSUN = NULL; -PFNGLREPLACEMENTCODEUSSUNPROC __glewReplacementCodeusSUN = NULL; -PFNGLREPLACEMENTCODEUSVSUNPROC __glewReplacementCodeusvSUN = NULL; - -PFNGLCOLOR3FVERTEX3FSUNPROC __glewColor3fVertex3fSUN = NULL; -PFNGLCOLOR3FVERTEX3FVSUNPROC __glewColor3fVertex3fvSUN = NULL; -PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewColor4fNormal3fVertex3fSUN = NULL; -PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewColor4fNormal3fVertex3fvSUN = NULL; -PFNGLCOLOR4UBVERTEX2FSUNPROC __glewColor4ubVertex2fSUN = NULL; -PFNGLCOLOR4UBVERTEX2FVSUNPROC __glewColor4ubVertex2fvSUN = NULL; -PFNGLCOLOR4UBVERTEX3FSUNPROC __glewColor4ubVertex3fSUN = NULL; -PFNGLCOLOR4UBVERTEX3FVSUNPROC __glewColor4ubVertex3fvSUN = NULL; -PFNGLNORMAL3FVERTEX3FSUNPROC __glewNormal3fVertex3fSUN = NULL; -PFNGLNORMAL3FVERTEX3FVSUNPROC __glewNormal3fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC __glewReplacementCodeuiColor3fVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor3fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiColor4fNormal3fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC __glewReplacementCodeuiColor4ubVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC __glewReplacementCodeuiColor4ubVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiNormal3fVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiNormal3fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC __glewReplacementCodeuiTexCoord2fVertex3fvSUN = NULL; -PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC __glewReplacementCodeuiVertex3fSUN = NULL; -PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC __glewReplacementCodeuiVertex3fvSUN = NULL; -PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC __glewTexCoord2fColor3fVertex3fSUN = NULL; -PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC __glewTexCoord2fColor3fVertex3fvSUN = NULL; -PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fSUN = NULL; -PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fColor4fNormal3fVertex3fvSUN = NULL; -PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC __glewTexCoord2fColor4ubVertex3fSUN = NULL; -PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC __glewTexCoord2fColor4ubVertex3fvSUN = NULL; -PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC __glewTexCoord2fNormal3fVertex3fSUN = NULL; -PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC __glewTexCoord2fNormal3fVertex3fvSUN = NULL; -PFNGLTEXCOORD2FVERTEX3FSUNPROC __glewTexCoord2fVertex3fSUN = NULL; -PFNGLTEXCOORD2FVERTEX3FVSUNPROC __glewTexCoord2fVertex3fvSUN = NULL; -PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fSUN = NULL; -PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC __glewTexCoord4fColor4fNormal3fVertex4fvSUN = NULL; -PFNGLTEXCOORD4FVERTEX4FSUNPROC __glewTexCoord4fVertex4fSUN = NULL; -PFNGLTEXCOORD4FVERTEX4FVSUNPROC __glewTexCoord4fVertex4fvSUN = NULL; - -PFNGLADDSWAPHINTRECTWINPROC __glewAddSwapHintRectWIN = NULL; - -#endif /* !WIN32 || !GLEW_MX */ - -#if !defined(GLEW_MX) - -GLboolean __GLEW_VERSION_1_1 = GL_FALSE; -GLboolean __GLEW_VERSION_1_2 = GL_FALSE; -GLboolean __GLEW_VERSION_1_2_1 = GL_FALSE; -GLboolean __GLEW_VERSION_1_3 = GL_FALSE; -GLboolean __GLEW_VERSION_1_4 = GL_FALSE; -GLboolean __GLEW_VERSION_1_5 = GL_FALSE; -GLboolean __GLEW_VERSION_2_0 = GL_FALSE; -GLboolean __GLEW_VERSION_2_1 = GL_FALSE; -GLboolean __GLEW_VERSION_3_0 = GL_FALSE; -GLboolean __GLEW_VERSION_3_1 = GL_FALSE; -GLboolean __GLEW_VERSION_3_2 = GL_FALSE; -GLboolean __GLEW_VERSION_3_3 = GL_FALSE; -GLboolean __GLEW_VERSION_4_0 = GL_FALSE; -GLboolean __GLEW_VERSION_4_1 = GL_FALSE; -GLboolean __GLEW_VERSION_4_2 = GL_FALSE; -GLboolean __GLEW_VERSION_4_3 = GL_FALSE; -GLboolean __GLEW_VERSION_4_4 = GL_FALSE; -GLboolean __GLEW_3DFX_multisample = GL_FALSE; -GLboolean __GLEW_3DFX_tbuffer = GL_FALSE; -GLboolean __GLEW_3DFX_texture_compression_FXT1 = GL_FALSE; -GLboolean __GLEW_AMD_blend_minmax_factor = GL_FALSE; -GLboolean __GLEW_AMD_conservative_depth = GL_FALSE; -GLboolean __GLEW_AMD_debug_output = GL_FALSE; -GLboolean __GLEW_AMD_depth_clamp_separate = GL_FALSE; -GLboolean __GLEW_AMD_draw_buffers_blend = GL_FALSE; -GLboolean __GLEW_AMD_interleaved_elements = GL_FALSE; -GLboolean __GLEW_AMD_multi_draw_indirect = GL_FALSE; -GLboolean __GLEW_AMD_name_gen_delete = GL_FALSE; -GLboolean __GLEW_AMD_performance_monitor = GL_FALSE; -GLboolean __GLEW_AMD_pinned_memory = GL_FALSE; -GLboolean __GLEW_AMD_query_buffer_object = GL_FALSE; -GLboolean __GLEW_AMD_sample_positions = GL_FALSE; -GLboolean __GLEW_AMD_seamless_cubemap_per_texture = GL_FALSE; -GLboolean __GLEW_AMD_shader_stencil_export = GL_FALSE; -GLboolean __GLEW_AMD_shader_trinary_minmax = GL_FALSE; -GLboolean __GLEW_AMD_sparse_texture = GL_FALSE; -GLboolean __GLEW_AMD_stencil_operation_extended = GL_FALSE; -GLboolean __GLEW_AMD_texture_texture4 = GL_FALSE; -GLboolean __GLEW_AMD_transform_feedback3_lines_triangles = GL_FALSE; -GLboolean __GLEW_AMD_vertex_shader_layer = GL_FALSE; -GLboolean __GLEW_AMD_vertex_shader_tessellator = GL_FALSE; -GLboolean __GLEW_AMD_vertex_shader_viewport_index = GL_FALSE; -GLboolean __GLEW_ANGLE_depth_texture = GL_FALSE; -GLboolean __GLEW_ANGLE_framebuffer_blit = GL_FALSE; -GLboolean __GLEW_ANGLE_framebuffer_multisample = GL_FALSE; -GLboolean __GLEW_ANGLE_instanced_arrays = GL_FALSE; -GLboolean __GLEW_ANGLE_pack_reverse_row_order = GL_FALSE; -GLboolean __GLEW_ANGLE_program_binary = GL_FALSE; -GLboolean __GLEW_ANGLE_texture_compression_dxt1 = GL_FALSE; -GLboolean __GLEW_ANGLE_texture_compression_dxt3 = GL_FALSE; -GLboolean __GLEW_ANGLE_texture_compression_dxt5 = GL_FALSE; -GLboolean __GLEW_ANGLE_texture_usage = GL_FALSE; -GLboolean __GLEW_ANGLE_timer_query = GL_FALSE; -GLboolean __GLEW_ANGLE_translated_shader_source = GL_FALSE; -GLboolean __GLEW_APPLE_aux_depth_stencil = GL_FALSE; -GLboolean __GLEW_APPLE_client_storage = GL_FALSE; -GLboolean __GLEW_APPLE_element_array = GL_FALSE; -GLboolean __GLEW_APPLE_fence = GL_FALSE; -GLboolean __GLEW_APPLE_float_pixels = GL_FALSE; -GLboolean __GLEW_APPLE_flush_buffer_range = GL_FALSE; -GLboolean __GLEW_APPLE_object_purgeable = GL_FALSE; -GLboolean __GLEW_APPLE_pixel_buffer = GL_FALSE; -GLboolean __GLEW_APPLE_rgb_422 = GL_FALSE; -GLboolean __GLEW_APPLE_row_bytes = GL_FALSE; -GLboolean __GLEW_APPLE_specular_vector = GL_FALSE; -GLboolean __GLEW_APPLE_texture_range = GL_FALSE; -GLboolean __GLEW_APPLE_transform_hint = GL_FALSE; -GLboolean __GLEW_APPLE_vertex_array_object = GL_FALSE; -GLboolean __GLEW_APPLE_vertex_array_range = GL_FALSE; -GLboolean __GLEW_APPLE_vertex_program_evaluators = GL_FALSE; -GLboolean __GLEW_APPLE_ycbcr_422 = GL_FALSE; -GLboolean __GLEW_ARB_ES2_compatibility = GL_FALSE; -GLboolean __GLEW_ARB_ES3_compatibility = GL_FALSE; -GLboolean __GLEW_ARB_arrays_of_arrays = GL_FALSE; -GLboolean __GLEW_ARB_base_instance = GL_FALSE; -GLboolean __GLEW_ARB_bindless_texture = GL_FALSE; -GLboolean __GLEW_ARB_blend_func_extended = GL_FALSE; -GLboolean __GLEW_ARB_buffer_storage = GL_FALSE; -GLboolean __GLEW_ARB_cl_event = GL_FALSE; -GLboolean __GLEW_ARB_clear_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_clear_texture = GL_FALSE; -GLboolean __GLEW_ARB_color_buffer_float = GL_FALSE; -GLboolean __GLEW_ARB_compatibility = GL_FALSE; -GLboolean __GLEW_ARB_compressed_texture_pixel_storage = GL_FALSE; -GLboolean __GLEW_ARB_compute_shader = GL_FALSE; -GLboolean __GLEW_ARB_compute_variable_group_size = GL_FALSE; -GLboolean __GLEW_ARB_conservative_depth = GL_FALSE; -GLboolean __GLEW_ARB_copy_buffer = GL_FALSE; -GLboolean __GLEW_ARB_copy_image = GL_FALSE; -GLboolean __GLEW_ARB_debug_output = GL_FALSE; -GLboolean __GLEW_ARB_depth_buffer_float = GL_FALSE; -GLboolean __GLEW_ARB_depth_clamp = GL_FALSE; -GLboolean __GLEW_ARB_depth_texture = GL_FALSE; -GLboolean __GLEW_ARB_draw_buffers = GL_FALSE; -GLboolean __GLEW_ARB_draw_buffers_blend = GL_FALSE; -GLboolean __GLEW_ARB_draw_elements_base_vertex = GL_FALSE; -GLboolean __GLEW_ARB_draw_indirect = GL_FALSE; -GLboolean __GLEW_ARB_draw_instanced = GL_FALSE; -GLboolean __GLEW_ARB_enhanced_layouts = GL_FALSE; -GLboolean __GLEW_ARB_explicit_attrib_location = GL_FALSE; -GLboolean __GLEW_ARB_explicit_uniform_location = GL_FALSE; -GLboolean __GLEW_ARB_fragment_coord_conventions = GL_FALSE; -GLboolean __GLEW_ARB_fragment_layer_viewport = GL_FALSE; -GLboolean __GLEW_ARB_fragment_program = GL_FALSE; -GLboolean __GLEW_ARB_fragment_program_shadow = GL_FALSE; -GLboolean __GLEW_ARB_fragment_shader = GL_FALSE; -GLboolean __GLEW_ARB_framebuffer_no_attachments = GL_FALSE; -GLboolean __GLEW_ARB_framebuffer_object = GL_FALSE; -GLboolean __GLEW_ARB_framebuffer_sRGB = GL_FALSE; -GLboolean __GLEW_ARB_geometry_shader4 = GL_FALSE; -GLboolean __GLEW_ARB_get_program_binary = GL_FALSE; -GLboolean __GLEW_ARB_gpu_shader5 = GL_FALSE; -GLboolean __GLEW_ARB_gpu_shader_fp64 = GL_FALSE; -GLboolean __GLEW_ARB_half_float_pixel = GL_FALSE; -GLboolean __GLEW_ARB_half_float_vertex = GL_FALSE; -GLboolean __GLEW_ARB_imaging = GL_FALSE; -GLboolean __GLEW_ARB_indirect_parameters = GL_FALSE; -GLboolean __GLEW_ARB_instanced_arrays = GL_FALSE; -GLboolean __GLEW_ARB_internalformat_query = GL_FALSE; -GLboolean __GLEW_ARB_internalformat_query2 = GL_FALSE; -GLboolean __GLEW_ARB_invalidate_subdata = GL_FALSE; -GLboolean __GLEW_ARB_map_buffer_alignment = GL_FALSE; -GLboolean __GLEW_ARB_map_buffer_range = GL_FALSE; -GLboolean __GLEW_ARB_matrix_palette = GL_FALSE; -GLboolean __GLEW_ARB_multi_bind = GL_FALSE; -GLboolean __GLEW_ARB_multi_draw_indirect = GL_FALSE; -GLboolean __GLEW_ARB_multisample = GL_FALSE; -GLboolean __GLEW_ARB_multitexture = GL_FALSE; -GLboolean __GLEW_ARB_occlusion_query = GL_FALSE; -GLboolean __GLEW_ARB_occlusion_query2 = GL_FALSE; -GLboolean __GLEW_ARB_pixel_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_point_parameters = GL_FALSE; -GLboolean __GLEW_ARB_point_sprite = GL_FALSE; -GLboolean __GLEW_ARB_program_interface_query = GL_FALSE; -GLboolean __GLEW_ARB_provoking_vertex = GL_FALSE; -GLboolean __GLEW_ARB_query_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_robust_buffer_access_behavior = GL_FALSE; -GLboolean __GLEW_ARB_robustness = GL_FALSE; -GLboolean __GLEW_ARB_robustness_application_isolation = GL_FALSE; -GLboolean __GLEW_ARB_robustness_share_group_isolation = GL_FALSE; -GLboolean __GLEW_ARB_sample_shading = GL_FALSE; -GLboolean __GLEW_ARB_sampler_objects = GL_FALSE; -GLboolean __GLEW_ARB_seamless_cube_map = GL_FALSE; -GLboolean __GLEW_ARB_seamless_cubemap_per_texture = GL_FALSE; -GLboolean __GLEW_ARB_separate_shader_objects = GL_FALSE; -GLboolean __GLEW_ARB_shader_atomic_counters = GL_FALSE; -GLboolean __GLEW_ARB_shader_bit_encoding = GL_FALSE; -GLboolean __GLEW_ARB_shader_draw_parameters = GL_FALSE; -GLboolean __GLEW_ARB_shader_group_vote = GL_FALSE; -GLboolean __GLEW_ARB_shader_image_load_store = GL_FALSE; -GLboolean __GLEW_ARB_shader_image_size = GL_FALSE; -GLboolean __GLEW_ARB_shader_objects = GL_FALSE; -GLboolean __GLEW_ARB_shader_precision = GL_FALSE; -GLboolean __GLEW_ARB_shader_stencil_export = GL_FALSE; -GLboolean __GLEW_ARB_shader_storage_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_shader_subroutine = GL_FALSE; -GLboolean __GLEW_ARB_shader_texture_lod = GL_FALSE; -GLboolean __GLEW_ARB_shading_language_100 = GL_FALSE; -GLboolean __GLEW_ARB_shading_language_420pack = GL_FALSE; -GLboolean __GLEW_ARB_shading_language_include = GL_FALSE; -GLboolean __GLEW_ARB_shading_language_packing = GL_FALSE; -GLboolean __GLEW_ARB_shadow = GL_FALSE; -GLboolean __GLEW_ARB_shadow_ambient = GL_FALSE; -GLboolean __GLEW_ARB_sparse_texture = GL_FALSE; -GLboolean __GLEW_ARB_stencil_texturing = GL_FALSE; -GLboolean __GLEW_ARB_sync = GL_FALSE; -GLboolean __GLEW_ARB_tessellation_shader = GL_FALSE; -GLboolean __GLEW_ARB_texture_border_clamp = GL_FALSE; -GLboolean __GLEW_ARB_texture_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_texture_buffer_object_rgb32 = GL_FALSE; -GLboolean __GLEW_ARB_texture_buffer_range = GL_FALSE; -GLboolean __GLEW_ARB_texture_compression = GL_FALSE; -GLboolean __GLEW_ARB_texture_compression_bptc = GL_FALSE; -GLboolean __GLEW_ARB_texture_compression_rgtc = GL_FALSE; -GLboolean __GLEW_ARB_texture_cube_map = GL_FALSE; -GLboolean __GLEW_ARB_texture_cube_map_array = GL_FALSE; -GLboolean __GLEW_ARB_texture_env_add = GL_FALSE; -GLboolean __GLEW_ARB_texture_env_combine = GL_FALSE; -GLboolean __GLEW_ARB_texture_env_crossbar = GL_FALSE; -GLboolean __GLEW_ARB_texture_env_dot3 = GL_FALSE; -GLboolean __GLEW_ARB_texture_float = GL_FALSE; -GLboolean __GLEW_ARB_texture_gather = GL_FALSE; -GLboolean __GLEW_ARB_texture_mirror_clamp_to_edge = GL_FALSE; -GLboolean __GLEW_ARB_texture_mirrored_repeat = GL_FALSE; -GLboolean __GLEW_ARB_texture_multisample = GL_FALSE; -GLboolean __GLEW_ARB_texture_non_power_of_two = GL_FALSE; -GLboolean __GLEW_ARB_texture_query_levels = GL_FALSE; -GLboolean __GLEW_ARB_texture_query_lod = GL_FALSE; -GLboolean __GLEW_ARB_texture_rectangle = GL_FALSE; -GLboolean __GLEW_ARB_texture_rg = GL_FALSE; -GLboolean __GLEW_ARB_texture_rgb10_a2ui = GL_FALSE; -GLboolean __GLEW_ARB_texture_stencil8 = GL_FALSE; -GLboolean __GLEW_ARB_texture_storage = GL_FALSE; -GLboolean __GLEW_ARB_texture_storage_multisample = GL_FALSE; -GLboolean __GLEW_ARB_texture_swizzle = GL_FALSE; -GLboolean __GLEW_ARB_texture_view = GL_FALSE; -GLboolean __GLEW_ARB_timer_query = GL_FALSE; -GLboolean __GLEW_ARB_transform_feedback2 = GL_FALSE; -GLboolean __GLEW_ARB_transform_feedback3 = GL_FALSE; -GLboolean __GLEW_ARB_transform_feedback_instanced = GL_FALSE; -GLboolean __GLEW_ARB_transpose_matrix = GL_FALSE; -GLboolean __GLEW_ARB_uniform_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_vertex_array_bgra = GL_FALSE; -GLboolean __GLEW_ARB_vertex_array_object = GL_FALSE; -GLboolean __GLEW_ARB_vertex_attrib_64bit = GL_FALSE; -GLboolean __GLEW_ARB_vertex_attrib_binding = GL_FALSE; -GLboolean __GLEW_ARB_vertex_blend = GL_FALSE; -GLboolean __GLEW_ARB_vertex_buffer_object = GL_FALSE; -GLboolean __GLEW_ARB_vertex_program = GL_FALSE; -GLboolean __GLEW_ARB_vertex_shader = GL_FALSE; -GLboolean __GLEW_ARB_vertex_type_10f_11f_11f_rev = GL_FALSE; -GLboolean __GLEW_ARB_vertex_type_2_10_10_10_rev = GL_FALSE; -GLboolean __GLEW_ARB_viewport_array = GL_FALSE; -GLboolean __GLEW_ARB_window_pos = GL_FALSE; -GLboolean __GLEW_ATIX_point_sprites = GL_FALSE; -GLboolean __GLEW_ATIX_texture_env_combine3 = GL_FALSE; -GLboolean __GLEW_ATIX_texture_env_route = GL_FALSE; -GLboolean __GLEW_ATIX_vertex_shader_output_point_size = GL_FALSE; -GLboolean __GLEW_ATI_draw_buffers = GL_FALSE; -GLboolean __GLEW_ATI_element_array = GL_FALSE; -GLboolean __GLEW_ATI_envmap_bumpmap = GL_FALSE; -GLboolean __GLEW_ATI_fragment_shader = GL_FALSE; -GLboolean __GLEW_ATI_map_object_buffer = GL_FALSE; -GLboolean __GLEW_ATI_meminfo = GL_FALSE; -GLboolean __GLEW_ATI_pn_triangles = GL_FALSE; -GLboolean __GLEW_ATI_separate_stencil = GL_FALSE; -GLboolean __GLEW_ATI_shader_texture_lod = GL_FALSE; -GLboolean __GLEW_ATI_text_fragment_shader = GL_FALSE; -GLboolean __GLEW_ATI_texture_compression_3dc = GL_FALSE; -GLboolean __GLEW_ATI_texture_env_combine3 = GL_FALSE; -GLboolean __GLEW_ATI_texture_float = GL_FALSE; -GLboolean __GLEW_ATI_texture_mirror_once = GL_FALSE; -GLboolean __GLEW_ATI_vertex_array_object = GL_FALSE; -GLboolean __GLEW_ATI_vertex_attrib_array_object = GL_FALSE; -GLboolean __GLEW_ATI_vertex_streams = GL_FALSE; -GLboolean __GLEW_EXT_422_pixels = GL_FALSE; -GLboolean __GLEW_EXT_Cg_shader = GL_FALSE; -GLboolean __GLEW_EXT_abgr = GL_FALSE; -GLboolean __GLEW_EXT_bgra = GL_FALSE; -GLboolean __GLEW_EXT_bindable_uniform = GL_FALSE; -GLboolean __GLEW_EXT_blend_color = GL_FALSE; -GLboolean __GLEW_EXT_blend_equation_separate = GL_FALSE; -GLboolean __GLEW_EXT_blend_func_separate = GL_FALSE; -GLboolean __GLEW_EXT_blend_logic_op = GL_FALSE; -GLboolean __GLEW_EXT_blend_minmax = GL_FALSE; -GLboolean __GLEW_EXT_blend_subtract = GL_FALSE; -GLboolean __GLEW_EXT_clip_volume_hint = GL_FALSE; -GLboolean __GLEW_EXT_cmyka = GL_FALSE; -GLboolean __GLEW_EXT_color_subtable = GL_FALSE; -GLboolean __GLEW_EXT_compiled_vertex_array = GL_FALSE; -GLboolean __GLEW_EXT_convolution = GL_FALSE; -GLboolean __GLEW_EXT_coordinate_frame = GL_FALSE; -GLboolean __GLEW_EXT_copy_texture = GL_FALSE; -GLboolean __GLEW_EXT_cull_vertex = GL_FALSE; -GLboolean __GLEW_EXT_debug_marker = GL_FALSE; -GLboolean __GLEW_EXT_depth_bounds_test = GL_FALSE; -GLboolean __GLEW_EXT_direct_state_access = GL_FALSE; -GLboolean __GLEW_EXT_draw_buffers2 = GL_FALSE; -GLboolean __GLEW_EXT_draw_instanced = GL_FALSE; -GLboolean __GLEW_EXT_draw_range_elements = GL_FALSE; -GLboolean __GLEW_EXT_fog_coord = GL_FALSE; -GLboolean __GLEW_EXT_fragment_lighting = GL_FALSE; -GLboolean __GLEW_EXT_framebuffer_blit = GL_FALSE; -GLboolean __GLEW_EXT_framebuffer_multisample = GL_FALSE; -GLboolean __GLEW_EXT_framebuffer_multisample_blit_scaled = GL_FALSE; -GLboolean __GLEW_EXT_framebuffer_object = GL_FALSE; -GLboolean __GLEW_EXT_framebuffer_sRGB = GL_FALSE; -GLboolean __GLEW_EXT_geometry_shader4 = GL_FALSE; -GLboolean __GLEW_EXT_gpu_program_parameters = GL_FALSE; -GLboolean __GLEW_EXT_gpu_shader4 = GL_FALSE; -GLboolean __GLEW_EXT_histogram = GL_FALSE; -GLboolean __GLEW_EXT_index_array_formats = GL_FALSE; -GLboolean __GLEW_EXT_index_func = GL_FALSE; -GLboolean __GLEW_EXT_index_material = GL_FALSE; -GLboolean __GLEW_EXT_index_texture = GL_FALSE; -GLboolean __GLEW_EXT_light_texture = GL_FALSE; -GLboolean __GLEW_EXT_misc_attribute = GL_FALSE; -GLboolean __GLEW_EXT_multi_draw_arrays = GL_FALSE; -GLboolean __GLEW_EXT_multisample = GL_FALSE; -GLboolean __GLEW_EXT_packed_depth_stencil = GL_FALSE; -GLboolean __GLEW_EXT_packed_float = GL_FALSE; -GLboolean __GLEW_EXT_packed_pixels = GL_FALSE; -GLboolean __GLEW_EXT_paletted_texture = GL_FALSE; -GLboolean __GLEW_EXT_pixel_buffer_object = GL_FALSE; -GLboolean __GLEW_EXT_pixel_transform = GL_FALSE; -GLboolean __GLEW_EXT_pixel_transform_color_table = GL_FALSE; -GLboolean __GLEW_EXT_point_parameters = GL_FALSE; -GLboolean __GLEW_EXT_polygon_offset = GL_FALSE; -GLboolean __GLEW_EXT_provoking_vertex = GL_FALSE; -GLboolean __GLEW_EXT_rescale_normal = GL_FALSE; -GLboolean __GLEW_EXT_scene_marker = GL_FALSE; -GLboolean __GLEW_EXT_secondary_color = GL_FALSE; -GLboolean __GLEW_EXT_separate_shader_objects = GL_FALSE; -GLboolean __GLEW_EXT_separate_specular_color = GL_FALSE; -GLboolean __GLEW_EXT_shader_image_load_store = GL_FALSE; -GLboolean __GLEW_EXT_shadow_funcs = GL_FALSE; -GLboolean __GLEW_EXT_shared_texture_palette = GL_FALSE; -GLboolean __GLEW_EXT_stencil_clear_tag = GL_FALSE; -GLboolean __GLEW_EXT_stencil_two_side = GL_FALSE; -GLboolean __GLEW_EXT_stencil_wrap = GL_FALSE; -GLboolean __GLEW_EXT_subtexture = GL_FALSE; -GLboolean __GLEW_EXT_texture = GL_FALSE; -GLboolean __GLEW_EXT_texture3D = GL_FALSE; -GLboolean __GLEW_EXT_texture_array = GL_FALSE; -GLboolean __GLEW_EXT_texture_buffer_object = GL_FALSE; -GLboolean __GLEW_EXT_texture_compression_dxt1 = GL_FALSE; -GLboolean __GLEW_EXT_texture_compression_latc = GL_FALSE; -GLboolean __GLEW_EXT_texture_compression_rgtc = GL_FALSE; -GLboolean __GLEW_EXT_texture_compression_s3tc = GL_FALSE; -GLboolean __GLEW_EXT_texture_cube_map = GL_FALSE; -GLboolean __GLEW_EXT_texture_edge_clamp = GL_FALSE; -GLboolean __GLEW_EXT_texture_env = GL_FALSE; -GLboolean __GLEW_EXT_texture_env_add = GL_FALSE; -GLboolean __GLEW_EXT_texture_env_combine = GL_FALSE; -GLboolean __GLEW_EXT_texture_env_dot3 = GL_FALSE; -GLboolean __GLEW_EXT_texture_filter_anisotropic = GL_FALSE; -GLboolean __GLEW_EXT_texture_integer = GL_FALSE; -GLboolean __GLEW_EXT_texture_lod_bias = GL_FALSE; -GLboolean __GLEW_EXT_texture_mirror_clamp = GL_FALSE; -GLboolean __GLEW_EXT_texture_object = GL_FALSE; -GLboolean __GLEW_EXT_texture_perturb_normal = GL_FALSE; -GLboolean __GLEW_EXT_texture_rectangle = GL_FALSE; -GLboolean __GLEW_EXT_texture_sRGB = GL_FALSE; -GLboolean __GLEW_EXT_texture_sRGB_decode = GL_FALSE; -GLboolean __GLEW_EXT_texture_shared_exponent = GL_FALSE; -GLboolean __GLEW_EXT_texture_snorm = GL_FALSE; -GLboolean __GLEW_EXT_texture_swizzle = GL_FALSE; -GLboolean __GLEW_EXT_timer_query = GL_FALSE; -GLboolean __GLEW_EXT_transform_feedback = GL_FALSE; -GLboolean __GLEW_EXT_vertex_array = GL_FALSE; -GLboolean __GLEW_EXT_vertex_array_bgra = GL_FALSE; -GLboolean __GLEW_EXT_vertex_attrib_64bit = GL_FALSE; -GLboolean __GLEW_EXT_vertex_shader = GL_FALSE; -GLboolean __GLEW_EXT_vertex_weighting = GL_FALSE; -GLboolean __GLEW_EXT_x11_sync_object = GL_FALSE; -GLboolean __GLEW_GREMEDY_frame_terminator = GL_FALSE; -GLboolean __GLEW_GREMEDY_string_marker = GL_FALSE; -GLboolean __GLEW_HP_convolution_border_modes = GL_FALSE; -GLboolean __GLEW_HP_image_transform = GL_FALSE; -GLboolean __GLEW_HP_occlusion_test = GL_FALSE; -GLboolean __GLEW_HP_texture_lighting = GL_FALSE; -GLboolean __GLEW_IBM_cull_vertex = GL_FALSE; -GLboolean __GLEW_IBM_multimode_draw_arrays = GL_FALSE; -GLboolean __GLEW_IBM_rasterpos_clip = GL_FALSE; -GLboolean __GLEW_IBM_static_data = GL_FALSE; -GLboolean __GLEW_IBM_texture_mirrored_repeat = GL_FALSE; -GLboolean __GLEW_IBM_vertex_array_lists = GL_FALSE; -GLboolean __GLEW_INGR_color_clamp = GL_FALSE; -GLboolean __GLEW_INGR_interlace_read = GL_FALSE; -GLboolean __GLEW_INTEL_map_texture = GL_FALSE; -GLboolean __GLEW_INTEL_parallel_arrays = GL_FALSE; -GLboolean __GLEW_INTEL_texture_scissor = GL_FALSE; -GLboolean __GLEW_KHR_debug = GL_FALSE; -GLboolean __GLEW_KHR_texture_compression_astc_ldr = GL_FALSE; -GLboolean __GLEW_KTX_buffer_region = GL_FALSE; -GLboolean __GLEW_MESAX_texture_stack = GL_FALSE; -GLboolean __GLEW_MESA_pack_invert = GL_FALSE; -GLboolean __GLEW_MESA_resize_buffers = GL_FALSE; -GLboolean __GLEW_MESA_window_pos = GL_FALSE; -GLboolean __GLEW_MESA_ycbcr_texture = GL_FALSE; -GLboolean __GLEW_NVX_conditional_render = GL_FALSE; -GLboolean __GLEW_NVX_gpu_memory_info = GL_FALSE; -GLboolean __GLEW_NV_bindless_multi_draw_indirect = GL_FALSE; -GLboolean __GLEW_NV_bindless_texture = GL_FALSE; -GLboolean __GLEW_NV_blend_equation_advanced = GL_FALSE; -GLboolean __GLEW_NV_blend_equation_advanced_coherent = GL_FALSE; -GLboolean __GLEW_NV_blend_square = GL_FALSE; -GLboolean __GLEW_NV_compute_program5 = GL_FALSE; -GLboolean __GLEW_NV_conditional_render = GL_FALSE; -GLboolean __GLEW_NV_copy_depth_to_color = GL_FALSE; -GLboolean __GLEW_NV_copy_image = GL_FALSE; -GLboolean __GLEW_NV_deep_texture3D = GL_FALSE; -GLboolean __GLEW_NV_depth_buffer_float = GL_FALSE; -GLboolean __GLEW_NV_depth_clamp = GL_FALSE; -GLboolean __GLEW_NV_depth_range_unclamped = GL_FALSE; -GLboolean __GLEW_NV_draw_texture = GL_FALSE; -GLboolean __GLEW_NV_evaluators = GL_FALSE; -GLboolean __GLEW_NV_explicit_multisample = GL_FALSE; -GLboolean __GLEW_NV_fence = GL_FALSE; -GLboolean __GLEW_NV_float_buffer = GL_FALSE; -GLboolean __GLEW_NV_fog_distance = GL_FALSE; -GLboolean __GLEW_NV_fragment_program = GL_FALSE; -GLboolean __GLEW_NV_fragment_program2 = GL_FALSE; -GLboolean __GLEW_NV_fragment_program4 = GL_FALSE; -GLboolean __GLEW_NV_fragment_program_option = GL_FALSE; -GLboolean __GLEW_NV_framebuffer_multisample_coverage = GL_FALSE; -GLboolean __GLEW_NV_geometry_program4 = GL_FALSE; -GLboolean __GLEW_NV_geometry_shader4 = GL_FALSE; -GLboolean __GLEW_NV_gpu_program4 = GL_FALSE; -GLboolean __GLEW_NV_gpu_program5 = GL_FALSE; -GLboolean __GLEW_NV_gpu_program5_mem_extended = GL_FALSE; -GLboolean __GLEW_NV_gpu_program_fp64 = GL_FALSE; -GLboolean __GLEW_NV_gpu_shader5 = GL_FALSE; -GLboolean __GLEW_NV_half_float = GL_FALSE; -GLboolean __GLEW_NV_light_max_exponent = GL_FALSE; -GLboolean __GLEW_NV_multisample_coverage = GL_FALSE; -GLboolean __GLEW_NV_multisample_filter_hint = GL_FALSE; -GLboolean __GLEW_NV_occlusion_query = GL_FALSE; -GLboolean __GLEW_NV_packed_depth_stencil = GL_FALSE; -GLboolean __GLEW_NV_parameter_buffer_object = GL_FALSE; -GLboolean __GLEW_NV_parameter_buffer_object2 = GL_FALSE; -GLboolean __GLEW_NV_path_rendering = GL_FALSE; -GLboolean __GLEW_NV_pixel_data_range = GL_FALSE; -GLboolean __GLEW_NV_point_sprite = GL_FALSE; -GLboolean __GLEW_NV_present_video = GL_FALSE; -GLboolean __GLEW_NV_primitive_restart = GL_FALSE; -GLboolean __GLEW_NV_register_combiners = GL_FALSE; -GLboolean __GLEW_NV_register_combiners2 = GL_FALSE; -GLboolean __GLEW_NV_shader_atomic_counters = GL_FALSE; -GLboolean __GLEW_NV_shader_atomic_float = GL_FALSE; -GLboolean __GLEW_NV_shader_buffer_load = GL_FALSE; -GLboolean __GLEW_NV_shader_storage_buffer_object = GL_FALSE; -GLboolean __GLEW_NV_tessellation_program5 = GL_FALSE; -GLboolean __GLEW_NV_texgen_emboss = GL_FALSE; -GLboolean __GLEW_NV_texgen_reflection = GL_FALSE; -GLboolean __GLEW_NV_texture_barrier = GL_FALSE; -GLboolean __GLEW_NV_texture_compression_vtc = GL_FALSE; -GLboolean __GLEW_NV_texture_env_combine4 = GL_FALSE; -GLboolean __GLEW_NV_texture_expand_normal = GL_FALSE; -GLboolean __GLEW_NV_texture_multisample = GL_FALSE; -GLboolean __GLEW_NV_texture_rectangle = GL_FALSE; -GLboolean __GLEW_NV_texture_shader = GL_FALSE; -GLboolean __GLEW_NV_texture_shader2 = GL_FALSE; -GLboolean __GLEW_NV_texture_shader3 = GL_FALSE; -GLboolean __GLEW_NV_transform_feedback = GL_FALSE; -GLboolean __GLEW_NV_transform_feedback2 = GL_FALSE; -GLboolean __GLEW_NV_vdpau_interop = GL_FALSE; -GLboolean __GLEW_NV_vertex_array_range = GL_FALSE; -GLboolean __GLEW_NV_vertex_array_range2 = GL_FALSE; -GLboolean __GLEW_NV_vertex_attrib_integer_64bit = GL_FALSE; -GLboolean __GLEW_NV_vertex_buffer_unified_memory = GL_FALSE; -GLboolean __GLEW_NV_vertex_program = GL_FALSE; -GLboolean __GLEW_NV_vertex_program1_1 = GL_FALSE; -GLboolean __GLEW_NV_vertex_program2 = GL_FALSE; -GLboolean __GLEW_NV_vertex_program2_option = GL_FALSE; -GLboolean __GLEW_NV_vertex_program3 = GL_FALSE; -GLboolean __GLEW_NV_vertex_program4 = GL_FALSE; -GLboolean __GLEW_NV_video_capture = GL_FALSE; -GLboolean __GLEW_OES_byte_coordinates = GL_FALSE; -GLboolean __GLEW_OES_compressed_paletted_texture = GL_FALSE; -GLboolean __GLEW_OES_read_format = GL_FALSE; -GLboolean __GLEW_OES_single_precision = GL_FALSE; -GLboolean __GLEW_OML_interlace = GL_FALSE; -GLboolean __GLEW_OML_resample = GL_FALSE; -GLboolean __GLEW_OML_subsample = GL_FALSE; -GLboolean __GLEW_PGI_misc_hints = GL_FALSE; -GLboolean __GLEW_PGI_vertex_hints = GL_FALSE; -GLboolean __GLEW_REGAL_ES1_0_compatibility = GL_FALSE; -GLboolean __GLEW_REGAL_ES1_1_compatibility = GL_FALSE; -GLboolean __GLEW_REGAL_enable = GL_FALSE; -GLboolean __GLEW_REGAL_error_string = GL_FALSE; -GLboolean __GLEW_REGAL_extension_query = GL_FALSE; -GLboolean __GLEW_REGAL_log = GL_FALSE; -GLboolean __GLEW_REND_screen_coordinates = GL_FALSE; -GLboolean __GLEW_S3_s3tc = GL_FALSE; -GLboolean __GLEW_SGIS_color_range = GL_FALSE; -GLboolean __GLEW_SGIS_detail_texture = GL_FALSE; -GLboolean __GLEW_SGIS_fog_function = GL_FALSE; -GLboolean __GLEW_SGIS_generate_mipmap = GL_FALSE; -GLboolean __GLEW_SGIS_multisample = GL_FALSE; -GLboolean __GLEW_SGIS_pixel_texture = GL_FALSE; -GLboolean __GLEW_SGIS_point_line_texgen = GL_FALSE; -GLboolean __GLEW_SGIS_sharpen_texture = GL_FALSE; -GLboolean __GLEW_SGIS_texture4D = GL_FALSE; -GLboolean __GLEW_SGIS_texture_border_clamp = GL_FALSE; -GLboolean __GLEW_SGIS_texture_edge_clamp = GL_FALSE; -GLboolean __GLEW_SGIS_texture_filter4 = GL_FALSE; -GLboolean __GLEW_SGIS_texture_lod = GL_FALSE; -GLboolean __GLEW_SGIS_texture_select = GL_FALSE; -GLboolean __GLEW_SGIX_async = GL_FALSE; -GLboolean __GLEW_SGIX_async_histogram = GL_FALSE; -GLboolean __GLEW_SGIX_async_pixel = GL_FALSE; -GLboolean __GLEW_SGIX_blend_alpha_minmax = GL_FALSE; -GLboolean __GLEW_SGIX_clipmap = GL_FALSE; -GLboolean __GLEW_SGIX_convolution_accuracy = GL_FALSE; -GLboolean __GLEW_SGIX_depth_texture = GL_FALSE; -GLboolean __GLEW_SGIX_flush_raster = GL_FALSE; -GLboolean __GLEW_SGIX_fog_offset = GL_FALSE; -GLboolean __GLEW_SGIX_fog_texture = GL_FALSE; -GLboolean __GLEW_SGIX_fragment_specular_lighting = GL_FALSE; -GLboolean __GLEW_SGIX_framezoom = GL_FALSE; -GLboolean __GLEW_SGIX_interlace = GL_FALSE; -GLboolean __GLEW_SGIX_ir_instrument1 = GL_FALSE; -GLboolean __GLEW_SGIX_list_priority = GL_FALSE; -GLboolean __GLEW_SGIX_pixel_texture = GL_FALSE; -GLboolean __GLEW_SGIX_pixel_texture_bits = GL_FALSE; -GLboolean __GLEW_SGIX_reference_plane = GL_FALSE; -GLboolean __GLEW_SGIX_resample = GL_FALSE; -GLboolean __GLEW_SGIX_shadow = GL_FALSE; -GLboolean __GLEW_SGIX_shadow_ambient = GL_FALSE; -GLboolean __GLEW_SGIX_sprite = GL_FALSE; -GLboolean __GLEW_SGIX_tag_sample_buffer = GL_FALSE; -GLboolean __GLEW_SGIX_texture_add_env = GL_FALSE; -GLboolean __GLEW_SGIX_texture_coordinate_clamp = GL_FALSE; -GLboolean __GLEW_SGIX_texture_lod_bias = GL_FALSE; -GLboolean __GLEW_SGIX_texture_multi_buffer = GL_FALSE; -GLboolean __GLEW_SGIX_texture_range = GL_FALSE; -GLboolean __GLEW_SGIX_texture_scale_bias = GL_FALSE; -GLboolean __GLEW_SGIX_vertex_preclip = GL_FALSE; -GLboolean __GLEW_SGIX_vertex_preclip_hint = GL_FALSE; -GLboolean __GLEW_SGIX_ycrcb = GL_FALSE; -GLboolean __GLEW_SGI_color_matrix = GL_FALSE; -GLboolean __GLEW_SGI_color_table = GL_FALSE; -GLboolean __GLEW_SGI_texture_color_table = GL_FALSE; -GLboolean __GLEW_SUNX_constant_data = GL_FALSE; -GLboolean __GLEW_SUN_convolution_border_modes = GL_FALSE; -GLboolean __GLEW_SUN_global_alpha = GL_FALSE; -GLboolean __GLEW_SUN_mesh_array = GL_FALSE; -GLboolean __GLEW_SUN_read_video_pixels = GL_FALSE; -GLboolean __GLEW_SUN_slice_accum = GL_FALSE; -GLboolean __GLEW_SUN_triangle_list = GL_FALSE; -GLboolean __GLEW_SUN_vertex = GL_FALSE; -GLboolean __GLEW_WIN_phong_shading = GL_FALSE; -GLboolean __GLEW_WIN_specular_fog = GL_FALSE; -GLboolean __GLEW_WIN_swap_hint = GL_FALSE; - -#endif /* !GLEW_MX */ - -#ifdef GL_VERSION_1_2 - -static GLboolean _glewInit_GL_VERSION_1_2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCopyTexSubImage3D = (PFNGLCOPYTEXSUBIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage3D")) == NULL) || r; - r = ((glDrawRangeElements = (PFNGLDRAWRANGEELEMENTSPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElements")) == NULL) || r; - r = ((glTexImage3D = (PFNGLTEXIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glTexImage3D")) == NULL) || r; - r = ((glTexSubImage3D = (PFNGLTEXSUBIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage3D")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_1_2 */ - -#ifdef GL_VERSION_1_2_1 - -#endif /* GL_VERSION_1_2_1 */ - -#ifdef GL_VERSION_1_3 - -static GLboolean _glewInit_GL_VERSION_1_3 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glActiveTexture = (PFNGLACTIVETEXTUREPROC)glewGetProcAddress((const GLubyte*)"glActiveTexture")) == NULL) || r; - r = ((glClientActiveTexture = (PFNGLCLIENTACTIVETEXTUREPROC)glewGetProcAddress((const GLubyte*)"glClientActiveTexture")) == NULL) || r; - r = ((glCompressedTexImage1D = (PFNGLCOMPRESSEDTEXIMAGE1DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage1D")) == NULL) || r; - r = ((glCompressedTexImage2D = (PFNGLCOMPRESSEDTEXIMAGE2DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage2D")) == NULL) || r; - r = ((glCompressedTexImage3D = (PFNGLCOMPRESSEDTEXIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage3D")) == NULL) || r; - r = ((glCompressedTexSubImage1D = (PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage1D")) == NULL) || r; - r = ((glCompressedTexSubImage2D = (PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage2D")) == NULL) || r; - r = ((glCompressedTexSubImage3D = (PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage3D")) == NULL) || r; - r = ((glGetCompressedTexImage = (PFNGLGETCOMPRESSEDTEXIMAGEPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedTexImage")) == NULL) || r; - r = ((glLoadTransposeMatrixd = (PFNGLLOADTRANSPOSEMATRIXDPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixd")) == NULL) || r; - r = ((glLoadTransposeMatrixf = (PFNGLLOADTRANSPOSEMATRIXFPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixf")) == NULL) || r; - r = ((glMultTransposeMatrixd = (PFNGLMULTTRANSPOSEMATRIXDPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixd")) == NULL) || r; - r = ((glMultTransposeMatrixf = (PFNGLMULTTRANSPOSEMATRIXFPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixf")) == NULL) || r; - r = ((glMultiTexCoord1d = (PFNGLMULTITEXCOORD1DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1d")) == NULL) || r; - r = ((glMultiTexCoord1dv = (PFNGLMULTITEXCOORD1DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1dv")) == NULL) || r; - r = ((glMultiTexCoord1f = (PFNGLMULTITEXCOORD1FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1f")) == NULL) || r; - r = ((glMultiTexCoord1fv = (PFNGLMULTITEXCOORD1FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1fv")) == NULL) || r; - r = ((glMultiTexCoord1i = (PFNGLMULTITEXCOORD1IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1i")) == NULL) || r; - r = ((glMultiTexCoord1iv = (PFNGLMULTITEXCOORD1IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1iv")) == NULL) || r; - r = ((glMultiTexCoord1s = (PFNGLMULTITEXCOORD1SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1s")) == NULL) || r; - r = ((glMultiTexCoord1sv = (PFNGLMULTITEXCOORD1SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1sv")) == NULL) || r; - r = ((glMultiTexCoord2d = (PFNGLMULTITEXCOORD2DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2d")) == NULL) || r; - r = ((glMultiTexCoord2dv = (PFNGLMULTITEXCOORD2DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2dv")) == NULL) || r; - r = ((glMultiTexCoord2f = (PFNGLMULTITEXCOORD2FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2f")) == NULL) || r; - r = ((glMultiTexCoord2fv = (PFNGLMULTITEXCOORD2FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2fv")) == NULL) || r; - r = ((glMultiTexCoord2i = (PFNGLMULTITEXCOORD2IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2i")) == NULL) || r; - r = ((glMultiTexCoord2iv = (PFNGLMULTITEXCOORD2IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2iv")) == NULL) || r; - r = ((glMultiTexCoord2s = (PFNGLMULTITEXCOORD2SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2s")) == NULL) || r; - r = ((glMultiTexCoord2sv = (PFNGLMULTITEXCOORD2SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2sv")) == NULL) || r; - r = ((glMultiTexCoord3d = (PFNGLMULTITEXCOORD3DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3d")) == NULL) || r; - r = ((glMultiTexCoord3dv = (PFNGLMULTITEXCOORD3DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3dv")) == NULL) || r; - r = ((glMultiTexCoord3f = (PFNGLMULTITEXCOORD3FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3f")) == NULL) || r; - r = ((glMultiTexCoord3fv = (PFNGLMULTITEXCOORD3FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3fv")) == NULL) || r; - r = ((glMultiTexCoord3i = (PFNGLMULTITEXCOORD3IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3i")) == NULL) || r; - r = ((glMultiTexCoord3iv = (PFNGLMULTITEXCOORD3IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3iv")) == NULL) || r; - r = ((glMultiTexCoord3s = (PFNGLMULTITEXCOORD3SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3s")) == NULL) || r; - r = ((glMultiTexCoord3sv = (PFNGLMULTITEXCOORD3SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3sv")) == NULL) || r; - r = ((glMultiTexCoord4d = (PFNGLMULTITEXCOORD4DPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4d")) == NULL) || r; - r = ((glMultiTexCoord4dv = (PFNGLMULTITEXCOORD4DVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4dv")) == NULL) || r; - r = ((glMultiTexCoord4f = (PFNGLMULTITEXCOORD4FPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4f")) == NULL) || r; - r = ((glMultiTexCoord4fv = (PFNGLMULTITEXCOORD4FVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4fv")) == NULL) || r; - r = ((glMultiTexCoord4i = (PFNGLMULTITEXCOORD4IPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4i")) == NULL) || r; - r = ((glMultiTexCoord4iv = (PFNGLMULTITEXCOORD4IVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4iv")) == NULL) || r; - r = ((glMultiTexCoord4s = (PFNGLMULTITEXCOORD4SPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4s")) == NULL) || r; - r = ((glMultiTexCoord4sv = (PFNGLMULTITEXCOORD4SVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4sv")) == NULL) || r; - r = ((glSampleCoverage = (PFNGLSAMPLECOVERAGEPROC)glewGetProcAddress((const GLubyte*)"glSampleCoverage")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_1_3 */ - -#ifdef GL_VERSION_1_4 - -static GLboolean _glewInit_GL_VERSION_1_4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendColor = (PFNGLBLENDCOLORPROC)glewGetProcAddress((const GLubyte*)"glBlendColor")) == NULL) || r; - r = ((glBlendEquation = (PFNGLBLENDEQUATIONPROC)glewGetProcAddress((const GLubyte*)"glBlendEquation")) == NULL) || r; - r = ((glBlendFuncSeparate = (PFNGLBLENDFUNCSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparate")) == NULL) || r; - r = ((glFogCoordPointer = (PFNGLFOGCOORDPOINTERPROC)glewGetProcAddress((const GLubyte*)"glFogCoordPointer")) == NULL) || r; - r = ((glFogCoordd = (PFNGLFOGCOORDDPROC)glewGetProcAddress((const GLubyte*)"glFogCoordd")) == NULL) || r; - r = ((glFogCoorddv = (PFNGLFOGCOORDDVPROC)glewGetProcAddress((const GLubyte*)"glFogCoorddv")) == NULL) || r; - r = ((glFogCoordf = (PFNGLFOGCOORDFPROC)glewGetProcAddress((const GLubyte*)"glFogCoordf")) == NULL) || r; - r = ((glFogCoordfv = (PFNGLFOGCOORDFVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordfv")) == NULL) || r; - r = ((glMultiDrawArrays = (PFNGLMULTIDRAWARRAYSPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArrays")) == NULL) || r; - r = ((glMultiDrawElements = (PFNGLMULTIDRAWELEMENTSPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElements")) == NULL) || r; - r = ((glPointParameterf = (PFNGLPOINTPARAMETERFPROC)glewGetProcAddress((const GLubyte*)"glPointParameterf")) == NULL) || r; - r = ((glPointParameterfv = (PFNGLPOINTPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfv")) == NULL) || r; - r = ((glPointParameteri = (PFNGLPOINTPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glPointParameteri")) == NULL) || r; - r = ((glPointParameteriv = (PFNGLPOINTPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glPointParameteriv")) == NULL) || r; - r = ((glSecondaryColor3b = (PFNGLSECONDARYCOLOR3BPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3b")) == NULL) || r; - r = ((glSecondaryColor3bv = (PFNGLSECONDARYCOLOR3BVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3bv")) == NULL) || r; - r = ((glSecondaryColor3d = (PFNGLSECONDARYCOLOR3DPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3d")) == NULL) || r; - r = ((glSecondaryColor3dv = (PFNGLSECONDARYCOLOR3DVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3dv")) == NULL) || r; - r = ((glSecondaryColor3f = (PFNGLSECONDARYCOLOR3FPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3f")) == NULL) || r; - r = ((glSecondaryColor3fv = (PFNGLSECONDARYCOLOR3FVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3fv")) == NULL) || r; - r = ((glSecondaryColor3i = (PFNGLSECONDARYCOLOR3IPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3i")) == NULL) || r; - r = ((glSecondaryColor3iv = (PFNGLSECONDARYCOLOR3IVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3iv")) == NULL) || r; - r = ((glSecondaryColor3s = (PFNGLSECONDARYCOLOR3SPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3s")) == NULL) || r; - r = ((glSecondaryColor3sv = (PFNGLSECONDARYCOLOR3SVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3sv")) == NULL) || r; - r = ((glSecondaryColor3ub = (PFNGLSECONDARYCOLOR3UBPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ub")) == NULL) || r; - r = ((glSecondaryColor3ubv = (PFNGLSECONDARYCOLOR3UBVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ubv")) == NULL) || r; - r = ((glSecondaryColor3ui = (PFNGLSECONDARYCOLOR3UIPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ui")) == NULL) || r; - r = ((glSecondaryColor3uiv = (PFNGLSECONDARYCOLOR3UIVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3uiv")) == NULL) || r; - r = ((glSecondaryColor3us = (PFNGLSECONDARYCOLOR3USPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3us")) == NULL) || r; - r = ((glSecondaryColor3usv = (PFNGLSECONDARYCOLOR3USVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3usv")) == NULL) || r; - r = ((glSecondaryColorPointer = (PFNGLSECONDARYCOLORPOINTERPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorPointer")) == NULL) || r; - r = ((glWindowPos2d = (PFNGLWINDOWPOS2DPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2d")) == NULL) || r; - r = ((glWindowPos2dv = (PFNGLWINDOWPOS2DVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dv")) == NULL) || r; - r = ((glWindowPos2f = (PFNGLWINDOWPOS2FPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2f")) == NULL) || r; - r = ((glWindowPos2fv = (PFNGLWINDOWPOS2FVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fv")) == NULL) || r; - r = ((glWindowPos2i = (PFNGLWINDOWPOS2IPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2i")) == NULL) || r; - r = ((glWindowPos2iv = (PFNGLWINDOWPOS2IVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2iv")) == NULL) || r; - r = ((glWindowPos2s = (PFNGLWINDOWPOS2SPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2s")) == NULL) || r; - r = ((glWindowPos2sv = (PFNGLWINDOWPOS2SVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2sv")) == NULL) || r; - r = ((glWindowPos3d = (PFNGLWINDOWPOS3DPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3d")) == NULL) || r; - r = ((glWindowPos3dv = (PFNGLWINDOWPOS3DVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dv")) == NULL) || r; - r = ((glWindowPos3f = (PFNGLWINDOWPOS3FPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3f")) == NULL) || r; - r = ((glWindowPos3fv = (PFNGLWINDOWPOS3FVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fv")) == NULL) || r; - r = ((glWindowPos3i = (PFNGLWINDOWPOS3IPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3i")) == NULL) || r; - r = ((glWindowPos3iv = (PFNGLWINDOWPOS3IVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3iv")) == NULL) || r; - r = ((glWindowPos3s = (PFNGLWINDOWPOS3SPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3s")) == NULL) || r; - r = ((glWindowPos3sv = (PFNGLWINDOWPOS3SVPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3sv")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_1_4 */ - -#ifdef GL_VERSION_1_5 - -static GLboolean _glewInit_GL_VERSION_1_5 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginQuery = (PFNGLBEGINQUERYPROC)glewGetProcAddress((const GLubyte*)"glBeginQuery")) == NULL) || r; - r = ((glBindBuffer = (PFNGLBINDBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindBuffer")) == NULL) || r; - r = ((glBufferData = (PFNGLBUFFERDATAPROC)glewGetProcAddress((const GLubyte*)"glBufferData")) == NULL) || r; - r = ((glBufferSubData = (PFNGLBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glBufferSubData")) == NULL) || r; - r = ((glDeleteBuffers = (PFNGLDELETEBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteBuffers")) == NULL) || r; - r = ((glDeleteQueries = (PFNGLDELETEQUERIESPROC)glewGetProcAddress((const GLubyte*)"glDeleteQueries")) == NULL) || r; - r = ((glEndQuery = (PFNGLENDQUERYPROC)glewGetProcAddress((const GLubyte*)"glEndQuery")) == NULL) || r; - r = ((glGenBuffers = (PFNGLGENBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glGenBuffers")) == NULL) || r; - r = ((glGenQueries = (PFNGLGENQUERIESPROC)glewGetProcAddress((const GLubyte*)"glGenQueries")) == NULL) || r; - r = ((glGetBufferParameteriv = (PFNGLGETBUFFERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameteriv")) == NULL) || r; - r = ((glGetBufferPointerv = (PFNGLGETBUFFERPOINTERVPROC)glewGetProcAddress((const GLubyte*)"glGetBufferPointerv")) == NULL) || r; - r = ((glGetBufferSubData = (PFNGLGETBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glGetBufferSubData")) == NULL) || r; - r = ((glGetQueryObjectiv = (PFNGLGETQUERYOBJECTIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectiv")) == NULL) || r; - r = ((glGetQueryObjectuiv = (PFNGLGETQUERYOBJECTUIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectuiv")) == NULL) || r; - r = ((glGetQueryiv = (PFNGLGETQUERYIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryiv")) == NULL) || r; - r = ((glIsBuffer = (PFNGLISBUFFERPROC)glewGetProcAddress((const GLubyte*)"glIsBuffer")) == NULL) || r; - r = ((glIsQuery = (PFNGLISQUERYPROC)glewGetProcAddress((const GLubyte*)"glIsQuery")) == NULL) || r; - r = ((glMapBuffer = (PFNGLMAPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glMapBuffer")) == NULL) || r; - r = ((glUnmapBuffer = (PFNGLUNMAPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glUnmapBuffer")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_1_5 */ - -#ifdef GL_VERSION_2_0 - -static GLboolean _glewInit_GL_VERSION_2_0 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAttachShader = (PFNGLATTACHSHADERPROC)glewGetProcAddress((const GLubyte*)"glAttachShader")) == NULL) || r; - r = ((glBindAttribLocation = (PFNGLBINDATTRIBLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glBindAttribLocation")) == NULL) || r; - r = ((glBlendEquationSeparate = (PFNGLBLENDEQUATIONSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparate")) == NULL) || r; - r = ((glCompileShader = (PFNGLCOMPILESHADERPROC)glewGetProcAddress((const GLubyte*)"glCompileShader")) == NULL) || r; - r = ((glCreateProgram = (PFNGLCREATEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glCreateProgram")) == NULL) || r; - r = ((glCreateShader = (PFNGLCREATESHADERPROC)glewGetProcAddress((const GLubyte*)"glCreateShader")) == NULL) || r; - r = ((glDeleteProgram = (PFNGLDELETEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgram")) == NULL) || r; - r = ((glDeleteShader = (PFNGLDELETESHADERPROC)glewGetProcAddress((const GLubyte*)"glDeleteShader")) == NULL) || r; - r = ((glDetachShader = (PFNGLDETACHSHADERPROC)glewGetProcAddress((const GLubyte*)"glDetachShader")) == NULL) || r; - r = ((glDisableVertexAttribArray = (PFNGLDISABLEVERTEXATTRIBARRAYPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexAttribArray")) == NULL) || r; - r = ((glDrawBuffers = (PFNGLDRAWBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDrawBuffers")) == NULL) || r; - r = ((glEnableVertexAttribArray = (PFNGLENABLEVERTEXATTRIBARRAYPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexAttribArray")) == NULL) || r; - r = ((glGetActiveAttrib = (PFNGLGETACTIVEATTRIBPROC)glewGetProcAddress((const GLubyte*)"glGetActiveAttrib")) == NULL) || r; - r = ((glGetActiveUniform = (PFNGLGETACTIVEUNIFORMPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniform")) == NULL) || r; - r = ((glGetAttachedShaders = (PFNGLGETATTACHEDSHADERSPROC)glewGetProcAddress((const GLubyte*)"glGetAttachedShaders")) == NULL) || r; - r = ((glGetAttribLocation = (PFNGLGETATTRIBLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetAttribLocation")) == NULL) || r; - r = ((glGetProgramInfoLog = (PFNGLGETPROGRAMINFOLOGPROC)glewGetProcAddress((const GLubyte*)"glGetProgramInfoLog")) == NULL) || r; - r = ((glGetProgramiv = (PFNGLGETPROGRAMIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramiv")) == NULL) || r; - r = ((glGetShaderInfoLog = (PFNGLGETSHADERINFOLOGPROC)glewGetProcAddress((const GLubyte*)"glGetShaderInfoLog")) == NULL) || r; - r = ((glGetShaderSource = (PFNGLGETSHADERSOURCEPROC)glewGetProcAddress((const GLubyte*)"glGetShaderSource")) == NULL) || r; - r = ((glGetShaderiv = (PFNGLGETSHADERIVPROC)glewGetProcAddress((const GLubyte*)"glGetShaderiv")) == NULL) || r; - r = ((glGetUniformLocation = (PFNGLGETUNIFORMLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetUniformLocation")) == NULL) || r; - r = ((glGetUniformfv = (PFNGLGETUNIFORMFVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformfv")) == NULL) || r; - r = ((glGetUniformiv = (PFNGLGETUNIFORMIVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformiv")) == NULL) || r; - r = ((glGetVertexAttribPointerv = (PFNGLGETVERTEXATTRIBPOINTERVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribPointerv")) == NULL) || r; - r = ((glGetVertexAttribdv = (PFNGLGETVERTEXATTRIBDVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribdv")) == NULL) || r; - r = ((glGetVertexAttribfv = (PFNGLGETVERTEXATTRIBFVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribfv")) == NULL) || r; - r = ((glGetVertexAttribiv = (PFNGLGETVERTEXATTRIBIVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribiv")) == NULL) || r; - r = ((glIsProgram = (PFNGLISPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glIsProgram")) == NULL) || r; - r = ((glIsShader = (PFNGLISSHADERPROC)glewGetProcAddress((const GLubyte*)"glIsShader")) == NULL) || r; - r = ((glLinkProgram = (PFNGLLINKPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glLinkProgram")) == NULL) || r; - r = ((glShaderSource = (PFNGLSHADERSOURCEPROC)glewGetProcAddress((const GLubyte*)"glShaderSource")) == NULL) || r; - r = ((glStencilFuncSeparate = (PFNGLSTENCILFUNCSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glStencilFuncSeparate")) == NULL) || r; - r = ((glStencilMaskSeparate = (PFNGLSTENCILMASKSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glStencilMaskSeparate")) == NULL) || r; - r = ((glStencilOpSeparate = (PFNGLSTENCILOPSEPARATEPROC)glewGetProcAddress((const GLubyte*)"glStencilOpSeparate")) == NULL) || r; - r = ((glUniform1f = (PFNGLUNIFORM1FPROC)glewGetProcAddress((const GLubyte*)"glUniform1f")) == NULL) || r; - r = ((glUniform1fv = (PFNGLUNIFORM1FVPROC)glewGetProcAddress((const GLubyte*)"glUniform1fv")) == NULL) || r; - r = ((glUniform1i = (PFNGLUNIFORM1IPROC)glewGetProcAddress((const GLubyte*)"glUniform1i")) == NULL) || r; - r = ((glUniform1iv = (PFNGLUNIFORM1IVPROC)glewGetProcAddress((const GLubyte*)"glUniform1iv")) == NULL) || r; - r = ((glUniform2f = (PFNGLUNIFORM2FPROC)glewGetProcAddress((const GLubyte*)"glUniform2f")) == NULL) || r; - r = ((glUniform2fv = (PFNGLUNIFORM2FVPROC)glewGetProcAddress((const GLubyte*)"glUniform2fv")) == NULL) || r; - r = ((glUniform2i = (PFNGLUNIFORM2IPROC)glewGetProcAddress((const GLubyte*)"glUniform2i")) == NULL) || r; - r = ((glUniform2iv = (PFNGLUNIFORM2IVPROC)glewGetProcAddress((const GLubyte*)"glUniform2iv")) == NULL) || r; - r = ((glUniform3f = (PFNGLUNIFORM3FPROC)glewGetProcAddress((const GLubyte*)"glUniform3f")) == NULL) || r; - r = ((glUniform3fv = (PFNGLUNIFORM3FVPROC)glewGetProcAddress((const GLubyte*)"glUniform3fv")) == NULL) || r; - r = ((glUniform3i = (PFNGLUNIFORM3IPROC)glewGetProcAddress((const GLubyte*)"glUniform3i")) == NULL) || r; - r = ((glUniform3iv = (PFNGLUNIFORM3IVPROC)glewGetProcAddress((const GLubyte*)"glUniform3iv")) == NULL) || r; - r = ((glUniform4f = (PFNGLUNIFORM4FPROC)glewGetProcAddress((const GLubyte*)"glUniform4f")) == NULL) || r; - r = ((glUniform4fv = (PFNGLUNIFORM4FVPROC)glewGetProcAddress((const GLubyte*)"glUniform4fv")) == NULL) || r; - r = ((glUniform4i = (PFNGLUNIFORM4IPROC)glewGetProcAddress((const GLubyte*)"glUniform4i")) == NULL) || r; - r = ((glUniform4iv = (PFNGLUNIFORM4IVPROC)glewGetProcAddress((const GLubyte*)"glUniform4iv")) == NULL) || r; - r = ((glUniformMatrix2fv = (PFNGLUNIFORMMATRIX2FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2fv")) == NULL) || r; - r = ((glUniformMatrix3fv = (PFNGLUNIFORMMATRIX3FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3fv")) == NULL) || r; - r = ((glUniformMatrix4fv = (PFNGLUNIFORMMATRIX4FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4fv")) == NULL) || r; - r = ((glUseProgram = (PFNGLUSEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glUseProgram")) == NULL) || r; - r = ((glValidateProgram = (PFNGLVALIDATEPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glValidateProgram")) == NULL) || r; - r = ((glVertexAttrib1d = (PFNGLVERTEXATTRIB1DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1d")) == NULL) || r; - r = ((glVertexAttrib1dv = (PFNGLVERTEXATTRIB1DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dv")) == NULL) || r; - r = ((glVertexAttrib1f = (PFNGLVERTEXATTRIB1FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1f")) == NULL) || r; - r = ((glVertexAttrib1fv = (PFNGLVERTEXATTRIB1FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fv")) == NULL) || r; - r = ((glVertexAttrib1s = (PFNGLVERTEXATTRIB1SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1s")) == NULL) || r; - r = ((glVertexAttrib1sv = (PFNGLVERTEXATTRIB1SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1sv")) == NULL) || r; - r = ((glVertexAttrib2d = (PFNGLVERTEXATTRIB2DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2d")) == NULL) || r; - r = ((glVertexAttrib2dv = (PFNGLVERTEXATTRIB2DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dv")) == NULL) || r; - r = ((glVertexAttrib2f = (PFNGLVERTEXATTRIB2FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2f")) == NULL) || r; - r = ((glVertexAttrib2fv = (PFNGLVERTEXATTRIB2FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fv")) == NULL) || r; - r = ((glVertexAttrib2s = (PFNGLVERTEXATTRIB2SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2s")) == NULL) || r; - r = ((glVertexAttrib2sv = (PFNGLVERTEXATTRIB2SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2sv")) == NULL) || r; - r = ((glVertexAttrib3d = (PFNGLVERTEXATTRIB3DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3d")) == NULL) || r; - r = ((glVertexAttrib3dv = (PFNGLVERTEXATTRIB3DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dv")) == NULL) || r; - r = ((glVertexAttrib3f = (PFNGLVERTEXATTRIB3FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3f")) == NULL) || r; - r = ((glVertexAttrib3fv = (PFNGLVERTEXATTRIB3FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fv")) == NULL) || r; - r = ((glVertexAttrib3s = (PFNGLVERTEXATTRIB3SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3s")) == NULL) || r; - r = ((glVertexAttrib3sv = (PFNGLVERTEXATTRIB3SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3sv")) == NULL) || r; - r = ((glVertexAttrib4Nbv = (PFNGLVERTEXATTRIB4NBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nbv")) == NULL) || r; - r = ((glVertexAttrib4Niv = (PFNGLVERTEXATTRIB4NIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Niv")) == NULL) || r; - r = ((glVertexAttrib4Nsv = (PFNGLVERTEXATTRIB4NSVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nsv")) == NULL) || r; - r = ((glVertexAttrib4Nub = (PFNGLVERTEXATTRIB4NUBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nub")) == NULL) || r; - r = ((glVertexAttrib4Nubv = (PFNGLVERTEXATTRIB4NUBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nubv")) == NULL) || r; - r = ((glVertexAttrib4Nuiv = (PFNGLVERTEXATTRIB4NUIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nuiv")) == NULL) || r; - r = ((glVertexAttrib4Nusv = (PFNGLVERTEXATTRIB4NUSVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4Nusv")) == NULL) || r; - r = ((glVertexAttrib4bv = (PFNGLVERTEXATTRIB4BVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4bv")) == NULL) || r; - r = ((glVertexAttrib4d = (PFNGLVERTEXATTRIB4DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4d")) == NULL) || r; - r = ((glVertexAttrib4dv = (PFNGLVERTEXATTRIB4DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dv")) == NULL) || r; - r = ((glVertexAttrib4f = (PFNGLVERTEXATTRIB4FPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4f")) == NULL) || r; - r = ((glVertexAttrib4fv = (PFNGLVERTEXATTRIB4FVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fv")) == NULL) || r; - r = ((glVertexAttrib4iv = (PFNGLVERTEXATTRIB4IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4iv")) == NULL) || r; - r = ((glVertexAttrib4s = (PFNGLVERTEXATTRIB4SPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4s")) == NULL) || r; - r = ((glVertexAttrib4sv = (PFNGLVERTEXATTRIB4SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4sv")) == NULL) || r; - r = ((glVertexAttrib4ubv = (PFNGLVERTEXATTRIB4UBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubv")) == NULL) || r; - r = ((glVertexAttrib4uiv = (PFNGLVERTEXATTRIB4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4uiv")) == NULL) || r; - r = ((glVertexAttrib4usv = (PFNGLVERTEXATTRIB4USVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4usv")) == NULL) || r; - r = ((glVertexAttribPointer = (PFNGLVERTEXATTRIBPOINTERPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribPointer")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_2_0 */ - -#ifdef GL_VERSION_2_1 - -static GLboolean _glewInit_GL_VERSION_2_1 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glUniformMatrix2x3fv = (PFNGLUNIFORMMATRIX2X3FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2x3fv")) == NULL) || r; - r = ((glUniformMatrix2x4fv = (PFNGLUNIFORMMATRIX2X4FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2x4fv")) == NULL) || r; - r = ((glUniformMatrix3x2fv = (PFNGLUNIFORMMATRIX3X2FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3x2fv")) == NULL) || r; - r = ((glUniformMatrix3x4fv = (PFNGLUNIFORMMATRIX3X4FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3x4fv")) == NULL) || r; - r = ((glUniformMatrix4x2fv = (PFNGLUNIFORMMATRIX4X2FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4x2fv")) == NULL) || r; - r = ((glUniformMatrix4x3fv = (PFNGLUNIFORMMATRIX4X3FVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4x3fv")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_2_1 */ - -#ifdef GL_VERSION_3_0 - -static GLboolean _glewInit_GL_VERSION_3_0 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginConditionalRender = (PFNGLBEGINCONDITIONALRENDERPROC)glewGetProcAddress((const GLubyte*)"glBeginConditionalRender")) == NULL) || r; - r = ((glBeginTransformFeedback = (PFNGLBEGINTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glBeginTransformFeedback")) == NULL) || r; - r = ((glBindFragDataLocation = (PFNGLBINDFRAGDATALOCATIONPROC)glewGetProcAddress((const GLubyte*)"glBindFragDataLocation")) == NULL) || r; - r = ((glClampColor = (PFNGLCLAMPCOLORPROC)glewGetProcAddress((const GLubyte*)"glClampColor")) == NULL) || r; - r = ((glClearBufferfi = (PFNGLCLEARBUFFERFIPROC)glewGetProcAddress((const GLubyte*)"glClearBufferfi")) == NULL) || r; - r = ((glClearBufferfv = (PFNGLCLEARBUFFERFVPROC)glewGetProcAddress((const GLubyte*)"glClearBufferfv")) == NULL) || r; - r = ((glClearBufferiv = (PFNGLCLEARBUFFERIVPROC)glewGetProcAddress((const GLubyte*)"glClearBufferiv")) == NULL) || r; - r = ((glClearBufferuiv = (PFNGLCLEARBUFFERUIVPROC)glewGetProcAddress((const GLubyte*)"glClearBufferuiv")) == NULL) || r; - r = ((glColorMaski = (PFNGLCOLORMASKIPROC)glewGetProcAddress((const GLubyte*)"glColorMaski")) == NULL) || r; - r = ((glDisablei = (PFNGLDISABLEIPROC)glewGetProcAddress((const GLubyte*)"glDisablei")) == NULL) || r; - r = ((glEnablei = (PFNGLENABLEIPROC)glewGetProcAddress((const GLubyte*)"glEnablei")) == NULL) || r; - r = ((glEndConditionalRender = (PFNGLENDCONDITIONALRENDERPROC)glewGetProcAddress((const GLubyte*)"glEndConditionalRender")) == NULL) || r; - r = ((glEndTransformFeedback = (PFNGLENDTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glEndTransformFeedback")) == NULL) || r; - r = ((glGetBooleani_v = (PFNGLGETBOOLEANI_VPROC)glewGetProcAddress((const GLubyte*)"glGetBooleani_v")) == NULL) || r; - r = ((glGetFragDataLocation = (PFNGLGETFRAGDATALOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetFragDataLocation")) == NULL) || r; - r = ((glGetStringi = (PFNGLGETSTRINGIPROC)glewGetProcAddress((const GLubyte*)"glGetStringi")) == NULL) || r; - r = ((glGetTexParameterIiv = (PFNGLGETTEXPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIiv")) == NULL) || r; - r = ((glGetTexParameterIuiv = (PFNGLGETTEXPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIuiv")) == NULL) || r; - r = ((glGetTransformFeedbackVarying = (PFNGLGETTRANSFORMFEEDBACKVARYINGPROC)glewGetProcAddress((const GLubyte*)"glGetTransformFeedbackVarying")) == NULL) || r; - r = ((glGetUniformuiv = (PFNGLGETUNIFORMUIVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformuiv")) == NULL) || r; - r = ((glGetVertexAttribIiv = (PFNGLGETVERTEXATTRIBIIVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIiv")) == NULL) || r; - r = ((glGetVertexAttribIuiv = (PFNGLGETVERTEXATTRIBIUIVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIuiv")) == NULL) || r; - r = ((glIsEnabledi = (PFNGLISENABLEDIPROC)glewGetProcAddress((const GLubyte*)"glIsEnabledi")) == NULL) || r; - r = ((glTexParameterIiv = (PFNGLTEXPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIiv")) == NULL) || r; - r = ((glTexParameterIuiv = (PFNGLTEXPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIuiv")) == NULL) || r; - r = ((glTransformFeedbackVaryings = (PFNGLTRANSFORMFEEDBACKVARYINGSPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackVaryings")) == NULL) || r; - r = ((glUniform1ui = (PFNGLUNIFORM1UIPROC)glewGetProcAddress((const GLubyte*)"glUniform1ui")) == NULL) || r; - r = ((glUniform1uiv = (PFNGLUNIFORM1UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform1uiv")) == NULL) || r; - r = ((glUniform2ui = (PFNGLUNIFORM2UIPROC)glewGetProcAddress((const GLubyte*)"glUniform2ui")) == NULL) || r; - r = ((glUniform2uiv = (PFNGLUNIFORM2UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform2uiv")) == NULL) || r; - r = ((glUniform3ui = (PFNGLUNIFORM3UIPROC)glewGetProcAddress((const GLubyte*)"glUniform3ui")) == NULL) || r; - r = ((glUniform3uiv = (PFNGLUNIFORM3UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform3uiv")) == NULL) || r; - r = ((glUniform4ui = (PFNGLUNIFORM4UIPROC)glewGetProcAddress((const GLubyte*)"glUniform4ui")) == NULL) || r; - r = ((glUniform4uiv = (PFNGLUNIFORM4UIVPROC)glewGetProcAddress((const GLubyte*)"glUniform4uiv")) == NULL) || r; - r = ((glVertexAttribI1i = (PFNGLVERTEXATTRIBI1IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1i")) == NULL) || r; - r = ((glVertexAttribI1iv = (PFNGLVERTEXATTRIBI1IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1iv")) == NULL) || r; - r = ((glVertexAttribI1ui = (PFNGLVERTEXATTRIBI1UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1ui")) == NULL) || r; - r = ((glVertexAttribI1uiv = (PFNGLVERTEXATTRIBI1UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1uiv")) == NULL) || r; - r = ((glVertexAttribI2i = (PFNGLVERTEXATTRIBI2IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2i")) == NULL) || r; - r = ((glVertexAttribI2iv = (PFNGLVERTEXATTRIBI2IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2iv")) == NULL) || r; - r = ((glVertexAttribI2ui = (PFNGLVERTEXATTRIBI2UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2ui")) == NULL) || r; - r = ((glVertexAttribI2uiv = (PFNGLVERTEXATTRIBI2UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2uiv")) == NULL) || r; - r = ((glVertexAttribI3i = (PFNGLVERTEXATTRIBI3IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3i")) == NULL) || r; - r = ((glVertexAttribI3iv = (PFNGLVERTEXATTRIBI3IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3iv")) == NULL) || r; - r = ((glVertexAttribI3ui = (PFNGLVERTEXATTRIBI3UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3ui")) == NULL) || r; - r = ((glVertexAttribI3uiv = (PFNGLVERTEXATTRIBI3UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3uiv")) == NULL) || r; - r = ((glVertexAttribI4bv = (PFNGLVERTEXATTRIBI4BVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4bv")) == NULL) || r; - r = ((glVertexAttribI4i = (PFNGLVERTEXATTRIBI4IPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4i")) == NULL) || r; - r = ((glVertexAttribI4iv = (PFNGLVERTEXATTRIBI4IVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4iv")) == NULL) || r; - r = ((glVertexAttribI4sv = (PFNGLVERTEXATTRIBI4SVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4sv")) == NULL) || r; - r = ((glVertexAttribI4ubv = (PFNGLVERTEXATTRIBI4UBVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ubv")) == NULL) || r; - r = ((glVertexAttribI4ui = (PFNGLVERTEXATTRIBI4UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ui")) == NULL) || r; - r = ((glVertexAttribI4uiv = (PFNGLVERTEXATTRIBI4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4uiv")) == NULL) || r; - r = ((glVertexAttribI4usv = (PFNGLVERTEXATTRIBI4USVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4usv")) == NULL) || r; - r = ((glVertexAttribIPointer = (PFNGLVERTEXATTRIBIPOINTERPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIPointer")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_3_0 */ - -#ifdef GL_VERSION_3_1 - -static GLboolean _glewInit_GL_VERSION_3_1 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawArraysInstanced = (PFNGLDRAWARRAYSINSTANCEDPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstanced")) == NULL) || r; - r = ((glDrawElementsInstanced = (PFNGLDRAWELEMENTSINSTANCEDPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstanced")) == NULL) || r; - r = ((glPrimitiveRestartIndex = (PFNGLPRIMITIVERESTARTINDEXPROC)glewGetProcAddress((const GLubyte*)"glPrimitiveRestartIndex")) == NULL) || r; - r = ((glTexBuffer = (PFNGLTEXBUFFERPROC)glewGetProcAddress((const GLubyte*)"glTexBuffer")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_3_1 */ - -#ifdef GL_VERSION_3_2 - -static GLboolean _glewInit_GL_VERSION_3_2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFramebufferTexture = (PFNGLFRAMEBUFFERTEXTUREPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture")) == NULL) || r; - r = ((glGetBufferParameteri64v = (PFNGLGETBUFFERPARAMETERI64VPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameteri64v")) == NULL) || r; - r = ((glGetInteger64i_v = (PFNGLGETINTEGER64I_VPROC)glewGetProcAddress((const GLubyte*)"glGetInteger64i_v")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_3_2 */ - -#ifdef GL_VERSION_3_3 - -static GLboolean _glewInit_GL_VERSION_3_3 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glVertexAttribDivisor = (PFNGLVERTEXATTRIBDIVISORPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribDivisor")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_3_3 */ - -#ifdef GL_VERSION_4_0 - -static GLboolean _glewInit_GL_VERSION_4_0 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendEquationSeparatei = (PFNGLBLENDEQUATIONSEPARATEIPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparatei")) == NULL) || r; - r = ((glBlendEquationi = (PFNGLBLENDEQUATIONIPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationi")) == NULL) || r; - r = ((glBlendFuncSeparatei = (PFNGLBLENDFUNCSEPARATEIPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparatei")) == NULL) || r; - r = ((glBlendFunci = (PFNGLBLENDFUNCIPROC)glewGetProcAddress((const GLubyte*)"glBlendFunci")) == NULL) || r; - r = ((glMinSampleShading = (PFNGLMINSAMPLESHADINGPROC)glewGetProcAddress((const GLubyte*)"glMinSampleShading")) == NULL) || r; - - return r; -} - -#endif /* GL_VERSION_4_0 */ - -#ifdef GL_VERSION_4_1 - -#endif /* GL_VERSION_4_1 */ - -#ifdef GL_VERSION_4_2 - -#endif /* GL_VERSION_4_2 */ - -#ifdef GL_VERSION_4_3 - -#endif /* GL_VERSION_4_3 */ - -#ifdef GL_VERSION_4_4 - -#endif /* GL_VERSION_4_4 */ - -#ifdef GL_3DFX_multisample - -#endif /* GL_3DFX_multisample */ - -#ifdef GL_3DFX_tbuffer - -static GLboolean _glewInit_GL_3DFX_tbuffer (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTbufferMask3DFX = (PFNGLTBUFFERMASK3DFXPROC)glewGetProcAddress((const GLubyte*)"glTbufferMask3DFX")) == NULL) || r; - - return r; -} - -#endif /* GL_3DFX_tbuffer */ - -#ifdef GL_3DFX_texture_compression_FXT1 - -#endif /* GL_3DFX_texture_compression_FXT1 */ - -#ifdef GL_AMD_blend_minmax_factor - -#endif /* GL_AMD_blend_minmax_factor */ - -#ifdef GL_AMD_conservative_depth - -#endif /* GL_AMD_conservative_depth */ - -#ifdef GL_AMD_debug_output - -static GLboolean _glewInit_GL_AMD_debug_output (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDebugMessageCallbackAMD = (PFNGLDEBUGMESSAGECALLBACKAMDPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageCallbackAMD")) == NULL) || r; - r = ((glDebugMessageEnableAMD = (PFNGLDEBUGMESSAGEENABLEAMDPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageEnableAMD")) == NULL) || r; - r = ((glDebugMessageInsertAMD = (PFNGLDEBUGMESSAGEINSERTAMDPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageInsertAMD")) == NULL) || r; - r = ((glGetDebugMessageLogAMD = (PFNGLGETDEBUGMESSAGELOGAMDPROC)glewGetProcAddress((const GLubyte*)"glGetDebugMessageLogAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_debug_output */ - -#ifdef GL_AMD_depth_clamp_separate - -#endif /* GL_AMD_depth_clamp_separate */ - -#ifdef GL_AMD_draw_buffers_blend - -static GLboolean _glewInit_GL_AMD_draw_buffers_blend (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendEquationIndexedAMD = (PFNGLBLENDEQUATIONINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationIndexedAMD")) == NULL) || r; - r = ((glBlendEquationSeparateIndexedAMD = (PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparateIndexedAMD")) == NULL) || r; - r = ((glBlendFuncIndexedAMD = (PFNGLBLENDFUNCINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncIndexedAMD")) == NULL) || r; - r = ((glBlendFuncSeparateIndexedAMD = (PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparateIndexedAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_draw_buffers_blend */ - -#ifdef GL_AMD_interleaved_elements - -static GLboolean _glewInit_GL_AMD_interleaved_elements (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glVertexAttribParameteriAMD = (PFNGLVERTEXATTRIBPARAMETERIAMDPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribParameteriAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_interleaved_elements */ - -#ifdef GL_AMD_multi_draw_indirect - -static GLboolean _glewInit_GL_AMD_multi_draw_indirect (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMultiDrawArraysIndirectAMD = (PFNGLMULTIDRAWARRAYSINDIRECTAMDPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArraysIndirectAMD")) == NULL) || r; - r = ((glMultiDrawElementsIndirectAMD = (PFNGLMULTIDRAWELEMENTSINDIRECTAMDPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsIndirectAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_multi_draw_indirect */ - -#ifdef GL_AMD_name_gen_delete - -static GLboolean _glewInit_GL_AMD_name_gen_delete (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDeleteNamesAMD = (PFNGLDELETENAMESAMDPROC)glewGetProcAddress((const GLubyte*)"glDeleteNamesAMD")) == NULL) || r; - r = ((glGenNamesAMD = (PFNGLGENNAMESAMDPROC)glewGetProcAddress((const GLubyte*)"glGenNamesAMD")) == NULL) || r; - r = ((glIsNameAMD = (PFNGLISNAMEAMDPROC)glewGetProcAddress((const GLubyte*)"glIsNameAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_name_gen_delete */ - -#ifdef GL_AMD_performance_monitor - -static GLboolean _glewInit_GL_AMD_performance_monitor (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginPerfMonitorAMD = (PFNGLBEGINPERFMONITORAMDPROC)glewGetProcAddress((const GLubyte*)"glBeginPerfMonitorAMD")) == NULL) || r; - r = ((glDeletePerfMonitorsAMD = (PFNGLDELETEPERFMONITORSAMDPROC)glewGetProcAddress((const GLubyte*)"glDeletePerfMonitorsAMD")) == NULL) || r; - r = ((glEndPerfMonitorAMD = (PFNGLENDPERFMONITORAMDPROC)glewGetProcAddress((const GLubyte*)"glEndPerfMonitorAMD")) == NULL) || r; - r = ((glGenPerfMonitorsAMD = (PFNGLGENPERFMONITORSAMDPROC)glewGetProcAddress((const GLubyte*)"glGenPerfMonitorsAMD")) == NULL) || r; - r = ((glGetPerfMonitorCounterDataAMD = (PFNGLGETPERFMONITORCOUNTERDATAAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCounterDataAMD")) == NULL) || r; - r = ((glGetPerfMonitorCounterInfoAMD = (PFNGLGETPERFMONITORCOUNTERINFOAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCounterInfoAMD")) == NULL) || r; - r = ((glGetPerfMonitorCounterStringAMD = (PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCounterStringAMD")) == NULL) || r; - r = ((glGetPerfMonitorCountersAMD = (PFNGLGETPERFMONITORCOUNTERSAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorCountersAMD")) == NULL) || r; - r = ((glGetPerfMonitorGroupStringAMD = (PFNGLGETPERFMONITORGROUPSTRINGAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorGroupStringAMD")) == NULL) || r; - r = ((glGetPerfMonitorGroupsAMD = (PFNGLGETPERFMONITORGROUPSAMDPROC)glewGetProcAddress((const GLubyte*)"glGetPerfMonitorGroupsAMD")) == NULL) || r; - r = ((glSelectPerfMonitorCountersAMD = (PFNGLSELECTPERFMONITORCOUNTERSAMDPROC)glewGetProcAddress((const GLubyte*)"glSelectPerfMonitorCountersAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_performance_monitor */ - -#ifdef GL_AMD_pinned_memory - -#endif /* GL_AMD_pinned_memory */ - -#ifdef GL_AMD_query_buffer_object - -#endif /* GL_AMD_query_buffer_object */ - -#ifdef GL_AMD_sample_positions - -static GLboolean _glewInit_GL_AMD_sample_positions (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glSetMultisamplefvAMD = (PFNGLSETMULTISAMPLEFVAMDPROC)glewGetProcAddress((const GLubyte*)"glSetMultisamplefvAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_sample_positions */ - -#ifdef GL_AMD_seamless_cubemap_per_texture - -#endif /* GL_AMD_seamless_cubemap_per_texture */ - -#ifdef GL_AMD_shader_stencil_export - -#endif /* GL_AMD_shader_stencil_export */ - -#ifdef GL_AMD_shader_trinary_minmax - -#endif /* GL_AMD_shader_trinary_minmax */ - -#ifdef GL_AMD_sparse_texture - -static GLboolean _glewInit_GL_AMD_sparse_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexStorageSparseAMD = (PFNGLTEXSTORAGESPARSEAMDPROC)glewGetProcAddress((const GLubyte*)"glTexStorageSparseAMD")) == NULL) || r; - r = ((glTextureStorageSparseAMD = (PFNGLTEXTURESTORAGESPARSEAMDPROC)glewGetProcAddress((const GLubyte*)"glTextureStorageSparseAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_sparse_texture */ - -#ifdef GL_AMD_stencil_operation_extended - -static GLboolean _glewInit_GL_AMD_stencil_operation_extended (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glStencilOpValueAMD = (PFNGLSTENCILOPVALUEAMDPROC)glewGetProcAddress((const GLubyte*)"glStencilOpValueAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_stencil_operation_extended */ - -#ifdef GL_AMD_texture_texture4 - -#endif /* GL_AMD_texture_texture4 */ - -#ifdef GL_AMD_transform_feedback3_lines_triangles - -#endif /* GL_AMD_transform_feedback3_lines_triangles */ - -#ifdef GL_AMD_vertex_shader_layer - -#endif /* GL_AMD_vertex_shader_layer */ - -#ifdef GL_AMD_vertex_shader_tessellator - -static GLboolean _glewInit_GL_AMD_vertex_shader_tessellator (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTessellationFactorAMD = (PFNGLTESSELLATIONFACTORAMDPROC)glewGetProcAddress((const GLubyte*)"glTessellationFactorAMD")) == NULL) || r; - r = ((glTessellationModeAMD = (PFNGLTESSELLATIONMODEAMDPROC)glewGetProcAddress((const GLubyte*)"glTessellationModeAMD")) == NULL) || r; - - return r; -} - -#endif /* GL_AMD_vertex_shader_tessellator */ - -#ifdef GL_AMD_vertex_shader_viewport_index - -#endif /* GL_AMD_vertex_shader_viewport_index */ - -#ifdef GL_ANGLE_depth_texture - -#endif /* GL_ANGLE_depth_texture */ - -#ifdef GL_ANGLE_framebuffer_blit - -static GLboolean _glewInit_GL_ANGLE_framebuffer_blit (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlitFramebufferANGLE = (PFNGLBLITFRAMEBUFFERANGLEPROC)glewGetProcAddress((const GLubyte*)"glBlitFramebufferANGLE")) == NULL) || r; - - return r; -} - -#endif /* GL_ANGLE_framebuffer_blit */ - -#ifdef GL_ANGLE_framebuffer_multisample - -static GLboolean _glewInit_GL_ANGLE_framebuffer_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glRenderbufferStorageMultisampleANGLE = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLEANGLEPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisampleANGLE")) == NULL) || r; - - return r; -} - -#endif /* GL_ANGLE_framebuffer_multisample */ - -#ifdef GL_ANGLE_instanced_arrays - -static GLboolean _glewInit_GL_ANGLE_instanced_arrays (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawArraysInstancedANGLE = (PFNGLDRAWARRAYSINSTANCEDANGLEPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstancedANGLE")) == NULL) || r; - r = ((glDrawElementsInstancedANGLE = (PFNGLDRAWELEMENTSINSTANCEDANGLEPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedANGLE")) == NULL) || r; - r = ((glVertexAttribDivisorANGLE = (PFNGLVERTEXATTRIBDIVISORANGLEPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribDivisorANGLE")) == NULL) || r; - - return r; -} - -#endif /* GL_ANGLE_instanced_arrays */ - -#ifdef GL_ANGLE_pack_reverse_row_order - -#endif /* GL_ANGLE_pack_reverse_row_order */ - -#ifdef GL_ANGLE_program_binary - -#endif /* GL_ANGLE_program_binary */ - -#ifdef GL_ANGLE_texture_compression_dxt1 - -#endif /* GL_ANGLE_texture_compression_dxt1 */ - -#ifdef GL_ANGLE_texture_compression_dxt3 - -#endif /* GL_ANGLE_texture_compression_dxt3 */ - -#ifdef GL_ANGLE_texture_compression_dxt5 - -#endif /* GL_ANGLE_texture_compression_dxt5 */ - -#ifdef GL_ANGLE_texture_usage - -#endif /* GL_ANGLE_texture_usage */ - -#ifdef GL_ANGLE_timer_query - -static GLboolean _glewInit_GL_ANGLE_timer_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginQueryANGLE = (PFNGLBEGINQUERYANGLEPROC)glewGetProcAddress((const GLubyte*)"glBeginQueryANGLE")) == NULL) || r; - r = ((glDeleteQueriesANGLE = (PFNGLDELETEQUERIESANGLEPROC)glewGetProcAddress((const GLubyte*)"glDeleteQueriesANGLE")) == NULL) || r; - r = ((glEndQueryANGLE = (PFNGLENDQUERYANGLEPROC)glewGetProcAddress((const GLubyte*)"glEndQueryANGLE")) == NULL) || r; - r = ((glGenQueriesANGLE = (PFNGLGENQUERIESANGLEPROC)glewGetProcAddress((const GLubyte*)"glGenQueriesANGLE")) == NULL) || r; - r = ((glGetQueryObjecti64vANGLE = (PFNGLGETQUERYOBJECTI64VANGLEPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjecti64vANGLE")) == NULL) || r; - r = ((glGetQueryObjectivANGLE = (PFNGLGETQUERYOBJECTIVANGLEPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectivANGLE")) == NULL) || r; - r = ((glGetQueryObjectui64vANGLE = (PFNGLGETQUERYOBJECTUI64VANGLEPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectui64vANGLE")) == NULL) || r; - r = ((glGetQueryObjectuivANGLE = (PFNGLGETQUERYOBJECTUIVANGLEPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectuivANGLE")) == NULL) || r; - r = ((glGetQueryivANGLE = (PFNGLGETQUERYIVANGLEPROC)glewGetProcAddress((const GLubyte*)"glGetQueryivANGLE")) == NULL) || r; - r = ((glIsQueryANGLE = (PFNGLISQUERYANGLEPROC)glewGetProcAddress((const GLubyte*)"glIsQueryANGLE")) == NULL) || r; - r = ((glQueryCounterANGLE = (PFNGLQUERYCOUNTERANGLEPROC)glewGetProcAddress((const GLubyte*)"glQueryCounterANGLE")) == NULL) || r; - - return r; -} - -#endif /* GL_ANGLE_timer_query */ - -#ifdef GL_ANGLE_translated_shader_source - -static GLboolean _glewInit_GL_ANGLE_translated_shader_source (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetTranslatedShaderSourceANGLE = (PFNGLGETTRANSLATEDSHADERSOURCEANGLEPROC)glewGetProcAddress((const GLubyte*)"glGetTranslatedShaderSourceANGLE")) == NULL) || r; - - return r; -} - -#endif /* GL_ANGLE_translated_shader_source */ - -#ifdef GL_APPLE_aux_depth_stencil - -#endif /* GL_APPLE_aux_depth_stencil */ - -#ifdef GL_APPLE_client_storage - -#endif /* GL_APPLE_client_storage */ - -#ifdef GL_APPLE_element_array - -static GLboolean _glewInit_GL_APPLE_element_array (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawElementArrayAPPLE = (PFNGLDRAWELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDrawElementArrayAPPLE")) == NULL) || r; - r = ((glDrawRangeElementArrayAPPLE = (PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementArrayAPPLE")) == NULL) || r; - r = ((glElementPointerAPPLE = (PFNGLELEMENTPOINTERAPPLEPROC)glewGetProcAddress((const GLubyte*)"glElementPointerAPPLE")) == NULL) || r; - r = ((glMultiDrawElementArrayAPPLE = (PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementArrayAPPLE")) == NULL) || r; - r = ((glMultiDrawRangeElementArrayAPPLE = (PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawRangeElementArrayAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_element_array */ - -#ifdef GL_APPLE_fence - -static GLboolean _glewInit_GL_APPLE_fence (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDeleteFencesAPPLE = (PFNGLDELETEFENCESAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDeleteFencesAPPLE")) == NULL) || r; - r = ((glFinishFenceAPPLE = (PFNGLFINISHFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFinishFenceAPPLE")) == NULL) || r; - r = ((glFinishObjectAPPLE = (PFNGLFINISHOBJECTAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFinishObjectAPPLE")) == NULL) || r; - r = ((glGenFencesAPPLE = (PFNGLGENFENCESAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGenFencesAPPLE")) == NULL) || r; - r = ((glIsFenceAPPLE = (PFNGLISFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glIsFenceAPPLE")) == NULL) || r; - r = ((glSetFenceAPPLE = (PFNGLSETFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glSetFenceAPPLE")) == NULL) || r; - r = ((glTestFenceAPPLE = (PFNGLTESTFENCEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glTestFenceAPPLE")) == NULL) || r; - r = ((glTestObjectAPPLE = (PFNGLTESTOBJECTAPPLEPROC)glewGetProcAddress((const GLubyte*)"glTestObjectAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_fence */ - -#ifdef GL_APPLE_float_pixels - -#endif /* GL_APPLE_float_pixels */ - -#ifdef GL_APPLE_flush_buffer_range - -static GLboolean _glewInit_GL_APPLE_flush_buffer_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBufferParameteriAPPLE = (PFNGLBUFFERPARAMETERIAPPLEPROC)glewGetProcAddress((const GLubyte*)"glBufferParameteriAPPLE")) == NULL) || r; - r = ((glFlushMappedBufferRangeAPPLE = (PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFlushMappedBufferRangeAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_flush_buffer_range */ - -#ifdef GL_APPLE_object_purgeable - -static GLboolean _glewInit_GL_APPLE_object_purgeable (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetObjectParameterivAPPLE = (PFNGLGETOBJECTPARAMETERIVAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGetObjectParameterivAPPLE")) == NULL) || r; - r = ((glObjectPurgeableAPPLE = (PFNGLOBJECTPURGEABLEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glObjectPurgeableAPPLE")) == NULL) || r; - r = ((glObjectUnpurgeableAPPLE = (PFNGLOBJECTUNPURGEABLEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glObjectUnpurgeableAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_object_purgeable */ - -#ifdef GL_APPLE_pixel_buffer - -#endif /* GL_APPLE_pixel_buffer */ - -#ifdef GL_APPLE_rgb_422 - -#endif /* GL_APPLE_rgb_422 */ - -#ifdef GL_APPLE_row_bytes - -#endif /* GL_APPLE_row_bytes */ - -#ifdef GL_APPLE_specular_vector - -#endif /* GL_APPLE_specular_vector */ - -#ifdef GL_APPLE_texture_range - -static GLboolean _glewInit_GL_APPLE_texture_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetTexParameterPointervAPPLE = (PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterPointervAPPLE")) == NULL) || r; - r = ((glTextureRangeAPPLE = (PFNGLTEXTURERANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glTextureRangeAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_texture_range */ - -#ifdef GL_APPLE_transform_hint - -#endif /* GL_APPLE_transform_hint */ - -#ifdef GL_APPLE_vertex_array_object - -static GLboolean _glewInit_GL_APPLE_vertex_array_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindVertexArrayAPPLE = (PFNGLBINDVERTEXARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glBindVertexArrayAPPLE")) == NULL) || r; - r = ((glDeleteVertexArraysAPPLE = (PFNGLDELETEVERTEXARRAYSAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDeleteVertexArraysAPPLE")) == NULL) || r; - r = ((glGenVertexArraysAPPLE = (PFNGLGENVERTEXARRAYSAPPLEPROC)glewGetProcAddress((const GLubyte*)"glGenVertexArraysAPPLE")) == NULL) || r; - r = ((glIsVertexArrayAPPLE = (PFNGLISVERTEXARRAYAPPLEPROC)glewGetProcAddress((const GLubyte*)"glIsVertexArrayAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_vertex_array_object */ - -#ifdef GL_APPLE_vertex_array_range - -static GLboolean _glewInit_GL_APPLE_vertex_array_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFlushVertexArrayRangeAPPLE = (PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glFlushVertexArrayRangeAPPLE")) == NULL) || r; - r = ((glVertexArrayParameteriAPPLE = (PFNGLVERTEXARRAYPARAMETERIAPPLEPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayParameteriAPPLE")) == NULL) || r; - r = ((glVertexArrayRangeAPPLE = (PFNGLVERTEXARRAYRANGEAPPLEPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayRangeAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_vertex_array_range */ - -#ifdef GL_APPLE_vertex_program_evaluators - -static GLboolean _glewInit_GL_APPLE_vertex_program_evaluators (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDisableVertexAttribAPPLE = (PFNGLDISABLEVERTEXATTRIBAPPLEPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexAttribAPPLE")) == NULL) || r; - r = ((glEnableVertexAttribAPPLE = (PFNGLENABLEVERTEXATTRIBAPPLEPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexAttribAPPLE")) == NULL) || r; - r = ((glIsVertexAttribEnabledAPPLE = (PFNGLISVERTEXATTRIBENABLEDAPPLEPROC)glewGetProcAddress((const GLubyte*)"glIsVertexAttribEnabledAPPLE")) == NULL) || r; - r = ((glMapVertexAttrib1dAPPLE = (PFNGLMAPVERTEXATTRIB1DAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib1dAPPLE")) == NULL) || r; - r = ((glMapVertexAttrib1fAPPLE = (PFNGLMAPVERTEXATTRIB1FAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib1fAPPLE")) == NULL) || r; - r = ((glMapVertexAttrib2dAPPLE = (PFNGLMAPVERTEXATTRIB2DAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib2dAPPLE")) == NULL) || r; - r = ((glMapVertexAttrib2fAPPLE = (PFNGLMAPVERTEXATTRIB2FAPPLEPROC)glewGetProcAddress((const GLubyte*)"glMapVertexAttrib2fAPPLE")) == NULL) || r; - - return r; -} - -#endif /* GL_APPLE_vertex_program_evaluators */ - -#ifdef GL_APPLE_ycbcr_422 - -#endif /* GL_APPLE_ycbcr_422 */ - -#ifdef GL_ARB_ES2_compatibility - -static GLboolean _glewInit_GL_ARB_ES2_compatibility (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClearDepthf = (PFNGLCLEARDEPTHFPROC)glewGetProcAddress((const GLubyte*)"glClearDepthf")) == NULL) || r; - r = ((glDepthRangef = (PFNGLDEPTHRANGEFPROC)glewGetProcAddress((const GLubyte*)"glDepthRangef")) == NULL) || r; - r = ((glGetShaderPrecisionFormat = (PFNGLGETSHADERPRECISIONFORMATPROC)glewGetProcAddress((const GLubyte*)"glGetShaderPrecisionFormat")) == NULL) || r; - r = ((glReleaseShaderCompiler = (PFNGLRELEASESHADERCOMPILERPROC)glewGetProcAddress((const GLubyte*)"glReleaseShaderCompiler")) == NULL) || r; - r = ((glShaderBinary = (PFNGLSHADERBINARYPROC)glewGetProcAddress((const GLubyte*)"glShaderBinary")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_ES2_compatibility */ - -#ifdef GL_ARB_ES3_compatibility - -#endif /* GL_ARB_ES3_compatibility */ - -#ifdef GL_ARB_arrays_of_arrays - -#endif /* GL_ARB_arrays_of_arrays */ - -#ifdef GL_ARB_base_instance - -static GLboolean _glewInit_GL_ARB_base_instance (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawArraysInstancedBaseInstance = (PFNGLDRAWARRAYSINSTANCEDBASEINSTANCEPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstancedBaseInstance")) == NULL) || r; - r = ((glDrawElementsInstancedBaseInstance = (PFNGLDRAWELEMENTSINSTANCEDBASEINSTANCEPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedBaseInstance")) == NULL) || r; - r = ((glDrawElementsInstancedBaseVertexBaseInstance = (PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXBASEINSTANCEPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedBaseVertexBaseInstance")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_base_instance */ - -#ifdef GL_ARB_bindless_texture - -static GLboolean _glewInit_GL_ARB_bindless_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetImageHandleARB = (PFNGLGETIMAGEHANDLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetImageHandleARB")) == NULL) || r; - r = ((glGetTextureHandleARB = (PFNGLGETTEXTUREHANDLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetTextureHandleARB")) == NULL) || r; - r = ((glGetTextureSamplerHandleARB = (PFNGLGETTEXTURESAMPLERHANDLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetTextureSamplerHandleARB")) == NULL) || r; - r = ((glGetVertexAttribLui64vARB = (PFNGLGETVERTEXATTRIBLUI64VARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLui64vARB")) == NULL) || r; - r = ((glIsImageHandleResidentARB = (PFNGLISIMAGEHANDLERESIDENTARBPROC)glewGetProcAddress((const GLubyte*)"glIsImageHandleResidentARB")) == NULL) || r; - r = ((glIsTextureHandleResidentARB = (PFNGLISTEXTUREHANDLERESIDENTARBPROC)glewGetProcAddress((const GLubyte*)"glIsTextureHandleResidentARB")) == NULL) || r; - r = ((glMakeImageHandleNonResidentARB = (PFNGLMAKEIMAGEHANDLENONRESIDENTARBPROC)glewGetProcAddress((const GLubyte*)"glMakeImageHandleNonResidentARB")) == NULL) || r; - r = ((glMakeImageHandleResidentARB = (PFNGLMAKEIMAGEHANDLERESIDENTARBPROC)glewGetProcAddress((const GLubyte*)"glMakeImageHandleResidentARB")) == NULL) || r; - r = ((glMakeTextureHandleNonResidentARB = (PFNGLMAKETEXTUREHANDLENONRESIDENTARBPROC)glewGetProcAddress((const GLubyte*)"glMakeTextureHandleNonResidentARB")) == NULL) || r; - r = ((glMakeTextureHandleResidentARB = (PFNGLMAKETEXTUREHANDLERESIDENTARBPROC)glewGetProcAddress((const GLubyte*)"glMakeTextureHandleResidentARB")) == NULL) || r; - r = ((glProgramUniformHandleui64ARB = (PFNGLPROGRAMUNIFORMHANDLEUI64ARBPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformHandleui64ARB")) == NULL) || r; - r = ((glProgramUniformHandleui64vARB = (PFNGLPROGRAMUNIFORMHANDLEUI64VARBPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformHandleui64vARB")) == NULL) || r; - r = ((glUniformHandleui64ARB = (PFNGLUNIFORMHANDLEUI64ARBPROC)glewGetProcAddress((const GLubyte*)"glUniformHandleui64ARB")) == NULL) || r; - r = ((glUniformHandleui64vARB = (PFNGLUNIFORMHANDLEUI64VARBPROC)glewGetProcAddress((const GLubyte*)"glUniformHandleui64vARB")) == NULL) || r; - r = ((glVertexAttribL1ui64ARB = (PFNGLVERTEXATTRIBL1UI64ARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1ui64ARB")) == NULL) || r; - r = ((glVertexAttribL1ui64vARB = (PFNGLVERTEXATTRIBL1UI64VARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1ui64vARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_bindless_texture */ - -#ifdef GL_ARB_blend_func_extended - -static GLboolean _glewInit_GL_ARB_blend_func_extended (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindFragDataLocationIndexed = (PFNGLBINDFRAGDATALOCATIONINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glBindFragDataLocationIndexed")) == NULL) || r; - r = ((glGetFragDataIndex = (PFNGLGETFRAGDATAINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetFragDataIndex")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_blend_func_extended */ - -#ifdef GL_ARB_buffer_storage - -static GLboolean _glewInit_GL_ARB_buffer_storage (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBufferStorage = (PFNGLBUFFERSTORAGEPROC)glewGetProcAddress((const GLubyte*)"glBufferStorage")) == NULL) || r; - r = ((glNamedBufferStorageEXT = (PFNGLNAMEDBUFFERSTORAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedBufferStorageEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_buffer_storage */ - -#ifdef GL_ARB_cl_event - -static GLboolean _glewInit_GL_ARB_cl_event (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCreateSyncFromCLeventARB = (PFNGLCREATESYNCFROMCLEVENTARBPROC)glewGetProcAddress((const GLubyte*)"glCreateSyncFromCLeventARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_cl_event */ - -#ifdef GL_ARB_clear_buffer_object - -static GLboolean _glewInit_GL_ARB_clear_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClearBufferData = (PFNGLCLEARBUFFERDATAPROC)glewGetProcAddress((const GLubyte*)"glClearBufferData")) == NULL) || r; - r = ((glClearBufferSubData = (PFNGLCLEARBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glClearBufferSubData")) == NULL) || r; - r = ((glClearNamedBufferDataEXT = (PFNGLCLEARNAMEDBUFFERDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glClearNamedBufferDataEXT")) == NULL) || r; - r = ((glClearNamedBufferSubDataEXT = (PFNGLCLEARNAMEDBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glClearNamedBufferSubDataEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_clear_buffer_object */ - -#ifdef GL_ARB_clear_texture - -static GLboolean _glewInit_GL_ARB_clear_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClearTexImage = (PFNGLCLEARTEXIMAGEPROC)glewGetProcAddress((const GLubyte*)"glClearTexImage")) == NULL) || r; - r = ((glClearTexSubImage = (PFNGLCLEARTEXSUBIMAGEPROC)glewGetProcAddress((const GLubyte*)"glClearTexSubImage")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_clear_texture */ - -#ifdef GL_ARB_color_buffer_float - -static GLboolean _glewInit_GL_ARB_color_buffer_float (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClampColorARB = (PFNGLCLAMPCOLORARBPROC)glewGetProcAddress((const GLubyte*)"glClampColorARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_color_buffer_float */ - -#ifdef GL_ARB_compatibility - -#endif /* GL_ARB_compatibility */ - -#ifdef GL_ARB_compressed_texture_pixel_storage - -#endif /* GL_ARB_compressed_texture_pixel_storage */ - -#ifdef GL_ARB_compute_shader - -static GLboolean _glewInit_GL_ARB_compute_shader (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDispatchCompute = (PFNGLDISPATCHCOMPUTEPROC)glewGetProcAddress((const GLubyte*)"glDispatchCompute")) == NULL) || r; - r = ((glDispatchComputeIndirect = (PFNGLDISPATCHCOMPUTEINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glDispatchComputeIndirect")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_compute_shader */ - -#ifdef GL_ARB_compute_variable_group_size - -static GLboolean _glewInit_GL_ARB_compute_variable_group_size (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDispatchComputeGroupSizeARB = (PFNGLDISPATCHCOMPUTEGROUPSIZEARBPROC)glewGetProcAddress((const GLubyte*)"glDispatchComputeGroupSizeARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_compute_variable_group_size */ - -#ifdef GL_ARB_conservative_depth - -#endif /* GL_ARB_conservative_depth */ - -#ifdef GL_ARB_copy_buffer - -static GLboolean _glewInit_GL_ARB_copy_buffer (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCopyBufferSubData = (PFNGLCOPYBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glCopyBufferSubData")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_copy_buffer */ - -#ifdef GL_ARB_copy_image - -static GLboolean _glewInit_GL_ARB_copy_image (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCopyImageSubData = (PFNGLCOPYIMAGESUBDATAPROC)glewGetProcAddress((const GLubyte*)"glCopyImageSubData")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_copy_image */ - -#ifdef GL_ARB_debug_output - -static GLboolean _glewInit_GL_ARB_debug_output (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDebugMessageCallbackARB = (PFNGLDEBUGMESSAGECALLBACKARBPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageCallbackARB")) == NULL) || r; - r = ((glDebugMessageControlARB = (PFNGLDEBUGMESSAGECONTROLARBPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageControlARB")) == NULL) || r; - r = ((glDebugMessageInsertARB = (PFNGLDEBUGMESSAGEINSERTARBPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageInsertARB")) == NULL) || r; - r = ((glGetDebugMessageLogARB = (PFNGLGETDEBUGMESSAGELOGARBPROC)glewGetProcAddress((const GLubyte*)"glGetDebugMessageLogARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_debug_output */ - -#ifdef GL_ARB_depth_buffer_float - -#endif /* GL_ARB_depth_buffer_float */ - -#ifdef GL_ARB_depth_clamp - -#endif /* GL_ARB_depth_clamp */ - -#ifdef GL_ARB_depth_texture - -#endif /* GL_ARB_depth_texture */ - -#ifdef GL_ARB_draw_buffers - -static GLboolean _glewInit_GL_ARB_draw_buffers (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawBuffersARB = (PFNGLDRAWBUFFERSARBPROC)glewGetProcAddress((const GLubyte*)"glDrawBuffersARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_draw_buffers */ - -#ifdef GL_ARB_draw_buffers_blend - -static GLboolean _glewInit_GL_ARB_draw_buffers_blend (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendEquationSeparateiARB = (PFNGLBLENDEQUATIONSEPARATEIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparateiARB")) == NULL) || r; - r = ((glBlendEquationiARB = (PFNGLBLENDEQUATIONIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationiARB")) == NULL) || r; - r = ((glBlendFuncSeparateiARB = (PFNGLBLENDFUNCSEPARATEIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparateiARB")) == NULL) || r; - r = ((glBlendFunciARB = (PFNGLBLENDFUNCIARBPROC)glewGetProcAddress((const GLubyte*)"glBlendFunciARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_draw_buffers_blend */ - -#ifdef GL_ARB_draw_elements_base_vertex - -static GLboolean _glewInit_GL_ARB_draw_elements_base_vertex (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawElementsBaseVertex = (PFNGLDRAWELEMENTSBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsBaseVertex")) == NULL) || r; - r = ((glDrawElementsInstancedBaseVertex = (PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedBaseVertex")) == NULL) || r; - r = ((glDrawRangeElementsBaseVertex = (PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementsBaseVertex")) == NULL) || r; - r = ((glMultiDrawElementsBaseVertex = (PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsBaseVertex")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_draw_elements_base_vertex */ - -#ifdef GL_ARB_draw_indirect - -static GLboolean _glewInit_GL_ARB_draw_indirect (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawArraysIndirect = (PFNGLDRAWARRAYSINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysIndirect")) == NULL) || r; - r = ((glDrawElementsIndirect = (PFNGLDRAWELEMENTSINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsIndirect")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_draw_indirect */ - -#ifdef GL_ARB_draw_instanced - -#endif /* GL_ARB_draw_instanced */ - -#ifdef GL_ARB_enhanced_layouts - -#endif /* GL_ARB_enhanced_layouts */ - -#ifdef GL_ARB_explicit_attrib_location - -#endif /* GL_ARB_explicit_attrib_location */ - -#ifdef GL_ARB_explicit_uniform_location - -#endif /* GL_ARB_explicit_uniform_location */ - -#ifdef GL_ARB_fragment_coord_conventions - -#endif /* GL_ARB_fragment_coord_conventions */ - -#ifdef GL_ARB_fragment_layer_viewport - -#endif /* GL_ARB_fragment_layer_viewport */ - -#ifdef GL_ARB_fragment_program - -#endif /* GL_ARB_fragment_program */ - -#ifdef GL_ARB_fragment_program_shadow - -#endif /* GL_ARB_fragment_program_shadow */ - -#ifdef GL_ARB_fragment_shader - -#endif /* GL_ARB_fragment_shader */ - -#ifdef GL_ARB_framebuffer_no_attachments - -static GLboolean _glewInit_GL_ARB_framebuffer_no_attachments (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFramebufferParameteri = (PFNGLFRAMEBUFFERPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glFramebufferParameteri")) == NULL) || r; - r = ((glGetFramebufferParameteriv = (PFNGLGETFRAMEBUFFERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferParameteriv")) == NULL) || r; - r = ((glGetNamedFramebufferParameterivEXT = (PFNGLGETNAMEDFRAMEBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedFramebufferParameterivEXT")) == NULL) || r; - r = ((glNamedFramebufferParameteriEXT = (PFNGLNAMEDFRAMEBUFFERPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferParameteriEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_framebuffer_no_attachments */ - -#ifdef GL_ARB_framebuffer_object - -static GLboolean _glewInit_GL_ARB_framebuffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindFramebuffer = (PFNGLBINDFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindFramebuffer")) == NULL) || r; - r = ((glBindRenderbuffer = (PFNGLBINDRENDERBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindRenderbuffer")) == NULL) || r; - r = ((glBlitFramebuffer = (PFNGLBLITFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBlitFramebuffer")) == NULL) || r; - r = ((glCheckFramebufferStatus = (PFNGLCHECKFRAMEBUFFERSTATUSPROC)glewGetProcAddress((const GLubyte*)"glCheckFramebufferStatus")) == NULL) || r; - r = ((glDeleteFramebuffers = (PFNGLDELETEFRAMEBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteFramebuffers")) == NULL) || r; - r = ((glDeleteRenderbuffers = (PFNGLDELETERENDERBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteRenderbuffers")) == NULL) || r; - r = ((glFramebufferRenderbuffer = (PFNGLFRAMEBUFFERRENDERBUFFERPROC)glewGetProcAddress((const GLubyte*)"glFramebufferRenderbuffer")) == NULL) || r; - r = ((glFramebufferTexture1D = (PFNGLFRAMEBUFFERTEXTURE1DPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture1D")) == NULL) || r; - r = ((glFramebufferTexture2D = (PFNGLFRAMEBUFFERTEXTURE2DPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture2D")) == NULL) || r; - r = ((glFramebufferTexture3D = (PFNGLFRAMEBUFFERTEXTURE3DPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture3D")) == NULL) || r; - r = ((glFramebufferTextureLayer = (PFNGLFRAMEBUFFERTEXTURELAYERPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureLayer")) == NULL) || r; - r = ((glGenFramebuffers = (PFNGLGENFRAMEBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glGenFramebuffers")) == NULL) || r; - r = ((glGenRenderbuffers = (PFNGLGENRENDERBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glGenRenderbuffers")) == NULL) || r; - r = ((glGenerateMipmap = (PFNGLGENERATEMIPMAPPROC)glewGetProcAddress((const GLubyte*)"glGenerateMipmap")) == NULL) || r; - r = ((glGetFramebufferAttachmentParameteriv = (PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferAttachmentParameteriv")) == NULL) || r; - r = ((glGetRenderbufferParameteriv = (PFNGLGETRENDERBUFFERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetRenderbufferParameteriv")) == NULL) || r; - r = ((glIsFramebuffer = (PFNGLISFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glIsFramebuffer")) == NULL) || r; - r = ((glIsRenderbuffer = (PFNGLISRENDERBUFFERPROC)glewGetProcAddress((const GLubyte*)"glIsRenderbuffer")) == NULL) || r; - r = ((glRenderbufferStorage = (PFNGLRENDERBUFFERSTORAGEPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorage")) == NULL) || r; - r = ((glRenderbufferStorageMultisample = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisample")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_framebuffer_object */ - -#ifdef GL_ARB_framebuffer_sRGB - -#endif /* GL_ARB_framebuffer_sRGB */ - -#ifdef GL_ARB_geometry_shader4 - -static GLboolean _glewInit_GL_ARB_geometry_shader4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFramebufferTextureARB = (PFNGLFRAMEBUFFERTEXTUREARBPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureARB")) == NULL) || r; - r = ((glFramebufferTextureFaceARB = (PFNGLFRAMEBUFFERTEXTUREFACEARBPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureFaceARB")) == NULL) || r; - r = ((glFramebufferTextureLayerARB = (PFNGLFRAMEBUFFERTEXTURELAYERARBPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureLayerARB")) == NULL) || r; - r = ((glProgramParameteriARB = (PFNGLPROGRAMPARAMETERIARBPROC)glewGetProcAddress((const GLubyte*)"glProgramParameteriARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_geometry_shader4 */ - -#ifdef GL_ARB_get_program_binary - -static GLboolean _glewInit_GL_ARB_get_program_binary (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetProgramBinary = (PFNGLGETPROGRAMBINARYPROC)glewGetProcAddress((const GLubyte*)"glGetProgramBinary")) == NULL) || r; - r = ((glProgramBinary = (PFNGLPROGRAMBINARYPROC)glewGetProcAddress((const GLubyte*)"glProgramBinary")) == NULL) || r; - r = ((glProgramParameteri = (PFNGLPROGRAMPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glProgramParameteri")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_get_program_binary */ - -#ifdef GL_ARB_gpu_shader5 - -#endif /* GL_ARB_gpu_shader5 */ - -#ifdef GL_ARB_gpu_shader_fp64 - -static GLboolean _glewInit_GL_ARB_gpu_shader_fp64 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetUniformdv = (PFNGLGETUNIFORMDVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformdv")) == NULL) || r; - r = ((glUniform1d = (PFNGLUNIFORM1DPROC)glewGetProcAddress((const GLubyte*)"glUniform1d")) == NULL) || r; - r = ((glUniform1dv = (PFNGLUNIFORM1DVPROC)glewGetProcAddress((const GLubyte*)"glUniform1dv")) == NULL) || r; - r = ((glUniform2d = (PFNGLUNIFORM2DPROC)glewGetProcAddress((const GLubyte*)"glUniform2d")) == NULL) || r; - r = ((glUniform2dv = (PFNGLUNIFORM2DVPROC)glewGetProcAddress((const GLubyte*)"glUniform2dv")) == NULL) || r; - r = ((glUniform3d = (PFNGLUNIFORM3DPROC)glewGetProcAddress((const GLubyte*)"glUniform3d")) == NULL) || r; - r = ((glUniform3dv = (PFNGLUNIFORM3DVPROC)glewGetProcAddress((const GLubyte*)"glUniform3dv")) == NULL) || r; - r = ((glUniform4d = (PFNGLUNIFORM4DPROC)glewGetProcAddress((const GLubyte*)"glUniform4d")) == NULL) || r; - r = ((glUniform4dv = (PFNGLUNIFORM4DVPROC)glewGetProcAddress((const GLubyte*)"glUniform4dv")) == NULL) || r; - r = ((glUniformMatrix2dv = (PFNGLUNIFORMMATRIX2DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2dv")) == NULL) || r; - r = ((glUniformMatrix2x3dv = (PFNGLUNIFORMMATRIX2X3DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2x3dv")) == NULL) || r; - r = ((glUniformMatrix2x4dv = (PFNGLUNIFORMMATRIX2X4DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2x4dv")) == NULL) || r; - r = ((glUniformMatrix3dv = (PFNGLUNIFORMMATRIX3DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3dv")) == NULL) || r; - r = ((glUniformMatrix3x2dv = (PFNGLUNIFORMMATRIX3X2DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3x2dv")) == NULL) || r; - r = ((glUniformMatrix3x4dv = (PFNGLUNIFORMMATRIX3X4DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3x4dv")) == NULL) || r; - r = ((glUniformMatrix4dv = (PFNGLUNIFORMMATRIX4DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4dv")) == NULL) || r; - r = ((glUniformMatrix4x2dv = (PFNGLUNIFORMMATRIX4X2DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4x2dv")) == NULL) || r; - r = ((glUniformMatrix4x3dv = (PFNGLUNIFORMMATRIX4X3DVPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4x3dv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_gpu_shader_fp64 */ - -#ifdef GL_ARB_half_float_pixel - -#endif /* GL_ARB_half_float_pixel */ - -#ifdef GL_ARB_half_float_vertex - -#endif /* GL_ARB_half_float_vertex */ - -#ifdef GL_ARB_imaging - -static GLboolean _glewInit_GL_ARB_imaging (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendEquation = (PFNGLBLENDEQUATIONPROC)glewGetProcAddress((const GLubyte*)"glBlendEquation")) == NULL) || r; - r = ((glColorSubTable = (PFNGLCOLORSUBTABLEPROC)glewGetProcAddress((const GLubyte*)"glColorSubTable")) == NULL) || r; - r = ((glColorTable = (PFNGLCOLORTABLEPROC)glewGetProcAddress((const GLubyte*)"glColorTable")) == NULL) || r; - r = ((glColorTableParameterfv = (PFNGLCOLORTABLEPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameterfv")) == NULL) || r; - r = ((glColorTableParameteriv = (PFNGLCOLORTABLEPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameteriv")) == NULL) || r; - r = ((glConvolutionFilter1D = (PFNGLCONVOLUTIONFILTER1DPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter1D")) == NULL) || r; - r = ((glConvolutionFilter2D = (PFNGLCONVOLUTIONFILTER2DPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter2D")) == NULL) || r; - r = ((glConvolutionParameterf = (PFNGLCONVOLUTIONPARAMETERFPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterf")) == NULL) || r; - r = ((glConvolutionParameterfv = (PFNGLCONVOLUTIONPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterfv")) == NULL) || r; - r = ((glConvolutionParameteri = (PFNGLCONVOLUTIONPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameteri")) == NULL) || r; - r = ((glConvolutionParameteriv = (PFNGLCONVOLUTIONPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameteriv")) == NULL) || r; - r = ((glCopyColorSubTable = (PFNGLCOPYCOLORSUBTABLEPROC)glewGetProcAddress((const GLubyte*)"glCopyColorSubTable")) == NULL) || r; - r = ((glCopyColorTable = (PFNGLCOPYCOLORTABLEPROC)glewGetProcAddress((const GLubyte*)"glCopyColorTable")) == NULL) || r; - r = ((glCopyConvolutionFilter1D = (PFNGLCOPYCONVOLUTIONFILTER1DPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter1D")) == NULL) || r; - r = ((glCopyConvolutionFilter2D = (PFNGLCOPYCONVOLUTIONFILTER2DPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter2D")) == NULL) || r; - r = ((glGetColorTable = (PFNGLGETCOLORTABLEPROC)glewGetProcAddress((const GLubyte*)"glGetColorTable")) == NULL) || r; - r = ((glGetColorTableParameterfv = (PFNGLGETCOLORTABLEPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterfv")) == NULL) || r; - r = ((glGetColorTableParameteriv = (PFNGLGETCOLORTABLEPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameteriv")) == NULL) || r; - r = ((glGetConvolutionFilter = (PFNGLGETCONVOLUTIONFILTERPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionFilter")) == NULL) || r; - r = ((glGetConvolutionParameterfv = (PFNGLGETCONVOLUTIONPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameterfv")) == NULL) || r; - r = ((glGetConvolutionParameteriv = (PFNGLGETCONVOLUTIONPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameteriv")) == NULL) || r; - r = ((glGetHistogram = (PFNGLGETHISTOGRAMPROC)glewGetProcAddress((const GLubyte*)"glGetHistogram")) == NULL) || r; - r = ((glGetHistogramParameterfv = (PFNGLGETHISTOGRAMPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameterfv")) == NULL) || r; - r = ((glGetHistogramParameteriv = (PFNGLGETHISTOGRAMPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameteriv")) == NULL) || r; - r = ((glGetMinmax = (PFNGLGETMINMAXPROC)glewGetProcAddress((const GLubyte*)"glGetMinmax")) == NULL) || r; - r = ((glGetMinmaxParameterfv = (PFNGLGETMINMAXPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameterfv")) == NULL) || r; - r = ((glGetMinmaxParameteriv = (PFNGLGETMINMAXPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameteriv")) == NULL) || r; - r = ((glGetSeparableFilter = (PFNGLGETSEPARABLEFILTERPROC)glewGetProcAddress((const GLubyte*)"glGetSeparableFilter")) == NULL) || r; - r = ((glHistogram = (PFNGLHISTOGRAMPROC)glewGetProcAddress((const GLubyte*)"glHistogram")) == NULL) || r; - r = ((glMinmax = (PFNGLMINMAXPROC)glewGetProcAddress((const GLubyte*)"glMinmax")) == NULL) || r; - r = ((glResetHistogram = (PFNGLRESETHISTOGRAMPROC)glewGetProcAddress((const GLubyte*)"glResetHistogram")) == NULL) || r; - r = ((glResetMinmax = (PFNGLRESETMINMAXPROC)glewGetProcAddress((const GLubyte*)"glResetMinmax")) == NULL) || r; - r = ((glSeparableFilter2D = (PFNGLSEPARABLEFILTER2DPROC)glewGetProcAddress((const GLubyte*)"glSeparableFilter2D")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_imaging */ - -#ifdef GL_ARB_indirect_parameters - -static GLboolean _glewInit_GL_ARB_indirect_parameters (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMultiDrawArraysIndirectCountARB = (PFNGLMULTIDRAWARRAYSINDIRECTCOUNTARBPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArraysIndirectCountARB")) == NULL) || r; - r = ((glMultiDrawElementsIndirectCountARB = (PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTARBPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsIndirectCountARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_indirect_parameters */ - -#ifdef GL_ARB_instanced_arrays - -static GLboolean _glewInit_GL_ARB_instanced_arrays (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawArraysInstancedARB = (PFNGLDRAWARRAYSINSTANCEDARBPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstancedARB")) == NULL) || r; - r = ((glDrawElementsInstancedARB = (PFNGLDRAWELEMENTSINSTANCEDARBPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedARB")) == NULL) || r; - r = ((glVertexAttribDivisorARB = (PFNGLVERTEXATTRIBDIVISORARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribDivisorARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_instanced_arrays */ - -#ifdef GL_ARB_internalformat_query - -static GLboolean _glewInit_GL_ARB_internalformat_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetInternalformativ = (PFNGLGETINTERNALFORMATIVPROC)glewGetProcAddress((const GLubyte*)"glGetInternalformativ")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_internalformat_query */ - -#ifdef GL_ARB_internalformat_query2 - -static GLboolean _glewInit_GL_ARB_internalformat_query2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetInternalformati64v = (PFNGLGETINTERNALFORMATI64VPROC)glewGetProcAddress((const GLubyte*)"glGetInternalformati64v")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_internalformat_query2 */ - -#ifdef GL_ARB_invalidate_subdata - -static GLboolean _glewInit_GL_ARB_invalidate_subdata (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glInvalidateBufferData = (PFNGLINVALIDATEBUFFERDATAPROC)glewGetProcAddress((const GLubyte*)"glInvalidateBufferData")) == NULL) || r; - r = ((glInvalidateBufferSubData = (PFNGLINVALIDATEBUFFERSUBDATAPROC)glewGetProcAddress((const GLubyte*)"glInvalidateBufferSubData")) == NULL) || r; - r = ((glInvalidateFramebuffer = (PFNGLINVALIDATEFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glInvalidateFramebuffer")) == NULL) || r; - r = ((glInvalidateSubFramebuffer = (PFNGLINVALIDATESUBFRAMEBUFFERPROC)glewGetProcAddress((const GLubyte*)"glInvalidateSubFramebuffer")) == NULL) || r; - r = ((glInvalidateTexImage = (PFNGLINVALIDATETEXIMAGEPROC)glewGetProcAddress((const GLubyte*)"glInvalidateTexImage")) == NULL) || r; - r = ((glInvalidateTexSubImage = (PFNGLINVALIDATETEXSUBIMAGEPROC)glewGetProcAddress((const GLubyte*)"glInvalidateTexSubImage")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_invalidate_subdata */ - -#ifdef GL_ARB_map_buffer_alignment - -#endif /* GL_ARB_map_buffer_alignment */ - -#ifdef GL_ARB_map_buffer_range - -static GLboolean _glewInit_GL_ARB_map_buffer_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFlushMappedBufferRange = (PFNGLFLUSHMAPPEDBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glFlushMappedBufferRange")) == NULL) || r; - r = ((glMapBufferRange = (PFNGLMAPBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glMapBufferRange")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_map_buffer_range */ - -#ifdef GL_ARB_matrix_palette - -static GLboolean _glewInit_GL_ARB_matrix_palette (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCurrentPaletteMatrixARB = (PFNGLCURRENTPALETTEMATRIXARBPROC)glewGetProcAddress((const GLubyte*)"glCurrentPaletteMatrixARB")) == NULL) || r; - r = ((glMatrixIndexPointerARB = (PFNGLMATRIXINDEXPOINTERARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexPointerARB")) == NULL) || r; - r = ((glMatrixIndexubvARB = (PFNGLMATRIXINDEXUBVARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexubvARB")) == NULL) || r; - r = ((glMatrixIndexuivARB = (PFNGLMATRIXINDEXUIVARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexuivARB")) == NULL) || r; - r = ((glMatrixIndexusvARB = (PFNGLMATRIXINDEXUSVARBPROC)glewGetProcAddress((const GLubyte*)"glMatrixIndexusvARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_matrix_palette */ - -#ifdef GL_ARB_multi_bind - -static GLboolean _glewInit_GL_ARB_multi_bind (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindBuffersBase = (PFNGLBINDBUFFERSBASEPROC)glewGetProcAddress((const GLubyte*)"glBindBuffersBase")) == NULL) || r; - r = ((glBindBuffersRange = (PFNGLBINDBUFFERSRANGEPROC)glewGetProcAddress((const GLubyte*)"glBindBuffersRange")) == NULL) || r; - r = ((glBindImageTextures = (PFNGLBINDIMAGETEXTURESPROC)glewGetProcAddress((const GLubyte*)"glBindImageTextures")) == NULL) || r; - r = ((glBindSamplers = (PFNGLBINDSAMPLERSPROC)glewGetProcAddress((const GLubyte*)"glBindSamplers")) == NULL) || r; - r = ((glBindTextures = (PFNGLBINDTEXTURESPROC)glewGetProcAddress((const GLubyte*)"glBindTextures")) == NULL) || r; - r = ((glBindVertexBuffers = (PFNGLBINDVERTEXBUFFERSPROC)glewGetProcAddress((const GLubyte*)"glBindVertexBuffers")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_multi_bind */ - -#ifdef GL_ARB_multi_draw_indirect - -static GLboolean _glewInit_GL_ARB_multi_draw_indirect (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMultiDrawArraysIndirect = (PFNGLMULTIDRAWARRAYSINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArraysIndirect")) == NULL) || r; - r = ((glMultiDrawElementsIndirect = (PFNGLMULTIDRAWELEMENTSINDIRECTPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsIndirect")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_multi_draw_indirect */ - -#ifdef GL_ARB_multisample - -static GLboolean _glewInit_GL_ARB_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glSampleCoverageARB = (PFNGLSAMPLECOVERAGEARBPROC)glewGetProcAddress((const GLubyte*)"glSampleCoverageARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_multisample */ - -#ifdef GL_ARB_multitexture - -static GLboolean _glewInit_GL_ARB_multitexture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glActiveTextureARB = (PFNGLACTIVETEXTUREARBPROC)glewGetProcAddress((const GLubyte*)"glActiveTextureARB")) == NULL) || r; - r = ((glClientActiveTextureARB = (PFNGLCLIENTACTIVETEXTUREARBPROC)glewGetProcAddress((const GLubyte*)"glClientActiveTextureARB")) == NULL) || r; - r = ((glMultiTexCoord1dARB = (PFNGLMULTITEXCOORD1DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1dARB")) == NULL) || r; - r = ((glMultiTexCoord1dvARB = (PFNGLMULTITEXCOORD1DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1dvARB")) == NULL) || r; - r = ((glMultiTexCoord1fARB = (PFNGLMULTITEXCOORD1FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1fARB")) == NULL) || r; - r = ((glMultiTexCoord1fvARB = (PFNGLMULTITEXCOORD1FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1fvARB")) == NULL) || r; - r = ((glMultiTexCoord1iARB = (PFNGLMULTITEXCOORD1IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1iARB")) == NULL) || r; - r = ((glMultiTexCoord1ivARB = (PFNGLMULTITEXCOORD1IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1ivARB")) == NULL) || r; - r = ((glMultiTexCoord1sARB = (PFNGLMULTITEXCOORD1SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1sARB")) == NULL) || r; - r = ((glMultiTexCoord1svARB = (PFNGLMULTITEXCOORD1SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1svARB")) == NULL) || r; - r = ((glMultiTexCoord2dARB = (PFNGLMULTITEXCOORD2DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2dARB")) == NULL) || r; - r = ((glMultiTexCoord2dvARB = (PFNGLMULTITEXCOORD2DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2dvARB")) == NULL) || r; - r = ((glMultiTexCoord2fARB = (PFNGLMULTITEXCOORD2FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2fARB")) == NULL) || r; - r = ((glMultiTexCoord2fvARB = (PFNGLMULTITEXCOORD2FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2fvARB")) == NULL) || r; - r = ((glMultiTexCoord2iARB = (PFNGLMULTITEXCOORD2IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2iARB")) == NULL) || r; - r = ((glMultiTexCoord2ivARB = (PFNGLMULTITEXCOORD2IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2ivARB")) == NULL) || r; - r = ((glMultiTexCoord2sARB = (PFNGLMULTITEXCOORD2SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2sARB")) == NULL) || r; - r = ((glMultiTexCoord2svARB = (PFNGLMULTITEXCOORD2SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2svARB")) == NULL) || r; - r = ((glMultiTexCoord3dARB = (PFNGLMULTITEXCOORD3DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3dARB")) == NULL) || r; - r = ((glMultiTexCoord3dvARB = (PFNGLMULTITEXCOORD3DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3dvARB")) == NULL) || r; - r = ((glMultiTexCoord3fARB = (PFNGLMULTITEXCOORD3FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3fARB")) == NULL) || r; - r = ((glMultiTexCoord3fvARB = (PFNGLMULTITEXCOORD3FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3fvARB")) == NULL) || r; - r = ((glMultiTexCoord3iARB = (PFNGLMULTITEXCOORD3IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3iARB")) == NULL) || r; - r = ((glMultiTexCoord3ivARB = (PFNGLMULTITEXCOORD3IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3ivARB")) == NULL) || r; - r = ((glMultiTexCoord3sARB = (PFNGLMULTITEXCOORD3SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3sARB")) == NULL) || r; - r = ((glMultiTexCoord3svARB = (PFNGLMULTITEXCOORD3SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3svARB")) == NULL) || r; - r = ((glMultiTexCoord4dARB = (PFNGLMULTITEXCOORD4DARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4dARB")) == NULL) || r; - r = ((glMultiTexCoord4dvARB = (PFNGLMULTITEXCOORD4DVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4dvARB")) == NULL) || r; - r = ((glMultiTexCoord4fARB = (PFNGLMULTITEXCOORD4FARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4fARB")) == NULL) || r; - r = ((glMultiTexCoord4fvARB = (PFNGLMULTITEXCOORD4FVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4fvARB")) == NULL) || r; - r = ((glMultiTexCoord4iARB = (PFNGLMULTITEXCOORD4IARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4iARB")) == NULL) || r; - r = ((glMultiTexCoord4ivARB = (PFNGLMULTITEXCOORD4IVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4ivARB")) == NULL) || r; - r = ((glMultiTexCoord4sARB = (PFNGLMULTITEXCOORD4SARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4sARB")) == NULL) || r; - r = ((glMultiTexCoord4svARB = (PFNGLMULTITEXCOORD4SVARBPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4svARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_multitexture */ - -#ifdef GL_ARB_occlusion_query - -static GLboolean _glewInit_GL_ARB_occlusion_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginQueryARB = (PFNGLBEGINQUERYARBPROC)glewGetProcAddress((const GLubyte*)"glBeginQueryARB")) == NULL) || r; - r = ((glDeleteQueriesARB = (PFNGLDELETEQUERIESARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteQueriesARB")) == NULL) || r; - r = ((glEndQueryARB = (PFNGLENDQUERYARBPROC)glewGetProcAddress((const GLubyte*)"glEndQueryARB")) == NULL) || r; - r = ((glGenQueriesARB = (PFNGLGENQUERIESARBPROC)glewGetProcAddress((const GLubyte*)"glGenQueriesARB")) == NULL) || r; - r = ((glGetQueryObjectivARB = (PFNGLGETQUERYOBJECTIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectivARB")) == NULL) || r; - r = ((glGetQueryObjectuivARB = (PFNGLGETQUERYOBJECTUIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectuivARB")) == NULL) || r; - r = ((glGetQueryivARB = (PFNGLGETQUERYIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetQueryivARB")) == NULL) || r; - r = ((glIsQueryARB = (PFNGLISQUERYARBPROC)glewGetProcAddress((const GLubyte*)"glIsQueryARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_occlusion_query */ - -#ifdef GL_ARB_occlusion_query2 - -#endif /* GL_ARB_occlusion_query2 */ - -#ifdef GL_ARB_pixel_buffer_object - -#endif /* GL_ARB_pixel_buffer_object */ - -#ifdef GL_ARB_point_parameters - -static GLboolean _glewInit_GL_ARB_point_parameters (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPointParameterfARB = (PFNGLPOINTPARAMETERFARBPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfARB")) == NULL) || r; - r = ((glPointParameterfvARB = (PFNGLPOINTPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfvARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_point_parameters */ - -#ifdef GL_ARB_point_sprite - -#endif /* GL_ARB_point_sprite */ - -#ifdef GL_ARB_program_interface_query - -static GLboolean _glewInit_GL_ARB_program_interface_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetProgramInterfaceiv = (PFNGLGETPROGRAMINTERFACEIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramInterfaceiv")) == NULL) || r; - r = ((glGetProgramResourceIndex = (PFNGLGETPROGRAMRESOURCEINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetProgramResourceIndex")) == NULL) || r; - r = ((glGetProgramResourceLocation = (PFNGLGETPROGRAMRESOURCELOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetProgramResourceLocation")) == NULL) || r; - r = ((glGetProgramResourceLocationIndex = (PFNGLGETPROGRAMRESOURCELOCATIONINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetProgramResourceLocationIndex")) == NULL) || r; - r = ((glGetProgramResourceName = (PFNGLGETPROGRAMRESOURCENAMEPROC)glewGetProcAddress((const GLubyte*)"glGetProgramResourceName")) == NULL) || r; - r = ((glGetProgramResourceiv = (PFNGLGETPROGRAMRESOURCEIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramResourceiv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_program_interface_query */ - -#ifdef GL_ARB_provoking_vertex - -static GLboolean _glewInit_GL_ARB_provoking_vertex (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glProvokingVertex = (PFNGLPROVOKINGVERTEXPROC)glewGetProcAddress((const GLubyte*)"glProvokingVertex")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_provoking_vertex */ - -#ifdef GL_ARB_query_buffer_object - -#endif /* GL_ARB_query_buffer_object */ - -#ifdef GL_ARB_robust_buffer_access_behavior - -#endif /* GL_ARB_robust_buffer_access_behavior */ - -#ifdef GL_ARB_robustness - -static GLboolean _glewInit_GL_ARB_robustness (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetGraphicsResetStatusARB = (PFNGLGETGRAPHICSRESETSTATUSARBPROC)glewGetProcAddress((const GLubyte*)"glGetGraphicsResetStatusARB")) == NULL) || r; - r = ((glGetnColorTableARB = (PFNGLGETNCOLORTABLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetnColorTableARB")) == NULL) || r; - r = ((glGetnCompressedTexImageARB = (PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"glGetnCompressedTexImageARB")) == NULL) || r; - r = ((glGetnConvolutionFilterARB = (PFNGLGETNCONVOLUTIONFILTERARBPROC)glewGetProcAddress((const GLubyte*)"glGetnConvolutionFilterARB")) == NULL) || r; - r = ((glGetnHistogramARB = (PFNGLGETNHISTOGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glGetnHistogramARB")) == NULL) || r; - r = ((glGetnMapdvARB = (PFNGLGETNMAPDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnMapdvARB")) == NULL) || r; - r = ((glGetnMapfvARB = (PFNGLGETNMAPFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnMapfvARB")) == NULL) || r; - r = ((glGetnMapivARB = (PFNGLGETNMAPIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnMapivARB")) == NULL) || r; - r = ((glGetnMinmaxARB = (PFNGLGETNMINMAXARBPROC)glewGetProcAddress((const GLubyte*)"glGetnMinmaxARB")) == NULL) || r; - r = ((glGetnPixelMapfvARB = (PFNGLGETNPIXELMAPFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnPixelMapfvARB")) == NULL) || r; - r = ((glGetnPixelMapuivARB = (PFNGLGETNPIXELMAPUIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnPixelMapuivARB")) == NULL) || r; - r = ((glGetnPixelMapusvARB = (PFNGLGETNPIXELMAPUSVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnPixelMapusvARB")) == NULL) || r; - r = ((glGetnPolygonStippleARB = (PFNGLGETNPOLYGONSTIPPLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetnPolygonStippleARB")) == NULL) || r; - r = ((glGetnSeparableFilterARB = (PFNGLGETNSEPARABLEFILTERARBPROC)glewGetProcAddress((const GLubyte*)"glGetnSeparableFilterARB")) == NULL) || r; - r = ((glGetnTexImageARB = (PFNGLGETNTEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"glGetnTexImageARB")) == NULL) || r; - r = ((glGetnUniformdvARB = (PFNGLGETNUNIFORMDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnUniformdvARB")) == NULL) || r; - r = ((glGetnUniformfvARB = (PFNGLGETNUNIFORMFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnUniformfvARB")) == NULL) || r; - r = ((glGetnUniformivARB = (PFNGLGETNUNIFORMIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnUniformivARB")) == NULL) || r; - r = ((glGetnUniformuivARB = (PFNGLGETNUNIFORMUIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetnUniformuivARB")) == NULL) || r; - r = ((glReadnPixelsARB = (PFNGLREADNPIXELSARBPROC)glewGetProcAddress((const GLubyte*)"glReadnPixelsARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_robustness */ - -#ifdef GL_ARB_robustness_application_isolation - -#endif /* GL_ARB_robustness_application_isolation */ - -#ifdef GL_ARB_robustness_share_group_isolation - -#endif /* GL_ARB_robustness_share_group_isolation */ - -#ifdef GL_ARB_sample_shading - -static GLboolean _glewInit_GL_ARB_sample_shading (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMinSampleShadingARB = (PFNGLMINSAMPLESHADINGARBPROC)glewGetProcAddress((const GLubyte*)"glMinSampleShadingARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_sample_shading */ - -#ifdef GL_ARB_sampler_objects - -static GLboolean _glewInit_GL_ARB_sampler_objects (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindSampler = (PFNGLBINDSAMPLERPROC)glewGetProcAddress((const GLubyte*)"glBindSampler")) == NULL) || r; - r = ((glDeleteSamplers = (PFNGLDELETESAMPLERSPROC)glewGetProcAddress((const GLubyte*)"glDeleteSamplers")) == NULL) || r; - r = ((glGenSamplers = (PFNGLGENSAMPLERSPROC)glewGetProcAddress((const GLubyte*)"glGenSamplers")) == NULL) || r; - r = ((glGetSamplerParameterIiv = (PFNGLGETSAMPLERPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameterIiv")) == NULL) || r; - r = ((glGetSamplerParameterIuiv = (PFNGLGETSAMPLERPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameterIuiv")) == NULL) || r; - r = ((glGetSamplerParameterfv = (PFNGLGETSAMPLERPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameterfv")) == NULL) || r; - r = ((glGetSamplerParameteriv = (PFNGLGETSAMPLERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glGetSamplerParameteriv")) == NULL) || r; - r = ((glIsSampler = (PFNGLISSAMPLERPROC)glewGetProcAddress((const GLubyte*)"glIsSampler")) == NULL) || r; - r = ((glSamplerParameterIiv = (PFNGLSAMPLERPARAMETERIIVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterIiv")) == NULL) || r; - r = ((glSamplerParameterIuiv = (PFNGLSAMPLERPARAMETERIUIVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterIuiv")) == NULL) || r; - r = ((glSamplerParameterf = (PFNGLSAMPLERPARAMETERFPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterf")) == NULL) || r; - r = ((glSamplerParameterfv = (PFNGLSAMPLERPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameterfv")) == NULL) || r; - r = ((glSamplerParameteri = (PFNGLSAMPLERPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameteri")) == NULL) || r; - r = ((glSamplerParameteriv = (PFNGLSAMPLERPARAMETERIVPROC)glewGetProcAddress((const GLubyte*)"glSamplerParameteriv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_sampler_objects */ - -#ifdef GL_ARB_seamless_cube_map - -#endif /* GL_ARB_seamless_cube_map */ - -#ifdef GL_ARB_seamless_cubemap_per_texture - -#endif /* GL_ARB_seamless_cubemap_per_texture */ - -#ifdef GL_ARB_separate_shader_objects - -static GLboolean _glewInit_GL_ARB_separate_shader_objects (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glActiveShaderProgram = (PFNGLACTIVESHADERPROGRAMPROC)glewGetProcAddress((const GLubyte*)"glActiveShaderProgram")) == NULL) || r; - r = ((glBindProgramPipeline = (PFNGLBINDPROGRAMPIPELINEPROC)glewGetProcAddress((const GLubyte*)"glBindProgramPipeline")) == NULL) || r; - r = ((glCreateShaderProgramv = (PFNGLCREATESHADERPROGRAMVPROC)glewGetProcAddress((const GLubyte*)"glCreateShaderProgramv")) == NULL) || r; - r = ((glDeleteProgramPipelines = (PFNGLDELETEPROGRAMPIPELINESPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgramPipelines")) == NULL) || r; - r = ((glGenProgramPipelines = (PFNGLGENPROGRAMPIPELINESPROC)glewGetProcAddress((const GLubyte*)"glGenProgramPipelines")) == NULL) || r; - r = ((glGetProgramPipelineInfoLog = (PFNGLGETPROGRAMPIPELINEINFOLOGPROC)glewGetProcAddress((const GLubyte*)"glGetProgramPipelineInfoLog")) == NULL) || r; - r = ((glGetProgramPipelineiv = (PFNGLGETPROGRAMPIPELINEIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramPipelineiv")) == NULL) || r; - r = ((glIsProgramPipeline = (PFNGLISPROGRAMPIPELINEPROC)glewGetProcAddress((const GLubyte*)"glIsProgramPipeline")) == NULL) || r; - r = ((glProgramUniform1d = (PFNGLPROGRAMUNIFORM1DPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1d")) == NULL) || r; - r = ((glProgramUniform1dv = (PFNGLPROGRAMUNIFORM1DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1dv")) == NULL) || r; - r = ((glProgramUniform1f = (PFNGLPROGRAMUNIFORM1FPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1f")) == NULL) || r; - r = ((glProgramUniform1fv = (PFNGLPROGRAMUNIFORM1FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1fv")) == NULL) || r; - r = ((glProgramUniform1i = (PFNGLPROGRAMUNIFORM1IPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1i")) == NULL) || r; - r = ((glProgramUniform1iv = (PFNGLPROGRAMUNIFORM1IVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1iv")) == NULL) || r; - r = ((glProgramUniform1ui = (PFNGLPROGRAMUNIFORM1UIPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ui")) == NULL) || r; - r = ((glProgramUniform1uiv = (PFNGLPROGRAMUNIFORM1UIVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1uiv")) == NULL) || r; - r = ((glProgramUniform2d = (PFNGLPROGRAMUNIFORM2DPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2d")) == NULL) || r; - r = ((glProgramUniform2dv = (PFNGLPROGRAMUNIFORM2DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2dv")) == NULL) || r; - r = ((glProgramUniform2f = (PFNGLPROGRAMUNIFORM2FPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2f")) == NULL) || r; - r = ((glProgramUniform2fv = (PFNGLPROGRAMUNIFORM2FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2fv")) == NULL) || r; - r = ((glProgramUniform2i = (PFNGLPROGRAMUNIFORM2IPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2i")) == NULL) || r; - r = ((glProgramUniform2iv = (PFNGLPROGRAMUNIFORM2IVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2iv")) == NULL) || r; - r = ((glProgramUniform2ui = (PFNGLPROGRAMUNIFORM2UIPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ui")) == NULL) || r; - r = ((glProgramUniform2uiv = (PFNGLPROGRAMUNIFORM2UIVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2uiv")) == NULL) || r; - r = ((glProgramUniform3d = (PFNGLPROGRAMUNIFORM3DPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3d")) == NULL) || r; - r = ((glProgramUniform3dv = (PFNGLPROGRAMUNIFORM3DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3dv")) == NULL) || r; - r = ((glProgramUniform3f = (PFNGLPROGRAMUNIFORM3FPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3f")) == NULL) || r; - r = ((glProgramUniform3fv = (PFNGLPROGRAMUNIFORM3FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3fv")) == NULL) || r; - r = ((glProgramUniform3i = (PFNGLPROGRAMUNIFORM3IPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3i")) == NULL) || r; - r = ((glProgramUniform3iv = (PFNGLPROGRAMUNIFORM3IVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3iv")) == NULL) || r; - r = ((glProgramUniform3ui = (PFNGLPROGRAMUNIFORM3UIPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ui")) == NULL) || r; - r = ((glProgramUniform3uiv = (PFNGLPROGRAMUNIFORM3UIVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3uiv")) == NULL) || r; - r = ((glProgramUniform4d = (PFNGLPROGRAMUNIFORM4DPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4d")) == NULL) || r; - r = ((glProgramUniform4dv = (PFNGLPROGRAMUNIFORM4DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4dv")) == NULL) || r; - r = ((glProgramUniform4f = (PFNGLPROGRAMUNIFORM4FPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4f")) == NULL) || r; - r = ((glProgramUniform4fv = (PFNGLPROGRAMUNIFORM4FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4fv")) == NULL) || r; - r = ((glProgramUniform4i = (PFNGLPROGRAMUNIFORM4IPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4i")) == NULL) || r; - r = ((glProgramUniform4iv = (PFNGLPROGRAMUNIFORM4IVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4iv")) == NULL) || r; - r = ((glProgramUniform4ui = (PFNGLPROGRAMUNIFORM4UIPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ui")) == NULL) || r; - r = ((glProgramUniform4uiv = (PFNGLPROGRAMUNIFORM4UIVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4uiv")) == NULL) || r; - r = ((glProgramUniformMatrix2dv = (PFNGLPROGRAMUNIFORMMATRIX2DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2dv")) == NULL) || r; - r = ((glProgramUniformMatrix2fv = (PFNGLPROGRAMUNIFORMMATRIX2FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2fv")) == NULL) || r; - r = ((glProgramUniformMatrix2x3dv = (PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x3dv")) == NULL) || r; - r = ((glProgramUniformMatrix2x3fv = (PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x3fv")) == NULL) || r; - r = ((glProgramUniformMatrix2x4dv = (PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x4dv")) == NULL) || r; - r = ((glProgramUniformMatrix2x4fv = (PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x4fv")) == NULL) || r; - r = ((glProgramUniformMatrix3dv = (PFNGLPROGRAMUNIFORMMATRIX3DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3dv")) == NULL) || r; - r = ((glProgramUniformMatrix3fv = (PFNGLPROGRAMUNIFORMMATRIX3FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3fv")) == NULL) || r; - r = ((glProgramUniformMatrix3x2dv = (PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x2dv")) == NULL) || r; - r = ((glProgramUniformMatrix3x2fv = (PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x2fv")) == NULL) || r; - r = ((glProgramUniformMatrix3x4dv = (PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x4dv")) == NULL) || r; - r = ((glProgramUniformMatrix3x4fv = (PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x4fv")) == NULL) || r; - r = ((glProgramUniformMatrix4dv = (PFNGLPROGRAMUNIFORMMATRIX4DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4dv")) == NULL) || r; - r = ((glProgramUniformMatrix4fv = (PFNGLPROGRAMUNIFORMMATRIX4FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4fv")) == NULL) || r; - r = ((glProgramUniformMatrix4x2dv = (PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x2dv")) == NULL) || r; - r = ((glProgramUniformMatrix4x2fv = (PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x2fv")) == NULL) || r; - r = ((glProgramUniformMatrix4x3dv = (PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x3dv")) == NULL) || r; - r = ((glProgramUniformMatrix4x3fv = (PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x3fv")) == NULL) || r; - r = ((glUseProgramStages = (PFNGLUSEPROGRAMSTAGESPROC)glewGetProcAddress((const GLubyte*)"glUseProgramStages")) == NULL) || r; - r = ((glValidateProgramPipeline = (PFNGLVALIDATEPROGRAMPIPELINEPROC)glewGetProcAddress((const GLubyte*)"glValidateProgramPipeline")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_separate_shader_objects */ - -#ifdef GL_ARB_shader_atomic_counters - -static GLboolean _glewInit_GL_ARB_shader_atomic_counters (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetActiveAtomicCounterBufferiv = (PFNGLGETACTIVEATOMICCOUNTERBUFFERIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveAtomicCounterBufferiv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_shader_atomic_counters */ - -#ifdef GL_ARB_shader_bit_encoding - -#endif /* GL_ARB_shader_bit_encoding */ - -#ifdef GL_ARB_shader_draw_parameters - -#endif /* GL_ARB_shader_draw_parameters */ - -#ifdef GL_ARB_shader_group_vote - -#endif /* GL_ARB_shader_group_vote */ - -#ifdef GL_ARB_shader_image_load_store - -static GLboolean _glewInit_GL_ARB_shader_image_load_store (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindImageTexture = (PFNGLBINDIMAGETEXTUREPROC)glewGetProcAddress((const GLubyte*)"glBindImageTexture")) == NULL) || r; - r = ((glMemoryBarrier = (PFNGLMEMORYBARRIERPROC)glewGetProcAddress((const GLubyte*)"glMemoryBarrier")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_shader_image_load_store */ - -#ifdef GL_ARB_shader_image_size - -#endif /* GL_ARB_shader_image_size */ - -#ifdef GL_ARB_shader_objects - -static GLboolean _glewInit_GL_ARB_shader_objects (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAttachObjectARB = (PFNGLATTACHOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glAttachObjectARB")) == NULL) || r; - r = ((glCompileShaderARB = (PFNGLCOMPILESHADERARBPROC)glewGetProcAddress((const GLubyte*)"glCompileShaderARB")) == NULL) || r; - r = ((glCreateProgramObjectARB = (PFNGLCREATEPROGRAMOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glCreateProgramObjectARB")) == NULL) || r; - r = ((glCreateShaderObjectARB = (PFNGLCREATESHADEROBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glCreateShaderObjectARB")) == NULL) || r; - r = ((glDeleteObjectARB = (PFNGLDELETEOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteObjectARB")) == NULL) || r; - r = ((glDetachObjectARB = (PFNGLDETACHOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glDetachObjectARB")) == NULL) || r; - r = ((glGetActiveUniformARB = (PFNGLGETACTIVEUNIFORMARBPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformARB")) == NULL) || r; - r = ((glGetAttachedObjectsARB = (PFNGLGETATTACHEDOBJECTSARBPROC)glewGetProcAddress((const GLubyte*)"glGetAttachedObjectsARB")) == NULL) || r; - r = ((glGetHandleARB = (PFNGLGETHANDLEARBPROC)glewGetProcAddress((const GLubyte*)"glGetHandleARB")) == NULL) || r; - r = ((glGetInfoLogARB = (PFNGLGETINFOLOGARBPROC)glewGetProcAddress((const GLubyte*)"glGetInfoLogARB")) == NULL) || r; - r = ((glGetObjectParameterfvARB = (PFNGLGETOBJECTPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetObjectParameterfvARB")) == NULL) || r; - r = ((glGetObjectParameterivARB = (PFNGLGETOBJECTPARAMETERIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetObjectParameterivARB")) == NULL) || r; - r = ((glGetShaderSourceARB = (PFNGLGETSHADERSOURCEARBPROC)glewGetProcAddress((const GLubyte*)"glGetShaderSourceARB")) == NULL) || r; - r = ((glGetUniformLocationARB = (PFNGLGETUNIFORMLOCATIONARBPROC)glewGetProcAddress((const GLubyte*)"glGetUniformLocationARB")) == NULL) || r; - r = ((glGetUniformfvARB = (PFNGLGETUNIFORMFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetUniformfvARB")) == NULL) || r; - r = ((glGetUniformivARB = (PFNGLGETUNIFORMIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetUniformivARB")) == NULL) || r; - r = ((glLinkProgramARB = (PFNGLLINKPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glLinkProgramARB")) == NULL) || r; - r = ((glShaderSourceARB = (PFNGLSHADERSOURCEARBPROC)glewGetProcAddress((const GLubyte*)"glShaderSourceARB")) == NULL) || r; - r = ((glUniform1fARB = (PFNGLUNIFORM1FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1fARB")) == NULL) || r; - r = ((glUniform1fvARB = (PFNGLUNIFORM1FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1fvARB")) == NULL) || r; - r = ((glUniform1iARB = (PFNGLUNIFORM1IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1iARB")) == NULL) || r; - r = ((glUniform1ivARB = (PFNGLUNIFORM1IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform1ivARB")) == NULL) || r; - r = ((glUniform2fARB = (PFNGLUNIFORM2FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2fARB")) == NULL) || r; - r = ((glUniform2fvARB = (PFNGLUNIFORM2FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2fvARB")) == NULL) || r; - r = ((glUniform2iARB = (PFNGLUNIFORM2IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2iARB")) == NULL) || r; - r = ((glUniform2ivARB = (PFNGLUNIFORM2IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform2ivARB")) == NULL) || r; - r = ((glUniform3fARB = (PFNGLUNIFORM3FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3fARB")) == NULL) || r; - r = ((glUniform3fvARB = (PFNGLUNIFORM3FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3fvARB")) == NULL) || r; - r = ((glUniform3iARB = (PFNGLUNIFORM3IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3iARB")) == NULL) || r; - r = ((glUniform3ivARB = (PFNGLUNIFORM3IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform3ivARB")) == NULL) || r; - r = ((glUniform4fARB = (PFNGLUNIFORM4FARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4fARB")) == NULL) || r; - r = ((glUniform4fvARB = (PFNGLUNIFORM4FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4fvARB")) == NULL) || r; - r = ((glUniform4iARB = (PFNGLUNIFORM4IARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4iARB")) == NULL) || r; - r = ((glUniform4ivARB = (PFNGLUNIFORM4IVARBPROC)glewGetProcAddress((const GLubyte*)"glUniform4ivARB")) == NULL) || r; - r = ((glUniformMatrix2fvARB = (PFNGLUNIFORMMATRIX2FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix2fvARB")) == NULL) || r; - r = ((glUniformMatrix3fvARB = (PFNGLUNIFORMMATRIX3FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix3fvARB")) == NULL) || r; - r = ((glUniformMatrix4fvARB = (PFNGLUNIFORMMATRIX4FVARBPROC)glewGetProcAddress((const GLubyte*)"glUniformMatrix4fvARB")) == NULL) || r; - r = ((glUseProgramObjectARB = (PFNGLUSEPROGRAMOBJECTARBPROC)glewGetProcAddress((const GLubyte*)"glUseProgramObjectARB")) == NULL) || r; - r = ((glValidateProgramARB = (PFNGLVALIDATEPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glValidateProgramARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_shader_objects */ - -#ifdef GL_ARB_shader_precision - -#endif /* GL_ARB_shader_precision */ - -#ifdef GL_ARB_shader_stencil_export - -#endif /* GL_ARB_shader_stencil_export */ - -#ifdef GL_ARB_shader_storage_buffer_object - -static GLboolean _glewInit_GL_ARB_shader_storage_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glShaderStorageBlockBinding = (PFNGLSHADERSTORAGEBLOCKBINDINGPROC)glewGetProcAddress((const GLubyte*)"glShaderStorageBlockBinding")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_shader_storage_buffer_object */ - -#ifdef GL_ARB_shader_subroutine - -static GLboolean _glewInit_GL_ARB_shader_subroutine (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetActiveSubroutineName = (PFNGLGETACTIVESUBROUTINENAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveSubroutineName")) == NULL) || r; - r = ((glGetActiveSubroutineUniformName = (PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveSubroutineUniformName")) == NULL) || r; - r = ((glGetActiveSubroutineUniformiv = (PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveSubroutineUniformiv")) == NULL) || r; - r = ((glGetProgramStageiv = (PFNGLGETPROGRAMSTAGEIVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramStageiv")) == NULL) || r; - r = ((glGetSubroutineIndex = (PFNGLGETSUBROUTINEINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetSubroutineIndex")) == NULL) || r; - r = ((glGetSubroutineUniformLocation = (PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC)glewGetProcAddress((const GLubyte*)"glGetSubroutineUniformLocation")) == NULL) || r; - r = ((glGetUniformSubroutineuiv = (PFNGLGETUNIFORMSUBROUTINEUIVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformSubroutineuiv")) == NULL) || r; - r = ((glUniformSubroutinesuiv = (PFNGLUNIFORMSUBROUTINESUIVPROC)glewGetProcAddress((const GLubyte*)"glUniformSubroutinesuiv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_shader_subroutine */ - -#ifdef GL_ARB_shader_texture_lod - -#endif /* GL_ARB_shader_texture_lod */ - -#ifdef GL_ARB_shading_language_100 - -#endif /* GL_ARB_shading_language_100 */ - -#ifdef GL_ARB_shading_language_420pack - -#endif /* GL_ARB_shading_language_420pack */ - -#ifdef GL_ARB_shading_language_include - -static GLboolean _glewInit_GL_ARB_shading_language_include (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCompileShaderIncludeARB = (PFNGLCOMPILESHADERINCLUDEARBPROC)glewGetProcAddress((const GLubyte*)"glCompileShaderIncludeARB")) == NULL) || r; - r = ((glDeleteNamedStringARB = (PFNGLDELETENAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteNamedStringARB")) == NULL) || r; - r = ((glGetNamedStringARB = (PFNGLGETNAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glGetNamedStringARB")) == NULL) || r; - r = ((glGetNamedStringivARB = (PFNGLGETNAMEDSTRINGIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetNamedStringivARB")) == NULL) || r; - r = ((glIsNamedStringARB = (PFNGLISNAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glIsNamedStringARB")) == NULL) || r; - r = ((glNamedStringARB = (PFNGLNAMEDSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glNamedStringARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_shading_language_include */ - -#ifdef GL_ARB_shading_language_packing - -#endif /* GL_ARB_shading_language_packing */ - -#ifdef GL_ARB_shadow - -#endif /* GL_ARB_shadow */ - -#ifdef GL_ARB_shadow_ambient - -#endif /* GL_ARB_shadow_ambient */ - -#ifdef GL_ARB_sparse_texture - -static GLboolean _glewInit_GL_ARB_sparse_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexPageCommitmentARB = (PFNGLTEXPAGECOMMITMENTARBPROC)glewGetProcAddress((const GLubyte*)"glTexPageCommitmentARB")) == NULL) || r; - r = ((glTexturePageCommitmentEXT = (PFNGLTEXTUREPAGECOMMITMENTEXTPROC)glewGetProcAddress((const GLubyte*)"glTexturePageCommitmentEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_sparse_texture */ - -#ifdef GL_ARB_stencil_texturing - -#endif /* GL_ARB_stencil_texturing */ - -#ifdef GL_ARB_sync - -static GLboolean _glewInit_GL_ARB_sync (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClientWaitSync = (PFNGLCLIENTWAITSYNCPROC)glewGetProcAddress((const GLubyte*)"glClientWaitSync")) == NULL) || r; - r = ((glDeleteSync = (PFNGLDELETESYNCPROC)glewGetProcAddress((const GLubyte*)"glDeleteSync")) == NULL) || r; - r = ((glFenceSync = (PFNGLFENCESYNCPROC)glewGetProcAddress((const GLubyte*)"glFenceSync")) == NULL) || r; - r = ((glGetInteger64v = (PFNGLGETINTEGER64VPROC)glewGetProcAddress((const GLubyte*)"glGetInteger64v")) == NULL) || r; - r = ((glGetSynciv = (PFNGLGETSYNCIVPROC)glewGetProcAddress((const GLubyte*)"glGetSynciv")) == NULL) || r; - r = ((glIsSync = (PFNGLISSYNCPROC)glewGetProcAddress((const GLubyte*)"glIsSync")) == NULL) || r; - r = ((glWaitSync = (PFNGLWAITSYNCPROC)glewGetProcAddress((const GLubyte*)"glWaitSync")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_sync */ - -#ifdef GL_ARB_tessellation_shader - -static GLboolean _glewInit_GL_ARB_tessellation_shader (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPatchParameterfv = (PFNGLPATCHPARAMETERFVPROC)glewGetProcAddress((const GLubyte*)"glPatchParameterfv")) == NULL) || r; - r = ((glPatchParameteri = (PFNGLPATCHPARAMETERIPROC)glewGetProcAddress((const GLubyte*)"glPatchParameteri")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_tessellation_shader */ - -#ifdef GL_ARB_texture_border_clamp - -#endif /* GL_ARB_texture_border_clamp */ - -#ifdef GL_ARB_texture_buffer_object - -static GLboolean _glewInit_GL_ARB_texture_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexBufferARB = (PFNGLTEXBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glTexBufferARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_buffer_object */ - -#ifdef GL_ARB_texture_buffer_object_rgb32 - -#endif /* GL_ARB_texture_buffer_object_rgb32 */ - -#ifdef GL_ARB_texture_buffer_range - -static GLboolean _glewInit_GL_ARB_texture_buffer_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexBufferRange = (PFNGLTEXBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glTexBufferRange")) == NULL) || r; - r = ((glTextureBufferRangeEXT = (PFNGLTEXTUREBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureBufferRangeEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_buffer_range */ - -#ifdef GL_ARB_texture_compression - -static GLboolean _glewInit_GL_ARB_texture_compression (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCompressedTexImage1DARB = (PFNGLCOMPRESSEDTEXIMAGE1DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage1DARB")) == NULL) || r; - r = ((glCompressedTexImage2DARB = (PFNGLCOMPRESSEDTEXIMAGE2DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage2DARB")) == NULL) || r; - r = ((glCompressedTexImage3DARB = (PFNGLCOMPRESSEDTEXIMAGE3DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexImage3DARB")) == NULL) || r; - r = ((glCompressedTexSubImage1DARB = (PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage1DARB")) == NULL) || r; - r = ((glCompressedTexSubImage2DARB = (PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage2DARB")) == NULL) || r; - r = ((glCompressedTexSubImage3DARB = (PFNGLCOMPRESSEDTEXSUBIMAGE3DARBPROC)glewGetProcAddress((const GLubyte*)"glCompressedTexSubImage3DARB")) == NULL) || r; - r = ((glGetCompressedTexImageARB = (PFNGLGETCOMPRESSEDTEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedTexImageARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_compression */ - -#ifdef GL_ARB_texture_compression_bptc - -#endif /* GL_ARB_texture_compression_bptc */ - -#ifdef GL_ARB_texture_compression_rgtc - -#endif /* GL_ARB_texture_compression_rgtc */ - -#ifdef GL_ARB_texture_cube_map - -#endif /* GL_ARB_texture_cube_map */ - -#ifdef GL_ARB_texture_cube_map_array - -#endif /* GL_ARB_texture_cube_map_array */ - -#ifdef GL_ARB_texture_env_add - -#endif /* GL_ARB_texture_env_add */ - -#ifdef GL_ARB_texture_env_combine - -#endif /* GL_ARB_texture_env_combine */ - -#ifdef GL_ARB_texture_env_crossbar - -#endif /* GL_ARB_texture_env_crossbar */ - -#ifdef GL_ARB_texture_env_dot3 - -#endif /* GL_ARB_texture_env_dot3 */ - -#ifdef GL_ARB_texture_float - -#endif /* GL_ARB_texture_float */ - -#ifdef GL_ARB_texture_gather - -#endif /* GL_ARB_texture_gather */ - -#ifdef GL_ARB_texture_mirror_clamp_to_edge - -#endif /* GL_ARB_texture_mirror_clamp_to_edge */ - -#ifdef GL_ARB_texture_mirrored_repeat - -#endif /* GL_ARB_texture_mirrored_repeat */ - -#ifdef GL_ARB_texture_multisample - -static GLboolean _glewInit_GL_ARB_texture_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetMultisamplefv = (PFNGLGETMULTISAMPLEFVPROC)glewGetProcAddress((const GLubyte*)"glGetMultisamplefv")) == NULL) || r; - r = ((glSampleMaski = (PFNGLSAMPLEMASKIPROC)glewGetProcAddress((const GLubyte*)"glSampleMaski")) == NULL) || r; - r = ((glTexImage2DMultisample = (PFNGLTEXIMAGE2DMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glTexImage2DMultisample")) == NULL) || r; - r = ((glTexImage3DMultisample = (PFNGLTEXIMAGE3DMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glTexImage3DMultisample")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_multisample */ - -#ifdef GL_ARB_texture_non_power_of_two - -#endif /* GL_ARB_texture_non_power_of_two */ - -#ifdef GL_ARB_texture_query_levels - -#endif /* GL_ARB_texture_query_levels */ - -#ifdef GL_ARB_texture_query_lod - -#endif /* GL_ARB_texture_query_lod */ - -#ifdef GL_ARB_texture_rectangle - -#endif /* GL_ARB_texture_rectangle */ - -#ifdef GL_ARB_texture_rg - -#endif /* GL_ARB_texture_rg */ - -#ifdef GL_ARB_texture_rgb10_a2ui - -#endif /* GL_ARB_texture_rgb10_a2ui */ - -#ifdef GL_ARB_texture_stencil8 - -#endif /* GL_ARB_texture_stencil8 */ - -#ifdef GL_ARB_texture_storage - -static GLboolean _glewInit_GL_ARB_texture_storage (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexStorage1D = (PFNGLTEXSTORAGE1DPROC)glewGetProcAddress((const GLubyte*)"glTexStorage1D")) == NULL) || r; - r = ((glTexStorage2D = (PFNGLTEXSTORAGE2DPROC)glewGetProcAddress((const GLubyte*)"glTexStorage2D")) == NULL) || r; - r = ((glTexStorage3D = (PFNGLTEXSTORAGE3DPROC)glewGetProcAddress((const GLubyte*)"glTexStorage3D")) == NULL) || r; - r = ((glTextureStorage1DEXT = (PFNGLTEXTURESTORAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureStorage1DEXT")) == NULL) || r; - r = ((glTextureStorage2DEXT = (PFNGLTEXTURESTORAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureStorage2DEXT")) == NULL) || r; - r = ((glTextureStorage3DEXT = (PFNGLTEXTURESTORAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureStorage3DEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_storage */ - -#ifdef GL_ARB_texture_storage_multisample - -static GLboolean _glewInit_GL_ARB_texture_storage_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexStorage2DMultisample = (PFNGLTEXSTORAGE2DMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glTexStorage2DMultisample")) == NULL) || r; - r = ((glTexStorage3DMultisample = (PFNGLTEXSTORAGE3DMULTISAMPLEPROC)glewGetProcAddress((const GLubyte*)"glTexStorage3DMultisample")) == NULL) || r; - r = ((glTextureStorage2DMultisampleEXT = (PFNGLTEXTURESTORAGE2DMULTISAMPLEEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureStorage2DMultisampleEXT")) == NULL) || r; - r = ((glTextureStorage3DMultisampleEXT = (PFNGLTEXTURESTORAGE3DMULTISAMPLEEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureStorage3DMultisampleEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_storage_multisample */ - -#ifdef GL_ARB_texture_swizzle - -#endif /* GL_ARB_texture_swizzle */ - -#ifdef GL_ARB_texture_view - -static GLboolean _glewInit_GL_ARB_texture_view (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTextureView = (PFNGLTEXTUREVIEWPROC)glewGetProcAddress((const GLubyte*)"glTextureView")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_texture_view */ - -#ifdef GL_ARB_timer_query - -static GLboolean _glewInit_GL_ARB_timer_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetQueryObjecti64v = (PFNGLGETQUERYOBJECTI64VPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjecti64v")) == NULL) || r; - r = ((glGetQueryObjectui64v = (PFNGLGETQUERYOBJECTUI64VPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectui64v")) == NULL) || r; - r = ((glQueryCounter = (PFNGLQUERYCOUNTERPROC)glewGetProcAddress((const GLubyte*)"glQueryCounter")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_timer_query */ - -#ifdef GL_ARB_transform_feedback2 - -static GLboolean _glewInit_GL_ARB_transform_feedback2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindTransformFeedback = (PFNGLBINDTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glBindTransformFeedback")) == NULL) || r; - r = ((glDeleteTransformFeedbacks = (PFNGLDELETETRANSFORMFEEDBACKSPROC)glewGetProcAddress((const GLubyte*)"glDeleteTransformFeedbacks")) == NULL) || r; - r = ((glDrawTransformFeedback = (PFNGLDRAWTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedback")) == NULL) || r; - r = ((glGenTransformFeedbacks = (PFNGLGENTRANSFORMFEEDBACKSPROC)glewGetProcAddress((const GLubyte*)"glGenTransformFeedbacks")) == NULL) || r; - r = ((glIsTransformFeedback = (PFNGLISTRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glIsTransformFeedback")) == NULL) || r; - r = ((glPauseTransformFeedback = (PFNGLPAUSETRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glPauseTransformFeedback")) == NULL) || r; - r = ((glResumeTransformFeedback = (PFNGLRESUMETRANSFORMFEEDBACKPROC)glewGetProcAddress((const GLubyte*)"glResumeTransformFeedback")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_transform_feedback2 */ - -#ifdef GL_ARB_transform_feedback3 - -static GLboolean _glewInit_GL_ARB_transform_feedback3 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginQueryIndexed = (PFNGLBEGINQUERYINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glBeginQueryIndexed")) == NULL) || r; - r = ((glDrawTransformFeedbackStream = (PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedbackStream")) == NULL) || r; - r = ((glEndQueryIndexed = (PFNGLENDQUERYINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glEndQueryIndexed")) == NULL) || r; - r = ((glGetQueryIndexediv = (PFNGLGETQUERYINDEXEDIVPROC)glewGetProcAddress((const GLubyte*)"glGetQueryIndexediv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_transform_feedback3 */ - -#ifdef GL_ARB_transform_feedback_instanced - -static GLboolean _glewInit_GL_ARB_transform_feedback_instanced (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawTransformFeedbackInstanced = (PFNGLDRAWTRANSFORMFEEDBACKINSTANCEDPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedbackInstanced")) == NULL) || r; - r = ((glDrawTransformFeedbackStreamInstanced = (PFNGLDRAWTRANSFORMFEEDBACKSTREAMINSTANCEDPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedbackStreamInstanced")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_transform_feedback_instanced */ - -#ifdef GL_ARB_transpose_matrix - -static GLboolean _glewInit_GL_ARB_transpose_matrix (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glLoadTransposeMatrixdARB = (PFNGLLOADTRANSPOSEMATRIXDARBPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixdARB")) == NULL) || r; - r = ((glLoadTransposeMatrixfARB = (PFNGLLOADTRANSPOSEMATRIXFARBPROC)glewGetProcAddress((const GLubyte*)"glLoadTransposeMatrixfARB")) == NULL) || r; - r = ((glMultTransposeMatrixdARB = (PFNGLMULTTRANSPOSEMATRIXDARBPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixdARB")) == NULL) || r; - r = ((glMultTransposeMatrixfARB = (PFNGLMULTTRANSPOSEMATRIXFARBPROC)glewGetProcAddress((const GLubyte*)"glMultTransposeMatrixfARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_transpose_matrix */ - -#ifdef GL_ARB_uniform_buffer_object - -static GLboolean _glewInit_GL_ARB_uniform_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindBufferBase = (PFNGLBINDBUFFERBASEPROC)glewGetProcAddress((const GLubyte*)"glBindBufferBase")) == NULL) || r; - r = ((glBindBufferRange = (PFNGLBINDBUFFERRANGEPROC)glewGetProcAddress((const GLubyte*)"glBindBufferRange")) == NULL) || r; - r = ((glGetActiveUniformBlockName = (PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformBlockName")) == NULL) || r; - r = ((glGetActiveUniformBlockiv = (PFNGLGETACTIVEUNIFORMBLOCKIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformBlockiv")) == NULL) || r; - r = ((glGetActiveUniformName = (PFNGLGETACTIVEUNIFORMNAMEPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformName")) == NULL) || r; - r = ((glGetActiveUniformsiv = (PFNGLGETACTIVEUNIFORMSIVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveUniformsiv")) == NULL) || r; - r = ((glGetIntegeri_v = (PFNGLGETINTEGERI_VPROC)glewGetProcAddress((const GLubyte*)"glGetIntegeri_v")) == NULL) || r; - r = ((glGetUniformBlockIndex = (PFNGLGETUNIFORMBLOCKINDEXPROC)glewGetProcAddress((const GLubyte*)"glGetUniformBlockIndex")) == NULL) || r; - r = ((glGetUniformIndices = (PFNGLGETUNIFORMINDICESPROC)glewGetProcAddress((const GLubyte*)"glGetUniformIndices")) == NULL) || r; - r = ((glUniformBlockBinding = (PFNGLUNIFORMBLOCKBINDINGPROC)glewGetProcAddress((const GLubyte*)"glUniformBlockBinding")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_uniform_buffer_object */ - -#ifdef GL_ARB_vertex_array_bgra - -#endif /* GL_ARB_vertex_array_bgra */ - -#ifdef GL_ARB_vertex_array_object - -static GLboolean _glewInit_GL_ARB_vertex_array_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindVertexArray = (PFNGLBINDVERTEXARRAYPROC)glewGetProcAddress((const GLubyte*)"glBindVertexArray")) == NULL) || r; - r = ((glDeleteVertexArrays = (PFNGLDELETEVERTEXARRAYSPROC)glewGetProcAddress((const GLubyte*)"glDeleteVertexArrays")) == NULL) || r; - r = ((glGenVertexArrays = (PFNGLGENVERTEXARRAYSPROC)glewGetProcAddress((const GLubyte*)"glGenVertexArrays")) == NULL) || r; - r = ((glIsVertexArray = (PFNGLISVERTEXARRAYPROC)glewGetProcAddress((const GLubyte*)"glIsVertexArray")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_array_object */ - -#ifdef GL_ARB_vertex_attrib_64bit - -static GLboolean _glewInit_GL_ARB_vertex_attrib_64bit (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetVertexAttribLdv = (PFNGLGETVERTEXATTRIBLDVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLdv")) == NULL) || r; - r = ((glVertexAttribL1d = (PFNGLVERTEXATTRIBL1DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1d")) == NULL) || r; - r = ((glVertexAttribL1dv = (PFNGLVERTEXATTRIBL1DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1dv")) == NULL) || r; - r = ((glVertexAttribL2d = (PFNGLVERTEXATTRIBL2DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2d")) == NULL) || r; - r = ((glVertexAttribL2dv = (PFNGLVERTEXATTRIBL2DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2dv")) == NULL) || r; - r = ((glVertexAttribL3d = (PFNGLVERTEXATTRIBL3DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3d")) == NULL) || r; - r = ((glVertexAttribL3dv = (PFNGLVERTEXATTRIBL3DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3dv")) == NULL) || r; - r = ((glVertexAttribL4d = (PFNGLVERTEXATTRIBL4DPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4d")) == NULL) || r; - r = ((glVertexAttribL4dv = (PFNGLVERTEXATTRIBL4DVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4dv")) == NULL) || r; - r = ((glVertexAttribLPointer = (PFNGLVERTEXATTRIBLPOINTERPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribLPointer")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_attrib_64bit */ - -#ifdef GL_ARB_vertex_attrib_binding - -static GLboolean _glewInit_GL_ARB_vertex_attrib_binding (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindVertexBuffer = (PFNGLBINDVERTEXBUFFERPROC)glewGetProcAddress((const GLubyte*)"glBindVertexBuffer")) == NULL) || r; - r = ((glVertexAttribBinding = (PFNGLVERTEXATTRIBBINDINGPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribBinding")) == NULL) || r; - r = ((glVertexAttribFormat = (PFNGLVERTEXATTRIBFORMATPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribFormat")) == NULL) || r; - r = ((glVertexAttribIFormat = (PFNGLVERTEXATTRIBIFORMATPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIFormat")) == NULL) || r; - r = ((glVertexAttribLFormat = (PFNGLVERTEXATTRIBLFORMATPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribLFormat")) == NULL) || r; - r = ((glVertexBindingDivisor = (PFNGLVERTEXBINDINGDIVISORPROC)glewGetProcAddress((const GLubyte*)"glVertexBindingDivisor")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_attrib_binding */ - -#ifdef GL_ARB_vertex_blend - -static GLboolean _glewInit_GL_ARB_vertex_blend (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glVertexBlendARB = (PFNGLVERTEXBLENDARBPROC)glewGetProcAddress((const GLubyte*)"glVertexBlendARB")) == NULL) || r; - r = ((glWeightPointerARB = (PFNGLWEIGHTPOINTERARBPROC)glewGetProcAddress((const GLubyte*)"glWeightPointerARB")) == NULL) || r; - r = ((glWeightbvARB = (PFNGLWEIGHTBVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightbvARB")) == NULL) || r; - r = ((glWeightdvARB = (PFNGLWEIGHTDVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightdvARB")) == NULL) || r; - r = ((glWeightfvARB = (PFNGLWEIGHTFVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightfvARB")) == NULL) || r; - r = ((glWeightivARB = (PFNGLWEIGHTIVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightivARB")) == NULL) || r; - r = ((glWeightsvARB = (PFNGLWEIGHTSVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightsvARB")) == NULL) || r; - r = ((glWeightubvARB = (PFNGLWEIGHTUBVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightubvARB")) == NULL) || r; - r = ((glWeightuivARB = (PFNGLWEIGHTUIVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightuivARB")) == NULL) || r; - r = ((glWeightusvARB = (PFNGLWEIGHTUSVARBPROC)glewGetProcAddress((const GLubyte*)"glWeightusvARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_blend */ - -#ifdef GL_ARB_vertex_buffer_object - -static GLboolean _glewInit_GL_ARB_vertex_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindBufferARB = (PFNGLBINDBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glBindBufferARB")) == NULL) || r; - r = ((glBufferDataARB = (PFNGLBUFFERDATAARBPROC)glewGetProcAddress((const GLubyte*)"glBufferDataARB")) == NULL) || r; - r = ((glBufferSubDataARB = (PFNGLBUFFERSUBDATAARBPROC)glewGetProcAddress((const GLubyte*)"glBufferSubDataARB")) == NULL) || r; - r = ((glDeleteBuffersARB = (PFNGLDELETEBUFFERSARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteBuffersARB")) == NULL) || r; - r = ((glGenBuffersARB = (PFNGLGENBUFFERSARBPROC)glewGetProcAddress((const GLubyte*)"glGenBuffersARB")) == NULL) || r; - r = ((glGetBufferParameterivARB = (PFNGLGETBUFFERPARAMETERIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameterivARB")) == NULL) || r; - r = ((glGetBufferPointervARB = (PFNGLGETBUFFERPOINTERVARBPROC)glewGetProcAddress((const GLubyte*)"glGetBufferPointervARB")) == NULL) || r; - r = ((glGetBufferSubDataARB = (PFNGLGETBUFFERSUBDATAARBPROC)glewGetProcAddress((const GLubyte*)"glGetBufferSubDataARB")) == NULL) || r; - r = ((glIsBufferARB = (PFNGLISBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glIsBufferARB")) == NULL) || r; - r = ((glMapBufferARB = (PFNGLMAPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glMapBufferARB")) == NULL) || r; - r = ((glUnmapBufferARB = (PFNGLUNMAPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"glUnmapBufferARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_buffer_object */ - -#ifdef GL_ARB_vertex_program - -static GLboolean _glewInit_GL_ARB_vertex_program (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindProgramARB = (PFNGLBINDPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glBindProgramARB")) == NULL) || r; - r = ((glDeleteProgramsARB = (PFNGLDELETEPROGRAMSARBPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgramsARB")) == NULL) || r; - r = ((glDisableVertexAttribArrayARB = (PFNGLDISABLEVERTEXATTRIBARRAYARBPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexAttribArrayARB")) == NULL) || r; - r = ((glEnableVertexAttribArrayARB = (PFNGLENABLEVERTEXATTRIBARRAYARBPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexAttribArrayARB")) == NULL) || r; - r = ((glGenProgramsARB = (PFNGLGENPROGRAMSARBPROC)glewGetProcAddress((const GLubyte*)"glGenProgramsARB")) == NULL) || r; - r = ((glGetProgramEnvParameterdvARB = (PFNGLGETPROGRAMENVPARAMETERDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramEnvParameterdvARB")) == NULL) || r; - r = ((glGetProgramEnvParameterfvARB = (PFNGLGETPROGRAMENVPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramEnvParameterfvARB")) == NULL) || r; - r = ((glGetProgramLocalParameterdvARB = (PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramLocalParameterdvARB")) == NULL) || r; - r = ((glGetProgramLocalParameterfvARB = (PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramLocalParameterfvARB")) == NULL) || r; - r = ((glGetProgramStringARB = (PFNGLGETPROGRAMSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramStringARB")) == NULL) || r; - r = ((glGetProgramivARB = (PFNGLGETPROGRAMIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetProgramivARB")) == NULL) || r; - r = ((glGetVertexAttribPointervARB = (PFNGLGETVERTEXATTRIBPOINTERVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribPointervARB")) == NULL) || r; - r = ((glGetVertexAttribdvARB = (PFNGLGETVERTEXATTRIBDVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribdvARB")) == NULL) || r; - r = ((glGetVertexAttribfvARB = (PFNGLGETVERTEXATTRIBFVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribfvARB")) == NULL) || r; - r = ((glGetVertexAttribivARB = (PFNGLGETVERTEXATTRIBIVARBPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribivARB")) == NULL) || r; - r = ((glIsProgramARB = (PFNGLISPROGRAMARBPROC)glewGetProcAddress((const GLubyte*)"glIsProgramARB")) == NULL) || r; - r = ((glProgramEnvParameter4dARB = (PFNGLPROGRAMENVPARAMETER4DARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4dARB")) == NULL) || r; - r = ((glProgramEnvParameter4dvARB = (PFNGLPROGRAMENVPARAMETER4DVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4dvARB")) == NULL) || r; - r = ((glProgramEnvParameter4fARB = (PFNGLPROGRAMENVPARAMETER4FARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4fARB")) == NULL) || r; - r = ((glProgramEnvParameter4fvARB = (PFNGLPROGRAMENVPARAMETER4FVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameter4fvARB")) == NULL) || r; - r = ((glProgramLocalParameter4dARB = (PFNGLPROGRAMLOCALPARAMETER4DARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4dARB")) == NULL) || r; - r = ((glProgramLocalParameter4dvARB = (PFNGLPROGRAMLOCALPARAMETER4DVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4dvARB")) == NULL) || r; - r = ((glProgramLocalParameter4fARB = (PFNGLPROGRAMLOCALPARAMETER4FARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4fARB")) == NULL) || r; - r = ((glProgramLocalParameter4fvARB = (PFNGLPROGRAMLOCALPARAMETER4FVARBPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameter4fvARB")) == NULL) || r; - r = ((glProgramStringARB = (PFNGLPROGRAMSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"glProgramStringARB")) == NULL) || r; - r = ((glVertexAttrib1dARB = (PFNGLVERTEXATTRIB1DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dARB")) == NULL) || r; - r = ((glVertexAttrib1dvARB = (PFNGLVERTEXATTRIB1DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dvARB")) == NULL) || r; - r = ((glVertexAttrib1fARB = (PFNGLVERTEXATTRIB1FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fARB")) == NULL) || r; - r = ((glVertexAttrib1fvARB = (PFNGLVERTEXATTRIB1FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fvARB")) == NULL) || r; - r = ((glVertexAttrib1sARB = (PFNGLVERTEXATTRIB1SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1sARB")) == NULL) || r; - r = ((glVertexAttrib1svARB = (PFNGLVERTEXATTRIB1SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1svARB")) == NULL) || r; - r = ((glVertexAttrib2dARB = (PFNGLVERTEXATTRIB2DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dARB")) == NULL) || r; - r = ((glVertexAttrib2dvARB = (PFNGLVERTEXATTRIB2DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dvARB")) == NULL) || r; - r = ((glVertexAttrib2fARB = (PFNGLVERTEXATTRIB2FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fARB")) == NULL) || r; - r = ((glVertexAttrib2fvARB = (PFNGLVERTEXATTRIB2FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fvARB")) == NULL) || r; - r = ((glVertexAttrib2sARB = (PFNGLVERTEXATTRIB2SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2sARB")) == NULL) || r; - r = ((glVertexAttrib2svARB = (PFNGLVERTEXATTRIB2SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2svARB")) == NULL) || r; - r = ((glVertexAttrib3dARB = (PFNGLVERTEXATTRIB3DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dARB")) == NULL) || r; - r = ((glVertexAttrib3dvARB = (PFNGLVERTEXATTRIB3DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dvARB")) == NULL) || r; - r = ((glVertexAttrib3fARB = (PFNGLVERTEXATTRIB3FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fARB")) == NULL) || r; - r = ((glVertexAttrib3fvARB = (PFNGLVERTEXATTRIB3FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fvARB")) == NULL) || r; - r = ((glVertexAttrib3sARB = (PFNGLVERTEXATTRIB3SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3sARB")) == NULL) || r; - r = ((glVertexAttrib3svARB = (PFNGLVERTEXATTRIB3SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3svARB")) == NULL) || r; - r = ((glVertexAttrib4NbvARB = (PFNGLVERTEXATTRIB4NBVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NbvARB")) == NULL) || r; - r = ((glVertexAttrib4NivARB = (PFNGLVERTEXATTRIB4NIVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NivARB")) == NULL) || r; - r = ((glVertexAttrib4NsvARB = (PFNGLVERTEXATTRIB4NSVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NsvARB")) == NULL) || r; - r = ((glVertexAttrib4NubARB = (PFNGLVERTEXATTRIB4NUBARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NubARB")) == NULL) || r; - r = ((glVertexAttrib4NubvARB = (PFNGLVERTEXATTRIB4NUBVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NubvARB")) == NULL) || r; - r = ((glVertexAttrib4NuivARB = (PFNGLVERTEXATTRIB4NUIVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NuivARB")) == NULL) || r; - r = ((glVertexAttrib4NusvARB = (PFNGLVERTEXATTRIB4NUSVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4NusvARB")) == NULL) || r; - r = ((glVertexAttrib4bvARB = (PFNGLVERTEXATTRIB4BVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4bvARB")) == NULL) || r; - r = ((glVertexAttrib4dARB = (PFNGLVERTEXATTRIB4DARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dARB")) == NULL) || r; - r = ((glVertexAttrib4dvARB = (PFNGLVERTEXATTRIB4DVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dvARB")) == NULL) || r; - r = ((glVertexAttrib4fARB = (PFNGLVERTEXATTRIB4FARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fARB")) == NULL) || r; - r = ((glVertexAttrib4fvARB = (PFNGLVERTEXATTRIB4FVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fvARB")) == NULL) || r; - r = ((glVertexAttrib4ivARB = (PFNGLVERTEXATTRIB4IVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ivARB")) == NULL) || r; - r = ((glVertexAttrib4sARB = (PFNGLVERTEXATTRIB4SARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4sARB")) == NULL) || r; - r = ((glVertexAttrib4svARB = (PFNGLVERTEXATTRIB4SVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4svARB")) == NULL) || r; - r = ((glVertexAttrib4ubvARB = (PFNGLVERTEXATTRIB4UBVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubvARB")) == NULL) || r; - r = ((glVertexAttrib4uivARB = (PFNGLVERTEXATTRIB4UIVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4uivARB")) == NULL) || r; - r = ((glVertexAttrib4usvARB = (PFNGLVERTEXATTRIB4USVARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4usvARB")) == NULL) || r; - r = ((glVertexAttribPointerARB = (PFNGLVERTEXATTRIBPOINTERARBPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribPointerARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_program */ - -#ifdef GL_ARB_vertex_shader - -static GLboolean _glewInit_GL_ARB_vertex_shader (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindAttribLocationARB = (PFNGLBINDATTRIBLOCATIONARBPROC)glewGetProcAddress((const GLubyte*)"glBindAttribLocationARB")) == NULL) || r; - r = ((glGetActiveAttribARB = (PFNGLGETACTIVEATTRIBARBPROC)glewGetProcAddress((const GLubyte*)"glGetActiveAttribARB")) == NULL) || r; - r = ((glGetAttribLocationARB = (PFNGLGETATTRIBLOCATIONARBPROC)glewGetProcAddress((const GLubyte*)"glGetAttribLocationARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_shader */ - -#ifdef GL_ARB_vertex_type_10f_11f_11f_rev - -#endif /* GL_ARB_vertex_type_10f_11f_11f_rev */ - -#ifdef GL_ARB_vertex_type_2_10_10_10_rev - -static GLboolean _glewInit_GL_ARB_vertex_type_2_10_10_10_rev (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorP3ui = (PFNGLCOLORP3UIPROC)glewGetProcAddress((const GLubyte*)"glColorP3ui")) == NULL) || r; - r = ((glColorP3uiv = (PFNGLCOLORP3UIVPROC)glewGetProcAddress((const GLubyte*)"glColorP3uiv")) == NULL) || r; - r = ((glColorP4ui = (PFNGLCOLORP4UIPROC)glewGetProcAddress((const GLubyte*)"glColorP4ui")) == NULL) || r; - r = ((glColorP4uiv = (PFNGLCOLORP4UIVPROC)glewGetProcAddress((const GLubyte*)"glColorP4uiv")) == NULL) || r; - r = ((glMultiTexCoordP1ui = (PFNGLMULTITEXCOORDP1UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP1ui")) == NULL) || r; - r = ((glMultiTexCoordP1uiv = (PFNGLMULTITEXCOORDP1UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP1uiv")) == NULL) || r; - r = ((glMultiTexCoordP2ui = (PFNGLMULTITEXCOORDP2UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP2ui")) == NULL) || r; - r = ((glMultiTexCoordP2uiv = (PFNGLMULTITEXCOORDP2UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP2uiv")) == NULL) || r; - r = ((glMultiTexCoordP3ui = (PFNGLMULTITEXCOORDP3UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP3ui")) == NULL) || r; - r = ((glMultiTexCoordP3uiv = (PFNGLMULTITEXCOORDP3UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP3uiv")) == NULL) || r; - r = ((glMultiTexCoordP4ui = (PFNGLMULTITEXCOORDP4UIPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP4ui")) == NULL) || r; - r = ((glMultiTexCoordP4uiv = (PFNGLMULTITEXCOORDP4UIVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordP4uiv")) == NULL) || r; - r = ((glNormalP3ui = (PFNGLNORMALP3UIPROC)glewGetProcAddress((const GLubyte*)"glNormalP3ui")) == NULL) || r; - r = ((glNormalP3uiv = (PFNGLNORMALP3UIVPROC)glewGetProcAddress((const GLubyte*)"glNormalP3uiv")) == NULL) || r; - r = ((glSecondaryColorP3ui = (PFNGLSECONDARYCOLORP3UIPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorP3ui")) == NULL) || r; - r = ((glSecondaryColorP3uiv = (PFNGLSECONDARYCOLORP3UIVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorP3uiv")) == NULL) || r; - r = ((glTexCoordP1ui = (PFNGLTEXCOORDP1UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP1ui")) == NULL) || r; - r = ((glTexCoordP1uiv = (PFNGLTEXCOORDP1UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP1uiv")) == NULL) || r; - r = ((glTexCoordP2ui = (PFNGLTEXCOORDP2UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP2ui")) == NULL) || r; - r = ((glTexCoordP2uiv = (PFNGLTEXCOORDP2UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP2uiv")) == NULL) || r; - r = ((glTexCoordP3ui = (PFNGLTEXCOORDP3UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP3ui")) == NULL) || r; - r = ((glTexCoordP3uiv = (PFNGLTEXCOORDP3UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP3uiv")) == NULL) || r; - r = ((glTexCoordP4ui = (PFNGLTEXCOORDP4UIPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP4ui")) == NULL) || r; - r = ((glTexCoordP4uiv = (PFNGLTEXCOORDP4UIVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordP4uiv")) == NULL) || r; - r = ((glVertexAttribP1ui = (PFNGLVERTEXATTRIBP1UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP1ui")) == NULL) || r; - r = ((glVertexAttribP1uiv = (PFNGLVERTEXATTRIBP1UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP1uiv")) == NULL) || r; - r = ((glVertexAttribP2ui = (PFNGLVERTEXATTRIBP2UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP2ui")) == NULL) || r; - r = ((glVertexAttribP2uiv = (PFNGLVERTEXATTRIBP2UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP2uiv")) == NULL) || r; - r = ((glVertexAttribP3ui = (PFNGLVERTEXATTRIBP3UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP3ui")) == NULL) || r; - r = ((glVertexAttribP3uiv = (PFNGLVERTEXATTRIBP3UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP3uiv")) == NULL) || r; - r = ((glVertexAttribP4ui = (PFNGLVERTEXATTRIBP4UIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP4ui")) == NULL) || r; - r = ((glVertexAttribP4uiv = (PFNGLVERTEXATTRIBP4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribP4uiv")) == NULL) || r; - r = ((glVertexP2ui = (PFNGLVERTEXP2UIPROC)glewGetProcAddress((const GLubyte*)"glVertexP2ui")) == NULL) || r; - r = ((glVertexP2uiv = (PFNGLVERTEXP2UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexP2uiv")) == NULL) || r; - r = ((glVertexP3ui = (PFNGLVERTEXP3UIPROC)glewGetProcAddress((const GLubyte*)"glVertexP3ui")) == NULL) || r; - r = ((glVertexP3uiv = (PFNGLVERTEXP3UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexP3uiv")) == NULL) || r; - r = ((glVertexP4ui = (PFNGLVERTEXP4UIPROC)glewGetProcAddress((const GLubyte*)"glVertexP4ui")) == NULL) || r; - r = ((glVertexP4uiv = (PFNGLVERTEXP4UIVPROC)glewGetProcAddress((const GLubyte*)"glVertexP4uiv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ - -#ifdef GL_ARB_viewport_array - -static GLboolean _glewInit_GL_ARB_viewport_array (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDepthRangeArrayv = (PFNGLDEPTHRANGEARRAYVPROC)glewGetProcAddress((const GLubyte*)"glDepthRangeArrayv")) == NULL) || r; - r = ((glDepthRangeIndexed = (PFNGLDEPTHRANGEINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glDepthRangeIndexed")) == NULL) || r; - r = ((glGetDoublei_v = (PFNGLGETDOUBLEI_VPROC)glewGetProcAddress((const GLubyte*)"glGetDoublei_v")) == NULL) || r; - r = ((glGetFloati_v = (PFNGLGETFLOATI_VPROC)glewGetProcAddress((const GLubyte*)"glGetFloati_v")) == NULL) || r; - r = ((glScissorArrayv = (PFNGLSCISSORARRAYVPROC)glewGetProcAddress((const GLubyte*)"glScissorArrayv")) == NULL) || r; - r = ((glScissorIndexed = (PFNGLSCISSORINDEXEDPROC)glewGetProcAddress((const GLubyte*)"glScissorIndexed")) == NULL) || r; - r = ((glScissorIndexedv = (PFNGLSCISSORINDEXEDVPROC)glewGetProcAddress((const GLubyte*)"glScissorIndexedv")) == NULL) || r; - r = ((glViewportArrayv = (PFNGLVIEWPORTARRAYVPROC)glewGetProcAddress((const GLubyte*)"glViewportArrayv")) == NULL) || r; - r = ((glViewportIndexedf = (PFNGLVIEWPORTINDEXEDFPROC)glewGetProcAddress((const GLubyte*)"glViewportIndexedf")) == NULL) || r; - r = ((glViewportIndexedfv = (PFNGLVIEWPORTINDEXEDFVPROC)glewGetProcAddress((const GLubyte*)"glViewportIndexedfv")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_viewport_array */ - -#ifdef GL_ARB_window_pos - -static GLboolean _glewInit_GL_ARB_window_pos (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glWindowPos2dARB = (PFNGLWINDOWPOS2DARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dARB")) == NULL) || r; - r = ((glWindowPos2dvARB = (PFNGLWINDOWPOS2DVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dvARB")) == NULL) || r; - r = ((glWindowPos2fARB = (PFNGLWINDOWPOS2FARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fARB")) == NULL) || r; - r = ((glWindowPos2fvARB = (PFNGLWINDOWPOS2FVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fvARB")) == NULL) || r; - r = ((glWindowPos2iARB = (PFNGLWINDOWPOS2IARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2iARB")) == NULL) || r; - r = ((glWindowPos2ivARB = (PFNGLWINDOWPOS2IVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2ivARB")) == NULL) || r; - r = ((glWindowPos2sARB = (PFNGLWINDOWPOS2SARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2sARB")) == NULL) || r; - r = ((glWindowPos2svARB = (PFNGLWINDOWPOS2SVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2svARB")) == NULL) || r; - r = ((glWindowPos3dARB = (PFNGLWINDOWPOS3DARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dARB")) == NULL) || r; - r = ((glWindowPos3dvARB = (PFNGLWINDOWPOS3DVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dvARB")) == NULL) || r; - r = ((glWindowPos3fARB = (PFNGLWINDOWPOS3FARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fARB")) == NULL) || r; - r = ((glWindowPos3fvARB = (PFNGLWINDOWPOS3FVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fvARB")) == NULL) || r; - r = ((glWindowPos3iARB = (PFNGLWINDOWPOS3IARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3iARB")) == NULL) || r; - r = ((glWindowPos3ivARB = (PFNGLWINDOWPOS3IVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3ivARB")) == NULL) || r; - r = ((glWindowPos3sARB = (PFNGLWINDOWPOS3SARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3sARB")) == NULL) || r; - r = ((glWindowPos3svARB = (PFNGLWINDOWPOS3SVARBPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3svARB")) == NULL) || r; - - return r; -} - -#endif /* GL_ARB_window_pos */ - -#ifdef GL_ATIX_point_sprites - -#endif /* GL_ATIX_point_sprites */ - -#ifdef GL_ATIX_texture_env_combine3 - -#endif /* GL_ATIX_texture_env_combine3 */ - -#ifdef GL_ATIX_texture_env_route - -#endif /* GL_ATIX_texture_env_route */ - -#ifdef GL_ATIX_vertex_shader_output_point_size - -#endif /* GL_ATIX_vertex_shader_output_point_size */ - -#ifdef GL_ATI_draw_buffers - -static GLboolean _glewInit_GL_ATI_draw_buffers (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawBuffersATI = (PFNGLDRAWBUFFERSATIPROC)glewGetProcAddress((const GLubyte*)"glDrawBuffersATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_draw_buffers */ - -#ifdef GL_ATI_element_array - -static GLboolean _glewInit_GL_ATI_element_array (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawElementArrayATI = (PFNGLDRAWELEMENTARRAYATIPROC)glewGetProcAddress((const GLubyte*)"glDrawElementArrayATI")) == NULL) || r; - r = ((glDrawRangeElementArrayATI = (PFNGLDRAWRANGEELEMENTARRAYATIPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementArrayATI")) == NULL) || r; - r = ((glElementPointerATI = (PFNGLELEMENTPOINTERATIPROC)glewGetProcAddress((const GLubyte*)"glElementPointerATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_element_array */ - -#ifdef GL_ATI_envmap_bumpmap - -static GLboolean _glewInit_GL_ATI_envmap_bumpmap (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetTexBumpParameterfvATI = (PFNGLGETTEXBUMPPARAMETERFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetTexBumpParameterfvATI")) == NULL) || r; - r = ((glGetTexBumpParameterivATI = (PFNGLGETTEXBUMPPARAMETERIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetTexBumpParameterivATI")) == NULL) || r; - r = ((glTexBumpParameterfvATI = (PFNGLTEXBUMPPARAMETERFVATIPROC)glewGetProcAddress((const GLubyte*)"glTexBumpParameterfvATI")) == NULL) || r; - r = ((glTexBumpParameterivATI = (PFNGLTEXBUMPPARAMETERIVATIPROC)glewGetProcAddress((const GLubyte*)"glTexBumpParameterivATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_envmap_bumpmap */ - -#ifdef GL_ATI_fragment_shader - -static GLboolean _glewInit_GL_ATI_fragment_shader (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAlphaFragmentOp1ATI = (PFNGLALPHAFRAGMENTOP1ATIPROC)glewGetProcAddress((const GLubyte*)"glAlphaFragmentOp1ATI")) == NULL) || r; - r = ((glAlphaFragmentOp2ATI = (PFNGLALPHAFRAGMENTOP2ATIPROC)glewGetProcAddress((const GLubyte*)"glAlphaFragmentOp2ATI")) == NULL) || r; - r = ((glAlphaFragmentOp3ATI = (PFNGLALPHAFRAGMENTOP3ATIPROC)glewGetProcAddress((const GLubyte*)"glAlphaFragmentOp3ATI")) == NULL) || r; - r = ((glBeginFragmentShaderATI = (PFNGLBEGINFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glBeginFragmentShaderATI")) == NULL) || r; - r = ((glBindFragmentShaderATI = (PFNGLBINDFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glBindFragmentShaderATI")) == NULL) || r; - r = ((glColorFragmentOp1ATI = (PFNGLCOLORFRAGMENTOP1ATIPROC)glewGetProcAddress((const GLubyte*)"glColorFragmentOp1ATI")) == NULL) || r; - r = ((glColorFragmentOp2ATI = (PFNGLCOLORFRAGMENTOP2ATIPROC)glewGetProcAddress((const GLubyte*)"glColorFragmentOp2ATI")) == NULL) || r; - r = ((glColorFragmentOp3ATI = (PFNGLCOLORFRAGMENTOP3ATIPROC)glewGetProcAddress((const GLubyte*)"glColorFragmentOp3ATI")) == NULL) || r; - r = ((glDeleteFragmentShaderATI = (PFNGLDELETEFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glDeleteFragmentShaderATI")) == NULL) || r; - r = ((glEndFragmentShaderATI = (PFNGLENDFRAGMENTSHADERATIPROC)glewGetProcAddress((const GLubyte*)"glEndFragmentShaderATI")) == NULL) || r; - r = ((glGenFragmentShadersATI = (PFNGLGENFRAGMENTSHADERSATIPROC)glewGetProcAddress((const GLubyte*)"glGenFragmentShadersATI")) == NULL) || r; - r = ((glPassTexCoordATI = (PFNGLPASSTEXCOORDATIPROC)glewGetProcAddress((const GLubyte*)"glPassTexCoordATI")) == NULL) || r; - r = ((glSampleMapATI = (PFNGLSAMPLEMAPATIPROC)glewGetProcAddress((const GLubyte*)"glSampleMapATI")) == NULL) || r; - r = ((glSetFragmentShaderConstantATI = (PFNGLSETFRAGMENTSHADERCONSTANTATIPROC)glewGetProcAddress((const GLubyte*)"glSetFragmentShaderConstantATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_fragment_shader */ - -#ifdef GL_ATI_map_object_buffer - -static GLboolean _glewInit_GL_ATI_map_object_buffer (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMapObjectBufferATI = (PFNGLMAPOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glMapObjectBufferATI")) == NULL) || r; - r = ((glUnmapObjectBufferATI = (PFNGLUNMAPOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glUnmapObjectBufferATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_map_object_buffer */ - -#ifdef GL_ATI_meminfo - -#endif /* GL_ATI_meminfo */ - -#ifdef GL_ATI_pn_triangles - -static GLboolean _glewInit_GL_ATI_pn_triangles (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPNTrianglesfATI = (PFNGLPNTRIANGLESFATIPROC)glewGetProcAddress((const GLubyte*)"glPNTrianglesfATI")) == NULL) || r; - r = ((glPNTrianglesiATI = (PFNGLPNTRIANGLESIATIPROC)glewGetProcAddress((const GLubyte*)"glPNTrianglesiATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_pn_triangles */ - -#ifdef GL_ATI_separate_stencil - -static GLboolean _glewInit_GL_ATI_separate_stencil (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glStencilFuncSeparateATI = (PFNGLSTENCILFUNCSEPARATEATIPROC)glewGetProcAddress((const GLubyte*)"glStencilFuncSeparateATI")) == NULL) || r; - r = ((glStencilOpSeparateATI = (PFNGLSTENCILOPSEPARATEATIPROC)glewGetProcAddress((const GLubyte*)"glStencilOpSeparateATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_separate_stencil */ - -#ifdef GL_ATI_shader_texture_lod - -#endif /* GL_ATI_shader_texture_lod */ - -#ifdef GL_ATI_text_fragment_shader - -#endif /* GL_ATI_text_fragment_shader */ - -#ifdef GL_ATI_texture_compression_3dc - -#endif /* GL_ATI_texture_compression_3dc */ - -#ifdef GL_ATI_texture_env_combine3 - -#endif /* GL_ATI_texture_env_combine3 */ - -#ifdef GL_ATI_texture_float - -#endif /* GL_ATI_texture_float */ - -#ifdef GL_ATI_texture_mirror_once - -#endif /* GL_ATI_texture_mirror_once */ - -#ifdef GL_ATI_vertex_array_object - -static GLboolean _glewInit_GL_ATI_vertex_array_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glArrayObjectATI = (PFNGLARRAYOBJECTATIPROC)glewGetProcAddress((const GLubyte*)"glArrayObjectATI")) == NULL) || r; - r = ((glFreeObjectBufferATI = (PFNGLFREEOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glFreeObjectBufferATI")) == NULL) || r; - r = ((glGetArrayObjectfvATI = (PFNGLGETARRAYOBJECTFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetArrayObjectfvATI")) == NULL) || r; - r = ((glGetArrayObjectivATI = (PFNGLGETARRAYOBJECTIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetArrayObjectivATI")) == NULL) || r; - r = ((glGetObjectBufferfvATI = (PFNGLGETOBJECTBUFFERFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetObjectBufferfvATI")) == NULL) || r; - r = ((glGetObjectBufferivATI = (PFNGLGETOBJECTBUFFERIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetObjectBufferivATI")) == NULL) || r; - r = ((glGetVariantArrayObjectfvATI = (PFNGLGETVARIANTARRAYOBJECTFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVariantArrayObjectfvATI")) == NULL) || r; - r = ((glGetVariantArrayObjectivATI = (PFNGLGETVARIANTARRAYOBJECTIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVariantArrayObjectivATI")) == NULL) || r; - r = ((glIsObjectBufferATI = (PFNGLISOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glIsObjectBufferATI")) == NULL) || r; - r = ((glNewObjectBufferATI = (PFNGLNEWOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glNewObjectBufferATI")) == NULL) || r; - r = ((glUpdateObjectBufferATI = (PFNGLUPDATEOBJECTBUFFERATIPROC)glewGetProcAddress((const GLubyte*)"glUpdateObjectBufferATI")) == NULL) || r; - r = ((glVariantArrayObjectATI = (PFNGLVARIANTARRAYOBJECTATIPROC)glewGetProcAddress((const GLubyte*)"glVariantArrayObjectATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_vertex_array_object */ - -#ifdef GL_ATI_vertex_attrib_array_object - -static GLboolean _glewInit_GL_ATI_vertex_attrib_array_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetVertexAttribArrayObjectfvATI = (PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribArrayObjectfvATI")) == NULL) || r; - r = ((glGetVertexAttribArrayObjectivATI = (PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribArrayObjectivATI")) == NULL) || r; - r = ((glVertexAttribArrayObjectATI = (PFNGLVERTEXATTRIBARRAYOBJECTATIPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribArrayObjectATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_vertex_attrib_array_object */ - -#ifdef GL_ATI_vertex_streams - -static GLboolean _glewInit_GL_ATI_vertex_streams (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClientActiveVertexStreamATI = (PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC)glewGetProcAddress((const GLubyte*)"glClientActiveVertexStreamATI")) == NULL) || r; - r = ((glNormalStream3bATI = (PFNGLNORMALSTREAM3BATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3bATI")) == NULL) || r; - r = ((glNormalStream3bvATI = (PFNGLNORMALSTREAM3BVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3bvATI")) == NULL) || r; - r = ((glNormalStream3dATI = (PFNGLNORMALSTREAM3DATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3dATI")) == NULL) || r; - r = ((glNormalStream3dvATI = (PFNGLNORMALSTREAM3DVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3dvATI")) == NULL) || r; - r = ((glNormalStream3fATI = (PFNGLNORMALSTREAM3FATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3fATI")) == NULL) || r; - r = ((glNormalStream3fvATI = (PFNGLNORMALSTREAM3FVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3fvATI")) == NULL) || r; - r = ((glNormalStream3iATI = (PFNGLNORMALSTREAM3IATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3iATI")) == NULL) || r; - r = ((glNormalStream3ivATI = (PFNGLNORMALSTREAM3IVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3ivATI")) == NULL) || r; - r = ((glNormalStream3sATI = (PFNGLNORMALSTREAM3SATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3sATI")) == NULL) || r; - r = ((glNormalStream3svATI = (PFNGLNORMALSTREAM3SVATIPROC)glewGetProcAddress((const GLubyte*)"glNormalStream3svATI")) == NULL) || r; - r = ((glVertexBlendEnvfATI = (PFNGLVERTEXBLENDENVFATIPROC)glewGetProcAddress((const GLubyte*)"glVertexBlendEnvfATI")) == NULL) || r; - r = ((glVertexBlendEnviATI = (PFNGLVERTEXBLENDENVIATIPROC)glewGetProcAddress((const GLubyte*)"glVertexBlendEnviATI")) == NULL) || r; - r = ((glVertexStream1dATI = (PFNGLVERTEXSTREAM1DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1dATI")) == NULL) || r; - r = ((glVertexStream1dvATI = (PFNGLVERTEXSTREAM1DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1dvATI")) == NULL) || r; - r = ((glVertexStream1fATI = (PFNGLVERTEXSTREAM1FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1fATI")) == NULL) || r; - r = ((glVertexStream1fvATI = (PFNGLVERTEXSTREAM1FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1fvATI")) == NULL) || r; - r = ((glVertexStream1iATI = (PFNGLVERTEXSTREAM1IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1iATI")) == NULL) || r; - r = ((glVertexStream1ivATI = (PFNGLVERTEXSTREAM1IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1ivATI")) == NULL) || r; - r = ((glVertexStream1sATI = (PFNGLVERTEXSTREAM1SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1sATI")) == NULL) || r; - r = ((glVertexStream1svATI = (PFNGLVERTEXSTREAM1SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream1svATI")) == NULL) || r; - r = ((glVertexStream2dATI = (PFNGLVERTEXSTREAM2DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2dATI")) == NULL) || r; - r = ((glVertexStream2dvATI = (PFNGLVERTEXSTREAM2DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2dvATI")) == NULL) || r; - r = ((glVertexStream2fATI = (PFNGLVERTEXSTREAM2FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2fATI")) == NULL) || r; - r = ((glVertexStream2fvATI = (PFNGLVERTEXSTREAM2FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2fvATI")) == NULL) || r; - r = ((glVertexStream2iATI = (PFNGLVERTEXSTREAM2IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2iATI")) == NULL) || r; - r = ((glVertexStream2ivATI = (PFNGLVERTEXSTREAM2IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2ivATI")) == NULL) || r; - r = ((glVertexStream2sATI = (PFNGLVERTEXSTREAM2SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2sATI")) == NULL) || r; - r = ((glVertexStream2svATI = (PFNGLVERTEXSTREAM2SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream2svATI")) == NULL) || r; - r = ((glVertexStream3dATI = (PFNGLVERTEXSTREAM3DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3dATI")) == NULL) || r; - r = ((glVertexStream3dvATI = (PFNGLVERTEXSTREAM3DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3dvATI")) == NULL) || r; - r = ((glVertexStream3fATI = (PFNGLVERTEXSTREAM3FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3fATI")) == NULL) || r; - r = ((glVertexStream3fvATI = (PFNGLVERTEXSTREAM3FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3fvATI")) == NULL) || r; - r = ((glVertexStream3iATI = (PFNGLVERTEXSTREAM3IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3iATI")) == NULL) || r; - r = ((glVertexStream3ivATI = (PFNGLVERTEXSTREAM3IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3ivATI")) == NULL) || r; - r = ((glVertexStream3sATI = (PFNGLVERTEXSTREAM3SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3sATI")) == NULL) || r; - r = ((glVertexStream3svATI = (PFNGLVERTEXSTREAM3SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream3svATI")) == NULL) || r; - r = ((glVertexStream4dATI = (PFNGLVERTEXSTREAM4DATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4dATI")) == NULL) || r; - r = ((glVertexStream4dvATI = (PFNGLVERTEXSTREAM4DVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4dvATI")) == NULL) || r; - r = ((glVertexStream4fATI = (PFNGLVERTEXSTREAM4FATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4fATI")) == NULL) || r; - r = ((glVertexStream4fvATI = (PFNGLVERTEXSTREAM4FVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4fvATI")) == NULL) || r; - r = ((glVertexStream4iATI = (PFNGLVERTEXSTREAM4IATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4iATI")) == NULL) || r; - r = ((glVertexStream4ivATI = (PFNGLVERTEXSTREAM4IVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4ivATI")) == NULL) || r; - r = ((glVertexStream4sATI = (PFNGLVERTEXSTREAM4SATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4sATI")) == NULL) || r; - r = ((glVertexStream4svATI = (PFNGLVERTEXSTREAM4SVATIPROC)glewGetProcAddress((const GLubyte*)"glVertexStream4svATI")) == NULL) || r; - - return r; -} - -#endif /* GL_ATI_vertex_streams */ - -#ifdef GL_EXT_422_pixels - -#endif /* GL_EXT_422_pixels */ - -#ifdef GL_EXT_Cg_shader - -#endif /* GL_EXT_Cg_shader */ - -#ifdef GL_EXT_abgr - -#endif /* GL_EXT_abgr */ - -#ifdef GL_EXT_bgra - -#endif /* GL_EXT_bgra */ - -#ifdef GL_EXT_bindable_uniform - -static GLboolean _glewInit_GL_EXT_bindable_uniform (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetUniformBufferSizeEXT = (PFNGLGETUNIFORMBUFFERSIZEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetUniformBufferSizeEXT")) == NULL) || r; - r = ((glGetUniformOffsetEXT = (PFNGLGETUNIFORMOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glGetUniformOffsetEXT")) == NULL) || r; - r = ((glUniformBufferEXT = (PFNGLUNIFORMBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glUniformBufferEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_bindable_uniform */ - -#ifdef GL_EXT_blend_color - -static GLboolean _glewInit_GL_EXT_blend_color (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendColorEXT = (PFNGLBLENDCOLOREXTPROC)glewGetProcAddress((const GLubyte*)"glBlendColorEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_blend_color */ - -#ifdef GL_EXT_blend_equation_separate - -static GLboolean _glewInit_GL_EXT_blend_equation_separate (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendEquationSeparateEXT = (PFNGLBLENDEQUATIONSEPARATEEXTPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationSeparateEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_blend_equation_separate */ - -#ifdef GL_EXT_blend_func_separate - -static GLboolean _glewInit_GL_EXT_blend_func_separate (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendFuncSeparateEXT = (PFNGLBLENDFUNCSEPARATEEXTPROC)glewGetProcAddress((const GLubyte*)"glBlendFuncSeparateEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_blend_func_separate */ - -#ifdef GL_EXT_blend_logic_op - -#endif /* GL_EXT_blend_logic_op */ - -#ifdef GL_EXT_blend_minmax - -static GLboolean _glewInit_GL_EXT_blend_minmax (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendEquationEXT = (PFNGLBLENDEQUATIONEXTPROC)glewGetProcAddress((const GLubyte*)"glBlendEquationEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_blend_minmax */ - -#ifdef GL_EXT_blend_subtract - -#endif /* GL_EXT_blend_subtract */ - -#ifdef GL_EXT_clip_volume_hint - -#endif /* GL_EXT_clip_volume_hint */ - -#ifdef GL_EXT_cmyka - -#endif /* GL_EXT_cmyka */ - -#ifdef GL_EXT_color_subtable - -static GLboolean _glewInit_GL_EXT_color_subtable (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorSubTableEXT = (PFNGLCOLORSUBTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glColorSubTableEXT")) == NULL) || r; - r = ((glCopyColorSubTableEXT = (PFNGLCOPYCOLORSUBTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyColorSubTableEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_color_subtable */ - -#ifdef GL_EXT_compiled_vertex_array - -static GLboolean _glewInit_GL_EXT_compiled_vertex_array (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glLockArraysEXT = (PFNGLLOCKARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glLockArraysEXT")) == NULL) || r; - r = ((glUnlockArraysEXT = (PFNGLUNLOCKARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glUnlockArraysEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_compiled_vertex_array */ - -#ifdef GL_EXT_convolution - -static GLboolean _glewInit_GL_EXT_convolution (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glConvolutionFilter1DEXT = (PFNGLCONVOLUTIONFILTER1DEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter1DEXT")) == NULL) || r; - r = ((glConvolutionFilter2DEXT = (PFNGLCONVOLUTIONFILTER2DEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionFilter2DEXT")) == NULL) || r; - r = ((glConvolutionParameterfEXT = (PFNGLCONVOLUTIONPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterfEXT")) == NULL) || r; - r = ((glConvolutionParameterfvEXT = (PFNGLCONVOLUTIONPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterfvEXT")) == NULL) || r; - r = ((glConvolutionParameteriEXT = (PFNGLCONVOLUTIONPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameteriEXT")) == NULL) || r; - r = ((glConvolutionParameterivEXT = (PFNGLCONVOLUTIONPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glConvolutionParameterivEXT")) == NULL) || r; - r = ((glCopyConvolutionFilter1DEXT = (PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter1DEXT")) == NULL) || r; - r = ((glCopyConvolutionFilter2DEXT = (PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyConvolutionFilter2DEXT")) == NULL) || r; - r = ((glGetConvolutionFilterEXT = (PFNGLGETCONVOLUTIONFILTEREXTPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionFilterEXT")) == NULL) || r; - r = ((glGetConvolutionParameterfvEXT = (PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameterfvEXT")) == NULL) || r; - r = ((glGetConvolutionParameterivEXT = (PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetConvolutionParameterivEXT")) == NULL) || r; - r = ((glGetSeparableFilterEXT = (PFNGLGETSEPARABLEFILTEREXTPROC)glewGetProcAddress((const GLubyte*)"glGetSeparableFilterEXT")) == NULL) || r; - r = ((glSeparableFilter2DEXT = (PFNGLSEPARABLEFILTER2DEXTPROC)glewGetProcAddress((const GLubyte*)"glSeparableFilter2DEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_convolution */ - -#ifdef GL_EXT_coordinate_frame - -static GLboolean _glewInit_GL_EXT_coordinate_frame (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBinormalPointerEXT = (PFNGLBINORMALPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glBinormalPointerEXT")) == NULL) || r; - r = ((glTangentPointerEXT = (PFNGLTANGENTPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glTangentPointerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_coordinate_frame */ - -#ifdef GL_EXT_copy_texture - -static GLboolean _glewInit_GL_EXT_copy_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCopyTexImage1DEXT = (PFNGLCOPYTEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexImage1DEXT")) == NULL) || r; - r = ((glCopyTexImage2DEXT = (PFNGLCOPYTEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexImage2DEXT")) == NULL) || r; - r = ((glCopyTexSubImage1DEXT = (PFNGLCOPYTEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage1DEXT")) == NULL) || r; - r = ((glCopyTexSubImage2DEXT = (PFNGLCOPYTEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage2DEXT")) == NULL) || r; - r = ((glCopyTexSubImage3DEXT = (PFNGLCOPYTEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTexSubImage3DEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_copy_texture */ - -#ifdef GL_EXT_cull_vertex - -static GLboolean _glewInit_GL_EXT_cull_vertex (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCullParameterdvEXT = (PFNGLCULLPARAMETERDVEXTPROC)glewGetProcAddress((const GLubyte*)"glCullParameterdvEXT")) == NULL) || r; - r = ((glCullParameterfvEXT = (PFNGLCULLPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glCullParameterfvEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_cull_vertex */ - -#ifdef GL_EXT_debug_marker - -static GLboolean _glewInit_GL_EXT_debug_marker (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glInsertEventMarkerEXT = (PFNGLINSERTEVENTMARKEREXTPROC)glewGetProcAddress((const GLubyte*)"glInsertEventMarkerEXT")) == NULL) || r; - r = ((glPopGroupMarkerEXT = (PFNGLPOPGROUPMARKEREXTPROC)glewGetProcAddress((const GLubyte*)"glPopGroupMarkerEXT")) == NULL) || r; - r = ((glPushGroupMarkerEXT = (PFNGLPUSHGROUPMARKEREXTPROC)glewGetProcAddress((const GLubyte*)"glPushGroupMarkerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_debug_marker */ - -#ifdef GL_EXT_depth_bounds_test - -static GLboolean _glewInit_GL_EXT_depth_bounds_test (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDepthBoundsEXT = (PFNGLDEPTHBOUNDSEXTPROC)glewGetProcAddress((const GLubyte*)"glDepthBoundsEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_depth_bounds_test */ - -#ifdef GL_EXT_direct_state_access - -static GLboolean _glewInit_GL_EXT_direct_state_access (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindMultiTextureEXT = (PFNGLBINDMULTITEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glBindMultiTextureEXT")) == NULL) || r; - r = ((glCheckNamedFramebufferStatusEXT = (PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC)glewGetProcAddress((const GLubyte*)"glCheckNamedFramebufferStatusEXT")) == NULL) || r; - r = ((glClientAttribDefaultEXT = (PFNGLCLIENTATTRIBDEFAULTEXTPROC)glewGetProcAddress((const GLubyte*)"glClientAttribDefaultEXT")) == NULL) || r; - r = ((glCompressedMultiTexImage1DEXT = (PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexImage1DEXT")) == NULL) || r; - r = ((glCompressedMultiTexImage2DEXT = (PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexImage2DEXT")) == NULL) || r; - r = ((glCompressedMultiTexImage3DEXT = (PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexImage3DEXT")) == NULL) || r; - r = ((glCompressedMultiTexSubImage1DEXT = (PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexSubImage1DEXT")) == NULL) || r; - r = ((glCompressedMultiTexSubImage2DEXT = (PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexSubImage2DEXT")) == NULL) || r; - r = ((glCompressedMultiTexSubImage3DEXT = (PFNGLCOMPRESSEDMULTITEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedMultiTexSubImage3DEXT")) == NULL) || r; - r = ((glCompressedTextureImage1DEXT = (PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureImage1DEXT")) == NULL) || r; - r = ((glCompressedTextureImage2DEXT = (PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureImage2DEXT")) == NULL) || r; - r = ((glCompressedTextureImage3DEXT = (PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureImage3DEXT")) == NULL) || r; - r = ((glCompressedTextureSubImage1DEXT = (PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureSubImage1DEXT")) == NULL) || r; - r = ((glCompressedTextureSubImage2DEXT = (PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureSubImage2DEXT")) == NULL) || r; - r = ((glCompressedTextureSubImage3DEXT = (PFNGLCOMPRESSEDTEXTURESUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCompressedTextureSubImage3DEXT")) == NULL) || r; - r = ((glCopyMultiTexImage1DEXT = (PFNGLCOPYMULTITEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexImage1DEXT")) == NULL) || r; - r = ((glCopyMultiTexImage2DEXT = (PFNGLCOPYMULTITEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexImage2DEXT")) == NULL) || r; - r = ((glCopyMultiTexSubImage1DEXT = (PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexSubImage1DEXT")) == NULL) || r; - r = ((glCopyMultiTexSubImage2DEXT = (PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexSubImage2DEXT")) == NULL) || r; - r = ((glCopyMultiTexSubImage3DEXT = (PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyMultiTexSubImage3DEXT")) == NULL) || r; - r = ((glCopyTextureImage1DEXT = (PFNGLCOPYTEXTUREIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureImage1DEXT")) == NULL) || r; - r = ((glCopyTextureImage2DEXT = (PFNGLCOPYTEXTUREIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureImage2DEXT")) == NULL) || r; - r = ((glCopyTextureSubImage1DEXT = (PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureSubImage1DEXT")) == NULL) || r; - r = ((glCopyTextureSubImage2DEXT = (PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureSubImage2DEXT")) == NULL) || r; - r = ((glCopyTextureSubImage3DEXT = (PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glCopyTextureSubImage3DEXT")) == NULL) || r; - r = ((glDisableClientStateIndexedEXT = (PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableClientStateIndexedEXT")) == NULL) || r; - r = ((glDisableClientStateiEXT = (PFNGLDISABLECLIENTSTATEIEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableClientStateiEXT")) == NULL) || r; - r = ((glDisableVertexArrayAttribEXT = (PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexArrayAttribEXT")) == NULL) || r; - r = ((glDisableVertexArrayEXT = (PFNGLDISABLEVERTEXARRAYEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableVertexArrayEXT")) == NULL) || r; - r = ((glEnableClientStateIndexedEXT = (PFNGLENABLECLIENTSTATEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableClientStateIndexedEXT")) == NULL) || r; - r = ((glEnableClientStateiEXT = (PFNGLENABLECLIENTSTATEIEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableClientStateiEXT")) == NULL) || r; - r = ((glEnableVertexArrayAttribEXT = (PFNGLENABLEVERTEXARRAYATTRIBEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexArrayAttribEXT")) == NULL) || r; - r = ((glEnableVertexArrayEXT = (PFNGLENABLEVERTEXARRAYEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableVertexArrayEXT")) == NULL) || r; - r = ((glFlushMappedNamedBufferRangeEXT = (PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glFlushMappedNamedBufferRangeEXT")) == NULL) || r; - r = ((glFramebufferDrawBufferEXT = (PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferDrawBufferEXT")) == NULL) || r; - r = ((glFramebufferDrawBuffersEXT = (PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferDrawBuffersEXT")) == NULL) || r; - r = ((glFramebufferReadBufferEXT = (PFNGLFRAMEBUFFERREADBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferReadBufferEXT")) == NULL) || r; - r = ((glGenerateMultiTexMipmapEXT = (PFNGLGENERATEMULTITEXMIPMAPEXTPROC)glewGetProcAddress((const GLubyte*)"glGenerateMultiTexMipmapEXT")) == NULL) || r; - r = ((glGenerateTextureMipmapEXT = (PFNGLGENERATETEXTUREMIPMAPEXTPROC)glewGetProcAddress((const GLubyte*)"glGenerateTextureMipmapEXT")) == NULL) || r; - r = ((glGetCompressedMultiTexImageEXT = (PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedMultiTexImageEXT")) == NULL) || r; - r = ((glGetCompressedTextureImageEXT = (PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetCompressedTextureImageEXT")) == NULL) || r; - r = ((glGetDoubleIndexedvEXT = (PFNGLGETDOUBLEINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetDoubleIndexedvEXT")) == NULL) || r; - r = ((glGetDoublei_vEXT = (PFNGLGETDOUBLEI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetDoublei_vEXT")) == NULL) || r; - r = ((glGetFloatIndexedvEXT = (PFNGLGETFLOATINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFloatIndexedvEXT")) == NULL) || r; - r = ((glGetFloati_vEXT = (PFNGLGETFLOATI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFloati_vEXT")) == NULL) || r; - r = ((glGetFramebufferParameterivEXT = (PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferParameterivEXT")) == NULL) || r; - r = ((glGetMultiTexEnvfvEXT = (PFNGLGETMULTITEXENVFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexEnvfvEXT")) == NULL) || r; - r = ((glGetMultiTexEnvivEXT = (PFNGLGETMULTITEXENVIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexEnvivEXT")) == NULL) || r; - r = ((glGetMultiTexGendvEXT = (PFNGLGETMULTITEXGENDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexGendvEXT")) == NULL) || r; - r = ((glGetMultiTexGenfvEXT = (PFNGLGETMULTITEXGENFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexGenfvEXT")) == NULL) || r; - r = ((glGetMultiTexGenivEXT = (PFNGLGETMULTITEXGENIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexGenivEXT")) == NULL) || r; - r = ((glGetMultiTexImageEXT = (PFNGLGETMULTITEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexImageEXT")) == NULL) || r; - r = ((glGetMultiTexLevelParameterfvEXT = (PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexLevelParameterfvEXT")) == NULL) || r; - r = ((glGetMultiTexLevelParameterivEXT = (PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexLevelParameterivEXT")) == NULL) || r; - r = ((glGetMultiTexParameterIivEXT = (PFNGLGETMULTITEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterIivEXT")) == NULL) || r; - r = ((glGetMultiTexParameterIuivEXT = (PFNGLGETMULTITEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterIuivEXT")) == NULL) || r; - r = ((glGetMultiTexParameterfvEXT = (PFNGLGETMULTITEXPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterfvEXT")) == NULL) || r; - r = ((glGetMultiTexParameterivEXT = (PFNGLGETMULTITEXPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMultiTexParameterivEXT")) == NULL) || r; - r = ((glGetNamedBufferParameterivEXT = (PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferParameterivEXT")) == NULL) || r; - r = ((glGetNamedBufferPointervEXT = (PFNGLGETNAMEDBUFFERPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferPointervEXT")) == NULL) || r; - r = ((glGetNamedBufferSubDataEXT = (PFNGLGETNAMEDBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferSubDataEXT")) == NULL) || r; - r = ((glGetNamedFramebufferAttachmentParameterivEXT = (PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedFramebufferAttachmentParameterivEXT")) == NULL) || r; - r = ((glGetNamedProgramLocalParameterIivEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterIivEXT")) == NULL) || r; - r = ((glGetNamedProgramLocalParameterIuivEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterIuivEXT")) == NULL) || r; - r = ((glGetNamedProgramLocalParameterdvEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterdvEXT")) == NULL) || r; - r = ((glGetNamedProgramLocalParameterfvEXT = (PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramLocalParameterfvEXT")) == NULL) || r; - r = ((glGetNamedProgramStringEXT = (PFNGLGETNAMEDPROGRAMSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramStringEXT")) == NULL) || r; - r = ((glGetNamedProgramivEXT = (PFNGLGETNAMEDPROGRAMIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedProgramivEXT")) == NULL) || r; - r = ((glGetNamedRenderbufferParameterivEXT = (PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetNamedRenderbufferParameterivEXT")) == NULL) || r; - r = ((glGetPointerIndexedvEXT = (PFNGLGETPOINTERINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPointerIndexedvEXT")) == NULL) || r; - r = ((glGetPointeri_vEXT = (PFNGLGETPOINTERI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPointeri_vEXT")) == NULL) || r; - r = ((glGetTextureImageEXT = (PFNGLGETTEXTUREIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureImageEXT")) == NULL) || r; - r = ((glGetTextureLevelParameterfvEXT = (PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureLevelParameterfvEXT")) == NULL) || r; - r = ((glGetTextureLevelParameterivEXT = (PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureLevelParameterivEXT")) == NULL) || r; - r = ((glGetTextureParameterIivEXT = (PFNGLGETTEXTUREPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterIivEXT")) == NULL) || r; - r = ((glGetTextureParameterIuivEXT = (PFNGLGETTEXTUREPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterIuivEXT")) == NULL) || r; - r = ((glGetTextureParameterfvEXT = (PFNGLGETTEXTUREPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterfvEXT")) == NULL) || r; - r = ((glGetTextureParameterivEXT = (PFNGLGETTEXTUREPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTextureParameterivEXT")) == NULL) || r; - r = ((glGetVertexArrayIntegeri_vEXT = (PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayIntegeri_vEXT")) == NULL) || r; - r = ((glGetVertexArrayIntegervEXT = (PFNGLGETVERTEXARRAYINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayIntegervEXT")) == NULL) || r; - r = ((glGetVertexArrayPointeri_vEXT = (PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayPointeri_vEXT")) == NULL) || r; - r = ((glGetVertexArrayPointervEXT = (PFNGLGETVERTEXARRAYPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexArrayPointervEXT")) == NULL) || r; - r = ((glMapNamedBufferEXT = (PFNGLMAPNAMEDBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glMapNamedBufferEXT")) == NULL) || r; - r = ((glMapNamedBufferRangeEXT = (PFNGLMAPNAMEDBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glMapNamedBufferRangeEXT")) == NULL) || r; - r = ((glMatrixFrustumEXT = (PFNGLMATRIXFRUSTUMEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixFrustumEXT")) == NULL) || r; - r = ((glMatrixLoadIdentityEXT = (PFNGLMATRIXLOADIDENTITYEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadIdentityEXT")) == NULL) || r; - r = ((glMatrixLoadTransposedEXT = (PFNGLMATRIXLOADTRANSPOSEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadTransposedEXT")) == NULL) || r; - r = ((glMatrixLoadTransposefEXT = (PFNGLMATRIXLOADTRANSPOSEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadTransposefEXT")) == NULL) || r; - r = ((glMatrixLoaddEXT = (PFNGLMATRIXLOADDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoaddEXT")) == NULL) || r; - r = ((glMatrixLoadfEXT = (PFNGLMATRIXLOADFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixLoadfEXT")) == NULL) || r; - r = ((glMatrixMultTransposedEXT = (PFNGLMATRIXMULTTRANSPOSEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultTransposedEXT")) == NULL) || r; - r = ((glMatrixMultTransposefEXT = (PFNGLMATRIXMULTTRANSPOSEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultTransposefEXT")) == NULL) || r; - r = ((glMatrixMultdEXT = (PFNGLMATRIXMULTDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultdEXT")) == NULL) || r; - r = ((glMatrixMultfEXT = (PFNGLMATRIXMULTFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixMultfEXT")) == NULL) || r; - r = ((glMatrixOrthoEXT = (PFNGLMATRIXORTHOEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixOrthoEXT")) == NULL) || r; - r = ((glMatrixPopEXT = (PFNGLMATRIXPOPEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixPopEXT")) == NULL) || r; - r = ((glMatrixPushEXT = (PFNGLMATRIXPUSHEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixPushEXT")) == NULL) || r; - r = ((glMatrixRotatedEXT = (PFNGLMATRIXROTATEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixRotatedEXT")) == NULL) || r; - r = ((glMatrixRotatefEXT = (PFNGLMATRIXROTATEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixRotatefEXT")) == NULL) || r; - r = ((glMatrixScaledEXT = (PFNGLMATRIXSCALEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixScaledEXT")) == NULL) || r; - r = ((glMatrixScalefEXT = (PFNGLMATRIXSCALEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixScalefEXT")) == NULL) || r; - r = ((glMatrixTranslatedEXT = (PFNGLMATRIXTRANSLATEDEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixTranslatedEXT")) == NULL) || r; - r = ((glMatrixTranslatefEXT = (PFNGLMATRIXTRANSLATEFEXTPROC)glewGetProcAddress((const GLubyte*)"glMatrixTranslatefEXT")) == NULL) || r; - r = ((glMultiTexBufferEXT = (PFNGLMULTITEXBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexBufferEXT")) == NULL) || r; - r = ((glMultiTexCoordPointerEXT = (PFNGLMULTITEXCOORDPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoordPointerEXT")) == NULL) || r; - r = ((glMultiTexEnvfEXT = (PFNGLMULTITEXENVFEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnvfEXT")) == NULL) || r; - r = ((glMultiTexEnvfvEXT = (PFNGLMULTITEXENVFVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnvfvEXT")) == NULL) || r; - r = ((glMultiTexEnviEXT = (PFNGLMULTITEXENVIEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnviEXT")) == NULL) || r; - r = ((glMultiTexEnvivEXT = (PFNGLMULTITEXENVIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexEnvivEXT")) == NULL) || r; - r = ((glMultiTexGendEXT = (PFNGLMULTITEXGENDEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGendEXT")) == NULL) || r; - r = ((glMultiTexGendvEXT = (PFNGLMULTITEXGENDVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGendvEXT")) == NULL) || r; - r = ((glMultiTexGenfEXT = (PFNGLMULTITEXGENFEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGenfEXT")) == NULL) || r; - r = ((glMultiTexGenfvEXT = (PFNGLMULTITEXGENFVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGenfvEXT")) == NULL) || r; - r = ((glMultiTexGeniEXT = (PFNGLMULTITEXGENIEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGeniEXT")) == NULL) || r; - r = ((glMultiTexGenivEXT = (PFNGLMULTITEXGENIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexGenivEXT")) == NULL) || r; - r = ((glMultiTexImage1DEXT = (PFNGLMULTITEXIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexImage1DEXT")) == NULL) || r; - r = ((glMultiTexImage2DEXT = (PFNGLMULTITEXIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexImage2DEXT")) == NULL) || r; - r = ((glMultiTexImage3DEXT = (PFNGLMULTITEXIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexImage3DEXT")) == NULL) || r; - r = ((glMultiTexParameterIivEXT = (PFNGLMULTITEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterIivEXT")) == NULL) || r; - r = ((glMultiTexParameterIuivEXT = (PFNGLMULTITEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterIuivEXT")) == NULL) || r; - r = ((glMultiTexParameterfEXT = (PFNGLMULTITEXPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterfEXT")) == NULL) || r; - r = ((glMultiTexParameterfvEXT = (PFNGLMULTITEXPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterfvEXT")) == NULL) || r; - r = ((glMultiTexParameteriEXT = (PFNGLMULTITEXPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameteriEXT")) == NULL) || r; - r = ((glMultiTexParameterivEXT = (PFNGLMULTITEXPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexParameterivEXT")) == NULL) || r; - r = ((glMultiTexRenderbufferEXT = (PFNGLMULTITEXRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexRenderbufferEXT")) == NULL) || r; - r = ((glMultiTexSubImage1DEXT = (PFNGLMULTITEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexSubImage1DEXT")) == NULL) || r; - r = ((glMultiTexSubImage2DEXT = (PFNGLMULTITEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexSubImage2DEXT")) == NULL) || r; - r = ((glMultiTexSubImage3DEXT = (PFNGLMULTITEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiTexSubImage3DEXT")) == NULL) || r; - r = ((glNamedBufferDataEXT = (PFNGLNAMEDBUFFERDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedBufferDataEXT")) == NULL) || r; - r = ((glNamedBufferSubDataEXT = (PFNGLNAMEDBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedBufferSubDataEXT")) == NULL) || r; - r = ((glNamedCopyBufferSubDataEXT = (PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedCopyBufferSubDataEXT")) == NULL) || r; - r = ((glNamedFramebufferRenderbufferEXT = (PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferRenderbufferEXT")) == NULL) || r; - r = ((glNamedFramebufferTexture1DEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTexture1DEXT")) == NULL) || r; - r = ((glNamedFramebufferTexture2DEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTexture2DEXT")) == NULL) || r; - r = ((glNamedFramebufferTexture3DEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTexture3DEXT")) == NULL) || r; - r = ((glNamedFramebufferTextureEXT = (PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTextureEXT")) == NULL) || r; - r = ((glNamedFramebufferTextureFaceEXT = (PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTextureFaceEXT")) == NULL) || r; - r = ((glNamedFramebufferTextureLayerEXT = (PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC)glewGetProcAddress((const GLubyte*)"glNamedFramebufferTextureLayerEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameter4dEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4dEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameter4dvEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4dvEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameter4fEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4fEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameter4fvEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameter4fvEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameterI4iEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4iEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameterI4ivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4ivEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameterI4uiEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4uiEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameterI4uivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameterI4uivEXT")) == NULL) || r; - r = ((glNamedProgramLocalParameters4fvEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParameters4fvEXT")) == NULL) || r; - r = ((glNamedProgramLocalParametersI4ivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParametersI4ivEXT")) == NULL) || r; - r = ((glNamedProgramLocalParametersI4uivEXT = (PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramLocalParametersI4uivEXT")) == NULL) || r; - r = ((glNamedProgramStringEXT = (PFNGLNAMEDPROGRAMSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedProgramStringEXT")) == NULL) || r; - r = ((glNamedRenderbufferStorageEXT = (PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedRenderbufferStorageEXT")) == NULL) || r; - r = ((glNamedRenderbufferStorageMultisampleCoverageEXT = (PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedRenderbufferStorageMultisampleCoverageEXT")) == NULL) || r; - r = ((glNamedRenderbufferStorageMultisampleEXT = (PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC)glewGetProcAddress((const GLubyte*)"glNamedRenderbufferStorageMultisampleEXT")) == NULL) || r; - r = ((glProgramUniform1fEXT = (PFNGLPROGRAMUNIFORM1FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1fEXT")) == NULL) || r; - r = ((glProgramUniform1fvEXT = (PFNGLPROGRAMUNIFORM1FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1fvEXT")) == NULL) || r; - r = ((glProgramUniform1iEXT = (PFNGLPROGRAMUNIFORM1IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1iEXT")) == NULL) || r; - r = ((glProgramUniform1ivEXT = (PFNGLPROGRAMUNIFORM1IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ivEXT")) == NULL) || r; - r = ((glProgramUniform1uiEXT = (PFNGLPROGRAMUNIFORM1UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1uiEXT")) == NULL) || r; - r = ((glProgramUniform1uivEXT = (PFNGLPROGRAMUNIFORM1UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1uivEXT")) == NULL) || r; - r = ((glProgramUniform2fEXT = (PFNGLPROGRAMUNIFORM2FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2fEXT")) == NULL) || r; - r = ((glProgramUniform2fvEXT = (PFNGLPROGRAMUNIFORM2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2fvEXT")) == NULL) || r; - r = ((glProgramUniform2iEXT = (PFNGLPROGRAMUNIFORM2IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2iEXT")) == NULL) || r; - r = ((glProgramUniform2ivEXT = (PFNGLPROGRAMUNIFORM2IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ivEXT")) == NULL) || r; - r = ((glProgramUniform2uiEXT = (PFNGLPROGRAMUNIFORM2UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2uiEXT")) == NULL) || r; - r = ((glProgramUniform2uivEXT = (PFNGLPROGRAMUNIFORM2UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2uivEXT")) == NULL) || r; - r = ((glProgramUniform3fEXT = (PFNGLPROGRAMUNIFORM3FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3fEXT")) == NULL) || r; - r = ((glProgramUniform3fvEXT = (PFNGLPROGRAMUNIFORM3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3fvEXT")) == NULL) || r; - r = ((glProgramUniform3iEXT = (PFNGLPROGRAMUNIFORM3IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3iEXT")) == NULL) || r; - r = ((glProgramUniform3ivEXT = (PFNGLPROGRAMUNIFORM3IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ivEXT")) == NULL) || r; - r = ((glProgramUniform3uiEXT = (PFNGLPROGRAMUNIFORM3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3uiEXT")) == NULL) || r; - r = ((glProgramUniform3uivEXT = (PFNGLPROGRAMUNIFORM3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3uivEXT")) == NULL) || r; - r = ((glProgramUniform4fEXT = (PFNGLPROGRAMUNIFORM4FEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4fEXT")) == NULL) || r; - r = ((glProgramUniform4fvEXT = (PFNGLPROGRAMUNIFORM4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4fvEXT")) == NULL) || r; - r = ((glProgramUniform4iEXT = (PFNGLPROGRAMUNIFORM4IEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4iEXT")) == NULL) || r; - r = ((glProgramUniform4ivEXT = (PFNGLPROGRAMUNIFORM4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ivEXT")) == NULL) || r; - r = ((glProgramUniform4uiEXT = (PFNGLPROGRAMUNIFORM4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4uiEXT")) == NULL) || r; - r = ((glProgramUniform4uivEXT = (PFNGLPROGRAMUNIFORM4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4uivEXT")) == NULL) || r; - r = ((glProgramUniformMatrix2fvEXT = (PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix2x3fvEXT = (PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x3fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix2x4fvEXT = (PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix2x4fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix3fvEXT = (PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix3x2fvEXT = (PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x2fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix3x4fvEXT = (PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix3x4fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix4fvEXT = (PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix4x2fvEXT = (PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x2fvEXT")) == NULL) || r; - r = ((glProgramUniformMatrix4x3fvEXT = (PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformMatrix4x3fvEXT")) == NULL) || r; - r = ((glPushClientAttribDefaultEXT = (PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC)glewGetProcAddress((const GLubyte*)"glPushClientAttribDefaultEXT")) == NULL) || r; - r = ((glTextureBufferEXT = (PFNGLTEXTUREBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glTextureBufferEXT")) == NULL) || r; - r = ((glTextureImage1DEXT = (PFNGLTEXTUREIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureImage1DEXT")) == NULL) || r; - r = ((glTextureImage2DEXT = (PFNGLTEXTUREIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureImage2DEXT")) == NULL) || r; - r = ((glTextureImage3DEXT = (PFNGLTEXTUREIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureImage3DEXT")) == NULL) || r; - r = ((glTextureParameterIivEXT = (PFNGLTEXTUREPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterIivEXT")) == NULL) || r; - r = ((glTextureParameterIuivEXT = (PFNGLTEXTUREPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterIuivEXT")) == NULL) || r; - r = ((glTextureParameterfEXT = (PFNGLTEXTUREPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterfEXT")) == NULL) || r; - r = ((glTextureParameterfvEXT = (PFNGLTEXTUREPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterfvEXT")) == NULL) || r; - r = ((glTextureParameteriEXT = (PFNGLTEXTUREPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameteriEXT")) == NULL) || r; - r = ((glTextureParameterivEXT = (PFNGLTEXTUREPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureParameterivEXT")) == NULL) || r; - r = ((glTextureRenderbufferEXT = (PFNGLTEXTURERENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glTextureRenderbufferEXT")) == NULL) || r; - r = ((glTextureSubImage1DEXT = (PFNGLTEXTURESUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureSubImage1DEXT")) == NULL) || r; - r = ((glTextureSubImage2DEXT = (PFNGLTEXTURESUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureSubImage2DEXT")) == NULL) || r; - r = ((glTextureSubImage3DEXT = (PFNGLTEXTURESUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureSubImage3DEXT")) == NULL) || r; - r = ((glUnmapNamedBufferEXT = (PFNGLUNMAPNAMEDBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glUnmapNamedBufferEXT")) == NULL) || r; - r = ((glVertexArrayColorOffsetEXT = (PFNGLVERTEXARRAYCOLOROFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayColorOffsetEXT")) == NULL) || r; - r = ((glVertexArrayEdgeFlagOffsetEXT = (PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayEdgeFlagOffsetEXT")) == NULL) || r; - r = ((glVertexArrayFogCoordOffsetEXT = (PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayFogCoordOffsetEXT")) == NULL) || r; - r = ((glVertexArrayIndexOffsetEXT = (PFNGLVERTEXARRAYINDEXOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayIndexOffsetEXT")) == NULL) || r; - r = ((glVertexArrayMultiTexCoordOffsetEXT = (PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayMultiTexCoordOffsetEXT")) == NULL) || r; - r = ((glVertexArrayNormalOffsetEXT = (PFNGLVERTEXARRAYNORMALOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayNormalOffsetEXT")) == NULL) || r; - r = ((glVertexArraySecondaryColorOffsetEXT = (PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArraySecondaryColorOffsetEXT")) == NULL) || r; - r = ((glVertexArrayTexCoordOffsetEXT = (PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayTexCoordOffsetEXT")) == NULL) || r; - r = ((glVertexArrayVertexAttribIOffsetEXT = (PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexAttribIOffsetEXT")) == NULL) || r; - r = ((glVertexArrayVertexAttribOffsetEXT = (PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexAttribOffsetEXT")) == NULL) || r; - r = ((glVertexArrayVertexOffsetEXT = (PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexOffsetEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_direct_state_access */ - -#ifdef GL_EXT_draw_buffers2 - -static GLboolean _glewInit_GL_EXT_draw_buffers2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorMaskIndexedEXT = (PFNGLCOLORMASKINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glColorMaskIndexedEXT")) == NULL) || r; - r = ((glDisableIndexedEXT = (PFNGLDISABLEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableIndexedEXT")) == NULL) || r; - r = ((glEnableIndexedEXT = (PFNGLENABLEINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableIndexedEXT")) == NULL) || r; - r = ((glGetBooleanIndexedvEXT = (PFNGLGETBOOLEANINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetBooleanIndexedvEXT")) == NULL) || r; - r = ((glGetIntegerIndexedvEXT = (PFNGLGETINTEGERINDEXEDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetIntegerIndexedvEXT")) == NULL) || r; - r = ((glIsEnabledIndexedEXT = (PFNGLISENABLEDINDEXEDEXTPROC)glewGetProcAddress((const GLubyte*)"glIsEnabledIndexedEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_draw_buffers2 */ - -#ifdef GL_EXT_draw_instanced - -static GLboolean _glewInit_GL_EXT_draw_instanced (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawArraysInstancedEXT = (PFNGLDRAWARRAYSINSTANCEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysInstancedEXT")) == NULL) || r; - r = ((glDrawElementsInstancedEXT = (PFNGLDRAWELEMENTSINSTANCEDEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawElementsInstancedEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_draw_instanced */ - -#ifdef GL_EXT_draw_range_elements - -static GLboolean _glewInit_GL_EXT_draw_range_elements (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawRangeElementsEXT = (PFNGLDRAWRANGEELEMENTSEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawRangeElementsEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_draw_range_elements */ - -#ifdef GL_EXT_fog_coord - -static GLboolean _glewInit_GL_EXT_fog_coord (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFogCoordPointerEXT = (PFNGLFOGCOORDPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoordPointerEXT")) == NULL) || r; - r = ((glFogCoorddEXT = (PFNGLFOGCOORDDEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoorddEXT")) == NULL) || r; - r = ((glFogCoorddvEXT = (PFNGLFOGCOORDDVEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoorddvEXT")) == NULL) || r; - r = ((glFogCoordfEXT = (PFNGLFOGCOORDFEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoordfEXT")) == NULL) || r; - r = ((glFogCoordfvEXT = (PFNGLFOGCOORDFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFogCoordfvEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_fog_coord */ - -#ifdef GL_EXT_fragment_lighting - -static GLboolean _glewInit_GL_EXT_fragment_lighting (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFragmentColorMaterialEXT = (PFNGLFRAGMENTCOLORMATERIALEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentColorMaterialEXT")) == NULL) || r; - r = ((glFragmentLightModelfEXT = (PFNGLFRAGMENTLIGHTMODELFEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfEXT")) == NULL) || r; - r = ((glFragmentLightModelfvEXT = (PFNGLFRAGMENTLIGHTMODELFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfvEXT")) == NULL) || r; - r = ((glFragmentLightModeliEXT = (PFNGLFRAGMENTLIGHTMODELIEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModeliEXT")) == NULL) || r; - r = ((glFragmentLightModelivEXT = (PFNGLFRAGMENTLIGHTMODELIVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelivEXT")) == NULL) || r; - r = ((glFragmentLightfEXT = (PFNGLFRAGMENTLIGHTFEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfEXT")) == NULL) || r; - r = ((glFragmentLightfvEXT = (PFNGLFRAGMENTLIGHTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfvEXT")) == NULL) || r; - r = ((glFragmentLightiEXT = (PFNGLFRAGMENTLIGHTIEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightiEXT")) == NULL) || r; - r = ((glFragmentLightivEXT = (PFNGLFRAGMENTLIGHTIVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightivEXT")) == NULL) || r; - r = ((glFragmentMaterialfEXT = (PFNGLFRAGMENTMATERIALFEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfEXT")) == NULL) || r; - r = ((glFragmentMaterialfvEXT = (PFNGLFRAGMENTMATERIALFVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfvEXT")) == NULL) || r; - r = ((glFragmentMaterialiEXT = (PFNGLFRAGMENTMATERIALIEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialiEXT")) == NULL) || r; - r = ((glFragmentMaterialivEXT = (PFNGLFRAGMENTMATERIALIVEXTPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialivEXT")) == NULL) || r; - r = ((glGetFragmentLightfvEXT = (PFNGLGETFRAGMENTLIGHTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightfvEXT")) == NULL) || r; - r = ((glGetFragmentLightivEXT = (PFNGLGETFRAGMENTLIGHTIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightivEXT")) == NULL) || r; - r = ((glGetFragmentMaterialfvEXT = (PFNGLGETFRAGMENTMATERIALFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialfvEXT")) == NULL) || r; - r = ((glGetFragmentMaterialivEXT = (PFNGLGETFRAGMENTMATERIALIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialivEXT")) == NULL) || r; - r = ((glLightEnviEXT = (PFNGLLIGHTENVIEXTPROC)glewGetProcAddress((const GLubyte*)"glLightEnviEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_fragment_lighting */ - -#ifdef GL_EXT_framebuffer_blit - -static GLboolean _glewInit_GL_EXT_framebuffer_blit (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlitFramebufferEXT = (PFNGLBLITFRAMEBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glBlitFramebufferEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_framebuffer_blit */ - -#ifdef GL_EXT_framebuffer_multisample - -static GLboolean _glewInit_GL_EXT_framebuffer_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glRenderbufferStorageMultisampleEXT = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisampleEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_framebuffer_multisample */ - -#ifdef GL_EXT_framebuffer_multisample_blit_scaled - -#endif /* GL_EXT_framebuffer_multisample_blit_scaled */ - -#ifdef GL_EXT_framebuffer_object - -static GLboolean _glewInit_GL_EXT_framebuffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindFramebufferEXT = (PFNGLBINDFRAMEBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindFramebufferEXT")) == NULL) || r; - r = ((glBindRenderbufferEXT = (PFNGLBINDRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindRenderbufferEXT")) == NULL) || r; - r = ((glCheckFramebufferStatusEXT = (PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC)glewGetProcAddress((const GLubyte*)"glCheckFramebufferStatusEXT")) == NULL) || r; - r = ((glDeleteFramebuffersEXT = (PFNGLDELETEFRAMEBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteFramebuffersEXT")) == NULL) || r; - r = ((glDeleteRenderbuffersEXT = (PFNGLDELETERENDERBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteRenderbuffersEXT")) == NULL) || r; - r = ((glFramebufferRenderbufferEXT = (PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferRenderbufferEXT")) == NULL) || r; - r = ((glFramebufferTexture1DEXT = (PFNGLFRAMEBUFFERTEXTURE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture1DEXT")) == NULL) || r; - r = ((glFramebufferTexture2DEXT = (PFNGLFRAMEBUFFERTEXTURE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture2DEXT")) == NULL) || r; - r = ((glFramebufferTexture3DEXT = (PFNGLFRAMEBUFFERTEXTURE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTexture3DEXT")) == NULL) || r; - r = ((glGenFramebuffersEXT = (PFNGLGENFRAMEBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenFramebuffersEXT")) == NULL) || r; - r = ((glGenRenderbuffersEXT = (PFNGLGENRENDERBUFFERSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenRenderbuffersEXT")) == NULL) || r; - r = ((glGenerateMipmapEXT = (PFNGLGENERATEMIPMAPEXTPROC)glewGetProcAddress((const GLubyte*)"glGenerateMipmapEXT")) == NULL) || r; - r = ((glGetFramebufferAttachmentParameterivEXT = (PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFramebufferAttachmentParameterivEXT")) == NULL) || r; - r = ((glGetRenderbufferParameterivEXT = (PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetRenderbufferParameterivEXT")) == NULL) || r; - r = ((glIsFramebufferEXT = (PFNGLISFRAMEBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glIsFramebufferEXT")) == NULL) || r; - r = ((glIsRenderbufferEXT = (PFNGLISRENDERBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glIsRenderbufferEXT")) == NULL) || r; - r = ((glRenderbufferStorageEXT = (PFNGLRENDERBUFFERSTORAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_framebuffer_object */ - -#ifdef GL_EXT_framebuffer_sRGB - -#endif /* GL_EXT_framebuffer_sRGB */ - -#ifdef GL_EXT_geometry_shader4 - -static GLboolean _glewInit_GL_EXT_geometry_shader4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFramebufferTextureEXT = (PFNGLFRAMEBUFFERTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureEXT")) == NULL) || r; - r = ((glFramebufferTextureFaceEXT = (PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureFaceEXT")) == NULL) || r; - r = ((glProgramParameteriEXT = (PFNGLPROGRAMPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramParameteriEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_geometry_shader4 */ - -#ifdef GL_EXT_gpu_program_parameters - -static GLboolean _glewInit_GL_EXT_gpu_program_parameters (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glProgramEnvParameters4fvEXT = (PFNGLPROGRAMENVPARAMETERS4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameters4fvEXT")) == NULL) || r; - r = ((glProgramLocalParameters4fvEXT = (PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameters4fvEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_gpu_program_parameters */ - -#ifdef GL_EXT_gpu_shader4 - -static GLboolean _glewInit_GL_EXT_gpu_shader4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindFragDataLocationEXT = (PFNGLBINDFRAGDATALOCATIONEXTPROC)glewGetProcAddress((const GLubyte*)"glBindFragDataLocationEXT")) == NULL) || r; - r = ((glGetFragDataLocationEXT = (PFNGLGETFRAGDATALOCATIONEXTPROC)glewGetProcAddress((const GLubyte*)"glGetFragDataLocationEXT")) == NULL) || r; - r = ((glGetUniformuivEXT = (PFNGLGETUNIFORMUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetUniformuivEXT")) == NULL) || r; - r = ((glGetVertexAttribIivEXT = (PFNGLGETVERTEXATTRIBIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIivEXT")) == NULL) || r; - r = ((glGetVertexAttribIuivEXT = (PFNGLGETVERTEXATTRIBIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribIuivEXT")) == NULL) || r; - r = ((glUniform1uiEXT = (PFNGLUNIFORM1UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform1uiEXT")) == NULL) || r; - r = ((glUniform1uivEXT = (PFNGLUNIFORM1UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform1uivEXT")) == NULL) || r; - r = ((glUniform2uiEXT = (PFNGLUNIFORM2UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform2uiEXT")) == NULL) || r; - r = ((glUniform2uivEXT = (PFNGLUNIFORM2UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform2uivEXT")) == NULL) || r; - r = ((glUniform3uiEXT = (PFNGLUNIFORM3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform3uiEXT")) == NULL) || r; - r = ((glUniform3uivEXT = (PFNGLUNIFORM3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform3uivEXT")) == NULL) || r; - r = ((glUniform4uiEXT = (PFNGLUNIFORM4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform4uiEXT")) == NULL) || r; - r = ((glUniform4uivEXT = (PFNGLUNIFORM4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glUniform4uivEXT")) == NULL) || r; - r = ((glVertexAttribI1iEXT = (PFNGLVERTEXATTRIBI1IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1iEXT")) == NULL) || r; - r = ((glVertexAttribI1ivEXT = (PFNGLVERTEXATTRIBI1IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1ivEXT")) == NULL) || r; - r = ((glVertexAttribI1uiEXT = (PFNGLVERTEXATTRIBI1UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1uiEXT")) == NULL) || r; - r = ((glVertexAttribI1uivEXT = (PFNGLVERTEXATTRIBI1UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI1uivEXT")) == NULL) || r; - r = ((glVertexAttribI2iEXT = (PFNGLVERTEXATTRIBI2IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2iEXT")) == NULL) || r; - r = ((glVertexAttribI2ivEXT = (PFNGLVERTEXATTRIBI2IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2ivEXT")) == NULL) || r; - r = ((glVertexAttribI2uiEXT = (PFNGLVERTEXATTRIBI2UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2uiEXT")) == NULL) || r; - r = ((glVertexAttribI2uivEXT = (PFNGLVERTEXATTRIBI2UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI2uivEXT")) == NULL) || r; - r = ((glVertexAttribI3iEXT = (PFNGLVERTEXATTRIBI3IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3iEXT")) == NULL) || r; - r = ((glVertexAttribI3ivEXT = (PFNGLVERTEXATTRIBI3IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3ivEXT")) == NULL) || r; - r = ((glVertexAttribI3uiEXT = (PFNGLVERTEXATTRIBI3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3uiEXT")) == NULL) || r; - r = ((glVertexAttribI3uivEXT = (PFNGLVERTEXATTRIBI3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI3uivEXT")) == NULL) || r; - r = ((glVertexAttribI4bvEXT = (PFNGLVERTEXATTRIBI4BVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4bvEXT")) == NULL) || r; - r = ((glVertexAttribI4iEXT = (PFNGLVERTEXATTRIBI4IEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4iEXT")) == NULL) || r; - r = ((glVertexAttribI4ivEXT = (PFNGLVERTEXATTRIBI4IVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ivEXT")) == NULL) || r; - r = ((glVertexAttribI4svEXT = (PFNGLVERTEXATTRIBI4SVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4svEXT")) == NULL) || r; - r = ((glVertexAttribI4ubvEXT = (PFNGLVERTEXATTRIBI4UBVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4ubvEXT")) == NULL) || r; - r = ((glVertexAttribI4uiEXT = (PFNGLVERTEXATTRIBI4UIEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4uiEXT")) == NULL) || r; - r = ((glVertexAttribI4uivEXT = (PFNGLVERTEXATTRIBI4UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4uivEXT")) == NULL) || r; - r = ((glVertexAttribI4usvEXT = (PFNGLVERTEXATTRIBI4USVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribI4usvEXT")) == NULL) || r; - r = ((glVertexAttribIPointerEXT = (PFNGLVERTEXATTRIBIPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIPointerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_gpu_shader4 */ - -#ifdef GL_EXT_histogram - -static GLboolean _glewInit_GL_EXT_histogram (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetHistogramEXT = (PFNGLGETHISTOGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramEXT")) == NULL) || r; - r = ((glGetHistogramParameterfvEXT = (PFNGLGETHISTOGRAMPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameterfvEXT")) == NULL) || r; - r = ((glGetHistogramParameterivEXT = (PFNGLGETHISTOGRAMPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetHistogramParameterivEXT")) == NULL) || r; - r = ((glGetMinmaxEXT = (PFNGLGETMINMAXEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxEXT")) == NULL) || r; - r = ((glGetMinmaxParameterfvEXT = (PFNGLGETMINMAXPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameterfvEXT")) == NULL) || r; - r = ((glGetMinmaxParameterivEXT = (PFNGLGETMINMAXPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetMinmaxParameterivEXT")) == NULL) || r; - r = ((glHistogramEXT = (PFNGLHISTOGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glHistogramEXT")) == NULL) || r; - r = ((glMinmaxEXT = (PFNGLMINMAXEXTPROC)glewGetProcAddress((const GLubyte*)"glMinmaxEXT")) == NULL) || r; - r = ((glResetHistogramEXT = (PFNGLRESETHISTOGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glResetHistogramEXT")) == NULL) || r; - r = ((glResetMinmaxEXT = (PFNGLRESETMINMAXEXTPROC)glewGetProcAddress((const GLubyte*)"glResetMinmaxEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_histogram */ - -#ifdef GL_EXT_index_array_formats - -#endif /* GL_EXT_index_array_formats */ - -#ifdef GL_EXT_index_func - -static GLboolean _glewInit_GL_EXT_index_func (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glIndexFuncEXT = (PFNGLINDEXFUNCEXTPROC)glewGetProcAddress((const GLubyte*)"glIndexFuncEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_index_func */ - -#ifdef GL_EXT_index_material - -static GLboolean _glewInit_GL_EXT_index_material (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glIndexMaterialEXT = (PFNGLINDEXMATERIALEXTPROC)glewGetProcAddress((const GLubyte*)"glIndexMaterialEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_index_material */ - -#ifdef GL_EXT_index_texture - -#endif /* GL_EXT_index_texture */ - -#ifdef GL_EXT_light_texture - -static GLboolean _glewInit_GL_EXT_light_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glApplyTextureEXT = (PFNGLAPPLYTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glApplyTextureEXT")) == NULL) || r; - r = ((glTextureLightEXT = (PFNGLTEXTURELIGHTEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureLightEXT")) == NULL) || r; - r = ((glTextureMaterialEXT = (PFNGLTEXTUREMATERIALEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureMaterialEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_light_texture */ - -#ifdef GL_EXT_misc_attribute - -#endif /* GL_EXT_misc_attribute */ - -#ifdef GL_EXT_multi_draw_arrays - -static GLboolean _glewInit_GL_EXT_multi_draw_arrays (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMultiDrawArraysEXT = (PFNGLMULTIDRAWARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArraysEXT")) == NULL) || r; - r = ((glMultiDrawElementsEXT = (PFNGLMULTIDRAWELEMENTSEXTPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_multi_draw_arrays */ - -#ifdef GL_EXT_multisample - -static GLboolean _glewInit_GL_EXT_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glSampleMaskEXT = (PFNGLSAMPLEMASKEXTPROC)glewGetProcAddress((const GLubyte*)"glSampleMaskEXT")) == NULL) || r; - r = ((glSamplePatternEXT = (PFNGLSAMPLEPATTERNEXTPROC)glewGetProcAddress((const GLubyte*)"glSamplePatternEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_multisample */ - -#ifdef GL_EXT_packed_depth_stencil - -#endif /* GL_EXT_packed_depth_stencil */ - -#ifdef GL_EXT_packed_float - -#endif /* GL_EXT_packed_float */ - -#ifdef GL_EXT_packed_pixels - -#endif /* GL_EXT_packed_pixels */ - -#ifdef GL_EXT_paletted_texture - -static GLboolean _glewInit_GL_EXT_paletted_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorTableEXT = (PFNGLCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glColorTableEXT")) == NULL) || r; - r = ((glGetColorTableEXT = (PFNGLGETCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableEXT")) == NULL) || r; - r = ((glGetColorTableParameterfvEXT = (PFNGLGETCOLORTABLEPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterfvEXT")) == NULL) || r; - r = ((glGetColorTableParameterivEXT = (PFNGLGETCOLORTABLEPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterivEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_paletted_texture */ - -#ifdef GL_EXT_pixel_buffer_object - -#endif /* GL_EXT_pixel_buffer_object */ - -#ifdef GL_EXT_pixel_transform - -static GLboolean _glewInit_GL_EXT_pixel_transform (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetPixelTransformParameterfvEXT = (PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPixelTransformParameterfvEXT")) == NULL) || r; - r = ((glGetPixelTransformParameterivEXT = (PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetPixelTransformParameterivEXT")) == NULL) || r; - r = ((glPixelTransformParameterfEXT = (PFNGLPIXELTRANSFORMPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameterfEXT")) == NULL) || r; - r = ((glPixelTransformParameterfvEXT = (PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameterfvEXT")) == NULL) || r; - r = ((glPixelTransformParameteriEXT = (PFNGLPIXELTRANSFORMPARAMETERIEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameteriEXT")) == NULL) || r; - r = ((glPixelTransformParameterivEXT = (PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC)glewGetProcAddress((const GLubyte*)"glPixelTransformParameterivEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_pixel_transform */ - -#ifdef GL_EXT_pixel_transform_color_table - -#endif /* GL_EXT_pixel_transform_color_table */ - -#ifdef GL_EXT_point_parameters - -static GLboolean _glewInit_GL_EXT_point_parameters (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPointParameterfEXT = (PFNGLPOINTPARAMETERFEXTPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfEXT")) == NULL) || r; - r = ((glPointParameterfvEXT = (PFNGLPOINTPARAMETERFVEXTPROC)glewGetProcAddress((const GLubyte*)"glPointParameterfvEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_point_parameters */ - -#ifdef GL_EXT_polygon_offset - -static GLboolean _glewInit_GL_EXT_polygon_offset (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPolygonOffsetEXT = (PFNGLPOLYGONOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glPolygonOffsetEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_polygon_offset */ - -#ifdef GL_EXT_provoking_vertex - -static GLboolean _glewInit_GL_EXT_provoking_vertex (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glProvokingVertexEXT = (PFNGLPROVOKINGVERTEXEXTPROC)glewGetProcAddress((const GLubyte*)"glProvokingVertexEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_provoking_vertex */ - -#ifdef GL_EXT_rescale_normal - -#endif /* GL_EXT_rescale_normal */ - -#ifdef GL_EXT_scene_marker - -static GLboolean _glewInit_GL_EXT_scene_marker (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginSceneEXT = (PFNGLBEGINSCENEEXTPROC)glewGetProcAddress((const GLubyte*)"glBeginSceneEXT")) == NULL) || r; - r = ((glEndSceneEXT = (PFNGLENDSCENEEXTPROC)glewGetProcAddress((const GLubyte*)"glEndSceneEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_scene_marker */ - -#ifdef GL_EXT_secondary_color - -static GLboolean _glewInit_GL_EXT_secondary_color (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glSecondaryColor3bEXT = (PFNGLSECONDARYCOLOR3BEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3bEXT")) == NULL) || r; - r = ((glSecondaryColor3bvEXT = (PFNGLSECONDARYCOLOR3BVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3bvEXT")) == NULL) || r; - r = ((glSecondaryColor3dEXT = (PFNGLSECONDARYCOLOR3DEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3dEXT")) == NULL) || r; - r = ((glSecondaryColor3dvEXT = (PFNGLSECONDARYCOLOR3DVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3dvEXT")) == NULL) || r; - r = ((glSecondaryColor3fEXT = (PFNGLSECONDARYCOLOR3FEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3fEXT")) == NULL) || r; - r = ((glSecondaryColor3fvEXT = (PFNGLSECONDARYCOLOR3FVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3fvEXT")) == NULL) || r; - r = ((glSecondaryColor3iEXT = (PFNGLSECONDARYCOLOR3IEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3iEXT")) == NULL) || r; - r = ((glSecondaryColor3ivEXT = (PFNGLSECONDARYCOLOR3IVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ivEXT")) == NULL) || r; - r = ((glSecondaryColor3sEXT = (PFNGLSECONDARYCOLOR3SEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3sEXT")) == NULL) || r; - r = ((glSecondaryColor3svEXT = (PFNGLSECONDARYCOLOR3SVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3svEXT")) == NULL) || r; - r = ((glSecondaryColor3ubEXT = (PFNGLSECONDARYCOLOR3UBEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ubEXT")) == NULL) || r; - r = ((glSecondaryColor3ubvEXT = (PFNGLSECONDARYCOLOR3UBVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3ubvEXT")) == NULL) || r; - r = ((glSecondaryColor3uiEXT = (PFNGLSECONDARYCOLOR3UIEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3uiEXT")) == NULL) || r; - r = ((glSecondaryColor3uivEXT = (PFNGLSECONDARYCOLOR3UIVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3uivEXT")) == NULL) || r; - r = ((glSecondaryColor3usEXT = (PFNGLSECONDARYCOLOR3USEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3usEXT")) == NULL) || r; - r = ((glSecondaryColor3usvEXT = (PFNGLSECONDARYCOLOR3USVEXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3usvEXT")) == NULL) || r; - r = ((glSecondaryColorPointerEXT = (PFNGLSECONDARYCOLORPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorPointerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_secondary_color */ - -#ifdef GL_EXT_separate_shader_objects - -static GLboolean _glewInit_GL_EXT_separate_shader_objects (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glActiveProgramEXT = (PFNGLACTIVEPROGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glActiveProgramEXT")) == NULL) || r; - r = ((glCreateShaderProgramEXT = (PFNGLCREATESHADERPROGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glCreateShaderProgramEXT")) == NULL) || r; - r = ((glUseShaderProgramEXT = (PFNGLUSESHADERPROGRAMEXTPROC)glewGetProcAddress((const GLubyte*)"glUseShaderProgramEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_separate_shader_objects */ - -#ifdef GL_EXT_separate_specular_color - -#endif /* GL_EXT_separate_specular_color */ - -#ifdef GL_EXT_shader_image_load_store - -static GLboolean _glewInit_GL_EXT_shader_image_load_store (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindImageTextureEXT = (PFNGLBINDIMAGETEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glBindImageTextureEXT")) == NULL) || r; - r = ((glMemoryBarrierEXT = (PFNGLMEMORYBARRIEREXTPROC)glewGetProcAddress((const GLubyte*)"glMemoryBarrierEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_shader_image_load_store */ - -#ifdef GL_EXT_shadow_funcs - -#endif /* GL_EXT_shadow_funcs */ - -#ifdef GL_EXT_shared_texture_palette - -#endif /* GL_EXT_shared_texture_palette */ - -#ifdef GL_EXT_stencil_clear_tag - -#endif /* GL_EXT_stencil_clear_tag */ - -#ifdef GL_EXT_stencil_two_side - -static GLboolean _glewInit_GL_EXT_stencil_two_side (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glActiveStencilFaceEXT = (PFNGLACTIVESTENCILFACEEXTPROC)glewGetProcAddress((const GLubyte*)"glActiveStencilFaceEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_stencil_two_side */ - -#ifdef GL_EXT_stencil_wrap - -#endif /* GL_EXT_stencil_wrap */ - -#ifdef GL_EXT_subtexture - -static GLboolean _glewInit_GL_EXT_subtexture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexSubImage1DEXT = (PFNGLTEXSUBIMAGE1DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage1DEXT")) == NULL) || r; - r = ((glTexSubImage2DEXT = (PFNGLTEXSUBIMAGE2DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage2DEXT")) == NULL) || r; - r = ((glTexSubImage3DEXT = (PFNGLTEXSUBIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage3DEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_subtexture */ - -#ifdef GL_EXT_texture - -#endif /* GL_EXT_texture */ - -#ifdef GL_EXT_texture3D - -static GLboolean _glewInit_GL_EXT_texture3D (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexImage3DEXT = (PFNGLTEXIMAGE3DEXTPROC)glewGetProcAddress((const GLubyte*)"glTexImage3DEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_texture3D */ - -#ifdef GL_EXT_texture_array - -static GLboolean _glewInit_GL_EXT_texture_array (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFramebufferTextureLayerEXT = (PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC)glewGetProcAddress((const GLubyte*)"glFramebufferTextureLayerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_texture_array */ - -#ifdef GL_EXT_texture_buffer_object - -static GLboolean _glewInit_GL_EXT_texture_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexBufferEXT = (PFNGLTEXBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"glTexBufferEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_texture_buffer_object */ - -#ifdef GL_EXT_texture_compression_dxt1 - -#endif /* GL_EXT_texture_compression_dxt1 */ - -#ifdef GL_EXT_texture_compression_latc - -#endif /* GL_EXT_texture_compression_latc */ - -#ifdef GL_EXT_texture_compression_rgtc - -#endif /* GL_EXT_texture_compression_rgtc */ - -#ifdef GL_EXT_texture_compression_s3tc - -#endif /* GL_EXT_texture_compression_s3tc */ - -#ifdef GL_EXT_texture_cube_map - -#endif /* GL_EXT_texture_cube_map */ - -#ifdef GL_EXT_texture_edge_clamp - -#endif /* GL_EXT_texture_edge_clamp */ - -#ifdef GL_EXT_texture_env - -#endif /* GL_EXT_texture_env */ - -#ifdef GL_EXT_texture_env_add - -#endif /* GL_EXT_texture_env_add */ - -#ifdef GL_EXT_texture_env_combine - -#endif /* GL_EXT_texture_env_combine */ - -#ifdef GL_EXT_texture_env_dot3 - -#endif /* GL_EXT_texture_env_dot3 */ - -#ifdef GL_EXT_texture_filter_anisotropic - -#endif /* GL_EXT_texture_filter_anisotropic */ - -#ifdef GL_EXT_texture_integer - -static GLboolean _glewInit_GL_EXT_texture_integer (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClearColorIiEXT = (PFNGLCLEARCOLORIIEXTPROC)glewGetProcAddress((const GLubyte*)"glClearColorIiEXT")) == NULL) || r; - r = ((glClearColorIuiEXT = (PFNGLCLEARCOLORIUIEXTPROC)glewGetProcAddress((const GLubyte*)"glClearColorIuiEXT")) == NULL) || r; - r = ((glGetTexParameterIivEXT = (PFNGLGETTEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIivEXT")) == NULL) || r; - r = ((glGetTexParameterIuivEXT = (PFNGLGETTEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterIuivEXT")) == NULL) || r; - r = ((glTexParameterIivEXT = (PFNGLTEXPARAMETERIIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIivEXT")) == NULL) || r; - r = ((glTexParameterIuivEXT = (PFNGLTEXPARAMETERIUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glTexParameterIuivEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_texture_integer */ - -#ifdef GL_EXT_texture_lod_bias - -#endif /* GL_EXT_texture_lod_bias */ - -#ifdef GL_EXT_texture_mirror_clamp - -#endif /* GL_EXT_texture_mirror_clamp */ - -#ifdef GL_EXT_texture_object - -static GLboolean _glewInit_GL_EXT_texture_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAreTexturesResidentEXT = (PFNGLARETEXTURESRESIDENTEXTPROC)glewGetProcAddress((const GLubyte*)"glAreTexturesResidentEXT")) == NULL) || r; - r = ((glBindTextureEXT = (PFNGLBINDTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glBindTextureEXT")) == NULL) || r; - r = ((glDeleteTexturesEXT = (PFNGLDELETETEXTURESEXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteTexturesEXT")) == NULL) || r; - r = ((glGenTexturesEXT = (PFNGLGENTEXTURESEXTPROC)glewGetProcAddress((const GLubyte*)"glGenTexturesEXT")) == NULL) || r; - r = ((glIsTextureEXT = (PFNGLISTEXTUREEXTPROC)glewGetProcAddress((const GLubyte*)"glIsTextureEXT")) == NULL) || r; - r = ((glPrioritizeTexturesEXT = (PFNGLPRIORITIZETEXTURESEXTPROC)glewGetProcAddress((const GLubyte*)"glPrioritizeTexturesEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_texture_object */ - -#ifdef GL_EXT_texture_perturb_normal - -static GLboolean _glewInit_GL_EXT_texture_perturb_normal (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTextureNormalEXT = (PFNGLTEXTURENORMALEXTPROC)glewGetProcAddress((const GLubyte*)"glTextureNormalEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_texture_perturb_normal */ - -#ifdef GL_EXT_texture_rectangle - -#endif /* GL_EXT_texture_rectangle */ - -#ifdef GL_EXT_texture_sRGB - -#endif /* GL_EXT_texture_sRGB */ - -#ifdef GL_EXT_texture_sRGB_decode - -#endif /* GL_EXT_texture_sRGB_decode */ - -#ifdef GL_EXT_texture_shared_exponent - -#endif /* GL_EXT_texture_shared_exponent */ - -#ifdef GL_EXT_texture_snorm - -#endif /* GL_EXT_texture_snorm */ - -#ifdef GL_EXT_texture_swizzle - -#endif /* GL_EXT_texture_swizzle */ - -#ifdef GL_EXT_timer_query - -static GLboolean _glewInit_GL_EXT_timer_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetQueryObjecti64vEXT = (PFNGLGETQUERYOBJECTI64VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjecti64vEXT")) == NULL) || r; - r = ((glGetQueryObjectui64vEXT = (PFNGLGETQUERYOBJECTUI64VEXTPROC)glewGetProcAddress((const GLubyte*)"glGetQueryObjectui64vEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_timer_query */ - -#ifdef GL_EXT_transform_feedback - -static GLboolean _glewInit_GL_EXT_transform_feedback (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginTransformFeedbackEXT = (PFNGLBEGINTRANSFORMFEEDBACKEXTPROC)glewGetProcAddress((const GLubyte*)"glBeginTransformFeedbackEXT")) == NULL) || r; - r = ((glBindBufferBaseEXT = (PFNGLBINDBUFFERBASEEXTPROC)glewGetProcAddress((const GLubyte*)"glBindBufferBaseEXT")) == NULL) || r; - r = ((glBindBufferOffsetEXT = (PFNGLBINDBUFFEROFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glBindBufferOffsetEXT")) == NULL) || r; - r = ((glBindBufferRangeEXT = (PFNGLBINDBUFFERRANGEEXTPROC)glewGetProcAddress((const GLubyte*)"glBindBufferRangeEXT")) == NULL) || r; - r = ((glEndTransformFeedbackEXT = (PFNGLENDTRANSFORMFEEDBACKEXTPROC)glewGetProcAddress((const GLubyte*)"glEndTransformFeedbackEXT")) == NULL) || r; - r = ((glGetTransformFeedbackVaryingEXT = (PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC)glewGetProcAddress((const GLubyte*)"glGetTransformFeedbackVaryingEXT")) == NULL) || r; - r = ((glTransformFeedbackVaryingsEXT = (PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackVaryingsEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_transform_feedback */ - -#ifdef GL_EXT_vertex_array - -static GLboolean _glewInit_GL_EXT_vertex_array (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glArrayElementEXT = (PFNGLARRAYELEMENTEXTPROC)glewGetProcAddress((const GLubyte*)"glArrayElementEXT")) == NULL) || r; - r = ((glColorPointerEXT = (PFNGLCOLORPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glColorPointerEXT")) == NULL) || r; - r = ((glDrawArraysEXT = (PFNGLDRAWARRAYSEXTPROC)glewGetProcAddress((const GLubyte*)"glDrawArraysEXT")) == NULL) || r; - r = ((glEdgeFlagPointerEXT = (PFNGLEDGEFLAGPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glEdgeFlagPointerEXT")) == NULL) || r; - r = ((glIndexPointerEXT = (PFNGLINDEXPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glIndexPointerEXT")) == NULL) || r; - r = ((glNormalPointerEXT = (PFNGLNORMALPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glNormalPointerEXT")) == NULL) || r; - r = ((glTexCoordPointerEXT = (PFNGLTEXCOORDPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glTexCoordPointerEXT")) == NULL) || r; - r = ((glVertexPointerEXT = (PFNGLVERTEXPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexPointerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_vertex_array */ - -#ifdef GL_EXT_vertex_array_bgra - -#endif /* GL_EXT_vertex_array_bgra */ - -#ifdef GL_EXT_vertex_attrib_64bit - -static GLboolean _glewInit_GL_EXT_vertex_attrib_64bit (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetVertexAttribLdvEXT = (PFNGLGETVERTEXATTRIBLDVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLdvEXT")) == NULL) || r; - r = ((glVertexArrayVertexAttribLOffsetEXT = (PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayVertexAttribLOffsetEXT")) == NULL) || r; - r = ((glVertexAttribL1dEXT = (PFNGLVERTEXATTRIBL1DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1dEXT")) == NULL) || r; - r = ((glVertexAttribL1dvEXT = (PFNGLVERTEXATTRIBL1DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1dvEXT")) == NULL) || r; - r = ((glVertexAttribL2dEXT = (PFNGLVERTEXATTRIBL2DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2dEXT")) == NULL) || r; - r = ((glVertexAttribL2dvEXT = (PFNGLVERTEXATTRIBL2DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2dvEXT")) == NULL) || r; - r = ((glVertexAttribL3dEXT = (PFNGLVERTEXATTRIBL3DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3dEXT")) == NULL) || r; - r = ((glVertexAttribL3dvEXT = (PFNGLVERTEXATTRIBL3DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3dvEXT")) == NULL) || r; - r = ((glVertexAttribL4dEXT = (PFNGLVERTEXATTRIBL4DEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4dEXT")) == NULL) || r; - r = ((glVertexAttribL4dvEXT = (PFNGLVERTEXATTRIBL4DVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4dvEXT")) == NULL) || r; - r = ((glVertexAttribLPointerEXT = (PFNGLVERTEXATTRIBLPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribLPointerEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_vertex_attrib_64bit */ - -#ifdef GL_EXT_vertex_shader - -static GLboolean _glewInit_GL_EXT_vertex_shader (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginVertexShaderEXT = (PFNGLBEGINVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glBeginVertexShaderEXT")) == NULL) || r; - r = ((glBindLightParameterEXT = (PFNGLBINDLIGHTPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindLightParameterEXT")) == NULL) || r; - r = ((glBindMaterialParameterEXT = (PFNGLBINDMATERIALPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindMaterialParameterEXT")) == NULL) || r; - r = ((glBindParameterEXT = (PFNGLBINDPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindParameterEXT")) == NULL) || r; - r = ((glBindTexGenParameterEXT = (PFNGLBINDTEXGENPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindTexGenParameterEXT")) == NULL) || r; - r = ((glBindTextureUnitParameterEXT = (PFNGLBINDTEXTUREUNITPARAMETEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindTextureUnitParameterEXT")) == NULL) || r; - r = ((glBindVertexShaderEXT = (PFNGLBINDVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glBindVertexShaderEXT")) == NULL) || r; - r = ((glDeleteVertexShaderEXT = (PFNGLDELETEVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glDeleteVertexShaderEXT")) == NULL) || r; - r = ((glDisableVariantClientStateEXT = (PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC)glewGetProcAddress((const GLubyte*)"glDisableVariantClientStateEXT")) == NULL) || r; - r = ((glEnableVariantClientStateEXT = (PFNGLENABLEVARIANTCLIENTSTATEEXTPROC)glewGetProcAddress((const GLubyte*)"glEnableVariantClientStateEXT")) == NULL) || r; - r = ((glEndVertexShaderEXT = (PFNGLENDVERTEXSHADEREXTPROC)glewGetProcAddress((const GLubyte*)"glEndVertexShaderEXT")) == NULL) || r; - r = ((glExtractComponentEXT = (PFNGLEXTRACTCOMPONENTEXTPROC)glewGetProcAddress((const GLubyte*)"glExtractComponentEXT")) == NULL) || r; - r = ((glGenSymbolsEXT = (PFNGLGENSYMBOLSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenSymbolsEXT")) == NULL) || r; - r = ((glGenVertexShadersEXT = (PFNGLGENVERTEXSHADERSEXTPROC)glewGetProcAddress((const GLubyte*)"glGenVertexShadersEXT")) == NULL) || r; - r = ((glGetInvariantBooleanvEXT = (PFNGLGETINVARIANTBOOLEANVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetInvariantBooleanvEXT")) == NULL) || r; - r = ((glGetInvariantFloatvEXT = (PFNGLGETINVARIANTFLOATVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetInvariantFloatvEXT")) == NULL) || r; - r = ((glGetInvariantIntegervEXT = (PFNGLGETINVARIANTINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetInvariantIntegervEXT")) == NULL) || r; - r = ((glGetLocalConstantBooleanvEXT = (PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetLocalConstantBooleanvEXT")) == NULL) || r; - r = ((glGetLocalConstantFloatvEXT = (PFNGLGETLOCALCONSTANTFLOATVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetLocalConstantFloatvEXT")) == NULL) || r; - r = ((glGetLocalConstantIntegervEXT = (PFNGLGETLOCALCONSTANTINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetLocalConstantIntegervEXT")) == NULL) || r; - r = ((glGetVariantBooleanvEXT = (PFNGLGETVARIANTBOOLEANVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantBooleanvEXT")) == NULL) || r; - r = ((glGetVariantFloatvEXT = (PFNGLGETVARIANTFLOATVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantFloatvEXT")) == NULL) || r; - r = ((glGetVariantIntegervEXT = (PFNGLGETVARIANTINTEGERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantIntegervEXT")) == NULL) || r; - r = ((glGetVariantPointervEXT = (PFNGLGETVARIANTPOINTERVEXTPROC)glewGetProcAddress((const GLubyte*)"glGetVariantPointervEXT")) == NULL) || r; - r = ((glInsertComponentEXT = (PFNGLINSERTCOMPONENTEXTPROC)glewGetProcAddress((const GLubyte*)"glInsertComponentEXT")) == NULL) || r; - r = ((glIsVariantEnabledEXT = (PFNGLISVARIANTENABLEDEXTPROC)glewGetProcAddress((const GLubyte*)"glIsVariantEnabledEXT")) == NULL) || r; - r = ((glSetInvariantEXT = (PFNGLSETINVARIANTEXTPROC)glewGetProcAddress((const GLubyte*)"glSetInvariantEXT")) == NULL) || r; - r = ((glSetLocalConstantEXT = (PFNGLSETLOCALCONSTANTEXTPROC)glewGetProcAddress((const GLubyte*)"glSetLocalConstantEXT")) == NULL) || r; - r = ((glShaderOp1EXT = (PFNGLSHADEROP1EXTPROC)glewGetProcAddress((const GLubyte*)"glShaderOp1EXT")) == NULL) || r; - r = ((glShaderOp2EXT = (PFNGLSHADEROP2EXTPROC)glewGetProcAddress((const GLubyte*)"glShaderOp2EXT")) == NULL) || r; - r = ((glShaderOp3EXT = (PFNGLSHADEROP3EXTPROC)glewGetProcAddress((const GLubyte*)"glShaderOp3EXT")) == NULL) || r; - r = ((glSwizzleEXT = (PFNGLSWIZZLEEXTPROC)glewGetProcAddress((const GLubyte*)"glSwizzleEXT")) == NULL) || r; - r = ((glVariantPointerEXT = (PFNGLVARIANTPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVariantPointerEXT")) == NULL) || r; - r = ((glVariantbvEXT = (PFNGLVARIANTBVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantbvEXT")) == NULL) || r; - r = ((glVariantdvEXT = (PFNGLVARIANTDVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantdvEXT")) == NULL) || r; - r = ((glVariantfvEXT = (PFNGLVARIANTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantfvEXT")) == NULL) || r; - r = ((glVariantivEXT = (PFNGLVARIANTIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantivEXT")) == NULL) || r; - r = ((glVariantsvEXT = (PFNGLVARIANTSVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantsvEXT")) == NULL) || r; - r = ((glVariantubvEXT = (PFNGLVARIANTUBVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantubvEXT")) == NULL) || r; - r = ((glVariantuivEXT = (PFNGLVARIANTUIVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantuivEXT")) == NULL) || r; - r = ((glVariantusvEXT = (PFNGLVARIANTUSVEXTPROC)glewGetProcAddress((const GLubyte*)"glVariantusvEXT")) == NULL) || r; - r = ((glWriteMaskEXT = (PFNGLWRITEMASKEXTPROC)glewGetProcAddress((const GLubyte*)"glWriteMaskEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_vertex_shader */ - -#ifdef GL_EXT_vertex_weighting - -static GLboolean _glewInit_GL_EXT_vertex_weighting (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glVertexWeightPointerEXT = (PFNGLVERTEXWEIGHTPOINTEREXTPROC)glewGetProcAddress((const GLubyte*)"glVertexWeightPointerEXT")) == NULL) || r; - r = ((glVertexWeightfEXT = (PFNGLVERTEXWEIGHTFEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexWeightfEXT")) == NULL) || r; - r = ((glVertexWeightfvEXT = (PFNGLVERTEXWEIGHTFVEXTPROC)glewGetProcAddress((const GLubyte*)"glVertexWeightfvEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_vertex_weighting */ - -#ifdef GL_EXT_x11_sync_object - -static GLboolean _glewInit_GL_EXT_x11_sync_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glImportSyncEXT = (PFNGLIMPORTSYNCEXTPROC)glewGetProcAddress((const GLubyte*)"glImportSyncEXT")) == NULL) || r; - - return r; -} - -#endif /* GL_EXT_x11_sync_object */ - -#ifdef GL_GREMEDY_frame_terminator - -static GLboolean _glewInit_GL_GREMEDY_frame_terminator (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFrameTerminatorGREMEDY = (PFNGLFRAMETERMINATORGREMEDYPROC)glewGetProcAddress((const GLubyte*)"glFrameTerminatorGREMEDY")) == NULL) || r; - - return r; -} - -#endif /* GL_GREMEDY_frame_terminator */ - -#ifdef GL_GREMEDY_string_marker - -static GLboolean _glewInit_GL_GREMEDY_string_marker (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glStringMarkerGREMEDY = (PFNGLSTRINGMARKERGREMEDYPROC)glewGetProcAddress((const GLubyte*)"glStringMarkerGREMEDY")) == NULL) || r; - - return r; -} - -#endif /* GL_GREMEDY_string_marker */ - -#ifdef GL_HP_convolution_border_modes - -#endif /* GL_HP_convolution_border_modes */ - -#ifdef GL_HP_image_transform - -static GLboolean _glewInit_GL_HP_image_transform (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetImageTransformParameterfvHP = (PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC)glewGetProcAddress((const GLubyte*)"glGetImageTransformParameterfvHP")) == NULL) || r; - r = ((glGetImageTransformParameterivHP = (PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC)glewGetProcAddress((const GLubyte*)"glGetImageTransformParameterivHP")) == NULL) || r; - r = ((glImageTransformParameterfHP = (PFNGLIMAGETRANSFORMPARAMETERFHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameterfHP")) == NULL) || r; - r = ((glImageTransformParameterfvHP = (PFNGLIMAGETRANSFORMPARAMETERFVHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameterfvHP")) == NULL) || r; - r = ((glImageTransformParameteriHP = (PFNGLIMAGETRANSFORMPARAMETERIHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameteriHP")) == NULL) || r; - r = ((glImageTransformParameterivHP = (PFNGLIMAGETRANSFORMPARAMETERIVHPPROC)glewGetProcAddress((const GLubyte*)"glImageTransformParameterivHP")) == NULL) || r; - - return r; -} - -#endif /* GL_HP_image_transform */ - -#ifdef GL_HP_occlusion_test - -#endif /* GL_HP_occlusion_test */ - -#ifdef GL_HP_texture_lighting - -#endif /* GL_HP_texture_lighting */ - -#ifdef GL_IBM_cull_vertex - -#endif /* GL_IBM_cull_vertex */ - -#ifdef GL_IBM_multimode_draw_arrays - -static GLboolean _glewInit_GL_IBM_multimode_draw_arrays (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMultiModeDrawArraysIBM = (PFNGLMULTIMODEDRAWARRAYSIBMPROC)glewGetProcAddress((const GLubyte*)"glMultiModeDrawArraysIBM")) == NULL) || r; - r = ((glMultiModeDrawElementsIBM = (PFNGLMULTIMODEDRAWELEMENTSIBMPROC)glewGetProcAddress((const GLubyte*)"glMultiModeDrawElementsIBM")) == NULL) || r; - - return r; -} - -#endif /* GL_IBM_multimode_draw_arrays */ - -#ifdef GL_IBM_rasterpos_clip - -#endif /* GL_IBM_rasterpos_clip */ - -#ifdef GL_IBM_static_data - -#endif /* GL_IBM_static_data */ - -#ifdef GL_IBM_texture_mirrored_repeat - -#endif /* GL_IBM_texture_mirrored_repeat */ - -#ifdef GL_IBM_vertex_array_lists - -static GLboolean _glewInit_GL_IBM_vertex_array_lists (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorPointerListIBM = (PFNGLCOLORPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glColorPointerListIBM")) == NULL) || r; - r = ((glEdgeFlagPointerListIBM = (PFNGLEDGEFLAGPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glEdgeFlagPointerListIBM")) == NULL) || r; - r = ((glFogCoordPointerListIBM = (PFNGLFOGCOORDPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glFogCoordPointerListIBM")) == NULL) || r; - r = ((glIndexPointerListIBM = (PFNGLINDEXPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glIndexPointerListIBM")) == NULL) || r; - r = ((glNormalPointerListIBM = (PFNGLNORMALPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glNormalPointerListIBM")) == NULL) || r; - r = ((glSecondaryColorPointerListIBM = (PFNGLSECONDARYCOLORPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorPointerListIBM")) == NULL) || r; - r = ((glTexCoordPointerListIBM = (PFNGLTEXCOORDPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glTexCoordPointerListIBM")) == NULL) || r; - r = ((glVertexPointerListIBM = (PFNGLVERTEXPOINTERLISTIBMPROC)glewGetProcAddress((const GLubyte*)"glVertexPointerListIBM")) == NULL) || r; - - return r; -} - -#endif /* GL_IBM_vertex_array_lists */ - -#ifdef GL_INGR_color_clamp - -#endif /* GL_INGR_color_clamp */ - -#ifdef GL_INGR_interlace_read - -#endif /* GL_INGR_interlace_read */ - -#ifdef GL_INTEL_map_texture - -static GLboolean _glewInit_GL_INTEL_map_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMapTexture2DINTEL = (PFNGLMAPTEXTURE2DINTELPROC)glewGetProcAddress((const GLubyte*)"glMapTexture2DINTEL")) == NULL) || r; - r = ((glSyncTextureINTEL = (PFNGLSYNCTEXTUREINTELPROC)glewGetProcAddress((const GLubyte*)"glSyncTextureINTEL")) == NULL) || r; - r = ((glUnmapTexture2DINTEL = (PFNGLUNMAPTEXTURE2DINTELPROC)glewGetProcAddress((const GLubyte*)"glUnmapTexture2DINTEL")) == NULL) || r; - - return r; -} - -#endif /* GL_INTEL_map_texture */ - -#ifdef GL_INTEL_parallel_arrays - -static GLboolean _glewInit_GL_INTEL_parallel_arrays (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorPointervINTEL = (PFNGLCOLORPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glColorPointervINTEL")) == NULL) || r; - r = ((glNormalPointervINTEL = (PFNGLNORMALPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glNormalPointervINTEL")) == NULL) || r; - r = ((glTexCoordPointervINTEL = (PFNGLTEXCOORDPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glTexCoordPointervINTEL")) == NULL) || r; - r = ((glVertexPointervINTEL = (PFNGLVERTEXPOINTERVINTELPROC)glewGetProcAddress((const GLubyte*)"glVertexPointervINTEL")) == NULL) || r; - - return r; -} - -#endif /* GL_INTEL_parallel_arrays */ - -#ifdef GL_INTEL_texture_scissor - -static GLboolean _glewInit_GL_INTEL_texture_scissor (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexScissorFuncINTEL = (PFNGLTEXSCISSORFUNCINTELPROC)glewGetProcAddress((const GLubyte*)"glTexScissorFuncINTEL")) == NULL) || r; - r = ((glTexScissorINTEL = (PFNGLTEXSCISSORINTELPROC)glewGetProcAddress((const GLubyte*)"glTexScissorINTEL")) == NULL) || r; - - return r; -} - -#endif /* GL_INTEL_texture_scissor */ - -#ifdef GL_KHR_debug - -static GLboolean _glewInit_GL_KHR_debug (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDebugMessageCallback = (PFNGLDEBUGMESSAGECALLBACKPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageCallback")) == NULL) || r; - r = ((glDebugMessageControl = (PFNGLDEBUGMESSAGECONTROLPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageControl")) == NULL) || r; - r = ((glDebugMessageInsert = (PFNGLDEBUGMESSAGEINSERTPROC)glewGetProcAddress((const GLubyte*)"glDebugMessageInsert")) == NULL) || r; - r = ((glGetDebugMessageLog = (PFNGLGETDEBUGMESSAGELOGPROC)glewGetProcAddress((const GLubyte*)"glGetDebugMessageLog")) == NULL) || r; - r = ((glGetObjectLabel = (PFNGLGETOBJECTLABELPROC)glewGetProcAddress((const GLubyte*)"glGetObjectLabel")) == NULL) || r; - r = ((glGetObjectPtrLabel = (PFNGLGETOBJECTPTRLABELPROC)glewGetProcAddress((const GLubyte*)"glGetObjectPtrLabel")) == NULL) || r; - r = ((glObjectLabel = (PFNGLOBJECTLABELPROC)glewGetProcAddress((const GLubyte*)"glObjectLabel")) == NULL) || r; - r = ((glObjectPtrLabel = (PFNGLOBJECTPTRLABELPROC)glewGetProcAddress((const GLubyte*)"glObjectPtrLabel")) == NULL) || r; - r = ((glPopDebugGroup = (PFNGLPOPDEBUGGROUPPROC)glewGetProcAddress((const GLubyte*)"glPopDebugGroup")) == NULL) || r; - r = ((glPushDebugGroup = (PFNGLPUSHDEBUGGROUPPROC)glewGetProcAddress((const GLubyte*)"glPushDebugGroup")) == NULL) || r; - - return r; -} - -#endif /* GL_KHR_debug */ - -#ifdef GL_KHR_texture_compression_astc_ldr - -#endif /* GL_KHR_texture_compression_astc_ldr */ - -#ifdef GL_KTX_buffer_region - -static GLboolean _glewInit_GL_KTX_buffer_region (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBufferRegionEnabled = (PFNGLBUFFERREGIONENABLEDPROC)glewGetProcAddress((const GLubyte*)"glBufferRegionEnabled")) == NULL) || r; - r = ((glDeleteBufferRegion = (PFNGLDELETEBUFFERREGIONPROC)glewGetProcAddress((const GLubyte*)"glDeleteBufferRegion")) == NULL) || r; - r = ((glDrawBufferRegion = (PFNGLDRAWBUFFERREGIONPROC)glewGetProcAddress((const GLubyte*)"glDrawBufferRegion")) == NULL) || r; - r = ((glNewBufferRegion = (PFNGLNEWBUFFERREGIONPROC)glewGetProcAddress((const GLubyte*)"glNewBufferRegion")) == NULL) || r; - r = ((glReadBufferRegion = (PFNGLREADBUFFERREGIONPROC)glewGetProcAddress((const GLubyte*)"glReadBufferRegion")) == NULL) || r; - - return r; -} - -#endif /* GL_KTX_buffer_region */ - -#ifdef GL_MESAX_texture_stack - -#endif /* GL_MESAX_texture_stack */ - -#ifdef GL_MESA_pack_invert - -#endif /* GL_MESA_pack_invert */ - -#ifdef GL_MESA_resize_buffers - -static GLboolean _glewInit_GL_MESA_resize_buffers (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glResizeBuffersMESA = (PFNGLRESIZEBUFFERSMESAPROC)glewGetProcAddress((const GLubyte*)"glResizeBuffersMESA")) == NULL) || r; - - return r; -} - -#endif /* GL_MESA_resize_buffers */ - -#ifdef GL_MESA_window_pos - -static GLboolean _glewInit_GL_MESA_window_pos (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glWindowPos2dMESA = (PFNGLWINDOWPOS2DMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dMESA")) == NULL) || r; - r = ((glWindowPos2dvMESA = (PFNGLWINDOWPOS2DVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2dvMESA")) == NULL) || r; - r = ((glWindowPos2fMESA = (PFNGLWINDOWPOS2FMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fMESA")) == NULL) || r; - r = ((glWindowPos2fvMESA = (PFNGLWINDOWPOS2FVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2fvMESA")) == NULL) || r; - r = ((glWindowPos2iMESA = (PFNGLWINDOWPOS2IMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2iMESA")) == NULL) || r; - r = ((glWindowPos2ivMESA = (PFNGLWINDOWPOS2IVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2ivMESA")) == NULL) || r; - r = ((glWindowPos2sMESA = (PFNGLWINDOWPOS2SMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2sMESA")) == NULL) || r; - r = ((glWindowPos2svMESA = (PFNGLWINDOWPOS2SVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos2svMESA")) == NULL) || r; - r = ((glWindowPos3dMESA = (PFNGLWINDOWPOS3DMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dMESA")) == NULL) || r; - r = ((glWindowPos3dvMESA = (PFNGLWINDOWPOS3DVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3dvMESA")) == NULL) || r; - r = ((glWindowPos3fMESA = (PFNGLWINDOWPOS3FMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fMESA")) == NULL) || r; - r = ((glWindowPos3fvMESA = (PFNGLWINDOWPOS3FVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3fvMESA")) == NULL) || r; - r = ((glWindowPos3iMESA = (PFNGLWINDOWPOS3IMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3iMESA")) == NULL) || r; - r = ((glWindowPos3ivMESA = (PFNGLWINDOWPOS3IVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3ivMESA")) == NULL) || r; - r = ((glWindowPos3sMESA = (PFNGLWINDOWPOS3SMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3sMESA")) == NULL) || r; - r = ((glWindowPos3svMESA = (PFNGLWINDOWPOS3SVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos3svMESA")) == NULL) || r; - r = ((glWindowPos4dMESA = (PFNGLWINDOWPOS4DMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4dMESA")) == NULL) || r; - r = ((glWindowPos4dvMESA = (PFNGLWINDOWPOS4DVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4dvMESA")) == NULL) || r; - r = ((glWindowPos4fMESA = (PFNGLWINDOWPOS4FMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4fMESA")) == NULL) || r; - r = ((glWindowPos4fvMESA = (PFNGLWINDOWPOS4FVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4fvMESA")) == NULL) || r; - r = ((glWindowPos4iMESA = (PFNGLWINDOWPOS4IMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4iMESA")) == NULL) || r; - r = ((glWindowPos4ivMESA = (PFNGLWINDOWPOS4IVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4ivMESA")) == NULL) || r; - r = ((glWindowPos4sMESA = (PFNGLWINDOWPOS4SMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4sMESA")) == NULL) || r; - r = ((glWindowPos4svMESA = (PFNGLWINDOWPOS4SVMESAPROC)glewGetProcAddress((const GLubyte*)"glWindowPos4svMESA")) == NULL) || r; - - return r; -} - -#endif /* GL_MESA_window_pos */ - -#ifdef GL_MESA_ycbcr_texture - -#endif /* GL_MESA_ycbcr_texture */ - -#ifdef GL_NVX_conditional_render - -static GLboolean _glewInit_GL_NVX_conditional_render (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginConditionalRenderNVX = (PFNGLBEGINCONDITIONALRENDERNVXPROC)glewGetProcAddress((const GLubyte*)"glBeginConditionalRenderNVX")) == NULL) || r; - r = ((glEndConditionalRenderNVX = (PFNGLENDCONDITIONALRENDERNVXPROC)glewGetProcAddress((const GLubyte*)"glEndConditionalRenderNVX")) == NULL) || r; - - return r; -} - -#endif /* GL_NVX_conditional_render */ - -#ifdef GL_NVX_gpu_memory_info - -#endif /* GL_NVX_gpu_memory_info */ - -#ifdef GL_NV_bindless_multi_draw_indirect - -static GLboolean _glewInit_GL_NV_bindless_multi_draw_indirect (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glMultiDrawArraysIndirectBindlessNV = (PFNGLMULTIDRAWARRAYSINDIRECTBINDLESSNVPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawArraysIndirectBindlessNV")) == NULL) || r; - r = ((glMultiDrawElementsIndirectBindlessNV = (PFNGLMULTIDRAWELEMENTSINDIRECTBINDLESSNVPROC)glewGetProcAddress((const GLubyte*)"glMultiDrawElementsIndirectBindlessNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_bindless_multi_draw_indirect */ - -#ifdef GL_NV_bindless_texture - -static GLboolean _glewInit_GL_NV_bindless_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetImageHandleNV = (PFNGLGETIMAGEHANDLENVPROC)glewGetProcAddress((const GLubyte*)"glGetImageHandleNV")) == NULL) || r; - r = ((glGetTextureHandleNV = (PFNGLGETTEXTUREHANDLENVPROC)glewGetProcAddress((const GLubyte*)"glGetTextureHandleNV")) == NULL) || r; - r = ((glGetTextureSamplerHandleNV = (PFNGLGETTEXTURESAMPLERHANDLENVPROC)glewGetProcAddress((const GLubyte*)"glGetTextureSamplerHandleNV")) == NULL) || r; - r = ((glIsImageHandleResidentNV = (PFNGLISIMAGEHANDLERESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glIsImageHandleResidentNV")) == NULL) || r; - r = ((glIsTextureHandleResidentNV = (PFNGLISTEXTUREHANDLERESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glIsTextureHandleResidentNV")) == NULL) || r; - r = ((glMakeImageHandleNonResidentNV = (PFNGLMAKEIMAGEHANDLENONRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeImageHandleNonResidentNV")) == NULL) || r; - r = ((glMakeImageHandleResidentNV = (PFNGLMAKEIMAGEHANDLERESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeImageHandleResidentNV")) == NULL) || r; - r = ((glMakeTextureHandleNonResidentNV = (PFNGLMAKETEXTUREHANDLENONRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeTextureHandleNonResidentNV")) == NULL) || r; - r = ((glMakeTextureHandleResidentNV = (PFNGLMAKETEXTUREHANDLERESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeTextureHandleResidentNV")) == NULL) || r; - r = ((glProgramUniformHandleui64NV = (PFNGLPROGRAMUNIFORMHANDLEUI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformHandleui64NV")) == NULL) || r; - r = ((glProgramUniformHandleui64vNV = (PFNGLPROGRAMUNIFORMHANDLEUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformHandleui64vNV")) == NULL) || r; - r = ((glUniformHandleui64NV = (PFNGLUNIFORMHANDLEUI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniformHandleui64NV")) == NULL) || r; - r = ((glUniformHandleui64vNV = (PFNGLUNIFORMHANDLEUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniformHandleui64vNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_bindless_texture */ - -#ifdef GL_NV_blend_equation_advanced - -static GLboolean _glewInit_GL_NV_blend_equation_advanced (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBlendBarrierNV = (PFNGLBLENDBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"glBlendBarrierNV")) == NULL) || r; - r = ((glBlendParameteriNV = (PFNGLBLENDPARAMETERINVPROC)glewGetProcAddress((const GLubyte*)"glBlendParameteriNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_blend_equation_advanced */ - -#ifdef GL_NV_blend_equation_advanced_coherent - -#endif /* GL_NV_blend_equation_advanced_coherent */ - -#ifdef GL_NV_blend_square - -#endif /* GL_NV_blend_square */ - -#ifdef GL_NV_compute_program5 - -#endif /* GL_NV_compute_program5 */ - -#ifdef GL_NV_conditional_render - -static GLboolean _glewInit_GL_NV_conditional_render (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginConditionalRenderNV = (PFNGLBEGINCONDITIONALRENDERNVPROC)glewGetProcAddress((const GLubyte*)"glBeginConditionalRenderNV")) == NULL) || r; - r = ((glEndConditionalRenderNV = (PFNGLENDCONDITIONALRENDERNVPROC)glewGetProcAddress((const GLubyte*)"glEndConditionalRenderNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_conditional_render */ - -#ifdef GL_NV_copy_depth_to_color - -#endif /* GL_NV_copy_depth_to_color */ - -#ifdef GL_NV_copy_image - -static GLboolean _glewInit_GL_NV_copy_image (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCopyImageSubDataNV = (PFNGLCOPYIMAGESUBDATANVPROC)glewGetProcAddress((const GLubyte*)"glCopyImageSubDataNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_copy_image */ - -#ifdef GL_NV_deep_texture3D - -#endif /* GL_NV_deep_texture3D */ - -#ifdef GL_NV_depth_buffer_float - -static GLboolean _glewInit_GL_NV_depth_buffer_float (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClearDepthdNV = (PFNGLCLEARDEPTHDNVPROC)glewGetProcAddress((const GLubyte*)"glClearDepthdNV")) == NULL) || r; - r = ((glDepthBoundsdNV = (PFNGLDEPTHBOUNDSDNVPROC)glewGetProcAddress((const GLubyte*)"glDepthBoundsdNV")) == NULL) || r; - r = ((glDepthRangedNV = (PFNGLDEPTHRANGEDNVPROC)glewGetProcAddress((const GLubyte*)"glDepthRangedNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_depth_buffer_float */ - -#ifdef GL_NV_depth_clamp - -#endif /* GL_NV_depth_clamp */ - -#ifdef GL_NV_depth_range_unclamped - -#endif /* GL_NV_depth_range_unclamped */ - -#ifdef GL_NV_draw_texture - -static GLboolean _glewInit_GL_NV_draw_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDrawTextureNV = (PFNGLDRAWTEXTURENVPROC)glewGetProcAddress((const GLubyte*)"glDrawTextureNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_draw_texture */ - -#ifdef GL_NV_evaluators - -static GLboolean _glewInit_GL_NV_evaluators (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glEvalMapsNV = (PFNGLEVALMAPSNVPROC)glewGetProcAddress((const GLubyte*)"glEvalMapsNV")) == NULL) || r; - r = ((glGetMapAttribParameterfvNV = (PFNGLGETMAPATTRIBPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapAttribParameterfvNV")) == NULL) || r; - r = ((glGetMapAttribParameterivNV = (PFNGLGETMAPATTRIBPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapAttribParameterivNV")) == NULL) || r; - r = ((glGetMapControlPointsNV = (PFNGLGETMAPCONTROLPOINTSNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapControlPointsNV")) == NULL) || r; - r = ((glGetMapParameterfvNV = (PFNGLGETMAPPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapParameterfvNV")) == NULL) || r; - r = ((glGetMapParameterivNV = (PFNGLGETMAPPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMapParameterivNV")) == NULL) || r; - r = ((glMapControlPointsNV = (PFNGLMAPCONTROLPOINTSNVPROC)glewGetProcAddress((const GLubyte*)"glMapControlPointsNV")) == NULL) || r; - r = ((glMapParameterfvNV = (PFNGLMAPPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glMapParameterfvNV")) == NULL) || r; - r = ((glMapParameterivNV = (PFNGLMAPPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glMapParameterivNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_evaluators */ - -#ifdef GL_NV_explicit_multisample - -static GLboolean _glewInit_GL_NV_explicit_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetMultisamplefvNV = (PFNGLGETMULTISAMPLEFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetMultisamplefvNV")) == NULL) || r; - r = ((glSampleMaskIndexedNV = (PFNGLSAMPLEMASKINDEXEDNVPROC)glewGetProcAddress((const GLubyte*)"glSampleMaskIndexedNV")) == NULL) || r; - r = ((glTexRenderbufferNV = (PFNGLTEXRENDERBUFFERNVPROC)glewGetProcAddress((const GLubyte*)"glTexRenderbufferNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_explicit_multisample */ - -#ifdef GL_NV_fence - -static GLboolean _glewInit_GL_NV_fence (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDeleteFencesNV = (PFNGLDELETEFENCESNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteFencesNV")) == NULL) || r; - r = ((glFinishFenceNV = (PFNGLFINISHFENCENVPROC)glewGetProcAddress((const GLubyte*)"glFinishFenceNV")) == NULL) || r; - r = ((glGenFencesNV = (PFNGLGENFENCESNVPROC)glewGetProcAddress((const GLubyte*)"glGenFencesNV")) == NULL) || r; - r = ((glGetFenceivNV = (PFNGLGETFENCEIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetFenceivNV")) == NULL) || r; - r = ((glIsFenceNV = (PFNGLISFENCENVPROC)glewGetProcAddress((const GLubyte*)"glIsFenceNV")) == NULL) || r; - r = ((glSetFenceNV = (PFNGLSETFENCENVPROC)glewGetProcAddress((const GLubyte*)"glSetFenceNV")) == NULL) || r; - r = ((glTestFenceNV = (PFNGLTESTFENCENVPROC)glewGetProcAddress((const GLubyte*)"glTestFenceNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_fence */ - -#ifdef GL_NV_float_buffer - -#endif /* GL_NV_float_buffer */ - -#ifdef GL_NV_fog_distance - -#endif /* GL_NV_fog_distance */ - -#ifdef GL_NV_fragment_program - -static GLboolean _glewInit_GL_NV_fragment_program (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetProgramNamedParameterdvNV = (PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramNamedParameterdvNV")) == NULL) || r; - r = ((glGetProgramNamedParameterfvNV = (PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramNamedParameterfvNV")) == NULL) || r; - r = ((glProgramNamedParameter4dNV = (PFNGLPROGRAMNAMEDPARAMETER4DNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4dNV")) == NULL) || r; - r = ((glProgramNamedParameter4dvNV = (PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4dvNV")) == NULL) || r; - r = ((glProgramNamedParameter4fNV = (PFNGLPROGRAMNAMEDPARAMETER4FNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4fNV")) == NULL) || r; - r = ((glProgramNamedParameter4fvNV = (PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramNamedParameter4fvNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_fragment_program */ - -#ifdef GL_NV_fragment_program2 - -#endif /* GL_NV_fragment_program2 */ - -#ifdef GL_NV_fragment_program4 - -#endif /* GL_NV_fragment_program4 */ - -#ifdef GL_NV_fragment_program_option - -#endif /* GL_NV_fragment_program_option */ - -#ifdef GL_NV_framebuffer_multisample_coverage - -static GLboolean _glewInit_GL_NV_framebuffer_multisample_coverage (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glRenderbufferStorageMultisampleCoverageNV = (PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC)glewGetProcAddress((const GLubyte*)"glRenderbufferStorageMultisampleCoverageNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_framebuffer_multisample_coverage */ - -#ifdef GL_NV_geometry_program4 - -static GLboolean _glewInit_GL_NV_geometry_program4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glProgramVertexLimitNV = (PFNGLPROGRAMVERTEXLIMITNVPROC)glewGetProcAddress((const GLubyte*)"glProgramVertexLimitNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_geometry_program4 */ - -#ifdef GL_NV_geometry_shader4 - -#endif /* GL_NV_geometry_shader4 */ - -#ifdef GL_NV_gpu_program4 - -static GLboolean _glewInit_GL_NV_gpu_program4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glProgramEnvParameterI4iNV = (PFNGLPROGRAMENVPARAMETERI4INVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4iNV")) == NULL) || r; - r = ((glProgramEnvParameterI4ivNV = (PFNGLPROGRAMENVPARAMETERI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4ivNV")) == NULL) || r; - r = ((glProgramEnvParameterI4uiNV = (PFNGLPROGRAMENVPARAMETERI4UINVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4uiNV")) == NULL) || r; - r = ((glProgramEnvParameterI4uivNV = (PFNGLPROGRAMENVPARAMETERI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParameterI4uivNV")) == NULL) || r; - r = ((glProgramEnvParametersI4ivNV = (PFNGLPROGRAMENVPARAMETERSI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParametersI4ivNV")) == NULL) || r; - r = ((glProgramEnvParametersI4uivNV = (PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramEnvParametersI4uivNV")) == NULL) || r; - r = ((glProgramLocalParameterI4iNV = (PFNGLPROGRAMLOCALPARAMETERI4INVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4iNV")) == NULL) || r; - r = ((glProgramLocalParameterI4ivNV = (PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4ivNV")) == NULL) || r; - r = ((glProgramLocalParameterI4uiNV = (PFNGLPROGRAMLOCALPARAMETERI4UINVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4uiNV")) == NULL) || r; - r = ((glProgramLocalParameterI4uivNV = (PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParameterI4uivNV")) == NULL) || r; - r = ((glProgramLocalParametersI4ivNV = (PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParametersI4ivNV")) == NULL) || r; - r = ((glProgramLocalParametersI4uivNV = (PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramLocalParametersI4uivNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_gpu_program4 */ - -#ifdef GL_NV_gpu_program5 - -#endif /* GL_NV_gpu_program5 */ - -#ifdef GL_NV_gpu_program5_mem_extended - -#endif /* GL_NV_gpu_program5_mem_extended */ - -#ifdef GL_NV_gpu_program_fp64 - -#endif /* GL_NV_gpu_program_fp64 */ - -#ifdef GL_NV_gpu_shader5 - -static GLboolean _glewInit_GL_NV_gpu_shader5 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetUniformi64vNV = (PFNGLGETUNIFORMI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformi64vNV")) == NULL) || r; - r = ((glGetUniformui64vNV = (PFNGLGETUNIFORMUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetUniformui64vNV")) == NULL) || r; - r = ((glProgramUniform1i64NV = (PFNGLPROGRAMUNIFORM1I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1i64NV")) == NULL) || r; - r = ((glProgramUniform1i64vNV = (PFNGLPROGRAMUNIFORM1I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1i64vNV")) == NULL) || r; - r = ((glProgramUniform1ui64NV = (PFNGLPROGRAMUNIFORM1UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ui64NV")) == NULL) || r; - r = ((glProgramUniform1ui64vNV = (PFNGLPROGRAMUNIFORM1UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform1ui64vNV")) == NULL) || r; - r = ((glProgramUniform2i64NV = (PFNGLPROGRAMUNIFORM2I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2i64NV")) == NULL) || r; - r = ((glProgramUniform2i64vNV = (PFNGLPROGRAMUNIFORM2I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2i64vNV")) == NULL) || r; - r = ((glProgramUniform2ui64NV = (PFNGLPROGRAMUNIFORM2UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ui64NV")) == NULL) || r; - r = ((glProgramUniform2ui64vNV = (PFNGLPROGRAMUNIFORM2UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform2ui64vNV")) == NULL) || r; - r = ((glProgramUniform3i64NV = (PFNGLPROGRAMUNIFORM3I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3i64NV")) == NULL) || r; - r = ((glProgramUniform3i64vNV = (PFNGLPROGRAMUNIFORM3I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3i64vNV")) == NULL) || r; - r = ((glProgramUniform3ui64NV = (PFNGLPROGRAMUNIFORM3UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ui64NV")) == NULL) || r; - r = ((glProgramUniform3ui64vNV = (PFNGLPROGRAMUNIFORM3UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform3ui64vNV")) == NULL) || r; - r = ((glProgramUniform4i64NV = (PFNGLPROGRAMUNIFORM4I64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4i64NV")) == NULL) || r; - r = ((glProgramUniform4i64vNV = (PFNGLPROGRAMUNIFORM4I64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4i64vNV")) == NULL) || r; - r = ((glProgramUniform4ui64NV = (PFNGLPROGRAMUNIFORM4UI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ui64NV")) == NULL) || r; - r = ((glProgramUniform4ui64vNV = (PFNGLPROGRAMUNIFORM4UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniform4ui64vNV")) == NULL) || r; - r = ((glUniform1i64NV = (PFNGLUNIFORM1I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform1i64NV")) == NULL) || r; - r = ((glUniform1i64vNV = (PFNGLUNIFORM1I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform1i64vNV")) == NULL) || r; - r = ((glUniform1ui64NV = (PFNGLUNIFORM1UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform1ui64NV")) == NULL) || r; - r = ((glUniform1ui64vNV = (PFNGLUNIFORM1UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform1ui64vNV")) == NULL) || r; - r = ((glUniform2i64NV = (PFNGLUNIFORM2I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform2i64NV")) == NULL) || r; - r = ((glUniform2i64vNV = (PFNGLUNIFORM2I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform2i64vNV")) == NULL) || r; - r = ((glUniform2ui64NV = (PFNGLUNIFORM2UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform2ui64NV")) == NULL) || r; - r = ((glUniform2ui64vNV = (PFNGLUNIFORM2UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform2ui64vNV")) == NULL) || r; - r = ((glUniform3i64NV = (PFNGLUNIFORM3I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform3i64NV")) == NULL) || r; - r = ((glUniform3i64vNV = (PFNGLUNIFORM3I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform3i64vNV")) == NULL) || r; - r = ((glUniform3ui64NV = (PFNGLUNIFORM3UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform3ui64NV")) == NULL) || r; - r = ((glUniform3ui64vNV = (PFNGLUNIFORM3UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform3ui64vNV")) == NULL) || r; - r = ((glUniform4i64NV = (PFNGLUNIFORM4I64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform4i64NV")) == NULL) || r; - r = ((glUniform4i64vNV = (PFNGLUNIFORM4I64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform4i64vNV")) == NULL) || r; - r = ((glUniform4ui64NV = (PFNGLUNIFORM4UI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniform4ui64NV")) == NULL) || r; - r = ((glUniform4ui64vNV = (PFNGLUNIFORM4UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniform4ui64vNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_gpu_shader5 */ - -#ifdef GL_NV_half_float - -static GLboolean _glewInit_GL_NV_half_float (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColor3hNV = (PFNGLCOLOR3HNVPROC)glewGetProcAddress((const GLubyte*)"glColor3hNV")) == NULL) || r; - r = ((glColor3hvNV = (PFNGLCOLOR3HVNVPROC)glewGetProcAddress((const GLubyte*)"glColor3hvNV")) == NULL) || r; - r = ((glColor4hNV = (PFNGLCOLOR4HNVPROC)glewGetProcAddress((const GLubyte*)"glColor4hNV")) == NULL) || r; - r = ((glColor4hvNV = (PFNGLCOLOR4HVNVPROC)glewGetProcAddress((const GLubyte*)"glColor4hvNV")) == NULL) || r; - r = ((glFogCoordhNV = (PFNGLFOGCOORDHNVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordhNV")) == NULL) || r; - r = ((glFogCoordhvNV = (PFNGLFOGCOORDHVNVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordhvNV")) == NULL) || r; - r = ((glMultiTexCoord1hNV = (PFNGLMULTITEXCOORD1HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1hNV")) == NULL) || r; - r = ((glMultiTexCoord1hvNV = (PFNGLMULTITEXCOORD1HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord1hvNV")) == NULL) || r; - r = ((glMultiTexCoord2hNV = (PFNGLMULTITEXCOORD2HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2hNV")) == NULL) || r; - r = ((glMultiTexCoord2hvNV = (PFNGLMULTITEXCOORD2HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord2hvNV")) == NULL) || r; - r = ((glMultiTexCoord3hNV = (PFNGLMULTITEXCOORD3HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3hNV")) == NULL) || r; - r = ((glMultiTexCoord3hvNV = (PFNGLMULTITEXCOORD3HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord3hvNV")) == NULL) || r; - r = ((glMultiTexCoord4hNV = (PFNGLMULTITEXCOORD4HNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4hNV")) == NULL) || r; - r = ((glMultiTexCoord4hvNV = (PFNGLMULTITEXCOORD4HVNVPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4hvNV")) == NULL) || r; - r = ((glNormal3hNV = (PFNGLNORMAL3HNVPROC)glewGetProcAddress((const GLubyte*)"glNormal3hNV")) == NULL) || r; - r = ((glNormal3hvNV = (PFNGLNORMAL3HVNVPROC)glewGetProcAddress((const GLubyte*)"glNormal3hvNV")) == NULL) || r; - r = ((glSecondaryColor3hNV = (PFNGLSECONDARYCOLOR3HNVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3hNV")) == NULL) || r; - r = ((glSecondaryColor3hvNV = (PFNGLSECONDARYCOLOR3HVNVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColor3hvNV")) == NULL) || r; - r = ((glTexCoord1hNV = (PFNGLTEXCOORD1HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord1hNV")) == NULL) || r; - r = ((glTexCoord1hvNV = (PFNGLTEXCOORD1HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord1hvNV")) == NULL) || r; - r = ((glTexCoord2hNV = (PFNGLTEXCOORD2HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2hNV")) == NULL) || r; - r = ((glTexCoord2hvNV = (PFNGLTEXCOORD2HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2hvNV")) == NULL) || r; - r = ((glTexCoord3hNV = (PFNGLTEXCOORD3HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord3hNV")) == NULL) || r; - r = ((glTexCoord3hvNV = (PFNGLTEXCOORD3HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord3hvNV")) == NULL) || r; - r = ((glTexCoord4hNV = (PFNGLTEXCOORD4HNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4hNV")) == NULL) || r; - r = ((glTexCoord4hvNV = (PFNGLTEXCOORD4HVNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4hvNV")) == NULL) || r; - r = ((glVertex2hNV = (PFNGLVERTEX2HNVPROC)glewGetProcAddress((const GLubyte*)"glVertex2hNV")) == NULL) || r; - r = ((glVertex2hvNV = (PFNGLVERTEX2HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertex2hvNV")) == NULL) || r; - r = ((glVertex3hNV = (PFNGLVERTEX3HNVPROC)glewGetProcAddress((const GLubyte*)"glVertex3hNV")) == NULL) || r; - r = ((glVertex3hvNV = (PFNGLVERTEX3HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertex3hvNV")) == NULL) || r; - r = ((glVertex4hNV = (PFNGLVERTEX4HNVPROC)glewGetProcAddress((const GLubyte*)"glVertex4hNV")) == NULL) || r; - r = ((glVertex4hvNV = (PFNGLVERTEX4HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertex4hvNV")) == NULL) || r; - r = ((glVertexAttrib1hNV = (PFNGLVERTEXATTRIB1HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1hNV")) == NULL) || r; - r = ((glVertexAttrib1hvNV = (PFNGLVERTEXATTRIB1HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1hvNV")) == NULL) || r; - r = ((glVertexAttrib2hNV = (PFNGLVERTEXATTRIB2HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2hNV")) == NULL) || r; - r = ((glVertexAttrib2hvNV = (PFNGLVERTEXATTRIB2HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2hvNV")) == NULL) || r; - r = ((glVertexAttrib3hNV = (PFNGLVERTEXATTRIB3HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3hNV")) == NULL) || r; - r = ((glVertexAttrib3hvNV = (PFNGLVERTEXATTRIB3HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3hvNV")) == NULL) || r; - r = ((glVertexAttrib4hNV = (PFNGLVERTEXATTRIB4HNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4hNV")) == NULL) || r; - r = ((glVertexAttrib4hvNV = (PFNGLVERTEXATTRIB4HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4hvNV")) == NULL) || r; - r = ((glVertexAttribs1hvNV = (PFNGLVERTEXATTRIBS1HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1hvNV")) == NULL) || r; - r = ((glVertexAttribs2hvNV = (PFNGLVERTEXATTRIBS2HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2hvNV")) == NULL) || r; - r = ((glVertexAttribs3hvNV = (PFNGLVERTEXATTRIBS3HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3hvNV")) == NULL) || r; - r = ((glVertexAttribs4hvNV = (PFNGLVERTEXATTRIBS4HVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4hvNV")) == NULL) || r; - r = ((glVertexWeighthNV = (PFNGLVERTEXWEIGHTHNVPROC)glewGetProcAddress((const GLubyte*)"glVertexWeighthNV")) == NULL) || r; - r = ((glVertexWeighthvNV = (PFNGLVERTEXWEIGHTHVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexWeighthvNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_half_float */ - -#ifdef GL_NV_light_max_exponent - -#endif /* GL_NV_light_max_exponent */ - -#ifdef GL_NV_multisample_coverage - -#endif /* GL_NV_multisample_coverage */ - -#ifdef GL_NV_multisample_filter_hint - -#endif /* GL_NV_multisample_filter_hint */ - -#ifdef GL_NV_occlusion_query - -static GLboolean _glewInit_GL_NV_occlusion_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginOcclusionQueryNV = (PFNGLBEGINOCCLUSIONQUERYNVPROC)glewGetProcAddress((const GLubyte*)"glBeginOcclusionQueryNV")) == NULL) || r; - r = ((glDeleteOcclusionQueriesNV = (PFNGLDELETEOCCLUSIONQUERIESNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteOcclusionQueriesNV")) == NULL) || r; - r = ((glEndOcclusionQueryNV = (PFNGLENDOCCLUSIONQUERYNVPROC)glewGetProcAddress((const GLubyte*)"glEndOcclusionQueryNV")) == NULL) || r; - r = ((glGenOcclusionQueriesNV = (PFNGLGENOCCLUSIONQUERIESNVPROC)glewGetProcAddress((const GLubyte*)"glGenOcclusionQueriesNV")) == NULL) || r; - r = ((glGetOcclusionQueryivNV = (PFNGLGETOCCLUSIONQUERYIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetOcclusionQueryivNV")) == NULL) || r; - r = ((glGetOcclusionQueryuivNV = (PFNGLGETOCCLUSIONQUERYUIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetOcclusionQueryuivNV")) == NULL) || r; - r = ((glIsOcclusionQueryNV = (PFNGLISOCCLUSIONQUERYNVPROC)glewGetProcAddress((const GLubyte*)"glIsOcclusionQueryNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_occlusion_query */ - -#ifdef GL_NV_packed_depth_stencil - -#endif /* GL_NV_packed_depth_stencil */ - -#ifdef GL_NV_parameter_buffer_object - -static GLboolean _glewInit_GL_NV_parameter_buffer_object (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glProgramBufferParametersIivNV = (PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramBufferParametersIivNV")) == NULL) || r; - r = ((glProgramBufferParametersIuivNV = (PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramBufferParametersIuivNV")) == NULL) || r; - r = ((glProgramBufferParametersfvNV = (PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramBufferParametersfvNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_parameter_buffer_object */ - -#ifdef GL_NV_parameter_buffer_object2 - -#endif /* GL_NV_parameter_buffer_object2 */ - -#ifdef GL_NV_path_rendering - -static GLboolean _glewInit_GL_NV_path_rendering (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCopyPathNV = (PFNGLCOPYPATHNVPROC)glewGetProcAddress((const GLubyte*)"glCopyPathNV")) == NULL) || r; - r = ((glCoverFillPathInstancedNV = (PFNGLCOVERFILLPATHINSTANCEDNVPROC)glewGetProcAddress((const GLubyte*)"glCoverFillPathInstancedNV")) == NULL) || r; - r = ((glCoverFillPathNV = (PFNGLCOVERFILLPATHNVPROC)glewGetProcAddress((const GLubyte*)"glCoverFillPathNV")) == NULL) || r; - r = ((glCoverStrokePathInstancedNV = (PFNGLCOVERSTROKEPATHINSTANCEDNVPROC)glewGetProcAddress((const GLubyte*)"glCoverStrokePathInstancedNV")) == NULL) || r; - r = ((glCoverStrokePathNV = (PFNGLCOVERSTROKEPATHNVPROC)glewGetProcAddress((const GLubyte*)"glCoverStrokePathNV")) == NULL) || r; - r = ((glDeletePathsNV = (PFNGLDELETEPATHSNVPROC)glewGetProcAddress((const GLubyte*)"glDeletePathsNV")) == NULL) || r; - r = ((glGenPathsNV = (PFNGLGENPATHSNVPROC)glewGetProcAddress((const GLubyte*)"glGenPathsNV")) == NULL) || r; - r = ((glGetPathColorGenfvNV = (PFNGLGETPATHCOLORGENFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathColorGenfvNV")) == NULL) || r; - r = ((glGetPathColorGenivNV = (PFNGLGETPATHCOLORGENIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathColorGenivNV")) == NULL) || r; - r = ((glGetPathCommandsNV = (PFNGLGETPATHCOMMANDSNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathCommandsNV")) == NULL) || r; - r = ((glGetPathCoordsNV = (PFNGLGETPATHCOORDSNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathCoordsNV")) == NULL) || r; - r = ((glGetPathDashArrayNV = (PFNGLGETPATHDASHARRAYNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathDashArrayNV")) == NULL) || r; - r = ((glGetPathLengthNV = (PFNGLGETPATHLENGTHNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathLengthNV")) == NULL) || r; - r = ((glGetPathMetricRangeNV = (PFNGLGETPATHMETRICRANGENVPROC)glewGetProcAddress((const GLubyte*)"glGetPathMetricRangeNV")) == NULL) || r; - r = ((glGetPathMetricsNV = (PFNGLGETPATHMETRICSNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathMetricsNV")) == NULL) || r; - r = ((glGetPathParameterfvNV = (PFNGLGETPATHPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathParameterfvNV")) == NULL) || r; - r = ((glGetPathParameterivNV = (PFNGLGETPATHPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathParameterivNV")) == NULL) || r; - r = ((glGetPathSpacingNV = (PFNGLGETPATHSPACINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathSpacingNV")) == NULL) || r; - r = ((glGetPathTexGenfvNV = (PFNGLGETPATHTEXGENFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathTexGenfvNV")) == NULL) || r; - r = ((glGetPathTexGenivNV = (PFNGLGETPATHTEXGENIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetPathTexGenivNV")) == NULL) || r; - r = ((glInterpolatePathsNV = (PFNGLINTERPOLATEPATHSNVPROC)glewGetProcAddress((const GLubyte*)"glInterpolatePathsNV")) == NULL) || r; - r = ((glIsPathNV = (PFNGLISPATHNVPROC)glewGetProcAddress((const GLubyte*)"glIsPathNV")) == NULL) || r; - r = ((glIsPointInFillPathNV = (PFNGLISPOINTINFILLPATHNVPROC)glewGetProcAddress((const GLubyte*)"glIsPointInFillPathNV")) == NULL) || r; - r = ((glIsPointInStrokePathNV = (PFNGLISPOINTINSTROKEPATHNVPROC)glewGetProcAddress((const GLubyte*)"glIsPointInStrokePathNV")) == NULL) || r; - r = ((glPathColorGenNV = (PFNGLPATHCOLORGENNVPROC)glewGetProcAddress((const GLubyte*)"glPathColorGenNV")) == NULL) || r; - r = ((glPathCommandsNV = (PFNGLPATHCOMMANDSNVPROC)glewGetProcAddress((const GLubyte*)"glPathCommandsNV")) == NULL) || r; - r = ((glPathCoordsNV = (PFNGLPATHCOORDSNVPROC)glewGetProcAddress((const GLubyte*)"glPathCoordsNV")) == NULL) || r; - r = ((glPathCoverDepthFuncNV = (PFNGLPATHCOVERDEPTHFUNCNVPROC)glewGetProcAddress((const GLubyte*)"glPathCoverDepthFuncNV")) == NULL) || r; - r = ((glPathDashArrayNV = (PFNGLPATHDASHARRAYNVPROC)glewGetProcAddress((const GLubyte*)"glPathDashArrayNV")) == NULL) || r; - r = ((glPathFogGenNV = (PFNGLPATHFOGGENNVPROC)glewGetProcAddress((const GLubyte*)"glPathFogGenNV")) == NULL) || r; - r = ((glPathGlyphRangeNV = (PFNGLPATHGLYPHRANGENVPROC)glewGetProcAddress((const GLubyte*)"glPathGlyphRangeNV")) == NULL) || r; - r = ((glPathGlyphsNV = (PFNGLPATHGLYPHSNVPROC)glewGetProcAddress((const GLubyte*)"glPathGlyphsNV")) == NULL) || r; - r = ((glPathParameterfNV = (PFNGLPATHPARAMETERFNVPROC)glewGetProcAddress((const GLubyte*)"glPathParameterfNV")) == NULL) || r; - r = ((glPathParameterfvNV = (PFNGLPATHPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glPathParameterfvNV")) == NULL) || r; - r = ((glPathParameteriNV = (PFNGLPATHPARAMETERINVPROC)glewGetProcAddress((const GLubyte*)"glPathParameteriNV")) == NULL) || r; - r = ((glPathParameterivNV = (PFNGLPATHPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glPathParameterivNV")) == NULL) || r; - r = ((glPathStencilDepthOffsetNV = (PFNGLPATHSTENCILDEPTHOFFSETNVPROC)glewGetProcAddress((const GLubyte*)"glPathStencilDepthOffsetNV")) == NULL) || r; - r = ((glPathStencilFuncNV = (PFNGLPATHSTENCILFUNCNVPROC)glewGetProcAddress((const GLubyte*)"glPathStencilFuncNV")) == NULL) || r; - r = ((glPathStringNV = (PFNGLPATHSTRINGNVPROC)glewGetProcAddress((const GLubyte*)"glPathStringNV")) == NULL) || r; - r = ((glPathSubCommandsNV = (PFNGLPATHSUBCOMMANDSNVPROC)glewGetProcAddress((const GLubyte*)"glPathSubCommandsNV")) == NULL) || r; - r = ((glPathSubCoordsNV = (PFNGLPATHSUBCOORDSNVPROC)glewGetProcAddress((const GLubyte*)"glPathSubCoordsNV")) == NULL) || r; - r = ((glPathTexGenNV = (PFNGLPATHTEXGENNVPROC)glewGetProcAddress((const GLubyte*)"glPathTexGenNV")) == NULL) || r; - r = ((glPointAlongPathNV = (PFNGLPOINTALONGPATHNVPROC)glewGetProcAddress((const GLubyte*)"glPointAlongPathNV")) == NULL) || r; - r = ((glStencilFillPathInstancedNV = (PFNGLSTENCILFILLPATHINSTANCEDNVPROC)glewGetProcAddress((const GLubyte*)"glStencilFillPathInstancedNV")) == NULL) || r; - r = ((glStencilFillPathNV = (PFNGLSTENCILFILLPATHNVPROC)glewGetProcAddress((const GLubyte*)"glStencilFillPathNV")) == NULL) || r; - r = ((glStencilStrokePathInstancedNV = (PFNGLSTENCILSTROKEPATHINSTANCEDNVPROC)glewGetProcAddress((const GLubyte*)"glStencilStrokePathInstancedNV")) == NULL) || r; - r = ((glStencilStrokePathNV = (PFNGLSTENCILSTROKEPATHNVPROC)glewGetProcAddress((const GLubyte*)"glStencilStrokePathNV")) == NULL) || r; - r = ((glTransformPathNV = (PFNGLTRANSFORMPATHNVPROC)glewGetProcAddress((const GLubyte*)"glTransformPathNV")) == NULL) || r; - r = ((glWeightPathsNV = (PFNGLWEIGHTPATHSNVPROC)glewGetProcAddress((const GLubyte*)"glWeightPathsNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_path_rendering */ - -#ifdef GL_NV_pixel_data_range - -static GLboolean _glewInit_GL_NV_pixel_data_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFlushPixelDataRangeNV = (PFNGLFLUSHPIXELDATARANGENVPROC)glewGetProcAddress((const GLubyte*)"glFlushPixelDataRangeNV")) == NULL) || r; - r = ((glPixelDataRangeNV = (PFNGLPIXELDATARANGENVPROC)glewGetProcAddress((const GLubyte*)"glPixelDataRangeNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_pixel_data_range */ - -#ifdef GL_NV_point_sprite - -static GLboolean _glewInit_GL_NV_point_sprite (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPointParameteriNV = (PFNGLPOINTPARAMETERINVPROC)glewGetProcAddress((const GLubyte*)"glPointParameteriNV")) == NULL) || r; - r = ((glPointParameterivNV = (PFNGLPOINTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glPointParameterivNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_point_sprite */ - -#ifdef GL_NV_present_video - -static GLboolean _glewInit_GL_NV_present_video (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetVideoi64vNV = (PFNGLGETVIDEOI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoi64vNV")) == NULL) || r; - r = ((glGetVideoivNV = (PFNGLGETVIDEOIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoivNV")) == NULL) || r; - r = ((glGetVideoui64vNV = (PFNGLGETVIDEOUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoui64vNV")) == NULL) || r; - r = ((glGetVideouivNV = (PFNGLGETVIDEOUIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideouivNV")) == NULL) || r; - r = ((glPresentFrameDualFillNV = (PFNGLPRESENTFRAMEDUALFILLNVPROC)glewGetProcAddress((const GLubyte*)"glPresentFrameDualFillNV")) == NULL) || r; - r = ((glPresentFrameKeyedNV = (PFNGLPRESENTFRAMEKEYEDNVPROC)glewGetProcAddress((const GLubyte*)"glPresentFrameKeyedNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_present_video */ - -#ifdef GL_NV_primitive_restart - -static GLboolean _glewInit_GL_NV_primitive_restart (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPrimitiveRestartIndexNV = (PFNGLPRIMITIVERESTARTINDEXNVPROC)glewGetProcAddress((const GLubyte*)"glPrimitiveRestartIndexNV")) == NULL) || r; - r = ((glPrimitiveRestartNV = (PFNGLPRIMITIVERESTARTNVPROC)glewGetProcAddress((const GLubyte*)"glPrimitiveRestartNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_primitive_restart */ - -#ifdef GL_NV_register_combiners - -static GLboolean _glewInit_GL_NV_register_combiners (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCombinerInputNV = (PFNGLCOMBINERINPUTNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerInputNV")) == NULL) || r; - r = ((glCombinerOutputNV = (PFNGLCOMBINEROUTPUTNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerOutputNV")) == NULL) || r; - r = ((glCombinerParameterfNV = (PFNGLCOMBINERPARAMETERFNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameterfNV")) == NULL) || r; - r = ((glCombinerParameterfvNV = (PFNGLCOMBINERPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameterfvNV")) == NULL) || r; - r = ((glCombinerParameteriNV = (PFNGLCOMBINERPARAMETERINVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameteriNV")) == NULL) || r; - r = ((glCombinerParameterivNV = (PFNGLCOMBINERPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerParameterivNV")) == NULL) || r; - r = ((glFinalCombinerInputNV = (PFNGLFINALCOMBINERINPUTNVPROC)glewGetProcAddress((const GLubyte*)"glFinalCombinerInputNV")) == NULL) || r; - r = ((glGetCombinerInputParameterfvNV = (PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerInputParameterfvNV")) == NULL) || r; - r = ((glGetCombinerInputParameterivNV = (PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerInputParameterivNV")) == NULL) || r; - r = ((glGetCombinerOutputParameterfvNV = (PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerOutputParameterfvNV")) == NULL) || r; - r = ((glGetCombinerOutputParameterivNV = (PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerOutputParameterivNV")) == NULL) || r; - r = ((glGetFinalCombinerInputParameterfvNV = (PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetFinalCombinerInputParameterfvNV")) == NULL) || r; - r = ((glGetFinalCombinerInputParameterivNV = (PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetFinalCombinerInputParameterivNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_register_combiners */ - -#ifdef GL_NV_register_combiners2 - -static GLboolean _glewInit_GL_NV_register_combiners2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glCombinerStageParameterfvNV = (PFNGLCOMBINERSTAGEPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glCombinerStageParameterfvNV")) == NULL) || r; - r = ((glGetCombinerStageParameterfvNV = (PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetCombinerStageParameterfvNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_register_combiners2 */ - -#ifdef GL_NV_shader_atomic_counters - -#endif /* GL_NV_shader_atomic_counters */ - -#ifdef GL_NV_shader_atomic_float - -#endif /* GL_NV_shader_atomic_float */ - -#ifdef GL_NV_shader_buffer_load - -static GLboolean _glewInit_GL_NV_shader_buffer_load (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetBufferParameterui64vNV = (PFNGLGETBUFFERPARAMETERUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetBufferParameterui64vNV")) == NULL) || r; - r = ((glGetIntegerui64vNV = (PFNGLGETINTEGERUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetIntegerui64vNV")) == NULL) || r; - r = ((glGetNamedBufferParameterui64vNV = (PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetNamedBufferParameterui64vNV")) == NULL) || r; - r = ((glIsBufferResidentNV = (PFNGLISBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glIsBufferResidentNV")) == NULL) || r; - r = ((glIsNamedBufferResidentNV = (PFNGLISNAMEDBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glIsNamedBufferResidentNV")) == NULL) || r; - r = ((glMakeBufferNonResidentNV = (PFNGLMAKEBUFFERNONRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeBufferNonResidentNV")) == NULL) || r; - r = ((glMakeBufferResidentNV = (PFNGLMAKEBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeBufferResidentNV")) == NULL) || r; - r = ((glMakeNamedBufferNonResidentNV = (PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeNamedBufferNonResidentNV")) == NULL) || r; - r = ((glMakeNamedBufferResidentNV = (PFNGLMAKENAMEDBUFFERRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glMakeNamedBufferResidentNV")) == NULL) || r; - r = ((glProgramUniformui64NV = (PFNGLPROGRAMUNIFORMUI64NVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformui64NV")) == NULL) || r; - r = ((glProgramUniformui64vNV = (PFNGLPROGRAMUNIFORMUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glProgramUniformui64vNV")) == NULL) || r; - r = ((glUniformui64NV = (PFNGLUNIFORMUI64NVPROC)glewGetProcAddress((const GLubyte*)"glUniformui64NV")) == NULL) || r; - r = ((glUniformui64vNV = (PFNGLUNIFORMUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glUniformui64vNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_shader_buffer_load */ - -#ifdef GL_NV_shader_storage_buffer_object - -#endif /* GL_NV_shader_storage_buffer_object */ - -#ifdef GL_NV_tessellation_program5 - -#endif /* GL_NV_tessellation_program5 */ - -#ifdef GL_NV_texgen_emboss - -#endif /* GL_NV_texgen_emboss */ - -#ifdef GL_NV_texgen_reflection - -#endif /* GL_NV_texgen_reflection */ - -#ifdef GL_NV_texture_barrier - -static GLboolean _glewInit_GL_NV_texture_barrier (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTextureBarrierNV = (PFNGLTEXTUREBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"glTextureBarrierNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_texture_barrier */ - -#ifdef GL_NV_texture_compression_vtc - -#endif /* GL_NV_texture_compression_vtc */ - -#ifdef GL_NV_texture_env_combine4 - -#endif /* GL_NV_texture_env_combine4 */ - -#ifdef GL_NV_texture_expand_normal - -#endif /* GL_NV_texture_expand_normal */ - -#ifdef GL_NV_texture_multisample - -static GLboolean _glewInit_GL_NV_texture_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexImage2DMultisampleCoverageNV = (PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC)glewGetProcAddress((const GLubyte*)"glTexImage2DMultisampleCoverageNV")) == NULL) || r; - r = ((glTexImage3DMultisampleCoverageNV = (PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC)glewGetProcAddress((const GLubyte*)"glTexImage3DMultisampleCoverageNV")) == NULL) || r; - r = ((glTextureImage2DMultisampleCoverageNV = (PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC)glewGetProcAddress((const GLubyte*)"glTextureImage2DMultisampleCoverageNV")) == NULL) || r; - r = ((glTextureImage2DMultisampleNV = (PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC)glewGetProcAddress((const GLubyte*)"glTextureImage2DMultisampleNV")) == NULL) || r; - r = ((glTextureImage3DMultisampleCoverageNV = (PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC)glewGetProcAddress((const GLubyte*)"glTextureImage3DMultisampleCoverageNV")) == NULL) || r; - r = ((glTextureImage3DMultisampleNV = (PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC)glewGetProcAddress((const GLubyte*)"glTextureImage3DMultisampleNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_texture_multisample */ - -#ifdef GL_NV_texture_rectangle - -#endif /* GL_NV_texture_rectangle */ - -#ifdef GL_NV_texture_shader - -#endif /* GL_NV_texture_shader */ - -#ifdef GL_NV_texture_shader2 - -#endif /* GL_NV_texture_shader2 */ - -#ifdef GL_NV_texture_shader3 - -#endif /* GL_NV_texture_shader3 */ - -#ifdef GL_NV_transform_feedback - -static GLboolean _glewInit_GL_NV_transform_feedback (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glActiveVaryingNV = (PFNGLACTIVEVARYINGNVPROC)glewGetProcAddress((const GLubyte*)"glActiveVaryingNV")) == NULL) || r; - r = ((glBeginTransformFeedbackNV = (PFNGLBEGINTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glBeginTransformFeedbackNV")) == NULL) || r; - r = ((glBindBufferBaseNV = (PFNGLBINDBUFFERBASENVPROC)glewGetProcAddress((const GLubyte*)"glBindBufferBaseNV")) == NULL) || r; - r = ((glBindBufferOffsetNV = (PFNGLBINDBUFFEROFFSETNVPROC)glewGetProcAddress((const GLubyte*)"glBindBufferOffsetNV")) == NULL) || r; - r = ((glBindBufferRangeNV = (PFNGLBINDBUFFERRANGENVPROC)glewGetProcAddress((const GLubyte*)"glBindBufferRangeNV")) == NULL) || r; - r = ((glEndTransformFeedbackNV = (PFNGLENDTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glEndTransformFeedbackNV")) == NULL) || r; - r = ((glGetActiveVaryingNV = (PFNGLGETACTIVEVARYINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetActiveVaryingNV")) == NULL) || r; - r = ((glGetTransformFeedbackVaryingNV = (PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetTransformFeedbackVaryingNV")) == NULL) || r; - r = ((glGetVaryingLocationNV = (PFNGLGETVARYINGLOCATIONNVPROC)glewGetProcAddress((const GLubyte*)"glGetVaryingLocationNV")) == NULL) || r; - r = ((glTransformFeedbackAttribsNV = (PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackAttribsNV")) == NULL) || r; - r = ((glTransformFeedbackVaryingsNV = (PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC)glewGetProcAddress((const GLubyte*)"glTransformFeedbackVaryingsNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_transform_feedback */ - -#ifdef GL_NV_transform_feedback2 - -static GLboolean _glewInit_GL_NV_transform_feedback2 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBindTransformFeedbackNV = (PFNGLBINDTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glBindTransformFeedbackNV")) == NULL) || r; - r = ((glDeleteTransformFeedbacksNV = (PFNGLDELETETRANSFORMFEEDBACKSNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteTransformFeedbacksNV")) == NULL) || r; - r = ((glDrawTransformFeedbackNV = (PFNGLDRAWTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glDrawTransformFeedbackNV")) == NULL) || r; - r = ((glGenTransformFeedbacksNV = (PFNGLGENTRANSFORMFEEDBACKSNVPROC)glewGetProcAddress((const GLubyte*)"glGenTransformFeedbacksNV")) == NULL) || r; - r = ((glIsTransformFeedbackNV = (PFNGLISTRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glIsTransformFeedbackNV")) == NULL) || r; - r = ((glPauseTransformFeedbackNV = (PFNGLPAUSETRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glPauseTransformFeedbackNV")) == NULL) || r; - r = ((glResumeTransformFeedbackNV = (PFNGLRESUMETRANSFORMFEEDBACKNVPROC)glewGetProcAddress((const GLubyte*)"glResumeTransformFeedbackNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_transform_feedback2 */ - -#ifdef GL_NV_vdpau_interop - -static GLboolean _glewInit_GL_NV_vdpau_interop (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glVDPAUFiniNV = (PFNGLVDPAUFININVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUFiniNV")) == NULL) || r; - r = ((glVDPAUGetSurfaceivNV = (PFNGLVDPAUGETSURFACEIVNVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUGetSurfaceivNV")) == NULL) || r; - r = ((glVDPAUInitNV = (PFNGLVDPAUINITNVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUInitNV")) == NULL) || r; - r = ((glVDPAUIsSurfaceNV = (PFNGLVDPAUISSURFACENVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUIsSurfaceNV")) == NULL) || r; - r = ((glVDPAUMapSurfacesNV = (PFNGLVDPAUMAPSURFACESNVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUMapSurfacesNV")) == NULL) || r; - r = ((glVDPAURegisterOutputSurfaceNV = (PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC)glewGetProcAddress((const GLubyte*)"glVDPAURegisterOutputSurfaceNV")) == NULL) || r; - r = ((glVDPAURegisterVideoSurfaceNV = (PFNGLVDPAUREGISTERVIDEOSURFACENVPROC)glewGetProcAddress((const GLubyte*)"glVDPAURegisterVideoSurfaceNV")) == NULL) || r; - r = ((glVDPAUSurfaceAccessNV = (PFNGLVDPAUSURFACEACCESSNVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUSurfaceAccessNV")) == NULL) || r; - r = ((glVDPAUUnmapSurfacesNV = (PFNGLVDPAUUNMAPSURFACESNVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUUnmapSurfacesNV")) == NULL) || r; - r = ((glVDPAUUnregisterSurfaceNV = (PFNGLVDPAUUNREGISTERSURFACENVPROC)glewGetProcAddress((const GLubyte*)"glVDPAUUnregisterSurfaceNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_vdpau_interop */ - -#ifdef GL_NV_vertex_array_range - -static GLboolean _glewInit_GL_NV_vertex_array_range (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFlushVertexArrayRangeNV = (PFNGLFLUSHVERTEXARRAYRANGENVPROC)glewGetProcAddress((const GLubyte*)"glFlushVertexArrayRangeNV")) == NULL) || r; - r = ((glVertexArrayRangeNV = (PFNGLVERTEXARRAYRANGENVPROC)glewGetProcAddress((const GLubyte*)"glVertexArrayRangeNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_vertex_array_range */ - -#ifdef GL_NV_vertex_array_range2 - -#endif /* GL_NV_vertex_array_range2 */ - -#ifdef GL_NV_vertex_attrib_integer_64bit - -static GLboolean _glewInit_GL_NV_vertex_attrib_integer_64bit (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetVertexAttribLi64vNV = (PFNGLGETVERTEXATTRIBLI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLi64vNV")) == NULL) || r; - r = ((glGetVertexAttribLui64vNV = (PFNGLGETVERTEXATTRIBLUI64VNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribLui64vNV")) == NULL) || r; - r = ((glVertexAttribL1i64NV = (PFNGLVERTEXATTRIBL1I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1i64NV")) == NULL) || r; - r = ((glVertexAttribL1i64vNV = (PFNGLVERTEXATTRIBL1I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1i64vNV")) == NULL) || r; - r = ((glVertexAttribL1ui64NV = (PFNGLVERTEXATTRIBL1UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1ui64NV")) == NULL) || r; - r = ((glVertexAttribL1ui64vNV = (PFNGLVERTEXATTRIBL1UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL1ui64vNV")) == NULL) || r; - r = ((glVertexAttribL2i64NV = (PFNGLVERTEXATTRIBL2I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2i64NV")) == NULL) || r; - r = ((glVertexAttribL2i64vNV = (PFNGLVERTEXATTRIBL2I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2i64vNV")) == NULL) || r; - r = ((glVertexAttribL2ui64NV = (PFNGLVERTEXATTRIBL2UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2ui64NV")) == NULL) || r; - r = ((glVertexAttribL2ui64vNV = (PFNGLVERTEXATTRIBL2UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL2ui64vNV")) == NULL) || r; - r = ((glVertexAttribL3i64NV = (PFNGLVERTEXATTRIBL3I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3i64NV")) == NULL) || r; - r = ((glVertexAttribL3i64vNV = (PFNGLVERTEXATTRIBL3I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3i64vNV")) == NULL) || r; - r = ((glVertexAttribL3ui64NV = (PFNGLVERTEXATTRIBL3UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3ui64NV")) == NULL) || r; - r = ((glVertexAttribL3ui64vNV = (PFNGLVERTEXATTRIBL3UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL3ui64vNV")) == NULL) || r; - r = ((glVertexAttribL4i64NV = (PFNGLVERTEXATTRIBL4I64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4i64NV")) == NULL) || r; - r = ((glVertexAttribL4i64vNV = (PFNGLVERTEXATTRIBL4I64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4i64vNV")) == NULL) || r; - r = ((glVertexAttribL4ui64NV = (PFNGLVERTEXATTRIBL4UI64NVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4ui64NV")) == NULL) || r; - r = ((glVertexAttribL4ui64vNV = (PFNGLVERTEXATTRIBL4UI64VNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribL4ui64vNV")) == NULL) || r; - r = ((glVertexAttribLFormatNV = (PFNGLVERTEXATTRIBLFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribLFormatNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_vertex_attrib_integer_64bit */ - -#ifdef GL_NV_vertex_buffer_unified_memory - -static GLboolean _glewInit_GL_NV_vertex_buffer_unified_memory (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBufferAddressRangeNV = (PFNGLBUFFERADDRESSRANGENVPROC)glewGetProcAddress((const GLubyte*)"glBufferAddressRangeNV")) == NULL) || r; - r = ((glColorFormatNV = (PFNGLCOLORFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glColorFormatNV")) == NULL) || r; - r = ((glEdgeFlagFormatNV = (PFNGLEDGEFLAGFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glEdgeFlagFormatNV")) == NULL) || r; - r = ((glFogCoordFormatNV = (PFNGLFOGCOORDFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glFogCoordFormatNV")) == NULL) || r; - r = ((glGetIntegerui64i_vNV = (PFNGLGETINTEGERUI64I_VNVPROC)glewGetProcAddress((const GLubyte*)"glGetIntegerui64i_vNV")) == NULL) || r; - r = ((glIndexFormatNV = (PFNGLINDEXFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glIndexFormatNV")) == NULL) || r; - r = ((glNormalFormatNV = (PFNGLNORMALFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glNormalFormatNV")) == NULL) || r; - r = ((glSecondaryColorFormatNV = (PFNGLSECONDARYCOLORFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glSecondaryColorFormatNV")) == NULL) || r; - r = ((glTexCoordFormatNV = (PFNGLTEXCOORDFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glTexCoordFormatNV")) == NULL) || r; - r = ((glVertexAttribFormatNV = (PFNGLVERTEXATTRIBFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribFormatNV")) == NULL) || r; - r = ((glVertexAttribIFormatNV = (PFNGLVERTEXATTRIBIFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribIFormatNV")) == NULL) || r; - r = ((glVertexFormatNV = (PFNGLVERTEXFORMATNVPROC)glewGetProcAddress((const GLubyte*)"glVertexFormatNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_vertex_buffer_unified_memory */ - -#ifdef GL_NV_vertex_program - -static GLboolean _glewInit_GL_NV_vertex_program (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAreProgramsResidentNV = (PFNGLAREPROGRAMSRESIDENTNVPROC)glewGetProcAddress((const GLubyte*)"glAreProgramsResidentNV")) == NULL) || r; - r = ((glBindProgramNV = (PFNGLBINDPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glBindProgramNV")) == NULL) || r; - r = ((glDeleteProgramsNV = (PFNGLDELETEPROGRAMSNVPROC)glewGetProcAddress((const GLubyte*)"glDeleteProgramsNV")) == NULL) || r; - r = ((glExecuteProgramNV = (PFNGLEXECUTEPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glExecuteProgramNV")) == NULL) || r; - r = ((glGenProgramsNV = (PFNGLGENPROGRAMSNVPROC)glewGetProcAddress((const GLubyte*)"glGenProgramsNV")) == NULL) || r; - r = ((glGetProgramParameterdvNV = (PFNGLGETPROGRAMPARAMETERDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramParameterdvNV")) == NULL) || r; - r = ((glGetProgramParameterfvNV = (PFNGLGETPROGRAMPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramParameterfvNV")) == NULL) || r; - r = ((glGetProgramStringNV = (PFNGLGETPROGRAMSTRINGNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramStringNV")) == NULL) || r; - r = ((glGetProgramivNV = (PFNGLGETPROGRAMIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetProgramivNV")) == NULL) || r; - r = ((glGetTrackMatrixivNV = (PFNGLGETTRACKMATRIXIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetTrackMatrixivNV")) == NULL) || r; - r = ((glGetVertexAttribPointervNV = (PFNGLGETVERTEXATTRIBPOINTERVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribPointervNV")) == NULL) || r; - r = ((glGetVertexAttribdvNV = (PFNGLGETVERTEXATTRIBDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribdvNV")) == NULL) || r; - r = ((glGetVertexAttribfvNV = (PFNGLGETVERTEXATTRIBFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribfvNV")) == NULL) || r; - r = ((glGetVertexAttribivNV = (PFNGLGETVERTEXATTRIBIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVertexAttribivNV")) == NULL) || r; - r = ((glIsProgramNV = (PFNGLISPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glIsProgramNV")) == NULL) || r; - r = ((glLoadProgramNV = (PFNGLLOADPROGRAMNVPROC)glewGetProcAddress((const GLubyte*)"glLoadProgramNV")) == NULL) || r; - r = ((glProgramParameter4dNV = (PFNGLPROGRAMPARAMETER4DNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4dNV")) == NULL) || r; - r = ((glProgramParameter4dvNV = (PFNGLPROGRAMPARAMETER4DVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4dvNV")) == NULL) || r; - r = ((glProgramParameter4fNV = (PFNGLPROGRAMPARAMETER4FNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4fNV")) == NULL) || r; - r = ((glProgramParameter4fvNV = (PFNGLPROGRAMPARAMETER4FVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameter4fvNV")) == NULL) || r; - r = ((glProgramParameters4dvNV = (PFNGLPROGRAMPARAMETERS4DVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameters4dvNV")) == NULL) || r; - r = ((glProgramParameters4fvNV = (PFNGLPROGRAMPARAMETERS4FVNVPROC)glewGetProcAddress((const GLubyte*)"glProgramParameters4fvNV")) == NULL) || r; - r = ((glRequestResidentProgramsNV = (PFNGLREQUESTRESIDENTPROGRAMSNVPROC)glewGetProcAddress((const GLubyte*)"glRequestResidentProgramsNV")) == NULL) || r; - r = ((glTrackMatrixNV = (PFNGLTRACKMATRIXNVPROC)glewGetProcAddress((const GLubyte*)"glTrackMatrixNV")) == NULL) || r; - r = ((glVertexAttrib1dNV = (PFNGLVERTEXATTRIB1DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dNV")) == NULL) || r; - r = ((glVertexAttrib1dvNV = (PFNGLVERTEXATTRIB1DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1dvNV")) == NULL) || r; - r = ((glVertexAttrib1fNV = (PFNGLVERTEXATTRIB1FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fNV")) == NULL) || r; - r = ((glVertexAttrib1fvNV = (PFNGLVERTEXATTRIB1FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1fvNV")) == NULL) || r; - r = ((glVertexAttrib1sNV = (PFNGLVERTEXATTRIB1SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1sNV")) == NULL) || r; - r = ((glVertexAttrib1svNV = (PFNGLVERTEXATTRIB1SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib1svNV")) == NULL) || r; - r = ((glVertexAttrib2dNV = (PFNGLVERTEXATTRIB2DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dNV")) == NULL) || r; - r = ((glVertexAttrib2dvNV = (PFNGLVERTEXATTRIB2DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2dvNV")) == NULL) || r; - r = ((glVertexAttrib2fNV = (PFNGLVERTEXATTRIB2FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fNV")) == NULL) || r; - r = ((glVertexAttrib2fvNV = (PFNGLVERTEXATTRIB2FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2fvNV")) == NULL) || r; - r = ((glVertexAttrib2sNV = (PFNGLVERTEXATTRIB2SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2sNV")) == NULL) || r; - r = ((glVertexAttrib2svNV = (PFNGLVERTEXATTRIB2SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib2svNV")) == NULL) || r; - r = ((glVertexAttrib3dNV = (PFNGLVERTEXATTRIB3DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dNV")) == NULL) || r; - r = ((glVertexAttrib3dvNV = (PFNGLVERTEXATTRIB3DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3dvNV")) == NULL) || r; - r = ((glVertexAttrib3fNV = (PFNGLVERTEXATTRIB3FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fNV")) == NULL) || r; - r = ((glVertexAttrib3fvNV = (PFNGLVERTEXATTRIB3FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3fvNV")) == NULL) || r; - r = ((glVertexAttrib3sNV = (PFNGLVERTEXATTRIB3SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3sNV")) == NULL) || r; - r = ((glVertexAttrib3svNV = (PFNGLVERTEXATTRIB3SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib3svNV")) == NULL) || r; - r = ((glVertexAttrib4dNV = (PFNGLVERTEXATTRIB4DNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dNV")) == NULL) || r; - r = ((glVertexAttrib4dvNV = (PFNGLVERTEXATTRIB4DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4dvNV")) == NULL) || r; - r = ((glVertexAttrib4fNV = (PFNGLVERTEXATTRIB4FNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fNV")) == NULL) || r; - r = ((glVertexAttrib4fvNV = (PFNGLVERTEXATTRIB4FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4fvNV")) == NULL) || r; - r = ((glVertexAttrib4sNV = (PFNGLVERTEXATTRIB4SNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4sNV")) == NULL) || r; - r = ((glVertexAttrib4svNV = (PFNGLVERTEXATTRIB4SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4svNV")) == NULL) || r; - r = ((glVertexAttrib4ubNV = (PFNGLVERTEXATTRIB4UBNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubNV")) == NULL) || r; - r = ((glVertexAttrib4ubvNV = (PFNGLVERTEXATTRIB4UBVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttrib4ubvNV")) == NULL) || r; - r = ((glVertexAttribPointerNV = (PFNGLVERTEXATTRIBPOINTERNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribPointerNV")) == NULL) || r; - r = ((glVertexAttribs1dvNV = (PFNGLVERTEXATTRIBS1DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1dvNV")) == NULL) || r; - r = ((glVertexAttribs1fvNV = (PFNGLVERTEXATTRIBS1FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1fvNV")) == NULL) || r; - r = ((glVertexAttribs1svNV = (PFNGLVERTEXATTRIBS1SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs1svNV")) == NULL) || r; - r = ((glVertexAttribs2dvNV = (PFNGLVERTEXATTRIBS2DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2dvNV")) == NULL) || r; - r = ((glVertexAttribs2fvNV = (PFNGLVERTEXATTRIBS2FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2fvNV")) == NULL) || r; - r = ((glVertexAttribs2svNV = (PFNGLVERTEXATTRIBS2SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs2svNV")) == NULL) || r; - r = ((glVertexAttribs3dvNV = (PFNGLVERTEXATTRIBS3DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3dvNV")) == NULL) || r; - r = ((glVertexAttribs3fvNV = (PFNGLVERTEXATTRIBS3FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3fvNV")) == NULL) || r; - r = ((glVertexAttribs3svNV = (PFNGLVERTEXATTRIBS3SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs3svNV")) == NULL) || r; - r = ((glVertexAttribs4dvNV = (PFNGLVERTEXATTRIBS4DVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4dvNV")) == NULL) || r; - r = ((glVertexAttribs4fvNV = (PFNGLVERTEXATTRIBS4FVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4fvNV")) == NULL) || r; - r = ((glVertexAttribs4svNV = (PFNGLVERTEXATTRIBS4SVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4svNV")) == NULL) || r; - r = ((glVertexAttribs4ubvNV = (PFNGLVERTEXATTRIBS4UBVNVPROC)glewGetProcAddress((const GLubyte*)"glVertexAttribs4ubvNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_vertex_program */ - -#ifdef GL_NV_vertex_program1_1 - -#endif /* GL_NV_vertex_program1_1 */ - -#ifdef GL_NV_vertex_program2 - -#endif /* GL_NV_vertex_program2 */ - -#ifdef GL_NV_vertex_program2_option - -#endif /* GL_NV_vertex_program2_option */ - -#ifdef GL_NV_vertex_program3 - -#endif /* GL_NV_vertex_program3 */ - -#ifdef GL_NV_vertex_program4 - -#endif /* GL_NV_vertex_program4 */ - -#ifdef GL_NV_video_capture - -static GLboolean _glewInit_GL_NV_video_capture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glBeginVideoCaptureNV = (PFNGLBEGINVIDEOCAPTURENVPROC)glewGetProcAddress((const GLubyte*)"glBeginVideoCaptureNV")) == NULL) || r; - r = ((glBindVideoCaptureStreamBufferNV = (PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC)glewGetProcAddress((const GLubyte*)"glBindVideoCaptureStreamBufferNV")) == NULL) || r; - r = ((glBindVideoCaptureStreamTextureNV = (PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC)glewGetProcAddress((const GLubyte*)"glBindVideoCaptureStreamTextureNV")) == NULL) || r; - r = ((glEndVideoCaptureNV = (PFNGLENDVIDEOCAPTURENVPROC)glewGetProcAddress((const GLubyte*)"glEndVideoCaptureNV")) == NULL) || r; - r = ((glGetVideoCaptureStreamdvNV = (PFNGLGETVIDEOCAPTURESTREAMDVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoCaptureStreamdvNV")) == NULL) || r; - r = ((glGetVideoCaptureStreamfvNV = (PFNGLGETVIDEOCAPTURESTREAMFVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoCaptureStreamfvNV")) == NULL) || r; - r = ((glGetVideoCaptureStreamivNV = (PFNGLGETVIDEOCAPTURESTREAMIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoCaptureStreamivNV")) == NULL) || r; - r = ((glGetVideoCaptureivNV = (PFNGLGETVIDEOCAPTUREIVNVPROC)glewGetProcAddress((const GLubyte*)"glGetVideoCaptureivNV")) == NULL) || r; - r = ((glVideoCaptureNV = (PFNGLVIDEOCAPTURENVPROC)glewGetProcAddress((const GLubyte*)"glVideoCaptureNV")) == NULL) || r; - r = ((glVideoCaptureStreamParameterdvNV = (PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC)glewGetProcAddress((const GLubyte*)"glVideoCaptureStreamParameterdvNV")) == NULL) || r; - r = ((glVideoCaptureStreamParameterfvNV = (PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC)glewGetProcAddress((const GLubyte*)"glVideoCaptureStreamParameterfvNV")) == NULL) || r; - r = ((glVideoCaptureStreamParameterivNV = (PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC)glewGetProcAddress((const GLubyte*)"glVideoCaptureStreamParameterivNV")) == NULL) || r; - - return r; -} - -#endif /* GL_NV_video_capture */ - -#ifdef GL_OES_byte_coordinates - -#endif /* GL_OES_byte_coordinates */ - -#ifdef GL_OES_compressed_paletted_texture - -#endif /* GL_OES_compressed_paletted_texture */ - -#ifdef GL_OES_read_format - -#endif /* GL_OES_read_format */ - -#ifdef GL_OES_single_precision - -static GLboolean _glewInit_GL_OES_single_precision (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClearDepthfOES = (PFNGLCLEARDEPTHFOESPROC)glewGetProcAddress((const GLubyte*)"glClearDepthfOES")) == NULL) || r; - r = ((glClipPlanefOES = (PFNGLCLIPPLANEFOESPROC)glewGetProcAddress((const GLubyte*)"glClipPlanefOES")) == NULL) || r; - r = ((glDepthRangefOES = (PFNGLDEPTHRANGEFOESPROC)glewGetProcAddress((const GLubyte*)"glDepthRangefOES")) == NULL) || r; - r = ((glFrustumfOES = (PFNGLFRUSTUMFOESPROC)glewGetProcAddress((const GLubyte*)"glFrustumfOES")) == NULL) || r; - r = ((glGetClipPlanefOES = (PFNGLGETCLIPPLANEFOESPROC)glewGetProcAddress((const GLubyte*)"glGetClipPlanefOES")) == NULL) || r; - r = ((glOrthofOES = (PFNGLORTHOFOESPROC)glewGetProcAddress((const GLubyte*)"glOrthofOES")) == NULL) || r; - - return r; -} - -#endif /* GL_OES_single_precision */ - -#ifdef GL_OML_interlace - -#endif /* GL_OML_interlace */ - -#ifdef GL_OML_resample - -#endif /* GL_OML_resample */ - -#ifdef GL_OML_subsample - -#endif /* GL_OML_subsample */ - -#ifdef GL_PGI_misc_hints - -#endif /* GL_PGI_misc_hints */ - -#ifdef GL_PGI_vertex_hints - -#endif /* GL_PGI_vertex_hints */ - -#ifdef GL_REGAL_ES1_0_compatibility - -static GLboolean _glewInit_GL_REGAL_ES1_0_compatibility (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAlphaFuncx = (PFNGLALPHAFUNCXPROC)glewGetProcAddress((const GLubyte*)"glAlphaFuncx")) == NULL) || r; - r = ((glClearColorx = (PFNGLCLEARCOLORXPROC)glewGetProcAddress((const GLubyte*)"glClearColorx")) == NULL) || r; - r = ((glClearDepthx = (PFNGLCLEARDEPTHXPROC)glewGetProcAddress((const GLubyte*)"glClearDepthx")) == NULL) || r; - r = ((glColor4x = (PFNGLCOLOR4XPROC)glewGetProcAddress((const GLubyte*)"glColor4x")) == NULL) || r; - r = ((glDepthRangex = (PFNGLDEPTHRANGEXPROC)glewGetProcAddress((const GLubyte*)"glDepthRangex")) == NULL) || r; - r = ((glFogx = (PFNGLFOGXPROC)glewGetProcAddress((const GLubyte*)"glFogx")) == NULL) || r; - r = ((glFogxv = (PFNGLFOGXVPROC)glewGetProcAddress((const GLubyte*)"glFogxv")) == NULL) || r; - r = ((glFrustumf = (PFNGLFRUSTUMFPROC)glewGetProcAddress((const GLubyte*)"glFrustumf")) == NULL) || r; - r = ((glFrustumx = (PFNGLFRUSTUMXPROC)glewGetProcAddress((const GLubyte*)"glFrustumx")) == NULL) || r; - r = ((glLightModelx = (PFNGLLIGHTMODELXPROC)glewGetProcAddress((const GLubyte*)"glLightModelx")) == NULL) || r; - r = ((glLightModelxv = (PFNGLLIGHTMODELXVPROC)glewGetProcAddress((const GLubyte*)"glLightModelxv")) == NULL) || r; - r = ((glLightx = (PFNGLLIGHTXPROC)glewGetProcAddress((const GLubyte*)"glLightx")) == NULL) || r; - r = ((glLightxv = (PFNGLLIGHTXVPROC)glewGetProcAddress((const GLubyte*)"glLightxv")) == NULL) || r; - r = ((glLineWidthx = (PFNGLLINEWIDTHXPROC)glewGetProcAddress((const GLubyte*)"glLineWidthx")) == NULL) || r; - r = ((glLoadMatrixx = (PFNGLLOADMATRIXXPROC)glewGetProcAddress((const GLubyte*)"glLoadMatrixx")) == NULL) || r; - r = ((glMaterialx = (PFNGLMATERIALXPROC)glewGetProcAddress((const GLubyte*)"glMaterialx")) == NULL) || r; - r = ((glMaterialxv = (PFNGLMATERIALXVPROC)glewGetProcAddress((const GLubyte*)"glMaterialxv")) == NULL) || r; - r = ((glMultMatrixx = (PFNGLMULTMATRIXXPROC)glewGetProcAddress((const GLubyte*)"glMultMatrixx")) == NULL) || r; - r = ((glMultiTexCoord4x = (PFNGLMULTITEXCOORD4XPROC)glewGetProcAddress((const GLubyte*)"glMultiTexCoord4x")) == NULL) || r; - r = ((glNormal3x = (PFNGLNORMAL3XPROC)glewGetProcAddress((const GLubyte*)"glNormal3x")) == NULL) || r; - r = ((glOrthof = (PFNGLORTHOFPROC)glewGetProcAddress((const GLubyte*)"glOrthof")) == NULL) || r; - r = ((glOrthox = (PFNGLORTHOXPROC)glewGetProcAddress((const GLubyte*)"glOrthox")) == NULL) || r; - r = ((glPointSizex = (PFNGLPOINTSIZEXPROC)glewGetProcAddress((const GLubyte*)"glPointSizex")) == NULL) || r; - r = ((glPolygonOffsetx = (PFNGLPOLYGONOFFSETXPROC)glewGetProcAddress((const GLubyte*)"glPolygonOffsetx")) == NULL) || r; - r = ((glRotatex = (PFNGLROTATEXPROC)glewGetProcAddress((const GLubyte*)"glRotatex")) == NULL) || r; - r = ((glSampleCoveragex = (PFNGLSAMPLECOVERAGEXPROC)glewGetProcAddress((const GLubyte*)"glSampleCoveragex")) == NULL) || r; - r = ((glScalex = (PFNGLSCALEXPROC)glewGetProcAddress((const GLubyte*)"glScalex")) == NULL) || r; - r = ((glTexEnvx = (PFNGLTEXENVXPROC)glewGetProcAddress((const GLubyte*)"glTexEnvx")) == NULL) || r; - r = ((glTexEnvxv = (PFNGLTEXENVXVPROC)glewGetProcAddress((const GLubyte*)"glTexEnvxv")) == NULL) || r; - r = ((glTexParameterx = (PFNGLTEXPARAMETERXPROC)glewGetProcAddress((const GLubyte*)"glTexParameterx")) == NULL) || r; - r = ((glTranslatex = (PFNGLTRANSLATEXPROC)glewGetProcAddress((const GLubyte*)"glTranslatex")) == NULL) || r; - - return r; -} - -#endif /* GL_REGAL_ES1_0_compatibility */ - -#ifdef GL_REGAL_ES1_1_compatibility - -static GLboolean _glewInit_GL_REGAL_ES1_1_compatibility (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glClipPlanef = (PFNGLCLIPPLANEFPROC)glewGetProcAddress((const GLubyte*)"glClipPlanef")) == NULL) || r; - r = ((glClipPlanex = (PFNGLCLIPPLANEXPROC)glewGetProcAddress((const GLubyte*)"glClipPlanex")) == NULL) || r; - r = ((glGetClipPlanef = (PFNGLGETCLIPPLANEFPROC)glewGetProcAddress((const GLubyte*)"glGetClipPlanef")) == NULL) || r; - r = ((glGetClipPlanex = (PFNGLGETCLIPPLANEXPROC)glewGetProcAddress((const GLubyte*)"glGetClipPlanex")) == NULL) || r; - r = ((glGetFixedv = (PFNGLGETFIXEDVPROC)glewGetProcAddress((const GLubyte*)"glGetFixedv")) == NULL) || r; - r = ((glGetLightxv = (PFNGLGETLIGHTXVPROC)glewGetProcAddress((const GLubyte*)"glGetLightxv")) == NULL) || r; - r = ((glGetMaterialxv = (PFNGLGETMATERIALXVPROC)glewGetProcAddress((const GLubyte*)"glGetMaterialxv")) == NULL) || r; - r = ((glGetTexEnvxv = (PFNGLGETTEXENVXVPROC)glewGetProcAddress((const GLubyte*)"glGetTexEnvxv")) == NULL) || r; - r = ((glGetTexParameterxv = (PFNGLGETTEXPARAMETERXVPROC)glewGetProcAddress((const GLubyte*)"glGetTexParameterxv")) == NULL) || r; - r = ((glPointParameterx = (PFNGLPOINTPARAMETERXPROC)glewGetProcAddress((const GLubyte*)"glPointParameterx")) == NULL) || r; - r = ((glPointParameterxv = (PFNGLPOINTPARAMETERXVPROC)glewGetProcAddress((const GLubyte*)"glPointParameterxv")) == NULL) || r; - r = ((glPointSizePointerOES = (PFNGLPOINTSIZEPOINTEROESPROC)glewGetProcAddress((const GLubyte*)"glPointSizePointerOES")) == NULL) || r; - r = ((glTexParameterxv = (PFNGLTEXPARAMETERXVPROC)glewGetProcAddress((const GLubyte*)"glTexParameterxv")) == NULL) || r; - - return r; -} - -#endif /* GL_REGAL_ES1_1_compatibility */ - -#ifdef GL_REGAL_enable - -#endif /* GL_REGAL_enable */ - -#ifdef GL_REGAL_error_string - -static GLboolean _glewInit_GL_REGAL_error_string (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glErrorStringREGAL = (PFNGLERRORSTRINGREGALPROC)glewGetProcAddress((const GLubyte*)"glErrorStringREGAL")) == NULL) || r; - - return r; -} - -#endif /* GL_REGAL_error_string */ - -#ifdef GL_REGAL_extension_query - -static GLboolean _glewInit_GL_REGAL_extension_query (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetExtensionREGAL = (PFNGLGETEXTENSIONREGALPROC)glewGetProcAddress((const GLubyte*)"glGetExtensionREGAL")) == NULL) || r; - r = ((glIsSupportedREGAL = (PFNGLISSUPPORTEDREGALPROC)glewGetProcAddress((const GLubyte*)"glIsSupportedREGAL")) == NULL) || r; - - return r; -} - -#endif /* GL_REGAL_extension_query */ - -#ifdef GL_REGAL_log - -static GLboolean _glewInit_GL_REGAL_log (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glLogMessageCallbackREGAL = (PFNGLLOGMESSAGECALLBACKREGALPROC)glewGetProcAddress((const GLubyte*)"glLogMessageCallbackREGAL")) == NULL) || r; - - return r; -} - -#endif /* GL_REGAL_log */ - -#ifdef GL_REND_screen_coordinates - -#endif /* GL_REND_screen_coordinates */ - -#ifdef GL_S3_s3tc - -#endif /* GL_S3_s3tc */ - -#ifdef GL_SGIS_color_range - -#endif /* GL_SGIS_color_range */ - -#ifdef GL_SGIS_detail_texture - -static GLboolean _glewInit_GL_SGIS_detail_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glDetailTexFuncSGIS = (PFNGLDETAILTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glDetailTexFuncSGIS")) == NULL) || r; - r = ((glGetDetailTexFuncSGIS = (PFNGLGETDETAILTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetDetailTexFuncSGIS")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIS_detail_texture */ - -#ifdef GL_SGIS_fog_function - -static GLboolean _glewInit_GL_SGIS_fog_function (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFogFuncSGIS = (PFNGLFOGFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glFogFuncSGIS")) == NULL) || r; - r = ((glGetFogFuncSGIS = (PFNGLGETFOGFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetFogFuncSGIS")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIS_fog_function */ - -#ifdef GL_SGIS_generate_mipmap - -#endif /* GL_SGIS_generate_mipmap */ - -#ifdef GL_SGIS_multisample - -static GLboolean _glewInit_GL_SGIS_multisample (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glSampleMaskSGIS = (PFNGLSAMPLEMASKSGISPROC)glewGetProcAddress((const GLubyte*)"glSampleMaskSGIS")) == NULL) || r; - r = ((glSamplePatternSGIS = (PFNGLSAMPLEPATTERNSGISPROC)glewGetProcAddress((const GLubyte*)"glSamplePatternSGIS")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIS_multisample */ - -#ifdef GL_SGIS_pixel_texture - -#endif /* GL_SGIS_pixel_texture */ - -#ifdef GL_SGIS_point_line_texgen - -#endif /* GL_SGIS_point_line_texgen */ - -#ifdef GL_SGIS_sharpen_texture - -static GLboolean _glewInit_GL_SGIS_sharpen_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetSharpenTexFuncSGIS = (PFNGLGETSHARPENTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetSharpenTexFuncSGIS")) == NULL) || r; - r = ((glSharpenTexFuncSGIS = (PFNGLSHARPENTEXFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glSharpenTexFuncSGIS")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIS_sharpen_texture */ - -#ifdef GL_SGIS_texture4D - -static GLboolean _glewInit_GL_SGIS_texture4D (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTexImage4DSGIS = (PFNGLTEXIMAGE4DSGISPROC)glewGetProcAddress((const GLubyte*)"glTexImage4DSGIS")) == NULL) || r; - r = ((glTexSubImage4DSGIS = (PFNGLTEXSUBIMAGE4DSGISPROC)glewGetProcAddress((const GLubyte*)"glTexSubImage4DSGIS")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIS_texture4D */ - -#ifdef GL_SGIS_texture_border_clamp - -#endif /* GL_SGIS_texture_border_clamp */ - -#ifdef GL_SGIS_texture_edge_clamp - -#endif /* GL_SGIS_texture_edge_clamp */ - -#ifdef GL_SGIS_texture_filter4 - -static GLboolean _glewInit_GL_SGIS_texture_filter4 (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGetTexFilterFuncSGIS = (PFNGLGETTEXFILTERFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glGetTexFilterFuncSGIS")) == NULL) || r; - r = ((glTexFilterFuncSGIS = (PFNGLTEXFILTERFUNCSGISPROC)glewGetProcAddress((const GLubyte*)"glTexFilterFuncSGIS")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIS_texture_filter4 */ - -#ifdef GL_SGIS_texture_lod - -#endif /* GL_SGIS_texture_lod */ - -#ifdef GL_SGIS_texture_select - -#endif /* GL_SGIS_texture_select */ - -#ifdef GL_SGIX_async - -static GLboolean _glewInit_GL_SGIX_async (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAsyncMarkerSGIX = (PFNGLASYNCMARKERSGIXPROC)glewGetProcAddress((const GLubyte*)"glAsyncMarkerSGIX")) == NULL) || r; - r = ((glDeleteAsyncMarkersSGIX = (PFNGLDELETEASYNCMARKERSSGIXPROC)glewGetProcAddress((const GLubyte*)"glDeleteAsyncMarkersSGIX")) == NULL) || r; - r = ((glFinishAsyncSGIX = (PFNGLFINISHASYNCSGIXPROC)glewGetProcAddress((const GLubyte*)"glFinishAsyncSGIX")) == NULL) || r; - r = ((glGenAsyncMarkersSGIX = (PFNGLGENASYNCMARKERSSGIXPROC)glewGetProcAddress((const GLubyte*)"glGenAsyncMarkersSGIX")) == NULL) || r; - r = ((glIsAsyncMarkerSGIX = (PFNGLISASYNCMARKERSGIXPROC)glewGetProcAddress((const GLubyte*)"glIsAsyncMarkerSGIX")) == NULL) || r; - r = ((glPollAsyncSGIX = (PFNGLPOLLASYNCSGIXPROC)glewGetProcAddress((const GLubyte*)"glPollAsyncSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_async */ - -#ifdef GL_SGIX_async_histogram - -#endif /* GL_SGIX_async_histogram */ - -#ifdef GL_SGIX_async_pixel - -#endif /* GL_SGIX_async_pixel */ - -#ifdef GL_SGIX_blend_alpha_minmax - -#endif /* GL_SGIX_blend_alpha_minmax */ - -#ifdef GL_SGIX_clipmap - -#endif /* GL_SGIX_clipmap */ - -#ifdef GL_SGIX_convolution_accuracy - -#endif /* GL_SGIX_convolution_accuracy */ - -#ifdef GL_SGIX_depth_texture - -#endif /* GL_SGIX_depth_texture */ - -#ifdef GL_SGIX_flush_raster - -static GLboolean _glewInit_GL_SGIX_flush_raster (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFlushRasterSGIX = (PFNGLFLUSHRASTERSGIXPROC)glewGetProcAddress((const GLubyte*)"glFlushRasterSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_flush_raster */ - -#ifdef GL_SGIX_fog_offset - -#endif /* GL_SGIX_fog_offset */ - -#ifdef GL_SGIX_fog_texture - -static GLboolean _glewInit_GL_SGIX_fog_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTextureFogSGIX = (PFNGLTEXTUREFOGSGIXPROC)glewGetProcAddress((const GLubyte*)"glTextureFogSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_fog_texture */ - -#ifdef GL_SGIX_fragment_specular_lighting - -static GLboolean _glewInit_GL_SGIX_fragment_specular_lighting (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFragmentColorMaterialSGIX = (PFNGLFRAGMENTCOLORMATERIALSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentColorMaterialSGIX")) == NULL) || r; - r = ((glFragmentLightModelfSGIX = (PFNGLFRAGMENTLIGHTMODELFSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfSGIX")) == NULL) || r; - r = ((glFragmentLightModelfvSGIX = (PFNGLFRAGMENTLIGHTMODELFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelfvSGIX")) == NULL) || r; - r = ((glFragmentLightModeliSGIX = (PFNGLFRAGMENTLIGHTMODELISGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModeliSGIX")) == NULL) || r; - r = ((glFragmentLightModelivSGIX = (PFNGLFRAGMENTLIGHTMODELIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightModelivSGIX")) == NULL) || r; - r = ((glFragmentLightfSGIX = (PFNGLFRAGMENTLIGHTFSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfSGIX")) == NULL) || r; - r = ((glFragmentLightfvSGIX = (PFNGLFRAGMENTLIGHTFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightfvSGIX")) == NULL) || r; - r = ((glFragmentLightiSGIX = (PFNGLFRAGMENTLIGHTISGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightiSGIX")) == NULL) || r; - r = ((glFragmentLightivSGIX = (PFNGLFRAGMENTLIGHTIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentLightivSGIX")) == NULL) || r; - r = ((glFragmentMaterialfSGIX = (PFNGLFRAGMENTMATERIALFSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfSGIX")) == NULL) || r; - r = ((glFragmentMaterialfvSGIX = (PFNGLFRAGMENTMATERIALFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialfvSGIX")) == NULL) || r; - r = ((glFragmentMaterialiSGIX = (PFNGLFRAGMENTMATERIALISGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialiSGIX")) == NULL) || r; - r = ((glFragmentMaterialivSGIX = (PFNGLFRAGMENTMATERIALIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glFragmentMaterialivSGIX")) == NULL) || r; - r = ((glGetFragmentLightfvSGIX = (PFNGLGETFRAGMENTLIGHTFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightfvSGIX")) == NULL) || r; - r = ((glGetFragmentLightivSGIX = (PFNGLGETFRAGMENTLIGHTIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentLightivSGIX")) == NULL) || r; - r = ((glGetFragmentMaterialfvSGIX = (PFNGLGETFRAGMENTMATERIALFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialfvSGIX")) == NULL) || r; - r = ((glGetFragmentMaterialivSGIX = (PFNGLGETFRAGMENTMATERIALIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glGetFragmentMaterialivSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_fragment_specular_lighting */ - -#ifdef GL_SGIX_framezoom - -static GLboolean _glewInit_GL_SGIX_framezoom (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFrameZoomSGIX = (PFNGLFRAMEZOOMSGIXPROC)glewGetProcAddress((const GLubyte*)"glFrameZoomSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_framezoom */ - -#ifdef GL_SGIX_interlace - -#endif /* GL_SGIX_interlace */ - -#ifdef GL_SGIX_ir_instrument1 - -#endif /* GL_SGIX_ir_instrument1 */ - -#ifdef GL_SGIX_list_priority - -#endif /* GL_SGIX_list_priority */ - -#ifdef GL_SGIX_pixel_texture - -static GLboolean _glewInit_GL_SGIX_pixel_texture (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glPixelTexGenSGIX = (PFNGLPIXELTEXGENSGIXPROC)glewGetProcAddress((const GLubyte*)"glPixelTexGenSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_pixel_texture */ - -#ifdef GL_SGIX_pixel_texture_bits - -#endif /* GL_SGIX_pixel_texture_bits */ - -#ifdef GL_SGIX_reference_plane - -static GLboolean _glewInit_GL_SGIX_reference_plane (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glReferencePlaneSGIX = (PFNGLREFERENCEPLANESGIXPROC)glewGetProcAddress((const GLubyte*)"glReferencePlaneSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_reference_plane */ - -#ifdef GL_SGIX_resample - -#endif /* GL_SGIX_resample */ - -#ifdef GL_SGIX_shadow - -#endif /* GL_SGIX_shadow */ - -#ifdef GL_SGIX_shadow_ambient - -#endif /* GL_SGIX_shadow_ambient */ - -#ifdef GL_SGIX_sprite - -static GLboolean _glewInit_GL_SGIX_sprite (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glSpriteParameterfSGIX = (PFNGLSPRITEPARAMETERFSGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameterfSGIX")) == NULL) || r; - r = ((glSpriteParameterfvSGIX = (PFNGLSPRITEPARAMETERFVSGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameterfvSGIX")) == NULL) || r; - r = ((glSpriteParameteriSGIX = (PFNGLSPRITEPARAMETERISGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameteriSGIX")) == NULL) || r; - r = ((glSpriteParameterivSGIX = (PFNGLSPRITEPARAMETERIVSGIXPROC)glewGetProcAddress((const GLubyte*)"glSpriteParameterivSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_sprite */ - -#ifdef GL_SGIX_tag_sample_buffer - -static GLboolean _glewInit_GL_SGIX_tag_sample_buffer (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glTagSampleBufferSGIX = (PFNGLTAGSAMPLEBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glTagSampleBufferSGIX")) == NULL) || r; - - return r; -} - -#endif /* GL_SGIX_tag_sample_buffer */ - -#ifdef GL_SGIX_texture_add_env - -#endif /* GL_SGIX_texture_add_env */ - -#ifdef GL_SGIX_texture_coordinate_clamp - -#endif /* GL_SGIX_texture_coordinate_clamp */ - -#ifdef GL_SGIX_texture_lod_bias - -#endif /* GL_SGIX_texture_lod_bias */ - -#ifdef GL_SGIX_texture_multi_buffer - -#endif /* GL_SGIX_texture_multi_buffer */ - -#ifdef GL_SGIX_texture_range - -#endif /* GL_SGIX_texture_range */ - -#ifdef GL_SGIX_texture_scale_bias - -#endif /* GL_SGIX_texture_scale_bias */ - -#ifdef GL_SGIX_vertex_preclip - -#endif /* GL_SGIX_vertex_preclip */ - -#ifdef GL_SGIX_vertex_preclip_hint - -#endif /* GL_SGIX_vertex_preclip_hint */ - -#ifdef GL_SGIX_ycrcb - -#endif /* GL_SGIX_ycrcb */ - -#ifdef GL_SGI_color_matrix - -#endif /* GL_SGI_color_matrix */ - -#ifdef GL_SGI_color_table - -static GLboolean _glewInit_GL_SGI_color_table (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColorTableParameterfvSGI = (PFNGLCOLORTABLEPARAMETERFVSGIPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameterfvSGI")) == NULL) || r; - r = ((glColorTableParameterivSGI = (PFNGLCOLORTABLEPARAMETERIVSGIPROC)glewGetProcAddress((const GLubyte*)"glColorTableParameterivSGI")) == NULL) || r; - r = ((glColorTableSGI = (PFNGLCOLORTABLESGIPROC)glewGetProcAddress((const GLubyte*)"glColorTableSGI")) == NULL) || r; - r = ((glCopyColorTableSGI = (PFNGLCOPYCOLORTABLESGIPROC)glewGetProcAddress((const GLubyte*)"glCopyColorTableSGI")) == NULL) || r; - r = ((glGetColorTableParameterfvSGI = (PFNGLGETCOLORTABLEPARAMETERFVSGIPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterfvSGI")) == NULL) || r; - r = ((glGetColorTableParameterivSGI = (PFNGLGETCOLORTABLEPARAMETERIVSGIPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableParameterivSGI")) == NULL) || r; - r = ((glGetColorTableSGI = (PFNGLGETCOLORTABLESGIPROC)glewGetProcAddress((const GLubyte*)"glGetColorTableSGI")) == NULL) || r; - - return r; -} - -#endif /* GL_SGI_color_table */ - -#ifdef GL_SGI_texture_color_table - -#endif /* GL_SGI_texture_color_table */ - -#ifdef GL_SUNX_constant_data - -static GLboolean _glewInit_GL_SUNX_constant_data (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glFinishTextureSUNX = (PFNGLFINISHTEXTURESUNXPROC)glewGetProcAddress((const GLubyte*)"glFinishTextureSUNX")) == NULL) || r; - - return r; -} - -#endif /* GL_SUNX_constant_data */ - -#ifdef GL_SUN_convolution_border_modes - -#endif /* GL_SUN_convolution_border_modes */ - -#ifdef GL_SUN_global_alpha - -static GLboolean _glewInit_GL_SUN_global_alpha (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glGlobalAlphaFactorbSUN = (PFNGLGLOBALALPHAFACTORBSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorbSUN")) == NULL) || r; - r = ((glGlobalAlphaFactordSUN = (PFNGLGLOBALALPHAFACTORDSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactordSUN")) == NULL) || r; - r = ((glGlobalAlphaFactorfSUN = (PFNGLGLOBALALPHAFACTORFSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorfSUN")) == NULL) || r; - r = ((glGlobalAlphaFactoriSUN = (PFNGLGLOBALALPHAFACTORISUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactoriSUN")) == NULL) || r; - r = ((glGlobalAlphaFactorsSUN = (PFNGLGLOBALALPHAFACTORSSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorsSUN")) == NULL) || r; - r = ((glGlobalAlphaFactorubSUN = (PFNGLGLOBALALPHAFACTORUBSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorubSUN")) == NULL) || r; - r = ((glGlobalAlphaFactoruiSUN = (PFNGLGLOBALALPHAFACTORUISUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactoruiSUN")) == NULL) || r; - r = ((glGlobalAlphaFactorusSUN = (PFNGLGLOBALALPHAFACTORUSSUNPROC)glewGetProcAddress((const GLubyte*)"glGlobalAlphaFactorusSUN")) == NULL) || r; - - return r; -} - -#endif /* GL_SUN_global_alpha */ - -#ifdef GL_SUN_mesh_array - -#endif /* GL_SUN_mesh_array */ - -#ifdef GL_SUN_read_video_pixels - -static GLboolean _glewInit_GL_SUN_read_video_pixels (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glReadVideoPixelsSUN = (PFNGLREADVIDEOPIXELSSUNPROC)glewGetProcAddress((const GLubyte*)"glReadVideoPixelsSUN")) == NULL) || r; - - return r; -} - -#endif /* GL_SUN_read_video_pixels */ - -#ifdef GL_SUN_slice_accum - -#endif /* GL_SUN_slice_accum */ - -#ifdef GL_SUN_triangle_list - -static GLboolean _glewInit_GL_SUN_triangle_list (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glReplacementCodePointerSUN = (PFNGLREPLACEMENTCODEPOINTERSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodePointerSUN")) == NULL) || r; - r = ((glReplacementCodeubSUN = (PFNGLREPLACEMENTCODEUBSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeubSUN")) == NULL) || r; - r = ((glReplacementCodeubvSUN = (PFNGLREPLACEMENTCODEUBVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeubvSUN")) == NULL) || r; - r = ((glReplacementCodeuiSUN = (PFNGLREPLACEMENTCODEUISUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiSUN")) == NULL) || r; - r = ((glReplacementCodeuivSUN = (PFNGLREPLACEMENTCODEUIVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuivSUN")) == NULL) || r; - r = ((glReplacementCodeusSUN = (PFNGLREPLACEMENTCODEUSSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeusSUN")) == NULL) || r; - r = ((glReplacementCodeusvSUN = (PFNGLREPLACEMENTCODEUSVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeusvSUN")) == NULL) || r; - - return r; -} - -#endif /* GL_SUN_triangle_list */ - -#ifdef GL_SUN_vertex - -static GLboolean _glewInit_GL_SUN_vertex (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glColor3fVertex3fSUN = (PFNGLCOLOR3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor3fVertex3fSUN")) == NULL) || r; - r = ((glColor3fVertex3fvSUN = (PFNGLCOLOR3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor3fVertex3fvSUN")) == NULL) || r; - r = ((glColor4fNormal3fVertex3fSUN = (PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4fNormal3fVertex3fSUN")) == NULL) || r; - r = ((glColor4fNormal3fVertex3fvSUN = (PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4fNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glColor4ubVertex2fSUN = (PFNGLCOLOR4UBVERTEX2FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex2fSUN")) == NULL) || r; - r = ((glColor4ubVertex2fvSUN = (PFNGLCOLOR4UBVERTEX2FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex2fvSUN")) == NULL) || r; - r = ((glColor4ubVertex3fSUN = (PFNGLCOLOR4UBVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex3fSUN")) == NULL) || r; - r = ((glColor4ubVertex3fvSUN = (PFNGLCOLOR4UBVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glColor4ubVertex3fvSUN")) == NULL) || r; - r = ((glNormal3fVertex3fSUN = (PFNGLNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glNormal3fVertex3fSUN")) == NULL) || r; - r = ((glNormal3fVertex3fvSUN = (PFNGLNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiColor3fVertex3fSUN = (PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor3fVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiColor3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor3fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiColor4fNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4fNormal3fVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiColor4fNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4fNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiColor4ubVertex3fSUN = (PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4ubVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiColor4ubVertex3fvSUN = (PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiColor4ubVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiNormal3fVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiTexCoord2fVertex3fSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiTexCoord2fVertex3fvSUN = (PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiTexCoord2fVertex3fvSUN")) == NULL) || r; - r = ((glReplacementCodeuiVertex3fSUN = (PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiVertex3fSUN")) == NULL) || r; - r = ((glReplacementCodeuiVertex3fvSUN = (PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glReplacementCodeuiVertex3fvSUN")) == NULL) || r; - r = ((glTexCoord2fColor3fVertex3fSUN = (PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor3fVertex3fSUN")) == NULL) || r; - r = ((glTexCoord2fColor3fVertex3fvSUN = (PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor3fVertex3fvSUN")) == NULL) || r; - r = ((glTexCoord2fColor4fNormal3fVertex3fSUN = (PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4fNormal3fVertex3fSUN")) == NULL) || r; - r = ((glTexCoord2fColor4fNormal3fVertex3fvSUN = (PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4fNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glTexCoord2fColor4ubVertex3fSUN = (PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4ubVertex3fSUN")) == NULL) || r; - r = ((glTexCoord2fColor4ubVertex3fvSUN = (PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fColor4ubVertex3fvSUN")) == NULL) || r; - r = ((glTexCoord2fNormal3fVertex3fSUN = (PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fNormal3fVertex3fSUN")) == NULL) || r; - r = ((glTexCoord2fNormal3fVertex3fvSUN = (PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fNormal3fVertex3fvSUN")) == NULL) || r; - r = ((glTexCoord2fVertex3fSUN = (PFNGLTEXCOORD2FVERTEX3FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fVertex3fSUN")) == NULL) || r; - r = ((glTexCoord2fVertex3fvSUN = (PFNGLTEXCOORD2FVERTEX3FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord2fVertex3fvSUN")) == NULL) || r; - r = ((glTexCoord4fColor4fNormal3fVertex4fSUN = (PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fColor4fNormal3fVertex4fSUN")) == NULL) || r; - r = ((glTexCoord4fColor4fNormal3fVertex4fvSUN = (PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fColor4fNormal3fVertex4fvSUN")) == NULL) || r; - r = ((glTexCoord4fVertex4fSUN = (PFNGLTEXCOORD4FVERTEX4FSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fVertex4fSUN")) == NULL) || r; - r = ((glTexCoord4fVertex4fvSUN = (PFNGLTEXCOORD4FVERTEX4FVSUNPROC)glewGetProcAddress((const GLubyte*)"glTexCoord4fVertex4fvSUN")) == NULL) || r; - - return r; -} - -#endif /* GL_SUN_vertex */ - -#ifdef GL_WIN_phong_shading - -#endif /* GL_WIN_phong_shading */ - -#ifdef GL_WIN_specular_fog - -#endif /* GL_WIN_specular_fog */ - -#ifdef GL_WIN_swap_hint - -static GLboolean _glewInit_GL_WIN_swap_hint (GLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glAddSwapHintRectWIN = (PFNGLADDSWAPHINTRECTWINPROC)glewGetProcAddress((const GLubyte*)"glAddSwapHintRectWIN")) == NULL) || r; - - return r; -} - -#endif /* GL_WIN_swap_hint */ - -/* ------------------------------------------------------------------------- */ - -GLboolean GLEWAPIENTRY glewGetExtension (const char* name) -{ - const GLubyte* start; - const GLubyte* end; - start = (const GLubyte*)glGetString(GL_EXTENSIONS); - if (start == 0) - return GL_FALSE; - end = start + _glewStrLen(start); - return _glewSearchExtension(name, start, end); -} - -/* ------------------------------------------------------------------------- */ - -#ifndef GLEW_MX -static -#endif -GLenum GLEWAPIENTRY glewContextInit (GLEW_CONTEXT_ARG_DEF_LIST) -{ - const GLubyte* s; - GLuint dot; - GLint major, minor; - const GLubyte* extStart; - const GLubyte* extEnd; - /* query opengl version */ - s = glGetString(GL_VERSION); - dot = _glewStrCLen(s, '.'); - if (dot == 0) - return GLEW_ERROR_NO_GL_VERSION; - - major = s[dot-1]-'0'; - minor = s[dot+1]-'0'; - - if (minor < 0 || minor > 9) - minor = 0; - if (major<0 || major>9) - return GLEW_ERROR_NO_GL_VERSION; - - - if (major == 1 && minor == 0) - { - return GLEW_ERROR_GL_VERSION_10_ONLY; - } - else - { - CONST_CAST(GLEW_VERSION_4_4) = ( major > 4 ) || ( major == 4 && minor >= 4 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_4_3) = GLEW_VERSION_4_4 == GL_TRUE || ( major == 4 && minor >= 3 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_4_2) = GLEW_VERSION_4_3 == GL_TRUE || ( major == 4 && minor >= 2 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_4_1) = GLEW_VERSION_4_2 == GL_TRUE || ( major == 4 && minor >= 1 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_4_0) = GLEW_VERSION_4_1 == GL_TRUE || ( major == 4 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_3_3) = GLEW_VERSION_4_0 == GL_TRUE || ( major == 3 && minor >= 3 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_3_2) = GLEW_VERSION_3_3 == GL_TRUE || ( major == 3 && minor >= 2 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_3_1) = GLEW_VERSION_3_2 == GL_TRUE || ( major == 3 && minor >= 1 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_3_0) = GLEW_VERSION_3_1 == GL_TRUE || ( major == 3 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_2_1) = GLEW_VERSION_3_0 == GL_TRUE || ( major == 2 && minor >= 1 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_2_0) = GLEW_VERSION_2_1 == GL_TRUE || ( major == 2 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_1_5) = GLEW_VERSION_2_0 == GL_TRUE || ( major == 1 && minor >= 5 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_1_4) = GLEW_VERSION_1_5 == GL_TRUE || ( major == 1 && minor >= 4 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_1_3) = GLEW_VERSION_1_4 == GL_TRUE || ( major == 1 && minor >= 3 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_1_2_1) = GLEW_VERSION_1_3 == GL_TRUE ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_1_2) = GLEW_VERSION_1_2_1 == GL_TRUE || ( major == 1 && minor >= 2 ) ? GL_TRUE : GL_FALSE; - CONST_CAST(GLEW_VERSION_1_1) = GLEW_VERSION_1_2 == GL_TRUE || ( major == 1 && minor >= 1 ) ? GL_TRUE : GL_FALSE; - } - - /* query opengl extensions string */ - extStart = glGetString(GL_EXTENSIONS); - if (extStart == 0) - extStart = (const GLubyte*)""; - extEnd = extStart + _glewStrLen(extStart); - - /* initialize extensions */ -#ifdef GL_VERSION_1_2 - if (glewExperimental || GLEW_VERSION_1_2) CONST_CAST(GLEW_VERSION_1_2) = !_glewInit_GL_VERSION_1_2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_1_2 */ -#ifdef GL_VERSION_1_2_1 -#endif /* GL_VERSION_1_2_1 */ -#ifdef GL_VERSION_1_3 - if (glewExperimental || GLEW_VERSION_1_3) CONST_CAST(GLEW_VERSION_1_3) = !_glewInit_GL_VERSION_1_3(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_1_3 */ -#ifdef GL_VERSION_1_4 - if (glewExperimental || GLEW_VERSION_1_4) CONST_CAST(GLEW_VERSION_1_4) = !_glewInit_GL_VERSION_1_4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_1_4 */ -#ifdef GL_VERSION_1_5 - if (glewExperimental || GLEW_VERSION_1_5) CONST_CAST(GLEW_VERSION_1_5) = !_glewInit_GL_VERSION_1_5(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_1_5 */ -#ifdef GL_VERSION_2_0 - if (glewExperimental || GLEW_VERSION_2_0) CONST_CAST(GLEW_VERSION_2_0) = !_glewInit_GL_VERSION_2_0(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_2_0 */ -#ifdef GL_VERSION_2_1 - if (glewExperimental || GLEW_VERSION_2_1) CONST_CAST(GLEW_VERSION_2_1) = !_glewInit_GL_VERSION_2_1(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_2_1 */ -#ifdef GL_VERSION_3_0 - if (glewExperimental || GLEW_VERSION_3_0) CONST_CAST(GLEW_VERSION_3_0) = !_glewInit_GL_VERSION_3_0(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_3_0 */ -#ifdef GL_VERSION_3_1 - if (glewExperimental || GLEW_VERSION_3_1) CONST_CAST(GLEW_VERSION_3_1) = !_glewInit_GL_VERSION_3_1(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_3_1 */ -#ifdef GL_VERSION_3_2 - if (glewExperimental || GLEW_VERSION_3_2) CONST_CAST(GLEW_VERSION_3_2) = !_glewInit_GL_VERSION_3_2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_3_2 */ -#ifdef GL_VERSION_3_3 - if (glewExperimental || GLEW_VERSION_3_3) CONST_CAST(GLEW_VERSION_3_3) = !_glewInit_GL_VERSION_3_3(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_3_3 */ -#ifdef GL_VERSION_4_0 - if (glewExperimental || GLEW_VERSION_4_0) CONST_CAST(GLEW_VERSION_4_0) = !_glewInit_GL_VERSION_4_0(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_VERSION_4_0 */ -#ifdef GL_VERSION_4_1 -#endif /* GL_VERSION_4_1 */ -#ifdef GL_VERSION_4_2 -#endif /* GL_VERSION_4_2 */ -#ifdef GL_VERSION_4_3 -#endif /* GL_VERSION_4_3 */ -#ifdef GL_VERSION_4_4 -#endif /* GL_VERSION_4_4 */ -#ifdef GL_3DFX_multisample - CONST_CAST(GLEW_3DFX_multisample) = _glewSearchExtension("GL_3DFX_multisample", extStart, extEnd); -#endif /* GL_3DFX_multisample */ -#ifdef GL_3DFX_tbuffer - CONST_CAST(GLEW_3DFX_tbuffer) = _glewSearchExtension("GL_3DFX_tbuffer", extStart, extEnd); - if (glewExperimental || GLEW_3DFX_tbuffer) CONST_CAST(GLEW_3DFX_tbuffer) = !_glewInit_GL_3DFX_tbuffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_3DFX_tbuffer */ -#ifdef GL_3DFX_texture_compression_FXT1 - CONST_CAST(GLEW_3DFX_texture_compression_FXT1) = _glewSearchExtension("GL_3DFX_texture_compression_FXT1", extStart, extEnd); -#endif /* GL_3DFX_texture_compression_FXT1 */ -#ifdef GL_AMD_blend_minmax_factor - CONST_CAST(GLEW_AMD_blend_minmax_factor) = _glewSearchExtension("GL_AMD_blend_minmax_factor", extStart, extEnd); -#endif /* GL_AMD_blend_minmax_factor */ -#ifdef GL_AMD_conservative_depth - CONST_CAST(GLEW_AMD_conservative_depth) = _glewSearchExtension("GL_AMD_conservative_depth", extStart, extEnd); -#endif /* GL_AMD_conservative_depth */ -#ifdef GL_AMD_debug_output - CONST_CAST(GLEW_AMD_debug_output) = _glewSearchExtension("GL_AMD_debug_output", extStart, extEnd); - if (glewExperimental || GLEW_AMD_debug_output) CONST_CAST(GLEW_AMD_debug_output) = !_glewInit_GL_AMD_debug_output(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_debug_output */ -#ifdef GL_AMD_depth_clamp_separate - CONST_CAST(GLEW_AMD_depth_clamp_separate) = _glewSearchExtension("GL_AMD_depth_clamp_separate", extStart, extEnd); -#endif /* GL_AMD_depth_clamp_separate */ -#ifdef GL_AMD_draw_buffers_blend - CONST_CAST(GLEW_AMD_draw_buffers_blend) = _glewSearchExtension("GL_AMD_draw_buffers_blend", extStart, extEnd); - if (glewExperimental || GLEW_AMD_draw_buffers_blend) CONST_CAST(GLEW_AMD_draw_buffers_blend) = !_glewInit_GL_AMD_draw_buffers_blend(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_draw_buffers_blend */ -#ifdef GL_AMD_interleaved_elements - CONST_CAST(GLEW_AMD_interleaved_elements) = _glewSearchExtension("GL_AMD_interleaved_elements", extStart, extEnd); - if (glewExperimental || GLEW_AMD_interleaved_elements) CONST_CAST(GLEW_AMD_interleaved_elements) = !_glewInit_GL_AMD_interleaved_elements(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_interleaved_elements */ -#ifdef GL_AMD_multi_draw_indirect - CONST_CAST(GLEW_AMD_multi_draw_indirect) = _glewSearchExtension("GL_AMD_multi_draw_indirect", extStart, extEnd); - if (glewExperimental || GLEW_AMD_multi_draw_indirect) CONST_CAST(GLEW_AMD_multi_draw_indirect) = !_glewInit_GL_AMD_multi_draw_indirect(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_multi_draw_indirect */ -#ifdef GL_AMD_name_gen_delete - CONST_CAST(GLEW_AMD_name_gen_delete) = _glewSearchExtension("GL_AMD_name_gen_delete", extStart, extEnd); - if (glewExperimental || GLEW_AMD_name_gen_delete) CONST_CAST(GLEW_AMD_name_gen_delete) = !_glewInit_GL_AMD_name_gen_delete(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_name_gen_delete */ -#ifdef GL_AMD_performance_monitor - CONST_CAST(GLEW_AMD_performance_monitor) = _glewSearchExtension("GL_AMD_performance_monitor", extStart, extEnd); - if (glewExperimental || GLEW_AMD_performance_monitor) CONST_CAST(GLEW_AMD_performance_monitor) = !_glewInit_GL_AMD_performance_monitor(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_performance_monitor */ -#ifdef GL_AMD_pinned_memory - CONST_CAST(GLEW_AMD_pinned_memory) = _glewSearchExtension("GL_AMD_pinned_memory", extStart, extEnd); -#endif /* GL_AMD_pinned_memory */ -#ifdef GL_AMD_query_buffer_object - CONST_CAST(GLEW_AMD_query_buffer_object) = _glewSearchExtension("GL_AMD_query_buffer_object", extStart, extEnd); -#endif /* GL_AMD_query_buffer_object */ -#ifdef GL_AMD_sample_positions - CONST_CAST(GLEW_AMD_sample_positions) = _glewSearchExtension("GL_AMD_sample_positions", extStart, extEnd); - if (glewExperimental || GLEW_AMD_sample_positions) CONST_CAST(GLEW_AMD_sample_positions) = !_glewInit_GL_AMD_sample_positions(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_sample_positions */ -#ifdef GL_AMD_seamless_cubemap_per_texture - CONST_CAST(GLEW_AMD_seamless_cubemap_per_texture) = _glewSearchExtension("GL_AMD_seamless_cubemap_per_texture", extStart, extEnd); -#endif /* GL_AMD_seamless_cubemap_per_texture */ -#ifdef GL_AMD_shader_stencil_export - CONST_CAST(GLEW_AMD_shader_stencil_export) = _glewSearchExtension("GL_AMD_shader_stencil_export", extStart, extEnd); -#endif /* GL_AMD_shader_stencil_export */ -#ifdef GL_AMD_shader_trinary_minmax - CONST_CAST(GLEW_AMD_shader_trinary_minmax) = _glewSearchExtension("GL_AMD_shader_trinary_minmax", extStart, extEnd); -#endif /* GL_AMD_shader_trinary_minmax */ -#ifdef GL_AMD_sparse_texture - CONST_CAST(GLEW_AMD_sparse_texture) = _glewSearchExtension("GL_AMD_sparse_texture", extStart, extEnd); - if (glewExperimental || GLEW_AMD_sparse_texture) CONST_CAST(GLEW_AMD_sparse_texture) = !_glewInit_GL_AMD_sparse_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_sparse_texture */ -#ifdef GL_AMD_stencil_operation_extended - CONST_CAST(GLEW_AMD_stencil_operation_extended) = _glewSearchExtension("GL_AMD_stencil_operation_extended", extStart, extEnd); - if (glewExperimental || GLEW_AMD_stencil_operation_extended) CONST_CAST(GLEW_AMD_stencil_operation_extended) = !_glewInit_GL_AMD_stencil_operation_extended(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_stencil_operation_extended */ -#ifdef GL_AMD_texture_texture4 - CONST_CAST(GLEW_AMD_texture_texture4) = _glewSearchExtension("GL_AMD_texture_texture4", extStart, extEnd); -#endif /* GL_AMD_texture_texture4 */ -#ifdef GL_AMD_transform_feedback3_lines_triangles - CONST_CAST(GLEW_AMD_transform_feedback3_lines_triangles) = _glewSearchExtension("GL_AMD_transform_feedback3_lines_triangles", extStart, extEnd); -#endif /* GL_AMD_transform_feedback3_lines_triangles */ -#ifdef GL_AMD_vertex_shader_layer - CONST_CAST(GLEW_AMD_vertex_shader_layer) = _glewSearchExtension("GL_AMD_vertex_shader_layer", extStart, extEnd); -#endif /* GL_AMD_vertex_shader_layer */ -#ifdef GL_AMD_vertex_shader_tessellator - CONST_CAST(GLEW_AMD_vertex_shader_tessellator) = _glewSearchExtension("GL_AMD_vertex_shader_tessellator", extStart, extEnd); - if (glewExperimental || GLEW_AMD_vertex_shader_tessellator) CONST_CAST(GLEW_AMD_vertex_shader_tessellator) = !_glewInit_GL_AMD_vertex_shader_tessellator(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_AMD_vertex_shader_tessellator */ -#ifdef GL_AMD_vertex_shader_viewport_index - CONST_CAST(GLEW_AMD_vertex_shader_viewport_index) = _glewSearchExtension("GL_AMD_vertex_shader_viewport_index", extStart, extEnd); -#endif /* GL_AMD_vertex_shader_viewport_index */ -#ifdef GL_ANGLE_depth_texture - CONST_CAST(GLEW_ANGLE_depth_texture) = _glewSearchExtension("GL_ANGLE_depth_texture", extStart, extEnd); -#endif /* GL_ANGLE_depth_texture */ -#ifdef GL_ANGLE_framebuffer_blit - CONST_CAST(GLEW_ANGLE_framebuffer_blit) = _glewSearchExtension("GL_ANGLE_framebuffer_blit", extStart, extEnd); - if (glewExperimental || GLEW_ANGLE_framebuffer_blit) CONST_CAST(GLEW_ANGLE_framebuffer_blit) = !_glewInit_GL_ANGLE_framebuffer_blit(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ANGLE_framebuffer_blit */ -#ifdef GL_ANGLE_framebuffer_multisample - CONST_CAST(GLEW_ANGLE_framebuffer_multisample) = _glewSearchExtension("GL_ANGLE_framebuffer_multisample", extStart, extEnd); - if (glewExperimental || GLEW_ANGLE_framebuffer_multisample) CONST_CAST(GLEW_ANGLE_framebuffer_multisample) = !_glewInit_GL_ANGLE_framebuffer_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ANGLE_framebuffer_multisample */ -#ifdef GL_ANGLE_instanced_arrays - CONST_CAST(GLEW_ANGLE_instanced_arrays) = _glewSearchExtension("GL_ANGLE_instanced_arrays", extStart, extEnd); - if (glewExperimental || GLEW_ANGLE_instanced_arrays) CONST_CAST(GLEW_ANGLE_instanced_arrays) = !_glewInit_GL_ANGLE_instanced_arrays(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ANGLE_instanced_arrays */ -#ifdef GL_ANGLE_pack_reverse_row_order - CONST_CAST(GLEW_ANGLE_pack_reverse_row_order) = _glewSearchExtension("GL_ANGLE_pack_reverse_row_order", extStart, extEnd); -#endif /* GL_ANGLE_pack_reverse_row_order */ -#ifdef GL_ANGLE_program_binary - CONST_CAST(GLEW_ANGLE_program_binary) = _glewSearchExtension("GL_ANGLE_program_binary", extStart, extEnd); -#endif /* GL_ANGLE_program_binary */ -#ifdef GL_ANGLE_texture_compression_dxt1 - CONST_CAST(GLEW_ANGLE_texture_compression_dxt1) = _glewSearchExtension("GL_ANGLE_texture_compression_dxt1", extStart, extEnd); -#endif /* GL_ANGLE_texture_compression_dxt1 */ -#ifdef GL_ANGLE_texture_compression_dxt3 - CONST_CAST(GLEW_ANGLE_texture_compression_dxt3) = _glewSearchExtension("GL_ANGLE_texture_compression_dxt3", extStart, extEnd); -#endif /* GL_ANGLE_texture_compression_dxt3 */ -#ifdef GL_ANGLE_texture_compression_dxt5 - CONST_CAST(GLEW_ANGLE_texture_compression_dxt5) = _glewSearchExtension("GL_ANGLE_texture_compression_dxt5", extStart, extEnd); -#endif /* GL_ANGLE_texture_compression_dxt5 */ -#ifdef GL_ANGLE_texture_usage - CONST_CAST(GLEW_ANGLE_texture_usage) = _glewSearchExtension("GL_ANGLE_texture_usage", extStart, extEnd); -#endif /* GL_ANGLE_texture_usage */ -#ifdef GL_ANGLE_timer_query - CONST_CAST(GLEW_ANGLE_timer_query) = _glewSearchExtension("GL_ANGLE_timer_query", extStart, extEnd); - if (glewExperimental || GLEW_ANGLE_timer_query) CONST_CAST(GLEW_ANGLE_timer_query) = !_glewInit_GL_ANGLE_timer_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ANGLE_timer_query */ -#ifdef GL_ANGLE_translated_shader_source - CONST_CAST(GLEW_ANGLE_translated_shader_source) = _glewSearchExtension("GL_ANGLE_translated_shader_source", extStart, extEnd); - if (glewExperimental || GLEW_ANGLE_translated_shader_source) CONST_CAST(GLEW_ANGLE_translated_shader_source) = !_glewInit_GL_ANGLE_translated_shader_source(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ANGLE_translated_shader_source */ -#ifdef GL_APPLE_aux_depth_stencil - CONST_CAST(GLEW_APPLE_aux_depth_stencil) = _glewSearchExtension("GL_APPLE_aux_depth_stencil", extStart, extEnd); -#endif /* GL_APPLE_aux_depth_stencil */ -#ifdef GL_APPLE_client_storage - CONST_CAST(GLEW_APPLE_client_storage) = _glewSearchExtension("GL_APPLE_client_storage", extStart, extEnd); -#endif /* GL_APPLE_client_storage */ -#ifdef GL_APPLE_element_array - CONST_CAST(GLEW_APPLE_element_array) = _glewSearchExtension("GL_APPLE_element_array", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_element_array) CONST_CAST(GLEW_APPLE_element_array) = !_glewInit_GL_APPLE_element_array(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_element_array */ -#ifdef GL_APPLE_fence - CONST_CAST(GLEW_APPLE_fence) = _glewSearchExtension("GL_APPLE_fence", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_fence) CONST_CAST(GLEW_APPLE_fence) = !_glewInit_GL_APPLE_fence(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_fence */ -#ifdef GL_APPLE_float_pixels - CONST_CAST(GLEW_APPLE_float_pixels) = _glewSearchExtension("GL_APPLE_float_pixels", extStart, extEnd); -#endif /* GL_APPLE_float_pixels */ -#ifdef GL_APPLE_flush_buffer_range - CONST_CAST(GLEW_APPLE_flush_buffer_range) = _glewSearchExtension("GL_APPLE_flush_buffer_range", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_flush_buffer_range) CONST_CAST(GLEW_APPLE_flush_buffer_range) = !_glewInit_GL_APPLE_flush_buffer_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_flush_buffer_range */ -#ifdef GL_APPLE_object_purgeable - CONST_CAST(GLEW_APPLE_object_purgeable) = _glewSearchExtension("GL_APPLE_object_purgeable", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_object_purgeable) CONST_CAST(GLEW_APPLE_object_purgeable) = !_glewInit_GL_APPLE_object_purgeable(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_object_purgeable */ -#ifdef GL_APPLE_pixel_buffer - CONST_CAST(GLEW_APPLE_pixel_buffer) = _glewSearchExtension("GL_APPLE_pixel_buffer", extStart, extEnd); -#endif /* GL_APPLE_pixel_buffer */ -#ifdef GL_APPLE_rgb_422 - CONST_CAST(GLEW_APPLE_rgb_422) = _glewSearchExtension("GL_APPLE_rgb_422", extStart, extEnd); -#endif /* GL_APPLE_rgb_422 */ -#ifdef GL_APPLE_row_bytes - CONST_CAST(GLEW_APPLE_row_bytes) = _glewSearchExtension("GL_APPLE_row_bytes", extStart, extEnd); -#endif /* GL_APPLE_row_bytes */ -#ifdef GL_APPLE_specular_vector - CONST_CAST(GLEW_APPLE_specular_vector) = _glewSearchExtension("GL_APPLE_specular_vector", extStart, extEnd); -#endif /* GL_APPLE_specular_vector */ -#ifdef GL_APPLE_texture_range - CONST_CAST(GLEW_APPLE_texture_range) = _glewSearchExtension("GL_APPLE_texture_range", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_texture_range) CONST_CAST(GLEW_APPLE_texture_range) = !_glewInit_GL_APPLE_texture_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_texture_range */ -#ifdef GL_APPLE_transform_hint - CONST_CAST(GLEW_APPLE_transform_hint) = _glewSearchExtension("GL_APPLE_transform_hint", extStart, extEnd); -#endif /* GL_APPLE_transform_hint */ -#ifdef GL_APPLE_vertex_array_object - CONST_CAST(GLEW_APPLE_vertex_array_object) = _glewSearchExtension("GL_APPLE_vertex_array_object", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_vertex_array_object) CONST_CAST(GLEW_APPLE_vertex_array_object) = !_glewInit_GL_APPLE_vertex_array_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_vertex_array_object */ -#ifdef GL_APPLE_vertex_array_range - CONST_CAST(GLEW_APPLE_vertex_array_range) = _glewSearchExtension("GL_APPLE_vertex_array_range", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_vertex_array_range) CONST_CAST(GLEW_APPLE_vertex_array_range) = !_glewInit_GL_APPLE_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_vertex_array_range */ -#ifdef GL_APPLE_vertex_program_evaluators - CONST_CAST(GLEW_APPLE_vertex_program_evaluators) = _glewSearchExtension("GL_APPLE_vertex_program_evaluators", extStart, extEnd); - if (glewExperimental || GLEW_APPLE_vertex_program_evaluators) CONST_CAST(GLEW_APPLE_vertex_program_evaluators) = !_glewInit_GL_APPLE_vertex_program_evaluators(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_APPLE_vertex_program_evaluators */ -#ifdef GL_APPLE_ycbcr_422 - CONST_CAST(GLEW_APPLE_ycbcr_422) = _glewSearchExtension("GL_APPLE_ycbcr_422", extStart, extEnd); -#endif /* GL_APPLE_ycbcr_422 */ -#ifdef GL_ARB_ES2_compatibility - CONST_CAST(GLEW_ARB_ES2_compatibility) = _glewSearchExtension("GL_ARB_ES2_compatibility", extStart, extEnd); - if (glewExperimental || GLEW_ARB_ES2_compatibility) CONST_CAST(GLEW_ARB_ES2_compatibility) = !_glewInit_GL_ARB_ES2_compatibility(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_ES2_compatibility */ -#ifdef GL_ARB_ES3_compatibility - CONST_CAST(GLEW_ARB_ES3_compatibility) = _glewSearchExtension("GL_ARB_ES3_compatibility", extStart, extEnd); -#endif /* GL_ARB_ES3_compatibility */ -#ifdef GL_ARB_arrays_of_arrays - CONST_CAST(GLEW_ARB_arrays_of_arrays) = _glewSearchExtension("GL_ARB_arrays_of_arrays", extStart, extEnd); -#endif /* GL_ARB_arrays_of_arrays */ -#ifdef GL_ARB_base_instance - CONST_CAST(GLEW_ARB_base_instance) = _glewSearchExtension("GL_ARB_base_instance", extStart, extEnd); - if (glewExperimental || GLEW_ARB_base_instance) CONST_CAST(GLEW_ARB_base_instance) = !_glewInit_GL_ARB_base_instance(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_base_instance */ -#ifdef GL_ARB_bindless_texture - CONST_CAST(GLEW_ARB_bindless_texture) = _glewSearchExtension("GL_ARB_bindless_texture", extStart, extEnd); - if (glewExperimental || GLEW_ARB_bindless_texture) CONST_CAST(GLEW_ARB_bindless_texture) = !_glewInit_GL_ARB_bindless_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_bindless_texture */ -#ifdef GL_ARB_blend_func_extended - CONST_CAST(GLEW_ARB_blend_func_extended) = _glewSearchExtension("GL_ARB_blend_func_extended", extStart, extEnd); - if (glewExperimental || GLEW_ARB_blend_func_extended) CONST_CAST(GLEW_ARB_blend_func_extended) = !_glewInit_GL_ARB_blend_func_extended(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_blend_func_extended */ -#ifdef GL_ARB_buffer_storage - CONST_CAST(GLEW_ARB_buffer_storage) = _glewSearchExtension("GL_ARB_buffer_storage", extStart, extEnd); - if (glewExperimental || GLEW_ARB_buffer_storage) CONST_CAST(GLEW_ARB_buffer_storage) = !_glewInit_GL_ARB_buffer_storage(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_buffer_storage */ -#ifdef GL_ARB_cl_event - CONST_CAST(GLEW_ARB_cl_event) = _glewSearchExtension("GL_ARB_cl_event", extStart, extEnd); - if (glewExperimental || GLEW_ARB_cl_event) CONST_CAST(GLEW_ARB_cl_event) = !_glewInit_GL_ARB_cl_event(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_cl_event */ -#ifdef GL_ARB_clear_buffer_object - CONST_CAST(GLEW_ARB_clear_buffer_object) = _glewSearchExtension("GL_ARB_clear_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_clear_buffer_object) CONST_CAST(GLEW_ARB_clear_buffer_object) = !_glewInit_GL_ARB_clear_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_clear_buffer_object */ -#ifdef GL_ARB_clear_texture - CONST_CAST(GLEW_ARB_clear_texture) = _glewSearchExtension("GL_ARB_clear_texture", extStart, extEnd); - if (glewExperimental || GLEW_ARB_clear_texture) CONST_CAST(GLEW_ARB_clear_texture) = !_glewInit_GL_ARB_clear_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_clear_texture */ -#ifdef GL_ARB_color_buffer_float - CONST_CAST(GLEW_ARB_color_buffer_float) = _glewSearchExtension("GL_ARB_color_buffer_float", extStart, extEnd); - if (glewExperimental || GLEW_ARB_color_buffer_float) CONST_CAST(GLEW_ARB_color_buffer_float) = !_glewInit_GL_ARB_color_buffer_float(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_color_buffer_float */ -#ifdef GL_ARB_compatibility - CONST_CAST(GLEW_ARB_compatibility) = _glewSearchExtension("GL_ARB_compatibility", extStart, extEnd); -#endif /* GL_ARB_compatibility */ -#ifdef GL_ARB_compressed_texture_pixel_storage - CONST_CAST(GLEW_ARB_compressed_texture_pixel_storage) = _glewSearchExtension("GL_ARB_compressed_texture_pixel_storage", extStart, extEnd); -#endif /* GL_ARB_compressed_texture_pixel_storage */ -#ifdef GL_ARB_compute_shader - CONST_CAST(GLEW_ARB_compute_shader) = _glewSearchExtension("GL_ARB_compute_shader", extStart, extEnd); - if (glewExperimental || GLEW_ARB_compute_shader) CONST_CAST(GLEW_ARB_compute_shader) = !_glewInit_GL_ARB_compute_shader(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_compute_shader */ -#ifdef GL_ARB_compute_variable_group_size - CONST_CAST(GLEW_ARB_compute_variable_group_size) = _glewSearchExtension("GL_ARB_compute_variable_group_size", extStart, extEnd); - if (glewExperimental || GLEW_ARB_compute_variable_group_size) CONST_CAST(GLEW_ARB_compute_variable_group_size) = !_glewInit_GL_ARB_compute_variable_group_size(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_compute_variable_group_size */ -#ifdef GL_ARB_conservative_depth - CONST_CAST(GLEW_ARB_conservative_depth) = _glewSearchExtension("GL_ARB_conservative_depth", extStart, extEnd); -#endif /* GL_ARB_conservative_depth */ -#ifdef GL_ARB_copy_buffer - CONST_CAST(GLEW_ARB_copy_buffer) = _glewSearchExtension("GL_ARB_copy_buffer", extStart, extEnd); - if (glewExperimental || GLEW_ARB_copy_buffer) CONST_CAST(GLEW_ARB_copy_buffer) = !_glewInit_GL_ARB_copy_buffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_copy_buffer */ -#ifdef GL_ARB_copy_image - CONST_CAST(GLEW_ARB_copy_image) = _glewSearchExtension("GL_ARB_copy_image", extStart, extEnd); - if (glewExperimental || GLEW_ARB_copy_image) CONST_CAST(GLEW_ARB_copy_image) = !_glewInit_GL_ARB_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_copy_image */ -#ifdef GL_ARB_debug_output - CONST_CAST(GLEW_ARB_debug_output) = _glewSearchExtension("GL_ARB_debug_output", extStart, extEnd); - if (glewExperimental || GLEW_ARB_debug_output) CONST_CAST(GLEW_ARB_debug_output) = !_glewInit_GL_ARB_debug_output(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_debug_output */ -#ifdef GL_ARB_depth_buffer_float - CONST_CAST(GLEW_ARB_depth_buffer_float) = _glewSearchExtension("GL_ARB_depth_buffer_float", extStart, extEnd); -#endif /* GL_ARB_depth_buffer_float */ -#ifdef GL_ARB_depth_clamp - CONST_CAST(GLEW_ARB_depth_clamp) = _glewSearchExtension("GL_ARB_depth_clamp", extStart, extEnd); -#endif /* GL_ARB_depth_clamp */ -#ifdef GL_ARB_depth_texture - CONST_CAST(GLEW_ARB_depth_texture) = _glewSearchExtension("GL_ARB_depth_texture", extStart, extEnd); -#endif /* GL_ARB_depth_texture */ -#ifdef GL_ARB_draw_buffers - CONST_CAST(GLEW_ARB_draw_buffers) = _glewSearchExtension("GL_ARB_draw_buffers", extStart, extEnd); - if (glewExperimental || GLEW_ARB_draw_buffers) CONST_CAST(GLEW_ARB_draw_buffers) = !_glewInit_GL_ARB_draw_buffers(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_draw_buffers */ -#ifdef GL_ARB_draw_buffers_blend - CONST_CAST(GLEW_ARB_draw_buffers_blend) = _glewSearchExtension("GL_ARB_draw_buffers_blend", extStart, extEnd); - if (glewExperimental || GLEW_ARB_draw_buffers_blend) CONST_CAST(GLEW_ARB_draw_buffers_blend) = !_glewInit_GL_ARB_draw_buffers_blend(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_draw_buffers_blend */ -#ifdef GL_ARB_draw_elements_base_vertex - CONST_CAST(GLEW_ARB_draw_elements_base_vertex) = _glewSearchExtension("GL_ARB_draw_elements_base_vertex", extStart, extEnd); - if (glewExperimental || GLEW_ARB_draw_elements_base_vertex) CONST_CAST(GLEW_ARB_draw_elements_base_vertex) = !_glewInit_GL_ARB_draw_elements_base_vertex(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_draw_elements_base_vertex */ -#ifdef GL_ARB_draw_indirect - CONST_CAST(GLEW_ARB_draw_indirect) = _glewSearchExtension("GL_ARB_draw_indirect", extStart, extEnd); - if (glewExperimental || GLEW_ARB_draw_indirect) CONST_CAST(GLEW_ARB_draw_indirect) = !_glewInit_GL_ARB_draw_indirect(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_draw_indirect */ -#ifdef GL_ARB_draw_instanced - CONST_CAST(GLEW_ARB_draw_instanced) = _glewSearchExtension("GL_ARB_draw_instanced", extStart, extEnd); -#endif /* GL_ARB_draw_instanced */ -#ifdef GL_ARB_enhanced_layouts - CONST_CAST(GLEW_ARB_enhanced_layouts) = _glewSearchExtension("GL_ARB_enhanced_layouts", extStart, extEnd); -#endif /* GL_ARB_enhanced_layouts */ -#ifdef GL_ARB_explicit_attrib_location - CONST_CAST(GLEW_ARB_explicit_attrib_location) = _glewSearchExtension("GL_ARB_explicit_attrib_location", extStart, extEnd); -#endif /* GL_ARB_explicit_attrib_location */ -#ifdef GL_ARB_explicit_uniform_location - CONST_CAST(GLEW_ARB_explicit_uniform_location) = _glewSearchExtension("GL_ARB_explicit_uniform_location", extStart, extEnd); -#endif /* GL_ARB_explicit_uniform_location */ -#ifdef GL_ARB_fragment_coord_conventions - CONST_CAST(GLEW_ARB_fragment_coord_conventions) = _glewSearchExtension("GL_ARB_fragment_coord_conventions", extStart, extEnd); -#endif /* GL_ARB_fragment_coord_conventions */ -#ifdef GL_ARB_fragment_layer_viewport - CONST_CAST(GLEW_ARB_fragment_layer_viewport) = _glewSearchExtension("GL_ARB_fragment_layer_viewport", extStart, extEnd); -#endif /* GL_ARB_fragment_layer_viewport */ -#ifdef GL_ARB_fragment_program - CONST_CAST(GLEW_ARB_fragment_program) = _glewSearchExtension("GL_ARB_fragment_program", extStart, extEnd); -#endif /* GL_ARB_fragment_program */ -#ifdef GL_ARB_fragment_program_shadow - CONST_CAST(GLEW_ARB_fragment_program_shadow) = _glewSearchExtension("GL_ARB_fragment_program_shadow", extStart, extEnd); -#endif /* GL_ARB_fragment_program_shadow */ -#ifdef GL_ARB_fragment_shader - CONST_CAST(GLEW_ARB_fragment_shader) = _glewSearchExtension("GL_ARB_fragment_shader", extStart, extEnd); -#endif /* GL_ARB_fragment_shader */ -#ifdef GL_ARB_framebuffer_no_attachments - CONST_CAST(GLEW_ARB_framebuffer_no_attachments) = _glewSearchExtension("GL_ARB_framebuffer_no_attachments", extStart, extEnd); - if (glewExperimental || GLEW_ARB_framebuffer_no_attachments) CONST_CAST(GLEW_ARB_framebuffer_no_attachments) = !_glewInit_GL_ARB_framebuffer_no_attachments(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_framebuffer_no_attachments */ -#ifdef GL_ARB_framebuffer_object - CONST_CAST(GLEW_ARB_framebuffer_object) = _glewSearchExtension("GL_ARB_framebuffer_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_framebuffer_object) CONST_CAST(GLEW_ARB_framebuffer_object) = !_glewInit_GL_ARB_framebuffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_framebuffer_object */ -#ifdef GL_ARB_framebuffer_sRGB - CONST_CAST(GLEW_ARB_framebuffer_sRGB) = _glewSearchExtension("GL_ARB_framebuffer_sRGB", extStart, extEnd); -#endif /* GL_ARB_framebuffer_sRGB */ -#ifdef GL_ARB_geometry_shader4 - CONST_CAST(GLEW_ARB_geometry_shader4) = _glewSearchExtension("GL_ARB_geometry_shader4", extStart, extEnd); - if (glewExperimental || GLEW_ARB_geometry_shader4) CONST_CAST(GLEW_ARB_geometry_shader4) = !_glewInit_GL_ARB_geometry_shader4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_geometry_shader4 */ -#ifdef GL_ARB_get_program_binary - CONST_CAST(GLEW_ARB_get_program_binary) = _glewSearchExtension("GL_ARB_get_program_binary", extStart, extEnd); - if (glewExperimental || GLEW_ARB_get_program_binary) CONST_CAST(GLEW_ARB_get_program_binary) = !_glewInit_GL_ARB_get_program_binary(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_get_program_binary */ -#ifdef GL_ARB_gpu_shader5 - CONST_CAST(GLEW_ARB_gpu_shader5) = _glewSearchExtension("GL_ARB_gpu_shader5", extStart, extEnd); -#endif /* GL_ARB_gpu_shader5 */ -#ifdef GL_ARB_gpu_shader_fp64 - CONST_CAST(GLEW_ARB_gpu_shader_fp64) = _glewSearchExtension("GL_ARB_gpu_shader_fp64", extStart, extEnd); - if (glewExperimental || GLEW_ARB_gpu_shader_fp64) CONST_CAST(GLEW_ARB_gpu_shader_fp64) = !_glewInit_GL_ARB_gpu_shader_fp64(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_gpu_shader_fp64 */ -#ifdef GL_ARB_half_float_pixel - CONST_CAST(GLEW_ARB_half_float_pixel) = _glewSearchExtension("GL_ARB_half_float_pixel", extStart, extEnd); -#endif /* GL_ARB_half_float_pixel */ -#ifdef GL_ARB_half_float_vertex - CONST_CAST(GLEW_ARB_half_float_vertex) = _glewSearchExtension("GL_ARB_half_float_vertex", extStart, extEnd); -#endif /* GL_ARB_half_float_vertex */ -#ifdef GL_ARB_imaging - CONST_CAST(GLEW_ARB_imaging) = _glewSearchExtension("GL_ARB_imaging", extStart, extEnd); - if (glewExperimental || GLEW_ARB_imaging) CONST_CAST(GLEW_ARB_imaging) = !_glewInit_GL_ARB_imaging(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_imaging */ -#ifdef GL_ARB_indirect_parameters - CONST_CAST(GLEW_ARB_indirect_parameters) = _glewSearchExtension("GL_ARB_indirect_parameters", extStart, extEnd); - if (glewExperimental || GLEW_ARB_indirect_parameters) CONST_CAST(GLEW_ARB_indirect_parameters) = !_glewInit_GL_ARB_indirect_parameters(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_indirect_parameters */ -#ifdef GL_ARB_instanced_arrays - CONST_CAST(GLEW_ARB_instanced_arrays) = _glewSearchExtension("GL_ARB_instanced_arrays", extStart, extEnd); - if (glewExperimental || GLEW_ARB_instanced_arrays) CONST_CAST(GLEW_ARB_instanced_arrays) = !_glewInit_GL_ARB_instanced_arrays(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_instanced_arrays */ -#ifdef GL_ARB_internalformat_query - CONST_CAST(GLEW_ARB_internalformat_query) = _glewSearchExtension("GL_ARB_internalformat_query", extStart, extEnd); - if (glewExperimental || GLEW_ARB_internalformat_query) CONST_CAST(GLEW_ARB_internalformat_query) = !_glewInit_GL_ARB_internalformat_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_internalformat_query */ -#ifdef GL_ARB_internalformat_query2 - CONST_CAST(GLEW_ARB_internalformat_query2) = _glewSearchExtension("GL_ARB_internalformat_query2", extStart, extEnd); - if (glewExperimental || GLEW_ARB_internalformat_query2) CONST_CAST(GLEW_ARB_internalformat_query2) = !_glewInit_GL_ARB_internalformat_query2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_internalformat_query2 */ -#ifdef GL_ARB_invalidate_subdata - CONST_CAST(GLEW_ARB_invalidate_subdata) = _glewSearchExtension("GL_ARB_invalidate_subdata", extStart, extEnd); - if (glewExperimental || GLEW_ARB_invalidate_subdata) CONST_CAST(GLEW_ARB_invalidate_subdata) = !_glewInit_GL_ARB_invalidate_subdata(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_invalidate_subdata */ -#ifdef GL_ARB_map_buffer_alignment - CONST_CAST(GLEW_ARB_map_buffer_alignment) = _glewSearchExtension("GL_ARB_map_buffer_alignment", extStart, extEnd); -#endif /* GL_ARB_map_buffer_alignment */ -#ifdef GL_ARB_map_buffer_range - CONST_CAST(GLEW_ARB_map_buffer_range) = _glewSearchExtension("GL_ARB_map_buffer_range", extStart, extEnd); - if (glewExperimental || GLEW_ARB_map_buffer_range) CONST_CAST(GLEW_ARB_map_buffer_range) = !_glewInit_GL_ARB_map_buffer_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_map_buffer_range */ -#ifdef GL_ARB_matrix_palette - CONST_CAST(GLEW_ARB_matrix_palette) = _glewSearchExtension("GL_ARB_matrix_palette", extStart, extEnd); - if (glewExperimental || GLEW_ARB_matrix_palette) CONST_CAST(GLEW_ARB_matrix_palette) = !_glewInit_GL_ARB_matrix_palette(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_matrix_palette */ -#ifdef GL_ARB_multi_bind - CONST_CAST(GLEW_ARB_multi_bind) = _glewSearchExtension("GL_ARB_multi_bind", extStart, extEnd); - if (glewExperimental || GLEW_ARB_multi_bind) CONST_CAST(GLEW_ARB_multi_bind) = !_glewInit_GL_ARB_multi_bind(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_multi_bind */ -#ifdef GL_ARB_multi_draw_indirect - CONST_CAST(GLEW_ARB_multi_draw_indirect) = _glewSearchExtension("GL_ARB_multi_draw_indirect", extStart, extEnd); - if (glewExperimental || GLEW_ARB_multi_draw_indirect) CONST_CAST(GLEW_ARB_multi_draw_indirect) = !_glewInit_GL_ARB_multi_draw_indirect(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_multi_draw_indirect */ -#ifdef GL_ARB_multisample - CONST_CAST(GLEW_ARB_multisample) = _glewSearchExtension("GL_ARB_multisample", extStart, extEnd); - if (glewExperimental || GLEW_ARB_multisample) CONST_CAST(GLEW_ARB_multisample) = !_glewInit_GL_ARB_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_multisample */ -#ifdef GL_ARB_multitexture - CONST_CAST(GLEW_ARB_multitexture) = _glewSearchExtension("GL_ARB_multitexture", extStart, extEnd); - if (glewExperimental || GLEW_ARB_multitexture) CONST_CAST(GLEW_ARB_multitexture) = !_glewInit_GL_ARB_multitexture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_multitexture */ -#ifdef GL_ARB_occlusion_query - CONST_CAST(GLEW_ARB_occlusion_query) = _glewSearchExtension("GL_ARB_occlusion_query", extStart, extEnd); - if (glewExperimental || GLEW_ARB_occlusion_query) CONST_CAST(GLEW_ARB_occlusion_query) = !_glewInit_GL_ARB_occlusion_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_occlusion_query */ -#ifdef GL_ARB_occlusion_query2 - CONST_CAST(GLEW_ARB_occlusion_query2) = _glewSearchExtension("GL_ARB_occlusion_query2", extStart, extEnd); -#endif /* GL_ARB_occlusion_query2 */ -#ifdef GL_ARB_pixel_buffer_object - CONST_CAST(GLEW_ARB_pixel_buffer_object) = _glewSearchExtension("GL_ARB_pixel_buffer_object", extStart, extEnd); -#endif /* GL_ARB_pixel_buffer_object */ -#ifdef GL_ARB_point_parameters - CONST_CAST(GLEW_ARB_point_parameters) = _glewSearchExtension("GL_ARB_point_parameters", extStart, extEnd); - if (glewExperimental || GLEW_ARB_point_parameters) CONST_CAST(GLEW_ARB_point_parameters) = !_glewInit_GL_ARB_point_parameters(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_point_parameters */ -#ifdef GL_ARB_point_sprite - CONST_CAST(GLEW_ARB_point_sprite) = _glewSearchExtension("GL_ARB_point_sprite", extStart, extEnd); -#endif /* GL_ARB_point_sprite */ -#ifdef GL_ARB_program_interface_query - CONST_CAST(GLEW_ARB_program_interface_query) = _glewSearchExtension("GL_ARB_program_interface_query", extStart, extEnd); - if (glewExperimental || GLEW_ARB_program_interface_query) CONST_CAST(GLEW_ARB_program_interface_query) = !_glewInit_GL_ARB_program_interface_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_program_interface_query */ -#ifdef GL_ARB_provoking_vertex - CONST_CAST(GLEW_ARB_provoking_vertex) = _glewSearchExtension("GL_ARB_provoking_vertex", extStart, extEnd); - if (glewExperimental || GLEW_ARB_provoking_vertex) CONST_CAST(GLEW_ARB_provoking_vertex) = !_glewInit_GL_ARB_provoking_vertex(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_provoking_vertex */ -#ifdef GL_ARB_query_buffer_object - CONST_CAST(GLEW_ARB_query_buffer_object) = _glewSearchExtension("GL_ARB_query_buffer_object", extStart, extEnd); -#endif /* GL_ARB_query_buffer_object */ -#ifdef GL_ARB_robust_buffer_access_behavior - CONST_CAST(GLEW_ARB_robust_buffer_access_behavior) = _glewSearchExtension("GL_ARB_robust_buffer_access_behavior", extStart, extEnd); -#endif /* GL_ARB_robust_buffer_access_behavior */ -#ifdef GL_ARB_robustness - CONST_CAST(GLEW_ARB_robustness) = _glewSearchExtension("GL_ARB_robustness", extStart, extEnd); - if (glewExperimental || GLEW_ARB_robustness) CONST_CAST(GLEW_ARB_robustness) = !_glewInit_GL_ARB_robustness(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_robustness */ -#ifdef GL_ARB_robustness_application_isolation - CONST_CAST(GLEW_ARB_robustness_application_isolation) = _glewSearchExtension("GL_ARB_robustness_application_isolation", extStart, extEnd); -#endif /* GL_ARB_robustness_application_isolation */ -#ifdef GL_ARB_robustness_share_group_isolation - CONST_CAST(GLEW_ARB_robustness_share_group_isolation) = _glewSearchExtension("GL_ARB_robustness_share_group_isolation", extStart, extEnd); -#endif /* GL_ARB_robustness_share_group_isolation */ -#ifdef GL_ARB_sample_shading - CONST_CAST(GLEW_ARB_sample_shading) = _glewSearchExtension("GL_ARB_sample_shading", extStart, extEnd); - if (glewExperimental || GLEW_ARB_sample_shading) CONST_CAST(GLEW_ARB_sample_shading) = !_glewInit_GL_ARB_sample_shading(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_sample_shading */ -#ifdef GL_ARB_sampler_objects - CONST_CAST(GLEW_ARB_sampler_objects) = _glewSearchExtension("GL_ARB_sampler_objects", extStart, extEnd); - if (glewExperimental || GLEW_ARB_sampler_objects) CONST_CAST(GLEW_ARB_sampler_objects) = !_glewInit_GL_ARB_sampler_objects(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_sampler_objects */ -#ifdef GL_ARB_seamless_cube_map - CONST_CAST(GLEW_ARB_seamless_cube_map) = _glewSearchExtension("GL_ARB_seamless_cube_map", extStart, extEnd); -#endif /* GL_ARB_seamless_cube_map */ -#ifdef GL_ARB_seamless_cubemap_per_texture - CONST_CAST(GLEW_ARB_seamless_cubemap_per_texture) = _glewSearchExtension("GL_ARB_seamless_cubemap_per_texture", extStart, extEnd); -#endif /* GL_ARB_seamless_cubemap_per_texture */ -#ifdef GL_ARB_separate_shader_objects - CONST_CAST(GLEW_ARB_separate_shader_objects) = _glewSearchExtension("GL_ARB_separate_shader_objects", extStart, extEnd); - if (glewExperimental || GLEW_ARB_separate_shader_objects) CONST_CAST(GLEW_ARB_separate_shader_objects) = !_glewInit_GL_ARB_separate_shader_objects(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_separate_shader_objects */ -#ifdef GL_ARB_shader_atomic_counters - CONST_CAST(GLEW_ARB_shader_atomic_counters) = _glewSearchExtension("GL_ARB_shader_atomic_counters", extStart, extEnd); - if (glewExperimental || GLEW_ARB_shader_atomic_counters) CONST_CAST(GLEW_ARB_shader_atomic_counters) = !_glewInit_GL_ARB_shader_atomic_counters(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_shader_atomic_counters */ -#ifdef GL_ARB_shader_bit_encoding - CONST_CAST(GLEW_ARB_shader_bit_encoding) = _glewSearchExtension("GL_ARB_shader_bit_encoding", extStart, extEnd); -#endif /* GL_ARB_shader_bit_encoding */ -#ifdef GL_ARB_shader_draw_parameters - CONST_CAST(GLEW_ARB_shader_draw_parameters) = _glewSearchExtension("GL_ARB_shader_draw_parameters", extStart, extEnd); -#endif /* GL_ARB_shader_draw_parameters */ -#ifdef GL_ARB_shader_group_vote - CONST_CAST(GLEW_ARB_shader_group_vote) = _glewSearchExtension("GL_ARB_shader_group_vote", extStart, extEnd); -#endif /* GL_ARB_shader_group_vote */ -#ifdef GL_ARB_shader_image_load_store - CONST_CAST(GLEW_ARB_shader_image_load_store) = _glewSearchExtension("GL_ARB_shader_image_load_store", extStart, extEnd); - if (glewExperimental || GLEW_ARB_shader_image_load_store) CONST_CAST(GLEW_ARB_shader_image_load_store) = !_glewInit_GL_ARB_shader_image_load_store(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_shader_image_load_store */ -#ifdef GL_ARB_shader_image_size - CONST_CAST(GLEW_ARB_shader_image_size) = _glewSearchExtension("GL_ARB_shader_image_size", extStart, extEnd); -#endif /* GL_ARB_shader_image_size */ -#ifdef GL_ARB_shader_objects - CONST_CAST(GLEW_ARB_shader_objects) = _glewSearchExtension("GL_ARB_shader_objects", extStart, extEnd); - if (glewExperimental || GLEW_ARB_shader_objects) CONST_CAST(GLEW_ARB_shader_objects) = !_glewInit_GL_ARB_shader_objects(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_shader_objects */ -#ifdef GL_ARB_shader_precision - CONST_CAST(GLEW_ARB_shader_precision) = _glewSearchExtension("GL_ARB_shader_precision", extStart, extEnd); -#endif /* GL_ARB_shader_precision */ -#ifdef GL_ARB_shader_stencil_export - CONST_CAST(GLEW_ARB_shader_stencil_export) = _glewSearchExtension("GL_ARB_shader_stencil_export", extStart, extEnd); -#endif /* GL_ARB_shader_stencil_export */ -#ifdef GL_ARB_shader_storage_buffer_object - CONST_CAST(GLEW_ARB_shader_storage_buffer_object) = _glewSearchExtension("GL_ARB_shader_storage_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_shader_storage_buffer_object) CONST_CAST(GLEW_ARB_shader_storage_buffer_object) = !_glewInit_GL_ARB_shader_storage_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_shader_storage_buffer_object */ -#ifdef GL_ARB_shader_subroutine - CONST_CAST(GLEW_ARB_shader_subroutine) = _glewSearchExtension("GL_ARB_shader_subroutine", extStart, extEnd); - if (glewExperimental || GLEW_ARB_shader_subroutine) CONST_CAST(GLEW_ARB_shader_subroutine) = !_glewInit_GL_ARB_shader_subroutine(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_shader_subroutine */ -#ifdef GL_ARB_shader_texture_lod - CONST_CAST(GLEW_ARB_shader_texture_lod) = _glewSearchExtension("GL_ARB_shader_texture_lod", extStart, extEnd); -#endif /* GL_ARB_shader_texture_lod */ -#ifdef GL_ARB_shading_language_100 - CONST_CAST(GLEW_ARB_shading_language_100) = _glewSearchExtension("GL_ARB_shading_language_100", extStart, extEnd); -#endif /* GL_ARB_shading_language_100 */ -#ifdef GL_ARB_shading_language_420pack - CONST_CAST(GLEW_ARB_shading_language_420pack) = _glewSearchExtension("GL_ARB_shading_language_420pack", extStart, extEnd); -#endif /* GL_ARB_shading_language_420pack */ -#ifdef GL_ARB_shading_language_include - CONST_CAST(GLEW_ARB_shading_language_include) = _glewSearchExtension("GL_ARB_shading_language_include", extStart, extEnd); - if (glewExperimental || GLEW_ARB_shading_language_include) CONST_CAST(GLEW_ARB_shading_language_include) = !_glewInit_GL_ARB_shading_language_include(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_shading_language_include */ -#ifdef GL_ARB_shading_language_packing - CONST_CAST(GLEW_ARB_shading_language_packing) = _glewSearchExtension("GL_ARB_shading_language_packing", extStart, extEnd); -#endif /* GL_ARB_shading_language_packing */ -#ifdef GL_ARB_shadow - CONST_CAST(GLEW_ARB_shadow) = _glewSearchExtension("GL_ARB_shadow", extStart, extEnd); -#endif /* GL_ARB_shadow */ -#ifdef GL_ARB_shadow_ambient - CONST_CAST(GLEW_ARB_shadow_ambient) = _glewSearchExtension("GL_ARB_shadow_ambient", extStart, extEnd); -#endif /* GL_ARB_shadow_ambient */ -#ifdef GL_ARB_sparse_texture - CONST_CAST(GLEW_ARB_sparse_texture) = _glewSearchExtension("GL_ARB_sparse_texture", extStart, extEnd); - if (glewExperimental || GLEW_ARB_sparse_texture) CONST_CAST(GLEW_ARB_sparse_texture) = !_glewInit_GL_ARB_sparse_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_sparse_texture */ -#ifdef GL_ARB_stencil_texturing - CONST_CAST(GLEW_ARB_stencil_texturing) = _glewSearchExtension("GL_ARB_stencil_texturing", extStart, extEnd); -#endif /* GL_ARB_stencil_texturing */ -#ifdef GL_ARB_sync - CONST_CAST(GLEW_ARB_sync) = _glewSearchExtension("GL_ARB_sync", extStart, extEnd); - if (glewExperimental || GLEW_ARB_sync) CONST_CAST(GLEW_ARB_sync) = !_glewInit_GL_ARB_sync(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_sync */ -#ifdef GL_ARB_tessellation_shader - CONST_CAST(GLEW_ARB_tessellation_shader) = _glewSearchExtension("GL_ARB_tessellation_shader", extStart, extEnd); - if (glewExperimental || GLEW_ARB_tessellation_shader) CONST_CAST(GLEW_ARB_tessellation_shader) = !_glewInit_GL_ARB_tessellation_shader(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_tessellation_shader */ -#ifdef GL_ARB_texture_border_clamp - CONST_CAST(GLEW_ARB_texture_border_clamp) = _glewSearchExtension("GL_ARB_texture_border_clamp", extStart, extEnd); -#endif /* GL_ARB_texture_border_clamp */ -#ifdef GL_ARB_texture_buffer_object - CONST_CAST(GLEW_ARB_texture_buffer_object) = _glewSearchExtension("GL_ARB_texture_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_buffer_object) CONST_CAST(GLEW_ARB_texture_buffer_object) = !_glewInit_GL_ARB_texture_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_buffer_object */ -#ifdef GL_ARB_texture_buffer_object_rgb32 - CONST_CAST(GLEW_ARB_texture_buffer_object_rgb32) = _glewSearchExtension("GL_ARB_texture_buffer_object_rgb32", extStart, extEnd); -#endif /* GL_ARB_texture_buffer_object_rgb32 */ -#ifdef GL_ARB_texture_buffer_range - CONST_CAST(GLEW_ARB_texture_buffer_range) = _glewSearchExtension("GL_ARB_texture_buffer_range", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_buffer_range) CONST_CAST(GLEW_ARB_texture_buffer_range) = !_glewInit_GL_ARB_texture_buffer_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_buffer_range */ -#ifdef GL_ARB_texture_compression - CONST_CAST(GLEW_ARB_texture_compression) = _glewSearchExtension("GL_ARB_texture_compression", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_compression) CONST_CAST(GLEW_ARB_texture_compression) = !_glewInit_GL_ARB_texture_compression(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_compression */ -#ifdef GL_ARB_texture_compression_bptc - CONST_CAST(GLEW_ARB_texture_compression_bptc) = _glewSearchExtension("GL_ARB_texture_compression_bptc", extStart, extEnd); -#endif /* GL_ARB_texture_compression_bptc */ -#ifdef GL_ARB_texture_compression_rgtc - CONST_CAST(GLEW_ARB_texture_compression_rgtc) = _glewSearchExtension("GL_ARB_texture_compression_rgtc", extStart, extEnd); -#endif /* GL_ARB_texture_compression_rgtc */ -#ifdef GL_ARB_texture_cube_map - CONST_CAST(GLEW_ARB_texture_cube_map) = _glewSearchExtension("GL_ARB_texture_cube_map", extStart, extEnd); -#endif /* GL_ARB_texture_cube_map */ -#ifdef GL_ARB_texture_cube_map_array - CONST_CAST(GLEW_ARB_texture_cube_map_array) = _glewSearchExtension("GL_ARB_texture_cube_map_array", extStart, extEnd); -#endif /* GL_ARB_texture_cube_map_array */ -#ifdef GL_ARB_texture_env_add - CONST_CAST(GLEW_ARB_texture_env_add) = _glewSearchExtension("GL_ARB_texture_env_add", extStart, extEnd); -#endif /* GL_ARB_texture_env_add */ -#ifdef GL_ARB_texture_env_combine - CONST_CAST(GLEW_ARB_texture_env_combine) = _glewSearchExtension("GL_ARB_texture_env_combine", extStart, extEnd); -#endif /* GL_ARB_texture_env_combine */ -#ifdef GL_ARB_texture_env_crossbar - CONST_CAST(GLEW_ARB_texture_env_crossbar) = _glewSearchExtension("GL_ARB_texture_env_crossbar", extStart, extEnd); -#endif /* GL_ARB_texture_env_crossbar */ -#ifdef GL_ARB_texture_env_dot3 - CONST_CAST(GLEW_ARB_texture_env_dot3) = _glewSearchExtension("GL_ARB_texture_env_dot3", extStart, extEnd); -#endif /* GL_ARB_texture_env_dot3 */ -#ifdef GL_ARB_texture_float - CONST_CAST(GLEW_ARB_texture_float) = _glewSearchExtension("GL_ARB_texture_float", extStart, extEnd); -#endif /* GL_ARB_texture_float */ -#ifdef GL_ARB_texture_gather - CONST_CAST(GLEW_ARB_texture_gather) = _glewSearchExtension("GL_ARB_texture_gather", extStart, extEnd); -#endif /* GL_ARB_texture_gather */ -#ifdef GL_ARB_texture_mirror_clamp_to_edge - CONST_CAST(GLEW_ARB_texture_mirror_clamp_to_edge) = _glewSearchExtension("GL_ARB_texture_mirror_clamp_to_edge", extStart, extEnd); -#endif /* GL_ARB_texture_mirror_clamp_to_edge */ -#ifdef GL_ARB_texture_mirrored_repeat - CONST_CAST(GLEW_ARB_texture_mirrored_repeat) = _glewSearchExtension("GL_ARB_texture_mirrored_repeat", extStart, extEnd); -#endif /* GL_ARB_texture_mirrored_repeat */ -#ifdef GL_ARB_texture_multisample - CONST_CAST(GLEW_ARB_texture_multisample) = _glewSearchExtension("GL_ARB_texture_multisample", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_multisample) CONST_CAST(GLEW_ARB_texture_multisample) = !_glewInit_GL_ARB_texture_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_multisample */ -#ifdef GL_ARB_texture_non_power_of_two - CONST_CAST(GLEW_ARB_texture_non_power_of_two) = _glewSearchExtension("GL_ARB_texture_non_power_of_two", extStart, extEnd); -#endif /* GL_ARB_texture_non_power_of_two */ -#ifdef GL_ARB_texture_query_levels - CONST_CAST(GLEW_ARB_texture_query_levels) = _glewSearchExtension("GL_ARB_texture_query_levels", extStart, extEnd); -#endif /* GL_ARB_texture_query_levels */ -#ifdef GL_ARB_texture_query_lod - CONST_CAST(GLEW_ARB_texture_query_lod) = _glewSearchExtension("GL_ARB_texture_query_lod", extStart, extEnd); -#endif /* GL_ARB_texture_query_lod */ -#ifdef GL_ARB_texture_rectangle - CONST_CAST(GLEW_ARB_texture_rectangle) = _glewSearchExtension("GL_ARB_texture_rectangle", extStart, extEnd); -#endif /* GL_ARB_texture_rectangle */ -#ifdef GL_ARB_texture_rg - CONST_CAST(GLEW_ARB_texture_rg) = _glewSearchExtension("GL_ARB_texture_rg", extStart, extEnd); -#endif /* GL_ARB_texture_rg */ -#ifdef GL_ARB_texture_rgb10_a2ui - CONST_CAST(GLEW_ARB_texture_rgb10_a2ui) = _glewSearchExtension("GL_ARB_texture_rgb10_a2ui", extStart, extEnd); -#endif /* GL_ARB_texture_rgb10_a2ui */ -#ifdef GL_ARB_texture_stencil8 - CONST_CAST(GLEW_ARB_texture_stencil8) = _glewSearchExtension("GL_ARB_texture_stencil8", extStart, extEnd); -#endif /* GL_ARB_texture_stencil8 */ -#ifdef GL_ARB_texture_storage - CONST_CAST(GLEW_ARB_texture_storage) = _glewSearchExtension("GL_ARB_texture_storage", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_storage) CONST_CAST(GLEW_ARB_texture_storage) = !_glewInit_GL_ARB_texture_storage(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_storage */ -#ifdef GL_ARB_texture_storage_multisample - CONST_CAST(GLEW_ARB_texture_storage_multisample) = _glewSearchExtension("GL_ARB_texture_storage_multisample", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_storage_multisample) CONST_CAST(GLEW_ARB_texture_storage_multisample) = !_glewInit_GL_ARB_texture_storage_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_storage_multisample */ -#ifdef GL_ARB_texture_swizzle - CONST_CAST(GLEW_ARB_texture_swizzle) = _glewSearchExtension("GL_ARB_texture_swizzle", extStart, extEnd); -#endif /* GL_ARB_texture_swizzle */ -#ifdef GL_ARB_texture_view - CONST_CAST(GLEW_ARB_texture_view) = _glewSearchExtension("GL_ARB_texture_view", extStart, extEnd); - if (glewExperimental || GLEW_ARB_texture_view) CONST_CAST(GLEW_ARB_texture_view) = !_glewInit_GL_ARB_texture_view(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_texture_view */ -#ifdef GL_ARB_timer_query - CONST_CAST(GLEW_ARB_timer_query) = _glewSearchExtension("GL_ARB_timer_query", extStart, extEnd); - if (glewExperimental || GLEW_ARB_timer_query) CONST_CAST(GLEW_ARB_timer_query) = !_glewInit_GL_ARB_timer_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_timer_query */ -#ifdef GL_ARB_transform_feedback2 - CONST_CAST(GLEW_ARB_transform_feedback2) = _glewSearchExtension("GL_ARB_transform_feedback2", extStart, extEnd); - if (glewExperimental || GLEW_ARB_transform_feedback2) CONST_CAST(GLEW_ARB_transform_feedback2) = !_glewInit_GL_ARB_transform_feedback2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_transform_feedback2 */ -#ifdef GL_ARB_transform_feedback3 - CONST_CAST(GLEW_ARB_transform_feedback3) = _glewSearchExtension("GL_ARB_transform_feedback3", extStart, extEnd); - if (glewExperimental || GLEW_ARB_transform_feedback3) CONST_CAST(GLEW_ARB_transform_feedback3) = !_glewInit_GL_ARB_transform_feedback3(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_transform_feedback3 */ -#ifdef GL_ARB_transform_feedback_instanced - CONST_CAST(GLEW_ARB_transform_feedback_instanced) = _glewSearchExtension("GL_ARB_transform_feedback_instanced", extStart, extEnd); - if (glewExperimental || GLEW_ARB_transform_feedback_instanced) CONST_CAST(GLEW_ARB_transform_feedback_instanced) = !_glewInit_GL_ARB_transform_feedback_instanced(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_transform_feedback_instanced */ -#ifdef GL_ARB_transpose_matrix - CONST_CAST(GLEW_ARB_transpose_matrix) = _glewSearchExtension("GL_ARB_transpose_matrix", extStart, extEnd); - if (glewExperimental || GLEW_ARB_transpose_matrix) CONST_CAST(GLEW_ARB_transpose_matrix) = !_glewInit_GL_ARB_transpose_matrix(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_transpose_matrix */ -#ifdef GL_ARB_uniform_buffer_object - CONST_CAST(GLEW_ARB_uniform_buffer_object) = _glewSearchExtension("GL_ARB_uniform_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_uniform_buffer_object) CONST_CAST(GLEW_ARB_uniform_buffer_object) = !_glewInit_GL_ARB_uniform_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_uniform_buffer_object */ -#ifdef GL_ARB_vertex_array_bgra - CONST_CAST(GLEW_ARB_vertex_array_bgra) = _glewSearchExtension("GL_ARB_vertex_array_bgra", extStart, extEnd); -#endif /* GL_ARB_vertex_array_bgra */ -#ifdef GL_ARB_vertex_array_object - CONST_CAST(GLEW_ARB_vertex_array_object) = _glewSearchExtension("GL_ARB_vertex_array_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_array_object) CONST_CAST(GLEW_ARB_vertex_array_object) = !_glewInit_GL_ARB_vertex_array_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_array_object */ -#ifdef GL_ARB_vertex_attrib_64bit - CONST_CAST(GLEW_ARB_vertex_attrib_64bit) = _glewSearchExtension("GL_ARB_vertex_attrib_64bit", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_attrib_64bit) CONST_CAST(GLEW_ARB_vertex_attrib_64bit) = !_glewInit_GL_ARB_vertex_attrib_64bit(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_attrib_64bit */ -#ifdef GL_ARB_vertex_attrib_binding - CONST_CAST(GLEW_ARB_vertex_attrib_binding) = _glewSearchExtension("GL_ARB_vertex_attrib_binding", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_attrib_binding) CONST_CAST(GLEW_ARB_vertex_attrib_binding) = !_glewInit_GL_ARB_vertex_attrib_binding(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_attrib_binding */ -#ifdef GL_ARB_vertex_blend - CONST_CAST(GLEW_ARB_vertex_blend) = _glewSearchExtension("GL_ARB_vertex_blend", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_blend) CONST_CAST(GLEW_ARB_vertex_blend) = !_glewInit_GL_ARB_vertex_blend(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_blend */ -#ifdef GL_ARB_vertex_buffer_object - CONST_CAST(GLEW_ARB_vertex_buffer_object) = _glewSearchExtension("GL_ARB_vertex_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_buffer_object) CONST_CAST(GLEW_ARB_vertex_buffer_object) = !_glewInit_GL_ARB_vertex_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_buffer_object */ -#ifdef GL_ARB_vertex_program - CONST_CAST(GLEW_ARB_vertex_program) = _glewSearchExtension("GL_ARB_vertex_program", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_program) CONST_CAST(GLEW_ARB_vertex_program) = !_glewInit_GL_ARB_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_program */ -#ifdef GL_ARB_vertex_shader - CONST_CAST(GLEW_ARB_vertex_shader) = _glewSearchExtension("GL_ARB_vertex_shader", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_shader) CONST_CAST(GLEW_ARB_vertex_shader) = !_glewInit_GL_ARB_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_shader */ -#ifdef GL_ARB_vertex_type_10f_11f_11f_rev - CONST_CAST(GLEW_ARB_vertex_type_10f_11f_11f_rev) = _glewSearchExtension("GL_ARB_vertex_type_10f_11f_11f_rev", extStart, extEnd); -#endif /* GL_ARB_vertex_type_10f_11f_11f_rev */ -#ifdef GL_ARB_vertex_type_2_10_10_10_rev - CONST_CAST(GLEW_ARB_vertex_type_2_10_10_10_rev) = _glewSearchExtension("GL_ARB_vertex_type_2_10_10_10_rev", extStart, extEnd); - if (glewExperimental || GLEW_ARB_vertex_type_2_10_10_10_rev) CONST_CAST(GLEW_ARB_vertex_type_2_10_10_10_rev) = !_glewInit_GL_ARB_vertex_type_2_10_10_10_rev(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ -#ifdef GL_ARB_viewport_array - CONST_CAST(GLEW_ARB_viewport_array) = _glewSearchExtension("GL_ARB_viewport_array", extStart, extEnd); - if (glewExperimental || GLEW_ARB_viewport_array) CONST_CAST(GLEW_ARB_viewport_array) = !_glewInit_GL_ARB_viewport_array(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_viewport_array */ -#ifdef GL_ARB_window_pos - CONST_CAST(GLEW_ARB_window_pos) = _glewSearchExtension("GL_ARB_window_pos", extStart, extEnd); - if (glewExperimental || GLEW_ARB_window_pos) CONST_CAST(GLEW_ARB_window_pos) = !_glewInit_GL_ARB_window_pos(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ARB_window_pos */ -#ifdef GL_ATIX_point_sprites - CONST_CAST(GLEW_ATIX_point_sprites) = _glewSearchExtension("GL_ATIX_point_sprites", extStart, extEnd); -#endif /* GL_ATIX_point_sprites */ -#ifdef GL_ATIX_texture_env_combine3 - CONST_CAST(GLEW_ATIX_texture_env_combine3) = _glewSearchExtension("GL_ATIX_texture_env_combine3", extStart, extEnd); -#endif /* GL_ATIX_texture_env_combine3 */ -#ifdef GL_ATIX_texture_env_route - CONST_CAST(GLEW_ATIX_texture_env_route) = _glewSearchExtension("GL_ATIX_texture_env_route", extStart, extEnd); -#endif /* GL_ATIX_texture_env_route */ -#ifdef GL_ATIX_vertex_shader_output_point_size - CONST_CAST(GLEW_ATIX_vertex_shader_output_point_size) = _glewSearchExtension("GL_ATIX_vertex_shader_output_point_size", extStart, extEnd); -#endif /* GL_ATIX_vertex_shader_output_point_size */ -#ifdef GL_ATI_draw_buffers - CONST_CAST(GLEW_ATI_draw_buffers) = _glewSearchExtension("GL_ATI_draw_buffers", extStart, extEnd); - if (glewExperimental || GLEW_ATI_draw_buffers) CONST_CAST(GLEW_ATI_draw_buffers) = !_glewInit_GL_ATI_draw_buffers(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_draw_buffers */ -#ifdef GL_ATI_element_array - CONST_CAST(GLEW_ATI_element_array) = _glewSearchExtension("GL_ATI_element_array", extStart, extEnd); - if (glewExperimental || GLEW_ATI_element_array) CONST_CAST(GLEW_ATI_element_array) = !_glewInit_GL_ATI_element_array(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_element_array */ -#ifdef GL_ATI_envmap_bumpmap - CONST_CAST(GLEW_ATI_envmap_bumpmap) = _glewSearchExtension("GL_ATI_envmap_bumpmap", extStart, extEnd); - if (glewExperimental || GLEW_ATI_envmap_bumpmap) CONST_CAST(GLEW_ATI_envmap_bumpmap) = !_glewInit_GL_ATI_envmap_bumpmap(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_envmap_bumpmap */ -#ifdef GL_ATI_fragment_shader - CONST_CAST(GLEW_ATI_fragment_shader) = _glewSearchExtension("GL_ATI_fragment_shader", extStart, extEnd); - if (glewExperimental || GLEW_ATI_fragment_shader) CONST_CAST(GLEW_ATI_fragment_shader) = !_glewInit_GL_ATI_fragment_shader(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_fragment_shader */ -#ifdef GL_ATI_map_object_buffer - CONST_CAST(GLEW_ATI_map_object_buffer) = _glewSearchExtension("GL_ATI_map_object_buffer", extStart, extEnd); - if (glewExperimental || GLEW_ATI_map_object_buffer) CONST_CAST(GLEW_ATI_map_object_buffer) = !_glewInit_GL_ATI_map_object_buffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_map_object_buffer */ -#ifdef GL_ATI_meminfo - CONST_CAST(GLEW_ATI_meminfo) = _glewSearchExtension("GL_ATI_meminfo", extStart, extEnd); -#endif /* GL_ATI_meminfo */ -#ifdef GL_ATI_pn_triangles - CONST_CAST(GLEW_ATI_pn_triangles) = _glewSearchExtension("GL_ATI_pn_triangles", extStart, extEnd); - if (glewExperimental || GLEW_ATI_pn_triangles) CONST_CAST(GLEW_ATI_pn_triangles) = !_glewInit_GL_ATI_pn_triangles(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_pn_triangles */ -#ifdef GL_ATI_separate_stencil - CONST_CAST(GLEW_ATI_separate_stencil) = _glewSearchExtension("GL_ATI_separate_stencil", extStart, extEnd); - if (glewExperimental || GLEW_ATI_separate_stencil) CONST_CAST(GLEW_ATI_separate_stencil) = !_glewInit_GL_ATI_separate_stencil(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_separate_stencil */ -#ifdef GL_ATI_shader_texture_lod - CONST_CAST(GLEW_ATI_shader_texture_lod) = _glewSearchExtension("GL_ATI_shader_texture_lod", extStart, extEnd); -#endif /* GL_ATI_shader_texture_lod */ -#ifdef GL_ATI_text_fragment_shader - CONST_CAST(GLEW_ATI_text_fragment_shader) = _glewSearchExtension("GL_ATI_text_fragment_shader", extStart, extEnd); -#endif /* GL_ATI_text_fragment_shader */ -#ifdef GL_ATI_texture_compression_3dc - CONST_CAST(GLEW_ATI_texture_compression_3dc) = _glewSearchExtension("GL_ATI_texture_compression_3dc", extStart, extEnd); -#endif /* GL_ATI_texture_compression_3dc */ -#ifdef GL_ATI_texture_env_combine3 - CONST_CAST(GLEW_ATI_texture_env_combine3) = _glewSearchExtension("GL_ATI_texture_env_combine3", extStart, extEnd); -#endif /* GL_ATI_texture_env_combine3 */ -#ifdef GL_ATI_texture_float - CONST_CAST(GLEW_ATI_texture_float) = _glewSearchExtension("GL_ATI_texture_float", extStart, extEnd); -#endif /* GL_ATI_texture_float */ -#ifdef GL_ATI_texture_mirror_once - CONST_CAST(GLEW_ATI_texture_mirror_once) = _glewSearchExtension("GL_ATI_texture_mirror_once", extStart, extEnd); -#endif /* GL_ATI_texture_mirror_once */ -#ifdef GL_ATI_vertex_array_object - CONST_CAST(GLEW_ATI_vertex_array_object) = _glewSearchExtension("GL_ATI_vertex_array_object", extStart, extEnd); - if (glewExperimental || GLEW_ATI_vertex_array_object) CONST_CAST(GLEW_ATI_vertex_array_object) = !_glewInit_GL_ATI_vertex_array_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_vertex_array_object */ -#ifdef GL_ATI_vertex_attrib_array_object - CONST_CAST(GLEW_ATI_vertex_attrib_array_object) = _glewSearchExtension("GL_ATI_vertex_attrib_array_object", extStart, extEnd); - if (glewExperimental || GLEW_ATI_vertex_attrib_array_object) CONST_CAST(GLEW_ATI_vertex_attrib_array_object) = !_glewInit_GL_ATI_vertex_attrib_array_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_vertex_attrib_array_object */ -#ifdef GL_ATI_vertex_streams - CONST_CAST(GLEW_ATI_vertex_streams) = _glewSearchExtension("GL_ATI_vertex_streams", extStart, extEnd); - if (glewExperimental || GLEW_ATI_vertex_streams) CONST_CAST(GLEW_ATI_vertex_streams) = !_glewInit_GL_ATI_vertex_streams(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_ATI_vertex_streams */ -#ifdef GL_EXT_422_pixels - CONST_CAST(GLEW_EXT_422_pixels) = _glewSearchExtension("GL_EXT_422_pixels", extStart, extEnd); -#endif /* GL_EXT_422_pixels */ -#ifdef GL_EXT_Cg_shader - CONST_CAST(GLEW_EXT_Cg_shader) = _glewSearchExtension("GL_EXT_Cg_shader", extStart, extEnd); -#endif /* GL_EXT_Cg_shader */ -#ifdef GL_EXT_abgr - CONST_CAST(GLEW_EXT_abgr) = _glewSearchExtension("GL_EXT_abgr", extStart, extEnd); -#endif /* GL_EXT_abgr */ -#ifdef GL_EXT_bgra - CONST_CAST(GLEW_EXT_bgra) = _glewSearchExtension("GL_EXT_bgra", extStart, extEnd); -#endif /* GL_EXT_bgra */ -#ifdef GL_EXT_bindable_uniform - CONST_CAST(GLEW_EXT_bindable_uniform) = _glewSearchExtension("GL_EXT_bindable_uniform", extStart, extEnd); - if (glewExperimental || GLEW_EXT_bindable_uniform) CONST_CAST(GLEW_EXT_bindable_uniform) = !_glewInit_GL_EXT_bindable_uniform(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_bindable_uniform */ -#ifdef GL_EXT_blend_color - CONST_CAST(GLEW_EXT_blend_color) = _glewSearchExtension("GL_EXT_blend_color", extStart, extEnd); - if (glewExperimental || GLEW_EXT_blend_color) CONST_CAST(GLEW_EXT_blend_color) = !_glewInit_GL_EXT_blend_color(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_blend_color */ -#ifdef GL_EXT_blend_equation_separate - CONST_CAST(GLEW_EXT_blend_equation_separate) = _glewSearchExtension("GL_EXT_blend_equation_separate", extStart, extEnd); - if (glewExperimental || GLEW_EXT_blend_equation_separate) CONST_CAST(GLEW_EXT_blend_equation_separate) = !_glewInit_GL_EXT_blend_equation_separate(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_blend_equation_separate */ -#ifdef GL_EXT_blend_func_separate - CONST_CAST(GLEW_EXT_blend_func_separate) = _glewSearchExtension("GL_EXT_blend_func_separate", extStart, extEnd); - if (glewExperimental || GLEW_EXT_blend_func_separate) CONST_CAST(GLEW_EXT_blend_func_separate) = !_glewInit_GL_EXT_blend_func_separate(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_blend_func_separate */ -#ifdef GL_EXT_blend_logic_op - CONST_CAST(GLEW_EXT_blend_logic_op) = _glewSearchExtension("GL_EXT_blend_logic_op", extStart, extEnd); -#endif /* GL_EXT_blend_logic_op */ -#ifdef GL_EXT_blend_minmax - CONST_CAST(GLEW_EXT_blend_minmax) = _glewSearchExtension("GL_EXT_blend_minmax", extStart, extEnd); - if (glewExperimental || GLEW_EXT_blend_minmax) CONST_CAST(GLEW_EXT_blend_minmax) = !_glewInit_GL_EXT_blend_minmax(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_blend_minmax */ -#ifdef GL_EXT_blend_subtract - CONST_CAST(GLEW_EXT_blend_subtract) = _glewSearchExtension("GL_EXT_blend_subtract", extStart, extEnd); -#endif /* GL_EXT_blend_subtract */ -#ifdef GL_EXT_clip_volume_hint - CONST_CAST(GLEW_EXT_clip_volume_hint) = _glewSearchExtension("GL_EXT_clip_volume_hint", extStart, extEnd); -#endif /* GL_EXT_clip_volume_hint */ -#ifdef GL_EXT_cmyka - CONST_CAST(GLEW_EXT_cmyka) = _glewSearchExtension("GL_EXT_cmyka", extStart, extEnd); -#endif /* GL_EXT_cmyka */ -#ifdef GL_EXT_color_subtable - CONST_CAST(GLEW_EXT_color_subtable) = _glewSearchExtension("GL_EXT_color_subtable", extStart, extEnd); - if (glewExperimental || GLEW_EXT_color_subtable) CONST_CAST(GLEW_EXT_color_subtable) = !_glewInit_GL_EXT_color_subtable(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_color_subtable */ -#ifdef GL_EXT_compiled_vertex_array - CONST_CAST(GLEW_EXT_compiled_vertex_array) = _glewSearchExtension("GL_EXT_compiled_vertex_array", extStart, extEnd); - if (glewExperimental || GLEW_EXT_compiled_vertex_array) CONST_CAST(GLEW_EXT_compiled_vertex_array) = !_glewInit_GL_EXT_compiled_vertex_array(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_compiled_vertex_array */ -#ifdef GL_EXT_convolution - CONST_CAST(GLEW_EXT_convolution) = _glewSearchExtension("GL_EXT_convolution", extStart, extEnd); - if (glewExperimental || GLEW_EXT_convolution) CONST_CAST(GLEW_EXT_convolution) = !_glewInit_GL_EXT_convolution(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_convolution */ -#ifdef GL_EXT_coordinate_frame - CONST_CAST(GLEW_EXT_coordinate_frame) = _glewSearchExtension("GL_EXT_coordinate_frame", extStart, extEnd); - if (glewExperimental || GLEW_EXT_coordinate_frame) CONST_CAST(GLEW_EXT_coordinate_frame) = !_glewInit_GL_EXT_coordinate_frame(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_coordinate_frame */ -#ifdef GL_EXT_copy_texture - CONST_CAST(GLEW_EXT_copy_texture) = _glewSearchExtension("GL_EXT_copy_texture", extStart, extEnd); - if (glewExperimental || GLEW_EXT_copy_texture) CONST_CAST(GLEW_EXT_copy_texture) = !_glewInit_GL_EXT_copy_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_copy_texture */ -#ifdef GL_EXT_cull_vertex - CONST_CAST(GLEW_EXT_cull_vertex) = _glewSearchExtension("GL_EXT_cull_vertex", extStart, extEnd); - if (glewExperimental || GLEW_EXT_cull_vertex) CONST_CAST(GLEW_EXT_cull_vertex) = !_glewInit_GL_EXT_cull_vertex(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_cull_vertex */ -#ifdef GL_EXT_debug_marker - CONST_CAST(GLEW_EXT_debug_marker) = _glewSearchExtension("GL_EXT_debug_marker", extStart, extEnd); - if (glewExperimental || GLEW_EXT_debug_marker) CONST_CAST(GLEW_EXT_debug_marker) = !_glewInit_GL_EXT_debug_marker(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_debug_marker */ -#ifdef GL_EXT_depth_bounds_test - CONST_CAST(GLEW_EXT_depth_bounds_test) = _glewSearchExtension("GL_EXT_depth_bounds_test", extStart, extEnd); - if (glewExperimental || GLEW_EXT_depth_bounds_test) CONST_CAST(GLEW_EXT_depth_bounds_test) = !_glewInit_GL_EXT_depth_bounds_test(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_depth_bounds_test */ -#ifdef GL_EXT_direct_state_access - CONST_CAST(GLEW_EXT_direct_state_access) = _glewSearchExtension("GL_EXT_direct_state_access", extStart, extEnd); - if (glewExperimental || GLEW_EXT_direct_state_access) CONST_CAST(GLEW_EXT_direct_state_access) = !_glewInit_GL_EXT_direct_state_access(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_direct_state_access */ -#ifdef GL_EXT_draw_buffers2 - CONST_CAST(GLEW_EXT_draw_buffers2) = _glewSearchExtension("GL_EXT_draw_buffers2", extStart, extEnd); - if (glewExperimental || GLEW_EXT_draw_buffers2) CONST_CAST(GLEW_EXT_draw_buffers2) = !_glewInit_GL_EXT_draw_buffers2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_draw_buffers2 */ -#ifdef GL_EXT_draw_instanced - CONST_CAST(GLEW_EXT_draw_instanced) = _glewSearchExtension("GL_EXT_draw_instanced", extStart, extEnd); - if (glewExperimental || GLEW_EXT_draw_instanced) CONST_CAST(GLEW_EXT_draw_instanced) = !_glewInit_GL_EXT_draw_instanced(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_draw_instanced */ -#ifdef GL_EXT_draw_range_elements - CONST_CAST(GLEW_EXT_draw_range_elements) = _glewSearchExtension("GL_EXT_draw_range_elements", extStart, extEnd); - if (glewExperimental || GLEW_EXT_draw_range_elements) CONST_CAST(GLEW_EXT_draw_range_elements) = !_glewInit_GL_EXT_draw_range_elements(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_draw_range_elements */ -#ifdef GL_EXT_fog_coord - CONST_CAST(GLEW_EXT_fog_coord) = _glewSearchExtension("GL_EXT_fog_coord", extStart, extEnd); - if (glewExperimental || GLEW_EXT_fog_coord) CONST_CAST(GLEW_EXT_fog_coord) = !_glewInit_GL_EXT_fog_coord(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_fog_coord */ -#ifdef GL_EXT_fragment_lighting - CONST_CAST(GLEW_EXT_fragment_lighting) = _glewSearchExtension("GL_EXT_fragment_lighting", extStart, extEnd); - if (glewExperimental || GLEW_EXT_fragment_lighting) CONST_CAST(GLEW_EXT_fragment_lighting) = !_glewInit_GL_EXT_fragment_lighting(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_fragment_lighting */ -#ifdef GL_EXT_framebuffer_blit - CONST_CAST(GLEW_EXT_framebuffer_blit) = _glewSearchExtension("GL_EXT_framebuffer_blit", extStart, extEnd); - if (glewExperimental || GLEW_EXT_framebuffer_blit) CONST_CAST(GLEW_EXT_framebuffer_blit) = !_glewInit_GL_EXT_framebuffer_blit(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_framebuffer_blit */ -#ifdef GL_EXT_framebuffer_multisample - CONST_CAST(GLEW_EXT_framebuffer_multisample) = _glewSearchExtension("GL_EXT_framebuffer_multisample", extStart, extEnd); - if (glewExperimental || GLEW_EXT_framebuffer_multisample) CONST_CAST(GLEW_EXT_framebuffer_multisample) = !_glewInit_GL_EXT_framebuffer_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_framebuffer_multisample */ -#ifdef GL_EXT_framebuffer_multisample_blit_scaled - CONST_CAST(GLEW_EXT_framebuffer_multisample_blit_scaled) = _glewSearchExtension("GL_EXT_framebuffer_multisample_blit_scaled", extStart, extEnd); -#endif /* GL_EXT_framebuffer_multisample_blit_scaled */ -#ifdef GL_EXT_framebuffer_object - CONST_CAST(GLEW_EXT_framebuffer_object) = _glewSearchExtension("GL_EXT_framebuffer_object", extStart, extEnd); - if (glewExperimental || GLEW_EXT_framebuffer_object) CONST_CAST(GLEW_EXT_framebuffer_object) = !_glewInit_GL_EXT_framebuffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_framebuffer_object */ -#ifdef GL_EXT_framebuffer_sRGB - CONST_CAST(GLEW_EXT_framebuffer_sRGB) = _glewSearchExtension("GL_EXT_framebuffer_sRGB", extStart, extEnd); -#endif /* GL_EXT_framebuffer_sRGB */ -#ifdef GL_EXT_geometry_shader4 - CONST_CAST(GLEW_EXT_geometry_shader4) = _glewSearchExtension("GL_EXT_geometry_shader4", extStart, extEnd); - if (glewExperimental || GLEW_EXT_geometry_shader4) CONST_CAST(GLEW_EXT_geometry_shader4) = !_glewInit_GL_EXT_geometry_shader4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_geometry_shader4 */ -#ifdef GL_EXT_gpu_program_parameters - CONST_CAST(GLEW_EXT_gpu_program_parameters) = _glewSearchExtension("GL_EXT_gpu_program_parameters", extStart, extEnd); - if (glewExperimental || GLEW_EXT_gpu_program_parameters) CONST_CAST(GLEW_EXT_gpu_program_parameters) = !_glewInit_GL_EXT_gpu_program_parameters(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_gpu_program_parameters */ -#ifdef GL_EXT_gpu_shader4 - CONST_CAST(GLEW_EXT_gpu_shader4) = _glewSearchExtension("GL_EXT_gpu_shader4", extStart, extEnd); - if (glewExperimental || GLEW_EXT_gpu_shader4) CONST_CAST(GLEW_EXT_gpu_shader4) = !_glewInit_GL_EXT_gpu_shader4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_gpu_shader4 */ -#ifdef GL_EXT_histogram - CONST_CAST(GLEW_EXT_histogram) = _glewSearchExtension("GL_EXT_histogram", extStart, extEnd); - if (glewExperimental || GLEW_EXT_histogram) CONST_CAST(GLEW_EXT_histogram) = !_glewInit_GL_EXT_histogram(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_histogram */ -#ifdef GL_EXT_index_array_formats - CONST_CAST(GLEW_EXT_index_array_formats) = _glewSearchExtension("GL_EXT_index_array_formats", extStart, extEnd); -#endif /* GL_EXT_index_array_formats */ -#ifdef GL_EXT_index_func - CONST_CAST(GLEW_EXT_index_func) = _glewSearchExtension("GL_EXT_index_func", extStart, extEnd); - if (glewExperimental || GLEW_EXT_index_func) CONST_CAST(GLEW_EXT_index_func) = !_glewInit_GL_EXT_index_func(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_index_func */ -#ifdef GL_EXT_index_material - CONST_CAST(GLEW_EXT_index_material) = _glewSearchExtension("GL_EXT_index_material", extStart, extEnd); - if (glewExperimental || GLEW_EXT_index_material) CONST_CAST(GLEW_EXT_index_material) = !_glewInit_GL_EXT_index_material(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_index_material */ -#ifdef GL_EXT_index_texture - CONST_CAST(GLEW_EXT_index_texture) = _glewSearchExtension("GL_EXT_index_texture", extStart, extEnd); -#endif /* GL_EXT_index_texture */ -#ifdef GL_EXT_light_texture - CONST_CAST(GLEW_EXT_light_texture) = _glewSearchExtension("GL_EXT_light_texture", extStart, extEnd); - if (glewExperimental || GLEW_EXT_light_texture) CONST_CAST(GLEW_EXT_light_texture) = !_glewInit_GL_EXT_light_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_light_texture */ -#ifdef GL_EXT_misc_attribute - CONST_CAST(GLEW_EXT_misc_attribute) = _glewSearchExtension("GL_EXT_misc_attribute", extStart, extEnd); -#endif /* GL_EXT_misc_attribute */ -#ifdef GL_EXT_multi_draw_arrays - CONST_CAST(GLEW_EXT_multi_draw_arrays) = _glewSearchExtension("GL_EXT_multi_draw_arrays", extStart, extEnd); - if (glewExperimental || GLEW_EXT_multi_draw_arrays) CONST_CAST(GLEW_EXT_multi_draw_arrays) = !_glewInit_GL_EXT_multi_draw_arrays(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_multi_draw_arrays */ -#ifdef GL_EXT_multisample - CONST_CAST(GLEW_EXT_multisample) = _glewSearchExtension("GL_EXT_multisample", extStart, extEnd); - if (glewExperimental || GLEW_EXT_multisample) CONST_CAST(GLEW_EXT_multisample) = !_glewInit_GL_EXT_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_multisample */ -#ifdef GL_EXT_packed_depth_stencil - CONST_CAST(GLEW_EXT_packed_depth_stencil) = _glewSearchExtension("GL_EXT_packed_depth_stencil", extStart, extEnd); -#endif /* GL_EXT_packed_depth_stencil */ -#ifdef GL_EXT_packed_float - CONST_CAST(GLEW_EXT_packed_float) = _glewSearchExtension("GL_EXT_packed_float", extStart, extEnd); -#endif /* GL_EXT_packed_float */ -#ifdef GL_EXT_packed_pixels - CONST_CAST(GLEW_EXT_packed_pixels) = _glewSearchExtension("GL_EXT_packed_pixels", extStart, extEnd); -#endif /* GL_EXT_packed_pixels */ -#ifdef GL_EXT_paletted_texture - CONST_CAST(GLEW_EXT_paletted_texture) = _glewSearchExtension("GL_EXT_paletted_texture", extStart, extEnd); - if (glewExperimental || GLEW_EXT_paletted_texture) CONST_CAST(GLEW_EXT_paletted_texture) = !_glewInit_GL_EXT_paletted_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_paletted_texture */ -#ifdef GL_EXT_pixel_buffer_object - CONST_CAST(GLEW_EXT_pixel_buffer_object) = _glewSearchExtension("GL_EXT_pixel_buffer_object", extStart, extEnd); -#endif /* GL_EXT_pixel_buffer_object */ -#ifdef GL_EXT_pixel_transform - CONST_CAST(GLEW_EXT_pixel_transform) = _glewSearchExtension("GL_EXT_pixel_transform", extStart, extEnd); - if (glewExperimental || GLEW_EXT_pixel_transform) CONST_CAST(GLEW_EXT_pixel_transform) = !_glewInit_GL_EXT_pixel_transform(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_pixel_transform */ -#ifdef GL_EXT_pixel_transform_color_table - CONST_CAST(GLEW_EXT_pixel_transform_color_table) = _glewSearchExtension("GL_EXT_pixel_transform_color_table", extStart, extEnd); -#endif /* GL_EXT_pixel_transform_color_table */ -#ifdef GL_EXT_point_parameters - CONST_CAST(GLEW_EXT_point_parameters) = _glewSearchExtension("GL_EXT_point_parameters", extStart, extEnd); - if (glewExperimental || GLEW_EXT_point_parameters) CONST_CAST(GLEW_EXT_point_parameters) = !_glewInit_GL_EXT_point_parameters(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_point_parameters */ -#ifdef GL_EXT_polygon_offset - CONST_CAST(GLEW_EXT_polygon_offset) = _glewSearchExtension("GL_EXT_polygon_offset", extStart, extEnd); - if (glewExperimental || GLEW_EXT_polygon_offset) CONST_CAST(GLEW_EXT_polygon_offset) = !_glewInit_GL_EXT_polygon_offset(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_polygon_offset */ -#ifdef GL_EXT_provoking_vertex - CONST_CAST(GLEW_EXT_provoking_vertex) = _glewSearchExtension("GL_EXT_provoking_vertex", extStart, extEnd); - if (glewExperimental || GLEW_EXT_provoking_vertex) CONST_CAST(GLEW_EXT_provoking_vertex) = !_glewInit_GL_EXT_provoking_vertex(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_provoking_vertex */ -#ifdef GL_EXT_rescale_normal - CONST_CAST(GLEW_EXT_rescale_normal) = _glewSearchExtension("GL_EXT_rescale_normal", extStart, extEnd); -#endif /* GL_EXT_rescale_normal */ -#ifdef GL_EXT_scene_marker - CONST_CAST(GLEW_EXT_scene_marker) = _glewSearchExtension("GL_EXT_scene_marker", extStart, extEnd); - if (glewExperimental || GLEW_EXT_scene_marker) CONST_CAST(GLEW_EXT_scene_marker) = !_glewInit_GL_EXT_scene_marker(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_scene_marker */ -#ifdef GL_EXT_secondary_color - CONST_CAST(GLEW_EXT_secondary_color) = _glewSearchExtension("GL_EXT_secondary_color", extStart, extEnd); - if (glewExperimental || GLEW_EXT_secondary_color) CONST_CAST(GLEW_EXT_secondary_color) = !_glewInit_GL_EXT_secondary_color(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_secondary_color */ -#ifdef GL_EXT_separate_shader_objects - CONST_CAST(GLEW_EXT_separate_shader_objects) = _glewSearchExtension("GL_EXT_separate_shader_objects", extStart, extEnd); - if (glewExperimental || GLEW_EXT_separate_shader_objects) CONST_CAST(GLEW_EXT_separate_shader_objects) = !_glewInit_GL_EXT_separate_shader_objects(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_separate_shader_objects */ -#ifdef GL_EXT_separate_specular_color - CONST_CAST(GLEW_EXT_separate_specular_color) = _glewSearchExtension("GL_EXT_separate_specular_color", extStart, extEnd); -#endif /* GL_EXT_separate_specular_color */ -#ifdef GL_EXT_shader_image_load_store - CONST_CAST(GLEW_EXT_shader_image_load_store) = _glewSearchExtension("GL_EXT_shader_image_load_store", extStart, extEnd); - if (glewExperimental || GLEW_EXT_shader_image_load_store) CONST_CAST(GLEW_EXT_shader_image_load_store) = !_glewInit_GL_EXT_shader_image_load_store(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_shader_image_load_store */ -#ifdef GL_EXT_shadow_funcs - CONST_CAST(GLEW_EXT_shadow_funcs) = _glewSearchExtension("GL_EXT_shadow_funcs", extStart, extEnd); -#endif /* GL_EXT_shadow_funcs */ -#ifdef GL_EXT_shared_texture_palette - CONST_CAST(GLEW_EXT_shared_texture_palette) = _glewSearchExtension("GL_EXT_shared_texture_palette", extStart, extEnd); -#endif /* GL_EXT_shared_texture_palette */ -#ifdef GL_EXT_stencil_clear_tag - CONST_CAST(GLEW_EXT_stencil_clear_tag) = _glewSearchExtension("GL_EXT_stencil_clear_tag", extStart, extEnd); -#endif /* GL_EXT_stencil_clear_tag */ -#ifdef GL_EXT_stencil_two_side - CONST_CAST(GLEW_EXT_stencil_two_side) = _glewSearchExtension("GL_EXT_stencil_two_side", extStart, extEnd); - if (glewExperimental || GLEW_EXT_stencil_two_side) CONST_CAST(GLEW_EXT_stencil_two_side) = !_glewInit_GL_EXT_stencil_two_side(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_stencil_two_side */ -#ifdef GL_EXT_stencil_wrap - CONST_CAST(GLEW_EXT_stencil_wrap) = _glewSearchExtension("GL_EXT_stencil_wrap", extStart, extEnd); -#endif /* GL_EXT_stencil_wrap */ -#ifdef GL_EXT_subtexture - CONST_CAST(GLEW_EXT_subtexture) = _glewSearchExtension("GL_EXT_subtexture", extStart, extEnd); - if (glewExperimental || GLEW_EXT_subtexture) CONST_CAST(GLEW_EXT_subtexture) = !_glewInit_GL_EXT_subtexture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_subtexture */ -#ifdef GL_EXT_texture - CONST_CAST(GLEW_EXT_texture) = _glewSearchExtension("GL_EXT_texture", extStart, extEnd); -#endif /* GL_EXT_texture */ -#ifdef GL_EXT_texture3D - CONST_CAST(GLEW_EXT_texture3D) = _glewSearchExtension("GL_EXT_texture3D", extStart, extEnd); - if (glewExperimental || GLEW_EXT_texture3D) CONST_CAST(GLEW_EXT_texture3D) = !_glewInit_GL_EXT_texture3D(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_texture3D */ -#ifdef GL_EXT_texture_array - CONST_CAST(GLEW_EXT_texture_array) = _glewSearchExtension("GL_EXT_texture_array", extStart, extEnd); - if (glewExperimental || GLEW_EXT_texture_array) CONST_CAST(GLEW_EXT_texture_array) = !_glewInit_GL_EXT_texture_array(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_texture_array */ -#ifdef GL_EXT_texture_buffer_object - CONST_CAST(GLEW_EXT_texture_buffer_object) = _glewSearchExtension("GL_EXT_texture_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_EXT_texture_buffer_object) CONST_CAST(GLEW_EXT_texture_buffer_object) = !_glewInit_GL_EXT_texture_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_texture_buffer_object */ -#ifdef GL_EXT_texture_compression_dxt1 - CONST_CAST(GLEW_EXT_texture_compression_dxt1) = _glewSearchExtension("GL_EXT_texture_compression_dxt1", extStart, extEnd); -#endif /* GL_EXT_texture_compression_dxt1 */ -#ifdef GL_EXT_texture_compression_latc - CONST_CAST(GLEW_EXT_texture_compression_latc) = _glewSearchExtension("GL_EXT_texture_compression_latc", extStart, extEnd); -#endif /* GL_EXT_texture_compression_latc */ -#ifdef GL_EXT_texture_compression_rgtc - CONST_CAST(GLEW_EXT_texture_compression_rgtc) = _glewSearchExtension("GL_EXT_texture_compression_rgtc", extStart, extEnd); -#endif /* GL_EXT_texture_compression_rgtc */ -#ifdef GL_EXT_texture_compression_s3tc - CONST_CAST(GLEW_EXT_texture_compression_s3tc) = _glewSearchExtension("GL_EXT_texture_compression_s3tc", extStart, extEnd); -#endif /* GL_EXT_texture_compression_s3tc */ -#ifdef GL_EXT_texture_cube_map - CONST_CAST(GLEW_EXT_texture_cube_map) = _glewSearchExtension("GL_EXT_texture_cube_map", extStart, extEnd); -#endif /* GL_EXT_texture_cube_map */ -#ifdef GL_EXT_texture_edge_clamp - CONST_CAST(GLEW_EXT_texture_edge_clamp) = _glewSearchExtension("GL_EXT_texture_edge_clamp", extStart, extEnd); -#endif /* GL_EXT_texture_edge_clamp */ -#ifdef GL_EXT_texture_env - CONST_CAST(GLEW_EXT_texture_env) = _glewSearchExtension("GL_EXT_texture_env", extStart, extEnd); -#endif /* GL_EXT_texture_env */ -#ifdef GL_EXT_texture_env_add - CONST_CAST(GLEW_EXT_texture_env_add) = _glewSearchExtension("GL_EXT_texture_env_add", extStart, extEnd); -#endif /* GL_EXT_texture_env_add */ -#ifdef GL_EXT_texture_env_combine - CONST_CAST(GLEW_EXT_texture_env_combine) = _glewSearchExtension("GL_EXT_texture_env_combine", extStart, extEnd); -#endif /* GL_EXT_texture_env_combine */ -#ifdef GL_EXT_texture_env_dot3 - CONST_CAST(GLEW_EXT_texture_env_dot3) = _glewSearchExtension("GL_EXT_texture_env_dot3", extStart, extEnd); -#endif /* GL_EXT_texture_env_dot3 */ -#ifdef GL_EXT_texture_filter_anisotropic - CONST_CAST(GLEW_EXT_texture_filter_anisotropic) = _glewSearchExtension("GL_EXT_texture_filter_anisotropic", extStart, extEnd); -#endif /* GL_EXT_texture_filter_anisotropic */ -#ifdef GL_EXT_texture_integer - CONST_CAST(GLEW_EXT_texture_integer) = _glewSearchExtension("GL_EXT_texture_integer", extStart, extEnd); - if (glewExperimental || GLEW_EXT_texture_integer) CONST_CAST(GLEW_EXT_texture_integer) = !_glewInit_GL_EXT_texture_integer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_texture_integer */ -#ifdef GL_EXT_texture_lod_bias - CONST_CAST(GLEW_EXT_texture_lod_bias) = _glewSearchExtension("GL_EXT_texture_lod_bias", extStart, extEnd); -#endif /* GL_EXT_texture_lod_bias */ -#ifdef GL_EXT_texture_mirror_clamp - CONST_CAST(GLEW_EXT_texture_mirror_clamp) = _glewSearchExtension("GL_EXT_texture_mirror_clamp", extStart, extEnd); -#endif /* GL_EXT_texture_mirror_clamp */ -#ifdef GL_EXT_texture_object - CONST_CAST(GLEW_EXT_texture_object) = _glewSearchExtension("GL_EXT_texture_object", extStart, extEnd); - if (glewExperimental || GLEW_EXT_texture_object) CONST_CAST(GLEW_EXT_texture_object) = !_glewInit_GL_EXT_texture_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_texture_object */ -#ifdef GL_EXT_texture_perturb_normal - CONST_CAST(GLEW_EXT_texture_perturb_normal) = _glewSearchExtension("GL_EXT_texture_perturb_normal", extStart, extEnd); - if (glewExperimental || GLEW_EXT_texture_perturb_normal) CONST_CAST(GLEW_EXT_texture_perturb_normal) = !_glewInit_GL_EXT_texture_perturb_normal(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_texture_perturb_normal */ -#ifdef GL_EXT_texture_rectangle - CONST_CAST(GLEW_EXT_texture_rectangle) = _glewSearchExtension("GL_EXT_texture_rectangle", extStart, extEnd); -#endif /* GL_EXT_texture_rectangle */ -#ifdef GL_EXT_texture_sRGB - CONST_CAST(GLEW_EXT_texture_sRGB) = _glewSearchExtension("GL_EXT_texture_sRGB", extStart, extEnd); -#endif /* GL_EXT_texture_sRGB */ -#ifdef GL_EXT_texture_sRGB_decode - CONST_CAST(GLEW_EXT_texture_sRGB_decode) = _glewSearchExtension("GL_EXT_texture_sRGB_decode", extStart, extEnd); -#endif /* GL_EXT_texture_sRGB_decode */ -#ifdef GL_EXT_texture_shared_exponent - CONST_CAST(GLEW_EXT_texture_shared_exponent) = _glewSearchExtension("GL_EXT_texture_shared_exponent", extStart, extEnd); -#endif /* GL_EXT_texture_shared_exponent */ -#ifdef GL_EXT_texture_snorm - CONST_CAST(GLEW_EXT_texture_snorm) = _glewSearchExtension("GL_EXT_texture_snorm", extStart, extEnd); -#endif /* GL_EXT_texture_snorm */ -#ifdef GL_EXT_texture_swizzle - CONST_CAST(GLEW_EXT_texture_swizzle) = _glewSearchExtension("GL_EXT_texture_swizzle", extStart, extEnd); -#endif /* GL_EXT_texture_swizzle */ -#ifdef GL_EXT_timer_query - CONST_CAST(GLEW_EXT_timer_query) = _glewSearchExtension("GL_EXT_timer_query", extStart, extEnd); - if (glewExperimental || GLEW_EXT_timer_query) CONST_CAST(GLEW_EXT_timer_query) = !_glewInit_GL_EXT_timer_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_timer_query */ -#ifdef GL_EXT_transform_feedback - CONST_CAST(GLEW_EXT_transform_feedback) = _glewSearchExtension("GL_EXT_transform_feedback", extStart, extEnd); - if (glewExperimental || GLEW_EXT_transform_feedback) CONST_CAST(GLEW_EXT_transform_feedback) = !_glewInit_GL_EXT_transform_feedback(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_transform_feedback */ -#ifdef GL_EXT_vertex_array - CONST_CAST(GLEW_EXT_vertex_array) = _glewSearchExtension("GL_EXT_vertex_array", extStart, extEnd); - if (glewExperimental || GLEW_EXT_vertex_array) CONST_CAST(GLEW_EXT_vertex_array) = !_glewInit_GL_EXT_vertex_array(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_vertex_array */ -#ifdef GL_EXT_vertex_array_bgra - CONST_CAST(GLEW_EXT_vertex_array_bgra) = _glewSearchExtension("GL_EXT_vertex_array_bgra", extStart, extEnd); -#endif /* GL_EXT_vertex_array_bgra */ -#ifdef GL_EXT_vertex_attrib_64bit - CONST_CAST(GLEW_EXT_vertex_attrib_64bit) = _glewSearchExtension("GL_EXT_vertex_attrib_64bit", extStart, extEnd); - if (glewExperimental || GLEW_EXT_vertex_attrib_64bit) CONST_CAST(GLEW_EXT_vertex_attrib_64bit) = !_glewInit_GL_EXT_vertex_attrib_64bit(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_vertex_attrib_64bit */ -#ifdef GL_EXT_vertex_shader - CONST_CAST(GLEW_EXT_vertex_shader) = _glewSearchExtension("GL_EXT_vertex_shader", extStart, extEnd); - if (glewExperimental || GLEW_EXT_vertex_shader) CONST_CAST(GLEW_EXT_vertex_shader) = !_glewInit_GL_EXT_vertex_shader(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_vertex_shader */ -#ifdef GL_EXT_vertex_weighting - CONST_CAST(GLEW_EXT_vertex_weighting) = _glewSearchExtension("GL_EXT_vertex_weighting", extStart, extEnd); - if (glewExperimental || GLEW_EXT_vertex_weighting) CONST_CAST(GLEW_EXT_vertex_weighting) = !_glewInit_GL_EXT_vertex_weighting(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_vertex_weighting */ -#ifdef GL_EXT_x11_sync_object - CONST_CAST(GLEW_EXT_x11_sync_object) = _glewSearchExtension("GL_EXT_x11_sync_object", extStart, extEnd); - if (glewExperimental || GLEW_EXT_x11_sync_object) CONST_CAST(GLEW_EXT_x11_sync_object) = !_glewInit_GL_EXT_x11_sync_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_EXT_x11_sync_object */ -#ifdef GL_GREMEDY_frame_terminator - CONST_CAST(GLEW_GREMEDY_frame_terminator) = _glewSearchExtension("GL_GREMEDY_frame_terminator", extStart, extEnd); - if (glewExperimental || GLEW_GREMEDY_frame_terminator) CONST_CAST(GLEW_GREMEDY_frame_terminator) = !_glewInit_GL_GREMEDY_frame_terminator(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_GREMEDY_frame_terminator */ -#ifdef GL_GREMEDY_string_marker - CONST_CAST(GLEW_GREMEDY_string_marker) = _glewSearchExtension("GL_GREMEDY_string_marker", extStart, extEnd); - if (glewExperimental || GLEW_GREMEDY_string_marker) CONST_CAST(GLEW_GREMEDY_string_marker) = !_glewInit_GL_GREMEDY_string_marker(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_GREMEDY_string_marker */ -#ifdef GL_HP_convolution_border_modes - CONST_CAST(GLEW_HP_convolution_border_modes) = _glewSearchExtension("GL_HP_convolution_border_modes", extStart, extEnd); -#endif /* GL_HP_convolution_border_modes */ -#ifdef GL_HP_image_transform - CONST_CAST(GLEW_HP_image_transform) = _glewSearchExtension("GL_HP_image_transform", extStart, extEnd); - if (glewExperimental || GLEW_HP_image_transform) CONST_CAST(GLEW_HP_image_transform) = !_glewInit_GL_HP_image_transform(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_HP_image_transform */ -#ifdef GL_HP_occlusion_test - CONST_CAST(GLEW_HP_occlusion_test) = _glewSearchExtension("GL_HP_occlusion_test", extStart, extEnd); -#endif /* GL_HP_occlusion_test */ -#ifdef GL_HP_texture_lighting - CONST_CAST(GLEW_HP_texture_lighting) = _glewSearchExtension("GL_HP_texture_lighting", extStart, extEnd); -#endif /* GL_HP_texture_lighting */ -#ifdef GL_IBM_cull_vertex - CONST_CAST(GLEW_IBM_cull_vertex) = _glewSearchExtension("GL_IBM_cull_vertex", extStart, extEnd); -#endif /* GL_IBM_cull_vertex */ -#ifdef GL_IBM_multimode_draw_arrays - CONST_CAST(GLEW_IBM_multimode_draw_arrays) = _glewSearchExtension("GL_IBM_multimode_draw_arrays", extStart, extEnd); - if (glewExperimental || GLEW_IBM_multimode_draw_arrays) CONST_CAST(GLEW_IBM_multimode_draw_arrays) = !_glewInit_GL_IBM_multimode_draw_arrays(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_IBM_multimode_draw_arrays */ -#ifdef GL_IBM_rasterpos_clip - CONST_CAST(GLEW_IBM_rasterpos_clip) = _glewSearchExtension("GL_IBM_rasterpos_clip", extStart, extEnd); -#endif /* GL_IBM_rasterpos_clip */ -#ifdef GL_IBM_static_data - CONST_CAST(GLEW_IBM_static_data) = _glewSearchExtension("GL_IBM_static_data", extStart, extEnd); -#endif /* GL_IBM_static_data */ -#ifdef GL_IBM_texture_mirrored_repeat - CONST_CAST(GLEW_IBM_texture_mirrored_repeat) = _glewSearchExtension("GL_IBM_texture_mirrored_repeat", extStart, extEnd); -#endif /* GL_IBM_texture_mirrored_repeat */ -#ifdef GL_IBM_vertex_array_lists - CONST_CAST(GLEW_IBM_vertex_array_lists) = _glewSearchExtension("GL_IBM_vertex_array_lists", extStart, extEnd); - if (glewExperimental || GLEW_IBM_vertex_array_lists) CONST_CAST(GLEW_IBM_vertex_array_lists) = !_glewInit_GL_IBM_vertex_array_lists(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_IBM_vertex_array_lists */ -#ifdef GL_INGR_color_clamp - CONST_CAST(GLEW_INGR_color_clamp) = _glewSearchExtension("GL_INGR_color_clamp", extStart, extEnd); -#endif /* GL_INGR_color_clamp */ -#ifdef GL_INGR_interlace_read - CONST_CAST(GLEW_INGR_interlace_read) = _glewSearchExtension("GL_INGR_interlace_read", extStart, extEnd); -#endif /* GL_INGR_interlace_read */ -#ifdef GL_INTEL_map_texture - CONST_CAST(GLEW_INTEL_map_texture) = _glewSearchExtension("GL_INTEL_map_texture", extStart, extEnd); - if (glewExperimental || GLEW_INTEL_map_texture) CONST_CAST(GLEW_INTEL_map_texture) = !_glewInit_GL_INTEL_map_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_INTEL_map_texture */ -#ifdef GL_INTEL_parallel_arrays - CONST_CAST(GLEW_INTEL_parallel_arrays) = _glewSearchExtension("GL_INTEL_parallel_arrays", extStart, extEnd); - if (glewExperimental || GLEW_INTEL_parallel_arrays) CONST_CAST(GLEW_INTEL_parallel_arrays) = !_glewInit_GL_INTEL_parallel_arrays(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_INTEL_parallel_arrays */ -#ifdef GL_INTEL_texture_scissor - CONST_CAST(GLEW_INTEL_texture_scissor) = _glewSearchExtension("GL_INTEL_texture_scissor", extStart, extEnd); - if (glewExperimental || GLEW_INTEL_texture_scissor) CONST_CAST(GLEW_INTEL_texture_scissor) = !_glewInit_GL_INTEL_texture_scissor(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_INTEL_texture_scissor */ -#ifdef GL_KHR_debug - CONST_CAST(GLEW_KHR_debug) = _glewSearchExtension("GL_KHR_debug", extStart, extEnd); - if (glewExperimental || GLEW_KHR_debug) CONST_CAST(GLEW_KHR_debug) = !_glewInit_GL_KHR_debug(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_KHR_debug */ -#ifdef GL_KHR_texture_compression_astc_ldr - CONST_CAST(GLEW_KHR_texture_compression_astc_ldr) = _glewSearchExtension("GL_KHR_texture_compression_astc_ldr", extStart, extEnd); -#endif /* GL_KHR_texture_compression_astc_ldr */ -#ifdef GL_KTX_buffer_region - CONST_CAST(GLEW_KTX_buffer_region) = _glewSearchExtension("GL_KTX_buffer_region", extStart, extEnd); - if (glewExperimental || GLEW_KTX_buffer_region) CONST_CAST(GLEW_KTX_buffer_region) = !_glewInit_GL_KTX_buffer_region(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_KTX_buffer_region */ -#ifdef GL_MESAX_texture_stack - CONST_CAST(GLEW_MESAX_texture_stack) = _glewSearchExtension("GL_MESAX_texture_stack", extStart, extEnd); -#endif /* GL_MESAX_texture_stack */ -#ifdef GL_MESA_pack_invert - CONST_CAST(GLEW_MESA_pack_invert) = _glewSearchExtension("GL_MESA_pack_invert", extStart, extEnd); -#endif /* GL_MESA_pack_invert */ -#ifdef GL_MESA_resize_buffers - CONST_CAST(GLEW_MESA_resize_buffers) = _glewSearchExtension("GL_MESA_resize_buffers", extStart, extEnd); - if (glewExperimental || GLEW_MESA_resize_buffers) CONST_CAST(GLEW_MESA_resize_buffers) = !_glewInit_GL_MESA_resize_buffers(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_MESA_resize_buffers */ -#ifdef GL_MESA_window_pos - CONST_CAST(GLEW_MESA_window_pos) = _glewSearchExtension("GL_MESA_window_pos", extStart, extEnd); - if (glewExperimental || GLEW_MESA_window_pos) CONST_CAST(GLEW_MESA_window_pos) = !_glewInit_GL_MESA_window_pos(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_MESA_window_pos */ -#ifdef GL_MESA_ycbcr_texture - CONST_CAST(GLEW_MESA_ycbcr_texture) = _glewSearchExtension("GL_MESA_ycbcr_texture", extStart, extEnd); -#endif /* GL_MESA_ycbcr_texture */ -#ifdef GL_NVX_conditional_render - CONST_CAST(GLEW_NVX_conditional_render) = _glewSearchExtension("GL_NVX_conditional_render", extStart, extEnd); - if (glewExperimental || GLEW_NVX_conditional_render) CONST_CAST(GLEW_NVX_conditional_render) = !_glewInit_GL_NVX_conditional_render(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NVX_conditional_render */ -#ifdef GL_NVX_gpu_memory_info - CONST_CAST(GLEW_NVX_gpu_memory_info) = _glewSearchExtension("GL_NVX_gpu_memory_info", extStart, extEnd); -#endif /* GL_NVX_gpu_memory_info */ -#ifdef GL_NV_bindless_multi_draw_indirect - CONST_CAST(GLEW_NV_bindless_multi_draw_indirect) = _glewSearchExtension("GL_NV_bindless_multi_draw_indirect", extStart, extEnd); - if (glewExperimental || GLEW_NV_bindless_multi_draw_indirect) CONST_CAST(GLEW_NV_bindless_multi_draw_indirect) = !_glewInit_GL_NV_bindless_multi_draw_indirect(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_bindless_multi_draw_indirect */ -#ifdef GL_NV_bindless_texture - CONST_CAST(GLEW_NV_bindless_texture) = _glewSearchExtension("GL_NV_bindless_texture", extStart, extEnd); - if (glewExperimental || GLEW_NV_bindless_texture) CONST_CAST(GLEW_NV_bindless_texture) = !_glewInit_GL_NV_bindless_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_bindless_texture */ -#ifdef GL_NV_blend_equation_advanced - CONST_CAST(GLEW_NV_blend_equation_advanced) = _glewSearchExtension("GL_NV_blend_equation_advanced", extStart, extEnd); - if (glewExperimental || GLEW_NV_blend_equation_advanced) CONST_CAST(GLEW_NV_blend_equation_advanced) = !_glewInit_GL_NV_blend_equation_advanced(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_blend_equation_advanced */ -#ifdef GL_NV_blend_equation_advanced_coherent - CONST_CAST(GLEW_NV_blend_equation_advanced_coherent) = _glewSearchExtension("GL_NV_blend_equation_advanced_coherent", extStart, extEnd); -#endif /* GL_NV_blend_equation_advanced_coherent */ -#ifdef GL_NV_blend_square - CONST_CAST(GLEW_NV_blend_square) = _glewSearchExtension("GL_NV_blend_square", extStart, extEnd); -#endif /* GL_NV_blend_square */ -#ifdef GL_NV_compute_program5 - CONST_CAST(GLEW_NV_compute_program5) = _glewSearchExtension("GL_NV_compute_program5", extStart, extEnd); -#endif /* GL_NV_compute_program5 */ -#ifdef GL_NV_conditional_render - CONST_CAST(GLEW_NV_conditional_render) = _glewSearchExtension("GL_NV_conditional_render", extStart, extEnd); - if (glewExperimental || GLEW_NV_conditional_render) CONST_CAST(GLEW_NV_conditional_render) = !_glewInit_GL_NV_conditional_render(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_conditional_render */ -#ifdef GL_NV_copy_depth_to_color - CONST_CAST(GLEW_NV_copy_depth_to_color) = _glewSearchExtension("GL_NV_copy_depth_to_color", extStart, extEnd); -#endif /* GL_NV_copy_depth_to_color */ -#ifdef GL_NV_copy_image - CONST_CAST(GLEW_NV_copy_image) = _glewSearchExtension("GL_NV_copy_image", extStart, extEnd); - if (glewExperimental || GLEW_NV_copy_image) CONST_CAST(GLEW_NV_copy_image) = !_glewInit_GL_NV_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_copy_image */ -#ifdef GL_NV_deep_texture3D - CONST_CAST(GLEW_NV_deep_texture3D) = _glewSearchExtension("GL_NV_deep_texture3D", extStart, extEnd); -#endif /* GL_NV_deep_texture3D */ -#ifdef GL_NV_depth_buffer_float - CONST_CAST(GLEW_NV_depth_buffer_float) = _glewSearchExtension("GL_NV_depth_buffer_float", extStart, extEnd); - if (glewExperimental || GLEW_NV_depth_buffer_float) CONST_CAST(GLEW_NV_depth_buffer_float) = !_glewInit_GL_NV_depth_buffer_float(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_depth_buffer_float */ -#ifdef GL_NV_depth_clamp - CONST_CAST(GLEW_NV_depth_clamp) = _glewSearchExtension("GL_NV_depth_clamp", extStart, extEnd); -#endif /* GL_NV_depth_clamp */ -#ifdef GL_NV_depth_range_unclamped - CONST_CAST(GLEW_NV_depth_range_unclamped) = _glewSearchExtension("GL_NV_depth_range_unclamped", extStart, extEnd); -#endif /* GL_NV_depth_range_unclamped */ -#ifdef GL_NV_draw_texture - CONST_CAST(GLEW_NV_draw_texture) = _glewSearchExtension("GL_NV_draw_texture", extStart, extEnd); - if (glewExperimental || GLEW_NV_draw_texture) CONST_CAST(GLEW_NV_draw_texture) = !_glewInit_GL_NV_draw_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_draw_texture */ -#ifdef GL_NV_evaluators - CONST_CAST(GLEW_NV_evaluators) = _glewSearchExtension("GL_NV_evaluators", extStart, extEnd); - if (glewExperimental || GLEW_NV_evaluators) CONST_CAST(GLEW_NV_evaluators) = !_glewInit_GL_NV_evaluators(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_evaluators */ -#ifdef GL_NV_explicit_multisample - CONST_CAST(GLEW_NV_explicit_multisample) = _glewSearchExtension("GL_NV_explicit_multisample", extStart, extEnd); - if (glewExperimental || GLEW_NV_explicit_multisample) CONST_CAST(GLEW_NV_explicit_multisample) = !_glewInit_GL_NV_explicit_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_explicit_multisample */ -#ifdef GL_NV_fence - CONST_CAST(GLEW_NV_fence) = _glewSearchExtension("GL_NV_fence", extStart, extEnd); - if (glewExperimental || GLEW_NV_fence) CONST_CAST(GLEW_NV_fence) = !_glewInit_GL_NV_fence(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_fence */ -#ifdef GL_NV_float_buffer - CONST_CAST(GLEW_NV_float_buffer) = _glewSearchExtension("GL_NV_float_buffer", extStart, extEnd); -#endif /* GL_NV_float_buffer */ -#ifdef GL_NV_fog_distance - CONST_CAST(GLEW_NV_fog_distance) = _glewSearchExtension("GL_NV_fog_distance", extStart, extEnd); -#endif /* GL_NV_fog_distance */ -#ifdef GL_NV_fragment_program - CONST_CAST(GLEW_NV_fragment_program) = _glewSearchExtension("GL_NV_fragment_program", extStart, extEnd); - if (glewExperimental || GLEW_NV_fragment_program) CONST_CAST(GLEW_NV_fragment_program) = !_glewInit_GL_NV_fragment_program(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_fragment_program */ -#ifdef GL_NV_fragment_program2 - CONST_CAST(GLEW_NV_fragment_program2) = _glewSearchExtension("GL_NV_fragment_program2", extStart, extEnd); -#endif /* GL_NV_fragment_program2 */ -#ifdef GL_NV_fragment_program4 - CONST_CAST(GLEW_NV_fragment_program4) = _glewSearchExtension("GL_NV_gpu_program4", extStart, extEnd); -#endif /* GL_NV_fragment_program4 */ -#ifdef GL_NV_fragment_program_option - CONST_CAST(GLEW_NV_fragment_program_option) = _glewSearchExtension("GL_NV_fragment_program_option", extStart, extEnd); -#endif /* GL_NV_fragment_program_option */ -#ifdef GL_NV_framebuffer_multisample_coverage - CONST_CAST(GLEW_NV_framebuffer_multisample_coverage) = _glewSearchExtension("GL_NV_framebuffer_multisample_coverage", extStart, extEnd); - if (glewExperimental || GLEW_NV_framebuffer_multisample_coverage) CONST_CAST(GLEW_NV_framebuffer_multisample_coverage) = !_glewInit_GL_NV_framebuffer_multisample_coverage(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_framebuffer_multisample_coverage */ -#ifdef GL_NV_geometry_program4 - CONST_CAST(GLEW_NV_geometry_program4) = _glewSearchExtension("GL_NV_gpu_program4", extStart, extEnd); - if (glewExperimental || GLEW_NV_geometry_program4) CONST_CAST(GLEW_NV_geometry_program4) = !_glewInit_GL_NV_geometry_program4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_geometry_program4 */ -#ifdef GL_NV_geometry_shader4 - CONST_CAST(GLEW_NV_geometry_shader4) = _glewSearchExtension("GL_NV_geometry_shader4", extStart, extEnd); -#endif /* GL_NV_geometry_shader4 */ -#ifdef GL_NV_gpu_program4 - CONST_CAST(GLEW_NV_gpu_program4) = _glewSearchExtension("GL_NV_gpu_program4", extStart, extEnd); - if (glewExperimental || GLEW_NV_gpu_program4) CONST_CAST(GLEW_NV_gpu_program4) = !_glewInit_GL_NV_gpu_program4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_gpu_program4 */ -#ifdef GL_NV_gpu_program5 - CONST_CAST(GLEW_NV_gpu_program5) = _glewSearchExtension("GL_NV_gpu_program5", extStart, extEnd); -#endif /* GL_NV_gpu_program5 */ -#ifdef GL_NV_gpu_program5_mem_extended - CONST_CAST(GLEW_NV_gpu_program5_mem_extended) = _glewSearchExtension("GL_NV_gpu_program5_mem_extended", extStart, extEnd); -#endif /* GL_NV_gpu_program5_mem_extended */ -#ifdef GL_NV_gpu_program_fp64 - CONST_CAST(GLEW_NV_gpu_program_fp64) = _glewSearchExtension("GL_NV_gpu_program_fp64", extStart, extEnd); -#endif /* GL_NV_gpu_program_fp64 */ -#ifdef GL_NV_gpu_shader5 - CONST_CAST(GLEW_NV_gpu_shader5) = _glewSearchExtension("GL_NV_gpu_shader5", extStart, extEnd); - if (glewExperimental || GLEW_NV_gpu_shader5) CONST_CAST(GLEW_NV_gpu_shader5) = !_glewInit_GL_NV_gpu_shader5(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_gpu_shader5 */ -#ifdef GL_NV_half_float - CONST_CAST(GLEW_NV_half_float) = _glewSearchExtension("GL_NV_half_float", extStart, extEnd); - if (glewExperimental || GLEW_NV_half_float) CONST_CAST(GLEW_NV_half_float) = !_glewInit_GL_NV_half_float(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_half_float */ -#ifdef GL_NV_light_max_exponent - CONST_CAST(GLEW_NV_light_max_exponent) = _glewSearchExtension("GL_NV_light_max_exponent", extStart, extEnd); -#endif /* GL_NV_light_max_exponent */ -#ifdef GL_NV_multisample_coverage - CONST_CAST(GLEW_NV_multisample_coverage) = _glewSearchExtension("GL_NV_multisample_coverage", extStart, extEnd); -#endif /* GL_NV_multisample_coverage */ -#ifdef GL_NV_multisample_filter_hint - CONST_CAST(GLEW_NV_multisample_filter_hint) = _glewSearchExtension("GL_NV_multisample_filter_hint", extStart, extEnd); -#endif /* GL_NV_multisample_filter_hint */ -#ifdef GL_NV_occlusion_query - CONST_CAST(GLEW_NV_occlusion_query) = _glewSearchExtension("GL_NV_occlusion_query", extStart, extEnd); - if (glewExperimental || GLEW_NV_occlusion_query) CONST_CAST(GLEW_NV_occlusion_query) = !_glewInit_GL_NV_occlusion_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_occlusion_query */ -#ifdef GL_NV_packed_depth_stencil - CONST_CAST(GLEW_NV_packed_depth_stencil) = _glewSearchExtension("GL_NV_packed_depth_stencil", extStart, extEnd); -#endif /* GL_NV_packed_depth_stencil */ -#ifdef GL_NV_parameter_buffer_object - CONST_CAST(GLEW_NV_parameter_buffer_object) = _glewSearchExtension("GL_NV_parameter_buffer_object", extStart, extEnd); - if (glewExperimental || GLEW_NV_parameter_buffer_object) CONST_CAST(GLEW_NV_parameter_buffer_object) = !_glewInit_GL_NV_parameter_buffer_object(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_parameter_buffer_object */ -#ifdef GL_NV_parameter_buffer_object2 - CONST_CAST(GLEW_NV_parameter_buffer_object2) = _glewSearchExtension("GL_NV_parameter_buffer_object2", extStart, extEnd); -#endif /* GL_NV_parameter_buffer_object2 */ -#ifdef GL_NV_path_rendering - CONST_CAST(GLEW_NV_path_rendering) = _glewSearchExtension("GL_NV_path_rendering", extStart, extEnd); - if (glewExperimental || GLEW_NV_path_rendering) CONST_CAST(GLEW_NV_path_rendering) = !_glewInit_GL_NV_path_rendering(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_path_rendering */ -#ifdef GL_NV_pixel_data_range - CONST_CAST(GLEW_NV_pixel_data_range) = _glewSearchExtension("GL_NV_pixel_data_range", extStart, extEnd); - if (glewExperimental || GLEW_NV_pixel_data_range) CONST_CAST(GLEW_NV_pixel_data_range) = !_glewInit_GL_NV_pixel_data_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_pixel_data_range */ -#ifdef GL_NV_point_sprite - CONST_CAST(GLEW_NV_point_sprite) = _glewSearchExtension("GL_NV_point_sprite", extStart, extEnd); - if (glewExperimental || GLEW_NV_point_sprite) CONST_CAST(GLEW_NV_point_sprite) = !_glewInit_GL_NV_point_sprite(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_point_sprite */ -#ifdef GL_NV_present_video - CONST_CAST(GLEW_NV_present_video) = _glewSearchExtension("GL_NV_present_video", extStart, extEnd); - if (glewExperimental || GLEW_NV_present_video) CONST_CAST(GLEW_NV_present_video) = !_glewInit_GL_NV_present_video(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_present_video */ -#ifdef GL_NV_primitive_restart - CONST_CAST(GLEW_NV_primitive_restart) = _glewSearchExtension("GL_NV_primitive_restart", extStart, extEnd); - if (glewExperimental || GLEW_NV_primitive_restart) CONST_CAST(GLEW_NV_primitive_restart) = !_glewInit_GL_NV_primitive_restart(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_primitive_restart */ -#ifdef GL_NV_register_combiners - CONST_CAST(GLEW_NV_register_combiners) = _glewSearchExtension("GL_NV_register_combiners", extStart, extEnd); - if (glewExperimental || GLEW_NV_register_combiners) CONST_CAST(GLEW_NV_register_combiners) = !_glewInit_GL_NV_register_combiners(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_register_combiners */ -#ifdef GL_NV_register_combiners2 - CONST_CAST(GLEW_NV_register_combiners2) = _glewSearchExtension("GL_NV_register_combiners2", extStart, extEnd); - if (glewExperimental || GLEW_NV_register_combiners2) CONST_CAST(GLEW_NV_register_combiners2) = !_glewInit_GL_NV_register_combiners2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_register_combiners2 */ -#ifdef GL_NV_shader_atomic_counters - CONST_CAST(GLEW_NV_shader_atomic_counters) = _glewSearchExtension("GL_NV_shader_atomic_counters", extStart, extEnd); -#endif /* GL_NV_shader_atomic_counters */ -#ifdef GL_NV_shader_atomic_float - CONST_CAST(GLEW_NV_shader_atomic_float) = _glewSearchExtension("GL_NV_shader_atomic_float", extStart, extEnd); -#endif /* GL_NV_shader_atomic_float */ -#ifdef GL_NV_shader_buffer_load - CONST_CAST(GLEW_NV_shader_buffer_load) = _glewSearchExtension("GL_NV_shader_buffer_load", extStart, extEnd); - if (glewExperimental || GLEW_NV_shader_buffer_load) CONST_CAST(GLEW_NV_shader_buffer_load) = !_glewInit_GL_NV_shader_buffer_load(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_shader_buffer_load */ -#ifdef GL_NV_shader_storage_buffer_object - CONST_CAST(GLEW_NV_shader_storage_buffer_object) = _glewSearchExtension("GL_NV_shader_storage_buffer_object", extStart, extEnd); -#endif /* GL_NV_shader_storage_buffer_object */ -#ifdef GL_NV_tessellation_program5 - CONST_CAST(GLEW_NV_tessellation_program5) = _glewSearchExtension("GL_NV_gpu_program5", extStart, extEnd); -#endif /* GL_NV_tessellation_program5 */ -#ifdef GL_NV_texgen_emboss - CONST_CAST(GLEW_NV_texgen_emboss) = _glewSearchExtension("GL_NV_texgen_emboss", extStart, extEnd); -#endif /* GL_NV_texgen_emboss */ -#ifdef GL_NV_texgen_reflection - CONST_CAST(GLEW_NV_texgen_reflection) = _glewSearchExtension("GL_NV_texgen_reflection", extStart, extEnd); -#endif /* GL_NV_texgen_reflection */ -#ifdef GL_NV_texture_barrier - CONST_CAST(GLEW_NV_texture_barrier) = _glewSearchExtension("GL_NV_texture_barrier", extStart, extEnd); - if (glewExperimental || GLEW_NV_texture_barrier) CONST_CAST(GLEW_NV_texture_barrier) = !_glewInit_GL_NV_texture_barrier(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_texture_barrier */ -#ifdef GL_NV_texture_compression_vtc - CONST_CAST(GLEW_NV_texture_compression_vtc) = _glewSearchExtension("GL_NV_texture_compression_vtc", extStart, extEnd); -#endif /* GL_NV_texture_compression_vtc */ -#ifdef GL_NV_texture_env_combine4 - CONST_CAST(GLEW_NV_texture_env_combine4) = _glewSearchExtension("GL_NV_texture_env_combine4", extStart, extEnd); -#endif /* GL_NV_texture_env_combine4 */ -#ifdef GL_NV_texture_expand_normal - CONST_CAST(GLEW_NV_texture_expand_normal) = _glewSearchExtension("GL_NV_texture_expand_normal", extStart, extEnd); -#endif /* GL_NV_texture_expand_normal */ -#ifdef GL_NV_texture_multisample - CONST_CAST(GLEW_NV_texture_multisample) = _glewSearchExtension("GL_NV_texture_multisample", extStart, extEnd); - if (glewExperimental || GLEW_NV_texture_multisample) CONST_CAST(GLEW_NV_texture_multisample) = !_glewInit_GL_NV_texture_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_texture_multisample */ -#ifdef GL_NV_texture_rectangle - CONST_CAST(GLEW_NV_texture_rectangle) = _glewSearchExtension("GL_NV_texture_rectangle", extStart, extEnd); -#endif /* GL_NV_texture_rectangle */ -#ifdef GL_NV_texture_shader - CONST_CAST(GLEW_NV_texture_shader) = _glewSearchExtension("GL_NV_texture_shader", extStart, extEnd); -#endif /* GL_NV_texture_shader */ -#ifdef GL_NV_texture_shader2 - CONST_CAST(GLEW_NV_texture_shader2) = _glewSearchExtension("GL_NV_texture_shader2", extStart, extEnd); -#endif /* GL_NV_texture_shader2 */ -#ifdef GL_NV_texture_shader3 - CONST_CAST(GLEW_NV_texture_shader3) = _glewSearchExtension("GL_NV_texture_shader3", extStart, extEnd); -#endif /* GL_NV_texture_shader3 */ -#ifdef GL_NV_transform_feedback - CONST_CAST(GLEW_NV_transform_feedback) = _glewSearchExtension("GL_NV_transform_feedback", extStart, extEnd); - if (glewExperimental || GLEW_NV_transform_feedback) CONST_CAST(GLEW_NV_transform_feedback) = !_glewInit_GL_NV_transform_feedback(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_transform_feedback */ -#ifdef GL_NV_transform_feedback2 - CONST_CAST(GLEW_NV_transform_feedback2) = _glewSearchExtension("GL_NV_transform_feedback2", extStart, extEnd); - if (glewExperimental || GLEW_NV_transform_feedback2) CONST_CAST(GLEW_NV_transform_feedback2) = !_glewInit_GL_NV_transform_feedback2(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_transform_feedback2 */ -#ifdef GL_NV_vdpau_interop - CONST_CAST(GLEW_NV_vdpau_interop) = _glewSearchExtension("GL_NV_vdpau_interop", extStart, extEnd); - if (glewExperimental || GLEW_NV_vdpau_interop) CONST_CAST(GLEW_NV_vdpau_interop) = !_glewInit_GL_NV_vdpau_interop(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_vdpau_interop */ -#ifdef GL_NV_vertex_array_range - CONST_CAST(GLEW_NV_vertex_array_range) = _glewSearchExtension("GL_NV_vertex_array_range", extStart, extEnd); - if (glewExperimental || GLEW_NV_vertex_array_range) CONST_CAST(GLEW_NV_vertex_array_range) = !_glewInit_GL_NV_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_vertex_array_range */ -#ifdef GL_NV_vertex_array_range2 - CONST_CAST(GLEW_NV_vertex_array_range2) = _glewSearchExtension("GL_NV_vertex_array_range2", extStart, extEnd); -#endif /* GL_NV_vertex_array_range2 */ -#ifdef GL_NV_vertex_attrib_integer_64bit - CONST_CAST(GLEW_NV_vertex_attrib_integer_64bit) = _glewSearchExtension("GL_NV_vertex_attrib_integer_64bit", extStart, extEnd); - if (glewExperimental || GLEW_NV_vertex_attrib_integer_64bit) CONST_CAST(GLEW_NV_vertex_attrib_integer_64bit) = !_glewInit_GL_NV_vertex_attrib_integer_64bit(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_vertex_attrib_integer_64bit */ -#ifdef GL_NV_vertex_buffer_unified_memory - CONST_CAST(GLEW_NV_vertex_buffer_unified_memory) = _glewSearchExtension("GL_NV_vertex_buffer_unified_memory", extStart, extEnd); - if (glewExperimental || GLEW_NV_vertex_buffer_unified_memory) CONST_CAST(GLEW_NV_vertex_buffer_unified_memory) = !_glewInit_GL_NV_vertex_buffer_unified_memory(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_vertex_buffer_unified_memory */ -#ifdef GL_NV_vertex_program - CONST_CAST(GLEW_NV_vertex_program) = _glewSearchExtension("GL_NV_vertex_program", extStart, extEnd); - if (glewExperimental || GLEW_NV_vertex_program) CONST_CAST(GLEW_NV_vertex_program) = !_glewInit_GL_NV_vertex_program(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_vertex_program */ -#ifdef GL_NV_vertex_program1_1 - CONST_CAST(GLEW_NV_vertex_program1_1) = _glewSearchExtension("GL_NV_vertex_program1_1", extStart, extEnd); -#endif /* GL_NV_vertex_program1_1 */ -#ifdef GL_NV_vertex_program2 - CONST_CAST(GLEW_NV_vertex_program2) = _glewSearchExtension("GL_NV_vertex_program2", extStart, extEnd); -#endif /* GL_NV_vertex_program2 */ -#ifdef GL_NV_vertex_program2_option - CONST_CAST(GLEW_NV_vertex_program2_option) = _glewSearchExtension("GL_NV_vertex_program2_option", extStart, extEnd); -#endif /* GL_NV_vertex_program2_option */ -#ifdef GL_NV_vertex_program3 - CONST_CAST(GLEW_NV_vertex_program3) = _glewSearchExtension("GL_NV_vertex_program3", extStart, extEnd); -#endif /* GL_NV_vertex_program3 */ -#ifdef GL_NV_vertex_program4 - CONST_CAST(GLEW_NV_vertex_program4) = _glewSearchExtension("GL_NV_gpu_program4", extStart, extEnd); -#endif /* GL_NV_vertex_program4 */ -#ifdef GL_NV_video_capture - CONST_CAST(GLEW_NV_video_capture) = _glewSearchExtension("GL_NV_video_capture", extStart, extEnd); - if (glewExperimental || GLEW_NV_video_capture) CONST_CAST(GLEW_NV_video_capture) = !_glewInit_GL_NV_video_capture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_NV_video_capture */ -#ifdef GL_OES_byte_coordinates - CONST_CAST(GLEW_OES_byte_coordinates) = _glewSearchExtension("GL_OES_byte_coordinates", extStart, extEnd); -#endif /* GL_OES_byte_coordinates */ -#ifdef GL_OES_compressed_paletted_texture - CONST_CAST(GLEW_OES_compressed_paletted_texture) = _glewSearchExtension("GL_OES_compressed_paletted_texture", extStart, extEnd); -#endif /* GL_OES_compressed_paletted_texture */ -#ifdef GL_OES_read_format - CONST_CAST(GLEW_OES_read_format) = _glewSearchExtension("GL_OES_read_format", extStart, extEnd); -#endif /* GL_OES_read_format */ -#ifdef GL_OES_single_precision - CONST_CAST(GLEW_OES_single_precision) = _glewSearchExtension("GL_OES_single_precision", extStart, extEnd); - if (glewExperimental || GLEW_OES_single_precision) CONST_CAST(GLEW_OES_single_precision) = !_glewInit_GL_OES_single_precision(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_OES_single_precision */ -#ifdef GL_OML_interlace - CONST_CAST(GLEW_OML_interlace) = _glewSearchExtension("GL_OML_interlace", extStart, extEnd); -#endif /* GL_OML_interlace */ -#ifdef GL_OML_resample - CONST_CAST(GLEW_OML_resample) = _glewSearchExtension("GL_OML_resample", extStart, extEnd); -#endif /* GL_OML_resample */ -#ifdef GL_OML_subsample - CONST_CAST(GLEW_OML_subsample) = _glewSearchExtension("GL_OML_subsample", extStart, extEnd); -#endif /* GL_OML_subsample */ -#ifdef GL_PGI_misc_hints - CONST_CAST(GLEW_PGI_misc_hints) = _glewSearchExtension("GL_PGI_misc_hints", extStart, extEnd); -#endif /* GL_PGI_misc_hints */ -#ifdef GL_PGI_vertex_hints - CONST_CAST(GLEW_PGI_vertex_hints) = _glewSearchExtension("GL_PGI_vertex_hints", extStart, extEnd); -#endif /* GL_PGI_vertex_hints */ -#ifdef GL_REGAL_ES1_0_compatibility - CONST_CAST(GLEW_REGAL_ES1_0_compatibility) = _glewSearchExtension("GL_REGAL_ES1_0_compatibility", extStart, extEnd); - if (glewExperimental || GLEW_REGAL_ES1_0_compatibility) CONST_CAST(GLEW_REGAL_ES1_0_compatibility) = !_glewInit_GL_REGAL_ES1_0_compatibility(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_REGAL_ES1_0_compatibility */ -#ifdef GL_REGAL_ES1_1_compatibility - CONST_CAST(GLEW_REGAL_ES1_1_compatibility) = _glewSearchExtension("GL_REGAL_ES1_1_compatibility", extStart, extEnd); - if (glewExperimental || GLEW_REGAL_ES1_1_compatibility) CONST_CAST(GLEW_REGAL_ES1_1_compatibility) = !_glewInit_GL_REGAL_ES1_1_compatibility(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_REGAL_ES1_1_compatibility */ -#ifdef GL_REGAL_enable - CONST_CAST(GLEW_REGAL_enable) = _glewSearchExtension("GL_REGAL_enable", extStart, extEnd); -#endif /* GL_REGAL_enable */ -#ifdef GL_REGAL_error_string - CONST_CAST(GLEW_REGAL_error_string) = _glewSearchExtension("GL_REGAL_error_string", extStart, extEnd); - if (glewExperimental || GLEW_REGAL_error_string) CONST_CAST(GLEW_REGAL_error_string) = !_glewInit_GL_REGAL_error_string(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_REGAL_error_string */ -#ifdef GL_REGAL_extension_query - CONST_CAST(GLEW_REGAL_extension_query) = _glewSearchExtension("GL_REGAL_extension_query", extStart, extEnd); - if (glewExperimental || GLEW_REGAL_extension_query) CONST_CAST(GLEW_REGAL_extension_query) = !_glewInit_GL_REGAL_extension_query(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_REGAL_extension_query */ -#ifdef GL_REGAL_log - CONST_CAST(GLEW_REGAL_log) = _glewSearchExtension("GL_REGAL_log", extStart, extEnd); - if (glewExperimental || GLEW_REGAL_log) CONST_CAST(GLEW_REGAL_log) = !_glewInit_GL_REGAL_log(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_REGAL_log */ -#ifdef GL_REND_screen_coordinates - CONST_CAST(GLEW_REND_screen_coordinates) = _glewSearchExtension("GL_REND_screen_coordinates", extStart, extEnd); -#endif /* GL_REND_screen_coordinates */ -#ifdef GL_S3_s3tc - CONST_CAST(GLEW_S3_s3tc) = _glewSearchExtension("GL_S3_s3tc", extStart, extEnd); -#endif /* GL_S3_s3tc */ -#ifdef GL_SGIS_color_range - CONST_CAST(GLEW_SGIS_color_range) = _glewSearchExtension("GL_SGIS_color_range", extStart, extEnd); -#endif /* GL_SGIS_color_range */ -#ifdef GL_SGIS_detail_texture - CONST_CAST(GLEW_SGIS_detail_texture) = _glewSearchExtension("GL_SGIS_detail_texture", extStart, extEnd); - if (glewExperimental || GLEW_SGIS_detail_texture) CONST_CAST(GLEW_SGIS_detail_texture) = !_glewInit_GL_SGIS_detail_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIS_detail_texture */ -#ifdef GL_SGIS_fog_function - CONST_CAST(GLEW_SGIS_fog_function) = _glewSearchExtension("GL_SGIS_fog_function", extStart, extEnd); - if (glewExperimental || GLEW_SGIS_fog_function) CONST_CAST(GLEW_SGIS_fog_function) = !_glewInit_GL_SGIS_fog_function(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIS_fog_function */ -#ifdef GL_SGIS_generate_mipmap - CONST_CAST(GLEW_SGIS_generate_mipmap) = _glewSearchExtension("GL_SGIS_generate_mipmap", extStart, extEnd); -#endif /* GL_SGIS_generate_mipmap */ -#ifdef GL_SGIS_multisample - CONST_CAST(GLEW_SGIS_multisample) = _glewSearchExtension("GL_SGIS_multisample", extStart, extEnd); - if (glewExperimental || GLEW_SGIS_multisample) CONST_CAST(GLEW_SGIS_multisample) = !_glewInit_GL_SGIS_multisample(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIS_multisample */ -#ifdef GL_SGIS_pixel_texture - CONST_CAST(GLEW_SGIS_pixel_texture) = _glewSearchExtension("GL_SGIS_pixel_texture", extStart, extEnd); -#endif /* GL_SGIS_pixel_texture */ -#ifdef GL_SGIS_point_line_texgen - CONST_CAST(GLEW_SGIS_point_line_texgen) = _glewSearchExtension("GL_SGIS_point_line_texgen", extStart, extEnd); -#endif /* GL_SGIS_point_line_texgen */ -#ifdef GL_SGIS_sharpen_texture - CONST_CAST(GLEW_SGIS_sharpen_texture) = _glewSearchExtension("GL_SGIS_sharpen_texture", extStart, extEnd); - if (glewExperimental || GLEW_SGIS_sharpen_texture) CONST_CAST(GLEW_SGIS_sharpen_texture) = !_glewInit_GL_SGIS_sharpen_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIS_sharpen_texture */ -#ifdef GL_SGIS_texture4D - CONST_CAST(GLEW_SGIS_texture4D) = _glewSearchExtension("GL_SGIS_texture4D", extStart, extEnd); - if (glewExperimental || GLEW_SGIS_texture4D) CONST_CAST(GLEW_SGIS_texture4D) = !_glewInit_GL_SGIS_texture4D(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIS_texture4D */ -#ifdef GL_SGIS_texture_border_clamp - CONST_CAST(GLEW_SGIS_texture_border_clamp) = _glewSearchExtension("GL_SGIS_texture_border_clamp", extStart, extEnd); -#endif /* GL_SGIS_texture_border_clamp */ -#ifdef GL_SGIS_texture_edge_clamp - CONST_CAST(GLEW_SGIS_texture_edge_clamp) = _glewSearchExtension("GL_SGIS_texture_edge_clamp", extStart, extEnd); -#endif /* GL_SGIS_texture_edge_clamp */ -#ifdef GL_SGIS_texture_filter4 - CONST_CAST(GLEW_SGIS_texture_filter4) = _glewSearchExtension("GL_SGIS_texture_filter4", extStart, extEnd); - if (glewExperimental || GLEW_SGIS_texture_filter4) CONST_CAST(GLEW_SGIS_texture_filter4) = !_glewInit_GL_SGIS_texture_filter4(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIS_texture_filter4 */ -#ifdef GL_SGIS_texture_lod - CONST_CAST(GLEW_SGIS_texture_lod) = _glewSearchExtension("GL_SGIS_texture_lod", extStart, extEnd); -#endif /* GL_SGIS_texture_lod */ -#ifdef GL_SGIS_texture_select - CONST_CAST(GLEW_SGIS_texture_select) = _glewSearchExtension("GL_SGIS_texture_select", extStart, extEnd); -#endif /* GL_SGIS_texture_select */ -#ifdef GL_SGIX_async - CONST_CAST(GLEW_SGIX_async) = _glewSearchExtension("GL_SGIX_async", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_async) CONST_CAST(GLEW_SGIX_async) = !_glewInit_GL_SGIX_async(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_async */ -#ifdef GL_SGIX_async_histogram - CONST_CAST(GLEW_SGIX_async_histogram) = _glewSearchExtension("GL_SGIX_async_histogram", extStart, extEnd); -#endif /* GL_SGIX_async_histogram */ -#ifdef GL_SGIX_async_pixel - CONST_CAST(GLEW_SGIX_async_pixel) = _glewSearchExtension("GL_SGIX_async_pixel", extStart, extEnd); -#endif /* GL_SGIX_async_pixel */ -#ifdef GL_SGIX_blend_alpha_minmax - CONST_CAST(GLEW_SGIX_blend_alpha_minmax) = _glewSearchExtension("GL_SGIX_blend_alpha_minmax", extStart, extEnd); -#endif /* GL_SGIX_blend_alpha_minmax */ -#ifdef GL_SGIX_clipmap - CONST_CAST(GLEW_SGIX_clipmap) = _glewSearchExtension("GL_SGIX_clipmap", extStart, extEnd); -#endif /* GL_SGIX_clipmap */ -#ifdef GL_SGIX_convolution_accuracy - CONST_CAST(GLEW_SGIX_convolution_accuracy) = _glewSearchExtension("GL_SGIX_convolution_accuracy", extStart, extEnd); -#endif /* GL_SGIX_convolution_accuracy */ -#ifdef GL_SGIX_depth_texture - CONST_CAST(GLEW_SGIX_depth_texture) = _glewSearchExtension("GL_SGIX_depth_texture", extStart, extEnd); -#endif /* GL_SGIX_depth_texture */ -#ifdef GL_SGIX_flush_raster - CONST_CAST(GLEW_SGIX_flush_raster) = _glewSearchExtension("GL_SGIX_flush_raster", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_flush_raster) CONST_CAST(GLEW_SGIX_flush_raster) = !_glewInit_GL_SGIX_flush_raster(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_flush_raster */ -#ifdef GL_SGIX_fog_offset - CONST_CAST(GLEW_SGIX_fog_offset) = _glewSearchExtension("GL_SGIX_fog_offset", extStart, extEnd); -#endif /* GL_SGIX_fog_offset */ -#ifdef GL_SGIX_fog_texture - CONST_CAST(GLEW_SGIX_fog_texture) = _glewSearchExtension("GL_SGIX_fog_texture", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_fog_texture) CONST_CAST(GLEW_SGIX_fog_texture) = !_glewInit_GL_SGIX_fog_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_fog_texture */ -#ifdef GL_SGIX_fragment_specular_lighting - CONST_CAST(GLEW_SGIX_fragment_specular_lighting) = _glewSearchExtension("GL_SGIX_fragment_specular_lighting", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_fragment_specular_lighting) CONST_CAST(GLEW_SGIX_fragment_specular_lighting) = !_glewInit_GL_SGIX_fragment_specular_lighting(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_fragment_specular_lighting */ -#ifdef GL_SGIX_framezoom - CONST_CAST(GLEW_SGIX_framezoom) = _glewSearchExtension("GL_SGIX_framezoom", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_framezoom) CONST_CAST(GLEW_SGIX_framezoom) = !_glewInit_GL_SGIX_framezoom(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_framezoom */ -#ifdef GL_SGIX_interlace - CONST_CAST(GLEW_SGIX_interlace) = _glewSearchExtension("GL_SGIX_interlace", extStart, extEnd); -#endif /* GL_SGIX_interlace */ -#ifdef GL_SGIX_ir_instrument1 - CONST_CAST(GLEW_SGIX_ir_instrument1) = _glewSearchExtension("GL_SGIX_ir_instrument1", extStart, extEnd); -#endif /* GL_SGIX_ir_instrument1 */ -#ifdef GL_SGIX_list_priority - CONST_CAST(GLEW_SGIX_list_priority) = _glewSearchExtension("GL_SGIX_list_priority", extStart, extEnd); -#endif /* GL_SGIX_list_priority */ -#ifdef GL_SGIX_pixel_texture - CONST_CAST(GLEW_SGIX_pixel_texture) = _glewSearchExtension("GL_SGIX_pixel_texture", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_pixel_texture) CONST_CAST(GLEW_SGIX_pixel_texture) = !_glewInit_GL_SGIX_pixel_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_pixel_texture */ -#ifdef GL_SGIX_pixel_texture_bits - CONST_CAST(GLEW_SGIX_pixel_texture_bits) = _glewSearchExtension("GL_SGIX_pixel_texture_bits", extStart, extEnd); -#endif /* GL_SGIX_pixel_texture_bits */ -#ifdef GL_SGIX_reference_plane - CONST_CAST(GLEW_SGIX_reference_plane) = _glewSearchExtension("GL_SGIX_reference_plane", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_reference_plane) CONST_CAST(GLEW_SGIX_reference_plane) = !_glewInit_GL_SGIX_reference_plane(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_reference_plane */ -#ifdef GL_SGIX_resample - CONST_CAST(GLEW_SGIX_resample) = _glewSearchExtension("GL_SGIX_resample", extStart, extEnd); -#endif /* GL_SGIX_resample */ -#ifdef GL_SGIX_shadow - CONST_CAST(GLEW_SGIX_shadow) = _glewSearchExtension("GL_SGIX_shadow", extStart, extEnd); -#endif /* GL_SGIX_shadow */ -#ifdef GL_SGIX_shadow_ambient - CONST_CAST(GLEW_SGIX_shadow_ambient) = _glewSearchExtension("GL_SGIX_shadow_ambient", extStart, extEnd); -#endif /* GL_SGIX_shadow_ambient */ -#ifdef GL_SGIX_sprite - CONST_CAST(GLEW_SGIX_sprite) = _glewSearchExtension("GL_SGIX_sprite", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_sprite) CONST_CAST(GLEW_SGIX_sprite) = !_glewInit_GL_SGIX_sprite(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_sprite */ -#ifdef GL_SGIX_tag_sample_buffer - CONST_CAST(GLEW_SGIX_tag_sample_buffer) = _glewSearchExtension("GL_SGIX_tag_sample_buffer", extStart, extEnd); - if (glewExperimental || GLEW_SGIX_tag_sample_buffer) CONST_CAST(GLEW_SGIX_tag_sample_buffer) = !_glewInit_GL_SGIX_tag_sample_buffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGIX_tag_sample_buffer */ -#ifdef GL_SGIX_texture_add_env - CONST_CAST(GLEW_SGIX_texture_add_env) = _glewSearchExtension("GL_SGIX_texture_add_env", extStart, extEnd); -#endif /* GL_SGIX_texture_add_env */ -#ifdef GL_SGIX_texture_coordinate_clamp - CONST_CAST(GLEW_SGIX_texture_coordinate_clamp) = _glewSearchExtension("GL_SGIX_texture_coordinate_clamp", extStart, extEnd); -#endif /* GL_SGIX_texture_coordinate_clamp */ -#ifdef GL_SGIX_texture_lod_bias - CONST_CAST(GLEW_SGIX_texture_lod_bias) = _glewSearchExtension("GL_SGIX_texture_lod_bias", extStart, extEnd); -#endif /* GL_SGIX_texture_lod_bias */ -#ifdef GL_SGIX_texture_multi_buffer - CONST_CAST(GLEW_SGIX_texture_multi_buffer) = _glewSearchExtension("GL_SGIX_texture_multi_buffer", extStart, extEnd); -#endif /* GL_SGIX_texture_multi_buffer */ -#ifdef GL_SGIX_texture_range - CONST_CAST(GLEW_SGIX_texture_range) = _glewSearchExtension("GL_SGIX_texture_range", extStart, extEnd); -#endif /* GL_SGIX_texture_range */ -#ifdef GL_SGIX_texture_scale_bias - CONST_CAST(GLEW_SGIX_texture_scale_bias) = _glewSearchExtension("GL_SGIX_texture_scale_bias", extStart, extEnd); -#endif /* GL_SGIX_texture_scale_bias */ -#ifdef GL_SGIX_vertex_preclip - CONST_CAST(GLEW_SGIX_vertex_preclip) = _glewSearchExtension("GL_SGIX_vertex_preclip", extStart, extEnd); -#endif /* GL_SGIX_vertex_preclip */ -#ifdef GL_SGIX_vertex_preclip_hint - CONST_CAST(GLEW_SGIX_vertex_preclip_hint) = _glewSearchExtension("GL_SGIX_vertex_preclip_hint", extStart, extEnd); -#endif /* GL_SGIX_vertex_preclip_hint */ -#ifdef GL_SGIX_ycrcb - CONST_CAST(GLEW_SGIX_ycrcb) = _glewSearchExtension("GL_SGIX_ycrcb", extStart, extEnd); -#endif /* GL_SGIX_ycrcb */ -#ifdef GL_SGI_color_matrix - CONST_CAST(GLEW_SGI_color_matrix) = _glewSearchExtension("GL_SGI_color_matrix", extStart, extEnd); -#endif /* GL_SGI_color_matrix */ -#ifdef GL_SGI_color_table - CONST_CAST(GLEW_SGI_color_table) = _glewSearchExtension("GL_SGI_color_table", extStart, extEnd); - if (glewExperimental || GLEW_SGI_color_table) CONST_CAST(GLEW_SGI_color_table) = !_glewInit_GL_SGI_color_table(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SGI_color_table */ -#ifdef GL_SGI_texture_color_table - CONST_CAST(GLEW_SGI_texture_color_table) = _glewSearchExtension("GL_SGI_texture_color_table", extStart, extEnd); -#endif /* GL_SGI_texture_color_table */ -#ifdef GL_SUNX_constant_data - CONST_CAST(GLEW_SUNX_constant_data) = _glewSearchExtension("GL_SUNX_constant_data", extStart, extEnd); - if (glewExperimental || GLEW_SUNX_constant_data) CONST_CAST(GLEW_SUNX_constant_data) = !_glewInit_GL_SUNX_constant_data(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SUNX_constant_data */ -#ifdef GL_SUN_convolution_border_modes - CONST_CAST(GLEW_SUN_convolution_border_modes) = _glewSearchExtension("GL_SUN_convolution_border_modes", extStart, extEnd); -#endif /* GL_SUN_convolution_border_modes */ -#ifdef GL_SUN_global_alpha - CONST_CAST(GLEW_SUN_global_alpha) = _glewSearchExtension("GL_SUN_global_alpha", extStart, extEnd); - if (glewExperimental || GLEW_SUN_global_alpha) CONST_CAST(GLEW_SUN_global_alpha) = !_glewInit_GL_SUN_global_alpha(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SUN_global_alpha */ -#ifdef GL_SUN_mesh_array - CONST_CAST(GLEW_SUN_mesh_array) = _glewSearchExtension("GL_SUN_mesh_array", extStart, extEnd); -#endif /* GL_SUN_mesh_array */ -#ifdef GL_SUN_read_video_pixels - CONST_CAST(GLEW_SUN_read_video_pixels) = _glewSearchExtension("GL_SUN_read_video_pixels", extStart, extEnd); - if (glewExperimental || GLEW_SUN_read_video_pixels) CONST_CAST(GLEW_SUN_read_video_pixels) = !_glewInit_GL_SUN_read_video_pixels(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SUN_read_video_pixels */ -#ifdef GL_SUN_slice_accum - CONST_CAST(GLEW_SUN_slice_accum) = _glewSearchExtension("GL_SUN_slice_accum", extStart, extEnd); -#endif /* GL_SUN_slice_accum */ -#ifdef GL_SUN_triangle_list - CONST_CAST(GLEW_SUN_triangle_list) = _glewSearchExtension("GL_SUN_triangle_list", extStart, extEnd); - if (glewExperimental || GLEW_SUN_triangle_list) CONST_CAST(GLEW_SUN_triangle_list) = !_glewInit_GL_SUN_triangle_list(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SUN_triangle_list */ -#ifdef GL_SUN_vertex - CONST_CAST(GLEW_SUN_vertex) = _glewSearchExtension("GL_SUN_vertex", extStart, extEnd); - if (glewExperimental || GLEW_SUN_vertex) CONST_CAST(GLEW_SUN_vertex) = !_glewInit_GL_SUN_vertex(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_SUN_vertex */ -#ifdef GL_WIN_phong_shading - CONST_CAST(GLEW_WIN_phong_shading) = _glewSearchExtension("GL_WIN_phong_shading", extStart, extEnd); -#endif /* GL_WIN_phong_shading */ -#ifdef GL_WIN_specular_fog - CONST_CAST(GLEW_WIN_specular_fog) = _glewSearchExtension("GL_WIN_specular_fog", extStart, extEnd); -#endif /* GL_WIN_specular_fog */ -#ifdef GL_WIN_swap_hint - CONST_CAST(GLEW_WIN_swap_hint) = _glewSearchExtension("GL_WIN_swap_hint", extStart, extEnd); - if (glewExperimental || GLEW_WIN_swap_hint) CONST_CAST(GLEW_WIN_swap_hint) = !_glewInit_GL_WIN_swap_hint(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GL_WIN_swap_hint */ - - return GLEW_OK; -} - - -#if defined(_WIN32) - -#if !defined(GLEW_MX) - -PFNWGLSETSTEREOEMITTERSTATE3DLPROC __wglewSetStereoEmitterState3DL = NULL; - -PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC __wglewBlitContextFramebufferAMD = NULL; -PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC __wglewCreateAssociatedContextAMD = NULL; -PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __wglewCreateAssociatedContextAttribsAMD = NULL; -PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC __wglewDeleteAssociatedContextAMD = NULL; -PFNWGLGETCONTEXTGPUIDAMDPROC __wglewGetContextGPUIDAMD = NULL; -PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC __wglewGetCurrentAssociatedContextAMD = NULL; -PFNWGLGETGPUIDSAMDPROC __wglewGetGPUIDsAMD = NULL; -PFNWGLGETGPUINFOAMDPROC __wglewGetGPUInfoAMD = NULL; -PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __wglewMakeAssociatedContextCurrentAMD = NULL; - -PFNWGLCREATEBUFFERREGIONARBPROC __wglewCreateBufferRegionARB = NULL; -PFNWGLDELETEBUFFERREGIONARBPROC __wglewDeleteBufferRegionARB = NULL; -PFNWGLRESTOREBUFFERREGIONARBPROC __wglewRestoreBufferRegionARB = NULL; -PFNWGLSAVEBUFFERREGIONARBPROC __wglewSaveBufferRegionARB = NULL; - -PFNWGLCREATECONTEXTATTRIBSARBPROC __wglewCreateContextAttribsARB = NULL; - -PFNWGLGETEXTENSIONSSTRINGARBPROC __wglewGetExtensionsStringARB = NULL; - -PFNWGLGETCURRENTREADDCARBPROC __wglewGetCurrentReadDCARB = NULL; -PFNWGLMAKECONTEXTCURRENTARBPROC __wglewMakeContextCurrentARB = NULL; - -PFNWGLCREATEPBUFFERARBPROC __wglewCreatePbufferARB = NULL; -PFNWGLDESTROYPBUFFERARBPROC __wglewDestroyPbufferARB = NULL; -PFNWGLGETPBUFFERDCARBPROC __wglewGetPbufferDCARB = NULL; -PFNWGLQUERYPBUFFERARBPROC __wglewQueryPbufferARB = NULL; -PFNWGLRELEASEPBUFFERDCARBPROC __wglewReleasePbufferDCARB = NULL; - -PFNWGLCHOOSEPIXELFORMATARBPROC __wglewChoosePixelFormatARB = NULL; -PFNWGLGETPIXELFORMATATTRIBFVARBPROC __wglewGetPixelFormatAttribfvARB = NULL; -PFNWGLGETPIXELFORMATATTRIBIVARBPROC __wglewGetPixelFormatAttribivARB = NULL; - -PFNWGLBINDTEXIMAGEARBPROC __wglewBindTexImageARB = NULL; -PFNWGLRELEASETEXIMAGEARBPROC __wglewReleaseTexImageARB = NULL; -PFNWGLSETPBUFFERATTRIBARBPROC __wglewSetPbufferAttribARB = NULL; - -PFNWGLBINDDISPLAYCOLORTABLEEXTPROC __wglewBindDisplayColorTableEXT = NULL; -PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC __wglewCreateDisplayColorTableEXT = NULL; -PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC __wglewDestroyDisplayColorTableEXT = NULL; -PFNWGLLOADDISPLAYCOLORTABLEEXTPROC __wglewLoadDisplayColorTableEXT = NULL; - -PFNWGLGETEXTENSIONSSTRINGEXTPROC __wglewGetExtensionsStringEXT = NULL; - -PFNWGLGETCURRENTREADDCEXTPROC __wglewGetCurrentReadDCEXT = NULL; -PFNWGLMAKECONTEXTCURRENTEXTPROC __wglewMakeContextCurrentEXT = NULL; - -PFNWGLCREATEPBUFFEREXTPROC __wglewCreatePbufferEXT = NULL; -PFNWGLDESTROYPBUFFEREXTPROC __wglewDestroyPbufferEXT = NULL; -PFNWGLGETPBUFFERDCEXTPROC __wglewGetPbufferDCEXT = NULL; -PFNWGLQUERYPBUFFEREXTPROC __wglewQueryPbufferEXT = NULL; -PFNWGLRELEASEPBUFFERDCEXTPROC __wglewReleasePbufferDCEXT = NULL; - -PFNWGLCHOOSEPIXELFORMATEXTPROC __wglewChoosePixelFormatEXT = NULL; -PFNWGLGETPIXELFORMATATTRIBFVEXTPROC __wglewGetPixelFormatAttribfvEXT = NULL; -PFNWGLGETPIXELFORMATATTRIBIVEXTPROC __wglewGetPixelFormatAttribivEXT = NULL; - -PFNWGLGETSWAPINTERVALEXTPROC __wglewGetSwapIntervalEXT = NULL; -PFNWGLSWAPINTERVALEXTPROC __wglewSwapIntervalEXT = NULL; - -PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC __wglewGetDigitalVideoParametersI3D = NULL; -PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC __wglewSetDigitalVideoParametersI3D = NULL; - -PFNWGLGETGAMMATABLEI3DPROC __wglewGetGammaTableI3D = NULL; -PFNWGLGETGAMMATABLEPARAMETERSI3DPROC __wglewGetGammaTableParametersI3D = NULL; -PFNWGLSETGAMMATABLEI3DPROC __wglewSetGammaTableI3D = NULL; -PFNWGLSETGAMMATABLEPARAMETERSI3DPROC __wglewSetGammaTableParametersI3D = NULL; - -PFNWGLDISABLEGENLOCKI3DPROC __wglewDisableGenlockI3D = NULL; -PFNWGLENABLEGENLOCKI3DPROC __wglewEnableGenlockI3D = NULL; -PFNWGLGENLOCKSAMPLERATEI3DPROC __wglewGenlockSampleRateI3D = NULL; -PFNWGLGENLOCKSOURCEDELAYI3DPROC __wglewGenlockSourceDelayI3D = NULL; -PFNWGLGENLOCKSOURCEEDGEI3DPROC __wglewGenlockSourceEdgeI3D = NULL; -PFNWGLGENLOCKSOURCEI3DPROC __wglewGenlockSourceI3D = NULL; -PFNWGLGETGENLOCKSAMPLERATEI3DPROC __wglewGetGenlockSampleRateI3D = NULL; -PFNWGLGETGENLOCKSOURCEDELAYI3DPROC __wglewGetGenlockSourceDelayI3D = NULL; -PFNWGLGETGENLOCKSOURCEEDGEI3DPROC __wglewGetGenlockSourceEdgeI3D = NULL; -PFNWGLGETGENLOCKSOURCEI3DPROC __wglewGetGenlockSourceI3D = NULL; -PFNWGLISENABLEDGENLOCKI3DPROC __wglewIsEnabledGenlockI3D = NULL; -PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC __wglewQueryGenlockMaxSourceDelayI3D = NULL; - -PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC __wglewAssociateImageBufferEventsI3D = NULL; -PFNWGLCREATEIMAGEBUFFERI3DPROC __wglewCreateImageBufferI3D = NULL; -PFNWGLDESTROYIMAGEBUFFERI3DPROC __wglewDestroyImageBufferI3D = NULL; -PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC __wglewReleaseImageBufferEventsI3D = NULL; - -PFNWGLDISABLEFRAMELOCKI3DPROC __wglewDisableFrameLockI3D = NULL; -PFNWGLENABLEFRAMELOCKI3DPROC __wglewEnableFrameLockI3D = NULL; -PFNWGLISENABLEDFRAMELOCKI3DPROC __wglewIsEnabledFrameLockI3D = NULL; -PFNWGLQUERYFRAMELOCKMASTERI3DPROC __wglewQueryFrameLockMasterI3D = NULL; - -PFNWGLBEGINFRAMETRACKINGI3DPROC __wglewBeginFrameTrackingI3D = NULL; -PFNWGLENDFRAMETRACKINGI3DPROC __wglewEndFrameTrackingI3D = NULL; -PFNWGLGETFRAMEUSAGEI3DPROC __wglewGetFrameUsageI3D = NULL; -PFNWGLQUERYFRAMETRACKINGI3DPROC __wglewQueryFrameTrackingI3D = NULL; - -PFNWGLDXCLOSEDEVICENVPROC __wglewDXCloseDeviceNV = NULL; -PFNWGLDXLOCKOBJECTSNVPROC __wglewDXLockObjectsNV = NULL; -PFNWGLDXOBJECTACCESSNVPROC __wglewDXObjectAccessNV = NULL; -PFNWGLDXOPENDEVICENVPROC __wglewDXOpenDeviceNV = NULL; -PFNWGLDXREGISTEROBJECTNVPROC __wglewDXRegisterObjectNV = NULL; -PFNWGLDXSETRESOURCESHAREHANDLENVPROC __wglewDXSetResourceShareHandleNV = NULL; -PFNWGLDXUNLOCKOBJECTSNVPROC __wglewDXUnlockObjectsNV = NULL; -PFNWGLDXUNREGISTEROBJECTNVPROC __wglewDXUnregisterObjectNV = NULL; - -PFNWGLCOPYIMAGESUBDATANVPROC __wglewCopyImageSubDataNV = NULL; - -PFNWGLCREATEAFFINITYDCNVPROC __wglewCreateAffinityDCNV = NULL; -PFNWGLDELETEDCNVPROC __wglewDeleteDCNV = NULL; -PFNWGLENUMGPUDEVICESNVPROC __wglewEnumGpuDevicesNV = NULL; -PFNWGLENUMGPUSFROMAFFINITYDCNVPROC __wglewEnumGpusFromAffinityDCNV = NULL; -PFNWGLENUMGPUSNVPROC __wglewEnumGpusNV = NULL; - -PFNWGLBINDVIDEODEVICENVPROC __wglewBindVideoDeviceNV = NULL; -PFNWGLENUMERATEVIDEODEVICESNVPROC __wglewEnumerateVideoDevicesNV = NULL; -PFNWGLQUERYCURRENTCONTEXTNVPROC __wglewQueryCurrentContextNV = NULL; - -PFNWGLBINDSWAPBARRIERNVPROC __wglewBindSwapBarrierNV = NULL; -PFNWGLJOINSWAPGROUPNVPROC __wglewJoinSwapGroupNV = NULL; -PFNWGLQUERYFRAMECOUNTNVPROC __wglewQueryFrameCountNV = NULL; -PFNWGLQUERYMAXSWAPGROUPSNVPROC __wglewQueryMaxSwapGroupsNV = NULL; -PFNWGLQUERYSWAPGROUPNVPROC __wglewQuerySwapGroupNV = NULL; -PFNWGLRESETFRAMECOUNTNVPROC __wglewResetFrameCountNV = NULL; - -PFNWGLALLOCATEMEMORYNVPROC __wglewAllocateMemoryNV = NULL; -PFNWGLFREEMEMORYNVPROC __wglewFreeMemoryNV = NULL; - -PFNWGLBINDVIDEOCAPTUREDEVICENVPROC __wglewBindVideoCaptureDeviceNV = NULL; -PFNWGLENUMERATEVIDEOCAPTUREDEVICESNVPROC __wglewEnumerateVideoCaptureDevicesNV = NULL; -PFNWGLLOCKVIDEOCAPTUREDEVICENVPROC __wglewLockVideoCaptureDeviceNV = NULL; -PFNWGLQUERYVIDEOCAPTUREDEVICENVPROC __wglewQueryVideoCaptureDeviceNV = NULL; -PFNWGLRELEASEVIDEOCAPTUREDEVICENVPROC __wglewReleaseVideoCaptureDeviceNV = NULL; - -PFNWGLBINDVIDEOIMAGENVPROC __wglewBindVideoImageNV = NULL; -PFNWGLGETVIDEODEVICENVPROC __wglewGetVideoDeviceNV = NULL; -PFNWGLGETVIDEOINFONVPROC __wglewGetVideoInfoNV = NULL; -PFNWGLRELEASEVIDEODEVICENVPROC __wglewReleaseVideoDeviceNV = NULL; -PFNWGLRELEASEVIDEOIMAGENVPROC __wglewReleaseVideoImageNV = NULL; -PFNWGLSENDPBUFFERTOVIDEONVPROC __wglewSendPbufferToVideoNV = NULL; - -PFNWGLGETMSCRATEOMLPROC __wglewGetMscRateOML = NULL; -PFNWGLGETSYNCVALUESOMLPROC __wglewGetSyncValuesOML = NULL; -PFNWGLSWAPBUFFERSMSCOMLPROC __wglewSwapBuffersMscOML = NULL; -PFNWGLSWAPLAYERBUFFERSMSCOMLPROC __wglewSwapLayerBuffersMscOML = NULL; -PFNWGLWAITFORMSCOMLPROC __wglewWaitForMscOML = NULL; -PFNWGLWAITFORSBCOMLPROC __wglewWaitForSbcOML = NULL; -GLboolean __WGLEW_3DFX_multisample = GL_FALSE; -GLboolean __WGLEW_3DL_stereo_control = GL_FALSE; -GLboolean __WGLEW_AMD_gpu_association = GL_FALSE; -GLboolean __WGLEW_ARB_buffer_region = GL_FALSE; -GLboolean __WGLEW_ARB_create_context = GL_FALSE; -GLboolean __WGLEW_ARB_create_context_profile = GL_FALSE; -GLboolean __WGLEW_ARB_create_context_robustness = GL_FALSE; -GLboolean __WGLEW_ARB_extensions_string = GL_FALSE; -GLboolean __WGLEW_ARB_framebuffer_sRGB = GL_FALSE; -GLboolean __WGLEW_ARB_make_current_read = GL_FALSE; -GLboolean __WGLEW_ARB_multisample = GL_FALSE; -GLboolean __WGLEW_ARB_pbuffer = GL_FALSE; -GLboolean __WGLEW_ARB_pixel_format = GL_FALSE; -GLboolean __WGLEW_ARB_pixel_format_float = GL_FALSE; -GLboolean __WGLEW_ARB_render_texture = GL_FALSE; -GLboolean __WGLEW_ARB_robustness_application_isolation = GL_FALSE; -GLboolean __WGLEW_ARB_robustness_share_group_isolation = GL_FALSE; -GLboolean __WGLEW_ATI_pixel_format_float = GL_FALSE; -GLboolean __WGLEW_ATI_render_texture_rectangle = GL_FALSE; -GLboolean __WGLEW_EXT_create_context_es2_profile = GL_FALSE; -GLboolean __WGLEW_EXT_create_context_es_profile = GL_FALSE; -GLboolean __WGLEW_EXT_depth_float = GL_FALSE; -GLboolean __WGLEW_EXT_display_color_table = GL_FALSE; -GLboolean __WGLEW_EXT_extensions_string = GL_FALSE; -GLboolean __WGLEW_EXT_framebuffer_sRGB = GL_FALSE; -GLboolean __WGLEW_EXT_make_current_read = GL_FALSE; -GLboolean __WGLEW_EXT_multisample = GL_FALSE; -GLboolean __WGLEW_EXT_pbuffer = GL_FALSE; -GLboolean __WGLEW_EXT_pixel_format = GL_FALSE; -GLboolean __WGLEW_EXT_pixel_format_packed_float = GL_FALSE; -GLboolean __WGLEW_EXT_swap_control = GL_FALSE; -GLboolean __WGLEW_EXT_swap_control_tear = GL_FALSE; -GLboolean __WGLEW_I3D_digital_video_control = GL_FALSE; -GLboolean __WGLEW_I3D_gamma = GL_FALSE; -GLboolean __WGLEW_I3D_genlock = GL_FALSE; -GLboolean __WGLEW_I3D_image_buffer = GL_FALSE; -GLboolean __WGLEW_I3D_swap_frame_lock = GL_FALSE; -GLboolean __WGLEW_I3D_swap_frame_usage = GL_FALSE; -GLboolean __WGLEW_NV_DX_interop = GL_FALSE; -GLboolean __WGLEW_NV_DX_interop2 = GL_FALSE; -GLboolean __WGLEW_NV_copy_image = GL_FALSE; -GLboolean __WGLEW_NV_float_buffer = GL_FALSE; -GLboolean __WGLEW_NV_gpu_affinity = GL_FALSE; -GLboolean __WGLEW_NV_multisample_coverage = GL_FALSE; -GLboolean __WGLEW_NV_present_video = GL_FALSE; -GLboolean __WGLEW_NV_render_depth_texture = GL_FALSE; -GLboolean __WGLEW_NV_render_texture_rectangle = GL_FALSE; -GLboolean __WGLEW_NV_swap_group = GL_FALSE; -GLboolean __WGLEW_NV_vertex_array_range = GL_FALSE; -GLboolean __WGLEW_NV_video_capture = GL_FALSE; -GLboolean __WGLEW_NV_video_output = GL_FALSE; -GLboolean __WGLEW_OML_sync_control = GL_FALSE; - -#endif /* !GLEW_MX */ - -#ifdef WGL_3DFX_multisample - -#endif /* WGL_3DFX_multisample */ - -#ifdef WGL_3DL_stereo_control - -static GLboolean _glewInit_WGL_3DL_stereo_control (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglSetStereoEmitterState3DL = (PFNWGLSETSTEREOEMITTERSTATE3DLPROC)glewGetProcAddress((const GLubyte*)"wglSetStereoEmitterState3DL")) == NULL) || r; - - return r; -} - -#endif /* WGL_3DL_stereo_control */ - -#ifdef WGL_AMD_gpu_association - -static GLboolean _glewInit_WGL_AMD_gpu_association (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBlitContextFramebufferAMD = (PFNWGLBLITCONTEXTFRAMEBUFFERAMDPROC)glewGetProcAddress((const GLubyte*)"wglBlitContextFramebufferAMD")) == NULL) || r; - r = ((wglCreateAssociatedContextAMD = (PFNWGLCREATEASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"wglCreateAssociatedContextAMD")) == NULL) || r; - r = ((wglCreateAssociatedContextAttribsAMD = (PFNWGLCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC)glewGetProcAddress((const GLubyte*)"wglCreateAssociatedContextAttribsAMD")) == NULL) || r; - r = ((wglDeleteAssociatedContextAMD = (PFNWGLDELETEASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"wglDeleteAssociatedContextAMD")) == NULL) || r; - r = ((wglGetContextGPUIDAMD = (PFNWGLGETCONTEXTGPUIDAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetContextGPUIDAMD")) == NULL) || r; - r = ((wglGetCurrentAssociatedContextAMD = (PFNWGLGETCURRENTASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetCurrentAssociatedContextAMD")) == NULL) || r; - r = ((wglGetGPUIDsAMD = (PFNWGLGETGPUIDSAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetGPUIDsAMD")) == NULL) || r; - r = ((wglGetGPUInfoAMD = (PFNWGLGETGPUINFOAMDPROC)glewGetProcAddress((const GLubyte*)"wglGetGPUInfoAMD")) == NULL) || r; - r = ((wglMakeAssociatedContextCurrentAMD = (PFNWGLMAKEASSOCIATEDCONTEXTCURRENTAMDPROC)glewGetProcAddress((const GLubyte*)"wglMakeAssociatedContextCurrentAMD")) == NULL) || r; - - return r; -} - -#endif /* WGL_AMD_gpu_association */ - -#ifdef WGL_ARB_buffer_region - -static GLboolean _glewInit_WGL_ARB_buffer_region (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglCreateBufferRegionARB = (PFNWGLCREATEBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglCreateBufferRegionARB")) == NULL) || r; - r = ((wglDeleteBufferRegionARB = (PFNWGLDELETEBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglDeleteBufferRegionARB")) == NULL) || r; - r = ((wglRestoreBufferRegionARB = (PFNWGLRESTOREBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglRestoreBufferRegionARB")) == NULL) || r; - r = ((wglSaveBufferRegionARB = (PFNWGLSAVEBUFFERREGIONARBPROC)glewGetProcAddress((const GLubyte*)"wglSaveBufferRegionARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_buffer_region */ - -#ifdef WGL_ARB_create_context - -static GLboolean _glewInit_WGL_ARB_create_context (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglCreateContextAttribsARB = (PFNWGLCREATECONTEXTATTRIBSARBPROC)glewGetProcAddress((const GLubyte*)"wglCreateContextAttribsARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_create_context */ - -#ifdef WGL_ARB_create_context_profile - -#endif /* WGL_ARB_create_context_profile */ - -#ifdef WGL_ARB_create_context_robustness - -#endif /* WGL_ARB_create_context_robustness */ - -#ifdef WGL_ARB_extensions_string - -static GLboolean _glewInit_WGL_ARB_extensions_string (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetExtensionsStringARB = (PFNWGLGETEXTENSIONSSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_extensions_string */ - -#ifdef WGL_ARB_framebuffer_sRGB - -#endif /* WGL_ARB_framebuffer_sRGB */ - -#ifdef WGL_ARB_make_current_read - -static GLboolean _glewInit_WGL_ARB_make_current_read (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetCurrentReadDCARB = (PFNWGLGETCURRENTREADDCARBPROC)glewGetProcAddress((const GLubyte*)"wglGetCurrentReadDCARB")) == NULL) || r; - r = ((wglMakeContextCurrentARB = (PFNWGLMAKECONTEXTCURRENTARBPROC)glewGetProcAddress((const GLubyte*)"wglMakeContextCurrentARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_make_current_read */ - -#ifdef WGL_ARB_multisample - -#endif /* WGL_ARB_multisample */ - -#ifdef WGL_ARB_pbuffer - -static GLboolean _glewInit_WGL_ARB_pbuffer (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglCreatePbufferARB = (PFNWGLCREATEPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"wglCreatePbufferARB")) == NULL) || r; - r = ((wglDestroyPbufferARB = (PFNWGLDESTROYPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"wglDestroyPbufferARB")) == NULL) || r; - r = ((wglGetPbufferDCARB = (PFNWGLGETPBUFFERDCARBPROC)glewGetProcAddress((const GLubyte*)"wglGetPbufferDCARB")) == NULL) || r; - r = ((wglQueryPbufferARB = (PFNWGLQUERYPBUFFERARBPROC)glewGetProcAddress((const GLubyte*)"wglQueryPbufferARB")) == NULL) || r; - r = ((wglReleasePbufferDCARB = (PFNWGLRELEASEPBUFFERDCARBPROC)glewGetProcAddress((const GLubyte*)"wglReleasePbufferDCARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_pbuffer */ - -#ifdef WGL_ARB_pixel_format - -static GLboolean _glewInit_WGL_ARB_pixel_format (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglChoosePixelFormatARB = (PFNWGLCHOOSEPIXELFORMATARBPROC)glewGetProcAddress((const GLubyte*)"wglChoosePixelFormatARB")) == NULL) || r; - r = ((wglGetPixelFormatAttribfvARB = (PFNWGLGETPIXELFORMATATTRIBFVARBPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribfvARB")) == NULL) || r; - r = ((wglGetPixelFormatAttribivARB = (PFNWGLGETPIXELFORMATATTRIBIVARBPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribivARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_pixel_format */ - -#ifdef WGL_ARB_pixel_format_float - -#endif /* WGL_ARB_pixel_format_float */ - -#ifdef WGL_ARB_render_texture - -static GLboolean _glewInit_WGL_ARB_render_texture (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBindTexImageARB = (PFNWGLBINDTEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"wglBindTexImageARB")) == NULL) || r; - r = ((wglReleaseTexImageARB = (PFNWGLRELEASETEXIMAGEARBPROC)glewGetProcAddress((const GLubyte*)"wglReleaseTexImageARB")) == NULL) || r; - r = ((wglSetPbufferAttribARB = (PFNWGLSETPBUFFERATTRIBARBPROC)glewGetProcAddress((const GLubyte*)"wglSetPbufferAttribARB")) == NULL) || r; - - return r; -} - -#endif /* WGL_ARB_render_texture */ - -#ifdef WGL_ARB_robustness_application_isolation - -#endif /* WGL_ARB_robustness_application_isolation */ - -#ifdef WGL_ARB_robustness_share_group_isolation - -#endif /* WGL_ARB_robustness_share_group_isolation */ - -#ifdef WGL_ATI_pixel_format_float - -#endif /* WGL_ATI_pixel_format_float */ - -#ifdef WGL_ATI_render_texture_rectangle - -#endif /* WGL_ATI_render_texture_rectangle */ - -#ifdef WGL_EXT_create_context_es2_profile - -#endif /* WGL_EXT_create_context_es2_profile */ - -#ifdef WGL_EXT_create_context_es_profile - -#endif /* WGL_EXT_create_context_es_profile */ - -#ifdef WGL_EXT_depth_float - -#endif /* WGL_EXT_depth_float */ - -#ifdef WGL_EXT_display_color_table - -static GLboolean _glewInit_WGL_EXT_display_color_table (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBindDisplayColorTableEXT = (PFNWGLBINDDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglBindDisplayColorTableEXT")) == NULL) || r; - r = ((wglCreateDisplayColorTableEXT = (PFNWGLCREATEDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglCreateDisplayColorTableEXT")) == NULL) || r; - r = ((wglDestroyDisplayColorTableEXT = (PFNWGLDESTROYDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglDestroyDisplayColorTableEXT")) == NULL) || r; - r = ((wglLoadDisplayColorTableEXT = (PFNWGLLOADDISPLAYCOLORTABLEEXTPROC)glewGetProcAddress((const GLubyte*)"wglLoadDisplayColorTableEXT")) == NULL) || r; - - return r; -} - -#endif /* WGL_EXT_display_color_table */ - -#ifdef WGL_EXT_extensions_string - -static GLboolean _glewInit_WGL_EXT_extensions_string (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetExtensionsStringEXT = (PFNWGLGETEXTENSIONSSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringEXT")) == NULL) || r; - - return r; -} - -#endif /* WGL_EXT_extensions_string */ - -#ifdef WGL_EXT_framebuffer_sRGB - -#endif /* WGL_EXT_framebuffer_sRGB */ - -#ifdef WGL_EXT_make_current_read - -static GLboolean _glewInit_WGL_EXT_make_current_read (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetCurrentReadDCEXT = (PFNWGLGETCURRENTREADDCEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetCurrentReadDCEXT")) == NULL) || r; - r = ((wglMakeContextCurrentEXT = (PFNWGLMAKECONTEXTCURRENTEXTPROC)glewGetProcAddress((const GLubyte*)"wglMakeContextCurrentEXT")) == NULL) || r; - - return r; -} - -#endif /* WGL_EXT_make_current_read */ - -#ifdef WGL_EXT_multisample - -#endif /* WGL_EXT_multisample */ - -#ifdef WGL_EXT_pbuffer - -static GLboolean _glewInit_WGL_EXT_pbuffer (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglCreatePbufferEXT = (PFNWGLCREATEPBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"wglCreatePbufferEXT")) == NULL) || r; - r = ((wglDestroyPbufferEXT = (PFNWGLDESTROYPBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"wglDestroyPbufferEXT")) == NULL) || r; - r = ((wglGetPbufferDCEXT = (PFNWGLGETPBUFFERDCEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetPbufferDCEXT")) == NULL) || r; - r = ((wglQueryPbufferEXT = (PFNWGLQUERYPBUFFEREXTPROC)glewGetProcAddress((const GLubyte*)"wglQueryPbufferEXT")) == NULL) || r; - r = ((wglReleasePbufferDCEXT = (PFNWGLRELEASEPBUFFERDCEXTPROC)glewGetProcAddress((const GLubyte*)"wglReleasePbufferDCEXT")) == NULL) || r; - - return r; -} - -#endif /* WGL_EXT_pbuffer */ - -#ifdef WGL_EXT_pixel_format - -static GLboolean _glewInit_WGL_EXT_pixel_format (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglChoosePixelFormatEXT = (PFNWGLCHOOSEPIXELFORMATEXTPROC)glewGetProcAddress((const GLubyte*)"wglChoosePixelFormatEXT")) == NULL) || r; - r = ((wglGetPixelFormatAttribfvEXT = (PFNWGLGETPIXELFORMATATTRIBFVEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribfvEXT")) == NULL) || r; - r = ((wglGetPixelFormatAttribivEXT = (PFNWGLGETPIXELFORMATATTRIBIVEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetPixelFormatAttribivEXT")) == NULL) || r; - - return r; -} - -#endif /* WGL_EXT_pixel_format */ - -#ifdef WGL_EXT_pixel_format_packed_float - -#endif /* WGL_EXT_pixel_format_packed_float */ - -#ifdef WGL_EXT_swap_control - -static GLboolean _glewInit_WGL_EXT_swap_control (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetSwapIntervalEXT = (PFNWGLGETSWAPINTERVALEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetSwapIntervalEXT")) == NULL) || r; - r = ((wglSwapIntervalEXT = (PFNWGLSWAPINTERVALEXTPROC)glewGetProcAddress((const GLubyte*)"wglSwapIntervalEXT")) == NULL) || r; - - return r; -} - -#endif /* WGL_EXT_swap_control */ - -#ifdef WGL_EXT_swap_control_tear - -#endif /* WGL_EXT_swap_control_tear */ - -#ifdef WGL_I3D_digital_video_control - -static GLboolean _glewInit_WGL_I3D_digital_video_control (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetDigitalVideoParametersI3D = (PFNWGLGETDIGITALVIDEOPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetDigitalVideoParametersI3D")) == NULL) || r; - r = ((wglSetDigitalVideoParametersI3D = (PFNWGLSETDIGITALVIDEOPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglSetDigitalVideoParametersI3D")) == NULL) || r; - - return r; -} - -#endif /* WGL_I3D_digital_video_control */ - -#ifdef WGL_I3D_gamma - -static GLboolean _glewInit_WGL_I3D_gamma (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetGammaTableI3D = (PFNWGLGETGAMMATABLEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGammaTableI3D")) == NULL) || r; - r = ((wglGetGammaTableParametersI3D = (PFNWGLGETGAMMATABLEPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGammaTableParametersI3D")) == NULL) || r; - r = ((wglSetGammaTableI3D = (PFNWGLSETGAMMATABLEI3DPROC)glewGetProcAddress((const GLubyte*)"wglSetGammaTableI3D")) == NULL) || r; - r = ((wglSetGammaTableParametersI3D = (PFNWGLSETGAMMATABLEPARAMETERSI3DPROC)glewGetProcAddress((const GLubyte*)"wglSetGammaTableParametersI3D")) == NULL) || r; - - return r; -} - -#endif /* WGL_I3D_gamma */ - -#ifdef WGL_I3D_genlock - -static GLboolean _glewInit_WGL_I3D_genlock (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglDisableGenlockI3D = (PFNWGLDISABLEGENLOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglDisableGenlockI3D")) == NULL) || r; - r = ((wglEnableGenlockI3D = (PFNWGLENABLEGENLOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglEnableGenlockI3D")) == NULL) || r; - r = ((wglGenlockSampleRateI3D = (PFNWGLGENLOCKSAMPLERATEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSampleRateI3D")) == NULL) || r; - r = ((wglGenlockSourceDelayI3D = (PFNWGLGENLOCKSOURCEDELAYI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSourceDelayI3D")) == NULL) || r; - r = ((wglGenlockSourceEdgeI3D = (PFNWGLGENLOCKSOURCEEDGEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSourceEdgeI3D")) == NULL) || r; - r = ((wglGenlockSourceI3D = (PFNWGLGENLOCKSOURCEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGenlockSourceI3D")) == NULL) || r; - r = ((wglGetGenlockSampleRateI3D = (PFNWGLGETGENLOCKSAMPLERATEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSampleRateI3D")) == NULL) || r; - r = ((wglGetGenlockSourceDelayI3D = (PFNWGLGETGENLOCKSOURCEDELAYI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSourceDelayI3D")) == NULL) || r; - r = ((wglGetGenlockSourceEdgeI3D = (PFNWGLGETGENLOCKSOURCEEDGEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSourceEdgeI3D")) == NULL) || r; - r = ((wglGetGenlockSourceI3D = (PFNWGLGETGENLOCKSOURCEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetGenlockSourceI3D")) == NULL) || r; - r = ((wglIsEnabledGenlockI3D = (PFNWGLISENABLEDGENLOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglIsEnabledGenlockI3D")) == NULL) || r; - r = ((wglQueryGenlockMaxSourceDelayI3D = (PFNWGLQUERYGENLOCKMAXSOURCEDELAYI3DPROC)glewGetProcAddress((const GLubyte*)"wglQueryGenlockMaxSourceDelayI3D")) == NULL) || r; - - return r; -} - -#endif /* WGL_I3D_genlock */ - -#ifdef WGL_I3D_image_buffer - -static GLboolean _glewInit_WGL_I3D_image_buffer (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglAssociateImageBufferEventsI3D = (PFNWGLASSOCIATEIMAGEBUFFEREVENTSI3DPROC)glewGetProcAddress((const GLubyte*)"wglAssociateImageBufferEventsI3D")) == NULL) || r; - r = ((wglCreateImageBufferI3D = (PFNWGLCREATEIMAGEBUFFERI3DPROC)glewGetProcAddress((const GLubyte*)"wglCreateImageBufferI3D")) == NULL) || r; - r = ((wglDestroyImageBufferI3D = (PFNWGLDESTROYIMAGEBUFFERI3DPROC)glewGetProcAddress((const GLubyte*)"wglDestroyImageBufferI3D")) == NULL) || r; - r = ((wglReleaseImageBufferEventsI3D = (PFNWGLRELEASEIMAGEBUFFEREVENTSI3DPROC)glewGetProcAddress((const GLubyte*)"wglReleaseImageBufferEventsI3D")) == NULL) || r; - - return r; -} - -#endif /* WGL_I3D_image_buffer */ - -#ifdef WGL_I3D_swap_frame_lock - -static GLboolean _glewInit_WGL_I3D_swap_frame_lock (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglDisableFrameLockI3D = (PFNWGLDISABLEFRAMELOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglDisableFrameLockI3D")) == NULL) || r; - r = ((wglEnableFrameLockI3D = (PFNWGLENABLEFRAMELOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglEnableFrameLockI3D")) == NULL) || r; - r = ((wglIsEnabledFrameLockI3D = (PFNWGLISENABLEDFRAMELOCKI3DPROC)glewGetProcAddress((const GLubyte*)"wglIsEnabledFrameLockI3D")) == NULL) || r; - r = ((wglQueryFrameLockMasterI3D = (PFNWGLQUERYFRAMELOCKMASTERI3DPROC)glewGetProcAddress((const GLubyte*)"wglQueryFrameLockMasterI3D")) == NULL) || r; - - return r; -} - -#endif /* WGL_I3D_swap_frame_lock */ - -#ifdef WGL_I3D_swap_frame_usage - -static GLboolean _glewInit_WGL_I3D_swap_frame_usage (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBeginFrameTrackingI3D = (PFNWGLBEGINFRAMETRACKINGI3DPROC)glewGetProcAddress((const GLubyte*)"wglBeginFrameTrackingI3D")) == NULL) || r; - r = ((wglEndFrameTrackingI3D = (PFNWGLENDFRAMETRACKINGI3DPROC)glewGetProcAddress((const GLubyte*)"wglEndFrameTrackingI3D")) == NULL) || r; - r = ((wglGetFrameUsageI3D = (PFNWGLGETFRAMEUSAGEI3DPROC)glewGetProcAddress((const GLubyte*)"wglGetFrameUsageI3D")) == NULL) || r; - r = ((wglQueryFrameTrackingI3D = (PFNWGLQUERYFRAMETRACKINGI3DPROC)glewGetProcAddress((const GLubyte*)"wglQueryFrameTrackingI3D")) == NULL) || r; - - return r; -} - -#endif /* WGL_I3D_swap_frame_usage */ - -#ifdef WGL_NV_DX_interop - -static GLboolean _glewInit_WGL_NV_DX_interop (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglDXCloseDeviceNV = (PFNWGLDXCLOSEDEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglDXCloseDeviceNV")) == NULL) || r; - r = ((wglDXLockObjectsNV = (PFNWGLDXLOCKOBJECTSNVPROC)glewGetProcAddress((const GLubyte*)"wglDXLockObjectsNV")) == NULL) || r; - r = ((wglDXObjectAccessNV = (PFNWGLDXOBJECTACCESSNVPROC)glewGetProcAddress((const GLubyte*)"wglDXObjectAccessNV")) == NULL) || r; - r = ((wglDXOpenDeviceNV = (PFNWGLDXOPENDEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglDXOpenDeviceNV")) == NULL) || r; - r = ((wglDXRegisterObjectNV = (PFNWGLDXREGISTEROBJECTNVPROC)glewGetProcAddress((const GLubyte*)"wglDXRegisterObjectNV")) == NULL) || r; - r = ((wglDXSetResourceShareHandleNV = (PFNWGLDXSETRESOURCESHAREHANDLENVPROC)glewGetProcAddress((const GLubyte*)"wglDXSetResourceShareHandleNV")) == NULL) || r; - r = ((wglDXUnlockObjectsNV = (PFNWGLDXUNLOCKOBJECTSNVPROC)glewGetProcAddress((const GLubyte*)"wglDXUnlockObjectsNV")) == NULL) || r; - r = ((wglDXUnregisterObjectNV = (PFNWGLDXUNREGISTEROBJECTNVPROC)glewGetProcAddress((const GLubyte*)"wglDXUnregisterObjectNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_DX_interop */ - -#ifdef WGL_NV_DX_interop2 - -#endif /* WGL_NV_DX_interop2 */ - -#ifdef WGL_NV_copy_image - -static GLboolean _glewInit_WGL_NV_copy_image (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglCopyImageSubDataNV = (PFNWGLCOPYIMAGESUBDATANVPROC)glewGetProcAddress((const GLubyte*)"wglCopyImageSubDataNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_copy_image */ - -#ifdef WGL_NV_float_buffer - -#endif /* WGL_NV_float_buffer */ - -#ifdef WGL_NV_gpu_affinity - -static GLboolean _glewInit_WGL_NV_gpu_affinity (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglCreateAffinityDCNV = (PFNWGLCREATEAFFINITYDCNVPROC)glewGetProcAddress((const GLubyte*)"wglCreateAffinityDCNV")) == NULL) || r; - r = ((wglDeleteDCNV = (PFNWGLDELETEDCNVPROC)glewGetProcAddress((const GLubyte*)"wglDeleteDCNV")) == NULL) || r; - r = ((wglEnumGpuDevicesNV = (PFNWGLENUMGPUDEVICESNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumGpuDevicesNV")) == NULL) || r; - r = ((wglEnumGpusFromAffinityDCNV = (PFNWGLENUMGPUSFROMAFFINITYDCNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumGpusFromAffinityDCNV")) == NULL) || r; - r = ((wglEnumGpusNV = (PFNWGLENUMGPUSNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumGpusNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_gpu_affinity */ - -#ifdef WGL_NV_multisample_coverage - -#endif /* WGL_NV_multisample_coverage */ - -#ifdef WGL_NV_present_video - -static GLboolean _glewInit_WGL_NV_present_video (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBindVideoDeviceNV = (PFNWGLBINDVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglBindVideoDeviceNV")) == NULL) || r; - r = ((wglEnumerateVideoDevicesNV = (PFNWGLENUMERATEVIDEODEVICESNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumerateVideoDevicesNV")) == NULL) || r; - r = ((wglQueryCurrentContextNV = (PFNWGLQUERYCURRENTCONTEXTNVPROC)glewGetProcAddress((const GLubyte*)"wglQueryCurrentContextNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_present_video */ - -#ifdef WGL_NV_render_depth_texture - -#endif /* WGL_NV_render_depth_texture */ - -#ifdef WGL_NV_render_texture_rectangle - -#endif /* WGL_NV_render_texture_rectangle */ - -#ifdef WGL_NV_swap_group - -static GLboolean _glewInit_WGL_NV_swap_group (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBindSwapBarrierNV = (PFNWGLBINDSWAPBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"wglBindSwapBarrierNV")) == NULL) || r; - r = ((wglJoinSwapGroupNV = (PFNWGLJOINSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"wglJoinSwapGroupNV")) == NULL) || r; - r = ((wglQueryFrameCountNV = (PFNWGLQUERYFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"wglQueryFrameCountNV")) == NULL) || r; - r = ((wglQueryMaxSwapGroupsNV = (PFNWGLQUERYMAXSWAPGROUPSNVPROC)glewGetProcAddress((const GLubyte*)"wglQueryMaxSwapGroupsNV")) == NULL) || r; - r = ((wglQuerySwapGroupNV = (PFNWGLQUERYSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"wglQuerySwapGroupNV")) == NULL) || r; - r = ((wglResetFrameCountNV = (PFNWGLRESETFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"wglResetFrameCountNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_swap_group */ - -#ifdef WGL_NV_vertex_array_range - -static GLboolean _glewInit_WGL_NV_vertex_array_range (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglAllocateMemoryNV = (PFNWGLALLOCATEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"wglAllocateMemoryNV")) == NULL) || r; - r = ((wglFreeMemoryNV = (PFNWGLFREEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"wglFreeMemoryNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_vertex_array_range */ - -#ifdef WGL_NV_video_capture - -static GLboolean _glewInit_WGL_NV_video_capture (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBindVideoCaptureDeviceNV = (PFNWGLBINDVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglBindVideoCaptureDeviceNV")) == NULL) || r; - r = ((wglEnumerateVideoCaptureDevicesNV = (PFNWGLENUMERATEVIDEOCAPTUREDEVICESNVPROC)glewGetProcAddress((const GLubyte*)"wglEnumerateVideoCaptureDevicesNV")) == NULL) || r; - r = ((wglLockVideoCaptureDeviceNV = (PFNWGLLOCKVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglLockVideoCaptureDeviceNV")) == NULL) || r; - r = ((wglQueryVideoCaptureDeviceNV = (PFNWGLQUERYVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglQueryVideoCaptureDeviceNV")) == NULL) || r; - r = ((wglReleaseVideoCaptureDeviceNV = (PFNWGLRELEASEVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglReleaseVideoCaptureDeviceNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_video_capture */ - -#ifdef WGL_NV_video_output - -static GLboolean _glewInit_WGL_NV_video_output (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglBindVideoImageNV = (PFNWGLBINDVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"wglBindVideoImageNV")) == NULL) || r; - r = ((wglGetVideoDeviceNV = (PFNWGLGETVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglGetVideoDeviceNV")) == NULL) || r; - r = ((wglGetVideoInfoNV = (PFNWGLGETVIDEOINFONVPROC)glewGetProcAddress((const GLubyte*)"wglGetVideoInfoNV")) == NULL) || r; - r = ((wglReleaseVideoDeviceNV = (PFNWGLRELEASEVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"wglReleaseVideoDeviceNV")) == NULL) || r; - r = ((wglReleaseVideoImageNV = (PFNWGLRELEASEVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"wglReleaseVideoImageNV")) == NULL) || r; - r = ((wglSendPbufferToVideoNV = (PFNWGLSENDPBUFFERTOVIDEONVPROC)glewGetProcAddress((const GLubyte*)"wglSendPbufferToVideoNV")) == NULL) || r; - - return r; -} - -#endif /* WGL_NV_video_output */ - -#ifdef WGL_OML_sync_control - -static GLboolean _glewInit_WGL_OML_sync_control (WGLEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((wglGetMscRateOML = (PFNWGLGETMSCRATEOMLPROC)glewGetProcAddress((const GLubyte*)"wglGetMscRateOML")) == NULL) || r; - r = ((wglGetSyncValuesOML = (PFNWGLGETSYNCVALUESOMLPROC)glewGetProcAddress((const GLubyte*)"wglGetSyncValuesOML")) == NULL) || r; - r = ((wglSwapBuffersMscOML = (PFNWGLSWAPBUFFERSMSCOMLPROC)glewGetProcAddress((const GLubyte*)"wglSwapBuffersMscOML")) == NULL) || r; - r = ((wglSwapLayerBuffersMscOML = (PFNWGLSWAPLAYERBUFFERSMSCOMLPROC)glewGetProcAddress((const GLubyte*)"wglSwapLayerBuffersMscOML")) == NULL) || r; - r = ((wglWaitForMscOML = (PFNWGLWAITFORMSCOMLPROC)glewGetProcAddress((const GLubyte*)"wglWaitForMscOML")) == NULL) || r; - r = ((wglWaitForSbcOML = (PFNWGLWAITFORSBCOMLPROC)glewGetProcAddress((const GLubyte*)"wglWaitForSbcOML")) == NULL) || r; - - return r; -} - -#endif /* WGL_OML_sync_control */ - -/* ------------------------------------------------------------------------- */ - -static PFNWGLGETEXTENSIONSSTRINGARBPROC _wglewGetExtensionsStringARB = NULL; -static PFNWGLGETEXTENSIONSSTRINGEXTPROC _wglewGetExtensionsStringEXT = NULL; - -GLboolean GLEWAPIENTRY wglewGetExtension (const char* name) -{ - const GLubyte* start; - const GLubyte* end; - if (_wglewGetExtensionsStringARB == NULL) - if (_wglewGetExtensionsStringEXT == NULL) - return GL_FALSE; - else - start = (const GLubyte*)_wglewGetExtensionsStringEXT(); - else - start = (const GLubyte*)_wglewGetExtensionsStringARB(wglGetCurrentDC()); - if (start == 0) - return GL_FALSE; - end = start + _glewStrLen(start); - return _glewSearchExtension(name, start, end); -} - -GLenum GLEWAPIENTRY wglewContextInit (WGLEW_CONTEXT_ARG_DEF_LIST) -{ - GLboolean crippled; - const GLubyte* extStart; - const GLubyte* extEnd; - /* find wgl extension string query functions */ - _wglewGetExtensionsStringARB = (PFNWGLGETEXTENSIONSSTRINGARBPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringARB"); - _wglewGetExtensionsStringEXT = (PFNWGLGETEXTENSIONSSTRINGEXTPROC)glewGetProcAddress((const GLubyte*)"wglGetExtensionsStringEXT"); - /* query wgl extension string */ - if (_wglewGetExtensionsStringARB == NULL) - if (_wglewGetExtensionsStringEXT == NULL) - extStart = (const GLubyte*)""; - else - extStart = (const GLubyte*)_wglewGetExtensionsStringEXT(); - else - extStart = (const GLubyte*)_wglewGetExtensionsStringARB(wglGetCurrentDC()); - extEnd = extStart + _glewStrLen(extStart); - /* initialize extensions */ - crippled = _wglewGetExtensionsStringARB == NULL && _wglewGetExtensionsStringEXT == NULL; -#ifdef WGL_3DFX_multisample - CONST_CAST(WGLEW_3DFX_multisample) = _glewSearchExtension("WGL_3DFX_multisample", extStart, extEnd); -#endif /* WGL_3DFX_multisample */ -#ifdef WGL_3DL_stereo_control - CONST_CAST(WGLEW_3DL_stereo_control) = _glewSearchExtension("WGL_3DL_stereo_control", extStart, extEnd); - if (glewExperimental || WGLEW_3DL_stereo_control|| crippled) CONST_CAST(WGLEW_3DL_stereo_control)= !_glewInit_WGL_3DL_stereo_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_3DL_stereo_control */ -#ifdef WGL_AMD_gpu_association - CONST_CAST(WGLEW_AMD_gpu_association) = _glewSearchExtension("WGL_AMD_gpu_association", extStart, extEnd); - if (glewExperimental || WGLEW_AMD_gpu_association|| crippled) CONST_CAST(WGLEW_AMD_gpu_association)= !_glewInit_WGL_AMD_gpu_association(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_AMD_gpu_association */ -#ifdef WGL_ARB_buffer_region - CONST_CAST(WGLEW_ARB_buffer_region) = _glewSearchExtension("WGL_ARB_buffer_region", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_buffer_region|| crippled) CONST_CAST(WGLEW_ARB_buffer_region)= !_glewInit_WGL_ARB_buffer_region(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_buffer_region */ -#ifdef WGL_ARB_create_context - CONST_CAST(WGLEW_ARB_create_context) = _glewSearchExtension("WGL_ARB_create_context", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_create_context|| crippled) CONST_CAST(WGLEW_ARB_create_context)= !_glewInit_WGL_ARB_create_context(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_create_context */ -#ifdef WGL_ARB_create_context_profile - CONST_CAST(WGLEW_ARB_create_context_profile) = _glewSearchExtension("WGL_ARB_create_context_profile", extStart, extEnd); -#endif /* WGL_ARB_create_context_profile */ -#ifdef WGL_ARB_create_context_robustness - CONST_CAST(WGLEW_ARB_create_context_robustness) = _glewSearchExtension("WGL_ARB_create_context_robustness", extStart, extEnd); -#endif /* WGL_ARB_create_context_robustness */ -#ifdef WGL_ARB_extensions_string - CONST_CAST(WGLEW_ARB_extensions_string) = _glewSearchExtension("WGL_ARB_extensions_string", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_extensions_string|| crippled) CONST_CAST(WGLEW_ARB_extensions_string)= !_glewInit_WGL_ARB_extensions_string(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_extensions_string */ -#ifdef WGL_ARB_framebuffer_sRGB - CONST_CAST(WGLEW_ARB_framebuffer_sRGB) = _glewSearchExtension("WGL_ARB_framebuffer_sRGB", extStart, extEnd); -#endif /* WGL_ARB_framebuffer_sRGB */ -#ifdef WGL_ARB_make_current_read - CONST_CAST(WGLEW_ARB_make_current_read) = _glewSearchExtension("WGL_ARB_make_current_read", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_make_current_read|| crippled) CONST_CAST(WGLEW_ARB_make_current_read)= !_glewInit_WGL_ARB_make_current_read(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_make_current_read */ -#ifdef WGL_ARB_multisample - CONST_CAST(WGLEW_ARB_multisample) = _glewSearchExtension("WGL_ARB_multisample", extStart, extEnd); -#endif /* WGL_ARB_multisample */ -#ifdef WGL_ARB_pbuffer - CONST_CAST(WGLEW_ARB_pbuffer) = _glewSearchExtension("WGL_ARB_pbuffer", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_pbuffer|| crippled) CONST_CAST(WGLEW_ARB_pbuffer)= !_glewInit_WGL_ARB_pbuffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_pbuffer */ -#ifdef WGL_ARB_pixel_format - CONST_CAST(WGLEW_ARB_pixel_format) = _glewSearchExtension("WGL_ARB_pixel_format", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_pixel_format|| crippled) CONST_CAST(WGLEW_ARB_pixel_format)= !_glewInit_WGL_ARB_pixel_format(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_pixel_format */ -#ifdef WGL_ARB_pixel_format_float - CONST_CAST(WGLEW_ARB_pixel_format_float) = _glewSearchExtension("WGL_ARB_pixel_format_float", extStart, extEnd); -#endif /* WGL_ARB_pixel_format_float */ -#ifdef WGL_ARB_render_texture - CONST_CAST(WGLEW_ARB_render_texture) = _glewSearchExtension("WGL_ARB_render_texture", extStart, extEnd); - if (glewExperimental || WGLEW_ARB_render_texture|| crippled) CONST_CAST(WGLEW_ARB_render_texture)= !_glewInit_WGL_ARB_render_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_ARB_render_texture */ -#ifdef WGL_ARB_robustness_application_isolation - CONST_CAST(WGLEW_ARB_robustness_application_isolation) = _glewSearchExtension("WGL_ARB_robustness_application_isolation", extStart, extEnd); -#endif /* WGL_ARB_robustness_application_isolation */ -#ifdef WGL_ARB_robustness_share_group_isolation - CONST_CAST(WGLEW_ARB_robustness_share_group_isolation) = _glewSearchExtension("WGL_ARB_robustness_share_group_isolation", extStart, extEnd); -#endif /* WGL_ARB_robustness_share_group_isolation */ -#ifdef WGL_ATI_pixel_format_float - CONST_CAST(WGLEW_ATI_pixel_format_float) = _glewSearchExtension("WGL_ATI_pixel_format_float", extStart, extEnd); -#endif /* WGL_ATI_pixel_format_float */ -#ifdef WGL_ATI_render_texture_rectangle - CONST_CAST(WGLEW_ATI_render_texture_rectangle) = _glewSearchExtension("WGL_ATI_render_texture_rectangle", extStart, extEnd); -#endif /* WGL_ATI_render_texture_rectangle */ -#ifdef WGL_EXT_create_context_es2_profile - CONST_CAST(WGLEW_EXT_create_context_es2_profile) = _glewSearchExtension("WGL_EXT_create_context_es2_profile", extStart, extEnd); -#endif /* WGL_EXT_create_context_es2_profile */ -#ifdef WGL_EXT_create_context_es_profile - CONST_CAST(WGLEW_EXT_create_context_es_profile) = _glewSearchExtension("WGL_EXT_create_context_es_profile", extStart, extEnd); -#endif /* WGL_EXT_create_context_es_profile */ -#ifdef WGL_EXT_depth_float - CONST_CAST(WGLEW_EXT_depth_float) = _glewSearchExtension("WGL_EXT_depth_float", extStart, extEnd); -#endif /* WGL_EXT_depth_float */ -#ifdef WGL_EXT_display_color_table - CONST_CAST(WGLEW_EXT_display_color_table) = _glewSearchExtension("WGL_EXT_display_color_table", extStart, extEnd); - if (glewExperimental || WGLEW_EXT_display_color_table|| crippled) CONST_CAST(WGLEW_EXT_display_color_table)= !_glewInit_WGL_EXT_display_color_table(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_EXT_display_color_table */ -#ifdef WGL_EXT_extensions_string - CONST_CAST(WGLEW_EXT_extensions_string) = _glewSearchExtension("WGL_EXT_extensions_string", extStart, extEnd); - if (glewExperimental || WGLEW_EXT_extensions_string|| crippled) CONST_CAST(WGLEW_EXT_extensions_string)= !_glewInit_WGL_EXT_extensions_string(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_EXT_extensions_string */ -#ifdef WGL_EXT_framebuffer_sRGB - CONST_CAST(WGLEW_EXT_framebuffer_sRGB) = _glewSearchExtension("WGL_EXT_framebuffer_sRGB", extStart, extEnd); -#endif /* WGL_EXT_framebuffer_sRGB */ -#ifdef WGL_EXT_make_current_read - CONST_CAST(WGLEW_EXT_make_current_read) = _glewSearchExtension("WGL_EXT_make_current_read", extStart, extEnd); - if (glewExperimental || WGLEW_EXT_make_current_read|| crippled) CONST_CAST(WGLEW_EXT_make_current_read)= !_glewInit_WGL_EXT_make_current_read(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_EXT_make_current_read */ -#ifdef WGL_EXT_multisample - CONST_CAST(WGLEW_EXT_multisample) = _glewSearchExtension("WGL_EXT_multisample", extStart, extEnd); -#endif /* WGL_EXT_multisample */ -#ifdef WGL_EXT_pbuffer - CONST_CAST(WGLEW_EXT_pbuffer) = _glewSearchExtension("WGL_EXT_pbuffer", extStart, extEnd); - if (glewExperimental || WGLEW_EXT_pbuffer|| crippled) CONST_CAST(WGLEW_EXT_pbuffer)= !_glewInit_WGL_EXT_pbuffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_EXT_pbuffer */ -#ifdef WGL_EXT_pixel_format - CONST_CAST(WGLEW_EXT_pixel_format) = _glewSearchExtension("WGL_EXT_pixel_format", extStart, extEnd); - if (glewExperimental || WGLEW_EXT_pixel_format|| crippled) CONST_CAST(WGLEW_EXT_pixel_format)= !_glewInit_WGL_EXT_pixel_format(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_EXT_pixel_format */ -#ifdef WGL_EXT_pixel_format_packed_float - CONST_CAST(WGLEW_EXT_pixel_format_packed_float) = _glewSearchExtension("WGL_EXT_pixel_format_packed_float", extStart, extEnd); -#endif /* WGL_EXT_pixel_format_packed_float */ -#ifdef WGL_EXT_swap_control - CONST_CAST(WGLEW_EXT_swap_control) = _glewSearchExtension("WGL_EXT_swap_control", extStart, extEnd); - if (glewExperimental || WGLEW_EXT_swap_control|| crippled) CONST_CAST(WGLEW_EXT_swap_control)= !_glewInit_WGL_EXT_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_EXT_swap_control */ -#ifdef WGL_EXT_swap_control_tear - CONST_CAST(WGLEW_EXT_swap_control_tear) = _glewSearchExtension("WGL_EXT_swap_control_tear", extStart, extEnd); -#endif /* WGL_EXT_swap_control_tear */ -#ifdef WGL_I3D_digital_video_control - CONST_CAST(WGLEW_I3D_digital_video_control) = _glewSearchExtension("WGL_I3D_digital_video_control", extStart, extEnd); - if (glewExperimental || WGLEW_I3D_digital_video_control|| crippled) CONST_CAST(WGLEW_I3D_digital_video_control)= !_glewInit_WGL_I3D_digital_video_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_I3D_digital_video_control */ -#ifdef WGL_I3D_gamma - CONST_CAST(WGLEW_I3D_gamma) = _glewSearchExtension("WGL_I3D_gamma", extStart, extEnd); - if (glewExperimental || WGLEW_I3D_gamma|| crippled) CONST_CAST(WGLEW_I3D_gamma)= !_glewInit_WGL_I3D_gamma(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_I3D_gamma */ -#ifdef WGL_I3D_genlock - CONST_CAST(WGLEW_I3D_genlock) = _glewSearchExtension("WGL_I3D_genlock", extStart, extEnd); - if (glewExperimental || WGLEW_I3D_genlock|| crippled) CONST_CAST(WGLEW_I3D_genlock)= !_glewInit_WGL_I3D_genlock(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_I3D_genlock */ -#ifdef WGL_I3D_image_buffer - CONST_CAST(WGLEW_I3D_image_buffer) = _glewSearchExtension("WGL_I3D_image_buffer", extStart, extEnd); - if (glewExperimental || WGLEW_I3D_image_buffer|| crippled) CONST_CAST(WGLEW_I3D_image_buffer)= !_glewInit_WGL_I3D_image_buffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_I3D_image_buffer */ -#ifdef WGL_I3D_swap_frame_lock - CONST_CAST(WGLEW_I3D_swap_frame_lock) = _glewSearchExtension("WGL_I3D_swap_frame_lock", extStart, extEnd); - if (glewExperimental || WGLEW_I3D_swap_frame_lock|| crippled) CONST_CAST(WGLEW_I3D_swap_frame_lock)= !_glewInit_WGL_I3D_swap_frame_lock(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_I3D_swap_frame_lock */ -#ifdef WGL_I3D_swap_frame_usage - CONST_CAST(WGLEW_I3D_swap_frame_usage) = _glewSearchExtension("WGL_I3D_swap_frame_usage", extStart, extEnd); - if (glewExperimental || WGLEW_I3D_swap_frame_usage|| crippled) CONST_CAST(WGLEW_I3D_swap_frame_usage)= !_glewInit_WGL_I3D_swap_frame_usage(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_I3D_swap_frame_usage */ -#ifdef WGL_NV_DX_interop - CONST_CAST(WGLEW_NV_DX_interop) = _glewSearchExtension("WGL_NV_DX_interop", extStart, extEnd); - if (glewExperimental || WGLEW_NV_DX_interop|| crippled) CONST_CAST(WGLEW_NV_DX_interop)= !_glewInit_WGL_NV_DX_interop(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_DX_interop */ -#ifdef WGL_NV_DX_interop2 - CONST_CAST(WGLEW_NV_DX_interop2) = _glewSearchExtension("WGL_NV_DX_interop2", extStart, extEnd); -#endif /* WGL_NV_DX_interop2 */ -#ifdef WGL_NV_copy_image - CONST_CAST(WGLEW_NV_copy_image) = _glewSearchExtension("WGL_NV_copy_image", extStart, extEnd); - if (glewExperimental || WGLEW_NV_copy_image|| crippled) CONST_CAST(WGLEW_NV_copy_image)= !_glewInit_WGL_NV_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_copy_image */ -#ifdef WGL_NV_float_buffer - CONST_CAST(WGLEW_NV_float_buffer) = _glewSearchExtension("WGL_NV_float_buffer", extStart, extEnd); -#endif /* WGL_NV_float_buffer */ -#ifdef WGL_NV_gpu_affinity - CONST_CAST(WGLEW_NV_gpu_affinity) = _glewSearchExtension("WGL_NV_gpu_affinity", extStart, extEnd); - if (glewExperimental || WGLEW_NV_gpu_affinity|| crippled) CONST_CAST(WGLEW_NV_gpu_affinity)= !_glewInit_WGL_NV_gpu_affinity(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_gpu_affinity */ -#ifdef WGL_NV_multisample_coverage - CONST_CAST(WGLEW_NV_multisample_coverage) = _glewSearchExtension("WGL_NV_multisample_coverage", extStart, extEnd); -#endif /* WGL_NV_multisample_coverage */ -#ifdef WGL_NV_present_video - CONST_CAST(WGLEW_NV_present_video) = _glewSearchExtension("WGL_NV_present_video", extStart, extEnd); - if (glewExperimental || WGLEW_NV_present_video|| crippled) CONST_CAST(WGLEW_NV_present_video)= !_glewInit_WGL_NV_present_video(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_present_video */ -#ifdef WGL_NV_render_depth_texture - CONST_CAST(WGLEW_NV_render_depth_texture) = _glewSearchExtension("WGL_NV_render_depth_texture", extStart, extEnd); -#endif /* WGL_NV_render_depth_texture */ -#ifdef WGL_NV_render_texture_rectangle - CONST_CAST(WGLEW_NV_render_texture_rectangle) = _glewSearchExtension("WGL_NV_render_texture_rectangle", extStart, extEnd); -#endif /* WGL_NV_render_texture_rectangle */ -#ifdef WGL_NV_swap_group - CONST_CAST(WGLEW_NV_swap_group) = _glewSearchExtension("WGL_NV_swap_group", extStart, extEnd); - if (glewExperimental || WGLEW_NV_swap_group|| crippled) CONST_CAST(WGLEW_NV_swap_group)= !_glewInit_WGL_NV_swap_group(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_swap_group */ -#ifdef WGL_NV_vertex_array_range - CONST_CAST(WGLEW_NV_vertex_array_range) = _glewSearchExtension("WGL_NV_vertex_array_range", extStart, extEnd); - if (glewExperimental || WGLEW_NV_vertex_array_range|| crippled) CONST_CAST(WGLEW_NV_vertex_array_range)= !_glewInit_WGL_NV_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_vertex_array_range */ -#ifdef WGL_NV_video_capture - CONST_CAST(WGLEW_NV_video_capture) = _glewSearchExtension("WGL_NV_video_capture", extStart, extEnd); - if (glewExperimental || WGLEW_NV_video_capture|| crippled) CONST_CAST(WGLEW_NV_video_capture)= !_glewInit_WGL_NV_video_capture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_video_capture */ -#ifdef WGL_NV_video_output - CONST_CAST(WGLEW_NV_video_output) = _glewSearchExtension("WGL_NV_video_output", extStart, extEnd); - if (glewExperimental || WGLEW_NV_video_output|| crippled) CONST_CAST(WGLEW_NV_video_output)= !_glewInit_WGL_NV_video_output(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_NV_video_output */ -#ifdef WGL_OML_sync_control - CONST_CAST(WGLEW_OML_sync_control) = _glewSearchExtension("WGL_OML_sync_control", extStart, extEnd); - if (glewExperimental || WGLEW_OML_sync_control|| crippled) CONST_CAST(WGLEW_OML_sync_control)= !_glewInit_WGL_OML_sync_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* WGL_OML_sync_control */ - - return GLEW_OK; -} - -#elif !defined(__ANDROID__) && !defined(__native_client__) && (!defined(__APPLE__) || defined(GLEW_APPLE_GLX)) - - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -PFNGLXGETPROCADDRESSARBPROC __glewXGetProcAddressARB = NULL; -PFNGLXQUERYEXTENSION __glewXQueryExtension=NULL; -PFNGLXQUERYVERSION __glewXQueryVersion=NULL; -PFNGLXGETCONFIG __glewXGetConfig=NULL; -PFNGLXCHOOSEVISUAL __glewXChooseVisual=NULL; -PFNGLXCREATECONTEXT __glewXCreateContext=NULL; -PFNGLXDESTROYCONTEXT __glewXDestroyContext=NULL; -PFNGLXISDIRECT __glewXIsDirect=NULL; -PFNGLXMAKECURRENT __glewXMakeCurrent=NULL; -PFNGLXQUERYEXTENSIONSSTRING __glewXQueryExtensionsString=NULL; -PFNGLXGETCLIENTSTRING __glewXGetClientString=NULL; -PFNGLXQUERYSERVERSTRING __glewXQueryServerString=NULL; -PFNGLXSWAPBUFFERS __glewXSwapBuffers=NULL; - -#endif//GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -PFNGLXGETCURRENTDISPLAYPROC __glewXGetCurrentDisplay = NULL; - -PFNGLXCHOOSEFBCONFIGPROC __glewXChooseFBConfig = NULL; -PFNGLXCREATENEWCONTEXTPROC __glewXCreateNewContext = NULL; -PFNGLXCREATEPBUFFERPROC __glewXCreatePbuffer = NULL; -PFNGLXCREATEPIXMAPPROC __glewXCreatePixmap = NULL; -PFNGLXCREATEWINDOWPROC __glewXCreateWindow = NULL; -PFNGLXDESTROYPBUFFERPROC __glewXDestroyPbuffer = NULL; -PFNGLXDESTROYPIXMAPPROC __glewXDestroyPixmap = NULL; -PFNGLXDESTROYWINDOWPROC __glewXDestroyWindow = NULL; -PFNGLXGETCURRENTREADDRAWABLEPROC __glewXGetCurrentReadDrawable = NULL; -PFNGLXGETFBCONFIGATTRIBPROC __glewXGetFBConfigAttrib = NULL; -PFNGLXGETFBCONFIGSPROC __glewXGetFBConfigs = NULL; -PFNGLXGETSELECTEDEVENTPROC __glewXGetSelectedEvent = NULL; -PFNGLXGETVISUALFROMFBCONFIGPROC __glewXGetVisualFromFBConfig = NULL; -PFNGLXMAKECONTEXTCURRENTPROC __glewXMakeContextCurrent = NULL; -PFNGLXQUERYCONTEXTPROC __glewXQueryContext = NULL; -PFNGLXQUERYDRAWABLEPROC __glewXQueryDrawable = NULL; -PFNGLXSELECTEVENTPROC __glewXSelectEvent = NULL; - -PFNGLXBLITCONTEXTFRAMEBUFFERAMDPROC __glewXBlitContextFramebufferAMD = NULL; -PFNGLXCREATEASSOCIATEDCONTEXTAMDPROC __glewXCreateAssociatedContextAMD = NULL; -PFNGLXCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC __glewXCreateAssociatedContextAttribsAMD = NULL; -PFNGLXDELETEASSOCIATEDCONTEXTAMDPROC __glewXDeleteAssociatedContextAMD = NULL; -PFNGLXGETCONTEXTGPUIDAMDPROC __glewXGetContextGPUIDAMD = NULL; -PFNGLXGETCURRENTASSOCIATEDCONTEXTAMDPROC __glewXGetCurrentAssociatedContextAMD = NULL; -PFNGLXGETGPUIDSAMDPROC __glewXGetGPUIDsAMD = NULL; -PFNGLXGETGPUINFOAMDPROC __glewXGetGPUInfoAMD = NULL; -PFNGLXMAKEASSOCIATEDCONTEXTCURRENTAMDPROC __glewXMakeAssociatedContextCurrentAMD = NULL; - -PFNGLXCREATECONTEXTATTRIBSARBPROC __glewXCreateContextAttribsARB = NULL; - -PFNGLXBINDTEXIMAGEATIPROC __glewXBindTexImageATI = NULL; -PFNGLXDRAWABLEATTRIBATIPROC __glewXDrawableAttribATI = NULL; -PFNGLXRELEASETEXIMAGEATIPROC __glewXReleaseTexImageATI = NULL; - -PFNGLXFREECONTEXTEXTPROC __glewXFreeContextEXT = NULL; -PFNGLXGETCONTEXTIDEXTPROC __glewXGetContextIDEXT = NULL; -PFNGLXIMPORTCONTEXTEXTPROC __glewXImportContextEXT = NULL; -PFNGLXQUERYCONTEXTINFOEXTPROC __glewXQueryContextInfoEXT = NULL; - -PFNGLXSWAPINTERVALEXTPROC __glewXSwapIntervalEXT = NULL; - -PFNGLXBINDTEXIMAGEEXTPROC __glewXBindTexImageEXT = NULL; -PFNGLXRELEASETEXIMAGEEXTPROC __glewXReleaseTexImageEXT = NULL; - -PFNGLXGETAGPOFFSETMESAPROC __glewXGetAGPOffsetMESA = NULL; - -PFNGLXCOPYSUBBUFFERMESAPROC __glewXCopySubBufferMESA = NULL; - -PFNGLXCREATEGLXPIXMAPMESAPROC __glewXCreateGLXPixmapMESA = NULL; - -PFNGLXRELEASEBUFFERSMESAPROC __glewXReleaseBuffersMESA = NULL; - -PFNGLXSET3DFXMODEMESAPROC __glewXSet3DfxModeMESA = NULL; - -PFNGLXGETSWAPINTERVALMESAPROC __glewXGetSwapIntervalMESA = NULL; -PFNGLXSWAPINTERVALMESAPROC __glewXSwapIntervalMESA = NULL; - -PFNGLXCOPYIMAGESUBDATANVPROC __glewXCopyImageSubDataNV = NULL; - -PFNGLXBINDVIDEODEVICENVPROC __glewXBindVideoDeviceNV = NULL; -PFNGLXENUMERATEVIDEODEVICESNVPROC __glewXEnumerateVideoDevicesNV = NULL; - -PFNGLXBINDSWAPBARRIERNVPROC __glewXBindSwapBarrierNV = NULL; -PFNGLXJOINSWAPGROUPNVPROC __glewXJoinSwapGroupNV = NULL; -PFNGLXQUERYFRAMECOUNTNVPROC __glewXQueryFrameCountNV = NULL; -PFNGLXQUERYMAXSWAPGROUPSNVPROC __glewXQueryMaxSwapGroupsNV = NULL; -PFNGLXQUERYSWAPGROUPNVPROC __glewXQuerySwapGroupNV = NULL; -PFNGLXRESETFRAMECOUNTNVPROC __glewXResetFrameCountNV = NULL; - -PFNGLXALLOCATEMEMORYNVPROC __glewXAllocateMemoryNV = NULL; -PFNGLXFREEMEMORYNVPROC __glewXFreeMemoryNV = NULL; - -PFNGLXBINDVIDEOCAPTUREDEVICENVPROC __glewXBindVideoCaptureDeviceNV = NULL; -PFNGLXENUMERATEVIDEOCAPTUREDEVICESNVPROC __glewXEnumerateVideoCaptureDevicesNV = NULL; -PFNGLXLOCKVIDEOCAPTUREDEVICENVPROC __glewXLockVideoCaptureDeviceNV = NULL; -PFNGLXQUERYVIDEOCAPTUREDEVICENVPROC __glewXQueryVideoCaptureDeviceNV = NULL; -PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC __glewXReleaseVideoCaptureDeviceNV = NULL; - -PFNGLXBINDVIDEOIMAGENVPROC __glewXBindVideoImageNV = NULL; -PFNGLXGETVIDEODEVICENVPROC __glewXGetVideoDeviceNV = NULL; -PFNGLXGETVIDEOINFONVPROC __glewXGetVideoInfoNV = NULL; -PFNGLXRELEASEVIDEODEVICENVPROC __glewXReleaseVideoDeviceNV = NULL; -PFNGLXRELEASEVIDEOIMAGENVPROC __glewXReleaseVideoImageNV = NULL; -PFNGLXSENDPBUFFERTOVIDEONVPROC __glewXSendPbufferToVideoNV = NULL; - -PFNGLXGETMSCRATEOMLPROC __glewXGetMscRateOML = NULL; -PFNGLXGETSYNCVALUESOMLPROC __glewXGetSyncValuesOML = NULL; -PFNGLXSWAPBUFFERSMSCOMLPROC __glewXSwapBuffersMscOML = NULL; -PFNGLXWAITFORMSCOMLPROC __glewXWaitForMscOML = NULL; -PFNGLXWAITFORSBCOMLPROC __glewXWaitForSbcOML = NULL; - -PFNGLXCHOOSEFBCONFIGSGIXPROC __glewXChooseFBConfigSGIX = NULL; -PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC __glewXCreateContextWithConfigSGIX = NULL; -PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC __glewXCreateGLXPixmapWithConfigSGIX = NULL; -PFNGLXGETFBCONFIGATTRIBSGIXPROC __glewXGetFBConfigAttribSGIX = NULL; -PFNGLXGETFBCONFIGFROMVISUALSGIXPROC __glewXGetFBConfigFromVisualSGIX = NULL; -PFNGLXGETVISUALFROMFBCONFIGSGIXPROC __glewXGetVisualFromFBConfigSGIX = NULL; - -PFNGLXBINDHYPERPIPESGIXPROC __glewXBindHyperpipeSGIX = NULL; -PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC __glewXDestroyHyperpipeConfigSGIX = NULL; -PFNGLXHYPERPIPEATTRIBSGIXPROC __glewXHyperpipeAttribSGIX = NULL; -PFNGLXHYPERPIPECONFIGSGIXPROC __glewXHyperpipeConfigSGIX = NULL; -PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC __glewXQueryHyperpipeAttribSGIX = NULL; -PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC __glewXQueryHyperpipeBestAttribSGIX = NULL; -PFNGLXQUERYHYPERPIPECONFIGSGIXPROC __glewXQueryHyperpipeConfigSGIX = NULL; -PFNGLXQUERYHYPERPIPENETWORKSGIXPROC __glewXQueryHyperpipeNetworkSGIX = NULL; - -PFNGLXCREATEGLXPBUFFERSGIXPROC __glewXCreateGLXPbufferSGIX = NULL; -PFNGLXDESTROYGLXPBUFFERSGIXPROC __glewXDestroyGLXPbufferSGIX = NULL; -PFNGLXGETSELECTEDEVENTSGIXPROC __glewXGetSelectedEventSGIX = NULL; -PFNGLXQUERYGLXPBUFFERSGIXPROC __glewXQueryGLXPbufferSGIX = NULL; -PFNGLXSELECTEVENTSGIXPROC __glewXSelectEventSGIX = NULL; - -PFNGLXBINDSWAPBARRIERSGIXPROC __glewXBindSwapBarrierSGIX = NULL; -PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC __glewXQueryMaxSwapBarriersSGIX = NULL; - -PFNGLXJOINSWAPGROUPSGIXPROC __glewXJoinSwapGroupSGIX = NULL; - -PFNGLXBINDCHANNELTOWINDOWSGIXPROC __glewXBindChannelToWindowSGIX = NULL; -PFNGLXCHANNELRECTSGIXPROC __glewXChannelRectSGIX = NULL; -PFNGLXCHANNELRECTSYNCSGIXPROC __glewXChannelRectSyncSGIX = NULL; -PFNGLXQUERYCHANNELDELTASSGIXPROC __glewXQueryChannelDeltasSGIX = NULL; -PFNGLXQUERYCHANNELRECTSGIXPROC __glewXQueryChannelRectSGIX = NULL; - -PFNGLXCUSHIONSGIPROC __glewXCushionSGI = NULL; - -PFNGLXGETCURRENTREADDRAWABLESGIPROC __glewXGetCurrentReadDrawableSGI = NULL; -PFNGLXMAKECURRENTREADSGIPROC __glewXMakeCurrentReadSGI = NULL; - -PFNGLXSWAPINTERVALSGIPROC __glewXSwapIntervalSGI = NULL; - -PFNGLXGETVIDEOSYNCSGIPROC __glewXGetVideoSyncSGI = NULL; -PFNGLXWAITVIDEOSYNCSGIPROC __glewXWaitVideoSyncSGI = NULL; - -PFNGLXGETTRANSPARENTINDEXSUNPROC __glewXGetTransparentIndexSUN = NULL; - -PFNGLXGETVIDEORESIZESUNPROC __glewXGetVideoResizeSUN = NULL; -PFNGLXVIDEORESIZESUNPROC __glewXVideoResizeSUN = NULL; - -#if !defined(GLEW_MX) - -GLboolean __GLXEW_VERSION_1_0 = GL_FALSE; -GLboolean __GLXEW_VERSION_1_1 = GL_FALSE; -GLboolean __GLXEW_VERSION_1_2 = GL_FALSE; -GLboolean __GLXEW_VERSION_1_3 = GL_FALSE; -GLboolean __GLXEW_VERSION_1_4 = GL_FALSE; -GLboolean __GLXEW_3DFX_multisample = GL_FALSE; -GLboolean __GLXEW_AMD_gpu_association = GL_FALSE; -GLboolean __GLXEW_ARB_create_context = GL_FALSE; -GLboolean __GLXEW_ARB_create_context_profile = GL_FALSE; -GLboolean __GLXEW_ARB_create_context_robustness = GL_FALSE; -GLboolean __GLXEW_ARB_fbconfig_float = GL_FALSE; -GLboolean __GLXEW_ARB_framebuffer_sRGB = GL_FALSE; -GLboolean __GLXEW_ARB_get_proc_address = GL_FALSE; -GLboolean __GLXEW_ARB_multisample = GL_FALSE; -GLboolean __GLXEW_ARB_robustness_application_isolation = GL_FALSE; -GLboolean __GLXEW_ARB_robustness_share_group_isolation = GL_FALSE; -GLboolean __GLXEW_ARB_vertex_buffer_object = GL_FALSE; -GLboolean __GLXEW_ATI_pixel_format_float = GL_FALSE; -GLboolean __GLXEW_ATI_render_texture = GL_FALSE; -GLboolean __GLXEW_EXT_buffer_age = GL_FALSE; -GLboolean __GLXEW_EXT_create_context_es2_profile = GL_FALSE; -GLboolean __GLXEW_EXT_create_context_es_profile = GL_FALSE; -GLboolean __GLXEW_EXT_fbconfig_packed_float = GL_FALSE; -GLboolean __GLXEW_EXT_framebuffer_sRGB = GL_FALSE; -GLboolean __GLXEW_EXT_import_context = GL_FALSE; -GLboolean __GLXEW_EXT_scene_marker = GL_FALSE; -GLboolean __GLXEW_EXT_swap_control = GL_FALSE; -GLboolean __GLXEW_EXT_swap_control_tear = GL_FALSE; -GLboolean __GLXEW_EXT_texture_from_pixmap = GL_FALSE; -GLboolean __GLXEW_EXT_visual_info = GL_FALSE; -GLboolean __GLXEW_EXT_visual_rating = GL_FALSE; -GLboolean __GLXEW_INTEL_swap_event = GL_FALSE; -GLboolean __GLXEW_MESA_agp_offset = GL_FALSE; -GLboolean __GLXEW_MESA_copy_sub_buffer = GL_FALSE; -GLboolean __GLXEW_MESA_pixmap_colormap = GL_FALSE; -GLboolean __GLXEW_MESA_release_buffers = GL_FALSE; -GLboolean __GLXEW_MESA_set_3dfx_mode = GL_FALSE; -GLboolean __GLXEW_MESA_swap_control = GL_FALSE; -GLboolean __GLXEW_NV_copy_image = GL_FALSE; -GLboolean __GLXEW_NV_float_buffer = GL_FALSE; -GLboolean __GLXEW_NV_multisample_coverage = GL_FALSE; -GLboolean __GLXEW_NV_present_video = GL_FALSE; -GLboolean __GLXEW_NV_swap_group = GL_FALSE; -GLboolean __GLXEW_NV_vertex_array_range = GL_FALSE; -GLboolean __GLXEW_NV_video_capture = GL_FALSE; -GLboolean __GLXEW_NV_video_output = GL_FALSE; -GLboolean __GLXEW_OML_swap_method = GL_FALSE; -GLboolean __GLXEW_OML_sync_control = GL_FALSE; -GLboolean __GLXEW_SGIS_blended_overlay = GL_FALSE; -GLboolean __GLXEW_SGIS_color_range = GL_FALSE; -GLboolean __GLXEW_SGIS_multisample = GL_FALSE; -GLboolean __GLXEW_SGIS_shared_multisample = GL_FALSE; -GLboolean __GLXEW_SGIX_fbconfig = GL_FALSE; -GLboolean __GLXEW_SGIX_hyperpipe = GL_FALSE; -GLboolean __GLXEW_SGIX_pbuffer = GL_FALSE; -GLboolean __GLXEW_SGIX_swap_barrier = GL_FALSE; -GLboolean __GLXEW_SGIX_swap_group = GL_FALSE; -GLboolean __GLXEW_SGIX_video_resize = GL_FALSE; -GLboolean __GLXEW_SGIX_visual_select_group = GL_FALSE; -GLboolean __GLXEW_SGI_cushion = GL_FALSE; -GLboolean __GLXEW_SGI_make_current_read = GL_FALSE; -GLboolean __GLXEW_SGI_swap_control = GL_FALSE; -GLboolean __GLXEW_SGI_video_sync = GL_FALSE; -GLboolean __GLXEW_SUN_get_transparent_index = GL_FALSE; -GLboolean __GLXEW_SUN_video_resize = GL_FALSE; - -#endif /* !GLEW_MX */ - -#ifdef GLX_VERSION_1_2 - -static GLboolean _glewInit_GLX_VERSION_1_2 (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetCurrentDisplay = (PFNGLXGETCURRENTDISPLAYPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentDisplay")) == NULL) || r; - - return r; -} - -#endif /* GLX_VERSION_1_2 */ - -#ifdef GLX_VERSION_1_3 - -static GLboolean _glewInit_GLX_VERSION_1_3 (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXChooseFBConfig = (PFNGLXCHOOSEFBCONFIGPROC)glewGetProcAddress((const GLubyte*)"glXChooseFBConfig")) == NULL) || r; - r = ((glXCreateNewContext = (PFNGLXCREATENEWCONTEXTPROC)glewGetProcAddress((const GLubyte*)"glXCreateNewContext")) == NULL) || r; - r = ((glXCreatePbuffer = (PFNGLXCREATEPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glXCreatePbuffer")) == NULL) || r; - r = ((glXCreatePixmap = (PFNGLXCREATEPIXMAPPROC)glewGetProcAddress((const GLubyte*)"glXCreatePixmap")) == NULL) || r; - r = ((glXCreateWindow = (PFNGLXCREATEWINDOWPROC)glewGetProcAddress((const GLubyte*)"glXCreateWindow")) == NULL) || r; - r = ((glXDestroyPbuffer = (PFNGLXDESTROYPBUFFERPROC)glewGetProcAddress((const GLubyte*)"glXDestroyPbuffer")) == NULL) || r; - r = ((glXDestroyPixmap = (PFNGLXDESTROYPIXMAPPROC)glewGetProcAddress((const GLubyte*)"glXDestroyPixmap")) == NULL) || r; - r = ((glXDestroyWindow = (PFNGLXDESTROYWINDOWPROC)glewGetProcAddress((const GLubyte*)"glXDestroyWindow")) == NULL) || r; - r = ((glXGetCurrentReadDrawable = (PFNGLXGETCURRENTREADDRAWABLEPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentReadDrawable")) == NULL) || r; - r = ((glXGetFBConfigAttrib = (PFNGLXGETFBCONFIGATTRIBPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigAttrib")) == NULL) || r; - r = ((glXGetFBConfigs = (PFNGLXGETFBCONFIGSPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigs")) == NULL) || r; - r = ((glXGetSelectedEvent = (PFNGLXGETSELECTEDEVENTPROC)glewGetProcAddress((const GLubyte*)"glXGetSelectedEvent")) == NULL) || r; - r = ((glXGetVisualFromFBConfig = (PFNGLXGETVISUALFROMFBCONFIGPROC)glewGetProcAddress((const GLubyte*)"glXGetVisualFromFBConfig")) == NULL) || r; - r = ((glXMakeContextCurrent = (PFNGLXMAKECONTEXTCURRENTPROC)glewGetProcAddress((const GLubyte*)"glXMakeContextCurrent")) == NULL) || r; - r = ((glXQueryContext = (PFNGLXQUERYCONTEXTPROC)glewGetProcAddress((const GLubyte*)"glXQueryContext")) == NULL) || r; - r = ((glXQueryDrawable = (PFNGLXQUERYDRAWABLEPROC)glewGetProcAddress((const GLubyte*)"glXQueryDrawable")) == NULL) || r; - r = ((glXSelectEvent = (PFNGLXSELECTEVENTPROC)glewGetProcAddress((const GLubyte*)"glXSelectEvent")) == NULL) || r; - - return r; -} - -#endif /* GLX_VERSION_1_3 */ - -#ifdef GLX_VERSION_1_4 - -#endif /* GLX_VERSION_1_4 */ - -#ifdef GLX_3DFX_multisample - -#endif /* GLX_3DFX_multisample */ - -#ifdef GLX_AMD_gpu_association - -static GLboolean _glewInit_GLX_AMD_gpu_association (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBlitContextFramebufferAMD = (PFNGLXBLITCONTEXTFRAMEBUFFERAMDPROC)glewGetProcAddress((const GLubyte*)"glXBlitContextFramebufferAMD")) == NULL) || r; - r = ((glXCreateAssociatedContextAMD = (PFNGLXCREATEASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"glXCreateAssociatedContextAMD")) == NULL) || r; - r = ((glXCreateAssociatedContextAttribsAMD = (PFNGLXCREATEASSOCIATEDCONTEXTATTRIBSAMDPROC)glewGetProcAddress((const GLubyte*)"glXCreateAssociatedContextAttribsAMD")) == NULL) || r; - r = ((glXDeleteAssociatedContextAMD = (PFNGLXDELETEASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"glXDeleteAssociatedContextAMD")) == NULL) || r; - r = ((glXGetContextGPUIDAMD = (PFNGLXGETCONTEXTGPUIDAMDPROC)glewGetProcAddress((const GLubyte*)"glXGetContextGPUIDAMD")) == NULL) || r; - r = ((glXGetCurrentAssociatedContextAMD = (PFNGLXGETCURRENTASSOCIATEDCONTEXTAMDPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentAssociatedContextAMD")) == NULL) || r; - r = ((glXGetGPUIDsAMD = (PFNGLXGETGPUIDSAMDPROC)glewGetProcAddress((const GLubyte*)"glXGetGPUIDsAMD")) == NULL) || r; - r = ((glXGetGPUInfoAMD = (PFNGLXGETGPUINFOAMDPROC)glewGetProcAddress((const GLubyte*)"glXGetGPUInfoAMD")) == NULL) || r; - r = ((glXMakeAssociatedContextCurrentAMD = (PFNGLXMAKEASSOCIATEDCONTEXTCURRENTAMDPROC)glewGetProcAddress((const GLubyte*)"glXMakeAssociatedContextCurrentAMD")) == NULL) || r; - - return r; -} - -#endif /* GLX_AMD_gpu_association */ - -#ifdef GLX_ARB_create_context - -static GLboolean _glewInit_GLX_ARB_create_context (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXCreateContextAttribsARB = (PFNGLXCREATECONTEXTATTRIBSARBPROC)glewGetProcAddress((const GLubyte*)"glXCreateContextAttribsARB")) == NULL) || r; - - return r; -} - -#endif /* GLX_ARB_create_context */ - -#ifdef GLX_ARB_create_context_profile - -#endif /* GLX_ARB_create_context_profile */ - -#ifdef GLX_ARB_create_context_robustness - -#endif /* GLX_ARB_create_context_robustness */ - -#ifdef GLX_ARB_fbconfig_float - -#endif /* GLX_ARB_fbconfig_float */ - -#ifdef GLX_ARB_framebuffer_sRGB - -#endif /* GLX_ARB_framebuffer_sRGB */ - -#ifdef GLX_ARB_get_proc_address - -#endif /* GLX_ARB_get_proc_address */ - -#ifdef GLX_ARB_multisample - -#endif /* GLX_ARB_multisample */ - -#ifdef GLX_ARB_robustness_application_isolation - -#endif /* GLX_ARB_robustness_application_isolation */ - -#ifdef GLX_ARB_robustness_share_group_isolation - -#endif /* GLX_ARB_robustness_share_group_isolation */ - -#ifdef GLX_ARB_vertex_buffer_object - -#endif /* GLX_ARB_vertex_buffer_object */ - -#ifdef GLX_ATI_pixel_format_float - -#endif /* GLX_ATI_pixel_format_float */ - -#ifdef GLX_ATI_render_texture - -static GLboolean _glewInit_GLX_ATI_render_texture (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindTexImageATI = (PFNGLXBINDTEXIMAGEATIPROC)glewGetProcAddress((const GLubyte*)"glXBindTexImageATI")) == NULL) || r; - r = ((glXDrawableAttribATI = (PFNGLXDRAWABLEATTRIBATIPROC)glewGetProcAddress((const GLubyte*)"glXDrawableAttribATI")) == NULL) || r; - r = ((glXReleaseTexImageATI = (PFNGLXRELEASETEXIMAGEATIPROC)glewGetProcAddress((const GLubyte*)"glXReleaseTexImageATI")) == NULL) || r; - - return r; -} - -#endif /* GLX_ATI_render_texture */ - -#ifdef GLX_EXT_buffer_age - -#endif /* GLX_EXT_buffer_age */ - -#ifdef GLX_EXT_create_context_es2_profile - -#endif /* GLX_EXT_create_context_es2_profile */ - -#ifdef GLX_EXT_create_context_es_profile - -#endif /* GLX_EXT_create_context_es_profile */ - -#ifdef GLX_EXT_fbconfig_packed_float - -#endif /* GLX_EXT_fbconfig_packed_float */ - -#ifdef GLX_EXT_framebuffer_sRGB - -#endif /* GLX_EXT_framebuffer_sRGB */ - -#ifdef GLX_EXT_import_context - -static GLboolean _glewInit_GLX_EXT_import_context (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXFreeContextEXT = (PFNGLXFREECONTEXTEXTPROC)glewGetProcAddress((const GLubyte*)"glXFreeContextEXT")) == NULL) || r; - r = ((glXGetContextIDEXT = (PFNGLXGETCONTEXTIDEXTPROC)glewGetProcAddress((const GLubyte*)"glXGetContextIDEXT")) == NULL) || r; - r = ((glXImportContextEXT = (PFNGLXIMPORTCONTEXTEXTPROC)glewGetProcAddress((const GLubyte*)"glXImportContextEXT")) == NULL) || r; - r = ((glXQueryContextInfoEXT = (PFNGLXQUERYCONTEXTINFOEXTPROC)glewGetProcAddress((const GLubyte*)"glXQueryContextInfoEXT")) == NULL) || r; - - return r; -} - -#endif /* GLX_EXT_import_context */ - -#ifdef GLX_EXT_scene_marker - -#endif /* GLX_EXT_scene_marker */ - -#ifdef GLX_EXT_swap_control - -static GLboolean _glewInit_GLX_EXT_swap_control (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXSwapIntervalEXT = (PFNGLXSWAPINTERVALEXTPROC)glewGetProcAddress((const GLubyte*)"glXSwapIntervalEXT")) == NULL) || r; - - return r; -} - -#endif /* GLX_EXT_swap_control */ - -#ifdef GLX_EXT_swap_control_tear - -#endif /* GLX_EXT_swap_control_tear */ - -#ifdef GLX_EXT_texture_from_pixmap - -static GLboolean _glewInit_GLX_EXT_texture_from_pixmap (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindTexImageEXT = (PFNGLXBINDTEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glXBindTexImageEXT")) == NULL) || r; - r = ((glXReleaseTexImageEXT = (PFNGLXRELEASETEXIMAGEEXTPROC)glewGetProcAddress((const GLubyte*)"glXReleaseTexImageEXT")) == NULL) || r; - - return r; -} - -#endif /* GLX_EXT_texture_from_pixmap */ - -#ifdef GLX_EXT_visual_info - -#endif /* GLX_EXT_visual_info */ - -#ifdef GLX_EXT_visual_rating - -#endif /* GLX_EXT_visual_rating */ - -#ifdef GLX_INTEL_swap_event - -#endif /* GLX_INTEL_swap_event */ - -#ifdef GLX_MESA_agp_offset - -static GLboolean _glewInit_GLX_MESA_agp_offset (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetAGPOffsetMESA = (PFNGLXGETAGPOFFSETMESAPROC)glewGetProcAddress((const GLubyte*)"glXGetAGPOffsetMESA")) == NULL) || r; - - return r; -} - -#endif /* GLX_MESA_agp_offset */ - -#ifdef GLX_MESA_copy_sub_buffer - -static GLboolean _glewInit_GLX_MESA_copy_sub_buffer (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXCopySubBufferMESA = (PFNGLXCOPYSUBBUFFERMESAPROC)glewGetProcAddress((const GLubyte*)"glXCopySubBufferMESA")) == NULL) || r; - - return r; -} - -#endif /* GLX_MESA_copy_sub_buffer */ - -#ifdef GLX_MESA_pixmap_colormap - -static GLboolean _glewInit_GLX_MESA_pixmap_colormap (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXCreateGLXPixmapMESA = (PFNGLXCREATEGLXPIXMAPMESAPROC)glewGetProcAddress((const GLubyte*)"glXCreateGLXPixmapMESA")) == NULL) || r; - - return r; -} - -#endif /* GLX_MESA_pixmap_colormap */ - -#ifdef GLX_MESA_release_buffers - -static GLboolean _glewInit_GLX_MESA_release_buffers (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXReleaseBuffersMESA = (PFNGLXRELEASEBUFFERSMESAPROC)glewGetProcAddress((const GLubyte*)"glXReleaseBuffersMESA")) == NULL) || r; - - return r; -} - -#endif /* GLX_MESA_release_buffers */ - -#ifdef GLX_MESA_set_3dfx_mode - -static GLboolean _glewInit_GLX_MESA_set_3dfx_mode (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXSet3DfxModeMESA = (PFNGLXSET3DFXMODEMESAPROC)glewGetProcAddress((const GLubyte*)"glXSet3DfxModeMESA")) == NULL) || r; - - return r; -} - -#endif /* GLX_MESA_set_3dfx_mode */ - -#ifdef GLX_MESA_swap_control - -static GLboolean _glewInit_GLX_MESA_swap_control (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetSwapIntervalMESA = (PFNGLXGETSWAPINTERVALMESAPROC)glewGetProcAddress((const GLubyte*)"glXGetSwapIntervalMESA")) == NULL) || r; - r = ((glXSwapIntervalMESA = (PFNGLXSWAPINTERVALMESAPROC)glewGetProcAddress((const GLubyte*)"glXSwapIntervalMESA")) == NULL) || r; - - return r; -} - -#endif /* GLX_MESA_swap_control */ - -#ifdef GLX_NV_copy_image - -static GLboolean _glewInit_GLX_NV_copy_image (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXCopyImageSubDataNV = (PFNGLXCOPYIMAGESUBDATANVPROC)glewGetProcAddress((const GLubyte*)"glXCopyImageSubDataNV")) == NULL) || r; - - return r; -} - -#endif /* GLX_NV_copy_image */ - -#ifdef GLX_NV_float_buffer - -#endif /* GLX_NV_float_buffer */ - -#ifdef GLX_NV_multisample_coverage - -#endif /* GLX_NV_multisample_coverage */ - -#ifdef GLX_NV_present_video - -static GLboolean _glewInit_GLX_NV_present_video (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindVideoDeviceNV = (PFNGLXBINDVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXBindVideoDeviceNV")) == NULL) || r; - r = ((glXEnumerateVideoDevicesNV = (PFNGLXENUMERATEVIDEODEVICESNVPROC)glewGetProcAddress((const GLubyte*)"glXEnumerateVideoDevicesNV")) == NULL) || r; - - return r; -} - -#endif /* GLX_NV_present_video */ - -#ifdef GLX_NV_swap_group - -static GLboolean _glewInit_GLX_NV_swap_group (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindSwapBarrierNV = (PFNGLXBINDSWAPBARRIERNVPROC)glewGetProcAddress((const GLubyte*)"glXBindSwapBarrierNV")) == NULL) || r; - r = ((glXJoinSwapGroupNV = (PFNGLXJOINSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"glXJoinSwapGroupNV")) == NULL) || r; - r = ((glXQueryFrameCountNV = (PFNGLXQUERYFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"glXQueryFrameCountNV")) == NULL) || r; - r = ((glXQueryMaxSwapGroupsNV = (PFNGLXQUERYMAXSWAPGROUPSNVPROC)glewGetProcAddress((const GLubyte*)"glXQueryMaxSwapGroupsNV")) == NULL) || r; - r = ((glXQuerySwapGroupNV = (PFNGLXQUERYSWAPGROUPNVPROC)glewGetProcAddress((const GLubyte*)"glXQuerySwapGroupNV")) == NULL) || r; - r = ((glXResetFrameCountNV = (PFNGLXRESETFRAMECOUNTNVPROC)glewGetProcAddress((const GLubyte*)"glXResetFrameCountNV")) == NULL) || r; - - return r; -} - -#endif /* GLX_NV_swap_group */ - -#ifdef GLX_NV_vertex_array_range - -static GLboolean _glewInit_GLX_NV_vertex_array_range (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXAllocateMemoryNV = (PFNGLXALLOCATEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"glXAllocateMemoryNV")) == NULL) || r; - r = ((glXFreeMemoryNV = (PFNGLXFREEMEMORYNVPROC)glewGetProcAddress((const GLubyte*)"glXFreeMemoryNV")) == NULL) || r; - - return r; -} - -#endif /* GLX_NV_vertex_array_range */ - -#ifdef GLX_NV_video_capture - -static GLboolean _glewInit_GLX_NV_video_capture (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindVideoCaptureDeviceNV = (PFNGLXBINDVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXBindVideoCaptureDeviceNV")) == NULL) || r; - r = ((glXEnumerateVideoCaptureDevicesNV = (PFNGLXENUMERATEVIDEOCAPTUREDEVICESNVPROC)glewGetProcAddress((const GLubyte*)"glXEnumerateVideoCaptureDevicesNV")) == NULL) || r; - r = ((glXLockVideoCaptureDeviceNV = (PFNGLXLOCKVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXLockVideoCaptureDeviceNV")) == NULL) || r; - r = ((glXQueryVideoCaptureDeviceNV = (PFNGLXQUERYVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXQueryVideoCaptureDeviceNV")) == NULL) || r; - r = ((glXReleaseVideoCaptureDeviceNV = (PFNGLXRELEASEVIDEOCAPTUREDEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXReleaseVideoCaptureDeviceNV")) == NULL) || r; - - return r; -} - -#endif /* GLX_NV_video_capture */ - -#ifdef GLX_NV_video_output - -static GLboolean _glewInit_GLX_NV_video_output (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindVideoImageNV = (PFNGLXBINDVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"glXBindVideoImageNV")) == NULL) || r; - r = ((glXGetVideoDeviceNV = (PFNGLXGETVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoDeviceNV")) == NULL) || r; - r = ((glXGetVideoInfoNV = (PFNGLXGETVIDEOINFONVPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoInfoNV")) == NULL) || r; - r = ((glXReleaseVideoDeviceNV = (PFNGLXRELEASEVIDEODEVICENVPROC)glewGetProcAddress((const GLubyte*)"glXReleaseVideoDeviceNV")) == NULL) || r; - r = ((glXReleaseVideoImageNV = (PFNGLXRELEASEVIDEOIMAGENVPROC)glewGetProcAddress((const GLubyte*)"glXReleaseVideoImageNV")) == NULL) || r; - r = ((glXSendPbufferToVideoNV = (PFNGLXSENDPBUFFERTOVIDEONVPROC)glewGetProcAddress((const GLubyte*)"glXSendPbufferToVideoNV")) == NULL) || r; - - return r; -} - -#endif /* GLX_NV_video_output */ - -#ifdef GLX_OML_swap_method - -#endif /* GLX_OML_swap_method */ - -#ifdef GLX_OML_sync_control - -static GLboolean _glewInit_GLX_OML_sync_control (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetMscRateOML = (PFNGLXGETMSCRATEOMLPROC)glewGetProcAddress((const GLubyte*)"glXGetMscRateOML")) == NULL) || r; - r = ((glXGetSyncValuesOML = (PFNGLXGETSYNCVALUESOMLPROC)glewGetProcAddress((const GLubyte*)"glXGetSyncValuesOML")) == NULL) || r; - r = ((glXSwapBuffersMscOML = (PFNGLXSWAPBUFFERSMSCOMLPROC)glewGetProcAddress((const GLubyte*)"glXSwapBuffersMscOML")) == NULL) || r; - r = ((glXWaitForMscOML = (PFNGLXWAITFORMSCOMLPROC)glewGetProcAddress((const GLubyte*)"glXWaitForMscOML")) == NULL) || r; - r = ((glXWaitForSbcOML = (PFNGLXWAITFORSBCOMLPROC)glewGetProcAddress((const GLubyte*)"glXWaitForSbcOML")) == NULL) || r; - - return r; -} - -#endif /* GLX_OML_sync_control */ - -#ifdef GLX_SGIS_blended_overlay - -#endif /* GLX_SGIS_blended_overlay */ - -#ifdef GLX_SGIS_color_range - -#endif /* GLX_SGIS_color_range */ - -#ifdef GLX_SGIS_multisample - -#endif /* GLX_SGIS_multisample */ - -#ifdef GLX_SGIS_shared_multisample - -#endif /* GLX_SGIS_shared_multisample */ - -#ifdef GLX_SGIX_fbconfig - -static GLboolean _glewInit_GLX_SGIX_fbconfig (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXChooseFBConfigSGIX = (PFNGLXCHOOSEFBCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXChooseFBConfigSGIX")) == NULL) || r; - r = ((glXCreateContextWithConfigSGIX = (PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXCreateContextWithConfigSGIX")) == NULL) || r; - r = ((glXCreateGLXPixmapWithConfigSGIX = (PFNGLXCREATEGLXPIXMAPWITHCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXCreateGLXPixmapWithConfigSGIX")) == NULL) || r; - r = ((glXGetFBConfigAttribSGIX = (PFNGLXGETFBCONFIGATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigAttribSGIX")) == NULL) || r; - r = ((glXGetFBConfigFromVisualSGIX = (PFNGLXGETFBCONFIGFROMVISUALSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetFBConfigFromVisualSGIX")) == NULL) || r; - r = ((glXGetVisualFromFBConfigSGIX = (PFNGLXGETVISUALFROMFBCONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetVisualFromFBConfigSGIX")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGIX_fbconfig */ - -#ifdef GLX_SGIX_hyperpipe - -static GLboolean _glewInit_GLX_SGIX_hyperpipe (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindHyperpipeSGIX = (PFNGLXBINDHYPERPIPESGIXPROC)glewGetProcAddress((const GLubyte*)"glXBindHyperpipeSGIX")) == NULL) || r; - r = ((glXDestroyHyperpipeConfigSGIX = (PFNGLXDESTROYHYPERPIPECONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXDestroyHyperpipeConfigSGIX")) == NULL) || r; - r = ((glXHyperpipeAttribSGIX = (PFNGLXHYPERPIPEATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXHyperpipeAttribSGIX")) == NULL) || r; - r = ((glXHyperpipeConfigSGIX = (PFNGLXHYPERPIPECONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXHyperpipeConfigSGIX")) == NULL) || r; - r = ((glXQueryHyperpipeAttribSGIX = (PFNGLXQUERYHYPERPIPEATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeAttribSGIX")) == NULL) || r; - r = ((glXQueryHyperpipeBestAttribSGIX = (PFNGLXQUERYHYPERPIPEBESTATTRIBSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeBestAttribSGIX")) == NULL) || r; - r = ((glXQueryHyperpipeConfigSGIX = (PFNGLXQUERYHYPERPIPECONFIGSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeConfigSGIX")) == NULL) || r; - r = ((glXQueryHyperpipeNetworkSGIX = (PFNGLXQUERYHYPERPIPENETWORKSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryHyperpipeNetworkSGIX")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGIX_hyperpipe */ - -#ifdef GLX_SGIX_pbuffer - -static GLboolean _glewInit_GLX_SGIX_pbuffer (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXCreateGLXPbufferSGIX = (PFNGLXCREATEGLXPBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXCreateGLXPbufferSGIX")) == NULL) || r; - r = ((glXDestroyGLXPbufferSGIX = (PFNGLXDESTROYGLXPBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXDestroyGLXPbufferSGIX")) == NULL) || r; - r = ((glXGetSelectedEventSGIX = (PFNGLXGETSELECTEDEVENTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXGetSelectedEventSGIX")) == NULL) || r; - r = ((glXQueryGLXPbufferSGIX = (PFNGLXQUERYGLXPBUFFERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryGLXPbufferSGIX")) == NULL) || r; - r = ((glXSelectEventSGIX = (PFNGLXSELECTEVENTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXSelectEventSGIX")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGIX_pbuffer */ - -#ifdef GLX_SGIX_swap_barrier - -static GLboolean _glewInit_GLX_SGIX_swap_barrier (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindSwapBarrierSGIX = (PFNGLXBINDSWAPBARRIERSGIXPROC)glewGetProcAddress((const GLubyte*)"glXBindSwapBarrierSGIX")) == NULL) || r; - r = ((glXQueryMaxSwapBarriersSGIX = (PFNGLXQUERYMAXSWAPBARRIERSSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryMaxSwapBarriersSGIX")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGIX_swap_barrier */ - -#ifdef GLX_SGIX_swap_group - -static GLboolean _glewInit_GLX_SGIX_swap_group (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXJoinSwapGroupSGIX = (PFNGLXJOINSWAPGROUPSGIXPROC)glewGetProcAddress((const GLubyte*)"glXJoinSwapGroupSGIX")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGIX_swap_group */ - -#ifdef GLX_SGIX_video_resize - -static GLboolean _glewInit_GLX_SGIX_video_resize (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXBindChannelToWindowSGIX = (PFNGLXBINDCHANNELTOWINDOWSGIXPROC)glewGetProcAddress((const GLubyte*)"glXBindChannelToWindowSGIX")) == NULL) || r; - r = ((glXChannelRectSGIX = (PFNGLXCHANNELRECTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXChannelRectSGIX")) == NULL) || r; - r = ((glXChannelRectSyncSGIX = (PFNGLXCHANNELRECTSYNCSGIXPROC)glewGetProcAddress((const GLubyte*)"glXChannelRectSyncSGIX")) == NULL) || r; - r = ((glXQueryChannelDeltasSGIX = (PFNGLXQUERYCHANNELDELTASSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryChannelDeltasSGIX")) == NULL) || r; - r = ((glXQueryChannelRectSGIX = (PFNGLXQUERYCHANNELRECTSGIXPROC)glewGetProcAddress((const GLubyte*)"glXQueryChannelRectSGIX")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGIX_video_resize */ - -#ifdef GLX_SGIX_visual_select_group - -#endif /* GLX_SGIX_visual_select_group */ - -#ifdef GLX_SGI_cushion - -static GLboolean _glewInit_GLX_SGI_cushion (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXCushionSGI = (PFNGLXCUSHIONSGIPROC)glewGetProcAddress((const GLubyte*)"glXCushionSGI")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGI_cushion */ - -#ifdef GLX_SGI_make_current_read - -static GLboolean _glewInit_GLX_SGI_make_current_read (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetCurrentReadDrawableSGI = (PFNGLXGETCURRENTREADDRAWABLESGIPROC)glewGetProcAddress((const GLubyte*)"glXGetCurrentReadDrawableSGI")) == NULL) || r; - r = ((glXMakeCurrentReadSGI = (PFNGLXMAKECURRENTREADSGIPROC)glewGetProcAddress((const GLubyte*)"glXMakeCurrentReadSGI")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGI_make_current_read */ - -#ifdef GLX_SGI_swap_control - -static GLboolean _glewInit_GLX_SGI_swap_control (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXSwapIntervalSGI = (PFNGLXSWAPINTERVALSGIPROC)glewGetProcAddress((const GLubyte*)"glXSwapIntervalSGI")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGI_swap_control */ - -#ifdef GLX_SGI_video_sync - -static GLboolean _glewInit_GLX_SGI_video_sync (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetVideoSyncSGI = (PFNGLXGETVIDEOSYNCSGIPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoSyncSGI")) == NULL) || r; - r = ((glXWaitVideoSyncSGI = (PFNGLXWAITVIDEOSYNCSGIPROC)glewGetProcAddress((const GLubyte*)"glXWaitVideoSyncSGI")) == NULL) || r; - - return r; -} - -#endif /* GLX_SGI_video_sync */ - -#ifdef GLX_SUN_get_transparent_index - -static GLboolean _glewInit_GLX_SUN_get_transparent_index (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetTransparentIndexSUN = (PFNGLXGETTRANSPARENTINDEXSUNPROC)glewGetProcAddress((const GLubyte*)"glXGetTransparentIndexSUN")) == NULL) || r; - - return r; -} - -#endif /* GLX_SUN_get_transparent_index */ - -#ifdef GLX_SUN_video_resize - -static GLboolean _glewInit_GLX_SUN_video_resize (GLXEW_CONTEXT_ARG_DEF_INIT) -{ - GLboolean r = GL_FALSE; - - r = ((glXGetVideoResizeSUN = (PFNGLXGETVIDEORESIZESUNPROC)glewGetProcAddress((const GLubyte*)"glXGetVideoResizeSUN")) == NULL) || r; - r = ((glXVideoResizeSUN = (PFNGLXVIDEORESIZESUNPROC)glewGetProcAddress((const GLubyte*)"glXVideoResizeSUN")) == NULL) || r; - - return r; -} - -#endif /* GLX_SUN_video_resize */ - -/* ------------------------------------------------------------------------ */ - -GLboolean glxewGetExtension (const char* name) -{ - const GLubyte* start; - const GLubyte* end; - - if (glXGetCurrentDisplay == NULL) return GL_FALSE; - start = (const GLubyte*)glXGetClientString(glXGetCurrentDisplay(), GLX_EXTENSIONS); - if (0 == start) return GL_FALSE; - end = start + _glewStrLen(start); - return _glewSearchExtension(name, start, end); -} - -GLenum glxewContextInit (GLXEW_CONTEXT_ARG_DEF_LIST) -{ - int major, minor; - const GLubyte* extStart; - const GLubyte* extEnd; - /* initialize core GLX 1.2 */ - if (_glewInit_GLX_VERSION_1_2(GLEW_CONTEXT_ARG_VAR_INIT)) return GLEW_ERROR_GLX_VERSION_11_ONLY; - /* initialize flags */ - CONST_CAST(GLXEW_VERSION_1_0) = GL_TRUE; - CONST_CAST(GLXEW_VERSION_1_1) = GL_TRUE; - CONST_CAST(GLXEW_VERSION_1_2) = GL_TRUE; - CONST_CAST(GLXEW_VERSION_1_3) = GL_TRUE; - CONST_CAST(GLXEW_VERSION_1_4) = GL_TRUE; - /* query GLX version */ - glXQueryVersion(glXGetCurrentDisplay(), &major, &minor); - if (major == 1 && minor <= 3) - { - switch (minor) - { - case 3: - CONST_CAST(GLXEW_VERSION_1_4) = GL_FALSE; - break; - case 2: - CONST_CAST(GLXEW_VERSION_1_4) = GL_FALSE; - CONST_CAST(GLXEW_VERSION_1_3) = GL_FALSE; - break; - default: - return GLEW_ERROR_GLX_VERSION_11_ONLY; - break; - } - } - /* query GLX extension string */ - extStart = 0; - if (glXGetCurrentDisplay != NULL) - extStart = (const GLubyte*)glXGetClientString(glXGetCurrentDisplay(), GLX_EXTENSIONS); - if (extStart == 0) - extStart = (const GLubyte *)""; - extEnd = extStart + _glewStrLen(extStart); - /* initialize extensions */ -#ifdef GLX_VERSION_1_3 - if (glewExperimental || GLXEW_VERSION_1_3) CONST_CAST(GLXEW_VERSION_1_3) = !_glewInit_GLX_VERSION_1_3(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_VERSION_1_3 */ -#ifdef GLX_3DFX_multisample - CONST_CAST(GLXEW_3DFX_multisample) = _glewSearchExtension("GLX_3DFX_multisample", extStart, extEnd); -#endif /* GLX_3DFX_multisample */ -#ifdef GLX_AMD_gpu_association - CONST_CAST(GLXEW_AMD_gpu_association) = _glewSearchExtension("GLX_AMD_gpu_association", extStart, extEnd); - if (glewExperimental || GLXEW_AMD_gpu_association) CONST_CAST(GLXEW_AMD_gpu_association) = !_glewInit_GLX_AMD_gpu_association(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_AMD_gpu_association */ -#ifdef GLX_ARB_create_context - CONST_CAST(GLXEW_ARB_create_context) = _glewSearchExtension("GLX_ARB_create_context", extStart, extEnd); - if (glewExperimental || GLXEW_ARB_create_context) CONST_CAST(GLXEW_ARB_create_context) = !_glewInit_GLX_ARB_create_context(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_ARB_create_context */ -#ifdef GLX_ARB_create_context_profile - CONST_CAST(GLXEW_ARB_create_context_profile) = _glewSearchExtension("GLX_ARB_create_context_profile", extStart, extEnd); -#endif /* GLX_ARB_create_context_profile */ -#ifdef GLX_ARB_create_context_robustness - CONST_CAST(GLXEW_ARB_create_context_robustness) = _glewSearchExtension("GLX_ARB_create_context_robustness", extStart, extEnd); -#endif /* GLX_ARB_create_context_robustness */ -#ifdef GLX_ARB_fbconfig_float - CONST_CAST(GLXEW_ARB_fbconfig_float) = _glewSearchExtension("GLX_ARB_fbconfig_float", extStart, extEnd); -#endif /* GLX_ARB_fbconfig_float */ -#ifdef GLX_ARB_framebuffer_sRGB - CONST_CAST(GLXEW_ARB_framebuffer_sRGB) = _glewSearchExtension("GLX_ARB_framebuffer_sRGB", extStart, extEnd); -#endif /* GLX_ARB_framebuffer_sRGB */ -#ifdef GLX_ARB_get_proc_address - CONST_CAST(GLXEW_ARB_get_proc_address) = _glewSearchExtension("GLX_ARB_get_proc_address", extStart, extEnd); -#endif /* GLX_ARB_get_proc_address */ -#ifdef GLX_ARB_multisample - CONST_CAST(GLXEW_ARB_multisample) = _glewSearchExtension("GLX_ARB_multisample", extStart, extEnd); -#endif /* GLX_ARB_multisample */ -#ifdef GLX_ARB_robustness_application_isolation - CONST_CAST(GLXEW_ARB_robustness_application_isolation) = _glewSearchExtension("GLX_ARB_robustness_application_isolation", extStart, extEnd); -#endif /* GLX_ARB_robustness_application_isolation */ -#ifdef GLX_ARB_robustness_share_group_isolation - CONST_CAST(GLXEW_ARB_robustness_share_group_isolation) = _glewSearchExtension("GLX_ARB_robustness_share_group_isolation", extStart, extEnd); -#endif /* GLX_ARB_robustness_share_group_isolation */ -#ifdef GLX_ARB_vertex_buffer_object - CONST_CAST(GLXEW_ARB_vertex_buffer_object) = _glewSearchExtension("GLX_ARB_vertex_buffer_object", extStart, extEnd); -#endif /* GLX_ARB_vertex_buffer_object */ -#ifdef GLX_ATI_pixel_format_float - CONST_CAST(GLXEW_ATI_pixel_format_float) = _glewSearchExtension("GLX_ATI_pixel_format_float", extStart, extEnd); -#endif /* GLX_ATI_pixel_format_float */ -#ifdef GLX_ATI_render_texture - CONST_CAST(GLXEW_ATI_render_texture) = _glewSearchExtension("GLX_ATI_render_texture", extStart, extEnd); - if (glewExperimental || GLXEW_ATI_render_texture) CONST_CAST(GLXEW_ATI_render_texture) = !_glewInit_GLX_ATI_render_texture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_ATI_render_texture */ -#ifdef GLX_EXT_buffer_age - CONST_CAST(GLXEW_EXT_buffer_age) = _glewSearchExtension("GLX_EXT_buffer_age", extStart, extEnd); -#endif /* GLX_EXT_buffer_age */ -#ifdef GLX_EXT_create_context_es2_profile - CONST_CAST(GLXEW_EXT_create_context_es2_profile) = _glewSearchExtension("GLX_EXT_create_context_es2_profile", extStart, extEnd); -#endif /* GLX_EXT_create_context_es2_profile */ -#ifdef GLX_EXT_create_context_es_profile - CONST_CAST(GLXEW_EXT_create_context_es_profile) = _glewSearchExtension("GLX_EXT_create_context_es_profile", extStart, extEnd); -#endif /* GLX_EXT_create_context_es_profile */ -#ifdef GLX_EXT_fbconfig_packed_float - CONST_CAST(GLXEW_EXT_fbconfig_packed_float) = _glewSearchExtension("GLX_EXT_fbconfig_packed_float", extStart, extEnd); -#endif /* GLX_EXT_fbconfig_packed_float */ -#ifdef GLX_EXT_framebuffer_sRGB - CONST_CAST(GLXEW_EXT_framebuffer_sRGB) = _glewSearchExtension("GLX_EXT_framebuffer_sRGB", extStart, extEnd); -#endif /* GLX_EXT_framebuffer_sRGB */ -#ifdef GLX_EXT_import_context - CONST_CAST(GLXEW_EXT_import_context) = _glewSearchExtension("GLX_EXT_import_context", extStart, extEnd); - if (glewExperimental || GLXEW_EXT_import_context) CONST_CAST(GLXEW_EXT_import_context) = !_glewInit_GLX_EXT_import_context(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_EXT_import_context */ -#ifdef GLX_EXT_scene_marker - CONST_CAST(GLXEW_EXT_scene_marker) = _glewSearchExtension("GLX_EXT_scene_marker", extStart, extEnd); -#endif /* GLX_EXT_scene_marker */ -#ifdef GLX_EXT_swap_control - CONST_CAST(GLXEW_EXT_swap_control) = _glewSearchExtension("GLX_EXT_swap_control", extStart, extEnd); - if (glewExperimental || GLXEW_EXT_swap_control) CONST_CAST(GLXEW_EXT_swap_control) = !_glewInit_GLX_EXT_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_EXT_swap_control */ -#ifdef GLX_EXT_swap_control_tear - CONST_CAST(GLXEW_EXT_swap_control_tear) = _glewSearchExtension("GLX_EXT_swap_control_tear", extStart, extEnd); -#endif /* GLX_EXT_swap_control_tear */ -#ifdef GLX_EXT_texture_from_pixmap - CONST_CAST(GLXEW_EXT_texture_from_pixmap) = _glewSearchExtension("GLX_EXT_texture_from_pixmap", extStart, extEnd); - if (glewExperimental || GLXEW_EXT_texture_from_pixmap) CONST_CAST(GLXEW_EXT_texture_from_pixmap) = !_glewInit_GLX_EXT_texture_from_pixmap(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_EXT_texture_from_pixmap */ -#ifdef GLX_EXT_visual_info - CONST_CAST(GLXEW_EXT_visual_info) = _glewSearchExtension("GLX_EXT_visual_info", extStart, extEnd); -#endif /* GLX_EXT_visual_info */ -#ifdef GLX_EXT_visual_rating - CONST_CAST(GLXEW_EXT_visual_rating) = _glewSearchExtension("GLX_EXT_visual_rating", extStart, extEnd); -#endif /* GLX_EXT_visual_rating */ -#ifdef GLX_INTEL_swap_event - CONST_CAST(GLXEW_INTEL_swap_event) = _glewSearchExtension("GLX_INTEL_swap_event", extStart, extEnd); -#endif /* GLX_INTEL_swap_event */ -#ifdef GLX_MESA_agp_offset - CONST_CAST(GLXEW_MESA_agp_offset) = _glewSearchExtension("GLX_MESA_agp_offset", extStart, extEnd); - if (glewExperimental || GLXEW_MESA_agp_offset) CONST_CAST(GLXEW_MESA_agp_offset) = !_glewInit_GLX_MESA_agp_offset(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_MESA_agp_offset */ -#ifdef GLX_MESA_copy_sub_buffer - CONST_CAST(GLXEW_MESA_copy_sub_buffer) = _glewSearchExtension("GLX_MESA_copy_sub_buffer", extStart, extEnd); - if (glewExperimental || GLXEW_MESA_copy_sub_buffer) CONST_CAST(GLXEW_MESA_copy_sub_buffer) = !_glewInit_GLX_MESA_copy_sub_buffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_MESA_copy_sub_buffer */ -#ifdef GLX_MESA_pixmap_colormap - CONST_CAST(GLXEW_MESA_pixmap_colormap) = _glewSearchExtension("GLX_MESA_pixmap_colormap", extStart, extEnd); - if (glewExperimental || GLXEW_MESA_pixmap_colormap) CONST_CAST(GLXEW_MESA_pixmap_colormap) = !_glewInit_GLX_MESA_pixmap_colormap(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_MESA_pixmap_colormap */ -#ifdef GLX_MESA_release_buffers - CONST_CAST(GLXEW_MESA_release_buffers) = _glewSearchExtension("GLX_MESA_release_buffers", extStart, extEnd); - if (glewExperimental || GLXEW_MESA_release_buffers) CONST_CAST(GLXEW_MESA_release_buffers) = !_glewInit_GLX_MESA_release_buffers(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_MESA_release_buffers */ -#ifdef GLX_MESA_set_3dfx_mode - CONST_CAST(GLXEW_MESA_set_3dfx_mode) = _glewSearchExtension("GLX_MESA_set_3dfx_mode", extStart, extEnd); - if (glewExperimental || GLXEW_MESA_set_3dfx_mode) CONST_CAST(GLXEW_MESA_set_3dfx_mode) = !_glewInit_GLX_MESA_set_3dfx_mode(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_MESA_set_3dfx_mode */ -#ifdef GLX_MESA_swap_control - CONST_CAST(GLXEW_MESA_swap_control) = _glewSearchExtension("GLX_MESA_swap_control", extStart, extEnd); - if (glewExperimental || GLXEW_MESA_swap_control) CONST_CAST(GLXEW_MESA_swap_control) = !_glewInit_GLX_MESA_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_MESA_swap_control */ -#ifdef GLX_NV_copy_image - CONST_CAST(GLXEW_NV_copy_image) = _glewSearchExtension("GLX_NV_copy_image", extStart, extEnd); - if (glewExperimental || GLXEW_NV_copy_image) CONST_CAST(GLXEW_NV_copy_image) = !_glewInit_GLX_NV_copy_image(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_NV_copy_image */ -#ifdef GLX_NV_float_buffer - CONST_CAST(GLXEW_NV_float_buffer) = _glewSearchExtension("GLX_NV_float_buffer", extStart, extEnd); -#endif /* GLX_NV_float_buffer */ -#ifdef GLX_NV_multisample_coverage - CONST_CAST(GLXEW_NV_multisample_coverage) = _glewSearchExtension("GLX_NV_multisample_coverage", extStart, extEnd); -#endif /* GLX_NV_multisample_coverage */ -#ifdef GLX_NV_present_video - CONST_CAST(GLXEW_NV_present_video) = _glewSearchExtension("GLX_NV_present_video", extStart, extEnd); - if (glewExperimental || GLXEW_NV_present_video) CONST_CAST(GLXEW_NV_present_video) = !_glewInit_GLX_NV_present_video(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_NV_present_video */ -#ifdef GLX_NV_swap_group - CONST_CAST(GLXEW_NV_swap_group) = _glewSearchExtension("GLX_NV_swap_group", extStart, extEnd); - if (glewExperimental || GLXEW_NV_swap_group) CONST_CAST(GLXEW_NV_swap_group) = !_glewInit_GLX_NV_swap_group(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_NV_swap_group */ -#ifdef GLX_NV_vertex_array_range - CONST_CAST(GLXEW_NV_vertex_array_range) = _glewSearchExtension("GLX_NV_vertex_array_range", extStart, extEnd); - if (glewExperimental || GLXEW_NV_vertex_array_range) CONST_CAST(GLXEW_NV_vertex_array_range) = !_glewInit_GLX_NV_vertex_array_range(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_NV_vertex_array_range */ -#ifdef GLX_NV_video_capture - CONST_CAST(GLXEW_NV_video_capture) = _glewSearchExtension("GLX_NV_video_capture", extStart, extEnd); - if (glewExperimental || GLXEW_NV_video_capture) CONST_CAST(GLXEW_NV_video_capture) = !_glewInit_GLX_NV_video_capture(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_NV_video_capture */ -#ifdef GLX_NV_video_output - CONST_CAST(GLXEW_NV_video_output) = _glewSearchExtension("GLX_NV_video_output", extStart, extEnd); - if (glewExperimental || GLXEW_NV_video_output) CONST_CAST(GLXEW_NV_video_output) = !_glewInit_GLX_NV_video_output(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_NV_video_output */ -#ifdef GLX_OML_swap_method - CONST_CAST(GLXEW_OML_swap_method) = _glewSearchExtension("GLX_OML_swap_method", extStart, extEnd); -#endif /* GLX_OML_swap_method */ -#ifdef GLX_OML_sync_control - CONST_CAST(GLXEW_OML_sync_control) = _glewSearchExtension("GLX_OML_sync_control", extStart, extEnd); - if (glewExperimental || GLXEW_OML_sync_control) CONST_CAST(GLXEW_OML_sync_control) = !_glewInit_GLX_OML_sync_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_OML_sync_control */ -#ifdef GLX_SGIS_blended_overlay - CONST_CAST(GLXEW_SGIS_blended_overlay) = _glewSearchExtension("GLX_SGIS_blended_overlay", extStart, extEnd); -#endif /* GLX_SGIS_blended_overlay */ -#ifdef GLX_SGIS_color_range - CONST_CAST(GLXEW_SGIS_color_range) = _glewSearchExtension("GLX_SGIS_color_range", extStart, extEnd); -#endif /* GLX_SGIS_color_range */ -#ifdef GLX_SGIS_multisample - CONST_CAST(GLXEW_SGIS_multisample) = _glewSearchExtension("GLX_SGIS_multisample", extStart, extEnd); -#endif /* GLX_SGIS_multisample */ -#ifdef GLX_SGIS_shared_multisample - CONST_CAST(GLXEW_SGIS_shared_multisample) = _glewSearchExtension("GLX_SGIS_shared_multisample", extStart, extEnd); -#endif /* GLX_SGIS_shared_multisample */ -#ifdef GLX_SGIX_fbconfig - CONST_CAST(GLXEW_SGIX_fbconfig) = _glewSearchExtension("GLX_SGIX_fbconfig", extStart, extEnd); - if (glewExperimental || GLXEW_SGIX_fbconfig) CONST_CAST(GLXEW_SGIX_fbconfig) = !_glewInit_GLX_SGIX_fbconfig(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGIX_fbconfig */ -#ifdef GLX_SGIX_hyperpipe - CONST_CAST(GLXEW_SGIX_hyperpipe) = _glewSearchExtension("GLX_SGIX_hyperpipe", extStart, extEnd); - if (glewExperimental || GLXEW_SGIX_hyperpipe) CONST_CAST(GLXEW_SGIX_hyperpipe) = !_glewInit_GLX_SGIX_hyperpipe(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGIX_hyperpipe */ -#ifdef GLX_SGIX_pbuffer - CONST_CAST(GLXEW_SGIX_pbuffer) = _glewSearchExtension("GLX_SGIX_pbuffer", extStart, extEnd); - if (glewExperimental || GLXEW_SGIX_pbuffer) CONST_CAST(GLXEW_SGIX_pbuffer) = !_glewInit_GLX_SGIX_pbuffer(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGIX_pbuffer */ -#ifdef GLX_SGIX_swap_barrier - CONST_CAST(GLXEW_SGIX_swap_barrier) = _glewSearchExtension("GLX_SGIX_swap_barrier", extStart, extEnd); - if (glewExperimental || GLXEW_SGIX_swap_barrier) CONST_CAST(GLXEW_SGIX_swap_barrier) = !_glewInit_GLX_SGIX_swap_barrier(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGIX_swap_barrier */ -#ifdef GLX_SGIX_swap_group - CONST_CAST(GLXEW_SGIX_swap_group) = _glewSearchExtension("GLX_SGIX_swap_group", extStart, extEnd); - if (glewExperimental || GLXEW_SGIX_swap_group) CONST_CAST(GLXEW_SGIX_swap_group) = !_glewInit_GLX_SGIX_swap_group(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGIX_swap_group */ -#ifdef GLX_SGIX_video_resize - CONST_CAST(GLXEW_SGIX_video_resize) = _glewSearchExtension("GLX_SGIX_video_resize", extStart, extEnd); - if (glewExperimental || GLXEW_SGIX_video_resize) CONST_CAST(GLXEW_SGIX_video_resize) = !_glewInit_GLX_SGIX_video_resize(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGIX_video_resize */ -#ifdef GLX_SGIX_visual_select_group - CONST_CAST(GLXEW_SGIX_visual_select_group) = _glewSearchExtension("GLX_SGIX_visual_select_group", extStart, extEnd); -#endif /* GLX_SGIX_visual_select_group */ -#ifdef GLX_SGI_cushion - CONST_CAST(GLXEW_SGI_cushion) = _glewSearchExtension("GLX_SGI_cushion", extStart, extEnd); - if (glewExperimental || GLXEW_SGI_cushion) CONST_CAST(GLXEW_SGI_cushion) = !_glewInit_GLX_SGI_cushion(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGI_cushion */ -#ifdef GLX_SGI_make_current_read - CONST_CAST(GLXEW_SGI_make_current_read) = _glewSearchExtension("GLX_SGI_make_current_read", extStart, extEnd); - if (glewExperimental || GLXEW_SGI_make_current_read) CONST_CAST(GLXEW_SGI_make_current_read) = !_glewInit_GLX_SGI_make_current_read(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGI_make_current_read */ -#ifdef GLX_SGI_swap_control - CONST_CAST(GLXEW_SGI_swap_control) = _glewSearchExtension("GLX_SGI_swap_control", extStart, extEnd); - if (glewExperimental || GLXEW_SGI_swap_control) CONST_CAST(GLXEW_SGI_swap_control) = !_glewInit_GLX_SGI_swap_control(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGI_swap_control */ -#ifdef GLX_SGI_video_sync - CONST_CAST(GLXEW_SGI_video_sync) = _glewSearchExtension("GLX_SGI_video_sync", extStart, extEnd); - if (glewExperimental || GLXEW_SGI_video_sync) CONST_CAST(GLXEW_SGI_video_sync) = !_glewInit_GLX_SGI_video_sync(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SGI_video_sync */ -#ifdef GLX_SUN_get_transparent_index - CONST_CAST(GLXEW_SUN_get_transparent_index) = _glewSearchExtension("GLX_SUN_get_transparent_index", extStart, extEnd); - if (glewExperimental || GLXEW_SUN_get_transparent_index) CONST_CAST(GLXEW_SUN_get_transparent_index) = !_glewInit_GLX_SUN_get_transparent_index(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SUN_get_transparent_index */ -#ifdef GLX_SUN_video_resize - CONST_CAST(GLXEW_SUN_video_resize) = _glewSearchExtension("GLX_SUN_video_resize", extStart, extEnd); - if (glewExperimental || GLXEW_SUN_video_resize) CONST_CAST(GLXEW_SUN_video_resize) = !_glewInit_GLX_SUN_video_resize(GLEW_CONTEXT_ARG_VAR_INIT); -#endif /* GLX_SUN_video_resize */ - - return GLEW_OK; -} - -#endif /* !defined(__ANDROID__) && !defined(__native_client__) && (!defined(__APPLE__) || defined(GLEW_APPLE_GLX)) */ - -/* ------------------------------------------------------------------------ */ - -const GLubyte * GLEWAPIENTRY glewGetErrorString (GLenum error) -{ - static const GLubyte* _glewErrorString[] = - { - (const GLubyte*)"No error", - (const GLubyte*)"Missing GL version", - (const GLubyte*)"GL 1.1 and up are not supported", - (const GLubyte*)"GLX 1.2 and up are not supported", - (const GLubyte*)"Unknown error" - }; - const int max_error = sizeof(_glewErrorString)/sizeof(*_glewErrorString) - 1; - return _glewErrorString[(int)error > max_error ? max_error : (int)error]; -} - -const GLubyte * GLEWAPIENTRY glewGetString (GLenum name) -{ - static const GLubyte* _glewString[] = - { - (const GLubyte*)NULL, - (const GLubyte*)"1.10.0", - (const GLubyte*)"1", - (const GLubyte*)"10", - (const GLubyte*)"0" - }; - const int max_string = sizeof(_glewString)/sizeof(*_glewString) - 1; - return _glewString[(int)name > max_string ? 0 : (int)name]; -} - -/* ------------------------------------------------------------------------ */ - -GLboolean glewExperimental = GL_FALSE; - -#if !defined(GLEW_MX) - -#if defined(_WIN32) -extern GLenum GLEWAPIENTRY wglewContextInit (void); -#elif !defined(__ANDROID__) && !defined(__native_client__) && (!defined(__APPLE__) || defined(GLEW_APPLE_GLX)) -extern GLenum GLEWAPIENTRY glxewContextInit (void); -#endif /* _WIN32 */ - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -GLboolean GLEWAPIENTRY glewXInit(void) -{ - GLboolean r = GL_FALSE; - r = ((glXGetProcAddressARB = (PFNGLXGETPROCADDRESSARBPROC)dlglXGetProcAddressARB((const GLubyte*)"glXGetProcAddressARB")) == NULL) || r; - r = ((glXQueryExtension = (PFNGLXQUERYEXTENSION)dlglXGetProcAddressARB((const GLubyte*)"glXQueryExtension")) == NULL) || r; - r = ((glXQueryVersion = (PFNGLXQUERYVERSION)dlglXGetProcAddressARB((const GLubyte*)"glXQueryVersion")) == NULL) || r; - r = ((glXGetConfig = (PFNGLXGETCONFIG)dlglXGetProcAddressARB((const GLubyte*)"glXGetConfig")) == NULL) || r; - r = ((glXChooseVisual = (PFNGLXCHOOSEVISUAL)dlglXGetProcAddressARB((const GLubyte*)"glXChooseVisual")) == NULL) || r; - r = ((glXCreateContext = (PFNGLXCREATECONTEXT)dlglXGetProcAddressARB((const GLubyte*)"glXCreateContext")) == NULL) || r; - r = ((glXDestroyContext = (PFNGLXDESTROYCONTEXT)dlglXGetProcAddressARB((const GLubyte*)"glXDestroyContext")) == NULL) || r; - r = ((glXDestroyContext = (PFNGLXDESTROYCONTEXT)dlglXGetProcAddressARB((const GLubyte*)"glXDestroyContext")) == NULL) || r; - r = ((glXIsDirect = (PFNGLXISDIRECT)dlglXGetProcAddressARB((const GLubyte*)"glXIsDirect")) == NULL) || r; - r = ((glXMakeCurrent = (PFNGLXMAKECURRENT)dlglXGetProcAddressARB((const GLubyte*)"glXMakeCurrent")) == NULL) || r; - r = ((glXQueryExtensionsString = (PFNGLXQUERYEXTENSIONSSTRING)dlglXGetProcAddressARB((const GLubyte*)"glXQueryExtensionsString")) == NULL) || r; - r = ((glXGetClientString = (PFNGLXGETCLIENTSTRING)dlglXGetProcAddressARB((const GLubyte*)"glXGetClientString")) == NULL) || r; - r = ((glXQueryServerString = (PFNGLXQUERYSERVERSTRING)dlglXGetProcAddressARB((const GLubyte*)"glXQueryServerString")) == NULL) || r; - r = ((glXSwapBuffers = (PFNGLXSWAPBUFFERS)dlglXGetProcAddressARB((const GLubyte*)"glXSwapBuffers")) == NULL) || r; - //glxewContextInit(); - _glewInit_GLX_VERSION_1_3(); - - if (r==0) - { - printf("glewXInit dynamically loaded using dlopen/dlsym OK\n"); - } - return r; -} -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - -#ifdef GLEW_INIT_OPENGL11_FUNCTIONS - -PFNGLACCUMPROC __glewAccum = NULL; -PFNGLALPHAFUNCPROC __glewAlphaFunc = NULL; -PFNGLARETEXTURESRESIDENTPROC __glewAreTexturesResident = NULL; -PFNGLARRAYELEMENTPROC __glewArrayElement = NULL; -PFNGLBEGINPROC __glewBegin = NULL; -PFNGLBINDTEXTUREPROC __glewBindTexture = NULL; -PFNGLBITMAPPROC __glewBitmap = NULL; -PFNGLBLENDFUNCPROC __glewBlendFunc = NULL; -PFNGLCALLLISTPROC __glewCallList = NULL; -PFNGLCALLLISTSPROC __glewCallLists = NULL; -PFNGLCLEARPROC __glewClear = NULL; -PFNGLCLEARACCUMPROC __glewClearAccum = NULL; -PFNGLCLEARCOLORPROC __glewClearColor = NULL; -PFNGLCLEARDEPTHPROC __glewClearDepth = NULL; -PFNGLCLEARINDEXPROC __glewClearIndex = NULL; -PFNGLCLEARSTENCILPROC __glewClearStencil = NULL; -PFNGLCLIPPLANEPROC __glewClipPlane = NULL; -PFNGLCOLOR3BPROC __glewColor3b = NULL; -PFNGLCOLOR3BVPROC __glewColor3bv = NULL; -PFNGLCOLOR3DPROC __glewColor3d = NULL; -PFNGLCOLOR3DVPROC __glewColor3dv = NULL; -PFNGLCOLOR3FPROC __glewColor3f = NULL; -PFNGLCOLOR3FVPROC __glewColor3fv = NULL; -PFNGLCOLOR3IPROC __glewColor3i = NULL; -PFNGLCOLOR3IVPROC __glewColor3iv = NULL; -PFNGLCOLOR3SPROC __glewColor3s = NULL; -PFNGLCOLOR3SVPROC __glewColor3sv = NULL; -PFNGLCOLOR3UBPROC __glewColor3ub = NULL; -PFNGLCOLOR3UBVPROC __glewColor3ubv = NULL; -PFNGLCOLOR3UIPROC __glewColor3ui = NULL; -PFNGLCOLOR3UIVPROC __glewColor3uiv = NULL; -PFNGLCOLOR3USPROC __glewColor3us = NULL; -PFNGLCOLOR3USVPROC __glewColor3usv = NULL; -PFNGLCOLOR4BPROC __glewColor4b = NULL; -PFNGLCOLOR4BVPROC __glewColor4bv = NULL; -PFNGLCOLOR4DPROC __glewColor4d = NULL; -PFNGLCOLOR4DVPROC __glewColor4dv = NULL; -PFNGLCOLOR4FPROC __glewColor4f = NULL; -PFNGLCOLOR4FVPROC __glewColor4fv = NULL; -PFNGLCOLOR4IPROC __glewColor4i = NULL; -PFNGLCOLOR4IVPROC __glewColor4iv = NULL; -PFNGLCOLOR4SPROC __glewColor4s = NULL; -PFNGLCOLOR4SVPROC __glewColor4sv = NULL; -PFNGLCOLOR4UBPROC __glewColor4ub = NULL; -PFNGLCOLOR4UBVPROC __glewColor4ubv = NULL; -PFNGLCOLOR4UIPROC __glewColor4ui = NULL; -PFNGLCOLOR4UIVPROC __glewColor4uiv = NULL; -PFNGLCOLOR4USPROC __glewColor4us = NULL; -PFNGLCOLOR4USVPROC __glewColor4usv = NULL; -PFNGLCOLORMASKPROC __glewColorMask = NULL; -PFNGLCOLORMATERIALPROC __glewColorMaterial = NULL; -PFNGLCOLORPOINTERPROC __glewColorPointer = NULL; -PFNGLCOPYPIXELSPROC __glewCopyPixels = NULL; -PFNGLCOPYTEXIMAGE1DPROC __glewCopyTexImage1D = NULL; -PFNGLCOPYTEXIMAGE2DPROC __glewCopyTexImage2D = NULL; -PFNGLCOPYTEXSUBIMAGE1DPROC __glewCopyTexSubImage1D = NULL; -PFNGLCOPYTEXSUBIMAGE2DPROC __glewCopyTexSubImage2D = NULL; -PFNGLCULLFACEPROC __glewCullFace = NULL; -PFNGLDELETELISTSPROC __glewDeleteLists = NULL; -PFNGLDELETETEXTURESPROC __glewDeleteTextures = NULL; -PFNGLDEPTHFUNCPROC __glewDepthFunc = NULL; -PFNGLDEPTHMASKPROC __glewDepthMask = NULL; -PFNGLDEPTHRANGEPROC __glewDepthRange = NULL; -PFNGLDISABLEPROC __glewDisable = NULL; -PFNGLDISABLECLIENTSTATEPROC __glewDisableClientState = NULL; -PFNGLDRAWARRAYSPROC __glewDrawArrays = NULL; -PFNGLDRAWBUFFERPROC __glewDrawBuffer = NULL; -PFNGLDRAWELEMENTSPROC __glewDrawElements = NULL; -PFNGLDRAWPIXELSPROC __glewDrawPixels = NULL; -PFNGLEDGEFLAGPROC __glewEdgeFlag = NULL; -PFNGLEDGEFLAGPOINTERPROC __glewEdgeFlagPointer = NULL; -PFNGLEDGEFLAGVPROC __glewEdgeFlagv = NULL; -PFNGLENABLEPROC __glewEnable = NULL; -PFNGLENABLECLIENTSTATEPROC __glewEnableClientState = NULL; -PFNGLENDPROC __glewEnd = NULL; -PFNGLENDLISTPROC __glewEndList = NULL; -PFNGLEVALCOORD1DPROC __glewEvalCoord1d = NULL; -PFNGLEVALCOORD1DVPROC __glewEvalCoord1dv = NULL; -PFNGLEVALCOORD1FPROC __glewEvalCoord1f = NULL; -PFNGLEVALCOORD1FVPROC __glewEvalCoord1fv = NULL; -PFNGLEVALCOORD2DPROC __glewEvalCoord2d = NULL; -PFNGLEVALCOORD2DVPROC __glewEvalCoord2dv = NULL; -PFNGLEVALCOORD2FPROC __glewEvalCoord2f = NULL; -PFNGLEVALCOORD2FVPROC __glewEvalCoord2fv = NULL; -PFNGLEVALMESH1PROC __glewEvalMesh1 = NULL; -PFNGLEVALMESH2PROC __glewEvalMesh2 = NULL; -PFNGLEVALPOINT1PROC __glewEvalPoint1 = NULL; -PFNGLEVALPOINT2PROC __glewEvalPoint2 = NULL; -PFNGLFEEDBACKBUFFERPROC __glewFeedbackBuffer = NULL; -PFNGLFINISHPROC __glewFinish = NULL; -PFNGLFLUSHPROC __glewFlush = NULL; -PFNGLFOGFPROC __glewFogf = NULL; -PFNGLFOGFVPROC __glewFogfv = NULL; -PFNGLFOGIPROC __glewFogi = NULL; -PFNGLFOGIVPROC __glewFogiv = NULL; -PFNGLFRONTFACEPROC __glewFrontFace = NULL; -PFNGLFRUSTUMPROC __glewFrustum = NULL; -PFNGLGENLISTSPROC __glewGenLists = NULL; -PFNGLGENTEXTURESPROC __glewGenTextures = NULL; -PFNGLGETBOOLEANVPROC __glewGetBooleanv = NULL; -PFNGLGETCLIPPLANEPROC __glewGetClipPlane = NULL; -PFNGLGETDOUBLEVPROC __glewGetDoublev = NULL; -PFNGLGETERRORPROC __glewGetError = NULL; -PFNGLGETFLOATVPROC __glewGetFloatv = NULL; -PFNGLGETINTEGERVPROC __glewGetIntegerv = NULL; -PFNGLGETLIGHTFVPROC __glewGetLightfv = NULL; -PFNGLGETLIGHTIVPROC __glewGetLightiv = NULL; -PFNGLGETMAPDVPROC __glewGetMapdv = NULL; -PFNGLGETMAPFVPROC __glewGetMapfv = NULL; -PFNGLGETMAPIVPROC __glewGetMapiv = NULL; -PFNGLGETMATERIALFVPROC __glewGetMaterialfv = NULL; -PFNGLGETMATERIALIVPROC __glewGetMaterialiv = NULL; -PFNGLGETPIXELMAPFVPROC __glewGetPixelMapfv = NULL; -PFNGLGETPIXELMAPUIVPROC __glewGetPixelMapuiv = NULL; -PFNGLGETPIXELMAPUSVPROC __glewGetPixelMapusv = NULL; -PFNGLGETPOINTERVPROC __glewGetPointerv = NULL; -PFNGLGETPOLYGONSTIPPLEPROC __glewGetPolygonStipple = NULL; -PFNGLGETSTRINGPROC __glewGetString = NULL; -PFNGLGETTEXENVFVPROC __glewGetTexEnvfv = NULL; -PFNGLGETTEXENVIVPROC __glewGetTexEnviv = NULL; -PFNGLGETTEXGENDVPROC __glewGetTexGendv = NULL; -PFNGLGETTEXGENFVPROC __glewGetTexGenfv = NULL; -PFNGLGETTEXGENIVPROC __glewGetTexGeniv = NULL; -PFNGLGETTEXIMAGEPROC __glewGetTexImage = NULL; -PFNGLGETTEXLEVELPARAMETERFVPROC __glewGetTexLevelParameterfv = NULL; -PFNGLGETTEXLEVELPARAMETERIVPROC __glewGetTexLevelParameteriv = NULL; -PFNGLGETTEXPARAMETERFVPROC __glewGetTexParameterfv = NULL; -PFNGLGETTEXPARAMETERIVPROC __glewGetTexParameteriv = NULL; -PFNGLHINTPROC __glewHint = NULL; -PFNGLINDEXMASKPROC __glewIndexMask = NULL; -PFNGLINDEXPOINTERPROC __glewIndexPointer = NULL; -PFNGLINDEXDPROC __glewIndexd = NULL; -PFNGLINDEXDVPROC __glewIndexdv = NULL; -PFNGLINDEXFPROC __glewIndexf = NULL; -PFNGLINDEXFVPROC __glewIndexfv = NULL; -PFNGLINDEXIPROC __glewIndexi = NULL; -PFNGLINDEXIVPROC __glewIndexiv = NULL; -PFNGLINDEXSPROC __glewIndexs = NULL; -PFNGLINDEXSVPROC __glewIndexsv = NULL; -PFNGLINDEXUBPROC __glewIndexub = NULL; -PFNGLINDEXUBVPROC __glewIndexubv = NULL; -PFNGLINITNAMESPROC __glewInitNames = NULL; -PFNGLINTERLEAVEDARRAYSPROC __glewInterleavedArrays = NULL; -PFNGLISENABLEDPROC __glewIsEnabled = NULL; -PFNGLISLISTPROC __glewIsList = NULL; -PFNGLISTEXTUREPROC __glewIsTexture = NULL; -PFNGLLIGHTMODELFPROC __glewLightModelf = NULL; -PFNGLLIGHTMODELFVPROC __glewLightModelfv = NULL; -PFNGLLIGHTMODELIPROC __glewLightModeli = NULL; -PFNGLLIGHTMODELIVPROC __glewLightModeliv = NULL; -PFNGLLIGHTFPROC __glewLightf = NULL; -PFNGLLIGHTFVPROC __glewLightfv = NULL; -PFNGLLIGHTIPROC __glewLighti = NULL; -PFNGLLIGHTIVPROC __glewLightiv = NULL; -PFNGLLINESTIPPLEPROC __glewLineStipple = NULL; -PFNGLLINEWIDTHPROC __glewLineWidth = NULL; -PFNGLLISTBASEPROC __glewListBase = NULL; -PFNGLLOADIDENTITYPROC __glewLoadIdentity = NULL; -PFNGLLOADMATRIXDPROC __glewLoadMatrixd = NULL; -PFNGLLOADMATRIXFPROC __glewLoadMatrixf = NULL; -PFNGLLOADNAMEPROC __glewLoadName = NULL; -PFNGLLOGICOPPROC __glewLogicOp = NULL; -PFNGLMAP1DPROC __glewMap1d = NULL; -PFNGLMAP1FPROC __glewMap1f = NULL; -PFNGLMAP2DPROC __glewMap2d = NULL; -PFNGLMAP2FPROC __glewMap2f = NULL; -PFNGLMAPGRID1DPROC __glewMapGrid1d = NULL; -PFNGLMAPGRID1FPROC __glewMapGrid1f = NULL; -PFNGLMAPGRID2DPROC __glewMapGrid2d = NULL; -PFNGLMAPGRID2FPROC __glewMapGrid2f = NULL; -PFNGLMATERIALFPROC __glewMaterialf = NULL; -PFNGLMATERIALFVPROC __glewMaterialfv = NULL; -PFNGLMATERIALIPROC __glewMateriali = NULL; -PFNGLMATERIALIVPROC __glewMaterialiv = NULL; -PFNGLMATRIXMODEPROC __glewMatrixMode = NULL; -PFNGLMULTMATRIXDPROC __glewMultMatrixd = NULL; -PFNGLMULTMATRIXFPROC __glewMultMatrixf = NULL; -PFNGLNEWLISTPROC __glewNewList = NULL; -PFNGLNORMAL3BPROC __glewNormal3b = NULL; -PFNGLNORMAL3BVPROC __glewNormal3bv = NULL; -PFNGLNORMAL3DPROC __glewNormal3d = NULL; -PFNGLNORMAL3DVPROC __glewNormal3dv = NULL; -PFNGLNORMAL3FPROC __glewNormal3f = NULL; -PFNGLNORMAL3FVPROC __glewNormal3fv = NULL; -PFNGLNORMAL3IPROC __glewNormal3i = NULL; -PFNGLNORMAL3IVPROC __glewNormal3iv = NULL; -PFNGLNORMAL3SPROC __glewNormal3s = NULL; -PFNGLNORMAL3SVPROC __glewNormal3sv = NULL; -PFNGLNORMALPOINTERPROC __glewNormalPointer = NULL; -PFNGLORTHOPROC __glewOrtho = NULL; -PFNGLPASSTHROUGHPROC __glewPassThrough = NULL; -PFNGLPIXELMAPFVPROC __glewPixelMapfv = NULL; -PFNGLPIXELMAPUIVPROC __glewPixelMapuiv = NULL; -PFNGLPIXELMAPUSVPROC __glewPixelMapusv = NULL; -PFNGLPIXELSTOREFPROC __glewPixelStoref = NULL; -PFNGLPIXELSTOREIPROC __glewPixelStorei = NULL; -PFNGLPIXELTRANSFERFPROC __glewPixelTransferf = NULL; -PFNGLPIXELTRANSFERIPROC __glewPixelTransferi = NULL; -PFNGLPIXELZOOMPROC __glewPixelZoom = NULL; -PFNGLPOINTSIZEPROC __glewPointSize = NULL; -PFNGLPOLYGONMODEPROC __glewPolygonMode = NULL; -PFNGLPOLYGONOFFSETPROC __glewPolygonOffset = NULL; -PFNGLPOLYGONSTIPPLEPROC __glewPolygonStipple = NULL; -PFNGLPOPATTRIBPROC __glewPopAttrib = NULL; -PFNGLPOPCLIENTATTRIBPROC __glewPopClientAttrib = NULL; -PFNGLPOPMATRIXPROC __glewPopMatrix = NULL; -PFNGLPOPNAMEPROC __glewPopName = NULL; -PFNGLPRIORITIZETEXTURESPROC __glewPrioritizeTextures = NULL; -PFNGLPUSHATTRIBPROC __glewPushAttrib = NULL; -PFNGLPUSHCLIENTATTRIBPROC __glewPushClientAttrib = NULL; -PFNGLPUSHMATRIXPROC __glewPushMatrix = NULL; -PFNGLPUSHNAMEPROC __glewPushName = NULL; -PFNGLRASTERPOS2DPROC __glewRasterPos2d = NULL; -PFNGLRASTERPOS2DVPROC __glewRasterPos2dv = NULL; -PFNGLRASTERPOS2FPROC __glewRasterPos2f = NULL; -PFNGLRASTERPOS2FVPROC __glewRasterPos2fv = NULL; -PFNGLRASTERPOS2IPROC __glewRasterPos2i = NULL; -PFNGLRASTERPOS2IVPROC __glewRasterPos2iv = NULL; -PFNGLRASTERPOS2SPROC __glewRasterPos2s = NULL; -PFNGLRASTERPOS2SVPROC __glewRasterPos2sv = NULL; -PFNGLRASTERPOS3DPROC __glewRasterPos3d = NULL; -PFNGLRASTERPOS3DVPROC __glewRasterPos3dv = NULL; -PFNGLRASTERPOS3FPROC __glewRasterPos3f = NULL; -PFNGLRASTERPOS3FVPROC __glewRasterPos3fv = NULL; -PFNGLRASTERPOS3IPROC __glewRasterPos3i = NULL; -PFNGLRASTERPOS3IVPROC __glewRasterPos3iv = NULL; -PFNGLRASTERPOS3SPROC __glewRasterPos3s = NULL; -PFNGLRASTERPOS3SVPROC __glewRasterPos3sv = NULL; -PFNGLRASTERPOS4DPROC __glewRasterPos4d = NULL; -PFNGLRASTERPOS4DVPROC __glewRasterPos4dv = NULL; -PFNGLRASTERPOS4FPROC __glewRasterPos4f = NULL; -PFNGLRASTERPOS4FVPROC __glewRasterPos4fv = NULL; -PFNGLRASTERPOS4IPROC __glewRasterPos4i = NULL; -PFNGLRASTERPOS4IVPROC __glewRasterPos4iv = NULL; -PFNGLRASTERPOS4SPROC __glewRasterPos4s = NULL; -PFNGLRASTERPOS4SVPROC __glewRasterPos4sv = NULL; -PFNGLREADBUFFERPROC __glewReadBuffer = NULL; -PFNGLREADPIXELSPROC __glewReadPixels = NULL; -PFNGLRECTDPROC __glewRectd = NULL; -PFNGLRECTDVPROC __glewRectdv = NULL; -PFNGLRECTFPROC __glewRectf = NULL; -PFNGLRECTFVPROC __glewRectfv = NULL; -PFNGLRECTIPROC __glewRecti = NULL; -PFNGLRECTIVPROC __glewRectiv = NULL; -PFNGLRECTSPROC __glewRects = NULL; -PFNGLRECTSVPROC __glewRectsv = NULL; -PFNGLRENDERMODEPROC __glewRenderMode = NULL; -PFNGLROTATEDPROC __glewRotated = NULL; -PFNGLROTATEFPROC __glewRotatef = NULL; -PFNGLSCALEDPROC __glewScaled = NULL; -PFNGLSCALEFPROC __glewScalef = NULL; -PFNGLSCISSORPROC __glewScissor = NULL; -PFNGLSELECTBUFFERPROC __glewSelectBuffer = NULL; -PFNGLSHADEMODELPROC __glewShadeModel = NULL; -PFNGLSTENCILFUNCPROC __glewStencilFunc = NULL; -PFNGLSTENCILMASKPROC __glewStencilMask = NULL; -PFNGLSTENCILOPPROC __glewStencilOp = NULL; -PFNGLTEXCOORD1DPROC __glewTexCoord1d = NULL; -PFNGLTEXCOORD1DVPROC __glewTexCoord1dv = NULL; -PFNGLTEXCOORD1FPROC __glewTexCoord1f = NULL; -PFNGLTEXCOORD1FVPROC __glewTexCoord1fv = NULL; -PFNGLTEXCOORD1IPROC __glewTexCoord1i = NULL; -PFNGLTEXCOORD1IVPROC __glewTexCoord1iv = NULL; -PFNGLTEXCOORD1SPROC __glewTexCoord1s = NULL; -PFNGLTEXCOORD1SVPROC __glewTexCoord1sv = NULL; -PFNGLTEXCOORD2DPROC __glewTexCoord2d = NULL; -PFNGLTEXCOORD2DVPROC __glewTexCoord2dv = NULL; -PFNGLTEXCOORD2FPROC __glewTexCoord2f = NULL; -PFNGLTEXCOORD2FVPROC __glewTexCoord2fv = NULL; -PFNGLTEXCOORD2IPROC __glewTexCoord2i = NULL; -PFNGLTEXCOORD2IVPROC __glewTexCoord2iv = NULL; -PFNGLTEXCOORD2SPROC __glewTexCoord2s = NULL; -PFNGLTEXCOORD2SVPROC __glewTexCoord2sv = NULL; -PFNGLTEXCOORD3DPROC __glewTexCoord3d = NULL; -PFNGLTEXCOORD3DVPROC __glewTexCoord3dv = NULL; -PFNGLTEXCOORD3FPROC __glewTexCoord3f = NULL; -PFNGLTEXCOORD3FVPROC __glewTexCoord3fv = NULL; -PFNGLTEXCOORD3IPROC __glewTexCoord3i = NULL; -PFNGLTEXCOORD3IVPROC __glewTexCoord3iv = NULL; -PFNGLTEXCOORD3SPROC __glewTexCoord3s = NULL; -PFNGLTEXCOORD3SVPROC __glewTexCoord3sv = NULL; -PFNGLTEXCOORD4DPROC __glewTexCoord4d = NULL; -PFNGLTEXCOORD4DVPROC __glewTexCoord4dv = NULL; -PFNGLTEXCOORD4FPROC __glewTexCoord4f = NULL; -PFNGLTEXCOORD4FVPROC __glewTexCoord4fv = NULL; -PFNGLTEXCOORD4IPROC __glewTexCoord4i = NULL; -PFNGLTEXCOORD4IVPROC __glewTexCoord4iv = NULL; -PFNGLTEXCOORD4SPROC __glewTexCoord4s = NULL; -PFNGLTEXCOORD4SVPROC __glewTexCoord4sv = NULL; -PFNGLTEXCOORDPOINTERPROC __glewTexCoordPointer = NULL; -PFNGLTEXENVFPROC __glewTexEnvf = NULL; -PFNGLTEXENVFVPROC __glewTexEnvfv = NULL; -PFNGLTEXENVIPROC __glewTexEnvi = NULL; -PFNGLTEXENVIVPROC __glewTexEnviv = NULL; -PFNGLTEXGENDPROC __glewTexGend = NULL; -PFNGLTEXGENDVPROC __glewTexGendv = NULL; -PFNGLTEXGENFPROC __glewTexGenf = NULL; -PFNGLTEXGENFVPROC __glewTexGenfv = NULL; -PFNGLTEXGENIPROC __glewTexGeni = NULL; -PFNGLTEXGENIVPROC __glewTexGeniv = NULL; -PFNGLTEXIMAGE1DPROC __glewTexImage1D = NULL; -PFNGLTEXIMAGE2DPROC __glewTexImage2D = NULL; -PFNGLTEXPARAMETERFPROC __glewTexParameterf = NULL; -PFNGLTEXPARAMETERFVPROC __glewTexParameterfv = NULL; -PFNGLTEXPARAMETERIPROC __glewTexParameteri = NULL; -PFNGLTEXPARAMETERIVPROC __glewTexParameteriv = NULL; -PFNGLTEXSUBIMAGE1DPROC __glewTexSubImage1D = NULL; -PFNGLTEXSUBIMAGE2DPROC __glewTexSubImage2D = NULL; -PFNGLTRANSLATEDPROC __glewTranslated = NULL; -PFNGLTRANSLATEFPROC __glewTranslatef = NULL; -PFNGLVERTEX2DPROC __glewVertex2d = NULL; -PFNGLVERTEX2DVPROC __glewVertex2dv = NULL; -PFNGLVERTEX2FPROC __glewVertex2f = NULL; -PFNGLVERTEX2FVPROC __glewVertex2fv = NULL; -PFNGLVERTEX2IPROC __glewVertex2i = NULL; -PFNGLVERTEX2IVPROC __glewVertex2iv = NULL; -PFNGLVERTEX2SPROC __glewVertex2s = NULL; -PFNGLVERTEX2SVPROC __glewVertex2sv = NULL; -PFNGLVERTEX3DPROC __glewVertex3d = NULL; -PFNGLVERTEX3DVPROC __glewVertex3dv = NULL; -PFNGLVERTEX3FPROC __glewVertex3f = NULL; -PFNGLVERTEX3FVPROC __glewVertex3fv = NULL; -PFNGLVERTEX3IPROC __glewVertex3i = NULL; -PFNGLVERTEX3IVPROC __glewVertex3iv = NULL; -PFNGLVERTEX3SPROC __glewVertex3s = NULL; -PFNGLVERTEX3SVPROC __glewVertex3sv = NULL; -PFNGLVERTEX4DPROC __glewVertex4d = NULL; -PFNGLVERTEX4DVPROC __glewVertex4dv = NULL; -PFNGLVERTEX4FPROC __glewVertex4f = NULL; -PFNGLVERTEX4FVPROC __glewVertex4fv = NULL; -PFNGLVERTEX4IPROC __glewVertex4i = NULL; -PFNGLVERTEX4IVPROC __glewVertex4iv = NULL; -PFNGLVERTEX4SPROC __glewVertex4s = NULL; -PFNGLVERTEX4SVPROC __glewVertex4sv = NULL; -PFNGLVERTEXPOINTERPROC __glewVertexPointer = NULL; -PFNGLVIEWPORTPROC __glewViewport = NULL; - -#define fqn_from_convention(convention, fqn) \ - (const GLubyte*)fqn - -GLboolean GLEWAPIENTRY glewOpenGL11Init(void) -{ - GLboolean r = GL_FALSE; - - r = ((glAccum = (PFNGLACCUMPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glAccum"))) == NULL) || r; - r = ((glAlphaFunc = (PFNGLALPHAFUNCPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glAlphaFunc"))) == NULL) || r; - r = ((glAreTexturesResident = (PFNGLARETEXTURESRESIDENTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glAreTexturesResident"))) == NULL) || r; - r = ((glArrayElement = (PFNGLARRAYELEMENTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glArrayElement"))) == NULL) || r; - r = ((glBegin = (PFNGLBEGINPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glBegin"))) == NULL) || r; - r = ((glBindTexture = (PFNGLBINDTEXTUREPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glBindTexture"))) == NULL) || r; - r = ((glBitmap = (PFNGLBITMAPPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glBitmap"))) == NULL) || r; - r = ((glBlendFunc = (PFNGLBLENDFUNCPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glBlendFunc"))) == NULL) || r; - r = ((glCallList = (PFNGLCALLLISTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCallList"))) == NULL) || r; - r = ((glCallLists = (PFNGLCALLLISTSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCallLists"))) == NULL) || r; - r = ((glClear = (PFNGLCLEARPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClear"))) == NULL) || r; - r = ((glClearAccum = (PFNGLCLEARACCUMPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClearAccum"))) == NULL) || r; - r = ((glClearColor = (PFNGLCLEARCOLORPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClearColor"))) == NULL) || r; - r = ((glClearDepth = (PFNGLCLEARDEPTHPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClearDepth"))) == NULL) || r; - r = ((glClearIndex = (PFNGLCLEARINDEXPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClearIndex"))) == NULL) || r; - r = ((glClearStencil = (PFNGLCLEARSTENCILPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClearStencil"))) == NULL) || r; - r = ((glClipPlane = (PFNGLCLIPPLANEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glClipPlane"))) == NULL) || r; - r = ((glColor3b = (PFNGLCOLOR3BPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3b"))) == NULL) || r; - r = ((glColor3bv = (PFNGLCOLOR3BVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3bv"))) == NULL) || r; - r = ((glColor3d = (PFNGLCOLOR3DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3d"))) == NULL) || r; - r = ((glColor3dv = (PFNGLCOLOR3DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3dv"))) == NULL) || r; - r = ((glColor3f = (PFNGLCOLOR3FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3f"))) == NULL) || r; - r = ((glColor3fv = (PFNGLCOLOR3FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3fv"))) == NULL) || r; - r = ((glColor3i = (PFNGLCOLOR3IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3i"))) == NULL) || r; - r = ((glColor3iv = (PFNGLCOLOR3IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3iv"))) == NULL) || r; - r = ((glColor3s = (PFNGLCOLOR3SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3s"))) == NULL) || r; - r = ((glColor3sv = (PFNGLCOLOR3SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3sv"))) == NULL) || r; - r = ((glColor3ub = (PFNGLCOLOR3UBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3ub"))) == NULL) || r; - r = ((glColor3ubv = (PFNGLCOLOR3UBVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3ubv"))) == NULL) || r; - r = ((glColor3ui = (PFNGLCOLOR3UIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3ui"))) == NULL) || r; - r = ((glColor3uiv = (PFNGLCOLOR3UIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3uiv"))) == NULL) || r; - r = ((glColor3us = (PFNGLCOLOR3USPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3us"))) == NULL) || r; - r = ((glColor3usv = (PFNGLCOLOR3USVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor3usv"))) == NULL) || r; - r = ((glColor4b = (PFNGLCOLOR4BPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4b"))) == NULL) || r; - r = ((glColor4bv = (PFNGLCOLOR4BVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4bv"))) == NULL) || r; - r = ((glColor4d = (PFNGLCOLOR4DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4d"))) == NULL) || r; - r = ((glColor4dv = (PFNGLCOLOR4DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4dv"))) == NULL) || r; - r = ((glColor4f = (PFNGLCOLOR4FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4f"))) == NULL) || r; - r = ((glColor4fv = (PFNGLCOLOR4FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4fv"))) == NULL) || r; - r = ((glColor4i = (PFNGLCOLOR4IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4i"))) == NULL) || r; - r = ((glColor4iv = (PFNGLCOLOR4IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4iv"))) == NULL) || r; - r = ((glColor4s = (PFNGLCOLOR4SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4s"))) == NULL) || r; - r = ((glColor4sv = (PFNGLCOLOR4SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4sv"))) == NULL) || r; - r = ((glColor4ub = (PFNGLCOLOR4UBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4ub"))) == NULL) || r; - r = ((glColor4ubv = (PFNGLCOLOR4UBVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4ubv"))) == NULL) || r; - r = ((glColor4ui = (PFNGLCOLOR4UIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4ui"))) == NULL) || r; - r = ((glColor4uiv = (PFNGLCOLOR4UIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4uiv"))) == NULL) || r; - r = ((glColor4us = (PFNGLCOLOR4USPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4us"))) == NULL) || r; - r = ((glColor4usv = (PFNGLCOLOR4USVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColor4usv"))) == NULL) || r; - r = ((glColorMask = (PFNGLCOLORMASKPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColorMask"))) == NULL) || r; - r = ((glColorMaterial = (PFNGLCOLORMATERIALPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColorMaterial"))) == NULL) || r; - r = ((glColorPointer = (PFNGLCOLORPOINTERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glColorPointer"))) == NULL) || r; - r = ((glCopyPixels = (PFNGLCOPYPIXELSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCopyPixels"))) == NULL) || r; - r = ((glCopyTexImage1D = (PFNGLCOPYTEXIMAGE1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCopyTexImage1D"))) == NULL) || r; - r = ((glCopyTexImage2D = (PFNGLCOPYTEXIMAGE2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCopyTexImage2D"))) == NULL) || r; - r = ((glCopyTexSubImage1D = (PFNGLCOPYTEXSUBIMAGE1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCopyTexSubImage1D"))) == NULL) || r; - r = ((glCopyTexSubImage2D = (PFNGLCOPYTEXSUBIMAGE2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCopyTexSubImage2D"))) == NULL) || r; - r = ((glCullFace = (PFNGLCULLFACEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glCullFace"))) == NULL) || r; - r = ((glDeleteLists = (PFNGLDELETELISTSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDeleteLists"))) == NULL) || r; - r = ((glDeleteTextures = (PFNGLDELETETEXTURESPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDeleteTextures"))) == NULL) || r; - r = ((glDepthFunc = (PFNGLDEPTHFUNCPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDepthFunc"))) == NULL) || r; - r = ((glDepthMask = (PFNGLDEPTHMASKPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDepthMask"))) == NULL) || r; - r = ((glDepthRange = (PFNGLDEPTHRANGEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDepthRange"))) == NULL) || r; - r = ((glDisable = (PFNGLDISABLEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDisable"))) == NULL) || r; - r = ((glDisableClientState = (PFNGLDISABLECLIENTSTATEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDisableClientState"))) == NULL) || r; - r = ((glDrawArrays = (PFNGLDRAWARRAYSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDrawArrays"))) == NULL) || r; - r = ((glDrawBuffer = (PFNGLDRAWBUFFERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDrawBuffer"))) == NULL) || r; - r = ((glDrawElements = (PFNGLDRAWELEMENTSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDrawElements"))) == NULL) || r; - r = ((glDrawPixels = (PFNGLDRAWPIXELSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glDrawPixels"))) == NULL) || r; - r = ((glEdgeFlag = (PFNGLEDGEFLAGPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEdgeFlag"))) == NULL) || r; - r = ((glEdgeFlagPointer = (PFNGLEDGEFLAGPOINTERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEdgeFlagPointer"))) == NULL) || r; - r = ((glEdgeFlagv = (PFNGLEDGEFLAGVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEdgeFlagv"))) == NULL) || r; - r = ((glEnable = (PFNGLENABLEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEnable"))) == NULL) || r; - r = ((glEnableClientState = (PFNGLENABLECLIENTSTATEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEnableClientState"))) == NULL) || r; - r = ((glEnd = (PFNGLENDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEnd"))) == NULL) || r; - r = ((glEndList = (PFNGLENDLISTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEndList"))) == NULL) || r; - r = ((glEvalCoord1d = (PFNGLEVALCOORD1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord1d"))) == NULL) || r; - r = ((glEvalCoord1dv = (PFNGLEVALCOORD1DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord1dv"))) == NULL) || r; - r = ((glEvalCoord1f = (PFNGLEVALCOORD1FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord1f"))) == NULL) || r; - r = ((glEvalCoord1fv = (PFNGLEVALCOORD1FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord1fv"))) == NULL) || r; - r = ((glEvalCoord2d = (PFNGLEVALCOORD2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord2d"))) == NULL) || r; - r = ((glEvalCoord2dv = (PFNGLEVALCOORD2DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord2dv"))) == NULL) || r; - r = ((glEvalCoord2f = (PFNGLEVALCOORD2FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord2f"))) == NULL) || r; - r = ((glEvalCoord2fv = (PFNGLEVALCOORD2FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalCoord2fv"))) == NULL) || r; - r = ((glEvalMesh1 = (PFNGLEVALMESH1PROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalMesh1"))) == NULL) || r; - r = ((glEvalMesh2 = (PFNGLEVALMESH2PROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalMesh2"))) == NULL) || r; - r = ((glEvalPoint1 = (PFNGLEVALPOINT1PROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalPoint1"))) == NULL) || r; - r = ((glEvalPoint2 = (PFNGLEVALPOINT2PROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glEvalPoint2"))) == NULL) || r; - r = ((glFeedbackBuffer = (PFNGLFEEDBACKBUFFERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFeedbackBuffer"))) == NULL) || r; - r = ((glFinish = (PFNGLFINISHPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFinish"))) == NULL) || r; - r = ((glFlush = (PFNGLFLUSHPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFlush"))) == NULL) || r; - r = ((glFogf = (PFNGLFOGFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFogf"))) == NULL) || r; - r = ((glFogfv = (PFNGLFOGFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFogfv"))) == NULL) || r; - r = ((glFogi = (PFNGLFOGIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFogi"))) == NULL) || r; - r = ((glFogiv = (PFNGLFOGIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFogiv"))) == NULL) || r; - r = ((glFrontFace = (PFNGLFRONTFACEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFrontFace"))) == NULL) || r; - r = ((glFrustum = (PFNGLFRUSTUMPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glFrustum"))) == NULL) || r; - r = ((glGenLists = (PFNGLGENLISTSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGenLists"))) == NULL) || r; - r = ((glGenTextures = (PFNGLGENTEXTURESPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGenTextures"))) == NULL) || r; - r = ((glGetBooleanv = (PFNGLGETBOOLEANVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetBooleanv"))) == NULL) || r; - r = ((glGetClipPlane = (PFNGLGETCLIPPLANEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetClipPlane"))) == NULL) || r; - r = ((glGetDoublev = (PFNGLGETDOUBLEVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetDoublev"))) == NULL) || r; - r = ((glGetError = (PFNGLGETERRORPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetError"))) == NULL) || r; - r = ((glGetFloatv = (PFNGLGETFLOATVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetFloatv"))) == NULL) || r; - r = ((glGetIntegerv = (PFNGLGETINTEGERVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetIntegerv"))) == NULL) || r; - r = ((glGetLightfv = (PFNGLGETLIGHTFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetLightfv"))) == NULL) || r; - r = ((glGetLightiv = (PFNGLGETLIGHTIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetLightiv"))) == NULL) || r; - r = ((glGetMapdv = (PFNGLGETMAPDVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetMapdv"))) == NULL) || r; - r = ((glGetMapfv = (PFNGLGETMAPFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetMapfv"))) == NULL) || r; - r = ((glGetMapiv = (PFNGLGETMAPIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetMapiv"))) == NULL) || r; - r = ((glGetMaterialfv = (PFNGLGETMATERIALFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetMaterialfv"))) == NULL) || r; - r = ((glGetMaterialiv = (PFNGLGETMATERIALIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetMaterialiv"))) == NULL) || r; - r = ((glGetPixelMapfv = (PFNGLGETPIXELMAPFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetPixelMapfv"))) == NULL) || r; - r = ((glGetPixelMapuiv = (PFNGLGETPIXELMAPUIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetPixelMapuiv"))) == NULL) || r; - r = ((glGetPixelMapusv = (PFNGLGETPIXELMAPUSVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetPixelMapusv"))) == NULL) || r; - r = ((glGetPointerv = (PFNGLGETPOINTERVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetPointerv"))) == NULL) || r; - r = ((glGetPolygonStipple = (PFNGLGETPOLYGONSTIPPLEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetPolygonStipple"))) == NULL) || r; - r = ((glGetString = (PFNGLGETSTRINGPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetString"))) == NULL) || r; - r = ((glGetTexEnvfv = (PFNGLGETTEXENVFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexEnvfv"))) == NULL) || r; - r = ((glGetTexEnviv = (PFNGLGETTEXENVIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexEnviv"))) == NULL) || r; - r = ((glGetTexGendv = (PFNGLGETTEXGENDVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexGendv"))) == NULL) || r; - r = ((glGetTexGenfv = (PFNGLGETTEXGENFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexGenfv"))) == NULL) || r; - r = ((glGetTexGeniv = (PFNGLGETTEXGENIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexGeniv"))) == NULL) || r; - r = ((glGetTexImage = (PFNGLGETTEXIMAGEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexImage"))) == NULL) || r; - r = ((glGetTexLevelParameterfv = (PFNGLGETTEXLEVELPARAMETERFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexLevelParameterfv"))) == NULL) || r; - r = ((glGetTexLevelParameteriv = (PFNGLGETTEXLEVELPARAMETERIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexLevelParameteriv"))) == NULL) || r; - r = ((glGetTexParameterfv = (PFNGLGETTEXPARAMETERFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexParameterfv"))) == NULL) || r; - r = ((glGetTexParameteriv = (PFNGLGETTEXPARAMETERIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glGetTexParameteriv"))) == NULL) || r; - r = ((glHint = (PFNGLHINTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glHint"))) == NULL) || r; - r = ((glIndexMask = (PFNGLINDEXMASKPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexMask"))) == NULL) || r; - r = ((glIndexPointer = (PFNGLINDEXPOINTERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexPointer"))) == NULL) || r; - r = ((glIndexd = (PFNGLINDEXDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexd"))) == NULL) || r; - r = ((glIndexdv = (PFNGLINDEXDVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexdv"))) == NULL) || r; - r = ((glIndexf = (PFNGLINDEXFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexf"))) == NULL) || r; - r = ((glIndexfv = (PFNGLINDEXFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexfv"))) == NULL) || r; - r = ((glIndexi = (PFNGLINDEXIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexi"))) == NULL) || r; - r = ((glIndexiv = (PFNGLINDEXIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexiv"))) == NULL) || r; - r = ((glIndexs = (PFNGLINDEXSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexs"))) == NULL) || r; - r = ((glIndexsv = (PFNGLINDEXSVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexsv"))) == NULL) || r; - r = ((glIndexub = (PFNGLINDEXUBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexub"))) == NULL) || r; - r = ((glIndexubv = (PFNGLINDEXUBVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIndexubv"))) == NULL) || r; - r = ((glInitNames = (PFNGLINITNAMESPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glInitNames"))) == NULL) || r; - r = ((glInterleavedArrays = (PFNGLINTERLEAVEDARRAYSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glInterleavedArrays"))) == NULL) || r; - r = ((glIsEnabled = (PFNGLISENABLEDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIsEnabled"))) == NULL) || r; - r = ((glIsList = (PFNGLISLISTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIsList"))) == NULL) || r; - r = ((glIsTexture = (PFNGLISTEXTUREPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glIsTexture"))) == NULL) || r; - r = ((glLightModelf = (PFNGLLIGHTMODELFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightModelf"))) == NULL) || r; - r = ((glLightModelfv = (PFNGLLIGHTMODELFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightModelfv"))) == NULL) || r; - r = ((glLightModeli = (PFNGLLIGHTMODELIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightModeli"))) == NULL) || r; - r = ((glLightModeliv = (PFNGLLIGHTMODELIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightModeliv"))) == NULL) || r; - r = ((glLightf = (PFNGLLIGHTFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightf"))) == NULL) || r; - r = ((glLightfv = (PFNGLLIGHTFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightfv"))) == NULL) || r; - r = ((glLighti = (PFNGLLIGHTIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLighti"))) == NULL) || r; - r = ((glLightiv = (PFNGLLIGHTIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLightiv"))) == NULL) || r; - r = ((glLineStipple = (PFNGLLINESTIPPLEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLineStipple"))) == NULL) || r; - r = ((glLineWidth = (PFNGLLINEWIDTHPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLineWidth"))) == NULL) || r; - r = ((glListBase = (PFNGLLISTBASEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glListBase"))) == NULL) || r; - r = ((glLoadIdentity = (PFNGLLOADIDENTITYPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLoadIdentity"))) == NULL) || r; - r = ((glLoadMatrixd = (PFNGLLOADMATRIXDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLoadMatrixd"))) == NULL) || r; - r = ((glLoadMatrixf = (PFNGLLOADMATRIXFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLoadMatrixf"))) == NULL) || r; - r = ((glLoadName = (PFNGLLOADNAMEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLoadName"))) == NULL) || r; - r = ((glLogicOp = (PFNGLLOGICOPPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glLogicOp"))) == NULL) || r; - r = ((glMap1d = (PFNGLMAP1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMap1d"))) == NULL) || r; - r = ((glMap1f = (PFNGLMAP1FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMap1f"))) == NULL) || r; - r = ((glMap2d = (PFNGLMAP2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMap2d"))) == NULL) || r; - r = ((glMap2f = (PFNGLMAP2FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMap2f"))) == NULL) || r; - r = ((glMapGrid1d = (PFNGLMAPGRID1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMapGrid1d"))) == NULL) || r; - r = ((glMapGrid1f = (PFNGLMAPGRID1FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMapGrid1f"))) == NULL) || r; - r = ((glMapGrid2d = (PFNGLMAPGRID2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMapGrid2d"))) == NULL) || r; - r = ((glMapGrid2f = (PFNGLMAPGRID2FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMapGrid2f"))) == NULL) || r; - r = ((glMaterialf = (PFNGLMATERIALFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMaterialf"))) == NULL) || r; - r = ((glMaterialfv = (PFNGLMATERIALFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMaterialfv"))) == NULL) || r; - r = ((glMateriali = (PFNGLMATERIALIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMateriali"))) == NULL) || r; - r = ((glMaterialiv = (PFNGLMATERIALIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMaterialiv"))) == NULL) || r; - r = ((glMatrixMode = (PFNGLMATRIXMODEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMatrixMode"))) == NULL) || r; - r = ((glMultMatrixd = (PFNGLMULTMATRIXDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMultMatrixd"))) == NULL) || r; - r = ((glMultMatrixf = (PFNGLMULTMATRIXFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glMultMatrixf"))) == NULL) || r; - r = ((glNewList = (PFNGLNEWLISTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNewList"))) == NULL) || r; - r = ((glNormal3b = (PFNGLNORMAL3BPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3b"))) == NULL) || r; - r = ((glNormal3bv = (PFNGLNORMAL3BVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3bv"))) == NULL) || r; - r = ((glNormal3d = (PFNGLNORMAL3DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3d"))) == NULL) || r; - r = ((glNormal3dv = (PFNGLNORMAL3DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3dv"))) == NULL) || r; - r = ((glNormal3f = (PFNGLNORMAL3FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3f"))) == NULL) || r; - r = ((glNormal3fv = (PFNGLNORMAL3FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3fv"))) == NULL) || r; - r = ((glNormal3i = (PFNGLNORMAL3IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3i"))) == NULL) || r; - r = ((glNormal3iv = (PFNGLNORMAL3IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3iv"))) == NULL) || r; - r = ((glNormal3s = (PFNGLNORMAL3SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3s"))) == NULL) || r; - r = ((glNormal3sv = (PFNGLNORMAL3SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormal3sv"))) == NULL) || r; - r = ((glNormalPointer = (PFNGLNORMALPOINTERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glNormalPointer"))) == NULL) || r; - r = ((glOrtho = (PFNGLORTHOPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glOrtho"))) == NULL) || r; - r = ((glPassThrough = (PFNGLPASSTHROUGHPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPassThrough"))) == NULL) || r; - r = ((glPixelMapfv = (PFNGLPIXELMAPFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelMapfv"))) == NULL) || r; - r = ((glPixelMapuiv = (PFNGLPIXELMAPUIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelMapuiv"))) == NULL) || r; - r = ((glPixelMapusv = (PFNGLPIXELMAPUSVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelMapusv"))) == NULL) || r; - r = ((glPixelStoref = (PFNGLPIXELSTOREFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelStoref"))) == NULL) || r; - r = ((glPixelStorei = (PFNGLPIXELSTOREIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelStorei"))) == NULL) || r; - r = ((glPixelTransferf = (PFNGLPIXELTRANSFERFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelTransferf"))) == NULL) || r; - r = ((glPixelTransferi = (PFNGLPIXELTRANSFERIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelTransferi"))) == NULL) || r; - r = ((glPixelZoom = (PFNGLPIXELZOOMPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPixelZoom"))) == NULL) || r; - r = ((glPointSize = (PFNGLPOINTSIZEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPointSize"))) == NULL) || r; - r = ((glPolygonMode = (PFNGLPOLYGONMODEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPolygonMode"))) == NULL) || r; - r = ((glPolygonOffset = (PFNGLPOLYGONOFFSETPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPolygonOffset"))) == NULL) || r; - r = ((glPolygonStipple = (PFNGLPOLYGONSTIPPLEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPolygonStipple"))) == NULL) || r; - r = ((glPopAttrib = (PFNGLPOPATTRIBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPopAttrib"))) == NULL) || r; - r = ((glPopClientAttrib = (PFNGLPOPCLIENTATTRIBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPopClientAttrib"))) == NULL) || r; - r = ((glPopMatrix = (PFNGLPOPMATRIXPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPopMatrix"))) == NULL) || r; - r = ((glPopName = (PFNGLPOPNAMEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPopName"))) == NULL) || r; - r = ((glPrioritizeTextures = (PFNGLPRIORITIZETEXTURESPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPrioritizeTextures"))) == NULL) || r; - r = ((glPushAttrib = (PFNGLPUSHATTRIBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPushAttrib"))) == NULL) || r; - r = ((glPushClientAttrib = (PFNGLPUSHCLIENTATTRIBPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPushClientAttrib"))) == NULL) || r; - r = ((glPushMatrix = (PFNGLPUSHMATRIXPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPushMatrix"))) == NULL) || r; - r = ((glPushName = (PFNGLPUSHNAMEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glPushName"))) == NULL) || r; - r = ((glRasterPos2d = (PFNGLRASTERPOS2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2d"))) == NULL) || r; - r = ((glRasterPos2dv = (PFNGLRASTERPOS2DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2dv"))) == NULL) || r; - r = ((glRasterPos2f = (PFNGLRASTERPOS2FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2f"))) == NULL) || r; - r = ((glRasterPos2fv = (PFNGLRASTERPOS2FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2fv"))) == NULL) || r; - r = ((glRasterPos2i = (PFNGLRASTERPOS2IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2i"))) == NULL) || r; - r = ((glRasterPos2iv = (PFNGLRASTERPOS2IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2iv"))) == NULL) || r; - r = ((glRasterPos2s = (PFNGLRASTERPOS2SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2s"))) == NULL) || r; - r = ((glRasterPos2sv = (PFNGLRASTERPOS2SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos2sv"))) == NULL) || r; - r = ((glRasterPos3d = (PFNGLRASTERPOS3DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3d"))) == NULL) || r; - r = ((glRasterPos3dv = (PFNGLRASTERPOS3DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3dv"))) == NULL) || r; - r = ((glRasterPos3f = (PFNGLRASTERPOS3FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3f"))) == NULL) || r; - r = ((glRasterPos3fv = (PFNGLRASTERPOS3FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3fv"))) == NULL) || r; - r = ((glRasterPos3i = (PFNGLRASTERPOS3IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3i"))) == NULL) || r; - r = ((glRasterPos3iv = (PFNGLRASTERPOS3IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3iv"))) == NULL) || r; - r = ((glRasterPos3s = (PFNGLRASTERPOS3SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3s"))) == NULL) || r; - r = ((glRasterPos3sv = (PFNGLRASTERPOS3SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos3sv"))) == NULL) || r; - r = ((glRasterPos4d = (PFNGLRASTERPOS4DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4d"))) == NULL) || r; - r = ((glRasterPos4dv = (PFNGLRASTERPOS4DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4dv"))) == NULL) || r; - r = ((glRasterPos4f = (PFNGLRASTERPOS4FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4f"))) == NULL) || r; - r = ((glRasterPos4fv = (PFNGLRASTERPOS4FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4fv"))) == NULL) || r; - r = ((glRasterPos4i = (PFNGLRASTERPOS4IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4i"))) == NULL) || r; - r = ((glRasterPos4iv = (PFNGLRASTERPOS4IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4iv"))) == NULL) || r; - r = ((glRasterPos4s = (PFNGLRASTERPOS4SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4s"))) == NULL) || r; - r = ((glRasterPos4sv = (PFNGLRASTERPOS4SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRasterPos4sv"))) == NULL) || r; - r = ((glReadBuffer = (PFNGLREADBUFFERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glReadBuffer"))) == NULL) || r; - r = ((glReadPixels = (PFNGLREADPIXELSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glReadPixels"))) == NULL) || r; - r = ((glRectd = (PFNGLRECTDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRectd"))) == NULL) || r; - r = ((glRectdv = (PFNGLRECTDVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRectdv"))) == NULL) || r; - r = ((glRectf = (PFNGLRECTFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRectf"))) == NULL) || r; - r = ((glRectfv = (PFNGLRECTFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRectfv"))) == NULL) || r; - r = ((glRecti = (PFNGLRECTIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRecti"))) == NULL) || r; - r = ((glRectiv = (PFNGLRECTIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRectiv"))) == NULL) || r; - r = ((glRects = (PFNGLRECTSPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRects"))) == NULL) || r; - r = ((glRectsv = (PFNGLRECTSVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRectsv"))) == NULL) || r; - r = ((glRenderMode = (PFNGLRENDERMODEPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRenderMode"))) == NULL) || r; - r = ((glRotated = (PFNGLROTATEDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRotated"))) == NULL) || r; - r = ((glRotatef = (PFNGLROTATEFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glRotatef"))) == NULL) || r; - r = ((glScaled = (PFNGLSCALEDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glScaled"))) == NULL) || r; - r = ((glScalef = (PFNGLSCALEFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glScalef"))) == NULL) || r; - r = ((glScissor = (PFNGLSCISSORPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glScissor"))) == NULL) || r; - r = ((glSelectBuffer = (PFNGLSELECTBUFFERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glSelectBuffer"))) == NULL) || r; - r = ((glShadeModel = (PFNGLSHADEMODELPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glShadeModel"))) == NULL) || r; - r = ((glStencilFunc = (PFNGLSTENCILFUNCPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glStencilFunc"))) == NULL) || r; - r = ((glStencilMask = (PFNGLSTENCILMASKPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glStencilMask"))) == NULL) || r; - r = ((glStencilOp = (PFNGLSTENCILOPPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glStencilOp"))) == NULL) || r; - r = ((glTexCoord1d = (PFNGLTEXCOORD1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1d"))) == NULL) || r; - r = ((glTexCoord1dv = (PFNGLTEXCOORD1DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1dv"))) == NULL) || r; - r = ((glTexCoord1f = (PFNGLTEXCOORD1FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1f"))) == NULL) || r; - r = ((glTexCoord1fv = (PFNGLTEXCOORD1FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1fv"))) == NULL) || r; - r = ((glTexCoord1i = (PFNGLTEXCOORD1IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1i"))) == NULL) || r; - r = ((glTexCoord1iv = (PFNGLTEXCOORD1IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1iv"))) == NULL) || r; - r = ((glTexCoord1s = (PFNGLTEXCOORD1SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1s"))) == NULL) || r; - r = ((glTexCoord1sv = (PFNGLTEXCOORD1SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord1sv"))) == NULL) || r; - r = ((glTexCoord2d = (PFNGLTEXCOORD2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2d"))) == NULL) || r; - r = ((glTexCoord2dv = (PFNGLTEXCOORD2DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2dv"))) == NULL) || r; - r = ((glTexCoord2f = (PFNGLTEXCOORD2FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2f"))) == NULL) || r; - r = ((glTexCoord2fv = (PFNGLTEXCOORD2FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2fv"))) == NULL) || r; - r = ((glTexCoord2i = (PFNGLTEXCOORD2IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2i"))) == NULL) || r; - r = ((glTexCoord2iv = (PFNGLTEXCOORD2IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2iv"))) == NULL) || r; - r = ((glTexCoord2s = (PFNGLTEXCOORD2SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2s"))) == NULL) || r; - r = ((glTexCoord2sv = (PFNGLTEXCOORD2SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord2sv"))) == NULL) || r; - r = ((glTexCoord3d = (PFNGLTEXCOORD3DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3d"))) == NULL) || r; - r = ((glTexCoord3dv = (PFNGLTEXCOORD3DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3dv"))) == NULL) || r; - r = ((glTexCoord3f = (PFNGLTEXCOORD3FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3f"))) == NULL) || r; - r = ((glTexCoord3fv = (PFNGLTEXCOORD3FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3fv"))) == NULL) || r; - r = ((glTexCoord3i = (PFNGLTEXCOORD3IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3i"))) == NULL) || r; - r = ((glTexCoord3iv = (PFNGLTEXCOORD3IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3iv"))) == NULL) || r; - r = ((glTexCoord3s = (PFNGLTEXCOORD3SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3s"))) == NULL) || r; - r = ((glTexCoord3sv = (PFNGLTEXCOORD3SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord3sv"))) == NULL) || r; - r = ((glTexCoord4d = (PFNGLTEXCOORD4DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4d"))) == NULL) || r; - r = ((glTexCoord4dv = (PFNGLTEXCOORD4DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4dv"))) == NULL) || r; - r = ((glTexCoord4f = (PFNGLTEXCOORD4FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4f"))) == NULL) || r; - r = ((glTexCoord4fv = (PFNGLTEXCOORD4FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4fv"))) == NULL) || r; - r = ((glTexCoord4i = (PFNGLTEXCOORD4IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4i"))) == NULL) || r; - r = ((glTexCoord4iv = (PFNGLTEXCOORD4IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4iv"))) == NULL) || r; - r = ((glTexCoord4s = (PFNGLTEXCOORD4SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4s"))) == NULL) || r; - r = ((glTexCoord4sv = (PFNGLTEXCOORD4SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoord4sv"))) == NULL) || r; - r = ((glTexCoordPointer = (PFNGLTEXCOORDPOINTERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexCoordPointer"))) == NULL) || r; - r = ((glTexEnvf = (PFNGLTEXENVFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexEnvf"))) == NULL) || r; - r = ((glTexEnvfv = (PFNGLTEXENVFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexEnvfv"))) == NULL) || r; - r = ((glTexEnvi = (PFNGLTEXENVIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexEnvi"))) == NULL) || r; - r = ((glTexEnviv = (PFNGLTEXENVIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexEnviv"))) == NULL) || r; - r = ((glTexGend = (PFNGLTEXGENDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexGend"))) == NULL) || r; - r = ((glTexGendv = (PFNGLTEXGENDVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexGendv"))) == NULL) || r; - r = ((glTexGenf = (PFNGLTEXGENFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexGenf"))) == NULL) || r; - r = ((glTexGenfv = (PFNGLTEXGENFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexGenfv"))) == NULL) || r; - r = ((glTexGeni = (PFNGLTEXGENIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexGeni"))) == NULL) || r; - r = ((glTexGeniv = (PFNGLTEXGENIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexGeniv"))) == NULL) || r; - r = ((glTexImage1D = (PFNGLTEXIMAGE1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexImage1D"))) == NULL) || r; - r = ((glTexImage2D = (PFNGLTEXIMAGE2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexImage2D"))) == NULL) || r; - r = ((glTexParameterf = (PFNGLTEXPARAMETERFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexParameterf"))) == NULL) || r; - r = ((glTexParameterfv = (PFNGLTEXPARAMETERFVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexParameterfv"))) == NULL) || r; - r = ((glTexParameteri = (PFNGLTEXPARAMETERIPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexParameteri"))) == NULL) || r; - r = ((glTexParameteriv = (PFNGLTEXPARAMETERIVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexParameteriv"))) == NULL) || r; - r = ((glTexSubImage1D = (PFNGLTEXSUBIMAGE1DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexSubImage1D"))) == NULL) || r; - r = ((glTexSubImage2D = (PFNGLTEXSUBIMAGE2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTexSubImage2D"))) == NULL) || r; - r = ((glTranslated = (PFNGLTRANSLATEDPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTranslated"))) == NULL) || r; - r = ((glTranslatef = (PFNGLTRANSLATEFPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glTranslatef"))) == NULL) || r; - r = ((glVertex2d = (PFNGLVERTEX2DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2d"))) == NULL) || r; - r = ((glVertex2dv = (PFNGLVERTEX2DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2dv"))) == NULL) || r; - r = ((glVertex2f = (PFNGLVERTEX2FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2f"))) == NULL) || r; - r = ((glVertex2fv = (PFNGLVERTEX2FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2fv"))) == NULL) || r; - r = ((glVertex2i = (PFNGLVERTEX2IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2i"))) == NULL) || r; - r = ((glVertex2iv = (PFNGLVERTEX2IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2iv"))) == NULL) || r; - r = ((glVertex2s = (PFNGLVERTEX2SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2s"))) == NULL) || r; - r = ((glVertex2sv = (PFNGLVERTEX2SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex2sv"))) == NULL) || r; - r = ((glVertex3d = (PFNGLVERTEX3DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3d"))) == NULL) || r; - r = ((glVertex3dv = (PFNGLVERTEX3DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3dv"))) == NULL) || r; - r = ((glVertex3f = (PFNGLVERTEX3FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3f"))) == NULL) || r; - r = ((glVertex3fv = (PFNGLVERTEX3FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3fv"))) == NULL) || r; - r = ((glVertex3i = (PFNGLVERTEX3IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3i"))) == NULL) || r; - r = ((glVertex3iv = (PFNGLVERTEX3IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3iv"))) == NULL) || r; - r = ((glVertex3s = (PFNGLVERTEX3SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3s"))) == NULL) || r; - r = ((glVertex3sv = (PFNGLVERTEX3SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex3sv"))) == NULL) || r; - r = ((glVertex4d = (PFNGLVERTEX4DPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4d"))) == NULL) || r; - r = ((glVertex4dv = (PFNGLVERTEX4DVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4dv"))) == NULL) || r; - r = ((glVertex4f = (PFNGLVERTEX4FPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4f"))) == NULL) || r; - r = ((glVertex4fv = (PFNGLVERTEX4FVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4fv"))) == NULL) || r; - r = ((glVertex4i = (PFNGLVERTEX4IPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4i"))) == NULL) || r; - r = ((glVertex4iv = (PFNGLVERTEX4IVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4iv"))) == NULL) || r; - r = ((glVertex4s = (PFNGLVERTEX4SPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4s"))) == NULL) || r; - r = ((glVertex4sv = (PFNGLVERTEX4SVPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertex4sv"))) == NULL) || r; - r = ((glVertexPointer = (PFNGLVERTEXPOINTERPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glVertexPointer"))) == NULL) || r; - r = ((glViewport = (PFNGLVIEWPORTPROC)glewGetProcAddress(fqn_from_convention(glew_convention, "glViewport"))) == NULL) || r; - - if (r==0) - { - printf("glewOpenGL11Init dynamically loaded using dlopen/dlsym OK\n"); - } - return r; -} -#endif //GLEW_INIT_OPENGL11_FUNCTIONS - - -GLenum GLEWAPIENTRY glewInit (void) -{ - GLenum r; - r = glewContextInit(); - if ( r != 0 ) return r; -#if defined(_WIN32) - return wglewContextInit(); -#elif !defined(__ANDROID__) && !defined(__native_client__) && (!defined(__APPLE__) || defined(GLEW_APPLE_GLX)) /* _UNIX */ - return glxewContextInit(); -#else - return r; -#endif /* _WIN32 */ -} - -#endif /* !GLEW_MX */ -#ifdef GLEW_MX -GLboolean GLEWAPIENTRY glewContextIsSupported (const GLEWContext* ctx, const char* name) -#else -GLboolean GLEWAPIENTRY glewIsSupported (const char* name) -#endif -{ - GLubyte* pos = (GLubyte*)name; - GLuint len = _glewStrLen(pos); - GLboolean ret = GL_TRUE; - while (ret && len > 0) - { - if (_glewStrSame1(&pos, &len, (const GLubyte*)"GL_", 3)) - { - if (_glewStrSame2(&pos, &len, (const GLubyte*)"VERSION_", 8)) - { -#ifdef GL_VERSION_1_2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_2", 3)) - { - ret = GLEW_VERSION_1_2; - continue; - } -#endif -#ifdef GL_VERSION_1_2_1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_2_1", 5)) - { - ret = GLEW_VERSION_1_2_1; - continue; - } -#endif -#ifdef GL_VERSION_1_3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_3", 3)) - { - ret = GLEW_VERSION_1_3; - continue; - } -#endif -#ifdef GL_VERSION_1_4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_4", 3)) - { - ret = GLEW_VERSION_1_4; - continue; - } -#endif -#ifdef GL_VERSION_1_5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_5", 3)) - { - ret = GLEW_VERSION_1_5; - continue; - } -#endif -#ifdef GL_VERSION_2_0 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"2_0", 3)) - { - ret = GLEW_VERSION_2_0; - continue; - } -#endif -#ifdef GL_VERSION_2_1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"2_1", 3)) - { - ret = GLEW_VERSION_2_1; - continue; - } -#endif -#ifdef GL_VERSION_3_0 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_0", 3)) - { - ret = GLEW_VERSION_3_0; - continue; - } -#endif -#ifdef GL_VERSION_3_1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_1", 3)) - { - ret = GLEW_VERSION_3_1; - continue; - } -#endif -#ifdef GL_VERSION_3_2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_2", 3)) - { - ret = GLEW_VERSION_3_2; - continue; - } -#endif -#ifdef GL_VERSION_3_3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"3_3", 3)) - { - ret = GLEW_VERSION_3_3; - continue; - } -#endif -#ifdef GL_VERSION_4_0 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"4_0", 3)) - { - ret = GLEW_VERSION_4_0; - continue; - } -#endif -#ifdef GL_VERSION_4_1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"4_1", 3)) - { - ret = GLEW_VERSION_4_1; - continue; - } -#endif -#ifdef GL_VERSION_4_2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"4_2", 3)) - { - ret = GLEW_VERSION_4_2; - continue; - } -#endif -#ifdef GL_VERSION_4_3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"4_3", 3)) - { - ret = GLEW_VERSION_4_3; - continue; - } -#endif -#ifdef GL_VERSION_4_4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"4_4", 3)) - { - ret = GLEW_VERSION_4_4; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DFX_", 5)) - { -#ifdef GL_3DFX_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLEW_3DFX_multisample; - continue; - } -#endif -#ifdef GL_3DFX_tbuffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"tbuffer", 7)) - { - ret = GLEW_3DFX_tbuffer; - continue; - } -#endif -#ifdef GL_3DFX_texture_compression_FXT1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_FXT1", 24)) - { - ret = GLEW_3DFX_texture_compression_FXT1; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"AMD_", 4)) - { -#ifdef GL_AMD_blend_minmax_factor - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_minmax_factor", 19)) - { - ret = GLEW_AMD_blend_minmax_factor; - continue; - } -#endif -#ifdef GL_AMD_conservative_depth - if (_glewStrSame3(&pos, &len, (const GLubyte*)"conservative_depth", 18)) - { - ret = GLEW_AMD_conservative_depth; - continue; - } -#endif -#ifdef GL_AMD_debug_output - if (_glewStrSame3(&pos, &len, (const GLubyte*)"debug_output", 12)) - { - ret = GLEW_AMD_debug_output; - continue; - } -#endif -#ifdef GL_AMD_depth_clamp_separate - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_clamp_separate", 20)) - { - ret = GLEW_AMD_depth_clamp_separate; - continue; - } -#endif -#ifdef GL_AMD_draw_buffers_blend - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers_blend", 18)) - { - ret = GLEW_AMD_draw_buffers_blend; - continue; - } -#endif -#ifdef GL_AMD_interleaved_elements - if (_glewStrSame3(&pos, &len, (const GLubyte*)"interleaved_elements", 20)) - { - ret = GLEW_AMD_interleaved_elements; - continue; - } -#endif -#ifdef GL_AMD_multi_draw_indirect - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multi_draw_indirect", 19)) - { - ret = GLEW_AMD_multi_draw_indirect; - continue; - } -#endif -#ifdef GL_AMD_name_gen_delete - if (_glewStrSame3(&pos, &len, (const GLubyte*)"name_gen_delete", 15)) - { - ret = GLEW_AMD_name_gen_delete; - continue; - } -#endif -#ifdef GL_AMD_performance_monitor - if (_glewStrSame3(&pos, &len, (const GLubyte*)"performance_monitor", 19)) - { - ret = GLEW_AMD_performance_monitor; - continue; - } -#endif -#ifdef GL_AMD_pinned_memory - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pinned_memory", 13)) - { - ret = GLEW_AMD_pinned_memory; - continue; - } -#endif -#ifdef GL_AMD_query_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"query_buffer_object", 19)) - { - ret = GLEW_AMD_query_buffer_object; - continue; - } -#endif -#ifdef GL_AMD_sample_positions - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sample_positions", 16)) - { - ret = GLEW_AMD_sample_positions; - continue; - } -#endif -#ifdef GL_AMD_seamless_cubemap_per_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"seamless_cubemap_per_texture", 28)) - { - ret = GLEW_AMD_seamless_cubemap_per_texture; - continue; - } -#endif -#ifdef GL_AMD_shader_stencil_export - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_stencil_export", 21)) - { - ret = GLEW_AMD_shader_stencil_export; - continue; - } -#endif -#ifdef GL_AMD_shader_trinary_minmax - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_trinary_minmax", 21)) - { - ret = GLEW_AMD_shader_trinary_minmax; - continue; - } -#endif -#ifdef GL_AMD_sparse_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sparse_texture", 14)) - { - ret = GLEW_AMD_sparse_texture; - continue; - } -#endif -#ifdef GL_AMD_stencil_operation_extended - if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_operation_extended", 26)) - { - ret = GLEW_AMD_stencil_operation_extended; - continue; - } -#endif -#ifdef GL_AMD_texture_texture4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_texture4", 16)) - { - ret = GLEW_AMD_texture_texture4; - continue; - } -#endif -#ifdef GL_AMD_transform_feedback3_lines_triangles - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback3_lines_triangles", 35)) - { - ret = GLEW_AMD_transform_feedback3_lines_triangles; - continue; - } -#endif -#ifdef GL_AMD_vertex_shader_layer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader_layer", 19)) - { - ret = GLEW_AMD_vertex_shader_layer; - continue; - } -#endif -#ifdef GL_AMD_vertex_shader_tessellator - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader_tessellator", 25)) - { - ret = GLEW_AMD_vertex_shader_tessellator; - continue; - } -#endif -#ifdef GL_AMD_vertex_shader_viewport_index - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader_viewport_index", 28)) - { - ret = GLEW_AMD_vertex_shader_viewport_index; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ANGLE_", 6)) - { -#ifdef GL_ANGLE_depth_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_texture", 13)) - { - ret = GLEW_ANGLE_depth_texture; - continue; - } -#endif -#ifdef GL_ANGLE_framebuffer_blit - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_blit", 16)) - { - ret = GLEW_ANGLE_framebuffer_blit; - continue; - } -#endif -#ifdef GL_ANGLE_framebuffer_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_multisample", 23)) - { - ret = GLEW_ANGLE_framebuffer_multisample; - continue; - } -#endif -#ifdef GL_ANGLE_instanced_arrays - if (_glewStrSame3(&pos, &len, (const GLubyte*)"instanced_arrays", 16)) - { - ret = GLEW_ANGLE_instanced_arrays; - continue; - } -#endif -#ifdef GL_ANGLE_pack_reverse_row_order - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pack_reverse_row_order", 22)) - { - ret = GLEW_ANGLE_pack_reverse_row_order; - continue; - } -#endif -#ifdef GL_ANGLE_program_binary - if (_glewStrSame3(&pos, &len, (const GLubyte*)"program_binary", 14)) - { - ret = GLEW_ANGLE_program_binary; - continue; - } -#endif -#ifdef GL_ANGLE_texture_compression_dxt1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_dxt1", 24)) - { - ret = GLEW_ANGLE_texture_compression_dxt1; - continue; - } -#endif -#ifdef GL_ANGLE_texture_compression_dxt3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_dxt3", 24)) - { - ret = GLEW_ANGLE_texture_compression_dxt3; - continue; - } -#endif -#ifdef GL_ANGLE_texture_compression_dxt5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_dxt5", 24)) - { - ret = GLEW_ANGLE_texture_compression_dxt5; - continue; - } -#endif -#ifdef GL_ANGLE_texture_usage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_usage", 13)) - { - ret = GLEW_ANGLE_texture_usage; - continue; - } -#endif -#ifdef GL_ANGLE_timer_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"timer_query", 11)) - { - ret = GLEW_ANGLE_timer_query; - continue; - } -#endif -#ifdef GL_ANGLE_translated_shader_source - if (_glewStrSame3(&pos, &len, (const GLubyte*)"translated_shader_source", 24)) - { - ret = GLEW_ANGLE_translated_shader_source; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"APPLE_", 6)) - { -#ifdef GL_APPLE_aux_depth_stencil - if (_glewStrSame3(&pos, &len, (const GLubyte*)"aux_depth_stencil", 17)) - { - ret = GLEW_APPLE_aux_depth_stencil; - continue; - } -#endif -#ifdef GL_APPLE_client_storage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"client_storage", 14)) - { - ret = GLEW_APPLE_client_storage; - continue; - } -#endif -#ifdef GL_APPLE_element_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"element_array", 13)) - { - ret = GLEW_APPLE_element_array; - continue; - } -#endif -#ifdef GL_APPLE_fence - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fence", 5)) - { - ret = GLEW_APPLE_fence; - continue; - } -#endif -#ifdef GL_APPLE_float_pixels - if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_pixels", 12)) - { - ret = GLEW_APPLE_float_pixels; - continue; - } -#endif -#ifdef GL_APPLE_flush_buffer_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"flush_buffer_range", 18)) - { - ret = GLEW_APPLE_flush_buffer_range; - continue; - } -#endif -#ifdef GL_APPLE_object_purgeable - if (_glewStrSame3(&pos, &len, (const GLubyte*)"object_purgeable", 16)) - { - ret = GLEW_APPLE_object_purgeable; - continue; - } -#endif -#ifdef GL_APPLE_pixel_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_buffer", 12)) - { - ret = GLEW_APPLE_pixel_buffer; - continue; - } -#endif -#ifdef GL_APPLE_rgb_422 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"rgb_422", 7)) - { - ret = GLEW_APPLE_rgb_422; - continue; - } -#endif -#ifdef GL_APPLE_row_bytes - if (_glewStrSame3(&pos, &len, (const GLubyte*)"row_bytes", 9)) - { - ret = GLEW_APPLE_row_bytes; - continue; - } -#endif -#ifdef GL_APPLE_specular_vector - if (_glewStrSame3(&pos, &len, (const GLubyte*)"specular_vector", 15)) - { - ret = GLEW_APPLE_specular_vector; - continue; - } -#endif -#ifdef GL_APPLE_texture_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_range", 13)) - { - ret = GLEW_APPLE_texture_range; - continue; - } -#endif -#ifdef GL_APPLE_transform_hint - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_hint", 14)) - { - ret = GLEW_APPLE_transform_hint; - continue; - } -#endif -#ifdef GL_APPLE_vertex_array_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_object", 19)) - { - ret = GLEW_APPLE_vertex_array_object; - continue; - } -#endif -#ifdef GL_APPLE_vertex_array_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) - { - ret = GLEW_APPLE_vertex_array_range; - continue; - } -#endif -#ifdef GL_APPLE_vertex_program_evaluators - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program_evaluators", 25)) - { - ret = GLEW_APPLE_vertex_program_evaluators; - continue; - } -#endif -#ifdef GL_APPLE_ycbcr_422 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ycbcr_422", 9)) - { - ret = GLEW_APPLE_ycbcr_422; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ARB_", 4)) - { -#ifdef GL_ARB_ES2_compatibility - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ES2_compatibility", 17)) - { - ret = GLEW_ARB_ES2_compatibility; - continue; - } -#endif -#ifdef GL_ARB_ES3_compatibility - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ES3_compatibility", 17)) - { - ret = GLEW_ARB_ES3_compatibility; - continue; - } -#endif -#ifdef GL_ARB_arrays_of_arrays - if (_glewStrSame3(&pos, &len, (const GLubyte*)"arrays_of_arrays", 16)) - { - ret = GLEW_ARB_arrays_of_arrays; - continue; - } -#endif -#ifdef GL_ARB_base_instance - if (_glewStrSame3(&pos, &len, (const GLubyte*)"base_instance", 13)) - { - ret = GLEW_ARB_base_instance; - continue; - } -#endif -#ifdef GL_ARB_bindless_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"bindless_texture", 16)) - { - ret = GLEW_ARB_bindless_texture; - continue; - } -#endif -#ifdef GL_ARB_blend_func_extended - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_func_extended", 19)) - { - ret = GLEW_ARB_blend_func_extended; - continue; - } -#endif -#ifdef GL_ARB_buffer_storage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"buffer_storage", 14)) - { - ret = GLEW_ARB_buffer_storage; - continue; - } -#endif -#ifdef GL_ARB_cl_event - if (_glewStrSame3(&pos, &len, (const GLubyte*)"cl_event", 8)) - { - ret = GLEW_ARB_cl_event; - continue; - } -#endif -#ifdef GL_ARB_clear_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"clear_buffer_object", 19)) - { - ret = GLEW_ARB_clear_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_clear_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"clear_texture", 13)) - { - ret = GLEW_ARB_clear_texture; - continue; - } -#endif -#ifdef GL_ARB_color_buffer_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_buffer_float", 18)) - { - ret = GLEW_ARB_color_buffer_float; - continue; - } -#endif -#ifdef GL_ARB_compatibility - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compatibility", 13)) - { - ret = GLEW_ARB_compatibility; - continue; - } -#endif -#ifdef GL_ARB_compressed_texture_pixel_storage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compressed_texture_pixel_storage", 32)) - { - ret = GLEW_ARB_compressed_texture_pixel_storage; - continue; - } -#endif -#ifdef GL_ARB_compute_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compute_shader", 14)) - { - ret = GLEW_ARB_compute_shader; - continue; - } -#endif -#ifdef GL_ARB_compute_variable_group_size - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compute_variable_group_size", 27)) - { - ret = GLEW_ARB_compute_variable_group_size; - continue; - } -#endif -#ifdef GL_ARB_conservative_depth - if (_glewStrSame3(&pos, &len, (const GLubyte*)"conservative_depth", 18)) - { - ret = GLEW_ARB_conservative_depth; - continue; - } -#endif -#ifdef GL_ARB_copy_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_buffer", 11)) - { - ret = GLEW_ARB_copy_buffer; - continue; - } -#endif -#ifdef GL_ARB_copy_image - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) - { - ret = GLEW_ARB_copy_image; - continue; - } -#endif -#ifdef GL_ARB_debug_output - if (_glewStrSame3(&pos, &len, (const GLubyte*)"debug_output", 12)) - { - ret = GLEW_ARB_debug_output; - continue; - } -#endif -#ifdef GL_ARB_depth_buffer_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_buffer_float", 18)) - { - ret = GLEW_ARB_depth_buffer_float; - continue; - } -#endif -#ifdef GL_ARB_depth_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_clamp", 11)) - { - ret = GLEW_ARB_depth_clamp; - continue; - } -#endif -#ifdef GL_ARB_depth_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_texture", 13)) - { - ret = GLEW_ARB_depth_texture; - continue; - } -#endif -#ifdef GL_ARB_draw_buffers - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers", 12)) - { - ret = GLEW_ARB_draw_buffers; - continue; - } -#endif -#ifdef GL_ARB_draw_buffers_blend - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers_blend", 18)) - { - ret = GLEW_ARB_draw_buffers_blend; - continue; - } -#endif -#ifdef GL_ARB_draw_elements_base_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_elements_base_vertex", 25)) - { - ret = GLEW_ARB_draw_elements_base_vertex; - continue; - } -#endif -#ifdef GL_ARB_draw_indirect - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_indirect", 13)) - { - ret = GLEW_ARB_draw_indirect; - continue; - } -#endif -#ifdef GL_ARB_draw_instanced - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_instanced", 14)) - { - ret = GLEW_ARB_draw_instanced; - continue; - } -#endif -#ifdef GL_ARB_enhanced_layouts - if (_glewStrSame3(&pos, &len, (const GLubyte*)"enhanced_layouts", 16)) - { - ret = GLEW_ARB_enhanced_layouts; - continue; - } -#endif -#ifdef GL_ARB_explicit_attrib_location - if (_glewStrSame3(&pos, &len, (const GLubyte*)"explicit_attrib_location", 24)) - { - ret = GLEW_ARB_explicit_attrib_location; - continue; - } -#endif -#ifdef GL_ARB_explicit_uniform_location - if (_glewStrSame3(&pos, &len, (const GLubyte*)"explicit_uniform_location", 25)) - { - ret = GLEW_ARB_explicit_uniform_location; - continue; - } -#endif -#ifdef GL_ARB_fragment_coord_conventions - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_coord_conventions", 26)) - { - ret = GLEW_ARB_fragment_coord_conventions; - continue; - } -#endif -#ifdef GL_ARB_fragment_layer_viewport - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_layer_viewport", 23)) - { - ret = GLEW_ARB_fragment_layer_viewport; - continue; - } -#endif -#ifdef GL_ARB_fragment_program - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program", 16)) - { - ret = GLEW_ARB_fragment_program; - continue; - } -#endif -#ifdef GL_ARB_fragment_program_shadow - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program_shadow", 23)) - { - ret = GLEW_ARB_fragment_program_shadow; - continue; - } -#endif -#ifdef GL_ARB_fragment_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_shader", 15)) - { - ret = GLEW_ARB_fragment_shader; - continue; - } -#endif -#ifdef GL_ARB_framebuffer_no_attachments - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_no_attachments", 26)) - { - ret = GLEW_ARB_framebuffer_no_attachments; - continue; - } -#endif -#ifdef GL_ARB_framebuffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_object", 18)) - { - ret = GLEW_ARB_framebuffer_object; - continue; - } -#endif -#ifdef GL_ARB_framebuffer_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) - { - ret = GLEW_ARB_framebuffer_sRGB; - continue; - } -#endif -#ifdef GL_ARB_geometry_shader4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_shader4", 16)) - { - ret = GLEW_ARB_geometry_shader4; - continue; - } -#endif -#ifdef GL_ARB_get_program_binary - if (_glewStrSame3(&pos, &len, (const GLubyte*)"get_program_binary", 18)) - { - ret = GLEW_ARB_get_program_binary; - continue; - } -#endif -#ifdef GL_ARB_gpu_shader5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader5", 11)) - { - ret = GLEW_ARB_gpu_shader5; - continue; - } -#endif -#ifdef GL_ARB_gpu_shader_fp64 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader_fp64", 15)) - { - ret = GLEW_ARB_gpu_shader_fp64; - continue; - } -#endif -#ifdef GL_ARB_half_float_pixel - if (_glewStrSame3(&pos, &len, (const GLubyte*)"half_float_pixel", 16)) - { - ret = GLEW_ARB_half_float_pixel; - continue; - } -#endif -#ifdef GL_ARB_half_float_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"half_float_vertex", 17)) - { - ret = GLEW_ARB_half_float_vertex; - continue; - } -#endif -#ifdef GL_ARB_imaging - if (_glewStrSame3(&pos, &len, (const GLubyte*)"imaging", 7)) - { - ret = GLEW_ARB_imaging; - continue; - } -#endif -#ifdef GL_ARB_indirect_parameters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"indirect_parameters", 19)) - { - ret = GLEW_ARB_indirect_parameters; - continue; - } -#endif -#ifdef GL_ARB_instanced_arrays - if (_glewStrSame3(&pos, &len, (const GLubyte*)"instanced_arrays", 16)) - { - ret = GLEW_ARB_instanced_arrays; - continue; - } -#endif -#ifdef GL_ARB_internalformat_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"internalformat_query", 20)) - { - ret = GLEW_ARB_internalformat_query; - continue; - } -#endif -#ifdef GL_ARB_internalformat_query2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"internalformat_query2", 21)) - { - ret = GLEW_ARB_internalformat_query2; - continue; - } -#endif -#ifdef GL_ARB_invalidate_subdata - if (_glewStrSame3(&pos, &len, (const GLubyte*)"invalidate_subdata", 18)) - { - ret = GLEW_ARB_invalidate_subdata; - continue; - } -#endif -#ifdef GL_ARB_map_buffer_alignment - if (_glewStrSame3(&pos, &len, (const GLubyte*)"map_buffer_alignment", 20)) - { - ret = GLEW_ARB_map_buffer_alignment; - continue; - } -#endif -#ifdef GL_ARB_map_buffer_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"map_buffer_range", 16)) - { - ret = GLEW_ARB_map_buffer_range; - continue; - } -#endif -#ifdef GL_ARB_matrix_palette - if (_glewStrSame3(&pos, &len, (const GLubyte*)"matrix_palette", 14)) - { - ret = GLEW_ARB_matrix_palette; - continue; - } -#endif -#ifdef GL_ARB_multi_bind - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multi_bind", 10)) - { - ret = GLEW_ARB_multi_bind; - continue; - } -#endif -#ifdef GL_ARB_multi_draw_indirect - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multi_draw_indirect", 19)) - { - ret = GLEW_ARB_multi_draw_indirect; - continue; - } -#endif -#ifdef GL_ARB_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLEW_ARB_multisample; - continue; - } -#endif -#ifdef GL_ARB_multitexture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multitexture", 12)) - { - ret = GLEW_ARB_multitexture; - continue; - } -#endif -#ifdef GL_ARB_occlusion_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_query", 15)) - { - ret = GLEW_ARB_occlusion_query; - continue; - } -#endif -#ifdef GL_ARB_occlusion_query2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_query2", 16)) - { - ret = GLEW_ARB_occlusion_query2; - continue; - } -#endif -#ifdef GL_ARB_pixel_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_buffer_object", 19)) - { - ret = GLEW_ARB_pixel_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_point_parameters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_parameters", 16)) - { - ret = GLEW_ARB_point_parameters; - continue; - } -#endif -#ifdef GL_ARB_point_sprite - if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_sprite", 12)) - { - ret = GLEW_ARB_point_sprite; - continue; - } -#endif -#ifdef GL_ARB_program_interface_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"program_interface_query", 23)) - { - ret = GLEW_ARB_program_interface_query; - continue; - } -#endif -#ifdef GL_ARB_provoking_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"provoking_vertex", 16)) - { - ret = GLEW_ARB_provoking_vertex; - continue; - } -#endif -#ifdef GL_ARB_query_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"query_buffer_object", 19)) - { - ret = GLEW_ARB_query_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_robust_buffer_access_behavior - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robust_buffer_access_behavior", 29)) - { - ret = GLEW_ARB_robust_buffer_access_behavior; - continue; - } -#endif -#ifdef GL_ARB_robustness - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness", 10)) - { - ret = GLEW_ARB_robustness; - continue; - } -#endif -#ifdef GL_ARB_robustness_application_isolation - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness_application_isolation", 32)) - { - ret = GLEW_ARB_robustness_application_isolation; - continue; - } -#endif -#ifdef GL_ARB_robustness_share_group_isolation - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness_share_group_isolation", 32)) - { - ret = GLEW_ARB_robustness_share_group_isolation; - continue; - } -#endif -#ifdef GL_ARB_sample_shading - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sample_shading", 14)) - { - ret = GLEW_ARB_sample_shading; - continue; - } -#endif -#ifdef GL_ARB_sampler_objects - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sampler_objects", 15)) - { - ret = GLEW_ARB_sampler_objects; - continue; - } -#endif -#ifdef GL_ARB_seamless_cube_map - if (_glewStrSame3(&pos, &len, (const GLubyte*)"seamless_cube_map", 17)) - { - ret = GLEW_ARB_seamless_cube_map; - continue; - } -#endif -#ifdef GL_ARB_seamless_cubemap_per_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"seamless_cubemap_per_texture", 28)) - { - ret = GLEW_ARB_seamless_cubemap_per_texture; - continue; - } -#endif -#ifdef GL_ARB_separate_shader_objects - if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_shader_objects", 23)) - { - ret = GLEW_ARB_separate_shader_objects; - continue; - } -#endif -#ifdef GL_ARB_shader_atomic_counters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_atomic_counters", 22)) - { - ret = GLEW_ARB_shader_atomic_counters; - continue; - } -#endif -#ifdef GL_ARB_shader_bit_encoding - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_bit_encoding", 19)) - { - ret = GLEW_ARB_shader_bit_encoding; - continue; - } -#endif -#ifdef GL_ARB_shader_draw_parameters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_draw_parameters", 22)) - { - ret = GLEW_ARB_shader_draw_parameters; - continue; - } -#endif -#ifdef GL_ARB_shader_group_vote - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_group_vote", 17)) - { - ret = GLEW_ARB_shader_group_vote; - continue; - } -#endif -#ifdef GL_ARB_shader_image_load_store - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_image_load_store", 23)) - { - ret = GLEW_ARB_shader_image_load_store; - continue; - } -#endif -#ifdef GL_ARB_shader_image_size - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_image_size", 17)) - { - ret = GLEW_ARB_shader_image_size; - continue; - } -#endif -#ifdef GL_ARB_shader_objects - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_objects", 14)) - { - ret = GLEW_ARB_shader_objects; - continue; - } -#endif -#ifdef GL_ARB_shader_precision - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_precision", 16)) - { - ret = GLEW_ARB_shader_precision; - continue; - } -#endif -#ifdef GL_ARB_shader_stencil_export - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_stencil_export", 21)) - { - ret = GLEW_ARB_shader_stencil_export; - continue; - } -#endif -#ifdef GL_ARB_shader_storage_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_storage_buffer_object", 28)) - { - ret = GLEW_ARB_shader_storage_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_shader_subroutine - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_subroutine", 17)) - { - ret = GLEW_ARB_shader_subroutine; - continue; - } -#endif -#ifdef GL_ARB_shader_texture_lod - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_texture_lod", 18)) - { - ret = GLEW_ARB_shader_texture_lod; - continue; - } -#endif -#ifdef GL_ARB_shading_language_100 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shading_language_100", 20)) - { - ret = GLEW_ARB_shading_language_100; - continue; - } -#endif -#ifdef GL_ARB_shading_language_420pack - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shading_language_420pack", 24)) - { - ret = GLEW_ARB_shading_language_420pack; - continue; - } -#endif -#ifdef GL_ARB_shading_language_include - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shading_language_include", 24)) - { - ret = GLEW_ARB_shading_language_include; - continue; - } -#endif -#ifdef GL_ARB_shading_language_packing - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shading_language_packing", 24)) - { - ret = GLEW_ARB_shading_language_packing; - continue; - } -#endif -#ifdef GL_ARB_shadow - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow", 6)) - { - ret = GLEW_ARB_shadow; - continue; - } -#endif -#ifdef GL_ARB_shadow_ambient - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow_ambient", 14)) - { - ret = GLEW_ARB_shadow_ambient; - continue; - } -#endif -#ifdef GL_ARB_sparse_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sparse_texture", 14)) - { - ret = GLEW_ARB_sparse_texture; - continue; - } -#endif -#ifdef GL_ARB_stencil_texturing - if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_texturing", 17)) - { - ret = GLEW_ARB_stencil_texturing; - continue; - } -#endif -#ifdef GL_ARB_sync - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sync", 4)) - { - ret = GLEW_ARB_sync; - continue; - } -#endif -#ifdef GL_ARB_tessellation_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"tessellation_shader", 19)) - { - ret = GLEW_ARB_tessellation_shader; - continue; - } -#endif -#ifdef GL_ARB_texture_border_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_border_clamp", 20)) - { - ret = GLEW_ARB_texture_border_clamp; - continue; - } -#endif -#ifdef GL_ARB_texture_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_object", 21)) - { - ret = GLEW_ARB_texture_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_texture_buffer_object_rgb32 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_object_rgb32", 27)) - { - ret = GLEW_ARB_texture_buffer_object_rgb32; - continue; - } -#endif -#ifdef GL_ARB_texture_buffer_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_range", 20)) - { - ret = GLEW_ARB_texture_buffer_range; - continue; - } -#endif -#ifdef GL_ARB_texture_compression - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression", 19)) - { - ret = GLEW_ARB_texture_compression; - continue; - } -#endif -#ifdef GL_ARB_texture_compression_bptc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_bptc", 24)) - { - ret = GLEW_ARB_texture_compression_bptc; - continue; - } -#endif -#ifdef GL_ARB_texture_compression_rgtc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_rgtc", 24)) - { - ret = GLEW_ARB_texture_compression_rgtc; - continue; - } -#endif -#ifdef GL_ARB_texture_cube_map - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_cube_map", 16)) - { - ret = GLEW_ARB_texture_cube_map; - continue; - } -#endif -#ifdef GL_ARB_texture_cube_map_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_cube_map_array", 22)) - { - ret = GLEW_ARB_texture_cube_map_array; - continue; - } -#endif -#ifdef GL_ARB_texture_env_add - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_add", 15)) - { - ret = GLEW_ARB_texture_env_add; - continue; - } -#endif -#ifdef GL_ARB_texture_env_combine - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine", 19)) - { - ret = GLEW_ARB_texture_env_combine; - continue; - } -#endif -#ifdef GL_ARB_texture_env_crossbar - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_crossbar", 20)) - { - ret = GLEW_ARB_texture_env_crossbar; - continue; - } -#endif -#ifdef GL_ARB_texture_env_dot3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_dot3", 16)) - { - ret = GLEW_ARB_texture_env_dot3; - continue; - } -#endif -#ifdef GL_ARB_texture_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_float", 13)) - { - ret = GLEW_ARB_texture_float; - continue; - } -#endif -#ifdef GL_ARB_texture_gather - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_gather", 14)) - { - ret = GLEW_ARB_texture_gather; - continue; - } -#endif -#ifdef GL_ARB_texture_mirror_clamp_to_edge - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirror_clamp_to_edge", 28)) - { - ret = GLEW_ARB_texture_mirror_clamp_to_edge; - continue; - } -#endif -#ifdef GL_ARB_texture_mirrored_repeat - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirrored_repeat", 23)) - { - ret = GLEW_ARB_texture_mirrored_repeat; - continue; - } -#endif -#ifdef GL_ARB_texture_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_multisample", 19)) - { - ret = GLEW_ARB_texture_multisample; - continue; - } -#endif -#ifdef GL_ARB_texture_non_power_of_two - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_non_power_of_two", 24)) - { - ret = GLEW_ARB_texture_non_power_of_two; - continue; - } -#endif -#ifdef GL_ARB_texture_query_levels - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_query_levels", 20)) - { - ret = GLEW_ARB_texture_query_levels; - continue; - } -#endif -#ifdef GL_ARB_texture_query_lod - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_query_lod", 17)) - { - ret = GLEW_ARB_texture_query_lod; - continue; - } -#endif -#ifdef GL_ARB_texture_rectangle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rectangle", 17)) - { - ret = GLEW_ARB_texture_rectangle; - continue; - } -#endif -#ifdef GL_ARB_texture_rg - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rg", 10)) - { - ret = GLEW_ARB_texture_rg; - continue; - } -#endif -#ifdef GL_ARB_texture_rgb10_a2ui - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rgb10_a2ui", 18)) - { - ret = GLEW_ARB_texture_rgb10_a2ui; - continue; - } -#endif -#ifdef GL_ARB_texture_stencil8 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_stencil8", 16)) - { - ret = GLEW_ARB_texture_stencil8; - continue; - } -#endif -#ifdef GL_ARB_texture_storage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_storage", 15)) - { - ret = GLEW_ARB_texture_storage; - continue; - } -#endif -#ifdef GL_ARB_texture_storage_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_storage_multisample", 27)) - { - ret = GLEW_ARB_texture_storage_multisample; - continue; - } -#endif -#ifdef GL_ARB_texture_swizzle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_swizzle", 15)) - { - ret = GLEW_ARB_texture_swizzle; - continue; - } -#endif -#ifdef GL_ARB_texture_view - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_view", 12)) - { - ret = GLEW_ARB_texture_view; - continue; - } -#endif -#ifdef GL_ARB_timer_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"timer_query", 11)) - { - ret = GLEW_ARB_timer_query; - continue; - } -#endif -#ifdef GL_ARB_transform_feedback2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback2", 19)) - { - ret = GLEW_ARB_transform_feedback2; - continue; - } -#endif -#ifdef GL_ARB_transform_feedback3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback3", 19)) - { - ret = GLEW_ARB_transform_feedback3; - continue; - } -#endif -#ifdef GL_ARB_transform_feedback_instanced - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback_instanced", 28)) - { - ret = GLEW_ARB_transform_feedback_instanced; - continue; - } -#endif -#ifdef GL_ARB_transpose_matrix - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transpose_matrix", 16)) - { - ret = GLEW_ARB_transpose_matrix; - continue; - } -#endif -#ifdef GL_ARB_uniform_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"uniform_buffer_object", 21)) - { - ret = GLEW_ARB_uniform_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_vertex_array_bgra - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_bgra", 17)) - { - ret = GLEW_ARB_vertex_array_bgra; - continue; - } -#endif -#ifdef GL_ARB_vertex_array_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_object", 19)) - { - ret = GLEW_ARB_vertex_array_object; - continue; - } -#endif -#ifdef GL_ARB_vertex_attrib_64bit - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_64bit", 19)) - { - ret = GLEW_ARB_vertex_attrib_64bit; - continue; - } -#endif -#ifdef GL_ARB_vertex_attrib_binding - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_binding", 21)) - { - ret = GLEW_ARB_vertex_attrib_binding; - continue; - } -#endif -#ifdef GL_ARB_vertex_blend - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_blend", 12)) - { - ret = GLEW_ARB_vertex_blend; - continue; - } -#endif -#ifdef GL_ARB_vertex_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_buffer_object", 20)) - { - ret = GLEW_ARB_vertex_buffer_object; - continue; - } -#endif -#ifdef GL_ARB_vertex_program - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program", 14)) - { - ret = GLEW_ARB_vertex_program; - continue; - } -#endif -#ifdef GL_ARB_vertex_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader", 13)) - { - ret = GLEW_ARB_vertex_shader; - continue; - } -#endif -#ifdef GL_ARB_vertex_type_10f_11f_11f_rev - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_type_10f_11f_11f_rev", 27)) - { - ret = GLEW_ARB_vertex_type_10f_11f_11f_rev; - continue; - } -#endif -#ifdef GL_ARB_vertex_type_2_10_10_10_rev - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_type_2_10_10_10_rev", 26)) - { - ret = GLEW_ARB_vertex_type_2_10_10_10_rev; - continue; - } -#endif -#ifdef GL_ARB_viewport_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"viewport_array", 14)) - { - ret = GLEW_ARB_viewport_array; - continue; - } -#endif -#ifdef GL_ARB_window_pos - if (_glewStrSame3(&pos, &len, (const GLubyte*)"window_pos", 10)) - { - ret = GLEW_ARB_window_pos; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATIX_", 5)) - { -#ifdef GL_ATIX_point_sprites - if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_sprites", 13)) - { - ret = GLEW_ATIX_point_sprites; - continue; - } -#endif -#ifdef GL_ATIX_texture_env_combine3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine3", 20)) - { - ret = GLEW_ATIX_texture_env_combine3; - continue; - } -#endif -#ifdef GL_ATIX_texture_env_route - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_route", 17)) - { - ret = GLEW_ATIX_texture_env_route; - continue; - } -#endif -#ifdef GL_ATIX_vertex_shader_output_point_size - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader_output_point_size", 31)) - { - ret = GLEW_ATIX_vertex_shader_output_point_size; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATI_", 4)) - { -#ifdef GL_ATI_draw_buffers - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers", 12)) - { - ret = GLEW_ATI_draw_buffers; - continue; - } -#endif -#ifdef GL_ATI_element_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"element_array", 13)) - { - ret = GLEW_ATI_element_array; - continue; - } -#endif -#ifdef GL_ATI_envmap_bumpmap - if (_glewStrSame3(&pos, &len, (const GLubyte*)"envmap_bumpmap", 14)) - { - ret = GLEW_ATI_envmap_bumpmap; - continue; - } -#endif -#ifdef GL_ATI_fragment_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_shader", 15)) - { - ret = GLEW_ATI_fragment_shader; - continue; - } -#endif -#ifdef GL_ATI_map_object_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"map_object_buffer", 17)) - { - ret = GLEW_ATI_map_object_buffer; - continue; - } -#endif -#ifdef GL_ATI_meminfo - if (_glewStrSame3(&pos, &len, (const GLubyte*)"meminfo", 7)) - { - ret = GLEW_ATI_meminfo; - continue; - } -#endif -#ifdef GL_ATI_pn_triangles - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pn_triangles", 12)) - { - ret = GLEW_ATI_pn_triangles; - continue; - } -#endif -#ifdef GL_ATI_separate_stencil - if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_stencil", 16)) - { - ret = GLEW_ATI_separate_stencil; - continue; - } -#endif -#ifdef GL_ATI_shader_texture_lod - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_texture_lod", 18)) - { - ret = GLEW_ATI_shader_texture_lod; - continue; - } -#endif -#ifdef GL_ATI_text_fragment_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"text_fragment_shader", 20)) - { - ret = GLEW_ATI_text_fragment_shader; - continue; - } -#endif -#ifdef GL_ATI_texture_compression_3dc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_3dc", 23)) - { - ret = GLEW_ATI_texture_compression_3dc; - continue; - } -#endif -#ifdef GL_ATI_texture_env_combine3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine3", 20)) - { - ret = GLEW_ATI_texture_env_combine3; - continue; - } -#endif -#ifdef GL_ATI_texture_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_float", 13)) - { - ret = GLEW_ATI_texture_float; - continue; - } -#endif -#ifdef GL_ATI_texture_mirror_once - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirror_once", 19)) - { - ret = GLEW_ATI_texture_mirror_once; - continue; - } -#endif -#ifdef GL_ATI_vertex_array_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_object", 19)) - { - ret = GLEW_ATI_vertex_array_object; - continue; - } -#endif -#ifdef GL_ATI_vertex_attrib_array_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_array_object", 26)) - { - ret = GLEW_ATI_vertex_attrib_array_object; - continue; - } -#endif -#ifdef GL_ATI_vertex_streams - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_streams", 14)) - { - ret = GLEW_ATI_vertex_streams; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"EXT_", 4)) - { -#ifdef GL_EXT_422_pixels - if (_glewStrSame3(&pos, &len, (const GLubyte*)"422_pixels", 10)) - { - ret = GLEW_EXT_422_pixels; - continue; - } -#endif -#ifdef GL_EXT_Cg_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"Cg_shader", 9)) - { - ret = GLEW_EXT_Cg_shader; - continue; - } -#endif -#ifdef GL_EXT_abgr - if (_glewStrSame3(&pos, &len, (const GLubyte*)"abgr", 4)) - { - ret = GLEW_EXT_abgr; - continue; - } -#endif -#ifdef GL_EXT_bgra - if (_glewStrSame3(&pos, &len, (const GLubyte*)"bgra", 4)) - { - ret = GLEW_EXT_bgra; - continue; - } -#endif -#ifdef GL_EXT_bindable_uniform - if (_glewStrSame3(&pos, &len, (const GLubyte*)"bindable_uniform", 16)) - { - ret = GLEW_EXT_bindable_uniform; - continue; - } -#endif -#ifdef GL_EXT_blend_color - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_color", 11)) - { - ret = GLEW_EXT_blend_color; - continue; - } -#endif -#ifdef GL_EXT_blend_equation_separate - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_equation_separate", 23)) - { - ret = GLEW_EXT_blend_equation_separate; - continue; - } -#endif -#ifdef GL_EXT_blend_func_separate - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_func_separate", 19)) - { - ret = GLEW_EXT_blend_func_separate; - continue; - } -#endif -#ifdef GL_EXT_blend_logic_op - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_logic_op", 14)) - { - ret = GLEW_EXT_blend_logic_op; - continue; - } -#endif -#ifdef GL_EXT_blend_minmax - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_minmax", 12)) - { - ret = GLEW_EXT_blend_minmax; - continue; - } -#endif -#ifdef GL_EXT_blend_subtract - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_subtract", 14)) - { - ret = GLEW_EXT_blend_subtract; - continue; - } -#endif -#ifdef GL_EXT_clip_volume_hint - if (_glewStrSame3(&pos, &len, (const GLubyte*)"clip_volume_hint", 16)) - { - ret = GLEW_EXT_clip_volume_hint; - continue; - } -#endif -#ifdef GL_EXT_cmyka - if (_glewStrSame3(&pos, &len, (const GLubyte*)"cmyka", 5)) - { - ret = GLEW_EXT_cmyka; - continue; - } -#endif -#ifdef GL_EXT_color_subtable - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_subtable", 14)) - { - ret = GLEW_EXT_color_subtable; - continue; - } -#endif -#ifdef GL_EXT_compiled_vertex_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compiled_vertex_array", 21)) - { - ret = GLEW_EXT_compiled_vertex_array; - continue; - } -#endif -#ifdef GL_EXT_convolution - if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution", 11)) - { - ret = GLEW_EXT_convolution; - continue; - } -#endif -#ifdef GL_EXT_coordinate_frame - if (_glewStrSame3(&pos, &len, (const GLubyte*)"coordinate_frame", 16)) - { - ret = GLEW_EXT_coordinate_frame; - continue; - } -#endif -#ifdef GL_EXT_copy_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_texture", 12)) - { - ret = GLEW_EXT_copy_texture; - continue; - } -#endif -#ifdef GL_EXT_cull_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"cull_vertex", 11)) - { - ret = GLEW_EXT_cull_vertex; - continue; - } -#endif -#ifdef GL_EXT_debug_marker - if (_glewStrSame3(&pos, &len, (const GLubyte*)"debug_marker", 12)) - { - ret = GLEW_EXT_debug_marker; - continue; - } -#endif -#ifdef GL_EXT_depth_bounds_test - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_bounds_test", 17)) - { - ret = GLEW_EXT_depth_bounds_test; - continue; - } -#endif -#ifdef GL_EXT_direct_state_access - if (_glewStrSame3(&pos, &len, (const GLubyte*)"direct_state_access", 19)) - { - ret = GLEW_EXT_direct_state_access; - continue; - } -#endif -#ifdef GL_EXT_draw_buffers2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_buffers2", 13)) - { - ret = GLEW_EXT_draw_buffers2; - continue; - } -#endif -#ifdef GL_EXT_draw_instanced - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_instanced", 14)) - { - ret = GLEW_EXT_draw_instanced; - continue; - } -#endif -#ifdef GL_EXT_draw_range_elements - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_range_elements", 19)) - { - ret = GLEW_EXT_draw_range_elements; - continue; - } -#endif -#ifdef GL_EXT_fog_coord - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_coord", 9)) - { - ret = GLEW_EXT_fog_coord; - continue; - } -#endif -#ifdef GL_EXT_fragment_lighting - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_lighting", 17)) - { - ret = GLEW_EXT_fragment_lighting; - continue; - } -#endif -#ifdef GL_EXT_framebuffer_blit - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_blit", 16)) - { - ret = GLEW_EXT_framebuffer_blit; - continue; - } -#endif -#ifdef GL_EXT_framebuffer_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_multisample", 23)) - { - ret = GLEW_EXT_framebuffer_multisample; - continue; - } -#endif -#ifdef GL_EXT_framebuffer_multisample_blit_scaled - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_multisample_blit_scaled", 35)) - { - ret = GLEW_EXT_framebuffer_multisample_blit_scaled; - continue; - } -#endif -#ifdef GL_EXT_framebuffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_object", 18)) - { - ret = GLEW_EXT_framebuffer_object; - continue; - } -#endif -#ifdef GL_EXT_framebuffer_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) - { - ret = GLEW_EXT_framebuffer_sRGB; - continue; - } -#endif -#ifdef GL_EXT_geometry_shader4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_shader4", 16)) - { - ret = GLEW_EXT_geometry_shader4; - continue; - } -#endif -#ifdef GL_EXT_gpu_program_parameters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program_parameters", 22)) - { - ret = GLEW_EXT_gpu_program_parameters; - continue; - } -#endif -#ifdef GL_EXT_gpu_shader4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader4", 11)) - { - ret = GLEW_EXT_gpu_shader4; - continue; - } -#endif -#ifdef GL_EXT_histogram - if (_glewStrSame3(&pos, &len, (const GLubyte*)"histogram", 9)) - { - ret = GLEW_EXT_histogram; - continue; - } -#endif -#ifdef GL_EXT_index_array_formats - if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_array_formats", 19)) - { - ret = GLEW_EXT_index_array_formats; - continue; - } -#endif -#ifdef GL_EXT_index_func - if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_func", 10)) - { - ret = GLEW_EXT_index_func; - continue; - } -#endif -#ifdef GL_EXT_index_material - if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_material", 14)) - { - ret = GLEW_EXT_index_material; - continue; - } -#endif -#ifdef GL_EXT_index_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"index_texture", 13)) - { - ret = GLEW_EXT_index_texture; - continue; - } -#endif -#ifdef GL_EXT_light_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"light_texture", 13)) - { - ret = GLEW_EXT_light_texture; - continue; - } -#endif -#ifdef GL_EXT_misc_attribute - if (_glewStrSame3(&pos, &len, (const GLubyte*)"misc_attribute", 14)) - { - ret = GLEW_EXT_misc_attribute; - continue; - } -#endif -#ifdef GL_EXT_multi_draw_arrays - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multi_draw_arrays", 17)) - { - ret = GLEW_EXT_multi_draw_arrays; - continue; - } -#endif -#ifdef GL_EXT_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLEW_EXT_multisample; - continue; - } -#endif -#ifdef GL_EXT_packed_depth_stencil - if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_depth_stencil", 20)) - { - ret = GLEW_EXT_packed_depth_stencil; - continue; - } -#endif -#ifdef GL_EXT_packed_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_float", 12)) - { - ret = GLEW_EXT_packed_float; - continue; - } -#endif -#ifdef GL_EXT_packed_pixels - if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_pixels", 13)) - { - ret = GLEW_EXT_packed_pixels; - continue; - } -#endif -#ifdef GL_EXT_paletted_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"paletted_texture", 16)) - { - ret = GLEW_EXT_paletted_texture; - continue; - } -#endif -#ifdef GL_EXT_pixel_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_buffer_object", 19)) - { - ret = GLEW_EXT_pixel_buffer_object; - continue; - } -#endif -#ifdef GL_EXT_pixel_transform - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_transform", 15)) - { - ret = GLEW_EXT_pixel_transform; - continue; - } -#endif -#ifdef GL_EXT_pixel_transform_color_table - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_transform_color_table", 27)) - { - ret = GLEW_EXT_pixel_transform_color_table; - continue; - } -#endif -#ifdef GL_EXT_point_parameters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_parameters", 16)) - { - ret = GLEW_EXT_point_parameters; - continue; - } -#endif -#ifdef GL_EXT_polygon_offset - if (_glewStrSame3(&pos, &len, (const GLubyte*)"polygon_offset", 14)) - { - ret = GLEW_EXT_polygon_offset; - continue; - } -#endif -#ifdef GL_EXT_provoking_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"provoking_vertex", 16)) - { - ret = GLEW_EXT_provoking_vertex; - continue; - } -#endif -#ifdef GL_EXT_rescale_normal - if (_glewStrSame3(&pos, &len, (const GLubyte*)"rescale_normal", 14)) - { - ret = GLEW_EXT_rescale_normal; - continue; - } -#endif -#ifdef GL_EXT_scene_marker - if (_glewStrSame3(&pos, &len, (const GLubyte*)"scene_marker", 12)) - { - ret = GLEW_EXT_scene_marker; - continue; - } -#endif -#ifdef GL_EXT_secondary_color - if (_glewStrSame3(&pos, &len, (const GLubyte*)"secondary_color", 15)) - { - ret = GLEW_EXT_secondary_color; - continue; - } -#endif -#ifdef GL_EXT_separate_shader_objects - if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_shader_objects", 23)) - { - ret = GLEW_EXT_separate_shader_objects; - continue; - } -#endif -#ifdef GL_EXT_separate_specular_color - if (_glewStrSame3(&pos, &len, (const GLubyte*)"separate_specular_color", 23)) - { - ret = GLEW_EXT_separate_specular_color; - continue; - } -#endif -#ifdef GL_EXT_shader_image_load_store - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_image_load_store", 23)) - { - ret = GLEW_EXT_shader_image_load_store; - continue; - } -#endif -#ifdef GL_EXT_shadow_funcs - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow_funcs", 12)) - { - ret = GLEW_EXT_shadow_funcs; - continue; - } -#endif -#ifdef GL_EXT_shared_texture_palette - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shared_texture_palette", 22)) - { - ret = GLEW_EXT_shared_texture_palette; - continue; - } -#endif -#ifdef GL_EXT_stencil_clear_tag - if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_clear_tag", 17)) - { - ret = GLEW_EXT_stencil_clear_tag; - continue; - } -#endif -#ifdef GL_EXT_stencil_two_side - if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_two_side", 16)) - { - ret = GLEW_EXT_stencil_two_side; - continue; - } -#endif -#ifdef GL_EXT_stencil_wrap - if (_glewStrSame3(&pos, &len, (const GLubyte*)"stencil_wrap", 12)) - { - ret = GLEW_EXT_stencil_wrap; - continue; - } -#endif -#ifdef GL_EXT_subtexture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"subtexture", 10)) - { - ret = GLEW_EXT_subtexture; - continue; - } -#endif -#ifdef GL_EXT_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture", 7)) - { - ret = GLEW_EXT_texture; - continue; - } -#endif -#ifdef GL_EXT_texture3D - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture3D", 9)) - { - ret = GLEW_EXT_texture3D; - continue; - } -#endif -#ifdef GL_EXT_texture_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_array", 13)) - { - ret = GLEW_EXT_texture_array; - continue; - } -#endif -#ifdef GL_EXT_texture_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_buffer_object", 21)) - { - ret = GLEW_EXT_texture_buffer_object; - continue; - } -#endif -#ifdef GL_EXT_texture_compression_dxt1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_dxt1", 24)) - { - ret = GLEW_EXT_texture_compression_dxt1; - continue; - } -#endif -#ifdef GL_EXT_texture_compression_latc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_latc", 24)) - { - ret = GLEW_EXT_texture_compression_latc; - continue; - } -#endif -#ifdef GL_EXT_texture_compression_rgtc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_rgtc", 24)) - { - ret = GLEW_EXT_texture_compression_rgtc; - continue; - } -#endif -#ifdef GL_EXT_texture_compression_s3tc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_s3tc", 24)) - { - ret = GLEW_EXT_texture_compression_s3tc; - continue; - } -#endif -#ifdef GL_EXT_texture_cube_map - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_cube_map", 16)) - { - ret = GLEW_EXT_texture_cube_map; - continue; - } -#endif -#ifdef GL_EXT_texture_edge_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_edge_clamp", 18)) - { - ret = GLEW_EXT_texture_edge_clamp; - continue; - } -#endif -#ifdef GL_EXT_texture_env - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env", 11)) - { - ret = GLEW_EXT_texture_env; - continue; - } -#endif -#ifdef GL_EXT_texture_env_add - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_add", 15)) - { - ret = GLEW_EXT_texture_env_add; - continue; - } -#endif -#ifdef GL_EXT_texture_env_combine - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine", 19)) - { - ret = GLEW_EXT_texture_env_combine; - continue; - } -#endif -#ifdef GL_EXT_texture_env_dot3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_dot3", 16)) - { - ret = GLEW_EXT_texture_env_dot3; - continue; - } -#endif -#ifdef GL_EXT_texture_filter_anisotropic - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_filter_anisotropic", 26)) - { - ret = GLEW_EXT_texture_filter_anisotropic; - continue; - } -#endif -#ifdef GL_EXT_texture_integer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_integer", 15)) - { - ret = GLEW_EXT_texture_integer; - continue; - } -#endif -#ifdef GL_EXT_texture_lod_bias - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lod_bias", 16)) - { - ret = GLEW_EXT_texture_lod_bias; - continue; - } -#endif -#ifdef GL_EXT_texture_mirror_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirror_clamp", 20)) - { - ret = GLEW_EXT_texture_mirror_clamp; - continue; - } -#endif -#ifdef GL_EXT_texture_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_object", 14)) - { - ret = GLEW_EXT_texture_object; - continue; - } -#endif -#ifdef GL_EXT_texture_perturb_normal - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_perturb_normal", 22)) - { - ret = GLEW_EXT_texture_perturb_normal; - continue; - } -#endif -#ifdef GL_EXT_texture_rectangle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rectangle", 17)) - { - ret = GLEW_EXT_texture_rectangle; - continue; - } -#endif -#ifdef GL_EXT_texture_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_sRGB", 12)) - { - ret = GLEW_EXT_texture_sRGB; - continue; - } -#endif -#ifdef GL_EXT_texture_sRGB_decode - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_sRGB_decode", 19)) - { - ret = GLEW_EXT_texture_sRGB_decode; - continue; - } -#endif -#ifdef GL_EXT_texture_shared_exponent - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shared_exponent", 23)) - { - ret = GLEW_EXT_texture_shared_exponent; - continue; - } -#endif -#ifdef GL_EXT_texture_snorm - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_snorm", 13)) - { - ret = GLEW_EXT_texture_snorm; - continue; - } -#endif -#ifdef GL_EXT_texture_swizzle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_swizzle", 15)) - { - ret = GLEW_EXT_texture_swizzle; - continue; - } -#endif -#ifdef GL_EXT_timer_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"timer_query", 11)) - { - ret = GLEW_EXT_timer_query; - continue; - } -#endif -#ifdef GL_EXT_transform_feedback - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback", 18)) - { - ret = GLEW_EXT_transform_feedback; - continue; - } -#endif -#ifdef GL_EXT_vertex_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array", 12)) - { - ret = GLEW_EXT_vertex_array; - continue; - } -#endif -#ifdef GL_EXT_vertex_array_bgra - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_bgra", 17)) - { - ret = GLEW_EXT_vertex_array_bgra; - continue; - } -#endif -#ifdef GL_EXT_vertex_attrib_64bit - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_64bit", 19)) - { - ret = GLEW_EXT_vertex_attrib_64bit; - continue; - } -#endif -#ifdef GL_EXT_vertex_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_shader", 13)) - { - ret = GLEW_EXT_vertex_shader; - continue; - } -#endif -#ifdef GL_EXT_vertex_weighting - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_weighting", 16)) - { - ret = GLEW_EXT_vertex_weighting; - continue; - } -#endif -#ifdef GL_EXT_x11_sync_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"x11_sync_object", 15)) - { - ret = GLEW_EXT_x11_sync_object; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"GREMEDY_", 8)) - { -#ifdef GL_GREMEDY_frame_terminator - if (_glewStrSame3(&pos, &len, (const GLubyte*)"frame_terminator", 16)) - { - ret = GLEW_GREMEDY_frame_terminator; - continue; - } -#endif -#ifdef GL_GREMEDY_string_marker - if (_glewStrSame3(&pos, &len, (const GLubyte*)"string_marker", 13)) - { - ret = GLEW_GREMEDY_string_marker; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"HP_", 3)) - { -#ifdef GL_HP_convolution_border_modes - if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution_border_modes", 24)) - { - ret = GLEW_HP_convolution_border_modes; - continue; - } -#endif -#ifdef GL_HP_image_transform - if (_glewStrSame3(&pos, &len, (const GLubyte*)"image_transform", 15)) - { - ret = GLEW_HP_image_transform; - continue; - } -#endif -#ifdef GL_HP_occlusion_test - if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_test", 14)) - { - ret = GLEW_HP_occlusion_test; - continue; - } -#endif -#ifdef GL_HP_texture_lighting - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lighting", 16)) - { - ret = GLEW_HP_texture_lighting; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"IBM_", 4)) - { -#ifdef GL_IBM_cull_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"cull_vertex", 11)) - { - ret = GLEW_IBM_cull_vertex; - continue; - } -#endif -#ifdef GL_IBM_multimode_draw_arrays - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multimode_draw_arrays", 21)) - { - ret = GLEW_IBM_multimode_draw_arrays; - continue; - } -#endif -#ifdef GL_IBM_rasterpos_clip - if (_glewStrSame3(&pos, &len, (const GLubyte*)"rasterpos_clip", 14)) - { - ret = GLEW_IBM_rasterpos_clip; - continue; - } -#endif -#ifdef GL_IBM_static_data - if (_glewStrSame3(&pos, &len, (const GLubyte*)"static_data", 11)) - { - ret = GLEW_IBM_static_data; - continue; - } -#endif -#ifdef GL_IBM_texture_mirrored_repeat - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_mirrored_repeat", 23)) - { - ret = GLEW_IBM_texture_mirrored_repeat; - continue; - } -#endif -#ifdef GL_IBM_vertex_array_lists - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_lists", 18)) - { - ret = GLEW_IBM_vertex_array_lists; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"INGR_", 5)) - { -#ifdef GL_INGR_color_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_clamp", 11)) - { - ret = GLEW_INGR_color_clamp; - continue; - } -#endif -#ifdef GL_INGR_interlace_read - if (_glewStrSame3(&pos, &len, (const GLubyte*)"interlace_read", 14)) - { - ret = GLEW_INGR_interlace_read; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"INTEL_", 6)) - { -#ifdef GL_INTEL_map_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"map_texture", 11)) - { - ret = GLEW_INTEL_map_texture; - continue; - } -#endif -#ifdef GL_INTEL_parallel_arrays - if (_glewStrSame3(&pos, &len, (const GLubyte*)"parallel_arrays", 15)) - { - ret = GLEW_INTEL_parallel_arrays; - continue; - } -#endif -#ifdef GL_INTEL_texture_scissor - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_scissor", 15)) - { - ret = GLEW_INTEL_texture_scissor; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"KHR_", 4)) - { -#ifdef GL_KHR_debug - if (_glewStrSame3(&pos, &len, (const GLubyte*)"debug", 5)) - { - ret = GLEW_KHR_debug; - continue; - } -#endif -#ifdef GL_KHR_texture_compression_astc_ldr - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_astc_ldr", 28)) - { - ret = GLEW_KHR_texture_compression_astc_ldr; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"KTX_", 4)) - { -#ifdef GL_KTX_buffer_region - if (_glewStrSame3(&pos, &len, (const GLubyte*)"buffer_region", 13)) - { - ret = GLEW_KTX_buffer_region; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"MESAX_", 6)) - { -#ifdef GL_MESAX_texture_stack - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_stack", 13)) - { - ret = GLEW_MESAX_texture_stack; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"MESA_", 5)) - { -#ifdef GL_MESA_pack_invert - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pack_invert", 11)) - { - ret = GLEW_MESA_pack_invert; - continue; - } -#endif -#ifdef GL_MESA_resize_buffers - if (_glewStrSame3(&pos, &len, (const GLubyte*)"resize_buffers", 14)) - { - ret = GLEW_MESA_resize_buffers; - continue; - } -#endif -#ifdef GL_MESA_window_pos - if (_glewStrSame3(&pos, &len, (const GLubyte*)"window_pos", 10)) - { - ret = GLEW_MESA_window_pos; - continue; - } -#endif -#ifdef GL_MESA_ycbcr_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ycbcr_texture", 13)) - { - ret = GLEW_MESA_ycbcr_texture; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"NVX_", 4)) - { -#ifdef GL_NVX_conditional_render - if (_glewStrSame3(&pos, &len, (const GLubyte*)"conditional_render", 18)) - { - ret = GLEW_NVX_conditional_render; - continue; - } -#endif -#ifdef GL_NVX_gpu_memory_info - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_memory_info", 15)) - { - ret = GLEW_NVX_gpu_memory_info; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"NV_", 3)) - { -#ifdef GL_NV_bindless_multi_draw_indirect - if (_glewStrSame3(&pos, &len, (const GLubyte*)"bindless_multi_draw_indirect", 28)) - { - ret = GLEW_NV_bindless_multi_draw_indirect; - continue; - } -#endif -#ifdef GL_NV_bindless_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"bindless_texture", 16)) - { - ret = GLEW_NV_bindless_texture; - continue; - } -#endif -#ifdef GL_NV_blend_equation_advanced - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_equation_advanced", 23)) - { - ret = GLEW_NV_blend_equation_advanced; - continue; - } -#endif -#ifdef GL_NV_blend_equation_advanced_coherent - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_equation_advanced_coherent", 32)) - { - ret = GLEW_NV_blend_equation_advanced_coherent; - continue; - } -#endif -#ifdef GL_NV_blend_square - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_square", 12)) - { - ret = GLEW_NV_blend_square; - continue; - } -#endif -#ifdef GL_NV_compute_program5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compute_program5", 16)) - { - ret = GLEW_NV_compute_program5; - continue; - } -#endif -#ifdef GL_NV_conditional_render - if (_glewStrSame3(&pos, &len, (const GLubyte*)"conditional_render", 18)) - { - ret = GLEW_NV_conditional_render; - continue; - } -#endif -#ifdef GL_NV_copy_depth_to_color - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_depth_to_color", 19)) - { - ret = GLEW_NV_copy_depth_to_color; - continue; - } -#endif -#ifdef GL_NV_copy_image - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) - { - ret = GLEW_NV_copy_image; - continue; - } -#endif -#ifdef GL_NV_deep_texture3D - if (_glewStrSame3(&pos, &len, (const GLubyte*)"deep_texture3D", 14)) - { - ret = GLEW_NV_deep_texture3D; - continue; - } -#endif -#ifdef GL_NV_depth_buffer_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_buffer_float", 18)) - { - ret = GLEW_NV_depth_buffer_float; - continue; - } -#endif -#ifdef GL_NV_depth_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_clamp", 11)) - { - ret = GLEW_NV_depth_clamp; - continue; - } -#endif -#ifdef GL_NV_depth_range_unclamped - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_range_unclamped", 21)) - { - ret = GLEW_NV_depth_range_unclamped; - continue; - } -#endif -#ifdef GL_NV_draw_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"draw_texture", 12)) - { - ret = GLEW_NV_draw_texture; - continue; - } -#endif -#ifdef GL_NV_evaluators - if (_glewStrSame3(&pos, &len, (const GLubyte*)"evaluators", 10)) - { - ret = GLEW_NV_evaluators; - continue; - } -#endif -#ifdef GL_NV_explicit_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"explicit_multisample", 20)) - { - ret = GLEW_NV_explicit_multisample; - continue; - } -#endif -#ifdef GL_NV_fence - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fence", 5)) - { - ret = GLEW_NV_fence; - continue; - } -#endif -#ifdef GL_NV_float_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_buffer", 12)) - { - ret = GLEW_NV_float_buffer; - continue; - } -#endif -#ifdef GL_NV_fog_distance - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_distance", 12)) - { - ret = GLEW_NV_fog_distance; - continue; - } -#endif -#ifdef GL_NV_fragment_program - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program", 16)) - { - ret = GLEW_NV_fragment_program; - continue; - } -#endif -#ifdef GL_NV_fragment_program2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program2", 17)) - { - ret = GLEW_NV_fragment_program2; - continue; - } -#endif -#ifdef GL_NV_fragment_program4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program4", 17)) - { - ret = GLEW_NV_fragment_program4; - continue; - } -#endif -#ifdef GL_NV_fragment_program_option - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_program_option", 23)) - { - ret = GLEW_NV_fragment_program_option; - continue; - } -#endif -#ifdef GL_NV_framebuffer_multisample_coverage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_multisample_coverage", 32)) - { - ret = GLEW_NV_framebuffer_multisample_coverage; - continue; - } -#endif -#ifdef GL_NV_geometry_program4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_program4", 17)) - { - ret = GLEW_NV_geometry_program4; - continue; - } -#endif -#ifdef GL_NV_geometry_shader4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"geometry_shader4", 16)) - { - ret = GLEW_NV_geometry_shader4; - continue; - } -#endif -#ifdef GL_NV_gpu_program4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program4", 12)) - { - ret = GLEW_NV_gpu_program4; - continue; - } -#endif -#ifdef GL_NV_gpu_program5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program5", 12)) - { - ret = GLEW_NV_gpu_program5; - continue; - } -#endif -#ifdef GL_NV_gpu_program5_mem_extended - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program5_mem_extended", 25)) - { - ret = GLEW_NV_gpu_program5_mem_extended; - continue; - } -#endif -#ifdef GL_NV_gpu_program_fp64 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_program_fp64", 16)) - { - ret = GLEW_NV_gpu_program_fp64; - continue; - } -#endif -#ifdef GL_NV_gpu_shader5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_shader5", 11)) - { - ret = GLEW_NV_gpu_shader5; - continue; - } -#endif -#ifdef GL_NV_half_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"half_float", 10)) - { - ret = GLEW_NV_half_float; - continue; - } -#endif -#ifdef GL_NV_light_max_exponent - if (_glewStrSame3(&pos, &len, (const GLubyte*)"light_max_exponent", 18)) - { - ret = GLEW_NV_light_max_exponent; - continue; - } -#endif -#ifdef GL_NV_multisample_coverage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample_coverage", 20)) - { - ret = GLEW_NV_multisample_coverage; - continue; - } -#endif -#ifdef GL_NV_multisample_filter_hint - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample_filter_hint", 23)) - { - ret = GLEW_NV_multisample_filter_hint; - continue; - } -#endif -#ifdef GL_NV_occlusion_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"occlusion_query", 15)) - { - ret = GLEW_NV_occlusion_query; - continue; - } -#endif -#ifdef GL_NV_packed_depth_stencil - if (_glewStrSame3(&pos, &len, (const GLubyte*)"packed_depth_stencil", 20)) - { - ret = GLEW_NV_packed_depth_stencil; - continue; - } -#endif -#ifdef GL_NV_parameter_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"parameter_buffer_object", 23)) - { - ret = GLEW_NV_parameter_buffer_object; - continue; - } -#endif -#ifdef GL_NV_parameter_buffer_object2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"parameter_buffer_object2", 24)) - { - ret = GLEW_NV_parameter_buffer_object2; - continue; - } -#endif -#ifdef GL_NV_path_rendering - if (_glewStrSame3(&pos, &len, (const GLubyte*)"path_rendering", 14)) - { - ret = GLEW_NV_path_rendering; - continue; - } -#endif -#ifdef GL_NV_pixel_data_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_data_range", 16)) - { - ret = GLEW_NV_pixel_data_range; - continue; - } -#endif -#ifdef GL_NV_point_sprite - if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_sprite", 12)) - { - ret = GLEW_NV_point_sprite; - continue; - } -#endif -#ifdef GL_NV_present_video - if (_glewStrSame3(&pos, &len, (const GLubyte*)"present_video", 13)) - { - ret = GLEW_NV_present_video; - continue; - } -#endif -#ifdef GL_NV_primitive_restart - if (_glewStrSame3(&pos, &len, (const GLubyte*)"primitive_restart", 17)) - { - ret = GLEW_NV_primitive_restart; - continue; - } -#endif -#ifdef GL_NV_register_combiners - if (_glewStrSame3(&pos, &len, (const GLubyte*)"register_combiners", 18)) - { - ret = GLEW_NV_register_combiners; - continue; - } -#endif -#ifdef GL_NV_register_combiners2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"register_combiners2", 19)) - { - ret = GLEW_NV_register_combiners2; - continue; - } -#endif -#ifdef GL_NV_shader_atomic_counters - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_atomic_counters", 22)) - { - ret = GLEW_NV_shader_atomic_counters; - continue; - } -#endif -#ifdef GL_NV_shader_atomic_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_atomic_float", 19)) - { - ret = GLEW_NV_shader_atomic_float; - continue; - } -#endif -#ifdef GL_NV_shader_buffer_load - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_buffer_load", 18)) - { - ret = GLEW_NV_shader_buffer_load; - continue; - } -#endif -#ifdef GL_NV_shader_storage_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shader_storage_buffer_object", 28)) - { - ret = GLEW_NV_shader_storage_buffer_object; - continue; - } -#endif -#ifdef GL_NV_tessellation_program5 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"tessellation_program5", 21)) - { - ret = GLEW_NV_tessellation_program5; - continue; - } -#endif -#ifdef GL_NV_texgen_emboss - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texgen_emboss", 13)) - { - ret = GLEW_NV_texgen_emboss; - continue; - } -#endif -#ifdef GL_NV_texgen_reflection - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texgen_reflection", 17)) - { - ret = GLEW_NV_texgen_reflection; - continue; - } -#endif -#ifdef GL_NV_texture_barrier - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_barrier", 15)) - { - ret = GLEW_NV_texture_barrier; - continue; - } -#endif -#ifdef GL_NV_texture_compression_vtc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_compression_vtc", 23)) - { - ret = GLEW_NV_texture_compression_vtc; - continue; - } -#endif -#ifdef GL_NV_texture_env_combine4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_env_combine4", 20)) - { - ret = GLEW_NV_texture_env_combine4; - continue; - } -#endif -#ifdef GL_NV_texture_expand_normal - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_expand_normal", 21)) - { - ret = GLEW_NV_texture_expand_normal; - continue; - } -#endif -#ifdef GL_NV_texture_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_multisample", 19)) - { - ret = GLEW_NV_texture_multisample; - continue; - } -#endif -#ifdef GL_NV_texture_rectangle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_rectangle", 17)) - { - ret = GLEW_NV_texture_rectangle; - continue; - } -#endif -#ifdef GL_NV_texture_shader - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shader", 14)) - { - ret = GLEW_NV_texture_shader; - continue; - } -#endif -#ifdef GL_NV_texture_shader2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shader2", 15)) - { - ret = GLEW_NV_texture_shader2; - continue; - } -#endif -#ifdef GL_NV_texture_shader3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_shader3", 15)) - { - ret = GLEW_NV_texture_shader3; - continue; - } -#endif -#ifdef GL_NV_transform_feedback - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback", 18)) - { - ret = GLEW_NV_transform_feedback; - continue; - } -#endif -#ifdef GL_NV_transform_feedback2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"transform_feedback2", 19)) - { - ret = GLEW_NV_transform_feedback2; - continue; - } -#endif -#ifdef GL_NV_vdpau_interop - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vdpau_interop", 13)) - { - ret = GLEW_NV_vdpau_interop; - continue; - } -#endif -#ifdef GL_NV_vertex_array_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) - { - ret = GLEW_NV_vertex_array_range; - continue; - } -#endif -#ifdef GL_NV_vertex_array_range2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range2", 19)) - { - ret = GLEW_NV_vertex_array_range2; - continue; - } -#endif -#ifdef GL_NV_vertex_attrib_integer_64bit - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_attrib_integer_64bit", 27)) - { - ret = GLEW_NV_vertex_attrib_integer_64bit; - continue; - } -#endif -#ifdef GL_NV_vertex_buffer_unified_memory - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_buffer_unified_memory", 28)) - { - ret = GLEW_NV_vertex_buffer_unified_memory; - continue; - } -#endif -#ifdef GL_NV_vertex_program - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program", 14)) - { - ret = GLEW_NV_vertex_program; - continue; - } -#endif -#ifdef GL_NV_vertex_program1_1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program1_1", 17)) - { - ret = GLEW_NV_vertex_program1_1; - continue; - } -#endif -#ifdef GL_NV_vertex_program2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program2", 15)) - { - ret = GLEW_NV_vertex_program2; - continue; - } -#endif -#ifdef GL_NV_vertex_program2_option - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program2_option", 22)) - { - ret = GLEW_NV_vertex_program2_option; - continue; - } -#endif -#ifdef GL_NV_vertex_program3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program3", 15)) - { - ret = GLEW_NV_vertex_program3; - continue; - } -#endif -#ifdef GL_NV_vertex_program4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_program4", 15)) - { - ret = GLEW_NV_vertex_program4; - continue; - } -#endif -#ifdef GL_NV_video_capture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_capture", 13)) - { - ret = GLEW_NV_video_capture; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"OES_", 4)) - { -#ifdef GL_OES_byte_coordinates - if (_glewStrSame3(&pos, &len, (const GLubyte*)"byte_coordinates", 16)) - { - ret = GLEW_OES_byte_coordinates; - continue; - } -#endif -#ifdef GL_OES_compressed_paletted_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"compressed_paletted_texture", 27)) - { - ret = GLEW_OES_compressed_paletted_texture; - continue; - } -#endif -#ifdef GL_OES_read_format - if (_glewStrSame3(&pos, &len, (const GLubyte*)"read_format", 11)) - { - ret = GLEW_OES_read_format; - continue; - } -#endif -#ifdef GL_OES_single_precision - if (_glewStrSame3(&pos, &len, (const GLubyte*)"single_precision", 16)) - { - ret = GLEW_OES_single_precision; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"OML_", 4)) - { -#ifdef GL_OML_interlace - if (_glewStrSame3(&pos, &len, (const GLubyte*)"interlace", 9)) - { - ret = GLEW_OML_interlace; - continue; - } -#endif -#ifdef GL_OML_resample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"resample", 8)) - { - ret = GLEW_OML_resample; - continue; - } -#endif -#ifdef GL_OML_subsample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"subsample", 9)) - { - ret = GLEW_OML_subsample; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"PGI_", 4)) - { -#ifdef GL_PGI_misc_hints - if (_glewStrSame3(&pos, &len, (const GLubyte*)"misc_hints", 10)) - { - ret = GLEW_PGI_misc_hints; - continue; - } -#endif -#ifdef GL_PGI_vertex_hints - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_hints", 12)) - { - ret = GLEW_PGI_vertex_hints; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"REGAL_", 6)) - { -#ifdef GL_REGAL_ES1_0_compatibility - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ES1_0_compatibility", 19)) - { - ret = GLEW_REGAL_ES1_0_compatibility; - continue; - } -#endif -#ifdef GL_REGAL_ES1_1_compatibility - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ES1_1_compatibility", 19)) - { - ret = GLEW_REGAL_ES1_1_compatibility; - continue; - } -#endif -#ifdef GL_REGAL_enable - if (_glewStrSame3(&pos, &len, (const GLubyte*)"enable", 6)) - { - ret = GLEW_REGAL_enable; - continue; - } -#endif -#ifdef GL_REGAL_error_string - if (_glewStrSame3(&pos, &len, (const GLubyte*)"error_string", 12)) - { - ret = GLEW_REGAL_error_string; - continue; - } -#endif -#ifdef GL_REGAL_extension_query - if (_glewStrSame3(&pos, &len, (const GLubyte*)"extension_query", 15)) - { - ret = GLEW_REGAL_extension_query; - continue; - } -#endif -#ifdef GL_REGAL_log - if (_glewStrSame3(&pos, &len, (const GLubyte*)"log", 3)) - { - ret = GLEW_REGAL_log; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"REND_", 5)) - { -#ifdef GL_REND_screen_coordinates - if (_glewStrSame3(&pos, &len, (const GLubyte*)"screen_coordinates", 18)) - { - ret = GLEW_REND_screen_coordinates; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"S3_", 3)) - { -#ifdef GL_S3_s3tc - if (_glewStrSame3(&pos, &len, (const GLubyte*)"s3tc", 4)) - { - ret = GLEW_S3_s3tc; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIS_", 5)) - { -#ifdef GL_SGIS_color_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_range", 11)) - { - ret = GLEW_SGIS_color_range; - continue; - } -#endif -#ifdef GL_SGIS_detail_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"detail_texture", 14)) - { - ret = GLEW_SGIS_detail_texture; - continue; - } -#endif -#ifdef GL_SGIS_fog_function - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_function", 12)) - { - ret = GLEW_SGIS_fog_function; - continue; - } -#endif -#ifdef GL_SGIS_generate_mipmap - if (_glewStrSame3(&pos, &len, (const GLubyte*)"generate_mipmap", 15)) - { - ret = GLEW_SGIS_generate_mipmap; - continue; - } -#endif -#ifdef GL_SGIS_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLEW_SGIS_multisample; - continue; - } -#endif -#ifdef GL_SGIS_pixel_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_texture", 13)) - { - ret = GLEW_SGIS_pixel_texture; - continue; - } -#endif -#ifdef GL_SGIS_point_line_texgen - if (_glewStrSame3(&pos, &len, (const GLubyte*)"point_line_texgen", 17)) - { - ret = GLEW_SGIS_point_line_texgen; - continue; - } -#endif -#ifdef GL_SGIS_sharpen_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sharpen_texture", 15)) - { - ret = GLEW_SGIS_sharpen_texture; - continue; - } -#endif -#ifdef GL_SGIS_texture4D - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture4D", 9)) - { - ret = GLEW_SGIS_texture4D; - continue; - } -#endif -#ifdef GL_SGIS_texture_border_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_border_clamp", 20)) - { - ret = GLEW_SGIS_texture_border_clamp; - continue; - } -#endif -#ifdef GL_SGIS_texture_edge_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_edge_clamp", 18)) - { - ret = GLEW_SGIS_texture_edge_clamp; - continue; - } -#endif -#ifdef GL_SGIS_texture_filter4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_filter4", 15)) - { - ret = GLEW_SGIS_texture_filter4; - continue; - } -#endif -#ifdef GL_SGIS_texture_lod - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lod", 11)) - { - ret = GLEW_SGIS_texture_lod; - continue; - } -#endif -#ifdef GL_SGIS_texture_select - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_select", 14)) - { - ret = GLEW_SGIS_texture_select; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIX_", 5)) - { -#ifdef GL_SGIX_async - if (_glewStrSame3(&pos, &len, (const GLubyte*)"async", 5)) - { - ret = GLEW_SGIX_async; - continue; - } -#endif -#ifdef GL_SGIX_async_histogram - if (_glewStrSame3(&pos, &len, (const GLubyte*)"async_histogram", 15)) - { - ret = GLEW_SGIX_async_histogram; - continue; - } -#endif -#ifdef GL_SGIX_async_pixel - if (_glewStrSame3(&pos, &len, (const GLubyte*)"async_pixel", 11)) - { - ret = GLEW_SGIX_async_pixel; - continue; - } -#endif -#ifdef GL_SGIX_blend_alpha_minmax - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blend_alpha_minmax", 18)) - { - ret = GLEW_SGIX_blend_alpha_minmax; - continue; - } -#endif -#ifdef GL_SGIX_clipmap - if (_glewStrSame3(&pos, &len, (const GLubyte*)"clipmap", 7)) - { - ret = GLEW_SGIX_clipmap; - continue; - } -#endif -#ifdef GL_SGIX_convolution_accuracy - if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution_accuracy", 20)) - { - ret = GLEW_SGIX_convolution_accuracy; - continue; - } -#endif -#ifdef GL_SGIX_depth_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_texture", 13)) - { - ret = GLEW_SGIX_depth_texture; - continue; - } -#endif -#ifdef GL_SGIX_flush_raster - if (_glewStrSame3(&pos, &len, (const GLubyte*)"flush_raster", 12)) - { - ret = GLEW_SGIX_flush_raster; - continue; - } -#endif -#ifdef GL_SGIX_fog_offset - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_offset", 10)) - { - ret = GLEW_SGIX_fog_offset; - continue; - } -#endif -#ifdef GL_SGIX_fog_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fog_texture", 11)) - { - ret = GLEW_SGIX_fog_texture; - continue; - } -#endif -#ifdef GL_SGIX_fragment_specular_lighting - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fragment_specular_lighting", 26)) - { - ret = GLEW_SGIX_fragment_specular_lighting; - continue; - } -#endif -#ifdef GL_SGIX_framezoom - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framezoom", 9)) - { - ret = GLEW_SGIX_framezoom; - continue; - } -#endif -#ifdef GL_SGIX_interlace - if (_glewStrSame3(&pos, &len, (const GLubyte*)"interlace", 9)) - { - ret = GLEW_SGIX_interlace; - continue; - } -#endif -#ifdef GL_SGIX_ir_instrument1 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ir_instrument1", 14)) - { - ret = GLEW_SGIX_ir_instrument1; - continue; - } -#endif -#ifdef GL_SGIX_list_priority - if (_glewStrSame3(&pos, &len, (const GLubyte*)"list_priority", 13)) - { - ret = GLEW_SGIX_list_priority; - continue; - } -#endif -#ifdef GL_SGIX_pixel_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_texture", 13)) - { - ret = GLEW_SGIX_pixel_texture; - continue; - } -#endif -#ifdef GL_SGIX_pixel_texture_bits - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_texture_bits", 18)) - { - ret = GLEW_SGIX_pixel_texture_bits; - continue; - } -#endif -#ifdef GL_SGIX_reference_plane - if (_glewStrSame3(&pos, &len, (const GLubyte*)"reference_plane", 15)) - { - ret = GLEW_SGIX_reference_plane; - continue; - } -#endif -#ifdef GL_SGIX_resample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"resample", 8)) - { - ret = GLEW_SGIX_resample; - continue; - } -#endif -#ifdef GL_SGIX_shadow - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow", 6)) - { - ret = GLEW_SGIX_shadow; - continue; - } -#endif -#ifdef GL_SGIX_shadow_ambient - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shadow_ambient", 14)) - { - ret = GLEW_SGIX_shadow_ambient; - continue; - } -#endif -#ifdef GL_SGIX_sprite - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sprite", 6)) - { - ret = GLEW_SGIX_sprite; - continue; - } -#endif -#ifdef GL_SGIX_tag_sample_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"tag_sample_buffer", 17)) - { - ret = GLEW_SGIX_tag_sample_buffer; - continue; - } -#endif -#ifdef GL_SGIX_texture_add_env - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_add_env", 15)) - { - ret = GLEW_SGIX_texture_add_env; - continue; - } -#endif -#ifdef GL_SGIX_texture_coordinate_clamp - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_coordinate_clamp", 24)) - { - ret = GLEW_SGIX_texture_coordinate_clamp; - continue; - } -#endif -#ifdef GL_SGIX_texture_lod_bias - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_lod_bias", 16)) - { - ret = GLEW_SGIX_texture_lod_bias; - continue; - } -#endif -#ifdef GL_SGIX_texture_multi_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_multi_buffer", 20)) - { - ret = GLEW_SGIX_texture_multi_buffer; - continue; - } -#endif -#ifdef GL_SGIX_texture_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_range", 13)) - { - ret = GLEW_SGIX_texture_range; - continue; - } -#endif -#ifdef GL_SGIX_texture_scale_bias - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_scale_bias", 18)) - { - ret = GLEW_SGIX_texture_scale_bias; - continue; - } -#endif -#ifdef GL_SGIX_vertex_preclip - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_preclip", 14)) - { - ret = GLEW_SGIX_vertex_preclip; - continue; - } -#endif -#ifdef GL_SGIX_vertex_preclip_hint - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_preclip_hint", 19)) - { - ret = GLEW_SGIX_vertex_preclip_hint; - continue; - } -#endif -#ifdef GL_SGIX_ycrcb - if (_glewStrSame3(&pos, &len, (const GLubyte*)"ycrcb", 5)) - { - ret = GLEW_SGIX_ycrcb; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGI_", 4)) - { -#ifdef GL_SGI_color_matrix - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_matrix", 12)) - { - ret = GLEW_SGI_color_matrix; - continue; - } -#endif -#ifdef GL_SGI_color_table - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_table", 11)) - { - ret = GLEW_SGI_color_table; - continue; - } -#endif -#ifdef GL_SGI_texture_color_table - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_color_table", 19)) - { - ret = GLEW_SGI_texture_color_table; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SUNX_", 5)) - { -#ifdef GL_SUNX_constant_data - if (_glewStrSame3(&pos, &len, (const GLubyte*)"constant_data", 13)) - { - ret = GLEW_SUNX_constant_data; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SUN_", 4)) - { -#ifdef GL_SUN_convolution_border_modes - if (_glewStrSame3(&pos, &len, (const GLubyte*)"convolution_border_modes", 24)) - { - ret = GLEW_SUN_convolution_border_modes; - continue; - } -#endif -#ifdef GL_SUN_global_alpha - if (_glewStrSame3(&pos, &len, (const GLubyte*)"global_alpha", 12)) - { - ret = GLEW_SUN_global_alpha; - continue; - } -#endif -#ifdef GL_SUN_mesh_array - if (_glewStrSame3(&pos, &len, (const GLubyte*)"mesh_array", 10)) - { - ret = GLEW_SUN_mesh_array; - continue; - } -#endif -#ifdef GL_SUN_read_video_pixels - if (_glewStrSame3(&pos, &len, (const GLubyte*)"read_video_pixels", 17)) - { - ret = GLEW_SUN_read_video_pixels; - continue; - } -#endif -#ifdef GL_SUN_slice_accum - if (_glewStrSame3(&pos, &len, (const GLubyte*)"slice_accum", 11)) - { - ret = GLEW_SUN_slice_accum; - continue; - } -#endif -#ifdef GL_SUN_triangle_list - if (_glewStrSame3(&pos, &len, (const GLubyte*)"triangle_list", 13)) - { - ret = GLEW_SUN_triangle_list; - continue; - } -#endif -#ifdef GL_SUN_vertex - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex", 6)) - { - ret = GLEW_SUN_vertex; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"WIN_", 4)) - { -#ifdef GL_WIN_phong_shading - if (_glewStrSame3(&pos, &len, (const GLubyte*)"phong_shading", 13)) - { - ret = GLEW_WIN_phong_shading; - continue; - } -#endif -#ifdef GL_WIN_specular_fog - if (_glewStrSame3(&pos, &len, (const GLubyte*)"specular_fog", 12)) - { - ret = GLEW_WIN_specular_fog; - continue; - } -#endif -#ifdef GL_WIN_swap_hint - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_hint", 9)) - { - ret = GLEW_WIN_swap_hint; - continue; - } -#endif - } - } - ret = (len == 0); - } - return ret; -} - -#if defined(_WIN32) - -#if defined(GLEW_MX) -GLboolean GLEWAPIENTRY wglewContextIsSupported (const WGLEWContext* ctx, const char* name) -#else -GLboolean GLEWAPIENTRY wglewIsSupported (const char* name) -#endif -{ - GLubyte* pos = (GLubyte*)name; - GLuint len = _glewStrLen(pos); - GLboolean ret = GL_TRUE; - while (ret && len > 0) - { - if (_glewStrSame1(&pos, &len, (const GLubyte*)"WGL_", 4)) - { - if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DFX_", 5)) - { -#ifdef WGL_3DFX_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = WGLEW_3DFX_multisample; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DL_", 4)) - { -#ifdef WGL_3DL_stereo_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"stereo_control", 14)) - { - ret = WGLEW_3DL_stereo_control; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"AMD_", 4)) - { -#ifdef WGL_AMD_gpu_association - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_association", 15)) - { - ret = WGLEW_AMD_gpu_association; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ARB_", 4)) - { -#ifdef WGL_ARB_buffer_region - if (_glewStrSame3(&pos, &len, (const GLubyte*)"buffer_region", 13)) - { - ret = WGLEW_ARB_buffer_region; - continue; - } -#endif -#ifdef WGL_ARB_create_context - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context", 14)) - { - ret = WGLEW_ARB_create_context; - continue; - } -#endif -#ifdef WGL_ARB_create_context_profile - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_profile", 22)) - { - ret = WGLEW_ARB_create_context_profile; - continue; - } -#endif -#ifdef WGL_ARB_create_context_robustness - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_robustness", 25)) - { - ret = WGLEW_ARB_create_context_robustness; - continue; - } -#endif -#ifdef WGL_ARB_extensions_string - if (_glewStrSame3(&pos, &len, (const GLubyte*)"extensions_string", 17)) - { - ret = WGLEW_ARB_extensions_string; - continue; - } -#endif -#ifdef WGL_ARB_framebuffer_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) - { - ret = WGLEW_ARB_framebuffer_sRGB; - continue; - } -#endif -#ifdef WGL_ARB_make_current_read - if (_glewStrSame3(&pos, &len, (const GLubyte*)"make_current_read", 17)) - { - ret = WGLEW_ARB_make_current_read; - continue; - } -#endif -#ifdef WGL_ARB_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = WGLEW_ARB_multisample; - continue; - } -#endif -#ifdef WGL_ARB_pbuffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pbuffer", 7)) - { - ret = WGLEW_ARB_pbuffer; - continue; - } -#endif -#ifdef WGL_ARB_pixel_format - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format", 12)) - { - ret = WGLEW_ARB_pixel_format; - continue; - } -#endif -#ifdef WGL_ARB_pixel_format_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_float", 18)) - { - ret = WGLEW_ARB_pixel_format_float; - continue; - } -#endif -#ifdef WGL_ARB_render_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture", 14)) - { - ret = WGLEW_ARB_render_texture; - continue; - } -#endif -#ifdef WGL_ARB_robustness_application_isolation - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness_application_isolation", 32)) - { - ret = WGLEW_ARB_robustness_application_isolation; - continue; - } -#endif -#ifdef WGL_ARB_robustness_share_group_isolation - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness_share_group_isolation", 32)) - { - ret = WGLEW_ARB_robustness_share_group_isolation; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATI_", 4)) - { -#ifdef WGL_ATI_pixel_format_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_float", 18)) - { - ret = WGLEW_ATI_pixel_format_float; - continue; - } -#endif -#ifdef WGL_ATI_render_texture_rectangle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture_rectangle", 24)) - { - ret = WGLEW_ATI_render_texture_rectangle; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"EXT_", 4)) - { -#ifdef WGL_EXT_create_context_es2_profile - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_es2_profile", 26)) - { - ret = WGLEW_EXT_create_context_es2_profile; - continue; - } -#endif -#ifdef WGL_EXT_create_context_es_profile - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_es_profile", 25)) - { - ret = WGLEW_EXT_create_context_es_profile; - continue; - } -#endif -#ifdef WGL_EXT_depth_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"depth_float", 11)) - { - ret = WGLEW_EXT_depth_float; - continue; - } -#endif -#ifdef WGL_EXT_display_color_table - if (_glewStrSame3(&pos, &len, (const GLubyte*)"display_color_table", 19)) - { - ret = WGLEW_EXT_display_color_table; - continue; - } -#endif -#ifdef WGL_EXT_extensions_string - if (_glewStrSame3(&pos, &len, (const GLubyte*)"extensions_string", 17)) - { - ret = WGLEW_EXT_extensions_string; - continue; - } -#endif -#ifdef WGL_EXT_framebuffer_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) - { - ret = WGLEW_EXT_framebuffer_sRGB; - continue; - } -#endif -#ifdef WGL_EXT_make_current_read - if (_glewStrSame3(&pos, &len, (const GLubyte*)"make_current_read", 17)) - { - ret = WGLEW_EXT_make_current_read; - continue; - } -#endif -#ifdef WGL_EXT_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = WGLEW_EXT_multisample; - continue; - } -#endif -#ifdef WGL_EXT_pbuffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pbuffer", 7)) - { - ret = WGLEW_EXT_pbuffer; - continue; - } -#endif -#ifdef WGL_EXT_pixel_format - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format", 12)) - { - ret = WGLEW_EXT_pixel_format; - continue; - } -#endif -#ifdef WGL_EXT_pixel_format_packed_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_packed_float", 25)) - { - ret = WGLEW_EXT_pixel_format_packed_float; - continue; - } -#endif -#ifdef WGL_EXT_swap_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) - { - ret = WGLEW_EXT_swap_control; - continue; - } -#endif -#ifdef WGL_EXT_swap_control_tear - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control_tear", 17)) - { - ret = WGLEW_EXT_swap_control_tear; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"I3D_", 4)) - { -#ifdef WGL_I3D_digital_video_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"digital_video_control", 21)) - { - ret = WGLEW_I3D_digital_video_control; - continue; - } -#endif -#ifdef WGL_I3D_gamma - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gamma", 5)) - { - ret = WGLEW_I3D_gamma; - continue; - } -#endif -#ifdef WGL_I3D_genlock - if (_glewStrSame3(&pos, &len, (const GLubyte*)"genlock", 7)) - { - ret = WGLEW_I3D_genlock; - continue; - } -#endif -#ifdef WGL_I3D_image_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"image_buffer", 12)) - { - ret = WGLEW_I3D_image_buffer; - continue; - } -#endif -#ifdef WGL_I3D_swap_frame_lock - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_frame_lock", 15)) - { - ret = WGLEW_I3D_swap_frame_lock; - continue; - } -#endif -#ifdef WGL_I3D_swap_frame_usage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_frame_usage", 16)) - { - ret = WGLEW_I3D_swap_frame_usage; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"NV_", 3)) - { -#ifdef WGL_NV_DX_interop - if (_glewStrSame3(&pos, &len, (const GLubyte*)"DX_interop", 10)) - { - ret = WGLEW_NV_DX_interop; - continue; - } -#endif -#ifdef WGL_NV_DX_interop2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"DX_interop2", 11)) - { - ret = WGLEW_NV_DX_interop2; - continue; - } -#endif -#ifdef WGL_NV_copy_image - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) - { - ret = WGLEW_NV_copy_image; - continue; - } -#endif -#ifdef WGL_NV_float_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_buffer", 12)) - { - ret = WGLEW_NV_float_buffer; - continue; - } -#endif -#ifdef WGL_NV_gpu_affinity - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_affinity", 12)) - { - ret = WGLEW_NV_gpu_affinity; - continue; - } -#endif -#ifdef WGL_NV_multisample_coverage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample_coverage", 20)) - { - ret = WGLEW_NV_multisample_coverage; - continue; - } -#endif -#ifdef WGL_NV_present_video - if (_glewStrSame3(&pos, &len, (const GLubyte*)"present_video", 13)) - { - ret = WGLEW_NV_present_video; - continue; - } -#endif -#ifdef WGL_NV_render_depth_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_depth_texture", 20)) - { - ret = WGLEW_NV_render_depth_texture; - continue; - } -#endif -#ifdef WGL_NV_render_texture_rectangle - if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture_rectangle", 24)) - { - ret = WGLEW_NV_render_texture_rectangle; - continue; - } -#endif -#ifdef WGL_NV_swap_group - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_group", 10)) - { - ret = WGLEW_NV_swap_group; - continue; - } -#endif -#ifdef WGL_NV_vertex_array_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) - { - ret = WGLEW_NV_vertex_array_range; - continue; - } -#endif -#ifdef WGL_NV_video_capture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_capture", 13)) - { - ret = WGLEW_NV_video_capture; - continue; - } -#endif -#ifdef WGL_NV_video_output - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_output", 12)) - { - ret = WGLEW_NV_video_output; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"OML_", 4)) - { -#ifdef WGL_OML_sync_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sync_control", 12)) - { - ret = WGLEW_OML_sync_control; - continue; - } -#endif - } - } - ret = (len == 0); - } - return ret; -} - -#elif !defined(__ANDROID__) && !defined(__native_client__) && !defined(__APPLE__) || defined(GLEW_APPLE_GLX) - -#if defined(GLEW_MX) -GLboolean glxewContextIsSupported (const GLXEWContext* ctx, const char* name) -#else -GLboolean glxewIsSupported (const char* name) -#endif -{ - GLubyte* pos = (GLubyte*)name; - GLuint len = _glewStrLen(pos); - GLboolean ret = GL_TRUE; - while (ret && len > 0) - { - if(_glewStrSame1(&pos, &len, (const GLubyte*)"GLX_", 4)) - { - if (_glewStrSame2(&pos, &len, (const GLubyte*)"VERSION_", 8)) - { -#ifdef GLX_VERSION_1_2 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_2", 3)) - { - ret = GLXEW_VERSION_1_2; - continue; - } -#endif -#ifdef GLX_VERSION_1_3 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_3", 3)) - { - ret = GLXEW_VERSION_1_3; - continue; - } -#endif -#ifdef GLX_VERSION_1_4 - if (_glewStrSame3(&pos, &len, (const GLubyte*)"1_4", 3)) - { - ret = GLXEW_VERSION_1_4; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"3DFX_", 5)) - { -#ifdef GLX_3DFX_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLXEW_3DFX_multisample; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"AMD_", 4)) - { -#ifdef GLX_AMD_gpu_association - if (_glewStrSame3(&pos, &len, (const GLubyte*)"gpu_association", 15)) - { - ret = GLXEW_AMD_gpu_association; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ARB_", 4)) - { -#ifdef GLX_ARB_create_context - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context", 14)) - { - ret = GLXEW_ARB_create_context; - continue; - } -#endif -#ifdef GLX_ARB_create_context_profile - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_profile", 22)) - { - ret = GLXEW_ARB_create_context_profile; - continue; - } -#endif -#ifdef GLX_ARB_create_context_robustness - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_robustness", 25)) - { - ret = GLXEW_ARB_create_context_robustness; - continue; - } -#endif -#ifdef GLX_ARB_fbconfig_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fbconfig_float", 14)) - { - ret = GLXEW_ARB_fbconfig_float; - continue; - } -#endif -#ifdef GLX_ARB_framebuffer_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) - { - ret = GLXEW_ARB_framebuffer_sRGB; - continue; - } -#endif -#ifdef GLX_ARB_get_proc_address - if (_glewStrSame3(&pos, &len, (const GLubyte*)"get_proc_address", 16)) - { - ret = GLXEW_ARB_get_proc_address; - continue; - } -#endif -#ifdef GLX_ARB_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLXEW_ARB_multisample; - continue; - } -#endif -#ifdef GLX_ARB_robustness_application_isolation - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness_application_isolation", 32)) - { - ret = GLXEW_ARB_robustness_application_isolation; - continue; - } -#endif -#ifdef GLX_ARB_robustness_share_group_isolation - if (_glewStrSame3(&pos, &len, (const GLubyte*)"robustness_share_group_isolation", 32)) - { - ret = GLXEW_ARB_robustness_share_group_isolation; - continue; - } -#endif -#ifdef GLX_ARB_vertex_buffer_object - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_buffer_object", 20)) - { - ret = GLXEW_ARB_vertex_buffer_object; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"ATI_", 4)) - { -#ifdef GLX_ATI_pixel_format_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixel_format_float", 18)) - { - ret = GLXEW_ATI_pixel_format_float; - continue; - } -#endif -#ifdef GLX_ATI_render_texture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"render_texture", 14)) - { - ret = GLXEW_ATI_render_texture; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"EXT_", 4)) - { -#ifdef GLX_EXT_buffer_age - if (_glewStrSame3(&pos, &len, (const GLubyte*)"buffer_age", 10)) - { - ret = GLXEW_EXT_buffer_age; - continue; - } -#endif -#ifdef GLX_EXT_create_context_es2_profile - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_es2_profile", 26)) - { - ret = GLXEW_EXT_create_context_es2_profile; - continue; - } -#endif -#ifdef GLX_EXT_create_context_es_profile - if (_glewStrSame3(&pos, &len, (const GLubyte*)"create_context_es_profile", 25)) - { - ret = GLXEW_EXT_create_context_es_profile; - continue; - } -#endif -#ifdef GLX_EXT_fbconfig_packed_float - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fbconfig_packed_float", 21)) - { - ret = GLXEW_EXT_fbconfig_packed_float; - continue; - } -#endif -#ifdef GLX_EXT_framebuffer_sRGB - if (_glewStrSame3(&pos, &len, (const GLubyte*)"framebuffer_sRGB", 16)) - { - ret = GLXEW_EXT_framebuffer_sRGB; - continue; - } -#endif -#ifdef GLX_EXT_import_context - if (_glewStrSame3(&pos, &len, (const GLubyte*)"import_context", 14)) - { - ret = GLXEW_EXT_import_context; - continue; - } -#endif -#ifdef GLX_EXT_scene_marker - if (_glewStrSame3(&pos, &len, (const GLubyte*)"scene_marker", 12)) - { - ret = GLXEW_EXT_scene_marker; - continue; - } -#endif -#ifdef GLX_EXT_swap_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) - { - ret = GLXEW_EXT_swap_control; - continue; - } -#endif -#ifdef GLX_EXT_swap_control_tear - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control_tear", 17)) - { - ret = GLXEW_EXT_swap_control_tear; - continue; - } -#endif -#ifdef GLX_EXT_texture_from_pixmap - if (_glewStrSame3(&pos, &len, (const GLubyte*)"texture_from_pixmap", 19)) - { - ret = GLXEW_EXT_texture_from_pixmap; - continue; - } -#endif -#ifdef GLX_EXT_visual_info - if (_glewStrSame3(&pos, &len, (const GLubyte*)"visual_info", 11)) - { - ret = GLXEW_EXT_visual_info; - continue; - } -#endif -#ifdef GLX_EXT_visual_rating - if (_glewStrSame3(&pos, &len, (const GLubyte*)"visual_rating", 13)) - { - ret = GLXEW_EXT_visual_rating; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"INTEL_", 6)) - { -#ifdef GLX_INTEL_swap_event - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_event", 10)) - { - ret = GLXEW_INTEL_swap_event; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"MESA_", 5)) - { -#ifdef GLX_MESA_agp_offset - if (_glewStrSame3(&pos, &len, (const GLubyte*)"agp_offset", 10)) - { - ret = GLXEW_MESA_agp_offset; - continue; - } -#endif -#ifdef GLX_MESA_copy_sub_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_sub_buffer", 15)) - { - ret = GLXEW_MESA_copy_sub_buffer; - continue; - } -#endif -#ifdef GLX_MESA_pixmap_colormap - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pixmap_colormap", 15)) - { - ret = GLXEW_MESA_pixmap_colormap; - continue; - } -#endif -#ifdef GLX_MESA_release_buffers - if (_glewStrSame3(&pos, &len, (const GLubyte*)"release_buffers", 15)) - { - ret = GLXEW_MESA_release_buffers; - continue; - } -#endif -#ifdef GLX_MESA_set_3dfx_mode - if (_glewStrSame3(&pos, &len, (const GLubyte*)"set_3dfx_mode", 13)) - { - ret = GLXEW_MESA_set_3dfx_mode; - continue; - } -#endif -#ifdef GLX_MESA_swap_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) - { - ret = GLXEW_MESA_swap_control; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"NV_", 3)) - { -#ifdef GLX_NV_copy_image - if (_glewStrSame3(&pos, &len, (const GLubyte*)"copy_image", 10)) - { - ret = GLXEW_NV_copy_image; - continue; - } -#endif -#ifdef GLX_NV_float_buffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"float_buffer", 12)) - { - ret = GLXEW_NV_float_buffer; - continue; - } -#endif -#ifdef GLX_NV_multisample_coverage - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample_coverage", 20)) - { - ret = GLXEW_NV_multisample_coverage; - continue; - } -#endif -#ifdef GLX_NV_present_video - if (_glewStrSame3(&pos, &len, (const GLubyte*)"present_video", 13)) - { - ret = GLXEW_NV_present_video; - continue; - } -#endif -#ifdef GLX_NV_swap_group - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_group", 10)) - { - ret = GLXEW_NV_swap_group; - continue; - } -#endif -#ifdef GLX_NV_vertex_array_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"vertex_array_range", 18)) - { - ret = GLXEW_NV_vertex_array_range; - continue; - } -#endif -#ifdef GLX_NV_video_capture - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_capture", 13)) - { - ret = GLXEW_NV_video_capture; - continue; - } -#endif -#ifdef GLX_NV_video_output - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_output", 12)) - { - ret = GLXEW_NV_video_output; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"OML_", 4)) - { -#ifdef GLX_OML_swap_method - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_method", 11)) - { - ret = GLXEW_OML_swap_method; - continue; - } -#endif -#ifdef GLX_OML_sync_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"sync_control", 12)) - { - ret = GLXEW_OML_sync_control; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIS_", 5)) - { -#ifdef GLX_SGIS_blended_overlay - if (_glewStrSame3(&pos, &len, (const GLubyte*)"blended_overlay", 15)) - { - ret = GLXEW_SGIS_blended_overlay; - continue; - } -#endif -#ifdef GLX_SGIS_color_range - if (_glewStrSame3(&pos, &len, (const GLubyte*)"color_range", 11)) - { - ret = GLXEW_SGIS_color_range; - continue; - } -#endif -#ifdef GLX_SGIS_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"multisample", 11)) - { - ret = GLXEW_SGIS_multisample; - continue; - } -#endif -#ifdef GLX_SGIS_shared_multisample - if (_glewStrSame3(&pos, &len, (const GLubyte*)"shared_multisample", 18)) - { - ret = GLXEW_SGIS_shared_multisample; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGIX_", 5)) - { -#ifdef GLX_SGIX_fbconfig - if (_glewStrSame3(&pos, &len, (const GLubyte*)"fbconfig", 8)) - { - ret = GLXEW_SGIX_fbconfig; - continue; - } -#endif -#ifdef GLX_SGIX_hyperpipe - if (_glewStrSame3(&pos, &len, (const GLubyte*)"hyperpipe", 9)) - { - ret = GLXEW_SGIX_hyperpipe; - continue; - } -#endif -#ifdef GLX_SGIX_pbuffer - if (_glewStrSame3(&pos, &len, (const GLubyte*)"pbuffer", 7)) - { - ret = GLXEW_SGIX_pbuffer; - continue; - } -#endif -#ifdef GLX_SGIX_swap_barrier - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_barrier", 12)) - { - ret = GLXEW_SGIX_swap_barrier; - continue; - } -#endif -#ifdef GLX_SGIX_swap_group - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_group", 10)) - { - ret = GLXEW_SGIX_swap_group; - continue; - } -#endif -#ifdef GLX_SGIX_video_resize - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_resize", 12)) - { - ret = GLXEW_SGIX_video_resize; - continue; - } -#endif -#ifdef GLX_SGIX_visual_select_group - if (_glewStrSame3(&pos, &len, (const GLubyte*)"visual_select_group", 19)) - { - ret = GLXEW_SGIX_visual_select_group; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SGI_", 4)) - { -#ifdef GLX_SGI_cushion - if (_glewStrSame3(&pos, &len, (const GLubyte*)"cushion", 7)) - { - ret = GLXEW_SGI_cushion; - continue; - } -#endif -#ifdef GLX_SGI_make_current_read - if (_glewStrSame3(&pos, &len, (const GLubyte*)"make_current_read", 17)) - { - ret = GLXEW_SGI_make_current_read; - continue; - } -#endif -#ifdef GLX_SGI_swap_control - if (_glewStrSame3(&pos, &len, (const GLubyte*)"swap_control", 12)) - { - ret = GLXEW_SGI_swap_control; - continue; - } -#endif -#ifdef GLX_SGI_video_sync - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_sync", 10)) - { - ret = GLXEW_SGI_video_sync; - continue; - } -#endif - } - if (_glewStrSame2(&pos, &len, (const GLubyte*)"SUN_", 4)) - { -#ifdef GLX_SUN_get_transparent_index - if (_glewStrSame3(&pos, &len, (const GLubyte*)"get_transparent_index", 21)) - { - ret = GLXEW_SUN_get_transparent_index; - continue; - } -#endif -#ifdef GLX_SUN_video_resize - if (_glewStrSame3(&pos, &len, (const GLubyte*)"video_resize", 12)) - { - ret = GLXEW_SUN_video_resize; - continue; - } -#endif - } - } - ret = (len == 0); - } - return ret; -} - -#endif /* _WIN32 */ diff --git a/btgui/OpenGLWindow/GwenOpenGL3CoreRenderer.h b/btgui/OpenGLWindow/GwenOpenGL3CoreRenderer.h deleted file mode 100644 index fb3abe410..000000000 --- a/btgui/OpenGLWindow/GwenOpenGL3CoreRenderer.h +++ /dev/null @@ -1,393 +0,0 @@ - -#ifndef __GWEN_OPENGL3_CORE_RENDERER_H -#define __GWEN_OPENGL3_CORE_RENDERER_H - -#include "Gwen/Gwen.h" -#include "Gwen/BaseRender.h" -#include "GLPrimitiveRenderer.h" -#include "OpenGLWindow/OpenGLInclude.h" - -struct sth_stash; -#include "fontstash.h" -#include "Gwen/Texture.h" - -#include "TwFonts.h" -static float extraSpacing = 0.;//6f; -#include -#include - -template -inline void MyClamp(T& a, const T& lb, const T& ub) -{ - if (a < lb) - { - a = lb; - } - else if (ub < a) - { - a = ub; - } -} - - -static GLuint BindFont(const CTexFont *_Font) -{ - GLuint TexID = 0; - glGenTextures(1, &TexID); - glBindTexture(GL_TEXTURE_2D, TexID); - glPixelStorei(GL_UNPACK_SWAP_BYTES, GL_FALSE); - glPixelStorei(GL_UNPACK_LSB_FIRST, GL_FALSE); - glPixelStorei(GL_UNPACK_ROW_LENGTH, 0); - glPixelStorei(GL_UNPACK_SKIP_ROWS, 0); - glPixelStorei(GL_UNPACK_SKIP_PIXELS, 0); - glPixelStorei(GL_UNPACK_ALIGNMENT, 1); - glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, _Font->m_TexWidth, _Font->m_TexHeight, 0, GL_RED, GL_UNSIGNED_BYTE, _Font->m_TexBytes); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER,GL_NEAREST); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,GL_NEAREST); - glBindTexture(GL_TEXTURE_2D, 0); - - return TexID; -} - -struct MyTextureLoader -{ - virtual ~MyTextureLoader() - { - } - virtual void LoadTexture( Gwen::Texture* pTexture ) = 0; - virtual void FreeTexture( Gwen::Texture* pTexture )=0; -}; - -class GwenOpenGL3CoreRenderer : public Gwen::Renderer::Base -{ - GLPrimitiveRenderer* m_primitiveRenderer; - float m_currentColor[4]; - float m_yOffset; - sth_stash* m_font; - float m_screenWidth; - float m_screenHeight; - float m_fontScaling; - float m_retinaScale; - bool m_useTrueTypeFont; - const CTexFont* m_currentFont; - - GLuint m_fontTextureId; - MyTextureLoader* m_textureLoader; -public: - GwenOpenGL3CoreRenderer (GLPrimitiveRenderer* primRender, sth_stash* font,float screenWidth, float screenHeight, float retinaScale, MyTextureLoader* loader=0) - :m_primitiveRenderer(primRender), - m_font(font), - m_screenWidth(screenWidth), - m_screenHeight(screenHeight), - m_retinaScale(retinaScale), - m_useTrueTypeFont(false), - m_textureLoader(loader) - { - ///only enable true type fonts on Macbook Retina, it looks gorgeous - if (retinaScale==2.0f) - { - m_useTrueTypeFont = true; - } - m_currentColor[0] = 1; - m_currentColor[1] = 1; - m_currentColor[2] = 1; - m_currentColor[3] = 1; - - m_fontScaling = 16.f*m_retinaScale; - - TwGenerateDefaultFonts(); - - m_currentFont = g_DefaultNormalFont; - //m_currentFont = g_DefaultNormalFontAA; - - //m_currentFont = g_DefaultLargeFont; - m_fontTextureId = BindFont(m_currentFont); - - } - - virtual ~GwenOpenGL3CoreRenderer() - { - TwDeleteDefaultFonts(); - } - virtual void Resize(int width, int height) - { - m_screenWidth = width; - m_screenHeight = height; - } - - virtual void Begin() - { - m_yOffset=0; - glEnable(GL_BLEND); - assert(glGetError()==GL_NO_ERROR); - - - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - - assert(glGetError()==GL_NO_ERROR); - - assert(glGetError()==GL_NO_ERROR); - - glDisable(GL_DEPTH_TEST); - assert(glGetError()==GL_NO_ERROR); - //glColor4ub(255,0,0,255); - - - - glBlendFunc(GL_SRC_ALPHA,GL_ONE_MINUS_SRC_ALPHA); - - // saveOpenGLState(width,height);//m_glutScreenWidth,m_glutScreenHeight); - - assert(glGetError()==GL_NO_ERROR); - - - glDisable(GL_CULL_FACE); - - glDisable(GL_DEPTH_TEST); - assert(glGetError()==GL_NO_ERROR); - - - glEnable(GL_BLEND); - - assert(glGetError()==GL_NO_ERROR); - } - virtual void End() - { - glDisable(GL_BLEND); - - } - - virtual void StartClip() - { - if (m_useTrueTypeFont) - sth_flush_draw(m_font); - Gwen::Rect rect = ClipRegion(); - - // OpenGL's coords are from the bottom left - // so we need to translate them here. - { - GLint view[4]; - glGetIntegerv( GL_VIEWPORT, &view[0] ); - rect.y = view[3]/m_retinaScale - (rect.y + rect.h); - } - - glScissor( m_retinaScale * rect.x * Scale(), m_retinaScale * rect.y * Scale(), m_retinaScale * rect.w * Scale(), m_retinaScale * rect.h * Scale() ); - glEnable( GL_SCISSOR_TEST ); - //glDisable( GL_SCISSOR_TEST ); - - }; - - virtual void EndClip() - { - if (m_useTrueTypeFont) - sth_flush_draw(m_font); - glDisable( GL_SCISSOR_TEST ); - }; - - virtual void SetDrawColor( Gwen::Color color ) - { - m_currentColor[0] = color.r/256.f; - m_currentColor[1] = color.g/256.f; - m_currentColor[2] = color.b/256.f; - m_currentColor[3] = color.a/256.f; - - } - virtual void DrawFilledRect( Gwen::Rect rect ) - { - Translate( rect ); - - m_primitiveRenderer->drawRect(rect.x, rect.y+m_yOffset, rect.x+rect.w, rect.y+rect.h+m_yOffset, m_currentColor); -// m_yOffset+=rect.h+10; - - } - - void RenderText( Gwen::Font* pFont, Gwen::Point rasterPos, const Gwen::UnicodeString& text ) - { - - Gwen::String str = Gwen::Utility::UnicodeToString(text); - const char* unicodeText = (const char*)str.c_str(); - - Gwen::Rect r; - r.x = rasterPos.x; - r.y = rasterPos.y; - r.w = 0; - r.h = 0; - - - // - //printf("str = %s\n",unicodeText); - //int xpos=0; - //int ypos=0; - float dx; - - int measureOnly=0; - - if (m_useTrueTypeFont) - { - - float yoffset = 0.f; - if (m_retinaScale==2.0f) - { - yoffset = -12; - } - Translate(r); - sth_draw_text(m_font, - 1,m_fontScaling, - r.x,r.y+yoffset, - unicodeText,&dx, m_screenWidth,m_screenHeight,measureOnly,m_retinaScale); - - } else - { - //float width = 0.f; - int pos=0; - //float color[]={0.2f,0.2,0.2f,1.f}; - - glBindTexture(GL_TEXTURE_2D,m_fontTextureId); - float width = r.x; - while (unicodeText[pos]) - { - int c = unicodeText[pos]; - r.h = m_currentFont->m_CharHeight; - r.w = m_currentFont->m_CharWidth[c]+extraSpacing; - Gwen::Rect rect = r; - Translate( rect ); - - m_primitiveRenderer->drawTexturedRect(rect.x, rect.y+m_yOffset, rect.x+rect.w, rect.y+rect.h+m_yOffset, m_currentColor,m_currentFont->m_CharU0[c],m_currentFont->m_CharV0[c],m_currentFont->m_CharU1[c],m_currentFont->m_CharV1[c]); - - //DrawTexturedRect(0,r,m_currentFont->m_CharU0[c],m_currentFont->m_CharV0[c],m_currentFont->m_CharU1[c],m_currentFont->m_CharV1[c]); - // DrawFilledRect(r); - - - - width += r.w; - r.x = width; - pos++; - - } - glBindTexture(GL_TEXTURE_2D,0); - } - - } - Gwen::Point MeasureText( Gwen::Font* pFont, const Gwen::UnicodeString& text ) - { - Gwen::String str = Gwen::Utility::UnicodeToString(text); - const char* unicodeText = (const char*)str.c_str(); - - // printf("str = %s\n",unicodeText); - int xpos=0; - int ypos=0; - - - int measureOnly=1; - float dx=0; - if (m_useTrueTypeFont) - { - sth_draw_text(m_font, - 1,m_fontScaling, - xpos,ypos, - unicodeText,&dx, m_screenWidth,m_screenHeight,measureOnly); - - Gwen::Point pt; - - if (m_retinaScale==2.0f) - { - pt.x = dx*Scale()/2.f; - pt.y = m_fontScaling/2*Scale()+1; - } - else - { - pt.x = dx*Scale(); - pt.y = m_fontScaling*Scale()+1; - } - return pt; - } - else - { - float width = 0.f; - int pos=0; - while (unicodeText[pos]) - { - width += m_currentFont->m_CharWidth[(int)unicodeText[pos]]+extraSpacing; - pos++; - } - Gwen::Point pt; - int fontHeight = m_currentFont->m_CharHeight; - - - pt.x = width*Scale(); - pt.y = (fontHeight+2) * Scale(); - - return pt; - } - - return Gwen::Renderer::Base::MeasureText(pFont,text); - } - - - virtual void LoadTexture( Gwen::Texture* pTexture ) - { - if (m_textureLoader) - m_textureLoader->LoadTexture(pTexture); - } - virtual void FreeTexture( Gwen::Texture* pTexture ) - { - if (m_textureLoader) - m_textureLoader->FreeTexture(pTexture); - - } - - - virtual void DrawTexturedRect( Gwen::Texture* pTexture, Gwen::Rect rect, float u1=0.0f, float v1=0.0f, float u2=1.0f, float v2=1.0f ) - { - - Translate( rect ); - - //float eraseColor[4] = {0,0,0,0}; - //m_primitiveRenderer->drawRect(rect.x, rect.y+m_yOffset, rect.x+rect.w, rect.y+rect.h+m_yOffset, eraseColor); - - GLint texHandle = (GLint) pTexture->m_intData; - //if (!texHandle) - // return; - - glActiveTexture(GL_TEXTURE0); - glBindTexture(GL_TEXTURE_2D,texHandle); -// glDisable(GL_DEPTH_TEST); - - assert(glGetError()==GL_NO_ERROR); - - -/* bool useFiltering = true; - if (useFiltering) - { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); - } else - { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - } - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT); -*/ - - //glEnable(GL_TEXTURE_2D); - - - -// glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_COMPARE_MODE, GL_NONE ); - static float add=0.0; - //add+=1./512.;//0.01; - float color[4]={1,1,1,1}; - - m_primitiveRenderer->drawTexturedRect(rect.x, rect.y+m_yOffset, rect.x+rect.w, rect.y+rect.h+m_yOffset, color,0+add,0,1+add,1,true); - - - assert(glGetError()==GL_NO_ERROR); - - - - } - -}; -#endif //__GWEN_OPENGL3_CORE_RENDERER_H diff --git a/btgui/OpenGLWindow/LoadShader.cpp b/btgui/OpenGLWindow/LoadShader.cpp deleted file mode 100644 index e24fa7f12..000000000 --- a/btgui/OpenGLWindow/LoadShader.cpp +++ /dev/null @@ -1,111 +0,0 @@ -#include "LoadShader.h" -#include "OpenGLInclude.h" -#include -#include -#include - - -// Load the shader from the source text -void gltLoadShaderSrc(const char *szShaderSrc, GLuint shader) -{ - GLchar *fsStringPtr[1]; - - fsStringPtr[0] = (GLchar *)szShaderSrc; - glShaderSource(shader, 1, (const GLchar **)fsStringPtr, NULL); -} - - -GLuint gltLoadShaderPair(const char *szVertexProg, const char *szFragmentProg) -{ - - assert(glGetError()==GL_NO_ERROR); - - // Temporary Shader objects - GLuint hVertexShader; - GLuint hFragmentShader; - GLuint hReturn = 0; - GLint testVal; - - // Create shader objects - hVertexShader = glCreateShader(GL_VERTEX_SHADER); - hFragmentShader = glCreateShader(GL_FRAGMENT_SHADER); - - gltLoadShaderSrc(szVertexProg, hVertexShader); - gltLoadShaderSrc(szFragmentProg, hFragmentShader); - - // Compile them - glCompileShader(hVertexShader); - assert(glGetError()==GL_NO_ERROR); - - glGetShaderiv(hVertexShader, GL_COMPILE_STATUS, &testVal); - if(testVal == GL_FALSE) - { - char temp[256] = ""; - glGetShaderInfoLog( hVertexShader, 256, NULL, temp); - fprintf( stderr, "Compile failed:\n%s\n", temp); - assert(0); - return 0; - glDeleteShader(hVertexShader); - glDeleteShader(hFragmentShader); - return (GLuint)NULL; - } - - assert(glGetError()==GL_NO_ERROR); - - glCompileShader(hFragmentShader); - assert(glGetError()==GL_NO_ERROR); - - glGetShaderiv(hFragmentShader, GL_COMPILE_STATUS, &testVal); - if(testVal == GL_FALSE) - { - char temp[256] = ""; - glGetShaderInfoLog( hFragmentShader, 256, NULL, temp); - fprintf( stderr, "Compile failed:\n%s\n", temp); - assert(0); - exit(0); - glDeleteShader(hVertexShader); - glDeleteShader(hFragmentShader); - return (GLuint)NULL; - } - - assert(glGetError()==GL_NO_ERROR); - - // Check for errors - - - - - // Link them - assuming it works... - hReturn = glCreateProgram(); - glAttachShader(hReturn, hVertexShader); - glAttachShader(hReturn, hFragmentShader); - - glLinkProgram(hReturn); - - // These are no longer needed - glDeleteShader(hVertexShader); - glDeleteShader(hFragmentShader); - - // Make sure link worked too - glGetProgramiv(hReturn, GL_LINK_STATUS, &testVal); - if(testVal == GL_FALSE) - { - GLsizei maxLen = 4096; - GLchar infoLog[4096]; - GLsizei actualLen; - - glGetProgramInfoLog( hReturn, - maxLen, - &actualLen, - infoLog); - - printf("Warning/Error in GLSL shader:\n"); - printf("%s\n",infoLog); - glDeleteProgram(hReturn); - return (GLuint)NULL; - } - - return hReturn; -} - - diff --git a/btgui/OpenGLWindow/LoadShader.h b/btgui/OpenGLWindow/LoadShader.h deleted file mode 100644 index e41c97904..000000000 --- a/btgui/OpenGLWindow/LoadShader.h +++ /dev/null @@ -1,18 +0,0 @@ -#ifndef _LOAD_SHADER_H -#define _LOAD_SHADER_H - -#include "OpenGLInclude.h" - -#ifdef __cplusplus -extern "C" { -#endif//__cplusplus - -GLuint gltLoadShaderPair(const char *szVertexProg, const char *szFragmentProg); - -#ifdef __cplusplus -} -#endif//__cplusplus - -#endif//_LOAD_SHADER_H - - diff --git a/btgui/OpenGLWindow/MacOpenGLWindow.h b/btgui/OpenGLWindow/MacOpenGLWindow.h deleted file mode 100644 index d31387574..000000000 --- a/btgui/OpenGLWindow/MacOpenGLWindow.h +++ /dev/null @@ -1,105 +0,0 @@ -#ifndef MAC_OPENGL_WINDOW_H -#define MAC_OPENGL_WINDOW_H - -#include "b3gWindowInterface.h" - -#define b3gDefaultOpenGLWindow MacOpenGLWindow - -class MacOpenGLWindow : public b3gWindowInterface -{ - struct MacOpenGLWindowInternalData* m_internalData; - float m_mouseX; - float m_mouseY; - int m_modifierFlags; - - b3MouseButtonCallback m_mouseButtonCallback; - b3MouseMoveCallback m_mouseMoveCallback; - b3WheelCallback m_wheelCallback; - b3KeyboardCallback m_keyboardCallback; - b3RenderCallback m_renderCallback; - - float m_retinaScaleFactor; -public: - - MacOpenGLWindow(); - virtual ~MacOpenGLWindow(); - - void init(int width, int height, const char* windowTitle); - - void closeWindow(); - - void startRendering(); - - void endRendering();//swap buffers - - virtual bool requestedExit() const; - - virtual void setRequestExit(); - - void getMouseCoordinates(int& x, int& y); - - void runMainLoop(); - - void setMouseButtonCallback(b3MouseButtonCallback mouseCallback) - { - m_mouseButtonCallback = mouseCallback; - } - - void setMouseMoveCallback(b3MouseMoveCallback mouseCallback) - { - m_mouseMoveCallback = mouseCallback; - } - - void setResizeCallback(b3ResizeCallback resizeCallback); - - void setKeyboardCallback( b3KeyboardCallback keyboardCallback) - { - m_keyboardCallback = keyboardCallback; - } - - virtual b3MouseMoveCallback getMouseMoveCallback() - { - return m_mouseMoveCallback; - } - virtual b3MouseButtonCallback getMouseButtonCallback() - { - return m_mouseButtonCallback; - } - virtual b3ResizeCallback getResizeCallback(); - virtual b3WheelCallback getWheelCallback() - { - return m_wheelCallback; - } - - b3KeyboardCallback getKeyboardCallback() - { - return m_keyboardCallback; - } - - void setWheelCallback (b3WheelCallback wheelCallback) - { - m_wheelCallback = wheelCallback; - } - - float getRetinaScale() const - { - return m_retinaScaleFactor; - } - - virtual void createWindow(const b3gWindowConstructionInfo& ci); - - virtual float getTimeInSeconds(); - - - - virtual void setRenderCallback( b3RenderCallback renderCallback); - - virtual void setWindowTitle(const char* title); - - int fileOpenDialog(char* filename, int maxNameLength); - -}; - - -#endif - diff --git a/btgui/OpenGLWindow/MacOpenGLWindow.mm b/btgui/OpenGLWindow/MacOpenGLWindow.mm deleted file mode 100644 index 50998b7e7..000000000 --- a/btgui/OpenGLWindow/MacOpenGLWindow.mm +++ /dev/null @@ -1,1079 +0,0 @@ -#include "MacOpenGLWindow.h" - -#define GL_DO_NOT_WARN_IF_MULTI_GL_VERSION_HEADERS_INCLUDED -#import -#include -#include - - -#include -#include -#include -#include - - - - -/* report GL errors, if any, to stderr */ -static void checkError(const char *functionName) -{ - GLenum error; - while (( error = glGetError() ) != GL_NO_ERROR) - { - fprintf (stderr, "GL error 0x%X detected in %s\n", error, functionName); - } -} - -void dumpInfo(void) -{ - printf ("Vendor: %s\n", glGetString (GL_VENDOR)); - printf ("Renderer: %s\n", glGetString (GL_RENDERER)); - printf ("Version: %s\n", glGetString (GL_VERSION)); - printf ("GLSL: %s\n", glGetString (GL_SHADING_LANGUAGE_VERSION)); - checkError ("dumpInfo"); -} - - - - - -// -------------------- View ------------------------ - -@interface TestView : NSView -{ - NSOpenGLContext* m_context; - int m_lastWidth; - int m_lastHeight; - b3ResizeCallback m_resizeCallback; - -} --(void)drawRect:(NSRect)rect; --(void) MakeContext:(int) openglVersion; --(void) MakeCurrent; --(float) GetWindowWidth; --(float) GetWindowHeight; --(void) setResizeCallback:(b3ResizeCallback) callback; --(b3ResizeCallback) getResizeCallback; -@end - -float loop; - -#define Pi 3.1415 - -@implementation TestView - --(float) GetWindowWidth -{ - return m_lastWidth; -} --(float) GetWindowHeight -{ - return m_lastHeight; -} - --(b3ResizeCallback) getResizeCallback -{ - return m_resizeCallback; -} - --(void)setResizeCallback:(b3ResizeCallback)callback -{ - m_resizeCallback = callback; -} --(void)drawRect:(NSRect)rect -{ - if (([self frame].size.width != m_lastWidth) || ([self frame].size.height != m_lastHeight)) - { - m_lastWidth = [self frame].size.width; - m_lastHeight = [self frame].size.height; - - // Only needed on resize: - [m_context clearDrawable]; - -// reshape([self frame].size.width, [self frame].size.height); - float width = [self frame].size.width; - float height = [self frame].size.height; - - - // Get view dimensions in pixels - // glViewport(0,0,10,10); - - if (m_resizeCallback) - { - (*m_resizeCallback)(width,height); - } - - NSRect backingBounds = [self convertRectToBacking:[self bounds]]; - GLsizei backingPixelWidth = (GLsizei)(backingBounds.size.width), - backingPixelHeight = (GLsizei)(backingBounds.size.height); - - // Set viewport - glViewport(0, 0, backingPixelWidth, backingPixelHeight); - - // glViewport(0,0,(GLsizei)width,(GLsizei)height); - - } - - [m_context setView: self]; - [m_context makeCurrentContext]; - - // Draw - //display(); - - [m_context flushBuffer]; - [NSOpenGLContext clearCurrentContext]; - - loop = loop + 0.1; -} - --(void) MakeContext :(int) openglVersion -{ - // NSWindow *w; - NSOpenGLPixelFormat *fmt; - - - - - - - if (openglVersion==3) - { - NSOpenGLPixelFormatAttribute attrs[] = - { - NSOpenGLPFAOpenGLProfile, - NSOpenGLProfileVersion3_2Core, - NSOpenGLPFADoubleBuffer, - NSOpenGLPFADepthSize, 32, - NSOpenGLPFAStencilSize, (NSOpenGLPixelFormatAttribute)8, - (NSOpenGLPixelFormatAttribute)0 - }; - - // Init GL context - fmt = [[NSOpenGLPixelFormat alloc] initWithAttributes: (NSOpenGLPixelFormatAttribute*)attrs]; - } else - { - NSOpenGLPixelFormatAttribute attrs[] = - { - NSOpenGLPFADoubleBuffer, - NSOpenGLPFADepthSize, 32, - NSOpenGLPFAStencilSize, (NSOpenGLPixelFormatAttribute)8, - (NSOpenGLPixelFormatAttribute)0 - }; - // Init GL context - fmt = [[NSOpenGLPixelFormat alloc] initWithAttributes: (NSOpenGLPixelFormatAttribute*)attrs]; - - } - m_context = [[NSOpenGLContext alloc] initWithFormat: fmt shareContext: nil]; - [fmt release]; - [m_context makeCurrentContext]; - - checkError("makeCurrentContext"); -} - --(void) MakeCurrent -{ - [m_context makeCurrentContext]; -} --(void)windowWillClose:(NSNotification *)note -{ - [[NSApplication sharedApplication] terminate:self]; -} -@end - -struct MacOpenGLWindowInternalData -{ - MacOpenGLWindowInternalData() - { - m_myApp = 0; - m_myview = 0; - m_pool = 0; - m_window = 0; - m_width = -1; - m_height = -1; - m_exitRequested = false; - } - NSApplication* m_myApp; - TestView* m_myview; - NSAutoreleasePool* m_pool; - NSWindow* m_window; - int m_width; - int m_height; - bool m_exitRequested; - -}; - -MacOpenGLWindow::MacOpenGLWindow() -:m_internalData(0), -m_mouseX(0), -m_mouseY(0), -m_modifierFlags(0), -m_mouseMoveCallback(0), -m_mouseButtonCallback(0), -m_wheelCallback(0), -m_keyboardCallback(0), -m_retinaScaleFactor(1) -{ -} - -MacOpenGLWindow::~MacOpenGLWindow() -{ - if (m_internalData) - closeWindow(); -} - - -float MacOpenGLWindow::getTimeInSeconds() -{ - return 0.f; -} - - -void MacOpenGLWindow::setRenderCallback( b3RenderCallback renderCallback) -{ - m_renderCallback = renderCallback; -} - -void MacOpenGLWindow::setWindowTitle(const char* windowTitle) -{ - [m_internalData->m_window setTitle:[NSString stringWithCString:windowTitle encoding:NSISOLatin1StringEncoding]] ; -} - -void MacOpenGLWindow::createWindow(const b3gWindowConstructionInfo& ci) -{ - if (m_internalData) - closeWindow(); - - int width = ci.m_width; - int height = ci.m_height; - const char* windowTitle = ci.m_title; - - - - NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; - - m_internalData = new MacOpenGLWindowInternalData; - m_internalData->m_width = width; - m_internalData->m_height = height; - - m_internalData->m_pool = [NSAutoreleasePool new]; - m_internalData->m_myApp = [NSApplication sharedApplication]; - //myApp = [MyApp sharedApplication]; - //home(); - - [NSApp setActivationPolicy:NSApplicationActivationPolicyRegular]; - - id menubar = [[NSMenu new] autorelease]; - id appMenuItem = [[NSMenuItem new] autorelease]; - [menubar addItem:appMenuItem]; - [NSApp setMainMenu:menubar]; - - id appMenu = [[NSMenu new] autorelease]; - id appName = [[NSProcessInfo processInfo] processName]; - id quitTitle = [@"Quit " stringByAppendingString:appName]; - id quitMenuItem = [[[NSMenuItem alloc] initWithTitle:quitTitle - action:@selector(terminate:) keyEquivalent:@"q"] autorelease]; - - [appMenu addItem:quitMenuItem]; - [appMenuItem setSubmenu:appMenu]; - - NSMenuItem *fileMenuItem = [[NSMenuItem new] autorelease]; - NSMenu *fileMenu = [[NSMenu alloc] initWithTitle:@"File"]; - [fileMenuItem setSubmenu: fileMenu]; // was setMenu: - - NSMenuItem *newMenu = [[NSMenuItem alloc] initWithTitle:@"New" action:NULL keyEquivalent:@""]; - NSMenuItem *openMenu = [[NSMenuItem alloc] initWithTitle:@"Open" action:NULL keyEquivalent:@""]; - NSMenuItem *saveMenu = [[NSMenuItem alloc] initWithTitle:@"Save" action:NULL keyEquivalent:@""]; - - [fileMenu addItem: newMenu]; - [fileMenu addItem: openMenu]; - [fileMenu addItem: saveMenu]; - [menubar addItem: fileMenuItem]; - - - // add Edit menu - NSMenuItem *editMenuItem = [[NSMenuItem new] autorelease]; - NSMenu *menu = [[NSMenu allocWithZone:[NSMenu menuZone]]initWithTitle:@"Edit"]; - [editMenuItem setSubmenu: menu]; - - NSMenuItem *copyItem = [[NSMenuItem allocWithZone:[NSMenu menuZone]]initWithTitle:@"Copy" action:@selector(copy:) keyEquivalent:@"c"]; - - [menu addItem:copyItem]; - [menubar addItem:editMenuItem]; - - // [mainMenu setSubmenu:menu forItem:menuItem]; - - - //NSMenuItem *fileMenuItem = [[NSMenuItem alloc] initWithTitle: @"File"]; - /*[fileMenuItem setSubmenu: fileMenu]; // was setMenu: - [fileMenuItem release]; - */ - - /*NSMenu *newMenu; - NSMenuItem *newItem; - - // Add the submenu - newItem = [[NSMenuItem allocWithZone:[NSMenu menuZone]] - initWithTitle:@"Flashy" action:NULL keyEquivalent:@""]; - newMenu = [[NSMenu allocWithZone:[NSMenu menuZone]] - initWithTitle:@"Flashy"]; - [newItem setSubmenu:newMenu]; - [newMenu release]; - [[NSApp mainMenu] addItem:newItem]; - [newItem release]; - */ - - NSRect frame = NSMakeRect(0., 0., width, height); - - m_internalData->m_window = [NSWindow alloc]; - [m_internalData->m_window initWithContentRect:frame - styleMask:NSTitledWindowMask |NSResizableWindowMask| NSClosableWindowMask | NSMiniaturizableWindowMask - backing:NSBackingStoreBuffered - defer:false]; - - - [m_internalData->m_window setTitle:[NSString stringWithCString:windowTitle encoding:NSISOLatin1StringEncoding]] ; - - m_internalData->m_myview = [TestView alloc]; - - [m_internalData->m_myview setResizeCallback:0]; - ///ci.m_resizeCallback]; - - [m_internalData->m_myview initWithFrame: frame]; - - // OpenGL init! - [m_internalData->m_myview MakeContext : ci.m_openglVersion]; - - // https://developer.apple.com/library/mac/#documentation/GraphicsAnimation/Conceptual/HighResolutionOSX/CapturingScreenContents/CapturingScreenContents.html#//apple_ref/doc/uid/TP40012302-CH10-SW1 - //support HighResolutionOSX for Retina Macbook - if (ci.m_openglVersion>=3) - { - [m_internalData->m_myview setWantsBestResolutionOpenGLSurface:YES]; - } - NSSize sz; - sz.width = 1; - sz.height = 1; - - // float newBackingScaleFactor = [m_internalData->m_window backingScaleFactor]; - - dumpInfo(); - - - - - [m_internalData->m_window setContentView: m_internalData->m_myview]; - - - - [m_internalData->m_window setDelegate:(id) m_internalData->m_myview]; - - [m_internalData->m_window makeKeyAndOrderFront: nil]; - - [m_internalData->m_myview MakeCurrent]; - m_internalData->m_width = m_internalData->m_myview.GetWindowWidth; - m_internalData->m_height = m_internalData->m_myview.GetWindowHeight; - - - [NSApp activateIgnoringOtherApps:YES]; - - -//[m_internalData->m_window setLevel:NSMainMenuWindowLevel]; - -// [NSEvent addGlobalMonitorForEventsMatchingMask:NSMouseMovedMask]; - -// [NSEvent addGlobalMonitorForEventsMatchingMask:NSMouseMovedMask handler:^(NSEvent *event) - // { - //[window setFrameOrigin:[NSEvent mouseLocation]]; - // NSPoint eventLocation = [m_internalData->m_window mouseLocationOutsideOfEventStream]; - - // NSPoint eventLocation = [event locationInWindow]; - //NSPoint center = [m_internalData->m_myview convertPoint:eventLocation fromView:nil]; - // m_mouseX = center.x; - // m_mouseY = [m_internalData->m_myview GetWindowHeight] - center.y; - - - // printf("mouse coord = %f, %f\n",m_mouseX,m_mouseY); - // if (m_mouseMoveCallback) - // (*m_mouseMoveCallback)(m_mouseX,m_mouseY); - - // }]; - - //see http://stackoverflow.com/questions/8238473/cant-get-nsmousemoved-events-from-nexteventmatchingmask-with-an-nsopenglview -/* ProcessSerialNumber psn; - GetCurrentProcess(&psn); - TransformProcessType(&psn, kProcessTransformToForegroundApplication); - SetFrontProcess(&psn); - */ - - m_retinaScaleFactor = [m_internalData->m_myview convertSizeToBacking:sz].width; - - [m_internalData->m_myApp finishLaunching]; - [pool release]; - -} - -void MacOpenGLWindow::runMainLoop() -{ - NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; - // FILE* dump = fopen ("/Users/erwincoumans/yes.txt","wb"); - // fclose(dump); - - - - - [pool release]; - -} - -void MacOpenGLWindow::closeWindow() -{ - - delete m_internalData; - m_internalData = 0; - -} -extern float m_azi; -extern float m_ele; -extern float m_cameraDistance; - - - /* - * Summary: - * Virtual keycodes - * - * Discussion: - * These constants are the virtual keycodes defined originally in - * Inside Mac Volume V, pg. V-191. They identify physical keys on a - * keyboard. Those constants with "ANSI" in the name are labeled - * according to the key position on an ANSI-standard US keyboard. - * For example, kVK_ANSI_A indicates the virtual keycode for the key - * with the letter 'A' in the US keyboard layout. Other keyboard - * layouts may have the 'A' key label on a different physical key; - * in this case, pressing 'A' will generate a different virtual - * keycode. - */ -enum { - kVK_ANSI_A = 0x00, - kVK_ANSI_S = 0x01, - kVK_ANSI_D = 0x02, - kVK_ANSI_F = 0x03, - kVK_ANSI_H = 0x04, - kVK_ANSI_G = 0x05, - kVK_ANSI_Z = 0x06, - kVK_ANSI_X = 0x07, - kVK_ANSI_C = 0x08, - kVK_ANSI_V = 0x09, - kVK_ANSI_B = 0x0B, - kVK_ANSI_Q = 0x0C, - kVK_ANSI_W = 0x0D, - kVK_ANSI_E = 0x0E, - kVK_ANSI_R = 0x0F, - kVK_ANSI_Y = 0x10, - kVK_ANSI_T = 0x11, - kVK_ANSI_1 = 0x12, - kVK_ANSI_2 = 0x13, - kVK_ANSI_3 = 0x14, - kVK_ANSI_4 = 0x15, - kVK_ANSI_6 = 0x16, - kVK_ANSI_5 = 0x17, - kVK_ANSI_Equal = 0x18, - kVK_ANSI_9 = 0x19, - kVK_ANSI_7 = 0x1A, - kVK_ANSI_Minus = 0x1B, - kVK_ANSI_8 = 0x1C, - kVK_ANSI_0 = 0x1D, - kVK_ANSI_RightBracket = 0x1E, - kVK_ANSI_O = 0x1F, - kVK_ANSI_U = 0x20, - kVK_ANSI_LeftBracket = 0x21, - kVK_ANSI_I = 0x22, - kVK_ANSI_P = 0x23, - kVK_ANSI_L = 0x25, - kVK_ANSI_J = 0x26, - kVK_ANSI_Quote = 0x27, - kVK_ANSI_K = 0x28, - kVK_ANSI_Semicolon = 0x29, - kVK_ANSI_Backslash = 0x2A, - kVK_ANSI_Comma = 0x2B, - kVK_ANSI_Slash = 0x2C, - kVK_ANSI_N = 0x2D, - kVK_ANSI_M = 0x2E, - kVK_ANSI_Period = 0x2F, - kVK_ANSI_Grave = 0x32, - kVK_ANSI_KeypadDecimal = 0x41, - kVK_ANSI_KeypadMultiply = 0x43, - kVK_ANSI_KeypadPlus = 0x45, - kVK_ANSI_KeypadClear = 0x47, - kVK_ANSI_KeypadDivide = 0x4B, - kVK_ANSI_KeypadEnter = 0x4C, - kVK_ANSI_KeypadMinus = 0x4E, - kVK_ANSI_KeypadEquals = 0x51, - kVK_ANSI_Keypad0 = 0x52, - kVK_ANSI_Keypad1 = 0x53, - kVK_ANSI_Keypad2 = 0x54, - kVK_ANSI_Keypad3 = 0x55, - kVK_ANSI_Keypad4 = 0x56, - kVK_ANSI_Keypad5 = 0x57, - kVK_ANSI_Keypad6 = 0x58, - kVK_ANSI_Keypad7 = 0x59, - kVK_ANSI_Keypad8 = 0x5B, - kVK_ANSI_Keypad9 = 0x5C -}; - -/* keycodes for keys that are independent of keyboard layout*/ -enum { - kVK_Return = 0x24, - kVK_Tab = 0x30, - kVK_Space = 0x31, - kVK_Delete = 0x33, - kVK_Escape = 0x35, - kVK_Command = 0x37, - kVK_Shift = 0x38, - kVK_CapsLock = 0x39, - kVK_Option = 0x3A, - kVK_Control = 0x3B, - kVK_RightShift = 0x3C, - kVK_RightOption = 0x3D, - kVK_RightControl = 0x3E, - kVK_Function = 0x3F, - kVK_F17 = 0x40, - kVK_VolumeUp = 0x48, - kVK_VolumeDown = 0x49, - kVK_Mute = 0x4A, - kVK_F18 = 0x4F, - kVK_F19 = 0x50, - kVK_F20 = 0x5A, - kVK_F5 = 0x60, - kVK_F6 = 0x61, - kVK_F7 = 0x62, - kVK_F3 = 0x63, - kVK_F8 = 0x64, - kVK_F9 = 0x65, - kVK_F11 = 0x67, - kVK_F13 = 0x69, - kVK_F16 = 0x6A, - kVK_F14 = 0x6B, - kVK_F10 = 0x6D, - kVK_F12 = 0x6F, - kVK_F15 = 0x71, - kVK_Help = 0x72, - kVK_Home = 0x73, - kVK_PageUp = 0x74, - kVK_ForwardDelete = 0x75, - kVK_F4 = 0x76, - kVK_End = 0x77, - kVK_F2 = 0x78, - kVK_PageDown = 0x79, - kVK_F1 = 0x7A, - kVK_LeftArrow = 0x7B, - kVK_RightArrow = 0x7C, - kVK_DownArrow = 0x7D, - kVK_UpArrow = 0x7E -}; - -/* ISO keyboards only*/ -enum { - kVK_ISO_Section = 0x0A -}; - -/* JIS keyboards only*/ -enum { - kVK_JIS_Yen = 0x5D, - kVK_JIS_Underscore = 0x5E, - kVK_JIS_KeypadComma = 0x5F, - kVK_JIS_Eisu = 0x66, - kVK_JIS_Kana = 0x68 -}; - -int getAsciiCodeFromVirtualKeycode(int virtualKeyCode) -{ - int keycode = 0xffffffff; - - switch (virtualKeyCode) - { - - case kVK_ANSI_A : {keycode = 'a'; break;} - case kVK_ANSI_B : {keycode = 'b'; break;} - case kVK_ANSI_C : {keycode = 'c'; break;} - case kVK_ANSI_D : {keycode = 'd';break;} - case kVK_ANSI_E : {keycode = 'e'; break;} - case kVK_ANSI_F : {keycode = 'f'; break;} - case kVK_ANSI_G : {keycode = 'g'; break;} - case kVK_ANSI_H : {keycode = 'h'; break;} - case kVK_ANSI_I : {keycode = 'i'; break;} - case kVK_ANSI_J : {keycode = 'j'; break;} - case kVK_ANSI_K : {keycode = 'k'; break;} - case kVK_ANSI_L : {keycode = 'l'; break;} - case kVK_ANSI_M : {keycode = 'm'; break;} - case kVK_ANSI_N : {keycode = 'n'; break;} - case kVK_ANSI_O : {keycode = 'o'; break;} - case kVK_ANSI_P : {keycode = 'p'; break;} - case kVK_ANSI_Q : {keycode = 'q'; break;} - case kVK_ANSI_R : {keycode = 'r'; break;} - case kVK_ANSI_S : {keycode = 's';break;} - case kVK_ANSI_T : {keycode = 't'; break;} - case kVK_ANSI_U : {keycode = 'u'; break;} - case kVK_ANSI_V : {keycode = 'v'; break;} - case kVK_ANSI_W : {keycode = 'w'; break;} - case kVK_ANSI_X : {keycode = 'x'; break;} - case kVK_ANSI_Y : {keycode = 'y'; break;} - case kVK_ANSI_Z : {keycode = 'z'; break;} - - case kVK_ANSI_1 : {keycode = '1'; break;} - case kVK_ANSI_2 : {keycode = '2'; break;} - case kVK_ANSI_3 : {keycode = '3'; break;} - case kVK_ANSI_4 : {keycode = '4'; break;} - case kVK_ANSI_5 : {keycode = '5'; break;} - case kVK_ANSI_6 : {keycode = '6'; break;} - case kVK_ANSI_7 : {keycode = '7'; break;} - case kVK_ANSI_8 : {keycode = '8'; break;} - case kVK_ANSI_9 : {keycode = '9'; break;} - case kVK_ANSI_0 : {keycode = '0'; break;} - case kVK_ANSI_Equal : {keycode = '='; break;} - case kVK_ANSI_Minus : {keycode = '-'; break;} - - case kVK_Tab: {keycode = 9; break;} - case kVK_Space: {keycode=' '; break;} - case kVK_Escape: {keycode=27; break;} - case kVK_Delete: {keycode=8; break;} - case kVK_ForwardDelete: {keycode=B3G_INSERT; break;} - - - case kVK_F1: {keycode = B3G_F1; break;} - case kVK_F2: {keycode = B3G_F2; break;} - case kVK_F3: {keycode = B3G_F3; break;} - case kVK_F4: {keycode = B3G_F4; break;} - case kVK_F5: {keycode = B3G_F5; break;} - case kVK_F6: {keycode = B3G_F6; break;} - case kVK_F7: {keycode = B3G_F7; break;} - case kVK_F8: {keycode = B3G_F8; break;} - case kVK_F9: {keycode = B3G_F9; break;} - case kVK_F10: {keycode = B3G_F10; break;} - case kVK_F11: {keycode = B3G_F11; break;} - case kVK_F12: {keycode = B3G_F12; break;} - case kVK_F13: {keycode = B3G_F13; break;} - case kVK_F14: {keycode = B3G_F14; break;} - case kVK_F15: {keycode = B3G_F15; break;} - - case kVK_LeftArrow: {keycode = B3G_LEFT_ARROW;break;} - case kVK_RightArrow: {keycode = B3G_RIGHT_ARROW;break;} - case kVK_UpArrow: {keycode = B3G_UP_ARROW;break;} - case kVK_DownArrow: {keycode = B3G_DOWN_ARROW;break;} - - case kVK_PageUp :{keycode = B3G_PAGE_UP;break;} - case kVK_PageDown :{keycode = B3G_PAGE_DOWN;break;} - case kVK_End :{keycode = B3G_END;break;} - case kVK_Home :{keycode = B3G_HOME;break;} - case kVK_Control: {keycode = B3G_CONTROL;break;} - case kVK_Option: {keycode = B3G_ALT;break;} - - case kVK_ANSI_RightBracket : {keycode = ']'; break;} - case kVK_ANSI_LeftBracket : {keycode = '['; break;} - case kVK_ANSI_Quote : {keycode = '\''; break;} - case kVK_ANSI_Semicolon : {keycode = ';'; break;} - case kVK_ANSI_Backslash : {keycode = '\\'; break;} - case kVK_ANSI_Comma : {keycode = ','; break;} - case kVK_ANSI_Slash : {keycode = '/'; break;} - case kVK_ANSI_Period : {keycode = '.'; break;} - case kVK_ANSI_Grave : {keycode = '`'; break;} - case kVK_ANSI_KeypadDecimal : {keycode = '.'; break;} - case kVK_ANSI_KeypadMultiply : {keycode = '*'; break;} - case kVK_ANSI_KeypadPlus : {keycode = '+'; break;} - case kVK_ANSI_KeypadClear : {keycode = '?'; break;} - case kVK_ANSI_KeypadDivide : {keycode = '/'; break;} - case kVK_ANSI_KeypadEnter : {keycode = B3G_RETURN; break;} - case kVK_ANSI_KeypadMinus : {keycode = '-'; break;} - case kVK_ANSI_KeypadEquals : {keycode = '='; break;} - case kVK_ANSI_Keypad0 : {keycode = '0'; break;} - case kVK_ANSI_Keypad1 : {keycode = '1'; break;} - case kVK_ANSI_Keypad2 : {keycode = '2'; break;} - case kVK_ANSI_Keypad3 : {keycode = '3'; break;} - case kVK_ANSI_Keypad4 : {keycode = '4'; break;} - case kVK_ANSI_Keypad5 : {keycode = '5'; break;} - case kVK_ANSI_Keypad6 : {keycode = '6'; break;} - case kVK_ANSI_Keypad7 : {keycode = '7'; break;} - case kVK_ANSI_Keypad8 : {keycode = '8'; break;} - case kVK_ANSI_Keypad9 : {keycode = '9'; break;} - case kVK_Return: - { - keycode = B3G_RETURN; break; - } - - default: - { - - printf("unknown keycode\n"); - } - } - return keycode; -} - - -void MacOpenGLWindow::startRendering() -{ - NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; - - - GLint err = glGetError(); - assert(err==GL_NO_ERROR); - - - NSEvent *event = nil; - bool handledEvent = false; - - do - { - [pool release]; - pool = [[NSAutoreleasePool alloc] init]; - event = [m_internalData->m_myApp - nextEventMatchingMask:NSAnyEventMask - untilDate:[NSDate distantPast] - inMode:NSDefaultRunLoopMode - // inMode:NSEventTrackingRunLoopMode - dequeue:YES]; - - //NSShiftKeyMask = 1 << 17, - //NSControlKeyMask - - - if ([event type] == NSFlagsChanged) - { - int modifiers = [event modifierFlags]; - if (m_keyboardCallback) - { - if ((modifiers & NSShiftKeyMask)) - { - m_keyboardCallback(B3G_SHIFT,1); - }else - { - if (m_modifierFlags&NSShiftKeyMask) - { - m_keyboardCallback(B3G_SHIFT,0); - } - } - if (modifiers & NSControlKeyMask) - { - m_keyboardCallback(B3G_CONTROL,1); - } else - { - if (m_modifierFlags&NSControlKeyMask) - { - m_keyboardCallback(B3G_CONTROL,0); - } - } - if (modifiers & NSAlternateKeyMask) - { - m_keyboardCallback(B3G_ALT,1); - } else - { - if (m_modifierFlags&NSAlternateKeyMask) - { - m_keyboardCallback(B3G_ALT,0); - } - } - //handle NSCommandKeyMask - - } - m_modifierFlags=modifiers; - } - if ([event type] == NSKeyUp) - { - handledEvent = true; - - uint32 virtualKeycode = [event keyCode]; - - int keycode = getAsciiCodeFromVirtualKeycode(virtualKeycode); - printf("keycode = %d\n", keycode); - - if (m_keyboardCallback) - { - int state = 0; - m_keyboardCallback(keycode,state); - } - } - if ([event type] == NSKeyDown) - { - handledEvent = true; - - if (![event isARepeat]) - { - uint32 virtualKeycode = [event keyCode]; - - int keycode = getAsciiCodeFromVirtualKeycode(virtualKeycode); - printf("keycode = %d\n", keycode); - - if (m_keyboardCallback) - { - int state = 1; - m_keyboardCallback(keycode,state); - } - } - } - - - if (([event type]== NSRightMouseDown) || ([ event type]==NSLeftMouseDown)||([event type]==NSOtherMouseDown)) - { - // printf("right mouse!"); - // float mouseX,mouseY; - - NSPoint eventLocation = [event locationInWindow]; - NSPoint center = [m_internalData->m_myview convertPoint:eventLocation fromView:nil]; - m_mouseX = center.x; - m_mouseY = [m_internalData->m_myview GetWindowHeight] - center.y; - int button=0; - switch ([event type]) - { - case NSLeftMouseDown: - { - button=0; - break; - } - case NSOtherMouseDown: - { - button=1; - break; - } - case NSRightMouseDown: - { - button=2; - break; - } - default: - { - - } - }; - // printf("mouse coord = %f, %f\n",mouseX,mouseY); - if (m_mouseButtonCallback) - { - //handledEvent = true; - (*m_mouseButtonCallback)(button,1,m_mouseX,m_mouseY); - } - } - - - if (([event type]== NSRightMouseUp) || ([ event type]==NSLeftMouseUp)||([event type]==NSOtherMouseUp)) - { - // printf("right mouse!"); - // float mouseX,mouseY; - - NSPoint eventLocation = [event locationInWindow]; - NSPoint center = [m_internalData->m_myview convertPoint:eventLocation fromView:nil]; - m_mouseX = center.x; - m_mouseY = [m_internalData->m_myview GetWindowHeight] - center.y; - - int button=0; - switch ([event type]) - { - case NSLeftMouseUp: - { - button=0; - break; - } - case NSOtherMouseUp: - { - button=1; - break; - } - case NSRightMouseUp: - { - button=2; - break; - } - default: - { - - } - }; - - // printf("mouse coord = %f, %f\n",mouseX,mouseY); - if (m_mouseButtonCallback) - (*m_mouseButtonCallback)(button,0,m_mouseX,m_mouseY); - - } - - - if ([event type] == NSMouseMoved) - { - - NSPoint eventLocation = [event locationInWindow]; - NSPoint center = [m_internalData->m_myview convertPoint:eventLocation fromView:nil]; - m_mouseX = center.x; - m_mouseY = [m_internalData->m_myview GetWindowHeight] - center.y; - - - // printf("mouse coord = %f, %f\n",m_mouseX,m_mouseY); - if (m_mouseMoveCallback) - { - //handledEvent = true; - (*m_mouseMoveCallback)(m_mouseX,m_mouseY); - } - } - - if (([event type] == NSLeftMouseDragged) || ([event type] == NSRightMouseDragged) || ([event type] == NSOtherMouseDragged)) - { - int dx1, dy1; - CGGetLastMouseDelta (&dx1, &dy1); - - NSPoint eventLocation = [event locationInWindow]; - NSPoint center = [m_internalData->m_myview convertPoint:eventLocation fromView:nil]; - m_mouseX = center.x; - m_mouseY = [m_internalData->m_myview GetWindowHeight] - center.y; - - if (m_mouseMoveCallback) - { - //handledEvent = true; - (*m_mouseMoveCallback)(m_mouseX,m_mouseY); - } - - // printf("mouse coord = %f, %f\n",m_mouseX,m_mouseY); - } - - if ([event type] == NSScrollWheel) - { - float dy, dx; - dy = [ event deltaY ]; - dx = [ event deltaX ]; - - if (m_wheelCallback) - { - handledEvent = true; - (*m_wheelCallback)(dx,dy); - } - // m_cameraDistance -= dy*0.1; - // m_azi -= dx*0.1; - - } - - if (!handledEvent) - [m_internalData->m_myApp sendEvent:event]; - - [m_internalData->m_myApp updateWindows]; - } while (event); - - err = glGetError(); - assert(err==GL_NO_ERROR); - - [m_internalData->m_myview MakeCurrent]; - err = glGetError(); - assert(err==GL_NO_ERROR); - - - // glClearColor(1,1,1,1); - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); //clear buffers - - err = glGetError(); - assert(err==GL_NO_ERROR); - - //glCullFace(GL_BACK); - //glFrontFace(GL_CCW); - glEnable(GL_DEPTH_TEST); - err = glGetError(); - assert(err==GL_NO_ERROR); - - float aspect; - //b3Vector3 extents; - - if (m_internalData->m_width > m_internalData->m_height) - { - aspect = (float)m_internalData->m_width / (float)m_internalData->m_height; - //extents.setValue(aspect * 1.0f, 1.0f,0); - } else - { - aspect = (float)m_internalData->m_height / (float)m_internalData->m_width; - //extents.setValue(1.0f, aspect*1.f,0); - } - - err = glGetError(); - assert(err==GL_NO_ERROR); - [pool release]; - -} - -void MacOpenGLWindow::endRendering() -{ - [m_internalData->m_myview MakeCurrent]; - glSwapAPPLE(); -} - -bool MacOpenGLWindow::requestedExit() const -{ - return m_internalData->m_exitRequested; -} - -void MacOpenGLWindow::setRequestExit() -{ - m_internalData->m_exitRequested = true; -} - -#include -int MacOpenGLWindow::fileOpenDialog(char* filename, int maxNameLength) -{ - //save/restore the OpenGL context, NSOpenPanel can mess it up - //http://stackoverflow.com/questions/13987148/nsopenpanel-breaks-my-sdl-opengl-app - - NSOpenGLContext *foo = [NSOpenGLContext currentContext]; - // get the url of a .txt file - NSOpenPanel * zOpenPanel = [NSOpenPanel openPanel]; - NSArray * zAryOfExtensions = [NSArray arrayWithObject:@"urdf"]; - [zOpenPanel setAllowedFileTypes:zAryOfExtensions]; - NSInteger zIntResult = [zOpenPanel runModal]; - - [foo makeCurrentContext]; - - if (zIntResult == NSFileHandlingPanelCancelButton) { - NSLog(@"readUsingOpenPanel cancelled"); - return 0; - } - NSURL *zUrl = [zOpenPanel URL]; - if (zUrl) - { - //without the file:// - NSString *myString = [zUrl absoluteString]; - int slen = [myString length]; - if (slen < maxNameLength) - { - const char *cfilename=[myString UTF8String]; - //expect file:// at start of URL - const char* p = strstr(cfilename, "file://"); - if (p==cfilename) - { - int actualLen = strlen(cfilename)-7; - memcpy(filename, cfilename+7,actualLen); - filename[actualLen]=0; - return actualLen; - } - } - } - - return 0; -} - - - -void MacOpenGLWindow::getMouseCoordinates(int& x, int& y) -{ - - NSPoint pt = [m_internalData->m_window mouseLocationOutsideOfEventStream]; - m_mouseX = pt.x; - m_mouseY = pt.y; - - x = m_mouseX; - //our convention is x,y is upper left hand side - y = [m_internalData->m_myview GetWindowHeight]-m_mouseY; - - -} - -void MacOpenGLWindow::setResizeCallback(b3ResizeCallback resizeCallback) -{ - [m_internalData->m_myview setResizeCallback:resizeCallback]; - if (resizeCallback) - { - (resizeCallback)(m_internalData->m_width,m_internalData->m_height); - } -} - -b3ResizeCallback MacOpenGLWindow::getResizeCallback() -{ - return [m_internalData->m_myview getResizeCallback]; -} diff --git a/btgui/OpenGLWindow/OpenGL2Include.h b/btgui/OpenGLWindow/OpenGL2Include.h deleted file mode 100644 index 25d48ad33..000000000 --- a/btgui/OpenGLWindow/OpenGL2Include.h +++ /dev/null @@ -1,55 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -#ifndef __OPENGL_INCLUDE_H -#define __OPENGL_INCLUDE_H - - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -#include -#else - -#include "GlewWindows/GL/glew.h" - -#ifdef _WINDOWS -#include -//#include -//#include -#else -//#include -//#include -#endif //_WINDOWS -#endif //APPLE - -//disable glGetError -//#undef glGetError -//#define glGetError MyGetError -// -//GLenum inline MyGetError() -//{ -// return 0; -//} - -///on Linux only glDrawElementsInstancedARB is defined?!? -//#ifdef __linux -//#define glDrawElementsInstanced glDrawElementsInstancedARB -// -//#endif //__linux - -#endif //__OPENGL_INCLUDE_H - diff --git a/btgui/OpenGLWindow/OpenGLInclude.h b/btgui/OpenGLWindow/OpenGLInclude.h deleted file mode 100644 index 6b4f3df11..000000000 --- a/btgui/OpenGLWindow/OpenGLInclude.h +++ /dev/null @@ -1,62 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -#ifndef __OPENGL_INCLUDE_H -#define __OPENGL_INCLUDE_H - - -//think different -#if defined(__APPLE__) && !defined (VMDMESA) -#include -//#include -//#include -//#import -#ifdef USE_OPENGL2 -#include -#else -#include -#endif -#else - -#include "GlewWindows/GL/glew.h" - -#ifdef _WINDOWS -#include -//#include -//#include -#else -//#include -//#include -#endif //_WINDOWS -#endif //APPLE - -//disable glGetError -//#undef glGetError -//#define glGetError MyGetError -// -//GLenum inline MyGetError() -//{ -// return 0; -//} - -///on Linux only glDrawElementsInstancedARB is defined?!? -//#ifdef __linux -//#define glDrawElementsInstanced glDrawElementsInstancedARB -// -//#endif //__linux - -#endif //__OPENGL_INCLUDE_H - diff --git a/btgui/OpenGLWindow/OpenSans.cpp b/btgui/OpenGLWindow/OpenSans.cpp deleted file mode 100644 index a0f685f6d..000000000 --- a/btgui/OpenGLWindow/OpenSans.cpp +++ /dev/null @@ -1,21738 +0,0 @@ -char OpenSansData[]={char(0),char(1),char(0),char(0),char(0),char(19),char(1),char(0),char(0),char(4), -char(0),char(48),char(68),char(83),char(73),char(71),char(158),char(18),char(68),char(29), -char(0),char(3),char(59),char(156),char(0),char(0),char(21),char(116),char(71),char(68), -char(69),char(70),char(0),char(38),char(3),char(175),char(0),char(3),char(55),char(124), -char(0),char(0),char(0),char(30),char(71),char(80),char(79),char(83),char(11),char(55), -char(15),char(55),char(0),char(3),char(55),char(156),char(0),char(0),char(0),char(56), -char(71),char(83),char(85),char(66),char(14),char(43),char(61),char(183),char(0),char(3), -char(55),char(212),char(0),char(0),char(3),char(198),char(79),char(83),char(47),char(50), -char(161),char(62),char(158),char(201),char(0),char(0),char(1),char(184),char(0),char(0), -char(0),char(96),char(99),char(109),char(97),char(112),char(41),char(171),char(47),char(104), -char(0),char(0),char(16),char(180),char(0),char(0),char(4),char(26),char(99),char(118), -char(116),char(32),char(15),char(77),char(24),char(164),char(0),char(0),char(29),char(144), -char(0),char(0),char(0),char(162),char(102),char(112),char(103),char(109),char(126),char(97), -char(182),char(17),char(0),char(0),char(20),char(208),char(0),char(0),char(7),char(180), -char(103),char(97),char(115),char(112),char(0),char(21),char(0),char(35),char(0),char(3), -char(55),char(108),char(0),char(0),char(0),char(16),char(103),char(108),char(121),char(102), -char(116),char(56),char(153),char(75),char(0),char(0),char(37),char(140),char(0),char(1), -char(47),char(180),char(104),char(101),char(97),char(100),char(247),char(118),char(226),char(166), -char(0),char(0),char(1),char(60),char(0),char(0),char(0),char(54),char(104),char(104), -char(101),char(97),char(13),char(204),char(9),char(115),char(0),char(0),char(1),char(116), -char(0),char(0),char(0),char(36),char(104),char(109),char(116),char(120),char(232),char(53), -char(60),char(221),char(0),char(0),char(2),char(24),char(0),char(0),char(14),char(154), -char(107),char(101),char(114),char(110),char(84),char(43),char(9),char(126),char(0),char(1), -char(85),char(64),char(0),char(1),char(182),char(54),char(108),char(111),char(99),char(97), -char(41),char(20),char(220),char(241),char(0),char(0),char(30),char(52),char(0),char(0), -char(7),char(86),char(109),char(97),char(120),char(112),char(5),char(67),char(2),char(10), -char(0),char(0),char(1),char(152),char(0),char(0),char(0),char(32),char(110),char(97), -char(109),char(101),char(115),char(176),char(136),char(133),char(0),char(3),char(11),char(120), -char(0),char(0),char(5),char(199),char(112),char(111),char(115),char(116),char(2),char(67), -char(239),char(108),char(0),char(3),char(17),char(64),char(0),char(0),char(38),char(43), -char(112),char(114),char(101),char(112),char(67),char(183),char(150),char(164),char(0),char(0), -char(28),char(132),char(0),char(0),char(1),char(9),char(0),char(1),char(0),char(0), -char(0),char(1),char(25),char(154),char(33),char(199),char(245),char(95),char(95),char(15), -char(60),char(245),char(0),char(9),char(8),char(0),char(0),char(0),char(0),char(0), -char(201),char(53),char(49),char(139),char(0),char(0),char(0),char(0),char(201),char(232), -char(76),char(76),char(251),char(154),char(253),char(213),char(9),char(162),char(8),char(98), -char(0),char(0),char(0),char(9),char(0),char(2),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(1),char(0),char(0),char(8),char(141),char(253),char(168), -char(0),char(0),char(9),char(172),char(251),char(154),char(254),char(123),char(9),char(162), -char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(3),char(163),char(0),char(1), -char(0),char(0),char(3),char(170),char(0),char(138),char(0),char(22),char(0),char(86), -char(0),char(5),char(0),char(2),char(0),char(16),char(0),char(47),char(0),char(92), -char(0),char(0),char(1),char(14),char(0),char(248),char(0),char(3),char(0),char(1), -char(0),char(3),char(4),char(182),char(1),char(144),char(0),char(5),char(0),char(8), -char(5),char(154),char(5),char(51),char(0),char(0),char(1),char(31),char(5),char(154), -char(5),char(51),char(0),char(0),char(3),char(209),char(0),char(102),char(1),char(241), -char(8),char(2),char(2),char(11),char(6),char(6),char(3),char(5),char(4),char(2), -char(2),char(4),char(224),char(0),char(2),char(239),char(64),char(0),char(32),char(91), -char(0),char(0),char(0),char(40),char(0),char(0),char(0),char(0),char(49),char(65), -char(83),char(67),char(0),char(64),char(0),char(32),char(255),char(253),char(6),char(31), -char(254),char(20),char(0),char(132),char(8),char(141),char(2),char(88),char(32),char(0), -char(1),char(159),char(0),char(0),char(0),char(0),char(4),char(72),char(5),char(182), -char(0),char(0),char(0),char(32),char(0),char(3),char(4),char(205),char(0),char(193), -char(0),char(0),char(0),char(0),char(4),char(20),char(0),char(0),char(2),char(20), -char(0),char(0),char(2),char(35),char(0),char(152),char(3),char(53),char(0),char(133), -char(5),char(43),char(0),char(51),char(4),char(147),char(0),char(131),char(6),char(150), -char(0),char(104),char(5),char(215),char(0),char(113),char(1),char(197),char(0),char(133), -char(2),char(94),char(0),char(82),char(2),char(94),char(0),char(61),char(4),char(106), -char(0),char(86),char(4),char(147),char(0),char(104),char(1),char(246),char(0),char(63), -char(2),char(147),char(0),char(84),char(2),char(33),char(0),char(152),char(2),char(240), -char(0),char(20),char(4),char(147),char(0),char(102),char(4),char(147),char(0),char(188), -char(4),char(147),char(0),char(100),char(4),char(147),char(0),char(94),char(4),char(147), -char(0),char(43),char(4),char(147),char(0),char(133),char(4),char(147),char(0),char(117), -char(4),char(147),char(0),char(94),char(4),char(147),char(0),char(104),char(4),char(147), -char(0),char(106),char(2),char(33),char(0),char(152),char(2),char(33),char(0),char(63), -char(4),char(147),char(0),char(104),char(4),char(147),char(0),char(119),char(4),char(147), -char(0),char(104),char(3),char(111),char(0),char(27),char(7),char(49),char(0),char(121), -char(5),char(16),char(0),char(0),char(5),char(47),char(0),char(201),char(5),char(12), -char(0),char(125),char(5),char(213),char(0),char(201),char(4),char(115),char(0),char(201), -char(4),char(33),char(0),char(201),char(5),char(211),char(0),char(125),char(5),char(231), -char(0),char(201),char(2),char(170),char(0),char(84),char(2),char(35),char(255),char(96), -char(4),char(233),char(0),char(201),char(4),char(39),char(0),char(201),char(7),char(57), -char(0),char(201),char(6),char(8),char(0),char(201),char(6),char(59),char(0),char(125), -char(4),char(209),char(0),char(201),char(6),char(59),char(0),char(125),char(4),char(242), -char(0),char(201),char(4),char(100),char(0),char(106),char(4),char(109),char(0),char(18), -char(5),char(211),char(0),char(186),char(4),char(195),char(0),char(0),char(7),char(104), -char(0),char(27),char(4),char(158),char(0),char(8),char(4),char(123),char(0),char(0), -char(4),char(145),char(0),char(82),char(2),char(162),char(0),char(166),char(2),char(240), -char(0),char(23),char(2),char(162),char(0),char(51),char(4),char(86),char(0),char(49), -char(3),char(150),char(255),char(252),char(4),char(158),char(1),char(137),char(4),char(115), -char(0),char(94),char(4),char(231),char(0),char(176),char(3),char(207),char(0),char(115), -char(4),char(231),char(0),char(115),char(4),char(125),char(0),char(115),char(2),char(182), -char(0),char(29),char(4),char(98),char(0),char(39),char(4),char(233),char(0),char(176), -char(2),char(6),char(0),char(162),char(2),char(6),char(255),char(145),char(4),char(51), -char(0),char(176),char(2),char(6),char(0),char(176),char(7),char(113),char(0),char(176), -char(4),char(233),char(0),char(176),char(4),char(213),char(0),char(115),char(4),char(231), -char(0),char(176),char(4),char(231),char(0),char(115),char(3),char(68),char(0),char(176), -char(3),char(209),char(0),char(106),char(2),char(211),char(0),char(31),char(4),char(233), -char(0),char(164),char(4),char(2),char(0),char(0),char(6),char(57),char(0),char(23), -char(4),char(49),char(0),char(39),char(4),char(8),char(0),char(2),char(3),char(190), -char(0),char(82),char(3),char(8),char(0),char(61),char(4),char(104),char(1),char(238), -char(3),char(8),char(0),char(72),char(4),char(147),char(0),char(104),char(2),char(20), -char(0),char(0),char(2),char(35),char(0),char(152),char(4),char(147),char(0),char(190), -char(4),char(147),char(0),char(63),char(4),char(147),char(0),char(123),char(4),char(147), -char(0),char(31),char(4),char(104),char(1),char(238),char(4),char(33),char(0),char(123), -char(4),char(158),char(1),char(53),char(6),char(168),char(0),char(100),char(2),char(213), -char(0),char(70),char(3),char(250),char(0),char(82),char(4),char(147),char(0),char(104), -char(2),char(147),char(0),char(84),char(6),char(168),char(0),char(100),char(4),char(0), -char(255),char(250),char(3),char(109),char(0),char(127),char(4),char(147),char(0),char(104), -char(2),char(199),char(0),char(49),char(2),char(199),char(0),char(33),char(4),char(158), -char(1),char(137),char(4),char(244),char(0),char(176),char(5),char(61),char(0),char(113), -char(2),char(33),char(0),char(152),char(1),char(209),char(0),char(37),char(2),char(199), -char(0),char(76),char(3),char(0),char(0),char(66),char(3),char(250),char(0),char(80), -char(6),char(61),char(0),char(75),char(6),char(61),char(0),char(46),char(6),char(61), -char(0),char(26),char(3),char(111),char(0),char(51),char(5),char(16),char(0),char(0), -char(5),char(16),char(0),char(0),char(5),char(16),char(0),char(0),char(5),char(16), -char(0),char(0),char(5),char(16),char(0),char(0),char(5),char(16),char(0),char(0), -char(6),char(252),char(255),char(254),char(5),char(12),char(0),char(125),char(4),char(115), -char(0),char(201),char(4),char(115),char(0),char(201),char(4),char(115),char(0),char(201), -char(4),char(115),char(0),char(201),char(2),char(170),char(0),char(60),char(2),char(170), -char(0),char(84),char(2),char(170),char(255),char(255),char(2),char(170),char(0),char(60), -char(5),char(199),char(0),char(47),char(6),char(8),char(0),char(201),char(6),char(59), -char(0),char(125),char(6),char(59),char(0),char(125),char(6),char(59),char(0),char(125), -char(6),char(59),char(0),char(125),char(6),char(59),char(0),char(125),char(4),char(147), -char(0),char(133),char(6),char(59),char(0),char(125),char(5),char(211),char(0),char(186), -char(5),char(211),char(0),char(186),char(5),char(211),char(0),char(186),char(5),char(211), -char(0),char(186),char(4),char(123),char(0),char(0),char(4),char(227),char(0),char(201), -char(4),char(250),char(0),char(176),char(4),char(115),char(0),char(94),char(4),char(115), -char(0),char(94),char(4),char(115),char(0),char(94),char(4),char(115),char(0),char(94), -char(4),char(115),char(0),char(94),char(4),char(115),char(0),char(94),char(6),char(221), -char(0),char(94),char(3),char(207),char(0),char(115),char(4),char(125),char(0),char(115), -char(4),char(125),char(0),char(115),char(4),char(125),char(0),char(115),char(4),char(125), -char(0),char(115),char(2),char(6),char(255),char(218),char(2),char(6),char(0),char(169), -char(2),char(6),char(255),char(179),char(2),char(6),char(255),char(236),char(4),char(197), -char(0),char(113),char(4),char(233),char(0),char(176),char(4),char(213),char(0),char(115), -char(4),char(213),char(0),char(115),char(4),char(213),char(0),char(115),char(4),char(213), -char(0),char(115),char(4),char(213),char(0),char(115),char(4),char(147),char(0),char(104), -char(4),char(213),char(0),char(115),char(4),char(233),char(0),char(164),char(4),char(233), -char(0),char(164),char(4),char(233),char(0),char(164),char(4),char(233),char(0),char(164), -char(4),char(8),char(0),char(2),char(4),char(231),char(0),char(176),char(4),char(8), -char(0),char(2),char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94), -char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94),char(5),char(16), -char(0),char(0),char(4),char(115),char(0),char(94),char(5),char(12),char(0),char(125), -char(3),char(207),char(0),char(115),char(5),char(12),char(0),char(125),char(3),char(207), -char(0),char(115),char(5),char(12),char(0),char(125),char(3),char(207),char(0),char(115), -char(5),char(12),char(0),char(125),char(3),char(207),char(0),char(115),char(5),char(213), -char(0),char(201),char(4),char(231),char(0),char(115),char(5),char(199),char(0),char(47), -char(4),char(231),char(0),char(115),char(4),char(115),char(0),char(201),char(4),char(125), -char(0),char(115),char(4),char(115),char(0),char(201),char(4),char(125),char(0),char(115), -char(4),char(115),char(0),char(201),char(4),char(125),char(0),char(115),char(4),char(115), -char(0),char(201),char(4),char(125),char(0),char(115),char(4),char(115),char(0),char(201), -char(4),char(125),char(0),char(115),char(5),char(211),char(0),char(125),char(4),char(98), -char(0),char(39),char(5),char(211),char(0),char(125),char(4),char(98),char(0),char(39), -char(5),char(211),char(0),char(125),char(4),char(98),char(0),char(39),char(5),char(211), -char(0),char(125),char(4),char(98),char(0),char(39),char(5),char(231),char(0),char(201), -char(4),char(233),char(0),char(176),char(5),char(231),char(0),char(0),char(4),char(233), -char(0),char(20),char(2),char(170),char(255),char(226),char(2),char(6),char(255),char(144), -char(2),char(170),char(0),char(42),char(2),char(6),char(255),char(218),char(2),char(170), -char(0),char(30),char(2),char(6),char(255),char(204),char(2),char(170),char(0),char(84), -char(2),char(6),char(0),char(53),char(2),char(170),char(0),char(84),char(2),char(6), -char(0),char(176),char(4),char(205),char(0),char(84),char(4),char(12),char(0),char(162), -char(2),char(35),char(255),char(96),char(2),char(6),char(255),char(145),char(4),char(233), -char(0),char(201),char(4),char(51),char(0),char(176),char(4),char(37),char(0),char(176), -char(4),char(39),char(0),char(201),char(2),char(6),char(0),char(163),char(4),char(39), -char(0),char(201),char(2),char(6),char(0),char(89),char(4),char(39),char(0),char(201), -char(2),char(6),char(0),char(176),char(4),char(39),char(0),char(201),char(2),char(131), -char(0),char(176),char(4),char(47),char(0),char(29),char(2),char(23),char(255),char(252), -char(6),char(8),char(0),char(201),char(4),char(233),char(0),char(176),char(6),char(8), -char(0),char(201),char(4),char(233),char(0),char(176),char(6),char(8),char(0),char(201), -char(4),char(233),char(0),char(176),char(5),char(115),char(0),char(1),char(6),char(8), -char(0),char(201),char(4),char(233),char(0),char(176),char(6),char(59),char(0),char(125), -char(4),char(213),char(0),char(115),char(6),char(59),char(0),char(125),char(4),char(213), -char(0),char(115),char(6),char(59),char(0),char(125),char(4),char(213),char(0),char(115), -char(7),char(98),char(0),char(125),char(7),char(137),char(0),char(113),char(4),char(242), -char(0),char(201),char(3),char(68),char(0),char(176),char(4),char(242),char(0),char(201), -char(3),char(68),char(0),char(96),char(4),char(242),char(0),char(201),char(3),char(68), -char(0),char(130),char(4),char(100),char(0),char(106),char(3),char(209),char(0),char(106), -char(4),char(100),char(0),char(106),char(3),char(209),char(0),char(106),char(4),char(100), -char(0),char(106),char(3),char(209),char(0),char(106),char(4),char(100),char(0),char(106), -char(3),char(209),char(0),char(106),char(4),char(109),char(0),char(18),char(2),char(211), -char(0),char(31),char(4),char(109),char(0),char(18),char(2),char(211),char(0),char(31), -char(4),char(109),char(0),char(18),char(2),char(211),char(0),char(31),char(5),char(211), -char(0),char(186),char(4),char(233),char(0),char(164),char(5),char(211),char(0),char(186), -char(4),char(233),char(0),char(164),char(5),char(211),char(0),char(186),char(4),char(233), -char(0),char(164),char(5),char(211),char(0),char(186),char(4),char(233),char(0),char(164), -char(5),char(211),char(0),char(186),char(4),char(233),char(0),char(164),char(5),char(211), -char(0),char(186),char(4),char(233),char(0),char(164),char(7),char(104),char(0),char(27), -char(6),char(57),char(0),char(23),char(4),char(123),char(0),char(0),char(4),char(8), -char(0),char(2),char(4),char(123),char(0),char(0),char(4),char(145),char(0),char(82), -char(3),char(190),char(0),char(82),char(4),char(145),char(0),char(82),char(3),char(190), -char(0),char(82),char(4),char(145),char(0),char(82),char(3),char(190),char(0),char(82), -char(2),char(143),char(0),char(176),char(4),char(158),char(0),char(195),char(5),char(20), -char(0),char(0),char(4),char(115),char(0),char(94),char(6),char(252),char(255),char(254), -char(6),char(221),char(0),char(94),char(6),char(59),char(0),char(125),char(4),char(213), -char(0),char(115),char(4),char(100),char(0),char(106),char(3),char(209),char(0),char(106), -char(4),char(188),char(1),char(12),char(4),char(188),char(1),char(12),char(4),char(178), -char(1),char(45),char(4),char(188),char(1),char(37),char(2),char(6),char(0),char(162), -char(4),char(158),char(1),char(111),char(1),char(147),char(0),char(37),char(4),char(188), -char(1),char(8),char(4),char(158),char(0),char(231),char(4),char(158),char(1),char(252), -char(4),char(158),char(1),char(27),char(5),char(16),char(0),char(0),char(2),char(33), -char(0),char(152),char(4),char(242),char(255),char(212),char(6),char(125),char(255),char(212), -char(3),char(152),char(255),char(228),char(6),char(129),char(255),char(228),char(5),char(133), -char(255),char(212),char(6),char(129),char(255),char(228),char(2),char(182),char(255),char(233), -char(5),char(16),char(0),char(0),char(5),char(47),char(0),char(201),char(4),char(41), -char(0),char(201),char(4),char(147),char(0),char(39),char(4),char(115),char(0),char(201), -char(4),char(145),char(0),char(82),char(5),char(231),char(0),char(201),char(6),char(59), -char(0),char(125),char(2),char(170),char(0),char(84),char(4),char(233),char(0),char(201), -char(4),char(211),char(0),char(0),char(7),char(57),char(0),char(201),char(6),char(8), -char(0),char(201),char(4),char(109),char(0),char(72),char(6),char(59),char(0),char(125), -char(5),char(213),char(0),char(201),char(4),char(209),char(0),char(201),char(4),char(137), -char(0),char(74),char(4),char(109),char(0),char(18),char(4),char(123),char(0),char(0), -char(6),char(98),char(0),char(106),char(4),char(158),char(0),char(8),char(6),char(94), -char(0),char(109),char(6),char(66),char(0),char(80),char(2),char(170),char(0),char(60), -char(4),char(123),char(0),char(0),char(4),char(227),char(0),char(115),char(3),char(205), -char(0),char(90),char(4),char(233),char(0),char(176),char(2),char(182),char(0),char(168), -char(4),char(223),char(0),char(164),char(4),char(227),char(0),char(115),char(5),char(6), -char(0),char(176),char(4),char(25),char(0),char(10),char(4),char(164),char(0),char(113), -char(3),char(205),char(0),char(90),char(3),char(221),char(0),char(115),char(4),char(233), -char(0),char(176),char(4),char(188),char(0),char(115),char(2),char(182),char(0),char(168), -char(4),char(37),char(0),char(176),char(4),char(70),char(255),char(242),char(4),char(244), -char(0),char(176),char(4),char(86),char(0),char(0),char(3),char(205),char(0),char(113), -char(4),char(213),char(0),char(115),char(5),char(51),char(0),char(25),char(4),char(213), -char(0),char(166),char(3),char(219),char(0),char(115),char(4),char(231),char(0),char(115), -char(3),char(201),char(0),char(18),char(4),char(223),char(0),char(164),char(5),char(190), -char(0),char(115),char(4),char(94),char(255),char(236),char(6),char(6),char(0),char(164), -char(6),char(47),char(0),char(115),char(2),char(182),char(0),char(9),char(4),char(223), -char(0),char(164),char(4),char(213),char(0),char(115),char(4),char(223),char(0),char(164), -char(6),char(47),char(0),char(115),char(4),char(115),char(0),char(201),char(5),char(223), -char(0),char(18),char(4),char(41),char(0),char(201),char(5),char(29),char(0),char(125), -char(4),char(100),char(0),char(106),char(2),char(170),char(0),char(84),char(2),char(170), -char(0),char(60),char(2),char(35),char(255),char(96),char(7),char(111),char(0),char(0), -char(7),char(160),char(0),char(201),char(5),char(223),char(0),char(18),char(4),char(229), -char(0),char(201),char(4),char(248),char(0),char(27),char(5),char(213),char(0),char(201), -char(5),char(16),char(0),char(0),char(4),char(231),char(0),char(201),char(5),char(47), -char(0),char(201),char(4),char(41),char(0),char(201),char(5),char(119),char(0),char(14), -char(4),char(115),char(0),char(201),char(6),char(193),char(0),char(2),char(4),char(166), -char(0),char(74),char(6),char(25),char(0),char(203),char(6),char(25),char(0),char(203), -char(4),char(229),char(0),char(201),char(5),char(162),char(0),char(0),char(7),char(57), -char(0),char(201),char(5),char(231),char(0),char(201),char(6),char(59),char(0),char(125), -char(5),char(213),char(0),char(201),char(4),char(209),char(0),char(201),char(5),char(12), -char(0),char(125),char(4),char(109),char(0),char(18),char(4),char(248),char(0),char(27), -char(6),char(98),char(0),char(106),char(4),char(158),char(0),char(8),char(5),char(229), -char(0),char(201),char(5),char(143),char(0),char(170),char(8),char(66),char(0),char(201), -char(8),char(68),char(0),char(201),char(5),char(129),char(0),char(18),char(6),char(211), -char(0),char(201),char(5),char(37),char(0),char(201),char(5),char(10),char(0),char(61), -char(8),char(102),char(0),char(201),char(5),char(23),char(0),char(51),char(4),char(115), -char(0),char(94),char(4),char(197),char(0),char(119),char(4),char(141),char(0),char(176), -char(3),char(109),char(0),char(176),char(4),char(147),char(0),char(41),char(4),char(125), -char(0),char(115),char(5),char(227),char(0),char(4),char(3),char(221),char(0),char(68), -char(5),char(18),char(0),char(176),char(5),char(18),char(0),char(176),char(4),char(39), -char(0),char(176),char(4),char(145),char(0),char(16),char(5),char(225),char(0),char(176), -char(5),char(18),char(0),char(176),char(4),char(213),char(0),char(115),char(4),char(248), -char(0),char(176),char(4),char(231),char(0),char(176),char(3),char(207),char(0),char(115), -char(3),char(188),char(0),char(41),char(4),char(8),char(0),char(2),char(5),char(184), -char(0),char(113),char(4),char(49),char(0),char(39),char(5),char(2),char(0),char(176), -char(4),char(221),char(0),char(156),char(7),char(31),char(0),char(176),char(7),char(45), -char(0),char(176),char(5),char(143),char(0),char(41),char(6),char(41),char(0),char(176), -char(4),char(188),char(0),char(176),char(3),char(240),char(0),char(57),char(6),char(166), -char(0),char(176),char(4),char(113),char(0),char(37),char(4),char(125),char(0),char(115), -char(4),char(233),char(0),char(20),char(3),char(109),char(0),char(176),char(3),char(240), -char(0),char(115),char(3),char(209),char(0),char(106),char(2),char(6),char(0),char(162), -char(2),char(6),char(255),char(236),char(2),char(6),char(255),char(145),char(6),char(178), -char(0),char(16),char(7),char(23),char(0),char(176),char(4),char(233),char(0),char(20), -char(4),char(39),char(0),char(176),char(4),char(8),char(0),char(2),char(4),char(248), -char(0),char(176),char(4),char(55),char(0),char(201),char(3),char(109),char(0),char(176), -char(7),char(104),char(0),char(27),char(6),char(57),char(0),char(23),char(7),char(104), -char(0),char(27),char(6),char(57),char(0),char(23),char(7),char(104),char(0),char(27), -char(6),char(57),char(0),char(23),char(4),char(123),char(0),char(0),char(4),char(8), -char(0),char(2),char(4),char(0),char(0),char(82),char(8),char(0),char(0),char(82), -char(8),char(0),char(0),char(82),char(3),char(74),char(255),char(252),char(1),char(92), -char(0),char(25),char(1),char(92),char(0),char(25),char(1),char(246),char(0),char(63), -char(1),char(92),char(0),char(25),char(2),char(205),char(0),char(25),char(2),char(205), -char(0),char(25),char(3),char(61),char(0),char(25),char(4),char(4),char(0),char(123), -char(4),char(20),char(0),char(123),char(3),char(2),char(0),char(164),char(6),char(70), -char(0),char(152),char(9),char(158),char(0),char(100),char(1),char(197),char(0),char(133), -char(3),char(37),char(0),char(133),char(2),char(111),char(0),char(82),char(2),char(111), -char(0),char(80),char(3),char(227),char(0),char(152),char(1),char(10),char(254),char(121), -char(3),char(39),char(0),char(109),char(4),char(147),char(0),char(98),char(4),char(147), -char(0),char(68),char(6),char(27),char(0),char(154),char(4),char(184),char(0),char(63), -char(6),char(152),char(0),char(141),char(4),char(41),char(0),char(119),char(8),char(39), -char(0),char(201),char(6),char(53),char(0),char(37),char(6),char(66),char(0),char(80), -char(4),char(244),char(0),char(102),char(6),char(61),char(0),char(71),char(6),char(61), -char(0),char(32),char(6),char(61),char(0),char(71),char(6),char(61),char(0),char(106), -char(4),char(166),char(0),char(102),char(4),char(147),char(0),char(39),char(5),char(233), -char(0),char(201),char(5),char(12),char(0),char(76),char(4),char(147),char(0),char(104), -char(4),char(100),char(0),char(37),char(5),char(164),char(0),char(119),char(3),char(18), -char(0),char(12),char(4),char(147),char(0),char(98),char(4),char(147),char(0),char(104), -char(4),char(147),char(0),char(104),char(4),char(147),char(0),char(104),char(4),char(170), -char(0),char(111),char(4),char(188),char(0),char(29),char(4),char(188),char(0),char(29), -char(4),char(158),char(0),char(219),char(2),char(6),char(255),char(145),char(4),char(0), -char(1),char(137),char(4),char(0),char(1),char(113),char(4),char(0),char(1),char(129), -char(2),char(199),char(0),char(39),char(2),char(199),char(0),char(20),char(2),char(199), -char(0),char(59),char(2),char(199),char(0),char(41),char(2),char(199),char(0),char(57), -char(2),char(199),char(0),char(51),char(2),char(199),char(0),char(35),char(4),char(0), -char(0),char(0),char(8),char(0),char(0),char(0),char(4),char(0),char(0),char(0), -char(8),char(0),char(0),char(0),char(2),char(170),char(0),char(0),char(2),char(0), -char(0),char(0),char(1),char(86),char(0),char(0),char(4),char(121),char(0),char(0), -char(2),char(33),char(0),char(0),char(1),char(154),char(0),char(0),char(0),char(205), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(8),char(0),char(0),char(84),char(8),char(0),char(0),char(84),char(2),char(6), -char(255),char(145),char(1),char(92),char(0),char(25),char(4),char(250),char(0),char(10), -char(4),char(133),char(0),char(0),char(6),char(184),char(0),char(18),char(7),char(57), -char(0),char(201),char(7),char(113),char(0),char(176),char(5),char(16),char(0),char(0), -char(4),char(115),char(0),char(94),char(6),char(82),char(254),char(223),char(2),char(170), -char(0),char(117),char(3),char(51),char(0),char(152),char(7),char(117),char(0),char(29), -char(7),char(117),char(0),char(29),char(6),char(61),char(0),char(125),char(4),char(223), -char(0),char(115),char(6),char(37),char(0),char(186),char(5),char(82),char(0),char(164), -char(0),char(0),char(252),char(83),char(0),char(0),char(253),char(13),char(0),char(0), -char(252),char(25),char(0),char(0),char(253),char(8),char(0),char(0),char(253),char(59), -char(4),char(115),char(0),char(201),char(6),char(25),char(0),char(203),char(4),char(125), -char(0),char(115),char(5),char(18),char(0),char(176),char(8),char(23),char(0),char(133), -char(6),char(141),char(0),char(0),char(5),char(102),char(0),char(23),char(5),char(14), -char(0),char(23),char(7),char(90),char(0),char(201),char(5),char(227),char(0),char(176), -char(5),char(109),char(0),char(0),char(4),char(131),char(0),char(10),char(7),char(94), -char(0),char(201),char(6),char(33),char(0),char(176),char(5),char(197),char(0),char(20), -char(5),char(35),char(0),char(12),char(7),char(203),char(0),char(201),char(6),char(197), -char(0),char(176),char(4),char(168),char(0),char(63),char(3),char(221),char(0),char(25), -char(6),char(94),char(0),char(109),char(6),char(6),char(0),char(164),char(6),char(61), -char(0),char(125),char(4),char(213),char(0),char(115),char(5),char(2),char(0),char(0), -char(4),char(12),char(0),char(0),char(5),char(2),char(0),char(0),char(4),char(12), -char(0),char(0),char(9),char(172),char(0),char(125),char(8),char(125),char(0),char(115), -char(6),char(141),char(0),char(125),char(5),char(66),char(0),char(115),char(7),char(254), -char(0),char(125),char(6),char(119),char(0),char(115),char(7),char(223),char(0),char(94), -char(6),char(141),char(0),char(0),char(5),char(29),char(0),char(125),char(3),char(231), -char(0),char(115),char(4),char(223),char(0),char(106),char(4),char(117),char(0),char(203), -char(4),char(158),char(0),char(248),char(4),char(158),char(1),char(223),char(4),char(158), -char(1),char(225),char(7),char(233),char(0),char(41),char(7),char(166),char(0),char(41), -char(6),char(41),char(0),char(201),char(5),char(37),char(0),char(176),char(4),char(231), -char(0),char(47),char(4),char(188),char(0),char(20),char(4),char(227),char(0),char(201), -char(4),char(231),char(0),char(176),char(4),char(55),char(0),char(47),char(3),char(109), -char(0),char(18),char(5),char(35),char(0),char(201),char(4),char(51),char(0),char(176), -char(7),char(31),char(0),char(2),char(6),char(61),char(0),char(4),char(4),char(166), -char(0),char(74),char(3),char(221),char(0),char(68),char(5),char(74),char(0),char(201), -char(4),char(92),char(0),char(176),char(4),char(233),char(0),char(201),char(4),char(68), -char(0),char(176),char(4),char(233),char(0),char(47),char(4),char(35),char(0),char(20), -char(5),char(131),char(0),char(16),char(4),char(236),char(0),char(41),char(5),char(248), -char(0),char(201),char(5),char(47),char(0),char(176),char(6),char(129),char(0),char(201), -char(5),char(227),char(0),char(176),char(8),char(137),char(0),char(201),char(6),char(236), -char(0),char(176),char(6),char(59),char(0),char(125),char(5),char(31),char(0),char(115), -char(5),char(12),char(0),char(125),char(3),char(207),char(0),char(115),char(4),char(109), -char(0),char(16),char(3),char(188),char(0),char(41),char(4),char(123),char(0),char(0), -char(4),char(2),char(0),char(0),char(4),char(123),char(0),char(0),char(4),char(2), -char(0),char(0),char(4),char(244),char(0),char(8),char(4),char(86),char(0),char(39), -char(6),char(215),char(0),char(16),char(5),char(188),char(0),char(41),char(5),char(137), -char(0),char(170),char(4),char(223),char(0),char(156),char(5),char(143),char(0),char(170), -char(4),char(205),char(0),char(156),char(5),char(143),char(0),char(201),char(4),char(174), -char(0),char(176),char(6),char(180),char(0),char(61),char(5),char(70),char(0),char(51), -char(6),char(180),char(0),char(61),char(5),char(70),char(0),char(51),char(2),char(170), -char(0),char(84),char(6),char(193),char(0),char(2),char(5),char(227),char(0),char(4), -char(5),char(131),char(0),char(201),char(4),char(100),char(0),char(176),char(5),char(166), -char(0),char(0),char(4),char(147),char(0),char(16),char(5),char(209),char(0),char(201), -char(4),char(238),char(0),char(176),char(5),char(246),char(0),char(201),char(5),char(57), -char(0),char(176),char(5),char(143),char(0),char(170),char(4),char(221),char(0),char(156), -char(7),char(59),char(0),char(201),char(5),char(227),char(0),char(176),char(2),char(170), -char(0),char(84),char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94), -char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94),char(6),char(252), -char(255),char(254),char(6),char(221),char(0),char(94),char(4),char(115),char(0),char(201), -char(4),char(125),char(0),char(115),char(5),char(215),char(0),char(117),char(4),char(121), -char(0),char(102),char(5),char(215),char(0),char(117),char(4),char(121),char(0),char(102), -char(6),char(193),char(0),char(2),char(5),char(227),char(0),char(4),char(4),char(166), -char(0),char(74),char(3),char(221),char(0),char(68),char(4),char(170),char(0),char(74), -char(3),char(233),char(0),char(27),char(6),char(25),char(0),char(203),char(5),char(18), -char(0),char(176),char(6),char(25),char(0),char(203),char(5),char(18),char(0),char(176), -char(6),char(59),char(0),char(125),char(4),char(213),char(0),char(115),char(6),char(61), -char(0),char(125),char(4),char(213),char(0),char(115),char(6),char(61),char(0),char(125), -char(4),char(213),char(0),char(115),char(5),char(10),char(0),char(61),char(3),char(240), -char(0),char(57),char(4),char(248),char(0),char(27),char(4),char(8),char(0),char(2), -char(4),char(248),char(0),char(27),char(4),char(8),char(0),char(2),char(4),char(248), -char(0),char(27),char(4),char(8),char(0),char(2),char(5),char(143),char(0),char(170), -char(4),char(221),char(0),char(156),char(4),char(55),char(0),char(201),char(3),char(109), -char(0),char(176),char(6),char(211),char(0),char(201),char(6),char(41),char(0),char(176), -char(4),char(55),char(0),char(47),char(3),char(109),char(0),char(18),char(4),char(248), -char(0),char(8),char(4),char(82),char(0),char(39),char(4),char(158),char(0),char(6), -char(4),char(49),char(0),char(39),char(4),char(231),char(0),char(131),char(4),char(231), -char(0),char(115),char(7),char(49),char(0),char(131),char(7),char(43),char(0),char(115), -char(7),char(59),char(0),char(78),char(6),char(106),char(0),char(80),char(5),char(0), -char(0),char(78),char(4),char(47),char(0),char(80),char(7),char(217),char(0),char(0), -char(6),char(207),char(0),char(16),char(8),char(25),char(0),char(201),char(7),char(78), -char(0),char(176),char(6),char(12),char(0),char(125),char(5),char(31),char(0),char(115), -char(5),char(174),char(0),char(16),char(5),char(45),char(0),char(41),char(4),char(170), -char(0),char(111),char(3),char(205),char(0),char(90),char(5),char(154),char(0),char(0), -char(4),char(145),char(0),char(16),char(5),char(16),char(0),char(0),char(4),char(115), -char(0),char(94),char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94), -char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94),char(5),char(16), -char(0),char(0),char(4),char(115),char(0),char(45),char(5),char(16),char(0),char(0), -char(4),char(115),char(0),char(94),char(5),char(16),char(0),char(0),char(4),char(115), -char(0),char(94),char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94), -char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94),char(5),char(16), -char(0),char(0),char(4),char(115),char(0),char(94),char(5),char(16),char(0),char(0), -char(4),char(115),char(0),char(94),char(5),char(16),char(0),char(0),char(4),char(115), -char(0),char(94),char(5),char(16),char(0),char(0),char(4),char(115),char(0),char(94), -char(4),char(115),char(0),char(201),char(4),char(125),char(0),char(115),char(4),char(115), -char(0),char(201),char(4),char(125),char(0),char(115),char(4),char(115),char(0),char(201), -char(4),char(125),char(0),char(115),char(4),char(115),char(0),char(201),char(4),char(125), -char(0),char(115),char(4),char(115),char(0),char(93),char(4),char(125),char(0),char(74), -char(4),char(115),char(0),char(201),char(4),char(125),char(0),char(115),char(4),char(115), -char(0),char(201),char(4),char(125),char(0),char(115),char(4),char(115),char(0),char(201), -char(4),char(125),char(0),char(115),char(2),char(170),char(0),char(84),char(2),char(6), -char(0),char(123),char(2),char(170),char(0),char(84),char(2),char(6),char(0),char(157), -char(6),char(59),char(0),char(125),char(4),char(213),char(0),char(115),char(6),char(59), -char(0),char(125),char(4),char(213),char(0),char(115),char(6),char(59),char(0),char(125), -char(4),char(213),char(0),char(115),char(6),char(59),char(0),char(125),char(4),char(213), -char(0),char(97),char(6),char(59),char(0),char(125),char(4),char(213),char(0),char(115), -char(6),char(59),char(0),char(125),char(4),char(213),char(0),char(115),char(6),char(59), -char(0),char(125),char(4),char(213),char(0),char(115),char(6),char(61),char(0),char(125), -char(4),char(223),char(0),char(115),char(6),char(61),char(0),char(125),char(4),char(223), -char(0),char(115),char(6),char(61),char(0),char(125),char(4),char(223),char(0),char(115), -char(6),char(61),char(0),char(125),char(4),char(223),char(0),char(115),char(6),char(61), -char(0),char(125),char(4),char(223),char(0),char(115),char(5),char(211),char(0),char(186), -char(4),char(233),char(0),char(164),char(5),char(211),char(0),char(186),char(4),char(233), -char(0),char(164),char(6),char(37),char(0),char(186),char(5),char(82),char(0),char(164), -char(6),char(37),char(0),char(186),char(5),char(82),char(0),char(164),char(6),char(37), -char(0),char(186),char(5),char(82),char(0),char(164),char(6),char(37),char(0),char(186), -char(5),char(82),char(0),char(164),char(6),char(37),char(0),char(186),char(5),char(82), -char(0),char(164),char(4),char(123),char(0),char(0),char(4),char(8),char(0),char(2), -char(4),char(123),char(0),char(0),char(4),char(8),char(0),char(2),char(4),char(123), -char(0),char(0),char(4),char(8),char(0),char(2),char(4),char(231),char(0),char(115), -char(0),char(0),char(251),char(229),char(0),char(0),char(252),char(113),char(0),char(0), -char(251),char(154),char(0),char(0),char(252),char(113),char(0),char(0),char(252),char(104), -char(0),char(0),char(252),char(121),char(0),char(0),char(252),char(121),char(0),char(0), -char(252),char(121),char(0),char(0),char(252),char(104),char(1),char(164),char(0),char(49), -char(1),char(164),char(0),char(25),char(1),char(164),char(0),char(25),char(3),char(45), -char(0),char(52),char(4),char(137),char(0),char(115),char(2),char(244),char(0),char(45), -char(4),char(20),char(0),char(41),char(4),char(147),char(0),char(94),char(4),char(143), -char(0),char(23),char(4),char(147),char(0),char(133),char(4),char(147),char(0),char(117), -char(4),char(147),char(0),char(94),char(4),char(147),char(0),char(104),char(4),char(147), -char(0),char(106),char(5),char(109),char(0),char(29),char(6),char(90),char(0),char(92), -char(4),char(109),char(0),char(18),char(2),char(211),char(0),char(31),char(4),char(231), -char(0),char(113),char(4),char(231),char(0),char(113),char(4),char(231),char(0),char(113), -char(4),char(231),char(0),char(113),char(4),char(231),char(0),char(113),char(2),char(59), -char(0),char(201),char(2),char(59),char(0),char(5),char(2),char(59),char(0),char(179), -char(2),char(59),char(255),char(199),char(2),char(59),char(0),char(5),char(2),char(59), -char(255),char(171),char(2),char(59),char(255),char(243),char(2),char(59),char(255),char(231), -char(2),char(59),char(0),char(86),char(2),char(59),char(0),char(187),char(4),char(94), -char(0),char(201),char(2),char(229),char(255),char(228),char(2),char(59),char(0),char(201), -char(0),char(5),char(0),char(201),char(0),char(5),char(0),char(201),char(0),char(201), -char(0),char(153),char(0),char(184),char(0),char(0),char(0),char(0),char(0),char(1), -char(0),char(3),char(0),char(1),char(0),char(0),char(0),char(12),char(0),char(4), -char(4),char(14),char(0),char(0),char(0),char(176),char(0),char(128),char(0),char(6), -char(0),char(48),char(0),char(72),char(0),char(73),char(0),char(126),char(0),char(203), -char(0),char(207),char(1),char(39),char(1),char(50),char(1),char(97),char(1),char(127), -char(1),char(146),char(1),char(161),char(1),char(176),char(1),char(240),char(1),char(255), -char(2),char(27),char(2),char(55),char(2),char(188),char(2),char(199),char(2),char(201), -char(2),char(221),char(2),char(243),char(3),char(1),char(3),char(3),char(3),char(9), -char(3),char(15),char(3),char(35),char(3),char(138),char(3),char(140),char(3),char(161), -char(3),char(170),char(3),char(206),char(3),char(210),char(3),char(214),char(4),char(13), -char(4),char(79),char(4),char(95),char(4),char(134),char(4),char(145),char(4),char(191), -char(4),char(207),char(5),char(19),char(30),char(1),char(30),char(63),char(30),char(133), -char(30),char(199),char(30),char(202),char(30),char(241),char(30),char(249),char(31),char(77), -char(32),char(11),char(32),char(21),char(32),char(30),char(32),char(34),char(32),char(38), -char(32),char(48),char(32),char(51),char(32),char(58),char(32),char(60),char(32),char(68), -char(32),char(112),char(32),char(121),char(32),char(127),char(32),char(164),char(32),char(167), -char(32),char(172),char(33),char(5),char(33),char(19),char(33),char(22),char(33),char(32), -char(33),char(34),char(33),char(38),char(33),char(46),char(33),char(94),char(34),char(2), -char(34),char(6),char(34),char(15),char(34),char(18),char(34),char(26),char(34),char(30), -char(34),char(43),char(34),char(72),char(34),char(96),char(34),char(101),char(37),char(202), -char(251),char(4),char(254),char(255),char(255),char(253),char(255),char(255),char(0),char(0), -char(0),char(32),char(0),char(73),char(0),char(74),char(0),char(160),char(0),char(204), -char(0),char(208),char(1),char(40),char(1),char(51),char(1),char(98),char(1),char(146), -char(1),char(160),char(1),char(175),char(1),char(240),char(1),char(250),char(2),char(24), -char(2),char(55),char(2),char(188),char(2),char(198),char(2),char(201),char(2),char(216), -char(2),char(243),char(3),char(0),char(3),char(3),char(3),char(9),char(3),char(15), -char(3),char(35),char(3),char(132),char(3),char(140),char(3),char(142),char(3),char(163), -char(3),char(171),char(3),char(209),char(3),char(214),char(4),char(0),char(4),char(14), -char(4),char(80),char(4),char(96),char(4),char(136),char(4),char(146),char(4),char(192), -char(4),char(208),char(30),char(0),char(30),char(62),char(30),char(128),char(30),char(160), -char(30),char(200),char(30),char(203),char(30),char(242),char(31),char(77),char(32),char(0), -char(32),char(19),char(32),char(23),char(32),char(32),char(32),char(38),char(32),char(48), -char(32),char(50),char(32),char(57),char(32),char(60),char(32),char(68),char(32),char(112), -char(32),char(116),char(32),char(127),char(32),char(163),char(32),char(167),char(32),char(171), -char(33),char(5),char(33),char(19),char(33),char(22),char(33),char(32),char(33),char(34), -char(33),char(38),char(33),char(46),char(33),char(91),char(34),char(2),char(34),char(6), -char(34),char(15),char(34),char(17),char(34),char(26),char(34),char(30),char(34),char(43), -char(34),char(72),char(34),char(96),char(34),char(100),char(37),char(202),char(251),char(0), -char(254),char(255),char(255),char(252),char(255),char(255),char(255),char(227),char(0),char(0), -char(255),char(227),char(255),char(194),char(0),char(0),char(255),char(194),char(0),char(0), -char(255),char(194),char(0),char(0),char(255),char(176),char(0),char(191),char(0),char(178), -char(0),char(97),char(255),char(73),char(0),char(0),char(0),char(0),char(255),char(150), -char(254),char(133),char(254),char(132),char(254),char(118),char(255),char(104),char(255),char(99), -char(255),char(98),char(255),char(93),char(0),char(103),char(255),char(68),char(0),char(0), -char(253),char(207),char(0),char(0),char(0),char(0),char(253),char(205),char(254),char(130), -char(254),char(127),char(0),char(0),char(253),char(154),char(0),char(0),char(254),char(12), -char(0),char(0),char(254),char(9),char(0),char(0),char(254),char(9),char(228),char(88), -char(228),char(24),char(227),char(122),char(228),char(125),char(0),char(0),char(228),char(125), -char(0),char(0),char(227),char(13),char(226),char(66),char(225),char(239),char(225),char(238), -char(225),char(237),char(225),char(234),char(225),char(225),char(225),char(224),char(225),char(219), -char(225),char(218),char(225),char(211),char(225),char(203),char(225),char(200),char(225),char(153), -char(225),char(118),char(225),char(116),char(0),char(0),char(225),char(24),char(225),char(11), -char(225),char(9),char(226),char(110),char(224),char(254),char(224),char(251),char(224),char(244), -char(224),char(200),char(224),char(37),char(224),char(34),char(224),char(26),char(224),char(25), -char(224),char(18),char(224),char(15),char(224),char(3),char(223),char(231),char(223),char(208), -char(223),char(205),char(220),char(105),char(0),char(0),char(3),char(79),char(2),char(83), -char(0),char(1),char(0),char(0),char(0),char(174),char(0),char(0),char(0),char(0), -char(0),char(170),char(0),char(0),char(0),char(174),char(0),char(0),char(0),char(192), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(240),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(224),char(0),char(0),char(0),char(234), -char(1),char(16),char(0),char(0),char(0),char(0),char(0),char(0),char(1),char(24), -char(0),char(0),char(1),char(48),char(0),char(0),char(1),char(76),char(0),char(0), -char(1),char(92),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(1),char(112),char(0),char(0),char(1),char(114),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(1),char(96),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(1),char(60),char(0),char(0),char(0),char(0),char(0),char(0),char(3),char(150), -char(3),char(151),char(3),char(152),char(3),char(153),char(3),char(154),char(3),char(155), -char(0),char(235),char(3),char(156),char(0),char(237),char(3),char(157),char(0),char(239), -char(3),char(158),char(0),char(241),char(3),char(159),char(0),char(243),char(3),char(160), -char(3),char(143),char(3),char(144),char(1),char(38),char(1),char(39),char(1),char(40), -char(1),char(41),char(1),char(42),char(1),char(43),char(1),char(44),char(1),char(45), -char(1),char(46),char(1),char(47),char(1),char(48),char(1),char(49),char(1),char(50), -char(1),char(51),char(1),char(52),char(1),char(53),char(1),char(54),char(1),char(55), -char(1),char(56),char(1),char(57),char(1),char(58),char(1),char(59),char(1),char(60), -char(1),char(61),char(1),char(62),char(1),char(63),char(1),char(64),char(1),char(65), -char(1),char(73),char(1),char(74),char(1),char(36),char(1),char(37),char(1),char(84), -char(1),char(85),char(1),char(86),char(1),char(87),char(1),char(88),char(1),char(89), -char(3),char(161),char(1),char(92),char(1),char(93),char(1),char(94),char(1),char(95), -char(1),char(96),char(1),char(97),char(1),char(98),char(1),char(99),char(1),char(100), -char(1),char(101),char(1),char(102),char(3),char(162),char(1),char(104),char(1),char(105), -char(1),char(106),char(1),char(107),char(1),char(108),char(1),char(109),char(1),char(110), -char(1),char(111),char(1),char(112),char(1),char(113),char(1),char(114),char(1),char(115), -char(1),char(116),char(1),char(117),char(1),char(118),char(3),char(163),char(2),char(104), -char(1),char(156),char(1),char(157),char(1),char(158),char(1),char(159),char(1),char(160), -char(3),char(164),char(3),char(165),char(1),char(163),char(1),char(164),char(1),char(165), -char(1),char(166),char(1),char(167),char(2),char(105),char(2),char(106),char(1),char(234), -char(1),char(235),char(1),char(236),char(1),char(237),char(1),char(238),char(1),char(239), -char(1),char(240),char(1),char(241),char(1),char(242),char(1),char(243),char(1),char(244), -char(1),char(245),char(2),char(107),char(1),char(246),char(1),char(247),char(2),char(147), -char(2),char(148),char(2),char(149),char(2),char(150),char(2),char(151),char(2),char(152), -char(2),char(153),char(2),char(154),char(1),char(248),char(1),char(249),char(3),char(166), -char(2),char(202),char(2),char(203),char(2),char(204),char(2),char(205),char(2),char(206), -char(2),char(207),char(2),char(208),char(2),char(209),char(2),char(210),char(2),char(211), -char(2),char(212),char(2),char(213),char(2),char(214),char(2),char(215),char(3),char(167), -char(3),char(168),char(3),char(70),char(3),char(169),char(2),char(0),char(2),char(1), -char(3),char(111),char(3),char(112),char(3),char(113),char(3),char(114),char(3),char(115), -char(3),char(116),char(3),char(117),char(2),char(28),char(3),char(141),char(2),char(52), -char(2),char(53),char(2),char(93),char(2),char(94),char(0),char(0),char(64),char(71), -char(91),char(90),char(89),char(88),char(85),char(84),char(83),char(82),char(81),char(80), -char(79),char(78),char(77),char(76),char(75),char(74),char(73),char(72),char(71),char(70), -char(69),char(68),char(67),char(66),char(65),char(64),char(63),char(62),char(61),char(60), -char(59),char(58),char(57),char(56),char(55),char(54),char(53),char(49),char(48),char(47), -char(46),char(45),char(44),char(40),char(39),char(38),char(37),char(36),char(35),char(34), -char(33),char(31),char(24),char(20),char(17),char(16),char(15),char(14),char(13),char(11), -char(10),char(9),char(8),char(7),char(6),char(5),char(4),char(3),char(2),char(1), -char(0),char(44),char(32),char(176),char(1),char(96),char(69),char(176),char(3),char(37), -char(32),char(17),char(70),char(97),char(35),char(69),char(35),char(97),char(72),char(45), -char(44),char(32),char(69),char(24),char(104),char(68),char(45),char(44),char(69),char(35), -char(70),char(96),char(176),char(32),char(97),char(32),char(176),char(70),char(96),char(176), -char(4),char(38),char(35),char(72),char(72),char(45),char(44),char(69),char(35),char(70), -char(35),char(97),char(176),char(32),char(96),char(32),char(176),char(38),char(97),char(176), -char(32),char(97),char(176),char(4),char(38),char(35),char(72),char(72),char(45),char(44), -char(69),char(35),char(70),char(96),char(176),char(64),char(97),char(32),char(176),char(102), -char(96),char(176),char(4),char(38),char(35),char(72),char(72),char(45),char(44),char(69), -char(35),char(70),char(35),char(97),char(176),char(64),char(96),char(32),char(176),char(38), -char(97),char(176),char(64),char(97),char(176),char(4),char(38),char(35),char(72),char(72), -char(45),char(44),char(1),char(16),char(32),char(60),char(0),char(60),char(45),char(44), -char(32),char(69),char(35),char(32),char(176),char(205),char(68),char(35),char(32),char(184), -char(1),char(90),char(81),char(88),char(35),char(32),char(176),char(141),char(68),char(35), -char(89),char(32),char(176),char(237),char(81),char(88),char(35),char(32),char(176),char(77), -char(68),char(35),char(89),char(32),char(176),char(4),char(38),char(81),char(88),char(35), -char(32),char(176),char(13),char(68),char(35),char(89),char(33),char(33),char(45),char(44), -char(32),char(32),char(69),char(24),char(104),char(68),char(32),char(176),char(1),char(96), -char(32),char(69),char(176),char(70),char(118),char(104),char(138),char(69),char(96),char(68), -char(45),char(44),char(1),char(177),char(11),char(10),char(67),char(35),char(67),char(101), -char(10),char(45),char(44),char(0),char(177),char(10),char(11),char(67),char(35),char(67), -char(11),char(45),char(44),char(0),char(176),char(40),char(35),char(112),char(177),char(1), -char(40),char(62),char(1),char(176),char(40),char(35),char(112),char(177),char(2),char(40), -char(69),char(58),char(177),char(2),char(0),char(8),char(13),char(45),char(44),char(32), -char(69),char(176),char(3),char(37),char(69),char(97),char(100),char(176),char(80),char(81), -char(88),char(69),char(68),char(27),char(33),char(33),char(89),char(45),char(44),char(73), -char(176),char(14),char(35),char(68),char(45),char(44),char(32),char(69),char(176),char(0), -char(67),char(96),char(68),char(45),char(44),char(1),char(176),char(6),char(67),char(176), -char(7),char(67),char(101),char(10),char(45),char(44),char(32),char(105),char(176),char(64), -char(97),char(176),char(0),char(139),char(32),char(177),char(44),char(192),char(138),char(140), -char(184),char(16),char(0),char(98),char(96),char(43),char(12),char(100),char(35),char(100), -char(97),char(92),char(88),char(176),char(3),char(97),char(89),char(45),char(44),char(138), -char(3),char(69),char(138),char(138),char(135),char(176),char(17),char(43),char(176),char(41), -char(35),char(68),char(176),char(41),char(122),char(228),char(24),char(45),char(44),char(69), -char(101),char(176),char(44),char(35),char(68),char(69),char(176),char(43),char(35),char(68), -char(45),char(44),char(75),char(82),char(88),char(69),char(68),char(27),char(33),char(33), -char(89),char(45),char(44),char(75),char(81),char(88),char(69),char(68),char(27),char(33), -char(33),char(89),char(45),char(44),char(1),char(176),char(5),char(37),char(16),char(35), -char(32),char(138),char(245),char(0),char(176),char(1),char(96),char(35),char(237),char(236), -char(45),char(44),char(1),char(176),char(5),char(37),char(16),char(35),char(32),char(138), -char(245),char(0),char(176),char(1),char(97),char(35),char(237),char(236),char(45),char(44), -char(1),char(176),char(6),char(37),char(16),char(245),char(0),char(237),char(236),char(45), -char(44),char(176),char(2),char(67),char(176),char(1),char(82),char(88),char(33),char(33), -char(33),char(33),char(33),char(27),char(70),char(35),char(70),char(96),char(138),char(138), -char(70),char(35),char(32),char(70),char(138),char(96),char(138),char(97),char(184),char(255), -char(128),char(98),char(35),char(32),char(16),char(35),char(138),char(177),char(12),char(12), -char(138),char(112),char(69),char(96),char(32),char(176),char(0),char(80),char(88),char(176), -char(1),char(97),char(184),char(255),char(186),char(139),char(27),char(176),char(70),char(140), -char(89),char(176),char(16),char(96),char(104),char(1),char(58),char(89),char(45),char(44), -char(32),char(69),char(176),char(3),char(37),char(70),char(82),char(75),char(176),char(19), -char(81),char(91),char(88),char(176),char(2),char(37),char(70),char(32),char(104),char(97), -char(176),char(3),char(37),char(176),char(3),char(37),char(63),char(35),char(33),char(56), -char(27),char(33),char(17),char(89),char(45),char(44),char(32),char(69),char(176),char(3), -char(37),char(70),char(80),char(88),char(176),char(2),char(37),char(70),char(32),char(104), -char(97),char(176),char(3),char(37),char(176),char(3),char(37),char(63),char(35),char(33), -char(56),char(27),char(33),char(17),char(89),char(45),char(44),char(0),char(176),char(7), -char(67),char(176),char(6),char(67),char(11),char(45),char(44),char(33),char(33),char(12), -char(100),char(35),char(100),char(139),char(184),char(64),char(0),char(98),char(45),char(44), -char(33),char(176),char(128),char(81),char(88),char(12),char(100),char(35),char(100),char(139), -char(184),char(32),char(0),char(98),char(27),char(178),char(0),char(64),char(47),char(43), -char(89),char(176),char(2),char(96),char(45),char(44),char(33),char(176),char(192),char(81), -char(88),char(12),char(100),char(35),char(100),char(139),char(184),char(21),char(85),char(98), -char(27),char(178),char(0),char(128),char(47),char(43),char(89),char(176),char(2),char(96), -char(45),char(44),char(12),char(100),char(35),char(100),char(139),char(184),char(64),char(0), -char(98),char(96),char(35),char(33),char(45),char(44),char(75),char(83),char(88),char(138), -char(176),char(4),char(37),char(73),char(100),char(35),char(69),char(105),char(176),char(64), -char(139),char(97),char(176),char(128),char(98),char(176),char(32),char(97),char(106),char(176), -char(14),char(35),char(68),char(35),char(16),char(176),char(14),char(246),char(27),char(33), -char(35),char(138),char(18),char(17),char(32),char(57),char(47),char(89),char(45),char(44), -char(75),char(83),char(88),char(32),char(176),char(3),char(37),char(73),char(100),char(105), -char(32),char(176),char(5),char(38),char(176),char(6),char(37),char(73),char(100),char(35), -char(97),char(176),char(128),char(98),char(176),char(32),char(97),char(106),char(176),char(14), -char(35),char(68),char(176),char(4),char(38),char(16),char(176),char(14),char(246),char(138), -char(16),char(176),char(14),char(35),char(68),char(176),char(14),char(246),char(176),char(14), -char(35),char(68),char(176),char(14),char(237),char(27),char(138),char(176),char(4),char(38), -char(17),char(18),char(32),char(57),char(35),char(32),char(57),char(47),char(47),char(89), -char(45),char(44),char(69),char(35),char(69),char(96),char(35),char(69),char(96),char(35), -char(69),char(96),char(35),char(118),char(104),char(24),char(176),char(128),char(98),char(32), -char(45),char(44),char(176),char(72),char(43),char(45),char(44),char(32),char(69),char(176), -char(0),char(84),char(88),char(176),char(64),char(68),char(32),char(69),char(176),char(64), -char(97),char(68),char(27),char(33),char(33),char(89),char(45),char(44),char(69),char(177), -char(48),char(47),char(69),char(35),char(69),char(97),char(96),char(176),char(1),char(96), -char(105),char(68),char(45),char(44),char(75),char(81),char(88),char(176),char(47),char(35), -char(112),char(176),char(20),char(35),char(66),char(27),char(33),char(33),char(89),char(45), -char(44),char(75),char(81),char(88),char(32),char(176),char(3),char(37),char(69),char(105), -char(83),char(88),char(68),char(27),char(33),char(33),char(89),char(27),char(33),char(33), -char(89),char(45),char(44),char(69),char(176),char(20),char(67),char(176),char(0),char(96), -char(99),char(176),char(1),char(96),char(105),char(68),char(45),char(44),char(176),char(47), -char(69),char(68),char(45),char(44),char(69),char(35),char(32),char(69),char(138),char(96), -char(68),char(45),char(44),char(69),char(35),char(69),char(96),char(68),char(45),char(44), -char(75),char(35),char(81),char(88),char(185),char(0),char(51),char(255),char(224),char(177), -char(52),char(32),char(27),char(179),char(51),char(0),char(52),char(0),char(89),char(68), -char(68),char(45),char(44),char(176),char(22),char(67),char(88),char(176),char(3),char(38), -char(69),char(138),char(88),char(100),char(102),char(176),char(31),char(96),char(27),char(100), -char(176),char(32),char(96),char(102),char(32),char(88),char(27),char(33),char(176),char(64), -char(89),char(176),char(1),char(97),char(89),char(35),char(88),char(101),char(89),char(176), -char(41),char(35),char(68),char(35),char(16),char(176),char(41),char(224),char(27),char(33), -char(33),char(33),char(33),char(33),char(89),char(45),char(44),char(176),char(2),char(67), -char(84),char(88),char(75),char(83),char(35),char(75),char(81),char(90),char(88),char(56), -char(27),char(33),char(33),char(89),char(27),char(33),char(33),char(33),char(33),char(89), -char(45),char(44),char(176),char(22),char(67),char(88),char(176),char(4),char(37),char(69), -char(100),char(176),char(32),char(96),char(102),char(32),char(88),char(27),char(33),char(176), -char(64),char(89),char(176),char(1),char(97),char(35),char(88),char(27),char(101),char(89), -char(176),char(41),char(35),char(68),char(176),char(5),char(37),char(176),char(8),char(37), -char(8),char(32),char(88),char(2),char(27),char(3),char(89),char(176),char(4),char(37), -char(16),char(176),char(5),char(37),char(32),char(70),char(176),char(4),char(37),char(35), -char(66),char(60),char(176),char(4),char(37),char(176),char(7),char(37),char(8),char(176), -char(7),char(37),char(16),char(176),char(6),char(37),char(32),char(70),char(176),char(4), -char(37),char(176),char(1),char(96),char(35),char(66),char(60),char(32),char(88),char(1), -char(27),char(0),char(89),char(176),char(4),char(37),char(16),char(176),char(5),char(37), -char(176),char(41),char(224),char(176),char(41),char(32),char(69),char(101),char(68),char(176), -char(7),char(37),char(16),char(176),char(6),char(37),char(176),char(41),char(224),char(176), -char(5),char(37),char(176),char(8),char(37),char(8),char(32),char(88),char(2),char(27), -char(3),char(89),char(176),char(5),char(37),char(176),char(3),char(37),char(67),char(72), -char(176),char(4),char(37),char(176),char(7),char(37),char(8),char(176),char(6),char(37), -char(176),char(3),char(37),char(176),char(1),char(96),char(67),char(72),char(27),char(33), -char(89),char(33),char(33),char(33),char(33),char(33),char(33),char(33),char(45),char(44), -char(2),char(176),char(4),char(37),char(32),char(32),char(70),char(176),char(4),char(37), -char(35),char(66),char(176),char(5),char(37),char(8),char(176),char(3),char(37),char(69), -char(72),char(33),char(33),char(33),char(33),char(45),char(44),char(2),char(176),char(3), -char(37),char(32),char(176),char(4),char(37),char(8),char(176),char(2),char(37),char(67), -char(72),char(33),char(33),char(33),char(45),char(44),char(69),char(35),char(32),char(69), -char(24),char(32),char(176),char(0),char(80),char(32),char(88),char(35),char(101),char(35), -char(89),char(35),char(104),char(32),char(176),char(64),char(80),char(88),char(33),char(176), -char(64),char(89),char(35),char(88),char(101),char(89),char(138),char(96),char(68),char(45), -char(44),char(75),char(83),char(35),char(75),char(81),char(90),char(88),char(32),char(69), -char(138),char(96),char(68),char(27),char(33),char(33),char(89),char(45),char(44),char(75), -char(84),char(88),char(32),char(69),char(138),char(96),char(68),char(27),char(33),char(33), -char(89),char(45),char(44),char(75),char(83),char(35),char(75),char(81),char(90),char(88), -char(56),char(27),char(33),char(33),char(89),char(45),char(44),char(176),char(0),char(33), -char(75),char(84),char(88),char(56),char(27),char(33),char(33),char(89),char(45),char(44), -char(176),char(2),char(67),char(84),char(88),char(176),char(70),char(43),char(27),char(33), -char(33),char(33),char(33),char(89),char(45),char(44),char(176),char(2),char(67),char(84), -char(88),char(176),char(71),char(43),char(27),char(33),char(33),char(33),char(89),char(45), -char(44),char(176),char(2),char(67),char(84),char(88),char(176),char(72),char(43),char(27), -char(33),char(33),char(33),char(33),char(89),char(45),char(44),char(176),char(2),char(67), -char(84),char(88),char(176),char(73),char(43),char(27),char(33),char(33),char(33),char(89), -char(45),char(44),char(32),char(138),char(8),char(35),char(75),char(83),char(138),char(75), -char(81),char(90),char(88),char(35),char(56),char(27),char(33),char(33),char(89),char(45), -char(44),char(0),char(176),char(2),char(37),char(73),char(176),char(0),char(83),char(88), -char(32),char(176),char(64),char(56),char(17),char(27),char(33),char(89),char(45),char(44), -char(1),char(70),char(35),char(70),char(96),char(35),char(70),char(97),char(35),char(32), -char(16),char(32),char(70),char(138),char(97),char(184),char(255),char(128),char(98),char(138), -char(177),char(64),char(64),char(138),char(112),char(69),char(96),char(104),char(58),char(45), -char(44),char(32),char(138),char(35),char(73),char(100),char(138),char(35),char(83),char(88), -char(60),char(27),char(33),char(89),char(45),char(44),char(75),char(82),char(88),char(125), -char(27),char(122),char(89),char(45),char(44),char(176),char(18),char(0),char(75),char(1), -char(75),char(84),char(66),char(45),char(44),char(177),char(2),char(0),char(66),char(177), -char(35),char(1),char(136),char(81),char(177),char(64),char(1),char(136),char(83),char(90), -char(88),char(185),char(16),char(0),char(0),char(32),char(136),char(84),char(88),char(178), -char(2),char(1),char(2),char(67),char(96),char(66),char(89),char(177),char(36),char(1), -char(136),char(81),char(88),char(185),char(32),char(0),char(0),char(64),char(136),char(84), -char(88),char(178),char(2),char(2),char(2),char(67),char(96),char(66),char(177),char(36), -char(1),char(136),char(84),char(88),char(178),char(2),char(32),char(2),char(67),char(96), -char(66),char(0),char(75),char(1),char(75),char(82),char(88),char(178),char(2),char(8), -char(2),char(67),char(96),char(66),char(89),char(27),char(185),char(64),char(0),char(0), -char(128),char(136),char(84),char(88),char(178),char(2),char(4),char(2),char(67),char(96), -char(66),char(89),char(185),char(64),char(0),char(0),char(128),char(99),char(184),char(1), -char(0),char(136),char(84),char(88),char(178),char(2),char(8),char(2),char(67),char(96), -char(66),char(89),char(185),char(64),char(0),char(1),char(0),char(99),char(184),char(2), -char(0),char(136),char(84),char(88),char(178),char(2),char(16),char(2),char(67),char(96), -char(66),char(89),char(177),char(38),char(1),char(136),char(81),char(88),char(185),char(64), -char(0),char(2),char(0),char(99),char(184),char(4),char(0),char(136),char(84),char(88), -char(178),char(2),char(64),char(2),char(67),char(96),char(66),char(89),char(185),char(64), -char(0),char(4),char(0),char(99),char(184),char(8),char(0),char(136),char(84),char(88), -char(178),char(2),char(128),char(2),char(67),char(96),char(66),char(89),char(89),char(89), -char(89),char(89),char(89),char(177),char(0),char(2),char(67),char(84),char(88),char(64), -char(10),char(5),char(64),char(8),char(64),char(9),char(64),char(12),char(2),char(13), -char(2),char(27),char(177),char(1),char(2),char(67),char(84),char(88),char(178),char(5), -char(64),char(8),char(186),char(1),char(0),char(0),char(9),char(1),char(0),char(179), -char(12),char(1),char(13),char(1),char(27),char(177),char(128),char(2),char(67),char(82), -char(88),char(178),char(5),char(64),char(8),char(184),char(1),char(128),char(177),char(9), -char(64),char(27),char(178),char(5),char(64),char(8),char(186),char(1),char(128),char(0), -char(9),char(1),char(64),char(89),char(185),char(64),char(0),char(0),char(128),char(136), -char(85),char(185),char(64),char(0),char(2),char(0),char(99),char(184),char(4),char(0), -char(136),char(85),char(90),char(88),char(179),char(12),char(0),char(13),char(1),char(27), -char(179),char(12),char(0),char(13),char(1),char(89),char(89),char(89),char(66),char(66), -char(66),char(66),char(66),char(45),char(44),char(69),char(24),char(104),char(35),char(75), -char(81),char(88),char(35),char(32),char(69),char(32),char(100),char(176),char(64),char(80), -char(88),char(124),char(89),char(104),char(138),char(96),char(89),char(68),char(45),char(44), -char(176),char(0),char(22),char(176),char(2),char(37),char(176),char(2),char(37),char(1), -char(176),char(1),char(35),char(62),char(0),char(176),char(2),char(35),char(62),char(177), -char(1),char(2),char(6),char(12),char(176),char(10),char(35),char(101),char(66),char(176), -char(11),char(35),char(66),char(1),char(176),char(1),char(35),char(63),char(0),char(176), -char(2),char(35),char(63),char(177),char(1),char(2),char(6),char(12),char(176),char(6), -char(35),char(101),char(66),char(176),char(7),char(35),char(66),char(176),char(1),char(22), -char(1),char(45),char(44),char(176),char(128),char(176),char(2),char(67),char(80),char(176), -char(1),char(176),char(2),char(67),char(84),char(91),char(88),char(33),char(35),char(16), -char(176),char(32),char(26),char(201),char(27),char(138),char(16),char(237),char(89),char(45), -char(44),char(176),char(89),char(43),char(45),char(44),char(138),char(16),char(229),char(45), -char(64),char(153),char(9),char(33),char(72),char(32),char(85),char(32),char(1),char(30), -char(85),char(31),char(72),char(3),char(85),char(31),char(30),char(1),char(15),char(30), -char(63),char(30),char(175),char(30),char(3),char(77),char(75),char(38),char(31),char(76), -char(75),char(51),char(31),char(75),char(70),char(37),char(31),char(38),char(52),char(16), -char(85),char(37),char(51),char(36),char(85),char(25),char(19),char(255),char(31),char(7), -char(4),char(255),char(31),char(6),char(3),char(255),char(31),char(74),char(73),char(51), -char(31),char(73),char(70),char(37),char(31),char(19),char(51),char(18),char(85),char(5), -char(1),char(3),char(85),char(4),char(51),char(3),char(85),char(31),char(3),char(1), -char(15),char(3),char(63),char(3),char(175),char(3),char(3),char(71),char(70),char(25), -char(31),char(235),char(70),char(1),char(35),char(51),char(34),char(85),char(28),char(51), -char(27),char(85),char(22),char(51),char(21),char(85),char(17),char(1),char(15),char(85), -char(16),char(51),char(15),char(85),char(15),char(15),char(79),char(15),char(2),char(31), -char(15),char(207),char(15),char(2),char(15),char(15),char(255),char(15),char(2),char(6), -char(2),char(1),char(0),char(85),char(1),char(51),char(0),char(85),char(111),char(0), -char(127),char(0),char(175),char(0),char(239),char(0),char(4),char(16),char(0),char(1), -char(128),char(22),char(1),char(5),char(1),char(184),char(1),char(144),char(177),char(84), -char(83),char(43),char(43),char(75),char(184),char(7),char(255),char(82),char(75),char(176), -char(9),char(80),char(91),char(176),char(1),char(136),char(176),char(37),char(83),char(176), -char(1),char(136),char(176),char(64),char(81),char(90),char(176),char(6),char(136),char(176), -char(0),char(85),char(90),char(91),char(88),char(177),char(1),char(1),char(142),char(89), -char(133),char(141),char(141),char(0),char(66),char(29),char(75),char(176),char(50),char(83), -char(88),char(176),char(32),char(29),char(89),char(75),char(176),char(100),char(83),char(88), -char(176),char(16),char(29),char(177),char(22),char(0),char(66),char(89),char(115),char(115), -char(43),char(43),char(94),char(115),char(116),char(117),char(43),char(43),char(43),char(43), -char(43),char(116),char(43),char(115),char(116),char(43),char(43),char(43),char(43),char(43), -char(43),char(43),char(43),char(43),char(43),char(43),char(43),char(43),char(115),char(116), -char(43),char(43),char(43),char(24),char(94),char(0),char(0),char(0),char(6),char(20), -char(0),char(23),char(0),char(78),char(5),char(182),char(0),char(23),char(0),char(117), -char(5),char(182),char(5),char(205),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(4),char(72), -char(0),char(20),char(0),char(145),char(0),char(0),char(255),char(236),char(0),char(0), -char(0),char(0),char(255),char(236),char(0),char(0),char(0),char(0),char(255),char(236), -char(0),char(0),char(254),char(20),char(255),char(236),char(0),char(0),char(5),char(182), -char(0),char(19),char(252),char(148),char(255),char(237),char(254),char(133),char(255),char(234), -char(254),char(169),char(255),char(236),char(0),char(24),char(254),char(188),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(8),char(0),char(0),char(0),char(0),char(0),char(0),char(139), -char(0),char(129),char(0),char(221),char(0),char(152),char(0),char(143),char(0),char(142), -char(0),char(153),char(0),char(136),char(0),char(129),char(1),char(15),char(0),char(138), -char(0),char(0),char(0),char(0),char(0),char(31),char(0),char(31),char(0),char(31), -char(0),char(31),char(0),char(81),char(0),char(119),char(0),char(255),char(1),char(123), -char(1),char(236),char(2),char(106),char(2),char(131),char(2),char(174),char(2),char(217), -char(3),char(21),char(3),char(65),char(3),char(95),char(3),char(116),char(3),char(150), -char(3),char(175),char(3),char(241),char(4),char(26),char(4),char(91),char(4),char(185), -char(4),char(251),char(5),char(70),char(5),char(163),char(5),char(197),char(6),char(52), -char(6),char(145),char(6),char(199),char(6),char(251),char(7),char(27),char(7),char(68), -char(7),char(100),char(7),char(187),char(8),char(65),char(8),char(128),char(8),char(219), -char(9),char(25),char(9),char(85),char(9),char(138),char(9),char(184),char(10),char(8), -char(10),char(57),char(10),char(108),char(10),char(148),char(10),char(195),char(10),char(225), -char(11),char(31),char(11),char(86),char(11),char(156),char(11),char(217),char(12),char(44), -char(12),char(121),char(12),char(204),char(12),char(240),char(13),char(36),char(13),char(75), -char(13),char(143),char(13),char(191),char(13),char(230),char(14),char(18),char(14),char(54), -char(14),char(79),char(14),char(114),char(14),char(147),char(14),char(169),char(14),char(200), -char(15),char(36),char(15),char(121),char(15),char(180),char(16),char(7),char(16),char(84), -char(16),char(148),char(17),char(40),char(17),char(102),char(17),char(148),char(17),char(210), -char(18),char(16),char(18),char(39),char(18),char(127),char(18),char(185),char(18),char(250), -char(19),char(79),char(19),char(163),char(19),char(214),char(20),char(40),char(20),char(104), -char(20),char(165),char(20),char(204),char(21),char(23),char(21),char(71),char(21),char(128), -char(21),char(172),char(21),char(238),char(22),char(6),char(22),char(75),char(22),char(133), -char(22),char(133),char(22),char(182),char(23),char(1),char(23),char(83),char(23),char(161), -char(23),char(245),char(24),char(26),char(24),char(149),char(24),char(203),char(25),char(71), -char(25),char(148),char(25),char(207),char(25),char(237),char(25),char(245),char(26),char(127), -char(26),char(149),char(26),char(205),char(26),char(217),char(27),char(19),char(27),char(99), -char(27),char(130),char(27),char(193),char(27),char(241),char(28),char(19),char(28),char(69), -char(28),char(108),char(28),char(165),char(28),char(221),char(28),char(243),char(29),char(8), -char(29),char(30),char(29),char(123),char(29),char(140),char(29),char(157),char(29),char(174), -char(29),char(191),char(29),char(209),char(29),char(221),char(30),char(43),char(30),char(55), -char(30),char(72),char(30),char(89),char(30),char(106),char(30),char(124),char(30),char(141), -char(30),char(158),char(30),char(175),char(30),char(193),char(31),char(25),char(31),char(42), -char(31),char(59),char(31),char(76),char(31),char(93),char(31),char(110),char(31),char(128), -char(31),char(174),char(32),char(25),char(32),char(42),char(32),char(59),char(32),char(76), -char(32),char(94),char(32),char(111),char(32),char(177),char(33),char(24),char(33),char(40), -char(33),char(56),char(33),char(72),char(33),char(88),char(33),char(105),char(33),char(122), -char(34),char(5),char(34),char(17),char(34),char(33),char(34),char(49),char(34),char(65), -char(34),char(82),char(34),char(99),char(34),char(116),char(34),char(133),char(34),char(151), -char(34),char(255),char(35),char(15),char(35),char(31),char(35),char(47),char(35),char(63), -char(35),char(79),char(35),char(96),char(35),char(166),char(36),char(12),char(36),char(28), -char(36),char(44),char(36),char(60),char(36),char(77),char(36),char(93),char(36),char(180), -char(36),char(197),char(36),char(214),char(36),char(230),char(36),char(247),char(37),char(7), -char(37),char(19),char(37),char(31),char(37),char(48),char(37),char(64),char(37),char(81), -char(37),char(97),char(37),char(114),char(37),char(131),char(37),char(148),char(37),char(164), -char(37),char(181),char(37),char(198),char(37),char(206),char(38),char(58),char(38),char(75), -char(38),char(91),char(38),char(108),char(38),char(124),char(38),char(141),char(38),char(158), -char(38),char(170),char(38),char(182),char(38),char(199),char(38),char(215),char(38),char(232), -char(38),char(248),char(39),char(9),char(39),char(25),char(39),char(42),char(39),char(59), -char(39),char(71),char(39),char(87),char(39),char(104),char(39),char(121),char(39),char(201), -char(40),char(34),char(40),char(51),char(40),char(68),char(40),char(85),char(40),char(102), -char(40),char(119),char(40),char(136),char(40),char(147),char(40),char(158),char(40),char(175), -char(40),char(198),char(40),char(210),char(40),char(222),char(40),char(239),char(41),char(0), -char(41),char(12),char(41),char(23),char(41),char(76),char(41),char(93),char(41),char(110), -char(41),char(121),char(41),char(133),char(41),char(150),char(41),char(166),char(41),char(178), -char(41),char(190),char(41),char(248),char(42),char(45),char(42),char(62),char(42),char(78), -char(42),char(90),char(42),char(101),char(42),char(118),char(42),char(134),char(42),char(151), -char(42),char(222),char(43),char(39),char(43),char(56),char(43),char(72),char(43),char(89), -char(43),char(105),char(43),char(123),char(43),char(140),char(43),char(239),char(44),char(105), -char(44),char(122),char(44),char(138),char(44),char(149),char(44),char(161),char(44),char(178), -char(44),char(195),char(44),char(212),char(44),char(228),char(44),char(245),char(45),char(5), -char(45),char(17),char(45),char(29),char(45),char(46),char(45),char(62),char(45),char(73), -char(45),char(84),char(45),char(101),char(45),char(117),char(45),char(178),char(46),char(4), -char(46),char(21),char(46),char(37),char(46),char(54),char(46),char(70),char(46),char(87), -char(46),char(103),char(46),char(121),char(46),char(138),char(46),char(156),char(46),char(173), -char(46),char(185),char(46),char(197),char(46),char(214),char(46),char(231),char(46),char(248), -char(47),char(8),char(47),char(26),char(47),char(43),char(47),char(59),char(47),char(76), -char(47),char(93),char(47),char(110),char(47),char(126),char(47),char(165),char(47),char(248), -char(48),char(119),char(49),char(22),char(49),char(39),char(49),char(56),char(49),char(73), -char(49),char(89),char(49),char(100),char(49),char(111),char(49),char(152),char(49),char(193), -char(49),char(215),char(49),char(255),char(50),char(31),char(50),char(84),char(50),char(123), -char(50),char(180),char(50),char(230),char(51),char(5),char(51),char(78),char(51),char(95), -char(51),char(103),char(51),char(120),char(51),char(138),char(51),char(156),char(51),char(173), -char(51),char(191),char(51),char(208),char(51),char(227),char(51),char(235),char(51),char(243), -char(52),char(18),char(52),char(26),char(52),char(34),char(52),char(42),char(52),char(50), -char(52),char(139),char(52),char(147),char(52),char(155),char(52),char(193),char(52),char(201), -char(52),char(209),char(53),char(6),char(53),char(14),char(53),char(50),char(53),char(58), -char(53),char(113),char(53),char(121),char(53),char(129),char(53),char(232),char(53),char(240), -char(54),char(60),char(54),char(144),char(54),char(162),char(54),char(180),char(54),char(196), -char(54),char(212),char(54),char(228),char(54),char(245),char(55),char(7),char(55),char(107), -char(55),char(208),char(56),char(6),char(56),char(103),char(56),char(197),char(57),char(18), -char(57),char(76),char(57),char(166),char(57),char(210),char(57),char(218),char(58),char(44), -char(58),char(52),char(58),char(95),char(58),char(202),char(58),char(210),char(59),char(16), -char(59),char(92),char(59),char(168),char(59),char(237),char(60),char(37),char(60),char(93), -char(60),char(186),char(61),char(16),char(61),char(95),char(61),char(185),char(61),char(203), -char(61),char(220),char(61),char(236),char(61),char(252),char(62),char(13),char(62),char(31), -char(62),char(111),char(62),char(128),char(62),char(202),char(62),char(210),char(62),char(218), -char(62),char(236),char(62),char(244),char(63),char(83),char(63),char(166),char(63),char(229), -char(63),char(246),char(64),char(7),char(64),char(55),char(64),char(63),char(64),char(134), -char(64),char(142),char(64),char(150),char(64),char(223),char(64),char(231),char(65),char(44), -char(65),char(137),char(65),char(193),char(65),char(210),char(66),char(1),char(66),char(60), -char(66),char(68),char(66),char(76),char(66),char(84),char(66),char(92),char(66),char(100), -char(66),char(108),char(66),char(116),char(66),char(179),char(66),char(187),char(66),char(195), -char(66),char(244),char(67),char(43),char(67),char(91),char(67),char(149),char(67),char(219), -char(68),char(35),char(68),char(97),char(68),char(175),char(69),char(15),char(69),char(86), -char(69),char(94),char(69),char(186),char(70),char(21),char(70),char(52),char(70),char(124), -char(70),char(132),char(70),char(202),char(71),char(35),char(71),char(91),char(71),char(107), -char(71),char(155),char(71),char(209),char(72),char(20),char(72),char(73),char(72),char(81), -char(72),char(117),char(72),char(125),char(72),char(133),char(72),char(170),char(72),char(178), -char(73),char(19),char(73),char(27),char(73),char(76),char(73),char(131),char(73),char(180), -char(73),char(239),char(74),char(52),char(74),char(125),char(74),char(184),char(75),char(8), -char(75),char(101),char(75),char(169),char(75),char(186),char(76),char(37),char(76),char(53), -char(76),char(131),char(76),char(139),char(76),char(147),char(76),char(165),char(76),char(173), -char(77),char(6),char(77),char(88),char(77),char(96),char(77),char(112),char(77),char(128), -char(77),char(177),char(77),char(214),char(77),char(253),char(78),char(14),char(78),char(30), -char(78),char(47),char(78),char(64),char(78),char(82),char(78),char(100),char(78),char(117), -char(78),char(134),char(78),char(155),char(78),char(176),char(78),char(184),char(78),char(218), -char(78),char(247),char(79),char(21),char(79),char(29),char(79),char(58),char(79),char(105), -char(79),char(154),char(79),char(180),char(79),char(242),char(80),char(90),char(80),char(122), -char(80),char(138),char(81),char(36),char(81),char(44),char(81),char(52),char(81),char(87), -char(81),char(123),char(81),char(135),char(81),char(160),char(81),char(211),char(82),char(24), -char(82),char(134),char(82),char(248),char(83),char(110),char(83),char(212),char(84),char(44), -char(84),char(160),char(84),char(244),char(84),char(252),char(85),char(75),char(85),char(98), -char(85),char(121),char(85),char(144),char(85),char(167),char(86),char(10),char(86),char(62), -char(86),char(99),char(86),char(151),char(86),char(174),char(86),char(210),char(87),char(50), -char(87),char(98),char(87),char(227),char(88),char(44),char(88),char(62),char(88),char(80), -char(88),char(125),char(88),char(137),char(88),char(149),char(88),char(188),char(88),char(227), -char(89),char(2),char(89),char(33),char(89),char(64),char(89),char(117),char(89),char(183), -char(89),char(252),char(90),char(77),char(90),char(110),char(90),char(211),char(91),char(39), -char(91),char(39),char(91),char(39),char(91),char(39),char(91),char(39),char(91),char(39), -char(91),char(39),char(91),char(39),char(91),char(39),char(91),char(39),char(91),char(39), -char(91),char(39),char(91),char(39),char(91),char(39),char(92),char(113),char(92),char(204), -char(92),char(221),char(92),char(229),char(93),char(108),char(93),char(167),char(94),char(11), -char(94),char(28),char(94),char(45),char(94),char(57),char(94),char(69),char(94),char(87), -char(94),char(140),char(94),char(195),char(94),char(211),char(94),char(227),char(95),char(64), -char(95),char(151),char(95),char(224),char(96),char(49),char(96),char(58),char(96),char(67), -char(96),char(76),char(96),char(122),char(96),char(153),char(96),char(170),char(96),char(187), -char(96),char(203),char(96),char(219),char(97),char(78),char(97),char(153),char(97),char(237), -char(98),char(59),char(98),char(155),char(98),char(254),char(99),char(63),char(99),char(128), -char(99),char(214),char(100),char(44),char(100),char(143),char(100),char(244),char(101),char(105), -char(101),char(224),char(102),char(140),char(103),char(48),char(103),char(56),char(103),char(64), -char(103),char(157),char(103),char(246),char(104),char(47),char(104),char(103),char(104),char(121), -char(104),char(139),char(105),char(1),char(105),char(13),char(105),char(128),char(105),char(243), -char(106),char(157),char(107),char(59),char(107),char(209),char(108),char(58),char(108),char(125), -char(108),char(191),char(109),char(3),char(109),char(51),char(109),char(96),char(109),char(134), -char(109),char(172),char(110),char(144),char(111),char(27),char(111),char(129),char(111),char(223), -char(112),char(49),char(112),char(130),char(112),char(215),char(113),char(67),char(113),char(123), -char(113),char(180),char(114),char(6),char(114),char(85),char(114),char(168),char(114),char(251), -char(115),char(7),char(115),char(19),char(115),char(80),char(115),char(140),char(115),char(205), -char(116),char(16),char(116),char(88),char(116),char(172),char(116),char(230),char(117),char(30), -char(117),char(93),char(117),char(162),char(117),char(221),char(118),char(29),char(118),char(115), -char(118),char(198),char(119),char(66),char(119),char(185),char(119),char(197),char(119),char(209), -char(120),char(2),char(120),char(52),char(120),char(60),char(120),char(111),char(120),char(173), -char(120),char(241),char(121),char(48),char(121),char(113),char(121),char(174),char(121),char(236), -char(122),char(48),char(122),char(115),char(122),char(191),char(123),char(11),char(123),char(67), -char(123),char(122),char(123),char(232),char(124),char(75),char(124),char(193),char(125),char(45), -char(125),char(53),char(125),char(70),char(125),char(87),char(125),char(172),char(125),char(252), -char(126),char(68),char(126),char(135),char(126),char(204),char(127),char(21),char(127),char(85), -char(127),char(150),char(127),char(218),char(128),char(30),char(128),char(111),char(128),char(189), -char(128),char(197),char(128),char(214),char(128),char(230),char(128),char(248),char(129),char(9), -char(129),char(17),char(129),char(25),char(129),char(42),char(129),char(58),char(129),char(139), -char(129),char(218),char(129),char(236),char(129),char(253),char(130),char(15),char(130),char(33), -char(130),char(51),char(130),char(68),char(130),char(144),char(130),char(218),char(130),char(235), -char(130),char(251),char(131),char(13),char(131),char(30),char(131),char(48),char(131),char(65), -char(131),char(73),char(131),char(81),char(131),char(99),char(131),char(116),char(131),char(134), -char(131),char(151),char(131),char(168),char(131),char(184),char(131),char(202),char(131),char(219), -char(131),char(237),char(131),char(254),char(132),char(16),char(132),char(33),char(132),char(76), -char(132),char(119),char(132),char(137),char(132),char(155),char(132),char(167),char(132),char(178), -char(132),char(190),char(132),char(202),char(133),char(16),char(133),char(86),char(133),char(148), -char(133),char(156),char(133),char(246),char(134),char(100),char(134),char(201),char(135),char(39), -char(135),char(129),char(135),char(212),char(136),char(43),char(136),char(121),char(136),char(196), -char(137),char(19),char(137),char(102),char(137),char(176),char(137),char(239),char(138),char(45), -char(138),char(138),char(138),char(146),char(138),char(158),char(138),char(170),char(138),char(182), -char(138),char(194),char(138),char(211),char(138),char(228),char(138),char(246),char(139),char(8), -char(139),char(26),char(139),char(44),char(139),char(62),char(139),char(80),char(139),char(98), -char(139),char(116),char(139),char(137),char(139),char(157),char(139),char(175),char(139),char(193), -char(139),char(211),char(139),char(229),char(139),char(247),char(140),char(9),char(140),char(27), -char(140),char(45),char(140),char(66),char(140),char(86),char(140),char(98),char(140),char(110), -char(140),char(127),char(140),char(144),char(140),char(161),char(140),char(177),char(140),char(195), -char(140),char(213),char(140),char(231),char(140),char(249),char(141),char(11),char(141),char(29), -char(141),char(47),char(141),char(65),char(141),char(86),char(141),char(106),char(141),char(123), -char(141),char(140),char(141),char(152),char(141),char(164),char(141),char(176),char(141),char(188), -char(141),char(205),char(141),char(222),char(141),char(240),char(142),char(2),char(142),char(20), -char(142),char(38),char(142),char(56),char(142),char(74),char(142),char(92),char(142),char(110), -char(142),char(131),char(142),char(151),char(142),char(168),char(142),char(184),char(142),char(201), -char(142),char(217),char(142),char(234),char(142),char(251),char(143),char(12),char(143),char(28), -char(143),char(40),char(143),char(52),char(143),char(64),char(143),char(76),char(143),char(93), -char(143),char(110),char(143),char(127),char(143),char(143),char(143),char(160),char(143),char(176), -char(143),char(193),char(143),char(210),char(143),char(227),char(143),char(243),char(143),char(255), -char(144),char(11),char(144),char(23),char(144),char(35),char(144),char(52),char(144),char(69), -char(144),char(86),char(144),char(102),char(144),char(114),char(144),char(166),char(144),char(225), -char(145),char(29),char(145),char(106),char(145),char(194),char(145),char(250),char(146),char(50), -char(146),char(123),char(146),char(205),char(146),char(245),char(147),char(24),char(147),char(59), -char(147),char(68),char(147),char(131),char(147),char(173),char(147),char(238),char(148),char(78), -char(148),char(147),char(148),char(222),char(148),char(230),char(149),char(9),char(149),char(17), -char(149),char(110),char(149),char(122),char(149),char(246),char(150),char(2),char(150),char(14), -char(150),char(113),char(150),char(129),char(150),char(145),char(150),char(162),char(150),char(178), -char(150),char(199),char(150),char(216),char(150),char(233),char(150),char(250),char(151),char(12), -char(151),char(29),char(151),char(46),char(151),char(63),char(151),char(74),char(151),char(91), -char(151),char(103),char(151),char(121),char(151),char(129),char(151),char(147),char(151),char(155), -char(151),char(173),char(151),char(181),char(151),char(189),char(151),char(206),char(151),char(218), -char(0),char(0),char(0),char(2),char(0),char(193),char(0),char(0),char(4),char(10), -char(5),char(182),char(0),char(3),char(0),char(7),char(0),char(21),char(183),char(4), -char(3),char(5),char(2),char(4),char(3),char(7),char(0),char(0),char(47),char(50), -char(47),char(51),char(1),char(47),char(51),char(47),char(51),char(49),char(48),char(19), -char(33),char(17),char(33),char(55),char(33),char(17),char(33),char(193),char(3),char(73), -char(252),char(183),char(104),char(2),char(121),char(253),char(135),char(5),char(182),char(250), -char(74),char(104),char(4),char(230),char(0),char(2),char(0),char(152),char(255),char(227), -char(1),char(137),char(5),char(182),char(0),char(3),char(0),char(14),char(0),char(43), -char(64),char(20),char(3),char(9),char(9),char(2),char(4),char(4),char(15),char(16), -char(1),char(1),char(12),char(2),char(12),char(6),char(79),char(89),char(12),char(22), -char(2),char(3),char(0),char(63),char(63),char(43),char(17),char(18),char(0),char(57), -char(24),char(47),char(17),char(18),char(1),char(57),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(1),char(35),char(3),char(51),char(3),char(52),char(51), -char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(1),char(70), -char(105),char(51),char(207),char(225),char(120),char(58),char(63),char(64),char(57),char(52), -char(68),char(1),char(147),char(4),char(35),char(250),char(180),char(136),char(70),char(66), -char(64),char(71),char(63),char(0),char(0),char(2),char(0),char(133),char(3),char(166), -char(2),char(176),char(5),char(182),char(0),char(3),char(0),char(7),char(0),char(31), -char(64),char(13),char(0),char(3),char(7),char(4),char(3),char(4),char(8),char(9), -char(6),char(2),char(7),char(3),char(3),char(0),char(63),char(51),char(205),char(50), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(3),char(35),char(3),char(33),char(3),char(35),char(3),char(1), -char(63),char(40),char(105),char(41),char(2),char(43),char(41),char(104),char(41),char(5), -char(182),char(253),char(240),char(2),char(16),char(253),char(240),char(2),char(16),char(0), -char(0),char(2),char(0),char(51),char(0),char(0),char(4),char(246),char(5),char(182), -char(0),char(27),char(0),char(31),char(0),char(153),char(64),char(85),char(8),char(31), -char(28),char(21),char(4),char(20),char(9),char(17),char(12),char(12),char(9),char(18), -char(15),char(14),char(11),char(4),char(10),char(19),char(19),char(20),char(22),char(29), -char(30),char(7),char(4),char(6),char(23),char(4),char(1),char(0),char(25),char(4), -char(24),char(5),char(5),char(6),char(20),char(6),char(10),char(33),char(3),char(26), -char(23),char(3),char(24),char(10),char(24),char(32),char(33),char(8),char(4),char(12), -char(13),char(12),char(78),char(89),char(28),char(1),char(13),char(31),char(0),char(16), -char(17),char(16),char(78),char(89),char(25),char(21),char(17),char(79),char(13),char(1), -char(79),char(17),char(1),char(13),char(17),char(13),char(17),char(5),char(23),char(19), -char(3),char(10),char(5),char(0),char(47),char(51),char(63),char(51),char(18),char(57), -char(57),char(47),char(47),char(93),char(93),char(17),char(51),char(51),char(43),char(17), -char(0),char(51),char(51),char(17),char(51),char(51),char(43),char(17),char(0),char(51), -char(51),char(17),char(18),char(1),char(57),char(57),char(17),char(23),char(51),char(17), -char(18),char(57),char(57),char(17),char(51),char(17),char(18),char(23),char(57),char(17), -char(18),char(23),char(57),char(17),char(51),char(17),char(18),char(23),char(57),char(50), -char(50),char(17),char(51),char(17),char(18),char(23),char(57),char(49),char(48),char(1), -char(3),char(33),char(21),char(33),char(3),char(35),char(19),char(33),char(3),char(35), -char(19),char(33),char(53),char(33),char(19),char(33),char(53),char(33),char(19),char(51), -char(3),char(33),char(19),char(51),char(3),char(33),char(21),char(1),char(33),char(19), -char(33),char(3),char(213),char(66),char(1),char(27),char(254),char(205),char(84),char(137), -char(84),char(254),char(209),char(82),char(136),char(80),char(254),char(250),char(1),char(31), -char(68),char(254),char(235),char(1),char(43),char(82),char(139),char(82),char(1),char(49), -char(84),char(134),char(84),char(1),char(8),char(252),char(229),char(1),char(47),char(66), -char(254),char(209),char(3),char(131),char(254),char(172),char(129),char(254),char(82),char(1), -char(174),char(254),char(82),char(1),char(174),char(129),char(1),char(84),char(127),char(1), -char(180),char(254),char(76),char(1),char(180),char(254),char(76),char(127),char(254),char(172), -char(1),char(84),char(0),char(3),char(0),char(131),char(255),char(137),char(4),char(12), -char(6),char(18),char(0),char(32),char(0),char(38),char(0),char(45),char(0),char(102), -char(64),char(53),char(39),char(17),char(37),char(29),char(23),char(4),char(4),char(42), -char(20),char(13),char(5),char(33),char(0),char(0),char(25),char(5),char(17),char(9), -char(5),char(46),char(47),char(37),char(13),char(6),char(13),char(77),char(89),char(3), -char(6),char(36),char(14),char(42),char(14),char(76),char(89),char(29),char(42),char(43), -char(28),char(20),char(28),char(77),char(89),char(23),char(42),char(20),char(6),char(20), -char(6),char(20),char(5),char(22),char(5),char(0),char(47),char(47),char(18),char(57), -char(57),char(47),char(47),char(18),char(57),char(50),char(43),char(17),char(0),char(51), -char(17),char(51),char(43),char(17),char(0),char(51),char(17),char(51),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(51),char(51),char(51),char(17),char(51),char(51),char(51),char(17),char(51), -char(49),char(48),char(1),char(20),char(6),char(7),char(21),char(35),char(53),char(34), -char(38),char(39),char(53),char(22),char(22),char(51),char(17),char(38),char(38),char(53), -char(52),char(54),char(55),char(53),char(51),char(21),char(22),char(23),char(7),char(38), -char(39),char(17),char(30),char(2),char(7),char(52),char(38),char(39),char(17),char(54), -char(1),char(20),char(22),char(23),char(17),char(6),char(6),char(4),char(12),char(204), -char(183),char(129),char(112),char(210),char(67),char(83),char(217),char(89),char(205),char(165), -char(203),char(167),char(129),char(184),char(171),char(52),char(149),char(154),char(157),char(156), -char(74),char(170),char(89),char(128),char(217),char(253),char(221),char(90),char(111),char(99), -char(102),char(1),char(193),char(136),char(177),char(23),char(232),char(223),char(35),char(31), -char(156),char(37),char(47),char(1),char(184),char(65),char(172),char(136),char(131),char(168), -char(18),char(182),char(180),char(5),char(69),char(131),char(59),char(11),char(254),char(78), -char(50),char(95),char(123),char(101),char(72),char(89),char(44),char(254),char(123),char(30), -char(3),char(7),char(76),char(92),char(41),char(1),char(131),char(16),char(93),char(0), -char(0),char(5),char(0),char(104),char(255),char(236),char(6),char(45),char(5),char(203), -char(0),char(9),char(0),char(21),char(0),char(33),char(0),char(45),char(0),char(49), -char(0),char(69),char(64),char(36),char(0),char(16),char(5),char(10),char(22),char(40), -char(28),char(34),char(34),char(46),char(40),char(10),char(48),char(16),char(6),char(50), -char(51),char(3),char(13),char(31),char(43),char(13),char(43),char(13),char(43),char(48), -char(49),char(6),char(48),char(24),char(25),char(37),char(25),char(7),char(19),char(7), -char(0),char(63),char(51),char(63),char(51),char(63),char(63),char(18),char(57),char(57), -char(47),char(47),char(17),char(51),char(17),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(19),char(20),char(22),char(51),char(50),char(17),char(16),char(35),char(34), -char(6),char(5),char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54), -char(51),char(50),char(22),char(1),char(20),char(22),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(34),char(6),char(5),char(20),char(6),char(35),char(34), -char(38),char(53),char(52),char(54),char(51),char(50),char(22),char(1),char(1),char(35), -char(1),char(242),char(74),char(83),char(164),char(164),char(83),char(74),char(1),char(202), -char(153),char(148),char(140),char(155),char(149),char(146),char(145),char(156),char(1),char(166), -char(74),char(84),char(84),char(80),char(80),char(84),char(84),char(74),char(1),char(203), -char(153),char(148),char(142),char(153),char(149),char(146),char(142),char(159),char(254),char(254), -char(252),char(213),char(147),char(3),char(43),char(4),char(2),char(170),char(170),char(1), -char(84),char(1),char(82),char(168),char(170),char(228),char(233),char(238),char(223),char(227), -char(230),char(238),char(252),char(219),char(171),char(169),char(167),char(173),char(171),char(165), -char(165),char(171),char(227),char(233),char(238),char(222),char(227),char(230),char(235),char(3), -char(32),char(250),char(74),char(5),char(182),char(0),char(0),char(3),char(0),char(113), -char(255),char(236),char(5),char(211),char(5),char(205),char(0),char(11),char(0),char(21), -char(0),char(53),char(0),char(81),char(64),char(48),char(19),char(22),char(0),char(29), -char(6),char(35),char(42),char(43),char(46),char(43),char(45),char(35),char(14),char(38), -char(25),char(29),char(22),char(9),char(54),char(55),char(51),char(12),char(73),char(89), -char(51),char(19),char(15),char(39),char(45),char(14),char(48),char(5),char(47),char(3), -char(25),char(38),char(3),char(42),char(42),char(32),char(47),char(18),char(32),char(9), -char(74),char(89),char(32),char(4),char(0),char(63),char(43),char(0),char(24),char(63), -char(18),char(57),char(47),char(23),char(57),char(18),char(23),char(57),char(63),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(22),char(23),char(54), -char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(19),char(50),char(55), -char(1),char(14),char(2),char(21),char(20),char(22),char(37),char(52),char(54),char(55), -char(46),char(2),char(53),char(52),char(54),char(51),char(50),char(22),char(21),char(20), -char(6),char(7),char(1),char(54),char(54),char(55),char(51),char(2),char(7),char(1), -char(35),char(39),char(6),char(6),char(35),char(34),char(38),char(1),char(158),char(72), -char(87),char(129),char(101),char(103),char(86),char(89),char(111),char(155),char(241),char(159), -char(254),char(75),char(111),char(92),char(44),char(155),char(254),char(185),char(139),char(180), -char(85),char(61),char(36),char(196),char(175),char(162),char(186),char(136),char(157),char(1), -char(151),char(56),char(67),char(23),char(168),char(68),char(137),char(1),char(43),char(229), -char(185),char(118),char(244),char(150),char(215),char(237),char(4),char(147),char(69),char(125), -char(88),char(75),char(127),char(83),char(77),char(97),char(96),char(251),char(157),char(154), -char(1),char(168),char(68),char(89),char(102),char(65),char(117),char(137),char(250),char(130), -char(200),char(102),char(95),char(98),char(106),char(57),char(150),char(168),char(167),char(149), -char(107),char(181),char(93),char(254),char(121),char(62),char(167),char(99),char(254),char(226), -char(148),char(254),char(221),char(178),char(106),char(92),char(212),char(0),char(0),char(1), -char(0),char(133),char(3),char(166),char(1),char(63),char(5),char(182),char(0),char(3), -char(0),char(20),char(183),char(0),char(3),char(3),char(4),char(5),char(2),char(3), -char(3),char(0),char(63),char(205),char(17),char(18),char(1),char(57),char(17),char(51), -char(49),char(48),char(1),char(3),char(35),char(3),char(1),char(63),char(40),char(105), -char(41),char(5),char(182),char(253),char(240),char(2),char(16),char(0),char(0),char(1), -char(0),char(82),char(254),char(188),char(2),char(33),char(5),char(182),char(0),char(13), -char(0),char(28),char(64),char(12),char(7),char(0),char(10),char(4),char(0),char(4), -char(14),char(15),char(11),char(39),char(3),char(3),char(0),char(63),char(63),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(19),char(16),char(18),char(55),char(51),char(6),char(2),char(21),char(20),char(18), -char(23),char(35),char(38),char(2),char(82),char(155),char(146),char(162),char(144),char(145), -char(148),char(139),char(160),char(147),char(154),char(2),char(49),char(1),char(9),char(1), -char(206),char(174),char(193),char(254),char(50),char(244),char(240),char(254),char(54),char(189), -char(170),char(1),char(198),char(0),char(0),char(1),char(0),char(61),char(254),char(188), -char(2),char(12),char(5),char(182),char(0),char(13),char(0),char(28),char(64),char(12), -char(4),char(10),char(7),char(0),char(10),char(0),char(14),char(15),char(10),char(3), -char(4),char(39),char(0),char(63),char(63),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(2),char(7), -char(35),char(54),char(18),char(53),char(52),char(2),char(39),char(51),char(22),char(18), -char(2),char(12),char(155),char(146),char(160),char(139),char(148),char(145),char(144),char(162), -char(147),char(154),char(2),char(49),char(254),char(249),char(254),char(58),char(168),char(188), -char(1),char(203),char(240),char(244),char(1),char(206),char(193),char(175),char(254),char(49), -char(0),char(1),char(0),char(86),char(2),char(127),char(4),char(14),char(6),char(20), -char(0),char(14),char(0),char(48),char(64),char(27),char(3),char(5),char(4),char(1), -char(7),char(13),char(10),char(9),char(11),char(9),char(15),char(16),char(4),char(10), -char(1),char(13),char(2),char(12),char(12),char(13),char(10),char(7),char(4),char(6), -char(8),char(14),char(0),char(0),char(63),char(196),char(50),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(18),char(1),char(23),char(57), -char(49),char(48),char(1),char(3),char(37),char(23),char(5),char(19),char(7),char(3), -char(3),char(39),char(19),char(37),char(55),char(5),char(3),char(2),char(145),char(43), -char(1),char(142),char(26),char(254),char(131),char(248),char(172),char(176),char(160),char(176), -char(242),char(254),char(135),char(29),char(1),char(135),char(43),char(6),char(20),char(254), -char(117),char(111),char(182),char(31),char(254),char(186),char(94),char(1),char(106),char(254), -char(150),char(94),char(1),char(70),char(31),char(182),char(111),char(1),char(139),char(0), -char(0),char(1),char(0),char(104),char(0),char(227),char(4),char(41),char(4),char(195), -char(0),char(11),char(0),char(40),char(64),char(19),char(0),char(4),char(4),char(9), -char(5),char(5),char(12),char(13),char(3),char(7),char(8),char(7),char(80),char(89), -char(0),char(15),char(8),char(1),char(8),char(0),char(47),char(93),char(51),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(57),char(17),char(51),char(51), -char(17),char(51),char(49),char(48),char(1),char(33),char(21),char(33),char(17),char(35), -char(17),char(33),char(53),char(33),char(17),char(51),char(2),char(141),char(1),char(156), -char(254),char(100),char(139),char(254),char(102),char(1),char(154),char(139),char(3),char(23), -char(138),char(254),char(86),char(1),char(170),char(138),char(1),char(172),char(0),char(1), -char(0),char(63),char(254),char(248),char(1),char(109),char(0),char(238),char(0),char(8), -char(0),char(17),char(181),char(5),char(0),char(9),char(10),char(5),char(0),char(0), -char(47),char(205),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(37), -char(23),char(6),char(2),char(7),char(35),char(54),char(18),char(55),char(1),char(94), -char(15),char(26),char(98),char(53),char(125),char(27),char(65),char(13),char(238),char(23), -char(100),char(254),char(247),char(114),char(104),char(1),char(50),char(92),char(0),char(1), -char(0),char(84),char(1),char(217),char(2),char(63),char(2),char(113),char(0),char(3), -char(0),char(17),char(181),char(2),char(0),char(5),char(4),char(0),char(1),char(0), -char(47),char(51),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(19), -char(53),char(33),char(21),char(84),char(1),char(235),char(1),char(217),char(152),char(152), -char(0),char(1),char(0),char(152),char(255),char(227),char(1),char(137),char(0),char(242), -char(0),char(11),char(0),char(24),char(64),char(11),char(6),char(0),char(0),char(12), -char(13),char(9),char(3),char(79),char(89),char(9),char(22),char(0),char(63),char(43), -char(17),char(18),char(1),char(57),char(17),char(51),char(49),char(48),char(55),char(52), -char(54),char(51),char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38), -char(152),char(61),char(57),char(58),char(65),char(66),char(57),char(51),char(67),char(106), -char(67),char(69),char(69),char(67),char(65),char(70),char(63),char(0),char(0),char(1), -char(0),char(20),char(0),char(0),char(2),char(219),char(5),char(182),char(0),char(3), -char(0),char(19),char(183),char(2),char(0),char(4),char(5),char(3),char(3),char(2), -char(18),char(0),char(63),char(63),char(17),char(18),char(1),char(57),char(57),char(49), -char(48),char(1),char(1),char(35),char(1),char(2),char(219),char(253),char(223),char(166), -char(2),char(33),char(5),char(182),char(250),char(74),char(5),char(182),char(0),char(2), -char(0),char(102),char(255),char(236),char(4),char(45),char(5),char(205),char(0),char(11), -char(0),char(23),char(0),char(40),char(64),char(20),char(18),char(0),char(12),char(6), -char(0),char(6),char(25),char(24),char(9),char(21),char(75),char(89),char(9),char(7), -char(3),char(15),char(75),char(89),char(3),char(25),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(16),char(2),char(35),char(34),char(2), -char(17),char(16),char(18),char(51),char(50),char(18),char(1),char(16),char(18),char(51), -char(50),char(18),char(17),char(16),char(2),char(35),char(34),char(2),char(4),char(45), -char(239),char(246),char(236),char(246),char(238),char(244),char(238),char(247),char(252),char(225), -char(150),char(164),char(166),char(149),char(149),char(166),char(164),char(150),char(2),char(221), -char(254),char(133),char(254),char(138),char(1),char(127),char(1),char(114),char(1),char(126), -char(1),char(114),char(254),char(126),char(254),char(146),char(254),char(193),char(254),char(221), -char(1),char(39),char(1),char(59),char(1),char(59),char(1),char(37),char(254),char(223), -char(0),char(1),char(0),char(188),char(0),char(0),char(2),char(203),char(5),char(182), -char(0),char(10),char(0),char(36),char(64),char(16),char(9),char(0),char(1),char(8), -char(1),char(11),char(12),char(4),char(9),char(7),char(7),char(1),char(9),char(6), -char(1),char(24),char(0),char(63),char(63),char(18),char(57),char(47),char(18),char(57), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(51),char(49),char(48), -char(33),char(35),char(17),char(52),char(55),char(6),char(6),char(7),char(39),char(1), -char(51),char(2),char(203),char(162),char(8),char(21),char(52),char(212),char(88),char(1), -char(131),char(140),char(4),char(18),char(130),char(116),char(21),char(46),char(172),char(114), -char(1),char(43),char(0),char(1),char(0),char(100),char(0),char(0),char(4),char(37), -char(5),char(203),char(0),char(25),char(0),char(43),char(64),char(23),char(24),char(1), -char(7),char(19),char(0),char(19),char(14),char(1),char(4),char(26),char(27),char(16), -char(10),char(75),char(89),char(16),char(7),char(1),char(24),char(76),char(89),char(1), -char(24),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(33), -char(33),char(53),char(1),char(62),char(2),char(53),char(52),char(38),char(35),char(34), -char(6),char(7),char(39),char(54),char(51),char(50),char(22),char(21),char(20),char(2), -char(7),char(1),char(21),char(33),char(4),char(37),char(252),char(63),char(1),char(129), -char(176),char(112),char(56),char(142),char(126),char(91),char(163),char(100),char(88),char(202), -char(238),char(206),char(234),char(156),char(214),char(254),char(192),char(2),char(240),char(143), -char(1),char(131),char(178),char(152),char(144),char(83),char(117),char(137),char(60),char(79), -char(113),char(168),char(211),char(178),char(139),char(254),char(240),char(208),char(254),char(199), -char(8),char(0),char(0),char(1),char(0),char(94),char(255),char(236),char(4),char(27), -char(5),char(203),char(0),char(39),char(0),char(67),char(64),char(36),char(27),char(0), -char(19),char(7),char(7),char(0),char(3),char(22),char(34),char(13),char(6),char(40), -char(41),char(3),char(23),char(22),char(23),char(22),char(75),char(89),char(23),char(23), -char(10),char(37),char(37),char(30),char(75),char(89),char(37),char(7),char(10),char(17), -char(75),char(89),char(10),char(25),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18), -char(0),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(20),char(6),char(7),char(21),char(22),char(22), -char(21),char(20),char(4),char(33),char(34),char(38),char(39),char(53),char(22),char(22), -char(51),char(32),char(17),char(16),char(33),char(35),char(53),char(51),char(50),char(54), -char(53),char(52),char(38),char(35),char(34),char(6),char(7),char(39),char(54),char(54), -char(51),char(50),char(22),char(3),char(238),char(157),char(144),char(176),char(170),char(254), -char(222),char(254),char(245),char(116),char(193),char(91),char(95),char(215),char(96),char(1), -char(123),char(254),char(94),char(144),char(146),char(171),char(200),char(147),char(126),char(96), -char(170),char(109),char(84),char(90),char(235),char(130),char(213),char(236),char(4),char(94), -char(140),char(178),char(30),char(8),char(22),char(180),char(146),char(209),char(225),char(35), -char(44),char(158),char(47),char(49),char(1),char(41),char(1),char(10),char(143),char(151), -char(134),char(107),char(122),char(52),char(70),char(112),char(71),char(81),char(195),char(0), -char(0),char(2),char(0),char(43),char(0),char(0),char(4),char(106),char(5),char(190), -char(0),char(10),char(0),char(18),char(0),char(60),char(64),char(30),char(18),char(5), -char(9),char(2),char(2),char(11),char(7),char(3),char(0),char(3),char(5),char(3), -char(19),char(20),char(1),char(5),char(18),char(5),char(76),char(89),char(9),char(15), -char(7),char(18),char(18),char(3),char(7),char(6),char(3),char(24),char(0),char(63), -char(63),char(18),char(57),char(47),char(18),char(57),char(51),char(43),char(17),char(0), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(35),char(17),char(35), -char(17),char(33),char(53),char(1),char(51),char(17),char(51),char(33),char(17),char(52), -char(55),char(35),char(6),char(7),char(1),char(4),char(106),char(217),char(159),char(253), -char(57),char(2),char(182),char(176),char(217),char(254),char(136),char(10),char(8),char(48), -char(42),char(254),char(55),char(1),char(80),char(254),char(176),char(1),char(80),char(145), -char(3),char(221),char(252),char(41),char(1),char(230),char(143),char(180),char(96),char(63), -char(253),char(118),char(0),char(1),char(0),char(133),char(255),char(236),char(4),char(29), -char(5),char(182),char(0),char(26),char(0),char(58),char(64),char(31),char(15),char(3), -char(25),char(20),char(8),char(20),char(23),char(3),char(4),char(28),char(27),char(0), -char(17),char(75),char(89),char(0),char(0),char(6),char(21),char(21),char(24),char(76), -char(89),char(21),char(6),char(6),char(12),char(75),char(89),char(6),char(25),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(24),char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(50),char(4),char(21),char(20),char(0), -char(35),char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53), -char(16),char(33),char(34),char(7),char(39),char(19),char(33),char(21),char(33),char(3), -char(54),char(2),char(45),char(231),char(1),char(9),char(254),char(223),char(254),char(247), -char(130),char(70),char(208),char(101),char(176),char(195),char(254),char(137),char(95),char(159), -char(86),char(55),char(2),char(215),char(253),char(183),char(37),char(115),char(3),char(125), -char(229),char(199),char(227),char(254),char(254),char(79),char(160),char(45),char(51),char(166), -char(157),char(1),char(50),char(29),char(55),char(2),char(172),char(153),char(254),char(73), -char(23),char(0),char(0),char(2),char(0),char(117),char(255),char(236),char(4),char(47), -char(5),char(203),char(0),char(22),char(0),char(36),char(0),char(68),char(64),char(35), -char(26),char(17),char(11),char(33),char(33),char(0),char(0),char(6),char(17),char(3), -char(38),char(37),char(12),char(11),char(14),char(29),char(77),char(89),char(11),char(14), -char(14),char(20),char(3),char(20),char(23),char(75),char(89),char(20),char(25),char(3), -char(8),char(77),char(89),char(3),char(7),char(0),char(63),char(43),char(0),char(24), -char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(57),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(16),char(0),char(33), -char(50),char(23),char(21),char(38),char(35),char(34),char(2),char(3),char(51),char(54), -char(51),char(50),char(22),char(21),char(20),char(2),char(35),char(34),char(0),char(5), -char(50),char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(6),char(21), -char(20),char(22),char(22),char(117),char(1),char(79),char(1),char(72),char(113),char(65), -char(77),char(99),char(235),char(248),char(12),char(12),char(110),char(238),char(197),char(227), -char(249),char(212),char(227),char(254),char(246),char(1),char(235),char(142),char(157),char(146), -char(145),char(90),char(150),char(89),char(80),char(147),char(2),char(113),char(1),char(175), -char(1),char(171),char(19),char(143),char(25),char(254),char(219),char(254),char(198),char(172), -char(238),char(204),char(228),char(254),char(251),char(1),char(85),char(200),char(179),char(169), -char(145),char(166),char(74),char(130),char(70),char(103),char(178),char(104),char(0),char(1), -char(0),char(94),char(0),char(0),char(4),char(43),char(5),char(182),char(0),char(6), -char(0),char(31),char(64),char(16),char(1),char(5),char(5),char(0),char(2),char(3), -char(7),char(8),char(3),char(2),char(76),char(89),char(3),char(6),char(0),char(24), -char(0),char(63),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(49),char(48),char(33),char(1),char(33),char(53),char(33),char(21),char(1), -char(1),char(29),char(2),char(94),char(252),char(227),char(3),char(205),char(253),char(170), -char(5),char(29),char(153),char(133),char(250),char(207),char(0),char(3),char(0),char(104), -char(255),char(236),char(4),char(41),char(5),char(203),char(0),char(22),char(0),char(34), -char(0),char(46),char(0),char(77),char(64),char(41),char(23),char(15),char(38),char(20), -char(44),char(3),char(29),char(9),char(9),char(3),char(6),char(17),char(20),char(15), -char(6),char(47),char(48),char(6),char(17),char(41),char(32),char(41),char(32),char(75), -char(89),char(41),char(41),char(12),char(0),char(12),char(26),char(77),char(89),char(12), -char(25),char(0),char(35),char(77),char(89),char(0),char(7),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(0),char(57),char(57),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(50),char(22),char(21),char(20),char(6),char(7),char(22),char(22), -char(21),char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(37),char(38), -char(38),char(53),char(52),char(54),char(3),char(20),char(22),char(51),char(50),char(54), -char(53),char(52),char(38),char(39),char(6),char(6),char(1),char(34),char(6),char(21), -char(20),char(22),char(23),char(54),char(54),char(53),char(52),char(38),char(2),char(72), -char(200),char(234),char(134),char(147),char(178),char(150),char(254),char(221),char(234),char(252), -char(1),char(50),char(138),char(120),char(235),char(119),char(167),char(151),char(149),char(166), -char(156),char(194),char(149),char(134),char(1),char(58),char(125),char(142),char(118),char(159), -char(143),char(119),char(145),char(5),char(203),char(186),char(164),char(108),char(178),char(73), -char(85),char(187),char(123),char(182),char(217),char(205),char(188),char(251),char(140),char(78), -char(181),char(112),char(159),char(189),char(251),char(166),char(120),char(134),char(140),char(122), -char(97),char(151),char(71),char(64),char(155),char(3),char(103),char(120),char(100),char(92), -char(132),char(66),char(60),char(138),char(92),char(101),char(119),char(0),char(0),char(2), -char(0),char(106),char(255),char(236),char(4),char(37),char(5),char(203),char(0),char(23), -char(0),char(37),char(0),char(65),char(64),char(34),char(27),char(17),char(34),char(10), -char(10),char(0),char(0),char(4),char(17),char(3),char(38),char(39),char(14),char(30), -char(77),char(89),char(11),char(20),char(14),char(14),char(2),char(20),char(20),char(24), -char(75),char(89),char(20),char(7),char(2),char(7),char(77),char(89),char(2),char(25), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0), -char(57),char(24),char(47),char(18),char(57),char(43),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(16),char(33),char(34),char(39),char(53),char(22),char(51),char(50),char(18),char(19), -char(35),char(6),char(6),char(35),char(34),char(38),char(53),char(52),char(18),char(51), -char(50),char(22),char(18),char(1),char(34),char(6),char(21),char(20),char(22),char(51), -char(50),char(54),char(54),char(53),char(52),char(38),char(38),char(4),char(37),char(253), -char(104),char(116),char(68),char(80),char(102),char(240),char(245),char(11),char(12),char(55), -char(182),char(114),char(194),char(228),char(255),char(208),char(149),char(223),char(120),char(254), -char(20),char(143),char(156),char(144),char(147),char(91),char(153),char(88),char(82),char(147), -char(3),char(70),char(252),char(166),char(20),char(143),char(26),char(1),char(41),char(1), -char(51),char(83),char(87),char(232),char(208),char(228),char(1),char(8),char(153),char(254), -char(219),char(1),char(48),char(184),char(164),char(144),char(165),char(74),char(128),char(70), -char(105),char(178),char(102),char(0),char(0),char(2),char(0),char(152),char(255),char(227), -char(1),char(137),char(4),char(100),char(0),char(11),char(0),char(21),char(0),char(40), -char(64),char(20),char(16),char(6),char(6),char(12),char(0),char(0),char(22),char(23), -char(14),char(19),char(79),char(89),char(14),char(16),char(9),char(3),char(79),char(89), -char(9),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(1),char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48), -char(55),char(52),char(54),char(51),char(50),char(22),char(21),char(20),char(6),char(35), -char(34),char(38),char(17),char(52),char(51),char(50),char(21),char(20),char(6),char(35), -char(34),char(38),char(152),char(61),char(57),char(58),char(65),char(66),char(57),char(51), -char(67),char(118),char(123),char(66),char(57),char(51),char(67),char(106),char(67),char(69), -char(69),char(67),char(65),char(70),char(63),char(3),char(187),char(135),char(135),char(65), -char(70),char(63),char(0),char(2),char(0),char(63),char(254),char(248),char(1),char(133), -char(4),char(100),char(0),char(8),char(0),char(18),char(0),char(34),char(64),char(16), -char(1),char(13),char(13),char(5),char(9),char(9),char(20),char(19),char(11),char(16), -char(79),char(89),char(11),char(16),char(5),char(0),char(0),char(47),char(205),char(63), -char(43),char(17),char(18),char(1),char(57),char(17),char(51),char(51),char(17),char(51), -char(49),char(48),char(37),char(23),char(6),char(2),char(7),char(35),char(54),char(18), -char(55),char(3),char(52),char(51),char(50),char(21),char(20),char(6),char(35),char(34), -char(38),char(1),char(94),char(15),char(26),char(98),char(53),char(125),char(27),char(65), -char(13),char(21),char(119),char(123),char(66),char(57),char(58),char(61),char(238),char(23), -char(100),char(254),char(247),char(114),char(104),char(1),char(50),char(92),char(2),char(239), -char(135),char(135),char(65),char(70),char(70),char(0),char(0),char(1),char(0),char(104), -char(0),char(242),char(4),char(41),char(4),char(217),char(0),char(6),char(0),char(21), -char(64),char(9),char(4),char(0),char(5),char(1),char(4),char(7),char(8),char(3), -char(0),char(0),char(47),char(47),char(17),char(18),char(1),char(23),char(57),char(49), -char(48),char(37),char(1),char(53),char(1),char(21),char(1),char(1),char(4),char(41), -char(252),char(63),char(3),char(193),char(252),char(242),char(3),char(14),char(242),char(1), -char(166),char(98),char(1),char(223),char(149),char(254),char(141),char(254),char(184),char(0), -char(0),char(2),char(0),char(119),char(1),char(193),char(4),char(25),char(3),char(227), -char(0),char(3),char(0),char(7),char(0),char(42),char(64),char(21),char(7),char(2), -char(4),char(0),char(2),char(0),char(9),char(8),char(4),char(5),char(80),char(89), -char(4),char(1),char(0),char(80),char(89),char(15),char(1),char(1),char(1),char(0), -char(47),char(93),char(43),char(0),char(24),char(47),char(43),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(53), -char(33),char(21),char(1),char(53),char(33),char(21),char(119),char(3),char(162),char(252), -char(94),char(3),char(162),char(3),char(90),char(137),char(137),char(254),char(103),char(137), -char(137),char(0),char(0),char(1),char(0),char(104),char(0),char(242),char(4),char(41), -char(4),char(217),char(0),char(6),char(0),char(21),char(64),char(9),char(5),char(1), -char(2),char(0),char(4),char(7),char(8),char(6),char(3),char(0),char(47),char(47), -char(17),char(18),char(1),char(23),char(57),char(49),char(48),char(19),char(1),char(1), -char(53),char(1),char(21),char(1),char(104),char(3),char(15),char(252),char(241),char(3), -char(193),char(252),char(63),char(1),char(137),char(1),char(70),char(1),char(117),char(149), -char(254),char(33),char(98),char(254),char(90),char(0),char(0),char(2),char(0),char(27), -char(255),char(227),char(3),char(57),char(5),char(203),char(0),char(27),char(0),char(38), -char(0),char(57),char(64),char(29),char(33),char(28),char(27),char(0),char(7),char(19), -char(19),char(0),char(28),char(14),char(4),char(39),char(40),char(0),char(0),char(36), -char(16),char(36),char(30),char(79),char(89),char(36),char(22),char(16),char(10),char(73), -char(89),char(16),char(4),char(0),char(63),char(43),char(0),char(24),char(63),char(43), -char(17),char(18),char(0),char(57),char(24),char(47),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(53),char(52),char(54),char(55),char(54),char(54),char(53),char(52),char(38),char(35), -char(34),char(6),char(7),char(39),char(54),char(51),char(50),char(22),char(21),char(20), -char(6),char(6),char(7),char(6),char(6),char(21),char(21),char(3),char(52),char(51), -char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(1),char(33), -char(72),char(98),char(136),char(71),char(131),char(123),char(79),char(150),char(97),char(59), -char(189),char(206),char(191),char(212),char(39),char(76),char(126),char(101),char(65),char(178), -char(120),char(58),char(63),char(64),char(57),char(52),char(68),char(1),char(147),char(54), -char(117),char(151),char(84),char(115),char(116),char(82),char(102),char(111),char(37),char(49), -char(135),char(99),char(188),char(171),char(73),char(111),char(99),char(110),char(86),char(114), -char(95),char(33),char(254),char(215),char(136),char(70),char(66),char(64),char(71),char(63), -char(0),char(2),char(0),char(121),char(255),char(70),char(6),char(184),char(5),char(180), -char(0),char(53),char(0),char(63),char(0),char(69),char(64),char(34),char(35),char(46), -char(54),char(14),char(59),char(7),char(20),char(27),char(0),char(0),char(41),char(20), -char(14),char(46),char(5),char(64),char(65),char(24),char(56),char(56),char(4),char(61), -char(8),char(17),char(11),char(17),char(11),char(17),char(43),char(31),char(50),char(3), -char(38),char(43),char(0),char(47),char(51),char(63),char(51),char(18),char(57),char(57), -char(47),char(47),char(18),char(57),char(50),char(51),char(51),char(17),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(6),char(6),char(35), -char(34),char(38),char(39),char(35),char(6),char(6),char(35),char(34),char(38),char(53), -char(52),char(54),char(51),char(50),char(22),char(23),char(3),char(21),char(20),char(51), -char(50),char(54),char(53),char(52),char(2),char(36),char(35),char(34),char(4),char(2), -char(21),char(16),char(0),char(33),char(50),char(55),char(21),char(6),char(35),char(32), -char(0),char(17),char(16),char(18),char(36),char(33),char(50),char(4),char(18),char(1), -char(20),char(51),char(50),char(19),char(19),char(38),char(35),char(34),char(6),char(6), -char(184),char(88),char(160),char(104),char(86),char(118),char(11),char(8),char(40),char(149), -char(102),char(150),char(169),char(236),char(192),char(68),char(172),char(69),char(25),char(133), -char(91),char(114),char(148),char(254),char(239),char(177),char(223),char(254),char(182),char(174), -char(1),char(66),char(1),char(47),char(210),char(226),char(192),char(244),char(254),char(149), -char(254),char(111),char(214),char(1),char(140),char(1),char(0),char(215),char(1),char(79), -char(183),char(251),char(246),char(195),char(207),char(18),char(14),char(72),char(85),char(130), -char(147),char(2),char(217),char(142),char(236),char(130),char(104),char(81),char(87),char(98), -char(205),char(176),char(204),char(255),char(25),char(22),char(254),char(42),char(22),char(178), -char(215),char(172),char(181),char(1),char(16),char(147),char(185),char(254),char(169),char(225), -char(254),char(207),char(254),char(184),char(86),char(133),char(84),char(1),char(143),char(1), -char(102),char(1),char(4),char(1),char(150),char(223),char(181),char(254),char(179),char(254), -char(164),char(254),char(1),char(57),char(1),char(5),char(20),char(180),char(0),char(2), -char(0),char(0),char(0),char(0),char(5),char(16),char(5),char(188),char(0),char(7), -char(0),char(14),char(0),char(57),char(64),char(30),char(2),char(14),char(11),char(8), -char(1),char(5),char(0),char(3),char(0),char(7),char(3),char(4),char(7),char(4), -char(16),char(15),char(14),char(2),char(73),char(89),char(11),char(5),char(14),char(14), -char(4),char(5),char(3),char(0),char(4),char(18),char(0),char(63),char(51),char(63), -char(18),char(57),char(47),char(18),char(57),char(43),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(17),char(18),char(23),char(57),char(49), -char(48),char(33),char(3),char(33),char(3),char(35),char(1),char(51),char(1),char(1), -char(3),char(38),char(39),char(6),char(7),char(3),char(4),char(96),char(182),char(253), -char(182),char(180),char(172),char(2),char(66),char(143),char(2),char(63),char(254),char(101), -char(170),char(33),char(35),char(22),char(41),char(172),char(1),char(209),char(254),char(47), -char(5),char(188),char(250),char(68),char(2),char(106),char(1),char(197),char(86),char(125), -char(96),char(115),char(254),char(59),char(0),char(3),char(0),char(201),char(0),char(0), -char(4),char(190),char(5),char(182),char(0),char(14),char(0),char(23),char(0),char(32), -char(0),char(73),char(64),char(38),char(19),char(4),char(29),char(10),char(15),char(25), -char(25),char(14),char(10),char(4),char(7),char(14),char(4),char(33),char(34),char(8), -char(15),char(24),char(15),char(24),char(74),char(89),char(15),char(15),char(14),char(0), -char(14),char(25),char(74),char(89),char(14),char(18),char(0),char(23),char(74),char(89), -char(0),char(3),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(0),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(19),char(33),char(32),char(4),char(21), -char(20),char(6),char(7),char(21),char(4),char(17),char(20),char(4),char(35),char(33), -char(19),char(33),char(50),char(54),char(53),char(52),char(38),char(35),char(35),char(17), -char(17),char(33),char(50),char(54),char(53),char(52),char(38),char(35),char(201),char(1), -char(157),char(1),char(35),char(1),char(4),char(145),char(139),char(1),char(77),char(254), -char(247),char(238),char(254),char(2),char(170),char(1),char(24),char(180),char(158),char(176), -char(192),char(250),char(1),char(49),char(177),char(179),char(183),char(187),char(5),char(182), -char(174),char(188),char(130),char(169),char(25),char(10),char(57),char(254),char(219),char(196), -char(220),char(3),char(68),char(113),char(134),char(123),char(109),char(253),char(145),char(253), -char(221),char(137),char(146),char(136),char(128),char(0),char(0),char(1),char(0),char(125), -char(255),char(236),char(4),char(207),char(5),char(203),char(0),char(22),char(0),char(38), -char(64),char(20),char(3),char(14),char(20),char(9),char(14),char(3),char(23),char(24), -char(18),char(0),char(73),char(89),char(18),char(4),char(11),char(6),char(73),char(89), -char(11),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(34), -char(0),char(17),char(16),char(0),char(51),char(50),char(55),char(21),char(6),char(35), -char(32),char(0),char(17),char(52),char(18),char(36),char(51),char(50),char(23),char(7), -char(38),char(3),char(59),char(241),char(254),char(233),char(1),char(13),char(249),char(153), -char(196),char(152),char(223),char(254),char(189),char(254),char(161),char(169),char(1),char(63), -char(216),char(230),char(172),char(72),char(166),char(5),char(51),char(254),char(191),char(254), -char(233),char(254),char(225),char(254),char(199),char(55),char(149),char(57),char(1),char(136), -char(1),char(105),char(226),char(1),char(84),char(184),char(84),char(146),char(78),char(0), -char(0),char(2),char(0),char(201),char(0),char(0),char(5),char(88),char(5),char(182), -char(0),char(8),char(0),char(17),char(0),char(40),char(64),char(20),char(14),char(4), -char(9),char(0),char(4),char(0),char(18),char(19),char(5),char(13),char(74),char(89), -char(5),char(3),char(4),char(14),char(74),char(89),char(4),char(18),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(33), -char(33),char(17),char(33),char(32),char(0),char(3),char(16),char(0),char(33),char(35), -char(17),char(51),char(32),char(0),char(5),char(88),char(254),char(119),char(254),char(143), -char(254),char(107),char(1),char(192),char(1),char(85),char(1),char(122),char(180),char(254), -char(225),char(254),char(229),char(247),char(207),char(1),char(48),char(1),char(50),char(2), -char(233),char(254),char(150),char(254),char(129),char(5),char(182),char(254),char(134),char(254), -char(167),char(1),char(30),char(1),char(34),char(251),char(112),char(1),char(43),char(0), -char(0),char(1),char(0),char(201),char(0),char(0),char(3),char(248),char(5),char(182), -char(0),char(11),char(0),char(58),char(64),char(31),char(6),char(10),char(10),char(1), -char(4),char(0),char(8),char(1),char(4),char(12),char(13),char(6),char(9),char(73), -char(89),char(6),char(6),char(1),char(2),char(2),char(5),char(73),char(89),char(2), -char(3),char(1),char(10),char(73),char(89),char(1),char(18),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(33),char(33),char(17),char(33),char(21),char(33),char(17),char(33), -char(21),char(33),char(17),char(33),char(3),char(248),char(252),char(209),char(3),char(47), -char(253),char(123),char(2),char(94),char(253),char(162),char(2),char(133),char(5),char(182), -char(151),char(254),char(41),char(150),char(253),char(230),char(0),char(1),char(0),char(201), -char(0),char(0),char(3),char(248),char(5),char(182),char(0),char(9),char(0),char(50), -char(64),char(26),char(6),char(0),char(0),char(1),char(3),char(8),char(1),char(3), -char(10),char(11),char(6),char(9),char(73),char(89),char(6),char(6),char(1),char(2), -char(2),char(5),char(73),char(89),char(2),char(3),char(1),char(18),char(0),char(63), -char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(33),char(35),char(17),char(33),char(21),char(33),char(17),char(33),char(21),char(33), -char(1),char(115),char(170),char(3),char(47),char(253),char(123),char(2),char(94),char(253), -char(162),char(5),char(182),char(151),char(253),char(233),char(151),char(0),char(0),char(1), -char(0),char(125),char(255),char(236),char(5),char(61),char(5),char(203),char(0),char(27), -char(0),char(58),char(64),char(31),char(20),char(8),char(25),char(2),char(2),char(14), -char(27),char(8),char(4),char(28),char(29),char(0),char(27),char(73),char(89),char(0), -char(0),char(5),char(12),char(12),char(17),char(73),char(89),char(12),char(4),char(5), -char(23),char(73),char(89),char(5),char(19),char(0),char(63),char(43),char(0),char(24), -char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(33),char(17),char(6),char(6),char(35),char(32),char(0),char(17),char(52), -char(18),char(36),char(51),char(50),char(23),char(7),char(38),char(35),char(32),char(0), -char(17),char(16),char(0),char(33),char(50),char(55),char(17),char(33),char(3),char(76), -char(1),char(241),char(116),char(240),char(158),char(254),char(180),char(254),char(142),char(183), -char(1),char(88),char(231),char(234),char(202),char(66),char(198),char(183),char(254),char(245), -char(254),char(212),char(1),char(33),char(1),char(24),char(152),char(145),char(254),char(185), -char(2),char(254),char(253),char(57),char(37),char(38),char(1),char(139),char(1),char(100), -char(228),char(1),char(87),char(181),char(86),char(150),char(84),char(254),char(194),char(254), -char(230),char(254),char(216),char(254),char(206),char(35),char(1),char(194),char(0),char(1), -char(0),char(201),char(0),char(0),char(5),char(31),char(5),char(182),char(0),char(11), -char(0),char(51),char(64),char(25),char(9),char(1),char(1),char(0),char(8),char(4), -char(4),char(5),char(0),char(5),char(13),char(12),char(8),char(3),char(73),char(89), -char(8),char(8),char(5),char(10),char(6),char(3),char(1),char(5),char(18),char(0), -char(63),char(51),char(63),char(51),char(18),char(57),char(47),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(33),char(35),char(17),char(33),char(17),char(35),char(17), -char(51),char(17),char(33),char(17),char(51),char(5),char(31),char(170),char(252),char(254), -char(170),char(170),char(3),char(2),char(170),char(2),char(176),char(253),char(80),char(5), -char(182),char(253),char(146),char(2),char(110),char(0),char(0),char(1),char(0),char(84), -char(0),char(0),char(2),char(86),char(5),char(182),char(0),char(11),char(0),char(55), -char(64),char(28),char(5),char(1),char(10),char(3),char(8),char(0),char(0),char(3), -char(1),char(3),char(12),char(13),char(9),char(4),char(6),char(4),char(74),char(89), -char(6),char(3),char(10),char(3),char(1),char(3),char(74),char(89),char(1),char(18), -char(0),char(63),char(43),char(17),char(0),char(51),char(24),char(63),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(53),char(55),char(17), -char(39),char(53),char(33),char(21),char(7),char(17),char(23),char(2),char(86),char(253), -char(254),char(172),char(172),char(2),char(2),char(172),char(172),char(98),char(35),char(4), -char(170),char(37),char(98),char(98),char(37),char(251),char(86),char(35),char(0),char(1), -char(255),char(96),char(254),char(127),char(1),char(104),char(5),char(182),char(0),char(13), -char(0),char(29),char(64),char(13),char(11),char(8),char(8),char(14),char(15),char(9), -char(3),char(0),char(5),char(73),char(89),char(0),char(34),char(0),char(63),char(43), -char(0),char(24),char(63),char(17),char(18),char(1),char(57),char(17),char(51),char(49), -char(48),char(3),char(34),char(39),char(53),char(22),char(51),char(50),char(54),char(53), -char(17),char(51),char(17),char(20),char(6),char(12),char(94),char(54),char(71),char(77), -char(99),char(103),char(170),char(192),char(254),char(127),char(27),char(145),char(20),char(120), -char(113),char(5),char(182),char(250),char(88),char(190),char(209),char(0),char(0),char(1), -char(0),char(201),char(0),char(0),char(4),char(233),char(5),char(182),char(0),char(11), -char(0),char(42),char(64),char(21),char(8),char(4),char(4),char(5),char(5),char(2), -char(11),char(10),char(0),char(5),char(13),char(12),char(2),char(8),char(5),char(9), -char(6),char(3),char(1),char(5),char(18),char(0),char(63),char(51),char(63),char(51), -char(18),char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(33),char(35),char(1),char(7),char(17),char(35), -char(17),char(51),char(17),char(1),char(51),char(1),char(4),char(233),char(200),char(253), -char(235),char(153),char(170),char(170),char(2),char(151),char(201),char(253),char(180),char(2), -char(197),char(136),char(253),char(195),char(5),char(182),char(253),char(43),char(2),char(213), -char(253),char(133),char(0),char(1),char(0),char(201),char(0),char(0),char(3),char(248), -char(5),char(182),char(0),char(5),char(0),char(31),char(64),char(14),char(3),char(0), -char(0),char(4),char(6),char(7),char(1),char(3),char(0),char(3),char(73),char(89), -char(0),char(18),char(0),char(63),char(43),char(0),char(24),char(63),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(49),char(48),char(51),char(17),char(51), -char(17),char(33),char(21),char(201),char(170),char(2),char(133),char(5),char(182),char(250), -char(228),char(154),char(0),char(1),char(0),char(201),char(0),char(0),char(6),char(113), -char(5),char(182),char(0),char(19),char(0),char(50),char(64),char(24),char(8),char(5), -char(5),char(6),char(11),char(14),char(14),char(13),char(6),char(13),char(20),char(21), -char(1),char(10),char(17),char(3),char(6),char(11),char(7),char(3),char(14),char(0), -char(6),char(18),char(0),char(63),char(51),char(51),char(63),char(51),char(18),char(23), -char(57),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(1),char(35),char(22), -char(21),char(17),char(35),char(17),char(33),char(1),char(51),char(1),char(51),char(17), -char(35),char(17),char(52),char(55),char(35),char(1),char(3),char(80),char(254),char(16), -char(8),char(14),char(157),char(1),char(0),char(1),char(207),char(8),char(1),char(211), -char(254),char(170),char(14),char(8),char(254),char(12),char(5),char(16),char(154),char(212), -char(252),char(94),char(5),char(182),char(251),char(74),char(4),char(182),char(250),char(74), -char(3),char(174),char(162),char(190),char(250),char(242),char(0),char(1),char(0),char(201), -char(0),char(0),char(5),char(63),char(5),char(182),char(0),char(16),char(0),char(46), -char(64),char(21),char(9),char(6),char(6),char(7),char(1),char(15),char(15),char(0), -char(7),char(0),char(17),char(18),char(11),char(3),char(7),char(15),char(8),char(3), -char(1),char(7),char(18),char(0),char(63),char(51),char(63),char(51),char(18),char(57), -char(57),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(35),char(1),char(35), -char(22),char(21),char(17),char(35),char(17),char(51),char(1),char(51),char(38),char(2), -char(55),char(17),char(51),char(5),char(63),char(194),char(252),char(225),char(8),char(16), -char(157),char(192),char(3),char(29),char(8),char(2),char(14),char(2),char(159),char(4), -char(203),char(216),char(180),char(252),char(193),char(5),char(182),char(251),char(58),char(27), -char(1),char(37),char(63),char(3),char(71),char(0),char(0),char(2),char(0),char(125), -char(255),char(236),char(5),char(190),char(5),char(205),char(0),char(11),char(0),char(23), -char(0),char(40),char(64),char(20),char(18),char(0),char(12),char(6),char(0),char(6), -char(25),char(24),char(9),char(21),char(73),char(89),char(9),char(4),char(3),char(15), -char(73),char(89),char(3),char(19),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(16),char(0),char(33),char(32),char(0),char(17),char(16), -char(0),char(33),char(32),char(0),char(1),char(16),char(18),char(51),char(50),char(18), -char(17),char(16),char(2),char(35),char(34),char(2),char(5),char(190),char(254),char(157), -char(254),char(196),char(254),char(189),char(254),char(161),char(1),char(96),char(1),char(68), -char(1),char(59),char(1),char(98),char(251),char(115),char(253),char(241),char(243),char(248), -char(247),char(242),char(243),char(253),char(2),char(221),char(254),char(161),char(254),char(110), -char(1),char(139),char(1),char(104),char(1),char(101),char(1),char(137),char(254),char(112), -char(254),char(160),char(254),char(215),char(254),char(205),char(1),char(50),char(1),char(42), -char(1),char(39),char(1),char(49),char(254),char(205),char(0),char(2),char(0),char(201), -char(0),char(0),char(4),char(104),char(5),char(182),char(0),char(9),char(0),char(18), -char(0),char(52),char(64),char(26),char(10),char(5),char(5),char(6),char(14),char(0), -char(6),char(0),char(19),char(20),char(10),char(4),char(74),char(89),char(10),char(10), -char(6),char(7),char(7),char(18),char(74),char(89),char(7),char(3),char(6),char(18), -char(0),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(4),char(33),char(35),char(17), -char(35),char(17),char(33),char(32),char(1),char(51),char(50),char(54),char(53),char(52), -char(38),char(35),char(35),char(4),char(104),char(254),char(209),char(254),char(230),char(172), -char(170),char(1),char(123),char(2),char(36),char(253),char(11),char(153),char(226),char(202), -char(190),char(201),char(190),char(4),char(12),char(222),char(239),char(253),char(193),char(5), -char(182),char(253),char(27),char(146),char(161),char(145),char(142),char(0),char(0),char(2), -char(0),char(125),char(254),char(164),char(5),char(190),char(5),char(205),char(0),char(15), -char(0),char(27),char(0),char(52),char(64),char(27),char(16),char(10),char(22),char(0), -char(0),char(4),char(3),char(10),char(4),char(28),char(29),char(3),char(13),char(7), -char(13),char(25),char(73),char(89),char(13),char(4),char(7),char(19),char(73),char(89), -char(5),char(7),char(19),char(0),char(63),char(198),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(2),char(7), -char(1),char(35),char(1),char(7),char(32),char(0),char(17),char(16),char(0),char(33), -char(32),char(0),char(1),char(16),char(18),char(51),char(50),char(18),char(17),char(16), -char(2),char(35),char(34),char(2),char(5),char(190),char(226),char(206),char(1),char(92), -char(247),char(254),char(227),char(55),char(254),char(189),char(254),char(161),char(1),char(96), -char(1),char(68),char(1),char(59),char(1),char(98),char(251),char(115),char(253),char(241), -char(243),char(248),char(247),char(242),char(243),char(253),char(2),char(221),char(254),char(231), -char(254),char(140),char(66),char(254),char(150),char(1),char(74),char(2),char(1),char(139), -char(1),char(104),char(1),char(101),char(1),char(137),char(254),char(112),char(254),char(160), -char(254),char(215),char(254),char(205),char(1),char(50),char(1),char(42),char(1),char(39), -char(1),char(49),char(254),char(205),char(0),char(2),char(0),char(201),char(0),char(0), -char(4),char(207),char(5),char(182),char(0),char(12),char(0),char(21),char(0),char(72), -char(64),char(37),char(13),char(1),char(1),char(2),char(12),char(9),char(17),char(7), -char(11),char(10),char(10),char(7),char(9),char(2),char(4),char(22),char(23),char(9), -char(13),char(0),char(13),char(0),char(74),char(89),char(13),char(13),char(2),char(3), -char(3),char(21),char(73),char(89),char(3),char(3),char(11),char(2),char(18),char(0), -char(63),char(51),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(17),char(35),char(17),char(33),char(32),char(4),char(21), -char(16),char(5),char(1),char(35),char(1),char(37),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(35),char(1),char(115),char(170),char(1),char(145),char(1), -char(13),char(1),char(1),char(254),char(218),char(1),char(141),char(201),char(254),char(158), -char(254),char(207),char(233),char(180),char(168),char(171),char(189),char(221),char(2),char(96), -char(253),char(160),char(5),char(182),char(206),char(207),char(254),char(222),char(102),char(253), -char(111),char(2),char(96),char(146),char(143),char(143),char(145),char(128),char(0),char(1), -char(0),char(106),char(255),char(236),char(4),char(2),char(5),char(203),char(0),char(36), -char(0),char(52),char(64),char(27),char(30),char(19),char(12),char(0),char(0),char(24), -char(19),char(5),char(4),char(37),char(38),char(12),char(30),char(3),char(22),char(22), -char(27),char(73),char(89),char(22),char(4),char(3),char(9),char(73),char(89),char(3), -char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(4),char(35),char(32),char(39), -char(53),char(22),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(38), -char(39),char(38),char(38),char(53),char(52),char(54),char(51),char(50),char(23),char(7), -char(38),char(35),char(34),char(6),char(21),char(20),char(22),char(22),char(23),char(22), -char(22),char(4),char(2),char(254),char(232),char(240),char(254),char(252),char(140),char(90), -char(212),char(104),char(170),char(172),char(61),char(143),char(146),char(204),char(175),char(254), -char(209),char(218),char(183),char(53),char(181),char(171),char(135),char(152),char(56),char(133), -char(137),char(230),char(173),char(1),char(133),char(193),char(216),char(67),char(164),char(38), -char(44),char(129),char(115),char(76),char(97),char(82),char(52),char(73),char(200),char(161), -char(169),char(200),char(80),char(148),char(76),char(116),char(103),char(76),char(97),char(81), -char(49),char(82),char(188),char(0),char(0),char(1),char(0),char(18),char(0),char(0), -char(4),char(90),char(5),char(182),char(0),char(7),char(0),char(36),char(64),char(18), -char(0),char(1),char(5),char(1),char(3),char(3),char(8),char(9),char(7),char(3), -char(4),char(3),char(73),char(89),char(4),char(3),char(1),char(18),char(0),char(63), -char(63),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(49),char(48),char(33),char(35),char(17),char(33),char(53),char(33), -char(21),char(33),char(2),char(139),char(170),char(254),char(49),char(4),char(72),char(254), -char(49),char(5),char(31),char(151),char(151),char(0),char(0),char(1),char(0),char(186), -char(255),char(236),char(5),char(25),char(5),char(182),char(0),char(17),char(0),char(37), -char(64),char(17),char(16),char(1),char(10),char(7),char(1),char(7),char(19),char(18), -char(17),char(8),char(3),char(4),char(13),char(73),char(89),char(4),char(19),char(0), -char(63),char(43),char(0),char(24),char(63),char(51),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(20), -char(0),char(33),char(32),char(0),char(53),char(17),char(51),char(17),char(20),char(22), -char(51),char(50),char(54),char(53),char(17),char(5),char(25),char(254),char(210),char(254), -char(248),char(254),char(248),char(254),char(223),char(170),char(200),char(194),char(185),char(200), -char(5),char(182),char(252),char(78),char(250),char(254),char(226),char(1),char(32),char(252), -char(3),char(174),char(252),char(70),char(183),char(196),char(197),char(184),char(3),char(184), -char(0),char(1),char(0),char(0),char(0),char(0),char(4),char(195),char(5),char(182), -char(0),char(10),char(0),char(26),char(64),char(11),char(1),char(4),char(12),char(11), -char(8),char(3),char(0),char(4),char(3),char(3),char(18),char(0),char(63),char(63), -char(51),char(18),char(57),char(17),char(18),char(1),char(57),char(57),char(49),char(48), -char(1),char(51),char(1),char(35),char(1),char(51),char(1),char(22),char(23),char(54), -char(55),char(4),char(12),char(183),char(253),char(241),char(168),char(253),char(244),char(180), -char(1),char(80),char(58),char(34),char(36),char(58),char(5),char(182),char(250),char(74), -char(5),char(182),char(252),char(78),char(163),char(154),char(162),char(161),char(0),char(1), -char(0),char(27),char(0),char(0),char(7),char(76),char(5),char(182),char(0),char(25), -char(0),char(36),char(64),char(16),char(25),char(10),char(27),char(26),char(21),char(14), -char(14),char(5),char(9),char(24),char(17),char(10),char(3),char(1),char(9),char(18), -char(0),char(63),char(51),char(63),char(51),char(51),char(18),char(57),char(57),char(17), -char(51),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(33),char(35), -char(1),char(38),char(38),char(39),char(6),char(7),char(1),char(35),char(1),char(51), -char(19),char(22),char(23),char(54),char(55),char(1),char(51),char(1),char(22),char(23), -char(54),char(55),char(19),char(51),char(5),char(197),char(168),char(254),char(217),char(21), -char(52),char(1),char(22),char(48),char(254),char(226),char(168),char(254),char(123),char(180), -char(231),char(48),char(22),char(27),char(53),char(1),char(6),char(180),char(1),char(19), -char(48),char(33),char(19),char(53),char(230),char(180),char(3),char(211),char(65),char(198), -char(20),char(132),char(157),char(252),char(51),char(5),char(182),char(252),char(121),char(190), -char(154),char(183),char(175),char(3),char(121),char(252),char(127),char(155),char(195),char(142), -char(204),char(3),char(133),char(0),char(0),char(1),char(0),char(8),char(0),char(0), -char(4),char(150),char(5),char(182),char(0),char(11),char(0),char(35),char(64),char(18), -char(4),char(6),char(5),char(11),char(10),char(0),char(6),char(13),char(12),char(2), -char(8),char(4),char(9),char(6),char(3),char(1),char(4),char(18),char(0),char(63), -char(51),char(63),char(51),char(18),char(57),char(57),char(17),char(18),char(1),char(23), -char(57),char(49),char(48),char(33),char(35),char(1),char(1),char(35),char(1),char(1), -char(51),char(1),char(1),char(51),char(1),char(4),char(150),char(193),char(254),char(119), -char(254),char(112),char(180),char(1),char(230),char(254),char(59),char(188),char(1),char(107), -char(1),char(110),char(181),char(254),char(59),char(2),char(131),char(253),char(125),char(2), -char(252),char(2),char(186),char(253),char(189),char(2),char(67),char(253),char(76),char(0), -char(0),char(1),char(0),char(0),char(0),char(0),char(4),char(123),char(5),char(182), -char(0),char(8),char(0),char(32),char(64),char(15),char(4),char(5),char(2),char(5), -char(7),char(3),char(9),char(10),char(0),char(5),char(1),char(7),char(3),char(5), -char(18),char(0),char(63),char(63),char(51),char(18),char(57),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(1),char(51),char(1), -char(17),char(35),char(17),char(1),char(51),char(2),char(61),char(1),char(134),char(184), -char(254),char(24),char(172),char(254),char(25),char(186),char(2),char(219),char(2),char(219), -char(252),char(129),char(253),char(201),char(2),char(47),char(3),char(135),char(0),char(1), -char(0),char(82),char(0),char(0),char(4),char(63),char(5),char(182),char(0),char(9), -char(0),char(43),char(64),char(23),char(8),char(1),char(3),char(7),char(0),char(7), -char(4),char(1),char(4),char(10),char(11),char(5),char(4),char(73),char(89),char(5), -char(3),char(1),char(8),char(73),char(89),char(1),char(18),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(53),char(1),char(33), -char(53),char(33),char(21),char(1),char(33),char(4),char(63),char(252),char(19),char(3), -char(8),char(253),char(16),char(3),char(191),char(252),char(248),char(3),char(30),char(133), -char(4),char(152),char(153),char(133),char(251),char(105),char(0),char(1),char(0),char(166), -char(254),char(188),char(2),char(111),char(5),char(182),char(0),char(7),char(0),char(32), -char(64),char(14),char(6),char(1),char(4),char(0),char(1),char(0),char(8),char(9), -char(5),char(2),char(3),char(6),char(1),char(39),char(0),char(63),char(51),char(63), -char(51),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(33),char(17),char(33),char(21),char(33),char(17),char(33), -char(2),char(111),char(254),char(55),char(1),char(201),char(254),char(223),char(1),char(33), -char(254),char(188),char(6),char(250),char(141),char(250),char(33),char(0),char(0),char(1), -char(0),char(23),char(0),char(0),char(2),char(221),char(5),char(182),char(0),char(3), -char(0),char(19),char(183),char(3),char(1),char(4),char(5),char(3),char(3),char(2), -char(18),char(0),char(63),char(63),char(17),char(18),char(1),char(57),char(57),char(49), -char(48),char(19),char(1),char(35),char(1),char(186),char(2),char(35),char(166),char(253), -char(224),char(5),char(182),char(250),char(74),char(5),char(182),char(0),char(0),char(1), -char(0),char(51),char(254),char(188),char(1),char(252),char(5),char(182),char(0),char(7), -char(0),char(32),char(64),char(14),char(3),char(0),char(1),char(6),char(0),char(6), -char(8),char(9),char(0),char(7),char(39),char(3),char(4),char(3),char(0),char(63), -char(51),char(63),char(51),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(23),char(33),char(17),char(33),char(53),char(33), -char(17),char(33),char(51),char(1),char(33),char(254),char(223),char(1),char(201),char(254), -char(55),char(182),char(5),char(223),char(141),char(249),char(6),char(0),char(0),char(1), -char(0),char(49),char(2),char(39),char(4),char(35),char(5),char(193),char(0),char(6), -char(0),char(24),char(64),char(9),char(0),char(3),char(7),char(8),char(5),char(2), -char(0),char(4),char(2),char(0),char(47),char(47),char(51),char(18),char(57),char(17), -char(18),char(1),char(57),char(57),char(49),char(48),char(19),char(1),char(51),char(1), -char(35),char(1),char(1),char(49),char(1),char(178),char(99),char(1),char(221),char(152), -char(254),char(140),char(254),char(178),char(2),char(39),char(3),char(154),char(252),char(102), -char(2),char(233),char(253),char(23),char(0),char(1),char(255),char(252),char(254),char(197), -char(3),char(154),char(255),char(72),char(0),char(3),char(0),char(17),char(181),char(0), -char(5),char(1),char(4),char(1),char(2),char(0),char(47),char(51),char(17),char(1), -char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(53),char(33),char(3), -char(154),char(252),char(98),char(3),char(158),char(254),char(197),char(131),char(0),char(1), -char(1),char(137),char(4),char(217),char(3),char(18),char(6),char(33),char(0),char(9), -char(0),char(19),char(182),char(0),char(4),char(11),char(10),char(6),char(128),char(1), -char(0),char(47),char(26),char(205),char(17),char(18),char(1),char(57),char(57),char(49), -char(48),char(1),char(35),char(38),char(38),char(39),char(53),char(51),char(22),char(22), -char(23),char(3),char(18),char(110),char(65),char(178),char(40),char(203),char(32),char(114), -char(44),char(4),char(217),char(52),char(192),char(63),char(21),char(69),char(181),char(53), -char(0),char(2),char(0),char(94),char(255),char(236),char(3),char(205),char(4),char(90), -char(0),char(25),char(0),char(36),char(0),char(71),char(64),char(37),char(34),char(8), -char(11),char(30),char(30),char(25),char(25),char(18),char(8),char(3),char(37),char(38), -char(1),char(2),char(11),char(30),char(71),char(89),char(2),char(11),char(11),char(0), -char(21),char(21),char(15),char(70),char(89),char(21),char(16),char(5),char(26),char(70), -char(89),char(5),char(22),char(0),char(21),char(0),char(63),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(57), -char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(39),char(35), -char(6),char(6),char(35),char(34),char(38),char(53),char(16),char(37),char(55),char(53), -char(52),char(38),char(35),char(34),char(7),char(39),char(54),char(54),char(51),char(50), -char(22),char(21),char(17),char(37),char(50),char(54),char(53),char(53),char(7),char(6), -char(6),char(21),char(20),char(22),char(3),char(82),char(33),char(8),char(82),char(163), -char(122),char(163),char(185),char(2),char(19),char(186),char(111),char(122),char(137),char(173), -char(51),char(81),char(193),char(97),char(196),char(189),char(254),char(14),char(155),char(177), -char(166),char(198),char(175),char(109),char(156),char(103),char(73),char(168),char(155),char(1), -char(76),char(16),char(6),char(68),char(129),char(123),char(84),char(127),char(44),char(50), -char(174),char(192),char(253),char(20),char(117),char(170),char(153),char(99),char(7),char(7), -char(109),char(115),char(90),char(94),char(0),char(2),char(0),char(176),char(255),char(236), -char(4),char(117),char(6),char(20),char(0),char(19),char(0),char(31),char(0),char(68), -char(64),char(34),char(10),char(23),char(23),char(15),char(15),char(12),char(29),char(3), -char(12),char(3),char(32),char(33),char(13),char(0),char(12),char(21),char(18),char(17), -char(10),char(17),char(6),char(0),char(6),char(26),char(70),char(89),char(6),char(22), -char(0),char(20),char(70),char(89),char(0),char(16),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(17),char(51), -char(24),char(63),char(63),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(50), -char(18),char(17),char(16),char(2),char(35),char(34),char(38),char(39),char(35),char(7), -char(35),char(17),char(51),char(17),char(20),char(7),char(51),char(54),char(23),char(34), -char(6),char(21),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38), -char(2),char(174),char(216),char(239),char(241),char(214),char(107),char(177),char(60),char(12), -char(35),char(119),char(166),char(8),char(8),char(116),char(204),char(170),char(150),char(154), -char(170),char(153),char(150),char(150),char(4),char(90),char(254),char(217),char(254),char(242), -char(254),char(242),char(254),char(213),char(79),char(82),char(141),char(6),char(20),char(254), -char(134),char(127),char(101),char(164),char(139),char(195),char(231),char(231),char(199),char(223), -char(209),char(214),char(210),char(0),char(0),char(1),char(0),char(115),char(255),char(236), -char(3),char(139),char(4),char(92),char(0),char(22),char(0),char(38),char(64),char(20), -char(15),char(3),char(3),char(21),char(9),char(3),char(24),char(23),char(6),char(13), -char(70),char(89),char(6),char(16),char(0),char(18),char(70),char(89),char(0),char(22), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(49),char(48),char(5),char(34),char(0),char(17), -char(16),char(0),char(51),char(50),char(22),char(23),char(7),char(38),char(38),char(35), -char(32),char(17),char(20),char(22),char(51),char(50),char(55),char(21),char(6),char(2), -char(102),char(238),char(254),char(251),char(1),char(9),char(245),char(79),char(158),char(45), -char(51),char(55),char(130),char(50),char(254),char(178),char(163),char(160),char(137),char(144), -char(110),char(20),char(1),char(37),char(1),char(12),char(1),char(19),char(1),char(44), -char(34),char(23),char(141),char(22),char(29),char(254),char(86),char(202),char(216),char(59), -char(147),char(57),char(0),char(2),char(0),char(115),char(255),char(236),char(4),char(55), -char(6),char(20),char(0),char(18),char(0),char(31),char(0),char(66),char(64),char(33), -char(29),char(6),char(23),char(0),char(14),char(14),char(17),char(6),char(17),char(32), -char(33),char(18),char(21),char(15),char(0),char(0),char(1),char(1),char(12),char(3), -char(9),char(9),char(26),char(70),char(89),char(9),char(16),char(3),char(19),char(70), -char(89),char(3),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(43), -char(17),char(18),char(0),char(57),char(57),char(17),char(51),char(24),char(63),char(63), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(51), -char(17),char(51),char(49),char(48),char(37),char(35),char(6),char(35),char(34),char(2), -char(17),char(16),char(18),char(51),char(50),char(23),char(51),char(39),char(39),char(17), -char(51),char(17),char(35),char(37),char(50),char(54),char(53),char(53),char(52),char(38), -char(35),char(34),char(6),char(21),char(20),char(22),char(3),char(154),char(9),char(115), -char(229),char(215),char(239),char(240),char(214),char(223),char(119),char(13),char(7),char(4), -char(166),char(135),char(254),char(158),char(170),char(153),char(155),char(170),char(146),char(155), -char(154),char(147),char(167),char(1),char(38),char(1),char(15),char(1),char(15),char(1), -char(44),char(162),char(79),char(77),char(1),char(190),char(249),char(236),char(119),char(185), -char(206),char(35),char(233),char(199),char(227),char(207),char(210),char(214),char(0),char(2), -char(0),char(115),char(255),char(236),char(4),char(18),char(4),char(92),char(0),char(19), -char(0),char(26),char(0),char(59),char(64),char(31),char(24),char(10),char(23),char(11), -char(3),char(3),char(17),char(10),char(3),char(28),char(27),char(23),char(11),char(70), -char(89),char(23),char(23),char(0),char(6),char(6),char(20),char(70),char(89),char(6), -char(16),char(0),char(14),char(70),char(89),char(0),char(22),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(5),char(34),char(0),char(17),char(16),char(0),char(51), -char(50),char(18),char(21),char(21),char(33),char(22),char(22),char(51),char(50),char(55), -char(21),char(6),char(6),char(3),char(34),char(6),char(7),char(33),char(52),char(38), -char(2),char(127),char(243),char(254),char(231),char(1),char(5),char(220),char(206),char(240), -char(253),char(13),char(5),char(185),char(168),char(177),char(173),char(88),char(157),char(156), -char(132),char(157),char(14),char(2),char(61),char(140),char(20),char(1),char(40),char(1), -char(7),char(1),char(9),char(1),char(56),char(254),char(241),char(222),char(105),char(193), -char(200),char(74),char(148),char(38),char(33),char(3),char(229),char(172),char(152),char(157), -char(167),char(0),char(0),char(1),char(0),char(29),char(0),char(0),char(3),char(14), -char(6),char(31),char(0),char(20),char(0),char(57),char(64),char(29),char(20),char(12), -char(12),char(19),char(2),char(2),char(7),char(3),char(5),char(3),char(21),char(22), -char(10),char(15),char(70),char(89),char(10),char(0),char(1),char(5),char(7),char(5), -char(70),char(89),char(19),char(7),char(15),char(3),char(21),char(0),char(63),char(63), -char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(51),char(17),char(51),char(51),char(18), -char(57),char(49),char(48),char(1),char(33),char(17),char(35),char(17),char(35),char(53), -char(55),char(53),char(16),char(33),char(50),char(23),char(7),char(38),char(35),char(34), -char(6),char(21),char(21),char(33),char(2),char(158),char(254),char(233),char(166),char(196), -char(196),char(1),char(97),char(87),char(117),char(43),char(96),char(68),char(94),char(90), -char(1),char(23),char(3),char(199),char(252),char(57),char(3),char(199),char(75),char(60), -char(61),char(1),char(148),char(35),char(133),char(31),char(125),char(138),char(71),char(0), -char(0),char(3),char(0),char(39),char(254),char(20),char(4),char(49),char(4),char(92), -char(0),char(42),char(0),char(55),char(0),char(65),char(0),char(110),char(64),char(62), -char(43),char(25),char(56),char(37),char(12),char(31),char(61),char(5),char(49),char(19), -char(1),char(19),char(5),char(2),char(42),char(34),char(28),char(31),char(37),char(25), -char(10),char(66),char(67),char(28),char(15),char(53),char(15),char(53),char(70),char(89), -char(8),char(59),char(71),char(89),char(10),char(34),char(8),char(42),char(15),char(8), -char(15),char(8),char(22),char(42),char(42),char(2),char(71),char(89),char(42),char(15), -char(40),char(63),char(71),char(89),char(40),char(16),char(22),char(46),char(71),char(89), -char(22),char(27),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(24),char(47), -char(47),char(17),char(18),char(57),char(57),char(43),char(43),char(17),char(18),char(0), -char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(21), -char(7),char(22),char(22),char(21),char(20),char(6),char(35),char(34),char(39),char(6), -char(21),char(20),char(22),char(51),char(51),char(50),char(22),char(21),char(20),char(4), -char(33),char(34),char(38),char(53),char(52),char(54),char(55),char(38),char(38),char(53), -char(52),char(54),char(55),char(38),char(38),char(53),char(52),char(54),char(51),char(50), -char(23),char(1),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38), -char(35),char(35),char(34),char(6),char(19),char(20),char(22),char(51),char(50),char(53), -char(52),char(35),char(34),char(6),char(4),char(49),char(203),char(28),char(44),char(220), -char(192),char(49),char(43),char(106),char(74),char(90),char(194),char(178),char(191),char(254), -char(220),char(254),char(232),char(215),char(233),char(128),char(116),char(42),char(57),char(64), -char(69),char(85),char(107),char(216),char(198),char(86),char(69),char(254),char(17),char(150), -char(140),char(209),char(201),char(110),char(152),char(199),char(113),char(126),char(90),char(130), -char(116),char(243),char(246),char(117),char(126),char(4),char(72),char(105),char(24),char(35), -char(113),char(71),char(161),char(192),char(8),char(56),char(85),char(45),char(43),char(150), -char(143),char(182),char(191),char(160),char(146),char(100),char(146),char(26),char(19),char(80), -char(53),char(60),char(90),char(42),char(35),char(168),char(108),char(180),char(195),char(20), -char(251),char(0),char(89),char(92),char(125),char(107),char(89),char(69),char(108),char(3), -char(60),char(115),char(118),char(236),char(247),char(126),char(0),char(1),char(0),char(176), -char(0),char(0),char(4),char(68),char(6),char(20),char(0),char(22),char(0),char(51), -char(64),char(25),char(14),char(12),char(8),char(8),char(9),char(0),char(22),char(9), -char(22),char(23),char(24),char(14),char(9),char(18),char(18),char(4),char(70),char(89), -char(18),char(16),char(10),char(0),char(0),char(9),char(21),char(0),char(63),char(51), -char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(49), -char(48),char(33),char(17),char(52),char(38),char(35),char(34),char(6),char(21),char(17), -char(35),char(17),char(51),char(17),char(20),char(7),char(51),char(54),char(54),char(51), -char(50),char(22),char(21),char(17),char(3),char(158),char(122),char(130),char(173),char(159), -char(166),char(166),char(8),char(10),char(49),char(181),char(116),char(201),char(201),char(2), -char(197),char(134),char(132),char(188),char(214),char(253),char(195),char(6),char(20),char(254), -char(41),char(85),char(56),char(79),char(91),char(191),char(208),char(253),char(53),char(0), -char(0),char(2),char(0),char(162),char(0),char(0),char(1),char(102),char(5),char(223), -char(0),char(3),char(0),char(15),char(0),char(35),char(64),char(17),char(10),char(0), -char(0),char(4),char(1),char(1),char(16),char(17),char(13),char(7),char(72),char(89), -char(13),char(2),char(15),char(1),char(21),char(0),char(63),char(63),char(206),char(43), -char(17),char(18),char(1),char(57),char(17),char(51),char(51),char(17),char(51),char(49), -char(48),char(33),char(35),char(17),char(51),char(3),char(52),char(54),char(51),char(50), -char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(1),char(86),char(166), -char(166),char(180),char(56),char(42),char(40),char(58),char(58),char(40),char(42),char(56), -char(4),char(72),char(1),char(41),char(57),char(53),char(54),char(56),char(56),char(55), -char(55),char(0),char(0),char(2),char(255),char(145),char(254),char(20),char(1),char(102), -char(5),char(223),char(0),char(12),char(0),char(24),char(0),char(44),char(64),char(22), -char(19),char(11),char(11),char(13),char(8),char(8),char(25),char(26),char(22),char(16), -char(72),char(89),char(22),char(64),char(9),char(15),char(0),char(5),char(70),char(89), -char(0),char(27),char(0),char(63),char(43),char(0),char(24),char(63),char(26),char(206), -char(43),char(17),char(18),char(1),char(57),char(17),char(51),char(51),char(17),char(51), -char(49),char(48),char(19),char(34),char(39),char(53),char(22),char(51),char(50),char(54), -char(53),char(17),char(51),char(17),char(16),char(3),char(52),char(54),char(51),char(50), -char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(43),char(95),char(59), -char(69),char(67),char(78),char(73),char(166),char(180),char(56),char(42),char(40),char(58), -char(58),char(40),char(42),char(56),char(254),char(20),char(25),char(135),char(20),char(85), -char(87),char(4),char(252),char(251),char(16),char(254),char(188),char(7),char(93),char(57), -char(53),char(54),char(56),char(56),char(55),char(55),char(0),char(1),char(0),char(176), -char(0),char(0),char(4),char(29),char(6),char(20),char(0),char(16),char(0),char(54), -char(64),char(27),char(16),char(14),char(10),char(10),char(11),char(11),char(8),char(6), -char(4),char(5),char(8),char(4),char(17),char(18),char(12),char(0),char(0),char(16), -char(16),char(8),char(8),char(3),char(7),char(11),char(21),char(3),char(15),char(0), -char(63),char(63),char(51),char(18),char(57),char(47),char(57),char(17),char(51),char(63), -char(17),char(18),char(1),char(23),char(57),char(17),char(57),char(17),char(51),char(17), -char(51),char(51),char(49),char(48),char(1),char(54),char(55),char(1),char(51),char(1), -char(1),char(35),char(1),char(7),char(17),char(35),char(17),char(51),char(17),char(20), -char(7),char(1),char(84),char(43),char(88),char(1),char(98),char(197),char(254),char(68), -char(1),char(219),char(201),char(254),char(125),char(125),char(164),char(164),char(8),char(2), -char(49),char(61),char(99),char(1),char(119),char(254),char(45),char(253),char(139),char(2), -char(6),char(108),char(254),char(102),char(6),char(20),char(252),char(199),char(55),char(115), -char(0),char(1),char(0),char(176),char(0),char(0),char(1),char(86),char(6),char(20), -char(0),char(3),char(0),char(22),char(64),char(9),char(0),char(1),char(1),char(4), -char(5),char(2),char(0),char(1),char(21),char(0),char(63),char(63),char(17),char(18), -char(1),char(57),char(17),char(51),char(49),char(48),char(33),char(35),char(17),char(51), -char(1),char(86),char(166),char(166),char(6),char(20),char(0),char(1),char(0),char(176), -char(0),char(0),char(6),char(203),char(4),char(92),char(0),char(35),char(0),char(70), -char(64),char(35),char(21),char(17),char(17),char(18),char(8),char(9),char(0),char(35), -char(9),char(18),char(35),char(3),char(36),char(37),char(28),char(22),char(21),char(21), -char(18),char(25),char(4),char(13),char(25),char(13),char(70),char(89),char(31),char(25), -char(16),char(19),char(15),char(9),char(0),char(18),char(21),char(0),char(63),char(51), -char(51),char(63),char(63),char(51),char(43),char(17),char(0),char(51),char(17),char(18), -char(57),char(24),char(47),char(51),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(33),char(17),char(52),char(38),char(35),char(34),char(6),char(21),char(17),char(35), -char(17),char(52),char(38),char(35),char(34),char(6),char(21),char(17),char(35),char(17), -char(51),char(23),char(51),char(54),char(54),char(51),char(32),char(23),char(51),char(54), -char(54),char(51),char(50),char(22),char(21),char(17),char(6),char(37),char(112),char(118), -char(155),char(148),char(166),char(112),char(119),char(156),char(145),char(166),char(135),char(27), -char(8),char(47),char(171),char(106),char(1),char(1),char(79),char(8),char(49),char(186), -char(119),char(186),char(185),char(2),char(201),char(131),char(131),char(178),char(185),char(253), -char(156),char(2),char(201),char(131),char(131),char(187),char(213),char(253),char(193),char(4), -char(72),char(150),char(80),char(90),char(186),char(86),char(100),char(191),char(210),char(253), -char(53),char(0),char(0),char(1),char(0),char(176),char(0),char(0),char(4),char(68), -char(4),char(92),char(0),char(20),char(0),char(49),char(64),char(24),char(0),char(20), -char(12),char(8),char(8),char(9),char(20),char(9),char(22),char(21),char(12),char(9), -char(16),char(16),char(4),char(70),char(89),char(16),char(16),char(10),char(15),char(0), -char(9),char(21),char(0),char(63),char(51),char(63),char(63),char(43),char(17),char(18), -char(0),char(57),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(33),char(17),char(52),char(38),char(35), -char(34),char(6),char(21),char(17),char(35),char(17),char(51),char(23),char(51),char(54), -char(54),char(51),char(50),char(22),char(21),char(17),char(3),char(158),char(122),char(130), -char(172),char(160),char(166),char(135),char(27),char(8),char(51),char(184),char(113),char(198), -char(200),char(2),char(197),char(134),char(132),char(186),char(214),char(253),char(193),char(4), -char(72),char(150),char(81),char(89),char(191),char(210),char(253),char(53),char(0),char(2), -char(0),char(115),char(255),char(236),char(4),char(98),char(4),char(92),char(0),char(12), -char(0),char(24),char(0),char(40),char(64),char(20),char(19),char(0),char(13),char(7), -char(0),char(7),char(26),char(25),char(10),char(22),char(70),char(89),char(10),char(16), -char(3),char(16),char(70),char(89),char(3),char(22),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(35),char(34),char(38), -char(2),char(53),char(16),char(0),char(51),char(50),char(0),char(1),char(20),char(22), -char(51),char(50),char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(4), -char(98),char(254),char(242),char(238),char(147),char(228),char(124),char(1),char(12),char(238), -char(230),char(1),char(15),char(252),char(189),char(168),char(163),char(163),char(169),char(169), -char(165),char(163),char(166),char(2),char(37),char(254),char(244),char(254),char(211),char(138), -char(1),char(2),char(173),char(1),char(12),char(1),char(43),char(254),char(206),char(254), -char(251),char(210),char(220),char(219),char(211),char(209),char(217),char(214),char(0),char(2), -char(0),char(176),char(254),char(20),char(4),char(117),char(4),char(92),char(0),char(20), -char(0),char(33),char(0),char(63),char(64),char(32),char(25),char(11),char(4),char(7), -char(7),char(8),char(31),char(18),char(8),char(18),char(34),char(35),char(4),char(11), -char(0),char(15),char(15),char(21),char(70),char(89),char(15),char(16),char(9),char(15), -char(8),char(27),char(0),char(28),char(70),char(89),char(0),char(22),char(0),char(63), -char(43),char(0),char(24),char(63),char(63),char(63),char(43),char(17),char(18),char(0), -char(57),char(57),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(51),char(51),char(49),char(48),char(5),char(34),char(38), -char(39),char(35),char(22),char(21),char(17),char(35),char(17),char(51),char(23),char(51), -char(54),char(54),char(51),char(50),char(18),char(17),char(16),char(2),char(3),char(34), -char(6),char(7),char(21),char(20),char(22),char(51),char(50),char(54),char(53),char(52), -char(38),char(2),char(174),char(107),char(177),char(60),char(12),char(12),char(166),char(135), -char(23),char(8),char(64),char(170),char(110),char(218),char(237),char(241),char(238),char(168), -char(150),char(2),char(154),char(170),char(142),char(161),char(161),char(20),char(79),char(82), -char(96),char(86),char(254),char(61),char(6),char(52),char(150),char(90),char(80),char(254), -char(214),char(254),char(243),char(254),char(242),char(254),char(213),char(3),char(227),char(186), -char(203),char(37),char(231),char(199),char(230),char(202),char(205),char(219),char(0),char(2), -char(0),char(115),char(254),char(20),char(4),char(55),char(4),char(92),char(0),char(12), -char(0),char(31),char(0),char(68),char(64),char(34),char(10),char(16),char(29),char(22), -char(3),char(26),char(26),char(25),char(16),char(25),char(32),char(33),char(26),char(27), -char(23),char(15),char(29),char(30),char(30),char(22),char(13),char(19),char(19),char(7), -char(70),char(89),char(19),char(16),char(13),char(0),char(70),char(89),char(13),char(22), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0), -char(57),char(57),char(17),char(51),char(24),char(63),char(63),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(51),char(51),char(17),char(51), -char(49),char(48),char(37),char(50),char(54),char(55),char(53),char(52),char(38),char(35), -char(34),char(6),char(21),char(20),char(22),char(23),char(34),char(2),char(17),char(16), -char(18),char(51),char(50),char(23),char(51),char(55),char(51),char(17),char(35),char(17), -char(52),char(55),char(35),char(6),char(2),char(78),char(166),char(152),char(5),char(156), -char(169),char(146),char(155),char(153),char(125),char(212),char(238),char(240),char(214),char(225), -char(121),char(9),char(24),char(131),char(166),char(11),char(13),char(115),char(119),char(178), -char(211),char(37),char(230),char(202),char(227),char(207),char(207),char(217),char(139),char(1), -char(42),char(1),char(11),char(1),char(13),char(1),char(46),char(170),char(150),char(249), -char(204),char(1),char(213),char(100),char(70),char(167),char(0),char(1),char(0),char(176), -char(0),char(0),char(3),char(39),char(4),char(92),char(0),char(16),char(0),char(42), -char(64),char(20),char(13),char(9),char(9),char(10),char(10),char(2),char(17),char(18), -char(11),char(15),char(13),char(0),char(10),char(21),char(0),char(5),char(70),char(89), -char(0),char(16),char(0),char(63),char(43),char(0),char(24),char(63),char(18),char(57), -char(63),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(50),char(23),char(7),char(38),char(35),char(34),char(6), -char(21),char(17),char(35),char(17),char(51),char(23),char(51),char(54),char(54),char(2), -char(164),char(73),char(58),char(23),char(68),char(52),char(133),char(189),char(166),char(137), -char(19),char(8),char(61),char(172),char(4),char(92),char(12),char(154),char(15),char(216), -char(161),char(253),char(180),char(4),char(72),char(203),char(107),char(116),char(0),char(1), -char(0),char(106),char(255),char(236),char(3),char(115),char(4),char(92),char(0),char(36), -char(0),char(54),char(64),char(28),char(30),char(19),char(12),char(0),char(0),char(24), -char(5),char(19),char(4),char(37),char(38),char(12),char(30),char(3),char(22),char(22), -char(27),char(70),char(89),char(22),char(16),char(6),char(3),char(9),char(70),char(89), -char(3),char(22),char(0),char(63),char(43),char(0),char(24),char(47),char(63),char(43), -char(17),char(18),char(0),char(57),char(57),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(6),char(35), -char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53),char(52), -char(38),char(39),char(46),char(2),char(53),char(52),char(54),char(51),char(50),char(23), -char(7),char(38),char(35),char(34),char(6),char(21),char(20),char(22),char(22),char(23), -char(22),char(22),char(3),char(115),char(228),char(206),char(218),char(122),char(79),char(181), -char(84),char(130),char(140),char(111),char(161),char(153),char(129),char(63),char(218),char(190), -char(177),char(169),char(59),char(165),char(134),char(118),char(120),char(45),char(100),char(142), -char(195),char(137),char(1),char(43),char(153),char(166),char(69),char(154),char(40),char(46), -char(83),char(85),char(64),char(91),char(62),char(57),char(85),char(108),char(75),char(134), -char(155),char(72),char(135),char(68),char(74),char(65),char(44),char(62),char(56),char(53), -char(71),char(144),char(0),char(1),char(0),char(31),char(255),char(236),char(2),char(168), -char(5),char(70),char(0),char(22),char(0),char(52),char(64),char(27),char(16),char(20), -char(20),char(9),char(11),char(9),char(18),char(3),char(4),char(24),char(23),char(10), -char(19),char(16),char(19),char(71),char(89),char(14),char(64),char(16),char(15),char(7), -char(0),char(70),char(89),char(7),char(22),char(0),char(63),char(43),char(0),char(24), -char(63),char(26),char(205),char(43),char(17),char(0),char(51),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(50), -char(54),char(55),char(21),char(6),char(6),char(35),char(32),char(17),char(17),char(35), -char(53),char(55),char(55),char(51),char(21),char(33),char(21),char(33),char(17),char(20), -char(22),char(2),char(18),char(44),char(82),char(24),char(27),char(105),char(42),char(254), -char(194),char(157),char(157),char(70),char(96),char(1),char(62),char(254),char(194),char(94), -char(117),char(13),char(7),char(127),char(13),char(17),char(1),char(79),char(2),char(140), -char(80),char(69),char(234),char(254),char(129),char(253),char(123),char(99),char(106),char(0), -char(0),char(1),char(0),char(164),char(255),char(236),char(4),char(57),char(4),char(72), -char(0),char(20),char(0),char(52),char(64),char(25),char(1),char(19),char(7),char(12), -char(12),char(10),char(19),char(10),char(21),char(22),char(12),char(13),char(13),char(16), -char(8),char(20),char(15),char(16),char(4),char(70),char(89),char(16),char(22),char(11), -char(21),char(0),char(63),char(63),char(43),char(0),char(24),char(63),char(51),char(18), -char(57),char(17),char(51),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(20),char(22), -char(51),char(50),char(54),char(53),char(17),char(51),char(17),char(35),char(39),char(35), -char(6),char(6),char(35),char(34),char(38),char(53),char(17),char(1),char(76),char(122), -char(130),char(172),char(159),char(166),char(137),char(24),char(9),char(51),char(181),char(116), -char(200),char(199),char(4),char(72),char(253),char(57),char(134),char(132),char(188),char(213), -char(2),char(64),char(251),char(184),char(147),char(81),char(86),char(190),char(209),char(2), -char(205),char(0),char(0),char(1),char(0),char(0),char(0),char(0),char(4),char(2), -char(4),char(72),char(0),char(11),char(0),char(24),char(64),char(10),char(1),char(10), -char(12),char(13),char(5),char(9),char(1),char(15),char(0),char(21),char(0),char(63), -char(63),char(51),char(57),char(17),char(18),char(1),char(57),char(57),char(49),char(48), -char(33),char(1),char(51),char(19),char(22),char(23),char(51),char(54),char(18),char(19), -char(51),char(1),char(1),char(160),char(254),char(96),char(178),char(236),char(80),char(14), -char(8),char(11),char(117),char(204),char(178),char(254),char(96),char(4),char(72),char(253), -char(118),char(228),char(68),char(53),char(1),char(77),char(2),char(48),char(251),char(184), -char(0),char(1),char(0),char(23),char(0),char(0),char(6),char(35),char(4),char(72), -char(0),char(28),char(0),char(44),char(64),char(20),char(9),char(27),char(29),char(30), -char(23),char(22),char(14),char(13),char(3),char(4),char(13),char(4),char(8),char(26), -char(18),char(9),char(15),char(0),char(8),char(21),char(0),char(63),char(51),char(63), -char(51),char(51),char(18),char(57),char(57),char(17),char(51),char(17),char(51),char(51), -char(51),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(33),char(3), -char(38),char(39),char(35),char(6),char(7),char(3),char(35),char(1),char(51),char(18), -char(18),char(23),char(51),char(54),char(54),char(55),char(19),char(51),char(19),char(22), -char(23),char(51),char(54),char(54),char(19),char(51),char(1),char(4),char(47),char(201), -char(19),char(52),char(8),char(40),char(30),char(207),char(192),char(254),char(213),char(174), -char(106),char(111),char(8),char(8),char(11),char(49),char(18),char(201),char(180),char(196), -char(56),char(20),char(8),char(4),char(35),char(191),char(172),char(254),char(209),char(2), -char(131),char(59),char(209),char(175),char(95),char(253),char(127),char(4),char(72),char(254), -char(99),char(254),char(80),char(75),char(57),char(181),char(53),char(2),char(117),char(253), -char(139),char(172),char(117),char(36),char(150),char(2),char(220),char(251),char(184),char(0), -char(0),char(1),char(0),char(39),char(0),char(0),char(4),char(8),char(4),char(72), -char(0),char(11),char(0),char(34),char(64),char(17),char(7),char(5),char(6),char(0), -char(1),char(5),char(12),char(13),char(9),char(3),char(1),char(8),char(11),char(21), -char(4),char(1),char(15),char(0),char(63),char(51),char(63),char(51),char(18),char(57), -char(57),char(17),char(18),char(1),char(23),char(57),char(49),char(48),char(1),char(1), -char(51),char(1),char(1),char(51),char(1),char(1),char(35),char(1),char(1),char(35), -char(1),char(184),char(254),char(131),char(189),char(1),char(33),char(1),char(32),char(187), -char(254),char(131),char(1),char(145),char(188),char(254),char(205),char(254),char(202),char(188), -char(2),char(49),char(2),char(23),char(254),char(92),char(1),char(164),char(253),char(233), -char(253),char(207),char(1),char(188),char(254),char(68),char(0),char(1),char(0),char(2), -char(254),char(20),char(4),char(6),char(4),char(72),char(0),char(21),char(0),char(36), -char(64),char(18),char(9),char(15),char(0),char(3),char(22),char(23),char(4),char(13), -char(0),char(13),char(18),char(70),char(89),char(13),char(27),char(8),char(0),char(15), -char(0),char(63),char(50),char(63),char(43),char(17),char(18),char(0),char(57),char(17), -char(18),char(1),char(23),char(57),char(49),char(48),char(19),char(51),char(19),char(22), -char(23),char(51),char(54),char(54),char(19),char(51),char(1),char(6),char(6),char(35), -char(34),char(39),char(53),char(22),char(51),char(50),char(55),char(55),char(2),char(178), -char(240),char(79),char(19),char(8),char(13),char(83),char(230),char(178),char(254),char(41), -char(70),char(187),char(136),char(76),char(74),char(55),char(68),char(171),char(73),char(61), -char(4),char(72),char(253),char(143),char(214),char(95),char(51),char(247),char(2),char(124), -char(251),char(32),char(185),char(155),char(17),char(133),char(12),char(192),char(156),char(0), -char(0),char(1),char(0),char(82),char(0),char(0),char(3),char(109),char(4),char(72), -char(0),char(9),char(0),char(43),char(64),char(23),char(8),char(1),char(3),char(7), -char(0),char(7),char(4),char(1),char(4),char(10),char(11),char(5),char(4),char(71), -char(89),char(5),char(15),char(1),char(8),char(71),char(89),char(1),char(21),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(53), -char(1),char(33),char(53),char(33),char(21),char(1),char(33),char(3),char(109),char(252), -char(229),char(2),char(86),char(253),char(207),char(2),char(231),char(253),char(178),char(2), -char(93),char(113),char(3),char(86),char(129),char(129),char(252),char(186),char(0),char(1), -char(0),char(61),char(254),char(188),char(2),char(193),char(5),char(182),char(0),char(28), -char(0),char(44),char(64),char(21),char(25),char(26),char(26),char(11),char(23),char(0), -char(0),char(15),char(7),char(20),char(3),char(3),char(7),char(11),char(3),char(29), -char(30),char(19),char(3),char(4),char(39),char(0),char(63),char(63),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(20),char(22),char(23), -char(21),char(38),char(38),char(53),char(17),char(52),char(38),char(35),char(53),char(54), -char(54),char(53),char(17),char(52),char(54),char(51),char(21),char(6),char(21),char(17), -char(20),char(7),char(21),char(22),char(21),char(1),char(219),char(117),char(113),char(190), -char(208),char(126),char(120),char(130),char(116),char(216),char(182),char(230),char(223),char(223), -char(12),char(102),char(92),char(2),char(140),char(2),char(170),char(154),char(1),char(47), -char(104),char(89),char(141),char(2),char(92),char(96),char(1),char(50),char(155),char(172), -char(139),char(6),char(193),char(254),char(217),char(215),char(39),char(12),char(39),char(215), -char(0),char(1),char(1),char(238),char(254),char(16),char(2),char(123),char(6),char(20), -char(0),char(3),char(0),char(22),char(64),char(9),char(2),char(3),char(3),char(4), -char(5),char(3),char(27),char(0),char(0),char(0),char(63),char(63),char(17),char(18), -char(1),char(57),char(17),char(51),char(49),char(48),char(1),char(51),char(17),char(35), -char(1),char(238),char(141),char(141),char(6),char(20),char(247),char(252),char(0),char(1), -char(0),char(72),char(254),char(188),char(2),char(203),char(5),char(182),char(0),char(29), -char(0),char(44),char(64),char(21),char(21),char(5),char(10),char(18),char(18),char(2), -char(25),char(0),char(29),char(29),char(14),char(14),char(25),char(5),char(3),char(30), -char(31),char(21),char(39),char(6),char(3),char(0),char(63),char(63),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(38),char(53),char(17), -char(52),char(39),char(53),char(50),char(22),char(21),char(17),char(20),char(22),char(23), -char(21),char(34),char(6),char(21),char(17),char(20),char(6),char(7),char(53),char(54), -char(54),char(53),char(17),char(52),char(54),char(55),char(2),char(10),char(223),char(227), -char(184),char(211),char(118),char(130),char(122),char(126),char(205),char(190),char(111),char(116), -char(110),char(113),char(2),char(63),char(39),char(215),char(1),char(39),char(193),char(6), -char(139),char(174),char(153),char(254),char(206),char(97),char(91),char(2),char(141),char(89), -char(104),char(254),char(209),char(153),char(171),char(2),char(140),char(2),char(92),char(102), -char(1),char(41),char(114),char(120),char(20),char(0),char(0),char(1),char(0),char(104), -char(2),char(80),char(4),char(41),char(3),char(84),char(0),char(23),char(0),char(36), -char(64),char(17),char(3),char(15),char(24),char(25),char(18),char(12),char(80),char(89), -char(3),char(18),char(15),char(6),char(6),char(0),char(80),char(89),char(6),char(0), -char(47),char(43),char(0),char(16),char(24),char(196),char(47),char(196),char(43),char(17), -char(18),char(1),char(57),char(57),char(49),char(48),char(1),char(34),char(6),char(7), -char(53),char(54),char(51),char(50),char(22),char(23),char(22),char(22),char(51),char(50), -char(54),char(55),char(21),char(6),char(35),char(34),char(38),char(39),char(38),char(38), -char(1),char(82),char(53),char(127),char(54),char(100),char(144),char(68),char(113),char(89), -char(66),char(98),char(47),char(54),char(128),char(54),char(102),char(142),char(72),char(126), -char(72),char(75),char(90),char(2),char(201),char(67),char(54),char(151),char(109),char(28), -char(38),char(28),char(27),char(64),char(57),char(150),char(110),char(33),char(32),char(32), -char(24),char(0),char(0),char(2),char(0),char(152),char(254),char(139),char(1),char(137), -char(4),char(94),char(0),char(3),char(0),char(14),char(0),char(43),char(64),char(20), -char(2),char(4),char(4),char(3),char(9),char(9),char(15),char(16),char(0),char(0), -char(3),char(12),char(12),char(6),char(79),char(89),char(12),char(16),char(3),char(34), -char(0),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(17),char(18),char(1),char(57),char(17),char(51),char(51),char(17),char(51),char(49), -char(48),char(19),char(51),char(19),char(35),char(19),char(20),char(35),char(34),char(38), -char(53),char(52),char(54),char(51),char(50),char(22),char(219),char(105),char(51),char(207), -char(225),char(121),char(60),char(60),char(63),char(57),char(51),char(70),char(2),char(172), -char(251),char(223),char(5),char(76),char(135),char(71),char(64),char(63),char(72),char(64), -char(0),char(1),char(0),char(190),char(255),char(236),char(3),char(219),char(5),char(203), -char(0),char(27),char(0),char(62),char(64),char(30),char(22),char(8),char(13),char(3), -char(3),char(10),char(4),char(0),char(16),char(16),char(4),char(8),char(3),char(28), -char(29),char(25),char(5),char(2),char(19),char(10),char(13),char(2),char(13),char(2), -char(13),char(4),char(11),char(7),char(4),char(25),char(0),char(63),char(63),char(18), -char(57),char(57),char(47),char(47),char(17),char(51),char(51),char(17),char(51),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(6),char(7),char(21), -char(35),char(53),char(38),char(2),char(53),char(16),char(37),char(53),char(51),char(21), -char(22),char(22),char(23),char(7),char(38),char(35),char(34),char(6),char(21),char(20), -char(22),char(51),char(50),char(55),char(3),char(203),char(105),char(147),char(133),char(203), -char(193),char(1),char(140),char(135),char(75),char(142),char(49),char(49),char(133),char(109), -char(172),char(162),char(159),char(167),char(141),char(142),char(240),char(54),char(6),char(200), -char(206),char(32),char(1),char(17),char(250),char(1),char(252),char(62),char(172),char(164), -char(3),char(33),char(23),char(140),char(51),char(211),char(217),char(212),char(203),char(59), -char(0),char(1),char(0),char(63),char(0),char(0),char(4),char(68),char(5),char(201), -char(0),char(29),char(0),char(72),char(64),char(38),char(24),char(19),char(9),char(13), -char(13),char(26),char(22),char(17),char(2),char(11),char(22),char(19),char(5),char(30), -char(31),char(12),char(24),char(25),char(24),char(78),char(89),char(9),char(25),char(25), -char(19),char(0),char(19),char(16),char(76),char(89),char(19),char(24),char(0),char(5), -char(75),char(89),char(0),char(7),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(51),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(50),char(23),char(7), -char(38),char(35),char(34),char(6),char(21),char(17),char(33),char(21),char(33),char(21), -char(20),char(6),char(7),char(33),char(21),char(33),char(53),char(54),char(53),char(53), -char(35),char(53),char(51),char(17),char(52),char(54),char(2),char(170),char(190),char(170), -char(61),char(154),char(143),char(123),char(125),char(1),char(166),char(254),char(90),char(65), -char(74),char(3),char(27),char(251),char(251),char(205),char(198),char(198),char(224),char(5), -char(201),char(84),char(133),char(77),char(124),char(140),char(254),char(217),char(127),char(221), -char(100),char(136),char(44),char(154),char(141),char(47),char(244),char(223),char(127),char(1), -char(60),char(178),char(205),char(0),char(0),char(2),char(0),char(123),char(1),char(6), -char(4),char(23),char(4),char(160),char(0),char(27),char(0),char(39),char(0),char(32), -char(64),char(13),char(28),char(0),char(34),char(14),char(0),char(14),char(40),char(41), -char(31),char(21),char(21),char(37),char(7),char(0),char(47),char(51),char(51),char(47), -char(51),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(19),char(52),char(55),char(39),char(55),char(23),char(54),char(51), -char(50),char(23),char(55),char(23),char(7),char(22),char(21),char(20),char(7),char(23), -char(7),char(39),char(6),char(35),char(34),char(39),char(7),char(39),char(55),char(38), -char(55),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(34),char(6),char(184),char(74),char(135),char(94),char(135),char(104),char(130),char(127), -char(102),char(137),char(95),char(134),char(74),char(74),char(131),char(92),char(137),char(102), -char(127),char(134),char(100),char(135),char(92),char(133),char(74),char(129),char(157),char(116), -char(116),char(158),char(160),char(114),char(116),char(157),char(2),char(211),char(122),char(107), -char(140),char(92),char(133),char(73),char(73),char(133),char(92),char(138),char(113),char(118), -char(131),char(103),char(135),char(92),char(133),char(71),char(73),char(133),char(92),char(136), -char(107),char(124),char(112),char(160),char(159),char(113),char(114),char(162),char(164),char(0), -char(0),char(1),char(0),char(31),char(0),char(0),char(4),char(113),char(5),char(182), -char(0),char(22),char(0),char(86),char(64),char(46),char(18),char(14),char(7),char(11), -char(11),char(16),char(12),char(5),char(9),char(2),char(9),char(3),char(12),char(20), -char(14),char(21),char(7),char(23),char(24),char(10),char(14),char(14),char(7),char(15), -char(6),char(18),char(18),char(3),char(0),char(19),char(21),char(15),char(19),char(31), -char(19),char(2),char(15),char(19),char(15),char(19),char(12),char(1),char(21),char(6), -char(12),char(24),char(0),char(63),char(63),char(51),char(18),char(57),char(57),char(47), -char(47),char(93),char(17),char(18),char(57),char(50),char(50),char(17),char(51),char(17), -char(51),char(51),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(1),char(51),char(1),char(33),char(21),char(33),char(21),char(33),char(21), -char(33),char(17),char(35),char(17),char(33),char(53),char(33),char(53),char(33),char(53), -char(33),char(1),char(51),char(2),char(72),char(1),char(123),char(174),char(254),char(96), -char(1),char(6),char(254),char(195),char(1),char(61),char(254),char(195),char(164),char(254), -char(196),char(1),char(60),char(254),char(196),char(1),char(0),char(254),char(101),char(178), -char(2),char(223),char(2),char(215),char(252),char(254),char(127),char(170),char(127),char(254), -char(244),char(1),char(12),char(127),char(170),char(127),char(3),char(2),char(0),char(2), -char(1),char(238),char(254),char(16),char(2),char(123),char(6),char(20),char(0),char(3), -char(0),char(7),char(0),char(36),char(64),char(16),char(2),char(6),char(6),char(3), -char(7),char(7),char(8),char(9),char(4),char(3),char(4),char(3),char(7),char(27), -char(0),char(0),char(0),char(63),char(63),char(57),char(57),char(47),char(47),char(17), -char(18),char(1),char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48), -char(1),char(51),char(17),char(35),char(17),char(51),char(17),char(35),char(1),char(238), -char(141),char(141),char(141),char(141),char(6),char(20),char(252),char(248),char(254),char(13), -char(252),char(247),char(0),char(2),char(0),char(123),char(255),char(248),char(3),char(150), -char(6),char(29),char(0),char(49),char(0),char(61),char(0),char(67),char(64),char(38), -char(50),char(0),char(19),char(6),char(42),char(30),char(56),char(25),char(25),char(30), -char(12),char(6),char(0),char(35),char(6),char(62),char(63),char(21),char(3),char(59), -char(54),char(28),char(45),char(6),char(33),char(9),char(33),char(39),char(71),char(89), -char(33),char(21),char(9),char(16),char(71),char(89),char(9),char(0),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(23),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(19),char(52),char(54),char(55),char(38), -char(38),char(53),char(52),char(54),char(51),char(50),char(22),char(23),char(7),char(38), -char(38),char(35),char(34),char(6),char(21),char(20),char(22),char(23),char(22),char(22), -char(21),char(20),char(6),char(7),char(22),char(21),char(20),char(6),char(35),char(34), -char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53),char(52),char(38), -char(38),char(39),char(46),char(2),char(55),char(20),char(22),char(23),char(23),char(54), -char(53),char(52),char(38),char(39),char(6),char(6),char(139),char(86),char(78),char(74), -char(84),char(207),char(197),char(94),char(159),char(97),char(53),char(98),char(135),char(76), -char(116),char(116),char(123),char(154),char(186),char(150),char(82),char(74),char(153),char(234), -char(212),char(218),char(128),char(78),char(194),char(82),char(134),char(141),char(48),char(108), -char(115),char(142),char(134),char(66),char(146),char(132),char(167),char(49),char(137),char(147), -char(185),char(68),char(85),char(3),char(41),char(86),char(137),char(37),char(40),char(111), -char(85),char(121),char(139),char(29),char(39),char(131),char(39),char(27),char(59),char(64), -char(60),char(84),char(55),char(68),char(151),char(107),char(90),char(141),char(41),char(81), -char(146),char(140),char(153),char(65),char(148),char(37),char(45),char(76),char(71),char(46), -char(58),char(58),char(43),char(52),char(90),char(114),char(98),char(77),char(105),char(61), -char(19),char(80),char(111),char(83),char(112),char(57),char(19),char(100),char(0),char(2), -char(1),char(53),char(5),char(14),char(3),char(104),char(5),char(211),char(0),char(11), -char(0),char(23),char(0),char(30),char(64),char(12),char(6),char(0),char(12),char(18), -char(0),char(18),char(24),char(25),char(15),char(3),char(21),char(9),char(0),char(47), -char(51),char(205),char(50),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(52),char(54),char(51),char(50),char(22), -char(21),char(20),char(6),char(35),char(34),char(38),char(37),char(52),char(54),char(51), -char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(1),char(53), -char(53),char(37),char(38),char(55),char(55),char(38),char(37),char(53),char(1),char(125), -char(53),char(37),char(37),char(55),char(55),char(37),char(37),char(53),char(5),char(113), -char(52),char(46),char(46),char(52),char(50),char(49),char(49),char(50),char(52),char(46), -char(46),char(52),char(50),char(49),char(49),char(0),char(0),char(3),char(0),char(100), -char(255),char(236),char(6),char(68),char(5),char(203),char(0),char(22),char(0),char(38), -char(0),char(54),char(0),char(70),char(64),char(39),char(39),char(23),char(3),char(15), -char(47),char(31),char(31),char(20),char(9),char(15),char(23),char(5),char(55),char(56), -char(6),char(12),char(0),char(18),char(15),char(12),char(31),char(12),char(2),char(0), -char(18),char(16),char(18),char(2),char(12),char(18),char(12),char(18),char(27),char(43), -char(35),char(19),char(51),char(27),char(4),char(0),char(63),char(51),char(63),char(51), -char(18),char(57),char(57),char(47),char(47),char(93),char(93),char(17),char(51),char(17), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(34),char(6),char(21),char(20),char(22), -char(51),char(50),char(55),char(21),char(6),char(6),char(35),char(34),char(38),char(53), -char(52),char(54),char(51),char(50),char(23),char(7),char(38),char(1),char(52),char(18), -char(36),char(51),char(50),char(4),char(18),char(21),char(20),char(2),char(4),char(35), -char(34),char(36),char(2),char(55),char(20),char(18),char(4),char(51),char(50),char(36), -char(18),char(53),char(52),char(2),char(36),char(35),char(34),char(4),char(2),char(3), -char(125),char(125),char(135),char(127),char(131),char(86),char(125),char(48),char(101),char(70), -char(194),char(208),char(221),char(191),char(128),char(118),char(58),char(108),char(252),char(151), -char(200),char(1),char(94),char(202),char(200),char(1),char(94),char(202),char(194),char(254), -char(162),char(208),char(207),char(254),char(162),char(195),char(105),char(174),char(1),char(45), -char(172),char(174),char(1),char(42),char(175),char(174),char(254),char(215),char(176),char(174), -char(254),char(214),char(175),char(4),char(35),char(174),char(154),char(168),char(162),char(45), -char(124),char(20),char(28),char(241),char(216),char(209),char(246),char(60),char(118),char(51), -char(254),char(184),char(200),char(1),char(94),char(202),char(200),char(254),char(162),char(202), -char(197),char(254),char(166),char(208),char(207),char(1),char(90),char(198),char(173),char(254), -char(211),char(173),char(174),char(1),char(41),char(176),char(174),char(1),char(42),char(175), -char(174),char(254),char(215),char(0),char(0),char(2),char(0),char(70),char(3),char(20), -char(2),char(113),char(5),char(199),char(0),char(22),char(0),char(31),char(0),char(55), -char(64),char(28),char(23),char(6),char(27),char(10),char(1),char(1),char(22),char(22), -char(16),char(6),char(3),char(32),char(33),char(28),char(10),char(10),char(18),char(25), -char(22),char(0),char(3),char(16),char(3),char(2),char(3),char(13),char(18),char(31), -char(0),char(63),char(51),char(212),char(93),char(196),char(51),char(18),char(57),char(47), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(49),char(48),char(1),char(39),char(6),char(35),char(34), -char(38),char(53),char(52),char(54),char(55),char(55),char(53),char(52),char(35),char(34), -char(7),char(39),char(54),char(51),char(50),char(22),char(21),char(17),char(37),char(20), -char(51),char(50),char(53),char(53),char(7),char(6),char(6),char(2),char(20),char(24), -char(92),char(140),char(95),char(111),char(154),char(165),char(117),char(148),char(100),char(104), -char(43),char(114),char(133),char(130),char(137),char(254),char(80),char(112),char(201),char(98), -char(112),char(103),char(3),char(33),char(84),char(97),char(99),char(102),char(102),char(105), -char(6),char(4),char(39),char(133),char(51),char(96),char(56),char(105),char(121),char(254), -char(60),char(188),char(100),char(180),char(49),char(4),char(4),char(57),char(0),char(2), -char(0),char(82),char(0),char(117),char(3),char(170),char(3),char(190),char(0),char(6), -char(0),char(13),char(0),char(41),char(64),char(19),char(3),char(6),char(10),char(13), -char(2),char(4),char(11),char(9),char(9),char(4),char(13),char(6),char(4),char(14), -char(15),char(12),char(5),char(8),char(1),char(0),char(47),char(51),char(47),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(19),char(1),char(23),char(1),char(1), -char(7),char(1),char(37),char(1),char(23),char(1),char(1),char(7),char(1),char(82), -char(1),char(86),char(119),char(254),char(223),char(1),char(33),char(119),char(254),char(170), -char(1),char(139),char(1),char(88),char(117),char(254),char(225),char(1),char(31),char(117), -char(254),char(168),char(2),char(39),char(1),char(151),char(69),char(254),char(162),char(254), -char(161),char(71),char(1),char(151),char(27),char(1),char(151),char(69),char(254),char(162), -char(254),char(161),char(71),char(1),char(151),char(0),char(0),char(1),char(0),char(104), -char(1),char(8),char(4),char(41),char(3),char(23),char(0),char(5),char(0),char(27), -char(64),char(12),char(2),char(1),char(4),char(1),char(6),char(7),char(5),char(4), -char(80),char(89),char(5),char(2),char(0),char(47),char(47),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(49),char(48),char(1),char(17),char(35), -char(17),char(33),char(53),char(4),char(41),char(137),char(252),char(200),char(3),char(23), -char(253),char(241),char(1),char(133),char(138),char(0),char(255),char(255),char(0),char(84), -char(1),char(217),char(2),char(63),char(2),char(113),char(2),char(6),char(0),char(16), -char(0),char(0),char(0),char(4),char(0),char(100),char(255),char(236),char(6),char(68), -char(5),char(203),char(0),char(8),char(0),char(22),char(0),char(38),char(0),char(54), -char(0),char(93),char(64),char(51),char(39),char(23),char(0),char(17),char(17),char(18), -char(4),char(9),char(47),char(31),char(31),char(13),char(9),char(12),char(18),char(23), -char(6),char(55),char(56),char(12),char(16),char(16),char(0),char(0),char(14),char(19), -char(14),char(18),char(8),char(19),char(15),char(18),char(31),char(18),char(2),char(0), -char(19),char(16),char(19),char(2),char(18),char(19),char(18),char(19),char(27),char(43), -char(35),char(19),char(51),char(27),char(4),char(0),char(63),char(51),char(63),char(51), -char(18),char(57),char(57),char(47),char(47),char(93),char(93),char(17),char(51),char(17), -char(51),char(17),char(18),char(57),char(47),char(51),char(17),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(35),char(5),char(20),char(6),char(7),char(19),char(35), -char(3),char(35),char(17),char(35),char(17),char(33),char(50),char(22),char(1),char(52), -char(18),char(36),char(51),char(50),char(4),char(18),char(21),char(20),char(2),char(4), -char(35),char(34),char(36),char(2),char(55),char(20),char(18),char(4),char(51),char(50), -char(36),char(18),char(53),char(52),char(2),char(36),char(35),char(34),char(4),char(2), -char(2),char(211),char(108),char(80),char(97),char(86),char(93),char(106),char(1),char(178), -char(85),char(77),char(238),char(168),char(207),char(135),char(148),char(1),char(5),char(166), -char(155),char(251),char(223),char(200),char(1),char(94),char(202),char(200),char(1),char(94), -char(202),char(194),char(254),char(162),char(208),char(207),char(254),char(162),char(195),char(105), -char(174),char(1),char(45),char(172),char(174),char(1),char(42),char(175),char(174),char(254), -char(215),char(176),char(174),char(254),char(214),char(175),char(2),char(250),char(83),char(64), -char(75),char(65),char(136),char(80),char(123),char(30),char(254),char(117),char(1),char(98), -char(254),char(158),char(3),char(123),char(130),char(254),char(197),char(200),char(1),char(94), -char(202),char(200),char(254),char(162),char(202),char(197),char(254),char(166),char(208),char(207), -char(1),char(90),char(198),char(173),char(254),char(211),char(173),char(174),char(1),char(41), -char(176),char(174),char(1),char(42),char(175),char(174),char(254),char(215),char(0),char(1), -char(255),char(250),char(6),char(20),char(4),char(6),char(6),char(147),char(0),char(3), -char(0),char(17),char(181),char(0),char(5),char(1),char(4),char(1),char(2),char(0), -char(47),char(51),char(17),char(1),char(51),char(17),char(51),char(49),char(48),char(1), -char(33),char(53),char(33),char(4),char(6),char(251),char(244),char(4),char(12),char(6), -char(20),char(127),char(0),char(2),char(0),char(127),char(3),char(92),char(2),char(238), -char(5),char(203),char(0),char(12),char(0),char(24),char(0),char(33),char(64),char(14), -char(13),char(0),char(19),char(6),char(0),char(6),char(25),char(26),char(16),char(10), -char(192),char(22),char(3),char(4),char(0),char(63),char(51),char(26),char(204),char(50), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(19),char(52),char(54),char(51),char(50),char(22),char(21),char(20),char(6), -char(6),char(35),char(34),char(38),char(55),char(20),char(22),char(51),char(50),char(54), -char(53),char(52),char(38),char(35),char(34),char(6),char(127),char(181),char(130),char(130), -char(182),char(82),char(146),char(84),char(130),char(181),char(115),char(117),char(81),char(80), -char(115),char(113),char(82),char(83),char(115),char(4),char(147),char(130),char(182),char(181), -char(131),char(84),char(143),char(84),char(180),char(131),char(82),char(114),char(113),char(83), -char(84),char(113),char(114),char(0),char(255),char(255),char(0),char(104),char(0),char(1), -char(4),char(41),char(4),char(195),char(2),char(38),char(0),char(14),char(0),char(0), -char(0),char(7),char(2),char(43),char(0),char(0),char(253),char(116),char(0),char(1), -char(0),char(49),char(2),char(74),char(2),char(141),char(5),char(201),char(0),char(24), -char(0),char(35),char(64),char(17),char(7),char(19),char(23),char(1),char(1),char(14), -char(19),char(0),char(4),char(26),char(25),char(10),char(16),char(31),char(23),char(1), -char(32),char(0),char(63),char(51),char(63),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(53), -char(55),char(62),char(2),char(53),char(52),char(38),char(35),char(34),char(6),char(7), -char(39),char(54),char(51),char(50),char(22),char(21),char(20),char(6),char(7),char(7), -char(33),char(2),char(141),char(253),char(164),char(236),char(89),char(82),char(33),char(80), -char(63),char(52),char(98),char(69),char(66),char(131),char(152),char(132),char(147),char(89), -char(147),char(174),char(1),char(184),char(2),char(74),char(104),char(230),char(86),char(97), -char(76),char(54),char(68),char(69),char(38),char(50),char(88),char(111),char(130),char(112), -char(80),char(151),char(138),char(165),char(0),char(1),char(0),char(33),char(2),char(57), -char(2),char(141),char(5),char(201),char(0),char(35),char(0),char(57),char(64),char(34), -char(15),char(5),char(5),char(0),char(3),char(18),char(30),char(10),char(6),char(36), -char(37),char(18),char(93),char(19),char(109),char(19),char(2),char(76),char(19),char(1), -char(11),char(19),char(27),char(19),char(2),char(19),char(19),char(8),char(26),char(33), -char(31),char(13),char(8),char(33),char(0),char(63),char(51),char(63),char(51),char(18), -char(57),char(47),char(93),char(93),char(93),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(49),char(48),char(1),char(20),char(6),char(7),char(22), -char(21),char(20),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50), -char(53),char(52),char(35),char(35),char(53),char(51),char(50),char(54),char(53),char(52), -char(38),char(35),char(34),char(6),char(7),char(39),char(54),char(54),char(51),char(50), -char(22),char(2),char(115),char(82),char(68),char(176),char(184),char(168),char(152),char(116), -char(147),char(123),char(211),char(231),char(117),char(119),char(103),char(99),char(80),char(67), -char(66),char(112),char(56),char(69),char(63),char(140),char(94),char(136),char(157),char(4), -char(231),char(80),char(103),char(23),char(47),char(162),char(128),char(143),char(56),char(123), -char(68),char(162),char(145),char(107),char(79),char(68),char(61),char(68),char(43),char(35), -char(90),char(45),char(54),char(119),char(0),char(1),char(1),char(137),char(4),char(217), -char(3),char(18),char(6),char(33),char(0),char(9),char(0),char(19),char(182),char(9), -char(4),char(10),char(11),char(4),char(128),char(9),char(0),char(47),char(26),char(205), -char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(1),char(54),char(54), -char(55),char(51),char(21),char(6),char(6),char(7),char(35),char(1),char(137),char(48), -char(111),char(32),char(202),char(44),char(174),char(64),char(111),char(4),char(242),char(62), -char(176),char(65),char(21),char(65),char(190),char(52),char(0),char(1),char(0),char(176), -char(254),char(20),char(4),char(68),char(4),char(72),char(0),char(22),char(0),char(53), -char(64),char(26),char(5),char(10),char(10),char(8),char(16),char(0),char(19),char(19), -char(20),char(8),char(20),char(24),char(23),char(6),char(21),char(15),char(20),char(27), -char(13),char(2),char(70),char(89),char(13),char(22),char(9),char(21),char(0),char(63), -char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(16),char(51),char(50),char(54),char(53),char(17), -char(51),char(17),char(35),char(39),char(35),char(6),char(35),char(34),char(39),char(35), -char(22),char(21),char(17),char(35),char(17),char(51),char(1),char(86),char(254),char(171), -char(159),char(166),char(136),char(26),char(10),char(111),char(229),char(150),char(88),char(10), -char(10),char(166),char(166),char(1),char(125),char(254),char(250),char(189),char(212),char(2), -char(64),char(251),char(184),char(147),char(167),char(92),char(84),char(160),char(254),char(192), -char(6),char(52),char(0),char(1),char(0),char(113),char(254),char(252),char(4),char(96), -char(6),char(20),char(0),char(15),char(0),char(39),char(64),char(18),char(4),char(5), -char(1),char(0),char(0),char(5),char(11),char(3),char(16),char(17),char(8),char(8), -char(5),char(3),char(15),char(5),char(1),char(5),char(0),char(47),char(51),char(63), -char(51),char(18),char(57),char(47),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(35),char(17),char(35),char(17), -char(35),char(17),char(6),char(35),char(34),char(38),char(53),char(16),char(54),char(51), -char(33),char(4),char(96),char(114),char(213),char(115),char(62),char(84),char(216),char(203), -char(218),char(232),char(2),char(45),char(254),char(252),char(6),char(176),char(249),char(80), -char(3),char(51),char(18),char(250),char(251),char(1),char(4),char(254),char(0),char(1), -char(0),char(152),char(2),char(76),char(1),char(137),char(3),char(90),char(0),char(11), -char(0),char(23),char(64),char(10),char(6),char(0),char(0),char(13),char(12),char(3), -char(9),char(79),char(89),char(3),char(0),char(47),char(43),char(17),char(18),char(1), -char(57),char(17),char(51),char(49),char(48),char(19),char(52),char(54),char(51),char(50), -char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(152),char(62),char(56), -char(58),char(65),char(66),char(57),char(51),char(67),char(2),char(211),char(66),char(69), -char(69),char(66),char(65),char(70),char(63),char(0),char(0),char(1),char(0),char(37), -char(254),char(20),char(1),char(180),char(0),char(0),char(0),char(18),char(0),char(36), -char(64),char(16),char(17),char(14),char(11),char(0),char(0),char(14),char(5),char(3), -char(19),char(20),char(14),char(17),char(17),char(8),char(3),char(16),char(0),char(47), -char(204),char(50),char(57),char(47),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(6),char(35), -char(34),char(39),char(53),char(22),char(51),char(50),char(54),char(53),char(52),char(38), -char(39),char(55),char(51),char(7),char(22),char(1),char(180),char(153),char(150),char(51), -char(45),char(45),char(59),char(79),char(81),char(79),char(109),char(88),char(110),char(55), -char(180),char(254),char(223),char(97),char(106),char(9),char(106),char(8),char(40),char(54), -char(43),char(53),char(17),char(178),char(115),char(39),char(0),char(1),char(0),char(76), -char(2),char(74),char(1),char(225),char(5),char(182),char(0),char(10),char(0),char(32), -char(64),char(14),char(2),char(0),char(3),char(3),char(10),char(12),char(11),char(9), -char(9),char(3),char(32),char(6),char(0),char(30),char(0),char(63),char(50),char(63), -char(57),char(47),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(51), -char(49),char(48),char(1),char(51),char(17),char(35),char(17),char(52),char(55),char(6), -char(6),char(7),char(39),char(1),char(82),char(143),char(133),char(6),char(22),char(54), -char(135),char(67),char(5),char(182),char(252),char(148),char(2),char(67),char(91),char(90), -char(22),char(45),char(95),char(96),char(0),char(2),char(0),char(66),char(3),char(20), -char(2),char(190),char(5),char(199),char(0),char(11),char(0),char(23),char(0),char(37), -char(64),char(18),char(12),char(6),char(18),char(0),char(6),char(0),char(24),char(25), -char(15),char(0),char(3),char(16),char(3),char(2),char(3),char(21),char(9),char(31), -char(0),char(63),char(51),char(196),char(93),char(50),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(6), -char(35),char(34),char(38),char(53),char(52),char(54),char(51),char(50),char(22),char(5), -char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(35),char(34), -char(6),char(2),char(190),char(171),char(150),char(146),char(169),char(168),char(151),char(152), -char(165),char(253),char(254),char(91),char(104),char(105),char(92),char(92),char(105),char(103), -char(92),char(4),char(111),char(164),char(183),char(186),char(161),char(163),char(181),char(182), -char(162),char(122),char(122),char(122),char(122),char(123),char(118),char(118),char(0),char(2), -char(0),char(80),char(0),char(117),char(3),char(168),char(3),char(190),char(0),char(6), -char(0),char(13),char(0),char(35),char(64),char(17),char(11),char(9),char(4),char(2), -char(0),char(3),char(7),char(2),char(10),char(9),char(6),char(14),char(15),char(12), -char(5),char(8),char(1),char(0),char(47),char(51),char(47),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(1),char(39),char(1),char(1),char(55),char(1),char(5),char(1),char(39),char(1), -char(1),char(55),char(1),char(3),char(168),char(254),char(168),char(117),char(1),char(31), -char(254),char(225),char(117),char(1),char(88),char(254),char(117),char(254),char(168),char(117), -char(1),char(31),char(254),char(225),char(117),char(1),char(88),char(2),char(12),char(254), -char(105),char(71),char(1),char(95),char(1),char(94),char(69),char(254),char(105),char(27), -char(254),char(105),char(71),char(1),char(95),char(1),char(94),char(69),char(254),char(105), -char(255),char(255),char(0),char(75),char(0),char(0),char(5),char(209),char(5),char(182), -char(0),char(39),char(2),char(23),char(2),char(131),char(0),char(0),char(0),char(38), -char(0),char(123),char(255),char(0),char(1),char(7),char(2),char(60),char(3),char(29), -char(253),char(183),char(0),char(9),char(179),char(3),char(2),char(18),char(24),char(0), -char(63),char(53),char(53),char(0),char(255),char(255),char(0),char(46),char(0),char(0), -char(5),char(219),char(5),char(182),char(0),char(39),char(2),char(23),char(2),char(63), -char(0),char(0),char(0),char(38),char(0),char(123),char(226),char(0),char(1),char(7), -char(0),char(116),char(3),char(78),char(253),char(183),char(0),char(7),char(178),char(2), -char(16),char(24),char(0),char(63),char(53),char(0),char(255),char(255),char(0),char(26), -char(0),char(0),char(6),char(33),char(5),char(201),char(0),char(38),char(0),char(117), -char(249),char(0),char(0),char(39),char(2),char(23),char(2),char(223),char(0),char(0), -char(1),char(7),char(2),char(60),char(3),char(109),char(253),char(183),char(0),char(9), -char(179),char(3),char(2),char(43),char(24),char(0),char(63),char(53),char(53),char(0), -char(0),char(2),char(0),char(51),char(254),char(119),char(3),char(84),char(4),char(94), -char(0),char(29),char(0),char(40),char(0),char(65),char(64),char(34),char(8),char(20), -char(30),char(35),char(1),char(28),char(15),char(28),char(35),char(20),char(4),char(41), -char(42),char(0),char(29),char(1),char(12),char(3),char(29),char(29),char(17),char(38), -char(38),char(32),char(79),char(89),char(38),char(16),char(17),char(11),char(73),char(89), -char(17),char(35),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(95),char(94),char(93),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(21),char(20),char(6),char(7),char(14),char(2),char(21),char(20), -char(22),char(51),char(50),char(54),char(55),char(23),char(6),char(35),char(34),char(38), -char(53),char(52),char(62),char(2),char(55),char(54),char(54),char(53),char(53),char(19), -char(20),char(35),char(34),char(38),char(53),char(52),char(54),char(51),char(50),char(22), -char(2),char(78),char(75),char(97),char(121),char(61),char(25),char(132),char(122),char(80), -char(150),char(98),char(59),char(197),char(198),char(190),char(216),char(35),char(64),char(89), -char(54),char(101),char(65),char(180),char(121),char(59),char(62),char(66),char(55),char(51), -char(70),char(2),char(172),char(51),char(122),char(148),char(84),char(106),char(75),char(77), -char(56),char(100),char(113),char(38),char(48),char(135),char(96),char(186),char(170),char(70), -char(105),char(89),char(82),char(47),char(88),char(116),char(93),char(31),char(1),char(43), -char(135),char(69),char(66),char(64),char(71),char(64),char(255),char(255),char(0),char(0), -char(0),char(0),char(5),char(16),char(7),char(115),char(2),char(38),char(0),char(36), -char(0),char(0),char(1),char(7),char(0),char(67),char(255),char(194),char(1),char(82), -char(0),char(8),char(179),char(2),char(16),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16),char(7),char(115), -char(2),char(38),char(0),char(36),char(0),char(0),char(1),char(7),char(0),char(118), -char(0),char(133),char(1),char(82),char(0),char(8),char(179),char(2),char(24),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(0),char(0),char(0), -char(5),char(16),char(7),char(115),char(2),char(38),char(0),char(36),char(0),char(0), -char(1),char(7),char(1),char(75),char(0),char(35),char(1),char(82),char(0),char(8), -char(179),char(2),char(29),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(7),char(47),char(2),char(38), -char(0),char(36),char(0),char(0),char(1),char(7),char(1),char(82),char(0),char(4), -char(1),char(82),char(0),char(8),char(179),char(2),char(24),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16), -char(7),char(37),char(2),char(38),char(0),char(36),char(0),char(0),char(1),char(7), -char(0),char(106),char(0),char(55),char(1),char(82),char(0),char(10),char(180),char(3), -char(2),char(36),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(7),char(6),char(2),char(38), -char(0),char(36),char(0),char(0),char(0),char(7),char(1),char(80),char(0),char(57), -char(0),char(129),char(0),char(2),char(255),char(254),char(0),char(0),char(6),char(129), -char(5),char(182),char(0),char(15),char(0),char(19),char(0),char(78),char(64),char(44), -char(10),char(14),char(14),char(17),char(1),char(0),char(8),char(12),char(1),char(16), -char(5),char(5),char(21),char(5),char(20),char(9),char(19),char(6),char(19),char(73), -char(89),char(16),char(3),char(73),char(89),char(10),char(13),char(73),char(89),char(16), -char(10),char(16),char(10),char(1),char(6),char(3),char(5),char(18),char(1),char(14), -char(73),char(89),char(1),char(18),char(0),char(63),char(43),char(0),char(24),char(63), -char(63),char(18),char(57),char(57),char(47),char(47),char(43),char(43),char(43),char(17), -char(0),char(51),char(17),char(1),char(51),char(17),char(18),char(23),char(57),char(17), -char(51),char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(17),char(33), -char(3),char(35),char(1),char(33),char(21),char(33),char(17),char(33),char(21),char(33), -char(17),char(33),char(1),char(33),char(17),char(35),char(6),char(129),char(253),char(18), -char(253),char(254),char(227),char(176),char(2),char(186),char(3),char(201),char(253),char(188), -char(2),char(29),char(253),char(227),char(2),char(68),char(251),char(84),char(1),char(190), -char(118),char(1),char(209),char(254),char(47),char(5),char(182),char(151),char(254),char(41), -char(150),char(253),char(230),char(1),char(210),char(2),char(181),char(0),char(255),char(255), -char(0),char(125),char(254),char(20),char(4),char(207),char(5),char(203),char(2),char(38), -char(0),char(38),char(0),char(0),char(0),char(7),char(0),char(122),char(2),char(2), -char(0),char(0),char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248), -char(7),char(115),char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7), -char(0),char(67),char(255),char(183),char(1),char(82),char(0),char(8),char(179),char(1), -char(13),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201), -char(0),char(0),char(3),char(248),char(7),char(115),char(2),char(38),char(0),char(40), -char(0),char(0),char(1),char(7),char(0),char(118),char(0),char(63),char(1),char(82), -char(0),char(8),char(179),char(1),char(21),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248),char(7),char(115), -char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7),char(1),char(75), -char(255),char(251),char(1),char(82),char(0),char(8),char(179),char(1),char(26),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(0),char(0), -char(3),char(248),char(7),char(37),char(2),char(38),char(0),char(40),char(0),char(0), -char(1),char(7),char(0),char(106),char(0),char(18),char(1),char(82),char(0),char(10), -char(180),char(2),char(1),char(33),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(60),char(0),char(0),char(2),char(86),char(7),char(115), -char(2),char(38),char(0),char(44),char(0),char(0),char(1),char(7),char(0),char(67), -char(254),char(179),char(1),char(82),char(0),char(8),char(179),char(1),char(13),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(84),char(0),char(0), -char(2),char(115),char(7),char(115),char(2),char(38),char(0),char(44),char(0),char(0), -char(1),char(7),char(0),char(118),char(255),char(97),char(1),char(82),char(0),char(8), -char(179),char(1),char(21),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(255),char(255),char(0),char(0),char(2),char(161),char(7),char(115),char(2),char(38), -char(0),char(44),char(0),char(0),char(1),char(7),char(1),char(75),char(254),char(243), -char(1),char(82),char(0),char(8),char(179),char(1),char(26),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(60),char(0),char(0),char(2),char(111), -char(7),char(37),char(2),char(38),char(0),char(44),char(0),char(0),char(1),char(7), -char(0),char(106),char(255),char(7),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(33),char(5),char(38),char(0),char(43),char(53),char(53),char(0),char(2), -char(0),char(47),char(0),char(0),char(5),char(72),char(5),char(182),char(0),char(12), -char(0),char(23),char(0),char(87),char(64),char(50),char(17),char(21),char(21),char(8), -char(4),char(13),char(0),char(0),char(19),char(4),char(6),char(4),char(24),char(25), -char(20),char(6),char(7),char(6),char(73),char(89),char(17),char(15),char(7),char(63), -char(7),char(175),char(7),char(207),char(7),char(223),char(7),char(5),char(11),char(3), -char(7),char(7),char(4),char(9),char(9),char(16),char(74),char(89),char(9),char(3), -char(4),char(21),char(74),char(89),char(4),char(18),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(95), -char(94),char(93),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(49), -char(48),char(1),char(16),char(0),char(33),char(33),char(17),char(35),char(53),char(51), -char(17),char(33),char(32),char(0),char(3),char(16),char(33),char(35),char(17),char(33), -char(21),char(33),char(17),char(51),char(32),char(5),char(72),char(254),char(119),char(254), -char(143),char(254),char(123),char(154),char(154),char(1),char(178),char(1),char(81),char(1), -char(124),char(181),char(253),char(199),char(231),char(1),char(123),char(254),char(133),char(190), -char(2),char(98),char(2),char(233),char(254),char(150),char(254),char(129),char(2),char(137), -char(150),char(2),char(151),char(254),char(137),char(254),char(164),char(2),char(64),char(253), -char(252),char(150),char(254),char(10),char(255),char(255),char(0),char(201),char(0),char(0), -char(5),char(63),char(7),char(47),char(2),char(38),char(0),char(49),char(0),char(0), -char(1),char(7),char(1),char(82),char(0),char(147),char(1),char(82),char(0),char(8), -char(179),char(1),char(26),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(5),char(190),char(7),char(115),char(2),char(38), -char(0),char(50),char(0),char(0),char(1),char(7),char(0),char(67),char(0),char(121), -char(1),char(82),char(0),char(8),char(179),char(2),char(25),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190), -char(7),char(115),char(2),char(38),char(0),char(50),char(0),char(0),char(1),char(7), -char(0),char(118),char(1),char(10),char(1),char(82),char(0),char(8),char(179),char(2), -char(33),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(125), -char(255),char(236),char(5),char(190),char(7),char(115),char(2),char(38),char(0),char(50), -char(0),char(0),char(1),char(7),char(1),char(75),char(0),char(180),char(1),char(82), -char(0),char(8),char(179),char(2),char(38),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190),char(7),char(47), -char(2),char(38),char(0),char(50),char(0),char(0),char(1),char(7),char(1),char(82), -char(0),char(154),char(1),char(82),char(0),char(8),char(179),char(2),char(33),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(5),char(190),char(7),char(37),char(2),char(38),char(0),char(50),char(0),char(0), -char(1),char(7),char(0),char(106),char(0),char(213),char(1),char(82),char(0),char(10), -char(180),char(3),char(2),char(45),char(5),char(38),char(0),char(43),char(53),char(53), -char(0),char(1),char(0),char(133),char(1),char(16),char(4),char(12),char(4),char(152), -char(0),char(11),char(0),char(25),char(64),char(9),char(7),char(9),char(3),char(1), -char(9),char(1),char(12),char(13),char(8),char(0),char(25),char(47),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(23),char(1),char(1),char(7),char(1),char(1),char(39),char(1),char(1),char(55), -char(1),char(3),char(172),char(96),char(254),char(160),char(1),char(94),char(96),char(254), -char(158),char(254),char(164),char(101),char(1),char(94),char(254),char(160),char(100),char(1), -char(97),char(4),char(152),char(99),char(254),char(158),char(254),char(160),char(99),char(1), -char(95),char(254),char(161),char(99),char(1),char(96),char(1),char(96),char(101),char(254), -char(157),char(0),char(0),char(3),char(0),char(125),char(255),char(195),char(5),char(190), -char(5),char(246),char(0),char(19),char(0),char(27),char(0),char(35),char(0),char(78), -char(64),char(44),char(22),char(31),char(23),char(30),char(4),char(28),char(20),char(28), -char(10),char(20),char(0),char(0),char(18),char(15),char(5),char(8),char(10),char(6), -char(36),char(37),char(22),char(30),char(33),char(25),char(13),char(33),char(73),char(89), -char(15),char(18),char(8),char(5),char(4),char(3),char(16),char(13),char(4),char(3), -char(25),char(73),char(89),char(6),char(3),char(19),char(0),char(63),char(198),char(43), -char(0),char(24),char(63),char(198),char(18),char(23),char(57),char(43),char(17),char(18), -char(0),char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(18),char(23),char(57),char(49),char(48),char(1),char(16), -char(0),char(33),char(34),char(39),char(7),char(39),char(55),char(38),char(17),char(16), -char(0),char(33),char(50),char(23),char(55),char(23),char(7),char(22),char(3),char(16), -char(39),char(1),char(22),char(51),char(50),char(18),char(1),char(16),char(23),char(1), -char(38),char(35),char(34),char(2),char(5),char(190),char(254),char(157),char(254),char(196), -char(235),char(148),char(101),char(120),char(108),char(178),char(1),char(96),char(1),char(68), -char(209),char(157),char(97),char(120),char(106),char(192),char(180),char(110),char(253),char(96), -char(115),char(176),char(243),char(248),char(252),char(39),char(101),char(2),char(157),char(106), -char(168),char(243),char(253),char(2),char(221),char(254),char(161),char(254),char(110),char(100), -char(141),char(79),char(154),char(198),char(1),char(109),char(1),char(101),char(1),char(137), -char(94),char(135),char(80),char(148),char(202),char(254),char(149),char(1),char(16),char(154), -char(252),char(76),char(82),char(1),char(50),char(1),char(42),char(254),char(250),char(154), -char(3),char(175),char(73),char(254),char(205),char(0),char(255),char(255),char(0),char(186), -char(255),char(236),char(5),char(25),char(7),char(115),char(2),char(38),char(0),char(56), -char(0),char(0),char(1),char(7),char(0),char(67),char(0),char(70),char(1),char(82), -char(0),char(8),char(179),char(1),char(19),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(186),char(255),char(236),char(5),char(25),char(7),char(115), -char(2),char(38),char(0),char(56),char(0),char(0),char(1),char(7),char(0),char(118), -char(0),char(207),char(1),char(82),char(0),char(8),char(179),char(1),char(27),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(186),char(255),char(236), -char(5),char(25),char(7),char(115),char(2),char(38),char(0),char(56),char(0),char(0), -char(1),char(7),char(1),char(75),char(0),char(125),char(1),char(82),char(0),char(8), -char(179),char(1),char(32),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(186),char(255),char(236),char(5),char(25),char(7),char(37),char(2),char(38), -char(0),char(56),char(0),char(0),char(1),char(7),char(0),char(106),char(0),char(152), -char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(39),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(0),char(0),char(0), -char(4),char(123),char(7),char(115),char(2),char(38),char(0),char(60),char(0),char(0), -char(1),char(7),char(0),char(118),char(0),char(49),char(1),char(82),char(0),char(8), -char(179),char(1),char(18),char(5),char(38),char(0),char(43),char(53),char(0),char(2), -char(0),char(201),char(0),char(0),char(4),char(121),char(5),char(182),char(0),char(12), -char(0),char(21),char(0),char(54),char(64),char(28),char(13),char(9),char(5),char(5), -char(6),char(17),char(0),char(6),char(0),char(22),char(23),char(13),char(4),char(74), -char(89),char(9),char(21),char(74),char(89),char(13),char(9),char(13),char(9),char(6), -char(7),char(3),char(6),char(18),char(0),char(63),char(63),char(18),char(57),char(57), -char(47),char(47),char(43),char(43),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(1),char(20), -char(4),char(33),char(35),char(17),char(35),char(17),char(51),char(17),char(51),char(32), -char(4),char(1),char(51),char(50),char(54),char(53),char(52),char(38),char(35),char(35), -char(4),char(121),char(254),char(209),char(254),char(225),char(184),char(170),char(170),char(215), -char(1),char(25),char(1),char(22),char(252),char(250),char(168),char(226),char(202),char(190), -char(202),char(204),char(3),char(16),char(227),char(238),char(254),char(193),char(5),char(182), -char(255),char(0),char(207),char(253),char(234),char(143),char(164),char(149),char(138),char(0), -char(0),char(1),char(0),char(176),char(255),char(236),char(4),char(156),char(6),char(31), -char(0),char(48),char(0),char(65),char(64),char(34),char(41),char(42),char(5),char(29), -char(35),char(0),char(23),char(12),char(12),char(0),char(29),char(17),char(42),char(5), -char(49),char(50),char(18),char(18),char(42),char(46),char(46),char(38),char(70),char(89), -char(46),char(0),char(42),char(21),char(15),char(21),char(70),char(89),char(15),char(22), -char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(43),char(17),char(18), -char(0),char(57),char(24),char(47),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(20),char(7),char(6),char(6),char(21),char(20),char(22),char(22),char(23),char(22), -char(22),char(21),char(20),char(6),char(35),char(34),char(39),char(53),char(22),char(22), -char(51),char(50),char(53),char(52),char(38),char(39),char(38),char(38),char(53),char(52), -char(54),char(55),char(54),char(54),char(53),char(52),char(38),char(35),char(32),char(21), -char(17),char(35),char(17),char(52),char(54),char(51),char(50),char(22),char(4),char(25), -char(143),char(88),char(56),char(27),char(71),char(78),char(140),char(102),char(194),char(179), -char(188),char(107),char(63),char(156),char(72),char(215),char(83),char(110),char(127),char(96), -char(69),char(71),char(75),char(64),char(136),char(127),char(254),char(236),char(166),char(220), -char(222),char(206),char(225),char(4),char(242),char(135),char(115),char(70),char(67),char(33), -char(32),char(42),char(57),char(51),char(95),char(157),char(101),char(160),char(171),char(69), -char(154),char(39),char(47),char(182),char(75),char(107),char(70),char(82),char(123),char(84), -char(63),char(106),char(53),char(57),char(90),char(53),char(80),char(85),char(223),char(251), -char(76),char(4),char(178),char(178),char(187),char(157),char(255),char(255),char(0),char(94), -char(255),char(236),char(3),char(205),char(6),char(33),char(2),char(38),char(0),char(68), -char(0),char(0),char(1),char(6),char(0),char(67),char(142),char(0),char(0),char(8), -char(179),char(2),char(38),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(94),char(255),char(236),char(3),char(205),char(6),char(33),char(2),char(38), -char(0),char(68),char(0),char(0),char(1),char(6),char(0),char(118),char(43),char(0), -char(0),char(8),char(179),char(2),char(46),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205),char(6),char(33), -char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(6),char(1),char(75), -char(216),char(0),char(0),char(8),char(179),char(2),char(51),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205), -char(5),char(221),char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(6), -char(1),char(82),char(189),char(0),char(0),char(8),char(179),char(2),char(46),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(94),char(255),char(236), -char(3),char(205),char(5),char(211),char(2),char(38),char(0),char(68),char(0),char(0), -char(1),char(6),char(0),char(106),char(226),char(0),char(0),char(10),char(180),char(3), -char(2),char(58),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(94),char(255),char(236),char(3),char(205),char(6),char(133),char(2),char(38), -char(0),char(68),char(0),char(0),char(1),char(6),char(1),char(80),char(247),char(0), -char(0),char(10),char(180),char(3),char(2),char(40),char(17),char(38),char(0),char(43), -char(53),char(53),char(0),char(3),char(0),char(94),char(255),char(236),char(6),char(115), -char(4),char(92),char(0),char(41),char(0),char(52),char(0),char(59),char(0),char(97), -char(64),char(51),char(42),char(0),char(36),char(17),char(48),char(56),char(25),char(25), -char(4),char(48),char(57),char(24),char(24),char(31),char(48),char(11),char(0),char(5), -char(60),char(61),char(27),char(45),char(39),char(45),char(70),char(89),char(25),char(49), -char(4),char(49),char(71),char(89),char(56),char(36),char(39),char(17),char(4),char(4), -char(14),char(34),char(39),char(22),char(53),char(8),char(14),char(8),char(70),char(89), -char(20),char(14),char(16),char(0),char(63),char(51),char(43),char(17),char(0),char(51), -char(24),char(63),char(51),char(18),char(57),char(47),char(57),char(18),char(57),char(51), -char(43),char(17),char(0),char(51),char(43),char(17),char(0),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51), -char(18),char(57),char(57),char(17),char(51),char(49),char(48),char(19),char(52),char(54), -char(55),char(55),char(53),char(52),char(38),char(35),char(34),char(7),char(39),char(54), -char(54),char(51),char(50),char(22),char(23),char(54),char(54),char(51),char(50),char(18), -char(21),char(21),char(33),char(18),char(33),char(50),char(54),char(55),char(21),char(6), -char(6),char(35),char(32),char(39),char(6),char(6),char(35),char(34),char(38),char(55), -char(20),char(22),char(51),char(50),char(54),char(53),char(53),char(7),char(6),char(6), -char(1),char(34),char(6),char(7),char(33),char(52),char(38),char(94),char(248),char(254), -char(184),char(116),char(119),char(144),char(163),char(52),char(74),char(199),char(98),char(130), -char(165),char(41),char(53),char(171),char(110),char(192),char(232),char(253),char(67),char(8), -char(1),char(58),char(91),char(157),char(84),char(86),char(149),char(101),char(254),char(223), -char(125),char(81),char(197),char(134),char(163),char(185),char(174),char(107),char(88),char(145), -char(168),char(158),char(186),char(164),char(3),char(189),char(121),char(139),char(11),char(2), -char(7),char(128),char(1),char(47),char(161),char(179),char(8),char(6),char(68),char(129), -char(123),char(84),char(127),char(41),char(53),char(87),char(95),char(88),char(96),char(254), -char(245),char(222),char(107),char(254),char(117),char(35),char(39),char(148),char(38),char(33), -char(233),char(127),char(106),char(170),char(151),char(95),char(89),char(169),char(154),char(99), -char(7),char(8),char(109),char(2),char(50),char(166),char(158),char(156),char(168),char(0), -char(255),char(255),char(0),char(115),char(254),char(20),char(3),char(139),char(4),char(92), -char(2),char(38),char(0),char(70),char(0),char(0),char(0),char(7),char(0),char(122), -char(1),char(70),char(0),char(0),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(18),char(6),char(33),char(2),char(38),char(0),char(72),char(0),char(0), -char(1),char(6),char(0),char(67),char(181),char(0),char(0),char(8),char(179),char(2), -char(28),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(255),char(236),char(4),char(18),char(6),char(33),char(2),char(38),char(0),char(72), -char(0),char(0),char(1),char(6),char(0),char(118),char(78),char(0),char(0),char(8), -char(179),char(2),char(36),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(4),char(18),char(6),char(33),char(2),char(38), -char(0),char(72),char(0),char(0),char(1),char(6),char(1),char(75),char(247),char(0), -char(0),char(8),char(179),char(2),char(41),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(18),char(5),char(211), -char(2),char(38),char(0),char(72),char(0),char(0),char(1),char(6),char(0),char(106), -char(10),char(0),char(0),char(10),char(180),char(3),char(2),char(48),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(255),char(218),char(0),char(0), -char(1),char(99),char(6),char(33),char(2),char(38),char(0),char(243),char(0),char(0), -char(1),char(7),char(0),char(67),char(254),char(81),char(0),char(0),char(0),char(8), -char(179),char(1),char(5),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(169),char(0),char(0),char(2),char(50),char(6),char(33),char(2),char(38), -char(0),char(243),char(0),char(0),char(1),char(7),char(0),char(118),char(255),char(32), -char(0),char(0),char(0),char(8),char(179),char(1),char(13),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(255),char(179),char(0),char(0),char(2),char(85), -char(6),char(33),char(2),char(38),char(0),char(243),char(0),char(0),char(1),char(7), -char(1),char(75),char(254),char(167),char(0),char(0),char(0),char(8),char(179),char(1), -char(18),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(255),char(236), -char(0),char(0),char(2),char(31),char(5),char(211),char(2),char(38),char(0),char(243), -char(0),char(0),char(1),char(7),char(0),char(106),char(254),char(183),char(0),char(0), -char(0),char(10),char(180),char(2),char(1),char(25),char(17),char(38),char(0),char(43), -char(53),char(53),char(0),char(2),char(0),char(113),char(255),char(236),char(4),char(98), -char(6),char(33),char(0),char(27),char(0),char(38),char(0),char(74),char(64),char(43), -char(33),char(6),char(12),char(28),char(28),char(0),char(0),char(24),char(25),char(22), -char(14),char(17),char(19),char(16),char(6),char(9),char(39),char(40),char(9),char(31), -char(70),char(89),char(11),char(3),char(22),char(17),char(25),char(14),char(15),char(5), -char(20),char(9),char(9),char(3),char(23),char(20),char(1),char(3),char(36),char(70), -char(89),char(3),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(51), -char(18),char(57),char(47),char(18),char(23),char(57),char(18),char(57),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(16),char(0),char(35),char(34),char(0),char(53),char(52), -char(0),char(51),char(50),char(23),char(55),char(38),char(39),char(5),char(39),char(55), -char(38),char(39),char(55),char(22),char(23),char(55),char(23),char(7),char(22),char(18), -char(3),char(52),char(38),char(35),char(32),char(17),char(20),char(22),char(51),char(50), -char(54),char(4),char(98),char(254),char(251),char(247),char(222),char(254),char(233),char(1), -char(7),char(220),char(226),char(100),char(8),char(57),char(205),char(254),char(241),char(73), -char(233),char(92),char(94),char(69),char(156),char(102),char(238),char(76),char(207),char(152), -char(165),char(168),char(180),char(156),char(254),char(175),char(175),char(162),char(175),char(161), -char(2),char(51),char(254),char(231),char(254),char(210),char(1),char(13),char(226),char(230), -char(1),char(6),char(121),char(4),char(214),char(191),char(155),char(108),char(133),char(62), -char(49),char(117),char(73),char(75),char(138),char(107),char(119),char(143),char(254),char(114), -char(254),char(232),char(147),char(170),char(254),char(152),char(167),char(183),char(201),char(0), -char(255),char(255),char(0),char(176),char(0),char(0),char(4),char(68),char(5),char(221), -char(2),char(38),char(0),char(81),char(0),char(0),char(1),char(6),char(1),char(82), -char(14),char(0),char(0),char(8),char(179),char(1),char(30),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98), -char(6),char(33),char(2),char(38),char(0),char(82),char(0),char(0),char(1),char(6), -char(0),char(67),char(212),char(0),char(0),char(8),char(179),char(2),char(26),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(98),char(6),char(33),char(2),char(38),char(0),char(82),char(0),char(0), -char(1),char(6),char(0),char(118),char(86),char(0),char(0),char(8),char(179),char(2), -char(34),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(255),char(236),char(4),char(98),char(6),char(33),char(2),char(38),char(0),char(82), -char(0),char(0),char(1),char(6),char(1),char(75),char(14),char(0),char(0),char(8), -char(179),char(2),char(39),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(4),char(98),char(5),char(221),char(2),char(38), -char(0),char(82),char(0),char(0),char(1),char(6),char(1),char(82),char(241),char(0), -char(0),char(8),char(179),char(2),char(34),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98),char(5),char(211), -char(2),char(38),char(0),char(82),char(0),char(0),char(1),char(6),char(0),char(106), -char(27),char(0),char(0),char(10),char(180),char(3),char(2),char(46),char(17),char(38), -char(0),char(43),char(53),char(53),char(0),char(3),char(0),char(104),char(0),char(252), -char(4),char(41),char(4),char(168),char(0),char(3),char(0),char(15),char(0),char(27), -char(0),char(51),char(64),char(24),char(22),char(10),char(10),char(16),char(4),char(2), -char(4),char(1),char(3),char(28),char(29),char(25),char(19),char(19),char(1),char(7), -char(13),char(13),char(1),char(1),char(0),char(80),char(89),char(1),char(0),char(47), -char(43),char(17),char(0),char(51),char(24),char(47),char(51),char(17),char(51),char(47), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(19),char(53),char(33),char(21),char(1),char(52),char(54), -char(51),char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(17), -char(52),char(54),char(51),char(50),char(22),char(21),char(20),char(6),char(35),char(34), -char(38),char(104),char(3),char(193),char(253),char(174),char(59),char(54),char(52),char(58), -char(59),char(51),char(52),char(61),char(59),char(54),char(52),char(58),char(59),char(51), -char(52),char(61),char(2),char(141),char(138),char(138),char(254),char(232),char(60),char(61), -char(63),char(58),char(57),char(64),char(63),char(2),char(244),char(60),char(61),char(63), -char(58),char(57),char(64),char(63),char(0),char(3),char(0),char(115),char(255),char(188), -char(4),char(98),char(4),char(135),char(0),char(19),char(0),char(27),char(0),char(35), -char(0),char(75),char(64),char(41),char(23),char(31),char(28),char(20),char(20),char(10), -char(28),char(0),char(0),char(18),char(15),char(5),char(8),char(10),char(6),char(36), -char(37),char(22),char(30),char(33),char(25),char(13),char(25),char(70),char(89),char(15), -char(18),char(8),char(5),char(4),char(3),char(16),char(13),char(16),char(3),char(33), -char(70),char(89),char(6),char(3),char(22),char(0),char(63),char(198),char(43),char(0), -char(24),char(63),char(198),char(18),char(23),char(57),char(43),char(17),char(18),char(0), -char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(18),char(57),char(57),char(49),char(48),char(1),char(16),char(0), -char(35),char(34),char(39),char(7),char(39),char(55),char(38),char(17),char(16),char(0), -char(51),char(50),char(23),char(55),char(23),char(7),char(22),char(5),char(20),char(23), -char(1),char(38),char(35),char(34),char(6),char(5),char(52),char(39),char(1),char(22), -char(51),char(50),char(54),char(4),char(98),char(254),char(242),char(238),char(154),char(112), -char(84),char(114),char(94),char(129),char(1),char(12),char(238),char(154),char(116),char(84), -char(117),char(97),char(127),char(252),char(189),char(53),char(1),char(209),char(75),char(114), -char(163),char(166),char(2),char(151),char(51),char(254),char(47),char(71),char(113),char(163), -char(169),char(2),char(37),char(254),char(244),char(254),char(211),char(69),char(117),char(78), -char(131),char(152),char(1),char(0),char(1),char(12),char(1),char(43),char(76),char(119), -char(76),char(133),char(152),char(249),char(171),char(102),char(2),char(134),char(53),char(214), -char(212),char(164),char(100),char(253),char(125),char(51),char(219),char(0),char(255),char(255), -char(0),char(164),char(255),char(236),char(4),char(57),char(6),char(33),char(2),char(38), -char(0),char(88),char(0),char(0),char(1),char(6),char(0),char(67),char(196),char(0), -char(0),char(8),char(179),char(1),char(22),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(164),char(255),char(236),char(4),char(57),char(6),char(33), -char(2),char(38),char(0),char(88),char(0),char(0),char(1),char(6),char(0),char(118), -char(113),char(0),char(0),char(8),char(179),char(1),char(30),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236),char(4),char(57), -char(6),char(33),char(2),char(38),char(0),char(88),char(0),char(0),char(1),char(6), -char(1),char(75),char(18),char(0),char(0),char(8),char(179),char(1),char(35),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236), -char(4),char(57),char(5),char(211),char(2),char(38),char(0),char(88),char(0),char(0), -char(1),char(6),char(0),char(106),char(33),char(0),char(0),char(10),char(180),char(2), -char(1),char(42),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(2),char(254),char(20),char(4),char(6),char(6),char(33),char(2),char(38), -char(0),char(92),char(0),char(0),char(1),char(6),char(0),char(118),char(18),char(0), -char(0),char(8),char(179),char(1),char(31),char(17),char(38),char(0),char(43),char(53), -char(0),char(2),char(0),char(176),char(254),char(20),char(4),char(117),char(6),char(20), -char(0),char(22),char(0),char(34),char(0),char(62),char(64),char(31),char(32),char(6), -char(27),char(20),char(16),char(16),char(17),char(6),char(17),char(36),char(35),char(18), -char(0),char(17),char(27),char(12),char(22),char(9),char(3),char(9),char(30),char(70), -char(89),char(9),char(22),char(3),char(23),char(70),char(89),char(3),char(16),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(57),char(24),char(63),char(63),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(54), -char(54),char(51),char(50),char(18),char(17),char(16),char(2),char(35),char(34),char(39), -char(35),char(23),char(22),char(21),char(17),char(35),char(17),char(51),char(17),char(20), -char(7),char(37),char(34),char(6),char(7),char(21),char(20),char(22),char(51),char(32), -char(17),char(52),char(38),char(1),char(88),char(66),char(170),char(106),char(215),char(240), -char(241),char(214),char(222),char(122),char(12),char(4),char(8),char(166),char(166),char(6), -char(1),char(72),char(168),char(152),char(2),char(154),char(170),char(1),char(47),char(148), -char(3),char(180),char(89),char(79),char(254),char(212),char(254),char(245),char(254),char(244), -char(254),char(211),char(161),char(34),char(77),char(63),char(254),char(53),char(8),char(0), -char(254),char(46),char(52),char(90),char(27),char(184),char(201),char(41),char(231),char(199), -char(1),char(176),char(215),char(209),char(255),char(255),char(0),char(2),char(254),char(20), -char(4),char(6),char(5),char(211),char(2),char(38),char(0),char(92),char(0),char(0), -char(1),char(6),char(0),char(106),char(181),char(0),char(0),char(10),char(180),char(2), -char(1),char(43),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(6),char(180),char(2),char(38), -char(0),char(36),char(0),char(0),char(1),char(7),char(1),char(77),char(0),char(63), -char(1),char(82),char(0),char(8),char(179),char(2),char(18),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205), -char(5),char(98),char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(6), -char(1),char(77),char(245),char(0),char(0),char(8),char(179),char(2),char(40),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(0),char(0),char(0), -char(5),char(16),char(7),char(55),char(2),char(38),char(0),char(36),char(0),char(0), -char(1),char(7),char(1),char(78),char(0),char(43),char(1),char(82),char(0),char(8), -char(179),char(2),char(15),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(94),char(255),char(236),char(3),char(205),char(5),char(229),char(2),char(38), -char(0),char(68),char(0),char(0),char(1),char(6),char(1),char(78),char(228),char(0), -char(0),char(8),char(179),char(2),char(37),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(0),char(254),char(66),char(5),char(17),char(5),char(188), -char(2),char(38),char(0),char(36),char(0),char(0),char(0),char(7),char(1),char(81), -char(3),char(160),char(0),char(0),char(255),char(255),char(0),char(94),char(254),char(66), -char(4),char(0),char(4),char(90),char(2),char(38),char(0),char(68),char(0),char(0), -char(0),char(7),char(1),char(81),char(2),char(143),char(0),char(0),char(255),char(255), -char(0),char(125),char(255),char(236),char(4),char(207),char(7),char(115),char(2),char(38), -char(0),char(38),char(0),char(0),char(1),char(7),char(0),char(118),char(1),char(8), -char(1),char(82),char(0),char(8),char(179),char(1),char(32),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(3),char(139), -char(6),char(33),char(2),char(38),char(0),char(70),char(0),char(0),char(1),char(6), -char(0),char(118),char(68),char(0),char(0),char(8),char(179),char(1),char(32),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(4),char(207),char(7),char(115),char(2),char(38),char(0),char(38),char(0),char(0), -char(1),char(7),char(1),char(75),char(0),char(172),char(1),char(82),char(0),char(8), -char(179),char(1),char(37),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(3),char(139),char(6),char(33),char(2),char(38), -char(0),char(70),char(0),char(0),char(1),char(6),char(1),char(75),char(212),char(0), -char(0),char(8),char(179),char(1),char(37),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(125),char(255),char(236),char(4),char(207),char(7),char(49), -char(2),char(38),char(0),char(38),char(0),char(0),char(1),char(7),char(1),char(79), -char(2),char(27),char(1),char(82),char(0),char(8),char(179),char(1),char(32),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(3),char(139),char(5),char(223),char(2),char(38),char(0),char(70),char(0),char(0), -char(1),char(7),char(1),char(79),char(1),char(80),char(0),char(0),char(0),char(8), -char(179),char(1),char(32),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(4),char(207),char(7),char(115),char(2),char(38), -char(0),char(38),char(0),char(0),char(1),char(7),char(1),char(76),char(0),char(193), -char(1),char(82),char(0),char(8),char(179),char(1),char(34),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(3),char(161), -char(6),char(33),char(2),char(38),char(0),char(70),char(0),char(0),char(1),char(6), -char(1),char(76),char(243),char(0),char(0),char(8),char(179),char(1),char(34),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(0),char(0), -char(5),char(88),char(7),char(115),char(2),char(38),char(0),char(39),char(0),char(0), -char(1),char(7),char(1),char(76),char(0),char(88),char(1),char(82),char(0),char(8), -char(179),char(2),char(29),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(5),char(129),char(6),char(20),char(2),char(38), -char(0),char(71),char(0),char(0),char(1),char(7),char(2),char(56),char(3),char(12), -char(0),char(0),char(0),char(7),char(178),char(2),char(35),char(0),char(0),char(63), -char(53),char(0),char(255),char(255),char(0),char(47),char(0),char(0),char(5),char(72), -char(5),char(182),char(2),char(6),char(0),char(146),char(0),char(0),char(0),char(2), -char(0),char(115),char(255),char(236),char(4),char(211),char(6),char(20),char(0),char(26), -char(0),char(39),char(0),char(100),char(64),char(55),char(37),char(6),char(18),char(14), -char(0),char(30),char(30),char(21),char(25),char(22),char(25),char(16),char(6),char(4), -char(40),char(41),char(26),char(21),char(24),char(16),char(17),char(16),char(71),char(89), -char(21),char(15),char(17),char(31),char(17),char(47),char(17),char(3),char(9),char(3), -char(17),char(17),char(9),char(19),char(0),char(1),char(12),char(3),char(9),char(9), -char(34),char(70),char(89),char(9),char(16),char(3),char(27),char(70),char(89),char(3), -char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(57),char(24),char(63),char(18),char(57),char(47),char(95),char(94), -char(93),char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(51),char(17),char(51),char(51),char(51), -char(17),char(51),char(49),char(48),char(37),char(35),char(6),char(35),char(34),char(2), -char(17),char(16),char(18),char(51),char(50),char(23),char(51),char(38),char(53),char(53), -char(33),char(53),char(33),char(53),char(51),char(21),char(51),char(21),char(35),char(17), -char(35),char(37),char(50),char(54),char(53),char(53),char(52),char(38),char(35),char(34), -char(6),char(21),char(20),char(22),char(3),char(154),char(9),char(115),char(229),char(215), -char(239),char(240),char(214),char(223),char(119),char(13),char(11),char(254),char(64),char(1), -char(192),char(166),char(156),char(156),char(135),char(254),char(158),char(170),char(153),char(155), -char(170),char(146),char(155),char(154),char(147),char(167),char(1),char(38),char(1),char(15), -char(1),char(15),char(1),char(44),char(162),char(83),char(73),char(133),char(129),char(184), -char(184),char(129),char(251),char(37),char(119),char(185),char(206),char(35),char(233),char(199), -char(227),char(207),char(210),char(214),char(255),char(255),char(0),char(201),char(0),char(0), -char(3),char(248),char(6),char(180),char(2),char(38),char(0),char(40),char(0),char(0), -char(1),char(7),char(1),char(77),char(0),char(18),char(1),char(82),char(0),char(8), -char(179),char(1),char(15),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(4),char(18),char(5),char(98),char(2),char(38), -char(0),char(72),char(0),char(0),char(1),char(6),char(1),char(77),char(10),char(0), -char(0),char(8),char(179),char(2),char(30),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248),char(7),char(55), -char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7),char(1),char(78), -char(0),char(16),char(1),char(82),char(0),char(8),char(179),char(1),char(12),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(18),char(5),char(229),char(2),char(38),char(0),char(72),char(0),char(0), -char(1),char(6),char(1),char(78),char(251),char(0),char(0),char(8),char(179),char(2), -char(27),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201), -char(0),char(0),char(3),char(248),char(7),char(20),char(2),char(38),char(0),char(40), -char(0),char(0),char(1),char(7),char(1),char(79),char(1),char(111),char(1),char(53), -char(0),char(8),char(179),char(1),char(21),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(18),char(5),char(223), -char(2),char(38),char(0),char(72),char(0),char(0),char(1),char(7),char(1),char(79), -char(1),char(84),char(0),char(0),char(0),char(8),char(179),char(2),char(36),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(254),char(66), -char(3),char(248),char(5),char(182),char(2),char(38),char(0),char(40),char(0),char(0), -char(0),char(7),char(1),char(81),char(2),char(115),char(0),char(0),char(255),char(255), -char(0),char(115),char(254),char(97),char(4),char(18),char(4),char(92),char(2),char(38), -char(0),char(72),char(0),char(0),char(0),char(7),char(1),char(81),char(2),char(102), -char(0),char(31),char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248), -char(7),char(115),char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7), -char(1),char(76),char(0),char(16),char(1),char(82),char(0),char(8),char(179),char(1), -char(23),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(255),char(236),char(4),char(18),char(6),char(33),char(2),char(38),char(0),char(72), -char(0),char(0),char(1),char(6),char(1),char(76),char(251),char(0),char(0),char(8), -char(179),char(2),char(38),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(5),char(61),char(7),char(115),char(2),char(38), -char(0),char(42),char(0),char(0),char(1),char(7),char(1),char(75),char(0),char(233), -char(1),char(82),char(0),char(8),char(179),char(1),char(42),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(39),char(254),char(20),char(4),char(49), -char(6),char(33),char(2),char(38),char(0),char(74),char(0),char(0),char(1),char(6), -char(1),char(75),char(202),char(0),char(0),char(8),char(179),char(3),char(80),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(5),char(61),char(7),char(55),char(2),char(38),char(0),char(42),char(0),char(0), -char(1),char(7),char(1),char(78),char(1),char(0),char(1),char(82),char(0),char(8), -char(179),char(1),char(28),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(39),char(254),char(20),char(4),char(49),char(5),char(229),char(2),char(38), -char(0),char(74),char(0),char(0),char(1),char(6),char(1),char(78),char(206),char(0), -char(0),char(8),char(179),char(3),char(66),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(61),char(7),char(49), -char(2),char(38),char(0),char(42),char(0),char(0),char(1),char(7),char(1),char(79), -char(2),char(100),char(1),char(82),char(0),char(8),char(179),char(1),char(37),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(39),char(254),char(20), -char(4),char(49),char(5),char(223),char(2),char(38),char(0),char(74),char(0),char(0), -char(1),char(7),char(1),char(79),char(1),char(31),char(0),char(0),char(0),char(8), -char(179),char(3),char(75),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(254),char(59),char(5),char(61),char(5),char(203),char(2),char(38), -char(0),char(42),char(0),char(0),char(0),char(7),char(2),char(57),char(1),char(39), -char(0),char(0),char(255),char(255),char(0),char(39),char(254),char(20),char(4),char(49), -char(6),char(33),char(2),char(38),char(0),char(74),char(0),char(0),char(1),char(6), -char(2),char(58),char(68),char(0),char(0),char(8),char(179),char(3),char(70),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(0),char(0), -char(5),char(31),char(7),char(115),char(2),char(38),char(0),char(43),char(0),char(0), -char(1),char(7),char(1),char(75),char(0),char(150),char(1),char(82),char(0),char(8), -char(179),char(1),char(26),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(176),char(0),char(0),char(4),char(68),char(7),char(170),char(2),char(38), -char(0),char(75),char(0),char(0),char(1),char(7),char(1),char(75),char(0),char(31), -char(1),char(137),char(0),char(8),char(179),char(1),char(37),char(2),char(38),char(0), -char(43),char(53),char(0),char(2),char(0),char(0),char(0),char(0),char(5),char(231), -char(5),char(182),char(0),char(19),char(0),char(23),char(0),char(84),char(64),char(44), -char(23),char(3),char(15),char(15),char(0),char(16),char(20),char(4),char(12),char(12), -char(7),char(11),char(8),char(11),char(16),char(18),char(4),char(24),char(25),char(23), -char(14),char(73),char(89),char(22),char(10),char(18),char(19),char(18),char(74),char(89), -char(7),char(3),char(19),char(23),char(19),char(23),char(19),char(1),char(12),char(16), -char(18),char(5),char(1),char(3),char(0),char(63),char(51),char(63),char(51),char(18), -char(57),char(57),char(47),char(47),char(17),char(51),char(51),char(43),char(17),char(0), -char(51),char(51),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(51),char(17),char(51),char(51),char(17),char(51),char(51),char(17),char(51),char(51), -char(49),char(48),char(19),char(53),char(51),char(21),char(33),char(53),char(51),char(21), -char(51),char(21),char(35),char(17),char(35),char(17),char(33),char(17),char(35),char(17), -char(35),char(53),char(1),char(53),char(33),char(21),char(201),char(170),char(3),char(2), -char(170),char(200),char(200),char(170),char(252),char(254),char(170),char(201),char(4),char(117), -char(252),char(254),char(4),char(190),char(248),char(248),char(248),char(248),char(141),char(251), -char(207),char(2),char(176),char(253),char(80),char(4),char(49),char(141),char(254),char(138), -char(233),char(233),char(0),char(1),char(0),char(20),char(0),char(0),char(4),char(68), -char(6),char(20),char(0),char(30),char(0),char(89),char(64),char(50),char(22),char(20), -char(16),char(8),char(8),char(13),char(9),char(0),char(30),char(30),char(18),char(9), -char(11),char(4),char(31),char(32),char(23),char(22),char(26),char(4),char(70),char(89), -char(19),char(11),char(12),char(11),char(71),char(89),char(16),char(12),char(15),char(12), -char(31),char(12),char(47),char(12),char(3),char(22),char(26),char(12),char(12),char(26), -char(22),char(3),char(9),char(14),char(0),char(0),char(9),char(21),char(0),char(63), -char(51),char(63),char(18),char(23),char(57),char(47),char(47),char(47),char(93),char(17), -char(51),char(43),char(17),char(0),char(51),char(43),char(17),char(0),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(51),char(51),char(49),char(48),char(33),char(17),char(52),char(38),char(35), -char(34),char(6),char(21),char(17),char(35),char(17),char(35),char(53),char(51),char(53), -char(51),char(21),char(33),char(21),char(33),char(21),char(20),char(7),char(51),char(54), -char(54),char(51),char(50),char(22),char(21),char(17),char(3),char(158),char(122),char(130), -char(174),char(158),char(166),char(156),char(156),char(166),char(1),char(193),char(254),char(63), -char(8),char(10),char(49),char(181),char(116),char(201),char(201),char(2),char(158),char(134), -char(132),char(186),char(213),char(253),char(231),char(4),char(219),char(127),char(186),char(186), -char(127),char(196),char(84),char(56),char(79),char(91),char(191),char(210),char(253),char(92), -char(255),char(255),char(255),char(226),char(0),char(0),char(2),char(202),char(7),char(47), -char(2),char(38),char(0),char(44),char(0),char(0),char(1),char(7),char(1),char(82), -char(254),char(218),char(1),char(82),char(0),char(8),char(179),char(1),char(21),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(255),char(144),char(0),char(0), -char(2),char(120),char(5),char(221),char(2),char(38),char(0),char(243),char(0),char(0), -char(1),char(7),char(1),char(82),char(254),char(136),char(0),char(0),char(0),char(8), -char(179),char(1),char(13),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(42),char(0),char(0),char(2),char(130),char(6),char(180),char(2),char(38), -char(0),char(44),char(0),char(0),char(1),char(7),char(1),char(77),char(254),char(253), -char(1),char(82),char(0),char(8),char(179),char(1),char(15),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(255),char(218),char(0),char(0),char(2),char(50), -char(5),char(98),char(2),char(38),char(0),char(243),char(0),char(0),char(1),char(7), -char(1),char(77),char(254),char(173),char(0),char(0),char(0),char(8),char(179),char(1), -char(7),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(30), -char(0),char(0),char(2),char(138),char(7),char(55),char(2),char(38),char(0),char(44), -char(0),char(0),char(1),char(7),char(1),char(78),char(254),char(249),char(1),char(82), -char(0),char(8),char(179),char(1),char(12),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(255),char(204),char(0),char(0),char(2),char(56),char(5),char(229), -char(2),char(38),char(0),char(243),char(0),char(0),char(1),char(7),char(1),char(78), -char(254),char(167),char(0),char(0),char(0),char(8),char(179),char(1),char(4),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(84),char(254),char(66), -char(2),char(86),char(5),char(182),char(2),char(38),char(0),char(44),char(0),char(0), -char(0),char(6),char(1),char(81),char(104),char(0),char(255),char(255),char(0),char(53), -char(254),char(66),char(1),char(129),char(5),char(223),char(2),char(38),char(0),char(76), -char(0),char(0),char(0),char(6),char(1),char(81),char(16),char(0),char(255),char(255), -char(0),char(84),char(0),char(0),char(2),char(86),char(7),char(49),char(2),char(38), -char(0),char(44),char(0),char(0),char(1),char(7),char(1),char(79),char(0),char(80), -char(1),char(82),char(0),char(8),char(179),char(1),char(21),char(5),char(38),char(0), -char(43),char(53),char(0),char(1),char(0),char(176),char(0),char(0),char(1),char(86), -char(4),char(72),char(0),char(3),char(0),char(22),char(64),char(9),char(0),char(1), -char(1),char(5),char(4),char(2),char(15),char(1),char(21),char(0),char(63),char(63), -char(17),char(18),char(1),char(57),char(17),char(51),char(49),char(48),char(33),char(35), -char(17),char(51),char(1),char(86),char(166),char(166),char(4),char(72),char(255),char(255), -char(0),char(84),char(254),char(127),char(4),char(16),char(5),char(182),char(0),char(38), -char(0),char(44),char(0),char(0),char(0),char(7),char(0),char(45),char(2),char(168), -char(0),char(0),char(255),char(255),char(0),char(162),char(254),char(20),char(3),char(108), -char(5),char(223),char(0),char(38),char(0),char(76),char(0),char(0),char(0),char(7), -char(0),char(77),char(2),char(6),char(0),char(0),char(255),char(255),char(255),char(96), -char(254),char(127),char(2),char(101),char(7),char(115),char(2),char(38),char(0),char(45), -char(0),char(0),char(1),char(7),char(1),char(75),char(254),char(183),char(1),char(82), -char(0),char(8),char(179),char(1),char(28),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(255),char(145),char(254),char(20),char(2),char(79),char(6),char(33), -char(2),char(38),char(2),char(55),char(0),char(0),char(1),char(7),char(1),char(75), -char(254),char(161),char(0),char(0),char(0),char(8),char(179),char(1),char(27),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(254),char(59), -char(4),char(233),char(5),char(182),char(2),char(38),char(0),char(46),char(0),char(0), -char(0),char(7),char(2),char(57),char(0),char(137),char(0),char(0),char(255),char(255), -char(0),char(176),char(254),char(59),char(4),char(29),char(6),char(20),char(2),char(38), -char(0),char(78),char(0),char(0),char(0),char(6),char(2),char(57),char(43),char(0), -char(0),char(1),char(0),char(176),char(0),char(0),char(4),char(27),char(4),char(70), -char(0),char(13),char(0),char(47),char(64),char(25),char(13),char(11),char(7),char(7), -char(8),char(3),char(1),char(2),char(5),char(8),char(5),char(14),char(15),char(2), -char(13),char(5),char(6),char(4),char(8),char(0),char(9),char(15),char(4),char(8), -char(21),char(0),char(63),char(51),char(63),char(51),char(18),char(23),char(57),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(49), -char(48),char(1),char(51),char(1),char(1),char(35),char(1),char(7),char(17),char(35), -char(17),char(51),char(17),char(20),char(7),char(3),char(47),char(207),char(254),char(98), -char(1),char(187),char(201),char(254),char(151),char(135),char(178),char(178),char(12),char(4), -char(70),char(254),char(30),char(253),char(156),char(1),char(248),char(113),char(254),char(121), -char(4),char(70),char(254),char(229),char(166),char(113),char(255),char(255),char(0),char(201), -char(0),char(0),char(3),char(248),char(7),char(115),char(2),char(38),char(0),char(47), -char(0),char(0),char(1),char(7),char(0),char(118),char(255),char(99),char(1),char(82), -char(0),char(8),char(179),char(1),char(15),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(163),char(0),char(0),char(2),char(44),char(7),char(172), -char(2),char(38),char(0),char(79),char(0),char(0),char(1),char(7),char(0),char(118), -char(255),char(26),char(1),char(139),char(0),char(8),char(179),char(1),char(13),char(2), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(254),char(59), -char(3),char(248),char(5),char(182),char(2),char(38),char(0),char(47),char(0),char(0), -char(0),char(6),char(2),char(57),char(49),char(0),char(255),char(255),char(0),char(89), -char(254),char(59),char(1),char(87),char(6),char(20),char(2),char(38),char(0),char(79), -char(0),char(0),char(0),char(7),char(2),char(57),char(254),char(232),char(0),char(0), -char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248),char(5),char(183), -char(2),char(38),char(0),char(47),char(0),char(0),char(1),char(7),char(2),char(56), -char(1),char(29),char(255),char(163),char(0),char(7),char(178),char(1),char(9),char(3), -char(0),char(63),char(53),char(0),char(255),char(255),char(0),char(176),char(0),char(0), -char(2),char(160),char(6),char(20),char(2),char(38),char(0),char(79),char(0),char(0), -char(1),char(6),char(2),char(56),char(43),char(0),char(0),char(7),char(178),char(1), -char(7),char(0),char(0),char(63),char(53),char(0),char(255),char(255),char(0),char(201), -char(0),char(0),char(3),char(248),char(5),char(182),char(2),char(38),char(0),char(47), -char(0),char(0),char(0),char(7),char(1),char(79),char(2),char(4),char(253),char(103), -char(255),char(255),char(0),char(176),char(0),char(0),char(2),char(168),char(6),char(20), -char(0),char(38),char(0),char(79),char(0),char(0),char(0),char(7),char(1),char(79), -char(1),char(66),char(253),char(56),char(0),char(1),char(0),char(29),char(0),char(0), -char(3),char(248),char(5),char(182),char(0),char(13),char(0),char(61),char(64),char(33), -char(7),char(11),char(11),char(4),char(0),char(12),char(9),char(0),char(3),char(4), -char(15),char(14),char(9),char(7),char(4),char(10),char(3),char(1),char(6),char(8), -char(2),char(8),char(2),char(8),char(0),char(5),char(3),char(0),char(11),char(73), -char(89),char(0),char(18),char(0),char(63),char(43),char(0),char(24),char(63),char(18), -char(57),char(57),char(47),char(47),char(18),char(23),char(57),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(51), -char(17),char(7),char(39),char(55),char(17),char(51),char(17),char(37),char(23),char(5), -char(17),char(33),char(21),char(201),char(105),char(67),char(172),char(170),char(1),char(41), -char(67),char(254),char(148),char(2),char(133),char(1),char(252),char(59),char(114),char(101), -char(3),char(30),char(253),char(70),char(174),char(121),char(211),char(254),char(60),char(154), -char(0),char(1),char(255),char(252),char(0),char(0),char(2),char(39),char(6),char(20), -char(0),char(11),char(0),char(55),char(64),char(28),char(0),char(4),char(4),char(9), -char(5),char(5),char(12),char(2),char(13),char(8),char(12),char(0),char(2),char(9), -char(3),char(8),char(6),char(6),char(1),char(7),char(1),char(7),char(1),char(5), -char(10),char(0),char(5),char(21),char(0),char(63),char(63),char(18),char(57),char(57), -char(47),char(47),char(18),char(23),char(57),char(17),char(1),char(51),char(17),char(51), -char(18),char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(1), -char(55),char(23),char(7),char(17),char(35),char(17),char(7),char(39),char(55),char(17), -char(51),char(1),char(86),char(137),char(72),char(209),char(166),char(110),char(70),char(180), -char(166),char(3),char(96),char(94),char(112),char(141),char(253),char(63),char(2),char(84), -char(72),char(113),char(119),char(3),char(32),char(0),char(255),char(255),char(0),char(201), -char(0),char(0),char(5),char(63),char(7),char(115),char(2),char(38),char(0),char(49), -char(0),char(0),char(1),char(7),char(0),char(118),char(1),char(2),char(1),char(82), -char(0),char(8),char(179),char(1),char(26),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(176),char(0),char(0),char(4),char(68),char(6),char(33), -char(2),char(38),char(0),char(81),char(0),char(0),char(1),char(6),char(0),char(118), -char(121),char(0),char(0),char(8),char(179),char(1),char(30),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(201),char(254),char(59),char(5),char(63), -char(5),char(182),char(2),char(38),char(0),char(49),char(0),char(0),char(0),char(7), -char(2),char(57),char(0),char(205),char(0),char(0),char(255),char(255),char(0),char(176), -char(254),char(59),char(4),char(68),char(4),char(92),char(2),char(38),char(0),char(81), -char(0),char(0),char(0),char(6),char(2),char(57),char(86),char(0),char(255),char(255), -char(0),char(201),char(0),char(0),char(5),char(63),char(7),char(115),char(2),char(38), -char(0),char(49),char(0),char(0),char(1),char(7),char(1),char(76),char(0),char(166), -char(1),char(82),char(0),char(8),char(179),char(1),char(28),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(176),char(0),char(0),char(4),char(68), -char(6),char(33),char(2),char(38),char(0),char(81),char(0),char(0),char(1),char(6), -char(1),char(76),char(31),char(0),char(0),char(8),char(179),char(1),char(32),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(1),char(0),char(0), -char(4),char(203),char(5),char(182),char(0),char(39),char(0),char(81),char(0),char(135), -char(0),char(0),char(1),char(6),char(2),char(7),char(232),char(0),char(0),char(7), -char(178),char(1),char(28),char(3),char(0),char(63),char(53),char(0),char(0),char(1), -char(0),char(201),char(254),char(127),char(5),char(63),char(5),char(182),char(0),char(25), -char(0),char(56),char(64),char(28),char(16),char(13),char(13),char(14),char(8),char(20), -char(20),char(23),char(23),char(2),char(14),char(3),char(26),char(27),char(18),char(10), -char(14),char(21),char(15),char(3),char(14),char(18),char(0),char(5),char(73),char(89), -char(0),char(34),char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(51), -char(18),char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(34), -char(39),char(53),char(22),char(51),char(50),char(54),char(53),char(1),char(35),char(18), -char(21),char(17),char(35),char(17),char(51),char(1),char(51),char(38),char(53),char(17), -char(51),char(17),char(20),char(6),char(3),char(201),char(98),char(54),char(71),char(83), -char(105),char(106),char(252),char(192),char(8),char(16),char(157),char(192),char(3),char(29), -char(8),char(14),char(159),char(193),char(254),char(127),char(27),char(145),char(20),char(122), -char(111),char(4),char(203),char(254),char(248),char(158),char(252),char(219),char(5),char(182), -char(251),char(78),char(149),char(224),char(3),char(61),char(250),char(88),char(195),char(204), -char(0),char(1),char(0),char(176),char(254),char(20),char(4),char(68),char(4),char(92), -char(0),char(29),char(0),char(56),char(64),char(30),char(19),char(15),char(15),char(16), -char(7),char(27),char(27),char(2),char(16),char(3),char(30),char(31),char(23),char(11), -char(70),char(89),char(23),char(16),char(19),char(16),char(17),char(15),char(16),char(21), -char(0),char(5),char(70),char(89),char(0),char(27),char(0),char(63),char(43),char(0), -char(24),char(63),char(63),char(18),char(57),char(63),char(43),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(34),char(39),char(53),char(22),char(51),char(50),char(53),char(17),char(52), -char(38),char(35),char(34),char(6),char(21),char(17),char(35),char(17),char(51),char(23), -char(51),char(54),char(54),char(51),char(50),char(22),char(21),char(17),char(20),char(6), -char(3),char(37),char(86),char(55),char(60),char(62),char(140),char(122),char(130),char(172), -char(160),char(166),char(135),char(27),char(10),char(52),char(180),char(110),char(203),char(199), -char(140),char(254),char(20),char(25),char(135),char(20),char(172),char(3),char(121),char(134), -char(132),char(186),char(214),char(253),char(193),char(4),char(72),char(150),char(82),char(88), -char(191),char(210),char(252),char(141),char(154),char(170),char(255),char(255),char(0),char(125), -char(255),char(236),char(5),char(190),char(6),char(180),char(2),char(38),char(0),char(50), -char(0),char(0),char(1),char(7),char(1),char(77),char(0),char(199),char(1),char(82), -char(0),char(8),char(179),char(2),char(27),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98),char(5),char(98), -char(2),char(38),char(0),char(82),char(0),char(0),char(1),char(6),char(1),char(77), -char(18),char(0),char(0),char(8),char(179),char(2),char(28),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190), -char(7),char(55),char(2),char(38),char(0),char(50),char(0),char(0),char(1),char(7), -char(1),char(78),char(0),char(193),char(1),char(82),char(0),char(8),char(179),char(2), -char(24),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(255),char(236),char(4),char(98),char(5),char(229),char(2),char(38),char(0),char(82), -char(0),char(0),char(1),char(6),char(1),char(78),char(14),char(0),char(0),char(8), -char(179),char(2),char(25),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(5),char(190),char(7),char(115),char(2),char(38), -char(0),char(50),char(0),char(0),char(1),char(7),char(1),char(83),char(1),char(20), -char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(43),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(98),char(6),char(33),char(2),char(38),char(0),char(82),char(0),char(0), -char(1),char(6),char(1),char(83),char(90),char(0),char(0),char(10),char(180),char(3), -char(2),char(44),char(17),char(38),char(0),char(43),char(53),char(53),char(0),char(2), -char(0),char(125),char(255),char(236),char(6),char(231),char(5),char(205),char(0),char(20), -char(0),char(31),char(0),char(83),char(64),char(46),char(24),char(6),char(15),char(19), -char(19),char(29),char(0),char(13),char(17),char(29),char(6),char(5),char(32),char(33), -char(15),char(18),char(73),char(89),char(15),char(15),char(0),char(11),char(11),char(14), -char(73),char(89),char(11),char(3),char(9),char(21),char(73),char(89),char(9),char(4), -char(3),char(27),char(73),char(89),char(3),char(18),char(0),char(19),char(73),char(89), -char(0),char(18),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(0), -char(24),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0), -char(57),char(24),char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(6), -char(35),char(32),char(0),char(17),char(16),char(0),char(33),char(50),char(23),char(33), -char(21),char(33),char(17),char(33),char(21),char(33),char(17),char(33),char(1),char(34), -char(0),char(17),char(16),char(0),char(51),char(50),char(55),char(17),char(38),char(6), -char(231),char(253),char(0),char(102),char(92),char(254),char(185),char(254),char(159),char(1), -char(92),char(1),char(64),char(102),char(90),char(3),char(14),char(253),char(179),char(2), -char(39),char(253),char(217),char(2),char(77),char(252),char(68),char(249),char(254),char(255), -char(1),char(1),char(247),char(112),char(87),char(87),char(20),char(1),char(137),char(1), -char(106),char(1),char(104),char(1),char(134),char(23),char(151),char(254),char(41),char(150), -char(253),char(230),char(4),char(157),char(254),char(207),char(254),char(217),char(254),char(215), -char(254),char(205),char(33),char(4),char(117),char(30),char(0),char(3),char(0),char(113), -char(255),char(236),char(7),char(31),char(4),char(90),char(0),char(30),char(0),char(42), -char(0),char(49),char(0),char(85),char(64),char(45),char(31),char(8),char(14),char(2), -char(22),char(22),char(37),char(47),char(21),char(21),char(28),char(37),char(8),char(4), -char(50),char(51),char(43),char(40),char(11),char(40),char(70),char(89),char(46),char(22), -char(70),char(89),char(2),char(5),char(14),char(11),char(46),char(46),char(5),char(17), -char(11),char(16),char(24),char(34),char(5),char(34),char(70),char(89),char(0),char(5), -char(22),char(0),char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(63), -char(51),char(18),char(57),char(47),char(18),char(57),char(18),char(57),char(43),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(18),char(57),char(57),char(17),char(51),char(49),char(48),char(5), -char(32),char(39),char(6),char(6),char(35),char(34),char(0),char(17),char(16),char(0), -char(51),char(50),char(22),char(23),char(54),char(54),char(51),char(50),char(18),char(21), -char(21),char(33),char(18),char(33),char(50),char(54),char(55),char(21),char(6),char(6), -char(1),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(34),char(6),char(37),char(34),char(6),char(7),char(33),char(52),char(38),char(5), -char(150),char(254),char(219),char(125),char(62),char(209),char(137),char(223),char(254),char(244), -char(1),char(6),char(235),char(131),char(205),char(62),char(58),char(192),char(126),char(201), -char(238),char(253),char(39),char(8),char(1),char(74),char(94),char(161),char(87),char(88), -char(152),char(251),char(33),char(152),char(167),char(163),char(153),char(155),char(165),char(166), -char(149),char(4),char(71),char(127),char(145),char(12),char(2),char(32),char(132),char(20), -char(235),char(116),char(119),char(1),char(49),char(1),char(8),char(1),char(9),char(1), -char(44),char(119),char(114),char(112),char(121),char(254),char(247),char(226),char(105),char(254), -char(119),char(35),char(39),char(148),char(39),char(32),char(2),char(57),char(211),char(219), -char(213),char(209),char(221),char(213),char(216),char(216),char(164),char(158),char(158),char(164), -char(255),char(255),char(0),char(201),char(0),char(0),char(4),char(207),char(7),char(115), -char(2),char(38),char(0),char(53),char(0),char(0),char(1),char(7),char(0),char(118), -char(0),char(121),char(1),char(82),char(0),char(8),char(179),char(2),char(31),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(176),char(0),char(0), -char(3),char(39),char(6),char(33),char(2),char(38),char(0),char(85),char(0),char(0), -char(1),char(6),char(0),char(118),char(220),char(0),char(0),char(8),char(179),char(1), -char(26),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201), -char(254),char(59),char(4),char(207),char(5),char(182),char(2),char(38),char(0),char(53), -char(0),char(0),char(0),char(6),char(2),char(57),char(125),char(0),char(255),char(255), -char(0),char(96),char(254),char(59),char(3),char(39),char(4),char(92),char(2),char(38), -char(0),char(85),char(0),char(0),char(0),char(7),char(2),char(57),char(254),char(239), -char(0),char(0),char(255),char(255),char(0),char(201),char(0),char(0),char(4),char(207), -char(7),char(115),char(2),char(38),char(0),char(53),char(0),char(0),char(1),char(7), -char(1),char(76),char(0),char(27),char(1),char(82),char(0),char(8),char(179),char(2), -char(33),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(130), -char(0),char(0),char(3),char(39),char(6),char(33),char(2),char(38),char(0),char(85), -char(0),char(0),char(1),char(7),char(1),char(76),char(255),char(118),char(0),char(0), -char(0),char(8),char(179),char(1),char(28),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(106),char(255),char(236),char(4),char(2),char(7),char(115), -char(2),char(38),char(0),char(54),char(0),char(0),char(1),char(7),char(0),char(118), -char(0),char(80),char(1),char(82),char(0),char(8),char(179),char(1),char(46),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(106),char(255),char(236), -char(3),char(115),char(6),char(33),char(2),char(38),char(0),char(86),char(0),char(0), -char(1),char(6),char(0),char(118),char(234),char(0),char(0),char(8),char(179),char(1), -char(46),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(106), -char(255),char(236),char(4),char(2),char(7),char(115),char(2),char(38),char(0),char(54), -char(0),char(0),char(1),char(7),char(1),char(75),char(255),char(234),char(1),char(82), -char(0),char(8),char(179),char(1),char(51),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(106),char(255),char(236),char(3),char(115),char(6),char(33), -char(2),char(38),char(0),char(86),char(0),char(0),char(1),char(6),char(1),char(75), -char(151),char(0),char(0),char(8),char(179),char(1),char(51),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(106),char(254),char(20),char(4),char(2), -char(5),char(203),char(2),char(38),char(0),char(54),char(0),char(0),char(0),char(7), -char(0),char(122),char(1),char(39),char(0),char(0),char(255),char(255),char(0),char(106), -char(254),char(20),char(3),char(115),char(4),char(92),char(2),char(38),char(0),char(86), -char(0),char(0),char(0),char(7),char(0),char(122),char(0),char(213),char(0),char(0), -char(255),char(255),char(0),char(106),char(255),char(236),char(4),char(2),char(7),char(115), -char(2),char(38),char(0),char(54),char(0),char(0),char(1),char(7),char(1),char(76), -char(255),char(228),char(1),char(82),char(0),char(8),char(179),char(1),char(48),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(106),char(255),char(236), -char(3),char(115),char(6),char(33),char(2),char(38),char(0),char(86),char(0),char(0), -char(1),char(6),char(1),char(76),char(153),char(0),char(0),char(8),char(179),char(1), -char(48),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(18), -char(254),char(59),char(4),char(90),char(5),char(182),char(2),char(38),char(0),char(55), -char(0),char(0),char(0),char(6),char(2),char(57),char(25),char(0),char(255),char(255), -char(0),char(31),char(254),char(59),char(2),char(168),char(5),char(70),char(2),char(38), -char(0),char(87),char(0),char(0),char(0),char(6),char(2),char(57),char(130),char(0), -char(255),char(255),char(0),char(18),char(0),char(0),char(4),char(90),char(7),char(115), -char(2),char(38),char(0),char(55),char(0),char(0),char(1),char(7),char(1),char(76), -char(255),char(220),char(1),char(82),char(0),char(8),char(179),char(1),char(19),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(31),char(255),char(236), -char(2),char(215),char(6),char(20),char(2),char(38),char(0),char(87),char(0),char(0), -char(1),char(6),char(2),char(56),char(98),char(0),char(0),char(7),char(178),char(1), -char(26),char(0),char(0),char(63),char(53),char(0),char(0),char(1),char(0),char(18), -char(0),char(0),char(4),char(90),char(5),char(182),char(0),char(15),char(0),char(63), -char(64),char(33),char(7),char(11),char(11),char(0),char(12),char(4),char(9),char(12), -char(14),char(2),char(5),char(16),char(17),char(10),char(14),char(15),char(14),char(74), -char(89),char(7),char(15),char(15),char(3),char(12),char(18),char(6),char(2),char(3), -char(2),char(73),char(89),char(3),char(3),char(0),char(63),char(43),char(17),char(0), -char(51),char(24),char(63),char(18),char(57),char(47),char(51),char(43),char(17),char(0), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(1),char(17),char(33),char(53),char(33),char(21),char(33), -char(17),char(33),char(21),char(33),char(17),char(35),char(17),char(33),char(53),char(1), -char(225),char(254),char(49),char(4),char(72),char(254),char(49),char(1),char(54),char(254), -char(202),char(170),char(254),char(199),char(3),char(47),char(1),char(240),char(151),char(151), -char(254),char(16),char(141),char(253),char(94),char(2),char(162),char(141),char(0),char(1), -char(0),char(31),char(255),char(236),char(2),char(168),char(5),char(70),char(0),char(28), -char(0),char(76),char(64),char(41),char(23),char(19),char(27),char(27),char(12),char(8), -char(2),char(21),char(25),char(8),char(10),char(14),char(6),char(29),char(30),char(14), -char(22),char(19),char(22),char(71),char(89),char(26),char(10),char(11),char(10),char(71), -char(89),char(23),char(11),char(11),char(6),char(17),char(64),char(19),char(15),char(6), -char(0),char(70),char(89),char(6),char(22),char(0),char(63),char(43),char(0),char(24), -char(63),char(26),char(205),char(18),char(57),char(47),char(51),char(43),char(17),char(0), -char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(51),char(17),char(51),char(51),char(49),char(48),char(37),char(50), -char(55),char(21),char(6),char(6),char(35),char(32),char(17),char(53),char(35),char(53), -char(51),char(17),char(35),char(53),char(55),char(55),char(51),char(21),char(33),char(21), -char(33),char(17),char(33),char(21),char(33),char(21),char(20),char(2),char(23),char(85), -char(60),char(32),char(106),char(42),char(254),char(200),char(141),char(141),char(157),char(157), -char(70),char(96),char(1),char(62),char(254),char(194),char(1),char(45),char(254),char(211), -char(117),char(20),char(127),char(14),char(16),char(1),char(92),char(254),char(129),char(1), -char(0),char(80),char(69),char(234),char(254),char(129),char(255),char(0),char(129),char(244), -char(221),char(0),char(255),char(255),char(0),char(186),char(255),char(236),char(5),char(25), -char(7),char(47),char(2),char(38),char(0),char(56),char(0),char(0),char(1),char(7), -char(1),char(82),char(0),char(111),char(1),char(82),char(0),char(8),char(179),char(1), -char(27),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(164), -char(255),char(236),char(4),char(57),char(5),char(221),char(2),char(38),char(0),char(88), -char(0),char(0),char(1),char(6),char(1),char(82),char(247),char(0),char(0),char(8), -char(179),char(1),char(30),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(186),char(255),char(236),char(5),char(25),char(6),char(180),char(2),char(38), -char(0),char(56),char(0),char(0),char(1),char(7),char(1),char(77),char(0),char(145), -char(1),char(82),char(0),char(8),char(179),char(1),char(21),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236),char(4),char(57), -char(5),char(98),char(2),char(38),char(0),char(88),char(0),char(0),char(1),char(6), -char(1),char(77),char(25),char(0),char(0),char(8),char(179),char(1),char(24),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(186),char(255),char(236), -char(5),char(25),char(7),char(55),char(2),char(38),char(0),char(56),char(0),char(0), -char(1),char(7),char(1),char(78),char(0),char(139),char(1),char(82),char(0),char(8), -char(179),char(1),char(18),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(164),char(255),char(236),char(4),char(57),char(5),char(229),char(2),char(38), -char(0),char(88),char(0),char(0),char(1),char(6),char(1),char(78),char(18),char(0), -char(0),char(8),char(179),char(1),char(21),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(186),char(255),char(236),char(5),char(25),char(7),char(215), -char(2),char(38),char(0),char(56),char(0),char(0),char(1),char(7),char(1),char(80), -char(0),char(156),char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(21), -char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(164), -char(255),char(236),char(4),char(57),char(6),char(133),char(2),char(38),char(0),char(88), -char(0),char(0),char(1),char(6),char(1),char(80),char(35),char(0),char(0),char(10), -char(180),char(2),char(1),char(24),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(186),char(255),char(236),char(5),char(25),char(7),char(115), -char(2),char(38),char(0),char(56),char(0),char(0),char(1),char(7),char(1),char(83), -char(0),char(225),char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(37), -char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(164), -char(255),char(236),char(4),char(57),char(6),char(33),char(2),char(38),char(0),char(88), -char(0),char(0),char(1),char(6),char(1),char(83),char(104),char(0),char(0),char(10), -char(180),char(2),char(1),char(40),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(186),char(254),char(66),char(5),char(25),char(5),char(182), -char(2),char(38),char(0),char(56),char(0),char(0),char(0),char(7),char(1),char(81), -char(2),char(33),char(0),char(0),char(255),char(255),char(0),char(164),char(254),char(66), -char(4),char(101),char(4),char(72),char(2),char(38),char(0),char(88),char(0),char(0), -char(0),char(7),char(1),char(81),char(2),char(244),char(0),char(0),char(255),char(255), -char(0),char(27),char(0),char(0),char(7),char(76),char(7),char(115),char(2),char(38), -char(0),char(58),char(0),char(0),char(1),char(7),char(1),char(75),char(1),char(84), -char(1),char(82),char(0),char(8),char(179),char(1),char(40),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(23),char(0),char(0),char(6),char(35), -char(6),char(33),char(2),char(38),char(0),char(90),char(0),char(0),char(1),char(7), -char(1),char(75),char(0),char(193),char(0),char(0),char(0),char(8),char(179),char(1), -char(43),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(0), -char(0),char(0),char(4),char(123),char(7),char(115),char(2),char(38),char(0),char(60), -char(0),char(0),char(1),char(7),char(1),char(75),char(255),char(224),char(1),char(82), -char(0),char(8),char(179),char(1),char(23),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(2),char(254),char(20),char(4),char(6),char(6),char(33), -char(2),char(38),char(0),char(92),char(0),char(0),char(1),char(6),char(1),char(75), -char(173),char(0),char(0),char(8),char(179),char(1),char(36),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(0),char(0),char(0),char(4),char(123), -char(7),char(37),char(2),char(38),char(0),char(60),char(0),char(0),char(1),char(7), -char(0),char(106),char(255),char(241),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(30),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(82),char(0),char(0),char(4),char(63),char(7),char(115),char(2),char(38), -char(0),char(61),char(0),char(0),char(1),char(7),char(0),char(118),char(0),char(66), -char(1),char(82),char(0),char(8),char(179),char(1),char(19),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(82),char(0),char(0),char(3),char(109), -char(6),char(33),char(2),char(38),char(0),char(93),char(0),char(0),char(1),char(6), -char(0),char(118),char(232),char(0),char(0),char(8),char(179),char(1),char(19),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(82),char(0),char(0), -char(4),char(63),char(7),char(49),char(2),char(38),char(0),char(61),char(0),char(0), -char(1),char(7),char(1),char(79),char(1),char(68),char(1),char(82),char(0),char(8), -char(179),char(1),char(19),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(82),char(0),char(0),char(3),char(109),char(5),char(223),char(2),char(38), -char(0),char(93),char(0),char(0),char(1),char(7),char(1),char(79),char(0),char(223), -char(0),char(0),char(0),char(8),char(179),char(1),char(19),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(82),char(0),char(0),char(4),char(63), -char(7),char(115),char(2),char(38),char(0),char(61),char(0),char(0),char(1),char(7), -char(1),char(76),char(255),char(237),char(1),char(82),char(0),char(8),char(179),char(1), -char(21),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(82), -char(0),char(0),char(3),char(109),char(6),char(33),char(2),char(38),char(0),char(93), -char(0),char(0),char(1),char(6),char(1),char(76),char(134),char(0),char(0),char(8), -char(179),char(1),char(21),char(17),char(38),char(0),char(43),char(53),char(0),char(1), -char(0),char(176),char(0),char(0),char(2),char(219),char(6),char(31),char(0),char(12), -char(0),char(29),char(64),char(14),char(0),char(1),char(1),char(13),char(6),char(14), -char(4),char(9),char(70),char(89),char(4),char(0),char(1),char(21),char(0),char(63), -char(63),char(43),char(17),char(1),char(51),char(18),char(57),char(17),char(51),char(49), -char(48),char(33),char(35),char(17),char(16),char(33),char(50),char(23),char(7),char(38), -char(35),char(34),char(6),char(21),char(1),char(86),char(166),char(1),char(103),char(96), -char(100),char(43),char(87),char(73),char(97),char(89),char(4),char(156),char(1),char(131), -char(37),char(133),char(30),char(123),char(122),char(0),char(0),char(1),char(0),char(195), -char(254),char(20),char(4),char(23),char(5),char(203),char(0),char(32),char(0),char(68), -char(64),char(36),char(26),char(30),char(30),char(12),char(8),char(18),char(28),char(8), -char(10),char(2),char(5),char(33),char(34),char(29),char(10),char(12),char(10),char(70), -char(89),char(26),char(12),char(12),char(16),char(0),char(16),char(22),char(70),char(89), -char(16),char(4),char(0),char(5),char(70),char(89),char(0),char(27),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(34), -char(39),char(53),char(22),char(51),char(50),char(54),char(53),char(17),char(35),char(53), -char(55),char(53),char(52),char(54),char(51),char(50),char(23),char(7),char(7),char(38), -char(35),char(34),char(6),char(21),char(21),char(33),char(21),char(33),char(17),char(20), -char(6),char(1),char(72),char(69),char(64),char(70),char(61),char(95),char(77),char(222), -char(222),char(162),char(182),char(85),char(120),char(22),char(21),char(102),char(60),char(98), -char(80),char(1),char(26),char(254),char(234),char(158),char(254),char(20),char(19),char(139), -char(18),char(102),char(113),char(3),char(205),char(75),char(60),char(139),char(195),char(178), -char(43),char(64),char(65),char(32),char(105),char(124),char(149),char(129),char(252),char(55), -char(184),char(175),char(0),char(4),char(0),char(0),char(0),char(0),char(5),char(20), -char(7),char(170),char(0),char(16),char(0),char(24),char(0),char(34),char(0),char(46), -char(0),char(97),char(64),char(52),char(17),char(5),char(4),char(24),char(6),char(20), -char(7),char(4),char(3),char(7),char(8),char(35),char(0),char(41),char(11),char(8), -char(11),char(9),char(34),char(20),char(2),char(0),char(29),char(3),char(9),char(48), -char(47),char(38),char(14),char(44),char(2),char(9),char(24),char(6),char(73),char(89), -char(9),char(20),char(14),char(24),char(34),char(14),char(24),char(24),char(14),char(34), -char(3),char(8),char(28),char(4),char(8),char(18),char(0),char(63),char(51),char(47), -char(18),char(23),char(57),char(47),char(47),char(47),char(17),char(18),char(57),char(57), -char(43),char(17),char(0),char(51),char(51),char(17),char(51),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(17),char(18),char(57),char(57),char(17),char(57),char(57),char(49),char(48),char(1), -char(20),char(7),char(1),char(35),char(3),char(33),char(3),char(35),char(1),char(38), -char(53),char(52),char(54),char(51),char(50),char(22),char(19),char(3),char(38),char(39), -char(6),char(6),char(7),char(3),char(19),char(54),char(54),char(55),char(51),char(21), -char(6),char(6),char(7),char(35),char(19),char(52),char(38),char(35),char(34),char(6), -char(21),char(20),char(22),char(51),char(50),char(54),char(3),char(104),char(104),char(2), -char(20),char(174),char(176),char(253),char(158),char(166),char(174),char(2),char(20),char(106), -char(122),char(99),char(100),char(125),char(27),char(178),char(25),char(47),char(14),char(48), -char(9),char(177),char(152),char(49),char(102),char(23),char(203),char(32),char(168),char(66), -char(111),char(211),char(66),char(51),char(51),char(66),char(60),char(57),char(53),char(64), -char(5),char(150),char(133),char(56),char(251),char(39),char(1),char(145),char(254),char(111), -char(4),char(215),char(52),char(136),char(101),char(114),char(117),char(252),char(54),char(1), -char(176),char(58),char(145),char(48),char(135),char(24),char(254),char(84),char(4),char(133), -char(59),char(149),char(42),char(16),char(46),char(161),char(45),char(254),char(245),char(57), -char(60),char(60),char(57),char(55),char(61),char(61),char(0),char(5),char(0),char(94), -char(255),char(236),char(3),char(205),char(7),char(170),char(0),char(9),char(0),char(36), -char(0),char(47),char(0),char(59),char(0),char(71),char(0),char(103),char(64),char(55), -char(45),char(18),char(66),char(54),char(60),char(48),char(41),char(21),char(21),char(11), -char(36),char(36),char(6),char(48),char(0),char(54),char(29),char(18),char(7),char(72), -char(73),char(9),char(9),char(4),char(63),char(57),char(69),char(51),char(17),char(11), -char(12),char(21),char(41),char(71),char(89),char(12),char(21),char(21),char(15),char(32), -char(32),char(25),char(70),char(89),char(32),char(16),char(15),char(37),char(70),char(89), -char(15),char(22),char(10),char(21),char(4),char(0),char(47),char(63),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(57),char(43),char(17),char(0),char(51),char(24),char(63),char(51),char(196),char(50), -char(17),char(57),char(47),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(53),char(54),char(54),char(55),char(33),char(21),char(6),char(6), -char(7),char(1),char(39),char(35),char(6),char(6),char(35),char(34),char(38),char(53), -char(16),char(37),char(55),char(53),char(52),char(38),char(35),char(34),char(6),char(7), -char(39),char(54),char(54),char(51),char(50),char(22),char(21),char(17),char(37),char(50), -char(54),char(53),char(53),char(7),char(6),char(6),char(21),char(20),char(22),char(1), -char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51),char(50), -char(22),char(7),char(52),char(38),char(35),char(34),char(6),char(21),char(20),char(22), -char(51),char(50),char(54),char(1),char(215),char(46),char(106),char(22),char(1),char(4), -char(21),char(164),char(128),char(1),char(2),char(33),char(8),char(82),char(163),char(122), -char(163),char(185),char(2),char(25),char(180),char(119),char(133),char(96),char(167),char(71), -char(55),char(84),char(208),char(101),char(209),char(201),char(254),char(14),char(155),char(177), -char(166),char(198),char(175),char(109),char(1),char(170),char(123),char(102),char(101),char(121), -char(121),char(101),char(101),char(124),char(109),char(65),char(51),char(51),char(66),char(60), -char(57),char(52),char(64),char(6),char(217),char(16),char(42),char(120),char(31),char(12), -char(24),char(105),char(68),char(249),char(39),char(156),char(103),char(73),char(168),char(155), -char(1),char(76),char(16),char(6),char(68),char(130),char(122),char(52),char(32),char(127), -char(43),char(51),char(174),char(192),char(253),char(20),char(117),char(170),char(153),char(99), -char(7),char(7),char(109),char(115),char(90),char(94),char(5),char(61),char(98),char(119), -char(116),char(99),char(98),char(115),char(119),char(94),char(56),char(61),char(61),char(56), -char(56),char(61),char(61),char(0),char(255),char(255),char(255),char(254),char(0),char(0), -char(6),char(129),char(7),char(115),char(2),char(38),char(0),char(136),char(0),char(0), -char(1),char(7),char(0),char(118),char(2),char(76),char(1),char(82),char(0),char(8), -char(179),char(2),char(29),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(94),char(255),char(236),char(6),char(115),char(6),char(33),char(2),char(38), -char(0),char(168),char(0),char(0),char(1),char(7),char(0),char(118),char(1),char(133), -char(0),char(0),char(0),char(8),char(179),char(3),char(69),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(195),char(5),char(190), -char(7),char(115),char(2),char(38),char(0),char(154),char(0),char(0),char(1),char(7), -char(0),char(118),char(1),char(25),char(1),char(82),char(0),char(8),char(179),char(3), -char(45),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(255),char(188),char(4),char(98),char(6),char(33),char(2),char(38),char(0),char(186), -char(0),char(0),char(1),char(6),char(0),char(118),char(86),char(0),char(0),char(8), -char(179),char(3),char(45),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(106),char(254),char(59),char(4),char(2),char(5),char(203),char(2),char(38), -char(0),char(54),char(0),char(0),char(0),char(6),char(2),char(57),char(6),char(0), -char(255),char(255),char(0),char(106),char(254),char(59),char(3),char(115),char(4),char(92), -char(2),char(38),char(0),char(86),char(0),char(0),char(0),char(6),char(2),char(57), -char(185),char(0),char(0),char(1),char(1),char(12),char(4),char(217),char(3),char(174), -char(6),char(33),char(0),char(14),char(0),char(24),char(64),char(9),char(7),char(0), -char(16),char(15),char(11),char(4),char(128),char(14),char(9),char(0),char(47),char(51), -char(26),char(205),char(50),char(17),char(18),char(1),char(57),char(57),char(49),char(48), -char(1),char(54),char(54),char(55),char(51),char(22),char(22),char(23),char(21),char(35), -char(38),char(39),char(6),char(7),char(35),char(1),char(12),char(127),char(102),char(23), -char(166),char(22),char(109),char(125),char(119),char(88),char(133),char(136),char(83),char(115), -char(4),char(240),char(136),char(128),char(41),char(42),char(133),char(130),char(23),char(55), -char(131),char(134),char(52),char(0),char(0),char(1),char(1),char(12),char(4),char(217), -char(3),char(174),char(6),char(33),char(0),char(14),char(0),char(24),char(64),char(9), -char(6),char(0),char(16),char(15),char(5),char(1),char(128),char(3),char(11),char(0), -char(47),char(51),char(26),char(205),char(50),char(17),char(18),char(1),char(57),char(57), -char(49),char(48),char(1),char(51),char(22),char(23),char(54),char(55),char(51),char(21), -char(7),char(6),char(7),char(35),char(38),char(38),char(39),char(1),char(12),char(115), -char(114),char(105),char(130),char(91),char(119),char(66),char(144),char(46),char(166),char(23), -char(102),char(127),char(6),char(33),char(74),char(115),char(130),char(59),char(25),char(68), -char(148),char(87),char(41),char(126),char(136),char(0),char(0),char(1),char(1),char(45), -char(4),char(217),char(3),char(133),char(5),char(98),char(0),char(3),char(0),char(17), -char(181),char(0),char(1),char(4),char(5),char(0),char(3),char(0),char(47),char(51), -char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(1),char(33),char(21), -char(33),char(1),char(45),char(2),char(88),char(253),char(168),char(5),char(98),char(137), -char(0),char(1),char(1),char(37),char(4),char(217),char(3),char(145),char(5),char(229), -char(0),char(14),char(0),char(24),char(64),char(9),char(12),char(3),char(16),char(15), -char(11),char(4),char(128),char(8),char(0),char(0),char(47),char(50),char(26),char(204), -char(50),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(1),char(34), -char(38),char(39),char(51),char(30),char(2),char(51),char(50),char(54),char(55),char(51), -char(6),char(6),char(2),char(86),char(140),char(156),char(9),char(104),char(6),char(41), -char(73),char(85),char(101),char(96),char(10),char(104),char(10),char(167),char(4),char(217), -char(137),char(131),char(49),char(56),char(26),char(64),char(67),char(126),char(142),char(0), -char(0),char(1),char(0),char(162),char(5),char(2),char(1),char(102),char(5),char(223), -char(0),char(11),char(0),char(19),char(182),char(6),char(0),char(0),char(12),char(13), -char(3),char(9),char(0),char(47),char(205),char(17),char(18),char(1),char(57),char(17), -char(51),char(49),char(48),char(19),char(52),char(54),char(51),char(50),char(22),char(21), -char(20),char(6),char(35),char(34),char(38),char(162),char(56),char(42),char(40),char(58), -char(58),char(40),char(42),char(56),char(5),char(113),char(57),char(53),char(54),char(56), -char(56),char(55),char(55),char(0),char(0),char(2),char(1),char(111),char(4),char(217), -char(3),char(45),char(6),char(133),char(0),char(11),char(0),char(23),char(0),char(30), -char(64),char(12),char(18),char(6),char(12),char(0),char(6),char(0),char(24),char(25), -char(15),char(9),char(21),char(3),char(0),char(47),char(51),char(204),char(50),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51), -char(50),char(22),char(7),char(52),char(38),char(35),char(34),char(6),char(21),char(20), -char(22),char(51),char(50),char(54),char(3),char(45),char(123),char(102),char(101),char(120), -char(121),char(100),char(101),char(124),char(108),char(66),char(51),char(51),char(66),char(60), -char(57),char(52),char(65),char(5),char(178),char(98),char(119),char(117),char(98),char(98), -char(115),char(119),char(94),char(56),char(61),char(61),char(56),char(56),char(61),char(61), -char(0),char(1),char(0),char(37),char(254),char(66),char(1),char(113),char(0),char(0), -char(0),char(15),char(0),char(24),char(64),char(10),char(0),char(9),char(4),char(13), -char(9),char(3),char(16),char(17),char(2),char(7),char(0),char(47),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48),char(23),char(20), -char(51),char(50),char(55),char(21),char(6),char(35),char(34),char(53),char(52),char(54), -char(55),char(51),char(6),char(6),char(178),char(94),char(42),char(55),char(65),char(60), -char(207),char(86),char(72),char(120),char(68),char(69),char(238),char(94),char(13),char(109), -char(18),char(188),char(70),char(135),char(53),char(66),char(109),char(0),char(0),char(1), -char(1),char(8),char(4),char(217),char(3),char(240),char(5),char(221),char(0),char(23), -char(0),char(36),char(64),char(15),char(9),char(21),char(24),char(25),char(17),char(0), -char(5),char(12),char(0),char(12),char(0),char(12),char(21),char(128),char(9),char(0), -char(47),char(26),char(204),char(57),char(57),char(47),char(47),char(17),char(51),char(17), -char(51),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(1),char(34), -char(46),char(2),char(35),char(34),char(6),char(7),char(35),char(54),char(54),char(51), -char(50),char(30),char(2),char(51),char(50),char(54),char(55),char(51),char(6),char(6), -char(3),char(20),char(43),char(82),char(79),char(73),char(34),char(50),char(51),char(14), -char(98),char(13),char(115),char(91),char(46),char(86),char(78),char(72),char(32),char(49), -char(48),char(15),char(99),char(13),char(113),char(4),char(219),char(37),char(45),char(37), -char(60),char(61),char(121),char(137),char(37),char(45),char(37),char(59),char(62),char(121), -char(137),char(0),char(0),char(2),char(0),char(231),char(4),char(217),char(3),char(182), -char(6),char(33),char(0),char(9),char(0),char(19),char(0),char(27),char(64),char(12), -char(14),char(5),char(19),char(9),char(4),char(20),char(21),char(13),char(4),char(128), -char(19),char(9),char(0),char(47),char(51),char(26),char(205),char(50),char(17),char(18), -char(1),char(23),char(57),char(49),char(48),char(19),char(54),char(54),char(55),char(51), -char(21),char(6),char(6),char(7),char(35),char(37),char(54),char(54),char(55),char(51), -char(21),char(6),char(6),char(7),char(35),char(231),char(36),char(110),char(31),char(186), -char(37),char(171),char(58),char(97),char(1),char(101),char(49),char(101),char(26),char(186), -char(37),char(171),char(58),char(96),char(4),char(242),char(48),char(186),char(69),char(21), -char(63),char(196),char(48),char(25),char(68),char(177),char(58),char(21),char(63),char(196), -char(48),char(0),char(0),char(1),char(1),char(252),char(4),char(217),char(3),char(16), -char(6),char(115),char(0),char(9),char(0),char(19),char(182),char(4),char(0),char(11), -char(10),char(4),char(128),char(9),char(0),char(47),char(26),char(205),char(17),char(18), -char(1),char(57),char(57),char(49),char(48),char(1),char(54),char(54),char(55),char(51), -char(21),char(6),char(6),char(7),char(35),char(1),char(252),char(27),char(53),char(12), -char(184),char(18),char(109),char(49),char(100),char(4),char(246),char(72),char(227),char(82), -char(23),char(74),char(237),char(76),char(0),char(3),char(1),char(27),char(5),char(14), -char(3),char(131),char(6),char(180),char(0),char(8),char(0),char(20),char(0),char(32), -char(0),char(43),char(64),char(20),char(15),char(9),char(21),char(27),char(27),char(3), -char(8),char(9),char(4),char(33),char(34),char(24),char(12),char(8),char(12),char(8), -char(12),char(3),char(30),char(18),char(0),char(47),char(51),char(204),char(57),char(57), -char(47),char(47),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(54),char(55),char(51),char(21), -char(6),char(6),char(7),char(35),char(39),char(52),char(54),char(51),char(50),char(22), -char(21),char(20),char(6),char(35),char(34),char(38),char(37),char(52),char(54),char(51), -char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(2),char(0), -char(65),char(31),char(189),char(33),char(121),char(51),char(80),char(229),char(52),char(38), -char(41),char(49),char(55),char(35),char(38),char(52),char(1),char(180),char(52),char(38), -char(41),char(49),char(55),char(35),char(38),char(52),char(5),char(133),char(169),char(134), -char(20),char(67),char(179),char(61),char(4),char(52),char(46),char(52),char(46),char(50), -char(49),char(49),char(50),char(52),char(46),char(52),char(46),char(50),char(49),char(49), -char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16),char(6),char(10), -char(2),char(38),char(0),char(36),char(0),char(0),char(1),char(7),char(1),char(84), -char(254),char(32),char(255),char(151),char(0),char(7),char(178),char(2),char(18),char(0), -char(0),char(63),char(53),char(0),char(255),char(255),char(0),char(152),char(2),char(76), -char(1),char(137),char(3),char(90),char(2),char(6),char(0),char(121),char(0),char(0), -char(255),char(255),char(255),char(212),char(0),char(0),char(4),char(117),char(6),char(10), -char(0),char(38),char(0),char(40),char(125),char(0),char(1),char(7),char(1),char(84), -char(253),char(216),char(255),char(151),char(0),char(7),char(178),char(1),char(16),char(0), -char(0),char(63),char(53),char(0),char(255),char(255),char(255),char(212),char(0),char(0), -char(5),char(181),char(6),char(10),char(0),char(39),char(0),char(43),char(0),char(150), -char(0),char(0),char(1),char(7),char(1),char(84),char(253),char(216),char(255),char(151), -char(0),char(7),char(178),char(1),char(16),char(0),char(0),char(63),char(53),char(0), -char(255),char(255),char(255),char(228),char(0),char(0),char(3),char(68),char(6),char(10), -char(0),char(39),char(0),char(44),char(0),char(238),char(0),char(0),char(1),char(7), -char(1),char(84),char(253),char(232),char(255),char(151),char(0),char(7),char(178),char(1), -char(16),char(0),char(0),char(63),char(53),char(0),char(255),char(255),char(255),char(228), -char(255),char(236),char(6),char(2),char(6),char(10),char(0),char(38),char(0),char(50), -char(68),char(0),char(1),char(7),char(1),char(84),char(253),char(232),char(255),char(151), -char(0),char(7),char(178),char(2),char(28),char(0),char(0),char(63),char(53),char(0), -char(255),char(255),char(255),char(212),char(0),char(0),char(5),char(133),char(6),char(10), -char(0),char(39),char(0),char(60),char(1),char(10),char(0),char(0),char(1),char(7), -char(1),char(84),char(253),char(216),char(255),char(151),char(0),char(7),char(178),char(1), -char(13),char(0),char(0),char(63),char(53),char(0),char(255),char(255),char(255),char(228), -char(0),char(0),char(6),char(51),char(6),char(10),char(0),char(38),char(1),char(118), -char(63),char(0),char(1),char(7),char(1),char(84),char(253),char(232),char(255),char(151), -char(0),char(7),char(178),char(1),char(35),char(0),char(0),char(63),char(53),char(0), -char(255),char(255),char(255),char(233),char(255),char(236),char(2),char(147),char(6),char(180), -char(2),char(38),char(1),char(134),char(0),char(0),char(1),char(7),char(1),char(85), -char(254),char(206),char(0),char(0),char(0),char(12),char(181),char(3),char(2),char(1), -char(46),char(17),char(38),char(0),char(43),char(53),char(53),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(5),char(188),char(2),char(6), -char(0),char(36),char(0),char(0),char(255),char(255),char(0),char(201),char(0),char(0), -char(4),char(190),char(5),char(182),char(2),char(6),char(0),char(37),char(0),char(0), -char(0),char(1),char(0),char(201),char(0),char(0),char(3),char(248),char(5),char(182), -char(0),char(5),char(0),char(29),char(64),char(14),char(3),char(4),char(4),char(0), -char(6),char(7),char(5),char(2),char(73),char(89),char(5),char(3),char(4),char(18), -char(0),char(63),char(63),char(43),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(49),char(48),char(1),char(21),char(33),char(17),char(35),char(17),char(3), -char(248),char(253),char(123),char(170),char(5),char(182),char(153),char(250),char(227),char(5), -char(182),char(0),char(255),char(255),char(0),char(39),char(0),char(0),char(4),char(109), -char(5),char(182),char(2),char(6),char(2),char(40),char(0),char(0),char(255),char(255), -char(0),char(201),char(0),char(0),char(3),char(248),char(5),char(182),char(2),char(6), -char(0),char(40),char(0),char(0),char(255),char(255),char(0),char(82),char(0),char(0), -char(4),char(63),char(5),char(182),char(2),char(6),char(0),char(61),char(0),char(0), -char(255),char(255),char(0),char(201),char(0),char(0),char(5),char(31),char(5),char(182), -char(2),char(6),char(0),char(43),char(0),char(0),char(0),char(3),char(0),char(125), -char(255),char(236),char(5),char(190),char(5),char(205),char(0),char(3),char(0),char(15), -char(0),char(27),char(0),char(63),char(64),char(32),char(2),char(3),char(16),char(22), -char(16),char(10),char(22),char(4),char(10),char(4),char(28),char(29),char(0),char(3), -char(73),char(89),char(0),char(0),char(7),char(13),char(13),char(25),char(73),char(89), -char(13),char(4),char(7),char(19),char(73),char(89),char(7),char(19),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17), -char(51),char(17),char(18),char(57),char(57),char(49),char(48),char(1),char(33),char(21), -char(33),char(37),char(16),char(0),char(33),char(32),char(0),char(17),char(16),char(0), -char(33),char(32),char(0),char(1),char(16),char(18),char(51),char(50),char(18),char(17), -char(16),char(2),char(35),char(34),char(2),char(1),char(227),char(2),char(117),char(253), -char(139),char(3),char(219),char(254),char(157),char(254),char(196),char(254),char(189),char(254), -char(161),char(1),char(96),char(1),char(68),char(1),char(59),char(1),char(98),char(251), -char(115),char(250),char(244),char(243),char(248),char(247),char(242),char(245),char(251),char(3), -char(51),char(149),char(63),char(254),char(161),char(254),char(110),char(1),char(139),char(1), -char(104),char(1),char(101),char(1),char(137),char(254),char(112),char(254),char(160),char(254), -char(216),char(254),char(204),char(1),char(48),char(1),char(44),char(1),char(42),char(1), -char(46),char(254),char(206),char(0),char(255),char(255),char(0),char(84),char(0),char(0), -char(2),char(86),char(5),char(182),char(2),char(6),char(0),char(44),char(0),char(0), -char(255),char(255),char(0),char(201),char(0),char(0),char(4),char(233),char(5),char(182), -char(2),char(6),char(0),char(46),char(0),char(0),char(0),char(1),char(0),char(0), -char(0),char(0),char(4),char(211),char(5),char(182),char(0),char(10),char(0),char(26), -char(64),char(11),char(8),char(0),char(12),char(11),char(4),char(8),char(9),char(3), -char(1),char(8),char(18),char(0),char(63),char(51),char(63),char(18),char(57),char(17), -char(18),char(1),char(57),char(57),char(49),char(48),char(33),char(35),char(1),char(38), -char(39),char(6),char(7),char(1),char(35),char(1),char(51),char(4),char(211),char(182), -char(254),char(182),char(87),char(22),char(33),char(71),char(254),char(184),char(182),char(2), -char(16),char(177),char(3),char(160),char(252),char(90),char(139),char(201),char(252),char(94), -char(5),char(182),char(255),char(255),char(0),char(201),char(0),char(0),char(6),char(113), -char(5),char(182),char(2),char(6),char(0),char(48),char(0),char(0),char(255),char(255), -char(0),char(201),char(0),char(0),char(5),char(63),char(5),char(182),char(2),char(6), -char(0),char(49),char(0),char(0),char(0),char(3),char(0),char(72),char(0),char(0), -char(4),char(37),char(5),char(182),char(0),char(3),char(0),char(7),char(0),char(11), -char(0),char(52),char(64),char(29),char(10),char(7),char(3),char(2),char(6),char(8), -char(6),char(13),char(12),char(0),char(3),char(73),char(89),char(0),char(0),char(10), -char(4),char(10),char(11),char(73),char(89),char(10),char(18),char(4),char(7),char(73), -char(89),char(4),char(3),char(0),char(63),char(43),char(0),char(24),char(63),char(43), -char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(1), -char(23),char(57),char(49),char(48),char(19),char(33),char(21),char(33),char(3),char(33), -char(21),char(33),char(1),char(21),char(33),char(53),char(195),char(2),char(231),char(253), -char(25),char(82),char(3),char(139),char(252),char(117),char(3),char(180),char(252),char(35), -char(3),char(72),char(150),char(3),char(4),char(151),char(251),char(121),char(152),char(152), -char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190),char(5),char(205), -char(2),char(6),char(0),char(50),char(0),char(0),char(0),char(1),char(0),char(201), -char(0),char(0),char(5),char(12),char(5),char(182),char(0),char(7),char(0),char(35), -char(64),char(17),char(1),char(0),char(4),char(5),char(0),char(5),char(9),char(8), -char(6),char(3),char(73),char(89),char(6),char(3),char(1),char(5),char(18),char(0), -char(63),char(51),char(63),char(43),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(17),char(51),char(49),char(48),char(33),char(35),char(17),char(33),char(17), -char(35),char(17),char(33),char(5),char(12),char(170),char(253),char(17),char(170),char(4), -char(67),char(5),char(31),char(250),char(225),char(5),char(182),char(0),char(255),char(255), -char(0),char(201),char(0),char(0),char(4),char(104),char(5),char(182),char(2),char(6), -char(0),char(51),char(0),char(0),char(0),char(1),char(0),char(74),char(0),char(0), -char(4),char(92),char(5),char(182),char(0),char(12),char(0),char(53),char(64),char(28), -char(8),char(10),char(10),char(0),char(9),char(2),char(11),char(6),char(3),char(2), -char(0),char(5),char(13),char(14),char(7),char(8),char(4),char(8),char(73),char(89), -char(4),char(3),char(0),char(10),char(73),char(89),char(0),char(18),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(0),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(51),char(53),char(1),char(1),char(53),char(33),char(21),char(33),char(39), -char(1),char(1),char(33),char(21),char(74),char(1),char(225),char(254),char(43),char(3), -char(203),char(253),char(92),char(96),char(1),char(204),char(254),char(31),char(3),char(84), -char(141),char(2),char(111),char(2),char(43),char(143),char(153),char(2),char(253),char(223), -char(253),char(154),char(152),char(0),char(255),char(255),char(0),char(18),char(0),char(0), -char(4),char(90),char(5),char(182),char(2),char(6),char(0),char(55),char(0),char(0), -char(255),char(255),char(0),char(0),char(0),char(0),char(4),char(123),char(5),char(182), -char(2),char(6),char(0),char(60),char(0),char(0),char(0),char(3),char(0),char(106), -char(255),char(236),char(5),char(248),char(5),char(203),char(0),char(25),char(0),char(34), -char(0),char(43),char(0),char(80),char(64),char(41),char(39),char(20),char(26),char(2), -char(13),char(13),char(43),char(25),char(14),char(30),char(7),char(7),char(14),char(20), -char(3),char(44),char(45),char(12),char(16),char(26),char(42),char(16),char(42),char(74), -char(89),char(34),char(36),char(24),char(36),char(74),char(89),char(2),char(24),char(16), -char(24),char(16),char(24),char(14),char(19),char(0),char(4),char(0),char(63),char(63), -char(57),char(57),char(47),char(47),char(17),char(51),char(43),char(17),char(0),char(51), -char(43),char(17),char(0),char(51),char(17),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(51),char(51),char(17),char(51),char(51), -char(17),char(51),char(49),char(48),char(1),char(51),char(21),char(51),char(50),char(22), -char(22),char(21),char(20),char(2),char(4),char(35),char(35),char(21),char(35),char(53), -char(35),char(34),char(36),char(2),char(53),char(52),char(54),char(54),char(51),char(51), -char(19),char(51),char(50),char(54),char(53),char(52),char(38),char(43),char(3),char(34), -char(6),char(21),char(20),char(22),char(51),char(51),char(2),char(219),char(172),char(70), -char(171),char(251),char(133),char(149),char(254),char(253),char(176),char(41),char(172),char(45), -char(176),char(254),char(254),char(146),char(135),char(252),char(171),char(67),char(172),char(25), -char(201),char(223),char(206),char(185),char(58),char(172),char(57),char(182),char(209),char(222), -char(202),char(24),char(5),char(203),char(180),char(136),char(248),char(159),char(166),char(254), -char(253),char(130),char(225),char(225),char(132),char(1),char(4),char(161),char(158),char(248), -char(139),char(252),char(69),char(219),char(195),char(185),char(210),char(212),char(183),char(197), -char(217),char(0),char(255),char(255),char(0),char(8),char(0),char(0),char(4),char(150), -char(5),char(182),char(2),char(6),char(0),char(59),char(0),char(0),char(0),char(1), -char(0),char(109),char(0),char(0),char(5),char(242),char(5),char(182),char(0),char(29), -char(0),char(62),char(64),char(31),char(10),char(7),char(17),char(0),char(0),char(14), -char(1),char(21),char(24),char(24),char(1),char(7),char(3),char(30),char(31),char(29), -char(3),char(13),char(3),char(73),char(89),char(17),char(13),char(13),char(1),char(22), -char(15),char(8),char(3),char(1),char(18),char(0),char(63),char(63),char(51),char(51), -char(18),char(57),char(47),char(51),char(43),char(17),char(0),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(33),char(35),char(17),char(35),char(34),char(38), -char(38),char(53),char(17),char(51),char(17),char(20),char(22),char(51),char(51),char(17), -char(51),char(17),char(51),char(50),char(54),char(53),char(17),char(51),char(17),char(20), -char(6),char(4),char(35),char(35),char(3),char(131),char(170),char(45),char(176),char(255), -char(144),char(174),char(207),char(212),char(27),char(170),char(29),char(211),char(207),char(176), -char(144),char(254),char(253),char(175),char(45),char(1),char(190),char(122),char(247),char(164), -char(1),char(227),char(254),char(33),char(188),char(201),char(3),char(100),char(252),char(156), -char(198),char(187),char(1),char(227),char(254),char(31),char(165),char(247),char(123),char(0), -char(0),char(1),char(0),char(80),char(0),char(0),char(5),char(244),char(5),char(205), -char(0),char(31),char(0),char(57),char(64),char(32),char(3),char(13),char(29),char(19), -char(24),char(19),char(22),char(25),char(7),char(10),char(13),char(8),char(8),char(32), -char(33),char(16),char(0),char(73),char(89),char(16),char(4),char(26),char(22),char(6), -char(9),char(8),char(9),char(73),char(89),char(25),char(8),char(18),char(0),char(63), -char(51),char(43),char(17),char(0),char(51),char(51),char(51),char(24),char(63),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(34),char(2),char(21),char(20),char(18),char(23),char(21),char(33), -char(53),char(33),char(38),char(2),char(53),char(16),char(0),char(33),char(32),char(0), -char(17),char(20),char(2),char(7),char(33),char(21),char(33),char(53),char(54),char(18), -char(53),char(52),char(2),char(3),char(33),char(238),char(250),char(173),char(180),char(253), -char(182),char(1),char(108),char(151),char(160),char(1),char(98),char(1),char(58),char(1), -char(59),char(1),char(98),char(158),char(151),char(1),char(107),char(253),char(182),char(183), -char(169),char(249),char(5),char(53),char(254),char(255),char(253),char(225),char(254),char(179), -char(132),char(133),char(152),char(118),char(1),char(94),char(203),char(1),char(54),char(1), -char(96),char(254),char(165),char(254),char(199),char(207),char(254),char(166),char(120),char(152), -char(133),char(134),char(1),char(78),char(222),char(252),char(1),char(2),char(255),char(255), -char(0),char(60),char(0),char(0),char(2),char(111),char(7),char(37),char(2),char(38), -char(0),char(44),char(0),char(0),char(1),char(7),char(0),char(106),char(255),char(7), -char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(33),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(0),char(0),char(0), -char(4),char(123),char(7),char(37),char(2),char(38),char(0),char(60),char(0),char(0), -char(1),char(7),char(0),char(106),char(255),char(239),char(1),char(82),char(0),char(10), -char(180),char(2),char(1),char(30),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(199),char(6),char(115), -char(2),char(38),char(1),char(126),char(0),char(0),char(1),char(6),char(1),char(84), -char(29),char(0),char(0),char(8),char(179),char(2),char(52),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(90),char(255),char(236),char(3),char(135), -char(6),char(115),char(2),char(38),char(1),char(130),char(0),char(0),char(1),char(6), -char(1),char(84),char(200),char(0),char(0),char(8),char(179),char(1),char(47),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(176),char(254),char(20), -char(4),char(68),char(6),char(115),char(2),char(38),char(1),char(132),char(0),char(0), -char(1),char(6),char(1),char(84),char(59),char(0),char(0),char(8),char(179),char(1), -char(30),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(168), -char(255),char(236),char(2),char(147),char(6),char(115),char(2),char(38),char(1),char(134), -char(0),char(0),char(1),char(7),char(1),char(84),char(254),char(196),char(0),char(0), -char(0),char(8),char(179),char(1),char(25),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(164),char(255),char(236),char(4),char(113),char(6),char(180), -char(2),char(38),char(1),char(146),char(0),char(0),char(1),char(6),char(1),char(85), -char(59),char(0),char(0),char(12),char(181),char(3),char(2),char(1),char(52),char(17), -char(38),char(0),char(43),char(53),char(53),char(53),char(0),char(2),char(0),char(115), -char(255),char(236),char(4),char(199),char(4),char(92),char(0),char(11),char(0),char(42), -char(0),char(71),char(64),char(36),char(9),char(15),char(39),char(21),char(4),char(4), -char(29),char(34),char(29),char(15),char(3),char(43),char(44),char(24),char(15),char(39), -char(40),char(40),char(22),char(12),char(18),char(18),char(7),char(70),char(89),char(18), -char(16),char(31),char(0),char(12),char(0),char(70),char(89),char(36),char(12),char(22), -char(0),char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(43), -char(17),char(18),char(0),char(57),char(57),char(17),char(51),char(24),char(63),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(37),char(50),char(54),char(53),char(53),char(52),char(38), -char(35),char(32),char(17),char(20),char(22),char(23),char(34),char(2),char(17),char(16), -char(18),char(51),char(50),char(22),char(23),char(51),char(54),char(55),char(51),char(6), -char(6),char(21),char(17),char(20),char(51),char(50),char(55),char(21),char(6),char(35), -char(34),char(38),char(39),char(35),char(6),char(6),char(2),char(80),char(169),char(150), -char(152),char(169),char(254),char(209),char(147),char(133),char(214),char(238),char(244),char(225), -char(121),char(161),char(54),char(12),char(24),char(41),char(129),char(21),char(28),char(84), -char(29),char(33),char(46),char(65),char(81),char(89),char(18),char(13),char(59),char(167), -char(119),char(195),char(218),char(15),char(229),char(199),char(254),char(80),char(212),char(212), -char(139),char(1),char(41),char(1),char(12),char(1),char(18),char(1),char(41),char(84), -char(84),char(92),char(56),char(66),char(246),char(116),char(254),char(73),char(114),char(10), -char(119),char(26),char(81),char(86),char(86),char(81),char(0),char(2),char(0),char(176), -char(254),char(20),char(4),char(168),char(6),char(31),char(0),char(19),char(0),char(41), -char(0),char(76),char(64),char(40),char(24),char(15),char(15),char(16),char(39),char(3), -char(30),char(8),char(8),char(3),char(5),char(34),char(16),char(5),char(42),char(43), -char(16),char(27),char(35),char(34),char(70),char(89),char(14),char(35),char(14),char(35), -char(11),char(0),char(11),char(27),char(70),char(89),char(11),char(22),char(0),char(20), -char(70),char(89),char(0),char(0),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(57),char(24),char(47),char(47),char(43), -char(0),char(24),char(63),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(50), -char(22),char(21),char(16),char(5),char(21),char(4),char(17),char(20),char(4),char(35), -char(34),char(38),char(39),char(17),char(35),char(17),char(52),char(54),char(23),char(34), -char(6),char(21),char(17),char(22),char(22),char(51),char(50),char(54),char(53),char(52), -char(38),char(35),char(35),char(53),char(51),char(50),char(54),char(53),char(52),char(38), -char(2),char(147),char(220),char(249),char(254),char(199),char(1),char(121),char(254),char(248), -char(238),char(109),char(160),char(79),char(166),char(253),char(228),char(158),char(157),char(93), -char(161),char(86),char(171),char(173),char(190),char(177),char(112),char(92),char(155),char(162), -char(156),char(6),char(31),char(208),char(183),char(254),char(218),char(51),char(8),char(42), -char(254),char(145),char(209),char(225),char(31),char(38),char(253),char(227),char(6),char(52), -char(225),char(246),char(140),char(172),char(165),char(252),char(137),char(49),char(37),char(150), -char(157),char(157),char(164),char(142),char(147),char(137),char(123),char(133),char(0),char(1), -char(0),char(10),char(254),char(20),char(4),char(14),char(4),char(72),char(0),char(18), -char(0),char(33),char(64),char(16),char(15),char(4),char(1),char(5),char(4),char(19), -char(20),char(10),char(9),char(9),char(1),char(14),char(5),char(15),char(1),char(27), -char(0),char(63),char(63),char(51),char(18),char(57),char(47),char(51),char(17),char(18), -char(1),char(23),char(57),char(49),char(48),char(1),char(35),char(52),char(18),char(55), -char(1),char(51),char(19),char(22),char(23),char(51),char(62),char(2),char(19),char(51), -char(1),char(6),char(2),char(2),char(20),char(180),char(64),char(43),char(254),char(63), -char(172),char(240),char(94),char(19),char(8),char(5),char(41),char(43),char(234),char(172), -char(254),char(107),char(48),char(53),char(254),char(20),char(96),char(1),char(38),char(114), -char(4),char(60),char(253),char(184),char(235),char(103),char(30),char(142),char(129),char(2), -char(109),char(251),char(211),char(124),char(254),char(220),char(0),char(2),char(0),char(113), -char(255),char(236),char(4),char(96),char(6),char(18),char(0),char(30),char(0),char(42), -char(0),char(59),char(64),char(32),char(37),char(28),char(16),char(3),char(31),char(22), -char(22),char(9),char(0),char(3),char(28),char(5),char(43),char(44),char(16),char(0), -char(34),char(3),char(25),char(6),char(25),char(40),char(70),char(89),char(25),char(22), -char(6),char(13),char(70),char(89),char(6),char(0),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(23),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(38),char(38),char(53),char(52),char(54),char(51),char(50),char(22), -char(23),char(7),char(38),char(38),char(35),char(34),char(6),char(21),char(20),char(22), -char(23),char(22),char(22),char(21),char(20),char(0),char(35),char(34),char(36),char(53), -char(52),char(18),char(1),char(52),char(38),char(39),char(6),char(6),char(21),char(20), -char(22),char(51),char(50),char(54),char(2),char(33),char(140),char(116),char(194),char(164), -char(103),char(189),char(126),char(72),char(112),char(159),char(81),char(85),char(97),char(107), -char(167),char(210),char(177),char(254),char(240),char(236),char(227),char(254),char(240),char(226), -char(2),char(97),char(123),char(141),char(206),char(191),char(178),char(147),char(162),char(174), -char(3),char(168),char(78),char(159),char(99),char(130),char(152),char(45),char(63),char(135), -char(62),char(44),char(79),char(66),char(71),char(111),char(91),char(115),char(241),char(164), -char(235),char(254),char(248),char(248),char(210),char(177),char(1),char(5),char(254),char(115), -char(128),char(183),char(74),char(53),char(217),char(160),char(144),char(171),char(186),char(0), -char(0),char(1),char(0),char(90),char(255),char(236),char(3),char(135),char(4),char(92), -char(0),char(37),char(0),char(77),char(64),char(43),char(4),char(16),char(35),char(23), -char(29),char(11),char(1),char(19),char(23),char(16),char(6),char(38),char(39),char(20), -char(37),char(2),char(37),char(2),char(70),char(89),char(15),char(37),char(31),char(37), -char(2),char(11),char(3),char(37),char(37),char(13),char(26),char(26),char(33),char(70), -char(89),char(26),char(16),char(13),char(7),char(70),char(89),char(13),char(22),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(24),char(47),char(95),char(94),char(93),char(43),char(17),char(18),char(0),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(21),char(35),char(32),char(21),char(20),char(22),char(51),char(50), -char(54),char(55),char(21),char(6),char(35),char(34),char(38),char(53),char(52),char(54), -char(55),char(53),char(38),char(38),char(53),char(52),char(54),char(51),char(50),char(22), -char(23),char(7),char(38),char(38),char(35),char(34),char(21),char(20),char(33),char(2), -char(203),char(148),char(254),char(201),char(147),char(146),char(84),char(166),char(100),char(137), -char(221),char(210),char(241),char(110),char(130),char(98),char(107),char(224),char(192),char(97), -char(165),char(100),char(63),char(94),char(130),char(79),char(250),char(1),char(61),char(2), -char(129),char(141),char(195),char(90),char(98),char(39),char(47),char(148),char(75),char(169), -char(148),char(98),char(131),char(41),char(11),char(28),char(127),char(92),char(133),char(158), -char(33),char(45),char(133),char(42),char(28),char(162),char(172),char(0),char(0),char(1), -char(0),char(115),char(254),char(111),char(3),char(160),char(6),char(20),char(0),char(32), -char(0),char(48),char(64),char(24),char(7),char(25),char(30),char(19),char(19),char(14), -char(14),char(3),char(0),char(25),char(4),char(33),char(34),char(17),char(35),char(30), -char(3),char(0),char(1),char(0),char(70),char(89),char(1),char(0),char(0),char(63), -char(43),char(17),char(0),char(51),char(51),char(24),char(63),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(19),char(53),char(33),char(21),char(6),char(0),char(2),char(21),char(20),char(22), -char(22),char(23),char(22),char(22),char(21),char(20),char(7),char(35),char(54),char(53), -char(52),char(38),char(39),char(38),char(38),char(53),char(52),char(62),char(2),char(55), -char(6),char(33),char(176),char(2),char(240),char(215),char(254),char(224),char(138),char(59), -char(125),char(172),char(149),char(136),char(127),char(166),char(125),char(111),char(143),char(203), -char(188),char(59),char(112),char(201),char(242),char(40),char(254),char(241),char(5),char(135), -char(141),char(129),char(180),char(254),char(189),char(254),char(223),char(166),char(98),char(118), -char(73),char(37),char(31),char(109),char(91),char(149),char(164),char(161),char(107),char(56), -char(61),char(26),char(36),char(219),char(194),char(114),char(208),char(195),char(229),char(218), -char(8),char(0),char(0),char(1),char(0),char(176),char(254),char(20),char(4),char(68), -char(4),char(92),char(0),char(20),char(0),char(47),char(64),char(24),char(0),char(20), -char(12),char(8),char(8),char(9),char(20),char(9),char(22),char(21),char(16),char(4), -char(70),char(89),char(16),char(16),char(12),char(9),char(10),char(15),char(9),char(21), -char(0),char(27),char(0),char(63),char(63),char(63),char(18),char(57),char(63),char(43), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(17),char(52),char(38),char(35),char(34),char(6), -char(21),char(17),char(35),char(17),char(51),char(23),char(51),char(54),char(54),char(51), -char(50),char(22),char(21),char(17),char(3),char(158),char(122),char(130),char(172),char(160), -char(166),char(135),char(27),char(8),char(51),char(184),char(113),char(198),char(200),char(254), -char(20),char(4),char(177),char(134),char(132),char(186),char(214),char(253),char(193),char(4), -char(72),char(150),char(81),char(89),char(191),char(210),char(251),char(73),char(0),char(3), -char(0),char(115),char(255),char(236),char(4),char(74),char(6),char(43),char(0),char(11), -char(0),char(18),char(0),char(25),char(0),char(73),char(64),char(39),char(22),char(16), -char(16),char(6),char(23),char(15),char(15),char(0),char(6),char(0),char(26),char(27), -char(22),char(16),char(70),char(89),char(15),char(22),char(191),char(22),char(2),char(11), -char(3),char(22),char(22),char(3),char(9),char(9),char(19),char(70),char(89),char(9), -char(1),char(3),char(12),char(70),char(89),char(3),char(22),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(95),char(94),char(93),char(43),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(16),char(2),char(35),char(34),char(2),char(17),char(16),char(18),char(51),char(50), -char(18),char(1),char(50),char(18),char(19),char(33),char(18),char(18),char(19),char(34), -char(2),char(3),char(33),char(2),char(2),char(4),char(74),char(244),char(250),char(240), -char(249),char(245),char(244),char(244),char(250),char(254),char(18),char(164),char(156),char(6), -char(253),char(121),char(4),char(150),char(167),char(161),char(150),char(10),char(2),char(133), -char(11),char(152),char(3),char(12),char(254),char(106),char(254),char(118),char(1),char(147), -char(1),char(141),char(1),char(151),char(1),char(136),char(254),char(107),char(251),char(225), -char(1),char(49),char(1),char(51),char(254),char(208),char(254),char(204),char(5),char(41), -char(254),char(225),char(254),char(231),char(1),char(25),char(1),char(31),char(0),char(1), -char(0),char(168),char(255),char(236),char(2),char(147),char(4),char(72),char(0),char(15), -char(0),char(31),char(64),char(14),char(1),char(14),char(7),char(14),char(17),char(16), -char(15),char(15),char(11),char(4),char(70),char(89),char(11),char(22),char(0),char(63), -char(43),char(0),char(24),char(63),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(49),char(48),char(1),char(17),char(20),char(22),char(51),char(50),char(54), -char(55),char(21),char(6),char(6),char(35),char(34),char(38),char(53),char(17),char(1), -char(78),char(73),char(87),char(37),char(101),char(27),char(31),char(105),char(50),char(160), -char(145),char(4),char(72),char(252),char(250),char(104),char(101),char(13),char(7),char(127), -char(13),char(17),char(168),char(169),char(3),char(11),char(255),char(255),char(0),char(176), -char(0),char(0),char(4),char(27),char(4),char(70),char(2),char(6),char(0),char(250), -char(0),char(0),char(0),char(1),char(255),char(242),char(255),char(236),char(4),char(70), -char(6),char(33),char(0),char(34),char(0),char(51),char(64),char(27),char(8),char(1), -char(21),char(3),char(36),char(0),char(0),char(35),char(24),char(19),char(70),char(89), -char(24),char(22),char(30),char(31),char(31),char(0),char(11),char(11),char(6),char(70), -char(89),char(11),char(1),char(0),char(21),char(0),char(63),char(63),char(43),char(17), -char(18),char(0),char(57),char(17),char(51),char(24),char(63),char(43),char(17),char(1), -char(51),char(17),char(18),char(23),char(57),char(49),char(48),char(35),char(1),char(39), -char(46),char(2),char(35),char(34),char(7),char(53),char(54),char(51),char(50),char(22), -char(22),char(23),char(1),char(22),char(22),char(51),char(50),char(55),char(21),char(6), -char(35),char(34),char(38),char(39),char(3),char(38),char(39),char(35),char(6),char(7), -char(3),char(14),char(1),char(217),char(58),char(30),char(50),char(67),char(49),char(58), -char(57),char(68),char(63),char(91),char(121),char(88),char(54),char(1),char(107),char(19), -char(42),char(35),char(27),char(33),char(48),char(61),char(74),char(83),char(29),char(156), -char(84),char(22),char(9),char(28),char(88),char(254),char(4),char(55),char(162),char(85), -char(70),char(36),char(13),char(133),char(17),char(60),char(130),char(152),char(252),char(12), -char(49),char(51),char(10),char(121),char(24),char(76),char(83),char(1),char(180),char(240), -char(96),char(116),char(209),char(253),char(182),char(0),char(255),char(255),char(0),char(176), -char(254),char(20),char(4),char(68),char(4),char(72),char(2),char(6),char(0),char(119), -char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(0),char(4),char(2), -char(4),char(72),char(0),char(14),char(0),char(28),char(64),char(12),char(9),char(10), -char(10),char(0),char(16),char(15),char(5),char(14),char(21),char(9),char(0),char(15), -char(0),char(63),char(50),char(63),char(57),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(49),char(48),char(17),char(51),char(19),char(22),char(22),char(23), -char(51),char(54),char(18),char(17),char(51),char(16),char(2),char(7),char(35),char(172), -char(219),char(26),char(83),char(16),char(8),char(177),char(159),char(166),char(207),char(225), -char(186),char(4),char(72),char(253),char(178),char(67),char(238),char(62),char(175),char(1), -char(189),char(1),char(81),char(254),char(149),char(254),char(4),char(225),char(0),char(1), -char(0),char(113),char(254),char(111),char(3),char(160),char(6),char(20),char(0),char(49), -char(0),char(73),char(64),char(39),char(4),char(25),char(45),char(31),char(29),char(28), -char(19),char(12),char(12),char(40),char(0),char(28),char(31),char(37),char(25),char(7), -char(50),char(51),char(28),char(48),char(1),char(48),char(1),char(71),char(89),char(48), -char(48),char(16),char(38),char(41),char(37),char(38),char(37),char(70),char(89),char(38), -char(0),char(16),char(35),char(0),char(63),char(63),char(43),char(17),char(0),char(51), -char(17),char(18),char(57),char(24),char(47),char(43),char(17),char(18),char(0),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(35),char(34),char(6),char(21), -char(20),char(30),char(2),char(23),char(22),char(22),char(21),char(20),char(6),char(7), -char(35),char(54),char(54),char(53),char(52),char(38),char(39),char(38),char(38),char(53), -char(52),char(54),char(55),char(53),char(38),char(53),char(52),char(54),char(55),char(6), -char(35),char(35),char(53),char(33),char(21),char(35),char(34),char(6),char(6),char(21), -char(20),char(22),char(51),char(51),char(3),char(86),char(178),char(176),char(213),char(50), -char(95),char(135),char(84),char(142),char(135),char(54),char(67),char(156),char(53),char(66), -char(115),char(143),char(200),char(199),char(158),char(128),char(217),char(139),char(166),char(128), -char(115),char(68),char(2),char(186),char(51),char(130),char(224),char(127),char(167),char(175), -char(170),char(2),char(242),char(178),char(142),char(80),char(98),char(61),char(36),char(18), -char(29),char(110),char(90),char(65),char(149),char(99),char(71),char(147),char(52),char(55), -char(61),char(25),char(34),char(200),char(176),char(140),char(210),char(39),char(12),char(64), -char(217),char(117),char(158),char(50),char(12),char(141),char(131),char(80),char(144),char(95), -char(115),char(108),char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98), -char(4),char(92),char(2),char(6),char(0),char(82),char(0),char(0),char(0),char(1), -char(0),char(25),char(255),char(236),char(4),char(244),char(4),char(72),char(0),char(21), -char(0),char(54),char(64),char(29),char(10),char(11),char(7),char(19),char(16),char(3), -char(19),char(11),char(13),char(5),char(22),char(23),char(18),char(9),char(13),char(15), -char(13),char(70),char(89),char(15),char(15),char(11),char(21),char(5),char(0),char(70), -char(89),char(5),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(63), -char(43),char(17),char(0),char(51),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(50),char(55),char(21), -char(6),char(35),char(34),char(53),char(17),char(33),char(17),char(35),char(17),char(35), -char(53),char(55),char(33),char(21),char(35),char(17),char(20),char(22),char(4),char(125), -char(38),char(48),char(43),char(84),char(219),char(254),char(35),char(166),char(221),char(143), -char(4),char(76),char(213),char(51),char(117),char(18),char(131),char(24),char(253),char(2), -char(209),char(252),char(70),char(3),char(186),char(74),char(68),char(142),char(253),char(60), -char(74),char(55),char(0),char(2),char(0),char(166),char(254),char(20),char(4),char(98), -char(4),char(92),char(0),char(16),char(0),char(28),char(0),char(54),char(64),char(27), -char(21),char(9),char(9),char(10),char(26),char(0),char(10),char(0),char(29),char(30), -char(6),char(3),char(14),char(14),char(17),char(70),char(89),char(14),char(16),char(10), -char(27),char(3),char(23),char(70),char(89),char(3),char(22),char(0),char(63),char(43), -char(0),char(24),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(16),char(0),char(35),char(34),char(39),char(35),char(22), -char(21),char(17),char(35),char(17),char(16),char(18),char(51),char(50),char(18),char(37), -char(34),char(6),char(21),char(17),char(22),char(51),char(50),char(54),char(53),char(52), -char(38),char(4),char(98),char(255),char(0),char(233),char(179),char(120),char(8),char(8), -char(168),char(251),char(234),char(219),char(252),char(254),char(33),char(158),char(151),char(122), -char(183),char(159),char(152),char(144),char(2),char(37),char(254),char(241),char(254),char(214), -char(94),char(61),char(212),char(254),char(219),char(4),char(31),char(1),char(10),char(1), -char(31),char(254),char(209),char(162),char(207),char(209),char(254),char(174),char(102),char(208), -char(222),char(214),char(212),char(0),char(0),char(1),char(0),char(115),char(254),char(111), -char(3),char(162),char(4),char(92),char(0),char(32),char(0),char(46),char(64),char(23), -char(14),char(7),char(0),char(21),char(21),char(7),char(27),char(3),char(34),char(33), -char(4),char(18),char(18),char(24),char(11),char(24),char(30),char(70),char(89),char(24), -char(16),char(11),char(35),char(0),char(63),char(63),char(43),char(17),char(18),char(0), -char(57),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(22),char(22),char(23),char(22), -char(22),char(21),char(20),char(6),char(7),char(35),char(54),char(54),char(53),char(52), -char(38),char(38),char(39),char(38),char(38),char(53),char(16),char(0),char(51),char(50), -char(22),char(23),char(7),char(38),char(35),char(34),char(6),char(1),char(31),char(59), -char(143),char(160),char(148),char(131),char(54),char(67),char(156),char(54),char(67),char(51), -char(110),char(97),char(204),char(195),char(1),char(20),char(248),char(79),char(158),char(54), -char(53),char(130),char(114),char(176),char(170),char(2),char(10),char(135),char(132),char(80), -char(34),char(32),char(107),char(90),char(66),char(152),char(95),char(70),char(148),char(50), -char(40),char(47),char(38),char(18),char(37),char(254),char(219),char(1),char(30),char(1), -char(54),char(33),char(24),char(141),char(51),char(218),char(0),char(2),char(0),char(115), -char(255),char(236),char(4),char(182),char(4),char(72),char(0),char(13),char(0),char(25), -char(0),char(48),char(64),char(25),char(20),char(0),char(14),char(7),char(7),char(12), -char(0),char(11),char(4),char(27),char(26),char(12),char(23),char(9),char(23),char(70), -char(89),char(9),char(15),char(4),char(17),char(70),char(89),char(4),char(22),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(0),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(20),char(6),char(6),char(35),char(34),char(0),char(53),char(16),char(33), -char(33),char(21),char(33),char(22),char(1),char(20),char(22),char(51),char(50),char(54), -char(53),char(16),char(39),char(35),char(34),char(6),char(4),char(96),char(123),char(229), -char(154),char(235),char(254),char(248),char(2),char(80),char(1),char(243),char(254),char(248), -char(178),char(252),char(191),char(170),char(161),char(159),char(171),char(174),char(65),char(222), -char(200),char(1),char(252),char(157),char(241),char(130),char(1),char(32),char(254),char(2), -char(62),char(142),char(167),char(254),char(247),char(194),char(209),char(197),char(182),char(1), -char(14),char(186),char(208),char(0),char(0),char(1),char(0),char(18),char(255),char(231), -char(3),char(147),char(4),char(72),char(0),char(19),char(0),char(44),char(64),char(23), -char(3),char(15),char(0),char(9),char(15),char(17),char(4),char(20),char(21),char(2), -char(17),char(19),char(17),char(70),char(89),char(19),char(15),char(12),char(5),char(70), -char(89),char(12),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(49),char(48),char(1),char(21),char(33),char(17),char(20),char(51),char(50),char(54), -char(55),char(21),char(6),char(6),char(35),char(34),char(38),char(53),char(17),char(33), -char(53),char(55),char(3),char(147),char(254),char(80),char(205),char(47),char(98),char(27), -char(35),char(111),char(48),char(181),char(170),char(254),char(215),char(148),char(4),char(72), -char(142),char(253),char(150),char(223),char(13),char(7),char(125),char(15),char(18),char(170), -char(170),char(2),char(127),char(74),char(68),char(0),char(0),char(1),char(0),char(164), -char(255),char(236),char(4),char(113),char(4),char(72),char(0),char(21),char(0),char(37), -char(64),char(17),char(12),char(19),char(6),char(3),char(19),char(3),char(23),char(22), -char(15),char(4),char(15),char(0),char(9),char(70),char(89),char(0),char(22),char(0), -char(63),char(43),char(0),char(24),char(63),char(51),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(5),char(34),char(38), -char(17),char(17),char(51),char(17),char(20),char(22),char(51),char(50),char(54),char(53), -char(52),char(38),char(39),char(51),char(22),char(22),char(21),char(16),char(0),char(2), -char(115),char(231),char(232),char(166),char(158),char(153),char(167),char(161),char(28),char(34), -char(166),char(36),char(28),char(254),char(254),char(20),char(250),char(1),char(10),char(2), -char(88),char(253),char(176),char(192),char(195),char(238),char(251),char(130),char(224),char(136), -char(144),char(214),char(140),char(254),char(194),char(254),char(212),char(0),char(0),char(2), -char(0),char(115),char(254),char(20),char(5),char(76),char(4),char(92),char(0),char(24), -char(0),char(34),char(0),char(65),char(64),char(35),char(10),char(4),char(32),char(24), -char(24),char(12),char(0),char(25),char(19),char(19),char(0),char(7),char(4),char(4), -char(35),char(36),char(16),char(28),char(70),char(89),char(16),char(16),char(6),char(15), -char(32),char(12),char(1),char(12),char(70),char(89),char(23),char(1),char(22),char(0), -char(27),char(0),char(63),char(63),char(51),char(43),char(17),char(0),char(51),char(24), -char(63),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(17),char(36),char(0),char(17),char(16),char(55),char(23),char(6),char(6),char(21), -char(16),char(5),char(17),char(52),char(54),char(51),char(50),char(18),char(21),char(20), -char(2),char(6),char(7),char(17),char(1),char(52),char(38),char(35),char(34),char(6), -char(21),char(17),char(54),char(54),char(2),char(131),char(254),char(252),char(254),char(244), -char(207),char(131),char(89),char(81),char(1),char(104),char(166),char(149),char(180),char(218), -char(136),char(248),char(165),char(1),char(121),char(124),char(102),char(73),char(78),char(179), -char(198),char(254),char(20),char(1),char(218),char(11),char(1),char(35),char(1),char(15), -char(1),char(40),char(253),char(90),char(117),char(224),char(124),char(254),char(117),char(35), -char(2),char(108),char(187),char(190),char(254),char(219),char(250),char(178),char(254),char(251), -char(144),char(8),char(254),char(38),char(4),char(39),char(185),char(219),char(120),char(114), -char(253),char(146),char(16),char(236),char(0),char(1),char(255),char(236),char(254),char(20), -char(4),char(80),char(4),char(78),char(0),char(32),char(0),char(57),char(64),char(33), -char(14),char(7),char(8),char(5),char(21),char(24),char(30),char(7),char(34),char(23), -char(33),char(5),char(24),char(8),char(21),char(4),char(6),char(23),char(27),char(17), -char(12),char(70),char(89),char(17),char(27),char(6),char(15),char(0),char(28),char(70), -char(89),char(0),char(15),char(0),char(63),char(43),char(0),char(24),char(63),char(63), -char(43),char(0),char(24),char(63),char(18),char(23),char(57),char(17),char(1),char(51), -char(18),char(23),char(57),char(49),char(48),char(19),char(50),char(22),char(22),char(23), -char(19),char(1),char(51),char(1),char(19),char(22),char(22),char(51),char(50),char(55), -char(21),char(6),char(35),char(34),char(38),char(39),char(3),char(1),char(35),char(1), -char(3),char(38),char(38),char(35),char(34),char(7),char(53),char(54),char(178),char(54), -char(78),char(62),char(44),char(145),char(1),char(62),char(180),char(254),char(84),char(190), -char(48),char(82),char(63),char(45),char(45),char(60),char(59),char(115),char(141),char(59), -char(150),char(254),char(150),char(178),char(1),char(208),char(172),char(38),char(70),char(43), -char(37),char(27),char(49),char(4),char(78),char(43),char(91),char(112),char(254),char(143), -char(2),char(97),char(252),char(252),char(254),char(28),char(122),char(74),char(8),char(129), -char(15),char(118),char(159),char(1),char(131),char(253),char(104),char(3),char(68),char(1), -char(188),char(99),char(80),char(11),char(129),char(17),char(0),char(1),char(0),char(164), -char(254),char(20),char(5),char(135),char(6),char(18),char(0),char(26),char(0),char(61), -char(64),char(31),char(22),char(19),char(1),char(14),char(14),char(25),char(15),char(4), -char(10),char(10),char(15),char(19),char(3),char(27),char(28),char(26),char(0),char(7), -char(20),char(15),char(1),char(25),char(16),char(25),char(70),char(89),char(13),char(16), -char(22),char(15),char(27),char(0),char(63),char(63),char(51),char(43),char(17),char(0), -char(51),char(24),char(63),char(51),char(63),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(17),char(54),char(54),char(53),char(52),char(38),char(39),char(51), -char(18),char(21),char(16),char(0),char(5),char(17),char(35),char(17),char(36),char(0), -char(17),char(17),char(51),char(17),char(20),char(22),char(23),char(17),char(3),char(90), -char(188),char(203),char(26),char(37),char(166),char(63),char(254),char(227),char(254),char(240), -char(164),char(254),char(248),char(254),char(246),char(166),char(180),char(184),char(6),char(18), -char(250),char(105),char(15),char(231),char(204),char(120),char(235),char(168),char(254),char(240), -char(244),char(254),char(236),char(254),char(206),char(16),char(254),char(38),char(1),char(218), -char(9),char(1),char(34),char(1),char(16),char(2),char(31),char(253),char(219),char(195), -char(218),char(13),char(5),char(153),char(0),char(1),char(0),char(115),char(255),char(236), -char(5),char(188),char(4),char(72),char(0),char(39),char(0),char(61),char(64),char(30), -char(10),char(3),char(38),char(19),char(19),char(16),char(25),char(32),char(32),char(16), -char(3),char(3),char(40),char(41),char(38),char(17),char(17),char(0),char(28),char(6), -char(15),char(22),char(13),char(0),char(13),char(70),char(89),char(35),char(0),char(22), -char(0),char(63),char(50),char(43),char(17),char(0),char(51),char(24),char(63),char(51), -char(18),char(57),char(47),char(57),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(18),char(57),char(17),char(51),char(49),char(48),char(5), -char(34),char(2),char(53),char(52),char(18),char(55),char(51),char(6),char(6),char(21), -char(20),char(22),char(51),char(50),char(54),char(53),char(17),char(51),char(17),char(20), -char(22),char(51),char(50),char(54),char(53),char(52),char(2),char(39),char(51),char(22), -char(18),char(21),char(20),char(2),char(35),char(34),char(39),char(35),char(6),char(1), -char(244),char(182),char(203),char(55),char(68),char(172),char(68),char(57),char(120),char(107), -char(94),char(105),char(161),char(106),char(93),char(107),char(120),char(55),char(69),char(172), -char(65),char(57),char(203),char(182),char(220),char(68),char(9),char(65),char(20),char(1), -char(40),char(254),char(156),char(1),char(1),char(153),char(156),char(255),char(157),char(193), -char(216),char(143),char(125),char(1),char(55),char(254),char(201),char(128),char(140),char(216), -char(193),char(151),char(1),char(4),char(157),char(146),char(254),char(249),char(157),char(252), -char(254),char(214),char(182),char(182),char(255),char(255),char(0),char(9),char(255),char(236), -char(2),char(147),char(5),char(211),char(2),char(38),char(1),char(134),char(0),char(0), -char(1),char(7),char(0),char(106),char(254),char(212),char(0),char(0),char(0),char(10), -char(180),char(2),char(1),char(37),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(164),char(255),char(236),char(4),char(113),char(5),char(211), -char(2),char(38),char(1),char(146),char(0),char(0),char(1),char(6),char(0),char(106), -char(57),char(0),char(0),char(10),char(180),char(2),char(1),char(43),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(98),char(6),char(115),char(2),char(38),char(0),char(82),char(0),char(0), -char(1),char(6),char(1),char(84),char(33),char(0),char(0),char(8),char(179),char(2), -char(34),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(164), -char(255),char(236),char(4),char(113),char(6),char(115),char(2),char(38),char(1),char(146), -char(0),char(0),char(1),char(6),char(1),char(84),char(39),char(0),char(0),char(8), -char(179),char(1),char(31),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(5),char(188),char(6),char(115),char(2),char(38), -char(1),char(150),char(0),char(0),char(1),char(7),char(1),char(84),char(0),char(201), -char(0),char(0),char(0),char(8),char(179),char(1),char(49),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248), -char(7),char(37),char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7), -char(0),char(106),char(0),char(39),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(33),char(5),char(38),char(0),char(43),char(53),char(53),char(0),char(1), -char(0),char(18),char(255),char(236),char(5),char(66),char(5),char(182),char(0),char(29), -char(0),char(70),char(64),char(38),char(22),char(14),char(14),char(15),char(8),char(27), -char(27),char(20),char(2),char(15),char(17),char(5),char(30),char(31),char(22),char(13), -char(73),char(89),char(22),char(22),char(15),char(18),char(21),char(17),char(18),char(17), -char(73),char(89),char(18),char(3),char(15),char(18),char(0),char(5),char(73),char(89), -char(0),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(43), -char(17),char(0),char(51),char(17),char(18),char(57),char(24),char(47),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(5),char(34),char(39),char(53),char(22),char(51),char(50),char(54), -char(53),char(53),char(52),char(38),char(35),char(33),char(17),char(35),char(17),char(33), -char(53),char(33),char(21),char(33),char(17),char(33),char(50),char(22),char(21),char(21), -char(20),char(6),char(3),char(207),char(96),char(54),char(55),char(91),char(101),char(104), -char(131),char(140),char(254),char(131),char(170),char(254),char(176),char(3),char(183),char(254), -char(67),char(1),char(140),char(205),char(221),char(196),char(20),char(22),char(150),char(19), -char(124),char(112),char(131),char(128),char(113),char(253),char(27),char(5),char(31),char(151), -char(151),char(254),char(94),char(191),char(178),char(143),char(190),char(211),char(255),char(255), -char(0),char(201),char(0),char(0),char(3),char(248),char(7),char(115),char(2),char(38), -char(1),char(97),char(0),char(0),char(1),char(7),char(0),char(118),char(0),char(90), -char(1),char(82),char(0),char(8),char(179),char(1),char(15),char(5),char(38),char(0), -char(43),char(53),char(0),char(1),char(0),char(125),char(255),char(236),char(4),char(227), -char(5),char(205),char(0),char(24),char(0),char(56),char(64),char(30),char(6),char(3), -char(17),char(22),char(12),char(5),char(17),char(4),char(25),char(26),char(3),char(6), -char(73),char(89),char(3),char(3),char(14),char(20),char(20),char(0),char(73),char(89), -char(20),char(4),char(14),char(9),char(73),char(89),char(14),char(19),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51), -char(49),char(48),char(1),char(34),char(4),char(7),char(33),char(21),char(33),char(18), -char(0),char(51),char(50),char(55),char(21),char(6),char(35),char(32),char(0),char(17), -char(16),char(0),char(33),char(50),char(23),char(7),char(38),char(3),char(66),char(226), -char(254),char(243),char(30),char(2),char(211),char(253),char(41),char(10),char(1),char(11), -char(249),char(162),char(201),char(161),char(226),char(254),char(180),char(254),char(162),char(1), -char(121),char(1),char(78),char(237),char(178),char(71),char(169),char(5),char(51),char(250), -char(241),char(150),char(254),char(238),char(254),char(227),char(55),char(149),char(57),char(1), -char(132),char(1),char(109),char(1),char(95),char(1),char(145),char(88),char(148),char(82), -char(255),char(255),char(0),char(106),char(255),char(236),char(4),char(2),char(5),char(203), -char(2),char(6),char(0),char(54),char(0),char(0),char(255),char(255),char(0),char(84), -char(0),char(0),char(2),char(86),char(5),char(182),char(2),char(6),char(0),char(44), -char(0),char(0),char(255),char(255),char(0),char(60),char(0),char(0),char(2),char(111), -char(7),char(37),char(2),char(38),char(0),char(44),char(0),char(0),char(1),char(7), -char(0),char(106),char(255),char(7),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(33),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(255),char(96),char(254),char(127),char(1),char(104),char(5),char(182),char(2),char(6), -char(0),char(45),char(0),char(0),char(0),char(2),char(0),char(0),char(255),char(233), -char(7),char(35),char(5),char(182),char(0),char(26),char(0),char(35),char(0),char(71), -char(64),char(38),char(24),char(27),char(27),char(4),char(31),char(0),char(0),char(4), -char(13),char(3),char(36),char(37),char(24),char(35),char(73),char(89),char(24),char(24), -char(11),char(22),char(22),char(6),char(73),char(89),char(22),char(3),char(11),char(16), -char(74),char(89),char(11),char(18),char(4),char(27),char(74),char(89),char(4),char(18), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(20),char(4),char(33),char(33),char(17),char(33),char(2),char(2), -char(6),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50),char(62), -char(2),char(18),char(19),char(33),char(17),char(51),char(32),char(1),char(51),char(50), -char(54),char(53),char(52),char(38),char(35),char(35),char(7),char(35),char(254),char(237), -char(254),char(252),char(254),char(185),char(254),char(147),char(57),char(84),char(80),char(139), -char(107),char(69),char(64),char(50),char(63),char(48),char(65),char(43),char(55),char(68), -char(65),char(2),char(166),char(122),char(2),char(58),char(253),char(76),char(133),char(198), -char(183),char(192),char(220),char(102),char(1),char(170),char(206),char(220),char(5),char(31), -char(254),char(72),char(253),char(246),char(251),char(121),char(25),char(143),char(26),char(62), -char(103),char(250),char(1),char(190),char(1),char(226),char(253),char(144),char(253),char(77), -char(139),char(140),char(138),char(124),char(0),char(2),char(0),char(201),char(0),char(0), -char(7),char(84),char(5),char(182),char(0),char(17),char(0),char(26),char(0),char(74), -char(64),char(38),char(11),char(7),char(7),char(8),char(15),char(18),char(18),char(12), -char(4),char(22),char(0),char(0),char(4),char(8),char(3),char(27),char(28),char(26), -char(6),char(11),char(6),char(73),char(89),char(15),char(11),char(11),char(4),char(13), -char(9),char(3),char(8),char(18),char(4),char(18),char(74),char(89),char(4),char(18), -char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(57), -char(47),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(4),char(33),char(33),char(17), -char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(17),char(51),char(17), -char(51),char(32),char(1),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(35),char(7),char(84),char(254),char(240),char(254),char(251),char(254),char(183),char(253), -char(125),char(170),char(170),char(2),char(131),char(172),char(121),char(2),char(57),char(253), -char(78),char(133),char(196),char(185),char(193),char(219),char(102),char(1),char(170),char(206), -char(220),char(2),char(176),char(253),char(80),char(5),char(182),char(253),char(146),char(2), -char(110),char(253),char(144),char(253),char(77),char(139),char(140),char(137),char(125),char(0), -char(0),char(1),char(0),char(18),char(0),char(0),char(5),char(66),char(5),char(182), -char(0),char(19),char(0),char(58),char(64),char(31),char(0),char(12),char(12),char(13), -char(6),char(5),char(5),char(18),char(13),char(15),char(4),char(20),char(21),char(19), -char(15),char(16),char(15),char(73),char(89),char(0),char(11),char(73),char(89),char(0), -char(0),char(13),char(16),char(3),char(6),char(13),char(18),char(0),char(63),char(51), -char(63),char(18),char(57),char(47),char(43),char(43),char(17),char(0),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(33),char(50),char(22),char(21),char(17),char(35),char(17), -char(52),char(38),char(35),char(33),char(17),char(35),char(17),char(33),char(53),char(33), -char(21),char(33),char(2),char(12),char(1),char(144),char(205),char(217),char(170),char(125), -char(140),char(254),char(125),char(170),char(254),char(176),char(3),char(246),char(254),char(4), -char(3),char(125),char(188),char(181),char(253),char(244),char(1),char(246),char(126),char(113), -char(253),char(27),char(5),char(31),char(151),char(151),char(255),char(255),char(0),char(201), -char(0),char(0),char(4),char(229),char(7),char(115),char(2),char(38),char(1),char(180), -char(0),char(0),char(1),char(7),char(0),char(118),char(0),char(162),char(1),char(82), -char(0),char(8),char(179),char(1),char(20),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(27),char(255),char(236),char(4),char(248),char(7),char(94), -char(2),char(38),char(1),char(189),char(0),char(0),char(1),char(7),char(2),char(54), -char(0),char(68),char(1),char(82),char(0),char(8),char(179),char(1),char(23),char(5), -char(38),char(0),char(43),char(53),char(0),char(1),char(0),char(201),char(254),char(131), -char(5),char(12),char(5),char(182),char(0),char(11),char(0),char(48),char(64),char(24), -char(8),char(5),char(2),char(3),char(9),char(0),char(0),char(3),char(5),char(3), -char(12),char(13),char(10),char(6),char(3),char(5),char(8),char(73),char(89),char(1), -char(5),char(18),char(3),char(34),char(0),char(63),char(63),char(51),char(43),char(0), -char(24),char(63),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(17),char(35), -char(17),char(33),char(17),char(51),char(17),char(33),char(17),char(51),char(5),char(12), -char(254),char(47),char(176),char(254),char(62),char(170),char(2),char(239),char(170),char(254), -char(131),char(1),char(125),char(5),char(182),char(250),char(228),char(5),char(28),char(0), -char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16),char(5),char(188), -char(2),char(6),char(0),char(36),char(0),char(0),char(0),char(2),char(0),char(201), -char(0),char(0),char(4),char(125),char(5),char(182),char(0),char(13),char(0),char(22), -char(0),char(61),char(64),char(32),char(18),char(0),char(9),char(14),char(14),char(4), -char(4),char(7),char(0),char(3),char(24),char(23),char(9),char(22),char(73),char(89), -char(9),char(9),char(4),char(5),char(5),char(8),char(73),char(89),char(5),char(3), -char(4),char(14),char(74),char(89),char(4),char(18),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(20),char(4),char(33),char(33),char(17),char(33), -char(21),char(33),char(17),char(51),char(50),char(22),char(22),char(1),char(51),char(50), -char(54),char(53),char(52),char(38),char(35),char(35),char(4),char(125),char(254),char(253), -char(254),char(251),char(254),char(84),char(3),char(94),char(253),char(76),char(227),char(193), -char(242),char(116),char(252),char(246),char(239),char(190),char(173),char(176),char(219),char(207), -char(1),char(170),char(218),char(208),char(5),char(182),char(151),char(254),char(39),char(89), -char(174),char(254),char(84),char(130),char(149),char(142),char(120),char(0),char(255),char(255), -char(0),char(201),char(0),char(0),char(4),char(190),char(5),char(182),char(2),char(6), -char(0),char(37),char(0),char(0),char(255),char(255),char(0),char(201),char(0),char(0), -char(3),char(248),char(5),char(182),char(2),char(6),char(1),char(97),char(0),char(0), -char(0),char(2),char(0),char(14),char(254),char(131),char(5),char(74),char(5),char(182), -char(0),char(13),char(0),char(19),char(0),char(67),char(64),char(36),char(4),char(5), -char(19),char(7),char(16),char(10),char(14),char(12),char(1),char(0),char(0),char(12), -char(10),char(7),char(5),char(5),char(20),char(21),char(10),char(16),char(73),char(89), -char(10),char(3),char(1),char(5),char(34),char(19),char(12),char(6),char(3),char(6), -char(73),char(89),char(3),char(18),char(0),char(63),char(43),char(17),char(0),char(51), -char(51),char(24),char(63),char(51),char(63),char(43),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(35),char(17),char(33),char(17),char(35),char(17), -char(51),char(18),char(18),char(19),char(33),char(17),char(51),char(33),char(17),char(33), -char(6),char(2),char(7),char(5),char(74),char(162),char(252),char(8),char(162),char(113), -char(154),char(219),char(12),char(2),char(145),char(185),char(254),char(157),char(254),char(179), -char(18),char(206),char(137),char(254),char(131),char(1),char(125),char(254),char(131),char(2), -char(23),char(1),char(3),char(2),char(230),char(1),char(51),char(250),char(228),char(4), -char(131),char(242),char(253),char(89),char(234),char(0),char(255),char(255),char(0),char(201), -char(0),char(0),char(3),char(248),char(5),char(182),char(2),char(6),char(0),char(40), -char(0),char(0),char(0),char(1),char(0),char(2),char(0),char(0),char(6),char(188), -char(5),char(182),char(0),char(17),char(0),char(60),char(64),char(31),char(6),char(13), -char(13),char(3),char(14),char(10),char(9),char(8),char(1),char(14),char(0),char(17), -char(7),char(18),char(19),char(15),char(12),char(9),char(6),char(3),char(0),char(0), -char(1),char(14),char(11),char(17),char(18),char(7),char(4),char(1),char(3),char(0), -char(63),char(51),char(51),char(63),char(51),char(51),char(18),char(57),char(17),char(51), -char(51),char(51),char(51),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(1),char(51),char(1), -char(17),char(51),char(17),char(1),char(51),char(1),char(1),char(35),char(1),char(17), -char(35),char(17),char(1),char(35),char(2),char(86),char(253),char(193),char(190),char(2), -char(57),char(164),char(2),char(58),char(190),char(253),char(192),char(2),char(82),char(196), -char(253),char(186),char(164),char(253),char(187),char(199),char(2),char(240),char(2),char(198), -char(253),char(60),char(2),char(196),char(253),char(60),char(2),char(196),char(253),char(60), -char(253),char(14),char(2),char(229),char(253),char(27),char(2),char(229),char(253),char(27), -char(0),char(1),char(0),char(74),char(255),char(236),char(4),char(53),char(5),char(203), -char(0),char(40),char(0),char(67),char(64),char(36),char(28),char(0),char(19),char(7), -char(7),char(0),char(3),char(23),char(35),char(12),char(6),char(41),char(42),char(3), -char(24),char(23),char(24),char(23),char(74),char(89),char(24),char(24),char(10),char(38), -char(38),char(31),char(74),char(89),char(38),char(4),char(10),char(16),char(74),char(89), -char(10),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(0),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(20),char(6),char(7),char(21),char(22),char(22),char(21),char(20), -char(4),char(33),char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54), -char(53),char(52),char(38),char(35),char(35),char(53),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(34),char(6),char(7),char(39),char(54),char(54),char(51), -char(50),char(22),char(4),char(25),char(183),char(161),char(183),char(189),char(254),char(206), -char(254),char(233),char(255),char(163),char(96),char(223),char(103),char(198),char(203),char(225), -char(223),char(218),char(209),char(205),char(225),char(162),char(137),char(110),char(178),char(117), -char(84),char(101),char(251),char(135),char(225),char(255),char(4),char(96),char(144),char(180), -char(24),char(8),char(25),char(180),char(145),char(205),char(229),char(79),char(158),char(46), -char(50),char(150),char(141),char(134),char(138),char(143),char(147),char(132),char(107),char(128), -char(50),char(74),char(114),char(75),char(77),char(197),char(0),char(1),char(0),char(203), -char(0),char(0),char(5),char(82),char(5),char(182),char(0),char(15),char(0),char(52), -char(64),char(24),char(14),char(2),char(2),char(15),char(6),char(9),char(9),char(8), -char(15),char(8),char(16),char(17),char(5),char(4),char(12),char(13),char(4),char(13), -char(9),char(15),char(18),char(6),char(0),char(3),char(0),char(63),char(50),char(63), -char(51),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(19),char(51),char(17),char(20),char(7),char(51),char(1),char(51), -char(17),char(35),char(17),char(52),char(55),char(35),char(1),char(35),char(203),char(159), -char(14),char(8),char(3),char(52),char(186),char(160),char(17),char(9),char(252),char(203), -char(186),char(5),char(182),char(252),char(211),char(225),char(182),char(4),char(196),char(250), -char(74),char(3),char(37),char(201),char(221),char(251),char(53),char(0),char(255),char(255), -char(0),char(203),char(0),char(0),char(5),char(82),char(7),char(94),char(2),char(38), -char(1),char(178),char(0),char(0),char(1),char(7),char(2),char(54),char(0),char(225), -char(1),char(82),char(0),char(8),char(179),char(1),char(16),char(5),char(38),char(0), -char(43),char(53),char(0),char(1),char(0),char(201),char(0),char(0),char(4),char(229), -char(5),char(182),char(0),char(10),char(0),char(45),char(64),char(22),char(7),char(3), -char(3),char(4),char(0),char(9),char(10),char(4),char(4),char(11),char(12),char(10), -char(7),char(2),char(7),char(4),char(8),char(5),char(3),char(1),char(4),char(18), -char(0),char(63),char(51),char(63),char(51),char(18),char(57),char(57),char(17),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(33),char(35),char(1),char(17),char(35),char(17),char(51),char(17),char(1), -char(51),char(1),char(4),char(229),char(206),char(253),char(92),char(170),char(170),char(2), -char(147),char(195),char(253),char(121),char(2),char(229),char(253),char(27),char(5),char(182), -char(253),char(60),char(2),char(196),char(253),char(58),char(0),char(1),char(0),char(0), -char(255),char(231),char(4),char(217),char(5),char(182),char(0),char(19),char(0),char(45), -char(64),char(24),char(3),char(18),char(1),char(0),char(0),char(18),char(10),char(3), -char(20),char(21),char(18),char(3),char(73),char(89),char(18),char(3),char(8),char(13), -char(74),char(89),char(8),char(19),char(1),char(18),char(0),char(63),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(49),char(48),char(33),char(35),char(17),char(33),char(7), -char(2),char(2),char(6),char(39),char(34),char(39),char(53),char(22),char(51),char(50), -char(54),char(54),char(18),char(19),char(33),char(4),char(217),char(170),char(254),char(37), -char(31),char(61),char(93),char(152),char(126),char(74),char(59),char(54),char(59),char(53), -char(79),char(61),char(93),char(56),char(3),char(18),char(5),char(31),char(240),char(254), -char(33),char(254),char(69),char(174),char(2),char(25),char(143),char(26),char(87),char(215), -char(2),char(89),char(1),char(184),char(255),char(255),char(0),char(201),char(0),char(0), -char(6),char(113),char(5),char(182),char(2),char(6),char(0),char(48),char(0),char(0), -char(255),char(255),char(0),char(201),char(0),char(0),char(5),char(31),char(5),char(182), -char(2),char(6),char(0),char(43),char(0),char(0),char(255),char(255),char(0),char(125), -char(255),char(236),char(5),char(190),char(5),char(205),char(2),char(6),char(0),char(50), -char(0),char(0),char(255),char(255),char(0),char(201),char(0),char(0),char(5),char(12), -char(5),char(182),char(2),char(6),char(1),char(110),char(0),char(0),char(255),char(255), -char(0),char(201),char(0),char(0),char(4),char(104),char(5),char(182),char(2),char(6), -char(0),char(51),char(0),char(0),char(255),char(255),char(0),char(125),char(255),char(236), -char(4),char(207),char(5),char(203),char(2),char(6),char(0),char(38),char(0),char(0), -char(255),char(255),char(0),char(18),char(0),char(0),char(4),char(90),char(5),char(182), -char(2),char(6),char(0),char(55),char(0),char(0),char(0),char(1),char(0),char(27), -char(255),char(236),char(4),char(248),char(5),char(182),char(0),char(22),char(0),char(42), -char(64),char(21),char(18),char(8),char(2),char(9),char(4),char(23),char(24),char(14), -char(13),char(8),char(13),char(0),char(17),char(9),char(3),char(0),char(5),char(73), -char(89),char(0),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(51), -char(18),char(57),char(57),char(17),char(51),char(17),char(18),char(1),char(23),char(57), -char(49),char(48),char(5),char(34),char(39),char(53),char(22),char(51),char(50),char(54), -char(55),char(1),char(51),char(1),char(22),char(23),char(51),char(54),char(55),char(1), -char(51),char(1),char(14),char(2),char(1),char(37),char(111),char(84),char(93),char(96), -char(110),char(133),char(66),char(253),char(199),char(188),char(1),char(176),char(25),char(14), -char(8),char(28),char(11),char(1),char(103),char(180),char(254),char(45),char(84),char(135), -char(169),char(20),char(30),char(166),char(43),char(101),char(139),char(4),char(65),char(252), -char(193),char(49),char(47),char(84),char(22),char(3),char(53),char(251),char(234),char(187), -char(170),char(79),char(255),char(255),char(0),char(106),char(255),char(236),char(5),char(248), -char(5),char(203),char(2),char(6),char(1),char(115),char(0),char(0),char(255),char(255), -char(0),char(8),char(0),char(0),char(4),char(150),char(5),char(182),char(2),char(6), -char(0),char(59),char(0),char(0),char(0),char(1),char(0),char(201),char(254),char(131), -char(5),char(184),char(5),char(182),char(0),char(11),char(0),char(50),char(64),char(25), -char(8),char(5),char(9),char(0),char(3),char(2),char(2),char(0),char(5),char(3), -char(12),char(13),char(10),char(6),char(3),char(0),char(8),char(5),char(8),char(73), -char(89),char(5),char(18),char(3),char(34),char(0),char(63),char(63),char(43),char(17), -char(0),char(51),char(24),char(63),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(51), -char(17),char(35),char(17),char(33),char(17),char(51),char(17),char(33),char(17),char(51), -char(5),char(12),char(172),char(161),char(251),char(178),char(170),char(2),char(239),char(170), -char(154),char(253),char(233),char(1),char(125),char(5),char(182),char(250),char(228),char(5), -char(28),char(0),char(0),char(1),char(0),char(170),char(0),char(0),char(4),char(199), -char(5),char(182),char(0),char(19),char(0),char(45),char(64),char(22),char(11),char(8), -char(17),char(1),char(1),char(0),char(8),char(0),char(20),char(21),char(5),char(14), -char(73),char(89),char(5),char(5),char(1),char(18),char(9),char(3),char(1),char(18), -char(0),char(63),char(63),char(51),char(18),char(57),char(47),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(33),char(35),char(17),char(6),char(6),char(35),char(34),char(38),char(53), -char(17),char(51),char(17),char(20),char(22),char(51),char(50),char(54),char(55),char(17), -char(51),char(4),char(199),char(170),char(149),char(198),char(106),char(207),char(223),char(170), -char(127),char(143),char(97),char(177),char(169),char(170),char(2),char(92),char(53),char(39), -char(190),char(179),char(2),char(69),char(253),char(207),char(121),char(116),char(29),char(55), -char(2),char(202),char(0),char(1),char(0),char(201),char(0),char(0),char(7),char(121), -char(5),char(182),char(0),char(11),char(0),char(49),char(64),char(24),char(4),char(1), -char(8),char(5),char(9),char(0),char(0),char(5),char(1),char(3),char(12),char(13), -char(10),char(6),char(2),char(3),char(8),char(4),char(1),char(4),char(73),char(89), -char(1),char(18),char(0),char(63),char(43),char(17),char(0),char(51),char(24),char(63), -char(51),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(17),char(51),char(17), -char(33),char(17),char(51),char(17),char(33),char(17),char(51),char(7),char(121),char(249), -char(80),char(170),char(2),char(88),char(170),char(2),char(88),char(172),char(5),char(182), -char(250),char(228),char(5),char(28),char(250),char(228),char(5),char(28),char(0),char(1), -char(0),char(201),char(254),char(131),char(8),char(4),char(5),char(182),char(0),char(15), -char(0),char(59),char(64),char(30),char(3),char(0),char(7),char(4),char(8),char(11), -char(14),char(13),char(13),char(11),char(4),char(0),char(4),char(16),char(17),char(14), -char(34),char(9),char(5),char(1),char(3),char(11),char(7),char(3),char(0),char(3), -char(73),char(89),char(0),char(18),char(0),char(63),char(43),char(17),char(0),char(51), -char(51),char(24),char(63),char(51),char(51),char(63),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(51),char(17),char(51),char(17),char(33),char(17),char(51),char(17),char(33), -char(17),char(51),char(17),char(51),char(17),char(35),char(17),char(201),char(170),char(2), -char(71),char(172),char(2),char(72),char(170),char(172),char(162),char(5),char(182),char(250), -char(228),char(5),char(28),char(250),char(228),char(5),char(28),char(250),char(228),char(253), -char(233),char(1),char(125),char(0),char(0),char(2),char(0),char(18),char(0),char(0), -char(5),char(23),char(5),char(182),char(0),char(12),char(0),char(21),char(0),char(61), -char(64),char(32),char(9),char(13),char(13),char(4),char(17),char(0),char(0),char(4), -char(6),char(3),char(22),char(23),char(9),char(21),char(73),char(89),char(9),char(9), -char(4),char(7),char(7),char(6),char(73),char(89),char(7),char(3),char(4),char(13), -char(74),char(89),char(4),char(18),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(20),char(4),char(35),char(33),char(17),char(33),char(53),char(33), -char(17),char(51),char(32),char(4),char(1),char(51),char(50),char(54),char(53),char(52), -char(38),char(35),char(35),char(5),char(23),char(254),char(253),char(249),char(254),char(71), -char(254),char(176),char(1),char(250),char(244),char(1),char(5),char(1),char(18),char(252), -char(245),char(252),char(181),char(169),char(175),char(203),char(224),char(1),char(170),char(206), -char(220),char(5),char(31),char(151),char(253),char(144),char(205),char(254),char(26),char(139), -char(140),char(136),char(126),char(0),char(0),char(3),char(0),char(201),char(0),char(0), -char(6),char(10),char(5),char(182),char(0),char(10),char(0),char(19),char(0),char(23), -char(0),char(63),char(64),char(32),char(3),char(11),char(11),char(0),char(15),char(7), -char(21),char(20),char(20),char(7),char(0),char(3),char(24),char(25),char(21),char(18), -char(3),char(19),char(73),char(89),char(3),char(3),char(0),char(22),char(1),char(3), -char(0),char(11),char(74),char(89),char(0),char(18),char(0),char(63),char(43),char(0), -char(24),char(63),char(51),char(18),char(57),char(47),char(43),char(0),char(24),char(63), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(51),char(17),char(51),char(17),char(51), -char(32),char(4),char(21),char(20),char(4),char(35),char(37),char(51),char(50),char(54), -char(53),char(52),char(38),char(35),char(35),char(1),char(35),char(17),char(51),char(201), -char(170),char(239),char(1),char(5),char(1),char(18),char(254),char(253),char(249),char(254), -char(246),char(247),char(181),char(170),char(179),char(200),char(219),char(4),char(151),char(170), -char(170),char(5),char(182),char(253),char(144),char(205),char(207),char(206),char(220),char(145), -char(141),char(140),char(137),char(123),char(253),char(82),char(5),char(182),char(0),char(2), -char(0),char(201),char(0),char(0),char(4),char(186),char(5),char(182),char(0),char(10), -char(0),char(18),char(0),char(50),char(64),char(25),char(7),char(11),char(11),char(4), -char(14),char(0),char(4),char(0),char(19),char(20),char(7),char(18),char(73),char(89), -char(7),char(7),char(4),char(5),char(3),char(4),char(11),char(74),char(89),char(4), -char(18),char(0),char(63),char(43),char(0),char(24),char(63),char(18),char(57),char(47), -char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(4),char(35),char(33),char(17), -char(51),char(17),char(33),char(32),char(4),char(1),char(33),char(32),char(17),char(52), -char(38),char(35),char(33),char(4),char(186),char(254),char(241),char(251),char(254),char(25), -char(170),char(1),char(35),char(1),char(11),char(1),char(25),char(252),char(185),char(1), -char(43),char(1),char(108),char(187),char(206),char(254),char(242),char(1),char(170),char(203), -char(223),char(5),char(182),char(253),char(144),char(211),char(254),char(32),char(1),char(23), -char(135),char(127),char(0),char(1),char(0),char(61),char(255),char(236),char(4),char(137), -char(5),char(203),char(0),char(26),char(0),char(58),char(64),char(31),char(24),char(21), -char(21),char(9),char(9),char(22),char(15),char(3),char(4),char(27),char(28),char(23), -char(22),char(73),char(89),char(23),char(23),char(12),char(5),char(12),char(18),char(73), -char(89),char(12),char(19),char(5),char(0),char(73),char(89),char(5),char(4),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(24),char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(34),char(7),char(39),char(54),char(51), -char(50),char(4),char(18),char(21),char(16),char(0),char(33),char(34),char(39),char(53), -char(22),char(22),char(51),char(32),char(0),char(19),char(33),char(53),char(33),char(38), -char(0),char(1),char(211),char(172),char(162),char(72),char(172),char(236),char(217),char(1), -char(57),char(162),char(254),char(148),char(254),char(170),char(227),char(156),char(83),char(172), -char(99),char(1),char(15),char(1),char(20),char(8),char(253),char(49),char(2),char(205), -char(22),char(254),char(241),char(5),char(51),char(76),char(144),char(84),char(176),char(254), -char(186),char(221),char(254),char(136),char(254),char(108),char(57),char(149),char(21),char(34), -char(1),char(33),char(1),char(16),char(152),char(229),char(1),char(2),char(0),char(2), -char(0),char(201),char(255),char(236),char(7),char(231),char(5),char(205),char(0),char(18), -char(0),char(30),char(0),char(71),char(64),char(38),char(12),char(8),char(8),char(9), -char(19),char(13),char(6),char(25),char(0),char(0),char(6),char(9),char(3),char(31), -char(32),char(16),char(28),char(73),char(89),char(16),char(4),char(12),char(7),char(73), -char(89),char(12),char(12),char(9),char(10),char(3),char(9),char(18),char(3),char(22), -char(73),char(89),char(3),char(19),char(0),char(63),char(43),char(0),char(24),char(63), -char(63),char(18),char(57),char(47),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(33),char(32), -char(0),char(3),char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(18), -char(0),char(33),char(32),char(0),char(1),char(16),char(18),char(51),char(50),char(18), -char(17),char(16),char(2),char(35),char(34),char(2),char(7),char(231),char(254),char(171), -char(254),char(208),char(254),char(211),char(254),char(171),char(11),char(254),char(158),char(170), -char(170),char(1),char(100),char(23),char(1),char(81),char(1),char(31),char(1),char(51), -char(1),char(86),char(251),char(160),char(238),char(231),char(234),char(237),char(235),char(232), -char(233),char(240),char(2),char(221),char(254),char(158),char(254),char(113),char(1),char(111), -char(1),char(85),char(253),char(80),char(5),char(182),char(253),char(146),char(1),char(55), -char(1),char(78),char(254),char(111),char(254),char(161),char(254),char(216),char(254),char(204), -char(1),char(50),char(1),char(42),char(1),char(42),char(1),char(46),char(254),char(207), -char(0),char(2),char(0),char(51),char(0),char(0),char(4),char(78),char(5),char(182), -char(0),char(13),char(0),char(21),char(0),char(61),char(64),char(32),char(21),char(12), -char(12),char(11),char(18),char(6),char(2),char(6),char(3),char(11),char(4),char(23), -char(22),char(0),char(20),char(74),char(89),char(3),char(9),char(0),char(0),char(2), -char(9),char(9),char(15),char(74),char(89),char(9),char(3),char(12),char(2),char(18), -char(0),char(63),char(51),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(18),char(57),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(1),char(35), -char(1),char(38),char(38),char(53),char(52),char(36),char(33),char(33),char(17),char(35), -char(17),char(17),char(35),char(34),char(6),char(21),char(16),char(33),char(51),char(2), -char(123),char(254),char(129),char(201),char(1),char(154),char(161),char(146),char(1),char(15), -char(1),char(19),char(1),char(146),char(170),char(227),char(183),char(190),char(1),char(123), -char(221),char(2),char(98),char(253),char(158),char(2),char(127),char(51),char(207),char(158), -char(196),char(211),char(250),char(74),char(2),char(98),char(2),char(193),char(126),char(142), -char(254),char(221),char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205), -char(4),char(90),char(2),char(6),char(0),char(68),char(0),char(0),char(0),char(2), -char(0),char(119),char(255),char(236),char(4),char(84),char(6),char(33),char(0),char(23), -char(0),char(34),char(0),char(59),char(64),char(30),char(26),char(18),char(32),char(11), -char(0),char(0),char(6),char(18),char(3),char(36),char(35),char(12),char(11),char(15), -char(28),char(70),char(89),char(11),char(15),char(15),char(21),char(5),char(21),char(24), -char(70),char(89),char(21),char(22),char(5),char(1),char(0),char(63),char(63),char(43), -char(17),char(18),char(0),char(57),char(24),char(47),char(57),char(43),char(17),char(0), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(19),char(16),char(18),char(55),char(36),char(55),char(23), -char(4),char(7),char(6),char(6),char(7),char(51),char(54),char(54),char(51),char(50), -char(18),char(21),char(16),char(0),char(35),char(34),char(0),char(5),char(32),char(17), -char(16),char(33),char(34),char(6),char(6),char(7),char(16),char(18),char(119),char(212), -char(230),char(1),char(30),char(218),char(31),char(254),char(165),char(149),char(145),char(145), -char(7),char(12),char(62),char(196),char(107),char(202),char(226),char(254),char(250),char(234), -char(231),char(254),char(250),char(1),char(252),char(1),char(49),char(254),char(235),char(76), -char(141),char(117),char(32),char(166),char(2),char(145),char(1),char(104),char(1),char(147), -char(50),char(61),char(38),char(146),char(58),char(34),char(33),char(246),char(212),char(84), -char(96),char(254),char(250),char(232),char(254),char(255),char(254),char(223),char(1),char(98), -char(215),char(1),char(133),char(1),char(115),char(63),char(104),char(55),char(254),char(249), -char(254),char(237),char(0),char(3),char(0),char(176),char(0),char(0),char(4),char(76), -char(4),char(72),char(0),char(14),char(0),char(22),char(0),char(31),char(0),char(73), -char(64),char(38),char(28),char(20),char(20),char(11),char(23),char(0),char(15),char(7), -char(7),char(0),char(3),char(11),char(4),char(32),char(33),char(4),char(28),char(19), -char(28),char(19),char(70),char(89),char(28),char(28),char(11),char(12),char(12),char(27), -char(70),char(89),char(12),char(15),char(11),char(20),char(70),char(89),char(11),char(21), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0), -char(57),char(24),char(47),char(43),char(17),char(18),char(0),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(20),char(6),char(7),char(21),char(22),char(22), -char(21),char(20),char(6),char(35),char(33),char(17),char(33),char(32),char(3),char(52), -char(38),char(35),char(33),char(17),char(33),char(32),char(3),char(52),char(38),char(35), -char(33),char(17),char(33),char(50),char(54),char(4),char(41),char(123),char(111),char(140), -char(129),char(225),char(216),char(254),char(29),char(1),char(225),char(1),char(152),char(131), -char(135),char(156),char(254),char(211),char(1),char(49),char(1),char(31),char(31),char(123), -char(125),char(254),char(199),char(1),char(25),char(154),char(126),char(3),char(53),char(107), -char(111),char(19),char(9),char(19),char(126),char(111),char(153),char(166),char(4),char(72), -char(253),char(2),char(89),char(81),char(254),char(151),char(2),char(154),char(80),char(67), -char(254),char(203),char(76),char(0),char(0),char(1),char(0),char(176),char(0),char(0), -char(3),char(68),char(4),char(72),char(0),char(5),char(0),char(29),char(64),char(14), -char(2),char(3),char(0),char(3),char(7),char(6),char(4),char(1),char(70),char(89), -char(4),char(15),char(3),char(21),char(0),char(63),char(63),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(49),char(48),char(1),char(33),char(17), -char(35),char(17),char(33),char(3),char(68),char(254),char(18),char(166),char(2),char(148), -char(3),char(186),char(252),char(70),char(4),char(72),char(0),char(2),char(0),char(41), -char(254),char(133),char(4),char(104),char(4),char(72),char(0),char(13),char(0),char(19), -char(0),char(67),char(64),char(36),char(4),char(5),char(19),char(7),char(16),char(10), -char(14),char(12),char(1),char(0),char(0),char(12),char(10),char(7),char(5),char(5), -char(20),char(21),char(10),char(16),char(71),char(89),char(10),char(15),char(1),char(5), -char(34),char(19),char(12),char(6),char(3),char(6),char(70),char(89),char(3),char(21), -char(0),char(63),char(43),char(17),char(0),char(51),char(51),char(24),char(63),char(51), -char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(35),char(17),char(33),char(17),char(35),char(17),char(51),char(54),char(18),char(19), -char(33),char(17),char(51),char(33),char(17),char(35),char(6),char(2),char(7),char(4), -char(104),char(161),char(253),char(2),char(160),char(86),char(134),char(152),char(3),char(2), -char(43),char(157),char(254),char(195),char(246),char(13),char(145),char(108),char(254),char(133), -char(1),char(123),char(254),char(133),char(2),char(10),char(182),char(1),char(234),char(1), -char(25),char(252),char(71),char(3),char(54),char(222),char(254),char(57),char(145),char(0), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(18),char(4),char(92), -char(2),char(6),char(0),char(72),char(0),char(0),char(0),char(1),char(0),char(4), -char(0),char(0),char(5),char(223),char(4),char(70),char(0),char(17),char(0),char(60), -char(64),char(31),char(2),char(9),char(9),char(17),char(10),char(6),char(4),char(5), -char(10),char(14),char(15),char(13),char(7),char(19),char(18),char(17),char(11),char(8), -char(5),char(2),char(14),char(14),char(13),char(3),char(0),char(15),char(15),char(10), -char(7),char(13),char(21),char(0),char(63),char(51),char(51),char(63),char(51),char(51), -char(18),char(57),char(17),char(51),char(51),char(51),char(51),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48), -char(1),char(51),char(17),char(1),char(51),char(1),char(1),char(35),char(1),char(17), -char(35),char(17),char(1),char(35),char(1),char(1),char(51),char(1),char(2),char(164), -char(153),char(1),char(197),char(182),char(254),char(54),char(1),char(241),char(192),char(254), -char(30),char(153),char(254),char(31),char(191),char(1),char(240),char(254),char(55),char(182), -char(1),char(195),char(4),char(70),char(253),char(237),char(2),char(19),char(253),char(237), -char(253),char(205),char(2),char(43),char(253),char(213),char(2),char(43),char(253),char(213), -char(2),char(51),char(2),char(19),char(253),char(237),char(0),char(1),char(0),char(68), -char(255),char(236),char(3),char(127),char(4),char(92),char(0),char(34),char(0),char(77), -char(64),char(43),char(2),char(13),char(30),char(19),char(19),char(13),char(15),char(33), -char(8),char(24),char(6),char(35),char(36),char(16),char(34),char(33),char(34),char(33), -char(70),char(89),char(15),char(34),char(31),char(34),char(2),char(11),char(3),char(34), -char(34),char(22),char(10),char(22),char(27),char(70),char(89),char(22),char(22),char(10), -char(4),char(70),char(89),char(10),char(16),char(0),char(63),char(43),char(0),char(24), -char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(95),char(94), -char(93),char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(32),char(53), -char(52),char(35),char(34),char(6),char(7),char(39),char(54),char(51),char(50),char(22), -char(21),char(20),char(7),char(21),char(22),char(22),char(21),char(20),char(6),char(35), -char(34),char(39),char(53),char(22),char(51),char(50),char(54),char(53),char(52),char(33), -char(35),char(53),char(1),char(129),char(1),char(55),char(252),char(77),char(126),char(102), -char(59),char(170),char(201),char(189),char(218),char(205),char(126),char(116),char(245),char(216), -char(237),char(129),char(183),char(187),char(144),char(147),char(254),char(201),char(152),char(2), -char(129),char(172),char(162),char(28),char(42),char(135),char(76),char(155),char(134),char(184), -char(57),char(8),char(37),char(137),char(103),char(152),char(169),char(71),char(152),char(86), -char(99),char(93),char(191),char(141),char(0),char(1),char(0),char(176),char(0),char(0), -char(4),char(98),char(4),char(72),char(0),char(13),char(0),char(52),char(64),char(25), -char(8),char(4),char(7),char(7),char(6),char(11),char(3),char(3),char(12),char(6), -char(12),char(15),char(14),char(3),char(10),char(12),char(4),char(13),char(15),char(12), -char(21),char(7),char(21),char(4),char(15),char(0),char(63),char(63),char(63),char(63), -char(17),char(18),char(57),char(57),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(49),char(48), -char(1),char(17),char(7),char(7),char(1),char(51),char(17),char(35),char(17),char(55), -char(55),char(1),char(35),char(17),char(1),char(76),char(7),char(3),char(2),char(81), -char(207),char(155),char(3),char(5),char(253),char(176),char(207),char(4),char(72),char(253), -char(73),char(182),char(57),char(3),char(166),char(251),char(184),char(2),char(158),char(132), -char(130),char(252),char(92),char(4),char(72),char(0),char(255),char(255),char(0),char(176), -char(0),char(0),char(4),char(98),char(6),char(12),char(2),char(38),char(1),char(210), -char(0),char(0),char(1),char(6),char(2),char(54),char(61),char(0),char(0),char(8), -char(179),char(1),char(14),char(17),char(38),char(0),char(43),char(53),char(0),char(1), -char(0),char(176),char(0),char(0),char(4),char(12),char(4),char(72),char(0),char(10), -char(0),char(45),char(64),char(22),char(10),char(6),char(6),char(7),char(3),char(1), -char(2),char(7),char(4),char(12),char(11),char(2),char(10),char(5),char(10),char(7), -char(0),char(8),char(15),char(4),char(7),char(21),char(0),char(63),char(51),char(63), -char(51),char(18),char(57),char(57),char(17),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(51),char(1), -char(1),char(35),char(1),char(17),char(35),char(17),char(51),char(17),char(3),char(47), -char(182),char(254),char(39),char(2),char(0),char(194),char(254),char(12),char(166),char(166), -char(4),char(72),char(253),char(239),char(253),char(201),char(2),char(43),char(253),char(213), -char(4),char(72),char(253),char(235),char(0),char(1),char(0),char(16),char(255),char(242), -char(3),char(225),char(4),char(72),char(0),char(16),char(0),char(45),char(64),char(24), -char(1),char(0),char(3),char(15),char(10),char(15),char(0),char(3),char(18),char(17), -char(15),char(3),char(70),char(89),char(15),char(15),char(7),char(12),char(71),char(89), -char(7),char(22),char(1),char(21),char(0),char(63),char(63),char(43),char(0),char(24), -char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(49),char(48),char(33),char(35),char(17),char(33),char(2),char(2),char(6), -char(35),char(34),char(39),char(53),char(22),char(51),char(50),char(18),char(19),char(33), -char(3),char(225),char(168),char(254),char(183),char(27),char(96),char(153),char(118),char(54), -char(32),char(22),char(28),char(115),char(136),char(35),char(2),char(129),char(3),char(186), -char(254),char(156),char(254),char(94),char(194),char(12),char(123),char(6),char(1),char(230), -char(1),char(239),char(0),char(1),char(0),char(176),char(0),char(0),char(5),char(47), -char(4),char(70),char(0),char(20),char(0),char(53),char(64),char(25),char(3),char(6), -char(6),char(5),char(18),char(15),char(15),char(16),char(5),char(16),char(22),char(21), -char(7),char(14),char(0),char(14),char(11),char(3),char(17),char(15),char(6),char(16), -char(21),char(11),char(21),char(0),char(63),char(63),char(51),char(63),char(51),char(18), -char(57),char(57),char(17),char(51),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(37), -char(55),char(55),char(1),char(51),char(17),char(35),char(17),char(7),char(7),char(1), -char(35),char(1),char(38),char(39),char(17),char(35),char(17),char(51),char(1),char(22), -char(2),char(233),char(31),char(43),char(1),char(41),char(211),char(147),char(20),char(58), -char(254),char(229),char(139),char(254),char(229),char(53),char(20),char(148),char(203),char(1), -char(31),char(43),char(160),char(93),char(118),char(2),char(211),char(251),char(186),char(3), -char(137),char(58),char(153),char(253),char(74),char(2),char(184),char(134),char(75),char(252), -char(119),char(4),char(70),char(253),char(73),char(110),char(0),char(1),char(0),char(176), -char(0),char(0),char(4),char(98),char(4),char(72),char(0),char(11),char(0),char(57), -char(64),char(30),char(2),char(6),char(6),char(5),char(1),char(9),char(9),char(10), -char(5),char(10),char(13),char(12),char(1),char(8),char(70),char(89),char(47),char(1), -char(63),char(1),char(2),char(1),char(1),char(10),char(3),char(11),char(15),char(6), -char(10),char(21),char(0),char(63),char(51),char(63),char(51),char(18),char(57),char(47), -char(93),char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(33), -char(17),char(51),char(17),char(35),char(17),char(33),char(17),char(35),char(17),char(1), -char(86),char(2),char(102),char(166),char(166),char(253),char(154),char(166),char(4),char(72), -char(254),char(53),char(1),char(203),char(251),char(184),char(1),char(238),char(254),char(18), -char(4),char(72),char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98), -char(4),char(92),char(2),char(6),char(0),char(82),char(0),char(0),char(0),char(1), -char(0),char(176),char(0),char(0),char(4),char(72),char(4),char(72),char(0),char(7), -char(0),char(35),char(64),char(17),char(0),char(1),char(5),char(4),char(1),char(4), -char(8),char(9),char(2),char(7),char(70),char(89),char(2),char(15),char(5),char(1), -char(21),char(0),char(63),char(51),char(63),char(43),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(35),char(17), -char(33),char(17),char(35),char(17),char(33),char(1),char(86),char(166),char(3),char(152), -char(168),char(253),char(182),char(4),char(72),char(251),char(184),char(3),char(184),char(0), -char(255),char(255),char(0),char(176),char(254),char(20),char(4),char(117),char(4),char(92), -char(2),char(6),char(0),char(83),char(0),char(0),char(255),char(255),char(0),char(115), -char(255),char(236),char(3),char(139),char(4),char(92),char(2),char(6),char(0),char(70), -char(0),char(0),char(0),char(1),char(0),char(41),char(0),char(0),char(3),char(147), -char(4),char(72),char(0),char(7),char(0),char(36),char(64),char(18),char(2),char(3), -char(0),char(3),char(5),char(3),char(8),char(9),char(1),char(5),char(6),char(5), -char(70),char(89),char(6),char(15),char(3),char(21),char(0),char(63),char(63),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(49),char(48),char(1),char(33),char(17),char(35),char(17),char(33),char(53),char(33), -char(3),char(147),char(254),char(156),char(166),char(254),char(160),char(3),char(106),char(3), -char(186),char(252),char(70),char(3),char(186),char(142),char(255),char(255),char(0),char(2), -char(254),char(20),char(4),char(6),char(4),char(72),char(2),char(6),char(0),char(92), -char(0),char(0),char(0),char(3),char(0),char(113),char(254),char(20),char(5),char(70), -char(6),char(20),char(0),char(17),char(0),char(24),char(0),char(30),char(0),char(76), -char(64),char(39),char(18),char(9),char(28),char(15),char(4),char(4),char(21),char(12), -char(5),char(25),char(0),char(0),char(5),char(9),char(3),char(31),char(32),char(13), -char(0),char(27),char(22),char(12),char(22),char(70),char(89),char(15),char(12),char(16), -char(28),char(21),char(6),char(21),char(70),char(89),char(3),char(6),char(22),char(5), -char(27),char(0),char(63),char(63),char(51),char(43),char(17),char(0),char(51),char(24), -char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(51),char(17), -char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(0),char(7), -char(17),char(35),char(17),char(38),char(0),char(53),char(52),char(0),char(55),char(17), -char(51),char(17),char(22),char(0),char(5),char(20),char(22),char(23),char(17),char(6), -char(6),char(5),char(16),char(37),char(17),char(54),char(54),char(5),char(70),char(254), -char(229),char(254),char(164),char(248),char(254),char(224),char(1),char(31),char(255),char(158), -char(251),char(1),char(30),char(251),char(217),char(176),char(192),char(185),char(183),char(3), -char(123),char(254),char(147),char(190),char(175),char(2),char(37),char(249),char(254),char(217), -char(21),char(254),char(36),char(1),char(220),char(19),char(1),char(46),char(244),char(249), -char(1),char(38),char(20),char(1),char(188),char(254),char(68),char(23),char(254),char(212), -char(240),char(192),char(218),char(18),char(3),char(84),char(17),char(207),char(200),char(1), -char(127),char(39),char(252),char(174),char(19),char(218),char(255),char(255),char(0),char(39), -char(0),char(0),char(4),char(8),char(4),char(72),char(2),char(6),char(0),char(91), -char(0),char(0),char(0),char(1),char(0),char(176),char(254),char(133),char(4),char(221), -char(4),char(72),char(0),char(11),char(0),char(50),char(64),char(25),char(6),char(3), -char(7),char(10),char(1),char(0),char(0),char(10),char(3),char(3),char(12),char(13), -char(8),char(4),char(15),char(10),char(6),char(3),char(6),char(70),char(89),char(3), -char(21),char(1),char(34),char(0),char(63),char(63),char(43),char(17),char(0),char(51), -char(24),char(63),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(35),char(17),char(33), -char(17),char(51),char(17),char(33),char(17),char(51),char(17),char(51),char(4),char(221), -char(166),char(252),char(121),char(166),char(2),char(70),char(166),char(155),char(254),char(133), -char(1),char(123),char(4),char(72),char(252),char(71),char(3),char(185),char(252),char(71), -char(0),char(1),char(0),char(156),char(0),char(0),char(4),char(45),char(4),char(72), -char(0),char(18),char(0),char(45),char(64),char(22),char(6),char(10),char(10),char(9), -char(1),char(17),char(9),char(17),char(20),char(19),char(3),char(14),char(70),char(89), -char(3),char(3),char(10),char(7),char(18),char(15),char(10),char(21),char(0),char(63), -char(63),char(51),char(18),char(57),char(47),char(43),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(17),char(20),char(51),char(50),char(54),char(55),char(17),char(51),char(17),char(35), -char(17),char(6),char(6),char(35),char(34),char(38),char(53),char(17),char(1),char(66), -char(219),char(91),char(166),char(105),char(166),char(166),char(105),char(179),char(113),char(164), -char(186),char(4),char(72),char(254),char(112),char(192),char(56),char(67),char(1),char(213), -char(251),char(184),char(1),char(240),char(72),char(59),char(172),char(147),char(1),char(156), -char(0),char(1),char(0),char(176),char(0),char(0),char(6),char(111),char(4),char(72), -char(0),char(11),char(0),char(49),char(64),char(24),char(8),char(5),char(0),char(9), -char(1),char(4),char(4),char(9),char(5),char(3),char(12),char(13),char(10),char(2), -char(6),char(15),char(0),char(8),char(5),char(8),char(70),char(89),char(5),char(21), -char(0),char(63),char(43),char(17),char(0),char(51),char(24),char(63),char(51),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(37),char(33),char(17),char(51),char(17),char(33),char(17), -char(51),char(17),char(33),char(17),char(51),char(3),char(225),char(1),char(230),char(168), -char(250),char(65),char(166),char(1),char(229),char(166),char(143),char(3),char(185),char(251), -char(184),char(4),char(72),char(252),char(71),char(3),char(185),char(0),char(0),char(1), -char(0),char(176),char(254),char(135),char(7),char(10),char(4),char(70),char(0),char(15), -char(0),char(59),char(64),char(30),char(12),char(9),char(0),char(13),char(1),char(4), -char(7),char(6),char(6),char(4),char(13),char(9),char(4),char(16),char(17),char(14), -char(2),char(10),char(15),char(4),char(0),char(12),char(9),char(12),char(70),char(89), -char(9),char(21),char(7),char(34),char(0),char(63),char(63),char(43),char(17),char(0), -char(51),char(51),char(24),char(63),char(51),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(37),char(33),char(17),char(51),char(17),char(51),char(17),char(35),char(17), -char(33),char(17),char(51),char(17),char(33),char(17),char(51),char(3),char(225),char(1), -char(230),char(166),char(157),char(168),char(250),char(78),char(166),char(1),char(229),char(166), -char(143),char(3),char(183),char(252),char(73),char(253),char(248),char(1),char(121),char(4), -char(70),char(252),char(73),char(3),char(183),char(0),char(0),char(2),char(0),char(41), -char(0),char(0),char(5),char(29),char(4),char(72),char(0),char(12),char(0),char(20), -char(0),char(61),char(64),char(32),char(0),char(18),char(18),char(8),char(13),char(4), -char(4),char(8),char(10),char(3),char(21),char(22),char(0),char(17),char(70),char(89), -char(0),char(0),char(8),char(11),char(11),char(10),char(70),char(89),char(11),char(15), -char(8),char(18),char(70),char(89),char(8),char(21),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(33),char(50),char(22),char(21),char(20),char(6), -char(35),char(33),char(17),char(33),char(53),char(33),char(1),char(52),char(38),char(35), -char(33),char(17),char(33),char(32),char(2),char(45),char(1),char(57),char(224),char(215), -char(223),char(220),char(254),char(37),char(254),char(162),char(2),char(4),char(2),char(76), -char(124),char(157),char(254),char(205),char(1),char(57),char(1),char(19),char(2),char(131), -char(154),char(155),char(166),char(168),char(3),char(186),char(142),char(252),char(252),char(93), -char(83),char(254),char(151),char(0),char(0),char(3),char(0),char(176),char(0),char(0), -char(5),char(121),char(4),char(72),char(0),char(10),char(0),char(14),char(0),char(22), -char(0),char(63),char(64),char(32),char(0),char(16),char(16),char(8),char(4),char(19), -char(12),char(11),char(11),char(19),char(8),char(3),char(23),char(24),char(12),char(21), -char(0),char(15),char(70),char(89),char(0),char(0),char(8),char(13),char(9),char(15), -char(8),char(16),char(70),char(89),char(8),char(21),char(0),char(63),char(43),char(0), -char(24),char(63),char(51),char(18),char(57),char(47),char(43),char(0),char(24),char(63), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(50),char(22),char(21), -char(20),char(6),char(35),char(33),char(17),char(51),char(1),char(35),char(17),char(51), -char(1),char(17),char(33),char(32),char(53),char(52),char(38),char(35),char(1),char(86), -char(1),char(43),char(209),char(201),char(213),char(207),char(254),char(57),char(166),char(4), -char(35),char(166),char(166),char(251),char(221),char(1),char(25),char(1),char(8),char(122), -char(147),char(2),char(131),char(155),char(154),char(165),char(169),char(4),char(72),char(251), -char(184),char(4),char(72),char(253),char(172),char(254),char(151),char(185),char(92),char(84), -char(0),char(2),char(0),char(176),char(0),char(0),char(4),char(76),char(4),char(72), -char(0),char(9),char(0),char(18),char(0),char(50),char(64),char(25),char(15),char(3), -char(0),char(11),char(11),char(7),char(3),char(7),char(20),char(19),char(0),char(10), -char(70),char(89),char(0),char(0),char(7),char(8),char(15),char(7),char(11),char(70), -char(89),char(7),char(21),char(0),char(63),char(43),char(0),char(24),char(63),char(18), -char(57),char(47),char(43),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(32),char(17), -char(20),char(6),char(35),char(33),char(17),char(51),char(17),char(17),char(33),char(50), -char(54),char(53),char(52),char(38),char(35),char(1),char(86),char(1),char(82),char(1), -char(164),char(219),char(211),char(254),char(18),char(166),char(1),char(64),char(132),char(140), -char(129),char(148),char(2),char(131),char(254),char(203),char(162),char(172),char(4),char(72), -char(253),char(172),char(254),char(151),char(92),char(93),char(91),char(85),char(0),char(1), -char(0),char(57),char(255),char(236),char(3),char(125),char(4),char(92),char(0),char(26), -char(0),char(68),char(64),char(38),char(12),char(9),char(9),char(24),char(24),char(10), -char(18),char(2),char(4),char(27),char(28),char(11),char(10),char(70),char(89),char(15), -char(11),char(31),char(11),char(2),char(11),char(3),char(11),char(11),char(0),char(21), -char(21),char(15),char(70),char(89),char(21),char(16),char(0),char(6),char(70),char(89), -char(0),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(95),char(94),char(93),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(5),char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(55), -char(33),char(53),char(33),char(38),char(38),char(35),char(34),char(7),char(39),char(54), -char(54),char(51),char(32),char(0),char(17),char(16),char(0),char(1),char(86),char(167), -char(118),char(60),char(140),char(91),char(174),char(189),char(10),char(253),char(213),char(2), -char(41),char(16),char(169),char(161),char(103),char(151),char(47),char(55),char(164),char(80), -char(1),char(0),char(1),char(10),char(254),char(223),char(20),char(57),char(147),char(23), -char(36),char(186),char(185),char(141),char(172),char(160),char(54),char(140),char(26),char(35), -char(254),char(219),char(254),char(236),char(254),char(243),char(254),char(214),char(0),char(2), -char(0),char(176),char(255),char(236),char(6),char(51),char(4),char(92),char(0),char(18), -char(0),char(30),char(0),char(81),char(64),char(45),char(12),char(8),char(8),char(9), -char(19),char(13),char(6),char(25),char(0),char(0),char(6),char(9),char(3),char(31), -char(32),char(16),char(28),char(70),char(89),char(16),char(16),char(12),char(7),char(70), -char(89),char(15),char(12),char(31),char(12),char(2),char(11),char(3),char(12),char(12), -char(9),char(10),char(15),char(9),char(21),char(3),char(22),char(70),char(89),char(3), -char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(18),char(57), -char(47),char(95),char(94),char(93),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(35),char(34), -char(2),char(39),char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(54), -char(54),char(51),char(50),char(0),char(1),char(20),char(22),char(51),char(50),char(54), -char(53),char(52),char(38),char(35),char(34),char(6),char(6),char(51),char(254),char(255), -char(224),char(213),char(250),char(14),char(254),char(225),char(166),char(166),char(1),char(33), -char(20),char(252),char(207),char(220),char(1),char(1),char(252),char(238),char(146),char(161), -char(158),char(149),char(146),char(161),char(161),char(146),char(2),char(37),char(254),char(243), -char(254),char(212),char(1),char(11),char(247),char(254),char(18),char(4),char(72),char(254), -char(53),char(228),char(251),char(254),char(207),char(254),char(250),char(211),char(219),char(213), -char(217),char(210),char(216),char(216),char(0),char(2),char(0),char(37),char(0),char(0), -char(3),char(193),char(4),char(72),char(0),char(13),char(0),char(20),char(0),char(61), -char(64),char(32),char(17),char(11),char(11),char(10),char(14),char(5),char(1),char(5), -char(2),char(10),char(4),char(22),char(21),char(13),char(16),char(70),char(89),char(2), -char(8),char(13),char(13),char(1),char(8),char(8),char(19),char(70),char(89),char(8), -char(15),char(11),char(1),char(21),char(0),char(63),char(51),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(18),char(57),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(51),char(35),char(1),char(38),char(38),char(53),char(52),char(54),char(51), -char(33),char(17),char(35),char(17),char(33),char(1),char(20),char(33),char(33),char(17), -char(33),char(34),char(231),char(194),char(1),char(59),char(127),char(135),char(202),char(181), -char(1),char(232),char(166),char(254),char(235),char(254),char(246),char(1),char(20),char(1), -char(11),char(254),char(211),char(242),char(1),char(207),char(28),char(161),char(122),char(150), -char(172),char(251),char(184),char(1),char(182),char(1),char(78),char(190),char(1),char(114), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(18),char(5),char(211), -char(2),char(38),char(0),char(72),char(0),char(0),char(1),char(6),char(0),char(106), -char(8),char(0),char(0),char(10),char(180),char(3),char(2),char(48),char(17),char(38), -char(0),char(43),char(53),char(53),char(0),char(1),char(0),char(20),char(254),char(20), -char(4),char(68),char(6),char(20),char(0),char(39),char(0),char(102),char(64),char(58), -char(29),char(27),char(23),char(15),char(15),char(20),char(16),char(7),char(37),char(37), -char(25),char(2),char(16),char(18),char(5),char(40),char(41),char(30),char(29),char(33), -char(11),char(70),char(89),char(26),char(18),char(19),char(18),char(71),char(89),char(23), -char(19),char(15),char(19),char(31),char(19),char(47),char(19),char(3),char(9),char(3), -char(29),char(33),char(19),char(19),char(33),char(29),char(3),char(16),char(21),char(0), -char(16),char(21),char(0),char(5),char(70),char(89),char(0),char(27),char(0),char(63), -char(43),char(0),char(24),char(63),char(63),char(18),char(23),char(57),char(47),char(47), -char(47),char(95),char(94),char(93),char(17),char(51),char(43),char(17),char(0),char(51), -char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(51),char(17),char(51),char(51),char(51),char(49),char(48), -char(1),char(34),char(39),char(53),char(22),char(51),char(50),char(53),char(17),char(52), -char(38),char(35),char(34),char(6),char(21),char(17),char(35),char(17),char(35),char(53), -char(51),char(53),char(51),char(21),char(33),char(21),char(33),char(21),char(20),char(7), -char(51),char(54),char(54),char(51),char(50),char(22),char(21),char(17),char(20),char(6), -char(3),char(47),char(79),char(52),char(58),char(55),char(129),char(122),char(130),char(173), -char(157),char(168),char(156),char(156),char(166),char(1),char(145),char(254),char(111),char(8), -char(10),char(49),char(181),char(116),char(201),char(201),char(137),char(254),char(20),char(25), -char(137),char(20),char(170),char(3),char(82),char(134),char(132),char(188),char(211),char(253), -char(231),char(4),char(219),char(127),char(186),char(186),char(127),char(196),char(84),char(56), -char(79),char(91),char(191),char(210),char(252),char(182),char(156),char(170),char(255),char(255), -char(0),char(176),char(0),char(0),char(3),char(68),char(6),char(33),char(2),char(38), -char(1),char(205),char(0),char(0),char(1),char(6),char(0),char(118),char(241),char(0), -char(0),char(8),char(179),char(1),char(15),char(17),char(38),char(0),char(43),char(53), -char(0),char(1),char(0),char(115),char(255),char(236),char(3),char(170),char(4),char(92), -char(0),char(25),char(0),char(68),char(64),char(38),char(15),char(18),char(18),char(3), -char(9),char(24),char(17),char(3),char(4),char(26),char(27),char(15),char(18),char(70), -char(89),char(15),char(15),char(31),char(15),char(2),char(11),char(3),char(15),char(15), -char(0),char(6),char(6),char(12),char(70),char(89),char(6),char(16),char(0),char(21), -char(70),char(89),char(0),char(22),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(95),char(94),char(93), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(5),char(34),char(0),char(17),char(16),char(0),char(51),char(50), -char(22),char(23),char(7),char(38),char(35),char(34),char(6),char(7),char(33),char(21), -char(33),char(22),char(22),char(51),char(50),char(55),char(21),char(6),char(2),char(121), -char(248),char(254),char(242),char(1),char(19),char(251),char(82),char(158),char(57),char(49), -char(143),char(109),char(164),char(170),char(16),char(2),char(41),char(253),char(213),char(9), -char(170),char(167),char(140),char(151),char(116),char(20),char(1),char(35),char(1),char(16), -char(1),char(19),char(1),char(42),char(32),char(25),char(141),char(51),char(163),char(169), -char(141),char(190),char(181),char(59),char(147),char(57),char(255),char(255),char(0),char(106), -char(255),char(236),char(3),char(115),char(4),char(92),char(2),char(6),char(0),char(86), -char(0),char(0),char(255),char(255),char(0),char(162),char(0),char(0),char(1),char(102), -char(5),char(223),char(2),char(6),char(0),char(76),char(0),char(0),char(255),char(255), -char(255),char(236),char(0),char(0),char(2),char(31),char(5),char(211),char(2),char(38), -char(0),char(243),char(0),char(0),char(1),char(7),char(0),char(106),char(254),char(183), -char(0),char(0),char(0),char(10),char(180),char(2),char(1),char(25),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(255),char(145),char(254),char(20), -char(1),char(102),char(5),char(223),char(2),char(6),char(0),char(77),char(0),char(0), -char(0),char(2),char(0),char(16),char(255),char(242),char(6),char(66),char(4),char(72), -char(0),char(21),char(0),char(29),char(0),char(76),char(64),char(41),char(9),char(20), -char(0),char(27),char(27),char(7),char(22),char(4),char(4),char(7),char(20),char(14), -char(4),char(30),char(31),char(0),char(26),char(70),char(89),char(0),char(0),char(12), -char(20),char(20),char(9),char(70),char(89),char(20),char(15),char(12),char(17),char(71), -char(89),char(12),char(21),char(7),char(27),char(70),char(89),char(7),char(21),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(0),char(24),char(63),char(43), -char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(51),char(50),char(22),char(21),char(16),char(33),char(33), -char(17),char(33),char(2),char(2),char(35),char(34),char(39),char(53),char(22),char(51), -char(50),char(18),char(19),char(33),char(1),char(52),char(38),char(35),char(35),char(17), -char(51),char(32),char(3),char(176),char(244),char(211),char(203),char(254),char(75),char(254), -char(101),char(254),char(254),char(40),char(181),char(171),char(56),char(32),char(22),char(28), -char(115),char(136),char(35),char(2),char(80),char(1),char(236),char(125),char(158),char(231), -char(237),char(1),char(21),char(2),char(131),char(155),char(154),char(254),char(178),char(3), -char(186),char(253),char(250),char(254),char(62),char(12),char(123),char(6),char(1),char(230), -char(1),char(239),char(252),char(252),char(91),char(85),char(254),char(151),char(0),char(2), -char(0),char(176),char(0),char(0),char(6),char(164),char(4),char(70),char(0),char(17), -char(0),char(25),char(0),char(74),char(64),char(38),char(15),char(11),char(11),char(12), -char(1),char(19),char(19),char(16),char(8),char(22),char(5),char(5),char(8),char(12), -char(3),char(26),char(27),char(18),char(10),char(15),char(10),char(70),char(89),char(1), -char(15),char(15),char(8),char(17),char(13),char(15),char(12),char(21),char(8),char(19), -char(70),char(89),char(8),char(21),char(0),char(63),char(43),char(0),char(24),char(63), -char(63),char(51),char(18),char(57),char(47),char(51),char(43),char(17),char(0),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17), -char(33),char(50),char(22),char(21),char(16),char(33),char(33),char(17),char(33),char(17), -char(35),char(17),char(51),char(17),char(33),char(17),char(19),char(17),char(51),char(32), -char(53),char(52),char(38),char(35),char(4),char(0),char(1),char(0),char(217),char(203), -char(254),char(78),char(254),char(96),char(254),char(10),char(172),char(172),char(1),char(250), -char(166),char(240),char(1),char(20),char(128),char(153),char(4),char(70),char(254),char(59), -char(153),char(154),char(254),char(178),char(1),char(238),char(254),char(18),char(4),char(70), -char(254),char(55),char(1),char(201),char(253),char(174),char(254),char(151),char(185),char(92), -char(84),char(0),char(255),char(255),char(0),char(20),char(0),char(0),char(4),char(68), -char(6),char(20),char(2),char(6),char(0),char(233),char(0),char(0),char(255),char(255), -char(0),char(176),char(0),char(0),char(4),char(12),char(6),char(33),char(2),char(38), -char(1),char(212),char(0),char(0),char(1),char(6),char(0),char(118),char(51),char(0), -char(0),char(8),char(179),char(1),char(20),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(2),char(254),char(20),char(4),char(6),char(6),char(12), -char(2),char(38),char(0),char(92),char(0),char(0),char(1),char(6),char(2),char(54), -char(183),char(0),char(0),char(8),char(179),char(1),char(22),char(17),char(38),char(0), -char(43),char(53),char(0),char(1),char(0),char(176),char(254),char(135),char(4),char(70), -char(4),char(70),char(0),char(11),char(0),char(50),char(64),char(25),char(4),char(1), -char(10),char(11),char(5),char(8),char(8),char(11),char(1),char(3),char(12),char(13), -char(11),char(34),char(6),char(2),char(15),char(9),char(1),char(1),char(4),char(70), -char(89),char(1),char(21),char(0),char(63),char(43),char(17),char(0),char(51),char(24), -char(63),char(51),char(63),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(33),char(17),char(51), -char(17),char(33),char(17),char(51),char(17),char(33),char(17),char(35),char(2),char(47), -char(254),char(129),char(166),char(2),char(74),char(166),char(254),char(143),char(166),char(4), -char(70),char(252),char(73),char(3),char(183),char(251),char(186),char(254),char(135),char(0), -char(0),char(1),char(0),char(201),char(0),char(0),char(4),char(8),char(6),char(227), -char(0),char(7),char(0),char(35),char(64),char(17),char(0),char(3),char(5),char(6), -char(3),char(6),char(9),char(8),char(7),char(4),char(73),char(89),char(1),char(7), -char(3),char(6),char(18),char(0),char(63),char(63),char(198),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(17),char(51),char(17),char(33),char(17),char(35),char(17),char(3),char(102),char(162), -char(253),char(107),char(170),char(5),char(182),char(1),char(45),char(254),char(58),char(250), -char(227),char(5),char(182),char(0),char(0),char(1),char(0),char(176),char(0),char(0), -char(3),char(68),char(5),char(137),char(0),char(7),char(0),char(39),char(64),char(18), -char(5),char(0),char(2),char(3),char(0),char(3),char(9),char(8),char(6),char(4), -char(4),char(1),char(71),char(89),char(4),char(15),char(3),char(21),char(0),char(63), -char(63),char(43),char(0),char(24),char(16),char(198),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(17), -char(35),char(17),char(33),char(17),char(51),char(3),char(68),char(254),char(18),char(166), -char(1),char(238),char(166),char(3),char(199),char(252),char(57),char(4),char(72),char(1), -char(65),char(0),char(255),char(255),char(0),char(27),char(0),char(0),char(7),char(76), -char(7),char(115),char(2),char(38),char(0),char(58),char(0),char(0),char(1),char(7), -char(0),char(67),char(1),char(23),char(1),char(82),char(0),char(8),char(179),char(1), -char(27),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(23), -char(0),char(0),char(6),char(35),char(6),char(33),char(2),char(38),char(0),char(90), -char(0),char(0),char(1),char(6),char(0),char(67),char(115),char(0),char(0),char(8), -char(179),char(1),char(30),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(27),char(0),char(0),char(7),char(76),char(7),char(115),char(2),char(38), -char(0),char(58),char(0),char(0),char(1),char(7),char(0),char(118),char(1),char(176), -char(1),char(82),char(0),char(8),char(179),char(1),char(35),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(23),char(0),char(0),char(6),char(35), -char(6),char(33),char(2),char(38),char(0),char(90),char(0),char(0),char(1),char(7), -char(0),char(118),char(1),char(27),char(0),char(0),char(0),char(8),char(179),char(1), -char(38),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(27), -char(0),char(0),char(7),char(76),char(7),char(37),char(2),char(38),char(0),char(58), -char(0),char(0),char(1),char(7),char(0),char(106),char(1),char(100),char(1),char(82), -char(0),char(10),char(180),char(2),char(1),char(47),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(23),char(0),char(0),char(6),char(35), -char(5),char(211),char(2),char(38),char(0),char(90),char(0),char(0),char(1),char(7), -char(0),char(106),char(0),char(207),char(0),char(0),char(0),char(10),char(180),char(2), -char(1),char(50),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(4),char(123),char(7),char(115),char(2),char(38), -char(0),char(60),char(0),char(0),char(1),char(7),char(0),char(67),char(255),char(148), -char(1),char(82),char(0),char(8),char(179),char(1),char(10),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(2),char(254),char(20),char(4),char(6), -char(6),char(33),char(2),char(38),char(0),char(92),char(0),char(0),char(1),char(7), -char(0),char(67),char(255),char(97),char(0),char(0),char(0),char(8),char(179),char(1), -char(23),char(17),char(38),char(0),char(43),char(53),char(0),char(1),char(0),char(82), -char(1),char(217),char(3),char(174),char(2),char(113),char(0),char(3),char(0),char(17), -char(181),char(0),char(2),char(4),char(5),char(0),char(1),char(0),char(47),char(51), -char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(19),char(53),char(33), -char(21),char(82),char(3),char(92),char(1),char(217),char(152),char(152),char(0),char(1), -char(0),char(82),char(1),char(217),char(7),char(174),char(2),char(113),char(0),char(3), -char(0),char(17),char(181),char(0),char(2),char(4),char(5),char(0),char(1),char(0), -char(47),char(51),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(19), -char(53),char(33),char(21),char(82),char(7),char(92),char(1),char(217),char(152),char(152), -char(255),char(255),char(0),char(82),char(1),char(217),char(7),char(174),char(2),char(113), -char(2),char(6),char(2),char(3),char(0),char(0),char(0),char(2),char(255),char(252), -char(254),char(49),char(3),char(78),char(255),char(211),char(0),char(3),char(0),char(7), -char(0),char(28),char(64),char(11),char(4),char(0),char(9),char(5),char(1),char(1), -char(8),char(5),char(6),char(2),char(1),char(0),char(47),char(51),char(47),char(51), -char(17),char(1),char(51),char(17),char(51),char(17),char(51),char(50),char(49),char(48), -char(1),char(33),char(53),char(33),char(53),char(33),char(53),char(33),char(3),char(78), -char(252),char(174),char(3),char(82),char(252),char(174),char(3),char(82),char(254),char(49), -char(139),char(140),char(139),char(0),char(0),char(1),char(0),char(25),char(3),char(193), -char(1),char(68),char(5),char(182),char(0),char(7),char(0),char(18),char(182),char(1), -char(5),char(8),char(9),char(0),char(4),char(3),char(0),char(63),char(205),char(17), -char(18),char(1),char(57),char(57),char(49),char(48),char(19),char(39),char(54),char(18), -char(55),char(51),char(6),char(7),char(37),char(12),char(22),char(98),char(56),char(123), -char(66),char(37),char(3),char(193),char(22),char(90),char(1),char(12),char(121),char(254), -char(247),char(0),char(0),char(1),char(0),char(25),char(3),char(193),char(1),char(68), -char(5),char(182),char(0),char(7),char(0),char(18),char(182),char(5),char(1),char(8), -char(9),char(5),char(7),char(3),char(0),char(63),char(198),char(17),char(18),char(1), -char(57),char(57),char(49),char(48),char(1),char(23),char(6),char(2),char(7),char(35), -char(18),char(55),char(1),char(53),char(15),char(26),char(98),char(53),char(122),char(70), -char(32),char(5),char(182),char(22),char(100),char(254),char(247),char(114),char(1),char(29), -char(216),char(0),char(255),char(255),char(0),char(63),char(254),char(248),char(1),char(109), -char(0),char(238),char(2),char(6),char(0),char(15),char(0),char(0),char(0),char(1), -char(0),char(25),char(3),char(193),char(1),char(70),char(5),char(182),char(0),char(7), -char(0),char(18),char(182),char(2),char(6),char(9),char(8),char(3),char(7),char(3), -char(0),char(63),char(205),char(17),char(18),char(1),char(57),char(57),char(49),char(48), -char(19),char(22),char(23),char(35),char(38),char(2),char(39),char(55),char(223),char(37), -char(66),char(123),char(45),char(109),char(24),char(14),char(5),char(182),char(251),char(250), -char(94),char(1),char(28),char(101),char(22),char(0),char(0),char(2),char(0),char(25), -char(3),char(193),char(2),char(180),char(5),char(182),char(0),char(7),char(0),char(15), -char(0),char(26),char(64),char(12),char(4),char(1),char(13),char(9),char(4),char(16), -char(17),char(0),char(8),char(3),char(12),char(3),char(0),char(63),char(51),char(205), -char(50),char(17),char(18),char(1),char(23),char(57),char(49),char(48),char(1),char(39), -char(54),char(19),char(51),char(6),char(2),char(7),char(33),char(39),char(54),char(18), -char(55),char(51),char(6),char(7),char(1),char(150),char(15),char(56),char(122),char(123), -char(30),char(59),char(13),char(253),char(215),char(12),char(22),char(98),char(56),char(123), -char(66),char(37),char(3),char(193),char(22),char(215),char(1),char(8),char(115),char(254), -char(223),char(97),char(22),char(90),char(1),char(12),char(121),char(254),char(247),char(0), -char(0),char(2),char(0),char(25),char(3),char(193),char(2),char(180),char(5),char(182), -char(0),char(7),char(0),char(16),char(0),char(26),char(64),char(12),char(9),char(13), -char(1),char(5),char(4),char(17),char(18),char(13),char(5),char(16),char(7),char(3), -char(0),char(63),char(51),char(198),char(50),char(17),char(18),char(1),char(23),char(57), -char(49),char(48),char(1),char(23),char(6),char(2),char(7),char(35),char(18),char(55), -char(33),char(23),char(6),char(2),char(7),char(35),char(54),char(18),char(55),char(1), -char(53),char(15),char(26),char(98),char(53),char(122),char(70),char(32),char(2),char(39), -char(14),char(24),char(96),char(56),char(125),char(26),char(66),char(13),char(5),char(182), -char(22),char(100),char(254),char(247),char(114),char(1),char(29),char(216),char(22),char(91), -char(254),char(246),char(122),char(100),char(1),char(52),char(93),char(0),char(255),char(255), -char(0),char(25),char(254),char(249),char(2),char(180),char(0),char(238),char(1),char(7), -char(2),char(11),char(0),char(0),char(251),char(56),char(0),char(32),char(183),char(1), -char(0),char(7),char(64),char(13),char(13),char(72),char(7),char(184),char(255),char(192), -char(179),char(12),char(12),char(72),char(7),char(184),char(255),char(192),char(179),char(9), -char(9),char(72),char(7),char(0),char(17),char(43),char(43),char(43),char(53),char(53), -char(0),char(1),char(0),char(123),char(0),char(0),char(3),char(137),char(6),char(20), -char(0),char(11),char(0),char(67),char(64),char(33),char(9),char(2),char(2),char(8), -char(3),char(10),char(1),char(1),char(7),char(4),char(0),char(4),char(3),char(5), -char(4),char(12),char(13),char(0),char(5),char(5),char(11),char(6),char(6),char(7), -char(8),char(0),char(1),char(4),char(4),char(10),char(7),char(3),char(18),char(0), -char(63),char(46),char(51),char(51),char(17),char(51),char(63),char(18),char(57),char(47), -char(51),char(51),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(51),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(49), -char(48),char(1),char(37),char(19),char(35),char(19),char(5),char(53),char(5),char(3), -char(51),char(3),char(37),char(3),char(137),char(254),char(160),char(49),char(196),char(49), -char(254),char(180),char(1),char(76),char(49),char(196),char(49),char(1),char(96),char(3), -char(231),char(31),char(251),char(250),char(4),char(6),char(31),char(170),char(30),char(1), -char(161),char(254),char(95),char(30),char(0),char(1),char(0),char(123),char(0),char(0), -char(3),char(154),char(6),char(20),char(0),char(21),char(0),char(117),char(64),char(58), -char(12),char(7),char(21),char(16),char(4),char(4),char(15),char(10),char(5),char(20), -char(17),char(0),char(3),char(3),char(14),char(11),char(9),char(6),char(19),char(1), -char(1),char(6),char(5),char(7),char(4),char(22),char(23),char(1),char(8),char(8), -char(2),char(7),char(3),char(6),char(6),char(0),char(9),char(20),char(11),char(11), -char(17),char(14),char(19),char(12),char(12),char(18),char(9),char(14),char(13),char(7), -char(13),char(7),char(13),char(5),char(15),char(0),char(5),char(18),char(0),char(63), -char(63),char(18),char(57),char(57),char(47),char(47),char(18),char(57),char(57),char(50), -char(50),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(51),char(51), -char(17),char(51),char(51),char(51),char(17),char(51),char(51),char(51),char(17),char(51), -char(51),char(17),char(51),char(49),char(48),char(1),char(37),char(21),char(37),char(19), -char(35),char(19),char(5),char(53),char(5),char(3),char(19),char(5),char(53),char(5), -char(3),char(51),char(3),char(37),char(21),char(37),char(19),char(2),char(57),char(1), -char(97),char(254),char(159),char(49),char(198),char(49),char(254),char(166),char(1),char(90), -char(43),char(43),char(254),char(166),char(1),char(90),char(49),char(198),char(49),char(1), -char(97),char(254),char(159),char(43),char(1),char(231),char(31),char(168),char(29),char(254), -char(133),char(1),char(123),char(29),char(168),char(31),char(1),char(43),char(1),char(27), -char(31),char(168),char(30),char(1),char(124),char(254),char(132),char(30),char(168),char(31), -char(254),char(229),char(0),char(1),char(0),char(164),char(1),char(244),char(2),char(94), -char(3),char(227),char(0),char(11),char(0),char(19),char(182),char(6),char(0),char(0), -char(12),char(13),char(9),char(3),char(0),char(47),char(205),char(17),char(18),char(1), -char(57),char(17),char(51),char(49),char(48),char(19),char(52),char(54),char(51),char(50), -char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(164),char(113),char(108), -char(105),char(116),char(115),char(106),char(107),char(114),char(2),char(236),char(121),char(126), -char(124),char(123),char(119),char(129),char(131),char(0),char(255),char(255),char(0),char(152), -char(255),char(227),char(5),char(174),char(0),char(242),char(0),char(38),char(0),char(17), -char(0),char(0),char(0),char(39),char(0),char(17),char(2),char(18),char(0),char(0), -char(0),char(7),char(0),char(17),char(4),char(37),char(0),char(0),char(0),char(7), -char(0),char(100),char(255),char(236),char(9),char(59),char(5),char(203),char(0),char(9), -char(0),char(20),char(0),char(24),char(0),char(36),char(0),char(47),char(0),char(59), -char(0),char(70),char(0),char(91),char(64),char(48),char(0),char(16),char(5),char(10), -char(48),char(66),char(54),char(60),char(25),char(43),char(31),char(37),char(37),char(43), -char(60),char(21),char(66),char(10),char(23),char(16),char(8),char(71),char(72),char(28), -char(51),char(51),char(40),char(63),char(25),char(3),char(13),char(34),char(57),char(57), -char(45),char(68),char(13),char(68),char(13),char(68),char(23),char(24),char(6),char(23), -char(24),char(7),char(18),char(7),char(0),char(63),char(51),char(63),char(63),char(18), -char(57),char(57),char(47),char(47),char(17),char(51),char(51),char(17),char(51),char(17), -char(51),char(63),char(51),char(51),char(17),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(19),char(20),char(22),char(51),char(50), -char(17),char(16),char(35),char(34),char(6),char(5),char(20),char(6),char(35),char(34), -char(38),char(53),char(16),char(33),char(50),char(22),char(37),char(1),char(35),char(1), -char(1),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(34),char(6),char(5),char(20),char(6),char(35),char(34),char(38),char(53),char(16), -char(33),char(50),char(22),char(5),char(20),char(22),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(34),char(6),char(5),char(20),char(6),char(35),char(34), -char(38),char(53),char(16),char(33),char(50),char(22),char(236),char(83),char(93),char(180), -char(180),char(93),char(83),char(1),char(237),char(161),char(156),char(149),char(163),char(1), -char(56),char(152),char(165),char(2),char(105),char(252),char(213),char(148),char(3),char(43), -char(2),char(160),char(83),char(93),char(91),char(89),char(89),char(91),char(93),char(83), -char(1),char(237),char(162),char(155),char(148),char(163),char(1),char(55),char(150),char(167), -char(251),char(56),char(81),char(93),char(91),char(89),char(89),char(91),char(93),char(81), -char(1),char(235),char(162),char(155),char(149),char(163),char(1),char(56),char(150),char(167), -char(4),char(2),char(170),char(170),char(1),char(84),char(1),char(82),char(168),char(170), -char(230),char(231),char(238),char(223),char(1),char(201),char(240),char(219),char(250),char(74), -char(5),char(182),char(252),char(2),char(171),char(169),char(167),char(173),char(171),char(165), -char(165),char(171),char(230),char(230),char(239),char(221),char(1),char(201),char(236),char(221), -char(171),char(169),char(167),char(173),char(171),char(165),char(165),char(171),char(230),char(230), -char(238),char(222),char(1),char(201),char(236),char(0),char(255),char(255),char(0),char(133), -char(3),char(166),char(1),char(63),char(5),char(182),char(2),char(6),char(0),char(10), -char(0),char(0),char(255),char(255),char(0),char(133),char(3),char(166),char(2),char(176), -char(5),char(182),char(0),char(6),char(0),char(5),char(0),char(0),char(0),char(1), -char(0),char(82),char(0),char(117),char(2),char(31),char(3),char(190),char(0),char(6), -char(0),char(26),char(64),char(10),char(4),char(2),char(3),char(6),char(2),char(6), -char(8),char(7),char(5),char(1),char(0),char(47),char(47),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(1), -char(23),char(1),char(1),char(7),char(1),char(82),char(1),char(86),char(119),char(254), -char(223),char(1),char(33),char(119),char(254),char(170),char(2),char(39),char(1),char(151), -char(69),char(254),char(162),char(254),char(161),char(71),char(1),char(151),char(0),char(1), -char(0),char(80),char(0),char(117),char(2),char(29),char(3),char(190),char(0),char(6), -char(0),char(26),char(64),char(10),char(3),char(0),char(4),char(2),char(0),char(2), -char(8),char(7),char(5),char(1),char(0),char(47),char(47),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(1), -char(39),char(1),char(1),char(55),char(1),char(2),char(29),char(254),char(168),char(117), -char(1),char(31),char(254),char(225),char(117),char(1),char(88),char(2),char(12),char(254), -char(105),char(71),char(1),char(95),char(1),char(94),char(69),char(254),char(105),char(0), -char(255),char(255),char(0),char(152),char(255),char(227),char(3),char(74),char(5),char(182), -char(0),char(38),char(0),char(4),char(0),char(0),char(0),char(7),char(0),char(4), -char(1),char(193),char(0),char(0),char(0),char(1),char(254),char(121),char(0),char(0), -char(2),char(143),char(5),char(182),char(0),char(3),char(0),char(19),char(183),char(0), -char(5),char(2),char(4),char(3),char(3),char(2),char(18),char(0),char(63),char(63), -char(17),char(1),char(51),char(17),char(51),char(49),char(48),char(1),char(1),char(35), -char(1),char(2),char(143),char(252),char(121),char(143),char(3),char(135),char(5),char(182), -char(250),char(74),char(5),char(182),char(0),char(1),char(0),char(109),char(3),char(33), -char(2),char(195),char(5),char(199),char(0),char(18),char(0),char(38),char(64),char(17), -char(0),char(18),char(12),char(8),char(8),char(9),char(18),char(9),char(20),char(19), -char(4),char(15),char(31),char(0),char(9),char(10),char(31),char(0),char(63),char(205), -char(50),char(63),char(51),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(52),char(38), -char(35),char(34),char(6),char(21),char(17),char(35),char(17),char(51),char(23),char(51), -char(54),char(51),char(32),char(21),char(17),char(2),char(76),char(78),char(80),char(114), -char(91),char(116),char(96),char(14),char(10),char(75),char(145),char(1),char(2),char(3), -char(33),char(1),char(164),char(84),char(71),char(105),char(122),char(254),char(164),char(2), -char(153),char(88),char(101),char(250),char(254),char(84),char(0),char(1),char(0),char(98), -char(0),char(0),char(4),char(35),char(5),char(182),char(0),char(17),char(0),char(75), -char(64),char(40),char(14),char(0),char(4),char(4),char(9),char(5),char(11),char(16), -char(2),char(5),char(7),char(5),char(18),char(19),char(3),char(7),char(8),char(7), -char(78),char(89),char(0),char(8),char(14),char(17),char(76),char(89),char(8),char(14), -char(8),char(14),char(5),char(10),char(10),char(13),char(76),char(89),char(10),char(6), -char(5),char(24),char(0),char(63),char(63),char(43),char(17),char(18),char(0),char(57), -char(57),char(24),char(47),char(47),char(43),char(17),char(0),char(51),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51), -char(17),char(51),char(51),char(49),char(48),char(1),char(33),char(21),char(33),char(17), -char(35),char(17),char(35),char(53),char(51),char(17),char(33),char(21),char(33),char(17), -char(33),char(21),char(33),char(1),char(184),char(1),char(52),char(254),char(204),char(166), -char(176),char(176),char(3),char(17),char(253),char(149),char(2),char(68),char(253),char(188), -char(1),char(139),char(129),char(254),char(246),char(1),char(10),char(129),char(4),char(43), -char(151),char(253),char(233),char(151),char(0),char(1),char(0),char(68),char(0),char(0), -char(4),char(72),char(5),char(201),char(0),char(37),char(0),char(112),char(64),char(64), -char(13),char(9),char(17),char(17),char(34),char(30),char(26),char(11),char(15),char(21), -char(2),char(15),char(26),char(28),char(32),char(23),char(7),char(38),char(39),char(16), -char(28),char(29),char(28),char(78),char(89),char(13),char(29),char(12),char(32),char(33), -char(32),char(78),char(89),char(9),char(33),char(15),char(33),char(31),char(33),char(63), -char(33),char(79),char(33),char(4),char(9),char(3),char(29),char(33),char(29),char(33), -char(23),char(0),char(23),char(20),char(76),char(89),char(23),char(24),char(0),char(5), -char(75),char(89),char(0),char(7),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(57),char(24),char(47),char(47),char(95), -char(94),char(93),char(17),char(51),char(43),char(17),char(0),char(51),char(17),char(51), -char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(51),char(51),char(17),char(51),char(51),char(49),char(48), -char(1),char(50),char(23),char(7),char(38),char(35),char(34),char(6),char(21),char(21), -char(33),char(21),char(33),char(21),char(33),char(21),char(33),char(21),char(20),char(6), -char(7),char(33),char(21),char(33),char(53),char(54),char(53),char(53),char(35),char(53), -char(51),char(53),char(35),char(53),char(51),char(53),char(52),char(54),char(2),char(176), -char(201),char(158),char(60),char(152),char(147),char(122),char(126),char(1),char(164),char(254), -char(92),char(1),char(164),char(254),char(92),char(65),char(74),char(3),char(27),char(251), -char(252),char(206),char(200),char(200),char(200),char(200),char(224),char(5),char(201),char(80), -char(131),char(71),char(135),char(129),char(186),char(129),char(166),char(129),char(33),char(100), -char(136),char(44),char(154),char(141),char(48),char(243),char(35),char(129),char(166),char(129), -char(207),char(178),char(205),char(0),char(0),char(3),char(0),char(154),char(255),char(236), -char(5),char(209),char(5),char(182),char(0),char(22),char(0),char(33),char(0),char(42), -char(0),char(96),char(64),char(55),char(34),char(28),char(28),char(29),char(38),char(23), -char(16),char(20),char(20),char(13),char(9),char(2),char(18),char(9),char(23),char(11), -char(29),char(6),char(43),char(44),char(27),char(34),char(75),char(89),char(16),char(19), -char(78),char(89),char(3),char(27),char(11),char(16),char(14),char(14),char(16),char(11), -char(27),char(3),char(5),char(29),char(30),char(30),char(42),char(75),char(89),char(30), -char(6),char(29),char(24),char(6),char(0),char(77),char(89),char(6),char(25),char(0), -char(63),char(43),char(0),char(24),char(63),char(63),char(43),char(17),char(18),char(0), -char(23),char(57),char(24),char(47),char(47),char(47),char(47),char(47),char(43),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(50), -char(54),char(55),char(21),char(6),char(35),char(34),char(38),char(53),char(17),char(35), -char(53),char(55),char(55),char(51),char(21),char(51),char(21),char(35),char(17),char(20), -char(22),char(1),char(20),char(4),char(33),char(35),char(17),char(35),char(17),char(33), -char(32),char(22),char(1),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(35),char(5),char(78),char(34),char(86),char(11),char(60),char(110),char(109),char(129), -char(157),char(157),char(62),char(98),char(221),char(221),char(52),char(254),char(145),char(254), -char(235),char(254),char(246),char(64),char(165),char(1),char(6),char(1),char(0),char(254), -char(253),char(161),char(52),char(200),char(185),char(172),char(183),char(82),char(117),char(14), -char(4),char(125),char(30),char(136),char(138),char(1),char(207),char(80),char(69),char(191), -char(211),char(129),char(254),char(71),char(77),char(82),char(3),char(151),char(227),char(234), -char(253),char(193),char(5),char(182),char(211),char(253),char(238),char(145),char(162),char(145), -char(142),char(0),char(0),char(1),char(0),char(63),char(255),char(236),char(4),char(137), -char(5),char(203),char(0),char(38),char(0),char(113),char(64),char(63),char(29),char(23), -char(31),char(22),char(22),char(26),char(11),char(2),char(7),char(7),char(26),char(36), -char(17),char(4),char(10),char(26),char(23),char(6),char(39),char(40),char(11),char(23), -char(24),char(23),char(78),char(89),char(8),char(24),char(5),char(29),char(30),char(29), -char(78),char(89),char(2),char(30),char(15),char(30),char(31),char(30),char(47),char(30), -char(3),char(9),char(3),char(24),char(30),char(24),char(30),char(19),char(34),char(34), -char(0),char(76),char(89),char(34),char(7),char(19),char(14),char(76),char(89),char(19), -char(25),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(57),char(24),char(47),char(47),char(95),char(94),char(93),char(17), -char(51),char(43),char(17),char(0),char(51),char(17),char(51),char(43),char(17),char(0), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(32),char(3),char(33),char(21),char(33),char(7),char(21),char(23),char(33),char(21), -char(33),char(22),char(22),char(51),char(50),char(55),char(21),char(6),char(35),char(34), -char(0),char(3),char(35),char(53),char(51),char(39),char(53),char(55),char(35),char(53), -char(51),char(18),char(0),char(51),char(50),char(23),char(7),char(38),char(3),char(27), -char(254),char(193),char(79),char(1),char(254),char(253),char(244),char(2),char(2),char(1), -char(207),char(254),char(65),char(37),char(203),char(170),char(156),char(153),char(146),char(171), -char(237),char(254),char(223),char(46),char(166),char(152),char(2),char(2),char(152),char(164), -char(39),char(1),char(36),char(237),char(201),char(165),char(71),char(166),char(5),char(53), -char(254),char(109),char(129),char(57),char(64),char(45),char(129),char(180),char(197),char(66), -char(150),char(65),char(1),char(13),char(1),char(1),char(129),char(42),char(44),char(80), -char(129),char(1),char(5),char(1),char(36),char(97),char(139),char(86),char(0),char(4), -char(0),char(141),char(255),char(248),char(6),char(10),char(5),char(193),char(0),char(3), -char(0),char(15),char(0),char(23),char(0),char(43),char(0),char(69),char(64),char(36), -char(37),char(27),char(32),char(42),char(16),char(10),char(20),char(4),char(4),char(0), -char(10),char(42),char(2),char(27),char(6),char(44),char(45),char(35),char(30),char(6), -char(18),char(7),char(24),char(22),char(13),char(39),char(24),char(13),char(24),char(13), -char(24),char(2),char(3),char(6),char(2),char(24),char(0),char(63),char(63),char(18), -char(57),char(57),char(47),char(47),char(17),char(51),char(17),char(51),char(63),char(51), -char(63),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(1),char(35), -char(1),char(1),char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54), -char(51),char(50),char(22),char(5),char(20),char(51),char(50),char(53),char(52),char(35), -char(34),char(37),char(34),char(38),char(53),char(52),char(54),char(51),char(50),char(23), -char(7),char(38),char(35),char(34),char(21),char(20),char(51),char(50),char(55),char(21), -char(6),char(5),char(31),char(252),char(213),char(148),char(3),char(43),char(1),char(127), -char(169),char(148),char(139),char(170),char(167),char(148),char(141),char(170),char(254),char(21), -char(178),char(176),char(176),char(178),char(253),char(202),char(166),char(182),char(188),char(171), -char(104),char(88),char(33),char(81),char(80),char(224),char(220),char(98),char(90),char(78), -char(5),char(182),char(250),char(74),char(5),char(182),char(251),char(152),char(159),char(183), -char(185),char(157),char(158),char(184),char(186),char(156),char(238),char(238),char(235),char(219), -char(177),char(161),char(168),char(179),char(35),char(103),char(31),char(238),char(235),char(33), -char(101),char(37),char(0),char(2),char(0),char(119),char(255),char(236),char(3),char(156), -char(5),char(203),char(0),char(28),char(0),char(36),char(0),char(61),char(64),char(31), -char(35),char(26),char(26),char(15),char(9),char(29),char(22),char(3),char(22),char(9), -char(12),char(4),char(37),char(38),char(35),char(15),char(13),char(25),char(10),char(5), -char(12),char(19),char(2),char(12),char(2),char(12),char(6),char(31),char(19),char(0), -char(6),char(0),char(47),char(51),char(47),char(51),char(18),char(57),char(57),char(47), -char(47),char(17),char(18),char(23),char(57),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(37), -char(50),char(55),char(51),char(6),char(6),char(35),char(34),char(38),char(53),char(53), -char(6),char(7),char(53),char(54),char(55),char(17),char(52),char(54),char(51),char(50), -char(22),char(21),char(20),char(2),char(7),char(17),char(20),char(22),char(19),char(52), -char(35),char(34),char(6),char(21),char(17),char(36),char(2),char(125),char(174),char(18), -char(95),char(8),char(153),char(142),char(150),char(160),char(96),char(96),char(78),char(114), -char(150),char(135),char(117),char(135),char(206),char(175),char(82),char(174),char(127),char(67), -char(62),char(1),char(0),char(111),char(213),char(166),char(178),char(181),char(169),char(243), -char(35),char(22),char(113),char(21),char(38),char(1),char(242),char(138),char(159),char(161), -char(138),char(185),char(254),char(208),char(74),char(254),char(229),char(104),char(123),char(4), -char(43),char(194),char(86),char(108),char(254),char(75),char(137),char(0),char(0),char(4), -char(0),char(201),char(0),char(0),char(7),char(195),char(5),char(182),char(0),char(15), -char(0),char(27),char(0),char(39),char(0),char(43),char(0),char(95),char(64),char(49), -char(9),char(6),char(6),char(7),char(1),char(13),char(13),char(0),char(28),char(22), -char(34),char(16),char(16),char(43),char(40),char(22),char(0),char(7),char(6),char(44), -char(45),char(31),char(19),char(37),char(25),char(11),char(40),char(19),char(3),char(25), -char(8),char(19),char(25),char(19),char(25),char(40),char(8),char(40),char(41),char(74), -char(89),char(40),char(18),char(14),char(8),char(3),char(1),char(7),char(18),char(0), -char(63),char(51),char(63),char(51),char(63),char(43),char(17),char(18),char(0),char(57), -char(57),char(24),char(47),char(47),char(17),char(18),char(57),char(17),char(18),char(57), -char(17),char(51),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(33),char(35),char(1),char(35),char(18),char(21),char(17), -char(35),char(17),char(51),char(1),char(51),char(38),char(53),char(17),char(51),char(1), -char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51),char(50), -char(22),char(5),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38), -char(35),char(34),char(6),char(3),char(53),char(33),char(21),char(4),char(199),char(187), -char(253),char(76),char(8),char(16),char(151),char(194),char(2),char(170),char(8),char(14), -char(152),char(2),char(252),char(161),char(147),char(139),char(162),char(161),char(147),char(139), -char(162),char(254),char(34),char(81),char(93),char(91),char(79),char(79),char(91),char(92), -char(82),char(86),char(2),char(0),char(4),char(203),char(254),char(224),char(108),char(252), -char(193),char(5),char(182),char(251),char(58),char(245),char(138),char(3),char(71),char(252), -char(183),char(163),char(184),char(187),char(160),char(163),char(181),char(187),char(157),char(114), -char(118),char(117),char(115),char(115),char(112),char(112),char(253),char(32),char(135),char(135), -char(0),char(2),char(0),char(37),char(2),char(229),char(5),char(133),char(5),char(182), -char(0),char(7),char(0),char(24),char(0),char(79),char(64),char(39),char(0),char(1), -char(15),char(12),char(12),char(13),char(17),char(20),char(20),char(19),char(19),char(13), -char(6),char(1),char(3),char(5),char(25),char(26),char(23),char(22),char(9),char(10), -char(10),char(17),char(14),char(14),char(4),char(7),char(3),char(3),char(4),char(16), -char(8),char(8),char(20),char(13),char(1),char(4),char(3),char(0),char(63),char(196), -char(50),char(50),char(57),char(47),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(51),char(17),char(51),char(51),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(35),char(17),char(35),char(53), -char(33),char(21),char(35),char(1),char(3),char(35),char(23),char(17),char(35),char(17), -char(51),char(19),char(19),char(51),char(17),char(35),char(17),char(55),char(35),char(3), -char(1),char(113),char(123),char(209),char(2),char(31),char(211),char(2),char(88),char(201), -char(8),char(6),char(119),char(187),char(196),char(203),char(180),char(127),char(6),char(8), -char(211),char(2),char(229),char(2),char(103),char(106),char(106),char(253),char(153),char(2), -char(47),char(129),char(254),char(82),char(2),char(209),char(253),char(209),char(2),char(47), -char(253),char(47),char(1),char(164),char(137),char(253),char(211),char(0),char(255),char(255), -char(0),char(80),char(0),char(0),char(5),char(244),char(5),char(205),char(2),char(6), -char(1),char(118),char(0),char(0),char(0),char(2),char(0),char(102),char(255),char(221), -char(4),char(139),char(4),char(72),char(0),char(23),char(0),char(31),char(0),char(52), -char(64),char(26),char(31),char(14),char(14),char(4),char(24),char(12),char(12),char(21), -char(4),char(3),char(32),char(33),char(13),char(20),char(47),char(31),char(63),char(31), -char(2),char(31),char(31),char(17),char(28),char(8),char(17),char(0),char(0),char(47), -char(50),char(47),char(51),char(18),char(57),char(47),char(93),char(57),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(5),char(34),char(38),char(2),char(53),char(52),char(54),char(54), -char(51),char(50),char(22),char(18),char(21),char(33),char(17),char(22),char(22),char(51), -char(50),char(54),char(55),char(23),char(6),char(6),char(19),char(17),char(38),char(38), -char(35),char(34),char(7),char(17),char(2),char(121),char(157),char(241),char(133),char(138), -char(244),char(149),char(152),char(243),char(135),char(252),char(197),char(49),char(166),char(82), -char(131),char(183),char(81),char(72),char(98),char(217),char(147),char(50),char(163),char(88), -char(173),char(122),char(35),char(147),char(1),char(5),char(157),char(171),char(255),char(140), -char(142),char(254),char(253),char(165),char(254),char(156),char(53),char(70),char(105),char(129), -char(41),char(155),char(124),char(2),char(139),char(1),char(21),char(53),char(66),char(117), -char(254),char(233),char(255),char(255),char(0),char(71),char(255),char(236),char(5),char(243), -char(5),char(182),char(0),char(39),char(2),char(23),char(2),char(92),char(0),char(0), -char(0),char(38),char(0),char(123),char(251),char(0),char(1),char(7),char(2),char(64), -char(3),char(96),char(253),char(179),char(0),char(11),char(180),char(4),char(3),char(2), -char(25),char(25),char(0),char(63),char(53),char(53),char(53),char(0),char(255),char(255), -char(0),char(32),char(255),char(236),char(6),char(8),char(5),char(201),char(0),char(39), -char(2),char(23),char(2),char(162),char(0),char(0),char(0),char(39),char(2),char(64), -char(3),char(117),char(253),char(179),char(1),char(6),char(0),char(117),char(255),char(0), -char(0),char(11),char(180),char(1),char(3),char(2),char(14),char(25),char(0),char(63), -char(53),char(53),char(53),char(0),char(255),char(255),char(0),char(71),char(255),char(236), -char(6),char(4),char(5),char(182),char(0),char(39),char(2),char(23),char(2),char(156), -char(0),char(0),char(0),char(38),char(2),char(61),char(12),char(0),char(1),char(7), -char(2),char(64),char(3),char(113),char(253),char(179),char(0),char(11),char(180),char(4), -char(3),char(2),char(44),char(25),char(0),char(63),char(53),char(53),char(53),char(0), -char(255),char(255),char(0),char(106),char(255),char(236),char(6),char(0),char(5),char(182), -char(0),char(39),char(2),char(23),char(2),char(70),char(0),char(0),char(0),char(39), -char(2),char(64),char(3),char(109),char(253),char(179),char(1),char(6),char(2),char(63), -char(49),char(0),char(0),char(11),char(180),char(1),char(3),char(2),char(14),char(25), -char(0),char(63),char(53),char(53),char(53),char(0),char(0),char(2),char(0),char(102), -char(255),char(236),char(4),char(53),char(5),char(199),char(0),char(26),char(0),char(40), -char(0),char(65),char(64),char(34),char(38),char(7),char(31),char(15),char(15),char(0), -char(0),char(20),char(7),char(3),char(41),char(42),char(11),char(34),char(71),char(89), -char(14),char(4),char(11),char(11),char(24),char(4),char(24),char(17),char(70),char(89), -char(24),char(3),char(4),char(27),char(70),char(89),char(4),char(22),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(18),char(57),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(2), -char(4),char(35),char(34),char(38),char(53),char(52),char(18),char(54),char(51),char(50), -char(22),char(23),char(55),char(16),char(33),char(34),char(6),char(7),char(53),char(54), -char(54),char(51),char(50),char(18),char(1),char(50),char(54),char(18),char(55),char(38), -char(38),char(35),char(34),char(6),char(6),char(21),char(20),char(22),char(4),char(53), -char(167),char(254),char(236),char(173),char(172),char(187),char(136),char(232),char(151),char(97), -char(146),char(43),char(4),char(254),char(230),char(62),char(144),char(48),char(47),char(155), -char(74),char(210),char(216),char(253),char(162),char(95),char(166),char(120),char(22),char(25), -char(128),char(80),char(101),char(165),char(101),char(101),char(3),char(166),char(254),char(250), -char(254),char(53),char(233),char(201),char(192),char(169),char(1),char(51),char(161),char(93), -char(75),char(90),char(1),char(149),char(44),char(33),char(159),char(23),char(37),char(254), -char(236),char(251),char(198),char(144),char(1),char(3),char(150),char(97),char(108),char(132), -char(250),char(128),char(118),char(130),char(0),char(2),char(0),char(39),char(0),char(0), -char(4),char(109),char(5),char(182),char(0),char(5),char(0),char(12),char(0),char(40), -char(64),char(19),char(9),char(5),char(10),char(4),char(5),char(4),char(14),char(13), -char(6),char(5),char(1),char(5),char(9),char(73),char(89),char(5),char(18),char(1), -char(3),char(0),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(55),char(1),char(51),char(1),char(21),char(33),char(1),char(6),char(7),char(1), -char(33),char(1),char(38),char(39),char(1),char(207),char(166),char(1),char(209),char(251), -char(186),char(2),char(33),char(61),char(40),char(254),char(252),char(2),char(209),char(254), -char(254),char(68),char(104),char(5),char(78),char(250),char(176),char(102),char(4),char(244), -char(225),char(121),char(252),char(254),char(2),char(249),char(202),char(0),char(0),char(1), -char(0),char(201),char(254),char(16),char(5),char(33),char(5),char(182),char(0),char(7), -char(0),char(35),char(64),char(17),char(0),char(7),char(3),char(4),char(7),char(4), -char(9),char(8),char(5),char(2),char(73),char(89),char(5),char(3),char(0),char(4), -char(27),char(0),char(63),char(51),char(63),char(43),char(17),char(18),char(1),char(57), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(33), -char(17),char(35),char(17),char(33),char(17),char(4),char(119),char(252),char(252),char(170), -char(4),char(88),char(254),char(16),char(7),char(13),char(248),char(243),char(7),char(166), -char(248),char(90),char(0),char(1),char(0),char(76),char(254),char(16),char(4),char(221), -char(5),char(182),char(0),char(11),char(0),char(49),char(64),char(26),char(7),char(9), -char(9),char(3),char(0),char(8),char(2),char(10),char(6),char(2),char(0),char(4), -char(12),char(13),char(4),char(7),char(73),char(89),char(4),char(3),char(0),char(9), -char(73),char(89),char(0),char(27),char(0),char(63),char(43),char(0),char(24),char(63), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(49),char(48),char(19),char(53),char(1),char(1),char(53), -char(33),char(21),char(33),char(1),char(1),char(33),char(21),char(76),char(2),char(119), -char(253),char(153),char(4),char(64),char(252),char(176),char(2),char(67),char(253),char(164), -char(3),char(170),char(254),char(16),char(107),char(3),char(156),char(3),char(51),char(108), -char(151),char(252),char(252),char(252),char(141),char(152),char(0),char(1),char(0),char(104), -char(2),char(141),char(4),char(41),char(3),char(23),char(0),char(3),char(0),char(21), -char(64),char(9),char(2),char(0),char(5),char(4),char(1),char(0),char(80),char(89), -char(1),char(0),char(47),char(43),char(17),char(18),char(1),char(57),char(57),char(49), -char(48),char(19),char(53),char(33),char(21),char(104),char(3),char(193),char(2),char(141), -char(138),char(138),char(0),char(1),char(0),char(37),char(255),char(242),char(4),char(188), -char(6),char(152),char(0),char(8),char(0),char(28),char(64),char(11),char(8),char(10), -char(3),char(9),char(3),char(6),char(4),char(4),char(1),char(8),char(1),char(0), -char(47),char(47),char(18),char(57),char(47),char(57),char(51),char(17),char(1),char(51), -char(17),char(51),char(49),char(48),char(5),char(35),char(1),char(35),char(53),char(33), -char(19),char(1),char(51),char(2),char(111),char(127),char(254),char(233),char(180),char(1), -char(33),char(235),char(2),char(2),char(137),char(14),char(3),char(14),char(135),char(253), -char(84),char(5),char(189),char(0),char(0),char(3),char(0),char(119),char(1),char(147), -char(5),char(45),char(4),char(12),char(0),char(21),char(0),char(33),char(0),char(45), -char(0),char(51),char(64),char(24),char(31),char(12),char(43),char(0),char(0),char(37), -char(25),char(12),char(4),char(46),char(47),char(34),char(28),char(28),char(17),char(6), -char(9),char(19),char(15),char(40),char(22),char(22),char(3),char(9),char(0),char(47), -char(51),char(51),char(17),char(51),char(47),char(51),char(18),char(57),char(57),char(51), -char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(20),char(6),char(35),char(34),char(38),char(39), -char(6),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51),char(50), -char(23),char(54),char(51),char(50),char(22),char(1),char(50),char(54),char(55),char(38), -char(38),char(35),char(34),char(6),char(21),char(20),char(22),char(1),char(34),char(6), -char(7),char(22),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(5), -char(45),char(167),char(128),char(93),char(153),char(65),char(60),char(153),char(88),char(131), -char(168),char(168),char(131),char(181),char(122),char(124),char(185),char(133),char(162),char(252), -char(125),char(66),char(109),char(54),char(50),char(109),char(72),char(76),char(100),char(97), -char(2),char(161),char(66),char(109),char(55),char(51),char(110),char(71),char(76),char(100), -char(101),char(2),char(207),char(131),char(185),char(106),char(116),char(104),char(113),char(173), -char(142),char(134),char(179),char(219),char(215),char(175),char(254),char(187),char(91),char(100), -char(97),char(93),char(105),char(87),char(83),char(106),char(1),char(121),char(92),char(98), -char(97),char(94),char(107),char(84),char(85),char(105),char(0),char(1),char(0),char(12), -char(254),char(20),char(2),char(248),char(6),char(20),char(0),char(20),char(0),char(28), -char(64),char(12),char(8),char(18),char(2),char(18),char(13),char(3),char(21),char(22), -char(16),char(11),char(5),char(0),char(0),char(47),char(50),char(47),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(50), -char(23),char(21),char(38),char(35),char(34),char(21),char(17),char(20),char(6),char(35), -char(34),char(39),char(53),char(22),char(51),char(50),char(53),char(17),char(16),char(2), -char(125),char(79),char(44),char(49),char(62),char(176),char(165),char(163),char(74),char(59), -char(61),char(58),char(182),char(6),char(20),char(16),char(137),char(22),char(243),char(250), -char(225),char(176),char(187),char(19),char(135),char(22),char(243),char(5),char(31),char(1), -char(106),char(0),char(0),char(2),char(0),char(98),char(1),char(135),char(4),char(45), -char(4),char(31),char(0),char(23),char(0),char(47),char(0),char(112),char(64),char(64), -char(40),char(15),char(27),char(3),char(15),char(3),char(49),char(48),char(39),char(30), -char(30),char(24),char(80),char(89),char(15),char(30),char(31),char(30),char(47),char(30), -char(3),char(9),char(3),char(30),char(42),char(64),char(42),char(36),char(80),char(89), -char(27),char(42),char(64),char(15),char(6),char(6),char(0),char(80),char(89),char(15), -char(6),char(31),char(6),char(47),char(6),char(3),char(9),char(3),char(6),char(18), -char(64),char(18),char(12),char(80),char(89),char(3),char(0),char(18),char(16),char(18), -char(32),char(18),char(3),char(18),char(0),char(47),char(93),char(196),char(43),char(0), -char(26),char(24),char(16),char(205),char(95),char(94),char(93),char(43),char(0),char(16), -char(24),char(196),char(26),char(222),char(196),char(43),char(0),char(26),char(24),char(16), -char(205),char(95),char(94),char(93),char(43),char(0),char(16),char(24),char(196),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(34),char(6),char(7),char(53),char(54),char(51),char(50),char(22),char(23), -char(22),char(22),char(51),char(50),char(54),char(55),char(21),char(6),char(35),char(34), -char(38),char(39),char(38),char(38),char(3),char(34),char(6),char(7),char(53),char(54), -char(51),char(50),char(22),char(23),char(22),char(22),char(51),char(50),char(54),char(55), -char(21),char(6),char(35),char(34),char(38),char(39),char(38),char(38),char(1),char(80), -char(54),char(127),char(57),char(108),char(148),char(67),char(112),char(88),char(77),char(91), -char(45),char(53),char(128),char(54),char(101),char(153),char(67),char(111),char(88),char(73), -char(91),char(49),char(57),char(128),char(53),char(106),char(150),char(69),char(116),char(82), -char(69),char(95),char(49),char(55),char(129),char(51),char(100),char(154),char(69),char(118), -char(79),char(84),char(85),char(2),char(0),char(64),char(57),char(150),char(110),char(28), -char(37),char(33),char(25),char(66),char(57),char(151),char(109),char(29),char(37),char(30), -char(25),char(1),char(150),char(68),char(53),char(149),char(109),char(32),char(34),char(29), -char(26),char(66),char(55),char(150),char(110),char(32),char(33),char(34),char(24),char(0), -char(0),char(1),char(0),char(104),char(0),char(166),char(4),char(41),char(5),char(2), -char(0),char(19),char(0),char(70),char(64),char(38),char(5),char(1),char(16),char(11), -char(11),char(9),char(10),char(14),char(4),char(0),char(19),char(1),char(8),char(20), -char(21),char(13),char(5),char(6),char(5),char(80),char(89),char(10),char(8),char(15), -char(6),char(1),char(9),char(3),char(6),char(14),char(2),char(1),char(2),char(80), -char(89),char(18),char(17),char(1),char(0),char(47),char(51),char(196),char(43),char(17), -char(0),char(51),char(24),char(47),char(95),char(94),char(93),char(198),char(51),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(33),char(53),char(33),char(19),char(33), -char(53),char(33),char(19),char(23),char(7),char(33),char(21),char(33),char(3),char(33), -char(21),char(33),char(3),char(39),char(1),char(125),char(254),char(235),char(1),char(84), -char(127),char(254),char(45),char(2),char(19),char(135),char(125),char(109),char(1),char(23), -char(254),char(170),char(129),char(1),char(215),char(253),char(233),char(131),char(125),char(1), -char(193),char(137),char(1),char(16),char(137),char(1),char(31),char(57),char(230),char(137), -char(254),char(240),char(137),char(254),char(229),char(55),char(255),char(255),char(0),char(104), -char(0),char(1),char(4),char(41),char(4),char(217),char(2),char(38),char(0),char(31), -char(0),char(0),char(1),char(7),char(2),char(43),char(0),char(0),char(253),char(116), -char(0),char(9),char(179),char(1),char(0),char(7),char(18),char(0),char(63),char(53), -char(53),char(0),char(255),char(255),char(0),char(104),char(0),char(1),char(4),char(41), -char(4),char(217),char(2),char(38),char(0),char(33),char(0),char(0),char(1),char(7), -char(2),char(43),char(0),char(0),char(253),char(116),char(0),char(9),char(179),char(1), -char(0),char(7),char(18),char(0),char(63),char(53),char(53),char(0),char(0),char(2), -char(0),char(111),char(0),char(0),char(4),char(61),char(5),char(195),char(0),char(5), -char(0),char(9),char(0),char(32),char(64),char(13),char(8),char(0),char(6),char(3), -char(0),char(3),char(10),char(11),char(9),char(7),char(2),char(5),char(2),char(0), -char(47),char(47),char(18),char(57),char(57),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(1),char(51),char(1), -char(1),char(35),char(9),char(3),char(111),char(1),char(194),char(72),char(1),char(196), -char(254),char(60),char(72),char(1),char(98),char(254),char(195),char(254),char(195),char(1), -char(61),char(2),char(223),char(2),char(228),char(253),char(28),char(253),char(33),char(2), -char(225),char(2),char(19),char(253),char(237),char(253),char(236),char(0),char(255),char(255), -char(0),char(29),char(0),char(0),char(4),char(28),char(6),char(31),char(0),char(38), -char(0),char(73),char(0),char(0),char(0),char(7),char(0),char(76),char(2),char(182), -char(0),char(0),char(255),char(255),char(0),char(29),char(0),char(0),char(4),char(12), -char(6),char(31),char(0),char(38),char(0),char(73),char(0),char(0),char(0),char(7), -char(0),char(79),char(2),char(182),char(0),char(0),char(0),char(1),char(0),char(219), -char(4),char(217),char(3),char(190),char(6),char(12),char(0),char(13),char(0),char(24), -char(64),char(9),char(11),char(3),char(15),char(14),char(10),char(4),char(128),char(7), -char(0),char(0),char(47),char(50),char(26),char(204),char(50),char(17),char(18),char(1), -char(57),char(57),char(49),char(48),char(1),char(34),char(38),char(39),char(51),char(22), -char(22),char(51),char(50),char(54),char(55),char(51),char(6),char(6),char(2),char(72), -char(185),char(170),char(10),char(156),char(9),char(91),char(113),char(103),char(99),char(11), -char(157),char(12),char(178),char(4),char(217),char(143),char(164),char(104),char(82),char(88), -char(98),char(158),char(149),char(0),char(0),char(1),char(255),char(145),char(254),char(20), -char(1),char(86),char(4),char(72),char(0),char(12),char(0),char(29),char(64),char(13), -char(11),char(8),char(8),char(14),char(13),char(9),char(15),char(0),char(5),char(70), -char(89),char(0),char(27),char(0),char(63),char(43),char(0),char(24),char(63),char(17), -char(18),char(1),char(57),char(17),char(51),char(49),char(48),char(19),char(34),char(39), -char(53),char(22),char(51),char(50),char(54),char(53),char(17),char(51),char(17),char(16), -char(43),char(95),char(59),char(69),char(67),char(78),char(73),char(166),char(254),char(20), -char(25),char(135),char(20),char(85),char(87),char(4),char(252),char(251),char(16),char(254), -char(188),char(0),char(0),char(1),char(1),char(137),char(4),char(205),char(2),char(117), -char(6),char(20),char(0),char(9),char(0),char(19),char(182),char(9),char(4),char(10), -char(11),char(4),char(128),char(9),char(0),char(47),char(26),char(205),char(17),char(18), -char(1),char(57),char(57),char(49),char(48),char(1),char(54),char(54),char(55),char(51), -char(21),char(6),char(6),char(7),char(35),char(1),char(137),char(19),char(39),char(10), -char(168),char(11),char(88),char(47),char(90),char(4),char(229),char(55),char(167),char(81), -char(18),char(51),char(188),char(70),char(0),char(1),char(1),char(113),char(254),char(59), -char(2),char(111),char(255),char(131),char(0),char(9),char(0),char(19),char(182),char(9), -char(4),char(10),char(11),char(9),char(128),char(4),char(0),char(47),char(26),char(205), -char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(1),char(54),char(54), -char(55),char(51),char(21),char(6),char(6),char(7),char(35),char(1),char(113),char(28), -char(51),char(7),char(168),char(11),char(98),char(55),char(90),char(254),char(84),char(64), -char(186),char(53),char(18),char(51),char(193),char(66),char(0),char(1),char(1),char(129), -char(4),char(217),char(2),char(127),char(6),char(33),char(0),char(9),char(0),char(19), -char(182),char(9),char(4),char(10),char(11),char(9),char(128),char(4),char(0),char(47), -char(26),char(205),char(17),char(18),char(1),char(57),char(57),char(49),char(48),char(1), -char(6),char(6),char(7),char(35),char(53),char(54),char(54),char(55),char(51),char(2), -char(127),char(29),char(53),char(6),char(166),char(14),char(99),char(49),char(92),char(6), -char(8),char(61),char(193),char(49),char(19),char(61),char(191),char(57),char(0),char(2), -char(0),char(39),char(2),char(57),char(2),char(158),char(5),char(199),char(0),char(11), -char(0),char(21),char(0),char(32),char(64),char(14),char(6),char(12),char(0),char(17), -char(12),char(17),char(23),char(22),char(9),char(19),char(31),char(3),char(14),char(33), -char(0),char(63),char(51),char(63),char(51),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(20),char(22),char(51), -char(50),char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(5),char(16), -char(33),char(34),char(38),char(53),char(16),char(33),char(50),char(22),char(176),char(82), -char(94),char(94),char(86),char(86),char(94),char(94),char(82),char(1),char(238),char(254), -char(196),char(158),char(157),char(1),char(59),char(158),char(158),char(4),char(0),char(168), -char(166),char(165),char(171),char(170),char(164),char(165),char(169),char(254),char(55),char(236), -char(221),char(1),char(197),char(232),char(0),char(2),char(0),char(20),char(2),char(74), -char(2),char(180),char(5),char(188),char(0),char(10),char(0),char(20),char(0),char(60), -char(64),char(31),char(20),char(5),char(11),char(7),char(3),char(3),char(9),char(2), -char(0),char(2),char(5),char(3),char(21),char(22),char(1),char(5),char(5),char(9), -char(15),char(20),char(31),char(20),char(2),char(20),char(20),char(3),char(14),char(7), -char(31),char(3),char(32),char(0),char(63),char(63),char(51),char(18),char(57),char(47), -char(93),char(51),char(51),char(17),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(51),char(17),char(51),char(51),char(17),char(51),char(49),char(48), -char(1),char(35),char(21),char(35),char(53),char(33),char(53),char(1),char(51),char(17), -char(51),char(33),char(53),char(52),char(55),char(14),char(3),char(7),char(7),char(2), -char(180),char(125),char(145),char(254),char(110),char(1),char(152),char(139),char(125),char(254), -char(242),char(6),char(5),char(24),char(30),char(30),char(11),char(168),char(3),char(20), -char(202),char(202),char(101),char(2),char(67),char(253),char(205),char(195),char(134),char(75), -char(12),char(39),char(45),char(45),char(17),char(246),char(0),char(1),char(0),char(59), -char(2),char(55),char(2),char(137),char(5),char(170),char(0),char(29),char(0),char(43), -char(64),char(21),char(16),char(3),char(28),char(23),char(9),char(23),char(26),char(3), -char(4),char(31),char(30),char(19),char(0),char(0),char(6),char(27),char(24),char(30), -char(13),char(6),char(33),char(0),char(63),char(51),char(63),char(51),char(18),char(57), -char(47),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(50),char(22),char(21),char(20),char(6),char(35), -char(34),char(38),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(34),char(6),char(7),char(39),char(19),char(33),char(21), -char(33),char(7),char(54),char(1),char(72),char(145),char(176),char(170),char(166),char(74), -char(139),char(41),char(56),char(140),char(54),char(95),char(110),char(109),char(102),char(57), -char(76),char(31),char(59),char(33),char(1),char(239),char(254),char(131),char(20),char(62), -char(4),char(104),char(143),char(123),char(140),char(155),char(31),char(23),char(131),char(34), -char(38),char(83),char(89),char(78),char(88),char(17),char(8),char(41),char(1),char(160), -char(104),char(230),char(12),char(0),char(0),char(2),char(0),char(41),char(2),char(57), -char(2),char(162),char(5),char(199),char(0),char(23),char(0),char(35),char(0),char(54), -char(64),char(28),char(27),char(18),char(33),char(11),char(0),char(0),char(6),char(18), -char(3),char(37),char(36),char(30),char(11),char(21),char(0),char(15),char(16),char(15), -char(2),char(15),char(15),char(3),char(24),char(21),char(33),char(8),char(3),char(31), -char(0),char(63),char(51),char(63),char(51),char(18),char(57),char(47),char(93),char(18), -char(57),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51), -char(17),char(51),char(49),char(48),char(19),char(16),char(54),char(51),char(50),char(23), -char(21),char(38),char(35),char(34),char(6),char(7),char(51),char(54),char(54),char(51), -char(50),char(22),char(21),char(20),char(6),char(35),char(34),char(38),char(5),char(50), -char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(21),char(20),char(22), -char(41),char(219),char(219),char(74),char(49),char(52),char(83),char(141),char(150),char(10), -char(8),char(29),char(113),char(85),char(125),char(148),char(166),char(141),char(153),char(173), -char(1),char(68),char(81),char(99),char(88),char(86),char(85),char(112),char(106),char(3), -char(195),char(1),char(5),char(255),char(15),char(114),char(18),char(153),char(166),char(43), -char(59),char(148),char(126),char(144),char(164),char(210),char(99),char(93),char(99),char(79), -char(91),char(90),char(59),char(89),char(124),char(0),char(0),char(1),char(0),char(57), -char(2),char(74),char(2),char(143),char(5),char(182),char(0),char(6),char(0),char(28), -char(64),char(13),char(1),char(5),char(5),char(0),char(2),char(3),char(7),char(8), -char(2),char(3),char(30),char(0),char(32),char(0),char(63),char(63),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48),char(19),char(1), -char(33),char(53),char(33),char(21),char(1),char(162),char(1),char(94),char(254),char(57), -char(2),char(86),char(254),char(160),char(2),char(74),char(2),char(248),char(116),char(94), -char(252),char(242),char(0),char(3),char(0),char(51),char(2),char(57),char(2),char(147), -char(5),char(199),char(0),char(21),char(0),char(34),char(0),char(45),char(0),char(63), -char(64),char(34),char(22),char(13),char(38),char(19),char(43),char(3),char(28),char(7), -char(7),char(3),char(5),char(16),char(19),char(13),char(6),char(46),char(47),char(5), -char(16),char(32),char(32),char(11),char(41),char(27),char(41),char(2),char(41),char(41), -char(25),char(10),char(33),char(35),char(0),char(31),char(0),char(63),char(50),char(63), -char(51),char(57),char(47),char(93),char(51),char(18),char(57),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(50),char(22),char(21),char(20),char(7),char(22), -char(21),char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(55), -char(38),char(38),char(53),char(52),char(54),char(3),char(20),char(22),char(51),char(50), -char(54),char(53),char(52),char(38),char(39),char(39),char(6),char(6),char(19),char(34), -char(6),char(21),char(20),char(22),char(23),char(54),char(53),char(52),char(38),char(1), -char(100),char(124),char(151),char(148),char(176),char(165),char(138),char(146),char(159),char(73), -char(85),char(74),char(57),char(157),char(53),char(84),char(86),char(90),char(84),char(93), -char(81),char(28),char(72),char(70),char(172),char(68),char(75),char(68),char(81),char(140), -char(78),char(5),char(199),char(118),char(104),char(130),char(76),char(74),char(158),char(113), -char(137),char(128),char(116),char(69),char(116),char(46),char(46),char(93),char(68),char(102), -char(126),char(253),char(102),char(60),char(73),char(73),char(60),char(63),char(79),char(28), -char(10),char(34),char(84),char(1),char(239),char(60),char(57),char(47),char(71),char(33), -char(54),char(97),char(57),char(60),char(0),char(2),char(0),char(35),char(2),char(57), -char(2),char(156),char(5),char(201),char(0),char(22),char(0),char(34),char(0),char(60), -char(64),char(31),char(26),char(17),char(32),char(10),char(0),char(0),char(5),char(17), -char(3),char(35),char(36),char(29),char(14),char(10),char(11),char(11),char(20),char(15), -char(14),char(31),char(14),char(2),char(14),char(14),char(3),char(23),char(20),char(31), -char(8),char(3),char(33),char(0),char(63),char(51),char(63),char(51),char(18),char(57), -char(47),char(93),char(18),char(57),char(17),char(51),char(17),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48), -char(1),char(16),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(32), -char(19),char(35),char(6),char(6),char(35),char(34),char(38),char(53),char(52),char(54), -char(51),char(50),char(22),char(37),char(34),char(6),char(21),char(20),char(22),char(51), -char(50),char(54),char(53),char(52),char(38),char(2),char(156),char(218),char(212),char(83), -char(49),char(49),char(93),char(1),char(20),char(21),char(10),char(35),char(116),char(65), -char(131),char(153),char(169),char(136),char(152),char(176),char(254),char(184),char(81),char(95), -char(85),char(87),char(84),char(115),char(103),char(4),char(70),char(254),char(242),char(255), -char(15),char(116),char(20),char(1),char(70),char(51),char(52),char(146),char(131),char(136), -char(165),char(202),char(91),char(95),char(87),char(81),char(95),char(85),char(62),char(97), -char(114),char(0),char(0),char(22),char(0),char(84),char(254),char(129),char(7),char(193), -char(5),char(238),char(0),char(5),char(0),char(11),char(0),char(17),char(0),char(23), -char(0),char(27),char(0),char(31),char(0),char(35),char(0),char(39),char(0),char(43), -char(0),char(47),char(0),char(51),char(0),char(55),char(0),char(59),char(0),char(63), -char(0),char(67),char(0),char(71),char(0),char(83),char(0),char(91),char(0),char(107), -char(0),char(116),char(0),char(124),char(0),char(137),char(0),char(248),char(64),char(135), -char(65),char(64),char(61),char(60),char(49),char(48),char(15),char(5),char(0),char(12), -char(84),char(78),char(88),char(72),char(118),char(107),char(112),char(96),char(122),char(103), -char(133),char(134),char(69),char(68),char(41),char(40),char(37),char(36),char(20),char(10), -char(9),char(23),char(23),char(134),char(6),char(18),char(59),char(27),char(127),char(103), -char(96),char(56),char(24),char(55),char(47),char(107),char(52),char(44),char(72),char(35), -char(31),char(32),char(28),char(3),char(17),char(78),char(12),char(25),char(138),char(139), -char(10),char(0),char(42),char(66),char(90),char(81),char(134),char(92),char(116),char(92), -char(41),char(65),char(70),char(62),char(100),char(117),char(117),char(108),char(69),char(61), -char(130),char(125),char(86),char(75),char(107),char(118),char(107),char(38),char(50),char(37), -char(49),char(21),char(13),char(0),char(66),char(1),char(65),char(62),char(92),char(61), -char(108),char(13),char(49),char(50),char(3),char(107),char(12),char(92),char(108),char(107), -char(107),char(108),char(92),char(3),char(1),char(45),char(44),char(29),char(28),char(25), -char(24),char(19),char(18),char(15),char(12),char(57),char(56),char(53),char(52),char(33), -char(32),char(7),char(6),char(4),char(1),char(0),char(47),char(51),char(51),char(51), -char(51),char(51),char(51),char(51),char(51),char(51),char(47),char(51),char(51),char(51), -char(51),char(51),char(51),char(51),char(51),char(51),char(18),char(23),char(57),char(47), -char(47),char(47),char(17),char(18),char(23),char(57),char(17),char(57),char(18),char(57), -char(57),char(17),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(17),char(51),char(16),char(196),char(50),char(196),char(50),char(17),char(51),char(17), -char(51),char(18),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(16), -char(196),char(196),char(50),char(17),char(51),char(17),char(51),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(51),char(51),char(51),char(51),char(51),char(51), -char(51),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(51),char(51),char(51), -char(51),char(51),char(51),char(51),char(49),char(48),char(19),char(17),char(33),char(21), -char(35),char(21),char(37),char(53),char(33),char(17),char(35),char(53),char(1),char(17), -char(51),char(21),char(51),char(21),char(33),char(53),char(51),char(53),char(51),char(17), -char(33),char(53),char(33),char(21),char(33),char(53),char(33),char(21),char(1),char(53), -char(33),char(21),char(1),char(35),char(17),char(51),char(17),char(35),char(17),char(51), -char(1),char(53),char(33),char(21),char(1),char(35),char(17),char(51),char(1),char(53), -char(33),char(21),char(51),char(53),char(33),char(21),char(1),char(35),char(17),char(51), -char(53),char(35),char(17),char(51),char(1),char(35),char(17),char(51),char(5),char(20), -char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51),char(50),char(22), -char(5),char(20),char(51),char(50),char(53),char(52),char(35),char(34),char(37),char(51), -char(50),char(22),char(21),char(20),char(6),char(7),char(21),char(22),char(22),char(21), -char(20),char(6),char(35),char(35),char(19),char(51),char(50),char(54),char(53),char(52), -char(38),char(35),char(35),char(21),char(21),char(51),char(50),char(54),char(53),char(52), -char(35),char(1),char(34),char(39),char(53),char(22),char(51),char(50),char(53),char(17), -char(51),char(17),char(20),char(6),char(84),char(1),char(47),char(192),char(5),char(206), -char(1),char(48),char(109),char(249),char(0),char(111),char(192),char(5),char(14),char(195), -char(109),char(253),char(73),char(1),char(17),char(251),char(225),char(1),char(14),char(254), -char(242),char(1),char(14),char(4),char(183),char(109),char(109),char(109),char(109),char(251), -char(194),char(1),char(16),char(252),char(48),char(111),char(111),char(2),char(192),char(1), -char(16),char(119),char(1),char(17),char(250),char(168),char(111),char(111),char(111),char(111), -char(6),char(254),char(109),char(109),char(251),char(159),char(135),char(127),char(127),char(135), -char(135),char(127),char(126),char(136),char(254),char(115),char(135),char(135),char(135),char(135), -char(1),char(225),char(172),char(109),char(112),char(46),char(44),char(61),char(46),char(109), -char(94),char(207),char(123),char(66),char(46),char(36),char(42),char(47),char(59),char(74), -char(49),char(37),char(90),char(1),char(94),char(52),char(28),char(43),char(25),char(86), -char(125),char(105),char(4),char(190),char(1),char(48),char(111),char(193),char(193),char(111), -char(254),char(208),char(193),char(249),char(2),char(1),char(47),char(194),char(109),char(109), -char(194),char(254),char(209),char(109),char(109),char(109),char(109),char(6),char(254),char(111), -char(111),char(250),char(168),char(1),char(14),char(2),char(2),char(1),char(15),char(250), -char(59),char(109),char(109),char(1),char(166),char(1),char(14),char(4),char(74),char(111), -char(111),char(111),char(111),char(252),char(47),char(1),char(16),char(121),char(1),char(15), -char(253),char(104),char(1),char(16),char(73),char(145),char(156),char(156),char(145),char(146), -char(155),char(154),char(147),char(197),char(197),char(196),char(97),char(67),char(83),char(49), -char(66),char(8),char(8),char(14),char(68),char(53),char(81),char(89),char(1),char(98), -char(34),char(32),char(34),char(29),char(227),char(154),char(43),char(37),char(74),char(254), -char(250),char(10),char(102),char(8),char(86),char(1),char(146),char(254),char(114),char(95), -char(99),char(0),char(0),char(3),char(0),char(84),char(254),char(193),char(7),char(170), -char(6),char(20),char(0),char(3),char(0),char(30),char(0),char(42),char(0),char(46), -char(64),char(25),char(1),char(11),char(23),char(37),char(4),char(30),char(31),char(17), -char(3),char(9),char(43),char(44),char(40),char(30),char(20),char(14),char(34),char(30), -char(14),char(14),char(30),char(34),char(3),char(2),char(0),char(0),char(47),char(47), -char(23),char(57),char(47),char(47),char(47),char(17),char(51),char(17),char(51),char(17), -char(18),char(1),char(23),char(57),char(49),char(48),char(9),char(3),char(5),char(53), -char(52),char(54),char(55),char(54),char(54),char(53),char(52),char(38),char(35),char(34), -char(6),char(7),char(23),char(54),char(51),char(50),char(22),char(21),char(20),char(6), -char(7),char(6),char(6),char(21),char(21),char(3),char(20),char(22),char(51),char(50), -char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(3),char(254),char(3), -char(172),char(252),char(84),char(252),char(86),char(3),char(235),char(44),char(65),char(103), -char(73),char(187),char(165),char(79),char(186),char(71),char(82),char(160),char(90),char(63), -char(62),char(49),char(72),char(84),char(59),char(27),char(71),char(70),char(66),char(73), -char(72),char(67),char(72),char(69),char(6),char(20),char(252),char(86),char(252),char(87), -char(3),char(169),char(251),char(47),char(50),char(65),char(49),char(82),char(126),char(88), -char(135),char(154),char(56),char(42),char(178),char(80),char(58),char(47),char(53),char(75), -char(54),char(68),char(112),char(74),char(59),char(254),char(237),char(63),char(72),char(73), -char(62),char(64),char(73),char(72),char(255),char(255),char(255),char(145),char(254),char(20), -char(2),char(87),char(6),char(33),char(2),char(38),char(2),char(55),char(0),char(0), -char(1),char(7),char(1),char(76),char(254),char(169),char(0),char(0),char(0),char(8), -char(179),char(1),char(24),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(25),char(3),char(193),char(1),char(68),char(5),char(182),char(2),char(6), -char(2),char(7),char(0),char(0),char(0),char(2),char(0),char(10),char(255),char(236), -char(4),char(223),char(6),char(43),char(0),char(45),char(0),char(54),char(0),char(102), -char(64),char(57),char(27),char(7),char(23),char(11),char(52),char(37),char(46),char(31), -char(31),char(43),char(2),char(45),char(2),char(37),char(11),char(7),char(18),char(6), -char(55),char(56),char(20),char(14),char(71),char(89),char(0),char(33),char(46),char(33), -char(71),char(89),char(43),char(46),char(15),char(46),char(31),char(46),char(2),char(9), -char(3),char(20),char(46),char(20),char(46),char(5),char(40),char(40),char(49),char(70), -char(89),char(40),char(1),char(5),char(29),char(70),char(89),char(5),char(22),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(57),char(24),char(47),char(47),char(95),char(94),char(93),char(17),char(51),char(43), -char(17),char(0),char(51),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(22),char(21),char(16),char(0),char(33),char(32),char(17), -char(52),char(55),char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(7), -char(39),char(54),char(51),char(50),char(22),char(21),char(20),char(7),char(6),char(21), -char(20),char(51),char(32),char(17),char(52),char(39),char(38),char(36),char(38),char(53), -char(52),char(54),char(51),char(50),char(0),char(19),char(51),char(21),char(37),char(38), -char(2),char(35),char(34),char(6),char(21),char(20),char(4),char(4),char(86),char(4), -char(254),char(224),char(254),char(253),char(254),char(119),char(16),char(15),char(36),char(32), -char(25),char(54),char(15),char(33),char(83),char(95),char(88),char(93),char(15),char(16), -char(233),char(1),char(119),char(4),char(223),char(254),char(201),char(160),char(182),char(168), -char(208),char(1),char(0),char(42),char(143),char(254),char(199),char(28),char(183),char(123), -char(93),char(97),char(1),char(19),char(3),char(78),char(46),char(65),char(254),char(159), -char(254),char(110),char(1),char(88),char(57),char(123),char(122),char(23),char(47),char(35), -char(15),char(9),char(118),char(39),char(93),char(93),char(35),char(131),char(132),char(58), -char(207),char(2),char(112),char(63),char(44),char(2),char(105),char(188),char(131),char(144), -char(163),char(254),char(205),char(254),char(215),char(129),char(129),char(211),char(1),char(0), -char(95),char(75),char(141),char(154),char(0),char(1),char(0),char(0),char(0),char(0), -char(4),char(123),char(5),char(195),char(0),char(21),char(0),char(40),char(64),char(20), -char(17),char(18),char(7),char(18),char(20),char(3),char(22),char(23),char(0),char(18), -char(20),char(3),char(18),char(18),char(5),char(10),char(74),char(89),char(5),char(4), -char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(18),char(57),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(18), -char(18),char(54),char(54),char(51),char(50),char(23),char(21),char(38),char(35),char(34), -char(14),char(3),char(7),char(17),char(35),char(17),char(1),char(51),char(2),char(57), -char(122),char(141),char(77),char(92),char(58),char(48),char(40),char(26),char(31),char(40), -char(59),char(86),char(124),char(101),char(31),char(172),char(254),char(35),char(186),char(2), -char(205),char(1),char(35),char(1),char(55),char(108),char(48),char(15),char(135),char(6), -char(56),char(161),char(252),char(236),char(85),char(253),char(227),char(2),char(47),char(3), -char(135),char(0),char(0),char(2),char(0),char(18),char(255),char(236),char(6),char(119), -char(4),char(72),char(0),char(20),char(0),char(41),char(0),char(76),char(64),char(39), -char(24),char(3),char(18),char(33),char(33),char(30),char(39),char(13),char(10),char(13), -char(30),char(3),char(6),char(5),char(42),char(43),char(19),char(31),char(31),char(0), -char(8),char(21),char(11),char(6),char(8),char(6),char(70),char(89),char(8),char(15), -char(36),char(27),char(0),char(27),char(70),char(89),char(16),char(0),char(22),char(0), -char(63),char(50),char(43),char(17),char(0),char(51),char(24),char(63),char(43),char(17), -char(0),char(51),char(51),char(17),char(18),char(57),char(24),char(47),char(57),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(18),char(57), -char(17),char(51),char(49),char(48),char(5),char(34),char(38),char(53),char(52),char(19), -char(33),char(53),char(55),char(33),char(21),char(35),char(22),char(21),char(20),char(6), -char(35),char(34),char(39),char(35),char(6),char(1),char(6),char(2),char(21),char(20), -char(22),char(51),char(50),char(54),char(53),char(53),char(51),char(21),char(20),char(22), -char(51),char(50),char(54),char(53),char(52),char(39),char(2),char(41),char(186),char(199), -char(135),char(254),char(227),char(142),char(5),char(215),char(250),char(117),char(200),char(185), -char(221),char(68),char(8),char(68),char(254),char(207),char(63),char(66),char(108),char(117), -char(93),char(108),char(162),char(107),char(93),char(117),char(109),char(111),char(20),char(231), -char(240),char(240),char(1),char(7),char(74),char(68),char(142),char(252),char(251),char(240), -char(231),char(182),char(182),char(3),char(206),char(132),char(254),char(254),char(103),char(174), -char(168),char(143),char(125),char(188),char(188),char(122),char(146),char(169),char(173),char(254), -char(239),char(0),char(255),char(255),char(0),char(201),char(0),char(0),char(6),char(113), -char(7),char(117),char(2),char(38),char(0),char(48),char(0),char(0),char(1),char(7), -char(0),char(118),char(1),char(156),char(1),char(84),char(0),char(8),char(179),char(1), -char(29),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(176), -char(0),char(0),char(6),char(203),char(6),char(33),char(2),char(38),char(0),char(80), -char(0),char(0),char(1),char(7),char(0),char(118),char(1),char(205),char(0),char(0), -char(0),char(8),char(179),char(1),char(45),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(0),char(253),char(213),char(5),char(16),char(5),char(188), -char(2),char(38),char(0),char(36),char(0),char(0),char(0),char(7),char(2),char(91), -char(1),char(53),char(0),char(0),char(255),char(255),char(0),char(94),char(253),char(213), -char(3),char(205),char(4),char(90),char(2),char(38),char(0),char(68),char(0),char(0), -char(0),char(7),char(2),char(91),char(0),char(199),char(0),char(0),char(255),char(255), -char(254),char(223),char(255),char(236),char(5),char(210),char(5),char(205),char(0),char(38), -char(0),char(50),char(20),char(0),char(1),char(7),char(2),char(92),char(254),char(71), -char(0),char(0),char(0),char(9),char(179),char(3),char(2),char(26),char(3),char(0), -char(63),char(53),char(53),char(0),char(0),char(2),char(0),char(117),char(253),char(213), -char(2),char(53),char(255),char(131),char(0),char(11),char(0),char(23),char(0),char(30), -char(64),char(12),char(18),char(6),char(12),char(0),char(6),char(0),char(24),char(25), -char(21),char(3),char(15),char(9),char(0),char(47),char(51),char(204),char(50),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(20),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51), -char(50),char(22),char(7),char(52),char(38),char(35),char(34),char(6),char(21),char(20), -char(22),char(51),char(50),char(54),char(2),char(53),char(125),char(102),char(101),char(120), -char(120),char(101),char(101),char(126),char(110),char(66),char(51),char(51),char(66),char(60), -char(57),char(53),char(64),char(254),char(174),char(97),char(120),char(117),char(98),char(98), -char(117),char(118),char(97),char(57),char(60),char(60),char(57),char(56),char(61),char(61), -char(0),char(2),char(0),char(152),char(4),char(104),char(2),char(207),char(5),char(197), -char(0),char(8),char(0),char(23),char(0),char(30),char(64),char(14),char(14),char(9), -char(3),char(8),char(12),char(19),char(9),char(5),char(24),char(25),char(2),char(11), -char(8),char(21),char(0),char(47),char(196),char(220),char(198),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(54),char(55),char(51), -char(21),char(6),char(6),char(7),char(35),char(37),char(52),char(55),char(21),char(6), -char(21),char(20),char(30),char(2),char(21),char(20),char(35),char(34),char(38),char(1), -char(176),char(70),char(28),char(189),char(41),char(119),char(49),char(78),char(254),char(232), -char(237),char(121),char(31),char(37),char(31),char(93),char(55),char(67),char(4),char(135), -char(181),char(122),char(20),char(78),char(172),char(57),char(118),char(163),char(61),char(72), -char(41),char(53),char(20),char(19),char(16),char(26),char(28),char(74),char(68),char(0), -char(255),char(255),char(0),char(29),char(0),char(0),char(6),char(211),char(6),char(31), -char(0),char(39),char(0),char(73),char(2),char(176),char(0),char(0),char(0),char(38), -char(0),char(73),char(0),char(0),char(0),char(7),char(0),char(76),char(5),char(109), -char(0),char(0),char(255),char(255),char(0),char(29),char(0),char(0),char(6),char(195), -char(6),char(31),char(0),char(39),char(0),char(73),char(2),char(176),char(0),char(0), -char(0),char(38),char(0),char(73),char(0),char(0),char(0),char(7),char(0),char(79), -char(5),char(109),char(0),char(0),char(0),char(2),char(0),char(125),char(255),char(236), -char(6),char(100),char(6),char(20),char(0),char(21),char(0),char(33),char(0),char(60), -char(64),char(31),char(22),char(6),char(15),char(17),char(17),char(28),char(0),char(0), -char(20),char(11),char(6),char(4),char(34),char(35),char(20),char(11),char(3),char(9), -char(9),char(31),char(73),char(89),char(15),char(9),char(4),char(3),char(25),char(73), -char(89),char(3),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(198), -char(43),char(17),char(18),char(0),char(57),char(57),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(16),char(0),char(33),char(32),char(0),char(17),char(16),char(0),char(33), -char(32),char(23),char(62),char(2),char(53),char(51),char(23),char(6),char(6),char(7), -char(22),char(1),char(16),char(18),char(51),char(50),char(18),char(17),char(16),char(2), -char(35),char(34),char(2),char(5),char(188),char(254),char(157),char(254),char(198),char(254), -char(189),char(254),char(161),char(1),char(97),char(1),char(67),char(1),char(69),char(179), -char(50),char(58),char(27),char(182),char(14),char(29),char(131),char(104),char(96),char(251), -char(117),char(250),char(244),char(243),char(246),char(245),char(242),char(243),char(253),char(2), -char(221),char(254),char(158),char(254),char(113),char(1),char(137),char(1),char(106),char(1), -char(104),char(1),char(134),char(215),char(12),char(67),char(102),char(105),char(22),char(155), -char(173),char(39),char(176),char(254),char(254),char(254),char(214),char(254),char(206),char(1), -char(49),char(1),char(43),char(1),char(39),char(1),char(49),char(254),char(209),char(0), -char(0),char(2),char(0),char(115),char(255),char(236),char(5),char(25),char(4),char(240), -char(0),char(22),char(0),char(34),char(0),char(60),char(64),char(31),char(23),char(7), -char(16),char(18),char(18),char(29),char(0),char(0),char(21),char(12),char(7),char(4), -char(35),char(36),char(21),char(12),char(3),char(10),char(10),char(32),char(70),char(89), -char(16),char(10),char(16),char(3),char(26),char(70),char(89),char(3),char(22),char(0), -char(63),char(43),char(0),char(24),char(63),char(198),char(43),char(17),char(18),char(0), -char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(35), -char(34),char(38),char(2),char(53),char(16),char(0),char(51),char(50),char(23),char(62), -char(2),char(53),char(51),char(23),char(6),char(6),char(7),char(22),char(5),char(20), -char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(35),char(34),char(6), -char(4),char(98),char(254),char(242),char(238),char(147),char(228),char(124),char(1),char(12), -char(238),char(217),char(137),char(51),char(58),char(26),char(180),char(15),char(31),char(121), -char(102),char(71),char(252),char(189),char(158),char(173),char(175),char(157),char(159),char(175), -char(173),char(156),char(2),char(37),char(254),char(244),char(254),char(211),char(138),char(1), -char(2),char(173),char(1),char(12),char(1),char(43),char(141),char(15),char(65),char(99), -char(110),char(23),char(156),char(175),char(38),char(138),char(185),char(211),char(219),char(219), -char(211),char(210),char(216),char(216),char(0),char(1),char(0),char(186),char(255),char(236), -char(6),char(123),char(6),char(20),char(0),char(27),char(0),char(51),char(64),char(24), -char(5),char(7),char(7),char(1),char(11),char(20),char(17),char(11),char(17),char(29), -char(28),char(10),char(1),char(14),char(27),char(5),char(18),char(3),char(14),char(23), -char(73),char(89),char(14),char(19),char(0),char(63),char(43),char(0),char(24),char(63), -char(198),char(51),char(18),char(57),char(57),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(1), -char(21),char(62),char(2),char(53),char(51),char(23),char(6),char(6),char(7),char(17), -char(16),char(0),char(33),char(32),char(0),char(53),char(17),char(51),char(17),char(20), -char(22),char(51),char(50),char(54),char(53),char(17),char(5),char(25),char(58),char(70), -char(31),char(181),char(14),char(33),char(172),char(149),char(254),char(225),char(254),char(248), -char(254),char(244),char(254),char(212),char(170),char(204),char(198),char(184),char(193),char(5), -char(182),char(198),char(8),char(62),char(112),char(110),char(22),char(182),char(184),char(25), -char(253),char(141),char(254),char(254),char(254),char(234),char(1),char(31),char(253),char(3), -char(174),char(252),char(70),char(183),char(196),char(193),char(188),char(3),char(184),char(0), -char(0),char(1),char(0),char(164),char(255),char(236),char(5),char(150),char(4),char(242), -char(0),char(29),char(0),char(68),char(64),char(34),char(1),char(28),char(13),char(15), -char(15),char(19),char(20),char(7),char(7),char(10),char(19),char(28),char(19),char(30), -char(31),char(21),char(22),char(10),char(18),char(22),char(3),char(20),char(13),char(8), -char(29),char(15),char(25),char(4),char(70),char(89),char(25),char(22),char(20),char(21), -char(0),char(63),char(63),char(43),char(0),char(24),char(63),char(51),char(198),char(18), -char(23),char(57),char(17),char(51),char(17),char(18),char(1),char(57),char(57),char(17), -char(51),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(17),char(20),char(22),char(51),char(50),char(54),char(53), -char(17),char(51),char(21),char(54),char(54),char(53),char(51),char(23),char(6),char(6), -char(7),char(17),char(35),char(39),char(35),char(6),char(6),char(35),char(34),char(38), -char(53),char(17),char(1),char(76),char(122),char(130),char(172),char(159),char(166),char(82), -char(74),char(178),char(15),char(32),char(176),char(141),char(137),char(24),char(9),char(52), -char(181),char(111),char(203),char(200),char(4),char(70),char(253),char(59),char(134),char(132), -char(188),char(213),char(2),char(62),char(121),char(11),char(128),char(154),char(23),char(186), -char(191),char(14),char(252),char(172),char(147),char(82),char(85),char(190),char(209),char(2), -char(203),char(0),char(255),char(255),char(252),char(83),char(4),char(217),char(253),char(220), -char(6),char(33),char(0),char(7),char(0),char(67),char(250),char(202),char(0),char(0), -char(255),char(255),char(253),char(13),char(4),char(217),char(254),char(150),char(6),char(33), -char(0),char(7),char(0),char(118),char(251),char(132),char(0),char(0),char(255),char(255), -char(252),char(25),char(4),char(217),char(255),char(1),char(5),char(221),char(0),char(7), -char(1),char(82),char(251),char(17),char(0),char(0),char(0),char(1),char(253),char(8), -char(4),char(184),char(254),char(115),char(6),char(143),char(0),char(17),char(0),char(30), -char(64),char(12),char(2),char(5),char(5),char(13),char(13),char(8),char(0),char(0), -char(19),char(11),char(16),char(4),char(0),char(47),char(204),char(50),char(17),char(1), -char(51),char(17),char(51),char(51),char(18),char(57),char(17),char(51),char(49),char(48), -char(1),char(20),char(7),char(7),char(35),char(39),char(54),char(54),char(53),char(52), -char(38),char(35),char(34),char(7),char(53),char(54),char(51),char(32),char(254),char(115), -char(166),char(10),char(105),char(12),char(86),char(78),char(67),char(73),char(62),char(32), -char(38),char(69),char(1),char(0),char(5),char(215),char(140),char(34),char(113),char(176), -char(14),char(50),char(43),char(43),char(41),char(6),char(100),char(10),char(0),char(1), -char(253),char(59),char(254),char(160),char(254),char(2),char(255),char(125),char(0),char(11), -char(0),char(17),char(181),char(6),char(0),char(0),char(13),char(9),char(3),char(0), -char(47),char(205),char(17),char(1),char(51),char(17),char(51),char(49),char(48),char(5), -char(52),char(54),char(51),char(50),char(22),char(21),char(20),char(6),char(35),char(34), -char(38),char(253),char(59),char(59),char(42),char(40),char(58),char(58),char(40),char(42), -char(59),char(242),char(57),char(54),char(54),char(57),char(55),char(55),char(55),char(0), -char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248),char(7),char(115), -char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7),char(0),char(67), -char(255),char(216),char(1),char(82),char(0),char(8),char(179),char(1),char(13),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(203),char(0),char(0), -char(5),char(82),char(7),char(115),char(2),char(38),char(1),char(178),char(0),char(0), -char(1),char(7),char(0),char(67),char(0),char(104),char(1),char(82),char(0),char(8), -char(179),char(1),char(17),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(4),char(18),char(6),char(33),char(2),char(38), -char(0),char(72),char(0),char(0),char(1),char(6),char(0),char(67),char(183),char(0), -char(0),char(8),char(179),char(2),char(28),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(176),char(0),char(0),char(4),char(98),char(6),char(33), -char(2),char(38),char(1),char(210),char(0),char(0),char(1),char(6),char(0),char(67), -char(220),char(0),char(0),char(8),char(179),char(1),char(15),char(17),char(38),char(0), -char(43),char(53),char(0),char(1),char(0),char(133),char(255),char(236),char(7),char(145), -char(5),char(201),char(0),char(49),char(0),char(69),char(64),char(36),char(34),char(22), -char(42),char(39),char(47),char(9),char(9),char(4),char(39),char(27),char(22),char(5), -char(50),char(51),char(0),char(31),char(25),char(31),char(73),char(89),char(16),char(40), -char(40),char(19),char(6),char(25),char(4),char(44),char(37),char(19),char(37),char(73), -char(89),char(12),char(19),char(19),char(0),char(63),char(51),char(43),char(17),char(0), -char(51),char(24),char(63),char(51),char(18),char(57),char(47),char(57),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(34),char(6),char(7),char(39), -char(54),char(51),char(50),char(0),char(17),char(16),char(0),char(35),char(34),char(38), -char(39),char(35),char(6),char(6),char(35),char(32),char(0),char(17),char(16),char(18), -char(51),char(50),char(23),char(7),char(38),char(38),char(35),char(34),char(2),char(17), -char(16),char(18),char(51),char(50),char(55),char(17),char(51),char(17),char(22),char(51), -char(50),char(18),char(17),char(16),char(2),char(5),char(164),char(60),char(94),char(45), -char(69),char(126),char(150),char(228),char(1),char(1),char(254),char(229),char(255),char(108), -char(172),char(83),char(8),char(80),char(169),char(107),char(255),char(0),char(254),char(229), -char(255),char(228),char(153),char(124),char(70),char(45),char(93),char(60),char(147),char(165), -char(207),char(187),char(139),char(102),char(170),char(102),char(142),char(187),char(206),char(165), -char(5),char(47),char(41),char(31),char(146),char(80),char(254),char(136),char(254),char(173), -char(254),char(141),char(254),char(97),char(45),char(51),char(50),char(46),char(1),char(155), -char(1),char(119),char(1),char(83),char(1),char(120),char(80),char(146),char(31),char(41), -char(254),char(215),char(254),char(246),char(254),char(211),char(254),char(178),char(76),char(1), -char(201),char(254),char(55),char(76),char(1),char(75),char(1),char(48),char(1),char(11), -char(1),char(40),char(0),char(1),char(0),char(0),char(0),char(0),char(6),char(29), -char(4),char(72),char(0),char(29),char(0),char(40),char(64),char(22),char(23),char(0), -char(13),char(14),char(5),char(5),char(30),char(31),char(27),char(21),char(13),char(0), -char(18),char(10),char(4),char(4),char(22),char(14),char(5),char(15),char(4),char(21), -char(0),char(63),char(63),char(51),char(51),char(18),char(23),char(57),char(63),char(17), -char(18),char(1),char(23),char(57),char(49),char(48),char(1),char(6),char(6),char(3), -char(35),char(1),char(51),char(19),char(22),char(23),char(51),char(54),char(54),char(19), -char(3),char(51),char(0),char(22),char(23),char(51),char(54),char(18),char(17),char(51), -char(16),char(2),char(7),char(35),char(3),char(38),char(3),char(39),char(10),char(20), -char(179),char(213),char(254),char(127),char(172),char(246),char(32),char(46),char(8),char(19), -char(74),char(142),char(172),char(178),char(1),char(9),char(45),char(10),char(8),char(173), -char(153),char(166),char(195),char(219),char(182),char(125),char(33),char(1),char(201),char(26), -char(51),char(254),char(132),char(4),char(72),char(253),char(73),char(93),char(189),char(53), -char(163),char(1),char(36),char(1),char(213),char(252),char(255),char(144),char(44),char(184), -char(1),char(179),char(1),char(82),char(254),char(150),char(254),char(7),char(229),char(1), -char(90),char(92),char(0),char(2),char(0),char(23),char(0),char(0),char(4),char(252), -char(6),char(20),char(0),char(17),char(0),char(26),char(0),char(76),char(64),char(40), -char(8),char(4),char(18),char(18),char(1),char(15),char(22),char(11),char(11),char(6), -char(15),char(0),char(4),char(27),char(28),char(7),char(17),char(0),char(17),char(73), -char(89),char(4),char(0),char(8),char(26),char(73),char(89),char(0),char(8),char(0), -char(8),char(15),char(2),char(0),char(15),char(18),char(74),char(89),char(15),char(18), -char(0),char(63),char(43),char(0),char(24),char(63),char(18),char(57),char(57),char(47), -char(47),char(43),char(17),char(0),char(51),char(43),char(17),char(0),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(51),char(49),char(48),char(19),char(33),char(17),char(51),char(17),char(33), -char(21),char(33),char(17),char(51),char(32),char(17),char(20),char(4),char(33),char(33), -char(17),char(33),char(1),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(35),char(23),char(1),char(63),char(172),char(1),char(162),char(254),char(94),char(201), -char(2),char(49),char(254),char(247),char(254),char(251),char(254),char(104),char(254),char(193), -char(1),char(235),char(213),char(192),char(181),char(186),char(218),char(182),char(4),char(250), -char(1),char(26),char(254),char(230),char(148),char(254),char(224),char(254),char(100),char(208), -char(218),char(4),char(102),char(252),char(43),char(137),char(144),char(138),char(122),char(0), -char(0),char(2),char(0),char(23),char(0),char(0),char(4),char(156),char(5),char(39), -char(0),char(17),char(0),char(25),char(0),char(71),char(64),char(38),char(4),char(0), -char(19),char(19),char(15),char(11),char(22),char(7),char(7),char(2),char(11),char(13), -char(4),char(26),char(27),char(3),char(13),char(14),char(13),char(70),char(89),char(4), -char(18),char(70),char(89),char(4),char(4),char(11),char(16),char(0),char(14),char(15), -char(11),char(19),char(70),char(89),char(11),char(21),char(0),char(63),char(43),char(0), -char(24),char(63),char(51),char(198),char(18),char(57),char(47),char(43),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(51),char(17),char(51),char(51),char(49),char(48),char(1),char(33),char(21), -char(33),char(17),char(33),char(32),char(17),char(20),char(6),char(35),char(33),char(17), -char(35),char(53),char(51),char(53),char(51),char(17),char(17),char(33),char(32),char(53), -char(52),char(38),char(35),char(1),char(168),char(1),char(88),char(254),char(168),char(1), -char(63),char(1),char(181),char(223),char(220),char(254),char(33),char(235),char(235),char(166), -char(1),char(49),char(1),char(31),char(135),char(156),char(4),char(72),char(140),char(254), -char(197),char(254),char(205),char(166),char(168),char(3),char(188),char(140),char(223),char(252), -char(205),char(254),char(151),char(185),char(92),char(84),char(0),char(1),char(0),char(201), -char(255),char(236),char(7),char(33),char(5),char(203),char(0),char(32),char(0),char(74), -char(64),char(41),char(23),char(19),char(19),char(20),char(6),char(24),char(29),char(12), -char(5),char(24),char(17),char(20),char(6),char(33),char(34),char(27),char(0),char(73), -char(89),char(27),char(4),char(6),char(18),char(23),char(18),char(73),char(89),char(3), -char(23),char(23),char(20),char(21),char(3),char(20),char(18),char(14),char(9),char(73), -char(89),char(14),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(63), -char(18),char(57),char(47),char(51),char(43),char(17),char(0),char(51),char(24),char(63), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(34),char(4),char(7),char(33),char(21), -char(33),char(18),char(0),char(51),char(50),char(55),char(21),char(6),char(35),char(32), -char(0),char(3),char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(18), -char(0),char(37),char(50),char(23),char(7),char(38),char(38),char(5),char(143),char(227), -char(254),char(252),char(31),char(2),char(191),char(253),char(61),char(8),char(1),char(9), -char(247),char(154),char(194),char(152),char(222),char(254),char(193),char(254),char(165),char(8), -char(254),char(162),char(170),char(170),char(1),char(100),char(30),char(1),char(113),char(1), -char(48),char(213),char(182),char(72),char(100),char(157),char(5),char(51),char(250),char(241), -char(150),char(254),char(239),char(254),char(226),char(55),char(149),char(57),char(1),char(112), -char(1),char(84),char(253),char(80),char(5),char(182),char(253),char(146),char(1),char(51), -char(1),char(78),char(2),char(92),char(146),char(48),char(38),char(0),char(0),char(1), -char(0),char(176),char(255),char(236),char(5),char(156),char(4),char(92),char(0),char(33), -char(0),char(89),char(64),char(50),char(22),char(25),char(25),char(10),char(3),char(9), -char(5),char(5),char(6),char(16),char(32),char(24),char(3),char(6),char(5),char(34), -char(35),char(13),char(19),char(70),char(89),char(13),char(16),char(25),char(4),char(9), -char(4),char(70),char(89),char(22),char(15),char(9),char(31),char(9),char(2),char(11), -char(3),char(9),char(9),char(6),char(7),char(15),char(6),char(21),char(0),char(28), -char(70),char(89),char(0),char(22),char(0),char(63),char(43),char(0),char(24),char(63), -char(63),char(18),char(57),char(47),char(95),char(94),char(93),char(51),char(43),char(17), -char(0),char(51),char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(49), -char(48),char(5),char(34),char(0),char(39),char(33),char(17),char(35),char(17),char(51), -char(17),char(33),char(54),char(36),char(51),char(50),char(22),char(23),char(7),char(38), -char(35),char(34),char(6),char(7),char(33),char(21),char(33),char(22),char(22),char(51), -char(50),char(54),char(55),char(21),char(6),char(4),char(119),char(235),char(254),char(244), -char(11),char(254),char(225),char(166),char(166),char(1),char(33),char(24),char(1),char(13), -char(223),char(81),char(154),char(54),char(50),char(138),char(101),char(163),char(167),char(16), -char(2),char(24),char(253),char(230),char(9),char(169),char(164),char(61),char(119),char(98), -char(110),char(20),char(1),char(10),char(248),char(254),char(18),char(4),char(72),char(254), -char(51),char(235),char(246),char(32),char(25),char(141),char(51),char(164),char(170),char(141), -char(188),char(181),char(22),char(37),char(147),char(57),char(0),char(2),char(0),char(0), -char(0),char(0),char(5),char(109),char(5),char(182),char(0),char(11),char(0),char(18), -char(0),char(52),char(64),char(27),char(2),char(3),char(7),char(12),char(3),char(13), -char(10),char(5),char(20),char(19),char(1),char(5),char(12),char(5),char(73),char(89), -char(16),char(8),char(12),char(12),char(7),char(8),char(3),char(11),char(3),char(7), -char(18),char(0),char(63),char(51),char(51),char(63),char(18),char(57),char(47),char(18), -char(57),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(49),char(48),char(1),char(35),char(17),char(35),char(17),char(35), -char(1),char(35),char(1),char(51),char(1),char(35),char(1),char(33),char(39),char(38), -char(39),char(6),char(7),char(3),char(152),char(148),char(156),char(149),char(254),char(223), -char(178),char(2),char(104),char(158),char(2),char(103),char(183),char(253),char(92),char(1), -char(76),char(82),char(56),char(30),char(24),char(64),char(2),char(170),char(253),char(86), -char(2),char(170),char(253),char(86),char(5),char(182),char(250),char(74),char(3),char(63), -char(207),char(144),char(100),char(98),char(164),char(0),char(0),char(2),char(0),char(10), -char(0),char(0),char(4),char(121),char(4),char(72),char(0),char(11),char(0),char(18), -char(0),char(53),char(64),char(28),char(5),char(6),char(10),char(12),char(6),char(13), -char(3),char(1),char(6),char(20),char(19),char(4),char(8),char(12),char(8),char(70), -char(89),char(17),char(11),char(12),char(12),char(10),char(11),char(15),char(6),char(2), -char(10),char(21),char(0),char(63),char(51),char(51),char(63),char(18),char(57),char(47), -char(18),char(57),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(49),char(48),char(1),char(1),char(35),char(3),char(35), -char(17),char(35),char(17),char(35),char(3),char(35),char(1),char(3),char(33),char(38), -char(38),char(39),char(35),char(6),char(2),char(168),char(1),char(209),char(172),char(207), -char(113),char(151),char(115),char(205),char(172),char(1),char(209),char(33),char(1),char(15), -char(43),char(56),char(34),char(9),char(28),char(4),char(72),char(251),char(184),char(1), -char(233),char(254),char(23),char(1),char(233),char(254),char(23),char(4),char(72),char(254), -char(45),char(108),char(138),char(106),char(92),char(0),char(0),char(2),char(0),char(201), -char(0),char(0),char(7),char(94),char(5),char(182),char(0),char(19),char(0),char(26), -char(0),char(70),char(64),char(37),char(14),char(10),char(10),char(11),char(2),char(3), -char(18),char(21),char(3),char(20),char(8),char(7),char(11),char(7),char(27),char(28), -char(5),char(1),char(9),char(14),char(9),char(73),char(89),char(20),char(24),char(12), -char(14),char(14),char(11),char(16),char(12),char(3),char(19),char(7),char(3),char(11), -char(18),char(0),char(63),char(51),char(51),char(51),char(63),char(51),char(18),char(57), -char(47),char(18),char(57),char(51),char(43),char(17),char(0),char(51),char(51),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(35),char(17),char(35),char(17),char(35),char(1),char(35), -char(1),char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(1),char(51), -char(1),char(35),char(1),char(33),char(2),char(38),char(39),char(6),char(6),char(5), -char(133),char(143),char(154),char(147),char(254),char(227),char(186),char(1),char(34),char(254), -char(95),char(170),char(170),char(1),char(225),char(1),char(6),char(158),char(2),char(102), -char(188),char(253),char(102),char(1),char(62),char(118),char(28),char(12),char(19),char(35), -char(2),char(176),char(253),char(80),char(2),char(176),char(253),char(80),char(2),char(176), -char(253),char(80),char(5),char(182),char(253),char(146),char(2),char(110),char(250),char(74), -char(3),char(72),char(1),char(53),char(86),char(47),char(67),char(104),char(0),char(2), -char(0),char(176),char(0),char(0),char(6),char(20),char(4),char(72),char(0),char(19), -char(0),char(25),char(0),char(77),char(64),char(43),char(17),char(13),char(13),char(14), -char(5),char(6),char(1),char(25),char(6),char(24),char(11),char(10),char(14),char(7), -char(26),char(27),char(8),char(4),char(12),char(17),char(12),char(70),char(89),char(24), -char(21),char(19),char(47),char(17),char(63),char(17),char(2),char(17),char(17),char(14), -char(19),char(15),char(15),char(15),char(10),char(6),char(2),char(14),char(21),char(0), -char(63),char(51),char(51),char(51),char(63),char(63),char(18),char(57),char(47),char(93), -char(18),char(57),char(51),char(43),char(17),char(0),char(51),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(1),char(35),char(3),char(35),char(17),char(35),char(17),char(35), -char(3),char(35),char(19),char(33),char(17),char(35),char(17),char(51),char(17),char(33), -char(19),char(23),char(35),char(6),char(6),char(7),char(33),char(4),char(70),char(1), -char(206),char(170),char(208),char(113),char(152),char(110),char(209),char(172),char(209),char(254), -char(223),char(166),char(166),char(1),char(94),char(197),char(104),char(8),char(10),char(32), -char(89),char(1),char(12),char(4),char(72),char(251),char(184),char(1),char(238),char(254), -char(18),char(1),char(238),char(254),char(18),char(1),char(238),char(254),char(18),char(4), -char(72),char(254),char(51),char(1),char(205),char(115),char(34),char(95),char(217),char(0), -char(0),char(2),char(0),char(20),char(0),char(0),char(5),char(174),char(5),char(182), -char(0),char(31),char(0),char(34),char(0),char(75),char(64),char(40),char(32),char(1), -char(15),char(16),char(33),char(30),char(30),char(29),char(16),char(2),char(1),char(7), -char(6),char(36),char(35),char(30),char(1),char(33),char(31),char(31),char(33),char(73), -char(89),char(14),char(18),char(29),char(18),char(74),char(89),char(34),char(2),char(29), -char(29),char(24),char(31),char(3),char(16),char(8),char(24),char(18),char(0),char(63), -char(51),char(51),char(63),char(18),char(57),char(47),char(51),char(51),char(43),char(17), -char(0),char(51),char(43),char(17),char(18),char(0),char(57),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(21),char(1),char(30),char(2),char(23),char(19),char(35),char(3), -char(46),char(2),char(35),char(35),char(17),char(35),char(17),char(35),char(34),char(6), -char(6),char(7),char(3),char(35),char(19),char(62),char(2),char(55),char(1),char(53), -char(5),char(33),char(1),char(5),char(41),char(254),char(90),char(118),char(154),char(100), -char(50),char(133),char(174),char(137),char(35),char(68),char(101),char(89),char(27),char(170), -char(26),char(91),char(99),char(65),char(32),char(135),char(185),char(136),char(47),char(99), -char(149),char(118),char(254),char(101),char(3),char(190),char(253),char(10),char(1),char(123), -char(5),char(182),char(133),char(254),char(17),char(6),char(72),char(139),char(164),char(254), -char(59),char(1),char(201),char(111),char(96),char(38),char(253),char(66),char(2),char(190), -char(39),char(95),char(111),char(254),char(55),char(1),char(197),char(159),char(142),char(73), -char(7),char(1),char(239),char(133),char(153),char(254),char(57),char(0),char(0),char(2), -char(0),char(12),char(0),char(0),char(5),char(20),char(4),char(72),char(0),char(32), -char(0),char(35),char(0),char(78),char(64),char(42),char(33),char(1),char(15),char(16), -char(34),char(31),char(24),char(31),char(30),char(16),char(2),char(1),char(7),char(7), -char(37),char(36),char(31),char(1),char(34),char(32),char(32),char(34),char(70),char(89), -char(17),char(14),char(18),char(30),char(18),char(71),char(89),char(35),char(2),char(30), -char(30),char(24),char(32),char(15),char(16),char(8),char(24),char(21),char(0),char(63), -char(51),char(51),char(63),char(18),char(57),char(47),char(51),char(51),char(43),char(17), -char(0),char(51),char(51),char(43),char(17),char(18),char(0),char(57),char(57),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(21),char(1),char(30),char(3),char(19),char(35),char(3), -char(46),char(2),char(35),char(35),char(17),char(35),char(17),char(35),char(34),char(6), -char(6),char(7),char(3),char(35),char(19),char(62),char(3),char(55),char(1),char(53), -char(5),char(33),char(1),char(4),char(139),char(254),char(174),char(87),char(111),char(73), -char(49),char(155),char(172),char(133),char(34),char(58),char(84),char(76),char(10),char(153), -char(11),char(75),char(82),char(56),char(39),char(135),char(170),char(131),char(24),char(48), -char(73),char(110),char(87),char(254),char(177),char(3),char(32),char(253),char(180),char(1), -char(37),char(4),char(72),char(105),char(254),char(160),char(7),char(48),char(80),char(105), -char(254),char(113),char(1),char(80),char(87),char(71),char(28),char(253),char(246),char(2), -char(10),char(26),char(64),char(94),char(254),char(174),char(1),char(80),char(61),char(105), -char(79),char(50),char(8),char(1),char(96),char(105),char(140),char(254),char(193),char(0), -char(0),char(2),char(0),char(201),char(0),char(0),char(7),char(197),char(5),char(182), -char(0),char(36),char(0),char(39),char(0),char(97),char(64),char(53),char(33),char(29), -char(29),char(30),char(38),char(35),char(15),char(16),char(2),char(39),char(37),char(1), -char(7),char(1),char(39),char(16),char(34),char(27),char(35),char(24),char(30),char(9), -char(41),char(40),char(35),char(1),char(36),char(38),char(36),char(38),char(73),char(89), -char(18),char(14),char(28),char(33),char(28),char(73),char(89),char(39),char(2),char(33), -char(33),char(30),char(36),char(3),char(31),char(3),char(24),char(16),char(8),char(30), -char(18),char(0),char(63),char(51),char(51),char(51),char(63),char(63),char(18),char(57), -char(47),char(51),char(51),char(43),char(17),char(0),char(51),char(51),char(43),char(17), -char(18),char(0),char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(21),char(1),char(30),char(2),char(23),char(19), -char(35),char(3),char(46),char(2),char(35),char(35),char(17),char(35),char(17),char(35), -char(34),char(6),char(6),char(7),char(3),char(35),char(19),char(54),char(55),char(33), -char(17),char(35),char(17),char(51),char(17),char(33),char(1),char(53),char(5),char(33), -char(1),char(7),char(61),char(254),char(93),char(120),char(153),char(101),char(45),char(136), -char(168),char(138),char(31),char(70),char(105),char(95),char(24),char(172),char(25),char(94), -char(100),char(66),char(33),char(135),char(178),char(135),char(55),char(56),char(254),char(82), -char(170),char(170),char(2),char(215),char(254),char(104),char(3),char(193),char(253),char(10), -char(1),char(123),char(5),char(182),char(133),char(254),char(14),char(6),char(72),char(144), -char(156),char(254),char(59),char(1),char(201),char(104),char(99),char(40),char(253),char(68), -char(2),char(188),char(40),char(95),char(108),char(254),char(55),char(1),char(190),char(184), -char(58),char(253),char(80),char(5),char(182),char(253),char(146),char(1),char(233),char(133), -char(153),char(254),char(55),char(0),char(0),char(2),char(0),char(176),char(0),char(0), -char(6),char(186),char(4),char(72),char(0),char(36),char(0),char(39),char(0),char(103), -char(64),char(58),char(33),char(29),char(29),char(30),char(38),char(35),char(15),char(16), -char(2),char(39),char(37),char(1),char(7),char(1),char(39),char(16),char(34),char(27), -char(35),char(24),char(30),char(9),char(41),char(40),char(35),char(1),char(36),char(38), -char(36),char(38),char(70),char(89),char(18),char(14),char(28),char(33),char(28),char(70), -char(89),char(39),char(2),char(47),char(33),char(63),char(33),char(2),char(33),char(33), -char(30),char(36),char(15),char(31),char(15),char(24),char(16),char(8),char(30),char(21), -char(0),char(63),char(51),char(51),char(51),char(63),char(63),char(18),char(57),char(47), -char(93),char(51),char(51),char(43),char(17),char(0),char(51),char(51),char(43),char(17), -char(18),char(0),char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(21),char(1),char(30),char(3),char(19),char(35), -char(3),char(46),char(2),char(35),char(35),char(17),char(35),char(17),char(35),char(34), -char(6),char(6),char(7),char(3),char(35),char(19),char(54),char(55),char(33),char(17), -char(35),char(17),char(51),char(17),char(33),char(1),char(53),char(5),char(33),char(1), -char(6),char(49),char(254),char(174),char(88),char(111),char(73),char(48),char(155),char(172), -char(133),char(34),char(58),char(86),char(74),char(10),char(154),char(10),char(75),char(84), -char(55),char(38),char(135),char(170),char(131),char(47),char(37),char(254),char(205),char(166), -char(166),char(2),char(53),char(254),char(176),char(3),char(33),char(253),char(180),char(1), -char(37),char(4),char(72),char(105),char(254),char(158),char(7),char(49),char(78),char(105), -char(254),char(114),char(1),char(80),char(86),char(70),char(28),char(253),char(248),char(2), -char(8),char(27),char(63),char(92),char(254),char(174),char(1),char(80),char(120),char(40), -char(254),char(16),char(4),char(72),char(254),char(53),char(1),char(98),char(105),char(140), -char(254),char(199),char(0),char(1),char(0),char(63),char(254),char(78),char(4),char(53), -char(6),char(209),char(0),char(75),char(0),char(132),char(64),char(77),char(0),char(19), -char(33),char(63),char(25),char(70),char(70),char(10),char(63),char(55),char(67),char(60), -char(42),char(28),char(45),char(40),char(19),char(11),char(76),char(77),char(73),char(22), -char(74),char(89),char(73),char(19),char(57),char(52),char(49),char(15),char(46),char(31), -char(46),char(47),char(46),char(3),char(9),char(3),char(46),char(42),char(64),char(67), -char(29),char(28),char(29),char(28),char(74),char(89),char(29),char(29),char(16),char(60), -char(42),char(42),char(36),char(74),char(89),char(42),char(4),char(10),char(9),char(73), -char(89),char(10),char(16),char(16),char(3),char(73),char(89),char(16),char(35),char(12), -char(7),char(73),char(89),char(12),char(34),char(0),char(63),char(43),char(0),char(24), -char(63),char(43),char(0),char(24),char(16),char(198),char(43),char(0),char(24),char(63), -char(43),char(17),char(0),char(51),char(18),char(57),char(24),char(47),char(43),char(17), -char(18),char(0),char(57),char(26),char(24),char(16),char(221),char(95),char(94),char(93), -char(57),char(196),char(50),char(63),char(43),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(23),char(20), -char(22),char(51),char(50),char(55),char(54),char(51),char(50),char(23),char(21),char(38), -char(35),char(34),char(7),char(6),char(35),char(34),char(38),char(53),char(52),char(54), -char(55),char(54),char(54),char(53),char(16),char(33),char(35),char(53),char(51),char(50), -char(54),char(53),char(52),char(38),char(35),char(34),char(6),char(7),char(39),char(54), -char(55),char(38),char(39),char(39),char(53),char(51),char(22),char(23),char(54),char(54), -char(51),char(50),char(23),char(21),char(38),char(35),char(34),char(6),char(7),char(22), -char(22),char(21),char(20),char(6),char(7),char(21),char(22),char(22),char(21),char(20), -char(4),char(5),char(6),char(6),char(240),char(87),char(89),char(97),char(120),char(120), -char(70),char(155),char(71),char(80),char(160),char(68),char(105),char(105),char(105),char(179), -char(184),char(217),char(232),char(204),char(181),char(254),char(64),char(218),char(209),char(205), -char(225),char(162),char(137),char(106),char(187),char(110),char(86),char(168),char(190),char(57), -char(117),char(49),char(123),char(92),char(131),char(92),char(131),char(64),char(50),char(48), -char(24),char(43),char(44),char(111),char(48),char(178),char(193),char(191),char(170),char(186), -char(203),char(254),char(229),char(254),char(230),char(138),char(134),char(137),char(55),char(50), -char(7),char(6),char(39),char(166),char(51),char(5),char(5),char(125),char(133),char(126), -char(129),char(9),char(8),char(138),char(141),char(1),char(12),char(143),char(147),char(132), -char(107),char(128),char(55),char(69),char(114),char(114),char(28),char(66),char(121),char(52), -char(27),char(59),char(136),char(115),char(86),char(14),char(113),char(10),char(82),char(71), -char(23),char(189),char(143),char(140),char(184),char(26),char(8),char(24),char(178),char(144), -char(208),char(213),char(9),char(5),char(55),char(0),char(0),char(1),char(0),char(25), -char(254),char(123),char(3),char(127),char(5),char(78),char(0),char(70),char(0),char(131), -char(64),char(78),char(23),char(41),char(54),char(11),char(46),char(16),char(16),char(32), -char(11),char(3),char(14),char(8),char(62),char(50),char(64),char(60),char(41),char(11), -char(71),char(72),char(68),char(62),char(65),char(0),char(5),char(71),char(89),char(0), -char(15),char(65),char(31),char(65),char(47),char(65),char(3),char(9),char(3),char(65), -char(62),char(38),char(26),char(70),char(89),char(35),char(29),char(70),char(89),char(14), -char(51),char(50),char(51),char(50),char(70),char(89),char(38),char(35),char(51),char(51), -char(35),char(38),char(3),char(32),char(62),char(62),char(56),char(70),char(89),char(8), -char(62),char(16),char(32),char(34),char(19),char(44),char(71),char(89),char(19),char(22), -char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(43),char(17), -char(18),char(0),char(23),char(57),char(24),char(47),char(47),char(47),char(43),char(17), -char(18),char(0),char(57),char(43),char(43),char(0),char(24),char(16),char(212),char(95), -char(94),char(93),char(196),char(43),char(17),char(18),char(0),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(50),char(23),char(21),char(38),char(35),char(34),char(6),char(7), -char(22),char(22),char(21),char(20),char(7),char(21),char(22),char(21),char(20),char(6), -char(7),char(14),char(2),char(21),char(20),char(22),char(51),char(50),char(55),char(55), -char(50),char(23),char(21),char(38),char(38),char(35),char(7),char(6),char(35),char(34), -char(38),char(53),char(52),char(54),char(55),char(36),char(53),char(52),char(38),char(35), -char(35),char(53),char(51),char(32),char(53),char(52),char(35),char(34),char(6),char(7), -char(39),char(54),char(55),char(38),char(39),char(53),char(51),char(22),char(23),char(54), -char(54),char(2),char(248),char(51),char(45),char(24),char(41),char(47),char(103),char(45), -char(122),char(140),char(211),char(248),char(242),char(225),char(93),char(109),char(48),char(75), -char(89),char(86),char(122),char(175),char(125),char(39),char(21),char(84),char(55),char(179), -char(130),char(92),char(144),char(159),char(190),char(180),char(1),char(78),char(156),char(159), -char(148),char(119),char(1),char(55),char(252),char(74),char(143),char(88),char(59),char(124), -char(126),char(92),char(103),char(123),char(75),char(140),char(88),char(134),char(5),char(78), -char(15),char(112),char(10),char(79),char(62),char(28),char(138),char(107),char(184),char(57), -char(8),char(71),char(202),char(148),char(168),char(3),char(2),char(23),char(42),char(44), -char(49),char(43),char(5),char(5),char(39),char(143),char(19),char(24),char(5),char(5), -char(119),char(112),char(116),char(125),char(3),char(4),char(190),char(97),char(90),char(141), -char(172),char(162),char(34),char(36),char(135),char(55),char(15),char(117),char(98),char(27), -char(52),char(137),char(110),char(85),char(255),char(255),char(0),char(109),char(0),char(0), -char(5),char(242),char(5),char(182),char(2),char(6),char(1),char(117),char(0),char(0), -char(255),char(255),char(0),char(164),char(254),char(20),char(5),char(135),char(6),char(18), -char(2),char(6),char(1),char(149),char(0),char(0),char(0),char(3),char(0),char(125), -char(255),char(236),char(5),char(190),char(5),char(205),char(0),char(11),char(0),char(18), -char(0),char(25),char(0),char(71),char(64),char(37),char(22),char(16),char(16),char(6), -char(23),char(15),char(15),char(0),char(6),char(0),char(26),char(27),char(22),char(16), -char(73),char(89),char(15),char(22),char(1),char(11),char(3),char(22),char(22),char(3), -char(9),char(9),char(19),char(73),char(89),char(9),char(4),char(3),char(12),char(73), -char(89),char(3),char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(43), -char(17),char(18),char(0),char(57),char(24),char(47),char(95),char(94),char(93),char(43), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(33),char(32), -char(0),char(17),char(16),char(0),char(33),char(32),char(0),char(1),char(50),char(18), -char(19),char(33),char(18),char(18),char(19),char(34),char(2),char(3),char(33),char(38), -char(2),char(5),char(190),char(254),char(157),char(254),char(196),char(254),char(189),char(254), -char(161),char(1),char(96),char(1),char(68),char(1),char(59),char(1),char(98),char(253), -char(97),char(229),char(247),char(13),char(252),char(43),char(13),char(249),char(232),char(224), -char(251),char(19),char(3),char(211),char(17),char(244),char(2),char(221),char(254),char(161), -char(254),char(110),char(1),char(139),char(1),char(104),char(1),char(101),char(1),char(137), -char(254),char(112),char(252),char(68),char(1),char(17),char(1),char(12),char(254),char(245), -char(254),char(238),char(4),char(180),char(254),char(254),char(255),char(0),char(254),char(1), -char(4),char(0),char(0),char(3),char(0),char(115),char(255),char(236),char(4),char(98), -char(4),char(92),char(0),char(12),char(0),char(19),char(0),char(26),char(0),char(73), -char(64),char(39),char(23),char(17),char(17),char(7),char(24),char(16),char(16),char(0), -char(7),char(0),char(27),char(28),char(23),char(17),char(70),char(89),char(15),char(23), -char(31),char(23),char(2),char(11),char(3),char(23),char(23),char(3),char(10),char(10), -char(20),char(70),char(89),char(10),char(16),char(3),char(13),char(70),char(89),char(3), -char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(24),char(47),char(95),char(94),char(93),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(16),char(0),char(35),char(34),char(38),char(2), -char(53),char(16),char(0),char(51),char(50),char(0),char(1),char(50),char(54),char(55), -char(33),char(22),char(22),char(19),char(34),char(6),char(7),char(33),char(38),char(38), -char(4),char(98),char(254),char(242),char(238),char(147),char(228),char(124),char(1),char(12), -char(238),char(230),char(1),char(15),char(254),char(8),char(158),char(164),char(10),char(253), -char(105),char(9),char(160),char(160),char(156),char(158),char(13),char(2),char(147),char(15), -char(161),char(2),char(37),char(254),char(244),char(254),char(211),char(138),char(1),char(2), -char(173),char(1),char(12),char(1),char(43),char(254),char(206),char(253),char(77),char(184), -char(191),char(186),char(189),char(3),char(88),char(173),char(167),char(168),char(172),char(0), -char(0),char(1),char(0),char(0),char(0),char(0),char(5),char(72),char(5),char(195), -char(0),char(21),char(0),char(32),char(64),char(16),char(6),char(22),char(19),char(23), -char(17),char(0),char(74),char(89),char(17),char(4),char(10),char(5),char(6),char(3), -char(5),char(18),char(0),char(63),char(63),char(18),char(57),char(63),char(43),char(17), -char(1),char(51),char(18),char(57),char(49),char(48),char(1),char(34),char(6),char(7), -char(1),char(35),char(1),char(51),char(1),char(22),char(23),char(54),char(55),char(19), -char(62),char(2),char(51),char(50),char(23),char(21),char(38),char(4),char(225),char(59), -char(78),char(57),char(254),char(184),char(197),char(253),char(238),char(180),char(1),char(82), -char(72),char(35),char(32),char(70),char(162),char(59),char(84),char(110),char(89),char(42), -char(79),char(56),char(5),char(55),char(103),char(181),char(251),char(229),char(5),char(182), -char(252),char(86),char(199),char(143),char(144),char(223),char(2),char(6),char(191),char(152), -char(65),char(19),char(141),char(20),char(0),char(1),char(0),char(0),char(0),char(0), -char(4),char(61),char(4),char(82),char(0),char(22),char(0),char(30),char(64),char(15), -char(1),char(23),char(15),char(24),char(13),char(18),char(71),char(89),char(13),char(16), -char(5),char(1),char(15),char(0),char(21),char(0),char(63),char(63),char(57),char(63), -char(43),char(17),char(1),char(51),char(18),char(57),char(49),char(48),char(33),char(1), -char(51),char(19),char(18),char(23),char(51),char(54),char(19),char(19),char(62),char(2), -char(51),char(50),char(23),char(21),char(38),char(35),char(34),char(6),char(7),char(3), -char(1),char(150),char(254),char(106),char(174),char(225),char(100),char(19),char(8),char(23), -char(82),char(96),char(37),char(71),char(91),char(84),char(45),char(30),char(29),char(38), -char(47),char(58),char(28),char(248),char(4),char(72),char(253),char(155),char(254),char(244), -char(100),char(118),char(1),char(11),char(1),char(53),char(122),char(123),char(52),char(10), -char(127),char(8),char(84),char(92),char(252),char(223),char(255),char(255),char(0),char(0), -char(0),char(0),char(5),char(72),char(7),char(115),char(2),char(38),char(2),char(128), -char(0),char(0),char(1),char(7),char(3),char(118),char(4),char(215),char(1),char(82), -char(0),char(10),char(180),char(2),char(1),char(33),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(0),char(0),char(0),char(4),char(61), -char(6),char(33),char(2),char(38),char(2),char(129),char(0),char(0),char(1),char(7), -char(3),char(118),char(4),char(100),char(0),char(0),char(0),char(10),char(180),char(2), -char(1),char(34),char(17),char(38),char(0),char(43),char(53),char(53),char(0),char(3), -char(0),char(125),char(254),char(20),char(9),char(162),char(5),char(205),char(0),char(11), -char(0),char(23),char(0),char(46),char(0),char(68),char(64),char(38),char(12),char(6), -char(18),char(0),char(33),char(46),char(39),char(24),char(0),char(6),char(6),char(47), -char(48),char(37),char(42),char(74),char(89),char(37),char(27),char(29),char(28),char(28), -char(3),char(32),char(24),char(15),char(9),char(21),char(73),char(89),char(9),char(4), -char(3),char(15),char(73),char(89),char(3),char(19),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(0),char(24),char(63),char(51),char(18),char(57),char(17), -char(51),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(33),char(32),char(0), -char(17),char(16),char(0),char(33),char(32),char(0),char(1),char(16),char(18),char(51), -char(50),char(18),char(17),char(16),char(2),char(35),char(34),char(2),char(37),char(51), -char(19),char(22),char(23),char(51),char(54),char(54),char(19),char(51),char(1),char(6), -char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50),char(54),char(55), -char(55),char(5),char(84),char(254),char(185),char(254),char(220),char(254),char(215),char(254), -char(189),char(1),char(67),char(1),char(44),char(1),char(35),char(1),char(69),char(251), -char(221),char(223),char(217),char(218),char(221),char(220),char(216),char(218),char(225),char(4), -char(111),char(176),char(246),char(78),char(20),char(8),char(11),char(83),char(228),char(176), -char(254),char(43),char(69),char(188),char(136),char(76),char(74),char(55),char(66),char(94), -char(117),char(35),char(61),char(2),char(221),char(254),char(160),char(254),char(111),char(1), -char(139),char(1),char(104),char(1),char(102),char(1),char(136),char(254),char(112),char(254), -char(160),char(254),char(215),char(254),char(205),char(1),char(49),char(1),char(43),char(1), -char(41),char(1),char(47),char(254),char(210),char(65),char(253),char(139),char(207),char(102), -char(44),char(251),char(2),char(131),char(251),char(32),char(182),char(158),char(17),char(133), -char(12),char(103),char(89),char(156),char(255),char(255),char(0),char(115),char(254),char(20), -char(8),char(123),char(4),char(92),char(0),char(38),char(0),char(82),char(0),char(0), -char(0),char(7),char(0),char(92),char(4),char(117),char(0),char(0),char(0),char(2), -char(0),char(125),char(255),char(135),char(6),char(16),char(6),char(45),char(0),char(19), -char(0),char(40),char(0),char(81),char(64),char(42),char(20),char(10),char(38),char(13), -char(7),char(17),char(34),char(34),char(3),char(28),char(31),char(0),char(0),char(28), -char(7),char(23),char(10),char(5),char(41),char(42),char(36),char(34),char(38),char(13), -char(38),char(73),char(89),char(17),char(15),char(13),char(3),char(28),char(26),char(23), -char(7),char(23),char(73),char(89),char(5),char(3),char(7),char(18),char(0),char(63), -char(51),char(51),char(43),char(17),char(0),char(51),char(51),char(24),char(63),char(51), -char(51),char(43),char(17),char(0),char(51),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(0),char(5),char(6), -char(35),char(34),char(39),char(36),char(0),char(17),char(16),char(0),char(37),char(54), -char(51),char(50),char(23),char(4),char(0),char(1),char(20),char(18),char(23),char(54), -char(54),char(51),char(50),char(23),char(54),char(18),char(53),char(52),char(2),char(39), -char(6),char(35),char(34),char(39),char(6),char(2),char(6),char(16),char(254),char(209), -char(254),char(248),char(26),char(119),char(124),char(20),char(254),char(244),char(254),char(209), -char(1),char(43),char(1),char(16),char(20),char(124),char(121),char(22),char(1),char(12), -char(1),char(45),char(251),char(33),char(202),char(189),char(17),char(73),char(54),char(110), -char(31),char(189),char(202),char(202),char(189),char(31),char(110),char(113),char(31),char(189), -char(202),char(2),char(221),char(254),char(210),char(254),char(115),char(44),char(111),char(111), -char(41),char(1),char(138),char(1),char(54),char(1),char(49),char(1),char(133),char(44), -char(108),char(108),char(44),char(254),char(115),char(254),char(213),char(244),char(254),char(207), -char(41),char(48),char(38),char(86),char(41),char(1),char(49),char(244),char(244),char(1), -char(47),char(39),char(88),char(86),char(39),char(254),char(211),char(0),char(0),char(2), -char(0),char(115),char(255),char(147),char(4),char(207),char(4),char(180),char(0),char(23), -char(0),char(45),char(0),char(80),char(64),char(42),char(24),char(12),char(15),char(9), -char(43),char(27),char(37),char(21),char(3),char(35),char(0),char(0),char(3),char(32), -char(27),char(9),char(12),char(6),char(46),char(47),char(40),char(37),char(43),char(15), -char(43),char(70),char(89),char(21),char(18),char(15),char(16),char(32),char(30),char(27), -char(9),char(27),char(70),char(89),char(6),char(3),char(9),char(21),char(0),char(63), -char(51),char(51),char(43),char(17),char(0),char(51),char(51),char(24),char(63),char(51), -char(51),char(43),char(17),char(0),char(51),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(2),char(7),char(6),char(6), -char(35),char(34),char(38),char(39),char(38),char(2),char(53),char(52),char(18),char(55), -char(54),char(54),char(51),char(50),char(22),char(23),char(22),char(18),char(5),char(20), -char(22),char(23),char(54),char(54),char(51),char(50),char(23),char(54),char(54),char(53), -char(16),char(37),char(6),char(6),char(35),char(34),char(38),char(39),char(6),char(6), -char(4),char(207),char(224),char(204),char(9),char(64),char(56),char(57),char(61),char(9), -char(203),char(229),char(224),char(208),char(8),char(62),char(57),char(56),char(64),char(9), -char(202),char(226),char(252),char(80),char(125),char(137),char(12),char(60),char(53),char(103), -char(24),char(134),char(124),char(254),char(252),char(13),char(61),char(51),char(53),char(60), -char(12),char(137),char(125),char(2),char(37),char(233),char(254),char(223),char(37),char(54), -char(45),char(43),char(56),char(36),char(1),char(38),char(229),char(233),char(1),char(32), -char(36),char(56),char(42),char(43),char(57),char(38),char(254),char(220),char(225),char(177), -char(210),char(31),char(42),char(34),char(74),char(31),char(210),char(175),char(1),char(96), -char(62),char(42),char(32),char(32),char(44),char(31),char(209),char(0),char(0),char(3), -char(0),char(125),char(255),char(236),char(7),char(127),char(8),char(59),char(0),char(21), -char(0),char(69),char(0),char(84),char(0),char(85),char(64),char(46),char(67),char(55), -char(31),char(43),char(43),char(1),char(38),char(70),char(75),char(80),char(72),char(60), -char(12),char(55),char(10),char(85),char(86),char(21),char(2),char(2),char(7),char(7), -char(16),char(12),char(82),char(64),char(72),char(58),char(34),char(64),char(58),char(64), -char(73),char(89),char(40),char(58),char(4),char(28),char(22),char(52),char(22),char(73), -char(89),char(46),char(52),char(19),char(0),char(63),char(51),char(43),char(17),char(0), -char(51),char(24),char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(16), -char(214),char(26),char(220),char(212),char(205),char(50),char(18),char(57),char(47),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(21),char(35),char(34),char(46),char(2),char(35),char(34),char(6), -char(21),char(21),char(35),char(53),char(52),char(54),char(51),char(50),char(30),char(2), -char(51),char(1),char(50),char(54),char(55),char(22),char(22),char(51),char(50),char(18), -char(17),char(16),char(2),char(35),char(34),char(6),char(7),char(39),char(54),char(51), -char(50),char(0),char(17),char(16),char(0),char(33),char(34),char(38),char(39),char(6), -char(6),char(35),char(32),char(0),char(17),char(16),char(0),char(51),char(50),char(23), -char(7),char(38),char(38),char(35),char(34),char(2),char(17),char(16),char(18),char(1), -char(20),char(7),char(53),char(54),char(53),char(52),char(46),char(2),char(53),char(52), -char(51),char(50),char(22),char(5),char(162),char(17),char(84),char(142),char(120),char(102), -char(43),char(47),char(60),char(125),char(116),char(112),char(58),char(112),char(119),char(133), -char(78),char(253),char(40),char(88),char(171),char(61),char(55),char(171),char(93),char(188), -char(210),char(165),char(147),char(60),char(95),char(43),char(70),char(121),char(154),char(228), -char(1),char(1),char(254),char(224),char(254),char(253),char(104),char(170),char(76),char(75), -char(167),char(110),char(254),char(252),char(254),char(227),char(1),char(1),char(228),char(154), -char(121),char(70),char(43),char(94),char(60),char(148),char(165),char(210),char(2),char(128), -char(237),char(120),char(31),char(36),char(31),char(92),char(56),char(67),char(7),char(199), -char(121),char(36),char(43),char(36),char(52),char(51),char(16),char(28),char(103),char(110), -char(36),char(44),char(36),char(248),char(186),char(66),char(63),char(57),char(72),char(1), -char(78),char(1),char(45),char(1),char(11),char(1),char(40),char(43),char(31),char(146), -char(82),char(254),char(136),char(254),char(173),char(254),char(140),char(254),char(98),char(40), -char(48),char(45),char(43),char(1),char(157),char(1),char(117),char(1),char(85),char(1), -char(118),char(82),char(146),char(31),char(43),char(254),char(217),char(254),char(244),char(254), -char(209),char(254),char(180),char(6),char(104),char(162),char(61),char(72),char(41),char(53), -char(20),char(18),char(17),char(26),char(28),char(73),char(68),char(0),char(0),char(3), -char(0),char(115),char(255),char(236),char(6),char(4),char(7),char(6),char(0),char(42), -char(0),char(63),char(0),char(78),char(0),char(92),char(64),char(51),char(19),char(7), -char(28),char(40),char(40),char(44),char(34),char(64),char(69),char(13),char(74),char(66), -char(54),char(7),char(10),char(79),char(80),char(50),char(58),char(63),char(45),char(45), -char(54),char(76),char(66),char(10),char(64),char(31),char(16),char(10),char(16),char(70), -char(89),char(2),char(23),char(70),char(89),char(2),char(4),char(37),char(10),char(16), -char(26),char(21),char(4),char(21),char(70),char(89),char(0),char(4),char(22),char(0), -char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(51),char(18), -char(57),char(43),char(43),char(17),char(0),char(51),char(26),char(24),char(16),char(222), -char(220),char(212),char(50),char(17),char(51),char(205),char(50),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(5),char(34), -char(39),char(6),char(35),char(34),char(2),char(17),char(16),char(18),char(51),char(50), -char(22),char(23),char(7),char(38),char(35),char(34),char(6),char(21),char(16),char(33), -char(50),char(55),char(22),char(22),char(51),char(32),char(17),char(52),char(38),char(35), -char(34),char(7),char(39),char(54),char(54),char(51),char(50),char(18),char(17),char(16), -char(2),char(3),char(21),char(35),char(34),char(46),char(2),char(35),char(34),char(21), -char(21),char(35),char(53),char(52),char(54),char(51),char(50),char(30),char(2),char(51), -char(5),char(20),char(7),char(53),char(54),char(53),char(52),char(46),char(2),char(53), -char(52),char(51),char(50),char(22),char(4),char(43),char(148),char(94),char(92),char(143), -char(225),char(250),char(207),char(186),char(62),char(119),char(40),char(57),char(89),char(71), -char(116),char(109),char(1),char(49),char(123),char(112),char(62),char(111),char(67),char(1), -char(45),char(110),char(115),char(71),char(89),char(57),char(40),char(119),char(62),char(187), -char(206),char(247),char(81),char(16),char(84),char(143),char(120),char(101),char(43),char(107), -char(125),char(115),char(112),char(58),char(113),char(118),char(131),char(78),char(254),char(240), -char(238),char(119),char(30),char(36),char(30),char(92),char(56),char(67),char(20),char(65), -char(65),char(1),char(35),char(1),char(14),char(1),char(23),char(1),char(40),char(32), -char(25),char(139),char(51),char(214),char(214),char(254),char(94),char(80),char(42),char(38), -char(1),char(162),char(214),char(214),char(51),char(139),char(25),char(32),char(254),char(215), -char(254),char(234),char(254),char(245),char(254),char(218),char(6),char(165),char(120),char(36), -char(42),char(36),char(102),char(17),char(31),char(100),char(111),char(37),char(43),char(37), -char(221),char(161),char(62),char(72),char(40),char(56),char(20),char(17),char(17),char(25), -char(27),char(74),char(68),char(0),char(0),char(2),char(0),char(94),char(255),char(236), -char(7),char(127),char(7),char(4),char(0),char(13),char(0),char(64),char(0),char(95), -char(64),char(52),char(48),char(36),char(57),char(54),char(62),char(23),char(23),char(1), -char(18),char(54),char(41),char(12),char(36),char(7),char(65),char(66),char(14),char(45), -char(39),char(45),char(73),char(89),char(30),char(55),char(55),char(33),char(39),char(5), -char(9),char(9),char(13),char(64),char(9),char(15),char(72),char(13),char(7),char(3), -char(11),char(64),char(20),char(39),char(4),char(59),char(51),char(33),char(51),char(73), -char(89),char(26),char(33),char(19),char(0),char(63),char(51),char(43),char(17),char(0), -char(51),char(24),char(63),char(51),char(26),char(222),char(50),char(50),char(205),char(43), -char(50),char(17),char(51),char(17),char(18),char(57),char(47),char(57),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(21),char(7),char(35),char(39), -char(35),char(7),char(35),char(39),char(35),char(7),char(35),char(39),char(53),char(1), -char(34),char(6),char(7),char(39),char(54),char(51),char(50),char(18),char(17),char(16), -char(0),char(33),char(34),char(38),char(39),char(35),char(6),char(6),char(35),char(32), -char(0),char(17),char(16),char(0),char(51),char(50),char(23),char(7),char(38),char(38), -char(35),char(34),char(2),char(17),char(16),char(18),char(51),char(50),char(54),char(55), -char(17),char(51),char(17),char(22),char(51),char(50),char(18),char(17),char(16),char(2), -char(5),char(139),char(80),char(32),char(50),char(186),char(49),char(33),char(49),char(188), -char(47),char(33),char(80),char(3),char(67),char(60),char(93),char(45),char(70),char(124), -char(153),char(228),char(255),char(254),char(226),char(254),char(253),char(116),char(172),char(76), -char(9),char(78),char(172),char(112),char(254),char(252),char(254),char(227),char(1),char(1), -char(229),char(150),char(126),char(70),char(45),char(93),char(60),char(147),char(165),char(210), -char(190),char(65),char(130),char(51),char(170),char(102),char(145),char(188),char(212),char(165), -char(7),char(4),char(27),char(172),char(103),char(103),char(103),char(103),char(172),char(27), -char(254),char(43),char(41),char(31),char(146),char(80),char(254),char(136),char(254),char(173), -char(254),char(139),char(254),char(99),char(48),char(48),char(49),char(47),char(1),char(160), -char(1),char(114),char(1),char(85),char(1),char(118),char(80),char(146),char(31),char(41), -char(254),char(215),char(254),char(246),char(254),char(209),char(254),char(180),char(38),char(38), -char(1),char(201),char(254),char(55),char(76),char(1),char(74),char(1),char(49),char(1), -char(11),char(1),char(40),char(0),char(0),char(2),char(0),char(0),char(0),char(0), -char(6),char(29),char(5),char(164),char(0),char(13),char(0),char(42),char(0),char(63), -char(64),char(36),char(36),char(1),char(14),char(26),char(27),char(12),char(18),char(7), -char(43),char(44),char(40),char(21),char(14),char(31),char(22),char(3),char(17),char(18), -char(5),char(9),char(9),char(13),char(64),char(9),char(15),char(72),char(13),char(7), -char(3),char(11),char(35),char(27),char(18),char(15),char(17),char(21),char(0),char(63), -char(63),char(51),char(51),char(222),char(50),char(50),char(205),char(43),char(50),char(17), -char(51),char(17),char(18),char(23),char(57),char(63),char(17),char(18),char(1),char(23), -char(57),char(49),char(48),char(1),char(21),char(7),char(35),char(39),char(35),char(7), -char(35),char(39),char(35),char(7),char(35),char(39),char(53),char(1),char(7),char(3), -char(35),char(1),char(51),char(19),char(22),char(23),char(51),char(54),char(54),char(19), -char(3),char(51),char(0),char(22),char(23),char(51),char(54),char(18),char(17),char(51), -char(16),char(2),char(7),char(35),char(3),char(38),char(4),char(182),char(82),char(30), -char(50),char(188),char(49),char(31),char(49),char(188),char(50),char(30),char(80),char(1), -char(172),char(39),char(170),char(213),char(254),char(127),char(172),char(246),char(39),char(41), -char(8),char(12),char(35),char(186),char(172),char(178),char(1),char(9),char(45),char(10), -char(8),char(173),char(153),char(166),char(195),char(219),char(182),char(125),char(33),char(5), -char(164),char(27),char(172),char(103),char(103),char(103),char(103),char(172),char(27),char(252), -char(37),char(95),char(254),char(150),char(4),char(72),char(253),char(73),char(111),char(171), -char(35),char(81),char(1),char(136),char(1),char(213),char(252),char(255),char(144),char(44), -char(184),char(1),char(179),char(1),char(82),char(254),char(150),char(254),char(7),char(229), -char(1),char(90),char(92),char(0),char(0),char(1),char(0),char(125),char(254),char(20), -char(4),char(227),char(5),char(203),char(0),char(23),char(0),char(45),char(64),char(24), -char(3),char(15),char(9),char(10),char(21),char(10),char(15),char(3),char(24),char(25), -char(19),char(0),char(73),char(89),char(19),char(4),char(12),char(6),char(73),char(89), -char(12),char(19),char(10),char(27),char(0),char(63),char(63),char(43),char(0),char(24), -char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(34),char(0),char(17),char(16),char(0),char(33), -char(50),char(55),char(17),char(35),char(17),char(35),char(32),char(0),char(17),char(52), -char(18),char(36),char(51),char(50),char(23),char(7),char(38),char(3),char(72),char(245), -char(254),char(224),char(1),char(10),char(1),char(2),char(111),char(57),char(170),char(20), -char(254),char(181),char(254),char(159),char(175),char(1),char(72),char(216),char(237),char(170), -char(71),char(171),char(5),char(51),char(254),char(192),char(254),char(232),char(254),char(218), -char(254),char(212),char(23),char(253),char(116),char(1),char(216),char(1),char(132),char(1), -char(109),char(224),char(1),char(86),char(184),char(84),char(146),char(78),char(0),char(1), -char(0),char(115),char(254),char(20),char(3),char(162),char(4),char(92),char(0),char(24), -char(0),char(47),char(64),char(24),char(15),char(3),char(23),char(22),char(9),char(22), -char(3),char(3),char(25),char(26),char(23),char(27),char(6),char(12),char(70),char(89), -char(6),char(16),char(0),char(18),char(70),char(89),char(0),char(22),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(0),char(24),char(63),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(5), -char(34),char(0),char(17),char(16),char(0),char(51),char(50),char(22),char(23),char(7), -char(38),char(35),char(34),char(6),char(21),char(20),char(22),char(51),char(50),char(54), -char(55),char(17),char(35),char(17),char(2),char(117),char(254),char(254),char(252),char(1), -char(17),char(251),char(79),char(164),char(48),char(49),char(142),char(104),char(177),char(171), -char(171),char(171),char(53),char(80),char(57),char(166),char(20),char(1),char(31),char(1), -char(18),char(1),char(20),char(1),char(43),char(34),char(23),char(141),char(51),char(205), -char(221),char(220),char(200),char(17),char(26),char(253),char(110),char(1),char(216),char(0), -char(0),char(1),char(0),char(106),char(255),char(252),char(4),char(117),char(5),char(6), -char(0),char(19),char(0),char(47),char(64),char(33),char(4),char(2),char(8),char(3), -char(6),char(0),char(17),char(7),char(10),char(16),char(13),char(18),char(12),char(14), -char(14),char(21),char(20),char(19),char(0),char(3),char(17),char(6),char(15),char(5), -char(16),char(7),char(13),char(10),char(9),char(12),char(11),char(1),char(18),char(0), -char(63),char(205),char(23),char(57),char(17),char(18),char(1),char(23),char(57),char(49), -char(48),char(1),char(3),char(39),char(19),char(37),char(55),char(5),char(19),char(37), -char(55),char(5),char(19),char(23),char(3),char(5),char(7),char(37),char(3),char(5), -char(7),char(2),char(2),char(182),char(121),char(182),char(254),char(225),char(66),char(1), -char(33),char(205),char(254),char(223),char(67),char(1),char(33),char(185),char(118),char(184), -char(1),char(33),char(68),char(254),char(225),char(204),char(1),char(30),char(65),char(1), -char(57),char(254),char(195),char(67),char(1),char(66),char(166),char(115),char(168),char(1), -char(100),char(166),char(117),char(168),char(1),char(61),char(67),char(254),char(192),char(166), -char(115),char(166),char(254),char(158),char(168),char(115),char(0),char(1),char(0),char(203), -char(4),char(145),char(3),char(172),char(5),char(180),char(0),char(19),char(0),char(30), -char(64),char(12),char(0),char(6),char(10),char(16),char(6),char(16),char(20),char(21), -char(3),char(0),char(13),char(9),char(0),char(47),char(51),char(51),char(50),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(6),char(6),char(35),char(34),char(38),char(53),char(52),char(54),char(51), -char(33),char(54),char(54),char(51),char(50),char(22),char(21),char(20),char(6),char(35), -char(1),char(135),char(6),char(42),char(48),char(51),char(41),char(42),char(54),char(1), -char(193),char(6),char(43),char(47),char(51),char(45),char(44),char(54),char(4),char(240), -char(45),char(50),char(50),char(53),char(53),char(41),char(46),char(48),char(49),char(51), -char(56),char(40),char(0),char(1),char(0),char(248),char(4),char(229),char(3),char(219), -char(5),char(215),char(0),char(19),char(0),char(28),char(64),char(11),char(7),char(18), -char(21),char(20),char(0),char(18),char(18),char(12),char(4),char(128),char(9),char(0), -char(47),char(26),char(204),char(50),char(51),char(17),char(51),char(17),char(18),char(1), -char(57),char(57),char(49),char(48),char(1),char(50),char(55),char(54),char(51),char(50), -char(22),char(21),char(21),char(35),char(53),char(52),char(35),char(34),char(14),char(2), -char(35),char(35),char(53),char(1),char(4),char(120),char(150),char(149),char(81),char(111), -char(116),char(125),char(106),char(43),char(102),char(121),char(142),char(84),char(16),char(5), -char(98),char(59),char(58),char(111),char(100),char(31),char(17),char(102),char(36),char(43), -char(36),char(121),char(0),char(1),char(1),char(223),char(4),char(215),char(2),char(205), -char(6),char(53),char(0),char(14),char(0),char(24),char(64),char(10),char(10),char(0), -char(12),char(5),char(0),char(3),char(15),char(16),char(3),char(13),char(0),char(47), -char(204),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48), -char(1),char(52),char(54),char(51),char(50),char(21),char(20),char(14),char(2),char(21), -char(20),char(23),char(21),char(38),char(1),char(223),char(67),char(56),char(92),char(30), -char(36),char(30),char(119),char(238),char(5),char(184),char(56),char(69),char(76),char(27), -char(25),char(16),char(18),char(20),char(54),char(40),char(74),char(64),char(0),char(1), -char(1),char(225),char(4),char(215),char(2),char(207),char(6),char(53),char(0),char(14), -char(0),char(24),char(64),char(10),char(5),char(0),char(0),char(10),char(2),char(3), -char(15),char(16),char(12),char(2),char(0),char(47),char(204),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(20),char(7),char(53), -char(54),char(53),char(52),char(46),char(2),char(53),char(52),char(51),char(50),char(22), -char(2),char(207),char(238),char(119),char(30),char(36),char(30),char(92),char(56),char(67), -char(5),char(184),char(161),char(64),char(74),char(40),char(54),char(20),char(18),char(16), -char(25),char(27),char(76),char(69),char(0),char(8),char(0),char(41),char(254),char(193), -char(7),char(193),char(5),char(145),char(0),char(12),char(0),char(26),char(0),char(40), -char(0),char(54),char(0),char(68),char(0),char(82),char(0),char(95),char(0),char(109), -char(0),char(128),char(64),char(73),char(95),char(40),char(68),char(90),char(34),char(62), -char(12),char(26),char(7),char(20),char(82),char(54),char(109),char(76),char(48),char(103), -char(16),char(110),char(111),char(0),char(7),char(58),char(72),char(72),char(65),char(79), -char(69),char(68),char(62),char(76),char(86),char(99),char(99),char(92),char(106),char(102), -char(95),char(90),char(109),char(30),char(44),char(44),char(37),char(51),char(47),char(34), -char(40),char(3),char(54),char(16),char(23),char(7),char(79),char(76),char(106),char(109), -char(51),char(54),char(23),char(23),char(54),char(51),char(109),char(106),char(76),char(79), -char(7),char(8),char(9),char(13),char(20),char(3),char(9),char(0),char(47),char(51), -char(47),char(51),char(18),char(23),char(57),char(47),char(47),char(47),char(47),char(47), -char(47),char(47),char(47),char(17),char(51),char(17),char(23),char(51),char(17),char(51), -char(51),char(17),char(51),char(17),char(51),char(51),char(51),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(51),char(51),char(17),char(51),char(51),char(17), -char(51),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(49),char(48), -char(1),char(38),char(38),char(35),char(34),char(6),char(7),char(35),char(54),char(51), -char(50),char(22),char(23),char(3),char(38),char(38),char(35),char(34),char(6),char(7), -char(35),char(54),char(54),char(51),char(50),char(22),char(23),char(1),char(38),char(38), -char(35),char(34),char(6),char(7),char(35),char(54),char(54),char(51),char(50),char(22), -char(23),char(33),char(38),char(38),char(35),char(34),char(6),char(7),char(35),char(54), -char(54),char(51),char(50),char(22),char(23),char(1),char(38),char(38),char(35),char(34), -char(6),char(7),char(35),char(54),char(54),char(51),char(50),char(22),char(23),char(33), -char(38),char(38),char(35),char(34),char(6),char(7),char(35),char(54),char(54),char(51), -char(50),char(22),char(23),char(1),char(38),char(38),char(35),char(34),char(6),char(7), -char(35),char(54),char(51),char(50),char(22),char(23),char(33),char(38),char(38),char(35), -char(34),char(6),char(7),char(35),char(54),char(54),char(51),char(50),char(22),char(23), -char(4),char(111),char(5),char(60),char(69),char(78),char(50),char(5),char(75),char(11), -char(197),char(93),char(113),char(7),char(79),char(5),char(60),char(69),char(78),char(50), -char(5),char(75),char(5),char(100),char(103),char(92),char(115),char(6),char(1),char(244), -char(5),char(60),char(68),char(78),char(50),char(5),char(76),char(5),char(101),char(103), -char(92),char(115),char(6),char(251),char(47),char(5),char(60),char(68),char(78),char(50), -char(5),char(76),char(5),char(101),char(103),char(92),char(115),char(6),char(4),char(49), -char(5),char(60),char(68),char(78),char(50),char(5),char(76),char(5),char(101),char(103), -char(92),char(115),char(6),char(251),char(47),char(5),char(60),char(68),char(78),char(50), -char(5),char(76),char(5),char(101),char(103),char(92),char(115),char(6),char(4),char(240), -char(5),char(60),char(68),char(78),char(51),char(5),char(75),char(11),char(198),char(92), -char(115),char(6),char(249),char(190),char(5),char(60),char(68),char(78),char(50),char(5), -char(76),char(5),char(101),char(103),char(92),char(115),char(6),char(4),char(207),char(44), -char(44),char(41),char(47),char(194),char(101),char(93),char(249),char(242),char(44),char(44), -char(41),char(47),char(89),char(105),char(102),char(92),char(1),char(22),char(45),char(43), -char(39),char(49),char(90),char(105),char(102),char(93),char(45),char(43),char(39),char(49), -char(90),char(105),char(102),char(93),char(3),char(219),char(45),char(43),char(39),char(49), -char(90),char(105),char(102),char(93),char(45),char(43),char(39),char(49),char(90),char(105), -char(102),char(93),char(254),char(25),char(44),char(44),char(40),char(48),char(194),char(104), -char(90),char(45),char(43),char(39),char(49),char(90),char(104),char(102),char(92),char(0), -char(0),char(8),char(0),char(41),char(254),char(127),char(7),char(125),char(5),char(211), -char(0),char(7),char(0),char(15),char(0),char(23),char(0),char(31),char(0),char(39), -char(0),char(46),char(0),char(53),char(0),char(62),char(0),char(52),char(64),char(37), -char(21),char(23),char(37),char(32),char(62),char(58),char(5),char(1),char(41),char(44), -char(31),char(28),char(50),char(53),char(9),char(13),char(16),char(63),char(64),char(59), -char(43),char(7),char(46),char(54),char(25),char(21),char(29),char(17),char(47),char(39), -char(15),char(36),char(51),char(14),char(5),char(12),char(5),char(0),char(47),char(47), -char(18),char(23),char(57),char(17),char(18),char(1),char(23),char(57),char(49),char(48), -char(5),char(23),char(6),char(6),char(7),char(35),char(54),char(55),char(3),char(39), -char(54),char(54),char(55),char(51),char(6),char(7),char(1),char(55),char(22),char(22), -char(23),char(21),char(38),char(39),char(5),char(7),char(38),char(38),char(39),char(53), -char(22),char(23),char(1),char(55),char(54),char(54),char(55),char(23),char(6),char(7), -char(1),char(7),char(6),char(7),char(39),char(54),char(55),char(3),char(39),char(38), -char(39),char(55),char(22),char(23),char(1),char(23),char(22),char(22),char(23),char(7), -char(38),char(38),char(39),char(4),char(55),char(11),char(17),char(70),char(36),char(97), -char(53),char(17),char(59),char(11),char(19),char(73),char(31),char(97),char(52),char(18), -char(2),char(35),char(14),char(71),char(200),char(65),char(221),char(129),char(251),char(104), -char(14),char(66),char(191),char(79),char(221),char(129),char(3),char(166),char(2),char(67), -char(190),char(67),char(69),char(177),char(120),char(252),char(234),char(2),char(155),char(169), -char(69),char(177),char(120),char(43),char(17),char(82),char(69),char(67),char(123),char(76), -char(3),char(106),char(17),char(39),char(90),char(22),char(67),char(31),char(130),char(38), -char(35),char(14),char(66),char(191),char(79),char(221),char(129),char(4),char(152),char(14), -char(71),char(200),char(65),char(220),char(130),char(254),char(22),char(11),char(19),char(73), -char(31),char(97),char(53),char(17),char(59),char(11),char(17),char(70),char(36),char(97), -char(53),char(17),char(1),char(170),char(16),char(39),char(88),char(25),char(68),char(110), -char(88),char(252),char(149),char(16),char(89),char(63),char(68),char(110),char(88),char(2), -char(222),char(2),char(140),char(183),char(70),char(198),char(99),char(252),char(233),char(2), -char(69),char(194),char(60),char(70),char(50),char(195),char(52),char(0),char(0),char(2), -char(0),char(201),char(254),char(131),char(6),char(8),char(7),char(94),char(0),char(20), -char(0),char(34),char(0),char(89),char(64),char(47),char(13),char(10),char(12),char(7), -char(14),char(14),char(9),char(19),char(2),char(2),char(20),char(20),char(24),char(32), -char(9),char(10),char(5),char(36),char(35),char(20),char(18),char(6),char(5),char(17), -char(18),char(5),char(18),char(14),char(0),char(14),char(9),char(73),char(89),char(14), -char(18),char(12),char(34),char(31),char(15),char(24),char(1),char(24),char(28),char(21), -char(7),char(0),char(3),char(0),char(63),char(50),char(222),char(50),char(205),char(93), -char(50),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(17), -char(51),char(17),char(51),char(24),char(63),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(19),char(51),char(17),char(20),char(7),char(7),char(51), -char(1),char(51),char(17),char(51),char(3),char(35),char(19),char(35),char(17),char(52), -char(55),char(35),char(1),char(35),char(1),char(34),char(38),char(39),char(51),char(22), -char(22),char(51),char(50),char(54),char(55),char(51),char(6),char(6),char(201),char(161), -char(10),char(4),char(8),char(3),char(52),char(184),char(184),char(143),char(197),char(156), -char(160),char(19),char(9),char(252),char(201),char(186),char(2),char(67),char(186),char(168), -char(10),char(155),char(10),char(93),char(110),char(105),char(99),char(9),char(158),char(12), -char(181),char(5),char(182),char(252),char(209),char(118),char(206),char(83),char(4),char(198), -char(250),char(226),char(253),char(235),char(1),char(125),char(3),char(37),char(175),char(247), -char(251),char(53),char(6),char(43),char(143),char(164),char(108),char(78),char(93),char(93), -char(159),char(148),char(0),char(2),char(0),char(176),char(254),char(135),char(5),char(18), -char(6),char(12),char(0),char(17),char(0),char(31),char(0),char(79),char(64),char(42), -char(10),char(7),char(9),char(4),char(11),char(11),char(6),char(15),char(1),char(1), -char(16),char(16),char(21),char(29),char(6),char(7),char(5),char(33),char(32),char(3), -char(14),char(16),char(17),char(15),char(11),char(6),char(70),char(89),char(11),char(16), -char(21),char(9),char(34),char(28),char(15),char(21),char(1),char(21),char(25),char(18), -char(4),char(15),char(0),char(63),char(222),char(50),char(205),char(93),char(50),char(63), -char(63),char(51),char(43),char(0),char(24),char(63),char(18),char(57),char(57),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51), -char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(20), -char(7),char(1),char(51),char(17),char(51),char(3),char(35),char(19),char(35),char(17), -char(52),char(55),char(1),char(35),char(17),char(37),char(34),char(38),char(39),char(51), -char(22),char(22),char(51),char(50),char(54),char(55),char(51),char(6),char(6),char(1), -char(76),char(10),char(2),char(81),char(207),char(176),char(129),char(172),char(125),char(155), -char(8),char(253),char(174),char(205),char(1),char(236),char(185),char(170),char(10),char(156), -char(7),char(90),char(116),char(103),char(100),char(10),char(157),char(12),char(178),char(4), -char(72),char(253),char(106),char(136),char(136),char(3),char(166),char(252),char(71),char(253), -char(248),char(1),char(121),char(2),char(160),char(158),char(104),char(252),char(90),char(4), -char(72),char(145),char(143),char(164),char(102),char(84),char(90),char(96),char(158),char(149), -char(0),char(2),char(0),char(47),char(0),char(0),char(4),char(125),char(5),char(182), -char(0),char(17),char(0),char(25),char(0),char(77),char(64),char(41),char(8),char(4), -char(18),char(18),char(1),char(15),char(21),char(11),char(11),char(6),char(15),char(17), -char(4),char(26),char(27),char(8),char(25),char(73),char(89),char(7),char(17),char(0), -char(17),char(73),char(89),char(4),char(0),char(8),char(0),char(8),char(0),char(15), -char(2),char(15),char(18),char(74),char(89),char(15),char(18),char(2),char(3),char(0), -char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(24),char(47), -char(47),char(17),char(51),char(43),char(17),char(0),char(51),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51), -char(51),char(49),char(48),char(19),char(51),char(53),char(51),char(21),char(33),char(21), -char(33),char(17),char(51),char(32),char(17),char(20),char(4),char(33),char(33),char(17), -char(35),char(1),char(51),char(32),char(17),char(52),char(38),char(35),char(35),char(47), -char(154),char(170),char(1),char(86),char(254),char(170),char(192),char(2),char(74),char(254), -char(236),char(254),char(241),char(254),char(111),char(154),char(1),char(68),char(221),char(1), -char(123),char(184),char(201),char(215),char(4),char(252),char(186),char(186),char(150),char(254), -char(224),char(254),char(100),char(210),char(216),char(4),char(102),char(252),char(43),char(1), -char(25),char(132),char(128),char(0),char(0),char(2),char(0),char(20),char(0),char(0), -char(4),char(76),char(6),char(20),char(0),char(18),char(0),char(26),char(0),char(75), -char(64),char(40),char(4),char(0),char(20),char(20),char(16),char(12),char(23),char(8), -char(8),char(2),char(12),char(14),char(4),char(27),char(28),char(4),char(19),char(70), -char(89),char(3),char(14),char(15),char(14),char(71),char(89),char(0),char(15),char(4), -char(15),char(4),char(15),char(12),char(17),char(0),char(12),char(20),char(70),char(89), -char(12),char(21),char(0),char(63),char(43),char(0),char(24),char(63),char(18),char(57), -char(57),char(47),char(47),char(17),char(51),char(43),char(17),char(0),char(51),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51), -char(17),char(51),char(51),char(49),char(48),char(1),char(33),char(21),char(33),char(17), -char(33),char(50),char(22),char(21),char(20),char(6),char(35),char(33),char(17),char(35), -char(53),char(51),char(53),char(51),char(17),char(17),char(33),char(32),char(53),char(52), -char(38),char(35),char(1),char(86),char(1),char(39),char(254),char(217),char(1),char(64), -char(223),char(215),char(224),char(221),char(254),char(33),char(156),char(156),char(166),char(1), -char(49),char(1),char(31),char(132),char(159),char(5),char(31),char(129),char(253),char(229), -char(154),char(155),char(164),char(170),char(4),char(158),char(129),char(245),char(251),char(224), -char(254),char(151),char(185),char(92),char(84),char(0),char(0),char(2),char(0),char(201), -char(0),char(0),char(4),char(121),char(5),char(182),char(0),char(15),char(0),char(28), -char(0),char(72),char(64),char(41),char(16),char(10),char(10),char(11),char(24),char(0), -char(0),char(4),char(5),char(3),char(22),char(6),char(21),char(19),char(20),char(11), -char(10),char(29),char(30),char(22),char(19),char(28),char(16),char(12),char(28),char(74), -char(89),char(9),char(16),char(74),char(89),char(6),char(3),char(12),char(9),char(9), -char(11),char(12),char(3),char(11),char(18),char(0),char(63),char(63),char(18),char(57), -char(47),char(18),char(57),char(57),char(43),char(43),char(17),char(18),char(0),char(57), -char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(20),char(6),char(7),char(23),char(7), -char(39),char(6),char(35),char(35),char(17),char(35),char(17),char(33),char(32),char(4), -char(1),char(51),char(50),char(55),char(39),char(55),char(23),char(54),char(53),char(52), -char(38),char(35),char(35),char(4),char(121),char(115),char(108),char(120),char(100),char(149), -char(102),char(136),char(184),char(170),char(1),char(137),char(1),char(18),char(1),char(21), -char(252),char(250),char(166),char(87),char(76),char(108),char(108),char(140),char(127),char(194), -char(202),char(200),char(4),char(12),char(127),char(201),char(57),char(157),char(84),char(192), -char(27),char(253),char(193),char(5),char(182),char(215),char(253),char(242),char(10),char(141), -char(82),char(176),char(72),char(178),char(145),char(142),char(0),char(2),char(0),char(176), -char(254),char(20),char(4),char(117),char(4),char(92),char(0),char(24),char(0),char(41), -char(0),char(85),char(64),char(49),char(29),char(11),char(4),char(7),char(7),char(8), -char(39),char(18),char(18),char(21),char(22),char(20),char(37),char(23),char(34),char(36), -char(35),char(8),char(10),char(42),char(43),char(37),char(34),char(25),char(32),char(15), -char(25),char(70),char(89),char(12),char(11),char(11),char(4),char(20),char(23),char(4), -char(0),char(15),char(16),char(9),char(15),char(8),char(27),char(0),char(32),char(70), -char(89),char(0),char(22),char(0),char(63),char(43),char(0),char(24),char(63),char(63), -char(63),char(18),char(23),char(57),char(17),char(51),char(43),char(17),char(18),char(0), -char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(51),char(51),char(49),char(48),char(5),char(34),char(38), -char(39),char(35),char(22),char(21),char(17),char(35),char(17),char(51),char(23),char(51), -char(54),char(54),char(51),char(50),char(18),char(17),char(16),char(7),char(23),char(7), -char(39),char(6),char(3),char(34),char(6),char(7),char(21),char(20),char(22),char(51), -char(50),char(55),char(39),char(55),char(23),char(54),char(53),char(52),char(38),char(2), -char(174),char(107),char(177),char(60),char(12),char(12),char(166),char(135),char(25),char(8), -char(64),char(169),char(109),char(218),char(237),char(183),char(115),char(100),char(131),char(71), -char(109),char(168),char(150),char(2),char(154),char(170),char(47),char(41),char(121),char(106), -char(129),char(101),char(150),char(20),char(79),char(82),char(148),char(34),char(254),char(61), -char(6),char(52),char(150),char(90),char(80),char(254),char(214),char(254),char(243),char(254), -char(174),char(145),char(156),char(80),char(174),char(24),char(3),char(227),char(186),char(203), -char(37),char(231),char(199),char(12),char(158),char(80),char(170),char(103),char(249),char(215), -char(209),char(0),char(0),char(1),char(0),char(47),char(0),char(0),char(4),char(8), -char(5),char(182),char(0),char(13),char(0),char(60),char(64),char(31),char(3),char(7), -char(7),char(12),char(8),char(0),char(5),char(8),char(10),char(4),char(14),char(15), -char(6),char(10),char(11),char(10),char(73),char(89),char(3),char(11),char(11),char(8), -char(13),char(13),char(2),char(73),char(89),char(13),char(3),char(8),char(18),char(0), -char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(51), -char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(21),char(33),char(17), -char(33),char(21),char(33),char(17),char(35),char(17),char(35),char(53),char(51),char(17), -char(4),char(8),char(253),char(107),char(1),char(168),char(254),char(88),char(170),char(154), -char(154),char(5),char(182),char(153),char(254),char(2),char(150),char(253),char(119),char(2), -char(137),char(150),char(2),char(151),char(0),char(1),char(0),char(18),char(0),char(0), -char(3),char(66),char(4),char(72),char(0),char(13),char(0),char(60),char(64),char(31), -char(2),char(6),char(6),char(11),char(7),char(0),char(4),char(7),char(9),char(4), -char(14),char(15),char(5),char(9),char(10),char(9),char(71),char(89),char(2),char(10), -char(10),char(7),char(12),char(12),char(1),char(70),char(89),char(12),char(15),char(7), -char(21),char(0),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(33), -char(17),char(33),char(21),char(33),char(17),char(35),char(17),char(35),char(53),char(51), -char(17),char(33),char(3),char(66),char(254),char(20),char(1),char(90),char(254),char(166), -char(166),char(158),char(158),char(2),char(146),char(3),char(188),char(254),char(168),char(127), -char(254),char(27),char(1),char(229),char(127),char(1),char(228),char(0),char(0),char(1), -char(0),char(201),char(254),char(0),char(4),char(219),char(5),char(182),char(0),char(27), -char(0),char(65),char(64),char(35),char(9),char(3),char(3),char(4),char(25),char(14), -char(14),char(7),char(20),char(4),char(4),char(28),char(29),char(17),char(23),char(73), -char(89),char(17),char(28),char(11),char(0),char(73),char(89),char(11),char(11),char(4), -char(5),char(5),char(8),char(73),char(89),char(5),char(3),char(4),char(18),char(0), -char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(34),char(7), -char(17),char(35),char(17),char(33),char(21),char(33),char(17),char(54),char(51),char(32), -char(0),char(17),char(16),char(0),char(33),char(34),char(38),char(39),char(53),char(22), -char(51),char(32),char(17),char(52),char(0),char(2),char(49),char(100),char(90),char(170), -char(3),char(73),char(253),char(97),char(90),char(121),char(1),char(64),char(1),char(85), -char(254),char(226),char(254),char(253),char(83),char(125),char(70),char(123),char(137),char(1), -char(127),char(255),char(0),char(2),char(143),char(12),char(253),char(125),char(5),char(182), -char(153),char(253),char(252),char(10),char(254),char(173),char(254),char(198),char(254),char(197), -char(254),char(165),char(21),char(28),char(152),char(49),char(1),char(254),char(245),char(1), -char(4),char(0),char(0),char(1),char(0),char(176),char(254),char(10),char(3),char(250), -char(4),char(72),char(0),char(27),char(0),char(65),char(64),char(35),char(8),char(25), -char(20),char(14),char(14),char(15),char(15),char(2),char(18),char(25),char(4),char(29), -char(28),char(22),char(11),char(70),char(89),char(22),char(22),char(15),char(16),char(16), -char(19),char(70),char(89),char(16),char(15),char(15),char(21),char(0),char(5),char(70), -char(89),char(0),char(27),char(0),char(63),char(43),char(0),char(24),char(63),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(1),char(34),char(39),char(53),char(22),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(34),char(7),char(17),char(35),char(17),char(33),char(21), -char(33),char(17),char(54),char(51),char(32),char(0),char(17),char(16),char(2),char(2), -char(70),char(145),char(101),char(116),char(123),char(133),char(136),char(178),char(181),char(69), -char(74),char(166),char(2),char(154),char(254),char(12),char(82),char(59),char(1),char(16), -char(1),char(7),char(228),char(254),char(10),char(60),char(149),char(63),char(202),char(215), -char(223),char(208),char(17),char(254),char(37),char(4),char(72),char(142),char(254),char(183), -char(12),char(254),char(229),char(254),char(217),char(254),char(245),char(254),char(218),char(0), -char(0),char(1),char(0),char(2),char(254),char(131),char(6),char(248),char(5),char(182), -char(0),char(21),char(0),char(77),char(64),char(41),char(6),char(17),char(17),char(3), -char(18),char(13),char(12),char(12),char(8),char(9),char(18),char(0),char(1),char(21), -char(7),char(22),char(23),char(18),char(21),char(18),char(19),char(16),char(9),char(6), -char(3),char(0),char(0),char(15),char(1),char(15),char(10),char(73),char(89),char(15), -char(18),char(13),char(34),char(7),char(4),char(1),char(3),char(0),char(63),char(51), -char(51),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(17),char(51), -char(51),char(51),char(51),char(51),char(24),char(63),char(51),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(49), -char(48),char(1),char(1),char(51),char(1),char(17),char(51),char(17),char(1),char(51), -char(1),char(1),char(51),char(17),char(35),char(17),char(35),char(1),char(17),char(35), -char(17),char(1),char(35),char(2),char(86),char(253),char(193),char(190),char(2),char(57), -char(164),char(2),char(58),char(190),char(253),char(192),char(1),char(218),char(180),char(162), -char(94),char(253),char(186),char(164),char(253),char(187),char(199),char(2),char(240),char(2), -char(198),char(253),char(60),char(2),char(196),char(253),char(60),char(2),char(196),char(253), -char(60),char(253),char(168),char(253),char(233),char(1),char(125),char(2),char(229),char(253), -char(27),char(2),char(229),char(253),char(27),char(0),char(0),char(1),char(0),char(4), -char(254),char(135),char(6),char(31),char(4),char(72),char(0),char(21),char(0),char(75), -char(64),char(40),char(2),char(13),char(13),char(21),char(14),char(9),char(8),char(8), -char(4),char(5),char(14),char(18),char(19),char(17),char(7),char(22),char(23),char(21), -char(15),char(12),char(5),char(2),char(18),char(18),char(11),char(3),char(0),char(19), -char(15),char(14),char(17),char(21),char(11),char(6),char(70),char(89),char(11),char(21), -char(9),char(34),char(0),char(63),char(63),char(43),char(0),char(24),char(63),char(51), -char(63),char(51),char(51),char(18),char(57),char(17),char(51),char(51),char(51),char(51), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(49),char(48),char(1),char(51),char(17),char(1),char(51), -char(1),char(1),char(51),char(17),char(35),char(17),char(35),char(1),char(17),char(35), -char(17),char(1),char(35),char(1),char(1),char(51),char(1),char(2),char(164),char(153), -char(1),char(197),char(182),char(254),char(54),char(1),char(112),char(193),char(162),char(94), -char(254),char(30),char(153),char(254),char(31),char(191),char(1),char(240),char(254),char(55), -char(182),char(1),char(195),char(4),char(72),char(253),char(237),char(2),char(19),char(253), -char(237),char(254),char(90),char(253),char(248),char(1),char(121),char(2),char(45),char(253), -char(211),char(2),char(45),char(253),char(211),char(2),char(53),char(2),char(19),char(253), -char(237),char(0),char(255),char(255),char(0),char(74),char(254),char(66),char(4),char(53), -char(5),char(203),char(2),char(38),char(1),char(177),char(0),char(0),char(0),char(7), -char(3),char(127),char(1),char(88),char(0),char(0),char(255),char(255),char(0),char(68), -char(254),char(66),char(3),char(127),char(4),char(92),char(2),char(38),char(1),char(209), -char(0),char(0),char(0),char(7),char(3),char(127),char(1),char(8),char(0),char(0), -char(0),char(1),char(0),char(201),char(254),char(131),char(5),char(43),char(5),char(182), -char(0),char(15),char(0),char(59),char(64),char(32),char(12),char(8),char(8),char(9), -char(3),char(2),char(2),char(14),char(15),char(6),char(9),char(5),char(16),char(17), -char(15),char(12),char(6),char(3),char(5),char(13),char(10),char(3),char(9),char(18), -char(5),char(0),char(73),char(89),char(5),char(18),char(3),char(34),char(0),char(63), -char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(23),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(37),char(51),char(17),char(35),char(17),char(35),char(1), -char(7),char(17),char(35),char(17),char(51),char(17),char(1),char(51),char(1),char(4), -char(127),char(172),char(162),char(102),char(253),char(233),char(153),char(170),char(170),char(2), -char(151),char(201),char(253),char(180),char(154),char(253),char(233),char(1),char(125),char(2), -char(197),char(136),char(253),char(195),char(5),char(182),char(253),char(43),char(2),char(213), -char(253),char(133),char(0),char(1),char(0),char(176),char(254),char(133),char(4),char(61), -char(4),char(72),char(0),char(14),char(0),char(58),char(64),char(31),char(14),char(10), -char(10),char(11),char(6),char(5),char(5),char(1),char(2),char(11),char(4),char(15), -char(16),char(2),char(14),char(9),char(3),char(8),char(0),char(12),char(15),char(11), -char(21),char(8),char(3),char(70),char(89),char(8),char(21),char(6),char(34),char(0), -char(63),char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(23), -char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(51),char(1),char(1),char(51),char(17), -char(35),char(17),char(35),char(1),char(17),char(35),char(17),char(51),char(17),char(3), -char(47),char(182),char(254),char(39),char(1),char(127),char(178),char(159),char(84),char(254), -char(12),char(166),char(166),char(4),char(72),char(253),char(239),char(254),char(88),char(253), -char(246),char(1),char(123),char(2),char(43),char(253),char(213),char(4),char(72),char(253), -char(235),char(0),char(0),char(1),char(0),char(201),char(0),char(0),char(4),char(233), -char(5),char(182),char(0),char(18),char(0),char(56),char(64),char(30),char(6),char(2), -char(2),char(3),char(10),char(17),char(17),char(7),char(18),char(14),char(12),char(18), -char(3),char(4),char(19),char(20),char(8),char(10),char(6),char(0),char(16),char(18), -char(6),char(3),char(11),char(4),char(3),char(15),char(3),char(18),char(0),char(63), -char(51),char(63),char(51),char(18),char(23),char(57),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(7),char(17),char(35),char(17),char(51),char(17),char(55), -char(17),char(51),char(21),char(1),char(51),char(1),char(1),char(35),char(1),char(17), -char(35),char(1),char(240),char(125),char(170),char(170),char(125),char(125),char(1),char(155), -char(203),char(253),char(180),char(2),char(98),char(200),char(254),char(76),char(125),char(2), -char(168),char(107),char(253),char(195),char(5),char(182),char(253),char(37),char(139),char(1), -char(93),char(211),char(1),char(198),char(253),char(133),char(252),char(197),char(2),char(92), -char(254),char(207),char(0),char(1),char(0),char(176),char(0),char(0),char(4),char(59), -char(4),char(72),char(0),char(19),char(0),char(58),char(64),char(31),char(6),char(2), -char(2),char(3),char(14),char(10),char(18),char(18),char(7),char(19),char(15),char(12), -char(19),char(3),char(4),char(20),char(21),char(8),char(10),char(6),char(1),char(17), -char(19),char(6),char(3),char(11),char(4),char(15),char(16),char(3),char(21),char(0), -char(63),char(51),char(63),char(51),char(18),char(23),char(57),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(51),char(17),char(51),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(39),char(17),char(35),char(17),char(51), -char(17),char(55),char(17),char(51),char(21),char(1),char(51),char(1),char(21),char(1), -char(35),char(1),char(21),char(35),char(1),char(205),char(119),char(166),char(166),char(119), -char(131),char(1),char(14),char(182),char(254),char(60),char(1),char(235),char(194),char(254), -char(213),char(129),char(1),char(178),char(121),char(253),char(213),char(4),char(72),char(253), -char(235),char(121),char(1),char(74),char(205),char(1),char(31),char(254),char(37),char(107), -char(253),char(254),char(1),char(59),char(221),char(0),char(0),char(1),char(0),char(47), -char(0),char(0),char(4),char(233),char(5),char(182),char(0),char(19),char(0),char(71), -char(64),char(38),char(8),char(4),char(16),char(16),char(1),char(17),char(11),char(14), -char(12),char(10),char(6),char(14),char(17),char(19),char(6),char(20),char(21),char(7), -char(19),char(0),char(19),char(73),char(89),char(4),char(11),char(8),char(14),char(3), -char(17),char(0),char(0),char(2),char(13),char(17),char(18),char(9),char(2),char(3), -char(0),char(63),char(51),char(63),char(51),char(18),char(57),char(47),char(18),char(23), -char(57),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(51),char(17),char(51),char(51),char(49), -char(48),char(19),char(51),char(53),char(51),char(21),char(51),char(21),char(35),char(17), -char(1),char(51),char(1),char(1),char(35),char(1),char(7),char(17),char(35),char(17), -char(35),char(47),char(154),char(170),char(221),char(221),char(2),char(149),char(203),char(253), -char(180),char(2),char(98),char(206),char(253),char(241),char(153),char(170),char(154),char(5), -char(4),char(178),char(178),char(151),char(254),char(110),char(2),char(219),char(253),char(133), -char(252),char(197),char(2),char(197),char(134),char(253),char(193),char(4),char(109),char(0), -char(0),char(1),char(0),char(20),char(0),char(0),char(4),char(27),char(6),char(20), -char(0),char(25),char(0),char(77),char(64),char(43),char(10),char(8),char(4),char(22), -char(22),char(1),char(23),char(18),char(16),char(6),char(17),char(23),char(25),char(6), -char(26),char(27),char(20),char(10),char(15),char(19),char(23),char(21),char(7),char(25), -char(0),char(25),char(71),char(89),char(4),char(15),char(0),char(31),char(0),char(47), -char(0),char(3),char(0),char(0),char(2),char(15),char(15),char(2),char(0),char(0), -char(63),char(63),char(18),char(57),char(47),char(93),char(51),char(43),char(17),char(0), -char(51),char(24),char(63),char(51),char(18),char(57),char(57),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(51),char(17),char(51),char(51),char(51),char(49), -char(48),char(19),char(51),char(53),char(51),char(21),char(33),char(21),char(33),char(17), -char(7),char(7),char(51),char(55),char(54),char(54),char(1),char(51),char(1),char(1), -char(35),char(1),char(7),char(17),char(35),char(17),char(35),char(20),char(156),char(164), -char(1),char(125),char(254),char(131),char(3),char(3),char(8),char(18),char(55),char(40), -char(1),char(112),char(199),char(254),char(68),char(1),char(217),char(199),char(254),char(125), -char(125),char(164),char(156),char(5),char(90),char(186),char(186),char(127),char(253),char(232), -char(91),char(55),char(24),char(74),char(48),char(1),char(133),char(254),char(45),char(253), -char(139),char(2),char(4),char(106),char(254),char(102),char(4),char(219),char(0),char(1), -char(0),char(16),char(0),char(0),char(5),char(131),char(5),char(182),char(0),char(13), -char(0),char(53),char(64),char(27),char(2),char(10),char(10),char(11),char(5),char(8), -char(6),char(4),char(8),char(11),char(4),char(14),char(15),char(8),char(2),char(0), -char(7),char(11),char(18),char(3),char(3),char(0),char(13),char(73),char(89),char(0), -char(3),char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18), -char(57),char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(19),char(33),char(17),char(1),char(51), -char(1),char(1),char(35),char(1),char(7),char(17),char(35),char(17),char(33),char(16), -char(1),char(252),char(2),char(150),char(203),char(253),char(180),char(2),char(98),char(201), -char(253),char(236),char(154),char(170),char(254),char(174),char(5),char(182),char(253),char(37), -char(2),char(219),char(253),char(133),char(252),char(197),char(2),char(197),char(136),char(253), -char(195),char(5),char(29),char(0),char(0),char(1),char(0),char(41),char(0),char(0), -char(4),char(227),char(4),char(72),char(0),char(12),char(0),char(53),char(64),char(27), -char(5),char(1),char(1),char(9),char(9),char(10),char(12),char(10),char(4),char(6), -char(4),char(14),char(13),char(8),char(2),char(0),char(7),char(10),char(21),char(3), -char(15),char(0),char(12),char(70),char(89),char(0),char(15),char(0),char(63),char(43), -char(0),char(24),char(63),char(63),char(51),char(18),char(57),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(19),char(33),char(17),char(1),char(51),char(1),char(1),char(35),char(1), -char(17),char(35),char(17),char(33),char(41),char(2),char(2),char(1),char(219),char(182), -char(254),char(39),char(2),char(0),char(194),char(254),char(10),char(164),char(254),char(162), -char(4),char(72),char(253),char(235),char(2),char(21),char(253),char(237),char(253),char(203), -char(2),char(43),char(253),char(213),char(3),char(188),char(0),char(1),char(0),char(201), -char(254),char(131),char(5),char(193),char(5),char(182),char(0),char(15),char(0),char(68), -char(64),char(36),char(12),char(8),char(8),char(9),char(13),char(5),char(5),char(0), -char(3),char(2),char(2),char(0),char(9),char(3),char(16),char(17),char(12),char(7), -char(73),char(89),char(12),char(12),char(5),char(14),char(10),char(3),char(9),char(18), -char(5),char(0),char(73),char(89),char(5),char(18),char(3),char(34),char(0),char(63), -char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(57),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(51), -char(17),char(35),char(17),char(35),char(17),char(33),char(17),char(35),char(17),char(51), -char(17),char(33),char(17),char(51),char(5),char(31),char(162),char(162),char(170),char(252), -char(254),char(170),char(170),char(3),char(2),char(170),char(154),char(253),char(233),char(1), -char(125),char(2),char(176),char(253),char(80),char(5),char(182),char(253),char(146),char(2), -char(110),char(0),char(0),char(1),char(0),char(176),char(254),char(135),char(4),char(248), -char(4),char(72),char(0),char(15),char(0),char(78),char(64),char(43),char(1),char(13), -char(13),char(14),char(2),char(10),char(10),char(5),char(8),char(7),char(7),char(5), -char(14),char(3),char(16),char(17),char(1),char(12),char(70),char(89),char(15),char(1), -char(31),char(1),char(2),char(11),char(3),char(1),char(1),char(10),char(3),char(15), -char(15),char(14),char(21),char(10),char(5),char(70),char(89),char(10),char(21),char(8), -char(34),char(0),char(63),char(63),char(43),char(0),char(24),char(63),char(63),char(51), -char(18),char(57),char(47),char(95),char(94),char(93),char(43),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(17),char(33),char(17),char(51),char(17), -char(51),char(17),char(35),char(17),char(35),char(17),char(33),char(17),char(35),char(17), -char(1),char(86),char(2),char(102),char(166),char(150),char(166),char(150),char(253),char(154), -char(166),char(4),char(72),char(254),char(53),char(1),char(203),char(252),char(71),char(253), -char(248),char(1),char(121),char(1),char(238),char(254),char(18),char(4),char(72),char(0), -char(0),char(1),char(0),char(201),char(0),char(0),char(6),char(111),char(5),char(182), -char(0),char(13),char(0),char(63),char(64),char(33),char(10),char(6),char(6),char(7), -char(11),char(3),char(3),char(2),char(0),char(2),char(7),char(3),char(14),char(15), -char(10),char(5),char(73),char(89),char(10),char(10),char(7),char(12),char(12),char(1), -char(73),char(89),char(12),char(3),char(8),char(3),char(3),char(7),char(18),char(0), -char(63),char(51),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(17), -char(35),char(17),char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(17), -char(33),char(6),char(111),char(254),char(176),char(172),char(253),char(0),char(170),char(170), -char(3),char(0),char(1),char(252),char(5),char(29),char(250),char(227),char(2),char(176), -char(253),char(80),char(5),char(182),char(253),char(146),char(2),char(110),char(0),char(1), -char(0),char(176),char(0),char(0),char(5),char(193),char(4),char(72),char(0),char(13), -char(0),char(73),char(64),char(39),char(1),char(11),char(11),char(12),char(2),char(8), -char(8),char(7),char(4),char(7),char(12),char(3),char(14),char(15),char(13),char(15), -char(1),char(10),char(70),char(89),char(15),char(1),char(31),char(1),char(2),char(11), -char(3),char(1),char(1),char(3),char(8),char(12),char(21),char(3),char(6),char(70), -char(89),char(3),char(15),char(0),char(63),char(43),char(0),char(24),char(63),char(51), -char(18),char(57),char(47),char(95),char(94),char(93),char(43),char(0),char(24),char(63), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(33),char(17),char(33), -char(21),char(33),char(17),char(35),char(17),char(33),char(17),char(35),char(17),char(1), -char(86),char(2),char(102),char(2),char(5),char(254),char(161),char(166),char(253),char(154), -char(166),char(4),char(72),char(254),char(53),char(1),char(203),char(140),char(252),char(68), -char(1),char(238),char(254),char(18),char(4),char(72),char(0),char(1),char(0),char(201), -char(254),char(0),char(8),char(29),char(5),char(182),char(0),char(29),char(0),char(71), -char(64),char(38),char(4),char(5),char(8),char(0),char(0),char(1),char(23),char(13), -char(13),char(18),char(1),char(5),char(4),char(30),char(31),char(16),char(21),char(73), -char(89),char(16),char(28),char(10),char(26),char(73),char(89),char(10),char(10),char(5), -char(6),char(6),char(3),char(73),char(89),char(6),char(3),char(1),char(5),char(18), -char(0),char(63),char(51),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(33),char(35),char(17),char(33),char(17),char(35),char(17),char(33),char(17), -char(54),char(51),char(32),char(0),char(17),char(16),char(0),char(33),char(34),char(39), -char(53),char(22),char(51),char(32),char(17),char(52),char(2),char(35),char(34),char(6), -char(7),char(4),char(217),char(170),char(253),char(68),char(170),char(4),char(16),char(68), -char(125),char(1),char(50),char(1),char(81),char(254),char(229),char(254),char(254),char(156), -char(123),char(134),char(127),char(1),char(122),char(230),char(232),char(42),char(127),char(24), -char(5),char(29),char(250),char(227),char(5),char(182),char(253),char(97),char(12),char(254), -char(168),char(254),char(200),char(254),char(199),char(254),char(166),char(49),char(152),char(49), -char(1),char(254),char(242),char(1),char(5),char(7),char(5),char(0),char(0),char(1), -char(0),char(176),char(254),char(10),char(6),char(168),char(4),char(72),char(0),char(28), -char(0),char(71),char(64),char(38),char(17),char(18),char(21),char(13),char(13),char(14), -char(7),char(26),char(26),char(2),char(14),char(18),char(4),char(29),char(30),char(23), -char(10),char(70),char(89),char(23),char(23),char(18),char(19),char(19),char(16),char(70), -char(89),char(19),char(15),char(14),char(18),char(21),char(0),char(5),char(70),char(89), -char(0),char(27),char(0),char(63),char(43),char(0),char(24),char(63),char(51),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(34),char(39),char(53),char(22),char(51),char(50), -char(17),char(52),char(38),char(35),char(34),char(7),char(17),char(35),char(17),char(33), -char(17),char(35),char(17),char(33),char(17),char(54),char(51),char(50),char(0),char(17), -char(16),char(2),char(5),char(23),char(131),char(97),char(109),char(108),char(240),char(166), -char(172),char(67),char(72),char(168),char(253),char(223),char(166),char(3),char(111),char(75), -char(66),char(246),char(1),char(6),char(209),char(254),char(10),char(60),char(149),char(63), -char(1),char(161),char(223),char(208),char(21),char(254),char(41),char(3),char(184),char(252), -char(72),char(4),char(72),char(254),char(39),char(14),char(254),char(215),char(254),char(231), -char(254),char(244),char(254),char(219),char(0),char(2),char(0),char(125),char(255),char(172), -char(5),char(225),char(5),char(205),char(0),char(40),char(0),char(52),char(0),char(80), -char(64),char(44),char(27),char(17),char(47),char(35),char(41),char(0),char(8),char(0), -char(3),char(22),char(32),char(35),char(17),char(7),char(53),char(54),char(38),char(44), -char(74),char(89),char(12),char(50),char(38),char(38),char(14),char(20),char(20),char(25), -char(73),char(89),char(20),char(4),char(10),char(5),char(73),char(89),char(10),char(14), -char(14),char(30),char(73),char(89),char(14),char(19),char(0),char(63),char(43),char(0), -char(24),char(16),char(196),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(24),char(47),char(57),char(57),char(43),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(20),char(2),char(7),char(22),char(51),char(50),char(55),char(21),char(6), -char(35),char(34),char(39),char(6),char(35),char(32),char(0),char(17),char(16),char(0), -char(33),char(50),char(23),char(7),char(38),char(35),char(32),char(17),char(16),char(18), -char(51),char(50),char(55),char(38),char(2),char(53),char(52),char(18),char(51),char(50), -char(18),char(3),char(52),char(38),char(35),char(34),char(6),char(21),char(20),char(22), -char(23),char(54),char(54),char(5),char(184),char(138),char(116),char(66),char(90),char(78), -char(61),char(56),char(91),char(178),char(148),char(102),char(144),char(254),char(202),char(254), -char(161),char(1),char(73),char(1),char(58),char(127),char(92),char(47),char(84),char(90), -char(254),char(51),char(255),char(235),char(54),char(46),char(86),char(92),char(198),char(175), -char(181),char(193),char(176),char(103),char(93),char(94),char(103),char(93),char(83),char(102), -char(115),char(2),char(166),char(181),char(254),char(203),char(86),char(30),char(22),char(153), -char(25),char(100),char(36),char(1),char(137),char(1),char(86),char(1),char(120),char(1), -char(138),char(35),char(145),char(28),char(253),char(158),char(254),char(224),char(254),char(206), -char(10),char(103),char(1),char(28),char(160),char(244),char(1),char(10),char(254),char(246), -char(254),char(254),char(177),char(204),char(201),char(176),char(140),char(254),char(85),char(67), -char(255),char(0),char(0),char(2),char(0),char(115),char(255),char(199),char(4),char(211), -char(4),char(92),char(0),char(10),char(0),char(53),char(0),char(80),char(64),char(44), -char(30),char(19),char(0),char(38),char(6),char(44),char(52),char(44),char(47),char(24), -char(36),char(38),char(19),char(7),char(54),char(55),char(41),char(8),char(71),char(89), -char(13),char(3),char(41),char(41),char(15),char(22),char(22),char(27),char(70),char(89), -char(22),char(16),char(11),char(49),char(70),char(89),char(11),char(15),char(15),char(33), -char(70),char(89),char(15),char(22),char(0),char(63),char(43),char(0),char(24),char(16), -char(196),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(24),char(47),char(57),char(57),char(43),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(20), -char(22),char(23),char(54),char(54),char(53),char(52),char(35),char(34),char(6),char(1), -char(34),char(39),char(6),char(35),char(34),char(38),char(38),char(53),char(16),char(18), -char(51),char(50),char(23),char(7),char(38),char(35),char(34),char(6),char(21),char(20), -char(22),char(51),char(50),char(54),char(55),char(38),char(53),char(52),char(54),char(51), -char(50),char(22),char(21),char(20),char(6),char(7),char(22),char(51),char(50),char(55), -char(21),char(6),char(2),char(238),char(68),char(63),char(68),char(83),char(135),char(72), -char(75),char(1),char(102),char(147),char(130),char(96),char(123),char(149),char(226),char(122), -char(248),char(227),char(91),char(77),char(37),char(54),char(79),char(156),char(145),char(170), -char(164),char(37),char(53),char(6),char(139),char(168),char(151),char(148),char(157),char(107), -char(94),char(52),char(67),char(66),char(49),char(39),char(1),char(242),char(94),char(161), -char(53),char(44),char(158),char(110),char(235),char(125),char(253),char(99),char(77),char(40), -char(139),char(254),char(164),char(1),char(19),char(1),char(48),char(22),char(138),char(19), -char(209),char(231),char(206),char(210),char(9),char(3),char(148),char(225),char(173),char(193), -char(189),char(177),char(125),char(209),char(64),char(26),char(14),char(137),char(14),char(0), -char(255),char(255),char(0),char(125),char(254),char(66),char(4),char(207),char(5),char(203), -char(2),char(38),char(0),char(38),char(0),char(0),char(0),char(7),char(3),char(127), -char(2),char(37),char(0),char(0),char(255),char(255),char(0),char(115),char(254),char(66), -char(3),char(139),char(4),char(92),char(2),char(38),char(0),char(70),char(0),char(0), -char(0),char(7),char(3),char(127),char(1),char(131),char(0),char(0),char(0),char(1), -char(0),char(16),char(254),char(131),char(4),char(90),char(5),char(182),char(0),char(11), -char(0),char(50),char(64),char(27),char(6),char(11),char(8),char(9),char(3),char(9), -char(11),char(1),char(4),char(12),char(13),char(11),char(6),char(73),char(89),char(11), -char(18),char(9),char(34),char(5),char(1),char(2),char(1),char(73),char(89),char(2), -char(3),char(0),char(63),char(43),char(17),char(0),char(51),char(24),char(63),char(63), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(33),char(53),char(33),char(21),char(33),char(17),char(51), -char(17),char(35),char(17),char(35),char(1),char(223),char(254),char(49),char(4),char(74), -char(254),char(49),char(162),char(162),char(172),char(5),char(29),char(153),char(153),char(251), -char(125),char(253),char(233),char(1),char(125),char(0),char(0),char(1),char(0),char(41), -char(254),char(135),char(3),char(145),char(4),char(72),char(0),char(11),char(0),char(52), -char(64),char(27),char(6),char(11),char(8),char(9),char(3),char(9),char(11),char(1), -char(4),char(12),char(13),char(9),char(34),char(5),char(1),char(2),char(1),char(70), -char(89),char(2),char(15),char(11),char(6),char(70),char(89),char(11),char(21),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(0),char(51),char(24), -char(63),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(33),char(53),char(33),char(21),char(33),char(17),char(51), -char(17),char(35),char(17),char(35),char(1),char(137),char(254),char(160),char(3),char(104), -char(254),char(158),char(150),char(166),char(150),char(3),char(188),char(140),char(140),char(252), -char(211),char(253),char(248),char(1),char(121),char(0),char(255),char(255),char(0),char(0), -char(0),char(0),char(4),char(123),char(5),char(182),char(2),char(6),char(0),char(60), -char(0),char(0),char(0),char(1),char(0),char(0),char(254),char(20),char(4),char(2), -char(4),char(72),char(0),char(13),char(0),char(41),char(64),char(20),char(0),char(1), -char(12),char(1),char(3),char(3),char(14),char(15),char(8),char(7),char(13),char(7), -char(2),char(11),char(3),char(15),char(2),char(21),char(1),char(27),char(0),char(63), -char(63),char(63),char(51),char(18),char(57),char(57),char(17),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(35),char(17), -char(1),char(51),char(19),char(22),char(23),char(51),char(54),char(55),char(19),char(51), -char(1),char(2),char(84),char(166),char(254),char(82),char(172),char(236),char(83),char(19), -char(8),char(33),char(70),char(233),char(172),char(254),char(82),char(254),char(20),char(1), -char(232),char(4),char(76),char(253),char(155),char(222),char(97),char(138),char(181),char(2), -char(101),char(251),char(180),char(0),char(0),char(1),char(0),char(0),char(0),char(0), -char(4),char(123),char(5),char(182),char(0),char(16),char(0),char(58),char(64),char(30), -char(4),char(8),char(8),char(13),char(9),char(2),char(6),char(9),char(11),char(15), -char(5),char(17),char(18),char(7),char(11),char(12),char(11),char(73),char(89),char(4), -char(0),char(15),char(12),char(12),char(9),char(1),char(15),char(3),char(9),char(18), -char(0),char(63),char(63),char(51),char(18),char(57),char(47),char(18),char(57),char(51), -char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(51),char(17),char(51),char(49),char(48),char(1),char(1),char(51),char(1), -char(21),char(33),char(21),char(33),char(17),char(35),char(17),char(33),char(53),char(33), -char(53),char(1),char(51),char(2),char(61),char(1),char(134),char(184),char(254),char(24), -char(1),char(43),char(254),char(213),char(172),char(254),char(211),char(1),char(45),char(254), -char(25),char(186),char(2),char(219),char(2),char(219),char(252),char(129),char(59),char(152), -char(254),char(156),char(1),char(100),char(152),char(51),char(3),char(135),char(0),char(1), -char(0),char(0),char(254),char(20),char(4),char(2),char(4),char(72),char(0),char(19), -char(0),char(60),char(64),char(31),char(17),char(1),char(1),char(6),char(2),char(16), -char(19),char(2),char(4),char(7),char(5),char(20),char(21),char(12),char(11),char(11), -char(5),char(15),char(7),char(15),char(0),char(4),char(5),char(4),char(71),char(89), -char(17),char(5),char(21),char(2),char(27),char(0),char(63),char(63),char(51),char(43), -char(17),char(0),char(51),char(24),char(63),char(51),char(18),char(57),char(17),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17),char(51), -char(49),char(48),char(5),char(17),char(35),char(17),char(33),char(53),char(33),char(1), -char(51),char(19),char(22),char(23),char(51),char(54),char(55),char(19),char(51),char(1), -char(33),char(21),char(2),char(84),char(166),char(254),char(234),char(1),char(20),char(254), -char(84),char(172),char(236),char(83),char(19),char(8),char(33),char(70),char(233),char(172), -char(254),char(84),char(1),char(18),char(129),char(254),char(149),char(1),char(107),char(129), -char(4),char(72),char(253),char(155),char(222),char(97),char(138),char(181),char(2),char(101), -char(251),char(184),char(129),char(0),char(0),char(1),char(0),char(8),char(254),char(131), -char(4),char(213),char(5),char(182),char(0),char(15),char(0),char(55),char(64),char(32), -char(3),char(2),char(2),char(14),char(15),char(12),char(6),char(9),char(10),char(8), -char(8),char(16),char(17),char(12),char(15),char(9),char(6),char(4),char(5),char(13), -char(10),char(3),char(8),char(18),char(5),char(0),char(73),char(89),char(5),char(18), -char(3),char(34),char(0),char(63),char(63),char(43),char(0),char(24),char(63),char(63), -char(51),char(18),char(23),char(57),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(49),char(48),char(37),char(51),char(17),char(35),char(17),char(35),char(1), -char(1),char(35),char(1),char(1),char(51),char(1),char(1),char(51),char(1),char(4), -char(51),char(162),char(162),char(94),char(254),char(119),char(254),char(112),char(180),char(1), -char(230),char(254),char(59),char(188),char(1),char(107),char(1),char(110),char(181),char(254), -char(59),char(154),char(253),char(233),char(1),char(125),char(2),char(131),char(253),char(125), -char(2),char(252),char(2),char(186),char(253),char(189),char(2),char(67),char(253),char(76), -char(0),char(1),char(0),char(39),char(254),char(133),char(4),char(55),char(4),char(72), -char(0),char(15),char(0),char(57),char(64),char(33),char(10),char(9),char(9),char(5), -char(6),char(3),char(13),char(0),char(1),char(15),char(8),char(16),char(17),char(15), -char(21),char(3),char(6),char(0),char(13),char(4),char(12),char(1),char(12),char(7), -char(70),char(89),char(12),char(21),char(10),char(34),char(4),char(1),char(15),char(0), -char(63),char(51),char(63),char(63),char(43),char(17),char(18),char(0),char(23),char(57), -char(24),char(63),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(49), -char(48),char(1),char(1),char(51),char(1),char(1),char(51),char(1),char(1),char(51), -char(17),char(35),char(17),char(35),char(1),char(1),char(35),char(1),char(184),char(254), -char(131),char(189),char(1),char(33),char(1),char(32),char(187),char(254),char(131),char(1), -char(43),char(149),char(166),char(69),char(254),char(205),char(254),char(202),char(188),char(2), -char(49),char(2),char(23),char(254),char(92),char(1),char(164),char(253),char(233),char(254), -char(94),char(253),char(246),char(1),char(123),char(1),char(188),char(254),char(68),char(0), -char(0),char(1),char(0),char(16),char(254),char(131),char(6),char(168),char(5),char(182), -char(0),char(15),char(0),char(64),char(64),char(34),char(12),char(5),char(0),char(13), -char(3),char(2),char(2),char(13),char(10),char(5),char(7),char(5),char(16),char(17), -char(14),char(3),char(11),char(7),char(8),char(7),char(73),char(89),char(8),char(3), -char(0),char(12),char(5),char(12),char(73),char(89),char(5),char(18),char(3),char(34), -char(0),char(63),char(63),char(43),char(17),char(0),char(51),char(24),char(63),char(43), -char(17),char(0),char(51),char(24),char(63),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(51), -char(17),char(35),char(17),char(33),char(17),char(33),char(53),char(33),char(21),char(33), -char(17),char(33),char(17),char(51),char(5),char(254),char(170),char(162),char(251),char(180), -char(254),char(86),char(4),char(47),char(254),char(37),char(2),char(240),char(170),char(154), -char(253),char(233),char(1),char(125),char(5),char(29),char(153),char(153),char(251),char(125), -char(5),char(28),char(0),char(1),char(0),char(41),char(254),char(135),char(5),char(152), -char(4),char(70),char(0),char(15),char(0),char(63),char(64),char(34),char(2),char(11), -char(6),char(3),char(9),char(8),char(8),char(3),char(0),char(11),char(13),char(5), -char(16),char(17),char(1),char(13),char(14),char(13),char(70),char(89),char(14),char(15), -char(6),char(2),char(11),char(2),char(70),char(89),char(11),char(21),char(9),char(34), -char(4),char(15),char(0),char(63),char(63),char(63),char(43),char(17),char(0),char(51), -char(24),char(63),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(33),char(17),char(33),char(17),char(51),char(17),char(51),char(17),char(35),char(17), -char(33),char(17),char(33),char(53),char(33),char(3),char(121),char(254),char(151),char(2), -char(70),char(166),char(156),char(166),char(252),char(120),char(254),char(191),char(3),char(80), -char(3),char(186),char(252),char(213),char(3),char(183),char(252),char(73),char(253),char(248), -char(1),char(121),char(3),char(186),char(140),char(0),char(0),char(1),char(0),char(170), -char(254),char(131),char(5),char(104),char(5),char(182),char(0),char(23),char(0),char(59), -char(64),char(31),char(21),char(0),char(5),char(3),char(2),char(15),char(12),char(2), -char(5),char(12),char(3),char(24),char(25),char(18),char(9),char(73),char(89),char(18), -char(18),char(5),char(22),char(13),char(3),char(5),char(0),char(73),char(89),char(5), -char(18),char(3),char(34),char(0),char(63),char(63),char(43),char(0),char(24),char(63), -char(51),char(18),char(57),char(47),char(43),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(37), -char(51),char(17),char(35),char(17),char(35),char(17),char(6),char(6),char(35),char(34), -char(38),char(53),char(17),char(51),char(17),char(20),char(22),char(51),char(50),char(54), -char(55),char(17),char(51),char(4),char(199),char(161),char(161),char(170),char(149),char(198), -char(106),char(207),char(223),char(170),char(127),char(143),char(97),char(177),char(169),char(170), -char(154),char(253),char(233),char(1),char(125),char(2),char(92),char(53),char(39),char(190), -char(179),char(2),char(69),char(253),char(207),char(121),char(116),char(29),char(55),char(2), -char(202),char(0),char(0),char(1),char(0),char(156),char(254),char(133),char(4),char(195), -char(4),char(72),char(0),char(22),char(0),char(59),char(64),char(31),char(1),char(21), -char(9),char(6),char(14),char(12),char(11),char(11),char(14),char(21),char(3),char(23), -char(24),char(3),char(18),char(70),char(89),char(3),char(3),char(14),char(7),char(22), -char(15),char(14),char(9),char(70),char(89),char(14),char(21),char(12),char(34),char(0), -char(63),char(63),char(43),char(0),char(24),char(63),char(51),char(18),char(57),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(20),char(51),char(50), -char(54),char(55),char(17),char(51),char(17),char(51),char(17),char(35),char(17),char(35), -char(17),char(6),char(6),char(35),char(34),char(38),char(53),char(17),char(1),char(66), -char(219),char(91),char(166),char(105),char(166),char(150),char(166),char(150),char(105),char(179), -char(113),char(164),char(186),char(4),char(72),char(254),char(112),char(192),char(56),char(67), -char(1),char(213),char(252),char(71),char(253),char(246),char(1),char(123),char(1),char(240), -char(72),char(59),char(172),char(147),char(1),char(156),char(0),char(1),char(0),char(170), -char(0),char(0),char(4),char(199),char(5),char(182),char(0),char(22),char(0),char(74), -char(64),char(38),char(5),char(2),char(11),char(21),char(21),char(8),char(22),char(13), -char(17),char(17),char(16),char(16),char(22),char(2),char(3),char(23),char(24),char(20), -char(0),char(8),char(0),char(73),char(89),char(11),char(8),char(22),char(8),char(9), -char(9),char(8),char(22),char(3),char(3),char(17),char(18),char(14),char(3),char(3), -char(0),char(63),char(51),char(63),char(18),char(23),char(57),char(47),char(47),char(47), -char(17),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(32),char(17),char(17),char(51),char(17), -char(20),char(22),char(51),char(17),char(51),char(17),char(54),char(55),char(17),char(51), -char(17),char(35),char(17),char(6),char(7),char(17),char(35),char(2),char(117),char(254), -char(53),char(170),char(135),char(154),char(125),char(134),char(163),char(172),char(172),char(168), -char(129),char(125),char(2),char(0),char(1),char(113),char(2),char(69),char(253),char(207), -char(119),char(118),char(1),char(92),char(254),char(170),char(13),char(60),char(2),char(207), -char(250),char(74),char(2),char(88),char(65),char(17),char(254),char(207),char(0),char(1), -char(0),char(156),char(0),char(0),char(4),char(29),char(4),char(72),char(0),char(23), -char(0),char(74),char(64),char(38),char(1),char(22),char(6),char(16),char(16),char(3), -char(17),char(8),char(12),char(12),char(11),char(11),char(17),char(22),char(3),char(24), -char(25),char(15),char(19),char(3),char(19),char(70),char(89),char(6),char(3),char(17), -char(3),char(4),char(4),char(3),char(17),char(3),char(12),char(9),char(23),char(15), -char(12),char(21),char(0),char(63),char(63),char(51),char(18),char(23),char(57),char(47), -char(47),char(47),char(17),char(51),char(43),char(17),char(0),char(51),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(20),char(23), -char(17),char(51),char(17),char(54),char(55),char(17),char(51),char(17),char(35),char(17), -char(6),char(7),char(21),char(35),char(53),char(35),char(34),char(38),char(53),char(17), -char(1),char(66),char(200),char(119),char(113),char(133),char(166),char(166),char(128),char(118), -char(119),char(22),char(160),char(184),char(4),char(72),char(254),char(112),char(186),char(6), -char(1),char(45),char(254),char(221),char(24),char(89),char(1),char(213),char(251),char(184), -char(1),char(240),char(91),char(26),char(248),char(234),char(170),char(149),char(1),char(156), -char(0),char(1),char(0),char(201),char(0),char(0),char(4),char(229),char(5),char(182), -char(0),char(18),char(0),char(47),char(64),char(23),char(2),char(17),char(17),char(18), -char(9),char(8),char(8),char(18),char(20),char(19),char(4),char(13),char(73),char(89), -char(2),char(18),char(4),char(4),char(9),char(18),char(18),char(0),char(3),char(0), -char(63),char(63),char(51),char(57),char(47),char(18),char(57),char(43),char(17),char(18), -char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(19),char(51),char(17),char(36),char(51),char(50),char(22),char(21),char(17), -char(35),char(17),char(52),char(38),char(35),char(34),char(6),char(7),char(17),char(35), -char(201),char(170),char(1),char(0),char(196),char(207),char(223),char(170),char(127),char(143), -char(107),char(186),char(149),char(170),char(5),char(182),char(253),char(164),char(92),char(191), -char(177),char(253),char(186),char(2),char(49),char(120),char(118),char(34),char(50),char(253), -char(53),char(0),char(0),char(1),char(0),char(176),char(0),char(0),char(4),char(66), -char(4),char(72),char(0),char(18),char(0),char(47),char(64),char(23),char(0),char(18), -char(11),char(7),char(7),char(8),char(18),char(8),char(20),char(19),char(14),char(3), -char(70),char(89),char(11),char(14),char(14),char(8),char(9),char(15),char(0),char(8), -char(21),char(0),char(63),char(51),char(63),char(18),char(57),char(47),char(57),char(43), -char(17),char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(33),char(17),char(52),char(35),char(34),char(6),char(7), -char(17),char(35),char(17),char(51),char(17),char(54),char(54),char(51),char(50),char(22), -char(21),char(17),char(3),char(154),char(217),char(88),char(156),char(119),char(166),char(166), -char(95),char(186),char(114),char(163),char(190),char(1),char(141),char(193),char(49),char(74), -char(254),char(45),char(4),char(72),char(254),char(14),char(69),char(62),char(168),char(151), -char(254),char(102),char(0),char(2),char(0),char(61),char(255),char(236),char(6),char(63), -char(5),char(205),char(0),char(32),char(0),char(39),char(0),char(81),char(64),char(42), -char(5),char(3),char(0),char(36),char(17),char(17),char(8),char(30),char(37),char(16), -char(16),char(24),char(30),char(0),char(4),char(40),char(41),char(17),char(30),char(7), -char(30),char(73),char(89),char(36),char(7),char(2),char(7),char(2),char(27),char(12), -char(27),char(20),char(73),char(89),char(27),char(19),char(12),char(33),char(73),char(89), -char(12),char(4),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(57),char(24),char(47),char(47),char(51),char(43),char(17), -char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(51),char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(19), -char(52),char(55),char(51),char(6),char(21),char(20),char(51),char(51),char(55),char(18), -char(0),char(33),char(32),char(0),char(17),char(21),char(33),char(18),char(0),char(51), -char(50),char(54),char(55),char(21),char(6),char(6),char(35),char(32),char(0),char(3), -char(34),char(38),char(1),char(34),char(2),char(7),char(33),char(16),char(38),char(61), -char(27),char(145),char(20),char(113),char(34),char(5),char(29),char(1),char(77),char(1), -char(23),char(1),char(41),char(1),char(40),char(251),char(220),char(14),char(1),char(5), -char(247),char(101),char(202),char(141),char(114),char(221),char(130),char(254),char(198),char(254), -char(163),char(19),char(142),char(155),char(3),char(175),char(209),char(240),char(16),char(3), -char(110),char(203),char(3),char(135),char(73),char(54),char(50),char(60),char(103),char(43), -char(1),char(42),char(1),char(71),char(254),char(133),char(254),char(143),char(69),char(254), -char(248),char(254),char(239),char(31),char(43),char(156),char(39),char(30),char(1),char(100), -char(1),char(76),char(118),char(2),char(35),char(254),char(245),char(249),char(1),char(9), -char(251),char(0),char(0),char(2),char(0),char(51),char(255),char(236),char(4),char(221), -char(4),char(90),char(0),char(31),char(0),char(38),char(0),char(76),char(64),char(40), -char(10),char(8),char(5),char(22),char(13),char(36),char(21),char(21),char(29),char(13), -char(3),char(5),char(5),char(39),char(40),char(22),char(3),char(12),char(3),char(70), -char(89),char(35),char(12),char(7),char(12),char(7),char(0),char(17),char(17),char(32), -char(70),char(89),char(17),char(16),char(0),char(25),char(70),char(89),char(0),char(22), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0), -char(57),char(57),char(24),char(47),char(47),char(51),char(43),char(17),char(0),char(51), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(51),char(49),char(48),char(5),char(34),char(0),char(39),char(36),char(53), -char(52),char(55),char(51),char(6),char(21),char(20),char(51),char(51),char(55),char(54), -char(54),char(51),char(50),char(18),char(21),char(21),char(33),char(22),char(22),char(51), -char(50),char(54),char(55),char(21),char(6),char(6),char(3),char(34),char(6),char(7), -char(33),char(52),char(38),char(3),char(74),char(243),char(254),char(236),char(6),char(254), -char(246),char(25),char(141),char(20),char(106),char(21),char(6),char(34),char(250),char(183), -char(207),char(241),char(253),char(12),char(6),char(172),char(173),char(101),char(159),char(98), -char(88),char(157),char(160),char(134),char(151),char(14),char(2),char(61),char(140),char(20), -char(1),char(30),char(252),char(4),char(221),char(69),char(50),char(47),char(59),char(103), -char(35),char(202),char(224),char(254),char(247),char(226),char(105),char(198),char(195),char(32), -char(42),char(148),char(38),char(33),char(3),char(227),char(164),char(158),char(157),char(165), -char(0),char(2),char(0),char(61),char(254),char(131),char(6),char(63),char(5),char(205), -char(0),char(34),char(0),char(41),char(0),char(93),char(64),char(49),char(11),char(9), -char(6),char(38),char(23),char(23),char(14),char(3),char(33),char(34),char(39),char(22), -char(22),char(30),char(34),char(3),char(6),char(5),char(42),char(43),char(34),char(34), -char(32),char(19),char(23),char(3),char(13),char(3),char(73),char(89),char(38),char(13), -char(8),char(13),char(8),char(0),char(18),char(18),char(35),char(73),char(89),char(18), -char(4),char(0),char(26),char(74),char(89),char(0),char(19),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(24), -char(47),char(47),char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(63), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(51),char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(5), -char(36),char(0),char(3),char(34),char(38),char(53),char(52),char(55),char(51),char(6), -char(21),char(20),char(51),char(51),char(55),char(18),char(0),char(33),char(32),char(0), -char(17),char(21),char(33),char(18),char(0),char(51),char(50),char(54),char(55),char(21), -char(6),char(7),char(17),char(35),char(19),char(34),char(2),char(7),char(33),char(16), -char(38),char(3),char(160),char(254),char(254),char(254),char(219),char(19),char(142),char(155), -char(27),char(145),char(20),char(113),char(34),char(5),char(29),char(1),char(77),char(1), -char(23),char(1),char(41),char(1),char(40),char(251),char(220),char(14),char(1),char(5), -char(247),char(101),char(202),char(141),char(176),char(235),char(166),char(76),char(209),char(240), -char(16),char(3),char(110),char(203),char(12),char(29),char(1),char(90),char(1),char(49), -char(118),char(117),char(73),char(54),char(50),char(60),char(103),char(43),char(1),char(42), -char(1),char(71),char(254),char(133),char(254),char(143),char(69),char(254),char(248),char(254), -char(239),char(31),char(43),char(156),char(62),char(5),char(254),char(149),char(6),char(178), -char(254),char(245),char(249),char(1),char(9),char(251),char(0),char(2),char(0),char(51), -char(254),char(135),char(4),char(221),char(4),char(90),char(0),char(33),char(0),char(40), -char(0),char(88),char(64),char(47),char(10),char(8),char(5),char(22),char(13),char(32), -char(33),char(38),char(21),char(21),char(29),char(33),char(13),char(3),char(5),char(6), -char(41),char(42),char(33),char(34),char(31),char(22),char(22),char(3),char(12),char(3), -char(70),char(89),char(37),char(12),char(7),char(12),char(7),char(0),char(17),char(17), -char(34),char(70),char(89),char(17),char(16),char(0),char(25),char(70),char(89),char(0), -char(21),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(57),char(24),char(47),char(47),char(51),char(43),char(17),char(0), -char(51),char(24),char(63),char(63),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(51),char(49),char(48), -char(5),char(38),char(2),char(39),char(36),char(53),char(52),char(55),char(51),char(6), -char(21),char(20),char(51),char(51),char(55),char(54),char(54),char(51),char(50),char(18), -char(21),char(21),char(33),char(22),char(22),char(51),char(50),char(54),char(55),char(21), -char(6),char(7),char(17),char(35),char(19),char(34),char(6),char(7),char(33),char(52), -char(38),char(2),char(213),char(191),char(211),char(6),char(254),char(246),char(25),char(141), -char(20),char(106),char(21),char(6),char(34),char(250),char(183),char(207),char(241),char(253), -char(12),char(6),char(172),char(173),char(101),char(159),char(98),char(142),char(165),char(166), -char(68),char(134),char(151),char(14),char(2),char(61),char(140),char(10),char(31),char(1), -char(17),char(224),char(4),char(221),char(69),char(50),char(47),char(59),char(103),char(35), -char(202),char(224),char(254),char(247),char(226),char(105),char(198),char(195),char(32),char(42), -char(148),char(65),char(4),char(254),char(153),char(5),char(72),char(164),char(158),char(157), -char(165),char(0),char(255),char(255),char(0),char(84),char(0),char(0),char(2),char(86), -char(5),char(182),char(2),char(6),char(0),char(44),char(0),char(0),char(255),char(255), -char(0),char(2),char(0),char(0),char(6),char(188),char(7),char(96),char(2),char(38), -char(1),char(176),char(0),char(0),char(1),char(7),char(2),char(54),char(1),char(16), -char(1),char(84),char(0),char(8),char(179),char(1),char(18),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(4),char(0),char(0),char(5),char(223), -char(6),char(12),char(2),char(38),char(1),char(208),char(0),char(0),char(1),char(7), -char(2),char(54),char(0),char(164),char(0),char(0),char(0),char(8),char(179),char(1), -char(18),char(17),char(38),char(0),char(43),char(53),char(0),char(1),char(0),char(201), -char(254),char(0),char(5),char(25),char(5),char(182),char(0),char(28),char(0),char(66), -char(64),char(37),char(7),char(3),char(3),char(4),char(26),char(14),char(14),char(9), -char(10),char(20),char(4),char(5),char(29),char(30),char(17),char(23),char(73),char(89), -char(17),char(28),char(7),char(2),char(73),char(89),char(11),char(0),char(74),char(89), -char(7),char(11),char(11),char(4),char(8),char(5),char(3),char(4),char(18),char(0), -char(63),char(63),char(51),char(18),char(57),char(47),char(57),char(43),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(34),char(7),char(17), -char(35),char(17),char(51),char(17),char(1),char(51),char(1),char(55),char(32),char(0), -char(17),char(16),char(0),char(33),char(34),char(38),char(39),char(53),char(22),char(51), -char(50),char(18),char(53),char(52),char(36),char(2),char(94),char(140),char(95),char(170), -char(170),char(2),char(137),char(205),char(253),char(133),char(26),char(1),char(79),char(1), -char(98),char(254),char(217),char(254),char(245),char(82),char(124),char(70),char(122),char(152), -char(187),char(200),char(254),char(235),char(2),char(123),char(31),char(253),char(164),char(5), -char(182),char(253),char(60),char(2),char(196),char(253),char(84),char(2),char(254),char(187), -char(254),char(207),char(254),char(198),char(254),char(164),char(20),char(29),char(152),char(49), -char(1),char(13),char(241),char(232),char(253),char(0),char(0),char(1),char(0),char(176), -char(254),char(10),char(4),char(33),char(4),char(72),char(0),char(28),char(0),char(66), -char(64),char(37),char(4),char(0),char(0),char(1),char(23),char(10),char(16),char(10), -char(6),char(7),char(1),char(5),char(29),char(30),char(14),char(20),char(70),char(89), -char(14),char(27),char(4),char(28),char(71),char(89),char(7),char(26),char(70),char(89), -char(4),char(7),char(7),char(1),char(5),char(2),char(15),char(1),char(21),char(0), -char(63),char(63),char(51),char(18),char(57),char(47),char(57),char(43),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(33),char(35),char(17),char(51), -char(17),char(1),char(51),char(1),char(4),char(18),char(17),char(20),char(6),char(6), -char(35),char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53), -char(52),char(38),char(35),char(34),char(7),char(1),char(84),char(164),char(164),char(1), -char(227),char(183),char(254),char(55),char(1),char(0),char(252),char(110),char(204),char(133), -char(136),char(95),char(46),char(108),char(71),char(135),char(152),char(187),char(190),char(82), -char(92),char(4),char(72),char(253),char(250),char(2),char(6),char(254),char(30),char(4), -char(254),char(228),char(254),char(245),char(177),char(252),char(132),char(60),char(145),char(25), -char(38),char(217),char(200),char(211),char(207),char(24),char(0),char(1),char(0),char(0), -char(254),char(131),char(5),char(145),char(5),char(182),char(0),char(23),char(0),char(57), -char(64),char(31),char(3),char(0),char(5),char(4),char(1),char(1),char(5),char(14), -char(3),char(24),char(25),char(22),char(7),char(73),char(89),char(22),char(3),char(12), -char(17),char(74),char(89),char(12),char(18),char(5),char(0),char(73),char(89),char(5), -char(18),char(3),char(34),char(0),char(63),char(63),char(43),char(0),char(24),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(37),char(51),char(3), -char(35),char(19),char(35),char(17),char(33),char(7),char(2),char(2),char(6),char(39), -char(34),char(39),char(53),char(22),char(51),char(50),char(54),char(54),char(18),char(19), -char(33),char(4),char(217),char(184),char(143),char(197),char(156),char(170),char(254),char(37), -char(31),char(61),char(93),char(152),char(126),char(74),char(59),char(54),char(59),char(53), -char(79),char(61),char(93),char(56),char(3),char(18),char(154),char(253),char(233),char(1), -char(125),char(5),char(31),char(240),char(254),char(33),char(254),char(69),char(174),char(2), -char(25),char(143),char(26),char(87),char(215),char(2),char(89),char(1),char(184),char(0), -char(0),char(1),char(0),char(16),char(254),char(135),char(4),char(143),char(4),char(70), -char(0),char(20),char(0),char(57),char(64),char(31),char(3),char(0),char(5),char(4), -char(1),char(1),char(5),char(13),char(3),char(21),char(22),char(19),char(7),char(70), -char(89),char(19),char(15),char(11),char(16),char(71),char(89),char(11),char(21),char(5), -char(0),char(70),char(89),char(5),char(21),char(3),char(34),char(0),char(63),char(63), -char(43),char(0),char(24),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(49), -char(48),char(37),char(51),char(3),char(35),char(19),char(35),char(17),char(33),char(2), -char(2),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50),char(18), -char(19),char(33),char(3),char(223),char(176),char(129),char(172),char(125),char(166),char(254), -char(181),char(28),char(94),char(152),char(118),char(58),char(28),char(22),char(28),char(113), -char(137),char(34),char(2),char(129),char(143),char(253),char(248),char(1),char(121),char(3), -char(184),char(254),char(152),char(254),char(100),char(192),char(10),char(127),char(6),char(1), -char(217),char(1),char(246),char(0),char(0),char(1),char(0),char(201),char(254),char(0), -char(5),char(31),char(5),char(182),char(0),char(21),char(0),char(61),char(64),char(32), -char(18),char(14),char(14),char(15),char(19),char(11),char(11),char(0),char(0),char(6), -char(15),char(3),char(22),char(23),char(18),char(13),char(73),char(89),char(18),char(18), -char(15),char(20),char(16),char(3),char(15),char(18),char(3),char(9),char(73),char(89), -char(3),char(28),char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(51), -char(18),char(57),char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(37), -char(16),char(0),char(33),char(34),char(38),char(39),char(53),char(22),char(51),char(32), -char(17),char(17),char(33),char(17),char(35),char(17),char(51),char(17),char(33),char(17), -char(51),char(5),char(31),char(254),char(230),char(254),char(251),char(82),char(122),char(77), -char(123),char(135),char(1),char(140),char(252),char(254),char(170),char(170),char(3),char(2), -char(170),char(150),char(254),char(194),char(254),char(168),char(19),char(30),char(150),char(49), -char(1),char(247),char(2),char(35),char(253),char(80),char(5),char(182),char(253),char(146), -char(2),char(110),char(0),char(1),char(0),char(176),char(254),char(10),char(4),char(98), -char(4),char(72),char(0),char(21),char(0),char(71),char(64),char(39),char(15),char(11), -char(11),char(12),char(16),char(8),char(8),char(19),char(19),char(2),char(12),char(3), -char(22),char(23),char(15),char(10),char(70),char(89),char(15),char(15),char(31),char(15), -char(2),char(11),char(3),char(15),char(15),char(12),char(17),char(13),char(15),char(12), -char(21),char(0),char(5),char(70),char(89),char(0),char(27),char(0),char(63),char(43), -char(0),char(24),char(63),char(63),char(51),char(18),char(57),char(47),char(95),char(94), -char(93),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(34),char(39), -char(53),char(22),char(51),char(50),char(54),char(53),char(17),char(33),char(17),char(35), -char(17),char(51),char(17),char(33),char(17),char(51),char(17),char(16),char(2),char(2), -char(211),char(132),char(93),char(111),char(102),char(125),char(118),char(253),char(156),char(166), -char(166),char(2),char(100),char(168),char(207),char(254),char(10),char(58),char(149),char(61), -char(198),char(207),char(1),char(189),char(254),char(18),char(4),char(72),char(254),char(53), -char(1),char(203),char(251),char(235),char(254),char(244),char(254),char(227),char(0),char(1), -char(0),char(201),char(254),char(131),char(5),char(215),char(5),char(182),char(0),char(15), -char(0),char(68),char(64),char(36),char(12),char(8),char(8),char(9),char(13),char(3), -char(0),char(5),char(4),char(1),char(1),char(5),char(9),char(3),char(16),char(17), -char(12),char(7),char(73),char(89),char(12),char(12),char(5),char(14),char(10),char(3), -char(9),char(18),char(5),char(0),char(73),char(89),char(5),char(18),char(3),char(34), -char(0),char(63),char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18), -char(57),char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(51),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(37),char(51),char(3),char(35),char(19),char(35),char(17),char(33),char(17),char(35), -char(17),char(51),char(17),char(33),char(17),char(51),char(5),char(31),char(184),char(145), -char(197),char(158),char(170),char(252),char(254),char(170),char(170),char(3),char(2),char(170), -char(154),char(253),char(233),char(1),char(125),char(2),char(176),char(253),char(80),char(5), -char(182),char(253),char(146),char(2),char(110),char(0),char(0),char(1),char(0),char(176), -char(254),char(135),char(5),char(18),char(4),char(70),char(0),char(15),char(0),char(68), -char(64),char(36),char(1),char(13),char(13),char(14),char(8),char(5),char(2),char(10), -char(9),char(6),char(6),char(10),char(14),char(3),char(16),char(17),char(1),char(12), -char(70),char(89),char(1),char(1),char(10),char(3),char(15),char(15),char(14),char(21), -char(10),char(5),char(70),char(89),char(10),char(21),char(8),char(34),char(0),char(63), -char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(57),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(51),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17), -char(33),char(17),char(51),char(17),char(51),char(3),char(35),char(19),char(35),char(17), -char(33),char(17),char(35),char(17),char(1),char(86),char(2),char(102),char(166),char(176), -char(129),char(172),char(125),char(166),char(253),char(154),char(166),char(4),char(70),char(254), -char(55),char(1),char(201),char(252),char(73),char(253),char(248),char(1),char(121),char(1), -char(238),char(254),char(18),char(4),char(70),char(0),char(0),char(1),char(0),char(170), -char(254),char(131),char(4),char(199),char(5),char(182),char(0),char(23),char(0),char(61), -char(64),char(32),char(15),char(12),char(2),char(3),char(21),char(5),char(5),char(0), -char(0),char(3),char(12),char(3),char(24),char(25),char(18),char(9),char(73),char(89), -char(18),char(18),char(1),char(22),char(13),char(3),char(3),char(34),char(1),char(4), -char(73),char(89),char(1),char(18),char(0),char(63),char(43),char(0),char(24),char(63), -char(63),char(51),char(18),char(57),char(47),char(43),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(33),char(35),char(17),char(35),char(17),char(51),char(17),char(6),char(6), -char(35),char(34),char(38),char(53),char(17),char(51),char(17),char(20),char(22),char(51), -char(50),char(54),char(55),char(17),char(51),char(4),char(199),char(170),char(162),char(162), -char(149),char(198),char(106),char(207),char(223),char(170),char(127),char(143),char(97),char(177), -char(169),char(170),char(254),char(131),char(2),char(23),char(1),char(194),char(53),char(39), -char(190),char(179),char(2),char(69),char(253),char(207),char(121),char(116),char(29),char(55), -char(2),char(202),char(0),char(1),char(0),char(156),char(254),char(133),char(4),char(45), -char(4),char(72),char(0),char(22),char(0),char(61),char(64),char(32),char(1),char(21), -char(11),char(12),char(6),char(14),char(14),char(9),char(9),char(12),char(21),char(3), -char(23),char(24),char(3),char(18),char(70),char(89),char(3),char(3),char(10),char(7), -char(22),char(15),char(12),char(34),char(10),char(13),char(70),char(89),char(10),char(21), -char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(57), -char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(17),char(20), -char(51),char(50),char(54),char(55),char(17),char(51),char(17),char(35),char(17),char(35), -char(17),char(51),char(17),char(6),char(6),char(35),char(34),char(38),char(53),char(17), -char(1),char(66),char(219),char(91),char(166),char(105),char(166),char(149),char(166),char(149), -char(105),char(179),char(113),char(164),char(186),char(4),char(72),char(254),char(112),char(192), -char(56),char(67),char(1),char(213),char(251),char(184),char(254),char(133),char(2),char(10), -char(1),char(97),char(72),char(59),char(172),char(147),char(1),char(156),char(0),char(1), -char(0),char(201),char(254),char(131),char(7),char(41),char(5),char(182),char(0),char(24), -char(0),char(72),char(64),char(37),char(9),char(6),char(6),char(7),char(17),char(14), -char(12),char(19),char(18),char(15),char(15),char(19),char(7),char(3),char(25),char(26), -char(23),char(22),char(2),char(11),char(2),char(19),char(8),char(19),char(14),char(73), -char(89),char(19),char(18),char(17),char(34),char(12),char(8),char(3),char(0),char(7), -char(18),char(0),char(63),char(51),char(63),char(51),char(63),char(63),char(43),char(17), -char(18),char(0),char(57),char(57),char(17),char(51),char(51),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(51),char(51),char(17),char(51), -char(17),char(51),char(49),char(48),char(33),char(1),char(35),char(23),char(22),char(21), -char(17),char(35),char(17),char(33),char(1),char(51),char(1),char(51),char(17),char(51), -char(3),char(35),char(19),char(35),char(17),char(52),char(55),char(35),char(1),char(3), -char(80),char(254),char(16),char(8),char(7),char(7),char(157),char(1),char(0),char(1), -char(209),char(8),char(1),char(209),char(254),char(184),char(143),char(199),char(158),char(170), -char(14),char(8),char(254),char(12),char(5),char(16),char(127),char(192),char(47),char(252), -char(94),char(5),char(182),char(251),char(74),char(4),char(182),char(250),char(228),char(253), -char(233),char(1),char(125),char(3),char(174),char(132),char(220),char(250),char(242),char(0), -char(0),char(1),char(0),char(176),char(254),char(135),char(5),char(223),char(4),char(70), -char(0),char(24),char(0),char(63),char(64),char(32),char(19),char(20),char(8),char(5), -char(10),char(9),char(6),char(6),char(10),char(20),char(3),char(25),char(26),char(11), -char(18),char(0),char(18),char(15),char(3),char(21),char(15),char(20),char(21),char(10), -char(5),char(70),char(89),char(10),char(15),char(21),char(8),char(34),char(0),char(63), -char(63),char(51),char(43),char(0),char(24),char(63),char(63),char(51),char(18),char(57), -char(57),char(17),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(37),char(55),char(55), -char(1),char(51),char(17),char(51),char(3),char(35),char(19),char(35),char(17),char(7), -char(7),char(1),char(35),char(1),char(38),char(39),char(17),char(35),char(17),char(51), -char(1),char(22),char(2),char(233),char(31),char(43),char(1),char(41),char(211),char(176), -char(129),char(172),char(125),char(147),char(20),char(58),char(254),char(229),char(139),char(254), -char(229),char(53),char(20),char(148),char(203),char(1),char(41),char(45),char(160),char(93), -char(118),char(2),char(211),char(252),char(73),char(253),char(248),char(1),char(121),char(3), -char(137),char(58),char(153),char(253),char(74),char(2),char(184),char(134),char(75),char(252), -char(119),char(4),char(70),char(253),char(45),char(110),char(255),char(255),char(0),char(84), -char(0),char(0),char(2),char(86),char(5),char(182),char(2),char(6),char(0),char(44), -char(0),char(0),char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16), -char(7),char(94),char(2),char(38),char(0),char(36),char(0),char(0),char(1),char(7), -char(2),char(54),char(0),char(57),char(1),char(82),char(0),char(8),char(179),char(2), -char(15),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(94), -char(255),char(236),char(3),char(205),char(6),char(12),char(2),char(38),char(0),char(68), -char(0),char(0),char(1),char(6),char(2),char(54),char(232),char(0),char(0),char(8), -char(179),char(2),char(37),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(7),char(37),char(2),char(38), -char(0),char(36),char(0),char(0),char(1),char(7),char(0),char(106),char(0),char(61), -char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(36),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(94),char(255),char(236), -char(3),char(205),char(5),char(211),char(2),char(38),char(0),char(68),char(0),char(0), -char(1),char(6),char(0),char(106),char(243),char(0),char(0),char(10),char(180),char(3), -char(2),char(58),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(255),char(254),char(0),char(0),char(6),char(129),char(5),char(182),char(2),char(6), -char(0),char(136),char(0),char(0),char(255),char(255),char(0),char(94),char(255),char(236), -char(6),char(115),char(4),char(92),char(2),char(6),char(0),char(168),char(0),char(0), -char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248),char(7),char(94), -char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7),char(2),char(54), -char(0),char(16),char(1),char(82),char(0),char(8),char(179),char(1),char(12),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(18),char(6),char(12),char(2),char(38),char(0),char(72),char(0),char(0), -char(1),char(6),char(2),char(54),char(12),char(0),char(0),char(8),char(179),char(2), -char(27),char(17),char(38),char(0),char(43),char(53),char(0),char(2),char(0),char(117), -char(255),char(236),char(5),char(88),char(5),char(205),char(0),char(18),char(0),char(25), -char(0),char(61),char(64),char(32),char(23),char(14),char(16),char(22),char(22),char(9), -char(9),char(2),char(14),char(3),char(26),char(27),char(15),char(23),char(73),char(89), -char(15),char(15),char(12),char(6),char(12),char(19),char(73),char(89),char(12),char(19), -char(6),char(0),char(73),char(89),char(6),char(4),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(1),char(34),char(7),char(53),char(54),char(54),char(51), -char(32),char(0),char(17),char(16),char(0),char(33),char(32),char(17),char(53),char(33), -char(2),char(0),char(3),char(50),char(18),char(55),char(33),char(16),char(22),char(2), -char(152),char(227),char(226),char(115),char(210),char(134),char(1),char(75),char(1),char(111), -char(254),char(166),char(254),char(203),char(253),char(172),char(4),char(47),char(17),char(254), -char(249),char(195),char(210),char(249),char(16),char(252),char(135),char(204),char(5),char(53), -char(76),char(158),char(38),char(32),char(254),char(113),char(254),char(155),char(254),char(162), -char(254),char(113),char(2),char(235),char(70),char(1),char(10),char(1),char(14),char(251), -char(78),char(1),char(13),char(247),char(254),char(248),char(252),char(0),char(0),char(2), -char(0),char(102),char(255),char(236),char(4),char(6),char(4),char(92),char(0),char(20), -char(0),char(27),char(0),char(59),char(64),char(31),char(25),char(9),char(24),char(11), -char(3),char(3),char(17),char(9),char(3),char(28),char(29),char(10),char(25),char(70), -char(89),char(10),char(10),char(6),char(0),char(6),char(21),char(70),char(89),char(6), -char(22),char(0),char(14),char(70),char(89),char(0),char(16),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(17), -char(51),char(49),char(48),char(1),char(50),char(0),char(17),char(16),char(0),char(35), -char(34),char(2),char(53),char(53),char(33),char(38),char(38),char(35),char(34),char(6), -char(7),char(53),char(54),char(54),char(19),char(50),char(54),char(55),char(33),char(20), -char(22),char(1),char(250),char(245),char(1),char(23),char(254),char(253),char(218),char(208), -char(243),char(2),char(244),char(5),char(179),char(166),char(98),char(165),char(95),char(89), -char(162),char(154),char(133),char(154),char(12),char(253),char(195),char(141),char(4),char(92), -char(254),char(212),char(254),char(251),char(254),char(248),char(254),char(201),char(1),char(12), -char(225),char(105),char(204),char(187),char(33),char(41),char(147),char(40),char(34),char(252), -char(27),char(165),char(156),char(157),char(164),char(0),char(255),char(255),char(0),char(117), -char(255),char(236),char(5),char(88),char(7),char(37),char(2),char(38),char(2),char(225), -char(0),char(0),char(1),char(7),char(0),char(106),char(0),char(147),char(1),char(82), -char(0),char(10),char(180),char(3),char(2),char(47),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(102),char(255),char(236),char(4),char(6), -char(5),char(211),char(2),char(38),char(2),char(226),char(0),char(0),char(1),char(6), -char(0),char(106),char(234),char(0),char(0),char(10),char(180),char(3),char(2),char(49), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(2), -char(0),char(0),char(6),char(188),char(7),char(37),char(2),char(38),char(1),char(176), -char(0),char(0),char(1),char(7),char(0),char(106),char(1),char(16),char(1),char(82), -char(0),char(10),char(180),char(2),char(1),char(39),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(4),char(0),char(0),char(5),char(223), -char(5),char(211),char(2),char(38),char(1),char(208),char(0),char(0),char(1),char(7), -char(0),char(106),char(0),char(162),char(0),char(0),char(0),char(10),char(180),char(2), -char(1),char(39),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(74),char(255),char(236),char(4),char(53),char(7),char(37),char(2),char(38), -char(1),char(177),char(0),char(0),char(1),char(7),char(0),char(106),char(255),char(243), -char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(62),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(68),char(255),char(236), -char(3),char(127),char(5),char(211),char(2),char(38),char(1),char(209),char(0),char(0), -char(1),char(6),char(0),char(106),char(148),char(0),char(0),char(10),char(180),char(2), -char(1),char(56),char(17),char(38),char(0),char(43),char(53),char(53),char(0),char(1), -char(0),char(74),char(255),char(236),char(4),char(55),char(5),char(182),char(0),char(25), -char(0),char(64),char(64),char(35),char(0),char(19),char(21),char(25),char(15),char(3), -char(3),char(25),char(19),char(22),char(8),char(5),char(26),char(27),char(25),char(22), -char(23),char(22),char(73),char(89),char(0),char(18),char(74),char(89),char(0),char(0), -char(6),char(23),char(3),char(6),char(12),char(74),char(89),char(6),char(19),char(0), -char(63),char(43),char(0),char(24),char(63),char(18),char(57),char(47),char(43),char(43), -char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(4),char(4),char(21), -char(20),char(4),char(33),char(32),char(39),char(53),char(22),char(22),char(51),char(50), -char(54),char(53),char(52),char(38),char(35),char(35),char(53),char(1),char(33),char(53), -char(33),char(21),char(1),char(252),char(1),char(23),char(1),char(36),char(254),char(205), -char(254),char(234),char(254),char(255),char(163),char(96),char(222),char(106),char(199),char(202), -char(225),char(223),char(140),char(1),char(238),char(253),char(78),char(3),char(135),char(3), -char(63),char(9),char(211),char(193),char(206),char(232),char(79),char(158),char(46),char(50), -char(153),char(144),char(134),char(138),char(141),char(1),char(222),char(153),char(139),char(0), -char(0),char(1),char(0),char(27),char(254),char(20),char(3),char(166),char(4),char(72), -char(0),char(25),char(0),char(64),char(64),char(35),char(0),char(19),char(21),char(25), -char(15),char(4),char(4),char(25),char(19),char(22),char(9),char(5),char(26),char(27), -char(25),char(22),char(23),char(22),char(70),char(89),char(0),char(18),char(71),char(89), -char(0),char(0),char(7),char(23),char(15),char(7),char(12),char(70),char(89),char(7), -char(27),char(0),char(63),char(43),char(0),char(24),char(63),char(18),char(57),char(47), -char(43),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(30), -char(2),char(21),char(20),char(0),char(35),char(34),char(39),char(53),char(22),char(51), -char(50),char(54),char(53),char(52),char(38),char(35),char(35),char(53),char(1),char(33), -char(53),char(33),char(21),char(1),char(172),char(149),char(230),char(127),char(254),char(216), -char(239),char(234),char(138),char(183),char(200),char(161),char(197),char(214),char(202),char(121), -char(1),char(197),char(253),char(137),char(3),char(56),char(1),char(207),char(7),char(114), -char(202),char(136),char(222),char(254),char(238),char(70),char(154),char(86),char(190),char(160), -char(164),char(170),char(114),char(1),char(254),char(142),char(123),char(0),char(255),char(255), -char(0),char(203),char(0),char(0),char(5),char(82),char(6),char(180),char(2),char(38), -char(1),char(178),char(0),char(0),char(1),char(7),char(1),char(77),char(0),char(180), -char(1),char(82),char(0),char(8),char(179),char(1),char(19),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(176),char(0),char(0),char(4),char(98), -char(5),char(98),char(2),char(38),char(1),char(210),char(0),char(0),char(1),char(6), -char(1),char(77),char(49),char(0),char(0),char(8),char(179),char(1),char(17),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(203),char(0),char(0), -char(5),char(82),char(7),char(37),char(2),char(38),char(1),char(178),char(0),char(0), -char(1),char(7),char(0),char(106),char(0),char(190),char(1),char(82),char(0),char(10), -char(180),char(2),char(1),char(37),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(176),char(0),char(0),char(4),char(98),char(5),char(211), -char(2),char(38),char(1),char(210),char(0),char(0),char(1),char(6),char(0),char(106), -char(61),char(0),char(0),char(10),char(180),char(2),char(1),char(35),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(5),char(190),char(7),char(37),char(2),char(38),char(0),char(50),char(0),char(0), -char(1),char(7),char(0),char(106),char(0),char(209),char(1),char(82),char(0),char(10), -char(180),char(3),char(2),char(45),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98),char(5),char(211), -char(2),char(38),char(0),char(82),char(0),char(0),char(1),char(6),char(0),char(106), -char(29),char(0),char(0),char(10),char(180),char(3),char(2),char(46),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(5),char(190),char(5),char(205),char(2),char(6),char(2),char(126),char(0),char(0), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98),char(4),char(92), -char(2),char(6),char(2),char(127),char(0),char(0),char(255),char(255),char(0),char(125), -char(255),char(236),char(5),char(190),char(7),char(37),char(2),char(38),char(2),char(126), -char(0),char(0),char(1),char(7),char(0),char(106),char(0),char(209),char(1),char(82), -char(0),char(10),char(180),char(4),char(3),char(47),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98), -char(5),char(211),char(2),char(38),char(2),char(127),char(0),char(0),char(1),char(6), -char(0),char(106),char(27),char(0),char(0),char(10),char(180),char(4),char(3),char(48), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(61), -char(255),char(236),char(4),char(137),char(7),char(37),char(2),char(38),char(1),char(199), -char(0),char(0),char(1),char(7),char(0),char(106),char(255),char(237),char(1),char(82), -char(0),char(10),char(180),char(2),char(1),char(48),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(57),char(255),char(236),char(3),char(125), -char(5),char(211),char(2),char(38),char(1),char(231),char(0),char(0),char(1),char(6), -char(0),char(106),char(142),char(0),char(0),char(10),char(180),char(2),char(1),char(48), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(27), -char(255),char(236),char(4),char(248),char(6),char(180),char(2),char(38),char(1),char(189), -char(0),char(0),char(1),char(7),char(1),char(77),char(0),char(47),char(1),char(82), -char(0),char(8),char(179),char(1),char(26),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(2),char(254),char(20),char(4),char(6),char(5),char(98), -char(2),char(38),char(0),char(92),char(0),char(0),char(1),char(6),char(1),char(77), -char(173),char(0),char(0),char(8),char(179),char(1),char(25),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(27),char(255),char(236),char(4),char(248), -char(7),char(37),char(2),char(38),char(1),char(189),char(0),char(0),char(1),char(7), -char(0),char(106),char(0),char(59),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(44),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(2),char(254),char(20),char(4),char(6),char(5),char(211),char(2),char(38), -char(0),char(92),char(0),char(0),char(1),char(6),char(0),char(106),char(183),char(0), -char(0),char(10),char(180),char(2),char(1),char(43),char(17),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(27),char(255),char(236),char(4),char(248), -char(7),char(115),char(2),char(38),char(1),char(189),char(0),char(0),char(1),char(7), -char(1),char(83),char(0),char(141),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(42),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(2),char(254),char(20),char(4),char(6),char(6),char(33),char(2),char(38), -char(0),char(92),char(0),char(0),char(1),char(6),char(1),char(83),char(4),char(0), -char(0),char(10),char(180),char(2),char(1),char(41),char(17),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(170),char(0),char(0),char(4),char(199), -char(7),char(37),char(2),char(38),char(1),char(193),char(0),char(0),char(1),char(7), -char(0),char(106),char(0),char(106),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(41),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(156),char(0),char(0),char(4),char(45),char(5),char(211),char(2),char(38), -char(1),char(225),char(0),char(0),char(1),char(6),char(0),char(106),char(23),char(0), -char(0),char(10),char(180),char(2),char(1),char(40),char(17),char(38),char(0),char(43), -char(53),char(53),char(0),char(1),char(0),char(201),char(254),char(131),char(4),char(8), -char(5),char(182),char(0),char(9),char(0),char(45),char(64),char(24),char(4),char(9), -char(6),char(7),char(1),char(7),char(9),char(3),char(10),char(11),char(9),char(4), -char(73),char(89),char(9),char(18),char(7),char(34),char(0),char(3),char(73),char(89), -char(0),char(3),char(0),char(63),char(43),char(0),char(24),char(63),char(63),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49), -char(48),char(19),char(33),char(21),char(33),char(17),char(51),char(17),char(35),char(17), -char(35),char(201),char(3),char(63),char(253),char(107),char(161),char(161),char(170),char(5), -char(182),char(153),char(251),char(125),char(253),char(233),char(1),char(125),char(0),char(1), -char(0),char(176),char(254),char(135),char(3),char(66),char(4),char(70),char(0),char(9), -char(0),char(45),char(64),char(24),char(4),char(9),char(6),char(7),char(1),char(7), -char(9),char(3),char(10),char(11),char(9),char(4),char(70),char(89),char(9),char(21), -char(7),char(34),char(0),char(3),char(70),char(89),char(0),char(15),char(0),char(63), -char(43),char(0),char(24),char(63),char(63),char(43),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(33),char(21), -char(33),char(17),char(51),char(17),char(35),char(17),char(35),char(176),char(2),char(146), -char(254),char(20),char(150),char(166),char(150),char(4),char(70),char(140),char(252),char(213), -char(253),char(248),char(1),char(121),char(255),char(255),char(0),char(201),char(0),char(0), -char(6),char(10),char(7),char(37),char(2),char(38),char(1),char(197),char(0),char(0), -char(1),char(7),char(0),char(106),char(1),char(27),char(1),char(82),char(0),char(10), -char(180),char(4),char(3),char(45),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(176),char(0),char(0),char(5),char(121),char(5),char(211), -char(2),char(38),char(1),char(229),char(0),char(0),char(1),char(7),char(0),char(106), -char(0),char(197),char(0),char(0),char(0),char(10),char(180),char(4),char(3),char(44), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(47), -char(254),char(117),char(4),char(8),char(5),char(182),char(2),char(38),char(2),char(155), -char(0),char(0),char(0),char(7),char(3),char(128),char(0),char(147),char(0),char(0), -char(255),char(255),char(0),char(18),char(254),char(117),char(3),char(66),char(4),char(72), -char(2),char(38),char(2),char(156),char(0),char(0),char(0),char(6),char(3),char(129), -char(117),char(0),char(255),char(255),char(0),char(8),char(254),char(117),char(4),char(201), -char(5),char(182),char(0),char(38),char(0),char(59),char(0),char(0),char(0),char(7), -char(3),char(128),char(3),char(88),char(0),char(0),char(255),char(255),char(0),char(39), -char(254),char(117),char(4),char(52),char(4),char(72),char(0),char(38),char(0),char(91), -char(0),char(0),char(0),char(7),char(3),char(129),char(2),char(195),char(0),char(0), -char(0),char(1),char(0),char(6),char(0),char(0),char(4),char(150),char(5),char(182), -char(0),char(17),char(0),char(59),char(64),char(34),char(15),char(2),char(17),char(1), -char(16),char(13),char(4),char(10),char(7),char(9),char(6),char(11),char(12),char(19), -char(18),char(10),char(17),char(0),char(17),char(73),char(89),char(7),char(13),char(15), -char(4),char(0),char(0),char(2),char(12),char(15),char(18),char(5),char(2),char(3), -char(0),char(63),char(51),char(63),char(51),char(18),char(57),char(47),char(57),char(18), -char(57),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(49),char(48),char(19),char(33),char(1),char(51),char(1),char(1),char(51), -char(1),char(33),char(21),char(33),char(1),char(35),char(1),char(1),char(35),char(1), -char(33),char(127),char(1),char(51),char(254),char(119),char(188),char(1),char(107),char(1), -char(108),char(183),char(254),char(112),char(1),char(60),char(254),char(186),char(1),char(189), -char(193),char(254),char(119),char(254),char(112),char(182),char(1),char(191),char(254),char(186), -char(3),char(84),char(2),char(98),char(253),char(187),char(2),char(69),char(253),char(158), -char(152),char(253),char(68),char(2),char(131),char(253),char(125),char(2),char(188),char(0), -char(0),char(1),char(0),char(39),char(0),char(0),char(4),char(8),char(4),char(72), -char(0),char(17),char(0),char(59),char(64),char(34),char(15),char(2),char(17),char(1), -char(16),char(13),char(4),char(10),char(7),char(9),char(6),char(11),char(12),char(19), -char(18),char(10),char(17),char(0),char(17),char(71),char(89),char(7),char(13),char(15), -char(4),char(0),char(0),char(2),char(12),char(15),char(21),char(5),char(2),char(15), -char(0),char(63),char(51),char(63),char(51),char(18),char(57),char(47),char(57),char(18), -char(57),char(51),char(43),char(17),char(0),char(51),char(17),char(18),char(1),char(23), -char(57),char(49),char(48),char(19),char(33),char(1),char(51),char(1),char(1),char(51), -char(1),char(33),char(21),char(33),char(1),char(35),char(1),char(1),char(35),char(1), -char(33),char(117),char(1),char(18),char(254),char(180),char(189),char(1),char(33),char(1), -char(32),char(187),char(254),char(178),char(1),char(24),char(254),char(226),char(1),char(104), -char(188),char(254),char(205),char(254),char(202),char(188),char(1),char(102),char(254),char(232), -char(2),char(119),char(1),char(209),char(254),char(92),char(1),char(164),char(254),char(47), -char(129),char(254),char(10),char(1),char(188),char(254),char(68),char(1),char(246),char(0), -char(0),char(2),char(0),char(131),char(0),char(0),char(4),char(55),char(5),char(182), -char(0),char(10),char(0),char(19),char(0),char(52),char(64),char(26),char(4),char(19), -char(19),char(7),char(15),char(0),char(7),char(0),char(21),char(20),char(3),char(12), -char(73),char(89),char(3),char(3),char(8),char(5),char(8),char(18),char(74),char(89), -char(8),char(18),char(5),char(3),char(0),char(63),char(63),char(43),char(17),char(18), -char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(1),char(57),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(19),char(52), -char(36),char(33),char(51),char(17),char(51),char(17),char(33),char(32),char(36),char(1), -char(35),char(34),char(6),char(21),char(20),char(22),char(51),char(51),char(131),char(1), -char(36),char(1),char(32),char(198),char(170),char(254),char(99),char(254),char(245),char(254), -char(244),char(3),char(10),char(186),char(222),char(194),char(182),char(203),char(217),char(1), -char(164),char(212),char(206),char(2),char(112),char(250),char(74),char(213),char(1),char(219), -char(124),char(142),char(143),char(132),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(55),char(6),char(20),char(2),char(6),char(0),char(71),char(0),char(0), -char(0),char(2),char(0),char(131),char(255),char(236),char(6),char(119),char(5),char(182), -char(0),char(25),char(0),char(35),char(0),char(70),char(64),char(36),char(30),char(3), -char(24),char(10),char(10),char(7),char(35),char(15),char(18),char(18),char(35),char(3), -char(3),char(36),char(37),char(6),char(27),char(73),char(89),char(24),char(6),char(16), -char(6),char(16),char(0),char(8),char(3),char(12),char(32),char(0),char(32),char(74), -char(89),char(21),char(0),char(19),char(0),char(63),char(50),char(43),char(17),char(0), -char(51),char(24),char(63),char(18),char(57),char(57),char(47),char(47),char(57),char(43), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51), -char(18),char(57),char(17),char(51),char(49),char(48),char(5),char(34),char(38),char(53), -char(52),char(36),char(33),char(51),char(17),char(51),char(17),char(20),char(51),char(50), -char(54),char(53),char(17),char(51),char(17),char(20),char(6),char(35),char(34),char(38), -char(39),char(6),char(19),char(35),char(34),char(6),char(21),char(16),char(33),char(50), -char(54),char(53),char(2),char(78),char(226),char(233),char(1),char(42),char(1),char(34), -char(145),char(170),char(230),char(100),char(121),char(170),char(207),char(184),char(118),char(159), -char(51),char(113),char(41),char(151),char(212),char(194),char(1),char(33),char(127),char(141), -char(18),char(209),char(208),char(217),char(222),char(2),char(112),char(251),char(183),char(236), -char(123),char(110),char(1),char(230),char(254),char(24),char(174),char(206),char(82),char(90), -char(170),char(2),char(192),char(139),char(150),char(254),char(244),char(119),char(112),char(0), -char(0),char(2),char(0),char(115),char(255),char(236),char(6),char(135),char(6),char(20), -char(0),char(34),char(0),char(46),char(0),char(81),char(64),char(41),char(44),char(19), -char(12),char(32),char(32),char(29),char(26),char(38),char(3),char(6),char(6),char(38), -char(19),char(3),char(47),char(48),char(30),char(0),char(13),char(16),char(26),char(22), -char(4),char(4),char(16),char(22),char(22),char(42),char(70),char(89),char(22),char(16), -char(0),char(35),char(16),char(35),char(70),char(89),char(9),char(16),char(22),char(0), -char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(18),char(57),char(18),char(57),char(63), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(51), -char(51),char(18),char(57),char(17),char(51),char(49),char(48),char(37),char(50),char(54), -char(53),char(17),char(51),char(17),char(20),char(6),char(35),char(34),char(38),char(39), -char(35),char(6),char(6),char(35),char(34),char(2),char(17),char(16),char(18),char(51), -char(50),char(22),char(23),char(51),char(38),char(38),char(53),char(17),char(51),char(17), -char(20),char(22),char(33),char(50),char(54),char(53),char(53),char(52),char(38),char(35), -char(32),char(17),char(20),char(22),char(4),char(254),char(118),char(107),char(168),char(200), -char(189),char(129),char(158),char(43),char(8),char(75),char(185),char(129),char(208),char(232), -char(231),char(207),char(106),char(159),char(63),char(12),char(2),char(8),char(166),char(109), -char(253),char(185),char(162),char(146),char(148),char(162),char(254),char(226),char(139),char(119), -char(132),char(136),char(1),char(57),char(254),char(189),char(200),char(197),char(91),char(113), -char(113),char(91),char(1),char(41),char(1),char(12),char(1),char(12),char(1),char(47), -char(77),char(85),char(17),char(112),char(27),char(1),char(190),char(251),char(140),char(160), -char(137),char(185),char(206),char(35),char(231),char(201),char(254),char(78),char(214),char(210), -char(0),char(1),char(0),char(78),char(255),char(236),char(6),char(129),char(5),char(203), -char(0),char(42),char(0),char(75),char(64),char(40),char(6),char(19),char(40),char(25), -char(31),char(34),char(34),char(22),char(25),char(19),char(1),char(13),char(6),char(43), -char(44),char(23),char(2),char(1),char(2),char(1),char(74),char(89),char(2),char(32), -char(2),char(32),char(37),char(16),char(37),char(28),char(73),char(89),char(37),char(19), -char(16),char(9),char(74),char(89),char(16),char(4),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(24),char(47), -char(47),char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1), -char(35),char(53),char(51),char(50),char(54),char(53),char(52),char(38),char(35),char(34), -char(6),char(7),char(39),char(54),char(54),char(51),char(50),char(22),char(21),char(20), -char(6),char(7),char(21),char(4),char(19),char(22),char(22),char(51),char(50),char(54), -char(53),char(17),char(51),char(17),char(20),char(6),char(35),char(34),char(38),char(39), -char(38),char(38),char(1),char(174),char(201),char(193),char(192),char(213),char(154),char(128), -char(103),char(177),char(103),char(84),char(93),char(246),char(130),char(214),char(245),char(178), -char(156),char(1),char(98),char(6),char(2),char(108),char(124),char(119),char(112),char(168), -char(210),char(189),char(202),char(208),char(2),char(2),char(205),char(2),char(172),char(143), -char(147),char(132),char(108),char(127),char(55),char(69),char(114),char(72),char(80),char(196), -char(167),char(141),char(183),char(26),char(8),char(51),char(254),char(209),char(150),char(127), -char(121),char(135),char(1),char(205),char(254),char(41),char(198),char(199),char(209),char(200), -char(150),char(145),char(0),char(1),char(0),char(80),char(255),char(236),char(5),char(197), -char(4),char(92),char(0),char(37),char(0),char(75),char(64),char(40),char(18),char(30), -char(10),char(36),char(2),char(5),char(5),char(36),char(30),char(32),char(14),char(24), -char(6),char(38),char(39),char(33),char(15),char(14),char(15),char(14),char(70),char(89), -char(15),char(3),char(15),char(3),char(8),char(27),char(27),char(20),char(70),char(89), -char(27),char(16),char(8),char(0),char(70),char(89),char(8),char(22),char(0),char(63), -char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(57), -char(24),char(47),char(47),char(43),char(17),char(18),char(0),char(57),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(49), -char(48),char(37),char(50),char(17),char(17),char(51),char(17),char(20),char(6),char(35), -char(32),char(3),char(38),char(38),char(35),char(35),char(53),char(51),char(32),char(53), -char(52),char(35),char(34),char(6),char(7),char(39),char(54),char(54),char(51),char(50), -char(22),char(21),char(20),char(7),char(21),char(22),char(22),char(23),char(22),char(4), -char(66),char(221),char(166),char(187),char(196),char(254),char(134),char(16),char(5),char(141), -char(148),char(140),char(111),char(1),char(33),char(242),char(75),char(135),char(77),char(57), -char(85),char(163),char(104),char(184),char(211),char(192),char(99),char(123),char(5),char(9), -char(119),char(1),char(12),char(1),char(57),char(254),char(189),char(202),char(195),char(1), -char(77),char(99),char(88),char(141),char(172),char(162),char(36),char(34),char(135),char(40), -char(36),char(155),char(134),char(184),char(57),char(8),char(20),char(122),char(106),char(211), -char(0),char(1),char(0),char(78),char(254),char(131),char(4),char(209),char(5),char(203), -char(0),char(35),char(0),char(74),char(64),char(40),char(25),char(26),char(30),char(35), -char(33),char(32),char(32),char(22),char(26),char(35),char(4),char(16),char(6),char(36), -char(37),char(26),char(5),char(4),char(5),char(4),char(74),char(89),char(5),char(5), -char(35),char(19),char(35),char(30),char(73),char(89),char(35),char(18),char(33),char(34), -char(19),char(12),char(74),char(89),char(19),char(4),char(0),char(63),char(43),char(0), -char(24),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(52), -char(38),char(35),char(35),char(53),char(51),char(50),char(54),char(53),char(52),char(38), -char(35),char(34),char(6),char(7),char(39),char(54),char(54),char(51),char(50),char(22), -char(21),char(20),char(6),char(7),char(21),char(22),char(22),char(21),char(17),char(51), -char(17),char(35),char(17),char(35),char(3),char(131),char(229),char(226),char(217),char(209), -char(205),char(225),char(164),char(135),char(105),char(195),char(105),char(84),char(97),char(254), -char(132),char(220),char(253),char(189),char(163),char(184),char(195),char(172),char(162),char(172), -char(1),char(156),char(133),char(139),char(143),char(147),char(132),char(107),char(128),char(58), -char(66),char(114),char(74),char(78),char(196),char(167),char(140),char(183),char(25),char(8), -char(25),char(179),char(148),char(254),char(254),char(253),char(233),char(1),char(125),char(0), -char(0),char(1),char(0),char(80),char(254),char(135),char(4),char(16),char(4),char(90), -char(0),char(30),char(0),char(74),char(64),char(40),char(7),char(18),char(25),char(30), -char(28),char(27),char(27),char(21),char(30),char(18),char(3),char(13),char(6),char(32), -char(31),char(21),char(4),char(3),char(4),char(3),char(70),char(89),char(4),char(4), -char(30),char(15),char(30),char(25),char(70),char(89),char(30),char(21),char(28),char(34), -char(15),char(10),char(70),char(89),char(15),char(16),char(0),char(63),char(43),char(0), -char(24),char(63),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(52), -char(33),char(35),char(53),char(51),char(32),char(53),char(52),char(38),char(35),char(34), -char(7),char(39),char(54),char(51),char(50),char(22),char(21),char(20),char(7),char(21), -char(22),char(22),char(21),char(21),char(51),char(17),char(35),char(17),char(35),char(2), -char(213),char(254),char(203),char(150),char(117),char(1),char(57),char(133),char(119),char(153), -char(150),char(61),char(161),char(203),char(191),char(213),char(203),char(126),char(112),char(157), -char(166),char(149),char(1),char(45),char(199),char(141),char(172),char(82),char(80),char(70), -char(135),char(74),char(154),char(135),char(182),char(57),char(11),char(37),char(137),char(102), -char(156),char(253),char(248),char(1),char(121),char(0),char(0),char(1),char(0),char(0), -char(255),char(233),char(7),char(33),char(5),char(182),char(0),char(35),char(0),char(58), -char(64),char(29),char(20),char(35),char(26),char(29),char(29),char(35),char(9),char(3), -char(36),char(37),char(27),char(27),char(7),char(18),char(18),char(1),char(73),char(89), -char(18),char(3),char(23),char(12),char(7),char(12),char(74),char(89),char(32),char(7), -char(19),char(0),char(63),char(51),char(43),char(17),char(0),char(51),char(24),char(63), -char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(17),char(18),char(1), -char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(33), -char(7),char(2),char(2),char(6),char(6),char(35),char(34),char(39),char(53),char(22), -char(51),char(50),char(54),char(54),char(18),char(18),char(19),char(33),char(17),char(20), -char(22),char(51),char(50),char(54),char(53),char(17),char(51),char(17),char(20),char(6), -char(35),char(34),char(38),char(53),char(4),char(12),char(254),char(72),char(31),char(43), -char(76),char(83),char(130),char(100),char(69),char(64),char(50),char(63),char(49),char(64), -char(44),char(56),char(74),char(55),char(2),char(239),char(111),char(115),char(112),char(113), -char(168),char(205),char(188),char(196),char(200),char(5),char(31),char(240),char(254),char(174), -char(254),char(68),char(210),char(102),char(25),char(143),char(26),char(62),char(104),char(1), -char(2),char(1),char(233),char(1),char(174),char(251),char(207),char(137),char(121),char(121), -char(135),char(1),char(205),char(254),char(41),char(193),char(204),char(204),char(197),char(0), -char(0),char(1),char(0),char(16),char(255),char(236),char(6),char(41),char(4),char(70), -char(0),char(29),char(0),char(58),char(64),char(29),char(0),char(14),char(5),char(8), -char(8),char(14),char(22),char(3),char(31),char(30),char(6),char(6),char(20),char(28), -char(28),char(16),char(70),char(89),char(28),char(15),char(3),char(25),char(20),char(25), -char(71),char(89),char(11),char(20),char(22),char(0),char(63),char(51),char(43),char(17), -char(0),char(51),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24), -char(47),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(20),char(22),char(51),char(50),char(17),char(17),char(51), -char(17),char(20),char(6),char(35),char(34),char(38),char(53),char(17),char(33),char(2), -char(2),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50),char(18), -char(19),char(33),char(3),char(207),char(104),char(119),char(213),char(166),char(187),char(190), -char(188),char(203),char(254),char(197),char(28),char(94),char(152),char(118),char(58),char(28), -char(22),char(28),char(113),char(137),char(34),char(2),char(113),char(1),char(131),char(137), -char(131),char(1),char(10),char(1),char(59),char(254),char(189),char(202),char(195),char(196), -char(203),char(2),char(61),char(254),char(152),char(254),char(100),char(192),char(10),char(127), -char(6),char(1),char(217),char(1),char(246),char(0),char(0),char(1),char(0),char(201), -char(255),char(236),char(7),char(94),char(5),char(182),char(0),char(25),char(0),char(67), -char(64),char(35),char(23),char(0),char(15),char(6),char(9),char(22),char(18),char(18), -char(19),char(9),char(15),char(19),char(3),char(26),char(27),char(22),char(17),char(73), -char(89),char(22),char(7),char(22),char(7),char(19),char(24),char(20),char(3),char(19), -char(18),char(12),char(3),char(73),char(89),char(12),char(19),char(0),char(63),char(43), -char(0),char(24),char(63),char(63),char(51),char(18),char(57),char(57),char(47),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(1),char(20),char(22), -char(51),char(50),char(54),char(53),char(17),char(51),char(17),char(20),char(6),char(35), -char(34),char(38),char(53),char(17),char(33),char(17),char(35),char(17),char(51),char(17), -char(33),char(17),char(51),char(4),char(246),char(110),char(115),char(112),char(113),char(166), -char(200),char(191),char(195),char(200),char(253),char(39),char(170),char(170),char(2),char(217), -char(170),char(1),char(133),char(137),char(121),char(121),char(135),char(1),char(205),char(254), -char(41),char(191),char(206),char(203),char(198),char(1),char(51),char(253),char(80),char(5), -char(182),char(253),char(146),char(2),char(110),char(0),char(0),char(1),char(0),char(176), -char(255),char(236),char(6),char(168),char(4),char(72),char(0),char(24),char(0),char(77), -char(64),char(42),char(5),char(2),char(19),char(10),char(13),char(1),char(22),char(22), -char(23),char(13),char(19),char(23),char(3),char(25),char(26),char(1),char(21),char(70), -char(89),char(15),char(1),char(31),char(1),char(2),char(11),char(3),char(1),char(11), -char(1),char(11),char(23),char(3),char(24),char(15),char(23),char(21),char(16),char(8), -char(70),char(89),char(16),char(22),char(0),char(63),char(43),char(0),char(24),char(63), -char(63),char(51),char(18),char(57),char(57),char(47),char(47),char(95),char(94),char(93), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(51),char(49),char(48),char(1),char(17),char(33), -char(17),char(51),char(17),char(20),char(22),char(51),char(50),char(17),char(17),char(51), -char(17),char(20),char(6),char(35),char(34),char(38),char(53),char(53),char(33),char(17), -char(35),char(17),char(1),char(86),char(2),char(80),char(166),char(106),char(119),char(213), -char(166),char(187),char(192),char(186),char(205),char(253),char(176),char(166),char(4),char(72), -char(254),char(53),char(1),char(203),char(253),char(61),char(137),char(133),char(1),char(12), -char(1),char(57),char(254),char(189),char(202),char(195),char(198),char(201),char(115),char(254), -char(18),char(4),char(72),char(0),char(0),char(1),char(0),char(125),char(255),char(236), -char(5),char(154),char(5),char(203),char(0),char(28),char(0),char(58),char(64),char(31), -char(22),char(8),char(27),char(2),char(2),char(15),char(28),char(8),char(4),char(29), -char(30),char(0),char(28),char(73),char(89),char(0),char(0),char(5),char(12),char(12), -char(19),char(73),char(89),char(12),char(4),char(5),char(25),char(73),char(89),char(5), -char(19),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18), -char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(33),char(21),char(16), -char(0),char(33),char(32),char(0),char(17),char(52),char(18),char(36),char(51),char(50), -char(22),char(23),char(7),char(38),char(38),char(35),char(32),char(0),char(17),char(16), -char(0),char(51),char(32),char(17),char(33),char(3),char(102),char(2),char(52),char(254), -char(204),char(254),char(201),char(254),char(187),char(254),char(147),char(179),char(1),char(85), -char(234),char(120),char(237),char(83),char(66),char(90),char(214),char(87),char(254),char(245), -char(254),char(222),char(1),char(11),char(247),char(1),char(180),char(254),char(127),char(2), -char(240),char(86),char(254),char(161),char(254),char(177),char(1),char(145),char(1),char(96), -char(229),char(1),char(84),char(181),char(49),char(39),char(148),char(38),char(46),char(254), -char(197),char(254),char(227),char(254),char(227),char(254),char(195),char(1),char(215),char(0), -char(0),char(1),char(0),char(115),char(255),char(236),char(4),char(176),char(4),char(92), -char(0),char(25),char(0),char(58),char(64),char(31),char(18),char(7),char(24),char(2), -char(2),char(12),char(25),char(7),char(4),char(26),char(27),char(0),char(25),char(70), -char(89),char(0),char(0),char(4),char(10),char(10),char(15),char(70),char(89),char(10), -char(16),char(4),char(21),char(70),char(89),char(4),char(22),char(0),char(63),char(43), -char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(33),char(21),char(16),char(33),char(32),char(0),char(17), -char(16),char(0),char(33),char(50),char(23),char(7),char(38),char(35),char(34),char(6), -char(21),char(20),char(22),char(51),char(50),char(54),char(53),char(33),char(2),char(178), -char(1),char(254),char(253),char(254),char(254),char(238),char(254),char(215),char(1),char(67), -char(1),char(33),char(212),char(175),char(59),char(168),char(166),char(205),char(229),char(204), -char(197),char(169),char(175),char(254),char(170),char(2),char(63),char(67),char(253),char(240), -char(1),char(39),char(1),char(16),char(1),char(14),char(1),char(43),char(80),char(131), -char(74),char(222),char(210),char(207),char(223),char(160),char(157),char(0),char(0),char(1), -char(0),char(16),char(255),char(236),char(4),char(244),char(5),char(182),char(0),char(20), -char(0),char(57),char(64),char(29),char(5),char(19),char(10),char(13),char(13),char(3), -char(19),char(0),char(4),char(21),char(22),char(11),char(11),char(16),char(1),char(16), -char(8),char(73),char(89),char(16),char(19),char(4),char(0),char(1),char(0),char(73), -char(89),char(1),char(3),char(0),char(63),char(43),char(17),char(0),char(51),char(24), -char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(17),char(18), -char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(19), -char(53),char(33),char(21),char(33),char(17),char(20),char(22),char(51),char(50),char(17), -char(17),char(51),char(17),char(20),char(6),char(35),char(34),char(38),char(53),char(17), -char(16),char(4),char(60),char(254),char(47),char(119),char(114),char(232),char(168),char(211), -char(189),char(198),char(205),char(5),char(29),char(153),char(153),char(252),char(104),char(137), -char(123),char(1),char(0),char(1),char(207),char(254),char(41),char(192),char(205),char(206), -char(195),char(3),char(160),char(0),char(0),char(1),char(0),char(41),char(255),char(236), -char(4),char(135),char(4),char(70),char(0),char(20),char(0),char(54),char(64),char(28), -char(2),char(16),char(7),char(10),char(10),char(0),char(16),char(18),char(4),char(21), -char(22),char(1),char(18),char(19),char(18),char(70),char(89),char(8),char(8),char(13), -char(19),char(15),char(13),char(5),char(70),char(89),char(13),char(22),char(0),char(63), -char(43),char(0),char(24),char(63),char(18),char(57),char(47),char(43),char(17),char(0), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(49),char(48),char(1),char(33),char(17),char(20),char(22),char(51),char(50),char(17), -char(17),char(51),char(17),char(20),char(6),char(35),char(34),char(38),char(53),char(17), -char(33),char(53),char(33),char(3),char(129),char(254),char(166),char(109),char(118),char(215), -char(166),char(189),char(192),char(192),char(201),char(254),char(168),char(3),char(88),char(3), -char(186),char(253),char(201),char(137),char(131),char(1),char(4),char(1),char(65),char(254), -char(189),char(202),char(195),char(203),char(196),char(2),char(63),char(140),char(0),char(1), -char(0),char(111),char(255),char(236),char(4),char(88),char(5),char(203),char(0),char(38), -char(0),char(71),char(64),char(38),char(21),char(32),char(12),char(0),char(36),char(35), -char(5),char(27),char(17),char(35),char(0),char(32),char(6),char(39),char(40),char(35), -char(15),char(18),char(15),char(18),char(74),char(89),char(15),char(15),char(29),char(3), -char(29),char(24),char(74),char(89),char(29),char(19),char(3),char(9),char(74),char(89), -char(3),char(4),char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17), -char(18),char(0),char(57),char(24),char(47),char(43),char(17),char(18),char(0),char(57), -char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51),char(17), -char(51),char(49),char(48),char(19),char(52),char(36),char(51),char(32),char(23),char(7), -char(38),char(38),char(35),char(34),char(6),char(21),char(20),char(22),char(51),char(51), -char(21),char(35),char(34),char(6),char(21),char(20),char(22),char(51),char(50),char(55), -char(21),char(6),char(33),char(32),char(36),char(53),char(52),char(54),char(55),char(53), -char(38),char(38),char(156),char(1),char(8),char(225),char(1),char(2),char(209),char(94), -char(105),char(181),char(101),char(140),char(159),char(209),char(200),char(217),char(213),char(222), -char(232),char(202),char(183),char(233),char(199),char(175),char(254),char(251),char(254),char(244), -char(254),char(219),char(207),char(188),char(170),char(180),char(4),char(92),char(169),char(198), -char(144),char(120),char(68),char(52),char(123),char(114),char(128),char(147),char(141),char(142), -char(138),char(142),char(141),char(92),char(158),char(77),char(220),char(197),char(151),char(192), -char(22),char(8),char(25),char(178),char(255),char(255),char(0),char(90),char(255),char(236), -char(3),char(135),char(4),char(92),char(2),char(6),char(1),char(130),char(0),char(0), -char(255),char(255),char(0),char(0),char(254),char(117),char(5),char(107),char(5),char(182), -char(0),char(38),char(1),char(181),char(0),char(0),char(0),char(7),char(3),char(128), -char(3),char(250),char(0),char(0),char(255),char(255),char(0),char(16),char(254),char(117), -char(4),char(115),char(4),char(72),char(2),char(38),char(1),char(213),char(0),char(0), -char(0),char(7),char(3),char(129),char(3),char(2),char(0),char(0),char(255),char(255), -char(0),char(0),char(254),char(160),char(5),char(16),char(5),char(188),char(2),char(38), -char(0),char(36),char(0),char(0),char(0),char(7),char(2),char(103),char(4),char(233), -char(0),char(0),char(255),char(255),char(0),char(94),char(254),char(160),char(3),char(205), -char(4),char(90),char(2),char(38),char(0),char(68),char(0),char(0),char(0),char(7), -char(2),char(103),char(4),char(121),char(0),char(0),char(255),char(255),char(0),char(0), -char(0),char(0),char(5),char(16),char(7),char(225),char(2),char(38),char(0),char(36), -char(0),char(0),char(1),char(7),char(2),char(102),char(4),char(252),char(1),char(82), -char(0),char(8),char(179),char(2),char(19),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205),char(6),char(143), -char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(7),char(2),char(102), -char(4),char(166),char(0),char(0),char(0),char(8),char(179),char(2),char(41),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(0),char(0),char(0), -char(5),char(16),char(7),char(209),char(2),char(38),char(0),char(36),char(0),char(0), -char(1),char(7),char(3),char(119),char(4),char(229),char(1),char(82),char(0),char(10), -char(180),char(3),char(2),char(21),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(94),char(255),char(236),char(4),char(65),char(6),char(127), -char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(7),char(3),char(119), -char(4),char(147),char(0),char(0),char(0),char(10),char(180),char(3),char(2),char(43), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(0), -char(0),char(0),char(5),char(16),char(7),char(209),char(2),char(38),char(0),char(36), -char(0),char(0),char(1),char(7),char(3),char(120),char(4),char(221),char(1),char(82), -char(0),char(10),char(180),char(3),char(2),char(21),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(45),char(255),char(236),char(3),char(205), -char(6),char(127),char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(7), -char(3),char(120),char(4),char(147),char(0),char(0),char(0),char(10),char(180),char(3), -char(2),char(43),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(8),char(74),char(2),char(38), -char(0),char(36),char(0),char(0),char(1),char(7),char(3),char(121),char(4),char(217), -char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(21),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(94),char(255),char(236), -char(4),char(23),char(6),char(248),char(2),char(38),char(0),char(68),char(0),char(0), -char(1),char(7),char(3),char(121),char(4),char(156),char(0),char(0),char(0),char(10), -char(180),char(3),char(2),char(43),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16),char(8),char(98), -char(2),char(38),char(0),char(36),char(0),char(0),char(1),char(7),char(3),char(122), -char(4),char(229),char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(45), -char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(94), -char(255),char(236),char(3),char(205),char(7),char(16),char(2),char(38),char(0),char(68), -char(0),char(0),char(1),char(7),char(3),char(122),char(4),char(145),char(0),char(0), -char(0),char(10),char(180),char(3),char(2),char(67),char(17),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(0),char(254),char(160),char(5),char(16), -char(7),char(115),char(2),char(38),char(0),char(36),char(0),char(0),char(0),char(39), -char(2),char(103),char(4),char(233),char(0),char(0),char(1),char(7),char(1),char(75), -char(0),char(43),char(1),char(82),char(0),char(8),char(179),char(3),char(41),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(94),char(254),char(160), -char(3),char(205),char(6),char(33),char(2),char(38),char(0),char(68),char(0),char(0), -char(0),char(39),char(2),char(103),char(4),char(121),char(0),char(0),char(1),char(6), -char(1),char(75),char(212),char(0),char(0),char(8),char(179),char(3),char(62),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(0),char(0),char(0), -char(5),char(16),char(8),char(19),char(2),char(38),char(0),char(36),char(0),char(0), -char(1),char(7),char(3),char(123),char(4),char(236),char(1),char(82),char(0),char(10), -char(180),char(3),char(2),char(23),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205),char(6),char(193), -char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(7),char(3),char(123), -char(4),char(154),char(0),char(0),char(0),char(10),char(180),char(3),char(2),char(45), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(0), -char(0),char(0),char(5),char(16),char(8),char(19),char(2),char(38),char(0),char(36), -char(0),char(0),char(1),char(7),char(3),char(124),char(4),char(233),char(1),char(82), -char(0),char(10),char(180),char(3),char(2),char(23),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(94),char(255),char(236),char(3),char(205), -char(6),char(193),char(2),char(38),char(0),char(68),char(0),char(0),char(1),char(7), -char(3),char(124),char(4),char(152),char(0),char(0),char(0),char(10),char(180),char(3), -char(2),char(45),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(5),char(16),char(8),char(88),char(2),char(38), -char(0),char(36),char(0),char(0),char(1),char(7),char(3),char(125),char(4),char(233), -char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(33),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(94),char(255),char(236), -char(3),char(205),char(7),char(6),char(2),char(38),char(0),char(68),char(0),char(0), -char(1),char(7),char(3),char(125),char(4),char(160),char(0),char(0),char(0),char(10), -char(180),char(3),char(2),char(55),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(0),char(0),char(0),char(5),char(16),char(8),char(94), -char(2),char(38),char(0),char(36),char(0),char(0),char(1),char(7),char(3),char(126), -char(4),char(227),char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(39), -char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(94), -char(255),char(236),char(3),char(205),char(7),char(12),char(2),char(38),char(0),char(68), -char(0),char(0),char(1),char(7),char(3),char(126),char(4),char(152),char(0),char(0), -char(0),char(10),char(180),char(3),char(2),char(61),char(17),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(0),char(254),char(160),char(5),char(16), -char(7),char(73),char(2),char(38),char(0),char(36),char(0),char(0),char(0),char(39), -char(1),char(78),char(0),char(45),char(1),char(100),char(1),char(7),char(2),char(103), -char(4),char(233),char(0),char(0),char(0),char(8),char(179),char(2),char(15),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(94),char(254),char(160), -char(3),char(205),char(5),char(229),char(2),char(38),char(0),char(68),char(0),char(0), -char(0),char(38),char(1),char(78),char(216),char(0),char(1),char(7),char(2),char(103), -char(4),char(121),char(0),char(0),char(0),char(8),char(179),char(2),char(37),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201),char(254),char(160), -char(3),char(248),char(5),char(182),char(2),char(38),char(0),char(40),char(0),char(0), -char(0),char(7),char(2),char(103),char(4),char(193),char(0),char(0),char(255),char(255), -char(0),char(115),char(254),char(160),char(4),char(18),char(4),char(92),char(2),char(38), -char(0),char(72),char(0),char(0),char(0),char(7),char(2),char(103),char(4),char(184), -char(0),char(0),char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248), -char(7),char(225),char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7), -char(2),char(102),char(4),char(209),char(1),char(82),char(0),char(8),char(179),char(1), -char(16),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(255),char(236),char(4),char(18),char(6),char(143),char(2),char(38),char(0),char(72), -char(0),char(0),char(1),char(7),char(2),char(102),char(4),char(201),char(0),char(0), -char(0),char(8),char(179),char(2),char(31),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248),char(7),char(47), -char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7),char(1),char(82), -char(255),char(228),char(1),char(82),char(0),char(8),char(179),char(1),char(21),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(18),char(5),char(221),char(2),char(38),char(0),char(72),char(0),char(0), -char(1),char(6),char(1),char(82),char(208),char(0),char(0),char(8),char(179),char(2), -char(36),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201), -char(0),char(0),char(4),char(111),char(7),char(209),char(2),char(38),char(0),char(40), -char(0),char(0),char(1),char(7),char(3),char(119),char(4),char(193),char(1),char(82), -char(0),char(10),char(180),char(2),char(1),char(18),char(5),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(92), -char(6),char(127),char(2),char(38),char(0),char(72),char(0),char(0),char(1),char(7), -char(3),char(119),char(4),char(174),char(0),char(0),char(0),char(10),char(180),char(3), -char(2),char(33),char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(93),char(0),char(0),char(3),char(248),char(7),char(209),char(2),char(38), -char(0),char(40),char(0),char(0),char(1),char(7),char(3),char(120),char(4),char(195), -char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(18),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(74),char(255),char(236), -char(4),char(18),char(6),char(127),char(2),char(38),char(0),char(72),char(0),char(0), -char(1),char(7),char(3),char(120),char(4),char(176),char(0),char(0),char(0),char(10), -char(180),char(3),char(2),char(33),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(201),char(0),char(0),char(4),char(57),char(8),char(74), -char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7),char(3),char(121), -char(4),char(190),char(1),char(82),char(0),char(10),char(180),char(2),char(1),char(18), -char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(115), -char(255),char(236),char(4),char(29),char(6),char(248),char(2),char(38),char(0),char(72), -char(0),char(0),char(1),char(7),char(3),char(121),char(4),char(162),char(0),char(0), -char(0),char(10),char(180),char(3),char(2),char(33),char(17),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(201),char(0),char(0),char(3),char(248), -char(8),char(98),char(2),char(38),char(0),char(40),char(0),char(0),char(1),char(7), -char(3),char(122),char(4),char(184),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(42),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(4),char(18),char(7),char(16),char(2),char(38), -char(0),char(72),char(0),char(0),char(1),char(7),char(3),char(122),char(4),char(162), -char(0),char(0),char(0),char(10),char(180),char(3),char(2),char(57),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(201),char(254),char(160), -char(3),char(248),char(7),char(115),char(2),char(38),char(0),char(40),char(0),char(0), -char(0),char(39),char(2),char(103),char(4),char(190),char(0),char(0),char(1),char(7), -char(1),char(75),char(0),char(2),char(1),char(82),char(0),char(8),char(179),char(2), -char(37),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115), -char(254),char(160),char(4),char(18),char(6),char(33),char(2),char(38),char(0),char(72), -char(0),char(0),char(0),char(39),char(2),char(103),char(4),char(176),char(0),char(0), -char(1),char(6),char(1),char(75),char(241),char(0),char(0),char(8),char(179),char(3), -char(52),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(84), -char(0),char(0),char(2),char(86),char(7),char(225),char(2),char(38),char(0),char(44), -char(0),char(0),char(1),char(7),char(2),char(102),char(3),char(201),char(1),char(82), -char(0),char(8),char(179),char(1),char(16),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(123),char(0),char(0),char(1),char(230),char(6),char(143), -char(2),char(38),char(0),char(243),char(0),char(0),char(1),char(7),char(2),char(102), -char(3),char(115),char(0),char(0),char(0),char(8),char(179),char(1),char(8),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(84),char(254),char(160), -char(2),char(86),char(5),char(182),char(2),char(38),char(0),char(44),char(0),char(0), -char(0),char(7),char(2),char(103),char(3),char(180),char(0),char(0),char(255),char(255), -char(0),char(157),char(254),char(160),char(1),char(102),char(5),char(223),char(2),char(38), -char(0),char(76),char(0),char(0),char(0),char(7),char(2),char(103),char(3),char(98), -char(0),char(0),char(255),char(255),char(0),char(125),char(254),char(160),char(5),char(190), -char(5),char(205),char(2),char(38),char(0),char(50),char(0),char(0),char(0),char(7), -char(2),char(103),char(5),char(127),char(0),char(0),char(255),char(255),char(0),char(115), -char(254),char(160),char(4),char(98),char(4),char(92),char(2),char(38),char(0),char(82), -char(0),char(0),char(0),char(7),char(2),char(103),char(4),char(201),char(0),char(0), -char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190),char(7),char(225), -char(2),char(38),char(0),char(50),char(0),char(0),char(1),char(7),char(2),char(102), -char(5),char(143),char(1),char(82),char(0),char(8),char(179),char(2),char(28),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(98),char(6),char(143),char(2),char(38),char(0),char(82),char(0),char(0), -char(1),char(7),char(2),char(102),char(4),char(217),char(0),char(0),char(0),char(8), -char(179),char(2),char(29),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(5),char(190),char(7),char(209),char(2),char(38), -char(0),char(50),char(0),char(0),char(1),char(7),char(3),char(119),char(5),char(125), -char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(30),char(5),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(4),char(117),char(6),char(127),char(2),char(38),char(0),char(82),char(0),char(0), -char(1),char(7),char(3),char(119),char(4),char(199),char(0),char(0),char(0),char(10), -char(180),char(3),char(2),char(31),char(17),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190),char(7),char(209), -char(2),char(38),char(0),char(50),char(0),char(0),char(1),char(7),char(3),char(120), -char(5),char(125),char(1),char(82),char(0),char(10),char(180),char(3),char(2),char(30), -char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(97), -char(255),char(236),char(4),char(98),char(6),char(127),char(2),char(38),char(0),char(82), -char(0),char(0),char(1),char(7),char(3),char(120),char(4),char(199),char(0),char(0), -char(0),char(10),char(180),char(3),char(2),char(31),char(17),char(38),char(0),char(43), -char(53),char(53),char(255),char(255),char(0),char(125),char(255),char(236),char(5),char(190), -char(8),char(74),char(2),char(38),char(0),char(50),char(0),char(0),char(1),char(7), -char(3),char(121),char(5),char(123),char(1),char(82),char(0),char(10),char(180),char(3), -char(2),char(30),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(4),char(98),char(6),char(248),char(2),char(38), -char(0),char(82),char(0),char(0),char(1),char(7),char(3),char(121),char(4),char(199), -char(0),char(0),char(0),char(10),char(180),char(3),char(2),char(31),char(17),char(38), -char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(5),char(190),char(8),char(98),char(2),char(38),char(0),char(50),char(0),char(0), -char(1),char(7),char(3),char(122),char(5),char(121),char(1),char(82),char(0),char(10), -char(180),char(3),char(2),char(54),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(115),char(255),char(236),char(4),char(98),char(7),char(16), -char(2),char(38),char(0),char(82),char(0),char(0),char(1),char(7),char(3),char(122), -char(4),char(197),char(0),char(0),char(0),char(10),char(180),char(3),char(2),char(55), -char(17),char(38),char(0),char(43),char(53),char(53),char(255),char(255),char(0),char(125), -char(254),char(160),char(5),char(190),char(7),char(115),char(2),char(38),char(0),char(50), -char(0),char(0),char(0),char(39),char(2),char(103),char(5),char(127),char(0),char(0), -char(1),char(7),char(1),char(75),char(0),char(193),char(1),char(82),char(0),char(8), -char(179),char(3),char(49),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(254),char(160),char(4),char(98),char(6),char(33),char(2),char(38), -char(0),char(82),char(0),char(0),char(0),char(39),char(2),char(103),char(4),char(205), -char(0),char(0),char(1),char(6),char(1),char(75),char(14),char(0),char(0),char(8), -char(179),char(3),char(50),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(6),char(100),char(7),char(115),char(2),char(38), -char(2),char(95),char(0),char(0),char(1),char(7),char(0),char(118),char(1),char(43), -char(1),char(82),char(0),char(8),char(179),char(2),char(43),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(5),char(25), -char(6),char(33),char(2),char(38),char(2),char(96),char(0),char(0),char(1),char(6), -char(0),char(118),char(109),char(0),char(0),char(8),char(179),char(2),char(43),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(125),char(255),char(236), -char(6),char(100),char(7),char(115),char(2),char(38),char(2),char(95),char(0),char(0), -char(1),char(7),char(0),char(67),char(0),char(135),char(1),char(82),char(0),char(8), -char(179),char(2),char(35),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(115),char(255),char(236),char(5),char(25),char(6),char(33),char(2),char(38), -char(2),char(96),char(0),char(0),char(1),char(6),char(0),char(67),char(212),char(0), -char(0),char(8),char(179),char(2),char(36),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(125),char(255),char(236),char(6),char(100),char(7),char(225), -char(2),char(38),char(2),char(95),char(0),char(0),char(1),char(7),char(2),char(102), -char(5),char(143),char(1),char(82),char(0),char(8),char(179),char(2),char(38),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236), -char(5),char(25),char(6),char(143),char(2),char(38),char(2),char(96),char(0),char(0), -char(1),char(7),char(2),char(102),char(4),char(217),char(0),char(0),char(0),char(8), -char(179),char(2),char(39),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(125),char(255),char(236),char(6),char(100),char(7),char(47),char(2),char(38), -char(2),char(95),char(0),char(0),char(1),char(7),char(1),char(82),char(0),char(160), -char(1),char(82),char(0),char(8),char(179),char(2),char(43),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(115),char(255),char(236),char(5),char(25), -char(5),char(221),char(2),char(38),char(2),char(96),char(0),char(0),char(1),char(6), -char(1),char(82),char(245),char(0),char(0),char(8),char(179),char(2),char(35),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(125),char(254),char(160), -char(6),char(100),char(6),char(20),char(2),char(38),char(2),char(95),char(0),char(0), -char(0),char(7),char(2),char(103),char(5),char(123),char(0),char(0),char(255),char(255), -char(0),char(115),char(254),char(160),char(5),char(25),char(4),char(240),char(2),char(38), -char(2),char(96),char(0),char(0),char(0),char(7),char(2),char(103),char(4),char(201), -char(0),char(0),char(255),char(255),char(0),char(186),char(254),char(160),char(5),char(25), -char(5),char(182),char(2),char(38),char(0),char(56),char(0),char(0),char(0),char(7), -char(2),char(103),char(5),char(74),char(0),char(0),char(255),char(255),char(0),char(164), -char(254),char(160),char(4),char(57),char(4),char(72),char(2),char(38),char(0),char(88), -char(0),char(0),char(0),char(7),char(2),char(103),char(4),char(184),char(0),char(0), -char(255),char(255),char(0),char(186),char(255),char(236),char(5),char(25),char(7),char(225), -char(2),char(38),char(0),char(56),char(0),char(0),char(1),char(7),char(2),char(102), -char(5),char(84),char(1),char(82),char(0),char(8),char(179),char(1),char(22),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236), -char(4),char(57),char(6),char(143),char(2),char(38),char(0),char(88),char(0),char(0), -char(1),char(7),char(2),char(102),char(4),char(213),char(0),char(0),char(0),char(8), -char(179),char(1),char(25),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(186),char(255),char(236),char(6),char(123),char(7),char(115),char(2),char(38), -char(2),char(97),char(0),char(0),char(1),char(7),char(0),char(118),char(0),char(238), -char(1),char(82),char(0),char(8),char(179),char(1),char(37),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236),char(5),char(150), -char(6),char(33),char(2),char(38),char(2),char(98),char(0),char(0),char(1),char(6), -char(0),char(118),char(121),char(0),char(0),char(8),char(179),char(1),char(38),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(186),char(255),char(236), -char(6),char(123),char(7),char(115),char(2),char(38),char(2),char(97),char(0),char(0), -char(1),char(7),char(0),char(67),char(0),char(90),char(1),char(82),char(0),char(8), -char(179),char(1),char(29),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(164),char(255),char(236),char(5),char(150),char(6),char(33),char(2),char(38), -char(2),char(98),char(0),char(0),char(1),char(6),char(0),char(67),char(187),char(0), -char(0),char(8),char(179),char(1),char(31),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(186),char(255),char(236),char(6),char(123),char(7),char(225), -char(2),char(38),char(2),char(97),char(0),char(0),char(1),char(7),char(2),char(102), -char(5),char(96),char(1),char(82),char(0),char(8),char(179),char(1),char(32),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236), -char(5),char(150),char(6),char(143),char(2),char(38),char(2),char(98),char(0),char(0), -char(1),char(7),char(2),char(102),char(4),char(219),char(0),char(0),char(0),char(8), -char(179),char(1),char(34),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(186),char(255),char(236),char(6),char(123),char(7),char(47),char(2),char(38), -char(2),char(97),char(0),char(0),char(1),char(7),char(1),char(82),char(0),char(127), -char(1),char(82),char(0),char(8),char(179),char(1),char(37),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(164),char(255),char(236),char(5),char(150), -char(5),char(221),char(2),char(38),char(2),char(98),char(0),char(0),char(1),char(6), -char(1),char(82),char(255),char(0),char(0),char(8),char(179),char(1),char(30),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(186),char(254),char(160), -char(6),char(123),char(6),char(20),char(2),char(38),char(2),char(97),char(0),char(0), -char(0),char(7),char(2),char(103),char(5),char(76),char(0),char(0),char(255),char(255), -char(0),char(164),char(254),char(160),char(5),char(150),char(4),char(242),char(2),char(38), -char(2),char(98),char(0),char(0),char(0),char(7),char(2),char(103),char(4),char(178), -char(0),char(0),char(255),char(255),char(0),char(0),char(254),char(160),char(4),char(123), -char(5),char(182),char(2),char(38),char(0),char(60),char(0),char(0),char(0),char(7), -char(2),char(103),char(4),char(156),char(0),char(0),char(255),char(255),char(0),char(2), -char(254),char(20),char(4),char(6),char(4),char(72),char(2),char(38),char(0),char(92), -char(0),char(0),char(0),char(7),char(2),char(103),char(5),char(158),char(255),char(253), -char(255),char(255),char(0),char(0),char(0),char(0),char(4),char(123),char(7),char(225), -char(2),char(38),char(0),char(60),char(0),char(0),char(1),char(7),char(2),char(102), -char(4),char(170),char(1),char(82),char(0),char(8),char(179),char(1),char(13),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(2),char(254),char(20), -char(4),char(6),char(6),char(143),char(2),char(38),char(0),char(92),char(0),char(0), -char(1),char(7),char(2),char(102),char(4),char(106),char(0),char(0),char(0),char(8), -char(179),char(1),char(26),char(17),char(38),char(0),char(43),char(53),char(255),char(255), -char(0),char(0),char(0),char(0),char(4),char(123),char(7),char(47),char(2),char(38), -char(0),char(60),char(0),char(0),char(1),char(7),char(1),char(82),char(255),char(194), -char(1),char(82),char(0),char(8),char(179),char(1),char(18),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(2),char(254),char(20),char(4),char(6), -char(5),char(221),char(2),char(38),char(0),char(92),char(0),char(0),char(1),char(6), -char(1),char(82),char(138),char(0),char(0),char(8),char(179),char(1),char(31),char(17), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(115),char(254),char(197), -char(4),char(211),char(6),char(20),char(2),char(38),char(0),char(211),char(0),char(0), -char(0),char(7),char(0),char(66),char(0),char(180),char(0),char(0),char(0),char(2), -char(251),char(229),char(4),char(217),char(254),char(180),char(6),char(33),char(0),char(9), -char(0),char(19),char(0),char(30),char(64),char(12),char(4),char(10),char(14),char(14), -char(0),char(0),char(21),char(15),char(6),char(128),char(11),char(1),char(0),char(47), -char(51),char(26),char(205),char(50),char(17),char(1),char(51),char(17),char(51),char(18), -char(57),char(57),char(49),char(48),char(1),char(35),char(38),char(38),char(39),char(53), -char(51),char(22),char(22),char(23),char(5),char(35),char(38),char(38),char(39),char(53), -char(51),char(22),char(22),char(23),char(254),char(180),char(96),char(52),char(177),char(37), -char(186),char(28),char(99),char(49),char(254),char(156),char(96),char(56),char(174),char(37), -char(187),char(28),char(99),char(49),char(4),char(217),char(42),char(202),char(63),char(21), -char(61),char(174),char(68),char(25),char(44),char(200),char(63),char(21),char(61),char(174), -char(68),char(0),char(0),char(2),char(252),char(113),char(4),char(217),char(255),char(174), -char(6),char(127),char(0),char(13),char(0),char(21),char(0),char(40),char(64),char(17), -char(21),char(0),char(6),char(17),char(17),char(23),char(3),char(6),char(10),char(21), -char(10),char(21),char(10),char(17),char(192),char(6),char(1),char(0),char(47),char(51), -char(26),char(204),char(57),char(57),char(47),char(47),char(17),char(18),char(57),char(17), -char(1),char(51),char(17),char(51),char(57),char(57),char(49),char(48),char(1),char(35), -char(38),char(39),char(6),char(7),char(35),char(53),char(55),char(54),char(55),char(51), -char(22),char(23),char(39),char(54),char(55),char(51),char(21),char(6),char(7),char(35), -char(254),char(211),char(94),char(112),char(99),char(114),char(97),char(94),char(53),char(112), -char(52),char(176),char(66),char(151),char(80),char(73),char(54),char(172),char(83),char(120), -char(96),char(4),char(217),char(75),char(91),char(101),char(65),char(25),char(60),char(123), -char(77),char(94),char(166),char(194),char(91),char(112),char(21),char(110),char(96),char(0), -char(0),char(2),char(251),char(154),char(4),char(217),char(254),char(215),char(6),char(127), -char(0),char(13),char(0),char(21),char(0),char(42),char(64),char(18),char(6),char(14), -char(17),char(17),char(0),char(0),char(23),char(3),char(6),char(10),char(15),char(10), -char(15),char(10),char(19),char(192),char(6),char(1),char(0),char(47),char(51),char(26), -char(204),char(57),char(57),char(47),char(47),char(17),char(18),char(57),char(17),char(1), -char(51),char(17),char(51),char(18),char(57),char(57),char(49),char(48),char(1),char(35), -char(38),char(39),char(6),char(7),char(35),char(53),char(55),char(54),char(55),char(51), -char(22),char(23),char(37),char(35),char(38),char(39),char(53),char(51),char(22),char(23), -char(254),char(215),char(94),char(97),char(114),char(106),char(105),char(94),char(53),char(112), -char(52),char(176),char(66),char(151),char(253),char(238),char(95),char(120),char(84),char(172), -char(52),char(75),char(4),char(217),char(65),char(101),char(96),char(70),char(23),char(60), -char(123),char(77),char(94),char(166),char(172),char(94),char(112),char(21),char(108),char(97), -char(0),char(2),char(252),char(113),char(4),char(217),char(255),char(123),char(6),char(248), -char(0),char(13),char(0),char(31),char(0),char(52),char(64),char(24),char(16),char(19), -char(0),char(19),char(27),char(3),char(6),char(6),char(22),char(14),char(14),char(33), -char(3),char(10),char(6),char(18),char(10),char(18),char(10),char(25),char(30),char(192), -char(6),char(1),char(0),char(47),char(51),char(26),char(204),char(50),char(57),char(57), -char(47),char(47),char(17),char(18),char(57),char(17),char(1),char(51),char(17),char(51), -char(51),char(18),char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(35), -char(38),char(39),char(6),char(7),char(35),char(53),char(55),char(54),char(55),char(51), -char(22),char(23),char(19),char(20),char(7),char(7),char(35),char(39),char(54),char(54), -char(53),char(52),char(38),char(35),char(34),char(7),char(53),char(54),char(51),char(50), -char(254),char(211),char(94),char(112),char(99),char(114),char(97),char(94),char(53),char(112), -char(52),char(176),char(66),char(151),char(168),char(127),char(6),char(80),char(10),char(57), -char(63),char(57),char(43),char(46),char(26),char(25),char(55),char(195),char(4),char(217), -char(75),char(91),char(101),char(65),char(25),char(60),char(123),char(77),char(94),char(166), -char(1),char(123),char(103),char(29),char(81),char(131),char(9),char(32),char(38),char(37), -char(25),char(6),char(80),char(6),char(0),char(2),char(252),char(104),char(4),char(217), -char(254),char(231),char(7),char(16),char(0),char(23),char(0),char(37),char(0),char(58), -char(64),char(27),char(24),char(30),char(9),char(9),char(21),char(21),char(39),char(27), -char(30),char(34),char(30),char(25),char(17),char(9),char(0),char(5),char(12),char(34), -char(0),char(12),char(12),char(0),char(34),char(3),char(21),char(192),char(25),char(0), -char(47),char(26),char(204),char(23),char(57),char(47),char(47),char(47),char(17),char(51), -char(16),char(196),char(51),char(17),char(51),char(17),char(18),char(57),char(17),char(1), -char(51),char(17),char(51),char(18),char(57),char(57),char(49),char(48),char(1),char(34), -char(46),char(2),char(35),char(34),char(6),char(7),char(35),char(54),char(54),char(51), -char(50),char(30),char(2),char(51),char(50),char(54),char(55),char(51),char(6),char(6), -char(19),char(35),char(38),char(39),char(6),char(7),char(35),char(53),char(55),char(54), -char(55),char(51),char(22),char(23),char(254),char(45),char(37),char(71),char(67),char(63), -char(28),char(40),char(42),char(14),char(91),char(13),char(101),char(75),char(37),char(73), -char(67),char(62),char(27),char(40),char(42),char(12),char(90),char(11),char(99),char(94), -char(94),char(97),char(114),char(106),char(105),char(94),char(53),char(112),char(52),char(176), -char(66),char(151),char(6),char(53),char(30),char(37),char(30),char(49),char(50),char(106), -char(113),char(30),char(36),char(30),char(49),char(49),char(104),char(115),char(254),char(164), -char(65),char(101),char(96),char(70),char(23),char(60),char(123),char(77),char(94),char(166), -char(0),char(2),char(252),char(121),char(4),char(217),char(254),char(199),char(6),char(193), -char(0),char(7),char(0),char(20),char(0),char(36),char(64),char(15),char(7),char(4), -char(10),char(10),char(18),char(18),char(22),char(3),char(64),char(7),char(17),char(10), -char(128),char(14),char(8),char(0),char(47),char(51),char(26),char(221),char(50),char(212), -char(26),char(205),char(17),char(1),char(51),char(17),char(51),char(18),char(57),char(57), -char(49),char(48),char(1),char(54),char(55),char(51),char(21),char(6),char(7),char(35), -char(19),char(32),char(3),char(51),char(22),char(22),char(51),char(50),char(54),char(55), -char(51),char(6),char(6),char(253),char(94),char(80),char(49),char(172),char(86),char(119), -char(96),char(62),char(254),char(236),char(15),char(102),char(9),char(76),char(106),char(98), -char(86),char(8),char(105),char(11),char(149),char(5),char(244),char(104),char(101),char(21), -char(114),char(93),char(254),char(252),char(1),char(4),char(72),char(57),char(65),char(64), -char(120),char(140),char(0),char(2),char(252),char(121),char(4),char(217),char(254),char(199), -char(6),char(193),char(0),char(7),char(0),char(20),char(0),char(36),char(64),char(15), -char(7),char(4),char(10),char(10),char(18),char(18),char(22),char(4),char(64),char(1), -char(17),char(10),char(128),char(14),char(8),char(0),char(47),char(51),char(26),char(221), -char(50),char(212),char(26),char(205),char(17),char(1),char(51),char(17),char(51),char(18), -char(57),char(57),char(49),char(48),char(1),char(35),char(38),char(39),char(53),char(51), -char(22),char(23),char(3),char(32),char(3),char(51),char(22),char(22),char(51),char(50), -char(54),char(55),char(51),char(6),char(6),char(253),char(209),char(94),char(119),char(86), -char(172),char(52),char(75),char(53),char(254),char(236),char(15),char(102),char(9),char(76), -char(106),char(98),char(86),char(8),char(105),char(11),char(149),char(5),char(221),char(93), -char(114),char(21),char(108),char(97),char(254),char(229),char(1),char(4),char(72),char(57), -char(65),char(64),char(120),char(140),char(0),char(2),char(252),char(121),char(4),char(217), -char(254),char(199),char(7),char(6),char(0),char(17),char(0),char(30),char(0),char(46), -char(64),char(21),char(8),char(0),char(0),char(5),char(13),char(3),char(20),char(20), -char(28),char(28),char(32),char(11),char(16),char(4),char(4),char(24),char(24),char(27), -char(20),char(128),char(18),char(0),char(47),char(26),char(205),char(50),char(51),char(17), -char(57),char(47),char(196),char(50),char(17),char(1),char(51),char(17),char(51),char(18), -char(23),char(57),char(17),char(51),char(49),char(48),char(1),char(20),char(7),char(7), -char(35),char(39),char(54),char(54),char(53),char(52),char(38),char(35),char(34),char(7), -char(53),char(54),char(51),char(50),char(3),char(32),char(3),char(51),char(22),char(22), -char(51),char(50),char(54),char(55),char(51),char(6),char(6),char(254),char(49),char(127), -char(6),char(82),char(10),char(57),char(66),char(57),char(44),char(37),char(36),char(22), -char(62),char(192),char(149),char(254),char(236),char(15),char(102),char(9),char(76),char(106), -char(98),char(86),char(8),char(105),char(11),char(149),char(6),char(121),char(100),char(29), -char(41),char(90),char(9),char(32),char(37),char(37),char(26),char(6),char(78),char(8), -char(253),char(211),char(1),char(4),char(72),char(57),char(65),char(64),char(120),char(140), -char(0),char(2),char(252),char(104),char(4),char(217),char(254),char(231),char(7),char(12), -char(0),char(23),char(0),char(36),char(0),char(48),char(64),char(21),char(26),char(34), -char(9),char(9),char(21),char(38),char(5),char(12),char(12),char(30),char(30),char(24), -char(21),char(64),char(17),char(9),char(0),char(33),char(26),char(128),char(24),char(0), -char(47),char(26),char(221),char(50),char(214),char(196),char(51),char(26),char(205),char(17), -char(51),char(17),char(57),char(47),char(51),char(17),char(1),char(51),char(50),char(17), -char(57),char(57),char(49),char(48),char(1),char(34),char(46),char(2),char(35),char(34), -char(6),char(7),char(35),char(54),char(54),char(51),char(50),char(30),char(2),char(51), -char(50),char(54),char(55),char(51),char(6),char(6),char(3),char(32),char(3),char(51), -char(22),char(22),char(51),char(50),char(54),char(55),char(51),char(6),char(6),char(254), -char(45),char(37),char(71),char(67),char(63),char(28),char(40),char(42),char(14),char(91), -char(13),char(100),char(76),char(37),char(73),char(67),char(62),char(27),char(40),char(42), -char(12),char(90),char(11),char(99),char(221),char(254),char(236),char(15),char(102),char(9), -char(76),char(106),char(98),char(86),char(8),char(105),char(11),char(149),char(6),char(51), -char(30),char(36),char(30),char(48),char(50),char(104),char(113),char(30),char(36),char(30), -char(49),char(49),char(103),char(114),char(254),char(166),char(1),char(4),char(72),char(57), -char(65),char(64),char(120),char(140),char(0),char(1),char(0),char(49),char(254),char(66), -char(1),char(109),char(0),char(0),char(0),char(15),char(0),char(26),char(64),char(11), -char(0),char(5),char(5),char(2),char(10),char(3),char(16),char(17),char(13),char(8), -char(3),char(0),char(47),char(204),char(50),char(17),char(18),char(1),char(23),char(57), -char(17),char(51),char(49),char(48),char(23),char(52),char(39),char(51),char(22),char(21), -char(20),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50),char(54), -char(223),char(139),char(123),char(158),char(102),char(99),char(65),char(50),char(32),char(54), -char(37),char(51),char(238),char(103),char(135),char(120),char(132),char(91),char(103),char(16), -char(108),char(10),char(48),char(0),char(0),char(1),char(0),char(25),char(254),char(117), -char(1),char(113),char(0),char(154),char(0),char(11),char(0),char(24),char(64),char(9), -char(10),char(0),char(6),char(0),char(12),char(13),char(8),char(3),char(0),char(0), -char(47),char(204),char(50),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(49),char(48),char(37),char(17),char(16),char(35),char(34),char(39),char(53),char(22), -char(51),char(50),char(53),char(17),char(1),char(113),char(228),char(56),char(60),char(41), -char(61),char(94),char(154),char(254),char(223),char(254),char(252),char(24),char(140),char(19), -char(100),char(1),char(48),char(0),char(0),char(1),char(0),char(25),char(254),char(117), -char(1),char(113),char(0),char(143),char(0),char(11),char(0),char(24),char(64),char(9), -char(10),char(0),char(6),char(0),char(12),char(13),char(8),char(3),char(0),char(0), -char(47),char(204),char(50),char(17),char(18),char(1),char(57),char(57),char(17),char(51), -char(49),char(48),char(37),char(17),char(16),char(35),char(34),char(39),char(53),char(22), -char(51),char(50),char(53),char(17),char(1),char(113),char(228),char(56),char(60),char(41), -char(61),char(94),char(143),char(254),char(234),char(254),char(252),char(24),char(140),char(19), -char(100),char(1),char(37),char(0),char(255),char(255),char(0),char(52),char(0),char(0), -char(2),char(67),char(5),char(182),char(0),char(7),char(0),char(20),char(255),char(120), -char(0),char(0),char(0),char(2),char(0),char(115),char(255),char(236),char(4),char(23), -char(4),char(115),char(0),char(11),char(0),char(23),char(0),char(40),char(64),char(20), -char(12),char(6),char(18),char(0),char(6),char(0),char(24),char(25),char(9),char(21), -char(75),char(89),char(9),char(38),char(3),char(15),char(77),char(89),char(3),char(25), -char(0),char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(1), -char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(16), -char(2),char(35),char(34),char(2),char(17),char(16),char(18),char(51),char(50),char(18), -char(1),char(20),char(22),char(51),char(50),char(54),char(53),char(52),char(38),char(35), -char(34),char(6),char(4),char(23),char(247),char(222),char(217),char(246),char(249),char(218), -char(216),char(249),char(253),char(4),char(155),char(142),char(141),char(158),char(158),char(143), -char(141),char(154),char(2),char(47),char(254),char(245),char(254),char(200),char(1),char(53), -char(1),char(14),char(1),char(15),char(1),char(53),char(254),char(203),char(254),char(241), -char(208),char(232),char(234),char(206),char(204),char(236),char(233),char(0),char(0),char(1), -char(0),char(45),char(0),char(0),char(2),char(55),char(4),char(94),char(0),char(10), -char(0),char(38),char(64),char(17),char(9),char(1),char(1),char(0),char(8),char(0), -char(11),char(12),char(7),char(4),char(7),char(4),char(1),char(9),char(16),char(1), -char(24),char(0),char(63),char(63),char(18),char(57),char(57),char(47),char(47),char(17), -char(18),char(1),char(57),char(57),char(17),char(51),char(17),char(51),char(49),char(48), -char(33),char(35),char(17),char(52),char(55),char(6),char(7),char(7),char(39),char(1), -char(51),char(2),char(55),char(161),char(8),char(67),char(62),char(150),char(90),char(1), -char(127),char(139),char(2),char(49),char(239),char(140),char(67),char(48),char(112),char(114), -char(1),char(35),char(0),char(1),char(0),char(41),char(0),char(0),char(3),char(215), -char(4),char(115),char(0),char(25),char(0),char(44),char(64),char(24),char(7),char(19), -char(0),char(19),char(23),char(14),char(1),char(5),char(26),char(27),char(16),char(10), -char(75),char(89),char(16),char(38),char(24),char(23),char(1),char(23),char(76),char(89), -char(1),char(24),char(0),char(63),char(43),char(17),char(0),char(51),char(24),char(63), -char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(49),char(48), -char(33),char(33),char(53),char(1),char(62),char(2),char(53),char(52),char(38),char(35), -char(34),char(6),char(7),char(39),char(54),char(51),char(50),char(22),char(21),char(20), -char(6),char(7),char(5),char(23),char(33),char(3),char(215),char(252),char(82),char(1), -char(145),char(157),char(113),char(44),char(139),char(119),char(88),char(156),char(92),char(90), -char(192),char(242),char(198),char(218),char(130),char(186),char(254),char(185),char(2),char(2), -char(190),char(133),char(1),char(47),char(119),char(104),char(83),char(65),char(87),char(103), -char(61),char(74),char(109),char(168),char(168),char(150),char(115),char(187),char(128),char(231), -char(6),char(0),char(0),char(1),char(0),char(94),char(254),char(149),char(4),char(27), -char(4),char(116),char(0),char(39),char(0),char(71),char(64),char(38),char(3),char(4), -char(27),char(0),char(19),char(7),char(7),char(0),char(4),char(22),char(34),char(13), -char(6),char(40),char(41),char(4),char(23),char(22),char(23),char(22),char(75),char(89), -char(23),char(23),char(10),char(37),char(37),char(30),char(75),char(89),char(37),char(38), -char(10),char(17),char(75),char(89),char(10),char(37),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(43), -char(17),char(18),char(0),char(57),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(17),char(51),char(17),char(51),char(49),char(48),char(1),char(20),char(6), -char(7),char(21),char(22),char(22),char(21),char(20),char(4),char(33),char(34),char(38), -char(39),char(53),char(22),char(22),char(51),char(32),char(17),char(16),char(33),char(35), -char(53),char(51),char(50),char(54),char(53),char(52),char(38),char(35),char(34),char(6), -char(7),char(39),char(54),char(54),char(51),char(50),char(22),char(3),char(238),char(157), -char(144),char(176),char(170),char(254),char(222),char(254),char(245),char(116),char(193),char(91), -char(95),char(215),char(96),char(1),char(123),char(254),char(94),char(144),char(146),char(171), -char(200),char(147),char(126),char(96),char(170),char(109),char(84),char(90),char(235),char(130), -char(213),char(236),char(3),char(7),char(140),char(178),char(30),char(8),char(22),char(180), -char(146),char(209),char(225),char(35),char(44),char(158),char(47),char(49),char(1),char(41), -char(1),char(10),char(143),char(151),char(134),char(107),char(122),char(52),char(70),char(112), -char(71),char(81),char(195),char(0),char(0),char(2),char(0),char(23),char(254),char(168), -char(4),char(102),char(4),char(94),char(0),char(10),char(0),char(18),char(0),char(66), -char(64),char(33),char(18),char(5),char(9),char(2),char(2),char(11),char(7),char(3), -char(0),char(3),char(5),char(3),char(19),char(20),char(1),char(5),char(18),char(5), -char(77),char(89),char(9),char(18),char(14),char(15),char(15),char(7),char(18),char(18), -char(3),char(7),char(16),char(3),char(36),char(0),char(63),char(63),char(18),char(57), -char(47),char(18),char(57),char(17),char(51),char(17),char(51),char(43),char(17),char(0), -char(51),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(51),char(51), -char(17),char(51),char(17),char(51),char(49),char(48),char(37),char(35),char(17),char(35), -char(17),char(33),char(53),char(1),char(51),char(17),char(51),char(33),char(17),char(52), -char(55),char(35),char(6),char(7),char(1),char(4),char(102),char(217),char(168),char(253), -char(50),char(2),char(190),char(184),char(217),char(254),char(134),char(12),char(10),char(41), -char(68),char(254),char(57),char(27),char(254),char(141),char(1),char(115),char(125),char(3), -char(198),char(252),char(68),char(1),char(92),char(218),char(222),char(86),char(92),char(253), -char(158),char(0),char(0),char(1),char(0),char(133),char(254),char(149),char(4),char(29), -char(4),char(95),char(0),char(26),char(0),char(58),char(64),char(31),char(15),char(3), -char(25),char(20),char(8),char(20),char(23),char(3),char(4),char(28),char(27),char(0), -char(17),char(75),char(89),char(0),char(0),char(6),char(21),char(21),char(24),char(76), -char(89),char(21),char(16),char(6),char(12),char(75),char(89),char(6),char(37),char(0), -char(63),char(43),char(0),char(24),char(63),char(43),char(17),char(18),char(0),char(57), -char(24),char(47),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(49),char(48),char(1),char(50),char(4),char(21),char(20),char(0), -char(35),char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53), -char(16),char(33),char(34),char(7),char(39),char(19),char(33),char(21),char(33),char(3), -char(54),char(2),char(45),char(231),char(1),char(9),char(254),char(223),char(254),char(247), -char(130),char(70),char(208),char(101),char(176),char(195),char(254),char(137),char(94),char(160), -char(86),char(55),char(2),char(215),char(253),char(183),char(37),char(115),char(2),char(38), -char(229),char(199),char(227),char(254),char(254),char(79),char(160),char(45),char(51),char(166), -char(157),char(1),char(50),char(29),char(55),char(2),char(172),char(153),char(254),char(73), -char(23),char(0),char(255),char(255),char(0),char(117),char(255),char(236),char(4),char(47), -char(5),char(203),char(2),char(6),char(0),char(25),char(0),char(0),char(0),char(1), -char(0),char(94),char(254),char(169),char(4),char(43),char(4),char(95),char(0),char(6), -char(0),char(31),char(64),char(16),char(1),char(5),char(5),char(0),char(2),char(3), -char(7),char(8),char(3),char(2),char(76),char(89),char(3),char(16),char(0),char(36), -char(0),char(63),char(63),char(43),char(17),char(18),char(1),char(23),char(57),char(17), -char(51),char(49),char(48),char(1),char(1),char(33),char(53),char(33),char(21),char(1), -char(1),char(29),char(2),char(94),char(252),char(227),char(3),char(205),char(253),char(170), -char(254),char(169),char(5),char(29),char(153),char(133),char(250),char(207),char(255),char(255), -char(0),char(104),char(255),char(236),char(4),char(41),char(5),char(203),char(2),char(6), -char(0),char(27),char(0),char(0),char(0),char(2),char(0),char(106),char(254),char(149), -char(4),char(37),char(4),char(116),char(0),char(23),char(0),char(37),char(0),char(65), -char(64),char(34),char(27),char(17),char(34),char(10),char(10),char(0),char(0),char(4), -char(17),char(3),char(38),char(39),char(14),char(30),char(77),char(89),char(10),char(20), -char(14),char(14),char(2),char(20),char(20),char(24),char(75),char(89),char(20),char(38), -char(2),char(7),char(77),char(89),char(2),char(37),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(24),char(47),char(18), -char(57),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17), -char(51),char(17),char(51),char(49),char(48),char(1),char(16),char(33),char(34),char(39), -char(53),char(22),char(51),char(50),char(18),char(19),char(35),char(6),char(6),char(35), -char(34),char(38),char(53),char(52),char(18),char(51),char(50),char(22),char(18),char(1), -char(34),char(6),char(21),char(20),char(22),char(51),char(50),char(54),char(54),char(53), -char(52),char(38),char(38),char(4),char(37),char(253),char(104),char(116),char(68),char(80), -char(102),char(240),char(245),char(11),char(12),char(55),char(182),char(114),char(194),char(228), -char(255),char(208),char(149),char(223),char(120),char(254),char(20),char(143),char(156),char(144), -char(147),char(91),char(153),char(88),char(82),char(147),char(1),char(239),char(252),char(166), -char(20),char(143),char(26),char(1),char(41),char(1),char(51),char(83),char(87),char(232), -char(208),char(228),char(1),char(8),char(153),char(254),char(219),char(1),char(48),char(184), -char(164),char(144),char(165),char(74),char(128),char(70),char(105),char(178),char(102),char(0), -char(255),char(255),char(0),char(29),char(0),char(0),char(5),char(196),char(6),char(31), -char(0),char(39),char(0),char(73),char(2),char(182),char(0),char(0),char(0),char(6), -char(0),char(73),char(0),char(0),char(0),char(2),char(0),char(92),char(2),char(221), -char(5),char(170),char(5),char(193),char(0),char(34),char(0),char(51),char(0),char(90), -char(64),char(46),char(44),char(48),char(48),char(46),char(42),char(38),char(38),char(40), -char(10),char(0),char(28),char(17),char(5),char(17),char(22),char(0),char(40),char(46), -char(6),char(53),char(52),char(43),char(49),char(36),char(3),char(45),char(47),char(45), -char(41),char(47),char(35),char(35),char(40),char(28),char(10),char(20),char(8),char(3), -char(3),char(40),char(41),char(25),char(20),char(20),char(41),char(3),char(0),char(63), -char(51),char(47),char(51),char(16),char(205),char(50),char(47),char(51),char(18),char(57), -char(57),char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(18),char(23), -char(57),char(17),char(18),char(1),char(23),char(57),char(17),char(51),char(17),char(51), -char(17),char(51),char(17),char(51),char(17),char(51),char(17),char(51),char(49),char(48), -char(1),char(20),char(6),char(35),char(34),char(39),char(53),char(22),char(51),char(50), -char(53),char(52),char(38),char(38),char(39),char(38),char(38),char(53),char(52),char(54), -char(51),char(50),char(23),char(7),char(38),char(35),char(34),char(6),char(21),char(20), -char(22),char(22),char(23),char(22),char(22),char(1),char(3),char(35),char(23),char(17), -char(35),char(17),char(51),char(19),char(19),char(51),char(17),char(35),char(17),char(55), -char(35),char(3),char(2),char(72),char(149),char(124),char(145),char(74),char(106),char(119), -char(148),char(23),char(54),char(85),char(120),char(81),char(142),char(110),char(125),char(92), -char(34),char(100),char(83),char(60),char(75),char(18),char(43),char(95),char(129),char(80), -char(1),char(166),char(201),char(8),char(6),char(119),char(188),char(195),char(203),char(180), -char(127),char(6),char(8),char(211),char(3),char(172),char(98),char(109),char(33),char(108), -char(40),char(100),char(33),char(40),char(33),char(31),char(44),char(91),char(76),char(86), -char(105),char(39),char(99),char(37),char(46),char(40),char(29),char(36),char(28),char(36), -char(50),char(90),char(254),char(236),char(2),char(47),char(129),char(254),char(82),char(2), -char(209),char(253),char(209),char(2),char(47),char(253),char(47),char(1),char(164),char(137), -char(253),char(211),char(255),char(255),char(0),char(18),char(254),char(20),char(4),char(90), -char(5),char(182),char(2),char(38),char(0),char(55),char(0),char(0),char(0),char(7), -char(0),char(122),char(1),char(63),char(0),char(0),char(255),char(255),char(0),char(31), -char(254),char(20),char(2),char(168),char(5),char(70),char(2),char(38),char(0),char(87), -char(0),char(0),char(0),char(7),char(0),char(122),char(0),char(197),char(0),char(0), -char(0),char(2),char(0),char(113),char(254),char(20),char(4),char(55),char(4),char(92), -char(0),char(12),char(0),char(42),char(0),char(71),char(64),char(38),char(10),char(21), -char(26),char(3),char(42),char(42),char(30),char(30),char(36),char(21),char(3),char(43), -char(44),char(33),char(39),char(70),char(89),char(36),char(33),char(27),char(28),char(15), -char(26),char(15),char(24),char(18),char(24),char(7),char(70),char(89),char(24),char(16), -char(18),char(0),char(70),char(89),char(18),char(22),char(0),char(63),char(43),char(0), -char(24),char(63),char(43),char(17),char(18),char(0),char(57),char(57),char(24),char(63), -char(63),char(51),char(43),char(17),char(18),char(1),char(23),char(57),char(17),char(51), -char(17),char(51),char(51),char(17),char(51),char(49),char(48),char(37),char(50),char(54), -char(55),char(53),char(52),char(38),char(35),char(34),char(6),char(21),char(20),char(22), -char(5),char(52),char(55),char(35),char(6),char(35),char(34),char(2),char(17),char(16), -char(18),char(51),char(50),char(23),char(51),char(55),char(51),char(17),char(20),char(6), -char(35),char(34),char(39),char(53),char(22),char(22),char(51),char(50),char(54),char(53), -char(2),char(76),char(170),char(151),char(4),char(158),char(171),char(144),char(153),char(151), -char(1),char(219),char(9),char(11),char(112),char(230),char(217),char(239),char(243),char(211), -char(223),char(123),char(11),char(24),char(131),char(236),char(249),char(242),char(149),char(75), -char(210),char(118),char(142),char(165),char(119),char(183),char(202),char(43),char(226),char(204), -char(224),char(208),char(209),char(217),char(107),char(36),char(99),char(167),char(1),char(45), -char(1),char(10),char(1),char(8),char(1),char(49),char(166),char(146),char(251),char(164), -char(236),char(236),char(70),char(158),char(42),char(46),char(169),char(146),char(255),char(255), -char(0),char(113),char(254),char(20),char(4),char(55),char(6),char(33),char(2),char(38), -char(3),char(145),char(0),char(0),char(1),char(6),char(1),char(75),char(6),char(0), -char(0),char(8),char(179),char(2),char(57),char(17),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(113),char(254),char(20),char(4),char(55),char(5),char(229), -char(2),char(38),char(3),char(145),char(0),char(0),char(1),char(6),char(1),char(78), -char(12),char(0),char(0),char(8),char(179),char(2),char(43),char(17),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(113),char(254),char(20),char(4),char(55), -char(5),char(223),char(2),char(38),char(3),char(145),char(0),char(0),char(1),char(7), -char(1),char(79),char(1),char(86),char(0),char(0),char(0),char(8),char(179),char(2), -char(52),char(17),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(113), -char(254),char(20),char(4),char(55),char(6),char(33),char(2),char(38),char(3),char(145), -char(0),char(0),char(1),char(6),char(2),char(58),char(119),char(0),char(0),char(8), -char(179),char(2),char(47),char(17),char(38),char(0),char(43),char(53),char(0),char(1), -char(0),char(201),char(0),char(0),char(1),char(115),char(5),char(182),char(0),char(3), -char(0),char(17),char(182),char(0),char(4),char(5),char(1),char(3),char(0),char(18), -char(0),char(63),char(63),char(17),char(18),char(1),char(57),char(49),char(48),char(51), -char(17),char(51),char(17),char(201),char(170),char(5),char(182),char(250),char(74),char(0), -char(255),char(255),char(0),char(5),char(0),char(0),char(1),char(142),char(7),char(115), -char(2),char(38),char(3),char(150),char(0),char(0),char(1),char(7),char(0),char(67), -char(254),char(124),char(1),char(82),char(0),char(8),char(179),char(1),char(5),char(5), -char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(179),char(0),char(0), -char(2),char(60),char(7),char(115),char(2),char(38),char(3),char(150),char(0),char(0), -char(1),char(7),char(0),char(118),char(255),char(42),char(1),char(82),char(0),char(8), -char(179),char(1),char(13),char(5),char(38),char(0),char(43),char(53),char(255),char(255), -char(255),char(199),char(0),char(0),char(2),char(105),char(7),char(115),char(2),char(38), -char(3),char(150),char(0),char(0),char(1),char(7),char(1),char(75),char(254),char(187), -char(1),char(82),char(0),char(8),char(179),char(1),char(18),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(0),char(5),char(0),char(0),char(2),char(56), -char(7),char(37),char(2),char(38),char(3),char(150),char(0),char(0),char(1),char(7), -char(0),char(106),char(254),char(208),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(25),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(255),char(171),char(0),char(0),char(2),char(147),char(7),char(47),char(2),char(38), -char(3),char(150),char(0),char(0),char(1),char(7),char(1),char(82),char(254),char(163), -char(1),char(82),char(0),char(8),char(179),char(1),char(13),char(5),char(38),char(0), -char(43),char(53),char(255),char(255),char(255),char(243),char(0),char(0),char(2),char(75), -char(6),char(180),char(2),char(38),char(3),char(150),char(0),char(0),char(1),char(7), -char(1),char(77),char(254),char(198),char(1),char(82),char(0),char(8),char(179),char(1), -char(7),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(255),char(231), -char(0),char(0),char(2),char(83),char(7),char(55),char(2),char(38),char(3),char(150), -char(0),char(0),char(1),char(7),char(1),char(78),char(254),char(194),char(1),char(82), -char(0),char(8),char(179),char(1),char(4),char(5),char(38),char(0),char(43),char(53), -char(255),char(255),char(0),char(86),char(254),char(66),char(1),char(162),char(5),char(182), -char(2),char(38),char(3),char(150),char(0),char(0),char(0),char(6),char(1),char(81), -char(49),char(0),char(255),char(255),char(0),char(187),char(0),char(0),char(1),char(127), -char(7),char(49),char(2),char(38),char(3),char(150),char(0),char(0),char(1),char(7), -char(1),char(79),char(0),char(25),char(1),char(82),char(0),char(8),char(179),char(1), -char(13),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(201), -char(254),char(127),char(3),char(163),char(5),char(182),char(0),char(38),char(3),char(150), -char(0),char(0),char(0),char(7),char(0),char(45),char(2),char(59),char(0),char(0), -char(255),char(255),char(255),char(228),char(0),char(0),char(2),char(29),char(6),char(10), -char(0),char(39),char(3),char(150),char(0),char(170),char(0),char(0),char(1),char(7), -char(1),char(84),char(253),char(232),char(255),char(151),char(0),char(7),char(178),char(1), -char(8),char(0),char(0),char(63),char(53),char(0),char(255),char(255),char(0),char(201), -char(0),char(0),char(1),char(115),char(5),char(182),char(2),char(6),char(3),char(150), -char(0),char(0),char(255),char(255),char(0),char(5),char(0),char(0),char(2),char(56), -char(7),char(37),char(2),char(38),char(3),char(150),char(0),char(0),char(1),char(7), -char(0),char(106),char(254),char(208),char(1),char(82),char(0),char(10),char(180),char(2), -char(1),char(25),char(5),char(38),char(0),char(43),char(53),char(53),char(255),char(255), -char(0),char(201),char(0),char(0),char(1),char(115),char(5),char(182),char(2),char(6), -char(3),char(150),char(0),char(0),char(255),char(255),char(0),char(5),char(0),char(0), -char(2),char(56),char(7),char(37),char(2),char(38),char(3),char(150),char(0),char(0), -char(1),char(7),char(0),char(106),char(254),char(208),char(1),char(82),char(0),char(10), -char(180),char(2),char(1),char(25),char(5),char(38),char(0),char(43),char(53),char(53), -char(255),char(255),char(0),char(201),char(0),char(0),char(1),char(115),char(5),char(182), -char(2),char(6),char(3),char(150),char(0),char(0),char(255),char(255),char(0),char(201), -char(0),char(0),char(1),char(115),char(5),char(182),char(2),char(6),char(3),char(150), -char(0),char(0),char(255),char(255),char(0),char(153),char(0),char(0),char(2),char(4), -char(7),char(225),char(2),char(38),char(3),char(150),char(0),char(0),char(1),char(7), -char(2),char(102),char(3),char(145),char(1),char(82),char(0),char(8),char(179),char(1), -char(8),char(5),char(38),char(0),char(43),char(53),char(255),char(255),char(0),char(184), -char(254),char(160),char(1),char(127),char(5),char(182),char(2),char(38),char(3),char(150), -char(0),char(0),char(0),char(7),char(2),char(103),char(3),char(125),char(0),char(0), -char(0),char(0),char(0),char(1),char(0),char(0),char(182),char(50),char(0),char(1), -char(73),char(6),char(128),char(0),char(0),char(14),char(54),char(36),char(0),char(5), -char(0),char(36),char(255),char(113),char(0),char(5),char(0),char(55),char(0),char(41), -char(0),char(5),char(0),char(57),char(0),char(41),char(0),char(5),char(0),char(58), -char(0),char(41),char(0),char(5),char(0),char(60),char(0),char(20),char(0),char(5), -char(0),char(68),char(255),char(174),char(0),char(5),char(0),char(70),char(255),char(133), -char(0),char(5),char(0),char(71),char(255),char(133),char(0),char(5),char(0),char(72), -char(255),char(133),char(0),char(5),char(0),char(74),char(255),char(195),char(0),char(5), -char(0),char(80),char(255),char(195),char(0),char(5),char(0),char(81),char(255),char(195), -char(0),char(5),char(0),char(82),char(255),char(133),char(0),char(5),char(0),char(83), -char(255),char(195),char(0),char(5),char(0),char(84),char(255),char(133),char(0),char(5), -char(0),char(85),char(255),char(195),char(0),char(5),char(0),char(86),char(255),char(195), -char(0),char(5),char(0),char(88),char(255),char(195),char(0),char(5),char(0),char(130), -char(255),char(113),char(0),char(5),char(0),char(131),char(255),char(113),char(0),char(5), -char(0),char(132),char(255),char(113),char(0),char(5),char(0),char(133),char(255),char(113), -char(0),char(5),char(0),char(134),char(255),char(113),char(0),char(5),char(0),char(135), -char(255),char(113),char(0),char(5),char(0),char(159),char(0),char(20),char(0),char(5), -char(0),char(162),char(255),char(133),char(0),char(5),char(0),char(163),char(255),char(174), -char(0),char(5),char(0),char(164),char(255),char(174),char(0),char(5),char(0),char(165), -char(255),char(174),char(0),char(5),char(0),char(166),char(255),char(174),char(0),char(5), -char(0),char(167),char(255),char(174),char(0),char(5),char(0),char(168),char(255),char(174), -char(0),char(5),char(0),char(169),char(255),char(133),char(0),char(5),char(0),char(170), -char(255),char(133),char(0),char(5),char(0),char(171),char(255),char(133),char(0),char(5), -char(0),char(172),char(255),char(133),char(0),char(5),char(0),char(173),char(255),char(133), -char(0),char(5),char(0),char(180),char(255),char(133),char(0),char(5),char(0),char(181), -char(255),char(133),char(0),char(5),char(0),char(182),char(255),char(133),char(0),char(5), -char(0),char(183),char(255),char(133),char(0),char(5),char(0),char(184),char(255),char(133), -char(0),char(5),char(0),char(186),char(255),char(133),char(0),char(5),char(0),char(187), -char(255),char(195),char(0),char(5),char(0),char(188),char(255),char(195),char(0),char(5), -char(0),char(189),char(255),char(195),char(0),char(5),char(0),char(190),char(255),char(195), -char(0),char(5),char(0),char(194),char(255),char(113),char(0),char(5),char(0),char(195), -char(255),char(174),char(0),char(5),char(0),char(196),char(255),char(113),char(0),char(5), -char(0),char(197),char(255),char(174),char(0),char(5),char(0),char(198),char(255),char(113), -char(0),char(5),char(0),char(199),char(255),char(174),char(0),char(5),char(0),char(201), -char(255),char(133),char(0),char(5),char(0),char(203),char(255),char(133),char(0),char(5), -char(0),char(205),char(255),char(133),char(0),char(5),char(0),char(207),char(255),char(133), -char(0),char(5),char(0),char(209),char(255),char(133),char(0),char(5),char(0),char(211), -char(255),char(133),char(0),char(5),char(0),char(213),char(255),char(133),char(0),char(5), -char(0),char(215),char(255),char(133),char(0),char(5),char(0),char(217),char(255),char(133), -char(0),char(5),char(0),char(219),char(255),char(133),char(0),char(5),char(0),char(221), -char(255),char(133),char(0),char(5),char(0),char(223),char(255),char(195),char(0),char(5), -char(0),char(225),char(255),char(195),char(0),char(5),char(0),char(227),char(255),char(195), -char(0),char(5),char(0),char(229),char(255),char(195),char(0),char(5),char(0),char(250), -char(255),char(195),char(0),char(5),char(1),char(6),char(255),char(195),char(0),char(5), -char(1),char(8),char(255),char(195),char(0),char(5),char(1),char(13),char(255),char(195), -char(0),char(5),char(1),char(15),char(255),char(133),char(0),char(5),char(1),char(17), -char(255),char(133),char(0),char(5),char(1),char(19),char(255),char(133),char(0),char(5), -char(1),char(21),char(255),char(133),char(0),char(5),char(1),char(23),char(255),char(195), -char(0),char(5),char(1),char(25),char(255),char(195),char(0),char(5),char(1),char(29), -char(255),char(195),char(0),char(5),char(1),char(33),char(255),char(195),char(0),char(5), -char(1),char(36),char(0),char(41),char(0),char(5),char(1),char(38),char(0),char(41), -char(0),char(5),char(1),char(43),char(255),char(195),char(0),char(5),char(1),char(45), -char(255),char(195),char(0),char(5),char(1),char(47),char(255),char(195),char(0),char(5), -char(1),char(49),char(255),char(195),char(0),char(5),char(1),char(51),char(255),char(195), -char(0),char(5),char(1),char(53),char(255),char(195),char(0),char(5),char(1),char(54), -char(0),char(41),char(0),char(5),char(1),char(56),char(0),char(20),char(0),char(5), -char(1),char(58),char(0),char(20),char(0),char(5),char(1),char(67),char(255),char(113), -char(0),char(5),char(1),char(68),char(255),char(174),char(0),char(5),char(1),char(70), -char(255),char(174),char(0),char(5),char(1),char(72),char(255),char(133),char(0),char(5), -char(1),char(74),char(255),char(195),char(0),char(5),char(1),char(86),char(255),char(113), -char(0),char(5),char(1),char(95),char(255),char(113),char(0),char(5),char(1),char(98), -char(255),char(113),char(0),char(5),char(1),char(105),char(255),char(113),char(0),char(5), -char(1),char(121),char(255),char(174),char(0),char(5),char(1),char(122),char(255),char(215), -char(0),char(5),char(1),char(123),char(255),char(215),char(0),char(5),char(1),char(126), -char(255),char(174),char(0),char(5),char(1),char(129),char(255),char(195),char(0),char(5), -char(1),char(130),char(255),char(215),char(0),char(5),char(1),char(131),char(255),char(215), -char(0),char(5),char(1),char(132),char(255),char(215),char(0),char(5),char(1),char(135), -char(255),char(215),char(0),char(5),char(1),char(137),char(255),char(215),char(0),char(5), -char(1),char(140),char(255),char(174),char(0),char(5),char(1),char(142),char(255),char(195), -char(0),char(5),char(1),char(143),char(255),char(174),char(0),char(5),char(1),char(144), -char(255),char(174),char(0),char(5),char(1),char(147),char(255),char(174),char(0),char(5), -char(1),char(153),char(255),char(174),char(0),char(5),char(1),char(164),char(255),char(133), -char(0),char(5),char(1),char(170),char(255),char(113),char(0),char(5),char(1),char(174), -char(255),char(133),char(0),char(5),char(1),char(181),char(255),char(133),char(0),char(5), -char(1),char(202),char(255),char(215),char(0),char(5),char(1),char(206),char(255),char(113), -char(0),char(5),char(1),char(207),char(255),char(133),char(0),char(5),char(1),char(213), -char(255),char(113),char(0),char(5),char(1),char(216),char(255),char(133),char(0),char(5), -char(1),char(219),char(255),char(133),char(0),char(5),char(1),char(222),char(255),char(133), -char(0),char(5),char(1),char(234),char(255),char(133),char(0),char(5),char(1),char(237), -char(255),char(133),char(0),char(5),char(1),char(238),char(255),char(195),char(0),char(5), -char(1),char(242),char(255),char(113),char(0),char(5),char(1),char(250),char(0),char(41), -char(0),char(5),char(1),char(252),char(0),char(41),char(0),char(5),char(1),char(254), -char(0),char(41),char(0),char(5),char(2),char(0),char(0),char(20),char(0),char(5), -char(2),char(87),char(255),char(195),char(0),char(5),char(2),char(88),char(255),char(113), -char(0),char(5),char(2),char(89),char(255),char(174),char(0),char(5),char(2),char(96), -char(255),char(133),char(0),char(5),char(2),char(98),char(255),char(195),char(0),char(5), -char(2),char(106),char(255),char(133),char(0),char(5),char(2),char(114),char(255),char(113), -char(0),char(5),char(2),char(115),char(255),char(113),char(0),char(5),char(2),char(125), -char(255),char(236),char(0),char(5),char(2),char(127),char(255),char(133),char(0),char(5), -char(2),char(133),char(255),char(133),char(0),char(5),char(2),char(135),char(255),char(133), -char(0),char(5),char(2),char(137),char(255),char(133),char(0),char(5),char(2),char(141), -char(255),char(133),char(0),char(5),char(2),char(178),char(255),char(133),char(0),char(5), -char(2),char(180),char(255),char(133),char(0),char(5),char(2),char(206),char(255),char(133), -char(0),char(5),char(2),char(207),char(255),char(113),char(0),char(5),char(2),char(217), -char(255),char(113),char(0),char(5),char(2),char(218),char(255),char(215),char(0),char(5), -char(2),char(219),char(255),char(113),char(0),char(5),char(2),char(220),char(255),char(215), -char(0),char(5),char(2),char(221),char(255),char(113),char(0),char(5),char(2),char(222), -char(255),char(215),char(0),char(5),char(2),char(224),char(255),char(133),char(0),char(5), -char(2),char(226),char(255),char(215),char(0),char(5),char(2),char(228),char(255),char(215), -char(0),char(5),char(2),char(240),char(255),char(133),char(0),char(5),char(2),char(242), -char(255),char(133),char(0),char(5),char(2),char(244),char(255),char(133),char(0),char(5), -char(3),char(9),char(255),char(113),char(0),char(5),char(3),char(10),char(255),char(133), -char(0),char(5),char(3),char(11),char(255),char(113),char(0),char(5),char(3),char(12), -char(255),char(133),char(0),char(5),char(3),char(17),char(255),char(133),char(0),char(5), -char(3),char(18),char(255),char(113),char(0),char(5),char(3),char(22),char(255),char(133), -char(0),char(5),char(3),char(26),char(255),char(133),char(0),char(5),char(3),char(27), -char(255),char(133),char(0),char(5),char(3),char(28),char(255),char(113),char(0),char(5), -char(3),char(29),char(255),char(113),char(0),char(5),char(3),char(30),char(255),char(174), -char(0),char(5),char(3),char(31),char(255),char(113),char(0),char(5),char(3),char(32), -char(255),char(174),char(0),char(5),char(3),char(33),char(255),char(113),char(0),char(5), -char(3),char(34),char(255),char(174),char(0),char(5),char(3),char(35),char(255),char(113), -char(0),char(5),char(3),char(37),char(255),char(113),char(0),char(5),char(3),char(38), -char(255),char(174),char(0),char(5),char(3),char(39),char(255),char(113),char(0),char(5), -char(3),char(40),char(255),char(174),char(0),char(5),char(3),char(41),char(255),char(113), -char(0),char(5),char(3),char(42),char(255),char(174),char(0),char(5),char(3),char(43), -char(255),char(113),char(0),char(5),char(3),char(44),char(255),char(174),char(0),char(5), -char(3),char(45),char(255),char(113),char(0),char(5),char(3),char(46),char(255),char(174), -char(0),char(5),char(3),char(47),char(255),char(113),char(0),char(5),char(3),char(48), -char(255),char(174),char(0),char(5),char(3),char(49),char(255),char(113),char(0),char(5), -char(3),char(50),char(255),char(174),char(0),char(5),char(3),char(51),char(255),char(113), -char(0),char(5),char(3),char(52),char(255),char(174),char(0),char(5),char(3),char(54), -char(255),char(133),char(0),char(5),char(3),char(56),char(255),char(133),char(0),char(5), -char(3),char(58),char(255),char(133),char(0),char(5),char(3),char(60),char(255),char(133), -char(0),char(5),char(3),char(64),char(255),char(133),char(0),char(5),char(3),char(66), -char(255),char(133),char(0),char(5),char(3),char(68),char(255),char(133),char(0),char(5), -char(3),char(74),char(255),char(133),char(0),char(5),char(3),char(76),char(255),char(133), -char(0),char(5),char(3),char(78),char(255),char(133),char(0),char(5),char(3),char(82), -char(255),char(133),char(0),char(5),char(3),char(84),char(255),char(133),char(0),char(5), -char(3),char(86),char(255),char(133),char(0),char(5),char(3),char(88),char(255),char(133), -char(0),char(5),char(3),char(90),char(255),char(133),char(0),char(5),char(3),char(92), -char(255),char(133),char(0),char(5),char(3),char(94),char(255),char(133),char(0),char(5), -char(3),char(96),char(255),char(133),char(0),char(5),char(3),char(98),char(255),char(195), -char(0),char(5),char(3),char(100),char(255),char(195),char(0),char(5),char(3),char(102), -char(255),char(195),char(0),char(5),char(3),char(104),char(255),char(195),char(0),char(5), -char(3),char(106),char(255),char(195),char(0),char(5),char(3),char(108),char(255),char(195), -char(0),char(5),char(3),char(110),char(255),char(195),char(0),char(5),char(3),char(111), -char(0),char(20),char(0),char(5),char(3),char(113),char(0),char(20),char(0),char(5), -char(3),char(115),char(0),char(20),char(0),char(5),char(3),char(143),char(0),char(41), -char(0),char(10),char(0),char(36),char(255),char(113),char(0),char(10),char(0),char(55), -char(0),char(41),char(0),char(10),char(0),char(57),char(0),char(41),char(0),char(10), -char(0),char(58),char(0),char(41),char(0),char(10),char(0),char(60),char(0),char(20), -char(0),char(10),char(0),char(68),char(255),char(174),char(0),char(10),char(0),char(70), -char(255),char(133),char(0),char(10),char(0),char(71),char(255),char(133),char(0),char(10), -char(0),char(72),char(255),char(133),char(0),char(10),char(0),char(74),char(255),char(195), -char(0),char(10),char(0),char(80),char(255),char(195),char(0),char(10),char(0),char(81), -char(255),char(195),char(0),char(10),char(0),char(82),char(255),char(133),char(0),char(10), -char(0),char(83),char(255),char(195),char(0),char(10),char(0),char(84),char(255),char(133), -char(0),char(10),char(0),char(85),char(255),char(195),char(0),char(10),char(0),char(86), -char(255),char(195),char(0),char(10),char(0),char(88),char(255),char(195),char(0),char(10), -char(0),char(130),char(255),char(113),char(0),char(10),char(0),char(131),char(255),char(113), -char(0),char(10),char(0),char(132),char(255),char(113),char(0),char(10),char(0),char(133), -char(255),char(113),char(0),char(10),char(0),char(134),char(255),char(113),char(0),char(10), -char(0),char(135),char(255),char(113),char(0),char(10),char(0),char(159),char(0),char(20), -char(0),char(10),char(0),char(162),char(255),char(133),char(0),char(10),char(0),char(163), -char(255),char(174),char(0),char(10),char(0),char(164),char(255),char(174),char(0),char(10), -char(0),char(165),char(255),char(174),char(0),char(10),char(0),char(166),char(255),char(174), -char(0),char(10),char(0),char(167),char(255),char(174),char(0),char(10),char(0),char(168), -char(255),char(174),char(0),char(10),char(0),char(169),char(255),char(133),char(0),char(10), -char(0),char(170),char(255),char(133),char(0),char(10),char(0),char(171),char(255),char(133), -char(0),char(10),char(0),char(172),char(255),char(133),char(0),char(10),char(0),char(173), -char(255),char(133),char(0),char(10),char(0),char(180),char(255),char(133),char(0),char(10), -char(0),char(181),char(255),char(133),char(0),char(10),char(0),char(182),char(255),char(133), -char(0),char(10),char(0),char(183),char(255),char(133),char(0),char(10),char(0),char(184), -char(255),char(133),char(0),char(10),char(0),char(186),char(255),char(133),char(0),char(10), -char(0),char(187),char(255),char(195),char(0),char(10),char(0),char(188),char(255),char(195), -char(0),char(10),char(0),char(189),char(255),char(195),char(0),char(10),char(0),char(190), -char(255),char(195),char(0),char(10),char(0),char(194),char(255),char(113),char(0),char(10), -char(0),char(195),char(255),char(174),char(0),char(10),char(0),char(196),char(255),char(113), -char(0),char(10),char(0),char(197),char(255),char(174),char(0),char(10),char(0),char(198), -char(255),char(113),char(0),char(10),char(0),char(199),char(255),char(174),char(0),char(10), -char(0),char(201),char(255),char(133),char(0),char(10),char(0),char(203),char(255),char(133), -char(0),char(10),char(0),char(205),char(255),char(133),char(0),char(10),char(0),char(207), -char(255),char(133),char(0),char(10),char(0),char(209),char(255),char(133),char(0),char(10), -char(0),char(211),char(255),char(133),char(0),char(10),char(0),char(213),char(255),char(133), -char(0),char(10),char(0),char(215),char(255),char(133),char(0),char(10),char(0),char(217), -char(255),char(133),char(0),char(10),char(0),char(219),char(255),char(133),char(0),char(10), -char(0),char(221),char(255),char(133),char(0),char(10),char(0),char(223),char(255),char(195), -char(0),char(10),char(0),char(225),char(255),char(195),char(0),char(10),char(0),char(227), -char(255),char(195),char(0),char(10),char(0),char(229),char(255),char(195),char(0),char(10), -char(0),char(250),char(255),char(195),char(0),char(10),char(1),char(6),char(255),char(195), -char(0),char(10),char(1),char(8),char(255),char(195),char(0),char(10),char(1),char(13), -char(255),char(195),char(0),char(10),char(1),char(15),char(255),char(133),char(0),char(10), -char(1),char(17),char(255),char(133),char(0),char(10),char(1),char(19),char(255),char(133), -char(0),char(10),char(1),char(21),char(255),char(133),char(0),char(10),char(1),char(23), -char(255),char(195),char(0),char(10),char(1),char(25),char(255),char(195),char(0),char(10), -char(1),char(29),char(255),char(195),char(0),char(10),char(1),char(33),char(255),char(195), -char(0),char(10),char(1),char(36),char(0),char(41),char(0),char(10),char(1),char(38), -char(0),char(41),char(0),char(10),char(1),char(43),char(255),char(195),char(0),char(10), -char(1),char(45),char(255),char(195),char(0),char(10),char(1),char(47),char(255),char(195), -char(0),char(10),char(1),char(49),char(255),char(195),char(0),char(10),char(1),char(51), -char(255),char(195),char(0),char(10),char(1),char(53),char(255),char(195),char(0),char(10), -char(1),char(54),char(0),char(41),char(0),char(10),char(1),char(56),char(0),char(20), -char(0),char(10),char(1),char(58),char(0),char(20),char(0),char(10),char(1),char(67), -char(255),char(113),char(0),char(10),char(1),char(68),char(255),char(174),char(0),char(10), -char(1),char(70),char(255),char(174),char(0),char(10),char(1),char(72),char(255),char(133), -char(0),char(10),char(1),char(74),char(255),char(195),char(0),char(10),char(1),char(86), -char(255),char(113),char(0),char(10),char(1),char(95),char(255),char(113),char(0),char(10), -char(1),char(98),char(255),char(113),char(0),char(10),char(1),char(105),char(255),char(113), -char(0),char(10),char(1),char(121),char(255),char(174),char(0),char(10),char(1),char(122), -char(255),char(215),char(0),char(10),char(1),char(123),char(255),char(215),char(0),char(10), -char(1),char(126),char(255),char(174),char(0),char(10),char(1),char(129),char(255),char(195), -char(0),char(10),char(1),char(130),char(255),char(215),char(0),char(10),char(1),char(131), -char(255),char(215),char(0),char(10),char(1),char(132),char(255),char(215),char(0),char(10), -char(1),char(135),char(255),char(215),char(0),char(10),char(1),char(137),char(255),char(215), -char(0),char(10),char(1),char(140),char(255),char(174),char(0),char(10),char(1),char(142), -char(255),char(195),char(0),char(10),char(1),char(143),char(255),char(174),char(0),char(10), -char(1),char(144),char(255),char(174),char(0),char(10),char(1),char(147),char(255),char(174), -char(0),char(10),char(1),char(153),char(255),char(174),char(0),char(10),char(1),char(164), -char(255),char(133),char(0),char(10),char(1),char(170),char(255),char(113),char(0),char(10), -char(1),char(174),char(255),char(133),char(0),char(10),char(1),char(181),char(255),char(133), -char(0),char(10),char(1),char(202),char(255),char(215),char(0),char(10),char(1),char(206), -char(255),char(113),char(0),char(10),char(1),char(207),char(255),char(133),char(0),char(10), -char(1),char(213),char(255),char(113),char(0),char(10),char(1),char(216),char(255),char(133), -char(0),char(10),char(1),char(219),char(255),char(133),char(0),char(10),char(1),char(222), -char(255),char(133),char(0),char(10),char(1),char(234),char(255),char(133),char(0),char(10), -char(1),char(237),char(255),char(133),char(0),char(10),char(1),char(238),char(255),char(195), -char(0),char(10),char(1),char(242),char(255),char(113),char(0),char(10),char(1),char(250), -char(0),char(41),char(0),char(10),char(1),char(252),char(0),char(41),char(0),char(10), -char(1),char(254),char(0),char(41),char(0),char(10),char(2),char(0),char(0),char(20), -char(0),char(10),char(2),char(87),char(255),char(195),char(0),char(10),char(2),char(88), -char(255),char(113),char(0),char(10),char(2),char(89),char(255),char(174),char(0),char(10), -char(2),char(96),char(255),char(133),char(0),char(10),char(2),char(98),char(255),char(195), -char(0),char(10),char(2),char(106),char(255),char(133),char(0),char(10),char(2),char(114), -char(255),char(113),char(0),char(10),char(2),char(115),char(255),char(113),char(0),char(10), -char(2),char(125),char(255),char(236),char(0),char(10),char(2),char(127),char(255),char(133), -char(0),char(10),char(2),char(133),char(255),char(133),char(0),char(10),char(2),char(135), -char(255),char(133),char(0),char(10),char(2),char(137),char(255),char(133),char(0),char(10), -char(2),char(141),char(255),char(133),char(0),char(10),char(2),char(178),char(255),char(133), -char(0),char(10),char(2),char(180),char(255),char(133),char(0),char(10),char(2),char(206), -char(255),char(133),char(0),char(10),char(2),char(207),char(255),char(113),char(0),char(10), -char(2),char(217),char(255),char(113),char(0),char(10),char(2),char(218),char(255),char(215), -char(0),char(10),char(2),char(219),char(255),char(113),char(0),char(10),char(2),char(220), -char(255),char(215),char(0),char(10),char(2),char(221),char(255),char(113),char(0),char(10), -char(2),char(222),char(255),char(215),char(0),char(10),char(2),char(224),char(255),char(133), -char(0),char(10),char(2),char(226),char(255),char(215),char(0),char(10),char(2),char(228), -char(255),char(215),char(0),char(10),char(2),char(240),char(255),char(133),char(0),char(10), -char(2),char(242),char(255),char(133),char(0),char(10),char(2),char(244),char(255),char(133), -char(0),char(10),char(3),char(9),char(255),char(113),char(0),char(10),char(3),char(10), -char(255),char(133),char(0),char(10),char(3),char(11),char(255),char(113),char(0),char(10), -char(3),char(12),char(255),char(133),char(0),char(10),char(3),char(17),char(255),char(133), -char(0),char(10),char(3),char(18),char(255),char(113),char(0),char(10),char(3),char(22), -char(255),char(133),char(0),char(10),char(3),char(26),char(255),char(133),char(0),char(10), -char(3),char(27),char(255),char(133),char(0),char(10),char(3),char(28),char(255),char(113), -char(0),char(10),char(3),char(29),char(255),char(113),char(0),char(10),char(3),char(30), -char(255),char(174),char(0),char(10),char(3),char(31),char(255),char(113),char(0),char(10), -char(3),char(32),char(255),char(174),char(0),char(10),char(3),char(33),char(255),char(113), -char(0),char(10),char(3),char(34),char(255),char(174),char(0),char(10),char(3),char(35), -char(255),char(113),char(0),char(10),char(3),char(37),char(255),char(113),char(0),char(10), -char(3),char(38),char(255),char(174),char(0),char(10),char(3),char(39),char(255),char(113), -char(0),char(10),char(3),char(40),char(255),char(174),char(0),char(10),char(3),char(41), -char(255),char(113),char(0),char(10),char(3),char(42),char(255),char(174),char(0),char(10), -char(3),char(43),char(255),char(113),char(0),char(10),char(3),char(44),char(255),char(174), -char(0),char(10),char(3),char(45),char(255),char(113),char(0),char(10),char(3),char(46), -char(255),char(174),char(0),char(10),char(3),char(47),char(255),char(113),char(0),char(10), -char(3),char(48),char(255),char(174),char(0),char(10),char(3),char(49),char(255),char(113), -char(0),char(10),char(3),char(50),char(255),char(174),char(0),char(10),char(3),char(51), -char(255),char(113),char(0),char(10),char(3),char(52),char(255),char(174),char(0),char(10), -char(3),char(54),char(255),char(133),char(0),char(10),char(3),char(56),char(255),char(133), -char(0),char(10),char(3),char(58),char(255),char(133),char(0),char(10),char(3),char(60), -char(255),char(133),char(0),char(10),char(3),char(64),char(255),char(133),char(0),char(10), -char(3),char(66),char(255),char(133),char(0),char(10),char(3),char(68),char(255),char(133), -char(0),char(10),char(3),char(74),char(255),char(133),char(0),char(10),char(3),char(76), -char(255),char(133),char(0),char(10),char(3),char(78),char(255),char(133),char(0),char(10), -char(3),char(82),char(255),char(133),char(0),char(10),char(3),char(84),char(255),char(133), -char(0),char(10),char(3),char(86),char(255),char(133),char(0),char(10),char(3),char(88), -char(255),char(133),char(0),char(10),char(3),char(90),char(255),char(133),char(0),char(10), -char(3),char(92),char(255),char(133),char(0),char(10),char(3),char(94),char(255),char(133), -char(0),char(10),char(3),char(96),char(255),char(133),char(0),char(10),char(3),char(98), -char(255),char(195),char(0),char(10),char(3),char(100),char(255),char(195),char(0),char(10), -char(3),char(102),char(255),char(195),char(0),char(10),char(3),char(104),char(255),char(195), -char(0),char(10),char(3),char(106),char(255),char(195),char(0),char(10),char(3),char(108), -char(255),char(195),char(0),char(10),char(3),char(110),char(255),char(195),char(0),char(10), -char(3),char(111),char(0),char(20),char(0),char(10),char(3),char(113),char(0),char(20), -char(0),char(10),char(3),char(115),char(0),char(20),char(0),char(10),char(3),char(143), -char(0),char(41),char(0),char(11),char(0),char(45),char(0),char(184),char(0),char(15), -char(0),char(38),char(255),char(154),char(0),char(15),char(0),char(42),char(255),char(154), -char(0),char(15),char(0),char(50),char(255),char(154),char(0),char(15),char(0),char(52), -char(255),char(154),char(0),char(15),char(0),char(55),char(255),char(113),char(0),char(15), -char(0),char(56),char(255),char(215),char(0),char(15),char(0),char(57),char(255),char(133), -char(0),char(15),char(0),char(58),char(255),char(133),char(0),char(15),char(0),char(60), -char(255),char(133),char(0),char(15),char(0),char(137),char(255),char(154),char(0),char(15), -char(0),char(148),char(255),char(154),char(0),char(15),char(0),char(149),char(255),char(154), -char(0),char(15),char(0),char(150),char(255),char(154),char(0),char(15),char(0),char(151), -char(255),char(154),char(0),char(15),char(0),char(152),char(255),char(154),char(0),char(15), -char(0),char(154),char(255),char(154),char(0),char(15),char(0),char(155),char(255),char(215), -char(0),char(15),char(0),char(156),char(255),char(215),char(0),char(15),char(0),char(157), -char(255),char(215),char(0),char(15),char(0),char(158),char(255),char(215),char(0),char(15), -char(0),char(159),char(255),char(133),char(0),char(15),char(0),char(200),char(255),char(154), -char(0),char(15),char(0),char(202),char(255),char(154),char(0),char(15),char(0),char(204), -char(255),char(154),char(0),char(15),char(0),char(206),char(255),char(154),char(0),char(15), -char(0),char(222),char(255),char(154),char(0),char(15),char(0),char(224),char(255),char(154), -char(0),char(15),char(0),char(226),char(255),char(154),char(0),char(15),char(0),char(228), -char(255),char(154),char(0),char(15),char(1),char(14),char(255),char(154),char(0),char(15), -char(1),char(16),char(255),char(154),char(0),char(15),char(1),char(18),char(255),char(154), -char(0),char(15),char(1),char(20),char(255),char(154),char(0),char(15),char(1),char(36), -char(255),char(113),char(0),char(15),char(1),char(38),char(255),char(113),char(0),char(15), -char(1),char(42),char(255),char(215),char(0),char(15),char(1),char(44),char(255),char(215), -char(0),char(15),char(1),char(46),char(255),char(215),char(0),char(15),char(1),char(48), -char(255),char(215),char(0),char(15),char(1),char(50),char(255),char(215),char(0),char(15), -char(1),char(52),char(255),char(215),char(0),char(15),char(1),char(54),char(255),char(133), -char(0),char(15),char(1),char(56),char(255),char(133),char(0),char(15),char(1),char(58), -char(255),char(133),char(0),char(15),char(1),char(71),char(255),char(154),char(0),char(15), -char(1),char(102),char(255),char(174),char(0),char(15),char(1),char(109),char(255),char(174), -char(0),char(15),char(1),char(113),char(255),char(113),char(0),char(15),char(1),char(114), -char(255),char(133),char(0),char(15),char(1),char(115),char(255),char(154),char(0),char(15), -char(1),char(117),char(255),char(133),char(0),char(15),char(1),char(120),char(255),char(133), -char(0),char(15),char(1),char(133),char(255),char(215),char(0),char(15),char(1),char(157), -char(255),char(113),char(0),char(15),char(1),char(159),char(255),char(154),char(0),char(15), -char(1),char(166),char(255),char(113),char(0),char(15),char(1),char(184),char(255),char(154), -char(0),char(15),char(1),char(187),char(255),char(154),char(0),char(15),char(1),char(188), -char(255),char(113),char(0),char(15),char(1),char(190),char(255),char(174),char(0),char(15), -char(1),char(193),char(255),char(92),char(0),char(15),char(1),char(196),char(255),char(113), -char(0),char(15),char(1),char(220),char(255),char(154),char(0),char(15),char(1),char(225), -char(255),char(133),char(0),char(15),char(1),char(228),char(255),char(154),char(0),char(15), -char(1),char(250),char(255),char(133),char(0),char(15),char(1),char(252),char(255),char(133), -char(0),char(15),char(1),char(254),char(255),char(133),char(0),char(15),char(2),char(0), -char(255),char(133),char(0),char(15),char(2),char(84),char(255),char(133),char(0),char(15), -char(2),char(95),char(255),char(154),char(0),char(15),char(2),char(97),char(255),char(215), -char(0),char(15),char(2),char(108),char(255),char(154),char(0),char(15),char(2),char(124), -char(255),char(92),char(0),char(15),char(2),char(126),char(255),char(154),char(0),char(15), -char(2),char(128),char(255),char(133),char(0),char(15),char(2),char(130),char(255),char(133), -char(0),char(15),char(2),char(132),char(255),char(154),char(0),char(15),char(2),char(134), -char(255),char(154),char(0),char(15),char(2),char(136),char(255),char(154),char(0),char(15), -char(2),char(138),char(255),char(154),char(0),char(15),char(2),char(140),char(255),char(154), -char(0),char(15),char(2),char(169),char(255),char(113),char(0),char(15),char(2),char(170), -char(255),char(154),char(0),char(15),char(2),char(177),char(255),char(154),char(0),char(15), -char(2),char(179),char(255),char(154),char(0),char(15),char(2),char(181),char(255),char(113), -char(0),char(15),char(2),char(182),char(255),char(154),char(0),char(15),char(2),char(183), -char(255),char(133),char(0),char(15),char(2),char(185),char(255),char(133),char(0),char(15), -char(2),char(189),char(255),char(113),char(0),char(15),char(2),char(190),char(255),char(154), -char(0),char(15),char(2),char(191),char(255),char(92),char(0),char(15),char(2),char(192), -char(255),char(133),char(0),char(15),char(2),char(193),char(255),char(92),char(0),char(15), -char(2),char(194),char(255),char(133),char(0),char(15),char(2),char(197),char(255),char(133), -char(0),char(15),char(2),char(199),char(255),char(133),char(0),char(15),char(2),char(212), -char(255),char(92),char(0),char(15),char(2),char(213),char(255),char(133),char(0),char(15), -char(2),char(239),char(255),char(154),char(0),char(15),char(2),char(241),char(255),char(154), -char(0),char(15),char(2),char(243),char(255),char(154),char(0),char(15),char(2),char(253), -char(255),char(92),char(0),char(15),char(2),char(254),char(255),char(133),char(0),char(15), -char(3),char(13),char(255),char(133),char(0),char(15),char(3),char(14),char(255),char(154), -char(0),char(15),char(3),char(15),char(255),char(133),char(0),char(15),char(3),char(16), -char(255),char(154),char(0),char(15),char(3),char(21),char(255),char(154),char(0),char(15), -char(3),char(23),char(255),char(113),char(0),char(15),char(3),char(24),char(255),char(154), -char(0),char(15),char(3),char(73),char(255),char(154),char(0),char(15),char(3),char(75), -char(255),char(154),char(0),char(15),char(3),char(77),char(255),char(154),char(0),char(15), -char(3),char(79),char(255),char(154),char(0),char(15),char(3),char(81),char(255),char(154), -char(0),char(15),char(3),char(83),char(255),char(154),char(0),char(15),char(3),char(85), -char(255),char(154),char(0),char(15),char(3),char(87),char(255),char(154),char(0),char(15), -char(3),char(89),char(255),char(154),char(0),char(15),char(3),char(91),char(255),char(154), -char(0),char(15),char(3),char(93),char(255),char(154),char(0),char(15),char(3),char(95), -char(255),char(154),char(0),char(15),char(3),char(97),char(255),char(215),char(0),char(15), -char(3),char(99),char(255),char(215),char(0),char(15),char(3),char(101),char(255),char(215), -char(0),char(15),char(3),char(103),char(255),char(215),char(0),char(15),char(3),char(105), -char(255),char(215),char(0),char(15),char(3),char(107),char(255),char(215),char(0),char(15), -char(3),char(109),char(255),char(215),char(0),char(15),char(3),char(111),char(255),char(133), -char(0),char(15),char(3),char(113),char(255),char(133),char(0),char(15),char(3),char(115), -char(255),char(133),char(0),char(15),char(3),char(143),char(255),char(113),char(0),char(16), -char(0),char(55),char(255),char(174),char(0),char(16),char(1),char(36),char(255),char(174), -char(0),char(16),char(1),char(38),char(255),char(174),char(0),char(16),char(1),char(113), -char(255),char(174),char(0),char(16),char(1),char(157),char(255),char(174),char(0),char(16), -char(1),char(166),char(255),char(174),char(0),char(16),char(1),char(188),char(255),char(174), -char(0),char(16),char(1),char(196),char(255),char(174),char(0),char(16),char(1),char(220), -char(255),char(215),char(0),char(16),char(1),char(228),char(255),char(215),char(0),char(16), -char(2),char(169),char(255),char(174),char(0),char(16),char(2),char(170),char(255),char(215), -char(0),char(16),char(2),char(181),char(255),char(174),char(0),char(16),char(2),char(182), -char(255),char(215),char(0),char(16),char(2),char(189),char(255),char(174),char(0),char(16), -char(2),char(190),char(255),char(215),char(0),char(16),char(3),char(23),char(255),char(174), -char(0),char(16),char(3),char(24),char(255),char(215),char(0),char(16),char(3),char(143), -char(255),char(174),char(0),char(17),char(0),char(38),char(255),char(154),char(0),char(17), -char(0),char(42),char(255),char(154),char(0),char(17),char(0),char(50),char(255),char(154), -char(0),char(17),char(0),char(52),char(255),char(154),char(0),char(17),char(0),char(55), -char(255),char(113),char(0),char(17),char(0),char(56),char(255),char(215),char(0),char(17), -char(0),char(57),char(255),char(133),char(0),char(17),char(0),char(58),char(255),char(133), -char(0),char(17),char(0),char(60),char(255),char(133),char(0),char(17),char(0),char(137), -char(255),char(154),char(0),char(17),char(0),char(148),char(255),char(154),char(0),char(17), -char(0),char(149),char(255),char(154),char(0),char(17),char(0),char(150),char(255),char(154), -char(0),char(17),char(0),char(151),char(255),char(154),char(0),char(17),char(0),char(152), -char(255),char(154),char(0),char(17),char(0),char(154),char(255),char(154),char(0),char(17), -char(0),char(155),char(255),char(215),char(0),char(17),char(0),char(156),char(255),char(215), -char(0),char(17),char(0),char(157),char(255),char(215),char(0),char(17),char(0),char(158), -char(255),char(215),char(0),char(17),char(0),char(159),char(255),char(133),char(0),char(17), -char(0),char(200),char(255),char(154),char(0),char(17),char(0),char(202),char(255),char(154), -char(0),char(17),char(0),char(204),char(255),char(154),char(0),char(17),char(0),char(206), -char(255),char(154),char(0),char(17),char(0),char(222),char(255),char(154),char(0),char(17), -char(0),char(224),char(255),char(154),char(0),char(17),char(0),char(226),char(255),char(154), -char(0),char(17),char(0),char(228),char(255),char(154),char(0),char(17),char(1),char(14), -char(255),char(154),char(0),char(17),char(1),char(16),char(255),char(154),char(0),char(17), -char(1),char(18),char(255),char(154),char(0),char(17),char(1),char(20),char(255),char(154), -char(0),char(17),char(1),char(36),char(255),char(113),char(0),char(17),char(1),char(38), -char(255),char(113),char(0),char(17),char(1),char(42),char(255),char(215),char(0),char(17), -char(1),char(44),char(255),char(215),char(0),char(17),char(1),char(46),char(255),char(215), -char(0),char(17),char(1),char(48),char(255),char(215),char(0),char(17),char(1),char(50), -char(255),char(215),char(0),char(17),char(1),char(52),char(255),char(215),char(0),char(17), -char(1),char(54),char(255),char(133),char(0),char(17),char(1),char(56),char(255),char(133), -char(0),char(17),char(1),char(58),char(255),char(133),char(0),char(17),char(1),char(71), -char(255),char(154),char(0),char(17),char(1),char(102),char(255),char(174),char(0),char(17), -char(1),char(109),char(255),char(174),char(0),char(17),char(1),char(113),char(255),char(113), -char(0),char(17),char(1),char(114),char(255),char(133),char(0),char(17),char(1),char(115), -char(255),char(154),char(0),char(17),char(1),char(117),char(255),char(133),char(0),char(17), -char(1),char(120),char(255),char(133),char(0),char(17),char(1),char(133),char(255),char(215), -char(0),char(17),char(1),char(157),char(255),char(113),char(0),char(17),char(1),char(159), -char(255),char(154),char(0),char(17),char(1),char(166),char(255),char(113),char(0),char(17), -char(1),char(184),char(255),char(154),char(0),char(17),char(1),char(187),char(255),char(154), -char(0),char(17),char(1),char(188),char(255),char(113),char(0),char(17),char(1),char(190), -char(255),char(174),char(0),char(17),char(1),char(193),char(255),char(92),char(0),char(17), -char(1),char(196),char(255),char(113),char(0),char(17),char(1),char(220),char(255),char(154), -char(0),char(17),char(1),char(225),char(255),char(133),char(0),char(17),char(1),char(228), -char(255),char(154),char(0),char(17),char(1),char(250),char(255),char(133),char(0),char(17), -char(1),char(252),char(255),char(133),char(0),char(17),char(1),char(254),char(255),char(133), -char(0),char(17),char(2),char(0),char(255),char(133),char(0),char(17),char(2),char(84), -char(255),char(133),char(0),char(17),char(2),char(95),char(255),char(154),char(0),char(17), -char(2),char(97),char(255),char(215),char(0),char(17),char(2),char(108),char(255),char(154), -char(0),char(17),char(2),char(124),char(255),char(92),char(0),char(17),char(2),char(126), -char(255),char(154),char(0),char(17),char(2),char(128),char(255),char(133),char(0),char(17), -char(2),char(130),char(255),char(133),char(0),char(17),char(2),char(132),char(255),char(154), -char(0),char(17),char(2),char(134),char(255),char(154),char(0),char(17),char(2),char(136), -char(255),char(154),char(0),char(17),char(2),char(138),char(255),char(154),char(0),char(17), -char(2),char(140),char(255),char(154),char(0),char(17),char(2),char(169),char(255),char(113), -char(0),char(17),char(2),char(170),char(255),char(154),char(0),char(17),char(2),char(177), -char(255),char(154),char(0),char(17),char(2),char(179),char(255),char(154),char(0),char(17), -char(2),char(181),char(255),char(113),char(0),char(17),char(2),char(182),char(255),char(154), -char(0),char(17),char(2),char(183),char(255),char(133),char(0),char(17),char(2),char(185), -char(255),char(133),char(0),char(17),char(2),char(189),char(255),char(113),char(0),char(17), -char(2),char(190),char(255),char(154),char(0),char(17),char(2),char(191),char(255),char(92), -char(0),char(17),char(2),char(192),char(255),char(133),char(0),char(17),char(2),char(193), -char(255),char(92),char(0),char(17),char(2),char(194),char(255),char(133),char(0),char(17), -char(2),char(197),char(255),char(133),char(0),char(17),char(2),char(199),char(255),char(133), -char(0),char(17),char(2),char(212),char(255),char(92),char(0),char(17),char(2),char(213), -char(255),char(133),char(0),char(17),char(2),char(239),char(255),char(154),char(0),char(17), -char(2),char(241),char(255),char(154),char(0),char(17),char(2),char(243),char(255),char(154), -char(0),char(17),char(2),char(253),char(255),char(92),char(0),char(17),char(2),char(254), -char(255),char(133),char(0),char(17),char(3),char(13),char(255),char(133),char(0),char(17), -char(3),char(14),char(255),char(154),char(0),char(17),char(3),char(15),char(255),char(133), -char(0),char(17),char(3),char(16),char(255),char(154),char(0),char(17),char(3),char(21), -char(255),char(154),char(0),char(17),char(3),char(23),char(255),char(113),char(0),char(17), -char(3),char(24),char(255),char(154),char(0),char(17),char(3),char(73),char(255),char(154), -char(0),char(17),char(3),char(75),char(255),char(154),char(0),char(17),char(3),char(77), -char(255),char(154),char(0),char(17),char(3),char(79),char(255),char(154),char(0),char(17), -char(3),char(81),char(255),char(154),char(0),char(17),char(3),char(83),char(255),char(154), -char(0),char(17),char(3),char(85),char(255),char(154),char(0),char(17),char(3),char(87), -char(255),char(154),char(0),char(17),char(3),char(89),char(255),char(154),char(0),char(17), -char(3),char(91),char(255),char(154),char(0),char(17),char(3),char(93),char(255),char(154), -char(0),char(17),char(3),char(95),char(255),char(154),char(0),char(17),char(3),char(97), -char(255),char(215),char(0),char(17),char(3),char(99),char(255),char(215),char(0),char(17), -char(3),char(101),char(255),char(215),char(0),char(17),char(3),char(103),char(255),char(215), -char(0),char(17),char(3),char(105),char(255),char(215),char(0),char(17),char(3),char(107), -char(255),char(215),char(0),char(17),char(3),char(109),char(255),char(215),char(0),char(17), -char(3),char(111),char(255),char(133),char(0),char(17),char(3),char(113),char(255),char(133), -char(0),char(17),char(3),char(115),char(255),char(133),char(0),char(17),char(3),char(143), -char(255),char(113),char(0),char(36),char(0),char(5),char(255),char(113),char(0),char(36), -char(0),char(10),char(255),char(113),char(0),char(36),char(0),char(38),char(255),char(215), -char(0),char(36),char(0),char(42),char(255),char(215),char(0),char(36),char(0),char(45), -char(1),char(10),char(0),char(36),char(0),char(50),char(255),char(215),char(0),char(36), -char(0),char(52),char(255),char(215),char(0),char(36),char(0),char(55),char(255),char(113), -char(0),char(36),char(0),char(57),char(255),char(174),char(0),char(36),char(0),char(58), -char(255),char(174),char(0),char(36),char(0),char(60),char(255),char(133),char(0),char(36), -char(0),char(137),char(255),char(215),char(0),char(36),char(0),char(148),char(255),char(215), -char(0),char(36),char(0),char(149),char(255),char(215),char(0),char(36),char(0),char(150), -char(255),char(215),char(0),char(36),char(0),char(151),char(255),char(215),char(0),char(36), -char(0),char(152),char(255),char(215),char(0),char(36),char(0),char(154),char(255),char(215), -char(0),char(36),char(0),char(159),char(255),char(133),char(0),char(36),char(0),char(200), -char(255),char(215),char(0),char(36),char(0),char(202),char(255),char(215),char(0),char(36), -char(0),char(204),char(255),char(215),char(0),char(36),char(0),char(206),char(255),char(215), -char(0),char(36),char(0),char(222),char(255),char(215),char(0),char(36),char(0),char(224), -char(255),char(215),char(0),char(36),char(0),char(226),char(255),char(215),char(0),char(36), -char(0),char(228),char(255),char(215),char(0),char(36),char(1),char(14),char(255),char(215), -char(0),char(36),char(1),char(16),char(255),char(215),char(0),char(36),char(1),char(18), -char(255),char(215),char(0),char(36),char(1),char(20),char(255),char(215),char(0),char(36), -char(1),char(36),char(255),char(113),char(0),char(36),char(1),char(38),char(255),char(113), -char(0),char(36),char(1),char(54),char(255),char(174),char(0),char(36),char(1),char(56), -char(255),char(133),char(0),char(36),char(1),char(58),char(255),char(133),char(0),char(36), -char(1),char(71),char(255),char(215),char(0),char(36),char(1),char(250),char(255),char(174), -char(0),char(36),char(1),char(252),char(255),char(174),char(0),char(36),char(1),char(254), -char(255),char(174),char(0),char(36),char(2),char(0),char(255),char(133),char(0),char(36), -char(2),char(7),char(255),char(113),char(0),char(36),char(2),char(11),char(255),char(113), -char(0),char(36),char(2),char(95),char(255),char(215),char(0),char(36),char(3),char(73), -char(255),char(215),char(0),char(36),char(3),char(75),char(255),char(215),char(0),char(36), -char(3),char(77),char(255),char(215),char(0),char(36),char(3),char(79),char(255),char(215), -char(0),char(36),char(3),char(81),char(255),char(215),char(0),char(36),char(3),char(83), -char(255),char(215),char(0),char(36),char(3),char(85),char(255),char(215),char(0),char(36), -char(3),char(87),char(255),char(215),char(0),char(36),char(3),char(89),char(255),char(215), -char(0),char(36),char(3),char(91),char(255),char(215),char(0),char(36),char(3),char(93), -char(255),char(215),char(0),char(36),char(3),char(95),char(255),char(215),char(0),char(36), -char(3),char(111),char(255),char(133),char(0),char(36),char(3),char(113),char(255),char(133), -char(0),char(36),char(3),char(115),char(255),char(133),char(0),char(36),char(3),char(143), -char(255),char(113),char(0),char(37),char(0),char(15),char(255),char(174),char(0),char(37), -char(0),char(17),char(255),char(174),char(0),char(37),char(0),char(36),char(255),char(215), -char(0),char(37),char(0),char(55),char(255),char(195),char(0),char(37),char(0),char(57), -char(255),char(236),char(0),char(37),char(0),char(58),char(255),char(236),char(0),char(37), -char(0),char(59),char(255),char(215),char(0),char(37),char(0),char(60),char(255),char(236), -char(0),char(37),char(0),char(61),char(255),char(236),char(0),char(37),char(0),char(130), -char(255),char(215),char(0),char(37),char(0),char(131),char(255),char(215),char(0),char(37), -char(0),char(132),char(255),char(215),char(0),char(37),char(0),char(133),char(255),char(215), -char(0),char(37),char(0),char(134),char(255),char(215),char(0),char(37),char(0),char(135), -char(255),char(215),char(0),char(37),char(0),char(159),char(255),char(236),char(0),char(37), -char(0),char(194),char(255),char(215),char(0),char(37),char(0),char(196),char(255),char(215), -char(0),char(37),char(0),char(198),char(255),char(215),char(0),char(37),char(1),char(36), -char(255),char(195),char(0),char(37),char(1),char(38),char(255),char(195),char(0),char(37), -char(1),char(54),char(255),char(236),char(0),char(37),char(1),char(56),char(255),char(236), -char(0),char(37),char(1),char(58),char(255),char(236),char(0),char(37),char(1),char(59), -char(255),char(236),char(0),char(37),char(1),char(61),char(255),char(236),char(0),char(37), -char(1),char(63),char(255),char(236),char(0),char(37),char(1),char(67),char(255),char(215), -char(0),char(37),char(1),char(160),char(255),char(236),char(0),char(37),char(1),char(250), -char(255),char(236),char(0),char(37),char(1),char(252),char(255),char(236),char(0),char(37), -char(1),char(254),char(255),char(236),char(0),char(37),char(2),char(0),char(255),char(236), -char(0),char(37),char(2),char(8),char(255),char(174),char(0),char(37),char(2),char(12), -char(255),char(174),char(0),char(37),char(2),char(88),char(255),char(215),char(0),char(37), -char(3),char(29),char(255),char(215),char(0),char(37),char(3),char(31),char(255),char(215), -char(0),char(37),char(3),char(33),char(255),char(215),char(0),char(37),char(3),char(35), -char(255),char(215),char(0),char(37),char(3),char(37),char(255),char(215),char(0),char(37), -char(3),char(39),char(255),char(215),char(0),char(37),char(3),char(41),char(255),char(215), -char(0),char(37),char(3),char(43),char(255),char(215),char(0),char(37),char(3),char(45), -char(255),char(215),char(0),char(37),char(3),char(47),char(255),char(215),char(0),char(37), -char(3),char(49),char(255),char(215),char(0),char(37),char(3),char(51),char(255),char(215), -char(0),char(37),char(3),char(111),char(255),char(236),char(0),char(37),char(3),char(113), -char(255),char(236),char(0),char(37),char(3),char(115),char(255),char(236),char(0),char(37), -char(3),char(143),char(255),char(195),char(0),char(38),char(0),char(38),char(255),char(215), -char(0),char(38),char(0),char(42),char(255),char(215),char(0),char(38),char(0),char(50), -char(255),char(215),char(0),char(38),char(0),char(52),char(255),char(215),char(0),char(38), -char(0),char(137),char(255),char(215),char(0),char(38),char(0),char(148),char(255),char(215), -char(0),char(38),char(0),char(149),char(255),char(215),char(0),char(38),char(0),char(150), -char(255),char(215),char(0),char(38),char(0),char(151),char(255),char(215),char(0),char(38), -char(0),char(152),char(255),char(215),char(0),char(38),char(0),char(154),char(255),char(215), -char(0),char(38),char(0),char(200),char(255),char(215),char(0),char(38),char(0),char(202), -char(255),char(215),char(0),char(38),char(0),char(204),char(255),char(215),char(0),char(38), -char(0),char(206),char(255),char(215),char(0),char(38),char(0),char(222),char(255),char(215), -char(0),char(38),char(0),char(224),char(255),char(215),char(0),char(38),char(0),char(226), -char(255),char(215),char(0),char(38),char(0),char(228),char(255),char(215),char(0),char(38), -char(1),char(14),char(255),char(215),char(0),char(38),char(1),char(16),char(255),char(215), -char(0),char(38),char(1),char(18),char(255),char(215),char(0),char(38),char(1),char(20), -char(255),char(215),char(0),char(38),char(1),char(71),char(255),char(215),char(0),char(38), -char(2),char(95),char(255),char(215),char(0),char(38),char(3),char(73),char(255),char(215), -char(0),char(38),char(3),char(75),char(255),char(215),char(0),char(38),char(3),char(77), -char(255),char(215),char(0),char(38),char(3),char(79),char(255),char(215),char(0),char(38), -char(3),char(81),char(255),char(215),char(0),char(38),char(3),char(83),char(255),char(215), -char(0),char(38),char(3),char(85),char(255),char(215),char(0),char(38),char(3),char(87), -char(255),char(215),char(0),char(38),char(3),char(89),char(255),char(215),char(0),char(38), -char(3),char(91),char(255),char(215),char(0),char(38),char(3),char(93),char(255),char(215), -char(0),char(38),char(3),char(95),char(255),char(215),char(0),char(39),char(0),char(15), -char(255),char(174),char(0),char(39),char(0),char(17),char(255),char(174),char(0),char(39), -char(0),char(36),char(255),char(215),char(0),char(39),char(0),char(55),char(255),char(195), -char(0),char(39),char(0),char(57),char(255),char(236),char(0),char(39),char(0),char(58), -char(255),char(236),char(0),char(39),char(0),char(59),char(255),char(215),char(0),char(39), -char(0),char(60),char(255),char(236),char(0),char(39),char(0),char(61),char(255),char(236), -char(0),char(39),char(0),char(130),char(255),char(215),char(0),char(39),char(0),char(131), -char(255),char(215),char(0),char(39),char(0),char(132),char(255),char(215),char(0),char(39), -char(0),char(133),char(255),char(215),char(0),char(39),char(0),char(134),char(255),char(215), -char(0),char(39),char(0),char(135),char(255),char(215),char(0),char(39),char(0),char(159), -char(255),char(236),char(0),char(39),char(0),char(194),char(255),char(215),char(0),char(39), -char(0),char(196),char(255),char(215),char(0),char(39),char(0),char(198),char(255),char(215), -char(0),char(39),char(1),char(36),char(255),char(195),char(0),char(39),char(1),char(38), -char(255),char(195),char(0),char(39),char(1),char(54),char(255),char(236),char(0),char(39), -char(1),char(56),char(255),char(236),char(0),char(39),char(1),char(58),char(255),char(236), -char(0),char(39),char(1),char(59),char(255),char(236),char(0),char(39),char(1),char(61), -char(255),char(236),char(0),char(39),char(1),char(63),char(255),char(236),char(0),char(39), -char(1),char(67),char(255),char(215),char(0),char(39),char(1),char(160),char(255),char(236), -char(0),char(39),char(1),char(250),char(255),char(236),char(0),char(39),char(1),char(252), -char(255),char(236),char(0),char(39),char(1),char(254),char(255),char(236),char(0),char(39), -char(2),char(0),char(255),char(236),char(0),char(39),char(2),char(8),char(255),char(174), -char(0),char(39),char(2),char(12),char(255),char(174),char(0),char(39),char(2),char(88), -char(255),char(215),char(0),char(39),char(3),char(29),char(255),char(215),char(0),char(39), -char(3),char(31),char(255),char(215),char(0),char(39),char(3),char(33),char(255),char(215), -char(0),char(39),char(3),char(35),char(255),char(215),char(0),char(39),char(3),char(37), -char(255),char(215),char(0),char(39),char(3),char(39),char(255),char(215),char(0),char(39), -char(3),char(41),char(255),char(215),char(0),char(39),char(3),char(43),char(255),char(215), -char(0),char(39),char(3),char(45),char(255),char(215),char(0),char(39),char(3),char(47), -char(255),char(215),char(0),char(39),char(3),char(49),char(255),char(215),char(0),char(39), -char(3),char(51),char(255),char(215),char(0),char(39),char(3),char(111),char(255),char(236), -char(0),char(39),char(3),char(113),char(255),char(236),char(0),char(39),char(3),char(115), -char(255),char(236),char(0),char(39),char(3),char(143),char(255),char(195),char(0),char(40), -char(0),char(45),char(0),char(123),char(0),char(41),char(0),char(15),char(255),char(133), -char(0),char(41),char(0),char(17),char(255),char(133),char(0),char(41),char(0),char(34), -char(0),char(41),char(0),char(41),char(0),char(36),char(255),char(215),char(0),char(41), -char(0),char(130),char(255),char(215),char(0),char(41),char(0),char(131),char(255),char(215), -char(0),char(41),char(0),char(132),char(255),char(215),char(0),char(41),char(0),char(133), -char(255),char(215),char(0),char(41),char(0),char(134),char(255),char(215),char(0),char(41), -char(0),char(135),char(255),char(215),char(0),char(41),char(0),char(194),char(255),char(215), -char(0),char(41),char(0),char(196),char(255),char(215),char(0),char(41),char(0),char(198), -char(255),char(215),char(0),char(41),char(1),char(67),char(255),char(215),char(0),char(41), -char(2),char(8),char(255),char(133),char(0),char(41),char(2),char(12),char(255),char(133), -char(0),char(41),char(2),char(88),char(255),char(215),char(0),char(41),char(3),char(29), -char(255),char(215),char(0),char(41),char(3),char(31),char(255),char(215),char(0),char(41), -char(3),char(33),char(255),char(215),char(0),char(41),char(3),char(35),char(255),char(215), -char(0),char(41),char(3),char(37),char(255),char(215),char(0),char(41),char(3),char(39), -char(255),char(215),char(0),char(41),char(3),char(41),char(255),char(215),char(0),char(41), -char(3),char(43),char(255),char(215),char(0),char(41),char(3),char(45),char(255),char(215), -char(0),char(41),char(3),char(47),char(255),char(215),char(0),char(41),char(3),char(49), -char(255),char(215),char(0),char(41),char(3),char(51),char(255),char(215),char(0),char(46), -char(0),char(38),char(255),char(215),char(0),char(46),char(0),char(42),char(255),char(215), -char(0),char(46),char(0),char(50),char(255),char(215),char(0),char(46),char(0),char(52), -char(255),char(215),char(0),char(46),char(0),char(137),char(255),char(215),char(0),char(46), -char(0),char(148),char(255),char(215),char(0),char(46),char(0),char(149),char(255),char(215), -char(0),char(46),char(0),char(150),char(255),char(215),char(0),char(46),char(0),char(151), -char(255),char(215),char(0),char(46),char(0),char(152),char(255),char(215),char(0),char(46), -char(0),char(154),char(255),char(215),char(0),char(46),char(0),char(200),char(255),char(215), -char(0),char(46),char(0),char(202),char(255),char(215),char(0),char(46),char(0),char(204), -char(255),char(215),char(0),char(46),char(0),char(206),char(255),char(215),char(0),char(46), -char(0),char(222),char(255),char(215),char(0),char(46),char(0),char(224),char(255),char(215), -char(0),char(46),char(0),char(226),char(255),char(215),char(0),char(46),char(0),char(228), -char(255),char(215),char(0),char(46),char(1),char(14),char(255),char(215),char(0),char(46), -char(1),char(16),char(255),char(215),char(0),char(46),char(1),char(18),char(255),char(215), -char(0),char(46),char(1),char(20),char(255),char(215),char(0),char(46),char(1),char(71), -char(255),char(215),char(0),char(46),char(2),char(95),char(255),char(215),char(0),char(46), -char(3),char(73),char(255),char(215),char(0),char(46),char(3),char(75),char(255),char(215), -char(0),char(46),char(3),char(77),char(255),char(215),char(0),char(46),char(3),char(79), -char(255),char(215),char(0),char(46),char(3),char(81),char(255),char(215),char(0),char(46), -char(3),char(83),char(255),char(215),char(0),char(46),char(3),char(85),char(255),char(215), -char(0),char(46),char(3),char(87),char(255),char(215),char(0),char(46),char(3),char(89), -char(255),char(215),char(0),char(46),char(3),char(91),char(255),char(215),char(0),char(46), -char(3),char(93),char(255),char(215),char(0),char(46),char(3),char(95),char(255),char(215), -char(0),char(47),char(0),char(5),char(255),char(92),char(0),char(47),char(0),char(10), -char(255),char(92),char(0),char(47),char(0),char(38),char(255),char(215),char(0),char(47), -char(0),char(42),char(255),char(215),char(0),char(47),char(0),char(50),char(255),char(215), -char(0),char(47),char(0),char(52),char(255),char(215),char(0),char(47),char(0),char(55), -char(255),char(215),char(0),char(47),char(0),char(56),char(255),char(236),char(0),char(47), -char(0),char(57),char(255),char(215),char(0),char(47),char(0),char(58),char(255),char(215), -char(0),char(47),char(0),char(60),char(255),char(195),char(0),char(47),char(0),char(137), -char(255),char(215),char(0),char(47),char(0),char(148),char(255),char(215),char(0),char(47), -char(0),char(149),char(255),char(215),char(0),char(47),char(0),char(150),char(255),char(215), -char(0),char(47),char(0),char(151),char(255),char(215),char(0),char(47),char(0),char(152), -char(255),char(215),char(0),char(47),char(0),char(154),char(255),char(215),char(0),char(47), -char(0),char(155),char(255),char(236),char(0),char(47),char(0),char(156),char(255),char(236), -char(0),char(47),char(0),char(157),char(255),char(236),char(0),char(47),char(0),char(158), -char(255),char(236),char(0),char(47),char(0),char(159),char(255),char(195),char(0),char(47), -char(0),char(200),char(255),char(215),char(0),char(47),char(0),char(202),char(255),char(215), -char(0),char(47),char(0),char(204),char(255),char(215),char(0),char(47),char(0),char(206), -char(255),char(215),char(0),char(47),char(0),char(222),char(255),char(215),char(0),char(47), -char(0),char(224),char(255),char(215),char(0),char(47),char(0),char(226),char(255),char(215), -char(0),char(47),char(0),char(228),char(255),char(215),char(0),char(47),char(1),char(14), -char(255),char(215),char(0),char(47),char(1),char(16),char(255),char(215),char(0),char(47), -char(1),char(18),char(255),char(215),char(0),char(47),char(1),char(20),char(255),char(215), -char(0),char(47),char(1),char(36),char(255),char(215),char(0),char(47),char(1),char(38), -char(255),char(215),char(0),char(47),char(1),char(42),char(255),char(236),char(0),char(47), -char(1),char(44),char(255),char(236),char(0),char(47),char(1),char(46),char(255),char(236), -char(0),char(47),char(1),char(48),char(255),char(236),char(0),char(47),char(1),char(50), -char(255),char(236),char(0),char(47),char(1),char(52),char(255),char(236),char(0),char(47), -char(1),char(54),char(255),char(215),char(0),char(47),char(1),char(56),char(255),char(195), -char(0),char(47),char(1),char(58),char(255),char(195),char(0),char(47),char(1),char(71), -char(255),char(215),char(0),char(47),char(1),char(250),char(255),char(215),char(0),char(47), -char(1),char(252),char(255),char(215),char(0),char(47),char(1),char(254),char(255),char(215), -char(0),char(47),char(2),char(0),char(255),char(195),char(0),char(47),char(2),char(7), -char(255),char(92),char(0),char(47),char(2),char(11),char(255),char(92),char(0),char(47), -char(2),char(95),char(255),char(215),char(0),char(47),char(2),char(97),char(255),char(236), -char(0),char(47),char(3),char(73),char(255),char(215),char(0),char(47),char(3),char(75), -char(255),char(215),char(0),char(47),char(3),char(77),char(255),char(215),char(0),char(47), -char(3),char(79),char(255),char(215),char(0),char(47),char(3),char(81),char(255),char(215), -char(0),char(47),char(3),char(83),char(255),char(215),char(0),char(47),char(3),char(85), -char(255),char(215),char(0),char(47),char(3),char(87),char(255),char(215),char(0),char(47), -char(3),char(89),char(255),char(215),char(0),char(47),char(3),char(91),char(255),char(215), -char(0),char(47),char(3),char(93),char(255),char(215),char(0),char(47),char(3),char(95), -char(255),char(215),char(0),char(47),char(3),char(97),char(255),char(236),char(0),char(47), -char(3),char(99),char(255),char(236),char(0),char(47),char(3),char(101),char(255),char(236), -char(0),char(47),char(3),char(103),char(255),char(236),char(0),char(47),char(3),char(105), -char(255),char(236),char(0),char(47),char(3),char(107),char(255),char(236),char(0),char(47), -char(3),char(109),char(255),char(236),char(0),char(47),char(3),char(111),char(255),char(195), -char(0),char(47),char(3),char(113),char(255),char(195),char(0),char(47),char(3),char(115), -char(255),char(195),char(0),char(47),char(3),char(143),char(255),char(215),char(0),char(50), -char(0),char(15),char(255),char(174),char(0),char(50),char(0),char(17),char(255),char(174), -char(0),char(50),char(0),char(36),char(255),char(215),char(0),char(50),char(0),char(55), -char(255),char(195),char(0),char(50),char(0),char(57),char(255),char(236),char(0),char(50), -char(0),char(58),char(255),char(236),char(0),char(50),char(0),char(59),char(255),char(215), -char(0),char(50),char(0),char(60),char(255),char(236),char(0),char(50),char(0),char(61), -char(255),char(236),char(0),char(50),char(0),char(130),char(255),char(215),char(0),char(50), -char(0),char(131),char(255),char(215),char(0),char(50),char(0),char(132),char(255),char(215), -char(0),char(50),char(0),char(133),char(255),char(215),char(0),char(50),char(0),char(134), -char(255),char(215),char(0),char(50),char(0),char(135),char(255),char(215),char(0),char(50), -char(0),char(159),char(255),char(236),char(0),char(50),char(0),char(194),char(255),char(215), -char(0),char(50),char(0),char(196),char(255),char(215),char(0),char(50),char(0),char(198), -char(255),char(215),char(0),char(50),char(1),char(36),char(255),char(195),char(0),char(50), -char(1),char(38),char(255),char(195),char(0),char(50),char(1),char(54),char(255),char(236), -char(0),char(50),char(1),char(56),char(255),char(236),char(0),char(50),char(1),char(58), -char(255),char(236),char(0),char(50),char(1),char(59),char(255),char(236),char(0),char(50), -char(1),char(61),char(255),char(236),char(0),char(50),char(1),char(63),char(255),char(236), -char(0),char(50),char(1),char(67),char(255),char(215),char(0),char(50),char(1),char(160), -char(255),char(236),char(0),char(50),char(1),char(250),char(255),char(236),char(0),char(50), -char(1),char(252),char(255),char(236),char(0),char(50),char(1),char(254),char(255),char(236), -char(0),char(50),char(2),char(0),char(255),char(236),char(0),char(50),char(2),char(8), -char(255),char(174),char(0),char(50),char(2),char(12),char(255),char(174),char(0),char(50), -char(2),char(88),char(255),char(215),char(0),char(50),char(3),char(29),char(255),char(215), -char(0),char(50),char(3),char(31),char(255),char(215),char(0),char(50),char(3),char(33), -char(255),char(215),char(0),char(50),char(3),char(35),char(255),char(215),char(0),char(50), -char(3),char(37),char(255),char(215),char(0),char(50),char(3),char(39),char(255),char(215), -char(0),char(50),char(3),char(41),char(255),char(215),char(0),char(50),char(3),char(43), -char(255),char(215),char(0),char(50),char(3),char(45),char(255),char(215),char(0),char(50), -char(3),char(47),char(255),char(215),char(0),char(50),char(3),char(49),char(255),char(215), -char(0),char(50),char(3),char(51),char(255),char(215),char(0),char(50),char(3),char(111), -char(255),char(236),char(0),char(50),char(3),char(113),char(255),char(236),char(0),char(50), -char(3),char(115),char(255),char(236),char(0),char(50),char(3),char(143),char(255),char(195), -char(0),char(51),char(0),char(15),char(254),char(246),char(0),char(51),char(0),char(17), -char(254),char(246),char(0),char(51),char(0),char(36),char(255),char(154),char(0),char(51), -char(0),char(59),char(255),char(215),char(0),char(51),char(0),char(61),char(255),char(236), -char(0),char(51),char(0),char(130),char(255),char(154),char(0),char(51),char(0),char(131), -char(255),char(154),char(0),char(51),char(0),char(132),char(255),char(154),char(0),char(51), -char(0),char(133),char(255),char(154),char(0),char(51),char(0),char(134),char(255),char(154), -char(0),char(51),char(0),char(135),char(255),char(154),char(0),char(51),char(0),char(194), -char(255),char(154),char(0),char(51),char(0),char(196),char(255),char(154),char(0),char(51), -char(0),char(198),char(255),char(154),char(0),char(51),char(1),char(59),char(255),char(236), -char(0),char(51),char(1),char(61),char(255),char(236),char(0),char(51),char(1),char(63), -char(255),char(236),char(0),char(51),char(1),char(67),char(255),char(154),char(0),char(51), -char(2),char(8),char(254),char(246),char(0),char(51),char(2),char(12),char(254),char(246), -char(0),char(51),char(2),char(88),char(255),char(154),char(0),char(51),char(3),char(29), -char(255),char(154),char(0),char(51),char(3),char(31),char(255),char(154),char(0),char(51), -char(3),char(33),char(255),char(154),char(0),char(51),char(3),char(35),char(255),char(154), -char(0),char(51),char(3),char(37),char(255),char(154),char(0),char(51),char(3),char(39), -char(255),char(154),char(0),char(51),char(3),char(41),char(255),char(154),char(0),char(51), -char(3),char(43),char(255),char(154),char(0),char(51),char(3),char(45),char(255),char(154), -char(0),char(51),char(3),char(47),char(255),char(154),char(0),char(51),char(3),char(49), -char(255),char(154),char(0),char(51),char(3),char(51),char(255),char(154),char(0),char(52), -char(0),char(15),char(255),char(174),char(0),char(52),char(0),char(17),char(255),char(174), -char(0),char(52),char(0),char(36),char(255),char(215),char(0),char(52),char(0),char(55), -char(255),char(195),char(0),char(52),char(0),char(57),char(255),char(236),char(0),char(52), -char(0),char(58),char(255),char(236),char(0),char(52),char(0),char(59),char(255),char(215), -char(0),char(52),char(0),char(60),char(255),char(236),char(0),char(52),char(0),char(61), -char(255),char(236),char(0),char(52),char(0),char(130),char(255),char(215),char(0),char(52), -char(0),char(131),char(255),char(215),char(0),char(52),char(0),char(132),char(255),char(215), -char(0),char(52),char(0),char(133),char(255),char(215),char(0),char(52),char(0),char(134), -char(255),char(215),char(0),char(52),char(0),char(135),char(255),char(215),char(0),char(52), -char(0),char(159),char(255),char(236),char(0),char(52),char(0),char(194),char(255),char(215), -char(0),char(52),char(0),char(196),char(255),char(215),char(0),char(52),char(0),char(198), -char(255),char(215),char(0),char(52),char(1),char(36),char(255),char(195),char(0),char(52), -char(1),char(38),char(255),char(195),char(0),char(52),char(1),char(54),char(255),char(236), -char(0),char(52),char(1),char(56),char(255),char(236),char(0),char(52),char(1),char(58), -char(255),char(236),char(0),char(52),char(1),char(59),char(255),char(236),char(0),char(52), -char(1),char(61),char(255),char(236),char(0),char(52),char(1),char(63),char(255),char(236), -char(0),char(52),char(1),char(67),char(255),char(215),char(0),char(52),char(1),char(160), -char(255),char(236),char(0),char(52),char(1),char(250),char(255),char(236),char(0),char(52), -char(1),char(252),char(255),char(236),char(0),char(52),char(1),char(254),char(255),char(236), -char(0),char(52),char(2),char(0),char(255),char(236),char(0),char(52),char(2),char(8), -char(255),char(174),char(0),char(52),char(2),char(12),char(255),char(174),char(0),char(52), -char(2),char(88),char(255),char(215),char(0),char(52),char(3),char(29),char(255),char(215), -char(0),char(52),char(3),char(31),char(255),char(215),char(0),char(52),char(3),char(33), -char(255),char(215),char(0),char(52),char(3),char(35),char(255),char(215),char(0),char(52), -char(3),char(37),char(255),char(215),char(0),char(52),char(3),char(39),char(255),char(215), -char(0),char(52),char(3),char(41),char(255),char(215),char(0),char(52),char(3),char(43), -char(255),char(215),char(0),char(52),char(3),char(45),char(255),char(215),char(0),char(52), -char(3),char(47),char(255),char(215),char(0),char(52),char(3),char(49),char(255),char(215), -char(0),char(52),char(3),char(51),char(255),char(215),char(0),char(52),char(3),char(111), -char(255),char(236),char(0),char(52),char(3),char(113),char(255),char(236),char(0),char(52), -char(3),char(115),char(255),char(236),char(0),char(52),char(3),char(143),char(255),char(195), -char(0),char(55),char(0),char(15),char(255),char(133),char(0),char(55),char(0),char(16), -char(255),char(174),char(0),char(55),char(0),char(17),char(255),char(133),char(0),char(55), -char(0),char(34),char(0),char(41),char(0),char(55),char(0),char(36),char(255),char(113), -char(0),char(55),char(0),char(38),char(255),char(215),char(0),char(55),char(0),char(42), -char(255),char(215),char(0),char(55),char(0),char(50),char(255),char(215),char(0),char(55), -char(0),char(52),char(255),char(215),char(0),char(55),char(0),char(55),char(0),char(41), -char(0),char(55),char(0),char(68),char(255),char(92),char(0),char(55),char(0),char(70), -char(255),char(113),char(0),char(55),char(0),char(71),char(255),char(113),char(0),char(55), -char(0),char(72),char(255),char(113),char(0),char(55),char(0),char(74),char(255),char(113), -char(0),char(55),char(0),char(80),char(255),char(154),char(0),char(55),char(0),char(81), -char(255),char(154),char(0),char(55),char(0),char(82),char(255),char(113),char(0),char(55), -char(0),char(83),char(255),char(154),char(0),char(55),char(0),char(84),char(255),char(113), -char(0),char(55),char(0),char(85),char(255),char(154),char(0),char(55),char(0),char(86), -char(255),char(133),char(0),char(55),char(0),char(88),char(255),char(154),char(0),char(55), -char(0),char(89),char(255),char(215),char(0),char(55),char(0),char(90),char(255),char(215), -char(0),char(55),char(0),char(91),char(255),char(215),char(0),char(55),char(0),char(92), -char(255),char(215),char(0),char(55),char(0),char(93),char(255),char(174),char(0),char(55), -char(0),char(130),char(255),char(113),char(0),char(55),char(0),char(131),char(255),char(113), -char(0),char(55),char(0),char(132),char(255),char(113),char(0),char(55),char(0),char(133), -char(255),char(113),char(0),char(55),char(0),char(134),char(255),char(113),char(0),char(55), -char(0),char(135),char(255),char(113),char(0),char(55),char(0),char(137),char(255),char(215), -char(0),char(55),char(0),char(148),char(255),char(215),char(0),char(55),char(0),char(149), -char(255),char(215),char(0),char(55),char(0),char(150),char(255),char(215),char(0),char(55), -char(0),char(151),char(255),char(215),char(0),char(55),char(0),char(152),char(255),char(215), -char(0),char(55),char(0),char(154),char(255),char(215),char(0),char(55),char(0),char(162), -char(255),char(113),char(0),char(55),char(0),char(163),char(255),char(92),char(0),char(55), -char(0),char(164),char(255),char(92),char(0),char(55),char(0),char(165),char(255),char(92), -char(0),char(55),char(0),char(166),char(255),char(92),char(0),char(55),char(0),char(167), -char(255),char(92),char(0),char(55),char(0),char(168),char(255),char(92),char(0),char(55), -char(0),char(169),char(255),char(113),char(0),char(55),char(0),char(170),char(255),char(113), -char(0),char(55),char(0),char(171),char(255),char(113),char(0),char(55),char(0),char(172), -char(255),char(113),char(0),char(55),char(0),char(173),char(255),char(113),char(0),char(55), -char(0),char(180),char(255),char(113),char(0),char(55),char(0),char(181),char(255),char(113), -char(0),char(55),char(0),char(182),char(255),char(113),char(0),char(55),char(0),char(183), -char(255),char(113),char(0),char(55),char(0),char(184),char(255),char(113),char(0),char(55), -char(0),char(186),char(255),char(113),char(0),char(55),char(0),char(187),char(255),char(154), -char(0),char(55),char(0),char(188),char(255),char(154),char(0),char(55),char(0),char(189), -char(255),char(154),char(0),char(55),char(0),char(190),char(255),char(154),char(0),char(55), -char(0),char(191),char(255),char(215),char(0),char(55),char(0),char(194),char(255),char(113), -char(0),char(55),char(0),char(195),char(255),char(92),char(0),char(55),char(0),char(196), -char(255),char(113),char(0),char(55),char(0),char(197),char(255),char(92),char(0),char(55), -char(0),char(198),char(255),char(113),char(0),char(55),char(0),char(199),char(255),char(92), -char(0),char(55),char(0),char(200),char(255),char(215),char(0),char(55),char(0),char(201), -char(255),char(113),char(0),char(55),char(0),char(202),char(255),char(215),char(0),char(55), -char(0),char(203),char(255),char(113),char(0),char(55),char(0),char(204),char(255),char(215), -char(0),char(55),char(0),char(205),char(255),char(113),char(0),char(55),char(0),char(206), -char(255),char(215),char(0),char(55),char(0),char(207),char(255),char(113),char(0),char(55), -char(0),char(209),char(255),char(113),char(0),char(55),char(0),char(211),char(255),char(113), -char(0),char(55),char(0),char(213),char(255),char(113),char(0),char(55),char(0),char(215), -char(255),char(113),char(0),char(55),char(0),char(217),char(255),char(113),char(0),char(55), -char(0),char(219),char(255),char(113),char(0),char(55),char(0),char(221),char(255),char(113), -char(0),char(55),char(0),char(222),char(255),char(215),char(0),char(55),char(0),char(223), -char(255),char(113),char(0),char(55),char(0),char(224),char(255),char(215),char(0),char(55), -char(0),char(225),char(255),char(113),char(0),char(55),char(0),char(226),char(255),char(215), -char(0),char(55),char(0),char(227),char(255),char(113),char(0),char(55),char(0),char(228), -char(255),char(215),char(0),char(55),char(0),char(229),char(255),char(113),char(0),char(55), -char(0),char(250),char(255),char(154),char(0),char(55),char(1),char(6),char(255),char(154), -char(0),char(55),char(1),char(8),char(255),char(154),char(0),char(55),char(1),char(13), -char(255),char(154),char(0),char(55),char(1),char(14),char(255),char(215),char(0),char(55), -char(1),char(15),char(255),char(113),char(0),char(55),char(1),char(16),char(255),char(215), -char(0),char(55),char(1),char(17),char(255),char(113),char(0),char(55),char(1),char(18), -char(255),char(215),char(0),char(55),char(1),char(19),char(255),char(113),char(0),char(55), -char(1),char(20),char(255),char(215),char(0),char(55),char(1),char(21),char(255),char(113), -char(0),char(55),char(1),char(23),char(255),char(154),char(0),char(55),char(1),char(25), -char(255),char(154),char(0),char(55),char(1),char(29),char(255),char(133),char(0),char(55), -char(1),char(33),char(255),char(133),char(0),char(55),char(1),char(36),char(0),char(41), -char(0),char(55),char(1),char(38),char(0),char(41),char(0),char(55),char(1),char(43), -char(255),char(154),char(0),char(55),char(1),char(45),char(255),char(154),char(0),char(55), -char(1),char(47),char(255),char(154),char(0),char(55),char(1),char(49),char(255),char(154), -char(0),char(55),char(1),char(51),char(255),char(154),char(0),char(55),char(1),char(53), -char(255),char(154),char(0),char(55),char(1),char(55),char(255),char(215),char(0),char(55), -char(1),char(60),char(255),char(174),char(0),char(55),char(1),char(62),char(255),char(174), -char(0),char(55),char(1),char(64),char(255),char(174),char(0),char(55),char(1),char(67), -char(255),char(113),char(0),char(55),char(1),char(68),char(255),char(92),char(0),char(55), -char(1),char(70),char(255),char(92),char(0),char(55),char(1),char(71),char(255),char(215), -char(0),char(55),char(1),char(72),char(255),char(113),char(0),char(55),char(1),char(74), -char(255),char(133),char(0),char(55),char(1),char(251),char(255),char(215),char(0),char(55), -char(1),char(253),char(255),char(215),char(0),char(55),char(2),char(2),char(255),char(174), -char(0),char(55),char(2),char(3),char(255),char(174),char(0),char(55),char(2),char(4), -char(255),char(174),char(0),char(55),char(2),char(8),char(255),char(133),char(0),char(55), -char(2),char(12),char(255),char(133),char(0),char(55),char(2),char(87),char(255),char(154), -char(0),char(55),char(2),char(88),char(255),char(113),char(0),char(55),char(2),char(89), -char(255),char(92),char(0),char(55),char(2),char(95),char(255),char(215),char(0),char(55), -char(2),char(96),char(255),char(113),char(0),char(55),char(2),char(98),char(255),char(154), -char(0),char(55),char(3),char(29),char(255),char(113),char(0),char(55),char(3),char(30), -char(255),char(92),char(0),char(55),char(3),char(31),char(255),char(113),char(0),char(55), -char(3),char(32),char(255),char(92),char(0),char(55),char(3),char(33),char(255),char(113), -char(0),char(55),char(3),char(34),char(255),char(92),char(0),char(55),char(3),char(35), -char(255),char(113),char(0),char(55),char(3),char(37),char(255),char(113),char(0),char(55), -char(3),char(38),char(255),char(92),char(0),char(55),char(3),char(39),char(255),char(113), -char(0),char(55),char(3),char(40),char(255),char(92),char(0),char(55),char(3),char(41), -char(255),char(113),char(0),char(55),char(3),char(42),char(255),char(92),char(0),char(55), -char(3),char(43),char(255),char(113),char(0),char(55),char(3),char(44),char(255),char(92), -char(0),char(55),char(3),char(45),char(255),char(113),char(0),char(55),char(3),char(46), -char(255),char(92),char(0),char(55),char(3),char(47),char(255),char(113),char(0),char(55), -char(3),char(48),char(255),char(92),char(0),char(55),char(3),char(49),char(255),char(113), -char(0),char(55),char(3),char(50),char(255),char(92),char(0),char(55),char(3),char(51), -char(255),char(113),char(0),char(55),char(3),char(52),char(255),char(92),char(0),char(55), -char(3),char(54),char(255),char(113),char(0),char(55),char(3),char(56),char(255),char(113), -char(0),char(55),char(3),char(58),char(255),char(113),char(0),char(55),char(3),char(60), -char(255),char(113),char(0),char(55),char(3),char(64),char(255),char(113),char(0),char(55), -char(3),char(66),char(255),char(113),char(0),char(55),char(3),char(68),char(255),char(113), -char(0),char(55),char(3),char(73),char(255),char(215),char(0),char(55),char(3),char(74), -char(255),char(113),char(0),char(55),char(3),char(75),char(255),char(215),char(0),char(55), -char(3),char(76),char(255),char(113),char(0),char(55),char(3),char(77),char(255),char(215), -char(0),char(55),char(3),char(78),char(255),char(113),char(0),char(55),char(3),char(79), -char(255),char(215),char(0),char(55),char(3),char(81),char(255),char(215),char(0),char(55), -char(3),char(82),char(255),char(113),char(0),char(55),char(3),char(83),char(255),char(215), -char(0),char(55),char(3),char(84),char(255),char(113),char(0),char(55),char(3),char(85), -char(255),char(215),char(0),char(55),char(3),char(86),char(255),char(113),char(0),char(55), -char(3),char(87),char(255),char(215),char(0),char(55),char(3),char(88),char(255),char(113), -char(0),char(55),char(3),char(89),char(255),char(215),char(0),char(55),char(3),char(90), -char(255),char(113),char(0),char(55),char(3),char(91),char(255),char(215),char(0),char(55), -char(3),char(92),char(255),char(113),char(0),char(55),char(3),char(93),char(255),char(215), -char(0),char(55),char(3),char(94),char(255),char(113),char(0),char(55),char(3),char(95), -char(255),char(215),char(0),char(55),char(3),char(96),char(255),char(113),char(0),char(55), -char(3),char(98),char(255),char(154),char(0),char(55),char(3),char(100),char(255),char(154), -char(0),char(55),char(3),char(102),char(255),char(154),char(0),char(55),char(3),char(104), -char(255),char(154),char(0),char(55),char(3),char(106),char(255),char(154),char(0),char(55), -char(3),char(108),char(255),char(154),char(0),char(55),char(3),char(110),char(255),char(154), -char(0),char(55),char(3),char(112),char(255),char(215),char(0),char(55),char(3),char(143), -char(0),char(41),char(0),char(56),char(0),char(15),char(255),char(215),char(0),char(56), -char(0),char(17),char(255),char(215),char(0),char(56),char(0),char(36),char(255),char(236), -char(0),char(56),char(0),char(130),char(255),char(236),char(0),char(56),char(0),char(131), -char(255),char(236),char(0),char(56),char(0),char(132),char(255),char(236),char(0),char(56), -char(0),char(133),char(255),char(236),char(0),char(56),char(0),char(134),char(255),char(236), -char(0),char(56),char(0),char(135),char(255),char(236),char(0),char(56),char(0),char(194), -char(255),char(236),char(0),char(56),char(0),char(196),char(255),char(236),char(0),char(56), -char(0),char(198),char(255),char(236),char(0),char(56),char(1),char(67),char(255),char(236), -char(0),char(56),char(2),char(8),char(255),char(215),char(0),char(56),char(2),char(12), -char(255),char(215),char(0),char(56),char(2),char(88),char(255),char(236),char(0),char(56), -char(3),char(29),char(255),char(236),char(0),char(56),char(3),char(31),char(255),char(236), -char(0),char(56),char(3),char(33),char(255),char(236),char(0),char(56),char(3),char(35), -char(255),char(236),char(0),char(56),char(3),char(37),char(255),char(236),char(0),char(56), -char(3),char(39),char(255),char(236),char(0),char(56),char(3),char(41),char(255),char(236), -char(0),char(56),char(3),char(43),char(255),char(236),char(0),char(56),char(3),char(45), -char(255),char(236),char(0),char(56),char(3),char(47),char(255),char(236),char(0),char(56), -char(3),char(49),char(255),char(236),char(0),char(56),char(3),char(51),char(255),char(236), -char(0),char(57),char(0),char(15),char(255),char(154),char(0),char(57),char(0),char(17), -char(255),char(154),char(0),char(57),char(0),char(34),char(0),char(41),char(0),char(57), -char(0),char(36),char(255),char(174),char(0),char(57),char(0),char(38),char(255),char(236), -char(0),char(57),char(0),char(42),char(255),char(236),char(0),char(57),char(0),char(50), -char(255),char(236),char(0),char(57),char(0),char(52),char(255),char(236),char(0),char(57), -char(0),char(68),char(255),char(215),char(0),char(57),char(0),char(70),char(255),char(215), -char(0),char(57),char(0),char(71),char(255),char(215),char(0),char(57),char(0),char(72), -char(255),char(215),char(0),char(57),char(0),char(74),char(255),char(236),char(0),char(57), -char(0),char(80),char(255),char(236),char(0),char(57),char(0),char(81),char(255),char(236), -char(0),char(57),char(0),char(82),char(255),char(215),char(0),char(57),char(0),char(83), -char(255),char(236),char(0),char(57),char(0),char(84),char(255),char(215),char(0),char(57), -char(0),char(85),char(255),char(236),char(0),char(57),char(0),char(86),char(255),char(236), -char(0),char(57),char(0),char(88),char(255),char(236),char(0),char(57),char(0),char(130), -char(255),char(174),char(0),char(57),char(0),char(131),char(255),char(174),char(0),char(57), -char(0),char(132),char(255),char(174),char(0),char(57),char(0),char(133),char(255),char(174), -char(0),char(57),char(0),char(134),char(255),char(174),char(0),char(57),char(0),char(135), -char(255),char(174),char(0),char(57),char(0),char(137),char(255),char(236),char(0),char(57), -char(0),char(148),char(255),char(236),char(0),char(57),char(0),char(149),char(255),char(236), -char(0),char(57),char(0),char(150),char(255),char(236),char(0),char(57),char(0),char(151), -char(255),char(236),char(0),char(57),char(0),char(152),char(255),char(236),char(0),char(57), -char(0),char(154),char(255),char(236),char(0),char(57),char(0),char(162),char(255),char(215), -char(0),char(57),char(0),char(163),char(255),char(215),char(0),char(57),char(0),char(164), -char(255),char(215),char(0),char(57),char(0),char(165),char(255),char(215),char(0),char(57), -char(0),char(166),char(255),char(215),char(0),char(57),char(0),char(167),char(255),char(215), -char(0),char(57),char(0),char(168),char(255),char(215),char(0),char(57),char(0),char(169), -char(255),char(215),char(0),char(57),char(0),char(170),char(255),char(215),char(0),char(57), -char(0),char(171),char(255),char(215),char(0),char(57),char(0),char(172),char(255),char(215), -char(0),char(57),char(0),char(173),char(255),char(215),char(0),char(57),char(0),char(180), -char(255),char(215),char(0),char(57),char(0),char(181),char(255),char(215),char(0),char(57), -char(0),char(182),char(255),char(215),char(0),char(57),char(0),char(183),char(255),char(215), -char(0),char(57),char(0),char(184),char(255),char(215),char(0),char(57),char(0),char(186), -char(255),char(215),char(0),char(57),char(0),char(187),char(255),char(236),char(0),char(57), -char(0),char(188),char(255),char(236),char(0),char(57),char(0),char(189),char(255),char(236), -char(0),char(57),char(0),char(190),char(255),char(236),char(0),char(57),char(0),char(194), -char(255),char(174),char(0),char(57),char(0),char(195),char(255),char(215),char(0),char(57), -char(0),char(196),char(255),char(174),char(0),char(57),char(0),char(197),char(255),char(215), -char(0),char(57),char(0),char(198),char(255),char(174),char(0),char(57),char(0),char(199), -char(255),char(215),char(0),char(57),char(0),char(200),char(255),char(236),char(0),char(57), -char(0),char(201),char(255),char(215),char(0),char(57),char(0),char(202),char(255),char(236), -char(0),char(57),char(0),char(203),char(255),char(215),char(0),char(57),char(0),char(204), -char(255),char(236),char(0),char(57),char(0),char(205),char(255),char(215),char(0),char(57), -char(0),char(206),char(255),char(236),char(0),char(57),char(0),char(207),char(255),char(215), -char(0),char(57),char(0),char(209),char(255),char(215),char(0),char(57),char(0),char(211), -char(255),char(215),char(0),char(57),char(0),char(213),char(255),char(215),char(0),char(57), -char(0),char(215),char(255),char(215),char(0),char(57),char(0),char(217),char(255),char(215), -char(0),char(57),char(0),char(219),char(255),char(215),char(0),char(57),char(0),char(221), -char(255),char(215),char(0),char(57),char(0),char(222),char(255),char(236),char(0),char(57), -char(0),char(223),char(255),char(236),char(0),char(57),char(0),char(224),char(255),char(236), -char(0),char(57),char(0),char(225),char(255),char(236),char(0),char(57),char(0),char(226), -char(255),char(236),char(0),char(57),char(0),char(227),char(255),char(236),char(0),char(57), -char(0),char(228),char(255),char(236),char(0),char(57),char(0),char(229),char(255),char(236), -char(0),char(57),char(0),char(250),char(255),char(236),char(0),char(57),char(1),char(6), -char(255),char(236),char(0),char(57),char(1),char(8),char(255),char(236),char(0),char(57), -char(1),char(13),char(255),char(236),char(0),char(57),char(1),char(14),char(255),char(236), -char(0),char(57),char(1),char(15),char(255),char(215),char(0),char(57),char(1),char(16), -char(255),char(236),char(0),char(57),char(1),char(17),char(255),char(215),char(0),char(57), -char(1),char(18),char(255),char(236),char(0),char(57),char(1),char(19),char(255),char(215), -char(0),char(57),char(1),char(20),char(255),char(236),char(0),char(57),char(1),char(21), -char(255),char(215),char(0),char(57),char(1),char(23),char(255),char(236),char(0),char(57), -char(1),char(25),char(255),char(236),char(0),char(57),char(1),char(29),char(255),char(236), -char(0),char(57),char(1),char(33),char(255),char(236),char(0),char(57),char(1),char(43), -char(255),char(236),char(0),char(57),char(1),char(45),char(255),char(236),char(0),char(57), -char(1),char(47),char(255),char(236),char(0),char(57),char(1),char(49),char(255),char(236), -char(0),char(57),char(1),char(51),char(255),char(236),char(0),char(57),char(1),char(53), -char(255),char(236),char(0),char(57),char(1),char(67),char(255),char(174),char(0),char(57), -char(1),char(68),char(255),char(215),char(0),char(57),char(1),char(70),char(255),char(215), -char(0),char(57),char(1),char(71),char(255),char(236),char(0),char(57),char(1),char(72), -char(255),char(215),char(0),char(57),char(1),char(74),char(255),char(236),char(0),char(57), -char(2),char(8),char(255),char(154),char(0),char(57),char(2),char(12),char(255),char(154), -char(0),char(57),char(2),char(87),char(255),char(236),char(0),char(57),char(2),char(88), -char(255),char(174),char(0),char(57),char(2),char(89),char(255),char(215),char(0),char(57), -char(2),char(95),char(255),char(236),char(0),char(57),char(2),char(96),char(255),char(215), -char(0),char(57),char(2),char(98),char(255),char(236),char(0),char(57),char(3),char(29), -char(255),char(174),char(0),char(57),char(3),char(30),char(255),char(215),char(0),char(57), -char(3),char(31),char(255),char(174),char(0),char(57),char(3),char(32),char(255),char(215), -char(0),char(57),char(3),char(33),char(255),char(174),char(0),char(57),char(3),char(34), -char(255),char(215),char(0),char(57),char(3),char(35),char(255),char(174),char(0),char(57), -char(3),char(37),char(255),char(174),char(0),char(57),char(3),char(38),char(255),char(215), -char(0),char(57),char(3),char(39),char(255),char(174),char(0),char(57),char(3),char(40), -char(255),char(215),char(0),char(57),char(3),char(41),char(255),char(174),char(0),char(57), -char(3),char(42),char(255),char(215),char(0),char(57),char(3),char(43),char(255),char(174), -char(0),char(57),char(3),char(44),char(255),char(215),char(0),char(57),char(3),char(45), -char(255),char(174),char(0),char(57),char(3),char(46),char(255),char(215),char(0),char(57), -char(3),char(47),char(255),char(174),char(0),char(57),char(3),char(48),char(255),char(215), -char(0),char(57),char(3),char(49),char(255),char(174),char(0),char(57),char(3),char(50), -char(255),char(215),char(0),char(57),char(3),char(51),char(255),char(174),char(0),char(57), -char(3),char(52),char(255),char(215),char(0),char(57),char(3),char(54),char(255),char(215), -char(0),char(57),char(3),char(56),char(255),char(215),char(0),char(57),char(3),char(58), -char(255),char(215),char(0),char(57),char(3),char(60),char(255),char(215),char(0),char(57), -char(3),char(64),char(255),char(215),char(0),char(57),char(3),char(66),char(255),char(215), -char(0),char(57),char(3),char(68),char(255),char(215),char(0),char(57),char(3),char(73), -char(255),char(236),char(0),char(57),char(3),char(74),char(255),char(215),char(0),char(57), -char(3),char(75),char(255),char(236),char(0),char(57),char(3),char(76),char(255),char(215), -char(0),char(57),char(3),char(77),char(255),char(236),char(0),char(57),char(3),char(78), -char(255),char(215),char(0),char(57),char(3),char(79),char(255),char(236),char(0),char(57), -char(3),char(81),char(255),char(236),char(0),char(57),char(3),char(82),char(255),char(215), -char(0),char(57),char(3),char(83),char(255),char(236),char(0),char(57),char(3),char(84), -char(255),char(215),char(0),char(57),char(3),char(85),char(255),char(236),char(0),char(57), -char(3),char(86),char(255),char(215),char(0),char(57),char(3),char(87),char(255),char(236), -char(0),char(57),char(3),char(88),char(255),char(215),char(0),char(57),char(3),char(89), -char(255),char(236),char(0),char(57),char(3),char(90),char(255),char(215),char(0),char(57), -char(3),char(91),char(255),char(236),char(0),char(57),char(3),char(92),char(255),char(215), -char(0),char(57),char(3),char(93),char(255),char(236),char(0),char(57),char(3),char(94), -char(255),char(215),char(0),char(57),char(3),char(95),char(255),char(236),char(0),char(57), -char(3),char(96),char(255),char(215),char(0),char(57),char(3),char(98),char(255),char(236), -char(0),char(57),char(3),char(100),char(255),char(236),char(0),char(57),char(3),char(102), -char(255),char(236),char(0),char(57),char(3),char(104),char(255),char(236),char(0),char(57), -char(3),char(106),char(255),char(236),char(0),char(57),char(3),char(108),char(255),char(236), -char(0),char(57),char(3),char(110),char(255),char(236),char(0),char(58),char(0),char(15), -char(255),char(154),char(0),char(58),char(0),char(17),char(255),char(154),char(0),char(58), -char(0),char(34),char(0),char(41),char(0),char(58),char(0),char(36),char(255),char(174), -char(0),char(58),char(0),char(38),char(255),char(236),char(0),char(58),char(0),char(42), -char(255),char(236),char(0),char(58),char(0),char(50),char(255),char(236),char(0),char(58), -char(0),char(52),char(255),char(236),char(0),char(58),char(0),char(68),char(255),char(215), -char(0),char(58),char(0),char(70),char(255),char(215),char(0),char(58),char(0),char(71), -char(255),char(215),char(0),char(58),char(0),char(72),char(255),char(215),char(0),char(58), -char(0),char(74),char(255),char(236),char(0),char(58),char(0),char(80),char(255),char(236), -char(0),char(58),char(0),char(81),char(255),char(236),char(0),char(58),char(0),char(82), -char(255),char(215),char(0),char(58),char(0),char(83),char(255),char(236),char(0),char(58), -char(0),char(84),char(255),char(215),char(0),char(58),char(0),char(85),char(255),char(236), -char(0),char(58),char(0),char(86),char(255),char(236),char(0),char(58),char(0),char(88), -char(255),char(236),char(0),char(58),char(0),char(130),char(255),char(174),char(0),char(58), -char(0),char(131),char(255),char(174),char(0),char(58),char(0),char(132),char(255),char(174), -char(0),char(58),char(0),char(133),char(255),char(174),char(0),char(58),char(0),char(134), -char(255),char(174),char(0),char(58),char(0),char(135),char(255),char(174),char(0),char(58), -char(0),char(137),char(255),char(236),char(0),char(58),char(0),char(148),char(255),char(236), -char(0),char(58),char(0),char(149),char(255),char(236),char(0),char(58),char(0),char(150), -char(255),char(236),char(0),char(58),char(0),char(151),char(255),char(236),char(0),char(58), -char(0),char(152),char(255),char(236),char(0),char(58),char(0),char(154),char(255),char(236), -char(0),char(58),char(0),char(162),char(255),char(215),char(0),char(58),char(0),char(163), -char(255),char(215),char(0),char(58),char(0),char(164),char(255),char(215),char(0),char(58), -char(0),char(165),char(255),char(215),char(0),char(58),char(0),char(166),char(255),char(215), -char(0),char(58),char(0),char(167),char(255),char(215),char(0),char(58),char(0),char(168), -char(255),char(215),char(0),char(58),char(0),char(169),char(255),char(215),char(0),char(58), -char(0),char(170),char(255),char(215),char(0),char(58),char(0),char(171),char(255),char(215), -char(0),char(58),char(0),char(172),char(255),char(215),char(0),char(58),char(0),char(173), -char(255),char(215),char(0),char(58),char(0),char(180),char(255),char(215),char(0),char(58), -char(0),char(181),char(255),char(215),char(0),char(58),char(0),char(182),char(255),char(215), -char(0),char(58),char(0),char(183),char(255),char(215),char(0),char(58),char(0),char(184), -char(255),char(215),char(0),char(58),char(0),char(186),char(255),char(215),char(0),char(58), -char(0),char(187),char(255),char(236),char(0),char(58),char(0),char(188),char(255),char(236), -char(0),char(58),char(0),char(189),char(255),char(236),char(0),char(58),char(0),char(190), -char(255),char(236),char(0),char(58),char(0),char(194),char(255),char(174),char(0),char(58), -char(0),char(195),char(255),char(215),char(0),char(58),char(0),char(196),char(255),char(174), -char(0),char(58),char(0),char(197),char(255),char(215),char(0),char(58),char(0),char(198), -char(255),char(174),char(0),char(58),char(0),char(199),char(255),char(215),char(0),char(58), -char(0),char(200),char(255),char(236),char(0),char(58),char(0),char(201),char(255),char(215), -char(0),char(58),char(0),char(202),char(255),char(236),char(0),char(58),char(0),char(203), -char(255),char(215),char(0),char(58),char(0),char(204),char(255),char(236),char(0),char(58), -char(0),char(205),char(255),char(215),char(0),char(58),char(0),char(206),char(255),char(236), -char(0),char(58),char(0),char(207),char(255),char(215),char(0),char(58),char(0),char(209), -char(255),char(215),char(0),char(58),char(0),char(211),char(255),char(215),char(0),char(58), -char(0),char(213),char(255),char(215),char(0),char(58),char(0),char(215),char(255),char(215), -char(0),char(58),char(0),char(217),char(255),char(215),char(0),char(58),char(0),char(219), -char(255),char(215),char(0),char(58),char(0),char(221),char(255),char(215),char(0),char(58), -char(0),char(222),char(255),char(236),char(0),char(58),char(0),char(223),char(255),char(236), -char(0),char(58),char(0),char(224),char(255),char(236),char(0),char(58),char(0),char(225), -char(255),char(236),char(0),char(58),char(0),char(226),char(255),char(236),char(0),char(58), -char(0),char(227),char(255),char(236),char(0),char(58),char(0),char(228),char(255),char(236), -char(0),char(58),char(0),char(229),char(255),char(236),char(0),char(58),char(0),char(250), -char(255),char(236),char(0),char(58),char(1),char(6),char(255),char(236),char(0),char(58), -char(1),char(8),char(255),char(236),char(0),char(58),char(1),char(13),char(255),char(236), -char(0),char(58),char(1),char(14),char(255),char(236),char(0),char(58),char(1),char(15), -char(255),char(215),char(0),char(58),char(1),char(16),char(255),char(236),char(0),char(58), -char(1),char(17),char(255),char(215),char(0),char(58),char(1),char(18),char(255),char(236), -char(0),char(58),char(1),char(19),char(255),char(215),char(0),char(58),char(1),char(20), -char(255),char(236),char(0),char(58),char(1),char(21),char(255),char(215),char(0),char(58), -char(1),char(23),char(255),char(236),char(0),char(58),char(1),char(25),char(255),char(236), -char(0),char(58),char(1),char(29),char(255),char(236),char(0),char(58),char(1),char(33), -char(255),char(236),char(0),char(58),char(1),char(43),char(255),char(236),char(0),char(58), -char(1),char(45),char(255),char(236),char(0),char(58),char(1),char(47),char(255),char(236), -char(0),char(58),char(1),char(49),char(255),char(236),char(0),char(58),char(1),char(51), -char(255),char(236),char(0),char(58),char(1),char(53),char(255),char(236),char(0),char(58), -char(1),char(67),char(255),char(174),char(0),char(58),char(1),char(68),char(255),char(215), -char(0),char(58),char(1),char(70),char(255),char(215),char(0),char(58),char(1),char(71), -char(255),char(236),char(0),char(58),char(1),char(72),char(255),char(215),char(0),char(58), -char(1),char(74),char(255),char(236),char(0),char(58),char(2),char(8),char(255),char(154), -char(0),char(58),char(2),char(12),char(255),char(154),char(0),char(58),char(2),char(87), -char(255),char(236),char(0),char(58),char(2),char(88),char(255),char(174),char(0),char(58), -char(2),char(89),char(255),char(215),char(0),char(58),char(2),char(95),char(255),char(236), -char(0),char(58),char(2),char(96),char(255),char(215),char(0),char(58),char(2),char(98), -char(255),char(236),char(0),char(58),char(3),char(29),char(255),char(174),char(0),char(58), -char(3),char(30),char(255),char(215),char(0),char(58),char(3),char(31),char(255),char(174), -char(0),char(58),char(3),char(32),char(255),char(215),char(0),char(58),char(3),char(33), -char(255),char(174),char(0),char(58),char(3),char(34),char(255),char(215),char(0),char(58), -char(3),char(35),char(255),char(174),char(0),char(58),char(3),char(37),char(255),char(174), -char(0),char(58),char(3),char(38),char(255),char(215),char(0),char(58),char(3),char(39), -char(255),char(174),char(0),char(58),char(3),char(40),char(255),char(215),char(0),char(58), -char(3),char(41),char(255),char(174),char(0),char(58),char(3),char(42),char(255),char(215), -char(0),char(58),char(3),char(43),char(255),char(174),char(0),char(58),char(3),char(44), -char(255),char(215),char(0),char(58),char(3),char(45),char(255),char(174),char(0),char(58), -char(3),char(46),char(255),char(215),char(0),char(58),char(3),char(47),char(255),char(174), -char(0),char(58),char(3),char(48),char(255),char(215),char(0),char(58),char(3),char(49), -char(255),char(174),char(0),char(58),char(3),char(50),char(255),char(215),char(0),char(58), -char(3),char(51),char(255),char(174),char(0),char(58),char(3),char(52),char(255),char(215), -char(0),char(58),char(3),char(54),char(255),char(215),char(0),char(58),char(3),char(56), -char(255),char(215),char(0),char(58),char(3),char(58),char(255),char(215),char(0),char(58), -char(3),char(60),char(255),char(215),char(0),char(58),char(3),char(64),char(255),char(215), -char(0),char(58),char(3),char(66),char(255),char(215),char(0),char(58),char(3),char(68), -char(255),char(215),char(0),char(58),char(3),char(73),char(255),char(236),char(0),char(58), -char(3),char(74),char(255),char(215),char(0),char(58),char(3),char(75),char(255),char(236), -char(0),char(58),char(3),char(76),char(255),char(215),char(0),char(58),char(3),char(77), -char(255),char(236),char(0),char(58),char(3),char(78),char(255),char(215),char(0),char(58), -char(3),char(79),char(255),char(236),char(0),char(58),char(3),char(81),char(255),char(236), -char(0),char(58),char(3),char(82),char(255),char(215),char(0),char(58),char(3),char(83), -char(255),char(236),char(0),char(58),char(3),char(84),char(255),char(215),char(0),char(58), -char(3),char(85),char(255),char(236),char(0),char(58),char(3),char(86),char(255),char(215), -char(0),char(58),char(3),char(87),char(255),char(236),char(0),char(58),char(3),char(88), -char(255),char(215),char(0),char(58),char(3),char(89),char(255),char(236),char(0),char(58), -char(3),char(90),char(255),char(215),char(0),char(58),char(3),char(91),char(255),char(236), -char(0),char(58),char(3),char(92),char(255),char(215),char(0),char(58),char(3),char(93), -char(255),char(236),char(0),char(58),char(3),char(94),char(255),char(215),char(0),char(58), -char(3),char(95),char(255),char(236),char(0),char(58),char(3),char(96),char(255),char(215), -char(0),char(58),char(3),char(98),char(255),char(236),char(0),char(58),char(3),char(100), -char(255),char(236),char(0),char(58),char(3),char(102),char(255),char(236),char(0),char(58), -char(3),char(104),char(255),char(236),char(0),char(58),char(3),char(106),char(255),char(236), -char(0),char(58),char(3),char(108),char(255),char(236),char(0),char(58),char(3),char(110), -char(255),char(236),char(0),char(59),char(0),char(38),char(255),char(215),char(0),char(59), -char(0),char(42),char(255),char(215),char(0),char(59),char(0),char(50),char(255),char(215), -char(0),char(59),char(0),char(52),char(255),char(215),char(0),char(59),char(0),char(137), -char(255),char(215),char(0),char(59),char(0),char(148),char(255),char(215),char(0),char(59), -char(0),char(149),char(255),char(215),char(0),char(59),char(0),char(150),char(255),char(215), -char(0),char(59),char(0),char(151),char(255),char(215),char(0),char(59),char(0),char(152), -char(255),char(215),char(0),char(59),char(0),char(154),char(255),char(215),char(0),char(59), -char(0),char(200),char(255),char(215),char(0),char(59),char(0),char(202),char(255),char(215), -char(0),char(59),char(0),char(204),char(255),char(215),char(0),char(59),char(0),char(206), -char(255),char(215),char(0),char(59),char(0),char(222),char(255),char(215),char(0),char(59), -char(0),char(224),char(255),char(215),char(0),char(59),char(0),char(226),char(255),char(215), -char(0),char(59),char(0),char(228),char(255),char(215),char(0),char(59),char(1),char(14), -char(255),char(215),char(0),char(59),char(1),char(16),char(255),char(215),char(0),char(59), -char(1),char(18),char(255),char(215),char(0),char(59),char(1),char(20),char(255),char(215), -char(0),char(59),char(1),char(71),char(255),char(215),char(0),char(59),char(2),char(95), -char(255),char(215),char(0),char(59),char(3),char(73),char(255),char(215),char(0),char(59), -char(3),char(75),char(255),char(215),char(0),char(59),char(3),char(77),char(255),char(215), -char(0),char(59),char(3),char(79),char(255),char(215),char(0),char(59),char(3),char(81), -char(255),char(215),char(0),char(59),char(3),char(83),char(255),char(215),char(0),char(59), -char(3),char(85),char(255),char(215),char(0),char(59),char(3),char(87),char(255),char(215), -char(0),char(59),char(3),char(89),char(255),char(215),char(0),char(59),char(3),char(91), -char(255),char(215),char(0),char(59),char(3),char(93),char(255),char(215),char(0),char(59), -char(3),char(95),char(255),char(215),char(0),char(60),char(0),char(15),char(255),char(133), -char(0),char(60),char(0),char(17),char(255),char(133),char(0),char(60),char(0),char(34), -char(0),char(41),char(0),char(60),char(0),char(36),char(255),char(133),char(0),char(60), -char(0),char(38),char(255),char(215),char(0),char(60),char(0),char(42),char(255),char(215), -char(0),char(60),char(0),char(50),char(255),char(215),char(0),char(60),char(0),char(52), -char(255),char(215),char(0),char(60),char(0),char(68),char(255),char(154),char(0),char(60), -char(0),char(70),char(255),char(154),char(0),char(60),char(0),char(71),char(255),char(154), -char(0),char(60),char(0),char(72),char(255),char(154),char(0),char(60),char(0),char(74), -char(255),char(215),char(0),char(60),char(0),char(80),char(255),char(195),char(0),char(60), -char(0),char(81),char(255),char(195),char(0),char(60),char(0),char(82),char(255),char(154), -char(0),char(60),char(0),char(83),char(255),char(195),char(0),char(60),char(0),char(84), -char(255),char(154),char(0),char(60),char(0),char(85),char(255),char(195),char(0),char(60), -char(0),char(86),char(255),char(174),char(0),char(60),char(0),char(88),char(255),char(195), -char(0),char(60),char(0),char(93),char(255),char(215),char(0),char(60),char(0),char(130), -char(255),char(133),char(0),char(60),char(0),char(131),char(255),char(133),char(0),char(60), -char(0),char(132),char(255),char(133),char(0),char(60),char(0),char(133),char(255),char(133), -char(0),char(60),char(0),char(134),char(255),char(133),char(0),char(60),char(0),char(135), -char(255),char(133),char(0),char(60),char(0),char(137),char(255),char(215),char(0),char(60), -char(0),char(148),char(255),char(215),char(0),char(60),char(0),char(149),char(255),char(215), -char(0),char(60),char(0),char(150),char(255),char(215),char(0),char(60),char(0),char(151), -char(255),char(215),char(0),char(60),char(0),char(152),char(255),char(215),char(0),char(60), -char(0),char(154),char(255),char(215),char(0),char(60),char(0),char(162),char(255),char(154), -char(0),char(60),char(0),char(163),char(255),char(154),char(0),char(60),char(0),char(164), -char(255),char(154),char(0),char(60),char(0),char(165),char(255),char(154),char(0),char(60), -char(0),char(166),char(255),char(154),char(0),char(60),char(0),char(167),char(255),char(154), -char(0),char(60),char(0),char(168),char(255),char(154),char(0),char(60),char(0),char(169), -char(255),char(154),char(0),char(60),char(0),char(170),char(255),char(154),char(0),char(60), -char(0),char(171),char(255),char(154),char(0),char(60),char(0),char(172),char(255),char(154), -char(0),char(60),char(0),char(173),char(255),char(154),char(0),char(60),char(0),char(180), -char(255),char(154),char(0),char(60),char(0),char(181),char(255),char(154),char(0),char(60), -char(0),char(182),char(255),char(154),char(0),char(60),char(0),char(183),char(255),char(154), -char(0),char(60),char(0),char(184),char(255),char(154),char(0),char(60),char(0),char(186), -char(255),char(154),char(0),char(60),char(0),char(187),char(255),char(195),char(0),char(60), -char(0),char(188),char(255),char(195),char(0),char(60),char(0),char(189),char(255),char(195), -char(0),char(60),char(0),char(190),char(255),char(195),char(0),char(60),char(0),char(194), -char(255),char(133),char(0),char(60),char(0),char(195),char(255),char(154),char(0),char(60), -char(0),char(196),char(255),char(133),char(0),char(60),char(0),char(197),char(255),char(154), -char(0),char(60),char(0),char(198),char(255),char(133),char(0),char(60),char(0),char(199), -char(255),char(154),char(0),char(60),char(0),char(200),char(255),char(215),char(0),char(60), -char(0),char(201),char(255),char(154),char(0),char(60),char(0),char(202),char(255),char(215), -char(0),char(60),char(0),char(203),char(255),char(154),char(0),char(60),char(0),char(204), -char(255),char(215),char(0),char(60),char(0),char(205),char(255),char(154),char(0),char(60), -char(0),char(206),char(255),char(215),char(0),char(60),char(0),char(207),char(255),char(154), -char(0),char(60),char(0),char(209),char(255),char(154),char(0),char(60),char(0),char(211), -char(255),char(154),char(0),char(60),char(0),char(213),char(255),char(154),char(0),char(60), -char(0),char(215),char(255),char(154),char(0),char(60),char(0),char(217),char(255),char(154), -char(0),char(60),char(0),char(219),char(255),char(154),char(0),char(60),char(0),char(221), -char(255),char(154),char(0),char(60),char(0),char(222),char(255),char(215),char(0),char(60), -char(0),char(223),char(255),char(215),char(0),char(60),char(0),char(224),char(255),char(215), -char(0),char(60),char(0),char(225),char(255),char(215),char(0),char(60),char(0),char(226), -char(255),char(215),char(0),char(60),char(0),char(227),char(255),char(215),char(0),char(60), -char(0),char(228),char(255),char(215),char(0),char(60),char(0),char(229),char(255),char(215), -char(0),char(60),char(0),char(250),char(255),char(195),char(0),char(60),char(1),char(6), -char(255),char(195),char(0),char(60),char(1),char(8),char(255),char(195),char(0),char(60), -char(1),char(13),char(255),char(195),char(0),char(60),char(1),char(14),char(255),char(215), -char(0),char(60),char(1),char(15),char(255),char(154),char(0),char(60),char(1),char(16), -char(255),char(215),char(0),char(60),char(1),char(17),char(255),char(154),char(0),char(60), -char(1),char(18),char(255),char(215),char(0),char(60),char(1),char(19),char(255),char(154), -char(0),char(60),char(1),char(20),char(255),char(215),char(0),char(60),char(1),char(21), -char(255),char(154),char(0),char(60),char(1),char(23),char(255),char(195),char(0),char(60), -char(1),char(25),char(255),char(195),char(0),char(60),char(1),char(29),char(255),char(174), -char(0),char(60),char(1),char(33),char(255),char(174),char(0),char(60),char(1),char(43), -char(255),char(195),char(0),char(60),char(1),char(45),char(255),char(195),char(0),char(60), -char(1),char(47),char(255),char(195),char(0),char(60),char(1),char(49),char(255),char(195), -char(0),char(60),char(1),char(51),char(255),char(195),char(0),char(60),char(1),char(53), -char(255),char(195),char(0),char(60),char(1),char(60),char(255),char(215),char(0),char(60), -char(1),char(62),char(255),char(215),char(0),char(60),char(1),char(64),char(255),char(215), -char(0),char(60),char(1),char(67),char(255),char(133),char(0),char(60),char(1),char(68), -char(255),char(154),char(0),char(60),char(1),char(70),char(255),char(154),char(0),char(60), -char(1),char(71),char(255),char(215),char(0),char(60),char(1),char(72),char(255),char(154), -char(0),char(60),char(1),char(74),char(255),char(174),char(0),char(60),char(2),char(8), -char(255),char(133),char(0),char(60),char(2),char(12),char(255),char(133),char(0),char(60), -char(2),char(87),char(255),char(195),char(0),char(60),char(2),char(88),char(255),char(133), -char(0),char(60),char(2),char(89),char(255),char(154),char(0),char(60),char(2),char(95), -char(255),char(215),char(0),char(60),char(2),char(96),char(255),char(154),char(0),char(60), -char(2),char(98),char(255),char(195),char(0),char(60),char(3),char(29),char(255),char(133), -char(0),char(60),char(3),char(30),char(255),char(154),char(0),char(60),char(3),char(31), -char(255),char(133),char(0),char(60),char(3),char(32),char(255),char(154),char(0),char(60), -char(3),char(33),char(255),char(133),char(0),char(60),char(3),char(34),char(255),char(154), -char(0),char(60),char(3),char(35),char(255),char(133),char(0),char(60),char(3),char(37), -char(255),char(133),char(0),char(60),char(3),char(38),char(255),char(154),char(0),char(60), -char(3),char(39),char(255),char(133),char(0),char(60),char(3),char(40),char(255),char(154), -char(0),char(60),char(3),char(41),char(255),char(133),char(0),char(60),char(3),char(42), -char(255),char(154),char(0),char(60),char(3),char(43),char(255),char(133),char(0),char(60), -char(3),char(44),char(255),char(154),char(0),char(60),char(3),char(45),char(255),char(133), -char(0),char(60),char(3),char(46),char(255),char(154),char(0),char(60),char(3),char(47), -char(255),char(133),char(0),char(60),char(3),char(48),char(255),char(154),char(0),char(60), -char(3),char(49),char(255),char(133),char(0),char(60),char(3),char(50),char(255),char(154), -char(0),char(60),char(3),char(51),char(255),char(133),char(0),char(60),char(3),char(52), -char(255),char(154),char(0),char(60),char(3),char(54),char(255),char(154),char(0),char(60), -char(3),char(56),char(255),char(154),char(0),char(60),char(3),char(58),char(255),char(154), -char(0),char(60),char(3),char(60),char(255),char(154),char(0),char(60),char(3),char(64), -char(255),char(154),char(0),char(60),char(3),char(66),char(255),char(154),char(0),char(60), -char(3),char(68),char(255),char(154),char(0),char(60),char(3),char(73),char(255),char(215), -char(0),char(60),char(3),char(74),char(255),char(154),char(0),char(60),char(3),char(75), -char(255),char(215),char(0),char(60),char(3),char(76),char(255),char(154),char(0),char(60), -char(3),char(77),char(255),char(215),char(0),char(60),char(3),char(78),char(255),char(154), -char(0),char(60),char(3),char(79),char(255),char(215),char(0),char(60),char(3),char(81), -char(255),char(215),char(0),char(60),char(3),char(82),char(255),char(154),char(0),char(60), -char(3),char(83),char(255),char(215),char(0),char(60),char(3),char(84),char(255),char(154), -char(0),char(60),char(3),char(85),char(255),char(215),char(0),char(60),char(3),char(86), -char(255),char(154),char(0),char(60),char(3),char(87),char(255),char(215),char(0),char(60), -char(3),char(88),char(255),char(154),char(0),char(60),char(3),char(89),char(255),char(215), -char(0),char(60),char(3),char(90),char(255),char(154),char(0),char(60),char(3),char(91), -char(255),char(215),char(0),char(60),char(3),char(92),char(255),char(154),char(0),char(60), -char(3),char(93),char(255),char(215),char(0),char(60),char(3),char(94),char(255),char(154), -char(0),char(60),char(3),char(95),char(255),char(215),char(0),char(60),char(3),char(96), -char(255),char(154),char(0),char(60),char(3),char(98),char(255),char(195),char(0),char(60), -char(3),char(100),char(255),char(195),char(0),char(60),char(3),char(102),char(255),char(195), -char(0),char(60),char(3),char(104),char(255),char(195),char(0),char(60),char(3),char(106), -char(255),char(195),char(0),char(60),char(3),char(108),char(255),char(195),char(0),char(60), -char(3),char(110),char(255),char(195),char(0),char(61),char(0),char(38),char(255),char(236), -char(0),char(61),char(0),char(42),char(255),char(236),char(0),char(61),char(0),char(50), -char(255),char(236),char(0),char(61),char(0),char(52),char(255),char(236),char(0),char(61), -char(0),char(137),char(255),char(236),char(0),char(61),char(0),char(148),char(255),char(236), -char(0),char(61),char(0),char(149),char(255),char(236),char(0),char(61),char(0),char(150), -char(255),char(236),char(0),char(61),char(0),char(151),char(255),char(236),char(0),char(61), -char(0),char(152),char(255),char(236),char(0),char(61),char(0),char(154),char(255),char(236), -char(0),char(61),char(0),char(200),char(255),char(236),char(0),char(61),char(0),char(202), -char(255),char(236),char(0),char(61),char(0),char(204),char(255),char(236),char(0),char(61), -char(0),char(206),char(255),char(236),char(0),char(61),char(0),char(222),char(255),char(236), -char(0),char(61),char(0),char(224),char(255),char(236),char(0),char(61),char(0),char(226), -char(255),char(236),char(0),char(61),char(0),char(228),char(255),char(236),char(0),char(61), -char(1),char(14),char(255),char(236),char(0),char(61),char(1),char(16),char(255),char(236), -char(0),char(61),char(1),char(18),char(255),char(236),char(0),char(61),char(1),char(20), -char(255),char(236),char(0),char(61),char(1),char(71),char(255),char(236),char(0),char(61), -char(2),char(95),char(255),char(236),char(0),char(61),char(3),char(73),char(255),char(236), -char(0),char(61),char(3),char(75),char(255),char(236),char(0),char(61),char(3),char(77), -char(255),char(236),char(0),char(61),char(3),char(79),char(255),char(236),char(0),char(61), -char(3),char(81),char(255),char(236),char(0),char(61),char(3),char(83),char(255),char(236), -char(0),char(61),char(3),char(85),char(255),char(236),char(0),char(61),char(3),char(87), -char(255),char(236),char(0),char(61),char(3),char(89),char(255),char(236),char(0),char(61), -char(3),char(91),char(255),char(236),char(0),char(61),char(3),char(93),char(255),char(236), -char(0),char(61),char(3),char(95),char(255),char(236),char(0),char(62),char(0),char(45), -char(0),char(184),char(0),char(68),char(0),char(5),char(255),char(236),char(0),char(68), -char(0),char(10),char(255),char(236),char(0),char(68),char(2),char(7),char(255),char(236), -char(0),char(68),char(2),char(11),char(255),char(236),char(0),char(69),char(0),char(5), -char(255),char(236),char(0),char(69),char(0),char(10),char(255),char(236),char(0),char(69), -char(0),char(89),char(255),char(215),char(0),char(69),char(0),char(90),char(255),char(215), -char(0),char(69),char(0),char(91),char(255),char(215),char(0),char(69),char(0),char(92), -char(255),char(215),char(0),char(69),char(0),char(93),char(255),char(236),char(0),char(69), -char(0),char(191),char(255),char(215),char(0),char(69),char(1),char(55),char(255),char(215), -char(0),char(69),char(1),char(60),char(255),char(236),char(0),char(69),char(1),char(62), -char(255),char(236),char(0),char(69),char(1),char(64),char(255),char(236),char(0),char(69), -char(1),char(251),char(255),char(215),char(0),char(69),char(1),char(253),char(255),char(215), -char(0),char(69),char(2),char(7),char(255),char(236),char(0),char(69),char(2),char(11), -char(255),char(236),char(0),char(69),char(3),char(112),char(255),char(215),char(0),char(70), -char(0),char(5),char(0),char(41),char(0),char(70),char(0),char(10),char(0),char(41), -char(0),char(70),char(2),char(7),char(0),char(41),char(0),char(70),char(2),char(11), -char(0),char(41),char(0),char(72),char(0),char(5),char(255),char(236),char(0),char(72), -char(0),char(10),char(255),char(236),char(0),char(72),char(0),char(89),char(255),char(215), -char(0),char(72),char(0),char(90),char(255),char(215),char(0),char(72),char(0),char(91), -char(255),char(215),char(0),char(72),char(0),char(92),char(255),char(215),char(0),char(72), -char(0),char(93),char(255),char(236),char(0),char(72),char(0),char(191),char(255),char(215), -char(0),char(72),char(1),char(55),char(255),char(215),char(0),char(72),char(1),char(60), -char(255),char(236),char(0),char(72),char(1),char(62),char(255),char(236),char(0),char(72), -char(1),char(64),char(255),char(236),char(0),char(72),char(1),char(251),char(255),char(215), -char(0),char(72),char(1),char(253),char(255),char(215),char(0),char(72),char(2),char(7), -char(255),char(236),char(0),char(72),char(2),char(11),char(255),char(236),char(0),char(72), -char(3),char(112),char(255),char(215),char(0),char(73),char(0),char(5),char(0),char(123), -char(0),char(73),char(0),char(10),char(0),char(123),char(0),char(73),char(2),char(7), -char(0),char(123),char(0),char(73),char(2),char(11),char(0),char(123),char(0),char(75), -char(0),char(5),char(255),char(236),char(0),char(75),char(0),char(10),char(255),char(236), -char(0),char(75),char(2),char(7),char(255),char(236),char(0),char(75),char(2),char(11), -char(255),char(236),char(0),char(78),char(0),char(70),char(255),char(215),char(0),char(78), -char(0),char(71),char(255),char(215),char(0),char(78),char(0),char(72),char(255),char(215), -char(0),char(78),char(0),char(82),char(255),char(215),char(0),char(78),char(0),char(84), -char(255),char(215),char(0),char(78),char(0),char(162),char(255),char(215),char(0),char(78), -char(0),char(169),char(255),char(215),char(0),char(78),char(0),char(170),char(255),char(215), -char(0),char(78),char(0),char(171),char(255),char(215),char(0),char(78),char(0),char(172), -char(255),char(215),char(0),char(78),char(0),char(173),char(255),char(215),char(0),char(78), -char(0),char(180),char(255),char(215),char(0),char(78),char(0),char(181),char(255),char(215), -char(0),char(78),char(0),char(182),char(255),char(215),char(0),char(78),char(0),char(183), -char(255),char(215),char(0),char(78),char(0),char(184),char(255),char(215),char(0),char(78), -char(0),char(186),char(255),char(215),char(0),char(78),char(0),char(201),char(255),char(215), -char(0),char(78),char(0),char(203),char(255),char(215),char(0),char(78),char(0),char(205), -char(255),char(215),char(0),char(78),char(0),char(207),char(255),char(215),char(0),char(78), -char(0),char(209),char(255),char(215),char(0),char(78),char(0),char(211),char(255),char(215), -char(0),char(78),char(0),char(213),char(255),char(215),char(0),char(78),char(0),char(215), -char(255),char(215),char(0),char(78),char(0),char(217),char(255),char(215),char(0),char(78), -char(0),char(219),char(255),char(215),char(0),char(78),char(0),char(221),char(255),char(215), -char(0),char(78),char(1),char(15),char(255),char(215),char(0),char(78),char(1),char(17), -char(255),char(215),char(0),char(78),char(1),char(19),char(255),char(215),char(0),char(78), -char(1),char(21),char(255),char(215),char(0),char(78),char(1),char(72),char(255),char(215), -char(0),char(78),char(2),char(96),char(255),char(215),char(0),char(78),char(3),char(54), -char(255),char(215),char(0),char(78),char(3),char(56),char(255),char(215),char(0),char(78), -char(3),char(58),char(255),char(215),char(0),char(78),char(3),char(60),char(255),char(215), -char(0),char(78),char(3),char(64),char(255),char(215),char(0),char(78),char(3),char(66), -char(255),char(215),char(0),char(78),char(3),char(68),char(255),char(215),char(0),char(78), -char(3),char(74),char(255),char(215),char(0),char(78),char(3),char(76),char(255),char(215), -char(0),char(78),char(3),char(78),char(255),char(215),char(0),char(78),char(3),char(82), -char(255),char(215),char(0),char(78),char(3),char(84),char(255),char(215),char(0),char(78), -char(3),char(86),char(255),char(215),char(0),char(78),char(3),char(88),char(255),char(215), -char(0),char(78),char(3),char(90),char(255),char(215),char(0),char(78),char(3),char(92), -char(255),char(215),char(0),char(78),char(3),char(94),char(255),char(215),char(0),char(78), -char(3),char(96),char(255),char(215),char(0),char(80),char(0),char(5),char(255),char(236), -char(0),char(80),char(0),char(10),char(255),char(236),char(0),char(80),char(2),char(7), -char(255),char(236),char(0),char(80),char(2),char(11),char(255),char(236),char(0),char(81), -char(0),char(5),char(255),char(236),char(0),char(81),char(0),char(10),char(255),char(236), -char(0),char(81),char(2),char(7),char(255),char(236),char(0),char(81),char(2),char(11), -char(255),char(236),char(0),char(82),char(0),char(5),char(255),char(236),char(0),char(82), -char(0),char(10),char(255),char(236),char(0),char(82),char(0),char(89),char(255),char(215), -char(0),char(82),char(0),char(90),char(255),char(215),char(0),char(82),char(0),char(91), -char(255),char(215),char(0),char(82),char(0),char(92),char(255),char(215),char(0),char(82), -char(0),char(93),char(255),char(236),char(0),char(82),char(0),char(191),char(255),char(215), -char(0),char(82),char(1),char(55),char(255),char(215),char(0),char(82),char(1),char(60), -char(255),char(236),char(0),char(82),char(1),char(62),char(255),char(236),char(0),char(82), -char(1),char(64),char(255),char(236),char(0),char(82),char(1),char(251),char(255),char(215), -char(0),char(82),char(1),char(253),char(255),char(215),char(0),char(82),char(2),char(7), -char(255),char(236),char(0),char(82),char(2),char(11),char(255),char(236),char(0),char(82), -char(3),char(112),char(255),char(215),char(0),char(83),char(0),char(5),char(255),char(236), -char(0),char(83),char(0),char(10),char(255),char(236),char(0),char(83),char(0),char(89), -char(255),char(215),char(0),char(83),char(0),char(90),char(255),char(215),char(0),char(83), -char(0),char(91),char(255),char(215),char(0),char(83),char(0),char(92),char(255),char(215), -char(0),char(83),char(0),char(93),char(255),char(236),char(0),char(83),char(0),char(191), -char(255),char(215),char(0),char(83),char(1),char(55),char(255),char(215),char(0),char(83), -char(1),char(60),char(255),char(236),char(0),char(83),char(1),char(62),char(255),char(236), -char(0),char(83),char(1),char(64),char(255),char(236),char(0),char(83),char(1),char(251), -char(255),char(215),char(0),char(83),char(1),char(253),char(255),char(215),char(0),char(83), -char(2),char(7),char(255),char(236),char(0),char(83),char(2),char(11),char(255),char(236), -char(0),char(83),char(3),char(112),char(255),char(215),char(0),char(85),char(0),char(5), -char(0),char(82),char(0),char(85),char(0),char(10),char(0),char(82),char(0),char(85), -char(0),char(68),char(255),char(215),char(0),char(85),char(0),char(70),char(255),char(215), -char(0),char(85),char(0),char(71),char(255),char(215),char(0),char(85),char(0),char(72), -char(255),char(215),char(0),char(85),char(0),char(74),char(255),char(236),char(0),char(85), -char(0),char(82),char(255),char(215),char(0),char(85),char(0),char(84),char(255),char(215), -char(0),char(85),char(0),char(162),char(255),char(215),char(0),char(85),char(0),char(163), -char(255),char(215),char(0),char(85),char(0),char(164),char(255),char(215),char(0),char(85), -char(0),char(165),char(255),char(215),char(0),char(85),char(0),char(166),char(255),char(215), -char(0),char(85),char(0),char(167),char(255),char(215),char(0),char(85),char(0),char(168), -char(255),char(215),char(0),char(85),char(0),char(169),char(255),char(215),char(0),char(85), -char(0),char(170),char(255),char(215),char(0),char(85),char(0),char(171),char(255),char(215), -char(0),char(85),char(0),char(172),char(255),char(215),char(0),char(85),char(0),char(173), -char(255),char(215),char(0),char(85),char(0),char(180),char(255),char(215),char(0),char(85), -char(0),char(181),char(255),char(215),char(0),char(85),char(0),char(182),char(255),char(215), -char(0),char(85),char(0),char(183),char(255),char(215),char(0),char(85),char(0),char(184), -char(255),char(215),char(0),char(85),char(0),char(186),char(255),char(215),char(0),char(85), -char(0),char(195),char(255),char(215),char(0),char(85),char(0),char(197),char(255),char(215), -char(0),char(85),char(0),char(199),char(255),char(215),char(0),char(85),char(0),char(201), -char(255),char(215),char(0),char(85),char(0),char(203),char(255),char(215),char(0),char(85), -char(0),char(205),char(255),char(215),char(0),char(85),char(0),char(207),char(255),char(215), -char(0),char(85),char(0),char(209),char(255),char(215),char(0),char(85),char(0),char(211), -char(255),char(215),char(0),char(85),char(0),char(213),char(255),char(215),char(0),char(85), -char(0),char(215),char(255),char(215),char(0),char(85),char(0),char(217),char(255),char(215), -char(0),char(85),char(0),char(219),char(255),char(215),char(0),char(85),char(0),char(221), -char(255),char(215),char(0),char(85),char(0),char(223),char(255),char(236),char(0),char(85), -char(0),char(225),char(255),char(236),char(0),char(85),char(0),char(227),char(255),char(236), -char(0),char(85),char(0),char(229),char(255),char(236),char(0),char(85),char(1),char(15), -char(255),char(215),char(0),char(85),char(1),char(17),char(255),char(215),char(0),char(85), -char(1),char(19),char(255),char(215),char(0),char(85),char(1),char(21),char(255),char(215), -char(0),char(85),char(1),char(68),char(255),char(215),char(0),char(85),char(1),char(70), -char(255),char(215),char(0),char(85),char(1),char(72),char(255),char(215),char(0),char(85), -char(2),char(7),char(0),char(82),char(0),char(85),char(2),char(11),char(0),char(82), -char(0),char(85),char(2),char(89),char(255),char(215),char(0),char(85),char(2),char(96), -char(255),char(215),char(0),char(85),char(3),char(30),char(255),char(215),char(0),char(85), -char(3),char(32),char(255),char(215),char(0),char(85),char(3),char(34),char(255),char(215), -char(0),char(85),char(3),char(38),char(255),char(215),char(0),char(85),char(3),char(40), -char(255),char(215),char(0),char(85),char(3),char(42),char(255),char(215),char(0),char(85), -char(3),char(44),char(255),char(215),char(0),char(85),char(3),char(46),char(255),char(215), -char(0),char(85),char(3),char(48),char(255),char(215),char(0),char(85),char(3),char(50), -char(255),char(215),char(0),char(85),char(3),char(52),char(255),char(215),char(0),char(85), -char(3),char(54),char(255),char(215),char(0),char(85),char(3),char(56),char(255),char(215), -char(0),char(85),char(3),char(58),char(255),char(215),char(0),char(85),char(3),char(60), -char(255),char(215),char(0),char(85),char(3),char(64),char(255),char(215),char(0),char(85), -char(3),char(66),char(255),char(215),char(0),char(85),char(3),char(68),char(255),char(215), -char(0),char(85),char(3),char(74),char(255),char(215),char(0),char(85),char(3),char(76), -char(255),char(215),char(0),char(85),char(3),char(78),char(255),char(215),char(0),char(85), -char(3),char(82),char(255),char(215),char(0),char(85),char(3),char(84),char(255),char(215), -char(0),char(85),char(3),char(86),char(255),char(215),char(0),char(85),char(3),char(88), -char(255),char(215),char(0),char(85),char(3),char(90),char(255),char(215),char(0),char(85), -char(3),char(92),char(255),char(215),char(0),char(85),char(3),char(94),char(255),char(215), -char(0),char(85),char(3),char(96),char(255),char(215),char(0),char(87),char(0),char(5), -char(0),char(41),char(0),char(87),char(0),char(10),char(0),char(41),char(0),char(87), -char(2),char(7),char(0),char(41),char(0),char(87),char(2),char(11),char(0),char(41), -char(0),char(89),char(0),char(5),char(0),char(82),char(0),char(89),char(0),char(10), -char(0),char(82),char(0),char(89),char(0),char(15),char(255),char(174),char(0),char(89), -char(0),char(17),char(255),char(174),char(0),char(89),char(0),char(34),char(0),char(41), -char(0),char(89),char(2),char(7),char(0),char(82),char(0),char(89),char(2),char(8), -char(255),char(174),char(0),char(89),char(2),char(11),char(0),char(82),char(0),char(89), -char(2),char(12),char(255),char(174),char(0),char(90),char(0),char(5),char(0),char(82), -char(0),char(90),char(0),char(10),char(0),char(82),char(0),char(90),char(0),char(15), -char(255),char(174),char(0),char(90),char(0),char(17),char(255),char(174),char(0),char(90), -char(0),char(34),char(0),char(41),char(0),char(90),char(2),char(7),char(0),char(82), -char(0),char(90),char(2),char(8),char(255),char(174),char(0),char(90),char(2),char(11), -char(0),char(82),char(0),char(90),char(2),char(12),char(255),char(174),char(0),char(91), -char(0),char(70),char(255),char(215),char(0),char(91),char(0),char(71),char(255),char(215), -char(0),char(91),char(0),char(72),char(255),char(215),char(0),char(91),char(0),char(82), -char(255),char(215),char(0),char(91),char(0),char(84),char(255),char(215),char(0),char(91), -char(0),char(162),char(255),char(215),char(0),char(91),char(0),char(169),char(255),char(215), -char(0),char(91),char(0),char(170),char(255),char(215),char(0),char(91),char(0),char(171), -char(255),char(215),char(0),char(91),char(0),char(172),char(255),char(215),char(0),char(91), -char(0),char(173),char(255),char(215),char(0),char(91),char(0),char(180),char(255),char(215), -char(0),char(91),char(0),char(181),char(255),char(215),char(0),char(91),char(0),char(182), -char(255),char(215),char(0),char(91),char(0),char(183),char(255),char(215),char(0),char(91), -char(0),char(184),char(255),char(215),char(0),char(91),char(0),char(186),char(255),char(215), -char(0),char(91),char(0),char(201),char(255),char(215),char(0),char(91),char(0),char(203), -char(255),char(215),char(0),char(91),char(0),char(205),char(255),char(215),char(0),char(91), -char(0),char(207),char(255),char(215),char(0),char(91),char(0),char(209),char(255),char(215), -char(0),char(91),char(0),char(211),char(255),char(215),char(0),char(91),char(0),char(213), -char(255),char(215),char(0),char(91),char(0),char(215),char(255),char(215),char(0),char(91), -char(0),char(217),char(255),char(215),char(0),char(91),char(0),char(219),char(255),char(215), -char(0),char(91),char(0),char(221),char(255),char(215),char(0),char(91),char(1),char(15), -char(255),char(215),char(0),char(91),char(1),char(17),char(255),char(215),char(0),char(91), -char(1),char(19),char(255),char(215),char(0),char(91),char(1),char(21),char(255),char(215), -char(0),char(91),char(1),char(72),char(255),char(215),char(0),char(91),char(2),char(96), -char(255),char(215),char(0),char(91),char(3),char(54),char(255),char(215),char(0),char(91), -char(3),char(56),char(255),char(215),char(0),char(91),char(3),char(58),char(255),char(215), -char(0),char(91),char(3),char(60),char(255),char(215),char(0),char(91),char(3),char(64), -char(255),char(215),char(0),char(91),char(3),char(66),char(255),char(215),char(0),char(91), -char(3),char(68),char(255),char(215),char(0),char(91),char(3),char(74),char(255),char(215), -char(0),char(91),char(3),char(76),char(255),char(215),char(0),char(91),char(3),char(78), -char(255),char(215),char(0),char(91),char(3),char(82),char(255),char(215),char(0),char(91), -char(3),char(84),char(255),char(215),char(0),char(91),char(3),char(86),char(255),char(215), -char(0),char(91),char(3),char(88),char(255),char(215),char(0),char(91),char(3),char(90), -char(255),char(215),char(0),char(91),char(3),char(92),char(255),char(215),char(0),char(91), -char(3),char(94),char(255),char(215),char(0),char(91),char(3),char(96),char(255),char(215), -char(0),char(92),char(0),char(5),char(0),char(82),char(0),char(92),char(0),char(10), -char(0),char(82),char(0),char(92),char(0),char(15),char(255),char(174),char(0),char(92), -char(0),char(17),char(255),char(174),char(0),char(92),char(0),char(34),char(0),char(41), -char(0),char(92),char(2),char(7),char(0),char(82),char(0),char(92),char(2),char(8), -char(255),char(174),char(0),char(92),char(2),char(11),char(0),char(82),char(0),char(92), -char(2),char(12),char(255),char(174),char(0),char(94),char(0),char(45),char(0),char(184), -char(0),char(130),char(0),char(5),char(255),char(113),char(0),char(130),char(0),char(10), -char(255),char(113),char(0),char(130),char(0),char(38),char(255),char(215),char(0),char(130), -char(0),char(42),char(255),char(215),char(0),char(130),char(0),char(45),char(1),char(10), -char(0),char(130),char(0),char(50),char(255),char(215),char(0),char(130),char(0),char(52), -char(255),char(215),char(0),char(130),char(0),char(55),char(255),char(113),char(0),char(130), -char(0),char(57),char(255),char(174),char(0),char(130),char(0),char(58),char(255),char(174), -char(0),char(130),char(0),char(60),char(255),char(133),char(0),char(130),char(0),char(137), -char(255),char(215),char(0),char(130),char(0),char(148),char(255),char(215),char(0),char(130), -char(0),char(149),char(255),char(215),char(0),char(130),char(0),char(150),char(255),char(215), -char(0),char(130),char(0),char(151),char(255),char(215),char(0),char(130),char(0),char(152), -char(255),char(215),char(0),char(130),char(0),char(154),char(255),char(215),char(0),char(130), -char(0),char(159),char(255),char(133),char(0),char(130),char(0),char(200),char(255),char(215), -char(0),char(130),char(0),char(202),char(255),char(215),char(0),char(130),char(0),char(204), -char(255),char(215),char(0),char(130),char(0),char(206),char(255),char(215),char(0),char(130), -char(0),char(222),char(255),char(215),char(0),char(130),char(0),char(224),char(255),char(215), -char(0),char(130),char(0),char(226),char(255),char(215),char(0),char(130),char(0),char(228), -char(255),char(215),char(0),char(130),char(1),char(14),char(255),char(215),char(0),char(130), -char(1),char(16),char(255),char(215),char(0),char(130),char(1),char(18),char(255),char(215), -char(0),char(130),char(1),char(20),char(255),char(215),char(0),char(130),char(1),char(36), -char(255),char(113),char(0),char(130),char(1),char(38),char(255),char(113),char(0),char(130), -char(1),char(54),char(255),char(174),char(0),char(130),char(1),char(56),char(255),char(133), -char(0),char(130),char(1),char(58),char(255),char(133),char(0),char(130),char(1),char(71), -char(255),char(215),char(0),char(130),char(1),char(250),char(255),char(174),char(0),char(130), -char(1),char(252),char(255),char(174),char(0),char(130),char(1),char(254),char(255),char(174), -char(0),char(130),char(2),char(0),char(255),char(133),char(0),char(130),char(2),char(7), -char(255),char(113),char(0),char(130),char(2),char(11),char(255),char(113),char(0),char(130), -char(2),char(95),char(255),char(215),char(0),char(130),char(3),char(73),char(255),char(215), -char(0),char(130),char(3),char(75),char(255),char(215),char(0),char(130),char(3),char(77), -char(255),char(215),char(0),char(130),char(3),char(79),char(255),char(215),char(0),char(130), -char(3),char(81),char(255),char(215),char(0),char(130),char(3),char(83),char(255),char(215), -char(0),char(130),char(3),char(85),char(255),char(215),char(0),char(130),char(3),char(87), -char(255),char(215),char(0),char(130),char(3),char(89),char(255),char(215),char(0),char(130), -char(3),char(91),char(255),char(215),char(0),char(130),char(3),char(93),char(255),char(215), -char(0),char(130),char(3),char(95),char(255),char(215),char(0),char(130),char(3),char(111), -char(255),char(133),char(0),char(130),char(3),char(113),char(255),char(133),char(0),char(130), -char(3),char(115),char(255),char(133),char(0),char(130),char(3),char(143),char(255),char(113), -char(0),char(131),char(0),char(5),char(255),char(113),char(0),char(131),char(0),char(10), -char(255),char(113),char(0),char(131),char(0),char(38),char(255),char(215),char(0),char(131), -char(0),char(42),char(255),char(215),char(0),char(131),char(0),char(45),char(1),char(10), -char(0),char(131),char(0),char(50),char(255),char(215),char(0),char(131),char(0),char(52), -char(255),char(215),char(0),char(131),char(0),char(55),char(255),char(113),char(0),char(131), -char(0),char(57),char(255),char(174),char(0),char(131),char(0),char(58),char(255),char(174), -char(0),char(131),char(0),char(60),char(255),char(133),char(0),char(131),char(0),char(137), -char(255),char(215),char(0),char(131),char(0),char(148),char(255),char(215),char(0),char(131), -char(0),char(149),char(255),char(215),char(0),char(131),char(0),char(150),char(255),char(215), -char(0),char(131),char(0),char(151),char(255),char(215),char(0),char(131),char(0),char(152), -char(255),char(215),char(0),char(131),char(0),char(154),char(255),char(215),char(0),char(131), -char(0),char(159),char(255),char(133),char(0),char(131),char(0),char(200),char(255),char(215), -char(0),char(131),char(0),char(202),char(255),char(215),char(0),char(131),char(0),char(204), -char(255),char(215),char(0),char(131),char(0),char(206),char(255),char(215),char(0),char(131), -char(0),char(222),char(255),char(215),char(0),char(131),char(0),char(224),char(255),char(215), -char(0),char(131),char(0),char(226),char(255),char(215),char(0),char(131),char(0),char(228), -char(255),char(215),char(0),char(131),char(1),char(14),char(255),char(215),char(0),char(131), -char(1),char(16),char(255),char(215),char(0),char(131),char(1),char(18),char(255),char(215), -char(0),char(131),char(1),char(20),char(255),char(215),char(0),char(131),char(1),char(36), -char(255),char(113),char(0),char(131),char(1),char(38),char(255),char(113),char(0),char(131), -char(1),char(54),char(255),char(174),char(0),char(131),char(1),char(56),char(255),char(133), -char(0),char(131),char(1),char(58),char(255),char(133),char(0),char(131),char(1),char(71), -char(255),char(215),char(0),char(131),char(1),char(250),char(255),char(174),char(0),char(131), -char(1),char(252),char(255),char(174),char(0),char(131),char(1),char(254),char(255),char(174), -char(0),char(131),char(2),char(0),char(255),char(133),char(0),char(131),char(2),char(7), -char(255),char(113),char(0),char(131),char(2),char(11),char(255),char(113),char(0),char(131), -char(2),char(95),char(255),char(215),char(0),char(131),char(3),char(73),char(255),char(215), -char(0),char(131),char(3),char(75),char(255),char(215),char(0),char(131),char(3),char(77), -char(255),char(215),char(0),char(131),char(3),char(79),char(255),char(215),char(0),char(131), -char(3),char(81),char(255),char(215),char(0),char(131),char(3),char(83),char(255),char(215), -char(0),char(131),char(3),char(85),char(255),char(215),char(0),char(131),char(3),char(87), -char(255),char(215),char(0),char(131),char(3),char(89),char(255),char(215),char(0),char(131), -char(3),char(91),char(255),char(215),char(0),char(131),char(3),char(93),char(255),char(215), -char(0),char(131),char(3),char(95),char(255),char(215),char(0),char(131),char(3),char(111), -char(255),char(133),char(0),char(131),char(3),char(113),char(255),char(133),char(0),char(131), -char(3),char(115),char(255),char(133),char(0),char(131),char(3),char(143),char(255),char(113), -char(0),char(132),char(0),char(5),char(255),char(113),char(0),char(132),char(0),char(10), -char(255),char(113),char(0),char(132),char(0),char(38),char(255),char(215),char(0),char(132), -char(0),char(42),char(255),char(215),char(0),char(132),char(0),char(45),char(1),char(10), -char(0),char(132),char(0),char(50),char(255),char(215),char(0),char(132),char(0),char(52), -char(255),char(215),char(0),char(132),char(0),char(55),char(255),char(113),char(0),char(132), -char(0),char(57),char(255),char(174),char(0),char(132),char(0),char(58),char(255),char(174), -char(0),char(132),char(0),char(60),char(255),char(133),char(0),char(132),char(0),char(137), -char(255),char(215),char(0),char(132),char(0),char(148),char(255),char(215),char(0),char(132), -char(0),char(149),char(255),char(215),char(0),char(132),char(0),char(150),char(255),char(215), -char(0),char(132),char(0),char(151),char(255),char(215),char(0),char(132),char(0),char(152), -char(255),char(215),char(0),char(132),char(0),char(154),char(255),char(215),char(0),char(132), -char(0),char(159),char(255),char(133),char(0),char(132),char(0),char(200),char(255),char(215), -char(0),char(132),char(0),char(202),char(255),char(215),char(0),char(132),char(0),char(204), -char(255),char(215),char(0),char(132),char(0),char(206),char(255),char(215),char(0),char(132), -char(0),char(222),char(255),char(215),char(0),char(132),char(0),char(224),char(255),char(215), -char(0),char(132),char(0),char(226),char(255),char(215),char(0),char(132),char(0),char(228), -char(255),char(215),char(0),char(132),char(1),char(14),char(255),char(215),char(0),char(132), -char(1),char(16),char(255),char(215),char(0),char(132),char(1),char(18),char(255),char(215), -char(0),char(132),char(1),char(20),char(255),char(215),char(0),char(132),char(1),char(36), -char(255),char(113),char(0),char(132),char(1),char(38),char(255),char(113),char(0),char(132), -char(1),char(54),char(255),char(174),char(0),char(132),char(1),char(56),char(255),char(133), -char(0),char(132),char(1),char(58),char(255),char(133),char(0),char(132),char(1),char(71), -char(255),char(215),char(0),char(132),char(1),char(250),char(255),char(174),char(0),char(132), -char(1),char(252),char(255),char(174),char(0),char(132),char(1),char(254),char(255),char(174), -char(0),char(132),char(2),char(0),char(255),char(133),char(0),char(132),char(2),char(7), -char(255),char(113),char(0),char(132),char(2),char(11),char(255),char(113),char(0),char(132), -char(2),char(95),char(255),char(215),char(0),char(132),char(3),char(73),char(255),char(215), -char(0),char(132),char(3),char(75),char(255),char(215),char(0),char(132),char(3),char(77), -char(255),char(215),char(0),char(132),char(3),char(79),char(255),char(215),char(0),char(132), -char(3),char(81),char(255),char(215),char(0),char(132),char(3),char(83),char(255),char(215), -char(0),char(132),char(3),char(85),char(255),char(215),char(0),char(132),char(3),char(87), -char(255),char(215),char(0),char(132),char(3),char(89),char(255),char(215),char(0),char(132), -char(3),char(91),char(255),char(215),char(0),char(132),char(3),char(93),char(255),char(215), -char(0),char(132),char(3),char(95),char(255),char(215),char(0),char(132),char(3),char(111), -char(255),char(133),char(0),char(132),char(3),char(113),char(255),char(133),char(0),char(132), -char(3),char(115),char(255),char(133),char(0),char(132),char(3),char(143),char(255),char(113), -char(0),char(133),char(0),char(5),char(255),char(113),char(0),char(133),char(0),char(10), -char(255),char(113),char(0),char(133),char(0),char(38),char(255),char(215),char(0),char(133), -char(0),char(42),char(255),char(215),char(0),char(133),char(0),char(45),char(1),char(10), -char(0),char(133),char(0),char(50),char(255),char(215),char(0),char(133),char(0),char(52), -char(255),char(215),char(0),char(133),char(0),char(55),char(255),char(113),char(0),char(133), -char(0),char(57),char(255),char(174),char(0),char(133),char(0),char(58),char(255),char(174), -char(0),char(133),char(0),char(60),char(255),char(133),char(0),char(133),char(0),char(137), -char(255),char(215),char(0),char(133),char(0),char(148),char(255),char(215),char(0),char(133), -char(0),char(149),char(255),char(215),char(0),char(133),char(0),char(150),char(255),char(215), -char(0),char(133),char(0),char(151),char(255),char(215),char(0),char(133),char(0),char(152), -char(255),char(215),char(0),char(133),char(0),char(154),char(255),char(215),char(0),char(133), -char(0),char(159),char(255),char(133),char(0),char(133),char(0),char(200),char(255),char(215), -char(0),char(133),char(0),char(202),char(255),char(215),char(0),char(133),char(0),char(204), -char(255),char(215),char(0),char(133),char(0),char(206),char(255),char(215),char(0),char(133), -char(0),char(222),char(255),char(215),char(0),char(133),char(0),char(224),char(255),char(215), -char(0),char(133),char(0),char(226),char(255),char(215),char(0),char(133),char(0),char(228), -char(255),char(215),char(0),char(133),char(1),char(14),char(255),char(215),char(0),char(133), -char(1),char(16),char(255),char(215),char(0),char(133),char(1),char(18),char(255),char(215), -char(0),char(133),char(1),char(20),char(255),char(215),char(0),char(133),char(1),char(36), -char(255),char(113),char(0),char(133),char(1),char(38),char(255),char(113),char(0),char(133), -char(1),char(54),char(255),char(174),char(0),char(133),char(1),char(56),char(255),char(133), -char(0),char(133),char(1),char(58),char(255),char(133),char(0),char(133),char(1),char(71), -char(255),char(215),char(0),char(133),char(1),char(250),char(255),char(174),char(0),char(133), -char(1),char(252),char(255),char(174),char(0),char(133),char(1),char(254),char(255),char(174), -char(0),char(133),char(2),char(0),char(255),char(133),char(0),char(133),char(2),char(7), -char(255),char(113),char(0),char(133),char(2),char(11),char(255),char(113),char(0),char(133), -char(2),char(95),char(255),char(215),char(0),char(133),char(3),char(73),char(255),char(215), -char(0),char(133),char(3),char(75),char(255),char(215),char(0),char(133),char(3),char(77), -char(255),char(215),char(0),char(133),char(3),char(79),char(255),char(215),char(0),char(133), -char(3),char(81),char(255),char(215),char(0),char(133),char(3),char(83),char(255),char(215), -char(0),char(133),char(3),char(85),char(255),char(215),char(0),char(133),char(3),char(87), -char(255),char(215),char(0),char(133),char(3),char(89),char(255),char(215),char(0),char(133), -char(3),char(91),char(255),char(215),char(0),char(133),char(3),char(93),char(255),char(215), -char(0),char(133),char(3),char(95),char(255),char(215),char(0),char(133),char(3),char(111), -char(255),char(133),char(0),char(133),char(3),char(113),char(255),char(133),char(0),char(133), -char(3),char(115),char(255),char(133),char(0),char(133),char(3),char(143),char(255),char(113), -char(0),char(134),char(0),char(5),char(255),char(113),char(0),char(134),char(0),char(10), -char(255),char(113),char(0),char(134),char(0),char(38),char(255),char(215),char(0),char(134), -char(0),char(42),char(255),char(215),char(0),char(134),char(0),char(45),char(1),char(10), -char(0),char(134),char(0),char(50),char(255),char(215),char(0),char(134),char(0),char(52), -char(255),char(215),char(0),char(134),char(0),char(55),char(255),char(113),char(0),char(134), -char(0),char(57),char(255),char(174),char(0),char(134),char(0),char(58),char(255),char(174), -char(0),char(134),char(0),char(60),char(255),char(133),char(0),char(134),char(0),char(137), -char(255),char(215),char(0),char(134),char(0),char(148),char(255),char(215),char(0),char(134), -char(0),char(149),char(255),char(215),char(0),char(134),char(0),char(150),char(255),char(215), -char(0),char(134),char(0),char(151),char(255),char(215),char(0),char(134),char(0),char(152), -char(255),char(215),char(0),char(134),char(0),char(154),char(255),char(215),char(0),char(134), -char(0),char(159),char(255),char(133),char(0),char(134),char(0),char(200),char(255),char(215), -char(0),char(134),char(0),char(202),char(255),char(215),char(0),char(134),char(0),char(204), -char(255),char(215),char(0),char(134),char(0),char(206),char(255),char(215),char(0),char(134), -char(0),char(222),char(255),char(215),char(0),char(134),char(0),char(224),char(255),char(215), -char(0),char(134),char(0),char(226),char(255),char(215),char(0),char(134),char(0),char(228), -char(255),char(215),char(0),char(134),char(1),char(14),char(255),char(215),char(0),char(134), -char(1),char(16),char(255),char(215),char(0),char(134),char(1),char(18),char(255),char(215), -char(0),char(134),char(1),char(20),char(255),char(215),char(0),char(134),char(1),char(36), -char(255),char(113),char(0),char(134),char(1),char(38),char(255),char(113),char(0),char(134), -char(1),char(54),char(255),char(174),char(0),char(134),char(1),char(56),char(255),char(133), -char(0),char(134),char(1),char(58),char(255),char(133),char(0),char(134),char(1),char(71), -char(255),char(215),char(0),char(134),char(1),char(250),char(255),char(174),char(0),char(134), -char(1),char(252),char(255),char(174),char(0),char(134),char(1),char(254),char(255),char(174), -char(0),char(134),char(2),char(0),char(255),char(133),char(0),char(134),char(2),char(7), -char(255),char(113),char(0),char(134),char(2),char(11),char(255),char(113),char(0),char(134), -char(2),char(95),char(255),char(215),char(0),char(134),char(3),char(73),char(255),char(215), -char(0),char(134),char(3),char(75),char(255),char(215),char(0),char(134),char(3),char(77), -char(255),char(215),char(0),char(134),char(3),char(79),char(255),char(215),char(0),char(134), -char(3),char(81),char(255),char(215),char(0),char(134),char(3),char(83),char(255),char(215), -char(0),char(134),char(3),char(85),char(255),char(215),char(0),char(134),char(3),char(87), -char(255),char(215),char(0),char(134),char(3),char(89),char(255),char(215),char(0),char(134), -char(3),char(91),char(255),char(215),char(0),char(134),char(3),char(93),char(255),char(215), -char(0),char(134),char(3),char(95),char(255),char(215),char(0),char(134),char(3),char(111), -char(255),char(133),char(0),char(134),char(3),char(113),char(255),char(133),char(0),char(134), -char(3),char(115),char(255),char(133),char(0),char(134),char(3),char(143),char(255),char(113), -char(0),char(135),char(0),char(5),char(255),char(113),char(0),char(135),char(0),char(10), -char(255),char(113),char(0),char(135),char(0),char(38),char(255),char(215),char(0),char(135), -char(0),char(42),char(255),char(215),char(0),char(135),char(0),char(45),char(1),char(10), -char(0),char(135),char(0),char(50),char(255),char(215),char(0),char(135),char(0),char(52), -char(255),char(215),char(0),char(135),char(0),char(55),char(255),char(113),char(0),char(135), -char(0),char(57),char(255),char(174),char(0),char(135),char(0),char(58),char(255),char(174), -char(0),char(135),char(0),char(60),char(255),char(133),char(0),char(135),char(0),char(137), -char(255),char(215),char(0),char(135),char(0),char(148),char(255),char(215),char(0),char(135), -char(0),char(149),char(255),char(215),char(0),char(135),char(0),char(150),char(255),char(215), -char(0),char(135),char(0),char(151),char(255),char(215),char(0),char(135),char(0),char(152), -char(255),char(215),char(0),char(135),char(0),char(154),char(255),char(215),char(0),char(135), -char(0),char(159),char(255),char(133),char(0),char(135),char(0),char(200),char(255),char(215), -char(0),char(135),char(0),char(202),char(255),char(215),char(0),char(135),char(0),char(204), -char(255),char(215),char(0),char(135),char(0),char(206),char(255),char(215),char(0),char(135), -char(0),char(222),char(255),char(215),char(0),char(135),char(0),char(224),char(255),char(215), -char(0),char(135),char(0),char(226),char(255),char(215),char(0),char(135),char(0),char(228), -char(255),char(215),char(0),char(135),char(1),char(14),char(255),char(215),char(0),char(135), -char(1),char(16),char(255),char(215),char(0),char(135),char(1),char(18),char(255),char(215), -char(0),char(135),char(1),char(20),char(255),char(215),char(0),char(135),char(1),char(36), -char(255),char(113),char(0),char(135),char(1),char(38),char(255),char(113),char(0),char(135), -char(1),char(54),char(255),char(174),char(0),char(135),char(1),char(56),char(255),char(133), -char(0),char(135),char(1),char(58),char(255),char(133),char(0),char(135),char(1),char(71), -char(255),char(215),char(0),char(135),char(1),char(250),char(255),char(174),char(0),char(135), -char(1),char(252),char(255),char(174),char(0),char(135),char(1),char(254),char(255),char(174), -char(0),char(135),char(2),char(0),char(255),char(133),char(0),char(135),char(2),char(7), -char(255),char(113),char(0),char(135),char(2),char(11),char(255),char(113),char(0),char(135), -char(2),char(95),char(255),char(215),char(0),char(135),char(3),char(73),char(255),char(215), -char(0),char(135),char(3),char(75),char(255),char(215),char(0),char(135),char(3),char(77), -char(255),char(215),char(0),char(135),char(3),char(79),char(255),char(215),char(0),char(135), -char(3),char(81),char(255),char(215),char(0),char(135),char(3),char(83),char(255),char(215), -char(0),char(135),char(3),char(85),char(255),char(215),char(0),char(135),char(3),char(87), -char(255),char(215),char(0),char(135),char(3),char(89),char(255),char(215),char(0),char(135), -char(3),char(91),char(255),char(215),char(0),char(135),char(3),char(93),char(255),char(215), -char(0),char(135),char(3),char(95),char(255),char(215),char(0),char(135),char(3),char(111), -char(255),char(133),char(0),char(135),char(3),char(113),char(255),char(133),char(0),char(135), -char(3),char(115),char(255),char(133),char(0),char(135),char(3),char(143),char(255),char(113), -char(0),char(136),char(0),char(45),char(0),char(123),char(0),char(137),char(0),char(38), -char(255),char(215),char(0),char(137),char(0),char(42),char(255),char(215),char(0),char(137), -char(0),char(50),char(255),char(215),char(0),char(137),char(0),char(52),char(255),char(215), -char(0),char(137),char(0),char(137),char(255),char(215),char(0),char(137),char(0),char(148), -char(255),char(215),char(0),char(137),char(0),char(149),char(255),char(215),char(0),char(137), -char(0),char(150),char(255),char(215),char(0),char(137),char(0),char(151),char(255),char(215), -char(0),char(137),char(0),char(152),char(255),char(215),char(0),char(137),char(0),char(154), -char(255),char(215),char(0),char(137),char(0),char(200),char(255),char(215),char(0),char(137), -char(0),char(202),char(255),char(215),char(0),char(137),char(0),char(204),char(255),char(215), -char(0),char(137),char(0),char(206),char(255),char(215),char(0),char(137),char(0),char(222), -char(255),char(215),char(0),char(137),char(0),char(224),char(255),char(215),char(0),char(137), -char(0),char(226),char(255),char(215),char(0),char(137),char(0),char(228),char(255),char(215), -char(0),char(137),char(1),char(14),char(255),char(215),char(0),char(137),char(1),char(16), -char(255),char(215),char(0),char(137),char(1),char(18),char(255),char(215),char(0),char(137), -char(1),char(20),char(255),char(215),char(0),char(137),char(1),char(71),char(255),char(215), -char(0),char(137),char(2),char(95),char(255),char(215),char(0),char(137),char(3),char(73), -char(255),char(215),char(0),char(137),char(3),char(75),char(255),char(215),char(0),char(137), -char(3),char(77),char(255),char(215),char(0),char(137),char(3),char(79),char(255),char(215), -char(0),char(137),char(3),char(81),char(255),char(215),char(0),char(137),char(3),char(83), -char(255),char(215),char(0),char(137),char(3),char(85),char(255),char(215),char(0),char(137), -char(3),char(87),char(255),char(215),char(0),char(137),char(3),char(89),char(255),char(215), -char(0),char(137),char(3),char(91),char(255),char(215),char(0),char(137),char(3),char(93), -char(255),char(215),char(0),char(137),char(3),char(95),char(255),char(215),char(0),char(138), -char(0),char(45),char(0),char(123),char(0),char(139),char(0),char(45),char(0),char(123), -char(0),char(140),char(0),char(45),char(0),char(123),char(0),char(141),char(0),char(45), -char(0),char(123),char(0),char(146),char(0),char(15),char(255),char(174),char(0),char(146), -char(0),char(17),char(255),char(174),char(0),char(146),char(0),char(36),char(255),char(215), -char(0),char(146),char(0),char(55),char(255),char(195),char(0),char(146),char(0),char(57), -char(255),char(236),char(0),char(146),char(0),char(58),char(255),char(236),char(0),char(146), -char(0),char(59),char(255),char(215),char(0),char(146),char(0),char(60),char(255),char(236), -char(0),char(146),char(0),char(61),char(255),char(236),char(0),char(146),char(0),char(130), -char(255),char(215),char(0),char(146),char(0),char(131),char(255),char(215),char(0),char(146), -char(0),char(132),char(255),char(215),char(0),char(146),char(0),char(133),char(255),char(215), -char(0),char(146),char(0),char(134),char(255),char(215),char(0),char(146),char(0),char(135), -char(255),char(215),char(0),char(146),char(0),char(159),char(255),char(236),char(0),char(146), -char(0),char(194),char(255),char(215),char(0),char(146),char(0),char(196),char(255),char(215), -char(0),char(146),char(0),char(198),char(255),char(215),char(0),char(146),char(1),char(36), -char(255),char(195),char(0),char(146),char(1),char(38),char(255),char(195),char(0),char(146), -char(1),char(54),char(255),char(236),char(0),char(146),char(1),char(56),char(255),char(236), -char(0),char(146),char(1),char(58),char(255),char(236),char(0),char(146),char(1),char(59), -char(255),char(236),char(0),char(146),char(1),char(61),char(255),char(236),char(0),char(146), -char(1),char(63),char(255),char(236),char(0),char(146),char(1),char(67),char(255),char(215), -char(0),char(146),char(1),char(160),char(255),char(236),char(0),char(146),char(1),char(250), -char(255),char(236),char(0),char(146),char(1),char(252),char(255),char(236),char(0),char(146), -char(1),char(254),char(255),char(236),char(0),char(146),char(2),char(0),char(255),char(236), -char(0),char(146),char(2),char(8),char(255),char(174),char(0),char(146),char(2),char(12), -char(255),char(174),char(0),char(146),char(2),char(88),char(255),char(215),char(0),char(146), -char(3),char(29),char(255),char(215),char(0),char(146),char(3),char(31),char(255),char(215), -char(0),char(146),char(3),char(33),char(255),char(215),char(0),char(146),char(3),char(35), -char(255),char(215),char(0),char(146),char(3),char(37),char(255),char(215),char(0),char(146), -char(3),char(39),char(255),char(215),char(0),char(146),char(3),char(41),char(255),char(215), -char(0),char(146),char(3),char(43),char(255),char(215),char(0),char(146),char(3),char(45), -char(255),char(215),char(0),char(146),char(3),char(47),char(255),char(215),char(0),char(146), -char(3),char(49),char(255),char(215),char(0),char(146),char(3),char(51),char(255),char(215), -char(0),char(146),char(3),char(111),char(255),char(236),char(0),char(146),char(3),char(113), -char(255),char(236),char(0),char(146),char(3),char(115),char(255),char(236),char(0),char(146), -char(3),char(143),char(255),char(195),char(0),char(148),char(0),char(15),char(255),char(174), -char(0),char(148),char(0),char(17),char(255),char(174),char(0),char(148),char(0),char(36), -char(255),char(215),char(0),char(148),char(0),char(55),char(255),char(195),char(0),char(148), -char(0),char(57),char(255),char(236),char(0),char(148),char(0),char(58),char(255),char(236), -char(0),char(148),char(0),char(59),char(255),char(215),char(0),char(148),char(0),char(60), -char(255),char(236),char(0),char(148),char(0),char(61),char(255),char(236),char(0),char(148), -char(0),char(130),char(255),char(215),char(0),char(148),char(0),char(131),char(255),char(215), -char(0),char(148),char(0),char(132),char(255),char(215),char(0),char(148),char(0),char(133), -char(255),char(215),char(0),char(148),char(0),char(134),char(255),char(215),char(0),char(148), -char(0),char(135),char(255),char(215),char(0),char(148),char(0),char(159),char(255),char(236), -char(0),char(148),char(0),char(194),char(255),char(215),char(0),char(148),char(0),char(196), -char(255),char(215),char(0),char(148),char(0),char(198),char(255),char(215),char(0),char(148), -char(1),char(36),char(255),char(195),char(0),char(148),char(1),char(38),char(255),char(195), -char(0),char(148),char(1),char(54),char(255),char(236),char(0),char(148),char(1),char(56), -char(255),char(236),char(0),char(148),char(1),char(58),char(255),char(236),char(0),char(148), -char(1),char(59),char(255),char(236),char(0),char(148),char(1),char(61),char(255),char(236), -char(0),char(148),char(1),char(63),char(255),char(236),char(0),char(148),char(1),char(67), -char(255),char(215),char(0),char(148),char(1),char(160),char(255),char(236),char(0),char(148), -char(1),char(250),char(255),char(236),char(0),char(148),char(1),char(252),char(255),char(236), -char(0),char(148),char(1),char(254),char(255),char(236),char(0),char(148),char(2),char(0), -char(255),char(236),char(0),char(148),char(2),char(8),char(255),char(174),char(0),char(148), -char(2),char(12),char(255),char(174),char(0),char(148),char(2),char(88),char(255),char(215), -char(0),char(148),char(3),char(29),char(255),char(215),char(0),char(148),char(3),char(31), -char(255),char(215),char(0),char(148),char(3),char(33),char(255),char(215),char(0),char(148), -char(3),char(35),char(255),char(215),char(0),char(148),char(3),char(37),char(255),char(215), -char(0),char(148),char(3),char(39),char(255),char(215),char(0),char(148),char(3),char(41), -char(255),char(215),char(0),char(148),char(3),char(43),char(255),char(215),char(0),char(148), -char(3),char(45),char(255),char(215),char(0),char(148),char(3),char(47),char(255),char(215), -char(0),char(148),char(3),char(49),char(255),char(215),char(0),char(148),char(3),char(51), -char(255),char(215),char(0),char(148),char(3),char(111),char(255),char(236),char(0),char(148), -char(3),char(113),char(255),char(236),char(0),char(148),char(3),char(115),char(255),char(236), -char(0),char(148),char(3),char(143),char(255),char(195),char(0),char(149),char(0),char(15), -char(255),char(174),char(0),char(149),char(0),char(17),char(255),char(174),char(0),char(149), -char(0),char(36),char(255),char(215),char(0),char(149),char(0),char(55),char(255),char(195), -char(0),char(149),char(0),char(57),char(255),char(236),char(0),char(149),char(0),char(58), -char(255),char(236),char(0),char(149),char(0),char(59),char(255),char(215),char(0),char(149), -char(0),char(60),char(255),char(236),char(0),char(149),char(0),char(61),char(255),char(236), -char(0),char(149),char(0),char(130),char(255),char(215),char(0),char(149),char(0),char(131), -char(255),char(215),char(0),char(149),char(0),char(132),char(255),char(215),char(0),char(149), -char(0),char(133),char(255),char(215),char(0),char(149),char(0),char(134),char(255),char(215), -char(0),char(149),char(0),char(135),char(255),char(215),char(0),char(149),char(0),char(159), -char(255),char(236),char(0),char(149),char(0),char(194),char(255),char(215),char(0),char(149), -char(0),char(196),char(255),char(215),char(0),char(149),char(0),char(198),char(255),char(215), -char(0),char(149),char(1),char(36),char(255),char(195),char(0),char(149),char(1),char(38), -char(255),char(195),char(0),char(149),char(1),char(54),char(255),char(236),char(0),char(149), -char(1),char(56),char(255),char(236),char(0),char(149),char(1),char(58),char(255),char(236), -char(0),char(149),char(1),char(59),char(255),char(236),char(0),char(149),char(1),char(61), -char(255),char(236),char(0),char(149),char(1),char(63),char(255),char(236),char(0),char(149), -char(1),char(67),char(255),char(215),char(0),char(149),char(1),char(160),char(255),char(236), -char(0),char(149),char(1),char(250),char(255),char(236),char(0),char(149),char(1),char(252), -char(255),char(236),char(0),char(149),char(1),char(254),char(255),char(236),char(0),char(149), -char(2),char(0),char(255),char(236),char(0),char(149),char(2),char(8),char(255),char(174), -char(0),char(149),char(2),char(12),char(255),char(174),char(0),char(149),char(2),char(88), -char(255),char(215),char(0),char(149),char(3),char(29),char(255),char(215),char(0),char(149), -char(3),char(31),char(255),char(215),char(0),char(149),char(3),char(33),char(255),char(215), -char(0),char(149),char(3),char(35),char(255),char(215),char(0),char(149),char(3),char(37), -char(255),char(215),char(0),char(149),char(3),char(39),char(255),char(215),char(0),char(149), -char(3),char(41),char(255),char(215),char(0),char(149),char(3),char(43),char(255),char(215), -char(0),char(149),char(3),char(45),char(255),char(215),char(0),char(149),char(3),char(47), -char(255),char(215),char(0),char(149),char(3),char(49),char(255),char(215),char(0),char(149), -char(3),char(51),char(255),char(215),char(0),char(149),char(3),char(111),char(255),char(236), -char(0),char(149),char(3),char(113),char(255),char(236),char(0),char(149),char(3),char(115), -char(255),char(236),char(0),char(149),char(3),char(143),char(255),char(195),char(0),char(150), -char(0),char(15),char(255),char(174),char(0),char(150),char(0),char(17),char(255),char(174), -char(0),char(150),char(0),char(36),char(255),char(215),char(0),char(150),char(0),char(55), -char(255),char(195),char(0),char(150),char(0),char(57),char(255),char(236),char(0),char(150), -char(0),char(58),char(255),char(236),char(0),char(150),char(0),char(59),char(255),char(215), -char(0),char(150),char(0),char(60),char(255),char(236),char(0),char(150),char(0),char(61), -char(255),char(236),char(0),char(150),char(0),char(130),char(255),char(215),char(0),char(150), -char(0),char(131),char(255),char(215),char(0),char(150),char(0),char(132),char(255),char(215), -char(0),char(150),char(0),char(133),char(255),char(215),char(0),char(150),char(0),char(134), -char(255),char(215),char(0),char(150),char(0),char(135),char(255),char(215),char(0),char(150), -char(0),char(159),char(255),char(236),char(0),char(150),char(0),char(194),char(255),char(215), -char(0),char(150),char(0),char(196),char(255),char(215),char(0),char(150),char(0),char(198), -char(255),char(215),char(0),char(150),char(1),char(36),char(255),char(195),char(0),char(150), -char(1),char(38),char(255),char(195),char(0),char(150),char(1),char(54),char(255),char(236), -char(0),char(150),char(1),char(56),char(255),char(236),char(0),char(150),char(1),char(58), -char(255),char(236),char(0),char(150),char(1),char(59),char(255),char(236),char(0),char(150), -char(1),char(61),char(255),char(236),char(0),char(150),char(1),char(63),char(255),char(236), -char(0),char(150),char(1),char(67),char(255),char(215),char(0),char(150),char(1),char(160), -char(255),char(236),char(0),char(150),char(1),char(250),char(255),char(236),char(0),char(150), -char(1),char(252),char(255),char(236),char(0),char(150),char(1),char(254),char(255),char(236), -char(0),char(150),char(2),char(0),char(255),char(236),char(0),char(150),char(2),char(8), -char(255),char(174),char(0),char(150),char(2),char(12),char(255),char(174),char(0),char(150), -char(2),char(88),char(255),char(215),char(0),char(150),char(3),char(29),char(255),char(215), -char(0),char(150),char(3),char(31),char(255),char(215),char(0),char(150),char(3),char(33), -char(255),char(215),char(0),char(150),char(3),char(35),char(255),char(215),char(0),char(150), -char(3),char(37),char(255),char(215),char(0),char(150),char(3),char(39),char(255),char(215), -char(0),char(150),char(3),char(41),char(255),char(215),char(0),char(150),char(3),char(43), -char(255),char(215),char(0),char(150),char(3),char(45),char(255),char(215),char(0),char(150), -char(3),char(47),char(255),char(215),char(0),char(150),char(3),char(49),char(255),char(215), -char(0),char(150),char(3),char(51),char(255),char(215),char(0),char(150),char(3),char(111), -char(255),char(236),char(0),char(150),char(3),char(113),char(255),char(236),char(0),char(150), -char(3),char(115),char(255),char(236),char(0),char(150),char(3),char(143),char(255),char(195), -char(0),char(151),char(0),char(15),char(255),char(174),char(0),char(151),char(0),char(17), -char(255),char(174),char(0),char(151),char(0),char(36),char(255),char(215),char(0),char(151), -char(0),char(55),char(255),char(195),char(0),char(151),char(0),char(57),char(255),char(236), -char(0),char(151),char(0),char(58),char(255),char(236),char(0),char(151),char(0),char(59), -char(255),char(215),char(0),char(151),char(0),char(60),char(255),char(236),char(0),char(151), -char(0),char(61),char(255),char(236),char(0),char(151),char(0),char(130),char(255),char(215), -char(0),char(151),char(0),char(131),char(255),char(215),char(0),char(151),char(0),char(132), -char(255),char(215),char(0),char(151),char(0),char(133),char(255),char(215),char(0),char(151), -char(0),char(134),char(255),char(215),char(0),char(151),char(0),char(135),char(255),char(215), -char(0),char(151),char(0),char(159),char(255),char(236),char(0),char(151),char(0),char(194), -char(255),char(215),char(0),char(151),char(0),char(196),char(255),char(215),char(0),char(151), -char(0),char(198),char(255),char(215),char(0),char(151),char(1),char(36),char(255),char(195), -char(0),char(151),char(1),char(38),char(255),char(195),char(0),char(151),char(1),char(54), -char(255),char(236),char(0),char(151),char(1),char(56),char(255),char(236),char(0),char(151), -char(1),char(58),char(255),char(236),char(0),char(151),char(1),char(59),char(255),char(236), -char(0),char(151),char(1),char(61),char(255),char(236),char(0),char(151),char(1),char(63), -char(255),char(236),char(0),char(151),char(1),char(67),char(255),char(215),char(0),char(151), -char(1),char(160),char(255),char(236),char(0),char(151),char(1),char(250),char(255),char(236), -char(0),char(151),char(1),char(252),char(255),char(236),char(0),char(151),char(1),char(254), -char(255),char(236),char(0),char(151),char(2),char(0),char(255),char(236),char(0),char(151), -char(2),char(8),char(255),char(174),char(0),char(151),char(2),char(12),char(255),char(174), -char(0),char(151),char(2),char(88),char(255),char(215),char(0),char(151),char(3),char(29), -char(255),char(215),char(0),char(151),char(3),char(31),char(255),char(215),char(0),char(151), -char(3),char(33),char(255),char(215),char(0),char(151),char(3),char(35),char(255),char(215), -char(0),char(151),char(3),char(37),char(255),char(215),char(0),char(151),char(3),char(39), -char(255),char(215),char(0),char(151),char(3),char(41),char(255),char(215),char(0),char(151), -char(3),char(43),char(255),char(215),char(0),char(151),char(3),char(45),char(255),char(215), -char(0),char(151),char(3),char(47),char(255),char(215),char(0),char(151),char(3),char(49), -char(255),char(215),char(0),char(151),char(3),char(51),char(255),char(215),char(0),char(151), -char(3),char(111),char(255),char(236),char(0),char(151),char(3),char(113),char(255),char(236), -char(0),char(151),char(3),char(115),char(255),char(236),char(0),char(151),char(3),char(143), -char(255),char(195),char(0),char(152),char(0),char(15),char(255),char(174),char(0),char(152), -char(0),char(17),char(255),char(174),char(0),char(152),char(0),char(36),char(255),char(215), -char(0),char(152),char(0),char(55),char(255),char(195),char(0),char(152),char(0),char(57), -char(255),char(236),char(0),char(152),char(0),char(58),char(255),char(236),char(0),char(152), -char(0),char(59),char(255),char(215),char(0),char(152),char(0),char(60),char(255),char(236), -char(0),char(152),char(0),char(61),char(255),char(236),char(0),char(152),char(0),char(130), -char(255),char(215),char(0),char(152),char(0),char(131),char(255),char(215),char(0),char(152), -char(0),char(132),char(255),char(215),char(0),char(152),char(0),char(133),char(255),char(215), -char(0),char(152),char(0),char(134),char(255),char(215),char(0),char(152),char(0),char(135), -char(255),char(215),char(0),char(152),char(0),char(159),char(255),char(236),char(0),char(152), -char(0),char(194),char(255),char(215),char(0),char(152),char(0),char(196),char(255),char(215), -char(0),char(152),char(0),char(198),char(255),char(215),char(0),char(152),char(1),char(36), -char(255),char(195),char(0),char(152),char(1),char(38),char(255),char(195),char(0),char(152), -char(1),char(54),char(255),char(236),char(0),char(152),char(1),char(56),char(255),char(236), -char(0),char(152),char(1),char(58),char(255),char(236),char(0),char(152),char(1),char(59), -char(255),char(236),char(0),char(152),char(1),char(61),char(255),char(236),char(0),char(152), -char(1),char(63),char(255),char(236),char(0),char(152),char(1),char(67),char(255),char(215), -char(0),char(152),char(1),char(160),char(255),char(236),char(0),char(152),char(1),char(250), -char(255),char(236),char(0),char(152),char(1),char(252),char(255),char(236),char(0),char(152), -char(1),char(254),char(255),char(236),char(0),char(152),char(2),char(0),char(255),char(236), -char(0),char(152),char(2),char(8),char(255),char(174),char(0),char(152),char(2),char(12), -char(255),char(174),char(0),char(152),char(2),char(88),char(255),char(215),char(0),char(152), -char(3),char(29),char(255),char(215),char(0),char(152),char(3),char(31),char(255),char(215), -char(0),char(152),char(3),char(33),char(255),char(215),char(0),char(152),char(3),char(35), -char(255),char(215),char(0),char(152),char(3),char(37),char(255),char(215),char(0),char(152), -char(3),char(39),char(255),char(215),char(0),char(152),char(3),char(41),char(255),char(215), -char(0),char(152),char(3),char(43),char(255),char(215),char(0),char(152),char(3),char(45), -char(255),char(215),char(0),char(152),char(3),char(47),char(255),char(215),char(0),char(152), -char(3),char(49),char(255),char(215),char(0),char(152),char(3),char(51),char(255),char(215), -char(0),char(152),char(3),char(111),char(255),char(236),char(0),char(152),char(3),char(113), -char(255),char(236),char(0),char(152),char(3),char(115),char(255),char(236),char(0),char(152), -char(3),char(143),char(255),char(195),char(0),char(154),char(0),char(15),char(255),char(174), -char(0),char(154),char(0),char(17),char(255),char(174),char(0),char(154),char(0),char(36), -char(255),char(215),char(0),char(154),char(0),char(55),char(255),char(195),char(0),char(154), -char(0),char(57),char(255),char(236),char(0),char(154),char(0),char(58),char(255),char(236), -char(0),char(154),char(0),char(59),char(255),char(215),char(0),char(154),char(0),char(60), -char(255),char(236),char(0),char(154),char(0),char(61),char(255),char(236),char(0),char(154), -char(0),char(130),char(255),char(215),char(0),char(154),char(0),char(131),char(255),char(215), -char(0),char(154),char(0),char(132),char(255),char(215),char(0),char(154),char(0),char(133), -char(255),char(215),char(0),char(154),char(0),char(134),char(255),char(215),char(0),char(154), -char(0),char(135),char(255),char(215),char(0),char(154),char(0),char(159),char(255),char(236), -char(0),char(154),char(0),char(194),char(255),char(215),char(0),char(154),char(0),char(196), -char(255),char(215),char(0),char(154),char(0),char(198),char(255),char(215),char(0),char(154), -char(1),char(36),char(255),char(195),char(0),char(154),char(1),char(38),char(255),char(195), -char(0),char(154),char(1),char(54),char(255),char(236),char(0),char(154),char(1),char(56), -char(255),char(236),char(0),char(154),char(1),char(58),char(255),char(236),char(0),char(154), -char(1),char(59),char(255),char(236),char(0),char(154),char(1),char(61),char(255),char(236), -char(0),char(154),char(1),char(63),char(255),char(236),char(0),char(154),char(1),char(67), -char(255),char(215),char(0),char(154),char(1),char(160),char(255),char(236),char(0),char(154), -char(1),char(250),char(255),char(236),char(0),char(154),char(1),char(252),char(255),char(236), -char(0),char(154),char(1),char(254),char(255),char(236),char(0),char(154),char(2),char(0), -char(255),char(236),char(0),char(154),char(2),char(8),char(255),char(174),char(0),char(154), -char(2),char(12),char(255),char(174),char(0),char(154),char(2),char(88),char(255),char(215), -char(0),char(154),char(3),char(29),char(255),char(215),char(0),char(154),char(3),char(31), -char(255),char(215),char(0),char(154),char(3),char(33),char(255),char(215),char(0),char(154), -char(3),char(35),char(255),char(215),char(0),char(154),char(3),char(37),char(255),char(215), -char(0),char(154),char(3),char(39),char(255),char(215),char(0),char(154),char(3),char(41), -char(255),char(215),char(0),char(154),char(3),char(43),char(255),char(215),char(0),char(154), -char(3),char(45),char(255),char(215),char(0),char(154),char(3),char(47),char(255),char(215), -char(0),char(154),char(3),char(49),char(255),char(215),char(0),char(154),char(3),char(51), -char(255),char(215),char(0),char(154),char(3),char(111),char(255),char(236),char(0),char(154), -char(3),char(113),char(255),char(236),char(0),char(154),char(3),char(115),char(255),char(236), -char(0),char(154),char(3),char(143),char(255),char(195),char(0),char(155),char(0),char(15), -char(255),char(215),char(0),char(155),char(0),char(17),char(255),char(215),char(0),char(155), -char(0),char(36),char(255),char(236),char(0),char(155),char(0),char(130),char(255),char(236), -char(0),char(155),char(0),char(131),char(255),char(236),char(0),char(155),char(0),char(132), -char(255),char(236),char(0),char(155),char(0),char(133),char(255),char(236),char(0),char(155), -char(0),char(134),char(255),char(236),char(0),char(155),char(0),char(135),char(255),char(236), -char(0),char(155),char(0),char(194),char(255),char(236),char(0),char(155),char(0),char(196), -char(255),char(236),char(0),char(155),char(0),char(198),char(255),char(236),char(0),char(155), -char(1),char(67),char(255),char(236),char(0),char(155),char(2),char(8),char(255),char(215), -char(0),char(155),char(2),char(12),char(255),char(215),char(0),char(155),char(2),char(88), -char(255),char(236),char(0),char(155),char(3),char(29),char(255),char(236),char(0),char(155), -char(3),char(31),char(255),char(236),char(0),char(155),char(3),char(33),char(255),char(236), -char(0),char(155),char(3),char(35),char(255),char(236),char(0),char(155),char(3),char(37), -char(255),char(236),char(0),char(155),char(3),char(39),char(255),char(236),char(0),char(155), -char(3),char(41),char(255),char(236),char(0),char(155),char(3),char(43),char(255),char(236), -char(0),char(155),char(3),char(45),char(255),char(236),char(0),char(155),char(3),char(47), -char(255),char(236),char(0),char(155),char(3),char(49),char(255),char(236),char(0),char(155), -char(3),char(51),char(255),char(236),char(0),char(156),char(0),char(15),char(255),char(215), -char(0),char(156),char(0),char(17),char(255),char(215),char(0),char(156),char(0),char(36), -char(255),char(236),char(0),char(156),char(0),char(130),char(255),char(236),char(0),char(156), -char(0),char(131),char(255),char(236),char(0),char(156),char(0),char(132),char(255),char(236), -char(0),char(156),char(0),char(133),char(255),char(236),char(0),char(156),char(0),char(134), -char(255),char(236),char(0),char(156),char(0),char(135),char(255),char(236),char(0),char(156), -char(0),char(194),char(255),char(236),char(0),char(156),char(0),char(196),char(255),char(236), -char(0),char(156),char(0),char(198),char(255),char(236),char(0),char(156),char(1),char(67), -char(255),char(236),char(0),char(156),char(2),char(8),char(255),char(215),char(0),char(156), -char(2),char(12),char(255),char(215),char(0),char(156),char(2),char(88),char(255),char(236), -char(0),char(156),char(3),char(29),char(255),char(236),char(0),char(156),char(3),char(31), -char(255),char(236),char(0),char(156),char(3),char(33),char(255),char(236),char(0),char(156), -char(3),char(35),char(255),char(236),char(0),char(156),char(3),char(37),char(255),char(236), -char(0),char(156),char(3),char(39),char(255),char(236),char(0),char(156),char(3),char(41), -char(255),char(236),char(0),char(156),char(3),char(43),char(255),char(236),char(0),char(156), -char(3),char(45),char(255),char(236),char(0),char(156),char(3),char(47),char(255),char(236), -char(0),char(156),char(3),char(49),char(255),char(236),char(0),char(156),char(3),char(51), -char(255),char(236),char(0),char(157),char(0),char(15),char(255),char(215),char(0),char(157), -char(0),char(17),char(255),char(215),char(0),char(157),char(0),char(36),char(255),char(236), -char(0),char(157),char(0),char(130),char(255),char(236),char(0),char(157),char(0),char(131), -char(255),char(236),char(0),char(157),char(0),char(132),char(255),char(236),char(0),char(157), -char(0),char(133),char(255),char(236),char(0),char(157),char(0),char(134),char(255),char(236), -char(0),char(157),char(0),char(135),char(255),char(236),char(0),char(157),char(0),char(194), -char(255),char(236),char(0),char(157),char(0),char(196),char(255),char(236),char(0),char(157), -char(0),char(198),char(255),char(236),char(0),char(157),char(1),char(67),char(255),char(236), -char(0),char(157),char(2),char(8),char(255),char(215),char(0),char(157),char(2),char(12), -char(255),char(215),char(0),char(157),char(2),char(88),char(255),char(236),char(0),char(157), -char(3),char(29),char(255),char(236),char(0),char(157),char(3),char(31),char(255),char(236), -char(0),char(157),char(3),char(33),char(255),char(236),char(0),char(157),char(3),char(35), -char(255),char(236),char(0),char(157),char(3),char(37),char(255),char(236),char(0),char(157), -char(3),char(39),char(255),char(236),char(0),char(157),char(3),char(41),char(255),char(236), -char(0),char(157),char(3),char(43),char(255),char(236),char(0),char(157),char(3),char(45), -char(255),char(236),char(0),char(157),char(3),char(47),char(255),char(236),char(0),char(157), -char(3),char(49),char(255),char(236),char(0),char(157),char(3),char(51),char(255),char(236), -char(0),char(158),char(0),char(15),char(255),char(215),char(0),char(158),char(0),char(17), -char(255),char(215),char(0),char(158),char(0),char(36),char(255),char(236),char(0),char(158), -char(0),char(130),char(255),char(236),char(0),char(158),char(0),char(131),char(255),char(236), -char(0),char(158),char(0),char(132),char(255),char(236),char(0),char(158),char(0),char(133), -char(255),char(236),char(0),char(158),char(0),char(134),char(255),char(236),char(0),char(158), -char(0),char(135),char(255),char(236),char(0),char(158),char(0),char(194),char(255),char(236), -char(0),char(158),char(0),char(196),char(255),char(236),char(0),char(158),char(0),char(198), -char(255),char(236),char(0),char(158),char(1),char(67),char(255),char(236),char(0),char(158), -char(2),char(8),char(255),char(215),char(0),char(158),char(2),char(12),char(255),char(215), -char(0),char(158),char(2),char(88),char(255),char(236),char(0),char(158),char(3),char(29), -char(255),char(236),char(0),char(158),char(3),char(31),char(255),char(236),char(0),char(158), -char(3),char(33),char(255),char(236),char(0),char(158),char(3),char(35),char(255),char(236), -char(0),char(158),char(3),char(37),char(255),char(236),char(0),char(158),char(3),char(39), -char(255),char(236),char(0),char(158),char(3),char(41),char(255),char(236),char(0),char(158), -char(3),char(43),char(255),char(236),char(0),char(158),char(3),char(45),char(255),char(236), -char(0),char(158),char(3),char(47),char(255),char(236),char(0),char(158),char(3),char(49), -char(255),char(236),char(0),char(158),char(3),char(51),char(255),char(236),char(0),char(159), -char(0),char(15),char(255),char(133),char(0),char(159),char(0),char(17),char(255),char(133), -char(0),char(159),char(0),char(34),char(0),char(41),char(0),char(159),char(0),char(36), -char(255),char(133),char(0),char(159),char(0),char(38),char(255),char(215),char(0),char(159), -char(0),char(42),char(255),char(215),char(0),char(159),char(0),char(50),char(255),char(215), -char(0),char(159),char(0),char(52),char(255),char(215),char(0),char(159),char(0),char(68), -char(255),char(154),char(0),char(159),char(0),char(70),char(255),char(154),char(0),char(159), -char(0),char(71),char(255),char(154),char(0),char(159),char(0),char(72),char(255),char(154), -char(0),char(159),char(0),char(74),char(255),char(215),char(0),char(159),char(0),char(80), -char(255),char(195),char(0),char(159),char(0),char(81),char(255),char(195),char(0),char(159), -char(0),char(82),char(255),char(154),char(0),char(159),char(0),char(83),char(255),char(195), -char(0),char(159),char(0),char(84),char(255),char(154),char(0),char(159),char(0),char(85), -char(255),char(195),char(0),char(159),char(0),char(86),char(255),char(174),char(0),char(159), -char(0),char(88),char(255),char(195),char(0),char(159),char(0),char(93),char(255),char(215), -char(0),char(159),char(0),char(130),char(255),char(133),char(0),char(159),char(0),char(131), -char(255),char(133),char(0),char(159),char(0),char(132),char(255),char(133),char(0),char(159), -char(0),char(133),char(255),char(133),char(0),char(159),char(0),char(134),char(255),char(133), -char(0),char(159),char(0),char(135),char(255),char(133),char(0),char(159),char(0),char(137), -char(255),char(215),char(0),char(159),char(0),char(148),char(255),char(215),char(0),char(159), -char(0),char(149),char(255),char(215),char(0),char(159),char(0),char(150),char(255),char(215), -char(0),char(159),char(0),char(151),char(255),char(215),char(0),char(159),char(0),char(152), -char(255),char(215),char(0),char(159),char(0),char(154),char(255),char(215),char(0),char(159), -char(0),char(162),char(255),char(154),char(0),char(159),char(0),char(163),char(255),char(154), -char(0),char(159),char(0),char(164),char(255),char(154),char(0),char(159),char(0),char(165), -char(255),char(154),char(0),char(159),char(0),char(166),char(255),char(154),char(0),char(159), -char(0),char(167),char(255),char(154),char(0),char(159),char(0),char(168),char(255),char(154), -char(0),char(159),char(0),char(169),char(255),char(154),char(0),char(159),char(0),char(170), -char(255),char(154),char(0),char(159),char(0),char(171),char(255),char(154),char(0),char(159), -char(0),char(172),char(255),char(154),char(0),char(159),char(0),char(173),char(255),char(154), -char(0),char(159),char(0),char(180),char(255),char(154),char(0),char(159),char(0),char(181), -char(255),char(154),char(0),char(159),char(0),char(182),char(255),char(154),char(0),char(159), -char(0),char(183),char(255),char(154),char(0),char(159),char(0),char(184),char(255),char(154), -char(0),char(159),char(0),char(186),char(255),char(154),char(0),char(159),char(0),char(187), -char(255),char(195),char(0),char(159),char(0),char(188),char(255),char(195),char(0),char(159), -char(0),char(189),char(255),char(195),char(0),char(159),char(0),char(190),char(255),char(195), -char(0),char(159),char(0),char(194),char(255),char(133),char(0),char(159),char(0),char(195), -char(255),char(154),char(0),char(159),char(0),char(196),char(255),char(133),char(0),char(159), -char(0),char(197),char(255),char(154),char(0),char(159),char(0),char(198),char(255),char(133), -char(0),char(159),char(0),char(199),char(255),char(154),char(0),char(159),char(0),char(200), -char(255),char(215),char(0),char(159),char(0),char(201),char(255),char(154),char(0),char(159), -char(0),char(202),char(255),char(215),char(0),char(159),char(0),char(203),char(255),char(154), -char(0),char(159),char(0),char(204),char(255),char(215),char(0),char(159),char(0),char(205), -char(255),char(154),char(0),char(159),char(0),char(206),char(255),char(215),char(0),char(159), -char(0),char(207),char(255),char(154),char(0),char(159),char(0),char(209),char(255),char(154), -char(0),char(159),char(0),char(211),char(255),char(154),char(0),char(159),char(0),char(213), -char(255),char(154),char(0),char(159),char(0),char(215),char(255),char(154),char(0),char(159), -char(0),char(217),char(255),char(154),char(0),char(159),char(0),char(219),char(255),char(154), -char(0),char(159),char(0),char(221),char(255),char(154),char(0),char(159),char(0),char(222), -char(255),char(215),char(0),char(159),char(0),char(223),char(255),char(215),char(0),char(159), -char(0),char(224),char(255),char(215),char(0),char(159),char(0),char(225),char(255),char(215), -char(0),char(159),char(0),char(226),char(255),char(215),char(0),char(159),char(0),char(227), -char(255),char(215),char(0),char(159),char(0),char(228),char(255),char(215),char(0),char(159), -char(0),char(229),char(255),char(215),char(0),char(159),char(0),char(250),char(255),char(195), -char(0),char(159),char(1),char(6),char(255),char(195),char(0),char(159),char(1),char(8), -char(255),char(195),char(0),char(159),char(1),char(13),char(255),char(195),char(0),char(159), -char(1),char(14),char(255),char(215),char(0),char(159),char(1),char(15),char(255),char(154), -char(0),char(159),char(1),char(16),char(255),char(215),char(0),char(159),char(1),char(17), -char(255),char(154),char(0),char(159),char(1),char(18),char(255),char(215),char(0),char(159), -char(1),char(19),char(255),char(154),char(0),char(159),char(1),char(20),char(255),char(215), -char(0),char(159),char(1),char(21),char(255),char(154),char(0),char(159),char(1),char(23), -char(255),char(195),char(0),char(159),char(1),char(25),char(255),char(195),char(0),char(159), -char(1),char(29),char(255),char(174),char(0),char(159),char(1),char(33),char(255),char(174), -char(0),char(159),char(1),char(43),char(255),char(195),char(0),char(159),char(1),char(45), -char(255),char(195),char(0),char(159),char(1),char(47),char(255),char(195),char(0),char(159), -char(1),char(49),char(255),char(195),char(0),char(159),char(1),char(51),char(255),char(195), -char(0),char(159),char(1),char(53),char(255),char(195),char(0),char(159),char(1),char(60), -char(255),char(215),char(0),char(159),char(1),char(62),char(255),char(215),char(0),char(159), -char(1),char(64),char(255),char(215),char(0),char(159),char(1),char(67),char(255),char(133), -char(0),char(159),char(1),char(68),char(255),char(154),char(0),char(159),char(1),char(70), -char(255),char(154),char(0),char(159),char(1),char(71),char(255),char(215),char(0),char(159), -char(1),char(72),char(255),char(154),char(0),char(159),char(1),char(74),char(255),char(174), -char(0),char(159),char(2),char(8),char(255),char(133),char(0),char(159),char(2),char(12), -char(255),char(133),char(0),char(159),char(2),char(87),char(255),char(195),char(0),char(159), -char(2),char(88),char(255),char(133),char(0),char(159),char(2),char(89),char(255),char(154), -char(0),char(159),char(2),char(95),char(255),char(215),char(0),char(159),char(2),char(96), -char(255),char(154),char(0),char(159),char(2),char(98),char(255),char(195),char(0),char(159), -char(3),char(29),char(255),char(133),char(0),char(159),char(3),char(30),char(255),char(154), -char(0),char(159),char(3),char(31),char(255),char(133),char(0),char(159),char(3),char(32), -char(255),char(154),char(0),char(159),char(3),char(33),char(255),char(133),char(0),char(159), -char(3),char(34),char(255),char(154),char(0),char(159),char(3),char(35),char(255),char(133), -char(0),char(159),char(3),char(37),char(255),char(133),char(0),char(159),char(3),char(38), -char(255),char(154),char(0),char(159),char(3),char(39),char(255),char(133),char(0),char(159), -char(3),char(40),char(255),char(154),char(0),char(159),char(3),char(41),char(255),char(133), -char(0),char(159),char(3),char(42),char(255),char(154),char(0),char(159),char(3),char(43), -char(255),char(133),char(0),char(159),char(3),char(44),char(255),char(154),char(0),char(159), -char(3),char(45),char(255),char(133),char(0),char(159),char(3),char(46),char(255),char(154), -char(0),char(159),char(3),char(47),char(255),char(133),char(0),char(159),char(3),char(48), -char(255),char(154),char(0),char(159),char(3),char(49),char(255),char(133),char(0),char(159), -char(3),char(50),char(255),char(154),char(0),char(159),char(3),char(51),char(255),char(133), -char(0),char(159),char(3),char(52),char(255),char(154),char(0),char(159),char(3),char(54), -char(255),char(154),char(0),char(159),char(3),char(56),char(255),char(154),char(0),char(159), -char(3),char(58),char(255),char(154),char(0),char(159),char(3),char(60),char(255),char(154), -char(0),char(159),char(3),char(64),char(255),char(154),char(0),char(159),char(3),char(66), -char(255),char(154),char(0),char(159),char(3),char(68),char(255),char(154),char(0),char(159), -char(3),char(73),char(255),char(215),char(0),char(159),char(3),char(74),char(255),char(154), -char(0),char(159),char(3),char(75),char(255),char(215),char(0),char(159),char(3),char(76), -char(255),char(154),char(0),char(159),char(3),char(77),char(255),char(215),char(0),char(159), -char(3),char(78),char(255),char(154),char(0),char(159),char(3),char(79),char(255),char(215), -char(0),char(159),char(3),char(81),char(255),char(215),char(0),char(159),char(3),char(82), -char(255),char(154),char(0),char(159),char(3),char(83),char(255),char(215),char(0),char(159), -char(3),char(84),char(255),char(154),char(0),char(159),char(3),char(85),char(255),char(215), -char(0),char(159),char(3),char(86),char(255),char(154),char(0),char(159),char(3),char(87), -char(255),char(215),char(0),char(159),char(3),char(88),char(255),char(154),char(0),char(159), -char(3),char(89),char(255),char(215),char(0),char(159),char(3),char(90),char(255),char(154), -char(0),char(159),char(3),char(91),char(255),char(215),char(0),char(159),char(3),char(92), -char(255),char(154),char(0),char(159),char(3),char(93),char(255),char(215),char(0),char(159), -char(3),char(94),char(255),char(154),char(0),char(159),char(3),char(95),char(255),char(215), -char(0),char(159),char(3),char(96),char(255),char(154),char(0),char(159),char(3),char(98), -char(255),char(195),char(0),char(159),char(3),char(100),char(255),char(195),char(0),char(159), -char(3),char(102),char(255),char(195),char(0),char(159),char(3),char(104),char(255),char(195), -char(0),char(159),char(3),char(106),char(255),char(195),char(0),char(159),char(3),char(108), -char(255),char(195),char(0),char(159),char(3),char(110),char(255),char(195),char(0),char(160), -char(0),char(15),char(254),char(246),char(0),char(160),char(0),char(17),char(254),char(246), -char(0),char(160),char(0),char(36),char(255),char(154),char(0),char(160),char(0),char(59), -char(255),char(215),char(0),char(160),char(0),char(61),char(255),char(236),char(0),char(160), -char(0),char(130),char(255),char(154),char(0),char(160),char(0),char(131),char(255),char(154), -char(0),char(160),char(0),char(132),char(255),char(154),char(0),char(160),char(0),char(133), -char(255),char(154),char(0),char(160),char(0),char(134),char(255),char(154),char(0),char(160), -char(0),char(135),char(255),char(154),char(0),char(160),char(0),char(194),char(255),char(154), -char(0),char(160),char(0),char(196),char(255),char(154),char(0),char(160),char(0),char(198), -char(255),char(154),char(0),char(160),char(1),char(59),char(255),char(236),char(0),char(160), -char(1),char(61),char(255),char(236),char(0),char(160),char(1),char(63),char(255),char(236), -char(0),char(160),char(1),char(67),char(255),char(154),char(0),char(160),char(2),char(8), -char(254),char(246),char(0),char(160),char(2),char(12),char(254),char(246),char(0),char(160), -char(2),char(88),char(255),char(154),char(0),char(160),char(3),char(29),char(255),char(154), -char(0),char(160),char(3),char(31),char(255),char(154),char(0),char(160),char(3),char(33), -char(255),char(154),char(0),char(160),char(3),char(35),char(255),char(154),char(0),char(160), -char(3),char(37),char(255),char(154),char(0),char(160),char(3),char(39),char(255),char(154), -char(0),char(160),char(3),char(41),char(255),char(154),char(0),char(160),char(3),char(43), -char(255),char(154),char(0),char(160),char(3),char(45),char(255),char(154),char(0),char(160), -char(3),char(47),char(255),char(154),char(0),char(160),char(3),char(49),char(255),char(154), -char(0),char(160),char(3),char(51),char(255),char(154),char(0),char(162),char(0),char(5), -char(255),char(236),char(0),char(162),char(0),char(10),char(255),char(236),char(0),char(162), -char(2),char(7),char(255),char(236),char(0),char(162),char(2),char(11),char(255),char(236), -char(0),char(163),char(0),char(5),char(255),char(236),char(0),char(163),char(0),char(10), -char(255),char(236),char(0),char(163),char(2),char(7),char(255),char(236),char(0),char(163), -char(2),char(11),char(255),char(236),char(0),char(164),char(0),char(5),char(255),char(236), -char(0),char(164),char(0),char(10),char(255),char(236),char(0),char(164),char(2),char(7), -char(255),char(236),char(0),char(164),char(2),char(11),char(255),char(236),char(0),char(165), -char(0),char(5),char(255),char(236),char(0),char(165),char(0),char(10),char(255),char(236), -char(0),char(165),char(2),char(7),char(255),char(236),char(0),char(165),char(2),char(11), -char(255),char(236),char(0),char(166),char(0),char(5),char(255),char(236),char(0),char(166), -char(0),char(10),char(255),char(236),char(0),char(166),char(2),char(7),char(255),char(236), -char(0),char(166),char(2),char(11),char(255),char(236),char(0),char(167),char(0),char(5), -char(255),char(236),char(0),char(167),char(0),char(10),char(255),char(236),char(0),char(167), -char(2),char(7),char(255),char(236),char(0),char(167),char(2),char(11),char(255),char(236), -char(0),char(170),char(0),char(5),char(255),char(236),char(0),char(170),char(0),char(10), -char(255),char(236),char(0),char(170),char(0),char(89),char(255),char(215),char(0),char(170), -char(0),char(90),char(255),char(215),char(0),char(170),char(0),char(91),char(255),char(215), -char(0),char(170),char(0),char(92),char(255),char(215),char(0),char(170),char(0),char(93), -char(255),char(236),char(0),char(170),char(0),char(191),char(255),char(215),char(0),char(170), -char(1),char(55),char(255),char(215),char(0),char(170),char(1),char(60),char(255),char(236), -char(0),char(170),char(1),char(62),char(255),char(236),char(0),char(170),char(1),char(64), -char(255),char(236),char(0),char(170),char(1),char(251),char(255),char(215),char(0),char(170), -char(1),char(253),char(255),char(215),char(0),char(170),char(2),char(7),char(255),char(236), -char(0),char(170),char(2),char(11),char(255),char(236),char(0),char(170),char(3),char(112), -char(255),char(215),char(0),char(171),char(0),char(5),char(255),char(236),char(0),char(171), -char(0),char(10),char(255),char(236),char(0),char(171),char(0),char(89),char(255),char(215), -char(0),char(171),char(0),char(90),char(255),char(215),char(0),char(171),char(0),char(91), -char(255),char(215),char(0),char(171),char(0),char(92),char(255),char(215),char(0),char(171), -char(0),char(93),char(255),char(236),char(0),char(171),char(0),char(191),char(255),char(215), -char(0),char(171),char(1),char(55),char(255),char(215),char(0),char(171),char(1),char(60), -char(255),char(236),char(0),char(171),char(1),char(62),char(255),char(236),char(0),char(171), -char(1),char(64),char(255),char(236),char(0),char(171),char(1),char(251),char(255),char(215), -char(0),char(171),char(1),char(253),char(255),char(215),char(0),char(171),char(2),char(7), -char(255),char(236),char(0),char(171),char(2),char(11),char(255),char(236),char(0),char(171), -char(3),char(112),char(255),char(215),char(0),char(172),char(0),char(5),char(255),char(236), -char(0),char(172),char(0),char(10),char(255),char(236),char(0),char(172),char(0),char(89), -char(255),char(215),char(0),char(172),char(0),char(90),char(255),char(215),char(0),char(172), -char(0),char(91),char(255),char(215),char(0),char(172),char(0),char(92),char(255),char(215), -char(0),char(172),char(0),char(93),char(255),char(236),char(0),char(172),char(0),char(191), -char(255),char(215),char(0),char(172),char(1),char(55),char(255),char(215),char(0),char(172), -char(1),char(60),char(255),char(236),char(0),char(172),char(1),char(62),char(255),char(236), -char(0),char(172),char(1),char(64),char(255),char(236),char(0),char(172),char(1),char(251), -char(255),char(215),char(0),char(172),char(1),char(253),char(255),char(215),char(0),char(172), -char(2),char(7),char(255),char(236),char(0),char(172),char(2),char(11),char(255),char(236), -char(0),char(172),char(3),char(112),char(255),char(215),char(0),char(173),char(0),char(5), -char(255),char(236),char(0),char(173),char(0),char(10),char(255),char(236),char(0),char(173), -char(0),char(89),char(255),char(215),char(0),char(173),char(0),char(90),char(255),char(215), -char(0),char(173),char(0),char(91),char(255),char(215),char(0),char(173),char(0),char(92), -char(255),char(215),char(0),char(173),char(0),char(93),char(255),char(236),char(0),char(173), -char(0),char(191),char(255),char(215),char(0),char(173),char(1),char(55),char(255),char(215), -char(0),char(173),char(1),char(60),char(255),char(236),char(0),char(173),char(1),char(62), -char(255),char(236),char(0),char(173),char(1),char(64),char(255),char(236),char(0),char(173), -char(1),char(251),char(255),char(215),char(0),char(173),char(1),char(253),char(255),char(215), -char(0),char(173),char(2),char(7),char(255),char(236),char(0),char(173),char(2),char(11), -char(255),char(236),char(0),char(173),char(3),char(112),char(255),char(215),char(0),char(178), -char(0),char(5),char(255),char(236),char(0),char(178),char(0),char(10),char(255),char(236), -char(0),char(178),char(0),char(89),char(255),char(215),char(0),char(178),char(0),char(90), -char(255),char(215),char(0),char(178),char(0),char(91),char(255),char(215),char(0),char(178), -char(0),char(92),char(255),char(215),char(0),char(178),char(0),char(93),char(255),char(236), -char(0),char(178),char(0),char(191),char(255),char(215),char(0),char(178),char(1),char(55), -char(255),char(215),char(0),char(178),char(1),char(60),char(255),char(236),char(0),char(178), -char(1),char(62),char(255),char(236),char(0),char(178),char(1),char(64),char(255),char(236), -char(0),char(178),char(1),char(251),char(255),char(215),char(0),char(178),char(1),char(253), -char(255),char(215),char(0),char(178),char(2),char(7),char(255),char(236),char(0),char(178), -char(2),char(11),char(255),char(236),char(0),char(178),char(3),char(112),char(255),char(215), -char(0),char(180),char(0),char(5),char(255),char(236),char(0),char(180),char(0),char(10), -char(255),char(236),char(0),char(180),char(0),char(89),char(255),char(215),char(0),char(180), -char(0),char(90),char(255),char(215),char(0),char(180),char(0),char(91),char(255),char(215), -char(0),char(180),char(0),char(92),char(255),char(215),char(0),char(180),char(0),char(93), -char(255),char(236),char(0),char(180),char(0),char(191),char(255),char(215),char(0),char(180), -char(1),char(55),char(255),char(215),char(0),char(180),char(1),char(60),char(255),char(236), -char(0),char(180),char(1),char(62),char(255),char(236),char(0),char(180),char(1),char(64), -char(255),char(236),char(0),char(180),char(1),char(251),char(255),char(215),char(0),char(180), -char(1),char(253),char(255),char(215),char(0),char(180),char(2),char(7),char(255),char(236), -char(0),char(180),char(2),char(11),char(255),char(236),char(0),char(180),char(3),char(112), -char(255),char(215),char(0),char(181),char(0),char(5),char(255),char(236),char(0),char(181), -char(0),char(10),char(255),char(236),char(0),char(181),char(0),char(89),char(255),char(215), -char(0),char(181),char(0),char(90),char(255),char(215),char(0),char(181),char(0),char(91), -char(255),char(215),char(0),char(181),char(0),char(92),char(255),char(215),char(0),char(181), -char(0),char(93),char(255),char(236),char(0),char(181),char(0),char(191),char(255),char(215), -char(0),char(181),char(1),char(55),char(255),char(215),char(0),char(181),char(1),char(60), -char(255),char(236),char(0),char(181),char(1),char(62),char(255),char(236),char(0),char(181), -char(1),char(64),char(255),char(236),char(0),char(181),char(1),char(251),char(255),char(215), -char(0),char(181),char(1),char(253),char(255),char(215),char(0),char(181),char(2),char(7), -char(255),char(236),char(0),char(181),char(2),char(11),char(255),char(236),char(0),char(181), -char(3),char(112),char(255),char(215),char(0),char(182),char(0),char(5),char(255),char(236), -char(0),char(182),char(0),char(10),char(255),char(236),char(0),char(182),char(0),char(89), -char(255),char(215),char(0),char(182),char(0),char(90),char(255),char(215),char(0),char(182), -char(0),char(91),char(255),char(215),char(0),char(182),char(0),char(92),char(255),char(215), -char(0),char(182),char(0),char(93),char(255),char(236),char(0),char(182),char(0),char(191), -char(255),char(215),char(0),char(182),char(1),char(55),char(255),char(215),char(0),char(182), -char(1),char(60),char(255),char(236),char(0),char(182),char(1),char(62),char(255),char(236), -char(0),char(182),char(1),char(64),char(255),char(236),char(0),char(182),char(1),char(251), -char(255),char(215),char(0),char(182),char(1),char(253),char(255),char(215),char(0),char(182), -char(2),char(7),char(255),char(236),char(0),char(182),char(2),char(11),char(255),char(236), -char(0),char(182),char(3),char(112),char(255),char(215),char(0),char(184),char(0),char(5), -char(255),char(215),char(0),char(184),char(0),char(10),char(255),char(215),char(0),char(184), -char(2),char(7),char(255),char(215),char(0),char(184),char(2),char(11),char(255),char(215), -char(0),char(186),char(0),char(5),char(255),char(236),char(0),char(186),char(0),char(10), -char(255),char(236),char(0),char(186),char(0),char(89),char(255),char(215),char(0),char(186), -char(0),char(90),char(255),char(215),char(0),char(186),char(0),char(91),char(255),char(215), -char(0),char(186),char(0),char(92),char(255),char(215),char(0),char(186),char(0),char(93), -char(255),char(236),char(0),char(186),char(0),char(191),char(255),char(215),char(0),char(186), -char(1),char(55),char(255),char(215),char(0),char(186),char(1),char(60),char(255),char(236), -char(0),char(186),char(1),char(62),char(255),char(236),char(0),char(186),char(1),char(64), -char(255),char(236),char(0),char(186),char(1),char(251),char(255),char(215),char(0),char(186), -char(1),char(253),char(255),char(215),char(0),char(186),char(2),char(7),char(255),char(236), -char(0),char(186),char(2),char(11),char(255),char(236),char(0),char(186),char(3),char(112), -char(255),char(215),char(0),char(191),char(0),char(5),char(0),char(82),char(0),char(191), -char(0),char(10),char(0),char(82),char(0),char(191),char(0),char(15),char(255),char(174), -char(0),char(191),char(0),char(17),char(255),char(174),char(0),char(191),char(0),char(34), -char(0),char(41),char(0),char(191),char(2),char(7),char(0),char(82),char(0),char(191), -char(2),char(8),char(255),char(174),char(0),char(191),char(2),char(11),char(0),char(82), -char(0),char(191),char(2),char(12),char(255),char(174),char(0),char(192),char(0),char(5), -char(255),char(236),char(0),char(192),char(0),char(10),char(255),char(236),char(0),char(192), -char(0),char(89),char(255),char(215),char(0),char(192),char(0),char(90),char(255),char(215), -char(0),char(192),char(0),char(91),char(255),char(215),char(0),char(192),char(0),char(92), -char(255),char(215),char(0),char(192),char(0),char(93),char(255),char(236),char(0),char(192), -char(0),char(191),char(255),char(215),char(0),char(192),char(1),char(55),char(255),char(215), -char(0),char(192),char(1),char(60),char(255),char(236),char(0),char(192),char(1),char(62), -char(255),char(236),char(0),char(192),char(1),char(64),char(255),char(236),char(0),char(192), -char(1),char(251),char(255),char(215),char(0),char(192),char(1),char(253),char(255),char(215), -char(0),char(192),char(2),char(7),char(255),char(236),char(0),char(192),char(2),char(11), -char(255),char(236),char(0),char(192),char(3),char(112),char(255),char(215),char(0),char(193), -char(0),char(5),char(0),char(82),char(0),char(193),char(0),char(10),char(0),char(82), -char(0),char(193),char(0),char(15),char(255),char(174),char(0),char(193),char(0),char(17), -char(255),char(174),char(0),char(193),char(0),char(34),char(0),char(41),char(0),char(193), -char(2),char(7),char(0),char(82),char(0),char(193),char(2),char(8),char(255),char(174), -char(0),char(193),char(2),char(11),char(0),char(82),char(0),char(193),char(2),char(12), -char(255),char(174),char(0),char(194),char(0),char(5),char(255),char(113),char(0),char(194), -char(0),char(10),char(255),char(113),char(0),char(194),char(0),char(38),char(255),char(215), -char(0),char(194),char(0),char(42),char(255),char(215),char(0),char(194),char(0),char(45), -char(1),char(10),char(0),char(194),char(0),char(50),char(255),char(215),char(0),char(194), -char(0),char(52),char(255),char(215),char(0),char(194),char(0),char(55),char(255),char(113), -char(0),char(194),char(0),char(57),char(255),char(174),char(0),char(194),char(0),char(58), -char(255),char(174),char(0),char(194),char(0),char(60),char(255),char(133),char(0),char(194), -char(0),char(137),char(255),char(215),char(0),char(194),char(0),char(148),char(255),char(215), -char(0),char(194),char(0),char(149),char(255),char(215),char(0),char(194),char(0),char(150), -char(255),char(215),char(0),char(194),char(0),char(151),char(255),char(215),char(0),char(194), -char(0),char(152),char(255),char(215),char(0),char(194),char(0),char(154),char(255),char(215), -char(0),char(194),char(0),char(159),char(255),char(133),char(0),char(194),char(0),char(200), -char(255),char(215),char(0),char(194),char(0),char(202),char(255),char(215),char(0),char(194), -char(0),char(204),char(255),char(215),char(0),char(194),char(0),char(206),char(255),char(215), -char(0),char(194),char(0),char(222),char(255),char(215),char(0),char(194),char(0),char(224), -char(255),char(215),char(0),char(194),char(0),char(226),char(255),char(215),char(0),char(194), -char(0),char(228),char(255),char(215),char(0),char(194),char(1),char(14),char(255),char(215), -char(0),char(194),char(1),char(16),char(255),char(215),char(0),char(194),char(1),char(18), -char(255),char(215),char(0),char(194),char(1),char(20),char(255),char(215),char(0),char(194), -char(1),char(36),char(255),char(113),char(0),char(194),char(1),char(38),char(255),char(113), -char(0),char(194),char(1),char(54),char(255),char(174),char(0),char(194),char(1),char(56), -char(255),char(133),char(0),char(194),char(1),char(58),char(255),char(133),char(0),char(194), -char(1),char(71),char(255),char(215),char(0),char(194),char(1),char(250),char(255),char(174), -char(0),char(194),char(1),char(252),char(255),char(174),char(0),char(194),char(1),char(254), -char(255),char(174),char(0),char(194),char(2),char(0),char(255),char(133),char(0),char(194), -char(2),char(7),char(255),char(113),char(0),char(194),char(2),char(11),char(255),char(113), -char(0),char(194),char(2),char(95),char(255),char(215),char(0),char(194),char(3),char(73), -char(255),char(215),char(0),char(194),char(3),char(75),char(255),char(215),char(0),char(194), -char(3),char(77),char(255),char(215),char(0),char(194),char(3),char(79),char(255),char(215), -char(0),char(194),char(3),char(81),char(255),char(215),char(0),char(194),char(3),char(83), -char(255),char(215),char(0),char(194),char(3),char(85),char(255),char(215),char(0),char(194), -char(3),char(87),char(255),char(215),char(0),char(194),char(3),char(89),char(255),char(215), -char(0),char(194),char(3),char(91),char(255),char(215),char(0),char(194),char(3),char(93), -char(255),char(215),char(0),char(194),char(3),char(95),char(255),char(215),char(0),char(194), -char(3),char(111),char(255),char(133),char(0),char(194),char(3),char(113),char(255),char(133), -char(0),char(194),char(3),char(115),char(255),char(133),char(0),char(194),char(3),char(143), -char(255),char(113),char(0),char(195),char(0),char(5),char(255),char(236),char(0),char(195), -char(0),char(10),char(255),char(236),char(0),char(195),char(2),char(7),char(255),char(236), -char(0),char(195),char(2),char(11),char(255),char(236),char(0),char(196),char(0),char(5), -char(255),char(113),char(0),char(196),char(0),char(10),char(255),char(113),char(0),char(196), -char(0),char(38),char(255),char(215),char(0),char(196),char(0),char(42),char(255),char(215), -char(0),char(196),char(0),char(45),char(1),char(10),char(0),char(196),char(0),char(50), -char(255),char(215),char(0),char(196),char(0),char(52),char(255),char(215),char(0),char(196), -char(0),char(55),char(255),char(113),char(0),char(196),char(0),char(57),char(255),char(174), -char(0),char(196),char(0),char(58),char(255),char(174),char(0),char(196),char(0),char(60), -char(255),char(133),char(0),char(196),char(0),char(137),char(255),char(215),char(0),char(196), -char(0),char(148),char(255),char(215),char(0),char(196),char(0),char(149),char(255),char(215), -char(0),char(196),char(0),char(150),char(255),char(215),char(0),char(196),char(0),char(151), -char(255),char(215),char(0),char(196),char(0),char(152),char(255),char(215),char(0),char(196), -char(0),char(154),char(255),char(215),char(0),char(196),char(0),char(159),char(255),char(133), -char(0),char(196),char(0),char(200),char(255),char(215),char(0),char(196),char(0),char(202), -char(255),char(215),char(0),char(196),char(0),char(204),char(255),char(215),char(0),char(196), -char(0),char(206),char(255),char(215),char(0),char(196),char(0),char(222),char(255),char(215), -char(0),char(196),char(0),char(224),char(255),char(215),char(0),char(196),char(0),char(226), -char(255),char(215),char(0),char(196),char(0),char(228),char(255),char(215),char(0),char(196), -char(1),char(14),char(255),char(215),char(0),char(196),char(1),char(16),char(255),char(215), -char(0),char(196),char(1),char(18),char(255),char(215),char(0),char(196),char(1),char(20), -char(255),char(215),char(0),char(196),char(1),char(36),char(255),char(113),char(0),char(196), -char(1),char(38),char(255),char(113),char(0),char(196),char(1),char(54),char(255),char(174), -char(0),char(196),char(1),char(56),char(255),char(133),char(0),char(196),char(1),char(58), -char(255),char(133),char(0),char(196),char(1),char(71),char(255),char(215),char(0),char(196), -char(1),char(250),char(255),char(174),char(0),char(196),char(1),char(252),char(255),char(174), -char(0),char(196),char(1),char(254),char(255),char(174),char(0),char(196),char(2),char(0), -char(255),char(133),char(0),char(196),char(2),char(7),char(255),char(113),char(0),char(196), -char(2),char(11),char(255),char(113),char(0),char(196),char(2),char(95),char(255),char(215), -char(0),char(196),char(3),char(73),char(255),char(215),char(0),char(196),char(3),char(75), -char(255),char(215),char(0),char(196),char(3),char(77),char(255),char(215),char(0),char(196), -char(3),char(79),char(255),char(215),char(0),char(196),char(3),char(81),char(255),char(215), -char(0),char(196),char(3),char(83),char(255),char(215),char(0),char(196),char(3),char(85), -char(255),char(215),char(0),char(196),char(3),char(87),char(255),char(215),char(0),char(196), -char(3),char(89),char(255),char(215),char(0),char(196),char(3),char(91),char(255),char(215), -char(0),char(196),char(3),char(93),char(255),char(215),char(0),char(196),char(3),char(95), -char(255),char(215),char(0),char(196),char(3),char(111),char(255),char(133),char(0),char(196), -char(3),char(113),char(255),char(133),char(0),char(196),char(3),char(115),char(255),char(133), -char(0),char(196),char(3),char(143),char(255),char(113),char(0),char(197),char(0),char(5), -char(255),char(236),char(0),char(197),char(0),char(10),char(255),char(236),char(0),char(197), -char(2),char(7),char(255),char(236),char(0),char(197),char(2),char(11),char(255),char(236), -char(0),char(198),char(0),char(5),char(255),char(113),char(0),char(198),char(0),char(10), -char(255),char(113),char(0),char(198),char(0),char(38),char(255),char(215),char(0),char(198), -char(0),char(42),char(255),char(215),char(0),char(198),char(0),char(45),char(1),char(10), -char(0),char(198),char(0),char(50),char(255),char(215),char(0),char(198),char(0),char(52), -char(255),char(215),char(0),char(198),char(0),char(55),char(255),char(113),char(0),char(198), -char(0),char(57),char(255),char(174),char(0),char(198),char(0),char(58),char(255),char(174), -char(0),char(198),char(0),char(60),char(255),char(133),char(0),char(198),char(0),char(137), -char(255),char(215),char(0),char(198),char(0),char(148),char(255),char(215),char(0),char(198), -char(0),char(149),char(255),char(215),char(0),char(198),char(0),char(150),char(255),char(215), -char(0),char(198),char(0),char(151),char(255),char(215),char(0),char(198),char(0),char(152), -char(255),char(215),char(0),char(198),char(0),char(154),char(255),char(215),char(0),char(198), -char(0),char(159),char(255),char(133),char(0),char(198),char(0),char(200),char(255),char(215), -char(0),char(198),char(0),char(202),char(255),char(215),char(0),char(198),char(0),char(204), -char(255),char(215),char(0),char(198),char(0),char(206),char(255),char(215),char(0),char(198), -char(0),char(222),char(255),char(215),char(0),char(198),char(0),char(224),char(255),char(215), -char(0),char(198),char(0),char(226),char(255),char(215),char(0),char(198),char(0),char(228), -char(255),char(215),char(0),char(198),char(1),char(14),char(255),char(215),char(0),char(198), -char(1),char(16),char(255),char(215),char(0),char(198),char(1),char(18),char(255),char(215), -char(0),char(198),char(1),char(20),char(255),char(215),char(0),char(198),char(1),char(36), -char(255),char(113),char(0),char(198),char(1),char(38),char(255),char(113),char(0),char(198), -char(1),char(54),char(255),char(174),char(0),char(198),char(1),char(56),char(255),char(133), -char(0),char(198),char(1),char(58),char(255),char(133),char(0),char(198),char(1),char(71), -char(255),char(215),char(0),char(198),char(1),char(250),char(255),char(174),char(0),char(198), -char(1),char(252),char(255),char(174),char(0),char(198),char(1),char(254),char(255),char(174), -char(0),char(198),char(2),char(0),char(255),char(133),char(0),char(198),char(2),char(7), -char(255),char(113),char(0),char(198),char(2),char(11),char(255),char(113),char(0),char(198), -char(2),char(95),char(255),char(215),char(0),char(198),char(3),char(73),char(255),char(215), -char(0),char(198),char(3),char(75),char(255),char(215),char(0),char(198),char(3),char(77), -char(255),char(215),char(0),char(198),char(3),char(79),char(255),char(215),char(0),char(198), -char(3),char(81),char(255),char(215),char(0),char(198),char(3),char(83),char(255),char(215), -char(0),char(198),char(3),char(85),char(255),char(215),char(0),char(198),char(3),char(87), -char(255),char(215),char(0),char(198),char(3),char(89),char(255),char(215),char(0),char(198), -char(3),char(91),char(255),char(215),char(0),char(198),char(3),char(93),char(255),char(215), -char(0),char(198),char(3),char(95),char(255),char(215),char(0),char(198),char(3),char(111), -char(255),char(133),char(0),char(198),char(3),char(113),char(255),char(133),char(0),char(198), -char(3),char(115),char(255),char(133),char(0),char(198),char(3),char(143),char(255),char(113), -char(0),char(199),char(0),char(5),char(255),char(236),char(0),char(199),char(0),char(10), -char(255),char(236),char(0),char(199),char(2),char(7),char(255),char(236),char(0),char(199), -char(2),char(11),char(255),char(236),char(0),char(200),char(0),char(38),char(255),char(215), -char(0),char(200),char(0),char(42),char(255),char(215),char(0),char(200),char(0),char(50), -char(255),char(215),char(0),char(200),char(0),char(52),char(255),char(215),char(0),char(200), -char(0),char(137),char(255),char(215),char(0),char(200),char(0),char(148),char(255),char(215), -char(0),char(200),char(0),char(149),char(255),char(215),char(0),char(200),char(0),char(150), -char(255),char(215),char(0),char(200),char(0),char(151),char(255),char(215),char(0),char(200), -char(0),char(152),char(255),char(215),char(0),char(200),char(0),char(154),char(255),char(215), -char(0),char(200),char(0),char(200),char(255),char(215),char(0),char(200),char(0),char(202), -char(255),char(215),char(0),char(200),char(0),char(204),char(255),char(215),char(0),char(200), -char(0),char(206),char(255),char(215),char(0),char(200),char(0),char(222),char(255),char(215), -char(0),char(200),char(0),char(224),char(255),char(215),char(0),char(200),char(0),char(226), -char(255),char(215),char(0),char(200),char(0),char(228),char(255),char(215),char(0),char(200), -char(1),char(14),char(255),char(215),char(0),char(200),char(1),char(16),char(255),char(215), -char(0),char(200),char(1),char(18),char(255),char(215),char(0),char(200),char(1),char(20), -char(255),char(215),char(0),char(200),char(1),char(71),char(255),char(215),char(0),char(200), -char(2),char(95),char(255),char(215),char(0),char(200),char(3),char(73),char(255),char(215), -char(0),char(200),char(3),char(75),char(255),char(215),char(0),char(200),char(3),char(77), -char(255),char(215),char(0),char(200),char(3),char(79),char(255),char(215),char(0),char(200), -char(3),char(81),char(255),char(215),char(0),char(200),char(3),char(83),char(255),char(215), -char(0),char(200),char(3),char(85),char(255),char(215),char(0),char(200),char(3),char(87), -char(255),char(215),char(0),char(200),char(3),char(89),char(255),char(215),char(0),char(200), -char(3),char(91),char(255),char(215),char(0),char(200),char(3),char(93),char(255),char(215), -char(0),char(200),char(3),char(95),char(255),char(215),char(0),char(202),char(0),char(38), -char(255),char(215),char(0),char(202),char(0),char(42),char(255),char(215),char(0),char(202), -char(0),char(50),char(255),char(215),char(0),char(202),char(0),char(52),char(255),char(215), -char(0),char(202),char(0),char(137),char(255),char(215),char(0),char(202),char(0),char(148), -char(255),char(215),char(0),char(202),char(0),char(149),char(255),char(215),char(0),char(202), -char(0),char(150),char(255),char(215),char(0),char(202),char(0),char(151),char(255),char(215), -char(0),char(202),char(0),char(152),char(255),char(215),char(0),char(202),char(0),char(154), -char(255),char(215),char(0),char(202),char(0),char(200),char(255),char(215),char(0),char(202), -char(0),char(202),char(255),char(215),char(0),char(202),char(0),char(204),char(255),char(215), -char(0),char(202),char(0),char(206),char(255),char(215),char(0),char(202),char(0),char(222), -char(255),char(215),char(0),char(202),char(0),char(224),char(255),char(215),char(0),char(202), -char(0),char(226),char(255),char(215),char(0),char(202),char(0),char(228),char(255),char(215), -char(0),char(202),char(1),char(14),char(255),char(215),char(0),char(202),char(1),char(16), -char(255),char(215),char(0),char(202),char(1),char(18),char(255),char(215),char(0),char(202), -char(1),char(20),char(255),char(215),char(0),char(202),char(1),char(71),char(255),char(215), -char(0),char(202),char(2),char(95),char(255),char(215),char(0),char(202),char(3),char(73), -char(255),char(215),char(0),char(202),char(3),char(75),char(255),char(215),char(0),char(202), -char(3),char(77),char(255),char(215),char(0),char(202),char(3),char(79),char(255),char(215), -char(0),char(202),char(3),char(81),char(255),char(215),char(0),char(202),char(3),char(83), -char(255),char(215),char(0),char(202),char(3),char(85),char(255),char(215),char(0),char(202), -char(3),char(87),char(255),char(215),char(0),char(202),char(3),char(89),char(255),char(215), -char(0),char(202),char(3),char(91),char(255),char(215),char(0),char(202),char(3),char(93), -char(255),char(215),char(0),char(202),char(3),char(95),char(255),char(215),char(0),char(204), -char(0),char(38),char(255),char(215),char(0),char(204),char(0),char(42),char(255),char(215), -char(0),char(204),char(0),char(50),char(255),char(215),char(0),char(204),char(0),char(52), -char(255),char(215),char(0),char(204),char(0),char(137),char(255),char(215),char(0),char(204), -char(0),char(148),char(255),char(215),char(0),char(204),char(0),char(149),char(255),char(215), -char(0),char(204),char(0),char(150),char(255),char(215),char(0),char(204),char(0),char(151), -char(255),char(215),char(0),char(204),char(0),char(152),char(255),char(215),char(0),char(204), -char(0),char(154),char(255),char(215),char(0),char(204),char(0),char(200),char(255),char(215), -char(0),char(204),char(0),char(202),char(255),char(215),char(0),char(204),char(0),char(204), -char(255),char(215),char(0),char(204),char(0),char(206),char(255),char(215),char(0),char(204), -char(0),char(222),char(255),char(215),char(0),char(204),char(0),char(224),char(255),char(215), -char(0),char(204),char(0),char(226),char(255),char(215),char(0),char(204),char(0),char(228), -char(255),char(215),char(0),char(204),char(1),char(14),char(255),char(215),char(0),char(204), -char(1),char(16),char(255),char(215),char(0),char(204),char(1),char(18),char(255),char(215), -char(0),char(204),char(1),char(20),char(255),char(215),char(0),char(204),char(1),char(71), -char(255),char(215),char(0),char(204),char(2),char(95),char(255),char(215),char(0),char(204), -char(3),char(73),char(255),char(215),char(0),char(204),char(3),char(75),char(255),char(215), -char(0),char(204),char(3),char(77),char(255),char(215),char(0),char(204),char(3),char(79), -char(255),char(215),char(0),char(204),char(3),char(81),char(255),char(215),char(0),char(204), -char(3),char(83),char(255),char(215),char(0),char(204),char(3),char(85),char(255),char(215), -char(0),char(204),char(3),char(87),char(255),char(215),char(0),char(204),char(3),char(89), -char(255),char(215),char(0),char(204),char(3),char(91),char(255),char(215),char(0),char(204), -char(3),char(93),char(255),char(215),char(0),char(204),char(3),char(95),char(255),char(215), -char(0),char(206),char(0),char(38),char(255),char(215),char(0),char(206),char(0),char(42), -char(255),char(215),char(0),char(206),char(0),char(50),char(255),char(215),char(0),char(206), -char(0),char(52),char(255),char(215),char(0),char(206),char(0),char(137),char(255),char(215), -char(0),char(206),char(0),char(148),char(255),char(215),char(0),char(206),char(0),char(149), -char(255),char(215),char(0),char(206),char(0),char(150),char(255),char(215),char(0),char(206), -char(0),char(151),char(255),char(215),char(0),char(206),char(0),char(152),char(255),char(215), -char(0),char(206),char(0),char(154),char(255),char(215),char(0),char(206),char(0),char(200), -char(255),char(215),char(0),char(206),char(0),char(202),char(255),char(215),char(0),char(206), -char(0),char(204),char(255),char(215),char(0),char(206),char(0),char(206),char(255),char(215), -char(0),char(206),char(0),char(222),char(255),char(215),char(0),char(206),char(0),char(224), -char(255),char(215),char(0),char(206),char(0),char(226),char(255),char(215),char(0),char(206), -char(0),char(228),char(255),char(215),char(0),char(206),char(1),char(14),char(255),char(215), -char(0),char(206),char(1),char(16),char(255),char(215),char(0),char(206),char(1),char(18), -char(255),char(215),char(0),char(206),char(1),char(20),char(255),char(215),char(0),char(206), -char(1),char(71),char(255),char(215),char(0),char(206),char(2),char(95),char(255),char(215), -char(0),char(206),char(3),char(73),char(255),char(215),char(0),char(206),char(3),char(75), -char(255),char(215),char(0),char(206),char(3),char(77),char(255),char(215),char(0),char(206), -char(3),char(79),char(255),char(215),char(0),char(206),char(3),char(81),char(255),char(215), -char(0),char(206),char(3),char(83),char(255),char(215),char(0),char(206),char(3),char(85), -char(255),char(215),char(0),char(206),char(3),char(87),char(255),char(215),char(0),char(206), -char(3),char(89),char(255),char(215),char(0),char(206),char(3),char(91),char(255),char(215), -char(0),char(206),char(3),char(93),char(255),char(215),char(0),char(206),char(3),char(95), -char(255),char(215),char(0),char(208),char(0),char(15),char(255),char(174),char(0),char(208), -char(0),char(17),char(255),char(174),char(0),char(208),char(0),char(36),char(255),char(215), -char(0),char(208),char(0),char(55),char(255),char(195),char(0),char(208),char(0),char(57), -char(255),char(236),char(0),char(208),char(0),char(58),char(255),char(236),char(0),char(208), -char(0),char(59),char(255),char(215),char(0),char(208),char(0),char(60),char(255),char(236), -char(0),char(208),char(0),char(61),char(255),char(236),char(0),char(208),char(0),char(130), -char(255),char(215),char(0),char(208),char(0),char(131),char(255),char(215),char(0),char(208), -char(0),char(132),char(255),char(215),char(0),char(208),char(0),char(133),char(255),char(215), -char(0),char(208),char(0),char(134),char(255),char(215),char(0),char(208),char(0),char(135), -char(255),char(215),char(0),char(208),char(0),char(159),char(255),char(236),char(0),char(208), -char(0),char(194),char(255),char(215),char(0),char(208),char(0),char(196),char(255),char(215), -char(0),char(208),char(0),char(198),char(255),char(215),char(0),char(208),char(1),char(36), -char(255),char(195),char(0),char(208),char(1),char(38),char(255),char(195),char(0),char(208), -char(1),char(54),char(255),char(236),char(0),char(208),char(1),char(56),char(255),char(236), -char(0),char(208),char(1),char(58),char(255),char(236),char(0),char(208),char(1),char(59), -char(255),char(236),char(0),char(208),char(1),char(61),char(255),char(236),char(0),char(208), -char(1),char(63),char(255),char(236),char(0),char(208),char(1),char(67),char(255),char(215), -char(0),char(208),char(1),char(160),char(255),char(236),char(0),char(208),char(1),char(250), -char(255),char(236),char(0),char(208),char(1),char(252),char(255),char(236),char(0),char(208), -char(1),char(254),char(255),char(236),char(0),char(208),char(2),char(0),char(255),char(236), -char(0),char(208),char(2),char(8),char(255),char(174),char(0),char(208),char(2),char(12), -char(255),char(174),char(0),char(208),char(2),char(88),char(255),char(215),char(0),char(208), -char(3),char(29),char(255),char(215),char(0),char(208),char(3),char(31),char(255),char(215), -char(0),char(208),char(3),char(33),char(255),char(215),char(0),char(208),char(3),char(35), -char(255),char(215),char(0),char(208),char(3),char(37),char(255),char(215),char(0),char(208), -char(3),char(39),char(255),char(215),char(0),char(208),char(3),char(41),char(255),char(215), -char(0),char(208),char(3),char(43),char(255),char(215),char(0),char(208),char(3),char(45), -char(255),char(215),char(0),char(208),char(3),char(47),char(255),char(215),char(0),char(208), -char(3),char(49),char(255),char(215),char(0),char(208),char(3),char(51),char(255),char(215), -char(0),char(208),char(3),char(111),char(255),char(236),char(0),char(208),char(3),char(113), -char(255),char(236),char(0),char(208),char(3),char(115),char(255),char(236),char(0),char(208), -char(3),char(143),char(255),char(195),char(0),char(209),char(0),char(5),char(0),char(82), -char(0),char(209),char(0),char(10),char(0),char(82),char(0),char(209),char(0),char(12), -char(0),char(143),char(0),char(209),char(0),char(34),char(0),char(164),char(0),char(209), -char(0),char(64),char(0),char(143),char(0),char(209),char(0),char(69),char(0),char(61), -char(0),char(209),char(0),char(75),char(0),char(61),char(0),char(209),char(0),char(78), -char(0),char(61),char(0),char(209),char(0),char(79),char(0),char(61),char(0),char(209), -char(0),char(96),char(0),char(143),char(0),char(209),char(0),char(231),char(0),char(61), -char(0),char(209),char(0),char(233),char(0),char(123),char(0),char(209),char(2),char(7), -char(0),char(82),char(0),char(209),char(2),char(11),char(0),char(82),char(0),char(210), -char(0),char(15),char(255),char(174),char(0),char(210),char(0),char(17),char(255),char(174), -char(0),char(210),char(0),char(36),char(255),char(215),char(0),char(210),char(0),char(55), -char(255),char(195),char(0),char(210),char(0),char(57),char(255),char(236),char(0),char(210), -char(0),char(58),char(255),char(236),char(0),char(210),char(0),char(59),char(255),char(215), -char(0),char(210),char(0),char(60),char(255),char(236),char(0),char(210),char(0),char(61), -char(255),char(236),char(0),char(210),char(0),char(130),char(255),char(215),char(0),char(210), -char(0),char(131),char(255),char(215),char(0),char(210),char(0),char(132),char(255),char(215), -char(0),char(210),char(0),char(133),char(255),char(215),char(0),char(210),char(0),char(134), -char(255),char(215),char(0),char(210),char(0),char(135),char(255),char(215),char(0),char(210), -char(0),char(159),char(255),char(236),char(0),char(210),char(0),char(194),char(255),char(215), -char(0),char(210),char(0),char(196),char(255),char(215),char(0),char(210),char(0),char(198), -char(255),char(215),char(0),char(210),char(1),char(36),char(255),char(195),char(0),char(210), -char(1),char(38),char(255),char(195),char(0),char(210),char(1),char(54),char(255),char(236), -char(0),char(210),char(1),char(56),char(255),char(236),char(0),char(210),char(1),char(58), -char(255),char(236),char(0),char(210),char(1),char(59),char(255),char(236),char(0),char(210), -char(1),char(61),char(255),char(236),char(0),char(210),char(1),char(63),char(255),char(236), -char(0),char(210),char(1),char(67),char(255),char(215),char(0),char(210),char(1),char(160), -char(255),char(236),char(0),char(210),char(1),char(250),char(255),char(236),char(0),char(210), -char(1),char(252),char(255),char(236),char(0),char(210),char(1),char(254),char(255),char(236), -char(0),char(210),char(2),char(0),char(255),char(236),char(0),char(210),char(2),char(8), -char(255),char(174),char(0),char(210),char(2),char(12),char(255),char(174),char(0),char(210), -char(2),char(88),char(255),char(215),char(0),char(210),char(3),char(29),char(255),char(215), -char(0),char(210),char(3),char(31),char(255),char(215),char(0),char(210),char(3),char(33), -char(255),char(215),char(0),char(210),char(3),char(35),char(255),char(215),char(0),char(210), -char(3),char(37),char(255),char(215),char(0),char(210),char(3),char(39),char(255),char(215), -char(0),char(210),char(3),char(41),char(255),char(215),char(0),char(210),char(3),char(43), -char(255),char(215),char(0),char(210),char(3),char(45),char(255),char(215),char(0),char(210), -char(3),char(47),char(255),char(215),char(0),char(210),char(3),char(49),char(255),char(215), -char(0),char(210),char(3),char(51),char(255),char(215),char(0),char(210),char(3),char(111), -char(255),char(236),char(0),char(210),char(3),char(113),char(255),char(236),char(0),char(210), -char(3),char(115),char(255),char(236),char(0),char(210),char(3),char(143),char(255),char(195), -char(0),char(212),char(0),char(45),char(0),char(123),char(0),char(213),char(0),char(5), -char(255),char(236),char(0),char(213),char(0),char(10),char(255),char(236),char(0),char(213), -char(0),char(89),char(255),char(215),char(0),char(213),char(0),char(90),char(255),char(215), -char(0),char(213),char(0),char(91),char(255),char(215),char(0),char(213),char(0),char(92), -char(255),char(215),char(0),char(213),char(0),char(93),char(255),char(236),char(0),char(213), -char(0),char(191),char(255),char(215),char(0),char(213),char(1),char(55),char(255),char(215), -char(0),char(213),char(1),char(60),char(255),char(236),char(0),char(213),char(1),char(62), -char(255),char(236),char(0),char(213),char(1),char(64),char(255),char(236),char(0),char(213), -char(1),char(251),char(255),char(215),char(0),char(213),char(1),char(253),char(255),char(215), -char(0),char(213),char(2),char(7),char(255),char(236),char(0),char(213),char(2),char(11), -char(255),char(236),char(0),char(213),char(3),char(112),char(255),char(215),char(0),char(214), -char(0),char(45),char(0),char(123),char(0),char(215),char(0),char(5),char(255),char(236), -char(0),char(215),char(0),char(10),char(255),char(236),char(0),char(215),char(0),char(89), -char(255),char(215),char(0),char(215),char(0),char(90),char(255),char(215),char(0),char(215), -char(0),char(91),char(255),char(215),char(0),char(215),char(0),char(92),char(255),char(215), -char(0),char(215),char(0),char(93),char(255),char(236),char(0),char(215),char(0),char(191), -char(255),char(215),char(0),char(215),char(1),char(55),char(255),char(215),char(0),char(215), -char(1),char(60),char(255),char(236),char(0),char(215),char(1),char(62),char(255),char(236), -char(0),char(215),char(1),char(64),char(255),char(236),char(0),char(215),char(1),char(251), -char(255),char(215),char(0),char(215),char(1),char(253),char(255),char(215),char(0),char(215), -char(2),char(7),char(255),char(236),char(0),char(215),char(2),char(11),char(255),char(236), -char(0),char(215),char(3),char(112),char(255),char(215),char(0),char(216),char(0),char(45), -char(0),char(123),char(0),char(217),char(0),char(5),char(255),char(236),char(0),char(217), -char(0),char(10),char(255),char(236),char(0),char(217),char(0),char(89),char(255),char(215), -char(0),char(217),char(0),char(90),char(255),char(215),char(0),char(217),char(0),char(91), -char(255),char(215),char(0),char(217),char(0),char(92),char(255),char(215),char(0),char(217), -char(0),char(93),char(255),char(236),char(0),char(217),char(0),char(191),char(255),char(215), -char(0),char(217),char(1),char(55),char(255),char(215),char(0),char(217),char(1),char(60), -char(255),char(236),char(0),char(217),char(1),char(62),char(255),char(236),char(0),char(217), -char(1),char(64),char(255),char(236),char(0),char(217),char(1),char(251),char(255),char(215), -char(0),char(217),char(1),char(253),char(255),char(215),char(0),char(217),char(2),char(7), -char(255),char(236),char(0),char(217),char(2),char(11),char(255),char(236),char(0),char(217), -char(3),char(112),char(255),char(215),char(0),char(218),char(0),char(45),char(0),char(123), -char(0),char(219),char(0),char(5),char(255),char(236),char(0),char(219),char(0),char(10), -char(255),char(236),char(0),char(219),char(0),char(89),char(255),char(215),char(0),char(219), -char(0),char(90),char(255),char(215),char(0),char(219),char(0),char(91),char(255),char(215), -char(0),char(219),char(0),char(92),char(255),char(215),char(0),char(219),char(0),char(93), -char(255),char(236),char(0),char(219),char(0),char(191),char(255),char(215),char(0),char(219), -char(1),char(55),char(255),char(215),char(0),char(219),char(1),char(60),char(255),char(236), -char(0),char(219),char(1),char(62),char(255),char(236),char(0),char(219),char(1),char(64), -char(255),char(236),char(0),char(219),char(1),char(251),char(255),char(215),char(0),char(219), -char(1),char(253),char(255),char(215),char(0),char(219),char(2),char(7),char(255),char(236), -char(0),char(219),char(2),char(11),char(255),char(236),char(0),char(219),char(3),char(112), -char(255),char(215),char(0),char(220),char(0),char(45),char(0),char(123),char(0),char(221), -char(0),char(5),char(255),char(236),char(0),char(221),char(0),char(10),char(255),char(236), -char(0),char(221),char(0),char(89),char(255),char(215),char(0),char(221),char(0),char(90), -char(255),char(215),char(0),char(221),char(0),char(91),char(255),char(215),char(0),char(221), -char(0),char(92),char(255),char(215),char(0),char(221),char(0),char(93),char(255),char(236), -char(0),char(221),char(0),char(191),char(255),char(215),char(0),char(221),char(1),char(55), -char(255),char(215),char(0),char(221),char(1),char(60),char(255),char(236),char(0),char(221), -char(1),char(62),char(255),char(236),char(0),char(221),char(1),char(64),char(255),char(236), -char(0),char(221),char(1),char(251),char(255),char(215),char(0),char(221),char(1),char(253), -char(255),char(215),char(0),char(221),char(2),char(7),char(255),char(236),char(0),char(221), -char(2),char(11),char(255),char(236),char(0),char(221),char(3),char(112),char(255),char(215), -char(0),char(231),char(0),char(5),char(255),char(236),char(0),char(231),char(0),char(10), -char(255),char(236),char(0),char(231),char(2),char(7),char(255),char(236),char(0),char(231), -char(2),char(11),char(255),char(236),char(0),char(248),char(0),char(38),char(255),char(215), -char(0),char(248),char(0),char(42),char(255),char(215),char(0),char(248),char(0),char(50), -char(255),char(215),char(0),char(248),char(0),char(52),char(255),char(215),char(0),char(248), -char(0),char(137),char(255),char(215),char(0),char(248),char(0),char(148),char(255),char(215), -char(0),char(248),char(0),char(149),char(255),char(215),char(0),char(248),char(0),char(150), -char(255),char(215),char(0),char(248),char(0),char(151),char(255),char(215),char(0),char(248), -char(0),char(152),char(255),char(215),char(0),char(248),char(0),char(154),char(255),char(215), -char(0),char(248),char(0),char(200),char(255),char(215),char(0),char(248),char(0),char(202), -char(255),char(215),char(0),char(248),char(0),char(204),char(255),char(215),char(0),char(248), -char(0),char(206),char(255),char(215),char(0),char(248),char(0),char(222),char(255),char(215), -char(0),char(248),char(0),char(224),char(255),char(215),char(0),char(248),char(0),char(226), -char(255),char(215),char(0),char(248),char(0),char(228),char(255),char(215),char(0),char(248), -char(1),char(14),char(255),char(215),char(0),char(248),char(1),char(16),char(255),char(215), -char(0),char(248),char(1),char(18),char(255),char(215),char(0),char(248),char(1),char(20), -char(255),char(215),char(0),char(248),char(1),char(71),char(255),char(215),char(0),char(248), -char(2),char(95),char(255),char(215),char(0),char(248),char(3),char(73),char(255),char(215), -char(0),char(248),char(3),char(75),char(255),char(215),char(0),char(248),char(3),char(77), -char(255),char(215),char(0),char(248),char(3),char(79),char(255),char(215),char(0),char(248), -char(3),char(81),char(255),char(215),char(0),char(248),char(3),char(83),char(255),char(215), -char(0),char(248),char(3),char(85),char(255),char(215),char(0),char(248),char(3),char(87), -char(255),char(215),char(0),char(248),char(3),char(89),char(255),char(215),char(0),char(248), -char(3),char(91),char(255),char(215),char(0),char(248),char(3),char(93),char(255),char(215), -char(0),char(248),char(3),char(95),char(255),char(215),char(0),char(249),char(0),char(70), -char(255),char(215),char(0),char(249),char(0),char(71),char(255),char(215),char(0),char(249), -char(0),char(72),char(255),char(215),char(0),char(249),char(0),char(82),char(255),char(215), -char(0),char(249),char(0),char(84),char(255),char(215),char(0),char(249),char(0),char(162), -char(255),char(215),char(0),char(249),char(0),char(169),char(255),char(215),char(0),char(249), -char(0),char(170),char(255),char(215),char(0),char(249),char(0),char(171),char(255),char(215), -char(0),char(249),char(0),char(172),char(255),char(215),char(0),char(249),char(0),char(173), -char(255),char(215),char(0),char(249),char(0),char(180),char(255),char(215),char(0),char(249), -char(0),char(181),char(255),char(215),char(0),char(249),char(0),char(182),char(255),char(215), -char(0),char(249),char(0),char(183),char(255),char(215),char(0),char(249),char(0),char(184), -char(255),char(215),char(0),char(249),char(0),char(186),char(255),char(215),char(0),char(249), -char(0),char(201),char(255),char(215),char(0),char(249),char(0),char(203),char(255),char(215), -char(0),char(249),char(0),char(205),char(255),char(215),char(0),char(249),char(0),char(207), -char(255),char(215),char(0),char(249),char(0),char(209),char(255),char(215),char(0),char(249), -char(0),char(211),char(255),char(215),char(0),char(249),char(0),char(213),char(255),char(215), -char(0),char(249),char(0),char(215),char(255),char(215),char(0),char(249),char(0),char(217), -char(255),char(215),char(0),char(249),char(0),char(219),char(255),char(215),char(0),char(249), -char(0),char(221),char(255),char(215),char(0),char(249),char(1),char(15),char(255),char(215), -char(0),char(249),char(1),char(17),char(255),char(215),char(0),char(249),char(1),char(19), -char(255),char(215),char(0),char(249),char(1),char(21),char(255),char(215),char(0),char(249), -char(1),char(72),char(255),char(215),char(0),char(249),char(2),char(96),char(255),char(215), -char(0),char(249),char(3),char(54),char(255),char(215),char(0),char(249),char(3),char(56), -char(255),char(215),char(0),char(249),char(3),char(58),char(255),char(215),char(0),char(249), -char(3),char(60),char(255),char(215),char(0),char(249),char(3),char(64),char(255),char(215), -char(0),char(249),char(3),char(66),char(255),char(215),char(0),char(249),char(3),char(68), -char(255),char(215),char(0),char(249),char(3),char(74),char(255),char(215),char(0),char(249), -char(3),char(76),char(255),char(215),char(0),char(249),char(3),char(78),char(255),char(215), -char(0),char(249),char(3),char(82),char(255),char(215),char(0),char(249),char(3),char(84), -char(255),char(215),char(0),char(249),char(3),char(86),char(255),char(215),char(0),char(249), -char(3),char(88),char(255),char(215),char(0),char(249),char(3),char(90),char(255),char(215), -char(0),char(249),char(3),char(92),char(255),char(215),char(0),char(249),char(3),char(94), -char(255),char(215),char(0),char(249),char(3),char(96),char(255),char(215),char(0),char(250), -char(0),char(70),char(255),char(215),char(0),char(250),char(0),char(71),char(255),char(215), -char(0),char(250),char(0),char(72),char(255),char(215),char(0),char(250),char(0),char(82), -char(255),char(215),char(0),char(250),char(0),char(84),char(255),char(215),char(0),char(250), -char(0),char(162),char(255),char(215),char(0),char(250),char(0),char(169),char(255),char(215), -char(0),char(250),char(0),char(170),char(255),char(215),char(0),char(250),char(0),char(171), -char(255),char(215),char(0),char(250),char(0),char(172),char(255),char(215),char(0),char(250), -char(0),char(173),char(255),char(215),char(0),char(250),char(0),char(180),char(255),char(215), -char(0),char(250),char(0),char(181),char(255),char(215),char(0),char(250),char(0),char(182), -char(255),char(215),char(0),char(250),char(0),char(183),char(255),char(215),char(0),char(250), -char(0),char(184),char(255),char(215),char(0),char(250),char(0),char(186),char(255),char(215), -char(0),char(250),char(0),char(201),char(255),char(215),char(0),char(250),char(0),char(203), -char(255),char(215),char(0),char(250),char(0),char(205),char(255),char(215),char(0),char(250), -char(0),char(207),char(255),char(215),char(0),char(250),char(0),char(209),char(255),char(215), -char(0),char(250),char(0),char(211),char(255),char(215),char(0),char(250),char(0),char(213), -char(255),char(215),char(0),char(250),char(0),char(215),char(255),char(215),char(0),char(250), -char(0),char(217),char(255),char(215),char(0),char(250),char(0),char(219),char(255),char(215), -char(0),char(250),char(0),char(221),char(255),char(215),char(0),char(250),char(1),char(15), -char(255),char(215),char(0),char(250),char(1),char(17),char(255),char(215),char(0),char(250), -char(1),char(19),char(255),char(215),char(0),char(250),char(1),char(21),char(255),char(215), -char(0),char(250),char(1),char(72),char(255),char(215),char(0),char(250),char(2),char(96), -char(255),char(215),char(0),char(250),char(3),char(54),char(255),char(215),char(0),char(250), -char(3),char(56),char(255),char(215),char(0),char(250),char(3),char(58),char(255),char(215), -char(0),char(250),char(3),char(60),char(255),char(215),char(0),char(250),char(3),char(64), -char(255),char(215),char(0),char(250),char(3),char(66),char(255),char(215),char(0),char(250), -char(3),char(68),char(255),char(215),char(0),char(250),char(3),char(74),char(255),char(215), -char(0),char(250),char(3),char(76),char(255),char(215),char(0),char(250),char(3),char(78), -char(255),char(215),char(0),char(250),char(3),char(82),char(255),char(215),char(0),char(250), -char(3),char(84),char(255),char(215),char(0),char(250),char(3),char(86),char(255),char(215), -char(0),char(250),char(3),char(88),char(255),char(215),char(0),char(250),char(3),char(90), -char(255),char(215),char(0),char(250),char(3),char(92),char(255),char(215),char(0),char(250), -char(3),char(94),char(255),char(215),char(0),char(250),char(3),char(96),char(255),char(215), -char(0),char(251),char(0),char(5),char(255),char(92),char(0),char(251),char(0),char(10), -char(255),char(92),char(0),char(251),char(0),char(38),char(255),char(215),char(0),char(251), -char(0),char(42),char(255),char(215),char(0),char(251),char(0),char(50),char(255),char(215), -char(0),char(251),char(0),char(52),char(255),char(215),char(0),char(251),char(0),char(55), -char(255),char(215),char(0),char(251),char(0),char(56),char(255),char(236),char(0),char(251), -char(0),char(57),char(255),char(215),char(0),char(251),char(0),char(58),char(255),char(215), -char(0),char(251),char(0),char(60),char(255),char(195),char(0),char(251),char(0),char(137), -char(255),char(215),char(0),char(251),char(0),char(148),char(255),char(215),char(0),char(251), -char(0),char(149),char(255),char(215),char(0),char(251),char(0),char(150),char(255),char(215), -char(0),char(251),char(0),char(151),char(255),char(215),char(0),char(251),char(0),char(152), -char(255),char(215),char(0),char(251),char(0),char(154),char(255),char(215),char(0),char(251), -char(0),char(155),char(255),char(236),char(0),char(251),char(0),char(156),char(255),char(236), -char(0),char(251),char(0),char(157),char(255),char(236),char(0),char(251),char(0),char(158), -char(255),char(236),char(0),char(251),char(0),char(159),char(255),char(195),char(0),char(251), -char(0),char(200),char(255),char(215),char(0),char(251),char(0),char(202),char(255),char(215), -char(0),char(251),char(0),char(204),char(255),char(215),char(0),char(251),char(0),char(206), -char(255),char(215),char(0),char(251),char(0),char(222),char(255),char(215),char(0),char(251), -char(0),char(224),char(255),char(215),char(0),char(251),char(0),char(226),char(255),char(215), -char(0),char(251),char(0),char(228),char(255),char(215),char(0),char(251),char(1),char(14), -char(255),char(215),char(0),char(251),char(1),char(16),char(255),char(215),char(0),char(251), -char(1),char(18),char(255),char(215),char(0),char(251),char(1),char(20),char(255),char(215), -char(0),char(251),char(1),char(36),char(255),char(215),char(0),char(251),char(1),char(38), -char(255),char(215),char(0),char(251),char(1),char(42),char(255),char(236),char(0),char(251), -char(1),char(44),char(255),char(236),char(0),char(251),char(1),char(46),char(255),char(236), -char(0),char(251),char(1),char(48),char(255),char(236),char(0),char(251),char(1),char(50), -char(255),char(236),char(0),char(251),char(1),char(52),char(255),char(236),char(0),char(251), -char(1),char(54),char(255),char(215),char(0),char(251),char(1),char(56),char(255),char(195), -char(0),char(251),char(1),char(58),char(255),char(195),char(0),char(251),char(1),char(71), -char(255),char(215),char(0),char(251),char(1),char(250),char(255),char(215),char(0),char(251), -char(1),char(252),char(255),char(215),char(0),char(251),char(1),char(254),char(255),char(215), -char(0),char(251),char(2),char(0),char(255),char(195),char(0),char(251),char(2),char(7), -char(255),char(92),char(0),char(251),char(2),char(11),char(255),char(92),char(0),char(251), -char(2),char(95),char(255),char(215),char(0),char(251),char(2),char(97),char(255),char(236), -char(0),char(251),char(3),char(73),char(255),char(215),char(0),char(251),char(3),char(75), -char(255),char(215),char(0),char(251),char(3),char(77),char(255),char(215),char(0),char(251), -char(3),char(79),char(255),char(215),char(0),char(251),char(3),char(81),char(255),char(215), -char(0),char(251),char(3),char(83),char(255),char(215),char(0),char(251),char(3),char(85), -char(255),char(215),char(0),char(251),char(3),char(87),char(255),char(215),char(0),char(251), -char(3),char(89),char(255),char(215),char(0),char(251),char(3),char(91),char(255),char(215), -char(0),char(251),char(3),char(93),char(255),char(215),char(0),char(251),char(3),char(95), -char(255),char(215),char(0),char(251),char(3),char(97),char(255),char(236),char(0),char(251), -char(3),char(99),char(255),char(236),char(0),char(251),char(3),char(101),char(255),char(236), -char(0),char(251),char(3),char(103),char(255),char(236),char(0),char(251),char(3),char(105), -char(255),char(236),char(0),char(251),char(3),char(107),char(255),char(236),char(0),char(251), -char(3),char(109),char(255),char(236),char(0),char(251),char(3),char(111),char(255),char(195), -char(0),char(251),char(3),char(113),char(255),char(195),char(0),char(251),char(3),char(115), -char(255),char(195),char(0),char(251),char(3),char(143),char(255),char(215),char(0),char(253), -char(0),char(5),char(255),char(92),char(0),char(253),char(0),char(10),char(255),char(92), -char(0),char(253),char(0),char(38),char(255),char(215),char(0),char(253),char(0),char(42), -char(255),char(215),char(0),char(253),char(0),char(50),char(255),char(215),char(0),char(253), -char(0),char(52),char(255),char(215),char(0),char(253),char(0),char(55),char(255),char(215), -char(0),char(253),char(0),char(56),char(255),char(236),char(0),char(253),char(0),char(57), -char(255),char(215),char(0),char(253),char(0),char(58),char(255),char(215),char(0),char(253), -char(0),char(60),char(255),char(195),char(0),char(253),char(0),char(137),char(255),char(215), -char(0),char(253),char(0),char(148),char(255),char(215),char(0),char(253),char(0),char(149), -char(255),char(215),char(0),char(253),char(0),char(150),char(255),char(215),char(0),char(253), -char(0),char(151),char(255),char(215),char(0),char(253),char(0),char(152),char(255),char(215), -char(0),char(253),char(0),char(154),char(255),char(215),char(0),char(253),char(0),char(155), -char(255),char(236),char(0),char(253),char(0),char(156),char(255),char(236),char(0),char(253), -char(0),char(157),char(255),char(236),char(0),char(253),char(0),char(158),char(255),char(236), -char(0),char(253),char(0),char(159),char(255),char(195),char(0),char(253),char(0),char(200), -char(255),char(215),char(0),char(253),char(0),char(202),char(255),char(215),char(0),char(253), -char(0),char(204),char(255),char(215),char(0),char(253),char(0),char(206),char(255),char(215), -char(0),char(253),char(0),char(222),char(255),char(215),char(0),char(253),char(0),char(224), -char(255),char(215),char(0),char(253),char(0),char(226),char(255),char(215),char(0),char(253), -char(0),char(228),char(255),char(215),char(0),char(253),char(1),char(14),char(255),char(215), -char(0),char(253),char(1),char(16),char(255),char(215),char(0),char(253),char(1),char(18), -char(255),char(215),char(0),char(253),char(1),char(20),char(255),char(215),char(0),char(253), -char(1),char(36),char(255),char(215),char(0),char(253),char(1),char(38),char(255),char(215), -char(0),char(253),char(1),char(42),char(255),char(236),char(0),char(253),char(1),char(44), -char(255),char(236),char(0),char(253),char(1),char(46),char(255),char(236),char(0),char(253), -char(1),char(48),char(255),char(236),char(0),char(253),char(1),char(50),char(255),char(236), -char(0),char(253),char(1),char(52),char(255),char(236),char(0),char(253),char(1),char(54), -char(255),char(215),char(0),char(253),char(1),char(56),char(255),char(195),char(0),char(253), -char(1),char(58),char(255),char(195),char(0),char(253),char(1),char(71),char(255),char(215), -char(0),char(253),char(1),char(250),char(255),char(215),char(0),char(253),char(1),char(252), -char(255),char(215),char(0),char(253),char(1),char(254),char(255),char(215),char(0),char(253), -char(2),char(0),char(255),char(195),char(0),char(253),char(2),char(7),char(255),char(92), -char(0),char(253),char(2),char(11),char(255),char(92),char(0),char(253),char(2),char(95), -char(255),char(215),char(0),char(253),char(2),char(97),char(255),char(236),char(0),char(253), -char(3),char(73),char(255),char(215),char(0),char(253),char(3),char(75),char(255),char(215), -char(0),char(253),char(3),char(77),char(255),char(215),char(0),char(253),char(3),char(79), -char(255),char(215),char(0),char(253),char(3),char(81),char(255),char(215),char(0),char(253), -char(3),char(83),char(255),char(215),char(0),char(253),char(3),char(85),char(255),char(215), -char(0),char(253),char(3),char(87),char(255),char(215),char(0),char(253),char(3),char(89), -char(255),char(215),char(0),char(253),char(3),char(91),char(255),char(215),char(0),char(253), -char(3),char(93),char(255),char(215),char(0),char(253),char(3),char(95),char(255),char(215), -char(0),char(253),char(3),char(97),char(255),char(236),char(0),char(253),char(3),char(99), -char(255),char(236),char(0),char(253),char(3),char(101),char(255),char(236),char(0),char(253), -char(3),char(103),char(255),char(236),char(0),char(253),char(3),char(105),char(255),char(236), -char(0),char(253),char(3),char(107),char(255),char(236),char(0),char(253),char(3),char(109), -char(255),char(236),char(0),char(253),char(3),char(111),char(255),char(195),char(0),char(253), -char(3),char(113),char(255),char(195),char(0),char(253),char(3),char(115),char(255),char(195), -char(0),char(253),char(3),char(143),char(255),char(215),char(0),char(255),char(0),char(5), -char(255),char(92),char(0),char(255),char(0),char(10),char(255),char(92),char(0),char(255), -char(0),char(38),char(255),char(215),char(0),char(255),char(0),char(42),char(255),char(215), -char(0),char(255),char(0),char(50),char(255),char(215),char(0),char(255),char(0),char(52), -char(255),char(215),char(0),char(255),char(0),char(55),char(255),char(215),char(0),char(255), -char(0),char(56),char(255),char(236),char(0),char(255),char(0),char(57),char(255),char(215), -char(0),char(255),char(0),char(58),char(255),char(215),char(0),char(255),char(0),char(60), -char(255),char(195),char(0),char(255),char(0),char(137),char(255),char(215),char(0),char(255), -char(0),char(148),char(255),char(215),char(0),char(255),char(0),char(149),char(255),char(215), -char(0),char(255),char(0),char(150),char(255),char(215),char(0),char(255),char(0),char(151), -char(255),char(215),char(0),char(255),char(0),char(152),char(255),char(215),char(0),char(255), -char(0),char(154),char(255),char(215),char(0),char(255),char(0),char(155),char(255),char(236), -char(0),char(255),char(0),char(156),char(255),char(236),char(0),char(255),char(0),char(157), -char(255),char(236),char(0),char(255),char(0),char(158),char(255),char(236),char(0),char(255), -char(0),char(159),char(255),char(195),char(0),char(255),char(0),char(200),char(255),char(215), -char(0),char(255),char(0),char(202),char(255),char(215),char(0),char(255),char(0),char(204), -char(255),char(215),char(0),char(255),char(0),char(206),char(255),char(215),char(0),char(255), -char(0),char(222),char(255),char(215),char(0),char(255),char(0),char(224),char(255),char(215), -char(0),char(255),char(0),char(226),char(255),char(215),char(0),char(255),char(0),char(228), -char(255),char(215),char(0),char(255),char(1),char(14),char(255),char(215),char(0),char(255), -char(1),char(16),char(255),char(215),char(0),char(255),char(1),char(18),char(255),char(215), -char(0),char(255),char(1),char(20),char(255),char(215),char(0),char(255),char(1),char(36), -char(255),char(215),char(0),char(255),char(1),char(38),char(255),char(215),char(0),char(255), -char(1),char(42),char(255),char(236),char(0),char(255),char(1),char(44),char(255),char(236), -char(0),char(255),char(1),char(46),char(255),char(236),char(0),char(255),char(1),char(48), -char(255),char(236),char(0),char(255),char(1),char(50),char(255),char(236),char(0),char(255), -char(1),char(52),char(255),char(236),char(0),char(255),char(1),char(54),char(255),char(215), -char(0),char(255),char(1),char(56),char(255),char(195),char(0),char(255),char(1),char(58), -char(255),char(195),char(0),char(255),char(1),char(71),char(255),char(215),char(0),char(255), -char(1),char(250),char(255),char(215),char(0),char(255),char(1),char(252),char(255),char(215), -char(0),char(255),char(1),char(254),char(255),char(215),char(0),char(255),char(2),char(0), -char(255),char(195),char(0),char(255),char(2),char(7),char(255),char(92),char(0),char(255), -char(2),char(11),char(255),char(92),char(0),char(255),char(2),char(95),char(255),char(215), -char(0),char(255),char(2),char(97),char(255),char(236),char(0),char(255),char(3),char(73), -char(255),char(215),char(0),char(255),char(3),char(75),char(255),char(215),char(0),char(255), -char(3),char(77),char(255),char(215),char(0),char(255),char(3),char(79),char(255),char(215), -char(0),char(255),char(3),char(81),char(255),char(215),char(0),char(255),char(3),char(83), -char(255),char(215),char(0),char(255),char(3),char(85),char(255),char(215),char(0),char(255), -char(3),char(87),char(255),char(215),char(0),char(255),char(3),char(89),char(255),char(215), -char(0),char(255),char(3),char(91),char(255),char(215),char(0),char(255),char(3),char(93), -char(255),char(215),char(0),char(255),char(3),char(95),char(255),char(215),char(0),char(255), -char(3),char(97),char(255),char(236),char(0),char(255),char(3),char(99),char(255),char(236), -char(0),char(255),char(3),char(101),char(255),char(236),char(0),char(255),char(3),char(103), -char(255),char(236),char(0),char(255),char(3),char(105),char(255),char(236),char(0),char(255), -char(3),char(107),char(255),char(236),char(0),char(255),char(3),char(109),char(255),char(236), -char(0),char(255),char(3),char(111),char(255),char(195),char(0),char(255),char(3),char(113), -char(255),char(195),char(0),char(255),char(3),char(115),char(255),char(195),char(0),char(255), -char(3),char(143),char(255),char(215),char(1),char(0),char(0),char(5),char(0),char(82), -char(1),char(0),char(0),char(10),char(0),char(82),char(1),char(0),char(0),char(12), -char(0),char(143),char(1),char(0),char(0),char(34),char(0),char(143),char(1),char(0), -char(0),char(64),char(0),char(143),char(1),char(0),char(0),char(69),char(0),char(61), -char(1),char(0),char(0),char(75),char(0),char(61),char(1),char(0),char(0),char(78), -char(0),char(61),char(1),char(0),char(0),char(79),char(0),char(61),char(1),char(0), -char(0),char(96),char(0),char(143),char(1),char(0),char(0),char(231),char(0),char(61), -char(1),char(0),char(0),char(233),char(0),char(143),char(1),char(0),char(2),char(7), -char(0),char(82),char(1),char(0),char(2),char(11),char(0),char(82),char(1),char(1), -char(0),char(5),char(255),char(92),char(1),char(1),char(0),char(10),char(255),char(92), -char(1),char(1),char(0),char(38),char(255),char(215),char(1),char(1),char(0),char(42), -char(255),char(215),char(1),char(1),char(0),char(50),char(255),char(215),char(1),char(1), -char(0),char(52),char(255),char(215),char(1),char(1),char(0),char(55),char(255),char(215), -char(1),char(1),char(0),char(56),char(255),char(236),char(1),char(1),char(0),char(57), -char(255),char(215),char(1),char(1),char(0),char(58),char(255),char(215),char(1),char(1), -char(0),char(60),char(255),char(195),char(1),char(1),char(0),char(137),char(255),char(215), -char(1),char(1),char(0),char(148),char(255),char(215),char(1),char(1),char(0),char(149), -char(255),char(215),char(1),char(1),char(0),char(150),char(255),char(215),char(1),char(1), -char(0),char(151),char(255),char(215),char(1),char(1),char(0),char(152),char(255),char(215), -char(1),char(1),char(0),char(154),char(255),char(215),char(1),char(1),char(0),char(155), -char(255),char(236),char(1),char(1),char(0),char(156),char(255),char(236),char(1),char(1), -char(0),char(157),char(255),char(236),char(1),char(1),char(0),char(158),char(255),char(236), -char(1),char(1),char(0),char(159),char(255),char(195),char(1),char(1),char(0),char(200), -char(255),char(215),char(1),char(1),char(0),char(202),char(255),char(215),char(1),char(1), -char(0),char(204),char(255),char(215),char(1),char(1),char(0),char(206),char(255),char(215), -char(1),char(1),char(0),char(222),char(255),char(215),char(1),char(1),char(0),char(224), -char(255),char(215),char(1),char(1),char(0),char(226),char(255),char(215),char(1),char(1), -char(0),char(228),char(255),char(215),char(1),char(1),char(1),char(14),char(255),char(215), -char(1),char(1),char(1),char(16),char(255),char(215),char(1),char(1),char(1),char(18), -char(255),char(215),char(1),char(1),char(1),char(20),char(255),char(215),char(1),char(1), -char(1),char(36),char(255),char(215),char(1),char(1),char(1),char(38),char(255),char(215), -char(1),char(1),char(1),char(42),char(255),char(236),char(1),char(1),char(1),char(44), -char(255),char(236),char(1),char(1),char(1),char(46),char(255),char(236),char(1),char(1), -char(1),char(48),char(255),char(236),char(1),char(1),char(1),char(50),char(255),char(236), -char(1),char(1),char(1),char(52),char(255),char(236),char(1),char(1),char(1),char(54), -char(255),char(215),char(1),char(1),char(1),char(56),char(255),char(195),char(1),char(1), -char(1),char(58),char(255),char(195),char(1),char(1),char(1),char(71),char(255),char(215), -char(1),char(1),char(1),char(250),char(255),char(215),char(1),char(1),char(1),char(252), -char(255),char(215),char(1),char(1),char(1),char(254),char(255),char(215),char(1),char(1), -char(2),char(0),char(255),char(195),char(1),char(1),char(2),char(7),char(255),char(92), -char(1),char(1),char(2),char(11),char(255),char(92),char(1),char(1),char(2),char(95), -char(255),char(215),char(1),char(1),char(2),char(97),char(255),char(236),char(1),char(1), -char(3),char(73),char(255),char(215),char(1),char(1),char(3),char(75),char(255),char(215), -char(1),char(1),char(3),char(77),char(255),char(215),char(1),char(1),char(3),char(79), -char(255),char(215),char(1),char(1),char(3),char(81),char(255),char(215),char(1),char(1), -char(3),char(83),char(255),char(215),char(1),char(1),char(3),char(85),char(255),char(215), -char(1),char(1),char(3),char(87),char(255),char(215),char(1),char(1),char(3),char(89), -char(255),char(215),char(1),char(1),char(3),char(91),char(255),char(215),char(1),char(1), -char(3),char(93),char(255),char(215),char(1),char(1),char(3),char(95),char(255),char(215), -char(1),char(1),char(3),char(97),char(255),char(236),char(1),char(1),char(3),char(99), -char(255),char(236),char(1),char(1),char(3),char(101),char(255),char(236),char(1),char(1), -char(3),char(103),char(255),char(236),char(1),char(1),char(3),char(105),char(255),char(236), -char(1),char(1),char(3),char(107),char(255),char(236),char(1),char(1),char(3),char(109), -char(255),char(236),char(1),char(1),char(3),char(111),char(255),char(195),char(1),char(1), -char(3),char(113),char(255),char(195),char(1),char(1),char(3),char(115),char(255),char(195), -char(1),char(1),char(3),char(143),char(255),char(215),char(1),char(3),char(0),char(5), -char(255),char(92),char(1),char(3),char(0),char(10),char(255),char(92),char(1),char(3), -char(0),char(38),char(255),char(215),char(1),char(3),char(0),char(42),char(255),char(215), -char(1),char(3),char(0),char(50),char(255),char(215),char(1),char(3),char(0),char(52), -char(255),char(215),char(1),char(3),char(0),char(55),char(255),char(215),char(1),char(3), -char(0),char(56),char(255),char(236),char(1),char(3),char(0),char(57),char(255),char(215), -char(1),char(3),char(0),char(58),char(255),char(215),char(1),char(3),char(0),char(60), -char(255),char(195),char(1),char(3),char(0),char(137),char(255),char(215),char(1),char(3), -char(0),char(148),char(255),char(215),char(1),char(3),char(0),char(149),char(255),char(215), -char(1),char(3),char(0),char(150),char(255),char(215),char(1),char(3),char(0),char(151), -char(255),char(215),char(1),char(3),char(0),char(152),char(255),char(215),char(1),char(3), -char(0),char(154),char(255),char(215),char(1),char(3),char(0),char(155),char(255),char(236), -char(1),char(3),char(0),char(156),char(255),char(236),char(1),char(3),char(0),char(157), -char(255),char(236),char(1),char(3),char(0),char(158),char(255),char(236),char(1),char(3), -char(0),char(159),char(255),char(195),char(1),char(3),char(0),char(200),char(255),char(215), -char(1),char(3),char(0),char(202),char(255),char(215),char(1),char(3),char(0),char(204), -char(255),char(215),char(1),char(3),char(0),char(206),char(255),char(215),char(1),char(3), -char(0),char(222),char(255),char(215),char(1),char(3),char(0),char(224),char(255),char(215), -char(1),char(3),char(0),char(226),char(255),char(215),char(1),char(3),char(0),char(228), -char(255),char(215),char(1),char(3),char(1),char(14),char(255),char(215),char(1),char(3), -char(1),char(16),char(255),char(215),char(1),char(3),char(1),char(18),char(255),char(215), -char(1),char(3),char(1),char(20),char(255),char(215),char(1),char(3),char(1),char(36), -char(255),char(215),char(1),char(3),char(1),char(38),char(255),char(215),char(1),char(3), -char(1),char(42),char(255),char(236),char(1),char(3),char(1),char(44),char(255),char(236), -char(1),char(3),char(1),char(46),char(255),char(236),char(1),char(3),char(1),char(48), -char(255),char(236),char(1),char(3),char(1),char(50),char(255),char(236),char(1),char(3), -char(1),char(52),char(255),char(236),char(1),char(3),char(1),char(54),char(255),char(215), -char(1),char(3),char(1),char(56),char(255),char(195),char(1),char(3),char(1),char(58), -char(255),char(195),char(1),char(3),char(1),char(71),char(255),char(215),char(1),char(3), -char(1),char(250),char(255),char(215),char(1),char(3),char(1),char(252),char(255),char(215), -char(1),char(3),char(1),char(254),char(255),char(215),char(1),char(3),char(2),char(0), -char(255),char(195),char(1),char(3),char(2),char(7),char(255),char(92),char(1),char(3), -char(2),char(11),char(255),char(92),char(1),char(3),char(2),char(95),char(255),char(215), -char(1),char(3),char(2),char(97),char(255),char(236),char(1),char(3),char(3),char(73), -char(255),char(215),char(1),char(3),char(3),char(75),char(255),char(215),char(1),char(3), -char(3),char(77),char(255),char(215),char(1),char(3),char(3),char(79),char(255),char(215), -char(1),char(3),char(3),char(81),char(255),char(215),char(1),char(3),char(3),char(83), -char(255),char(215),char(1),char(3),char(3),char(85),char(255),char(215),char(1),char(3), -char(3),char(87),char(255),char(215),char(1),char(3),char(3),char(89),char(255),char(215), -char(1),char(3),char(3),char(91),char(255),char(215),char(1),char(3),char(3),char(93), -char(255),char(215),char(1),char(3),char(3),char(95),char(255),char(215),char(1),char(3), -char(3),char(97),char(255),char(236),char(1),char(3),char(3),char(99),char(255),char(236), -char(1),char(3),char(3),char(101),char(255),char(236),char(1),char(3),char(3),char(103), -char(255),char(236),char(1),char(3),char(3),char(105),char(255),char(236),char(1),char(3), -char(3),char(107),char(255),char(236),char(1),char(3),char(3),char(109),char(255),char(236), -char(1),char(3),char(3),char(111),char(255),char(195),char(1),char(3),char(3),char(113), -char(255),char(195),char(1),char(3),char(3),char(115),char(255),char(195),char(1),char(3), -char(3),char(143),char(255),char(215),char(1),char(8),char(0),char(5),char(255),char(236), -char(1),char(8),char(0),char(10),char(255),char(236),char(1),char(8),char(2),char(7), -char(255),char(236),char(1),char(8),char(2),char(11),char(255),char(236),char(1),char(14), -char(0),char(15),char(255),char(174),char(1),char(14),char(0),char(17),char(255),char(174), -char(1),char(14),char(0),char(36),char(255),char(215),char(1),char(14),char(0),char(55), -char(255),char(195),char(1),char(14),char(0),char(57),char(255),char(236),char(1),char(14), -char(0),char(58),char(255),char(236),char(1),char(14),char(0),char(59),char(255),char(215), -char(1),char(14),char(0),char(60),char(255),char(236),char(1),char(14),char(0),char(61), -char(255),char(236),char(1),char(14),char(0),char(130),char(255),char(215),char(1),char(14), -char(0),char(131),char(255),char(215),char(1),char(14),char(0),char(132),char(255),char(215), -char(1),char(14),char(0),char(133),char(255),char(215),char(1),char(14),char(0),char(134), -char(255),char(215),char(1),char(14),char(0),char(135),char(255),char(215),char(1),char(14), -char(0),char(159),char(255),char(236),char(1),char(14),char(0),char(194),char(255),char(215), -char(1),char(14),char(0),char(196),char(255),char(215),char(1),char(14),char(0),char(198), -char(255),char(215),char(1),char(14),char(1),char(36),char(255),char(195),char(1),char(14), -char(1),char(38),char(255),char(195),char(1),char(14),char(1),char(54),char(255),char(236), -char(1),char(14),char(1),char(56),char(255),char(236),char(1),char(14),char(1),char(58), -char(255),char(236),char(1),char(14),char(1),char(59),char(255),char(236),char(1),char(14), -char(1),char(61),char(255),char(236),char(1),char(14),char(1),char(63),char(255),char(236), -char(1),char(14),char(1),char(67),char(255),char(215),char(1),char(14),char(1),char(160), -char(255),char(236),char(1),char(14),char(1),char(250),char(255),char(236),char(1),char(14), -char(1),char(252),char(255),char(236),char(1),char(14),char(1),char(254),char(255),char(236), -char(1),char(14),char(2),char(0),char(255),char(236),char(1),char(14),char(2),char(8), -char(255),char(174),char(1),char(14),char(2),char(12),char(255),char(174),char(1),char(14), -char(2),char(88),char(255),char(215),char(1),char(14),char(3),char(29),char(255),char(215), -char(1),char(14),char(3),char(31),char(255),char(215),char(1),char(14),char(3),char(33), -char(255),char(215),char(1),char(14),char(3),char(35),char(255),char(215),char(1),char(14), -char(3),char(37),char(255),char(215),char(1),char(14),char(3),char(39),char(255),char(215), -char(1),char(14),char(3),char(41),char(255),char(215),char(1),char(14),char(3),char(43), -char(255),char(215),char(1),char(14),char(3),char(45),char(255),char(215),char(1),char(14), -char(3),char(47),char(255),char(215),char(1),char(14),char(3),char(49),char(255),char(215), -char(1),char(14),char(3),char(51),char(255),char(215),char(1),char(14),char(3),char(111), -char(255),char(236),char(1),char(14),char(3),char(113),char(255),char(236),char(1),char(14), -char(3),char(115),char(255),char(236),char(1),char(14),char(3),char(143),char(255),char(195), -char(1),char(16),char(0),char(15),char(255),char(174),char(1),char(16),char(0),char(17), -char(255),char(174),char(1),char(16),char(0),char(36),char(255),char(215),char(1),char(16), -char(0),char(55),char(255),char(195),char(1),char(16),char(0),char(57),char(255),char(236), -char(1),char(16),char(0),char(58),char(255),char(236),char(1),char(16),char(0),char(59), -char(255),char(215),char(1),char(16),char(0),char(60),char(255),char(236),char(1),char(16), -char(0),char(61),char(255),char(236),char(1),char(16),char(0),char(130),char(255),char(215), -char(1),char(16),char(0),char(131),char(255),char(215),char(1),char(16),char(0),char(132), -char(255),char(215),char(1),char(16),char(0),char(133),char(255),char(215),char(1),char(16), -char(0),char(134),char(255),char(215),char(1),char(16),char(0),char(135),char(255),char(215), -char(1),char(16),char(0),char(159),char(255),char(236),char(1),char(16),char(0),char(194), -char(255),char(215),char(1),char(16),char(0),char(196),char(255),char(215),char(1),char(16), -char(0),char(198),char(255),char(215),char(1),char(16),char(1),char(36),char(255),char(195), -char(1),char(16),char(1),char(38),char(255),char(195),char(1),char(16),char(1),char(54), -char(255),char(236),char(1),char(16),char(1),char(56),char(255),char(236),char(1),char(16), -char(1),char(58),char(255),char(236),char(1),char(16),char(1),char(59),char(255),char(236), -char(1),char(16),char(1),char(61),char(255),char(236),char(1),char(16),char(1),char(63), -char(255),char(236),char(1),char(16),char(1),char(67),char(255),char(215),char(1),char(16), -char(1),char(160),char(255),char(236),char(1),char(16),char(1),char(250),char(255),char(236), -char(1),char(16),char(1),char(252),char(255),char(236),char(1),char(16),char(1),char(254), -char(255),char(236),char(1),char(16),char(2),char(0),char(255),char(236),char(1),char(16), -char(2),char(8),char(255),char(174),char(1),char(16),char(2),char(12),char(255),char(174), -char(1),char(16),char(2),char(88),char(255),char(215),char(1),char(16),char(3),char(29), -char(255),char(215),char(1),char(16),char(3),char(31),char(255),char(215),char(1),char(16), -char(3),char(33),char(255),char(215),char(1),char(16),char(3),char(35),char(255),char(215), -char(1),char(16),char(3),char(37),char(255),char(215),char(1),char(16),char(3),char(39), -char(255),char(215),char(1),char(16),char(3),char(41),char(255),char(215),char(1),char(16), -char(3),char(43),char(255),char(215),char(1),char(16),char(3),char(45),char(255),char(215), -char(1),char(16),char(3),char(47),char(255),char(215),char(1),char(16),char(3),char(49), -char(255),char(215),char(1),char(16),char(3),char(51),char(255),char(215),char(1),char(16), -char(3),char(111),char(255),char(236),char(1),char(16),char(3),char(113),char(255),char(236), -char(1),char(16),char(3),char(115),char(255),char(236),char(1),char(16),char(3),char(143), -char(255),char(195),char(1),char(18),char(0),char(15),char(255),char(174),char(1),char(18), -char(0),char(17),char(255),char(174),char(1),char(18),char(0),char(36),char(255),char(215), -char(1),char(18),char(0),char(55),char(255),char(195),char(1),char(18),char(0),char(57), -char(255),char(236),char(1),char(18),char(0),char(58),char(255),char(236),char(1),char(18), -char(0),char(59),char(255),char(215),char(1),char(18),char(0),char(60),char(255),char(236), -char(1),char(18),char(0),char(61),char(255),char(236),char(1),char(18),char(0),char(130), -char(255),char(215),char(1),char(18),char(0),char(131),char(255),char(215),char(1),char(18), -char(0),char(132),char(255),char(215),char(1),char(18),char(0),char(133),char(255),char(215), -char(1),char(18),char(0),char(134),char(255),char(215),char(1),char(18),char(0),char(135), -char(255),char(215),char(1),char(18),char(0),char(159),char(255),char(236),char(1),char(18), -char(0),char(194),char(255),char(215),char(1),char(18),char(0),char(196),char(255),char(215), -char(1),char(18),char(0),char(198),char(255),char(215),char(1),char(18),char(1),char(36), -char(255),char(195),char(1),char(18),char(1),char(38),char(255),char(195),char(1),char(18), -char(1),char(54),char(255),char(236),char(1),char(18),char(1),char(56),char(255),char(236), -char(1),char(18),char(1),char(58),char(255),char(236),char(1),char(18),char(1),char(59), -char(255),char(236),char(1),char(18),char(1),char(61),char(255),char(236),char(1),char(18), -char(1),char(63),char(255),char(236),char(1),char(18),char(1),char(67),char(255),char(215), -char(1),char(18),char(1),char(160),char(255),char(236),char(1),char(18),char(1),char(250), -char(255),char(236),char(1),char(18),char(1),char(252),char(255),char(236),char(1),char(18), -char(1),char(254),char(255),char(236),char(1),char(18),char(2),char(0),char(255),char(236), -char(1),char(18),char(2),char(8),char(255),char(174),char(1),char(18),char(2),char(12), -char(255),char(174),char(1),char(18),char(2),char(88),char(255),char(215),char(1),char(18), -char(3),char(29),char(255),char(215),char(1),char(18),char(3),char(31),char(255),char(215), -char(1),char(18),char(3),char(33),char(255),char(215),char(1),char(18),char(3),char(35), -char(255),char(215),char(1),char(18),char(3),char(37),char(255),char(215),char(1),char(18), -char(3),char(39),char(255),char(215),char(1),char(18),char(3),char(41),char(255),char(215), -char(1),char(18),char(3),char(43),char(255),char(215),char(1),char(18),char(3),char(45), -char(255),char(215),char(1),char(18),char(3),char(47),char(255),char(215),char(1),char(18), -char(3),char(49),char(255),char(215),char(1),char(18),char(3),char(51),char(255),char(215), -char(1),char(18),char(3),char(111),char(255),char(236),char(1),char(18),char(3),char(113), -char(255),char(236),char(1),char(18),char(3),char(115),char(255),char(236),char(1),char(18), -char(3),char(143),char(255),char(195),char(1),char(20),char(0),char(45),char(0),char(123), -char(1),char(23),char(0),char(5),char(0),char(82),char(1),char(23),char(0),char(10), -char(0),char(82),char(1),char(23),char(0),char(68),char(255),char(215),char(1),char(23), -char(0),char(70),char(255),char(215),char(1),char(23),char(0),char(71),char(255),char(215), -char(1),char(23),char(0),char(72),char(255),char(215),char(1),char(23),char(0),char(74), -char(255),char(236),char(1),char(23),char(0),char(82),char(255),char(215),char(1),char(23), -char(0),char(84),char(255),char(215),char(1),char(23),char(0),char(162),char(255),char(215), -char(1),char(23),char(0),char(163),char(255),char(215),char(1),char(23),char(0),char(164), -char(255),char(215),char(1),char(23),char(0),char(165),char(255),char(215),char(1),char(23), -char(0),char(166),char(255),char(215),char(1),char(23),char(0),char(167),char(255),char(215), -char(1),char(23),char(0),char(168),char(255),char(215),char(1),char(23),char(0),char(169), -char(255),char(215),char(1),char(23),char(0),char(170),char(255),char(215),char(1),char(23), -char(0),char(171),char(255),char(215),char(1),char(23),char(0),char(172),char(255),char(215), -char(1),char(23),char(0),char(173),char(255),char(215),char(1),char(23),char(0),char(180), -char(255),char(215),char(1),char(23),char(0),char(181),char(255),char(215),char(1),char(23), -char(0),char(182),char(255),char(215),char(1),char(23),char(0),char(183),char(255),char(215), -char(1),char(23),char(0),char(184),char(255),char(215),char(1),char(23),char(0),char(186), -char(255),char(215),char(1),char(23),char(0),char(195),char(255),char(215),char(1),char(23), -char(0),char(197),char(255),char(215),char(1),char(23),char(0),char(199),char(255),char(215), -char(1),char(23),char(0),char(201),char(255),char(215),char(1),char(23),char(0),char(203), -char(255),char(215),char(1),char(23),char(0),char(205),char(255),char(215),char(1),char(23), -char(0),char(207),char(255),char(215),char(1),char(23),char(0),char(209),char(255),char(215), -char(1),char(23),char(0),char(211),char(255),char(215),char(1),char(23),char(0),char(213), -char(255),char(215),char(1),char(23),char(0),char(215),char(255),char(215),char(1),char(23), -char(0),char(217),char(255),char(215),char(1),char(23),char(0),char(219),char(255),char(215), -char(1),char(23),char(0),char(221),char(255),char(215),char(1),char(23),char(0),char(223), -char(255),char(236),char(1),char(23),char(0),char(225),char(255),char(236),char(1),char(23), -char(0),char(227),char(255),char(236),char(1),char(23),char(0),char(229),char(255),char(236), -char(1),char(23),char(1),char(15),char(255),char(215),char(1),char(23),char(1),char(17), -char(255),char(215),char(1),char(23),char(1),char(19),char(255),char(215),char(1),char(23), -char(1),char(21),char(255),char(215),char(1),char(23),char(1),char(68),char(255),char(215), -char(1),char(23),char(1),char(70),char(255),char(215),char(1),char(23),char(1),char(72), -char(255),char(215),char(1),char(23),char(2),char(7),char(0),char(82),char(1),char(23), -char(2),char(11),char(0),char(82),char(1),char(23),char(2),char(89),char(255),char(215), -char(1),char(23),char(2),char(96),char(255),char(215),char(1),char(23),char(3),char(30), -char(255),char(215),char(1),char(23),char(3),char(32),char(255),char(215),char(1),char(23), -char(3),char(34),char(255),char(215),char(1),char(23),char(3),char(38),char(255),char(215), -char(1),char(23),char(3),char(40),char(255),char(215),char(1),char(23),char(3),char(42), -char(255),char(215),char(1),char(23),char(3),char(44),char(255),char(215),char(1),char(23), -char(3),char(46),char(255),char(215),char(1),char(23),char(3),char(48),char(255),char(215), -char(1),char(23),char(3),char(50),char(255),char(215),char(1),char(23),char(3),char(52), -char(255),char(215),char(1),char(23),char(3),char(54),char(255),char(215),char(1),char(23), -char(3),char(56),char(255),char(215),char(1),char(23),char(3),char(58),char(255),char(215), -char(1),char(23),char(3),char(60),char(255),char(215),char(1),char(23),char(3),char(64), -char(255),char(215),char(1),char(23),char(3),char(66),char(255),char(215),char(1),char(23), -char(3),char(68),char(255),char(215),char(1),char(23),char(3),char(74),char(255),char(215), -char(1),char(23),char(3),char(76),char(255),char(215),char(1),char(23),char(3),char(78), -char(255),char(215),char(1),char(23),char(3),char(82),char(255),char(215),char(1),char(23), -char(3),char(84),char(255),char(215),char(1),char(23),char(3),char(86),char(255),char(215), -char(1),char(23),char(3),char(88),char(255),char(215),char(1),char(23),char(3),char(90), -char(255),char(215),char(1),char(23),char(3),char(92),char(255),char(215),char(1),char(23), -char(3),char(94),char(255),char(215),char(1),char(23),char(3),char(96),char(255),char(215), -char(1),char(25),char(0),char(5),char(0),char(82),char(1),char(25),char(0),char(10), -char(0),char(82),char(1),char(25),char(0),char(68),char(255),char(215),char(1),char(25), -char(0),char(70),char(255),char(215),char(1),char(25),char(0),char(71),char(255),char(215), -char(1),char(25),char(0),char(72),char(255),char(215),char(1),char(25),char(0),char(74), -char(255),char(236),char(1),char(25),char(0),char(82),char(255),char(215),char(1),char(25), -char(0),char(84),char(255),char(215),char(1),char(25),char(0),char(162),char(255),char(215), -char(1),char(25),char(0),char(163),char(255),char(215),char(1),char(25),char(0),char(164), -char(255),char(215),char(1),char(25),char(0),char(165),char(255),char(215),char(1),char(25), -char(0),char(166),char(255),char(215),char(1),char(25),char(0),char(167),char(255),char(215), -char(1),char(25),char(0),char(168),char(255),char(215),char(1),char(25),char(0),char(169), -char(255),char(215),char(1),char(25),char(0),char(170),char(255),char(215),char(1),char(25), -char(0),char(171),char(255),char(215),char(1),char(25),char(0),char(172),char(255),char(215), -char(1),char(25),char(0),char(173),char(255),char(215),char(1),char(25),char(0),char(180), -char(255),char(215),char(1),char(25),char(0),char(181),char(255),char(215),char(1),char(25), -char(0),char(182),char(255),char(215),char(1),char(25),char(0),char(183),char(255),char(215), -char(1),char(25),char(0),char(184),char(255),char(215),char(1),char(25),char(0),char(186), -char(255),char(215),char(1),char(25),char(0),char(195),char(255),char(215),char(1),char(25), -char(0),char(197),char(255),char(215),char(1),char(25),char(0),char(199),char(255),char(215), -char(1),char(25),char(0),char(201),char(255),char(215),char(1),char(25),char(0),char(203), -char(255),char(215),char(1),char(25),char(0),char(205),char(255),char(215),char(1),char(25), -char(0),char(207),char(255),char(215),char(1),char(25),char(0),char(209),char(255),char(215), -char(1),char(25),char(0),char(211),char(255),char(215),char(1),char(25),char(0),char(213), -char(255),char(215),char(1),char(25),char(0),char(215),char(255),char(215),char(1),char(25), -char(0),char(217),char(255),char(215),char(1),char(25),char(0),char(219),char(255),char(215), -char(1),char(25),char(0),char(221),char(255),char(215),char(1),char(25),char(0),char(223), -char(255),char(236),char(1),char(25),char(0),char(225),char(255),char(236),char(1),char(25), -char(0),char(227),char(255),char(236),char(1),char(25),char(0),char(229),char(255),char(236), -char(1),char(25),char(1),char(15),char(255),char(215),char(1),char(25),char(1),char(17), -char(255),char(215),char(1),char(25),char(1),char(19),char(255),char(215),char(1),char(25), -char(1),char(21),char(255),char(215),char(1),char(25),char(1),char(68),char(255),char(215), -char(1),char(25),char(1),char(70),char(255),char(215),char(1),char(25),char(1),char(72), -char(255),char(215),char(1),char(25),char(2),char(7),char(0),char(82),char(1),char(25), -char(2),char(11),char(0),char(82),char(1),char(25),char(2),char(89),char(255),char(215), -char(1),char(25),char(2),char(96),char(255),char(215),char(1),char(25),char(3),char(30), -char(255),char(215),char(1),char(25),char(3),char(32),char(255),char(215),char(1),char(25), -char(3),char(34),char(255),char(215),char(1),char(25),char(3),char(38),char(255),char(215), -char(1),char(25),char(3),char(40),char(255),char(215),char(1),char(25),char(3),char(42), -char(255),char(215),char(1),char(25),char(3),char(44),char(255),char(215),char(1),char(25), -char(3),char(46),char(255),char(215),char(1),char(25),char(3),char(48),char(255),char(215), -char(1),char(25),char(3),char(50),char(255),char(215),char(1),char(25),char(3),char(52), -char(255),char(215),char(1),char(25),char(3),char(54),char(255),char(215),char(1),char(25), -char(3),char(56),char(255),char(215),char(1),char(25),char(3),char(58),char(255),char(215), -char(1),char(25),char(3),char(60),char(255),char(215),char(1),char(25),char(3),char(64), -char(255),char(215),char(1),char(25),char(3),char(66),char(255),char(215),char(1),char(25), -char(3),char(68),char(255),char(215),char(1),char(25),char(3),char(74),char(255),char(215), -char(1),char(25),char(3),char(76),char(255),char(215),char(1),char(25),char(3),char(78), -char(255),char(215),char(1),char(25),char(3),char(82),char(255),char(215),char(1),char(25), -char(3),char(84),char(255),char(215),char(1),char(25),char(3),char(86),char(255),char(215), -char(1),char(25),char(3),char(88),char(255),char(215),char(1),char(25),char(3),char(90), -char(255),char(215),char(1),char(25),char(3),char(92),char(255),char(215),char(1),char(25), -char(3),char(94),char(255),char(215),char(1),char(25),char(3),char(96),char(255),char(215), -char(1),char(27),char(0),char(5),char(0),char(82),char(1),char(27),char(0),char(10), -char(0),char(82),char(1),char(27),char(0),char(68),char(255),char(215),char(1),char(27), -char(0),char(70),char(255),char(215),char(1),char(27),char(0),char(71),char(255),char(215), -char(1),char(27),char(0),char(72),char(255),char(215),char(1),char(27),char(0),char(74), -char(255),char(236),char(1),char(27),char(0),char(82),char(255),char(215),char(1),char(27), -char(0),char(84),char(255),char(215),char(1),char(27),char(0),char(162),char(255),char(215), -char(1),char(27),char(0),char(163),char(255),char(215),char(1),char(27),char(0),char(164), -char(255),char(215),char(1),char(27),char(0),char(165),char(255),char(215),char(1),char(27), -char(0),char(166),char(255),char(215),char(1),char(27),char(0),char(167),char(255),char(215), -char(1),char(27),char(0),char(168),char(255),char(215),char(1),char(27),char(0),char(169), -char(255),char(215),char(1),char(27),char(0),char(170),char(255),char(215),char(1),char(27), -char(0),char(171),char(255),char(215),char(1),char(27),char(0),char(172),char(255),char(215), -char(1),char(27),char(0),char(173),char(255),char(215),char(1),char(27),char(0),char(180), -char(255),char(215),char(1),char(27),char(0),char(181),char(255),char(215),char(1),char(27), -char(0),char(182),char(255),char(215),char(1),char(27),char(0),char(183),char(255),char(215), -char(1),char(27),char(0),char(184),char(255),char(215),char(1),char(27),char(0),char(186), -char(255),char(215),char(1),char(27),char(0),char(195),char(255),char(215),char(1),char(27), -char(0),char(197),char(255),char(215),char(1),char(27),char(0),char(199),char(255),char(215), -char(1),char(27),char(0),char(201),char(255),char(215),char(1),char(27),char(0),char(203), -char(255),char(215),char(1),char(27),char(0),char(205),char(255),char(215),char(1),char(27), -char(0),char(207),char(255),char(215),char(1),char(27),char(0),char(209),char(255),char(215), -char(1),char(27),char(0),char(211),char(255),char(215),char(1),char(27),char(0),char(213), -char(255),char(215),char(1),char(27),char(0),char(215),char(255),char(215),char(1),char(27), -char(0),char(217),char(255),char(215),char(1),char(27),char(0),char(219),char(255),char(215), -char(1),char(27),char(0),char(221),char(255),char(215),char(1),char(27),char(0),char(223), -char(255),char(236),char(1),char(27),char(0),char(225),char(255),char(236),char(1),char(27), -char(0),char(227),char(255),char(236),char(1),char(27),char(0),char(229),char(255),char(236), -char(1),char(27),char(1),char(15),char(255),char(215),char(1),char(27),char(1),char(17), -char(255),char(215),char(1),char(27),char(1),char(19),char(255),char(215),char(1),char(27), -char(1),char(21),char(255),char(215),char(1),char(27),char(1),char(68),char(255),char(215), -char(1),char(27),char(1),char(70),char(255),char(215),char(1),char(27),char(1),char(72), -char(255),char(215),char(1),char(27),char(2),char(7),char(0),char(82),char(1),char(27), -char(2),char(11),char(0),char(82),char(1),char(27),char(2),char(89),char(255),char(215), -char(1),char(27),char(2),char(96),char(255),char(215),char(1),char(27),char(3),char(30), -char(255),char(215),char(1),char(27),char(3),char(32),char(255),char(215),char(1),char(27), -char(3),char(34),char(255),char(215),char(1),char(27),char(3),char(38),char(255),char(215), -char(1),char(27),char(3),char(40),char(255),char(215),char(1),char(27),char(3),char(42), -char(255),char(215),char(1),char(27),char(3),char(44),char(255),char(215),char(1),char(27), -char(3),char(46),char(255),char(215),char(1),char(27),char(3),char(48),char(255),char(215), -char(1),char(27),char(3),char(50),char(255),char(215),char(1),char(27),char(3),char(52), -char(255),char(215),char(1),char(27),char(3),char(54),char(255),char(215),char(1),char(27), -char(3),char(56),char(255),char(215),char(1),char(27),char(3),char(58),char(255),char(215), -char(1),char(27),char(3),char(60),char(255),char(215),char(1),char(27),char(3),char(64), -char(255),char(215),char(1),char(27),char(3),char(66),char(255),char(215),char(1),char(27), -char(3),char(68),char(255),char(215),char(1),char(27),char(3),char(74),char(255),char(215), -char(1),char(27),char(3),char(76),char(255),char(215),char(1),char(27),char(3),char(78), -char(255),char(215),char(1),char(27),char(3),char(82),char(255),char(215),char(1),char(27), -char(3),char(84),char(255),char(215),char(1),char(27),char(3),char(86),char(255),char(215), -char(1),char(27),char(3),char(88),char(255),char(215),char(1),char(27),char(3),char(90), -char(255),char(215),char(1),char(27),char(3),char(92),char(255),char(215),char(1),char(27), -char(3),char(94),char(255),char(215),char(1),char(27),char(3),char(96),char(255),char(215), -char(1),char(36),char(0),char(15),char(255),char(133),char(1),char(36),char(0),char(16), -char(255),char(174),char(1),char(36),char(0),char(17),char(255),char(133),char(1),char(36), -char(0),char(34),char(0),char(41),char(1),char(36),char(0),char(36),char(255),char(113), -char(1),char(36),char(0),char(38),char(255),char(215),char(1),char(36),char(0),char(42), -char(255),char(215),char(1),char(36),char(0),char(50),char(255),char(215),char(1),char(36), -char(0),char(52),char(255),char(215),char(1),char(36),char(0),char(55),char(0),char(41), -char(1),char(36),char(0),char(68),char(255),char(92),char(1),char(36),char(0),char(70), -char(255),char(113),char(1),char(36),char(0),char(71),char(255),char(113),char(1),char(36), -char(0),char(72),char(255),char(113),char(1),char(36),char(0),char(74),char(255),char(113), -char(1),char(36),char(0),char(80),char(255),char(154),char(1),char(36),char(0),char(81), -char(255),char(154),char(1),char(36),char(0),char(82),char(255),char(113),char(1),char(36), -char(0),char(83),char(255),char(154),char(1),char(36),char(0),char(84),char(255),char(113), -char(1),char(36),char(0),char(85),char(255),char(154),char(1),char(36),char(0),char(86), -char(255),char(133),char(1),char(36),char(0),char(88),char(255),char(154),char(1),char(36), -char(0),char(89),char(255),char(215),char(1),char(36),char(0),char(90),char(255),char(215), -char(1),char(36),char(0),char(91),char(255),char(215),char(1),char(36),char(0),char(92), -char(255),char(215),char(1),char(36),char(0),char(93),char(255),char(174),char(1),char(36), -char(0),char(130),char(255),char(113),char(1),char(36),char(0),char(131),char(255),char(113), -char(1),char(36),char(0),char(132),char(255),char(113),char(1),char(36),char(0),char(133), -char(255),char(113),char(1),char(36),char(0),char(134),char(255),char(113),char(1),char(36), -char(0),char(135),char(255),char(113),char(1),char(36),char(0),char(137),char(255),char(215), -char(1),char(36),char(0),char(148),char(255),char(215),char(1),char(36),char(0),char(149), -char(255),char(215),char(1),char(36),char(0),char(150),char(255),char(215),char(1),char(36), -char(0),char(151),char(255),char(215),char(1),char(36),char(0),char(152),char(255),char(215), -char(1),char(36),char(0),char(154),char(255),char(215),char(1),char(36),char(0),char(162), -char(255),char(113),char(1),char(36),char(0),char(163),char(255),char(92),char(1),char(36), -char(0),char(164),char(255),char(92),char(1),char(36),char(0),char(165),char(255),char(92), -char(1),char(36),char(0),char(166),char(255),char(92),char(1),char(36),char(0),char(167), -char(255),char(92),char(1),char(36),char(0),char(168),char(255),char(92),char(1),char(36), -char(0),char(169),char(255),char(113),char(1),char(36),char(0),char(170),char(255),char(113), -char(1),char(36),char(0),char(171),char(255),char(113),char(1),char(36),char(0),char(172), -char(255),char(113),char(1),char(36),char(0),char(173),char(255),char(113),char(1),char(36), -char(0),char(180),char(255),char(113),char(1),char(36),char(0),char(181),char(255),char(113), -char(1),char(36),char(0),char(182),char(255),char(113),char(1),char(36),char(0),char(183), -char(255),char(113),char(1),char(36),char(0),char(184),char(255),char(113),char(1),char(36), -char(0),char(186),char(255),char(113),char(1),char(36),char(0),char(187),char(255),char(154), -char(1),char(36),char(0),char(188),char(255),char(154),char(1),char(36),char(0),char(189), -char(255),char(154),char(1),char(36),char(0),char(190),char(255),char(154),char(1),char(36), -char(0),char(191),char(255),char(215),char(1),char(36),char(0),char(194),char(255),char(113), -char(1),char(36),char(0),char(195),char(255),char(92),char(1),char(36),char(0),char(196), -char(255),char(113),char(1),char(36),char(0),char(197),char(255),char(92),char(1),char(36), -char(0),char(198),char(255),char(113),char(1),char(36),char(0),char(199),char(255),char(92), -char(1),char(36),char(0),char(200),char(255),char(215),char(1),char(36),char(0),char(201), -char(255),char(113),char(1),char(36),char(0),char(202),char(255),char(215),char(1),char(36), -char(0),char(203),char(255),char(113),char(1),char(36),char(0),char(204),char(255),char(215), -char(1),char(36),char(0),char(205),char(255),char(113),char(1),char(36),char(0),char(206), -char(255),char(215),char(1),char(36),char(0),char(207),char(255),char(113),char(1),char(36), -char(0),char(209),char(255),char(113),char(1),char(36),char(0),char(211),char(255),char(113), -char(1),char(36),char(0),char(213),char(255),char(113),char(1),char(36),char(0),char(215), -char(255),char(113),char(1),char(36),char(0),char(217),char(255),char(113),char(1),char(36), -char(0),char(219),char(255),char(113),char(1),char(36),char(0),char(221),char(255),char(113), -char(1),char(36),char(0),char(222),char(255),char(215),char(1),char(36),char(0),char(223), -char(255),char(113),char(1),char(36),char(0),char(224),char(255),char(215),char(1),char(36), -char(0),char(225),char(255),char(113),char(1),char(36),char(0),char(226),char(255),char(215), -char(1),char(36),char(0),char(227),char(255),char(113),char(1),char(36),char(0),char(228), -char(255),char(215),char(1),char(36),char(0),char(229),char(255),char(113),char(1),char(36), -char(0),char(250),char(255),char(154),char(1),char(36),char(1),char(6),char(255),char(154), -char(1),char(36),char(1),char(8),char(255),char(154),char(1),char(36),char(1),char(13), -char(255),char(154),char(1),char(36),char(1),char(14),char(255),char(215),char(1),char(36), -char(1),char(15),char(255),char(113),char(1),char(36),char(1),char(16),char(255),char(215), -char(1),char(36),char(1),char(17),char(255),char(113),char(1),char(36),char(1),char(18), -char(255),char(215),char(1),char(36),char(1),char(19),char(255),char(113),char(1),char(36), -char(1),char(20),char(255),char(215),char(1),char(36),char(1),char(21),char(255),char(113), -char(1),char(36),char(1),char(23),char(255),char(154),char(1),char(36),char(1),char(25), -char(255),char(154),char(1),char(36),char(1),char(29),char(255),char(133),char(1),char(36), -char(1),char(33),char(255),char(133),char(1),char(36),char(1),char(36),char(0),char(41), -char(1),char(36),char(1),char(38),char(0),char(41),char(1),char(36),char(1),char(43), -char(255),char(154),char(1),char(36),char(1),char(45),char(255),char(154),char(1),char(36), -char(1),char(47),char(255),char(154),char(1),char(36),char(1),char(49),char(255),char(154), -char(1),char(36),char(1),char(51),char(255),char(154),char(1),char(36),char(1),char(53), -char(255),char(154),char(1),char(36),char(1),char(55),char(255),char(215),char(1),char(36), -char(1),char(60),char(255),char(174),char(1),char(36),char(1),char(62),char(255),char(174), -char(1),char(36),char(1),char(64),char(255),char(174),char(1),char(36),char(1),char(67), -char(255),char(113),char(1),char(36),char(1),char(68),char(255),char(92),char(1),char(36), -char(1),char(70),char(255),char(92),char(1),char(36),char(1),char(71),char(255),char(215), -char(1),char(36),char(1),char(72),char(255),char(113),char(1),char(36),char(1),char(74), -char(255),char(133),char(1),char(36),char(1),char(251),char(255),char(215),char(1),char(36), -char(1),char(253),char(255),char(215),char(1),char(36),char(2),char(2),char(255),char(174), -char(1),char(36),char(2),char(3),char(255),char(174),char(1),char(36),char(2),char(4), -char(255),char(174),char(1),char(36),char(2),char(8),char(255),char(133),char(1),char(36), -char(2),char(12),char(255),char(133),char(1),char(36),char(2),char(87),char(255),char(154), -char(1),char(36),char(2),char(88),char(255),char(113),char(1),char(36),char(2),char(89), -char(255),char(92),char(1),char(36),char(2),char(95),char(255),char(215),char(1),char(36), -char(2),char(96),char(255),char(113),char(1),char(36),char(2),char(98),char(255),char(154), -char(1),char(36),char(3),char(29),char(255),char(113),char(1),char(36),char(3),char(30), -char(255),char(92),char(1),char(36),char(3),char(31),char(255),char(113),char(1),char(36), -char(3),char(32),char(255),char(92),char(1),char(36),char(3),char(33),char(255),char(113), -char(1),char(36),char(3),char(34),char(255),char(92),char(1),char(36),char(3),char(35), -char(255),char(113),char(1),char(36),char(3),char(37),char(255),char(113),char(1),char(36), -char(3),char(38),char(255),char(92),char(1),char(36),char(3),char(39),char(255),char(113), -char(1),char(36),char(3),char(40),char(255),char(92),char(1),char(36),char(3),char(41), -char(255),char(113),char(1),char(36),char(3),char(42),char(255),char(92),char(1),char(36), -char(3),char(43),char(255),char(113),char(1),char(36),char(3),char(44),char(255),char(92), -char(1),char(36),char(3),char(45),char(255),char(113),char(1),char(36),char(3),char(46), -char(255),char(92),char(1),char(36),char(3),char(47),char(255),char(113),char(1),char(36), -char(3),char(48),char(255),char(92),char(1),char(36),char(3),char(49),char(255),char(113), -char(1),char(36),char(3),char(50),char(255),char(92),char(1),char(36),char(3),char(51), -char(255),char(113),char(1),char(36),char(3),char(52),char(255),char(92),char(1),char(36), -char(3),char(54),char(255),char(113),char(1),char(36),char(3),char(56),char(255),char(113), -char(1),char(36),char(3),char(58),char(255),char(113),char(1),char(36),char(3),char(60), -char(255),char(113),char(1),char(36),char(3),char(64),char(255),char(113),char(1),char(36), -char(3),char(66),char(255),char(113),char(1),char(36),char(3),char(68),char(255),char(113), -char(1),char(36),char(3),char(73),char(255),char(215),char(1),char(36),char(3),char(74), -char(255),char(113),char(1),char(36),char(3),char(75),char(255),char(215),char(1),char(36), -char(3),char(76),char(255),char(113),char(1),char(36),char(3),char(77),char(255),char(215), -char(1),char(36),char(3),char(78),char(255),char(113),char(1),char(36),char(3),char(79), -char(255),char(215),char(1),char(36),char(3),char(81),char(255),char(215),char(1),char(36), -char(3),char(82),char(255),char(113),char(1),char(36),char(3),char(83),char(255),char(215), -char(1),char(36),char(3),char(84),char(255),char(113),char(1),char(36),char(3),char(85), -char(255),char(215),char(1),char(36),char(3),char(86),char(255),char(113),char(1),char(36), -char(3),char(87),char(255),char(215),char(1),char(36),char(3),char(88),char(255),char(113), -char(1),char(36),char(3),char(89),char(255),char(215),char(1),char(36),char(3),char(90), -char(255),char(113),char(1),char(36),char(3),char(91),char(255),char(215),char(1),char(36), -char(3),char(92),char(255),char(113),char(1),char(36),char(3),char(93),char(255),char(215), -char(1),char(36),char(3),char(94),char(255),char(113),char(1),char(36),char(3),char(95), -char(255),char(215),char(1),char(36),char(3),char(96),char(255),char(113),char(1),char(36), -char(3),char(98),char(255),char(154),char(1),char(36),char(3),char(100),char(255),char(154), -char(1),char(36),char(3),char(102),char(255),char(154),char(1),char(36),char(3),char(104), -char(255),char(154),char(1),char(36),char(3),char(106),char(255),char(154),char(1),char(36), -char(3),char(108),char(255),char(154),char(1),char(36),char(3),char(110),char(255),char(154), -char(1),char(36),char(3),char(112),char(255),char(215),char(1),char(36),char(3),char(143), -char(0),char(41),char(1),char(37),char(0),char(5),char(0),char(41),char(1),char(37), -char(0),char(10),char(0),char(41),char(1),char(37),char(2),char(7),char(0),char(41), -char(1),char(37),char(2),char(11),char(0),char(41),char(1),char(38),char(0),char(15), -char(255),char(133),char(1),char(38),char(0),char(16),char(255),char(174),char(1),char(38), -char(0),char(17),char(255),char(133),char(1),char(38),char(0),char(34),char(0),char(41), -char(1),char(38),char(0),char(36),char(255),char(113),char(1),char(38),char(0),char(38), -char(255),char(215),char(1),char(38),char(0),char(42),char(255),char(215),char(1),char(38), -char(0),char(50),char(255),char(215),char(1),char(38),char(0),char(52),char(255),char(215), -char(1),char(38),char(0),char(55),char(0),char(41),char(1),char(38),char(0),char(68), -char(255),char(92),char(1),char(38),char(0),char(70),char(255),char(113),char(1),char(38), -char(0),char(71),char(255),char(113),char(1),char(38),char(0),char(72),char(255),char(113), -char(1),char(38),char(0),char(74),char(255),char(113),char(1),char(38),char(0),char(80), -char(255),char(154),char(1),char(38),char(0),char(81),char(255),char(154),char(1),char(38), -char(0),char(82),char(255),char(113),char(1),char(38),char(0),char(83),char(255),char(154), -char(1),char(38),char(0),char(84),char(255),char(113),char(1),char(38),char(0),char(85), -char(255),char(154),char(1),char(38),char(0),char(86),char(255),char(133),char(1),char(38), -char(0),char(88),char(255),char(154),char(1),char(38),char(0),char(89),char(255),char(215), -char(1),char(38),char(0),char(90),char(255),char(215),char(1),char(38),char(0),char(91), -char(255),char(215),char(1),char(38),char(0),char(92),char(255),char(215),char(1),char(38), -char(0),char(93),char(255),char(174),char(1),char(38),char(0),char(130),char(255),char(113), -char(1),char(38),char(0),char(131),char(255),char(113),char(1),char(38),char(0),char(132), -char(255),char(113),char(1),char(38),char(0),char(133),char(255),char(113),char(1),char(38), -char(0),char(134),char(255),char(113),char(1),char(38),char(0),char(135),char(255),char(113), -char(1),char(38),char(0),char(137),char(255),char(215),char(1),char(38),char(0),char(148), -char(255),char(215),char(1),char(38),char(0),char(149),char(255),char(215),char(1),char(38), -char(0),char(150),char(255),char(215),char(1),char(38),char(0),char(151),char(255),char(215), -char(1),char(38),char(0),char(152),char(255),char(215),char(1),char(38),char(0),char(154), -char(255),char(215),char(1),char(38),char(0),char(162),char(255),char(113),char(1),char(38), -char(0),char(163),char(255),char(92),char(1),char(38),char(0),char(164),char(255),char(92), -char(1),char(38),char(0),char(165),char(255),char(92),char(1),char(38),char(0),char(166), -char(255),char(92),char(1),char(38),char(0),char(167),char(255),char(92),char(1),char(38), -char(0),char(168),char(255),char(92),char(1),char(38),char(0),char(169),char(255),char(113), -char(1),char(38),char(0),char(170),char(255),char(113),char(1),char(38),char(0),char(171), -char(255),char(113),char(1),char(38),char(0),char(172),char(255),char(113),char(1),char(38), -char(0),char(173),char(255),char(113),char(1),char(38),char(0),char(180),char(255),char(113), -char(1),char(38),char(0),char(181),char(255),char(113),char(1),char(38),char(0),char(182), -char(255),char(113),char(1),char(38),char(0),char(183),char(255),char(113),char(1),char(38), -char(0),char(184),char(255),char(113),char(1),char(38),char(0),char(186),char(255),char(113), -char(1),char(38),char(0),char(187),char(255),char(154),char(1),char(38),char(0),char(188), -char(255),char(154),char(1),char(38),char(0),char(189),char(255),char(154),char(1),char(38), -char(0),char(190),char(255),char(154),char(1),char(38),char(0),char(191),char(255),char(215), -char(1),char(38),char(0),char(194),char(255),char(113),char(1),char(38),char(0),char(195), -char(255),char(92),char(1),char(38),char(0),char(196),char(255),char(113),char(1),char(38), -char(0),char(197),char(255),char(92),char(1),char(38),char(0),char(198),char(255),char(113), -char(1),char(38),char(0),char(199),char(255),char(92),char(1),char(38),char(0),char(200), -char(255),char(215),char(1),char(38),char(0),char(201),char(255),char(113),char(1),char(38), -char(0),char(202),char(255),char(215),char(1),char(38),char(0),char(203),char(255),char(113), -char(1),char(38),char(0),char(204),char(255),char(215),char(1),char(38),char(0),char(205), -char(255),char(113),char(1),char(38),char(0),char(206),char(255),char(215),char(1),char(38), -char(0),char(207),char(255),char(113),char(1),char(38),char(0),char(209),char(255),char(113), -char(1),char(38),char(0),char(211),char(255),char(113),char(1),char(38),char(0),char(213), -char(255),char(113),char(1),char(38),char(0),char(215),char(255),char(113),char(1),char(38), -char(0),char(217),char(255),char(113),char(1),char(38),char(0),char(219),char(255),char(113), -char(1),char(38),char(0),char(221),char(255),char(113),char(1),char(38),char(0),char(222), -char(255),char(215),char(1),char(38),char(0),char(223),char(255),char(113),char(1),char(38), -char(0),char(224),char(255),char(215),char(1),char(38),char(0),char(225),char(255),char(113), -char(1),char(38),char(0),char(226),char(255),char(215),char(1),char(38),char(0),char(227), -char(255),char(113),char(1),char(38),char(0),char(228),char(255),char(215),char(1),char(38), -char(0),char(229),char(255),char(113),char(1),char(38),char(0),char(250),char(255),char(154), -char(1),char(38),char(1),char(6),char(255),char(154),char(1),char(38),char(1),char(8), -char(255),char(154),char(1),char(38),char(1),char(13),char(255),char(154),char(1),char(38), -char(1),char(14),char(255),char(215),char(1),char(38),char(1),char(15),char(255),char(113), -char(1),char(38),char(1),char(16),char(255),char(215),char(1),char(38),char(1),char(17), -char(255),char(113),char(1),char(38),char(1),char(18),char(255),char(215),char(1),char(38), -char(1),char(19),char(255),char(113),char(1),char(38),char(1),char(20),char(255),char(215), -char(1),char(38),char(1),char(21),char(255),char(113),char(1),char(38),char(1),char(23), -char(255),char(154),char(1),char(38),char(1),char(25),char(255),char(154),char(1),char(38), -char(1),char(29),char(255),char(133),char(1),char(38),char(1),char(33),char(255),char(133), -char(1),char(38),char(1),char(36),char(0),char(41),char(1),char(38),char(1),char(38), -char(0),char(41),char(1),char(38),char(1),char(43),char(255),char(154),char(1),char(38), -char(1),char(45),char(255),char(154),char(1),char(38),char(1),char(47),char(255),char(154), -char(1),char(38),char(1),char(49),char(255),char(154),char(1),char(38),char(1),char(51), -char(255),char(154),char(1),char(38),char(1),char(53),char(255),char(154),char(1),char(38), -char(1),char(55),char(255),char(215),char(1),char(38),char(1),char(60),char(255),char(174), -char(1),char(38),char(1),char(62),char(255),char(174),char(1),char(38),char(1),char(64), -char(255),char(174),char(1),char(38),char(1),char(67),char(255),char(113),char(1),char(38), -char(1),char(68),char(255),char(92),char(1),char(38),char(1),char(70),char(255),char(92), -char(1),char(38),char(1),char(71),char(255),char(215),char(1),char(38),char(1),char(72), -char(255),char(113),char(1),char(38),char(1),char(74),char(255),char(133),char(1),char(38), -char(1),char(251),char(255),char(215),char(1),char(38),char(1),char(253),char(255),char(215), -char(1),char(38),char(2),char(2),char(255),char(174),char(1),char(38),char(2),char(3), -char(255),char(174),char(1),char(38),char(2),char(4),char(255),char(174),char(1),char(38), -char(2),char(8),char(255),char(133),char(1),char(38),char(2),char(12),char(255),char(133), -char(1),char(38),char(2),char(87),char(255),char(154),char(1),char(38),char(2),char(88), -char(255),char(113),char(1),char(38),char(2),char(89),char(255),char(92),char(1),char(38), -char(2),char(95),char(255),char(215),char(1),char(38),char(2),char(96),char(255),char(113), -char(1),char(38),char(2),char(98),char(255),char(154),char(1),char(38),char(3),char(29), -char(255),char(113),char(1),char(38),char(3),char(30),char(255),char(92),char(1),char(38), -char(3),char(31),char(255),char(113),char(1),char(38),char(3),char(32),char(255),char(92), -char(1),char(38),char(3),char(33),char(255),char(113),char(1),char(38),char(3),char(34), -char(255),char(92),char(1),char(38),char(3),char(35),char(255),char(113),char(1),char(38), -char(3),char(37),char(255),char(113),char(1),char(38),char(3),char(38),char(255),char(92), -char(1),char(38),char(3),char(39),char(255),char(113),char(1),char(38),char(3),char(40), -char(255),char(92),char(1),char(38),char(3),char(41),char(255),char(113),char(1),char(38), -char(3),char(42),char(255),char(92),char(1),char(38),char(3),char(43),char(255),char(113), -char(1),char(38),char(3),char(44),char(255),char(92),char(1),char(38),char(3),char(45), -char(255),char(113),char(1),char(38),char(3),char(46),char(255),char(92),char(1),char(38), -char(3),char(47),char(255),char(113),char(1),char(38),char(3),char(48),char(255),char(92), -char(1),char(38),char(3),char(49),char(255),char(113),char(1),char(38),char(3),char(50), -char(255),char(92),char(1),char(38),char(3),char(51),char(255),char(113),char(1),char(38), -char(3),char(52),char(255),char(92),char(1),char(38),char(3),char(54),char(255),char(113), -char(1),char(38),char(3),char(56),char(255),char(113),char(1),char(38),char(3),char(58), -char(255),char(113),char(1),char(38),char(3),char(60),char(255),char(113),char(1),char(38), -char(3),char(64),char(255),char(113),char(1),char(38),char(3),char(66),char(255),char(113), -char(1),char(38),char(3),char(68),char(255),char(113),char(1),char(38),char(3),char(73), -char(255),char(215),char(1),char(38),char(3),char(74),char(255),char(113),char(1),char(38), -char(3),char(75),char(255),char(215),char(1),char(38),char(3),char(76),char(255),char(113), -char(1),char(38),char(3),char(77),char(255),char(215),char(1),char(38),char(3),char(78), -char(255),char(113),char(1),char(38),char(3),char(79),char(255),char(215),char(1),char(38), -char(3),char(81),char(255),char(215),char(1),char(38),char(3),char(82),char(255),char(113), -char(1),char(38),char(3),char(83),char(255),char(215),char(1),char(38),char(3),char(84), -char(255),char(113),char(1),char(38),char(3),char(85),char(255),char(215),char(1),char(38), -char(3),char(86),char(255),char(113),char(1),char(38),char(3),char(87),char(255),char(215), -char(1),char(38),char(3),char(88),char(255),char(113),char(1),char(38),char(3),char(89), -char(255),char(215),char(1),char(38),char(3),char(90),char(255),char(113),char(1),char(38), -char(3),char(91),char(255),char(215),char(1),char(38),char(3),char(92),char(255),char(113), -char(1),char(38),char(3),char(93),char(255),char(215),char(1),char(38),char(3),char(94), -char(255),char(113),char(1),char(38),char(3),char(95),char(255),char(215),char(1),char(38), -char(3),char(96),char(255),char(113),char(1),char(38),char(3),char(98),char(255),char(154), -char(1),char(38),char(3),char(100),char(255),char(154),char(1),char(38),char(3),char(102), -char(255),char(154),char(1),char(38),char(3),char(104),char(255),char(154),char(1),char(38), -char(3),char(106),char(255),char(154),char(1),char(38),char(3),char(108),char(255),char(154), -char(1),char(38),char(3),char(110),char(255),char(154),char(1),char(38),char(3),char(112), -char(255),char(215),char(1),char(38),char(3),char(143),char(0),char(41),char(1),char(39), -char(0),char(5),char(0),char(41),char(1),char(39),char(0),char(10),char(0),char(41), -char(1),char(39),char(2),char(7),char(0),char(41),char(1),char(39),char(2),char(11), -char(0),char(41),char(1),char(40),char(0),char(15),char(255),char(133),char(1),char(40), -char(0),char(16),char(255),char(174),char(1),char(40),char(0),char(17),char(255),char(133), -char(1),char(40),char(0),char(34),char(0),char(41),char(1),char(40),char(0),char(36), -char(255),char(113),char(1),char(40),char(0),char(38),char(255),char(215),char(1),char(40), -char(0),char(42),char(255),char(215),char(1),char(40),char(0),char(50),char(255),char(215), -char(1),char(40),char(0),char(52),char(255),char(215),char(1),char(40),char(0),char(55), -char(0),char(41),char(1),char(40),char(0),char(68),char(255),char(92),char(1),char(40), -char(0),char(70),char(255),char(113),char(1),char(40),char(0),char(71),char(255),char(113), -char(1),char(40),char(0),char(72),char(255),char(113),char(1),char(40),char(0),char(74), -char(255),char(113),char(1),char(40),char(0),char(80),char(255),char(154),char(1),char(40), -char(0),char(81),char(255),char(154),char(1),char(40),char(0),char(82),char(255),char(113), -char(1),char(40),char(0),char(83),char(255),char(154),char(1),char(40),char(0),char(84), -char(255),char(113),char(1),char(40),char(0),char(85),char(255),char(154),char(1),char(40), -char(0),char(86),char(255),char(133),char(1),char(40),char(0),char(88),char(255),char(154), -char(1),char(40),char(0),char(89),char(255),char(215),char(1),char(40),char(0),char(90), -char(255),char(215),char(1),char(40),char(0),char(91),char(255),char(215),char(1),char(40), -char(0),char(92),char(255),char(215),char(1),char(40),char(0),char(93),char(255),char(174), -char(1),char(40),char(0),char(130),char(255),char(113),char(1),char(40),char(0),char(131), -char(255),char(113),char(1),char(40),char(0),char(132),char(255),char(113),char(1),char(40), -char(0),char(133),char(255),char(113),char(1),char(40),char(0),char(134),char(255),char(113), -char(1),char(40),char(0),char(135),char(255),char(113),char(1),char(40),char(0),char(137), -char(255),char(215),char(1),char(40),char(0),char(148),char(255),char(215),char(1),char(40), -char(0),char(149),char(255),char(215),char(1),char(40),char(0),char(150),char(255),char(215), -char(1),char(40),char(0),char(151),char(255),char(215),char(1),char(40),char(0),char(152), -char(255),char(215),char(1),char(40),char(0),char(154),char(255),char(215),char(1),char(40), -char(0),char(162),char(255),char(113),char(1),char(40),char(0),char(163),char(255),char(92), -char(1),char(40),char(0),char(164),char(255),char(92),char(1),char(40),char(0),char(165), -char(255),char(92),char(1),char(40),char(0),char(166),char(255),char(92),char(1),char(40), -char(0),char(167),char(255),char(92),char(1),char(40),char(0),char(168),char(255),char(92), -char(1),char(40),char(0),char(169),char(255),char(113),char(1),char(40),char(0),char(170), -char(255),char(113),char(1),char(40),char(0),char(171),char(255),char(113),char(1),char(40), -char(0),char(172),char(255),char(113),char(1),char(40),char(0),char(173),char(255),char(113), -char(1),char(40),char(0),char(180),char(255),char(113),char(1),char(40),char(0),char(181), -char(255),char(113),char(1),char(40),char(0),char(182),char(255),char(113),char(1),char(40), -char(0),char(183),char(255),char(113),char(1),char(40),char(0),char(184),char(255),char(113), -char(1),char(40),char(0),char(186),char(255),char(113),char(1),char(40),char(0),char(187), -char(255),char(154),char(1),char(40),char(0),char(188),char(255),char(154),char(1),char(40), -char(0),char(189),char(255),char(154),char(1),char(40),char(0),char(190),char(255),char(154), -char(1),char(40),char(0),char(191),char(255),char(215),char(1),char(40),char(0),char(194), -char(255),char(113),char(1),char(40),char(0),char(195),char(255),char(92),char(1),char(40), -char(0),char(196),char(255),char(113),char(1),char(40),char(0),char(197),char(255),char(92), -char(1),char(40),char(0),char(198),char(255),char(113),char(1),char(40),char(0),char(199), -char(255),char(92),char(1),char(40),char(0),char(200),char(255),char(215),char(1),char(40), -char(0),char(201),char(255),char(113),char(1),char(40),char(0),char(202),char(255),char(215), -char(1),char(40),char(0),char(203),char(255),char(113),char(1),char(40),char(0),char(204), -char(255),char(215),char(1),char(40),char(0),char(205),char(255),char(113),char(1),char(40), -char(0),char(206),char(255),char(215),char(1),char(40),char(0),char(207),char(255),char(113), -char(1),char(40),char(0),char(209),char(255),char(113),char(1),char(40),char(0),char(211), -char(255),char(113),char(1),char(40),char(0),char(213),char(255),char(113),char(1),char(40), -char(0),char(215),char(255),char(113),char(1),char(40),char(0),char(217),char(255),char(113), -char(1),char(40),char(0),char(219),char(255),char(113),char(1),char(40),char(0),char(221), -char(255),char(113),char(1),char(40),char(0),char(222),char(255),char(215),char(1),char(40), -char(0),char(223),char(255),char(113),char(1),char(40),char(0),char(224),char(255),char(215), -char(1),char(40),char(0),char(225),char(255),char(113),char(1),char(40),char(0),char(226), -char(255),char(215),char(1),char(40),char(0),char(227),char(255),char(113),char(1),char(40), -char(0),char(228),char(255),char(215),char(1),char(40),char(0),char(229),char(255),char(113), -char(1),char(40),char(0),char(250),char(255),char(154),char(1),char(40),char(1),char(6), -char(255),char(154),char(1),char(40),char(1),char(8),char(255),char(154),char(1),char(40), -char(1),char(13),char(255),char(154),char(1),char(40),char(1),char(14),char(255),char(215), -char(1),char(40),char(1),char(15),char(255),char(113),char(1),char(40),char(1),char(16), -char(255),char(215),char(1),char(40),char(1),char(17),char(255),char(113),char(1),char(40), -char(1),char(18),char(255),char(215),char(1),char(40),char(1),char(19),char(255),char(113), -char(1),char(40),char(1),char(20),char(255),char(215),char(1),char(40),char(1),char(21), -char(255),char(113),char(1),char(40),char(1),char(23),char(255),char(154),char(1),char(40), -char(1),char(25),char(255),char(154),char(1),char(40),char(1),char(29),char(255),char(133), -char(1),char(40),char(1),char(33),char(255),char(133),char(1),char(40),char(1),char(36), -char(0),char(41),char(1),char(40),char(1),char(38),char(0),char(41),char(1),char(40), -char(1),char(43),char(255),char(154),char(1),char(40),char(1),char(45),char(255),char(154), -char(1),char(40),char(1),char(47),char(255),char(154),char(1),char(40),char(1),char(49), -char(255),char(154),char(1),char(40),char(1),char(51),char(255),char(154),char(1),char(40), -char(1),char(53),char(255),char(154),char(1),char(40),char(1),char(55),char(255),char(215), -char(1),char(40),char(1),char(60),char(255),char(174),char(1),char(40),char(1),char(62), -char(255),char(174),char(1),char(40),char(1),char(64),char(255),char(174),char(1),char(40), -char(1),char(67),char(255),char(113),char(1),char(40),char(1),char(68),char(255),char(92), -char(1),char(40),char(1),char(70),char(255),char(92),char(1),char(40),char(1),char(71), -char(255),char(215),char(1),char(40),char(1),char(72),char(255),char(113),char(1),char(40), -char(1),char(74),char(255),char(133),char(1),char(40),char(1),char(251),char(255),char(215), -char(1),char(40),char(1),char(253),char(255),char(215),char(1),char(40),char(2),char(2), -char(255),char(174),char(1),char(40),char(2),char(3),char(255),char(174),char(1),char(40), -char(2),char(4),char(255),char(174),char(1),char(40),char(2),char(8),char(255),char(133), -char(1),char(40),char(2),char(12),char(255),char(133),char(1),char(40),char(2),char(87), -char(255),char(154),char(1),char(40),char(2),char(88),char(255),char(113),char(1),char(40), -char(2),char(89),char(255),char(92),char(1),char(40),char(2),char(95),char(255),char(215), -char(1),char(40),char(2),char(96),char(255),char(113),char(1),char(40),char(2),char(98), -char(255),char(154),char(1),char(40),char(3),char(29),char(255),char(113),char(1),char(40), -char(3),char(30),char(255),char(92),char(1),char(40),char(3),char(31),char(255),char(113), -char(1),char(40),char(3),char(32),char(255),char(92),char(1),char(40),char(3),char(33), -char(255),char(113),char(1),char(40),char(3),char(34),char(255),char(92),char(1),char(40), -char(3),char(35),char(255),char(113),char(1),char(40),char(3),char(37),char(255),char(113), -char(1),char(40),char(3),char(38),char(255),char(92),char(1),char(40),char(3),char(39), -char(255),char(113),char(1),char(40),char(3),char(40),char(255),char(92),char(1),char(40), -char(3),char(41),char(255),char(113),char(1),char(40),char(3),char(42),char(255),char(92), -char(1),char(40),char(3),char(43),char(255),char(113),char(1),char(40),char(3),char(44), -char(255),char(92),char(1),char(40),char(3),char(45),char(255),char(113),char(1),char(40), -char(3),char(46),char(255),char(92),char(1),char(40),char(3),char(47),char(255),char(113), -char(1),char(40),char(3),char(48),char(255),char(92),char(1),char(40),char(3),char(49), -char(255),char(113),char(1),char(40),char(3),char(50),char(255),char(92),char(1),char(40), -char(3),char(51),char(255),char(113),char(1),char(40),char(3),char(52),char(255),char(92), -char(1),char(40),char(3),char(54),char(255),char(113),char(1),char(40),char(3),char(56), -char(255),char(113),char(1),char(40),char(3),char(58),char(255),char(113),char(1),char(40), -char(3),char(60),char(255),char(113),char(1),char(40),char(3),char(64),char(255),char(113), -char(1),char(40),char(3),char(66),char(255),char(113),char(1),char(40),char(3),char(68), -char(255),char(113),char(1),char(40),char(3),char(73),char(255),char(215),char(1),char(40), -char(3),char(74),char(255),char(113),char(1),char(40),char(3),char(75),char(255),char(215), -char(1),char(40),char(3),char(76),char(255),char(113),char(1),char(40),char(3),char(77), -char(255),char(215),char(1),char(40),char(3),char(78),char(255),char(113),char(1),char(40), -char(3),char(79),char(255),char(215),char(1),char(40),char(3),char(81),char(255),char(215), -char(1),char(40),char(3),char(82),char(255),char(113),char(1),char(40),char(3),char(83), -char(255),char(215),char(1),char(40),char(3),char(84),char(255),char(113),char(1),char(40), -char(3),char(85),char(255),char(215),char(1),char(40),char(3),char(86),char(255),char(113), -char(1),char(40),char(3),char(87),char(255),char(215),char(1),char(40),char(3),char(88), -char(255),char(113),char(1),char(40),char(3),char(89),char(255),char(215),char(1),char(40), -char(3),char(90),char(255),char(113),char(1),char(40),char(3),char(91),char(255),char(215), -char(1),char(40),char(3),char(92),char(255),char(113),char(1),char(40),char(3),char(93), -char(255),char(215),char(1),char(40),char(3),char(94),char(255),char(113),char(1),char(40), -char(3),char(95),char(255),char(215),char(1),char(40),char(3),char(96),char(255),char(113), -char(1),char(40),char(3),char(98),char(255),char(154),char(1),char(40),char(3),char(100), -char(255),char(154),char(1),char(40),char(3),char(102),char(255),char(154),char(1),char(40), -char(3),char(104),char(255),char(154),char(1),char(40),char(3),char(106),char(255),char(154), -char(1),char(40),char(3),char(108),char(255),char(154),char(1),char(40),char(3),char(110), -char(255),char(154),char(1),char(40),char(3),char(112),char(255),char(215),char(1),char(40), -char(3),char(143),char(0),char(41),char(1),char(42),char(0),char(15),char(255),char(215), -char(1),char(42),char(0),char(17),char(255),char(215),char(1),char(42),char(0),char(36), -char(255),char(236),char(1),char(42),char(0),char(130),char(255),char(236),char(1),char(42), -char(0),char(131),char(255),char(236),char(1),char(42),char(0),char(132),char(255),char(236), -char(1),char(42),char(0),char(133),char(255),char(236),char(1),char(42),char(0),char(134), -char(255),char(236),char(1),char(42),char(0),char(135),char(255),char(236),char(1),char(42), -char(0),char(194),char(255),char(236),char(1),char(42),char(0),char(196),char(255),char(236), -char(1),char(42),char(0),char(198),char(255),char(236),char(1),char(42),char(1),char(67), -char(255),char(236),char(1),char(42),char(2),char(8),char(255),char(215),char(1),char(42), -char(2),char(12),char(255),char(215),char(1),char(42),char(2),char(88),char(255),char(236), -char(1),char(42),char(3),char(29),char(255),char(236),char(1),char(42),char(3),char(31), -char(255),char(236),char(1),char(42),char(3),char(33),char(255),char(236),char(1),char(42), -char(3),char(35),char(255),char(236),char(1),char(42),char(3),char(37),char(255),char(236), -char(1),char(42),char(3),char(39),char(255),char(236),char(1),char(42),char(3),char(41), -char(255),char(236),char(1),char(42),char(3),char(43),char(255),char(236),char(1),char(42), -char(3),char(45),char(255),char(236),char(1),char(42),char(3),char(47),char(255),char(236), -char(1),char(42),char(3),char(49),char(255),char(236),char(1),char(42),char(3),char(51), -char(255),char(236),char(1),char(44),char(0),char(15),char(255),char(215),char(1),char(44), -char(0),char(17),char(255),char(215),char(1),char(44),char(0),char(36),char(255),char(236), -char(1),char(44),char(0),char(130),char(255),char(236),char(1),char(44),char(0),char(131), -char(255),char(236),char(1),char(44),char(0),char(132),char(255),char(236),char(1),char(44), -char(0),char(133),char(255),char(236),char(1),char(44),char(0),char(134),char(255),char(236), -char(1),char(44),char(0),char(135),char(255),char(236),char(1),char(44),char(0),char(194), -char(255),char(236),char(1),char(44),char(0),char(196),char(255),char(236),char(1),char(44), -char(0),char(198),char(255),char(236),char(1),char(44),char(1),char(67),char(255),char(236), -char(1),char(44),char(2),char(8),char(255),char(215),char(1),char(44),char(2),char(12), -char(255),char(215),char(1),char(44),char(2),char(88),char(255),char(236),char(1),char(44), -char(3),char(29),char(255),char(236),char(1),char(44),char(3),char(31),char(255),char(236), -char(1),char(44),char(3),char(33),char(255),char(236),char(1),char(44),char(3),char(35), -char(255),char(236),char(1),char(44),char(3),char(37),char(255),char(236),char(1),char(44), -char(3),char(39),char(255),char(236),char(1),char(44),char(3),char(41),char(255),char(236), -char(1),char(44),char(3),char(43),char(255),char(236),char(1),char(44),char(3),char(45), -char(255),char(236),char(1),char(44),char(3),char(47),char(255),char(236),char(1),char(44), -char(3),char(49),char(255),char(236),char(1),char(44),char(3),char(51),char(255),char(236), -char(1),char(46),char(0),char(15),char(255),char(215),char(1),char(46),char(0),char(17), -char(255),char(215),char(1),char(46),char(0),char(36),char(255),char(236),char(1),char(46), -char(0),char(130),char(255),char(236),char(1),char(46),char(0),char(131),char(255),char(236), -char(1),char(46),char(0),char(132),char(255),char(236),char(1),char(46),char(0),char(133), -char(255),char(236),char(1),char(46),char(0),char(134),char(255),char(236),char(1),char(46), -char(0),char(135),char(255),char(236),char(1),char(46),char(0),char(194),char(255),char(236), -char(1),char(46),char(0),char(196),char(255),char(236),char(1),char(46),char(0),char(198), -char(255),char(236),char(1),char(46),char(1),char(67),char(255),char(236),char(1),char(46), -char(2),char(8),char(255),char(215),char(1),char(46),char(2),char(12),char(255),char(215), -char(1),char(46),char(2),char(88),char(255),char(236),char(1),char(46),char(3),char(29), -char(255),char(236),char(1),char(46),char(3),char(31),char(255),char(236),char(1),char(46), -char(3),char(33),char(255),char(236),char(1),char(46),char(3),char(35),char(255),char(236), -char(1),char(46),char(3),char(37),char(255),char(236),char(1),char(46),char(3),char(39), -char(255),char(236),char(1),char(46),char(3),char(41),char(255),char(236),char(1),char(46), -char(3),char(43),char(255),char(236),char(1),char(46),char(3),char(45),char(255),char(236), -char(1),char(46),char(3),char(47),char(255),char(236),char(1),char(46),char(3),char(49), -char(255),char(236),char(1),char(46),char(3),char(51),char(255),char(236),char(1),char(48), -char(0),char(15),char(255),char(215),char(1),char(48),char(0),char(17),char(255),char(215), -char(1),char(48),char(0),char(36),char(255),char(236),char(1),char(48),char(0),char(130), -char(255),char(236),char(1),char(48),char(0),char(131),char(255),char(236),char(1),char(48), -char(0),char(132),char(255),char(236),char(1),char(48),char(0),char(133),char(255),char(236), -char(1),char(48),char(0),char(134),char(255),char(236),char(1),char(48),char(0),char(135), -char(255),char(236),char(1),char(48),char(0),char(194),char(255),char(236),char(1),char(48), -char(0),char(196),char(255),char(236),char(1),char(48),char(0),char(198),char(255),char(236), -char(1),char(48),char(1),char(67),char(255),char(236),char(1),char(48),char(2),char(8), -char(255),char(215),char(1),char(48),char(2),char(12),char(255),char(215),char(1),char(48), -char(2),char(88),char(255),char(236),char(1),char(48),char(3),char(29),char(255),char(236), -char(1),char(48),char(3),char(31),char(255),char(236),char(1),char(48),char(3),char(33), -char(255),char(236),char(1),char(48),char(3),char(35),char(255),char(236),char(1),char(48), -char(3),char(37),char(255),char(236),char(1),char(48),char(3),char(39),char(255),char(236), -char(1),char(48),char(3),char(41),char(255),char(236),char(1),char(48),char(3),char(43), -char(255),char(236),char(1),char(48),char(3),char(45),char(255),char(236),char(1),char(48), -char(3),char(47),char(255),char(236),char(1),char(48),char(3),char(49),char(255),char(236), -char(1),char(48),char(3),char(51),char(255),char(236),char(1),char(50),char(0),char(15), -char(255),char(215),char(1),char(50),char(0),char(17),char(255),char(215),char(1),char(50), -char(0),char(36),char(255),char(236),char(1),char(50),char(0),char(130),char(255),char(236), -char(1),char(50),char(0),char(131),char(255),char(236),char(1),char(50),char(0),char(132), -char(255),char(236),char(1),char(50),char(0),char(133),char(255),char(236),char(1),char(50), -char(0),char(134),char(255),char(236),char(1),char(50),char(0),char(135),char(255),char(236), -char(1),char(50),char(0),char(194),char(255),char(236),char(1),char(50),char(0),char(196), -char(255),char(236),char(1),char(50),char(0),char(198),char(255),char(236),char(1),char(50), -char(1),char(67),char(255),char(236),char(1),char(50),char(2),char(8),char(255),char(215), -char(1),char(50),char(2),char(12),char(255),char(215),char(1),char(50),char(2),char(88), -char(255),char(236),char(1),char(50),char(3),char(29),char(255),char(236),char(1),char(50), -char(3),char(31),char(255),char(236),char(1),char(50),char(3),char(33),char(255),char(236), -char(1),char(50),char(3),char(35),char(255),char(236),char(1),char(50),char(3),char(37), -char(255),char(236),char(1),char(50),char(3),char(39),char(255),char(236),char(1),char(50), -char(3),char(41),char(255),char(236),char(1),char(50),char(3),char(43),char(255),char(236), -char(1),char(50),char(3),char(45),char(255),char(236),char(1),char(50),char(3),char(47), -char(255),char(236),char(1),char(50),char(3),char(49),char(255),char(236),char(1),char(50), -char(3),char(51),char(255),char(236),char(1),char(52),char(0),char(15),char(255),char(215), -char(1),char(52),char(0),char(17),char(255),char(215),char(1),char(52),char(0),char(36), -char(255),char(236),char(1),char(52),char(0),char(130),char(255),char(236),char(1),char(52), -char(0),char(131),char(255),char(236),char(1),char(52),char(0),char(132),char(255),char(236), -char(1),char(52),char(0),char(133),char(255),char(236),char(1),char(52),char(0),char(134), -char(255),char(236),char(1),char(52),char(0),char(135),char(255),char(236),char(1),char(52), -char(0),char(194),char(255),char(236),char(1),char(52),char(0),char(196),char(255),char(236), -char(1),char(52),char(0),char(198),char(255),char(236),char(1),char(52),char(1),char(67), -char(255),char(236),char(1),char(52),char(2),char(8),char(255),char(215),char(1),char(52), -char(2),char(12),char(255),char(215),char(1),char(52),char(2),char(88),char(255),char(236), -char(1),char(52),char(3),char(29),char(255),char(236),char(1),char(52),char(3),char(31), -char(255),char(236),char(1),char(52),char(3),char(33),char(255),char(236),char(1),char(52), -char(3),char(35),char(255),char(236),char(1),char(52),char(3),char(37),char(255),char(236), -char(1),char(52),char(3),char(39),char(255),char(236),char(1),char(52),char(3),char(41), -char(255),char(236),char(1),char(52),char(3),char(43),char(255),char(236),char(1),char(52), -char(3),char(45),char(255),char(236),char(1),char(52),char(3),char(47),char(255),char(236), -char(1),char(52),char(3),char(49),char(255),char(236),char(1),char(52),char(3),char(51), -char(255),char(236),char(1),char(54),char(0),char(15),char(255),char(154),char(1),char(54), -char(0),char(17),char(255),char(154),char(1),char(54),char(0),char(34),char(0),char(41), -char(1),char(54),char(0),char(36),char(255),char(174),char(1),char(54),char(0),char(38), -char(255),char(236),char(1),char(54),char(0),char(42),char(255),char(236),char(1),char(54), -char(0),char(50),char(255),char(236),char(1),char(54),char(0),char(52),char(255),char(236), -char(1),char(54),char(0),char(68),char(255),char(215),char(1),char(54),char(0),char(70), -char(255),char(215),char(1),char(54),char(0),char(71),char(255),char(215),char(1),char(54), -char(0),char(72),char(255),char(215),char(1),char(54),char(0),char(74),char(255),char(236), -char(1),char(54),char(0),char(80),char(255),char(236),char(1),char(54),char(0),char(81), -char(255),char(236),char(1),char(54),char(0),char(82),char(255),char(215),char(1),char(54), -char(0),char(83),char(255),char(236),char(1),char(54),char(0),char(84),char(255),char(215), -char(1),char(54),char(0),char(85),char(255),char(236),char(1),char(54),char(0),char(86), -char(255),char(236),char(1),char(54),char(0),char(88),char(255),char(236),char(1),char(54), -char(0),char(130),char(255),char(174),char(1),char(54),char(0),char(131),char(255),char(174), -char(1),char(54),char(0),char(132),char(255),char(174),char(1),char(54),char(0),char(133), -char(255),char(174),char(1),char(54),char(0),char(134),char(255),char(174),char(1),char(54), -char(0),char(135),char(255),char(174),char(1),char(54),char(0),char(137),char(255),char(236), -char(1),char(54),char(0),char(148),char(255),char(236),char(1),char(54),char(0),char(149), -char(255),char(236),char(1),char(54),char(0),char(150),char(255),char(236),char(1),char(54), -char(0),char(151),char(255),char(236),char(1),char(54),char(0),char(152),char(255),char(236), -char(1),char(54),char(0),char(154),char(255),char(236),char(1),char(54),char(0),char(162), -char(255),char(215),char(1),char(54),char(0),char(163),char(255),char(215),char(1),char(54), -char(0),char(164),char(255),char(215),char(1),char(54),char(0),char(165),char(255),char(215), -char(1),char(54),char(0),char(166),char(255),char(215),char(1),char(54),char(0),char(167), -char(255),char(215),char(1),char(54),char(0),char(168),char(255),char(215),char(1),char(54), -char(0),char(169),char(255),char(215),char(1),char(54),char(0),char(170),char(255),char(215), -char(1),char(54),char(0),char(171),char(255),char(215),char(1),char(54),char(0),char(172), -char(255),char(215),char(1),char(54),char(0),char(173),char(255),char(215),char(1),char(54), -char(0),char(180),char(255),char(215),char(1),char(54),char(0),char(181),char(255),char(215), -char(1),char(54),char(0),char(182),char(255),char(215),char(1),char(54),char(0),char(183), -char(255),char(215),char(1),char(54),char(0),char(184),char(255),char(215),char(1),char(54), -char(0),char(186),char(255),char(215),char(1),char(54),char(0),char(187),char(255),char(236), -char(1),char(54),char(0),char(188),char(255),char(236),char(1),char(54),char(0),char(189), -char(255),char(236),char(1),char(54),char(0),char(190),char(255),char(236),char(1),char(54), -char(0),char(194),char(255),char(174),char(1),char(54),char(0),char(195),char(255),char(215), -char(1),char(54),char(0),char(196),char(255),char(174),char(1),char(54),char(0),char(197), -char(255),char(215),char(1),char(54),char(0),char(198),char(255),char(174),char(1),char(54), -char(0),char(199),char(255),char(215),char(1),char(54),char(0),char(200),char(255),char(236), -char(1),char(54),char(0),char(201),char(255),char(215),char(1),char(54),char(0),char(202), -char(255),char(236),char(1),char(54),char(0),char(203),char(255),char(215),char(1),char(54), -char(0),char(204),char(255),char(236),char(1),char(54),char(0),char(205),char(255),char(215), -char(1),char(54),char(0),char(206),char(255),char(236),char(1),char(54),char(0),char(207), -char(255),char(215),char(1),char(54),char(0),char(209),char(255),char(215),char(1),char(54), -char(0),char(211),char(255),char(215),char(1),char(54),char(0),char(213),char(255),char(215), -char(1),char(54),char(0),char(215),char(255),char(215),char(1),char(54),char(0),char(217), -char(255),char(215),char(1),char(54),char(0),char(219),char(255),char(215),char(1),char(54), -char(0),char(221),char(255),char(215),char(1),char(54),char(0),char(222),char(255),char(236), -char(1),char(54),char(0),char(223),char(255),char(236),char(1),char(54),char(0),char(224), -char(255),char(236),char(1),char(54),char(0),char(225),char(255),char(236),char(1),char(54), -char(0),char(226),char(255),char(236),char(1),char(54),char(0),char(227),char(255),char(236), -char(1),char(54),char(0),char(228),char(255),char(236),char(1),char(54),char(0),char(229), -char(255),char(236),char(1),char(54),char(0),char(250),char(255),char(236),char(1),char(54), -char(1),char(6),char(255),char(236),char(1),char(54),char(1),char(8),char(255),char(236), -char(1),char(54),char(1),char(13),char(255),char(236),char(1),char(54),char(1),char(14), -char(255),char(236),char(1),char(54),char(1),char(15),char(255),char(215),char(1),char(54), -char(1),char(16),char(255),char(236),char(1),char(54),char(1),char(17),char(255),char(215), -char(1),char(54),char(1),char(18),char(255),char(236),char(1),char(54),char(1),char(19), -char(255),char(215),char(1),char(54),char(1),char(20),char(255),char(236),char(1),char(54), -char(1),char(21),char(255),char(215),char(1),char(54),char(1),char(23),char(255),char(236), -char(1),char(54),char(1),char(25),char(255),char(236),char(1),char(54),char(1),char(29), -char(255),char(236),char(1),char(54),char(1),char(33),char(255),char(236),char(1),char(54), -char(1),char(43),char(255),char(236),char(1),char(54),char(1),char(45),char(255),char(236), -char(1),char(54),char(1),char(47),char(255),char(236),char(1),char(54),char(1),char(49), -char(255),char(236),char(1),char(54),char(1),char(51),char(255),char(236),char(1),char(54), -char(1),char(53),char(255),char(236),char(1),char(54),char(1),char(67),char(255),char(174), -char(1),char(54),char(1),char(68),char(255),char(215),char(1),char(54),char(1),char(70), -char(255),char(215),char(1),char(54),char(1),char(71),char(255),char(236),char(1),char(54), -char(1),char(72),char(255),char(215),char(1),char(54),char(1),char(74),char(255),char(236), -char(1),char(54),char(2),char(8),char(255),char(154),char(1),char(54),char(2),char(12), -char(255),char(154),char(1),char(54),char(2),char(87),char(255),char(236),char(1),char(54), -char(2),char(88),char(255),char(174),char(1),char(54),char(2),char(89),char(255),char(215), -char(1),char(54),char(2),char(95),char(255),char(236),char(1),char(54),char(2),char(96), -char(255),char(215),char(1),char(54),char(2),char(98),char(255),char(236),char(1),char(54), -char(3),char(29),char(255),char(174),char(1),char(54),char(3),char(30),char(255),char(215), -char(1),char(54),char(3),char(31),char(255),char(174),char(1),char(54),char(3),char(32), -char(255),char(215),char(1),char(54),char(3),char(33),char(255),char(174),char(1),char(54), -char(3),char(34),char(255),char(215),char(1),char(54),char(3),char(35),char(255),char(174), -char(1),char(54),char(3),char(37),char(255),char(174),char(1),char(54),char(3),char(38), -char(255),char(215),char(1),char(54),char(3),char(39),char(255),char(174),char(1),char(54), -char(3),char(40),char(255),char(215),char(1),char(54),char(3),char(41),char(255),char(174), -char(1),char(54),char(3),char(42),char(255),char(215),char(1),char(54),char(3),char(43), -char(255),char(174),char(1),char(54),char(3),char(44),char(255),char(215),char(1),char(54), -char(3),char(45),char(255),char(174),char(1),char(54),char(3),char(46),char(255),char(215), -char(1),char(54),char(3),char(47),char(255),char(174),char(1),char(54),char(3),char(48), -char(255),char(215),char(1),char(54),char(3),char(49),char(255),char(174),char(1),char(54), -char(3),char(50),char(255),char(215),char(1),char(54),char(3),char(51),char(255),char(174), -char(1),char(54),char(3),char(52),char(255),char(215),char(1),char(54),char(3),char(54), -char(255),char(215),char(1),char(54),char(3),char(56),char(255),char(215),char(1),char(54), -char(3),char(58),char(255),char(215),char(1),char(54),char(3),char(60),char(255),char(215), -char(1),char(54),char(3),char(64),char(255),char(215),char(1),char(54),char(3),char(66), -char(255),char(215),char(1),char(54),char(3),char(68),char(255),char(215),char(1),char(54), -char(3),char(73),char(255),char(236),char(1),char(54),char(3),char(74),char(255),char(215), -char(1),char(54),char(3),char(75),char(255),char(236),char(1),char(54),char(3),char(76), -char(255),char(215),char(1),char(54),char(3),char(77),char(255),char(236),char(1),char(54), -char(3),char(78),char(255),char(215),char(1),char(54),char(3),char(79),char(255),char(236), -char(1),char(54),char(3),char(81),char(255),char(236),char(1),char(54),char(3),char(82), -char(255),char(215),char(1),char(54),char(3),char(83),char(255),char(236),char(1),char(54), -char(3),char(84),char(255),char(215),char(1),char(54),char(3),char(85),char(255),char(236), -char(1),char(54),char(3),char(86),char(255),char(215),char(1),char(54),char(3),char(87), -char(255),char(236),char(1),char(54),char(3),char(88),char(255),char(215),char(1),char(54), -char(3),char(89),char(255),char(236),char(1),char(54),char(3),char(90),char(255),char(215), -char(1),char(54),char(3),char(91),char(255),char(236),char(1),char(54),char(3),char(92), -char(255),char(215),char(1),char(54),char(3),char(93),char(255),char(236),char(1),char(54), -char(3),char(94),char(255),char(215),char(1),char(54),char(3),char(95),char(255),char(236), -char(1),char(54),char(3),char(96),char(255),char(215),char(1),char(54),char(3),char(98), -char(255),char(236),char(1),char(54),char(3),char(100),char(255),char(236),char(1),char(54), -char(3),char(102),char(255),char(236),char(1),char(54),char(3),char(104),char(255),char(236), -char(1),char(54),char(3),char(106),char(255),char(236),char(1),char(54),char(3),char(108), -char(255),char(236),char(1),char(54),char(3),char(110),char(255),char(236),char(1),char(55), -char(0),char(5),char(0),char(82),char(1),char(55),char(0),char(10),char(0),char(82), -char(1),char(55),char(0),char(15),char(255),char(174),char(1),char(55),char(0),char(17), -char(255),char(174),char(1),char(55),char(0),char(34),char(0),char(41),char(1),char(55), -char(2),char(7),char(0),char(82),char(1),char(55),char(2),char(8),char(255),char(174), -char(1),char(55),char(2),char(11),char(0),char(82),char(1),char(55),char(2),char(12), -char(255),char(174),char(1),char(56),char(0),char(15),char(255),char(133),char(1),char(56), -char(0),char(17),char(255),char(133),char(1),char(56),char(0),char(34),char(0),char(41), -char(1),char(56),char(0),char(36),char(255),char(133),char(1),char(56),char(0),char(38), -char(255),char(215),char(1),char(56),char(0),char(42),char(255),char(215),char(1),char(56), -char(0),char(50),char(255),char(215),char(1),char(56),char(0),char(52),char(255),char(215), -char(1),char(56),char(0),char(68),char(255),char(154),char(1),char(56),char(0),char(70), -char(255),char(154),char(1),char(56),char(0),char(71),char(255),char(154),char(1),char(56), -char(0),char(72),char(255),char(154),char(1),char(56),char(0),char(74),char(255),char(215), -char(1),char(56),char(0),char(80),char(255),char(195),char(1),char(56),char(0),char(81), -char(255),char(195),char(1),char(56),char(0),char(82),char(255),char(154),char(1),char(56), -char(0),char(83),char(255),char(195),char(1),char(56),char(0),char(84),char(255),char(154), -char(1),char(56),char(0),char(85),char(255),char(195),char(1),char(56),char(0),char(86), -char(255),char(174),char(1),char(56),char(0),char(88),char(255),char(195),char(1),char(56), -char(0),char(93),char(255),char(215),char(1),char(56),char(0),char(130),char(255),char(133), -char(1),char(56),char(0),char(131),char(255),char(133),char(1),char(56),char(0),char(132), -char(255),char(133),char(1),char(56),char(0),char(133),char(255),char(133),char(1),char(56), -char(0),char(134),char(255),char(133),char(1),char(56),char(0),char(135),char(255),char(133), -char(1),char(56),char(0),char(137),char(255),char(215),char(1),char(56),char(0),char(148), -char(255),char(215),char(1),char(56),char(0),char(149),char(255),char(215),char(1),char(56), -char(0),char(150),char(255),char(215),char(1),char(56),char(0),char(151),char(255),char(215), -char(1),char(56),char(0),char(152),char(255),char(215),char(1),char(56),char(0),char(154), -char(255),char(215),char(1),char(56),char(0),char(162),char(255),char(154),char(1),char(56), -char(0),char(163),char(255),char(154),char(1),char(56),char(0),char(164),char(255),char(154), -char(1),char(56),char(0),char(165),char(255),char(154),char(1),char(56),char(0),char(166), -char(255),char(154),char(1),char(56),char(0),char(167),char(255),char(154),char(1),char(56), -char(0),char(168),char(255),char(154),char(1),char(56),char(0),char(169),char(255),char(154), -char(1),char(56),char(0),char(170),char(255),char(154),char(1),char(56),char(0),char(171), -char(255),char(154),char(1),char(56),char(0),char(172),char(255),char(154),char(1),char(56), -char(0),char(173),char(255),char(154),char(1),char(56),char(0),char(180),char(255),char(154), -char(1),char(56),char(0),char(181),char(255),char(154),char(1),char(56),char(0),char(182), -char(255),char(154),char(1),char(56),char(0),char(183),char(255),char(154),char(1),char(56), -char(0),char(184),char(255),char(154),char(1),char(56),char(0),char(186),char(255),char(154), -char(1),char(56),char(0),char(187),char(255),char(195),char(1),char(56),char(0),char(188), -char(255),char(195),char(1),char(56),char(0),char(189),char(255),char(195),char(1),char(56), -char(0),char(190),char(255),char(195),char(1),char(56),char(0),char(194),char(255),char(133), -char(1),char(56),char(0),char(195),char(255),char(154),char(1),char(56),char(0),char(196), -char(255),char(133),char(1),char(56),char(0),char(197),char(255),char(154),char(1),char(56), -char(0),char(198),char(255),char(133),char(1),char(56),char(0),char(199),char(255),char(154), -char(1),char(56),char(0),char(200),char(255),char(215),char(1),char(56),char(0),char(201), -char(255),char(154),char(1),char(56),char(0),char(202),char(255),char(215),char(1),char(56), -char(0),char(203),char(255),char(154),char(1),char(56),char(0),char(204),char(255),char(215), -char(1),char(56),char(0),char(205),char(255),char(154),char(1),char(56),char(0),char(206), -char(255),char(215),char(1),char(56),char(0),char(207),char(255),char(154),char(1),char(56), -char(0),char(209),char(255),char(154),char(1),char(56),char(0),char(211),char(255),char(154), -char(1),char(56),char(0),char(213),char(255),char(154),char(1),char(56),char(0),char(215), -char(255),char(154),char(1),char(56),char(0),char(217),char(255),char(154),char(1),char(56), -char(0),char(219),char(255),char(154),char(1),char(56),char(0),char(221),char(255),char(154), -char(1),char(56),char(0),char(222),char(255),char(215),char(1),char(56),char(0),char(223), -char(255),char(215),char(1),char(56),char(0),char(224),char(255),char(215),char(1),char(56), -char(0),char(225),char(255),char(215),char(1),char(56),char(0),char(226),char(255),char(215), -char(1),char(56),char(0),char(227),char(255),char(215),char(1),char(56),char(0),char(228), -char(255),char(215),char(1),char(56),char(0),char(229),char(255),char(215),char(1),char(56), -char(0),char(250),char(255),char(195),char(1),char(56),char(1),char(6),char(255),char(195), -char(1),char(56),char(1),char(8),char(255),char(195),char(1),char(56),char(1),char(13), -char(255),char(195),char(1),char(56),char(1),char(14),char(255),char(215),char(1),char(56), -char(1),char(15),char(255),char(154),char(1),char(56),char(1),char(16),char(255),char(215), -char(1),char(56),char(1),char(17),char(255),char(154),char(1),char(56),char(1),char(18), -char(255),char(215),char(1),char(56),char(1),char(19),char(255),char(154),char(1),char(56), -char(1),char(20),char(255),char(215),char(1),char(56),char(1),char(21),char(255),char(154), -char(1),char(56),char(1),char(23),char(255),char(195),char(1),char(56),char(1),char(25), -char(255),char(195),char(1),char(56),char(1),char(29),char(255),char(174),char(1),char(56), -char(1),char(33),char(255),char(174),char(1),char(56),char(1),char(43),char(255),char(195), -char(1),char(56),char(1),char(45),char(255),char(195),char(1),char(56),char(1),char(47), -char(255),char(195),char(1),char(56),char(1),char(49),char(255),char(195),char(1),char(56), -char(1),char(51),char(255),char(195),char(1),char(56),char(1),char(53),char(255),char(195), -char(1),char(56),char(1),char(60),char(255),char(215),char(1),char(56),char(1),char(62), -char(255),char(215),char(1),char(56),char(1),char(64),char(255),char(215),char(1),char(56), -char(1),char(67),char(255),char(133),char(1),char(56),char(1),char(68),char(255),char(154), -char(1),char(56),char(1),char(70),char(255),char(154),char(1),char(56),char(1),char(71), -char(255),char(215),char(1),char(56),char(1),char(72),char(255),char(154),char(1),char(56), -char(1),char(74),char(255),char(174),char(1),char(56),char(2),char(8),char(255),char(133), -char(1),char(56),char(2),char(12),char(255),char(133),char(1),char(56),char(2),char(87), -char(255),char(195),char(1),char(56),char(2),char(88),char(255),char(133),char(1),char(56), -char(2),char(89),char(255),char(154),char(1),char(56),char(2),char(95),char(255),char(215), -char(1),char(56),char(2),char(96),char(255),char(154),char(1),char(56),char(2),char(98), -char(255),char(195),char(1),char(56),char(3),char(29),char(255),char(133),char(1),char(56), -char(3),char(30),char(255),char(154),char(1),char(56),char(3),char(31),char(255),char(133), -char(1),char(56),char(3),char(32),char(255),char(154),char(1),char(56),char(3),char(33), -char(255),char(133),char(1),char(56),char(3),char(34),char(255),char(154),char(1),char(56), -char(3),char(35),char(255),char(133),char(1),char(56),char(3),char(37),char(255),char(133), -char(1),char(56),char(3),char(38),char(255),char(154),char(1),char(56),char(3),char(39), -char(255),char(133),char(1),char(56),char(3),char(40),char(255),char(154),char(1),char(56), -char(3),char(41),char(255),char(133),char(1),char(56),char(3),char(42),char(255),char(154), -char(1),char(56),char(3),char(43),char(255),char(133),char(1),char(56),char(3),char(44), -char(255),char(154),char(1),char(56),char(3),char(45),char(255),char(133),char(1),char(56), -char(3),char(46),char(255),char(154),char(1),char(56),char(3),char(47),char(255),char(133), -char(1),char(56),char(3),char(48),char(255),char(154),char(1),char(56),char(3),char(49), -char(255),char(133),char(1),char(56),char(3),char(50),char(255),char(154),char(1),char(56), -char(3),char(51),char(255),char(133),char(1),char(56),char(3),char(52),char(255),char(154), -char(1),char(56),char(3),char(54),char(255),char(154),char(1),char(56),char(3),char(56), -char(255),char(154),char(1),char(56),char(3),char(58),char(255),char(154),char(1),char(56), -char(3),char(60),char(255),char(154),char(1),char(56),char(3),char(64),char(255),char(154), -char(1),char(56),char(3),char(66),char(255),char(154),char(1),char(56),char(3),char(68), -char(255),char(154),char(1),char(56),char(3),char(73),char(255),char(215),char(1),char(56), -char(3),char(74),char(255),char(154),char(1),char(56),char(3),char(75),char(255),char(215), -char(1),char(56),char(3),char(76),char(255),char(154),char(1),char(56),char(3),char(77), -char(255),char(215),char(1),char(56),char(3),char(78),char(255),char(154),char(1),char(56), -char(3),char(79),char(255),char(215),char(1),char(56),char(3),char(81),char(255),char(215), -char(1),char(56),char(3),char(82),char(255),char(154),char(1),char(56),char(3),char(83), -char(255),char(215),char(1),char(56),char(3),char(84),char(255),char(154),char(1),char(56), -char(3),char(85),char(255),char(215),char(1),char(56),char(3),char(86),char(255),char(154), -char(1),char(56),char(3),char(87),char(255),char(215),char(1),char(56),char(3),char(88), -char(255),char(154),char(1),char(56),char(3),char(89),char(255),char(215),char(1),char(56), -char(3),char(90),char(255),char(154),char(1),char(56),char(3),char(91),char(255),char(215), -char(1),char(56),char(3),char(92),char(255),char(154),char(1),char(56),char(3),char(93), -char(255),char(215),char(1),char(56),char(3),char(94),char(255),char(154),char(1),char(56), -char(3),char(95),char(255),char(215),char(1),char(56),char(3),char(96),char(255),char(154), -char(1),char(56),char(3),char(98),char(255),char(195),char(1),char(56),char(3),char(100), -char(255),char(195),char(1),char(56),char(3),char(102),char(255),char(195),char(1),char(56), -char(3),char(104),char(255),char(195),char(1),char(56),char(3),char(106),char(255),char(195), -char(1),char(56),char(3),char(108),char(255),char(195),char(1),char(56),char(3),char(110), -char(255),char(195),char(1),char(57),char(0),char(5),char(0),char(82),char(1),char(57), -char(0),char(10),char(0),char(82),char(1),char(57),char(0),char(15),char(255),char(174), -char(1),char(57),char(0),char(17),char(255),char(174),char(1),char(57),char(0),char(34), -char(0),char(41),char(1),char(57),char(2),char(7),char(0),char(82),char(1),char(57), -char(2),char(8),char(255),char(174),char(1),char(57),char(2),char(11),char(0),char(82), -char(1),char(57),char(2),char(12),char(255),char(174),char(1),char(58),char(0),char(15), -char(255),char(133),char(1),char(58),char(0),char(17),char(255),char(133),char(1),char(58), -char(0),char(34),char(0),char(41),char(1),char(58),char(0),char(36),char(255),char(133), -char(1),char(58),char(0),char(38),char(255),char(215),char(1),char(58),char(0),char(42), -char(255),char(215),char(1),char(58),char(0),char(50),char(255),char(215),char(1),char(58), -char(0),char(52),char(255),char(215),char(1),char(58),char(0),char(68),char(255),char(154), -char(1),char(58),char(0),char(70),char(255),char(154),char(1),char(58),char(0),char(71), -char(255),char(154),char(1),char(58),char(0),char(72),char(255),char(154),char(1),char(58), -char(0),char(74),char(255),char(215),char(1),char(58),char(0),char(80),char(255),char(195), -char(1),char(58),char(0),char(81),char(255),char(195),char(1),char(58),char(0),char(82), -char(255),char(154),char(1),char(58),char(0),char(83),char(255),char(195),char(1),char(58), -char(0),char(84),char(255),char(154),char(1),char(58),char(0),char(85),char(255),char(195), -char(1),char(58),char(0),char(86),char(255),char(174),char(1),char(58),char(0),char(88), -char(255),char(195),char(1),char(58),char(0),char(93),char(255),char(215),char(1),char(58), -char(0),char(130),char(255),char(133),char(1),char(58),char(0),char(131),char(255),char(133), -char(1),char(58),char(0),char(132),char(255),char(133),char(1),char(58),char(0),char(133), -char(255),char(133),char(1),char(58),char(0),char(134),char(255),char(133),char(1),char(58), -char(0),char(135),char(255),char(133),char(1),char(58),char(0),char(137),char(255),char(215), -char(1),char(58),char(0),char(148),char(255),char(215),char(1),char(58),char(0),char(149), -char(255),char(215),char(1),char(58),char(0),char(150),char(255),char(215),char(1),char(58), -char(0),char(151),char(255),char(215),char(1),char(58),char(0),char(152),char(255),char(215), -char(1),char(58),char(0),char(154),char(255),char(215),char(1),char(58),char(0),char(162), -char(255),char(154),char(1),char(58),char(0),char(163),char(255),char(154),char(1),char(58), -char(0),char(164),char(255),char(154),char(1),char(58),char(0),char(165),char(255),char(154), -char(1),char(58),char(0),char(166),char(255),char(154),char(1),char(58),char(0),char(167), -char(255),char(154),char(1),char(58),char(0),char(168),char(255),char(154),char(1),char(58), -char(0),char(169),char(255),char(154),char(1),char(58),char(0),char(170),char(255),char(154), -char(1),char(58),char(0),char(171),char(255),char(154),char(1),char(58),char(0),char(172), -char(255),char(154),char(1),char(58),char(0),char(173),char(255),char(154),char(1),char(58), -char(0),char(180),char(255),char(154),char(1),char(58),char(0),char(181),char(255),char(154), -char(1),char(58),char(0),char(182),char(255),char(154),char(1),char(58),char(0),char(183), -char(255),char(154),char(1),char(58),char(0),char(184),char(255),char(154),char(1),char(58), -char(0),char(186),char(255),char(154),char(1),char(58),char(0),char(187),char(255),char(195), -char(1),char(58),char(0),char(188),char(255),char(195),char(1),char(58),char(0),char(189), -char(255),char(195),char(1),char(58),char(0),char(190),char(255),char(195),char(1),char(58), -char(0),char(194),char(255),char(133),char(1),char(58),char(0),char(195),char(255),char(154), -char(1),char(58),char(0),char(196),char(255),char(133),char(1),char(58),char(0),char(197), -char(255),char(154),char(1),char(58),char(0),char(198),char(255),char(133),char(1),char(58), -char(0),char(199),char(255),char(154),char(1),char(58),char(0),char(200),char(255),char(215), -char(1),char(58),char(0),char(201),char(255),char(154),char(1),char(58),char(0),char(202), -char(255),char(215),char(1),char(58),char(0),char(203),char(255),char(154),char(1),char(58), -char(0),char(204),char(255),char(215),char(1),char(58),char(0),char(205),char(255),char(154), -char(1),char(58),char(0),char(206),char(255),char(215),char(1),char(58),char(0),char(207), -char(255),char(154),char(1),char(58),char(0),char(209),char(255),char(154),char(1),char(58), -char(0),char(211),char(255),char(154),char(1),char(58),char(0),char(213),char(255),char(154), -char(1),char(58),char(0),char(215),char(255),char(154),char(1),char(58),char(0),char(217), -char(255),char(154),char(1),char(58),char(0),char(219),char(255),char(154),char(1),char(58), -char(0),char(221),char(255),char(154),char(1),char(58),char(0),char(222),char(255),char(215), -char(1),char(58),char(0),char(223),char(255),char(215),char(1),char(58),char(0),char(224), -char(255),char(215),char(1),char(58),char(0),char(225),char(255),char(215),char(1),char(58), -char(0),char(226),char(255),char(215),char(1),char(58),char(0),char(227),char(255),char(215), -char(1),char(58),char(0),char(228),char(255),char(215),char(1),char(58),char(0),char(229), -char(255),char(215),char(1),char(58),char(0),char(250),char(255),char(195),char(1),char(58), -char(1),char(6),char(255),char(195),char(1),char(58),char(1),char(8),char(255),char(195), -char(1),char(58),char(1),char(13),char(255),char(195),char(1),char(58),char(1),char(14), -char(255),char(215),char(1),char(58),char(1),char(15),char(255),char(154),char(1),char(58), -char(1),char(16),char(255),char(215),char(1),char(58),char(1),char(17),char(255),char(154), -char(1),char(58),char(1),char(18),char(255),char(215),char(1),char(58),char(1),char(19), -char(255),char(154),char(1),char(58),char(1),char(20),char(255),char(215),char(1),char(58), -char(1),char(21),char(255),char(154),char(1),char(58),char(1),char(23),char(255),char(195), -char(1),char(58),char(1),char(25),char(255),char(195),char(1),char(58),char(1),char(29), -char(255),char(174),char(1),char(58),char(1),char(33),char(255),char(174),char(1),char(58), -char(1),char(43),char(255),char(195),char(1),char(58),char(1),char(45),char(255),char(195), -char(1),char(58),char(1),char(47),char(255),char(195),char(1),char(58),char(1),char(49), -char(255),char(195),char(1),char(58),char(1),char(51),char(255),char(195),char(1),char(58), -char(1),char(53),char(255),char(195),char(1),char(58),char(1),char(60),char(255),char(215), -char(1),char(58),char(1),char(62),char(255),char(215),char(1),char(58),char(1),char(64), -char(255),char(215),char(1),char(58),char(1),char(67),char(255),char(133),char(1),char(58), -char(1),char(68),char(255),char(154),char(1),char(58),char(1),char(70),char(255),char(154), -char(1),char(58),char(1),char(71),char(255),char(215),char(1),char(58),char(1),char(72), -char(255),char(154),char(1),char(58),char(1),char(74),char(255),char(174),char(1),char(58), -char(2),char(8),char(255),char(133),char(1),char(58),char(2),char(12),char(255),char(133), -char(1),char(58),char(2),char(87),char(255),char(195),char(1),char(58),char(2),char(88), -char(255),char(133),char(1),char(58),char(2),char(89),char(255),char(154),char(1),char(58), -char(2),char(95),char(255),char(215),char(1),char(58),char(2),char(96),char(255),char(154), -char(1),char(58),char(2),char(98),char(255),char(195),char(1),char(58),char(3),char(29), -char(255),char(133),char(1),char(58),char(3),char(30),char(255),char(154),char(1),char(58), -char(3),char(31),char(255),char(133),char(1),char(58),char(3),char(32),char(255),char(154), -char(1),char(58),char(3),char(33),char(255),char(133),char(1),char(58),char(3),char(34), -char(255),char(154),char(1),char(58),char(3),char(35),char(255),char(133),char(1),char(58), -char(3),char(37),char(255),char(133),char(1),char(58),char(3),char(38),char(255),char(154), -char(1),char(58),char(3),char(39),char(255),char(133),char(1),char(58),char(3),char(40), -char(255),char(154),char(1),char(58),char(3),char(41),char(255),char(133),char(1),char(58), -char(3),char(42),char(255),char(154),char(1),char(58),char(3),char(43),char(255),char(133), -char(1),char(58),char(3),char(44),char(255),char(154),char(1),char(58),char(3),char(45), -char(255),char(133),char(1),char(58),char(3),char(46),char(255),char(154),char(1),char(58), -char(3),char(47),char(255),char(133),char(1),char(58),char(3),char(48),char(255),char(154), -char(1),char(58),char(3),char(49),char(255),char(133),char(1),char(58),char(3),char(50), -char(255),char(154),char(1),char(58),char(3),char(51),char(255),char(133),char(1),char(58), -char(3),char(52),char(255),char(154),char(1),char(58),char(3),char(54),char(255),char(154), -char(1),char(58),char(3),char(56),char(255),char(154),char(1),char(58),char(3),char(58), -char(255),char(154),char(1),char(58),char(3),char(60),char(255),char(154),char(1),char(58), -char(3),char(64),char(255),char(154),char(1),char(58),char(3),char(66),char(255),char(154), -char(1),char(58),char(3),char(68),char(255),char(154),char(1),char(58),char(3),char(73), -char(255),char(215),char(1),char(58),char(3),char(74),char(255),char(154),char(1),char(58), -char(3),char(75),char(255),char(215),char(1),char(58),char(3),char(76),char(255),char(154), -char(1),char(58),char(3),char(77),char(255),char(215),char(1),char(58),char(3),char(78), -char(255),char(154),char(1),char(58),char(3),char(79),char(255),char(215),char(1),char(58), -char(3),char(81),char(255),char(215),char(1),char(58),char(3),char(82),char(255),char(154), -char(1),char(58),char(3),char(83),char(255),char(215),char(1),char(58),char(3),char(84), -char(255),char(154),char(1),char(58),char(3),char(85),char(255),char(215),char(1),char(58), -char(3),char(86),char(255),char(154),char(1),char(58),char(3),char(87),char(255),char(215), -char(1),char(58),char(3),char(88),char(255),char(154),char(1),char(58),char(3),char(89), -char(255),char(215),char(1),char(58),char(3),char(90),char(255),char(154),char(1),char(58), -char(3),char(91),char(255),char(215),char(1),char(58),char(3),char(92),char(255),char(154), -char(1),char(58),char(3),char(93),char(255),char(215),char(1),char(58),char(3),char(94), -char(255),char(154),char(1),char(58),char(3),char(95),char(255),char(215),char(1),char(58), -char(3),char(96),char(255),char(154),char(1),char(58),char(3),char(98),char(255),char(195), -char(1),char(58),char(3),char(100),char(255),char(195),char(1),char(58),char(3),char(102), -char(255),char(195),char(1),char(58),char(3),char(104),char(255),char(195),char(1),char(58), -char(3),char(106),char(255),char(195),char(1),char(58),char(3),char(108),char(255),char(195), -char(1),char(58),char(3),char(110),char(255),char(195),char(1),char(59),char(0),char(38), -char(255),char(236),char(1),char(59),char(0),char(42),char(255),char(236),char(1),char(59), -char(0),char(50),char(255),char(236),char(1),char(59),char(0),char(52),char(255),char(236), -char(1),char(59),char(0),char(137),char(255),char(236),char(1),char(59),char(0),char(148), -char(255),char(236),char(1),char(59),char(0),char(149),char(255),char(236),char(1),char(59), -char(0),char(150),char(255),char(236),char(1),char(59),char(0),char(151),char(255),char(236), -char(1),char(59),char(0),char(152),char(255),char(236),char(1),char(59),char(0),char(154), -char(255),char(236),char(1),char(59),char(0),char(200),char(255),char(236),char(1),char(59), -char(0),char(202),char(255),char(236),char(1),char(59),char(0),char(204),char(255),char(236), -char(1),char(59),char(0),char(206),char(255),char(236),char(1),char(59),char(0),char(222), -char(255),char(236),char(1),char(59),char(0),char(224),char(255),char(236),char(1),char(59), -char(0),char(226),char(255),char(236),char(1),char(59),char(0),char(228),char(255),char(236), -char(1),char(59),char(1),char(14),char(255),char(236),char(1),char(59),char(1),char(16), -char(255),char(236),char(1),char(59),char(1),char(18),char(255),char(236),char(1),char(59), -char(1),char(20),char(255),char(236),char(1),char(59),char(1),char(71),char(255),char(236), -char(1),char(59),char(2),char(95),char(255),char(236),char(1),char(59),char(3),char(73), -char(255),char(236),char(1),char(59),char(3),char(75),char(255),char(236),char(1),char(59), -char(3),char(77),char(255),char(236),char(1),char(59),char(3),char(79),char(255),char(236), -char(1),char(59),char(3),char(81),char(255),char(236),char(1),char(59),char(3),char(83), -char(255),char(236),char(1),char(59),char(3),char(85),char(255),char(236),char(1),char(59), -char(3),char(87),char(255),char(236),char(1),char(59),char(3),char(89),char(255),char(236), -char(1),char(59),char(3),char(91),char(255),char(236),char(1),char(59),char(3),char(93), -char(255),char(236),char(1),char(59),char(3),char(95),char(255),char(236),char(1),char(61), -char(0),char(38),char(255),char(236),char(1),char(61),char(0),char(42),char(255),char(236), -char(1),char(61),char(0),char(50),char(255),char(236),char(1),char(61),char(0),char(52), -char(255),char(236),char(1),char(61),char(0),char(137),char(255),char(236),char(1),char(61), -char(0),char(148),char(255),char(236),char(1),char(61),char(0),char(149),char(255),char(236), -char(1),char(61),char(0),char(150),char(255),char(236),char(1),char(61),char(0),char(151), -char(255),char(236),char(1),char(61),char(0),char(152),char(255),char(236),char(1),char(61), -char(0),char(154),char(255),char(236),char(1),char(61),char(0),char(200),char(255),char(236), -char(1),char(61),char(0),char(202),char(255),char(236),char(1),char(61),char(0),char(204), -char(255),char(236),char(1),char(61),char(0),char(206),char(255),char(236),char(1),char(61), -char(0),char(222),char(255),char(236),char(1),char(61),char(0),char(224),char(255),char(236), -char(1),char(61),char(0),char(226),char(255),char(236),char(1),char(61),char(0),char(228), -char(255),char(236),char(1),char(61),char(1),char(14),char(255),char(236),char(1),char(61), -char(1),char(16),char(255),char(236),char(1),char(61),char(1),char(18),char(255),char(236), -char(1),char(61),char(1),char(20),char(255),char(236),char(1),char(61),char(1),char(71), -char(255),char(236),char(1),char(61),char(2),char(95),char(255),char(236),char(1),char(61), -char(3),char(73),char(255),char(236),char(1),char(61),char(3),char(75),char(255),char(236), -char(1),char(61),char(3),char(77),char(255),char(236),char(1),char(61),char(3),char(79), -char(255),char(236),char(1),char(61),char(3),char(81),char(255),char(236),char(1),char(61), -char(3),char(83),char(255),char(236),char(1),char(61),char(3),char(85),char(255),char(236), -char(1),char(61),char(3),char(87),char(255),char(236),char(1),char(61),char(3),char(89), -char(255),char(236),char(1),char(61),char(3),char(91),char(255),char(236),char(1),char(61), -char(3),char(93),char(255),char(236),char(1),char(61),char(3),char(95),char(255),char(236), -char(1),char(63),char(0),char(38),char(255),char(236),char(1),char(63),char(0),char(42), -char(255),char(236),char(1),char(63),char(0),char(50),char(255),char(236),char(1),char(63), -char(0),char(52),char(255),char(236),char(1),char(63),char(0),char(137),char(255),char(236), -char(1),char(63),char(0),char(148),char(255),char(236),char(1),char(63),char(0),char(149), -char(255),char(236),char(1),char(63),char(0),char(150),char(255),char(236),char(1),char(63), -char(0),char(151),char(255),char(236),char(1),char(63),char(0),char(152),char(255),char(236), -char(1),char(63),char(0),char(154),char(255),char(236),char(1),char(63),char(0),char(200), -char(255),char(236),char(1),char(63),char(0),char(202),char(255),char(236),char(1),char(63), -char(0),char(204),char(255),char(236),char(1),char(63),char(0),char(206),char(255),char(236), -char(1),char(63),char(0),char(222),char(255),char(236),char(1),char(63),char(0),char(224), -char(255),char(236),char(1),char(63),char(0),char(226),char(255),char(236),char(1),char(63), -char(0),char(228),char(255),char(236),char(1),char(63),char(1),char(14),char(255),char(236), -char(1),char(63),char(1),char(16),char(255),char(236),char(1),char(63),char(1),char(18), -char(255),char(236),char(1),char(63),char(1),char(20),char(255),char(236),char(1),char(63), -char(1),char(71),char(255),char(236),char(1),char(63),char(2),char(95),char(255),char(236), -char(1),char(63),char(3),char(73),char(255),char(236),char(1),char(63),char(3),char(75), -char(255),char(236),char(1),char(63),char(3),char(77),char(255),char(236),char(1),char(63), -char(3),char(79),char(255),char(236),char(1),char(63),char(3),char(81),char(255),char(236), -char(1),char(63),char(3),char(83),char(255),char(236),char(1),char(63),char(3),char(85), -char(255),char(236),char(1),char(63),char(3),char(87),char(255),char(236),char(1),char(63), -char(3),char(89),char(255),char(236),char(1),char(63),char(3),char(91),char(255),char(236), -char(1),char(63),char(3),char(93),char(255),char(236),char(1),char(63),char(3),char(95), -char(255),char(236),char(1),char(67),char(0),char(5),char(255),char(113),char(1),char(67), -char(0),char(10),char(255),char(113),char(1),char(67),char(0),char(38),char(255),char(215), -char(1),char(67),char(0),char(42),char(255),char(215),char(1),char(67),char(0),char(45), -char(1),char(10),char(1),char(67),char(0),char(50),char(255),char(215),char(1),char(67), -char(0),char(52),char(255),char(215),char(1),char(67),char(0),char(55),char(255),char(113), -char(1),char(67),char(0),char(57),char(255),char(174),char(1),char(67),char(0),char(58), -char(255),char(174),char(1),char(67),char(0),char(60),char(255),char(133),char(1),char(67), -char(0),char(137),char(255),char(215),char(1),char(67),char(0),char(148),char(255),char(215), -char(1),char(67),char(0),char(149),char(255),char(215),char(1),char(67),char(0),char(150), -char(255),char(215),char(1),char(67),char(0),char(151),char(255),char(215),char(1),char(67), -char(0),char(152),char(255),char(215),char(1),char(67),char(0),char(154),char(255),char(215), -char(1),char(67),char(0),char(159),char(255),char(133),char(1),char(67),char(0),char(200), -char(255),char(215),char(1),char(67),char(0),char(202),char(255),char(215),char(1),char(67), -char(0),char(204),char(255),char(215),char(1),char(67),char(0),char(206),char(255),char(215), -char(1),char(67),char(0),char(222),char(255),char(215),char(1),char(67),char(0),char(224), -char(255),char(215),char(1),char(67),char(0),char(226),char(255),char(215),char(1),char(67), -char(0),char(228),char(255),char(215),char(1),char(67),char(1),char(14),char(255),char(215), -char(1),char(67),char(1),char(16),char(255),char(215),char(1),char(67),char(1),char(18), -char(255),char(215),char(1),char(67),char(1),char(20),char(255),char(215),char(1),char(67), -char(1),char(36),char(255),char(113),char(1),char(67),char(1),char(38),char(255),char(113), -char(1),char(67),char(1),char(54),char(255),char(174),char(1),char(67),char(1),char(56), -char(255),char(133),char(1),char(67),char(1),char(58),char(255),char(133),char(1),char(67), -char(1),char(71),char(255),char(215),char(1),char(67),char(1),char(250),char(255),char(174), -char(1),char(67),char(1),char(252),char(255),char(174),char(1),char(67),char(1),char(254), -char(255),char(174),char(1),char(67),char(2),char(0),char(255),char(133),char(1),char(67), -char(2),char(7),char(255),char(113),char(1),char(67),char(2),char(11),char(255),char(113), -char(1),char(67),char(2),char(95),char(255),char(215),char(1),char(67),char(3),char(73), -char(255),char(215),char(1),char(67),char(3),char(75),char(255),char(215),char(1),char(67), -char(3),char(77),char(255),char(215),char(1),char(67),char(3),char(79),char(255),char(215), -char(1),char(67),char(3),char(81),char(255),char(215),char(1),char(67),char(3),char(83), -char(255),char(215),char(1),char(67),char(3),char(85),char(255),char(215),char(1),char(67), -char(3),char(87),char(255),char(215),char(1),char(67),char(3),char(89),char(255),char(215), -char(1),char(67),char(3),char(91),char(255),char(215),char(1),char(67),char(3),char(93), -char(255),char(215),char(1),char(67),char(3),char(95),char(255),char(215),char(1),char(67), -char(3),char(111),char(255),char(133),char(1),char(67),char(3),char(113),char(255),char(133), -char(1),char(67),char(3),char(115),char(255),char(133),char(1),char(67),char(3),char(143), -char(255),char(113),char(1),char(68),char(0),char(5),char(255),char(236),char(1),char(68), -char(0),char(10),char(255),char(236),char(1),char(68),char(2),char(7),char(255),char(236), -char(1),char(68),char(2),char(11),char(255),char(236),char(1),char(69),char(0),char(45), -char(0),char(123),char(1),char(71),char(0),char(15),char(255),char(174),char(1),char(71), -char(0),char(17),char(255),char(174),char(1),char(71),char(0),char(36),char(255),char(215), -char(1),char(71),char(0),char(55),char(255),char(195),char(1),char(71),char(0),char(57), -char(255),char(236),char(1),char(71),char(0),char(58),char(255),char(236),char(1),char(71), -char(0),char(59),char(255),char(215),char(1),char(71),char(0),char(60),char(255),char(236), -char(1),char(71),char(0),char(61),char(255),char(236),char(1),char(71),char(0),char(130), -char(255),char(215),char(1),char(71),char(0),char(131),char(255),char(215),char(1),char(71), -char(0),char(132),char(255),char(215),char(1),char(71),char(0),char(133),char(255),char(215), -char(1),char(71),char(0),char(134),char(255),char(215),char(1),char(71),char(0),char(135), -char(255),char(215),char(1),char(71),char(0),char(159),char(255),char(236),char(1),char(71), -char(0),char(194),char(255),char(215),char(1),char(71),char(0),char(196),char(255),char(215), -char(1),char(71),char(0),char(198),char(255),char(215),char(1),char(71),char(1),char(36), -char(255),char(195),char(1),char(71),char(1),char(38),char(255),char(195),char(1),char(71), -char(1),char(54),char(255),char(236),char(1),char(71),char(1),char(56),char(255),char(236), -char(1),char(71),char(1),char(58),char(255),char(236),char(1),char(71),char(1),char(59), -char(255),char(236),char(1),char(71),char(1),char(61),char(255),char(236),char(1),char(71), -char(1),char(63),char(255),char(236),char(1),char(71),char(1),char(67),char(255),char(215), -char(1),char(71),char(1),char(160),char(255),char(236),char(1),char(71),char(1),char(250), -char(255),char(236),char(1),char(71),char(1),char(252),char(255),char(236),char(1),char(71), -char(1),char(254),char(255),char(236),char(1),char(71),char(2),char(0),char(255),char(236), -char(1),char(71),char(2),char(8),char(255),char(174),char(1),char(71),char(2),char(12), -char(255),char(174),char(1),char(71),char(2),char(88),char(255),char(215),char(1),char(71), -char(3),char(29),char(255),char(215),char(1),char(71),char(3),char(31),char(255),char(215), -char(1),char(71),char(3),char(33),char(255),char(215),char(1),char(71),char(3),char(35), -char(255),char(215),char(1),char(71),char(3),char(37),char(255),char(215),char(1),char(71), -char(3),char(39),char(255),char(215),char(1),char(71),char(3),char(41),char(255),char(215), -char(1),char(71),char(3),char(43),char(255),char(215),char(1),char(71),char(3),char(45), -char(255),char(215),char(1),char(71),char(3),char(47),char(255),char(215),char(1),char(71), -char(3),char(49),char(255),char(215),char(1),char(71),char(3),char(51),char(255),char(215), -char(1),char(71),char(3),char(111),char(255),char(236),char(1),char(71),char(3),char(113), -char(255),char(236),char(1),char(71),char(3),char(115),char(255),char(236),char(1),char(71), -char(3),char(143),char(255),char(195),char(1),char(86),char(0),char(5),char(255),char(113), -char(1),char(86),char(0),char(10),char(255),char(113),char(1),char(86),char(1),char(102), -char(255),char(215),char(1),char(86),char(1),char(109),char(255),char(215),char(1),char(86), -char(1),char(113),char(255),char(113),char(1),char(86),char(1),char(114),char(255),char(133), -char(1),char(86),char(1),char(115),char(255),char(215),char(1),char(86),char(1),char(117), -char(255),char(174),char(1),char(86),char(1),char(120),char(255),char(133),char(1),char(86), -char(2),char(7),char(255),char(113),char(1),char(86),char(2),char(11),char(255),char(113), -char(1),char(86),char(2),char(84),char(255),char(133),char(1),char(91),char(0),char(15), -char(255),char(174),char(1),char(91),char(0),char(17),char(255),char(174),char(1),char(91), -char(1),char(86),char(255),char(215),char(1),char(91),char(1),char(95),char(255),char(215), -char(1),char(91),char(1),char(98),char(255),char(215),char(1),char(91),char(1),char(100), -char(255),char(236),char(1),char(91),char(1),char(105),char(255),char(215),char(1),char(91), -char(1),char(112),char(255),char(236),char(1),char(91),char(1),char(113),char(255),char(195), -char(1),char(91),char(1),char(114),char(255),char(236),char(1),char(91),char(1),char(116), -char(255),char(215),char(1),char(91),char(1),char(117),char(255),char(236),char(1),char(91), -char(1),char(120),char(255),char(236),char(1),char(91),char(1),char(136),char(255),char(236), -char(1),char(91),char(2),char(8),char(255),char(174),char(1),char(91),char(2),char(12), -char(255),char(174),char(1),char(91),char(2),char(84),char(255),char(236),char(1),char(92), -char(0),char(15),char(255),char(133),char(1),char(92),char(0),char(17),char(255),char(133), -char(1),char(92),char(1),char(86),char(255),char(133),char(1),char(92),char(1),char(95), -char(255),char(133),char(1),char(92),char(1),char(98),char(255),char(133),char(1),char(92), -char(1),char(102),char(255),char(215),char(1),char(92),char(1),char(105),char(255),char(133), -char(1),char(92),char(1),char(109),char(255),char(215),char(1),char(92),char(1),char(115), -char(255),char(195),char(1),char(92),char(1),char(118),char(255),char(236),char(1),char(92), -char(1),char(121),char(255),char(154),char(1),char(92),char(1),char(122),char(255),char(174), -char(1),char(92),char(1),char(123),char(255),char(195),char(1),char(92),char(1),char(124), -char(255),char(195),char(1),char(92),char(1),char(125),char(255),char(195),char(1),char(92), -char(1),char(126),char(255),char(154),char(1),char(92),char(1),char(129),char(255),char(195), -char(1),char(92),char(1),char(130),char(255),char(174),char(1),char(92),char(1),char(132), -char(255),char(195),char(1),char(92),char(1),char(134),char(255),char(195),char(1),char(92), -char(1),char(135),char(255),char(195),char(1),char(92),char(1),char(137),char(255),char(195), -char(1),char(92),char(1),char(140),char(255),char(154),char(1),char(92),char(1),char(142), -char(255),char(154),char(1),char(92),char(1),char(143),char(255),char(154),char(1),char(92), -char(1),char(144),char(255),char(154),char(1),char(92),char(1),char(146),char(255),char(195), -char(1),char(92),char(1),char(147),char(255),char(154),char(1),char(92),char(1),char(149), -char(255),char(195),char(1),char(92),char(1),char(150),char(255),char(195),char(1),char(92), -char(1),char(152),char(255),char(195),char(1),char(92),char(1),char(153),char(255),char(154), -char(1),char(92),char(1),char(154),char(255),char(195),char(1),char(92),char(1),char(155), -char(255),char(195),char(1),char(92),char(2),char(8),char(255),char(133),char(1),char(92), -char(2),char(12),char(255),char(133),char(1),char(92),char(2),char(33),char(255),char(236), -char(1),char(93),char(1),char(113),char(255),char(215),char(1),char(93),char(1),char(114), -char(255),char(236),char(1),char(93),char(1),char(120),char(255),char(236),char(1),char(93), -char(2),char(84),char(255),char(236),char(1),char(94),char(0),char(5),char(255),char(215), -char(1),char(94),char(0),char(10),char(255),char(215),char(1),char(94),char(2),char(7), -char(255),char(215),char(1),char(94),char(2),char(11),char(255),char(215),char(1),char(95), -char(0),char(5),char(255),char(113),char(1),char(95),char(0),char(10),char(255),char(113), -char(1),char(95),char(1),char(102),char(255),char(215),char(1),char(95),char(1),char(109), -char(255),char(215),char(1),char(95),char(1),char(113),char(255),char(113),char(1),char(95), -char(1),char(114),char(255),char(133),char(1),char(95),char(1),char(115),char(255),char(215), -char(1),char(95),char(1),char(117),char(255),char(174),char(1),char(95),char(1),char(120), -char(255),char(133),char(1),char(95),char(2),char(7),char(255),char(113),char(1),char(95), -char(2),char(11),char(255),char(113),char(1),char(95),char(2),char(84),char(255),char(133), -char(1),char(96),char(0),char(15),char(255),char(174),char(1),char(96),char(0),char(17), -char(255),char(174),char(1),char(96),char(1),char(86),char(255),char(215),char(1),char(96), -char(1),char(95),char(255),char(215),char(1),char(96),char(1),char(98),char(255),char(215), -char(1),char(96),char(1),char(105),char(255),char(215),char(1),char(96),char(1),char(116), -char(255),char(215),char(1),char(96),char(2),char(8),char(255),char(174),char(1),char(96), -char(2),char(12),char(255),char(174),char(1),char(97),char(0),char(15),char(255),char(133), -char(1),char(97),char(0),char(16),char(255),char(174),char(1),char(97),char(0),char(17), -char(255),char(133),char(1),char(97),char(1),char(86),char(255),char(92),char(1),char(97), -char(1),char(95),char(255),char(92),char(1),char(97),char(1),char(98),char(255),char(92), -char(1),char(97),char(1),char(102),char(255),char(195),char(1),char(97),char(1),char(105), -char(255),char(92),char(1),char(97),char(1),char(109),char(255),char(195),char(1),char(97), -char(1),char(115),char(255),char(154),char(1),char(97),char(1),char(118),char(255),char(195), -char(1),char(97),char(1),char(121),char(255),char(113),char(1),char(97),char(1),char(122), -char(255),char(154),char(1),char(97),char(1),char(123),char(255),char(154),char(1),char(97), -char(1),char(124),char(255),char(174),char(1),char(97),char(1),char(125),char(255),char(154), -char(1),char(97),char(1),char(126),char(255),char(113),char(1),char(97),char(1),char(128), -char(255),char(215),char(1),char(97),char(1),char(129),char(255),char(195),char(1),char(97), -char(1),char(130),char(255),char(154),char(1),char(97),char(1),char(132),char(255),char(154), -char(1),char(97),char(1),char(134),char(255),char(174),char(1),char(97),char(1),char(135), -char(255),char(154),char(1),char(97),char(1),char(137),char(255),char(154),char(1),char(97), -char(1),char(138),char(255),char(215),char(1),char(97),char(1),char(140),char(255),char(113), -char(1),char(97),char(1),char(142),char(255),char(154),char(1),char(97),char(1),char(143), -char(255),char(113),char(1),char(97),char(1),char(144),char(255),char(113),char(1),char(97), -char(1),char(146),char(255),char(154),char(1),char(97),char(1),char(147),char(255),char(113), -char(1),char(97),char(1),char(148),char(255),char(215),char(1),char(97),char(1),char(149), -char(255),char(154),char(1),char(97),char(1),char(150),char(255),char(154),char(1),char(97), -char(1),char(152),char(255),char(154),char(1),char(97),char(1),char(153),char(255),char(113), -char(1),char(97),char(1),char(154),char(255),char(154),char(1),char(97),char(1),char(155), -char(255),char(154),char(1),char(97),char(2),char(2),char(255),char(174),char(1),char(97), -char(2),char(3),char(255),char(174),char(1),char(97),char(2),char(4),char(255),char(174), -char(1),char(97),char(2),char(8),char(255),char(133),char(1),char(97),char(2),char(12), -char(255),char(133),char(1),char(97),char(2),char(33),char(255),char(195),char(1),char(97), -char(2),char(83),char(255),char(215),char(1),char(98),char(0),char(5),char(255),char(113), -char(1),char(98),char(0),char(10),char(255),char(113),char(1),char(98),char(1),char(102), -char(255),char(215),char(1),char(98),char(1),char(109),char(255),char(215),char(1),char(98), -char(1),char(113),char(255),char(113),char(1),char(98),char(1),char(114),char(255),char(133), -char(1),char(98),char(1),char(115),char(255),char(215),char(1),char(98),char(1),char(117), -char(255),char(174),char(1),char(98),char(1),char(120),char(255),char(133),char(1),char(98), -char(2),char(7),char(255),char(113),char(1),char(98),char(2),char(11),char(255),char(113), -char(1),char(98),char(2),char(84),char(255),char(133),char(1),char(100),char(1),char(102), -char(255),char(236),char(1),char(100),char(1),char(109),char(255),char(236),char(1),char(100), -char(1),char(115),char(255),char(195),char(1),char(102),char(0),char(15),char(255),char(174), -char(1),char(102),char(0),char(17),char(255),char(174),char(1),char(102),char(1),char(86), -char(255),char(215),char(1),char(102),char(1),char(95),char(255),char(215),char(1),char(102), -char(1),char(98),char(255),char(215),char(1),char(102),char(1),char(100),char(255),char(236), -char(1),char(102),char(1),char(105),char(255),char(215),char(1),char(102),char(1),char(112), -char(255),char(236),char(1),char(102),char(1),char(113),char(255),char(195),char(1),char(102), -char(1),char(114),char(255),char(236),char(1),char(102),char(1),char(116),char(255),char(215), -char(1),char(102),char(1),char(117),char(255),char(236),char(1),char(102),char(1),char(120), -char(255),char(236),char(1),char(102),char(1),char(136),char(255),char(236),char(1),char(102), -char(2),char(8),char(255),char(174),char(1),char(102),char(2),char(12),char(255),char(174), -char(1),char(102),char(2),char(84),char(255),char(236),char(1),char(104),char(1),char(102), -char(255),char(215),char(1),char(104),char(1),char(109),char(255),char(215),char(1),char(104), -char(1),char(115),char(255),char(195),char(1),char(104),char(1),char(141),char(255),char(236), -char(1),char(104),char(1),char(145),char(255),char(236),char(1),char(105),char(0),char(5), -char(255),char(113),char(1),char(105),char(0),char(10),char(255),char(113),char(1),char(105), -char(1),char(102),char(255),char(215),char(1),char(105),char(1),char(109),char(255),char(215), -char(1),char(105),char(1),char(113),char(255),char(113),char(1),char(105),char(1),char(114), -char(255),char(133),char(1),char(105),char(1),char(115),char(255),char(215),char(1),char(105), -char(1),char(117),char(255),char(174),char(1),char(105),char(1),char(120),char(255),char(133), -char(1),char(105),char(2),char(7),char(255),char(113),char(1),char(105),char(2),char(11), -char(255),char(113),char(1),char(105),char(2),char(84),char(255),char(133),char(1),char(109), -char(0),char(15),char(255),char(174),char(1),char(109),char(0),char(17),char(255),char(174), -char(1),char(109),char(1),char(86),char(255),char(215),char(1),char(109),char(1),char(95), -char(255),char(215),char(1),char(109),char(1),char(98),char(255),char(215),char(1),char(109), -char(1),char(100),char(255),char(236),char(1),char(109),char(1),char(105),char(255),char(215), -char(1),char(109),char(1),char(112),char(255),char(236),char(1),char(109),char(1),char(113), -char(255),char(195),char(1),char(109),char(1),char(114),char(255),char(236),char(1),char(109), -char(1),char(116),char(255),char(215),char(1),char(109),char(1),char(117),char(255),char(236), -char(1),char(109),char(1),char(120),char(255),char(236),char(1),char(109),char(1),char(136), -char(255),char(236),char(1),char(109),char(2),char(8),char(255),char(174),char(1),char(109), -char(2),char(12),char(255),char(174),char(1),char(109),char(2),char(84),char(255),char(236), -char(1),char(111),char(0),char(15),char(254),char(246),char(1),char(111),char(0),char(17), -char(254),char(246),char(1),char(111),char(1),char(86),char(255),char(154),char(1),char(111), -char(1),char(95),char(255),char(154),char(1),char(111),char(1),char(98),char(255),char(154), -char(1),char(111),char(1),char(100),char(255),char(236),char(1),char(111),char(1),char(105), -char(255),char(154),char(1),char(111),char(1),char(116),char(255),char(215),char(1),char(111), -char(1),char(136),char(255),char(215),char(1),char(111),char(2),char(8),char(254),char(246), -char(1),char(111),char(2),char(12),char(254),char(246),char(1),char(113),char(0),char(15), -char(255),char(133),char(1),char(113),char(0),char(16),char(255),char(174),char(1),char(113), -char(0),char(17),char(255),char(133),char(1),char(113),char(1),char(86),char(255),char(92), -char(1),char(113),char(1),char(95),char(255),char(92),char(1),char(113),char(1),char(98), -char(255),char(92),char(1),char(113),char(1),char(102),char(255),char(195),char(1),char(113), -char(1),char(105),char(255),char(92),char(1),char(113),char(1),char(109),char(255),char(195), -char(1),char(113),char(1),char(115),char(255),char(154),char(1),char(113),char(1),char(118), -char(255),char(195),char(1),char(113),char(1),char(121),char(255),char(113),char(1),char(113), -char(1),char(122),char(255),char(154),char(1),char(113),char(1),char(123),char(255),char(154), -char(1),char(113),char(1),char(124),char(255),char(174),char(1),char(113),char(1),char(125), -char(255),char(154),char(1),char(113),char(1),char(126),char(255),char(113),char(1),char(113), -char(1),char(128),char(255),char(215),char(1),char(113),char(1),char(129),char(255),char(195), -char(1),char(113),char(1),char(130),char(255),char(154),char(1),char(113),char(1),char(132), -char(255),char(154),char(1),char(113),char(1),char(134),char(255),char(174),char(1),char(113), -char(1),char(135),char(255),char(154),char(1),char(113),char(1),char(137),char(255),char(154), -char(1),char(113),char(1),char(138),char(255),char(215),char(1),char(113),char(1),char(140), -char(255),char(113),char(1),char(113),char(1),char(142),char(255),char(154),char(1),char(113), -char(1),char(143),char(255),char(113),char(1),char(113),char(1),char(144),char(255),char(113), -char(1),char(113),char(1),char(146),char(255),char(154),char(1),char(113),char(1),char(147), -char(255),char(113),char(1),char(113),char(1),char(148),char(255),char(215),char(1),char(113), -char(1),char(149),char(255),char(154),char(1),char(113),char(1),char(150),char(255),char(154), -char(1),char(113),char(1),char(152),char(255),char(154),char(1),char(113),char(1),char(153), -char(255),char(113),char(1),char(113),char(1),char(154),char(255),char(154),char(1),char(113), -char(1),char(155),char(255),char(154),char(1),char(113),char(2),char(2),char(255),char(174), -char(1),char(113),char(2),char(3),char(255),char(174),char(1),char(113),char(2),char(4), -char(255),char(174),char(1),char(113),char(2),char(8),char(255),char(133),char(1),char(113), -char(2),char(12),char(255),char(133),char(1),char(113),char(2),char(33),char(255),char(195), -char(1),char(113),char(2),char(83),char(255),char(215),char(1),char(114),char(0),char(15), -char(255),char(133),char(1),char(114),char(0),char(17),char(255),char(133),char(1),char(114), -char(1),char(86),char(255),char(133),char(1),char(114),char(1),char(95),char(255),char(133), -char(1),char(114),char(1),char(98),char(255),char(133),char(1),char(114),char(1),char(102), -char(255),char(215),char(1),char(114),char(1),char(105),char(255),char(133),char(1),char(114), -char(1),char(109),char(255),char(215),char(1),char(114),char(1),char(115),char(255),char(195), -char(1),char(114),char(1),char(118),char(255),char(236),char(1),char(114),char(1),char(121), -char(255),char(154),char(1),char(114),char(1),char(122),char(255),char(174),char(1),char(114), -char(1),char(123),char(255),char(195),char(1),char(114),char(1),char(124),char(255),char(195), -char(1),char(114),char(1),char(125),char(255),char(195),char(1),char(114),char(1),char(126), -char(255),char(154),char(1),char(114),char(1),char(129),char(255),char(195),char(1),char(114), -char(1),char(130),char(255),char(174),char(1),char(114),char(1),char(132),char(255),char(195), -char(1),char(114),char(1),char(134),char(255),char(195),char(1),char(114),char(1),char(135), -char(255),char(195),char(1),char(114),char(1),char(137),char(255),char(195),char(1),char(114), -char(1),char(140),char(255),char(154),char(1),char(114),char(1),char(142),char(255),char(154), -char(1),char(114),char(1),char(143),char(255),char(154),char(1),char(114),char(1),char(144), -char(255),char(154),char(1),char(114),char(1),char(146),char(255),char(195),char(1),char(114), -char(1),char(147),char(255),char(154),char(1),char(114),char(1),char(149),char(255),char(195), -char(1),char(114),char(1),char(150),char(255),char(195),char(1),char(114),char(1),char(152), -char(255),char(195),char(1),char(114),char(1),char(153),char(255),char(154),char(1),char(114), -char(1),char(154),char(255),char(195),char(1),char(114),char(1),char(155),char(255),char(195), -char(1),char(114),char(2),char(8),char(255),char(133),char(1),char(114),char(2),char(12), -char(255),char(133),char(1),char(114),char(2),char(33),char(255),char(236),char(1),char(115), -char(0),char(15),char(255),char(154),char(1),char(115),char(0),char(17),char(255),char(154), -char(1),char(115),char(1),char(86),char(255),char(215),char(1),char(115),char(1),char(95), -char(255),char(215),char(1),char(115),char(1),char(98),char(255),char(215),char(1),char(115), -char(1),char(100),char(255),char(195),char(1),char(115),char(1),char(105),char(255),char(215), -char(1),char(115),char(1),char(112),char(255),char(236),char(1),char(115),char(1),char(113), -char(255),char(174),char(1),char(115),char(1),char(114),char(255),char(195),char(1),char(115), -char(1),char(116),char(255),char(236),char(1),char(115),char(1),char(120),char(255),char(195), -char(1),char(115),char(1),char(136),char(255),char(236),char(1),char(115),char(2),char(8), -char(255),char(154),char(1),char(115),char(2),char(12),char(255),char(154),char(1),char(115), -char(2),char(84),char(255),char(195),char(1),char(116),char(1),char(102),char(255),char(215), -char(1),char(116),char(1),char(109),char(255),char(215),char(1),char(116),char(1),char(115), -char(255),char(195),char(1),char(116),char(1),char(141),char(255),char(236),char(1),char(116), -char(1),char(145),char(255),char(236),char(1),char(117),char(0),char(15),char(255),char(133), -char(1),char(117),char(0),char(17),char(255),char(133),char(1),char(117),char(1),char(86), -char(255),char(174),char(1),char(117),char(1),char(95),char(255),char(174),char(1),char(117), -char(1),char(98),char(255),char(174),char(1),char(117),char(1),char(102),char(255),char(236), -char(1),char(117),char(1),char(105),char(255),char(174),char(1),char(117),char(1),char(109), -char(255),char(236),char(1),char(117),char(2),char(8),char(255),char(133),char(1),char(117), -char(2),char(12),char(255),char(133),char(1),char(118),char(1),char(113),char(255),char(215), -char(1),char(118),char(1),char(114),char(255),char(236),char(1),char(118),char(1),char(120), -char(255),char(236),char(1),char(118),char(2),char(84),char(255),char(236),char(1),char(120), -char(0),char(15),char(255),char(133),char(1),char(120),char(0),char(17),char(255),char(133), -char(1),char(120),char(1),char(86),char(255),char(133),char(1),char(120),char(1),char(95), -char(255),char(133),char(1),char(120),char(1),char(98),char(255),char(133),char(1),char(120), -char(1),char(102),char(255),char(215),char(1),char(120),char(1),char(105),char(255),char(133), -char(1),char(120),char(1),char(109),char(255),char(215),char(1),char(120),char(1),char(115), -char(255),char(195),char(1),char(120),char(1),char(118),char(255),char(236),char(1),char(120), -char(1),char(121),char(255),char(154),char(1),char(120),char(1),char(122),char(255),char(174), -char(1),char(120),char(1),char(123),char(255),char(195),char(1),char(120),char(1),char(124), -char(255),char(195),char(1),char(120),char(1),char(125),char(255),char(195),char(1),char(120), -char(1),char(126),char(255),char(154),char(1),char(120),char(1),char(129),char(255),char(195), -char(1),char(120),char(1),char(130),char(255),char(174),char(1),char(120),char(1),char(132), -char(255),char(195),char(1),char(120),char(1),char(134),char(255),char(195),char(1),char(120), -char(1),char(135),char(255),char(195),char(1),char(120),char(1),char(137),char(255),char(195), -char(1),char(120),char(1),char(140),char(255),char(154),char(1),char(120),char(1),char(142), -char(255),char(154),char(1),char(120),char(1),char(143),char(255),char(154),char(1),char(120), -char(1),char(144),char(255),char(154),char(1),char(120),char(1),char(146),char(255),char(195), -char(1),char(120),char(1),char(147),char(255),char(154),char(1),char(120),char(1),char(149), -char(255),char(195),char(1),char(120),char(1),char(150),char(255),char(195),char(1),char(120), -char(1),char(152),char(255),char(195),char(1),char(120),char(1),char(153),char(255),char(154), -char(1),char(120),char(1),char(154),char(255),char(195),char(1),char(120),char(1),char(155), -char(255),char(195),char(1),char(120),char(2),char(8),char(255),char(133),char(1),char(120), -char(2),char(12),char(255),char(133),char(1),char(120),char(2),char(33),char(255),char(236), -char(1),char(121),char(1),char(136),char(0),char(41),char(1),char(123),char(0),char(5), -char(255),char(236),char(1),char(123),char(0),char(10),char(255),char(236),char(1),char(123), -char(2),char(7),char(255),char(236),char(1),char(123),char(2),char(11),char(255),char(236), -char(1),char(124),char(0),char(5),char(255),char(174),char(1),char(124),char(0),char(10), -char(255),char(174),char(1),char(124),char(1),char(141),char(255),char(236),char(1),char(124), -char(1),char(145),char(255),char(236),char(1),char(124),char(2),char(7),char(255),char(174), -char(1),char(124),char(2),char(11),char(255),char(174),char(1),char(126),char(1),char(136), -char(0),char(41),char(1),char(128),char(0),char(15),char(255),char(174),char(1),char(128), -char(0),char(17),char(255),char(174),char(1),char(128),char(1),char(136),char(255),char(236), -char(1),char(128),char(2),char(8),char(255),char(174),char(1),char(128),char(2),char(12), -char(255),char(174),char(1),char(131),char(0),char(16),char(255),char(154),char(1),char(131), -char(1),char(121),char(255),char(215),char(1),char(131),char(1),char(126),char(255),char(215), -char(1),char(131),char(1),char(129),char(255),char(215),char(1),char(131),char(1),char(140), -char(255),char(215),char(1),char(131),char(1),char(141),char(255),char(215),char(1),char(131), -char(1),char(143),char(255),char(215),char(1),char(131),char(1),char(144),char(255),char(215), -char(1),char(131),char(1),char(145),char(255),char(215),char(1),char(131),char(1),char(147), -char(255),char(215),char(1),char(131),char(1),char(153),char(255),char(215),char(1),char(131), -char(2),char(2),char(255),char(154),char(1),char(131),char(2),char(3),char(255),char(154), -char(1),char(131),char(2),char(4),char(255),char(154),char(1),char(132),char(0),char(5), -char(255),char(236),char(1),char(132),char(0),char(10),char(255),char(236),char(1),char(132), -char(2),char(7),char(255),char(236),char(1),char(132),char(2),char(11),char(255),char(236), -char(1),char(133),char(0),char(15),char(255),char(215),char(1),char(133),char(0),char(17), -char(255),char(215),char(1),char(133),char(2),char(8),char(255),char(215),char(1),char(133), -char(2),char(12),char(255),char(215),char(1),char(134),char(0),char(5),char(255),char(174), -char(1),char(134),char(0),char(10),char(255),char(174),char(1),char(134),char(1),char(141), -char(255),char(236),char(1),char(134),char(1),char(145),char(255),char(236),char(1),char(134), -char(2),char(7),char(255),char(174),char(1),char(134),char(2),char(11),char(255),char(174), -char(1),char(135),char(1),char(121),char(255),char(215),char(1),char(135),char(1),char(126), -char(255),char(215),char(1),char(135),char(1),char(140),char(255),char(215),char(1),char(135), -char(1),char(143),char(255),char(215),char(1),char(135),char(1),char(144),char(255),char(215), -char(1),char(135),char(1),char(147),char(255),char(215),char(1),char(135),char(1),char(153), -char(255),char(215),char(1),char(136),char(0),char(5),char(255),char(133),char(1),char(136), -char(0),char(10),char(255),char(133),char(1),char(136),char(1),char(121),char(255),char(236), -char(1),char(136),char(1),char(126),char(255),char(236),char(1),char(136),char(1),char(128), -char(255),char(215),char(1),char(136),char(1),char(138),char(255),char(215),char(1),char(136), -char(1),char(140),char(255),char(236),char(1),char(136),char(1),char(141),char(255),char(215), -char(1),char(136),char(1),char(143),char(255),char(236),char(1),char(136),char(1),char(144), -char(255),char(236),char(1),char(136),char(1),char(145),char(255),char(215),char(1),char(136), -char(1),char(147),char(255),char(236),char(1),char(136),char(1),char(153),char(255),char(236), -char(1),char(136),char(2),char(7),char(255),char(133),char(1),char(136),char(2),char(11), -char(255),char(133),char(1),char(138),char(0),char(15),char(255),char(174),char(1),char(138), -char(0),char(17),char(255),char(174),char(1),char(138),char(1),char(136),char(255),char(236), -char(1),char(138),char(2),char(8),char(255),char(174),char(1),char(138),char(2),char(12), -char(255),char(174),char(1),char(140),char(0),char(5),char(255),char(236),char(1),char(140), -char(0),char(10),char(255),char(236),char(1),char(140),char(1),char(128),char(255),char(215), -char(1),char(140),char(1),char(138),char(255),char(215),char(1),char(140),char(2),char(7), -char(255),char(236),char(1),char(140),char(2),char(11),char(255),char(236),char(1),char(142), -char(0),char(5),char(255),char(236),char(1),char(142),char(0),char(10),char(255),char(236), -char(1),char(142),char(1),char(128),char(255),char(215),char(1),char(142),char(1),char(138), -char(255),char(215),char(1),char(142),char(2),char(7),char(255),char(236),char(1),char(142), -char(2),char(11),char(255),char(236),char(1),char(144),char(0),char(15),char(255),char(236), -char(1),char(144),char(0),char(17),char(255),char(236),char(1),char(144),char(2),char(8), -char(255),char(236),char(1),char(144),char(2),char(12),char(255),char(236),char(1),char(147), -char(0),char(5),char(255),char(236),char(1),char(147),char(0),char(10),char(255),char(236), -char(1),char(147),char(1),char(128),char(255),char(215),char(1),char(147),char(1),char(138), -char(255),char(215),char(1),char(147),char(2),char(7),char(255),char(236),char(1),char(147), -char(2),char(11),char(255),char(236),char(1),char(148),char(0),char(15),char(255),char(195), -char(1),char(148),char(0),char(16),char(255),char(215),char(1),char(148),char(0),char(17), -char(255),char(195),char(1),char(148),char(1),char(121),char(255),char(215),char(1),char(148), -char(1),char(126),char(255),char(215),char(1),char(148),char(1),char(129),char(255),char(215), -char(1),char(148),char(1),char(140),char(255),char(215),char(1),char(148),char(1),char(143), -char(255),char(215),char(1),char(148),char(1),char(144),char(255),char(215),char(1),char(148), -char(1),char(147),char(255),char(215),char(1),char(148),char(1),char(153),char(255),char(215), -char(1),char(148),char(2),char(2),char(255),char(215),char(1),char(148),char(2),char(3), -char(255),char(215),char(1),char(148),char(2),char(4),char(255),char(215),char(1),char(148), -char(2),char(8),char(255),char(195),char(1),char(148),char(2),char(12),char(255),char(195), -char(1),char(151),char(0),char(5),char(255),char(215),char(1),char(151),char(0),char(10), -char(255),char(215),char(1),char(151),char(2),char(7),char(255),char(215),char(1),char(151), -char(2),char(11),char(255),char(215),char(1),char(153),char(0),char(5),char(255),char(236), -char(1),char(153),char(0),char(10),char(255),char(236),char(1),char(153),char(1),char(128), -char(255),char(215),char(1),char(153),char(1),char(138),char(255),char(215),char(1),char(153), -char(2),char(7),char(255),char(236),char(1),char(153),char(2),char(11),char(255),char(236), -char(1),char(157),char(0),char(5),char(255),char(174),char(1),char(157),char(0),char(10), -char(255),char(174),char(1),char(157),char(1),char(157),char(255),char(133),char(1),char(157), -char(1),char(166),char(255),char(133),char(1),char(157),char(1),char(168),char(255),char(215), -char(1),char(157),char(1),char(188),char(255),char(154),char(1),char(157),char(1),char(189), -char(255),char(215),char(1),char(157),char(1),char(193),char(255),char(154),char(1),char(157), -char(1),char(196),char(255),char(133),char(1),char(157),char(1),char(220),char(255),char(215), -char(1),char(157),char(1),char(221),char(255),char(215),char(1),char(157),char(1),char(225), -char(255),char(215),char(1),char(157),char(1),char(228),char(255),char(215),char(1),char(157), -char(1),char(246),char(255),char(215),char(1),char(157),char(2),char(7),char(255),char(174), -char(1),char(157),char(2),char(11),char(255),char(174),char(1),char(157),char(2),char(110), -char(255),char(174),char(1),char(157),char(2),char(124),char(255),char(154),char(1),char(157), -char(2),char(128),char(255),char(174),char(1),char(157),char(2),char(130),char(255),char(174), -char(1),char(157),char(2),char(151),char(255),char(174),char(1),char(157),char(2),char(155), -char(255),char(174),char(1),char(157),char(2),char(167),char(255),char(174),char(1),char(157), -char(2),char(169),char(255),char(133),char(1),char(157),char(2),char(170),char(255),char(215), -char(1),char(157),char(2),char(181),char(255),char(154),char(1),char(157),char(2),char(182), -char(255),char(215),char(1),char(157),char(2),char(183),char(255),char(154),char(1),char(157), -char(2),char(184),char(255),char(215),char(1),char(157),char(2),char(185),char(255),char(154), -char(1),char(157),char(2),char(186),char(255),char(215),char(1),char(157),char(2),char(189), -char(255),char(133),char(1),char(157),char(2),char(190),char(255),char(215),char(1),char(157), -char(2),char(191),char(255),char(154),char(1),char(157),char(2),char(192),char(255),char(215), -char(1),char(157),char(2),char(193),char(255),char(154),char(1),char(157),char(2),char(194), -char(255),char(215),char(1),char(157),char(2),char(212),char(255),char(154),char(1),char(157), -char(2),char(213),char(255),char(215),char(1),char(157),char(2),char(247),char(255),char(215), -char(1),char(157),char(2),char(248),char(255),char(215),char(1),char(157),char(2),char(249), -char(255),char(215),char(1),char(157),char(2),char(250),char(255),char(215),char(1),char(157), -char(2),char(251),char(255),char(215),char(1),char(157),char(2),char(252),char(255),char(215), -char(1),char(157),char(2),char(253),char(255),char(154),char(1),char(157),char(2),char(254), -char(255),char(215),char(1),char(157),char(3),char(3),char(255),char(174),char(1),char(157), -char(3),char(13),char(255),char(154),char(1),char(157),char(3),char(14),char(255),char(195), -char(1),char(157),char(3),char(15),char(255),char(154),char(1),char(157),char(3),char(16), -char(255),char(195),char(1),char(157),char(3),char(23),char(255),char(133),char(1),char(157), -char(3),char(24),char(255),char(215),char(1),char(158),char(0),char(15),char(255),char(133), -char(1),char(158),char(0),char(16),char(255),char(174),char(1),char(158),char(0),char(17), -char(255),char(133),char(1),char(158),char(1),char(159),char(255),char(215),char(1),char(158), -char(1),char(164),char(255),char(154),char(1),char(158),char(1),char(170),char(255),char(113), -char(1),char(158),char(1),char(174),char(255),char(154),char(1),char(158),char(1),char(181), -char(255),char(154),char(1),char(158),char(1),char(184),char(255),char(215),char(1),char(158), -char(1),char(187),char(255),char(215),char(1),char(158),char(1),char(188),char(0),char(41), -char(1),char(158),char(1),char(190),char(255),char(174),char(1),char(158),char(1),char(204), -char(255),char(154),char(1),char(158),char(1),char(205),char(255),char(154),char(1),char(158), -char(1),char(206),char(255),char(133),char(1),char(158),char(1),char(207),char(255),char(113), -char(1),char(158),char(1),char(208),char(255),char(215),char(1),char(158),char(1),char(209), -char(255),char(215),char(1),char(158),char(1),char(210),char(255),char(154),char(1),char(158), -char(1),char(211),char(255),char(154),char(1),char(158),char(1),char(212),char(255),char(154), -char(1),char(158),char(1),char(213),char(255),char(133),char(1),char(158),char(1),char(214), -char(255),char(154),char(1),char(158),char(1),char(215),char(255),char(154),char(1),char(158), -char(1),char(216),char(255),char(113),char(1),char(158),char(1),char(217),char(255),char(154), -char(1),char(158),char(1),char(218),char(255),char(154),char(1),char(158),char(1),char(219), -char(255),char(113),char(1),char(158),char(1),char(220),char(255),char(174),char(1),char(158), -char(1),char(221),char(255),char(174),char(1),char(158),char(1),char(222),char(255),char(113), -char(1),char(158),char(1),char(223),char(255),char(215),char(1),char(158),char(1),char(224), -char(255),char(154),char(1),char(158),char(1),char(225),char(255),char(154),char(1),char(158), -char(1),char(226),char(255),char(154),char(1),char(158),char(1),char(227),char(255),char(154), -char(1),char(158),char(1),char(228),char(255),char(174),char(1),char(158),char(1),char(229), -char(255),char(154),char(1),char(158),char(1),char(230),char(255),char(154),char(1),char(158), -char(1),char(231),char(255),char(215),char(1),char(158),char(1),char(232),char(255),char(154), -char(1),char(158),char(1),char(233),char(255),char(195),char(1),char(158),char(1),char(234), -char(255),char(113),char(1),char(158),char(1),char(236),char(255),char(154),char(1),char(158), -char(1),char(237),char(255),char(113),char(1),char(158),char(1),char(238),char(255),char(133), -char(1),char(158),char(1),char(242),char(255),char(133),char(1),char(158),char(1),char(243), -char(255),char(154),char(1),char(158),char(1),char(245),char(255),char(154),char(1),char(158), -char(1),char(246),char(255),char(174),char(1),char(158),char(1),char(247),char(255),char(154), -char(1),char(158),char(1),char(249),char(255),char(154),char(1),char(158),char(2),char(2), -char(255),char(174),char(1),char(158),char(2),char(3),char(255),char(174),char(1),char(158), -char(2),char(4),char(255),char(174),char(1),char(158),char(2),char(8),char(255),char(133), -char(1),char(158),char(2),char(12),char(255),char(133),char(1),char(158),char(2),char(106), -char(255),char(113),char(1),char(158),char(2),char(107),char(255),char(154),char(1),char(158), -char(2),char(108),char(255),char(215),char(1),char(158),char(2),char(109),char(255),char(215), -char(1),char(158),char(2),char(113),char(255),char(154),char(1),char(158),char(2),char(114), -char(255),char(113),char(1),char(158),char(2),char(115),char(255),char(133),char(1),char(158), -char(2),char(117),char(255),char(154),char(1),char(158),char(2),char(119),char(255),char(154), -char(1),char(158),char(2),char(121),char(255),char(154),char(1),char(158),char(2),char(125), -char(255),char(154),char(1),char(158),char(2),char(126),char(255),char(215),char(1),char(158), -char(2),char(127),char(255),char(113),char(1),char(158),char(2),char(129),char(255),char(215), -char(1),char(158),char(2),char(131),char(255),char(215),char(1),char(158),char(2),char(132), -char(255),char(215),char(1),char(158),char(2),char(133),char(255),char(113),char(1),char(158), -char(2),char(134),char(255),char(215),char(1),char(158),char(2),char(135),char(255),char(113), -char(1),char(158),char(2),char(136),char(255),char(215),char(1),char(158),char(2),char(137), -char(255),char(113),char(1),char(158),char(2),char(138),char(255),char(215),char(1),char(158), -char(2),char(139),char(255),char(215),char(1),char(158),char(2),char(140),char(255),char(215), -char(1),char(158),char(2),char(141),char(255),char(113),char(1),char(158),char(2),char(150), -char(255),char(154),char(1),char(158),char(2),char(154),char(255),char(154),char(1),char(158), -char(2),char(158),char(255),char(154),char(1),char(158),char(2),char(160),char(255),char(215), -char(1),char(158),char(2),char(162),char(255),char(215),char(1),char(158),char(2),char(164), -char(255),char(154),char(1),char(158),char(2),char(166),char(255),char(154),char(1),char(158), -char(2),char(170),char(255),char(174),char(1),char(158),char(2),char(172),char(255),char(154), -char(1),char(158),char(2),char(174),char(255),char(154),char(1),char(158),char(2),char(176), -char(255),char(154),char(1),char(158),char(2),char(177),char(255),char(215),char(1),char(158), -char(2),char(178),char(255),char(113),char(1),char(158),char(2),char(179),char(255),char(215), -char(1),char(158),char(2),char(180),char(255),char(113),char(1),char(158),char(2),char(181), -char(0),char(41),char(1),char(158),char(2),char(182),char(255),char(174),char(1),char(158), -char(2),char(184),char(255),char(174),char(1),char(158),char(2),char(186),char(255),char(174), -char(1),char(158),char(2),char(188),char(255),char(215),char(1),char(158),char(2),char(190), -char(255),char(174),char(1),char(158),char(2),char(192),char(255),char(154),char(1),char(158), -char(2),char(194),char(255),char(154),char(1),char(158),char(2),char(196),char(255),char(154), -char(1),char(158),char(2),char(197),char(255),char(154),char(1),char(158),char(2),char(198), -char(255),char(113),char(1),char(158),char(2),char(199),char(255),char(154),char(1),char(158), -char(2),char(200),char(255),char(113),char(1),char(158),char(2),char(203),char(255),char(215), -char(1),char(158),char(2),char(205),char(255),char(154),char(1),char(158),char(2),char(206), -char(255),char(154),char(1),char(158),char(2),char(207),char(255),char(133),char(1),char(158), -char(2),char(209),char(255),char(154),char(1),char(158),char(2),char(211),char(255),char(154), -char(1),char(158),char(2),char(213),char(255),char(154),char(1),char(158),char(2),char(215), -char(255),char(154),char(1),char(158),char(2),char(217),char(255),char(113),char(1),char(158), -char(2),char(219),char(255),char(113),char(1),char(158),char(2),char(221),char(255),char(113), -char(1),char(158),char(2),char(224),char(255),char(113),char(1),char(158),char(2),char(230), -char(255),char(215),char(1),char(158),char(2),char(232),char(255),char(215),char(1),char(158), -char(2),char(234),char(255),char(195),char(1),char(158),char(2),char(236),char(255),char(154), -char(1),char(158),char(2),char(238),char(255),char(154),char(1),char(158),char(2),char(239), -char(255),char(215),char(1),char(158),char(2),char(240),char(255),char(113),char(1),char(158), -char(2),char(241),char(255),char(215),char(1),char(158),char(2),char(242),char(255),char(113), -char(1),char(158),char(2),char(243),char(255),char(215),char(1),char(158),char(2),char(244), -char(255),char(113),char(1),char(158),char(2),char(246),char(255),char(215),char(1),char(158), -char(2),char(248),char(255),char(174),char(1),char(158),char(2),char(250),char(255),char(174), -char(1),char(158),char(2),char(252),char(255),char(174),char(1),char(158),char(2),char(254), -char(255),char(154),char(1),char(158),char(3),char(0),char(255),char(154),char(1),char(158), -char(3),char(2),char(255),char(154),char(1),char(158),char(3),char(6),char(255),char(215), -char(1),char(158),char(3),char(8),char(255),char(215),char(1),char(158),char(3),char(9), -char(255),char(113),char(1),char(158),char(3),char(10),char(255),char(113),char(1),char(158), -char(3),char(11),char(255),char(113),char(1),char(158),char(3),char(12),char(255),char(113), -char(1),char(158),char(3),char(14),char(255),char(154),char(1),char(158),char(3),char(16), -char(255),char(154),char(1),char(158),char(3),char(17),char(255),char(154),char(1),char(158), -char(3),char(18),char(255),char(133),char(1),char(158),char(3),char(20),char(255),char(154), -char(1),char(158),char(3),char(21),char(255),char(215),char(1),char(158),char(3),char(22), -char(255),char(113),char(1),char(158),char(3),char(24),char(255),char(174),char(1),char(158), -char(3),char(26),char(255),char(113),char(1),char(158),char(3),char(27),char(255),char(154), -char(1),char(158),char(3),char(28),char(255),char(133),char(1),char(159),char(1),char(159), -char(255),char(215),char(1),char(159),char(1),char(184),char(255),char(215),char(1),char(159), -char(1),char(187),char(255),char(215),char(1),char(159),char(1),char(190),char(255),char(215), -char(1),char(159),char(1),char(225),char(255),char(215),char(1),char(159),char(2),char(108), -char(255),char(215),char(1),char(159),char(2),char(126),char(255),char(215),char(1),char(159), -char(2),char(132),char(255),char(215),char(1),char(159),char(2),char(134),char(255),char(215), -char(1),char(159),char(2),char(136),char(255),char(215),char(1),char(159),char(2),char(138), -char(255),char(215),char(1),char(159),char(2),char(140),char(255),char(215),char(1),char(159), -char(2),char(177),char(255),char(215),char(1),char(159),char(2),char(179),char(255),char(215), -char(1),char(159),char(2),char(192),char(255),char(215),char(1),char(159),char(2),char(194), -char(255),char(215),char(1),char(159),char(2),char(197),char(255),char(215),char(1),char(159), -char(2),char(199),char(255),char(215),char(1),char(159),char(2),char(213),char(255),char(215), -char(1),char(159),char(2),char(239),char(255),char(215),char(1),char(159),char(2),char(241), -char(255),char(215),char(1),char(159),char(2),char(243),char(255),char(215),char(1),char(159), -char(2),char(254),char(255),char(215),char(1),char(159),char(3),char(9),char(255),char(215), -char(1),char(159),char(3),char(11),char(255),char(215),char(1),char(159),char(3),char(14), -char(255),char(215),char(1),char(159),char(3),char(16),char(255),char(215),char(1),char(159), -char(3),char(21),char(255),char(215),char(1),char(160),char(3),char(14),char(255),char(215), -char(1),char(160),char(3),char(16),char(255),char(215),char(1),char(164),char(0),char(5), -char(255),char(174),char(1),char(164),char(0),char(10),char(255),char(174),char(1),char(164), -char(1),char(157),char(255),char(133),char(1),char(164),char(1),char(166),char(255),char(133), -char(1),char(164),char(1),char(168),char(255),char(215),char(1),char(164),char(1),char(188), -char(255),char(154),char(1),char(164),char(1),char(189),char(255),char(215),char(1),char(164), -char(1),char(193),char(255),char(154),char(1),char(164),char(1),char(196),char(255),char(133), -char(1),char(164),char(1),char(220),char(255),char(215),char(1),char(164),char(1),char(221), -char(255),char(215),char(1),char(164),char(1),char(225),char(255),char(215),char(1),char(164), -char(1),char(228),char(255),char(215),char(1),char(164),char(1),char(246),char(255),char(215), -char(1),char(164),char(2),char(7),char(255),char(174),char(1),char(164),char(2),char(11), -char(255),char(174),char(1),char(164),char(2),char(110),char(255),char(174),char(1),char(164), -char(2),char(124),char(255),char(154),char(1),char(164),char(2),char(128),char(255),char(174), -char(1),char(164),char(2),char(130),char(255),char(174),char(1),char(164),char(2),char(151), -char(255),char(174),char(1),char(164),char(2),char(155),char(255),char(174),char(1),char(164), -char(2),char(167),char(255),char(174),char(1),char(164),char(2),char(169),char(255),char(133), -char(1),char(164),char(2),char(170),char(255),char(215),char(1),char(164),char(2),char(181), -char(255),char(154),char(1),char(164),char(2),char(182),char(255),char(215),char(1),char(164), -char(2),char(183),char(255),char(154),char(1),char(164),char(2),char(184),char(255),char(215), -char(1),char(164),char(2),char(185),char(255),char(154),char(1),char(164),char(2),char(186), -char(255),char(215),char(1),char(164),char(2),char(189),char(255),char(133),char(1),char(164), -char(2),char(190),char(255),char(215),char(1),char(164),char(2),char(191),char(255),char(154), -char(1),char(164),char(2),char(192),char(255),char(215),char(1),char(164),char(2),char(193), -char(255),char(154),char(1),char(164),char(2),char(194),char(255),char(215),char(1),char(164), -char(2),char(212),char(255),char(154),char(1),char(164),char(2),char(213),char(255),char(215), -char(1),char(164),char(2),char(247),char(255),char(215),char(1),char(164),char(2),char(248), -char(255),char(215),char(1),char(164),char(2),char(249),char(255),char(215),char(1),char(164), -char(2),char(250),char(255),char(215),char(1),char(164),char(2),char(251),char(255),char(215), -char(1),char(164),char(2),char(252),char(255),char(215),char(1),char(164),char(2),char(253), -char(255),char(154),char(1),char(164),char(2),char(254),char(255),char(215),char(1),char(164), -char(3),char(3),char(255),char(174),char(1),char(164),char(3),char(13),char(255),char(154), -char(1),char(164),char(3),char(14),char(255),char(195),char(1),char(164),char(3),char(15), -char(255),char(154),char(1),char(164),char(3),char(16),char(255),char(195),char(1),char(164), -char(3),char(23),char(255),char(133),char(1),char(164),char(3),char(24),char(255),char(215), -char(1),char(165),char(0),char(5),char(255),char(174),char(1),char(165),char(0),char(10), -char(255),char(174),char(1),char(165),char(1),char(157),char(255),char(133),char(1),char(165), -char(1),char(166),char(255),char(133),char(1),char(165),char(1),char(168),char(255),char(215), -char(1),char(165),char(1),char(188),char(255),char(154),char(1),char(165),char(1),char(189), -char(255),char(215),char(1),char(165),char(1),char(193),char(255),char(154),char(1),char(165), -char(1),char(196),char(255),char(133),char(1),char(165),char(1),char(220),char(255),char(215), -char(1),char(165),char(1),char(221),char(255),char(215),char(1),char(165),char(1),char(225), -char(255),char(215),char(1),char(165),char(1),char(228),char(255),char(215),char(1),char(165), -char(1),char(246),char(255),char(215),char(1),char(165),char(2),char(7),char(255),char(174), -char(1),char(165),char(2),char(11),char(255),char(174),char(1),char(165),char(2),char(110), -char(255),char(174),char(1),char(165),char(2),char(124),char(255),char(154),char(1),char(165), -char(2),char(128),char(255),char(174),char(1),char(165),char(2),char(130),char(255),char(174), -char(1),char(165),char(2),char(151),char(255),char(174),char(1),char(165),char(2),char(155), -char(255),char(174),char(1),char(165),char(2),char(167),char(255),char(174),char(1),char(165), -char(2),char(169),char(255),char(133),char(1),char(165),char(2),char(170),char(255),char(215), -char(1),char(165),char(2),char(181),char(255),char(154),char(1),char(165),char(2),char(182), -char(255),char(215),char(1),char(165),char(2),char(183),char(255),char(154),char(1),char(165), -char(2),char(184),char(255),char(215),char(1),char(165),char(2),char(185),char(255),char(154), -char(1),char(165),char(2),char(186),char(255),char(215),char(1),char(165),char(2),char(189), -char(255),char(133),char(1),char(165),char(2),char(190),char(255),char(215),char(1),char(165), -char(2),char(191),char(255),char(154),char(1),char(165),char(2),char(192),char(255),char(215), -char(1),char(165),char(2),char(193),char(255),char(154),char(1),char(165),char(2),char(194), -char(255),char(215),char(1),char(165),char(2),char(212),char(255),char(154),char(1),char(165), -char(2),char(213),char(255),char(215),char(1),char(165),char(2),char(247),char(255),char(215), -char(1),char(165),char(2),char(248),char(255),char(215),char(1),char(165),char(2),char(249), -char(255),char(215),char(1),char(165),char(2),char(250),char(255),char(215),char(1),char(165), -char(2),char(251),char(255),char(215),char(1),char(165),char(2),char(252),char(255),char(215), -char(1),char(165),char(2),char(253),char(255),char(154),char(1),char(165),char(2),char(254), -char(255),char(215),char(1),char(165),char(3),char(3),char(255),char(174),char(1),char(165), -char(3),char(13),char(255),char(154),char(1),char(165),char(3),char(14),char(255),char(195), -char(1),char(165),char(3),char(15),char(255),char(154),char(1),char(165),char(3),char(16), -char(255),char(195),char(1),char(165),char(3),char(23),char(255),char(133),char(1),char(165), -char(3),char(24),char(255),char(215),char(1),char(166),char(0),char(5),char(255),char(174), -char(1),char(166),char(0),char(10),char(255),char(174),char(1),char(166),char(1),char(157), -char(255),char(133),char(1),char(166),char(1),char(166),char(255),char(133),char(1),char(166), -char(1),char(168),char(255),char(215),char(1),char(166),char(1),char(188),char(255),char(154), -char(1),char(166),char(1),char(189),char(255),char(215),char(1),char(166),char(1),char(193), -char(255),char(154),char(1),char(166),char(1),char(196),char(255),char(133),char(1),char(166), -char(1),char(220),char(255),char(215),char(1),char(166),char(1),char(221),char(255),char(215), -char(1),char(166),char(1),char(225),char(255),char(215),char(1),char(166),char(1),char(228), -char(255),char(215),char(1),char(166),char(1),char(246),char(255),char(215),char(1),char(166), -char(2),char(7),char(255),char(174),char(1),char(166),char(2),char(11),char(255),char(174), -char(1),char(166),char(2),char(110),char(255),char(174),char(1),char(166),char(2),char(124), -char(255),char(154),char(1),char(166),char(2),char(128),char(255),char(174),char(1),char(166), -char(2),char(130),char(255),char(174),char(1),char(166),char(2),char(151),char(255),char(174), -char(1),char(166),char(2),char(155),char(255),char(174),char(1),char(166),char(2),char(167), -char(255),char(174),char(1),char(166),char(2),char(169),char(255),char(133),char(1),char(166), -char(2),char(170),char(255),char(215),char(1),char(166),char(2),char(181),char(255),char(154), -char(1),char(166),char(2),char(182),char(255),char(215),char(1),char(166),char(2),char(183), -char(255),char(154),char(1),char(166),char(2),char(184),char(255),char(215),char(1),char(166), -char(2),char(185),char(255),char(154),char(1),char(166),char(2),char(186),char(255),char(215), -char(1),char(166),char(2),char(189),char(255),char(133),char(1),char(166),char(2),char(190), -char(255),char(215),char(1),char(166),char(2),char(191),char(255),char(154),char(1),char(166), -char(2),char(192),char(255),char(215),char(1),char(166),char(2),char(193),char(255),char(154), -char(1),char(166),char(2),char(194),char(255),char(215),char(1),char(166),char(2),char(212), -char(255),char(154),char(1),char(166),char(2),char(213),char(255),char(215),char(1),char(166), -char(2),char(247),char(255),char(215),char(1),char(166),char(2),char(248),char(255),char(215), -char(1),char(166),char(2),char(249),char(255),char(215),char(1),char(166),char(2),char(250), -char(255),char(215),char(1),char(166),char(2),char(251),char(255),char(215),char(1),char(166), -char(2),char(252),char(255),char(215),char(1),char(166),char(2),char(253),char(255),char(154), -char(1),char(166),char(2),char(254),char(255),char(215),char(1),char(166),char(3),char(3), -char(255),char(174),char(1),char(166),char(3),char(13),char(255),char(154),char(1),char(166), -char(3),char(14),char(255),char(195),char(1),char(166),char(3),char(15),char(255),char(154), -char(1),char(166),char(3),char(16),char(255),char(195),char(1),char(166),char(3),char(23), -char(255),char(133),char(1),char(166),char(3),char(24),char(255),char(215),char(1),char(167), -char(1),char(159),char(255),char(215),char(1),char(167),char(1),char(184),char(255),char(215), -char(1),char(167),char(1),char(187),char(255),char(215),char(1),char(167),char(1),char(190), -char(255),char(215),char(1),char(167),char(1),char(193),char(255),char(215),char(1),char(167), -char(1),char(225),char(255),char(215),char(1),char(167),char(2),char(108),char(255),char(215), -char(1),char(167),char(2),char(124),char(255),char(215),char(1),char(167),char(2),char(126), -char(255),char(215),char(1),char(167),char(2),char(132),char(255),char(215),char(1),char(167), -char(2),char(134),char(255),char(215),char(1),char(167),char(2),char(136),char(255),char(215), -char(1),char(167),char(2),char(138),char(255),char(215),char(1),char(167),char(2),char(140), -char(255),char(215),char(1),char(167),char(2),char(177),char(255),char(215),char(1),char(167), -char(2),char(179),char(255),char(215),char(1),char(167),char(2),char(191),char(255),char(215), -char(1),char(167),char(2),char(192),char(255),char(215),char(1),char(167),char(2),char(193), -char(255),char(215),char(1),char(167),char(2),char(194),char(255),char(215),char(1),char(167), -char(2),char(197),char(255),char(154),char(1),char(167),char(2),char(199),char(255),char(154), -char(1),char(167),char(2),char(212),char(255),char(215),char(1),char(167),char(2),char(213), -char(255),char(215),char(1),char(167),char(2),char(239),char(255),char(215),char(1),char(167), -char(2),char(241),char(255),char(215),char(1),char(167),char(2),char(243),char(255),char(215), -char(1),char(167),char(2),char(253),char(255),char(215),char(1),char(167),char(2),char(254), -char(255),char(215),char(1),char(167),char(3),char(9),char(255),char(215),char(1),char(167), -char(3),char(11),char(255),char(215),char(1),char(167),char(3),char(14),char(255),char(215), -char(1),char(167),char(3),char(16),char(255),char(215),char(1),char(167),char(3),char(21), -char(255),char(215),char(1),char(167),char(3),char(25),char(255),char(236),char(1),char(168), -char(0),char(15),char(255),char(133),char(1),char(168),char(0),char(17),char(255),char(133), -char(1),char(168),char(1),char(159),char(255),char(236),char(1),char(168),char(1),char(164), -char(255),char(154),char(1),char(168),char(1),char(170),char(255),char(113),char(1),char(168), -char(1),char(174),char(255),char(154),char(1),char(168),char(1),char(181),char(255),char(154), -char(1),char(168),char(1),char(184),char(255),char(236),char(1),char(168),char(1),char(187), -char(255),char(236),char(1),char(168),char(1),char(190),char(255),char(195),char(1),char(168), -char(1),char(201),char(255),char(236),char(1),char(168),char(1),char(206),char(255),char(174), -char(1),char(168),char(1),char(207),char(255),char(215),char(1),char(168),char(1),char(213), -char(255),char(174),char(1),char(168),char(1),char(216),char(255),char(215),char(1),char(168), -char(1),char(219),char(255),char(215),char(1),char(168),char(1),char(222),char(255),char(215), -char(1),char(168),char(1),char(225),char(255),char(215),char(1),char(168),char(1),char(234), -char(255),char(215),char(1),char(168),char(1),char(235),char(0),char(102),char(1),char(168), -char(1),char(237),char(255),char(215),char(1),char(168),char(1),char(238),char(255),char(236), -char(1),char(168),char(1),char(242),char(255),char(174),char(1),char(168),char(1),char(244), -char(0),char(102),char(1),char(168),char(2),char(8),char(255),char(133),char(1),char(168), -char(2),char(12),char(255),char(133),char(1),char(168),char(2),char(106),char(255),char(215), -char(1),char(168),char(2),char(108),char(255),char(236),char(1),char(168),char(2),char(114), -char(255),char(113),char(1),char(168),char(2),char(115),char(255),char(174),char(1),char(168), -char(2),char(126),char(255),char(236),char(1),char(168),char(2),char(127),char(255),char(215), -char(1),char(168),char(2),char(132),char(255),char(236),char(1),char(168),char(2),char(133), -char(255),char(215),char(1),char(168),char(2),char(134),char(255),char(236),char(1),char(168), -char(2),char(135),char(255),char(215),char(1),char(168),char(2),char(136),char(255),char(236), -char(1),char(168),char(2),char(137),char(255),char(215),char(1),char(168),char(2),char(138), -char(255),char(236),char(1),char(168),char(2),char(140),char(255),char(236),char(1),char(168), -char(2),char(141),char(255),char(215),char(1),char(168),char(2),char(152),char(0),char(102), -char(1),char(168),char(2),char(168),char(0),char(102),char(1),char(168),char(2),char(177), -char(255),char(236),char(1),char(168),char(2),char(178),char(255),char(215),char(1),char(168), -char(2),char(179),char(255),char(236),char(1),char(168),char(2),char(180),char(255),char(215), -char(1),char(168),char(2),char(192),char(255),char(215),char(1),char(168),char(2),char(194), -char(255),char(215),char(1),char(168),char(2),char(197),char(255),char(215),char(1),char(168), -char(2),char(198),char(255),char(195),char(1),char(168),char(2),char(199),char(255),char(215), -char(1),char(168),char(2),char(200),char(255),char(195),char(1),char(168),char(2),char(206), -char(255),char(154),char(1),char(168),char(2),char(207),char(255),char(174),char(1),char(168), -char(2),char(213),char(255),char(215),char(1),char(168),char(2),char(217),char(255),char(113), -char(1),char(168),char(2),char(219),char(255),char(113),char(1),char(168),char(2),char(221), -char(255),char(113),char(1),char(168),char(2),char(224),char(255),char(215),char(1),char(168), -char(2),char(239),char(255),char(236),char(1),char(168),char(2),char(240),char(255),char(215), -char(1),char(168),char(2),char(241),char(255),char(236),char(1),char(168),char(2),char(242), -char(255),char(215),char(1),char(168),char(2),char(243),char(255),char(236),char(1),char(168), -char(2),char(244),char(255),char(215),char(1),char(168),char(2),char(254),char(255),char(215), -char(1),char(168),char(3),char(9),char(255),char(113),char(1),char(168),char(3),char(10), -char(255),char(215),char(1),char(168),char(3),char(11),char(255),char(113),char(1),char(168), -char(3),char(12),char(255),char(215),char(1),char(168),char(3),char(17),char(255),char(154), -char(1),char(168),char(3),char(18),char(255),char(174),char(1),char(168),char(3),char(21), -char(255),char(236),char(1),char(168),char(3),char(22),char(255),char(215),char(1),char(168), -char(3),char(26),char(255),char(215),char(1),char(168),char(3),char(27),char(255),char(154), -char(1),char(168),char(3),char(28),char(255),char(174),char(1),char(170),char(0),char(5), -char(255),char(113),char(1),char(170),char(0),char(10),char(255),char(113),char(1),char(170), -char(1),char(157),char(255),char(154),char(1),char(170),char(1),char(166),char(255),char(154), -char(1),char(170),char(1),char(188),char(255),char(113),char(1),char(170),char(1),char(190), -char(255),char(215),char(1),char(170),char(1),char(193),char(255),char(154),char(1),char(170), -char(1),char(196),char(255),char(154),char(1),char(170),char(1),char(220),char(255),char(215), -char(1),char(170),char(1),char(225),char(255),char(215),char(1),char(170),char(1),char(228), -char(255),char(215),char(1),char(170),char(2),char(7),char(255),char(113),char(1),char(170), -char(2),char(11),char(255),char(113),char(1),char(170),char(2),char(110),char(255),char(215), -char(1),char(170),char(2),char(124),char(255),char(154),char(1),char(170),char(2),char(128), -char(255),char(174),char(1),char(170),char(2),char(130),char(255),char(174),char(1),char(170), -char(2),char(151),char(255),char(215),char(1),char(170),char(2),char(155),char(255),char(215), -char(1),char(170),char(2),char(167),char(255),char(215),char(1),char(170),char(2),char(169), -char(255),char(154),char(1),char(170),char(2),char(170),char(255),char(215),char(1),char(170), -char(2),char(181),char(255),char(113),char(1),char(170),char(2),char(182),char(255),char(215), -char(1),char(170),char(2),char(183),char(255),char(133),char(1),char(170),char(2),char(185), -char(255),char(133),char(1),char(170),char(2),char(189),char(255),char(154),char(1),char(170), -char(2),char(190),char(255),char(215),char(1),char(170),char(2),char(191),char(255),char(154), -char(1),char(170),char(2),char(192),char(255),char(215),char(1),char(170),char(2),char(193), -char(255),char(154),char(1),char(170),char(2),char(194),char(255),char(215),char(1),char(170), -char(2),char(197),char(255),char(154),char(1),char(170),char(2),char(199),char(255),char(154), -char(1),char(170),char(2),char(212),char(255),char(154),char(1),char(170),char(2),char(213), -char(255),char(215),char(1),char(170),char(2),char(225),char(255),char(215),char(1),char(170), -char(2),char(227),char(255),char(215),char(1),char(170),char(2),char(253),char(255),char(154), -char(1),char(170),char(2),char(254),char(255),char(215),char(1),char(170),char(3),char(3), -char(255),char(215),char(1),char(170),char(3),char(13),char(255),char(113),char(1),char(170), -char(3),char(14),char(255),char(215),char(1),char(170),char(3),char(15),char(255),char(113), -char(1),char(170),char(3),char(16),char(255),char(215),char(1),char(170),char(3),char(23), -char(255),char(154),char(1),char(170),char(3),char(24),char(255),char(215),char(1),char(171), -char(0),char(5),char(255),char(215),char(1),char(171),char(0),char(10),char(255),char(215), -char(1),char(171),char(1),char(170),char(255),char(236),char(1),char(171),char(1),char(193), -char(255),char(215),char(1),char(171),char(2),char(7),char(255),char(215),char(1),char(171), -char(2),char(11),char(255),char(215),char(1),char(171),char(2),char(114),char(255),char(236), -char(1),char(171),char(2),char(124),char(255),char(215),char(1),char(171),char(2),char(191), -char(255),char(215),char(1),char(171),char(2),char(193),char(255),char(215),char(1),char(171), -char(2),char(197),char(255),char(215),char(1),char(171),char(2),char(199),char(255),char(215), -char(1),char(171),char(2),char(212),char(255),char(215),char(1),char(171),char(2),char(217), -char(255),char(236),char(1),char(171),char(2),char(219),char(255),char(236),char(1),char(171), -char(2),char(221),char(255),char(236),char(1),char(171),char(2),char(253),char(255),char(215), -char(1),char(172),char(0),char(15),char(255),char(174),char(1),char(172),char(0),char(17), -char(255),char(174),char(1),char(172),char(2),char(8),char(255),char(174),char(1),char(172), -char(2),char(12),char(255),char(174),char(1),char(172),char(2),char(128),char(255),char(236), -char(1),char(172),char(2),char(130),char(255),char(236),char(1),char(172),char(2),char(183), -char(255),char(236),char(1),char(172),char(2),char(185),char(255),char(236),char(1),char(172), -char(3),char(13),char(255),char(215),char(1),char(172),char(3),char(15),char(255),char(215), -char(1),char(173),char(0),char(15),char(255),char(133),char(1),char(173),char(0),char(16), -char(255),char(174),char(1),char(173),char(0),char(17),char(255),char(133),char(1),char(173), -char(1),char(159),char(255),char(215),char(1),char(173),char(1),char(164),char(255),char(154), -char(1),char(173),char(1),char(170),char(255),char(113),char(1),char(173),char(1),char(174), -char(255),char(154),char(1),char(173),char(1),char(181),char(255),char(154),char(1),char(173), -char(1),char(184),char(255),char(215),char(1),char(173),char(1),char(187),char(255),char(215), -char(1),char(173),char(1),char(188),char(0),char(41),char(1),char(173),char(1),char(190), -char(255),char(174),char(1),char(173),char(1),char(204),char(255),char(154),char(1),char(173), -char(1),char(205),char(255),char(154),char(1),char(173),char(1),char(206),char(255),char(133), -char(1),char(173),char(1),char(207),char(255),char(113),char(1),char(173),char(1),char(208), -char(255),char(215),char(1),char(173),char(1),char(209),char(255),char(215),char(1),char(173), -char(1),char(210),char(255),char(154),char(1),char(173),char(1),char(211),char(255),char(154), -char(1),char(173),char(1),char(212),char(255),char(154),char(1),char(173),char(1),char(213), -char(255),char(133),char(1),char(173),char(1),char(214),char(255),char(154),char(1),char(173), -char(1),char(215),char(255),char(154),char(1),char(173),char(1),char(216),char(255),char(113), -char(1),char(173),char(1),char(217),char(255),char(154),char(1),char(173),char(1),char(218), -char(255),char(154),char(1),char(173),char(1),char(219),char(255),char(113),char(1),char(173), -char(1),char(220),char(255),char(174),char(1),char(173),char(1),char(221),char(255),char(174), -char(1),char(173),char(1),char(222),char(255),char(113),char(1),char(173),char(1),char(223), -char(255),char(215),char(1),char(173),char(1),char(224),char(255),char(154),char(1),char(173), -char(1),char(225),char(255),char(154),char(1),char(173),char(1),char(226),char(255),char(154), -char(1),char(173),char(1),char(227),char(255),char(154),char(1),char(173),char(1),char(228), -char(255),char(174),char(1),char(173),char(1),char(229),char(255),char(154),char(1),char(173), -char(1),char(230),char(255),char(154),char(1),char(173),char(1),char(231),char(255),char(215), -char(1),char(173),char(1),char(232),char(255),char(154),char(1),char(173),char(1),char(233), -char(255),char(195),char(1),char(173),char(1),char(234),char(255),char(113),char(1),char(173), -char(1),char(236),char(255),char(154),char(1),char(173),char(1),char(237),char(255),char(113), -char(1),char(173),char(1),char(238),char(255),char(133),char(1),char(173),char(1),char(242), -char(255),char(133),char(1),char(173),char(1),char(243),char(255),char(154),char(1),char(173), -char(1),char(245),char(255),char(154),char(1),char(173),char(1),char(246),char(255),char(174), -char(1),char(173),char(1),char(247),char(255),char(154),char(1),char(173),char(1),char(249), -char(255),char(154),char(1),char(173),char(2),char(2),char(255),char(174),char(1),char(173), -char(2),char(3),char(255),char(174),char(1),char(173),char(2),char(4),char(255),char(174), -char(1),char(173),char(2),char(8),char(255),char(133),char(1),char(173),char(2),char(12), -char(255),char(133),char(1),char(173),char(2),char(106),char(255),char(113),char(1),char(173), -char(2),char(107),char(255),char(154),char(1),char(173),char(2),char(108),char(255),char(215), -char(1),char(173),char(2),char(109),char(255),char(215),char(1),char(173),char(2),char(113), -char(255),char(154),char(1),char(173),char(2),char(114),char(255),char(113),char(1),char(173), -char(2),char(115),char(255),char(133),char(1),char(173),char(2),char(117),char(255),char(154), -char(1),char(173),char(2),char(119),char(255),char(154),char(1),char(173),char(2),char(121), -char(255),char(154),char(1),char(173),char(2),char(125),char(255),char(154),char(1),char(173), -char(2),char(126),char(255),char(215),char(1),char(173),char(2),char(127),char(255),char(113), -char(1),char(173),char(2),char(129),char(255),char(215),char(1),char(173),char(2),char(131), -char(255),char(215),char(1),char(173),char(2),char(132),char(255),char(215),char(1),char(173), -char(2),char(133),char(255),char(113),char(1),char(173),char(2),char(134),char(255),char(215), -char(1),char(173),char(2),char(135),char(255),char(113),char(1),char(173),char(2),char(136), -char(255),char(215),char(1),char(173),char(2),char(137),char(255),char(113),char(1),char(173), -char(2),char(138),char(255),char(215),char(1),char(173),char(2),char(139),char(255),char(215), -char(1),char(173),char(2),char(140),char(255),char(215),char(1),char(173),char(2),char(141), -char(255),char(113),char(1),char(173),char(2),char(150),char(255),char(154),char(1),char(173), -char(2),char(154),char(255),char(154),char(1),char(173),char(2),char(158),char(255),char(154), -char(1),char(173),char(2),char(160),char(255),char(215),char(1),char(173),char(2),char(162), -char(255),char(215),char(1),char(173),char(2),char(164),char(255),char(154),char(1),char(173), -char(2),char(166),char(255),char(154),char(1),char(173),char(2),char(170),char(255),char(174), -char(1),char(173),char(2),char(172),char(255),char(154),char(1),char(173),char(2),char(174), -char(255),char(154),char(1),char(173),char(2),char(176),char(255),char(154),char(1),char(173), -char(2),char(177),char(255),char(215),char(1),char(173),char(2),char(178),char(255),char(113), -char(1),char(173),char(2),char(179),char(255),char(215),char(1),char(173),char(2),char(180), -char(255),char(113),char(1),char(173),char(2),char(181),char(0),char(41),char(1),char(173), -char(2),char(182),char(255),char(174),char(1),char(173),char(2),char(184),char(255),char(174), -char(1),char(173),char(2),char(186),char(255),char(174),char(1),char(173),char(2),char(188), -char(255),char(215),char(1),char(173),char(2),char(190),char(255),char(174),char(1),char(173), -char(2),char(192),char(255),char(154),char(1),char(173),char(2),char(194),char(255),char(154), -char(1),char(173),char(2),char(196),char(255),char(154),char(1),char(173),char(2),char(197), -char(255),char(154),char(1),char(173),char(2),char(198),char(255),char(113),char(1),char(173), -char(2),char(199),char(255),char(154),char(1),char(173),char(2),char(200),char(255),char(113), -char(1),char(173),char(2),char(203),char(255),char(215),char(1),char(173),char(2),char(205), -char(255),char(154),char(1),char(173),char(2),char(206),char(255),char(154),char(1),char(173), -char(2),char(207),char(255),char(133),char(1),char(173),char(2),char(209),char(255),char(154), -char(1),char(173),char(2),char(211),char(255),char(154),char(1),char(173),char(2),char(213), -char(255),char(154),char(1),char(173),char(2),char(215),char(255),char(154),char(1),char(173), -char(2),char(217),char(255),char(113),char(1),char(173),char(2),char(219),char(255),char(113), -char(1),char(173),char(2),char(221),char(255),char(113),char(1),char(173),char(2),char(224), -char(255),char(113),char(1),char(173),char(2),char(230),char(255),char(215),char(1),char(173), -char(2),char(232),char(255),char(215),char(1),char(173),char(2),char(234),char(255),char(195), -char(1),char(173),char(2),char(236),char(255),char(154),char(1),char(173),char(2),char(238), -char(255),char(154),char(1),char(173),char(2),char(239),char(255),char(215),char(1),char(173), -char(2),char(240),char(255),char(113),char(1),char(173),char(2),char(241),char(255),char(215), -char(1),char(173),char(2),char(242),char(255),char(113),char(1),char(173),char(2),char(243), -char(255),char(215),char(1),char(173),char(2),char(244),char(255),char(113),char(1),char(173), -char(2),char(246),char(255),char(215),char(1),char(173),char(2),char(248),char(255),char(174), -char(1),char(173),char(2),char(250),char(255),char(174),char(1),char(173),char(2),char(252), -char(255),char(174),char(1),char(173),char(2),char(254),char(255),char(154),char(1),char(173), -char(3),char(0),char(255),char(154),char(1),char(173),char(3),char(2),char(255),char(154), -char(1),char(173),char(3),char(6),char(255),char(215),char(1),char(173),char(3),char(8), -char(255),char(215),char(1),char(173),char(3),char(9),char(255),char(113),char(1),char(173), -char(3),char(10),char(255),char(113),char(1),char(173),char(3),char(11),char(255),char(113), -char(1),char(173),char(3),char(12),char(255),char(113),char(1),char(173),char(3),char(14), -char(255),char(154),char(1),char(173),char(3),char(16),char(255),char(154),char(1),char(173), -char(3),char(17),char(255),char(154),char(1),char(173),char(3),char(18),char(255),char(133), -char(1),char(173),char(3),char(20),char(255),char(154),char(1),char(173),char(3),char(21), -char(255),char(215),char(1),char(173),char(3),char(22),char(255),char(113),char(1),char(173), -char(3),char(24),char(255),char(174),char(1),char(173),char(3),char(26),char(255),char(113), -char(1),char(173),char(3),char(27),char(255),char(154),char(1),char(173),char(3),char(28), -char(255),char(133),char(1),char(174),char(1),char(163),char(0),char(225),char(1),char(174), -char(2),char(234),char(0),char(41),char(1),char(174),char(3),char(14),char(255),char(215), -char(1),char(174),char(3),char(16),char(255),char(215),char(1),char(176),char(1),char(159), -char(255),char(215),char(1),char(176),char(1),char(184),char(255),char(215),char(1),char(176), -char(1),char(187),char(255),char(215),char(1),char(176),char(1),char(190),char(255),char(215), -char(1),char(176),char(1),char(193),char(255),char(215),char(1),char(176),char(1),char(225), -char(255),char(215),char(1),char(176),char(2),char(108),char(255),char(215),char(1),char(176), -char(2),char(124),char(255),char(215),char(1),char(176),char(2),char(126),char(255),char(215), -char(1),char(176),char(2),char(132),char(255),char(215),char(1),char(176),char(2),char(134), -char(255),char(215),char(1),char(176),char(2),char(136),char(255),char(215),char(1),char(176), -char(2),char(138),char(255),char(215),char(1),char(176),char(2),char(140),char(255),char(215), -char(1),char(176),char(2),char(177),char(255),char(215),char(1),char(176),char(2),char(179), -char(255),char(215),char(1),char(176),char(2),char(191),char(255),char(215),char(1),char(176), -char(2),char(192),char(255),char(215),char(1),char(176),char(2),char(193),char(255),char(215), -char(1),char(176),char(2),char(194),char(255),char(215),char(1),char(176),char(2),char(197), -char(255),char(154),char(1),char(176),char(2),char(199),char(255),char(154),char(1),char(176), -char(2),char(212),char(255),char(215),char(1),char(176),char(2),char(213),char(255),char(215), -char(1),char(176),char(2),char(239),char(255),char(215),char(1),char(176),char(2),char(241), -char(255),char(215),char(1),char(176),char(2),char(243),char(255),char(215),char(1),char(176), -char(2),char(253),char(255),char(215),char(1),char(176),char(2),char(254),char(255),char(215), -char(1),char(176),char(3),char(9),char(255),char(215),char(1),char(176),char(3),char(11), -char(255),char(215),char(1),char(176),char(3),char(14),char(255),char(215),char(1),char(176), -char(3),char(16),char(255),char(215),char(1),char(176),char(3),char(21),char(255),char(215), -char(1),char(176),char(3),char(25),char(255),char(236),char(1),char(177),char(0),char(15), -char(255),char(174),char(1),char(177),char(0),char(17),char(255),char(174),char(1),char(177), -char(2),char(8),char(255),char(174),char(1),char(177),char(2),char(12),char(255),char(174), -char(1),char(177),char(2),char(128),char(255),char(236),char(1),char(177),char(2),char(130), -char(255),char(236),char(1),char(177),char(2),char(183),char(255),char(236),char(1),char(177), -char(2),char(185),char(255),char(236),char(1),char(177),char(3),char(13),char(255),char(215), -char(1),char(177),char(3),char(15),char(255),char(215),char(1),char(180),char(1),char(159), -char(255),char(215),char(1),char(180),char(1),char(184),char(255),char(215),char(1),char(180), -char(1),char(187),char(255),char(215),char(1),char(180),char(1),char(190),char(255),char(215), -char(1),char(180),char(1),char(193),char(255),char(215),char(1),char(180),char(1),char(225), -char(255),char(215),char(1),char(180),char(2),char(108),char(255),char(215),char(1),char(180), -char(2),char(124),char(255),char(215),char(1),char(180),char(2),char(126),char(255),char(215), -char(1),char(180),char(2),char(132),char(255),char(215),char(1),char(180),char(2),char(134), -char(255),char(215),char(1),char(180),char(2),char(136),char(255),char(215),char(1),char(180), -char(2),char(138),char(255),char(215),char(1),char(180),char(2),char(140),char(255),char(215), -char(1),char(180),char(2),char(177),char(255),char(215),char(1),char(180),char(2),char(179), -char(255),char(215),char(1),char(180),char(2),char(191),char(255),char(215),char(1),char(180), -char(2),char(192),char(255),char(215),char(1),char(180),char(2),char(193),char(255),char(215), -char(1),char(180),char(2),char(194),char(255),char(215),char(1),char(180),char(2),char(197), -char(255),char(154),char(1),char(180),char(2),char(199),char(255),char(154),char(1),char(180), -char(2),char(212),char(255),char(215),char(1),char(180),char(2),char(213),char(255),char(215), -char(1),char(180),char(2),char(239),char(255),char(215),char(1),char(180),char(2),char(241), -char(255),char(215),char(1),char(180),char(2),char(243),char(255),char(215),char(1),char(180), -char(2),char(253),char(255),char(215),char(1),char(180),char(2),char(254),char(255),char(215), -char(1),char(180),char(3),char(9),char(255),char(215),char(1),char(180),char(3),char(11), -char(255),char(215),char(1),char(180),char(3),char(14),char(255),char(215),char(1),char(180), -char(3),char(16),char(255),char(215),char(1),char(180),char(3),char(21),char(255),char(215), -char(1),char(180),char(3),char(25),char(255),char(236),char(1),char(184),char(0),char(15), -char(255),char(174),char(1),char(184),char(0),char(17),char(255),char(174),char(1),char(184), -char(1),char(157),char(255),char(236),char(1),char(184),char(1),char(164),char(255),char(215), -char(1),char(184),char(1),char(166),char(255),char(236),char(1),char(184),char(1),char(168), -char(255),char(215),char(1),char(184),char(1),char(170),char(255),char(215),char(1),char(184), -char(1),char(174),char(255),char(215),char(1),char(184),char(1),char(176),char(255),char(215), -char(1),char(184),char(1),char(177),char(255),char(236),char(1),char(184),char(1),char(181), -char(255),char(215),char(1),char(184),char(1),char(188),char(255),char(195),char(1),char(184), -char(1),char(189),char(255),char(215),char(1),char(184),char(1),char(191),char(255),char(215), -char(1),char(184),char(1),char(193),char(255),char(215),char(1),char(184),char(1),char(196), -char(255),char(236),char(1),char(184),char(1),char(199),char(255),char(236),char(1),char(184), -char(1),char(206),char(255),char(236),char(1),char(184),char(1),char(213),char(255),char(236), -char(1),char(184),char(1),char(242),char(255),char(236),char(1),char(184),char(2),char(8), -char(255),char(174),char(1),char(184),char(2),char(12),char(255),char(174),char(1),char(184), -char(2),char(114),char(255),char(215),char(1),char(184),char(2),char(115),char(255),char(236), -char(1),char(184),char(2),char(122),char(255),char(236),char(1),char(184),char(2),char(124), -char(255),char(215),char(1),char(184),char(2),char(128),char(255),char(236),char(1),char(184), -char(2),char(130),char(255),char(236),char(1),char(184),char(2),char(159),char(255),char(215), -char(1),char(184),char(2),char(161),char(255),char(236),char(1),char(184),char(2),char(169), -char(255),char(236),char(1),char(184),char(2),char(181),char(255),char(195),char(1),char(184), -char(2),char(183),char(255),char(236),char(1),char(184),char(2),char(185),char(255),char(236), -char(1),char(184),char(2),char(187),char(255),char(215),char(1),char(184),char(2),char(189), -char(255),char(236),char(1),char(184),char(2),char(191),char(255),char(215),char(1),char(184), -char(2),char(193),char(255),char(215),char(1),char(184),char(2),char(202),char(255),char(215), -char(1),char(184),char(2),char(206),char(255),char(215),char(1),char(184),char(2),char(207), -char(255),char(236),char(1),char(184),char(2),char(212),char(255),char(215),char(1),char(184), -char(2),char(217),char(255),char(215),char(1),char(184),char(2),char(219),char(255),char(215), -char(1),char(184),char(2),char(221),char(255),char(215),char(1),char(184),char(2),char(229), -char(255),char(215),char(1),char(184),char(2),char(231),char(255),char(236),char(1),char(184), -char(2),char(245),char(255),char(236),char(1),char(184),char(2),char(247),char(255),char(215), -char(1),char(184),char(2),char(249),char(255),char(215),char(1),char(184),char(2),char(251), -char(255),char(215),char(1),char(184),char(2),char(253),char(255),char(215),char(1),char(184), -char(3),char(5),char(255),char(215),char(1),char(184),char(3),char(7),char(255),char(215), -char(1),char(184),char(3),char(13),char(255),char(215),char(1),char(184),char(3),char(15), -char(255),char(215),char(1),char(184),char(3),char(17),char(255),char(215),char(1),char(184), -char(3),char(18),char(255),char(236),char(1),char(184),char(3),char(23),char(255),char(236), -char(1),char(184),char(3),char(27),char(255),char(215),char(1),char(184),char(3),char(28), -char(255),char(236),char(1),char(186),char(0),char(15),char(254),char(246),char(1),char(186), -char(0),char(17),char(254),char(246),char(1),char(186),char(1),char(164),char(255),char(133), -char(1),char(186),char(1),char(170),char(255),char(154),char(1),char(186),char(1),char(174), -char(255),char(133),char(1),char(186),char(1),char(176),char(255),char(215),char(1),char(186), -char(1),char(181),char(255),char(133),char(1),char(186),char(1),char(191),char(255),char(215), -char(1),char(186),char(1),char(206),char(255),char(154),char(1),char(186),char(1),char(213), -char(255),char(154),char(1),char(186),char(1),char(242),char(255),char(154),char(1),char(186), -char(2),char(8),char(254),char(246),char(1),char(186),char(2),char(12),char(254),char(246), -char(1),char(186),char(2),char(114),char(255),char(154),char(1),char(186),char(2),char(115), -char(255),char(154),char(1),char(186),char(2),char(118),char(255),char(236),char(1),char(186), -char(2),char(159),char(255),char(215),char(1),char(186),char(2),char(187),char(255),char(215), -char(1),char(186),char(2),char(202),char(255),char(215),char(1),char(186),char(2),char(206), -char(255),char(133),char(1),char(186),char(2),char(207),char(255),char(154),char(1),char(186), -char(2),char(217),char(255),char(154),char(1),char(186),char(2),char(219),char(255),char(154), -char(1),char(186),char(2),char(221),char(255),char(154),char(1),char(186),char(2),char(229), -char(255),char(215),char(1),char(186),char(3),char(5),char(255),char(215),char(1),char(186), -char(3),char(7),char(255),char(215),char(1),char(186),char(3),char(9),char(255),char(174), -char(1),char(186),char(3),char(11),char(255),char(174),char(1),char(186),char(3),char(17), -char(255),char(133),char(1),char(186),char(3),char(18),char(255),char(154),char(1),char(186), -char(3),char(27),char(255),char(133),char(1),char(186),char(3),char(28),char(255),char(154), -char(1),char(187),char(1),char(159),char(255),char(215),char(1),char(187),char(1),char(184), -char(255),char(215),char(1),char(187),char(1),char(187),char(255),char(215),char(1),char(187), -char(1),char(190),char(255),char(215),char(1),char(187),char(1),char(225),char(255),char(215), -char(1),char(187),char(2),char(108),char(255),char(215),char(1),char(187),char(2),char(126), -char(255),char(215),char(1),char(187),char(2),char(132),char(255),char(215),char(1),char(187), -char(2),char(134),char(255),char(215),char(1),char(187),char(2),char(136),char(255),char(215), -char(1),char(187),char(2),char(138),char(255),char(215),char(1),char(187),char(2),char(140), -char(255),char(215),char(1),char(187),char(2),char(177),char(255),char(215),char(1),char(187), -char(2),char(179),char(255),char(215),char(1),char(187),char(2),char(192),char(255),char(215), -char(1),char(187),char(2),char(194),char(255),char(215),char(1),char(187),char(2),char(197), -char(255),char(215),char(1),char(187),char(2),char(199),char(255),char(215),char(1),char(187), -char(2),char(213),char(255),char(215),char(1),char(187),char(2),char(239),char(255),char(215), -char(1),char(187),char(2),char(241),char(255),char(215),char(1),char(187),char(2),char(243), -char(255),char(215),char(1),char(187),char(2),char(254),char(255),char(215),char(1),char(187), -char(3),char(9),char(255),char(215),char(1),char(187),char(3),char(11),char(255),char(215), -char(1),char(187),char(3),char(14),char(255),char(215),char(1),char(187),char(3),char(16), -char(255),char(215),char(1),char(187),char(3),char(21),char(255),char(215),char(1),char(188), -char(0),char(15),char(255),char(133),char(1),char(188),char(0),char(16),char(255),char(174), -char(1),char(188),char(0),char(17),char(255),char(133),char(1),char(188),char(1),char(159), -char(255),char(215),char(1),char(188),char(1),char(164),char(255),char(154),char(1),char(188), -char(1),char(170),char(255),char(113),char(1),char(188),char(1),char(174),char(255),char(154), -char(1),char(188),char(1),char(181),char(255),char(154),char(1),char(188),char(1),char(184), -char(255),char(215),char(1),char(188),char(1),char(187),char(255),char(215),char(1),char(188), -char(1),char(188),char(0),char(41),char(1),char(188),char(1),char(190),char(255),char(174), -char(1),char(188),char(1),char(204),char(255),char(154),char(1),char(188),char(1),char(205), -char(255),char(154),char(1),char(188),char(1),char(206),char(255),char(133),char(1),char(188), -char(1),char(207),char(255),char(113),char(1),char(188),char(1),char(208),char(255),char(215), -char(1),char(188),char(1),char(209),char(255),char(215),char(1),char(188),char(1),char(210), -char(255),char(154),char(1),char(188),char(1),char(211),char(255),char(154),char(1),char(188), -char(1),char(212),char(255),char(154),char(1),char(188),char(1),char(213),char(255),char(133), -char(1),char(188),char(1),char(214),char(255),char(154),char(1),char(188),char(1),char(215), -char(255),char(154),char(1),char(188),char(1),char(216),char(255),char(113),char(1),char(188), -char(1),char(217),char(255),char(154),char(1),char(188),char(1),char(218),char(255),char(154), -char(1),char(188),char(1),char(219),char(255),char(113),char(1),char(188),char(1),char(220), -char(255),char(174),char(1),char(188),char(1),char(221),char(255),char(174),char(1),char(188), -char(1),char(222),char(255),char(113),char(1),char(188),char(1),char(223),char(255),char(215), -char(1),char(188),char(1),char(224),char(255),char(154),char(1),char(188),char(1),char(225), -char(255),char(154),char(1),char(188),char(1),char(226),char(255),char(154),char(1),char(188), -char(1),char(227),char(255),char(154),char(1),char(188),char(1),char(228),char(255),char(174), -char(1),char(188),char(1),char(229),char(255),char(154),char(1),char(188),char(1),char(230), -char(255),char(154),char(1),char(188),char(1),char(231),char(255),char(215),char(1),char(188), -char(1),char(232),char(255),char(154),char(1),char(188),char(1),char(233),char(255),char(195), -char(1),char(188),char(1),char(234),char(255),char(113),char(1),char(188),char(1),char(236), -char(255),char(154),char(1),char(188),char(1),char(237),char(255),char(113),char(1),char(188), -char(1),char(238),char(255),char(133),char(1),char(188),char(1),char(242),char(255),char(133), -char(1),char(188),char(1),char(243),char(255),char(154),char(1),char(188),char(1),char(245), -char(255),char(154),char(1),char(188),char(1),char(246),char(255),char(174),char(1),char(188), -char(1),char(247),char(255),char(154),char(1),char(188),char(1),char(249),char(255),char(154), -char(1),char(188),char(2),char(2),char(255),char(174),char(1),char(188),char(2),char(3), -char(255),char(174),char(1),char(188),char(2),char(4),char(255),char(174),char(1),char(188), -char(2),char(8),char(255),char(133),char(1),char(188),char(2),char(12),char(255),char(133), -char(1),char(188),char(2),char(106),char(255),char(113),char(1),char(188),char(2),char(107), -char(255),char(154),char(1),char(188),char(2),char(108),char(255),char(215),char(1),char(188), -char(2),char(109),char(255),char(215),char(1),char(188),char(2),char(113),char(255),char(154), -char(1),char(188),char(2),char(114),char(255),char(113),char(1),char(188),char(2),char(115), -char(255),char(133),char(1),char(188),char(2),char(117),char(255),char(154),char(1),char(188), -char(2),char(119),char(255),char(154),char(1),char(188),char(2),char(121),char(255),char(154), -char(1),char(188),char(2),char(125),char(255),char(154),char(1),char(188),char(2),char(126), -char(255),char(215),char(1),char(188),char(2),char(127),char(255),char(113),char(1),char(188), -char(2),char(129),char(255),char(215),char(1),char(188),char(2),char(131),char(255),char(215), -char(1),char(188),char(2),char(132),char(255),char(215),char(1),char(188),char(2),char(133), -char(255),char(113),char(1),char(188),char(2),char(134),char(255),char(215),char(1),char(188), -char(2),char(135),char(255),char(113),char(1),char(188),char(2),char(136),char(255),char(215), -char(1),char(188),char(2),char(137),char(255),char(113),char(1),char(188),char(2),char(138), -char(255),char(215),char(1),char(188),char(2),char(139),char(255),char(215),char(1),char(188), -char(2),char(140),char(255),char(215),char(1),char(188),char(2),char(141),char(255),char(113), -char(1),char(188),char(2),char(150),char(255),char(154),char(1),char(188),char(2),char(154), -char(255),char(154),char(1),char(188),char(2),char(158),char(255),char(154),char(1),char(188), -char(2),char(160),char(255),char(215),char(1),char(188),char(2),char(162),char(255),char(215), -char(1),char(188),char(2),char(164),char(255),char(154),char(1),char(188),char(2),char(166), -char(255),char(154),char(1),char(188),char(2),char(170),char(255),char(174),char(1),char(188), -char(2),char(172),char(255),char(154),char(1),char(188),char(2),char(174),char(255),char(154), -char(1),char(188),char(2),char(176),char(255),char(154),char(1),char(188),char(2),char(177), -char(255),char(215),char(1),char(188),char(2),char(178),char(255),char(113),char(1),char(188), -char(2),char(179),char(255),char(215),char(1),char(188),char(2),char(180),char(255),char(113), -char(1),char(188),char(2),char(181),char(0),char(41),char(1),char(188),char(2),char(182), -char(255),char(174),char(1),char(188),char(2),char(184),char(255),char(174),char(1),char(188), -char(2),char(186),char(255),char(174),char(1),char(188),char(2),char(188),char(255),char(215), -char(1),char(188),char(2),char(190),char(255),char(174),char(1),char(188),char(2),char(192), -char(255),char(154),char(1),char(188),char(2),char(194),char(255),char(154),char(1),char(188), -char(2),char(196),char(255),char(154),char(1),char(188),char(2),char(197),char(255),char(154), -char(1),char(188),char(2),char(198),char(255),char(113),char(1),char(188),char(2),char(199), -char(255),char(154),char(1),char(188),char(2),char(200),char(255),char(113),char(1),char(188), -char(2),char(203),char(255),char(215),char(1),char(188),char(2),char(205),char(255),char(154), -char(1),char(188),char(2),char(206),char(255),char(154),char(1),char(188),char(2),char(207), -char(255),char(133),char(1),char(188),char(2),char(209),char(255),char(154),char(1),char(188), -char(2),char(211),char(255),char(154),char(1),char(188),char(2),char(213),char(255),char(154), -char(1),char(188),char(2),char(215),char(255),char(154),char(1),char(188),char(2),char(217), -char(255),char(113),char(1),char(188),char(2),char(219),char(255),char(113),char(1),char(188), -char(2),char(221),char(255),char(113),char(1),char(188),char(2),char(224),char(255),char(113), -char(1),char(188),char(2),char(230),char(255),char(215),char(1),char(188),char(2),char(232), -char(255),char(215),char(1),char(188),char(2),char(234),char(255),char(195),char(1),char(188), -char(2),char(236),char(255),char(154),char(1),char(188),char(2),char(238),char(255),char(154), -char(1),char(188),char(2),char(239),char(255),char(215),char(1),char(188),char(2),char(240), -char(255),char(113),char(1),char(188),char(2),char(241),char(255),char(215),char(1),char(188), -char(2),char(242),char(255),char(113),char(1),char(188),char(2),char(243),char(255),char(215), -char(1),char(188),char(2),char(244),char(255),char(113),char(1),char(188),char(2),char(246), -char(255),char(215),char(1),char(188),char(2),char(248),char(255),char(174),char(1),char(188), -char(2),char(250),char(255),char(174),char(1),char(188),char(2),char(252),char(255),char(174), -char(1),char(188),char(2),char(254),char(255),char(154),char(1),char(188),char(3),char(0), -char(255),char(154),char(1),char(188),char(3),char(2),char(255),char(154),char(1),char(188), -char(3),char(6),char(255),char(215),char(1),char(188),char(3),char(8),char(255),char(215), -char(1),char(188),char(3),char(9),char(255),char(113),char(1),char(188),char(3),char(10), -char(255),char(113),char(1),char(188),char(3),char(11),char(255),char(113),char(1),char(188), -char(3),char(12),char(255),char(113),char(1),char(188),char(3),char(14),char(255),char(154), -char(1),char(188),char(3),char(16),char(255),char(154),char(1),char(188),char(3),char(17), -char(255),char(154),char(1),char(188),char(3),char(18),char(255),char(133),char(1),char(188), -char(3),char(20),char(255),char(154),char(1),char(188),char(3),char(21),char(255),char(215), -char(1),char(188),char(3),char(22),char(255),char(113),char(1),char(188),char(3),char(24), -char(255),char(174),char(1),char(188),char(3),char(26),char(255),char(113),char(1),char(188), -char(3),char(27),char(255),char(154),char(1),char(188),char(3),char(28),char(255),char(133), -char(1),char(189),char(0),char(15),char(255),char(133),char(1),char(189),char(0),char(17), -char(255),char(133),char(1),char(189),char(1),char(159),char(255),char(236),char(1),char(189), -char(1),char(164),char(255),char(154),char(1),char(189),char(1),char(170),char(255),char(113), -char(1),char(189),char(1),char(174),char(255),char(154),char(1),char(189),char(1),char(181), -char(255),char(154),char(1),char(189),char(1),char(184),char(255),char(236),char(1),char(189), -char(1),char(187),char(255),char(236),char(1),char(189),char(1),char(190),char(255),char(195), -char(1),char(189),char(1),char(201),char(255),char(236),char(1),char(189),char(1),char(206), -char(255),char(174),char(1),char(189),char(1),char(207),char(255),char(215),char(1),char(189), -char(1),char(213),char(255),char(174),char(1),char(189),char(1),char(216),char(255),char(215), -char(1),char(189),char(1),char(219),char(255),char(215),char(1),char(189),char(1),char(222), -char(255),char(215),char(1),char(189),char(1),char(225),char(255),char(215),char(1),char(189), -char(1),char(234),char(255),char(215),char(1),char(189),char(1),char(235),char(0),char(102), -char(1),char(189),char(1),char(237),char(255),char(215),char(1),char(189),char(1),char(238), -char(255),char(236),char(1),char(189),char(1),char(242),char(255),char(174),char(1),char(189), -char(1),char(244),char(0),char(102),char(1),char(189),char(2),char(8),char(255),char(133), -char(1),char(189),char(2),char(12),char(255),char(133),char(1),char(189),char(2),char(106), -char(255),char(215),char(1),char(189),char(2),char(108),char(255),char(236),char(1),char(189), -char(2),char(114),char(255),char(113),char(1),char(189),char(2),char(115),char(255),char(174), -char(1),char(189),char(2),char(126),char(255),char(236),char(1),char(189),char(2),char(127), -char(255),char(215),char(1),char(189),char(2),char(132),char(255),char(236),char(1),char(189), -char(2),char(133),char(255),char(215),char(1),char(189),char(2),char(134),char(255),char(236), -char(1),char(189),char(2),char(135),char(255),char(215),char(1),char(189),char(2),char(136), -char(255),char(236),char(1),char(189),char(2),char(137),char(255),char(215),char(1),char(189), -char(2),char(138),char(255),char(236),char(1),char(189),char(2),char(140),char(255),char(236), -char(1),char(189),char(2),char(141),char(255),char(215),char(1),char(189),char(2),char(152), -char(0),char(102),char(1),char(189),char(2),char(168),char(0),char(102),char(1),char(189), -char(2),char(177),char(255),char(236),char(1),char(189),char(2),char(178),char(255),char(215), -char(1),char(189),char(2),char(179),char(255),char(236),char(1),char(189),char(2),char(180), -char(255),char(215),char(1),char(189),char(2),char(192),char(255),char(215),char(1),char(189), -char(2),char(194),char(255),char(215),char(1),char(189),char(2),char(197),char(255),char(215), -char(1),char(189),char(2),char(198),char(255),char(195),char(1),char(189),char(2),char(199), -char(255),char(215),char(1),char(189),char(2),char(200),char(255),char(195),char(1),char(189), -char(2),char(206),char(255),char(154),char(1),char(189),char(2),char(207),char(255),char(174), -char(1),char(189),char(2),char(213),char(255),char(215),char(1),char(189),char(2),char(217), -char(255),char(113),char(1),char(189),char(2),char(219),char(255),char(113),char(1),char(189), -char(2),char(221),char(255),char(113),char(1),char(189),char(2),char(224),char(255),char(215), -char(1),char(189),char(2),char(239),char(255),char(236),char(1),char(189),char(2),char(240), -char(255),char(215),char(1),char(189),char(2),char(241),char(255),char(236),char(1),char(189), -char(2),char(242),char(255),char(215),char(1),char(189),char(2),char(243),char(255),char(236), -char(1),char(189),char(2),char(244),char(255),char(215),char(1),char(189),char(2),char(254), -char(255),char(215),char(1),char(189),char(3),char(9),char(255),char(113),char(1),char(189), -char(3),char(10),char(255),char(215),char(1),char(189),char(3),char(11),char(255),char(113), -char(1),char(189),char(3),char(12),char(255),char(215),char(1),char(189),char(3),char(17), -char(255),char(154),char(1),char(189),char(3),char(18),char(255),char(174),char(1),char(189), -char(3),char(21),char(255),char(236),char(1),char(189),char(3),char(22),char(255),char(215), -char(1),char(189),char(3),char(26),char(255),char(215),char(1),char(189),char(3),char(27), -char(255),char(154),char(1),char(189),char(3),char(28),char(255),char(174),char(1),char(190), -char(0),char(15),char(255),char(174),char(1),char(190),char(0),char(17),char(255),char(174), -char(1),char(190),char(1),char(157),char(255),char(215),char(1),char(190),char(1),char(164), -char(255),char(215),char(1),char(190),char(1),char(166),char(255),char(215),char(1),char(190), -char(1),char(168),char(255),char(195),char(1),char(190),char(1),char(170),char(255),char(215), -char(1),char(190),char(1),char(174),char(255),char(215),char(1),char(190),char(1),char(176), -char(255),char(215),char(1),char(190),char(1),char(177),char(255),char(215),char(1),char(190), -char(1),char(181),char(255),char(215),char(1),char(190),char(1),char(188),char(255),char(195), -char(1),char(190),char(1),char(189),char(255),char(195),char(1),char(190),char(1),char(191), -char(255),char(215),char(1),char(190),char(1),char(196),char(255),char(215),char(1),char(190), -char(1),char(199),char(255),char(215),char(1),char(190),char(1),char(206),char(255),char(236), -char(1),char(190),char(1),char(213),char(255),char(236),char(1),char(190),char(1),char(242), -char(255),char(236),char(1),char(190),char(2),char(8),char(255),char(174),char(1),char(190), -char(2),char(12),char(255),char(174),char(1),char(190),char(2),char(114),char(255),char(215), -char(1),char(190),char(2),char(115),char(255),char(236),char(1),char(190),char(2),char(122), -char(255),char(215),char(1),char(190),char(2),char(128),char(255),char(236),char(1),char(190), -char(2),char(130),char(255),char(236),char(1),char(190),char(2),char(159),char(255),char(215), -char(1),char(190),char(2),char(161),char(255),char(215),char(1),char(190),char(2),char(169), -char(255),char(215),char(1),char(190),char(2),char(181),char(255),char(195),char(1),char(190), -char(2),char(183),char(255),char(195),char(1),char(190),char(2),char(185),char(255),char(195), -char(1),char(190),char(2),char(187),char(255),char(215),char(1),char(190),char(2),char(189), -char(255),char(215),char(1),char(190),char(2),char(202),char(255),char(215),char(1),char(190), -char(2),char(206),char(255),char(215),char(1),char(190),char(2),char(207),char(255),char(236), -char(1),char(190),char(2),char(217),char(255),char(215),char(1),char(190),char(2),char(219), -char(255),char(215),char(1),char(190),char(2),char(221),char(255),char(215),char(1),char(190), -char(2),char(229),char(255),char(215),char(1),char(190),char(2),char(231),char(255),char(215), -char(1),char(190),char(2),char(245),char(255),char(215),char(1),char(190),char(2),char(247), -char(255),char(195),char(1),char(190),char(2),char(249),char(255),char(195),char(1),char(190), -char(2),char(251),char(255),char(195),char(1),char(190),char(3),char(5),char(255),char(215), -char(1),char(190),char(3),char(7),char(255),char(215),char(1),char(190),char(3),char(13), -char(255),char(215),char(1),char(190),char(3),char(15),char(255),char(215),char(1),char(190), -char(3),char(17),char(255),char(215),char(1),char(190),char(3),char(18),char(255),char(236), -char(1),char(190),char(3),char(23),char(255),char(215),char(1),char(190),char(3),char(27), -char(255),char(215),char(1),char(190),char(3),char(28),char(255),char(236),char(1),char(191), -char(1),char(159),char(255),char(215),char(1),char(191),char(1),char(184),char(255),char(215), -char(1),char(191),char(1),char(187),char(255),char(215),char(1),char(191),char(1),char(190), -char(255),char(215),char(1),char(191),char(1),char(193),char(255),char(215),char(1),char(191), -char(1),char(225),char(255),char(215),char(1),char(191),char(2),char(108),char(255),char(215), -char(1),char(191),char(2),char(124),char(255),char(215),char(1),char(191),char(2),char(126), -char(255),char(215),char(1),char(191),char(2),char(132),char(255),char(215),char(1),char(191), -char(2),char(134),char(255),char(215),char(1),char(191),char(2),char(136),char(255),char(215), -char(1),char(191),char(2),char(138),char(255),char(215),char(1),char(191),char(2),char(140), -char(255),char(215),char(1),char(191),char(2),char(177),char(255),char(215),char(1),char(191), -char(2),char(179),char(255),char(215),char(1),char(191),char(2),char(191),char(255),char(215), -char(1),char(191),char(2),char(192),char(255),char(215),char(1),char(191),char(2),char(193), -char(255),char(215),char(1),char(191),char(2),char(194),char(255),char(215),char(1),char(191), -char(2),char(197),char(255),char(154),char(1),char(191),char(2),char(199),char(255),char(154), -char(1),char(191),char(2),char(212),char(255),char(215),char(1),char(191),char(2),char(213), -char(255),char(215),char(1),char(191),char(2),char(239),char(255),char(215),char(1),char(191), -char(2),char(241),char(255),char(215),char(1),char(191),char(2),char(243),char(255),char(215), -char(1),char(191),char(2),char(253),char(255),char(215),char(1),char(191),char(2),char(254), -char(255),char(215),char(1),char(191),char(3),char(9),char(255),char(215),char(1),char(191), -char(3),char(11),char(255),char(215),char(1),char(191),char(3),char(14),char(255),char(215), -char(1),char(191),char(3),char(16),char(255),char(215),char(1),char(191),char(3),char(21), -char(255),char(215),char(1),char(191),char(3),char(25),char(255),char(236),char(1),char(192), -char(1),char(163),char(0),char(225),char(1),char(192),char(2),char(234),char(0),char(41), -char(1),char(192),char(3),char(14),char(255),char(215),char(1),char(192),char(3),char(16), -char(255),char(215),char(1),char(195),char(1),char(163),char(0),char(225),char(1),char(195), -char(2),char(234),char(0),char(41),char(1),char(195),char(3),char(14),char(255),char(215), -char(1),char(195),char(3),char(16),char(255),char(215),char(1),char(196),char(0),char(5), -char(255),char(174),char(1),char(196),char(0),char(10),char(255),char(174),char(1),char(196), -char(1),char(157),char(255),char(133),char(1),char(196),char(1),char(166),char(255),char(133), -char(1),char(196),char(1),char(168),char(255),char(215),char(1),char(196),char(1),char(188), -char(255),char(154),char(1),char(196),char(1),char(189),char(255),char(215),char(1),char(196), -char(1),char(193),char(255),char(154),char(1),char(196),char(1),char(196),char(255),char(133), -char(1),char(196),char(1),char(220),char(255),char(215),char(1),char(196),char(1),char(221), -char(255),char(215),char(1),char(196),char(1),char(225),char(255),char(215),char(1),char(196), -char(1),char(228),char(255),char(215),char(1),char(196),char(1),char(246),char(255),char(215), -char(1),char(196),char(2),char(7),char(255),char(174),char(1),char(196),char(2),char(11), -char(255),char(174),char(1),char(196),char(2),char(110),char(255),char(174),char(1),char(196), -char(2),char(124),char(255),char(154),char(1),char(196),char(2),char(128),char(255),char(174), -char(1),char(196),char(2),char(130),char(255),char(174),char(1),char(196),char(2),char(151), -char(255),char(174),char(1),char(196),char(2),char(155),char(255),char(174),char(1),char(196), -char(2),char(167),char(255),char(174),char(1),char(196),char(2),char(169),char(255),char(133), -char(1),char(196),char(2),char(170),char(255),char(215),char(1),char(196),char(2),char(181), -char(255),char(154),char(1),char(196),char(2),char(182),char(255),char(215),char(1),char(196), -char(2),char(183),char(255),char(154),char(1),char(196),char(2),char(184),char(255),char(215), -char(1),char(196),char(2),char(185),char(255),char(154),char(1),char(196),char(2),char(186), -char(255),char(215),char(1),char(196),char(2),char(189),char(255),char(133),char(1),char(196), -char(2),char(190),char(255),char(215),char(1),char(196),char(2),char(191),char(255),char(154), -char(1),char(196),char(2),char(192),char(255),char(215),char(1),char(196),char(2),char(193), -char(255),char(154),char(1),char(196),char(2),char(194),char(255),char(215),char(1),char(196), -char(2),char(212),char(255),char(154),char(1),char(196),char(2),char(213),char(255),char(215), -char(1),char(196),char(2),char(247),char(255),char(215),char(1),char(196),char(2),char(248), -char(255),char(215),char(1),char(196),char(2),char(249),char(255),char(215),char(1),char(196), -char(2),char(250),char(255),char(215),char(1),char(196),char(2),char(251),char(255),char(215), -char(1),char(196),char(2),char(252),char(255),char(215),char(1),char(196),char(2),char(253), -char(255),char(154),char(1),char(196),char(2),char(254),char(255),char(215),char(1),char(196), -char(3),char(3),char(255),char(174),char(1),char(196),char(3),char(13),char(255),char(154), -char(1),char(196),char(3),char(14),char(255),char(195),char(1),char(196),char(3),char(15), -char(255),char(154),char(1),char(196),char(3),char(16),char(255),char(195),char(1),char(196), -char(3),char(23),char(255),char(133),char(1),char(196),char(3),char(24),char(255),char(215), -char(1),char(198),char(0),char(5),char(255),char(174),char(1),char(198),char(0),char(10), -char(255),char(174),char(1),char(198),char(1),char(157),char(255),char(133),char(1),char(198), -char(1),char(166),char(255),char(133),char(1),char(198),char(1),char(168),char(255),char(215), -char(1),char(198),char(1),char(188),char(255),char(154),char(1),char(198),char(1),char(189), -char(255),char(215),char(1),char(198),char(1),char(193),char(255),char(154),char(1),char(198), -char(1),char(196),char(255),char(133),char(1),char(198),char(1),char(220),char(255),char(215), -char(1),char(198),char(1),char(221),char(255),char(215),char(1),char(198),char(1),char(225), -char(255),char(215),char(1),char(198),char(1),char(228),char(255),char(215),char(1),char(198), -char(1),char(246),char(255),char(215),char(1),char(198),char(2),char(7),char(255),char(174), -char(1),char(198),char(2),char(11),char(255),char(174),char(1),char(198),char(2),char(110), -char(255),char(174),char(1),char(198),char(2),char(124),char(255),char(154),char(1),char(198), -char(2),char(128),char(255),char(174),char(1),char(198),char(2),char(130),char(255),char(174), -char(1),char(198),char(2),char(151),char(255),char(174),char(1),char(198),char(2),char(155), -char(255),char(174),char(1),char(198),char(2),char(167),char(255),char(174),char(1),char(198), -char(2),char(169),char(255),char(133),char(1),char(198),char(2),char(170),char(255),char(215), -char(1),char(198),char(2),char(181),char(255),char(154),char(1),char(198),char(2),char(182), -char(255),char(215),char(1),char(198),char(2),char(183),char(255),char(154),char(1),char(198), -char(2),char(184),char(255),char(215),char(1),char(198),char(2),char(185),char(255),char(154), -char(1),char(198),char(2),char(186),char(255),char(215),char(1),char(198),char(2),char(189), -char(255),char(133),char(1),char(198),char(2),char(190),char(255),char(215),char(1),char(198), -char(2),char(191),char(255),char(154),char(1),char(198),char(2),char(192),char(255),char(215), -char(1),char(198),char(2),char(193),char(255),char(154),char(1),char(198),char(2),char(194), -char(255),char(215),char(1),char(198),char(2),char(212),char(255),char(154),char(1),char(198), -char(2),char(213),char(255),char(215),char(1),char(198),char(2),char(247),char(255),char(215), -char(1),char(198),char(2),char(248),char(255),char(215),char(1),char(198),char(2),char(249), -char(255),char(215),char(1),char(198),char(2),char(250),char(255),char(215),char(1),char(198), -char(2),char(251),char(255),char(215),char(1),char(198),char(2),char(252),char(255),char(215), -char(1),char(198),char(2),char(253),char(255),char(154),char(1),char(198),char(2),char(254), -char(255),char(215),char(1),char(198),char(3),char(3),char(255),char(174),char(1),char(198), -char(3),char(13),char(255),char(154),char(1),char(198),char(3),char(14),char(255),char(195), -char(1),char(198),char(3),char(15),char(255),char(154),char(1),char(198),char(3),char(16), -char(255),char(195),char(1),char(198),char(3),char(23),char(255),char(133),char(1),char(198), -char(3),char(24),char(255),char(215),char(1),char(199),char(0),char(15),char(255),char(174), -char(1),char(199),char(0),char(17),char(255),char(174),char(1),char(199),char(1),char(157), -char(255),char(236),char(1),char(199),char(1),char(164),char(255),char(215),char(1),char(199), -char(1),char(166),char(255),char(236),char(1),char(199),char(1),char(168),char(255),char(215), -char(1),char(199),char(1),char(170),char(255),char(215),char(1),char(199),char(1),char(174), -char(255),char(215),char(1),char(199),char(1),char(176),char(255),char(215),char(1),char(199), -char(1),char(177),char(255),char(236),char(1),char(199),char(1),char(181),char(255),char(215), -char(1),char(199),char(1),char(188),char(255),char(195),char(1),char(199),char(1),char(189), -char(255),char(215),char(1),char(199),char(1),char(191),char(255),char(215),char(1),char(199), -char(1),char(193),char(255),char(215),char(1),char(199),char(1),char(196),char(255),char(236), -char(1),char(199),char(1),char(199),char(255),char(236),char(1),char(199),char(1),char(206), -char(255),char(236),char(1),char(199),char(1),char(213),char(255),char(236),char(1),char(199), -char(1),char(242),char(255),char(236),char(1),char(199),char(2),char(8),char(255),char(174), -char(1),char(199),char(2),char(12),char(255),char(174),char(1),char(199),char(2),char(114), -char(255),char(215),char(1),char(199),char(2),char(115),char(255),char(236),char(1),char(199), -char(2),char(122),char(255),char(236),char(1),char(199),char(2),char(124),char(255),char(215), -char(1),char(199),char(2),char(128),char(255),char(236),char(1),char(199),char(2),char(130), -char(255),char(236),char(1),char(199),char(2),char(159),char(255),char(215),char(1),char(199), -char(2),char(161),char(255),char(236),char(1),char(199),char(2),char(169),char(255),char(236), -char(1),char(199),char(2),char(181),char(255),char(195),char(1),char(199),char(2),char(183), -char(255),char(236),char(1),char(199),char(2),char(185),char(255),char(236),char(1),char(199), -char(2),char(187),char(255),char(215),char(1),char(199),char(2),char(189),char(255),char(236), -char(1),char(199),char(2),char(191),char(255),char(215),char(1),char(199),char(2),char(193), -char(255),char(215),char(1),char(199),char(2),char(202),char(255),char(215),char(1),char(199), -char(2),char(206),char(255),char(215),char(1),char(199),char(2),char(207),char(255),char(236), -char(1),char(199),char(2),char(212),char(255),char(215),char(1),char(199),char(2),char(217), -char(255),char(215),char(1),char(199),char(2),char(219),char(255),char(215),char(1),char(199), -char(2),char(221),char(255),char(215),char(1),char(199),char(2),char(229),char(255),char(215), -char(1),char(199),char(2),char(231),char(255),char(236),char(1),char(199),char(2),char(245), -char(255),char(236),char(1),char(199),char(2),char(247),char(255),char(215),char(1),char(199), -char(2),char(249),char(255),char(215),char(1),char(199),char(2),char(251),char(255),char(215), -char(1),char(199),char(2),char(253),char(255),char(215),char(1),char(199),char(3),char(5), -char(255),char(215),char(1),char(199),char(3),char(7),char(255),char(215),char(1),char(199), -char(3),char(13),char(255),char(215),char(1),char(199),char(3),char(15),char(255),char(215), -char(1),char(199),char(3),char(17),char(255),char(215),char(1),char(199),char(3),char(18), -char(255),char(236),char(1),char(199),char(3),char(23),char(255),char(236),char(1),char(199), -char(3),char(27),char(255),char(215),char(1),char(199),char(3),char(28),char(255),char(236), -char(1),char(200),char(0),char(15),char(255),char(174),char(1),char(200),char(0),char(17), -char(255),char(174),char(1),char(200),char(1),char(157),char(255),char(236),char(1),char(200), -char(1),char(164),char(255),char(215),char(1),char(200),char(1),char(166),char(255),char(236), -char(1),char(200),char(1),char(168),char(255),char(215),char(1),char(200),char(1),char(170), -char(255),char(215),char(1),char(200),char(1),char(174),char(255),char(215),char(1),char(200), -char(1),char(176),char(255),char(215),char(1),char(200),char(1),char(177),char(255),char(236), -char(1),char(200),char(1),char(181),char(255),char(215),char(1),char(200),char(1),char(188), -char(255),char(195),char(1),char(200),char(1),char(189),char(255),char(215),char(1),char(200), -char(1),char(191),char(255),char(215),char(1),char(200),char(1),char(193),char(255),char(215), -char(1),char(200),char(1),char(196),char(255),char(236),char(1),char(200),char(1),char(199), -char(255),char(236),char(1),char(200),char(1),char(206),char(255),char(236),char(1),char(200), -char(1),char(213),char(255),char(236),char(1),char(200),char(1),char(242),char(255),char(236), -char(1),char(200),char(2),char(8),char(255),char(174),char(1),char(200),char(2),char(12), -char(255),char(174),char(1),char(200),char(2),char(114),char(255),char(215),char(1),char(200), -char(2),char(115),char(255),char(236),char(1),char(200),char(2),char(122),char(255),char(236), -char(1),char(200),char(2),char(124),char(255),char(215),char(1),char(200),char(2),char(128), -char(255),char(236),char(1),char(200),char(2),char(130),char(255),char(236),char(1),char(200), -char(2),char(159),char(255),char(215),char(1),char(200),char(2),char(161),char(255),char(236), -char(1),char(200),char(2),char(169),char(255),char(236),char(1),char(200),char(2),char(181), -char(255),char(195),char(1),char(200),char(2),char(183),char(255),char(236),char(1),char(200), -char(2),char(185),char(255),char(236),char(1),char(200),char(2),char(187),char(255),char(215), -char(1),char(200),char(2),char(189),char(255),char(236),char(1),char(200),char(2),char(191), -char(255),char(215),char(1),char(200),char(2),char(193),char(255),char(215),char(1),char(200), -char(2),char(202),char(255),char(215),char(1),char(200),char(2),char(206),char(255),char(215), -char(1),char(200),char(2),char(207),char(255),char(236),char(1),char(200),char(2),char(212), -char(255),char(215),char(1),char(200),char(2),char(217),char(255),char(215),char(1),char(200), -char(2),char(219),char(255),char(215),char(1),char(200),char(2),char(221),char(255),char(215), -char(1),char(200),char(2),char(229),char(255),char(215),char(1),char(200),char(2),char(231), -char(255),char(236),char(1),char(200),char(2),char(245),char(255),char(236),char(1),char(200), -char(2),char(247),char(255),char(215),char(1),char(200),char(2),char(249),char(255),char(215), -char(1),char(200),char(2),char(251),char(255),char(215),char(1),char(200),char(2),char(253), -char(255),char(215),char(1),char(200),char(3),char(5),char(255),char(215),char(1),char(200), -char(3),char(7),char(255),char(215),char(1),char(200),char(3),char(13),char(255),char(215), -char(1),char(200),char(3),char(15),char(255),char(215),char(1),char(200),char(3),char(17), -char(255),char(215),char(1),char(200),char(3),char(18),char(255),char(236),char(1),char(200), -char(3),char(23),char(255),char(236),char(1),char(200),char(3),char(27),char(255),char(215), -char(1),char(200),char(3),char(28),char(255),char(236),char(1),char(202),char(0),char(5), -char(255),char(236),char(1),char(202),char(0),char(10),char(255),char(236),char(1),char(202), -char(2),char(7),char(255),char(236),char(1),char(202),char(2),char(11),char(255),char(236), -char(1),char(204),char(1),char(233),char(0),char(41),char(1),char(205),char(0),char(15), -char(255),char(154),char(1),char(205),char(0),char(16),char(255),char(215),char(1),char(205), -char(0),char(17),char(255),char(154),char(1),char(205),char(1),char(206),char(255),char(195), -char(1),char(205),char(1),char(207),char(255),char(236),char(1),char(205),char(1),char(213), -char(255),char(195),char(1),char(205),char(1),char(216),char(255),char(236),char(1),char(205), -char(1),char(219),char(255),char(236),char(1),char(205),char(1),char(222),char(255),char(236), -char(1),char(205),char(1),char(234),char(255),char(236),char(1),char(205),char(1),char(237), -char(255),char(236),char(1),char(205),char(1),char(242),char(255),char(195),char(1),char(205), -char(2),char(2),char(255),char(215),char(1),char(205),char(2),char(3),char(255),char(215), -char(1),char(205),char(2),char(4),char(255),char(215),char(1),char(205),char(2),char(8), -char(255),char(154),char(1),char(205),char(2),char(12),char(255),char(154),char(1),char(205), -char(2),char(106),char(255),char(236),char(1),char(205),char(2),char(115),char(255),char(195), -char(1),char(205),char(2),char(127),char(255),char(236),char(1),char(205),char(2),char(133), -char(255),char(236),char(1),char(205),char(2),char(135),char(255),char(236),char(1),char(205), -char(2),char(137),char(255),char(236),char(1),char(205),char(2),char(141),char(255),char(236), -char(1),char(205),char(2),char(178),char(255),char(236),char(1),char(205),char(2),char(180), -char(255),char(236),char(1),char(205),char(2),char(207),char(255),char(195),char(1),char(205), -char(2),char(224),char(255),char(236),char(1),char(205),char(2),char(240),char(255),char(236), -char(1),char(205),char(2),char(242),char(255),char(236),char(1),char(205),char(2),char(244), -char(255),char(236),char(1),char(205),char(3),char(10),char(255),char(236),char(1),char(205), -char(3),char(12),char(255),char(236),char(1),char(205),char(3),char(18),char(255),char(195), -char(1),char(205),char(3),char(22),char(255),char(236),char(1),char(205),char(3),char(26), -char(255),char(236),char(1),char(205),char(3),char(28),char(255),char(195),char(1),char(206), -char(0),char(5),char(255),char(236),char(1),char(206),char(0),char(10),char(255),char(236), -char(1),char(206),char(2),char(7),char(255),char(236),char(1),char(206),char(2),char(11), -char(255),char(236),char(1),char(207),char(0),char(5),char(255),char(236),char(1),char(207), -char(0),char(10),char(255),char(236),char(1),char(207),char(2),char(7),char(255),char(236), -char(1),char(207),char(2),char(11),char(255),char(236),char(1),char(208),char(1),char(207), -char(255),char(215),char(1),char(208),char(1),char(216),char(255),char(215),char(1),char(208), -char(1),char(219),char(255),char(215),char(1),char(208),char(1),char(222),char(255),char(215), -char(1),char(208),char(1),char(225),char(255),char(215),char(1),char(208),char(1),char(234), -char(255),char(215),char(1),char(208),char(1),char(237),char(255),char(215),char(1),char(208), -char(2),char(106),char(255),char(215),char(1),char(208),char(2),char(127),char(255),char(215), -char(1),char(208),char(2),char(133),char(255),char(215),char(1),char(208),char(2),char(135), -char(255),char(215),char(1),char(208),char(2),char(137),char(255),char(215),char(1),char(208), -char(2),char(141),char(255),char(215),char(1),char(208),char(2),char(178),char(255),char(215), -char(1),char(208),char(2),char(180),char(255),char(215),char(1),char(208),char(2),char(192), -char(255),char(215),char(1),char(208),char(2),char(194),char(255),char(215),char(1),char(208), -char(2),char(198),char(255),char(215),char(1),char(208),char(2),char(200),char(255),char(215), -char(1),char(208),char(2),char(213),char(255),char(215),char(1),char(208),char(2),char(224), -char(255),char(215),char(1),char(208),char(2),char(240),char(255),char(215),char(1),char(208), -char(2),char(242),char(255),char(215),char(1),char(208),char(2),char(244),char(255),char(215), -char(1),char(208),char(2),char(254),char(255),char(215),char(1),char(208),char(3),char(10), -char(255),char(215),char(1),char(208),char(3),char(12),char(255),char(215),char(1),char(208), -char(3),char(22),char(255),char(215),char(1),char(208),char(3),char(26),char(255),char(215), -char(1),char(209),char(1),char(233),char(0),char(41),char(1),char(212),char(1),char(207), -char(255),char(215),char(1),char(212),char(1),char(216),char(255),char(215),char(1),char(212), -char(1),char(219),char(255),char(215),char(1),char(212),char(1),char(222),char(255),char(215), -char(1),char(212),char(1),char(225),char(255),char(215),char(1),char(212),char(1),char(234), -char(255),char(215),char(1),char(212),char(1),char(237),char(255),char(215),char(1),char(212), -char(2),char(106),char(255),char(215),char(1),char(212),char(2),char(127),char(255),char(215), -char(1),char(212),char(2),char(133),char(255),char(215),char(1),char(212),char(2),char(135), -char(255),char(215),char(1),char(212),char(2),char(137),char(255),char(215),char(1),char(212), -char(2),char(141),char(255),char(215),char(1),char(212),char(2),char(178),char(255),char(215), -char(1),char(212),char(2),char(180),char(255),char(215),char(1),char(212),char(2),char(192), -char(255),char(215),char(1),char(212),char(2),char(194),char(255),char(215),char(1),char(212), -char(2),char(198),char(255),char(215),char(1),char(212),char(2),char(200),char(255),char(215), -char(1),char(212),char(2),char(213),char(255),char(215),char(1),char(212),char(2),char(224), -char(255),char(215),char(1),char(212),char(2),char(240),char(255),char(215),char(1),char(212), -char(2),char(242),char(255),char(215),char(1),char(212),char(2),char(244),char(255),char(215), -char(1),char(212),char(2),char(254),char(255),char(215),char(1),char(212),char(3),char(10), -char(255),char(215),char(1),char(212),char(3),char(12),char(255),char(215),char(1),char(212), -char(3),char(22),char(255),char(215),char(1),char(212),char(3),char(26),char(255),char(215), -char(1),char(216),char(0),char(5),char(255),char(236),char(1),char(216),char(0),char(10), -char(255),char(236),char(1),char(216),char(1),char(208),char(255),char(215),char(1),char(216), -char(1),char(220),char(255),char(236),char(1),char(216),char(1),char(221),char(255),char(236), -char(1),char(216),char(1),char(223),char(255),char(215),char(1),char(216),char(1),char(225), -char(255),char(236),char(1),char(216),char(1),char(228),char(255),char(236),char(1),char(216), -char(1),char(246),char(255),char(236),char(1),char(216),char(2),char(7),char(255),char(236), -char(1),char(216),char(2),char(11),char(255),char(236),char(1),char(216),char(2),char(160), -char(255),char(215),char(1),char(216),char(2),char(170),char(255),char(236),char(1),char(216), -char(2),char(182),char(255),char(236),char(1),char(216),char(2),char(188),char(255),char(215), -char(1),char(216),char(2),char(190),char(255),char(236),char(1),char(216),char(2),char(192), -char(255),char(236),char(1),char(216),char(2),char(194),char(255),char(236),char(1),char(216), -char(2),char(203),char(255),char(215),char(1),char(216),char(2),char(213),char(255),char(236), -char(1),char(216),char(2),char(230),char(255),char(215),char(1),char(216),char(2),char(248), -char(255),char(236),char(1),char(216),char(2),char(250),char(255),char(236),char(1),char(216), -char(2),char(252),char(255),char(236),char(1),char(216),char(2),char(254),char(255),char(236), -char(1),char(216),char(3),char(6),char(255),char(215),char(1),char(216),char(3),char(8), -char(255),char(215),char(1),char(216),char(3),char(14),char(255),char(236),char(1),char(216), -char(3),char(16),char(255),char(236),char(1),char(216),char(3),char(24),char(255),char(236), -char(1),char(218),char(0),char(5),char(255),char(236),char(1),char(218),char(0),char(10), -char(255),char(236),char(1),char(218),char(1),char(208),char(255),char(215),char(1),char(218), -char(1),char(220),char(255),char(236),char(1),char(218),char(1),char(221),char(255),char(236), -char(1),char(218),char(1),char(223),char(255),char(215),char(1),char(218),char(1),char(225), -char(255),char(236),char(1),char(218),char(1),char(228),char(255),char(236),char(1),char(218), -char(1),char(246),char(255),char(236),char(1),char(218),char(2),char(7),char(255),char(236), -char(1),char(218),char(2),char(11),char(255),char(236),char(1),char(218),char(2),char(160), -char(255),char(215),char(1),char(218),char(2),char(170),char(255),char(236),char(1),char(218), -char(2),char(182),char(255),char(236),char(1),char(218),char(2),char(188),char(255),char(215), -char(1),char(218),char(2),char(190),char(255),char(236),char(1),char(218),char(2),char(192), -char(255),char(236),char(1),char(218),char(2),char(194),char(255),char(236),char(1),char(218), -char(2),char(203),char(255),char(215),char(1),char(218),char(2),char(213),char(255),char(236), -char(1),char(218),char(2),char(230),char(255),char(215),char(1),char(218),char(2),char(248), -char(255),char(236),char(1),char(218),char(2),char(250),char(255),char(236),char(1),char(218), -char(2),char(252),char(255),char(236),char(1),char(218),char(2),char(254),char(255),char(236), -char(1),char(218),char(3),char(6),char(255),char(215),char(1),char(218),char(3),char(8), -char(255),char(215),char(1),char(218),char(3),char(14),char(255),char(236),char(1),char(218), -char(3),char(16),char(255),char(236),char(1),char(218),char(3),char(24),char(255),char(236), -char(1),char(220),char(0),char(15),char(255),char(154),char(1),char(220),char(0),char(16), -char(255),char(215),char(1),char(220),char(0),char(17),char(255),char(154),char(1),char(220), -char(1),char(206),char(255),char(195),char(1),char(220),char(1),char(207),char(255),char(236), -char(1),char(220),char(1),char(213),char(255),char(195),char(1),char(220),char(1),char(216), -char(255),char(236),char(1),char(220),char(1),char(219),char(255),char(236),char(1),char(220), -char(1),char(222),char(255),char(236),char(1),char(220),char(1),char(234),char(255),char(236), -char(1),char(220),char(1),char(237),char(255),char(236),char(1),char(220),char(1),char(242), -char(255),char(195),char(1),char(220),char(2),char(2),char(255),char(215),char(1),char(220), -char(2),char(3),char(255),char(215),char(1),char(220),char(2),char(4),char(255),char(215), -char(1),char(220),char(2),char(8),char(255),char(154),char(1),char(220),char(2),char(12), -char(255),char(154),char(1),char(220),char(2),char(106),char(255),char(236),char(1),char(220), -char(2),char(115),char(255),char(195),char(1),char(220),char(2),char(127),char(255),char(236), -char(1),char(220),char(2),char(133),char(255),char(236),char(1),char(220),char(2),char(135), -char(255),char(236),char(1),char(220),char(2),char(137),char(255),char(236),char(1),char(220), -char(2),char(141),char(255),char(236),char(1),char(220),char(2),char(178),char(255),char(236), -char(1),char(220),char(2),char(180),char(255),char(236),char(1),char(220),char(2),char(207), -char(255),char(195),char(1),char(220),char(2),char(224),char(255),char(236),char(1),char(220), -char(2),char(240),char(255),char(236),char(1),char(220),char(2),char(242),char(255),char(236), -char(1),char(220),char(2),char(244),char(255),char(236),char(1),char(220),char(3),char(10), -char(255),char(236),char(1),char(220),char(3),char(12),char(255),char(236),char(1),char(220), -char(3),char(18),char(255),char(195),char(1),char(220),char(3),char(22),char(255),char(236), -char(1),char(220),char(3),char(26),char(255),char(236),char(1),char(220),char(3),char(28), -char(255),char(195),char(1),char(221),char(0),char(15),char(255),char(174),char(1),char(221), -char(0),char(17),char(255),char(174),char(1),char(221),char(1),char(206),char(255),char(215), -char(1),char(221),char(1),char(213),char(255),char(215),char(1),char(221),char(1),char(242), -char(255),char(215),char(1),char(221),char(2),char(8),char(255),char(174),char(1),char(221), -char(2),char(12),char(255),char(174),char(1),char(221),char(2),char(115),char(255),char(215), -char(1),char(221),char(2),char(207),char(255),char(215),char(1),char(221),char(3),char(18), -char(255),char(215),char(1),char(221),char(3),char(28),char(255),char(215),char(1),char(222), -char(0),char(5),char(255),char(236),char(1),char(222),char(0),char(10),char(255),char(236), -char(1),char(222),char(1),char(208),char(255),char(215),char(1),char(222),char(1),char(220), -char(255),char(236),char(1),char(222),char(1),char(221),char(255),char(236),char(1),char(222), -char(1),char(223),char(255),char(215),char(1),char(222),char(1),char(225),char(255),char(236), -char(1),char(222),char(1),char(228),char(255),char(236),char(1),char(222),char(1),char(246), -char(255),char(236),char(1),char(222),char(2),char(7),char(255),char(236),char(1),char(222), -char(2),char(11),char(255),char(236),char(1),char(222),char(2),char(160),char(255),char(215), -char(1),char(222),char(2),char(170),char(255),char(236),char(1),char(222),char(2),char(182), -char(255),char(236),char(1),char(222),char(2),char(188),char(255),char(215),char(1),char(222), -char(2),char(190),char(255),char(236),char(1),char(222),char(2),char(192),char(255),char(236), -char(1),char(222),char(2),char(194),char(255),char(236),char(1),char(222),char(2),char(203), -char(255),char(215),char(1),char(222),char(2),char(213),char(255),char(236),char(1),char(222), -char(2),char(230),char(255),char(215),char(1),char(222),char(2),char(248),char(255),char(236), -char(1),char(222),char(2),char(250),char(255),char(236),char(1),char(222),char(2),char(252), -char(255),char(236),char(1),char(222),char(2),char(254),char(255),char(236),char(1),char(222), -char(3),char(6),char(255),char(215),char(1),char(222),char(3),char(8),char(255),char(215), -char(1),char(222),char(3),char(14),char(255),char(236),char(1),char(222),char(3),char(16), -char(255),char(236),char(1),char(222),char(3),char(24),char(255),char(236),char(1),char(223), -char(1),char(207),char(255),char(215),char(1),char(223),char(1),char(216),char(255),char(215), -char(1),char(223),char(1),char(219),char(255),char(215),char(1),char(223),char(1),char(222), -char(255),char(215),char(1),char(223),char(1),char(225),char(255),char(215),char(1),char(223), -char(1),char(234),char(255),char(215),char(1),char(223),char(1),char(237),char(255),char(215), -char(1),char(223),char(2),char(106),char(255),char(215),char(1),char(223),char(2),char(127), -char(255),char(215),char(1),char(223),char(2),char(133),char(255),char(215),char(1),char(223), -char(2),char(135),char(255),char(215),char(1),char(223),char(2),char(137),char(255),char(215), -char(1),char(223),char(2),char(141),char(255),char(215),char(1),char(223),char(2),char(178), -char(255),char(215),char(1),char(223),char(2),char(180),char(255),char(215),char(1),char(223), -char(2),char(192),char(255),char(215),char(1),char(223),char(2),char(194),char(255),char(215), -char(1),char(223),char(2),char(198),char(255),char(215),char(1),char(223),char(2),char(200), -char(255),char(215),char(1),char(223),char(2),char(213),char(255),char(215),char(1),char(223), -char(2),char(224),char(255),char(215),char(1),char(223),char(2),char(240),char(255),char(215), -char(1),char(223),char(2),char(242),char(255),char(215),char(1),char(223),char(2),char(244), -char(255),char(215),char(1),char(223),char(2),char(254),char(255),char(215),char(1),char(223), -char(3),char(10),char(255),char(215),char(1),char(223),char(3),char(12),char(255),char(215), -char(1),char(223),char(3),char(22),char(255),char(215),char(1),char(223),char(3),char(26), -char(255),char(215),char(1),char(224),char(0),char(5),char(255),char(236),char(1),char(224), -char(0),char(10),char(255),char(236),char(1),char(224),char(2),char(7),char(255),char(236), -char(1),char(224),char(2),char(11),char(255),char(236),char(1),char(227),char(0),char(5), -char(255),char(236),char(1),char(227),char(0),char(10),char(255),char(236),char(1),char(227), -char(2),char(7),char(255),char(236),char(1),char(227),char(2),char(11),char(255),char(236), -char(1),char(228),char(0),char(5),char(255),char(133),char(1),char(228),char(0),char(10), -char(255),char(133),char(1),char(228),char(1),char(208),char(255),char(215),char(1),char(228), -char(1),char(220),char(255),char(154),char(1),char(228),char(1),char(221),char(255),char(195), -char(1),char(228),char(1),char(223),char(255),char(215),char(1),char(228),char(1),char(225), -char(255),char(174),char(1),char(228),char(1),char(228),char(255),char(154),char(1),char(228), -char(1),char(246),char(255),char(195),char(1),char(228),char(2),char(7),char(255),char(133), -char(1),char(228),char(2),char(11),char(255),char(133),char(1),char(228),char(2),char(109), -char(255),char(215),char(1),char(228),char(2),char(129),char(255),char(215),char(1),char(228), -char(2),char(131),char(255),char(215),char(1),char(228),char(2),char(139),char(255),char(215), -char(1),char(228),char(2),char(160),char(255),char(215),char(1),char(228),char(2),char(170), -char(255),char(154),char(1),char(228),char(2),char(182),char(255),char(154),char(1),char(228), -char(2),char(184),char(255),char(195),char(1),char(228),char(2),char(186),char(255),char(195), -char(1),char(228),char(2),char(188),char(255),char(215),char(1),char(228),char(2),char(190), -char(255),char(154),char(1),char(228),char(2),char(192),char(255),char(174),char(1),char(228), -char(2),char(194),char(255),char(174),char(1),char(228),char(2),char(198),char(255),char(215), -char(1),char(228),char(2),char(200),char(255),char(215),char(1),char(228),char(2),char(203), -char(255),char(215),char(1),char(228),char(2),char(213),char(255),char(174),char(1),char(228), -char(2),char(230),char(255),char(215),char(1),char(228),char(2),char(234),char(255),char(215), -char(1),char(228),char(2),char(248),char(255),char(195),char(1),char(228),char(2),char(250), -char(255),char(195),char(1),char(228),char(2),char(252),char(255),char(195),char(1),char(228), -char(2),char(254),char(255),char(174),char(1),char(228),char(3),char(6),char(255),char(215), -char(1),char(228),char(3),char(8),char(255),char(215),char(1),char(228),char(3),char(14), -char(255),char(154),char(1),char(228),char(3),char(16),char(255),char(154),char(1),char(228), -char(3),char(24),char(255),char(154),char(1),char(230),char(0),char(5),char(255),char(133), -char(1),char(230),char(0),char(10),char(255),char(133),char(1),char(230),char(1),char(208), -char(255),char(215),char(1),char(230),char(1),char(220),char(255),char(154),char(1),char(230), -char(1),char(221),char(255),char(195),char(1),char(230),char(1),char(223),char(255),char(215), -char(1),char(230),char(1),char(225),char(255),char(174),char(1),char(230),char(1),char(228), -char(255),char(154),char(1),char(230),char(1),char(246),char(255),char(195),char(1),char(230), -char(2),char(7),char(255),char(133),char(1),char(230),char(2),char(11),char(255),char(133), -char(1),char(230),char(2),char(109),char(255),char(215),char(1),char(230),char(2),char(129), -char(255),char(215),char(1),char(230),char(2),char(131),char(255),char(215),char(1),char(230), -char(2),char(139),char(255),char(215),char(1),char(230),char(2),char(160),char(255),char(215), -char(1),char(230),char(2),char(170),char(255),char(154),char(1),char(230),char(2),char(182), -char(255),char(154),char(1),char(230),char(2),char(184),char(255),char(195),char(1),char(230), -char(2),char(186),char(255),char(195),char(1),char(230),char(2),char(188),char(255),char(215), -char(1),char(230),char(2),char(190),char(255),char(154),char(1),char(230),char(2),char(192), -char(255),char(174),char(1),char(230),char(2),char(194),char(255),char(174),char(1),char(230), -char(2),char(198),char(255),char(215),char(1),char(230),char(2),char(200),char(255),char(215), -char(1),char(230),char(2),char(203),char(255),char(215),char(1),char(230),char(2),char(213), -char(255),char(174),char(1),char(230),char(2),char(230),char(255),char(215),char(1),char(230), -char(2),char(234),char(255),char(215),char(1),char(230),char(2),char(248),char(255),char(195), -char(1),char(230),char(2),char(250),char(255),char(195),char(1),char(230),char(2),char(252), -char(255),char(195),char(1),char(230),char(2),char(254),char(255),char(174),char(1),char(230), -char(3),char(6),char(255),char(215),char(1),char(230),char(3),char(8),char(255),char(215), -char(1),char(230),char(3),char(14),char(255),char(154),char(1),char(230),char(3),char(16), -char(255),char(154),char(1),char(230),char(3),char(24),char(255),char(154),char(1),char(231), -char(0),char(5),char(255),char(236),char(1),char(231),char(0),char(10),char(255),char(236), -char(1),char(231),char(1),char(208),char(255),char(215),char(1),char(231),char(1),char(220), -char(255),char(236),char(1),char(231),char(1),char(221),char(255),char(236),char(1),char(231), -char(1),char(223),char(255),char(215),char(1),char(231),char(1),char(225),char(255),char(236), -char(1),char(231),char(1),char(228),char(255),char(236),char(1),char(231),char(1),char(246), -char(255),char(236),char(1),char(231),char(2),char(7),char(255),char(236),char(1),char(231), -char(2),char(11),char(255),char(236),char(1),char(231),char(2),char(160),char(255),char(215), -char(1),char(231),char(2),char(170),char(255),char(236),char(1),char(231),char(2),char(182), -char(255),char(236),char(1),char(231),char(2),char(188),char(255),char(215),char(1),char(231), -char(2),char(190),char(255),char(236),char(1),char(231),char(2),char(192),char(255),char(236), -char(1),char(231),char(2),char(194),char(255),char(236),char(1),char(231),char(2),char(203), -char(255),char(215),char(1),char(231),char(2),char(213),char(255),char(236),char(1),char(231), -char(2),char(230),char(255),char(215),char(1),char(231),char(2),char(248),char(255),char(236), -char(1),char(231),char(2),char(250),char(255),char(236),char(1),char(231),char(2),char(252), -char(255),char(236),char(1),char(231),char(2),char(254),char(255),char(236),char(1),char(231), -char(3),char(6),char(255),char(215),char(1),char(231),char(3),char(8),char(255),char(215), -char(1),char(231),char(3),char(14),char(255),char(236),char(1),char(231),char(3),char(16), -char(255),char(236),char(1),char(231),char(3),char(24),char(255),char(236),char(1),char(232), -char(0),char(5),char(255),char(236),char(1),char(232),char(0),char(10),char(255),char(236), -char(1),char(232),char(1),char(208),char(255),char(215),char(1),char(232),char(1),char(220), -char(255),char(236),char(1),char(232),char(1),char(221),char(255),char(236),char(1),char(232), -char(1),char(223),char(255),char(215),char(1),char(232),char(1),char(225),char(255),char(236), -char(1),char(232),char(1),char(228),char(255),char(236),char(1),char(232),char(1),char(246), -char(255),char(236),char(1),char(232),char(2),char(7),char(255),char(236),char(1),char(232), -char(2),char(11),char(255),char(236),char(1),char(232),char(2),char(160),char(255),char(215), -char(1),char(232),char(2),char(170),char(255),char(236),char(1),char(232),char(2),char(182), -char(255),char(236),char(1),char(232),char(2),char(188),char(255),char(215),char(1),char(232), -char(2),char(190),char(255),char(236),char(1),char(232),char(2),char(192),char(255),char(236), -char(1),char(232),char(2),char(194),char(255),char(236),char(1),char(232),char(2),char(203), -char(255),char(215),char(1),char(232),char(2),char(213),char(255),char(236),char(1),char(232), -char(2),char(230),char(255),char(215),char(1),char(232),char(2),char(248),char(255),char(236), -char(1),char(232),char(2),char(250),char(255),char(236),char(1),char(232),char(2),char(252), -char(255),char(236),char(1),char(232),char(2),char(254),char(255),char(236),char(1),char(232), -char(3),char(6),char(255),char(215),char(1),char(232),char(3),char(8),char(255),char(215), -char(1),char(232),char(3),char(14),char(255),char(236),char(1),char(232),char(3),char(16), -char(255),char(236),char(1),char(232),char(3),char(24),char(255),char(236),char(1),char(234), -char(0),char(5),char(255),char(236),char(1),char(234),char(0),char(10),char(255),char(236), -char(1),char(234),char(2),char(7),char(255),char(236),char(1),char(234),char(2),char(11), -char(255),char(236),char(1),char(235),char(0),char(5),char(255),char(236),char(1),char(235), -char(0),char(10),char(255),char(236),char(1),char(235),char(2),char(7),char(255),char(236), -char(1),char(235),char(2),char(11),char(255),char(236),char(1),char(235),char(3),char(14), -char(255),char(215),char(1),char(235),char(3),char(16),char(255),char(215),char(1),char(236), -char(0),char(15),char(255),char(154),char(1),char(236),char(0),char(16),char(255),char(215), -char(1),char(236),char(0),char(17),char(255),char(154),char(1),char(236),char(1),char(206), -char(255),char(195),char(1),char(236),char(1),char(207),char(255),char(236),char(1),char(236), -char(1),char(213),char(255),char(195),char(1),char(236),char(1),char(216),char(255),char(236), -char(1),char(236),char(1),char(219),char(255),char(236),char(1),char(236),char(1),char(222), -char(255),char(236),char(1),char(236),char(1),char(234),char(255),char(236),char(1),char(236), -char(1),char(237),char(255),char(236),char(1),char(236),char(1),char(242),char(255),char(195), -char(1),char(236),char(2),char(2),char(255),char(215),char(1),char(236),char(2),char(3), -char(255),char(215),char(1),char(236),char(2),char(4),char(255),char(215),char(1),char(236), -char(2),char(8),char(255),char(154),char(1),char(236),char(2),char(12),char(255),char(154), -char(1),char(236),char(2),char(106),char(255),char(236),char(1),char(236),char(2),char(115), -char(255),char(195),char(1),char(236),char(2),char(127),char(255),char(236),char(1),char(236), -char(2),char(133),char(255),char(236),char(1),char(236),char(2),char(135),char(255),char(236), -char(1),char(236),char(2),char(137),char(255),char(236),char(1),char(236),char(2),char(141), -char(255),char(236),char(1),char(236),char(2),char(178),char(255),char(236),char(1),char(236), -char(2),char(180),char(255),char(236),char(1),char(236),char(2),char(207),char(255),char(195), -char(1),char(236),char(2),char(224),char(255),char(236),char(1),char(236),char(2),char(240), -char(255),char(236),char(1),char(236),char(2),char(242),char(255),char(236),char(1),char(236), -char(2),char(244),char(255),char(236),char(1),char(236),char(3),char(10),char(255),char(236), -char(1),char(236),char(3),char(12),char(255),char(236),char(1),char(236),char(3),char(18), -char(255),char(195),char(1),char(236),char(3),char(22),char(255),char(236),char(1),char(236), -char(3),char(26),char(255),char(236),char(1),char(236),char(3),char(28),char(255),char(195), -char(1),char(242),char(0),char(5),char(255),char(133),char(1),char(242),char(0),char(10), -char(255),char(133),char(1),char(242),char(1),char(208),char(255),char(215),char(1),char(242), -char(1),char(220),char(255),char(154),char(1),char(242),char(1),char(221),char(255),char(195), -char(1),char(242),char(1),char(223),char(255),char(215),char(1),char(242),char(1),char(225), -char(255),char(174),char(1),char(242),char(1),char(228),char(255),char(154),char(1),char(242), -char(1),char(246),char(255),char(195),char(1),char(242),char(2),char(7),char(255),char(133), -char(1),char(242),char(2),char(11),char(255),char(133),char(1),char(242),char(2),char(109), -char(255),char(215),char(1),char(242),char(2),char(129),char(255),char(215),char(1),char(242), -char(2),char(131),char(255),char(215),char(1),char(242),char(2),char(139),char(255),char(215), -char(1),char(242),char(2),char(160),char(255),char(215),char(1),char(242),char(2),char(170), -char(255),char(154),char(1),char(242),char(2),char(182),char(255),char(154),char(1),char(242), -char(2),char(184),char(255),char(195),char(1),char(242),char(2),char(186),char(255),char(195), -char(1),char(242),char(2),char(188),char(255),char(215),char(1),char(242),char(2),char(190), -char(255),char(154),char(1),char(242),char(2),char(192),char(255),char(174),char(1),char(242), -char(2),char(194),char(255),char(174),char(1),char(242),char(2),char(198),char(255),char(215), -char(1),char(242),char(2),char(200),char(255),char(215),char(1),char(242),char(2),char(203), -char(255),char(215),char(1),char(242),char(2),char(213),char(255),char(174),char(1),char(242), -char(2),char(230),char(255),char(215),char(1),char(242),char(2),char(234),char(255),char(215), -char(1),char(242),char(2),char(248),char(255),char(195),char(1),char(242),char(2),char(250), -char(255),char(195),char(1),char(242),char(2),char(252),char(255),char(195),char(1),char(242), -char(2),char(254),char(255),char(174),char(1),char(242),char(3),char(6),char(255),char(215), -char(1),char(242),char(3),char(8),char(255),char(215),char(1),char(242),char(3),char(14), -char(255),char(154),char(1),char(242),char(3),char(16),char(255),char(154),char(1),char(242), -char(3),char(24),char(255),char(154),char(1),char(243),char(0),char(5),char(255),char(133), -char(1),char(243),char(0),char(10),char(255),char(133),char(1),char(243),char(1),char(208), -char(255),char(215),char(1),char(243),char(1),char(220),char(255),char(154),char(1),char(243), -char(1),char(221),char(255),char(195),char(1),char(243),char(1),char(223),char(255),char(215), -char(1),char(243),char(1),char(225),char(255),char(174),char(1),char(243),char(1),char(228), -char(255),char(154),char(1),char(243),char(1),char(246),char(255),char(195),char(1),char(243), -char(2),char(7),char(255),char(133),char(1),char(243),char(2),char(11),char(255),char(133), -char(1),char(243),char(2),char(109),char(255),char(215),char(1),char(243),char(2),char(129), -char(255),char(215),char(1),char(243),char(2),char(131),char(255),char(215),char(1),char(243), -char(2),char(139),char(255),char(215),char(1),char(243),char(2),char(160),char(255),char(215), -char(1),char(243),char(2),char(170),char(255),char(154),char(1),char(243),char(2),char(182), -char(255),char(154),char(1),char(243),char(2),char(184),char(255),char(195),char(1),char(243), -char(2),char(186),char(255),char(195),char(1),char(243),char(2),char(188),char(255),char(215), -char(1),char(243),char(2),char(190),char(255),char(154),char(1),char(243),char(2),char(192), -char(255),char(174),char(1),char(243),char(2),char(194),char(255),char(174),char(1),char(243), -char(2),char(198),char(255),char(215),char(1),char(243),char(2),char(200),char(255),char(215), -char(1),char(243),char(2),char(203),char(255),char(215),char(1),char(243),char(2),char(213), -char(255),char(174),char(1),char(243),char(2),char(230),char(255),char(215),char(1),char(243), -char(2),char(234),char(255),char(215),char(1),char(243),char(2),char(248),char(255),char(195), -char(1),char(243),char(2),char(250),char(255),char(195),char(1),char(243),char(2),char(252), -char(255),char(195),char(1),char(243),char(2),char(254),char(255),char(174),char(1),char(243), -char(3),char(6),char(255),char(215),char(1),char(243),char(3),char(8),char(255),char(215), -char(1),char(243),char(3),char(14),char(255),char(154),char(1),char(243),char(3),char(16), -char(255),char(154),char(1),char(243),char(3),char(24),char(255),char(154),char(1),char(244), -char(0),char(5),char(255),char(236),char(1),char(244),char(0),char(10),char(255),char(236), -char(1),char(244),char(2),char(7),char(255),char(236),char(1),char(244),char(2),char(11), -char(255),char(236),char(1),char(244),char(3),char(14),char(255),char(215),char(1),char(244), -char(3),char(16),char(255),char(215),char(1),char(245),char(1),char(207),char(255),char(215), -char(1),char(245),char(1),char(216),char(255),char(215),char(1),char(245),char(1),char(219), -char(255),char(215),char(1),char(245),char(1),char(222),char(255),char(215),char(1),char(245), -char(1),char(225),char(255),char(215),char(1),char(245),char(1),char(234),char(255),char(215), -char(1),char(245),char(1),char(237),char(255),char(215),char(1),char(245),char(2),char(106), -char(255),char(215),char(1),char(245),char(2),char(127),char(255),char(215),char(1),char(245), -char(2),char(133),char(255),char(215),char(1),char(245),char(2),char(135),char(255),char(215), -char(1),char(245),char(2),char(137),char(255),char(215),char(1),char(245),char(2),char(141), -char(255),char(215),char(1),char(245),char(2),char(178),char(255),char(215),char(1),char(245), -char(2),char(180),char(255),char(215),char(1),char(245),char(2),char(192),char(255),char(215), -char(1),char(245),char(2),char(194),char(255),char(215),char(1),char(245),char(2),char(198), -char(255),char(215),char(1),char(245),char(2),char(200),char(255),char(215),char(1),char(245), -char(2),char(213),char(255),char(215),char(1),char(245),char(2),char(224),char(255),char(215), -char(1),char(245),char(2),char(240),char(255),char(215),char(1),char(245),char(2),char(242), -char(255),char(215),char(1),char(245),char(2),char(244),char(255),char(215),char(1),char(245), -char(2),char(254),char(255),char(215),char(1),char(245),char(3),char(10),char(255),char(215), -char(1),char(245),char(3),char(12),char(255),char(215),char(1),char(245),char(3),char(22), -char(255),char(215),char(1),char(245),char(3),char(26),char(255),char(215),char(1),char(246), -char(0),char(15),char(255),char(174),char(1),char(246),char(0),char(17),char(255),char(174), -char(1),char(246),char(1),char(206),char(255),char(215),char(1),char(246),char(1),char(213), -char(255),char(215),char(1),char(246),char(1),char(242),char(255),char(215),char(1),char(246), -char(2),char(8),char(255),char(174),char(1),char(246),char(2),char(12),char(255),char(174), -char(1),char(246),char(2),char(115),char(255),char(215),char(1),char(246),char(2),char(207), -char(255),char(215),char(1),char(246),char(3),char(18),char(255),char(215),char(1),char(246), -char(3),char(28),char(255),char(215),char(1),char(248),char(0),char(15),char(255),char(133), -char(1),char(248),char(0),char(16),char(255),char(174),char(1),char(248),char(0),char(17), -char(255),char(133),char(1),char(248),char(1),char(159),char(255),char(215),char(1),char(248), -char(1),char(164),char(255),char(154),char(1),char(248),char(1),char(170),char(255),char(113), -char(1),char(248),char(1),char(174),char(255),char(154),char(1),char(248),char(1),char(181), -char(255),char(154),char(1),char(248),char(1),char(184),char(255),char(215),char(1),char(248), -char(1),char(187),char(255),char(215),char(1),char(248),char(1),char(188),char(0),char(41), -char(1),char(248),char(1),char(190),char(255),char(174),char(1),char(248),char(1),char(204), -char(255),char(154),char(1),char(248),char(1),char(205),char(255),char(154),char(1),char(248), -char(1),char(206),char(255),char(133),char(1),char(248),char(1),char(207),char(255),char(113), -char(1),char(248),char(1),char(208),char(255),char(215),char(1),char(248),char(1),char(209), -char(255),char(215),char(1),char(248),char(1),char(210),char(255),char(154),char(1),char(248), -char(1),char(211),char(255),char(154),char(1),char(248),char(1),char(212),char(255),char(154), -char(1),char(248),char(1),char(213),char(255),char(133),char(1),char(248),char(1),char(214), -char(255),char(154),char(1),char(248),char(1),char(215),char(255),char(154),char(1),char(248), -char(1),char(216),char(255),char(113),char(1),char(248),char(1),char(217),char(255),char(154), -char(1),char(248),char(1),char(218),char(255),char(154),char(1),char(248),char(1),char(219), -char(255),char(113),char(1),char(248),char(1),char(220),char(255),char(174),char(1),char(248), -char(1),char(221),char(255),char(174),char(1),char(248),char(1),char(222),char(255),char(113), -char(1),char(248),char(1),char(223),char(255),char(215),char(1),char(248),char(1),char(224), -char(255),char(154),char(1),char(248),char(1),char(225),char(255),char(154),char(1),char(248), -char(1),char(226),char(255),char(154),char(1),char(248),char(1),char(227),char(255),char(154), -char(1),char(248),char(1),char(228),char(255),char(174),char(1),char(248),char(1),char(229), -char(255),char(154),char(1),char(248),char(1),char(230),char(255),char(154),char(1),char(248), -char(1),char(231),char(255),char(215),char(1),char(248),char(1),char(232),char(255),char(154), -char(1),char(248),char(1),char(233),char(255),char(195),char(1),char(248),char(1),char(234), -char(255),char(113),char(1),char(248),char(1),char(236),char(255),char(154),char(1),char(248), -char(1),char(237),char(255),char(113),char(1),char(248),char(1),char(238),char(255),char(133), -char(1),char(248),char(1),char(242),char(255),char(133),char(1),char(248),char(1),char(243), -char(255),char(154),char(1),char(248),char(1),char(245),char(255),char(154),char(1),char(248), -char(1),char(246),char(255),char(174),char(1),char(248),char(1),char(247),char(255),char(154), -char(1),char(248),char(1),char(249),char(255),char(154),char(1),char(248),char(2),char(2), -char(255),char(174),char(1),char(248),char(2),char(3),char(255),char(174),char(1),char(248), -char(2),char(4),char(255),char(174),char(1),char(248),char(2),char(8),char(255),char(133), -char(1),char(248),char(2),char(12),char(255),char(133),char(1),char(248),char(2),char(106), -char(255),char(113),char(1),char(248),char(2),char(107),char(255),char(154),char(1),char(248), -char(2),char(108),char(255),char(215),char(1),char(248),char(2),char(109),char(255),char(215), -char(1),char(248),char(2),char(113),char(255),char(154),char(1),char(248),char(2),char(114), -char(255),char(113),char(1),char(248),char(2),char(115),char(255),char(133),char(1),char(248), -char(2),char(117),char(255),char(154),char(1),char(248),char(2),char(119),char(255),char(154), -char(1),char(248),char(2),char(121),char(255),char(154),char(1),char(248),char(2),char(125), -char(255),char(154),char(1),char(248),char(2),char(126),char(255),char(215),char(1),char(248), -char(2),char(127),char(255),char(113),char(1),char(248),char(2),char(129),char(255),char(215), -char(1),char(248),char(2),char(131),char(255),char(215),char(1),char(248),char(2),char(132), -char(255),char(215),char(1),char(248),char(2),char(133),char(255),char(113),char(1),char(248), -char(2),char(134),char(255),char(215),char(1),char(248),char(2),char(135),char(255),char(113), -char(1),char(248),char(2),char(136),char(255),char(215),char(1),char(248),char(2),char(137), -char(255),char(113),char(1),char(248),char(2),char(138),char(255),char(215),char(1),char(248), -char(2),char(139),char(255),char(215),char(1),char(248),char(2),char(140),char(255),char(215), -char(1),char(248),char(2),char(141),char(255),char(113),char(1),char(248),char(2),char(150), -char(255),char(154),char(1),char(248),char(2),char(154),char(255),char(154),char(1),char(248), -char(2),char(158),char(255),char(154),char(1),char(248),char(2),char(160),char(255),char(215), -char(1),char(248),char(2),char(162),char(255),char(215),char(1),char(248),char(2),char(164), -char(255),char(154),char(1),char(248),char(2),char(166),char(255),char(154),char(1),char(248), -char(2),char(170),char(255),char(174),char(1),char(248),char(2),char(172),char(255),char(154), -char(1),char(248),char(2),char(174),char(255),char(154),char(1),char(248),char(2),char(176), -char(255),char(154),char(1),char(248),char(2),char(177),char(255),char(215),char(1),char(248), -char(2),char(178),char(255),char(113),char(1),char(248),char(2),char(179),char(255),char(215), -char(1),char(248),char(2),char(180),char(255),char(113),char(1),char(248),char(2),char(181), -char(0),char(41),char(1),char(248),char(2),char(182),char(255),char(174),char(1),char(248), -char(2),char(184),char(255),char(174),char(1),char(248),char(2),char(186),char(255),char(174), -char(1),char(248),char(2),char(188),char(255),char(215),char(1),char(248),char(2),char(190), -char(255),char(174),char(1),char(248),char(2),char(192),char(255),char(154),char(1),char(248), -char(2),char(194),char(255),char(154),char(1),char(248),char(2),char(196),char(255),char(154), -char(1),char(248),char(2),char(197),char(255),char(154),char(1),char(248),char(2),char(198), -char(255),char(113),char(1),char(248),char(2),char(199),char(255),char(154),char(1),char(248), -char(2),char(200),char(255),char(113),char(1),char(248),char(2),char(203),char(255),char(215), -char(1),char(248),char(2),char(205),char(255),char(154),char(1),char(248),char(2),char(206), -char(255),char(154),char(1),char(248),char(2),char(207),char(255),char(133),char(1),char(248), -char(2),char(209),char(255),char(154),char(1),char(248),char(2),char(211),char(255),char(154), -char(1),char(248),char(2),char(213),char(255),char(154),char(1),char(248),char(2),char(215), -char(255),char(154),char(1),char(248),char(2),char(217),char(255),char(113),char(1),char(248), -char(2),char(219),char(255),char(113),char(1),char(248),char(2),char(221),char(255),char(113), -char(1),char(248),char(2),char(224),char(255),char(113),char(1),char(248),char(2),char(230), -char(255),char(215),char(1),char(248),char(2),char(232),char(255),char(215),char(1),char(248), -char(2),char(234),char(255),char(195),char(1),char(248),char(2),char(236),char(255),char(154), -char(1),char(248),char(2),char(238),char(255),char(154),char(1),char(248),char(2),char(239), -char(255),char(215),char(1),char(248),char(2),char(240),char(255),char(113),char(1),char(248), -char(2),char(241),char(255),char(215),char(1),char(248),char(2),char(242),char(255),char(113), -char(1),char(248),char(2),char(243),char(255),char(215),char(1),char(248),char(2),char(244), -char(255),char(113),char(1),char(248),char(2),char(246),char(255),char(215),char(1),char(248), -char(2),char(248),char(255),char(174),char(1),char(248),char(2),char(250),char(255),char(174), -char(1),char(248),char(2),char(252),char(255),char(174),char(1),char(248),char(2),char(254), -char(255),char(154),char(1),char(248),char(3),char(0),char(255),char(154),char(1),char(248), -char(3),char(2),char(255),char(154),char(1),char(248),char(3),char(6),char(255),char(215), -char(1),char(248),char(3),char(8),char(255),char(215),char(1),char(248),char(3),char(9), -char(255),char(113),char(1),char(248),char(3),char(10),char(255),char(113),char(1),char(248), -char(3),char(11),char(255),char(113),char(1),char(248),char(3),char(12),char(255),char(113), -char(1),char(248),char(3),char(14),char(255),char(154),char(1),char(248),char(3),char(16), -char(255),char(154),char(1),char(248),char(3),char(17),char(255),char(154),char(1),char(248), -char(3),char(18),char(255),char(133),char(1),char(248),char(3),char(20),char(255),char(154), -char(1),char(248),char(3),char(21),char(255),char(215),char(1),char(248),char(3),char(22), -char(255),char(113),char(1),char(248),char(3),char(24),char(255),char(174),char(1),char(248), -char(3),char(26),char(255),char(113),char(1),char(248),char(3),char(27),char(255),char(154), -char(1),char(248),char(3),char(28),char(255),char(133),char(1),char(249),char(0),char(15), -char(255),char(154),char(1),char(249),char(0),char(16),char(255),char(215),char(1),char(249), -char(0),char(17),char(255),char(154),char(1),char(249),char(1),char(206),char(255),char(195), -char(1),char(249),char(1),char(207),char(255),char(236),char(1),char(249),char(1),char(213), -char(255),char(195),char(1),char(249),char(1),char(216),char(255),char(236),char(1),char(249), -char(1),char(219),char(255),char(236),char(1),char(249),char(1),char(222),char(255),char(236), -char(1),char(249),char(1),char(234),char(255),char(236),char(1),char(249),char(1),char(237), -char(255),char(236),char(1),char(249),char(1),char(242),char(255),char(195),char(1),char(249), -char(2),char(2),char(255),char(215),char(1),char(249),char(2),char(3),char(255),char(215), -char(1),char(249),char(2),char(4),char(255),char(215),char(1),char(249),char(2),char(8), -char(255),char(154),char(1),char(249),char(2),char(12),char(255),char(154),char(1),char(249), -char(2),char(106),char(255),char(236),char(1),char(249),char(2),char(115),char(255),char(195), -char(1),char(249),char(2),char(127),char(255),char(236),char(1),char(249),char(2),char(133), -char(255),char(236),char(1),char(249),char(2),char(135),char(255),char(236),char(1),char(249), -char(2),char(137),char(255),char(236),char(1),char(249),char(2),char(141),char(255),char(236), -char(1),char(249),char(2),char(178),char(255),char(236),char(1),char(249),char(2),char(180), -char(255),char(236),char(1),char(249),char(2),char(207),char(255),char(195),char(1),char(249), -char(2),char(224),char(255),char(236),char(1),char(249),char(2),char(240),char(255),char(236), -char(1),char(249),char(2),char(242),char(255),char(236),char(1),char(249),char(2),char(244), -char(255),char(236),char(1),char(249),char(3),char(10),char(255),char(236),char(1),char(249), -char(3),char(12),char(255),char(236),char(1),char(249),char(3),char(18),char(255),char(195), -char(1),char(249),char(3),char(22),char(255),char(236),char(1),char(249),char(3),char(26), -char(255),char(236),char(1),char(249),char(3),char(28),char(255),char(195),char(1),char(250), -char(0),char(15),char(255),char(154),char(1),char(250),char(0),char(17),char(255),char(154), -char(1),char(250),char(0),char(34),char(0),char(41),char(1),char(250),char(0),char(36), -char(255),char(174),char(1),char(250),char(0),char(38),char(255),char(236),char(1),char(250), -char(0),char(42),char(255),char(236),char(1),char(250),char(0),char(50),char(255),char(236), -char(1),char(250),char(0),char(52),char(255),char(236),char(1),char(250),char(0),char(68), -char(255),char(215),char(1),char(250),char(0),char(70),char(255),char(215),char(1),char(250), -char(0),char(71),char(255),char(215),char(1),char(250),char(0),char(72),char(255),char(215), -char(1),char(250),char(0),char(74),char(255),char(236),char(1),char(250),char(0),char(80), -char(255),char(236),char(1),char(250),char(0),char(81),char(255),char(236),char(1),char(250), -char(0),char(82),char(255),char(215),char(1),char(250),char(0),char(83),char(255),char(236), -char(1),char(250),char(0),char(84),char(255),char(215),char(1),char(250),char(0),char(85), -char(255),char(236),char(1),char(250),char(0),char(86),char(255),char(236),char(1),char(250), -char(0),char(88),char(255),char(236),char(1),char(250),char(0),char(130),char(255),char(174), -char(1),char(250),char(0),char(131),char(255),char(174),char(1),char(250),char(0),char(132), -char(255),char(174),char(1),char(250),char(0),char(133),char(255),char(174),char(1),char(250), -char(0),char(134),char(255),char(174),char(1),char(250),char(0),char(135),char(255),char(174), -char(1),char(250),char(0),char(137),char(255),char(236),char(1),char(250),char(0),char(148), -char(255),char(236),char(1),char(250),char(0),char(149),char(255),char(236),char(1),char(250), -char(0),char(150),char(255),char(236),char(1),char(250),char(0),char(151),char(255),char(236), -char(1),char(250),char(0),char(152),char(255),char(236),char(1),char(250),char(0),char(154), -char(255),char(236),char(1),char(250),char(0),char(162),char(255),char(215),char(1),char(250), -char(0),char(163),char(255),char(215),char(1),char(250),char(0),char(164),char(255),char(215), -char(1),char(250),char(0),char(165),char(255),char(215),char(1),char(250),char(0),char(166), -char(255),char(215),char(1),char(250),char(0),char(167),char(255),char(215),char(1),char(250), -char(0),char(168),char(255),char(215),char(1),char(250),char(0),char(169),char(255),char(215), -char(1),char(250),char(0),char(170),char(255),char(215),char(1),char(250),char(0),char(171), -char(255),char(215),char(1),char(250),char(0),char(172),char(255),char(215),char(1),char(250), -char(0),char(173),char(255),char(215),char(1),char(250),char(0),char(180),char(255),char(215), -char(1),char(250),char(0),char(181),char(255),char(215),char(1),char(250),char(0),char(182), -char(255),char(215),char(1),char(250),char(0),char(183),char(255),char(215),char(1),char(250), -char(0),char(184),char(255),char(215),char(1),char(250),char(0),char(186),char(255),char(215), -char(1),char(250),char(0),char(187),char(255),char(236),char(1),char(250),char(0),char(188), -char(255),char(236),char(1),char(250),char(0),char(189),char(255),char(236),char(1),char(250), -char(0),char(190),char(255),char(236),char(1),char(250),char(0),char(194),char(255),char(174), -char(1),char(250),char(0),char(195),char(255),char(215),char(1),char(250),char(0),char(196), -char(255),char(174),char(1),char(250),char(0),char(197),char(255),char(215),char(1),char(250), -char(0),char(198),char(255),char(174),char(1),char(250),char(0),char(199),char(255),char(215), -char(1),char(250),char(0),char(200),char(255),char(236),char(1),char(250),char(0),char(201), -char(255),char(215),char(1),char(250),char(0),char(202),char(255),char(236),char(1),char(250), -char(0),char(203),char(255),char(215),char(1),char(250),char(0),char(204),char(255),char(236), -char(1),char(250),char(0),char(205),char(255),char(215),char(1),char(250),char(0),char(206), -char(255),char(236),char(1),char(250),char(0),char(207),char(255),char(215),char(1),char(250), -char(0),char(209),char(255),char(215),char(1),char(250),char(0),char(211),char(255),char(215), -char(1),char(250),char(0),char(213),char(255),char(215),char(1),char(250),char(0),char(215), -char(255),char(215),char(1),char(250),char(0),char(217),char(255),char(215),char(1),char(250), -char(0),char(219),char(255),char(215),char(1),char(250),char(0),char(221),char(255),char(215), -char(1),char(250),char(0),char(222),char(255),char(236),char(1),char(250),char(0),char(223), -char(255),char(236),char(1),char(250),char(0),char(224),char(255),char(236),char(1),char(250), -char(0),char(225),char(255),char(236),char(1),char(250),char(0),char(226),char(255),char(236), -char(1),char(250),char(0),char(227),char(255),char(236),char(1),char(250),char(0),char(228), -char(255),char(236),char(1),char(250),char(0),char(229),char(255),char(236),char(1),char(250), -char(0),char(250),char(255),char(236),char(1),char(250),char(1),char(6),char(255),char(236), -char(1),char(250),char(1),char(8),char(255),char(236),char(1),char(250),char(1),char(13), -char(255),char(236),char(1),char(250),char(1),char(14),char(255),char(236),char(1),char(250), -char(1),char(15),char(255),char(215),char(1),char(250),char(1),char(16),char(255),char(236), -char(1),char(250),char(1),char(17),char(255),char(215),char(1),char(250),char(1),char(18), -char(255),char(236),char(1),char(250),char(1),char(19),char(255),char(215),char(1),char(250), -char(1),char(20),char(255),char(236),char(1),char(250),char(1),char(21),char(255),char(215), -char(1),char(250),char(1),char(23),char(255),char(236),char(1),char(250),char(1),char(25), -char(255),char(236),char(1),char(250),char(1),char(29),char(255),char(236),char(1),char(250), -char(1),char(33),char(255),char(236),char(1),char(250),char(1),char(43),char(255),char(236), -char(1),char(250),char(1),char(45),char(255),char(236),char(1),char(250),char(1),char(47), -char(255),char(236),char(1),char(250),char(1),char(49),char(255),char(236),char(1),char(250), -char(1),char(51),char(255),char(236),char(1),char(250),char(1),char(53),char(255),char(236), -char(1),char(250),char(1),char(67),char(255),char(174),char(1),char(250),char(1),char(68), -char(255),char(215),char(1),char(250),char(1),char(70),char(255),char(215),char(1),char(250), -char(1),char(71),char(255),char(236),char(1),char(250),char(1),char(72),char(255),char(215), -char(1),char(250),char(1),char(74),char(255),char(236),char(1),char(250),char(2),char(8), -char(255),char(154),char(1),char(250),char(2),char(12),char(255),char(154),char(1),char(250), -char(2),char(87),char(255),char(236),char(1),char(250),char(2),char(88),char(255),char(174), -char(1),char(250),char(2),char(89),char(255),char(215),char(1),char(250),char(2),char(95), -char(255),char(236),char(1),char(250),char(2),char(96),char(255),char(215),char(1),char(250), -char(2),char(98),char(255),char(236),char(1),char(250),char(3),char(29),char(255),char(174), -char(1),char(250),char(3),char(30),char(255),char(215),char(1),char(250),char(3),char(31), -char(255),char(174),char(1),char(250),char(3),char(32),char(255),char(215),char(1),char(250), -char(3),char(33),char(255),char(174),char(1),char(250),char(3),char(34),char(255),char(215), -char(1),char(250),char(3),char(35),char(255),char(174),char(1),char(250),char(3),char(37), -char(255),char(174),char(1),char(250),char(3),char(38),char(255),char(215),char(1),char(250), -char(3),char(39),char(255),char(174),char(1),char(250),char(3),char(40),char(255),char(215), -char(1),char(250),char(3),char(41),char(255),char(174),char(1),char(250),char(3),char(42), -char(255),char(215),char(1),char(250),char(3),char(43),char(255),char(174),char(1),char(250), -char(3),char(44),char(255),char(215),char(1),char(250),char(3),char(45),char(255),char(174), -char(1),char(250),char(3),char(46),char(255),char(215),char(1),char(250),char(3),char(47), -char(255),char(174),char(1),char(250),char(3),char(48),char(255),char(215),char(1),char(250), -char(3),char(49),char(255),char(174),char(1),char(250),char(3),char(50),char(255),char(215), -char(1),char(250),char(3),char(51),char(255),char(174),char(1),char(250),char(3),char(52), -char(255),char(215),char(1),char(250),char(3),char(54),char(255),char(215),char(1),char(250), -char(3),char(56),char(255),char(215),char(1),char(250),char(3),char(58),char(255),char(215), -char(1),char(250),char(3),char(60),char(255),char(215),char(1),char(250),char(3),char(64), -char(255),char(215),char(1),char(250),char(3),char(66),char(255),char(215),char(1),char(250), -char(3),char(68),char(255),char(215),char(1),char(250),char(3),char(73),char(255),char(236), -char(1),char(250),char(3),char(74),char(255),char(215),char(1),char(250),char(3),char(75), -char(255),char(236),char(1),char(250),char(3),char(76),char(255),char(215),char(1),char(250), -char(3),char(77),char(255),char(236),char(1),char(250),char(3),char(78),char(255),char(215), -char(1),char(250),char(3),char(79),char(255),char(236),char(1),char(250),char(3),char(81), -char(255),char(236),char(1),char(250),char(3),char(82),char(255),char(215),char(1),char(250), -char(3),char(83),char(255),char(236),char(1),char(250),char(3),char(84),char(255),char(215), -char(1),char(250),char(3),char(85),char(255),char(236),char(1),char(250),char(3),char(86), -char(255),char(215),char(1),char(250),char(3),char(87),char(255),char(236),char(1),char(250), -char(3),char(88),char(255),char(215),char(1),char(250),char(3),char(89),char(255),char(236), -char(1),char(250),char(3),char(90),char(255),char(215),char(1),char(250),char(3),char(91), -char(255),char(236),char(1),char(250),char(3),char(92),char(255),char(215),char(1),char(250), -char(3),char(93),char(255),char(236),char(1),char(250),char(3),char(94),char(255),char(215), -char(1),char(250),char(3),char(95),char(255),char(236),char(1),char(250),char(3),char(96), -char(255),char(215),char(1),char(250),char(3),char(98),char(255),char(236),char(1),char(250), -char(3),char(100),char(255),char(236),char(1),char(250),char(3),char(102),char(255),char(236), -char(1),char(250),char(3),char(104),char(255),char(236),char(1),char(250),char(3),char(106), -char(255),char(236),char(1),char(250),char(3),char(108),char(255),char(236),char(1),char(250), -char(3),char(110),char(255),char(236),char(1),char(251),char(0),char(5),char(0),char(82), -char(1),char(251),char(0),char(10),char(0),char(82),char(1),char(251),char(0),char(15), -char(255),char(174),char(1),char(251),char(0),char(17),char(255),char(174),char(1),char(251), -char(0),char(34),char(0),char(41),char(1),char(251),char(2),char(7),char(0),char(82), -char(1),char(251),char(2),char(8),char(255),char(174),char(1),char(251),char(2),char(11), -char(0),char(82),char(1),char(251),char(2),char(12),char(255),char(174),char(1),char(252), -char(0),char(15),char(255),char(154),char(1),char(252),char(0),char(17),char(255),char(154), -char(1),char(252),char(0),char(34),char(0),char(41),char(1),char(252),char(0),char(36), -char(255),char(174),char(1),char(252),char(0),char(38),char(255),char(236),char(1),char(252), -char(0),char(42),char(255),char(236),char(1),char(252),char(0),char(50),char(255),char(236), -char(1),char(252),char(0),char(52),char(255),char(236),char(1),char(252),char(0),char(68), -char(255),char(215),char(1),char(252),char(0),char(70),char(255),char(215),char(1),char(252), -char(0),char(71),char(255),char(215),char(1),char(252),char(0),char(72),char(255),char(215), -char(1),char(252),char(0),char(74),char(255),char(236),char(1),char(252),char(0),char(80), -char(255),char(236),char(1),char(252),char(0),char(81),char(255),char(236),char(1),char(252), -char(0),char(82),char(255),char(215),char(1),char(252),char(0),char(83),char(255),char(236), -char(1),char(252),char(0),char(84),char(255),char(215),char(1),char(252),char(0),char(85), -char(255),char(236),char(1),char(252),char(0),char(86),char(255),char(236),char(1),char(252), -char(0),char(88),char(255),char(236),char(1),char(252),char(0),char(130),char(255),char(174), -char(1),char(252),char(0),char(131),char(255),char(174),char(1),char(252),char(0),char(132), -char(255),char(174),char(1),char(252),char(0),char(133),char(255),char(174),char(1),char(252), -char(0),char(134),char(255),char(174),char(1),char(252),char(0),char(135),char(255),char(174), -char(1),char(252),char(0),char(137),char(255),char(236),char(1),char(252),char(0),char(148), -char(255),char(236),char(1),char(252),char(0),char(149),char(255),char(236),char(1),char(252), -char(0),char(150),char(255),char(236),char(1),char(252),char(0),char(151),char(255),char(236), -char(1),char(252),char(0),char(152),char(255),char(236),char(1),char(252),char(0),char(154), -char(255),char(236),char(1),char(252),char(0),char(162),char(255),char(215),char(1),char(252), -char(0),char(163),char(255),char(215),char(1),char(252),char(0),char(164),char(255),char(215), -char(1),char(252),char(0),char(165),char(255),char(215),char(1),char(252),char(0),char(166), -char(255),char(215),char(1),char(252),char(0),char(167),char(255),char(215),char(1),char(252), -char(0),char(168),char(255),char(215),char(1),char(252),char(0),char(169),char(255),char(215), -char(1),char(252),char(0),char(170),char(255),char(215),char(1),char(252),char(0),char(171), -char(255),char(215),char(1),char(252),char(0),char(172),char(255),char(215),char(1),char(252), -char(0),char(173),char(255),char(215),char(1),char(252),char(0),char(180),char(255),char(215), -char(1),char(252),char(0),char(181),char(255),char(215),char(1),char(252),char(0),char(182), -char(255),char(215),char(1),char(252),char(0),char(183),char(255),char(215),char(1),char(252), -char(0),char(184),char(255),char(215),char(1),char(252),char(0),char(186),char(255),char(215), -char(1),char(252),char(0),char(187),char(255),char(236),char(1),char(252),char(0),char(188), -char(255),char(236),char(1),char(252),char(0),char(189),char(255),char(236),char(1),char(252), -char(0),char(190),char(255),char(236),char(1),char(252),char(0),char(194),char(255),char(174), -char(1),char(252),char(0),char(195),char(255),char(215),char(1),char(252),char(0),char(196), -char(255),char(174),char(1),char(252),char(0),char(197),char(255),char(215),char(1),char(252), -char(0),char(198),char(255),char(174),char(1),char(252),char(0),char(199),char(255),char(215), -char(1),char(252),char(0),char(200),char(255),char(236),char(1),char(252),char(0),char(201), -char(255),char(215),char(1),char(252),char(0),char(202),char(255),char(236),char(1),char(252), -char(0),char(203),char(255),char(215),char(1),char(252),char(0),char(204),char(255),char(236), -char(1),char(252),char(0),char(205),char(255),char(215),char(1),char(252),char(0),char(206), -char(255),char(236),char(1),char(252),char(0),char(207),char(255),char(215),char(1),char(252), -char(0),char(209),char(255),char(215),char(1),char(252),char(0),char(211),char(255),char(215), -char(1),char(252),char(0),char(213),char(255),char(215),char(1),char(252),char(0),char(215), -char(255),char(215),char(1),char(252),char(0),char(217),char(255),char(215),char(1),char(252), -char(0),char(219),char(255),char(215),char(1),char(252),char(0),char(221),char(255),char(215), -char(1),char(252),char(0),char(222),char(255),char(236),char(1),char(252),char(0),char(223), -char(255),char(236),char(1),char(252),char(0),char(224),char(255),char(236),char(1),char(252), -char(0),char(225),char(255),char(236),char(1),char(252),char(0),char(226),char(255),char(236), -char(1),char(252),char(0),char(227),char(255),char(236),char(1),char(252),char(0),char(228), -char(255),char(236),char(1),char(252),char(0),char(229),char(255),char(236),char(1),char(252), -char(0),char(250),char(255),char(236),char(1),char(252),char(1),char(6),char(255),char(236), -char(1),char(252),char(1),char(8),char(255),char(236),char(1),char(252),char(1),char(13), -char(255),char(236),char(1),char(252),char(1),char(14),char(255),char(236),char(1),char(252), -char(1),char(15),char(255),char(215),char(1),char(252),char(1),char(16),char(255),char(236), -char(1),char(252),char(1),char(17),char(255),char(215),char(1),char(252),char(1),char(18), -char(255),char(236),char(1),char(252),char(1),char(19),char(255),char(215),char(1),char(252), -char(1),char(20),char(255),char(236),char(1),char(252),char(1),char(21),char(255),char(215), -char(1),char(252),char(1),char(23),char(255),char(236),char(1),char(252),char(1),char(25), -char(255),char(236),char(1),char(252),char(1),char(29),char(255),char(236),char(1),char(252), -char(1),char(33),char(255),char(236),char(1),char(252),char(1),char(43),char(255),char(236), -char(1),char(252),char(1),char(45),char(255),char(236),char(1),char(252),char(1),char(47), -char(255),char(236),char(1),char(252),char(1),char(49),char(255),char(236),char(1),char(252), -char(1),char(51),char(255),char(236),char(1),char(252),char(1),char(53),char(255),char(236), -char(1),char(252),char(1),char(67),char(255),char(174),char(1),char(252),char(1),char(68), -char(255),char(215),char(1),char(252),char(1),char(70),char(255),char(215),char(1),char(252), -char(1),char(71),char(255),char(236),char(1),char(252),char(1),char(72),char(255),char(215), -char(1),char(252),char(1),char(74),char(255),char(236),char(1),char(252),char(2),char(8), -char(255),char(154),char(1),char(252),char(2),char(12),char(255),char(154),char(1),char(252), -char(2),char(87),char(255),char(236),char(1),char(252),char(2),char(88),char(255),char(174), -char(1),char(252),char(2),char(89),char(255),char(215),char(1),char(252),char(2),char(95), -char(255),char(236),char(1),char(252),char(2),char(96),char(255),char(215),char(1),char(252), -char(2),char(98),char(255),char(236),char(1),char(252),char(3),char(29),char(255),char(174), -char(1),char(252),char(3),char(30),char(255),char(215),char(1),char(252),char(3),char(31), -char(255),char(174),char(1),char(252),char(3),char(32),char(255),char(215),char(1),char(252), -char(3),char(33),char(255),char(174),char(1),char(252),char(3),char(34),char(255),char(215), -char(1),char(252),char(3),char(35),char(255),char(174),char(1),char(252),char(3),char(37), -char(255),char(174),char(1),char(252),char(3),char(38),char(255),char(215),char(1),char(252), -char(3),char(39),char(255),char(174),char(1),char(252),char(3),char(40),char(255),char(215), -char(1),char(252),char(3),char(41),char(255),char(174),char(1),char(252),char(3),char(42), -char(255),char(215),char(1),char(252),char(3),char(43),char(255),char(174),char(1),char(252), -char(3),char(44),char(255),char(215),char(1),char(252),char(3),char(45),char(255),char(174), -char(1),char(252),char(3),char(46),char(255),char(215),char(1),char(252),char(3),char(47), -char(255),char(174),char(1),char(252),char(3),char(48),char(255),char(215),char(1),char(252), -char(3),char(49),char(255),char(174),char(1),char(252),char(3),char(50),char(255),char(215), -char(1),char(252),char(3),char(51),char(255),char(174),char(1),char(252),char(3),char(52), -char(255),char(215),char(1),char(252),char(3),char(54),char(255),char(215),char(1),char(252), -char(3),char(56),char(255),char(215),char(1),char(252),char(3),char(58),char(255),char(215), -char(1),char(252),char(3),char(60),char(255),char(215),char(1),char(252),char(3),char(64), -char(255),char(215),char(1),char(252),char(3),char(66),char(255),char(215),char(1),char(252), -char(3),char(68),char(255),char(215),char(1),char(252),char(3),char(73),char(255),char(236), -char(1),char(252),char(3),char(74),char(255),char(215),char(1),char(252),char(3),char(75), -char(255),char(236),char(1),char(252),char(3),char(76),char(255),char(215),char(1),char(252), -char(3),char(77),char(255),char(236),char(1),char(252),char(3),char(78),char(255),char(215), -char(1),char(252),char(3),char(79),char(255),char(236),char(1),char(252),char(3),char(81), -char(255),char(236),char(1),char(252),char(3),char(82),char(255),char(215),char(1),char(252), -char(3),char(83),char(255),char(236),char(1),char(252),char(3),char(84),char(255),char(215), -char(1),char(252),char(3),char(85),char(255),char(236),char(1),char(252),char(3),char(86), -char(255),char(215),char(1),char(252),char(3),char(87),char(255),char(236),char(1),char(252), -char(3),char(88),char(255),char(215),char(1),char(252),char(3),char(89),char(255),char(236), -char(1),char(252),char(3),char(90),char(255),char(215),char(1),char(252),char(3),char(91), -char(255),char(236),char(1),char(252),char(3),char(92),char(255),char(215),char(1),char(252), -char(3),char(93),char(255),char(236),char(1),char(252),char(3),char(94),char(255),char(215), -char(1),char(252),char(3),char(95),char(255),char(236),char(1),char(252),char(3),char(96), -char(255),char(215),char(1),char(252),char(3),char(98),char(255),char(236),char(1),char(252), -char(3),char(100),char(255),char(236),char(1),char(252),char(3),char(102),char(255),char(236), -char(1),char(252),char(3),char(104),char(255),char(236),char(1),char(252),char(3),char(106), -char(255),char(236),char(1),char(252),char(3),char(108),char(255),char(236),char(1),char(252), -char(3),char(110),char(255),char(236),char(1),char(253),char(0),char(5),char(0),char(82), -char(1),char(253),char(0),char(10),char(0),char(82),char(1),char(253),char(0),char(15), -char(255),char(174),char(1),char(253),char(0),char(17),char(255),char(174),char(1),char(253), -char(0),char(34),char(0),char(41),char(1),char(253),char(2),char(7),char(0),char(82), -char(1),char(253),char(2),char(8),char(255),char(174),char(1),char(253),char(2),char(11), -char(0),char(82),char(1),char(253),char(2),char(12),char(255),char(174),char(1),char(254), -char(0),char(15),char(255),char(154),char(1),char(254),char(0),char(17),char(255),char(154), -char(1),char(254),char(0),char(34),char(0),char(41),char(1),char(254),char(0),char(36), -char(255),char(174),char(1),char(254),char(0),char(38),char(255),char(236),char(1),char(254), -char(0),char(42),char(255),char(236),char(1),char(254),char(0),char(50),char(255),char(236), -char(1),char(254),char(0),char(52),char(255),char(236),char(1),char(254),char(0),char(68), -char(255),char(215),char(1),char(254),char(0),char(70),char(255),char(215),char(1),char(254), -char(0),char(71),char(255),char(215),char(1),char(254),char(0),char(72),char(255),char(215), -char(1),char(254),char(0),char(74),char(255),char(236),char(1),char(254),char(0),char(80), -char(255),char(236),char(1),char(254),char(0),char(81),char(255),char(236),char(1),char(254), -char(0),char(82),char(255),char(215),char(1),char(254),char(0),char(83),char(255),char(236), -char(1),char(254),char(0),char(84),char(255),char(215),char(1),char(254),char(0),char(85), -char(255),char(236),char(1),char(254),char(0),char(86),char(255),char(236),char(1),char(254), -char(0),char(88),char(255),char(236),char(1),char(254),char(0),char(130),char(255),char(174), -char(1),char(254),char(0),char(131),char(255),char(174),char(1),char(254),char(0),char(132), -char(255),char(174),char(1),char(254),char(0),char(133),char(255),char(174),char(1),char(254), -char(0),char(134),char(255),char(174),char(1),char(254),char(0),char(135),char(255),char(174), -char(1),char(254),char(0),char(137),char(255),char(236),char(1),char(254),char(0),char(148), -char(255),char(236),char(1),char(254),char(0),char(149),char(255),char(236),char(1),char(254), -char(0),char(150),char(255),char(236),char(1),char(254),char(0),char(151),char(255),char(236), -char(1),char(254),char(0),char(152),char(255),char(236),char(1),char(254),char(0),char(154), -char(255),char(236),char(1),char(254),char(0),char(162),char(255),char(215),char(1),char(254), -char(0),char(163),char(255),char(215),char(1),char(254),char(0),char(164),char(255),char(215), -char(1),char(254),char(0),char(165),char(255),char(215),char(1),char(254),char(0),char(166), -char(255),char(215),char(1),char(254),char(0),char(167),char(255),char(215),char(1),char(254), -char(0),char(168),char(255),char(215),char(1),char(254),char(0),char(169),char(255),char(215), -char(1),char(254),char(0),char(170),char(255),char(215),char(1),char(254),char(0),char(171), -char(255),char(215),char(1),char(254),char(0),char(172),char(255),char(215),char(1),char(254), -char(0),char(173),char(255),char(215),char(1),char(254),char(0),char(180),char(255),char(215), -char(1),char(254),char(0),char(181),char(255),char(215),char(1),char(254),char(0),char(182), -char(255),char(215),char(1),char(254),char(0),char(183),char(255),char(215),char(1),char(254), -char(0),char(184),char(255),char(215),char(1),char(254),char(0),char(186),char(255),char(215), -char(1),char(254),char(0),char(187),char(255),char(236),char(1),char(254),char(0),char(188), -char(255),char(236),char(1),char(254),char(0),char(189),char(255),char(236),char(1),char(254), -char(0),char(190),char(255),char(236),char(1),char(254),char(0),char(194),char(255),char(174), -char(1),char(254),char(0),char(195),char(255),char(215),char(1),char(254),char(0),char(196), -char(255),char(174),char(1),char(254),char(0),char(197),char(255),char(215),char(1),char(254), -char(0),char(198),char(255),char(174),char(1),char(254),char(0),char(199),char(255),char(215), -char(1),char(254),char(0),char(200),char(255),char(236),char(1),char(254),char(0),char(201), -char(255),char(215),char(1),char(254),char(0),char(202),char(255),char(236),char(1),char(254), -char(0),char(203),char(255),char(215),char(1),char(254),char(0),char(204),char(255),char(236), -char(1),char(254),char(0),char(205),char(255),char(215),char(1),char(254),char(0),char(206), -char(255),char(236),char(1),char(254),char(0),char(207),char(255),char(215),char(1),char(254), -char(0),char(209),char(255),char(215),char(1),char(254),char(0),char(211),char(255),char(215), -char(1),char(254),char(0),char(213),char(255),char(215),char(1),char(254),char(0),char(215), -char(255),char(215),char(1),char(254),char(0),char(217),char(255),char(215),char(1),char(254), -char(0),char(219),char(255),char(215),char(1),char(254),char(0),char(221),char(255),char(215), -char(1),char(254),char(0),char(222),char(255),char(236),char(1),char(254),char(0),char(223), -char(255),char(236),char(1),char(254),char(0),char(224),char(255),char(236),char(1),char(254), -char(0),char(225),char(255),char(236),char(1),char(254),char(0),char(226),char(255),char(236), -char(1),char(254),char(0),char(227),char(255),char(236),char(1),char(254),char(0),char(228), -char(255),char(236),char(1),char(254),char(0),char(229),char(255),char(236),char(1),char(254), -char(0),char(250),char(255),char(236),char(1),char(254),char(1),char(6),char(255),char(236), -char(1),char(254),char(1),char(8),char(255),char(236),char(1),char(254),char(1),char(13), -char(255),char(236),char(1),char(254),char(1),char(14),char(255),char(236),char(1),char(254), -char(1),char(15),char(255),char(215),char(1),char(254),char(1),char(16),char(255),char(236), -char(1),char(254),char(1),char(17),char(255),char(215),char(1),char(254),char(1),char(18), -char(255),char(236),char(1),char(254),char(1),char(19),char(255),char(215),char(1),char(254), -char(1),char(20),char(255),char(236),char(1),char(254),char(1),char(21),char(255),char(215), -char(1),char(254),char(1),char(23),char(255),char(236),char(1),char(254),char(1),char(25), -char(255),char(236),char(1),char(254),char(1),char(29),char(255),char(236),char(1),char(254), -char(1),char(33),char(255),char(236),char(1),char(254),char(1),char(43),char(255),char(236), -char(1),char(254),char(1),char(45),char(255),char(236),char(1),char(254),char(1),char(47), -char(255),char(236),char(1),char(254),char(1),char(49),char(255),char(236),char(1),char(254), -char(1),char(51),char(255),char(236),char(1),char(254),char(1),char(53),char(255),char(236), -char(1),char(254),char(1),char(67),char(255),char(174),char(1),char(254),char(1),char(68), -char(255),char(215),char(1),char(254),char(1),char(70),char(255),char(215),char(1),char(254), -char(1),char(71),char(255),char(236),char(1),char(254),char(1),char(72),char(255),char(215), -char(1),char(254),char(1),char(74),char(255),char(236),char(1),char(254),char(2),char(8), -char(255),char(154),char(1),char(254),char(2),char(12),char(255),char(154),char(1),char(254), -char(2),char(87),char(255),char(236),char(1),char(254),char(2),char(88),char(255),char(174), -char(1),char(254),char(2),char(89),char(255),char(215),char(1),char(254),char(2),char(95), -char(255),char(236),char(1),char(254),char(2),char(96),char(255),char(215),char(1),char(254), -char(2),char(98),char(255),char(236),char(1),char(254),char(3),char(29),char(255),char(174), -char(1),char(254),char(3),char(30),char(255),char(215),char(1),char(254),char(3),char(31), -char(255),char(174),char(1),char(254),char(3),char(32),char(255),char(215),char(1),char(254), -char(3),char(33),char(255),char(174),char(1),char(254),char(3),char(34),char(255),char(215), -char(1),char(254),char(3),char(35),char(255),char(174),char(1),char(254),char(3),char(37), -char(255),char(174),char(1),char(254),char(3),char(38),char(255),char(215),char(1),char(254), -char(3),char(39),char(255),char(174),char(1),char(254),char(3),char(40),char(255),char(215), -char(1),char(254),char(3),char(41),char(255),char(174),char(1),char(254),char(3),char(42), -char(255),char(215),char(1),char(254),char(3),char(43),char(255),char(174),char(1),char(254), -char(3),char(44),char(255),char(215),char(1),char(254),char(3),char(45),char(255),char(174), -char(1),char(254),char(3),char(46),char(255),char(215),char(1),char(254),char(3),char(47), -char(255),char(174),char(1),char(254),char(3),char(48),char(255),char(215),char(1),char(254), -char(3),char(49),char(255),char(174),char(1),char(254),char(3),char(50),char(255),char(215), -char(1),char(254),char(3),char(51),char(255),char(174),char(1),char(254),char(3),char(52), -char(255),char(215),char(1),char(254),char(3),char(54),char(255),char(215),char(1),char(254), -char(3),char(56),char(255),char(215),char(1),char(254),char(3),char(58),char(255),char(215), -char(1),char(254),char(3),char(60),char(255),char(215),char(1),char(254),char(3),char(64), -char(255),char(215),char(1),char(254),char(3),char(66),char(255),char(215),char(1),char(254), -char(3),char(68),char(255),char(215),char(1),char(254),char(3),char(73),char(255),char(236), -char(1),char(254),char(3),char(74),char(255),char(215),char(1),char(254),char(3),char(75), -char(255),char(236),char(1),char(254),char(3),char(76),char(255),char(215),char(1),char(254), -char(3),char(77),char(255),char(236),char(1),char(254),char(3),char(78),char(255),char(215), -char(1),char(254),char(3),char(79),char(255),char(236),char(1),char(254),char(3),char(81), -char(255),char(236),char(1),char(254),char(3),char(82),char(255),char(215),char(1),char(254), -char(3),char(83),char(255),char(236),char(1),char(254),char(3),char(84),char(255),char(215), -char(1),char(254),char(3),char(85),char(255),char(236),char(1),char(254),char(3),char(86), -char(255),char(215),char(1),char(254),char(3),char(87),char(255),char(236),char(1),char(254), -char(3),char(88),char(255),char(215),char(1),char(254),char(3),char(89),char(255),char(236), -char(1),char(254),char(3),char(90),char(255),char(215),char(1),char(254),char(3),char(91), -char(255),char(236),char(1),char(254),char(3),char(92),char(255),char(215),char(1),char(254), -char(3),char(93),char(255),char(236),char(1),char(254),char(3),char(94),char(255),char(215), -char(1),char(254),char(3),char(95),char(255),char(236),char(1),char(254),char(3),char(96), -char(255),char(215),char(1),char(254),char(3),char(98),char(255),char(236),char(1),char(254), -char(3),char(100),char(255),char(236),char(1),char(254),char(3),char(102),char(255),char(236), -char(1),char(254),char(3),char(104),char(255),char(236),char(1),char(254),char(3),char(106), -char(255),char(236),char(1),char(254),char(3),char(108),char(255),char(236),char(1),char(254), -char(3),char(110),char(255),char(236),char(1),char(255),char(0),char(5),char(0),char(82), -char(1),char(255),char(0),char(10),char(0),char(82),char(1),char(255),char(0),char(15), -char(255),char(174),char(1),char(255),char(0),char(17),char(255),char(174),char(1),char(255), -char(0),char(34),char(0),char(41),char(1),char(255),char(2),char(7),char(0),char(82), -char(1),char(255),char(2),char(8),char(255),char(174),char(1),char(255),char(2),char(11), -char(0),char(82),char(1),char(255),char(2),char(12),char(255),char(174),char(2),char(0), -char(0),char(15),char(255),char(133),char(2),char(0),char(0),char(17),char(255),char(133), -char(2),char(0),char(0),char(34),char(0),char(41),char(2),char(0),char(0),char(36), -char(255),char(133),char(2),char(0),char(0),char(38),char(255),char(215),char(2),char(0), -char(0),char(42),char(255),char(215),char(2),char(0),char(0),char(50),char(255),char(215), -char(2),char(0),char(0),char(52),char(255),char(215),char(2),char(0),char(0),char(68), -char(255),char(154),char(2),char(0),char(0),char(70),char(255),char(154),char(2),char(0), -char(0),char(71),char(255),char(154),char(2),char(0),char(0),char(72),char(255),char(154), -char(2),char(0),char(0),char(74),char(255),char(215),char(2),char(0),char(0),char(80), -char(255),char(195),char(2),char(0),char(0),char(81),char(255),char(195),char(2),char(0), -char(0),char(82),char(255),char(154),char(2),char(0),char(0),char(83),char(255),char(195), -char(2),char(0),char(0),char(84),char(255),char(154),char(2),char(0),char(0),char(85), -char(255),char(195),char(2),char(0),char(0),char(86),char(255),char(174),char(2),char(0), -char(0),char(88),char(255),char(195),char(2),char(0),char(0),char(93),char(255),char(215), -char(2),char(0),char(0),char(130),char(255),char(133),char(2),char(0),char(0),char(131), -char(255),char(133),char(2),char(0),char(0),char(132),char(255),char(133),char(2),char(0), -char(0),char(133),char(255),char(133),char(2),char(0),char(0),char(134),char(255),char(133), -char(2),char(0),char(0),char(135),char(255),char(133),char(2),char(0),char(0),char(137), -char(255),char(215),char(2),char(0),char(0),char(148),char(255),char(215),char(2),char(0), -char(0),char(149),char(255),char(215),char(2),char(0),char(0),char(150),char(255),char(215), -char(2),char(0),char(0),char(151),char(255),char(215),char(2),char(0),char(0),char(152), -char(255),char(215),char(2),char(0),char(0),char(154),char(255),char(215),char(2),char(0), -char(0),char(162),char(255),char(154),char(2),char(0),char(0),char(163),char(255),char(154), -char(2),char(0),char(0),char(164),char(255),char(154),char(2),char(0),char(0),char(165), -char(255),char(154),char(2),char(0),char(0),char(166),char(255),char(154),char(2),char(0), -char(0),char(167),char(255),char(154),char(2),char(0),char(0),char(168),char(255),char(154), -char(2),char(0),char(0),char(169),char(255),char(154),char(2),char(0),char(0),char(170), -char(255),char(154),char(2),char(0),char(0),char(171),char(255),char(154),char(2),char(0), -char(0),char(172),char(255),char(154),char(2),char(0),char(0),char(173),char(255),char(154), -char(2),char(0),char(0),char(180),char(255),char(154),char(2),char(0),char(0),char(181), -char(255),char(154),char(2),char(0),char(0),char(182),char(255),char(154),char(2),char(0), -char(0),char(183),char(255),char(154),char(2),char(0),char(0),char(184),char(255),char(154), -char(2),char(0),char(0),char(186),char(255),char(154),char(2),char(0),char(0),char(187), -char(255),char(195),char(2),char(0),char(0),char(188),char(255),char(195),char(2),char(0), -char(0),char(189),char(255),char(195),char(2),char(0),char(0),char(190),char(255),char(195), -char(2),char(0),char(0),char(194),char(255),char(133),char(2),char(0),char(0),char(195), -char(255),char(154),char(2),char(0),char(0),char(196),char(255),char(133),char(2),char(0), -char(0),char(197),char(255),char(154),char(2),char(0),char(0),char(198),char(255),char(133), -char(2),char(0),char(0),char(199),char(255),char(154),char(2),char(0),char(0),char(200), -char(255),char(215),char(2),char(0),char(0),char(201),char(255),char(154),char(2),char(0), -char(0),char(202),char(255),char(215),char(2),char(0),char(0),char(203),char(255),char(154), -char(2),char(0),char(0),char(204),char(255),char(215),char(2),char(0),char(0),char(205), -char(255),char(154),char(2),char(0),char(0),char(206),char(255),char(215),char(2),char(0), -char(0),char(207),char(255),char(154),char(2),char(0),char(0),char(209),char(255),char(154), -char(2),char(0),char(0),char(211),char(255),char(154),char(2),char(0),char(0),char(213), -char(255),char(154),char(2),char(0),char(0),char(215),char(255),char(154),char(2),char(0), -char(0),char(217),char(255),char(154),char(2),char(0),char(0),char(219),char(255),char(154), -char(2),char(0),char(0),char(221),char(255),char(154),char(2),char(0),char(0),char(222), -char(255),char(215),char(2),char(0),char(0),char(223),char(255),char(215),char(2),char(0), -char(0),char(224),char(255),char(215),char(2),char(0),char(0),char(225),char(255),char(215), -char(2),char(0),char(0),char(226),char(255),char(215),char(2),char(0),char(0),char(227), -char(255),char(215),char(2),char(0),char(0),char(228),char(255),char(215),char(2),char(0), -char(0),char(229),char(255),char(215),char(2),char(0),char(0),char(250),char(255),char(195), -char(2),char(0),char(1),char(6),char(255),char(195),char(2),char(0),char(1),char(8), -char(255),char(195),char(2),char(0),char(1),char(13),char(255),char(195),char(2),char(0), -char(1),char(14),char(255),char(215),char(2),char(0),char(1),char(15),char(255),char(154), -char(2),char(0),char(1),char(16),char(255),char(215),char(2),char(0),char(1),char(17), -char(255),char(154),char(2),char(0),char(1),char(18),char(255),char(215),char(2),char(0), -char(1),char(19),char(255),char(154),char(2),char(0),char(1),char(20),char(255),char(215), -char(2),char(0),char(1),char(21),char(255),char(154),char(2),char(0),char(1),char(23), -char(255),char(195),char(2),char(0),char(1),char(25),char(255),char(195),char(2),char(0), -char(1),char(29),char(255),char(174),char(2),char(0),char(1),char(33),char(255),char(174), -char(2),char(0),char(1),char(43),char(255),char(195),char(2),char(0),char(1),char(45), -char(255),char(195),char(2),char(0),char(1),char(47),char(255),char(195),char(2),char(0), -char(1),char(49),char(255),char(195),char(2),char(0),char(1),char(51),char(255),char(195), -char(2),char(0),char(1),char(53),char(255),char(195),char(2),char(0),char(1),char(60), -char(255),char(215),char(2),char(0),char(1),char(62),char(255),char(215),char(2),char(0), -char(1),char(64),char(255),char(215),char(2),char(0),char(1),char(67),char(255),char(133), -char(2),char(0),char(1),char(68),char(255),char(154),char(2),char(0),char(1),char(70), -char(255),char(154),char(2),char(0),char(1),char(71),char(255),char(215),char(2),char(0), -char(1),char(72),char(255),char(154),char(2),char(0),char(1),char(74),char(255),char(174), -char(2),char(0),char(2),char(8),char(255),char(133),char(2),char(0),char(2),char(12), -char(255),char(133),char(2),char(0),char(2),char(87),char(255),char(195),char(2),char(0), -char(2),char(88),char(255),char(133),char(2),char(0),char(2),char(89),char(255),char(154), -char(2),char(0),char(2),char(95),char(255),char(215),char(2),char(0),char(2),char(96), -char(255),char(154),char(2),char(0),char(2),char(98),char(255),char(195),char(2),char(0), -char(3),char(29),char(255),char(133),char(2),char(0),char(3),char(30),char(255),char(154), -char(2),char(0),char(3),char(31),char(255),char(133),char(2),char(0),char(3),char(32), -char(255),char(154),char(2),char(0),char(3),char(33),char(255),char(133),char(2),char(0), -char(3),char(34),char(255),char(154),char(2),char(0),char(3),char(35),char(255),char(133), -char(2),char(0),char(3),char(37),char(255),char(133),char(2),char(0),char(3),char(38), -char(255),char(154),char(2),char(0),char(3),char(39),char(255),char(133),char(2),char(0), -char(3),char(40),char(255),char(154),char(2),char(0),char(3),char(41),char(255),char(133), -char(2),char(0),char(3),char(42),char(255),char(154),char(2),char(0),char(3),char(43), -char(255),char(133),char(2),char(0),char(3),char(44),char(255),char(154),char(2),char(0), -char(3),char(45),char(255),char(133),char(2),char(0),char(3),char(46),char(255),char(154), -char(2),char(0),char(3),char(47),char(255),char(133),char(2),char(0),char(3),char(48), -char(255),char(154),char(2),char(0),char(3),char(49),char(255),char(133),char(2),char(0), -char(3),char(50),char(255),char(154),char(2),char(0),char(3),char(51),char(255),char(133), -char(2),char(0),char(3),char(52),char(255),char(154),char(2),char(0),char(3),char(54), -char(255),char(154),char(2),char(0),char(3),char(56),char(255),char(154),char(2),char(0), -char(3),char(58),char(255),char(154),char(2),char(0),char(3),char(60),char(255),char(154), -char(2),char(0),char(3),char(64),char(255),char(154),char(2),char(0),char(3),char(66), -char(255),char(154),char(2),char(0),char(3),char(68),char(255),char(154),char(2),char(0), -char(3),char(73),char(255),char(215),char(2),char(0),char(3),char(74),char(255),char(154), -char(2),char(0),char(3),char(75),char(255),char(215),char(2),char(0),char(3),char(76), -char(255),char(154),char(2),char(0),char(3),char(77),char(255),char(215),char(2),char(0), -char(3),char(78),char(255),char(154),char(2),char(0),char(3),char(79),char(255),char(215), -char(2),char(0),char(3),char(81),char(255),char(215),char(2),char(0),char(3),char(82), -char(255),char(154),char(2),char(0),char(3),char(83),char(255),char(215),char(2),char(0), -char(3),char(84),char(255),char(154),char(2),char(0),char(3),char(85),char(255),char(215), -char(2),char(0),char(3),char(86),char(255),char(154),char(2),char(0),char(3),char(87), -char(255),char(215),char(2),char(0),char(3),char(88),char(255),char(154),char(2),char(0), -char(3),char(89),char(255),char(215),char(2),char(0),char(3),char(90),char(255),char(154), -char(2),char(0),char(3),char(91),char(255),char(215),char(2),char(0),char(3),char(92), -char(255),char(154),char(2),char(0),char(3),char(93),char(255),char(215),char(2),char(0), -char(3),char(94),char(255),char(154),char(2),char(0),char(3),char(95),char(255),char(215), -char(2),char(0),char(3),char(96),char(255),char(154),char(2),char(0),char(3),char(98), -char(255),char(195),char(2),char(0),char(3),char(100),char(255),char(195),char(2),char(0), -char(3),char(102),char(255),char(195),char(2),char(0),char(3),char(104),char(255),char(195), -char(2),char(0),char(3),char(106),char(255),char(195),char(2),char(0),char(3),char(108), -char(255),char(195),char(2),char(0),char(3),char(110),char(255),char(195),char(2),char(1), -char(0),char(5),char(0),char(82),char(2),char(1),char(0),char(10),char(0),char(82), -char(2),char(1),char(0),char(15),char(255),char(174),char(2),char(1),char(0),char(17), -char(255),char(174),char(2),char(1),char(0),char(34),char(0),char(41),char(2),char(1), -char(2),char(7),char(0),char(82),char(2),char(1),char(2),char(8),char(255),char(174), -char(2),char(1),char(2),char(11),char(0),char(82),char(2),char(1),char(2),char(12), -char(255),char(174),char(2),char(2),char(0),char(55),char(255),char(174),char(2),char(2), -char(1),char(36),char(255),char(174),char(2),char(2),char(1),char(38),char(255),char(174), -char(2),char(2),char(1),char(113),char(255),char(174),char(2),char(2),char(1),char(157), -char(255),char(174),char(2),char(2),char(1),char(166),char(255),char(174),char(2),char(2), -char(1),char(188),char(255),char(174),char(2),char(2),char(1),char(196),char(255),char(174), -char(2),char(2),char(1),char(220),char(255),char(215),char(2),char(2),char(1),char(228), -char(255),char(215),char(2),char(2),char(2),char(169),char(255),char(174),char(2),char(2), -char(2),char(170),char(255),char(215),char(2),char(2),char(2),char(181),char(255),char(174), -char(2),char(2),char(2),char(182),char(255),char(215),char(2),char(2),char(2),char(189), -char(255),char(174),char(2),char(2),char(2),char(190),char(255),char(215),char(2),char(2), -char(3),char(23),char(255),char(174),char(2),char(2),char(3),char(24),char(255),char(215), -char(2),char(2),char(3),char(143),char(255),char(174),char(2),char(3),char(0),char(55), -char(255),char(174),char(2),char(3),char(1),char(36),char(255),char(174),char(2),char(3), -char(1),char(38),char(255),char(174),char(2),char(3),char(1),char(113),char(255),char(174), -char(2),char(3),char(1),char(157),char(255),char(174),char(2),char(3),char(1),char(166), -char(255),char(174),char(2),char(3),char(1),char(188),char(255),char(174),char(2),char(3), -char(1),char(196),char(255),char(174),char(2),char(3),char(1),char(220),char(255),char(215), -char(2),char(3),char(1),char(228),char(255),char(215),char(2),char(3),char(2),char(169), -char(255),char(174),char(2),char(3),char(2),char(170),char(255),char(215),char(2),char(3), -char(2),char(181),char(255),char(174),char(2),char(3),char(2),char(182),char(255),char(215), -char(2),char(3),char(2),char(189),char(255),char(174),char(2),char(3),char(2),char(190), -char(255),char(215),char(2),char(3),char(3),char(23),char(255),char(174),char(2),char(3), -char(3),char(24),char(255),char(215),char(2),char(3),char(3),char(143),char(255),char(174), -char(2),char(4),char(0),char(55),char(255),char(174),char(2),char(4),char(1),char(36), -char(255),char(174),char(2),char(4),char(1),char(38),char(255),char(174),char(2),char(4), -char(1),char(113),char(255),char(174),char(2),char(4),char(1),char(157),char(255),char(174), -char(2),char(4),char(1),char(166),char(255),char(174),char(2),char(4),char(1),char(188), -char(255),char(174),char(2),char(4),char(1),char(196),char(255),char(174),char(2),char(4), -char(1),char(220),char(255),char(215),char(2),char(4),char(1),char(228),char(255),char(215), -char(2),char(4),char(2),char(169),char(255),char(174),char(2),char(4),char(2),char(170), -char(255),char(215),char(2),char(4),char(2),char(181),char(255),char(174),char(2),char(4), -char(2),char(182),char(255),char(215),char(2),char(4),char(2),char(189),char(255),char(174), -char(2),char(4),char(2),char(190),char(255),char(215),char(2),char(4),char(3),char(23), -char(255),char(174),char(2),char(4),char(3),char(24),char(255),char(215),char(2),char(4), -char(3),char(143),char(255),char(174),char(2),char(6),char(0),char(36),char(255),char(113), -char(2),char(6),char(0),char(55),char(0),char(41),char(2),char(6),char(0),char(57), -char(0),char(41),char(2),char(6),char(0),char(58),char(0),char(41),char(2),char(6), -char(0),char(60),char(0),char(20),char(2),char(6),char(0),char(68),char(255),char(174), -char(2),char(6),char(0),char(70),char(255),char(133),char(2),char(6),char(0),char(71), -char(255),char(133),char(2),char(6),char(0),char(72),char(255),char(133),char(2),char(6), -char(0),char(74),char(255),char(195),char(2),char(6),char(0),char(80),char(255),char(195), -char(2),char(6),char(0),char(81),char(255),char(195),char(2),char(6),char(0),char(82), -char(255),char(133),char(2),char(6),char(0),char(83),char(255),char(195),char(2),char(6), -char(0),char(84),char(255),char(133),char(2),char(6),char(0),char(85),char(255),char(195), -char(2),char(6),char(0),char(86),char(255),char(195),char(2),char(6),char(0),char(88), -char(255),char(195),char(2),char(6),char(0),char(130),char(255),char(113),char(2),char(6), -char(0),char(131),char(255),char(113),char(2),char(6),char(0),char(132),char(255),char(113), -char(2),char(6),char(0),char(133),char(255),char(113),char(2),char(6),char(0),char(134), -char(255),char(113),char(2),char(6),char(0),char(135),char(255),char(113),char(2),char(6), -char(0),char(159),char(0),char(20),char(2),char(6),char(0),char(162),char(255),char(133), -char(2),char(6),char(0),char(163),char(255),char(174),char(2),char(6),char(0),char(164), -char(255),char(174),char(2),char(6),char(0),char(165),char(255),char(174),char(2),char(6), -char(0),char(166),char(255),char(174),char(2),char(6),char(0),char(167),char(255),char(174), -char(2),char(6),char(0),char(168),char(255),char(174),char(2),char(6),char(0),char(169), -char(255),char(133),char(2),char(6),char(0),char(170),char(255),char(133),char(2),char(6), -char(0),char(171),char(255),char(133),char(2),char(6),char(0),char(172),char(255),char(133), -char(2),char(6),char(0),char(173),char(255),char(133),char(2),char(6),char(0),char(180), -char(255),char(133),char(2),char(6),char(0),char(181),char(255),char(133),char(2),char(6), -char(0),char(182),char(255),char(133),char(2),char(6),char(0),char(183),char(255),char(133), -char(2),char(6),char(0),char(184),char(255),char(133),char(2),char(6),char(0),char(186), -char(255),char(133),char(2),char(6),char(0),char(187),char(255),char(195),char(2),char(6), -char(0),char(188),char(255),char(195),char(2),char(6),char(0),char(189),char(255),char(195), -char(2),char(6),char(0),char(190),char(255),char(195),char(2),char(6),char(0),char(194), -char(255),char(113),char(2),char(6),char(0),char(195),char(255),char(174),char(2),char(6), -char(0),char(196),char(255),char(113),char(2),char(6),char(0),char(197),char(255),char(174), -char(2),char(6),char(0),char(198),char(255),char(113),char(2),char(6),char(0),char(199), -char(255),char(174),char(2),char(6),char(0),char(201),char(255),char(133),char(2),char(6), -char(0),char(203),char(255),char(133),char(2),char(6),char(0),char(205),char(255),char(133), -char(2),char(6),char(0),char(207),char(255),char(133),char(2),char(6),char(0),char(209), -char(255),char(133),char(2),char(6),char(0),char(211),char(255),char(133),char(2),char(6), -char(0),char(213),char(255),char(133),char(2),char(6),char(0),char(215),char(255),char(133), -char(2),char(6),char(0),char(217),char(255),char(133),char(2),char(6),char(0),char(219), -char(255),char(133),char(2),char(6),char(0),char(221),char(255),char(133),char(2),char(6), -char(0),char(223),char(255),char(195),char(2),char(6),char(0),char(225),char(255),char(195), -char(2),char(6),char(0),char(227),char(255),char(195),char(2),char(6),char(0),char(229), -char(255),char(195),char(2),char(6),char(0),char(250),char(255),char(195),char(2),char(6), -char(1),char(6),char(255),char(195),char(2),char(6),char(1),char(8),char(255),char(195), -char(2),char(6),char(1),char(13),char(255),char(195),char(2),char(6),char(1),char(15), -char(255),char(133),char(2),char(6),char(1),char(17),char(255),char(133),char(2),char(6), -char(1),char(19),char(255),char(133),char(2),char(6),char(1),char(21),char(255),char(133), -char(2),char(6),char(1),char(23),char(255),char(195),char(2),char(6),char(1),char(25), -char(255),char(195),char(2),char(6),char(1),char(29),char(255),char(195),char(2),char(6), -char(1),char(33),char(255),char(195),char(2),char(6),char(1),char(36),char(0),char(41), -char(2),char(6),char(1),char(38),char(0),char(41),char(2),char(6),char(1),char(43), -char(255),char(195),char(2),char(6),char(1),char(45),char(255),char(195),char(2),char(6), -char(1),char(47),char(255),char(195),char(2),char(6),char(1),char(49),char(255),char(195), -char(2),char(6),char(1),char(51),char(255),char(195),char(2),char(6),char(1),char(53), -char(255),char(195),char(2),char(6),char(1),char(54),char(0),char(41),char(2),char(6), -char(1),char(56),char(0),char(20),char(2),char(6),char(1),char(58),char(0),char(20), -char(2),char(6),char(1),char(67),char(255),char(113),char(2),char(6),char(1),char(68), -char(255),char(174),char(2),char(6),char(1),char(70),char(255),char(174),char(2),char(6), -char(1),char(72),char(255),char(133),char(2),char(6),char(1),char(74),char(255),char(195), -char(2),char(6),char(1),char(86),char(255),char(113),char(2),char(6),char(1),char(95), -char(255),char(113),char(2),char(6),char(1),char(98),char(255),char(113),char(2),char(6), -char(1),char(105),char(255),char(113),char(2),char(6),char(1),char(121),char(255),char(174), -char(2),char(6),char(1),char(122),char(255),char(215),char(2),char(6),char(1),char(123), -char(255),char(215),char(2),char(6),char(1),char(126),char(255),char(174),char(2),char(6), -char(1),char(129),char(255),char(195),char(2),char(6),char(1),char(130),char(255),char(215), -char(2),char(6),char(1),char(131),char(255),char(215),char(2),char(6),char(1),char(132), -char(255),char(215),char(2),char(6),char(1),char(135),char(255),char(215),char(2),char(6), -char(1),char(137),char(255),char(215),char(2),char(6),char(1),char(140),char(255),char(174), -char(2),char(6),char(1),char(142),char(255),char(195),char(2),char(6),char(1),char(143), -char(255),char(174),char(2),char(6),char(1),char(144),char(255),char(174),char(2),char(6), -char(1),char(147),char(255),char(174),char(2),char(6),char(1),char(153),char(255),char(174), -char(2),char(6),char(1),char(164),char(255),char(133),char(2),char(6),char(1),char(170), -char(255),char(113),char(2),char(6),char(1),char(174),char(255),char(133),char(2),char(6), -char(1),char(181),char(255),char(133),char(2),char(6),char(1),char(202),char(255),char(215), -char(2),char(6),char(1),char(206),char(255),char(113),char(2),char(6),char(1),char(207), -char(255),char(133),char(2),char(6),char(1),char(213),char(255),char(113),char(2),char(6), -char(1),char(216),char(255),char(133),char(2),char(6),char(1),char(219),char(255),char(133), -char(2),char(6),char(1),char(222),char(255),char(133),char(2),char(6),char(1),char(234), -char(255),char(133),char(2),char(6),char(1),char(237),char(255),char(133),char(2),char(6), -char(1),char(238),char(255),char(195),char(2),char(6),char(1),char(242),char(255),char(113), -char(2),char(6),char(1),char(250),char(0),char(41),char(2),char(6),char(1),char(252), -char(0),char(41),char(2),char(6),char(1),char(254),char(0),char(41),char(2),char(6), -char(2),char(0),char(0),char(20),char(2),char(6),char(2),char(87),char(255),char(195), -char(2),char(6),char(2),char(88),char(255),char(113),char(2),char(6),char(2),char(89), -char(255),char(174),char(2),char(6),char(2),char(96),char(255),char(133),char(2),char(6), -char(2),char(98),char(255),char(195),char(2),char(6),char(2),char(106),char(255),char(133), -char(2),char(6),char(2),char(114),char(255),char(113),char(2),char(6),char(2),char(115), -char(255),char(113),char(2),char(6),char(2),char(125),char(255),char(236),char(2),char(6), -char(2),char(127),char(255),char(133),char(2),char(6),char(2),char(133),char(255),char(133), -char(2),char(6),char(2),char(135),char(255),char(133),char(2),char(6),char(2),char(137), -char(255),char(133),char(2),char(6),char(2),char(141),char(255),char(133),char(2),char(6), -char(2),char(178),char(255),char(133),char(2),char(6),char(2),char(180),char(255),char(133), -char(2),char(6),char(2),char(206),char(255),char(133),char(2),char(6),char(2),char(207), -char(255),char(113),char(2),char(6),char(2),char(217),char(255),char(113),char(2),char(6), -char(2),char(218),char(255),char(215),char(2),char(6),char(2),char(219),char(255),char(113), -char(2),char(6),char(2),char(220),char(255),char(215),char(2),char(6),char(2),char(221), -char(255),char(113),char(2),char(6),char(2),char(222),char(255),char(215),char(2),char(6), -char(2),char(224),char(255),char(133),char(2),char(6),char(2),char(226),char(255),char(215), -char(2),char(6),char(2),char(228),char(255),char(215),char(2),char(6),char(2),char(240), -char(255),char(133),char(2),char(6),char(2),char(242),char(255),char(133),char(2),char(6), -char(2),char(244),char(255),char(133),char(2),char(6),char(3),char(9),char(255),char(113), -char(2),char(6),char(3),char(10),char(255),char(133),char(2),char(6),char(3),char(11), -char(255),char(113),char(2),char(6),char(3),char(12),char(255),char(133),char(2),char(6), -char(3),char(17),char(255),char(133),char(2),char(6),char(3),char(18),char(255),char(113), -char(2),char(6),char(3),char(22),char(255),char(133),char(2),char(6),char(3),char(26), -char(255),char(133),char(2),char(6),char(3),char(27),char(255),char(133),char(2),char(6), -char(3),char(28),char(255),char(113),char(2),char(6),char(3),char(29),char(255),char(113), -char(2),char(6),char(3),char(30),char(255),char(174),char(2),char(6),char(3),char(31), -char(255),char(113),char(2),char(6),char(3),char(32),char(255),char(174),char(2),char(6), -char(3),char(33),char(255),char(113),char(2),char(6),char(3),char(34),char(255),char(174), -char(2),char(6),char(3),char(35),char(255),char(113),char(2),char(6),char(3),char(37), -char(255),char(113),char(2),char(6),char(3),char(38),char(255),char(174),char(2),char(6), -char(3),char(39),char(255),char(113),char(2),char(6),char(3),char(40),char(255),char(174), -char(2),char(6),char(3),char(41),char(255),char(113),char(2),char(6),char(3),char(42), -char(255),char(174),char(2),char(6),char(3),char(43),char(255),char(113),char(2),char(6), -char(3),char(44),char(255),char(174),char(2),char(6),char(3),char(45),char(255),char(113), -char(2),char(6),char(3),char(46),char(255),char(174),char(2),char(6),char(3),char(47), -char(255),char(113),char(2),char(6),char(3),char(48),char(255),char(174),char(2),char(6), -char(3),char(49),char(255),char(113),char(2),char(6),char(3),char(50),char(255),char(174), -char(2),char(6),char(3),char(51),char(255),char(113),char(2),char(6),char(3),char(52), -char(255),char(174),char(2),char(6),char(3),char(54),char(255),char(133),char(2),char(6), -char(3),char(56),char(255),char(133),char(2),char(6),char(3),char(58),char(255),char(133), -char(2),char(6),char(3),char(60),char(255),char(133),char(2),char(6),char(3),char(64), -char(255),char(133),char(2),char(6),char(3),char(66),char(255),char(133),char(2),char(6), -char(3),char(68),char(255),char(133),char(2),char(6),char(3),char(74),char(255),char(133), -char(2),char(6),char(3),char(76),char(255),char(133),char(2),char(6),char(3),char(78), -char(255),char(133),char(2),char(6),char(3),char(82),char(255),char(133),char(2),char(6), -char(3),char(84),char(255),char(133),char(2),char(6),char(3),char(86),char(255),char(133), -char(2),char(6),char(3),char(88),char(255),char(133),char(2),char(6),char(3),char(90), -char(255),char(133),char(2),char(6),char(3),char(92),char(255),char(133),char(2),char(6), -char(3),char(94),char(255),char(133),char(2),char(6),char(3),char(96),char(255),char(133), -char(2),char(6),char(3),char(98),char(255),char(195),char(2),char(6),char(3),char(100), -char(255),char(195),char(2),char(6),char(3),char(102),char(255),char(195),char(2),char(6), -char(3),char(104),char(255),char(195),char(2),char(6),char(3),char(106),char(255),char(195), -char(2),char(6),char(3),char(108),char(255),char(195),char(2),char(6),char(3),char(110), -char(255),char(195),char(2),char(6),char(3),char(111),char(0),char(20),char(2),char(6), -char(3),char(113),char(0),char(20),char(2),char(6),char(3),char(115),char(0),char(20), -char(2),char(6),char(3),char(143),char(0),char(41),char(2),char(7),char(0),char(36), -char(255),char(113),char(2),char(7),char(0),char(55),char(0),char(41),char(2),char(7), -char(0),char(57),char(0),char(41),char(2),char(7),char(0),char(58),char(0),char(41), -char(2),char(7),char(0),char(60),char(0),char(20),char(2),char(7),char(0),char(68), -char(255),char(174),char(2),char(7),char(0),char(70),char(255),char(133),char(2),char(7), -char(0),char(71),char(255),char(133),char(2),char(7),char(0),char(72),char(255),char(133), -char(2),char(7),char(0),char(74),char(255),char(195),char(2),char(7),char(0),char(80), -char(255),char(195),char(2),char(7),char(0),char(81),char(255),char(195),char(2),char(7), -char(0),char(82),char(255),char(133),char(2),char(7),char(0),char(83),char(255),char(195), -char(2),char(7),char(0),char(84),char(255),char(133),char(2),char(7),char(0),char(85), -char(255),char(195),char(2),char(7),char(0),char(86),char(255),char(195),char(2),char(7), -char(0),char(88),char(255),char(195),char(2),char(7),char(0),char(130),char(255),char(113), -char(2),char(7),char(0),char(131),char(255),char(113),char(2),char(7),char(0),char(132), -char(255),char(113),char(2),char(7),char(0),char(133),char(255),char(113),char(2),char(7), -char(0),char(134),char(255),char(113),char(2),char(7),char(0),char(135),char(255),char(113), -char(2),char(7),char(0),char(159),char(0),char(20),char(2),char(7),char(0),char(162), -char(255),char(133),char(2),char(7),char(0),char(163),char(255),char(174),char(2),char(7), -char(0),char(164),char(255),char(174),char(2),char(7),char(0),char(165),char(255),char(174), -char(2),char(7),char(0),char(166),char(255),char(174),char(2),char(7),char(0),char(167), -char(255),char(174),char(2),char(7),char(0),char(168),char(255),char(174),char(2),char(7), -char(0),char(169),char(255),char(133),char(2),char(7),char(0),char(170),char(255),char(133), -char(2),char(7),char(0),char(171),char(255),char(133),char(2),char(7),char(0),char(172), -char(255),char(133),char(2),char(7),char(0),char(173),char(255),char(133),char(2),char(7), -char(0),char(180),char(255),char(133),char(2),char(7),char(0),char(181),char(255),char(133), -char(2),char(7),char(0),char(182),char(255),char(133),char(2),char(7),char(0),char(183), -char(255),char(133),char(2),char(7),char(0),char(184),char(255),char(133),char(2),char(7), -char(0),char(186),char(255),char(133),char(2),char(7),char(0),char(187),char(255),char(195), -char(2),char(7),char(0),char(188),char(255),char(195),char(2),char(7),char(0),char(189), -char(255),char(195),char(2),char(7),char(0),char(190),char(255),char(195),char(2),char(7), -char(0),char(194),char(255),char(113),char(2),char(7),char(0),char(195),char(255),char(174), -char(2),char(7),char(0),char(196),char(255),char(113),char(2),char(7),char(0),char(197), -char(255),char(174),char(2),char(7),char(0),char(198),char(255),char(113),char(2),char(7), -char(0),char(199),char(255),char(174),char(2),char(7),char(0),char(201),char(255),char(133), -char(2),char(7),char(0),char(203),char(255),char(133),char(2),char(7),char(0),char(205), -char(255),char(133),char(2),char(7),char(0),char(207),char(255),char(133),char(2),char(7), -char(0),char(209),char(255),char(133),char(2),char(7),char(0),char(211),char(255),char(133), -char(2),char(7),char(0),char(213),char(255),char(133),char(2),char(7),char(0),char(215), -char(255),char(133),char(2),char(7),char(0),char(217),char(255),char(133),char(2),char(7), -char(0),char(219),char(255),char(133),char(2),char(7),char(0),char(221),char(255),char(133), -char(2),char(7),char(0),char(223),char(255),char(195),char(2),char(7),char(0),char(225), -char(255),char(195),char(2),char(7),char(0),char(227),char(255),char(195),char(2),char(7), -char(0),char(229),char(255),char(195),char(2),char(7),char(0),char(250),char(255),char(195), -char(2),char(7),char(1),char(6),char(255),char(195),char(2),char(7),char(1),char(8), -char(255),char(195),char(2),char(7),char(1),char(13),char(255),char(195),char(2),char(7), -char(1),char(15),char(255),char(133),char(2),char(7),char(1),char(17),char(255),char(133), -char(2),char(7),char(1),char(19),char(255),char(133),char(2),char(7),char(1),char(21), -char(255),char(133),char(2),char(7),char(1),char(23),char(255),char(195),char(2),char(7), -char(1),char(25),char(255),char(195),char(2),char(7),char(1),char(29),char(255),char(195), -char(2),char(7),char(1),char(33),char(255),char(195),char(2),char(7),char(1),char(36), -char(0),char(41),char(2),char(7),char(1),char(38),char(0),char(41),char(2),char(7), -char(1),char(43),char(255),char(195),char(2),char(7),char(1),char(45),char(255),char(195), -char(2),char(7),char(1),char(47),char(255),char(195),char(2),char(7),char(1),char(49), -char(255),char(195),char(2),char(7),char(1),char(51),char(255),char(195),char(2),char(7), -char(1),char(53),char(255),char(195),char(2),char(7),char(1),char(54),char(0),char(41), -char(2),char(7),char(1),char(56),char(0),char(20),char(2),char(7),char(1),char(58), -char(0),char(20),char(2),char(7),char(1),char(67),char(255),char(113),char(2),char(7), -char(1),char(68),char(255),char(174),char(2),char(7),char(1),char(70),char(255),char(174), -char(2),char(7),char(1),char(72),char(255),char(133),char(2),char(7),char(1),char(74), -char(255),char(195),char(2),char(7),char(1),char(86),char(255),char(113),char(2),char(7), -char(1),char(95),char(255),char(113),char(2),char(7),char(1),char(98),char(255),char(113), -char(2),char(7),char(1),char(105),char(255),char(113),char(2),char(7),char(1),char(121), -char(255),char(174),char(2),char(7),char(1),char(122),char(255),char(215),char(2),char(7), -char(1),char(123),char(255),char(215),char(2),char(7),char(1),char(126),char(255),char(174), -char(2),char(7),char(1),char(129),char(255),char(195),char(2),char(7),char(1),char(130), -char(255),char(215),char(2),char(7),char(1),char(131),char(255),char(215),char(2),char(7), -char(1),char(132),char(255),char(215),char(2),char(7),char(1),char(135),char(255),char(215), -char(2),char(7),char(1),char(137),char(255),char(215),char(2),char(7),char(1),char(140), -char(255),char(174),char(2),char(7),char(1),char(142),char(255),char(195),char(2),char(7), -char(1),char(143),char(255),char(174),char(2),char(7),char(1),char(144),char(255),char(174), -char(2),char(7),char(1),char(147),char(255),char(174),char(2),char(7),char(1),char(153), -char(255),char(174),char(2),char(7),char(1),char(164),char(255),char(133),char(2),char(7), -char(1),char(170),char(255),char(113),char(2),char(7),char(1),char(174),char(255),char(133), -char(2),char(7),char(1),char(181),char(255),char(133),char(2),char(7),char(1),char(202), -char(255),char(215),char(2),char(7),char(1),char(206),char(255),char(113),char(2),char(7), -char(1),char(207),char(255),char(133),char(2),char(7),char(1),char(213),char(255),char(113), -char(2),char(7),char(1),char(216),char(255),char(133),char(2),char(7),char(1),char(219), -char(255),char(133),char(2),char(7),char(1),char(222),char(255),char(133),char(2),char(7), -char(1),char(234),char(255),char(133),char(2),char(7),char(1),char(237),char(255),char(133), -char(2),char(7),char(1),char(238),char(255),char(195),char(2),char(7),char(1),char(242), -char(255),char(113),char(2),char(7),char(1),char(250),char(0),char(41),char(2),char(7), -char(1),char(252),char(0),char(41),char(2),char(7),char(1),char(254),char(0),char(41), -char(2),char(7),char(2),char(0),char(0),char(20),char(2),char(7),char(2),char(87), -char(255),char(195),char(2),char(7),char(2),char(88),char(255),char(113),char(2),char(7), -char(2),char(89),char(255),char(174),char(2),char(7),char(2),char(96),char(255),char(133), -char(2),char(7),char(2),char(98),char(255),char(195),char(2),char(7),char(2),char(106), -char(255),char(133),char(2),char(7),char(2),char(114),char(255),char(113),char(2),char(7), -char(2),char(115),char(255),char(113),char(2),char(7),char(2),char(125),char(255),char(236), -char(2),char(7),char(2),char(127),char(255),char(133),char(2),char(7),char(2),char(133), -char(255),char(133),char(2),char(7),char(2),char(135),char(255),char(133),char(2),char(7), -char(2),char(137),char(255),char(133),char(2),char(7),char(2),char(141),char(255),char(133), -char(2),char(7),char(2),char(178),char(255),char(133),char(2),char(7),char(2),char(180), -char(255),char(133),char(2),char(7),char(2),char(206),char(255),char(133),char(2),char(7), -char(2),char(207),char(255),char(113),char(2),char(7),char(2),char(217),char(255),char(113), -char(2),char(7),char(2),char(218),char(255),char(215),char(2),char(7),char(2),char(219), -char(255),char(113),char(2),char(7),char(2),char(220),char(255),char(215),char(2),char(7), -char(2),char(221),char(255),char(113),char(2),char(7),char(2),char(222),char(255),char(215), -char(2),char(7),char(2),char(224),char(255),char(133),char(2),char(7),char(2),char(226), -char(255),char(215),char(2),char(7),char(2),char(228),char(255),char(215),char(2),char(7), -char(2),char(240),char(255),char(133),char(2),char(7),char(2),char(242),char(255),char(133), -char(2),char(7),char(2),char(244),char(255),char(133),char(2),char(7),char(3),char(9), -char(255),char(113),char(2),char(7),char(3),char(10),char(255),char(133),char(2),char(7), -char(3),char(11),char(255),char(113),char(2),char(7),char(3),char(12),char(255),char(133), -char(2),char(7),char(3),char(17),char(255),char(133),char(2),char(7),char(3),char(18), -char(255),char(113),char(2),char(7),char(3),char(22),char(255),char(133),char(2),char(7), -char(3),char(26),char(255),char(133),char(2),char(7),char(3),char(27),char(255),char(133), -char(2),char(7),char(3),char(28),char(255),char(113),char(2),char(7),char(3),char(29), -char(255),char(113),char(2),char(7),char(3),char(30),char(255),char(174),char(2),char(7), -char(3),char(31),char(255),char(113),char(2),char(7),char(3),char(32),char(255),char(174), -char(2),char(7),char(3),char(33),char(255),char(113),char(2),char(7),char(3),char(34), -char(255),char(174),char(2),char(7),char(3),char(35),char(255),char(113),char(2),char(7), -char(3),char(37),char(255),char(113),char(2),char(7),char(3),char(38),char(255),char(174), -char(2),char(7),char(3),char(39),char(255),char(113),char(2),char(7),char(3),char(40), -char(255),char(174),char(2),char(7),char(3),char(41),char(255),char(113),char(2),char(7), -char(3),char(42),char(255),char(174),char(2),char(7),char(3),char(43),char(255),char(113), -char(2),char(7),char(3),char(44),char(255),char(174),char(2),char(7),char(3),char(45), -char(255),char(113),char(2),char(7),char(3),char(46),char(255),char(174),char(2),char(7), -char(3),char(47),char(255),char(113),char(2),char(7),char(3),char(48),char(255),char(174), -char(2),char(7),char(3),char(49),char(255),char(113),char(2),char(7),char(3),char(50), -char(255),char(174),char(2),char(7),char(3),char(51),char(255),char(113),char(2),char(7), -char(3),char(52),char(255),char(174),char(2),char(7),char(3),char(54),char(255),char(133), -char(2),char(7),char(3),char(56),char(255),char(133),char(2),char(7),char(3),char(58), -char(255),char(133),char(2),char(7),char(3),char(60),char(255),char(133),char(2),char(7), -char(3),char(64),char(255),char(133),char(2),char(7),char(3),char(66),char(255),char(133), -char(2),char(7),char(3),char(68),char(255),char(133),char(2),char(7),char(3),char(74), -char(255),char(133),char(2),char(7),char(3),char(76),char(255),char(133),char(2),char(7), -char(3),char(78),char(255),char(133),char(2),char(7),char(3),char(82),char(255),char(133), -char(2),char(7),char(3),char(84),char(255),char(133),char(2),char(7),char(3),char(86), -char(255),char(133),char(2),char(7),char(3),char(88),char(255),char(133),char(2),char(7), -char(3),char(90),char(255),char(133),char(2),char(7),char(3),char(92),char(255),char(133), -char(2),char(7),char(3),char(94),char(255),char(133),char(2),char(7),char(3),char(96), -char(255),char(133),char(2),char(7),char(3),char(98),char(255),char(195),char(2),char(7), -char(3),char(100),char(255),char(195),char(2),char(7),char(3),char(102),char(255),char(195), -char(2),char(7),char(3),char(104),char(255),char(195),char(2),char(7),char(3),char(106), -char(255),char(195),char(2),char(7),char(3),char(108),char(255),char(195),char(2),char(7), -char(3),char(110),char(255),char(195),char(2),char(7),char(3),char(111),char(0),char(20), -char(2),char(7),char(3),char(113),char(0),char(20),char(2),char(7),char(3),char(115), -char(0),char(20),char(2),char(7),char(3),char(143),char(0),char(41),char(2),char(8), -char(0),char(38),char(255),char(154),char(2),char(8),char(0),char(42),char(255),char(154), -char(2),char(8),char(0),char(50),char(255),char(154),char(2),char(8),char(0),char(52), -char(255),char(154),char(2),char(8),char(0),char(55),char(255),char(113),char(2),char(8), -char(0),char(56),char(255),char(215),char(2),char(8),char(0),char(57),char(255),char(133), -char(2),char(8),char(0),char(58),char(255),char(133),char(2),char(8),char(0),char(60), -char(255),char(133),char(2),char(8),char(0),char(137),char(255),char(154),char(2),char(8), -char(0),char(148),char(255),char(154),char(2),char(8),char(0),char(149),char(255),char(154), -char(2),char(8),char(0),char(150),char(255),char(154),char(2),char(8),char(0),char(151), -char(255),char(154),char(2),char(8),char(0),char(152),char(255),char(154),char(2),char(8), -char(0),char(154),char(255),char(154),char(2),char(8),char(0),char(155),char(255),char(215), -char(2),char(8),char(0),char(156),char(255),char(215),char(2),char(8),char(0),char(157), -char(255),char(215),char(2),char(8),char(0),char(158),char(255),char(215),char(2),char(8), -char(0),char(159),char(255),char(133),char(2),char(8),char(0),char(200),char(255),char(154), -char(2),char(8),char(0),char(202),char(255),char(154),char(2),char(8),char(0),char(204), -char(255),char(154),char(2),char(8),char(0),char(206),char(255),char(154),char(2),char(8), -char(0),char(222),char(255),char(154),char(2),char(8),char(0),char(224),char(255),char(154), -char(2),char(8),char(0),char(226),char(255),char(154),char(2),char(8),char(0),char(228), -char(255),char(154),char(2),char(8),char(1),char(14),char(255),char(154),char(2),char(8), -char(1),char(16),char(255),char(154),char(2),char(8),char(1),char(18),char(255),char(154), -char(2),char(8),char(1),char(20),char(255),char(154),char(2),char(8),char(1),char(36), -char(255),char(113),char(2),char(8),char(1),char(38),char(255),char(113),char(2),char(8), -char(1),char(42),char(255),char(215),char(2),char(8),char(1),char(44),char(255),char(215), -char(2),char(8),char(1),char(46),char(255),char(215),char(2),char(8),char(1),char(48), -char(255),char(215),char(2),char(8),char(1),char(50),char(255),char(215),char(2),char(8), -char(1),char(52),char(255),char(215),char(2),char(8),char(1),char(54),char(255),char(133), -char(2),char(8),char(1),char(56),char(255),char(133),char(2),char(8),char(1),char(58), -char(255),char(133),char(2),char(8),char(1),char(71),char(255),char(154),char(2),char(8), -char(1),char(102),char(255),char(174),char(2),char(8),char(1),char(109),char(255),char(174), -char(2),char(8),char(1),char(113),char(255),char(113),char(2),char(8),char(1),char(114), -char(255),char(133),char(2),char(8),char(1),char(115),char(255),char(154),char(2),char(8), -char(1),char(117),char(255),char(133),char(2),char(8),char(1),char(120),char(255),char(133), -char(2),char(8),char(1),char(133),char(255),char(215),char(2),char(8),char(1),char(157), -char(255),char(113),char(2),char(8),char(1),char(159),char(255),char(154),char(2),char(8), -char(1),char(166),char(255),char(113),char(2),char(8),char(1),char(184),char(255),char(154), -char(2),char(8),char(1),char(187),char(255),char(154),char(2),char(8),char(1),char(188), -char(255),char(113),char(2),char(8),char(1),char(190),char(255),char(174),char(2),char(8), -char(1),char(193),char(255),char(92),char(2),char(8),char(1),char(196),char(255),char(113), -char(2),char(8),char(1),char(220),char(255),char(154),char(2),char(8),char(1),char(225), -char(255),char(133),char(2),char(8),char(1),char(228),char(255),char(154),char(2),char(8), -char(1),char(250),char(255),char(133),char(2),char(8),char(1),char(252),char(255),char(133), -char(2),char(8),char(1),char(254),char(255),char(133),char(2),char(8),char(2),char(0), -char(255),char(133),char(2),char(8),char(2),char(84),char(255),char(133),char(2),char(8), -char(2),char(95),char(255),char(154),char(2),char(8),char(2),char(97),char(255),char(215), -char(2),char(8),char(2),char(108),char(255),char(154),char(2),char(8),char(2),char(124), -char(255),char(92),char(2),char(8),char(2),char(126),char(255),char(154),char(2),char(8), -char(2),char(128),char(255),char(133),char(2),char(8),char(2),char(130),char(255),char(133), -char(2),char(8),char(2),char(132),char(255),char(154),char(2),char(8),char(2),char(134), -char(255),char(154),char(2),char(8),char(2),char(136),char(255),char(154),char(2),char(8), -char(2),char(138),char(255),char(154),char(2),char(8),char(2),char(140),char(255),char(154), -char(2),char(8),char(2),char(169),char(255),char(113),char(2),char(8),char(2),char(170), -char(255),char(154),char(2),char(8),char(2),char(177),char(255),char(154),char(2),char(8), -char(2),char(179),char(255),char(154),char(2),char(8),char(2),char(181),char(255),char(113), -char(2),char(8),char(2),char(182),char(255),char(154),char(2),char(8),char(2),char(183), -char(255),char(133),char(2),char(8),char(2),char(185),char(255),char(133),char(2),char(8), -char(2),char(189),char(255),char(113),char(2),char(8),char(2),char(190),char(255),char(154), -char(2),char(8),char(2),char(191),char(255),char(92),char(2),char(8),char(2),char(192), -char(255),char(133),char(2),char(8),char(2),char(193),char(255),char(92),char(2),char(8), -char(2),char(194),char(255),char(133),char(2),char(8),char(2),char(197),char(255),char(133), -char(2),char(8),char(2),char(199),char(255),char(133),char(2),char(8),char(2),char(212), -char(255),char(92),char(2),char(8),char(2),char(213),char(255),char(133),char(2),char(8), -char(2),char(239),char(255),char(154),char(2),char(8),char(2),char(241),char(255),char(154), -char(2),char(8),char(2),char(243),char(255),char(154),char(2),char(8),char(2),char(253), -char(255),char(92),char(2),char(8),char(2),char(254),char(255),char(133),char(2),char(8), -char(3),char(13),char(255),char(133),char(2),char(8),char(3),char(14),char(255),char(154), -char(2),char(8),char(3),char(15),char(255),char(133),char(2),char(8),char(3),char(16), -char(255),char(154),char(2),char(8),char(3),char(21),char(255),char(154),char(2),char(8), -char(3),char(23),char(255),char(113),char(2),char(8),char(3),char(24),char(255),char(154), -char(2),char(8),char(3),char(73),char(255),char(154),char(2),char(8),char(3),char(75), -char(255),char(154),char(2),char(8),char(3),char(77),char(255),char(154),char(2),char(8), -char(3),char(79),char(255),char(154),char(2),char(8),char(3),char(81),char(255),char(154), -char(2),char(8),char(3),char(83),char(255),char(154),char(2),char(8),char(3),char(85), -char(255),char(154),char(2),char(8),char(3),char(87),char(255),char(154),char(2),char(8), -char(3),char(89),char(255),char(154),char(2),char(8),char(3),char(91),char(255),char(154), -char(2),char(8),char(3),char(93),char(255),char(154),char(2),char(8),char(3),char(95), -char(255),char(154),char(2),char(8),char(3),char(97),char(255),char(215),char(2),char(8), -char(3),char(99),char(255),char(215),char(2),char(8),char(3),char(101),char(255),char(215), -char(2),char(8),char(3),char(103),char(255),char(215),char(2),char(8),char(3),char(105), -char(255),char(215),char(2),char(8),char(3),char(107),char(255),char(215),char(2),char(8), -char(3),char(109),char(255),char(215),char(2),char(8),char(3),char(111),char(255),char(133), -char(2),char(8),char(3),char(113),char(255),char(133),char(2),char(8),char(3),char(115), -char(255),char(133),char(2),char(8),char(3),char(143),char(255),char(113),char(2),char(10), -char(0),char(36),char(255),char(113),char(2),char(10),char(0),char(55),char(0),char(41), -char(2),char(10),char(0),char(57),char(0),char(41),char(2),char(10),char(0),char(58), -char(0),char(41),char(2),char(10),char(0),char(60),char(0),char(20),char(2),char(10), -char(0),char(68),char(255),char(174),char(2),char(10),char(0),char(70),char(255),char(133), -char(2),char(10),char(0),char(71),char(255),char(133),char(2),char(10),char(0),char(72), -char(255),char(133),char(2),char(10),char(0),char(74),char(255),char(195),char(2),char(10), -char(0),char(80),char(255),char(195),char(2),char(10),char(0),char(81),char(255),char(195), -char(2),char(10),char(0),char(82),char(255),char(133),char(2),char(10),char(0),char(83), -char(255),char(195),char(2),char(10),char(0),char(84),char(255),char(133),char(2),char(10), -char(0),char(85),char(255),char(195),char(2),char(10),char(0),char(86),char(255),char(195), -char(2),char(10),char(0),char(88),char(255),char(195),char(2),char(10),char(0),char(130), -char(255),char(113),char(2),char(10),char(0),char(131),char(255),char(113),char(2),char(10), -char(0),char(132),char(255),char(113),char(2),char(10),char(0),char(133),char(255),char(113), -char(2),char(10),char(0),char(134),char(255),char(113),char(2),char(10),char(0),char(135), -char(255),char(113),char(2),char(10),char(0),char(159),char(0),char(20),char(2),char(10), -char(0),char(162),char(255),char(133),char(2),char(10),char(0),char(163),char(255),char(174), -char(2),char(10),char(0),char(164),char(255),char(174),char(2),char(10),char(0),char(165), -char(255),char(174),char(2),char(10),char(0),char(166),char(255),char(174),char(2),char(10), -char(0),char(167),char(255),char(174),char(2),char(10),char(0),char(168),char(255),char(174), -char(2),char(10),char(0),char(169),char(255),char(133),char(2),char(10),char(0),char(170), -char(255),char(133),char(2),char(10),char(0),char(171),char(255),char(133),char(2),char(10), -char(0),char(172),char(255),char(133),char(2),char(10),char(0),char(173),char(255),char(133), -char(2),char(10),char(0),char(180),char(255),char(133),char(2),char(10),char(0),char(181), -char(255),char(133),char(2),char(10),char(0),char(182),char(255),char(133),char(2),char(10), -char(0),char(183),char(255),char(133),char(2),char(10),char(0),char(184),char(255),char(133), -char(2),char(10),char(0),char(186),char(255),char(133),char(2),char(10),char(0),char(187), -char(255),char(195),char(2),char(10),char(0),char(188),char(255),char(195),char(2),char(10), -char(0),char(189),char(255),char(195),char(2),char(10),char(0),char(190),char(255),char(195), -char(2),char(10),char(0),char(194),char(255),char(113),char(2),char(10),char(0),char(195), -char(255),char(174),char(2),char(10),char(0),char(196),char(255),char(113),char(2),char(10), -char(0),char(197),char(255),char(174),char(2),char(10),char(0),char(198),char(255),char(113), -char(2),char(10),char(0),char(199),char(255),char(174),char(2),char(10),char(0),char(201), -char(255),char(133),char(2),char(10),char(0),char(203),char(255),char(133),char(2),char(10), -char(0),char(205),char(255),char(133),char(2),char(10),char(0),char(207),char(255),char(133), -char(2),char(10),char(0),char(209),char(255),char(133),char(2),char(10),char(0),char(211), -char(255),char(133),char(2),char(10),char(0),char(213),char(255),char(133),char(2),char(10), -char(0),char(215),char(255),char(133),char(2),char(10),char(0),char(217),char(255),char(133), -char(2),char(10),char(0),char(219),char(255),char(133),char(2),char(10),char(0),char(221), -char(255),char(133),char(2),char(10),char(0),char(223),char(255),char(195),char(2),char(10), -char(0),char(225),char(255),char(195),char(2),char(10),char(0),char(227),char(255),char(195), -char(2),char(10),char(0),char(229),char(255),char(195),char(2),char(10),char(0),char(250), -char(255),char(195),char(2),char(10),char(1),char(6),char(255),char(195),char(2),char(10), -char(1),char(8),char(255),char(195),char(2),char(10),char(1),char(13),char(255),char(195), -char(2),char(10),char(1),char(15),char(255),char(133),char(2),char(10),char(1),char(17), -char(255),char(133),char(2),char(10),char(1),char(19),char(255),char(133),char(2),char(10), -char(1),char(21),char(255),char(133),char(2),char(10),char(1),char(23),char(255),char(195), -char(2),char(10),char(1),char(25),char(255),char(195),char(2),char(10),char(1),char(29), -char(255),char(195),char(2),char(10),char(1),char(33),char(255),char(195),char(2),char(10), -char(1),char(36),char(0),char(41),char(2),char(10),char(1),char(38),char(0),char(41), -char(2),char(10),char(1),char(43),char(255),char(195),char(2),char(10),char(1),char(45), -char(255),char(195),char(2),char(10),char(1),char(47),char(255),char(195),char(2),char(10), -char(1),char(49),char(255),char(195),char(2),char(10),char(1),char(51),char(255),char(195), -char(2),char(10),char(1),char(53),char(255),char(195),char(2),char(10),char(1),char(54), -char(0),char(41),char(2),char(10),char(1),char(56),char(0),char(20),char(2),char(10), -char(1),char(58),char(0),char(20),char(2),char(10),char(1),char(67),char(255),char(113), -char(2),char(10),char(1),char(68),char(255),char(174),char(2),char(10),char(1),char(70), -char(255),char(174),char(2),char(10),char(1),char(72),char(255),char(133),char(2),char(10), -char(1),char(74),char(255),char(195),char(2),char(10),char(1),char(86),char(255),char(113), -char(2),char(10),char(1),char(95),char(255),char(113),char(2),char(10),char(1),char(98), -char(255),char(113),char(2),char(10),char(1),char(105),char(255),char(113),char(2),char(10), -char(1),char(121),char(255),char(174),char(2),char(10),char(1),char(122),char(255),char(215), -char(2),char(10),char(1),char(123),char(255),char(215),char(2),char(10),char(1),char(126), -char(255),char(174),char(2),char(10),char(1),char(129),char(255),char(195),char(2),char(10), -char(1),char(130),char(255),char(215),char(2),char(10),char(1),char(131),char(255),char(215), -char(2),char(10),char(1),char(132),char(255),char(215),char(2),char(10),char(1),char(135), -char(255),char(215),char(2),char(10),char(1),char(137),char(255),char(215),char(2),char(10), -char(1),char(140),char(255),char(174),char(2),char(10),char(1),char(142),char(255),char(195), -char(2),char(10),char(1),char(143),char(255),char(174),char(2),char(10),char(1),char(144), -char(255),char(174),char(2),char(10),char(1),char(147),char(255),char(174),char(2),char(10), -char(1),char(153),char(255),char(174),char(2),char(10),char(1),char(164),char(255),char(133), -char(2),char(10),char(1),char(170),char(255),char(113),char(2),char(10),char(1),char(174), -char(255),char(133),char(2),char(10),char(1),char(181),char(255),char(133),char(2),char(10), -char(1),char(202),char(255),char(215),char(2),char(10),char(1),char(206),char(255),char(113), -char(2),char(10),char(1),char(207),char(255),char(133),char(2),char(10),char(1),char(213), -char(255),char(113),char(2),char(10),char(1),char(216),char(255),char(133),char(2),char(10), -char(1),char(219),char(255),char(133),char(2),char(10),char(1),char(222),char(255),char(133), -char(2),char(10),char(1),char(234),char(255),char(133),char(2),char(10),char(1),char(237), -char(255),char(133),char(2),char(10),char(1),char(238),char(255),char(195),char(2),char(10), -char(1),char(242),char(255),char(113),char(2),char(10),char(1),char(250),char(0),char(41), -char(2),char(10),char(1),char(252),char(0),char(41),char(2),char(10),char(1),char(254), -char(0),char(41),char(2),char(10),char(2),char(0),char(0),char(20),char(2),char(10), -char(2),char(87),char(255),char(195),char(2),char(10),char(2),char(88),char(255),char(113), -char(2),char(10),char(2),char(89),char(255),char(174),char(2),char(10),char(2),char(96), -char(255),char(133),char(2),char(10),char(2),char(98),char(255),char(195),char(2),char(10), -char(2),char(106),char(255),char(133),char(2),char(10),char(2),char(114),char(255),char(113), -char(2),char(10),char(2),char(115),char(255),char(113),char(2),char(10),char(2),char(125), -char(255),char(236),char(2),char(10),char(2),char(127),char(255),char(133),char(2),char(10), -char(2),char(133),char(255),char(133),char(2),char(10),char(2),char(135),char(255),char(133), -char(2),char(10),char(2),char(137),char(255),char(133),char(2),char(10),char(2),char(141), -char(255),char(133),char(2),char(10),char(2),char(178),char(255),char(133),char(2),char(10), -char(2),char(180),char(255),char(133),char(2),char(10),char(2),char(206),char(255),char(133), -char(2),char(10),char(2),char(207),char(255),char(113),char(2),char(10),char(2),char(217), -char(255),char(113),char(2),char(10),char(2),char(218),char(255),char(215),char(2),char(10), -char(2),char(219),char(255),char(113),char(2),char(10),char(2),char(220),char(255),char(215), -char(2),char(10),char(2),char(221),char(255),char(113),char(2),char(10),char(2),char(222), -char(255),char(215),char(2),char(10),char(2),char(224),char(255),char(133),char(2),char(10), -char(2),char(226),char(255),char(215),char(2),char(10),char(2),char(228),char(255),char(215), -char(2),char(10),char(2),char(240),char(255),char(133),char(2),char(10),char(2),char(242), -char(255),char(133),char(2),char(10),char(2),char(244),char(255),char(133),char(2),char(10), -char(3),char(9),char(255),char(113),char(2),char(10),char(3),char(10),char(255),char(133), -char(2),char(10),char(3),char(11),char(255),char(113),char(2),char(10),char(3),char(12), -char(255),char(133),char(2),char(10),char(3),char(17),char(255),char(133),char(2),char(10), -char(3),char(18),char(255),char(113),char(2),char(10),char(3),char(22),char(255),char(133), -char(2),char(10),char(3),char(26),char(255),char(133),char(2),char(10),char(3),char(27), -char(255),char(133),char(2),char(10),char(3),char(28),char(255),char(113),char(2),char(10), -char(3),char(29),char(255),char(113),char(2),char(10),char(3),char(30),char(255),char(174), -char(2),char(10),char(3),char(31),char(255),char(113),char(2),char(10),char(3),char(32), -char(255),char(174),char(2),char(10),char(3),char(33),char(255),char(113),char(2),char(10), -char(3),char(34),char(255),char(174),char(2),char(10),char(3),char(35),char(255),char(113), -char(2),char(10),char(3),char(37),char(255),char(113),char(2),char(10),char(3),char(38), -char(255),char(174),char(2),char(10),char(3),char(39),char(255),char(113),char(2),char(10), -char(3),char(40),char(255),char(174),char(2),char(10),char(3),char(41),char(255),char(113), -char(2),char(10),char(3),char(42),char(255),char(174),char(2),char(10),char(3),char(43), -char(255),char(113),char(2),char(10),char(3),char(44),char(255),char(174),char(2),char(10), -char(3),char(45),char(255),char(113),char(2),char(10),char(3),char(46),char(255),char(174), -char(2),char(10),char(3),char(47),char(255),char(113),char(2),char(10),char(3),char(48), -char(255),char(174),char(2),char(10),char(3),char(49),char(255),char(113),char(2),char(10), -char(3),char(50),char(255),char(174),char(2),char(10),char(3),char(51),char(255),char(113), -char(2),char(10),char(3),char(52),char(255),char(174),char(2),char(10),char(3),char(54), -char(255),char(133),char(2),char(10),char(3),char(56),char(255),char(133),char(2),char(10), -char(3),char(58),char(255),char(133),char(2),char(10),char(3),char(60),char(255),char(133), -char(2),char(10),char(3),char(64),char(255),char(133),char(2),char(10),char(3),char(66), -char(255),char(133),char(2),char(10),char(3),char(68),char(255),char(133),char(2),char(10), -char(3),char(74),char(255),char(133),char(2),char(10),char(3),char(76),char(255),char(133), -char(2),char(10),char(3),char(78),char(255),char(133),char(2),char(10),char(3),char(82), -char(255),char(133),char(2),char(10),char(3),char(84),char(255),char(133),char(2),char(10), -char(3),char(86),char(255),char(133),char(2),char(10),char(3),char(88),char(255),char(133), -char(2),char(10),char(3),char(90),char(255),char(133),char(2),char(10),char(3),char(92), -char(255),char(133),char(2),char(10),char(3),char(94),char(255),char(133),char(2),char(10), -char(3),char(96),char(255),char(133),char(2),char(10),char(3),char(98),char(255),char(195), -char(2),char(10),char(3),char(100),char(255),char(195),char(2),char(10),char(3),char(102), -char(255),char(195),char(2),char(10),char(3),char(104),char(255),char(195),char(2),char(10), -char(3),char(106),char(255),char(195),char(2),char(10),char(3),char(108),char(255),char(195), -char(2),char(10),char(3),char(110),char(255),char(195),char(2),char(10),char(3),char(111), -char(0),char(20),char(2),char(10),char(3),char(113),char(0),char(20),char(2),char(10), -char(3),char(115),char(0),char(20),char(2),char(10),char(3),char(143),char(0),char(41), -char(2),char(12),char(0),char(38),char(255),char(154),char(2),char(12),char(0),char(42), -char(255),char(154),char(2),char(12),char(0),char(50),char(255),char(154),char(2),char(12), -char(0),char(52),char(255),char(154),char(2),char(12),char(0),char(55),char(255),char(113), -char(2),char(12),char(0),char(56),char(255),char(215),char(2),char(12),char(0),char(57), -char(255),char(133),char(2),char(12),char(0),char(58),char(255),char(133),char(2),char(12), -char(0),char(60),char(255),char(133),char(2),char(12),char(0),char(137),char(255),char(154), -char(2),char(12),char(0),char(148),char(255),char(154),char(2),char(12),char(0),char(149), -char(255),char(154),char(2),char(12),char(0),char(150),char(255),char(154),char(2),char(12), -char(0),char(151),char(255),char(154),char(2),char(12),char(0),char(152),char(255),char(154), -char(2),char(12),char(0),char(154),char(255),char(154),char(2),char(12),char(0),char(155), -char(255),char(215),char(2),char(12),char(0),char(156),char(255),char(215),char(2),char(12), -char(0),char(157),char(255),char(215),char(2),char(12),char(0),char(158),char(255),char(215), -char(2),char(12),char(0),char(159),char(255),char(133),char(2),char(12),char(0),char(200), -char(255),char(154),char(2),char(12),char(0),char(202),char(255),char(154),char(2),char(12), -char(0),char(204),char(255),char(154),char(2),char(12),char(0),char(206),char(255),char(154), -char(2),char(12),char(0),char(222),char(255),char(154),char(2),char(12),char(0),char(224), -char(255),char(154),char(2),char(12),char(0),char(226),char(255),char(154),char(2),char(12), -char(0),char(228),char(255),char(154),char(2),char(12),char(1),char(14),char(255),char(154), -char(2),char(12),char(1),char(16),char(255),char(154),char(2),char(12),char(1),char(18), -char(255),char(154),char(2),char(12),char(1),char(20),char(255),char(154),char(2),char(12), -char(1),char(36),char(255),char(113),char(2),char(12),char(1),char(38),char(255),char(113), -char(2),char(12),char(1),char(42),char(255),char(215),char(2),char(12),char(1),char(44), -char(255),char(215),char(2),char(12),char(1),char(46),char(255),char(215),char(2),char(12), -char(1),char(48),char(255),char(215),char(2),char(12),char(1),char(50),char(255),char(215), -char(2),char(12),char(1),char(52),char(255),char(215),char(2),char(12),char(1),char(54), -char(255),char(133),char(2),char(12),char(1),char(56),char(255),char(133),char(2),char(12), -char(1),char(58),char(255),char(133),char(2),char(12),char(1),char(71),char(255),char(154), -char(2),char(12),char(1),char(102),char(255),char(174),char(2),char(12),char(1),char(109), -char(255),char(174),char(2),char(12),char(1),char(113),char(255),char(113),char(2),char(12), -char(1),char(114),char(255),char(133),char(2),char(12),char(1),char(115),char(255),char(154), -char(2),char(12),char(1),char(117),char(255),char(133),char(2),char(12),char(1),char(120), -char(255),char(133),char(2),char(12),char(1),char(133),char(255),char(215),char(2),char(12), -char(1),char(157),char(255),char(113),char(2),char(12),char(1),char(159),char(255),char(154), -char(2),char(12),char(1),char(166),char(255),char(113),char(2),char(12),char(1),char(184), -char(255),char(154),char(2),char(12),char(1),char(187),char(255),char(154),char(2),char(12), -char(1),char(188),char(255),char(113),char(2),char(12),char(1),char(190),char(255),char(174), -char(2),char(12),char(1),char(193),char(255),char(92),char(2),char(12),char(1),char(196), -char(255),char(113),char(2),char(12),char(1),char(220),char(255),char(154),char(2),char(12), -char(1),char(225),char(255),char(133),char(2),char(12),char(1),char(228),char(255),char(154), -char(2),char(12),char(1),char(250),char(255),char(133),char(2),char(12),char(1),char(252), -char(255),char(133),char(2),char(12),char(1),char(254),char(255),char(133),char(2),char(12), -char(2),char(0),char(255),char(133),char(2),char(12),char(2),char(84),char(255),char(133), -char(2),char(12),char(2),char(95),char(255),char(154),char(2),char(12),char(2),char(97), -char(255),char(215),char(2),char(12),char(2),char(108),char(255),char(154),char(2),char(12), -char(2),char(124),char(255),char(92),char(2),char(12),char(2),char(126),char(255),char(154), -char(2),char(12),char(2),char(128),char(255),char(133),char(2),char(12),char(2),char(130), -char(255),char(133),char(2),char(12),char(2),char(132),char(255),char(154),char(2),char(12), -char(2),char(134),char(255),char(154),char(2),char(12),char(2),char(136),char(255),char(154), -char(2),char(12),char(2),char(138),char(255),char(154),char(2),char(12),char(2),char(140), -char(255),char(154),char(2),char(12),char(2),char(169),char(255),char(113),char(2),char(12), -char(2),char(170),char(255),char(154),char(2),char(12),char(2),char(177),char(255),char(154), -char(2),char(12),char(2),char(179),char(255),char(154),char(2),char(12),char(2),char(181), -char(255),char(113),char(2),char(12),char(2),char(182),char(255),char(154),char(2),char(12), -char(2),char(183),char(255),char(133),char(2),char(12),char(2),char(185),char(255),char(133), -char(2),char(12),char(2),char(189),char(255),char(113),char(2),char(12),char(2),char(190), -char(255),char(154),char(2),char(12),char(2),char(191),char(255),char(92),char(2),char(12), -char(2),char(192),char(255),char(133),char(2),char(12),char(2),char(193),char(255),char(92), -char(2),char(12),char(2),char(194),char(255),char(133),char(2),char(12),char(2),char(197), -char(255),char(133),char(2),char(12),char(2),char(199),char(255),char(133),char(2),char(12), -char(2),char(212),char(255),char(92),char(2),char(12),char(2),char(213),char(255),char(133), -char(2),char(12),char(2),char(239),char(255),char(154),char(2),char(12),char(2),char(241), -char(255),char(154),char(2),char(12),char(2),char(243),char(255),char(154),char(2),char(12), -char(2),char(253),char(255),char(92),char(2),char(12),char(2),char(254),char(255),char(133), -char(2),char(12),char(3),char(13),char(255),char(133),char(2),char(12),char(3),char(14), -char(255),char(154),char(2),char(12),char(3),char(15),char(255),char(133),char(2),char(12), -char(3),char(16),char(255),char(154),char(2),char(12),char(3),char(21),char(255),char(154), -char(2),char(12),char(3),char(23),char(255),char(113),char(2),char(12),char(3),char(24), -char(255),char(154),char(2),char(12),char(3),char(73),char(255),char(154),char(2),char(12), -char(3),char(75),char(255),char(154),char(2),char(12),char(3),char(77),char(255),char(154), -char(2),char(12),char(3),char(79),char(255),char(154),char(2),char(12),char(3),char(81), -char(255),char(154),char(2),char(12),char(3),char(83),char(255),char(154),char(2),char(12), -char(3),char(85),char(255),char(154),char(2),char(12),char(3),char(87),char(255),char(154), -char(2),char(12),char(3),char(89),char(255),char(154),char(2),char(12),char(3),char(91), -char(255),char(154),char(2),char(12),char(3),char(93),char(255),char(154),char(2),char(12), -char(3),char(95),char(255),char(154),char(2),char(12),char(3),char(97),char(255),char(215), -char(2),char(12),char(3),char(99),char(255),char(215),char(2),char(12),char(3),char(101), -char(255),char(215),char(2),char(12),char(3),char(103),char(255),char(215),char(2),char(12), -char(3),char(105),char(255),char(215),char(2),char(12),char(3),char(107),char(255),char(215), -char(2),char(12),char(3),char(109),char(255),char(215),char(2),char(12),char(3),char(111), -char(255),char(133),char(2),char(12),char(3),char(113),char(255),char(133),char(2),char(12), -char(3),char(115),char(255),char(133),char(2),char(12),char(3),char(143),char(255),char(113), -char(2),char(33),char(1),char(113),char(255),char(215),char(2),char(33),char(1),char(114), -char(255),char(236),char(2),char(33),char(1),char(120),char(255),char(236),char(2),char(33), -char(2),char(84),char(255),char(236),char(2),char(83),char(0),char(15),char(255),char(195), -char(2),char(83),char(0),char(17),char(255),char(195),char(2),char(83),char(2),char(8), -char(255),char(195),char(2),char(83),char(2),char(12),char(255),char(195),char(2),char(84), -char(0),char(15),char(255),char(133),char(2),char(84),char(0),char(17),char(255),char(133), -char(2),char(84),char(1),char(86),char(255),char(133),char(2),char(84),char(1),char(95), -char(255),char(133),char(2),char(84),char(1),char(98),char(255),char(133),char(2),char(84), -char(1),char(102),char(255),char(215),char(2),char(84),char(1),char(105),char(255),char(133), -char(2),char(84),char(1),char(109),char(255),char(215),char(2),char(84),char(1),char(115), -char(255),char(195),char(2),char(84),char(1),char(118),char(255),char(236),char(2),char(84), -char(1),char(121),char(255),char(154),char(2),char(84),char(1),char(122),char(255),char(174), -char(2),char(84),char(1),char(123),char(255),char(195),char(2),char(84),char(1),char(124), -char(255),char(195),char(2),char(84),char(1),char(125),char(255),char(195),char(2),char(84), -char(1),char(126),char(255),char(154),char(2),char(84),char(1),char(129),char(255),char(195), -char(2),char(84),char(1),char(130),char(255),char(174),char(2),char(84),char(1),char(132), -char(255),char(195),char(2),char(84),char(1),char(134),char(255),char(195),char(2),char(84), -char(1),char(135),char(255),char(195),char(2),char(84),char(1),char(137),char(255),char(195), -char(2),char(84),char(1),char(140),char(255),char(154),char(2),char(84),char(1),char(142), -char(255),char(154),char(2),char(84),char(1),char(143),char(255),char(154),char(2),char(84), -char(1),char(144),char(255),char(154),char(2),char(84),char(1),char(146),char(255),char(195), -char(2),char(84),char(1),char(147),char(255),char(154),char(2),char(84),char(1),char(149), -char(255),char(195),char(2),char(84),char(1),char(150),char(255),char(195),char(2),char(84), -char(1),char(152),char(255),char(195),char(2),char(84),char(1),char(153),char(255),char(154), -char(2),char(84),char(1),char(154),char(255),char(195),char(2),char(84),char(1),char(155), -char(255),char(195),char(2),char(84),char(2),char(8),char(255),char(133),char(2),char(84), -char(2),char(12),char(255),char(133),char(2),char(84),char(2),char(33),char(255),char(236), -char(2),char(88),char(0),char(5),char(255),char(113),char(2),char(88),char(0),char(10), -char(255),char(113),char(2),char(88),char(0),char(38),char(255),char(215),char(2),char(88), -char(0),char(42),char(255),char(215),char(2),char(88),char(0),char(45),char(1),char(10), -char(2),char(88),char(0),char(50),char(255),char(215),char(2),char(88),char(0),char(52), -char(255),char(215),char(2),char(88),char(0),char(55),char(255),char(113),char(2),char(88), -char(0),char(57),char(255),char(174),char(2),char(88),char(0),char(58),char(255),char(174), -char(2),char(88),char(0),char(60),char(255),char(133),char(2),char(88),char(0),char(137), -char(255),char(215),char(2),char(88),char(0),char(148),char(255),char(215),char(2),char(88), -char(0),char(149),char(255),char(215),char(2),char(88),char(0),char(150),char(255),char(215), -char(2),char(88),char(0),char(151),char(255),char(215),char(2),char(88),char(0),char(152), -char(255),char(215),char(2),char(88),char(0),char(154),char(255),char(215),char(2),char(88), -char(0),char(159),char(255),char(133),char(2),char(88),char(0),char(200),char(255),char(215), -char(2),char(88),char(0),char(202),char(255),char(215),char(2),char(88),char(0),char(204), -char(255),char(215),char(2),char(88),char(0),char(206),char(255),char(215),char(2),char(88), -char(0),char(222),char(255),char(215),char(2),char(88),char(0),char(224),char(255),char(215), -char(2),char(88),char(0),char(226),char(255),char(215),char(2),char(88),char(0),char(228), -char(255),char(215),char(2),char(88),char(1),char(14),char(255),char(215),char(2),char(88), -char(1),char(16),char(255),char(215),char(2),char(88),char(1),char(18),char(255),char(215), -char(2),char(88),char(1),char(20),char(255),char(215),char(2),char(88),char(1),char(36), -char(255),char(113),char(2),char(88),char(1),char(38),char(255),char(113),char(2),char(88), -char(1),char(54),char(255),char(174),char(2),char(88),char(1),char(56),char(255),char(133), -char(2),char(88),char(1),char(58),char(255),char(133),char(2),char(88),char(1),char(71), -char(255),char(215),char(2),char(88),char(1),char(250),char(255),char(174),char(2),char(88), -char(1),char(252),char(255),char(174),char(2),char(88),char(1),char(254),char(255),char(174), -char(2),char(88),char(2),char(0),char(255),char(133),char(2),char(88),char(2),char(7), -char(255),char(113),char(2),char(88),char(2),char(11),char(255),char(113),char(2),char(88), -char(2),char(95),char(255),char(215),char(2),char(88),char(3),char(73),char(255),char(215), -char(2),char(88),char(3),char(75),char(255),char(215),char(2),char(88),char(3),char(77), -char(255),char(215),char(2),char(88),char(3),char(79),char(255),char(215),char(2),char(88), -char(3),char(81),char(255),char(215),char(2),char(88),char(3),char(83),char(255),char(215), -char(2),char(88),char(3),char(85),char(255),char(215),char(2),char(88),char(3),char(87), -char(255),char(215),char(2),char(88),char(3),char(89),char(255),char(215),char(2),char(88), -char(3),char(91),char(255),char(215),char(2),char(88),char(3),char(93),char(255),char(215), -char(2),char(88),char(3),char(95),char(255),char(215),char(2),char(88),char(3),char(111), -char(255),char(133),char(2),char(88),char(3),char(113),char(255),char(133),char(2),char(88), -char(3),char(115),char(255),char(133),char(2),char(88),char(3),char(143),char(255),char(113), -char(2),char(89),char(0),char(5),char(255),char(236),char(2),char(89),char(0),char(10), -char(255),char(236),char(2),char(89),char(2),char(7),char(255),char(236),char(2),char(89), -char(2),char(11),char(255),char(236),char(2),char(90),char(0),char(15),char(255),char(174), -char(2),char(90),char(0),char(17),char(255),char(174),char(2),char(90),char(1),char(86), -char(255),char(215),char(2),char(90),char(1),char(95),char(255),char(215),char(2),char(90), -char(1),char(98),char(255),char(215),char(2),char(90),char(1),char(100),char(255),char(236), -char(2),char(90),char(1),char(105),char(255),char(215),char(2),char(90),char(1),char(112), -char(255),char(236),char(2),char(90),char(1),char(113),char(255),char(195),char(2),char(90), -char(1),char(114),char(255),char(236),char(2),char(90),char(1),char(116),char(255),char(215), -char(2),char(90),char(1),char(117),char(255),char(236),char(2),char(90),char(1),char(120), -char(255),char(236),char(2),char(90),char(1),char(136),char(255),char(236),char(2),char(90), -char(2),char(8),char(255),char(174),char(2),char(90),char(2),char(12),char(255),char(174), -char(2),char(90),char(2),char(84),char(255),char(236),char(2),char(96),char(0),char(73), -char(0),char(82),char(2),char(96),char(0),char(87),char(0),char(82),char(2),char(96), -char(0),char(89),char(0),char(102),char(2),char(96),char(0),char(90),char(0),char(102), -char(2),char(96),char(0),char(91),char(0),char(102),char(2),char(96),char(0),char(92), -char(0),char(102),char(2),char(96),char(0),char(191),char(0),char(102),char(2),char(96), -char(1),char(37),char(0),char(82),char(2),char(96),char(1),char(39),char(0),char(82), -char(2),char(96),char(1),char(55),char(0),char(102),char(2),char(96),char(1),char(251), -char(0),char(102),char(2),char(96),char(1),char(253),char(0),char(102),char(2),char(96), -char(2),char(52),char(0),char(82),char(2),char(96),char(2),char(53),char(0),char(82), -char(2),char(96),char(2),char(93),char(0),char(82),char(2),char(96),char(2),char(94), -char(0),char(82),char(2),char(96),char(3),char(112),char(0),char(102),char(2),char(96), -char(3),char(141),char(0),char(82),char(2),char(96),char(3),char(144),char(0),char(82), -char(2),char(98),char(0),char(73),char(0),char(102),char(2),char(98),char(0),char(87), -char(0),char(102),char(2),char(98),char(0),char(89),char(0),char(102),char(2),char(98), -char(0),char(90),char(0),char(102),char(2),char(98),char(0),char(91),char(0),char(102), -char(2),char(98),char(0),char(92),char(0),char(102),char(2),char(98),char(0),char(191), -char(0),char(102),char(2),char(98),char(1),char(37),char(0),char(102),char(2),char(98), -char(1),char(39),char(0),char(102),char(2),char(98),char(1),char(55),char(0),char(102), -char(2),char(98),char(1),char(251),char(0),char(102),char(2),char(98),char(1),char(253), -char(0),char(102),char(2),char(98),char(2),char(52),char(0),char(102),char(2),char(98), -char(2),char(53),char(0),char(102),char(2),char(98),char(2),char(93),char(0),char(102), -char(2),char(98),char(2),char(94),char(0),char(102),char(2),char(98),char(3),char(112), -char(0),char(102),char(2),char(98),char(3),char(141),char(0),char(102),char(2),char(98), -char(3),char(144),char(0),char(102),char(2),char(106),char(0),char(5),char(255),char(236), -char(2),char(106),char(0),char(10),char(255),char(236),char(2),char(106),char(2),char(7), -char(255),char(236),char(2),char(106),char(2),char(11),char(255),char(236),char(2),char(108), -char(0),char(15),char(255),char(174),char(2),char(108),char(0),char(17),char(255),char(174), -char(2),char(108),char(1),char(157),char(255),char(236),char(2),char(108),char(1),char(164), -char(255),char(215),char(2),char(108),char(1),char(166),char(255),char(236),char(2),char(108), -char(1),char(168),char(255),char(215),char(2),char(108),char(1),char(170),char(255),char(215), -char(2),char(108),char(1),char(174),char(255),char(215),char(2),char(108),char(1),char(176), -char(255),char(215),char(2),char(108),char(1),char(177),char(255),char(236),char(2),char(108), -char(1),char(181),char(255),char(215),char(2),char(108),char(1),char(188),char(255),char(195), -char(2),char(108),char(1),char(189),char(255),char(215),char(2),char(108),char(1),char(191), -char(255),char(215),char(2),char(108),char(1),char(193),char(255),char(215),char(2),char(108), -char(1),char(196),char(255),char(236),char(2),char(108),char(1),char(199),char(255),char(236), -char(2),char(108),char(1),char(206),char(255),char(236),char(2),char(108),char(1),char(213), -char(255),char(236),char(2),char(108),char(1),char(242),char(255),char(236),char(2),char(108), -char(2),char(8),char(255),char(174),char(2),char(108),char(2),char(12),char(255),char(174), -char(2),char(108),char(2),char(114),char(255),char(215),char(2),char(108),char(2),char(115), -char(255),char(236),char(2),char(108),char(2),char(122),char(255),char(236),char(2),char(108), -char(2),char(124),char(255),char(215),char(2),char(108),char(2),char(128),char(255),char(236), -char(2),char(108),char(2),char(130),char(255),char(236),char(2),char(108),char(2),char(159), -char(255),char(215),char(2),char(108),char(2),char(161),char(255),char(236),char(2),char(108), -char(2),char(169),char(255),char(236),char(2),char(108),char(2),char(181),char(255),char(195), -char(2),char(108),char(2),char(183),char(255),char(236),char(2),char(108),char(2),char(185), -char(255),char(236),char(2),char(108),char(2),char(187),char(255),char(215),char(2),char(108), -char(2),char(189),char(255),char(236),char(2),char(108),char(2),char(191),char(255),char(215), -char(2),char(108),char(2),char(193),char(255),char(215),char(2),char(108),char(2),char(202), -char(255),char(215),char(2),char(108),char(2),char(206),char(255),char(215),char(2),char(108), -char(2),char(207),char(255),char(236),char(2),char(108),char(2),char(212),char(255),char(215), -char(2),char(108),char(2),char(217),char(255),char(215),char(2),char(108),char(2),char(219), -char(255),char(215),char(2),char(108),char(2),char(221),char(255),char(215),char(2),char(108), -char(2),char(229),char(255),char(215),char(2),char(108),char(2),char(231),char(255),char(236), -char(2),char(108),char(2),char(245),char(255),char(236),char(2),char(108),char(2),char(247), -char(255),char(215),char(2),char(108),char(2),char(249),char(255),char(215),char(2),char(108), -char(2),char(251),char(255),char(215),char(2),char(108),char(2),char(253),char(255),char(215), -char(2),char(108),char(3),char(5),char(255),char(215),char(2),char(108),char(3),char(7), -char(255),char(215),char(2),char(108),char(3),char(13),char(255),char(215),char(2),char(108), -char(3),char(15),char(255),char(215),char(2),char(108),char(3),char(17),char(255),char(215), -char(2),char(108),char(3),char(18),char(255),char(236),char(2),char(108),char(3),char(23), -char(255),char(236),char(2),char(108),char(3),char(27),char(255),char(215),char(2),char(108), -char(3),char(28),char(255),char(236),char(2),char(109),char(0),char(15),char(255),char(174), -char(2),char(109),char(0),char(17),char(255),char(174),char(2),char(109),char(1),char(206), -char(255),char(215),char(2),char(109),char(1),char(213),char(255),char(215),char(2),char(109), -char(1),char(242),char(255),char(215),char(2),char(109),char(2),char(8),char(255),char(174), -char(2),char(109),char(2),char(12),char(255),char(174),char(2),char(109),char(2),char(115), -char(255),char(215),char(2),char(109),char(2),char(207),char(255),char(215),char(2),char(109), -char(3),char(18),char(255),char(215),char(2),char(109),char(3),char(28),char(255),char(215), -char(2),char(110),char(0),char(5),char(255),char(174),char(2),char(110),char(0),char(10), -char(255),char(174),char(2),char(110),char(1),char(157),char(255),char(215),char(2),char(110), -char(1),char(166),char(255),char(215),char(2),char(110),char(1),char(188),char(255),char(174), -char(2),char(110),char(1),char(193),char(255),char(174),char(2),char(110),char(1),char(196), -char(255),char(215),char(2),char(110),char(1),char(220),char(255),char(215),char(2),char(110), -char(1),char(228),char(255),char(215),char(2),char(110),char(2),char(7),char(255),char(174), -char(2),char(110),char(2),char(11),char(255),char(174),char(2),char(110),char(2),char(124), -char(255),char(174),char(2),char(110),char(2),char(128),char(255),char(195),char(2),char(110), -char(2),char(130),char(255),char(195),char(2),char(110),char(2),char(169),char(255),char(215), -char(2),char(110),char(2),char(170),char(255),char(215),char(2),char(110),char(2),char(181), -char(255),char(174),char(2),char(110),char(2),char(182),char(255),char(215),char(2),char(110), -char(2),char(183),char(255),char(195),char(2),char(110),char(2),char(185),char(255),char(195), -char(2),char(110),char(2),char(189),char(255),char(215),char(2),char(110),char(2),char(190), -char(255),char(215),char(2),char(110),char(2),char(191),char(255),char(174),char(2),char(110), -char(2),char(193),char(255),char(174),char(2),char(110),char(2),char(212),char(255),char(174), -char(2),char(110),char(2),char(253),char(255),char(174),char(2),char(110),char(3),char(13), -char(255),char(154),char(2),char(110),char(3),char(15),char(255),char(154),char(2),char(110), -char(3),char(23),char(255),char(215),char(2),char(110),char(3),char(24),char(255),char(215), -char(2),char(111),char(0),char(5),char(255),char(133),char(2),char(111),char(0),char(10), -char(255),char(133),char(2),char(111),char(1),char(208),char(255),char(215),char(2),char(111), -char(1),char(220),char(255),char(154),char(2),char(111),char(1),char(221),char(255),char(195), -char(2),char(111),char(1),char(223),char(255),char(215),char(2),char(111),char(1),char(225), -char(255),char(174),char(2),char(111),char(1),char(228),char(255),char(154),char(2),char(111), -char(1),char(246),char(255),char(195),char(2),char(111),char(2),char(7),char(255),char(133), -char(2),char(111),char(2),char(11),char(255),char(133),char(2),char(111),char(2),char(109), -char(255),char(215),char(2),char(111),char(2),char(129),char(255),char(215),char(2),char(111), -char(2),char(131),char(255),char(215),char(2),char(111),char(2),char(139),char(255),char(215), -char(2),char(111),char(2),char(160),char(255),char(215),char(2),char(111),char(2),char(170), -char(255),char(154),char(2),char(111),char(2),char(182),char(255),char(154),char(2),char(111), -char(2),char(184),char(255),char(195),char(2),char(111),char(2),char(186),char(255),char(195), -char(2),char(111),char(2),char(188),char(255),char(215),char(2),char(111),char(2),char(190), -char(255),char(154),char(2),char(111),char(2),char(192),char(255),char(174),char(2),char(111), -char(2),char(194),char(255),char(174),char(2),char(111),char(2),char(198),char(255),char(215), -char(2),char(111),char(2),char(200),char(255),char(215),char(2),char(111),char(2),char(203), -char(255),char(215),char(2),char(111),char(2),char(213),char(255),char(174),char(2),char(111), -char(2),char(230),char(255),char(215),char(2),char(111),char(2),char(234),char(255),char(215), -char(2),char(111),char(2),char(248),char(255),char(195),char(2),char(111),char(2),char(250), -char(255),char(195),char(2),char(111),char(2),char(252),char(255),char(195),char(2),char(111), -char(2),char(254),char(255),char(174),char(2),char(111),char(3),char(6),char(255),char(215), -char(2),char(111),char(3),char(8),char(255),char(215),char(2),char(111),char(3),char(14), -char(255),char(154),char(2),char(111),char(3),char(16),char(255),char(154),char(2),char(111), -char(3),char(24),char(255),char(154),char(2),char(112),char(1),char(159),char(255),char(215), -char(2),char(112),char(1),char(184),char(255),char(215),char(2),char(112),char(1),char(187), -char(255),char(215),char(2),char(112),char(1),char(190),char(255),char(215),char(2),char(112), -char(1),char(225),char(255),char(215),char(2),char(112),char(2),char(108),char(255),char(215), -char(2),char(112),char(2),char(126),char(255),char(215),char(2),char(112),char(2),char(132), -char(255),char(215),char(2),char(112),char(2),char(134),char(255),char(215),char(2),char(112), -char(2),char(136),char(255),char(215),char(2),char(112),char(2),char(138),char(255),char(215), -char(2),char(112),char(2),char(140),char(255),char(215),char(2),char(112),char(2),char(177), -char(255),char(215),char(2),char(112),char(2),char(179),char(255),char(215),char(2),char(112), -char(2),char(192),char(255),char(215),char(2),char(112),char(2),char(194),char(255),char(215), -char(2),char(112),char(2),char(197),char(255),char(215),char(2),char(112),char(2),char(199), -char(255),char(215),char(2),char(112),char(2),char(213),char(255),char(215),char(2),char(112), -char(2),char(239),char(255),char(215),char(2),char(112),char(2),char(241),char(255),char(215), -char(2),char(112),char(2),char(243),char(255),char(215),char(2),char(112),char(2),char(254), -char(255),char(215),char(2),char(112),char(3),char(9),char(255),char(215),char(2),char(112), -char(3),char(11),char(255),char(215),char(2),char(112),char(3),char(14),char(255),char(215), -char(2),char(112),char(3),char(16),char(255),char(215),char(2),char(112),char(3),char(21), -char(255),char(215),char(2),char(114),char(0),char(5),char(255),char(113),char(2),char(114), -char(0),char(10),char(255),char(113),char(2),char(114),char(1),char(157),char(255),char(154), -char(2),char(114),char(1),char(166),char(255),char(154),char(2),char(114),char(1),char(188), -char(255),char(113),char(2),char(114),char(1),char(190),char(255),char(215),char(2),char(114), -char(1),char(193),char(255),char(154),char(2),char(114),char(1),char(196),char(255),char(154), -char(2),char(114),char(1),char(220),char(255),char(215),char(2),char(114),char(1),char(225), -char(255),char(215),char(2),char(114),char(1),char(228),char(255),char(215),char(2),char(114), -char(2),char(7),char(255),char(113),char(2),char(114),char(2),char(11),char(255),char(113), -char(2),char(114),char(2),char(110),char(255),char(215),char(2),char(114),char(2),char(124), -char(255),char(154),char(2),char(114),char(2),char(128),char(255),char(174),char(2),char(114), -char(2),char(130),char(255),char(174),char(2),char(114),char(2),char(151),char(255),char(215), -char(2),char(114),char(2),char(155),char(255),char(215),char(2),char(114),char(2),char(167), -char(255),char(215),char(2),char(114),char(2),char(169),char(255),char(154),char(2),char(114), -char(2),char(170),char(255),char(215),char(2),char(114),char(2),char(181),char(255),char(113), -char(2),char(114),char(2),char(182),char(255),char(215),char(2),char(114),char(2),char(183), -char(255),char(133),char(2),char(114),char(2),char(185),char(255),char(133),char(2),char(114), -char(2),char(189),char(255),char(154),char(2),char(114),char(2),char(190),char(255),char(215), -char(2),char(114),char(2),char(191),char(255),char(154),char(2),char(114),char(2),char(192), -char(255),char(215),char(2),char(114),char(2),char(193),char(255),char(154),char(2),char(114), -char(2),char(194),char(255),char(215),char(2),char(114),char(2),char(197),char(255),char(154), -char(2),char(114),char(2),char(199),char(255),char(154),char(2),char(114),char(2),char(212), -char(255),char(154),char(2),char(114),char(2),char(213),char(255),char(215),char(2),char(114), -char(2),char(225),char(255),char(215),char(2),char(114),char(2),char(227),char(255),char(215), -char(2),char(114),char(2),char(253),char(255),char(154),char(2),char(114),char(2),char(254), -char(255),char(215),char(2),char(114),char(3),char(3),char(255),char(215),char(2),char(114), -char(3),char(13),char(255),char(113),char(2),char(114),char(3),char(14),char(255),char(215), -char(2),char(114),char(3),char(15),char(255),char(113),char(2),char(114),char(3),char(16), -char(255),char(215),char(2),char(114),char(3),char(23),char(255),char(154),char(2),char(114), -char(3),char(24),char(255),char(215),char(2),char(115),char(0),char(5),char(255),char(113), -char(2),char(115),char(0),char(10),char(255),char(113),char(2),char(115),char(1),char(207), -char(255),char(215),char(2),char(115),char(1),char(216),char(255),char(215),char(2),char(115), -char(1),char(219),char(255),char(215),char(2),char(115),char(1),char(220),char(255),char(154), -char(2),char(115),char(1),char(221),char(255),char(195),char(2),char(115),char(1),char(222), -char(255),char(215),char(2),char(115),char(1),char(225),char(255),char(195),char(2),char(115), -char(1),char(228),char(255),char(154),char(2),char(115),char(1),char(234),char(255),char(215), -char(2),char(115),char(1),char(237),char(255),char(215),char(2),char(115),char(1),char(246), -char(255),char(195),char(2),char(115),char(2),char(7),char(255),char(113),char(2),char(115), -char(2),char(11),char(255),char(113),char(2),char(115),char(2),char(106),char(255),char(215), -char(2),char(115),char(2),char(109),char(255),char(215),char(2),char(115),char(2),char(125), -char(255),char(236),char(2),char(115),char(2),char(127),char(255),char(215),char(2),char(115), -char(2),char(129),char(255),char(215),char(2),char(115),char(2),char(131),char(255),char(215), -char(2),char(115),char(2),char(133),char(255),char(215),char(2),char(115),char(2),char(135), -char(255),char(215),char(2),char(115),char(2),char(137),char(255),char(215),char(2),char(115), -char(2),char(139),char(255),char(215),char(2),char(115),char(2),char(141),char(255),char(215), -char(2),char(115),char(2),char(170),char(255),char(154),char(2),char(115),char(2),char(178), -char(255),char(215),char(2),char(115),char(2),char(180),char(255),char(215),char(2),char(115), -char(2),char(182),char(255),char(154),char(2),char(115),char(2),char(184),char(255),char(215), -char(2),char(115),char(2),char(186),char(255),char(215),char(2),char(115),char(2),char(190), -char(255),char(154),char(2),char(115),char(2),char(192),char(255),char(195),char(2),char(115), -char(2),char(194),char(255),char(195),char(2),char(115),char(2),char(198),char(255),char(215), -char(2),char(115),char(2),char(200),char(255),char(215),char(2),char(115),char(2),char(213), -char(255),char(195),char(2),char(115),char(2),char(224),char(255),char(215),char(2),char(115), -char(2),char(240),char(255),char(215),char(2),char(115),char(2),char(242),char(255),char(215), -char(2),char(115),char(2),char(244),char(255),char(215),char(2),char(115),char(2),char(248), -char(255),char(195),char(2),char(115),char(2),char(250),char(255),char(195),char(2),char(115), -char(2),char(252),char(255),char(195),char(2),char(115),char(2),char(254),char(255),char(195), -char(2),char(115),char(3),char(10),char(255),char(215),char(2),char(115),char(3),char(12), -char(255),char(215),char(2),char(115),char(3),char(14),char(255),char(133),char(2),char(115), -char(3),char(16),char(255),char(133),char(2),char(115),char(3),char(22),char(255),char(215), -char(2),char(115),char(3),char(24),char(255),char(154),char(2),char(115),char(3),char(26), -char(255),char(215),char(2),char(116),char(0),char(5),char(255),char(113),char(2),char(116), -char(0),char(10),char(255),char(113),char(2),char(116),char(1),char(157),char(255),char(154), -char(2),char(116),char(1),char(166),char(255),char(154),char(2),char(116),char(1),char(188), -char(255),char(113),char(2),char(116),char(1),char(190),char(255),char(215),char(2),char(116), -char(1),char(193),char(255),char(154),char(2),char(116),char(1),char(196),char(255),char(154), -char(2),char(116),char(1),char(220),char(255),char(215),char(2),char(116),char(1),char(225), -char(255),char(215),char(2),char(116),char(1),char(228),char(255),char(215),char(2),char(116), -char(2),char(7),char(255),char(113),char(2),char(116),char(2),char(11),char(255),char(113), -char(2),char(116),char(2),char(110),char(255),char(215),char(2),char(116),char(2),char(124), -char(255),char(154),char(2),char(116),char(2),char(128),char(255),char(174),char(2),char(116), -char(2),char(130),char(255),char(174),char(2),char(116),char(2),char(151),char(255),char(215), -char(2),char(116),char(2),char(155),char(255),char(215),char(2),char(116),char(2),char(167), -char(255),char(215),char(2),char(116),char(2),char(169),char(255),char(154),char(2),char(116), -char(2),char(170),char(255),char(215),char(2),char(116),char(2),char(181),char(255),char(113), -char(2),char(116),char(2),char(182),char(255),char(215),char(2),char(116),char(2),char(183), -char(255),char(133),char(2),char(116),char(2),char(185),char(255),char(133),char(2),char(116), -char(2),char(189),char(255),char(154),char(2),char(116),char(2),char(190),char(255),char(215), -char(2),char(116),char(2),char(191),char(255),char(154),char(2),char(116),char(2),char(192), -char(255),char(215),char(2),char(116),char(2),char(193),char(255),char(154),char(2),char(116), -char(2),char(194),char(255),char(215),char(2),char(116),char(2),char(197),char(255),char(154), -char(2),char(116),char(2),char(199),char(255),char(154),char(2),char(116),char(2),char(212), -char(255),char(154),char(2),char(116),char(2),char(213),char(255),char(215),char(2),char(116), -char(2),char(225),char(255),char(215),char(2),char(116),char(2),char(227),char(255),char(215), -char(2),char(116),char(2),char(253),char(255),char(154),char(2),char(116),char(2),char(254), -char(255),char(215),char(2),char(116),char(3),char(3),char(255),char(215),char(2),char(116), -char(3),char(13),char(255),char(113),char(2),char(116),char(3),char(14),char(255),char(215), -char(2),char(116),char(3),char(15),char(255),char(113),char(2),char(116),char(3),char(16), -char(255),char(215),char(2),char(116),char(3),char(23),char(255),char(154),char(2),char(116), -char(3),char(24),char(255),char(215),char(2),char(117),char(0),char(5),char(255),char(113), -char(2),char(117),char(0),char(10),char(255),char(113),char(2),char(117),char(1),char(207), -char(255),char(215),char(2),char(117),char(1),char(216),char(255),char(215),char(2),char(117), -char(1),char(219),char(255),char(215),char(2),char(117),char(1),char(220),char(255),char(154), -char(2),char(117),char(1),char(221),char(255),char(195),char(2),char(117),char(1),char(222), -char(255),char(215),char(2),char(117),char(1),char(225),char(255),char(195),char(2),char(117), -char(1),char(228),char(255),char(154),char(2),char(117),char(1),char(234),char(255),char(215), -char(2),char(117),char(1),char(237),char(255),char(215),char(2),char(117),char(1),char(246), -char(255),char(195),char(2),char(117),char(2),char(7),char(255),char(113),char(2),char(117), -char(2),char(11),char(255),char(113),char(2),char(117),char(2),char(106),char(255),char(215), -char(2),char(117),char(2),char(109),char(255),char(215),char(2),char(117),char(2),char(125), -char(255),char(236),char(2),char(117),char(2),char(127),char(255),char(215),char(2),char(117), -char(2),char(129),char(255),char(215),char(2),char(117),char(2),char(131),char(255),char(215), -char(2),char(117),char(2),char(133),char(255),char(215),char(2),char(117),char(2),char(135), -char(255),char(215),char(2),char(117),char(2),char(137),char(255),char(215),char(2),char(117), -char(2),char(139),char(255),char(215),char(2),char(117),char(2),char(141),char(255),char(215), -char(2),char(117),char(2),char(170),char(255),char(154),char(2),char(117),char(2),char(178), -char(255),char(215),char(2),char(117),char(2),char(180),char(255),char(215),char(2),char(117), -char(2),char(182),char(255),char(154),char(2),char(117),char(2),char(184),char(255),char(215), -char(2),char(117),char(2),char(186),char(255),char(215),char(2),char(117),char(2),char(190), -char(255),char(154),char(2),char(117),char(2),char(192),char(255),char(195),char(2),char(117), -char(2),char(194),char(255),char(195),char(2),char(117),char(2),char(198),char(255),char(215), -char(2),char(117),char(2),char(200),char(255),char(215),char(2),char(117),char(2),char(213), -char(255),char(195),char(2),char(117),char(2),char(224),char(255),char(215),char(2),char(117), -char(2),char(240),char(255),char(215),char(2),char(117),char(2),char(242),char(255),char(215), -char(2),char(117),char(2),char(244),char(255),char(215),char(2),char(117),char(2),char(248), -char(255),char(195),char(2),char(117),char(2),char(250),char(255),char(195),char(2),char(117), -char(2),char(252),char(255),char(195),char(2),char(117),char(2),char(254),char(255),char(195), -char(2),char(117),char(3),char(10),char(255),char(215),char(2),char(117),char(3),char(12), -char(255),char(215),char(2),char(117),char(3),char(14),char(255),char(133),char(2),char(117), -char(3),char(16),char(255),char(133),char(2),char(117),char(3),char(22),char(255),char(215), -char(2),char(117),char(3),char(24),char(255),char(154),char(2),char(117),char(3),char(26), -char(255),char(215),char(2),char(118),char(3),char(13),char(255),char(236),char(2),char(118), -char(3),char(15),char(255),char(236),char(2),char(120),char(3),char(13),char(255),char(236), -char(2),char(120),char(3),char(15),char(255),char(236),char(2),char(122),char(0),char(15), -char(255),char(174),char(2),char(122),char(0),char(17),char(255),char(174),char(2),char(122), -char(2),char(8),char(255),char(174),char(2),char(122),char(2),char(12),char(255),char(174), -char(2),char(122),char(2),char(128),char(255),char(236),char(2),char(122),char(2),char(130), -char(255),char(236),char(2),char(122),char(2),char(183),char(255),char(236),char(2),char(122), -char(2),char(185),char(255),char(236),char(2),char(122),char(3),char(13),char(255),char(215), -char(2),char(122),char(3),char(15),char(255),char(215),char(2),char(124),char(0),char(15), -char(255),char(113),char(2),char(124),char(0),char(17),char(255),char(113),char(2),char(124), -char(1),char(164),char(255),char(195),char(2),char(124),char(1),char(170),char(255),char(174), -char(2),char(124),char(1),char(174),char(255),char(195),char(2),char(124),char(1),char(181), -char(255),char(195),char(2),char(124),char(1),char(206),char(255),char(215),char(2),char(124), -char(1),char(213),char(255),char(215),char(2),char(124),char(1),char(242),char(255),char(215), -char(2),char(124),char(2),char(8),char(255),char(113),char(2),char(124),char(2),char(12), -char(255),char(113),char(2),char(124),char(2),char(114),char(255),char(174),char(2),char(124), -char(2),char(115),char(255),char(215),char(2),char(124),char(2),char(206),char(255),char(195), -char(2),char(124),char(2),char(207),char(255),char(215),char(2),char(124),char(2),char(217), -char(255),char(174),char(2),char(124),char(2),char(219),char(255),char(174),char(2),char(124), -char(2),char(221),char(255),char(174),char(2),char(124),char(3),char(9),char(255),char(174), -char(2),char(124),char(3),char(11),char(255),char(174),char(2),char(124),char(3),char(17), -char(255),char(195),char(2),char(124),char(3),char(18),char(255),char(215),char(2),char(124), -char(3),char(27),char(255),char(195),char(2),char(124),char(3),char(28),char(255),char(215), -char(2),char(125),char(0),char(5),char(255),char(236),char(2),char(125),char(0),char(10), -char(255),char(236),char(2),char(125),char(1),char(208),char(255),char(215),char(2),char(125), -char(1),char(220),char(255),char(236),char(2),char(125),char(1),char(221),char(255),char(236), -char(2),char(125),char(1),char(223),char(255),char(215),char(2),char(125),char(1),char(225), -char(255),char(236),char(2),char(125),char(1),char(228),char(255),char(236),char(2),char(125), -char(1),char(246),char(255),char(236),char(2),char(125),char(2),char(7),char(255),char(236), -char(2),char(125),char(2),char(11),char(255),char(236),char(2),char(125),char(2),char(160), -char(255),char(215),char(2),char(125),char(2),char(170),char(255),char(236),char(2),char(125), -char(2),char(182),char(255),char(236),char(2),char(125),char(2),char(188),char(255),char(215), -char(2),char(125),char(2),char(190),char(255),char(236),char(2),char(125),char(2),char(192), -char(255),char(236),char(2),char(125),char(2),char(194),char(255),char(236),char(2),char(125), -char(2),char(203),char(255),char(215),char(2),char(125),char(2),char(213),char(255),char(236), -char(2),char(125),char(2),char(230),char(255),char(215),char(2),char(125),char(2),char(248), -char(255),char(236),char(2),char(125),char(2),char(250),char(255),char(236),char(2),char(125), -char(2),char(252),char(255),char(236),char(2),char(125),char(2),char(254),char(255),char(236), -char(2),char(125),char(3),char(6),char(255),char(215),char(2),char(125),char(3),char(8), -char(255),char(215),char(2),char(125),char(3),char(14),char(255),char(236),char(2),char(125), -char(3),char(16),char(255),char(236),char(2),char(125),char(3),char(24),char(255),char(236), -char(2),char(126),char(0),char(15),char(255),char(174),char(2),char(126),char(0),char(17), -char(255),char(174),char(2),char(126),char(1),char(157),char(255),char(236),char(2),char(126), -char(1),char(164),char(255),char(215),char(2),char(126),char(1),char(166),char(255),char(236), -char(2),char(126),char(1),char(168),char(255),char(215),char(2),char(126),char(1),char(170), -char(255),char(215),char(2),char(126),char(1),char(174),char(255),char(215),char(2),char(126), -char(1),char(176),char(255),char(215),char(2),char(126),char(1),char(177),char(255),char(236), -char(2),char(126),char(1),char(181),char(255),char(215),char(2),char(126),char(1),char(188), -char(255),char(195),char(2),char(126),char(1),char(189),char(255),char(215),char(2),char(126), -char(1),char(191),char(255),char(215),char(2),char(126),char(1),char(193),char(255),char(215), -char(2),char(126),char(1),char(196),char(255),char(236),char(2),char(126),char(1),char(199), -char(255),char(236),char(2),char(126),char(1),char(206),char(255),char(236),char(2),char(126), -char(1),char(213),char(255),char(236),char(2),char(126),char(1),char(242),char(255),char(236), -char(2),char(126),char(2),char(8),char(255),char(174),char(2),char(126),char(2),char(12), -char(255),char(174),char(2),char(126),char(2),char(114),char(255),char(215),char(2),char(126), -char(2),char(115),char(255),char(236),char(2),char(126),char(2),char(122),char(255),char(236), -char(2),char(126),char(2),char(124),char(255),char(215),char(2),char(126),char(2),char(128), -char(255),char(236),char(2),char(126),char(2),char(130),char(255),char(236),char(2),char(126), -char(2),char(159),char(255),char(215),char(2),char(126),char(2),char(161),char(255),char(236), -char(2),char(126),char(2),char(169),char(255),char(236),char(2),char(126),char(2),char(181), -char(255),char(195),char(2),char(126),char(2),char(183),char(255),char(236),char(2),char(126), -char(2),char(185),char(255),char(236),char(2),char(126),char(2),char(187),char(255),char(215), -char(2),char(126),char(2),char(189),char(255),char(236),char(2),char(126),char(2),char(191), -char(255),char(215),char(2),char(126),char(2),char(193),char(255),char(215),char(2),char(126), -char(2),char(202),char(255),char(215),char(2),char(126),char(2),char(206),char(255),char(215), -char(2),char(126),char(2),char(207),char(255),char(236),char(2),char(126),char(2),char(212), -char(255),char(215),char(2),char(126),char(2),char(217),char(255),char(215),char(2),char(126), -char(2),char(219),char(255),char(215),char(2),char(126),char(2),char(221),char(255),char(215), -char(2),char(126),char(2),char(229),char(255),char(215),char(2),char(126),char(2),char(231), -char(255),char(236),char(2),char(126),char(2),char(245),char(255),char(236),char(2),char(126), -char(2),char(247),char(255),char(215),char(2),char(126),char(2),char(249),char(255),char(215), -char(2),char(126),char(2),char(251),char(255),char(215),char(2),char(126),char(2),char(253), -char(255),char(215),char(2),char(126),char(3),char(5),char(255),char(215),char(2),char(126), -char(3),char(7),char(255),char(215),char(2),char(126),char(3),char(13),char(255),char(215), -char(2),char(126),char(3),char(15),char(255),char(215),char(2),char(126),char(3),char(17), -char(255),char(215),char(2),char(126),char(3),char(18),char(255),char(236),char(2),char(126), -char(3),char(23),char(255),char(236),char(2),char(126),char(3),char(27),char(255),char(215), -char(2),char(126),char(3),char(28),char(255),char(236),char(2),char(127),char(0),char(5), -char(255),char(236),char(2),char(127),char(0),char(10),char(255),char(236),char(2),char(127), -char(1),char(208),char(255),char(215),char(2),char(127),char(1),char(220),char(255),char(236), -char(2),char(127),char(1),char(221),char(255),char(236),char(2),char(127),char(1),char(223), -char(255),char(215),char(2),char(127),char(1),char(225),char(255),char(236),char(2),char(127), -char(1),char(228),char(255),char(236),char(2),char(127),char(1),char(246),char(255),char(236), -char(2),char(127),char(2),char(7),char(255),char(236),char(2),char(127),char(2),char(11), -char(255),char(236),char(2),char(127),char(2),char(160),char(255),char(215),char(2),char(127), -char(2),char(170),char(255),char(236),char(2),char(127),char(2),char(182),char(255),char(236), -char(2),char(127),char(2),char(188),char(255),char(215),char(2),char(127),char(2),char(190), -char(255),char(236),char(2),char(127),char(2),char(192),char(255),char(236),char(2),char(127), -char(2),char(194),char(255),char(236),char(2),char(127),char(2),char(203),char(255),char(215), -char(2),char(127),char(2),char(213),char(255),char(236),char(2),char(127),char(2),char(230), -char(255),char(215),char(2),char(127),char(2),char(248),char(255),char(236),char(2),char(127), -char(2),char(250),char(255),char(236),char(2),char(127),char(2),char(252),char(255),char(236), -char(2),char(127),char(2),char(254),char(255),char(236),char(2),char(127),char(3),char(6), -char(255),char(215),char(2),char(127),char(3),char(8),char(255),char(215),char(2),char(127), -char(3),char(14),char(255),char(236),char(2),char(127),char(3),char(16),char(255),char(236), -char(2),char(127),char(3),char(24),char(255),char(236),char(2),char(128),char(0),char(15), -char(255),char(133),char(2),char(128),char(0),char(17),char(255),char(133),char(2),char(128), -char(1),char(159),char(255),char(236),char(2),char(128),char(1),char(164),char(255),char(154), -char(2),char(128),char(1),char(170),char(255),char(113),char(2),char(128),char(1),char(174), -char(255),char(154),char(2),char(128),char(1),char(181),char(255),char(154),char(2),char(128), -char(1),char(184),char(255),char(236),char(2),char(128),char(1),char(187),char(255),char(236), -char(2),char(128),char(1),char(190),char(255),char(195),char(2),char(128),char(1),char(201), -char(255),char(236),char(2),char(128),char(1),char(206),char(255),char(174),char(2),char(128), -char(1),char(207),char(255),char(215),char(2),char(128),char(1),char(213),char(255),char(174), -char(2),char(128),char(1),char(216),char(255),char(215),char(2),char(128),char(1),char(219), -char(255),char(215),char(2),char(128),char(1),char(222),char(255),char(215),char(2),char(128), -char(1),char(225),char(255),char(215),char(2),char(128),char(1),char(234),char(255),char(215), -char(2),char(128),char(1),char(235),char(0),char(102),char(2),char(128),char(1),char(237), -char(255),char(215),char(2),char(128),char(1),char(238),char(255),char(236),char(2),char(128), -char(1),char(242),char(255),char(174),char(2),char(128),char(1),char(244),char(0),char(102), -char(2),char(128),char(2),char(8),char(255),char(133),char(2),char(128),char(2),char(12), -char(255),char(133),char(2),char(128),char(2),char(106),char(255),char(215),char(2),char(128), -char(2),char(108),char(255),char(236),char(2),char(128),char(2),char(114),char(255),char(113), -char(2),char(128),char(2),char(115),char(255),char(174),char(2),char(128),char(2),char(126), -char(255),char(236),char(2),char(128),char(2),char(127),char(255),char(215),char(2),char(128), -char(2),char(132),char(255),char(236),char(2),char(128),char(2),char(133),char(255),char(215), -char(2),char(128),char(2),char(134),char(255),char(236),char(2),char(128),char(2),char(135), -char(255),char(215),char(2),char(128),char(2),char(136),char(255),char(236),char(2),char(128), -char(2),char(137),char(255),char(215),char(2),char(128),char(2),char(138),char(255),char(236), -char(2),char(128),char(2),char(140),char(255),char(236),char(2),char(128),char(2),char(141), -char(255),char(215),char(2),char(128),char(2),char(152),char(0),char(102),char(2),char(128), -char(2),char(168),char(0),char(102),char(2),char(128),char(2),char(177),char(255),char(236), -char(2),char(128),char(2),char(178),char(255),char(215),char(2),char(128),char(2),char(179), -char(255),char(236),char(2),char(128),char(2),char(180),char(255),char(215),char(2),char(128), -char(2),char(192),char(255),char(215),char(2),char(128),char(2),char(194),char(255),char(215), -char(2),char(128),char(2),char(197),char(255),char(215),char(2),char(128),char(2),char(198), -char(255),char(195),char(2),char(128),char(2),char(199),char(255),char(215),char(2),char(128), -char(2),char(200),char(255),char(195),char(2),char(128),char(2),char(206),char(255),char(154), -char(2),char(128),char(2),char(207),char(255),char(174),char(2),char(128),char(2),char(213), -char(255),char(215),char(2),char(128),char(2),char(217),char(255),char(113),char(2),char(128), -char(2),char(219),char(255),char(113),char(2),char(128),char(2),char(221),char(255),char(113), -char(2),char(128),char(2),char(224),char(255),char(215),char(2),char(128),char(2),char(239), -char(255),char(236),char(2),char(128),char(2),char(240),char(255),char(215),char(2),char(128), -char(2),char(241),char(255),char(236),char(2),char(128),char(2),char(242),char(255),char(215), -char(2),char(128),char(2),char(243),char(255),char(236),char(2),char(128),char(2),char(244), -char(255),char(215),char(2),char(128),char(2),char(254),char(255),char(215),char(2),char(128), -char(3),char(9),char(255),char(113),char(2),char(128),char(3),char(10),char(255),char(215), -char(2),char(128),char(3),char(11),char(255),char(113),char(2),char(128),char(3),char(12), -char(255),char(215),char(2),char(128),char(3),char(17),char(255),char(154),char(2),char(128), -char(3),char(18),char(255),char(174),char(2),char(128),char(3),char(21),char(255),char(236), -char(2),char(128),char(3),char(22),char(255),char(215),char(2),char(128),char(3),char(26), -char(255),char(215),char(2),char(128),char(3),char(27),char(255),char(154),char(2),char(128), -char(3),char(28),char(255),char(174),char(2),char(129),char(0),char(15),char(255),char(174), -char(2),char(129),char(0),char(17),char(255),char(174),char(2),char(129),char(1),char(206), -char(255),char(215),char(2),char(129),char(1),char(213),char(255),char(215),char(2),char(129), -char(1),char(242),char(255),char(215),char(2),char(129),char(2),char(8),char(255),char(174), -char(2),char(129),char(2),char(12),char(255),char(174),char(2),char(129),char(2),char(115), -char(255),char(215),char(2),char(129),char(2),char(207),char(255),char(215),char(2),char(129), -char(3),char(18),char(255),char(215),char(2),char(129),char(3),char(28),char(255),char(215), -char(2),char(130),char(0),char(15),char(255),char(133),char(2),char(130),char(0),char(17), -char(255),char(133),char(2),char(130),char(1),char(159),char(255),char(236),char(2),char(130), -char(1),char(164),char(255),char(154),char(2),char(130),char(1),char(170),char(255),char(113), -char(2),char(130),char(1),char(174),char(255),char(154),char(2),char(130),char(1),char(181), -char(255),char(154),char(2),char(130),char(1),char(184),char(255),char(236),char(2),char(130), -char(1),char(187),char(255),char(236),char(2),char(130),char(1),char(190),char(255),char(195), -char(2),char(130),char(1),char(201),char(255),char(236),char(2),char(130),char(1),char(206), -char(255),char(174),char(2),char(130),char(1),char(207),char(255),char(215),char(2),char(130), -char(1),char(213),char(255),char(174),char(2),char(130),char(1),char(216),char(255),char(215), -char(2),char(130),char(1),char(219),char(255),char(215),char(2),char(130),char(1),char(222), -char(255),char(215),char(2),char(130),char(1),char(225),char(255),char(215),char(2),char(130), -char(1),char(234),char(255),char(215),char(2),char(130),char(1),char(235),char(0),char(102), -char(2),char(130),char(1),char(237),char(255),char(215),char(2),char(130),char(1),char(238), -char(255),char(236),char(2),char(130),char(1),char(242),char(255),char(174),char(2),char(130), -char(1),char(244),char(0),char(102),char(2),char(130),char(2),char(8),char(255),char(133), -char(2),char(130),char(2),char(12),char(255),char(133),char(2),char(130),char(2),char(106), -char(255),char(215),char(2),char(130),char(2),char(108),char(255),char(236),char(2),char(130), -char(2),char(114),char(255),char(113),char(2),char(130),char(2),char(115),char(255),char(174), -char(2),char(130),char(2),char(126),char(255),char(236),char(2),char(130),char(2),char(127), -char(255),char(215),char(2),char(130),char(2),char(132),char(255),char(236),char(2),char(130), -char(2),char(133),char(255),char(215),char(2),char(130),char(2),char(134),char(255),char(236), -char(2),char(130),char(2),char(135),char(255),char(215),char(2),char(130),char(2),char(136), -char(255),char(236),char(2),char(130),char(2),char(137),char(255),char(215),char(2),char(130), -char(2),char(138),char(255),char(236),char(2),char(130),char(2),char(140),char(255),char(236), -char(2),char(130),char(2),char(141),char(255),char(215),char(2),char(130),char(2),char(152), -char(0),char(102),char(2),char(130),char(2),char(168),char(0),char(102),char(2),char(130), -char(2),char(177),char(255),char(236),char(2),char(130),char(2),char(178),char(255),char(215), -char(2),char(130),char(2),char(179),char(255),char(236),char(2),char(130),char(2),char(180), -char(255),char(215),char(2),char(130),char(2),char(192),char(255),char(215),char(2),char(130), -char(2),char(194),char(255),char(215),char(2),char(130),char(2),char(197),char(255),char(215), -char(2),char(130),char(2),char(198),char(255),char(195),char(2),char(130),char(2),char(199), -char(255),char(215),char(2),char(130),char(2),char(200),char(255),char(195),char(2),char(130), -char(2),char(206),char(255),char(154),char(2),char(130),char(2),char(207),char(255),char(174), -char(2),char(130),char(2),char(213),char(255),char(215),char(2),char(130),char(2),char(217), -char(255),char(113),char(2),char(130),char(2),char(219),char(255),char(113),char(2),char(130), -char(2),char(221),char(255),char(113),char(2),char(130),char(2),char(224),char(255),char(215), -char(2),char(130),char(2),char(239),char(255),char(236),char(2),char(130),char(2),char(240), -char(255),char(215),char(2),char(130),char(2),char(241),char(255),char(236),char(2),char(130), -char(2),char(242),char(255),char(215),char(2),char(130),char(2),char(243),char(255),char(236), -char(2),char(130),char(2),char(244),char(255),char(215),char(2),char(130),char(2),char(254), -char(255),char(215),char(2),char(130),char(3),char(9),char(255),char(113),char(2),char(130), -char(3),char(10),char(255),char(215),char(2),char(130),char(3),char(11),char(255),char(113), -char(2),char(130),char(3),char(12),char(255),char(215),char(2),char(130),char(3),char(17), -char(255),char(154),char(2),char(130),char(3),char(18),char(255),char(174),char(2),char(130), -char(3),char(21),char(255),char(236),char(2),char(130),char(3),char(22),char(255),char(215), -char(2),char(130),char(3),char(26),char(255),char(215),char(2),char(130),char(3),char(27), -char(255),char(154),char(2),char(130),char(3),char(28),char(255),char(174),char(2),char(131), -char(0),char(15),char(255),char(174),char(2),char(131),char(0),char(17),char(255),char(174), -char(2),char(131),char(1),char(206),char(255),char(215),char(2),char(131),char(1),char(213), -char(255),char(215),char(2),char(131),char(1),char(242),char(255),char(215),char(2),char(131), -char(2),char(8),char(255),char(174),char(2),char(131),char(2),char(12),char(255),char(174), -char(2),char(131),char(2),char(115),char(255),char(215),char(2),char(131),char(2),char(207), -char(255),char(215),char(2),char(131),char(3),char(18),char(255),char(215),char(2),char(131), -char(3),char(28),char(255),char(215),char(2),char(132),char(0),char(15),char(255),char(174), -char(2),char(132),char(0),char(17),char(255),char(174),char(2),char(132),char(1),char(206), -char(255),char(215),char(2),char(132),char(1),char(213),char(255),char(215),char(2),char(132), -char(1),char(242),char(255),char(215),char(2),char(132),char(2),char(8),char(255),char(174), -char(2),char(132),char(2),char(12),char(255),char(174),char(2),char(132),char(2),char(115), -char(255),char(215),char(2),char(132),char(2),char(207),char(255),char(215),char(2),char(132), -char(3),char(18),char(255),char(215),char(2),char(132),char(3),char(28),char(255),char(215), -char(2),char(133),char(0),char(15),char(255),char(174),char(2),char(133),char(0),char(17), -char(255),char(174),char(2),char(133),char(1),char(206),char(255),char(215),char(2),char(133), -char(1),char(213),char(255),char(215),char(2),char(133),char(1),char(242),char(255),char(215), -char(2),char(133),char(2),char(8),char(255),char(174),char(2),char(133),char(2),char(12), -char(255),char(174),char(2),char(133),char(2),char(115),char(255),char(215),char(2),char(133), -char(2),char(207),char(255),char(215),char(2),char(133),char(3),char(18),char(255),char(215), -char(2),char(133),char(3),char(28),char(255),char(215),char(2),char(134),char(0),char(15), -char(255),char(174),char(2),char(134),char(0),char(17),char(255),char(174),char(2),char(134), -char(1),char(157),char(255),char(236),char(2),char(134),char(1),char(164),char(255),char(215), -char(2),char(134),char(1),char(166),char(255),char(236),char(2),char(134),char(1),char(168), -char(255),char(215),char(2),char(134),char(1),char(170),char(255),char(215),char(2),char(134), -char(1),char(174),char(255),char(215),char(2),char(134),char(1),char(176),char(255),char(215), -char(2),char(134),char(1),char(177),char(255),char(236),char(2),char(134),char(1),char(181), -char(255),char(215),char(2),char(134),char(1),char(188),char(255),char(195),char(2),char(134), -char(1),char(189),char(255),char(215),char(2),char(134),char(1),char(191),char(255),char(215), -char(2),char(134),char(1),char(193),char(255),char(215),char(2),char(134),char(1),char(196), -char(255),char(236),char(2),char(134),char(1),char(199),char(255),char(236),char(2),char(134), -char(1),char(206),char(255),char(236),char(2),char(134),char(1),char(213),char(255),char(236), -char(2),char(134),char(1),char(242),char(255),char(236),char(2),char(134),char(2),char(8), -char(255),char(174),char(2),char(134),char(2),char(12),char(255),char(174),char(2),char(134), -char(2),char(114),char(255),char(215),char(2),char(134),char(2),char(115),char(255),char(236), -char(2),char(134),char(2),char(122),char(255),char(236),char(2),char(134),char(2),char(124), -char(255),char(215),char(2),char(134),char(2),char(128),char(255),char(236),char(2),char(134), -char(2),char(130),char(255),char(236),char(2),char(134),char(2),char(159),char(255),char(215), -char(2),char(134),char(2),char(161),char(255),char(236),char(2),char(134),char(2),char(169), -char(255),char(236),char(2),char(134),char(2),char(181),char(255),char(195),char(2),char(134), -char(2),char(183),char(255),char(236),char(2),char(134),char(2),char(185),char(255),char(236), -char(2),char(134),char(2),char(187),char(255),char(215),char(2),char(134),char(2),char(189), -char(255),char(236),char(2),char(134),char(2),char(191),char(255),char(215),char(2),char(134), -char(2),char(193),char(255),char(215),char(2),char(134),char(2),char(202),char(255),char(215), -char(2),char(134),char(2),char(206),char(255),char(215),char(2),char(134),char(2),char(207), -char(255),char(236),char(2),char(134),char(2),char(212),char(255),char(215),char(2),char(134), -char(2),char(217),char(255),char(215),char(2),char(134),char(2),char(219),char(255),char(215), -char(2),char(134),char(2),char(221),char(255),char(215),char(2),char(134),char(2),char(229), -char(255),char(215),char(2),char(134),char(2),char(231),char(255),char(236),char(2),char(134), -char(2),char(245),char(255),char(236),char(2),char(134),char(2),char(247),char(255),char(215), -char(2),char(134),char(2),char(249),char(255),char(215),char(2),char(134),char(2),char(251), -char(255),char(215),char(2),char(134),char(2),char(253),char(255),char(215),char(2),char(134), -char(3),char(5),char(255),char(215),char(2),char(134),char(3),char(7),char(255),char(215), -char(2),char(134),char(3),char(13),char(255),char(215),char(2),char(134),char(3),char(15), -char(255),char(215),char(2),char(134),char(3),char(17),char(255),char(215),char(2),char(134), -char(3),char(18),char(255),char(236),char(2),char(134),char(3),char(23),char(255),char(236), -char(2),char(134),char(3),char(27),char(255),char(215),char(2),char(134),char(3),char(28), -char(255),char(236),char(2),char(135),char(0),char(5),char(255),char(236),char(2),char(135), -char(0),char(10),char(255),char(236),char(2),char(135),char(1),char(208),char(255),char(215), -char(2),char(135),char(1),char(220),char(255),char(236),char(2),char(135),char(1),char(221), -char(255),char(236),char(2),char(135),char(1),char(223),char(255),char(215),char(2),char(135), -char(1),char(225),char(255),char(236),char(2),char(135),char(1),char(228),char(255),char(236), -char(2),char(135),char(1),char(246),char(255),char(236),char(2),char(135),char(2),char(7), -char(255),char(236),char(2),char(135),char(2),char(11),char(255),char(236),char(2),char(135), -char(2),char(160),char(255),char(215),char(2),char(135),char(2),char(170),char(255),char(236), -char(2),char(135),char(2),char(182),char(255),char(236),char(2),char(135),char(2),char(188), -char(255),char(215),char(2),char(135),char(2),char(190),char(255),char(236),char(2),char(135), -char(2),char(192),char(255),char(236),char(2),char(135),char(2),char(194),char(255),char(236), -char(2),char(135),char(2),char(203),char(255),char(215),char(2),char(135),char(2),char(213), -char(255),char(236),char(2),char(135),char(2),char(230),char(255),char(215),char(2),char(135), -char(2),char(248),char(255),char(236),char(2),char(135),char(2),char(250),char(255),char(236), -char(2),char(135),char(2),char(252),char(255),char(236),char(2),char(135),char(2),char(254), -char(255),char(236),char(2),char(135),char(3),char(6),char(255),char(215),char(2),char(135), -char(3),char(8),char(255),char(215),char(2),char(135),char(3),char(14),char(255),char(236), -char(2),char(135),char(3),char(16),char(255),char(236),char(2),char(135),char(3),char(24), -char(255),char(236),char(2),char(136),char(0),char(15),char(255),char(174),char(2),char(136), -char(0),char(17),char(255),char(174),char(2),char(136),char(1),char(157),char(255),char(236), -char(2),char(136),char(1),char(164),char(255),char(215),char(2),char(136),char(1),char(166), -char(255),char(236),char(2),char(136),char(1),char(168),char(255),char(215),char(2),char(136), -char(1),char(170),char(255),char(215),char(2),char(136),char(1),char(174),char(255),char(215), -char(2),char(136),char(1),char(176),char(255),char(215),char(2),char(136),char(1),char(177), -char(255),char(236),char(2),char(136),char(1),char(181),char(255),char(215),char(2),char(136), -char(1),char(188),char(255),char(195),char(2),char(136),char(1),char(189),char(255),char(215), -char(2),char(136),char(1),char(191),char(255),char(215),char(2),char(136),char(1),char(193), -char(255),char(215),char(2),char(136),char(1),char(196),char(255),char(236),char(2),char(136), -char(1),char(199),char(255),char(236),char(2),char(136),char(1),char(206),char(255),char(236), -char(2),char(136),char(1),char(213),char(255),char(236),char(2),char(136),char(1),char(242), -char(255),char(236),char(2),char(136),char(2),char(8),char(255),char(174),char(2),char(136), -char(2),char(12),char(255),char(174),char(2),char(136),char(2),char(114),char(255),char(215), -char(2),char(136),char(2),char(115),char(255),char(236),char(2),char(136),char(2),char(122), -char(255),char(236),char(2),char(136),char(2),char(124),char(255),char(215),char(2),char(136), -char(2),char(128),char(255),char(236),char(2),char(136),char(2),char(130),char(255),char(236), -char(2),char(136),char(2),char(159),char(255),char(215),char(2),char(136),char(2),char(161), -char(255),char(236),char(2),char(136),char(2),char(169),char(255),char(236),char(2),char(136), -char(2),char(181),char(255),char(195),char(2),char(136),char(2),char(183),char(255),char(236), -char(2),char(136),char(2),char(185),char(255),char(236),char(2),char(136),char(2),char(187), -char(255),char(215),char(2),char(136),char(2),char(189),char(255),char(236),char(2),char(136), -char(2),char(191),char(255),char(215),char(2),char(136),char(2),char(193),char(255),char(215), -char(2),char(136),char(2),char(202),char(255),char(215),char(2),char(136),char(2),char(206), -char(255),char(215),char(2),char(136),char(2),char(207),char(255),char(236),char(2),char(136), -char(2),char(212),char(255),char(215),char(2),char(136),char(2),char(217),char(255),char(215), -char(2),char(136),char(2),char(219),char(255),char(215),char(2),char(136),char(2),char(221), -char(255),char(215),char(2),char(136),char(2),char(229),char(255),char(215),char(2),char(136), -char(2),char(231),char(255),char(236),char(2),char(136),char(2),char(245),char(255),char(236), -char(2),char(136),char(2),char(247),char(255),char(215),char(2),char(136),char(2),char(249), -char(255),char(215),char(2),char(136),char(2),char(251),char(255),char(215),char(2),char(136), -char(2),char(253),char(255),char(215),char(2),char(136),char(3),char(5),char(255),char(215), -char(2),char(136),char(3),char(7),char(255),char(215),char(2),char(136),char(3),char(13), -char(255),char(215),char(2),char(136),char(3),char(15),char(255),char(215),char(2),char(136), -char(3),char(17),char(255),char(215),char(2),char(136),char(3),char(18),char(255),char(236), -char(2),char(136),char(3),char(23),char(255),char(236),char(2),char(136),char(3),char(27), -char(255),char(215),char(2),char(136),char(3),char(28),char(255),char(236),char(2),char(137), -char(0),char(5),char(255),char(236),char(2),char(137),char(0),char(10),char(255),char(236), -char(2),char(137),char(1),char(208),char(255),char(215),char(2),char(137),char(1),char(220), -char(255),char(236),char(2),char(137),char(1),char(221),char(255),char(236),char(2),char(137), -char(1),char(223),char(255),char(215),char(2),char(137),char(1),char(225),char(255),char(236), -char(2),char(137),char(1),char(228),char(255),char(236),char(2),char(137),char(1),char(246), -char(255),char(236),char(2),char(137),char(2),char(7),char(255),char(236),char(2),char(137), -char(2),char(11),char(255),char(236),char(2),char(137),char(2),char(160),char(255),char(215), -char(2),char(137),char(2),char(170),char(255),char(236),char(2),char(137),char(2),char(182), -char(255),char(236),char(2),char(137),char(2),char(188),char(255),char(215),char(2),char(137), -char(2),char(190),char(255),char(236),char(2),char(137),char(2),char(192),char(255),char(236), -char(2),char(137),char(2),char(194),char(255),char(236),char(2),char(137),char(2),char(203), -char(255),char(215),char(2),char(137),char(2),char(213),char(255),char(236),char(2),char(137), -char(2),char(230),char(255),char(215),char(2),char(137),char(2),char(248),char(255),char(236), -char(2),char(137),char(2),char(250),char(255),char(236),char(2),char(137),char(2),char(252), -char(255),char(236),char(2),char(137),char(2),char(254),char(255),char(236),char(2),char(137), -char(3),char(6),char(255),char(215),char(2),char(137),char(3),char(8),char(255),char(215), -char(2),char(137),char(3),char(14),char(255),char(236),char(2),char(137),char(3),char(16), -char(255),char(236),char(2),char(137),char(3),char(24),char(255),char(236),char(2),char(138), -char(0),char(15),char(255),char(174),char(2),char(138),char(0),char(17),char(255),char(174), -char(2),char(138),char(1),char(157),char(255),char(236),char(2),char(138),char(1),char(164), -char(255),char(215),char(2),char(138),char(1),char(166),char(255),char(236),char(2),char(138), -char(1),char(168),char(255),char(215),char(2),char(138),char(1),char(170),char(255),char(215), -char(2),char(138),char(1),char(174),char(255),char(215),char(2),char(138),char(1),char(176), -char(255),char(215),char(2),char(138),char(1),char(177),char(255),char(236),char(2),char(138), -char(1),char(181),char(255),char(215),char(2),char(138),char(1),char(188),char(255),char(195), -char(2),char(138),char(1),char(189),char(255),char(215),char(2),char(138),char(1),char(191), -char(255),char(215),char(2),char(138),char(1),char(193),char(255),char(215),char(2),char(138), -char(1),char(196),char(255),char(236),char(2),char(138),char(1),char(199),char(255),char(236), -char(2),char(138),char(1),char(206),char(255),char(236),char(2),char(138),char(1),char(213), -char(255),char(236),char(2),char(138),char(1),char(242),char(255),char(236),char(2),char(138), -char(2),char(8),char(255),char(174),char(2),char(138),char(2),char(12),char(255),char(174), -char(2),char(138),char(2),char(114),char(255),char(215),char(2),char(138),char(2),char(115), -char(255),char(236),char(2),char(138),char(2),char(122),char(255),char(236),char(2),char(138), -char(2),char(124),char(255),char(215),char(2),char(138),char(2),char(128),char(255),char(236), -char(2),char(138),char(2),char(130),char(255),char(236),char(2),char(138),char(2),char(159), -char(255),char(215),char(2),char(138),char(2),char(161),char(255),char(236),char(2),char(138), -char(2),char(169),char(255),char(236),char(2),char(138),char(2),char(181),char(255),char(195), -char(2),char(138),char(2),char(183),char(255),char(236),char(2),char(138),char(2),char(185), -char(255),char(236),char(2),char(138),char(2),char(187),char(255),char(215),char(2),char(138), -char(2),char(189),char(255),char(236),char(2),char(138),char(2),char(191),char(255),char(215), -char(2),char(138),char(2),char(193),char(255),char(215),char(2),char(138),char(2),char(202), -char(255),char(215),char(2),char(138),char(2),char(206),char(255),char(215),char(2),char(138), -char(2),char(207),char(255),char(236),char(2),char(138),char(2),char(212),char(255),char(215), -char(2),char(138),char(2),char(217),char(255),char(215),char(2),char(138),char(2),char(219), -char(255),char(215),char(2),char(138),char(2),char(221),char(255),char(215),char(2),char(138), -char(2),char(229),char(255),char(215),char(2),char(138),char(2),char(231),char(255),char(236), -char(2),char(138),char(2),char(245),char(255),char(236),char(2),char(138),char(2),char(247), -char(255),char(215),char(2),char(138),char(2),char(249),char(255),char(215),char(2),char(138), -char(2),char(251),char(255),char(215),char(2),char(138),char(2),char(253),char(255),char(215), -char(2),char(138),char(3),char(5),char(255),char(215),char(2),char(138),char(3),char(7), -char(255),char(215),char(2),char(138),char(3),char(13),char(255),char(215),char(2),char(138), -char(3),char(15),char(255),char(215),char(2),char(138),char(3),char(17),char(255),char(215), -char(2),char(138),char(3),char(18),char(255),char(236),char(2),char(138),char(3),char(23), -char(255),char(236),char(2),char(138),char(3),char(27),char(255),char(215),char(2),char(138), -char(3),char(28),char(255),char(236),char(2),char(139),char(0),char(15),char(255),char(174), -char(2),char(139),char(0),char(17),char(255),char(174),char(2),char(139),char(1),char(206), -char(255),char(215),char(2),char(139),char(1),char(213),char(255),char(215),char(2),char(139), -char(1),char(242),char(255),char(215),char(2),char(139),char(2),char(8),char(255),char(174), -char(2),char(139),char(2),char(12),char(255),char(174),char(2),char(139),char(2),char(115), -char(255),char(215),char(2),char(139),char(2),char(207),char(255),char(215),char(2),char(139), -char(3),char(18),char(255),char(215),char(2),char(139),char(3),char(28),char(255),char(215), -char(2),char(140),char(1),char(159),char(255),char(215),char(2),char(140),char(1),char(184), -char(255),char(215),char(2),char(140),char(1),char(187),char(255),char(215),char(2),char(140), -char(1),char(190),char(255),char(215),char(2),char(140),char(1),char(225),char(255),char(215), -char(2),char(140),char(2),char(108),char(255),char(215),char(2),char(140),char(2),char(126), -char(255),char(215),char(2),char(140),char(2),char(132),char(255),char(215),char(2),char(140), -char(2),char(134),char(255),char(215),char(2),char(140),char(2),char(136),char(255),char(215), -char(2),char(140),char(2),char(138),char(255),char(215),char(2),char(140),char(2),char(140), -char(255),char(215),char(2),char(140),char(2),char(177),char(255),char(215),char(2),char(140), -char(2),char(179),char(255),char(215),char(2),char(140),char(2),char(192),char(255),char(215), -char(2),char(140),char(2),char(194),char(255),char(215),char(2),char(140),char(2),char(197), -char(255),char(215),char(2),char(140),char(2),char(199),char(255),char(215),char(2),char(140), -char(2),char(213),char(255),char(215),char(2),char(140),char(2),char(239),char(255),char(215), -char(2),char(140),char(2),char(241),char(255),char(215),char(2),char(140),char(2),char(243), -char(255),char(215),char(2),char(140),char(2),char(254),char(255),char(215),char(2),char(140), -char(3),char(9),char(255),char(215),char(2),char(140),char(3),char(11),char(255),char(215), -char(2),char(140),char(3),char(14),char(255),char(215),char(2),char(140),char(3),char(16), -char(255),char(215),char(2),char(140),char(3),char(21),char(255),char(215),char(2),char(149), -char(1),char(163),char(0),char(225),char(2),char(149),char(2),char(234),char(0),char(41), -char(2),char(149),char(3),char(14),char(255),char(215),char(2),char(149),char(3),char(16), -char(255),char(215),char(2),char(150),char(0),char(5),char(255),char(236),char(2),char(150), -char(0),char(10),char(255),char(236),char(2),char(150),char(2),char(7),char(255),char(236), -char(2),char(150),char(2),char(11),char(255),char(236),char(2),char(151),char(0),char(5), -char(255),char(174),char(2),char(151),char(0),char(10),char(255),char(174),char(2),char(151), -char(1),char(157),char(255),char(215),char(2),char(151),char(1),char(166),char(255),char(215), -char(2),char(151),char(1),char(188),char(255),char(174),char(2),char(151),char(1),char(193), -char(255),char(174),char(2),char(151),char(1),char(196),char(255),char(215),char(2),char(151), -char(1),char(220),char(255),char(215),char(2),char(151),char(1),char(228),char(255),char(215), -char(2),char(151),char(2),char(7),char(255),char(174),char(2),char(151),char(2),char(11), -char(255),char(174),char(2),char(151),char(2),char(124),char(255),char(174),char(2),char(151), -char(2),char(128),char(255),char(195),char(2),char(151),char(2),char(130),char(255),char(195), -char(2),char(151),char(2),char(169),char(255),char(215),char(2),char(151),char(2),char(170), -char(255),char(215),char(2),char(151),char(2),char(181),char(255),char(174),char(2),char(151), -char(2),char(182),char(255),char(215),char(2),char(151),char(2),char(183),char(255),char(195), -char(2),char(151),char(2),char(185),char(255),char(195),char(2),char(151),char(2),char(189), -char(255),char(215),char(2),char(151),char(2),char(190),char(255),char(215),char(2),char(151), -char(2),char(191),char(255),char(174),char(2),char(151),char(2),char(193),char(255),char(174), -char(2),char(151),char(2),char(212),char(255),char(174),char(2),char(151),char(2),char(253), -char(255),char(174),char(2),char(151),char(3),char(13),char(255),char(154),char(2),char(151), -char(3),char(15),char(255),char(154),char(2),char(151),char(3),char(23),char(255),char(215), -char(2),char(151),char(3),char(24),char(255),char(215),char(2),char(152),char(0),char(5), -char(255),char(133),char(2),char(152),char(0),char(10),char(255),char(133),char(2),char(152), -char(1),char(208),char(255),char(215),char(2),char(152),char(1),char(220),char(255),char(154), -char(2),char(152),char(1),char(221),char(255),char(195),char(2),char(152),char(1),char(223), -char(255),char(215),char(2),char(152),char(1),char(225),char(255),char(174),char(2),char(152), -char(1),char(228),char(255),char(154),char(2),char(152),char(1),char(246),char(255),char(195), -char(2),char(152),char(2),char(7),char(255),char(133),char(2),char(152),char(2),char(11), -char(255),char(133),char(2),char(152),char(2),char(109),char(255),char(215),char(2),char(152), -char(2),char(129),char(255),char(215),char(2),char(152),char(2),char(131),char(255),char(215), -char(2),char(152),char(2),char(139),char(255),char(215),char(2),char(152),char(2),char(160), -char(255),char(215),char(2),char(152),char(2),char(170),char(255),char(154),char(2),char(152), -char(2),char(182),char(255),char(154),char(2),char(152),char(2),char(184),char(255),char(195), -char(2),char(152),char(2),char(186),char(255),char(195),char(2),char(152),char(2),char(188), -char(255),char(215),char(2),char(152),char(2),char(190),char(255),char(154),char(2),char(152), -char(2),char(192),char(255),char(174),char(2),char(152),char(2),char(194),char(255),char(174), -char(2),char(152),char(2),char(198),char(255),char(215),char(2),char(152),char(2),char(200), -char(255),char(215),char(2),char(152),char(2),char(203),char(255),char(215),char(2),char(152), -char(2),char(213),char(255),char(174),char(2),char(152),char(2),char(230),char(255),char(215), -char(2),char(152),char(2),char(234),char(255),char(215),char(2),char(152),char(2),char(248), -char(255),char(195),char(2),char(152),char(2),char(250),char(255),char(195),char(2),char(152), -char(2),char(252),char(255),char(195),char(2),char(152),char(2),char(254),char(255),char(174), -char(2),char(152),char(3),char(6),char(255),char(215),char(2),char(152),char(3),char(8), -char(255),char(215),char(2),char(152),char(3),char(14),char(255),char(154),char(2),char(152), -char(3),char(16),char(255),char(154),char(2),char(152),char(3),char(24),char(255),char(154), -char(2),char(153),char(0),char(15),char(254),char(246),char(2),char(153),char(0),char(17), -char(254),char(246),char(2),char(153),char(1),char(164),char(255),char(133),char(2),char(153), -char(1),char(170),char(255),char(154),char(2),char(153),char(1),char(174),char(255),char(133), -char(2),char(153),char(1),char(176),char(255),char(215),char(2),char(153),char(1),char(181), -char(255),char(133),char(2),char(153),char(1),char(191),char(255),char(215),char(2),char(153), -char(1),char(206),char(255),char(154),char(2),char(153),char(1),char(213),char(255),char(154), -char(2),char(153),char(1),char(242),char(255),char(154),char(2),char(153),char(2),char(8), -char(254),char(246),char(2),char(153),char(2),char(12),char(254),char(246),char(2),char(153), -char(2),char(114),char(255),char(154),char(2),char(153),char(2),char(115),char(255),char(154), -char(2),char(153),char(2),char(118),char(255),char(236),char(2),char(153),char(2),char(159), -char(255),char(215),char(2),char(153),char(2),char(187),char(255),char(215),char(2),char(153), -char(2),char(202),char(255),char(215),char(2),char(153),char(2),char(206),char(255),char(133), -char(2),char(153),char(2),char(207),char(255),char(154),char(2),char(153),char(2),char(217), -char(255),char(154),char(2),char(153),char(2),char(219),char(255),char(154),char(2),char(153), -char(2),char(221),char(255),char(154),char(2),char(153),char(2),char(229),char(255),char(215), -char(2),char(153),char(3),char(5),char(255),char(215),char(2),char(153),char(3),char(7), -char(255),char(215),char(2),char(153),char(3),char(9),char(255),char(174),char(2),char(153), -char(3),char(11),char(255),char(174),char(2),char(153),char(3),char(17),char(255),char(133), -char(2),char(153),char(3),char(18),char(255),char(154),char(2),char(153),char(3),char(27), -char(255),char(133),char(2),char(153),char(3),char(28),char(255),char(154),char(2),char(154), -char(0),char(5),char(255),char(236),char(2),char(154),char(0),char(10),char(255),char(236), -char(2),char(154),char(1),char(208),char(255),char(215),char(2),char(154),char(1),char(220), -char(255),char(236),char(2),char(154),char(1),char(221),char(255),char(236),char(2),char(154), -char(1),char(223),char(255),char(215),char(2),char(154),char(1),char(225),char(255),char(236), -char(2),char(154),char(1),char(228),char(255),char(236),char(2),char(154),char(1),char(246), -char(255),char(236),char(2),char(154),char(2),char(7),char(255),char(236),char(2),char(154), -char(2),char(11),char(255),char(236),char(2),char(154),char(2),char(160),char(255),char(215), -char(2),char(154),char(2),char(170),char(255),char(236),char(2),char(154),char(2),char(182), -char(255),char(236),char(2),char(154),char(2),char(188),char(255),char(215),char(2),char(154), -char(2),char(190),char(255),char(236),char(2),char(154),char(2),char(192),char(255),char(236), -char(2),char(154),char(2),char(194),char(255),char(236),char(2),char(154),char(2),char(203), -char(255),char(215),char(2),char(154),char(2),char(213),char(255),char(236),char(2),char(154), -char(2),char(230),char(255),char(215),char(2),char(154),char(2),char(248),char(255),char(236), -char(2),char(154),char(2),char(250),char(255),char(236),char(2),char(154),char(2),char(252), -char(255),char(236),char(2),char(154),char(2),char(254),char(255),char(236),char(2),char(154), -char(3),char(6),char(255),char(215),char(2),char(154),char(3),char(8),char(255),char(215), -char(2),char(154),char(3),char(14),char(255),char(236),char(2),char(154),char(3),char(16), -char(255),char(236),char(2),char(154),char(3),char(24),char(255),char(236),char(2),char(155), -char(0),char(15),char(255),char(154),char(2),char(155),char(0),char(16),char(255),char(215), -char(2),char(155),char(0),char(17),char(255),char(154),char(2),char(155),char(1),char(157), -char(0),char(41),char(2),char(155),char(1),char(159),char(255),char(215),char(2),char(155), -char(1),char(164),char(255),char(174),char(2),char(155),char(1),char(166),char(0),char(41), -char(2),char(155),char(1),char(170),char(255),char(133),char(2),char(155),char(1),char(174), -char(255),char(174),char(2),char(155),char(1),char(181),char(255),char(174),char(2),char(155), -char(1),char(184),char(255),char(215),char(2),char(155),char(1),char(187),char(255),char(215), -char(2),char(155),char(1),char(188),char(0),char(41),char(2),char(155),char(1),char(190), -char(255),char(195),char(2),char(155),char(1),char(196),char(0),char(41),char(2),char(155), -char(1),char(204),char(255),char(195),char(2),char(155),char(1),char(205),char(255),char(195), -char(2),char(155),char(1),char(206),char(255),char(154),char(2),char(155),char(1),char(207), -char(255),char(174),char(2),char(155),char(1),char(208),char(255),char(215),char(2),char(155), -char(1),char(209),char(255),char(215),char(2),char(155),char(1),char(210),char(255),char(195), -char(2),char(155),char(1),char(211),char(255),char(195),char(2),char(155),char(1),char(212), -char(255),char(195),char(2),char(155),char(1),char(213),char(255),char(154),char(2),char(155), -char(1),char(214),char(255),char(195),char(2),char(155),char(1),char(215),char(255),char(195), -char(2),char(155),char(1),char(216),char(255),char(174),char(2),char(155),char(1),char(217), -char(255),char(195),char(2),char(155),char(1),char(218),char(255),char(195),char(2),char(155), -char(1),char(219),char(255),char(174),char(2),char(155),char(1),char(222),char(255),char(174), -char(2),char(155),char(1),char(223),char(255),char(215),char(2),char(155),char(1),char(224), -char(255),char(195),char(2),char(155),char(1),char(225),char(255),char(154),char(2),char(155), -char(1),char(226),char(255),char(195),char(2),char(155),char(1),char(227),char(255),char(195), -char(2),char(155),char(1),char(229),char(255),char(195),char(2),char(155),char(1),char(230), -char(255),char(195),char(2),char(155),char(1),char(231),char(255),char(215),char(2),char(155), -char(1),char(232),char(255),char(195),char(2),char(155),char(1),char(234),char(255),char(174), -char(2),char(155),char(1),char(235),char(0),char(41),char(2),char(155),char(1),char(236), -char(255),char(195),char(2),char(155),char(1),char(237),char(255),char(174),char(2),char(155), -char(1),char(238),char(255),char(195),char(2),char(155),char(1),char(242),char(255),char(154), -char(2),char(155),char(1),char(243),char(255),char(195),char(2),char(155),char(1),char(244), -char(0),char(41),char(2),char(155),char(1),char(245),char(255),char(195),char(2),char(155), -char(1),char(247),char(255),char(195),char(2),char(155),char(1),char(249),char(255),char(195), -char(2),char(155),char(2),char(2),char(255),char(215),char(2),char(155),char(2),char(3), -char(255),char(215),char(2),char(155),char(2),char(4),char(255),char(215),char(2),char(155), -char(2),char(8),char(255),char(154),char(2),char(155),char(2),char(12),char(255),char(154), -char(2),char(155),char(2),char(106),char(255),char(174),char(2),char(155),char(2),char(107), -char(255),char(195),char(2),char(155),char(2),char(108),char(255),char(215),char(2),char(155), -char(2),char(113),char(255),char(195),char(2),char(155),char(2),char(114),char(255),char(133), -char(2),char(155),char(2),char(115),char(255),char(154),char(2),char(155),char(2),char(117), -char(255),char(195),char(2),char(155),char(2),char(119),char(255),char(215),char(2),char(155), -char(2),char(121),char(255),char(195),char(2),char(155),char(2),char(125),char(255),char(195), -char(2),char(155),char(2),char(126),char(255),char(215),char(2),char(155),char(2),char(127), -char(255),char(174),char(2),char(155),char(2),char(132),char(255),char(215),char(2),char(155), -char(2),char(133),char(255),char(174),char(2),char(155),char(2),char(134),char(255),char(215), -char(2),char(155),char(2),char(135),char(255),char(174),char(2),char(155),char(2),char(136), -char(255),char(215),char(2),char(155),char(2),char(137),char(255),char(174),char(2),char(155), -char(2),char(138),char(255),char(215),char(2),char(155),char(2),char(140),char(255),char(215), -char(2),char(155),char(2),char(141),char(255),char(174),char(2),char(155),char(2),char(150), -char(255),char(195),char(2),char(155),char(2),char(152),char(0),char(41),char(2),char(155), -char(2),char(154),char(255),char(195),char(2),char(155),char(2),char(158),char(255),char(195), -char(2),char(155),char(2),char(160),char(255),char(215),char(2),char(155),char(2),char(162), -char(255),char(215),char(2),char(155),char(2),char(164),char(255),char(195),char(2),char(155), -char(2),char(166),char(255),char(195),char(2),char(155),char(2),char(168),char(0),char(41), -char(2),char(155),char(2),char(169),char(0),char(41),char(2),char(155),char(2),char(172), -char(255),char(195),char(2),char(155),char(2),char(174),char(255),char(195),char(2),char(155), -char(2),char(176),char(255),char(195),char(2),char(155),char(2),char(177),char(255),char(215), -char(2),char(155),char(2),char(178),char(255),char(174),char(2),char(155),char(2),char(179), -char(255),char(215),char(2),char(155),char(2),char(180),char(255),char(174),char(2),char(155), -char(2),char(181),char(0),char(41),char(2),char(155),char(2),char(188),char(255),char(215), -char(2),char(155),char(2),char(189),char(0),char(41),char(2),char(155),char(2),char(192), -char(255),char(154),char(2),char(155),char(2),char(194),char(255),char(154),char(2),char(155), -char(2),char(196),char(255),char(195),char(2),char(155),char(2),char(197),char(255),char(215), -char(2),char(155),char(2),char(198),char(255),char(195),char(2),char(155),char(2),char(199), -char(255),char(215),char(2),char(155),char(2),char(200),char(255),char(195),char(2),char(155), -char(2),char(203),char(255),char(215),char(2),char(155),char(2),char(205),char(255),char(195), -char(2),char(155),char(2),char(206),char(255),char(174),char(2),char(155),char(2),char(207), -char(255),char(154),char(2),char(155),char(2),char(209),char(255),char(195),char(2),char(155), -char(2),char(211),char(255),char(195),char(2),char(155),char(2),char(213),char(255),char(154), -char(2),char(155),char(2),char(215),char(255),char(195),char(2),char(155),char(2),char(217), -char(255),char(133),char(2),char(155),char(2),char(219),char(255),char(133),char(2),char(155), -char(2),char(221),char(255),char(133),char(2),char(155),char(2),char(224),char(255),char(174), -char(2),char(155),char(2),char(230),char(255),char(215),char(2),char(155),char(2),char(232), -char(255),char(215),char(2),char(155),char(2),char(236),char(255),char(195),char(2),char(155), -char(2),char(238),char(255),char(195),char(2),char(155),char(2),char(239),char(255),char(215), -char(2),char(155),char(2),char(240),char(255),char(174),char(2),char(155),char(2),char(241), -char(255),char(215),char(2),char(155),char(2),char(242),char(255),char(174),char(2),char(155), -char(2),char(243),char(255),char(215),char(2),char(155),char(2),char(244),char(255),char(174), -char(2),char(155),char(2),char(246),char(255),char(215),char(2),char(155),char(2),char(254), -char(255),char(154),char(2),char(155),char(3),char(0),char(255),char(195),char(2),char(155), -char(3),char(2),char(255),char(195),char(2),char(155),char(3),char(6),char(255),char(215), -char(2),char(155),char(3),char(8),char(255),char(215),char(2),char(155),char(3),char(9), -char(255),char(154),char(2),char(155),char(3),char(10),char(255),char(174),char(2),char(155), -char(3),char(11),char(255),char(154),char(2),char(155),char(3),char(12),char(255),char(174), -char(2),char(155),char(3),char(14),char(255),char(215),char(2),char(155),char(3),char(16), -char(255),char(215),char(2),char(155),char(3),char(17),char(255),char(174),char(2),char(155), -char(3),char(18),char(255),char(154),char(2),char(155),char(3),char(20),char(255),char(195), -char(2),char(155),char(3),char(21),char(255),char(215),char(2),char(155),char(3),char(22), -char(255),char(174),char(2),char(155),char(3),char(23),char(0),char(41),char(2),char(155), -char(3),char(26),char(255),char(174),char(2),char(155),char(3),char(27),char(255),char(174), -char(2),char(155),char(3),char(28),char(255),char(154),char(2),char(156),char(0),char(15), -char(255),char(195),char(2),char(156),char(0),char(17),char(255),char(195),char(2),char(156), -char(1),char(206),char(255),char(195),char(2),char(156),char(1),char(207),char(255),char(215), -char(2),char(156),char(1),char(213),char(255),char(195),char(2),char(156),char(1),char(216), -char(255),char(215),char(2),char(156),char(1),char(219),char(255),char(215),char(2),char(156), -char(1),char(222),char(255),char(215),char(2),char(156),char(1),char(234),char(255),char(215), -char(2),char(156),char(1),char(237),char(255),char(215),char(2),char(156),char(1),char(242), -char(255),char(195),char(2),char(156),char(2),char(8),char(255),char(195),char(2),char(156), -char(2),char(12),char(255),char(195),char(2),char(156),char(2),char(106),char(255),char(215), -char(2),char(156),char(2),char(115),char(255),char(195),char(2),char(156),char(2),char(127), -char(255),char(215),char(2),char(156),char(2),char(133),char(255),char(215),char(2),char(156), -char(2),char(135),char(255),char(215),char(2),char(156),char(2),char(137),char(255),char(215), -char(2),char(156),char(2),char(141),char(255),char(215),char(2),char(156),char(2),char(178), -char(255),char(215),char(2),char(156),char(2),char(180),char(255),char(215),char(2),char(156), -char(2),char(207),char(255),char(195),char(2),char(156),char(2),char(224),char(255),char(215), -char(2),char(156),char(2),char(240),char(255),char(215),char(2),char(156),char(2),char(242), -char(255),char(215),char(2),char(156),char(2),char(244),char(255),char(215),char(2),char(156), -char(3),char(10),char(255),char(215),char(2),char(156),char(3),char(12),char(255),char(215), -char(2),char(156),char(3),char(18),char(255),char(195),char(2),char(156),char(3),char(22), -char(255),char(215),char(2),char(156),char(3),char(26),char(255),char(215),char(2),char(156), -char(3),char(28),char(255),char(195),char(2),char(157),char(0),char(5),char(255),char(195), -char(2),char(157),char(0),char(10),char(255),char(195),char(2),char(157),char(1),char(157), -char(255),char(195),char(2),char(157),char(1),char(163),char(0),char(102),char(2),char(157), -char(1),char(166),char(255),char(195),char(2),char(157),char(1),char(188),char(255),char(195), -char(2),char(157),char(1),char(193),char(255),char(174),char(2),char(157),char(1),char(196), -char(255),char(195),char(2),char(157),char(1),char(220),char(255),char(215),char(2),char(157), -char(1),char(225),char(255),char(215),char(2),char(157),char(1),char(228),char(255),char(215), -char(2),char(157),char(2),char(7),char(255),char(195),char(2),char(157),char(2),char(11), -char(255),char(195),char(2),char(157),char(2),char(124),char(255),char(174),char(2),char(157), -char(2),char(128),char(255),char(195),char(2),char(157),char(2),char(130),char(255),char(195), -char(2),char(157),char(2),char(169),char(255),char(195),char(2),char(157),char(2),char(170), -char(255),char(215),char(2),char(157),char(2),char(181),char(255),char(195),char(2),char(157), -char(2),char(182),char(255),char(215),char(2),char(157),char(2),char(183),char(255),char(215), -char(2),char(157),char(2),char(185),char(255),char(215),char(2),char(157),char(2),char(189), -char(255),char(195),char(2),char(157),char(2),char(190),char(255),char(215),char(2),char(157), -char(2),char(191),char(255),char(174),char(2),char(157),char(2),char(192),char(255),char(215), -char(2),char(157),char(2),char(193),char(255),char(174),char(2),char(157),char(2),char(194), -char(255),char(215),char(2),char(157),char(2),char(212),char(255),char(174),char(2),char(157), -char(2),char(213),char(255),char(215),char(2),char(157),char(2),char(253),char(255),char(174), -char(2),char(157),char(2),char(254),char(255),char(215),char(2),char(157),char(3),char(13), -char(255),char(215),char(2),char(157),char(3),char(14),char(255),char(195),char(2),char(157), -char(3),char(15),char(255),char(215),char(2),char(157),char(3),char(16),char(255),char(195), -char(2),char(157),char(3),char(23),char(255),char(195),char(2),char(157),char(3),char(24), -char(255),char(215),char(2),char(158),char(0),char(5),char(255),char(195),char(2),char(158), -char(0),char(10),char(255),char(195),char(2),char(158),char(2),char(7),char(255),char(195), -char(2),char(158),char(2),char(11),char(255),char(195),char(2),char(158),char(3),char(14), -char(255),char(215),char(2),char(158),char(3),char(16),char(255),char(215),char(2),char(159), -char(1),char(159),char(255),char(215),char(2),char(159),char(1),char(163),char(0),char(225), -char(2),char(159),char(1),char(184),char(255),char(215),char(2),char(159),char(1),char(187), -char(255),char(215),char(2),char(159),char(1),char(190),char(255),char(195),char(2),char(159), -char(1),char(220),char(255),char(215),char(2),char(159),char(1),char(225),char(255),char(174), -char(2),char(159),char(1),char(228),char(255),char(215),char(2),char(159),char(2),char(108), -char(255),char(215),char(2),char(159),char(2),char(123),char(0),char(61),char(2),char(159), -char(2),char(125),char(255),char(236),char(2),char(159),char(2),char(126),char(255),char(215), -char(2),char(159),char(2),char(132),char(255),char(215),char(2),char(159),char(2),char(134), -char(255),char(215),char(2),char(159),char(2),char(136),char(255),char(215),char(2),char(159), -char(2),char(138),char(255),char(215),char(2),char(159),char(2),char(140),char(255),char(215), -char(2),char(159),char(2),char(170),char(255),char(215),char(2),char(159),char(2),char(177), -char(255),char(215),char(2),char(159),char(2),char(179),char(255),char(215),char(2),char(159), -char(2),char(182),char(255),char(215),char(2),char(159),char(2),char(190),char(255),char(215), -char(2),char(159),char(2),char(192),char(255),char(174),char(2),char(159),char(2),char(194), -char(255),char(174),char(2),char(159),char(2),char(197),char(255),char(195),char(2),char(159), -char(2),char(198),char(255),char(215),char(2),char(159),char(2),char(199),char(255),char(195), -char(2),char(159),char(2),char(200),char(255),char(215),char(2),char(159),char(2),char(213), -char(255),char(174),char(2),char(159),char(2),char(239),char(255),char(215),char(2),char(159), -char(2),char(241),char(255),char(215),char(2),char(159),char(2),char(243),char(255),char(215), -char(2),char(159),char(2),char(254),char(255),char(174),char(2),char(159),char(3),char(14), -char(255),char(215),char(2),char(159),char(3),char(16),char(255),char(215),char(2),char(159), -char(3),char(21),char(255),char(215),char(2),char(159),char(3),char(24),char(255),char(215), -char(2),char(160),char(1),char(207),char(255),char(236),char(2),char(160),char(1),char(216), -char(255),char(236),char(2),char(160),char(1),char(219),char(255),char(236),char(2),char(160), -char(1),char(222),char(255),char(236),char(2),char(160),char(1),char(225),char(255),char(236), -char(2),char(160),char(1),char(234),char(255),char(236),char(2),char(160),char(1),char(237), -char(255),char(236),char(2),char(160),char(2),char(106),char(255),char(236),char(2),char(160), -char(2),char(127),char(255),char(236),char(2),char(160),char(2),char(133),char(255),char(236), -char(2),char(160),char(2),char(135),char(255),char(236),char(2),char(160),char(2),char(137), -char(255),char(236),char(2),char(160),char(2),char(141),char(255),char(236),char(2),char(160), -char(2),char(178),char(255),char(236),char(2),char(160),char(2),char(180),char(255),char(236), -char(2),char(160),char(2),char(192),char(255),char(236),char(2),char(160),char(2),char(194), -char(255),char(236),char(2),char(160),char(2),char(213),char(255),char(236),char(2),char(160), -char(2),char(224),char(255),char(236),char(2),char(160),char(2),char(240),char(255),char(236), -char(2),char(160),char(2),char(242),char(255),char(236),char(2),char(160),char(2),char(244), -char(255),char(236),char(2),char(160),char(2),char(254),char(255),char(236),char(2),char(160), -char(3),char(10),char(255),char(236),char(2),char(160),char(3),char(12),char(255),char(236), -char(2),char(160),char(3),char(14),char(255),char(215),char(2),char(160),char(3),char(16), -char(255),char(215),char(2),char(160),char(3),char(22),char(255),char(236),char(2),char(160), -char(3),char(26),char(255),char(236),char(2),char(161),char(0),char(15),char(255),char(174), -char(2),char(161),char(0),char(17),char(255),char(174),char(2),char(161),char(2),char(8), -char(255),char(174),char(2),char(161),char(2),char(12),char(255),char(174),char(2),char(161), -char(2),char(128),char(255),char(236),char(2),char(161),char(2),char(130),char(255),char(236), -char(2),char(161),char(2),char(183),char(255),char(236),char(2),char(161),char(2),char(185), -char(255),char(236),char(2),char(161),char(3),char(13),char(255),char(215),char(2),char(161), -char(3),char(15),char(255),char(215),char(2),char(162),char(1),char(233),char(0),char(41), -char(2),char(163),char(1),char(159),char(255),char(215),char(2),char(163),char(1),char(163), -char(0),char(225),char(2),char(163),char(1),char(184),char(255),char(215),char(2),char(163), -char(1),char(187),char(255),char(215),char(2),char(163),char(1),char(190),char(255),char(195), -char(2),char(163),char(1),char(220),char(255),char(215),char(2),char(163),char(1),char(225), -char(255),char(174),char(2),char(163),char(1),char(228),char(255),char(215),char(2),char(163), -char(2),char(108),char(255),char(215),char(2),char(163),char(2),char(123),char(0),char(61), -char(2),char(163),char(2),char(125),char(255),char(236),char(2),char(163),char(2),char(126), -char(255),char(215),char(2),char(163),char(2),char(132),char(255),char(215),char(2),char(163), -char(2),char(134),char(255),char(215),char(2),char(163),char(2),char(136),char(255),char(215), -char(2),char(163),char(2),char(138),char(255),char(215),char(2),char(163),char(2),char(140), -char(255),char(215),char(2),char(163),char(2),char(170),char(255),char(215),char(2),char(163), -char(2),char(177),char(255),char(215),char(2),char(163),char(2),char(179),char(255),char(215), -char(2),char(163),char(2),char(182),char(255),char(215),char(2),char(163),char(2),char(190), -char(255),char(215),char(2),char(163),char(2),char(192),char(255),char(174),char(2),char(163), -char(2),char(194),char(255),char(174),char(2),char(163),char(2),char(197),char(255),char(195), -char(2),char(163),char(2),char(198),char(255),char(215),char(2),char(163),char(2),char(199), -char(255),char(195),char(2),char(163),char(2),char(200),char(255),char(215),char(2),char(163), -char(2),char(213),char(255),char(174),char(2),char(163),char(2),char(239),char(255),char(215), -char(2),char(163),char(2),char(241),char(255),char(215),char(2),char(163),char(2),char(243), -char(255),char(215),char(2),char(163),char(2),char(254),char(255),char(174),char(2),char(163), -char(3),char(14),char(255),char(215),char(2),char(163),char(3),char(16),char(255),char(215), -char(2),char(163),char(3),char(21),char(255),char(215),char(2),char(163),char(3),char(24), -char(255),char(215),char(2),char(164),char(1),char(207),char(255),char(236),char(2),char(164), -char(1),char(216),char(255),char(236),char(2),char(164),char(1),char(219),char(255),char(236), -char(2),char(164),char(1),char(222),char(255),char(236),char(2),char(164),char(1),char(225), -char(255),char(236),char(2),char(164),char(1),char(234),char(255),char(236),char(2),char(164), -char(1),char(237),char(255),char(236),char(2),char(164),char(2),char(106),char(255),char(236), -char(2),char(164),char(2),char(127),char(255),char(236),char(2),char(164),char(2),char(133), -char(255),char(236),char(2),char(164),char(2),char(135),char(255),char(236),char(2),char(164), -char(2),char(137),char(255),char(236),char(2),char(164),char(2),char(141),char(255),char(236), -char(2),char(164),char(2),char(178),char(255),char(236),char(2),char(164),char(2),char(180), -char(255),char(236),char(2),char(164),char(2),char(192),char(255),char(236),char(2),char(164), -char(2),char(194),char(255),char(236),char(2),char(164),char(2),char(213),char(255),char(236), -char(2),char(164),char(2),char(224),char(255),char(236),char(2),char(164),char(2),char(240), -char(255),char(236),char(2),char(164),char(2),char(242),char(255),char(236),char(2),char(164), -char(2),char(244),char(255),char(236),char(2),char(164),char(2),char(254),char(255),char(236), -char(2),char(164),char(3),char(10),char(255),char(236),char(2),char(164),char(3),char(12), -char(255),char(236),char(2),char(164),char(3),char(14),char(255),char(215),char(2),char(164), -char(3),char(16),char(255),char(215),char(2),char(164),char(3),char(22),char(255),char(236), -char(2),char(164),char(3),char(26),char(255),char(236),char(2),char(165),char(1),char(159), -char(255),char(215),char(2),char(165),char(1),char(184),char(255),char(215),char(2),char(165), -char(1),char(187),char(255),char(215),char(2),char(165),char(1),char(190),char(255),char(215), -char(2),char(165),char(1),char(193),char(255),char(215),char(2),char(165),char(1),char(225), -char(255),char(215),char(2),char(165),char(2),char(108),char(255),char(215),char(2),char(165), -char(2),char(124),char(255),char(215),char(2),char(165),char(2),char(126),char(255),char(215), -char(2),char(165),char(2),char(132),char(255),char(215),char(2),char(165),char(2),char(134), -char(255),char(215),char(2),char(165),char(2),char(136),char(255),char(215),char(2),char(165), -char(2),char(138),char(255),char(215),char(2),char(165),char(2),char(140),char(255),char(215), -char(2),char(165),char(2),char(177),char(255),char(215),char(2),char(165),char(2),char(179), -char(255),char(215),char(2),char(165),char(2),char(191),char(255),char(215),char(2),char(165), -char(2),char(192),char(255),char(215),char(2),char(165),char(2),char(193),char(255),char(215), -char(2),char(165),char(2),char(194),char(255),char(215),char(2),char(165),char(2),char(197), -char(255),char(154),char(2),char(165),char(2),char(199),char(255),char(154),char(2),char(165), -char(2),char(212),char(255),char(215),char(2),char(165),char(2),char(213),char(255),char(215), -char(2),char(165),char(2),char(239),char(255),char(215),char(2),char(165),char(2),char(241), -char(255),char(215),char(2),char(165),char(2),char(243),char(255),char(215),char(2),char(165), -char(2),char(253),char(255),char(215),char(2),char(165),char(2),char(254),char(255),char(215), -char(2),char(165),char(3),char(9),char(255),char(215),char(2),char(165),char(3),char(11), -char(255),char(215),char(2),char(165),char(3),char(14),char(255),char(215),char(2),char(165), -char(3),char(16),char(255),char(215),char(2),char(165),char(3),char(21),char(255),char(215), -char(2),char(165),char(3),char(25),char(255),char(236),char(2),char(166),char(1),char(207), -char(255),char(215),char(2),char(166),char(1),char(216),char(255),char(215),char(2),char(166), -char(1),char(219),char(255),char(215),char(2),char(166),char(1),char(222),char(255),char(215), -char(2),char(166),char(1),char(225),char(255),char(215),char(2),char(166),char(1),char(234), -char(255),char(215),char(2),char(166),char(1),char(237),char(255),char(215),char(2),char(166), -char(2),char(106),char(255),char(215),char(2),char(166),char(2),char(127),char(255),char(215), -char(2),char(166),char(2),char(133),char(255),char(215),char(2),char(166),char(2),char(135), -char(255),char(215),char(2),char(166),char(2),char(137),char(255),char(215),char(2),char(166), -char(2),char(141),char(255),char(215),char(2),char(166),char(2),char(178),char(255),char(215), -char(2),char(166),char(2),char(180),char(255),char(215),char(2),char(166),char(2),char(192), -char(255),char(215),char(2),char(166),char(2),char(194),char(255),char(215),char(2),char(166), -char(2),char(198),char(255),char(215),char(2),char(166),char(2),char(200),char(255),char(215), -char(2),char(166),char(2),char(213),char(255),char(215),char(2),char(166),char(2),char(224), -char(255),char(215),char(2),char(166),char(2),char(240),char(255),char(215),char(2),char(166), -char(2),char(242),char(255),char(215),char(2),char(166),char(2),char(244),char(255),char(215), -char(2),char(166),char(2),char(254),char(255),char(215),char(2),char(166),char(3),char(10), -char(255),char(215),char(2),char(166),char(3),char(12),char(255),char(215),char(2),char(166), -char(3),char(22),char(255),char(215),char(2),char(166),char(3),char(26),char(255),char(215), -char(2),char(167),char(1),char(159),char(255),char(215),char(2),char(167),char(1),char(184), -char(255),char(215),char(2),char(167),char(1),char(187),char(255),char(215),char(2),char(167), -char(1),char(190),char(255),char(215),char(2),char(167),char(1),char(193),char(255),char(215), -char(2),char(167),char(1),char(225),char(255),char(215),char(2),char(167),char(2),char(108), -char(255),char(215),char(2),char(167),char(2),char(124),char(255),char(215),char(2),char(167), -char(2),char(126),char(255),char(215),char(2),char(167),char(2),char(132),char(255),char(215), -char(2),char(167),char(2),char(134),char(255),char(215),char(2),char(167),char(2),char(136), -char(255),char(215),char(2),char(167),char(2),char(138),char(255),char(215),char(2),char(167), -char(2),char(140),char(255),char(215),char(2),char(167),char(2),char(177),char(255),char(215), -char(2),char(167),char(2),char(179),char(255),char(215),char(2),char(167),char(2),char(191), -char(255),char(215),char(2),char(167),char(2),char(192),char(255),char(215),char(2),char(167), -char(2),char(193),char(255),char(215),char(2),char(167),char(2),char(194),char(255),char(215), -char(2),char(167),char(2),char(197),char(255),char(154),char(2),char(167),char(2),char(199), -char(255),char(154),char(2),char(167),char(2),char(212),char(255),char(215),char(2),char(167), -char(2),char(213),char(255),char(215),char(2),char(167),char(2),char(239),char(255),char(215), -char(2),char(167),char(2),char(241),char(255),char(215),char(2),char(167),char(2),char(243), -char(255),char(215),char(2),char(167),char(2),char(253),char(255),char(215),char(2),char(167), -char(2),char(254),char(255),char(215),char(2),char(167),char(3),char(9),char(255),char(215), -char(2),char(167),char(3),char(11),char(255),char(215),char(2),char(167),char(3),char(14), -char(255),char(215),char(2),char(167),char(3),char(16),char(255),char(215),char(2),char(167), -char(3),char(21),char(255),char(215),char(2),char(167),char(3),char(25),char(255),char(236), -char(2),char(168),char(1),char(207),char(255),char(215),char(2),char(168),char(1),char(216), -char(255),char(215),char(2),char(168),char(1),char(219),char(255),char(215),char(2),char(168), -char(1),char(222),char(255),char(215),char(2),char(168),char(1),char(225),char(255),char(215), -char(2),char(168),char(1),char(234),char(255),char(215),char(2),char(168),char(1),char(237), -char(255),char(215),char(2),char(168),char(2),char(106),char(255),char(215),char(2),char(168), -char(2),char(127),char(255),char(215),char(2),char(168),char(2),char(133),char(255),char(215), -char(2),char(168),char(2),char(135),char(255),char(215),char(2),char(168),char(2),char(137), -char(255),char(215),char(2),char(168),char(2),char(141),char(255),char(215),char(2),char(168), -char(2),char(178),char(255),char(215),char(2),char(168),char(2),char(180),char(255),char(215), -char(2),char(168),char(2),char(192),char(255),char(215),char(2),char(168),char(2),char(194), -char(255),char(215),char(2),char(168),char(2),char(198),char(255),char(215),char(2),char(168), -char(2),char(200),char(255),char(215),char(2),char(168),char(2),char(213),char(255),char(215), -char(2),char(168),char(2),char(224),char(255),char(215),char(2),char(168),char(2),char(240), -char(255),char(215),char(2),char(168),char(2),char(242),char(255),char(215),char(2),char(168), -char(2),char(244),char(255),char(215),char(2),char(168),char(2),char(254),char(255),char(215), -char(2),char(168),char(3),char(10),char(255),char(215),char(2),char(168),char(3),char(12), -char(255),char(215),char(2),char(168),char(3),char(22),char(255),char(215),char(2),char(168), -char(3),char(26),char(255),char(215),char(2),char(169),char(1),char(159),char(255),char(215), -char(2),char(169),char(1),char(184),char(255),char(215),char(2),char(169),char(1),char(187), -char(255),char(215),char(2),char(169),char(1),char(190),char(255),char(215),char(2),char(169), -char(1),char(193),char(255),char(215),char(2),char(169),char(1),char(225),char(255),char(215), -char(2),char(169),char(2),char(108),char(255),char(215),char(2),char(169),char(2),char(124), -char(255),char(215),char(2),char(169),char(2),char(126),char(255),char(215),char(2),char(169), -char(2),char(132),char(255),char(215),char(2),char(169),char(2),char(134),char(255),char(215), -char(2),char(169),char(2),char(136),char(255),char(215),char(2),char(169),char(2),char(138), -char(255),char(215),char(2),char(169),char(2),char(140),char(255),char(215),char(2),char(169), -char(2),char(177),char(255),char(215),char(2),char(169),char(2),char(179),char(255),char(215), -char(2),char(169),char(2),char(191),char(255),char(215),char(2),char(169),char(2),char(192), -char(255),char(215),char(2),char(169),char(2),char(193),char(255),char(215),char(2),char(169), -char(2),char(194),char(255),char(215),char(2),char(169),char(2),char(197),char(255),char(154), -char(2),char(169),char(2),char(199),char(255),char(154),char(2),char(169),char(2),char(212), -char(255),char(215),char(2),char(169),char(2),char(213),char(255),char(215),char(2),char(169), -char(2),char(239),char(255),char(215),char(2),char(169),char(2),char(241),char(255),char(215), -char(2),char(169),char(2),char(243),char(255),char(215),char(2),char(169),char(2),char(253), -char(255),char(215),char(2),char(169),char(2),char(254),char(255),char(215),char(2),char(169), -char(3),char(9),char(255),char(215),char(2),char(169),char(3),char(11),char(255),char(215), -char(2),char(169),char(3),char(14),char(255),char(215),char(2),char(169),char(3),char(16), -char(255),char(215),char(2),char(169),char(3),char(21),char(255),char(215),char(2),char(169), -char(3),char(25),char(255),char(236),char(2),char(170),char(1),char(207),char(255),char(215), -char(2),char(170),char(1),char(216),char(255),char(215),char(2),char(170),char(1),char(219), -char(255),char(215),char(2),char(170),char(1),char(222),char(255),char(215),char(2),char(170), -char(1),char(225),char(255),char(215),char(2),char(170),char(1),char(234),char(255),char(215), -char(2),char(170),char(1),char(237),char(255),char(215),char(2),char(170),char(2),char(106), -char(255),char(215),char(2),char(170),char(2),char(127),char(255),char(215),char(2),char(170), -char(2),char(133),char(255),char(215),char(2),char(170),char(2),char(135),char(255),char(215), -char(2),char(170),char(2),char(137),char(255),char(215),char(2),char(170),char(2),char(141), -char(255),char(215),char(2),char(170),char(2),char(178),char(255),char(215),char(2),char(170), -char(2),char(180),char(255),char(215),char(2),char(170),char(2),char(192),char(255),char(215), -char(2),char(170),char(2),char(194),char(255),char(215),char(2),char(170),char(2),char(198), -char(255),char(215),char(2),char(170),char(2),char(200),char(255),char(215),char(2),char(170), -char(2),char(213),char(255),char(215),char(2),char(170),char(2),char(224),char(255),char(215), -char(2),char(170),char(2),char(240),char(255),char(215),char(2),char(170),char(2),char(242), -char(255),char(215),char(2),char(170),char(2),char(244),char(255),char(215),char(2),char(170), -char(2),char(254),char(255),char(215),char(2),char(170),char(3),char(10),char(255),char(215), -char(2),char(170),char(3),char(12),char(255),char(215),char(2),char(170),char(3),char(22), -char(255),char(215),char(2),char(170),char(3),char(26),char(255),char(215),char(2),char(171), -char(1),char(163),char(0),char(225),char(2),char(171),char(2),char(234),char(0),char(41), -char(2),char(171),char(3),char(14),char(255),char(215),char(2),char(171),char(3),char(16), -char(255),char(215),char(2),char(172),char(0),char(5),char(255),char(236),char(2),char(172), -char(0),char(10),char(255),char(236),char(2),char(172),char(2),char(7),char(255),char(236), -char(2),char(172),char(2),char(11),char(255),char(236),char(2),char(173),char(0),char(15), -char(255),char(154),char(2),char(173),char(0),char(16),char(255),char(215),char(2),char(173), -char(0),char(17),char(255),char(154),char(2),char(173),char(1),char(157),char(0),char(41), -char(2),char(173),char(1),char(159),char(255),char(215),char(2),char(173),char(1),char(164), -char(255),char(174),char(2),char(173),char(1),char(166),char(0),char(41),char(2),char(173), -char(1),char(170),char(255),char(133),char(2),char(173),char(1),char(174),char(255),char(174), -char(2),char(173),char(1),char(181),char(255),char(174),char(2),char(173),char(1),char(184), -char(255),char(215),char(2),char(173),char(1),char(187),char(255),char(215),char(2),char(173), -char(1),char(188),char(0),char(41),char(2),char(173),char(1),char(190),char(255),char(195), -char(2),char(173),char(1),char(196),char(0),char(41),char(2),char(173),char(1),char(204), -char(255),char(195),char(2),char(173),char(1),char(205),char(255),char(195),char(2),char(173), -char(1),char(206),char(255),char(154),char(2),char(173),char(1),char(207),char(255),char(174), -char(2),char(173),char(1),char(208),char(255),char(215),char(2),char(173),char(1),char(209), -char(255),char(215),char(2),char(173),char(1),char(210),char(255),char(195),char(2),char(173), -char(1),char(211),char(255),char(195),char(2),char(173),char(1),char(212),char(255),char(195), -char(2),char(173),char(1),char(213),char(255),char(154),char(2),char(173),char(1),char(214), -char(255),char(195),char(2),char(173),char(1),char(215),char(255),char(195),char(2),char(173), -char(1),char(216),char(255),char(174),char(2),char(173),char(1),char(217),char(255),char(195), -char(2),char(173),char(1),char(218),char(255),char(195),char(2),char(173),char(1),char(219), -char(255),char(174),char(2),char(173),char(1),char(222),char(255),char(174),char(2),char(173), -char(1),char(223),char(255),char(215),char(2),char(173),char(1),char(224),char(255),char(195), -char(2),char(173),char(1),char(225),char(255),char(154),char(2),char(173),char(1),char(226), -char(255),char(195),char(2),char(173),char(1),char(227),char(255),char(195),char(2),char(173), -char(1),char(229),char(255),char(195),char(2),char(173),char(1),char(230),char(255),char(195), -char(2),char(173),char(1),char(231),char(255),char(215),char(2),char(173),char(1),char(232), -char(255),char(195),char(2),char(173),char(1),char(234),char(255),char(174),char(2),char(173), -char(1),char(235),char(0),char(41),char(2),char(173),char(1),char(236),char(255),char(195), -char(2),char(173),char(1),char(237),char(255),char(174),char(2),char(173),char(1),char(238), -char(255),char(195),char(2),char(173),char(1),char(242),char(255),char(154),char(2),char(173), -char(1),char(243),char(255),char(195),char(2),char(173),char(1),char(244),char(0),char(41), -char(2),char(173),char(1),char(245),char(255),char(195),char(2),char(173),char(1),char(247), -char(255),char(195),char(2),char(173),char(1),char(249),char(255),char(195),char(2),char(173), -char(2),char(2),char(255),char(215),char(2),char(173),char(2),char(3),char(255),char(215), -char(2),char(173),char(2),char(4),char(255),char(215),char(2),char(173),char(2),char(8), -char(255),char(154),char(2),char(173),char(2),char(12),char(255),char(154),char(2),char(173), -char(2),char(106),char(255),char(174),char(2),char(173),char(2),char(107),char(255),char(195), -char(2),char(173),char(2),char(108),char(255),char(215),char(2),char(173),char(2),char(113), -char(255),char(195),char(2),char(173),char(2),char(114),char(255),char(133),char(2),char(173), -char(2),char(115),char(255),char(154),char(2),char(173),char(2),char(117),char(255),char(195), -char(2),char(173),char(2),char(119),char(255),char(215),char(2),char(173),char(2),char(121), -char(255),char(195),char(2),char(173),char(2),char(125),char(255),char(195),char(2),char(173), -char(2),char(126),char(255),char(215),char(2),char(173),char(2),char(127),char(255),char(174), -char(2),char(173),char(2),char(132),char(255),char(215),char(2),char(173),char(2),char(133), -char(255),char(174),char(2),char(173),char(2),char(134),char(255),char(215),char(2),char(173), -char(2),char(135),char(255),char(174),char(2),char(173),char(2),char(136),char(255),char(215), -char(2),char(173),char(2),char(137),char(255),char(174),char(2),char(173),char(2),char(138), -char(255),char(215),char(2),char(173),char(2),char(140),char(255),char(215),char(2),char(173), -char(2),char(141),char(255),char(174),char(2),char(173),char(2),char(150),char(255),char(195), -char(2),char(173),char(2),char(152),char(0),char(41),char(2),char(173),char(2),char(154), -char(255),char(195),char(2),char(173),char(2),char(158),char(255),char(195),char(2),char(173), -char(2),char(160),char(255),char(215),char(2),char(173),char(2),char(162),char(255),char(215), -char(2),char(173),char(2),char(164),char(255),char(195),char(2),char(173),char(2),char(166), -char(255),char(195),char(2),char(173),char(2),char(168),char(0),char(41),char(2),char(173), -char(2),char(169),char(0),char(41),char(2),char(173),char(2),char(172),char(255),char(195), -char(2),char(173),char(2),char(174),char(255),char(195),char(2),char(173),char(2),char(176), -char(255),char(195),char(2),char(173),char(2),char(177),char(255),char(215),char(2),char(173), -char(2),char(178),char(255),char(174),char(2),char(173),char(2),char(179),char(255),char(215), -char(2),char(173),char(2),char(180),char(255),char(174),char(2),char(173),char(2),char(181), -char(0),char(41),char(2),char(173),char(2),char(188),char(255),char(215),char(2),char(173), -char(2),char(189),char(0),char(41),char(2),char(173),char(2),char(192),char(255),char(154), -char(2),char(173),char(2),char(194),char(255),char(154),char(2),char(173),char(2),char(196), -char(255),char(195),char(2),char(173),char(2),char(197),char(255),char(215),char(2),char(173), -char(2),char(198),char(255),char(195),char(2),char(173),char(2),char(199),char(255),char(215), -char(2),char(173),char(2),char(200),char(255),char(195),char(2),char(173),char(2),char(203), -char(255),char(215),char(2),char(173),char(2),char(205),char(255),char(195),char(2),char(173), -char(2),char(206),char(255),char(174),char(2),char(173),char(2),char(207),char(255),char(154), -char(2),char(173),char(2),char(209),char(255),char(195),char(2),char(173),char(2),char(211), -char(255),char(195),char(2),char(173),char(2),char(213),char(255),char(154),char(2),char(173), -char(2),char(215),char(255),char(195),char(2),char(173),char(2),char(217),char(255),char(133), -char(2),char(173),char(2),char(219),char(255),char(133),char(2),char(173),char(2),char(221), -char(255),char(133),char(2),char(173),char(2),char(224),char(255),char(174),char(2),char(173), -char(2),char(230),char(255),char(215),char(2),char(173),char(2),char(232),char(255),char(215), -char(2),char(173),char(2),char(236),char(255),char(195),char(2),char(173),char(2),char(238), -char(255),char(195),char(2),char(173),char(2),char(239),char(255),char(215),char(2),char(173), -char(2),char(240),char(255),char(174),char(2),char(173),char(2),char(241),char(255),char(215), -char(2),char(173),char(2),char(242),char(255),char(174),char(2),char(173),char(2),char(243), -char(255),char(215),char(2),char(173),char(2),char(244),char(255),char(174),char(2),char(173), -char(2),char(246),char(255),char(215),char(2),char(173),char(2),char(254),char(255),char(154), -char(2),char(173),char(3),char(0),char(255),char(195),char(2),char(173),char(3),char(2), -char(255),char(195),char(2),char(173),char(3),char(6),char(255),char(215),char(2),char(173), -char(3),char(8),char(255),char(215),char(2),char(173),char(3),char(9),char(255),char(154), -char(2),char(173),char(3),char(10),char(255),char(174),char(2),char(173),char(3),char(11), -char(255),char(154),char(2),char(173),char(3),char(12),char(255),char(174),char(2),char(173), -char(3),char(14),char(255),char(215),char(2),char(173),char(3),char(16),char(255),char(215), -char(2),char(173),char(3),char(17),char(255),char(174),char(2),char(173),char(3),char(18), -char(255),char(154),char(2),char(173),char(3),char(20),char(255),char(195),char(2),char(173), -char(3),char(21),char(255),char(215),char(2),char(173),char(3),char(22),char(255),char(174), -char(2),char(173),char(3),char(23),char(0),char(41),char(2),char(173),char(3),char(26), -char(255),char(174),char(2),char(173),char(3),char(27),char(255),char(174),char(2),char(173), -char(3),char(28),char(255),char(154),char(2),char(174),char(0),char(15),char(255),char(154), -char(2),char(174),char(0),char(16),char(255),char(215),char(2),char(174),char(0),char(17), -char(255),char(154),char(2),char(174),char(1),char(206),char(255),char(195),char(2),char(174), -char(1),char(207),char(255),char(236),char(2),char(174),char(1),char(213),char(255),char(195), -char(2),char(174),char(1),char(216),char(255),char(236),char(2),char(174),char(1),char(219), -char(255),char(236),char(2),char(174),char(1),char(222),char(255),char(236),char(2),char(174), -char(1),char(234),char(255),char(236),char(2),char(174),char(1),char(237),char(255),char(236), -char(2),char(174),char(1),char(242),char(255),char(195),char(2),char(174),char(2),char(2), -char(255),char(215),char(2),char(174),char(2),char(3),char(255),char(215),char(2),char(174), -char(2),char(4),char(255),char(215),char(2),char(174),char(2),char(8),char(255),char(154), -char(2),char(174),char(2),char(12),char(255),char(154),char(2),char(174),char(2),char(106), -char(255),char(236),char(2),char(174),char(2),char(115),char(255),char(195),char(2),char(174), -char(2),char(127),char(255),char(236),char(2),char(174),char(2),char(133),char(255),char(236), -char(2),char(174),char(2),char(135),char(255),char(236),char(2),char(174),char(2),char(137), -char(255),char(236),char(2),char(174),char(2),char(141),char(255),char(236),char(2),char(174), -char(2),char(178),char(255),char(236),char(2),char(174),char(2),char(180),char(255),char(236), -char(2),char(174),char(2),char(207),char(255),char(195),char(2),char(174),char(2),char(224), -char(255),char(236),char(2),char(174),char(2),char(240),char(255),char(236),char(2),char(174), -char(2),char(242),char(255),char(236),char(2),char(174),char(2),char(244),char(255),char(236), -char(2),char(174),char(3),char(10),char(255),char(236),char(2),char(174),char(3),char(12), -char(255),char(236),char(2),char(174),char(3),char(18),char(255),char(195),char(2),char(174), -char(3),char(22),char(255),char(236),char(2),char(174),char(3),char(26),char(255),char(236), -char(2),char(174),char(3),char(28),char(255),char(195),char(2),char(175),char(0),char(5), -char(255),char(92),char(2),char(175),char(0),char(10),char(255),char(92),char(2),char(175), -char(1),char(157),char(255),char(154),char(2),char(175),char(1),char(163),char(0),char(102), -char(2),char(175),char(1),char(166),char(255),char(154),char(2),char(175),char(1),char(188), -char(255),char(72),char(2),char(175),char(1),char(193),char(255),char(133),char(2),char(175), -char(1),char(196),char(255),char(154),char(2),char(175),char(1),char(220),char(255),char(174), -char(2),char(175),char(1),char(225),char(255),char(215),char(2),char(175),char(1),char(228), -char(255),char(174),char(2),char(175),char(2),char(7),char(255),char(92),char(2),char(175), -char(2),char(11),char(255),char(92),char(2),char(175),char(2),char(124),char(255),char(133), -char(2),char(175),char(2),char(128),char(255),char(113),char(2),char(175),char(2),char(130), -char(255),char(113),char(2),char(175),char(2),char(169),char(255),char(154),char(2),char(175), -char(2),char(170),char(255),char(174),char(2),char(175),char(2),char(181),char(255),char(72), -char(2),char(175),char(2),char(182),char(255),char(174),char(2),char(175),char(2),char(183), -char(255),char(154),char(2),char(175),char(2),char(185),char(255),char(154),char(2),char(175), -char(2),char(189),char(255),char(154),char(2),char(175),char(2),char(190),char(255),char(174), -char(2),char(175),char(2),char(191),char(255),char(133),char(2),char(175),char(2),char(192), -char(255),char(215),char(2),char(175),char(2),char(193),char(255),char(133),char(2),char(175), -char(2),char(194),char(255),char(215),char(2),char(175),char(2),char(197),char(255),char(195), -char(2),char(175),char(2),char(198),char(255),char(215),char(2),char(175),char(2),char(199), -char(255),char(195),char(2),char(175),char(2),char(200),char(255),char(215),char(2),char(175), -char(2),char(212),char(255),char(133),char(2),char(175),char(2),char(213),char(255),char(215), -char(2),char(175),char(2),char(253),char(255),char(133),char(2),char(175),char(2),char(254), -char(255),char(215),char(2),char(175),char(3),char(13),char(255),char(72),char(2),char(175), -char(3),char(14),char(255),char(174),char(2),char(175),char(3),char(15),char(255),char(72), -char(2),char(175),char(3),char(16),char(255),char(174),char(2),char(175),char(3),char(23), -char(255),char(154),char(2),char(175),char(3),char(24),char(255),char(174),char(2),char(176), -char(0),char(5),char(255),char(113),char(2),char(176),char(0),char(10),char(255),char(113), -char(2),char(176),char(1),char(220),char(255),char(154),char(2),char(176),char(1),char(225), -char(255),char(215),char(2),char(176),char(1),char(228),char(255),char(154),char(2),char(176), -char(2),char(7),char(255),char(113),char(2),char(176),char(2),char(11),char(255),char(113), -char(2),char(176),char(2),char(109),char(255),char(215),char(2),char(176),char(2),char(129), -char(255),char(215),char(2),char(176),char(2),char(131),char(255),char(215),char(2),char(176), -char(2),char(139),char(255),char(215),char(2),char(176),char(2),char(170),char(255),char(154), -char(2),char(176),char(2),char(182),char(255),char(154),char(2),char(176),char(2),char(184), -char(255),char(215),char(2),char(176),char(2),char(186),char(255),char(215),char(2),char(176), -char(2),char(190),char(255),char(154),char(2),char(176),char(2),char(192),char(255),char(215), -char(2),char(176),char(2),char(194),char(255),char(215),char(2),char(176),char(2),char(198), -char(255),char(215),char(2),char(176),char(2),char(200),char(255),char(215),char(2),char(176), -char(2),char(213),char(255),char(215),char(2),char(176),char(2),char(254),char(255),char(215), -char(2),char(176),char(3),char(14),char(255),char(113),char(2),char(176),char(3),char(16), -char(255),char(113),char(2),char(176),char(3),char(24),char(255),char(154),char(2),char(177), -char(1),char(157),char(255),char(215),char(2),char(177),char(1),char(166),char(255),char(215), -char(2),char(177),char(1),char(188),char(255),char(195),char(2),char(177),char(1),char(196), -char(255),char(215),char(2),char(177),char(2),char(128),char(255),char(236),char(2),char(177), -char(2),char(130),char(255),char(236),char(2),char(177),char(2),char(169),char(255),char(215), -char(2),char(177),char(2),char(181),char(255),char(195),char(2),char(177),char(2),char(183), -char(255),char(236),char(2),char(177),char(2),char(185),char(255),char(236),char(2),char(177), -char(2),char(189),char(255),char(215),char(2),char(177),char(3),char(13),char(255),char(215), -char(2),char(177),char(3),char(15),char(255),char(215),char(2),char(177),char(3),char(23), -char(255),char(215),char(2),char(178),char(0),char(5),char(255),char(236),char(2),char(178), -char(0),char(10),char(255),char(236),char(2),char(178),char(1),char(208),char(255),char(215), -char(2),char(178),char(1),char(220),char(255),char(236),char(2),char(178),char(1),char(221), -char(255),char(236),char(2),char(178),char(1),char(223),char(255),char(215),char(2),char(178), -char(1),char(225),char(255),char(236),char(2),char(178),char(1),char(228),char(255),char(236), -char(2),char(178),char(1),char(246),char(255),char(236),char(2),char(178),char(2),char(7), -char(255),char(236),char(2),char(178),char(2),char(11),char(255),char(236),char(2),char(178), -char(2),char(160),char(255),char(215),char(2),char(178),char(2),char(170),char(255),char(236), -char(2),char(178),char(2),char(182),char(255),char(236),char(2),char(178),char(2),char(188), -char(255),char(215),char(2),char(178),char(2),char(190),char(255),char(236),char(2),char(178), -char(2),char(192),char(255),char(236),char(2),char(178),char(2),char(194),char(255),char(236), -char(2),char(178),char(2),char(203),char(255),char(215),char(2),char(178),char(2),char(213), -char(255),char(236),char(2),char(178),char(2),char(230),char(255),char(215),char(2),char(178), -char(2),char(248),char(255),char(236),char(2),char(178),char(2),char(250),char(255),char(236), -char(2),char(178),char(2),char(252),char(255),char(236),char(2),char(178),char(2),char(254), -char(255),char(236),char(2),char(178),char(3),char(6),char(255),char(215),char(2),char(178), -char(3),char(8),char(255),char(215),char(2),char(178),char(3),char(14),char(255),char(236), -char(2),char(178),char(3),char(16),char(255),char(236),char(2),char(178),char(3),char(24), -char(255),char(236),char(2),char(179),char(1),char(159),char(255),char(215),char(2),char(179), -char(1),char(184),char(255),char(215),char(2),char(179),char(1),char(187),char(255),char(215), -char(2),char(179),char(1),char(190),char(255),char(215),char(2),char(179),char(1),char(225), -char(255),char(215),char(2),char(179),char(2),char(108),char(255),char(215),char(2),char(179), -char(2),char(126),char(255),char(215),char(2),char(179),char(2),char(132),char(255),char(215), -char(2),char(179),char(2),char(134),char(255),char(215),char(2),char(179),char(2),char(136), -char(255),char(215),char(2),char(179),char(2),char(138),char(255),char(215),char(2),char(179), -char(2),char(140),char(255),char(215),char(2),char(179),char(2),char(177),char(255),char(215), -char(2),char(179),char(2),char(179),char(255),char(215),char(2),char(179),char(2),char(192), -char(255),char(215),char(2),char(179),char(2),char(194),char(255),char(215),char(2),char(179), -char(2),char(197),char(255),char(215),char(2),char(179),char(2),char(199),char(255),char(215), -char(2),char(179),char(2),char(213),char(255),char(215),char(2),char(179),char(2),char(239), -char(255),char(215),char(2),char(179),char(2),char(241),char(255),char(215),char(2),char(179), -char(2),char(243),char(255),char(215),char(2),char(179),char(2),char(254),char(255),char(215), -char(2),char(179),char(3),char(9),char(255),char(215),char(2),char(179),char(3),char(11), -char(255),char(215),char(2),char(179),char(3),char(14),char(255),char(215),char(2),char(179), -char(3),char(16),char(255),char(215),char(2),char(179),char(3),char(21),char(255),char(215), -char(2),char(181),char(0),char(15),char(255),char(133),char(2),char(181),char(0),char(16), -char(255),char(174),char(2),char(181),char(0),char(17),char(255),char(133),char(2),char(181), -char(1),char(159),char(255),char(215),char(2),char(181),char(1),char(164),char(255),char(154), -char(2),char(181),char(1),char(170),char(255),char(113),char(2),char(181),char(1),char(174), -char(255),char(154),char(2),char(181),char(1),char(181),char(255),char(154),char(2),char(181), -char(1),char(184),char(255),char(215),char(2),char(181),char(1),char(187),char(255),char(215), -char(2),char(181),char(1),char(188),char(0),char(41),char(2),char(181),char(1),char(190), -char(255),char(174),char(2),char(181),char(1),char(204),char(255),char(154),char(2),char(181), -char(1),char(205),char(255),char(154),char(2),char(181),char(1),char(206),char(255),char(133), -char(2),char(181),char(1),char(207),char(255),char(113),char(2),char(181),char(1),char(208), -char(255),char(215),char(2),char(181),char(1),char(209),char(255),char(215),char(2),char(181), -char(1),char(210),char(255),char(154),char(2),char(181),char(1),char(211),char(255),char(154), -char(2),char(181),char(1),char(212),char(255),char(154),char(2),char(181),char(1),char(213), -char(255),char(133),char(2),char(181),char(1),char(214),char(255),char(154),char(2),char(181), -char(1),char(215),char(255),char(154),char(2),char(181),char(1),char(216),char(255),char(113), -char(2),char(181),char(1),char(217),char(255),char(154),char(2),char(181),char(1),char(218), -char(255),char(154),char(2),char(181),char(1),char(219),char(255),char(113),char(2),char(181), -char(1),char(220),char(255),char(174),char(2),char(181),char(1),char(221),char(255),char(174), -char(2),char(181),char(1),char(222),char(255),char(113),char(2),char(181),char(1),char(223), -char(255),char(215),char(2),char(181),char(1),char(224),char(255),char(154),char(2),char(181), -char(1),char(225),char(255),char(154),char(2),char(181),char(1),char(226),char(255),char(154), -char(2),char(181),char(1),char(227),char(255),char(154),char(2),char(181),char(1),char(228), -char(255),char(174),char(2),char(181),char(1),char(229),char(255),char(154),char(2),char(181), -char(1),char(230),char(255),char(154),char(2),char(181),char(1),char(231),char(255),char(215), -char(2),char(181),char(1),char(232),char(255),char(154),char(2),char(181),char(1),char(233), -char(255),char(195),char(2),char(181),char(1),char(234),char(255),char(113),char(2),char(181), -char(1),char(236),char(255),char(154),char(2),char(181),char(1),char(237),char(255),char(113), -char(2),char(181),char(1),char(238),char(255),char(133),char(2),char(181),char(1),char(242), -char(255),char(133),char(2),char(181),char(1),char(243),char(255),char(154),char(2),char(181), -char(1),char(245),char(255),char(154),char(2),char(181),char(1),char(246),char(255),char(174), -char(2),char(181),char(1),char(247),char(255),char(154),char(2),char(181),char(1),char(249), -char(255),char(154),char(2),char(181),char(2),char(2),char(255),char(174),char(2),char(181), -char(2),char(3),char(255),char(174),char(2),char(181),char(2),char(4),char(255),char(174), -char(2),char(181),char(2),char(8),char(255),char(133),char(2),char(181),char(2),char(12), -char(255),char(133),char(2),char(181),char(2),char(106),char(255),char(113),char(2),char(181), -char(2),char(107),char(255),char(154),char(2),char(181),char(2),char(108),char(255),char(215), -char(2),char(181),char(2),char(109),char(255),char(215),char(2),char(181),char(2),char(113), -char(255),char(154),char(2),char(181),char(2),char(114),char(255),char(113),char(2),char(181), -char(2),char(115),char(255),char(133),char(2),char(181),char(2),char(117),char(255),char(154), -char(2),char(181),char(2),char(119),char(255),char(154),char(2),char(181),char(2),char(121), -char(255),char(154),char(2),char(181),char(2),char(125),char(255),char(154),char(2),char(181), -char(2),char(126),char(255),char(215),char(2),char(181),char(2),char(127),char(255),char(113), -char(2),char(181),char(2),char(129),char(255),char(215),char(2),char(181),char(2),char(131), -char(255),char(215),char(2),char(181),char(2),char(132),char(255),char(215),char(2),char(181), -char(2),char(133),char(255),char(113),char(2),char(181),char(2),char(134),char(255),char(215), -char(2),char(181),char(2),char(135),char(255),char(113),char(2),char(181),char(2),char(136), -char(255),char(215),char(2),char(181),char(2),char(137),char(255),char(113),char(2),char(181), -char(2),char(138),char(255),char(215),char(2),char(181),char(2),char(139),char(255),char(215), -char(2),char(181),char(2),char(140),char(255),char(215),char(2),char(181),char(2),char(141), -char(255),char(113),char(2),char(181),char(2),char(150),char(255),char(154),char(2),char(181), -char(2),char(154),char(255),char(154),char(2),char(181),char(2),char(158),char(255),char(154), -char(2),char(181),char(2),char(160),char(255),char(215),char(2),char(181),char(2),char(162), -char(255),char(215),char(2),char(181),char(2),char(164),char(255),char(154),char(2),char(181), -char(2),char(166),char(255),char(154),char(2),char(181),char(2),char(170),char(255),char(174), -char(2),char(181),char(2),char(172),char(255),char(154),char(2),char(181),char(2),char(174), -char(255),char(154),char(2),char(181),char(2),char(176),char(255),char(154),char(2),char(181), -char(2),char(177),char(255),char(215),char(2),char(181),char(2),char(178),char(255),char(113), -char(2),char(181),char(2),char(179),char(255),char(215),char(2),char(181),char(2),char(180), -char(255),char(113),char(2),char(181),char(2),char(181),char(0),char(41),char(2),char(181), -char(2),char(182),char(255),char(174),char(2),char(181),char(2),char(184),char(255),char(174), -char(2),char(181),char(2),char(186),char(255),char(174),char(2),char(181),char(2),char(188), -char(255),char(215),char(2),char(181),char(2),char(190),char(255),char(174),char(2),char(181), -char(2),char(192),char(255),char(154),char(2),char(181),char(2),char(194),char(255),char(154), -char(2),char(181),char(2),char(196),char(255),char(154),char(2),char(181),char(2),char(197), -char(255),char(154),char(2),char(181),char(2),char(198),char(255),char(113),char(2),char(181), -char(2),char(199),char(255),char(154),char(2),char(181),char(2),char(200),char(255),char(113), -char(2),char(181),char(2),char(203),char(255),char(215),char(2),char(181),char(2),char(205), -char(255),char(154),char(2),char(181),char(2),char(206),char(255),char(154),char(2),char(181), -char(2),char(207),char(255),char(133),char(2),char(181),char(2),char(209),char(255),char(154), -char(2),char(181),char(2),char(211),char(255),char(154),char(2),char(181),char(2),char(213), -char(255),char(154),char(2),char(181),char(2),char(215),char(255),char(154),char(2),char(181), -char(2),char(217),char(255),char(113),char(2),char(181),char(2),char(219),char(255),char(113), -char(2),char(181),char(2),char(221),char(255),char(113),char(2),char(181),char(2),char(224), -char(255),char(113),char(2),char(181),char(2),char(230),char(255),char(215),char(2),char(181), -char(2),char(232),char(255),char(215),char(2),char(181),char(2),char(234),char(255),char(195), -char(2),char(181),char(2),char(236),char(255),char(154),char(2),char(181),char(2),char(238), -char(255),char(154),char(2),char(181),char(2),char(239),char(255),char(215),char(2),char(181), -char(2),char(240),char(255),char(113),char(2),char(181),char(2),char(241),char(255),char(215), -char(2),char(181),char(2),char(242),char(255),char(113),char(2),char(181),char(2),char(243), -char(255),char(215),char(2),char(181),char(2),char(244),char(255),char(113),char(2),char(181), -char(2),char(246),char(255),char(215),char(2),char(181),char(2),char(248),char(255),char(174), -char(2),char(181),char(2),char(250),char(255),char(174),char(2),char(181),char(2),char(252), -char(255),char(174),char(2),char(181),char(2),char(254),char(255),char(154),char(2),char(181), -char(3),char(0),char(255),char(154),char(2),char(181),char(3),char(2),char(255),char(154), -char(2),char(181),char(3),char(6),char(255),char(215),char(2),char(181),char(3),char(8), -char(255),char(215),char(2),char(181),char(3),char(9),char(255),char(113),char(2),char(181), -char(3),char(10),char(255),char(113),char(2),char(181),char(3),char(11),char(255),char(113), -char(2),char(181),char(3),char(12),char(255),char(113),char(2),char(181),char(3),char(14), -char(255),char(154),char(2),char(181),char(3),char(16),char(255),char(154),char(2),char(181), -char(3),char(17),char(255),char(154),char(2),char(181),char(3),char(18),char(255),char(133), -char(2),char(181),char(3),char(20),char(255),char(154),char(2),char(181),char(3),char(21), -char(255),char(215),char(2),char(181),char(3),char(22),char(255),char(113),char(2),char(181), -char(3),char(24),char(255),char(174),char(2),char(181),char(3),char(26),char(255),char(113), -char(2),char(181),char(3),char(27),char(255),char(154),char(2),char(181),char(3),char(28), -char(255),char(133),char(2),char(182),char(0),char(15),char(255),char(154),char(2),char(182), -char(0),char(16),char(255),char(215),char(2),char(182),char(0),char(17),char(255),char(154), -char(2),char(182),char(1),char(206),char(255),char(195),char(2),char(182),char(1),char(207), -char(255),char(236),char(2),char(182),char(1),char(213),char(255),char(195),char(2),char(182), -char(1),char(216),char(255),char(236),char(2),char(182),char(1),char(219),char(255),char(236), -char(2),char(182),char(1),char(222),char(255),char(236),char(2),char(182),char(1),char(234), -char(255),char(236),char(2),char(182),char(1),char(237),char(255),char(236),char(2),char(182), -char(1),char(242),char(255),char(195),char(2),char(182),char(2),char(2),char(255),char(215), -char(2),char(182),char(2),char(3),char(255),char(215),char(2),char(182),char(2),char(4), -char(255),char(215),char(2),char(182),char(2),char(8),char(255),char(154),char(2),char(182), -char(2),char(12),char(255),char(154),char(2),char(182),char(2),char(106),char(255),char(236), -char(2),char(182),char(2),char(115),char(255),char(195),char(2),char(182),char(2),char(127), -char(255),char(236),char(2),char(182),char(2),char(133),char(255),char(236),char(2),char(182), -char(2),char(135),char(255),char(236),char(2),char(182),char(2),char(137),char(255),char(236), -char(2),char(182),char(2),char(141),char(255),char(236),char(2),char(182),char(2),char(178), -char(255),char(236),char(2),char(182),char(2),char(180),char(255),char(236),char(2),char(182), -char(2),char(207),char(255),char(195),char(2),char(182),char(2),char(224),char(255),char(236), -char(2),char(182),char(2),char(240),char(255),char(236),char(2),char(182),char(2),char(242), -char(255),char(236),char(2),char(182),char(2),char(244),char(255),char(236),char(2),char(182), -char(3),char(10),char(255),char(236),char(2),char(182),char(3),char(12),char(255),char(236), -char(2),char(182),char(3),char(18),char(255),char(195),char(2),char(182),char(3),char(22), -char(255),char(236),char(2),char(182),char(3),char(26),char(255),char(236),char(2),char(182), -char(3),char(28),char(255),char(195),char(2),char(183),char(0),char(15),char(255),char(133), -char(2),char(183),char(0),char(17),char(255),char(133),char(2),char(183),char(1),char(159), -char(255),char(215),char(2),char(183),char(1),char(164),char(255),char(174),char(2),char(183), -char(1),char(170),char(255),char(133),char(2),char(183),char(1),char(174),char(255),char(174), -char(2),char(183),char(1),char(181),char(255),char(174),char(2),char(183),char(1),char(184), -char(255),char(215),char(2),char(183),char(1),char(187),char(255),char(215),char(2),char(183), -char(1),char(190),char(255),char(195),char(2),char(183),char(1),char(202),char(255),char(174), -char(2),char(183),char(1),char(204),char(255),char(195),char(2),char(183),char(1),char(205), -char(255),char(195),char(2),char(183),char(1),char(206),char(255),char(154),char(2),char(183), -char(1),char(207),char(255),char(154),char(2),char(183),char(1),char(210),char(255),char(195), -char(2),char(183),char(1),char(211),char(255),char(195),char(2),char(183),char(1),char(212), -char(255),char(195),char(2),char(183),char(1),char(213),char(255),char(154),char(2),char(183), -char(1),char(214),char(255),char(195),char(2),char(183),char(1),char(215),char(255),char(195), -char(2),char(183),char(1),char(216),char(255),char(154),char(2),char(183),char(1),char(217), -char(255),char(195),char(2),char(183),char(1),char(218),char(255),char(195),char(2),char(183), -char(1),char(219),char(255),char(154),char(2),char(183),char(1),char(222),char(255),char(154), -char(2),char(183),char(1),char(224),char(255),char(195),char(2),char(183),char(1),char(225), -char(255),char(174),char(2),char(183),char(1),char(226),char(255),char(195),char(2),char(183), -char(1),char(227),char(255),char(195),char(2),char(183),char(1),char(229),char(255),char(195), -char(2),char(183),char(1),char(230),char(255),char(195),char(2),char(183),char(1),char(232), -char(255),char(195),char(2),char(183),char(1),char(233),char(255),char(215),char(2),char(183), -char(1),char(234),char(255),char(154),char(2),char(183),char(1),char(235),char(0),char(41), -char(2),char(183),char(1),char(236),char(255),char(195),char(2),char(183),char(1),char(237), -char(255),char(154),char(2),char(183),char(1),char(238),char(255),char(174),char(2),char(183), -char(1),char(242),char(255),char(154),char(2),char(183),char(1),char(243),char(255),char(195), -char(2),char(183),char(1),char(244),char(0),char(41),char(2),char(183),char(1),char(245), -char(255),char(195),char(2),char(183),char(1),char(247),char(255),char(195),char(2),char(183), -char(1),char(249),char(255),char(195),char(2),char(183),char(2),char(8),char(255),char(133), -char(2),char(183),char(2),char(12),char(255),char(133),char(2),char(183),char(2),char(106), -char(255),char(154),char(2),char(183),char(2),char(107),char(255),char(195),char(2),char(183), -char(2),char(108),char(255),char(215),char(2),char(183),char(2),char(113),char(255),char(195), -char(2),char(183),char(2),char(114),char(255),char(133),char(2),char(183),char(2),char(115), -char(255),char(154),char(2),char(183),char(2),char(117),char(255),char(195),char(2),char(183), -char(2),char(119),char(255),char(215),char(2),char(183),char(2),char(121),char(255),char(195), -char(2),char(183),char(2),char(125),char(255),char(215),char(2),char(183),char(2),char(126), -char(255),char(215),char(2),char(183),char(2),char(127),char(255),char(154),char(2),char(183), -char(2),char(132),char(255),char(215),char(2),char(183),char(2),char(133),char(255),char(154), -char(2),char(183),char(2),char(134),char(255),char(215),char(2),char(183),char(2),char(135), -char(255),char(154),char(2),char(183),char(2),char(136),char(255),char(215),char(2),char(183), -char(2),char(137),char(255),char(154),char(2),char(183),char(2),char(138),char(255),char(215), -char(2),char(183),char(2),char(140),char(255),char(215),char(2),char(183),char(2),char(141), -char(255),char(154),char(2),char(183),char(2),char(150),char(255),char(195),char(2),char(183), -char(2),char(152),char(0),char(41),char(2),char(183),char(2),char(154),char(255),char(195), -char(2),char(183),char(2),char(158),char(255),char(195),char(2),char(183),char(2),char(164), -char(255),char(195),char(2),char(183),char(2),char(166),char(255),char(195),char(2),char(183), -char(2),char(168),char(0),char(41),char(2),char(183),char(2),char(172),char(255),char(195), -char(2),char(183),char(2),char(174),char(255),char(195),char(2),char(183),char(2),char(176), -char(255),char(195),char(2),char(183),char(2),char(177),char(255),char(215),char(2),char(183), -char(2),char(178),char(255),char(154),char(2),char(183),char(2),char(179),char(255),char(215), -char(2),char(183),char(2),char(180),char(255),char(154),char(2),char(183),char(2),char(192), -char(255),char(174),char(2),char(183),char(2),char(194),char(255),char(174),char(2),char(183), -char(2),char(196),char(255),char(195),char(2),char(183),char(2),char(198),char(255),char(174), -char(2),char(183),char(2),char(200),char(255),char(174),char(2),char(183),char(2),char(205), -char(255),char(195),char(2),char(183),char(2),char(206),char(255),char(174),char(2),char(183), -char(2),char(207),char(255),char(154),char(2),char(183),char(2),char(209),char(255),char(195), -char(2),char(183),char(2),char(211),char(255),char(195),char(2),char(183),char(2),char(213), -char(255),char(174),char(2),char(183),char(2),char(215),char(255),char(195),char(2),char(183), -char(2),char(217),char(255),char(133),char(2),char(183),char(2),char(218),char(255),char(174), -char(2),char(183),char(2),char(219),char(255),char(133),char(2),char(183),char(2),char(220), -char(255),char(174),char(2),char(183),char(2),char(221),char(255),char(133),char(2),char(183), -char(2),char(222),char(255),char(174),char(2),char(183),char(2),char(224),char(255),char(154), -char(2),char(183),char(2),char(225),char(255),char(236),char(2),char(183),char(2),char(226), -char(255),char(174),char(2),char(183),char(2),char(227),char(255),char(236),char(2),char(183), -char(2),char(228),char(255),char(174),char(2),char(183),char(2),char(236),char(255),char(195), -char(2),char(183),char(2),char(238),char(255),char(195),char(2),char(183),char(2),char(239), -char(255),char(215),char(2),char(183),char(2),char(240),char(255),char(154),char(2),char(183), -char(2),char(241),char(255),char(215),char(2),char(183),char(2),char(242),char(255),char(154), -char(2),char(183),char(2),char(243),char(255),char(215),char(2),char(183),char(2),char(244), -char(255),char(154),char(2),char(183),char(2),char(254),char(255),char(174),char(2),char(183), -char(3),char(0),char(255),char(195),char(2),char(183),char(3),char(2),char(255),char(195), -char(2),char(183),char(3),char(9),char(255),char(174),char(2),char(183),char(3),char(10), -char(255),char(154),char(2),char(183),char(3),char(11),char(255),char(174),char(2),char(183), -char(3),char(12),char(255),char(154),char(2),char(183),char(3),char(14),char(255),char(215), -char(2),char(183),char(3),char(16),char(255),char(215),char(2),char(183),char(3),char(17), -char(255),char(174),char(2),char(183),char(3),char(18),char(255),char(154),char(2),char(183), -char(3),char(20),char(255),char(195),char(2),char(183),char(3),char(21),char(255),char(215), -char(2),char(183),char(3),char(22),char(255),char(154),char(2),char(183),char(3),char(25), -char(255),char(236),char(2),char(183),char(3),char(26),char(255),char(154),char(2),char(183), -char(3),char(27),char(255),char(174),char(2),char(183),char(3),char(28),char(255),char(154), -char(2),char(184),char(0),char(15),char(255),char(174),char(2),char(184),char(0),char(17), -char(255),char(174),char(2),char(184),char(1),char(206),char(255),char(236),char(2),char(184), -char(1),char(213),char(255),char(236),char(2),char(184),char(1),char(242),char(255),char(236), -char(2),char(184),char(2),char(8),char(255),char(174),char(2),char(184),char(2),char(12), -char(255),char(174),char(2),char(184),char(2),char(115),char(255),char(236),char(2),char(184), -char(2),char(207),char(255),char(236),char(2),char(184),char(3),char(18),char(255),char(236), -char(2),char(184),char(3),char(28),char(255),char(236),char(2),char(185),char(0),char(15), -char(255),char(133),char(2),char(185),char(0),char(17),char(255),char(133),char(2),char(185), -char(1),char(159),char(255),char(215),char(2),char(185),char(1),char(164),char(255),char(174), -char(2),char(185),char(1),char(170),char(255),char(133),char(2),char(185),char(1),char(174), -char(255),char(174),char(2),char(185),char(1),char(181),char(255),char(174),char(2),char(185), -char(1),char(184),char(255),char(215),char(2),char(185),char(1),char(187),char(255),char(215), -char(2),char(185),char(1),char(190),char(255),char(195),char(2),char(185),char(1),char(202), -char(255),char(174),char(2),char(185),char(1),char(204),char(255),char(195),char(2),char(185), -char(1),char(205),char(255),char(195),char(2),char(185),char(1),char(206),char(255),char(154), -char(2),char(185),char(1),char(207),char(255),char(154),char(2),char(185),char(1),char(210), -char(255),char(195),char(2),char(185),char(1),char(211),char(255),char(195),char(2),char(185), -char(1),char(212),char(255),char(195),char(2),char(185),char(1),char(213),char(255),char(154), -char(2),char(185),char(1),char(214),char(255),char(195),char(2),char(185),char(1),char(215), -char(255),char(195),char(2),char(185),char(1),char(216),char(255),char(154),char(2),char(185), -char(1),char(217),char(255),char(195),char(2),char(185),char(1),char(218),char(255),char(195), -char(2),char(185),char(1),char(219),char(255),char(154),char(2),char(185),char(1),char(222), -char(255),char(154),char(2),char(185),char(1),char(224),char(255),char(195),char(2),char(185), -char(1),char(225),char(255),char(174),char(2),char(185),char(1),char(226),char(255),char(195), -char(2),char(185),char(1),char(227),char(255),char(195),char(2),char(185),char(1),char(229), -char(255),char(195),char(2),char(185),char(1),char(230),char(255),char(195),char(2),char(185), -char(1),char(232),char(255),char(195),char(2),char(185),char(1),char(233),char(255),char(215), -char(2),char(185),char(1),char(234),char(255),char(154),char(2),char(185),char(1),char(235), -char(0),char(41),char(2),char(185),char(1),char(236),char(255),char(195),char(2),char(185), -char(1),char(237),char(255),char(154),char(2),char(185),char(1),char(238),char(255),char(174), -char(2),char(185),char(1),char(242),char(255),char(154),char(2),char(185),char(1),char(243), -char(255),char(195),char(2),char(185),char(1),char(244),char(0),char(41),char(2),char(185), -char(1),char(245),char(255),char(195),char(2),char(185),char(1),char(247),char(255),char(195), -char(2),char(185),char(1),char(249),char(255),char(195),char(2),char(185),char(2),char(8), -char(255),char(133),char(2),char(185),char(2),char(12),char(255),char(133),char(2),char(185), -char(2),char(106),char(255),char(154),char(2),char(185),char(2),char(107),char(255),char(195), -char(2),char(185),char(2),char(108),char(255),char(215),char(2),char(185),char(2),char(113), -char(255),char(195),char(2),char(185),char(2),char(114),char(255),char(133),char(2),char(185), -char(2),char(115),char(255),char(154),char(2),char(185),char(2),char(117),char(255),char(195), -char(2),char(185),char(2),char(119),char(255),char(215),char(2),char(185),char(2),char(121), -char(255),char(195),char(2),char(185),char(2),char(125),char(255),char(215),char(2),char(185), -char(2),char(126),char(255),char(215),char(2),char(185),char(2),char(127),char(255),char(154), -char(2),char(185),char(2),char(132),char(255),char(215),char(2),char(185),char(2),char(133), -char(255),char(154),char(2),char(185),char(2),char(134),char(255),char(215),char(2),char(185), -char(2),char(135),char(255),char(154),char(2),char(185),char(2),char(136),char(255),char(215), -char(2),char(185),char(2),char(137),char(255),char(154),char(2),char(185),char(2),char(138), -char(255),char(215),char(2),char(185),char(2),char(140),char(255),char(215),char(2),char(185), -char(2),char(141),char(255),char(154),char(2),char(185),char(2),char(150),char(255),char(195), -char(2),char(185),char(2),char(152),char(0),char(41),char(2),char(185),char(2),char(154), -char(255),char(195),char(2),char(185),char(2),char(158),char(255),char(195),char(2),char(185), -char(2),char(164),char(255),char(195),char(2),char(185),char(2),char(166),char(255),char(195), -char(2),char(185),char(2),char(168),char(0),char(41),char(2),char(185),char(2),char(172), -char(255),char(195),char(2),char(185),char(2),char(174),char(255),char(195),char(2),char(185), -char(2),char(176),char(255),char(195),char(2),char(185),char(2),char(177),char(255),char(215), -char(2),char(185),char(2),char(178),char(255),char(154),char(2),char(185),char(2),char(179), -char(255),char(215),char(2),char(185),char(2),char(180),char(255),char(154),char(2),char(185), -char(2),char(192),char(255),char(174),char(2),char(185),char(2),char(194),char(255),char(174), -char(2),char(185),char(2),char(196),char(255),char(195),char(2),char(185),char(2),char(198), -char(255),char(174),char(2),char(185),char(2),char(200),char(255),char(174),char(2),char(185), -char(2),char(205),char(255),char(195),char(2),char(185),char(2),char(206),char(255),char(174), -char(2),char(185),char(2),char(207),char(255),char(154),char(2),char(185),char(2),char(209), -char(255),char(195),char(2),char(185),char(2),char(211),char(255),char(195),char(2),char(185), -char(2),char(213),char(255),char(174),char(2),char(185),char(2),char(215),char(255),char(195), -char(2),char(185),char(2),char(217),char(255),char(133),char(2),char(185),char(2),char(218), -char(255),char(174),char(2),char(185),char(2),char(219),char(255),char(133),char(2),char(185), -char(2),char(220),char(255),char(174),char(2),char(185),char(2),char(221),char(255),char(133), -char(2),char(185),char(2),char(222),char(255),char(174),char(2),char(185),char(2),char(224), -char(255),char(154),char(2),char(185),char(2),char(225),char(255),char(236),char(2),char(185), -char(2),char(226),char(255),char(174),char(2),char(185),char(2),char(227),char(255),char(236), -char(2),char(185),char(2),char(228),char(255),char(174),char(2),char(185),char(2),char(236), -char(255),char(195),char(2),char(185),char(2),char(238),char(255),char(195),char(2),char(185), -char(2),char(239),char(255),char(215),char(2),char(185),char(2),char(240),char(255),char(154), -char(2),char(185),char(2),char(241),char(255),char(215),char(2),char(185),char(2),char(242), -char(255),char(154),char(2),char(185),char(2),char(243),char(255),char(215),char(2),char(185), -char(2),char(244),char(255),char(154),char(2),char(185),char(2),char(254),char(255),char(174), -char(2),char(185),char(3),char(0),char(255),char(195),char(2),char(185),char(3),char(2), -char(255),char(195),char(2),char(185),char(3),char(9),char(255),char(174),char(2),char(185), -char(3),char(10),char(255),char(154),char(2),char(185),char(3),char(11),char(255),char(174), -char(2),char(185),char(3),char(12),char(255),char(154),char(2),char(185),char(3),char(14), -char(255),char(215),char(2),char(185),char(3),char(16),char(255),char(215),char(2),char(185), -char(3),char(17),char(255),char(174),char(2),char(185),char(3),char(18),char(255),char(154), -char(2),char(185),char(3),char(20),char(255),char(195),char(2),char(185),char(3),char(21), -char(255),char(215),char(2),char(185),char(3),char(22),char(255),char(154),char(2),char(185), -char(3),char(25),char(255),char(236),char(2),char(185),char(3),char(26),char(255),char(154), -char(2),char(185),char(3),char(27),char(255),char(174),char(2),char(185),char(3),char(28), -char(255),char(154),char(2),char(186),char(0),char(15),char(255),char(174),char(2),char(186), -char(0),char(17),char(255),char(174),char(2),char(186),char(1),char(206),char(255),char(236), -char(2),char(186),char(1),char(213),char(255),char(236),char(2),char(186),char(1),char(242), -char(255),char(236),char(2),char(186),char(2),char(8),char(255),char(174),char(2),char(186), -char(2),char(12),char(255),char(174),char(2),char(186),char(2),char(115),char(255),char(236), -char(2),char(186),char(2),char(207),char(255),char(236),char(2),char(186),char(3),char(18), -char(255),char(236),char(2),char(186),char(3),char(28),char(255),char(236),char(2),char(187), -char(1),char(159),char(255),char(215),char(2),char(187),char(1),char(163),char(0),char(225), -char(2),char(187),char(1),char(184),char(255),char(215),char(2),char(187),char(1),char(187), -char(255),char(215),char(2),char(187),char(1),char(190),char(255),char(195),char(2),char(187), -char(1),char(220),char(255),char(215),char(2),char(187),char(1),char(225),char(255),char(174), -char(2),char(187),char(1),char(228),char(255),char(215),char(2),char(187),char(2),char(108), -char(255),char(215),char(2),char(187),char(2),char(123),char(0),char(61),char(2),char(187), -char(2),char(125),char(255),char(236),char(2),char(187),char(2),char(126),char(255),char(215), -char(2),char(187),char(2),char(132),char(255),char(215),char(2),char(187),char(2),char(134), -char(255),char(215),char(2),char(187),char(2),char(136),char(255),char(215),char(2),char(187), -char(2),char(138),char(255),char(215),char(2),char(187),char(2),char(140),char(255),char(215), -char(2),char(187),char(2),char(170),char(255),char(215),char(2),char(187),char(2),char(177), -char(255),char(215),char(2),char(187),char(2),char(179),char(255),char(215),char(2),char(187), -char(2),char(182),char(255),char(215),char(2),char(187),char(2),char(190),char(255),char(215), -char(2),char(187),char(2),char(192),char(255),char(174),char(2),char(187),char(2),char(194), -char(255),char(174),char(2),char(187),char(2),char(197),char(255),char(195),char(2),char(187), -char(2),char(198),char(255),char(215),char(2),char(187),char(2),char(199),char(255),char(195), -char(2),char(187),char(2),char(200),char(255),char(215),char(2),char(187),char(2),char(213), -char(255),char(174),char(2),char(187),char(2),char(239),char(255),char(215),char(2),char(187), -char(2),char(241),char(255),char(215),char(2),char(187),char(2),char(243),char(255),char(215), -char(2),char(187),char(2),char(254),char(255),char(174),char(2),char(187),char(3),char(14), -char(255),char(215),char(2),char(187),char(3),char(16),char(255),char(215),char(2),char(187), -char(3),char(21),char(255),char(215),char(2),char(187),char(3),char(24),char(255),char(215), -char(2),char(188),char(1),char(207),char(255),char(236),char(2),char(188),char(1),char(216), -char(255),char(236),char(2),char(188),char(1),char(219),char(255),char(236),char(2),char(188), -char(1),char(222),char(255),char(236),char(2),char(188),char(1),char(225),char(255),char(236), -char(2),char(188),char(1),char(234),char(255),char(236),char(2),char(188),char(1),char(237), -char(255),char(236),char(2),char(188),char(2),char(106),char(255),char(236),char(2),char(188), -char(2),char(127),char(255),char(236),char(2),char(188),char(2),char(133),char(255),char(236), -char(2),char(188),char(2),char(135),char(255),char(236),char(2),char(188),char(2),char(137), -char(255),char(236),char(2),char(188),char(2),char(141),char(255),char(236),char(2),char(188), -char(2),char(178),char(255),char(236),char(2),char(188),char(2),char(180),char(255),char(236), -char(2),char(188),char(2),char(192),char(255),char(236),char(2),char(188),char(2),char(194), -char(255),char(236),char(2),char(188),char(2),char(213),char(255),char(236),char(2),char(188), -char(2),char(224),char(255),char(236),char(2),char(188),char(2),char(240),char(255),char(236), -char(2),char(188),char(2),char(242),char(255),char(236),char(2),char(188),char(2),char(244), -char(255),char(236),char(2),char(188),char(2),char(254),char(255),char(236),char(2),char(188), -char(3),char(10),char(255),char(236),char(2),char(188),char(3),char(12),char(255),char(236), -char(2),char(188),char(3),char(14),char(255),char(215),char(2),char(188),char(3),char(16), -char(255),char(215),char(2),char(188),char(3),char(22),char(255),char(236),char(2),char(188), -char(3),char(26),char(255),char(236),char(2),char(189),char(1),char(163),char(0),char(225), -char(2),char(189),char(2),char(234),char(0),char(41),char(2),char(189),char(3),char(14), -char(255),char(215),char(2),char(189),char(3),char(16),char(255),char(215),char(2),char(190), -char(0),char(5),char(255),char(236),char(2),char(190),char(0),char(10),char(255),char(236), -char(2),char(190),char(2),char(7),char(255),char(236),char(2),char(190),char(2),char(11), -char(255),char(236),char(2),char(191),char(1),char(163),char(0),char(225),char(2),char(191), -char(2),char(234),char(0),char(41),char(2),char(191),char(3),char(14),char(255),char(215), -char(2),char(191),char(3),char(16),char(255),char(215),char(2),char(192),char(0),char(5), -char(255),char(236),char(2),char(192),char(0),char(10),char(255),char(236),char(2),char(192), -char(2),char(7),char(255),char(236),char(2),char(192),char(2),char(11),char(255),char(236), -char(2),char(195),char(0),char(5),char(255),char(195),char(2),char(195),char(0),char(10), -char(255),char(195),char(2),char(195),char(1),char(157),char(255),char(215),char(2),char(195), -char(1),char(166),char(255),char(215),char(2),char(195),char(1),char(188),char(255),char(133), -char(2),char(195),char(1),char(193),char(255),char(174),char(2),char(195),char(1),char(196), -char(255),char(215),char(2),char(195),char(1),char(220),char(255),char(215),char(2),char(195), -char(1),char(221),char(255),char(236),char(2),char(195),char(1),char(225),char(255),char(236), -char(2),char(195),char(1),char(228),char(255),char(215),char(2),char(195),char(1),char(246), -char(255),char(236),char(2),char(195),char(2),char(7),char(255),char(195),char(2),char(195), -char(2),char(11),char(255),char(195),char(2),char(195),char(2),char(124),char(255),char(174), -char(2),char(195),char(2),char(128),char(255),char(195),char(2),char(195),char(2),char(130), -char(255),char(195),char(2),char(195),char(2),char(169),char(255),char(215),char(2),char(195), -char(2),char(170),char(255),char(215),char(2),char(195),char(2),char(181),char(255),char(133), -char(2),char(195),char(2),char(182),char(255),char(215),char(2),char(195),char(2),char(183), -char(255),char(154),char(2),char(195),char(2),char(185),char(255),char(154),char(2),char(195), -char(2),char(189),char(255),char(215),char(2),char(195),char(2),char(190),char(255),char(215), -char(2),char(195),char(2),char(191),char(255),char(174),char(2),char(195),char(2),char(192), -char(255),char(236),char(2),char(195),char(2),char(193),char(255),char(174),char(2),char(195), -char(2),char(194),char(255),char(236),char(2),char(195),char(2),char(212),char(255),char(174), -char(2),char(195),char(2),char(213),char(255),char(236),char(2),char(195),char(2),char(248), -char(255),char(236),char(2),char(195),char(2),char(250),char(255),char(236),char(2),char(195), -char(2),char(252),char(255),char(236),char(2),char(195),char(2),char(253),char(255),char(174), -char(2),char(195),char(2),char(254),char(255),char(236),char(2),char(195),char(3),char(13), -char(255),char(174),char(2),char(195),char(3),char(14),char(255),char(215),char(2),char(195), -char(3),char(15),char(255),char(174),char(2),char(195),char(3),char(16),char(255),char(215), -char(2),char(195),char(3),char(23),char(255),char(215),char(2),char(195),char(3),char(24), -char(255),char(215),char(2),char(196),char(0),char(5),char(255),char(154),char(2),char(196), -char(0),char(10),char(255),char(154),char(2),char(196),char(1),char(220),char(255),char(215), -char(2),char(196),char(1),char(221),char(255),char(215),char(2),char(196),char(1),char(228), -char(255),char(215),char(2),char(196),char(1),char(246),char(255),char(215),char(2),char(196), -char(2),char(7),char(255),char(154),char(2),char(196),char(2),char(11),char(255),char(154), -char(2),char(196),char(2),char(170),char(255),char(215),char(2),char(196),char(2),char(182), -char(255),char(215),char(2),char(196),char(2),char(184),char(255),char(215),char(2),char(196), -char(2),char(186),char(255),char(215),char(2),char(196),char(2),char(190),char(255),char(215), -char(2),char(196),char(2),char(248),char(255),char(215),char(2),char(196),char(2),char(250), -char(255),char(215),char(2),char(196),char(2),char(252),char(255),char(215),char(2),char(196), -char(3),char(14),char(255),char(174),char(2),char(196),char(3),char(16),char(255),char(174), -char(2),char(196),char(3),char(24),char(255),char(215),char(2),char(197),char(1),char(188), -char(255),char(215),char(2),char(197),char(2),char(128),char(255),char(236),char(2),char(197), -char(2),char(130),char(255),char(236),char(2),char(197),char(2),char(181),char(255),char(215), -char(2),char(197),char(2),char(183),char(255),char(236),char(2),char(197),char(2),char(185), -char(255),char(236),char(2),char(197),char(3),char(13),char(255),char(236),char(2),char(197), -char(3),char(15),char(255),char(236),char(2),char(198),char(0),char(5),char(255),char(236), -char(2),char(198),char(0),char(10),char(255),char(236),char(2),char(198),char(2),char(7), -char(255),char(236),char(2),char(198),char(2),char(11),char(255),char(236),char(2),char(199), -char(1),char(188),char(255),char(215),char(2),char(199),char(2),char(128),char(255),char(236), -char(2),char(199),char(2),char(130),char(255),char(236),char(2),char(199),char(2),char(181), -char(255),char(215),char(2),char(199),char(2),char(183),char(255),char(236),char(2),char(199), -char(2),char(185),char(255),char(236),char(2),char(199),char(3),char(13),char(255),char(236), -char(2),char(199),char(3),char(15),char(255),char(236),char(2),char(200),char(0),char(5), -char(255),char(236),char(2),char(200),char(0),char(10),char(255),char(236),char(2),char(200), -char(2),char(7),char(255),char(236),char(2),char(200),char(2),char(11),char(255),char(236), -char(2),char(202),char(1),char(159),char(255),char(215),char(2),char(202),char(1),char(184), -char(255),char(215),char(2),char(202),char(1),char(187),char(255),char(215),char(2),char(202), -char(1),char(190),char(255),char(215),char(2),char(202),char(1),char(193),char(255),char(215), -char(2),char(202),char(1),char(225),char(255),char(215),char(2),char(202),char(2),char(108), -char(255),char(215),char(2),char(202),char(2),char(124),char(255),char(215),char(2),char(202), -char(2),char(126),char(255),char(215),char(2),char(202),char(2),char(132),char(255),char(215), -char(2),char(202),char(2),char(134),char(255),char(215),char(2),char(202),char(2),char(136), -char(255),char(215),char(2),char(202),char(2),char(138),char(255),char(215),char(2),char(202), -char(2),char(140),char(255),char(215),char(2),char(202),char(2),char(177),char(255),char(215), -char(2),char(202),char(2),char(179),char(255),char(215),char(2),char(202),char(2),char(191), -char(255),char(215),char(2),char(202),char(2),char(192),char(255),char(215),char(2),char(202), -char(2),char(193),char(255),char(215),char(2),char(202),char(2),char(194),char(255),char(215), -char(2),char(202),char(2),char(197),char(255),char(154),char(2),char(202),char(2),char(199), -char(255),char(154),char(2),char(202),char(2),char(212),char(255),char(215),char(2),char(202), -char(2),char(213),char(255),char(215),char(2),char(202),char(2),char(239),char(255),char(215), -char(2),char(202),char(2),char(241),char(255),char(215),char(2),char(202),char(2),char(243), -char(255),char(215),char(2),char(202),char(2),char(253),char(255),char(215),char(2),char(202), -char(2),char(254),char(255),char(215),char(2),char(202),char(3),char(9),char(255),char(215), -char(2),char(202),char(3),char(11),char(255),char(215),char(2),char(202),char(3),char(14), -char(255),char(215),char(2),char(202),char(3),char(16),char(255),char(215),char(2),char(202), -char(3),char(21),char(255),char(215),char(2),char(202),char(3),char(25),char(255),char(236), -char(2),char(203),char(1),char(207),char(255),char(215),char(2),char(203),char(1),char(216), -char(255),char(215),char(2),char(203),char(1),char(219),char(255),char(215),char(2),char(203), -char(1),char(222),char(255),char(215),char(2),char(203),char(1),char(225),char(255),char(215), -char(2),char(203),char(1),char(234),char(255),char(215),char(2),char(203),char(1),char(237), -char(255),char(215),char(2),char(203),char(2),char(106),char(255),char(215),char(2),char(203), -char(2),char(127),char(255),char(215),char(2),char(203),char(2),char(133),char(255),char(215), -char(2),char(203),char(2),char(135),char(255),char(215),char(2),char(203),char(2),char(137), -char(255),char(215),char(2),char(203),char(2),char(141),char(255),char(215),char(2),char(203), -char(2),char(178),char(255),char(215),char(2),char(203),char(2),char(180),char(255),char(215), -char(2),char(203),char(2),char(192),char(255),char(215),char(2),char(203),char(2),char(194), -char(255),char(215),char(2),char(203),char(2),char(198),char(255),char(215),char(2),char(203), -char(2),char(200),char(255),char(215),char(2),char(203),char(2),char(213),char(255),char(215), -char(2),char(203),char(2),char(224),char(255),char(215),char(2),char(203),char(2),char(240), -char(255),char(215),char(2),char(203),char(2),char(242),char(255),char(215),char(2),char(203), -char(2),char(244),char(255),char(215),char(2),char(203),char(2),char(254),char(255),char(215), -char(2),char(203),char(3),char(10),char(255),char(215),char(2),char(203),char(3),char(12), -char(255),char(215),char(2),char(203),char(3),char(22),char(255),char(215),char(2),char(203), -char(3),char(26),char(255),char(215),char(2),char(204),char(0),char(5),char(255),char(195), -char(2),char(204),char(0),char(10),char(255),char(195),char(2),char(204),char(1),char(163), -char(0),char(102),char(2),char(204),char(1),char(188),char(255),char(215),char(2),char(204), -char(1),char(190),char(255),char(215),char(2),char(204),char(1),char(193),char(255),char(174), -char(2),char(204),char(1),char(220),char(255),char(195),char(2),char(204),char(1),char(225), -char(255),char(215),char(2),char(204),char(1),char(228),char(255),char(195),char(2),char(204), -char(2),char(7),char(255),char(195),char(2),char(204),char(2),char(11),char(255),char(195), -char(2),char(204),char(2),char(109),char(255),char(236),char(2),char(204),char(2),char(124), -char(255),char(174),char(2),char(204),char(2),char(128),char(255),char(215),char(2),char(204), -char(2),char(129),char(255),char(236),char(2),char(204),char(2),char(130),char(255),char(215), -char(2),char(204),char(2),char(131),char(255),char(236),char(2),char(204),char(2),char(139), -char(255),char(236),char(2),char(204),char(2),char(170),char(255),char(195),char(2),char(204), -char(2),char(181),char(255),char(215),char(2),char(204),char(2),char(182),char(255),char(195), -char(2),char(204),char(2),char(183),char(255),char(215),char(2),char(204),char(2),char(184), -char(255),char(236),char(2),char(204),char(2),char(185),char(255),char(215),char(2),char(204), -char(2),char(186),char(255),char(236),char(2),char(204),char(2),char(190),char(255),char(195), -char(2),char(204),char(2),char(191),char(255),char(174),char(2),char(204),char(2),char(192), -char(255),char(215),char(2),char(204),char(2),char(193),char(255),char(174),char(2),char(204), -char(2),char(194),char(255),char(215),char(2),char(204),char(2),char(197),char(255),char(195), -char(2),char(204),char(2),char(198),char(255),char(215),char(2),char(204),char(2),char(199), -char(255),char(195),char(2),char(204),char(2),char(200),char(255),char(215),char(2),char(204), -char(2),char(212),char(255),char(174),char(2),char(204),char(2),char(213),char(255),char(215), -char(2),char(204),char(2),char(253),char(255),char(174),char(2),char(204),char(2),char(254), -char(255),char(215),char(2),char(204),char(3),char(13),char(255),char(215),char(2),char(204), -char(3),char(14),char(255),char(195),char(2),char(204),char(3),char(15),char(255),char(215), -char(2),char(204),char(3),char(16),char(255),char(195),char(2),char(204),char(3),char(24), -char(255),char(195),char(2),char(205),char(1),char(225),char(255),char(215),char(2),char(205), -char(2),char(192),char(255),char(215),char(2),char(205),char(2),char(194),char(255),char(215), -char(2),char(205),char(2),char(213),char(255),char(215),char(2),char(205),char(2),char(254), -char(255),char(215),char(2),char(206),char(1),char(163),char(0),char(225),char(2),char(206), -char(2),char(234),char(0),char(41),char(2),char(206),char(3),char(14),char(255),char(215), -char(2),char(206),char(3),char(16),char(255),char(215),char(2),char(207),char(0),char(5), -char(255),char(236),char(2),char(207),char(0),char(10),char(255),char(236),char(2),char(207), -char(2),char(7),char(255),char(236),char(2),char(207),char(2),char(11),char(255),char(236), -char(2),char(210),char(1),char(163),char(0),char(225),char(2),char(210),char(2),char(234), -char(0),char(41),char(2),char(210),char(3),char(14),char(255),char(215),char(2),char(210), -char(3),char(16),char(255),char(215),char(2),char(211),char(0),char(5),char(255),char(236), -char(2),char(211),char(0),char(10),char(255),char(236),char(2),char(211),char(2),char(7), -char(255),char(236),char(2),char(211),char(2),char(11),char(255),char(236),char(2),char(214), -char(1),char(163),char(0),char(225),char(2),char(214),char(2),char(234),char(0),char(41), -char(2),char(214),char(3),char(14),char(255),char(215),char(2),char(214),char(3),char(16), -char(255),char(215),char(2),char(215),char(0),char(5),char(255),char(236),char(2),char(215), -char(0),char(10),char(255),char(236),char(2),char(215),char(2),char(7),char(255),char(236), -char(2),char(215),char(2),char(11),char(255),char(236),char(2),char(217),char(0),char(5), -char(255),char(113),char(2),char(217),char(0),char(10),char(255),char(113),char(2),char(217), -char(1),char(157),char(255),char(154),char(2),char(217),char(1),char(166),char(255),char(154), -char(2),char(217),char(1),char(188),char(255),char(113),char(2),char(217),char(1),char(190), -char(255),char(215),char(2),char(217),char(1),char(193),char(255),char(154),char(2),char(217), -char(1),char(196),char(255),char(154),char(2),char(217),char(1),char(220),char(255),char(215), -char(2),char(217),char(1),char(225),char(255),char(215),char(2),char(217),char(1),char(228), -char(255),char(215),char(2),char(217),char(2),char(7),char(255),char(113),char(2),char(217), -char(2),char(11),char(255),char(113),char(2),char(217),char(2),char(110),char(255),char(215), -char(2),char(217),char(2),char(124),char(255),char(154),char(2),char(217),char(2),char(128), -char(255),char(174),char(2),char(217),char(2),char(130),char(255),char(174),char(2),char(217), -char(2),char(151),char(255),char(215),char(2),char(217),char(2),char(155),char(255),char(215), -char(2),char(217),char(2),char(167),char(255),char(215),char(2),char(217),char(2),char(169), -char(255),char(154),char(2),char(217),char(2),char(170),char(255),char(215),char(2),char(217), -char(2),char(181),char(255),char(113),char(2),char(217),char(2),char(182),char(255),char(215), -char(2),char(217),char(2),char(183),char(255),char(133),char(2),char(217),char(2),char(185), -char(255),char(133),char(2),char(217),char(2),char(189),char(255),char(154),char(2),char(217), -char(2),char(190),char(255),char(215),char(2),char(217),char(2),char(191),char(255),char(154), -char(2),char(217),char(2),char(192),char(255),char(215),char(2),char(217),char(2),char(193), -char(255),char(154),char(2),char(217),char(2),char(194),char(255),char(215),char(2),char(217), -char(2),char(197),char(255),char(154),char(2),char(217),char(2),char(199),char(255),char(154), -char(2),char(217),char(2),char(212),char(255),char(154),char(2),char(217),char(2),char(213), -char(255),char(215),char(2),char(217),char(2),char(225),char(255),char(215),char(2),char(217), -char(2),char(227),char(255),char(215),char(2),char(217),char(2),char(253),char(255),char(154), -char(2),char(217),char(2),char(254),char(255),char(215),char(2),char(217),char(3),char(3), -char(255),char(215),char(2),char(217),char(3),char(13),char(255),char(113),char(2),char(217), -char(3),char(14),char(255),char(215),char(2),char(217),char(3),char(15),char(255),char(113), -char(2),char(217),char(3),char(16),char(255),char(215),char(2),char(217),char(3),char(23), -char(255),char(154),char(2),char(217),char(3),char(24),char(255),char(215),char(2),char(218), -char(0),char(5),char(255),char(236),char(2),char(218),char(0),char(10),char(255),char(236), -char(2),char(218),char(2),char(7),char(255),char(236),char(2),char(218),char(2),char(11), -char(255),char(236),char(2),char(219),char(0),char(5),char(255),char(113),char(2),char(219), -char(0),char(10),char(255),char(113),char(2),char(219),char(1),char(157),char(255),char(154), -char(2),char(219),char(1),char(166),char(255),char(154),char(2),char(219),char(1),char(188), -char(255),char(113),char(2),char(219),char(1),char(190),char(255),char(215),char(2),char(219), -char(1),char(193),char(255),char(154),char(2),char(219),char(1),char(196),char(255),char(154), -char(2),char(219),char(1),char(220),char(255),char(215),char(2),char(219),char(1),char(225), -char(255),char(215),char(2),char(219),char(1),char(228),char(255),char(215),char(2),char(219), -char(2),char(7),char(255),char(113),char(2),char(219),char(2),char(11),char(255),char(113), -char(2),char(219),char(2),char(110),char(255),char(215),char(2),char(219),char(2),char(124), -char(255),char(154),char(2),char(219),char(2),char(128),char(255),char(174),char(2),char(219), -char(2),char(130),char(255),char(174),char(2),char(219),char(2),char(151),char(255),char(215), -char(2),char(219),char(2),char(155),char(255),char(215),char(2),char(219),char(2),char(167), -char(255),char(215),char(2),char(219),char(2),char(169),char(255),char(154),char(2),char(219), -char(2),char(170),char(255),char(215),char(2),char(219),char(2),char(181),char(255),char(113), -char(2),char(219),char(2),char(182),char(255),char(215),char(2),char(219),char(2),char(183), -char(255),char(133),char(2),char(219),char(2),char(185),char(255),char(133),char(2),char(219), -char(2),char(189),char(255),char(154),char(2),char(219),char(2),char(190),char(255),char(215), -char(2),char(219),char(2),char(191),char(255),char(154),char(2),char(219),char(2),char(192), -char(255),char(215),char(2),char(219),char(2),char(193),char(255),char(154),char(2),char(219), -char(2),char(194),char(255),char(215),char(2),char(219),char(2),char(197),char(255),char(154), -char(2),char(219),char(2),char(199),char(255),char(154),char(2),char(219),char(2),char(212), -char(255),char(154),char(2),char(219),char(2),char(213),char(255),char(215),char(2),char(219), -char(2),char(225),char(255),char(215),char(2),char(219),char(2),char(227),char(255),char(215), -char(2),char(219),char(2),char(253),char(255),char(154),char(2),char(219),char(2),char(254), -char(255),char(215),char(2),char(219),char(3),char(3),char(255),char(215),char(2),char(219), -char(3),char(13),char(255),char(113),char(2),char(219),char(3),char(14),char(255),char(215), -char(2),char(219),char(3),char(15),char(255),char(113),char(2),char(219),char(3),char(16), -char(255),char(215),char(2),char(219),char(3),char(23),char(255),char(154),char(2),char(219), -char(3),char(24),char(255),char(215),char(2),char(220),char(0),char(5),char(255),char(236), -char(2),char(220),char(0),char(10),char(255),char(236),char(2),char(220),char(2),char(7), -char(255),char(236),char(2),char(220),char(2),char(11),char(255),char(236),char(2),char(222), -char(0),char(5),char(255),char(236),char(2),char(222),char(0),char(10),char(255),char(236), -char(2),char(222),char(2),char(7),char(255),char(236),char(2),char(222),char(2),char(11), -char(255),char(236),char(2),char(224),char(0),char(5),char(255),char(236),char(2),char(224), -char(0),char(10),char(255),char(236),char(2),char(224),char(2),char(7),char(255),char(236), -char(2),char(224),char(2),char(11),char(255),char(236),char(2),char(225),char(0),char(15), -char(255),char(174),char(2),char(225),char(0),char(17),char(255),char(174),char(2),char(225), -char(1),char(157),char(255),char(236),char(2),char(225),char(1),char(164),char(255),char(215), -char(2),char(225),char(1),char(166),char(255),char(236),char(2),char(225),char(1),char(168), -char(255),char(215),char(2),char(225),char(1),char(170),char(255),char(215),char(2),char(225), -char(1),char(174),char(255),char(215),char(2),char(225),char(1),char(176),char(255),char(215), -char(2),char(225),char(1),char(177),char(255),char(236),char(2),char(225),char(1),char(181), -char(255),char(215),char(2),char(225),char(1),char(188),char(255),char(195),char(2),char(225), -char(1),char(189),char(255),char(215),char(2),char(225),char(1),char(191),char(255),char(215), -char(2),char(225),char(1),char(193),char(255),char(215),char(2),char(225),char(1),char(196), -char(255),char(236),char(2),char(225),char(1),char(199),char(255),char(236),char(2),char(225), -char(1),char(206),char(255),char(236),char(2),char(225),char(1),char(213),char(255),char(236), -char(2),char(225),char(1),char(242),char(255),char(236),char(2),char(225),char(2),char(8), -char(255),char(174),char(2),char(225),char(2),char(12),char(255),char(174),char(2),char(225), -char(2),char(114),char(255),char(215),char(2),char(225),char(2),char(115),char(255),char(236), -char(2),char(225),char(2),char(122),char(255),char(236),char(2),char(225),char(2),char(124), -char(255),char(215),char(2),char(225),char(2),char(128),char(255),char(236),char(2),char(225), -char(2),char(130),char(255),char(236),char(2),char(225),char(2),char(159),char(255),char(215), -char(2),char(225),char(2),char(161),char(255),char(236),char(2),char(225),char(2),char(169), -char(255),char(236),char(2),char(225),char(2),char(181),char(255),char(195),char(2),char(225), -char(2),char(183),char(255),char(236),char(2),char(225),char(2),char(185),char(255),char(236), -char(2),char(225),char(2),char(187),char(255),char(215),char(2),char(225),char(2),char(189), -char(255),char(236),char(2),char(225),char(2),char(191),char(255),char(215),char(2),char(225), -char(2),char(193),char(255),char(215),char(2),char(225),char(2),char(202),char(255),char(215), -char(2),char(225),char(2),char(206),char(255),char(215),char(2),char(225),char(2),char(207), -char(255),char(236),char(2),char(225),char(2),char(212),char(255),char(215),char(2),char(225), -char(2),char(217),char(255),char(215),char(2),char(225),char(2),char(219),char(255),char(215), -char(2),char(225),char(2),char(221),char(255),char(215),char(2),char(225),char(2),char(229), -char(255),char(215),char(2),char(225),char(2),char(231),char(255),char(236),char(2),char(225), -char(2),char(245),char(255),char(236),char(2),char(225),char(2),char(247),char(255),char(215), -char(2),char(225),char(2),char(249),char(255),char(215),char(2),char(225),char(2),char(251), -char(255),char(215),char(2),char(225),char(2),char(253),char(255),char(215),char(2),char(225), -char(3),char(5),char(255),char(215),char(2),char(225),char(3),char(7),char(255),char(215), -char(2),char(225),char(3),char(13),char(255),char(215),char(2),char(225),char(3),char(15), -char(255),char(215),char(2),char(225),char(3),char(17),char(255),char(215),char(2),char(225), -char(3),char(18),char(255),char(236),char(2),char(225),char(3),char(23),char(255),char(236), -char(2),char(225),char(3),char(27),char(255),char(215),char(2),char(225),char(3),char(28), -char(255),char(236),char(2),char(226),char(0),char(5),char(255),char(236),char(2),char(226), -char(0),char(10),char(255),char(236),char(2),char(226),char(1),char(208),char(255),char(215), -char(2),char(226),char(1),char(220),char(255),char(236),char(2),char(226),char(1),char(221), -char(255),char(236),char(2),char(226),char(1),char(223),char(255),char(215),char(2),char(226), -char(1),char(225),char(255),char(236),char(2),char(226),char(1),char(228),char(255),char(236), -char(2),char(226),char(1),char(246),char(255),char(236),char(2),char(226),char(2),char(7), -char(255),char(236),char(2),char(226),char(2),char(11),char(255),char(236),char(2),char(226), -char(2),char(160),char(255),char(215),char(2),char(226),char(2),char(170),char(255),char(236), -char(2),char(226),char(2),char(182),char(255),char(236),char(2),char(226),char(2),char(188), -char(255),char(215),char(2),char(226),char(2),char(190),char(255),char(236),char(2),char(226), -char(2),char(192),char(255),char(236),char(2),char(226),char(2),char(194),char(255),char(236), -char(2),char(226),char(2),char(203),char(255),char(215),char(2),char(226),char(2),char(213), -char(255),char(236),char(2),char(226),char(2),char(230),char(255),char(215),char(2),char(226), -char(2),char(248),char(255),char(236),char(2),char(226),char(2),char(250),char(255),char(236), -char(2),char(226),char(2),char(252),char(255),char(236),char(2),char(226),char(2),char(254), -char(255),char(236),char(2),char(226),char(3),char(6),char(255),char(215),char(2),char(226), -char(3),char(8),char(255),char(215),char(2),char(226),char(3),char(14),char(255),char(236), -char(2),char(226),char(3),char(16),char(255),char(236),char(2),char(226),char(3),char(24), -char(255),char(236),char(2),char(227),char(0),char(15),char(255),char(174),char(2),char(227), -char(0),char(17),char(255),char(174),char(2),char(227),char(1),char(157),char(255),char(236), -char(2),char(227),char(1),char(164),char(255),char(215),char(2),char(227),char(1),char(166), -char(255),char(236),char(2),char(227),char(1),char(168),char(255),char(215),char(2),char(227), -char(1),char(170),char(255),char(215),char(2),char(227),char(1),char(174),char(255),char(215), -char(2),char(227),char(1),char(176),char(255),char(215),char(2),char(227),char(1),char(177), -char(255),char(236),char(2),char(227),char(1),char(181),char(255),char(215),char(2),char(227), -char(1),char(188),char(255),char(195),char(2),char(227),char(1),char(189),char(255),char(215), -char(2),char(227),char(1),char(191),char(255),char(215),char(2),char(227),char(1),char(193), -char(255),char(215),char(2),char(227),char(1),char(196),char(255),char(236),char(2),char(227), -char(1),char(199),char(255),char(236),char(2),char(227),char(1),char(206),char(255),char(236), -char(2),char(227),char(1),char(213),char(255),char(236),char(2),char(227),char(1),char(242), -char(255),char(236),char(2),char(227),char(2),char(8),char(255),char(174),char(2),char(227), -char(2),char(12),char(255),char(174),char(2),char(227),char(2),char(114),char(255),char(215), -char(2),char(227),char(2),char(115),char(255),char(236),char(2),char(227),char(2),char(122), -char(255),char(236),char(2),char(227),char(2),char(124),char(255),char(215),char(2),char(227), -char(2),char(128),char(255),char(236),char(2),char(227),char(2),char(130),char(255),char(236), -char(2),char(227),char(2),char(159),char(255),char(215),char(2),char(227),char(2),char(161), -char(255),char(236),char(2),char(227),char(2),char(169),char(255),char(236),char(2),char(227), -char(2),char(181),char(255),char(195),char(2),char(227),char(2),char(183),char(255),char(236), -char(2),char(227),char(2),char(185),char(255),char(236),char(2),char(227),char(2),char(187), -char(255),char(215),char(2),char(227),char(2),char(189),char(255),char(236),char(2),char(227), -char(2),char(191),char(255),char(215),char(2),char(227),char(2),char(193),char(255),char(215), -char(2),char(227),char(2),char(202),char(255),char(215),char(2),char(227),char(2),char(206), -char(255),char(215),char(2),char(227),char(2),char(207),char(255),char(236),char(2),char(227), -char(2),char(212),char(255),char(215),char(2),char(227),char(2),char(217),char(255),char(215), -char(2),char(227),char(2),char(219),char(255),char(215),char(2),char(227),char(2),char(221), -char(255),char(215),char(2),char(227),char(2),char(229),char(255),char(215),char(2),char(227), -char(2),char(231),char(255),char(236),char(2),char(227),char(2),char(245),char(255),char(236), -char(2),char(227),char(2),char(247),char(255),char(215),char(2),char(227),char(2),char(249), -char(255),char(215),char(2),char(227),char(2),char(251),char(255),char(215),char(2),char(227), -char(2),char(253),char(255),char(215),char(2),char(227),char(3),char(5),char(255),char(215), -char(2),char(227),char(3),char(7),char(255),char(215),char(2),char(227),char(3),char(13), -char(255),char(215),char(2),char(227),char(3),char(15),char(255),char(215),char(2),char(227), -char(3),char(17),char(255),char(215),char(2),char(227),char(3),char(18),char(255),char(236), -char(2),char(227),char(3),char(23),char(255),char(236),char(2),char(227),char(3),char(27), -char(255),char(215),char(2),char(227),char(3),char(28),char(255),char(236),char(2),char(228), -char(0),char(5),char(255),char(236),char(2),char(228),char(0),char(10),char(255),char(236), -char(2),char(228),char(1),char(208),char(255),char(215),char(2),char(228),char(1),char(220), -char(255),char(236),char(2),char(228),char(1),char(221),char(255),char(236),char(2),char(228), -char(1),char(223),char(255),char(215),char(2),char(228),char(1),char(225),char(255),char(236), -char(2),char(228),char(1),char(228),char(255),char(236),char(2),char(228),char(1),char(246), -char(255),char(236),char(2),char(228),char(2),char(7),char(255),char(236),char(2),char(228), -char(2),char(11),char(255),char(236),char(2),char(228),char(2),char(160),char(255),char(215), -char(2),char(228),char(2),char(170),char(255),char(236),char(2),char(228),char(2),char(182), -char(255),char(236),char(2),char(228),char(2),char(188),char(255),char(215),char(2),char(228), -char(2),char(190),char(255),char(236),char(2),char(228),char(2),char(192),char(255),char(236), -char(2),char(228),char(2),char(194),char(255),char(236),char(2),char(228),char(2),char(203), -char(255),char(215),char(2),char(228),char(2),char(213),char(255),char(236),char(2),char(228), -char(2),char(230),char(255),char(215),char(2),char(228),char(2),char(248),char(255),char(236), -char(2),char(228),char(2),char(250),char(255),char(236),char(2),char(228),char(2),char(252), -char(255),char(236),char(2),char(228),char(2),char(254),char(255),char(236),char(2),char(228), -char(3),char(6),char(255),char(215),char(2),char(228),char(3),char(8),char(255),char(215), -char(2),char(228),char(3),char(14),char(255),char(236),char(2),char(228),char(3),char(16), -char(255),char(236),char(2),char(228),char(3),char(24),char(255),char(236),char(2),char(229), -char(1),char(159),char(255),char(215),char(2),char(229),char(1),char(184),char(255),char(215), -char(2),char(229),char(1),char(187),char(255),char(215),char(2),char(229),char(1),char(190), -char(255),char(215),char(2),char(229),char(1),char(193),char(255),char(215),char(2),char(229), -char(1),char(225),char(255),char(215),char(2),char(229),char(2),char(108),char(255),char(215), -char(2),char(229),char(2),char(124),char(255),char(215),char(2),char(229),char(2),char(126), -char(255),char(215),char(2),char(229),char(2),char(132),char(255),char(215),char(2),char(229), -char(2),char(134),char(255),char(215),char(2),char(229),char(2),char(136),char(255),char(215), -char(2),char(229),char(2),char(138),char(255),char(215),char(2),char(229),char(2),char(140), -char(255),char(215),char(2),char(229),char(2),char(177),char(255),char(215),char(2),char(229), -char(2),char(179),char(255),char(215),char(2),char(229),char(2),char(191),char(255),char(215), -char(2),char(229),char(2),char(192),char(255),char(215),char(2),char(229),char(2),char(193), -char(255),char(215),char(2),char(229),char(2),char(194),char(255),char(215),char(2),char(229), -char(2),char(197),char(255),char(154),char(2),char(229),char(2),char(199),char(255),char(154), -char(2),char(229),char(2),char(212),char(255),char(215),char(2),char(229),char(2),char(213), -char(255),char(215),char(2),char(229),char(2),char(239),char(255),char(215),char(2),char(229), -char(2),char(241),char(255),char(215),char(2),char(229),char(2),char(243),char(255),char(215), -char(2),char(229),char(2),char(253),char(255),char(215),char(2),char(229),char(2),char(254), -char(255),char(215),char(2),char(229),char(3),char(9),char(255),char(215),char(2),char(229), -char(3),char(11),char(255),char(215),char(2),char(229),char(3),char(14),char(255),char(215), -char(2),char(229),char(3),char(16),char(255),char(215),char(2),char(229),char(3),char(21), -char(255),char(215),char(2),char(229),char(3),char(25),char(255),char(236),char(2),char(230), -char(1),char(207),char(255),char(215),char(2),char(230),char(1),char(216),char(255),char(215), -char(2),char(230),char(1),char(219),char(255),char(215),char(2),char(230),char(1),char(222), -char(255),char(215),char(2),char(230),char(1),char(225),char(255),char(215),char(2),char(230), -char(1),char(234),char(255),char(215),char(2),char(230),char(1),char(237),char(255),char(215), -char(2),char(230),char(2),char(106),char(255),char(215),char(2),char(230),char(2),char(127), -char(255),char(215),char(2),char(230),char(2),char(133),char(255),char(215),char(2),char(230), -char(2),char(135),char(255),char(215),char(2),char(230),char(2),char(137),char(255),char(215), -char(2),char(230),char(2),char(141),char(255),char(215),char(2),char(230),char(2),char(178), -char(255),char(215),char(2),char(230),char(2),char(180),char(255),char(215),char(2),char(230), -char(2),char(192),char(255),char(215),char(2),char(230),char(2),char(194),char(255),char(215), -char(2),char(230),char(2),char(198),char(255),char(215),char(2),char(230),char(2),char(200), -char(255),char(215),char(2),char(230),char(2),char(213),char(255),char(215),char(2),char(230), -char(2),char(224),char(255),char(215),char(2),char(230),char(2),char(240),char(255),char(215), -char(2),char(230),char(2),char(242),char(255),char(215),char(2),char(230),char(2),char(244), -char(255),char(215),char(2),char(230),char(2),char(254),char(255),char(215),char(2),char(230), -char(3),char(10),char(255),char(215),char(2),char(230),char(3),char(12),char(255),char(215), -char(2),char(230),char(3),char(22),char(255),char(215),char(2),char(230),char(3),char(26), -char(255),char(215),char(2),char(231),char(0),char(15),char(255),char(174),char(2),char(231), -char(0),char(17),char(255),char(174),char(2),char(231),char(2),char(8),char(255),char(174), -char(2),char(231),char(2),char(12),char(255),char(174),char(2),char(231),char(2),char(128), -char(255),char(236),char(2),char(231),char(2),char(130),char(255),char(236),char(2),char(231), -char(2),char(183),char(255),char(236),char(2),char(231),char(2),char(185),char(255),char(236), -char(2),char(231),char(3),char(13),char(255),char(215),char(2),char(231),char(3),char(15), -char(255),char(215),char(2),char(232),char(1),char(233),char(0),char(41),char(2),char(233), -char(0),char(5),char(255),char(236),char(2),char(233),char(0),char(10),char(255),char(236), -char(2),char(233),char(2),char(7),char(255),char(236),char(2),char(233),char(2),char(11), -char(255),char(236),char(2),char(233),char(3),char(14),char(255),char(215),char(2),char(233), -char(3),char(16),char(255),char(215),char(2),char(239),char(0),char(15),char(255),char(174), -char(2),char(239),char(0),char(17),char(255),char(174),char(2),char(239),char(1),char(157), -char(255),char(236),char(2),char(239),char(1),char(164),char(255),char(215),char(2),char(239), -char(1),char(166),char(255),char(236),char(2),char(239),char(1),char(168),char(255),char(215), -char(2),char(239),char(1),char(170),char(255),char(215),char(2),char(239),char(1),char(174), -char(255),char(215),char(2),char(239),char(1),char(176),char(255),char(215),char(2),char(239), -char(1),char(177),char(255),char(236),char(2),char(239),char(1),char(181),char(255),char(215), -char(2),char(239),char(1),char(188),char(255),char(195),char(2),char(239),char(1),char(189), -char(255),char(215),char(2),char(239),char(1),char(191),char(255),char(215),char(2),char(239), -char(1),char(193),char(255),char(215),char(2),char(239),char(1),char(196),char(255),char(236), -char(2),char(239),char(1),char(199),char(255),char(236),char(2),char(239),char(1),char(206), -char(255),char(236),char(2),char(239),char(1),char(213),char(255),char(236),char(2),char(239), -char(1),char(242),char(255),char(236),char(2),char(239),char(2),char(8),char(255),char(174), -char(2),char(239),char(2),char(12),char(255),char(174),char(2),char(239),char(2),char(114), -char(255),char(215),char(2),char(239),char(2),char(115),char(255),char(236),char(2),char(239), -char(2),char(122),char(255),char(236),char(2),char(239),char(2),char(124),char(255),char(215), -char(2),char(239),char(2),char(128),char(255),char(236),char(2),char(239),char(2),char(130), -char(255),char(236),char(2),char(239),char(2),char(159),char(255),char(215),char(2),char(239), -char(2),char(161),char(255),char(236),char(2),char(239),char(2),char(169),char(255),char(236), -char(2),char(239),char(2),char(181),char(255),char(195),char(2),char(239),char(2),char(183), -char(255),char(236),char(2),char(239),char(2),char(185),char(255),char(236),char(2),char(239), -char(2),char(187),char(255),char(215),char(2),char(239),char(2),char(189),char(255),char(236), -char(2),char(239),char(2),char(191),char(255),char(215),char(2),char(239),char(2),char(193), -char(255),char(215),char(2),char(239),char(2),char(202),char(255),char(215),char(2),char(239), -char(2),char(206),char(255),char(215),char(2),char(239),char(2),char(207),char(255),char(236), -char(2),char(239),char(2),char(212),char(255),char(215),char(2),char(239),char(2),char(217), -char(255),char(215),char(2),char(239),char(2),char(219),char(255),char(215),char(2),char(239), -char(2),char(221),char(255),char(215),char(2),char(239),char(2),char(229),char(255),char(215), -char(2),char(239),char(2),char(231),char(255),char(236),char(2),char(239),char(2),char(245), -char(255),char(236),char(2),char(239),char(2),char(247),char(255),char(215),char(2),char(239), -char(2),char(249),char(255),char(215),char(2),char(239),char(2),char(251),char(255),char(215), -char(2),char(239),char(2),char(253),char(255),char(215),char(2),char(239),char(3),char(5), -char(255),char(215),char(2),char(239),char(3),char(7),char(255),char(215),char(2),char(239), -char(3),char(13),char(255),char(215),char(2),char(239),char(3),char(15),char(255),char(215), -char(2),char(239),char(3),char(17),char(255),char(215),char(2),char(239),char(3),char(18), -char(255),char(236),char(2),char(239),char(3),char(23),char(255),char(236),char(2),char(239), -char(3),char(27),char(255),char(215),char(2),char(239),char(3),char(28),char(255),char(236), -char(2),char(240),char(0),char(5),char(255),char(236),char(2),char(240),char(0),char(10), -char(255),char(236),char(2),char(240),char(1),char(208),char(255),char(215),char(2),char(240), -char(1),char(220),char(255),char(236),char(2),char(240),char(1),char(221),char(255),char(236), -char(2),char(240),char(1),char(223),char(255),char(215),char(2),char(240),char(1),char(225), -char(255),char(236),char(2),char(240),char(1),char(228),char(255),char(236),char(2),char(240), -char(1),char(246),char(255),char(236),char(2),char(240),char(2),char(7),char(255),char(236), -char(2),char(240),char(2),char(11),char(255),char(236),char(2),char(240),char(2),char(160), -char(255),char(215),char(2),char(240),char(2),char(170),char(255),char(236),char(2),char(240), -char(2),char(182),char(255),char(236),char(2),char(240),char(2),char(188),char(255),char(215), -char(2),char(240),char(2),char(190),char(255),char(236),char(2),char(240),char(2),char(192), -char(255),char(236),char(2),char(240),char(2),char(194),char(255),char(236),char(2),char(240), -char(2),char(203),char(255),char(215),char(2),char(240),char(2),char(213),char(255),char(236), -char(2),char(240),char(2),char(230),char(255),char(215),char(2),char(240),char(2),char(248), -char(255),char(236),char(2),char(240),char(2),char(250),char(255),char(236),char(2),char(240), -char(2),char(252),char(255),char(236),char(2),char(240),char(2),char(254),char(255),char(236), -char(2),char(240),char(3),char(6),char(255),char(215),char(2),char(240),char(3),char(8), -char(255),char(215),char(2),char(240),char(3),char(14),char(255),char(236),char(2),char(240), -char(3),char(16),char(255),char(236),char(2),char(240),char(3),char(24),char(255),char(236), -char(2),char(241),char(0),char(15),char(255),char(174),char(2),char(241),char(0),char(17), -char(255),char(174),char(2),char(241),char(1),char(157),char(255),char(236),char(2),char(241), -char(1),char(164),char(255),char(215),char(2),char(241),char(1),char(166),char(255),char(236), -char(2),char(241),char(1),char(168),char(255),char(215),char(2),char(241),char(1),char(170), -char(255),char(215),char(2),char(241),char(1),char(174),char(255),char(215),char(2),char(241), -char(1),char(176),char(255),char(215),char(2),char(241),char(1),char(177),char(255),char(236), -char(2),char(241),char(1),char(181),char(255),char(215),char(2),char(241),char(1),char(188), -char(255),char(195),char(2),char(241),char(1),char(189),char(255),char(215),char(2),char(241), -char(1),char(191),char(255),char(215),char(2),char(241),char(1),char(193),char(255),char(215), -char(2),char(241),char(1),char(196),char(255),char(236),char(2),char(241),char(1),char(199), -char(255),char(236),char(2),char(241),char(1),char(206),char(255),char(236),char(2),char(241), -char(1),char(213),char(255),char(236),char(2),char(241),char(1),char(242),char(255),char(236), -char(2),char(241),char(2),char(8),char(255),char(174),char(2),char(241),char(2),char(12), -char(255),char(174),char(2),char(241),char(2),char(114),char(255),char(215),char(2),char(241), -char(2),char(115),char(255),char(236),char(2),char(241),char(2),char(122),char(255),char(236), -char(2),char(241),char(2),char(124),char(255),char(215),char(2),char(241),char(2),char(128), -char(255),char(236),char(2),char(241),char(2),char(130),char(255),char(236),char(2),char(241), -char(2),char(159),char(255),char(215),char(2),char(241),char(2),char(161),char(255),char(236), -char(2),char(241),char(2),char(169),char(255),char(236),char(2),char(241),char(2),char(181), -char(255),char(195),char(2),char(241),char(2),char(183),char(255),char(236),char(2),char(241), -char(2),char(185),char(255),char(236),char(2),char(241),char(2),char(187),char(255),char(215), -char(2),char(241),char(2),char(189),char(255),char(236),char(2),char(241),char(2),char(191), -char(255),char(215),char(2),char(241),char(2),char(193),char(255),char(215),char(2),char(241), -char(2),char(202),char(255),char(215),char(2),char(241),char(2),char(206),char(255),char(215), -char(2),char(241),char(2),char(207),char(255),char(236),char(2),char(241),char(2),char(212), -char(255),char(215),char(2),char(241),char(2),char(217),char(255),char(215),char(2),char(241), -char(2),char(219),char(255),char(215),char(2),char(241),char(2),char(221),char(255),char(215), -char(2),char(241),char(2),char(229),char(255),char(215),char(2),char(241),char(2),char(231), -char(255),char(236),char(2),char(241),char(2),char(245),char(255),char(236),char(2),char(241), -char(2),char(247),char(255),char(215),char(2),char(241),char(2),char(249),char(255),char(215), -char(2),char(241),char(2),char(251),char(255),char(215),char(2),char(241),char(2),char(253), -char(255),char(215),char(2),char(241),char(3),char(5),char(255),char(215),char(2),char(241), -char(3),char(7),char(255),char(215),char(2),char(241),char(3),char(13),char(255),char(215), -char(2),char(241),char(3),char(15),char(255),char(215),char(2),char(241),char(3),char(17), -char(255),char(215),char(2),char(241),char(3),char(18),char(255),char(236),char(2),char(241), -char(3),char(23),char(255),char(236),char(2),char(241),char(3),char(27),char(255),char(215), -char(2),char(241),char(3),char(28),char(255),char(236),char(2),char(242),char(0),char(5), -char(255),char(236),char(2),char(242),char(0),char(10),char(255),char(236),char(2),char(242), -char(1),char(208),char(255),char(215),char(2),char(242),char(1),char(220),char(255),char(236), -char(2),char(242),char(1),char(221),char(255),char(236),char(2),char(242),char(1),char(223), -char(255),char(215),char(2),char(242),char(1),char(225),char(255),char(236),char(2),char(242), -char(1),char(228),char(255),char(236),char(2),char(242),char(1),char(246),char(255),char(236), -char(2),char(242),char(2),char(7),char(255),char(236),char(2),char(242),char(2),char(11), -char(255),char(236),char(2),char(242),char(2),char(160),char(255),char(215),char(2),char(242), -char(2),char(170),char(255),char(236),char(2),char(242),char(2),char(182),char(255),char(236), -char(2),char(242),char(2),char(188),char(255),char(215),char(2),char(242),char(2),char(190), -char(255),char(236),char(2),char(242),char(2),char(192),char(255),char(236),char(2),char(242), -char(2),char(194),char(255),char(236),char(2),char(242),char(2),char(203),char(255),char(215), -char(2),char(242),char(2),char(213),char(255),char(236),char(2),char(242),char(2),char(230), -char(255),char(215),char(2),char(242),char(2),char(248),char(255),char(236),char(2),char(242), -char(2),char(250),char(255),char(236),char(2),char(242),char(2),char(252),char(255),char(236), -char(2),char(242),char(2),char(254),char(255),char(236),char(2),char(242),char(3),char(6), -char(255),char(215),char(2),char(242),char(3),char(8),char(255),char(215),char(2),char(242), -char(3),char(14),char(255),char(236),char(2),char(242),char(3),char(16),char(255),char(236), -char(2),char(242),char(3),char(24),char(255),char(236),char(2),char(243),char(0),char(15), -char(255),char(174),char(2),char(243),char(0),char(17),char(255),char(174),char(2),char(243), -char(1),char(157),char(255),char(236),char(2),char(243),char(1),char(164),char(255),char(215), -char(2),char(243),char(1),char(166),char(255),char(236),char(2),char(243),char(1),char(168), -char(255),char(215),char(2),char(243),char(1),char(170),char(255),char(215),char(2),char(243), -char(1),char(174),char(255),char(215),char(2),char(243),char(1),char(176),char(255),char(215), -char(2),char(243),char(1),char(177),char(255),char(236),char(2),char(243),char(1),char(181), -char(255),char(215),char(2),char(243),char(1),char(188),char(255),char(195),char(2),char(243), -char(1),char(189),char(255),char(215),char(2),char(243),char(1),char(191),char(255),char(215), -char(2),char(243),char(1),char(193),char(255),char(215),char(2),char(243),char(1),char(196), -char(255),char(236),char(2),char(243),char(1),char(199),char(255),char(236),char(2),char(243), -char(1),char(206),char(255),char(236),char(2),char(243),char(1),char(213),char(255),char(236), -char(2),char(243),char(1),char(242),char(255),char(236),char(2),char(243),char(2),char(8), -char(255),char(174),char(2),char(243),char(2),char(12),char(255),char(174),char(2),char(243), -char(2),char(114),char(255),char(215),char(2),char(243),char(2),char(115),char(255),char(236), -char(2),char(243),char(2),char(122),char(255),char(236),char(2),char(243),char(2),char(124), -char(255),char(215),char(2),char(243),char(2),char(128),char(255),char(236),char(2),char(243), -char(2),char(130),char(255),char(236),char(2),char(243),char(2),char(159),char(255),char(215), -char(2),char(243),char(2),char(161),char(255),char(236),char(2),char(243),char(2),char(169), -char(255),char(236),char(2),char(243),char(2),char(181),char(255),char(195),char(2),char(243), -char(2),char(183),char(255),char(236),char(2),char(243),char(2),char(185),char(255),char(236), -char(2),char(243),char(2),char(187),char(255),char(215),char(2),char(243),char(2),char(189), -char(255),char(236),char(2),char(243),char(2),char(191),char(255),char(215),char(2),char(243), -char(2),char(193),char(255),char(215),char(2),char(243),char(2),char(202),char(255),char(215), -char(2),char(243),char(2),char(206),char(255),char(215),char(2),char(243),char(2),char(207), -char(255),char(236),char(2),char(243),char(2),char(212),char(255),char(215),char(2),char(243), -char(2),char(217),char(255),char(215),char(2),char(243),char(2),char(219),char(255),char(215), -char(2),char(243),char(2),char(221),char(255),char(215),char(2),char(243),char(2),char(229), -char(255),char(215),char(2),char(243),char(2),char(231),char(255),char(236),char(2),char(243), -char(2),char(245),char(255),char(236),char(2),char(243),char(2),char(247),char(255),char(215), -char(2),char(243),char(2),char(249),char(255),char(215),char(2),char(243),char(2),char(251), -char(255),char(215),char(2),char(243),char(2),char(253),char(255),char(215),char(2),char(243), -char(3),char(5),char(255),char(215),char(2),char(243),char(3),char(7),char(255),char(215), -char(2),char(243),char(3),char(13),char(255),char(215),char(2),char(243),char(3),char(15), -char(255),char(215),char(2),char(243),char(3),char(17),char(255),char(215),char(2),char(243), -char(3),char(18),char(255),char(236),char(2),char(243),char(3),char(23),char(255),char(236), -char(2),char(243),char(3),char(27),char(255),char(215),char(2),char(243),char(3),char(28), -char(255),char(236),char(2),char(244),char(0),char(5),char(255),char(236),char(2),char(244), -char(0),char(10),char(255),char(236),char(2),char(244),char(1),char(208),char(255),char(215), -char(2),char(244),char(1),char(220),char(255),char(236),char(2),char(244),char(1),char(221), -char(255),char(236),char(2),char(244),char(1),char(223),char(255),char(215),char(2),char(244), -char(1),char(225),char(255),char(236),char(2),char(244),char(1),char(228),char(255),char(236), -char(2),char(244),char(1),char(246),char(255),char(236),char(2),char(244),char(2),char(7), -char(255),char(236),char(2),char(244),char(2),char(11),char(255),char(236),char(2),char(244), -char(2),char(160),char(255),char(215),char(2),char(244),char(2),char(170),char(255),char(236), -char(2),char(244),char(2),char(182),char(255),char(236),char(2),char(244),char(2),char(188), -char(255),char(215),char(2),char(244),char(2),char(190),char(255),char(236),char(2),char(244), -char(2),char(192),char(255),char(236),char(2),char(244),char(2),char(194),char(255),char(236), -char(2),char(244),char(2),char(203),char(255),char(215),char(2),char(244),char(2),char(213), -char(255),char(236),char(2),char(244),char(2),char(230),char(255),char(215),char(2),char(244), -char(2),char(248),char(255),char(236),char(2),char(244),char(2),char(250),char(255),char(236), -char(2),char(244),char(2),char(252),char(255),char(236),char(2),char(244),char(2),char(254), -char(255),char(236),char(2),char(244),char(3),char(6),char(255),char(215),char(2),char(244), -char(3),char(8),char(255),char(215),char(2),char(244),char(3),char(14),char(255),char(236), -char(2),char(244),char(3),char(16),char(255),char(236),char(2),char(244),char(3),char(24), -char(255),char(236),char(2),char(245),char(0),char(15),char(255),char(174),char(2),char(245), -char(0),char(17),char(255),char(174),char(2),char(245),char(1),char(157),char(255),char(236), -char(2),char(245),char(1),char(164),char(255),char(215),char(2),char(245),char(1),char(166), -char(255),char(236),char(2),char(245),char(1),char(168),char(255),char(215),char(2),char(245), -char(1),char(170),char(255),char(215),char(2),char(245),char(1),char(174),char(255),char(215), -char(2),char(245),char(1),char(176),char(255),char(215),char(2),char(245),char(1),char(177), -char(255),char(236),char(2),char(245),char(1),char(181),char(255),char(215),char(2),char(245), -char(1),char(188),char(255),char(195),char(2),char(245),char(1),char(189),char(255),char(215), -char(2),char(245),char(1),char(191),char(255),char(215),char(2),char(245),char(1),char(193), -char(255),char(215),char(2),char(245),char(1),char(196),char(255),char(236),char(2),char(245), -char(1),char(199),char(255),char(236),char(2),char(245),char(1),char(206),char(255),char(236), -char(2),char(245),char(1),char(213),char(255),char(236),char(2),char(245),char(1),char(242), -char(255),char(236),char(2),char(245),char(2),char(8),char(255),char(174),char(2),char(245), -char(2),char(12),char(255),char(174),char(2),char(245),char(2),char(114),char(255),char(215), -char(2),char(245),char(2),char(115),char(255),char(236),char(2),char(245),char(2),char(122), -char(255),char(236),char(2),char(245),char(2),char(124),char(255),char(215),char(2),char(245), -char(2),char(128),char(255),char(236),char(2),char(245),char(2),char(130),char(255),char(236), -char(2),char(245),char(2),char(159),char(255),char(215),char(2),char(245),char(2),char(161), -char(255),char(236),char(2),char(245),char(2),char(169),char(255),char(236),char(2),char(245), -char(2),char(181),char(255),char(195),char(2),char(245),char(2),char(183),char(255),char(236), -char(2),char(245),char(2),char(185),char(255),char(236),char(2),char(245),char(2),char(187), -char(255),char(215),char(2),char(245),char(2),char(189),char(255),char(236),char(2),char(245), -char(2),char(191),char(255),char(215),char(2),char(245),char(2),char(193),char(255),char(215), -char(2),char(245),char(2),char(202),char(255),char(215),char(2),char(245),char(2),char(206), -char(255),char(215),char(2),char(245),char(2),char(207),char(255),char(236),char(2),char(245), -char(2),char(212),char(255),char(215),char(2),char(245),char(2),char(217),char(255),char(215), -char(2),char(245),char(2),char(219),char(255),char(215),char(2),char(245),char(2),char(221), -char(255),char(215),char(2),char(245),char(2),char(229),char(255),char(215),char(2),char(245), -char(2),char(231),char(255),char(236),char(2),char(245),char(2),char(245),char(255),char(236), -char(2),char(245),char(2),char(247),char(255),char(215),char(2),char(245),char(2),char(249), -char(255),char(215),char(2),char(245),char(2),char(251),char(255),char(215),char(2),char(245), -char(2),char(253),char(255),char(215),char(2),char(245),char(3),char(5),char(255),char(215), -char(2),char(245),char(3),char(7),char(255),char(215),char(2),char(245),char(3),char(13), -char(255),char(215),char(2),char(245),char(3),char(15),char(255),char(215),char(2),char(245), -char(3),char(17),char(255),char(215),char(2),char(245),char(3),char(18),char(255),char(236), -char(2),char(245),char(3),char(23),char(255),char(236),char(2),char(245),char(3),char(27), -char(255),char(215),char(2),char(245),char(3),char(28),char(255),char(236),char(2),char(246), -char(0),char(5),char(255),char(236),char(2),char(246),char(0),char(10),char(255),char(236), -char(2),char(246),char(1),char(208),char(255),char(215),char(2),char(246),char(1),char(220), -char(255),char(236),char(2),char(246),char(1),char(221),char(255),char(236),char(2),char(246), -char(1),char(223),char(255),char(215),char(2),char(246),char(1),char(225),char(255),char(236), -char(2),char(246),char(1),char(228),char(255),char(236),char(2),char(246),char(1),char(246), -char(255),char(236),char(2),char(246),char(2),char(7),char(255),char(236),char(2),char(246), -char(2),char(11),char(255),char(236),char(2),char(246),char(2),char(160),char(255),char(215), -char(2),char(246),char(2),char(170),char(255),char(236),char(2),char(246),char(2),char(182), -char(255),char(236),char(2),char(246),char(2),char(188),char(255),char(215),char(2),char(246), -char(2),char(190),char(255),char(236),char(2),char(246),char(2),char(192),char(255),char(236), -char(2),char(246),char(2),char(194),char(255),char(236),char(2),char(246),char(2),char(203), -char(255),char(215),char(2),char(246),char(2),char(213),char(255),char(236),char(2),char(246), -char(2),char(230),char(255),char(215),char(2),char(246),char(2),char(248),char(255),char(236), -char(2),char(246),char(2),char(250),char(255),char(236),char(2),char(246),char(2),char(252), -char(255),char(236),char(2),char(246),char(2),char(254),char(255),char(236),char(2),char(246), -char(3),char(6),char(255),char(215),char(2),char(246),char(3),char(8),char(255),char(215), -char(2),char(246),char(3),char(14),char(255),char(236),char(2),char(246),char(3),char(16), -char(255),char(236),char(2),char(246),char(3),char(24),char(255),char(236),char(2),char(247), -char(0),char(15),char(255),char(133),char(2),char(247),char(0),char(17),char(255),char(133), -char(2),char(247),char(1),char(159),char(255),char(236),char(2),char(247),char(1),char(164), -char(255),char(154),char(2),char(247),char(1),char(170),char(255),char(113),char(2),char(247), -char(1),char(174),char(255),char(154),char(2),char(247),char(1),char(181),char(255),char(154), -char(2),char(247),char(1),char(184),char(255),char(236),char(2),char(247),char(1),char(187), -char(255),char(236),char(2),char(247),char(1),char(190),char(255),char(195),char(2),char(247), -char(1),char(201),char(255),char(236),char(2),char(247),char(1),char(206),char(255),char(174), -char(2),char(247),char(1),char(207),char(255),char(215),char(2),char(247),char(1),char(213), -char(255),char(174),char(2),char(247),char(1),char(216),char(255),char(215),char(2),char(247), -char(1),char(219),char(255),char(215),char(2),char(247),char(1),char(222),char(255),char(215), -char(2),char(247),char(1),char(225),char(255),char(215),char(2),char(247),char(1),char(234), -char(255),char(215),char(2),char(247),char(1),char(235),char(0),char(102),char(2),char(247), -char(1),char(237),char(255),char(215),char(2),char(247),char(1),char(238),char(255),char(236), -char(2),char(247),char(1),char(242),char(255),char(174),char(2),char(247),char(1),char(244), -char(0),char(102),char(2),char(247),char(2),char(8),char(255),char(133),char(2),char(247), -char(2),char(12),char(255),char(133),char(2),char(247),char(2),char(106),char(255),char(215), -char(2),char(247),char(2),char(108),char(255),char(236),char(2),char(247),char(2),char(114), -char(255),char(113),char(2),char(247),char(2),char(115),char(255),char(174),char(2),char(247), -char(2),char(126),char(255),char(236),char(2),char(247),char(2),char(127),char(255),char(215), -char(2),char(247),char(2),char(132),char(255),char(236),char(2),char(247),char(2),char(133), -char(255),char(215),char(2),char(247),char(2),char(134),char(255),char(236),char(2),char(247), -char(2),char(135),char(255),char(215),char(2),char(247),char(2),char(136),char(255),char(236), -char(2),char(247),char(2),char(137),char(255),char(215),char(2),char(247),char(2),char(138), -char(255),char(236),char(2),char(247),char(2),char(140),char(255),char(236),char(2),char(247), -char(2),char(141),char(255),char(215),char(2),char(247),char(2),char(152),char(0),char(102), -char(2),char(247),char(2),char(168),char(0),char(102),char(2),char(247),char(2),char(177), -char(255),char(236),char(2),char(247),char(2),char(178),char(255),char(215),char(2),char(247), -char(2),char(179),char(255),char(236),char(2),char(247),char(2),char(180),char(255),char(215), -char(2),char(247),char(2),char(192),char(255),char(215),char(2),char(247),char(2),char(194), -char(255),char(215),char(2),char(247),char(2),char(197),char(255),char(215),char(2),char(247), -char(2),char(198),char(255),char(195),char(2),char(247),char(2),char(199),char(255),char(215), -char(2),char(247),char(2),char(200),char(255),char(195),char(2),char(247),char(2),char(206), -char(255),char(154),char(2),char(247),char(2),char(207),char(255),char(174),char(2),char(247), -char(2),char(213),char(255),char(215),char(2),char(247),char(2),char(217),char(255),char(113), -char(2),char(247),char(2),char(219),char(255),char(113),char(2),char(247),char(2),char(221), -char(255),char(113),char(2),char(247),char(2),char(224),char(255),char(215),char(2),char(247), -char(2),char(239),char(255),char(236),char(2),char(247),char(2),char(240),char(255),char(215), -char(2),char(247),char(2),char(241),char(255),char(236),char(2),char(247),char(2),char(242), -char(255),char(215),char(2),char(247),char(2),char(243),char(255),char(236),char(2),char(247), -char(2),char(244),char(255),char(215),char(2),char(247),char(2),char(254),char(255),char(215), -char(2),char(247),char(3),char(9),char(255),char(113),char(2),char(247),char(3),char(10), -char(255),char(215),char(2),char(247),char(3),char(11),char(255),char(113),char(2),char(247), -char(3),char(12),char(255),char(215),char(2),char(247),char(3),char(17),char(255),char(154), -char(2),char(247),char(3),char(18),char(255),char(174),char(2),char(247),char(3),char(21), -char(255),char(236),char(2),char(247),char(3),char(22),char(255),char(215),char(2),char(247), -char(3),char(26),char(255),char(215),char(2),char(247),char(3),char(27),char(255),char(154), -char(2),char(247),char(3),char(28),char(255),char(174),char(2),char(248),char(0),char(15), -char(255),char(174),char(2),char(248),char(0),char(17),char(255),char(174),char(2),char(248), -char(1),char(206),char(255),char(215),char(2),char(248),char(1),char(213),char(255),char(215), -char(2),char(248),char(1),char(242),char(255),char(215),char(2),char(248),char(2),char(8), -char(255),char(174),char(2),char(248),char(2),char(12),char(255),char(174),char(2),char(248), -char(2),char(115),char(255),char(215),char(2),char(248),char(2),char(207),char(255),char(215), -char(2),char(248),char(3),char(18),char(255),char(215),char(2),char(248),char(3),char(28), -char(255),char(215),char(2),char(249),char(0),char(15),char(255),char(133),char(2),char(249), -char(0),char(17),char(255),char(133),char(2),char(249),char(1),char(159),char(255),char(236), -char(2),char(249),char(1),char(164),char(255),char(154),char(2),char(249),char(1),char(170), -char(255),char(113),char(2),char(249),char(1),char(174),char(255),char(154),char(2),char(249), -char(1),char(181),char(255),char(154),char(2),char(249),char(1),char(184),char(255),char(236), -char(2),char(249),char(1),char(187),char(255),char(236),char(2),char(249),char(1),char(190), -char(255),char(195),char(2),char(249),char(1),char(201),char(255),char(236),char(2),char(249), -char(1),char(206),char(255),char(174),char(2),char(249),char(1),char(207),char(255),char(215), -char(2),char(249),char(1),char(213),char(255),char(174),char(2),char(249),char(1),char(216), -char(255),char(215),char(2),char(249),char(1),char(219),char(255),char(215),char(2),char(249), -char(1),char(222),char(255),char(215),char(2),char(249),char(1),char(225),char(255),char(215), -char(2),char(249),char(1),char(234),char(255),char(215),char(2),char(249),char(1),char(235), -char(0),char(102),char(2),char(249),char(1),char(237),char(255),char(215),char(2),char(249), -char(1),char(238),char(255),char(236),char(2),char(249),char(1),char(242),char(255),char(174), -char(2),char(249),char(1),char(244),char(0),char(102),char(2),char(249),char(2),char(8), -char(255),char(133),char(2),char(249),char(2),char(12),char(255),char(133),char(2),char(249), -char(2),char(106),char(255),char(215),char(2),char(249),char(2),char(108),char(255),char(236), -char(2),char(249),char(2),char(114),char(255),char(113),char(2),char(249),char(2),char(115), -char(255),char(174),char(2),char(249),char(2),char(126),char(255),char(236),char(2),char(249), -char(2),char(127),char(255),char(215),char(2),char(249),char(2),char(132),char(255),char(236), -char(2),char(249),char(2),char(133),char(255),char(215),char(2),char(249),char(2),char(134), -char(255),char(236),char(2),char(249),char(2),char(135),char(255),char(215),char(2),char(249), -char(2),char(136),char(255),char(236),char(2),char(249),char(2),char(137),char(255),char(215), -char(2),char(249),char(2),char(138),char(255),char(236),char(2),char(249),char(2),char(140), -char(255),char(236),char(2),char(249),char(2),char(141),char(255),char(215),char(2),char(249), -char(2),char(152),char(0),char(102),char(2),char(249),char(2),char(168),char(0),char(102), -char(2),char(249),char(2),char(177),char(255),char(236),char(2),char(249),char(2),char(178), -char(255),char(215),char(2),char(249),char(2),char(179),char(255),char(236),char(2),char(249), -char(2),char(180),char(255),char(215),char(2),char(249),char(2),char(192),char(255),char(215), -char(2),char(249),char(2),char(194),char(255),char(215),char(2),char(249),char(2),char(197), -char(255),char(215),char(2),char(249),char(2),char(198),char(255),char(195),char(2),char(249), -char(2),char(199),char(255),char(215),char(2),char(249),char(2),char(200),char(255),char(195), -char(2),char(249),char(2),char(206),char(255),char(154),char(2),char(249),char(2),char(207), -char(255),char(174),char(2),char(249),char(2),char(213),char(255),char(215),char(2),char(249), -char(2),char(217),char(255),char(113),char(2),char(249),char(2),char(219),char(255),char(113), -char(2),char(249),char(2),char(221),char(255),char(113),char(2),char(249),char(2),char(224), -char(255),char(215),char(2),char(249),char(2),char(239),char(255),char(236),char(2),char(249), -char(2),char(240),char(255),char(215),char(2),char(249),char(2),char(241),char(255),char(236), -char(2),char(249),char(2),char(242),char(255),char(215),char(2),char(249),char(2),char(243), -char(255),char(236),char(2),char(249),char(2),char(244),char(255),char(215),char(2),char(249), -char(2),char(254),char(255),char(215),char(2),char(249),char(3),char(9),char(255),char(113), -char(2),char(249),char(3),char(10),char(255),char(215),char(2),char(249),char(3),char(11), -char(255),char(113),char(2),char(249),char(3),char(12),char(255),char(215),char(2),char(249), -char(3),char(17),char(255),char(154),char(2),char(249),char(3),char(18),char(255),char(174), -char(2),char(249),char(3),char(21),char(255),char(236),char(2),char(249),char(3),char(22), -char(255),char(215),char(2),char(249),char(3),char(26),char(255),char(215),char(2),char(249), -char(3),char(27),char(255),char(154),char(2),char(249),char(3),char(28),char(255),char(174), -char(2),char(250),char(0),char(15),char(255),char(174),char(2),char(250),char(0),char(17), -char(255),char(174),char(2),char(250),char(1),char(206),char(255),char(215),char(2),char(250), -char(1),char(213),char(255),char(215),char(2),char(250),char(1),char(242),char(255),char(215), -char(2),char(250),char(2),char(8),char(255),char(174),char(2),char(250),char(2),char(12), -char(255),char(174),char(2),char(250),char(2),char(115),char(255),char(215),char(2),char(250), -char(2),char(207),char(255),char(215),char(2),char(250),char(3),char(18),char(255),char(215), -char(2),char(250),char(3),char(28),char(255),char(215),char(2),char(251),char(0),char(15), -char(255),char(133),char(2),char(251),char(0),char(17),char(255),char(133),char(2),char(251), -char(1),char(159),char(255),char(236),char(2),char(251),char(1),char(164),char(255),char(154), -char(2),char(251),char(1),char(170),char(255),char(113),char(2),char(251),char(1),char(174), -char(255),char(154),char(2),char(251),char(1),char(181),char(255),char(154),char(2),char(251), -char(1),char(184),char(255),char(236),char(2),char(251),char(1),char(187),char(255),char(236), -char(2),char(251),char(1),char(190),char(255),char(195),char(2),char(251),char(1),char(201), -char(255),char(236),char(2),char(251),char(1),char(206),char(255),char(174),char(2),char(251), -char(1),char(207),char(255),char(215),char(2),char(251),char(1),char(213),char(255),char(174), -char(2),char(251),char(1),char(216),char(255),char(215),char(2),char(251),char(1),char(219), -char(255),char(215),char(2),char(251),char(1),char(222),char(255),char(215),char(2),char(251), -char(1),char(225),char(255),char(215),char(2),char(251),char(1),char(234),char(255),char(215), -char(2),char(251),char(1),char(235),char(0),char(102),char(2),char(251),char(1),char(237), -char(255),char(215),char(2),char(251),char(1),char(238),char(255),char(236),char(2),char(251), -char(1),char(242),char(255),char(174),char(2),char(251),char(1),char(244),char(0),char(102), -char(2),char(251),char(2),char(8),char(255),char(133),char(2),char(251),char(2),char(12), -char(255),char(133),char(2),char(251),char(2),char(106),char(255),char(215),char(2),char(251), -char(2),char(108),char(255),char(236),char(2),char(251),char(2),char(114),char(255),char(113), -char(2),char(251),char(2),char(115),char(255),char(174),char(2),char(251),char(2),char(126), -char(255),char(236),char(2),char(251),char(2),char(127),char(255),char(215),char(2),char(251), -char(2),char(132),char(255),char(236),char(2),char(251),char(2),char(133),char(255),char(215), -char(2),char(251),char(2),char(134),char(255),char(236),char(2),char(251),char(2),char(135), -char(255),char(215),char(2),char(251),char(2),char(136),char(255),char(236),char(2),char(251), -char(2),char(137),char(255),char(215),char(2),char(251),char(2),char(138),char(255),char(236), -char(2),char(251),char(2),char(140),char(255),char(236),char(2),char(251),char(2),char(141), -char(255),char(215),char(2),char(251),char(2),char(152),char(0),char(102),char(2),char(251), -char(2),char(168),char(0),char(102),char(2),char(251),char(2),char(177),char(255),char(236), -char(2),char(251),char(2),char(178),char(255),char(215),char(2),char(251),char(2),char(179), -char(255),char(236),char(2),char(251),char(2),char(180),char(255),char(215),char(2),char(251), -char(2),char(192),char(255),char(215),char(2),char(251),char(2),char(194),char(255),char(215), -char(2),char(251),char(2),char(197),char(255),char(215),char(2),char(251),char(2),char(198), -char(255),char(195),char(2),char(251),char(2),char(199),char(255),char(215),char(2),char(251), -char(2),char(200),char(255),char(195),char(2),char(251),char(2),char(206),char(255),char(154), -char(2),char(251),char(2),char(207),char(255),char(174),char(2),char(251),char(2),char(213), -char(255),char(215),char(2),char(251),char(2),char(217),char(255),char(113),char(2),char(251), -char(2),char(219),char(255),char(113),char(2),char(251),char(2),char(221),char(255),char(113), -char(2),char(251),char(2),char(224),char(255),char(215),char(2),char(251),char(2),char(239), -char(255),char(236),char(2),char(251),char(2),char(240),char(255),char(215),char(2),char(251), -char(2),char(241),char(255),char(236),char(2),char(251),char(2),char(242),char(255),char(215), -char(2),char(251),char(2),char(243),char(255),char(236),char(2),char(251),char(2),char(244), -char(255),char(215),char(2),char(251),char(2),char(254),char(255),char(215),char(2),char(251), -char(3),char(9),char(255),char(113),char(2),char(251),char(3),char(10),char(255),char(215), -char(2),char(251),char(3),char(11),char(255),char(113),char(2),char(251),char(3),char(12), -char(255),char(215),char(2),char(251),char(3),char(17),char(255),char(154),char(2),char(251), -char(3),char(18),char(255),char(174),char(2),char(251),char(3),char(21),char(255),char(236), -char(2),char(251),char(3),char(22),char(255),char(215),char(2),char(251),char(3),char(26), -char(255),char(215),char(2),char(251),char(3),char(27),char(255),char(154),char(2),char(251), -char(3),char(28),char(255),char(174),char(2),char(252),char(0),char(15),char(255),char(174), -char(2),char(252),char(0),char(17),char(255),char(174),char(2),char(252),char(1),char(206), -char(255),char(215),char(2),char(252),char(1),char(213),char(255),char(215),char(2),char(252), -char(1),char(242),char(255),char(215),char(2),char(252),char(2),char(8),char(255),char(174), -char(2),char(252),char(2),char(12),char(255),char(174),char(2),char(252),char(2),char(115), -char(255),char(215),char(2),char(252),char(2),char(207),char(255),char(215),char(2),char(252), -char(3),char(18),char(255),char(215),char(2),char(252),char(3),char(28),char(255),char(215), -char(2),char(255),char(0),char(15),char(255),char(133),char(2),char(255),char(0),char(16), -char(255),char(174),char(2),char(255),char(0),char(17),char(255),char(133),char(2),char(255), -char(1),char(159),char(255),char(215),char(2),char(255),char(1),char(164),char(255),char(154), -char(2),char(255),char(1),char(170),char(255),char(113),char(2),char(255),char(1),char(174), -char(255),char(154),char(2),char(255),char(1),char(181),char(255),char(154),char(2),char(255), -char(1),char(184),char(255),char(215),char(2),char(255),char(1),char(187),char(255),char(215), -char(2),char(255),char(1),char(188),char(0),char(41),char(2),char(255),char(1),char(190), -char(255),char(174),char(2),char(255),char(1),char(204),char(255),char(154),char(2),char(255), -char(1),char(205),char(255),char(154),char(2),char(255),char(1),char(206),char(255),char(133), -char(2),char(255),char(1),char(207),char(255),char(113),char(2),char(255),char(1),char(208), -char(255),char(215),char(2),char(255),char(1),char(209),char(255),char(215),char(2),char(255), -char(1),char(210),char(255),char(154),char(2),char(255),char(1),char(211),char(255),char(154), -char(2),char(255),char(1),char(212),char(255),char(154),char(2),char(255),char(1),char(213), -char(255),char(133),char(2),char(255),char(1),char(214),char(255),char(154),char(2),char(255), -char(1),char(215),char(255),char(154),char(2),char(255),char(1),char(216),char(255),char(113), -char(2),char(255),char(1),char(217),char(255),char(154),char(2),char(255),char(1),char(218), -char(255),char(154),char(2),char(255),char(1),char(219),char(255),char(113),char(2),char(255), -char(1),char(220),char(255),char(174),char(2),char(255),char(1),char(221),char(255),char(174), -char(2),char(255),char(1),char(222),char(255),char(113),char(2),char(255),char(1),char(223), -char(255),char(215),char(2),char(255),char(1),char(224),char(255),char(154),char(2),char(255), -char(1),char(225),char(255),char(154),char(2),char(255),char(1),char(226),char(255),char(154), -char(2),char(255),char(1),char(227),char(255),char(154),char(2),char(255),char(1),char(228), -char(255),char(174),char(2),char(255),char(1),char(229),char(255),char(154),char(2),char(255), -char(1),char(230),char(255),char(154),char(2),char(255),char(1),char(231),char(255),char(215), -char(2),char(255),char(1),char(232),char(255),char(154),char(2),char(255),char(1),char(233), -char(255),char(195),char(2),char(255),char(1),char(234),char(255),char(113),char(2),char(255), -char(1),char(236),char(255),char(154),char(2),char(255),char(1),char(237),char(255),char(113), -char(2),char(255),char(1),char(238),char(255),char(133),char(2),char(255),char(1),char(242), -char(255),char(133),char(2),char(255),char(1),char(243),char(255),char(154),char(2),char(255), -char(1),char(245),char(255),char(154),char(2),char(255),char(1),char(246),char(255),char(174), -char(2),char(255),char(1),char(247),char(255),char(154),char(2),char(255),char(1),char(249), -char(255),char(154),char(2),char(255),char(2),char(2),char(255),char(174),char(2),char(255), -char(2),char(3),char(255),char(174),char(2),char(255),char(2),char(4),char(255),char(174), -char(2),char(255),char(2),char(8),char(255),char(133),char(2),char(255),char(2),char(12), -char(255),char(133),char(2),char(255),char(2),char(106),char(255),char(113),char(2),char(255), -char(2),char(107),char(255),char(154),char(2),char(255),char(2),char(108),char(255),char(215), -char(2),char(255),char(2),char(109),char(255),char(215),char(2),char(255),char(2),char(113), -char(255),char(154),char(2),char(255),char(2),char(114),char(255),char(113),char(2),char(255), -char(2),char(115),char(255),char(133),char(2),char(255),char(2),char(117),char(255),char(154), -char(2),char(255),char(2),char(119),char(255),char(154),char(2),char(255),char(2),char(121), -char(255),char(154),char(2),char(255),char(2),char(125),char(255),char(154),char(2),char(255), -char(2),char(126),char(255),char(215),char(2),char(255),char(2),char(127),char(255),char(113), -char(2),char(255),char(2),char(129),char(255),char(215),char(2),char(255),char(2),char(131), -char(255),char(215),char(2),char(255),char(2),char(132),char(255),char(215),char(2),char(255), -char(2),char(133),char(255),char(113),char(2),char(255),char(2),char(134),char(255),char(215), -char(2),char(255),char(2),char(135),char(255),char(113),char(2),char(255),char(2),char(136), -char(255),char(215),char(2),char(255),char(2),char(137),char(255),char(113),char(2),char(255), -char(2),char(138),char(255),char(215),char(2),char(255),char(2),char(139),char(255),char(215), -char(2),char(255),char(2),char(140),char(255),char(215),char(2),char(255),char(2),char(141), -char(255),char(113),char(2),char(255),char(2),char(150),char(255),char(154),char(2),char(255), -char(2),char(154),char(255),char(154),char(2),char(255),char(2),char(158),char(255),char(154), -char(2),char(255),char(2),char(160),char(255),char(215),char(2),char(255),char(2),char(162), -char(255),char(215),char(2),char(255),char(2),char(164),char(255),char(154),char(2),char(255), -char(2),char(166),char(255),char(154),char(2),char(255),char(2),char(170),char(255),char(174), -char(2),char(255),char(2),char(172),char(255),char(154),char(2),char(255),char(2),char(174), -char(255),char(154),char(2),char(255),char(2),char(176),char(255),char(154),char(2),char(255), -char(2),char(177),char(255),char(215),char(2),char(255),char(2),char(178),char(255),char(113), -char(2),char(255),char(2),char(179),char(255),char(215),char(2),char(255),char(2),char(180), -char(255),char(113),char(2),char(255),char(2),char(181),char(0),char(41),char(2),char(255), -char(2),char(182),char(255),char(174),char(2),char(255),char(2),char(184),char(255),char(174), -char(2),char(255),char(2),char(186),char(255),char(174),char(2),char(255),char(2),char(188), -char(255),char(215),char(2),char(255),char(2),char(190),char(255),char(174),char(2),char(255), -char(2),char(192),char(255),char(154),char(2),char(255),char(2),char(194),char(255),char(154), -char(2),char(255),char(2),char(196),char(255),char(154),char(2),char(255),char(2),char(197), -char(255),char(154),char(2),char(255),char(2),char(198),char(255),char(113),char(2),char(255), -char(2),char(199),char(255),char(154),char(2),char(255),char(2),char(200),char(255),char(113), -char(2),char(255),char(2),char(203),char(255),char(215),char(2),char(255),char(2),char(205), -char(255),char(154),char(2),char(255),char(2),char(206),char(255),char(154),char(2),char(255), -char(2),char(207),char(255),char(133),char(2),char(255),char(2),char(209),char(255),char(154), -char(2),char(255),char(2),char(211),char(255),char(154),char(2),char(255),char(2),char(213), -char(255),char(154),char(2),char(255),char(2),char(215),char(255),char(154),char(2),char(255), -char(2),char(217),char(255),char(113),char(2),char(255),char(2),char(219),char(255),char(113), -char(2),char(255),char(2),char(221),char(255),char(113),char(2),char(255),char(2),char(224), -char(255),char(113),char(2),char(255),char(2),char(230),char(255),char(215),char(2),char(255), -char(2),char(232),char(255),char(215),char(2),char(255),char(2),char(234),char(255),char(195), -char(2),char(255),char(2),char(236),char(255),char(154),char(2),char(255),char(2),char(238), -char(255),char(154),char(2),char(255),char(2),char(239),char(255),char(215),char(2),char(255), -char(2),char(240),char(255),char(113),char(2),char(255),char(2),char(241),char(255),char(215), -char(2),char(255),char(2),char(242),char(255),char(113),char(2),char(255),char(2),char(243), -char(255),char(215),char(2),char(255),char(2),char(244),char(255),char(113),char(2),char(255), -char(2),char(246),char(255),char(215),char(2),char(255),char(2),char(248),char(255),char(174), -char(2),char(255),char(2),char(250),char(255),char(174),char(2),char(255),char(2),char(252), -char(255),char(174),char(2),char(255),char(2),char(254),char(255),char(154),char(2),char(255), -char(3),char(0),char(255),char(154),char(2),char(255),char(3),char(2),char(255),char(154), -char(2),char(255),char(3),char(6),char(255),char(215),char(2),char(255),char(3),char(8), -char(255),char(215),char(2),char(255),char(3),char(9),char(255),char(113),char(2),char(255), -char(3),char(10),char(255),char(113),char(2),char(255),char(3),char(11),char(255),char(113), -char(2),char(255),char(3),char(12),char(255),char(113),char(2),char(255),char(3),char(14), -char(255),char(154),char(2),char(255),char(3),char(16),char(255),char(154),char(2),char(255), -char(3),char(17),char(255),char(154),char(2),char(255),char(3),char(18),char(255),char(133), -char(2),char(255),char(3),char(20),char(255),char(154),char(2),char(255),char(3),char(21), -char(255),char(215),char(2),char(255),char(3),char(22),char(255),char(113),char(2),char(255), -char(3),char(24),char(255),char(174),char(2),char(255),char(3),char(26),char(255),char(113), -char(2),char(255),char(3),char(27),char(255),char(154),char(2),char(255),char(3),char(28), -char(255),char(133),char(3),char(0),char(0),char(15),char(255),char(154),char(3),char(0), -char(0),char(16),char(255),char(215),char(3),char(0),char(0),char(17),char(255),char(154), -char(3),char(0),char(1),char(206),char(255),char(195),char(3),char(0),char(1),char(207), -char(255),char(236),char(3),char(0),char(1),char(213),char(255),char(195),char(3),char(0), -char(1),char(216),char(255),char(236),char(3),char(0),char(1),char(219),char(255),char(236), -char(3),char(0),char(1),char(222),char(255),char(236),char(3),char(0),char(1),char(234), -char(255),char(236),char(3),char(0),char(1),char(237),char(255),char(236),char(3),char(0), -char(1),char(242),char(255),char(195),char(3),char(0),char(2),char(2),char(255),char(215), -char(3),char(0),char(2),char(3),char(255),char(215),char(3),char(0),char(2),char(4), -char(255),char(215),char(3),char(0),char(2),char(8),char(255),char(154),char(3),char(0), -char(2),char(12),char(255),char(154),char(3),char(0),char(2),char(106),char(255),char(236), -char(3),char(0),char(2),char(115),char(255),char(195),char(3),char(0),char(2),char(127), -char(255),char(236),char(3),char(0),char(2),char(133),char(255),char(236),char(3),char(0), -char(2),char(135),char(255),char(236),char(3),char(0),char(2),char(137),char(255),char(236), -char(3),char(0),char(2),char(141),char(255),char(236),char(3),char(0),char(2),char(178), -char(255),char(236),char(3),char(0),char(2),char(180),char(255),char(236),char(3),char(0), -char(2),char(207),char(255),char(195),char(3),char(0),char(2),char(224),char(255),char(236), -char(3),char(0),char(2),char(240),char(255),char(236),char(3),char(0),char(2),char(242), -char(255),char(236),char(3),char(0),char(2),char(244),char(255),char(236),char(3),char(0), -char(3),char(10),char(255),char(236),char(3),char(0),char(3),char(12),char(255),char(236), -char(3),char(0),char(3),char(18),char(255),char(195),char(3),char(0),char(3),char(22), -char(255),char(236),char(3),char(0),char(3),char(26),char(255),char(236),char(3),char(0), -char(3),char(28),char(255),char(195),char(3),char(3),char(0),char(15),char(255),char(154), -char(3),char(3),char(0),char(16),char(255),char(215),char(3),char(3),char(0),char(17), -char(255),char(154),char(3),char(3),char(1),char(157),char(0),char(41),char(3),char(3), -char(1),char(159),char(255),char(215),char(3),char(3),char(1),char(164),char(255),char(174), -char(3),char(3),char(1),char(166),char(0),char(41),char(3),char(3),char(1),char(170), -char(255),char(133),char(3),char(3),char(1),char(174),char(255),char(174),char(3),char(3), -char(1),char(181),char(255),char(174),char(3),char(3),char(1),char(184),char(255),char(215), -char(3),char(3),char(1),char(187),char(255),char(215),char(3),char(3),char(1),char(188), -char(0),char(41),char(3),char(3),char(1),char(190),char(255),char(195),char(3),char(3), -char(1),char(196),char(0),char(41),char(3),char(3),char(1),char(204),char(255),char(195), -char(3),char(3),char(1),char(205),char(255),char(195),char(3),char(3),char(1),char(206), -char(255),char(154),char(3),char(3),char(1),char(207),char(255),char(174),char(3),char(3), -char(1),char(208),char(255),char(215),char(3),char(3),char(1),char(209),char(255),char(215), -char(3),char(3),char(1),char(210),char(255),char(195),char(3),char(3),char(1),char(211), -char(255),char(195),char(3),char(3),char(1),char(212),char(255),char(195),char(3),char(3), -char(1),char(213),char(255),char(154),char(3),char(3),char(1),char(214),char(255),char(195), -char(3),char(3),char(1),char(215),char(255),char(195),char(3),char(3),char(1),char(216), -char(255),char(174),char(3),char(3),char(1),char(217),char(255),char(195),char(3),char(3), -char(1),char(218),char(255),char(195),char(3),char(3),char(1),char(219),char(255),char(174), -char(3),char(3),char(1),char(222),char(255),char(174),char(3),char(3),char(1),char(223), -char(255),char(215),char(3),char(3),char(1),char(224),char(255),char(195),char(3),char(3), -char(1),char(225),char(255),char(154),char(3),char(3),char(1),char(226),char(255),char(195), -char(3),char(3),char(1),char(227),char(255),char(195),char(3),char(3),char(1),char(229), -char(255),char(195),char(3),char(3),char(1),char(230),char(255),char(195),char(3),char(3), -char(1),char(231),char(255),char(215),char(3),char(3),char(1),char(232),char(255),char(195), -char(3),char(3),char(1),char(234),char(255),char(174),char(3),char(3),char(1),char(235), -char(0),char(41),char(3),char(3),char(1),char(236),char(255),char(195),char(3),char(3), -char(1),char(237),char(255),char(174),char(3),char(3),char(1),char(238),char(255),char(195), -char(3),char(3),char(1),char(242),char(255),char(154),char(3),char(3),char(1),char(243), -char(255),char(195),char(3),char(3),char(1),char(244),char(0),char(41),char(3),char(3), -char(1),char(245),char(255),char(195),char(3),char(3),char(1),char(247),char(255),char(195), -char(3),char(3),char(1),char(249),char(255),char(195),char(3),char(3),char(2),char(2), -char(255),char(215),char(3),char(3),char(2),char(3),char(255),char(215),char(3),char(3), -char(2),char(4),char(255),char(215),char(3),char(3),char(2),char(8),char(255),char(154), -char(3),char(3),char(2),char(12),char(255),char(154),char(3),char(3),char(2),char(106), -char(255),char(174),char(3),char(3),char(2),char(107),char(255),char(195),char(3),char(3), -char(2),char(108),char(255),char(215),char(3),char(3),char(2),char(113),char(255),char(195), -char(3),char(3),char(2),char(114),char(255),char(133),char(3),char(3),char(2),char(115), -char(255),char(154),char(3),char(3),char(2),char(117),char(255),char(195),char(3),char(3), -char(2),char(119),char(255),char(215),char(3),char(3),char(2),char(121),char(255),char(195), -char(3),char(3),char(2),char(125),char(255),char(195),char(3),char(3),char(2),char(126), -char(255),char(215),char(3),char(3),char(2),char(127),char(255),char(174),char(3),char(3), -char(2),char(132),char(255),char(215),char(3),char(3),char(2),char(133),char(255),char(174), -char(3),char(3),char(2),char(134),char(255),char(215),char(3),char(3),char(2),char(135), -char(255),char(174),char(3),char(3),char(2),char(136),char(255),char(215),char(3),char(3), -char(2),char(137),char(255),char(174),char(3),char(3),char(2),char(138),char(255),char(215), -char(3),char(3),char(2),char(140),char(255),char(215),char(3),char(3),char(2),char(141), -char(255),char(174),char(3),char(3),char(2),char(150),char(255),char(195),char(3),char(3), -char(2),char(152),char(0),char(41),char(3),char(3),char(2),char(154),char(255),char(195), -char(3),char(3),char(2),char(158),char(255),char(195),char(3),char(3),char(2),char(160), -char(255),char(215),char(3),char(3),char(2),char(162),char(255),char(215),char(3),char(3), -char(2),char(164),char(255),char(195),char(3),char(3),char(2),char(166),char(255),char(195), -char(3),char(3),char(2),char(168),char(0),char(41),char(3),char(3),char(2),char(169), -char(0),char(41),char(3),char(3),char(2),char(172),char(255),char(195),char(3),char(3), -char(2),char(174),char(255),char(195),char(3),char(3),char(2),char(176),char(255),char(195), -char(3),char(3),char(2),char(177),char(255),char(215),char(3),char(3),char(2),char(178), -char(255),char(174),char(3),char(3),char(2),char(179),char(255),char(215),char(3),char(3), -char(2),char(180),char(255),char(174),char(3),char(3),char(2),char(181),char(0),char(41), -char(3),char(3),char(2),char(188),char(255),char(215),char(3),char(3),char(2),char(189), -char(0),char(41),char(3),char(3),char(2),char(192),char(255),char(154),char(3),char(3), -char(2),char(194),char(255),char(154),char(3),char(3),char(2),char(196),char(255),char(195), -char(3),char(3),char(2),char(197),char(255),char(215),char(3),char(3),char(2),char(198), -char(255),char(195),char(3),char(3),char(2),char(199),char(255),char(215),char(3),char(3), -char(2),char(200),char(255),char(195),char(3),char(3),char(2),char(203),char(255),char(215), -char(3),char(3),char(2),char(205),char(255),char(195),char(3),char(3),char(2),char(206), -char(255),char(174),char(3),char(3),char(2),char(207),char(255),char(154),char(3),char(3), -char(2),char(209),char(255),char(195),char(3),char(3),char(2),char(211),char(255),char(195), -char(3),char(3),char(2),char(213),char(255),char(154),char(3),char(3),char(2),char(215), -char(255),char(195),char(3),char(3),char(2),char(217),char(255),char(133),char(3),char(3), -char(2),char(219),char(255),char(133),char(3),char(3),char(2),char(221),char(255),char(133), -char(3),char(3),char(2),char(224),char(255),char(174),char(3),char(3),char(2),char(230), -char(255),char(215),char(3),char(3),char(2),char(232),char(255),char(215),char(3),char(3), -char(2),char(236),char(255),char(195),char(3),char(3),char(2),char(238),char(255),char(195), -char(3),char(3),char(2),char(239),char(255),char(215),char(3),char(3),char(2),char(240), -char(255),char(174),char(3),char(3),char(2),char(241),char(255),char(215),char(3),char(3), -char(2),char(242),char(255),char(174),char(3),char(3),char(2),char(243),char(255),char(215), -char(3),char(3),char(2),char(244),char(255),char(174),char(3),char(3),char(2),char(246), -char(255),char(215),char(3),char(3),char(2),char(254),char(255),char(154),char(3),char(3), -char(3),char(0),char(255),char(195),char(3),char(3),char(3),char(2),char(255),char(195), -char(3),char(3),char(3),char(6),char(255),char(215),char(3),char(3),char(3),char(8), -char(255),char(215),char(3),char(3),char(3),char(9),char(255),char(154),char(3),char(3), -char(3),char(10),char(255),char(174),char(3),char(3),char(3),char(11),char(255),char(154), -char(3),char(3),char(3),char(12),char(255),char(174),char(3),char(3),char(3),char(14), -char(255),char(215),char(3),char(3),char(3),char(16),char(255),char(215),char(3),char(3), -char(3),char(17),char(255),char(174),char(3),char(3),char(3),char(18),char(255),char(154), -char(3),char(3),char(3),char(20),char(255),char(195),char(3),char(3),char(3),char(21), -char(255),char(215),char(3),char(3),char(3),char(22),char(255),char(174),char(3),char(3), -char(3),char(23),char(0),char(41),char(3),char(3),char(3),char(26),char(255),char(174), -char(3),char(3),char(3),char(27),char(255),char(174),char(3),char(3),char(3),char(28), -char(255),char(154),char(3),char(4),char(0),char(15),char(255),char(195),char(3),char(4), -char(0),char(17),char(255),char(195),char(3),char(4),char(1),char(206),char(255),char(195), -char(3),char(4),char(1),char(207),char(255),char(215),char(3),char(4),char(1),char(213), -char(255),char(195),char(3),char(4),char(1),char(216),char(255),char(215),char(3),char(4), -char(1),char(219),char(255),char(215),char(3),char(4),char(1),char(222),char(255),char(215), -char(3),char(4),char(1),char(234),char(255),char(215),char(3),char(4),char(1),char(237), -char(255),char(215),char(3),char(4),char(1),char(242),char(255),char(195),char(3),char(4), -char(2),char(8),char(255),char(195),char(3),char(4),char(2),char(12),char(255),char(195), -char(3),char(4),char(2),char(106),char(255),char(215),char(3),char(4),char(2),char(115), -char(255),char(195),char(3),char(4),char(2),char(127),char(255),char(215),char(3),char(4), -char(2),char(133),char(255),char(215),char(3),char(4),char(2),char(135),char(255),char(215), -char(3),char(4),char(2),char(137),char(255),char(215),char(3),char(4),char(2),char(141), -char(255),char(215),char(3),char(4),char(2),char(178),char(255),char(215),char(3),char(4), -char(2),char(180),char(255),char(215),char(3),char(4),char(2),char(207),char(255),char(195), -char(3),char(4),char(2),char(224),char(255),char(215),char(3),char(4),char(2),char(240), -char(255),char(215),char(3),char(4),char(2),char(242),char(255),char(215),char(3),char(4), -char(2),char(244),char(255),char(215),char(3),char(4),char(3),char(10),char(255),char(215), -char(3),char(4),char(3),char(12),char(255),char(215),char(3),char(4),char(3),char(18), -char(255),char(195),char(3),char(4),char(3),char(22),char(255),char(215),char(3),char(4), -char(3),char(26),char(255),char(215),char(3),char(4),char(3),char(28),char(255),char(195), -char(3),char(5),char(1),char(159),char(255),char(215),char(3),char(5),char(1),char(163), -char(0),char(225),char(3),char(5),char(1),char(184),char(255),char(215),char(3),char(5), -char(1),char(187),char(255),char(215),char(3),char(5),char(1),char(190),char(255),char(195), -char(3),char(5),char(1),char(220),char(255),char(215),char(3),char(5),char(1),char(225), -char(255),char(174),char(3),char(5),char(1),char(228),char(255),char(215),char(3),char(5), -char(2),char(108),char(255),char(215),char(3),char(5),char(2),char(123),char(0),char(61), -char(3),char(5),char(2),char(125),char(255),char(236),char(3),char(5),char(2),char(126), -char(255),char(215),char(3),char(5),char(2),char(132),char(255),char(215),char(3),char(5), -char(2),char(134),char(255),char(215),char(3),char(5),char(2),char(136),char(255),char(215), -char(3),char(5),char(2),char(138),char(255),char(215),char(3),char(5),char(2),char(140), -char(255),char(215),char(3),char(5),char(2),char(170),char(255),char(215),char(3),char(5), -char(2),char(177),char(255),char(215),char(3),char(5),char(2),char(179),char(255),char(215), -char(3),char(5),char(2),char(182),char(255),char(215),char(3),char(5),char(2),char(190), -char(255),char(215),char(3),char(5),char(2),char(192),char(255),char(174),char(3),char(5), -char(2),char(194),char(255),char(174),char(3),char(5),char(2),char(197),char(255),char(195), -char(3),char(5),char(2),char(198),char(255),char(215),char(3),char(5),char(2),char(199), -char(255),char(195),char(3),char(5),char(2),char(200),char(255),char(215),char(3),char(5), -char(2),char(213),char(255),char(174),char(3),char(5),char(2),char(239),char(255),char(215), -char(3),char(5),char(2),char(241),char(255),char(215),char(3),char(5),char(2),char(243), -char(255),char(215),char(3),char(5),char(2),char(254),char(255),char(174),char(3),char(5), -char(3),char(14),char(255),char(215),char(3),char(5),char(3),char(16),char(255),char(215), -char(3),char(5),char(3),char(21),char(255),char(215),char(3),char(5),char(3),char(24), -char(255),char(215),char(3),char(6),char(1),char(207),char(255),char(236),char(3),char(6), -char(1),char(216),char(255),char(236),char(3),char(6),char(1),char(219),char(255),char(236), -char(3),char(6),char(1),char(222),char(255),char(236),char(3),char(6),char(1),char(225), -char(255),char(236),char(3),char(6),char(1),char(234),char(255),char(236),char(3),char(6), -char(1),char(237),char(255),char(236),char(3),char(6),char(2),char(106),char(255),char(236), -char(3),char(6),char(2),char(127),char(255),char(236),char(3),char(6),char(2),char(133), -char(255),char(236),char(3),char(6),char(2),char(135),char(255),char(236),char(3),char(6), -char(2),char(137),char(255),char(236),char(3),char(6),char(2),char(141),char(255),char(236), -char(3),char(6),char(2),char(178),char(255),char(236),char(3),char(6),char(2),char(180), -char(255),char(236),char(3),char(6),char(2),char(192),char(255),char(236),char(3),char(6), -char(2),char(194),char(255),char(236),char(3),char(6),char(2),char(213),char(255),char(236), -char(3),char(6),char(2),char(224),char(255),char(236),char(3),char(6),char(2),char(240), -char(255),char(236),char(3),char(6),char(2),char(242),char(255),char(236),char(3),char(6), -char(2),char(244),char(255),char(236),char(3),char(6),char(2),char(254),char(255),char(236), -char(3),char(6),char(3),char(10),char(255),char(236),char(3),char(6),char(3),char(12), -char(255),char(236),char(3),char(6),char(3),char(14),char(255),char(215),char(3),char(6), -char(3),char(16),char(255),char(215),char(3),char(6),char(3),char(22),char(255),char(236), -char(3),char(6),char(3),char(26),char(255),char(236),char(3),char(7),char(1),char(159), -char(255),char(215),char(3),char(7),char(1),char(184),char(255),char(215),char(3),char(7), -char(1),char(187),char(255),char(215),char(3),char(7),char(1),char(190),char(255),char(215), -char(3),char(7),char(1),char(193),char(255),char(215),char(3),char(7),char(1),char(225), -char(255),char(215),char(3),char(7),char(2),char(108),char(255),char(215),char(3),char(7), -char(2),char(124),char(255),char(215),char(3),char(7),char(2),char(126),char(255),char(215), -char(3),char(7),char(2),char(132),char(255),char(215),char(3),char(7),char(2),char(134), -char(255),char(215),char(3),char(7),char(2),char(136),char(255),char(215),char(3),char(7), -char(2),char(138),char(255),char(215),char(3),char(7),char(2),char(140),char(255),char(215), -char(3),char(7),char(2),char(177),char(255),char(215),char(3),char(7),char(2),char(179), -char(255),char(215),char(3),char(7),char(2),char(191),char(255),char(215),char(3),char(7), -char(2),char(192),char(255),char(215),char(3),char(7),char(2),char(193),char(255),char(215), -char(3),char(7),char(2),char(194),char(255),char(215),char(3),char(7),char(2),char(197), -char(255),char(154),char(3),char(7),char(2),char(199),char(255),char(154),char(3),char(7), -char(2),char(212),char(255),char(215),char(3),char(7),char(2),char(213),char(255),char(215), -char(3),char(7),char(2),char(239),char(255),char(215),char(3),char(7),char(2),char(241), -char(255),char(215),char(3),char(7),char(2),char(243),char(255),char(215),char(3),char(7), -char(2),char(253),char(255),char(215),char(3),char(7),char(2),char(254),char(255),char(215), -char(3),char(7),char(3),char(9),char(255),char(215),char(3),char(7),char(3),char(11), -char(255),char(215),char(3),char(7),char(3),char(14),char(255),char(215),char(3),char(7), -char(3),char(16),char(255),char(215),char(3),char(7),char(3),char(21),char(255),char(215), -char(3),char(7),char(3),char(25),char(255),char(236),char(3),char(8),char(1),char(207), -char(255),char(236),char(3),char(8),char(1),char(216),char(255),char(236),char(3),char(8), -char(1),char(219),char(255),char(236),char(3),char(8),char(1),char(222),char(255),char(236), -char(3),char(8),char(1),char(225),char(255),char(236),char(3),char(8),char(1),char(234), -char(255),char(236),char(3),char(8),char(1),char(237),char(255),char(236),char(3),char(8), -char(2),char(106),char(255),char(236),char(3),char(8),char(2),char(127),char(255),char(236), -char(3),char(8),char(2),char(133),char(255),char(236),char(3),char(8),char(2),char(135), -char(255),char(236),char(3),char(8),char(2),char(137),char(255),char(236),char(3),char(8), -char(2),char(141),char(255),char(236),char(3),char(8),char(2),char(178),char(255),char(236), -char(3),char(8),char(2),char(180),char(255),char(236),char(3),char(8),char(2),char(192), -char(255),char(236),char(3),char(8),char(2),char(194),char(255),char(236),char(3),char(8), -char(2),char(213),char(255),char(236),char(3),char(8),char(2),char(224),char(255),char(236), -char(3),char(8),char(2),char(240),char(255),char(236),char(3),char(8),char(2),char(242), -char(255),char(236),char(3),char(8),char(2),char(244),char(255),char(236),char(3),char(8), -char(2),char(254),char(255),char(236),char(3),char(8),char(3),char(10),char(255),char(236), -char(3),char(8),char(3),char(12),char(255),char(236),char(3),char(8),char(3),char(14), -char(255),char(215),char(3),char(8),char(3),char(16),char(255),char(215),char(3),char(8), -char(3),char(22),char(255),char(236),char(3),char(8),char(3),char(26),char(255),char(236), -char(3),char(11),char(0),char(5),char(255),char(154),char(3),char(11),char(0),char(10), -char(255),char(154),char(3),char(11),char(1),char(157),char(255),char(174),char(3),char(11), -char(1),char(166),char(255),char(174),char(3),char(11),char(1),char(168),char(255),char(195), -char(3),char(11),char(1),char(170),char(255),char(195),char(3),char(11),char(1),char(176), -char(255),char(195),char(3),char(11),char(1),char(188),char(255),char(113),char(3),char(11), -char(1),char(189),char(255),char(195),char(3),char(11),char(1),char(191),char(255),char(195), -char(3),char(11),char(1),char(193),char(255),char(195),char(3),char(11),char(1),char(196), -char(255),char(174),char(3),char(11),char(1),char(208),char(255),char(215),char(3),char(11), -char(1),char(220),char(255),char(195),char(3),char(11),char(1),char(223),char(255),char(215), -char(3),char(11),char(1),char(225),char(255),char(215),char(3),char(11),char(1),char(228), -char(255),char(195),char(3),char(11),char(2),char(7),char(255),char(154),char(3),char(11), -char(2),char(11),char(255),char(154),char(3),char(11),char(2),char(114),char(255),char(195), -char(3),char(11),char(2),char(118),char(255),char(215),char(3),char(11),char(2),char(124), -char(255),char(195),char(3),char(11),char(2),char(128),char(255),char(195),char(3),char(11), -char(2),char(130),char(255),char(195),char(3),char(11),char(2),char(159),char(255),char(195), -char(3),char(11),char(2),char(160),char(255),char(215),char(3),char(11),char(2),char(169), -char(255),char(174),char(3),char(11),char(2),char(170),char(255),char(195),char(3),char(11), -char(2),char(181),char(255),char(113),char(3),char(11),char(2),char(182),char(255),char(195), -char(3),char(11),char(2),char(183),char(255),char(195),char(3),char(11),char(2),char(185), -char(255),char(195),char(3),char(11),char(2),char(187),char(255),char(195),char(3),char(11), -char(2),char(188),char(255),char(215),char(3),char(11),char(2),char(189),char(255),char(174), -char(3),char(11),char(2),char(190),char(255),char(195),char(3),char(11),char(2),char(191), -char(255),char(195),char(3),char(11),char(2),char(192),char(255),char(215),char(3),char(11), -char(2),char(193),char(255),char(195),char(3),char(11),char(2),char(194),char(255),char(215), -char(3),char(11),char(2),char(202),char(255),char(195),char(3),char(11),char(2),char(203), -char(255),char(215),char(3),char(11),char(2),char(212),char(255),char(195),char(3),char(11), -char(2),char(213),char(255),char(215),char(3),char(11),char(2),char(217),char(255),char(195), -char(3),char(11),char(2),char(219),char(255),char(195),char(3),char(11),char(2),char(221), -char(255),char(195),char(3),char(11),char(2),char(229),char(255),char(195),char(3),char(11), -char(2),char(230),char(255),char(215),char(3),char(11),char(2),char(247),char(255),char(195), -char(3),char(11),char(2),char(249),char(255),char(195),char(3),char(11),char(2),char(251), -char(255),char(195),char(3),char(11),char(2),char(253),char(255),char(195),char(3),char(11), -char(2),char(254),char(255),char(215),char(3),char(11),char(3),char(5),char(255),char(195), -char(3),char(11),char(3),char(6),char(255),char(215),char(3),char(11),char(3),char(7), -char(255),char(195),char(3),char(11),char(3),char(8),char(255),char(215),char(3),char(11), -char(3),char(13),char(255),char(215),char(3),char(11),char(3),char(14),char(255),char(215), -char(3),char(11),char(3),char(15),char(255),char(215),char(3),char(11),char(3),char(16), -char(255),char(215),char(3),char(11),char(3),char(23),char(255),char(174),char(3),char(11), -char(3),char(24),char(255),char(195),char(3),char(12),char(0),char(5),char(255),char(154), -char(3),char(12),char(0),char(10),char(255),char(154),char(3),char(12),char(1),char(208), -char(255),char(215),char(3),char(12),char(1),char(220),char(255),char(195),char(3),char(12), -char(1),char(221),char(255),char(215),char(3),char(12),char(1),char(223),char(255),char(215), -char(3),char(12),char(1),char(225),char(255),char(215),char(3),char(12),char(1),char(228), -char(255),char(195),char(3),char(12),char(1),char(246),char(255),char(215),char(3),char(12), -char(2),char(7),char(255),char(154),char(3),char(12),char(2),char(11),char(255),char(154), -char(3),char(12),char(2),char(160),char(255),char(215),char(3),char(12),char(2),char(170), -char(255),char(195),char(3),char(12),char(2),char(182),char(255),char(195),char(3),char(12), -char(2),char(188),char(255),char(215),char(3),char(12),char(2),char(190),char(255),char(195), -char(3),char(12),char(2),char(192),char(255),char(215),char(3),char(12),char(2),char(194), -char(255),char(215),char(3),char(12),char(2),char(203),char(255),char(215),char(3),char(12), -char(2),char(213),char(255),char(215),char(3),char(12),char(2),char(230),char(255),char(215), -char(3),char(12),char(2),char(248),char(255),char(215),char(3),char(12),char(2),char(250), -char(255),char(215),char(3),char(12),char(2),char(252),char(255),char(215),char(3),char(12), -char(2),char(254),char(255),char(215),char(3),char(12),char(3),char(6),char(255),char(215), -char(3),char(12),char(3),char(8),char(255),char(215),char(3),char(12),char(3),char(14), -char(255),char(154),char(3),char(12),char(3),char(16),char(255),char(154),char(3),char(12), -char(3),char(24),char(255),char(195),char(3),char(13),char(0),char(5),char(255),char(154), -char(3),char(13),char(0),char(10),char(255),char(154),char(3),char(13),char(1),char(157), -char(255),char(174),char(3),char(13),char(1),char(166),char(255),char(174),char(3),char(13), -char(1),char(168),char(255),char(195),char(3),char(13),char(1),char(170),char(255),char(195), -char(3),char(13),char(1),char(176),char(255),char(195),char(3),char(13),char(1),char(188), -char(255),char(113),char(3),char(13),char(1),char(189),char(255),char(195),char(3),char(13), -char(1),char(191),char(255),char(195),char(3),char(13),char(1),char(193),char(255),char(195), -char(3),char(13),char(1),char(196),char(255),char(174),char(3),char(13),char(1),char(208), -char(255),char(215),char(3),char(13),char(1),char(220),char(255),char(195),char(3),char(13), -char(1),char(223),char(255),char(215),char(3),char(13),char(1),char(225),char(255),char(215), -char(3),char(13),char(1),char(228),char(255),char(195),char(3),char(13),char(2),char(7), -char(255),char(154),char(3),char(13),char(2),char(11),char(255),char(154),char(3),char(13), -char(2),char(114),char(255),char(195),char(3),char(13),char(2),char(118),char(255),char(215), -char(3),char(13),char(2),char(124),char(255),char(195),char(3),char(13),char(2),char(128), -char(255),char(195),char(3),char(13),char(2),char(130),char(255),char(195),char(3),char(13), -char(2),char(159),char(255),char(195),char(3),char(13),char(2),char(160),char(255),char(215), -char(3),char(13),char(2),char(169),char(255),char(174),char(3),char(13),char(2),char(170), -char(255),char(195),char(3),char(13),char(2),char(181),char(255),char(113),char(3),char(13), -char(2),char(182),char(255),char(195),char(3),char(13),char(2),char(183),char(255),char(195), -char(3),char(13),char(2),char(185),char(255),char(195),char(3),char(13),char(2),char(187), -char(255),char(195),char(3),char(13),char(2),char(188),char(255),char(215),char(3),char(13), -char(2),char(189),char(255),char(174),char(3),char(13),char(2),char(190),char(255),char(195), -char(3),char(13),char(2),char(191),char(255),char(195),char(3),char(13),char(2),char(192), -char(255),char(215),char(3),char(13),char(2),char(193),char(255),char(195),char(3),char(13), -char(2),char(194),char(255),char(215),char(3),char(13),char(2),char(202),char(255),char(195), -char(3),char(13),char(2),char(203),char(255),char(215),char(3),char(13),char(2),char(212), -char(255),char(195),char(3),char(13),char(2),char(213),char(255),char(215),char(3),char(13), -char(2),char(217),char(255),char(195),char(3),char(13),char(2),char(219),char(255),char(195), -char(3),char(13),char(2),char(221),char(255),char(195),char(3),char(13),char(2),char(229), -char(255),char(195),char(3),char(13),char(2),char(230),char(255),char(215),char(3),char(13), -char(2),char(247),char(255),char(195),char(3),char(13),char(2),char(249),char(255),char(195), -char(3),char(13),char(2),char(251),char(255),char(195),char(3),char(13),char(2),char(253), -char(255),char(195),char(3),char(13),char(2),char(254),char(255),char(215),char(3),char(13), -char(3),char(5),char(255),char(195),char(3),char(13),char(3),char(6),char(255),char(215), -char(3),char(13),char(3),char(7),char(255),char(195),char(3),char(13),char(3),char(8), -char(255),char(215),char(3),char(13),char(3),char(13),char(255),char(215),char(3),char(13), -char(3),char(14),char(255),char(215),char(3),char(13),char(3),char(15),char(255),char(215), -char(3),char(13),char(3),char(16),char(255),char(215),char(3),char(13),char(3),char(23), -char(255),char(174),char(3),char(13),char(3),char(24),char(255),char(195),char(3),char(14), -char(0),char(5),char(255),char(154),char(3),char(14),char(0),char(10),char(255),char(154), -char(3),char(14),char(1),char(208),char(255),char(215),char(3),char(14),char(1),char(220), -char(255),char(195),char(3),char(14),char(1),char(221),char(255),char(215),char(3),char(14), -char(1),char(223),char(255),char(215),char(3),char(14),char(1),char(225),char(255),char(215), -char(3),char(14),char(1),char(228),char(255),char(195),char(3),char(14),char(1),char(246), -char(255),char(215),char(3),char(14),char(2),char(7),char(255),char(154),char(3),char(14), -char(2),char(11),char(255),char(154),char(3),char(14),char(2),char(160),char(255),char(215), -char(3),char(14),char(2),char(170),char(255),char(195),char(3),char(14),char(2),char(182), -char(255),char(195),char(3),char(14),char(2),char(188),char(255),char(215),char(3),char(14), -char(2),char(190),char(255),char(195),char(3),char(14),char(2),char(192),char(255),char(215), -char(3),char(14),char(2),char(194),char(255),char(215),char(3),char(14),char(2),char(203), -char(255),char(215),char(3),char(14),char(2),char(213),char(255),char(215),char(3),char(14), -char(2),char(230),char(255),char(215),char(3),char(14),char(2),char(248),char(255),char(215), -char(3),char(14),char(2),char(250),char(255),char(215),char(3),char(14),char(2),char(252), -char(255),char(215),char(3),char(14),char(2),char(254),char(255),char(215),char(3),char(14), -char(3),char(6),char(255),char(215),char(3),char(14),char(3),char(8),char(255),char(215), -char(3),char(14),char(3),char(14),char(255),char(154),char(3),char(14),char(3),char(16), -char(255),char(154),char(3),char(14),char(3),char(24),char(255),char(195),char(3),char(15), -char(1),char(163),char(0),char(225),char(3),char(15),char(2),char(234),char(0),char(41), -char(3),char(15),char(3),char(14),char(255),char(215),char(3),char(15),char(3),char(16), -char(255),char(215),char(3),char(16),char(0),char(5),char(255),char(236),char(3),char(16), -char(0),char(10),char(255),char(236),char(3),char(16),char(2),char(7),char(255),char(236), -char(3),char(16),char(2),char(11),char(255),char(236),char(3),char(17),char(0),char(5), -char(255),char(154),char(3),char(17),char(0),char(10),char(255),char(154),char(3),char(17), -char(1),char(157),char(255),char(174),char(3),char(17),char(1),char(166),char(255),char(174), -char(3),char(17),char(1),char(168),char(255),char(195),char(3),char(17),char(1),char(170), -char(255),char(195),char(3),char(17),char(1),char(176),char(255),char(195),char(3),char(17), -char(1),char(188),char(255),char(113),char(3),char(17),char(1),char(189),char(255),char(195), -char(3),char(17),char(1),char(191),char(255),char(195),char(3),char(17),char(1),char(193), -char(255),char(195),char(3),char(17),char(1),char(196),char(255),char(174),char(3),char(17), -char(1),char(208),char(255),char(215),char(3),char(17),char(1),char(220),char(255),char(195), -char(3),char(17),char(1),char(223),char(255),char(215),char(3),char(17),char(1),char(225), -char(255),char(215),char(3),char(17),char(1),char(228),char(255),char(195),char(3),char(17), -char(2),char(7),char(255),char(154),char(3),char(17),char(2),char(11),char(255),char(154), -char(3),char(17),char(2),char(114),char(255),char(195),char(3),char(17),char(2),char(118), -char(255),char(215),char(3),char(17),char(2),char(124),char(255),char(195),char(3),char(17), -char(2),char(128),char(255),char(195),char(3),char(17),char(2),char(130),char(255),char(195), -char(3),char(17),char(2),char(159),char(255),char(195),char(3),char(17),char(2),char(160), -char(255),char(215),char(3),char(17),char(2),char(169),char(255),char(174),char(3),char(17), -char(2),char(170),char(255),char(195),char(3),char(17),char(2),char(181),char(255),char(113), -char(3),char(17),char(2),char(182),char(255),char(195),char(3),char(17),char(2),char(183), -char(255),char(195),char(3),char(17),char(2),char(185),char(255),char(195),char(3),char(17), -char(2),char(187),char(255),char(195),char(3),char(17),char(2),char(188),char(255),char(215), -char(3),char(17),char(2),char(189),char(255),char(174),char(3),char(17),char(2),char(190), -char(255),char(195),char(3),char(17),char(2),char(191),char(255),char(195),char(3),char(17), -char(2),char(192),char(255),char(215),char(3),char(17),char(2),char(193),char(255),char(195), -char(3),char(17),char(2),char(194),char(255),char(215),char(3),char(17),char(2),char(202), -char(255),char(195),char(3),char(17),char(2),char(203),char(255),char(215),char(3),char(17), -char(2),char(212),char(255),char(195),char(3),char(17),char(2),char(213),char(255),char(215), -char(3),char(17),char(2),char(217),char(255),char(195),char(3),char(17),char(2),char(219), -char(255),char(195),char(3),char(17),char(2),char(221),char(255),char(195),char(3),char(17), -char(2),char(229),char(255),char(195),char(3),char(17),char(2),char(230),char(255),char(215), -char(3),char(17),char(2),char(247),char(255),char(195),char(3),char(17),char(2),char(249), -char(255),char(195),char(3),char(17),char(2),char(251),char(255),char(195),char(3),char(17), -char(2),char(253),char(255),char(195),char(3),char(17),char(2),char(254),char(255),char(215), -char(3),char(17),char(3),char(5),char(255),char(195),char(3),char(17),char(3),char(6), -char(255),char(215),char(3),char(17),char(3),char(7),char(255),char(195),char(3),char(17), -char(3),char(8),char(255),char(215),char(3),char(17),char(3),char(13),char(255),char(215), -char(3),char(17),char(3),char(14),char(255),char(215),char(3),char(17),char(3),char(15), -char(255),char(215),char(3),char(17),char(3),char(16),char(255),char(215),char(3),char(17), -char(3),char(23),char(255),char(174),char(3),char(17),char(3),char(24),char(255),char(195), -char(3),char(18),char(0),char(5),char(255),char(154),char(3),char(18),char(0),char(10), -char(255),char(154),char(3),char(18),char(1),char(208),char(255),char(215),char(3),char(18), -char(1),char(220),char(255),char(195),char(3),char(18),char(1),char(221),char(255),char(215), -char(3),char(18),char(1),char(223),char(255),char(215),char(3),char(18),char(1),char(225), -char(255),char(215),char(3),char(18),char(1),char(228),char(255),char(195),char(3),char(18), -char(1),char(246),char(255),char(215),char(3),char(18),char(2),char(7),char(255),char(154), -char(3),char(18),char(2),char(11),char(255),char(154),char(3),char(18),char(2),char(160), -char(255),char(215),char(3),char(18),char(2),char(170),char(255),char(195),char(3),char(18), -char(2),char(182),char(255),char(195),char(3),char(18),char(2),char(188),char(255),char(215), -char(3),char(18),char(2),char(190),char(255),char(195),char(3),char(18),char(2),char(192), -char(255),char(215),char(3),char(18),char(2),char(194),char(255),char(215),char(3),char(18), -char(2),char(203),char(255),char(215),char(3),char(18),char(2),char(213),char(255),char(215), -char(3),char(18),char(2),char(230),char(255),char(215),char(3),char(18),char(2),char(248), -char(255),char(215),char(3),char(18),char(2),char(250),char(255),char(215),char(3),char(18), -char(2),char(252),char(255),char(215),char(3),char(18),char(2),char(254),char(255),char(215), -char(3),char(18),char(3),char(6),char(255),char(215),char(3),char(18),char(3),char(8), -char(255),char(215),char(3),char(18),char(3),char(14),char(255),char(154),char(3),char(18), -char(3),char(16),char(255),char(154),char(3),char(18),char(3),char(24),char(255),char(195), -char(3),char(19),char(0),char(5),char(255),char(154),char(3),char(19),char(0),char(10), -char(255),char(154),char(3),char(19),char(1),char(157),char(255),char(174),char(3),char(19), -char(1),char(166),char(255),char(174),char(3),char(19),char(1),char(168),char(255),char(195), -char(3),char(19),char(1),char(170),char(255),char(195),char(3),char(19),char(1),char(176), -char(255),char(195),char(3),char(19),char(1),char(188),char(255),char(113),char(3),char(19), -char(1),char(189),char(255),char(195),char(3),char(19),char(1),char(191),char(255),char(195), -char(3),char(19),char(1),char(193),char(255),char(195),char(3),char(19),char(1),char(196), -char(255),char(174),char(3),char(19),char(1),char(208),char(255),char(215),char(3),char(19), -char(1),char(220),char(255),char(195),char(3),char(19),char(1),char(223),char(255),char(215), -char(3),char(19),char(1),char(225),char(255),char(215),char(3),char(19),char(1),char(228), -char(255),char(195),char(3),char(19),char(2),char(7),char(255),char(154),char(3),char(19), -char(2),char(11),char(255),char(154),char(3),char(19),char(2),char(114),char(255),char(195), -char(3),char(19),char(2),char(118),char(255),char(215),char(3),char(19),char(2),char(124), -char(255),char(195),char(3),char(19),char(2),char(128),char(255),char(195),char(3),char(19), -char(2),char(130),char(255),char(195),char(3),char(19),char(2),char(159),char(255),char(195), -char(3),char(19),char(2),char(160),char(255),char(215),char(3),char(19),char(2),char(169), -char(255),char(174),char(3),char(19),char(2),char(170),char(255),char(195),char(3),char(19), -char(2),char(181),char(255),char(113),char(3),char(19),char(2),char(182),char(255),char(195), -char(3),char(19),char(2),char(183),char(255),char(195),char(3),char(19),char(2),char(185), -char(255),char(195),char(3),char(19),char(2),char(187),char(255),char(195),char(3),char(19), -char(2),char(188),char(255),char(215),char(3),char(19),char(2),char(189),char(255),char(174), -char(3),char(19),char(2),char(190),char(255),char(195),char(3),char(19),char(2),char(191), -char(255),char(195),char(3),char(19),char(2),char(192),char(255),char(215),char(3),char(19), -char(2),char(193),char(255),char(195),char(3),char(19),char(2),char(194),char(255),char(215), -char(3),char(19),char(2),char(202),char(255),char(195),char(3),char(19),char(2),char(203), -char(255),char(215),char(3),char(19),char(2),char(212),char(255),char(195),char(3),char(19), -char(2),char(213),char(255),char(215),char(3),char(19),char(2),char(217),char(255),char(195), -char(3),char(19),char(2),char(219),char(255),char(195),char(3),char(19),char(2),char(221), -char(255),char(195),char(3),char(19),char(2),char(229),char(255),char(195),char(3),char(19), -char(2),char(230),char(255),char(215),char(3),char(19),char(2),char(247),char(255),char(195), -char(3),char(19),char(2),char(249),char(255),char(195),char(3),char(19),char(2),char(251), -char(255),char(195),char(3),char(19),char(2),char(253),char(255),char(195),char(3),char(19), -char(2),char(254),char(255),char(215),char(3),char(19),char(3),char(5),char(255),char(195), -char(3),char(19),char(3),char(6),char(255),char(215),char(3),char(19),char(3),char(7), -char(255),char(195),char(3),char(19),char(3),char(8),char(255),char(215),char(3),char(19), -char(3),char(13),char(255),char(215),char(3),char(19),char(3),char(14),char(255),char(215), -char(3),char(19),char(3),char(15),char(255),char(215),char(3),char(19),char(3),char(16), -char(255),char(215),char(3),char(19),char(3),char(23),char(255),char(174),char(3),char(19), -char(3),char(24),char(255),char(195),char(3),char(20),char(0),char(5),char(255),char(154), -char(3),char(20),char(0),char(10),char(255),char(154),char(3),char(20),char(1),char(208), -char(255),char(215),char(3),char(20),char(1),char(220),char(255),char(195),char(3),char(20), -char(1),char(221),char(255),char(215),char(3),char(20),char(1),char(223),char(255),char(215), -char(3),char(20),char(1),char(225),char(255),char(215),char(3),char(20),char(1),char(228), -char(255),char(195),char(3),char(20),char(1),char(246),char(255),char(215),char(3),char(20), -char(2),char(7),char(255),char(154),char(3),char(20),char(2),char(11),char(255),char(154), -char(3),char(20),char(2),char(160),char(255),char(215),char(3),char(20),char(2),char(170), -char(255),char(195),char(3),char(20),char(2),char(182),char(255),char(195),char(3),char(20), -char(2),char(188),char(255),char(215),char(3),char(20),char(2),char(190),char(255),char(195), -char(3),char(20),char(2),char(192),char(255),char(215),char(3),char(20),char(2),char(194), -char(255),char(215),char(3),char(20),char(2),char(203),char(255),char(215),char(3),char(20), -char(2),char(213),char(255),char(215),char(3),char(20),char(2),char(230),char(255),char(215), -char(3),char(20),char(2),char(248),char(255),char(215),char(3),char(20),char(2),char(250), -char(255),char(215),char(3),char(20),char(2),char(252),char(255),char(215),char(3),char(20), -char(2),char(254),char(255),char(215),char(3),char(20),char(3),char(6),char(255),char(215), -char(3),char(20),char(3),char(8),char(255),char(215),char(3),char(20),char(3),char(14), -char(255),char(154),char(3),char(20),char(3),char(16),char(255),char(154),char(3),char(20), -char(3),char(24),char(255),char(195),char(3),char(21),char(0),char(15),char(255),char(174), -char(3),char(21),char(0),char(17),char(255),char(174),char(3),char(21),char(1),char(170), -char(255),char(236),char(3),char(21),char(1),char(176),char(255),char(215),char(3),char(21), -char(1),char(188),char(255),char(215),char(3),char(21),char(1),char(191),char(255),char(215), -char(3),char(21),char(2),char(8),char(255),char(174),char(3),char(21),char(2),char(12), -char(255),char(174),char(3),char(21),char(2),char(114),char(255),char(236),char(3),char(21), -char(2),char(128),char(255),char(236),char(3),char(21),char(2),char(130),char(255),char(236), -char(3),char(21),char(2),char(159),char(255),char(215),char(3),char(21),char(2),char(181), -char(255),char(215),char(3),char(21),char(2),char(183),char(255),char(236),char(3),char(21), -char(2),char(185),char(255),char(236),char(3),char(21),char(2),char(187),char(255),char(215), -char(3),char(21),char(2),char(202),char(255),char(215),char(3),char(21),char(2),char(217), -char(255),char(236),char(3),char(21),char(2),char(219),char(255),char(236),char(3),char(21), -char(2),char(221),char(255),char(236),char(3),char(21),char(2),char(229),char(255),char(215), -char(3),char(21),char(3),char(5),char(255),char(215),char(3),char(21),char(3),char(7), -char(255),char(215),char(3),char(22),char(0),char(5),char(255),char(215),char(3),char(22), -char(0),char(10),char(255),char(215),char(3),char(22),char(1),char(208),char(255),char(236), -char(3),char(22),char(1),char(221),char(255),char(236),char(3),char(22),char(1),char(223), -char(255),char(236),char(3),char(22),char(1),char(246),char(255),char(236),char(3),char(22), -char(2),char(7),char(255),char(215),char(3),char(22),char(2),char(11),char(255),char(215), -char(3),char(22),char(2),char(160),char(255),char(236),char(3),char(22),char(2),char(188), -char(255),char(236),char(3),char(22),char(2),char(203),char(255),char(236),char(3),char(22), -char(2),char(230),char(255),char(236),char(3),char(22),char(2),char(248),char(255),char(236), -char(3),char(22),char(2),char(250),char(255),char(236),char(3),char(22),char(2),char(252), -char(255),char(236),char(3),char(22),char(3),char(6),char(255),char(236),char(3),char(22), -char(3),char(8),char(255),char(236),char(3),char(22),char(3),char(14),char(255),char(215), -char(3),char(22),char(3),char(16),char(255),char(215),char(3),char(23),char(0),char(5), -char(255),char(174),char(3),char(23),char(0),char(10),char(255),char(174),char(3),char(23), -char(1),char(157),char(255),char(195),char(3),char(23),char(1),char(166),char(255),char(195), -char(3),char(23),char(1),char(170),char(255),char(215),char(3),char(23),char(1),char(176), -char(255),char(215),char(3),char(23),char(1),char(188),char(255),char(195),char(3),char(23), -char(1),char(191),char(255),char(215),char(3),char(23),char(1),char(193),char(255),char(215), -char(3),char(23),char(1),char(196),char(255),char(195),char(3),char(23),char(1),char(220), -char(255),char(215),char(3),char(23),char(1),char(228),char(255),char(215),char(3),char(23), -char(2),char(7),char(255),char(174),char(3),char(23),char(2),char(11),char(255),char(174), -char(3),char(23),char(2),char(114),char(255),char(215),char(3),char(23),char(2),char(124), -char(255),char(215),char(3),char(23),char(2),char(128),char(255),char(215),char(3),char(23), -char(2),char(130),char(255),char(215),char(3),char(23),char(2),char(159),char(255),char(215), -char(3),char(23),char(2),char(169),char(255),char(195),char(3),char(23),char(2),char(170), -char(255),char(215),char(3),char(23),char(2),char(181),char(255),char(195),char(3),char(23), -char(2),char(182),char(255),char(215),char(3),char(23),char(2),char(183),char(255),char(215), -char(3),char(23),char(2),char(185),char(255),char(215),char(3),char(23),char(2),char(187), -char(255),char(215),char(3),char(23),char(2),char(189),char(255),char(195),char(3),char(23), -char(2),char(190),char(255),char(215),char(3),char(23),char(2),char(191),char(255),char(215), -char(3),char(23),char(2),char(193),char(255),char(215),char(3),char(23),char(2),char(202), -char(255),char(215),char(3),char(23),char(2),char(212),char(255),char(215),char(3),char(23), -char(2),char(217),char(255),char(215),char(3),char(23),char(2),char(219),char(255),char(215), -char(3),char(23),char(2),char(221),char(255),char(215),char(3),char(23),char(2),char(229), -char(255),char(215),char(3),char(23),char(2),char(253),char(255),char(215),char(3),char(23), -char(3),char(5),char(255),char(215),char(3),char(23),char(3),char(7),char(255),char(215), -char(3),char(23),char(3),char(13),char(255),char(215),char(3),char(23),char(3),char(15), -char(255),char(215),char(3),char(23),char(3),char(23),char(255),char(195),char(3),char(23), -char(3),char(24),char(255),char(215),char(3),char(24),char(0),char(5),char(255),char(154), -char(3),char(24),char(0),char(10),char(255),char(154),char(3),char(24),char(1),char(208), -char(255),char(215),char(3),char(24),char(1),char(220),char(255),char(195),char(3),char(24), -char(1),char(221),char(255),char(215),char(3),char(24),char(1),char(223),char(255),char(215), -char(3),char(24),char(1),char(225),char(255),char(215),char(3),char(24),char(1),char(228), -char(255),char(195),char(3),char(24),char(1),char(246),char(255),char(215),char(3),char(24), -char(2),char(7),char(255),char(154),char(3),char(24),char(2),char(11),char(255),char(154), -char(3),char(24),char(2),char(160),char(255),char(215),char(3),char(24),char(2),char(170), -char(255),char(195),char(3),char(24),char(2),char(182),char(255),char(195),char(3),char(24), -char(2),char(188),char(255),char(215),char(3),char(24),char(2),char(190),char(255),char(195), -char(3),char(24),char(2),char(192),char(255),char(215),char(3),char(24),char(2),char(194), -char(255),char(215),char(3),char(24),char(2),char(203),char(255),char(215),char(3),char(24), -char(2),char(213),char(255),char(215),char(3),char(24),char(2),char(230),char(255),char(215), -char(3),char(24),char(2),char(248),char(255),char(215),char(3),char(24),char(2),char(250), -char(255),char(215),char(3),char(24),char(2),char(252),char(255),char(215),char(3),char(24), -char(2),char(254),char(255),char(215),char(3),char(24),char(3),char(6),char(255),char(215), -char(3),char(24),char(3),char(8),char(255),char(215),char(3),char(24),char(3),char(14), -char(255),char(154),char(3),char(24),char(3),char(16),char(255),char(154),char(3),char(24), -char(3),char(24),char(255),char(195),char(3),char(25),char(1),char(225),char(255),char(215), -char(3),char(25),char(2),char(192),char(255),char(215),char(3),char(25),char(2),char(194), -char(255),char(215),char(3),char(25),char(2),char(213),char(255),char(215),char(3),char(25), -char(2),char(254),char(255),char(215),char(3),char(27),char(1),char(163),char(0),char(225), -char(3),char(27),char(2),char(234),char(0),char(41),char(3),char(27),char(3),char(14), -char(255),char(215),char(3),char(27),char(3),char(16),char(255),char(215),char(3),char(28), -char(0),char(5),char(255),char(236),char(3),char(28),char(0),char(10),char(255),char(236), -char(3),char(28),char(2),char(7),char(255),char(236),char(3),char(28),char(2),char(11), -char(255),char(236),char(3),char(29),char(0),char(5),char(255),char(113),char(3),char(29), -char(0),char(10),char(255),char(113),char(3),char(29),char(0),char(38),char(255),char(215), -char(3),char(29),char(0),char(42),char(255),char(215),char(3),char(29),char(0),char(45), -char(1),char(10),char(3),char(29),char(0),char(50),char(255),char(215),char(3),char(29), -char(0),char(52),char(255),char(215),char(3),char(29),char(0),char(55),char(255),char(113), -char(3),char(29),char(0),char(57),char(255),char(174),char(3),char(29),char(0),char(58), -char(255),char(174),char(3),char(29),char(0),char(60),char(255),char(133),char(3),char(29), -char(0),char(137),char(255),char(215),char(3),char(29),char(0),char(148),char(255),char(215), -char(3),char(29),char(0),char(149),char(255),char(215),char(3),char(29),char(0),char(150), -char(255),char(215),char(3),char(29),char(0),char(151),char(255),char(215),char(3),char(29), -char(0),char(152),char(255),char(215),char(3),char(29),char(0),char(154),char(255),char(215), -char(3),char(29),char(0),char(159),char(255),char(133),char(3),char(29),char(0),char(200), -char(255),char(215),char(3),char(29),char(0),char(202),char(255),char(215),char(3),char(29), -char(0),char(204),char(255),char(215),char(3),char(29),char(0),char(206),char(255),char(215), -char(3),char(29),char(0),char(222),char(255),char(215),char(3),char(29),char(0),char(224), -char(255),char(215),char(3),char(29),char(0),char(226),char(255),char(215),char(3),char(29), -char(0),char(228),char(255),char(215),char(3),char(29),char(1),char(14),char(255),char(215), -char(3),char(29),char(1),char(16),char(255),char(215),char(3),char(29),char(1),char(18), -char(255),char(215),char(3),char(29),char(1),char(20),char(255),char(215),char(3),char(29), -char(1),char(36),char(255),char(113),char(3),char(29),char(1),char(38),char(255),char(113), -char(3),char(29),char(1),char(54),char(255),char(174),char(3),char(29),char(1),char(56), -char(255),char(133),char(3),char(29),char(1),char(58),char(255),char(133),char(3),char(29), -char(1),char(71),char(255),char(215),char(3),char(29),char(1),char(250),char(255),char(174), -char(3),char(29),char(1),char(252),char(255),char(174),char(3),char(29),char(1),char(254), -char(255),char(174),char(3),char(29),char(2),char(0),char(255),char(133),char(3),char(29), -char(2),char(7),char(255),char(113),char(3),char(29),char(2),char(11),char(255),char(113), -char(3),char(29),char(2),char(95),char(255),char(215),char(3),char(29),char(3),char(73), -char(255),char(215),char(3),char(29),char(3),char(75),char(255),char(215),char(3),char(29), -char(3),char(77),char(255),char(215),char(3),char(29),char(3),char(79),char(255),char(215), -char(3),char(29),char(3),char(81),char(255),char(215),char(3),char(29),char(3),char(83), -char(255),char(215),char(3),char(29),char(3),char(85),char(255),char(215),char(3),char(29), -char(3),char(87),char(255),char(215),char(3),char(29),char(3),char(89),char(255),char(215), -char(3),char(29),char(3),char(91),char(255),char(215),char(3),char(29),char(3),char(93), -char(255),char(215),char(3),char(29),char(3),char(95),char(255),char(215),char(3),char(29), -char(3),char(111),char(255),char(133),char(3),char(29),char(3),char(113),char(255),char(133), -char(3),char(29),char(3),char(115),char(255),char(133),char(3),char(29),char(3),char(143), -char(255),char(113),char(3),char(30),char(0),char(5),char(255),char(236),char(3),char(30), -char(0),char(10),char(255),char(236),char(3),char(30),char(2),char(7),char(255),char(236), -char(3),char(30),char(2),char(11),char(255),char(236),char(3),char(31),char(0),char(5), -char(255),char(113),char(3),char(31),char(0),char(10),char(255),char(113),char(3),char(31), -char(0),char(38),char(255),char(215),char(3),char(31),char(0),char(42),char(255),char(215), -char(3),char(31),char(0),char(45),char(1),char(10),char(3),char(31),char(0),char(50), -char(255),char(215),char(3),char(31),char(0),char(52),char(255),char(215),char(3),char(31), -char(0),char(55),char(255),char(113),char(3),char(31),char(0),char(57),char(255),char(174), -char(3),char(31),char(0),char(58),char(255),char(174),char(3),char(31),char(0),char(60), -char(255),char(133),char(3),char(31),char(0),char(137),char(255),char(215),char(3),char(31), -char(0),char(148),char(255),char(215),char(3),char(31),char(0),char(149),char(255),char(215), -char(3),char(31),char(0),char(150),char(255),char(215),char(3),char(31),char(0),char(151), -char(255),char(215),char(3),char(31),char(0),char(152),char(255),char(215),char(3),char(31), -char(0),char(154),char(255),char(215),char(3),char(31),char(0),char(159),char(255),char(133), -char(3),char(31),char(0),char(200),char(255),char(215),char(3),char(31),char(0),char(202), -char(255),char(215),char(3),char(31),char(0),char(204),char(255),char(215),char(3),char(31), -char(0),char(206),char(255),char(215),char(3),char(31),char(0),char(222),char(255),char(215), -char(3),char(31),char(0),char(224),char(255),char(215),char(3),char(31),char(0),char(226), -char(255),char(215),char(3),char(31),char(0),char(228),char(255),char(215),char(3),char(31), -char(1),char(14),char(255),char(215),char(3),char(31),char(1),char(16),char(255),char(215), -char(3),char(31),char(1),char(18),char(255),char(215),char(3),char(31),char(1),char(20), -char(255),char(215),char(3),char(31),char(1),char(36),char(255),char(113),char(3),char(31), -char(1),char(38),char(255),char(113),char(3),char(31),char(1),char(54),char(255),char(174), -char(3),char(31),char(1),char(56),char(255),char(133),char(3),char(31),char(1),char(58), -char(255),char(133),char(3),char(31),char(1),char(71),char(255),char(215),char(3),char(31), -char(1),char(250),char(255),char(174),char(3),char(31),char(1),char(252),char(255),char(174), -char(3),char(31),char(1),char(254),char(255),char(174),char(3),char(31),char(2),char(0), -char(255),char(133),char(3),char(31),char(2),char(7),char(255),char(113),char(3),char(31), -char(2),char(11),char(255),char(113),char(3),char(31),char(2),char(95),char(255),char(215), -char(3),char(31),char(3),char(73),char(255),char(215),char(3),char(31),char(3),char(75), -char(255),char(215),char(3),char(31),char(3),char(77),char(255),char(215),char(3),char(31), -char(3),char(79),char(255),char(215),char(3),char(31),char(3),char(81),char(255),char(215), -char(3),char(31),char(3),char(83),char(255),char(215),char(3),char(31),char(3),char(85), -char(255),char(215),char(3),char(31),char(3),char(87),char(255),char(215),char(3),char(31), -char(3),char(89),char(255),char(215),char(3),char(31),char(3),char(91),char(255),char(215), -char(3),char(31),char(3),char(93),char(255),char(215),char(3),char(31),char(3),char(95), -char(255),char(215),char(3),char(31),char(3),char(111),char(255),char(133),char(3),char(31), -char(3),char(113),char(255),char(133),char(3),char(31),char(3),char(115),char(255),char(133), -char(3),char(31),char(3),char(143),char(255),char(113),char(3),char(32),char(0),char(5), -char(255),char(236),char(3),char(32),char(0),char(10),char(255),char(236),char(3),char(32), -char(2),char(7),char(255),char(236),char(3),char(32),char(2),char(11),char(255),char(236), -char(3),char(33),char(0),char(5),char(255),char(113),char(3),char(33),char(0),char(10), -char(255),char(113),char(3),char(33),char(0),char(38),char(255),char(215),char(3),char(33), -char(0),char(42),char(255),char(215),char(3),char(33),char(0),char(45),char(1),char(10), -char(3),char(33),char(0),char(50),char(255),char(215),char(3),char(33),char(0),char(52), -char(255),char(215),char(3),char(33),char(0),char(55),char(255),char(113),char(3),char(33), -char(0),char(57),char(255),char(174),char(3),char(33),char(0),char(58),char(255),char(174), -char(3),char(33),char(0),char(60),char(255),char(133),char(3),char(33),char(0),char(137), -char(255),char(215),char(3),char(33),char(0),char(148),char(255),char(215),char(3),char(33), -char(0),char(149),char(255),char(215),char(3),char(33),char(0),char(150),char(255),char(215), -char(3),char(33),char(0),char(151),char(255),char(215),char(3),char(33),char(0),char(152), -char(255),char(215),char(3),char(33),char(0),char(154),char(255),char(215),char(3),char(33), -char(0),char(159),char(255),char(133),char(3),char(33),char(0),char(200),char(255),char(215), -char(3),char(33),char(0),char(202),char(255),char(215),char(3),char(33),char(0),char(204), -char(255),char(215),char(3),char(33),char(0),char(206),char(255),char(215),char(3),char(33), -char(0),char(222),char(255),char(215),char(3),char(33),char(0),char(224),char(255),char(215), -char(3),char(33),char(0),char(226),char(255),char(215),char(3),char(33),char(0),char(228), -char(255),char(215),char(3),char(33),char(1),char(14),char(255),char(215),char(3),char(33), -char(1),char(16),char(255),char(215),char(3),char(33),char(1),char(18),char(255),char(215), -char(3),char(33),char(1),char(20),char(255),char(215),char(3),char(33),char(1),char(36), -char(255),char(113),char(3),char(33),char(1),char(38),char(255),char(113),char(3),char(33), -char(1),char(54),char(255),char(174),char(3),char(33),char(1),char(56),char(255),char(133), -char(3),char(33),char(1),char(58),char(255),char(133),char(3),char(33),char(1),char(71), -char(255),char(215),char(3),char(33),char(1),char(250),char(255),char(174),char(3),char(33), -char(1),char(252),char(255),char(174),char(3),char(33),char(1),char(254),char(255),char(174), -char(3),char(33),char(2),char(0),char(255),char(133),char(3),char(33),char(2),char(7), -char(255),char(113),char(3),char(33),char(2),char(11),char(255),char(113),char(3),char(33), -char(2),char(95),char(255),char(215),char(3),char(33),char(3),char(73),char(255),char(215), -char(3),char(33),char(3),char(75),char(255),char(215),char(3),char(33),char(3),char(77), -char(255),char(215),char(3),char(33),char(3),char(79),char(255),char(215),char(3),char(33), -char(3),char(81),char(255),char(215),char(3),char(33),char(3),char(83),char(255),char(215), -char(3),char(33),char(3),char(85),char(255),char(215),char(3),char(33),char(3),char(87), -char(255),char(215),char(3),char(33),char(3),char(89),char(255),char(215),char(3),char(33), -char(3),char(91),char(255),char(215),char(3),char(33),char(3),char(93),char(255),char(215), -char(3),char(33),char(3),char(95),char(255),char(215),char(3),char(33),char(3),char(111), -char(255),char(133),char(3),char(33),char(3),char(113),char(255),char(133),char(3),char(33), -char(3),char(115),char(255),char(133),char(3),char(33),char(3),char(143),char(255),char(113), -char(3),char(34),char(0),char(5),char(255),char(236),char(3),char(34),char(0),char(10), -char(255),char(236),char(3),char(34),char(2),char(7),char(255),char(236),char(3),char(34), -char(2),char(11),char(255),char(236),char(3),char(35),char(0),char(5),char(255),char(113), -char(3),char(35),char(0),char(10),char(255),char(113),char(3),char(35),char(0),char(38), -char(255),char(215),char(3),char(35),char(0),char(42),char(255),char(215),char(3),char(35), -char(0),char(45),char(1),char(10),char(3),char(35),char(0),char(50),char(255),char(215), -char(3),char(35),char(0),char(52),char(255),char(215),char(3),char(35),char(0),char(55), -char(255),char(113),char(3),char(35),char(0),char(57),char(255),char(174),char(3),char(35), -char(0),char(58),char(255),char(174),char(3),char(35),char(0),char(60),char(255),char(133), -char(3),char(35),char(0),char(137),char(255),char(215),char(3),char(35),char(0),char(148), -char(255),char(215),char(3),char(35),char(0),char(149),char(255),char(215),char(3),char(35), -char(0),char(150),char(255),char(215),char(3),char(35),char(0),char(151),char(255),char(215), -char(3),char(35),char(0),char(152),char(255),char(215),char(3),char(35),char(0),char(154), -char(255),char(215),char(3),char(35),char(0),char(159),char(255),char(133),char(3),char(35), -char(0),char(200),char(255),char(215),char(3),char(35),char(0),char(202),char(255),char(215), -char(3),char(35),char(0),char(204),char(255),char(215),char(3),char(35),char(0),char(206), -char(255),char(215),char(3),char(35),char(0),char(222),char(255),char(215),char(3),char(35), -char(0),char(224),char(255),char(215),char(3),char(35),char(0),char(226),char(255),char(215), -char(3),char(35),char(0),char(228),char(255),char(215),char(3),char(35),char(1),char(14), -char(255),char(215),char(3),char(35),char(1),char(16),char(255),char(215),char(3),char(35), -char(1),char(18),char(255),char(215),char(3),char(35),char(1),char(20),char(255),char(215), -char(3),char(35),char(1),char(36),char(255),char(113),char(3),char(35),char(1),char(38), -char(255),char(113),char(3),char(35),char(1),char(54),char(255),char(174),char(3),char(35), -char(1),char(56),char(255),char(133),char(3),char(35),char(1),char(58),char(255),char(133), -char(3),char(35),char(1),char(71),char(255),char(215),char(3),char(35),char(1),char(250), -char(255),char(174),char(3),char(35),char(1),char(252),char(255),char(174),char(3),char(35), -char(1),char(254),char(255),char(174),char(3),char(35),char(2),char(0),char(255),char(133), -char(3),char(35),char(2),char(7),char(255),char(113),char(3),char(35),char(2),char(11), -char(255),char(113),char(3),char(35),char(2),char(95),char(255),char(215),char(3),char(35), -char(3),char(73),char(255),char(215),char(3),char(35),char(3),char(75),char(255),char(215), -char(3),char(35),char(3),char(77),char(255),char(215),char(3),char(35),char(3),char(79), -char(255),char(215),char(3),char(35),char(3),char(81),char(255),char(215),char(3),char(35), -char(3),char(83),char(255),char(215),char(3),char(35),char(3),char(85),char(255),char(215), -char(3),char(35),char(3),char(87),char(255),char(215),char(3),char(35),char(3),char(89), -char(255),char(215),char(3),char(35),char(3),char(91),char(255),char(215),char(3),char(35), -char(3),char(93),char(255),char(215),char(3),char(35),char(3),char(95),char(255),char(215), -char(3),char(35),char(3),char(111),char(255),char(133),char(3),char(35),char(3),char(113), -char(255),char(133),char(3),char(35),char(3),char(115),char(255),char(133),char(3),char(35), -char(3),char(143),char(255),char(113),char(3),char(36),char(0),char(5),char(255),char(236), -char(3),char(36),char(0),char(10),char(255),char(236),char(3),char(36),char(2),char(7), -char(255),char(236),char(3),char(36),char(2),char(11),char(255),char(236),char(3),char(37), -char(0),char(5),char(255),char(113),char(3),char(37),char(0),char(10),char(255),char(113), -char(3),char(37),char(0),char(38),char(255),char(215),char(3),char(37),char(0),char(42), -char(255),char(215),char(3),char(37),char(0),char(45),char(1),char(10),char(3),char(37), -char(0),char(50),char(255),char(215),char(3),char(37),char(0),char(52),char(255),char(215), -char(3),char(37),char(0),char(55),char(255),char(113),char(3),char(37),char(0),char(57), -char(255),char(174),char(3),char(37),char(0),char(58),char(255),char(174),char(3),char(37), -char(0),char(60),char(255),char(133),char(3),char(37),char(0),char(137),char(255),char(215), -char(3),char(37),char(0),char(148),char(255),char(215),char(3),char(37),char(0),char(149), -char(255),char(215),char(3),char(37),char(0),char(150),char(255),char(215),char(3),char(37), -char(0),char(151),char(255),char(215),char(3),char(37),char(0),char(152),char(255),char(215), -char(3),char(37),char(0),char(154),char(255),char(215),char(3),char(37),char(0),char(159), -char(255),char(133),char(3),char(37),char(0),char(200),char(255),char(215),char(3),char(37), -char(0),char(202),char(255),char(215),char(3),char(37),char(0),char(204),char(255),char(215), -char(3),char(37),char(0),char(206),char(255),char(215),char(3),char(37),char(0),char(222), -char(255),char(215),char(3),char(37),char(0),char(224),char(255),char(215),char(3),char(37), -char(0),char(226),char(255),char(215),char(3),char(37),char(0),char(228),char(255),char(215), -char(3),char(37),char(1),char(14),char(255),char(215),char(3),char(37),char(1),char(16), -char(255),char(215),char(3),char(37),char(1),char(18),char(255),char(215),char(3),char(37), -char(1),char(20),char(255),char(215),char(3),char(37),char(1),char(36),char(255),char(113), -char(3),char(37),char(1),char(38),char(255),char(113),char(3),char(37),char(1),char(54), -char(255),char(174),char(3),char(37),char(1),char(56),char(255),char(133),char(3),char(37), -char(1),char(58),char(255),char(133),char(3),char(37),char(1),char(71),char(255),char(215), -char(3),char(37),char(1),char(250),char(255),char(174),char(3),char(37),char(1),char(252), -char(255),char(174),char(3),char(37),char(1),char(254),char(255),char(174),char(3),char(37), -char(2),char(0),char(255),char(133),char(3),char(37),char(2),char(7),char(255),char(113), -char(3),char(37),char(2),char(11),char(255),char(113),char(3),char(37),char(2),char(95), -char(255),char(215),char(3),char(37),char(3),char(73),char(255),char(215),char(3),char(37), -char(3),char(75),char(255),char(215),char(3),char(37),char(3),char(77),char(255),char(215), -char(3),char(37),char(3),char(79),char(255),char(215),char(3),char(37),char(3),char(81), -char(255),char(215),char(3),char(37),char(3),char(83),char(255),char(215),char(3),char(37), -char(3),char(85),char(255),char(215),char(3),char(37),char(3),char(87),char(255),char(215), -char(3),char(37),char(3),char(89),char(255),char(215),char(3),char(37),char(3),char(91), -char(255),char(215),char(3),char(37),char(3),char(93),char(255),char(215),char(3),char(37), -char(3),char(95),char(255),char(215),char(3),char(37),char(3),char(111),char(255),char(133), -char(3),char(37),char(3),char(113),char(255),char(133),char(3),char(37),char(3),char(115), -char(255),char(133),char(3),char(37),char(3),char(143),char(255),char(113),char(3),char(38), -char(0),char(5),char(255),char(236),char(3),char(38),char(0),char(10),char(255),char(236), -char(3),char(38),char(2),char(7),char(255),char(236),char(3),char(38),char(2),char(11), -char(255),char(236),char(3),char(39),char(0),char(5),char(255),char(113),char(3),char(39), -char(0),char(10),char(255),char(113),char(3),char(39),char(0),char(38),char(255),char(215), -char(3),char(39),char(0),char(42),char(255),char(215),char(3),char(39),char(0),char(45), -char(1),char(10),char(3),char(39),char(0),char(50),char(255),char(215),char(3),char(39), -char(0),char(52),char(255),char(215),char(3),char(39),char(0),char(55),char(255),char(113), -char(3),char(39),char(0),char(57),char(255),char(174),char(3),char(39),char(0),char(58), -char(255),char(174),char(3),char(39),char(0),char(60),char(255),char(133),char(3),char(39), -char(0),char(137),char(255),char(215),char(3),char(39),char(0),char(148),char(255),char(215), -char(3),char(39),char(0),char(149),char(255),char(215),char(3),char(39),char(0),char(150), -char(255),char(215),char(3),char(39),char(0),char(151),char(255),char(215),char(3),char(39), -char(0),char(152),char(255),char(215),char(3),char(39),char(0),char(154),char(255),char(215), -char(3),char(39),char(0),char(159),char(255),char(133),char(3),char(39),char(0),char(200), -char(255),char(215),char(3),char(39),char(0),char(202),char(255),char(215),char(3),char(39), -char(0),char(204),char(255),char(215),char(3),char(39),char(0),char(206),char(255),char(215), -char(3),char(39),char(0),char(222),char(255),char(215),char(3),char(39),char(0),char(224), -char(255),char(215),char(3),char(39),char(0),char(226),char(255),char(215),char(3),char(39), -char(0),char(228),char(255),char(215),char(3),char(39),char(1),char(14),char(255),char(215), -char(3),char(39),char(1),char(16),char(255),char(215),char(3),char(39),char(1),char(18), -char(255),char(215),char(3),char(39),char(1),char(20),char(255),char(215),char(3),char(39), -char(1),char(36),char(255),char(113),char(3),char(39),char(1),char(38),char(255),char(113), -char(3),char(39),char(1),char(54),char(255),char(174),char(3),char(39),char(1),char(56), -char(255),char(133),char(3),char(39),char(1),char(58),char(255),char(133),char(3),char(39), -char(1),char(71),char(255),char(215),char(3),char(39),char(1),char(250),char(255),char(174), -char(3),char(39),char(1),char(252),char(255),char(174),char(3),char(39),char(1),char(254), -char(255),char(174),char(3),char(39),char(2),char(0),char(255),char(133),char(3),char(39), -char(2),char(7),char(255),char(113),char(3),char(39),char(2),char(11),char(255),char(113), -char(3),char(39),char(2),char(95),char(255),char(215),char(3),char(39),char(3),char(73), -char(255),char(215),char(3),char(39),char(3),char(75),char(255),char(215),char(3),char(39), -char(3),char(77),char(255),char(215),char(3),char(39),char(3),char(79),char(255),char(215), -char(3),char(39),char(3),char(81),char(255),char(215),char(3),char(39),char(3),char(83), -char(255),char(215),char(3),char(39),char(3),char(85),char(255),char(215),char(3),char(39), -char(3),char(87),char(255),char(215),char(3),char(39),char(3),char(89),char(255),char(215), -char(3),char(39),char(3),char(91),char(255),char(215),char(3),char(39),char(3),char(93), -char(255),char(215),char(3),char(39),char(3),char(95),char(255),char(215),char(3),char(39), -char(3),char(111),char(255),char(133),char(3),char(39),char(3),char(113),char(255),char(133), -char(3),char(39),char(3),char(115),char(255),char(133),char(3),char(39),char(3),char(143), -char(255),char(113),char(3),char(40),char(0),char(5),char(255),char(236),char(3),char(40), -char(0),char(10),char(255),char(236),char(3),char(40),char(2),char(7),char(255),char(236), -char(3),char(40),char(2),char(11),char(255),char(236),char(3),char(41),char(0),char(5), -char(255),char(113),char(3),char(41),char(0),char(10),char(255),char(113),char(3),char(41), -char(0),char(38),char(255),char(215),char(3),char(41),char(0),char(42),char(255),char(215), -char(3),char(41),char(0),char(45),char(1),char(10),char(3),char(41),char(0),char(50), -char(255),char(215),char(3),char(41),char(0),char(52),char(255),char(215),char(3),char(41), -char(0),char(55),char(255),char(113),char(3),char(41),char(0),char(57),char(255),char(174), -char(3),char(41),char(0),char(58),char(255),char(174),char(3),char(41),char(0),char(60), -char(255),char(133),char(3),char(41),char(0),char(137),char(255),char(215),char(3),char(41), -char(0),char(148),char(255),char(215),char(3),char(41),char(0),char(149),char(255),char(215), -char(3),char(41),char(0),char(150),char(255),char(215),char(3),char(41),char(0),char(151), -char(255),char(215),char(3),char(41),char(0),char(152),char(255),char(215),char(3),char(41), -char(0),char(154),char(255),char(215),char(3),char(41),char(0),char(159),char(255),char(133), -char(3),char(41),char(0),char(200),char(255),char(215),char(3),char(41),char(0),char(202), -char(255),char(215),char(3),char(41),char(0),char(204),char(255),char(215),char(3),char(41), -char(0),char(206),char(255),char(215),char(3),char(41),char(0),char(222),char(255),char(215), -char(3),char(41),char(0),char(224),char(255),char(215),char(3),char(41),char(0),char(226), -char(255),char(215),char(3),char(41),char(0),char(228),char(255),char(215),char(3),char(41), -char(1),char(14),char(255),char(215),char(3),char(41),char(1),char(16),char(255),char(215), -char(3),char(41),char(1),char(18),char(255),char(215),char(3),char(41),char(1),char(20), -char(255),char(215),char(3),char(41),char(1),char(36),char(255),char(113),char(3),char(41), -char(1),char(38),char(255),char(113),char(3),char(41),char(1),char(54),char(255),char(174), -char(3),char(41),char(1),char(56),char(255),char(133),char(3),char(41),char(1),char(58), -char(255),char(133),char(3),char(41),char(1),char(71),char(255),char(215),char(3),char(41), -char(1),char(250),char(255),char(174),char(3),char(41),char(1),char(252),char(255),char(174), -char(3),char(41),char(1),char(254),char(255),char(174),char(3),char(41),char(2),char(0), -char(255),char(133),char(3),char(41),char(2),char(7),char(255),char(113),char(3),char(41), -char(2),char(11),char(255),char(113),char(3),char(41),char(2),char(95),char(255),char(215), -char(3),char(41),char(3),char(73),char(255),char(215),char(3),char(41),char(3),char(75), -char(255),char(215),char(3),char(41),char(3),char(77),char(255),char(215),char(3),char(41), -char(3),char(79),char(255),char(215),char(3),char(41),char(3),char(81),char(255),char(215), -char(3),char(41),char(3),char(83),char(255),char(215),char(3),char(41),char(3),char(85), -char(255),char(215),char(3),char(41),char(3),char(87),char(255),char(215),char(3),char(41), -char(3),char(89),char(255),char(215),char(3),char(41),char(3),char(91),char(255),char(215), -char(3),char(41),char(3),char(93),char(255),char(215),char(3),char(41),char(3),char(95), -char(255),char(215),char(3),char(41),char(3),char(111),char(255),char(133),char(3),char(41), -char(3),char(113),char(255),char(133),char(3),char(41),char(3),char(115),char(255),char(133), -char(3),char(41),char(3),char(143),char(255),char(113),char(3),char(42),char(0),char(5), -char(255),char(236),char(3),char(42),char(0),char(10),char(255),char(236),char(3),char(42), -char(2),char(7),char(255),char(236),char(3),char(42),char(2),char(11),char(255),char(236), -char(3),char(43),char(0),char(5),char(255),char(113),char(3),char(43),char(0),char(10), -char(255),char(113),char(3),char(43),char(0),char(38),char(255),char(215),char(3),char(43), -char(0),char(42),char(255),char(215),char(3),char(43),char(0),char(45),char(1),char(10), -char(3),char(43),char(0),char(50),char(255),char(215),char(3),char(43),char(0),char(52), -char(255),char(215),char(3),char(43),char(0),char(55),char(255),char(113),char(3),char(43), -char(0),char(57),char(255),char(174),char(3),char(43),char(0),char(58),char(255),char(174), -char(3),char(43),char(0),char(60),char(255),char(133),char(3),char(43),char(0),char(137), -char(255),char(215),char(3),char(43),char(0),char(148),char(255),char(215),char(3),char(43), -char(0),char(149),char(255),char(215),char(3),char(43),char(0),char(150),char(255),char(215), -char(3),char(43),char(0),char(151),char(255),char(215),char(3),char(43),char(0),char(152), -char(255),char(215),char(3),char(43),char(0),char(154),char(255),char(215),char(3),char(43), -char(0),char(159),char(255),char(133),char(3),char(43),char(0),char(200),char(255),char(215), -char(3),char(43),char(0),char(202),char(255),char(215),char(3),char(43),char(0),char(204), -char(255),char(215),char(3),char(43),char(0),char(206),char(255),char(215),char(3),char(43), -char(0),char(222),char(255),char(215),char(3),char(43),char(0),char(224),char(255),char(215), -char(3),char(43),char(0),char(226),char(255),char(215),char(3),char(43),char(0),char(228), -char(255),char(215),char(3),char(43),char(1),char(14),char(255),char(215),char(3),char(43), -char(1),char(16),char(255),char(215),char(3),char(43),char(1),char(18),char(255),char(215), -char(3),char(43),char(1),char(20),char(255),char(215),char(3),char(43),char(1),char(36), -char(255),char(113),char(3),char(43),char(1),char(38),char(255),char(113),char(3),char(43), -char(1),char(54),char(255),char(174),char(3),char(43),char(1),char(56),char(255),char(133), -char(3),char(43),char(1),char(58),char(255),char(133),char(3),char(43),char(1),char(71), -char(255),char(215),char(3),char(43),char(1),char(250),char(255),char(174),char(3),char(43), -char(1),char(252),char(255),char(174),char(3),char(43),char(1),char(254),char(255),char(174), -char(3),char(43),char(2),char(0),char(255),char(133),char(3),char(43),char(2),char(7), -char(255),char(113),char(3),char(43),char(2),char(11),char(255),char(113),char(3),char(43), -char(2),char(95),char(255),char(215),char(3),char(43),char(3),char(73),char(255),char(215), -char(3),char(43),char(3),char(75),char(255),char(215),char(3),char(43),char(3),char(77), -char(255),char(215),char(3),char(43),char(3),char(79),char(255),char(215),char(3),char(43), -char(3),char(81),char(255),char(215),char(3),char(43),char(3),char(83),char(255),char(215), -char(3),char(43),char(3),char(85),char(255),char(215),char(3),char(43),char(3),char(87), -char(255),char(215),char(3),char(43),char(3),char(89),char(255),char(215),char(3),char(43), -char(3),char(91),char(255),char(215),char(3),char(43),char(3),char(93),char(255),char(215), -char(3),char(43),char(3),char(95),char(255),char(215),char(3),char(43),char(3),char(111), -char(255),char(133),char(3),char(43),char(3),char(113),char(255),char(133),char(3),char(43), -char(3),char(115),char(255),char(133),char(3),char(43),char(3),char(143),char(255),char(113), -char(3),char(44),char(0),char(5),char(255),char(236),char(3),char(44),char(0),char(10), -char(255),char(236),char(3),char(44),char(2),char(7),char(255),char(236),char(3),char(44), -char(2),char(11),char(255),char(236),char(3),char(45),char(0),char(5),char(255),char(113), -char(3),char(45),char(0),char(10),char(255),char(113),char(3),char(45),char(0),char(38), -char(255),char(215),char(3),char(45),char(0),char(42),char(255),char(215),char(3),char(45), -char(0),char(45),char(1),char(10),char(3),char(45),char(0),char(50),char(255),char(215), -char(3),char(45),char(0),char(52),char(255),char(215),char(3),char(45),char(0),char(55), -char(255),char(113),char(3),char(45),char(0),char(57),char(255),char(174),char(3),char(45), -char(0),char(58),char(255),char(174),char(3),char(45),char(0),char(60),char(255),char(133), -char(3),char(45),char(0),char(137),char(255),char(215),char(3),char(45),char(0),char(148), -char(255),char(215),char(3),char(45),char(0),char(149),char(255),char(215),char(3),char(45), -char(0),char(150),char(255),char(215),char(3),char(45),char(0),char(151),char(255),char(215), -char(3),char(45),char(0),char(152),char(255),char(215),char(3),char(45),char(0),char(154), -char(255),char(215),char(3),char(45),char(0),char(159),char(255),char(133),char(3),char(45), -char(0),char(200),char(255),char(215),char(3),char(45),char(0),char(202),char(255),char(215), -char(3),char(45),char(0),char(204),char(255),char(215),char(3),char(45),char(0),char(206), -char(255),char(215),char(3),char(45),char(0),char(222),char(255),char(215),char(3),char(45), -char(0),char(224),char(255),char(215),char(3),char(45),char(0),char(226),char(255),char(215), -char(3),char(45),char(0),char(228),char(255),char(215),char(3),char(45),char(1),char(14), -char(255),char(215),char(3),char(45),char(1),char(16),char(255),char(215),char(3),char(45), -char(1),char(18),char(255),char(215),char(3),char(45),char(1),char(20),char(255),char(215), -char(3),char(45),char(1),char(36),char(255),char(113),char(3),char(45),char(1),char(38), -char(255),char(113),char(3),char(45),char(1),char(54),char(255),char(174),char(3),char(45), -char(1),char(56),char(255),char(133),char(3),char(45),char(1),char(58),char(255),char(133), -char(3),char(45),char(1),char(71),char(255),char(215),char(3),char(45),char(1),char(250), -char(255),char(174),char(3),char(45),char(1),char(252),char(255),char(174),char(3),char(45), -char(1),char(254),char(255),char(174),char(3),char(45),char(2),char(0),char(255),char(133), -char(3),char(45),char(2),char(7),char(255),char(113),char(3),char(45),char(2),char(11), -char(255),char(113),char(3),char(45),char(2),char(95),char(255),char(215),char(3),char(45), -char(3),char(73),char(255),char(215),char(3),char(45),char(3),char(75),char(255),char(215), -char(3),char(45),char(3),char(77),char(255),char(215),char(3),char(45),char(3),char(79), -char(255),char(215),char(3),char(45),char(3),char(81),char(255),char(215),char(3),char(45), -char(3),char(83),char(255),char(215),char(3),char(45),char(3),char(85),char(255),char(215), -char(3),char(45),char(3),char(87),char(255),char(215),char(3),char(45),char(3),char(89), -char(255),char(215),char(3),char(45),char(3),char(91),char(255),char(215),char(3),char(45), -char(3),char(93),char(255),char(215),char(3),char(45),char(3),char(95),char(255),char(215), -char(3),char(45),char(3),char(111),char(255),char(133),char(3),char(45),char(3),char(113), -char(255),char(133),char(3),char(45),char(3),char(115),char(255),char(133),char(3),char(45), -char(3),char(143),char(255),char(113),char(3),char(46),char(0),char(5),char(255),char(236), -char(3),char(46),char(0),char(10),char(255),char(236),char(3),char(46),char(2),char(7), -char(255),char(236),char(3),char(46),char(2),char(11),char(255),char(236),char(3),char(47), -char(0),char(5),char(255),char(113),char(3),char(47),char(0),char(10),char(255),char(113), -char(3),char(47),char(0),char(38),char(255),char(215),char(3),char(47),char(0),char(42), -char(255),char(215),char(3),char(47),char(0),char(45),char(1),char(10),char(3),char(47), -char(0),char(50),char(255),char(215),char(3),char(47),char(0),char(52),char(255),char(215), -char(3),char(47),char(0),char(55),char(255),char(113),char(3),char(47),char(0),char(57), -char(255),char(174),char(3),char(47),char(0),char(58),char(255),char(174),char(3),char(47), -char(0),char(60),char(255),char(133),char(3),char(47),char(0),char(137),char(255),char(215), -char(3),char(47),char(0),char(148),char(255),char(215),char(3),char(47),char(0),char(149), -char(255),char(215),char(3),char(47),char(0),char(150),char(255),char(215),char(3),char(47), -char(0),char(151),char(255),char(215),char(3),char(47),char(0),char(152),char(255),char(215), -char(3),char(47),char(0),char(154),char(255),char(215),char(3),char(47),char(0),char(159), -char(255),char(133),char(3),char(47),char(0),char(200),char(255),char(215),char(3),char(47), -char(0),char(202),char(255),char(215),char(3),char(47),char(0),char(204),char(255),char(215), -char(3),char(47),char(0),char(206),char(255),char(215),char(3),char(47),char(0),char(222), -char(255),char(215),char(3),char(47),char(0),char(224),char(255),char(215),char(3),char(47), -char(0),char(226),char(255),char(215),char(3),char(47),char(0),char(228),char(255),char(215), -char(3),char(47),char(1),char(14),char(255),char(215),char(3),char(47),char(1),char(16), -char(255),char(215),char(3),char(47),char(1),char(18),char(255),char(215),char(3),char(47), -char(1),char(20),char(255),char(215),char(3),char(47),char(1),char(36),char(255),char(113), -char(3),char(47),char(1),char(38),char(255),char(113),char(3),char(47),char(1),char(54), -char(255),char(174),char(3),char(47),char(1),char(56),char(255),char(133),char(3),char(47), -char(1),char(58),char(255),char(133),char(3),char(47),char(1),char(71),char(255),char(215), -char(3),char(47),char(1),char(250),char(255),char(174),char(3),char(47),char(1),char(252), -char(255),char(174),char(3),char(47),char(1),char(254),char(255),char(174),char(3),char(47), -char(2),char(0),char(255),char(133),char(3),char(47),char(2),char(7),char(255),char(113), -char(3),char(47),char(2),char(11),char(255),char(113),char(3),char(47),char(2),char(95), -char(255),char(215),char(3),char(47),char(3),char(73),char(255),char(215),char(3),char(47), -char(3),char(75),char(255),char(215),char(3),char(47),char(3),char(77),char(255),char(215), -char(3),char(47),char(3),char(79),char(255),char(215),char(3),char(47),char(3),char(81), -char(255),char(215),char(3),char(47),char(3),char(83),char(255),char(215),char(3),char(47), -char(3),char(85),char(255),char(215),char(3),char(47),char(3),char(87),char(255),char(215), -char(3),char(47),char(3),char(89),char(255),char(215),char(3),char(47),char(3),char(91), -char(255),char(215),char(3),char(47),char(3),char(93),char(255),char(215),char(3),char(47), -char(3),char(95),char(255),char(215),char(3),char(47),char(3),char(111),char(255),char(133), -char(3),char(47),char(3),char(113),char(255),char(133),char(3),char(47),char(3),char(115), -char(255),char(133),char(3),char(47),char(3),char(143),char(255),char(113),char(3),char(48), -char(0),char(5),char(255),char(236),char(3),char(48),char(0),char(10),char(255),char(236), -char(3),char(48),char(2),char(7),char(255),char(236),char(3),char(48),char(2),char(11), -char(255),char(236),char(3),char(49),char(0),char(5),char(255),char(113),char(3),char(49), -char(0),char(10),char(255),char(113),char(3),char(49),char(0),char(38),char(255),char(215), -char(3),char(49),char(0),char(42),char(255),char(215),char(3),char(49),char(0),char(45), -char(1),char(10),char(3),char(49),char(0),char(50),char(255),char(215),char(3),char(49), -char(0),char(52),char(255),char(215),char(3),char(49),char(0),char(55),char(255),char(113), -char(3),char(49),char(0),char(57),char(255),char(174),char(3),char(49),char(0),char(58), -char(255),char(174),char(3),char(49),char(0),char(60),char(255),char(133),char(3),char(49), -char(0),char(137),char(255),char(215),char(3),char(49),char(0),char(148),char(255),char(215), -char(3),char(49),char(0),char(149),char(255),char(215),char(3),char(49),char(0),char(150), -char(255),char(215),char(3),char(49),char(0),char(151),char(255),char(215),char(3),char(49), -char(0),char(152),char(255),char(215),char(3),char(49),char(0),char(154),char(255),char(215), -char(3),char(49),char(0),char(159),char(255),char(133),char(3),char(49),char(0),char(200), -char(255),char(215),char(3),char(49),char(0),char(202),char(255),char(215),char(3),char(49), -char(0),char(204),char(255),char(215),char(3),char(49),char(0),char(206),char(255),char(215), -char(3),char(49),char(0),char(222),char(255),char(215),char(3),char(49),char(0),char(224), -char(255),char(215),char(3),char(49),char(0),char(226),char(255),char(215),char(3),char(49), -char(0),char(228),char(255),char(215),char(3),char(49),char(1),char(14),char(255),char(215), -char(3),char(49),char(1),char(16),char(255),char(215),char(3),char(49),char(1),char(18), -char(255),char(215),char(3),char(49),char(1),char(20),char(255),char(215),char(3),char(49), -char(1),char(36),char(255),char(113),char(3),char(49),char(1),char(38),char(255),char(113), -char(3),char(49),char(1),char(54),char(255),char(174),char(3),char(49),char(1),char(56), -char(255),char(133),char(3),char(49),char(1),char(58),char(255),char(133),char(3),char(49), -char(1),char(71),char(255),char(215),char(3),char(49),char(1),char(250),char(255),char(174), -char(3),char(49),char(1),char(252),char(255),char(174),char(3),char(49),char(1),char(254), -char(255),char(174),char(3),char(49),char(2),char(0),char(255),char(133),char(3),char(49), -char(2),char(7),char(255),char(113),char(3),char(49),char(2),char(11),char(255),char(113), -char(3),char(49),char(2),char(95),char(255),char(215),char(3),char(49),char(3),char(73), -char(255),char(215),char(3),char(49),char(3),char(75),char(255),char(215),char(3),char(49), -char(3),char(77),char(255),char(215),char(3),char(49),char(3),char(79),char(255),char(215), -char(3),char(49),char(3),char(81),char(255),char(215),char(3),char(49),char(3),char(83), -char(255),char(215),char(3),char(49),char(3),char(85),char(255),char(215),char(3),char(49), -char(3),char(87),char(255),char(215),char(3),char(49),char(3),char(89),char(255),char(215), -char(3),char(49),char(3),char(91),char(255),char(215),char(3),char(49),char(3),char(93), -char(255),char(215),char(3),char(49),char(3),char(95),char(255),char(215),char(3),char(49), -char(3),char(111),char(255),char(133),char(3),char(49),char(3),char(113),char(255),char(133), -char(3),char(49),char(3),char(115),char(255),char(133),char(3),char(49),char(3),char(143), -char(255),char(113),char(3),char(50),char(0),char(5),char(255),char(236),char(3),char(50), -char(0),char(10),char(255),char(236),char(3),char(50),char(2),char(7),char(255),char(236), -char(3),char(50),char(2),char(11),char(255),char(236),char(3),char(51),char(0),char(5), -char(255),char(113),char(3),char(51),char(0),char(10),char(255),char(113),char(3),char(51), -char(0),char(38),char(255),char(215),char(3),char(51),char(0),char(42),char(255),char(215), -char(3),char(51),char(0),char(45),char(1),char(10),char(3),char(51),char(0),char(50), -char(255),char(215),char(3),char(51),char(0),char(52),char(255),char(215),char(3),char(51), -char(0),char(55),char(255),char(113),char(3),char(51),char(0),char(57),char(255),char(174), -char(3),char(51),char(0),char(58),char(255),char(174),char(3),char(51),char(0),char(60), -char(255),char(133),char(3),char(51),char(0),char(137),char(255),char(215),char(3),char(51), -char(0),char(148),char(255),char(215),char(3),char(51),char(0),char(149),char(255),char(215), -char(3),char(51),char(0),char(150),char(255),char(215),char(3),char(51),char(0),char(151), -char(255),char(215),char(3),char(51),char(0),char(152),char(255),char(215),char(3),char(51), -char(0),char(154),char(255),char(215),char(3),char(51),char(0),char(159),char(255),char(133), -char(3),char(51),char(0),char(200),char(255),char(215),char(3),char(51),char(0),char(202), -char(255),char(215),char(3),char(51),char(0),char(204),char(255),char(215),char(3),char(51), -char(0),char(206),char(255),char(215),char(3),char(51),char(0),char(222),char(255),char(215), -char(3),char(51),char(0),char(224),char(255),char(215),char(3),char(51),char(0),char(226), -char(255),char(215),char(3),char(51),char(0),char(228),char(255),char(215),char(3),char(51), -char(1),char(14),char(255),char(215),char(3),char(51),char(1),char(16),char(255),char(215), -char(3),char(51),char(1),char(18),char(255),char(215),char(3),char(51),char(1),char(20), -char(255),char(215),char(3),char(51),char(1),char(36),char(255),char(113),char(3),char(51), -char(1),char(38),char(255),char(113),char(3),char(51),char(1),char(54),char(255),char(174), -char(3),char(51),char(1),char(56),char(255),char(133),char(3),char(51),char(1),char(58), -char(255),char(133),char(3),char(51),char(1),char(71),char(255),char(215),char(3),char(51), -char(1),char(250),char(255),char(174),char(3),char(51),char(1),char(252),char(255),char(174), -char(3),char(51),char(1),char(254),char(255),char(174),char(3),char(51),char(2),char(0), -char(255),char(133),char(3),char(51),char(2),char(7),char(255),char(113),char(3),char(51), -char(2),char(11),char(255),char(113),char(3),char(51),char(2),char(95),char(255),char(215), -char(3),char(51),char(3),char(73),char(255),char(215),char(3),char(51),char(3),char(75), -char(255),char(215),char(3),char(51),char(3),char(77),char(255),char(215),char(3),char(51), -char(3),char(79),char(255),char(215),char(3),char(51),char(3),char(81),char(255),char(215), -char(3),char(51),char(3),char(83),char(255),char(215),char(3),char(51),char(3),char(85), -char(255),char(215),char(3),char(51),char(3),char(87),char(255),char(215),char(3),char(51), -char(3),char(89),char(255),char(215),char(3),char(51),char(3),char(91),char(255),char(215), -char(3),char(51),char(3),char(93),char(255),char(215),char(3),char(51),char(3),char(95), -char(255),char(215),char(3),char(51),char(3),char(111),char(255),char(133),char(3),char(51), -char(3),char(113),char(255),char(133),char(3),char(51),char(3),char(115),char(255),char(133), -char(3),char(51),char(3),char(143),char(255),char(113),char(3),char(52),char(0),char(5), -char(255),char(236),char(3),char(52),char(0),char(10),char(255),char(236),char(3),char(52), -char(2),char(7),char(255),char(236),char(3),char(52),char(2),char(11),char(255),char(236), -char(3),char(53),char(0),char(45),char(0),char(123),char(3),char(54),char(0),char(5), -char(255),char(236),char(3),char(54),char(0),char(10),char(255),char(236),char(3),char(54), -char(0),char(89),char(255),char(215),char(3),char(54),char(0),char(90),char(255),char(215), -char(3),char(54),char(0),char(91),char(255),char(215),char(3),char(54),char(0),char(92), -char(255),char(215),char(3),char(54),char(0),char(93),char(255),char(236),char(3),char(54), -char(0),char(191),char(255),char(215),char(3),char(54),char(1),char(55),char(255),char(215), -char(3),char(54),char(1),char(60),char(255),char(236),char(3),char(54),char(1),char(62), -char(255),char(236),char(3),char(54),char(1),char(64),char(255),char(236),char(3),char(54), -char(1),char(251),char(255),char(215),char(3),char(54),char(1),char(253),char(255),char(215), -char(3),char(54),char(2),char(7),char(255),char(236),char(3),char(54),char(2),char(11), -char(255),char(236),char(3),char(54),char(3),char(112),char(255),char(215),char(3),char(55), -char(0),char(45),char(0),char(123),char(3),char(56),char(0),char(5),char(255),char(236), -char(3),char(56),char(0),char(10),char(255),char(236),char(3),char(56),char(0),char(89), -char(255),char(215),char(3),char(56),char(0),char(90),char(255),char(215),char(3),char(56), -char(0),char(91),char(255),char(215),char(3),char(56),char(0),char(92),char(255),char(215), -char(3),char(56),char(0),char(93),char(255),char(236),char(3),char(56),char(0),char(191), -char(255),char(215),char(3),char(56),char(1),char(55),char(255),char(215),char(3),char(56), -char(1),char(60),char(255),char(236),char(3),char(56),char(1),char(62),char(255),char(236), -char(3),char(56),char(1),char(64),char(255),char(236),char(3),char(56),char(1),char(251), -char(255),char(215),char(3),char(56),char(1),char(253),char(255),char(215),char(3),char(56), -char(2),char(7),char(255),char(236),char(3),char(56),char(2),char(11),char(255),char(236), -char(3),char(56),char(3),char(112),char(255),char(215),char(3),char(57),char(0),char(45), -char(0),char(123),char(3),char(58),char(0),char(5),char(255),char(236),char(3),char(58), -char(0),char(10),char(255),char(236),char(3),char(58),char(0),char(89),char(255),char(215), -char(3),char(58),char(0),char(90),char(255),char(215),char(3),char(58),char(0),char(91), -char(255),char(215),char(3),char(58),char(0),char(92),char(255),char(215),char(3),char(58), -char(0),char(93),char(255),char(236),char(3),char(58),char(0),char(191),char(255),char(215), -char(3),char(58),char(1),char(55),char(255),char(215),char(3),char(58),char(1),char(60), -char(255),char(236),char(3),char(58),char(1),char(62),char(255),char(236),char(3),char(58), -char(1),char(64),char(255),char(236),char(3),char(58),char(1),char(251),char(255),char(215), -char(3),char(58),char(1),char(253),char(255),char(215),char(3),char(58),char(2),char(7), -char(255),char(236),char(3),char(58),char(2),char(11),char(255),char(236),char(3),char(58), -char(3),char(112),char(255),char(215),char(3),char(59),char(0),char(45),char(0),char(123), -char(3),char(60),char(0),char(5),char(255),char(236),char(3),char(60),char(0),char(10), -char(255),char(236),char(3),char(60),char(0),char(89),char(255),char(215),char(3),char(60), -char(0),char(90),char(255),char(215),char(3),char(60),char(0),char(91),char(255),char(215), -char(3),char(60),char(0),char(92),char(255),char(215),char(3),char(60),char(0),char(93), -char(255),char(236),char(3),char(60),char(0),char(191),char(255),char(215),char(3),char(60), -char(1),char(55),char(255),char(215),char(3),char(60),char(1),char(60),char(255),char(236), -char(3),char(60),char(1),char(62),char(255),char(236),char(3),char(60),char(1),char(64), -char(255),char(236),char(3),char(60),char(1),char(251),char(255),char(215),char(3),char(60), -char(1),char(253),char(255),char(215),char(3),char(60),char(2),char(7),char(255),char(236), -char(3),char(60),char(2),char(11),char(255),char(236),char(3),char(60),char(3),char(112), -char(255),char(215),char(3),char(61),char(0),char(45),char(0),char(123),char(3),char(62), -char(0),char(5),char(255),char(236),char(3),char(62),char(0),char(10),char(255),char(236), -char(3),char(62),char(0),char(89),char(255),char(215),char(3),char(62),char(0),char(90), -char(255),char(215),char(3),char(62),char(0),char(91),char(255),char(215),char(3),char(62), -char(0),char(92),char(255),char(215),char(3),char(62),char(0),char(93),char(255),char(236), -char(3),char(62),char(0),char(191),char(255),char(215),char(3),char(62),char(1),char(55), -char(255),char(215),char(3),char(62),char(1),char(60),char(255),char(236),char(3),char(62), -char(1),char(62),char(255),char(236),char(3),char(62),char(1),char(64),char(255),char(236), -char(3),char(62),char(1),char(251),char(255),char(215),char(3),char(62),char(1),char(253), -char(255),char(215),char(3),char(62),char(2),char(7),char(255),char(236),char(3),char(62), -char(2),char(11),char(255),char(236),char(3),char(62),char(3),char(112),char(255),char(215), -char(3),char(63),char(0),char(45),char(0),char(123),char(3),char(64),char(0),char(5), -char(255),char(236),char(3),char(64),char(0),char(10),char(255),char(236),char(3),char(64), -char(0),char(89),char(255),char(215),char(3),char(64),char(0),char(90),char(255),char(215), -char(3),char(64),char(0),char(91),char(255),char(215),char(3),char(64),char(0),char(92), -char(255),char(215),char(3),char(64),char(0),char(93),char(255),char(236),char(3),char(64), -char(0),char(191),char(255),char(215),char(3),char(64),char(1),char(55),char(255),char(215), -char(3),char(64),char(1),char(60),char(255),char(236),char(3),char(64),char(1),char(62), -char(255),char(236),char(3),char(64),char(1),char(64),char(255),char(236),char(3),char(64), -char(1),char(251),char(255),char(215),char(3),char(64),char(1),char(253),char(255),char(215), -char(3),char(64),char(2),char(7),char(255),char(236),char(3),char(64),char(2),char(11), -char(255),char(236),char(3),char(64),char(3),char(112),char(255),char(215),char(3),char(65), -char(0),char(45),char(0),char(123),char(3),char(66),char(0),char(5),char(255),char(236), -char(3),char(66),char(0),char(10),char(255),char(236),char(3),char(66),char(0),char(89), -char(255),char(215),char(3),char(66),char(0),char(90),char(255),char(215),char(3),char(66), -char(0),char(91),char(255),char(215),char(3),char(66),char(0),char(92),char(255),char(215), -char(3),char(66),char(0),char(93),char(255),char(236),char(3),char(66),char(0),char(191), -char(255),char(215),char(3),char(66),char(1),char(55),char(255),char(215),char(3),char(66), -char(1),char(60),char(255),char(236),char(3),char(66),char(1),char(62),char(255),char(236), -char(3),char(66),char(1),char(64),char(255),char(236),char(3),char(66),char(1),char(251), -char(255),char(215),char(3),char(66),char(1),char(253),char(255),char(215),char(3),char(66), -char(2),char(7),char(255),char(236),char(3),char(66),char(2),char(11),char(255),char(236), -char(3),char(66),char(3),char(112),char(255),char(215),char(3),char(67),char(0),char(45), -char(0),char(123),char(3),char(68),char(0),char(5),char(255),char(236),char(3),char(68), -char(0),char(10),char(255),char(236),char(3),char(68),char(0),char(89),char(255),char(215), -char(3),char(68),char(0),char(90),char(255),char(215),char(3),char(68),char(0),char(91), -char(255),char(215),char(3),char(68),char(0),char(92),char(255),char(215),char(3),char(68), -char(0),char(93),char(255),char(236),char(3),char(68),char(0),char(191),char(255),char(215), -char(3),char(68),char(1),char(55),char(255),char(215),char(3),char(68),char(1),char(60), -char(255),char(236),char(3),char(68),char(1),char(62),char(255),char(236),char(3),char(68), -char(1),char(64),char(255),char(236),char(3),char(68),char(1),char(251),char(255),char(215), -char(3),char(68),char(1),char(253),char(255),char(215),char(3),char(68),char(2),char(7), -char(255),char(236),char(3),char(68),char(2),char(11),char(255),char(236),char(3),char(68), -char(3),char(112),char(255),char(215),char(3),char(73),char(0),char(15),char(255),char(174), -char(3),char(73),char(0),char(17),char(255),char(174),char(3),char(73),char(0),char(36), -char(255),char(215),char(3),char(73),char(0),char(55),char(255),char(195),char(3),char(73), -char(0),char(57),char(255),char(236),char(3),char(73),char(0),char(58),char(255),char(236), -char(3),char(73),char(0),char(59),char(255),char(215),char(3),char(73),char(0),char(60), -char(255),char(236),char(3),char(73),char(0),char(61),char(255),char(236),char(3),char(73), -char(0),char(130),char(255),char(215),char(3),char(73),char(0),char(131),char(255),char(215), -char(3),char(73),char(0),char(132),char(255),char(215),char(3),char(73),char(0),char(133), -char(255),char(215),char(3),char(73),char(0),char(134),char(255),char(215),char(3),char(73), -char(0),char(135),char(255),char(215),char(3),char(73),char(0),char(159),char(255),char(236), -char(3),char(73),char(0),char(194),char(255),char(215),char(3),char(73),char(0),char(196), -char(255),char(215),char(3),char(73),char(0),char(198),char(255),char(215),char(3),char(73), -char(1),char(36),char(255),char(195),char(3),char(73),char(1),char(38),char(255),char(195), -char(3),char(73),char(1),char(54),char(255),char(236),char(3),char(73),char(1),char(56), -char(255),char(236),char(3),char(73),char(1),char(58),char(255),char(236),char(3),char(73), -char(1),char(59),char(255),char(236),char(3),char(73),char(1),char(61),char(255),char(236), -char(3),char(73),char(1),char(63),char(255),char(236),char(3),char(73),char(1),char(67), -char(255),char(215),char(3),char(73),char(1),char(160),char(255),char(236),char(3),char(73), -char(1),char(250),char(255),char(236),char(3),char(73),char(1),char(252),char(255),char(236), -char(3),char(73),char(1),char(254),char(255),char(236),char(3),char(73),char(2),char(0), -char(255),char(236),char(3),char(73),char(2),char(8),char(255),char(174),char(3),char(73), -char(2),char(12),char(255),char(174),char(3),char(73),char(2),char(88),char(255),char(215), -char(3),char(73),char(3),char(29),char(255),char(215),char(3),char(73),char(3),char(31), -char(255),char(215),char(3),char(73),char(3),char(33),char(255),char(215),char(3),char(73), -char(3),char(35),char(255),char(215),char(3),char(73),char(3),char(37),char(255),char(215), -char(3),char(73),char(3),char(39),char(255),char(215),char(3),char(73),char(3),char(41), -char(255),char(215),char(3),char(73),char(3),char(43),char(255),char(215),char(3),char(73), -char(3),char(45),char(255),char(215),char(3),char(73),char(3),char(47),char(255),char(215), -char(3),char(73),char(3),char(49),char(255),char(215),char(3),char(73),char(3),char(51), -char(255),char(215),char(3),char(73),char(3),char(111),char(255),char(236),char(3),char(73), -char(3),char(113),char(255),char(236),char(3),char(73),char(3),char(115),char(255),char(236), -char(3),char(73),char(3),char(143),char(255),char(195),char(3),char(74),char(0),char(5), -char(255),char(236),char(3),char(74),char(0),char(10),char(255),char(236),char(3),char(74), -char(0),char(89),char(255),char(215),char(3),char(74),char(0),char(90),char(255),char(215), -char(3),char(74),char(0),char(91),char(255),char(215),char(3),char(74),char(0),char(92), -char(255),char(215),char(3),char(74),char(0),char(93),char(255),char(236),char(3),char(74), -char(0),char(191),char(255),char(215),char(3),char(74),char(1),char(55),char(255),char(215), -char(3),char(74),char(1),char(60),char(255),char(236),char(3),char(74),char(1),char(62), -char(255),char(236),char(3),char(74),char(1),char(64),char(255),char(236),char(3),char(74), -char(1),char(251),char(255),char(215),char(3),char(74),char(1),char(253),char(255),char(215), -char(3),char(74),char(2),char(7),char(255),char(236),char(3),char(74),char(2),char(11), -char(255),char(236),char(3),char(74),char(3),char(112),char(255),char(215),char(3),char(75), -char(0),char(15),char(255),char(174),char(3),char(75),char(0),char(17),char(255),char(174), -char(3),char(75),char(0),char(36),char(255),char(215),char(3),char(75),char(0),char(55), -char(255),char(195),char(3),char(75),char(0),char(57),char(255),char(236),char(3),char(75), -char(0),char(58),char(255),char(236),char(3),char(75),char(0),char(59),char(255),char(215), -char(3),char(75),char(0),char(60),char(255),char(236),char(3),char(75),char(0),char(61), -char(255),char(236),char(3),char(75),char(0),char(130),char(255),char(215),char(3),char(75), -char(0),char(131),char(255),char(215),char(3),char(75),char(0),char(132),char(255),char(215), -char(3),char(75),char(0),char(133),char(255),char(215),char(3),char(75),char(0),char(134), -char(255),char(215),char(3),char(75),char(0),char(135),char(255),char(215),char(3),char(75), -char(0),char(159),char(255),char(236),char(3),char(75),char(0),char(194),char(255),char(215), -char(3),char(75),char(0),char(196),char(255),char(215),char(3),char(75),char(0),char(198), -char(255),char(215),char(3),char(75),char(1),char(36),char(255),char(195),char(3),char(75), -char(1),char(38),char(255),char(195),char(3),char(75),char(1),char(54),char(255),char(236), -char(3),char(75),char(1),char(56),char(255),char(236),char(3),char(75),char(1),char(58), -char(255),char(236),char(3),char(75),char(1),char(59),char(255),char(236),char(3),char(75), -char(1),char(61),char(255),char(236),char(3),char(75),char(1),char(63),char(255),char(236), -char(3),char(75),char(1),char(67),char(255),char(215),char(3),char(75),char(1),char(160), -char(255),char(236),char(3),char(75),char(1),char(250),char(255),char(236),char(3),char(75), -char(1),char(252),char(255),char(236),char(3),char(75),char(1),char(254),char(255),char(236), -char(3),char(75),char(2),char(0),char(255),char(236),char(3),char(75),char(2),char(8), -char(255),char(174),char(3),char(75),char(2),char(12),char(255),char(174),char(3),char(75), -char(2),char(88),char(255),char(215),char(3),char(75),char(3),char(29),char(255),char(215), -char(3),char(75),char(3),char(31),char(255),char(215),char(3),char(75),char(3),char(33), -char(255),char(215),char(3),char(75),char(3),char(35),char(255),char(215),char(3),char(75), -char(3),char(37),char(255),char(215),char(3),char(75),char(3),char(39),char(255),char(215), -char(3),char(75),char(3),char(41),char(255),char(215),char(3),char(75),char(3),char(43), -char(255),char(215),char(3),char(75),char(3),char(45),char(255),char(215),char(3),char(75), -char(3),char(47),char(255),char(215),char(3),char(75),char(3),char(49),char(255),char(215), -char(3),char(75),char(3),char(51),char(255),char(215),char(3),char(75),char(3),char(111), -char(255),char(236),char(3),char(75),char(3),char(113),char(255),char(236),char(3),char(75), -char(3),char(115),char(255),char(236),char(3),char(75),char(3),char(143),char(255),char(195), -char(3),char(76),char(0),char(5),char(255),char(236),char(3),char(76),char(0),char(10), -char(255),char(236),char(3),char(76),char(0),char(89),char(255),char(215),char(3),char(76), -char(0),char(90),char(255),char(215),char(3),char(76),char(0),char(91),char(255),char(215), -char(3),char(76),char(0),char(92),char(255),char(215),char(3),char(76),char(0),char(93), -char(255),char(236),char(3),char(76),char(0),char(191),char(255),char(215),char(3),char(76), -char(1),char(55),char(255),char(215),char(3),char(76),char(1),char(60),char(255),char(236), -char(3),char(76),char(1),char(62),char(255),char(236),char(3),char(76),char(1),char(64), -char(255),char(236),char(3),char(76),char(1),char(251),char(255),char(215),char(3),char(76), -char(1),char(253),char(255),char(215),char(3),char(76),char(2),char(7),char(255),char(236), -char(3),char(76),char(2),char(11),char(255),char(236),char(3),char(76),char(3),char(112), -char(255),char(215),char(3),char(77),char(0),char(15),char(255),char(174),char(3),char(77), -char(0),char(17),char(255),char(174),char(3),char(77),char(0),char(36),char(255),char(215), -char(3),char(77),char(0),char(55),char(255),char(195),char(3),char(77),char(0),char(57), -char(255),char(236),char(3),char(77),char(0),char(58),char(255),char(236),char(3),char(77), -char(0),char(59),char(255),char(215),char(3),char(77),char(0),char(60),char(255),char(236), -char(3),char(77),char(0),char(61),char(255),char(236),char(3),char(77),char(0),char(130), -char(255),char(215),char(3),char(77),char(0),char(131),char(255),char(215),char(3),char(77), -char(0),char(132),char(255),char(215),char(3),char(77),char(0),char(133),char(255),char(215), -char(3),char(77),char(0),char(134),char(255),char(215),char(3),char(77),char(0),char(135), -char(255),char(215),char(3),char(77),char(0),char(159),char(255),char(236),char(3),char(77), -char(0),char(194),char(255),char(215),char(3),char(77),char(0),char(196),char(255),char(215), -char(3),char(77),char(0),char(198),char(255),char(215),char(3),char(77),char(1),char(36), -char(255),char(195),char(3),char(77),char(1),char(38),char(255),char(195),char(3),char(77), -char(1),char(54),char(255),char(236),char(3),char(77),char(1),char(56),char(255),char(236), -char(3),char(77),char(1),char(58),char(255),char(236),char(3),char(77),char(1),char(59), -char(255),char(236),char(3),char(77),char(1),char(61),char(255),char(236),char(3),char(77), -char(1),char(63),char(255),char(236),char(3),char(77),char(1),char(67),char(255),char(215), -char(3),char(77),char(1),char(160),char(255),char(236),char(3),char(77),char(1),char(250), -char(255),char(236),char(3),char(77),char(1),char(252),char(255),char(236),char(3),char(77), -char(1),char(254),char(255),char(236),char(3),char(77),char(2),char(0),char(255),char(236), -char(3),char(77),char(2),char(8),char(255),char(174),char(3),char(77),char(2),char(12), -char(255),char(174),char(3),char(77),char(2),char(88),char(255),char(215),char(3),char(77), -char(3),char(29),char(255),char(215),char(3),char(77),char(3),char(31),char(255),char(215), -char(3),char(77),char(3),char(33),char(255),char(215),char(3),char(77),char(3),char(35), -char(255),char(215),char(3),char(77),char(3),char(37),char(255),char(215),char(3),char(77), -char(3),char(39),char(255),char(215),char(3),char(77),char(3),char(41),char(255),char(215), -char(3),char(77),char(3),char(43),char(255),char(215),char(3),char(77),char(3),char(45), -char(255),char(215),char(3),char(77),char(3),char(47),char(255),char(215),char(3),char(77), -char(3),char(49),char(255),char(215),char(3),char(77),char(3),char(51),char(255),char(215), -char(3),char(77),char(3),char(111),char(255),char(236),char(3),char(77),char(3),char(113), -char(255),char(236),char(3),char(77),char(3),char(115),char(255),char(236),char(3),char(77), -char(3),char(143),char(255),char(195),char(3),char(79),char(0),char(15),char(255),char(174), -char(3),char(79),char(0),char(17),char(255),char(174),char(3),char(79),char(0),char(36), -char(255),char(215),char(3),char(79),char(0),char(55),char(255),char(195),char(3),char(79), -char(0),char(57),char(255),char(236),char(3),char(79),char(0),char(58),char(255),char(236), -char(3),char(79),char(0),char(59),char(255),char(215),char(3),char(79),char(0),char(60), -char(255),char(236),char(3),char(79),char(0),char(61),char(255),char(236),char(3),char(79), -char(0),char(130),char(255),char(215),char(3),char(79),char(0),char(131),char(255),char(215), -char(3),char(79),char(0),char(132),char(255),char(215),char(3),char(79),char(0),char(133), -char(255),char(215),char(3),char(79),char(0),char(134),char(255),char(215),char(3),char(79), -char(0),char(135),char(255),char(215),char(3),char(79),char(0),char(159),char(255),char(236), -char(3),char(79),char(0),char(194),char(255),char(215),char(3),char(79),char(0),char(196), -char(255),char(215),char(3),char(79),char(0),char(198),char(255),char(215),char(3),char(79), -char(1),char(36),char(255),char(195),char(3),char(79),char(1),char(38),char(255),char(195), -char(3),char(79),char(1),char(54),char(255),char(236),char(3),char(79),char(1),char(56), -char(255),char(236),char(3),char(79),char(1),char(58),char(255),char(236),char(3),char(79), -char(1),char(59),char(255),char(236),char(3),char(79),char(1),char(61),char(255),char(236), -char(3),char(79),char(1),char(63),char(255),char(236),char(3),char(79),char(1),char(67), -char(255),char(215),char(3),char(79),char(1),char(160),char(255),char(236),char(3),char(79), -char(1),char(250),char(255),char(236),char(3),char(79),char(1),char(252),char(255),char(236), -char(3),char(79),char(1),char(254),char(255),char(236),char(3),char(79),char(2),char(0), -char(255),char(236),char(3),char(79),char(2),char(8),char(255),char(174),char(3),char(79), -char(2),char(12),char(255),char(174),char(3),char(79),char(2),char(88),char(255),char(215), -char(3),char(79),char(3),char(29),char(255),char(215),char(3),char(79),char(3),char(31), -char(255),char(215),char(3),char(79),char(3),char(33),char(255),char(215),char(3),char(79), -char(3),char(35),char(255),char(215),char(3),char(79),char(3),char(37),char(255),char(215), -char(3),char(79),char(3),char(39),char(255),char(215),char(3),char(79),char(3),char(41), -char(255),char(215),char(3),char(79),char(3),char(43),char(255),char(215),char(3),char(79), -char(3),char(45),char(255),char(215),char(3),char(79),char(3),char(47),char(255),char(215), -char(3),char(79),char(3),char(49),char(255),char(215),char(3),char(79),char(3),char(51), -char(255),char(215),char(3),char(79),char(3),char(111),char(255),char(236),char(3),char(79), -char(3),char(113),char(255),char(236),char(3),char(79),char(3),char(115),char(255),char(236), -char(3),char(79),char(3),char(143),char(255),char(195),char(3),char(81),char(0),char(15), -char(255),char(174),char(3),char(81),char(0),char(17),char(255),char(174),char(3),char(81), -char(0),char(36),char(255),char(215),char(3),char(81),char(0),char(55),char(255),char(195), -char(3),char(81),char(0),char(57),char(255),char(236),char(3),char(81),char(0),char(58), -char(255),char(236),char(3),char(81),char(0),char(59),char(255),char(215),char(3),char(81), -char(0),char(60),char(255),char(236),char(3),char(81),char(0),char(61),char(255),char(236), -char(3),char(81),char(0),char(130),char(255),char(215),char(3),char(81),char(0),char(131), -char(255),char(215),char(3),char(81),char(0),char(132),char(255),char(215),char(3),char(81), -char(0),char(133),char(255),char(215),char(3),char(81),char(0),char(134),char(255),char(215), -char(3),char(81),char(0),char(135),char(255),char(215),char(3),char(81),char(0),char(159), -char(255),char(236),char(3),char(81),char(0),char(194),char(255),char(215),char(3),char(81), -char(0),char(196),char(255),char(215),char(3),char(81),char(0),char(198),char(255),char(215), -char(3),char(81),char(1),char(36),char(255),char(195),char(3),char(81),char(1),char(38), -char(255),char(195),char(3),char(81),char(1),char(54),char(255),char(236),char(3),char(81), -char(1),char(56),char(255),char(236),char(3),char(81),char(1),char(58),char(255),char(236), -char(3),char(81),char(1),char(59),char(255),char(236),char(3),char(81),char(1),char(61), -char(255),char(236),char(3),char(81),char(1),char(63),char(255),char(236),char(3),char(81), -char(1),char(67),char(255),char(215),char(3),char(81),char(1),char(160),char(255),char(236), -char(3),char(81),char(1),char(250),char(255),char(236),char(3),char(81),char(1),char(252), -char(255),char(236),char(3),char(81),char(1),char(254),char(255),char(236),char(3),char(81), -char(2),char(0),char(255),char(236),char(3),char(81),char(2),char(8),char(255),char(174), -char(3),char(81),char(2),char(12),char(255),char(174),char(3),char(81),char(2),char(88), -char(255),char(215),char(3),char(81),char(3),char(29),char(255),char(215),char(3),char(81), -char(3),char(31),char(255),char(215),char(3),char(81),char(3),char(33),char(255),char(215), -char(3),char(81),char(3),char(35),char(255),char(215),char(3),char(81),char(3),char(37), -char(255),char(215),char(3),char(81),char(3),char(39),char(255),char(215),char(3),char(81), -char(3),char(41),char(255),char(215),char(3),char(81),char(3),char(43),char(255),char(215), -char(3),char(81),char(3),char(45),char(255),char(215),char(3),char(81),char(3),char(47), -char(255),char(215),char(3),char(81),char(3),char(49),char(255),char(215),char(3),char(81), -char(3),char(51),char(255),char(215),char(3),char(81),char(3),char(111),char(255),char(236), -char(3),char(81),char(3),char(113),char(255),char(236),char(3),char(81),char(3),char(115), -char(255),char(236),char(3),char(81),char(3),char(143),char(255),char(195),char(3),char(83), -char(0),char(15),char(255),char(174),char(3),char(83),char(0),char(17),char(255),char(174), -char(3),char(83),char(0),char(36),char(255),char(215),char(3),char(83),char(0),char(55), -char(255),char(195),char(3),char(83),char(0),char(57),char(255),char(236),char(3),char(83), -char(0),char(58),char(255),char(236),char(3),char(83),char(0),char(59),char(255),char(215), -char(3),char(83),char(0),char(60),char(255),char(236),char(3),char(83),char(0),char(61), -char(255),char(236),char(3),char(83),char(0),char(130),char(255),char(215),char(3),char(83), -char(0),char(131),char(255),char(215),char(3),char(83),char(0),char(132),char(255),char(215), -char(3),char(83),char(0),char(133),char(255),char(215),char(3),char(83),char(0),char(134), -char(255),char(215),char(3),char(83),char(0),char(135),char(255),char(215),char(3),char(83), -char(0),char(159),char(255),char(236),char(3),char(83),char(0),char(194),char(255),char(215), -char(3),char(83),char(0),char(196),char(255),char(215),char(3),char(83),char(0),char(198), -char(255),char(215),char(3),char(83),char(1),char(36),char(255),char(195),char(3),char(83), -char(1),char(38),char(255),char(195),char(3),char(83),char(1),char(54),char(255),char(236), -char(3),char(83),char(1),char(56),char(255),char(236),char(3),char(83),char(1),char(58), -char(255),char(236),char(3),char(83),char(1),char(59),char(255),char(236),char(3),char(83), -char(1),char(61),char(255),char(236),char(3),char(83),char(1),char(63),char(255),char(236), -char(3),char(83),char(1),char(67),char(255),char(215),char(3),char(83),char(1),char(160), -char(255),char(236),char(3),char(83),char(1),char(250),char(255),char(236),char(3),char(83), -char(1),char(252),char(255),char(236),char(3),char(83),char(1),char(254),char(255),char(236), -char(3),char(83),char(2),char(0),char(255),char(236),char(3),char(83),char(2),char(8), -char(255),char(174),char(3),char(83),char(2),char(12),char(255),char(174),char(3),char(83), -char(2),char(88),char(255),char(215),char(3),char(83),char(3),char(29),char(255),char(215), -char(3),char(83),char(3),char(31),char(255),char(215),char(3),char(83),char(3),char(33), -char(255),char(215),char(3),char(83),char(3),char(35),char(255),char(215),char(3),char(83), -char(3),char(37),char(255),char(215),char(3),char(83),char(3),char(39),char(255),char(215), -char(3),char(83),char(3),char(41),char(255),char(215),char(3),char(83),char(3),char(43), -char(255),char(215),char(3),char(83),char(3),char(45),char(255),char(215),char(3),char(83), -char(3),char(47),char(255),char(215),char(3),char(83),char(3),char(49),char(255),char(215), -char(3),char(83),char(3),char(51),char(255),char(215),char(3),char(83),char(3),char(111), -char(255),char(236),char(3),char(83),char(3),char(113),char(255),char(236),char(3),char(83), -char(3),char(115),char(255),char(236),char(3),char(83),char(3),char(143),char(255),char(195), -char(3),char(85),char(0),char(15),char(255),char(174),char(3),char(85),char(0),char(17), -char(255),char(174),char(3),char(85),char(0),char(36),char(255),char(215),char(3),char(85), -char(0),char(55),char(255),char(195),char(3),char(85),char(0),char(57),char(255),char(236), -char(3),char(85),char(0),char(58),char(255),char(236),char(3),char(85),char(0),char(59), -char(255),char(215),char(3),char(85),char(0),char(60),char(255),char(236),char(3),char(85), -char(0),char(61),char(255),char(236),char(3),char(85),char(0),char(130),char(255),char(215), -char(3),char(85),char(0),char(131),char(255),char(215),char(3),char(85),char(0),char(132), -char(255),char(215),char(3),char(85),char(0),char(133),char(255),char(215),char(3),char(85), -char(0),char(134),char(255),char(215),char(3),char(85),char(0),char(135),char(255),char(215), -char(3),char(85),char(0),char(159),char(255),char(236),char(3),char(85),char(0),char(194), -char(255),char(215),char(3),char(85),char(0),char(196),char(255),char(215),char(3),char(85), -char(0),char(198),char(255),char(215),char(3),char(85),char(1),char(36),char(255),char(195), -char(3),char(85),char(1),char(38),char(255),char(195),char(3),char(85),char(1),char(54), -char(255),char(236),char(3),char(85),char(1),char(56),char(255),char(236),char(3),char(85), -char(1),char(58),char(255),char(236),char(3),char(85),char(1),char(59),char(255),char(236), -char(3),char(85),char(1),char(61),char(255),char(236),char(3),char(85),char(1),char(63), -char(255),char(236),char(3),char(85),char(1),char(67),char(255),char(215),char(3),char(85), -char(1),char(160),char(255),char(236),char(3),char(85),char(1),char(250),char(255),char(236), -char(3),char(85),char(1),char(252),char(255),char(236),char(3),char(85),char(1),char(254), -char(255),char(236),char(3),char(85),char(2),char(0),char(255),char(236),char(3),char(85), -char(2),char(8),char(255),char(174),char(3),char(85),char(2),char(12),char(255),char(174), -char(3),char(85),char(2),char(88),char(255),char(215),char(3),char(85),char(3),char(29), -char(255),char(215),char(3),char(85),char(3),char(31),char(255),char(215),char(3),char(85), -char(3),char(33),char(255),char(215),char(3),char(85),char(3),char(35),char(255),char(215), -char(3),char(85),char(3),char(37),char(255),char(215),char(3),char(85),char(3),char(39), -char(255),char(215),char(3),char(85),char(3),char(41),char(255),char(215),char(3),char(85), -char(3),char(43),char(255),char(215),char(3),char(85),char(3),char(45),char(255),char(215), -char(3),char(85),char(3),char(47),char(255),char(215),char(3),char(85),char(3),char(49), -char(255),char(215),char(3),char(85),char(3),char(51),char(255),char(215),char(3),char(85), -char(3),char(111),char(255),char(236),char(3),char(85),char(3),char(113),char(255),char(236), -char(3),char(85),char(3),char(115),char(255),char(236),char(3),char(85),char(3),char(143), -char(255),char(195),char(3),char(88),char(0),char(73),char(0),char(82),char(3),char(88), -char(0),char(87),char(0),char(82),char(3),char(88),char(0),char(89),char(0),char(102), -char(3),char(88),char(0),char(90),char(0),char(102),char(3),char(88),char(0),char(91), -char(0),char(102),char(3),char(88),char(0),char(92),char(0),char(102),char(3),char(88), -char(0),char(191),char(0),char(102),char(3),char(88),char(1),char(37),char(0),char(82), -char(3),char(88),char(1),char(39),char(0),char(82),char(3),char(88),char(1),char(55), -char(0),char(102),char(3),char(88),char(1),char(251),char(0),char(102),char(3),char(88), -char(1),char(253),char(0),char(102),char(3),char(88),char(2),char(52),char(0),char(82), -char(3),char(88),char(2),char(53),char(0),char(82),char(3),char(88),char(2),char(93), -char(0),char(82),char(3),char(88),char(2),char(94),char(0),char(82),char(3),char(88), -char(3),char(112),char(0),char(102),char(3),char(88),char(3),char(141),char(0),char(82), -char(3),char(88),char(3),char(144),char(0),char(82),char(3),char(90),char(0),char(73), -char(0),char(82),char(3),char(90),char(0),char(87),char(0),char(82),char(3),char(90), -char(0),char(89),char(0),char(102),char(3),char(90),char(0),char(90),char(0),char(102), -char(3),char(90),char(0),char(91),char(0),char(102),char(3),char(90),char(0),char(92), -char(0),char(102),char(3),char(90),char(0),char(191),char(0),char(102),char(3),char(90), -char(1),char(37),char(0),char(82),char(3),char(90),char(1),char(39),char(0),char(82), -char(3),char(90),char(1),char(55),char(0),char(102),char(3),char(90),char(1),char(251), -char(0),char(102),char(3),char(90),char(1),char(253),char(0),char(102),char(3),char(90), -char(2),char(52),char(0),char(82),char(3),char(90),char(2),char(53),char(0),char(82), -char(3),char(90),char(2),char(93),char(0),char(82),char(3),char(90),char(2),char(94), -char(0),char(82),char(3),char(90),char(3),char(112),char(0),char(102),char(3),char(90), -char(3),char(141),char(0),char(82),char(3),char(90),char(3),char(144),char(0),char(82), -char(3),char(92),char(0),char(73),char(0),char(82),char(3),char(92),char(0),char(87), -char(0),char(82),char(3),char(92),char(0),char(89),char(0),char(102),char(3),char(92), -char(0),char(90),char(0),char(102),char(3),char(92),char(0),char(91),char(0),char(102), -char(3),char(92),char(0),char(92),char(0),char(102),char(3),char(92),char(0),char(191), -char(0),char(102),char(3),char(92),char(1),char(37),char(0),char(82),char(3),char(92), -char(1),char(39),char(0),char(82),char(3),char(92),char(1),char(55),char(0),char(102), -char(3),char(92),char(1),char(251),char(0),char(102),char(3),char(92),char(1),char(253), -char(0),char(102),char(3),char(92),char(2),char(52),char(0),char(82),char(3),char(92), -char(2),char(53),char(0),char(82),char(3),char(92),char(2),char(93),char(0),char(82), -char(3),char(92),char(2),char(94),char(0),char(82),char(3),char(92),char(3),char(112), -char(0),char(102),char(3),char(92),char(3),char(141),char(0),char(82),char(3),char(92), -char(3),char(144),char(0),char(82),char(3),char(94),char(0),char(73),char(0),char(82), -char(3),char(94),char(0),char(87),char(0),char(82),char(3),char(94),char(0),char(89), -char(0),char(102),char(3),char(94),char(0),char(90),char(0),char(102),char(3),char(94), -char(0),char(91),char(0),char(102),char(3),char(94),char(0),char(92),char(0),char(102), -char(3),char(94),char(0),char(191),char(0),char(102),char(3),char(94),char(1),char(37), -char(0),char(82),char(3),char(94),char(1),char(39),char(0),char(82),char(3),char(94), -char(1),char(55),char(0),char(102),char(3),char(94),char(1),char(251),char(0),char(102), -char(3),char(94),char(1),char(253),char(0),char(102),char(3),char(94),char(2),char(52), -char(0),char(82),char(3),char(94),char(2),char(53),char(0),char(82),char(3),char(94), -char(2),char(93),char(0),char(82),char(3),char(94),char(2),char(94),char(0),char(82), -char(3),char(94),char(3),char(112),char(0),char(102),char(3),char(94),char(3),char(141), -char(0),char(82),char(3),char(94),char(3),char(144),char(0),char(82),char(3),char(96), -char(0),char(73),char(0),char(82),char(3),char(96),char(0),char(87),char(0),char(82), -char(3),char(96),char(0),char(89),char(0),char(102),char(3),char(96),char(0),char(90), -char(0),char(102),char(3),char(96),char(0),char(91),char(0),char(102),char(3),char(96), -char(0),char(92),char(0),char(102),char(3),char(96),char(0),char(191),char(0),char(102), -char(3),char(96),char(1),char(37),char(0),char(82),char(3),char(96),char(1),char(39), -char(0),char(82),char(3),char(96),char(1),char(55),char(0),char(102),char(3),char(96), -char(1),char(251),char(0),char(102),char(3),char(96),char(1),char(253),char(0),char(102), -char(3),char(96),char(2),char(52),char(0),char(82),char(3),char(96),char(2),char(53), -char(0),char(82),char(3),char(96),char(2),char(93),char(0),char(82),char(3),char(96), -char(2),char(94),char(0),char(82),char(3),char(96),char(3),char(112),char(0),char(102), -char(3),char(96),char(3),char(141),char(0),char(82),char(3),char(96),char(3),char(144), -char(0),char(82),char(3),char(97),char(0),char(15),char(255),char(215),char(3),char(97), -char(0),char(17),char(255),char(215),char(3),char(97),char(0),char(36),char(255),char(236), -char(3),char(97),char(0),char(130),char(255),char(236),char(3),char(97),char(0),char(131), -char(255),char(236),char(3),char(97),char(0),char(132),char(255),char(236),char(3),char(97), -char(0),char(133),char(255),char(236),char(3),char(97),char(0),char(134),char(255),char(236), -char(3),char(97),char(0),char(135),char(255),char(236),char(3),char(97),char(0),char(194), -char(255),char(236),char(3),char(97),char(0),char(196),char(255),char(236),char(3),char(97), -char(0),char(198),char(255),char(236),char(3),char(97),char(1),char(67),char(255),char(236), -char(3),char(97),char(2),char(8),char(255),char(215),char(3),char(97),char(2),char(12), -char(255),char(215),char(3),char(97),char(2),char(88),char(255),char(236),char(3),char(97), -char(3),char(29),char(255),char(236),char(3),char(97),char(3),char(31),char(255),char(236), -char(3),char(97),char(3),char(33),char(255),char(236),char(3),char(97),char(3),char(35), -char(255),char(236),char(3),char(97),char(3),char(37),char(255),char(236),char(3),char(97), -char(3),char(39),char(255),char(236),char(3),char(97),char(3),char(41),char(255),char(236), -char(3),char(97),char(3),char(43),char(255),char(236),char(3),char(97),char(3),char(45), -char(255),char(236),char(3),char(97),char(3),char(47),char(255),char(236),char(3),char(97), -char(3),char(49),char(255),char(236),char(3),char(97),char(3),char(51),char(255),char(236), -char(3),char(102),char(0),char(73),char(0),char(102),char(3),char(102),char(0),char(87), -char(0),char(102),char(3),char(102),char(0),char(89),char(0),char(102),char(3),char(102), -char(0),char(90),char(0),char(102),char(3),char(102),char(0),char(91),char(0),char(102), -char(3),char(102),char(0),char(92),char(0),char(102),char(3),char(102),char(0),char(191), -char(0),char(102),char(3),char(102),char(1),char(37),char(0),char(102),char(3),char(102), -char(1),char(39),char(0),char(102),char(3),char(102),char(1),char(55),char(0),char(102), -char(3),char(102),char(1),char(251),char(0),char(102),char(3),char(102),char(1),char(253), -char(0),char(102),char(3),char(102),char(2),char(52),char(0),char(102),char(3),char(102), -char(2),char(53),char(0),char(102),char(3),char(102),char(2),char(93),char(0),char(102), -char(3),char(102),char(2),char(94),char(0),char(102),char(3),char(102),char(3),char(112), -char(0),char(102),char(3),char(102),char(3),char(141),char(0),char(102),char(3),char(102), -char(3),char(144),char(0),char(102),char(3),char(104),char(0),char(73),char(0),char(102), -char(3),char(104),char(0),char(87),char(0),char(102),char(3),char(104),char(0),char(89), -char(0),char(102),char(3),char(104),char(0),char(90),char(0),char(102),char(3),char(104), -char(0),char(91),char(0),char(102),char(3),char(104),char(0),char(92),char(0),char(102), -char(3),char(104),char(0),char(191),char(0),char(102),char(3),char(104),char(1),char(37), -char(0),char(102),char(3),char(104),char(1),char(39),char(0),char(102),char(3),char(104), -char(1),char(55),char(0),char(102),char(3),char(104),char(1),char(251),char(0),char(102), -char(3),char(104),char(1),char(253),char(0),char(102),char(3),char(104),char(2),char(52), -char(0),char(102),char(3),char(104),char(2),char(53),char(0),char(102),char(3),char(104), -char(2),char(93),char(0),char(102),char(3),char(104),char(2),char(94),char(0),char(102), -char(3),char(104),char(3),char(112),char(0),char(102),char(3),char(104),char(3),char(141), -char(0),char(102),char(3),char(104),char(3),char(144),char(0),char(102),char(3),char(106), -char(0),char(73),char(0),char(102),char(3),char(106),char(0),char(87),char(0),char(102), -char(3),char(106),char(0),char(89),char(0),char(102),char(3),char(106),char(0),char(90), -char(0),char(102),char(3),char(106),char(0),char(91),char(0),char(102),char(3),char(106), -char(0),char(92),char(0),char(102),char(3),char(106),char(0),char(191),char(0),char(102), -char(3),char(106),char(1),char(37),char(0),char(102),char(3),char(106),char(1),char(39), -char(0),char(102),char(3),char(106),char(1),char(55),char(0),char(102),char(3),char(106), -char(1),char(251),char(0),char(102),char(3),char(106),char(1),char(253),char(0),char(102), -char(3),char(106),char(2),char(52),char(0),char(102),char(3),char(106),char(2),char(53), -char(0),char(102),char(3),char(106),char(2),char(93),char(0),char(102),char(3),char(106), -char(2),char(94),char(0),char(102),char(3),char(106),char(3),char(112),char(0),char(102), -char(3),char(106),char(3),char(141),char(0),char(102),char(3),char(106),char(3),char(144), -char(0),char(102),char(3),char(108),char(0),char(73),char(0),char(102),char(3),char(108), -char(0),char(87),char(0),char(102),char(3),char(108),char(0),char(89),char(0),char(102), -char(3),char(108),char(0),char(90),char(0),char(102),char(3),char(108),char(0),char(91), -char(0),char(102),char(3),char(108),char(0),char(92),char(0),char(102),char(3),char(108), -char(0),char(191),char(0),char(102),char(3),char(108),char(1),char(37),char(0),char(102), -char(3),char(108),char(1),char(39),char(0),char(102),char(3),char(108),char(1),char(55), -char(0),char(102),char(3),char(108),char(1),char(251),char(0),char(102),char(3),char(108), -char(1),char(253),char(0),char(102),char(3),char(108),char(2),char(52),char(0),char(102), -char(3),char(108),char(2),char(53),char(0),char(102),char(3),char(108),char(2),char(93), -char(0),char(102),char(3),char(108),char(2),char(94),char(0),char(102),char(3),char(108), -char(3),char(112),char(0),char(102),char(3),char(108),char(3),char(141),char(0),char(102), -char(3),char(108),char(3),char(144),char(0),char(102),char(3),char(110),char(0),char(73), -char(0),char(102),char(3),char(110),char(0),char(87),char(0),char(102),char(3),char(110), -char(0),char(89),char(0),char(102),char(3),char(110),char(0),char(90),char(0),char(102), -char(3),char(110),char(0),char(91),char(0),char(102),char(3),char(110),char(0),char(92), -char(0),char(102),char(3),char(110),char(0),char(191),char(0),char(102),char(3),char(110), -char(1),char(37),char(0),char(102),char(3),char(110),char(1),char(39),char(0),char(102), -char(3),char(110),char(1),char(55),char(0),char(102),char(3),char(110),char(1),char(251), -char(0),char(102),char(3),char(110),char(1),char(253),char(0),char(102),char(3),char(110), -char(2),char(52),char(0),char(102),char(3),char(110),char(2),char(53),char(0),char(102), -char(3),char(110),char(2),char(93),char(0),char(102),char(3),char(110),char(2),char(94), -char(0),char(102),char(3),char(110),char(3),char(112),char(0),char(102),char(3),char(110), -char(3),char(141),char(0),char(102),char(3),char(110),char(3),char(144),char(0),char(102), -char(3),char(111),char(0),char(15),char(255),char(133),char(3),char(111),char(0),char(17), -char(255),char(133),char(3),char(111),char(0),char(34),char(0),char(41),char(3),char(111), -char(0),char(36),char(255),char(133),char(3),char(111),char(0),char(38),char(255),char(215), -char(3),char(111),char(0),char(42),char(255),char(215),char(3),char(111),char(0),char(50), -char(255),char(215),char(3),char(111),char(0),char(52),char(255),char(215),char(3),char(111), -char(0),char(68),char(255),char(154),char(3),char(111),char(0),char(70),char(255),char(154), -char(3),char(111),char(0),char(71),char(255),char(154),char(3),char(111),char(0),char(72), -char(255),char(154),char(3),char(111),char(0),char(74),char(255),char(215),char(3),char(111), -char(0),char(80),char(255),char(195),char(3),char(111),char(0),char(81),char(255),char(195), -char(3),char(111),char(0),char(82),char(255),char(154),char(3),char(111),char(0),char(83), -char(255),char(195),char(3),char(111),char(0),char(84),char(255),char(154),char(3),char(111), -char(0),char(85),char(255),char(195),char(3),char(111),char(0),char(86),char(255),char(174), -char(3),char(111),char(0),char(88),char(255),char(195),char(3),char(111),char(0),char(93), -char(255),char(215),char(3),char(111),char(0),char(130),char(255),char(133),char(3),char(111), -char(0),char(131),char(255),char(133),char(3),char(111),char(0),char(132),char(255),char(133), -char(3),char(111),char(0),char(133),char(255),char(133),char(3),char(111),char(0),char(134), -char(255),char(133),char(3),char(111),char(0),char(135),char(255),char(133),char(3),char(111), -char(0),char(137),char(255),char(215),char(3),char(111),char(0),char(148),char(255),char(215), -char(3),char(111),char(0),char(149),char(255),char(215),char(3),char(111),char(0),char(150), -char(255),char(215),char(3),char(111),char(0),char(151),char(255),char(215),char(3),char(111), -char(0),char(152),char(255),char(215),char(3),char(111),char(0),char(154),char(255),char(215), -char(3),char(111),char(0),char(162),char(255),char(154),char(3),char(111),char(0),char(163), -char(255),char(154),char(3),char(111),char(0),char(164),char(255),char(154),char(3),char(111), -char(0),char(165),char(255),char(154),char(3),char(111),char(0),char(166),char(255),char(154), -char(3),char(111),char(0),char(167),char(255),char(154),char(3),char(111),char(0),char(168), -char(255),char(154),char(3),char(111),char(0),char(169),char(255),char(154),char(3),char(111), -char(0),char(170),char(255),char(154),char(3),char(111),char(0),char(171),char(255),char(154), -char(3),char(111),char(0),char(172),char(255),char(154),char(3),char(111),char(0),char(173), -char(255),char(154),char(3),char(111),char(0),char(180),char(255),char(154),char(3),char(111), -char(0),char(181),char(255),char(154),char(3),char(111),char(0),char(182),char(255),char(154), -char(3),char(111),char(0),char(183),char(255),char(154),char(3),char(111),char(0),char(184), -char(255),char(154),char(3),char(111),char(0),char(186),char(255),char(154),char(3),char(111), -char(0),char(187),char(255),char(195),char(3),char(111),char(0),char(188),char(255),char(195), -char(3),char(111),char(0),char(189),char(255),char(195),char(3),char(111),char(0),char(190), -char(255),char(195),char(3),char(111),char(0),char(194),char(255),char(133),char(3),char(111), -char(0),char(195),char(255),char(154),char(3),char(111),char(0),char(196),char(255),char(133), -char(3),char(111),char(0),char(197),char(255),char(154),char(3),char(111),char(0),char(198), -char(255),char(133),char(3),char(111),char(0),char(199),char(255),char(154),char(3),char(111), -char(0),char(200),char(255),char(215),char(3),char(111),char(0),char(201),char(255),char(154), -char(3),char(111),char(0),char(202),char(255),char(215),char(3),char(111),char(0),char(203), -char(255),char(154),char(3),char(111),char(0),char(204),char(255),char(215),char(3),char(111), -char(0),char(205),char(255),char(154),char(3),char(111),char(0),char(206),char(255),char(215), -char(3),char(111),char(0),char(207),char(255),char(154),char(3),char(111),char(0),char(209), -char(255),char(154),char(3),char(111),char(0),char(211),char(255),char(154),char(3),char(111), -char(0),char(213),char(255),char(154),char(3),char(111),char(0),char(215),char(255),char(154), -char(3),char(111),char(0),char(217),char(255),char(154),char(3),char(111),char(0),char(219), -char(255),char(154),char(3),char(111),char(0),char(221),char(255),char(154),char(3),char(111), -char(0),char(222),char(255),char(215),char(3),char(111),char(0),char(223),char(255),char(215), -char(3),char(111),char(0),char(224),char(255),char(215),char(3),char(111),char(0),char(225), -char(255),char(215),char(3),char(111),char(0),char(226),char(255),char(215),char(3),char(111), -char(0),char(227),char(255),char(215),char(3),char(111),char(0),char(228),char(255),char(215), -char(3),char(111),char(0),char(229),char(255),char(215),char(3),char(111),char(0),char(250), -char(255),char(195),char(3),char(111),char(1),char(6),char(255),char(195),char(3),char(111), -char(1),char(8),char(255),char(195),char(3),char(111),char(1),char(13),char(255),char(195), -char(3),char(111),char(1),char(14),char(255),char(215),char(3),char(111),char(1),char(15), -char(255),char(154),char(3),char(111),char(1),char(16),char(255),char(215),char(3),char(111), -char(1),char(17),char(255),char(154),char(3),char(111),char(1),char(18),char(255),char(215), -char(3),char(111),char(1),char(19),char(255),char(154),char(3),char(111),char(1),char(20), -char(255),char(215),char(3),char(111),char(1),char(21),char(255),char(154),char(3),char(111), -char(1),char(23),char(255),char(195),char(3),char(111),char(1),char(25),char(255),char(195), -char(3),char(111),char(1),char(29),char(255),char(174),char(3),char(111),char(1),char(33), -char(255),char(174),char(3),char(111),char(1),char(43),char(255),char(195),char(3),char(111), -char(1),char(45),char(255),char(195),char(3),char(111),char(1),char(47),char(255),char(195), -char(3),char(111),char(1),char(49),char(255),char(195),char(3),char(111),char(1),char(51), -char(255),char(195),char(3),char(111),char(1),char(53),char(255),char(195),char(3),char(111), -char(1),char(60),char(255),char(215),char(3),char(111),char(1),char(62),char(255),char(215), -char(3),char(111),char(1),char(64),char(255),char(215),char(3),char(111),char(1),char(67), -char(255),char(133),char(3),char(111),char(1),char(68),char(255),char(154),char(3),char(111), -char(1),char(70),char(255),char(154),char(3),char(111),char(1),char(71),char(255),char(215), -char(3),char(111),char(1),char(72),char(255),char(154),char(3),char(111),char(1),char(74), -char(255),char(174),char(3),char(111),char(2),char(8),char(255),char(133),char(3),char(111), -char(2),char(12),char(255),char(133),char(3),char(111),char(2),char(87),char(255),char(195), -char(3),char(111),char(2),char(88),char(255),char(133),char(3),char(111),char(2),char(89), -char(255),char(154),char(3),char(111),char(2),char(95),char(255),char(215),char(3),char(111), -char(2),char(96),char(255),char(154),char(3),char(111),char(2),char(98),char(255),char(195), -char(3),char(111),char(3),char(29),char(255),char(133),char(3),char(111),char(3),char(30), -char(255),char(154),char(3),char(111),char(3),char(31),char(255),char(133),char(3),char(111), -char(3),char(32),char(255),char(154),char(3),char(111),char(3),char(33),char(255),char(133), -char(3),char(111),char(3),char(34),char(255),char(154),char(3),char(111),char(3),char(35), -char(255),char(133),char(3),char(111),char(3),char(37),char(255),char(133),char(3),char(111), -char(3),char(38),char(255),char(154),char(3),char(111),char(3),char(39),char(255),char(133), -char(3),char(111),char(3),char(40),char(255),char(154),char(3),char(111),char(3),char(41), -char(255),char(133),char(3),char(111),char(3),char(42),char(255),char(154),char(3),char(111), -char(3),char(43),char(255),char(133),char(3),char(111),char(3),char(44),char(255),char(154), -char(3),char(111),char(3),char(45),char(255),char(133),char(3),char(111),char(3),char(46), -char(255),char(154),char(3),char(111),char(3),char(47),char(255),char(133),char(3),char(111), -char(3),char(48),char(255),char(154),char(3),char(111),char(3),char(49),char(255),char(133), -char(3),char(111),char(3),char(50),char(255),char(154),char(3),char(111),char(3),char(51), -char(255),char(133),char(3),char(111),char(3),char(52),char(255),char(154),char(3),char(111), -char(3),char(54),char(255),char(154),char(3),char(111),char(3),char(56),char(255),char(154), -char(3),char(111),char(3),char(58),char(255),char(154),char(3),char(111),char(3),char(60), -char(255),char(154),char(3),char(111),char(3),char(64),char(255),char(154),char(3),char(111), -char(3),char(66),char(255),char(154),char(3),char(111),char(3),char(68),char(255),char(154), -char(3),char(111),char(3),char(73),char(255),char(215),char(3),char(111),char(3),char(74), -char(255),char(154),char(3),char(111),char(3),char(75),char(255),char(215),char(3),char(111), -char(3),char(76),char(255),char(154),char(3),char(111),char(3),char(77),char(255),char(215), -char(3),char(111),char(3),char(78),char(255),char(154),char(3),char(111),char(3),char(79), -char(255),char(215),char(3),char(111),char(3),char(81),char(255),char(215),char(3),char(111), -char(3),char(82),char(255),char(154),char(3),char(111),char(3),char(83),char(255),char(215), -char(3),char(111),char(3),char(84),char(255),char(154),char(3),char(111),char(3),char(85), -char(255),char(215),char(3),char(111),char(3),char(86),char(255),char(154),char(3),char(111), -char(3),char(87),char(255),char(215),char(3),char(111),char(3),char(88),char(255),char(154), -char(3),char(111),char(3),char(89),char(255),char(215),char(3),char(111),char(3),char(90), -char(255),char(154),char(3),char(111),char(3),char(91),char(255),char(215),char(3),char(111), -char(3),char(92),char(255),char(154),char(3),char(111),char(3),char(93),char(255),char(215), -char(3),char(111),char(3),char(94),char(255),char(154),char(3),char(111),char(3),char(95), -char(255),char(215),char(3),char(111),char(3),char(96),char(255),char(154),char(3),char(111), -char(3),char(98),char(255),char(195),char(3),char(111),char(3),char(100),char(255),char(195), -char(3),char(111),char(3),char(102),char(255),char(195),char(3),char(111),char(3),char(104), -char(255),char(195),char(3),char(111),char(3),char(106),char(255),char(195),char(3),char(111), -char(3),char(108),char(255),char(195),char(3),char(111),char(3),char(110),char(255),char(195), -char(3),char(112),char(0),char(5),char(0),char(82),char(3),char(112),char(0),char(10), -char(0),char(82),char(3),char(112),char(0),char(15),char(255),char(174),char(3),char(112), -char(0),char(17),char(255),char(174),char(3),char(112),char(0),char(34),char(0),char(41), -char(3),char(112),char(2),char(7),char(0),char(82),char(3),char(112),char(2),char(8), -char(255),char(174),char(3),char(112),char(2),char(11),char(0),char(82),char(3),char(112), -char(2),char(12),char(255),char(174),char(3),char(113),char(0),char(15),char(255),char(133), -char(3),char(113),char(0),char(17),char(255),char(133),char(3),char(113),char(0),char(34), -char(0),char(41),char(3),char(113),char(0),char(36),char(255),char(133),char(3),char(113), -char(0),char(38),char(255),char(215),char(3),char(113),char(0),char(42),char(255),char(215), -char(3),char(113),char(0),char(50),char(255),char(215),char(3),char(113),char(0),char(52), -char(255),char(215),char(3),char(113),char(0),char(68),char(255),char(154),char(3),char(113), -char(0),char(70),char(255),char(154),char(3),char(113),char(0),char(71),char(255),char(154), -char(3),char(113),char(0),char(72),char(255),char(154),char(3),char(113),char(0),char(74), -char(255),char(215),char(3),char(113),char(0),char(80),char(255),char(195),char(3),char(113), -char(0),char(81),char(255),char(195),char(3),char(113),char(0),char(82),char(255),char(154), -char(3),char(113),char(0),char(83),char(255),char(195),char(3),char(113),char(0),char(84), -char(255),char(154),char(3),char(113),char(0),char(85),char(255),char(195),char(3),char(113), -char(0),char(86),char(255),char(174),char(3),char(113),char(0),char(88),char(255),char(195), -char(3),char(113),char(0),char(93),char(255),char(215),char(3),char(113),char(0),char(130), -char(255),char(133),char(3),char(113),char(0),char(131),char(255),char(133),char(3),char(113), -char(0),char(132),char(255),char(133),char(3),char(113),char(0),char(133),char(255),char(133), -char(3),char(113),char(0),char(134),char(255),char(133),char(3),char(113),char(0),char(135), -char(255),char(133),char(3),char(113),char(0),char(137),char(255),char(215),char(3),char(113), -char(0),char(148),char(255),char(215),char(3),char(113),char(0),char(149),char(255),char(215), -char(3),char(113),char(0),char(150),char(255),char(215),char(3),char(113),char(0),char(151), -char(255),char(215),char(3),char(113),char(0),char(152),char(255),char(215),char(3),char(113), -char(0),char(154),char(255),char(215),char(3),char(113),char(0),char(162),char(255),char(154), -char(3),char(113),char(0),char(163),char(255),char(154),char(3),char(113),char(0),char(164), -char(255),char(154),char(3),char(113),char(0),char(165),char(255),char(154),char(3),char(113), -char(0),char(166),char(255),char(154),char(3),char(113),char(0),char(167),char(255),char(154), -char(3),char(113),char(0),char(168),char(255),char(154),char(3),char(113),char(0),char(169), -char(255),char(154),char(3),char(113),char(0),char(170),char(255),char(154),char(3),char(113), -char(0),char(171),char(255),char(154),char(3),char(113),char(0),char(172),char(255),char(154), -char(3),char(113),char(0),char(173),char(255),char(154),char(3),char(113),char(0),char(180), -char(255),char(154),char(3),char(113),char(0),char(181),char(255),char(154),char(3),char(113), -char(0),char(182),char(255),char(154),char(3),char(113),char(0),char(183),char(255),char(154), -char(3),char(113),char(0),char(184),char(255),char(154),char(3),char(113),char(0),char(186), -char(255),char(154),char(3),char(113),char(0),char(187),char(255),char(195),char(3),char(113), -char(0),char(188),char(255),char(195),char(3),char(113),char(0),char(189),char(255),char(195), -char(3),char(113),char(0),char(190),char(255),char(195),char(3),char(113),char(0),char(194), -char(255),char(133),char(3),char(113),char(0),char(195),char(255),char(154),char(3),char(113), -char(0),char(196),char(255),char(133),char(3),char(113),char(0),char(197),char(255),char(154), -char(3),char(113),char(0),char(198),char(255),char(133),char(3),char(113),char(0),char(199), -char(255),char(154),char(3),char(113),char(0),char(200),char(255),char(215),char(3),char(113), -char(0),char(201),char(255),char(154),char(3),char(113),char(0),char(202),char(255),char(215), -char(3),char(113),char(0),char(203),char(255),char(154),char(3),char(113),char(0),char(204), -char(255),char(215),char(3),char(113),char(0),char(205),char(255),char(154),char(3),char(113), -char(0),char(206),char(255),char(215),char(3),char(113),char(0),char(207),char(255),char(154), -char(3),char(113),char(0),char(209),char(255),char(154),char(3),char(113),char(0),char(211), -char(255),char(154),char(3),char(113),char(0),char(213),char(255),char(154),char(3),char(113), -char(0),char(215),char(255),char(154),char(3),char(113),char(0),char(217),char(255),char(154), -char(3),char(113),char(0),char(219),char(255),char(154),char(3),char(113),char(0),char(221), -char(255),char(154),char(3),char(113),char(0),char(222),char(255),char(215),char(3),char(113), -char(0),char(223),char(255),char(215),char(3),char(113),char(0),char(224),char(255),char(215), -char(3),char(113),char(0),char(225),char(255),char(215),char(3),char(113),char(0),char(226), -char(255),char(215),char(3),char(113),char(0),char(227),char(255),char(215),char(3),char(113), -char(0),char(228),char(255),char(215),char(3),char(113),char(0),char(229),char(255),char(215), -char(3),char(113),char(0),char(250),char(255),char(195),char(3),char(113),char(1),char(6), -char(255),char(195),char(3),char(113),char(1),char(8),char(255),char(195),char(3),char(113), -char(1),char(13),char(255),char(195),char(3),char(113),char(1),char(14),char(255),char(215), -char(3),char(113),char(1),char(15),char(255),char(154),char(3),char(113),char(1),char(16), -char(255),char(215),char(3),char(113),char(1),char(17),char(255),char(154),char(3),char(113), -char(1),char(18),char(255),char(215),char(3),char(113),char(1),char(19),char(255),char(154), -char(3),char(113),char(1),char(20),char(255),char(215),char(3),char(113),char(1),char(21), -char(255),char(154),char(3),char(113),char(1),char(23),char(255),char(195),char(3),char(113), -char(1),char(25),char(255),char(195),char(3),char(113),char(1),char(29),char(255),char(174), -char(3),char(113),char(1),char(33),char(255),char(174),char(3),char(113),char(1),char(43), -char(255),char(195),char(3),char(113),char(1),char(45),char(255),char(195),char(3),char(113), -char(1),char(47),char(255),char(195),char(3),char(113),char(1),char(49),char(255),char(195), -char(3),char(113),char(1),char(51),char(255),char(195),char(3),char(113),char(1),char(53), -char(255),char(195),char(3),char(113),char(1),char(60),char(255),char(215),char(3),char(113), -char(1),char(62),char(255),char(215),char(3),char(113),char(1),char(64),char(255),char(215), -char(3),char(113),char(1),char(67),char(255),char(133),char(3),char(113),char(1),char(68), -char(255),char(154),char(3),char(113),char(1),char(70),char(255),char(154),char(3),char(113), -char(1),char(71),char(255),char(215),char(3),char(113),char(1),char(72),char(255),char(154), -char(3),char(113),char(1),char(74),char(255),char(174),char(3),char(113),char(2),char(8), -char(255),char(133),char(3),char(113),char(2),char(12),char(255),char(133),char(3),char(113), -char(2),char(87),char(255),char(195),char(3),char(113),char(2),char(88),char(255),char(133), -char(3),char(113),char(2),char(89),char(255),char(154),char(3),char(113),char(2),char(95), -char(255),char(215),char(3),char(113),char(2),char(96),char(255),char(154),char(3),char(113), -char(2),char(98),char(255),char(195),char(3),char(113),char(3),char(29),char(255),char(133), -char(3),char(113),char(3),char(30),char(255),char(154),char(3),char(113),char(3),char(31), -char(255),char(133),char(3),char(113),char(3),char(32),char(255),char(154),char(3),char(113), -char(3),char(33),char(255),char(133),char(3),char(113),char(3),char(34),char(255),char(154), -char(3),char(113),char(3),char(35),char(255),char(133),char(3),char(113),char(3),char(37), -char(255),char(133),char(3),char(113),char(3),char(38),char(255),char(154),char(3),char(113), -char(3),char(39),char(255),char(133),char(3),char(113),char(3),char(40),char(255),char(154), -char(3),char(113),char(3),char(41),char(255),char(133),char(3),char(113),char(3),char(42), -char(255),char(154),char(3),char(113),char(3),char(43),char(255),char(133),char(3),char(113), -char(3),char(44),char(255),char(154),char(3),char(113),char(3),char(45),char(255),char(133), -char(3),char(113),char(3),char(46),char(255),char(154),char(3),char(113),char(3),char(47), -char(255),char(133),char(3),char(113),char(3),char(48),char(255),char(154),char(3),char(113), -char(3),char(49),char(255),char(133),char(3),char(113),char(3),char(50),char(255),char(154), -char(3),char(113),char(3),char(51),char(255),char(133),char(3),char(113),char(3),char(52), -char(255),char(154),char(3),char(113),char(3),char(54),char(255),char(154),char(3),char(113), -char(3),char(56),char(255),char(154),char(3),char(113),char(3),char(58),char(255),char(154), -char(3),char(113),char(3),char(60),char(255),char(154),char(3),char(113),char(3),char(64), -char(255),char(154),char(3),char(113),char(3),char(66),char(255),char(154),char(3),char(113), -char(3),char(68),char(255),char(154),char(3),char(113),char(3),char(73),char(255),char(215), -char(3),char(113),char(3),char(74),char(255),char(154),char(3),char(113),char(3),char(75), -char(255),char(215),char(3),char(113),char(3),char(76),char(255),char(154),char(3),char(113), -char(3),char(77),char(255),char(215),char(3),char(113),char(3),char(78),char(255),char(154), -char(3),char(113),char(3),char(79),char(255),char(215),char(3),char(113),char(3),char(81), -char(255),char(215),char(3),char(113),char(3),char(82),char(255),char(154),char(3),char(113), -char(3),char(83),char(255),char(215),char(3),char(113),char(3),char(84),char(255),char(154), -char(3),char(113),char(3),char(85),char(255),char(215),char(3),char(113),char(3),char(86), -char(255),char(154),char(3),char(113),char(3),char(87),char(255),char(215),char(3),char(113), -char(3),char(88),char(255),char(154),char(3),char(113),char(3),char(89),char(255),char(215), -char(3),char(113),char(3),char(90),char(255),char(154),char(3),char(113),char(3),char(91), -char(255),char(215),char(3),char(113),char(3),char(92),char(255),char(154),char(3),char(113), -char(3),char(93),char(255),char(215),char(3),char(113),char(3),char(94),char(255),char(154), -char(3),char(113),char(3),char(95),char(255),char(215),char(3),char(113),char(3),char(96), -char(255),char(154),char(3),char(113),char(3),char(98),char(255),char(195),char(3),char(113), -char(3),char(100),char(255),char(195),char(3),char(113),char(3),char(102),char(255),char(195), -char(3),char(113),char(3),char(104),char(255),char(195),char(3),char(113),char(3),char(106), -char(255),char(195),char(3),char(113),char(3),char(108),char(255),char(195),char(3),char(113), -char(3),char(110),char(255),char(195),char(3),char(114),char(0),char(5),char(0),char(82), -char(3),char(114),char(0),char(10),char(0),char(82),char(3),char(114),char(0),char(15), -char(255),char(174),char(3),char(114),char(0),char(17),char(255),char(174),char(3),char(114), -char(0),char(34),char(0),char(41),char(3),char(114),char(2),char(7),char(0),char(82), -char(3),char(114),char(2),char(8),char(255),char(174),char(3),char(114),char(2),char(11), -char(0),char(82),char(3),char(114),char(2),char(12),char(255),char(174),char(3),char(115), -char(0),char(15),char(255),char(133),char(3),char(115),char(0),char(17),char(255),char(133), -char(3),char(115),char(0),char(34),char(0),char(41),char(3),char(115),char(0),char(36), -char(255),char(133),char(3),char(115),char(0),char(38),char(255),char(215),char(3),char(115), -char(0),char(42),char(255),char(215),char(3),char(115),char(0),char(50),char(255),char(215), -char(3),char(115),char(0),char(52),char(255),char(215),char(3),char(115),char(0),char(68), -char(255),char(154),char(3),char(115),char(0),char(70),char(255),char(154),char(3),char(115), -char(0),char(71),char(255),char(154),char(3),char(115),char(0),char(72),char(255),char(154), -char(3),char(115),char(0),char(74),char(255),char(215),char(3),char(115),char(0),char(80), -char(255),char(195),char(3),char(115),char(0),char(81),char(255),char(195),char(3),char(115), -char(0),char(82),char(255),char(154),char(3),char(115),char(0),char(83),char(255),char(195), -char(3),char(115),char(0),char(84),char(255),char(154),char(3),char(115),char(0),char(85), -char(255),char(195),char(3),char(115),char(0),char(86),char(255),char(174),char(3),char(115), -char(0),char(88),char(255),char(195),char(3),char(115),char(0),char(93),char(255),char(215), -char(3),char(115),char(0),char(130),char(255),char(133),char(3),char(115),char(0),char(131), -char(255),char(133),char(3),char(115),char(0),char(132),char(255),char(133),char(3),char(115), -char(0),char(133),char(255),char(133),char(3),char(115),char(0),char(134),char(255),char(133), -char(3),char(115),char(0),char(135),char(255),char(133),char(3),char(115),char(0),char(137), -char(255),char(215),char(3),char(115),char(0),char(148),char(255),char(215),char(3),char(115), -char(0),char(149),char(255),char(215),char(3),char(115),char(0),char(150),char(255),char(215), -char(3),char(115),char(0),char(151),char(255),char(215),char(3),char(115),char(0),char(152), -char(255),char(215),char(3),char(115),char(0),char(154),char(255),char(215),char(3),char(115), -char(0),char(162),char(255),char(154),char(3),char(115),char(0),char(163),char(255),char(154), -char(3),char(115),char(0),char(164),char(255),char(154),char(3),char(115),char(0),char(165), -char(255),char(154),char(3),char(115),char(0),char(166),char(255),char(154),char(3),char(115), -char(0),char(167),char(255),char(154),char(3),char(115),char(0),char(168),char(255),char(154), -char(3),char(115),char(0),char(169),char(255),char(154),char(3),char(115),char(0),char(170), -char(255),char(154),char(3),char(115),char(0),char(171),char(255),char(154),char(3),char(115), -char(0),char(172),char(255),char(154),char(3),char(115),char(0),char(173),char(255),char(154), -char(3),char(115),char(0),char(180),char(255),char(154),char(3),char(115),char(0),char(181), -char(255),char(154),char(3),char(115),char(0),char(182),char(255),char(154),char(3),char(115), -char(0),char(183),char(255),char(154),char(3),char(115),char(0),char(184),char(255),char(154), -char(3),char(115),char(0),char(186),char(255),char(154),char(3),char(115),char(0),char(187), -char(255),char(195),char(3),char(115),char(0),char(188),char(255),char(195),char(3),char(115), -char(0),char(189),char(255),char(195),char(3),char(115),char(0),char(190),char(255),char(195), -char(3),char(115),char(0),char(194),char(255),char(133),char(3),char(115),char(0),char(195), -char(255),char(154),char(3),char(115),char(0),char(196),char(255),char(133),char(3),char(115), -char(0),char(197),char(255),char(154),char(3),char(115),char(0),char(198),char(255),char(133), -char(3),char(115),char(0),char(199),char(255),char(154),char(3),char(115),char(0),char(200), -char(255),char(215),char(3),char(115),char(0),char(201),char(255),char(154),char(3),char(115), -char(0),char(202),char(255),char(215),char(3),char(115),char(0),char(203),char(255),char(154), -char(3),char(115),char(0),char(204),char(255),char(215),char(3),char(115),char(0),char(205), -char(255),char(154),char(3),char(115),char(0),char(206),char(255),char(215),char(3),char(115), -char(0),char(207),char(255),char(154),char(3),char(115),char(0),char(209),char(255),char(154), -char(3),char(115),char(0),char(211),char(255),char(154),char(3),char(115),char(0),char(213), -char(255),char(154),char(3),char(115),char(0),char(215),char(255),char(154),char(3),char(115), -char(0),char(217),char(255),char(154),char(3),char(115),char(0),char(219),char(255),char(154), -char(3),char(115),char(0),char(221),char(255),char(154),char(3),char(115),char(0),char(222), -char(255),char(215),char(3),char(115),char(0),char(223),char(255),char(215),char(3),char(115), -char(0),char(224),char(255),char(215),char(3),char(115),char(0),char(225),char(255),char(215), -char(3),char(115),char(0),char(226),char(255),char(215),char(3),char(115),char(0),char(227), -char(255),char(215),char(3),char(115),char(0),char(228),char(255),char(215),char(3),char(115), -char(0),char(229),char(255),char(215),char(3),char(115),char(0),char(250),char(255),char(195), -char(3),char(115),char(1),char(6),char(255),char(195),char(3),char(115),char(1),char(8), -char(255),char(195),char(3),char(115),char(1),char(13),char(255),char(195),char(3),char(115), -char(1),char(14),char(255),char(215),char(3),char(115),char(1),char(15),char(255),char(154), -char(3),char(115),char(1),char(16),char(255),char(215),char(3),char(115),char(1),char(17), -char(255),char(154),char(3),char(115),char(1),char(18),char(255),char(215),char(3),char(115), -char(1),char(19),char(255),char(154),char(3),char(115),char(1),char(20),char(255),char(215), -char(3),char(115),char(1),char(21),char(255),char(154),char(3),char(115),char(1),char(23), -char(255),char(195),char(3),char(115),char(1),char(25),char(255),char(195),char(3),char(115), -char(1),char(29),char(255),char(174),char(3),char(115),char(1),char(33),char(255),char(174), -char(3),char(115),char(1),char(43),char(255),char(195),char(3),char(115),char(1),char(45), -char(255),char(195),char(3),char(115),char(1),char(47),char(255),char(195),char(3),char(115), -char(1),char(49),char(255),char(195),char(3),char(115),char(1),char(51),char(255),char(195), -char(3),char(115),char(1),char(53),char(255),char(195),char(3),char(115),char(1),char(60), -char(255),char(215),char(3),char(115),char(1),char(62),char(255),char(215),char(3),char(115), -char(1),char(64),char(255),char(215),char(3),char(115),char(1),char(67),char(255),char(133), -char(3),char(115),char(1),char(68),char(255),char(154),char(3),char(115),char(1),char(70), -char(255),char(154),char(3),char(115),char(1),char(71),char(255),char(215),char(3),char(115), -char(1),char(72),char(255),char(154),char(3),char(115),char(1),char(74),char(255),char(174), -char(3),char(115),char(2),char(8),char(255),char(133),char(3),char(115),char(2),char(12), -char(255),char(133),char(3),char(115),char(2),char(87),char(255),char(195),char(3),char(115), -char(2),char(88),char(255),char(133),char(3),char(115),char(2),char(89),char(255),char(154), -char(3),char(115),char(2),char(95),char(255),char(215),char(3),char(115),char(2),char(96), -char(255),char(154),char(3),char(115),char(2),char(98),char(255),char(195),char(3),char(115), -char(3),char(29),char(255),char(133),char(3),char(115),char(3),char(30),char(255),char(154), -char(3),char(115),char(3),char(31),char(255),char(133),char(3),char(115),char(3),char(32), -char(255),char(154),char(3),char(115),char(3),char(33),char(255),char(133),char(3),char(115), -char(3),char(34),char(255),char(154),char(3),char(115),char(3),char(35),char(255),char(133), -char(3),char(115),char(3),char(37),char(255),char(133),char(3),char(115),char(3),char(38), -char(255),char(154),char(3),char(115),char(3),char(39),char(255),char(133),char(3),char(115), -char(3),char(40),char(255),char(154),char(3),char(115),char(3),char(41),char(255),char(133), -char(3),char(115),char(3),char(42),char(255),char(154),char(3),char(115),char(3),char(43), -char(255),char(133),char(3),char(115),char(3),char(44),char(255),char(154),char(3),char(115), -char(3),char(45),char(255),char(133),char(3),char(115),char(3),char(46),char(255),char(154), -char(3),char(115),char(3),char(47),char(255),char(133),char(3),char(115),char(3),char(48), -char(255),char(154),char(3),char(115),char(3),char(49),char(255),char(133),char(3),char(115), -char(3),char(50),char(255),char(154),char(3),char(115),char(3),char(51),char(255),char(133), -char(3),char(115),char(3),char(52),char(255),char(154),char(3),char(115),char(3),char(54), -char(255),char(154),char(3),char(115),char(3),char(56),char(255),char(154),char(3),char(115), -char(3),char(58),char(255),char(154),char(3),char(115),char(3),char(60),char(255),char(154), -char(3),char(115),char(3),char(64),char(255),char(154),char(3),char(115),char(3),char(66), -char(255),char(154),char(3),char(115),char(3),char(68),char(255),char(154),char(3),char(115), -char(3),char(73),char(255),char(215),char(3),char(115),char(3),char(74),char(255),char(154), -char(3),char(115),char(3),char(75),char(255),char(215),char(3),char(115),char(3),char(76), -char(255),char(154),char(3),char(115),char(3),char(77),char(255),char(215),char(3),char(115), -char(3),char(78),char(255),char(154),char(3),char(115),char(3),char(79),char(255),char(215), -char(3),char(115),char(3),char(81),char(255),char(215),char(3),char(115),char(3),char(82), -char(255),char(154),char(3),char(115),char(3),char(83),char(255),char(215),char(3),char(115), -char(3),char(84),char(255),char(154),char(3),char(115),char(3),char(85),char(255),char(215), -char(3),char(115),char(3),char(86),char(255),char(154),char(3),char(115),char(3),char(87), -char(255),char(215),char(3),char(115),char(3),char(88),char(255),char(154),char(3),char(115), -char(3),char(89),char(255),char(215),char(3),char(115),char(3),char(90),char(255),char(154), -char(3),char(115),char(3),char(91),char(255),char(215),char(3),char(115),char(3),char(92), -char(255),char(154),char(3),char(115),char(3),char(93),char(255),char(215),char(3),char(115), -char(3),char(94),char(255),char(154),char(3),char(115),char(3),char(95),char(255),char(215), -char(3),char(115),char(3),char(96),char(255),char(154),char(3),char(115),char(3),char(98), -char(255),char(195),char(3),char(115),char(3),char(100),char(255),char(195),char(3),char(115), -char(3),char(102),char(255),char(195),char(3),char(115),char(3),char(104),char(255),char(195), -char(3),char(115),char(3),char(106),char(255),char(195),char(3),char(115),char(3),char(108), -char(255),char(195),char(3),char(115),char(3),char(110),char(255),char(195),char(3),char(116), -char(0),char(5),char(0),char(82),char(3),char(116),char(0),char(10),char(0),char(82), -char(3),char(116),char(0),char(15),char(255),char(174),char(3),char(116),char(0),char(17), -char(255),char(174),char(3),char(116),char(0),char(34),char(0),char(41),char(3),char(116), -char(2),char(7),char(0),char(82),char(3),char(116),char(2),char(8),char(255),char(174), -char(3),char(116),char(2),char(11),char(0),char(82),char(3),char(116),char(2),char(12), -char(255),char(174),char(3),char(141),char(0),char(5),char(0),char(123),char(3),char(141), -char(0),char(10),char(0),char(123),char(3),char(141),char(2),char(7),char(0),char(123), -char(3),char(141),char(2),char(11),char(0),char(123),char(3),char(143),char(0),char(15), -char(255),char(133),char(3),char(143),char(0),char(16),char(255),char(174),char(3),char(143), -char(0),char(17),char(255),char(133),char(3),char(143),char(0),char(34),char(0),char(41), -char(3),char(143),char(0),char(36),char(255),char(113),char(3),char(143),char(0),char(38), -char(255),char(215),char(3),char(143),char(0),char(42),char(255),char(215),char(3),char(143), -char(0),char(50),char(255),char(215),char(3),char(143),char(0),char(52),char(255),char(215), -char(3),char(143),char(0),char(55),char(0),char(41),char(3),char(143),char(0),char(68), -char(255),char(92),char(3),char(143),char(0),char(70),char(255),char(113),char(3),char(143), -char(0),char(71),char(255),char(113),char(3),char(143),char(0),char(72),char(255),char(113), -char(3),char(143),char(0),char(74),char(255),char(113),char(3),char(143),char(0),char(80), -char(255),char(154),char(3),char(143),char(0),char(81),char(255),char(154),char(3),char(143), -char(0),char(82),char(255),char(113),char(3),char(143),char(0),char(83),char(255),char(154), -char(3),char(143),char(0),char(84),char(255),char(113),char(3),char(143),char(0),char(85), -char(255),char(154),char(3),char(143),char(0),char(86),char(255),char(133),char(3),char(143), -char(0),char(88),char(255),char(154),char(3),char(143),char(0),char(89),char(255),char(215), -char(3),char(143),char(0),char(90),char(255),char(215),char(3),char(143),char(0),char(91), -char(255),char(215),char(3),char(143),char(0),char(92),char(255),char(215),char(3),char(143), -char(0),char(93),char(255),char(174),char(3),char(143),char(0),char(130),char(255),char(113), -char(3),char(143),char(0),char(131),char(255),char(113),char(3),char(143),char(0),char(132), -char(255),char(113),char(3),char(143),char(0),char(133),char(255),char(113),char(3),char(143), -char(0),char(134),char(255),char(113),char(3),char(143),char(0),char(135),char(255),char(113), -char(3),char(143),char(0),char(137),char(255),char(215),char(3),char(143),char(0),char(148), -char(255),char(215),char(3),char(143),char(0),char(149),char(255),char(215),char(3),char(143), -char(0),char(150),char(255),char(215),char(3),char(143),char(0),char(151),char(255),char(215), -char(3),char(143),char(0),char(152),char(255),char(215),char(3),char(143),char(0),char(154), -char(255),char(215),char(3),char(143),char(0),char(162),char(255),char(113),char(3),char(143), -char(0),char(163),char(255),char(92),char(3),char(143),char(0),char(164),char(255),char(92), -char(3),char(143),char(0),char(165),char(255),char(92),char(3),char(143),char(0),char(166), -char(255),char(92),char(3),char(143),char(0),char(167),char(255),char(92),char(3),char(143), -char(0),char(168),char(255),char(92),char(3),char(143),char(0),char(169),char(255),char(113), -char(3),char(143),char(0),char(170),char(255),char(113),char(3),char(143),char(0),char(171), -char(255),char(113),char(3),char(143),char(0),char(172),char(255),char(113),char(3),char(143), -char(0),char(173),char(255),char(113),char(3),char(143),char(0),char(180),char(255),char(113), -char(3),char(143),char(0),char(181),char(255),char(113),char(3),char(143),char(0),char(182), -char(255),char(113),char(3),char(143),char(0),char(183),char(255),char(113),char(3),char(143), -char(0),char(184),char(255),char(113),char(3),char(143),char(0),char(186),char(255),char(113), -char(3),char(143),char(0),char(187),char(255),char(154),char(3),char(143),char(0),char(188), -char(255),char(154),char(3),char(143),char(0),char(189),char(255),char(154),char(3),char(143), -char(0),char(190),char(255),char(154),char(3),char(143),char(0),char(191),char(255),char(215), -char(3),char(143),char(0),char(194),char(255),char(113),char(3),char(143),char(0),char(195), -char(255),char(92),char(3),char(143),char(0),char(196),char(255),char(113),char(3),char(143), -char(0),char(197),char(255),char(92),char(3),char(143),char(0),char(198),char(255),char(113), -char(3),char(143),char(0),char(199),char(255),char(92),char(3),char(143),char(0),char(200), -char(255),char(215),char(3),char(143),char(0),char(201),char(255),char(113),char(3),char(143), -char(0),char(202),char(255),char(215),char(3),char(143),char(0),char(203),char(255),char(113), -char(3),char(143),char(0),char(204),char(255),char(215),char(3),char(143),char(0),char(205), -char(255),char(113),char(3),char(143),char(0),char(206),char(255),char(215),char(3),char(143), -char(0),char(207),char(255),char(113),char(3),char(143),char(0),char(209),char(255),char(113), -char(3),char(143),char(0),char(211),char(255),char(113),char(3),char(143),char(0),char(213), -char(255),char(113),char(3),char(143),char(0),char(215),char(255),char(113),char(3),char(143), -char(0),char(217),char(255),char(113),char(3),char(143),char(0),char(219),char(255),char(113), -char(3),char(143),char(0),char(221),char(255),char(113),char(3),char(143),char(0),char(222), -char(255),char(215),char(3),char(143),char(0),char(223),char(255),char(113),char(3),char(143), -char(0),char(224),char(255),char(215),char(3),char(143),char(0),char(225),char(255),char(113), -char(3),char(143),char(0),char(226),char(255),char(215),char(3),char(143),char(0),char(227), -char(255),char(113),char(3),char(143),char(0),char(228),char(255),char(215),char(3),char(143), -char(0),char(229),char(255),char(113),char(3),char(143),char(0),char(250),char(255),char(154), -char(3),char(143),char(1),char(6),char(255),char(154),char(3),char(143),char(1),char(8), -char(255),char(154),char(3),char(143),char(1),char(13),char(255),char(154),char(3),char(143), -char(1),char(14),char(255),char(215),char(3),char(143),char(1),char(15),char(255),char(113), -char(3),char(143),char(1),char(16),char(255),char(215),char(3),char(143),char(1),char(17), -char(255),char(113),char(3),char(143),char(1),char(18),char(255),char(215),char(3),char(143), -char(1),char(19),char(255),char(113),char(3),char(143),char(1),char(20),char(255),char(215), -char(3),char(143),char(1),char(21),char(255),char(113),char(3),char(143),char(1),char(23), -char(255),char(154),char(3),char(143),char(1),char(25),char(255),char(154),char(3),char(143), -char(1),char(29),char(255),char(133),char(3),char(143),char(1),char(33),char(255),char(133), -char(3),char(143),char(1),char(36),char(0),char(41),char(3),char(143),char(1),char(38), -char(0),char(41),char(3),char(143),char(1),char(43),char(255),char(154),char(3),char(143), -char(1),char(45),char(255),char(154),char(3),char(143),char(1),char(47),char(255),char(154), -char(3),char(143),char(1),char(49),char(255),char(154),char(3),char(143),char(1),char(51), -char(255),char(154),char(3),char(143),char(1),char(53),char(255),char(154),char(3),char(143), -char(1),char(55),char(255),char(215),char(3),char(143),char(1),char(60),char(255),char(174), -char(3),char(143),char(1),char(62),char(255),char(174),char(3),char(143),char(1),char(64), -char(255),char(174),char(3),char(143),char(1),char(67),char(255),char(113),char(3),char(143), -char(1),char(68),char(255),char(92),char(3),char(143),char(1),char(70),char(255),char(92), -char(3),char(143),char(1),char(71),char(255),char(215),char(3),char(143),char(1),char(72), -char(255),char(113),char(3),char(143),char(1),char(74),char(255),char(133),char(3),char(143), -char(1),char(251),char(255),char(215),char(3),char(143),char(1),char(253),char(255),char(215), -char(3),char(143),char(2),char(2),char(255),char(174),char(3),char(143),char(2),char(3), -char(255),char(174),char(3),char(143),char(2),char(4),char(255),char(174),char(3),char(143), -char(2),char(8),char(255),char(133),char(3),char(143),char(2),char(12),char(255),char(133), -char(3),char(143),char(2),char(87),char(255),char(154),char(3),char(143),char(2),char(88), -char(255),char(113),char(3),char(143),char(2),char(89),char(255),char(92),char(3),char(143), -char(2),char(95),char(255),char(215),char(3),char(143),char(2),char(96),char(255),char(113), -char(3),char(143),char(2),char(98),char(255),char(154),char(3),char(143),char(3),char(29), -char(255),char(113),char(3),char(143),char(3),char(30),char(255),char(92),char(3),char(143), -char(3),char(31),char(255),char(113),char(3),char(143),char(3),char(32),char(255),char(92), -char(3),char(143),char(3),char(33),char(255),char(113),char(3),char(143),char(3),char(34), -char(255),char(92),char(3),char(143),char(3),char(35),char(255),char(113),char(3),char(143), -char(3),char(37),char(255),char(113),char(3),char(143),char(3),char(38),char(255),char(92), -char(3),char(143),char(3),char(39),char(255),char(113),char(3),char(143),char(3),char(40), -char(255),char(92),char(3),char(143),char(3),char(41),char(255),char(113),char(3),char(143), -char(3),char(42),char(255),char(92),char(3),char(143),char(3),char(43),char(255),char(113), -char(3),char(143),char(3),char(44),char(255),char(92),char(3),char(143),char(3),char(45), -char(255),char(113),char(3),char(143),char(3),char(46),char(255),char(92),char(3),char(143), -char(3),char(47),char(255),char(113),char(3),char(143),char(3),char(48),char(255),char(92), -char(3),char(143),char(3),char(49),char(255),char(113),char(3),char(143),char(3),char(50), -char(255),char(92),char(3),char(143),char(3),char(51),char(255),char(113),char(3),char(143), -char(3),char(52),char(255),char(92),char(3),char(143),char(3),char(54),char(255),char(113), -char(3),char(143),char(3),char(56),char(255),char(113),char(3),char(143),char(3),char(58), -char(255),char(113),char(3),char(143),char(3),char(60),char(255),char(113),char(3),char(143), -char(3),char(64),char(255),char(113),char(3),char(143),char(3),char(66),char(255),char(113), -char(3),char(143),char(3),char(68),char(255),char(113),char(3),char(143),char(3),char(73), -char(255),char(215),char(3),char(143),char(3),char(74),char(255),char(113),char(3),char(143), -char(3),char(75),char(255),char(215),char(3),char(143),char(3),char(76),char(255),char(113), -char(3),char(143),char(3),char(77),char(255),char(215),char(3),char(143),char(3),char(78), -char(255),char(113),char(3),char(143),char(3),char(79),char(255),char(215),char(3),char(143), -char(3),char(81),char(255),char(215),char(3),char(143),char(3),char(82),char(255),char(113), -char(3),char(143),char(3),char(83),char(255),char(215),char(3),char(143),char(3),char(84), -char(255),char(113),char(3),char(143),char(3),char(85),char(255),char(215),char(3),char(143), -char(3),char(86),char(255),char(113),char(3),char(143),char(3),char(87),char(255),char(215), -char(3),char(143),char(3),char(88),char(255),char(113),char(3),char(143),char(3),char(89), -char(255),char(215),char(3),char(143),char(3),char(90),char(255),char(113),char(3),char(143), -char(3),char(91),char(255),char(215),char(3),char(143),char(3),char(92),char(255),char(113), -char(3),char(143),char(3),char(93),char(255),char(215),char(3),char(143),char(3),char(94), -char(255),char(113),char(3),char(143),char(3),char(95),char(255),char(215),char(3),char(143), -char(3),char(96),char(255),char(113),char(3),char(143),char(3),char(98),char(255),char(154), -char(3),char(143),char(3),char(100),char(255),char(154),char(3),char(143),char(3),char(102), -char(255),char(154),char(3),char(143),char(3),char(104),char(255),char(154),char(3),char(143), -char(3),char(106),char(255),char(154),char(3),char(143),char(3),char(108),char(255),char(154), -char(3),char(143),char(3),char(110),char(255),char(154),char(3),char(143),char(3),char(112), -char(255),char(215),char(3),char(143),char(3),char(143),char(0),char(41),char(3),char(144), -char(0),char(5),char(0),char(41),char(3),char(144),char(0),char(10),char(0),char(41), -char(3),char(144),char(2),char(7),char(0),char(41),char(3),char(144),char(2),char(11), -char(0),char(41),char(0),char(0),char(0),char(0),char(0),char(26),char(1),char(62), -char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(57), -char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(1), -char(0),char(9),char(0),char(57),char(0),char(1),char(0),char(0),char(0),char(0), -char(0),char(2),char(0),char(7),char(0),char(66),char(0),char(1),char(0),char(0), -char(0),char(0),char(0),char(3),char(0),char(30),char(0),char(73),char(0),char(1), -char(0),char(0),char(0),char(0),char(0),char(4),char(0),char(9),char(0),char(57), -char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(5),char(0),char(12), -char(0),char(103),char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(6), -char(0),char(8),char(0),char(115),char(0),char(1),char(0),char(0),char(0),char(0), -char(0),char(7),char(0),char(82),char(0),char(123),char(0),char(1),char(0),char(0), -char(0),char(0),char(0),char(8),char(0),char(20),char(0),char(205),char(0),char(1), -char(0),char(0),char(0),char(0),char(0),char(11),char(0),char(28),char(0),char(225), -char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(12),char(0),char(46), -char(0),char(253),char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(13), -char(0),char(46),char(1),char(43),char(0),char(1),char(0),char(0),char(0),char(0), -char(0),char(14),char(0),char(42),char(1),char(89),char(0),char(3),char(0),char(1), -char(4),char(9),char(0),char(0),char(0),char(114),char(1),char(131),char(0),char(3), -char(0),char(1),char(4),char(9),char(0),char(1),char(0),char(18),char(1),char(245), -char(0),char(3),char(0),char(1),char(4),char(9),char(0),char(2),char(0),char(14), -char(2),char(7),char(0),char(3),char(0),char(1),char(4),char(9),char(0),char(3), -char(0),char(60),char(2),char(21),char(0),char(3),char(0),char(1),char(4),char(9), -char(0),char(4),char(0),char(18),char(1),char(245),char(0),char(3),char(0),char(1), -char(4),char(9),char(0),char(5),char(0),char(24),char(2),char(81),char(0),char(3), -char(0),char(1),char(4),char(9),char(0),char(6),char(0),char(16),char(2),char(105), -char(0),char(3),char(0),char(1),char(4),char(9),char(0),char(7),char(0),char(164), -char(2),char(121),char(0),char(3),char(0),char(1),char(4),char(9),char(0),char(8), -char(0),char(40),char(3),char(29),char(0),char(3),char(0),char(1),char(4),char(9), -char(0),char(11),char(0),char(56),char(3),char(69),char(0),char(3),char(0),char(1), -char(4),char(9),char(0),char(12),char(0),char(92),char(3),char(125),char(0),char(3), -char(0),char(1),char(4),char(9),char(0),char(13),char(0),char(92),char(3),char(217), -char(0),char(3),char(0),char(1),char(4),char(9),char(0),char(14),char(0),char(84), -char(4),char(53),char(68),char(105),char(103),char(105),char(116),char(105),char(122),char(101), -char(100),char(32),char(100),char(97),char(116),char(97),char(32),char(99),char(111),char(112), -char(121),char(114),char(105),char(103),char(104),char(116),char(32),char(169),char(32),char(50), -char(48),char(49),char(48),char(45),char(50),char(48),char(49),char(49),char(44),char(32), -char(71),char(111),char(111),char(103),char(108),char(101),char(32),char(67),char(111),char(114), -char(112),char(111),char(114),char(97),char(116),char(105),char(111),char(110),char(46),char(79), -char(112),char(101),char(110),char(32),char(83),char(97),char(110),char(115),char(82),char(101), -char(103),char(117),char(108),char(97),char(114),char(65),char(115),char(99),char(101),char(110), -char(100),char(101),char(114),char(32),char(45),char(32),char(79),char(112),char(101),char(110), -char(32),char(83),char(97),char(110),char(115),char(32),char(66),char(117),char(105),char(108), -char(100),char(32),char(49),char(48),char(48),char(86),char(101),char(114),char(115),char(105), -char(111),char(110),char(32),char(49),char(46),char(49),char(48),char(79),char(112),char(101), -char(110),char(83),char(97),char(110),char(115),char(79),char(112),char(101),char(110),char(32), -char(83),char(97),char(110),char(115),char(32),char(105),char(115),char(32),char(97),char(32), -char(116),char(114),char(97),char(100),char(101),char(109),char(97),char(114),char(107),char(32), -char(111),char(102),char(32),char(71),char(111),char(111),char(103),char(108),char(101),char(32), -char(97),char(110),char(100),char(32),char(109),char(97),char(121),char(32),char(98),char(101), -char(32),char(114),char(101),char(103),char(105),char(115),char(116),char(101),char(114),char(101), -char(100),char(32),char(105),char(110),char(32),char(99),char(101),char(114),char(116),char(97), -char(105),char(110),char(32),char(106),char(117),char(114),char(105),char(115),char(100),char(105), -char(99),char(116),char(105),char(111),char(110),char(115),char(46),char(65),char(115),char(99), -char(101),char(110),char(100),char(101),char(114),char(32),char(67),char(111),char(114),char(112), -char(111),char(114),char(97),char(116),char(105),char(111),char(110),char(104),char(116),char(116), -char(112),char(58),char(47),char(47),char(119),char(119),char(119),char(46),char(97),char(115), -char(99),char(101),char(110),char(100),char(101),char(114),char(99),char(111),char(114),char(112), -char(46),char(99),char(111),char(109),char(47),char(104),char(116),char(116),char(112),char(58), -char(47),char(47),char(119),char(119),char(119),char(46),char(97),char(115),char(99),char(101), -char(110),char(100),char(101),char(114),char(99),char(111),char(114),char(112),char(46),char(99), -char(111),char(109),char(47),char(116),char(121),char(112),char(101),char(100),char(101),char(115), -char(105),char(103),char(110),char(101),char(114),char(115),char(46),char(104),char(116),char(109), -char(108),char(76),char(105),char(99),char(101),char(110),char(115),char(101),char(100),char(32), -char(117),char(110),char(100),char(101),char(114),char(32),char(116),char(104),char(101),char(32), -char(65),char(112),char(97),char(99),char(104),char(101),char(32),char(76),char(105),char(99), -char(101),char(110),char(115),char(101),char(44),char(32),char(86),char(101),char(114),char(115), -char(105),char(111),char(110),char(32),char(50),char(46),char(48),char(104),char(116),char(116), -char(112),char(58),char(47),char(47),char(119),char(119),char(119),char(46),char(97),char(112), -char(97),char(99),char(104),char(101),char(46),char(111),char(114),char(103),char(47),char(108), -char(105),char(99),char(101),char(110),char(115),char(101),char(115),char(47),char(76),char(73), -char(67),char(69),char(78),char(83),char(69),char(45),char(50),char(46),char(48),char(0), -char(68),char(0),char(105),char(0),char(103),char(0),char(105),char(0),char(116),char(0), -char(105),char(0),char(122),char(0),char(101),char(0),char(100),char(0),char(32),char(0), -char(100),char(0),char(97),char(0),char(116),char(0),char(97),char(0),char(32),char(0), -char(99),char(0),char(111),char(0),char(112),char(0),char(121),char(0),char(114),char(0), -char(105),char(0),char(103),char(0),char(104),char(0),char(116),char(0),char(32),char(0), -char(169),char(0),char(32),char(0),char(50),char(0),char(48),char(0),char(49),char(0), -char(48),char(0),char(45),char(0),char(50),char(0),char(48),char(0),char(49),char(0), -char(49),char(0),char(44),char(0),char(32),char(0),char(71),char(0),char(111),char(0), -char(111),char(0),char(103),char(0),char(108),char(0),char(101),char(0),char(32),char(0), -char(67),char(0),char(111),char(0),char(114),char(0),char(112),char(0),char(111),char(0), -char(114),char(0),char(97),char(0),char(116),char(0),char(105),char(0),char(111),char(0), -char(110),char(0),char(46),char(0),char(79),char(0),char(112),char(0),char(101),char(0), -char(110),char(0),char(32),char(0),char(83),char(0),char(97),char(0),char(110),char(0), -char(115),char(0),char(82),char(0),char(101),char(0),char(103),char(0),char(117),char(0), -char(108),char(0),char(97),char(0),char(114),char(0),char(65),char(0),char(115),char(0), -char(99),char(0),char(101),char(0),char(110),char(0),char(100),char(0),char(101),char(0), -char(114),char(0),char(32),char(0),char(45),char(0),char(32),char(0),char(79),char(0), -char(112),char(0),char(101),char(0),char(110),char(0),char(32),char(0),char(83),char(0), -char(97),char(0),char(110),char(0),char(115),char(0),char(32),char(0),char(66),char(0), -char(117),char(0),char(105),char(0),char(108),char(0),char(100),char(0),char(32),char(0), -char(49),char(0),char(48),char(0),char(48),char(0),char(86),char(0),char(101),char(0), -char(114),char(0),char(115),char(0),char(105),char(0),char(111),char(0),char(110),char(0), -char(32),char(0),char(49),char(0),char(46),char(0),char(49),char(0),char(48),char(0), -char(79),char(0),char(112),char(0),char(101),char(0),char(110),char(0),char(83),char(0), -char(97),char(0),char(110),char(0),char(115),char(0),char(79),char(0),char(112),char(0), -char(101),char(0),char(110),char(0),char(32),char(0),char(83),char(0),char(97),char(0), -char(110),char(0),char(115),char(0),char(32),char(0),char(105),char(0),char(115),char(0), -char(32),char(0),char(97),char(0),char(32),char(0),char(116),char(0),char(114),char(0), -char(97),char(0),char(100),char(0),char(101),char(0),char(109),char(0),char(97),char(0), -char(114),char(0),char(107),char(0),char(32),char(0),char(111),char(0),char(102),char(0), -char(32),char(0),char(71),char(0),char(111),char(0),char(111),char(0),char(103),char(0), -char(108),char(0),char(101),char(0),char(32),char(0),char(97),char(0),char(110),char(0), -char(100),char(0),char(32),char(0),char(109),char(0),char(97),char(0),char(121),char(0), -char(32),char(0),char(98),char(0),char(101),char(0),char(32),char(0),char(114),char(0), -char(101),char(0),char(103),char(0),char(105),char(0),char(115),char(0),char(116),char(0), -char(101),char(0),char(114),char(0),char(101),char(0),char(100),char(0),char(32),char(0), -char(105),char(0),char(110),char(0),char(32),char(0),char(99),char(0),char(101),char(0), -char(114),char(0),char(116),char(0),char(97),char(0),char(105),char(0),char(110),char(0), -char(32),char(0),char(106),char(0),char(117),char(0),char(114),char(0),char(105),char(0), -char(115),char(0),char(100),char(0),char(105),char(0),char(99),char(0),char(116),char(0), -char(105),char(0),char(111),char(0),char(110),char(0),char(115),char(0),char(46),char(0), -char(65),char(0),char(115),char(0),char(99),char(0),char(101),char(0),char(110),char(0), -char(100),char(0),char(101),char(0),char(114),char(0),char(32),char(0),char(67),char(0), -char(111),char(0),char(114),char(0),char(112),char(0),char(111),char(0),char(114),char(0), -char(97),char(0),char(116),char(0),char(105),char(0),char(111),char(0),char(110),char(0), -char(104),char(0),char(116),char(0),char(116),char(0),char(112),char(0),char(58),char(0), -char(47),char(0),char(47),char(0),char(119),char(0),char(119),char(0),char(119),char(0), -char(46),char(0),char(97),char(0),char(115),char(0),char(99),char(0),char(101),char(0), -char(110),char(0),char(100),char(0),char(101),char(0),char(114),char(0),char(99),char(0), -char(111),char(0),char(114),char(0),char(112),char(0),char(46),char(0),char(99),char(0), -char(111),char(0),char(109),char(0),char(47),char(0),char(104),char(0),char(116),char(0), -char(116),char(0),char(112),char(0),char(58),char(0),char(47),char(0),char(47),char(0), -char(119),char(0),char(119),char(0),char(119),char(0),char(46),char(0),char(97),char(0), -char(115),char(0),char(99),char(0),char(101),char(0),char(110),char(0),char(100),char(0), -char(101),char(0),char(114),char(0),char(99),char(0),char(111),char(0),char(114),char(0), -char(112),char(0),char(46),char(0),char(99),char(0),char(111),char(0),char(109),char(0), -char(47),char(0),char(116),char(0),char(121),char(0),char(112),char(0),char(101),char(0), -char(100),char(0),char(101),char(0),char(115),char(0),char(105),char(0),char(103),char(0), -char(110),char(0),char(101),char(0),char(114),char(0),char(115),char(0),char(46),char(0), -char(104),char(0),char(116),char(0),char(109),char(0),char(108),char(0),char(76),char(0), -char(105),char(0),char(99),char(0),char(101),char(0),char(110),char(0),char(115),char(0), -char(101),char(0),char(100),char(0),char(32),char(0),char(117),char(0),char(110),char(0), -char(100),char(0),char(101),char(0),char(114),char(0),char(32),char(0),char(116),char(0), -char(104),char(0),char(101),char(0),char(32),char(0),char(65),char(0),char(112),char(0), -char(97),char(0),char(99),char(0),char(104),char(0),char(101),char(0),char(32),char(0), -char(76),char(0),char(105),char(0),char(99),char(0),char(101),char(0),char(110),char(0), -char(115),char(0),char(101),char(0),char(44),char(0),char(32),char(0),char(86),char(0), -char(101),char(0),char(114),char(0),char(115),char(0),char(105),char(0),char(111),char(0), -char(110),char(0),char(32),char(0),char(50),char(0),char(46),char(0),char(48),char(0), -char(104),char(0),char(116),char(0),char(116),char(0),char(112),char(0),char(58),char(0), -char(47),char(0),char(47),char(0),char(119),char(0),char(119),char(0),char(119),char(0), -char(46),char(0),char(97),char(0),char(112),char(0),char(97),char(0),char(99),char(0), -char(104),char(0),char(101),char(0),char(46),char(0),char(111),char(0),char(114),char(0), -char(103),char(0),char(47),char(0),char(108),char(0),char(105),char(0),char(99),char(0), -char(101),char(0),char(110),char(0),char(115),char(0),char(101),char(0),char(115),char(0), -char(47),char(0),char(76),char(0),char(73),char(0),char(67),char(0),char(69),char(0), -char(78),char(0),char(83),char(0),char(69),char(0),char(45),char(0),char(50),char(0), -char(46),char(0),char(48),char(0),char(0),char(2),char(0),char(0),char(0),char(0), -char(0),char(0),char(255),char(102),char(0),char(102),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(0),char(0),char(0),char(0),char(0),char(3),char(170),char(1),char(2), -char(1),char(3),char(1),char(4),char(1),char(5),char(1),char(6),char(1),char(7), -char(1),char(8),char(1),char(9),char(1),char(10),char(1),char(11),char(1),char(12), -char(1),char(13),char(1),char(14),char(1),char(15),char(1),char(16),char(1),char(17), -char(1),char(18),char(1),char(19),char(1),char(20),char(1),char(21),char(1),char(22), -char(1),char(23),char(1),char(24),char(1),char(25),char(1),char(26),char(1),char(27), -char(1),char(28),char(1),char(29),char(1),char(30),char(1),char(31),char(1),char(32), -char(1),char(33),char(1),char(34),char(1),char(35),char(1),char(36),char(1),char(37), -char(1),char(38),char(1),char(39),char(1),char(40),char(1),char(41),char(1),char(42), -char(1),char(43),char(1),char(44),char(1),char(45),char(1),char(46),char(1),char(47), -char(1),char(48),char(1),char(49),char(1),char(50),char(1),char(51),char(1),char(52), -char(1),char(53),char(1),char(54),char(1),char(55),char(1),char(56),char(1),char(57), -char(1),char(58),char(1),char(59),char(1),char(60),char(1),char(61),char(1),char(62), -char(1),char(63),char(1),char(64),char(1),char(65),char(1),char(66),char(1),char(67), -char(1),char(68),char(1),char(69),char(1),char(70),char(1),char(71),char(1),char(72), -char(1),char(73),char(1),char(74),char(1),char(75),char(1),char(76),char(1),char(77), -char(1),char(78),char(1),char(79),char(1),char(80),char(1),char(81),char(1),char(82), -char(1),char(83),char(1),char(84),char(1),char(85),char(1),char(86),char(1),char(87), -char(1),char(88),char(1),char(89),char(1),char(90),char(1),char(91),char(1),char(92), -char(1),char(93),char(1),char(94),char(1),char(95),char(1),char(96),char(1),char(97), -char(1),char(98),char(1),char(99),char(1),char(100),char(1),char(101),char(1),char(102), -char(1),char(103),char(1),char(104),char(1),char(105),char(1),char(106),char(1),char(107), -char(1),char(108),char(1),char(109),char(1),char(110),char(1),char(111),char(1),char(112), -char(1),char(113),char(1),char(114),char(1),char(115),char(1),char(116),char(1),char(117), -char(1),char(118),char(1),char(119),char(1),char(120),char(1),char(121),char(1),char(122), -char(1),char(123),char(1),char(124),char(1),char(125),char(1),char(126),char(1),char(127), -char(1),char(128),char(1),char(129),char(1),char(130),char(1),char(131),char(1),char(132), -char(1),char(133),char(1),char(134),char(1),char(135),char(1),char(136),char(1),char(137), -char(1),char(138),char(1),char(139),char(1),char(140),char(1),char(141),char(1),char(142), -char(1),char(143),char(1),char(144),char(1),char(145),char(1),char(146),char(1),char(147), -char(1),char(148),char(1),char(149),char(1),char(150),char(1),char(151),char(1),char(152), -char(1),char(153),char(1),char(154),char(1),char(155),char(1),char(156),char(1),char(157), -char(1),char(158),char(1),char(159),char(1),char(160),char(1),char(161),char(1),char(162), -char(1),char(163),char(1),char(164),char(1),char(165),char(1),char(166),char(1),char(167), -char(1),char(168),char(1),char(169),char(1),char(170),char(1),char(171),char(1),char(172), -char(1),char(173),char(1),char(174),char(1),char(175),char(1),char(176),char(1),char(177), -char(1),char(178),char(1),char(179),char(1),char(180),char(1),char(181),char(1),char(182), -char(1),char(183),char(1),char(184),char(1),char(185),char(1),char(186),char(1),char(187), -char(1),char(188),char(1),char(189),char(1),char(190),char(1),char(191),char(1),char(192), -char(1),char(193),char(1),char(194),char(1),char(195),char(1),char(196),char(1),char(197), -char(1),char(198),char(1),char(199),char(1),char(200),char(1),char(201),char(1),char(202), -char(1),char(203),char(1),char(204),char(1),char(205),char(1),char(206),char(1),char(207), -char(1),char(208),char(1),char(209),char(1),char(210),char(1),char(211),char(1),char(212), -char(1),char(213),char(1),char(214),char(1),char(215),char(1),char(216),char(1),char(217), -char(1),char(218),char(1),char(219),char(1),char(220),char(1),char(221),char(1),char(222), -char(1),char(223),char(1),char(224),char(1),char(225),char(1),char(226),char(1),char(227), -char(1),char(228),char(1),char(229),char(1),char(230),char(1),char(231),char(1),char(232), -char(1),char(233),char(1),char(234),char(1),char(235),char(1),char(236),char(1),char(237), -char(1),char(238),char(1),char(239),char(1),char(240),char(1),char(241),char(1),char(242), -char(1),char(243),char(1),char(244),char(1),char(245),char(1),char(246),char(1),char(247), -char(1),char(248),char(1),char(249),char(1),char(250),char(1),char(251),char(1),char(252), -char(1),char(253),char(1),char(254),char(1),char(255),char(2),char(0),char(2),char(1), -char(2),char(2),char(2),char(3),char(2),char(4),char(2),char(5),char(2),char(6), -char(2),char(7),char(2),char(8),char(2),char(9),char(2),char(10),char(2),char(11), -char(2),char(12),char(2),char(13),char(2),char(14),char(2),char(15),char(2),char(16), -char(2),char(17),char(2),char(18),char(2),char(19),char(2),char(20),char(2),char(21), -char(2),char(22),char(2),char(23),char(2),char(24),char(2),char(25),char(2),char(26), -char(2),char(27),char(2),char(28),char(2),char(29),char(2),char(30),char(2),char(31), -char(2),char(32),char(2),char(33),char(2),char(34),char(2),char(35),char(2),char(36), -char(2),char(37),char(2),char(38),char(2),char(39),char(2),char(40),char(2),char(41), -char(2),char(42),char(2),char(43),char(2),char(44),char(2),char(45),char(2),char(46), -char(2),char(47),char(2),char(48),char(2),char(49),char(2),char(50),char(2),char(51), -char(2),char(52),char(2),char(53),char(2),char(54),char(2),char(55),char(2),char(56), -char(2),char(57),char(2),char(58),char(2),char(59),char(2),char(60),char(2),char(61), -char(2),char(62),char(2),char(63),char(2),char(64),char(2),char(65),char(2),char(66), -char(2),char(67),char(2),char(68),char(2),char(69),char(2),char(70),char(2),char(71), -char(2),char(72),char(2),char(73),char(2),char(74),char(2),char(75),char(2),char(76), -char(2),char(77),char(2),char(78),char(2),char(79),char(2),char(80),char(2),char(81), -char(2),char(82),char(2),char(83),char(2),char(84),char(2),char(85),char(2),char(86), -char(2),char(87),char(2),char(88),char(2),char(89),char(2),char(90),char(2),char(91), -char(2),char(92),char(2),char(93),char(2),char(94),char(2),char(95),char(2),char(96), -char(2),char(97),char(2),char(98),char(2),char(99),char(2),char(100),char(2),char(101), -char(2),char(102),char(2),char(103),char(2),char(104),char(2),char(105),char(2),char(106), -char(2),char(107),char(2),char(108),char(2),char(109),char(2),char(110),char(2),char(111), -char(2),char(112),char(2),char(113),char(2),char(114),char(2),char(115),char(2),char(116), -char(2),char(117),char(2),char(118),char(2),char(119),char(2),char(120),char(2),char(121), -char(2),char(122),char(2),char(123),char(2),char(124),char(2),char(125),char(2),char(126), -char(2),char(127),char(2),char(128),char(2),char(129),char(2),char(130),char(2),char(131), -char(2),char(132),char(2),char(133),char(2),char(134),char(2),char(135),char(2),char(136), -char(2),char(137),char(2),char(138),char(2),char(139),char(2),char(140),char(2),char(141), -char(2),char(142),char(2),char(143),char(2),char(144),char(2),char(145),char(2),char(146), -char(2),char(147),char(2),char(148),char(2),char(149),char(2),char(150),char(2),char(151), -char(2),char(152),char(2),char(153),char(2),char(154),char(2),char(155),char(2),char(156), -char(2),char(157),char(2),char(158),char(2),char(159),char(2),char(160),char(2),char(161), -char(2),char(162),char(2),char(163),char(2),char(164),char(2),char(165),char(2),char(166), -char(2),char(167),char(2),char(168),char(2),char(169),char(2),char(170),char(2),char(171), -char(2),char(172),char(2),char(173),char(2),char(174),char(2),char(175),char(2),char(176), -char(2),char(177),char(2),char(178),char(2),char(179),char(2),char(180),char(2),char(181), -char(2),char(182),char(2),char(183),char(2),char(184),char(2),char(185),char(2),char(186), -char(2),char(187),char(2),char(188),char(2),char(189),char(2),char(190),char(2),char(191), -char(2),char(192),char(2),char(193),char(2),char(194),char(2),char(195),char(2),char(196), -char(2),char(197),char(2),char(198),char(2),char(199),char(2),char(200),char(2),char(201), -char(2),char(202),char(2),char(203),char(2),char(204),char(2),char(205),char(2),char(206), -char(2),char(207),char(2),char(208),char(2),char(209),char(2),char(210),char(2),char(211), -char(2),char(212),char(2),char(213),char(2),char(214),char(2),char(215),char(2),char(216), -char(2),char(217),char(2),char(218),char(2),char(219),char(2),char(220),char(2),char(221), -char(2),char(222),char(2),char(223),char(2),char(224),char(2),char(225),char(2),char(226), -char(2),char(227),char(2),char(228),char(2),char(229),char(2),char(230),char(2),char(231), -char(2),char(232),char(2),char(233),char(2),char(234),char(2),char(235),char(2),char(236), -char(2),char(237),char(2),char(238),char(2),char(239),char(2),char(240),char(2),char(241), -char(2),char(242),char(2),char(243),char(2),char(244),char(2),char(245),char(2),char(246), -char(2),char(247),char(2),char(248),char(2),char(249),char(2),char(250),char(2),char(251), -char(2),char(252),char(2),char(253),char(2),char(254),char(2),char(255),char(3),char(0), -char(3),char(1),char(3),char(2),char(3),char(3),char(3),char(4),char(3),char(5), -char(3),char(6),char(3),char(7),char(3),char(8),char(3),char(9),char(3),char(10), -char(3),char(11),char(3),char(12),char(3),char(13),char(3),char(14),char(3),char(15), -char(3),char(16),char(3),char(17),char(3),char(18),char(3),char(19),char(3),char(20), -char(3),char(21),char(3),char(22),char(3),char(23),char(3),char(24),char(3),char(25), -char(3),char(26),char(3),char(27),char(3),char(28),char(3),char(29),char(3),char(30), -char(3),char(31),char(3),char(32),char(3),char(33),char(3),char(34),char(3),char(35), -char(3),char(36),char(3),char(37),char(3),char(38),char(3),char(39),char(3),char(40), -char(3),char(41),char(3),char(42),char(3),char(43),char(3),char(44),char(3),char(45), -char(3),char(46),char(3),char(47),char(3),char(48),char(3),char(49),char(3),char(50), -char(3),char(51),char(3),char(52),char(3),char(53),char(3),char(54),char(3),char(55), -char(3),char(56),char(3),char(57),char(3),char(58),char(3),char(59),char(3),char(60), -char(3),char(61),char(3),char(62),char(3),char(63),char(3),char(64),char(3),char(65), -char(3),char(66),char(3),char(67),char(3),char(68),char(3),char(69),char(3),char(70), -char(3),char(71),char(3),char(72),char(3),char(73),char(3),char(74),char(3),char(75), -char(3),char(76),char(3),char(77),char(3),char(78),char(3),char(79),char(3),char(80), -char(3),char(81),char(3),char(82),char(3),char(83),char(3),char(84),char(3),char(85), -char(3),char(86),char(3),char(87),char(3),char(88),char(3),char(89),char(3),char(90), -char(3),char(91),char(3),char(92),char(3),char(93),char(3),char(94),char(3),char(95), -char(3),char(96),char(3),char(97),char(3),char(98),char(3),char(99),char(3),char(100), -char(3),char(101),char(3),char(102),char(3),char(103),char(3),char(104),char(3),char(105), -char(3),char(106),char(3),char(107),char(3),char(108),char(3),char(109),char(3),char(110), -char(3),char(111),char(3),char(112),char(3),char(113),char(3),char(114),char(3),char(115), -char(3),char(116),char(3),char(117),char(3),char(118),char(3),char(119),char(3),char(120), -char(3),char(121),char(3),char(122),char(3),char(123),char(3),char(124),char(3),char(125), -char(3),char(126),char(3),char(127),char(3),char(128),char(3),char(129),char(3),char(130), -char(3),char(131),char(3),char(132),char(3),char(133),char(3),char(134),char(3),char(135), -char(3),char(136),char(3),char(137),char(3),char(138),char(3),char(139),char(3),char(140), -char(3),char(141),char(3),char(142),char(3),char(143),char(3),char(144),char(3),char(145), -char(3),char(146),char(3),char(147),char(3),char(148),char(3),char(149),char(3),char(150), -char(3),char(151),char(3),char(152),char(3),char(153),char(3),char(154),char(3),char(155), -char(3),char(156),char(3),char(157),char(3),char(158),char(3),char(159),char(3),char(160), -char(3),char(161),char(3),char(162),char(3),char(163),char(3),char(164),char(3),char(165), -char(3),char(166),char(3),char(167),char(3),char(168),char(3),char(169),char(3),char(170), -char(3),char(171),char(3),char(172),char(3),char(173),char(3),char(174),char(3),char(175), -char(3),char(176),char(3),char(177),char(3),char(178),char(3),char(179),char(3),char(180), -char(3),char(181),char(3),char(182),char(3),char(183),char(3),char(184),char(3),char(185), -char(3),char(186),char(3),char(187),char(3),char(188),char(3),char(189),char(3),char(190), -char(3),char(191),char(3),char(192),char(3),char(193),char(3),char(194),char(3),char(195), -char(3),char(196),char(3),char(197),char(3),char(198),char(3),char(199),char(3),char(200), -char(3),char(201),char(3),char(202),char(3),char(203),char(3),char(204),char(3),char(205), -char(3),char(206),char(3),char(207),char(3),char(208),char(3),char(209),char(3),char(210), -char(3),char(211),char(3),char(212),char(3),char(213),char(3),char(214),char(3),char(215), -char(3),char(216),char(3),char(217),char(3),char(218),char(3),char(219),char(3),char(220), -char(3),char(221),char(3),char(222),char(3),char(223),char(3),char(224),char(3),char(225), -char(3),char(226),char(3),char(227),char(3),char(228),char(3),char(229),char(3),char(230), -char(3),char(231),char(3),char(232),char(3),char(233),char(3),char(234),char(3),char(235), -char(3),char(236),char(3),char(237),char(3),char(238),char(3),char(239),char(3),char(240), -char(3),char(241),char(3),char(242),char(3),char(243),char(3),char(244),char(3),char(245), -char(3),char(246),char(3),char(247),char(3),char(248),char(3),char(249),char(3),char(250), -char(3),char(251),char(3),char(252),char(3),char(253),char(3),char(254),char(3),char(255), -char(4),char(0),char(4),char(1),char(4),char(2),char(4),char(3),char(4),char(4), -char(4),char(5),char(4),char(6),char(4),char(7),char(4),char(8),char(4),char(9), -char(4),char(10),char(4),char(11),char(4),char(12),char(4),char(13),char(4),char(14), -char(4),char(15),char(4),char(16),char(4),char(17),char(4),char(18),char(4),char(19), -char(4),char(20),char(4),char(21),char(4),char(22),char(4),char(23),char(4),char(24), -char(4),char(25),char(4),char(26),char(4),char(27),char(4),char(28),char(4),char(29), -char(4),char(30),char(4),char(31),char(4),char(32),char(4),char(33),char(4),char(34), -char(4),char(35),char(4),char(36),char(4),char(37),char(4),char(38),char(4),char(39), -char(4),char(40),char(4),char(41),char(4),char(42),char(4),char(43),char(4),char(44), -char(4),char(45),char(4),char(46),char(4),char(47),char(4),char(48),char(4),char(49), -char(4),char(50),char(4),char(51),char(4),char(52),char(4),char(53),char(4),char(54), -char(4),char(55),char(4),char(56),char(4),char(57),char(4),char(58),char(4),char(59), -char(4),char(60),char(4),char(61),char(4),char(62),char(4),char(63),char(4),char(64), -char(4),char(65),char(4),char(66),char(4),char(67),char(4),char(68),char(4),char(69), -char(4),char(70),char(4),char(71),char(4),char(72),char(4),char(73),char(4),char(74), -char(4),char(75),char(4),char(76),char(4),char(77),char(4),char(78),char(4),char(79), -char(4),char(80),char(4),char(81),char(4),char(82),char(4),char(83),char(4),char(84), -char(4),char(85),char(4),char(86),char(4),char(87),char(4),char(88),char(4),char(89), -char(4),char(90),char(4),char(91),char(4),char(92),char(4),char(93),char(4),char(94), -char(4),char(95),char(4),char(96),char(4),char(97),char(4),char(98),char(4),char(99), -char(4),char(100),char(4),char(101),char(4),char(102),char(4),char(103),char(4),char(104), -char(4),char(105),char(4),char(106),char(4),char(107),char(4),char(108),char(4),char(109), -char(4),char(110),char(4),char(111),char(4),char(112),char(4),char(113),char(4),char(114), -char(4),char(115),char(4),char(116),char(4),char(117),char(4),char(118),char(4),char(119), -char(4),char(120),char(4),char(121),char(4),char(122),char(4),char(123),char(4),char(124), -char(4),char(125),char(4),char(126),char(4),char(127),char(4),char(128),char(4),char(129), -char(4),char(130),char(4),char(131),char(4),char(132),char(4),char(133),char(4),char(134), -char(4),char(135),char(4),char(136),char(4),char(137),char(4),char(138),char(4),char(139), -char(4),char(140),char(4),char(141),char(4),char(142),char(4),char(143),char(4),char(144), -char(4),char(145),char(4),char(146),char(4),char(147),char(4),char(148),char(4),char(149), -char(4),char(150),char(4),char(151),char(4),char(152),char(4),char(153),char(4),char(154), -char(4),char(155),char(4),char(156),char(4),char(157),char(4),char(158),char(4),char(159), -char(4),char(160),char(4),char(161),char(4),char(162),char(4),char(163),char(4),char(164), -char(4),char(165),char(4),char(166),char(4),char(167),char(4),char(168),char(4),char(169), -char(4),char(170),char(4),char(171),char(7),char(46),char(110),char(111),char(116),char(100), -char(101),char(102),char(4),char(110),char(117),char(108),char(108),char(16),char(110),char(111), -char(110),char(109),char(97),char(114),char(107),char(105),char(110),char(103),char(114),char(101), -char(116),char(117),char(114),char(110),char(5),char(115),char(112),char(97),char(99),char(101), -char(6),char(101),char(120),char(99),char(108),char(97),char(109),char(8),char(113),char(117), -char(111),char(116),char(101),char(100),char(98),char(108),char(10),char(110),char(117),char(109), -char(98),char(101),char(114),char(115),char(105),char(103),char(110),char(6),char(100),char(111), -char(108),char(108),char(97),char(114),char(7),char(112),char(101),char(114),char(99),char(101), -char(110),char(116),char(9),char(97),char(109),char(112),char(101),char(114),char(115),char(97), -char(110),char(100),char(11),char(113),char(117),char(111),char(116),char(101),char(115),char(105), -char(110),char(103),char(108),char(101),char(9),char(112),char(97),char(114),char(101),char(110), -char(108),char(101),char(102),char(116),char(10),char(112),char(97),char(114),char(101),char(110), -char(114),char(105),char(103),char(104),char(116),char(8),char(97),char(115),char(116),char(101), -char(114),char(105),char(115),char(107),char(4),char(112),char(108),char(117),char(115),char(5), -char(99),char(111),char(109),char(109),char(97),char(6),char(104),char(121),char(112),char(104), -char(101),char(110),char(6),char(112),char(101),char(114),char(105),char(111),char(100),char(5), -char(115),char(108),char(97),char(115),char(104),char(4),char(122),char(101),char(114),char(111), -char(3),char(111),char(110),char(101),char(3),char(116),char(119),char(111),char(5),char(116), -char(104),char(114),char(101),char(101),char(4),char(102),char(111),char(117),char(114),char(4), -char(102),char(105),char(118),char(101),char(3),char(115),char(105),char(120),char(5),char(115), -char(101),char(118),char(101),char(110),char(5),char(101),char(105),char(103),char(104),char(116), -char(4),char(110),char(105),char(110),char(101),char(5),char(99),char(111),char(108),char(111), -char(110),char(9),char(115),char(101),char(109),char(105),char(99),char(111),char(108),char(111), -char(110),char(4),char(108),char(101),char(115),char(115),char(5),char(101),char(113),char(117), -char(97),char(108),char(7),char(103),char(114),char(101),char(97),char(116),char(101),char(114), -char(8),char(113),char(117),char(101),char(115),char(116),char(105),char(111),char(110),char(2), -char(97),char(116),char(1),char(65),char(1),char(66),char(1),char(67),char(1),char(68), -char(1),char(69),char(1),char(70),char(1),char(71),char(1),char(72),char(5),char(73), -char(46),char(97),char(108),char(116),char(1),char(74),char(1),char(75),char(1),char(76), -char(1),char(77),char(1),char(78),char(1),char(79),char(1),char(80),char(1),char(81), -char(1),char(82),char(1),char(83),char(1),char(84),char(1),char(85),char(1),char(86), -char(1),char(87),char(1),char(88),char(1),char(89),char(1),char(90),char(11),char(98), -char(114),char(97),char(99),char(107),char(101),char(116),char(108),char(101),char(102),char(116), -char(9),char(98),char(97),char(99),char(107),char(115),char(108),char(97),char(115),char(104), -char(12),char(98),char(114),char(97),char(99),char(107),char(101),char(116),char(114),char(105), -char(103),char(104),char(116),char(11),char(97),char(115),char(99),char(105),char(105),char(99), -char(105),char(114),char(99),char(117),char(109),char(10),char(117),char(110),char(100),char(101), -char(114),char(115),char(99),char(111),char(114),char(101),char(5),char(103),char(114),char(97), -char(118),char(101),char(1),char(97),char(1),char(98),char(1),char(99),char(1),char(100), -char(1),char(101),char(1),char(102),char(1),char(103),char(1),char(104),char(1),char(105), -char(1),char(106),char(1),char(107),char(1),char(108),char(1),char(109),char(1),char(110), -char(1),char(111),char(1),char(112),char(1),char(113),char(1),char(114),char(1),char(115), -char(1),char(116),char(1),char(117),char(1),char(118),char(1),char(119),char(1),char(120), -char(1),char(121),char(1),char(122),char(9),char(98),char(114),char(97),char(99),char(101), -char(108),char(101),char(102),char(116),char(3),char(98),char(97),char(114),char(10),char(98), -char(114),char(97),char(99),char(101),char(114),char(105),char(103),char(104),char(116),char(10), -char(97),char(115),char(99),char(105),char(105),char(116),char(105),char(108),char(100),char(101), -char(16),char(110),char(111),char(110),char(98),char(114),char(101),char(97),char(107),char(105), -char(110),char(103),char(115),char(112),char(97),char(99),char(101),char(10),char(101),char(120), -char(99),char(108),char(97),char(109),char(100),char(111),char(119),char(110),char(4),char(99), -char(101),char(110),char(116),char(8),char(115),char(116),char(101),char(114),char(108),char(105), -char(110),char(103),char(8),char(99),char(117),char(114),char(114),char(101),char(110),char(99), -char(121),char(3),char(121),char(101),char(110),char(9),char(98),char(114),char(111),char(107), -char(101),char(110),char(98),char(97),char(114),char(7),char(115),char(101),char(99),char(116), -char(105),char(111),char(110),char(8),char(100),char(105),char(101),char(114),char(101),char(115), -char(105),char(115),char(9),char(99),char(111),char(112),char(121),char(114),char(105),char(103), -char(104),char(116),char(11),char(111),char(114),char(100),char(102),char(101),char(109),char(105), -char(110),char(105),char(110),char(101),char(13),char(103),char(117),char(105),char(108),char(108), -char(101),char(109),char(111),char(116),char(108),char(101),char(102),char(116),char(10),char(108), -char(111),char(103),char(105),char(99),char(97),char(108),char(110),char(111),char(116),char(7), -char(117),char(110),char(105),char(48),char(48),char(65),char(68),char(10),char(114),char(101), -char(103),char(105),char(115),char(116),char(101),char(114),char(101),char(100),char(9),char(111), -char(118),char(101),char(114),char(115),char(99),char(111),char(114),char(101),char(6),char(100), -char(101),char(103),char(114),char(101),char(101),char(9),char(112),char(108),char(117),char(115), -char(109),char(105),char(110),char(117),char(115),char(11),char(116),char(119),char(111),char(115), -char(117),char(112),char(101),char(114),char(105),char(111),char(114),char(13),char(116),char(104), -char(114),char(101),char(101),char(115),char(117),char(112),char(101),char(114),char(105),char(111), -char(114),char(5),char(97),char(99),char(117),char(116),char(101),char(2),char(109),char(117), -char(9),char(112),char(97),char(114),char(97),char(103),char(114),char(97),char(112),char(104), -char(14),char(112),char(101),char(114),char(105),char(111),char(100),char(99),char(101),char(110), -char(116),char(101),char(114),char(101),char(100),char(7),char(99),char(101),char(100),char(105), -char(108),char(108),char(97),char(11),char(111),char(110),char(101),char(115),char(117),char(112), -char(101),char(114),char(105),char(111),char(114),char(12),char(111),char(114),char(100),char(109), -char(97),char(115),char(99),char(117),char(108),char(105),char(110),char(101),char(14),char(103), -char(117),char(105),char(108),char(108),char(101),char(109),char(111),char(116),char(114),char(105), -char(103),char(104),char(116),char(10),char(111),char(110),char(101),char(113),char(117),char(97), -char(114),char(116),char(101),char(114),char(7),char(111),char(110),char(101),char(104),char(97), -char(108),char(102),char(13),char(116),char(104),char(114),char(101),char(101),char(113),char(117), -char(97),char(114),char(116),char(101),char(114),char(115),char(12),char(113),char(117),char(101), -char(115),char(116),char(105),char(111),char(110),char(100),char(111),char(119),char(110),char(6), -char(65),char(103),char(114),char(97),char(118),char(101),char(6),char(65),char(97),char(99), -char(117),char(116),char(101),char(11),char(65),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(6),char(65),char(116),char(105),char(108), -char(100),char(101),char(9),char(65),char(100),char(105),char(101),char(114),char(101),char(115), -char(105),char(115),char(5),char(65),char(114),char(105),char(110),char(103),char(2),char(65), -char(69),char(8),char(67),char(99),char(101),char(100),char(105),char(108),char(108),char(97), -char(6),char(69),char(103),char(114),char(97),char(118),char(101),char(6),char(69),char(97), -char(99),char(117),char(116),char(101),char(11),char(69),char(99),char(105),char(114),char(99), -char(117),char(109),char(102),char(108),char(101),char(120),char(9),char(69),char(100),char(105), -char(101),char(114),char(101),char(115),char(105),char(115),char(10),char(73),char(103),char(114), -char(97),char(118),char(101),char(46),char(97),char(108),char(116),char(10),char(73),char(97), -char(99),char(117),char(116),char(101),char(46),char(97),char(108),char(116),char(15),char(73), -char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120), -char(46),char(97),char(108),char(116),char(13),char(73),char(100),char(105),char(101),char(114), -char(101),char(115),char(105),char(115),char(46),char(97),char(108),char(116),char(3),char(69), -char(116),char(104),char(6),char(78),char(116),char(105),char(108),char(100),char(101),char(6), -char(79),char(103),char(114),char(97),char(118),char(101),char(6),char(79),char(97),char(99), -char(117),char(116),char(101),char(11),char(79),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(6),char(79),char(116),char(105),char(108), -char(100),char(101),char(9),char(79),char(100),char(105),char(101),char(114),char(101),char(115), -char(105),char(115),char(8),char(109),char(117),char(108),char(116),char(105),char(112),char(108), -char(121),char(6),char(79),char(115),char(108),char(97),char(115),char(104),char(6),char(85), -char(103),char(114),char(97),char(118),char(101),char(6),char(85),char(97),char(99),char(117), -char(116),char(101),char(11),char(85),char(99),char(105),char(114),char(99),char(117),char(109), -char(102),char(108),char(101),char(120),char(9),char(85),char(100),char(105),char(101),char(114), -char(101),char(115),char(105),char(115),char(6),char(89),char(97),char(99),char(117),char(116), -char(101),char(5),char(84),char(104),char(111),char(114),char(110),char(10),char(103),char(101), -char(114),char(109),char(97),char(110),char(100),char(98),char(108),char(115),char(6),char(97), -char(103),char(114),char(97),char(118),char(101),char(6),char(97),char(97),char(99),char(117), -char(116),char(101),char(11),char(97),char(99),char(105),char(114),char(99),char(117),char(109), -char(102),char(108),char(101),char(120),char(6),char(97),char(116),char(105),char(108),char(100), -char(101),char(9),char(97),char(100),char(105),char(101),char(114),char(101),char(115),char(105), -char(115),char(5),char(97),char(114),char(105),char(110),char(103),char(2),char(97),char(101), -char(8),char(99),char(99),char(101),char(100),char(105),char(108),char(108),char(97),char(6), -char(101),char(103),char(114),char(97),char(118),char(101),char(6),char(101),char(97),char(99), -char(117),char(116),char(101),char(11),char(101),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(9),char(101),char(100),char(105),char(101), -char(114),char(101),char(115),char(105),char(115),char(6),char(105),char(103),char(114),char(97), -char(118),char(101),char(6),char(105),char(97),char(99),char(117),char(116),char(101),char(11), -char(105),char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101), -char(120),char(9),char(105),char(100),char(105),char(101),char(114),char(101),char(115),char(105), -char(115),char(3),char(101),char(116),char(104),char(6),char(110),char(116),char(105),char(108), -char(100),char(101),char(6),char(111),char(103),char(114),char(97),char(118),char(101),char(6), -char(111),char(97),char(99),char(117),char(116),char(101),char(11),char(111),char(99),char(105), -char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120),char(6),char(111), -char(116),char(105),char(108),char(100),char(101),char(9),char(111),char(100),char(105),char(101), -char(114),char(101),char(115),char(105),char(115),char(6),char(100),char(105),char(118),char(105), -char(100),char(101),char(6),char(111),char(115),char(108),char(97),char(115),char(104),char(6), -char(117),char(103),char(114),char(97),char(118),char(101),char(6),char(117),char(97),char(99), -char(117),char(116),char(101),char(11),char(117),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(9),char(117),char(100),char(105),char(101), -char(114),char(101),char(115),char(105),char(115),char(6),char(121),char(97),char(99),char(117), -char(116),char(101),char(5),char(116),char(104),char(111),char(114),char(110),char(9),char(121), -char(100),char(105),char(101),char(114),char(101),char(115),char(105),char(115),char(7),char(65), -char(109),char(97),char(99),char(114),char(111),char(110),char(7),char(97),char(109),char(97), -char(99),char(114),char(111),char(110),char(6),char(65),char(98),char(114),char(101),char(118), -char(101),char(6),char(97),char(98),char(114),char(101),char(118),char(101),char(7),char(65), -char(111),char(103),char(111),char(110),char(101),char(107),char(7),char(97),char(111),char(103), -char(111),char(110),char(101),char(107),char(6),char(67),char(97),char(99),char(117),char(116), -char(101),char(6),char(99),char(97),char(99),char(117),char(116),char(101),char(11),char(67), -char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120), -char(11),char(99),char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108), -char(101),char(120),char(4),char(67),char(100),char(111),char(116),char(4),char(99),char(100), -char(111),char(116),char(6),char(67),char(99),char(97),char(114),char(111),char(110),char(6), -char(99),char(99),char(97),char(114),char(111),char(110),char(6),char(68),char(99),char(97), -char(114),char(111),char(110),char(6),char(100),char(99),char(97),char(114),char(111),char(110), -char(6),char(68),char(99),char(114),char(111),char(97),char(116),char(6),char(100),char(99), -char(114),char(111),char(97),char(116),char(7),char(69),char(109),char(97),char(99),char(114), -char(111),char(110),char(7),char(101),char(109),char(97),char(99),char(114),char(111),char(110), -char(6),char(69),char(98),char(114),char(101),char(118),char(101),char(6),char(101),char(98), -char(114),char(101),char(118),char(101),char(10),char(69),char(100),char(111),char(116),char(97), -char(99),char(99),char(101),char(110),char(116),char(10),char(101),char(100),char(111),char(116), -char(97),char(99),char(99),char(101),char(110),char(116),char(7),char(69),char(111),char(103), -char(111),char(110),char(101),char(107),char(7),char(101),char(111),char(103),char(111),char(110), -char(101),char(107),char(6),char(69),char(99),char(97),char(114),char(111),char(110),char(6), -char(101),char(99),char(97),char(114),char(111),char(110),char(11),char(71),char(99),char(105), -char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120),char(11),char(103), -char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120), -char(6),char(71),char(98),char(114),char(101),char(118),char(101),char(6),char(103),char(98), -char(114),char(101),char(118),char(101),char(4),char(71),char(100),char(111),char(116),char(4), -char(103),char(100),char(111),char(116),char(12),char(71),char(99),char(111),char(109),char(109), -char(97),char(97),char(99),char(99),char(101),char(110),char(116),char(12),char(103),char(99), -char(111),char(109),char(109),char(97),char(97),char(99),char(99),char(101),char(110),char(116), -char(11),char(72),char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108), -char(101),char(120),char(11),char(104),char(99),char(105),char(114),char(99),char(117),char(109), -char(102),char(108),char(101),char(120),char(4),char(72),char(98),char(97),char(114),char(4), -char(104),char(98),char(97),char(114),char(10),char(73),char(116),char(105),char(108),char(100), -char(101),char(46),char(97),char(108),char(116),char(6),char(105),char(116),char(105),char(108), -char(100),char(101),char(11),char(73),char(109),char(97),char(99),char(114),char(111),char(110), -char(46),char(97),char(108),char(116),char(7),char(105),char(109),char(97),char(99),char(114), -char(111),char(110),char(10),char(73),char(98),char(114),char(101),char(118),char(101),char(46), -char(97),char(108),char(116),char(6),char(105),char(98),char(114),char(101),char(118),char(101), -char(11),char(73),char(111),char(103),char(111),char(110),char(101),char(107),char(46),char(97), -char(108),char(116),char(7),char(105),char(111),char(103),char(111),char(110),char(101),char(107), -char(14),char(73),char(100),char(111),char(116),char(97),char(99),char(99),char(101),char(110), -char(116),char(46),char(97),char(108),char(116),char(8),char(100),char(111),char(116),char(108), -char(101),char(115),char(115),char(105),char(6),char(73),char(74),char(46),char(97),char(108), -char(116),char(2),char(105),char(106),char(11),char(74),char(99),char(105),char(114),char(99), -char(117),char(109),char(102),char(108),char(101),char(120),char(11),char(106),char(99),char(105), -char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120),char(12),char(75), -char(99),char(111),char(109),char(109),char(97),char(97),char(99),char(99),char(101),char(110), -char(116),char(12),char(107),char(99),char(111),char(109),char(109),char(97),char(97),char(99), -char(99),char(101),char(110),char(116),char(12),char(107),char(103),char(114),char(101),char(101), -char(110),char(108),char(97),char(110),char(100),char(105),char(99),char(6),char(76),char(97), -char(99),char(117),char(116),char(101),char(6),char(108),char(97),char(99),char(117),char(116), -char(101),char(12),char(76),char(99),char(111),char(109),char(109),char(97),char(97),char(99), -char(99),char(101),char(110),char(116),char(12),char(108),char(99),char(111),char(109),char(109), -char(97),char(97),char(99),char(99),char(101),char(110),char(116),char(6),char(76),char(99), -char(97),char(114),char(111),char(110),char(6),char(108),char(99),char(97),char(114),char(111), -char(110),char(4),char(76),char(100),char(111),char(116),char(4),char(108),char(100),char(111), -char(116),char(6),char(76),char(115),char(108),char(97),char(115),char(104),char(6),char(108), -char(115),char(108),char(97),char(115),char(104),char(6),char(78),char(97),char(99),char(117), -char(116),char(101),char(6),char(110),char(97),char(99),char(117),char(116),char(101),char(12), -char(78),char(99),char(111),char(109),char(109),char(97),char(97),char(99),char(99),char(101), -char(110),char(116),char(12),char(110),char(99),char(111),char(109),char(109),char(97),char(97), -char(99),char(99),char(101),char(110),char(116),char(6),char(78),char(99),char(97),char(114), -char(111),char(110),char(6),char(110),char(99),char(97),char(114),char(111),char(110),char(11), -char(110),char(97),char(112),char(111),char(115),char(116),char(114),char(111),char(112),char(104), -char(101),char(3),char(69),char(110),char(103),char(3),char(101),char(110),char(103),char(7), -char(79),char(109),char(97),char(99),char(114),char(111),char(110),char(7),char(111),char(109), -char(97),char(99),char(114),char(111),char(110),char(6),char(79),char(98),char(114),char(101), -char(118),char(101),char(6),char(111),char(98),char(114),char(101),char(118),char(101),char(13), -char(79),char(104),char(117),char(110),char(103),char(97),char(114),char(117),char(109),char(108), -char(97),char(117),char(116),char(13),char(111),char(104),char(117),char(110),char(103),char(97), -char(114),char(117),char(109),char(108),char(97),char(117),char(116),char(2),char(79),char(69), -char(2),char(111),char(101),char(6),char(82),char(97),char(99),char(117),char(116),char(101), -char(6),char(114),char(97),char(99),char(117),char(116),char(101),char(12),char(82),char(99), -char(111),char(109),char(109),char(97),char(97),char(99),char(99),char(101),char(110),char(116), -char(12),char(114),char(99),char(111),char(109),char(109),char(97),char(97),char(99),char(99), -char(101),char(110),char(116),char(6),char(82),char(99),char(97),char(114),char(111),char(110), -char(6),char(114),char(99),char(97),char(114),char(111),char(110),char(6),char(83),char(97), -char(99),char(117),char(116),char(101),char(6),char(115),char(97),char(99),char(117),char(116), -char(101),char(11),char(83),char(99),char(105),char(114),char(99),char(117),char(109),char(102), -char(108),char(101),char(120),char(11),char(115),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(8),char(83),char(99),char(101),char(100), -char(105),char(108),char(108),char(97),char(8),char(115),char(99),char(101),char(100),char(105), -char(108),char(108),char(97),char(6),char(83),char(99),char(97),char(114),char(111),char(110), -char(6),char(115),char(99),char(97),char(114),char(111),char(110),char(12),char(84),char(99), -char(111),char(109),char(109),char(97),char(97),char(99),char(99),char(101),char(110),char(116), -char(12),char(116),char(99),char(111),char(109),char(109),char(97),char(97),char(99),char(99), -char(101),char(110),char(116),char(6),char(84),char(99),char(97),char(114),char(111),char(110), -char(6),char(116),char(99),char(97),char(114),char(111),char(110),char(4),char(84),char(98), -char(97),char(114),char(4),char(116),char(98),char(97),char(114),char(6),char(85),char(116), -char(105),char(108),char(100),char(101),char(6),char(117),char(116),char(105),char(108),char(100), -char(101),char(7),char(85),char(109),char(97),char(99),char(114),char(111),char(110),char(7), -char(117),char(109),char(97),char(99),char(114),char(111),char(110),char(6),char(85),char(98), -char(114),char(101),char(118),char(101),char(6),char(117),char(98),char(114),char(101),char(118), -char(101),char(5),char(85),char(114),char(105),char(110),char(103),char(5),char(117),char(114), -char(105),char(110),char(103),char(13),char(85),char(104),char(117),char(110),char(103),char(97), -char(114),char(117),char(109),char(108),char(97),char(117),char(116),char(13),char(117),char(104), -char(117),char(110),char(103),char(97),char(114),char(117),char(109),char(108),char(97),char(117), -char(116),char(7),char(85),char(111),char(103),char(111),char(110),char(101),char(107),char(7), -char(117),char(111),char(103),char(111),char(110),char(101),char(107),char(11),char(87),char(99), -char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101),char(120),char(11), -char(119),char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101), -char(120),char(11),char(89),char(99),char(105),char(114),char(99),char(117),char(109),char(102), -char(108),char(101),char(120),char(11),char(121),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(9),char(89),char(100),char(105),char(101), -char(114),char(101),char(115),char(105),char(115),char(6),char(90),char(97),char(99),char(117), -char(116),char(101),char(6),char(122),char(97),char(99),char(117),char(116),char(101),char(10), -char(90),char(100),char(111),char(116),char(97),char(99),char(99),char(101),char(110),char(116), -char(10),char(122),char(100),char(111),char(116),char(97),char(99),char(99),char(101),char(110), -char(116),char(6),char(90),char(99),char(97),char(114),char(111),char(110),char(6),char(122), -char(99),char(97),char(114),char(111),char(110),char(5),char(108),char(111),char(110),char(103), -char(115),char(6),char(102),char(108),char(111),char(114),char(105),char(110),char(10),char(65), -char(114),char(105),char(110),char(103),char(97),char(99),char(117),char(116),char(101),char(10), -char(97),char(114),char(105),char(110),char(103),char(97),char(99),char(117),char(116),char(101), -char(7),char(65),char(69),char(97),char(99),char(117),char(116),char(101),char(7),char(97), -char(101),char(97),char(99),char(117),char(116),char(101),char(11),char(79),char(115),char(108), -char(97),char(115),char(104),char(97),char(99),char(117),char(116),char(101),char(11),char(111), -char(115),char(108),char(97),char(115),char(104),char(97),char(99),char(117),char(116),char(101), -char(12),char(83),char(99),char(111),char(109),char(109),char(97),char(97),char(99),char(99), -char(101),char(110),char(116),char(12),char(115),char(99),char(111),char(109),char(109),char(97), -char(97),char(99),char(99),char(101),char(110),char(116),char(10),char(99),char(105),char(114), -char(99),char(117),char(109),char(102),char(108),char(101),char(120),char(5),char(99),char(97), -char(114),char(111),char(110),char(6),char(109),char(97),char(99),char(114),char(111),char(110), -char(5),char(98),char(114),char(101),char(118),char(101),char(9),char(100),char(111),char(116), -char(97),char(99),char(99),char(101),char(110),char(116),char(4),char(114),char(105),char(110), -char(103),char(6),char(111),char(103),char(111),char(110),char(101),char(107),char(5),char(116), -char(105),char(108),char(100),char(101),char(12),char(104),char(117),char(110),char(103),char(97), -char(114),char(117),char(109),char(108),char(97),char(117),char(116),char(5),char(116),char(111), -char(110),char(111),char(115),char(13),char(100),char(105),char(101),char(114),char(101),char(115), -char(105),char(115),char(116),char(111),char(110),char(111),char(115),char(10),char(65),char(108), -char(112),char(104),char(97),char(116),char(111),char(110),char(111),char(115),char(9),char(97), -char(110),char(111),char(116),char(101),char(108),char(101),char(105),char(97),char(12),char(69), -char(112),char(115),char(105),char(108),char(111),char(110),char(116),char(111),char(110),char(111), -char(115),char(8),char(69),char(116),char(97),char(116),char(111),char(110),char(111),char(115), -char(13),char(73),char(111),char(116),char(97),char(116),char(111),char(110),char(111),char(115), -char(46),char(97),char(108),char(116),char(12),char(79),char(109),char(105),char(99),char(114), -char(111),char(110),char(116),char(111),char(110),char(111),char(115),char(12),char(85),char(112), -char(115),char(105),char(108),char(111),char(110),char(116),char(111),char(110),char(111),char(115), -char(10),char(79),char(109),char(101),char(103),char(97),char(116),char(111),char(110),char(111), -char(115),char(17),char(105),char(111),char(116),char(97),char(100),char(105),char(101),char(114), -char(101),char(115),char(105),char(115),char(116),char(111),char(110),char(111),char(115),char(5), -char(65),char(108),char(112),char(104),char(97),char(4),char(66),char(101),char(116),char(97), -char(5),char(71),char(97),char(109),char(109),char(97),char(7),char(117),char(110),char(105), -char(48),char(51),char(57),char(52),char(7),char(69),char(112),char(115),char(105),char(108), -char(111),char(110),char(4),char(90),char(101),char(116),char(97),char(3),char(69),char(116), -char(97),char(5),char(84),char(104),char(101),char(116),char(97),char(8),char(73),char(111), -char(116),char(97),char(46),char(97),char(108),char(116),char(5),char(75),char(97),char(112), -char(112),char(97),char(6),char(76),char(97),char(109),char(98),char(100),char(97),char(2), -char(77),char(117),char(2),char(78),char(117),char(2),char(88),char(105),char(7),char(79), -char(109),char(105),char(99),char(114),char(111),char(110),char(2),char(80),char(105),char(3), -char(82),char(104),char(111),char(5),char(83),char(105),char(103),char(109),char(97),char(3), -char(84),char(97),char(117),char(7),char(85),char(112),char(115),char(105),char(108),char(111), -char(110),char(3),char(80),char(104),char(105),char(3),char(67),char(104),char(105),char(3), -char(80),char(115),char(105),char(7),char(117),char(110),char(105),char(48),char(51),char(65), -char(57),char(16),char(73),char(111),char(116),char(97),char(100),char(105),char(101),char(114), -char(101),char(115),char(105),char(115),char(46),char(97),char(108),char(116),char(15),char(85), -char(112),char(115),char(105),char(108),char(111),char(110),char(100),char(105),char(101),char(114), -char(101),char(115),char(105),char(115),char(10),char(97),char(108),char(112),char(104),char(97), -char(116),char(111),char(110),char(111),char(115),char(12),char(101),char(112),char(115),char(105), -char(108),char(111),char(110),char(116),char(111),char(110),char(111),char(115),char(8),char(101), -char(116),char(97),char(116),char(111),char(110),char(111),char(115),char(9),char(105),char(111), -char(116),char(97),char(116),char(111),char(110),char(111),char(115),char(20),char(117),char(112), -char(115),char(105),char(108),char(111),char(110),char(100),char(105),char(101),char(114),char(101), -char(115),char(105),char(115),char(116),char(111),char(110),char(111),char(115),char(5),char(97), -char(108),char(112),char(104),char(97),char(4),char(98),char(101),char(116),char(97),char(5), -char(103),char(97),char(109),char(109),char(97),char(5),char(100),char(101),char(108),char(116), -char(97),char(7),char(101),char(112),char(115),char(105),char(108),char(111),char(110),char(4), -char(122),char(101),char(116),char(97),char(3),char(101),char(116),char(97),char(5),char(116), -char(104),char(101),char(116),char(97),char(4),char(105),char(111),char(116),char(97),char(5), -char(107),char(97),char(112),char(112),char(97),char(6),char(108),char(97),char(109),char(98), -char(100),char(97),char(7),char(117),char(110),char(105),char(48),char(51),char(66),char(67), -char(2),char(110),char(117),char(2),char(120),char(105),char(7),char(111),char(109),char(105), -char(99),char(114),char(111),char(110),char(2),char(112),char(105),char(3),char(114),char(104), -char(111),char(6),char(115),char(105),char(103),char(109),char(97),char(49),char(5),char(115), -char(105),char(103),char(109),char(97),char(3),char(116),char(97),char(117),char(7),char(117), -char(112),char(115),char(105),char(108),char(111),char(110),char(3),char(112),char(104),char(105), -char(3),char(99),char(104),char(105),char(3),char(112),char(115),char(105),char(5),char(111), -char(109),char(101),char(103),char(97),char(12),char(105),char(111),char(116),char(97),char(100), -char(105),char(101),char(114),char(101),char(115),char(105),char(115),char(15),char(117),char(112), -char(115),char(105),char(108),char(111),char(110),char(100),char(105),char(101),char(114),char(101), -char(115),char(105),char(115),char(12),char(111),char(109),char(105),char(99),char(114),char(111), -char(110),char(116),char(111),char(110),char(111),char(115),char(12),char(117),char(112),char(115), -char(105),char(108),char(111),char(110),char(116),char(111),char(110),char(111),char(115),char(10), -char(111),char(109),char(101),char(103),char(97),char(116),char(111),char(110),char(111),char(115), -char(9),char(97),char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(51), -char(9),char(97),char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(49), -char(9),char(97),char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(50), -char(9),char(97),char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(51), -char(9),char(97),char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(52), -char(13),char(97),char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(53), -char(46),char(97),char(108),char(116),char(13),char(97),char(102),char(105),char(105),char(49), -char(48),char(48),char(53),char(54),char(46),char(97),char(108),char(116),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(52),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(49),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(49),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(49),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(50),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(51),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(52),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(54),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(56),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(55),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(49),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(50),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(52),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(53),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(54),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(55),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(56),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(48),char(57),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(49),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(49),char(57),char(51),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(53),char(48),char(9),char(97), -char(102),char(105),char(105),char(49),char(48),char(48),char(57),char(56),char(6),char(87), -char(103),char(114),char(97),char(118),char(101),char(6),char(119),char(103),char(114),char(97), -char(118),char(101),char(6),char(87),char(97),char(99),char(117),char(116),char(101),char(6), -char(119),char(97),char(99),char(117),char(116),char(101),char(9),char(87),char(100),char(105), -char(101),char(114),char(101),char(115),char(105),char(115),char(9),char(119),char(100),char(105), -char(101),char(114),char(101),char(115),char(105),char(115),char(6),char(89),char(103),char(114), -char(97),char(118),char(101),char(6),char(121),char(103),char(114),char(97),char(118),char(101), -char(6),char(101),char(110),char(100),char(97),char(115),char(104),char(6),char(101),char(109), -char(100),char(97),char(115),char(104),char(9),char(97),char(102),char(105),char(105),char(48), -char(48),char(50),char(48),char(56),char(13),char(117),char(110),char(100),char(101),char(114), -char(115),char(99),char(111),char(114),char(101),char(100),char(98),char(108),char(9),char(113), -char(117),char(111),char(116),char(101),char(108),char(101),char(102),char(116),char(10),char(113), -char(117),char(111),char(116),char(101),char(114),char(105),char(103),char(104),char(116),char(14), -char(113),char(117),char(111),char(116),char(101),char(115),char(105),char(110),char(103),char(108), -char(98),char(97),char(115),char(101),char(13),char(113),char(117),char(111),char(116),char(101), -char(114),char(101),char(118),char(101),char(114),char(115),char(101),char(100),char(12),char(113), -char(117),char(111),char(116),char(101),char(100),char(98),char(108),char(108),char(101),char(102), -char(116),char(13),char(113),char(117),char(111),char(116),char(101),char(100),char(98),char(108), -char(114),char(105),char(103),char(104),char(116),char(12),char(113),char(117),char(111),char(116), -char(101),char(100),char(98),char(108),char(98),char(97),char(115),char(101),char(6),char(100), -char(97),char(103),char(103),char(101),char(114),char(9),char(100),char(97),char(103),char(103), -char(101),char(114),char(100),char(98),char(108),char(6),char(98),char(117),char(108),char(108), -char(101),char(116),char(8),char(101),char(108),char(108),char(105),char(112),char(115),char(105), -char(115),char(11),char(112),char(101),char(114),char(116),char(104),char(111),char(117),char(115), -char(97),char(110),char(100),char(6),char(109),char(105),char(110),char(117),char(116),char(101), -char(6),char(115),char(101),char(99),char(111),char(110),char(100),char(13),char(103),char(117), -char(105),char(108),char(115),char(105),char(110),char(103),char(108),char(108),char(101),char(102), -char(116),char(14),char(103),char(117),char(105),char(108),char(115),char(105),char(110),char(103), -char(108),char(114),char(105),char(103),char(104),char(116),char(9),char(101),char(120),char(99), -char(108),char(97),char(109),char(100),char(98),char(108),char(8),char(102),char(114),char(97), -char(99),char(116),char(105),char(111),char(110),char(9),char(110),char(115),char(117),char(112), -char(101),char(114),char(105),char(111),char(114),char(5),char(102),char(114),char(97),char(110), -char(99),char(9),char(97),char(102),char(105),char(105),char(48),char(56),char(57),char(52), -char(49),char(6),char(112),char(101),char(115),char(101),char(116),char(97),char(4),char(69), -char(117),char(114),char(111),char(9),char(97),char(102),char(105),char(105),char(54),char(49), -char(50),char(52),char(56),char(9),char(97),char(102),char(105),char(105),char(54),char(49), -char(50),char(56),char(57),char(9),char(97),char(102),char(105),char(105),char(54),char(49), -char(51),char(53),char(50),char(9),char(116),char(114),char(97),char(100),char(101),char(109), -char(97),char(114),char(107),char(5),char(79),char(109),char(101),char(103),char(97),char(9), -char(101),char(115),char(116),char(105),char(109),char(97),char(116),char(101),char(100),char(9), -char(111),char(110),char(101),char(101),char(105),char(103),char(104),char(116),char(104),char(12), -char(116),char(104),char(114),char(101),char(101),char(101),char(105),char(103),char(104),char(116), -char(104),char(115),char(11),char(102),char(105),char(118),char(101),char(101),char(105),char(103), -char(104),char(116),char(104),char(115),char(12),char(115),char(101),char(118),char(101),char(110), -char(101),char(105),char(103),char(104),char(116),char(104),char(115),char(11),char(112),char(97), -char(114),char(116),char(105),char(97),char(108),char(100),char(105),char(102),char(102),char(5), -char(68),char(101),char(108),char(116),char(97),char(7),char(112),char(114),char(111),char(100), -char(117),char(99),char(116),char(9),char(115),char(117),char(109),char(109),char(97),char(116), -char(105),char(111),char(110),char(5),char(109),char(105),char(110),char(117),char(115),char(7), -char(114),char(97),char(100),char(105),char(99),char(97),char(108),char(8),char(105),char(110), -char(102),char(105),char(110),char(105),char(116),char(121),char(8),char(105),char(110),char(116), -char(101),char(103),char(114),char(97),char(108),char(11),char(97),char(112),char(112),char(114), -char(111),char(120),char(101),char(113),char(117),char(97),char(108),char(8),char(110),char(111), -char(116),char(101),char(113),char(117),char(97),char(108),char(9),char(108),char(101),char(115), -char(115),char(101),char(113),char(117),char(97),char(108),char(12),char(103),char(114),char(101), -char(97),char(116),char(101),char(114),char(101),char(113),char(117),char(97),char(108),char(7), -char(108),char(111),char(122),char(101),char(110),char(103),char(101),char(7),char(117),char(110), -char(105),char(70),char(66),char(48),char(49),char(7),char(117),char(110),char(105),char(70), -char(66),char(48),char(50),char(13),char(99),char(121),char(114),char(105),char(108),char(108), -char(105),char(99),char(98),char(114),char(101),char(118),char(101),char(8),char(100),char(111), -char(116),char(108),char(101),char(115),char(115),char(106),char(16),char(99),char(97),char(114), -char(111),char(110),char(99),char(111),char(109),char(109),char(97),char(97),char(99),char(99), -char(101),char(110),char(116),char(11),char(99),char(111),char(109),char(109),char(97),char(97), -char(99),char(99),char(101),char(110),char(116),char(17),char(99),char(111),char(109),char(109), -char(97),char(97),char(99),char(99),char(101),char(110),char(116),char(114),char(111),char(116), -char(97),char(116),char(101),char(12),char(122),char(101),char(114),char(111),char(115),char(117), -char(112),char(101),char(114),char(105),char(111),char(114),char(12),char(102),char(111),char(117), -char(114),char(115),char(117),char(112),char(101),char(114),char(105),char(111),char(114),char(12), -char(102),char(105),char(118),char(101),char(115),char(117),char(112),char(101),char(114),char(105), -char(111),char(114),char(11),char(115),char(105),char(120),char(115),char(117),char(112),char(101), -char(114),char(105),char(111),char(114),char(13),char(115),char(101),char(118),char(101),char(110), -char(115),char(117),char(112),char(101),char(114),char(105),char(111),char(114),char(13),char(101), -char(105),char(103),char(104),char(116),char(115),char(117),char(112),char(101),char(114),char(105), -char(111),char(114),char(12),char(110),char(105),char(110),char(101),char(115),char(117),char(112), -char(101),char(114),char(105),char(111),char(114),char(7),char(117),char(110),char(105),char(50), -char(48),char(48),char(48),char(7),char(117),char(110),char(105),char(50),char(48),char(48), -char(49),char(7),char(117),char(110),char(105),char(50),char(48),char(48),char(50),char(7), -char(117),char(110),char(105),char(50),char(48),char(48),char(51),char(7),char(117),char(110), -char(105),char(50),char(48),char(48),char(52),char(7),char(117),char(110),char(105),char(50), -char(48),char(48),char(53),char(7),char(117),char(110),char(105),char(50),char(48),char(48), -char(54),char(7),char(117),char(110),char(105),char(50),char(48),char(48),char(55),char(7), -char(117),char(110),char(105),char(50),char(48),char(48),char(56),char(7),char(117),char(110), -char(105),char(50),char(48),char(48),char(57),char(7),char(117),char(110),char(105),char(50), -char(48),char(48),char(65),char(7),char(117),char(110),char(105),char(50),char(48),char(48), -char(66),char(7),char(117),char(110),char(105),char(70),char(69),char(70),char(70),char(7), -char(117),char(110),char(105),char(70),char(70),char(70),char(67),char(7),char(117),char(110), -char(105),char(70),char(70),char(70),char(68),char(7),char(117),char(110),char(105),char(48), -char(49),char(70),char(48),char(7),char(117),char(110),char(105),char(48),char(50),char(66), -char(67),char(7),char(117),char(110),char(105),char(48),char(51),char(68),char(49),char(7), -char(117),char(110),char(105),char(48),char(51),char(68),char(50),char(7),char(117),char(110), -char(105),char(48),char(51),char(68),char(54),char(7),char(117),char(110),char(105),char(49), -char(69),char(51),char(69),char(7),char(117),char(110),char(105),char(49),char(69),char(51), -char(70),char(7),char(117),char(110),char(105),char(49),char(69),char(48),char(48),char(7), -char(117),char(110),char(105),char(49),char(69),char(48),char(49),char(7),char(117),char(110), -char(105),char(49),char(70),char(52),char(68),char(7),char(117),char(110),char(105),char(48), -char(50),char(70),char(51),char(9),char(100),char(97),char(115),char(105),char(97),char(111), -char(120),char(105),char(97),char(7),char(117),char(110),char(105),char(70),char(66),char(48), -char(51),char(7),char(117),char(110),char(105),char(70),char(66),char(48),char(52),char(5), -char(79),char(104),char(111),char(114),char(110),char(5),char(111),char(104),char(111),char(114), -char(110),char(5),char(85),char(104),char(111),char(114),char(110),char(5),char(117),char(104), -char(111),char(114),char(110),char(7),char(117),char(110),char(105),char(48),char(51),char(48), -char(48),char(7),char(117),char(110),char(105),char(48),char(51),char(48),char(49),char(7), -char(117),char(110),char(105),char(48),char(51),char(48),char(51),char(4),char(104),char(111), -char(111),char(107),char(8),char(100),char(111),char(116),char(98),char(101),char(108),char(111), -char(119),char(7),char(117),char(110),char(105),char(48),char(52),char(48),char(48),char(7), -char(117),char(110),char(105),char(48),char(52),char(48),char(68),char(7),char(117),char(110), -char(105),char(48),char(52),char(53),char(48),char(7),char(117),char(110),char(105),char(48), -char(52),char(53),char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(54), -char(48),char(7),char(117),char(110),char(105),char(48),char(52),char(54),char(49),char(7), -char(117),char(110),char(105),char(48),char(52),char(54),char(50),char(7),char(117),char(110), -char(105),char(48),char(52),char(54),char(51),char(7),char(117),char(110),char(105),char(48), -char(52),char(54),char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(54), -char(53),char(7),char(117),char(110),char(105),char(48),char(52),char(54),char(54),char(7), -char(117),char(110),char(105),char(48),char(52),char(54),char(55),char(7),char(117),char(110), -char(105),char(48),char(52),char(54),char(56),char(7),char(117),char(110),char(105),char(48), -char(52),char(54),char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(54), -char(65),char(7),char(117),char(110),char(105),char(48),char(52),char(54),char(66),char(7), -char(117),char(110),char(105),char(48),char(52),char(54),char(67),char(7),char(117),char(110), -char(105),char(48),char(52),char(54),char(68),char(7),char(117),char(110),char(105),char(48), -char(52),char(54),char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(54), -char(70),char(7),char(117),char(110),char(105),char(48),char(52),char(55),char(48),char(7), -char(117),char(110),char(105),char(48),char(52),char(55),char(49),char(7),char(117),char(110), -char(105),char(48),char(52),char(55),char(50),char(7),char(117),char(110),char(105),char(48), -char(52),char(55),char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(55), -char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(55),char(53),char(7), -char(117),char(110),char(105),char(48),char(52),char(55),char(54),char(7),char(117),char(110), -char(105),char(48),char(52),char(55),char(55),char(7),char(117),char(110),char(105),char(48), -char(52),char(55),char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(55), -char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(55),char(65),char(7), -char(117),char(110),char(105),char(48),char(52),char(55),char(66),char(7),char(117),char(110), -char(105),char(48),char(52),char(55),char(67),char(7),char(117),char(110),char(105),char(48), -char(52),char(55),char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(55), -char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(55),char(70),char(7), -char(117),char(110),char(105),char(48),char(52),char(56),char(48),char(7),char(117),char(110), -char(105),char(48),char(52),char(56),char(49),char(7),char(117),char(110),char(105),char(48), -char(52),char(56),char(50),char(7),char(117),char(110),char(105),char(48),char(52),char(56), -char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(56),char(52),char(7), -char(117),char(110),char(105),char(48),char(52),char(56),char(53),char(7),char(117),char(110), -char(105),char(48),char(52),char(56),char(54),char(7),char(117),char(110),char(105),char(48), -char(52),char(56),char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(56), -char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(56),char(65),char(7), -char(117),char(110),char(105),char(48),char(52),char(56),char(66),char(7),char(117),char(110), -char(105),char(48),char(52),char(56),char(67),char(7),char(117),char(110),char(105),char(48), -char(52),char(56),char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(56), -char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(56),char(70),char(7), -char(117),char(110),char(105),char(48),char(52),char(57),char(50),char(7),char(117),char(110), -char(105),char(48),char(52),char(57),char(51),char(7),char(117),char(110),char(105),char(48), -char(52),char(57),char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(57), -char(53),char(7),char(117),char(110),char(105),char(48),char(52),char(57),char(54),char(7), -char(117),char(110),char(105),char(48),char(52),char(57),char(55),char(7),char(117),char(110), -char(105),char(48),char(52),char(57),char(56),char(7),char(117),char(110),char(105),char(48), -char(52),char(57),char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(57), -char(65),char(7),char(117),char(110),char(105),char(48),char(52),char(57),char(66),char(7), -char(117),char(110),char(105),char(48),char(52),char(57),char(67),char(7),char(117),char(110), -char(105),char(48),char(52),char(57),char(68),char(7),char(117),char(110),char(105),char(48), -char(52),char(57),char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(57), -char(70),char(7),char(117),char(110),char(105),char(48),char(52),char(65),char(48),char(7), -char(117),char(110),char(105),char(48),char(52),char(65),char(49),char(7),char(117),char(110), -char(105),char(48),char(52),char(65),char(50),char(7),char(117),char(110),char(105),char(48), -char(52),char(65),char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(65), -char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(65),char(53),char(7), -char(117),char(110),char(105),char(48),char(52),char(65),char(54),char(7),char(117),char(110), -char(105),char(48),char(52),char(65),char(55),char(7),char(117),char(110),char(105),char(48), -char(52),char(65),char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(65), -char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(65),char(65),char(7), -char(117),char(110),char(105),char(48),char(52),char(65),char(66),char(7),char(117),char(110), -char(105),char(48),char(52),char(65),char(67),char(7),char(117),char(110),char(105),char(48), -char(52),char(65),char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(65), -char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(65),char(70),char(7), -char(117),char(110),char(105),char(48),char(52),char(66),char(48),char(7),char(117),char(110), -char(105),char(48),char(52),char(66),char(49),char(7),char(117),char(110),char(105),char(48), -char(52),char(66),char(50),char(7),char(117),char(110),char(105),char(48),char(52),char(66), -char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(66),char(52),char(7), -char(117),char(110),char(105),char(48),char(52),char(66),char(53),char(7),char(117),char(110), -char(105),char(48),char(52),char(66),char(54),char(7),char(117),char(110),char(105),char(48), -char(52),char(66),char(55),char(7),char(117),char(110),char(105),char(48),char(52),char(66), -char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(66),char(57),char(7), -char(117),char(110),char(105),char(48),char(52),char(66),char(65),char(7),char(117),char(110), -char(105),char(48),char(52),char(66),char(66),char(7),char(117),char(110),char(105),char(48), -char(52),char(66),char(67),char(7),char(117),char(110),char(105),char(48),char(52),char(66), -char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(66),char(69),char(7), -char(117),char(110),char(105),char(48),char(52),char(66),char(70),char(11),char(117),char(110), -char(105),char(48),char(52),char(67),char(48),char(46),char(97),char(108),char(116),char(7), -char(117),char(110),char(105),char(48),char(52),char(67),char(49),char(7),char(117),char(110), -char(105),char(48),char(52),char(67),char(50),char(7),char(117),char(110),char(105),char(48), -char(52),char(67),char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(67), -char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(67),char(53),char(7), -char(117),char(110),char(105),char(48),char(52),char(67),char(54),char(7),char(117),char(110), -char(105),char(48),char(52),char(67),char(55),char(7),char(117),char(110),char(105),char(48), -char(52),char(67),char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(67), -char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(67),char(65),char(7), -char(117),char(110),char(105),char(48),char(52),char(67),char(66),char(7),char(117),char(110), -char(105),char(48),char(52),char(67),char(67),char(7),char(117),char(110),char(105),char(48), -char(52),char(67),char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(67), -char(69),char(11),char(117),char(110),char(105),char(48),char(52),char(67),char(70),char(46), -char(97),char(108),char(116),char(7),char(117),char(110),char(105),char(48),char(52),char(68), -char(48),char(7),char(117),char(110),char(105),char(48),char(52),char(68),char(49),char(7), -char(117),char(110),char(105),char(48),char(52),char(68),char(50),char(7),char(117),char(110), -char(105),char(48),char(52),char(68),char(51),char(7),char(117),char(110),char(105),char(48), -char(52),char(68),char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(68), -char(53),char(7),char(117),char(110),char(105),char(48),char(52),char(68),char(54),char(7), -char(117),char(110),char(105),char(48),char(52),char(68),char(55),char(7),char(117),char(110), -char(105),char(48),char(52),char(68),char(56),char(7),char(117),char(110),char(105),char(48), -char(52),char(68),char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(68), -char(65),char(7),char(117),char(110),char(105),char(48),char(52),char(68),char(66),char(7), -char(117),char(110),char(105),char(48),char(52),char(68),char(67),char(7),char(117),char(110), -char(105),char(48),char(52),char(68),char(68),char(7),char(117),char(110),char(105),char(48), -char(52),char(68),char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(68), -char(70),char(7),char(117),char(110),char(105),char(48),char(52),char(69),char(48),char(7), -char(117),char(110),char(105),char(48),char(52),char(69),char(49),char(7),char(117),char(110), -char(105),char(48),char(52),char(69),char(50),char(7),char(117),char(110),char(105),char(48), -char(52),char(69),char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(69), -char(52),char(7),char(117),char(110),char(105),char(48),char(52),char(69),char(53),char(7), -char(117),char(110),char(105),char(48),char(52),char(69),char(54),char(7),char(117),char(110), -char(105),char(48),char(52),char(69),char(55),char(7),char(117),char(110),char(105),char(48), -char(52),char(69),char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(69), -char(57),char(7),char(117),char(110),char(105),char(48),char(52),char(69),char(65),char(7), -char(117),char(110),char(105),char(48),char(52),char(69),char(66),char(7),char(117),char(110), -char(105),char(48),char(52),char(69),char(67),char(7),char(117),char(110),char(105),char(48), -char(52),char(69),char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(69), -char(69),char(7),char(117),char(110),char(105),char(48),char(52),char(69),char(70),char(7), -char(117),char(110),char(105),char(48),char(52),char(70),char(48),char(7),char(117),char(110), -char(105),char(48),char(52),char(70),char(49),char(7),char(117),char(110),char(105),char(48), -char(52),char(70),char(50),char(7),char(117),char(110),char(105),char(48),char(52),char(70), -char(51),char(7),char(117),char(110),char(105),char(48),char(52),char(70),char(52),char(7), -char(117),char(110),char(105),char(48),char(52),char(70),char(53),char(7),char(117),char(110), -char(105),char(48),char(52),char(70),char(54),char(7),char(117),char(110),char(105),char(48), -char(52),char(70),char(55),char(7),char(117),char(110),char(105),char(48),char(52),char(70), -char(56),char(7),char(117),char(110),char(105),char(48),char(52),char(70),char(57),char(7), -char(117),char(110),char(105),char(48),char(52),char(70),char(65),char(7),char(117),char(110), -char(105),char(48),char(52),char(70),char(66),char(7),char(117),char(110),char(105),char(48), -char(52),char(70),char(67),char(7),char(117),char(110),char(105),char(48),char(52),char(70), -char(68),char(7),char(117),char(110),char(105),char(48),char(52),char(70),char(69),char(7), -char(117),char(110),char(105),char(48),char(52),char(70),char(70),char(7),char(117),char(110), -char(105),char(48),char(53),char(48),char(48),char(7),char(117),char(110),char(105),char(48), -char(53),char(48),char(49),char(7),char(117),char(110),char(105),char(48),char(53),char(48), -char(50),char(7),char(117),char(110),char(105),char(48),char(53),char(48),char(51),char(7), -char(117),char(110),char(105),char(48),char(53),char(48),char(52),char(7),char(117),char(110), -char(105),char(48),char(53),char(48),char(53),char(7),char(117),char(110),char(105),char(48), -char(53),char(48),char(54),char(7),char(117),char(110),char(105),char(48),char(53),char(48), -char(55),char(7),char(117),char(110),char(105),char(48),char(53),char(48),char(56),char(7), -char(117),char(110),char(105),char(48),char(53),char(48),char(57),char(7),char(117),char(110), -char(105),char(48),char(53),char(48),char(65),char(7),char(117),char(110),char(105),char(48), -char(53),char(48),char(66),char(7),char(117),char(110),char(105),char(48),char(53),char(48), -char(67),char(7),char(117),char(110),char(105),char(48),char(53),char(48),char(68),char(7), -char(117),char(110),char(105),char(48),char(53),char(48),char(69),char(7),char(117),char(110), -char(105),char(48),char(53),char(48),char(70),char(7),char(117),char(110),char(105),char(48), -char(53),char(49),char(48),char(7),char(117),char(110),char(105),char(48),char(53),char(49), -char(49),char(7),char(117),char(110),char(105),char(48),char(53),char(49),char(50),char(7), -char(117),char(110),char(105),char(48),char(53),char(49),char(51),char(7),char(117),char(110), -char(105),char(49),char(69),char(65),char(48),char(7),char(117),char(110),char(105),char(49), -char(69),char(65),char(49),char(7),char(117),char(110),char(105),char(49),char(69),char(65), -char(50),char(7),char(117),char(110),char(105),char(49),char(69),char(65),char(51),char(7), -char(117),char(110),char(105),char(49),char(69),char(65),char(52),char(7),char(117),char(110), -char(105),char(49),char(69),char(65),char(53),char(7),char(117),char(110),char(105),char(49), -char(69),char(65),char(54),char(7),char(117),char(110),char(105),char(49),char(69),char(65), -char(55),char(7),char(117),char(110),char(105),char(49),char(69),char(65),char(56),char(7), -char(117),char(110),char(105),char(49),char(69),char(65),char(57),char(7),char(117),char(110), -char(105),char(49),char(69),char(65),char(65),char(7),char(117),char(110),char(105),char(49), -char(69),char(65),char(66),char(7),char(117),char(110),char(105),char(49),char(69),char(65), -char(67),char(7),char(117),char(110),char(105),char(49),char(69),char(65),char(68),char(7), -char(117),char(110),char(105),char(49),char(69),char(65),char(69),char(7),char(117),char(110), -char(105),char(49),char(69),char(65),char(70),char(7),char(117),char(110),char(105),char(49), -char(69),char(66),char(48),char(7),char(117),char(110),char(105),char(49),char(69),char(66), -char(49),char(7),char(117),char(110),char(105),char(49),char(69),char(66),char(50),char(7), -char(117),char(110),char(105),char(49),char(69),char(66),char(51),char(7),char(117),char(110), -char(105),char(49),char(69),char(66),char(52),char(7),char(117),char(110),char(105),char(49), -char(69),char(66),char(53),char(7),char(117),char(110),char(105),char(49),char(69),char(66), -char(54),char(7),char(117),char(110),char(105),char(49),char(69),char(66),char(55),char(7), -char(117),char(110),char(105),char(49),char(69),char(66),char(56),char(7),char(117),char(110), -char(105),char(49),char(69),char(66),char(57),char(7),char(117),char(110),char(105),char(49), -char(69),char(66),char(65),char(7),char(117),char(110),char(105),char(49),char(69),char(66), -char(66),char(7),char(117),char(110),char(105),char(49),char(69),char(66),char(67),char(7), -char(117),char(110),char(105),char(49),char(69),char(66),char(68),char(7),char(117),char(110), -char(105),char(49),char(69),char(66),char(69),char(7),char(117),char(110),char(105),char(49), -char(69),char(66),char(70),char(7),char(117),char(110),char(105),char(49),char(69),char(67), -char(48),char(7),char(117),char(110),char(105),char(49),char(69),char(67),char(49),char(7), -char(117),char(110),char(105),char(49),char(69),char(67),char(50),char(7),char(117),char(110), -char(105),char(49),char(69),char(67),char(51),char(7),char(117),char(110),char(105),char(49), -char(69),char(67),char(52),char(7),char(117),char(110),char(105),char(49),char(69),char(67), -char(53),char(7),char(117),char(110),char(105),char(49),char(69),char(67),char(54),char(7), -char(117),char(110),char(105),char(49),char(69),char(67),char(55),char(11),char(117),char(110), -char(105),char(49),char(69),char(67),char(56),char(46),char(97),char(108),char(116),char(7), -char(117),char(110),char(105),char(49),char(69),char(67),char(57),char(11),char(117),char(110), -char(105),char(49),char(69),char(67),char(65),char(46),char(97),char(108),char(116),char(7), -char(117),char(110),char(105),char(49),char(69),char(67),char(66),char(7),char(117),char(110), -char(105),char(49),char(69),char(67),char(67),char(7),char(117),char(110),char(105),char(49), -char(69),char(67),char(68),char(7),char(117),char(110),char(105),char(49),char(69),char(67), -char(69),char(7),char(117),char(110),char(105),char(49),char(69),char(67),char(70),char(7), -char(117),char(110),char(105),char(49),char(69),char(68),char(48),char(7),char(117),char(110), -char(105),char(49),char(69),char(68),char(49),char(7),char(117),char(110),char(105),char(49), -char(69),char(68),char(50),char(7),char(117),char(110),char(105),char(49),char(69),char(68), -char(51),char(7),char(117),char(110),char(105),char(49),char(69),char(68),char(52),char(7), -char(117),char(110),char(105),char(49),char(69),char(68),char(53),char(7),char(117),char(110), -char(105),char(49),char(69),char(68),char(54),char(7),char(117),char(110),char(105),char(49), -char(69),char(68),char(55),char(7),char(117),char(110),char(105),char(49),char(69),char(68), -char(56),char(7),char(117),char(110),char(105),char(49),char(69),char(68),char(57),char(7), -char(117),char(110),char(105),char(49),char(69),char(68),char(65),char(7),char(117),char(110), -char(105),char(49),char(69),char(68),char(66),char(7),char(117),char(110),char(105),char(49), -char(69),char(68),char(67),char(7),char(117),char(110),char(105),char(49),char(69),char(68), -char(68),char(7),char(117),char(110),char(105),char(49),char(69),char(68),char(69),char(7), -char(117),char(110),char(105),char(49),char(69),char(68),char(70),char(7),char(117),char(110), -char(105),char(49),char(69),char(69),char(48),char(7),char(117),char(110),char(105),char(49), -char(69),char(69),char(49),char(7),char(117),char(110),char(105),char(49),char(69),char(69), -char(50),char(7),char(117),char(110),char(105),char(49),char(69),char(69),char(51),char(7), -char(117),char(110),char(105),char(49),char(69),char(69),char(52),char(7),char(117),char(110), -char(105),char(49),char(69),char(69),char(53),char(7),char(117),char(110),char(105),char(49), -char(69),char(69),char(54),char(7),char(117),char(110),char(105),char(49),char(69),char(69), -char(55),char(7),char(117),char(110),char(105),char(49),char(69),char(69),char(56),char(7), -char(117),char(110),char(105),char(49),char(69),char(69),char(57),char(7),char(117),char(110), -char(105),char(49),char(69),char(69),char(65),char(7),char(117),char(110),char(105),char(49), -char(69),char(69),char(66),char(7),char(117),char(110),char(105),char(49),char(69),char(69), -char(67),char(7),char(117),char(110),char(105),char(49),char(69),char(69),char(68),char(7), -char(117),char(110),char(105),char(49),char(69),char(69),char(69),char(7),char(117),char(110), -char(105),char(49),char(69),char(69),char(70),char(7),char(117),char(110),char(105),char(49), -char(69),char(70),char(48),char(7),char(117),char(110),char(105),char(49),char(69),char(70), -char(49),char(7),char(117),char(110),char(105),char(49),char(69),char(70),char(52),char(7), -char(117),char(110),char(105),char(49),char(69),char(70),char(53),char(7),char(117),char(110), -char(105),char(49),char(69),char(70),char(54),char(7),char(117),char(110),char(105),char(49), -char(69),char(70),char(55),char(7),char(117),char(110),char(105),char(49),char(69),char(70), -char(56),char(7),char(117),char(110),char(105),char(49),char(69),char(70),char(57),char(7), -char(117),char(110),char(105),char(50),char(48),char(65),char(66),char(7),char(117),char(110), -char(105),char(48),char(51),char(48),char(70),char(19),char(99),char(105),char(114),char(99), -char(117),char(109),char(102),char(108),char(101),char(120),char(97),char(99),char(117),char(116), -char(101),char(99),char(111),char(109),char(98),char(19),char(99),char(105),char(114),char(99), -char(117),char(109),char(102),char(108),char(101),char(120),char(103),char(114),char(97),char(118), -char(101),char(99),char(111),char(109),char(98),char(18),char(99),char(105),char(114),char(99), -char(117),char(109),char(102),char(108),char(101),char(120),char(104),char(111),char(111),char(107), -char(99),char(111),char(109),char(98),char(19),char(99),char(105),char(114),char(99),char(117), -char(109),char(102),char(108),char(101),char(120),char(116),char(105),char(108),char(100),char(101), -char(99),char(111),char(109),char(98),char(14),char(98),char(114),char(101),char(118),char(101), -char(97),char(99),char(117),char(116),char(101),char(99),char(111),char(109),char(98),char(14), -char(98),char(114),char(101),char(118),char(101),char(103),char(114),char(97),char(118),char(101), -char(99),char(111),char(109),char(98),char(13),char(98),char(114),char(101),char(118),char(101), -char(104),char(111),char(111),char(107),char(99),char(111),char(109),char(98),char(14),char(98), -char(114),char(101),char(118),char(101),char(116),char(105),char(108),char(100),char(101),char(99), -char(111),char(109),char(98),char(16),char(99),char(121),char(114),char(105),char(108),char(108), -char(105),char(99),char(104),char(111),char(111),char(107),char(108),char(101),char(102),char(116), -char(17),char(99),char(121),char(114),char(105),char(108),char(108),char(105),char(99),char(98), -char(105),char(103),char(104),char(111),char(111),char(107),char(85),char(67),char(17),char(99), -char(121),char(114),char(105),char(108),char(108),char(105),char(99),char(98),char(105),char(103), -char(104),char(111),char(111),char(107),char(76),char(67),char(8),char(111),char(110),char(101), -char(46),char(112),char(110),char(117),char(109),char(7),char(122),char(101),char(114),char(111), -char(46),char(111),char(115),char(6),char(111),char(110),char(101),char(46),char(111),char(115), -char(6),char(116),char(119),char(111),char(46),char(111),char(115),char(8),char(116),char(104), -char(114),char(101),char(101),char(46),char(111),char(115),char(7),char(102),char(111),char(117), -char(114),char(46),char(111),char(115),char(7),char(102),char(105),char(118),char(101),char(46), -char(111),char(115),char(6),char(115),char(105),char(120),char(46),char(111),char(115),char(8), -char(115),char(101),char(118),char(101),char(110),char(46),char(111),char(115),char(8),char(101), -char(105),char(103),char(104),char(116),char(46),char(111),char(115),char(7),char(110),char(105), -char(110),char(101),char(46),char(111),char(115),char(2),char(102),char(102),char(7),char(117), -char(110),char(105),char(50),char(49),char(50),char(48),char(8),char(84),char(99),char(101), -char(100),char(105),char(108),char(108),char(97),char(8),char(116),char(99),char(101),char(100), -char(105),char(108),char(108),char(97),char(5),char(103),char(46),char(97),char(108),char(116), -char(15),char(103),char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108), -char(101),char(120),char(46),char(97),char(108),char(116),char(10),char(103),char(98),char(114), -char(101),char(118),char(101),char(46),char(97),char(108),char(116),char(8),char(103),char(100), -char(111),char(116),char(46),char(97),char(108),char(116),char(16),char(103),char(99),char(111), -char(109),char(109),char(97),char(97),char(99),char(99),char(101),char(110),char(116),char(46), -char(97),char(108),char(116),char(1),char(73),char(6),char(73),char(103),char(114),char(97), -char(118),char(101),char(6),char(73),char(97),char(99),char(117),char(116),char(101),char(11), -char(73),char(99),char(105),char(114),char(99),char(117),char(109),char(102),char(108),char(101), -char(120),char(9),char(73),char(100),char(105),char(101),char(114),char(101),char(115),char(105), -char(115),char(6),char(73),char(116),char(105),char(108),char(100),char(101),char(7),char(73), -char(109),char(97),char(99),char(114),char(111),char(110),char(6),char(73),char(98),char(114), -char(101),char(118),char(101),char(7),char(73),char(111),char(103),char(111),char(110),char(101), -char(107),char(10),char(73),char(100),char(111),char(116),char(97),char(99),char(99),char(101), -char(110),char(116),char(2),char(73),char(74),char(9),char(73),char(111),char(116),char(97), -char(116),char(111),char(110),char(111),char(115),char(4),char(73),char(111),char(116),char(97), -char(12),char(73),char(111),char(116),char(97),char(100),char(105),char(101),char(114),char(101), -char(115),char(105),char(115),char(9),char(97),char(102),char(105),char(105),char(49),char(48), -char(48),char(53),char(53),char(9),char(97),char(102),char(105),char(105),char(49),char(48), -char(48),char(53),char(54),char(7),char(117),char(110),char(105),char(48),char(52),char(67), -char(48),char(7),char(117),char(110),char(105),char(48),char(52),char(67),char(70),char(7), -char(117),char(110),char(105),char(49),char(69),char(67),char(56),char(7),char(117),char(110), -char(105),char(49),char(69),char(67),char(65),char(0),char(0),char(1),char(0),char(3), -char(0),char(8),char(0),char(10),char(0),char(13),char(0),char(7),char(255),char(255), -char(0),char(15),char(0),char(1),char(0),char(0),char(0),char(12),char(0),char(0), -char(0),char(22),char(0),char(0),char(0),char(2),char(0),char(1),char(0),char(0), -char(3),char(169),char(0),char(1),char(0),char(4),char(0),char(0),char(0),char(1), -char(0),char(0),char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(10), -char(0),char(52),char(0),char(54),char(0),char(1),char(108),char(97),char(116),char(110), -char(0),char(8),char(0),char(16),char(0),char(2),char(77),char(79),char(76),char(32), -char(0),char(22),char(82),char(79),char(77),char(32),char(0),char(28),char(0),char(0), -char(255),char(255),char(0),char(0),char(0),char(0),char(255),char(255),char(0),char(0), -char(0),char(0),char(255),char(255),char(0),char(0),char(0),char(0),char(0),char(0), -char(0),char(1),char(0),char(0),char(0),char(10),char(0),char(110),char(1),char(228), -char(0),char(1),char(108),char(97),char(116),char(110),char(0),char(8),char(0),char(16), -char(0),char(2),char(77),char(79),char(76),char(32),char(0),char(40),char(82),char(79), -char(77),char(32),char(0),char(66),char(0),char(0),char(255),char(255),char(0),char(9), -char(0),char(3),char(0),char(8),char(0),char(11),char(0),char(0),char(0),char(14), -char(0),char(17),char(0),char(20),char(0),char(23),char(0),char(26),char(0),char(0), -char(255),char(255),char(0),char(10),char(0),char(4),char(0),char(6),char(0),char(9), -char(0),char(12),char(0),char(1),char(0),char(15),char(0),char(18),char(0),char(21), -char(0),char(24),char(0),char(27),char(0),char(0),char(255),char(255),char(0),char(10), -char(0),char(5),char(0),char(7),char(0),char(10),char(0),char(13),char(0),char(2), -char(0),char(16),char(0),char(19),char(0),char(22),char(0),char(25),char(0),char(28), -char(0),char(29),char(108),char(105),char(103),char(97),char(0),char(176),char(108),char(105), -char(103),char(97),char(0),char(182),char(108),char(105),char(103),char(97),char(0),char(188), -char(108),char(110),char(117),char(109),char(0),char(194),char(108),char(110),char(117),char(109), -char(0),char(200),char(108),char(110),char(117),char(109),char(0),char(206),char(108),char(111), -char(99),char(108),char(0),char(212),char(108),char(111),char(99),char(108),char(0),char(218), -char(111),char(110),char(117),char(109),char(0),char(224),char(111),char(110),char(117),char(109), -char(0),char(232),char(111),char(110),char(117),char(109),char(0),char(240),char(112),char(110), -char(117),char(109),char(0),char(248),char(112),char(110),char(117),char(109),char(0),char(254), -char(112),char(110),char(117),char(109),char(1),char(4),char(115),char(97),char(108),char(116), -char(1),char(10),char(115),char(97),char(108),char(116),char(1),char(18),char(115),char(97), -char(108),char(116),char(1),char(26),char(115),char(115),char(48),char(49),char(1),char(34), -char(115),char(115),char(48),char(49),char(1),char(42),char(115),char(115),char(48),char(49), -char(1),char(50),char(115),char(115),char(48),char(50),char(1),char(58),char(115),char(115), -char(48),char(50),char(1),char(64),char(115),char(115),char(48),char(50),char(1),char(70), -char(115),char(115),char(48),char(51),char(1),char(76),char(115),char(115),char(48),char(51), -char(1),char(82),char(115),char(115),char(48),char(51),char(1),char(88),char(116),char(110), -char(117),char(109),char(1),char(94),char(116),char(110),char(117),char(109),char(1),char(102), -char(116),char(110),char(117),char(109),char(1),char(110),char(0),char(0),char(0),char(1), -char(0),char(9),char(0),char(0),char(0),char(1),char(0),char(9),char(0),char(0), -char(0),char(1),char(0),char(9),char(0),char(0),char(0),char(1),char(0),char(7), -char(0),char(0),char(0),char(1),char(0),char(7),char(0),char(0),char(0),char(1), -char(0),char(7),char(0),char(0),char(0),char(1),char(0),char(8),char(0),char(0), -char(0),char(1),char(0),char(8),char(0),char(0),char(0),char(2),char(0),char(2), -char(0),char(3),char(0),char(0),char(0),char(2),char(0),char(2),char(0),char(3), -char(0),char(0),char(0),char(2),char(0),char(2),char(0),char(3),char(0),char(0), -char(0),char(1),char(0),char(4),char(0),char(0),char(0),char(1),char(0),char(4), -char(0),char(0),char(0),char(1),char(0),char(4),char(0),char(0),char(0),char(2), -char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(2),char(0),char(0), -char(0),char(1),char(0),char(0),char(0),char(2),char(0),char(0),char(0),char(1), -char(0),char(0),char(0),char(2),char(0),char(0),char(0),char(1),char(0),char(0), -char(0),char(2),char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(2), -char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(1),char(0),char(0), -char(0),char(0),char(0),char(1),char(0),char(0),char(0),char(0),char(0),char(1), -char(0),char(0),char(0),char(0),char(0),char(1),char(0),char(1),char(0),char(0), -char(0),char(1),char(0),char(1),char(0),char(0),char(0),char(1),char(0),char(1), -char(0),char(0),char(0),char(2),char(0),char(5),char(0),char(6),char(0),char(0), -char(0),char(2),char(0),char(5),char(0),char(6),char(0),char(0),char(0),char(2), -char(0),char(5),char(0),char(6),char(0),char(10),char(0),char(22),char(0),char(30), -char(0),char(38),char(0),char(46),char(0),char(54),char(0),char(62),char(0),char(70), -char(0),char(78),char(0),char(86),char(0),char(94),char(0),char(1),char(0),char(0), -char(0),char(1),char(0),char(80),char(0),char(1),char(0),char(0),char(0),char(1), -char(0),char(122),char(0),char(1),char(0),char(0),char(0),char(1),char(0),char(170), -char(0),char(1),char(0),char(0),char(0),char(1),char(0),char(198),char(0),char(1), -char(0),char(0),char(0),char(1),char(0),char(238),char(0),char(1),char(0),char(0), -char(0),char(1),char(0),char(244),char(0),char(1),char(0),char(0),char(0),char(1), -char(1),char(16),char(0),char(1),char(0),char(0),char(0),char(1),char(1),char(22), -char(0),char(1),char(0),char(0),char(0),char(1),char(1),char(50),char(0),char(4), -char(0),char(0),char(0),char(1),char(1),char(72),char(0),char(2),char(0),char(16), -char(0),char(5),char(3),char(145),char(3),char(146),char(3),char(147),char(3),char(148), -char(3),char(149),char(0),char(2),char(0),char(5),char(0),char(74),char(0),char(74), -char(0),char(0),char(0),char(223),char(0),char(223),char(0),char(1),char(0),char(225), -char(0),char(225),char(0),char(2),char(0),char(227),char(0),char(227),char(0),char(3), -char(0),char(229),char(0),char(229),char(0),char(4),char(0),char(2),char(0),char(46), -char(0),char(20),char(0),char(44),char(0),char(142),char(0),char(143),char(0),char(144), -char(0),char(145),char(0),char(234),char(0),char(236),char(0),char(238),char(0),char(240), -char(0),char(242),char(0),char(244),char(1),char(90),char(1),char(103),char(1),char(119), -char(1),char(161),char(1),char(162),char(2),char(201),char(2),char(216),char(3),char(69), -char(3),char(71),char(0),char(2),char(0),char(1),char(3),char(150),char(3),char(169), -char(0),char(0),char(0),char(2),char(0),char(26),char(0),char(10),char(3),char(131), -char(3),char(132),char(3),char(133),char(3),char(134),char(3),char(135),char(3),char(136), -char(3),char(137),char(3),char(138),char(3),char(139),char(3),char(140),char(0),char(2), -char(0),char(1),char(0),char(19),char(0),char(28),char(0),char(0),char(0),char(2), -char(0),char(26),char(0),char(10),char(3),char(131),char(3),char(133),char(3),char(134), -char(3),char(135),char(3),char(136),char(3),char(137),char(3),char(138),char(3),char(139), -char(3),char(140),char(3),char(132),char(0),char(2),char(0),char(3),char(0),char(19), -char(0),char(19),char(0),char(0),char(0),char(21),char(0),char(28),char(0),char(1), -char(3),char(130),char(3),char(130),char(0),char(9),char(0),char(2),char(0),char(8), -char(0),char(1),char(3),char(130),char(0),char(1),char(0),char(1),char(0),char(20), -char(0),char(2),char(0),char(26),char(0),char(10),char(0),char(19),char(0),char(20), -char(0),char(21),char(0),char(22),char(0),char(23),char(0),char(24),char(0),char(25), -char(0),char(26),char(0),char(27),char(0),char(28),char(0),char(2),char(0),char(1), -char(3),char(131),char(3),char(140),char(0),char(0),char(0),char(2),char(0),char(8), -char(0),char(1),char(0),char(20),char(0),char(1),char(0),char(1),char(3),char(130), -char(0),char(2),char(0),char(26),char(0),char(10),char(0),char(19),char(3),char(130), -char(0),char(21),char(0),char(22),char(0),char(23),char(0),char(24),char(0),char(25), -char(0),char(26),char(0),char(27),char(0),char(28),char(0),char(2),char(0),char(1), -char(3),char(131),char(3),char(140),char(0),char(0),char(0),char(2),char(0),char(14), -char(0),char(4),char(3),char(143),char(3),char(144),char(1),char(32),char(1),char(33), -char(0),char(2),char(0),char(2),char(1),char(36),char(1),char(37),char(0),char(0), -char(1),char(73),char(1),char(74),char(0),char(2),char(0),char(1),char(0),char(54), -char(0),char(1),char(0),char(8),char(0),char(5),char(0),char(12),char(0),char(20), -char(0),char(28),char(0),char(34),char(0),char(40),char(2),char(94),char(0),char(3), -char(0),char(73),char(0),char(79),char(2),char(93),char(0),char(3),char(0),char(73), -char(0),char(76),char(3),char(141),char(0),char(2),char(0),char(73),char(2),char(53), -char(0),char(2),char(0),char(79),char(2),char(52),char(0),char(2),char(0),char(76), -char(0),char(1),char(0),char(1),char(0),char(73),char(0),char(0),char(0),char(0), -char(0),char(1),char(0),char(1),char(0),char(1),char(0),char(0),char(0),char(1), -char(0),char(0),char(21),char(94),char(0),char(0),char(0),char(20),char(0),char(0), -char(0),char(0),char(0),char(0),char(21),char(86),char(48),char(130),char(21),char(82), -char(6),char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(7), -char(2),char(160),char(130),char(21),char(67),char(48),char(130),char(21),char(63),char(2), -char(1),char(1),char(49),char(11),char(48),char(9),char(6),char(5),char(43),char(14), -char(3),char(2),char(26),char(5),char(0),char(48),char(97),char(6),char(10),char(43), -char(6),char(1),char(4),char(1),char(130),char(55),char(2),char(1),char(4),char(160), -char(83),char(48),char(81),char(48),char(44),char(6),char(10),char(43),char(6),char(1), -char(4),char(1),char(130),char(55),char(2),char(1),char(28),char(162),char(30),char(128), -char(28),char(0),char(60),char(0),char(60),char(0),char(60),char(0),char(79),char(0), -char(98),char(0),char(115),char(0),char(111),char(0),char(108),char(0),char(101),char(0), -char(116),char(0),char(101),char(0),char(62),char(0),char(62),char(0),char(62),char(48), -char(33),char(48),char(9),char(6),char(5),char(43),char(14),char(3),char(2),char(26), -char(5),char(0),char(4),char(20),char(130),char(184),char(185),char(128),char(143),char(217), -char(245),char(64),char(166),char(109),char(110),char(179),char(21),char(84),char(65),char(54), -char(153),char(222),char(211),char(125),char(160),char(130),char(17),char(93),char(48),char(130), -char(3),char(122),char(48),char(130),char(2),char(98),char(160),char(3),char(2),char(1), -char(2),char(2),char(16),char(56),char(37),char(215),char(250),char(248),char(97),char(175), -char(158),char(244),char(144),char(231),char(38),char(181),char(214),char(90),char(213),char(48), -char(13),char(6),char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1), -char(1),char(5),char(5),char(0),char(48),char(83),char(49),char(11),char(48),char(9), -char(6),char(3),char(85),char(4),char(6),char(19),char(2),char(85),char(83),char(49), -char(23),char(48),char(21),char(6),char(3),char(85),char(4),char(10),char(19),char(14), -char(86),char(101),char(114),char(105),char(83),char(105),char(103),char(110),char(44),char(32), -char(73),char(110),char(99),char(46),char(49),char(43),char(48),char(41),char(6),char(3), -char(85),char(4),char(3),char(19),char(34),char(86),char(101),char(114),char(105),char(83), -char(105),char(103),char(110),char(32),char(84),char(105),char(109),char(101),char(32),char(83), -char(116),char(97),char(109),char(112),char(105),char(110),char(103),char(32),char(83),char(101), -char(114),char(118),char(105),char(99),char(101),char(115),char(32),char(67),char(65),char(48), -char(30),char(23),char(13),char(48),char(55),char(48),char(54),char(49),char(53),char(48), -char(48),char(48),char(48),char(48),char(48),char(90),char(23),char(13),char(49),char(50), -char(48),char(54),char(49),char(52),char(50),char(51),char(53),char(57),char(53),char(57), -char(90),char(48),char(92),char(49),char(11),char(48),char(9),char(6),char(3),char(85), -char(4),char(6),char(19),char(2),char(85),char(83),char(49),char(23),char(48),char(21), -char(6),char(3),char(85),char(4),char(10),char(19),char(14),char(86),char(101),char(114), -char(105),char(83),char(105),char(103),char(110),char(44),char(32),char(73),char(110),char(99), -char(46),char(49),char(52),char(48),char(50),char(6),char(3),char(85),char(4),char(3), -char(19),char(43),char(86),char(101),char(114),char(105),char(83),char(105),char(103),char(110), -char(32),char(84),char(105),char(109),char(101),char(32),char(83),char(116),char(97),char(109), -char(112),char(105),char(110),char(103),char(32),char(83),char(101),char(114),char(118),char(105), -char(99),char(101),char(115),char(32),char(83),char(105),char(103),char(110),char(101),char(114), -char(32),char(45),char(32),char(71),char(50),char(48),char(129),char(159),char(48),char(13), -char(6),char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(1), -char(1),char(5),char(0),char(3),char(129),char(141),char(0),char(48),char(129),char(137), -char(2),char(129),char(129),char(0),char(196),char(181),char(242),char(82),char(21),char(188), -char(136),char(134),char(96),char(41),char(22),char(74),char(91),char(47),char(75),char(145), -char(107),char(135),char(145),char(243),char(53),char(84),char(88),char(53),char(234),char(209), -char(54),char(94),char(98),char(77),char(82),char(81),char(52),char(113),char(194),char(123), -char(102),char(29),char(137),char(200),char(221),char(42),char(196),char(106),char(10),char(246), -char(55),char(217),char(152),char(116),char(145),char(246),char(146),char(174),char(176),char(181), -char(118),char(150),char(241),char(169),char(74),char(99),char(69),char(71),char(46),char(107), -char(11),char(146),char(78),char(75),char(43),char(140),char(238),char(88),char(74),char(139), -char(212),char(7),char(228),char(26),char(44),char(248),char(130),char(170),char(88),char(217), -char(205),char(66),char(243),char(45),char(192),char(117),char(222),char(141),char(171),char(199), -char(142),char(29),char(154),char(108),char(76),char(8),char(149),char(30),char(222),char(219), -char(239),char(103),char(225),char(114),char(194),char(73),char(194),char(158),char(96),char(60), -char(225),char(226),char(190),char(22),char(163),char(99),char(120),char(105),char(20),char(123), -char(173),char(45),char(2),char(3),char(1),char(0),char(1),char(163),char(129),char(196), -char(48),char(129),char(193),char(48),char(52),char(6),char(8),char(43),char(6),char(1), -char(5),char(5),char(7),char(1),char(1),char(4),char(40),char(48),char(38),char(48), -char(36),char(6),char(8),char(43),char(6),char(1),char(5),char(5),char(7),char(48), -char(1),char(134),char(24),char(104),char(116),char(116),char(112),char(58),char(47),char(47), -char(111),char(99),char(115),char(112),char(46),char(118),char(101),char(114),char(105),char(115), -char(105),char(103),char(110),char(46),char(99),char(111),char(109),char(48),char(12),char(6), -char(3),char(85),char(29),char(19),char(1),char(1),char(255),char(4),char(2),char(48), -char(0),char(48),char(51),char(6),char(3),char(85),char(29),char(31),char(4),char(44), -char(48),char(42),char(48),char(40),char(160),char(38),char(160),char(36),char(134),char(34), -char(104),char(116),char(116),char(112),char(58),char(47),char(47),char(99),char(114),char(108), -char(46),char(118),char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46), -char(99),char(111),char(109),char(47),char(116),char(115),char(115),char(45),char(99),char(97), -char(46),char(99),char(114),char(108),char(48),char(22),char(6),char(3),char(85),char(29), -char(37),char(1),char(1),char(255),char(4),char(12),char(48),char(10),char(6),char(8), -char(43),char(6),char(1),char(5),char(5),char(7),char(3),char(8),char(48),char(14), -char(6),char(3),char(85),char(29),char(15),char(1),char(1),char(255),char(4),char(4), -char(3),char(2),char(6),char(192),char(48),char(30),char(6),char(3),char(85),char(29), -char(17),char(4),char(23),char(48),char(21),char(164),char(19),char(48),char(17),char(49), -char(15),char(48),char(13),char(6),char(3),char(85),char(4),char(3),char(19),char(6), -char(84),char(83),char(65),char(49),char(45),char(50),char(48),char(13),char(6),char(9), -char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(1),char(5),char(5), -char(0),char(3),char(130),char(1),char(1),char(0),char(80),char(197),char(75),char(200), -char(36),char(128),char(223),char(228),char(13),char(36),char(194),char(222),char(26),char(177), -char(161),char(2),char(161),char(166),char(130),char(45),char(12),char(131),char(21),char(129), -char(55),char(10),char(130),char(14),char(44),char(176),char(90),char(23),char(97),char(181), -char(216),char(5),char(254),char(136),char(219),char(241),char(145),char(145),char(179),char(86), -char(26),char(64),char(166),char(235),char(146),char(190),char(56),char(57),char(176),char(117), -char(54),char(116),char(58),char(152),char(79),char(228),char(55),char(186),char(153),char(137), -char(202),char(149),char(66),char(29),char(176),char(185),char(199),char(160),char(141),char(87), -char(224),char(250),char(213),char(100),char(4),char(66),char(53),char(78),char(1),char(209), -char(51),char(162),char(23),char(200),char(77),char(170),char(39),char(199),char(242),char(225), -char(134),char(76),char(2),char(56),char(77),char(131),char(120),char(198),char(252),char(83), -char(224),char(235),char(224),char(6),char(135),char(221),char(164),char(150),char(158),char(94), -char(12),char(152),char(226),char(165),char(190),char(191),char(130),char(133),char(195),char(96), -char(225),char(223),char(173),char(40),char(216),char(199),char(165),char(75),char(100),char(218), -char(199),char(27),char(91),char(189),char(172),char(57),char(8),char(213),char(56),char(34), -char(161),char(51),char(139),char(47),char(138),char(154),char(235),char(188),char(7),char(33), -char(63),char(68),char(65),char(9),char(7),char(181),char(101),char(28),char(36),char(188), -char(72),char(211),char(68),char(128),char(235),char(161),char(207),char(201),char(2),char(180), -char(20),char(207),char(84),char(199),char(22),char(163),char(128),char(92),char(249),char(121), -char(62),char(93),char(114),char(125),char(136),char(23),char(158),char(44),char(67),char(162), -char(202),char(83),char(206),char(125),char(61),char(246),char(42),char(58),char(184),char(79), -char(148),char(0),char(165),char(109),char(10),char(131),char(93),char(249),char(94),char(83), -char(244),char(24),char(179),char(87),char(15),char(112),char(195),char(251),char(245),char(173), -char(149),char(160),char(14),char(23),char(222),char(196),char(22),char(128),char(96),char(201), -char(15),char(43),char(110),char(134),char(4),char(241),char(235),char(244),char(120),char(39), -char(209),char(5),char(197),char(238),char(52),char(91),char(94),char(185),char(73),char(50), -char(242),char(51),char(48),char(130),char(3),char(196),char(48),char(130),char(3),char(45), -char(160),char(3),char(2),char(1),char(2),char(2),char(16),char(71),char(191),char(25), -char(149),char(223),char(141),char(82),char(70),char(67),char(247),char(219),char(109),char(72), -char(13),char(49),char(164),char(48),char(13),char(6),char(9),char(42),char(134),char(72), -char(134),char(247),char(13),char(1),char(1),char(5),char(5),char(0),char(48),char(129), -char(139),char(49),char(11),char(48),char(9),char(6),char(3),char(85),char(4),char(6), -char(19),char(2),char(90),char(65),char(49),char(21),char(48),char(19),char(6),char(3), -char(85),char(4),char(8),char(19),char(12),char(87),char(101),char(115),char(116),char(101), -char(114),char(110),char(32),char(67),char(97),char(112),char(101),char(49),char(20),char(48), -char(18),char(6),char(3),char(85),char(4),char(7),char(19),char(11),char(68),char(117), -char(114),char(98),char(97),char(110),char(118),char(105),char(108),char(108),char(101),char(49), -char(15),char(48),char(13),char(6),char(3),char(85),char(4),char(10),char(19),char(6), -char(84),char(104),char(97),char(119),char(116),char(101),char(49),char(29),char(48),char(27), -char(6),char(3),char(85),char(4),char(11),char(19),char(20),char(84),char(104),char(97), -char(119),char(116),char(101),char(32),char(67),char(101),char(114),char(116),char(105),char(102), -char(105),char(99),char(97),char(116),char(105),char(111),char(110),char(49),char(31),char(48), -char(29),char(6),char(3),char(85),char(4),char(3),char(19),char(22),char(84),char(104), -char(97),char(119),char(116),char(101),char(32),char(84),char(105),char(109),char(101),char(115), -char(116),char(97),char(109),char(112),char(105),char(110),char(103),char(32),char(67),char(65), -char(48),char(30),char(23),char(13),char(48),char(51),char(49),char(50),char(48),char(52), -char(48),char(48),char(48),char(48),char(48),char(48),char(90),char(23),char(13),char(49), -char(51),char(49),char(50),char(48),char(51),char(50),char(51),char(53),char(57),char(53), -char(57),char(90),char(48),char(83),char(49),char(11),char(48),char(9),char(6),char(3), -char(85),char(4),char(6),char(19),char(2),char(85),char(83),char(49),char(23),char(48), -char(21),char(6),char(3),char(85),char(4),char(10),char(19),char(14),char(86),char(101), -char(114),char(105),char(83),char(105),char(103),char(110),char(44),char(32),char(73),char(110), -char(99),char(46),char(49),char(43),char(48),char(41),char(6),char(3),char(85),char(4), -char(3),char(19),char(34),char(86),char(101),char(114),char(105),char(83),char(105),char(103), -char(110),char(32),char(84),char(105),char(109),char(101),char(32),char(83),char(116),char(97), -char(109),char(112),char(105),char(110),char(103),char(32),char(83),char(101),char(114),char(118), -char(105),char(99),char(101),char(115),char(32),char(67),char(65),char(48),char(130),char(1), -char(34),char(48),char(13),char(6),char(9),char(42),char(134),char(72),char(134),char(247), -char(13),char(1),char(1),char(1),char(5),char(0),char(3),char(130),char(1),char(15), -char(0),char(48),char(130),char(1),char(10),char(2),char(130),char(1),char(1),char(0), -char(169),char(202),char(178),char(164),char(204),char(205),char(32),char(175),char(10),char(125), -char(137),char(172),char(135),char(117),char(240),char(180),char(78),char(241),char(223),char(193), -char(15),char(191),char(103),char(97),char(189),char(163),char(100),char(28),char(218),char(187), -char(249),char(202),char(51),char(171),char(132),char(48),char(137),char(88),char(126),char(140), -char(219),char(107),char(221),char(54),char(158),char(15),char(191),char(209),char(236),char(120), -char(242),char(119),char(166),char(126),char(111),char(60),char(191),char(147),char(175),char(13), -char(186),char(104),char(244),char(108),char(148),char(202),char(189),char(82),char(45),char(171), -char(72),char(61),char(245),char(182),char(213),char(93),char(95),char(27),char(2),char(159), -char(250),char(47),char(107),char(30),char(164),char(247),char(163),char(154),char(166),char(26), -char(200),char(2),char(225),char(127),char(76),char(82),char(227),char(14),char(96),char(236), -char(64),char(28),char(126),char(185),char(13),char(222),char(63),char(199),char(180),char(223), -char(135),char(189),char(95),char(122),char(106),char(49),char(46),char(3),char(153),char(129), -char(19),char(168),char(71),char(32),char(206),char(49),char(115),char(13),char(87),char(45), -char(205),char(120),char(52),char(51),char(149),char(18),char(153),char(18),char(185),char(222), -char(104),char(47),char(170),char(230),char(227),char(194),char(138),char(140),char(42),char(195), -char(139),char(33),char(135),char(102),char(189),char(131),char(88),char(87),char(111),char(117), -char(191),char(60),char(170),char(38),char(135),char(93),char(202),char(16),char(21),char(60), -char(159),char(132),char(234),char(84),char(193),char(10),char(110),char(196),char(254),char(197), -char(74),char(221),char(185),char(7),char(17),char(151),char(34),char(124),char(219),char(62), -char(39),char(209),char(30),char(120),char(236),char(159),char(49),char(201),char(241),char(230), -char(34),char(25),char(219),char(196),char(179),char(71),char(67),char(154),char(26),char(95), -char(160),char(30),char(144),char(228),char(94),char(245),char(238),char(124),char(241),char(125), -char(171),char(98),char(1),char(143),char(245),char(77),char(11),char(222),char(208),char(34), -char(86),char(168),char(149),char(205),char(174),char(136),char(118),char(174),char(238),char(186), -char(13),char(243),char(228),char(77),char(217),char(160),char(251),char(104),char(160),char(174), -char(20),char(59),char(179),char(135),char(193),char(187),char(2),char(3),char(1),char(0), -char(1),char(163),char(129),char(219),char(48),char(129),char(216),char(48),char(52),char(6), -char(8),char(43),char(6),char(1),char(5),char(5),char(7),char(1),char(1),char(4), -char(40),char(48),char(38),char(48),char(36),char(6),char(8),char(43),char(6),char(1), -char(5),char(5),char(7),char(48),char(1),char(134),char(24),char(104),char(116),char(116), -char(112),char(58),char(47),char(47),char(111),char(99),char(115),char(112),char(46),char(118), -char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99),char(111), -char(109),char(48),char(18),char(6),char(3),char(85),char(29),char(19),char(1),char(1), -char(255),char(4),char(8),char(48),char(6),char(1),char(1),char(255),char(2),char(1), -char(0),char(48),char(65),char(6),char(3),char(85),char(29),char(31),char(4),char(58), -char(48),char(56),char(48),char(54),char(160),char(52),char(160),char(50),char(134),char(48), -char(104),char(116),char(116),char(112),char(58),char(47),char(47),char(99),char(114),char(108), -char(46),char(118),char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46), -char(99),char(111),char(109),char(47),char(84),char(104),char(97),char(119),char(116),char(101), -char(84),char(105),char(109),char(101),char(115),char(116),char(97),char(109),char(112),char(105), -char(110),char(103),char(67),char(65),char(46),char(99),char(114),char(108),char(48),char(19), -char(6),char(3),char(85),char(29),char(37),char(4),char(12),char(48),char(10),char(6), -char(8),char(43),char(6),char(1),char(5),char(5),char(7),char(3),char(8),char(48), -char(14),char(6),char(3),char(85),char(29),char(15),char(1),char(1),char(255),char(4), -char(4),char(3),char(2),char(1),char(6),char(48),char(36),char(6),char(3),char(85), -char(29),char(17),char(4),char(29),char(48),char(27),char(164),char(25),char(48),char(23), -char(49),char(21),char(48),char(19),char(6),char(3),char(85),char(4),char(3),char(19), -char(12),char(84),char(83),char(65),char(50),char(48),char(52),char(56),char(45),char(49), -char(45),char(53),char(51),char(48),char(13),char(6),char(9),char(42),char(134),char(72), -char(134),char(247),char(13),char(1),char(1),char(5),char(5),char(0),char(3),char(129), -char(129),char(0),char(74),char(107),char(249),char(234),char(88),char(194),char(68),char(28), -char(49),char(137),char(121),char(153),char(43),char(150),char(191),char(130),char(172),char(1), -char(214),char(28),char(76),char(205),char(176),char(138),char(88),char(110),char(223),char(8), -char(41),char(163),char(94),char(200),char(202),char(147),char(19),char(231),char(4),char(82), -char(13),char(239),char(71),char(39),char(47),char(0),char(56),char(176),char(228),char(201), -char(147),char(78),char(154),char(212),char(34),char(98),char(21),char(247),char(63),char(55), -char(33),char(79),char(112),char(49),char(128),char(241),char(139),char(56),char(135),char(179), -char(232),char(232),char(151),char(0),char(254),char(207),char(85),char(150),char(78),char(36), -char(210),char(169),char(39),char(78),char(122),char(174),char(183),char(97),char(65),char(243), -char(42),char(206),char(231),char(201),char(217),char(94),char(221),char(187),char(43),char(133), -char(62),char(181),char(157),char(181),char(217),char(225),char(87),char(255),char(190),char(180), -char(197),char(126),char(245),char(207),char(12),char(158),char(240),char(151),char(254),char(43), -char(211),char(59),char(82),char(27),char(27),char(56),char(39),char(247),char(63),char(74), -char(48),char(130),char(4),char(252),char(48),char(130),char(4),char(101),char(160),char(3), -char(2),char(1),char(2),char(2),char(16),char(101),char(82),char(38),char(225),char(178), -char(46),char(24),char(225),char(89),char(15),char(41),char(133),char(172),char(34),char(231), -char(92),char(48),char(13),char(6),char(9),char(42),char(134),char(72),char(134),char(247), -char(13),char(1),char(1),char(5),char(5),char(0),char(48),char(95),char(49),char(11), -char(48),char(9),char(6),char(3),char(85),char(4),char(6),char(19),char(2),char(85), -char(83),char(49),char(23),char(48),char(21),char(6),char(3),char(85),char(4),char(10), -char(19),char(14),char(86),char(101),char(114),char(105),char(83),char(105),char(103),char(110), -char(44),char(32),char(73),char(110),char(99),char(46),char(49),char(55),char(48),char(53), -char(6),char(3),char(85),char(4),char(11),char(19),char(46),char(67),char(108),char(97), -char(115),char(115),char(32),char(51),char(32),char(80),char(117),char(98),char(108),char(105), -char(99),char(32),char(80),char(114),char(105),char(109),char(97),char(114),char(121),char(32), -char(67),char(101),char(114),char(116),char(105),char(102),char(105),char(99),char(97),char(116), -char(105),char(111),char(110),char(32),char(65),char(117),char(116),char(104),char(111),char(114), -char(105),char(116),char(121),char(48),char(30),char(23),char(13),char(48),char(57),char(48), -char(53),char(50),char(49),char(48),char(48),char(48),char(48),char(48),char(48),char(90), -char(23),char(13),char(49),char(57),char(48),char(53),char(50),char(48),char(50),char(51), -char(53),char(57),char(53),char(57),char(90),char(48),char(129),char(182),char(49),char(11), -char(48),char(9),char(6),char(3),char(85),char(4),char(6),char(19),char(2),char(85), -char(83),char(49),char(23),char(48),char(21),char(6),char(3),char(85),char(4),char(10), -char(19),char(14),char(86),char(101),char(114),char(105),char(83),char(105),char(103),char(110), -char(44),char(32),char(73),char(110),char(99),char(46),char(49),char(31),char(48),char(29), -char(6),char(3),char(85),char(4),char(11),char(19),char(22),char(86),char(101),char(114), -char(105),char(83),char(105),char(103),char(110),char(32),char(84),char(114),char(117),char(115), -char(116),char(32),char(78),char(101),char(116),char(119),char(111),char(114),char(107),char(49), -char(59),char(48),char(57),char(6),char(3),char(85),char(4),char(11),char(19),char(50), -char(84),char(101),char(114),char(109),char(115),char(32),char(111),char(102),char(32),char(117), -char(115),char(101),char(32),char(97),char(116),char(32),char(104),char(116),char(116),char(112), -char(115),char(58),char(47),char(47),char(119),char(119),char(119),char(46),char(118),char(101), -char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99),char(111),char(109), -char(47),char(114),char(112),char(97),char(32),char(40),char(99),char(41),char(48),char(57), -char(49),char(48),char(48),char(46),char(6),char(3),char(85),char(4),char(3),char(19), -char(39),char(86),char(101),char(114),char(105),char(83),char(105),char(103),char(110),char(32), -char(67),char(108),char(97),char(115),char(115),char(32),char(51),char(32),char(67),char(111), -char(100),char(101),char(32),char(83),char(105),char(103),char(110),char(105),char(110),char(103), -char(32),char(50),char(48),char(48),char(57),char(45),char(50),char(32),char(67),char(65), -char(48),char(130),char(1),char(34),char(48),char(13),char(6),char(9),char(42),char(134), -char(72),char(134),char(247),char(13),char(1),char(1),char(1),char(5),char(0),char(3), -char(130),char(1),char(15),char(0),char(48),char(130),char(1),char(10),char(2),char(130), -char(1),char(1),char(0),char(190),char(103),char(29),char(180),char(96),char(170),char(16), -char(73),char(111),char(86),char(23),char(124),char(102),char(201),char(94),char(134),char(13), -char(213),char(241),char(172),char(167),char(113),char(131),char(142),char(139),char(137),char(248), -char(136),char(4),char(137),char(21),char(6),char(186),char(45),char(132),char(33),char(149), -char(228),char(209),char(156),char(80),char(76),char(251),char(210),char(34),char(189),char(218), -char(242),char(178),char(53),char(59),char(30),char(143),char(195),char(9),char(251),char(252), -char(19),char(46),char(90),char(191),char(137),char(124),char(61),char(59),char(37),char(30), -char(246),char(243),char(88),char(123),char(156),char(244),char(1),char(181),char(198),char(10), -char(184),char(128),char(206),char(190),char(39),char(116),char(97),char(103),char(39),char(77), -char(106),char(229),char(236),char(129),char(97),char(88),char(121),char(163),char(224),char(23), -char(16),char(18),char(21),char(39),char(176),char(225),char(77),char(52),char(127),char(43), -char(71),char(32),char(68),char(185),char(222),char(102),char(36),char(102),char(138),char(205), -char(79),char(186),char(31),char(197),char(56),char(200),char(84),char(144),char(225),char(114), -char(246),char(25),char(102),char(117),char(106),char(185),char(73),char(104),char(207),char(56), -char(121),char(13),char(170),char(48),char(168),char(219),char(44),char(96),char(72),char(158), -char(215),char(170),char(20),char(1),char(169),char(131),char(215),char(56),char(145),char(48), -char(57),char(19),char(150),char(3),char(58),char(124),char(64),char(84),char(182),char(173), -char(224),char(47),char(27),char(131),char(220),char(168),char(17),char(82),char(62),char(2), -char(179),char(215),char(43),char(253),char(33),char(182),char(167),char(92),char(163),char(15), -char(11),char(169),char(166),char(16),char(80),char(14),char(52),char(46),char(77),char(167), -char(206),char(201),char(94),char(37),char(212),char(140),char(188),char(243),char(110),char(124), -char(41),char(188),char(1),char(93),char(252),char(49),char(135),char(90),char(213),char(140), -char(133),char(103),char(88),char(136),char(25),char(160),char(191),char(53),char(240),char(234), -char(43),char(163),char(33),char(231),char(144),char(246),char(131),char(229),char(168),char(237), -char(96),char(120),char(94),char(123),char(96),char(131),char(253),char(87),char(11),char(93), -char(65),char(13),char(99),char(84),char(96),char(214),char(67),char(33),char(239),char(2), -char(3),char(1),char(0),char(1),char(163),char(130),char(1),char(219),char(48),char(130), -char(1),char(215),char(48),char(18),char(6),char(3),char(85),char(29),char(19),char(1), -char(1),char(255),char(4),char(8),char(48),char(6),char(1),char(1),char(255),char(2), -char(1),char(0),char(48),char(112),char(6),char(3),char(85),char(29),char(32),char(4), -char(105),char(48),char(103),char(48),char(101),char(6),char(11),char(96),char(134),char(72), -char(1),char(134),char(248),char(69),char(1),char(7),char(23),char(3),char(48),char(86), -char(48),char(40),char(6),char(8),char(43),char(6),char(1),char(5),char(5),char(7), -char(2),char(1),char(22),char(28),char(104),char(116),char(116),char(112),char(115),char(58), -char(47),char(47),char(119),char(119),char(119),char(46),char(118),char(101),char(114),char(105), -char(115),char(105),char(103),char(110),char(46),char(99),char(111),char(109),char(47),char(99), -char(112),char(115),char(48),char(42),char(6),char(8),char(43),char(6),char(1),char(5), -char(5),char(7),char(2),char(2),char(48),char(30),char(26),char(28),char(104),char(116), -char(116),char(112),char(115),char(58),char(47),char(47),char(119),char(119),char(119),char(46), -char(118),char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99), -char(111),char(109),char(47),char(114),char(112),char(97),char(48),char(14),char(6),char(3), -char(85),char(29),char(15),char(1),char(1),char(255),char(4),char(4),char(3),char(2), -char(1),char(6),char(48),char(109),char(6),char(8),char(43),char(6),char(1),char(5), -char(5),char(7),char(1),char(12),char(4),char(97),char(48),char(95),char(161),char(93), -char(160),char(91),char(48),char(89),char(48),char(87),char(48),char(85),char(22),char(9), -char(105),char(109),char(97),char(103),char(101),char(47),char(103),char(105),char(102),char(48), -char(33),char(48),char(31),char(48),char(7),char(6),char(5),char(43),char(14),char(3), -char(2),char(26),char(4),char(20),char(143),char(229),char(211),char(26),char(134),char(172), -char(141),char(142),char(107),char(195),char(207),char(128),char(106),char(212),char(72),char(24), -char(44),char(123),char(25),char(46),char(48),char(37),char(22),char(35),char(104),char(116), -char(116),char(112),char(58),char(47),char(47),char(108),char(111),char(103),char(111),char(46), -char(118),char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99), -char(111),char(109),char(47),char(118),char(115),char(108),char(111),char(103),char(111),char(46), -char(103),char(105),char(102),char(48),char(29),char(6),char(3),char(85),char(29),char(37), -char(4),char(22),char(48),char(20),char(6),char(8),char(43),char(6),char(1),char(5), -char(5),char(7),char(3),char(2),char(6),char(8),char(43),char(6),char(1),char(5), -char(5),char(7),char(3),char(3),char(48),char(52),char(6),char(8),char(43),char(6), -char(1),char(5),char(5),char(7),char(1),char(1),char(4),char(40),char(48),char(38), -char(48),char(36),char(6),char(8),char(43),char(6),char(1),char(5),char(5),char(7), -char(48),char(1),char(134),char(24),char(104),char(116),char(116),char(112),char(58),char(47), -char(47),char(111),char(99),char(115),char(112),char(46),char(118),char(101),char(114),char(105), -char(115),char(105),char(103),char(110),char(46),char(99),char(111),char(109),char(48),char(49), -char(6),char(3),char(85),char(29),char(31),char(4),char(42),char(48),char(40),char(48), -char(38),char(160),char(36),char(160),char(34),char(134),char(32),char(104),char(116),char(116), -char(112),char(58),char(47),char(47),char(99),char(114),char(108),char(46),char(118),char(101), -char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99),char(111),char(109), -char(47),char(112),char(99),char(97),char(51),char(46),char(99),char(114),char(108),char(48), -char(41),char(6),char(3),char(85),char(29),char(17),char(4),char(34),char(48),char(32), -char(164),char(30),char(48),char(28),char(49),char(26),char(48),char(24),char(6),char(3), -char(85),char(4),char(3),char(19),char(17),char(67),char(108),char(97),char(115),char(115), -char(51),char(67),char(65),char(50),char(48),char(52),char(56),char(45),char(49),char(45), -char(53),char(53),char(48),char(29),char(6),char(3),char(85),char(29),char(14),char(4), -char(22),char(4),char(20),char(151),char(208),char(107),char(168),char(38),char(112),char(200), -char(161),char(63),char(148),char(31),char(8),char(45),char(196),char(53),char(155),char(164), -char(161),char(30),char(242),char(48),char(13),char(6),char(9),char(42),char(134),char(72), -char(134),char(247),char(13),char(1),char(1),char(5),char(5),char(0),char(3),char(129), -char(129),char(0),char(139),char(3),char(192),char(221),char(148),char(216),char(65),char(162), -char(97),char(105),char(176),char(21),char(168),char(120),char(199),char(48),char(198),char(144), -char(60),char(126),char(66),char(247),char(36),char(182),char(228),char(131),char(115),char(23), -char(4),char(127),char(4),char(16),char(156),char(161),char(226),char(250),char(129),char(47), -char(235),char(192),char(202),char(68),char(231),char(114),char(224),char(80),char(182),char(85), -char(16),char(32),char(131),char(110),char(150),char(146),char(228),char(154),char(81),char(106), -char(180),char(55),char(49),char(220),char(165),char(45),char(235),char(140),char(0),char(199), -char(29),char(79),char(231),char(77),char(50),char(186),char(133),char(248),char(78),char(190), -char(250),char(103),char(85),char(101),char(240),char(106),char(190),char(122),char(202),char(100), -char(56),char(26),char(16),char(16),char(120),char(69),char(118),char(49),char(243),char(134), -char(122),char(3),char(15),char(96),char(194),char(179),char(93),char(157),char(246),char(139), -char(102),char(118),char(130),char(27),char(89),char(225),char(131),char(229),char(189),char(73), -char(165),char(56),char(86),char(229),char(222),char(65),char(119),char(14),char(88),char(15), -char(48),char(130),char(5),char(19),char(48),char(130),char(3),char(251),char(160),char(3), -char(2),char(1),char(2),char(2),char(16),char(102),char(227),char(240),char(103),char(121), -char(202),char(21),char(22),char(109),char(80),char(83),char(111),char(136),char(25),char(26), -char(131),char(48),char(13),char(6),char(9),char(42),char(134),char(72),char(134),char(247), -char(13),char(1),char(1),char(5),char(5),char(0),char(48),char(129),char(182),char(49), -char(11),char(48),char(9),char(6),char(3),char(85),char(4),char(6),char(19),char(2), -char(85),char(83),char(49),char(23),char(48),char(21),char(6),char(3),char(85),char(4), -char(10),char(19),char(14),char(86),char(101),char(114),char(105),char(83),char(105),char(103), -char(110),char(44),char(32),char(73),char(110),char(99),char(46),char(49),char(31),char(48), -char(29),char(6),char(3),char(85),char(4),char(11),char(19),char(22),char(86),char(101), -char(114),char(105),char(83),char(105),char(103),char(110),char(32),char(84),char(114),char(117), -char(115),char(116),char(32),char(78),char(101),char(116),char(119),char(111),char(114),char(107), -char(49),char(59),char(48),char(57),char(6),char(3),char(85),char(4),char(11),char(19), -char(50),char(84),char(101),char(114),char(109),char(115),char(32),char(111),char(102),char(32), -char(117),char(115),char(101),char(32),char(97),char(116),char(32),char(104),char(116),char(116), -char(112),char(115),char(58),char(47),char(47),char(119),char(119),char(119),char(46),char(118), -char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99),char(111), -char(109),char(47),char(114),char(112),char(97),char(32),char(40),char(99),char(41),char(48), -char(57),char(49),char(48),char(48),char(46),char(6),char(3),char(85),char(4),char(3), -char(19),char(39),char(86),char(101),char(114),char(105),char(83),char(105),char(103),char(110), -char(32),char(67),char(108),char(97),char(115),char(115),char(32),char(51),char(32),char(67), -char(111),char(100),char(101),char(32),char(83),char(105),char(103),char(110),char(105),char(110), -char(103),char(32),char(50),char(48),char(48),char(57),char(45),char(50),char(32),char(67), -char(65),char(48),char(30),char(23),char(13),char(49),char(48),char(48),char(55),char(50), -char(57),char(48),char(48),char(48),char(48),char(48),char(48),char(90),char(23),char(13), -char(49),char(50),char(48),char(56),char(48),char(56),char(50),char(51),char(53),char(57), -char(53),char(57),char(90),char(48),char(129),char(208),char(49),char(11),char(48),char(9), -char(6),char(3),char(85),char(4),char(6),char(19),char(2),char(85),char(83),char(49), -char(22),char(48),char(20),char(6),char(3),char(85),char(4),char(8),char(19),char(13), -char(77),char(97),char(115),char(115),char(97),char(99),char(104),char(117),char(115),char(101), -char(116),char(116),char(115),char(49),char(15),char(48),char(13),char(6),char(3),char(85), -char(4),char(7),char(19),char(6),char(87),char(111),char(98),char(117),char(114),char(110), -char(49),char(30),char(48),char(28),char(6),char(3),char(85),char(4),char(10),char(20), -char(21),char(77),char(111),char(110),char(111),char(116),char(121),char(112),char(101),char(32), -char(73),char(109),char(97),char(103),char(105),char(110),char(103),char(32),char(73),char(110), -char(99),char(46),char(49),char(62),char(48),char(60),char(6),char(3),char(85),char(4), -char(11),char(19),char(53),char(68),char(105),char(103),char(105),char(116),char(97),char(108), -char(32),char(73),char(68),char(32),char(67),char(108),char(97),char(115),char(115),char(32), -char(51),char(32),char(45),char(32),char(77),char(105),char(99),char(114),char(111),char(115), -char(111),char(102),char(116),char(32),char(83),char(111),char(102),char(116),char(119),char(97), -char(114),char(101),char(32),char(86),char(97),char(108),char(105),char(100),char(97),char(116), -char(105),char(111),char(110),char(32),char(118),char(50),char(49),char(24),char(48),char(22), -char(6),char(3),char(85),char(4),char(11),char(20),char(15),char(84),char(121),char(112), -char(101),char(32),char(79),char(112),char(101),char(114),char(97),char(116),char(105),char(111), -char(110),char(115),char(49),char(30),char(48),char(28),char(6),char(3),char(85),char(4), -char(3),char(20),char(21),char(77),char(111),char(110),char(111),char(116),char(121),char(112), -char(101),char(32),char(73),char(109),char(97),char(103),char(105),char(110),char(103),char(32), -char(73),char(110),char(99),char(46),char(48),char(129),char(159),char(48),char(13),char(6), -char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(1),char(1), -char(5),char(0),char(3),char(129),char(141),char(0),char(48),char(129),char(137),char(2), -char(129),char(129),char(0),char(148),char(68),char(160),char(149),char(105),char(124),char(85), -char(13),char(208),char(219),char(22),char(141),char(50),char(53),char(138),char(76),char(51), -char(171),char(94),char(32),char(161),char(76),char(215),char(42),char(135),char(56),char(215), -char(152),char(165),char(64),char(240),char(25),char(73),char(11),char(34),char(30),char(83), -char(79),char(194),char(67),char(166),char(202),char(139),char(169),char(86),char(239),char(110), -char(72),char(6),char(168),char(5),char(21),char(57),char(30),char(99),char(59),char(36), -char(18),char(144),char(185),char(152),char(207),char(202),char(8),char(53),char(125),char(114), -char(227),char(71),char(87),char(253),char(121),char(203),char(138),char(74),char(231),char(64), -char(112),char(45),char(53),char(99),char(127),char(174),char(128),char(207),char(196),char(175), -char(216),char(251),char(247),char(201),char(252),char(137),char(216),char(215),char(164),char(160), -char(219),char(9),char(242),char(162),char(242),char(123),char(239),char(205),char(117),char(193), -char(247),char(101),char(80),char(100),char(34),char(157),char(189),char(125),char(188),char(173), -char(184),char(75),char(204),char(88),char(69),char(14),char(77),char(209),char(89),char(76), -char(77),char(2),char(3),char(1),char(0),char(1),char(163),char(130),char(1),char(131), -char(48),char(130),char(1),char(127),char(48),char(9),char(6),char(3),char(85),char(29), -char(19),char(4),char(2),char(48),char(0),char(48),char(14),char(6),char(3),char(85), -char(29),char(15),char(1),char(1),char(255),char(4),char(4),char(3),char(2),char(7), -char(128),char(48),char(68),char(6),char(3),char(85),char(29),char(31),char(4),char(61), -char(48),char(59),char(48),char(57),char(160),char(55),char(160),char(53),char(134),char(51), -char(104),char(116),char(116),char(112),char(58),char(47),char(47),char(99),char(115),char(99), -char(51),char(45),char(50),char(48),char(48),char(57),char(45),char(50),char(45),char(99), -char(114),char(108),char(46),char(118),char(101),char(114),char(105),char(115),char(105),char(103), -char(110),char(46),char(99),char(111),char(109),char(47),char(67),char(83),char(67),char(51), -char(45),char(50),char(48),char(48),char(57),char(45),char(50),char(46),char(99),char(114), -char(108),char(48),char(68),char(6),char(3),char(85),char(29),char(32),char(4),char(61), -char(48),char(59),char(48),char(57),char(6),char(11),char(96),char(134),char(72),char(1), -char(134),char(248),char(69),char(1),char(7),char(23),char(3),char(48),char(42),char(48), -char(40),char(6),char(8),char(43),char(6),char(1),char(5),char(5),char(7),char(2), -char(1),char(22),char(28),char(104),char(116),char(116),char(112),char(115),char(58),char(47), -char(47),char(119),char(119),char(119),char(46),char(118),char(101),char(114),char(105),char(115), -char(105),char(103),char(110),char(46),char(99),char(111),char(109),char(47),char(114),char(112), -char(97),char(48),char(19),char(6),char(3),char(85),char(29),char(37),char(4),char(12), -char(48),char(10),char(6),char(8),char(43),char(6),char(1),char(5),char(5),char(7), -char(3),char(3),char(48),char(117),char(6),char(8),char(43),char(6),char(1),char(5), -char(5),char(7),char(1),char(1),char(4),char(105),char(48),char(103),char(48),char(36), -char(6),char(8),char(43),char(6),char(1),char(5),char(5),char(7),char(48),char(1), -char(134),char(24),char(104),char(116),char(116),char(112),char(58),char(47),char(47),char(111), -char(99),char(115),char(112),char(46),char(118),char(101),char(114),char(105),char(115),char(105), -char(103),char(110),char(46),char(99),char(111),char(109),char(48),char(63),char(6),char(8), -char(43),char(6),char(1),char(5),char(5),char(7),char(48),char(2),char(134),char(51), -char(104),char(116),char(116),char(112),char(58),char(47),char(47),char(99),char(115),char(99), -char(51),char(45),char(50),char(48),char(48),char(57),char(45),char(50),char(45),char(97), -char(105),char(97),char(46),char(118),char(101),char(114),char(105),char(115),char(105),char(103), -char(110),char(46),char(99),char(111),char(109),char(47),char(67),char(83),char(67),char(51), -char(45),char(50),char(48),char(48),char(57),char(45),char(50),char(46),char(99),char(101), -char(114),char(48),char(31),char(6),char(3),char(85),char(29),char(35),char(4),char(24), -char(48),char(22),char(128),char(20),char(151),char(208),char(107),char(168),char(38),char(112), -char(200),char(161),char(63),char(148),char(31),char(8),char(45),char(196),char(53),char(155), -char(164),char(161),char(30),char(242),char(48),char(17),char(6),char(9),char(96),char(134), -char(72),char(1),char(134),char(248),char(66),char(1),char(1),char(4),char(4),char(3), -char(2),char(4),char(16),char(48),char(22),char(6),char(10),char(43),char(6),char(1), -char(4),char(1),char(130),char(55),char(2),char(1),char(27),char(4),char(8),char(48), -char(6),char(1),char(1),char(0),char(1),char(1),char(255),char(48),char(13),char(6), -char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(1),char(5), -char(5),char(0),char(3),char(130),char(1),char(1),char(0),char(78),char(230),char(34), -char(135),char(223),char(103),char(65),char(21),char(23),char(226),char(210),char(238),char(126), -char(14),char(206),char(194),char(153),char(214),char(99),char(189),char(240),char(181),char(147), -char(229),char(106),char(114),char(98),char(225),char(245),char(210),char(60),char(56),char(238), -char(168),char(61),char(8),char(95),char(186),char(71),char(129),char(130),char(95),char(91), -char(75),char(73),char(244),char(29),char(32),char(250),char(15),char(147),char(9),char(208), -char(29),char(25),char(86),char(68),char(23),char(162),char(136),char(243),char(251),char(141), -char(157),char(174),char(247),char(13),char(53),char(222),char(60),char(12),char(172),char(68), -char(148),char(96),char(69),char(42),char(155),char(254),char(155),char(111),char(76),char(59), -char(177),char(52),char(103),char(112),char(16),char(134),char(255),char(90),char(57),char(92), -char(90),char(227),char(108),char(130),char(171),char(53),char(124),char(101),char(75),char(253), -char(152),char(109),char(181),char(21),char(148),char(73),char(156),char(136),char(112),char(16), -char(190),char(61),char(177),char(98),char(149),char(180),char(219),char(180),char(212),char(218), -char(232),char(157),char(65),char(144),char(126),char(254),char(125),char(185),char(164),char(146), -char(235),char(110),char(242),char(34),char(138),char(198),char(119),char(54),char(77),char(138), -char(90),char(11),char(83),char(5),char(49),char(211),char(43),char(40),char(175),char(82), -char(225),char(141),char(122),char(107),char(181),char(119),char(68),char(189),char(12),char(173), -char(244),char(93),char(37),char(44),char(227),char(205),char(138),char(48),char(62),char(75), -char(3),char(156),char(121),char(202),char(166),char(78),char(174),char(11),char(194),char(204), -char(36),char(7),char(11),char(193),char(148),char(130),char(246),char(16),char(241),char(186), -char(144),char(182),char(155),char(154),char(216),char(92),char(60),char(19),char(241),char(234), -char(2),char(6),char(24),char(39),char(77),char(60),char(137),char(111),char(51),char(138), -char(211),char(134),char(222),char(233),char(88),char(51),char(117),char(61),char(235),char(147), -char(105),char(226),char(68),char(111),char(78),char(0),char(108),char(207),char(213),char(133), -char(218),char(86),char(166),char(154),char(166),char(63),char(203),char(76),char(33),char(104), -char(144),char(242),char(96),char(186),char(225),char(232),char(6),char(93),char(57),char(33), -char(19),char(50),char(237),char(49),char(130),char(3),char(103),char(48),char(130),char(3), -char(99),char(2),char(1),char(1),char(48),char(129),char(203),char(48),char(129),char(182), -char(49),char(11),char(48),char(9),char(6),char(3),char(85),char(4),char(6),char(19), -char(2),char(85),char(83),char(49),char(23),char(48),char(21),char(6),char(3),char(85), -char(4),char(10),char(19),char(14),char(86),char(101),char(114),char(105),char(83),char(105), -char(103),char(110),char(44),char(32),char(73),char(110),char(99),char(46),char(49),char(31), -char(48),char(29),char(6),char(3),char(85),char(4),char(11),char(19),char(22),char(86), -char(101),char(114),char(105),char(83),char(105),char(103),char(110),char(32),char(84),char(114), -char(117),char(115),char(116),char(32),char(78),char(101),char(116),char(119),char(111),char(114), -char(107),char(49),char(59),char(48),char(57),char(6),char(3),char(85),char(4),char(11), -char(19),char(50),char(84),char(101),char(114),char(109),char(115),char(32),char(111),char(102), -char(32),char(117),char(115),char(101),char(32),char(97),char(116),char(32),char(104),char(116), -char(116),char(112),char(115),char(58),char(47),char(47),char(119),char(119),char(119),char(46), -char(118),char(101),char(114),char(105),char(115),char(105),char(103),char(110),char(46),char(99), -char(111),char(109),char(47),char(114),char(112),char(97),char(32),char(40),char(99),char(41), -char(48),char(57),char(49),char(48),char(48),char(46),char(6),char(3),char(85),char(4), -char(3),char(19),char(39),char(86),char(101),char(114),char(105),char(83),char(105),char(103), -char(110),char(32),char(67),char(108),char(97),char(115),char(115),char(32),char(51),char(32), -char(67),char(111),char(100),char(101),char(32),char(83),char(105),char(103),char(110),char(105), -char(110),char(103),char(32),char(50),char(48),char(48),char(57),char(45),char(50),char(32), -char(67),char(65),char(2),char(16),char(102),char(227),char(240),char(103),char(121),char(202), -char(21),char(22),char(109),char(80),char(83),char(111),char(136),char(25),char(26),char(131), -char(48),char(9),char(6),char(5),char(43),char(14),char(3),char(2),char(26),char(5), -char(0),char(160),char(112),char(48),char(16),char(6),char(10),char(43),char(6),char(1), -char(4),char(1),char(130),char(55),char(2),char(1),char(12),char(49),char(2),char(48), -char(0),char(48),char(25),char(6),char(9),char(42),char(134),char(72),char(134),char(247), -char(13),char(1),char(9),char(3),char(49),char(12),char(6),char(10),char(43),char(6), -char(1),char(4),char(1),char(130),char(55),char(2),char(1),char(4),char(48),char(28), -char(6),char(10),char(43),char(6),char(1),char(4),char(1),char(130),char(55),char(2), -char(1),char(11),char(49),char(14),char(48),char(12),char(6),char(10),char(43),char(6), -char(1),char(4),char(1),char(130),char(55),char(2),char(1),char(21),char(48),char(35), -char(6),char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(9), -char(4),char(49),char(22),char(4),char(20),char(72),char(227),char(234),char(219),char(23), -char(99),char(143),char(198),char(177),char(21),char(87),char(39),char(32),char(183),char(101), -char(244),char(25),char(83),char(149),char(24),char(48),char(13),char(6),char(9),char(42), -char(134),char(72),char(134),char(247),char(13),char(1),char(1),char(1),char(5),char(0), -char(4),char(129),char(128),char(69),char(59),char(188),char(212),char(186),char(239),char(218), -char(27),char(191),char(98),char(59),char(222),char(18),char(236),char(74),char(6),char(132), -char(69),char(113),char(65),char(201),char(2),char(254),char(46),char(14),char(149),char(243), -char(137),char(177),char(82),char(244),char(65),char(235),char(109),char(50),char(44),char(72), -char(191),char(41),char(145),char(188),char(178),char(47),char(93),char(100),char(36),char(52), -char(46),char(186),char(150),char(180),char(182),char(74),char(115),char(151),char(224),char(246), -char(159),char(65),char(247),char(247),char(104),char(182),char(245),char(128),char(6),char(120), -char(65),char(190),char(83),char(144),char(192),char(126),char(120),char(82),char(91),char(28), -char(170),char(14),char(33),char(66),char(220),char(190),char(9),char(156),char(51),char(211), -char(70),char(80),char(144),char(59),char(5),char(153),char(16),char(43),char(89),char(105), -char(236),char(133),char(216),char(99),char(209),char(45),char(195),char(6),char(150),char(52), -char(237),char(20),char(163),char(156),char(242),char(241),char(84),char(64),char(213),char(71), -char(23),char(160),char(11),char(0),char(31),char(140),char(102),char(239),char(222),char(62), -char(27),char(161),char(130),char(1),char(127),char(48),char(130),char(1),char(123),char(6), -char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1),char(9),char(6), -char(49),char(130),char(1),char(108),char(48),char(130),char(1),char(104),char(2),char(1), -char(1),char(48),char(103),char(48),char(83),char(49),char(11),char(48),char(9),char(6), -char(3),char(85),char(4),char(6),char(19),char(2),char(85),char(83),char(49),char(23), -char(48),char(21),char(6),char(3),char(85),char(4),char(10),char(19),char(14),char(86), -char(101),char(114),char(105),char(83),char(105),char(103),char(110),char(44),char(32),char(73), -char(110),char(99),char(46),char(49),char(43),char(48),char(41),char(6),char(3),char(85), -char(4),char(3),char(19),char(34),char(86),char(101),char(114),char(105),char(83),char(105), -char(103),char(110),char(32),char(84),char(105),char(109),char(101),char(32),char(83),char(116), -char(97),char(109),char(112),char(105),char(110),char(103),char(32),char(83),char(101),char(114), -char(118),char(105),char(99),char(101),char(115),char(32),char(67),char(65),char(2),char(16), -char(56),char(37),char(215),char(250),char(248),char(97),char(175),char(158),char(244),char(144), -char(231),char(38),char(181),char(214),char(90),char(213),char(48),char(9),char(6),char(5), -char(43),char(14),char(3),char(2),char(26),char(5),char(0),char(160),char(93),char(48), -char(24),char(6),char(9),char(42),char(134),char(72),char(134),char(247),char(13),char(1), -char(9),char(3),char(49),char(11),char(6),char(9),char(42),char(134),char(72),char(134), -char(247),char(13),char(1),char(7),char(1),char(48),char(28),char(6),char(9),char(42), -char(134),char(72),char(134),char(247),char(13),char(1),char(9),char(5),char(49),char(15), -char(23),char(13),char(49),char(49),char(48),char(53),char(48),char(53),char(49),char(54), -char(53),char(53),char(49),char(48),char(90),char(48),char(35),char(6),char(9),char(42), -char(134),char(72),char(134),char(247),char(13),char(1),char(9),char(4),char(49),char(22), -char(4),char(20),char(84),char(23),char(8),char(43),char(11),char(189),char(238),char(26), -char(39),char(14),char(31),char(141),char(252),char(83),char(147),char(244),char(56),char(86), -char(16),char(15),char(48),char(13),char(6),char(9),char(42),char(134),char(72),char(134), -char(247),char(13),char(1),char(1),char(1),char(5),char(0),char(4),char(129),char(128), -char(29),char(193),char(119),char(137),char(174),char(155),char(111),char(34),char(227),char(107), -char(229),char(69),char(218),char(78),char(145),char(64),char(240),char(159),char(239),char(59), -char(31),char(39),char(74),char(86),char(172),char(58),char(253),char(168),char(148),char(106), -char(124),char(247),char(156),char(193),char(127),char(123),char(147),char(96),char(78),char(27), -char(196),char(43),char(87),char(149),char(148),char(203),char(22),char(225),char(154),char(103), -char(51),char(209),char(43),char(41),char(19),char(200),char(236),char(190),char(188),char(89), -char(177),char(3),char(164),char(41),char(153),char(236),char(29),char(136),char(153),char(36), -char(135),char(119),char(15),char(155),char(202),char(20),char(251),char(212),char(212),char(73), -char(76),char(116),char(14),char(200),char(61),char(46),char(111),char(32),char(201),char(3), -char(205),char(232),char(229),char(15),char(208),char(33),char(57),char(179),char(86),char(25), -char(213),char(251),char(172),char(189),char(172),char(169),char(56),char(189),char(176),char(213), -char(12),char(163),char(217),char(99),char(173),char(176),char(149),char(180),char(104),char(88), -char(195),char(226),char(215),char(41),char(255),char(145),char(164),char(199),char(0),char(0), - -}; \ No newline at end of file diff --git a/btgui/OpenGLWindow/OpenSans.ttf b/btgui/OpenGLWindow/OpenSans.ttf deleted file mode 100644 index db433349b..000000000 Binary files a/btgui/OpenGLWindow/OpenSans.ttf and /dev/null differ diff --git a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingPS.glsl b/btgui/OpenGLWindow/Shaders/createShadowMapInstancingPS.glsl deleted file mode 100644 index 75f39082a..000000000 --- a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingPS.glsl +++ /dev/null @@ -1,10 +0,0 @@ -#version 330 -precision highp float; - - -layout(location = 0) out float fragmentdepth; - -void main(void) -{ - fragmentdepth = gl_FragCoord.z; -} diff --git a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingPS.h b/btgui/OpenGLWindow/Shaders/createShadowMapInstancingPS.h deleted file mode 100644 index 8b2dce8f1..000000000 --- a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingPS.h +++ /dev/null @@ -1,10 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* createShadowMapInstancingFragmentShader= \ -"#version 330\n" -"precision highp float;\n" -"layout(location = 0) out float fragmentdepth;\n" -"void main(void)\n" -"{\n" -" fragmentdepth = gl_FragCoord.z;\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingVS.glsl b/btgui/OpenGLWindow/Shaders/createShadowMapInstancingVS.glsl deleted file mode 100644 index 86bbd6e8f..000000000 --- a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingVS.glsl +++ /dev/null @@ -1,55 +0,0 @@ -#version 330 -precision highp float; - - -layout (location = 0) in vec4 position; -layout (location = 1) in vec4 instance_position; -layout (location = 2) in vec4 instance_quaternion; -layout (location = 3) in vec2 uvcoords; -layout (location = 4) in vec3 vertexnormal; -layout (location = 5) in vec4 instance_color; -layout (location = 6) in vec3 instance_scale; - - -uniform mat4 depthMVP; - - -vec4 quatMul ( in vec4 q1, in vec4 q2 ) -{ - vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz ); - vec4 dt = q1 * q2; - float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) ); - return vec4 ( im, re ); -} - -vec4 quatFromAxisAngle(vec4 axis, in float angle) -{ - float cah = cos(angle*0.5); - float sah = sin(angle*0.5); - float d = inversesqrt(dot(axis,axis)); - vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah); - return q; -} -// -// vector rotation via quaternion -// -vec4 quatRotate3 ( in vec3 p, in vec4 q ) -{ - vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) ); - return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) ); -} -vec4 quatRotate ( in vec4 p, in vec4 q ) -{ - vec4 temp = quatMul ( q, p ); - return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) ); -} - - -void main(void) -{ - vec4 q = instance_quaternion; - vec4 localcoord = quatRotate3( position.xyz*instance_scale,q); - vec4 vertexPos = depthMVP * vec4( (instance_position+localcoord).xyz,1); - gl_Position = vertexPos; -} - diff --git a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingVS.h b/btgui/OpenGLWindow/Shaders/createShadowMapInstancingVS.h deleted file mode 100644 index 2a8aef96b..000000000 --- a/btgui/OpenGLWindow/Shaders/createShadowMapInstancingVS.h +++ /dev/null @@ -1,48 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* createShadowMapInstancingVertexShader= \ -"#version 330\n" -"precision highp float;\n" -"layout (location = 0) in vec4 position;\n" -"layout (location = 1) in vec4 instance_position;\n" -"layout (location = 2) in vec4 instance_quaternion;\n" -"layout (location = 3) in vec2 uvcoords;\n" -"layout (location = 4) in vec3 vertexnormal;\n" -"layout (location = 5) in vec4 instance_color;\n" -"layout (location = 6) in vec3 instance_scale;\n" -"uniform mat4 depthMVP;\n" -"vec4 quatMul ( in vec4 q1, in vec4 q2 )\n" -"{\n" -" vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz );\n" -" vec4 dt = q1 * q2;\n" -" float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) );\n" -" return vec4 ( im, re );\n" -"}\n" -"vec4 quatFromAxisAngle(vec4 axis, in float angle)\n" -"{\n" -" float cah = cos(angle*0.5);\n" -" float sah = sin(angle*0.5);\n" -" float d = inversesqrt(dot(axis,axis));\n" -" vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah);\n" -" return q;\n" -"}\n" -"//\n" -"// vector rotation via quaternion\n" -"//\n" -"vec4 quatRotate3 ( in vec3 p, in vec4 q )\n" -"{\n" -" vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) );\n" -" return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );\n" -"}\n" -"vec4 quatRotate ( in vec4 p, in vec4 q )\n" -"{\n" -" vec4 temp = quatMul ( q, p );\n" -" return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );\n" -"}\n" -"void main(void)\n" -"{\n" -" vec4 q = instance_quaternion;\n" -" vec4 localcoord = quatRotate3( position.xyz*instance_scale,q);\n" -" vec4 vertexPos = depthMVP * vec4( (instance_position+localcoord).xyz,1);\n" -" gl_Position = vertexPos;\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/instancingPS.glsl b/btgui/OpenGLWindow/Shaders/instancingPS.glsl deleted file mode 100644 index edb5bd9b7..000000000 --- a/btgui/OpenGLWindow/Shaders/instancingPS.glsl +++ /dev/null @@ -1,36 +0,0 @@ -#version 330 -precision highp float; - -in Fragment -{ - vec4 color; -} fragment; - -in Vert -{ - vec2 texcoord; -} vert; - -uniform sampler2D Diffuse; -in vec3 lightDir,normal,ambient; -out vec4 color; - -void main_textured(void) -{ - color = vec4(0.1,0.2,0.3,0.3); -} - -void main(void) -{ - vec4 texel = fragment.color*texture(Diffuse,vert.texcoord);//fragment.color; - vec3 ct,cf; - float intensity,at,af; - intensity = max(dot(lightDir,normalize(normal)),0); - cf = intensity*vec3(1.0,1.0,1.0)+ambient; - af = 1.0; - - ct = texel.rgb; - at = texel.a; - - color = vec4(ct * cf, at * af); -} diff --git a/btgui/OpenGLWindow/Shaders/instancingPS.h b/btgui/OpenGLWindow/Shaders/instancingPS.h deleted file mode 100644 index cf52431be..000000000 --- a/btgui/OpenGLWindow/Shaders/instancingPS.h +++ /dev/null @@ -1,34 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* instancingFragmentShader= \ -"#version 330\n" -"precision highp float;\n" -"in Fragment\n" -"{\n" -" vec4 color;\n" -"} fragment;\n" -"in Vert\n" -"{\n" -" vec2 texcoord;\n" -"} vert;\n" -"uniform sampler2D Diffuse;\n" -"in vec3 lightDir,normal,ambient;\n" -"out vec4 color;\n" -"void main_textured(void)\n" -"{\n" -" color = vec4(0.1,0.2,0.3,0.3);\n" -"}\n" -"void main(void)\n" -"{\n" -" vec4 texel = fragment.color*texture(Diffuse,vert.texcoord);//fragment.color;\n" -" vec3 ct,cf;\n" -" float intensity,at,af;\n" -" intensity = max(dot(lightDir,normalize(normal)),0);\n" -" cf = intensity*vec3(1.0,1.0,1.0)+ambient;\n" -" af = 1.0;\n" -" \n" -" ct = texel.rgb;\n" -" at = texel.a;\n" -" \n" -" color = vec4(ct * cf, at * af); \n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/instancingVS.glsl b/btgui/OpenGLWindow/Shaders/instancingVS.glsl deleted file mode 100644 index 3c0cbc683..000000000 --- a/btgui/OpenGLWindow/Shaders/instancingVS.glsl +++ /dev/null @@ -1,82 +0,0 @@ -#version 330 -precision highp float; - - -layout (location = 0) in vec4 position; -layout (location = 1) in vec4 instance_position; -layout (location = 2) in vec4 instance_quaternion; -layout (location = 3) in vec2 uvcoords; -layout (location = 4) in vec3 vertexnormal; -layout (location = 5) in vec4 instance_color; -layout (location = 6) in vec3 instance_scale; - - -uniform mat4 ModelViewMatrix; -uniform mat4 ProjectionMatrix; - -out Fragment -{ - vec4 color; -} fragment; - -out Vert -{ - vec2 texcoord; -} vert; - - -vec4 quatMul ( in vec4 q1, in vec4 q2 ) -{ - vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz ); - vec4 dt = q1 * q2; - float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) ); - return vec4 ( im, re ); -} - -vec4 quatFromAxisAngle(vec4 axis, in float angle) -{ - float cah = cos(angle*0.5); - float sah = sin(angle*0.5); - float d = inversesqrt(dot(axis,axis)); - vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah); - return q; -} -// -// vector rotation via quaternion -// -vec4 quatRotate3 ( in vec3 p, in vec4 q ) -{ - vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) ); - return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) ); -} -vec4 quatRotate ( in vec4 p, in vec4 q ) -{ - vec4 temp = quatMul ( q, p ); - return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) ); -} - -out vec3 lightDir,normal,ambient; - -void main(void) -{ - vec4 q = instance_quaternion; - ambient = vec3(0.3,.3,0.3); - - - vec4 local_normal = (quatRotate3( vertexnormal,q)); - vec3 light_pos = vec3(-0.3,0.1,0.1); - normal = local_normal.xyz;//normalize(ModelViewMatrix * local_normal).xyz; - - lightDir = normalize(light_pos);//gl_LightSource[0].position.xyz)); -// lightDir = normalize(vec3(gl_LightSource[0].position)); - - vec4 axis = vec4(1,1,1,0); - vec4 localcoord = quatRotate3( position.xyz*instance_scale,q); - vec4 vertexPos = ProjectionMatrix * ModelViewMatrix *(instance_position+localcoord); - - gl_Position = vertexPos; - - fragment.color = instance_color; - vert.texcoord = uvcoords; -} - diff --git a/btgui/OpenGLWindow/Shaders/instancingVS.h b/btgui/OpenGLWindow/Shaders/instancingVS.h deleted file mode 100644 index 94abae198..000000000 --- a/btgui/OpenGLWindow/Shaders/instancingVS.h +++ /dev/null @@ -1,71 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* instancingVertexShader= \ -"#version 330\n" -"precision highp float;\n" -"layout (location = 0) in vec4 position;\n" -"layout (location = 1) in vec4 instance_position;\n" -"layout (location = 2) in vec4 instance_quaternion;\n" -"layout (location = 3) in vec2 uvcoords;\n" -"layout (location = 4) in vec3 vertexnormal;\n" -"layout (location = 5) in vec4 instance_color;\n" -"layout (location = 6) in vec3 instance_scale;\n" -"uniform mat4 ModelViewMatrix;\n" -"uniform mat4 ProjectionMatrix;\n" -"out Fragment\n" -"{\n" -" vec4 color;\n" -"} fragment;\n" -"out Vert\n" -"{\n" -" vec2 texcoord;\n" -"} vert;\n" -"vec4 quatMul ( in vec4 q1, in vec4 q2 )\n" -"{\n" -" vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz );\n" -" vec4 dt = q1 * q2;\n" -" float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) );\n" -" return vec4 ( im, re );\n" -"}\n" -"vec4 quatFromAxisAngle(vec4 axis, in float angle)\n" -"{\n" -" float cah = cos(angle*0.5);\n" -" float sah = sin(angle*0.5);\n" -" float d = inversesqrt(dot(axis,axis));\n" -" vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah);\n" -" return q;\n" -"}\n" -"//\n" -"// vector rotation via quaternion\n" -"//\n" -"vec4 quatRotate3 ( in vec3 p, in vec4 q )\n" -"{\n" -" vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) );\n" -" return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );\n" -"}\n" -"vec4 quatRotate ( in vec4 p, in vec4 q )\n" -"{\n" -" vec4 temp = quatMul ( q, p );\n" -" return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );\n" -"}\n" -"out vec3 lightDir,normal,ambient;\n" -"void main(void)\n" -"{\n" -" vec4 q = instance_quaternion;\n" -" ambient = vec3(0.3,.3,0.3);\n" -" \n" -" \n" -" vec4 local_normal = (quatRotate3( vertexnormal,q));\n" -" vec3 light_pos = vec3(-0.3,0.1,0.1);\n" -" normal = local_normal.xyz;//normalize(ModelViewMatrix * local_normal).xyz;\n" -" lightDir = normalize(light_pos);//gl_LightSource[0].position.xyz));\n" -"// lightDir = normalize(vec3(gl_LightSource[0].position));\n" -" \n" -" vec4 axis = vec4(1,1,1,0);\n" -" vec4 localcoord = quatRotate3( position.xyz*instance_scale,q);\n" -" vec4 vertexPos = ProjectionMatrix * ModelViewMatrix *(instance_position+localcoord);\n" -" gl_Position = vertexPos;\n" -" \n" -" fragment.color = instance_color;\n" -" vert.texcoord = uvcoords;\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/linesPS.glsl b/btgui/OpenGLWindow/Shaders/linesPS.glsl deleted file mode 100644 index c646fa11b..000000000 --- a/btgui/OpenGLWindow/Shaders/linesPS.glsl +++ /dev/null @@ -1,10 +0,0 @@ - -#version 150 - -in vec4 colourV; -out vec4 fragColour; - -void main(void) -{ - fragColour = colourV; -} diff --git a/btgui/OpenGLWindow/Shaders/linesPS.h b/btgui/OpenGLWindow/Shaders/linesPS.h deleted file mode 100644 index 49a4cf3eb..000000000 --- a/btgui/OpenGLWindow/Shaders/linesPS.h +++ /dev/null @@ -1,10 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* linesFragmentShader= \ -"#version 150\n" -"in vec4 colourV;\n" -"out vec4 fragColour;\n" -"void main(void)\n" -"{\n" -" fragColour = colourV;\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/linesVS.glsl b/btgui/OpenGLWindow/Shaders/linesVS.glsl deleted file mode 100644 index f28363dac..000000000 --- a/btgui/OpenGLWindow/Shaders/linesVS.glsl +++ /dev/null @@ -1,17 +0,0 @@ -#version 150 - -uniform mat4 ModelViewMatrix; -uniform mat4 ProjectionMatrix; -uniform vec4 colour; - -in vec4 position; - - -out vec4 colourV; - -void main (void) -{ - colourV = colour; - gl_Position = ProjectionMatrix * ModelViewMatrix * position; - -} diff --git a/btgui/OpenGLWindow/Shaders/linesVS.h b/btgui/OpenGLWindow/Shaders/linesVS.h deleted file mode 100644 index 8fc6eb3e7..000000000 --- a/btgui/OpenGLWindow/Shaders/linesVS.h +++ /dev/null @@ -1,15 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* linesVertexShader= \ -"#version 150 \n" -"uniform mat4 ModelViewMatrix;\n" -"uniform mat4 ProjectionMatrix;\n" -"uniform vec4 colour;\n" -"in vec4 position;\n" -"out vec4 colourV;\n" -"void main (void)\n" -"{\n" -" colourV = colour;\n" -" gl_Position = ProjectionMatrix * ModelViewMatrix * position;\n" -" \n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/pointSpritePS.glsl b/btgui/OpenGLWindow/Shaders/pointSpritePS.glsl deleted file mode 100644 index 9e8190be4..000000000 --- a/btgui/OpenGLWindow/Shaders/pointSpritePS.glsl +++ /dev/null @@ -1,37 +0,0 @@ - -#version 330 -precision highp float; - -in Fragment -{ - vec4 color; -} fragment; - - -in vec3 ambient; - -out vec4 color; - -void main_textured(void) -{ - color = fragment.color;//texture2D(Diffuse,vert.texcoord);//fragment.color; -} - -void main(void) -{ - vec3 N; - N.xy = gl_PointCoord.st*vec2(2.0, -2.0) + vec2(-1.0, 1.0); - float mag = dot(N.xy, N.xy); - if (mag > 1.0) discard; - vec4 texel = fragment.color;//vec4(1,0,0,1);//fragment.color*texture(Diffuse,vert.texcoord);//fragment.color; - vec3 ct; - float at,af; - af = 1.0; - - ct = texel.rgb; - at = texel.a; - - vec3 lightDir= vec3(1,0,0); - float diffuse = max(0.0, dot(lightDir, N)); - color = vec4(ct * diffuse, at * af); -} diff --git a/btgui/OpenGLWindow/Shaders/pointSpritePS.h b/btgui/OpenGLWindow/Shaders/pointSpritePS.h deleted file mode 100644 index e0d57e238..000000000 --- a/btgui/OpenGLWindow/Shaders/pointSpritePS.h +++ /dev/null @@ -1,33 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* pointSpriteFragmentShader= \ -"#version 330\n" -"precision highp float;\n" -"in Fragment\n" -"{\n" -" vec4 color;\n" -"} fragment;\n" -"in vec3 ambient;\n" -"out vec4 color;\n" -"void main_textured(void)\n" -"{\n" -" color = fragment.color;//texture2D(Diffuse,vert.texcoord);//fragment.color;\n" -"}\n" -"void main(void)\n" -"{\n" -" vec3 N;\n" -" N.xy = gl_PointCoord.st*vec2(2.0, -2.0) + vec2(-1.0, 1.0);\n" -" float mag = dot(N.xy, N.xy);\n" -" if (mag > 1.0) discard; \n" -" vec4 texel = fragment.color;//vec4(1,0,0,1);//fragment.color*texture(Diffuse,vert.texcoord);//fragment.color;\n" -" vec3 ct;\n" -" float at,af;\n" -" af = 1.0;\n" -" \n" -" ct = texel.rgb;\n" -" at = texel.a;\n" -" \n" -" vec3 lightDir= vec3(1,0,0);\n" -" float diffuse = max(0.0, dot(lightDir, N));\n" -" color = vec4(ct * diffuse, at * af); \n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/pointSpriteVS.glsl b/btgui/OpenGLWindow/Shaders/pointSpriteVS.glsl deleted file mode 100644 index 27bfa33f5..000000000 --- a/btgui/OpenGLWindow/Shaders/pointSpriteVS.glsl +++ /dev/null @@ -1,46 +0,0 @@ -#version 330 -precision highp float; - - - -layout (location = 0) in vec4 position; -layout (location = 1) in vec4 instance_position; -layout (location = 3) in vec2 uvcoords; -layout (location = 4) in vec3 vertexnormal; -layout (location = 5) in vec4 instance_color; -layout (location = 6) in vec3 instance_scale; - - -uniform float screenWidth = 700.f; -uniform mat4 ModelViewMatrix; -uniform mat4 ProjectionMatrix; - -out Fragment -{ - vec4 color; -} fragment; - - - -// -// vector rotation via quaternion -// - -out vec3 ambient; - -void main(void) -{ - ambient = vec3(0.3,.3,0.3); - - - vec4 axis = vec4(1,1,1,0); - vec4 vertexPos = ProjectionMatrix * ModelViewMatrix *(instance_position); - vec3 posEye = vec3(ModelViewMatrix * vec4(instance_position.xyz, 1.0)); - float dist = length(posEye); - float pointRadius = 1.f; - gl_PointSize = instance_scale.x * pointRadius * (screenWidth / dist); - - gl_Position = vertexPos; - - fragment.color = instance_color; -} diff --git a/btgui/OpenGLWindow/Shaders/pointSpriteVS.h b/btgui/OpenGLWindow/Shaders/pointSpriteVS.h deleted file mode 100644 index 1234a37a5..000000000 --- a/btgui/OpenGLWindow/Shaders/pointSpriteVS.h +++ /dev/null @@ -1,37 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* pointSpriteVertexShader= \ -"#version 330\n" -"precision highp float;\n" -"layout (location = 0) in vec4 position;\n" -"layout (location = 1) in vec4 instance_position;\n" -"layout (location = 3) in vec2 uvcoords;\n" -"layout (location = 4) in vec3 vertexnormal;\n" -"layout (location = 5) in vec4 instance_color;\n" -"layout (location = 6) in vec3 instance_scale;\n" -"uniform float screenWidth = 700.f;\n" -"uniform mat4 ModelViewMatrix;\n" -"uniform mat4 ProjectionMatrix;\n" -"out Fragment\n" -"{\n" -" vec4 color;\n" -"} fragment;\n" -"//\n" -"// vector rotation via quaternion\n" -"//\n" -"out vec3 ambient;\n" -"void main(void)\n" -"{\n" -" ambient = vec3(0.3,.3,0.3);\n" -" \n" -" \n" -" vec4 axis = vec4(1,1,1,0);\n" -" vec4 vertexPos = ProjectionMatrix * ModelViewMatrix *(instance_position);\n" -" vec3 posEye = vec3(ModelViewMatrix * vec4(instance_position.xyz, 1.0));\n" -" float dist = length(posEye);\n" -" float pointRadius = 1.f;\n" -" gl_PointSize = instance_scale.x * pointRadius * (screenWidth / dist);\n" -" gl_Position = vertexPos;\n" -" \n" -" fragment.color = instance_color;\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingPS.glsl b/btgui/OpenGLWindow/Shaders/useShadowMapInstancingPS.glsl deleted file mode 100644 index c4913d702..000000000 --- a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingPS.glsl +++ /dev/null @@ -1,56 +0,0 @@ -#version 330 core -//precision highp float; - -in Fragment -{ - vec4 color; -} fragment; - -in Vert -{ - vec2 texcoord; -} vert; - -uniform sampler2D Diffuse; -uniform sampler2DShadow shadowMap; - -in vec3 lightDir,normal,ambient; -in vec4 ShadowCoord; - -out vec4 color; - - - -void main(void) -{ - vec4 texel = fragment.color*texture(Diffuse,vert.texcoord);//fragment.color; - vec3 ct,cf; - float intensity,at,af; - - intensity = clamp( dot( normalize(normal),lightDir ), 0,1 ); - - cf = ambient; - af = 1.0; - - ct = texel.rgb; - at = texel.a; - - //float bias = 0.005f; - - float bias = 0.0001*tan(acos(intensity)); - bias = clamp(bias, 0,0.01); - - - float visibility = texture(shadowMap, vec3(ShadowCoord.xy,(ShadowCoord.z-bias)/ShadowCoord.w)); - - intensity*=2; - if (intensity>1) - intensity=1.f; - - visibility *= intensity; - - if (visibility<0.6) - visibility=0.6f; - - color = vec4(ct * visibility, fragment.color.w); -} diff --git a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingPS.h b/btgui/OpenGLWindow/Shaders/useShadowMapInstancingPS.h deleted file mode 100644 index d43ec5dcb..000000000 --- a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingPS.h +++ /dev/null @@ -1,49 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* useShadowMapInstancingFragmentShader= \ -"#version 330 core\n" -"//precision highp float;\n" -"in Fragment\n" -"{\n" -" vec4 color;\n" -"} fragment;\n" -"in Vert\n" -"{\n" -" vec2 texcoord;\n" -"} vert;\n" -"uniform sampler2D Diffuse;\n" -"uniform sampler2DShadow shadowMap;\n" -"in vec3 lightDir,normal,ambient;\n" -"in vec4 ShadowCoord;\n" -"out vec4 color;\n" -"void main(void)\n" -"{\n" -" vec4 texel = fragment.color*texture(Diffuse,vert.texcoord);//fragment.color;\n" -" vec3 ct,cf;\n" -" float intensity,at,af;\n" -" \n" -" intensity = clamp( dot( normalize(normal),lightDir ), 0,1 );\n" -" \n" -" cf = ambient;\n" -" af = 1.0;\n" -" \n" -" ct = texel.rgb;\n" -" at = texel.a;\n" -" \n" -" //float bias = 0.005f;\n" -" \n" -" float bias = 0.0001*tan(acos(intensity));\n" -" bias = clamp(bias, 0,0.01);\n" -" float visibility = texture(shadowMap, vec3(ShadowCoord.xy,(ShadowCoord.z-bias)/ShadowCoord.w));\n" -" \n" -" intensity*=2;\n" -" if (intensity>1)\n" -" intensity=1.f;\n" -" \n" -" visibility *= intensity;\n" -" \n" -" if (visibility<0.6)\n" -" visibility=0.6f;\n" -" \n" -" color = vec4(ct * visibility, fragment.color.w);\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingVS.glsl b/btgui/OpenGLWindow/Shaders/useShadowMapInstancingVS.glsl deleted file mode 100644 index fe16aaf4c..000000000 --- a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingVS.glsl +++ /dev/null @@ -1,86 +0,0 @@ -#version 330 -precision highp float; - - -layout (location = 0) in vec4 position; -layout (location = 1) in vec4 instance_position; -layout (location = 2) in vec4 instance_quaternion; -layout (location = 3) in vec2 uvcoords; -layout (location = 4) in vec3 vertexnormal; -layout (location = 5) in vec4 instance_color; -layout (location = 6) in vec3 instance_scale; - - -uniform mat4 ModelViewMatrix; -uniform mat4 ProjectionMatrix; -uniform mat4 DepthBiasModelViewProjectionMatrix; -uniform mat4 MVP; -uniform vec3 lightDirIn; - -out vec4 ShadowCoord; - -out Fragment -{ - vec4 color; -} fragment; - -out Vert -{ - vec2 texcoord; -} vert; - - -vec4 quatMul ( in vec4 q1, in vec4 q2 ) -{ - vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz ); - vec4 dt = q1 * q2; - float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) ); - return vec4 ( im, re ); -} - -vec4 quatFromAxisAngle(vec4 axis, in float angle) -{ - float cah = cos(angle*0.5); - float sah = sin(angle*0.5); - float d = inversesqrt(dot(axis,axis)); - vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah); - return q; -} -// -// vector rotation via quaternion -// -vec4 quatRotate3 ( in vec3 p, in vec4 q ) -{ - vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) ); - return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) ); -} -vec4 quatRotate ( in vec4 p, in vec4 q ) -{ - vec4 temp = quatMul ( q, p ); - return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) ); -} - -out vec3 lightDir,normal,ambient; - -void main(void) -{ - vec4 q = instance_quaternion; - ambient = vec3(0.3,.3,0.3); - - vec4 worldNormal = (quatRotate3( vertexnormal,q)); - - normal = normalize(worldNormal).xyz; - - lightDir = lightDirIn; - - vec4 axis = vec4(1,1,1,0); - vec4 localcoord = quatRotate3( position.xyz*instance_scale,q); - vec4 vertexPos = MVP* vec4((instance_position+localcoord).xyz,1); - - gl_Position = vertexPos; - ShadowCoord = DepthBiasModelViewProjectionMatrix * vec4((instance_position+localcoord).xyz,1); - - fragment.color = instance_color; - vert.texcoord = uvcoords; -} - diff --git a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingVS.h b/btgui/OpenGLWindow/Shaders/useShadowMapInstancingVS.h deleted file mode 100644 index 8c2ee8765..000000000 --- a/btgui/OpenGLWindow/Shaders/useShadowMapInstancingVS.h +++ /dev/null @@ -1,73 +0,0 @@ -//this file is autogenerated using stringify.bat (premake --stringify) in the build folder of this project -static const char* useShadowMapInstancingVertexShader= \ -"#version 330 \n" -"precision highp float;\n" -"layout (location = 0) in vec4 position;\n" -"layout (location = 1) in vec4 instance_position;\n" -"layout (location = 2) in vec4 instance_quaternion;\n" -"layout (location = 3) in vec2 uvcoords;\n" -"layout (location = 4) in vec3 vertexnormal;\n" -"layout (location = 5) in vec4 instance_color;\n" -"layout (location = 6) in vec3 instance_scale;\n" -"uniform mat4 ModelViewMatrix;\n" -"uniform mat4 ProjectionMatrix;\n" -"uniform mat4 DepthBiasModelViewProjectionMatrix;\n" -"uniform mat4 MVP;\n" -"uniform vec3 lightDirIn;\n" -"out vec4 ShadowCoord;\n" -"out Fragment\n" -"{\n" -" vec4 color;\n" -"} fragment;\n" -"out Vert\n" -"{\n" -" vec2 texcoord;\n" -"} vert;\n" -"vec4 quatMul ( in vec4 q1, in vec4 q2 )\n" -"{\n" -" vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz );\n" -" vec4 dt = q1 * q2;\n" -" float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) );\n" -" return vec4 ( im, re );\n" -"}\n" -"vec4 quatFromAxisAngle(vec4 axis, in float angle)\n" -"{\n" -" float cah = cos(angle*0.5);\n" -" float sah = sin(angle*0.5);\n" -" float d = inversesqrt(dot(axis,axis));\n" -" vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah);\n" -" return q;\n" -"}\n" -"//\n" -"// vector rotation via quaternion\n" -"//\n" -"vec4 quatRotate3 ( in vec3 p, in vec4 q )\n" -"{\n" -" vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) );\n" -" return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );\n" -"}\n" -"vec4 quatRotate ( in vec4 p, in vec4 q )\n" -"{\n" -" vec4 temp = quatMul ( q, p );\n" -" return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );\n" -"}\n" -"out vec3 lightDir,normal,ambient;\n" -"void main(void)\n" -"{\n" -" vec4 q = instance_quaternion;\n" -" ambient = vec3(0.3,.3,0.3);\n" -" \n" -" vec4 worldNormal = (quatRotate3( vertexnormal,q));\n" -" \n" -" normal = normalize(worldNormal).xyz;\n" -" lightDir = lightDirIn;\n" -" \n" -" vec4 axis = vec4(1,1,1,0);\n" -" vec4 localcoord = quatRotate3( position.xyz*instance_scale,q);\n" -" vec4 vertexPos = MVP* vec4((instance_position+localcoord).xyz,1);\n" -" gl_Position = vertexPos;\n" -" ShadowCoord = DepthBiasModelViewProjectionMatrix * vec4((instance_position+localcoord).xyz,1);\n" -" fragment.color = instance_color;\n" -" vert.texcoord = uvcoords;\n" -"}\n" -; diff --git a/btgui/OpenGLWindow/ShapeData.h b/btgui/OpenGLWindow/ShapeData.h deleted file mode 100644 index f538f1e5f..000000000 --- a/btgui/OpenGLWindow/ShapeData.h +++ /dev/null @@ -1,4860 +0,0 @@ -#ifndef SHAPE_DATA_H -#define SHAPE_DATA_H - -#ifdef USE_BARREL_VERTICES -static float barrel_vertices[] = { -0.0f,-0.5f,0.0f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.282362f,-0.5f,-0.205148f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.349018f,-0.5f,0.0f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.107853f,-0.5f,-0.331936f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, --0.107853f,-0.5f,-0.331936f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.107853f,-0.5f,-0.331936f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, --0.282362f,-0.5f,-0.205148f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, --0.349018f,-0.5f,0.0f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, --0.282362f,-0.5f,0.205148f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, --0.107853f,-0.5f,0.331936f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.107853f,-0.5f,0.331936f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.282362f,-0.5f,0.205148f, 1.0f, 0.0f,-1.0f,0.0f, 0.5f, 0.5f, -0.0f,0.5f,0.0f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.349018f,0.5f,0.0f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.282362f,0.5f,-0.205148f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.107853f,0.5f,-0.331936f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.107853f,0.5f,-0.331936f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, --0.107853f,0.5f,-0.331936f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, --0.282362f,0.5f,-0.205148f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, --0.349018f,0.5f,0.0f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, --0.282362f,0.5f,0.205148f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, --0.107853f,0.5f,0.331936f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.107853f,0.5f,0.331936f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.282362f,0.5f,0.205148f, 1.0f, 0.0f,1.0f,0.0f, 0.5f, 0.5f, -0.349018f,-0.5f,0.0f, 1.0f, 0.957307f,-0.289072f,0.0f, 0.5f, 0.5f, -0.404509f,0.0f,-0.293893f, 1.0f, 0.809017f,0.0f,-0.587785f, 0.5f, 0.5f, -0.5f,0.0f,0.0f, 1.0f, 1.0f,0.0f,0.0f, 0.5f, 0.5f, -0.282362f,-0.5f,-0.205148f, 1.0f, 0.774478f,-0.289072f,-0.562691f, 0.5f, 0.5f, -0.154508f,0.0f,-0.475528f, 1.0f, 0.309017f,0.0f,-0.951057f, 0.5f, 0.5f, -0.107853f,-0.5f,-0.331936f, 1.0f, 0.295824f,-0.289072f,-0.910453f, 0.5f, 0.5f, -0.107853f,-0.5f,-0.331936f, 1.0f, 0.295824f,-0.289072f,-0.910453f, 0.5f, 0.5f, --0.154509f,0.0f,-0.475528f, 1.0f, -0.309017f,0.0f,-0.951057f, 0.5f, 0.5f, -0.154508f,0.0f,-0.475528f, 1.0f, 0.309017f,0.0f,-0.951057f, 0.5f, 0.5f, --0.107853f,-0.5f,-0.331936f, 1.0f, -0.295824f,-0.289072f,-0.910453f, 0.5f, 0.5f, --0.404509f,0.0f,-0.293893f, 1.0f, -0.809017f,0.0f,-0.587785f, 0.5f, 0.5f, --0.282362f,-0.5f,-0.205148f, 1.0f, -0.774478f,-0.289072f,-0.562691f, 0.5f, 0.5f, --0.5f,0.0f,0.0f, 1.0f, -1.0f,0.0f,0.0f, 0.5f, 0.5f, --0.349018f,-0.5f,0.0f, 1.0f, -0.957307f,-0.289072f,0.0f, 0.5f, 0.5f, --0.404508f,0.0f,0.293893f, 1.0f, -0.809017f,0.0f,0.587785f, 0.5f, 0.5f, --0.282362f,-0.5f,0.205148f, 1.0f, -0.774478f,-0.289072f,0.562691f, 0.5f, 0.5f, --0.154509f,0.0f,0.475528f, 1.0f, -0.309017f,0.0f,0.951056f, 0.5f, 0.5f, --0.107853f,-0.5f,0.331936f, 1.0f, -0.295824f,-0.289072f,0.910453f, 0.5f, 0.5f, -0.154509f,0.0f,0.475528f, 1.0f, 0.309017f,0.0f,0.951056f, 0.5f, 0.5f, -0.107853f,-0.5f,0.331936f, 1.0f, 0.295824f,-0.289072f,0.910453f, 0.5f, 0.5f, -0.404509f,0.0f,0.293892f, 1.0f, 0.809017f,0.0f,0.587785f, 0.5f, 0.5f, -0.282362f,-0.5f,0.205148f, 1.0f, 0.774478f,-0.289072f,0.562691f, 0.5f, 0.5f, -0.282362f,0.5f,-0.205148f, 1.0f, 0.774478f,0.289072f,-0.562691f, 0.5f, 0.5f, -0.349018f,0.5f,0.0f, 1.0f, 0.957307f,0.289072f,0.0f, 0.5f, 0.5f, -0.107853f,0.5f,-0.331936f, 1.0f, 0.295824f,0.289072f,-0.910453f, 0.5f, 0.5f, --0.107853f,0.5f,-0.331936f, 1.0f, -0.295824f,0.289072f,-0.910453f, 0.5f, 0.5f, -0.107853f,0.5f,-0.331936f, 1.0f, 0.295824f,0.289072f,-0.910453f, 0.5f, 0.5f, --0.282362f,0.5f,-0.205148f, 1.0f, -0.774478f,0.289072f,-0.562691f, 0.5f, 0.5f, --0.349018f,0.5f,0.0f, 1.0f, -0.957307f,0.289072f,0.0f, 0.5f, 0.5f, --0.282362f,0.5f,0.205148f, 1.0f, -0.774478f,0.289072f,0.562691f, 0.5f, 0.5f, --0.107853f,0.5f,0.331936f, 1.0f, -0.295824f,0.289072f,0.910453f, 0.5f, 0.5f, -0.107853f,0.5f,0.331936f, 1.0f, 0.295824f,0.289072f,0.910453f, 0.5f, 0.5f, -0.282362f,0.5f,0.205148f, 1.0f, 0.774478f,0.289072f,0.562691f, 0.5f, 0.5f -}; - - - -static int barrel_indices[] = { -0,1,2, -0,3,1, -0,4,5, -0,6,4, -0,7,6, -0,8,7, -0,9,8, -0,10,9, -0,11,10, -0,2,11, -12,13,14, -12,14,15, -12,16,17, -12,17,18, -12,18,19, -12,19,20, -12,20,21, -12,21,22, -12,22,23, -12,23,13, -24,25,26, -24,27,25, -27,28,25, -27,29,28, -30,31,32, -30,33,31, -33,34,31, -33,35,34, -35,36,34, -35,37,36, -37,38,36, -37,39,38, -39,40,38, -39,41,40, -41,42,40, -41,43,42, -43,44,42, -43,45,44, -45,26,44, -45,24,26, -26,46,47, -26,25,46, -25,48,46, -25,28,48, -32,49,50, -32,31,49, -31,51,49, -31,34,51, -34,52,51, -34,36,52, -36,53,52, -36,38,53, -38,54,53, -38,40,54, -40,55,54, -40,42,55, -42,56,55, -42,44,56, -44,47,56, -44,26,47, -}; -#endif //USE_BARREL_VERTICES - -///position xyz, unused w, normal, uv -static const float cube_vertices[] = -{ - -1.0f, -1.0f, 1.0f, 1.0f, 0,0,1, 0,0,//0 - 1.0f, -1.0f, 1.0f, 1.0f, 0,0,1, 1,0,//1 - 1.0f, 1.0f, 1.0f, 1.0f, 0,0,1, 1,1,//2 - -1.0f, 1.0f, 1.0f, 1.0f, 0,0,1, 0,1 ,//3 - - -1.0f, -1.0f, -1.0f, 1.0f, 0,0,-1, 0,0,//4 - 1.0f, -1.0f, -1.0f, 1.0f, 0,0,-1, 1,0,//5 - 1.0f, 1.0f, -1.0f, 1.0f, 0,0,-1, 1,1,//6 - -1.0f, 1.0f, -1.0f, 1.0f, 0,0,-1, 0,1,//7 - - -1.0f, -1.0f, -1.0f, 1.0f, -1,0,0, 0,0, - -1.0f, 1.0f, -1.0f, 1.0f, -1,0,0, 1,0, - -1.0f, 1.0f, 1.0f, 1.0f, -1,0,0, 1,1, - -1.0f, -1.0f, 1.0f, 1.0f, -1,0,0, 0,1, - - 1.0f, -1.0f, -1.0f, 1.0f, 1,0,0, 0,0, - 1.0f, 1.0f, -1.0f, 1.0f, 1,0,0, 1,0, - 1.0f, 1.0f, 1.0f, 1.0f, 1,0,0, 1,1, - 1.0f, -1.0f, 1.0f, 1.0f, 1,0,0, 0,1, - - -1.0f, -1.0f, -1.0f, 1.0f, 0,-1,0, 0,0, - -1.0f, -1.0f, 1.0f, 1.0f, 0,-1,0, 1,0, - 1.0f, -1.0f, 1.0f, 1.0f, 0,-1,0, 1,1, - 1.0f,-1.0f, -1.0f, 1.0f, 0,-1,0, 0,1, - - -1.0f, 1.0f, -1.0f, 1.0f, 0,1,0, 0,0, - -1.0f, 1.0f, 1.0f, 1.0f, 0,1,0, 1,0, - 1.0f, 1.0f, 1.0f, 1.0f, 0,1,0, 1,1, - 1.0f,1.0f, -1.0f, 1.0f, 0,1,0, 0,1, -}; - -///position xyz, unused w, normal, uv -static const float cube_vertices_textured[] = -{ - -1.0f, -1.0f, 1.0f, 1.0f, 0,0,1, 0.75,0.25,//0//back - 1.0f, -1.0f, 1.0f, 1.0f, 0,0,1, 1,0.25 ,//1 - 1.0f, 1.0f, 1.0f, 1.0f, 0,0,1, 1,0,//2 - -1.0f, 1.0f, 1.0f, 1.0f, 0,0,1, 0.75,0,//3 - - -1.0f, -1.0f, -1.0f, 1.0f, 0,0,-1, 0.5,0.25,//4//front - 1.0f, -1.0f, -1.0f, 1.0f, 0,0,-1, 0.25,0.25,//5 - 1.0f, 1.0f, -1.0f, 1.0f, 0,0,-1, 0.25,0,//6 - -1.0f, 1.0f, -1.0f, 1.0f, 0,0,-1, 0.5,0,//7 - - -1.0f, -1.0f, -1.0f, 1.0f, -1,0,0, 0.5,0,//Right - -1.0f, 1.0f, -1.0f, 1.0f, -1,0,0, 0.75,0, - -1.0f, 1.0f, 1.0f, 1.0f, -1,0,0, 0.75,0.25, - -1.0f, -1.0f, 1.0f, 1.0f, -1,0,0, 0.5,0.25, - - 1.0f, -1.0f, -1.0f, 1.0f, 1,0,0, 0.25,0.5,//Left - 1.0f, 1.0f, -1.0f, 1.0f, 1,0,0, 0.25,0.25, - 1.0f, 1.0f, 1.0f, 1.0f, 1,0,0, 0.,.25, - 1.0f, -1.0f, 1.0f, 1.0f, 1,0,0, 0,.5, - - -1.0f, -1.0f, -1.0f, 1.0f, 0,-1,0, 0.25,0.5,//bottom - -1.0f, -1.0f, 1.0f, 1.0f, 0,-1,0, 0.25,0.25, - 1.0f, -1.0f, 1.0f, 1.0f, 0,-1,0, 0.5,0.25, - 1.0f,-1.0f, -1.0f, 1.0f, 0,-1,0, 0.5,0.5, - - -1.0f, 1.0f, -1.0f, 1.0f, 0,1,0, 0,0,//top - -1.0f, 1.0f, 1.0f, 1.0f, 0,1,0, 0,0.25, - 1.0f, 1.0f, 1.0f, 1.0f, 0,1,0, 0.25,0.25, - 1.0f,1.0f, -1.0f, 1.0f, 0,1,0, 0.25,0, -}; - - - -///position xyz, unused w, normal, uv -static const float cube_vertices2[] = -{ - -1.5f, -0.5f, 0.5f, 0.0f, 0,0,1, 0,0,//0 - 1.5f, -0.5f, 0.5f, 0.0f, 0,0,1, 1,0,//1 - 1.5f, 0.5f, 0.5f, 0.0f, 0,0,1, 1,1,//2 - -1.5f, 0.5f, 0.5f, 0.0f, 0,0,1, 0,1 ,//3 - - -1.5f, -0.5f, -0.5f, 0.5f, 0,0,-1, 0,0,//4 - 1.5f, -0.5f, -0.5f, 0.5f, 0,0,-1, 1,0,//5 - 1.5f, 0.5f, -0.5f, 0.5f, 0,0,-1, 1,1,//6 - -1.5f, 0.5f, -0.5f, 0.5f, 0,0,-1, 0,1,//7 - - -1.5f, -0.5f, -0.5f, 0.5f, -1,0,0, 0,0, - -1.5f, 0.5f, -0.5f, 0.5f, -1,0,0, 1,0, - -1.5f, 0.5f, 0.5f, 0.5f, -1,0,0, 1,1, - -1.5f, -0.5f, 0.5f, 0.5f, -1,0,0, 0,1, - - 1.5f, -0.5f, -0.5f, 0.5f, 1,0,0, 0,0, - 1.5f, 0.5f, -0.5f, 0.5f, 1,0,0, 1,0, - 1.5f, 0.5f, 0.5f, 0.5f, 1,0,0, 1,1, - 1.5f, -0.5f, 0.5f, 0.5f, 1,0,0, 0,1, - - -1.5f, -0.5f, -0.5f, 0.5f, 0,-1,0, 0,0, - -1.5f, -0.5f, 0.5f, 0.5f, 0,-1,0, 1,0, - 1.5f, -0.5f, 0.5f, 0.5f, 0,-1,0, 1,1, - 1.5f, -0.5f, -0.5f, 0.5f, 0,-1,0, 0,1, - - -1.5f, 0.5f, -0.5f, 0.5f, 0,1,0, 0,0, - -1.5f, 0.5f, 0.5f, 0.5f, 0,1,0, 1,0, - 1.5f, 0.5f, 0.5f, 0.5f, 0,1,0, 1,1, - 1.5f, 0.5f, -0.5f, 0.5f, 0,1,0, 0,1, -}; - - -static const int cube_indices[]= -{ - 0,1,2,0,2,3,//ground face - 6,5,4,7,6,4,//top face - 10,9,8,11,10,8, - 12,13,14,12,14,15, - 18,17,16,19,18,16, - 20,21,22,20,22,23 -}; -/* -static const float fat_triangle[]= -{ - -6.158554,-0.000000,-0.000925, 0.5f, 0, 1,0, 0,1, - -0.028798,-0.000000,-0.000925, 0.5f, 0, 1,0, 0,1, - -6.158554,-0.000000,-6.130690, 0.5f, 0, 1,0, 0,1 -}; - - -static const int fat_triangle_indices[]= -{ - 0,1,2,3,4,5 -}; - -static const float fat_triangle[]= -{ - -10.f, -10, -0.05, 0.5f, 0, 1,0, 0,0, - -10.f, 0, -0.05, 0.5f, 0, 1,0, 1,0, - 10.f, 0, -0.05, 0.5f, 0, 1,0, 1,1, - -10.f, -10, 0.05, 0.5f, 0, 1,0, 0,1, - -10.f, 0, 0.05, 0.5f, 0, 1,0, 0,1, - 10.f, 0, 0.05, 0.5f, 0, 1,0, 0,0 -}; -*/ -#if 0 -static const float triangle_vertices[] = -{ - -1.f, -0.15, -1.f, 0.5f, 0, 1,0, 0,0, - -1.f, -0.15, 1.f, 0.5f, 0, 1,0, 1,0, - 1.f, -0.15, 1.f, 0.5f, 0, 1,0, 1,1, - -1.f, 0.15, -1.f, 0.5f, 0, 1,0, 0,0, - -1.f, 0.15, 1.f, 0.5f, 0, 1,0, 1,0, - 1.f, 0.15, 1.f, 0.5f, 0, 1,0, 1,1, - -}; - -static const int triangle_indices[]= -{ - 0,1,2,3,4,5 -}; -#endif - -static const float quad_vertices[] = -{ - -1.f, 0, -1.f, 0.5f, 0, 1,0, 0,0, - -1.f, 0, 1.f, 0.5f, 0, 1,0, 1,0, - 1.f, 0, 1.f, 0.5f, 0, 1,0, 1,1, - 1.f, 0, -1.f, 0.5f, 0, 1,0, 0,1, -}; - -static const int quad_indices[]= -{ - 0,1,2,0,2,3 -}; - - - -static const float pyramid_vertices[] = -{ - -1.f, 0, -1.f, 0.5f, 0, 1,0, 0,0, - -1.f, 0, 1.f, 0.5f, 0, 1,0, 1,0, - 1.f, 0, 1.f, 0.5f, 0, 1,0, 1,1, - 1.f, 0, -1.f, 0.5f, 0, 1,0, 0,1, - 0, -1, 0 , 0.5f, 0, 1,0, 0,1 -}; - - - - -static const int pyramid_indices[]= -{ - 0,1,2,0,2,3,//ground face - 4,1,2,4,2,3, - 4,3,0,4,0,1 -}; - -static const float tetra_vertices[] = -{ - 0.f, 0.f, 1.f, 0.5f, 0, 1,0, 0,0, - 1.f, -1.f, -1.f, 0.5f, 0, 1,0, 1,0, - -1.f, 1.f, -1.f, 0.5f, 0, 1,0, 1,1, - -1.f, -1, 1.f, 0.5f, 0, 1,0, 0,1 -}; - - - - -static const int tetra_indices[]= -{ - 0,1,2,//ground face - 2,1,3, - 1,0,3, - 0,2,3 -}; - - - - -static const float detailed_sphere_vertices[] = -{ -0.000000,-0.183479,-0.983024,0.000000,0.000000,-0.183479,-0.983024,0.500000,0.408260, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.500000,0.500000, -0.174499,-0.056698,-0.983024,0.000000,0.174499,-0.056698,-0.983024,0.587250,0.471651, -0.176851,-0.243415,-0.953663,0.000000,0.176851,-0.243415,-0.953663,0.588426,0.378293, -0.174499,-0.056698,-0.983024,0.000000,0.174499,-0.056698,-0.983024,0.587250,0.471651, -0.343074,-0.111472,-0.932670,0.000000,0.343074,-0.111472,-0.932670,0.671537,0.444264, -0.000000,-0.183479,-0.983024,0.000000,0.000000,-0.183479,-0.983024,0.500000,0.408260, -0.176851,-0.243415,-0.953663,0.000000,0.176851,-0.243415,-0.953663,0.588426,0.378293, -0.000000,-0.360730,-0.932670,0.000000,0.000000,-0.360730,-0.932670,0.500000,0.319635, -0.000000,-0.183479,-0.983024,0.000000,0.000000,-0.183479,-0.983024,0.500000,0.408260, -0.174499,-0.056698,-0.983024,0.000000,0.174499,-0.056698,-0.983024,0.587250,0.471651, -0.176851,-0.243415,-0.953663,0.000000,0.176851,-0.243415,-0.953663,0.588426,0.378293, -0.345991,-0.298381,-0.889527,0.000000,0.345991,-0.298381,-0.889527,0.672996,0.350810, -0.343074,-0.111472,-0.932670,0.000000,0.343074,-0.111472,-0.932670,0.671537,0.444264, -0.500000,-0.162460,-0.850651,0.000000,0.500000,-0.162460,-0.850651,0.750000,0.418770, -0.176860,-0.421262,-0.889527,0.000000,0.176860,-0.421262,-0.889527,0.588430,0.289369, -0.176851,-0.243415,-0.953663,0.000000,0.176851,-0.243415,-0.953663,0.588426,0.378293, -0.345991,-0.298381,-0.889527,0.000000,0.345991,-0.298381,-0.889527,0.672996,0.350810, -0.000000,-0.360730,-0.932670,0.000000,0.000000,-0.360730,-0.932670,0.500000,0.319635, -0.176860,-0.421262,-0.889527,0.000000,0.176860,-0.421262,-0.889527,0.588430,0.289369, -0.000000,-0.525731,-0.850651,0.000000,0.000000,-0.525731,-0.850651,0.500000,0.237134, -0.176851,-0.243415,-0.953663,0.000000,0.176851,-0.243415,-0.953663,0.588426,0.378293, -0.343074,-0.111472,-0.932670,0.000000,0.343074,-0.111472,-0.932670,0.671537,0.444264, -0.345991,-0.298381,-0.889527,0.000000,0.345991,-0.298381,-0.889527,0.672996,0.350810, -0.000000,-0.360730,-0.932670,0.000000,0.000000,-0.360730,-0.932670,0.500000,0.319635, -0.176851,-0.243415,-0.953663,0.000000,0.176851,-0.243415,-0.953663,0.588426,0.378293, -0.176860,-0.421262,-0.889527,0.000000,0.176860,-0.421262,-0.889527,0.588430,0.289369, -0.522851,-0.355846,-0.774597,0.000000,0.522851,-0.355846,-0.774597,0.761425,0.322077, -0.500000,-0.162460,-0.850651,0.000000,0.500000,-0.162460,-0.850651,0.750000,0.418770, -0.639949,-0.207932,-0.739749,0.000000,0.639949,-0.207932,-0.739749,0.819975,0.396034, -0.356822,-0.491123,-0.794654,0.000000,0.356822,-0.491123,-0.794654,0.678411,0.254439, -0.345991,-0.298381,-0.889527,0.000000,0.345991,-0.298381,-0.889527,0.672996,0.350810, -0.522851,-0.355846,-0.774597,0.000000,0.522851,-0.355846,-0.774597,0.761425,0.322077, -0.176860,-0.421262,-0.889527,0.000000,0.176860,-0.421262,-0.889527,0.588430,0.289369, -0.356822,-0.491123,-0.794654,0.000000,0.356822,-0.491123,-0.794654,0.678411,0.254439, -0.176860,-0.607223,-0.774597,0.000000,0.176860,-0.607223,-0.774597,0.588430,0.196389, -0.000000,-0.525731,-0.850651,0.000000,0.000000,-0.525731,-0.850651,0.500000,0.237134, -0.176860,-0.607223,-0.774597,0.000000,0.176860,-0.607223,-0.774597,0.588430,0.196389, -0.000000,-0.672883,-0.739749,0.000000,0.000000,-0.672883,-0.739749,0.500000,0.163559, -0.345991,-0.298381,-0.889527,0.000000,0.345991,-0.298381,-0.889527,0.672996,0.350810, -0.500000,-0.162460,-0.850651,0.000000,0.500000,-0.162460,-0.850651,0.750000,0.418770, -0.522851,-0.355846,-0.774597,0.000000,0.522851,-0.355846,-0.774597,0.761425,0.322077, -0.176860,-0.421262,-0.889527,0.000000,0.176860,-0.421262,-0.889527,0.588430,0.289369, -0.345991,-0.298381,-0.889527,0.000000,0.345991,-0.298381,-0.889527,0.672996,0.350810, -0.356822,-0.491123,-0.794654,0.000000,0.356822,-0.491123,-0.794654,0.678411,0.254439, -0.000000,-0.525731,-0.850651,0.000000,0.000000,-0.525731,-0.850651,0.500000,0.237134, -0.176860,-0.421262,-0.889527,0.000000,0.176860,-0.421262,-0.889527,0.588430,0.289369, -0.176860,-0.607223,-0.774597,0.000000,0.176860,-0.607223,-0.774597,0.588430,0.196389, -0.653054,-0.398142,-0.644208,0.000000,0.653054,-0.398142,-0.644208,0.912551,0.300929, -0.639949,-0.207932,-0.739749,0.000000,0.639949,-0.207932,-0.739749,0.819975,0.396034, -0.758172,-0.246345,-0.603730,0.000000,0.758172,-0.246345,-0.603730,0.960321,0.396034, -0.522851,-0.533682,-0.664689,0.000000,0.522851,-0.533682,-0.664689,0.892312,0.376828, -0.522851,-0.355846,-0.774597,0.000000,0.522851,-0.355846,-0.774597,0.761425,0.322077, -0.653054,-0.398142,-0.644208,0.000000,0.653054,-0.398142,-0.644208,0.912551,0.300929, -0.345991,-0.662178,-0.664689,0.000000,0.345991,-0.662178,-0.664689,0.761425,0.233159, -0.356822,-0.491123,-0.794654,0.000000,0.356822,-0.491123,-0.794654,0.678411,0.254439, -0.522851,-0.533682,-0.664689,0.000000,0.522851,-0.533682,-0.664689,0.892312,0.376828, -0.176860,-0.607223,-0.774597,0.000000,0.176860,-0.607223,-0.774597,0.588430,0.196389, -0.345991,-0.662178,-0.664689,0.000000,0.345991,-0.662178,-0.664689,0.761425,0.233159, -0.176851,-0.744124,-0.644208,0.000000,0.176851,-0.744124,-0.644208,0.826527,0.300929, -0.000000,-0.672883,-0.739749,0.000000,0.000000,-0.672883,-0.739749,0.500000,0.163559, -0.176851,-0.744124,-0.644208,0.000000,0.176851,-0.744124,-0.644208,0.826527,0.300929, -0.000000,-0.797189,-0.603730,0.000000,0.000000,-0.797189,-0.603730,0.672996,0.168911, -0.522851,-0.355846,-0.774597,0.000000,0.522851,-0.355846,-0.774597,0.761425,0.322077, -0.639949,-0.207932,-0.739749,0.000000,0.639949,-0.207932,-0.739749,0.819975,0.396034, -0.653054,-0.398142,-0.644208,0.000000,0.653054,-0.398142,-0.644208,0.912551,0.300929, -0.356822,-0.491123,-0.794654,0.000000,0.356822,-0.491123,-0.794654,0.678411,0.254439, -0.522851,-0.355846,-0.774597,0.000000,0.522851,-0.355846,-0.774597,0.761425,0.322077, -0.522851,-0.533682,-0.664689,0.000000,0.522851,-0.533682,-0.664689,0.892312,0.376828, -0.176860,-0.607223,-0.774597,0.000000,0.176860,-0.607223,-0.774597,0.588430,0.196389, -0.356822,-0.491123,-0.794654,0.000000,0.356822,-0.491123,-0.794654,0.678411,0.254439, -0.345991,-0.662178,-0.664689,0.000000,0.345991,-0.662178,-0.664689,0.761425,0.233159, -0.000000,-0.672883,-0.739749,0.000000,0.000000,-0.672883,-0.739749,0.500000,0.163559, -0.176860,-0.607223,-0.774597,0.000000,0.176860,-0.607223,-0.774597,0.588430,0.196389, -0.176851,-0.744124,-0.644208,0.000000,0.176851,-0.744124,-0.644208,0.826527,0.300929, -0.758172,-0.429824,-0.490334,0.000000,0.758172,-0.429824,-0.490334,0.588426,0.127938, -0.758172,-0.246345,-0.603730,0.000000,0.758172,-0.246345,-0.603730,0.960321,0.396034, -0.850651,-0.276393,-0.447214,0.000000,0.850651,-0.276393,-0.447214,0.500000,0.960321, -0.639949,-0.568662,-0.516806,0.000000,0.639949,-0.568662,-0.516806,0.588426,0.912551, -0.653054,-0.398142,-0.644208,0.000000,0.653054,-0.398142,-0.644208,0.912551,0.300929, -0.758172,-0.429824,-0.490334,0.000000,0.758172,-0.429824,-0.490334,0.588426,0.127938, -0.500000,-0.688191,-0.525731,0.000000,0.500000,-0.688191,-0.525731,0.500000,0.892312, -0.522851,-0.533682,-0.664689,0.000000,0.522851,-0.533682,-0.664689,0.892312,0.376828, -0.639949,-0.568662,-0.516806,0.000000,0.639949,-0.568662,-0.516806,0.588426,0.912551, -0.345991,-0.662178,-0.664689,0.000000,0.345991,-0.662178,-0.664689,0.761425,0.233159, -0.500000,-0.688191,-0.525731,0.000000,0.500000,-0.688191,-0.525731,0.500000,0.892312, -0.343074,-0.784354,-0.516806,0.000000,0.343074,-0.784354,-0.516806,0.835614,0.285088, -0.176851,-0.744124,-0.644208,0.000000,0.176851,-0.744124,-0.644208,0.826527,0.300929, -0.343074,-0.784354,-0.516806,0.000000,0.343074,-0.784354,-0.516806,0.835614,0.285088, -0.174499,-0.853887,-0.490334,0.000000,0.174499,-0.853887,-0.490334,0.814054,0.361804, -0.000000,-0.797189,-0.603730,0.000000,0.000000,-0.797189,-0.603730,0.672996,0.168911, -0.174499,-0.853887,-0.490334,0.000000,0.174499,-0.853887,-0.490334,0.814054,0.361804, -0.000000,-0.894427,-0.447214,0.000000,0.000000,-0.894427,-0.447214,0.848850,0.215669, -0.653054,-0.398142,-0.644208,0.000000,0.653054,-0.398142,-0.644208,0.912551,0.300929, -0.758172,-0.246345,-0.603730,0.000000,0.758172,-0.246345,-0.603730,0.960321,0.396034, -0.758172,-0.429824,-0.490334,0.000000,0.758172,-0.429824,-0.490334,0.588426,0.127938, -0.522851,-0.533682,-0.664689,0.000000,0.522851,-0.533682,-0.664689,0.892312,0.376828, -0.653054,-0.398142,-0.644208,0.000000,0.653054,-0.398142,-0.644208,0.912551,0.300929, -0.639949,-0.568662,-0.516806,0.000000,0.639949,-0.568662,-0.516806,0.588426,0.912551, -0.345991,-0.662178,-0.664689,0.000000,0.345991,-0.662178,-0.664689,0.761425,0.233159, -0.522851,-0.533682,-0.664689,0.000000,0.522851,-0.533682,-0.664689,0.892312,0.376828, -0.500000,-0.688191,-0.525731,0.000000,0.500000,-0.688191,-0.525731,0.500000,0.892312, -0.176851,-0.744124,-0.644208,0.000000,0.176851,-0.744124,-0.644208,0.826527,0.300929, -0.345991,-0.662178,-0.664689,0.000000,0.345991,-0.662178,-0.664689,0.761425,0.233159, -0.343074,-0.784354,-0.516806,0.000000,0.343074,-0.784354,-0.516806,0.835614,0.285088, -0.000000,-0.797189,-0.603730,0.000000,0.000000,-0.797189,-0.603730,0.672996,0.168911, -0.176851,-0.744124,-0.644208,0.000000,0.176851,-0.744124,-0.644208,0.826527,0.300929, -0.174499,-0.853887,-0.490334,0.000000,0.174499,-0.853887,-0.490334,0.814054,0.361804, -0.174499,-0.056698,-0.983024,0.000000,0.174499,-0.056698,-0.983024,0.587250,0.471651, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.500000,0.500000, -0.107846,0.148438,-0.983024,0.000000,0.107846,0.148438,-0.983024,0.750000,0.853312, -0.286151,0.092976,-0.953663,0.000000,0.286151,0.092976,-0.953663,0.761425,0.922791, -0.107846,0.148438,-0.983024,0.000000,0.107846,0.148438,-0.983024,0.750000,0.853312, -0.212032,0.291836,-0.932670,0.000000,0.212032,0.291836,-0.932670,0.819975,0.848850, -0.174499,-0.056698,-0.983024,0.000000,0.174499,-0.056698,-0.983024,0.587250,0.471651, -0.286151,0.092976,-0.953663,0.000000,0.286151,0.092976,-0.953663,0.761425,0.922791, -0.343074,-0.111472,-0.932670,0.000000,0.343074,-0.111472,-0.932670,0.671537,0.444264, -0.174499,-0.056698,-0.983024,0.000000,0.174499,-0.056698,-0.983024,0.587250,0.471651, -0.107846,0.148438,-0.983024,0.000000,0.107846,0.148438,-0.983024,0.750000,0.853312, -0.286151,0.092976,-0.953663,0.000000,0.286151,0.092976,-0.953663,0.761425,0.922791, -0.390694,0.236853,-0.889527,0.000000,0.390694,0.236853,-0.889527,0.672996,0.922791, -0.212032,0.291836,-0.932670,0.000000,0.212032,0.291836,-0.932670,0.819975,0.848850, -0.309017,0.425325,-0.850651,0.000000,0.309017,0.425325,-0.850651,0.671537,0.848850, -0.455297,0.038026,-0.889527,0.000000,0.455297,0.038026,-0.889527,0.587250,0.835614, -0.286151,0.092976,-0.953663,0.000000,0.286151,0.092976,-0.953663,0.761425,0.922791, -0.390694,0.236853,-0.889527,0.000000,0.390694,0.236853,-0.889527,0.672996,0.922791, -0.343074,-0.111472,-0.932670,0.000000,0.343074,-0.111472,-0.932670,0.671537,0.444264, -0.455297,0.038026,-0.889527,0.000000,0.455297,0.038026,-0.889527,0.587250,0.835614, -0.500000,-0.162460,-0.850651,0.000000,0.500000,-0.162460,-0.850651,0.750000,0.418770, -0.286151,0.092976,-0.953663,0.000000,0.286151,0.092976,-0.953663,0.761425,0.922791, -0.212032,0.291836,-0.932670,0.000000,0.212032,0.291836,-0.932670,0.819975,0.848850, -0.390694,0.236853,-0.889527,0.000000,0.390694,0.236853,-0.889527,0.672996,0.922791, -0.343074,-0.111472,-0.932670,0.000000,0.343074,-0.111472,-0.932670,0.671537,0.444264, -0.286151,0.092976,-0.953663,0.000000,0.286151,0.092976,-0.953663,0.761425,0.922791, -0.455297,0.038026,-0.889527,0.000000,0.455297,0.038026,-0.889527,0.587250,0.835614, -0.499999,0.387298,-0.774597,0.000000,0.499999,0.387298,-0.774597,0.500000,0.814054, -0.309017,0.425325,-0.850651,0.000000,0.309017,0.425325,-0.850651,0.671537,0.848850, -0.395510,0.544373,-0.739749,0.000000,0.395510,0.544373,-0.739749,0.922791,0.233159, -0.577350,0.187592,-0.794654,0.000000,0.577350,0.187592,-0.794654,0.553923,0.574219, -0.390694,0.236853,-0.889527,0.000000,0.390694,0.236853,-0.889527,0.672996,0.922791, -0.499999,0.387298,-0.774597,0.000000,0.499999,0.387298,-0.774597,0.500000,0.814054, -0.455297,0.038026,-0.889527,0.000000,0.455297,0.038026,-0.889527,0.587250,0.835614, -0.577350,0.187592,-0.794654,0.000000,0.577350,0.187592,-0.794654,0.553923,0.574219, -0.632156,-0.019439,-0.774597,0.000000,0.632156,-0.019439,-0.774597,0.643075,0.546488, -0.500000,-0.162460,-0.850651,0.000000,0.500000,-0.162460,-0.850651,0.750000,0.418770, -0.632156,-0.019439,-0.774597,0.000000,0.632156,-0.019439,-0.774597,0.643075,0.546488, -0.639949,-0.207932,-0.739749,0.000000,0.639949,-0.207932,-0.739749,0.819975,0.396034, -0.390694,0.236853,-0.889527,0.000000,0.390694,0.236853,-0.889527,0.672996,0.922791, -0.309017,0.425325,-0.850651,0.000000,0.309017,0.425325,-0.850651,0.671537,0.848850, -0.499999,0.387298,-0.774597,0.000000,0.499999,0.387298,-0.774597,0.500000,0.814054, -0.455297,0.038026,-0.889527,0.000000,0.455297,0.038026,-0.889527,0.587250,0.835614, -0.390694,0.236853,-0.889527,0.000000,0.390694,0.236853,-0.889527,0.672996,0.922791, -0.577350,0.187592,-0.794654,0.000000,0.577350,0.187592,-0.794654,0.553923,0.574219, -0.500000,-0.162460,-0.850651,0.000000,0.500000,-0.162460,-0.850651,0.750000,0.418770, -0.455297,0.038026,-0.889527,0.000000,0.455297,0.038026,-0.889527,0.587250,0.835614, -0.632156,-0.019439,-0.774597,0.000000,0.632156,-0.019439,-0.774597,0.643075,0.546488, -0.580460,0.498058,-0.644208,0.000000,0.580460,0.498058,-0.644208,0.606016,0.645918, -0.395510,0.544373,-0.739749,0.000000,0.395510,0.544373,-0.739749,0.922791,0.233159, -0.468576,0.644939,-0.603730,0.000000,0.468576,0.644939,-0.603730,0.695347,0.618427, -0.669131,0.332344,-0.664689,0.000000,0.669131,0.332344,-0.664689,0.654508,0.712663, -0.499999,0.387298,-0.774597,0.000000,0.499999,0.387298,-0.774597,0.500000,0.814054, -0.580460,0.498058,-0.644208,0.000000,0.580460,0.498058,-0.644208,0.606016,0.645918, -0.736686,0.124433,-0.664689,0.000000,0.736686,0.124433,-0.664689,0.727648,0.519013, -0.577350,0.187592,-0.794654,0.000000,0.577350,0.187592,-0.794654,0.553923,0.574219, -0.669131,0.332344,-0.664689,0.000000,0.669131,0.332344,-0.664689,0.654508,0.712663, -0.632156,-0.019439,-0.774597,0.000000,0.632156,-0.019439,-0.774597,0.643075,0.546488, -0.736686,0.124433,-0.664689,0.000000,0.736686,0.124433,-0.664689,0.727648,0.519013, -0.762354,-0.061752,-0.644208,0.000000,0.762354,-0.061752,-0.644208,0.750000,0.693649, -0.639949,-0.207932,-0.739749,0.000000,0.639949,-0.207932,-0.739749,0.819975,0.396034, -0.762354,-0.061752,-0.644208,0.000000,0.762354,-0.061752,-0.644208,0.750000,0.693649, -0.758172,-0.246345,-0.603730,0.000000,0.758172,-0.246345,-0.603730,0.960321,0.396034, -0.499999,0.387298,-0.774597,0.000000,0.499999,0.387298,-0.774597,0.500000,0.814054, -0.395510,0.544373,-0.739749,0.000000,0.395510,0.544373,-0.739749,0.922791,0.233159, -0.580460,0.498058,-0.644208,0.000000,0.580460,0.498058,-0.644208,0.606016,0.645918, -0.577350,0.187592,-0.794654,0.000000,0.577350,0.187592,-0.794654,0.553923,0.574219, -0.499999,0.387298,-0.774597,0.000000,0.499999,0.387298,-0.774597,0.500000,0.814054, -0.669131,0.332344,-0.664689,0.000000,0.669131,0.332344,-0.664689,0.654508,0.712663, -0.632156,-0.019439,-0.774597,0.000000,0.632156,-0.019439,-0.774597,0.643075,0.546488, -0.577350,0.187592,-0.794654,0.000000,0.577350,0.187592,-0.794654,0.553923,0.574219, -0.736686,0.124433,-0.664689,0.000000,0.736686,0.124433,-0.664689,0.727648,0.519013, -0.639949,-0.207932,-0.739749,0.000000,0.639949,-0.207932,-0.739749,0.819975,0.396034, -0.632156,-0.019439,-0.774597,0.000000,0.632156,-0.019439,-0.774597,0.643075,0.546488, -0.762354,-0.061752,-0.644208,0.000000,0.762354,-0.061752,-0.644208,0.750000,0.693649, -0.643075,0.588241,-0.490334,0.000000,0.643075,0.588241,-0.490334,0.697755,0.772187, -0.468576,0.644939,-0.603730,0.000000,0.468576,0.644939,-0.603730,0.695347,0.618427, -0.525731,0.723607,-0.447214,0.000000,0.525731,0.723607,-0.447214,0.788675,0.593796, -0.738585,0.432902,-0.516806,0.000000,0.738585,0.432902,-0.516806,0.816078,0.490281, -0.580460,0.498058,-0.644208,0.000000,0.580460,0.498058,-0.644208,0.606016,0.645918, -0.643075,0.588241,-0.490334,0.000000,0.643075,0.588241,-0.490334,0.697755,0.772187, -0.809017,0.262865,-0.525731,0.000000,0.809017,0.262865,-0.525731,0.790230,0.749029, -0.669131,0.332344,-0.664689,0.000000,0.669131,0.332344,-0.664689,0.654508,0.712663, -0.738585,0.432902,-0.516806,0.000000,0.738585,0.432902,-0.516806,0.816078,0.490281, -0.736686,0.124433,-0.664689,0.000000,0.736686,0.124433,-0.664689,0.727648,0.519013, -0.809017,0.262865,-0.525731,0.000000,0.809017,0.262865,-0.525731,0.790230,0.749029, -0.851981,0.083904,-0.516806,0.000000,0.851981,0.083904,-0.516806,0.734288,0.822469, -0.762354,-0.061752,-0.644208,0.000000,0.762354,-0.061752,-0.644208,0.750000,0.693649, -0.851981,0.083904,-0.516806,0.000000,0.851981,0.083904,-0.516806,0.734288,0.822469, -0.866018,-0.097907,-0.490334,0.000000,0.866018,-0.097907,-0.490334,0.834566,0.666172, -0.758172,-0.246345,-0.603730,0.000000,0.758172,-0.246345,-0.603730,0.960321,0.396034, -0.866018,-0.097907,-0.490334,0.000000,0.866018,-0.097907,-0.490334,0.834566,0.666172, -0.850651,-0.276393,-0.447214,0.000000,0.850651,-0.276393,-0.447214,0.500000,0.960321, -0.580460,0.498058,-0.644208,0.000000,0.580460,0.498058,-0.644208,0.606016,0.645918, -0.468576,0.644939,-0.603730,0.000000,0.468576,0.644939,-0.603730,0.695347,0.618427, -0.643075,0.588241,-0.490334,0.000000,0.643075,0.588241,-0.490334,0.697755,0.772187, -0.669131,0.332344,-0.664689,0.000000,0.669131,0.332344,-0.664689,0.654508,0.712663, -0.580460,0.498058,-0.644208,0.000000,0.580460,0.498058,-0.644208,0.606016,0.645918, -0.738585,0.432902,-0.516806,0.000000,0.738585,0.432902,-0.516806,0.816078,0.490281, -0.736686,0.124433,-0.664689,0.000000,0.736686,0.124433,-0.664689,0.727648,0.519013, -0.669131,0.332344,-0.664689,0.000000,0.669131,0.332344,-0.664689,0.654508,0.712663, -0.809017,0.262865,-0.525731,0.000000,0.809017,0.262865,-0.525731,0.790230,0.749029, -0.762354,-0.061752,-0.644208,0.000000,0.762354,-0.061752,-0.644208,0.750000,0.693649, -0.736686,0.124433,-0.664689,0.000000,0.736686,0.124433,-0.664689,0.727648,0.519013, -0.851981,0.083904,-0.516806,0.000000,0.851981,0.083904,-0.516806,0.734288,0.822469, -0.758172,-0.246345,-0.603730,0.000000,0.758172,-0.246345,-0.603730,0.960321,0.396034, -0.762354,-0.061752,-0.644208,0.000000,0.762354,-0.061752,-0.644208,0.750000,0.693649, -0.866018,-0.097907,-0.490334,0.000000,0.866018,-0.097907,-0.490334,0.834566,0.666172, -0.107846,0.148438,-0.983024,0.000000,0.107846,0.148438,-0.983024,0.750000,0.853312, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.500000,0.500000, --0.107846,0.148438,-0.983024,0.000000,-0.107846,0.148438,-0.983024,0.868343,0.562217, -0.000000,0.300877,-0.953663,0.000000,0.000000,0.300877,-0.953663,0.977745,0.490281, --0.107846,0.148438,-0.983024,0.000000,-0.107846,0.148438,-0.983024,0.868343,0.562217, --0.212032,0.291836,-0.932670,0.000000,-0.212032,0.291836,-0.932670,0.922791,0.562217, -0.107846,0.148438,-0.983024,0.000000,0.107846,0.148438,-0.983024,0.750000,0.853312, -0.000000,0.300877,-0.953663,0.000000,0.000000,0.300877,-0.953663,0.977745,0.490281, -0.212032,0.291836,-0.932670,0.000000,0.212032,0.291836,-0.932670,0.819975,0.848850, -0.107846,0.148438,-0.983024,0.000000,0.107846,0.148438,-0.983024,0.750000,0.853312, --0.107846,0.148438,-0.983024,0.000000,-0.107846,0.148438,-0.983024,0.868343,0.562217, -0.000000,0.300877,-0.953663,0.000000,0.000000,0.300877,-0.953663,0.977745,0.490281, --0.104529,0.444764,-0.889527,0.000000,-0.104529,0.444764,-0.889527,0.912551,0.469124, --0.212032,0.291836,-0.932670,0.000000,-0.212032,0.291836,-0.932670,0.922791,0.562217, --0.309017,0.425325,-0.850651,0.000000,-0.309017,0.425325,-0.850651,0.881177,0.469124, -0.104529,0.444764,-0.889527,0.000000,0.104529,0.444764,-0.889527,0.821537,0.835614, -0.000000,0.300877,-0.953663,0.000000,0.000000,0.300877,-0.953663,0.977745,0.490281, --0.104529,0.444764,-0.889527,0.000000,-0.104529,0.444764,-0.889527,0.912551,0.469124, -0.212032,0.291836,-0.932670,0.000000,0.212032,0.291836,-0.932670,0.819975,0.848850, -0.104529,0.444764,-0.889527,0.000000,0.104529,0.444764,-0.889527,0.821537,0.835614, -0.309017,0.425325,-0.850651,0.000000,0.309017,0.425325,-0.850651,0.671537,0.848850, -0.000000,0.300877,-0.953663,0.000000,0.000000,0.300877,-0.953663,0.977745,0.490281, --0.212032,0.291836,-0.932670,0.000000,-0.212032,0.291836,-0.932670,0.922791,0.562217, --0.104529,0.444764,-0.889527,0.000000,-0.104529,0.444764,-0.889527,0.912551,0.469124, -0.212032,0.291836,-0.932670,0.000000,0.212032,0.291836,-0.932670,0.819975,0.848850, -0.000000,0.300877,-0.953663,0.000000,0.000000,0.300877,-0.953663,0.977745,0.490281, -0.104529,0.444764,-0.889527,0.000000,0.104529,0.444764,-0.889527,0.821537,0.835614, --0.213834,0.595209,-0.774597,0.000000,-0.213834,0.595209,-0.774597,0.734288,0.892312, --0.309017,0.425325,-0.850651,0.000000,-0.309017,0.425325,-0.850651,0.881177,0.469124, --0.395510,0.544373,-0.739749,0.000000,-0.395510,0.544373,-0.739749,0.762866,0.814054, -0.000000,0.607062,-0.794654,0.000000,0.000000,0.607062,-0.794654,0.848850,0.716451, --0.104529,0.444764,-0.889527,0.000000,-0.104529,0.444764,-0.889527,0.912551,0.469124, --0.213834,0.595209,-0.774597,0.000000,-0.213834,0.595209,-0.774597,0.734288,0.892312, -0.104529,0.444764,-0.889527,0.000000,0.104529,0.444764,-0.889527,0.821537,0.835614, -0.000000,0.607062,-0.794654,0.000000,0.000000,0.607062,-0.794654,0.848850,0.716451, -0.213834,0.595209,-0.774597,0.000000,0.213834,0.595209,-0.774597,0.912551,0.749029, -0.309017,0.425325,-0.850651,0.000000,0.309017,0.425325,-0.850651,0.671537,0.848850, -0.213834,0.595209,-0.774597,0.000000,0.213834,0.595209,-0.774597,0.912551,0.749029, -0.395510,0.544373,-0.739749,0.000000,0.395510,0.544373,-0.739749,0.922791,0.233159, --0.104529,0.444764,-0.889527,0.000000,-0.104529,0.444764,-0.889527,0.912551,0.469124, --0.309017,0.425325,-0.850651,0.000000,-0.309017,0.425325,-0.850651,0.881177,0.469124, --0.213834,0.595209,-0.774597,0.000000,-0.213834,0.595209,-0.774597,0.734288,0.892312, -0.104529,0.444764,-0.889527,0.000000,0.104529,0.444764,-0.889527,0.821537,0.835614, --0.104529,0.444764,-0.889527,0.000000,-0.104529,0.444764,-0.889527,0.912551,0.469124, -0.000000,0.607062,-0.794654,0.000000,0.000000,0.607062,-0.794654,0.848850,0.716451, -0.309017,0.425325,-0.850651,0.000000,0.309017,0.425325,-0.850651,0.671537,0.848850, -0.104529,0.444764,-0.889527,0.000000,0.104529,0.444764,-0.889527,0.821537,0.835614, -0.213834,0.595209,-0.774597,0.000000,0.213834,0.595209,-0.774597,0.912551,0.749029, --0.294309,0.705959,-0.644208,0.000000,-0.294309,0.705959,-0.644208,0.835614,0.794120, --0.395510,0.544373,-0.739749,0.000000,-0.395510,0.544373,-0.739749,0.762866,0.814054, --0.468576,0.644939,-0.603730,0.000000,-0.468576,0.644939,-0.603730,0.853312,0.631433, --0.109305,0.739082,-0.664689,0.000000,-0.109305,0.739082,-0.664689,0.922791,0.666172, --0.213834,0.595209,-0.774597,0.000000,-0.213834,0.595209,-0.774597,0.734288,0.892312, --0.294309,0.705959,-0.644208,0.000000,-0.294309,0.705959,-0.644208,0.835614,0.794120, -0.109305,0.739082,-0.664689,0.000000,0.109305,0.739082,-0.664689,0.848850,0.541952, -0.000000,0.607062,-0.794654,0.000000,0.000000,0.607062,-0.794654,0.848850,0.716451, --0.109305,0.739082,-0.664689,0.000000,-0.109305,0.739082,-0.664689,0.922791,0.666172, -0.213834,0.595209,-0.774597,0.000000,0.213834,0.595209,-0.774597,0.912551,0.749029, -0.109305,0.739082,-0.664689,0.000000,0.109305,0.739082,-0.664689,0.848850,0.541952, -0.294310,0.705959,-0.644208,0.000000,0.294310,0.705959,-0.644208,0.835614,0.451046, -0.395510,0.544373,-0.739749,0.000000,0.395510,0.544373,-0.739749,0.922791,0.233159, -0.294310,0.705959,-0.644208,0.000000,0.294310,0.705959,-0.644208,0.835614,0.451046, -0.468576,0.644939,-0.603730,0.000000,0.468576,0.644939,-0.603730,0.695347,0.618427, --0.213834,0.595209,-0.774597,0.000000,-0.213834,0.595209,-0.774597,0.734288,0.892312, --0.395510,0.544373,-0.739749,0.000000,-0.395510,0.544373,-0.739749,0.762866,0.814054, --0.294309,0.705959,-0.644208,0.000000,-0.294309,0.705959,-0.644208,0.835614,0.794120, -0.000000,0.607062,-0.794654,0.000000,0.000000,0.607062,-0.794654,0.848850,0.716451, --0.213834,0.595209,-0.774597,0.000000,-0.213834,0.595209,-0.774597,0.734288,0.892312, --0.109305,0.739082,-0.664689,0.000000,-0.109305,0.739082,-0.664689,0.922791,0.666172, -0.213834,0.595209,-0.774597,0.000000,0.213834,0.595209,-0.774597,0.912551,0.749029, -0.000000,0.607062,-0.794654,0.000000,0.000000,0.607062,-0.794654,0.848850,0.716451, -0.109305,0.739082,-0.664689,0.000000,0.109305,0.739082,-0.664689,0.848850,0.541952, -0.395510,0.544373,-0.739749,0.000000,0.395510,0.544373,-0.739749,0.922791,0.233159, -0.213834,0.595209,-0.774597,0.000000,0.213834,0.595209,-0.774597,0.912551,0.749029, -0.294310,0.705959,-0.644208,0.000000,0.294310,0.705959,-0.644208,0.835614,0.451046, --0.360730,0.793377,-0.490334,0.000000,-0.360730,0.793377,-0.490334,0.790230,0.912551, --0.468576,0.644939,-0.603730,0.000000,-0.468576,0.644939,-0.603730,0.853312,0.631433, --0.525731,0.723607,-0.447214,0.000000,-0.525731,0.723607,-0.447214,0.446077,0.574219, --0.183479,0.836210,-0.516806,0.000000,-0.183479,0.836210,-0.516806,0.500000,0.650438, --0.294309,0.705959,-0.644208,0.000000,-0.294309,0.705959,-0.644208,0.835614,0.794120, --0.360730,0.793377,-0.490334,0.000000,-0.360730,0.793377,-0.490334,0.790230,0.912551, -0.000000,0.850651,-0.525731,0.000000,0.000000,0.850651,-0.525731,0.393984,0.645918, --0.109305,0.739082,-0.664689,0.000000,-0.109305,0.739082,-0.664689,0.922791,0.666172, --0.183479,0.836210,-0.516806,0.000000,-0.183479,0.836210,-0.516806,0.500000,0.650438, -0.109305,0.739082,-0.664689,0.000000,0.109305,0.739082,-0.664689,0.848850,0.541952, -0.000000,0.850651,-0.525731,0.000000,0.000000,0.850651,-0.525731,0.393984,0.645918, -0.183479,0.836210,-0.516806,0.000000,0.183479,0.836210,-0.516806,0.447735,0.722382, -0.294310,0.705959,-0.644208,0.000000,0.294310,0.705959,-0.644208,0.835614,0.451046, -0.183479,0.836210,-0.516806,0.000000,0.183479,0.836210,-0.516806,0.447735,0.722382, -0.360730,0.793377,-0.490334,0.000000,0.360730,0.793377,-0.490334,0.345491,0.712663, -0.468576,0.644939,-0.603730,0.000000,0.468576,0.644939,-0.603730,0.695347,0.618427, -0.360730,0.793377,-0.490334,0.000000,0.360730,0.793377,-0.490334,0.345491,0.712663, -0.525731,0.723607,-0.447214,0.000000,0.525731,0.723607,-0.447214,0.788675,0.593796, --0.294309,0.705959,-0.644208,0.000000,-0.294309,0.705959,-0.644208,0.835614,0.794120, --0.468576,0.644939,-0.603730,0.000000,-0.468576,0.644939,-0.603730,0.853312,0.631433, --0.360730,0.793377,-0.490334,0.000000,-0.360730,0.793377,-0.490334,0.790230,0.912551, --0.109305,0.739082,-0.664689,0.000000,-0.109305,0.739082,-0.664689,0.922791,0.666172, --0.294309,0.705959,-0.644208,0.000000,-0.294309,0.705959,-0.644208,0.835614,0.794120, --0.183479,0.836210,-0.516806,0.000000,-0.183479,0.836210,-0.516806,0.500000,0.650438, -0.109305,0.739082,-0.664689,0.000000,0.109305,0.739082,-0.664689,0.848850,0.541952, --0.109305,0.739082,-0.664689,0.000000,-0.109305,0.739082,-0.664689,0.922791,0.666172, -0.000000,0.850651,-0.525731,0.000000,0.000000,0.850651,-0.525731,0.393984,0.645918, -0.294310,0.705959,-0.644208,0.000000,0.294310,0.705959,-0.644208,0.835614,0.451046, -0.109305,0.739082,-0.664689,0.000000,0.109305,0.739082,-0.664689,0.848850,0.541952, -0.183479,0.836210,-0.516806,0.000000,0.183479,0.836210,-0.516806,0.447735,0.722382, -0.468576,0.644939,-0.603730,0.000000,0.468576,0.644939,-0.603730,0.695347,0.618427, -0.294310,0.705959,-0.644208,0.000000,0.294310,0.705959,-0.644208,0.835614,0.451046, -0.360730,0.793377,-0.490334,0.000000,0.360730,0.793377,-0.490334,0.345491,0.712663, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.500000,0.500000, --0.174499,-0.056698,-0.983024,0.000000,-0.174499,-0.056698,-0.983024,0.552265,0.722382, --0.107846,0.148438,-0.983024,0.000000,-0.107846,0.148438,-0.983024,0.868343,0.562217, --0.286151,0.092976,-0.953663,0.000000,-0.286151,0.092976,-0.953663,0.393083,0.797605, --0.174499,-0.056698,-0.983024,0.000000,-0.174499,-0.056698,-0.983024,0.552265,0.722382, --0.343074,-0.111472,-0.932670,0.000000,-0.343074,-0.111472,-0.932670,0.302245,0.772187, --0.107846,0.148438,-0.983024,0.000000,-0.107846,0.148438,-0.983024,0.868343,0.562217, --0.286151,0.092976,-0.953663,0.000000,-0.286151,0.092976,-0.953663,0.393083,0.797605, --0.212032,0.291836,-0.932670,0.000000,-0.212032,0.291836,-0.932670,0.922791,0.562217, --0.107846,0.148438,-0.983024,0.000000,-0.107846,0.148438,-0.983024,0.868343,0.562217, --0.174499,-0.056698,-0.983024,0.000000,-0.174499,-0.056698,-0.983024,0.552265,0.722382, --0.286151,0.092976,-0.953663,0.000000,-0.286151,0.092976,-0.953663,0.393083,0.797605, --0.455297,0.038026,-0.889527,0.000000,-0.455297,0.038026,-0.889527,0.500000,0.803531, --0.343074,-0.111472,-0.932670,0.000000,-0.343074,-0.111472,-0.932670,0.302245,0.772187, --0.500000,-0.162460,-0.850651,0.000000,-0.500000,-0.162460,-0.850651,0.606917,0.797605, --0.286151,0.092976,-0.953663,0.000000,-0.286151,0.092976,-0.953663,0.393083,0.797605, --0.455297,0.038026,-0.889527,0.000000,-0.455297,0.038026,-0.889527,0.500000,0.803531, --0.390694,0.236853,-0.889527,0.000000,-0.390694,0.236853,-0.889527,0.352845,0.852980, --0.212032,0.291836,-0.932670,0.000000,-0.212032,0.291836,-0.932670,0.922791,0.562217, --0.390694,0.236853,-0.889527,0.000000,-0.390694,0.236853,-0.889527,0.352845,0.852980, --0.309017,0.425325,-0.850651,0.000000,-0.309017,0.425325,-0.850651,0.881177,0.469124, --0.286151,0.092976,-0.953663,0.000000,-0.286151,0.092976,-0.953663,0.393083,0.797605, --0.343074,-0.111472,-0.932670,0.000000,-0.343074,-0.111472,-0.932670,0.302245,0.772187, --0.455297,0.038026,-0.889527,0.000000,-0.455297,0.038026,-0.889527,0.500000,0.803531, --0.212032,0.291836,-0.932670,0.000000,-0.212032,0.291836,-0.932670,0.922791,0.562217, --0.286151,0.092976,-0.953663,0.000000,-0.286151,0.092976,-0.953663,0.393083,0.797605, --0.390694,0.236853,-0.889527,0.000000,-0.390694,0.236853,-0.889527,0.352845,0.852980, --0.632156,-0.019439,-0.774597,0.000000,-0.632156,-0.019439,-0.774597,0.265712,0.822469, --0.500000,-0.162460,-0.850651,0.000000,-0.500000,-0.162460,-0.850651,0.606917,0.797605, --0.639949,-0.207932,-0.739749,0.000000,-0.639949,-0.207932,-0.739749,0.445347,0.869541, --0.577350,0.187593,-0.794654,0.000000,-0.577350,0.187593,-0.794654,0.554653,0.869541, --0.455297,0.038026,-0.889527,0.000000,-0.455297,0.038026,-0.889527,0.500000,0.803531, --0.632156,-0.019439,-0.774597,0.000000,-0.632156,-0.019439,-0.774597,0.265712,0.822469, --0.390694,0.236853,-0.889527,0.000000,-0.390694,0.236853,-0.889527,0.352845,0.852980, --0.577350,0.187593,-0.794654,0.000000,-0.577350,0.187593,-0.794654,0.554653,0.869541, --0.499999,0.387299,-0.774597,0.000000,-0.499999,0.387299,-0.774597,0.647155,0.852980, --0.309017,0.425325,-0.850651,0.000000,-0.309017,0.425325,-0.850651,0.881177,0.469124, --0.499999,0.387299,-0.774597,0.000000,-0.499999,0.387299,-0.774597,0.647155,0.852980, --0.395510,0.544373,-0.739749,0.000000,-0.395510,0.544373,-0.739749,0.762866,0.814054, --0.455297,0.038026,-0.889527,0.000000,-0.455297,0.038026,-0.889527,0.500000,0.803531, --0.500000,-0.162460,-0.850651,0.000000,-0.500000,-0.162460,-0.850651,0.606917,0.797605, --0.632156,-0.019439,-0.774597,0.000000,-0.632156,-0.019439,-0.774597,0.265712,0.822469, --0.390694,0.236853,-0.889527,0.000000,-0.390694,0.236853,-0.889527,0.352845,0.852980, --0.455297,0.038026,-0.889527,0.000000,-0.455297,0.038026,-0.889527,0.500000,0.803531, --0.577350,0.187593,-0.794654,0.000000,-0.577350,0.187593,-0.794654,0.554653,0.869541, --0.309017,0.425325,-0.850651,0.000000,-0.309017,0.425325,-0.850651,0.881177,0.469124, --0.390694,0.236853,-0.889527,0.000000,-0.390694,0.236853,-0.889527,0.352845,0.852980, --0.499999,0.387299,-0.774597,0.000000,-0.499999,0.387299,-0.774597,0.647155,0.852980, --0.762354,-0.061751,-0.644208,0.000000,-0.762354,-0.061751,-0.644208,0.319635,0.835614, --0.639949,-0.207932,-0.739749,0.000000,-0.639949,-0.207932,-0.739749,0.445347,0.869541, --0.758172,-0.246345,-0.603730,0.000000,-0.758172,-0.246345,-0.603730,0.265712,0.892312, --0.736685,0.124433,-0.664689,0.000000,-0.736685,0.124433,-0.664689,0.237134,0.814054, --0.632156,-0.019439,-0.774597,0.000000,-0.632156,-0.019439,-0.774597,0.265712,0.822469, --0.762354,-0.061751,-0.644208,0.000000,-0.762354,-0.061751,-0.644208,0.319635,0.835614, --0.577350,0.187593,-0.794654,0.000000,-0.577350,0.187593,-0.794654,0.554653,0.869541, --0.736685,0.124433,-0.664689,0.000000,-0.736685,0.124433,-0.664689,0.237134,0.814054, --0.669131,0.332344,-0.664689,0.000000,-0.669131,0.332344,-0.664689,0.408260,0.848850, --0.499999,0.387299,-0.774597,0.000000,-0.499999,0.387299,-0.774597,0.647155,0.852980, --0.669131,0.332344,-0.664689,0.000000,-0.669131,0.332344,-0.664689,0.408260,0.848850, --0.580460,0.498058,-0.644208,0.000000,-0.580460,0.498058,-0.644208,0.352845,0.912551, --0.395510,0.544373,-0.739749,0.000000,-0.395510,0.544373,-0.739749,0.762866,0.814054, --0.580460,0.498058,-0.644208,0.000000,-0.580460,0.498058,-0.644208,0.352845,0.912551, --0.468576,0.644939,-0.603730,0.000000,-0.468576,0.644939,-0.603730,0.853312,0.631433, --0.632156,-0.019439,-0.774597,0.000000,-0.632156,-0.019439,-0.774597,0.265712,0.822469, --0.639949,-0.207932,-0.739749,0.000000,-0.639949,-0.207932,-0.739749,0.445347,0.869541, --0.762354,-0.061751,-0.644208,0.000000,-0.762354,-0.061751,-0.644208,0.319635,0.835614, --0.577350,0.187593,-0.794654,0.000000,-0.577350,0.187593,-0.794654,0.554653,0.869541, --0.632156,-0.019439,-0.774597,0.000000,-0.632156,-0.019439,-0.774597,0.265712,0.822469, --0.736685,0.124433,-0.664689,0.000000,-0.736685,0.124433,-0.664689,0.237134,0.814054, --0.499999,0.387299,-0.774597,0.000000,-0.499999,0.387299,-0.774597,0.647155,0.852980, --0.577350,0.187593,-0.794654,0.000000,-0.577350,0.187593,-0.794654,0.554653,0.869541, --0.669131,0.332344,-0.664689,0.000000,-0.669131,0.332344,-0.664689,0.408260,0.848850, --0.395510,0.544373,-0.739749,0.000000,-0.395510,0.544373,-0.739749,0.762866,0.814054, --0.499999,0.387299,-0.774597,0.000000,-0.499999,0.387299,-0.774597,0.647155,0.852980, --0.580460,0.498058,-0.644208,0.000000,-0.580460,0.498058,-0.644208,0.352845,0.912551, --0.866018,-0.097907,-0.490334,0.000000,-0.866018,-0.097907,-0.490334,0.500000,0.853312, --0.758172,-0.246345,-0.603730,0.000000,-0.758172,-0.246345,-0.603730,0.265712,0.892312, --0.850651,-0.276393,-0.447214,0.000000,-0.850651,-0.276393,-0.447214,0.445347,0.922791, --0.851981,0.083904,-0.516806,0.000000,-0.851981,0.083904,-0.516806,0.554653,0.922791, --0.762354,-0.061751,-0.644208,0.000000,-0.762354,-0.061751,-0.644208,0.319635,0.835614, --0.866018,-0.097907,-0.490334,0.000000,-0.866018,-0.097907,-0.490334,0.500000,0.853312, --0.809017,0.262866,-0.525731,0.000000,-0.809017,0.262866,-0.525731,0.591739,0.848850, --0.736685,0.124433,-0.664689,0.000000,-0.736685,0.124433,-0.664689,0.237134,0.814054, --0.851981,0.083904,-0.516806,0.000000,-0.851981,0.083904,-0.516806,0.554653,0.922791, --0.669131,0.332344,-0.664689,0.000000,-0.669131,0.332344,-0.664689,0.408260,0.848850, --0.809017,0.262866,-0.525731,0.000000,-0.809017,0.262866,-0.525731,0.591739,0.848850, --0.738585,0.432902,-0.516806,0.000000,-0.738585,0.432902,-0.516806,0.647155,0.912551, --0.580460,0.498058,-0.644208,0.000000,-0.580460,0.498058,-0.644208,0.352845,0.912551, --0.738585,0.432902,-0.516806,0.000000,-0.738585,0.432902,-0.516806,0.647155,0.912551, --0.643075,0.588241,-0.490334,0.000000,-0.643075,0.588241,-0.490334,0.680365,0.835614, --0.468576,0.644939,-0.603730,0.000000,-0.468576,0.644939,-0.603730,0.853312,0.631433, --0.643075,0.588241,-0.490334,0.000000,-0.643075,0.588241,-0.490334,0.680365,0.835614, --0.525731,0.723607,-0.447214,0.000000,-0.525731,0.723607,-0.447214,0.446077,0.574219, --0.762354,-0.061751,-0.644208,0.000000,-0.762354,-0.061751,-0.644208,0.319635,0.835614, --0.758172,-0.246345,-0.603730,0.000000,-0.758172,-0.246345,-0.603730,0.265712,0.892312, --0.866018,-0.097907,-0.490334,0.000000,-0.866018,-0.097907,-0.490334,0.500000,0.853312, --0.736685,0.124433,-0.664689,0.000000,-0.736685,0.124433,-0.664689,0.237134,0.814054, --0.762354,-0.061751,-0.644208,0.000000,-0.762354,-0.061751,-0.644208,0.319635,0.835614, --0.851981,0.083904,-0.516806,0.000000,-0.851981,0.083904,-0.516806,0.554653,0.922791, --0.669131,0.332344,-0.664689,0.000000,-0.669131,0.332344,-0.664689,0.408260,0.848850, --0.736685,0.124433,-0.664689,0.000000,-0.736685,0.124433,-0.664689,0.237134,0.814054, --0.809017,0.262866,-0.525731,0.000000,-0.809017,0.262866,-0.525731,0.591739,0.848850, --0.580460,0.498058,-0.644208,0.000000,-0.580460,0.498058,-0.644208,0.352845,0.912551, --0.669131,0.332344,-0.664689,0.000000,-0.669131,0.332344,-0.664689,0.408260,0.848850, --0.738585,0.432902,-0.516806,0.000000,-0.738585,0.432902,-0.516806,0.647155,0.912551, --0.468576,0.644939,-0.603730,0.000000,-0.468576,0.644939,-0.603730,0.853312,0.631433, --0.580460,0.498058,-0.644208,0.000000,-0.580460,0.498058,-0.644208,0.352845,0.912551, --0.643075,0.588241,-0.490334,0.000000,-0.643075,0.588241,-0.490334,0.680365,0.835614, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.500000,0.500000, -0.000000,-0.183479,-0.983024,0.000000,0.000000,-0.183479,-0.983024,0.500000,0.408260, --0.174499,-0.056698,-0.983024,0.000000,-0.174499,-0.056698,-0.983024,0.552265,0.722382, --0.176851,-0.243415,-0.953663,0.000000,-0.176851,-0.243415,-0.953663,0.412750,0.471651, -0.000000,-0.183479,-0.983024,0.000000,0.000000,-0.183479,-0.983024,0.500000,0.408260, -0.000000,-0.360730,-0.932670,0.000000,0.000000,-0.360730,-0.932670,0.500000,0.319635, --0.174499,-0.056698,-0.983024,0.000000,-0.174499,-0.056698,-0.983024,0.552265,0.722382, --0.176851,-0.243415,-0.953663,0.000000,-0.176851,-0.243415,-0.953663,0.412750,0.471651, --0.343074,-0.111472,-0.932670,0.000000,-0.343074,-0.111472,-0.932670,0.302245,0.772187, --0.174499,-0.056698,-0.983024,0.000000,-0.174499,-0.056698,-0.983024,0.552265,0.722382, -0.000000,-0.183479,-0.983024,0.000000,0.000000,-0.183479,-0.983024,0.500000,0.408260, --0.176851,-0.243415,-0.953663,0.000000,-0.176851,-0.243415,-0.953663,0.412750,0.471651, --0.176860,-0.421262,-0.889527,0.000000,-0.176860,-0.421262,-0.889527,0.356925,0.546488, -0.000000,-0.360730,-0.932670,0.000000,0.000000,-0.360730,-0.932670,0.500000,0.319635, -0.000000,-0.525731,-0.850651,0.000000,0.000000,-0.525731,-0.850651,0.500000,0.237134, --0.176851,-0.243415,-0.953663,0.000000,-0.176851,-0.243415,-0.953663,0.412750,0.471651, --0.176860,-0.421262,-0.889527,0.000000,-0.176860,-0.421262,-0.889527,0.356925,0.546488, --0.345991,-0.298381,-0.889527,0.000000,-0.345991,-0.298381,-0.889527,0.328463,0.444264, --0.343074,-0.111472,-0.932670,0.000000,-0.343074,-0.111472,-0.932670,0.302245,0.772187, --0.345991,-0.298381,-0.889527,0.000000,-0.345991,-0.298381,-0.889527,0.328463,0.444264, --0.500000,-0.162460,-0.850651,0.000000,-0.500000,-0.162460,-0.850651,0.606917,0.797605, --0.176851,-0.243415,-0.953663,0.000000,-0.176851,-0.243415,-0.953663,0.412750,0.471651, -0.000000,-0.360730,-0.932670,0.000000,0.000000,-0.360730,-0.932670,0.500000,0.319635, --0.176860,-0.421262,-0.889527,0.000000,-0.176860,-0.421262,-0.889527,0.356925,0.546488, --0.343074,-0.111472,-0.932670,0.000000,-0.343074,-0.111472,-0.932670,0.302245,0.772187, --0.176851,-0.243415,-0.953663,0.000000,-0.176851,-0.243415,-0.953663,0.412750,0.471651, --0.345991,-0.298381,-0.889527,0.000000,-0.345991,-0.298381,-0.889527,0.328463,0.444264, --0.176860,-0.607223,-0.774597,0.000000,-0.176860,-0.607223,-0.774597,0.272352,0.519013, -0.000000,-0.525731,-0.850651,0.000000,0.000000,-0.525731,-0.850651,0.500000,0.237134, -0.000000,-0.672883,-0.739749,0.000000,0.000000,-0.672883,-0.739749,0.500000,0.163559, --0.356822,-0.491123,-0.794655,0.000000,-0.356822,-0.491123,-0.794655,0.250000,0.418770, --0.176860,-0.421262,-0.889527,0.000000,-0.176860,-0.421262,-0.889527,0.356925,0.546488, --0.176860,-0.607223,-0.774597,0.000000,-0.176860,-0.607223,-0.774597,0.272352,0.519013, --0.345991,-0.298381,-0.889527,0.000000,-0.345991,-0.298381,-0.889527,0.328463,0.444264, --0.356822,-0.491123,-0.794655,0.000000,-0.356822,-0.491123,-0.794655,0.250000,0.418770, --0.522851,-0.355846,-0.774597,0.000000,-0.522851,-0.355846,-0.774597,0.304653,0.618427, --0.500000,-0.162460,-0.850651,0.000000,-0.500000,-0.162460,-0.850651,0.606917,0.797605, --0.522851,-0.355846,-0.774597,0.000000,-0.522851,-0.355846,-0.774597,0.304653,0.618427, --0.639949,-0.207932,-0.739749,0.000000,-0.639949,-0.207932,-0.739749,0.445347,0.869541, --0.176860,-0.421262,-0.889527,0.000000,-0.176860,-0.421262,-0.889527,0.356925,0.546488, -0.000000,-0.525731,-0.850651,0.000000,0.000000,-0.525731,-0.850651,0.500000,0.237134, --0.176860,-0.607223,-0.774597,0.000000,-0.176860,-0.607223,-0.774597,0.272352,0.519013, --0.345991,-0.298381,-0.889527,0.000000,-0.345991,-0.298381,-0.889527,0.328463,0.444264, --0.176860,-0.421262,-0.889527,0.000000,-0.176860,-0.421262,-0.889527,0.356925,0.546488, --0.356822,-0.491123,-0.794655,0.000000,-0.356822,-0.491123,-0.794655,0.250000,0.418770, --0.500000,-0.162460,-0.850651,0.000000,-0.500000,-0.162460,-0.850651,0.606917,0.797605, --0.345991,-0.298381,-0.889527,0.000000,-0.345991,-0.298381,-0.889527,0.328463,0.444264, --0.522851,-0.355846,-0.774597,0.000000,-0.522851,-0.355846,-0.774597,0.304653,0.618427, --0.176851,-0.744124,-0.644208,0.000000,-0.176851,-0.744124,-0.644208,0.183922,0.490281, -0.000000,-0.672883,-0.739749,0.000000,0.000000,-0.672883,-0.739749,0.500000,0.163559, -0.000000,-0.797189,-0.603730,0.000000,0.000000,-0.797189,-0.603730,0.672996,0.168911, --0.345991,-0.662178,-0.664689,0.000000,-0.345991,-0.662178,-0.664689,0.180025,0.396034, --0.176860,-0.607223,-0.774597,0.000000,-0.176860,-0.607223,-0.774597,0.272352,0.519013, --0.176851,-0.744124,-0.644208,0.000000,-0.176851,-0.744124,-0.644208,0.183922,0.490281, --0.356822,-0.491123,-0.794655,0.000000,-0.356822,-0.491123,-0.794655,0.250000,0.418770, --0.345991,-0.662178,-0.664689,0.000000,-0.345991,-0.662178,-0.664689,0.180025,0.396034, --0.522851,-0.533681,-0.664689,0.000000,-0.522851,-0.533681,-0.664689,0.211325,0.593796, --0.522851,-0.355846,-0.774597,0.000000,-0.522851,-0.355846,-0.774597,0.304653,0.618427, --0.522851,-0.533681,-0.664689,0.000000,-0.522851,-0.533681,-0.664689,0.211325,0.593796, --0.653054,-0.398142,-0.644208,0.000000,-0.653054,-0.398142,-0.644208,0.250001,0.693650, --0.639949,-0.207932,-0.739749,0.000000,-0.639949,-0.207932,-0.739749,0.445347,0.869541, --0.653054,-0.398142,-0.644208,0.000000,-0.653054,-0.398142,-0.644208,0.250001,0.693650, --0.758172,-0.246345,-0.603730,0.000000,-0.758172,-0.246345,-0.603730,0.265712,0.892312, --0.176860,-0.607223,-0.774597,0.000000,-0.176860,-0.607223,-0.774597,0.272352,0.519013, -0.000000,-0.672883,-0.739749,0.000000,0.000000,-0.672883,-0.739749,0.500000,0.163559, --0.176851,-0.744124,-0.644208,0.000000,-0.176851,-0.744124,-0.644208,0.183922,0.490281, --0.356822,-0.491123,-0.794655,0.000000,-0.356822,-0.491123,-0.794655,0.250000,0.418770, --0.176860,-0.607223,-0.774597,0.000000,-0.176860,-0.607223,-0.774597,0.272352,0.519013, --0.345991,-0.662178,-0.664689,0.000000,-0.345991,-0.662178,-0.664689,0.180025,0.396034, --0.522851,-0.355846,-0.774597,0.000000,-0.522851,-0.355846,-0.774597,0.304653,0.618427, --0.356822,-0.491123,-0.794655,0.000000,-0.356822,-0.491123,-0.794655,0.250000,0.418770, --0.522851,-0.533681,-0.664689,0.000000,-0.522851,-0.533681,-0.664689,0.211325,0.593796, --0.639949,-0.207932,-0.739749,0.000000,-0.639949,-0.207932,-0.739749,0.445347,0.869541, --0.522851,-0.355846,-0.774597,0.000000,-0.522851,-0.355846,-0.774597,0.304653,0.618427, --0.653054,-0.398142,-0.644208,0.000000,-0.653054,-0.398142,-0.644208,0.250001,0.693650, --0.174499,-0.853887,-0.490334,0.000000,-0.174499,-0.853887,-0.490334,0.131658,0.562217, -0.000000,-0.797189,-0.603730,0.000000,0.000000,-0.797189,-0.603730,0.672996,0.168911, -0.000000,-0.894427,-0.447214,0.000000,0.000000,-0.894427,-0.447214,0.848850,0.215669, --0.343074,-0.784354,-0.516806,0.000000,-0.343074,-0.784354,-0.516806,0.165435,0.666172, --0.176851,-0.744124,-0.644208,0.000000,-0.176851,-0.744124,-0.644208,0.183922,0.490281, --0.174499,-0.853887,-0.490334,0.000000,-0.174499,-0.853887,-0.490334,0.131658,0.562217, --0.500000,-0.688191,-0.525731,0.000000,-0.500000,-0.688191,-0.525731,0.209770,0.749029, --0.345991,-0.662178,-0.664689,0.000000,-0.345991,-0.662178,-0.664689,0.180025,0.396034, --0.343074,-0.784354,-0.516806,0.000000,-0.343074,-0.784354,-0.516806,0.165435,0.666172, --0.522851,-0.533681,-0.664689,0.000000,-0.522851,-0.533681,-0.664689,0.211325,0.593796, --0.500000,-0.688191,-0.525731,0.000000,-0.500000,-0.688191,-0.525731,0.209770,0.749029, --0.639949,-0.568662,-0.516806,0.000000,-0.639949,-0.568662,-0.516806,0.118823,0.469124, --0.653054,-0.398142,-0.644208,0.000000,-0.653054,-0.398142,-0.644208,0.250001,0.693650, --0.639949,-0.568662,-0.516806,0.000000,-0.639949,-0.568662,-0.516806,0.118823,0.469124, --0.758172,-0.429824,-0.490334,0.000000,-0.758172,-0.429824,-0.490334,0.178463,0.835614, --0.758172,-0.246345,-0.603730,0.000000,-0.758172,-0.246345,-0.603730,0.265712,0.892312, --0.758172,-0.429824,-0.490334,0.000000,-0.758172,-0.429824,-0.490334,0.178463,0.835614, --0.850651,-0.276393,-0.447214,0.000000,-0.850651,-0.276393,-0.447214,0.445347,0.922791, --0.176851,-0.744124,-0.644208,0.000000,-0.176851,-0.744124,-0.644208,0.183922,0.490281, -0.000000,-0.797189,-0.603730,0.000000,0.000000,-0.797189,-0.603730,0.672996,0.168911, --0.174499,-0.853887,-0.490334,0.000000,-0.174499,-0.853887,-0.490334,0.131658,0.562217, --0.345991,-0.662178,-0.664689,0.000000,-0.345991,-0.662178,-0.664689,0.180025,0.396034, --0.176851,-0.744124,-0.644208,0.000000,-0.176851,-0.744124,-0.644208,0.183922,0.490281, --0.343074,-0.784354,-0.516806,0.000000,-0.343074,-0.784354,-0.516806,0.165435,0.666172, --0.522851,-0.533681,-0.664689,0.000000,-0.522851,-0.533681,-0.664689,0.211325,0.593796, --0.345991,-0.662178,-0.664689,0.000000,-0.345991,-0.662178,-0.664689,0.180025,0.396034, --0.500000,-0.688191,-0.525731,0.000000,-0.500000,-0.688191,-0.525731,0.209770,0.749029, --0.653054,-0.398142,-0.644208,0.000000,-0.653054,-0.398142,-0.644208,0.250001,0.693650, --0.522851,-0.533681,-0.664689,0.000000,-0.522851,-0.533681,-0.664689,0.211325,0.593796, --0.639949,-0.568662,-0.516806,0.000000,-0.639949,-0.568662,-0.516806,0.118823,0.469124, --0.758172,-0.246345,-0.603730,0.000000,-0.758172,-0.246345,-0.603730,0.265712,0.892312, --0.653054,-0.398142,-0.644208,0.000000,-0.653054,-0.398142,-0.644208,0.250001,0.693650, --0.758172,-0.429824,-0.490334,0.000000,-0.758172,-0.429824,-0.490334,0.178463,0.835614, -0.107846,-0.148438,0.983024,0.000000,0.107846,-0.148438,0.983024,0.209770,0.912551, -0.174499,0.056698,0.983024,0.000000,0.174499,0.056698,0.983024,0.411574,0.378293, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.411570,0.289369, -0.212032,-0.291836,0.932670,0.000000,0.212032,-0.291836,0.932670,0.327004,0.350810, -0.286151,-0.092976,0.953663,0.000000,0.286151,-0.092976,0.953663,0.411570,0.196389, -0.107846,-0.148438,0.983024,0.000000,0.107846,-0.148438,0.983024,0.209770,0.912551, -0.286151,-0.092976,0.953663,0.000000,0.286151,-0.092976,0.953663,0.411570,0.196389, -0.343074,0.111472,0.932670,0.000000,0.343074,0.111472,0.932670,0.321589,0.254439, -0.174499,0.056698,0.983024,0.000000,0.174499,0.056698,0.983024,0.411574,0.378293, -0.107846,-0.148438,0.983024,0.000000,0.107846,-0.148438,0.983024,0.209770,0.912551, -0.286151,-0.092976,0.953663,0.000000,0.286151,-0.092976,0.953663,0.411570,0.196389, -0.174499,0.056698,0.983024,0.000000,0.174499,0.056698,0.983024,0.411574,0.378293, -0.309017,-0.425325,0.850651,0.000000,0.309017,-0.425325,0.850651,0.238575,0.322077, -0.390694,-0.236853,0.889527,0.000000,0.390694,-0.236853,0.889527,0.411574,0.912551, -0.212032,-0.291836,0.932670,0.000000,0.212032,-0.291836,0.932670,0.327004,0.350810, -0.390694,-0.236853,0.889527,0.000000,0.390694,-0.236853,0.889527,0.411574,0.912551, -0.455297,-0.038026,0.889527,0.000000,0.455297,-0.038026,0.889527,0.327004,0.168911, -0.286151,-0.092976,0.953663,0.000000,0.286151,-0.092976,0.953663,0.411570,0.196389, -0.455297,-0.038026,0.889527,0.000000,0.455297,-0.038026,0.889527,0.327004,0.168911, -0.500000,0.162460,0.850651,0.000000,0.500000,0.162460,0.850651,0.411574,0.127938, -0.343074,0.111472,0.932670,0.000000,0.343074,0.111472,0.932670,0.321589,0.254439, -0.212032,-0.291836,0.932670,0.000000,0.212032,-0.291836,0.932670,0.327004,0.350810, -0.390694,-0.236853,0.889527,0.000000,0.390694,-0.236853,0.889527,0.411574,0.912551, -0.286151,-0.092976,0.953663,0.000000,0.286151,-0.092976,0.953663,0.411570,0.196389, -0.455297,-0.038026,0.889527,0.000000,0.455297,-0.038026,0.889527,0.327004,0.168911, -0.343074,0.111472,0.932670,0.000000,0.343074,0.111472,0.932670,0.321589,0.254439, -0.286151,-0.092976,0.953663,0.000000,0.286151,-0.092976,0.953663,0.411570,0.196389, -0.395510,-0.544373,0.739749,0.000000,0.395510,-0.544373,0.739749,0.238575,0.233160, -0.499999,-0.387298,0.774597,0.000000,0.499999,-0.387298,0.774597,0.173473,0.300929, -0.309017,-0.425325,0.850651,0.000000,0.309017,-0.425325,0.850651,0.238575,0.322077, -0.499999,-0.387298,0.774597,0.000000,0.499999,-0.387298,0.774597,0.173473,0.300929, -0.577350,-0.187592,0.794654,0.000000,0.577350,-0.187592,0.794654,0.412750,0.835614, -0.390694,-0.236853,0.889527,0.000000,0.390694,-0.236853,0.889527,0.411574,0.912551, -0.577350,-0.187592,0.794654,0.000000,0.577350,-0.187592,0.794654,0.412750,0.835614, -0.632156,0.019439,0.774597,0.000000,0.632156,0.019439,0.774597,0.328463,0.848850, -0.455297,-0.038026,0.889527,0.000000,0.455297,-0.038026,0.889527,0.327004,0.168911, -0.632156,0.019439,0.774597,0.000000,0.632156,0.019439,0.774597,0.328463,0.848850, -0.639949,0.207932,0.739749,0.000000,0.639949,0.207932,0.739749,0.250000,0.853312, -0.500000,0.162460,0.850651,0.000000,0.500000,0.162460,0.850651,0.411574,0.127938, -0.309017,-0.425325,0.850651,0.000000,0.309017,-0.425325,0.850651,0.238575,0.322077, -0.499999,-0.387298,0.774597,0.000000,0.499999,-0.387298,0.774597,0.173473,0.300929, -0.390694,-0.236853,0.889527,0.000000,0.390694,-0.236853,0.889527,0.411574,0.912551, -0.390694,-0.236853,0.889527,0.000000,0.390694,-0.236853,0.889527,0.411574,0.912551, -0.577350,-0.187592,0.794654,0.000000,0.577350,-0.187592,0.794654,0.412750,0.835614, -0.455297,-0.038026,0.889527,0.000000,0.455297,-0.038026,0.889527,0.327004,0.168911, -0.632156,0.019439,0.774597,0.000000,0.632156,0.019439,0.774597,0.328463,0.848850, -0.500000,0.162460,0.850651,0.000000,0.500000,0.162460,0.850651,0.411574,0.127938, -0.455297,-0.038026,0.889527,0.000000,0.455297,-0.038026,0.889527,0.327004,0.168911, -0.468576,-0.644939,0.603730,0.000000,0.468576,-0.644939,0.603730,0.327004,0.922791, -0.580460,-0.498058,0.644208,0.000000,0.580460,-0.498058,0.644208,0.238575,0.922791, -0.395510,-0.544373,0.739749,0.000000,0.395510,-0.544373,0.739749,0.238575,0.233160, -0.580460,-0.498058,0.644208,0.000000,0.580460,-0.498058,0.644208,0.238575,0.922791, -0.669131,-0.332344,0.664689,0.000000,0.669131,-0.332344,0.664689,0.180025,0.848850, -0.499999,-0.387298,0.774597,0.000000,0.499999,-0.387298,0.774597,0.173473,0.300929, -0.669131,-0.332344,0.664689,0.000000,0.669131,-0.332344,0.664689,0.180025,0.848850, -0.736685,-0.124433,0.664689,0.000000,0.736685,-0.124433,0.664689,0.922791,0.233160, -0.577350,-0.187592,0.794654,0.000000,0.577350,-0.187592,0.794654,0.412750,0.835614, -0.736685,-0.124433,0.664689,0.000000,0.736685,-0.124433,0.664689,0.922791,0.233160, -0.762354,0.061751,0.644208,0.000000,0.762354,0.061751,0.644208,0.553923,0.425781, -0.632156,0.019439,0.774597,0.000000,0.632156,0.019439,0.774597,0.328463,0.848850, -0.762354,0.061751,0.644208,0.000000,0.762354,0.061751,0.644208,0.553923,0.425781, -0.758172,0.246345,0.603730,0.000000,0.758172,0.246345,0.603730,0.587250,0.528349, -0.639949,0.207932,0.739749,0.000000,0.639949,0.207932,0.739749,0.250000,0.853312, -0.395510,-0.544373,0.739749,0.000000,0.395510,-0.544373,0.739749,0.238575,0.233160, -0.580460,-0.498058,0.644208,0.000000,0.580460,-0.498058,0.644208,0.238575,0.922791, -0.499999,-0.387298,0.774597,0.000000,0.499999,-0.387298,0.774597,0.173473,0.300929, -0.499999,-0.387298,0.774597,0.000000,0.499999,-0.387298,0.774597,0.173473,0.300929, -0.669131,-0.332344,0.664689,0.000000,0.669131,-0.332344,0.664689,0.180025,0.848850, -0.577350,-0.187592,0.794654,0.000000,0.577350,-0.187592,0.794654,0.412750,0.835614, -0.736685,-0.124433,0.664689,0.000000,0.736685,-0.124433,0.664689,0.922791,0.233160, -0.632156,0.019439,0.774597,0.000000,0.632156,0.019439,0.774597,0.328463,0.848850, -0.577350,-0.187592,0.794654,0.000000,0.577350,-0.187592,0.794654,0.412750,0.835614, -0.762354,0.061751,0.644208,0.000000,0.762354,0.061751,0.644208,0.553923,0.425781, -0.639949,0.207932,0.739749,0.000000,0.639949,0.207932,0.739749,0.250000,0.853312, -0.632156,0.019439,0.774597,0.000000,0.632156,0.019439,0.774597,0.328463,0.848850, -0.525731,-0.723607,0.447214,0.000000,0.525731,-0.723607,0.447214,0.606016,0.354082, -0.643075,-0.588241,0.490334,0.000000,0.643075,-0.588241,0.490334,0.643075,0.453512, -0.468576,-0.644939,0.603730,0.000000,0.468576,-0.644939,0.603730,0.327004,0.922791, -0.643075,-0.588241,0.490334,0.000000,0.643075,-0.588241,0.490334,0.643075,0.453512, -0.738585,-0.432902,0.516806,0.000000,0.738585,-0.432902,0.516806,0.671537,0.555736, -0.580460,-0.498058,0.644208,0.000000,0.580460,-0.498058,0.644208,0.238575,0.922791, -0.738585,-0.432902,0.516806,0.000000,0.738585,-0.432902,0.516806,0.671537,0.555736, -0.809017,-0.262866,0.525731,0.000000,0.809017,-0.262866,0.525731,0.654508,0.287337, -0.669131,-0.332344,0.664689,0.000000,0.669131,-0.332344,0.664689,0.180025,0.848850, -0.809017,-0.262866,0.525731,0.000000,0.809017,-0.262866,0.525731,0.654508,0.287337, -0.851981,-0.083904,0.516806,0.000000,0.851981,-0.083904,0.516806,0.695347,0.381573, -0.736685,-0.124433,0.664689,0.000000,0.736685,-0.124433,0.664689,0.922791,0.233160, -0.851981,-0.083904,0.516806,0.000000,0.851981,-0.083904,0.516806,0.695347,0.381573, -0.866018,0.097907,0.490334,0.000000,0.866018,0.097907,0.490334,0.727648,0.480987, -0.762354,0.061751,0.644208,0.000000,0.762354,0.061751,0.644208,0.553923,0.425781, -0.866018,0.097907,0.490334,0.000000,0.866018,0.097907,0.490334,0.727648,0.480987, -0.850651,0.276393,0.447214,0.000000,0.850651,0.276393,0.447214,0.750000,0.581230, -0.758172,0.246345,0.603730,0.000000,0.758172,0.246345,0.603730,0.587250,0.528349, -0.468576,-0.644939,0.603730,0.000000,0.468576,-0.644939,0.603730,0.327004,0.922791, -0.643075,-0.588241,0.490334,0.000000,0.643075,-0.588241,0.490334,0.643075,0.453512, -0.580460,-0.498058,0.644208,0.000000,0.580460,-0.498058,0.644208,0.238575,0.922791, -0.580460,-0.498058,0.644208,0.000000,0.580460,-0.498058,0.644208,0.238575,0.922791, -0.738585,-0.432902,0.516806,0.000000,0.738585,-0.432902,0.516806,0.671537,0.555736, -0.669131,-0.332344,0.664689,0.000000,0.669131,-0.332344,0.664689,0.180025,0.848850, -0.669131,-0.332344,0.664689,0.000000,0.669131,-0.332344,0.664689,0.180025,0.848850, -0.809017,-0.262866,0.525731,0.000000,0.809017,-0.262866,0.525731,0.654508,0.287337, -0.736685,-0.124433,0.664689,0.000000,0.736685,-0.124433,0.664689,0.922791,0.233160, -0.851981,-0.083904,0.516806,0.000000,0.851981,-0.083904,0.516806,0.695347,0.381573, -0.762354,0.061751,0.644208,0.000000,0.762354,0.061751,0.644208,0.553923,0.425781, -0.736685,-0.124433,0.664689,0.000000,0.736685,-0.124433,0.664689,0.922791,0.233160, -0.866018,0.097907,0.490334,0.000000,0.866018,0.097907,0.490334,0.727648,0.480987, -0.758172,0.246345,0.603730,0.000000,0.758172,0.246345,0.603730,0.587250,0.528349, -0.762354,0.061751,0.644208,0.000000,0.762354,0.061751,0.644208,0.553923,0.425781, -0.174499,0.056698,0.983024,0.000000,0.174499,0.056698,0.983024,0.411574,0.378293, -0.000000,0.183479,0.983024,0.000000,0.000000,0.183479,0.983024,0.697755,0.227814, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.411570,0.289369, -0.343074,0.111472,0.932670,0.000000,0.343074,0.111472,0.932670,0.321589,0.254439, -0.176851,0.243415,0.953663,0.000000,0.176851,0.243415,0.953663,0.750000,0.306351, -0.174499,0.056698,0.983024,0.000000,0.174499,0.056698,0.983024,0.411574,0.378293, -0.176851,0.243415,0.953663,0.000000,0.176851,0.243415,0.953663,0.750000,0.306351, -0.000000,0.360730,0.932670,0.000000,0.000000,0.360730,0.932670,0.788675,0.406204, -0.000000,0.183479,0.983024,0.000000,0.000000,0.183479,0.983024,0.697755,0.227814, -0.174499,0.056698,0.983024,0.000000,0.174499,0.056698,0.983024,0.411574,0.378293, -0.176851,0.243415,0.953663,0.000000,0.176851,0.243415,0.953663,0.750000,0.306351, -0.000000,0.183479,0.983024,0.000000,0.000000,0.183479,0.983024,0.697755,0.227814, -0.500000,0.162460,0.850651,0.000000,0.500000,0.162460,0.850651,0.411574,0.127938, -0.345991,0.298381,0.889527,0.000000,0.345991,0.298381,0.889527,0.816078,0.509719, -0.343074,0.111472,0.932670,0.000000,0.343074,0.111472,0.932670,0.321589,0.254439, -0.345991,0.298381,0.889527,0.000000,0.345991,0.298381,0.889527,0.816078,0.509719, -0.176860,0.421262,0.889527,0.000000,0.176860,0.421262,0.889527,0.819975,0.603966, -0.176851,0.243415,0.953663,0.000000,0.176851,0.243415,0.953663,0.750000,0.306351, -0.176860,0.421262,0.889527,0.000000,0.176860,0.421262,0.889527,0.819975,0.603966, -0.000000,0.525731,0.850651,0.000000,0.000000,0.525731,0.850651,0.734288,0.177530, -0.000000,0.360730,0.932670,0.000000,0.000000,0.360730,0.932670,0.788675,0.406204, -0.343074,0.111472,0.932670,0.000000,0.343074,0.111472,0.932670,0.321589,0.254439, -0.345991,0.298381,0.889527,0.000000,0.345991,0.298381,0.889527,0.816078,0.509719, -0.176851,0.243415,0.953663,0.000000,0.176851,0.243415,0.953663,0.750000,0.306351, -0.176860,0.421262,0.889527,0.000000,0.176860,0.421262,0.889527,0.819975,0.603966, -0.000000,0.360730,0.932670,0.000000,0.000000,0.360730,0.932670,0.788675,0.406204, -0.176851,0.243415,0.953663,0.000000,0.176851,0.243415,0.953663,0.750000,0.306351, -0.639949,0.207932,0.739749,0.000000,0.639949,0.207932,0.739749,0.250000,0.853312, -0.522851,0.355846,0.774597,0.000000,0.522851,0.355846,0.774597,0.790230,0.250971, -0.500000,0.162460,0.850651,0.000000,0.500000,0.162460,0.850651,0.411574,0.127938, -0.522851,0.355846,0.774597,0.000000,0.522851,0.355846,0.774597,0.790230,0.250971, -0.356822,0.491123,0.794654,0.000000,0.356822,0.491123,0.794654,0.834566,0.333828, -0.345991,0.298381,0.889527,0.000000,0.345991,0.298381,0.889527,0.816078,0.509719, -0.356822,0.491123,0.794654,0.000000,0.356822,0.491123,0.794654,0.834566,0.333828, -0.176860,0.607223,0.774597,0.000000,0.176860,0.607223,0.774597,0.868343,0.437784, -0.176860,0.421262,0.889527,0.000000,0.176860,0.421262,0.889527,0.819975,0.603966, -0.176860,0.607223,0.774597,0.000000,0.176860,0.607223,0.774597,0.868343,0.437784, -0.000000,0.672883,0.739749,0.000000,0.000000,0.672883,0.739749,0.258102,0.437784, -0.000000,0.525731,0.850651,0.000000,0.000000,0.525731,0.850651,0.734288,0.177530, -0.500000,0.162460,0.850651,0.000000,0.500000,0.162460,0.850651,0.411574,0.127938, -0.522851,0.355846,0.774597,0.000000,0.522851,0.355846,0.774597,0.790230,0.250971, -0.345991,0.298381,0.889527,0.000000,0.345991,0.298381,0.889527,0.816078,0.509719, -0.345991,0.298381,0.889527,0.000000,0.345991,0.298381,0.889527,0.816078,0.509719, -0.356822,0.491123,0.794654,0.000000,0.356822,0.491123,0.794654,0.834566,0.333828, -0.176860,0.421262,0.889527,0.000000,0.176860,0.421262,0.889527,0.819975,0.603966, -0.176860,0.607223,0.774597,0.000000,0.176860,0.607223,0.774597,0.868343,0.437784, -0.000000,0.525731,0.850651,0.000000,0.000000,0.525731,0.850651,0.734288,0.177530, -0.176860,0.421262,0.889527,0.000000,0.176860,0.421262,0.889527,0.819975,0.603966, -0.758172,0.246345,0.603730,0.000000,0.758172,0.246345,0.603730,0.587250,0.528349, -0.653054,0.398142,0.644208,0.000000,0.653054,0.398142,0.644208,0.268343,0.530876, -0.639949,0.207932,0.739749,0.000000,0.639949,0.207932,0.739749,0.250000,0.853312, -0.653054,0.398142,0.644208,0.000000,0.653054,0.398142,0.644208,0.268343,0.530876, -0.522851,0.533681,0.664689,0.000000,0.522851,0.533681,0.664689,0.203148,0.509719, -0.522851,0.355846,0.774597,0.000000,0.522851,0.355846,0.774597,0.790230,0.250971, -0.522851,0.533681,0.664689,0.000000,0.522851,0.533681,0.664689,0.203148,0.509719, -0.345991,0.662178,0.664689,0.000000,0.345991,0.662178,0.664689,0.288582,0.623173, -0.356822,0.491123,0.794654,0.000000,0.356822,0.491123,0.794654,0.834566,0.333828, -0.345991,0.662178,0.664689,0.000000,0.345991,0.662178,0.664689,0.288582,0.623173, -0.176851,0.744124,0.644208,0.000000,0.176851,0.744124,0.644208,0.220572,0.603966, -0.176860,0.607223,0.774597,0.000000,0.176860,0.607223,0.774597,0.868343,0.437784, -0.176851,0.744124,0.644208,0.000000,0.176851,0.744124,0.644208,0.220572,0.603966, -0.000000,0.797189,0.603730,0.000000,0.000000,0.797189,0.603730,0.881177,0.530876, -0.000000,0.672883,0.739749,0.000000,0.000000,0.672883,0.739749,0.258102,0.437784, -0.639949,0.207932,0.739749,0.000000,0.639949,0.207932,0.739749,0.250000,0.853312, -0.653054,0.398142,0.644208,0.000000,0.653054,0.398142,0.644208,0.268343,0.530876, -0.522851,0.355846,0.774597,0.000000,0.522851,0.355846,0.774597,0.790230,0.250971, -0.522851,0.355846,0.774597,0.000000,0.522851,0.355846,0.774597,0.790230,0.250971, -0.522851,0.533681,0.664689,0.000000,0.522851,0.533681,0.664689,0.203148,0.509719, -0.356822,0.491123,0.794654,0.000000,0.356822,0.491123,0.794654,0.834566,0.333828, -0.345991,0.662178,0.664689,0.000000,0.345991,0.662178,0.664689,0.288582,0.623173, -0.176860,0.607223,0.774597,0.000000,0.176860,0.607223,0.774597,0.868343,0.437784, -0.356822,0.491123,0.794654,0.000000,0.356822,0.491123,0.794654,0.834566,0.333828, -0.176851,0.744124,0.644208,0.000000,0.176851,0.744124,0.644208,0.220572,0.603966, -0.000000,0.672883,0.739749,0.000000,0.000000,0.672883,0.739749,0.258102,0.437784, -0.176860,0.607223,0.774597,0.000000,0.176860,0.607223,0.774597,0.868343,0.437784, -0.850651,0.276393,0.447214,0.000000,0.850651,0.276393,0.447214,0.750000,0.581230, -0.758172,0.429824,0.490334,0.000000,0.758172,0.429824,0.490334,0.762866,0.366840, -0.758172,0.246345,0.603730,0.000000,0.758172,0.246345,0.603730,0.587250,0.528349, -0.758172,0.429824,0.490334,0.000000,0.758172,0.429824,0.490334,0.762866,0.366840, -0.639949,0.568662,0.516806,0.000000,0.639949,0.568662,0.516806,0.821537,0.345280, -0.653054,0.398142,0.644208,0.000000,0.653054,0.398142,0.644208,0.268343,0.530876, -0.639949,0.568662,0.516806,0.000000,0.639949,0.568662,0.516806,0.821537,0.345280, -0.500000,0.688191,0.525731,0.000000,0.500000,0.688191,0.525731,0.734288,0.288582, -0.522851,0.533681,0.664689,0.000000,0.522851,0.533681,0.664689,0.203148,0.509719, -0.500000,0.688191,0.525731,0.000000,0.500000,0.688191,0.525731,0.734288,0.288582, -0.343074,0.784354,0.516806,0.000000,0.343074,0.784354,0.516806,0.345280,0.205880, -0.345991,0.662178,0.664689,0.000000,0.345991,0.662178,0.664689,0.288582,0.623173, -0.343074,0.784354,0.516806,0.000000,0.343074,0.784354,0.516806,0.345280,0.205880, -0.174499,0.853887,0.490334,0.000000,0.174499,0.853887,0.490334,0.332044,0.283549, -0.176851,0.744124,0.644208,0.000000,0.176851,0.744124,0.644208,0.220572,0.603966, -0.174499,0.853887,0.490334,0.000000,0.174499,0.853887,0.490334,0.332044,0.283549, -0.000000,0.894427,0.447214,0.000000,0.000000,0.894427,0.447214,0.268343,0.250971, -0.000000,0.797189,0.603730,0.000000,0.000000,0.797189,0.603730,0.881177,0.530876, -0.758172,0.246345,0.603730,0.000000,0.758172,0.246345,0.603730,0.587250,0.528349, -0.758172,0.429824,0.490334,0.000000,0.758172,0.429824,0.490334,0.762866,0.366840, -0.653054,0.398142,0.644208,0.000000,0.653054,0.398142,0.644208,0.268343,0.530876, -0.653054,0.398142,0.644208,0.000000,0.653054,0.398142,0.644208,0.268343,0.530876, -0.639949,0.568662,0.516806,0.000000,0.639949,0.568662,0.516806,0.821537,0.345280, -0.522851,0.533681,0.664689,0.000000,0.522851,0.533681,0.664689,0.203148,0.509719, -0.522851,0.533681,0.664689,0.000000,0.522851,0.533681,0.664689,0.203148,0.509719, -0.500000,0.688191,0.525731,0.000000,0.500000,0.688191,0.525731,0.734288,0.288582, -0.345991,0.662178,0.664689,0.000000,0.345991,0.662178,0.664689,0.288582,0.623173, -0.343074,0.784354,0.516806,0.000000,0.343074,0.784354,0.516806,0.345280,0.205880, -0.176851,0.744124,0.644208,0.000000,0.176851,0.744124,0.644208,0.220572,0.603966, -0.345991,0.662178,0.664689,0.000000,0.345991,0.662178,0.664689,0.288582,0.623173, -0.174499,0.853887,0.490334,0.000000,0.174499,0.853887,0.490334,0.332044,0.283549, -0.000000,0.797189,0.603730,0.000000,0.000000,0.797189,0.603730,0.881177,0.530876, -0.176851,0.744124,0.644208,0.000000,0.176851,0.744124,0.644208,0.220572,0.603966, -0.000000,0.183479,0.983024,0.000000,0.000000,0.183479,0.983024,0.697755,0.227814, --0.174499,0.056698,0.983024,0.000000,-0.174499,0.056698,0.983024,0.327581,0.368567, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.411570,0.289369, -0.000000,0.360730,0.932670,0.000000,0.000000,0.360730,0.932670,0.788675,0.406204, --0.176851,0.243415,0.953663,0.000000,-0.176851,0.243415,0.953663,0.258102,0.333828, -0.000000,0.183479,0.983024,0.000000,0.000000,0.183479,0.983024,0.697755,0.227814, --0.176851,0.243415,0.953663,0.000000,-0.176851,0.243415,0.953663,0.258102,0.333828, --0.343074,0.111472,0.932670,0.000000,-0.343074,0.111472,0.932670,0.332044,0.458048, --0.174499,0.056698,0.983024,0.000000,-0.174499,0.056698,0.983024,0.327581,0.368567, --0.176851,0.243415,0.953663,0.000000,-0.176851,0.243415,0.953663,0.258102,0.333828, --0.174499,0.056698,0.983024,0.000000,-0.174499,0.056698,0.983024,0.327581,0.368567, -0.000000,0.183479,0.983024,0.000000,0.000000,0.183479,0.983024,0.697755,0.227814, -0.000000,0.525731,0.850651,0.000000,0.000000,0.525731,0.850651,0.734288,0.177530, --0.176860,0.421262,0.889527,0.000000,-0.176860,0.421262,0.889527,0.345280,0.548954, -0.000000,0.360730,0.932670,0.000000,0.000000,0.360730,0.932670,0.788675,0.406204, --0.176860,0.421262,0.889527,0.000000,-0.176860,0.421262,0.889527,0.345280,0.548954, --0.345991,0.298381,0.889527,0.000000,-0.345991,0.298381,0.889527,0.366840,0.638196, --0.176851,0.243415,0.953663,0.000000,-0.176851,0.243415,0.953663,0.258102,0.333828, --0.345991,0.298381,0.889527,0.000000,-0.345991,0.298381,0.889527,0.366840,0.638196, --0.500000,0.162460,0.850651,0.000000,-0.500000,0.162460,0.850651,0.790230,0.268343, --0.343074,0.111472,0.932670,0.000000,-0.343074,0.111472,0.932670,0.332044,0.458048, -0.000000,0.360730,0.932670,0.000000,0.000000,0.360730,0.932670,0.788675,0.406204, --0.176860,0.421262,0.889527,0.000000,-0.176860,0.421262,0.889527,0.345280,0.548954, --0.176851,0.243415,0.953663,0.000000,-0.176851,0.243415,0.953663,0.258102,0.333828, --0.345991,0.298381,0.889527,0.000000,-0.345991,0.298381,0.889527,0.366840,0.638196, --0.343074,0.111472,0.932670,0.000000,-0.343074,0.111472,0.932670,0.332044,0.458048, --0.176851,0.243415,0.953663,0.000000,-0.176851,0.243415,0.953663,0.258102,0.333828, -0.000000,0.672883,0.739749,0.000000,0.000000,0.672883,0.739749,0.258102,0.437784, --0.176860,0.607223,0.774597,0.000000,-0.176860,0.607223,0.774597,0.500000,0.591739, -0.000000,0.525731,0.850651,0.000000,0.000000,0.525731,0.850651,0.734288,0.177530, --0.176860,0.607223,0.774597,0.000000,-0.176860,0.607223,0.774597,0.500000,0.591739, --0.356822,0.491123,0.794654,0.000000,-0.356822,0.491123,0.794654,0.588426,0.621707, --0.176860,0.421262,0.889527,0.000000,-0.176860,0.421262,0.889527,0.345280,0.548954, --0.356822,0.491123,0.794654,0.000000,-0.356822,0.491123,0.794654,0.588426,0.621707, --0.522851,0.355846,0.774597,0.000000,-0.522851,0.355846,0.774597,0.500000,0.680365, --0.345991,0.298381,0.889527,0.000000,-0.345991,0.298381,0.889527,0.366840,0.638196, --0.522851,0.355846,0.774597,0.000000,-0.522851,0.355846,0.774597,0.500000,0.680365, --0.639949,0.207932,0.739749,0.000000,-0.639949,0.207932,0.739749,0.672996,0.649190, --0.500000,0.162460,0.850651,0.000000,-0.500000,0.162460,0.850651,0.790230,0.268343, -0.000000,0.525731,0.850651,0.000000,0.000000,0.525731,0.850651,0.734288,0.177530, --0.176860,0.607223,0.774597,0.000000,-0.176860,0.607223,0.774597,0.500000,0.591739, --0.176860,0.421262,0.889527,0.000000,-0.176860,0.421262,0.889527,0.345280,0.548954, --0.356822,0.491123,0.794654,0.000000,-0.356822,0.491123,0.794654,0.588426,0.621707, --0.345991,0.298381,0.889527,0.000000,-0.345991,0.298381,0.889527,0.366840,0.638196, --0.176860,0.421262,0.889527,0.000000,-0.176860,0.421262,0.889527,0.345280,0.548954, --0.522851,0.355846,0.774597,0.000000,-0.522851,0.355846,0.774597,0.500000,0.680365, --0.500000,0.162460,0.850651,0.000000,-0.500000,0.162460,0.850651,0.790230,0.268343, --0.345991,0.298381,0.889527,0.000000,-0.345991,0.298381,0.889527,0.366840,0.638196, -0.000000,0.797189,0.603730,0.000000,0.000000,0.797189,0.603730,0.881177,0.530876, --0.176851,0.744124,0.644208,0.000000,-0.176851,0.744124,0.644208,0.588430,0.710631, -0.000000,0.672883,0.739749,0.000000,0.000000,0.672883,0.739749,0.258102,0.437784, --0.176851,0.744124,0.644208,0.000000,-0.176851,0.744124,0.644208,0.588430,0.710631, --0.345991,0.662178,0.664689,0.000000,-0.345991,0.662178,0.664689,0.500000,0.762866, --0.176860,0.607223,0.774597,0.000000,-0.176860,0.607223,0.774597,0.500000,0.591739, --0.345991,0.662178,0.664689,0.000000,-0.345991,0.662178,0.664689,0.500000,0.762866, --0.522851,0.533682,0.664689,0.000000,-0.522851,0.533682,0.664689,0.761425,0.677923, --0.356822,0.491123,0.794654,0.000000,-0.356822,0.491123,0.794654,0.588426,0.621707, --0.522851,0.533682,0.664689,0.000000,-0.522851,0.533682,0.664689,0.761425,0.677923, --0.653054,0.398142,0.644208,0.000000,-0.653054,0.398142,0.644208,0.678411,0.745561, --0.522851,0.355846,0.774597,0.000000,-0.522851,0.355846,0.774597,0.500000,0.680365, --0.653054,0.398142,0.644208,0.000000,-0.653054,0.398142,0.644208,0.678411,0.745561, --0.758172,0.246345,0.603730,0.000000,-0.758172,0.246345,0.603730,0.588430,0.803612, --0.639949,0.207932,0.739749,0.000000,-0.639949,0.207932,0.739749,0.672996,0.649190, -0.000000,0.672883,0.739749,0.000000,0.000000,0.672883,0.739749,0.258102,0.437784, --0.176851,0.744124,0.644208,0.000000,-0.176851,0.744124,0.644208,0.588430,0.710631, --0.176860,0.607223,0.774597,0.000000,-0.176860,0.607223,0.774597,0.500000,0.591739, --0.176860,0.607223,0.774597,0.000000,-0.176860,0.607223,0.774597,0.500000,0.591739, --0.345991,0.662178,0.664689,0.000000,-0.345991,0.662178,0.664689,0.500000,0.762866, --0.356822,0.491123,0.794654,0.000000,-0.356822,0.491123,0.794654,0.588426,0.621707, --0.522851,0.533682,0.664689,0.000000,-0.522851,0.533682,0.664689,0.761425,0.677923, --0.522851,0.355846,0.774597,0.000000,-0.522851,0.355846,0.774597,0.500000,0.680365, --0.356822,0.491123,0.794654,0.000000,-0.356822,0.491123,0.794654,0.588426,0.621707, --0.653054,0.398142,0.644208,0.000000,-0.653054,0.398142,0.644208,0.678411,0.745561, --0.639949,0.207932,0.739749,0.000000,-0.639949,0.207932,0.739749,0.672996,0.649190, --0.522851,0.355846,0.774597,0.000000,-0.522851,0.355846,0.774597,0.500000,0.680365, -0.000000,0.894427,0.447214,0.000000,0.000000,0.894427,0.447214,0.268343,0.250971, --0.174499,0.853887,0.490334,0.000000,-0.174499,0.853887,0.490334,0.500000,0.836442, -0.000000,0.797189,0.603730,0.000000,0.000000,0.797189,0.603730,0.881177,0.530876, --0.174499,0.853887,0.490334,0.000000,-0.174499,0.853887,0.490334,0.500000,0.836442, --0.343074,0.784354,0.516806,0.000000,-0.343074,0.784354,0.516806,0.268343,0.699071, --0.176851,0.744124,0.644208,0.000000,-0.176851,0.744124,0.644208,0.588430,0.710631, --0.343074,0.784354,0.516806,0.000000,-0.343074,0.784354,0.516806,0.268343,0.699071, --0.500000,0.688191,0.525731,0.000000,-0.500000,0.688191,0.525731,0.826527,0.699071, --0.345991,0.662178,0.664689,0.000000,-0.345991,0.662178,0.664689,0.500000,0.762866, --0.500000,0.688191,0.525731,0.000000,-0.500000,0.688191,0.525731,0.826527,0.699071, --0.639949,0.568662,0.516806,0.000000,-0.639949,0.568662,0.516806,0.761425,0.766840, --0.522851,0.533682,0.664689,0.000000,-0.522851,0.533682,0.664689,0.761425,0.677923, --0.639949,0.568662,0.516806,0.000000,-0.639949,0.568662,0.516806,0.761425,0.766840, --0.758172,0.429824,0.490334,0.000000,-0.758172,0.429824,0.490334,0.672996,0.831089, --0.653054,0.398142,0.644208,0.000000,-0.653054,0.398142,0.644208,0.678411,0.745561, --0.758172,0.429824,0.490334,0.000000,-0.758172,0.429824,0.490334,0.672996,0.831089, --0.850651,0.276393,0.447214,0.000000,-0.850651,0.276393,0.447214,0.588426,0.872062, --0.758172,0.246345,0.603730,0.000000,-0.758172,0.246345,0.603730,0.588430,0.803612, -0.000000,0.797189,0.603730,0.000000,0.000000,0.797189,0.603730,0.881177,0.530876, --0.174499,0.853887,0.490334,0.000000,-0.174499,0.853887,0.490334,0.500000,0.836442, --0.176851,0.744124,0.644208,0.000000,-0.176851,0.744124,0.644208,0.588430,0.710631, --0.176851,0.744124,0.644208,0.000000,-0.176851,0.744124,0.644208,0.588430,0.710631, --0.343074,0.784354,0.516806,0.000000,-0.343074,0.784354,0.516806,0.268343,0.699071, --0.345991,0.662178,0.664689,0.000000,-0.345991,0.662178,0.664689,0.500000,0.762866, --0.500000,0.688191,0.525731,0.000000,-0.500000,0.688191,0.525731,0.826527,0.699071, --0.522851,0.533682,0.664689,0.000000,-0.522851,0.533682,0.664689,0.761425,0.677923, --0.345991,0.662178,0.664689,0.000000,-0.345991,0.662178,0.664689,0.500000,0.762866, --0.639949,0.568662,0.516806,0.000000,-0.639949,0.568662,0.516806,0.761425,0.766840, --0.653054,0.398142,0.644208,0.000000,-0.653054,0.398142,0.644208,0.678411,0.745561, --0.522851,0.533682,0.664689,0.000000,-0.522851,0.533682,0.664689,0.761425,0.677923, --0.758172,0.429824,0.490334,0.000000,-0.758172,0.429824,0.490334,0.672996,0.831089, --0.758172,0.246345,0.603730,0.000000,-0.758172,0.246345,0.603730,0.588430,0.803612, --0.653054,0.398142,0.644208,0.000000,-0.653054,0.398142,0.644208,0.678411,0.745561, --0.174499,0.056698,0.983024,0.000000,-0.174499,0.056698,0.983024,0.327581,0.368567, --0.107846,-0.148438,0.983024,0.000000,-0.107846,-0.148438,0.983024,0.588426,0.268343, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.411570,0.289369, --0.343074,0.111472,0.932670,0.000000,-0.343074,0.111472,0.932670,0.332044,0.458048, --0.286151,-0.092976,0.953663,0.000000,-0.286151,-0.092976,0.953663,0.500000,0.288582, --0.174499,0.056698,0.983024,0.000000,-0.174499,0.056698,0.983024,0.327581,0.368567, --0.286151,-0.092976,0.953663,0.000000,-0.286151,-0.092976,0.953663,0.500000,0.288582, --0.212032,-0.291836,0.932670,0.000000,-0.212032,-0.291836,0.932670,0.500000,0.220572, --0.107846,-0.148438,0.983024,0.000000,-0.107846,-0.148438,0.983024,0.588426,0.268343, --0.286151,-0.092976,0.953663,0.000000,-0.286151,-0.092976,0.953663,0.500000,0.288582, --0.107846,-0.148438,0.983024,0.000000,-0.107846,-0.148438,0.983024,0.588426,0.268343, --0.174499,0.056698,0.983024,0.000000,-0.174499,0.056698,0.983024,0.327581,0.368567, --0.500000,0.162460,0.850651,0.000000,-0.500000,0.162460,0.850651,0.790230,0.268343, --0.455297,-0.038026,0.889527,0.000000,-0.455297,-0.038026,0.889527,0.345280,0.714912, --0.343074,0.111472,0.932670,0.000000,-0.343074,0.111472,0.932670,0.332044,0.458048, --0.455297,-0.038026,0.889527,0.000000,-0.455297,-0.038026,0.889527,0.345280,0.714912, --0.390694,-0.236853,0.889527,0.000000,-0.390694,-0.236853,0.889527,0.332044,0.784331, --0.286151,-0.092976,0.953663,0.000000,-0.286151,-0.092976,0.953663,0.500000,0.288582, --0.390694,-0.236853,0.889527,0.000000,-0.390694,-0.236853,0.889527,0.332044,0.784331, --0.309017,-0.425325,0.850651,0.000000,-0.309017,-0.425325,0.850651,0.819975,0.332044, --0.212032,-0.291836,0.932670,0.000000,-0.212032,-0.291836,0.932670,0.500000,0.220572, --0.343074,0.111472,0.932670,0.000000,-0.343074,0.111472,0.932670,0.332044,0.458048, --0.455297,-0.038026,0.889527,0.000000,-0.455297,-0.038026,0.889527,0.345280,0.714912, --0.286151,-0.092976,0.953663,0.000000,-0.286151,-0.092976,0.953663,0.500000,0.288582, --0.390694,-0.236853,0.889527,0.000000,-0.390694,-0.236853,0.889527,0.332044,0.784331, --0.212032,-0.291836,0.932670,0.000000,-0.212032,-0.291836,0.932670,0.500000,0.220572, --0.286151,-0.092976,0.953663,0.000000,-0.286151,-0.092976,0.953663,0.500000,0.288582, --0.639949,0.207932,0.739749,0.000000,-0.639949,0.207932,0.739749,0.672996,0.649190, --0.632156,0.019439,0.774597,0.000000,-0.632156,0.019439,0.774597,0.750000,0.327581, --0.500000,0.162460,0.850651,0.000000,-0.500000,0.162460,0.850651,0.790230,0.268343, --0.632156,0.019439,0.774597,0.000000,-0.632156,0.019439,0.774597,0.750000,0.327581, --0.577350,-0.187592,0.794654,0.000000,-0.577350,-0.187592,0.794654,0.761425,0.258102, --0.455297,-0.038026,0.889527,0.000000,-0.455297,-0.038026,0.889527,0.345280,0.714912, --0.577350,-0.187592,0.794654,0.000000,-0.577350,-0.187592,0.794654,0.761425,0.258102, --0.499999,-0.387298,0.774597,0.000000,-0.499999,-0.387298,0.774597,0.671537,0.332044, --0.390694,-0.236853,0.889527,0.000000,-0.390694,-0.236853,0.889527,0.332044,0.784331, --0.499999,-0.387298,0.774597,0.000000,-0.499999,-0.387298,0.774597,0.671537,0.332044, --0.395511,-0.544373,0.739749,0.000000,-0.395511,-0.544373,0.739749,0.672996,0.258102, --0.309017,-0.425325,0.850651,0.000000,-0.309017,-0.425325,0.850651,0.819975,0.332044, --0.500000,0.162460,0.850651,0.000000,-0.500000,0.162460,0.850651,0.790230,0.268343, --0.632156,0.019439,0.774597,0.000000,-0.632156,0.019439,0.774597,0.750000,0.327581, --0.455297,-0.038026,0.889527,0.000000,-0.455297,-0.038026,0.889527,0.345280,0.714912, --0.577350,-0.187592,0.794654,0.000000,-0.577350,-0.187592,0.794654,0.761425,0.258102, --0.390694,-0.236853,0.889527,0.000000,-0.390694,-0.236853,0.889527,0.332044,0.784331, --0.455297,-0.038026,0.889527,0.000000,-0.455297,-0.038026,0.889527,0.345280,0.714912, --0.499999,-0.387298,0.774597,0.000000,-0.499999,-0.387298,0.774597,0.671537,0.332044, --0.309017,-0.425325,0.850651,0.000000,-0.309017,-0.425325,0.850651,0.819975,0.332044, --0.390694,-0.236853,0.889527,0.000000,-0.390694,-0.236853,0.889527,0.332044,0.784331, --0.758172,0.246345,0.603730,0.000000,-0.758172,0.246345,0.603730,0.588430,0.803612, --0.762354,0.061752,0.644208,0.000000,-0.762354,0.061752,0.644208,0.587250,0.345280, --0.639949,0.207932,0.739749,0.000000,-0.639949,0.207932,0.739749,0.672996,0.649190, --0.762354,0.061752,0.644208,0.000000,-0.762354,0.061752,0.644208,0.587250,0.345280, --0.736686,-0.124433,0.664689,0.000000,-0.736686,-0.124433,0.664689,0.500000,0.366840, --0.632156,0.019439,0.774597,0.000000,-0.632156,0.019439,0.774597,0.750000,0.327581, --0.736686,-0.124433,0.664689,0.000000,-0.736686,-0.124433,0.664689,0.500000,0.366840, --0.669131,-0.332344,0.664689,0.000000,-0.669131,-0.332344,0.664689,0.258102,0.766840, --0.577350,-0.187592,0.794654,0.000000,-0.577350,-0.187592,0.794654,0.761425,0.258102, --0.669131,-0.332344,0.664689,0.000000,-0.669131,-0.332344,0.664689,0.258102,0.766840, --0.580461,-0.498058,0.644208,0.000000,-0.580461,-0.498058,0.644208,0.412750,0.528349, --0.499999,-0.387298,0.774597,0.000000,-0.499999,-0.387298,0.774597,0.671537,0.332044, --0.580461,-0.498058,0.644208,0.000000,-0.580461,-0.498058,0.644208,0.412750,0.528349, --0.468576,-0.644939,0.603730,0.000000,-0.468576,-0.644939,0.603730,0.411574,0.621707, --0.395511,-0.544373,0.739749,0.000000,-0.395511,-0.544373,0.739749,0.672996,0.258102, --0.639949,0.207932,0.739749,0.000000,-0.639949,0.207932,0.739749,0.672996,0.649190, --0.762354,0.061752,0.644208,0.000000,-0.762354,0.061752,0.644208,0.587250,0.345280, --0.632156,0.019439,0.774597,0.000000,-0.632156,0.019439,0.774597,0.750000,0.327581, --0.632156,0.019439,0.774597,0.000000,-0.632156,0.019439,0.774597,0.750000,0.327581, --0.736686,-0.124433,0.664689,0.000000,-0.736686,-0.124433,0.664689,0.500000,0.366840, --0.577350,-0.187592,0.794654,0.000000,-0.577350,-0.187592,0.794654,0.761425,0.258102, --0.669131,-0.332344,0.664689,0.000000,-0.669131,-0.332344,0.664689,0.258102,0.766840, --0.499999,-0.387298,0.774597,0.000000,-0.499999,-0.387298,0.774597,0.671537,0.332044, --0.577350,-0.187592,0.794654,0.000000,-0.577350,-0.187592,0.794654,0.761425,0.258102, --0.580461,-0.498058,0.644208,0.000000,-0.580461,-0.498058,0.644208,0.412750,0.528349, --0.395511,-0.544373,0.739749,0.000000,-0.395511,-0.544373,0.739749,0.672996,0.258102, --0.499999,-0.387298,0.774597,0.000000,-0.499999,-0.387298,0.774597,0.671537,0.332044, --0.850651,0.276393,0.447214,0.000000,-0.850651,0.276393,0.447214,0.588426,0.872062, --0.866018,0.097907,0.490334,0.000000,-0.866018,0.097907,0.490334,0.328463,0.555736, --0.758172,0.246345,0.603730,0.000000,-0.758172,0.246345,0.603730,0.588430,0.803612, --0.866018,0.097907,0.490334,0.000000,-0.866018,0.097907,0.490334,0.328463,0.555736, --0.851981,-0.083904,0.516806,0.000000,-0.851981,-0.083904,0.516806,0.411570,0.710631, --0.762354,0.061752,0.644208,0.000000,-0.762354,0.061752,0.644208,0.587250,0.345280, --0.851981,-0.083904,0.516806,0.000000,-0.851981,-0.083904,0.516806,0.411570,0.710631, --0.809017,-0.262865,0.525731,0.000000,-0.809017,-0.262865,0.525731,0.327004,0.649190, --0.736686,-0.124433,0.664689,0.000000,-0.736686,-0.124433,0.664689,0.500000,0.366840, --0.809017,-0.262865,0.525731,0.000000,-0.809017,-0.262865,0.525731,0.327004,0.649190, --0.738585,-0.432902,0.516806,0.000000,-0.738585,-0.432902,0.516806,0.250000,0.581230, --0.669131,-0.332344,0.664689,0.000000,-0.669131,-0.332344,0.664689,0.258102,0.766840, --0.738585,-0.432902,0.516806,0.000000,-0.738585,-0.432902,0.516806,0.250000,0.581230, --0.643075,-0.588241,0.490334,0.000000,-0.643075,-0.588241,0.490334,0.411570,0.803612, --0.580461,-0.498058,0.644208,0.000000,-0.580461,-0.498058,0.644208,0.412750,0.528349, --0.643075,-0.588241,0.490334,0.000000,-0.643075,-0.588241,0.490334,0.411570,0.803612, --0.525731,-0.723607,0.447214,0.000000,-0.525731,-0.723607,0.447214,0.321589,0.745561, --0.468576,-0.644939,0.603730,0.000000,-0.468576,-0.644939,0.603730,0.411574,0.621707, --0.758172,0.246345,0.603730,0.000000,-0.758172,0.246345,0.603730,0.588430,0.803612, --0.866018,0.097907,0.490334,0.000000,-0.866018,0.097907,0.490334,0.328463,0.555736, --0.762354,0.061752,0.644208,0.000000,-0.762354,0.061752,0.644208,0.587250,0.345280, --0.762354,0.061752,0.644208,0.000000,-0.762354,0.061752,0.644208,0.587250,0.345280, --0.851981,-0.083904,0.516806,0.000000,-0.851981,-0.083904,0.516806,0.411570,0.710631, --0.736686,-0.124433,0.664689,0.000000,-0.736686,-0.124433,0.664689,0.500000,0.366840, --0.809017,-0.262865,0.525731,0.000000,-0.809017,-0.262865,0.525731,0.327004,0.649190, --0.669131,-0.332344,0.664689,0.000000,-0.669131,-0.332344,0.664689,0.258102,0.766840, --0.736686,-0.124433,0.664689,0.000000,-0.736686,-0.124433,0.664689,0.500000,0.366840, --0.738585,-0.432902,0.516806,0.000000,-0.738585,-0.432902,0.516806,0.250000,0.581230, --0.580461,-0.498058,0.644208,0.000000,-0.580461,-0.498058,0.644208,0.412750,0.528349, --0.669131,-0.332344,0.664689,0.000000,-0.669131,-0.332344,0.664689,0.258102,0.766840, --0.643075,-0.588241,0.490334,0.000000,-0.643075,-0.588241,0.490334,0.411570,0.803612, --0.468576,-0.644939,0.603730,0.000000,-0.468576,-0.644939,0.603730,0.411574,0.621707, --0.580461,-0.498058,0.644208,0.000000,-0.580461,-0.498058,0.644208,0.412750,0.528349, --0.107846,-0.148438,0.983024,0.000000,-0.107846,-0.148438,0.983024,0.588426,0.268343, -0.107846,-0.148438,0.983024,0.000000,0.107846,-0.148438,0.983024,0.209770,0.912551, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.411570,0.289369, --0.212032,-0.291836,0.932670,0.000000,-0.212032,-0.291836,0.932670,0.500000,0.220572, --0.000000,-0.300877,0.953663,0.000000,-0.000000,-0.300877,0.953663,0.238575,0.677923, --0.107846,-0.148438,0.983024,0.000000,-0.107846,-0.148438,0.983024,0.588426,0.268343, --0.000000,-0.300877,0.953663,0.000000,-0.000000,-0.300877,0.953663,0.238575,0.677923, -0.212032,-0.291836,0.932670,0.000000,0.212032,-0.291836,0.932670,0.327004,0.350810, -0.107846,-0.148438,0.983024,0.000000,0.107846,-0.148438,0.983024,0.209770,0.912551, --0.000000,-0.300877,0.953663,0.000000,-0.000000,-0.300877,0.953663,0.238575,0.677923, -0.107846,-0.148438,0.983024,0.000000,0.107846,-0.148438,0.983024,0.209770,0.912551, --0.107846,-0.148438,0.983024,0.000000,-0.107846,-0.148438,0.983024,0.588426,0.268343, --0.309017,-0.425325,0.850651,0.000000,-0.309017,-0.425325,0.850651,0.819975,0.332044, --0.104529,-0.444764,0.889527,0.000000,-0.104529,-0.444764,0.889527,0.180025,0.603966, --0.212032,-0.291836,0.932670,0.000000,-0.212032,-0.291836,0.932670,0.500000,0.220572, --0.104529,-0.444764,0.889527,0.000000,-0.104529,-0.444764,0.889527,0.180025,0.603966, -0.104529,-0.444764,0.889527,0.000000,0.104529,-0.444764,0.889527,0.411574,0.268343, --0.000000,-0.300877,0.953663,0.000000,-0.000000,-0.300877,0.953663,0.238575,0.677923, -0.104529,-0.444764,0.889527,0.000000,0.104529,-0.444764,0.889527,0.411574,0.268343, -0.309017,-0.425325,0.850651,0.000000,0.309017,-0.425325,0.850651,0.238575,0.322077, -0.212032,-0.291836,0.932670,0.000000,0.212032,-0.291836,0.932670,0.327004,0.350810, --0.212032,-0.291836,0.932670,0.000000,-0.212032,-0.291836,0.932670,0.500000,0.220572, --0.104529,-0.444764,0.889527,0.000000,-0.104529,-0.444764,0.889527,0.180025,0.603966, --0.000000,-0.300877,0.953663,0.000000,-0.000000,-0.300877,0.953663,0.238575,0.677923, -0.104529,-0.444764,0.889527,0.000000,0.104529,-0.444764,0.889527,0.411574,0.268343, -0.212032,-0.291836,0.932670,0.000000,0.212032,-0.291836,0.932670,0.327004,0.350810, --0.000000,-0.300877,0.953663,0.000000,-0.000000,-0.300877,0.953663,0.238575,0.677923, --0.395511,-0.544373,0.739749,0.000000,-0.395511,-0.544373,0.739749,0.672996,0.258102, --0.213835,-0.595209,0.774597,0.000000,-0.213835,-0.595209,0.774597,0.411574,0.872062, --0.309017,-0.425325,0.850651,0.000000,-0.309017,-0.425325,0.850651,0.819975,0.332044, --0.213835,-0.595209,0.774597,0.000000,-0.213835,-0.595209,0.774597,0.411574,0.872062, --0.000000,-0.607062,0.794655,0.000000,-0.000000,-0.607062,0.794655,0.327004,0.831089, --0.104529,-0.444764,0.889527,0.000000,-0.104529,-0.444764,0.889527,0.180025,0.603966, --0.000000,-0.607062,0.794655,0.000000,-0.000000,-0.607062,0.794655,0.327004,0.831089, -0.213834,-0.595209,0.774597,0.000000,0.213834,-0.595209,0.774597,0.238575,0.766841, -0.104529,-0.444764,0.889527,0.000000,0.104529,-0.444764,0.889527,0.411574,0.268343, -0.213834,-0.595209,0.774597,0.000000,0.213834,-0.595209,0.774597,0.238575,0.766841, -0.395510,-0.544373,0.739749,0.000000,0.395510,-0.544373,0.739749,0.238575,0.233160, -0.309017,-0.425325,0.850651,0.000000,0.309017,-0.425325,0.850651,0.238575,0.322077, --0.309017,-0.425325,0.850651,0.000000,-0.309017,-0.425325,0.850651,0.819975,0.332044, --0.213835,-0.595209,0.774597,0.000000,-0.213835,-0.595209,0.774597,0.411574,0.872062, --0.104529,-0.444764,0.889527,0.000000,-0.104529,-0.444764,0.889527,0.180025,0.603966, --0.000000,-0.607062,0.794655,0.000000,-0.000000,-0.607062,0.794655,0.327004,0.831089, -0.104529,-0.444764,0.889527,0.000000,0.104529,-0.444764,0.889527,0.411574,0.268343, --0.104529,-0.444764,0.889527,0.000000,-0.104529,-0.444764,0.889527,0.180025,0.603966, -0.213834,-0.595209,0.774597,0.000000,0.213834,-0.595209,0.774597,0.238575,0.766841, -0.309017,-0.425325,0.850651,0.000000,0.309017,-0.425325,0.850651,0.238575,0.322077, -0.104529,-0.444764,0.889527,0.000000,0.104529,-0.444764,0.889527,0.411574,0.268343, --0.468576,-0.644939,0.603730,0.000000,-0.468576,-0.644939,0.603730,0.411574,0.621707, --0.294310,-0.705959,0.644208,0.000000,-0.294310,-0.705959,0.644208,0.173473,0.699071, --0.395511,-0.544373,0.739749,0.000000,-0.395511,-0.544373,0.739749,0.672996,0.258102, --0.294310,-0.705959,0.644208,0.000000,-0.294310,-0.705959,0.644208,0.173473,0.699071, --0.109305,-0.739082,0.664689,0.000000,-0.109305,-0.739082,0.664689,0.412750,0.345280, --0.213835,-0.595209,0.774597,0.000000,-0.213835,-0.595209,0.774597,0.411574,0.872062, --0.109305,-0.739082,0.664689,0.000000,-0.109305,-0.739082,0.664689,0.412750,0.345280, -0.109305,-0.739082,0.664689,0.000000,0.109305,-0.739082,0.664689,0.328463,0.332044, --0.000000,-0.607062,0.794655,0.000000,-0.000000,-0.607062,0.794655,0.327004,0.831089, -0.109305,-0.739082,0.664689,0.000000,0.109305,-0.739082,0.664689,0.328463,0.332044, -0.294309,-0.705959,0.644208,0.000000,0.294309,-0.705959,0.644208,0.250000,0.327581, -0.213834,-0.595209,0.774597,0.000000,0.213834,-0.595209,0.774597,0.238575,0.766841, -0.294309,-0.705959,0.644208,0.000000,0.294309,-0.705959,0.644208,0.250000,0.327581, -0.468576,-0.644939,0.603730,0.000000,0.468576,-0.644939,0.603730,0.327004,0.922791, -0.395510,-0.544373,0.739749,0.000000,0.395510,-0.544373,0.739749,0.238575,0.233160, --0.395511,-0.544373,0.739749,0.000000,-0.395511,-0.544373,0.739749,0.672996,0.258102, --0.294310,-0.705959,0.644208,0.000000,-0.294310,-0.705959,0.644208,0.173473,0.699071, --0.213835,-0.595209,0.774597,0.000000,-0.213835,-0.595209,0.774597,0.411574,0.872062, --0.213835,-0.595209,0.774597,0.000000,-0.213835,-0.595209,0.774597,0.411574,0.872062, --0.109305,-0.739082,0.664689,0.000000,-0.109305,-0.739082,0.664689,0.412750,0.345280, --0.000000,-0.607062,0.794655,0.000000,-0.000000,-0.607062,0.794655,0.327004,0.831089, -0.109305,-0.739082,0.664689,0.000000,0.109305,-0.739082,0.664689,0.328463,0.332044, -0.213834,-0.595209,0.774597,0.000000,0.213834,-0.595209,0.774597,0.238575,0.766841, --0.000000,-0.607062,0.794655,0.000000,-0.000000,-0.607062,0.794655,0.327004,0.831089, -0.294309,-0.705959,0.644208,0.000000,0.294309,-0.705959,0.644208,0.250000,0.327581, -0.395510,-0.544373,0.739749,0.000000,0.395510,-0.544373,0.739749,0.238575,0.233160, -0.213834,-0.595209,0.774597,0.000000,0.213834,-0.595209,0.774597,0.238575,0.766841, --0.525731,-0.723607,0.447214,0.000000,-0.525731,-0.723607,0.447214,0.321589,0.745561, --0.360730,-0.793377,0.490334,0.000000,-0.360730,-0.793377,0.490334,0.327004,0.258102, --0.468576,-0.644939,0.603730,0.000000,-0.468576,-0.644939,0.603730,0.411574,0.621707, --0.360730,-0.793377,0.490334,0.000000,-0.360730,-0.793377,0.490334,0.327004,0.258102, --0.183479,-0.836210,0.516806,0.000000,-0.183479,-0.836210,0.516806,0.180025,0.332044, --0.294310,-0.705959,0.644208,0.000000,-0.294310,-0.705959,0.644208,0.173473,0.699071, --0.183479,-0.836210,0.516806,0.000000,-0.183479,-0.836210,0.516806,0.180025,0.332044, --0.000000,-0.850651,0.525731,0.000000,-0.000000,-0.850651,0.525731,0.238575,0.258102, --0.109305,-0.739082,0.664689,0.000000,-0.109305,-0.739082,0.664689,0.412750,0.345280, --0.000000,-0.850651,0.525731,0.000000,-0.000000,-0.850651,0.525731,0.238575,0.258102, -0.183479,-0.836210,0.516806,0.000000,0.183479,-0.836210,0.516806,0.258102,0.766841, -0.109305,-0.739082,0.664689,0.000000,0.109305,-0.739082,0.664689,0.328463,0.332044, -0.183479,-0.836210,0.516806,0.000000,0.183479,-0.836210,0.516806,0.258102,0.766841, -0.360730,-0.793377,0.490334,0.000000,0.360730,-0.793377,0.490334,0.446077,0.425781, -0.294309,-0.705959,0.644208,0.000000,0.294309,-0.705959,0.644208,0.250000,0.327581, -0.360730,-0.793377,0.490334,0.000000,0.360730,-0.793377,0.490334,0.446077,0.425781, -0.525731,-0.723607,0.447214,0.000000,0.525731,-0.723607,0.447214,0.606016,0.354082, -0.468576,-0.644939,0.603730,0.000000,0.468576,-0.644939,0.603730,0.327004,0.922791, --0.468576,-0.644939,0.603730,0.000000,-0.468576,-0.644939,0.603730,0.411574,0.621707, --0.360730,-0.793377,0.490334,0.000000,-0.360730,-0.793377,0.490334,0.327004,0.258102, --0.294310,-0.705959,0.644208,0.000000,-0.294310,-0.705959,0.644208,0.173473,0.699071, --0.294310,-0.705959,0.644208,0.000000,-0.294310,-0.705959,0.644208,0.173473,0.699071, --0.183479,-0.836210,0.516806,0.000000,-0.183479,-0.836210,0.516806,0.180025,0.332044, --0.109305,-0.739082,0.664689,0.000000,-0.109305,-0.739082,0.664689,0.412750,0.345280, --0.109305,-0.739082,0.664689,0.000000,-0.109305,-0.739082,0.664689,0.412750,0.345280, --0.000000,-0.850651,0.525731,0.000000,-0.000000,-0.850651,0.525731,0.238575,0.258102, -0.109305,-0.739082,0.664689,0.000000,0.109305,-0.739082,0.664689,0.328463,0.332044, -0.183479,-0.836210,0.516806,0.000000,0.183479,-0.836210,0.516806,0.258102,0.766841, -0.294309,-0.705959,0.644208,0.000000,0.294309,-0.705959,0.644208,0.250000,0.327581, -0.109305,-0.739082,0.664689,0.000000,0.109305,-0.739082,0.664689,0.328463,0.332044, -0.360730,-0.793377,0.490334,0.000000,0.360730,-0.793377,0.490334,0.446077,0.425781, -0.468576,-0.644939,0.603730,0.000000,0.468576,-0.644939,0.603730,0.327004,0.922791, -0.294309,-0.705959,0.644208,0.000000,0.294309,-0.705959,0.644208,0.250000,0.327581, -0.000000,-0.894427,-0.447214,0.000000,0.000000,-0.894427,-0.447214,0.848850,0.215669, -0.174499,-0.853887,-0.490334,0.000000,0.174499,-0.853887,-0.490334,0.814054,0.361804, -0.107846,-0.945626,-0.306855,0.000000,0.107846,-0.945626,-0.306855,0.356925,0.453512, -0.174499,-0.853887,-0.490334,0.000000,0.174499,-0.853887,-0.490334,0.814054,0.361804, -0.343074,-0.784354,-0.516806,0.000000,0.343074,-0.784354,-0.516806,0.835614,0.285088, -0.286151,-0.894562,-0.343331,0.000000,0.286151,-0.894562,-0.343331,0.393984,0.354082, -0.107846,-0.945626,-0.306855,0.000000,0.107846,-0.945626,-0.306855,0.356925,0.453512, -0.286151,-0.894562,-0.343331,0.000000,0.286151,-0.894562,-0.343331,0.393984,0.354082, -0.212032,-0.964719,-0.156077,0.000000,0.212032,-0.964719,-0.156077,0.272352,0.480987, -0.174499,-0.853887,-0.490334,0.000000,0.174499,-0.853887,-0.490334,0.814054,0.361804, -0.286151,-0.894562,-0.343331,0.000000,0.286151,-0.894562,-0.343331,0.393984,0.354082, -0.107846,-0.945626,-0.306855,0.000000,0.107846,-0.945626,-0.306855,0.356925,0.453512, -0.343074,-0.784354,-0.516806,0.000000,0.343074,-0.784354,-0.516806,0.835614,0.285088, -0.500000,-0.688191,-0.525731,0.000000,0.500000,-0.688191,-0.525731,0.500000,0.892312, -0.455297,-0.812623,-0.363797,0.000000,0.455297,-0.812623,-0.363797,0.304653,0.381573, -0.286151,-0.894562,-0.343331,0.000000,0.286151,-0.894562,-0.343331,0.393984,0.354082, -0.455297,-0.812623,-0.363797,0.000000,0.455297,-0.812623,-0.363797,0.304653,0.381573, -0.390694,-0.901541,-0.185961,0.000000,0.390694,-0.901541,-0.185961,0.345491,0.287337, -0.212032,-0.964719,-0.156077,0.000000,0.212032,-0.964719,-0.156077,0.272352,0.480987, -0.390694,-0.901541,-0.185961,0.000000,0.390694,-0.901541,-0.185961,0.345491,0.287337, -0.309017,-0.951057,0.000000,0.000000,0.309017,-0.951057,0.000000,0.183922,0.509719, -0.343074,-0.784354,-0.516806,0.000000,0.343074,-0.784354,-0.516806,0.835614,0.285088, -0.455297,-0.812623,-0.363797,0.000000,0.455297,-0.812623,-0.363797,0.304653,0.381573, -0.286151,-0.894562,-0.343331,0.000000,0.286151,-0.894562,-0.343331,0.393984,0.354082, -0.286151,-0.894562,-0.343331,0.000000,0.286151,-0.894562,-0.343331,0.393984,0.354082, -0.390694,-0.901541,-0.185961,0.000000,0.390694,-0.901541,-0.185961,0.345491,0.287337, -0.212032,-0.964719,-0.156077,0.000000,0.212032,-0.964719,-0.156077,0.272352,0.480987, -0.500000,-0.688191,-0.525731,0.000000,0.500000,-0.688191,-0.525731,0.500000,0.892312, -0.639949,-0.568662,-0.516806,0.000000,0.639949,-0.568662,-0.516806,0.588426,0.912551, -0.632156,-0.684127,-0.363797,0.000000,0.632156,-0.684127,-0.363797,0.211325,0.406204, -0.455297,-0.812623,-0.363797,0.000000,0.455297,-0.812623,-0.363797,0.304653,0.381573, -0.632156,-0.684127,-0.363797,0.000000,0.632156,-0.684127,-0.363797,0.211325,0.406204, -0.577350,-0.794654,-0.187593,0.000000,0.577350,-0.794654,-0.187593,0.250001,0.306351, -0.390694,-0.901541,-0.185961,0.000000,0.390694,-0.901541,-0.185961,0.345491,0.287337, -0.577350,-0.794654,-0.187593,0.000000,0.577350,-0.794654,-0.187593,0.250001,0.306351, -0.499999,-0.866026,0.000000,0.000000,0.499999,-0.866026,0.000000,0.302244,0.227814, -0.309017,-0.951057,0.000000,0.000000,0.309017,-0.951057,0.000000,0.183922,0.509719, -0.499999,-0.866026,0.000000,0.000000,0.499999,-0.866026,0.000000,0.302244,0.227814, -0.395510,-0.905103,0.156077,0.000000,0.395510,-0.905103,0.156077,0.131657,0.437784, -0.455297,-0.812623,-0.363797,0.000000,0.455297,-0.812623,-0.363797,0.304653,0.381573, -0.500000,-0.688191,-0.525731,0.000000,0.500000,-0.688191,-0.525731,0.500000,0.892312, -0.632156,-0.684127,-0.363797,0.000000,0.632156,-0.684127,-0.363797,0.211325,0.406204, -0.455297,-0.812623,-0.363797,0.000000,0.455297,-0.812623,-0.363797,0.304653,0.381573, -0.577350,-0.794654,-0.187593,0.000000,0.577350,-0.794654,-0.187593,0.250001,0.306351, -0.390694,-0.901541,-0.185961,0.000000,0.390694,-0.901541,-0.185961,0.345491,0.287337, -0.309017,-0.951057,0.000000,0.000000,0.309017,-0.951057,0.000000,0.183922,0.509719, -0.390694,-0.901541,-0.185961,0.000000,0.390694,-0.901541,-0.185961,0.345491,0.287337, -0.499999,-0.866026,0.000000,0.000000,0.499999,-0.866026,0.000000,0.302244,0.227814, -0.639949,-0.568662,-0.516806,0.000000,0.639949,-0.568662,-0.516806,0.588426,0.912551, -0.758172,-0.429824,-0.490334,0.000000,0.758172,-0.429824,-0.490334,0.588426,0.127938, -0.762354,-0.548581,-0.343331,0.000000,0.762354,-0.548581,-0.343331,0.165435,0.333828, -0.632156,-0.684127,-0.363797,0.000000,0.632156,-0.684127,-0.363797,0.211325,0.406204, -0.762354,-0.548581,-0.343331,0.000000,0.762354,-0.548581,-0.343331,0.165435,0.333828, -0.736686,-0.650164,-0.185961,0.000000,0.736686,-0.650164,-0.185961,0.209769,0.250971, -0.577350,-0.794654,-0.187593,0.000000,0.577350,-0.794654,-0.187593,0.250001,0.306351, -0.736686,-0.650164,-0.185961,0.000000,0.736686,-0.650164,-0.185961,0.209769,0.250971, -0.669131,-0.743144,0.000000,0.000000,0.669131,-0.743144,0.000000,0.265712,0.177530, -0.499999,-0.866026,0.000000,0.000000,0.499999,-0.866026,0.000000,0.302244,0.227814, -0.669131,-0.743144,0.000000,0.000000,0.669131,-0.743144,0.000000,0.265712,0.177530, -0.580460,-0.798935,0.157379,0.000000,0.580460,-0.798935,0.157379,0.118823,0.530876, -0.395510,-0.905103,0.156077,0.000000,0.395510,-0.905103,0.156077,0.131657,0.437784, -0.580460,-0.798935,0.157379,0.000000,0.580460,-0.798935,0.157379,0.118823,0.530876, -0.468576,-0.828418,0.306855,0.000000,0.468576,-0.828418,0.306855,0.178463,0.345280, -0.632156,-0.684127,-0.363797,0.000000,0.632156,-0.684127,-0.363797,0.211325,0.406204, -0.639949,-0.568662,-0.516806,0.000000,0.639949,-0.568662,-0.516806,0.588426,0.912551, -0.762354,-0.548581,-0.343331,0.000000,0.762354,-0.548581,-0.343331,0.165435,0.333828, -0.577350,-0.794654,-0.187593,0.000000,0.577350,-0.794654,-0.187593,0.250001,0.306351, -0.632156,-0.684127,-0.363797,0.000000,0.632156,-0.684127,-0.363797,0.211325,0.406204, -0.736686,-0.650164,-0.185961,0.000000,0.736686,-0.650164,-0.185961,0.209769,0.250971, -0.499999,-0.866026,0.000000,0.000000,0.499999,-0.866026,0.000000,0.302244,0.227814, -0.577350,-0.794654,-0.187593,0.000000,0.577350,-0.794654,-0.187593,0.250001,0.306351, -0.669131,-0.743144,0.000000,0.000000,0.669131,-0.743144,0.000000,0.265712,0.177530, -0.395510,-0.905103,0.156077,0.000000,0.395510,-0.905103,0.156077,0.131657,0.437784, -0.499999,-0.866026,0.000000,0.000000,0.499999,-0.866026,0.000000,0.302244,0.227814, -0.580460,-0.798935,0.157379,0.000000,0.580460,-0.798935,0.157379,0.118823,0.530876, -0.758172,-0.429824,-0.490334,0.000000,0.758172,-0.429824,-0.490334,0.588426,0.127938, -0.850651,-0.276393,-0.447214,0.000000,0.850651,-0.276393,-0.447214,0.500000,0.960321, -0.866018,-0.394782,-0.306855,0.000000,0.866018,-0.394782,-0.306855,0.237134,0.366840, -0.762354,-0.548581,-0.343331,0.000000,0.762354,-0.548581,-0.343331,0.165435,0.333828, -0.866018,-0.394782,-0.306855,0.000000,0.866018,-0.394782,-0.306855,0.237134,0.366840, -0.851981,-0.499769,-0.156077,0.000000,0.851981,-0.499769,-0.156077,0.265712,0.288582, -0.736686,-0.650164,-0.185961,0.000000,0.736686,-0.650164,-0.185961,0.209769,0.250971, -0.851981,-0.499769,-0.156077,0.000000,0.851981,-0.499769,-0.156077,0.265712,0.288582, -0.809017,-0.587785,0.000000,0.000000,0.809017,-0.587785,0.000000,0.209769,0.268343, -0.669131,-0.743144,0.000000,0.000000,0.669131,-0.743144,0.000000,0.265712,0.177530, -0.809017,-0.587785,0.000000,0.000000,0.809017,-0.587785,0.000000,0.209769,0.268343, -0.738585,-0.655845,0.156077,0.000000,0.738585,-0.655845,0.156077,0.500000,0.349562, -0.580460,-0.798935,0.157379,0.000000,0.580460,-0.798935,0.157379,0.118823,0.530876, -0.738585,-0.655845,0.156077,0.000000,0.738585,-0.655845,0.156077,0.500000,0.349562, -0.643075,-0.701637,0.306855,0.000000,0.643075,-0.701637,0.306855,0.447735,0.277618, -0.468576,-0.828418,0.306855,0.000000,0.468576,-0.828418,0.306855,0.178463,0.345280, -0.643075,-0.701637,0.306855,0.000000,0.643075,-0.701637,0.306855,0.447735,0.277618, -0.525731,-0.723607,0.447214,0.000000,0.525731,-0.723607,0.447214,0.606016,0.354082, -0.762354,-0.548581,-0.343331,0.000000,0.762354,-0.548581,-0.343331,0.165435,0.333828, -0.758172,-0.429824,-0.490334,0.000000,0.758172,-0.429824,-0.490334,0.588426,0.127938, -0.866018,-0.394782,-0.306855,0.000000,0.866018,-0.394782,-0.306855,0.237134,0.366840, -0.736686,-0.650164,-0.185961,0.000000,0.736686,-0.650164,-0.185961,0.209769,0.250971, -0.762354,-0.548581,-0.343331,0.000000,0.762354,-0.548581,-0.343331,0.165435,0.333828, -0.851981,-0.499769,-0.156077,0.000000,0.851981,-0.499769,-0.156077,0.265712,0.288582, -0.669131,-0.743144,0.000000,0.000000,0.669131,-0.743144,0.000000,0.265712,0.177530, -0.736686,-0.650164,-0.185961,0.000000,0.736686,-0.650164,-0.185961,0.209769,0.250971, -0.809017,-0.587785,0.000000,0.000000,0.809017,-0.587785,0.000000,0.209769,0.268343, -0.669131,-0.743144,0.000000,0.000000,0.669131,-0.743144,0.000000,0.265712,0.177530, -0.738585,-0.655845,0.156077,0.000000,0.738585,-0.655845,0.156077,0.500000,0.349562, -0.580460,-0.798935,0.157379,0.000000,0.580460,-0.798935,0.157379,0.118823,0.530876, -0.468576,-0.828418,0.306855,0.000000,0.468576,-0.828418,0.306855,0.178463,0.345280, -0.580460,-0.798935,0.157379,0.000000,0.580460,-0.798935,0.157379,0.118823,0.530876, -0.643075,-0.701637,0.306855,0.000000,0.643075,-0.701637,0.306855,0.447735,0.277618, -0.850651,-0.276393,-0.447214,0.000000,0.850651,-0.276393,-0.447214,0.500000,0.960321, -0.866018,-0.097907,-0.490334,0.000000,0.866018,-0.097907,-0.490334,0.834566,0.666172, -0.932670,-0.189647,-0.306855,0.000000,0.932670,-0.189647,-0.306855,0.552265,0.277618, -0.866018,-0.097907,-0.490334,0.000000,0.866018,-0.097907,-0.490334,0.834566,0.666172, -0.851981,0.083904,-0.516806,0.000000,0.851981,0.083904,-0.516806,0.734288,0.822469, -0.939205,-0.004289,-0.343331,0.000000,0.939205,-0.004289,-0.343331,0.393082,0.202395, -0.932670,-0.189647,-0.306855,0.000000,0.932670,-0.189647,-0.306855,0.552265,0.277618, -0.939205,-0.004289,-0.343331,0.000000,0.939205,-0.004289,-0.343331,0.393082,0.202395, -0.983024,-0.096461,-0.156077,0.000000,0.983024,-0.096461,-0.156077,0.500000,0.196469, -0.866018,-0.097907,-0.490334,0.000000,0.866018,-0.097907,-0.490334,0.834566,0.666172, -0.939205,-0.004289,-0.343331,0.000000,0.939205,-0.004289,-0.343331,0.393082,0.202395, -0.932670,-0.189647,-0.306855,0.000000,0.932670,-0.189647,-0.306855,0.552265,0.277618, -0.851981,0.083904,-0.516806,0.000000,0.851981,0.083904,-0.516806,0.734288,0.822469, -0.809017,0.262865,-0.525731,0.000000,0.809017,0.262865,-0.525731,0.790230,0.749029, -0.913545,0.181898,-0.363797,0.000000,0.913545,0.181898,-0.363797,0.606917,0.202395, -0.939205,-0.004289,-0.343331,0.000000,0.939205,-0.004289,-0.343331,0.393082,0.202395, -0.913545,0.181898,-0.363797,0.000000,0.913545,0.181898,-0.363797,0.606917,0.202395, -0.978148,0.092981,-0.185961,0.000000,0.978148,0.092981,-0.185961,0.352845,0.147020, -0.983024,-0.096461,-0.156077,0.000000,0.983024,-0.096461,-0.156077,0.500000,0.196469, -0.978148,0.092981,-0.185961,0.000000,0.978148,0.092981,-0.185961,0.352845,0.147020, -1.000000,-0.000000,0.000000,0.000000,1.000000,-0.000000,0.000000,0.445347,0.130459, -0.851981,0.083904,-0.516806,0.000000,0.851981,0.083904,-0.516806,0.734288,0.822469, -0.913545,0.181898,-0.363797,0.000000,0.913545,0.181898,-0.363797,0.606917,0.202395, -0.939205,-0.004289,-0.343331,0.000000,0.939205,-0.004289,-0.343331,0.393082,0.202395, -0.939205,-0.004289,-0.343331,0.000000,0.939205,-0.004289,-0.343331,0.393082,0.202395, -0.978148,0.092981,-0.185961,0.000000,0.978148,0.092981,-0.185961,0.352845,0.147020, -0.983024,-0.096461,-0.156077,0.000000,0.983024,-0.096461,-0.156077,0.500000,0.196469, -0.809017,0.262865,-0.525731,0.000000,0.809017,0.262865,-0.525731,0.790230,0.749029, -0.738585,0.432902,-0.516806,0.000000,0.738585,0.432902,-0.516806,0.816078,0.490281, -0.845991,0.389809,-0.363797,0.000000,0.845991,0.389809,-0.363797,0.554653,0.130459, -0.913545,0.181898,-0.363797,0.000000,0.913545,0.181898,-0.363797,0.606917,0.202395, -0.845991,0.389809,-0.363797,0.000000,0.845991,0.389809,-0.363797,0.554653,0.130459, -0.934172,0.303531,-0.187593,0.000000,0.934172,0.303531,-0.187593,0.647155,0.147020, -0.978148,0.092981,-0.185961,0.000000,0.978148,0.092981,-0.185961,0.352845,0.147020, -0.934172,0.303531,-0.187593,0.000000,0.934172,0.303531,-0.187593,0.647155,0.147020, -0.978148,0.207911,0.000000,0.000000,0.978148,0.207911,0.000000,0.319635,0.345280, -1.000000,-0.000000,0.000000,0.000000,1.000000,-0.000000,0.000000,0.445347,0.130459, -0.978148,0.207911,0.000000,0.000000,0.978148,0.207911,0.000000,0.319635,0.345280, -0.983024,0.096460,0.156077,0.000000,0.983024,0.096460,0.156077,0.408260,0.332044, -0.913545,0.181898,-0.363797,0.000000,0.913545,0.181898,-0.363797,0.606917,0.202395, -0.809017,0.262865,-0.525731,0.000000,0.809017,0.262865,-0.525731,0.790230,0.749029, -0.845991,0.389809,-0.363797,0.000000,0.845991,0.389809,-0.363797,0.554653,0.130459, -0.913545,0.181898,-0.363797,0.000000,0.913545,0.181898,-0.363797,0.606917,0.202395, -0.934172,0.303531,-0.187593,0.000000,0.934172,0.303531,-0.187593,0.647155,0.147020, -0.978148,0.092981,-0.185961,0.000000,0.978148,0.092981,-0.185961,0.352845,0.147020, -1.000000,-0.000000,0.000000,0.000000,1.000000,-0.000000,0.000000,0.445347,0.130459, -0.978148,0.092981,-0.185961,0.000000,0.978148,0.092981,-0.185961,0.352845,0.147020, -0.978148,0.207911,0.000000,0.000000,0.978148,0.207911,0.000000,0.319635,0.345280, -0.738585,0.432902,-0.516806,0.000000,0.738585,0.432902,-0.516806,0.816078,0.490281, -0.643075,0.588241,-0.490334,0.000000,0.643075,0.588241,-0.490334,0.697755,0.772187, -0.757312,0.555521,-0.343331,0.000000,0.757312,0.555521,-0.343331,0.352845,0.268343, -0.845991,0.389809,-0.363797,0.000000,0.845991,0.389809,-0.363797,0.554653,0.130459, -0.757312,0.555521,-0.343331,0.000000,0.757312,0.555521,-0.343331,0.352845,0.268343, -0.845991,0.499718,-0.185961,0.000000,0.845991,0.499718,-0.185961,0.500000,0.327581, -0.934172,0.303531,-0.187593,0.000000,0.934172,0.303531,-0.187593,0.647155,0.147020, -0.845991,0.499718,-0.185961,0.000000,0.845991,0.499718,-0.185961,0.500000,0.327581, -0.913545,0.406737,0.000000,0.000000,0.913545,0.406737,0.000000,0.445347,0.258102, -0.978148,0.207911,0.000000,0.000000,0.978148,0.207911,0.000000,0.319635,0.345280, -0.913545,0.406737,0.000000,0.000000,0.913545,0.406737,0.000000,0.445347,0.258102, -0.939205,0.305166,0.157379,0.000000,0.939205,0.305166,0.157379,0.591739,0.332044, -0.983024,0.096460,0.156077,0.000000,0.983024,0.096460,0.156077,0.408260,0.332044, -0.939205,0.305166,0.157379,0.000000,0.939205,0.305166,0.157379,0.591739,0.332044, -0.932670,0.189647,0.306855,0.000000,0.932670,0.189647,0.306855,0.554653,0.258102, -0.845991,0.389809,-0.363797,0.000000,0.845991,0.389809,-0.363797,0.554653,0.130459, -0.738585,0.432902,-0.516806,0.000000,0.738585,0.432902,-0.516806,0.816078,0.490281, -0.757312,0.555521,-0.343331,0.000000,0.757312,0.555521,-0.343331,0.352845,0.268343, -0.934172,0.303531,-0.187593,0.000000,0.934172,0.303531,-0.187593,0.647155,0.147020, -0.845991,0.389809,-0.363797,0.000000,0.845991,0.389809,-0.363797,0.554653,0.130459, -0.845991,0.499718,-0.185961,0.000000,0.845991,0.499718,-0.185961,0.500000,0.327581, -0.978148,0.207911,0.000000,0.000000,0.978148,0.207911,0.000000,0.319635,0.345280, -0.934172,0.303531,-0.187593,0.000000,0.934172,0.303531,-0.187593,0.647155,0.147020, -0.913545,0.406737,0.000000,0.000000,0.913545,0.406737,0.000000,0.445347,0.258102, -0.983024,0.096460,0.156077,0.000000,0.983024,0.096460,0.156077,0.408260,0.332044, -0.978148,0.207911,0.000000,0.000000,0.978148,0.207911,0.000000,0.319635,0.345280, -0.939205,0.305166,0.157379,0.000000,0.939205,0.305166,0.157379,0.591739,0.332044, -0.643075,0.588241,-0.490334,0.000000,0.643075,0.588241,-0.490334,0.697755,0.772187, -0.525731,0.723607,-0.447214,0.000000,0.525731,0.723607,-0.447214,0.788675,0.593796, -0.643075,0.701637,-0.306855,0.000000,0.643075,0.701637,-0.306855,0.680365,0.345280, -0.757312,0.555521,-0.343331,0.000000,0.757312,0.555521,-0.343331,0.352845,0.268343, -0.643075,0.701637,-0.306855,0.000000,0.643075,0.701637,-0.306855,0.680365,0.345280, -0.738585,0.655845,-0.156077,0.000000,0.738585,0.655845,-0.156077,0.647155,0.268343, -0.845991,0.499718,-0.185961,0.000000,0.845991,0.499718,-0.185961,0.500000,0.327581, -0.738585,0.655845,-0.156077,0.000000,0.738585,0.655845,-0.156077,0.647155,0.268343, -0.809017,0.587785,0.000000,0.000000,0.809017,0.587785,0.000000,0.553923,0.743874, -0.913545,0.406737,0.000000,0.000000,0.913545,0.406737,0.000000,0.445347,0.258102, -0.809017,0.587785,0.000000,0.000000,0.809017,0.587785,0.000000,0.553923,0.743874, -0.851981,0.499768,0.156077,0.000000,0.851981,0.499768,0.156077,0.643075,0.762112, -0.939205,0.305166,0.157379,0.000000,0.939205,0.305166,0.157379,0.591739,0.332044, -0.851981,0.499768,0.156077,0.000000,0.851981,0.499768,0.156077,0.643075,0.762112, -0.866018,0.394782,0.306855,0.000000,0.866018,0.394782,0.306855,0.606016,0.668485, -0.932670,0.189647,0.306855,0.000000,0.932670,0.189647,0.306855,0.554653,0.258102, -0.866018,0.394782,0.306855,0.000000,0.866018,0.394782,0.306855,0.606016,0.668485, -0.850651,0.276393,0.447214,0.000000,0.850651,0.276393,0.447214,0.750000,0.581230, -0.757312,0.555521,-0.343331,0.000000,0.757312,0.555521,-0.343331,0.352845,0.268343, -0.643075,0.588241,-0.490334,0.000000,0.643075,0.588241,-0.490334,0.697755,0.772187, -0.643075,0.701637,-0.306855,0.000000,0.643075,0.701637,-0.306855,0.680365,0.345280, -0.845991,0.499718,-0.185961,0.000000,0.845991,0.499718,-0.185961,0.500000,0.327581, -0.757312,0.555521,-0.343331,0.000000,0.757312,0.555521,-0.343331,0.352845,0.268343, -0.738585,0.655845,-0.156077,0.000000,0.738585,0.655845,-0.156077,0.647155,0.268343, -0.913545,0.406737,0.000000,0.000000,0.913545,0.406737,0.000000,0.445347,0.258102, -0.845991,0.499718,-0.185961,0.000000,0.845991,0.499718,-0.185961,0.500000,0.327581, -0.809017,0.587785,0.000000,0.000000,0.809017,0.587785,0.000000,0.553923,0.743874, -0.913545,0.406737,0.000000,0.000000,0.913545,0.406737,0.000000,0.445347,0.258102, -0.851981,0.499768,0.156077,0.000000,0.851981,0.499768,0.156077,0.643075,0.762112, -0.939205,0.305166,0.157379,0.000000,0.939205,0.305166,0.157379,0.591739,0.332044, -0.932670,0.189647,0.306855,0.000000,0.932670,0.189647,0.306855,0.554653,0.258102, -0.939205,0.305166,0.157379,0.000000,0.939205,0.305166,0.157379,0.591739,0.332044, -0.866018,0.394782,0.306855,0.000000,0.866018,0.394782,0.306855,0.606016,0.668485, -0.525731,0.723607,-0.447214,0.000000,0.525731,0.723607,-0.447214,0.788675,0.593796, -0.360730,0.793377,-0.490334,0.000000,0.360730,0.793377,-0.490334,0.345491,0.712663, -0.468576,0.828418,-0.306855,0.000000,0.468576,0.828418,-0.306855,0.727648,0.772345, -0.360730,0.793377,-0.490334,0.000000,0.360730,0.793377,-0.490334,0.345491,0.712663, -0.183479,0.836210,-0.516806,0.000000,0.183479,0.836210,-0.516806,0.447735,0.722382, -0.294310,0.891911,-0.343331,0.000000,0.294310,0.891911,-0.343331,0.695347,0.683427, -0.468576,0.828418,-0.306855,0.000000,0.468576,0.828418,-0.306855,0.727648,0.772345, -0.294310,0.891911,-0.343331,0.000000,0.294310,0.891911,-0.343331,0.695347,0.683427, -0.395511,0.905103,-0.156077,0.000000,0.395511,0.905103,-0.156077,0.654508,0.590447, -0.360730,0.793377,-0.490334,0.000000,0.360730,0.793377,-0.490334,0.345491,0.712663, -0.294310,0.891911,-0.343331,0.000000,0.294310,0.891911,-0.343331,0.695347,0.683427, -0.468576,0.828418,-0.306855,0.000000,0.468576,0.828418,-0.306855,0.727648,0.772345, -0.183479,0.836210,-0.516806,0.000000,0.183479,0.836210,-0.516806,0.447735,0.722382, -0.000000,0.850651,-0.525731,0.000000,0.000000,0.850651,-0.525731,0.393984,0.645918, -0.109305,0.925043,-0.363797,0.000000,0.109305,0.925043,-0.363797,0.816078,0.772345, -0.294310,0.891911,-0.343331,0.000000,0.294310,0.891911,-0.343331,0.695347,0.683427, -0.109305,0.925043,-0.363797,0.000000,0.109305,0.925043,-0.363797,0.816078,0.772345, -0.213835,0.959006,-0.185961,0.000000,0.213835,0.959006,-0.185961,0.788675,0.684243, -0.395511,0.905103,-0.156077,0.000000,0.395511,0.905103,-0.156077,0.654508,0.590447, -0.213835,0.959006,-0.185961,0.000000,0.213835,0.959006,-0.185961,0.788675,0.684243, -0.309017,0.951056,0.000000,0.000000,0.309017,0.951056,0.000000,0.750000,0.590447, -0.183479,0.836210,-0.516806,0.000000,0.183479,0.836210,-0.516806,0.447735,0.722382, -0.109305,0.925043,-0.363797,0.000000,0.109305,0.925043,-0.363797,0.816078,0.772345, -0.294310,0.891911,-0.343331,0.000000,0.294310,0.891911,-0.343331,0.695347,0.683427, -0.294310,0.891911,-0.343331,0.000000,0.294310,0.891911,-0.343331,0.695347,0.683427, -0.213835,0.959006,-0.185961,0.000000,0.213835,0.959006,-0.185961,0.788675,0.684243, -0.395511,0.905103,-0.156077,0.000000,0.395511,0.905103,-0.156077,0.654508,0.590447, -0.000000,0.850651,-0.525731,0.000000,0.000000,0.850651,-0.525731,0.393984,0.645918, --0.183479,0.836210,-0.516806,0.000000,-0.183479,0.836210,-0.516806,0.500000,0.650438, --0.109305,0.925043,-0.363797,0.000000,-0.109305,0.925043,-0.363797,0.697755,0.512408, -0.109305,0.925043,-0.363797,0.000000,0.109305,0.925043,-0.363797,0.816078,0.772345, --0.109305,0.925043,-0.363797,0.000000,-0.109305,0.925043,-0.363797,0.697755,0.512408, -0.000000,0.982247,-0.187593,0.000000,0.000000,0.982247,-0.187593,0.762112,0.225709, -0.213835,0.959006,-0.185961,0.000000,0.213835,0.959006,-0.185961,0.788675,0.684243, -0.000000,0.982247,-0.187593,0.000000,0.000000,0.982247,-0.187593,0.762112,0.225709, -0.104529,0.994522,0.000000,0.000000,0.104529,0.994522,0.000000,0.772345,0.157937, -0.309017,0.951056,0.000000,0.000000,0.309017,0.951056,0.000000,0.750000,0.590447, -0.104529,0.994522,0.000000,0.000000,0.104529,0.994522,0.000000,0.772345,0.157937, -0.212032,0.964719,0.156077,0.000000,0.212032,0.964719,0.156077,0.683427,0.174918, -0.109305,0.925043,-0.363797,0.000000,0.109305,0.925043,-0.363797,0.816078,0.772345, -0.000000,0.850651,-0.525731,0.000000,0.000000,0.850651,-0.525731,0.393984,0.645918, --0.109305,0.925043,-0.363797,0.000000,-0.109305,0.925043,-0.363797,0.697755,0.512408, -0.109305,0.925043,-0.363797,0.000000,0.109305,0.925043,-0.363797,0.816078,0.772345, -0.000000,0.982247,-0.187593,0.000000,0.000000,0.982247,-0.187593,0.762112,0.225709, -0.213835,0.959006,-0.185961,0.000000,0.213835,0.959006,-0.185961,0.788675,0.684243, -0.309017,0.951056,0.000000,0.000000,0.309017,0.951056,0.000000,0.750000,0.590447, -0.213835,0.959006,-0.185961,0.000000,0.213835,0.959006,-0.185961,0.788675,0.684243, -0.104529,0.994522,0.000000,0.000000,0.104529,0.994522,0.000000,0.772345,0.157937, --0.183479,0.836210,-0.516806,0.000000,-0.183479,0.836210,-0.516806,0.500000,0.650438, --0.360730,0.793377,-0.490334,0.000000,-0.360730,0.793377,-0.490334,0.790230,0.912551, --0.294309,0.891911,-0.343331,0.000000,-0.294309,0.891911,-0.343331,0.868343,0.683427, --0.109305,0.925043,-0.363797,0.000000,-0.109305,0.925043,-0.363797,0.697755,0.512408, --0.294309,0.891911,-0.343331,0.000000,-0.294309,0.891911,-0.343331,0.868343,0.683427, --0.213834,0.959006,-0.185961,0.000000,-0.213834,0.959006,-0.185961,0.834566,0.590447, -0.000000,0.982247,-0.187593,0.000000,0.000000,0.982247,-0.187593,0.762112,0.225709, --0.213834,0.959006,-0.185961,0.000000,-0.213834,0.959006,-0.185961,0.834566,0.590447, --0.104529,0.994522,0.000000,0.000000,-0.104529,0.994522,0.000000,0.790230,0.511757, -0.104529,0.994522,0.000000,0.000000,0.104529,0.994522,0.000000,0.772345,0.157937, --0.104529,0.994522,0.000000,0.000000,-0.104529,0.994522,0.000000,0.790230,0.511757, -0.000000,0.987538,0.157379,0.000000,0.000000,0.987538,0.157379,0.734288,0.437019, -0.212032,0.964719,0.156077,0.000000,0.212032,0.964719,0.156077,0.683427,0.174918, -0.000000,0.987538,0.157379,0.000000,0.000000,0.987538,0.157379,0.734288,0.437019, -0.107846,0.945626,0.306855,0.000000,0.107846,0.945626,0.306855,0.743874,0.302609, --0.109305,0.925043,-0.363797,0.000000,-0.109305,0.925043,-0.363797,0.697755,0.512408, --0.183479,0.836210,-0.516806,0.000000,-0.183479,0.836210,-0.516806,0.500000,0.650438, --0.294309,0.891911,-0.343331,0.000000,-0.294309,0.891911,-0.343331,0.868343,0.683427, -0.000000,0.982247,-0.187593,0.000000,0.000000,0.982247,-0.187593,0.762112,0.225709, --0.109305,0.925043,-0.363797,0.000000,-0.109305,0.925043,-0.363797,0.697755,0.512408, --0.213834,0.959006,-0.185961,0.000000,-0.213834,0.959006,-0.185961,0.834566,0.590447, -0.104529,0.994522,0.000000,0.000000,0.104529,0.994522,0.000000,0.772345,0.157937, -0.000000,0.982247,-0.187593,0.000000,0.000000,0.982247,-0.187593,0.762112,0.225709, --0.104529,0.994522,0.000000,0.000000,-0.104529,0.994522,0.000000,0.790230,0.511757, -0.212032,0.964719,0.156077,0.000000,0.212032,0.964719,0.156077,0.683427,0.174918, -0.104529,0.994522,0.000000,0.000000,0.104529,0.994522,0.000000,0.772345,0.157937, -0.000000,0.987538,0.157379,0.000000,0.000000,0.987538,0.157379,0.734288,0.437019, --0.360730,0.793377,-0.490334,0.000000,-0.360730,0.793377,-0.490334,0.790230,0.912551, --0.525731,0.723607,-0.447214,0.000000,-0.525731,0.723607,-0.447214,0.446077,0.574219, --0.468576,0.828418,-0.306855,0.000000,-0.468576,0.828418,-0.306855,0.668485,0.250116, --0.294309,0.891911,-0.343331,0.000000,-0.294309,0.891911,-0.343331,0.868343,0.683427, --0.468576,0.828418,-0.306855,0.000000,-0.468576,0.828418,-0.306855,0.668485,0.250116, --0.395510,0.905103,-0.156077,0.000000,-0.395510,0.905103,-0.156077,0.590447,0.206107, --0.213834,0.959006,-0.185961,0.000000,-0.213834,0.959006,-0.185961,0.834566,0.590447, --0.395510,0.905103,-0.156077,0.000000,-0.395510,0.905103,-0.156077,0.590447,0.206107, --0.309017,0.951057,0.000000,0.000000,-0.309017,0.951057,0.000000,0.590447,0.128428, --0.104529,0.994522,0.000000,0.000000,-0.104529,0.994522,0.000000,0.790230,0.511757, --0.309017,0.951057,0.000000,0.000000,-0.309017,0.951057,0.000000,0.590447,0.128428, --0.212031,0.964719,0.156077,0.000000,-0.212031,0.964719,0.156077,0.512408,0.172078, -0.000000,0.987538,0.157379,0.000000,0.000000,0.987538,0.157379,0.734288,0.437019, --0.212031,0.964719,0.156077,0.000000,-0.212031,0.964719,0.156077,0.512408,0.172078, --0.107846,0.945626,0.306855,0.000000,-0.107846,0.945626,0.306855,0.869292,0.512408, -0.107846,0.945626,0.306855,0.000000,0.107846,0.945626,0.306855,0.743874,0.302609, --0.107846,0.945626,0.306855,0.000000,-0.107846,0.945626,0.306855,0.869292,0.512408, -0.000000,0.894427,0.447214,0.000000,0.000000,0.894427,0.447214,0.268343,0.250971, --0.294309,0.891911,-0.343331,0.000000,-0.294309,0.891911,-0.343331,0.868343,0.683427, --0.360730,0.793377,-0.490334,0.000000,-0.360730,0.793377,-0.490334,0.790230,0.912551, --0.468576,0.828418,-0.306855,0.000000,-0.468576,0.828418,-0.306855,0.668485,0.250116, --0.213834,0.959006,-0.185961,0.000000,-0.213834,0.959006,-0.185961,0.834566,0.590447, --0.294309,0.891911,-0.343331,0.000000,-0.294309,0.891911,-0.343331,0.868343,0.683427, --0.395510,0.905103,-0.156077,0.000000,-0.395510,0.905103,-0.156077,0.590447,0.206107, --0.213834,0.959006,-0.185961,0.000000,-0.213834,0.959006,-0.185961,0.834566,0.590447, --0.309017,0.951057,0.000000,0.000000,-0.309017,0.951057,0.000000,0.590447,0.128428, --0.104529,0.994522,0.000000,0.000000,-0.104529,0.994522,0.000000,0.790230,0.511757, --0.104529,0.994522,0.000000,0.000000,-0.104529,0.994522,0.000000,0.790230,0.511757, --0.212031,0.964719,0.156077,0.000000,-0.212031,0.964719,0.156077,0.512408,0.172078, -0.000000,0.987538,0.157379,0.000000,0.000000,0.987538,0.157379,0.734288,0.437019, -0.107846,0.945626,0.306855,0.000000,0.107846,0.945626,0.306855,0.743874,0.302609, -0.000000,0.987538,0.157379,0.000000,0.000000,0.987538,0.157379,0.734288,0.437019, --0.107846,0.945626,0.306855,0.000000,-0.107846,0.945626,0.306855,0.869292,0.512408, --0.525731,0.723607,-0.447214,0.000000,-0.525731,0.723607,-0.447214,0.446077,0.574219, --0.643075,0.588241,-0.490334,0.000000,-0.643075,0.588241,-0.490334,0.680365,0.835614, --0.643075,0.701637,-0.306855,0.000000,-0.643075,0.701637,-0.306855,0.821537,0.437019, --0.643075,0.588241,-0.490334,0.000000,-0.643075,0.588241,-0.490334,0.680365,0.835614, --0.738585,0.432902,-0.516806,0.000000,-0.738585,0.432902,-0.516806,0.647155,0.912551, --0.757311,0.555521,-0.343331,0.000000,-0.757311,0.555521,-0.343331,0.743874,0.405176, --0.643075,0.701637,-0.306855,0.000000,-0.643075,0.701637,-0.306855,0.821537,0.437019, --0.757311,0.555521,-0.343331,0.000000,-0.757311,0.555521,-0.343331,0.743874,0.405176, --0.738585,0.655845,-0.156077,0.000000,-0.738585,0.655845,-0.156077,0.762112,0.497855, --0.643075,0.588241,-0.490334,0.000000,-0.643075,0.588241,-0.490334,0.680365,0.835614, --0.757311,0.555521,-0.343331,0.000000,-0.757311,0.555521,-0.343331,0.743874,0.405176, --0.643075,0.701637,-0.306855,0.000000,-0.643075,0.701637,-0.306855,0.821537,0.437019, --0.738585,0.432902,-0.516806,0.000000,-0.738585,0.432902,-0.516806,0.647155,0.912551, --0.809017,0.262866,-0.525731,0.000000,-0.809017,0.262866,-0.525731,0.591739,0.848850, --0.845991,0.389810,-0.363797,0.000000,-0.845991,0.389810,-0.363797,0.668485,0.451770, --0.757311,0.555521,-0.343331,0.000000,-0.757311,0.555521,-0.343331,0.743874,0.405176, --0.845991,0.389810,-0.363797,0.000000,-0.845991,0.389810,-0.363797,0.668485,0.451770, --0.845991,0.499718,-0.185961,0.000000,-0.845991,0.499718,-0.185961,0.772345,0.590949, --0.738585,0.655845,-0.156077,0.000000,-0.738585,0.655845,-0.156077,0.762112,0.497855, --0.845991,0.499718,-0.185961,0.000000,-0.845991,0.499718,-0.185961,0.772345,0.590949, --0.809017,0.587785,0.000000,0.000000,-0.809017,0.587785,0.000000,0.683427,0.546490, --0.738585,0.432902,-0.516806,0.000000,-0.738585,0.432902,-0.516806,0.647155,0.912551, --0.845991,0.389810,-0.363797,0.000000,-0.845991,0.389810,-0.363797,0.668485,0.451770, --0.757311,0.555521,-0.343331,0.000000,-0.757311,0.555521,-0.343331,0.743874,0.405176, --0.757311,0.555521,-0.343331,0.000000,-0.757311,0.555521,-0.343331,0.743874,0.405176, --0.845991,0.499718,-0.185961,0.000000,-0.845991,0.499718,-0.185961,0.772345,0.590949, --0.738585,0.655845,-0.156077,0.000000,-0.738585,0.655845,-0.156077,0.762112,0.497855, --0.809017,0.262866,-0.525731,0.000000,-0.809017,0.262866,-0.525731,0.591739,0.848850, --0.851981,0.083904,-0.516806,0.000000,-0.851981,0.083904,-0.516806,0.554653,0.922791, --0.913545,0.181899,-0.363797,0.000000,-0.913545,0.181899,-0.363797,0.590447,0.500000, --0.845991,0.389810,-0.363797,0.000000,-0.845991,0.389810,-0.363797,0.668485,0.451770, --0.913545,0.181899,-0.363797,0.000000,-0.913545,0.181899,-0.363797,0.590447,0.500000, --0.934172,0.303531,-0.187593,0.000000,-0.934172,0.303531,-0.187593,0.772345,0.694905, --0.845991,0.499718,-0.185961,0.000000,-0.845991,0.499718,-0.185961,0.772345,0.590949, --0.934172,0.303531,-0.187593,0.000000,-0.934172,0.303531,-0.187593,0.772345,0.694905, --0.913545,0.406737,0.000000,0.000000,-0.913545,0.406737,0.000000,0.684243,0.651765, --0.809017,0.587785,0.000000,0.000000,-0.809017,0.587785,0.000000,0.683427,0.546490, --0.913545,0.406737,0.000000,0.000000,-0.913545,0.406737,0.000000,0.684243,0.651765, --0.851981,0.499769,0.156077,0.000000,-0.851981,0.499769,0.156077,0.590447,0.603956, --0.809017,0.262866,-0.525731,0.000000,-0.809017,0.262866,-0.525731,0.591739,0.848850, --0.913545,0.181899,-0.363797,0.000000,-0.913545,0.181899,-0.363797,0.590447,0.500000, --0.845991,0.389810,-0.363797,0.000000,-0.845991,0.389810,-0.363797,0.668485,0.451770, --0.845991,0.389810,-0.363797,0.000000,-0.845991,0.389810,-0.363797,0.668485,0.451770, --0.934172,0.303531,-0.187593,0.000000,-0.934172,0.303531,-0.187593,0.772345,0.694905, --0.845991,0.499718,-0.185961,0.000000,-0.845991,0.499718,-0.185961,0.772345,0.590949, --0.845991,0.499718,-0.185961,0.000000,-0.845991,0.499718,-0.185961,0.772345,0.590949, --0.913545,0.406737,0.000000,0.000000,-0.913545,0.406737,0.000000,0.684243,0.651765, --0.809017,0.587785,0.000000,0.000000,-0.809017,0.587785,0.000000,0.683427,0.546490, --0.851981,0.083904,-0.516806,0.000000,-0.851981,0.083904,-0.516806,0.554653,0.922791, --0.866018,-0.097907,-0.490334,0.000000,-0.866018,-0.097907,-0.490334,0.500000,0.853312, --0.939205,-0.004289,-0.343331,0.000000,-0.939205,-0.004289,-0.343331,0.512408,0.548230, --0.913545,0.181899,-0.363797,0.000000,-0.913545,0.181899,-0.363797,0.590447,0.500000, --0.939205,-0.004289,-0.343331,0.000000,-0.939205,-0.004289,-0.343331,0.512408,0.548230, --0.978148,0.092981,-0.185961,0.000000,-0.978148,0.092981,-0.185961,0.762112,0.777761, --0.934172,0.303531,-0.187593,0.000000,-0.934172,0.303531,-0.187593,0.772345,0.694905, --0.978148,0.092981,-0.185961,0.000000,-0.978148,0.092981,-0.185961,0.762112,0.777761, --0.978148,0.207911,0.000000,0.000000,-0.978148,0.207911,0.000000,0.683427,0.749859, --0.913545,0.406737,0.000000,0.000000,-0.913545,0.406737,0.000000,0.684243,0.651765, --0.978148,0.207911,0.000000,0.000000,-0.978148,0.207911,0.000000,0.683427,0.749859, --0.939205,0.305166,0.157379,0.000000,-0.939205,0.305166,0.157379,0.590447,0.703368, --0.851981,0.499769,0.156077,0.000000,-0.851981,0.499769,0.156077,0.590447,0.603956, --0.939205,0.305166,0.157379,0.000000,-0.939205,0.305166,0.157379,0.590447,0.703368, --0.866018,0.394783,0.306855,0.000000,-0.866018,0.394783,0.306855,0.511757,0.652583, --0.913545,0.181899,-0.363797,0.000000,-0.913545,0.181899,-0.363797,0.590447,0.500000, --0.851981,0.083904,-0.516806,0.000000,-0.851981,0.083904,-0.516806,0.554653,0.922791, --0.939205,-0.004289,-0.343331,0.000000,-0.939205,-0.004289,-0.343331,0.512408,0.548230, --0.934172,0.303531,-0.187593,0.000000,-0.934172,0.303531,-0.187593,0.772345,0.694905, --0.913545,0.181899,-0.363797,0.000000,-0.913545,0.181899,-0.363797,0.590447,0.500000, --0.978148,0.092981,-0.185961,0.000000,-0.978148,0.092981,-0.185961,0.762112,0.777761, --0.934172,0.303531,-0.187593,0.000000,-0.934172,0.303531,-0.187593,0.772345,0.694905, --0.978148,0.207911,0.000000,0.000000,-0.978148,0.207911,0.000000,0.683427,0.749859, --0.913545,0.406737,0.000000,0.000000,-0.913545,0.406737,0.000000,0.684243,0.651765, --0.851981,0.499769,0.156077,0.000000,-0.851981,0.499769,0.156077,0.590447,0.603956, --0.913545,0.406737,0.000000,0.000000,-0.913545,0.406737,0.000000,0.684243,0.651765, --0.939205,0.305166,0.157379,0.000000,-0.939205,0.305166,0.157379,0.590447,0.703368, --0.866018,-0.097907,-0.490334,0.000000,-0.866018,-0.097907,-0.490334,0.500000,0.853312, --0.850651,-0.276393,-0.447214,0.000000,-0.850651,-0.276393,-0.447214,0.445347,0.922791, --0.932670,-0.189647,-0.306855,0.000000,-0.932670,-0.189647,-0.306855,0.437019,0.594823, --0.939205,-0.004289,-0.343331,0.000000,-0.939205,-0.004289,-0.343331,0.512408,0.548230, --0.932670,-0.189647,-0.306855,0.000000,-0.932670,-0.189647,-0.306855,0.437019,0.594823, --0.983024,-0.096460,-0.156077,0.000000,-0.983024,-0.096460,-0.156077,0.821537,0.743874, --0.978148,0.092981,-0.185961,0.000000,-0.978148,0.092981,-0.185961,0.762112,0.777761, --0.983024,-0.096460,-0.156077,0.000000,-0.983024,-0.096460,-0.156077,0.821537,0.743874, --1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.000000,0.743874,0.850819, --0.978148,0.207911,0.000000,0.000000,-0.978148,0.207911,0.000000,0.683427,0.749859, --1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.000000,0.743874,0.850819, --0.983024,0.096461,0.156077,0.000000,-0.983024,0.096461,0.156077,0.668485,0.827922, --0.939205,0.305166,0.157379,0.000000,-0.939205,0.305166,0.157379,0.590447,0.703368, --0.983024,0.096461,0.156077,0.000000,-0.983024,0.096461,0.156077,0.668485,0.827922, --0.932670,0.189647,0.306855,0.000000,-0.932670,0.189647,0.306855,0.590447,0.793893, --0.866018,0.394783,0.306855,0.000000,-0.866018,0.394783,0.306855,0.511757,0.652583, --0.932670,0.189647,0.306855,0.000000,-0.932670,0.189647,0.306855,0.590447,0.793893, --0.850651,0.276393,0.447214,0.000000,-0.850651,0.276393,0.447214,0.588426,0.872062, --0.939205,-0.004289,-0.343331,0.000000,-0.939205,-0.004289,-0.343331,0.512408,0.548230, --0.866018,-0.097907,-0.490334,0.000000,-0.866018,-0.097907,-0.490334,0.500000,0.853312, --0.932670,-0.189647,-0.306855,0.000000,-0.932670,-0.189647,-0.306855,0.437019,0.594823, --0.978148,0.092981,-0.185961,0.000000,-0.978148,0.092981,-0.185961,0.762112,0.777761, --0.939205,-0.004289,-0.343331,0.000000,-0.939205,-0.004289,-0.343331,0.512408,0.548230, --0.983024,-0.096460,-0.156077,0.000000,-0.983024,-0.096460,-0.156077,0.821537,0.743874, --0.978148,0.092981,-0.185961,0.000000,-0.978148,0.092981,-0.185961,0.762112,0.777761, --1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.000000,0.743874,0.850819, --0.978148,0.207911,0.000000,0.000000,-0.978148,0.207911,0.000000,0.683427,0.749859, --0.978148,0.207911,0.000000,0.000000,-0.978148,0.207911,0.000000,0.683427,0.749859, --0.983024,0.096461,0.156077,0.000000,-0.983024,0.096461,0.156077,0.668485,0.827922, --0.939205,0.305166,0.157379,0.000000,-0.939205,0.305166,0.157379,0.590447,0.703368, --0.939205,0.305166,0.157379,0.000000,-0.939205,0.305166,0.157379,0.590447,0.703368, --0.932670,0.189647,0.306855,0.000000,-0.932670,0.189647,0.306855,0.590447,0.793893, --0.866018,0.394783,0.306855,0.000000,-0.866018,0.394783,0.306855,0.511757,0.652583, --0.850651,-0.276393,-0.447214,0.000000,-0.850651,-0.276393,-0.447214,0.445347,0.922791, --0.758172,-0.429824,-0.490334,0.000000,-0.758172,-0.429824,-0.490334,0.178463,0.835614, --0.866018,-0.394782,-0.306855,0.000000,-0.866018,-0.394782,-0.306855,0.512408,0.749884, --0.758172,-0.429824,-0.490334,0.000000,-0.758172,-0.429824,-0.490334,0.178463,0.835614, --0.639949,-0.568662,-0.516806,0.000000,-0.639949,-0.568662,-0.516806,0.118823,0.469124, --0.762354,-0.548581,-0.343331,0.000000,-0.762354,-0.548581,-0.343331,0.437019,0.697391, --0.866018,-0.394782,-0.306855,0.000000,-0.866018,-0.394782,-0.306855,0.512408,0.749884, --0.762354,-0.548581,-0.343331,0.000000,-0.762354,-0.548581,-0.343331,0.437019,0.697391, --0.851981,-0.499768,-0.156077,0.000000,-0.851981,-0.499768,-0.156077,0.734288,0.743874, --0.758172,-0.429824,-0.490334,0.000000,-0.758172,-0.429824,-0.490334,0.178463,0.835614, --0.762354,-0.548581,-0.343331,0.000000,-0.762354,-0.548581,-0.343331,0.437019,0.697391, --0.866018,-0.394782,-0.306855,0.000000,-0.866018,-0.394782,-0.306855,0.512408,0.749884, --0.639949,-0.568662,-0.516806,0.000000,-0.639949,-0.568662,-0.516806,0.118823,0.469124, --0.500000,-0.688191,-0.525731,0.000000,-0.500000,-0.688191,-0.525731,0.209770,0.749029, --0.632156,-0.684127,-0.363797,0.000000,-0.632156,-0.684127,-0.363797,0.647155,0.762112, --0.762354,-0.548581,-0.343331,0.000000,-0.762354,-0.548581,-0.343331,0.437019,0.697391, --0.632156,-0.684127,-0.363797,0.000000,-0.632156,-0.684127,-0.363797,0.647155,0.762112, --0.736686,-0.650164,-0.185961,0.000000,-0.736686,-0.650164,-0.185961,0.697756,0.668485, --0.851981,-0.499768,-0.156077,0.000000,-0.851981,-0.499768,-0.156077,0.734288,0.743874, --0.736686,-0.650164,-0.185961,0.000000,-0.736686,-0.650164,-0.185961,0.697756,0.668485, --0.809017,-0.587785,0.000000,0.000000,-0.809017,-0.587785,0.000000,0.554653,0.772345, --0.639949,-0.568662,-0.516806,0.000000,-0.639949,-0.568662,-0.516806,0.118823,0.469124, --0.632156,-0.684127,-0.363797,0.000000,-0.632156,-0.684127,-0.363797,0.647155,0.762112, --0.762354,-0.548581,-0.343331,0.000000,-0.762354,-0.548581,-0.343331,0.437019,0.697391, --0.762354,-0.548581,-0.343331,0.000000,-0.762354,-0.548581,-0.343331,0.437019,0.697391, --0.736686,-0.650164,-0.185961,0.000000,-0.736686,-0.650164,-0.185961,0.697756,0.668485, --0.851981,-0.499768,-0.156077,0.000000,-0.851981,-0.499768,-0.156077,0.734288,0.743874, --0.500000,-0.688191,-0.525731,0.000000,-0.500000,-0.688191,-0.525731,0.209770,0.749029, --0.343074,-0.784354,-0.516806,0.000000,-0.343074,-0.784354,-0.516806,0.165435,0.666172, --0.455297,-0.812623,-0.363797,0.000000,-0.455297,-0.812623,-0.363797,0.606918,0.683427, --0.632156,-0.684127,-0.363797,0.000000,-0.632156,-0.684127,-0.363797,0.647155,0.762112, --0.455297,-0.812623,-0.363797,0.000000,-0.455297,-0.812623,-0.363797,0.606918,0.683427, --0.577350,-0.794654,-0.187593,0.000000,-0.577350,-0.794654,-0.187593,0.445347,0.772345, --0.736686,-0.650164,-0.185961,0.000000,-0.736686,-0.650164,-0.185961,0.697756,0.668485, --0.577350,-0.794654,-0.187593,0.000000,-0.577350,-0.794654,-0.187593,0.445347,0.772345, --0.669131,-0.743144,0.000000,0.000000,-0.669131,-0.743144,0.000000,0.500000,0.684243, --0.809017,-0.587785,0.000000,0.000000,-0.809017,-0.587785,0.000000,0.554653,0.772345, --0.669131,-0.743144,0.000000,0.000000,-0.669131,-0.743144,0.000000,0.500000,0.684243, --0.738585,-0.655845,0.156077,0.000000,-0.738585,-0.655845,0.156077,0.552265,0.590447, --0.500000,-0.688191,-0.525731,0.000000,-0.500000,-0.688191,-0.525731,0.209770,0.749029, --0.455297,-0.812623,-0.363797,0.000000,-0.455297,-0.812623,-0.363797,0.606918,0.683427, --0.632156,-0.684127,-0.363797,0.000000,-0.632156,-0.684127,-0.363797,0.647155,0.762112, --0.632156,-0.684127,-0.363797,0.000000,-0.632156,-0.684127,-0.363797,0.647155,0.762112, --0.577350,-0.794654,-0.187593,0.000000,-0.577350,-0.794654,-0.187593,0.445347,0.772345, --0.736686,-0.650164,-0.185961,0.000000,-0.736686,-0.650164,-0.185961,0.697756,0.668485, --0.736686,-0.650164,-0.185961,0.000000,-0.736686,-0.650164,-0.185961,0.697756,0.668485, --0.669131,-0.743144,0.000000,0.000000,-0.669131,-0.743144,0.000000,0.500000,0.684243, --0.809017,-0.587785,0.000000,0.000000,-0.809017,-0.587785,0.000000,0.554653,0.772345, --0.343074,-0.784354,-0.516806,0.000000,-0.343074,-0.784354,-0.516806,0.165435,0.666172, --0.174499,-0.853887,-0.490334,0.000000,-0.174499,-0.853887,-0.490334,0.131658,0.562217, --0.286151,-0.894562,-0.343331,0.000000,-0.286151,-0.894562,-0.343331,0.606016,0.512408, --0.455297,-0.812623,-0.363797,0.000000,-0.455297,-0.812623,-0.363797,0.606918,0.683427, --0.286151,-0.894562,-0.343331,0.000000,-0.286151,-0.894562,-0.343331,0.606016,0.512408, --0.390694,-0.901541,-0.185961,0.000000,-0.390694,-0.901541,-0.185961,0.352845,0.762112, --0.577350,-0.794654,-0.187593,0.000000,-0.577350,-0.794654,-0.187593,0.445347,0.772345, --0.390694,-0.901541,-0.185961,0.000000,-0.390694,-0.901541,-0.185961,0.352845,0.762112, --0.499999,-0.866026,0.000000,0.000000,-0.499999,-0.866026,0.000000,0.393083,0.683427, --0.669131,-0.743144,0.000000,0.000000,-0.669131,-0.743144,0.000000,0.500000,0.684243, --0.499999,-0.866026,0.000000,0.000000,-0.499999,-0.866026,0.000000,0.393083,0.683427, --0.580461,-0.798935,0.157379,0.000000,-0.580461,-0.798935,0.157379,0.447735,0.590447, --0.738585,-0.655845,0.156077,0.000000,-0.738585,-0.655845,0.156077,0.552265,0.590447, --0.580461,-0.798935,0.157379,0.000000,-0.580461,-0.798935,0.157379,0.447735,0.590447, --0.643075,-0.701637,0.306855,0.000000,-0.643075,-0.701637,0.306855,0.500000,0.511757, --0.455297,-0.812623,-0.363797,0.000000,-0.455297,-0.812623,-0.363797,0.606918,0.683427, --0.343074,-0.784354,-0.516806,0.000000,-0.343074,-0.784354,-0.516806,0.165435,0.666172, --0.286151,-0.894562,-0.343331,0.000000,-0.286151,-0.894562,-0.343331,0.606016,0.512408, --0.577350,-0.794654,-0.187593,0.000000,-0.577350,-0.794654,-0.187593,0.445347,0.772345, --0.455297,-0.812623,-0.363797,0.000000,-0.455297,-0.812623,-0.363797,0.606918,0.683427, --0.390694,-0.901541,-0.185961,0.000000,-0.390694,-0.901541,-0.185961,0.352845,0.762112, --0.577350,-0.794654,-0.187593,0.000000,-0.577350,-0.794654,-0.187593,0.445347,0.772345, --0.499999,-0.866026,0.000000,0.000000,-0.499999,-0.866026,0.000000,0.393083,0.683427, --0.669131,-0.743144,0.000000,0.000000,-0.669131,-0.743144,0.000000,0.500000,0.684243, --0.738585,-0.655845,0.156077,0.000000,-0.738585,-0.655845,0.156077,0.552265,0.590447, --0.669131,-0.743144,0.000000,0.000000,-0.669131,-0.743144,0.000000,0.500000,0.684243, --0.580461,-0.798935,0.157379,0.000000,-0.580461,-0.798935,0.157379,0.447735,0.590447, --0.174499,-0.853887,-0.490334,0.000000,-0.174499,-0.853887,-0.490334,0.131658,0.562217, -0.000000,-0.894427,-0.447214,0.000000,0.000000,-0.894427,-0.447214,0.848850,0.215669, --0.107846,-0.945626,-0.306855,0.000000,-0.107846,-0.945626,-0.306855,0.553923,0.437019, --0.286151,-0.894562,-0.343331,0.000000,-0.286151,-0.894562,-0.343331,0.606016,0.512408, --0.107846,-0.945626,-0.306855,0.000000,-0.107846,-0.945626,-0.306855,0.553923,0.437019, --0.212032,-0.964719,-0.156077,0.000000,-0.212032,-0.964719,-0.156077,0.265712,0.743874, --0.390694,-0.901541,-0.185961,0.000000,-0.390694,-0.901541,-0.185961,0.352845,0.762112, --0.212032,-0.964719,-0.156077,0.000000,-0.212032,-0.964719,-0.156077,0.265712,0.743874, --0.309017,-0.951056,0.000000,0.000000,-0.309017,-0.951056,0.000000,0.302245,0.668485, --0.499999,-0.866026,0.000000,0.000000,-0.499999,-0.866026,0.000000,0.393083,0.683427, --0.309017,-0.951056,0.000000,0.000000,-0.309017,-0.951056,0.000000,0.302245,0.668485, --0.395511,-0.905103,0.156077,0.000000,-0.395511,-0.905103,0.156077,0.345491,0.590447, --0.580461,-0.798935,0.157379,0.000000,-0.580461,-0.798935,0.157379,0.447735,0.590447, --0.395511,-0.905103,0.156077,0.000000,-0.395511,-0.905103,0.156077,0.345491,0.590447, --0.468576,-0.828418,0.306855,0.000000,-0.468576,-0.828418,0.306855,0.393984,0.512408, --0.643075,-0.701637,0.306855,0.000000,-0.643075,-0.701637,0.306855,0.500000,0.511757, --0.468576,-0.828418,0.306855,0.000000,-0.468576,-0.828418,0.306855,0.393984,0.512408, --0.525731,-0.723607,0.447214,0.000000,-0.525731,-0.723607,0.447214,0.321589,0.745561, --0.286151,-0.894562,-0.343331,0.000000,-0.286151,-0.894562,-0.343331,0.606016,0.512408, --0.174499,-0.853887,-0.490334,0.000000,-0.174499,-0.853887,-0.490334,0.131658,0.562217, --0.107846,-0.945626,-0.306855,0.000000,-0.107846,-0.945626,-0.306855,0.553923,0.437019, --0.390694,-0.901541,-0.185961,0.000000,-0.390694,-0.901541,-0.185961,0.352845,0.762112, --0.286151,-0.894562,-0.343331,0.000000,-0.286151,-0.894562,-0.343331,0.606016,0.512408, --0.212032,-0.964719,-0.156077,0.000000,-0.212032,-0.964719,-0.156077,0.265712,0.743874, --0.390694,-0.901541,-0.185961,0.000000,-0.390694,-0.901541,-0.185961,0.352845,0.762112, --0.309017,-0.951056,0.000000,0.000000,-0.309017,-0.951056,0.000000,0.302245,0.668485, --0.499999,-0.866026,0.000000,0.000000,-0.499999,-0.866026,0.000000,0.393083,0.683427, --0.499999,-0.866026,0.000000,0.000000,-0.499999,-0.866026,0.000000,0.393083,0.683427, --0.395511,-0.905103,0.156077,0.000000,-0.395511,-0.905103,0.156077,0.345491,0.590447, --0.580461,-0.798935,0.157379,0.000000,-0.580461,-0.798935,0.157379,0.447735,0.590447, --0.580461,-0.798935,0.157379,0.000000,-0.580461,-0.798935,0.157379,0.447735,0.590447, --0.468576,-0.828418,0.306855,0.000000,-0.468576,-0.828418,0.306855,0.393984,0.512408, --0.643075,-0.701637,0.306855,0.000000,-0.643075,-0.701637,0.306855,0.500000,0.511757, -0.932670,0.189647,0.306855,0.000000,0.932670,0.189647,0.306855,0.554653,0.258102, -0.850651,0.276393,0.447214,0.000000,0.850651,0.276393,0.447214,0.750000,0.581230, -0.866018,0.097907,0.490334,0.000000,0.866018,0.097907,0.490334,0.727648,0.480987, -0.939205,0.004289,0.343331,0.000000,0.939205,0.004289,0.343331,0.446077,0.437019, -0.866018,0.097907,0.490334,0.000000,0.866018,0.097907,0.490334,0.727648,0.480987, -0.851981,-0.083904,0.516806,0.000000,0.851981,-0.083904,0.516806,0.695347,0.381573, -0.983024,0.096460,0.156077,0.000000,0.983024,0.096460,0.156077,0.408260,0.332044, -0.932670,0.189647,0.306855,0.000000,0.932670,0.189647,0.306855,0.554653,0.258102, -0.939205,0.004289,0.343331,0.000000,0.939205,0.004289,0.343331,0.446077,0.437019, -0.939205,0.004289,0.343331,0.000000,0.939205,0.004289,0.343331,0.446077,0.437019, -0.932670,0.189647,0.306855,0.000000,0.932670,0.189647,0.306855,0.554653,0.258102, -0.866018,0.097907,0.490334,0.000000,0.866018,0.097907,0.490334,0.727648,0.480987, -0.913545,-0.181898,0.363797,0.000000,0.913545,-0.181898,0.363797,0.178463,0.743874, -0.851981,-0.083904,0.516806,0.000000,0.851981,-0.083904,0.516806,0.695347,0.381573, -0.809017,-0.262866,0.525731,0.000000,0.809017,-0.262866,0.525731,0.654508,0.287337, -0.978148,-0.092981,0.185961,0.000000,0.978148,-0.092981,0.185961,0.437019,0.697392, -0.939205,0.004289,0.343331,0.000000,0.939205,0.004289,0.343331,0.446077,0.437019, -0.913545,-0.181898,0.363797,0.000000,0.913545,-0.181898,0.363797,0.178463,0.743874, -1.000000,-0.000000,0.000000,0.000000,1.000000,-0.000000,0.000000,0.445347,0.130459, -0.983024,0.096460,0.156077,0.000000,0.983024,0.096460,0.156077,0.408260,0.332044, -0.978148,-0.092981,0.185961,0.000000,0.978148,-0.092981,0.185961,0.437019,0.697392, -0.913545,-0.181898,0.363797,0.000000,0.913545,-0.181898,0.363797,0.178463,0.743874, -0.939205,0.004289,0.343331,0.000000,0.939205,0.004289,0.343331,0.446077,0.437019, -0.851981,-0.083904,0.516806,0.000000,0.851981,-0.083904,0.516806,0.695347,0.381573, -0.978148,-0.092981,0.185961,0.000000,0.978148,-0.092981,0.185961,0.437019,0.697392, -0.983024,0.096460,0.156077,0.000000,0.983024,0.096460,0.156077,0.408260,0.332044, -0.939205,0.004289,0.343331,0.000000,0.939205,0.004289,0.343331,0.446077,0.437019, -0.738585,-0.432902,0.516806,0.000000,0.738585,-0.432902,0.516806,0.671537,0.555736, -0.845991,-0.389809,0.363797,0.000000,0.845991,-0.389809,0.363797,0.183922,0.772345, -0.809017,-0.262866,0.525731,0.000000,0.809017,-0.262866,0.525731,0.654508,0.287337, -0.845991,-0.389809,0.363797,0.000000,0.845991,-0.389809,0.363797,0.183922,0.772345, -0.934172,-0.303531,0.187593,0.000000,0.934172,-0.303531,0.187593,0.272352,0.772345, -0.913545,-0.181898,0.363797,0.000000,0.913545,-0.181898,0.363797,0.178463,0.743874, -0.978148,-0.207911,0.000000,0.000000,0.978148,-0.207911,0.000000,0.211325,0.684243, -0.978148,-0.092981,0.185961,0.000000,0.978148,-0.092981,0.185961,0.437019,0.697392, -0.934172,-0.303531,0.187593,0.000000,0.934172,-0.303531,0.187593,0.272352,0.772345, -0.978148,-0.207911,0.000000,0.000000,0.978148,-0.207911,0.000000,0.211325,0.684243, -0.983024,-0.096461,-0.156077,0.000000,0.983024,-0.096461,-0.156077,0.500000,0.196469, -1.000000,-0.000000,0.000000,0.000000,1.000000,-0.000000,0.000000,0.445347,0.130459, -0.845991,-0.389809,0.363797,0.000000,0.845991,-0.389809,0.363797,0.183922,0.772345, -0.913545,-0.181898,0.363797,0.000000,0.913545,-0.181898,0.363797,0.178463,0.743874, -0.809017,-0.262866,0.525731,0.000000,0.809017,-0.262866,0.525731,0.654508,0.287337, -0.934172,-0.303531,0.187593,0.000000,0.934172,-0.303531,0.187593,0.272352,0.772345, -0.978148,-0.092981,0.185961,0.000000,0.978148,-0.092981,0.185961,0.437019,0.697392, -0.913545,-0.181898,0.363797,0.000000,0.913545,-0.181898,0.363797,0.178463,0.743874, -0.978148,-0.207911,0.000000,0.000000,0.978148,-0.207911,0.000000,0.211325,0.684243, -1.000000,-0.000000,0.000000,0.000000,1.000000,-0.000000,0.000000,0.445347,0.130459, -0.978148,-0.092981,0.185961,0.000000,0.978148,-0.092981,0.185961,0.437019,0.697392, -0.643075,-0.588241,0.490334,0.000000,0.643075,-0.588241,0.490334,0.643075,0.453512, -0.757311,-0.555521,0.343331,0.000000,0.757311,-0.555521,0.343331,0.131657,0.683427, -0.738585,-0.432902,0.516806,0.000000,0.738585,-0.432902,0.516806,0.671537,0.555736, -0.757311,-0.555521,0.343331,0.000000,0.757311,-0.555521,0.343331,0.131657,0.683427, -0.845991,-0.499718,0.185961,0.000000,0.845991,-0.499718,0.185961,0.165435,0.590447, -0.845991,-0.389809,0.363797,0.000000,0.845991,-0.389809,0.363797,0.183922,0.772345, -0.845991,-0.499718,0.185961,0.000000,0.845991,-0.499718,0.185961,0.165435,0.590447, -0.913545,-0.406737,0.000000,0.000000,0.913545,-0.406737,0.000000,0.356925,0.762112, -0.934172,-0.303531,0.187593,0.000000,0.934172,-0.303531,0.187593,0.272352,0.772345, -0.913545,-0.406737,0.000000,0.000000,0.913545,-0.406737,0.000000,0.356925,0.762112, -0.939205,-0.305166,-0.157379,0.000000,0.939205,-0.305166,-0.157379,0.304653,0.683427, -0.978148,-0.207911,0.000000,0.000000,0.978148,-0.207911,0.000000,0.211325,0.684243, -0.939205,-0.305166,-0.157379,0.000000,0.939205,-0.305166,-0.157379,0.304653,0.683427, -0.932670,-0.189647,-0.306855,0.000000,0.932670,-0.189647,-0.306855,0.552265,0.277618, -0.983024,-0.096461,-0.156077,0.000000,0.983024,-0.096461,-0.156077,0.500000,0.196469, -0.757311,-0.555521,0.343331,0.000000,0.757311,-0.555521,0.343331,0.131657,0.683427, -0.845991,-0.389809,0.363797,0.000000,0.845991,-0.389809,0.363797,0.183922,0.772345, -0.738585,-0.432902,0.516806,0.000000,0.738585,-0.432902,0.516806,0.671537,0.555736, -0.845991,-0.499718,0.185961,0.000000,0.845991,-0.499718,0.185961,0.165435,0.590447, -0.934172,-0.303531,0.187593,0.000000,0.934172,-0.303531,0.187593,0.272352,0.772345, -0.845991,-0.389809,0.363797,0.000000,0.845991,-0.389809,0.363797,0.183922,0.772345, -0.913545,-0.406737,0.000000,0.000000,0.913545,-0.406737,0.000000,0.356925,0.762112, -0.978148,-0.207911,0.000000,0.000000,0.978148,-0.207911,0.000000,0.211325,0.684243, -0.934172,-0.303531,0.187593,0.000000,0.934172,-0.303531,0.187593,0.272352,0.772345, -0.939205,-0.305166,-0.157379,0.000000,0.939205,-0.305166,-0.157379,0.304653,0.683427, -0.983024,-0.096461,-0.156077,0.000000,0.983024,-0.096461,-0.156077,0.500000,0.196469, -0.978148,-0.207911,0.000000,0.000000,0.978148,-0.207911,0.000000,0.211325,0.684243, -0.525731,-0.723607,0.447214,0.000000,0.525731,-0.723607,0.447214,0.606016,0.354082, -0.643075,-0.701637,0.306855,0.000000,0.643075,-0.701637,0.306855,0.447735,0.277618, -0.643075,-0.588241,0.490334,0.000000,0.643075,-0.588241,0.490334,0.643075,0.453512, -0.643075,-0.701637,0.306855,0.000000,0.643075,-0.701637,0.306855,0.447735,0.277618, -0.738585,-0.655845,0.156077,0.000000,0.738585,-0.655845,0.156077,0.500000,0.349562, -0.757311,-0.555521,0.343331,0.000000,0.757311,-0.555521,0.343331,0.131657,0.683427, -0.738585,-0.655845,0.156077,0.000000,0.738585,-0.655845,0.156077,0.500000,0.349562, -0.809017,-0.587785,0.000000,0.000000,0.809017,-0.587785,0.000000,0.209769,0.268343, -0.845991,-0.499718,0.185961,0.000000,0.845991,-0.499718,0.185961,0.165435,0.590447, -0.809017,-0.587785,0.000000,0.000000,0.809017,-0.587785,0.000000,0.209769,0.268343, -0.851981,-0.499769,-0.156077,0.000000,0.851981,-0.499769,-0.156077,0.265712,0.288582, -0.913545,-0.406737,0.000000,0.000000,0.913545,-0.406737,0.000000,0.356925,0.762112, -0.866018,-0.394782,-0.306855,0.000000,0.866018,-0.394782,-0.306855,0.237134,0.366840, -0.939205,-0.305166,-0.157379,0.000000,0.939205,-0.305166,-0.157379,0.304653,0.683427, -0.851981,-0.499769,-0.156077,0.000000,0.851981,-0.499769,-0.156077,0.265712,0.288582, -0.866018,-0.394782,-0.306855,0.000000,0.866018,-0.394782,-0.306855,0.237134,0.366840, -0.850651,-0.276393,-0.447214,0.000000,0.850651,-0.276393,-0.447214,0.500000,0.960321, -0.932670,-0.189647,-0.306855,0.000000,0.932670,-0.189647,-0.306855,0.552265,0.277618, -0.643075,-0.701637,0.306855,0.000000,0.643075,-0.701637,0.306855,0.447735,0.277618, -0.757311,-0.555521,0.343331,0.000000,0.757311,-0.555521,0.343331,0.131657,0.683427, -0.643075,-0.588241,0.490334,0.000000,0.643075,-0.588241,0.490334,0.643075,0.453512, -0.738585,-0.655845,0.156077,0.000000,0.738585,-0.655845,0.156077,0.500000,0.349562, -0.845991,-0.499718,0.185961,0.000000,0.845991,-0.499718,0.185961,0.165435,0.590447, -0.757311,-0.555521,0.343331,0.000000,0.757311,-0.555521,0.343331,0.131657,0.683427, -0.809017,-0.587785,0.000000,0.000000,0.809017,-0.587785,0.000000,0.209769,0.268343, -0.913545,-0.406737,0.000000,0.000000,0.913545,-0.406737,0.000000,0.356925,0.762112, -0.845991,-0.499718,0.185961,0.000000,0.845991,-0.499718,0.185961,0.165435,0.590447, -0.851981,-0.499769,-0.156077,0.000000,0.851981,-0.499769,-0.156077,0.265712,0.288582, -0.939205,-0.305166,-0.157379,0.000000,0.939205,-0.305166,-0.157379,0.304653,0.683427, -0.913545,-0.406737,0.000000,0.000000,0.913545,-0.406737,0.000000,0.356925,0.762112, -0.866018,-0.394782,-0.306855,0.000000,0.866018,-0.394782,-0.306855,0.237134,0.366840, -0.932670,-0.189647,-0.306855,0.000000,0.932670,-0.189647,-0.306855,0.552265,0.277618, -0.939205,-0.305166,-0.157379,0.000000,0.939205,-0.305166,-0.157379,0.304653,0.683427, -0.107846,0.945626,0.306855,0.000000,0.107846,0.945626,0.306855,0.743874,0.302609, -0.000000,0.894427,0.447214,0.000000,0.000000,0.894427,0.447214,0.268343,0.250971, -0.174499,0.853887,0.490334,0.000000,0.174499,0.853887,0.490334,0.332044,0.283549, -0.286151,0.894562,0.343331,0.000000,0.286151,0.894562,0.343331,0.250001,0.590447, -0.174499,0.853887,0.490334,0.000000,0.174499,0.853887,0.490334,0.332044,0.283549, -0.343074,0.784354,0.516806,0.000000,0.343074,0.784354,0.516806,0.345280,0.205880, -0.212032,0.964719,0.156077,0.000000,0.212032,0.964719,0.156077,0.683427,0.174918, -0.107846,0.945626,0.306855,0.000000,0.107846,0.945626,0.306855,0.743874,0.302609, -0.286151,0.894562,0.343331,0.000000,0.286151,0.894562,0.343331,0.250001,0.590447, -0.286151,0.894562,0.343331,0.000000,0.286151,0.894562,0.343331,0.250001,0.590447, -0.107846,0.945626,0.306855,0.000000,0.107846,0.945626,0.306855,0.743874,0.302609, -0.174499,0.853887,0.490334,0.000000,0.174499,0.853887,0.490334,0.332044,0.283549, -0.455297,0.812623,0.363797,0.000000,0.455297,0.812623,0.363797,0.209769,0.511757, -0.343074,0.784354,0.516806,0.000000,0.343074,0.784354,0.516806,0.345280,0.205880, -0.500000,0.688191,0.525731,0.000000,0.500000,0.688191,0.525731,0.734288,0.288582, -0.390694,0.901541,0.185961,0.000000,0.390694,0.901541,0.185961,0.130708,0.512408, -0.286151,0.894562,0.343331,0.000000,0.286151,0.894562,0.343331,0.250001,0.590447, -0.455297,0.812623,0.363797,0.000000,0.455297,0.812623,0.363797,0.209769,0.511757, -0.309017,0.951056,0.000000,0.000000,0.309017,0.951056,0.000000,0.750000,0.590447, -0.212032,0.964719,0.156077,0.000000,0.212032,0.964719,0.156077,0.683427,0.174918, -0.390694,0.901541,0.185961,0.000000,0.390694,0.901541,0.185961,0.130708,0.512408, -0.455297,0.812623,0.363797,0.000000,0.455297,0.812623,0.363797,0.209769,0.511757, -0.286151,0.894562,0.343331,0.000000,0.286151,0.894562,0.343331,0.250001,0.590447, -0.343074,0.784354,0.516806,0.000000,0.343074,0.784354,0.516806,0.345280,0.205880, -0.390694,0.901541,0.185961,0.000000,0.390694,0.901541,0.185961,0.130708,0.512408, -0.212032,0.964719,0.156077,0.000000,0.212032,0.964719,0.156077,0.683427,0.174918, -0.286151,0.894562,0.343331,0.000000,0.286151,0.894562,0.343331,0.250001,0.590447, -0.639949,0.568662,0.516806,0.000000,0.639949,0.568662,0.516806,0.821537,0.345280, -0.632156,0.684127,0.363797,0.000000,0.632156,0.684127,0.363797,0.178463,0.437019, -0.500000,0.688191,0.525731,0.000000,0.500000,0.688191,0.525731,0.734288,0.288582, -0.632156,0.684127,0.363797,0.000000,0.632156,0.684127,0.363797,0.178463,0.437019, -0.577350,0.794654,0.187593,0.000000,0.577350,0.794654,0.187593,0.446077,0.743874, -0.455297,0.812623,0.363797,0.000000,0.455297,0.812623,0.363797,0.209769,0.511757, -0.499999,0.866026,0.000000,0.000000,0.499999,0.866026,0.000000,0.393984,0.668485, -0.390694,0.901541,0.185961,0.000000,0.390694,0.901541,0.185961,0.130708,0.512408, -0.577350,0.794654,0.187593,0.000000,0.577350,0.794654,0.187593,0.446077,0.743874, -0.499999,0.866026,0.000000,0.000000,0.499999,0.866026,0.000000,0.393984,0.668485, -0.395511,0.905103,-0.156077,0.000000,0.395511,0.905103,-0.156077,0.654508,0.590447, -0.309017,0.951056,0.000000,0.000000,0.309017,0.951056,0.000000,0.750000,0.590447, -0.632156,0.684127,0.363797,0.000000,0.632156,0.684127,0.363797,0.178463,0.437019, -0.455297,0.812623,0.363797,0.000000,0.455297,0.812623,0.363797,0.209769,0.511757, -0.500000,0.688191,0.525731,0.000000,0.500000,0.688191,0.525731,0.734288,0.288582, -0.577350,0.794654,0.187593,0.000000,0.577350,0.794654,0.187593,0.446077,0.743874, -0.390694,0.901541,0.185961,0.000000,0.390694,0.901541,0.185961,0.130708,0.512408, -0.455297,0.812623,0.363797,0.000000,0.455297,0.812623,0.363797,0.209769,0.511757, -0.499999,0.866026,0.000000,0.000000,0.499999,0.866026,0.000000,0.393984,0.668485, -0.309017,0.951056,0.000000,0.000000,0.309017,0.951056,0.000000,0.750000,0.590447, -0.390694,0.901541,0.185961,0.000000,0.390694,0.901541,0.185961,0.130708,0.512408, -0.758172,0.429824,0.490334,0.000000,0.758172,0.429824,0.490334,0.762866,0.366840, -0.762354,0.548581,0.343331,0.000000,0.762354,0.548581,0.343331,0.302244,0.512408, -0.639949,0.568662,0.516806,0.000000,0.639949,0.568662,0.516806,0.821537,0.345280, -0.762354,0.548581,0.343331,0.000000,0.762354,0.548581,0.343331,0.302244,0.512408, -0.736686,0.650164,0.185961,0.000000,0.736686,0.650164,0.185961,0.265712,0.437019, -0.632156,0.684127,0.363797,0.000000,0.632156,0.684127,0.363797,0.178463,0.437019, -0.736686,0.650164,0.185961,0.000000,0.736686,0.650164,0.185961,0.265712,0.437019, -0.669131,0.743144,0.000000,0.000000,0.669131,0.743144,0.000000,0.418781,0.502145, -0.577350,0.794654,0.187593,0.000000,0.577350,0.794654,0.187593,0.446077,0.743874, -0.669131,0.743144,0.000000,0.000000,0.669131,0.743144,0.000000,0.418781,0.502145, -0.580461,0.798935,-0.157379,0.000000,0.580461,0.798935,-0.157379,0.408548,0.409051, -0.499999,0.866026,0.000000,0.000000,0.499999,0.866026,0.000000,0.393984,0.668485, -0.580461,0.798935,-0.157379,0.000000,0.580461,0.798935,-0.157379,0.408548,0.409051, -0.468576,0.828418,-0.306855,0.000000,0.468576,0.828418,-0.306855,0.727648,0.772345, -0.395511,0.905103,-0.156077,0.000000,0.395511,0.905103,-0.156077,0.654508,0.590447, -0.762354,0.548581,0.343331,0.000000,0.762354,0.548581,0.343331,0.302244,0.512408, -0.632156,0.684127,0.363797,0.000000,0.632156,0.684127,0.363797,0.178463,0.437019, -0.639949,0.568662,0.516806,0.000000,0.639949,0.568662,0.516806,0.821537,0.345280, -0.736686,0.650164,0.185961,0.000000,0.736686,0.650164,0.185961,0.265712,0.437019, -0.577350,0.794654,0.187593,0.000000,0.577350,0.794654,0.187593,0.446077,0.743874, -0.632156,0.684127,0.363797,0.000000,0.632156,0.684127,0.363797,0.178463,0.437019, -0.669131,0.743144,0.000000,0.000000,0.669131,0.743144,0.000000,0.418781,0.502145, -0.499999,0.866026,0.000000,0.000000,0.499999,0.866026,0.000000,0.393984,0.668485, -0.577350,0.794654,0.187593,0.000000,0.577350,0.794654,0.187593,0.446077,0.743874, -0.580461,0.798935,-0.157379,0.000000,0.580461,0.798935,-0.157379,0.408548,0.409051, -0.395511,0.905103,-0.156077,0.000000,0.395511,0.905103,-0.156077,0.654508,0.590447, -0.499999,0.866026,0.000000,0.000000,0.499999,0.866026,0.000000,0.393984,0.668485, -0.850651,0.276393,0.447214,0.000000,0.850651,0.276393,0.447214,0.750000,0.581230, -0.866018,0.394782,0.306855,0.000000,0.866018,0.394782,0.306855,0.606016,0.668485, -0.758172,0.429824,0.490334,0.000000,0.758172,0.429824,0.490334,0.762866,0.366840, -0.866018,0.394782,0.306855,0.000000,0.866018,0.394782,0.306855,0.606016,0.668485, -0.851981,0.499768,0.156077,0.000000,0.851981,0.499768,0.156077,0.643075,0.762112, -0.762354,0.548581,0.343331,0.000000,0.762354,0.548581,0.343331,0.302244,0.512408, -0.851981,0.499768,0.156077,0.000000,0.851981,0.499768,0.156077,0.643075,0.762112, -0.809017,0.587785,0.000000,0.000000,0.809017,0.587785,0.000000,0.553923,0.743874, -0.736686,0.650164,0.185961,0.000000,0.736686,0.650164,0.185961,0.265712,0.437019, -0.809017,0.587785,0.000000,0.000000,0.809017,0.587785,0.000000,0.553923,0.743874, -0.738585,0.655845,-0.156077,0.000000,0.738585,0.655845,-0.156077,0.647155,0.268343, -0.669131,0.743144,0.000000,0.000000,0.669131,0.743144,0.000000,0.418781,0.502145, -0.643075,0.701637,-0.306855,0.000000,0.643075,0.701637,-0.306855,0.680365,0.345280, -0.580461,0.798935,-0.157379,0.000000,0.580461,0.798935,-0.157379,0.408548,0.409051, -0.738585,0.655845,-0.156077,0.000000,0.738585,0.655845,-0.156077,0.647155,0.268343, -0.643075,0.701637,-0.306855,0.000000,0.643075,0.701637,-0.306855,0.680365,0.345280, -0.525731,0.723607,-0.447214,0.000000,0.525731,0.723607,-0.447214,0.788675,0.593796, -0.468576,0.828418,-0.306855,0.000000,0.468576,0.828418,-0.306855,0.727648,0.772345, -0.866018,0.394782,0.306855,0.000000,0.866018,0.394782,0.306855,0.606016,0.668485, -0.762354,0.548581,0.343331,0.000000,0.762354,0.548581,0.343331,0.302244,0.512408, -0.758172,0.429824,0.490334,0.000000,0.758172,0.429824,0.490334,0.762866,0.366840, -0.851981,0.499768,0.156077,0.000000,0.851981,0.499768,0.156077,0.643075,0.762112, -0.736686,0.650164,0.185961,0.000000,0.736686,0.650164,0.185961,0.265712,0.437019, -0.762354,0.548581,0.343331,0.000000,0.762354,0.548581,0.343331,0.302244,0.512408, -0.809017,0.587785,0.000000,0.000000,0.809017,0.587785,0.000000,0.553923,0.743874, -0.669131,0.743144,0.000000,0.000000,0.669131,0.743144,0.000000,0.418781,0.502145, -0.736686,0.650164,0.185961,0.000000,0.736686,0.650164,0.185961,0.265712,0.437019, -0.738585,0.655845,-0.156077,0.000000,0.738585,0.655845,-0.156077,0.647155,0.268343, -0.580461,0.798935,-0.157379,0.000000,0.580461,0.798935,-0.157379,0.408548,0.409051, -0.669131,0.743144,0.000000,0.000000,0.669131,0.743144,0.000000,0.418781,0.502145, -0.643075,0.701637,-0.306855,0.000000,0.643075,0.701637,-0.306855,0.680365,0.345280, -0.468576,0.828418,-0.306855,0.000000,0.468576,0.828418,-0.306855,0.727648,0.772345, -0.580461,0.798935,-0.157379,0.000000,0.580461,0.798935,-0.157379,0.408548,0.409051, --0.866018,0.394783,0.306855,0.000000,-0.866018,0.394783,0.306855,0.511757,0.652583, --0.850651,0.276393,0.447214,0.000000,-0.850651,0.276393,0.447214,0.588426,0.872062, --0.758172,0.429824,0.490334,0.000000,-0.758172,0.429824,0.490334,0.672996,0.831089, --0.762354,0.548581,0.343331,0.000000,-0.762354,0.548581,0.343331,0.497466,0.453510, --0.758172,0.429824,0.490334,0.000000,-0.758172,0.429824,0.490334,0.672996,0.831089, --0.639949,0.568662,0.516806,0.000000,-0.639949,0.568662,0.516806,0.761425,0.766840, --0.851981,0.499769,0.156077,0.000000,-0.851981,0.499769,0.156077,0.590447,0.603956, --0.866018,0.394783,0.306855,0.000000,-0.866018,0.394783,0.306855,0.511757,0.652583, --0.762354,0.548581,0.343331,0.000000,-0.762354,0.548581,0.343331,0.497466,0.453510, --0.762354,0.548581,0.343331,0.000000,-0.762354,0.548581,0.343331,0.497466,0.453510, --0.866018,0.394783,0.306855,0.000000,-0.866018,0.394783,0.306855,0.511757,0.652583, --0.758172,0.429824,0.490334,0.000000,-0.758172,0.429824,0.490334,0.672996,0.831089, --0.632156,0.684127,0.363797,0.000000,-0.632156,0.684127,0.363797,0.408548,0.305095, --0.639949,0.568662,0.516806,0.000000,-0.639949,0.568662,0.516806,0.761425,0.766840, --0.500000,0.688191,0.525731,0.000000,-0.500000,0.688191,0.525731,0.826527,0.699071, --0.736685,0.650164,0.185961,0.000000,-0.736685,0.650164,0.185961,0.496650,0.348235, --0.762354,0.548581,0.343331,0.000000,-0.762354,0.548581,0.343331,0.497466,0.453510, --0.632156,0.684127,0.363797,0.000000,-0.632156,0.684127,0.363797,0.408548,0.305095, --0.809017,0.587785,0.000000,0.000000,-0.809017,0.587785,0.000000,0.683427,0.546490, --0.851981,0.499769,0.156077,0.000000,-0.851981,0.499769,0.156077,0.590447,0.603956, --0.736685,0.650164,0.185961,0.000000,-0.736685,0.650164,0.185961,0.496650,0.348235, --0.632156,0.684127,0.363797,0.000000,-0.632156,0.684127,0.363797,0.408548,0.305095, --0.762354,0.548581,0.343331,0.000000,-0.762354,0.548581,0.343331,0.497466,0.453510, --0.639949,0.568662,0.516806,0.000000,-0.639949,0.568662,0.516806,0.761425,0.766840, --0.736685,0.650164,0.185961,0.000000,-0.736685,0.650164,0.185961,0.496650,0.348235, --0.851981,0.499769,0.156077,0.000000,-0.851981,0.499769,0.156077,0.590447,0.603956, --0.762354,0.548581,0.343331,0.000000,-0.762354,0.548581,0.343331,0.497466,0.453510, --0.343074,0.784354,0.516806,0.000000,-0.343074,0.784354,0.516806,0.268343,0.699071, --0.455297,0.812623,0.363797,0.000000,-0.455297,0.812623,0.363797,0.590447,0.396044, --0.500000,0.688191,0.525731,0.000000,-0.500000,0.688191,0.525731,0.826527,0.699071, --0.577350,0.794655,0.187593,0.000000,-0.577350,0.794655,0.187593,0.418781,0.222239, --0.632156,0.684127,0.363797,0.000000,-0.632156,0.684127,0.363797,0.408548,0.305095, --0.455297,0.812623,0.363797,0.000000,-0.455297,0.812623,0.363797,0.590447,0.396044, --0.669131,0.743144,0.000000,0.000000,-0.669131,0.743144,0.000000,0.497466,0.250141, --0.736685,0.650164,0.185961,0.000000,-0.736685,0.650164,0.185961,0.496650,0.348235, --0.577350,0.794655,0.187593,0.000000,-0.577350,0.794655,0.187593,0.418781,0.222239, --0.738585,0.655845,-0.156077,0.000000,-0.738585,0.655845,-0.156077,0.762112,0.497855, --0.809017,0.587785,0.000000,0.000000,-0.809017,0.587785,0.000000,0.683427,0.546490, --0.669131,0.743144,0.000000,0.000000,-0.669131,0.743144,0.000000,0.497466,0.250141, --0.455297,0.812623,0.363797,0.000000,-0.455297,0.812623,0.363797,0.590447,0.396044, --0.632156,0.684127,0.363797,0.000000,-0.632156,0.684127,0.363797,0.408548,0.305095, --0.500000,0.688191,0.525731,0.000000,-0.500000,0.688191,0.525731,0.826527,0.699071, --0.577350,0.794655,0.187593,0.000000,-0.577350,0.794655,0.187593,0.418781,0.222239, --0.736685,0.650164,0.185961,0.000000,-0.736685,0.650164,0.185961,0.496650,0.348235, --0.632156,0.684127,0.363797,0.000000,-0.632156,0.684127,0.363797,0.408548,0.305095, --0.669131,0.743144,0.000000,0.000000,-0.669131,0.743144,0.000000,0.497466,0.250141, --0.809017,0.587785,0.000000,0.000000,-0.809017,0.587785,0.000000,0.683427,0.546490, --0.736685,0.650164,0.185961,0.000000,-0.736685,0.650164,0.185961,0.496650,0.348235, --0.174499,0.853887,0.490334,0.000000,-0.174499,0.853887,0.490334,0.500000,0.836442, --0.286151,0.894562,0.343331,0.000000,-0.286151,0.894562,0.343331,0.590447,0.296632, --0.343074,0.784354,0.516806,0.000000,-0.343074,0.784354,0.516806,0.268343,0.699071, --0.286151,0.894562,0.343331,0.000000,-0.286151,0.894562,0.343331,0.590447,0.296632, --0.390694,0.901541,0.185961,0.000000,-0.390694,0.901541,0.185961,0.669136,0.347417, --0.455297,0.812623,0.363797,0.000000,-0.455297,0.812623,0.363797,0.590447,0.396044, --0.390694,0.901541,0.185961,0.000000,-0.390694,0.901541,0.185961,0.669136,0.347417, --0.499999,0.866026,0.000000,0.000000,-0.499999,0.866026,0.000000,0.437019,0.149181, --0.577350,0.794655,0.187593,0.000000,-0.577350,0.794655,0.187593,0.418781,0.222239, --0.580460,0.798935,-0.157379,0.000000,-0.580460,0.798935,-0.157379,0.643075,0.418781, --0.669131,0.743144,0.000000,0.000000,-0.669131,0.743144,0.000000,0.497466,0.250141, --0.499999,0.866026,0.000000,0.000000,-0.499999,0.866026,0.000000,0.437019,0.149181, --0.580460,0.798935,-0.157379,0.000000,-0.580460,0.798935,-0.157379,0.643075,0.418781, --0.643075,0.701637,-0.306855,0.000000,-0.643075,0.701637,-0.306855,0.821537,0.437019, --0.738585,0.655845,-0.156077,0.000000,-0.738585,0.655845,-0.156077,0.762112,0.497855, --0.286151,0.894562,0.343331,0.000000,-0.286151,0.894562,0.343331,0.590447,0.296632, --0.455297,0.812623,0.363797,0.000000,-0.455297,0.812623,0.363797,0.590447,0.396044, --0.343074,0.784354,0.516806,0.000000,-0.343074,0.784354,0.516806,0.268343,0.699071, --0.390694,0.901541,0.185961,0.000000,-0.390694,0.901541,0.185961,0.669136,0.347417, --0.577350,0.794655,0.187593,0.000000,-0.577350,0.794655,0.187593,0.418781,0.222239, --0.455297,0.812623,0.363797,0.000000,-0.455297,0.812623,0.363797,0.590447,0.396044, --0.499999,0.866026,0.000000,0.000000,-0.499999,0.866026,0.000000,0.437019,0.149181, --0.669131,0.743144,0.000000,0.000000,-0.669131,0.743144,0.000000,0.497466,0.250141, --0.577350,0.794655,0.187593,0.000000,-0.577350,0.794655,0.187593,0.418781,0.222239, --0.580460,0.798935,-0.157379,0.000000,-0.580460,0.798935,-0.157379,0.643075,0.418781, --0.738585,0.655845,-0.156077,0.000000,-0.738585,0.655845,-0.156077,0.762112,0.497855, --0.669131,0.743144,0.000000,0.000000,-0.669131,0.743144,0.000000,0.497466,0.250141, -0.000000,0.894427,0.447214,0.000000,0.000000,0.894427,0.447214,0.268343,0.250971, --0.107846,0.945626,0.306855,0.000000,-0.107846,0.945626,0.306855,0.869292,0.512408, --0.174499,0.853887,0.490334,0.000000,-0.174499,0.853887,0.490334,0.500000,0.836442, --0.107846,0.945626,0.306855,0.000000,-0.107846,0.945626,0.306855,0.869292,0.512408, --0.212031,0.964719,0.156077,0.000000,-0.212031,0.964719,0.156077,0.512408,0.172078, --0.286151,0.894562,0.343331,0.000000,-0.286151,0.894562,0.343331,0.590447,0.296632, --0.212031,0.964719,0.156077,0.000000,-0.212031,0.964719,0.156077,0.512408,0.172078, --0.309017,0.951057,0.000000,0.000000,-0.309017,0.951057,0.000000,0.590447,0.128428, --0.390694,0.901541,0.185961,0.000000,-0.390694,0.901541,0.185961,0.669136,0.347417, --0.395510,0.905103,-0.156077,0.000000,-0.395510,0.905103,-0.156077,0.590447,0.206107, --0.499999,0.866026,0.000000,0.000000,-0.499999,0.866026,0.000000,0.437019,0.149181, --0.309017,0.951057,0.000000,0.000000,-0.309017,0.951057,0.000000,0.590447,0.128428, --0.468576,0.828418,-0.306855,0.000000,-0.468576,0.828418,-0.306855,0.668485,0.250116, --0.580460,0.798935,-0.157379,0.000000,-0.580460,0.798935,-0.157379,0.643075,0.418781, --0.395510,0.905103,-0.156077,0.000000,-0.395510,0.905103,-0.156077,0.590447,0.206107, --0.525731,0.723607,-0.447214,0.000000,-0.525731,0.723607,-0.447214,0.446077,0.574219, --0.643075,0.701637,-0.306855,0.000000,-0.643075,0.701637,-0.306855,0.821537,0.437019, --0.468576,0.828418,-0.306855,0.000000,-0.468576,0.828418,-0.306855,0.668485,0.250116, --0.107846,0.945626,0.306855,0.000000,-0.107846,0.945626,0.306855,0.869292,0.512408, --0.286151,0.894562,0.343331,0.000000,-0.286151,0.894562,0.343331,0.590447,0.296632, --0.174499,0.853887,0.490334,0.000000,-0.174499,0.853887,0.490334,0.500000,0.836442, --0.212031,0.964719,0.156077,0.000000,-0.212031,0.964719,0.156077,0.512408,0.172078, --0.390694,0.901541,0.185961,0.000000,-0.390694,0.901541,0.185961,0.669136,0.347417, --0.286151,0.894562,0.343331,0.000000,-0.286151,0.894562,0.343331,0.590447,0.296632, --0.309017,0.951057,0.000000,0.000000,-0.309017,0.951057,0.000000,0.590447,0.128428, --0.499999,0.866026,0.000000,0.000000,-0.499999,0.866026,0.000000,0.437019,0.149181, --0.390694,0.901541,0.185961,0.000000,-0.390694,0.901541,0.185961,0.669136,0.347417, --0.395510,0.905103,-0.156077,0.000000,-0.395510,0.905103,-0.156077,0.590447,0.206107, --0.580460,0.798935,-0.157379,0.000000,-0.580460,0.798935,-0.157379,0.643075,0.418781, --0.499999,0.866026,0.000000,0.000000,-0.499999,0.866026,0.000000,0.437019,0.149181, --0.468576,0.828418,-0.306855,0.000000,-0.468576,0.828418,-0.306855,0.668485,0.250116, --0.643075,0.701637,-0.306855,0.000000,-0.643075,0.701637,-0.306855,0.821537,0.437019, --0.580460,0.798935,-0.157379,0.000000,-0.580460,0.798935,-0.157379,0.643075,0.418781, --0.643075,-0.701637,0.306855,0.000000,-0.643075,-0.701637,0.306855,0.500000,0.511757, --0.525731,-0.723607,0.447214,0.000000,-0.525731,-0.723607,0.447214,0.321589,0.745561, --0.643075,-0.588241,0.490334,0.000000,-0.643075,-0.588241,0.490334,0.411570,0.803612, --0.757312,-0.555521,0.343331,0.000000,-0.757312,-0.555521,0.343331,0.727648,0.408548, --0.643075,-0.588241,0.490334,0.000000,-0.643075,-0.588241,0.490334,0.411570,0.803612, --0.738585,-0.432902,0.516806,0.000000,-0.738585,-0.432902,0.516806,0.250000,0.581230, --0.738585,-0.655845,0.156077,0.000000,-0.738585,-0.655845,0.156077,0.552265,0.590447, --0.643075,-0.701637,0.306855,0.000000,-0.643075,-0.701637,0.306855,0.500000,0.511757, --0.757312,-0.555521,0.343331,0.000000,-0.757312,-0.555521,0.343331,0.727648,0.408548, --0.757312,-0.555521,0.343331,0.000000,-0.757312,-0.555521,0.343331,0.727648,0.408548, --0.643075,-0.701637,0.306855,0.000000,-0.643075,-0.701637,0.306855,0.500000,0.511757, --0.643075,-0.588241,0.490334,0.000000,-0.643075,-0.588241,0.490334,0.411570,0.803612, --0.845991,-0.389809,0.363797,0.000000,-0.845991,-0.389809,0.363797,0.695347,0.497466, --0.738585,-0.432902,0.516806,0.000000,-0.738585,-0.432902,0.516806,0.250000,0.581230, --0.809017,-0.262865,0.525731,0.000000,-0.809017,-0.262865,0.525731,0.327004,0.649190, --0.845991,-0.499718,0.185961,0.000000,-0.845991,-0.499718,0.185961,0.816078,0.408548, --0.757312,-0.555521,0.343331,0.000000,-0.757312,-0.555521,0.343331,0.727648,0.408548, --0.845991,-0.389809,0.363797,0.000000,-0.845991,-0.389809,0.363797,0.695347,0.497466, --0.809017,-0.587785,0.000000,0.000000,-0.809017,-0.587785,0.000000,0.554653,0.772345, --0.738585,-0.655845,0.156077,0.000000,-0.738585,-0.655845,0.156077,0.552265,0.590447, --0.845991,-0.499718,0.185961,0.000000,-0.845991,-0.499718,0.185961,0.816078,0.408548, --0.845991,-0.389809,0.363797,0.000000,-0.845991,-0.389809,0.363797,0.695347,0.497466, --0.757312,-0.555521,0.343331,0.000000,-0.757312,-0.555521,0.343331,0.727648,0.408548, --0.738585,-0.432902,0.516806,0.000000,-0.738585,-0.432902,0.516806,0.250000,0.581230, --0.845991,-0.499718,0.185961,0.000000,-0.845991,-0.499718,0.185961,0.816078,0.408548, --0.738585,-0.655845,0.156077,0.000000,-0.738585,-0.655845,0.156077,0.552265,0.590447, --0.757312,-0.555521,0.343331,0.000000,-0.757312,-0.555521,0.343331,0.727648,0.408548, --0.851981,-0.083904,0.516806,0.000000,-0.851981,-0.083904,0.516806,0.411570,0.710631, --0.913545,-0.181898,0.363797,0.000000,-0.913545,-0.181898,0.363797,0.788675,0.496650, --0.809017,-0.262865,0.525731,0.000000,-0.809017,-0.262865,0.525731,0.327004,0.649190, --0.934172,-0.303531,0.187593,0.000000,-0.934172,-0.303531,0.187593,0.418781,0.774291, --0.845991,-0.389809,0.363797,0.000000,-0.845991,-0.389809,0.363797,0.695347,0.497466, --0.913545,-0.181898,0.363797,0.000000,-0.913545,-0.181898,0.363797,0.788675,0.496650, --0.913545,-0.406737,0.000000,0.000000,-0.913545,-0.406737,0.000000,0.497466,0.825082, --0.845991,-0.499718,0.185961,0.000000,-0.845991,-0.499718,0.185961,0.816078,0.408548, --0.934172,-0.303531,0.187593,0.000000,-0.934172,-0.303531,0.187593,0.418781,0.774291, --0.851981,-0.499768,-0.156077,0.000000,-0.851981,-0.499768,-0.156077,0.734288,0.743874, --0.809017,-0.587785,0.000000,0.000000,-0.809017,-0.587785,0.000000,0.554653,0.772345, --0.913545,-0.406737,0.000000,0.000000,-0.913545,-0.406737,0.000000,0.497466,0.825082, --0.913545,-0.181898,0.363797,0.000000,-0.913545,-0.181898,0.363797,0.788675,0.496650, --0.845991,-0.389809,0.363797,0.000000,-0.845991,-0.389809,0.363797,0.695347,0.497466, --0.809017,-0.262865,0.525731,0.000000,-0.809017,-0.262865,0.525731,0.327004,0.649190, --0.934172,-0.303531,0.187593,0.000000,-0.934172,-0.303531,0.187593,0.418781,0.774291, --0.845991,-0.499718,0.185961,0.000000,-0.845991,-0.499718,0.185961,0.816078,0.408548, --0.845991,-0.389809,0.363797,0.000000,-0.845991,-0.389809,0.363797,0.695347,0.497466, --0.913545,-0.406737,0.000000,0.000000,-0.913545,-0.406737,0.000000,0.497466,0.825082, --0.809017,-0.587785,0.000000,0.000000,-0.809017,-0.587785,0.000000,0.554653,0.772345, --0.845991,-0.499718,0.185961,0.000000,-0.845991,-0.499718,0.185961,0.816078,0.408548, --0.866018,0.097907,0.490334,0.000000,-0.866018,0.097907,0.490334,0.328463,0.555736, --0.939205,0.004289,0.343331,0.000000,-0.939205,0.004289,0.343331,0.408548,0.842063, --0.851981,-0.083904,0.516806,0.000000,-0.851981,-0.083904,0.516806,0.411570,0.710631, --0.939205,0.004289,0.343331,0.000000,-0.939205,0.004289,0.343331,0.408548,0.842063, --0.978148,-0.092980,0.185961,0.000000,-0.978148,-0.092980,0.185961,0.868343,0.497466, --0.913545,-0.181898,0.363797,0.000000,-0.913545,-0.181898,0.363797,0.788675,0.496650, --0.978148,-0.092980,0.185961,0.000000,-0.978148,-0.092980,0.185961,0.868343,0.497466, --0.978148,-0.207911,0.000000,0.000000,-0.978148,-0.207911,0.000000,0.790231,0.669136, --0.934172,-0.303531,0.187593,0.000000,-0.934172,-0.303531,0.187593,0.418781,0.774291, --0.939205,-0.305166,-0.157379,0.000000,-0.939205,-0.305166,-0.157379,0.590447,0.871572, --0.913545,-0.406737,0.000000,0.000000,-0.913545,-0.406737,0.000000,0.497466,0.825082, --0.978148,-0.207911,0.000000,0.000000,-0.978148,-0.207911,0.000000,0.790231,0.669136, --0.939205,-0.305166,-0.157379,0.000000,-0.939205,-0.305166,-0.157379,0.590447,0.871572, --0.866018,-0.394782,-0.306855,0.000000,-0.866018,-0.394782,-0.306855,0.512408,0.749884, --0.851981,-0.499768,-0.156077,0.000000,-0.851981,-0.499768,-0.156077,0.734288,0.743874, --0.939205,0.004289,0.343331,0.000000,-0.939205,0.004289,0.343331,0.408548,0.842063, --0.913545,-0.181898,0.363797,0.000000,-0.913545,-0.181898,0.363797,0.788675,0.496650, --0.851981,-0.083904,0.516806,0.000000,-0.851981,-0.083904,0.516806,0.411570,0.710631, --0.978148,-0.092980,0.185961,0.000000,-0.978148,-0.092980,0.185961,0.868343,0.497466, --0.934172,-0.303531,0.187593,0.000000,-0.934172,-0.303531,0.187593,0.418781,0.774291, --0.913545,-0.181898,0.363797,0.000000,-0.913545,-0.181898,0.363797,0.788675,0.496650, --0.978148,-0.207911,0.000000,0.000000,-0.978148,-0.207911,0.000000,0.790231,0.669136, --0.913545,-0.406737,0.000000,0.000000,-0.913545,-0.406737,0.000000,0.497466,0.825082, --0.934172,-0.303531,0.187593,0.000000,-0.934172,-0.303531,0.187593,0.418781,0.774291, --0.939205,-0.305166,-0.157379,0.000000,-0.939205,-0.305166,-0.157379,0.590447,0.871572, --0.851981,-0.499768,-0.156077,0.000000,-0.851981,-0.499768,-0.156077,0.734288,0.743874, --0.913545,-0.406737,0.000000,0.000000,-0.913545,-0.406737,0.000000,0.497466,0.825082, --0.850651,0.276393,0.447214,0.000000,-0.850651,0.276393,0.447214,0.588426,0.872062, --0.932670,0.189647,0.306855,0.000000,-0.932670,0.189647,0.306855,0.590447,0.793893, --0.866018,0.097907,0.490334,0.000000,-0.866018,0.097907,0.490334,0.328463,0.555736, --0.932670,0.189647,0.306855,0.000000,-0.932670,0.189647,0.306855,0.590447,0.793893, --0.983024,0.096461,0.156077,0.000000,-0.983024,0.096461,0.156077,0.668485,0.827922, --0.939205,0.004289,0.343331,0.000000,-0.939205,0.004289,0.343331,0.408548,0.842063, --0.983024,0.096461,0.156077,0.000000,-0.983024,0.096461,0.156077,0.668485,0.827922, --1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.000000,0.743874,0.850819, --0.978148,-0.092980,0.185961,0.000000,-0.978148,-0.092980,0.185961,0.868343,0.497466, --0.983024,-0.096460,-0.156077,0.000000,-0.983024,-0.096460,-0.156077,0.821537,0.743874, --0.978148,-0.207911,0.000000,0.000000,-0.978148,-0.207911,0.000000,0.790231,0.669136, --1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.000000,0.743874,0.850819, --0.932670,-0.189647,-0.306855,0.000000,-0.932670,-0.189647,-0.306855,0.437019,0.594823, --0.939205,-0.305166,-0.157379,0.000000,-0.939205,-0.305166,-0.157379,0.590447,0.871572, --0.983024,-0.096460,-0.156077,0.000000,-0.983024,-0.096460,-0.156077,0.821537,0.743874, --0.850651,-0.276393,-0.447214,0.000000,-0.850651,-0.276393,-0.447214,0.445347,0.922791, --0.866018,-0.394782,-0.306855,0.000000,-0.866018,-0.394782,-0.306855,0.512408,0.749884, --0.932670,-0.189647,-0.306855,0.000000,-0.932670,-0.189647,-0.306855,0.437019,0.594823, --0.932670,0.189647,0.306855,0.000000,-0.932670,0.189647,0.306855,0.590447,0.793893, --0.939205,0.004289,0.343331,0.000000,-0.939205,0.004289,0.343331,0.408548,0.842063, --0.866018,0.097907,0.490334,0.000000,-0.866018,0.097907,0.490334,0.328463,0.555736, --0.983024,0.096461,0.156077,0.000000,-0.983024,0.096461,0.156077,0.668485,0.827922, --0.978148,-0.092980,0.185961,0.000000,-0.978148,-0.092980,0.185961,0.868343,0.497466, --0.939205,0.004289,0.343331,0.000000,-0.939205,0.004289,0.343331,0.408548,0.842063, --1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.000000,0.743874,0.850819, --0.978148,-0.207911,0.000000,0.000000,-0.978148,-0.207911,0.000000,0.790231,0.669136, --0.978148,-0.092980,0.185961,0.000000,-0.978148,-0.092980,0.185961,0.868343,0.497466, --0.983024,-0.096460,-0.156077,0.000000,-0.983024,-0.096460,-0.156077,0.821537,0.743874, --0.939205,-0.305166,-0.157379,0.000000,-0.939205,-0.305166,-0.157379,0.590447,0.871572, --0.978148,-0.207911,0.000000,0.000000,-0.978148,-0.207911,0.000000,0.790231,0.669136, --0.932670,-0.189647,-0.306855,0.000000,-0.932670,-0.189647,-0.306855,0.437019,0.594823, --0.866018,-0.394782,-0.306855,0.000000,-0.866018,-0.394782,-0.306855,0.512408,0.749884, --0.939205,-0.305166,-0.157379,0.000000,-0.939205,-0.305166,-0.157379,0.590447,0.871572, -0.468576,-0.828418,0.306855,0.000000,0.468576,-0.828418,0.306855,0.178463,0.345280, -0.525731,-0.723607,0.447214,0.000000,0.525731,-0.723607,0.447214,0.606016,0.354082, -0.360730,-0.793377,0.490334,0.000000,0.360730,-0.793377,0.490334,0.446077,0.425781, -0.294309,-0.891911,0.343331,0.000000,0.294309,-0.891911,0.343331,0.869292,0.668485, -0.360730,-0.793377,0.490334,0.000000,0.360730,-0.793377,0.490334,0.446077,0.425781, -0.183479,-0.836210,0.516806,0.000000,0.183479,-0.836210,0.516806,0.258102,0.766841, -0.395510,-0.905103,0.156077,0.000000,0.395510,-0.905103,0.156077,0.131657,0.437784, -0.468576,-0.828418,0.306855,0.000000,0.468576,-0.828418,0.306855,0.178463,0.345280, -0.294309,-0.891911,0.343331,0.000000,0.294309,-0.891911,0.343331,0.869292,0.668485, -0.294309,-0.891911,0.343331,0.000000,0.294309,-0.891911,0.343331,0.869292,0.668485, -0.468576,-0.828418,0.306855,0.000000,0.468576,-0.828418,0.306855,0.178463,0.345280, -0.360730,-0.793377,0.490334,0.000000,0.360730,-0.793377,0.490334,0.446077,0.425781, -0.109305,-0.925043,0.363797,0.000000,0.109305,-0.925043,0.363797,0.183922,0.408548, -0.183479,-0.836210,0.516806,0.000000,0.183479,-0.836210,0.516806,0.258102,0.766841, --0.000000,-0.850651,0.525731,0.000000,-0.000000,-0.850651,0.525731,0.238575,0.258102, -0.213834,-0.959006,0.185961,0.000000,0.213834,-0.959006,0.185961,0.272352,0.408548, -0.294309,-0.891911,0.343331,0.000000,0.294309,-0.891911,0.343331,0.869292,0.668485, -0.109305,-0.925043,0.363797,0.000000,0.109305,-0.925043,0.363797,0.183922,0.408548, -0.309017,-0.951057,0.000000,0.000000,0.309017,-0.951057,0.000000,0.183922,0.509719, -0.395510,-0.905103,0.156077,0.000000,0.395510,-0.905103,0.156077,0.131657,0.437784, -0.213834,-0.959006,0.185961,0.000000,0.213834,-0.959006,0.185961,0.272352,0.408548, -0.109305,-0.925043,0.363797,0.000000,0.109305,-0.925043,0.363797,0.183922,0.408548, -0.294309,-0.891911,0.343331,0.000000,0.294309,-0.891911,0.343331,0.869292,0.668485, -0.183479,-0.836210,0.516806,0.000000,0.183479,-0.836210,0.516806,0.258102,0.766841, -0.213834,-0.959006,0.185961,0.000000,0.213834,-0.959006,0.185961,0.272352,0.408548, -0.395510,-0.905103,0.156077,0.000000,0.395510,-0.905103,0.156077,0.131657,0.437784, -0.294309,-0.891911,0.343331,0.000000,0.294309,-0.891911,0.343331,0.869292,0.668485, --0.183479,-0.836210,0.516806,0.000000,-0.183479,-0.836210,0.516806,0.180025,0.332044, --0.109305,-0.925043,0.363797,0.000000,-0.109305,-0.925043,0.363797,0.211325,0.496650, --0.000000,-0.850651,0.525731,0.000000,-0.000000,-0.850651,0.525731,0.238575,0.258102, --0.109305,-0.925043,0.363797,0.000000,-0.109305,-0.925043,0.363797,0.211325,0.496650, --0.000000,-0.982247,0.187593,0.000000,-0.000000,-0.982247,0.187593,0.131658,0.497466, -0.109305,-0.925043,0.363797,0.000000,0.109305,-0.925043,0.363797,0.183922,0.408548, -0.104529,-0.994522,0.000000,0.000000,0.104529,-0.994522,0.000000,0.356925,0.418781, -0.213834,-0.959006,0.185961,0.000000,0.213834,-0.959006,0.185961,0.272352,0.408548, --0.000000,-0.982247,0.187593,0.000000,-0.000000,-0.982247,0.187593,0.131658,0.497466, -0.104529,-0.994522,0.000000,0.000000,0.104529,-0.994522,0.000000,0.356925,0.418781, -0.212032,-0.964719,-0.156077,0.000000,0.212032,-0.964719,-0.156077,0.272352,0.480987, -0.309017,-0.951057,0.000000,0.000000,0.309017,-0.951057,0.000000,0.183922,0.509719, --0.109305,-0.925043,0.363797,0.000000,-0.109305,-0.925043,0.363797,0.211325,0.496650, -0.109305,-0.925043,0.363797,0.000000,0.109305,-0.925043,0.363797,0.183922,0.408548, --0.000000,-0.850651,0.525731,0.000000,-0.000000,-0.850651,0.525731,0.238575,0.258102, --0.000000,-0.982247,0.187593,0.000000,-0.000000,-0.982247,0.187593,0.131658,0.497466, -0.213834,-0.959006,0.185961,0.000000,0.213834,-0.959006,0.185961,0.272352,0.408548, -0.109305,-0.925043,0.363797,0.000000,0.109305,-0.925043,0.363797,0.183922,0.408548, -0.104529,-0.994522,0.000000,0.000000,0.104529,-0.994522,0.000000,0.356925,0.418781, -0.309017,-0.951057,0.000000,0.000000,0.309017,-0.951057,0.000000,0.183922,0.509719, -0.213834,-0.959006,0.185961,0.000000,0.213834,-0.959006,0.185961,0.272352,0.408548, --0.360730,-0.793377,0.490334,0.000000,-0.360730,-0.793377,0.490334,0.327004,0.258102, --0.294310,-0.891911,0.343331,0.000000,-0.294310,-0.891911,0.343331,0.304653,0.497466, --0.183479,-0.836210,0.516806,0.000000,-0.183479,-0.836210,0.516806,0.180025,0.332044, --0.294310,-0.891911,0.343331,0.000000,-0.294310,-0.891911,0.343331,0.304653,0.497466, --0.213835,-0.959006,0.185961,0.000000,-0.213835,-0.959006,0.185961,0.209770,0.669136, --0.109305,-0.925043,0.363797,0.000000,-0.109305,-0.925043,0.363797,0.211325,0.496650, --0.213835,-0.959006,0.185961,0.000000,-0.213835,-0.959006,0.185961,0.209770,0.669136, --0.104529,-0.994522,0.000000,0.000000,-0.104529,-0.994522,0.000000,0.130708,0.668485, --0.000000,-0.982247,0.187593,0.000000,-0.000000,-0.982247,0.187593,0.131658,0.497466, --0.104529,-0.994522,0.000000,0.000000,-0.104529,-0.994522,0.000000,0.130708,0.668485, --0.000000,-0.987538,-0.157379,0.000000,-0.000000,-0.987538,-0.157379,0.647155,0.418781, -0.104529,-0.994522,0.000000,0.000000,0.104529,-0.994522,0.000000,0.356925,0.418781, --0.000000,-0.987538,-0.157379,0.000000,-0.000000,-0.987538,-0.157379,0.647155,0.418781, -0.107846,-0.945626,-0.306855,0.000000,0.107846,-0.945626,-0.306855,0.356925,0.453512, -0.212032,-0.964719,-0.156077,0.000000,0.212032,-0.964719,-0.156077,0.272352,0.480987, --0.294310,-0.891911,0.343331,0.000000,-0.294310,-0.891911,0.343331,0.304653,0.497466, --0.109305,-0.925043,0.363797,0.000000,-0.109305,-0.925043,0.363797,0.211325,0.496650, --0.183479,-0.836210,0.516806,0.000000,-0.183479,-0.836210,0.516806,0.180025,0.332044, --0.213835,-0.959006,0.185961,0.000000,-0.213835,-0.959006,0.185961,0.209770,0.669136, --0.000000,-0.982247,0.187593,0.000000,-0.000000,-0.982247,0.187593,0.131658,0.497466, --0.109305,-0.925043,0.363797,0.000000,-0.109305,-0.925043,0.363797,0.211325,0.496650, --0.104529,-0.994522,0.000000,0.000000,-0.104529,-0.994522,0.000000,0.130708,0.668485, -0.104529,-0.994522,0.000000,0.000000,0.104529,-0.994522,0.000000,0.356925,0.418781, --0.000000,-0.982247,0.187593,0.000000,-0.000000,-0.982247,0.187593,0.131658,0.497466, --0.000000,-0.987538,-0.157379,0.000000,-0.000000,-0.987538,-0.157379,0.647155,0.418781, -0.212032,-0.964719,-0.156077,0.000000,0.212032,-0.964719,-0.156077,0.272352,0.480987, -0.104529,-0.994522,0.000000,0.000000,0.104529,-0.994522,0.000000,0.356925,0.418781, --0.525731,-0.723607,0.447214,0.000000,-0.525731,-0.723607,0.447214,0.321589,0.745561, --0.468576,-0.828418,0.306855,0.000000,-0.468576,-0.828418,0.306855,0.393984,0.512408, --0.360730,-0.793377,0.490334,0.000000,-0.360730,-0.793377,0.490334,0.327004,0.258102, --0.468576,-0.828418,0.306855,0.000000,-0.468576,-0.828418,0.306855,0.393984,0.512408, --0.395511,-0.905103,0.156077,0.000000,-0.395511,-0.905103,0.156077,0.345491,0.590447, --0.294310,-0.891911,0.343331,0.000000,-0.294310,-0.891911,0.343331,0.304653,0.497466, --0.395511,-0.905103,0.156077,0.000000,-0.395511,-0.905103,0.156077,0.345491,0.590447, --0.309017,-0.951056,0.000000,0.000000,-0.309017,-0.951056,0.000000,0.302245,0.668485, --0.213835,-0.959006,0.185961,0.000000,-0.213835,-0.959006,0.185961,0.209770,0.669136, --0.212032,-0.964719,-0.156077,0.000000,-0.212032,-0.964719,-0.156077,0.265712,0.743874, --0.104529,-0.994522,0.000000,0.000000,-0.104529,-0.994522,0.000000,0.130708,0.668485, --0.309017,-0.951056,0.000000,0.000000,-0.309017,-0.951056,0.000000,0.302245,0.668485, --0.107846,-0.945626,-0.306855,0.000000,-0.107846,-0.945626,-0.306855,0.553923,0.437019, --0.000000,-0.987538,-0.157379,0.000000,-0.000000,-0.987538,-0.157379,0.647155,0.418781, --0.212032,-0.964719,-0.156077,0.000000,-0.212032,-0.964719,-0.156077,0.265712,0.743874, --0.107846,-0.945626,-0.306855,0.000000,-0.107846,-0.945626,-0.306855,0.553923,0.437019, -0.000000,-0.894427,-0.447214,0.000000,0.000000,-0.894427,-0.447214,0.848850,0.215669, -0.107846,-0.945626,-0.306855,0.000000,0.107846,-0.945626,-0.306855,0.356925,0.453512, --0.468576,-0.828418,0.306855,0.000000,-0.468576,-0.828418,0.306855,0.393984,0.512408, --0.294310,-0.891911,0.343331,0.000000,-0.294310,-0.891911,0.343331,0.304653,0.497466, --0.360730,-0.793377,0.490334,0.000000,-0.360730,-0.793377,0.490334,0.327004,0.258102, --0.395511,-0.905103,0.156077,0.000000,-0.395511,-0.905103,0.156077,0.345491,0.590447, --0.213835,-0.959006,0.185961,0.000000,-0.213835,-0.959006,0.185961,0.209770,0.669136, --0.294310,-0.891911,0.343331,0.000000,-0.294310,-0.891911,0.343331,0.304653,0.497466, --0.309017,-0.951056,0.000000,0.000000,-0.309017,-0.951056,0.000000,0.302245,0.668485, --0.104529,-0.994522,0.000000,0.000000,-0.104529,-0.994522,0.000000,0.130708,0.668485, --0.213835,-0.959006,0.185961,0.000000,-0.213835,-0.959006,0.185961,0.209770,0.669136, --0.212032,-0.964719,-0.156077,0.000000,-0.212032,-0.964719,-0.156077,0.265712,0.743874, --0.000000,-0.987538,-0.157379,0.000000,-0.000000,-0.987538,-0.157379,0.647155,0.418781, --0.104529,-0.994522,0.000000,0.000000,-0.104529,-0.994522,0.000000,0.130708,0.668485, --0.107846,-0.945626,-0.306855,0.000000,-0.107846,-0.945626,-0.306855,0.553923,0.437019, -0.107846,-0.945626,-0.306855,0.000000,0.107846,-0.945626,-0.306855,0.356925,0.453512, --0.000000,-0.987538,-0.157379,0.000000,-0.000000,-0.987538,-0.157379,0.647155,0.418781 -}; - -static const int detailed_sphere_indices[] = -{ - 0,1,2, -3,4,5, -6,7,8, -9,10,11, -12,13,14, -15,16,17, -18,19,20, -21,22,23, -24,25,26, -27,28,29, -30,31,32, -33,34,35, -36,37,38, -39,40,41, -42,43,44, -45,46,47, -48,49,50, -51,52,53, -54,55,56, -57,58,59, -60,61,62, -63,64,65, -66,67,68, -69,70,71, -72,73,74, -75,76,77, -78,79,80, -81,82,83, -84,85,86, -87,88,89, -90,91,92, -93,94,95, -96,97,98, -99,100,101, -102,103,104, -105,106,107, -108,109,110, -111,112,113, -114,115,116, -117,118,119, -120,121,122, -123,124,125, -126,127,128, -129,130,131, -132,133,134, -135,136,137, -138,139,140, -141,142,143, -144,145,146, -147,148,149, -150,151,152, -153,154,155, -156,157,158, -159,160,161, -162,163,164, -165,166,167, -168,169,170, -171,172,173, -174,175,176, -177,178,179, -180,181,182, -183,184,185, -186,187,188, -189,190,191, -192,193,194, -195,196,197, -198,199,200, -201,202,203, -204,205,206, -207,208,209, -210,211,212, -213,214,215, -216,217,218, -219,220,221, -222,223,224, -225,226,227, -228,229,230, -231,232,233, -234,235,236, -237,238,239, -240,241,242, -243,244,245, -246,247,248, -249,250,251, -252,253,254, -255,256,257, -258,259,260, -261,262,263, -264,265,266, -267,268,269, -270,271,272, -273,274,275, -276,277,278, -279,280,281, -282,283,284, -285,286,287, -288,289,290, -291,292,293, -294,295,296, -297,298,299, -300,301,302, -303,304,305, -306,307,308, -309,310,311, -312,313,314, -315,316,317, -318,319,320, -321,322,323, -324,325,326, -327,328,329, -330,331,332, -333,334,335, -336,337,338, -339,340,341, -342,343,344, -345,346,347, -348,349,350, -351,352,353, -354,355,356, -357,358,359, -360,361,362, -363,364,365, -366,367,368, -369,370,371, -372,373,374, -375,376,377, -378,379,380, -381,382,383, -384,385,386, -387,388,389, -390,391,392, -393,394,395, -396,397,398, -399,400,401, -402,403,404, -405,406,407, -408,409,410, -411,412,413, -414,415,416, -417,418,419, -420,421,422, -423,424,425, -426,427,428, -429,430,431, -432,433,434, -435,436,437, -438,439,440, -441,442,443, -444,445,446, -447,448,449, -450,451,452, -453,454,455, -456,457,458, -459,460,461, -462,463,464, -465,466,467, -468,469,470, -471,472,473, -474,475,476, -477,478,479, -480,481,482, -483,484,485, -486,487,488, -489,490,491, -492,493,494, -495,496,497, -498,499,500, -501,502,503, -504,505,506, -507,508,509, -510,511,512, -513,514,515, -516,517,518, -519,520,521, -522,523,524, -525,526,527, -528,529,530, -531,532,533, -534,535,536, -537,538,539, -540,541,542, -543,544,545, -546,547,548, -549,550,551, -552,553,554, -555,556,557, -558,559,560, -561,562,563, -564,565,566, -567,568,569, -570,571,572, -573,574,575, -576,577,578, -579,580,581, -582,583,584, -585,586,587, -588,589,590, -591,592,593, -594,595,596, -597,598,599, -600,601,602, -603,604,605, -606,607,608, -609,610,611, -612,613,614, -615,616,617, -618,619,620, -621,622,623, -624,625,626, -627,628,629, -630,631,632, -633,634,635, -636,637,638, -639,640,641, -642,643,644, -645,646,647, -648,649,650, -651,652,653, -654,655,656, -657,658,659, -660,661,662, -663,664,665, -666,667,668, -669,670,671, -672,673,674, -675,676,677, -678,679,680, -681,682,683, -684,685,686, -687,688,689, -690,691,692, -693,694,695, -696,697,698, -699,700,701, -702,703,704, -705,706,707, -708,709,710, -711,712,713, -714,715,716, -717,718,719, -720,721,722, -723,724,725, -726,727,728, -729,730,731, -732,733,734, -735,736,737, -738,739,740, -741,742,743, -744,745,746, -747,748,749, -750,751,752, -753,754,755, -756,757,758, -759,760,761, -762,763,764, -765,766,767, -768,769,770, -771,772,773, -774,775,776, -777,778,779, -780,781,782, -783,784,785, -786,787,788, -789,790,791, -792,793,794, -795,796,797, -798,799,800, -801,802,803, -804,805,806, -807,808,809, -810,811,812, -813,814,815, -816,817,818, -819,820,821, -822,823,824, -825,826,827, -828,829,830, -831,832,833, -834,835,836, -837,838,839, -840,841,842, -843,844,845, -846,847,848, -849,850,851, -852,853,854, -855,856,857, -858,859,860, -861,862,863, -864,865,866, -867,868,869, -870,871,872, -873,874,875, -876,877,878, -879,880,881, -882,883,884, -885,886,887, -888,889,890, -891,892,893, -894,895,896, -897,898,899, -900,901,902, -903,904,905, -906,907,908, -909,910,911, -912,913,914, -915,916,917, -918,919,920, -921,922,923, -924,925,926, -927,928,929, -930,931,932, -933,934,935, -936,937,938, -939,940,941, -942,943,944, -945,946,947, -948,949,950, -951,952,953, -954,955,956, -957,958,959, -960,961,962, -963,964,965, -966,967,968, -969,970,971, -972,973,974, -975,976,977, -978,979,980, -981,982,983, -984,985,986, -987,988,989, -990,991,992, -993,994,995, -996,997,998, -999,1000,1001, -1002,1003,1004, -1005,1006,1007, -1008,1009,1010, -1011,1012,1013, -1014,1015,1016, -1017,1018,1019, -1020,1021,1022, -1023,1024,1025, -1026,1027,1028, -1029,1030,1031, -1032,1033,1034, -1035,1036,1037, -1038,1039,1040, -1041,1042,1043, -1044,1045,1046, -1047,1048,1049, -1050,1051,1052, -1053,1054,1055, -1056,1057,1058, -1059,1060,1061, -1062,1063,1064, -1065,1066,1067, -1068,1069,1070, -1071,1072,1073, -1074,1075,1076, -1077,1078,1079, -1080,1081,1082, -1083,1084,1085, -1086,1087,1088, -1089,1090,1091, -1092,1093,1094, -1095,1096,1097, -1098,1099,1100, -1101,1102,1103, -1104,1105,1106, -1107,1108,1109, -1110,1111,1112, -1113,1114,1115, -1116,1117,1118, -1119,1120,1121, -1122,1123,1124, -1125,1126,1127, -1128,1129,1130, -1131,1132,1133, -1134,1135,1136, -1137,1138,1139, -1140,1141,1142, -1143,1144,1145, -1146,1147,1148, -1149,1150,1151, -1152,1153,1154, -1155,1156,1157, -1158,1159,1160, -1161,1162,1163, -1164,1165,1166, -1167,1168,1169, -1170,1171,1172, -1173,1174,1175, -1176,1177,1178, -1179,1180,1181, -1182,1183,1184, -1185,1186,1187, -1188,1189,1190, -1191,1192,1193, -1194,1195,1196, -1197,1198,1199, -1200,1201,1202, -1203,1204,1205, -1206,1207,1208, -1209,1210,1211, -1212,1213,1214, -1215,1216,1217, -1218,1219,1220, -1221,1222,1223, -1224,1225,1226, -1227,1228,1229, -1230,1231,1232, -1233,1234,1235, -1236,1237,1238, -1239,1240,1241, -1242,1243,1244, -1245,1246,1247, -1248,1249,1250, -1251,1252,1253, -1254,1255,1256, -1257,1258,1259, -1260,1261,1262, -1263,1264,1265, -1266,1267,1268, -1269,1270,1271, -1272,1273,1274, -1275,1276,1277, -1278,1279,1280, -1281,1282,1283, -1284,1285,1286, -1287,1288,1289, -1290,1291,1292, -1293,1294,1295, -1296,1297,1298, -1299,1300,1301, -1302,1303,1304, -1305,1306,1307, -1308,1309,1310, -1311,1312,1313, -1314,1315,1316, -1317,1318,1319, -1320,1321,1322, -1323,1324,1325, -1326,1327,1328, -1329,1330,1331, -1332,1333,1334, -1335,1336,1337, -1338,1339,1340, -1341,1342,1343, -1344,1345,1346, -1347,1348,1349, -1350,1351,1352, -1353,1354,1355, -1356,1357,1358, -1359,1360,1361, -1362,1363,1364, -1365,1366,1367, -1368,1369,1370, -1371,1372,1373, -1374,1375,1376, -1377,1378,1379, -1380,1381,1382, -1383,1384,1385, -1386,1387,1388, -1389,1390,1391, -1392,1393,1394, -1395,1396,1397, -1398,1399,1400, -1401,1402,1403, -1404,1405,1406, -1407,1408,1409, -1410,1411,1412, -1413,1414,1415, -1416,1417,1418, -1419,1420,1421, -1422,1423,1424, -1425,1426,1427, -1428,1429,1430, -1431,1432,1433, -1434,1435,1436, -1437,1438,1439, -1440,1441,1442, -1443,1444,1445, -1446,1447,1448, -1449,1450,1451, -1452,1453,1454, -1455,1456,1457, -1458,1459,1460, -1461,1462,1463, -1464,1465,1466, -1467,1468,1469, -1470,1471,1472, -1473,1474,1475, -1476,1477,1478, -1479,1480,1481, -1482,1483,1484, -1485,1486,1487, -1488,1489,1490, -1491,1492,1493, -1494,1495,1496, -1497,1498,1499, -1500,1501,1502, -1503,1504,1505, -1506,1507,1508, -1509,1510,1511, -1512,1513,1514, -1515,1516,1517, -1518,1519,1520, -1521,1522,1523, -1524,1525,1526, -1527,1528,1529, -1530,1531,1532, -1533,1534,1535, -1536,1537,1538, -1539,1540,1541, -1542,1543,1544, -1545,1546,1547, -1548,1549,1550, -1551,1552,1553, -1554,1555,1556, -1557,1558,1559, -1560,1561,1562, -1563,1564,1565, -1566,1567,1568, -1569,1570,1571, -1572,1573,1574, -1575,1576,1577, -1578,1579,1580, -1581,1582,1583, -1584,1585,1586, -1587,1588,1589, -1590,1591,1592, -1593,1594,1595, -1596,1597,1598, -1599,1600,1601, -1602,1603,1604, -1605,1606,1607, -1608,1609,1610, -1611,1612,1613, -1614,1615,1616, -1617,1618,1619, -1620,1621,1622, -1623,1624,1625, -1626,1627,1628, -1629,1630,1631, -1632,1633,1634, -1635,1636,1637, -1638,1639,1640, -1641,1642,1643, -1644,1645,1646, -1647,1648,1649, -1650,1651,1652, -1653,1654,1655, -1656,1657,1658, -1659,1660,1661, -1662,1663,1664, -1665,1666,1667, -1668,1669,1670, -1671,1672,1673, -1674,1675,1676, -1677,1678,1679, -1680,1681,1682, -1683,1684,1685, -1686,1687,1688, -1689,1690,1691, -1692,1693,1694, -1695,1696,1697, -1698,1699,1700, -1701,1702,1703, -1704,1705,1706, -1707,1708,1709, -1710,1711,1712, -1713,1714,1715, -1716,1717,1718, -1719,1720,1721, -1722,1723,1724, -1725,1726,1727, -1728,1729,1730, -1731,1732,1733, -1734,1735,1736, -1737,1738,1739, -1740,1741,1742, -1743,1744,1745, -1746,1747,1748, -1749,1750,1751, -1752,1753,1754, -1755,1756,1757, -1758,1759,1760, -1761,1762,1763, -1764,1765,1766, -1767,1768,1769, -1770,1771,1772, -1773,1774,1775, -1776,1777,1778, -1779,1780,1781, -1782,1783,1784, -1785,1786,1787, -1788,1789,1790, -1791,1792,1793, -1794,1795,1796, -1797,1798,1799, -1800,1801,1802, -1803,1804,1805, -1806,1807,1808, -1809,1810,1811, -1812,1813,1814, -1815,1816,1817, -1818,1819,1820, -1821,1822,1823, -1824,1825,1826, -1827,1828,1829, -1830,1831,1832, -1833,1834,1835, -1836,1837,1838, -1839,1840,1841, -1842,1843,1844, -1845,1846,1847, -1848,1849,1850, -1851,1852,1853, -1854,1855,1856, -1857,1858,1859, -1860,1861,1862, -1863,1864,1865, -1866,1867,1868, -1869,1870,1871, -1872,1873,1874, -1875,1876,1877, -1878,1879,1880, -1881,1882,1883, -1884,1885,1886, -1887,1888,1889, -1890,1891,1892, -1893,1894,1895, -1896,1897,1898, -1899,1900,1901, -1902,1903,1904, -1905,1906,1907, -1908,1909,1910, -1911,1912,1913, -1914,1915,1916, -1917,1918,1919, -1920,1921,1922, -1923,1924,1925, -1926,1927,1928, -1929,1930,1931, -1932,1933,1934, -1935,1936,1937, -1938,1939,1940, -1941,1942,1943, -1944,1945,1946, -1947,1948,1949, -1950,1951,1952, -1953,1954,1955, -1956,1957,1958, -1959,1960,1961, -1962,1963,1964, -1965,1966,1967, -1968,1969,1970, -1971,1972,1973, -1974,1975,1976, -1977,1978,1979, -1980,1981,1982, -1983,1984,1985, -1986,1987,1988, -1989,1990,1991, -1992,1993,1994, -1995,1996,1997, -1998,1999,2000, -2001,2002,2003, -2004,2005,2006, -2007,2008,2009, -2010,2011,2012, -2013,2014,2015, -2016,2017,2018, -2019,2020,2021, -2022,2023,2024, -2025,2026,2027, -2028,2029,2030, -2031,2032,2033, -2034,2035,2036, -2037,2038,2039, -2040,2041,2042, -2043,2044,2045, -2046,2047,2048, -2049,2050,2051, -2052,2053,2054, -2055,2056,2057, -2058,2059,2060, -2061,2062,2063, -2064,2065,2066, -2067,2068,2069, -2070,2071,2072, -2073,2074,2075, -2076,2077,2078, -2079,2080,2081, -2082,2083,2084, -2085,2086,2087, -2088,2089,2090, -2091,2092,2093, -2094,2095,2096, -2097,2098,2099, -2100,2101,2102, -2103,2104,2105, -2106,2107,2108, -2109,2110,2111, -2112,2113,2114, -2115,2116,2117, -2118,2119,2120, -2121,2122,2123, -2124,2125,2126, -2127,2128,2129, -2130,2131,2132, -2133,2134,2135, -2136,2137,2138, -2139,2140,2141, -2142,2143,2144, -2145,2146,2147, -2148,2149,2150, -2151,2152,2153, -2154,2155,2156, -2157,2158,2159 -}; - - -const float medium_sphere_vertices[]= -{ - 0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, -0.203181,-0.967950,0.147618,0.000000,0.203181,-0.967950,0.147618,0.566902,0.400852, --0.077607,-0.967950,0.238853,0.000000,-0.077607,-0.967950,0.238853,0.986368,0.352464, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.779690,0.082142, -0.609547,-0.657519,0.442856,0.000000,0.609547,-0.657519,0.442856,0.381800,0.317539, -0.812729,-0.502301,0.295238,0.000000,0.812729,-0.502301,0.295238,0.918131,0.436615, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, --0.077607,-0.967950,0.238853,0.000000,-0.077607,-0.967950,0.238853,0.986368,0.352464, --0.251147,-0.967949,0.000000,0.000000,-0.251147,-0.967949,0.000000,0.444254,0.709621, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, --0.251147,-0.967949,0.000000,0.000000,-0.251147,-0.967949,0.000000,0.444254,0.709621, --0.077607,-0.967950,-0.238853,0.000000,-0.077607,-0.967950,-0.238853,0.043816,0.747734, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, --0.077607,-0.967950,-0.238853,0.000000,-0.077607,-0.967950,-0.238853,0.043816,0.747734, -0.203181,-0.967950,-0.147618,0.000000,0.203181,-0.967950,-0.147618,0.966205,0.438787, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.779690,0.082142, -0.812729,-0.502301,0.295238,0.000000,0.812729,-0.502301,0.295238,0.918131,0.436615, -0.860698,-0.251151,0.442858,0.000000,0.860698,-0.251151,0.442858,0.689049,0.234408, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.554423,0.061638, --0.029639,-0.502302,0.864184,0.000000,-0.029639,-0.502302,0.864184,0.180731,0.340648, --0.155215,-0.251152,0.955422,0.000000,-0.155215,-0.251152,0.955422,0.885924,0.257323, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.831051,-0.502299,0.238853,0.000000,-0.831051,-0.502299,0.238853,0.634945,0.715428, --0.956626,-0.251149,0.147618,0.000000,-0.956626,-0.251149,0.147618,0.397050,0.226232, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.750122,0.271069, --0.483971,-0.502302,-0.716565,0.000000,-0.483971,-0.502302,-0.716565,0.250122,0.728931, --0.436007,-0.251152,-0.864188,0.000000,-0.436007,-0.251152,-0.864188,0.134945,0.284572, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,0.791456,0.337315, -0.531941,-0.502302,-0.681712,0.000000,0.531941,-0.502302,-0.681712,0.833640,0.738875, -0.687159,-0.251152,-0.681715,0.000000,0.687159,-0.251152,-0.681715,0.268675,0.239476, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.779690,0.082142, -0.860698,-0.251151,0.442858,0.000000,0.860698,-0.251151,0.442858,0.689049,0.234408, -0.687159,-0.251152,0.681715,0.000000,0.687159,-0.251152,0.681715,0.702477,0.326245, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.554423,0.061638, --0.155215,-0.251152,0.955422,0.000000,-0.155215,-0.251152,0.955422,0.885924,0.257323, --0.436007,-0.251152,0.864188,0.000000,-0.436007,-0.251152,0.864188,0.813138,0.249674, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.956626,-0.251149,0.147618,0.000000,-0.956626,-0.251149,0.147618,0.397050,0.226232, --0.956626,-0.251149,-0.147618,0.000000,-0.956626,-0.251149,-0.147618,0.304489,0.071876, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.750122,0.271069, --0.436007,-0.251152,-0.864188,0.000000,-0.436007,-0.251152,-0.864188,0.134945,0.284572, --0.155215,-0.251152,-0.955422,0.000000,-0.155215,-0.251152,-0.955422,0.129692,0.189429, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,0.791456,0.337315, -0.687159,-0.251152,-0.681715,0.000000,0.687159,-0.251152,-0.681715,0.268675,0.239476, -0.860698,-0.251151,-0.442858,0.000000,0.860698,-0.251151,-0.442858,0.543816,0.252266, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.304489,0.071876, -0.483971,0.502302,0.716565,0.000000,0.483971,0.502302,0.716565,1.036828,0.167036, -0.232822,0.657519,0.716563,0.000000,0.232822,0.657519,0.716563,0.616405,0.395845, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,1.115709,0.094716, --0.531941,0.502302,0.681712,0.000000,-0.531941,0.502302,0.681712,0.074553,0.260244, --0.609547,0.657519,0.442856,0.000000,-0.609547,0.657519,0.442856,0.418131,0.563385, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.952607,0.099770, --0.812729,0.502301,-0.295238,0.000000,-0.812729,0.502301,-0.295238,0.093723,0.349056, --0.609547,0.657519,-0.442856,0.000000,-0.609547,0.657519,-0.442856,0.441249,0.481295, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.768276,0.421330, -0.029639,0.502302,-0.864184,0.000000,0.029639,0.502302,-0.864184,0.791278,0.505149, -0.232822,0.657519,-0.716563,0.000000,0.232822,0.657519,-0.716563,0.467747,0.391208, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.542767,0.333057, -0.831051,0.502299,-0.238853,0.000000,0.831051,0.502299,-0.238853,0.891200,0.515555, -0.753442,0.657515,0.000000,0.000000,0.753442,0.657515,0.000000,0.870330,0.424531, --0.232822,-0.657519,0.716563,0.000000,-0.232822,-0.657519,0.716563,0.163633,0.429436, --0.029639,-0.502302,0.864184,0.000000,-0.029639,-0.502302,0.864184,0.180731,0.340648, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.554423,0.061638, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.943007,0.371159, -0.052790,-0.723612,0.688185,0.000000,0.052790,-0.723612,0.688185,0.219605,0.584779, --0.232822,-0.657519,0.716563,0.000000,-0.232822,-0.657519,0.716563,0.163633,0.429436, --0.077607,-0.967950,0.238853,0.000000,-0.077607,-0.967950,0.238853,0.986368,0.352464, -0.138199,-0.894429,0.425321,0.000000,0.138199,-0.894429,0.425321,0.268276,0.578670, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.943007,0.371159, --0.232822,-0.657519,0.716563,0.000000,-0.232822,-0.657519,0.716563,0.163633,0.429436, -0.052790,-0.723612,0.688185,0.000000,0.052790,-0.723612,0.688185,0.219605,0.584779, --0.029639,-0.502302,0.864184,0.000000,-0.029639,-0.502302,0.864184,0.180731,0.340648, -0.052790,-0.723612,0.688185,0.000000,0.052790,-0.723612,0.688185,0.219605,0.584779, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.137692,0.365246, --0.029639,-0.502302,0.864184,0.000000,-0.029639,-0.502302,0.864184,0.180731,0.340648, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.943007,0.371159, -0.138199,-0.894429,0.425321,0.000000,0.138199,-0.894429,0.425321,0.268276,0.578670, -0.052790,-0.723612,0.688185,0.000000,0.052790,-0.723612,0.688185,0.219605,0.584779, -0.138199,-0.894429,0.425321,0.000000,0.138199,-0.894429,0.425321,0.268276,0.578670, -0.361805,-0.723611,0.587779,0.000000,0.361805,-0.723611,0.587779,0.191461,0.507219, -0.052790,-0.723612,0.688185,0.000000,0.052790,-0.723612,0.688185,0.219605,0.584779, -0.052790,-0.723612,0.688185,0.000000,0.052790,-0.723612,0.688185,0.219605,0.584779, -0.361805,-0.723611,0.587779,0.000000,0.361805,-0.723611,0.587779,0.191461,0.507219, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.137692,0.365246, -0.361805,-0.723611,0.587779,0.000000,0.361805,-0.723611,0.587779,0.191461,0.507219, -0.531941,-0.502302,0.681712,0.000000,0.531941,-0.502302,0.681712,0.363599,0.405960, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.137692,0.365246, --0.077607,-0.967950,0.238853,0.000000,-0.077607,-0.967950,0.238853,0.986368,0.352464, -0.203181,-0.967950,0.147618,0.000000,0.203181,-0.967950,0.147618,0.566902,0.400852, -0.138199,-0.894429,0.425321,0.000000,0.138199,-0.894429,0.425321,0.268276,0.578670, -0.203181,-0.967950,0.147618,0.000000,0.203181,-0.967950,0.147618,0.566902,0.400852, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.138199,-0.894429,0.425321,0.000000,0.138199,-0.894429,0.425321,0.268276,0.578670, -0.138199,-0.894429,0.425321,0.000000,0.138199,-0.894429,0.425321,0.268276,0.578670, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.361805,-0.723611,0.587779,0.000000,0.361805,-0.723611,0.587779,0.191461,0.507219, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.609547,-0.657519,0.442856,0.000000,0.609547,-0.657519,0.442856,0.381800,0.317539, -0.361805,-0.723611,0.587779,0.000000,0.361805,-0.723611,0.587779,0.191461,0.507219, -0.361805,-0.723611,0.587779,0.000000,0.361805,-0.723611,0.587779,0.191461,0.507219, -0.609547,-0.657519,0.442856,0.000000,0.609547,-0.657519,0.442856,0.381800,0.317539, -0.531941,-0.502302,0.681712,0.000000,0.531941,-0.502302,0.681712,0.363599,0.405960, -0.609547,-0.657519,0.442856,0.000000,0.609547,-0.657519,0.442856,0.381800,0.317539, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.779690,0.082142, -0.531941,-0.502302,0.681712,0.000000,0.531941,-0.502302,0.681712,0.363599,0.405960, -0.812729,-0.502301,-0.295238,0.000000,0.812729,-0.502301,-0.295238,0.314480,0.411140, -0.609547,-0.657519,-0.442856,0.000000,0.609547,-0.657519,-0.442856,0.517304,0.399254, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,0.791456,0.337315, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.115418,0.434134, -0.670817,-0.723611,-0.162457,0.000000,0.670817,-0.723611,-0.162457,0.241373,0.501088, -0.812729,-0.502301,-0.295238,0.000000,0.812729,-0.502301,-0.295238,0.314480,0.411140, -0.812729,-0.502301,0.295238,0.000000,0.812729,-0.502301,0.295238,0.918131,0.436615, -0.670817,-0.723610,0.162458,0.000000,0.670817,-0.723610,0.162458,0.211591,0.415486, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.115418,0.434134, -0.812729,-0.502301,-0.295238,0.000000,0.812729,-0.502301,-0.295238,0.314480,0.411140, -0.670817,-0.723611,-0.162457,0.000000,0.670817,-0.723611,-0.162457,0.241373,0.501088, -0.609547,-0.657519,-0.442856,0.000000,0.609547,-0.657519,-0.442856,0.517304,0.399254, -0.670817,-0.723611,-0.162457,0.000000,0.670817,-0.723611,-0.162457,0.241373,0.501088, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.719605,0.415221, -0.609547,-0.657519,-0.442856,0.000000,0.609547,-0.657519,-0.442856,0.517304,0.399254, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.115418,0.434134, -0.670817,-0.723610,0.162458,0.000000,0.670817,-0.723610,0.162458,0.211591,0.415486, -0.670817,-0.723611,-0.162457,0.000000,0.670817,-0.723611,-0.162457,0.241373,0.501088, -0.670817,-0.723610,0.162458,0.000000,0.670817,-0.723610,0.162458,0.211591,0.415486, -0.447211,-0.894428,0.000001,0.000000,0.447211,-0.894428,0.000001,0.291278,0.494851, -0.670817,-0.723611,-0.162457,0.000000,0.670817,-0.723611,-0.162457,0.241373,0.501088, -0.670817,-0.723611,-0.162457,0.000000,0.670817,-0.723611,-0.162457,0.241373,0.501088, -0.447211,-0.894428,0.000001,0.000000,0.447211,-0.894428,0.000001,0.291278,0.494851, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.719605,0.415221, -0.447211,-0.894428,0.000001,0.000000,0.447211,-0.894428,0.000001,0.291278,0.494851, -0.203181,-0.967950,-0.147618,0.000000,0.203181,-0.967950,-0.147618,0.966205,0.438787, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.719605,0.415221, -0.812729,-0.502301,0.295238,0.000000,0.812729,-0.502301,0.295238,0.918131,0.436615, -0.609547,-0.657519,0.442856,0.000000,0.609547,-0.657519,0.442856,0.381800,0.317539, -0.670817,-0.723610,0.162458,0.000000,0.670817,-0.723610,0.162458,0.211591,0.415486, -0.609547,-0.657519,0.442856,0.000000,0.609547,-0.657519,0.442856,0.381800,0.317539, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.670817,-0.723610,0.162458,0.000000,0.670817,-0.723610,0.162458,0.211591,0.415486, -0.670817,-0.723610,0.162458,0.000000,0.670817,-0.723610,0.162458,0.211591,0.415486, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.447211,-0.894428,0.000001,0.000000,0.447211,-0.894428,0.000001,0.291278,0.494851, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.203181,-0.967950,0.147618,0.000000,0.203181,-0.967950,0.147618,0.566902,0.400852, -0.447211,-0.894428,0.000001,0.000000,0.447211,-0.894428,0.000001,0.291278,0.494851, -0.447211,-0.894428,0.000001,0.000000,0.447211,-0.894428,0.000001,0.291278,0.494851, -0.203181,-0.967950,0.147618,0.000000,0.203181,-0.967950,0.147618,0.566902,0.400852, -0.203181,-0.967950,-0.147618,0.000000,0.203181,-0.967950,-0.147618,0.966205,0.438787, -0.203181,-0.967950,0.147618,0.000000,0.203181,-0.967950,0.147618,0.566902,0.400852, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, -0.203181,-0.967950,-0.147618,0.000000,0.203181,-0.967950,-0.147618,0.966205,0.438787, --0.753442,-0.657515,0.000000,0.000000,-0.753442,-0.657515,0.000000,0.443007,0.628841, --0.831051,-0.502299,0.238853,0.000000,-0.831051,-0.502299,0.238853,0.634945,0.715428, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.486368,0.647536, --0.638195,-0.723609,0.262864,0.000000,-0.638195,-0.723609,0.262864,0.265485,0.408729, --0.753442,-0.657515,0.000000,0.000000,-0.753442,-0.657515,0.000000,0.443007,0.628841, --0.251147,-0.967949,0.000000,0.000000,-0.251147,-0.967949,0.000000,0.444254,0.709621, --0.361801,-0.894428,0.262864,0.000000,-0.361801,-0.894428,0.262864,0.017304,0.600746, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.486368,0.647536, --0.753442,-0.657515,0.000000,0.000000,-0.753442,-0.657515,0.000000,0.443007,0.628841, --0.638195,-0.723609,0.262864,0.000000,-0.638195,-0.723609,0.262864,0.265485,0.408729, --0.831051,-0.502299,0.238853,0.000000,-0.831051,-0.502299,0.238853,0.634945,0.715428, --0.638195,-0.723609,0.262864,0.000000,-0.638195,-0.723609,0.262864,0.265485,0.408729, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.680731,0.659352, --0.831051,-0.502299,0.238853,0.000000,-0.831051,-0.502299,0.238853,0.634945,0.715428, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.486368,0.647536, --0.361801,-0.894428,0.262864,0.000000,-0.361801,-0.894428,0.262864,0.017304,0.600746, --0.638195,-0.723609,0.262864,0.000000,-0.638195,-0.723609,0.262864,0.265485,0.408729, --0.361801,-0.894428,0.262864,0.000000,-0.361801,-0.894428,0.262864,0.017304,0.600746, --0.447211,-0.723610,0.525729,0.000000,-0.447211,-0.723610,0.525729,0.066902,0.599148, --0.638195,-0.723609,0.262864,0.000000,-0.638195,-0.723609,0.262864,0.265485,0.408729, --0.638195,-0.723609,0.262864,0.000000,-0.638195,-0.723609,0.262864,0.265485,0.408729, --0.447211,-0.723610,0.525729,0.000000,-0.447211,-0.723610,0.525729,0.066902,0.599148, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.680731,0.659352, --0.447211,-0.723610,0.525729,0.000000,-0.447211,-0.723610,0.525729,0.066902,0.599148, --0.483971,-0.502302,0.716565,0.000000,-0.483971,-0.502302,0.716565,0.637692,0.634754, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.680731,0.659352, --0.251147,-0.967949,0.000000,0.000000,-0.251147,-0.967949,0.000000,0.444254,0.709621, --0.077607,-0.967950,0.238853,0.000000,-0.077607,-0.967950,0.238853,0.986368,0.352464, --0.361801,-0.894428,0.262864,0.000000,-0.361801,-0.894428,0.262864,0.017304,0.600746, --0.077607,-0.967950,0.238853,0.000000,-0.077607,-0.967950,0.238853,0.986368,0.352464, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.943007,0.371159, --0.361801,-0.894428,0.262864,0.000000,-0.361801,-0.894428,0.262864,0.017304,0.600746, --0.361801,-0.894428,0.262864,0.000000,-0.361801,-0.894428,0.262864,0.017304,0.600746, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.943007,0.371159, --0.447211,-0.723610,0.525729,0.000000,-0.447211,-0.723610,0.525729,0.066902,0.599148, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.943007,0.371159, --0.232822,-0.657519,0.716563,0.000000,-0.232822,-0.657519,0.716563,0.163633,0.429436, --0.447211,-0.723610,0.525729,0.000000,-0.447211,-0.723610,0.525729,0.066902,0.599148, --0.447211,-0.723610,0.525729,0.000000,-0.447211,-0.723610,0.525729,0.066902,0.599148, --0.232822,-0.657519,0.716563,0.000000,-0.232822,-0.657519,0.716563,0.163633,0.429436, --0.483971,-0.502302,0.716565,0.000000,-0.483971,-0.502302,0.716565,0.637692,0.634754, --0.232822,-0.657519,0.716563,0.000000,-0.232822,-0.657519,0.716563,0.163633,0.429436, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.554423,0.061638, --0.483971,-0.502302,0.716565,0.000000,-0.483971,-0.502302,0.716565,0.637692,0.634754, --0.232822,-0.657519,-0.716563,0.000000,-0.232822,-0.657519,-0.716563,0.042767,0.666943, --0.483971,-0.502302,-0.716565,0.000000,-0.483971,-0.502302,-0.716565,0.250122,0.728931, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.750122,0.271069, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.089135,0.684613, --0.447211,-0.723611,-0.525727,0.000000,-0.447211,-0.723611,-0.525727,0.991338,0.520023, --0.232822,-0.657519,-0.716563,0.000000,-0.232822,-0.657519,-0.716563,0.042767,0.666943, --0.077607,-0.967950,-0.238853,0.000000,-0.077607,-0.967950,-0.238853,0.043816,0.747734, --0.361801,-0.894429,-0.262863,0.000000,-0.361801,-0.894429,-0.262863,1.041434,0.519379, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.089135,0.684613, --0.232822,-0.657519,-0.716563,0.000000,-0.232822,-0.657519,-0.716563,0.042767,0.666943, --0.447211,-0.723611,-0.525727,0.000000,-0.447211,-0.723611,-0.525727,0.991338,0.520023, --0.483971,-0.502302,-0.716565,0.000000,-0.483971,-0.502302,-0.716565,0.250122,0.728931, --0.447211,-0.723611,-0.525727,0.000000,-0.447211,-0.723611,-0.525727,0.991338,0.520023, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,0.291456,0.662685, --0.483971,-0.502302,-0.716565,0.000000,-0.483971,-0.502302,-0.716565,0.250122,0.728931, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.089135,0.684613, --0.361801,-0.894429,-0.262863,0.000000,-0.361801,-0.894429,-0.262863,1.041434,0.519379, --0.447211,-0.723611,-0.525727,0.000000,-0.447211,-0.723611,-0.525727,0.991338,0.520023, --0.361801,-0.894429,-0.262863,0.000000,-0.361801,-0.894429,-0.262863,1.041434,0.519379, --0.638195,-0.723609,-0.262863,0.000000,-0.638195,-0.723609,-0.262863,1.017304,0.600746, --0.447211,-0.723611,-0.525727,0.000000,-0.447211,-0.723611,-0.525727,0.991338,0.520023, --0.447211,-0.723611,-0.525727,0.000000,-0.447211,-0.723611,-0.525727,0.991338,0.520023, --0.638195,-0.723609,-0.262863,0.000000,-0.638195,-0.723609,-0.262863,1.017304,0.600746, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,0.291456,0.662685, --0.638195,-0.723609,-0.262863,0.000000,-0.638195,-0.723609,-0.262863,1.017304,0.600746, --0.831051,-0.502299,-0.238853,0.000000,-0.831051,-0.502299,-0.238853,0.246383,0.648358, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,0.291456,0.662685, --0.077607,-0.967950,-0.238853,0.000000,-0.077607,-0.967950,-0.238853,0.043816,0.747734, --0.251147,-0.967949,0.000000,0.000000,-0.251147,-0.967949,0.000000,0.444254,0.709621, --0.361801,-0.894429,-0.262863,0.000000,-0.361801,-0.894429,-0.262863,1.041434,0.519379, --0.251147,-0.967949,0.000000,0.000000,-0.251147,-0.967949,0.000000,0.444254,0.709621, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.486368,0.647536, --0.361801,-0.894429,-0.262863,0.000000,-0.361801,-0.894429,-0.262863,1.041434,0.519379, --0.361801,-0.894429,-0.262863,0.000000,-0.361801,-0.894429,-0.262863,1.041434,0.519379, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.486368,0.647536, --0.638195,-0.723609,-0.262863,0.000000,-0.638195,-0.723609,-0.262863,1.017304,0.600746, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.486368,0.647536, --0.753442,-0.657515,0.000000,0.000000,-0.753442,-0.657515,0.000000,0.443007,0.628841, --0.638195,-0.723609,-0.262863,0.000000,-0.638195,-0.723609,-0.262863,1.017304,0.600746, --0.638195,-0.723609,-0.262863,0.000000,-0.638195,-0.723609,-0.262863,1.017304,0.600746, --0.753442,-0.657515,0.000000,0.000000,-0.753442,-0.657515,0.000000,0.443007,0.628841, --0.831051,-0.502299,-0.238853,0.000000,-0.831051,-0.502299,-0.238853,0.246383,0.648358, --0.753442,-0.657515,0.000000,0.000000,-0.753442,-0.657515,0.000000,0.443007,0.628841, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.831051,-0.502299,-0.238853,0.000000,-0.831051,-0.502299,-0.238853,0.246383,0.648358, -0.609547,-0.657519,-0.442856,0.000000,0.609547,-0.657519,-0.442856,0.517304,0.399254, -0.531941,-0.502302,-0.681712,0.000000,0.531941,-0.502302,-0.681712,0.833640,0.738875, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,0.791456,0.337315, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.719605,0.415221, -0.361804,-0.723612,-0.587779,0.000000,0.361804,-0.723612,-0.587779,1.014094,0.430832, -0.609547,-0.657519,-0.442856,0.000000,0.609547,-0.657519,-0.442856,0.517304,0.399254, -0.203181,-0.967950,-0.147618,0.000000,0.203181,-0.967950,-0.147618,0.966205,0.438787, -0.138197,-0.894429,-0.425321,0.000000,0.138197,-0.894429,-0.425321,0.041434,0.519379, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.719605,0.415221, -0.609547,-0.657519,-0.442856,0.000000,0.609547,-0.657519,-0.442856,0.517304,0.399254, -0.361804,-0.723612,-0.587779,0.000000,0.361804,-0.723612,-0.587779,1.014094,0.430832, -0.531941,-0.502302,-0.681712,0.000000,0.531941,-0.502302,-0.681712,0.833640,0.738875, -0.361804,-0.723612,-0.587779,0.000000,0.361804,-0.723612,-0.587779,1.014094,0.430832, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.881800,0.682461, -0.531941,-0.502302,-0.681712,0.000000,0.531941,-0.502302,-0.681712,0.833640,0.738875, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.719605,0.415221, -0.138197,-0.894429,-0.425321,0.000000,0.138197,-0.894429,-0.425321,0.041434,0.519379, -0.361804,-0.723612,-0.587779,0.000000,0.361804,-0.723612,-0.587779,1.014094,0.430832, -0.138197,-0.894429,-0.425321,0.000000,0.138197,-0.894429,-0.425321,0.041434,0.519379, -0.052789,-0.723611,-0.688186,0.000000,0.052789,-0.723611,-0.688186,0.091499,0.516836, -0.361804,-0.723612,-0.587779,0.000000,0.361804,-0.723612,-0.587779,1.014094,0.430832, -0.361804,-0.723612,-0.587779,0.000000,0.361804,-0.723612,-0.587779,1.014094,0.430832, -0.052789,-0.723611,-0.688186,0.000000,0.052789,-0.723611,-0.688186,0.091499,0.516836, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.881800,0.682461, -0.052789,-0.723611,-0.688186,0.000000,0.052789,-0.723611,-0.688186,0.091499,0.516836, --0.029639,-0.502302,-0.864184,0.000000,-0.029639,-0.502302,-0.864184,0.836927,0.658241, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.881800,0.682461, -0.203181,-0.967950,-0.147618,0.000000,0.203181,-0.967950,-0.147618,0.966205,0.438787, --0.077607,-0.967950,-0.238853,0.000000,-0.077607,-0.967950,-0.238853,0.043816,0.747734, -0.138197,-0.894429,-0.425321,0.000000,0.138197,-0.894429,-0.425321,0.041434,0.519379, --0.077607,-0.967950,-0.238853,0.000000,-0.077607,-0.967950,-0.238853,0.043816,0.747734, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.089135,0.684613, -0.138197,-0.894429,-0.425321,0.000000,0.138197,-0.894429,-0.425321,0.041434,0.519379, -0.138197,-0.894429,-0.425321,0.000000,0.138197,-0.894429,-0.425321,0.041434,0.519379, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.089135,0.684613, -0.052789,-0.723611,-0.688186,0.000000,0.052789,-0.723611,-0.688186,0.091499,0.516836, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.089135,0.684613, --0.232822,-0.657519,-0.716563,0.000000,-0.232822,-0.657519,-0.716563,0.042767,0.666943, -0.052789,-0.723611,-0.688186,0.000000,0.052789,-0.723611,-0.688186,0.091499,0.516836, -0.052789,-0.723611,-0.688186,0.000000,0.052789,-0.723611,-0.688186,0.091499,0.516836, --0.232822,-0.657519,-0.716563,0.000000,-0.232822,-0.657519,-0.716563,0.042767,0.666943, --0.029639,-0.502302,-0.864184,0.000000,-0.029639,-0.502302,-0.864184,0.836927,0.658241, --0.232822,-0.657519,-0.716563,0.000000,-0.232822,-0.657519,-0.716563,0.042767,0.666943, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.750122,0.271069, --0.029639,-0.502302,-0.864184,0.000000,-0.029639,-0.502302,-0.864184,0.836927,0.658241, -0.956626,0.251149,0.147618,0.000000,0.956626,0.251149,0.147618,0.658365,0.135762, -0.956626,0.251149,-0.147618,0.000000,0.956626,0.251149,-0.147618,0.610420,0.226784, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.542767,0.333057, -0.951058,-0.000000,0.309013,0.000000,0.951058,-0.000000,0.309013,0.646443,0.311386, -1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.014094,0.430832, -0.956626,0.251149,0.147618,0.000000,0.956626,0.251149,0.147618,0.658365,0.135762, -0.860698,-0.251151,0.442858,0.000000,0.860698,-0.251151,0.442858,0.689049,0.234408, -0.947213,-0.276396,0.162458,0.000000,0.947213,-0.276396,0.162458,0.067324,0.429118, -0.951058,-0.000000,0.309013,0.000000,0.951058,-0.000000,0.309013,0.646443,0.311386, -0.956626,0.251149,0.147618,0.000000,0.956626,0.251149,0.147618,0.658365,0.135762, -1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.014094,0.430832, -0.956626,0.251149,-0.147618,0.000000,0.956626,0.251149,-0.147618,0.610420,0.226784, -1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.014094,0.430832, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.546072,0.156902, -0.956626,0.251149,-0.147618,0.000000,0.956626,0.251149,-0.147618,0.610420,0.226784, -0.951058,-0.000000,0.309013,0.000000,0.951058,-0.000000,0.309013,0.646443,0.311386, -0.947213,-0.276396,0.162458,0.000000,0.947213,-0.276396,0.162458,0.067324,0.429118, -1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.014094,0.430832, -0.947213,-0.276396,0.162458,0.000000,0.947213,-0.276396,0.162458,0.067324,0.429118, -0.947213,-0.276396,-0.162458,0.000000,0.947213,-0.276396,-0.162458,0.711591,0.584513, -1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.014094,0.430832, -1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.000000,0.014094,0.430832, -0.947213,-0.276396,-0.162458,0.000000,0.947213,-0.276396,-0.162458,0.711591,0.584513, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.546072,0.156902, -0.947213,-0.276396,-0.162458,0.000000,0.947213,-0.276396,-0.162458,0.711591,0.584513, -0.860698,-0.251151,-0.442858,0.000000,0.860698,-0.251151,-0.442858,0.543816,0.252266, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.546072,0.156902, -0.860698,-0.251151,0.442858,0.000000,0.860698,-0.251151,0.442858,0.689049,0.234408, -0.812729,-0.502301,0.295238,0.000000,0.812729,-0.502301,0.295238,0.918131,0.436615, -0.947213,-0.276396,0.162458,0.000000,0.947213,-0.276396,0.162458,0.067324,0.429118, -0.812729,-0.502301,0.295238,0.000000,0.812729,-0.502301,0.295238,0.918131,0.436615, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.115418,0.434134, -0.947213,-0.276396,0.162458,0.000000,0.947213,-0.276396,0.162458,0.067324,0.429118, -0.947213,-0.276396,0.162458,0.000000,0.947213,-0.276396,0.162458,0.067324,0.429118, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.115418,0.434134, -0.947213,-0.276396,-0.162458,0.000000,0.947213,-0.276396,-0.162458,0.711591,0.584513, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.115418,0.434134, -0.812729,-0.502301,-0.295238,0.000000,0.812729,-0.502301,-0.295238,0.314480,0.411140, -0.947213,-0.276396,-0.162458,0.000000,0.947213,-0.276396,-0.162458,0.711591,0.584513, -0.947213,-0.276396,-0.162458,0.000000,0.947213,-0.276396,-0.162458,0.711591,0.584513, -0.812729,-0.502301,-0.295238,0.000000,0.812729,-0.502301,-0.295238,0.314480,0.411140, -0.860698,-0.251151,-0.442858,0.000000,0.860698,-0.251151,-0.442858,0.543816,0.252266, -0.812729,-0.502301,-0.295238,0.000000,0.812729,-0.502301,-0.295238,0.314480,0.411140, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,0.791456,0.337315, -0.860698,-0.251151,-0.442858,0.000000,0.860698,-0.251151,-0.442858,0.543816,0.252266, -0.155215,0.251152,0.955422,0.000000,0.155215,0.251152,0.955422,0.944254,0.290379, -0.436007,0.251152,0.864188,0.000000,0.436007,0.251152,0.864188,0.900083,0.348597, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.304489,0.071876, --0.000000,-0.000000,1.000000,0.000000,-0.000000,-0.000000,1.000000,0.846308,0.334943, -0.309017,0.000000,0.951056,0.000000,0.309017,0.000000,0.951056,0.741373,0.498912, -0.155215,0.251152,0.955422,0.000000,0.155215,0.251152,0.955422,0.944254,0.290379, --0.155215,-0.251152,0.955422,0.000000,-0.155215,-0.251152,0.955422,0.885924,0.257323, -0.138199,-0.276398,0.951055,0.000000,0.138199,-0.276398,0.951055,0.735205,0.674734, --0.000000,-0.000000,1.000000,0.000000,-0.000000,-0.000000,1.000000,0.846308,0.334943, -0.155215,0.251152,0.955422,0.000000,0.155215,0.251152,0.955422,0.944254,0.290379, -0.309017,0.000000,0.951056,0.000000,0.309017,0.000000,0.951056,0.741373,0.498912, -0.436007,0.251152,0.864188,0.000000,0.436007,0.251152,0.864188,0.900083,0.348597, -0.309017,0.000000,0.951056,0.000000,0.309017,0.000000,0.951056,0.741373,0.498912, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.757596,0.176140, -0.436007,0.251152,0.864188,0.000000,0.436007,0.251152,0.864188,0.900083,0.348597, --0.000000,-0.000000,1.000000,0.000000,-0.000000,-0.000000,1.000000,0.846308,0.334943, -0.138199,-0.276398,0.951055,0.000000,0.138199,-0.276398,0.951055,0.735205,0.674734, -0.309017,0.000000,0.951056,0.000000,0.309017,0.000000,0.951056,0.741373,0.498912, -0.138199,-0.276398,0.951055,0.000000,0.138199,-0.276398,0.951055,0.735205,0.674734, -0.447216,-0.276398,0.850648,0.000000,0.447216,-0.276398,0.850648,0.765485,0.591271, -0.309017,0.000000,0.951056,0.000000,0.309017,0.000000,0.951056,0.741373,0.498912, -0.309017,0.000000,0.951056,0.000000,0.309017,0.000000,0.951056,0.741373,0.498912, -0.447216,-0.276398,0.850648,0.000000,0.447216,-0.276398,0.850648,0.765485,0.591271, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.757596,0.176140, -0.447216,-0.276398,0.850648,0.000000,0.447216,-0.276398,0.850648,0.765485,0.591271, -0.687159,-0.251152,0.681715,0.000000,0.687159,-0.251152,0.681715,0.702477,0.326245, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.757596,0.176140, --0.155215,-0.251152,0.955422,0.000000,-0.155215,-0.251152,0.955422,0.885924,0.257323, --0.029639,-0.502302,0.864184,0.000000,-0.029639,-0.502302,0.864184,0.180731,0.340648, -0.138199,-0.276398,0.951055,0.000000,0.138199,-0.276398,0.951055,0.735205,0.674734, --0.029639,-0.502302,0.864184,0.000000,-0.029639,-0.502302,0.864184,0.180731,0.340648, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.137692,0.365246, -0.138199,-0.276398,0.951055,0.000000,0.138199,-0.276398,0.951055,0.735205,0.674734, -0.138199,-0.276398,0.951055,0.000000,0.138199,-0.276398,0.951055,0.735205,0.674734, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.137692,0.365246, -0.447216,-0.276398,0.850648,0.000000,0.447216,-0.276398,0.850648,0.765485,0.591271, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.137692,0.365246, -0.531941,-0.502302,0.681712,0.000000,0.531941,-0.502302,0.681712,0.363599,0.405960, -0.447216,-0.276398,0.850648,0.000000,0.447216,-0.276398,0.850648,0.765485,0.591271, -0.447216,-0.276398,0.850648,0.000000,0.447216,-0.276398,0.850648,0.765485,0.591271, -0.531941,-0.502302,0.681712,0.000000,0.531941,-0.502302,0.681712,0.363599,0.405960, -0.687159,-0.251152,0.681715,0.000000,0.687159,-0.251152,0.681715,0.702477,0.326245, -0.531941,-0.502302,0.681712,0.000000,0.531941,-0.502302,0.681712,0.363599,0.405960, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.779690,0.082142, -0.687159,-0.251152,0.681715,0.000000,0.687159,-0.251152,0.681715,0.702477,0.326245, --0.860698,0.251151,0.442858,0.000000,-0.860698,0.251151,0.442858,0.333640,0.261125, --0.687159,0.251152,0.681715,0.000000,-0.687159,0.251152,0.681715,0.856930,0.159299, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,1.115709,0.094716, --0.951058,-0.000000,0.309013,0.000000,-0.951058,-0.000000,0.309013,0.326823,0.166086, --0.809018,0.000000,0.587783,0.000000,-0.809018,0.000000,0.587783,0.791096,0.672983, --0.860698,0.251151,0.442858,0.000000,-0.860698,0.251151,0.442858,0.333640,0.261125, --0.956626,-0.251149,0.147618,0.000000,-0.956626,-0.251149,0.147618,0.397050,0.226232, --0.861803,-0.276396,0.425324,0.000000,-0.861803,-0.276396,0.425324,0.514094,0.569167, --0.951058,-0.000000,0.309013,0.000000,-0.951058,-0.000000,0.309013,0.326823,0.166086, --0.860698,0.251151,0.442858,0.000000,-0.860698,0.251151,0.442858,0.333640,0.261125, --0.809018,0.000000,0.587783,0.000000,-0.809018,0.000000,0.587783,0.791096,0.672983, --0.687159,0.251152,0.681715,0.000000,-0.687159,0.251152,0.681715,0.856930,0.159299, --0.809018,0.000000,0.587783,0.000000,-0.809018,0.000000,0.587783,0.791096,0.672983, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.946597,0.195033, --0.687159,0.251152,0.681715,0.000000,-0.687159,0.251152,0.681715,0.856930,0.159299, --0.951058,-0.000000,0.309013,0.000000,-0.951058,-0.000000,0.309013,0.326823,0.166086, --0.861803,-0.276396,0.425324,0.000000,-0.861803,-0.276396,0.425324,0.514094,0.569167, --0.809018,0.000000,0.587783,0.000000,-0.809018,0.000000,0.587783,0.791096,0.672983, --0.861803,-0.276396,0.425324,0.000000,-0.861803,-0.276396,0.425324,0.514094,0.569167, --0.670819,-0.276397,0.688191,0.000000,-0.670819,-0.276397,0.688191,0.541434,0.480621, --0.809018,0.000000,0.587783,0.000000,-0.809018,0.000000,0.587783,0.791096,0.672983, --0.809018,0.000000,0.587783,0.000000,-0.809018,0.000000,0.587783,0.791096,0.672983, --0.670819,-0.276397,0.688191,0.000000,-0.670819,-0.276397,0.688191,0.541434,0.480621, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.946597,0.195033, --0.670819,-0.276397,0.688191,0.000000,-0.670819,-0.276397,0.688191,0.541434,0.480621, --0.436007,-0.251152,0.864188,0.000000,-0.436007,-0.251152,0.864188,0.813138,0.249674, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.946597,0.195033, --0.956626,-0.251149,0.147618,0.000000,-0.956626,-0.251149,0.147618,0.397050,0.226232, --0.831051,-0.502299,0.238853,0.000000,-0.831051,-0.502299,0.238853,0.634945,0.715428, --0.861803,-0.276396,0.425324,0.000000,-0.861803,-0.276396,0.425324,0.514094,0.569167, --0.831051,-0.502299,0.238853,0.000000,-0.831051,-0.502299,0.238853,0.634945,0.715428, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.680731,0.659352, --0.861803,-0.276396,0.425324,0.000000,-0.861803,-0.276396,0.425324,0.514094,0.569167, --0.861803,-0.276396,0.425324,0.000000,-0.861803,-0.276396,0.425324,0.514094,0.569167, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.680731,0.659352, --0.670819,-0.276397,0.688191,0.000000,-0.670819,-0.276397,0.688191,0.541434,0.480621, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.680731,0.659352, --0.483971,-0.502302,0.716565,0.000000,-0.483971,-0.502302,0.716565,0.637692,0.634754, --0.670819,-0.276397,0.688191,0.000000,-0.670819,-0.276397,0.688191,0.541434,0.480621, --0.670819,-0.276397,0.688191,0.000000,-0.670819,-0.276397,0.688191,0.541434,0.480621, --0.483971,-0.502302,0.716565,0.000000,-0.483971,-0.502302,0.716565,0.637692,0.634754, --0.436007,-0.251152,0.864188,0.000000,-0.436007,-0.251152,0.864188,0.813138,0.249674, --0.483971,-0.502302,0.716565,0.000000,-0.483971,-0.502302,0.716565,0.637692,0.634754, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.554423,0.061638, --0.436007,-0.251152,0.864188,0.000000,-0.436007,-0.251152,0.864188,0.813138,0.249674, --0.687159,0.251152,-0.681715,0.000000,-0.687159,0.251152,-0.681715,0.477658,0.222612, --0.860698,0.251151,-0.442858,0.000000,-0.860698,0.251151,-0.442858,0.438926,0.305137, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.952607,0.099770, --0.587786,-0.000000,-0.809017,0.000000,-0.587786,-0.000000,-0.809017,0.496685,0.312438, --0.809018,-0.000000,-0.587783,0.000000,-0.809018,-0.000000,-0.587783,0.539894,0.656807, --0.687159,0.251152,-0.681715,0.000000,-0.687159,0.251152,-0.681715,0.477658,0.222612, --0.436007,-0.251152,-0.864188,0.000000,-0.436007,-0.251152,-0.864188,0.134945,0.284572, --0.670819,-0.276397,-0.688191,0.000000,-0.670819,-0.276397,-0.688191,0.567324,0.570882, --0.587786,-0.000000,-0.809017,0.000000,-0.587786,-0.000000,-0.809017,0.496685,0.312438, --0.687159,0.251152,-0.681715,0.000000,-0.687159,0.251152,-0.681715,0.477658,0.222612, --0.809018,-0.000000,-0.587783,0.000000,-0.809018,-0.000000,-0.587783,0.539894,0.656807, --0.860698,0.251151,-0.442858,0.000000,-0.860698,0.251151,-0.442858,0.438926,0.305137, --0.809018,-0.000000,-0.587783,0.000000,-0.809018,-0.000000,-0.587783,0.539894,0.656807, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.433048,0.129063, --0.860698,0.251151,-0.442858,0.000000,-0.860698,0.251151,-0.442858,0.438926,0.305137, --0.587786,-0.000000,-0.809017,0.000000,-0.587786,-0.000000,-0.809017,0.496685,0.312438, --0.670819,-0.276397,-0.688191,0.000000,-0.670819,-0.276397,-0.688191,0.567324,0.570882, --0.809018,-0.000000,-0.587783,0.000000,-0.809018,-0.000000,-0.587783,0.539894,0.656807, --0.670819,-0.276397,-0.688191,0.000000,-0.670819,-0.276397,-0.688191,0.567324,0.570882, --0.861803,-0.276396,-0.425324,0.000000,-0.861803,-0.276396,-0.425324,0.593723,0.650945, --0.809018,-0.000000,-0.587783,0.000000,-0.809018,-0.000000,-0.587783,0.539894,0.656807, --0.809018,-0.000000,-0.587783,0.000000,-0.809018,-0.000000,-0.587783,0.539894,0.656807, --0.861803,-0.276396,-0.425324,0.000000,-0.861803,-0.276396,-0.425324,0.593723,0.650945, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.433048,0.129063, --0.861803,-0.276396,-0.425324,0.000000,-0.861803,-0.276396,-0.425324,0.593723,0.650945, --0.956626,-0.251149,-0.147618,0.000000,-0.956626,-0.251149,-0.147618,0.304489,0.071876, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.433048,0.129063, --0.436007,-0.251152,-0.864188,0.000000,-0.436007,-0.251152,-0.864188,0.134945,0.284572, --0.483971,-0.502302,-0.716565,0.000000,-0.483971,-0.502302,-0.716565,0.250122,0.728931, --0.670819,-0.276397,-0.688191,0.000000,-0.670819,-0.276397,-0.688191,0.567324,0.570882, --0.483971,-0.502302,-0.716565,0.000000,-0.483971,-0.502302,-0.716565,0.250122,0.728931, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,0.291456,0.662685, --0.670819,-0.276397,-0.688191,0.000000,-0.670819,-0.276397,-0.688191,0.567324,0.570882, --0.670819,-0.276397,-0.688191,0.000000,-0.670819,-0.276397,-0.688191,0.567324,0.570882, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,0.291456,0.662685, --0.861803,-0.276396,-0.425324,0.000000,-0.861803,-0.276396,-0.425324,0.593723,0.650945, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,0.291456,0.662685, --0.831051,-0.502299,-0.238853,0.000000,-0.831051,-0.502299,-0.238853,0.246383,0.648358, --0.861803,-0.276396,-0.425324,0.000000,-0.861803,-0.276396,-0.425324,0.593723,0.650945, --0.861803,-0.276396,-0.425324,0.000000,-0.861803,-0.276396,-0.425324,0.593723,0.650945, --0.831051,-0.502299,-0.238853,0.000000,-0.831051,-0.502299,-0.238853,0.246383,0.648358, --0.956626,-0.251149,-0.147618,0.000000,-0.956626,-0.251149,-0.147618,0.304489,0.071876, --0.831051,-0.502299,-0.238853,0.000000,-0.831051,-0.502299,-0.238853,0.246383,0.648358, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.956626,-0.251149,-0.147618,0.000000,-0.956626,-0.251149,-0.147618,0.304489,0.071876, -0.436007,0.251152,-0.864188,0.000000,0.436007,0.251152,-0.864188,0.221600,0.149916, -0.155215,0.251152,-0.955422,0.000000,0.155215,0.251152,-0.955422,0.115709,0.094716, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.768276,0.421330, -0.587786,-0.000000,-0.809017,0.000000,0.587786,-0.000000,-0.809017,0.235205,0.325266, -0.309017,-0.000000,-0.951056,0.000000,0.309017,-0.000000,-0.951056,0.316839,0.581107, -0.436007,0.251152,-0.864188,0.000000,0.436007,0.251152,-0.864188,0.221600,0.149916, -0.687159,-0.251152,-0.681715,0.000000,0.687159,-0.251152,-0.681715,0.268675,0.239476, -0.447216,-0.276398,-0.850648,0.000000,0.447216,-0.276398,-0.850648,0.341211,0.489117, -0.587786,-0.000000,-0.809017,0.000000,0.587786,-0.000000,-0.809017,0.235205,0.325266, -0.436007,0.251152,-0.864188,0.000000,0.436007,0.251152,-0.864188,0.221600,0.149916, -0.309017,-0.000000,-0.951056,0.000000,0.309017,-0.000000,-0.951056,0.316839,0.581107, -0.155215,0.251152,-0.955422,0.000000,0.155215,0.251152,-0.955422,0.115709,0.094716, -0.309017,-0.000000,-0.951056,0.000000,0.309017,-0.000000,-0.951056,0.316839,0.581107, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.193762,0.248844, -0.155215,0.251152,-0.955422,0.000000,0.155215,0.251152,-0.955422,0.115709,0.094716, -0.587786,-0.000000,-0.809017,0.000000,0.587786,-0.000000,-0.809017,0.235205,0.325266, -0.447216,-0.276398,-0.850648,0.000000,0.447216,-0.276398,-0.850648,0.341211,0.489117, -0.309017,-0.000000,-0.951056,0.000000,0.309017,-0.000000,-0.951056,0.316839,0.581107, -0.447216,-0.276398,-0.850648,0.000000,0.447216,-0.276398,-0.850648,0.341211,0.489117, -0.138199,-0.276398,-0.951055,0.000000,0.138199,-0.276398,-0.951055,0.346308,0.665057, -0.309017,-0.000000,-0.951056,0.000000,0.309017,-0.000000,-0.951056,0.316839,0.581107, -0.309017,-0.000000,-0.951056,0.000000,0.309017,-0.000000,-0.951056,0.316839,0.581107, -0.138199,-0.276398,-0.951055,0.000000,0.138199,-0.276398,-0.951055,0.346308,0.665057, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.193762,0.248844, -0.138199,-0.276398,-0.951055,0.000000,0.138199,-0.276398,-0.951055,0.346308,0.665057, --0.155215,-0.251152,-0.955422,0.000000,-0.155215,-0.251152,-0.955422,0.129692,0.189429, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.193762,0.248844, -0.687159,-0.251152,-0.681715,0.000000,0.687159,-0.251152,-0.681715,0.268675,0.239476, -0.531941,-0.502302,-0.681712,0.000000,0.531941,-0.502302,-0.681712,0.833640,0.738875, -0.447216,-0.276398,-0.850648,0.000000,0.447216,-0.276398,-0.850648,0.341211,0.489117, -0.531941,-0.502302,-0.681712,0.000000,0.531941,-0.502302,-0.681712,0.833640,0.738875, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.881800,0.682461, -0.447216,-0.276398,-0.850648,0.000000,0.447216,-0.276398,-0.850648,0.341211,0.489117, -0.447216,-0.276398,-0.850648,0.000000,0.447216,-0.276398,-0.850648,0.341211,0.489117, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.881800,0.682461, -0.138199,-0.276398,-0.951055,0.000000,0.138199,-0.276398,-0.951055,0.346308,0.665057, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.881800,0.682461, --0.029639,-0.502302,-0.864184,0.000000,-0.029639,-0.502302,-0.864184,0.836927,0.658241, -0.138199,-0.276398,-0.951055,0.000000,0.138199,-0.276398,-0.951055,0.346308,0.665057, -0.138199,-0.276398,-0.951055,0.000000,0.138199,-0.276398,-0.951055,0.346308,0.665057, --0.029639,-0.502302,-0.864184,0.000000,-0.029639,-0.502302,-0.864184,0.836927,0.658241, --0.155215,-0.251152,-0.955422,0.000000,-0.155215,-0.251152,-0.955422,0.129692,0.189429, --0.029639,-0.502302,-0.864184,0.000000,-0.029639,-0.502302,-0.864184,0.836927,0.658241, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.750122,0.271069, --0.155215,-0.251152,-0.955422,0.000000,-0.155215,-0.251152,-0.955422,0.129692,0.189429, -0.436007,0.251152,0.864188,0.000000,0.436007,0.251152,0.864188,0.900083,0.348597, -0.483971,0.502302,0.716565,0.000000,0.483971,0.502302,0.716565,1.036828,0.167036, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.304489,0.071876, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.757596,0.176140, -0.670820,0.276396,0.688190,0.000000,0.670820,0.276396,0.688190,0.370330,0.575469, -0.436007,0.251152,0.864188,0.000000,0.436007,0.251152,0.864188,0.900083,0.348597, -0.687159,-0.251152,0.681715,0.000000,0.687159,-0.251152,0.681715,0.702477,0.326245, -0.809019,-0.000002,0.587783,0.000000,0.809019,-0.000002,0.587783,0.400083,0.651403, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.757596,0.176140, -0.436007,0.251152,0.864188,0.000000,0.436007,0.251152,0.864188,0.900083,0.348597, -0.670820,0.276396,0.688190,0.000000,0.670820,0.276396,0.688190,0.370330,0.575469, -0.483971,0.502302,0.716565,0.000000,0.483971,0.502302,0.716565,1.036828,0.167036, -0.670820,0.276396,0.688190,0.000000,0.670820,0.276396,0.688190,0.370330,0.575469, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,1.003325,0.262529, -0.483971,0.502302,0.716565,0.000000,0.483971,0.502302,0.716565,1.036828,0.167036, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.757596,0.176140, -0.809019,-0.000002,0.587783,0.000000,0.809019,-0.000002,0.587783,0.400083,0.651403, -0.670820,0.276396,0.688190,0.000000,0.670820,0.276396,0.688190,0.370330,0.575469, -0.809019,-0.000002,0.587783,0.000000,0.809019,-0.000002,0.587783,0.400083,0.651403, -0.861804,0.276394,0.425323,0.000000,0.861804,0.276394,0.425323,0.116405,0.604155, -0.670820,0.276396,0.688190,0.000000,0.670820,0.276396,0.688190,0.370330,0.575469, -0.670820,0.276396,0.688190,0.000000,0.670820,0.276396,0.688190,0.370330,0.575469, -0.861804,0.276394,0.425323,0.000000,0.861804,0.276394,0.425323,0.116405,0.604155, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,1.003325,0.262529, -0.861804,0.276394,0.425323,0.000000,0.861804,0.276394,0.425323,0.116405,0.604155, -0.831051,0.502299,0.238853,0.000000,0.831051,0.502299,0.238853,0.291096,0.327017, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,1.003325,0.262529, -0.687159,-0.251152,0.681715,0.000000,0.687159,-0.251152,0.681715,0.702477,0.326245, -0.860698,-0.251151,0.442858,0.000000,0.860698,-0.251151,0.442858,0.689049,0.234408, -0.809019,-0.000002,0.587783,0.000000,0.809019,-0.000002,0.587783,0.400083,0.651403, -0.860698,-0.251151,0.442858,0.000000,0.860698,-0.251151,0.442858,0.689049,0.234408, -0.951058,-0.000000,0.309013,0.000000,0.951058,-0.000000,0.309013,0.646443,0.311386, -0.809019,-0.000002,0.587783,0.000000,0.809019,-0.000002,0.587783,0.400083,0.651403, -0.809019,-0.000002,0.587783,0.000000,0.809019,-0.000002,0.587783,0.400083,0.651403, -0.951058,-0.000000,0.309013,0.000000,0.951058,-0.000000,0.309013,0.646443,0.311386, -0.861804,0.276394,0.425323,0.000000,0.861804,0.276394,0.425323,0.116405,0.604155, -0.951058,-0.000000,0.309013,0.000000,0.951058,-0.000000,0.309013,0.646443,0.311386, -0.956626,0.251149,0.147618,0.000000,0.956626,0.251149,0.147618,0.658365,0.135762, -0.861804,0.276394,0.425323,0.000000,0.861804,0.276394,0.425323,0.116405,0.604155, -0.861804,0.276394,0.425323,0.000000,0.861804,0.276394,0.425323,0.116405,0.604155, -0.956626,0.251149,0.147618,0.000000,0.956626,0.251149,0.147618,0.658365,0.135762, -0.831051,0.502299,0.238853,0.000000,0.831051,0.502299,0.238853,0.291096,0.327017, -0.956626,0.251149,0.147618,0.000000,0.956626,0.251149,0.147618,0.658365,0.135762, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.542767,0.333057, -0.831051,0.502299,0.238853,0.000000,0.831051,0.502299,0.238853,0.291096,0.327017, --0.687159,0.251152,0.681715,0.000000,-0.687159,0.251152,0.681715,0.856930,0.159299, --0.531941,0.502302,0.681712,0.000000,-0.531941,0.502302,0.681712,0.074553,0.260244, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,1.115709,0.094716, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.946597,0.195033, --0.447216,0.276397,0.850649,0.000000,-0.447216,0.276397,0.850649,0.141510,0.512645, --0.687159,0.251152,0.681715,0.000000,-0.687159,0.251152,0.681715,0.856930,0.159299, --0.436007,-0.251152,0.864188,0.000000,-0.436007,-0.251152,0.864188,0.813138,0.249674, --0.309017,-0.000001,0.951056,0.000000,-0.309017,-0.000001,0.951056,0.146443,0.688614, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.946597,0.195033, --0.687159,0.251152,0.681715,0.000000,-0.687159,0.251152,0.681715,0.856930,0.159299, --0.447216,0.276397,0.850649,0.000000,-0.447216,0.276397,0.850649,0.141510,0.512645, --0.531941,0.502302,0.681712,0.000000,-0.531941,0.502302,0.681712,0.074553,0.260244, --0.447216,0.276397,0.850649,0.000000,-0.447216,0.276397,0.850649,0.141510,0.512645, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.036828,0.167036, --0.531941,0.502302,0.681712,0.000000,-0.531941,0.502302,0.681712,0.074553,0.260244, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.946597,0.195033, --0.309017,-0.000001,0.951056,0.000000,-0.309017,-0.000001,0.951056,0.146443,0.688614, --0.447216,0.276397,0.850649,0.000000,-0.447216,0.276397,0.850649,0.141510,0.512645, --0.309017,-0.000001,0.951056,0.000000,-0.309017,-0.000001,0.951056,0.146443,0.688614, --0.138199,0.276397,0.951055,0.000000,-0.138199,0.276397,0.951055,0.171061,0.598834, --0.447216,0.276397,0.850649,0.000000,-0.447216,0.276397,0.850649,0.141510,0.512645, --0.447216,0.276397,0.850649,0.000000,-0.447216,0.276397,0.850649,0.141510,0.512645, --0.138199,0.276397,0.951055,0.000000,-0.138199,0.276397,0.951055,0.171061,0.598834, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.036828,0.167036, --0.138199,0.276397,0.951055,0.000000,-0.138199,0.276397,0.951055,0.171061,0.598834, -0.029639,0.502302,0.864184,0.000000,0.029639,0.502302,0.864184,1.039894,0.343193, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.036828,0.167036, --0.436007,-0.251152,0.864188,0.000000,-0.436007,-0.251152,0.864188,0.813138,0.249674, --0.155215,-0.251152,0.955422,0.000000,-0.155215,-0.251152,0.955422,0.885924,0.257323, --0.309017,-0.000001,0.951056,0.000000,-0.309017,-0.000001,0.951056,0.146443,0.688614, --0.155215,-0.251152,0.955422,0.000000,-0.155215,-0.251152,0.955422,0.885924,0.257323, --0.000000,-0.000000,1.000000,0.000000,-0.000000,-0.000000,1.000000,0.846308,0.334943, --0.309017,-0.000001,0.951056,0.000000,-0.309017,-0.000001,0.951056,0.146443,0.688614, --0.309017,-0.000001,0.951056,0.000000,-0.309017,-0.000001,0.951056,0.146443,0.688614, --0.000000,-0.000000,1.000000,0.000000,-0.000000,-0.000000,1.000000,0.846308,0.334943, --0.138199,0.276397,0.951055,0.000000,-0.138199,0.276397,0.951055,0.171061,0.598834, --0.000000,-0.000000,1.000000,0.000000,-0.000000,-0.000000,1.000000,0.846308,0.334943, -0.155215,0.251152,0.955422,0.000000,0.155215,0.251152,0.955422,0.944254,0.290379, --0.138199,0.276397,0.951055,0.000000,-0.138199,0.276397,0.951055,0.171061,0.598834, --0.138199,0.276397,0.951055,0.000000,-0.138199,0.276397,0.951055,0.171061,0.598834, -0.155215,0.251152,0.955422,0.000000,0.155215,0.251152,0.955422,0.944254,0.290379, -0.029639,0.502302,0.864184,0.000000,0.029639,0.502302,0.864184,1.039894,0.343193, -0.155215,0.251152,0.955422,0.000000,0.155215,0.251152,0.955422,0.944254,0.290379, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.304489,0.071876, -0.029639,0.502302,0.864184,0.000000,0.029639,0.502302,0.864184,1.039894,0.343193, --0.860698,0.251151,-0.442858,0.000000,-0.860698,0.251151,-0.442858,0.438926,0.305137, --0.812729,0.502301,-0.295238,0.000000,-0.812729,0.502301,-0.295238,0.093723,0.349056, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.952607,0.099770, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.433048,0.129063, --0.947213,0.276396,-0.162458,0.000000,-0.947213,0.276396,-0.162458,0.202477,0.673755, --0.860698,0.251151,-0.442858,0.000000,-0.860698,0.251151,-0.442858,0.438926,0.305137, --0.956626,-0.251149,-0.147618,0.000000,-0.956626,-0.251149,-0.147618,0.304489,0.071876, --1.000000,0.000001,0.000000,0.000000,-1.000000,0.000001,0.000000,0.912676,0.606305, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.433048,0.129063, --0.860698,0.251151,-0.442858,0.000000,-0.860698,0.251151,-0.442858,0.438926,0.305137, --0.947213,0.276396,-0.162458,0.000000,-0.947213,0.276396,-0.162458,0.202477,0.673755, --0.812729,0.502301,-0.295238,0.000000,-0.812729,0.502301,-0.295238,0.093723,0.349056, --0.947213,0.276396,-0.162458,0.000000,-0.947213,0.276396,-0.162458,0.202477,0.673755, --0.850648,0.525736,-0.000000,0.000000,-0.850648,0.525736,-0.000000,0.039894,0.343193, --0.812729,0.502301,-0.295238,0.000000,-0.812729,0.502301,-0.295238,0.093723,0.349056, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.433048,0.129063, --1.000000,0.000001,0.000000,0.000000,-1.000000,0.000001,0.000000,0.912676,0.606305, --0.947213,0.276396,-0.162458,0.000000,-0.947213,0.276396,-0.162458,0.202477,0.673755, --1.000000,0.000001,0.000000,0.000000,-1.000000,0.000001,0.000000,0.912676,0.606305, --0.947213,0.276397,0.162458,0.000000,-0.947213,0.276397,0.162458,0.941248,0.518705, --0.947213,0.276396,-0.162458,0.000000,-0.947213,0.276396,-0.162458,0.202477,0.673755, --0.947213,0.276396,-0.162458,0.000000,-0.947213,0.276396,-0.162458,0.202477,0.673755, --0.947213,0.276397,0.162458,0.000000,-0.947213,0.276397,0.162458,0.941248,0.518705, --0.850648,0.525736,-0.000000,0.000000,-0.850648,0.525736,-0.000000,0.039894,0.343193, --0.947213,0.276397,0.162458,0.000000,-0.947213,0.276397,0.162458,0.941248,0.518705, --0.812729,0.502301,0.295238,0.000000,-0.812729,0.502301,0.295238,0.003325,0.262529, --0.850648,0.525736,-0.000000,0.000000,-0.850648,0.525736,-0.000000,0.039894,0.343193, --0.956626,-0.251149,-0.147618,0.000000,-0.956626,-0.251149,-0.147618,0.304489,0.071876, --0.956626,-0.251149,0.147618,0.000000,-0.956626,-0.251149,0.147618,0.397050,0.226232, --1.000000,0.000001,0.000000,0.000000,-1.000000,0.000001,0.000000,0.912676,0.606305, --0.956626,-0.251149,0.147618,0.000000,-0.956626,-0.251149,0.147618,0.397050,0.226232, --0.951058,-0.000000,0.309013,0.000000,-0.951058,-0.000000,0.309013,0.326823,0.166086, --1.000000,0.000001,0.000000,0.000000,-1.000000,0.000001,0.000000,0.912676,0.606305, --1.000000,0.000001,0.000000,0.000000,-1.000000,0.000001,0.000000,0.912676,0.606305, --0.951058,-0.000000,0.309013,0.000000,-0.951058,-0.000000,0.309013,0.326823,0.166086, --0.947213,0.276397,0.162458,0.000000,-0.947213,0.276397,0.162458,0.941248,0.518705, --0.951058,-0.000000,0.309013,0.000000,-0.951058,-0.000000,0.309013,0.326823,0.166086, --0.860698,0.251151,0.442858,0.000000,-0.860698,0.251151,0.442858,0.333640,0.261125, --0.947213,0.276397,0.162458,0.000000,-0.947213,0.276397,0.162458,0.941248,0.518705, --0.947213,0.276397,0.162458,0.000000,-0.947213,0.276397,0.162458,0.941248,0.518705, --0.860698,0.251151,0.442858,0.000000,-0.860698,0.251151,0.442858,0.333640,0.261125, --0.812729,0.502301,0.295238,0.000000,-0.812729,0.502301,0.295238,0.003325,0.262529, --0.860698,0.251151,0.442858,0.000000,-0.860698,0.251151,0.442858,0.333640,0.261125, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,1.115709,0.094716, --0.812729,0.502301,0.295238,0.000000,-0.812729,0.502301,0.295238,0.003325,0.262529, -0.155215,0.251152,-0.955422,0.000000,0.155215,0.251152,-0.955422,0.115709,0.094716, -0.029639,0.502302,-0.864184,0.000000,0.029639,0.502302,-0.864184,0.791278,0.505149, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.768276,0.421330, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.193762,0.248844, --0.138199,0.276397,-0.951055,0.000000,-0.138199,0.276397,-0.951055,0.938926,0.694863, -0.155215,0.251152,-0.955422,0.000000,0.155215,0.251152,-0.955422,0.115709,0.094716, --0.155215,-0.251152,-0.955422,0.000000,-0.155215,-0.251152,-0.955422,0.129692,0.189429, --0.309016,-0.000000,-0.951057,0.000000,-0.309016,-0.000000,-0.951057,0.967747,0.608792, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.193762,0.248844, -0.155215,0.251152,-0.955422,0.000000,0.155215,0.251152,-0.955422,0.115709,0.094716, --0.138199,0.276397,-0.951055,0.000000,-0.138199,0.276397,-0.951055,0.938926,0.694863, -0.029639,0.502302,-0.864184,0.000000,0.029639,0.502302,-0.864184,0.791278,0.505149, --0.138199,0.276397,-0.951055,0.000000,-0.138199,0.276397,-0.951055,0.938926,0.694863, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.863599,0.594041, -0.029639,0.502302,-0.864184,0.000000,0.029639,0.502302,-0.864184,0.791278,0.505149, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.193762,0.248844, --0.309016,-0.000000,-0.951057,0.000000,-0.309016,-0.000000,-0.951057,0.967747,0.608792, --0.138199,0.276397,-0.951055,0.000000,-0.138199,0.276397,-0.951055,0.938926,0.694863, --0.309016,-0.000000,-0.951057,0.000000,-0.309016,-0.000000,-0.951057,0.967747,0.608792, --0.447215,0.276397,-0.850649,0.000000,-0.447215,0.276397,-0.850649,0.996685,0.687562, --0.138199,0.276397,-0.951055,0.000000,-0.138199,0.276397,-0.951055,0.938926,0.694863, --0.138199,0.276397,-0.951055,0.000000,-0.138199,0.276397,-0.951055,0.938926,0.694863, --0.447215,0.276397,-0.850649,0.000000,-0.447215,0.276397,-0.850649,0.996685,0.687562, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.863599,0.594041, --0.447215,0.276397,-0.850649,0.000000,-0.447215,0.276397,-0.850649,0.996685,0.687562, --0.531941,0.502302,-0.681712,0.000000,-0.531941,0.502302,-0.681712,0.814480,0.588860, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.863599,0.594041, --0.155215,-0.251152,-0.955422,0.000000,-0.155215,-0.251152,-0.955422,0.129692,0.189429, --0.436007,-0.251152,-0.864188,0.000000,-0.436007,-0.251152,-0.864188,0.134945,0.284572, --0.309016,-0.000000,-0.951057,0.000000,-0.309016,-0.000000,-0.951057,0.967747,0.608792, --0.436007,-0.251152,-0.864188,0.000000,-0.436007,-0.251152,-0.864188,0.134945,0.284572, --0.587786,-0.000000,-0.809017,0.000000,-0.587786,-0.000000,-0.809017,0.496685,0.312438, --0.309016,-0.000000,-0.951057,0.000000,-0.309016,-0.000000,-0.951057,0.967747,0.608792, --0.309016,-0.000000,-0.951057,0.000000,-0.309016,-0.000000,-0.951057,0.967747,0.608792, --0.587786,-0.000000,-0.809017,0.000000,-0.587786,-0.000000,-0.809017,0.496685,0.312438, --0.447215,0.276397,-0.850649,0.000000,-0.447215,0.276397,-0.850649,0.996685,0.687562, --0.587786,-0.000000,-0.809017,0.000000,-0.587786,-0.000000,-0.809017,0.496685,0.312438, --0.687159,0.251152,-0.681715,0.000000,-0.687159,0.251152,-0.681715,0.477658,0.222612, --0.447215,0.276397,-0.850649,0.000000,-0.447215,0.276397,-0.850649,0.996685,0.687562, --0.447215,0.276397,-0.850649,0.000000,-0.447215,0.276397,-0.850649,0.996685,0.687562, --0.687159,0.251152,-0.681715,0.000000,-0.687159,0.251152,-0.681715,0.477658,0.222612, --0.531941,0.502302,-0.681712,0.000000,-0.531941,0.502302,-0.681712,0.814480,0.588860, --0.687159,0.251152,-0.681715,0.000000,-0.687159,0.251152,-0.681715,0.477658,0.222612, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.952607,0.099770, --0.531941,0.502302,-0.681712,0.000000,-0.531941,0.502302,-0.681712,0.814480,0.588860, -0.956626,0.251149,-0.147618,0.000000,0.956626,0.251149,-0.147618,0.610420,0.226784, -0.831051,0.502299,-0.238853,0.000000,0.831051,0.502299,-0.238853,0.891200,0.515555, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.542767,0.333057, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.546072,0.156902, -0.861804,0.276396,-0.425322,0.000000,0.861804,0.276396,-0.425322,1.042767,0.666943, -0.956626,0.251149,-0.147618,0.000000,0.956626,0.251149,-0.147618,0.610420,0.226784, -0.860698,-0.251151,-0.442858,0.000000,0.860698,-0.251151,-0.442858,0.543816,0.252266, -0.809019,0.000000,-0.587782,0.000000,0.809019,0.000000,-0.587782,0.615709,0.905284, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.546072,0.156902, -0.956626,0.251149,-0.147618,0.000000,0.956626,0.251149,-0.147618,0.610420,0.226784, -0.861804,0.276396,-0.425322,0.000000,0.861804,0.276396,-0.425322,1.042767,0.666943, -0.831051,0.502299,-0.238853,0.000000,0.831051,0.502299,-0.238853,0.891200,0.515555, -0.861804,0.276396,-0.425322,0.000000,0.861804,0.276396,-0.425322,1.042767,0.666943, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.816839,0.418893, -0.831051,0.502299,-0.238853,0.000000,0.831051,0.502299,-0.238853,0.891200,0.515555, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.546072,0.156902, -0.809019,0.000000,-0.587782,0.000000,0.809019,0.000000,-0.587782,0.615709,0.905284, -0.861804,0.276396,-0.425322,0.000000,0.861804,0.276396,-0.425322,1.042767,0.666943, -0.809019,0.000000,-0.587782,0.000000,0.809019,0.000000,-0.587782,0.615709,0.905284, -0.670821,0.276397,-0.688189,0.000000,0.670821,0.276397,-0.688189,0.804489,0.928124, -0.861804,0.276396,-0.425322,0.000000,0.861804,0.276396,-0.425322,1.042767,0.666943, -0.861804,0.276396,-0.425322,0.000000,0.861804,0.276396,-0.425322,1.042767,0.666943, -0.670821,0.276397,-0.688189,0.000000,0.670821,0.276397,-0.688189,0.804489,0.928124, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.816839,0.418893, -0.670821,0.276397,-0.688189,0.000000,0.670821,0.276397,-0.688189,0.804489,0.928124, -0.483971,0.502302,-0.716565,0.000000,0.483971,0.502302,-0.716565,0.841211,0.510884, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.816839,0.418893, -0.860698,-0.251151,-0.442858,0.000000,0.860698,-0.251151,-0.442858,0.543816,0.252266, -0.687159,-0.251152,-0.681715,0.000000,0.687159,-0.251152,-0.681715,0.268675,0.239476, -0.809019,0.000000,-0.587782,0.000000,0.809019,0.000000,-0.587782,0.615709,0.905284, -0.687159,-0.251152,-0.681715,0.000000,0.687159,-0.251152,-0.681715,0.268675,0.239476, -0.587786,-0.000000,-0.809017,0.000000,0.587786,-0.000000,-0.809017,0.235205,0.325266, -0.809019,0.000000,-0.587782,0.000000,0.809019,0.000000,-0.587782,0.615709,0.905284, -0.809019,0.000000,-0.587782,0.000000,0.809019,0.000000,-0.587782,0.615709,0.905284, -0.587786,-0.000000,-0.809017,0.000000,0.587786,-0.000000,-0.809017,0.235205,0.325266, -0.670821,0.276397,-0.688189,0.000000,0.670821,0.276397,-0.688189,0.804489,0.928124, -0.587786,-0.000000,-0.809017,0.000000,0.587786,-0.000000,-0.809017,0.235205,0.325266, -0.436007,0.251152,-0.864188,0.000000,0.436007,0.251152,-0.864188,0.221600,0.149916, -0.670821,0.276397,-0.688189,0.000000,0.670821,0.276397,-0.688189,0.804489,0.928124, -0.670821,0.276397,-0.688189,0.000000,0.670821,0.276397,-0.688189,0.804489,0.928124, -0.436007,0.251152,-0.864188,0.000000,0.436007,0.251152,-0.864188,0.221600,0.149916, -0.483971,0.502302,-0.716565,0.000000,0.483971,0.502302,-0.716565,0.841211,0.510884, -0.436007,0.251152,-0.864188,0.000000,0.436007,0.251152,-0.864188,0.221600,0.149916, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.768276,0.421330, -0.483971,0.502302,-0.716565,0.000000,0.483971,0.502302,-0.716565,0.841211,0.510884, -0.077607,0.967950,0.238853,0.000000,0.077607,0.967950,0.238853,0.591499,0.483164, -0.251147,0.967949,0.000000,0.000000,0.251147,0.967949,0.000000,0.663633,0.570564, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.589135,0.315387, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.641510,0.487355, -0.361800,0.894429,0.262863,0.000000,0.361800,0.894429,0.262863,0.499999,0.979947, -0.077607,0.967950,0.238853,0.000000,0.077607,0.967950,0.238853,0.591499,0.483164, -0.232822,0.657519,0.716563,0.000000,0.232822,0.657519,0.716563,0.616405,0.395845, -0.447209,0.723612,0.525728,0.000000,0.447209,0.723612,0.525728,0.629692,0.810571, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.641510,0.487355, -0.077607,0.967950,0.238853,0.000000,0.077607,0.967950,0.238853,0.591499,0.483164, -0.361800,0.894429,0.262863,0.000000,0.361800,0.894429,0.262863,0.499999,0.979947, -0.251147,0.967949,0.000000,0.000000,0.251147,0.967949,0.000000,0.663633,0.570564, -0.361800,0.894429,0.262863,0.000000,0.361800,0.894429,0.262863,0.499999,0.979947, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.615418,0.565866, -0.251147,0.967949,0.000000,0.000000,0.251147,0.967949,0.000000,0.663633,0.570564, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.641510,0.487355, -0.447209,0.723612,0.525728,0.000000,0.447209,0.723612,0.525728,0.629692,0.810571, -0.361800,0.894429,0.262863,0.000000,0.361800,0.894429,0.262863,0.499999,0.979947, -0.447209,0.723612,0.525728,0.000000,0.447209,0.723612,0.525728,0.629692,0.810571, -0.638194,0.723610,0.262864,0.000000,0.638194,0.723610,0.262864,0.721600,0.850084, -0.361800,0.894429,0.262863,0.000000,0.361800,0.894429,0.262863,0.499999,0.979947, -0.361800,0.894429,0.262863,0.000000,0.361800,0.894429,0.262863,0.499999,0.979947, -0.638194,0.723610,0.262864,0.000000,0.638194,0.723610,0.262864,0.721600,0.850084, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.615418,0.565866, -0.638194,0.723610,0.262864,0.000000,0.638194,0.723610,0.262864,0.721600,0.850084, -0.753442,0.657515,0.000000,0.000000,0.753442,0.657515,0.000000,0.870330,0.424531, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.615418,0.565866, -0.232822,0.657519,0.716563,0.000000,0.232822,0.657519,0.716563,0.616405,0.395845, -0.483971,0.502302,0.716565,0.000000,0.483971,0.502302,0.716565,1.036828,0.167036, -0.447209,0.723612,0.525728,0.000000,0.447209,0.723612,0.525728,0.629692,0.810571, -0.483971,0.502302,0.716565,0.000000,0.483971,0.502302,0.716565,1.036828,0.167036, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,1.003325,0.262529, -0.447209,0.723612,0.525728,0.000000,0.447209,0.723612,0.525728,0.629692,0.810571, -0.447209,0.723612,0.525728,0.000000,0.447209,0.723612,0.525728,0.629692,0.810571, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,1.003325,0.262529, -0.638194,0.723610,0.262864,0.000000,0.638194,0.723610,0.262864,0.721600,0.850084, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,1.003325,0.262529, -0.831051,0.502299,0.238853,0.000000,0.831051,0.502299,0.238853,0.291096,0.327017, -0.638194,0.723610,0.262864,0.000000,0.638194,0.723610,0.262864,0.721600,0.850084, -0.638194,0.723610,0.262864,0.000000,0.638194,0.723610,0.262864,0.721600,0.850084, -0.831051,0.502299,0.238853,0.000000,0.831051,0.502299,0.238853,0.291096,0.327017, -0.753442,0.657515,0.000000,0.000000,0.753442,0.657515,0.000000,0.870330,0.424531, -0.831051,0.502299,0.238853,0.000000,0.831051,0.502299,0.238853,0.291096,0.327017, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.542767,0.333057, -0.753442,0.657515,0.000000,0.000000,0.753442,0.657515,0.000000,0.870330,0.424531, --0.203181,0.967950,0.147618,0.000000,-0.203181,0.967950,0.147618,0.691461,0.492781, -0.077607,0.967950,0.238853,0.000000,0.077607,0.967950,0.238853,0.591499,0.483164, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.589135,0.315387, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.671061,0.401166, --0.138197,0.894430,0.425320,0.000000,-0.138197,0.894430,0.425320,0.693762,0.751156, --0.203181,0.967950,0.147618,0.000000,-0.203181,0.967950,0.147618,0.691461,0.492781, --0.609547,0.657519,0.442856,0.000000,-0.609547,0.657519,0.442856,0.418131,0.563385, --0.361804,0.723612,0.587778,0.000000,-0.361804,0.723612,0.587778,0.826823,0.833914, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.671061,0.401166, --0.203181,0.967950,0.147618,0.000000,-0.203181,0.967950,0.147618,0.691461,0.492781, --0.138197,0.894430,0.425320,0.000000,-0.138197,0.894430,0.425320,0.693762,0.751156, -0.077607,0.967950,0.238853,0.000000,0.077607,0.967950,0.238853,0.591499,0.483164, --0.138197,0.894430,0.425320,0.000000,-0.138197,0.894430,0.425320,0.693762,0.751156, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.641510,0.487355, -0.077607,0.967950,0.238853,0.000000,0.077607,0.967950,0.238853,0.591499,0.483164, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.671061,0.401166, --0.361804,0.723612,0.587778,0.000000,-0.361804,0.723612,0.587778,0.826823,0.833914, --0.138197,0.894430,0.425320,0.000000,-0.138197,0.894430,0.425320,0.693762,0.751156, --0.361804,0.723612,0.587778,0.000000,-0.361804,0.723612,0.587778,0.826823,0.833914, --0.052790,0.723612,0.688185,0.000000,-0.052790,0.723612,0.688185,0.768674,0.760524, --0.138197,0.894430,0.425320,0.000000,-0.138197,0.894430,0.425320,0.693762,0.751156, --0.138197,0.894430,0.425320,0.000000,-0.138197,0.894430,0.425320,0.693762,0.751156, --0.052790,0.723612,0.688185,0.000000,-0.052790,0.723612,0.688185,0.768674,0.760524, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.641510,0.487355, --0.052790,0.723612,0.688185,0.000000,-0.052790,0.723612,0.688185,0.768674,0.760524, -0.232822,0.657519,0.716563,0.000000,0.232822,0.657519,0.716563,0.616405,0.395845, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.641510,0.487355, --0.609547,0.657519,0.442856,0.000000,-0.609547,0.657519,0.442856,0.418131,0.563385, --0.531941,0.502302,0.681712,0.000000,-0.531941,0.502302,0.681712,0.074553,0.260244, --0.361804,0.723612,0.587778,0.000000,-0.361804,0.723612,0.587778,0.826823,0.833914, --0.531941,0.502302,0.681712,0.000000,-0.531941,0.502302,0.681712,0.074553,0.260244, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.036828,0.167036, --0.361804,0.723612,0.587778,0.000000,-0.361804,0.723612,0.587778,0.826823,0.833914, --0.361804,0.723612,0.587778,0.000000,-0.361804,0.723612,0.587778,0.826823,0.833914, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.036828,0.167036, --0.052790,0.723612,0.688185,0.000000,-0.052790,0.723612,0.688185,0.768674,0.760524, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.036828,0.167036, -0.029639,0.502302,0.864184,0.000000,0.029639,0.502302,0.864184,1.039894,0.343193, --0.052790,0.723612,0.688185,0.000000,-0.052790,0.723612,0.688185,0.768674,0.760524, --0.052790,0.723612,0.688185,0.000000,-0.052790,0.723612,0.688185,0.768674,0.760524, -0.029639,0.502302,0.864184,0.000000,0.029639,0.502302,0.864184,1.039894,0.343193, -0.232822,0.657519,0.716563,0.000000,0.232822,0.657519,0.716563,0.616405,0.395845, -0.029639,0.502302,0.864184,0.000000,0.029639,0.502302,0.864184,1.039894,0.343193, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.304489,0.071876, -0.232822,0.657519,0.716563,0.000000,0.232822,0.657519,0.716563,0.616405,0.395845, --0.203181,0.967950,-0.147618,0.000000,-0.203181,0.967950,-0.147618,0.466205,0.561213, --0.203181,0.967950,0.147618,0.000000,-0.203181,0.967950,0.147618,0.691461,0.492781, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.589135,0.315387, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.391200,0.484445, --0.447210,0.894429,0.000000,0.000000,-0.447210,0.894429,0.000000,0.452607,0.900230, --0.203181,0.967950,-0.147618,0.000000,-0.203181,0.967950,-0.147618,0.466205,0.561213, --0.609547,0.657519,-0.442856,0.000000,-0.609547,0.657519,-0.442856,0.441249,0.481295, --0.670817,0.723611,-0.162457,0.000000,-0.670817,0.723611,-0.162457,0.446597,0.804967, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.391200,0.484445, --0.203181,0.967950,-0.147618,0.000000,-0.203181,0.967950,-0.147618,0.466205,0.561213, --0.447210,0.894429,0.000000,0.000000,-0.447210,0.894429,0.000000,0.452607,0.900230, --0.203181,0.967950,0.147618,0.000000,-0.203181,0.967950,0.147618,0.691461,0.492781, --0.447210,0.894429,0.000000,0.000000,-0.447210,0.894429,0.000000,0.452607,0.900230, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.671061,0.401166, --0.203181,0.967950,0.147618,0.000000,-0.203181,0.967950,0.147618,0.691461,0.492781, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.391200,0.484445, --0.670817,0.723611,-0.162457,0.000000,-0.670817,0.723611,-0.162457,0.446597,0.804967, --0.447210,0.894429,0.000000,0.000000,-0.447210,0.894429,0.000000,0.452607,0.900230, --0.670817,0.723611,-0.162457,0.000000,-0.670817,0.723611,-0.162457,0.446597,0.804967, --0.670817,0.723611,0.162457,0.000000,-0.670817,0.723611,0.162457,0.536828,0.832965, --0.447210,0.894429,0.000000,0.000000,-0.447210,0.894429,0.000000,0.452607,0.900230, --0.447210,0.894429,0.000000,0.000000,-0.447210,0.894429,0.000000,0.452607,0.900230, --0.670817,0.723611,0.162457,0.000000,-0.670817,0.723611,0.162457,0.536828,0.832965, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.671061,0.401166, --0.670817,0.723611,0.162457,0.000000,-0.670817,0.723611,0.162457,0.536828,0.832965, --0.609547,0.657519,0.442856,0.000000,-0.609547,0.657519,0.442856,0.418131,0.563385, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.671061,0.401166, --0.609547,0.657519,-0.442856,0.000000,-0.609547,0.657519,-0.442856,0.441249,0.481295, --0.812729,0.502301,-0.295238,0.000000,-0.812729,0.502301,-0.295238,0.093723,0.349056, --0.670817,0.723611,-0.162457,0.000000,-0.670817,0.723611,-0.162457,0.446597,0.804967, --0.812729,0.502301,-0.295238,0.000000,-0.812729,0.502301,-0.295238,0.093723,0.349056, --0.850648,0.525736,-0.000000,0.000000,-0.850648,0.525736,-0.000000,0.039894,0.343193, --0.670817,0.723611,-0.162457,0.000000,-0.670817,0.723611,-0.162457,0.446597,0.804967, --0.670817,0.723611,-0.162457,0.000000,-0.670817,0.723611,-0.162457,0.446597,0.804967, --0.850648,0.525736,-0.000000,0.000000,-0.850648,0.525736,-0.000000,0.039894,0.343193, --0.670817,0.723611,0.162457,0.000000,-0.670817,0.723611,0.162457,0.536828,0.832965, --0.850648,0.525736,-0.000000,0.000000,-0.850648,0.525736,-0.000000,0.039894,0.343193, --0.812729,0.502301,0.295238,0.000000,-0.812729,0.502301,0.295238,0.003325,0.262529, --0.670817,0.723611,0.162457,0.000000,-0.670817,0.723611,0.162457,0.536828,0.832965, --0.670817,0.723611,0.162457,0.000000,-0.670817,0.723611,0.162457,0.536828,0.832965, --0.812729,0.502301,0.295238,0.000000,-0.812729,0.502301,0.295238,0.003325,0.262529, --0.609547,0.657519,0.442856,0.000000,-0.609547,0.657519,0.442856,0.418131,0.563385, --0.812729,0.502301,0.295238,0.000000,-0.812729,0.502301,0.295238,0.003325,0.262529, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,1.115709,0.094716, --0.609547,0.657519,0.442856,0.000000,-0.609547,0.657519,0.442856,0.418131,0.563385, -0.077607,0.967950,-0.238853,0.000000,0.077607,0.967950,-0.238853,0.412677,0.393695, --0.203181,0.967950,-0.147618,0.000000,-0.203181,0.967950,-0.147618,0.466205,0.561213, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.589135,0.315387, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.491338,0.479977, --0.138197,0.894430,-0.425320,0.000000,-0.138197,0.894430,-0.425320,0.503325,0.737471, -0.077607,0.967950,-0.238853,0.000000,0.077607,0.967950,-0.238853,0.412677,0.393695, -0.232822,0.657519,-0.716563,0.000000,0.232822,0.657519,-0.716563,0.467747,0.391208, --0.052790,0.723612,-0.688185,0.000000,-0.052790,0.723612,-0.688185,0.574552,0.739757, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.491338,0.479977, -0.077607,0.967950,-0.238853,0.000000,0.077607,0.967950,-0.238853,0.412677,0.393695, --0.138197,0.894430,-0.425320,0.000000,-0.138197,0.894430,-0.425320,0.503325,0.737471, --0.203181,0.967950,-0.147618,0.000000,-0.203181,0.967950,-0.147618,0.466205,0.561213, --0.138197,0.894430,-0.425320,0.000000,-0.138197,0.894430,-0.425320,0.503325,0.737471, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.391200,0.484445, --0.203181,0.967950,-0.147618,0.000000,-0.203181,0.967950,-0.147618,0.466205,0.561213, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.491338,0.479977, --0.052790,0.723612,-0.688185,0.000000,-0.052790,0.723612,-0.688185,0.574552,0.739757, --0.138197,0.894430,-0.425320,0.000000,-0.138197,0.894430,-0.425320,0.503325,0.737471, --0.052790,0.723612,-0.688185,0.000000,-0.052790,0.723612,-0.688185,0.574552,0.739757, --0.361804,0.723612,-0.587778,0.000000,-0.361804,0.723612,-0.587778,0.279690,0.917858, --0.138197,0.894430,-0.425320,0.000000,-0.138197,0.894430,-0.425320,0.503325,0.737471, --0.138197,0.894430,-0.425320,0.000000,-0.138197,0.894430,-0.425320,0.503325,0.737471, --0.361804,0.723612,-0.587778,0.000000,-0.361804,0.723612,-0.587778,0.279690,0.917858, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.391200,0.484445, --0.361804,0.723612,-0.587778,0.000000,-0.361804,0.723612,-0.587778,0.279690,0.917858, --0.609547,0.657519,-0.442856,0.000000,-0.609547,0.657519,-0.442856,0.441249,0.481295, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.391200,0.484445, -0.232822,0.657519,-0.716563,0.000000,0.232822,0.657519,-0.716563,0.467747,0.391208, -0.029639,0.502302,-0.864184,0.000000,0.029639,0.502302,-0.864184,0.791278,0.505149, --0.052790,0.723612,-0.688185,0.000000,-0.052790,0.723612,-0.688185,0.574552,0.739757, -0.029639,0.502302,-0.864184,0.000000,0.029639,0.502302,-0.864184,0.791278,0.505149, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.863599,0.594041, --0.052790,0.723612,-0.688185,0.000000,-0.052790,0.723612,-0.688185,0.574552,0.739757, --0.052790,0.723612,-0.688185,0.000000,-0.052790,0.723612,-0.688185,0.574552,0.739757, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.863599,0.594041, --0.361804,0.723612,-0.587778,0.000000,-0.361804,0.723612,-0.587778,0.279690,0.917858, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.863599,0.594041, --0.531941,0.502302,-0.681712,0.000000,-0.531941,0.502302,-0.681712,0.814480,0.588860, --0.361804,0.723612,-0.587778,0.000000,-0.361804,0.723612,-0.587778,0.279690,0.917858, --0.361804,0.723612,-0.587778,0.000000,-0.361804,0.723612,-0.587778,0.279690,0.917858, --0.531941,0.502302,-0.681712,0.000000,-0.531941,0.502302,-0.681712,0.814480,0.588860, --0.609547,0.657519,-0.442856,0.000000,-0.609547,0.657519,-0.442856,0.441249,0.481295, --0.531941,0.502302,-0.681712,0.000000,-0.531941,0.502302,-0.681712,0.814480,0.588860, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.952607,0.099770, --0.609547,0.657519,-0.442856,0.000000,-0.609547,0.657519,-0.442856,0.441249,0.481295, -0.251147,0.967949,0.000000,0.000000,0.251147,0.967949,0.000000,0.663633,0.570564, -0.077607,0.967950,-0.238853,0.000000,0.077607,0.967950,-0.238853,0.412677,0.393695, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.589135,0.315387, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.615418,0.565866, -0.361800,0.894429,-0.262863,0.000000,0.361800,0.894429,-0.262863,0.257596,0.823860, -0.251147,0.967949,0.000000,0.000000,0.251147,0.967949,0.000000,0.663633,0.570564, -0.753442,0.657515,0.000000,0.000000,0.753442,0.657515,0.000000,0.870330,0.424531, -0.638194,0.723610,-0.262864,0.000000,0.638194,0.723610,-0.262864,0.356930,0.840702, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.615418,0.565866, -0.251147,0.967949,0.000000,0.000000,0.251147,0.967949,0.000000,0.663633,0.570564, -0.361800,0.894429,-0.262863,0.000000,0.361800,0.894429,-0.262863,0.257596,0.823860, -0.077607,0.967950,-0.238853,0.000000,0.077607,0.967950,-0.238853,0.412677,0.393695, -0.361800,0.894429,-0.262863,0.000000,0.361800,0.894429,-0.262863,0.257596,0.823860, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.491338,0.479977, -0.077607,0.967950,-0.238853,0.000000,0.077607,0.967950,-0.238853,0.412677,0.393695, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.615418,0.565866, -0.638194,0.723610,-0.262864,0.000000,0.638194,0.723610,-0.262864,0.356930,0.840702, -0.361800,0.894429,-0.262863,0.000000,0.361800,0.894429,-0.262863,0.257596,0.823860, -0.638194,0.723610,-0.262864,0.000000,0.638194,0.723610,-0.262864,0.356930,0.840702, -0.447209,0.723612,-0.525728,0.000000,0.447209,0.723612,-0.525728,0.313138,0.750327, -0.361800,0.894429,-0.262863,0.000000,0.361800,0.894429,-0.262863,0.257596,0.823860, -0.361800,0.894429,-0.262863,0.000000,0.361800,0.894429,-0.262863,0.257596,0.823860, -0.447209,0.723612,-0.525728,0.000000,0.447209,0.723612,-0.525728,0.313138,0.750327, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.491338,0.479977, -0.447209,0.723612,-0.525728,0.000000,0.447209,0.723612,-0.525728,0.313138,0.750327, -0.232822,0.657519,-0.716563,0.000000,0.232822,0.657519,-0.716563,0.467747,0.391208, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.491338,0.479977, -0.753442,0.657515,0.000000,0.000000,0.753442,0.657515,0.000000,0.870330,0.424531, -0.831051,0.502299,-0.238853,0.000000,0.831051,0.502299,-0.238853,0.891200,0.515555, -0.638194,0.723610,-0.262864,0.000000,0.638194,0.723610,-0.262864,0.356930,0.840702, -0.831051,0.502299,-0.238853,0.000000,0.831051,0.502299,-0.238853,0.891200,0.515555, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.816839,0.418893, -0.638194,0.723610,-0.262864,0.000000,0.638194,0.723610,-0.262864,0.356930,0.840702, -0.638194,0.723610,-0.262864,0.000000,0.638194,0.723610,-0.262864,0.356930,0.840702, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.816839,0.418893, -0.447209,0.723612,-0.525728,0.000000,0.447209,0.723612,-0.525728,0.313138,0.750327, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.816839,0.418893, -0.483971,0.502302,-0.716565,0.000000,0.483971,0.502302,-0.716565,0.841211,0.510884, -0.447209,0.723612,-0.525728,0.000000,0.447209,0.723612,-0.525728,0.313138,0.750327, -0.447209,0.723612,-0.525728,0.000000,0.447209,0.723612,-0.525728,0.313138,0.750327, -0.483971,0.502302,-0.716565,0.000000,0.483971,0.502302,-0.716565,0.841211,0.510884, -0.232822,0.657519,-0.716563,0.000000,0.232822,0.657519,-0.716563,0.467747,0.391208, -0.483971,0.502302,-0.716565,0.000000,0.483971,0.502302,-0.716565,0.841211,0.510884, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.768276,0.421330, -0.232822,0.657519,-0.716563,0.000000,0.232822,0.657519,-0.716563,0.467747,0.391208 -}; - -const int medium_sphere_indices[]= -{ - 0,1,2, -3,4,5, -6,7,8, -9,10,11, -12,13,14, -15,16,17, -18,19,20, -21,22,23, -24,25,26, -27,28,29, -30,31,32, -33,34,35, -36,37,38, -39,40,41, -42,43,44, -45,46,47, -48,49,50, -51,52,53, -54,55,56, -57,58,59, -60,61,62, -63,64,65, -66,67,68, -69,70,71, -72,73,74, -75,76,77, -78,79,80, -81,82,83, -84,85,86, -87,88,89, -90,91,92, -93,94,95, -96,97,98, -99,100,101, -102,103,104, -105,106,107, -108,109,110, -111,112,113, -114,115,116, -117,118,119, -120,121,122, -123,124,125, -126,127,128, -129,130,131, -132,133,134, -135,136,137, -138,139,140, -141,142,143, -144,145,146, -147,148,149, -150,151,152, -153,154,155, -156,157,158, -159,160,161, -162,163,164, -165,166,167, -168,169,170, -171,172,173, -174,175,176, -177,178,179, -180,181,182, -183,184,185, -186,187,188, -189,190,191, -192,193,194, -195,196,197, -198,199,200, -201,202,203, -204,205,206, -207,208,209, -210,211,212, -213,214,215, -216,217,218, -219,220,221, -222,223,224, -225,226,227, -228,229,230, -231,232,233, -234,235,236, -237,238,239, -240,241,242, -243,244,245, -246,247,248, -249,250,251, -252,253,254, -255,256,257, -258,259,260, -261,262,263, -264,265,266, -267,268,269, -270,271,272, -273,274,275, -276,277,278, -279,280,281, -282,283,284, -285,286,287, -288,289,290, -291,292,293, -294,295,296, -297,298,299, -300,301,302, -303,304,305, -306,307,308, -309,310,311, -312,313,314, -315,316,317, -318,319,320, -321,322,323, -324,325,326, -327,328,329, -330,331,332, -333,334,335, -336,337,338, -339,340,341, -342,343,344, -345,346,347, -348,349,350, -351,352,353, -354,355,356, -357,358,359, -360,361,362, -363,364,365, -366,367,368, -369,370,371, -372,373,374, -375,376,377, -378,379,380, -381,382,383, -384,385,386, -387,388,389, -390,391,392, -393,394,395, -396,397,398, -399,400,401, -402,403,404, -405,406,407, -408,409,410, -411,412,413, -414,415,416, -417,418,419, -420,421,422, -423,424,425, -426,427,428, -429,430,431, -432,433,434, -435,436,437, -438,439,440, -441,442,443, -444,445,446, -447,448,449, -450,451,452, -453,454,455, -456,457,458, -459,460,461, -462,463,464, -465,466,467, -468,469,470, -471,472,473, -474,475,476, -477,478,479, -480,481,482, -483,484,485, -486,487,488, -489,490,491, -492,493,494, -495,496,497, -498,499,500, -501,502,503, -504,505,506, -507,508,509, -510,511,512, -513,514,515, -516,517,518, -519,520,521, -522,523,524, -525,526,527, -528,529,530, -531,532,533, -534,535,536, -537,538,539, -540,541,542, -543,544,545, -546,547,548, -549,550,551, -552,553,554, -555,556,557, -558,559,560, -561,562,563, -564,565,566, -567,568,569, -570,571,572, -573,574,575, -576,577,578, -579,580,581, -582,583,584, -585,586,587, -588,589,590, -591,592,593, -594,595,596, -597,598,599, -600,601,602, -603,604,605, -606,607,608, -609,610,611, -612,613,614, -615,616,617, -618,619,620, -621,622,623, -624,625,626, -627,628,629, -630,631,632, -633,634,635, -636,637,638, -639,640,641, -642,643,644, -645,646,647, -648,649,650, -651,652,653, -654,655,656, -657,658,659, -660,661,662, -663,664,665, -666,667,668, -669,670,671, -672,673,674, -675,676,677, -678,679,680, -681,682,683, -684,685,686, -687,688,689, -690,691,692, -693,694,695, -696,697,698, -699,700,701, -702,703,704, -705,706,707, -708,709,710, -711,712,713, -714,715,716, -717,718,719, -720,721,722, -723,724,725, -726,727,728, -729,730,731, -732,733,734, -735,736,737, -738,739,740, -741,742,743, -744,745,746, -747,748,749, -750,751,752, -753,754,755, -756,757,758, -759,760,761, -762,763,764, -765,766,767, -768,769,770, -771,772,773, -774,775,776, -777,778,779, -780,781,782, -783,784,785, -786,787,788, -789,790,791, -792,793,794, -795,796,797, -798,799,800, -801,802,803, -804,805,806, -807,808,809, -810,811,812, -813,814,815, -816,817,818, -819,820,821, -822,823,824, -825,826,827, -828,829,830, -831,832,833, -834,835,836, -837,838,839, -840,841,842, -843,844,845, -846,847,848, -849,850,851, -852,853,854, -855,856,857, -858,859,860, -861,862,863, -864,865,866, -867,868,869, -870,871,872, -873,874,875, -876,877,878, -879,880,881, -882,883,884, -885,886,887, -888,889,890, -891,892,893, -894,895,896, -897,898,899, -900,901,902, -903,904,905, -906,907,908, -909,910,911, -912,913,914, -915,916,917, -918,919,920, -921,922,923, -924,925,926, -927,928,929, -930,931,932, -933,934,935, -936,937,938, -939,940,941, -942,943,944, -945,946,947, -948,949,950, -951,952,953, -954,955,956, -957,958,959 -}; - - -const float low_sphere_vertices[]= -{ - 0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.391200,0.484445, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.757596,0.176140, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.235205,0.325266, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.391200,0.484445, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.943007,0.371159, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.943007,0.371159, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.991338,0.520023, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.991338,0.520023, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.137692,0.365246, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.757596,0.176140, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.235205,0.325266, -0.951058,0.000000,0.309013,0.000000,0.951058,0.000000,0.309013,0.291278,0.494851, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.546072,0.156902, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.438926,0.305137, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.891200,0.515555, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.191461,0.507219, --0.951058,0.000000,0.309013,0.000000,-0.951058,0.000000,0.309013,0.735205,0.674734, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.846308,0.334943, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,1.039894,0.343193, --0.587786,0.000000,-0.809017,0.000000,-0.587786,0.000000,-0.809017,0.443007,0.628841, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,1.326823,0.166086, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.691461,0.492781, -0.587786,0.000000,-0.809017,0.000000,0.587786,0.000000,-0.809017,0.446597,0.804967, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.757596,0.176140, -0.951058,0.000000,0.309013,0.000000,0.951058,0.000000,0.309013,0.291278,0.494851, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.091499,0.516836, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.546072,0.156902, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.891200,0.515555, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.637692,0.634754, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.951058,0.000000,0.309013,0.000000,-0.951058,0.000000,0.309013,0.735205,0.674734, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.629692,0.810571, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.846308,0.334943, --0.587786,0.000000,-0.809017,0.000000,-0.587786,0.000000,-0.809017,0.443007,0.628841, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.539894,0.656807, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,1.326823,0.166086, -0.587786,0.000000,-0.809017,0.000000,0.587786,0.000000,-0.809017,0.446597,0.804967, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.491338,0.479977, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.129692,0.189429, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,0.246383,0.648358, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.836927,0.658241, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,0.946597,0.195033, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.346308,0.665057, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.938926,0.694863, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.791278,0.505149, --0.850648,0.525736,0.000000,0.000000,-0.850648,0.525736,0.000000,0.257596,0.823860, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.826823,0.833914, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.542767,0.333057, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.042767,0.666943, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.326823,0.166086, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.646443,0.311386, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.146443,0.688614, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.046072,0.843098, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.391200,0.484445, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.438926,0.305137, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.546072,0.156902, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.391200,0.484445, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.438926,0.305137, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.757596,0.176140, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.438926,0.305137, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.235205,0.325266, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.137692,0.365246, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,1.326823,0.166086, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.235205,0.325266, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.137692,0.365246, -0.425323,-0.850654,0.309011,0.000000,0.425323,-0.850654,0.309011,0.336927,0.341759, -0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.999999,0.020053, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.137692,0.365246, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.943007,0.371159, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.191461,0.507219, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.943007,0.371159, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.391200,0.484445, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.191461,0.507219, --0.162456,-0.850654,0.499995,0.000000,-0.162456,-0.850654,0.499995,0.391200,0.484445, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.546072,0.156902, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.191461,0.507219, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.991338,0.520023, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,1.039894,0.343193, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.846308,0.334943, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.991338,0.520023, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.943007,0.371159, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,1.039894,0.343193, --0.525730,-0.850652,0.000000,0.000000,-0.525730,-0.850652,0.000000,0.943007,0.371159, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,1.039894,0.343193, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.137692,0.365246, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.691461,0.492781, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,1.326823,0.166086, -0.425323,-0.850654,-0.309011,0.000000,0.425323,-0.850654,-0.309011,0.137692,0.365246, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.991338,0.520023, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.691461,0.492781, --0.162456,-0.850654,-0.499995,0.000000,-0.162456,-0.850654,-0.499995,0.991338,0.520023, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.846308,0.334943, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.691461,0.492781, -0.951058,0.000000,0.309013,0.000000,0.951058,0.000000,0.309013,0.291278,0.494851, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.491338,0.479977, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.646443,0.311386, -0.951058,0.000000,0.309013,0.000000,0.951058,0.000000,0.309013,0.291278,0.494851, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.235205,0.325266, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.491338,0.479977, -0.850648,-0.525736,0.000000,0.000000,0.850648,-0.525736,0.000000,0.235205,0.325266, -0.723607,-0.447220,-0.525725,0.000000,0.723607,-0.447220,-0.525725,1.326823,0.166086, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.491338,0.479977, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.891200,0.515555, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.091499,0.516836, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.129692,0.189429, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.891200,0.515555, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.438926,0.305137, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.091499,0.516836, -0.262869,-0.525738,0.809012,0.000000,0.262869,-0.525738,0.809012,0.438926,0.305137, -0.723607,-0.447220,0.525725,0.000000,0.723607,-0.447220,0.525725,0.757596,0.176140, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.091499,0.516836, --0.951058,0.000000,0.309013,0.000000,-0.951058,0.000000,0.309013,0.735205,0.674734, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.637692,0.634754, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,0.946597,0.195033, --0.951058,0.000000,0.309013,0.000000,-0.951058,0.000000,0.309013,0.735205,0.674734, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.191461,0.507219, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.637692,0.634754, --0.688189,-0.525736,0.499997,0.000000,-0.688189,-0.525736,0.499997,0.191461,0.507219, --0.276388,-0.447220,0.850649,0.000000,-0.276388,-0.447220,0.850649,0.546072,0.156902, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.637692,0.634754, --0.587786,0.000000,-0.809017,0.000000,-0.587786,0.000000,-0.809017,0.443007,0.628841, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.629692,0.810571, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.791278,0.505149, --0.587786,0.000000,-0.809017,0.000000,-0.587786,0.000000,-0.809017,0.443007,0.628841, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,1.039894,0.343193, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.629692,0.810571, --0.688189,-0.525736,-0.499997,0.000000,-0.688189,-0.525736,-0.499997,1.039894,0.343193, --0.894426,-0.447216,0.000000,0.000000,-0.894426,-0.447216,0.000000,0.746383,0.351642, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.629692,0.810571, -0.587786,0.000000,-0.809017,0.000000,0.587786,0.000000,-0.809017,0.446597,0.804967, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.539894,0.656807, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.542767,0.333057, -0.587786,0.000000,-0.809017,0.000000,0.587786,0.000000,-0.809017,0.446597,0.804967, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.691461,0.492781, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.539894,0.656807, -0.262869,-0.525738,-0.809012,0.000000,0.262869,-0.525738,-0.809012,0.691461,0.492781, --0.276388,-0.447220,-0.850649,0.000000,-0.276388,-0.447220,-0.850649,0.846308,0.334943, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.539894,0.656807, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.091499,0.516836, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,0.246383,0.648358, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.129692,0.189429, -0.587786,0.000000,0.809017,0.000000,0.587786,0.000000,0.809017,0.091499,0.516836, -0.951058,0.000000,0.309013,0.000000,0.951058,0.000000,0.309013,0.291278,0.494851, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,0.246383,0.648358, -0.951058,0.000000,0.309013,0.000000,0.951058,0.000000,0.309013,0.291278,0.494851, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.646443,0.311386, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,0.246383,0.648358, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.637692,0.634754, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.346308,0.665057, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,0.946597,0.195033, --0.587786,0.000000,0.809017,0.000000,-0.587786,0.000000,0.809017,0.637692,0.634754, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.891200,0.515555, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.346308,0.665057, -0.000000,0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.891200,0.515555, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.129692,0.189429, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.346308,0.665057, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.629692,0.810571, --0.850648,0.525736,0.000000,0.000000,-0.850648,0.525736,0.000000,0.257596,0.823860, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.791278,0.505149, --0.951058,0.000000,-0.309013,0.000000,-0.951058,0.000000,-0.309013,0.629692,0.810571, --0.951058,0.000000,0.309013,0.000000,-0.951058,0.000000,0.309013,0.735205,0.674734, --0.850648,0.525736,0.000000,0.000000,-0.850648,0.525736,0.000000,0.257596,0.823860, --0.951058,0.000000,0.309013,0.000000,-0.951058,0.000000,0.309013,0.735205,0.674734, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,0.946597,0.195033, --0.850648,0.525736,0.000000,0.000000,-0.850648,0.525736,0.000000,0.257596,0.823860, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.539894,0.656807, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.042767,0.666943, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.542767,0.333057, -0.000000,0.000000,-1.000000,0.000000,0.000000,0.000000,-1.000000,0.539894,0.656807, --0.587786,0.000000,-0.809017,0.000000,-0.587786,0.000000,-0.809017,0.443007,0.628841, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.042767,0.666943, --0.587786,0.000000,-0.809017,0.000000,-0.587786,0.000000,-0.809017,0.443007,0.628841, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.791278,0.505149, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.042767,0.666943, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.491338,0.479977, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.146443,0.688614, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.646443,0.311386, -0.951058,0.000000,-0.309013,0.000000,0.951058,0.000000,-0.309013,0.491338,0.479977, -0.587786,0.000000,-0.809017,0.000000,0.587786,0.000000,-0.809017,0.446597,0.804967, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.146443,0.688614, -0.587786,0.000000,-0.809017,0.000000,0.587786,0.000000,-0.809017,0.446597,0.804967, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.542767,0.333057, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.146443,0.688614, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.836927,0.658241, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.046072,0.843098, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.591499,0.483164, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.836927,0.658241, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,0.246383,0.648358, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.046072,0.843098, -0.688189,0.525736,0.499997,0.000000,0.688189,0.525736,0.499997,0.246383,0.648358, -0.894426,0.447216,0.000000,0.000000,0.894426,0.447216,0.000000,0.646443,0.311386, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.046072,0.843098, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.938926,0.694863, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.836927,0.658241, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.591499,0.483164, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.938926,0.694863, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.346308,0.665057, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.836927,0.658241, --0.262869,0.525738,0.809012,0.000000,-0.262869,0.525738,0.809012,0.346308,0.665057, -0.276388,0.447220,0.850649,0.000000,0.276388,0.447220,0.850649,1.129692,0.189429, -0.162456,0.850654,0.499995,0.000000,0.162456,0.850654,0.499995,0.836927,0.658241, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.826823,0.833914, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.938926,0.694863, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.591499,0.483164, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.826823,0.833914, --0.850648,0.525736,0.000000,0.000000,-0.850648,0.525736,0.000000,0.257596,0.823860, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.938926,0.694863, --0.850648,0.525736,0.000000,0.000000,-0.850648,0.525736,0.000000,0.257596,0.823860, --0.723607,0.447220,0.525725,0.000000,-0.723607,0.447220,0.525725,0.946597,0.195033, --0.425323,0.850654,0.309011,0.000000,-0.425323,0.850654,0.309011,0.938926,0.694863, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.326823,0.166086, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.826823,0.833914, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.591499,0.483164, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.326823,0.166086, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.042767,0.666943, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.826823,0.833914, --0.262869,0.525738,-0.809012,0.000000,-0.262869,0.525738,-0.809012,0.042767,0.666943, --0.723607,0.447220,-0.525725,0.000000,-0.723607,0.447220,-0.525725,0.791278,0.505149, --0.425323,0.850654,-0.309011,0.000000,-0.425323,0.850654,-0.309011,0.826823,0.833914, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.046072,0.843098, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.326823,0.166086, -0.000000,1.000000,0.000000,0.000000,0.000000,1.000000,0.000000,0.591499,0.483164, -0.525730,0.850652,0.000000,0.000000,0.525730,0.850652,0.000000,0.046072,0.843098, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.146443,0.688614, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.326823,0.166086, -0.688189,0.525736,-0.499997,0.000000,0.688189,0.525736,-0.499997,0.146443,0.688614, -0.276388,0.447220,-0.850649,0.000000,0.276388,0.447220,-0.850649,0.542767,0.333057, -0.162456,0.850654,-0.499995,0.000000,0.162456,0.850654,-0.499995,0.326823,0.166086 -}; - -const int low_sphere_indices[]= -{ - 0,1,2, -3,4,5, -6,7,8, -9,10,11, -12,13,14, -15,16,17, -18,19,20, -21,22,23, -24,25,26, -27,28,29, -30,31,32, -33,34,35, -36,37,38, -39,40,41, -42,43,44, -45,46,47, -48,49,50, -51,52,53, -54,55,56, -57,58,59, -60,61,62, -63,64,65, -66,67,68, -69,70,71, -72,73,74, -75,76,77, -78,79,80, -81,82,83, -84,85,86, -87,88,89, -90,91,92, -93,94,95, -96,97,98, -99,100,101, -102,103,104, -105,106,107, -108,109,110, -111,112,113, -114,115,116, -117,118,119, -120,121,122, -123,124,125, -126,127,128, -129,130,131, -132,133,134, -135,136,137, -138,139,140, -141,142,143, -144,145,146, -147,148,149, -150,151,152, -153,154,155, -156,157,158, -159,160,161, -162,163,164, -165,166,167, -168,169,170, -171,172,173, -174,175,176, -177,178,179, -180,181,182, -183,184,185, -186,187,188, -189,190,191, -192,193,194, -195,196,197, -198,199,200, -201,202,203, -204,205,206, -207,208,209, -210,211,212, -213,214,215, -216,217,218, -219,220,221, -222,223,224, -225,226,227, -228,229,230, -231,232,233, -234,235,236, -237,238,239 -}; - -const float point_sphere_vertices[]= -{ - 0.000000,0.000000,0.000000,0.000000,0.000000,-1.000000,0.000000,0.48f, 0.48f, -}; - -const int point_sphere_indices[]= -{ - 0 -}; - - -#endif //SHAPE_DATA_H diff --git a/btgui/OpenGLWindow/SimpleCamera.cpp b/btgui/OpenGLWindow/SimpleCamera.cpp deleted file mode 100644 index 46d7dd09c..000000000 --- a/btgui/OpenGLWindow/SimpleCamera.cpp +++ /dev/null @@ -1,260 +0,0 @@ -#include "OpenGLWindow/SimpleCamera.h" - -#include "Bullet3Common/b3Vector3.h" -#include "Bullet3Common/b3Quaternion.h" -#include "Bullet3Common/b3Matrix3x3.h" - -struct SimpleCameraInternalData -{ - SimpleCameraInternalData() - :m_cameraTargetPosition(b3MakeVector3(0,0,0)), - m_cameraDistance(20), - m_cameraUp(b3MakeVector3(0,1,0)), - m_cameraUpAxis(1), - m_cameraForward(b3MakeVector3(1,0,0)), - m_frustumZNear(1), - m_frustumZFar(10000), - m_yaw(20), - m_pitch(0), - m_aspect(1) - { - } - b3Vector3 m_cameraTargetPosition; - float m_cameraDistance; - b3Vector3 m_cameraUp; - b3Vector3 m_cameraForward; - int m_cameraUpAxis; - //the m_cameraPosition is a cached value, recomputed from other values - b3Vector3 m_cameraPosition; - float m_yaw; - - float m_pitch; - float m_aspect; - float m_frustumZNear; - float m_frustumZFar; -}; - - - - -SimpleCamera::SimpleCamera() -{ - m_data = new SimpleCameraInternalData; -} -SimpleCamera::~SimpleCamera() -{ - delete m_data; -} - - - - -static void b3CreateFrustum( - float left, - float right, - float bottom, - float top, - float nearVal, - float farVal, - float frustum[16]) -{ - - frustum[0*4+0] = (float(2) * nearVal) / (right - left); - frustum[0*4+1] = float(0); - frustum[0*4+2] = float(0); - frustum[0*4+3] = float(0); - - frustum[1*4+0] = float(0); - frustum[1*4+1] = (float(2) * nearVal) / (top - bottom); - frustum[1*4+2] = float(0); - frustum[1*4+3] = float(0); - - frustum[2*4+0] = (right + left) / (right - left); - frustum[2*4+1] = (top + bottom) / (top - bottom); - frustum[2*4+2] = -(farVal + nearVal) / (farVal - nearVal); - frustum[2*4+3] = float(-1); - - frustum[3*4+0] = float(0); - frustum[3*4+1] = float(0); - frustum[3*4+2] = -(float(2) * farVal * nearVal) / (farVal - nearVal); - frustum[3*4+3] = float(0); - -} - - - - -static void b3CreateDiagonalMatrix(float value, float result[4][4]) -{ - for (int i=0;i<4;i++) - { - for (int j=0;j<4;j++) - { - if (i==j) - { - result[i][j] = value; - } else - { - result[i][j] = 0.f; - } - } - } -} - -static void b3CreateOrtho(float left, float right, float bottom, float top, float zNear, float zFar, float result[4][4]) -{ - b3CreateDiagonalMatrix(1.f,result); - - result[0][0] = 2.f / (right - left); - result[1][1] = 2.f / (top - bottom); - result[2][2] = - 2.f / (zFar - zNear); - result[3][0] = - (right + left) / (right - left); - result[3][1] = - (top + bottom) / (top - bottom); - result[3][2] = - (zFar + zNear) / (zFar - zNear); -} - -static void b3CreateLookAt(const b3Vector3& eye, const b3Vector3& center,const b3Vector3& up, float result[16]) -{ - b3Vector3 f = (center - eye).normalized(); - b3Vector3 u = up.normalized(); - b3Vector3 s = (f.cross(u)).normalized(); - u = s.cross(f); - - result[0*4+0] = s.x; - result[1*4+0] = s.y; - result[2*4+0] = s.z; - - result[0*4+1] = u.x; - result[1*4+1] = u.y; - result[2*4+1] = u.z; - - result[0*4+2] =-f.x; - result[1*4+2] =-f.y; - result[2*4+2] =-f.z; - - result[0*4+3] = 0.f; - result[1*4+3] = 0.f; - result[2*4+3] = 0.f; - - result[3*4+0] = -s.dot(eye); - result[3*4+1] = -u.dot(eye); - result[3*4+2] = f.dot(eye); - result[3*4+3] = 1.f; -} - -void SimpleCamera::setCameraUpAxis(int upAxis) -{ - m_data->m_cameraUpAxis = upAxis; - - update(); -} - -void SimpleCamera::update() -{ - - int forwardAxis(-1); - switch (m_data->m_cameraUpAxis) - { - case 1: - forwardAxis = 2; - m_data->m_cameraUp = b3MakeVector3(0,1,0); - //gLightPos = b3MakeVector3(-50.f,100,30); - break; - case 2: - forwardAxis = 1; - m_data->m_cameraUp = b3MakeVector3(0,0,1); - //gLightPos = b3MakeVector3(-50.f,30,100); - break; - default: - { - b3Assert(0); - return; - } - }; - - b3Vector3 eyePos = b3MakeVector3(0,0,0); - eyePos[forwardAxis] = -m_data->m_cameraDistance; - - m_data->m_cameraForward = b3MakeVector3(eyePos[0],eyePos[1],eyePos[2]); - if (m_data->m_cameraForward.length2() < B3_EPSILON) - { - m_data->m_cameraForward.setValue(1.f,0.f,0.f); - } else - { - m_data->m_cameraForward.normalize(); - } - - -// m_azi=m_azi+0.01; - b3Scalar rele = m_data->m_yaw * b3Scalar(0.01745329251994329547);// rads per deg - b3Scalar razi = m_data->m_pitch * b3Scalar(0.01745329251994329547);// rads per deg - - - b3Quaternion rot(m_data->m_cameraUp,razi); - - - b3Vector3 right = m_data->m_cameraUp.cross(m_data->m_cameraForward); - b3Quaternion roll(right,-rele); - - eyePos = b3Matrix3x3(rot) * b3Matrix3x3(roll) * eyePos; - - m_data->m_cameraPosition = eyePos; - m_data->m_cameraPosition+= m_data->m_cameraTargetPosition; - -} - -void SimpleCamera::getCameraProjectionMatrix(float projectionMatrix[16]) const -{ - b3CreateFrustum(-m_data->m_aspect * m_data->m_frustumZNear, m_data->m_aspect * m_data->m_frustumZNear, -m_data->m_frustumZNear,m_data->m_frustumZNear, m_data->m_frustumZNear, m_data->m_frustumZFar,projectionMatrix); -} -void SimpleCamera::getCameraViewMatrix(float viewMatrix[16]) const -{ - b3CreateLookAt(m_data->m_cameraPosition,m_data->m_cameraTargetPosition,m_data->m_cameraUp,viewMatrix); -} - -void SimpleCamera::getCameraTargetPosition(float pos[3]) const -{ - pos[0] =m_data->m_cameraTargetPosition[0]; - pos[1] =m_data->m_cameraTargetPosition[1]; - pos[2] =m_data->m_cameraTargetPosition[2]; -} -void SimpleCamera::getCameraPosition(float pos[3]) const -{ - pos[0] =m_data->m_cameraPosition[0]; - pos[1] =m_data->m_cameraPosition[1]; - pos[2] =m_data->m_cameraPosition[2]; -} - -void SimpleCamera::setCameraTargetPosition(float x,float y,float z) -{ - m_data->m_cameraTargetPosition.setValue(x,y,z); - update(); -} -void SimpleCamera::setCameraDistance(float dist) -{ - m_data->m_cameraDistance = dist; - update(); -} -void SimpleCamera::setCameraUpVector(float x,float y ,float z) -{ - m_data->m_cameraUp.setValue(x,y,z); - update(); -} - -void SimpleCamera::setCameraYaw(float yaw) -{ - m_data->m_yaw = yaw; - update(); -} - -void SimpleCamera::setCameraPitch(float pitch) -{ - m_data->m_pitch = pitch; - update(); -} - -void SimpleCamera::setAspectRatio(float ratio) -{ - m_data->m_aspect = ratio; - update(); -} diff --git a/btgui/OpenGLWindow/SimpleCamera.h b/btgui/OpenGLWindow/SimpleCamera.h deleted file mode 100644 index 5506d884f..000000000 --- a/btgui/OpenGLWindow/SimpleCamera.h +++ /dev/null @@ -1,36 +0,0 @@ -#ifndef SIMPLE_CAMERA_H -#define SIMPLE_CAMERA_H - -struct CommonCameraInterface -{ - virtual void getCameraProjectionMatrix(float m[16])const = 0; - virtual void getCameraViewMatrix(float m[16]) const = 0; -}; - -struct SimpleCamera : public CommonCameraInterface -{ - struct SimpleCameraInternalData* m_data; - - SimpleCamera(); - virtual ~SimpleCamera(); - - void update(); - virtual void getCameraProjectionMatrix(float m[16]) const; - virtual void getCameraViewMatrix(float m[16]) const; - - virtual void getCameraTargetPosition(float pos[3]) const; - virtual void getCameraPosition(float pos[3]) const; - - virtual void setCameraTargetPosition(float x,float y,float z); - virtual void setCameraDistance(float dist); - virtual void setCameraUpVector(float x,float y, float z); - ///the setCameraUpAxis will call the 'setCameraUpVector' and 'setCameraForwardVector' - virtual void setCameraUpAxis(int axis); - virtual void setCameraYaw(float yaw); - - virtual void setCameraPitch(float pitch); - virtual void setAspectRatio(float ratio); - -}; - -#endif //SIMPLE_CAMERA_H \ No newline at end of file diff --git a/btgui/OpenGLWindow/SimpleOpenGL2App.cpp b/btgui/OpenGLWindow/SimpleOpenGL2App.cpp deleted file mode 100644 index 7730416f0..000000000 --- a/btgui/OpenGLWindow/SimpleOpenGL2App.cpp +++ /dev/null @@ -1,207 +0,0 @@ -#include "OpenGLWindow/SimpleOpenGL2App.h" -#include "OpenGLWindow/OpenGLInclude.h" - -#include "Bullet3Common/b3Logging.h"//b3Assert? -#include "Bullet3Common/b3Scalar.h" -#include "Bullet3Common/b3AlignedObjectArray.h" -#include "Bullet3Common/b3Vector3.h" - - -#include "stdlib.h" - -#ifdef __APPLE__ -#include "OpenGLWindow/MacOpenGLWindow.h" -#else - -#include "OpenGLWindow/GlewWindows/GL/glew.h" -//#include "GL/glew.h" -#ifdef _WIN32 -#include "OpenGLWindow/Win32OpenGLWindow.h" -#else -//let's cross the fingers it is Linux/X11 -#include "OpenGLWindow/X11OpenGLWindow.h" -#endif //_WIN32 -#endif//__APPLE__ -#include -#include "OpenGLWindow/CommonRenderInterface.h" - -struct SimpleOpenGL2AppInternalData -{ - -}; - -SimpleOpenGL2App::SimpleOpenGL2App(const char* title, int width, int height) -{ - m_data = new SimpleOpenGL2AppInternalData; - - m_window = new b3gDefaultOpenGLWindow(); - b3gWindowConstructionInfo ci; - ci.m_title = title; - ci.m_openglVersion = 2; - ci.m_width = width; - ci.m_height = height; - m_window->createWindow(ci); - - m_window->setWindowTitle(title); - -#ifndef __APPLE__ -#ifndef _WIN32 -//some Linux implementations need the 'glewExperimental' to be true - glewExperimental = GL_TRUE; -#endif - - - if (glewInit() != GLEW_OK) - { - b3Error("glewInit failed"); - exit(1); - } - if (!GLEW_VERSION_2_1) // check that the machine supports the 2.1 API. - { - b3Error("GLEW_VERSION_2_1 needs to support 2_1"); - exit(1); // or handle the error in a nicer way - } - -#endif - glGetError();//don't remove this call, it is needed for Ubuntu - glClearColor(0.9,0.9,1,1); - - b3Assert(glGetError() ==GL_NO_ERROR); - - //m_primRenderer = new GLPrimitiveRenderer(width,height); - m_parameterInterface = 0; - - b3Assert(glGetError() ==GL_NO_ERROR); - - //m_instancingRenderer = new GLInstancingRenderer(128*1024,32*1024*1024); - //m_instancingRenderer->init(); - //m_instancingRenderer->resize(width,height); - - b3Assert(glGetError() ==GL_NO_ERROR); - - //m_instancingRenderer->InitShaders(); - -} - -SimpleOpenGL2App::~SimpleOpenGL2App() -{ - delete m_data; -} - -void SimpleOpenGL2App::drawGrid(DrawGridData data) -{ - int gridSize = data.gridSize; - float upOffset = data.upOffset; - int upAxis = data.upAxis; - float gridColor[4]; - gridColor[0] = data.gridColor[0]; - gridColor[1] = data.gridColor[1]; - gridColor[2] = data.gridColor[2]; - gridColor[3] = data.gridColor[3]; - - int sideAxis=-1; - int forwardAxis=-1; - - switch (upAxis) - { - case 1: - forwardAxis=2; - sideAxis=0; - break; - case 2: - forwardAxis=1; - sideAxis=0; - break; - default: - b3Assert(0); - }; - //b3Vector3 gridColor = b3MakeVector3(0.5,0.5,0.5); - - b3AlignedObjectArray indices; - b3AlignedObjectArray vertices; - int lineIndex=0; - for(int i=-gridSize;i<=gridSize;i++) - { - { - b3Assert(glGetError() ==GL_NO_ERROR); - b3Vector3 from = b3MakeVector3(0,0,0); - from[sideAxis] = float(i); - from[upAxis] = upOffset; - from[forwardAxis] = float(-gridSize); - b3Vector3 to=b3MakeVector3(0,0,0); - to[sideAxis] = float(i); - to[upAxis] = upOffset; - to[forwardAxis] = float(gridSize); - vertices.push_back(from); - indices.push_back(lineIndex++); - vertices.push_back(to); - indices.push_back(lineIndex++); - // m_renderer->drawLine(from,to,gridColor); - } - - b3Assert(glGetError() ==GL_NO_ERROR); - { - - b3Assert(glGetError() ==GL_NO_ERROR); - b3Vector3 from=b3MakeVector3(0,0,0); - from[sideAxis] = float(-gridSize); - from[upAxis] = upOffset; - from[forwardAxis] = float(i); - b3Vector3 to=b3MakeVector3(0,0,0); - to[sideAxis] = float(gridSize); - to[upAxis] = upOffset; - to[forwardAxis] = float(i); - vertices.push_back(from); - indices.push_back(lineIndex++); - vertices.push_back(to); - indices.push_back(lineIndex++); - // m_renderer->drawLine(from,to,gridColor); - } - - } - - - m_renderer->drawLines(&vertices[0].x, - gridColor, - vertices.size(),sizeof(b3Vector3),&indices[0],indices.size(),1); - - - m_renderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(1,0,0),b3MakeVector3(1,0,0),3); - m_renderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(0,1,0),b3MakeVector3(0,1,0),3); - m_renderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(0,0,1),b3MakeVector3(0,0,1),3); - -// void GLInstancingRenderer::drawPoints(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, float pointDrawSize) - - //we don't use drawPoints because all points would have the same color -// b3Vector3 points[3] = { b3MakeVector3(1, 0, 0), b3MakeVector3(0, 1, 0), b3MakeVector3(0, 0, 1) }; -// m_instancingRenderer->drawPoints(&points[0].x, b3MakeVector3(1, 0, 0), 3, sizeof(b3Vector3), 6); -} -void SimpleOpenGL2App::setUpAxis(int axis) -{ -} -int SimpleOpenGL2App::getUpAxis() const -{ - return 1; -} - -void SimpleOpenGL2App::swapBuffer() -{ - m_window->endRendering(); - m_window->startRendering(); - -} -void SimpleOpenGL2App::drawText( const char* txt, int posX, int posY) -{ - -} - -void SimpleOpenGL2App::drawText3D( const char* txt, float posX, float posZY, float posZ, float size) -{ - -} - -void SimpleOpenGL2App::registerGrid(int xres, int yres, float color0[4], float color1[4]) -{ - -} - diff --git a/btgui/OpenGLWindow/SimpleOpenGL2App.h b/btgui/OpenGLWindow/SimpleOpenGL2App.h deleted file mode 100644 index 5393902c5..000000000 --- a/btgui/OpenGLWindow/SimpleOpenGL2App.h +++ /dev/null @@ -1,35 +0,0 @@ -#ifndef SIMPLE_OPENGL2_APP_H -#define SIMPLE_OPENGL2_APP_H - -#include "OpenGLWindow/CommonGraphicsApp.h" - -class SimpleOpenGL2App : public CommonGraphicsApp -{ -protected: - struct SimpleOpenGL2AppInternalData* m_data; - -public: - SimpleOpenGL2App(const char* title, int width, int height); - virtual ~SimpleOpenGL2App(); - - virtual void drawGrid(DrawGridData data=DrawGridData()); - virtual void setUpAxis(int axis); - virtual int getUpAxis() const; - - virtual void swapBuffer(); - virtual void drawText( const char* txt, int posX, int posY); - - virtual int registerCubeShape(float halfExtentsX,float halfExtentsY, float halfExtentsZ) - { - return 0; - } - virtual int registerGraphicsSphereShape(float radius, bool usePointSprites, int largeSphereThreshold, int mediumSphereThreshold) - { - return 0; - } - virtual void drawText3D( const char* txt, float posX, float posZY, float posZ, float size); - virtual void registerGrid(int xres, int yres, float color0[4], float color1[4]); - - -}; -#endif //SIMPLE_OPENGL2_APP_H \ No newline at end of file diff --git a/btgui/OpenGLWindow/SimpleOpenGL2Renderer.cpp b/btgui/OpenGLWindow/SimpleOpenGL2Renderer.cpp deleted file mode 100644 index 6016e57d0..000000000 --- a/btgui/OpenGLWindow/SimpleOpenGL2Renderer.cpp +++ /dev/null @@ -1,199 +0,0 @@ - -#include "SimpleOpenGL2Renderer.h" -#include "OpenGL2Include.h" -#include "Bullet3Common/b3Vector3.h" - - -SimpleOpenGL2Renderer::SimpleOpenGL2Renderer(int width, int height) - :m_width(width), - m_height(height) -{ - -} - -void SimpleOpenGL2Renderer::init() -{ -} - -void SimpleOpenGL2Renderer::updateCamera(int upAxis) -{ - float projection[16]; - float view[16]; - m_camera.setAspectRatio((float)m_width/(float)m_height); - m_camera.update(); - m_camera.getCameraProjectionMatrix(projection); - m_camera.getCameraViewMatrix(view); - GLfloat projMat[16]; - GLfloat viewMat[16]; - for (int i=0;i<16;i++) - { - viewMat[i] = view[i]; - projMat[i] = projection[i]; - } - glMatrixMode(GL_PROJECTION); - glLoadIdentity(); - glMultMatrixf(projMat); - - glMatrixMode(GL_MODELVIEW); - glLoadIdentity(); - glMultMatrixf(viewMat); -} - -void SimpleOpenGL2Renderer::removeAllInstances() -{ -} - -void SimpleOpenGL2Renderer::setCameraDistance(float dist) -{ - m_camera.setCameraDistance(dist); -} - -void SimpleOpenGL2Renderer::setCameraPitch(float pitch) -{ - m_camera.setCameraPitch(pitch); -} - -void SimpleOpenGL2Renderer::setCameraTargetPosition(float x, float y, float z) -{ - m_camera.setCameraTargetPosition(x,y,z); -} - -void SimpleOpenGL2Renderer::getCameraPosition(float cameraPos[4]) -{ - float pos[3]; - m_camera.getCameraPosition(pos); - cameraPos[0] = pos[0]; - cameraPos[1] = pos[1]; - cameraPos[2] = pos[2]; - -} - -void SimpleOpenGL2Renderer::getCameraPosition(double cameraPos[4]) -{ - float pos[3]; - m_camera.getCameraPosition(pos); - cameraPos[0] = pos[0]; - cameraPos[1] = pos[1]; - cameraPos[2] = pos[2]; -} - -void SimpleOpenGL2Renderer::setCameraTargetPosition(float cameraPos[4]) -{ - m_camera.setCameraTargetPosition(cameraPos[0],cameraPos[1],cameraPos[2]); -} - -void SimpleOpenGL2Renderer::getCameraTargetPosition(float cameraPos[4]) const -{ - m_camera.getCameraTargetPosition(cameraPos); -} - -void SimpleOpenGL2Renderer::getCameraTargetPosition(double cameraPos[4]) const -{ - cameraPos[0] = 1; - cameraPos[1] = 1; - cameraPos[2] = 1; -} - -void SimpleOpenGL2Renderer::writeSingleInstanceColorToCPU(float* color, int srcIndex) -{ -} -void SimpleOpenGL2Renderer::writeSingleInstanceColorToCPU(double* color, int srcIndex) -{ - -} -void SimpleOpenGL2Renderer::getCameraViewMatrix(float viewMat[16]) const -{ - b3Assert(0); -} -void SimpleOpenGL2Renderer::getCameraProjectionMatrix(float projMat[16]) const -{ - b3Assert(0); - -} - - -void SimpleOpenGL2Renderer::renderScene() -{ -} - - - - -int SimpleOpenGL2Renderer::registerGraphicsInstance(int shapeIndex, const double* position, const double* quaternion, const double* color, const double* scaling) -{ - return 0; -} - -int SimpleOpenGL2Renderer::registerGraphicsInstance(int shapeIndex, const float* position, const float* quaternion, const float* color, const float* scaling) -{ - return 0; -} - -void SimpleOpenGL2Renderer::drawLines(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, const unsigned int* indices, int numIndices, float pointDrawSize) -{ - int pointStrideInFloats = pointStrideInBytes/4; - glLineWidth(pointDrawSize); - for (int i=0;i - -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "OpenGLWindow/GLInstancingRenderer.h" - -#include "Bullet3Common/b3Vector3.h" -#include "Bullet3Common/b3Logging.h" - -#include "OpenGLWindow/fontstash.h" -#include "OpenGLWindow/TwFonts.h" -#include "OpenGLWindow/opengl_fontstashcallbacks.h" -#include -#include "OpenGLWindow/GLRenderToTexture.h" -#include "Bullet3Common/b3Quaternion.h" - -#ifdef _WIN32 - #define popen _popen - #define pclose _pclose -#endif // _WIN32 - -struct SimpleInternalData -{ - GLuint m_fontTextureId; - GLuint m_largeFontTextureId; - struct sth_stash* m_fontStash; - OpenGL2RenderCallbacks* m_renderCallbacks; - int m_droidRegular; - const char* m_frameDumpPngFileName; - FILE* m_ffmpegFile; - GLRenderToTexture* m_renderTexture; - void* m_userPointer; - int m_upAxis;//y=1 or z=2 is supported - -}; - -static SimpleOpenGL3App* gApp=0; - -static void SimpleResizeCallback( float widthf, float heightf) -{ - int width = (int)widthf; - int height = (int)heightf; - gApp->m_instancingRenderer->resize(width,height); - gApp->m_primRenderer->setScreenSize(width,height); - -} - -static void SimpleKeyboardCallback(int key, int state) -{ - if (key==B3G_ESCAPE && gApp && gApp->m_window) - { - gApp->m_window->setRequestExit(); - } else - { - b3DefaultKeyboardCallback(key,state); - } -} - - - - -static GLuint BindFont(const CTexFont *_Font) -{ - GLuint TexID = 0; - glGenTextures(1, &TexID); - glBindTexture(GL_TEXTURE_2D, TexID); - glPixelStorei(GL_UNPACK_SWAP_BYTES, GL_FALSE); - glPixelStorei(GL_UNPACK_LSB_FIRST, GL_FALSE); - glPixelStorei(GL_UNPACK_ROW_LENGTH, 0); - glPixelStorei(GL_UNPACK_SKIP_ROWS, 0); - glPixelStorei(GL_UNPACK_SKIP_PIXELS, 0); - glPixelStorei(GL_UNPACK_ALIGNMENT, 1); - glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, _Font->m_TexWidth, _Font->m_TexHeight, 0, GL_RED, GL_UNSIGNED_BYTE, _Font->m_TexBytes); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER,GL_NEAREST); - glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,GL_NEAREST); - glBindTexture(GL_TEXTURE_2D, 0); - - return TexID; -} - -extern char OpenSansData[]; - -SimpleOpenGL3App::SimpleOpenGL3App( const char* title, int width,int height) -{ - gApp = this; - m_data = new SimpleInternalData; - m_data->m_frameDumpPngFileName = 0; - m_data->m_renderTexture = 0; - m_data->m_ffmpegFile = 0; - m_data->m_userPointer = 0; - m_data->m_upAxis = 1; - - m_window = new b3gDefaultOpenGLWindow(); - b3gWindowConstructionInfo ci; - ci.m_title = title; - ci.m_width = width; - ci.m_height = height; - m_window->createWindow(ci); - - m_window->setWindowTitle(title); - - b3Assert(glGetError() ==GL_NO_ERROR); - - glClearColor(0.9,0.9,1,1); - m_window->startRendering(); - b3Assert(glGetError() ==GL_NO_ERROR); - -#ifndef __APPLE__ -#ifndef _WIN32 -//some Linux implementations need the 'glewExperimental' to be true - glewExperimental = GL_TRUE; -#endif - - - if (glewInit() != GLEW_OK) - exit(1); // or handle the error in a nicer way - if (!GLEW_VERSION_2_1) // check that the machine supports the 2.1 API. - exit(1); // or handle the error in a nicer way - -#endif - glGetError();//don't remove this call, it is needed for Ubuntu - - b3Assert(glGetError() ==GL_NO_ERROR); - - m_primRenderer = new GLPrimitiveRenderer(width,height); - m_parameterInterface = 0; - - b3Assert(glGetError() ==GL_NO_ERROR); - - m_instancingRenderer = new GLInstancingRenderer(128*1024,64*1024*1024); - m_renderer = m_instancingRenderer ; - m_instancingRenderer->init(); - m_instancingRenderer->resize(width,height); - - b3Assert(glGetError() ==GL_NO_ERROR); - - m_instancingRenderer->InitShaders(); - - m_window->setMouseMoveCallback(b3DefaultMouseMoveCallback); - m_window->setMouseButtonCallback(b3DefaultMouseButtonCallback); - m_window->setKeyboardCallback(SimpleKeyboardCallback); - m_window->setWheelCallback(b3DefaultWheelCallback); - m_window->setResizeCallback(SimpleResizeCallback); - - TwGenerateDefaultFonts(); - m_data->m_fontTextureId = BindFont(g_DefaultNormalFont); - m_data->m_largeFontTextureId = BindFont(g_DefaultLargeFont); - - - - { - - - - m_data->m_renderCallbacks = new OpenGL2RenderCallbacks(m_primRenderer); - m_data->m_fontStash = sth_create(512,512,m_data->m_renderCallbacks);//256,256);//,1024);//512,512); - b3Assert(glGetError() ==GL_NO_ERROR); - - if (!m_data->m_fontStash) - { - b3Warning("Could not create stash"); - //fprintf(stderr, "Could not create stash.\n"); - } - - - char* data2 = OpenSansData; - unsigned char* data = (unsigned char*) data2; - if (!(m_data->m_droidRegular = sth_add_font_from_memory(m_data->m_fontStash, data))) - { - b3Warning("error!\n"); - } - b3Assert(glGetError() ==GL_NO_ERROR); - } -} - - -struct sth_stash* SimpleOpenGL3App::getFontStash() -{ - return m_data->m_fontStash; -} - -void SimpleOpenGL3App::drawText3D( const char* txt, float worldPosX, float worldPosY, float worldPosZ, float size1) -{ - - float viewMat[16]; - float projMat[16]; - m_instancingRenderer->getCameraViewMatrix(viewMat); - m_instancingRenderer->getCameraProjectionMatrix(projMat); - - - float camPos[4]; - this->m_instancingRenderer->getCameraPosition(camPos); - b3Vector3 cp= b3MakeVector3(camPos[0],camPos[2],camPos[1]); - b3Vector3 p = b3MakeVector3(worldPosX,worldPosY,worldPosZ); - //float dist = (cp-p).length(); - //float dv = 0;//dist/1000.f; - // - //printf("str = %s\n",unicodeText); - - float dx=0; - - //int measureOnly=0; - - glEnable(GL_BLEND); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - int viewport[4]={0,0,m_instancingRenderer->getScreenWidth(),m_instancingRenderer->getScreenHeight()}; - - float posX = 450.f; - float posY = 100.f; - float winx,winy, winz; - - if (!projectWorldCoordToScreen(worldPosX, worldPosY, worldPosZ,viewMat,projMat,viewport,&winx, &winy, &winz)) - { - return; - } - posX = winx; - posY = m_instancingRenderer->getScreenHeight()/2+(m_instancingRenderer->getScreenHeight()/2)-winy; - - - if (0)//m_useTrueTypeFont) - { - bool measureOnly = false; - - float fontSize= 32;//64;//512;//128; - sth_draw_text(m_data->m_fontStash, - m_data->m_droidRegular,fontSize,posX,posY, - txt,&dx, this->m_instancingRenderer->getScreenWidth(),this->m_instancingRenderer->getScreenHeight(),measureOnly,m_window->getRetinaScale()); - sth_end_draw(m_data->m_fontStash); - sth_flush_draw(m_data->m_fontStash); - } else - { - //float width = 0.f; - int pos=0; - //float color[]={0.2f,0.2,0.2f,1.f}; - glActiveTexture(GL_TEXTURE0); - glBindTexture(GL_TEXTURE_2D,m_data->m_largeFontTextureId); - - //float width = r.x; - //float extraSpacing = 0.; - - float startX = posX; - float startY = posY-g_DefaultLargeFont->m_CharHeight*size1; - - - while (txt[pos]) - { - int c = txt[pos]; - //r.h = g_DefaultNormalFont->m_CharHeight; - //r.w = g_DefaultNormalFont->m_CharWidth[c]+extraSpacing; - float endX = startX+g_DefaultLargeFont->m_CharWidth[c]*size1; - float endY = posY; - - - float currentColor[]={1.f,0.2,0.2f,1.f}; - - // m_primRenderer->drawTexturedRect(startX, startY, endX, endY, currentColor,g_DefaultLargeFont->m_CharU0[c],g_DefaultLargeFont->m_CharV0[c],g_DefaultLargeFont->m_CharU1[c],g_DefaultLargeFont->m_CharV1[c]); - float u0 = g_DefaultLargeFont->m_CharU0[c]; - float u1 = g_DefaultLargeFont->m_CharU1[c]; - float v0 = g_DefaultLargeFont->m_CharV0[c]; - float v1 = g_DefaultLargeFont->m_CharV1[c]; - float color[4] = {currentColor[0],currentColor[1],currentColor[2],currentColor[3]}; - float x0 = startX; - float x1 = endX; - float y0 = startY; - float y1 = endY; - int screenWidth = m_instancingRenderer->getScreenWidth(); - int screenHeight = m_instancingRenderer->getScreenHeight(); - - float z = 2.f*winz-1.f;//*(far - float identity[16]={1,0,0,0, - 0,1,0,0, - 0,0,1,0, - 0,0,0,1}; - PrimVertex vertexData[4] = { - { PrimVec4(-1.f+2.f*x0/float(screenWidth), 1.f-2.f*y0/float(screenHeight), z, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u0,v0)}, - { PrimVec4(-1.f+2.f*x0/float(screenWidth), 1.f-2.f*y1/float(screenHeight), z, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u0,v1)}, - { PrimVec4( -1.f+2.f*x1/float(screenWidth), 1.f-2.f*y1/float(screenHeight), z, 1.f ), PrimVec4(color[0], color[1], color[2], color[3]) ,PrimVec2(u1,v1)}, - { PrimVec4( -1.f+2.f*x1/float(screenWidth), 1.f-2.f*y0/float(screenHeight), z, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u1,v0)} - }; - - m_primRenderer->drawTexturedRect3D(vertexData[0],vertexData[1],vertexData[2],vertexData[3],identity,identity,false); - - //DrawTexturedRect(0,r,g_DefaultNormalFont->m_CharU0[c],g_DefaultNormalFont->m_CharV0[c],g_DefaultNormalFont->m_CharU1[c],g_DefaultNormalFont->m_CharV1[c]); - // DrawFilledRect(r); - - startX = endX; - //startY = endY; - - pos++; - - } - glBindTexture(GL_TEXTURE_2D,0); - } - - glDisable(GL_BLEND); - - -#if 0 - glEnable(GL_BLEND); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - - - int pos=0; - //float color[]={0.2f,0.2,0.2f,1.f}; - glActiveTexture(GL_TEXTURE0); - glBindTexture(GL_TEXTURE_2D,m_data->m_largeFontTextureId); - - //float width = r.x; - //float extraSpacing = 0.; - - float startX = posX; - float startY = posY; - - - while (txt[pos]) - { - float scaling = 0.02; - - int c = txt[pos]; - //r.h = g_DefaultNormalFont->m_CharHeight; - //r.w = g_DefaultNormalFont->m_CharWidth[c]+extraSpacing; - float endX = startX-float(g_DefaultLargeFont->m_CharWidth[c])*scaling; - float endY = startY-float(g_DefaultLargeFont->m_CharHeight)*scaling; - - - float currentColor[]={0.2f,0.2,0.2f,1.f}; - - float u0 = g_DefaultLargeFont->m_CharU0[c]; - float v0 = g_DefaultLargeFont->m_CharV0[c]; - float u1 = g_DefaultLargeFont->m_CharU1[c]; - float v1 = g_DefaultLargeFont->m_CharV1[c]; - float color[4] = {0,0,0,1}; - - PrimVertex vertexData[4] = { - { PrimVec4(startX, startY, 0, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u0,v0)}, - { PrimVec4(startX, endY, 0 , 1.f), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u0,v1)}, - { PrimVec4(endX, endY,0.f, 1.f ), PrimVec4(color[0], color[1], color[2], color[3]) ,PrimVec2(u1,v1)}, - { PrimVec4(endX,startY, 0.f, 1.f ), PrimVec4( color[0], color[1], color[2], color[3] ) ,PrimVec2(u1,v0)} - }; - float viewMat[16]; - float projMat[16]; - m_instancingRenderer->getCameraViewMatrix(viewMat); - m_instancingRenderer->getCameraProjectionMatrix(projMat); - - m_primRenderer->drawTexturedRect3D(vertexData[0],vertexData[1],vertexData[2],vertexData[3],viewMat,projMat,false); - - //DrawTexturedRect(0,r,g_DefaultNormalFont->m_CharU0[c],g_DefaultNormalFont->m_CharV0[c],g_DefaultNormalFont->m_CharU1[c],g_DefaultNormalFont->m_CharV1[c]); - // DrawFilledRect(r); - - startX = endX; - //startY = endY; - - pos++; - - } - glBindTexture(GL_TEXTURE_2D,0); - - glDisable(GL_BLEND); -#endif - -} - - -void SimpleOpenGL3App::drawText( const char* txt, int posXi, int posYi) -{ - - float posX = (float)posXi; - float posY = (float) posYi; - - - // - //printf("str = %s\n",unicodeText); - - float dx=0; - - //int measureOnly=0; - - glEnable(GL_BLEND); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - - - if (1)//m_useTrueTypeFont) - { - bool measureOnly = false; - - float fontSize= 64;//512;//128; - sth_draw_text(m_data->m_fontStash, - m_data->m_droidRegular,fontSize,posX,posY, - txt,&dx, this->m_instancingRenderer->getScreenWidth(), - this->m_instancingRenderer->getScreenHeight(), - measureOnly, - m_window->getRetinaScale()); - - sth_end_draw(m_data->m_fontStash); - sth_flush_draw(m_data->m_fontStash); - } else - { - //float width = 0.f; - int pos=0; - //float color[]={0.2f,0.2,0.2f,1.f}; - glActiveTexture(GL_TEXTURE0); - glBindTexture(GL_TEXTURE_2D,m_data->m_largeFontTextureId); - - //float width = r.x; - //float extraSpacing = 0.; - - float startX = posX; - float startY = posY; - - - while (txt[pos]) - { - int c = txt[pos]; - //r.h = g_DefaultNormalFont->m_CharHeight; - //r.w = g_DefaultNormalFont->m_CharWidth[c]+extraSpacing; - float endX = startX+g_DefaultLargeFont->m_CharWidth[c]; - float endY = startY+g_DefaultLargeFont->m_CharHeight; - - - float currentColor[]={0.2f,0.2,0.2f,1.f}; - - m_primRenderer->drawTexturedRect(startX, startY, endX, endY, currentColor,g_DefaultLargeFont->m_CharU0[c],g_DefaultLargeFont->m_CharV0[c],g_DefaultLargeFont->m_CharU1[c],g_DefaultLargeFont->m_CharV1[c]); - - //DrawTexturedRect(0,r,g_DefaultNormalFont->m_CharU0[c],g_DefaultNormalFont->m_CharV0[c],g_DefaultNormalFont->m_CharU1[c],g_DefaultNormalFont->m_CharV1[c]); - // DrawFilledRect(r); - - startX = endX; - //startY = endY; - - pos++; - - } - glBindTexture(GL_TEXTURE_2D,0); - } - - glDisable(GL_BLEND); -} - -struct GfxVertex - { - float x,y,z,w; - float nx,ny,nz; - float u,v; - }; - -int SimpleOpenGL3App::registerCubeShape(float halfExtentsX,float halfExtentsY, float halfExtentsZ) -{ - - - int strideInBytes = 9*sizeof(float); - int numVertices = sizeof(cube_vertices)/strideInBytes; - int numIndices = sizeof(cube_indices)/sizeof(int); - - b3AlignedObjectArray verts; - verts.resize(numVertices); - for (int i=0;iregisterShape(&verts[0].x,numVertices,cube_indices,numIndices); - return shapeId; -} - -void SimpleOpenGL3App::registerGrid(int cells_x, int cells_z, float color0[4], float color1[4]) -{ - b3Vector3 cubeExtents=b3MakeVector3(0.5,0.5,0.5); - cubeExtents[m_data->m_upAxis] = 0; - int cubeId = registerCubeShape(cubeExtents[0],cubeExtents[1],cubeExtents[2]); - - b3Quaternion orn(0,0,0,1); - b3Vector3 center=b3MakeVector3(0,0,0,1); - b3Vector3 scaling=b3MakeVector3(1,1,1,1); - - for ( int i = 0; i < cells_x; i++) - { - for (int j = 0; j < cells_z; j++) - { - float* color =0; - if ((i + j) % 2 == 0) - { - color = (float*)color0; - } else { - color = (float*)color1; - } - if (this->m_data->m_upAxis==1) - { - center =b3MakeVector3((i + 0.5f) - cells_x * 0.5f, 0.f, (j + 0.5f) - cells_z * 0.5f); - } else - { - center =b3MakeVector3((i + 0.5f) - cells_x * 0.5f, (j + 0.5f) - cells_z * 0.5f,0.f ); - } - m_instancingRenderer->registerGraphicsInstance(cubeId,center,orn,color,scaling); - } - } - -} - - -int SimpleOpenGL3App::registerGraphicsSphereShape(float radius, bool usePointSprites, int largeSphereThreshold, int mediumSphereThreshold) -{ - - int strideInBytes = 9*sizeof(float); - - int graphicsShapeIndex = -1; - - if (radius>=largeSphereThreshold) - { - int numVertices = sizeof(detailed_sphere_vertices)/strideInBytes; - int numIndices = sizeof(detailed_sphere_indices)/sizeof(int); - graphicsShapeIndex = m_instancingRenderer->registerShape(&detailed_sphere_vertices[0],numVertices,detailed_sphere_indices,numIndices); - } else - { - - if (usePointSprites) - { - int numVertices = sizeof(point_sphere_vertices)/strideInBytes; - int numIndices = sizeof(point_sphere_indices)/sizeof(int); - graphicsShapeIndex = m_instancingRenderer->registerShape(&point_sphere_vertices[0],numVertices,point_sphere_indices,numIndices,B3_GL_POINTS); - } else - { - if (radius>=mediumSphereThreshold) - { - int numVertices = sizeof(medium_sphere_vertices)/strideInBytes; - int numIndices = sizeof(medium_sphere_indices)/sizeof(int); - graphicsShapeIndex = m_instancingRenderer->registerShape(&medium_sphere_vertices[0],numVertices,medium_sphere_indices,numIndices); - } else - { - int numVertices = sizeof(low_sphere_vertices)/strideInBytes; - int numIndices = sizeof(low_sphere_indices)/sizeof(int); - graphicsShapeIndex = m_instancingRenderer->registerShape(&low_sphere_vertices[0],numVertices,low_sphere_indices,numIndices); - } - } - } - return graphicsShapeIndex; -} - - -void SimpleOpenGL3App::drawGrid(DrawGridData data) -{ - int gridSize = data.gridSize; - float upOffset = data.upOffset; - int upAxis = data.upAxis; - float gridColor[4]; - gridColor[0] = data.gridColor[0]; - gridColor[1] = data.gridColor[1]; - gridColor[2] = data.gridColor[2]; - gridColor[3] = data.gridColor[3]; - - int sideAxis=-1; - int forwardAxis=-1; - - switch (upAxis) - { - case 1: - forwardAxis=2; - sideAxis=0; - break; - case 2: - forwardAxis=1; - sideAxis=0; - break; - default: - b3Assert(0); - }; - //b3Vector3 gridColor = b3MakeVector3(0.5,0.5,0.5); - - b3AlignedObjectArray indices; - b3AlignedObjectArray vertices; - int lineIndex=0; - for(int i=-gridSize;i<=gridSize;i++) - { - { - b3Assert(glGetError() ==GL_NO_ERROR); - b3Vector3 from = b3MakeVector3(0,0,0); - from[sideAxis] = float(i); - from[upAxis] = upOffset; - from[forwardAxis] = float(-gridSize); - b3Vector3 to=b3MakeVector3(0,0,0); - to[sideAxis] = float(i); - to[upAxis] = upOffset; - to[forwardAxis] = float(gridSize); - vertices.push_back(from); - indices.push_back(lineIndex++); - vertices.push_back(to); - indices.push_back(lineIndex++); - m_instancingRenderer->drawLine(from,to,gridColor); - } - - b3Assert(glGetError() ==GL_NO_ERROR); - { - - b3Assert(glGetError() ==GL_NO_ERROR); - b3Vector3 from=b3MakeVector3(0,0,0); - from[sideAxis] = float(-gridSize); - from[upAxis] = upOffset; - from[forwardAxis] = float(i); - b3Vector3 to=b3MakeVector3(0,0,0); - to[sideAxis] = float(gridSize); - to[upAxis] = upOffset; - to[forwardAxis] = float(i); - vertices.push_back(from); - indices.push_back(lineIndex++); - vertices.push_back(to); - indices.push_back(lineIndex++); - m_instancingRenderer->drawLine(from,to,gridColor); - } - - } - - - /*m_instancingRenderer->drawLines(&vertices[0].x, - gridColor, - vertices.size(),sizeof(b3Vector3),&indices[0],indices.size(),1); - */ - - m_instancingRenderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(1,0,0),b3MakeVector3(1,0,0),3); - m_instancingRenderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(0,1,0),b3MakeVector3(0,1,0),3); - m_instancingRenderer->drawLine(b3MakeVector3(0,0,0),b3MakeVector3(0,0,1),b3MakeVector3(0,0,1),3); - -// void GLInstancingRenderer::drawPoints(const float* positions, const float color[4], int numPoints, int pointStrideInBytes, float pointDrawSize) - - //we don't use drawPoints because all points would have the same color -// b3Vector3 points[3] = { b3MakeVector3(1, 0, 0), b3MakeVector3(0, 1, 0), b3MakeVector3(0, 0, 1) }; -// m_instancingRenderer->drawPoints(&points[0].x, b3MakeVector3(1, 0, 0), 3, sizeof(b3Vector3), 6); - - m_instancingRenderer->drawPoint(b3MakeVector3(1,0,0),b3MakeVector3(1,0,0),6); - m_instancingRenderer->drawPoint(b3MakeVector3(0,1,0),b3MakeVector3(0,1,0),6); - m_instancingRenderer->drawPoint(b3MakeVector3(0,0,1),b3MakeVector3(0,0,1),6); -} - -SimpleOpenGL3App::~SimpleOpenGL3App() -{ - delete m_primRenderer ; - - m_window->closeWindow(); - delete m_window; - delete m_data ; -} - -//#define STB_IMAGE_WRITE_IMPLEMENTATION -#include "OpenGLWindow/stb_image_write.h" -static void writeTextureToFile(int textureWidth, int textureHeight, const char* fileName, FILE* ffmpegVideo) -{ - int numComponents = 4; - //glPixelStorei(GL_PACK_ALIGNMENT,1); - - b3Assert(glGetError()==GL_NO_ERROR); - //glReadBuffer(GL_BACK);//COLOR_ATTACHMENT0); - - float* orgPixels = (float*)malloc(textureWidth*textureHeight*numComponents*4); - glReadPixels(0,0,textureWidth, textureHeight, GL_RGBA, GL_FLOAT, orgPixels); - //it is useful to have the actual float values for debugging purposes - - //convert float->char - char* pixels = (char*)malloc(textureWidth*textureHeight*numComponents); - assert(glGetError()==GL_NO_ERROR); - - for (int j=0;jendRendering(); - if (m_data->m_frameDumpPngFileName) - { - writeTextureToFile((int)m_window->getRetinaScale()*m_instancingRenderer->getScreenWidth(), - (int) m_window->getRetinaScale()*this->m_instancingRenderer->getScreenHeight(),m_data->m_frameDumpPngFileName, - m_data->m_ffmpegFile); - //m_data->m_renderTexture->disable(); - //if (m_data->m_ffmpegFile==0) - //{ - // m_data->m_frameDumpPngFileName = 0; - //} - } - m_window->startRendering(); -} - -// see also http://blog.mmacklin.com/2013/06/11/real-time-video-capture-with-ffmpeg/ -void SimpleOpenGL3App::dumpFramesToVideo(const char* mp4FileName) -{ - int width = (int)m_window->getRetinaScale()*m_instancingRenderer->getScreenWidth(); - int height = (int)m_window->getRetinaScale()*m_instancingRenderer->getScreenHeight(); - char cmd[8192]; - -#ifdef _WIN32 - sprintf(cmd, "ffmpeg -r 60 -f rawvideo -pix_fmt rgba -s %dx%d -i - " - "-y -crf 0 -b:v 1500000 -an -vcodec h264 -vf vflip %s", width, height, mp4FileName); -#else - - sprintf(cmd, "ffmpeg -r 60 -f rawvideo -pix_fmt rgba -s %dx%d -i - " - "-threads 0 -y -crf 0 -b 50000k -vf vflip %s", width, height, mp4FileName); -#endif - - //sprintf(cmd,"ffmpeg -r 60 -f rawvideo -pix_fmt rgba -s %dx%d -i - " - // "-threads 0 -y -crf 0 -b 50000k -vf vflip %s",width,height,mp4FileName); - - // sprintf(cmd,"ffmpeg -r 60 -f rawvideo -pix_fmt rgba -s %dx%d -i - " - // "-threads 0 -preset fast -y -crf 21 -vf vflip %s",width,height,mp4FileName); - - if (m_data->m_ffmpegFile) - { - pclose(m_data->m_ffmpegFile); - } - m_data->m_ffmpegFile = popen(cmd, "w"); - - m_data->m_frameDumpPngFileName = mp4FileName; -} -void SimpleOpenGL3App::dumpNextFrameToPng(const char* filename) -{ - - // open pipe to ffmpeg's stdin in binary write mode - - m_data->m_frameDumpPngFileName = filename; - -//you could use m_renderTexture to allow to render at higher resolutions, such as 4k or so - /*if (!m_data->m_renderTexture) - { - m_data->m_renderTexture = new GLRenderToTexture(); - GLuint renderTextureId; - glGenTextures(1, &renderTextureId); - - // "Bind" the newly created texture : all future texture functions will modify this texture - glBindTexture(GL_TEXTURE_2D, renderTextureId); - - // Give an empty image to OpenGL ( the last "0" ) - //glTexImage2D(GL_TEXTURE_2D, 0,GL_RGB, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_UNSIGNED_BYTE, 0); - //glTexImage2D(GL_TEXTURE_2D, 0,GL_RGBA32F, g_OpenGLWidth,g_OpenGLHeight, 0,GL_RGBA, GL_FLOAT, 0); - glTexImage2D(GL_TEXTURE_2D, 0,GL_RGBA32F, - m_instancingRenderer->getScreenWidth(),m_instancingRenderer->getScreenHeight() - , 0,GL_RGBA, GL_FLOAT, 0); - - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - //glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); - //glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - - m_data->m_renderTexture->init(m_instancingRenderer->getScreenWidth(),this->m_instancingRenderer->getScreenHeight(),renderTextureId, RENDERTEXTURE_COLOR); - } - - bool result = m_data->m_renderTexture->enable(); -*/ -} - -void SimpleOpenGL3App::setUpAxis(int axis) -{ - b3Assert((axis == 1)||(axis==2));//only Y or Z is supported at the moment - m_data->m_upAxis = axis; -} -int SimpleOpenGL3App::getUpAxis() const -{ - return m_data->m_upAxis; -} - - diff --git a/btgui/OpenGLWindow/SimpleOpenGL3App.h b/btgui/OpenGLWindow/SimpleOpenGL3App.h deleted file mode 100644 index 54bb0e0b1..000000000 --- a/btgui/OpenGLWindow/SimpleOpenGL3App.h +++ /dev/null @@ -1,40 +0,0 @@ -#ifndef SIMPLE_OPENGL3_APP_H -#define SIMPLE_OPENGL3_APP_H - -#include "OpenGLWindow/GLInstancingRenderer.h" -#include "OpenGLWindow/GLPrimitiveRenderer.h" -#include "OpenGLWindow/b3gWindowInterface.h" - -#include "OpenGLWindow/CommonGraphicsApp.h" - - -struct SimpleOpenGL3App : public CommonGraphicsApp -{ - struct SimpleInternalData* m_data; - - class GLPrimitiveRenderer* m_primRenderer; - class GLInstancingRenderer* m_instancingRenderer; - - - SimpleOpenGL3App(const char* title, int width,int height); - virtual ~SimpleOpenGL3App(); - - virtual int registerCubeShape(float halfExtentsX=1.f,float halfExtentsY=1.f, float halfExtentsZ = 1.f); - virtual int registerGraphicsSphereShape(float radius, bool usePointSprites=true, int largeSphereThreshold=100, int mediumSphereThreshold=10); - virtual void registerGrid(int xres, int yres, float color0[4], float color1[4]); - void dumpNextFrameToPng(const char* pngFilename); - void dumpFramesToVideo(const char* mp4Filename); - - void drawGrid(DrawGridData data=DrawGridData()); - virtual void setUpAxis(int axis); - virtual int getUpAxis() const; - - virtual void swapBuffer(); - virtual void drawText( const char* txt, int posX, int posY); - virtual void drawText3D( const char* txt, float posX, float posZY, float posZ, float size); - struct sth_stash* getFontStash(); - - -}; - -#endif //SIMPLE_OPENGL3_APP_H diff --git a/btgui/OpenGLWindow/TwFonts.cpp b/btgui/OpenGLWindow/TwFonts.cpp deleted file mode 100644 index e5cd37595..000000000 --- a/btgui/OpenGLWindow/TwFonts.cpp +++ /dev/null @@ -1,4916 +0,0 @@ -// --------------------------------------------------------------------------- -// -// @file TwFonts.cpp -// @author Philippe Decaudin - http://www.antisphere.com -// @license This file is part of the AntTweakBar library. -// For conditions of distribution and use, see License.txt -// -// --------------------------------------------------------------------------- - - - -//#include "TwMgr.h" -#include "TwFonts.h" -#include -#include -#include - -// Fedora patch: memset() -//using std::memset; - -// --------------------------------------------------------------------------- - -CTexFont::CTexFont() -{ - for( int i=0; i<256; ++i ) - { - m_CharU0[i] = 0; - m_CharU1[i] = 0; - m_CharV0[i] = 0; - m_CharV1[i] = 0; - m_CharWidth[i] = 0; - } - m_TexWidth = 0; - m_TexHeight = 0; - m_TexBytes = NULL; - m_NbCharRead = 0; - m_CharHeight = 0; -} - -// --------------------------------------------------------------------------- - -CTexFont::~CTexFont() -{ - if( m_TexBytes ) - delete[] m_TexBytes; - m_TexBytes = NULL; - m_TexWidth = 0; - m_TexHeight = 0; - m_NbCharRead = 0; -} - -// --------------------------------------------------------------------------- - -static int NextPow2(int _n) -{ - int r = 1; - while( r<_n ) - r *= 2; - return r; -} - -// --------------------------------------------------------------------------- - -const char *g_ErrBadFontHeight = "Cannot determine font height while reading font bitmap (check first pixel column)"; - -CTexFont *TwGenerateFont(const unsigned char *_Bitmap, int _BmWidth, int _BmHeight) -{ - // find height of the font - int x, y; - int h = 0, hh = 0; - int r, NbRow = 0; - for( y=0; y<_BmHeight; ++y ) - if( _Bitmap[y*_BmWidth]==0 ) - { - if( (hh<=0 && h<=0) || (h!=hh && h>0 && hh>0) ) - { - assert(0); -#if 0 - - g_TwMgr->SetLastError(g_ErrBadFontHeight); -#endif - return NULL; - } - else if( h<=0 ) - h = hh; - else if( hh<=0 ) - break; - hh = 0; - ++NbRow; - } - else - ++hh; - - // find width and position of each character - int w = 0; - int x0[224], y0[224], x1[224], y1[224]; - int ch = 32; - int start; - for( r=0; rlmax ) - lmax = l; - } - // A little empty margin is added between chars to avoid artefact when antialiasing is on - const int MARGIN_X = 2; - const int MARGIN_Y = 2; - lmax += 16*MARGIN_X; - // - Second, build the texture - CTexFont *TexFont = new CTexFont; - TexFont->m_NbCharRead = ch-32; - TexFont->m_CharHeight = h; - TexFont->m_TexWidth = NextPow2(lmax); - TexFont->m_TexHeight = NextPow2(14*(h+MARGIN_Y)); - TexFont->m_TexBytes = new unsigned char[TexFont->m_TexWidth*TexFont->m_TexHeight]; - memset(TexFont->m_TexBytes, 0, TexFont->m_TexWidth*TexFont->m_TexHeight); - int xx; - float du = 0.f;//0.4f; - float dv = 0.f;//0.4f; -#if 0 - assert( g_TwMgr!=NULL ); - if( g_TwMgr ) - { - if( g_TwMgr->m_GraphAPI==TW_OPENGL || g_TwMgr->m_GraphAPI==TW_OPENGL_CORE ) - { - du = 0; - dv = 0; - } - else // texel alignement for D3D - { - du = 0.5f; - dv = 0.5f; - } - } -#endif - - float alpha; - for( r=0; r<14; ++r ) - for( xx=0, ch=r*16; ch<(r+1)*16; ++ch ) - if( y1[ch]-y0[ch]==h-1 ) - { - for( y=0; ym_TexBytes[(xx+x-x0[ch])+(r*(h+MARGIN_Y)+y)*TexFont->m_TexWidth] = (unsigned char)(alpha*256.0f); - } - TexFont->m_CharU0[ch+32] = (float(xx)+du)/float(TexFont->m_TexWidth); - xx += x1[ch]-x0[ch]+1; - TexFont->m_CharU1[ch+32] = (float(xx)+du)/float(TexFont->m_TexWidth); - TexFont->m_CharV0[ch+32] = (float(r*(h+MARGIN_Y))+dv)/float(TexFont->m_TexHeight); - TexFont->m_CharV1[ch+32] = (float(r*(h+MARGIN_Y)+h)+dv)/float(TexFont->m_TexHeight); - TexFont->m_CharWidth[ch+32] = x1[ch]-x0[ch]+1; - xx += MARGIN_X; - } - - const unsigned char Undef = 127; // default character used as for undifined ones (having ascii codes from 0 to 31) - for( ch=0; ch<32; ++ch ) - { - TexFont->m_CharU0[ch] = TexFont->m_CharU0[Undef]; - TexFont->m_CharU1[ch] = TexFont->m_CharU1[Undef]; - TexFont->m_CharV0[ch] = TexFont->m_CharV0[Undef]; - TexFont->m_CharV1[ch] = TexFont->m_CharV1[Undef]; - TexFont->m_CharWidth[ch] = TexFont->m_CharWidth[Undef]/2; - } - - return TexFont; -} - -// --------------------------------------------------------------------------- - -CTexFont *g_DefaultSmallFont = NULL; -CTexFont *g_DefaultNormalFont = NULL; -CTexFont *g_DefaultNormalFontAA= NULL; - -CTexFont *g_DefaultLargeFont = NULL; -CTexFont *g_DefaultFixed1Font = NULL; - -// Small font -const int FONT0_BM_W = 211; -const int FONT0_BM_H = 84; -static const unsigned char s_Font0[] = -{ - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,255,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,255,0,255,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,0,0,255,255,0,0, - 0,255,0,0,0,0,255,255,0,0,0,255,0,0,255,0,0,255,0,0,255,0,255,0,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,255,0,0,255,255, - 255,0,0,255,255,255,0,0,0,0,0,255,0,255,255,255,255,0,0,255,255,0,0,255, - 255,255,255,0,0,255,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,0,0,0,255,0,255,0,255,0,0,0,255,0,0,255,0,0,255,255,255,255, - 0,255,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,255,0,255,0,0,0,0,255,0,0,255, - 255,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,255, - 255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,255,255,0,255,0,0,0,0,255,0,0,0,0,0, - 0,0,255,0,255,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,255,0,0,0,0,0,0,255,255,255,255,255,255,255,0,255,0,0,0,255,0,0, - 255,0,255,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,255,0,255,0,255,0,255, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,255,0,0,0, - 0,0,255,0,0,0,0,255,0,0,255,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0, - 255,0,0,255,0,255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,255,255,0,0,0,0,0,0, - 0,0,0,255,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,0,0,0,255,0,0,0,0,0,0,0,255,0,255,0,0,0,255,255,0,0,0,0,255,255,0, - 255,0,255,255,0,0,0,255,255,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0, - 0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,255, - 0,0,0,0,255,0,0,0,255,255,0,0,255,0,0,255,0,255,255,255,0,0,255,255,255, - 0,0,0,0,255,0,0,0,255,255,0,0,0,255,255,255,0,0,255,0,0,255,0,0,0,255,255, - 0,0,0,255,255,255,255,255,255,0,0,0,0,255,255,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,255,0,0,0,0,0,255,255,255,255,255, - 255,0,0,0,255,255,0,0,0,0,0,255,0,255,0,0,255,0,255,0,0,255,0,0,0,0,255, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,255,0,0,0,0,0,255,0, - 0,255,0,0,255,0,0,255,0,0,0,255,0,0,0,0,0,0,255,0,255,255,255,255,255,0, - 0,0,255,0,255,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0, - 255,0,255,0,0,0,0,255,0,255,0,0,255,0,255,0,0,255,255,0,0,0,255,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,255,0, - 0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,255,0, - 0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0,0,255,0,0,255,0,0,0,255,255, - 0,0,0,255,255,255,255,255,255,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,255, - 255,255,255,0,0,0,0,255,0,0,0,255,255,0,0,0,255,255,0,0,255,0,0,255,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,255, - 255,0,0,255,255,255,0,255,255,255,255,0,255,255,255,0,0,0,0,0,255,0,255, - 255,255,0,0,0,255,255,0,0,255,0,0,0,0,0,255,255,0,0,0,255,255,0,0,0,255, - 0,0,255,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,0,127,0,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,127,0,127,127,127,127,127,0,127,0,127,127,0,127,127,127,0,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,0,127,127,127,0,127,0,127, - 127,127,0,127,127,127,127,0,127,127,127,0,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,0,127,127,127,127,0,127,127,0,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,0,255,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,255,255,255,0,0,0,0,0, - 255,255,0,0,0,255,255,255,0,0,0,0,0,255,255,255,0,0,255,255,255,255,0,0, - 0,255,255,255,255,255,0,255,255,255,255,255,0,0,0,255,255,255,0,0,255,0, - 0,0,0,255,0,255,255,255,0,0,255,255,0,255,0,0,0,255,0,255,0,0,0,255,255, - 0,0,0,255,255,0,255,0,0,0,0,255,0,0,0,255,255,255,0,0,0,255,255,255,255, - 0,0,0,0,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,255,255, - 255,255,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,255,0,0,255,0, - 255,0,0,255,0,255,0,0,0,255,0,255,255,255,255,0,255,0,0,255,0,0,0,0,255, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,0, - 0,0,255,0,0,0,0,255,255,0,0,0,255,0,0,255,0,0,0,255,0,0,0,255,0,255,0,0, - 0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255, - 0,0,255,0,0,0,0,255,0,255,0,0,255,0,0,255,0,0,0,255,255,0,0,0,255,255,0, - 255,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255, - 0,0,255,0,0,0,255,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,255,0, - 0,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,0,0,0,255, - 0,255,0,0,0,255,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,255,0,0,255,255,0,255,0,0,255,0,0,255,0,0,255,0,0,255, - 0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0, - 0,0,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,0,255,0,255,0,255,0,0,0,255,0,0, - 0,255,0,255,0,255,0,255,0,255,0,255,0,0,255,0,255,0,0,0,0,0,255,0,255,0, - 0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,0,0,0,0,255,0,0, - 0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,255,0,255,0,255,0,0,255,255, - 0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,0,255,0,0,0,255,0,255,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,255,0,255,0,255, - 0,0,255,0,0,255,0,0,255,255,255,255,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255, - 0,255,255,255,255,0,0,255,255,255,255,0,0,255,0,0,255,255,255,0,255,255, - 255,255,255,255,0,0,255,0,0,0,0,255,0,255,255,0,0,0,0,255,0,0,0,255,0,255, - 0,255,0,255,0,255,0,0,255,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,255,255,255,0,0,0,255,255,255,0,0,0,0,255,0,0,0,255, - 0,0,0,0,255,0,0,255,0,0,255,0,0,255,0,255,0,255,0,255,0,0,255,255,0,0,0, - 0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,255,0,255,0,255,0,255,255,255, - 255,255,255,0,255,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0, - 0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,0,0,255, - 0,255,0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,255,0,255,0,0,0,255,255,0,255, - 0,0,0,0,0,255,0,255,255,255,255,0,0,255,0,0,0,0,0,255,0,255,0,255,0,0,0, - 0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,255,0,0,255,0,0,255,0,255, - 0,255,0,255,0,0,255,255,0,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255, - 0,0,255,255,255,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,0,255,0,0,0,255,0, - 255,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0, - 0,0,255,0,0,255,0,0,0,0,255,0,255,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0, - 255,0,255,0,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,0,0,255,0,0,0,255, - 0,0,255,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255, - 255,0,0,0,0,255,0,0,0,255,0,0,255,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,255, - 0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,255,255,255,255,0,0,0,0,255, - 255,255,0,0,255,255,255,255,0,0,0,255,255,255,255,255,0,255,0,0,0,0,0,0, - 0,255,255,255,255,0,255,0,0,0,0,255,0,255,255,255,0,255,255,0,0,255,0,0, - 0,255,0,255,255,255,255,255,0,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,255,255, - 255,0,0,0,255,0,0,0,0,0,0,0,255,255,255,0,0,0,255,0,0,0,255,0,255,255,255, - 255,0,0,0,0,255,0,0,0,0,255,255,255,255,0,0,0,0,255,255,0,0,0,0,255,0,0, - 0,255,0,0,255,0,0,255,0,0,0,255,0,0,0,255,255,255,255,0,255,0,0,0,0,255, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0, - 0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 0,0,0,0,0,255,255,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,0, - 127,127,127,127,127,127,0,127,127,127,0,127,127,127,0,127,127,127,127,127, - 0,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,0,127, - 127,0,127,127,127,0,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,255,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,0,0,0,0,0,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0, - 255,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,4,4, - 4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0, - 0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,4,4,4,4,12,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,255,255,0,0,255,255,255,0,0,0,255,255,0,0,255,255,255,0,0, - 255,255,0,0,255,255,255,0,255,255,255,0,255,255,255,0,0,255,0,255,255,0, - 255,0,0,255,0,255,0,255,255,255,0,255,255,0,0,255,255,255,0,0,0,255,255, - 0,0,255,255,255,0,0,0,255,255,255,0,255,0,255,255,255,255,0,255,255,0,255, - 0,0,255,0,255,0,0,0,255,0,255,0,0,255,0,0,255,0,255,0,255,0,255,0,0,0,255, - 0,255,255,255,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0, - 255,0,255,0,0,255,0,255,0,0,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0, - 0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,255,0,0,255,0,255,0,0,255,0,0, - 255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,255,0, - 255,0,0,0,255,0,0,255,0,0,255,0,0,255,0,255,0,0,255,0,0,255,0,0,255,0,0, - 255,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,255, - 0,0,255,0,0,255,4,4,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,0,0,0,0,255,255,255,0,255,0,0,255,0,255,0,0,0,255,0,0,255,0, - 255,255,255,255,0,255,0,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255, - 255,0,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0, - 0,255,0,255,0,0,255,0,255,0,0,0,255,0,0,255,0,0,255,0,0,255,0,0,255,0,255, - 0,0,255,0,255,0,255,0,255,0,0,255,0,0,0,255,0,255,0,0,0,255,0,0,255,0,0, - 0,0,255,0,0,0,0,255,0,255,0,0,255,255,0,0,0,255,255,4,255,255,0,4,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,255,0,0,255,0,255,0, - 0,255,0,255,0,0,0,255,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,255,0,255,0, - 0,255,0,255,0,0,255,0,255,0,255,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0, - 255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,0,0,255,0,255,0, - 0,255,0,0,255,0,0,255,0,255,0,0,0,255,255,0,255,255,0,0,0,255,0,0,0,255, - 0,255,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,255,255,255,0,255,255,255,0,0,0,255,255,0,0,255,255,255,0,0,255,255,255, - 0,255,0,0,0,255,255,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255, - 0,255,0,0,255,0,0,255,0,255,0,0,255,0,0,255,255,0,0,255,255,255,0,0,0,255, - 255,255,0,255,0,0,255,255,255,0,0,255,0,0,255,255,255,0,0,0,255,0,0,0,0, - 255,0,0,0,255,0,0,255,0,255,0,0,0,255,0,0,0,255,255,255,0,0,255,0,0,0,255, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,20,0,255,0,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255, - 0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,4,0,0,0,4,4,4,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,0,127,127,127,127,0, - 127,127,127,127,0,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127, - 127,0,127,127,127,127,0,127,127,127,127,0,127,0,127,127,0,127,127,127,127, - 0,127,0,127,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,0,127,127,0,127,127,127,0,127,127,0, - 127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,0,127,127,127,127,127,0,127,127,127,0,127,127,127,0,127,127,127, - 0,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0, - 255,255,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 0,255,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,255,255,255,0,0,255,255,255,255,255,255,255,0,0,0,0,0,0,255,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,255,255,0,0, - 0,255,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,255,255,255,255,255,255,255, - 0,0,255,255,255,255,255,255,255,0,255,255,255,255,0,0,255,255,255,255,255, - 255,255,0,0,255,255,255,255,255,255,255,0,255,0,0,255,255,0,255,0,0,255, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,255,255,0,255, - 0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,0, - 0,255,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,255,255,255,255,0,255,255,255,255,255,0,0,0,0,0,0,255,0,0,255,0,255, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0, - 255,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,255,255, - 0,0,255,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255, - 0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 255,255,255,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,255,0,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0, - 0,255,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,255,0, - 255,255,255,0,255,0,0,0,255,255,0,255,255,0,0,0,255,0,0,0,0,0,255,0,255, - 255,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,255,255,0,255,0,255, - 255,0,255,255,0,0,0,255,255,255,0,0,255,0,0,255,0,0,0,255,255,255,255,0, - 0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,255,0,0,255,0,0,255,0, - 0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,255,255,255,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255, - 0,0,255,0,0,255,0,0,0,0,0,255,0,255,0,0,255,0,0,0,255,0,0,0,0,0,255,0,0, - 0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,255,255,255,0,255,255,255,255,255, - 255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,255,255, - 255,255,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,255, - 0,0,255,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,255,0,255,0,0,255,0,0,255,0,0,0,0,0,255,0,0,255,0,255,0,0,0,255, - 0,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,255,0,0,0,0,0, - 255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,0,255,255,255,0,0,255,255,255,255,255,255,255,0,0,255, - 0,255,0,0,0,0,255,0,255,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,0,0,0,255,255,0,255,255,0,0,255,255,255,255,0,0,0,0,0,0,255, - 255,255,255,255,255,255,0,0,255,255,255,255,255,255,255,0,255,255,255,255, - 0,0,255,255,255,255,255,255,255,0,0,255,255,255,255,255,255,255,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,255,255,0,0,0,0,0,255,255,0,255,255,255,0,0,255,255,255,255,255, - 255,255,0,255,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,255,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,0,127,127, - 127,127,0,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,0, - 127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,0,127,127,0,127,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,0,127,0,127, - 127,127,0,127,127,127,0,127,127,127,0,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 0,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,0,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,255,0,0,0,0,0,0,0,255,0, - 0,0,255,0,255,0,0,255,255,255,0,0,255,0,255,0,0,0,255,255,255,255,0,0,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,255,255,0,0,255,0,0,0,0,0,0, - 0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,255, - 0,0,255,0,0,0,0,0,255,0,0,0,255,0,0,0,255,255,255,0,0,255,0,0,0,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0, - 0,255,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,255,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,255, - 0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,255, - 0,0,0,0,0,0,0,0,0,0,255,255,0,255,0,0,255,0,0,0,0,0,0,255,255,0,255,0,0, - 0,0,0,255,255,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,255,0,0,255,255,255,0,0,255,0,0,0,0,255,255,255,0,0,0,255, - 0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,255,255,0,255, - 0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,0,0,255,0,0,0,0,0, - 0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,255, - 255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,255,0,255,0,255,0,0,0,255, - 0,255,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,255,0,255,0,255,0,0,255,255,255,0,0,0,255,0,255, - 0,0,0,0,255,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,255,0,255,0,0,0,0,255,0, - 255,255,0,255,0,255,0,0,0,255,255,255,255,255,0,0,0,0,255,0,255,0,0,255, - 0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,0,0,255,255,255,0,255,255, - 0,0,0,0,0,0,255,0,0,255,0,255,255,0,255,0,0,255,0,0,0,0,0,0,0,255,255,255, - 0,255,255,0,0,0,255,0,255,0,0,255,255,0,0,255,255,0,0,0,255,0,255,0,255, - 255,0,0,255,255,0,255,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0, - 255,0,255,0,255,0,0,0,255,0,0,0,0,255,255,255,0,0,0,255,255,255,0,0,0,0, - 255,0,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0, - 0,0,0,255,0,255,255,0,255,0,255,255,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,255,0,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,255,0,255,0,255,0,0,0,0,255, - 0,0,0,0,255,0,0,0,255,0,255,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,255,0,255,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0, - 255,255,255,0,0,0,0,0,0,255,0,0,255,255,0,0,255,0,0,0,0,0,255,0,255,0,0, - 0,0,0,0,255,0,0,0,0,255,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,255,0,255,255,255,255,0,0,0,255, - 0,0,0,255,0,0,0,0,255,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 0,0,0,255,0,0,255,255,255,0,255,255,255,255,0,0,0,0,0,0,0,0,0,255,0,0,0, - 255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,255,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,255, - 255,0,0,255,0,0,0,0,255,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0, - 0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,127,127,127,127,0,127,0,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,0,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,0,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,0,127,127,127,0,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127, - 127,127,0,127,127,127,0,127,127,127,0,127,127,127,127,0,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,255,0, - 0,0,0,0,255,0,0,0,0,0,0,255,0,255,0,0,0,255,0,255,255,0,0,0,255,0,0,255, - 0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,0,0,255,0,0,255,0,255,0,255, - 0,255,0,0,0,0,0,0,0,0,0,255,0,255,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,255,0,0,0,0,255,0,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,255, - 0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,127,0,0,255,255, - 0,0,0,0,0,255,255,0,0,0,0,0,255,255,0,0,0,0,0,255,255,0,0,0,0,0,255,255, - 0,0,0,0,0,255,255,0,0,0,0,0,255,255,255,255,255,0,0,0,255,255,255,0,0,255, - 255,255,255,255,0,255,255,255,255,255,0,255,255,255,255,255,0,255,255,255, - 255,255,0,255,255,255,0,255,255,255,0,255,255,255,0,255,255,255,0,255,255, - 255,255,0,0,0,255,0,0,0,0,255,0,0,0,255,255,255,0,0,0,0,0,255,255,255,0, - 0,0,0,0,255,255,255,0,0,0,0,0,255,255,255,0,0,0,0,0,255,255,255,0,0,0,0, - 0,0,0,0,0,0,0,0,255,255,255,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0, - 255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,0,255,0,0, - 255,0,127,0,0,255,255,0,0,0,0,0,255,255,0,0,0,0,0,255,255,0,0,0,0,0,255, - 255,0,0,0,0,0,255,255,0,0,0,0,0,255,255,0,0,0,0,255,0,255,0,0,0,0,0,255, - 0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,255,0,0,0,255,0, - 0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0, - 255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,255,0,0,0, - 0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,255, - 0,0,255,255,255,0,0,255,0,0,255,0,127,0,255,0,0,255,0,0,0,255,0,0,255,0, - 0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0, - 0,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0, - 0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,0, - 0,255,0,255,0,255,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,0,255, - 0,255,0,0,0,255,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0, - 255,0,255,0,0,0,0,255,0,0,255,0,255,0,0,255,0,0,255,0,255,0,255,0,0,127, - 0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0, - 0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,255,255,255,255,0,255,0,0,0, - 0,0,0,255,255,255,255,0,0,255,255,255,255,0,0,255,255,255,255,0,0,255,255, - 255,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,255,255,255,0,0,255, - 0,255,0,0,255,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0, - 0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,255,0,255,0,0,255, - 0,0,255,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0, - 255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,255,0,0,255,0,127,255,255, - 255,255,255,255,0,255,255,255,255,255,255,0,255,255,255,255,255,255,0,255, - 255,255,255,255,255,0,255,255,255,255,255,255,0,255,255,255,255,255,255, - 0,0,255,255,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255, - 0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,0, - 0,0,255,0,255,0,0,0,255,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0, - 255,0,255,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255, - 0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,255,0,0,255,0,127,255,0, - 0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0, - 0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,255,0,0,0,255,0,255, - 0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0, - 0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0,0,255,0,0,0,255, - 0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0, - 0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0,255, - 0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,255, - 255,0,0,255,0,0,255,0,127,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0, - 0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,255, - 255,255,255,0,0,0,255,255,255,0,0,255,255,255,255,255,0,255,255,255,255, - 255,0,255,255,255,255,255,0,255,255,255,255,255,0,255,255,255,0,255,255, - 255,0,255,255,255,0,255,255,255,0,255,255,255,255,0,0,0,255,0,0,0,0,255, - 0,0,0,255,255,255,0,0,0,0,0,255,255,255,0,0,0,0,0,255,255,255,0,0,0,0,0, - 255,255,255,0,0,0,0,0,255,255,255,0,0,0,0,255,0,0,0,255,0,255,0,255,255, - 255,0,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255, - 0,0,0,255,255,255,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,255,0,0,127,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127, - 127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 0,127,127,127,0,127,127,127,0,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,255,255,0,255,0, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0, - 0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,255,255,0,255, - 0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,255, - 0,0,0,0,255,0,0,0,255,0,255,0,255,0,255,255,0,0,255,0,255,0,0,255,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,255,0,255,0,0,255,0, - 255,0,0,255,0,255,0,255,0,255,255,0,255,0,0,255,255,0,255,0,255,255,0,0, - 0,255,0,0,0,0,255,0,0,0,255,0,255,0,255,0,255,255,0,255,0,0,255,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,255,0,255,0,0,255,0,255,0, - 0,0,255,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0,255, - 255,0,0,0,255,255,0,0,255,255,255,0,255,255,0,0,0,255,255,0,0,255,255,0, - 0,0,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0,255,0,255,0,0,255,0,0,255, - 0,0,0,0,255,0,255,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0,255,255,0,0, - 0,255,255,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,255,0,0,255, - 0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,0,255,0,255,255,255, - 0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,255,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,255, - 0,255,0,0,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,0,255, - 0,255,0,0,255,0,0,255,0,0,255,255,255,0,255,0,0,255,0,255,0,0,255,0,255, - 0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,0,255,255,255,255,255, - 0,255,0,0,255,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255, - 0,0,255,0,255,0,0,255,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,255,255,255,0,0,255,255,255,0,0,255,255,255,0,0,255,255,255, - 0,0,255,255,255,0,0,255,255,255,0,0,255,255,255,255,255,255,0,255,0,0,0, - 255,255,255,255,0,255,255,255,255,0,255,255,255,255,0,255,255,255,255,0, - 0,255,0,255,0,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0, - 255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,255, - 0,255,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,0, - 255,0,255,0,0,255,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0, - 255,0,255,0,0,255,0,255,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,255,0,255, - 0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255,0, - 0,255,0,0,0,0,255,0,0,0,255,255,0,0,255,0,255,0,0,255,0,255,0,0,255,0,255, - 0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,255,0,0,255,0,0,255,0,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,255,255,0,0,255,255,255,0,0,255, - 255,255,0,0,255,255,255,0,0,255,255,255,0,0,255,255,255,0,0,255,255,0,255, - 255,255,0,0,255,255,0,0,255,255,255,0,0,255,255,255,0,0,255,255,255,0,0, - 255,255,255,0,0,255,0,255,0,0,255,0,0,255,0,0,255,255,0,0,255,0,0,255,0, - 0,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0,255,255,0,0,0, - 0,0,0,0,0,0,0,255,255,255,0,0,0,255,255,255,0,0,255,255,255,0,0,255,255, - 255,0,0,255,255,255,0,0,0,255,0,0,0,255,255,255,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,0,127,127,127,127,0,127,127, - 127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,0,127,127,127,127,0,127,127,127,127,0, - 127,127,127,127,0,127,127,127,127,0,127,127,0,127,0,127,127,0,127,127,0, - 127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,0, - 127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127, - 127,127,0,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,0,127, - 127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 -}; - - -// Normal font -const int FONT1_BM_W = 253; -const int FONT1_BM_H = 106; -static const unsigned char s_Font1[] = -{ - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,255, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0, - 0,255,0,255,0,0,0,0,0,255,0,0,0,0,255,255,0,0,0,0,255,0,0,0,0,0,255,255, - 255,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,255,0,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,255,255,0,0,0,0,0, - 255,0,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,0,0,0,255,0,0,255, - 255,255,255,255,255,0,0,0,255,255,255,0,0,255,255,255,255,255,255,0,0,255, - 255,255,255,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,127,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,255,255, - 255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255, - 0,0,0,0,255,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,255,255,255,0,0,0,255,0,0,0,0,255,0, - 255,0,0,0,0,255,0,0,0,0,255,255,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255, - 0,0,255,0,255,0,255,0,255,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,255,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,255,0,0,0,0, - 0,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,0,255, - 0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255, - 0,0,0,0,255,0,255,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,255,0,255,0,0,0, - 0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,255,255,255,255,255,0,0,255,255, - 255,255,255,0,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255, - 0,0,0,255,0,0,0,0,0,0,255,255,0,0,0,0,255,255,255,255,255,255,0,0,0,0,255, - 255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,255,0,0, - 0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,255,255,0,0,0,0,255,255,0,0,255,0,0, - 255,255,0,0,0,255,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0, - 255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,255,255,0,0,255,0,0,0,255, - 0,0,0,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,255,255,255, - 0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,255,255,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,255,255,0, - 0,0,0,0,0,0,255,0,255,0,0,255,0,255,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,0,0,0,0,0,255,255, - 255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,255, - 0,0,0,0,0,0,0,0,255,0,255,255,255,255,255,255,0,0,0,0,0,0,255,0,255,0,0, - 0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,255,255,255,255,255,0,0,0, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,255,255,255,255,255,0,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,255,0,0,0,0, - 0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,255, - 0,255,0,0,0,255,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255, - 0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,255,0,0,0,0,0,255,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,255,0,255, - 0,0,0,255,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255, - 0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0, - 255,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0, - 0,0,255,0,0,0,255,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,255,0,255,0,0,0,0,0,0,255,255,255,0,0,0,0,0,255,0,0,0,0,255,255, - 0,0,0,255,255,255,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,255,255, - 255,0,0,0,255,255,255,255,255,0,255,255,255,255,255,255,0,0,255,255,255, - 255,0,0,0,0,0,0,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255, - 0,0,0,0,0,0,255,255,255,255,0,0,0,255,255,255,0,0,0,0,255,0,0,0,255,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,0, - 127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,0,127,127,127,0,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,0,127,127,127, - 127,0,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,255,0,0,0,0,0,255,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,255, - 255,255,255,0,0,0,0,0,0,0,255,0,0,0,0,255,255,255,255,255,0,0,0,0,255,255, - 255,255,0,255,255,255,255,255,0,0,0,255,255,255,255,255,255,0,255,255,255, - 255,255,0,0,0,255,255,255,255,0,0,255,0,0,0,0,0,255,0,255,255,255,0,0,255, - 255,255,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,255,0,0,0,0,255,255,0,255, - 255,0,0,0,0,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255,255,0,0,0,0, - 255,255,255,255,0,0,0,255,255,255,255,0,0,0,0,255,255,255,255,0,0,255,255, - 255,255,255,255,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0, - 0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,255,255,255, - 255,255,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,255,0,0,0,0,255,255,0,0, - 0,0,255,0,255,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0, - 0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0, - 0,255,0,0,0,0,0,255,0,255,0,0,0,255,0,0,255,0,0,0,0,0,255,255,0,0,0,0,255, - 255,0,255,255,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,255, - 0,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,255,0,0,255, - 0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0, - 0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,255,0,255,255,255,255,0,255,0,0,0,0,255,0,255,0,0,0,255,0,0, - 0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0, - 0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,255,0,0, - 255,0,0,0,255,0,0,0,0,0,255,0,255,0,0,255,0,255,0,255,0,255,0,0,0,255,0, - 255,0,0,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0, - 0,255,0,0,0,255,0,0,255,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,0, - 255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,255,0,0, - 0,255,0,0,255,0,0,0,255,0,255,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0, - 0,0,0,255,0,0,255,0,0,0,0,0,255,0,255,0,255,0,0,0,0,255,0,0,0,0,0,255,0, - 255,0,0,255,0,255,0,255,0,255,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0, - 0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,255, - 0,0,255,0,0,0,0,255,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,255,0,0,0,255,0,0,255,0,0,255,0,0,0,255, - 0,0,255,255,255,255,255,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,255,255, - 255,255,255,255,0,255,255,255,255,255,0,255,0,0,0,255,255,255,0,255,255, - 255,255,255,255,255,0,0,255,0,0,0,0,0,255,0,255,255,0,0,0,0,0,255,0,0,0, - 0,0,255,0,255,0,0,255,0,255,0,255,0,0,255,0,0,255,0,255,0,0,0,0,0,0,255, - 0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,255,255,255,0,0,0,0,255,255, - 255,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0,0, - 255,0,0,255,0,255,0,0,255,0,0,0,0,255,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,255,0,0,0,255,0,0,255,0,0,255, - 0,0,0,255,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255, - 0,0,0,0,0,255,0,255,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,255,255,0,0,255, - 0,255,0,0,0,255,0,255,0,255,0,0,0,0,0,0,255,0,255,255,255,255,255,0,0,255, - 0,0,0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,0, - 255,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,127,255,0,255,0,0,0,255,0,0,255,0,0,255,255,255,255,255,0,0,255,0,0,0, - 0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0, - 0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,255,0,0, - 255,0,0,0,255,0,0,0,0,0,255,0,0,255,255,0,0,255,0,255,0,0,0,255,0,255,0, - 255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,255,0,0,0,255, - 0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,0,255,0,255, - 0,0,0,0,0,255,255,0,0,0,255,255,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0, - 0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,0,255,255,255,255, - 255,255,0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0, - 0,0,0,255,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0, - 0,0,0,255,0,0,255,0,0,0,0,0,255,0,255,0,0,0,255,0,0,255,0,0,0,0,0,255,0, - 0,0,0,0,0,255,0,255,0,0,0,0,255,255,0,0,255,0,0,0,0,255,0,0,255,0,0,0,0, - 0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0, - 0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0, - 255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,255,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,255,255,255, - 255,255,0,0,0,0,255,255,255,255,0,255,255,255,255,255,0,0,0,255,255,255, - 255,255,255,0,255,0,0,0,0,0,0,0,255,255,255,255,255,0,255,0,0,0,0,0,255, - 0,255,255,255,0,255,255,255,0,0,255,0,0,0,0,255,0,255,255,255,255,255,0, - 255,0,0,0,0,0,0,255,0,255,0,0,0,0,255,255,0,0,0,255,255,255,255,0,0,0,255, - 0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,255,0,0,0,0,255,0,0,255,255,255,255, - 0,0,0,0,0,255,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0, - 0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,255,255,255,255, - 255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,255,255,255,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0,0,0,0,255,0,0, - 255,255,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 0,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0, - 0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,255, - 0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0, - 0,0,0,255,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,255,255,255,0,0,255,0,255,255, - 255,0,0,0,255,255,255,255,0,0,255,255,255,255,255,0,0,255,255,255,255,0, - 0,255,255,255,255,0,255,255,255,255,255,0,255,0,255,255,255,0,0,255,0,255, - 255,0,255,0,0,0,255,0,255,0,255,255,255,255,0,255,255,255,0,0,255,0,255, - 255,255,0,0,0,255,255,255,255,0,0,255,0,255,255,255,0,0,0,255,255,255,255, - 255,0,255,0,255,0,0,255,255,255,0,255,255,255,255,0,255,0,0,0,0,255,0,255, - 0,0,0,255,0,255,0,0,0,255,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255, - 255,255,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,0,0,0,0,0,255,0,255,255,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255, - 0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,255,0,255,255,0,0,0,255,0,255,0,0,255, - 0,255,0,0,255,0,0,255,0,255,0,0,0,255,0,0,0,255,0,255,255,0,0,0,255,0,255, - 0,0,0,0,255,0,255,255,0,0,0,255,0,255,0,0,0,0,255,0,255,255,0,0,255,0,0, - 0,0,0,255,0,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,0,0,255, - 0,0,255,0,255,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,0,255,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,255, - 0,255,0,0,0,0,255,0,255,0,0,255,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0, - 0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0, - 0,0,255,0,255,0,0,0,255,0,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,255,0,255, - 0,0,0,255,0,255,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,0,255, - 0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,255,0,0,0,255,0,0,0, - 255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0, - 0,255,255,255,255,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255, - 255,255,255,255,255,0,0,255,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255, - 0,0,255,0,255,255,0,0,0,0,255,0,255,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255, - 0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255, - 255,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,255,0,255,0,0,0,255,0,255,0,255, - 0,255,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,0,0,255,255,0,0,0,0,0,0, - 255,0,0,0,0,0,255,255,0,0,255,0,0,255,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,255,0,0,0,255,0,255,0, - 0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,0,255,0,0,255, - 0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,255,0,255,0,255,0,0,0,255,0,255, - 0,0,0,255,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255, - 0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0,0,0,255,0, - 0,255,0,255,0,0,0,255,0,255,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255, - 0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,255, - 255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,255, - 255,0,255,0,0,0,0,255,0,0,255,0,0,255,0,0,0,255,255,0,255,0,0,0,0,255,0, - 255,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,0,255,0,0,0,255,0,255,0,0,0, - 0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,255,255,0,255,0,0, - 0,0,0,0,255,0,0,255,0,0,0,255,0,0,0,255,255,0,0,0,255,0,0,0,0,0,255,0,0, - 0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0, - 255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,255,255,255,255,0,255,255, - 255,255,255,0,0,0,255,255,255,255,0,0,255,255,255,0,255,0,0,255,255,255, - 255,0,0,0,255,0,0,0,255,255,255,0,255,0,255,0,0,0,0,255,0,255,0,0,255,0, - 255,0,0,0,255,0,255,0,255,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255,0,0,255, - 255,255,255,0,0,255,255,255,255,255,0,0,0,255,255,255,0,255,0,255,0,0,0, - 255,255,255,0,0,0,0,255,255,0,0,255,255,255,0,255,0,0,0,255,0,0,0,0,0,255, - 0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,255,255,255,0,0,0,255, - 0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255, - 255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0, - 255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,0,127,127,127,127,127,0, - 127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,0,127,127,0,127,127,127,127,127,0,127,0,127,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,0,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 0,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,0,127,127, - 127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,255,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0, - 0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,255,0,255, - 0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,127,0,0,255, - 255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0, - 255,0,0,255,0,0,0,255,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255, - 255,255,255,255,255,255,0,255,255,255,255,255,255,0,0,0,255,255,255,255, - 255,255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,0,255,0,0, - 0,255,0,255,0,255,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,255,0,255,255,0,0,0,255,255,255,0,255,0,0,0,255,0,0,255,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255, - 255,0,0,255,255,0,0,255,0,0,0,0,0,255,0,127,0,255,0,0,0,0,0,0,0,255,0,0, - 0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,255,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,255,0,0,255,0,0, - 255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,255,0,255,0,0,0,255,0,255,0,255,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,127,255,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0, - 0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,255, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0, - 0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255, - 0,255,0,255,0,0,255,255,255,0,0,255,0,0,0,0,255,255,255,255,0,255,255,255, - 0,0,0,0,255,0,0,0,0,0,0,0,255,0,255,255,255,255,0,0,255,0,0,0,255,0,0,127, - 255,255,255,255,255,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0, - 0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255, - 0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0, - 0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,255,0,0, - 0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,255,0,255, - 0,0,0,127,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,255,255,0,0,0,255,255,0,0,0,255,255, - 255,255,0,0,0,255,0,0,0,255,0,0,0,0,0,255,255,255,255,255,0,0,0,255,0,0, - 0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0, - 0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0, - 0,0,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255, - 0,0,0,255,0,0,0,0,0,255,0,0,0,0,127,255,255,255,255,255,255,0,0,0,255,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255, - 0,0,255,0,255,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0,0,0,0,255,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,0,255,255,255,255,255,0,255,255,255,255,255,255,255,255,255, - 255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,255, - 0,255,0,0,0,0,255,255,255,255,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,255,0, - 0,0,0,0,0,255,0,0,0,0,127,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,255,0,0,255,0,0,0, - 0,0,0,255,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0, - 0,255,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255, - 0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0, - 0,0,255,0,0,0,0,127,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,255,0, - 0,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,255,0,0,255,0,255, - 0,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,255,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0, - 0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0, - 0,0,255,0,0,0,0,127,0,0,255,255,255,255,0,0,0,255,255,255,255,255,255,255, - 255,255,0,0,255,0,0,0,255,0,0,0,0,0,255,0,255,0,0,255,0,0,255,0,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,255,0, - 0,0,255,255,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,255,255,255,255,255, - 255,255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,0,255,255,255, - 255,255,255,0,0,0,255,255,255,255,255,255,255,255,255,0,0,0,255,255,255, - 255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,0,0,0,0,0,0,0,0,255,255,255,255,0,255,255,255,255,0,0,0,255,255, - 255,255,255,255,255,255,255,0,255,255,255,255,0,0,0,0,255,0,0,0,0,127,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,127,127,0,127,127,0,127,127,127,127,127,127,0,127,127,127,127,0,127, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,0, - 127,127,0,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127, - 0,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,0,127,127, - 127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,255,0,0,0, - 0,0,255,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0, - 255,0,0,0,0,255,255,255,255,0,0,255,0,0,255,0,0,0,0,0,255,255,255,255,0, - 0,0,0,0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,255, - 255,255,0,0,0,255,255,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,255,0,0,0,0,0,0, - 0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,255, - 255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 0,0,0,0,255,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,255,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,255, - 0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,255,0,0,0,255,0,0, - 0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,255,255,0,0,0,0,255,0,0,0,0, - 0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,127,0,0,0,0,0,255,0,0,0,0,255,255,255,255,0,0,255,0,0,0,0, - 0,255,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,0,0,255,255,0,0,255,0,0,0,0,255,255,255,0,0,0,255,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,255,255,0,0,255,0,0,0,0,0,0,0,0, - 0,0,255,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,255,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,255,0,255,255,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,255,0,0,0,255,0,255,0,0,255,0,0,0,0,0,255,0,0,0,255,0,0,0, - 0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,255,0,0,0,255,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,255,0,0, - 0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,255,255,255,255,0,0,0,0,255,0,255,0, - 0,0,0,255,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,255, - 0,0,255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255, - 0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,255,255,255,255,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,255,0,0, - 0,0,255,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,255, - 0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,0, - 0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0, - 0,0,0,255,0,0,255,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 255,255,255,0,0,255,255,255,255,0,0,255,255,255,0,0,0,0,0,0,0,0,0,255,0, - 0,0,0,255,0,0,255,255,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255,255, - 0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,255,255,0,0,0,0, - 255,0,0,255,0,255,255,255,0,0,0,0,0,0,255,0,255,0,0,255,255,0,0,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,255,0,0, - 0,255,0,255,0,0,0,255,255,255,255,255,0,0,0,255,0,0,255,0,0,0,255,255,255, - 255,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0, - 0,255,0,0,0,255,255,255,0,255,0,0,255,0,0,0,0,255,255,255,255,255,255,255, - 0,255,255,255,0,255,0,0,255,255,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,0, - 0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,255,0,0,0,0, - 255,0,0,255,255,255,0,255,0,0,255,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0, - 255,0,0,0,0,0,0,255,255,255,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255, - 0,0,255,0,0,0,0,0,0,0,0,255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0,0,255, - 0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0,255,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,255,0,0,255,0,0,0,0,0, - 0,255,0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,255,0,0,0,255,0,255, - 0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0, - 0,255,255,0,0,0,0,0,0,0,0,0,0,255,0,0,255,255,0,0,255,0,0,0,0,0,0,0,0,0, - 0,255,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,255,0,0,0,255,255,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,0,0,0,0,255,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,255,0,0,255, - 255,255,255,255,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,255,0,0,255,255,255, - 255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,255,0,0,0,0,255,255,255,255,0,255,255,255,255,255,255,0,0,0,0, - 0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255, - 255,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0, - 0,0,0,0,255,255,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,0,255,0,0,0, - 0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,255,255,255,255,0,0,0,0,255, - 0,0,0,0,0,0,255,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,255,255, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,255,255, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,0,255,0,255,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 127,127,0,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,0, - 127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,0,127,127,127,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,127,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,255, - 0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,255,255,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,255,255,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255, - 255,0,0,0,0,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,255,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,255,0,0,0, - 255,0,255,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,255,0, - 0,0,255,0,0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,255,255,0,255,0,0,0,0,0, - 0,0,0,0,0,255,0,255,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0, - 0,255,0,0,255,0,0,0,0,0,255,0,255,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,255,0,0,0,0,0,0,0,255,0, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0, - 0,0,0,0,0,0,255,255,255,255,255,255,255,0,0,0,255,255,255,255,0,255,255, - 255,255,255,255,0,255,255,255,255,255,255,0,255,255,255,255,255,255,0,255, - 255,255,255,255,255,0,255,255,255,0,255,255,255,0,255,255,255,0,255,255, - 255,0,0,255,255,255,255,0,0,0,255,255,0,0,0,0,255,0,0,0,255,255,255,255, - 0,0,0,0,0,255,255,255,255,0,0,0,0,0,255,255,255,255,0,0,0,0,0,255,255,255, - 255,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255, - 0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,127,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,0, - 255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255, - 0,0,0,255,0,0,255,255,0,0,0,0,255,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0, - 255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,255,0,0,0, - 0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0,255, - 0,0,0,0,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,127,0,0,255,0,255,0,0,0, - 0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0, - 255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,255,0,255,0,255,0,0,0,255,0,255, - 0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0, - 0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,0,255, - 0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0, - 0,0,255,0,0,255,0,0,0,255,0,0,255,255,255,255,255,0,0,255,0,0,0,255,0,0, - 0,0,0,0,0,0,0,0,0,127,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0, - 255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0, - 0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0, - 255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0, - 0,255,0,0,0,0,255,0,255,0,255,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0, - 0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,255,0,0,0,0,0,255, - 0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,255,0, - 255,0,0,0,255,0,0,0,0,255,0,255,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255, - 0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,255,255,255,255, - 255,0,255,0,0,0,0,0,0,255,255,255,255,255,255,0,255,255,255,255,255,255, - 0,255,255,255,255,255,255,0,255,255,255,255,255,255,0,0,255,0,0,0,255,0, - 0,0,255,0,0,0,255,0,0,255,255,255,255,0,0,255,0,255,0,0,255,0,0,255,0,255, - 0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0, - 0,0,0,255,0,255,0,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,0,255,0,0, - 0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,0,0, - 0,0,0,0,0,0,0,0,127,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0, - 255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255, - 255,255,255,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0, - 0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0, - 0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,255,0,0,0,0,0,0,255,0,255,0, - 0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0, - 0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,255,0,255,0,0,0,0,0,255, - 0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0,255, - 0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,127,0,255, - 255,255,255,255,0,0,0,255,255,255,255,255,0,0,0,255,255,255,255,255,0,0, - 0,255,255,255,255,255,0,0,0,255,255,255,255,255,0,0,0,255,255,255,255,255, - 0,0,0,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0, - 0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255, - 0,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,255,0,0,0,0,0,0,255,0,255, - 0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0,0,0,0,255,0,255,0,0,0, - 0,0,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,0, - 255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0, - 255,0,0,0,0,255,255,255,255,255,0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 127,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0, - 0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,255,0,0,0,255,0,0, - 0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255, - 0,0,0,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0, - 255,0,0,0,0,255,255,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255, - 0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,0,255,0,0,0,0,255,0,0, - 0,255,0,0,0,255,0,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0, - 0,255,0,0,0,255,0,0,0,255,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0, - 0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,127,255,0,0,0,0,0,255,0,255,0,0,0, - 0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255,0,0,0,0,0,255,0,255, - 0,0,0,0,0,255,0,255,0,0,0,0,255,255,255,255,255,0,0,0,255,255,255,255,0, - 255,255,255,255,255,255,0,255,255,255,255,255,255,0,255,255,255,255,255, - 255,0,255,255,255,255,255,255,0,255,255,255,0,255,255,255,0,255,255,255, - 0,255,255,255,0,0,255,255,255,255,0,0,0,255,0,0,0,0,255,255,0,0,0,255,255, - 255,255,0,0,0,0,0,255,255,255,255,0,0,0,0,0,255,255,255,255,0,0,0,0,0,255, - 255,255,255,0,0,0,0,0,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255, - 255,255,255,0,0,0,0,0,255,255,255,0,0,0,0,0,255,255,255,0,0,0,0,0,255,255, - 255,0,0,0,0,0,255,255,255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,0,0,0,0,255,0, - 255,255,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,0,127,127,127,0,127,127, - 127,0,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,255,0,0,0,0,0,0,255,0,0, - 0,0,255,255,0,0,0,255,255,0,255,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,255,255,0,0, - 0,0,0,0,0,0,0,0,255,0,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0, - 255,0,0,255,0,0,0,0,0,0,0,0,0,255,0,0,0,0,255,255,0,0,0,0,0,255,255,0,255, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0, - 0,255,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,255,0,0,0,0,255,0,0,0,0,255, - 0,0,255,0,255,0,255,255,0,0,0,255,0,0,255,0,0,255,0,0,255,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,255,0,0, - 0,255,0,0,255,0,0,0,255,0,255,0,255,0,255,255,0,255,0,0,255,0,255,0,0,0, - 255,0,255,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,255, - 0,255,255,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,255,0,0,0,0,255,0,0,255,0,0,0,255,0,0,255,0,0,0,0,255,0, - 0,0,255,0,0,0,0,0,0,0,255,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,255,255,255,0,0,0,255,255,255,0,0,0,255,255,255,0,0,0,255,255,255, - 0,0,0,255,255,255,0,0,0,255,255,255,0,0,0,255,255,255,0,0,255,255,0,0,0, - 0,255,255,255,255,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255, - 255,255,0,0,0,255,255,255,255,0,0,0,255,0,255,0,0,255,0,0,255,0,0,255,255, - 0,255,0,0,255,0,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255, - 0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0, - 0,0,0,255,0,0,0,0,0,0,255,255,255,255,0,0,255,0,0,0,0,255,0,255,0,0,0,0, - 255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,255,0,255,0,255,255, - 255,0,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,255,0,0,0,0,0, - 255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255, - 255,0,0,255,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0, - 0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,255,0,0,255,0,0,255,0,0,0,0,0,0,255, - 0,255,255,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255, - 0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,255, - 0,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255, - 0,255,0,0,0,255,0,255,255,0,0,0,255,0,255,0,0,0,255,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0, - 255,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0,0, - 255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,255, - 0,0,255,0,0,255,0,0,255,255,255,255,255,0,255,0,0,0,0,255,0,255,0,0,0,0, - 255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,255,0,0,0,255,0,255,0,255,0,0,0,0,255,0,255,0,0, - 0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,255,0,0,255,0,0,0, - 0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,255,255,255,0,0, - 255,255,255,255,0,0,255,255,255,255,0,0,255,255,255,255,0,0,255,255,255, - 255,0,0,255,255,255,255,0,0,255,255,255,255,255,255,255,255,255,0,255,0, - 0,0,0,0,255,255,255,255,255,255,0,255,255,255,255,255,255,0,255,255,255, - 255,255,255,0,255,255,255,255,255,255,0,0,255,0,255,0,0,255,0,0,255,0,255, - 0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255, - 0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,255,255,255,255, - 255,255,0,255,0,0,255,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255, - 0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,255,0,0,255,0,0,0,0,255,0,0,255, - 0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255,0,0,0,255,0,255,0,0,0,255,0,255, - 0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255, - 0,0,0,0,0,0,255,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0,0,255,0,0,0,0,0, - 0,255,0,0,0,0,0,0,0,255,0,255,0,0,255,0,0,255,0,255,0,0,0,0,255,0,255,0, - 0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0, - 0,0,0,255,0,255,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,255,0,255,0,0,0,255,0,255, - 0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255, - 0,255,0,0,255,0,0,0,0,255,0,0,255,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,255, - 0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255,0,255,0,0,0,255, - 0,255,0,0,0,255,0,255,0,0,0,255,255,0,0,0,255,0,255,0,0,0,0,0,255,0,0,0, - 0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,0,255,0,255, - 0,0,255,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0, - 255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0,255,0,0,0,0,255,0, - 0,0,0,0,255,0,0,0,0,0,255,0,0,0,255,0,0,255,0,0,0,255,255,0,255,0,0,0,255, - 255,0,255,0,0,0,255,255,0,255,0,0,0,255,255,0,0,0,255,0,0,0,255,0,0,0,0, - 255,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,255,255,255,255,0,0,255, - 255,255,255,0,0,255,255,255,255,0,0,255,255,255,255,0,0,255,255,255,255, - 0,0,255,255,255,255,0,0,255,255,255,0,0,255,255,255,0,0,0,255,255,255,255, - 0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255, - 255,255,255,0,0,0,255,0,255,0,0,255,0,0,255,0,0,255,255,255,255,0,0,255, - 0,0,0,0,255,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,255,255,255, - 255,0,0,0,255,255,255,255,0,0,0,255,255,255,255,0,0,0,0,0,0,255,0,0,0,0, - 0,255,255,255,255,0,0,0,0,255,255,255,0,255,0,0,255,255,255,0,255,0,0,255, - 255,255,0,255,0,0,255,255,255,0,255,0,0,0,255,0,0,0,255,255,255,255,255, - 0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,0,0, - 0,255,0,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,255,0,0,0,0,255,0,0,0,0,0,0,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,0,127,0,127,127,0,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 -}; - -// Normal font anti-aliased -const int FONT1AA_BM_W = 264; -const int FONT1AA_BM_H = 106; -static const unsigned char s_Font1AA[] = -{ - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0, - 0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0, - 59,241,97,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,168,34,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,251,89,0,0,89,255,125,89,255,125,0,0,0,0, - 7,199,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0, - 0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,59,238,42, - 206,125,0,0,0,0,7,199,34,89,166,0,0,0,0,168,34,0,0,0,175,255,255,166,0, - 0,7,202,89,0,0,0,0,59,245,255,251,89,0,0,0,59,238,34,0,12,232,89,0,0,89, - 247,34,0,59,245,206,199,124,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,7,202,89,0,12,235,255,247,34,0,0,0,0,12,232,89,0,0,12,235, - 255,255,251,89,0,7,206,255,255,255,125,0,0,0,0,138,251,89,0,0,59,245,255, - 255,255,251,89,0,0,89,255,255,166,0,89,255,255,255,255,255,201,0,0,59,245, - 255,255,125,0,0,12,235,255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255,255,255,247,34,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,138,225,21,59,238,34,175,125,0,0,0,0,59,192,0,172, - 89,0,0,59,245,255,255,251,89,89,247,34,12,228,34,0,138,166,0,0,0,0,12,235, - 125,0,175,225,21,0,0,59,238,34,0,138,201,0,0,0,0,175,166,0,0,0,89,255,201, - 0,0,0,0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,215,21,0,175, - 166,0,138,201,0,0,7,206,255,251,89,0,0,59,192,0,0,138,247,34,59,192,0,0, - 89,251,89,0,0,59,245,251,89,0,0,59,241,89,0,0,0,0,0,89,247,34,0,0,0,0,0, - 0,0,7,206,166,0,7,206,125,0,89,247,34,7,206,166,0,138,225,21,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,0,0,0,0,0,0,0,0,0,175,166,0,0,0,0,0, - 0,0,89,125,0,0,175,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0, - 0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,12,206, - 21,175,125,0,0,89,255,255,255,255,255,255,166,59,241,89,168,34,138,125, - 89,225,21,7,202,89,12,228,34,0,0,0,0,12,232,89,0,138,201,0,0,0,12,206,21, - 7,202,89,0,0,0,0,59,215,21,59,245,206,199,124,255,125,0,0,0,0,7,202,89, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0,12,232,89,0,59,238,34,0,0, - 0,59,241,89,0,0,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,12,232,132,241,89, - 0,0,59,241,89,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,89,247,34,0,12,232,89,0, - 12,232,89,59,241,89,0,59,241,89,0,138,247,34,0,0,138,247,34,0,0,0,0,0,12, - 235,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,166,0,0,0,0,0,0,0,0,0,138, - 225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0,0, - 0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,172, - 89,59,192,0,0,59,238,34,168,34,0,0,89,247,34,12,228,34,138,166,0,0,0,0, - 0,0,138,251,159,247,34,0,0,0,0,0,0,59,238,34,0,0,0,0,7,202,89,0,0,7,199, - 34,0,0,0,0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,59, - 241,89,0,59,241,89,0,0,0,59,241,89,0,0,0,0,0,0,89,247,34,0,0,0,0,138,201, - 0,7,206,125,59,241,89,0,0,59,245,255,255,251,89,0,12,235,255,255,255,125, - 0,0,0,0,7,206,166,0,0,0,175,251,89,138,201,0,59,241,89,0,12,235,125,0,138, - 247,34,0,0,138,247,34,0,0,0,59,245,247,34,0,0,0,0,7,206,255,255,255,255, - 255,255,125,0,0,0,0,138,255,201,0,0,0,0,0,0,89,251,89,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,138,201,0,0,0,0,0,0,0,0,0,12,206,21,138,125,0,0,7,206,255, - 247,34,0,0,0,175,255,255,166,59,215,21,175,255,255,125,0,0,138,171,206, - 166,0,175,201,0,0,0,0,89,201,0,0,0,0,0,0,175,125,0,0,0,0,0,0,0,0,12,235, - 255,255,255,255,255,255,125,0,0,0,0,138,255,255,251,89,0,0,0,0,0,59,215, - 21,0,59,241,89,0,59,241,89,0,0,0,59,241,89,0,0,0,0,0,12,235,166,0,0,0,138, - 255,255,125,0,175,201,0,59,241,89,0,0,0,0,0,0,175,247,34,59,241,89,0,89, - 247,34,0,0,0,89,247,34,0,0,0,89,255,255,255,125,0,12,235,166,0,59,245,125, - 0,0,0,0,0,0,0,0,0,0,0,175,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,89,251,89,0,0,7,206,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,201, - 0,0,0,0,0,0,0,12,235,255,255,255,255,255,225,21,0,0,0,175,255,251,89,0, - 0,0,0,0,175,125,89,225,21,59,238,34,89,225,21,12,235,166,175,166,0,0,0, - 0,89,201,0,0,0,0,0,0,175,125,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,138,166,0,0,59,241,89,0,59,241,89,0,0,0,59,241,89, - 0,0,0,0,12,235,166,0,0,0,0,0,0,59,241,97,206,255,255,255,255,255,125,0, - 0,0,0,0,59,241,89,59,238,34,0,12,235,125,0,0,12,235,125,0,0,0,12,232,89, - 0,59,245,125,0,89,255,255,232,241,89,0,0,0,0,0,0,0,0,0,0,0,0,59,245,247, - 34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,201,0,0,0,0,7,206,125,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,4, - 4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,125,12,206,21, - 0,0,0,0,0,168,34,175,166,0,0,0,0,59,215,21,138,201,0,12,228,34,138,225, - 21,0,12,235,251,89,0,0,0,0,59,215,21,0,0,0,0,12,232,89,0,0,0,0,0,0,0,0, - 0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,12,232,89,0, - 59,238,34,0,0,0,59,241,89,0,0,0,12,235,166,0,0,0,0,0,0,0,12,235,125,0,0, - 0,59,241,89,0,0,0,0,0,0,59,241,89,12,232,89,0,12,232,89,0,0,138,225,21, - 0,0,0,59,238,34,0,7,206,166,0,0,0,0,89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,12,235,247,34,0,0,7,206,255,255,255,255,255,255,125,0,0,138,255,166,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0, - 0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,0,0,0,0, - 0,0,0,0,172,89,89,166,0,0,0,89,166,0,168,42,206,125,0,0,0,7,202,89,0,89, - 225,21,59,238,34,89,251,89,0,0,175,255,201,0,0,0,0,7,202,89,0,0,0,0,59, - 215,21,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,0,0,138,247,34,0,0,0,0,0,7,206, - 201,0,12,228,34,0,0,0,175,166,0,138,201,0,0,0,0,59,241,89,0,0,12,235,166, - 0,0,0,0,89,166,0,0,89,251,89,0,0,0,59,241,89,0,0,59,192,0,0,175,225,21, - 0,175,201,0,138,225,21,0,12,235,125,0,0,0,0,12,235,166,0,59,241,89,0,0, - 0,7,206,166,0,0,138,247,34,0,0,59,245,125,0,0,0,0,0,0,0,12,232,89,0,0,0, - 0,0,0,0,0,0,0,0,175,166,0,0,0,0,0,0,0,0,7,206,166,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,12,206,21,138,125,0,0,0,12,235,255, - 255,255,166,0,0,0,0,138,201,0,0,0,175,255,255,125,0,0,138,255,255,255,125, - 12,235,247,0,0,0,0,138,201,0,0,0,0,175,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,7,206,166,0,0,0,0,0,0,7,206,201,0,89,201,0,0,0,0,12,235,255,247, - 34,0,0,7,206,255,255,255,225,21,89,255,255,255,255,255,166,59,245,255,255, - 251,89,0,0,0,0,59,241,89,0,0,12,235,255,255,225,21,0,0,12,235,255,251,89, - 0,0,175,225,21,0,0,0,0,0,59,245,255,255,125,0,0,89,255,255,166,0,0,0,138, - 247,34,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,7,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4, - 0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,168,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,125, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,0,0,0,0,0,0,0,0,0,0,0,0, - 4,4,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,168,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89, - 255,125,89,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,201,0,0,0,0, - 0,0,0,0,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,0,0,0,0,0,0,0,0,0, - 127,127,127,127,0,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,0,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,0,127,127,127,0,127,127,127,127,0,127,127,127,0,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,0, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,255,125,138,166,0,0,0,89,255,255,247, - 34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,89,255,255, - 255,255,166,0,0,0,0,0,12,235,225,21,0,0,59,245,255,255,255,251,89,0,0,0, - 59,245,255,255,251,89,59,245,255,255,255,247,34,0,0,59,245,255,255,255, - 255,127,81,245,255,255,255,255,127,0,0,59,245,255,255,255,166,0,59,241, - 89,0,0,0,59,241,89,89,255,255,255,125,7,206,255,251,89,59,241,89,0,0,89, - 255,166,59,241,89,0,0,0,0,59,245,225,21,0,0,7,206,251,89,59,245,247,34, - 0,0,59,241,89,0,0,138,255,255,255,166,0,0,59,245,255,255,255,225,21,0,0, - 0,138,255,255,255,166,0,0,59,245,255,255,255,251,89,0,0,0,59,245,255,255, - 201,89,255,255,255,255,255,255,255,125,59,241,89,0,0,0,59,241,97,206,166, - 0,0,0,0,175,201,175,201,0,0,7,206,201,0,0,0,175,171,206,225,21,0,0,59,245, - 166,245,125,0,0,0,89,251,89,89,255,255,255,255,255,127,0,228,34,0,0,59, - 215,21,0,0,0,0,12,228,34,0,0,0,59,245,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,175,225,21,0,0,0,175,225,21,0,0,0,89,232,241,89,0,0,59, - 241,89,0,0,138,225,21,0,89,255,125,0,0,59,192,59,241,89,0,0,175,251,89, - 0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,89,255,125,0,0,7,199,34,59,241, - 89,0,0,0,59,241,89,0,59,241,89,0,0,0,59,241,89,59,241,89,0,59,241,89,0, - 59,241,89,0,0,0,0,59,245,255,125,0,0,89,255,251,89,59,245,255,201,0,0,59, - 241,89,0,138,251,89,0,12,235,166,0,59,241,89,0,7,206,225,21,0,138,251,89, - 0,12,235,166,0,59,241,89,0,0,138,247,34,0,12,235,125,0,7,176,21,0,0,59, - 241,89,0,0,0,59,241,89,0,0,0,59,241,89,138,225,21,0,0,12,235,125,89,225, - 21,0,59,245,247,34,0,12,232,89,12,235,166,0,7,206,166,0,89,247,34,0,7,206, - 125,0,0,0,0,0,7,206,166,12,228,34,0,0,7,202,89,0,0,0,0,12,228,34,0,0,12, - 235,133,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,138,201,0,138, - 255,255,255,125,138,166,0,0,7,206,166,175,166,0,0,59,241,89,0,0,89,247, - 34,7,206,166,0,0,0,0,0,59,241,89,0,0,0,175,225,21,59,241,89,0,0,0,0,59, - 241,89,0,0,0,0,7,206,166,0,0,0,0,0,0,59,241,89,0,0,0,59,241,89,0,59,241, - 89,0,0,0,59,241,89,59,241,89,59,241,89,0,0,59,241,89,0,0,0,0,59,241,159, - 225,21,0,175,166,241,89,59,241,132,241,89,0,59,241,89,12,235,166,0,0,0, - 89,247,34,59,241,89,0,0,89,247,34,12,235,166,0,0,0,89,247,34,59,241,89, - 0,0,59,241,89,0,59,238,34,0,0,0,0,0,0,59,241,89,0,0,0,59,241,89,0,0,0,59, - 241,89,59,241,89,0,0,89,225,21,59,241,89,0,89,206,202,89,0,59,238,34,0, - 89,251,89,138,225,21,0,0,175,201,0,138,225,21,0,0,0,0,0,175,225,21,12,228, - 34,0,0,0,138,166,0,0,0,0,12,228,34,0,7,206,166,0,12,235,125,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,7,202,89,89,225,21,7,206,125,12,206,21,0,59,238, - 34,89,247,34,0,59,241,89,0,0,175,201,0,59,241,89,0,0,0,0,0,59,241,89,0, - 0,0,59,241,89,59,241,89,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,0, - 59,241,89,0,0,0,59,241,89,0,59,241,89,0,0,0,59,241,89,59,241,102,232,89, - 0,0,0,59,241,89,0,0,0,0,59,241,102,232,89,59,215,81,241,89,59,241,89,138, - 225,21,59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,7,206,201,0,59,241, - 89,0,0,0,59,241,89,59,241,89,0,0,175,201,0,0,12,235,166,0,0,0,0,0,0,59, - 241,89,0,0,0,59,241,89,0,0,0,59,241,89,7,206,166,0,0,175,166,0,7,206,125, - 0,175,125,175,166,0,138,201,0,0,0,175,255,251,89,0,0,0,59,245,166,241,89, - 0,0,0,0,0,89,247,34,0,12,228,34,0,0,0,89,201,0,0,0,0,12,228,34,12,235,201, - 0,0,0,59,245,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,59,215,21,175,125, - 0,7,206,125,7,199,34,0,138,201,0,12,235,125,0,59,245,255,255,255,247,34, - 0,59,241,89,0,0,0,0,0,59,241,89,0,0,0,59,241,89,59,245,255,255,255,255, - 127,59,245,255,255,255,255,127,59,241,89,0,0,0,0,0,0,59,245,255,255,255, - 255,255,251,89,0,59,241,89,0,0,0,59,241,89,59,245,255,247,34,0,0,0,59,241, - 89,0,0,0,0,59,241,89,138,201,175,166,59,241,89,59,241,89,12,235,125,59, - 241,89,59,241,89,0,0,0,12,235,125,59,245,255,255,255,201,0,0,59,241,89, - 0,0,0,12,235,125,59,245,255,255,255,125,0,0,0,0,59,245,255,255,125,0,0, - 0,59,241,89,0,0,0,59,241,89,0,0,0,59,241,89,0,138,225,21,59,241,89,0,0, - 175,201,7,202,89,89,201,0,175,166,0,0,0,12,235,166,0,0,0,0,0,138,255,166, - 0,0,0,0,0,59,245,125,0,0,12,228,34,0,0,0,12,228,34,0,0,0,12,228,34,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,59,215,21,175,125,0,7, - 206,125,7,199,34,7,206,125,0,0,175,201,0,59,241,89,0,0,89,247,34,59,241, - 89,0,0,0,0,0,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,0,59,241,89,0,0, - 0,0,59,241,89,0,59,245,255,251,89,59,241,89,0,0,0,59,241,89,0,59,241,89, - 0,0,0,59,241,89,59,241,89,175,225,21,0,0,59,241,89,0,0,0,0,59,241,89,12, - 235,247,34,59,241,89,59,241,89,0,89,247,94,241,89,59,241,89,0,0,0,59,241, - 89,59,241,89,0,0,0,0,0,59,241,89,0,0,0,59,241,89,59,241,89,12,235,166,0, - 0,0,0,0,0,0,138,251,89,0,0,59,241,89,0,0,0,59,241,89,0,0,0,59,241,89,0, - 12,232,89,138,225,21,0,0,89,225,81,215,21,12,228,47,232,89,0,0,0,175,255, - 251,89,0,0,0,0,59,241,89,0,0,0,0,7,206,201,0,0,0,12,228,34,0,0,0,0,175, - 125,0,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 12,228,34,89,201,0,7,206,125,59,215,21,59,245,255,255,255,255,247,34,59, - 241,89,0,0,59,241,89,7,206,166,0,0,0,0,0,59,241,89,0,0,0,138,225,21,59, - 241,89,0,0,0,0,59,241,89,0,0,0,0,7,206,166,0,0,0,59,241,89,59,241,89,0, - 0,0,59,241,89,0,59,241,89,0,0,0,59,241,89,59,241,89,7,206,201,0,0,59,241, - 89,0,0,0,0,59,241,89,0,175,166,0,59,241,89,59,241,89,0,7,206,200,241,89, - 12,235,166,0,0,0,89,247,34,59,241,89,0,0,0,0,0,12,235,166,0,0,0,89,247, - 34,59,241,89,0,59,245,125,0,0,0,0,0,0,12,232,89,0,0,59,241,89,0,0,0,12, - 232,89,0,0,0,59,238,34,0,0,175,171,206,166,0,0,0,12,232,159,201,0,7,202, - 132,215,21,0,0,89,247,34,175,225,21,0,0,0,59,241,89,0,0,0,0,138,225,21, - 0,0,0,12,228,34,0,0,0,0,89,201,0,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,138,201,7,206,255,251,226,255,255,166,0, - 138,201,0,0,0,12,235,125,59,241,89,0,0,138,247,34,0,89,255,125,0,0,59,192, - 59,241,89,0,0,138,251,89,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,89,255, - 125,0,0,59,241,89,59,241,89,0,0,0,59,241,89,0,59,241,89,0,0,0,89,247,34, - 59,241,89,0,12,235,166,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,59,241,89, - 59,241,89,0,0,59,245,251,89,0,138,251,89,0,59,245,166,0,59,241,89,0,0,0, - 0,0,0,138,251,89,0,59,245,166,0,59,241,89,0,0,138,251,89,0,89,166,0,0,89, - 247,34,0,0,59,241,89,0,0,0,0,138,225,21,0,7,206,166,0,0,0,89,255,251,89, - 0,0,0,7,206,255,125,0,0,138,255,201,0,0,12,235,125,0,12,235,166,0,0,0,59, - 241,89,0,0,0,89,251,89,0,0,0,0,12,228,34,0,0,0,0,12,228,34,0,0,12,228,34, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,7,206,225,21,0, - 0,0,0,0,0,7,206,125,0,0,0,0,175,201,59,245,255,255,255,247,34,0,0,0,59, - 245,255,255,251,89,59,245,255,255,255,225,21,0,0,59,245,255,255,255,255, - 127,81,241,89,0,0,0,0,0,0,59,245,255,255,255,201,0,59,241,89,0,0,0,59,241, - 89,89,255,255,255,138,235,255,255,125,0,59,241,89,0,0,89,255,201,59,245, - 255,255,255,255,166,59,241,89,0,0,0,0,59,241,89,59,241,89,0,0,0,175,251, - 89,0,0,138,255,255,255,166,0,0,59,241,89,0,0,0,0,0,0,0,138,255,255,255, - 166,0,0,59,241,89,0,0,0,175,251,89,12,235,255,255,251,89,0,0,0,59,241,89, - 0,0,0,0,0,59,245,255,251,89,0,0,0,0,12,235,201,0,0,0,0,0,138,251,89,0,0, - 89,255,125,0,7,206,225,21,0,0,89,255,125,0,0,59,241,89,0,0,0,175,255,255, - 255,255,255,127,0,228,34,0,0,0,0,0,175,125,0,0,12,228,34,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,89,255,255,255,255,125,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12, - 228,34,0,0,0,0,0,89,201,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,138,255,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,255,125,0,0,0,12,228, - 124,255,255,247,34,0,0,0,0,0,0,0,0,0,245,255,255,255,255,255,255,0,0,0, - 0,0,0,0,0,0,0,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,0,127, - 127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4,4,4,4,4,4,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,0,89,255,125,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,89,255,255,166,0,0,0,0,0, - 0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,255,201,0,12,228, - 34,0,0,89,255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4,4,4,116,116, - 4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,59,241,89,0,0,0,0,0,0,0,0,0,59,241,89,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0, - 0,0,0,59,241,89,0,0,0,0,59,241,89,0,89,251,89,59,241,89,0,0,0,0,59,241, - 89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,225, - 21,0,0,12,228,34,0,0,0,0,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4, - 4,4,28,244,252,52,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59, - 241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,59,241,89,0, - 0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,59,241, - 89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166, - 0,0,0,12,228,34,0,0,0,0,89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4, - 4,180,252,164,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,7,206,255,255,255, - 125,0,59,241,194,255,251,89,0,0,7,206,255,255,201,0,12,235,255,255,251, - 89,0,12,235,255,251,89,7,206,255,255,247,34,0,12,235,255,255,251,89,59, - 241,194,255,255,125,0,59,241,89,89,255,251,89,59,241,89,0,138,251,89,59, - 241,89,59,241,159,255,255,125,89,255,255,166,0,59,241,194,255,255,125,0, - 0,0,12,235,255,247,34,0,59,241,194,255,255,125,0,0,12,235,255,255,251,89, - 59,241,159,255,201,0,138,255,255,247,34,206,255,255,255,166,59,241,89,0, - 59,241,97,206,166,0,0,12,235,125,175,201,0,7,206,166,0,7,206,133,206,225, - 21,0,89,255,255,166,0,0,12,235,125,138,255,255,255,255,166,0,0,138,166, - 0,0,0,12,228,34,0,0,0,0,89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4, - 76,252,244,20,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,89,247,34, - 59,245,166,0,138,225,21,7,206,201,0,0,0,7,206,166,0,59,241,89,7,206,125, - 0,89,225,21,59,241,89,0,0,7,206,166,0,59,241,89,59,245,166,0,89,247,34, - 59,241,89,0,59,241,89,59,241,89,138,225,21,0,59,241,89,59,245,201,0,89, - 255,201,0,89,247,34,59,245,166,0,89,247,34,0,7,206,166,0,138,225,21,59, - 245,166,0,138,247,34,7,206,166,0,59,241,89,59,245,201,0,0,59,238,34,0,130, - 34,59,241,89,0,0,59,241,89,0,59,241,89,89,247,34,0,89,247,34,138,225,21, - 12,235,225,21,12,232,89,7,206,166,12,235,125,89,247,34,0,89,247,34,0,0, - 0,89,247,34,0,0,138,166,0,0,0,12,228,34,0,0,0,0,89,225,21,0,0,7,206,247, - 34,0,0,89,201,0,0,4,4,68,12,4,4,4,220,252,108,4,4,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,0,0,59, - 241,89,0,59,241,89,59,238,34,0,59,238,34,59,241,89,0,0,59,241,89,0,59,241, - 89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,159,201,0,0,0,59, - 241,89,59,241,89,0,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,59,241, - 89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0, - 0,59,241,89,0,0,0,59,241,89,0,0,59,241,89,0,59,241,89,12,235,125,0,175, - 166,0,59,238,34,89,171,202,89,89,225,21,0,59,241,226,201,0,12,235,125,0, - 175,166,0,0,0,12,235,125,0,0,59,238,34,0,0,0,12,228,34,0,0,0,0,7,206,125, - 0,7,202,89,12,235,166,0,175,125,0,0,4,60,244,172,4,4,132,252,212,4,4,4, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,89,255,255,255,251,89,59,241,89, - 0,59,241,89,59,238,34,0,0,0,59,238,34,0,59,241,89,59,245,255,255,255,251, - 0,59,241,89,0,0,59,238,34,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0, - 59,241,89,59,245,255,225,21,0,0,59,241,89,59,241,89,0,59,241,89,0,59,241, - 89,59,241,89,0,59,241,89,0,59,238,34,0,12,232,89,59,241,89,0,12,232,89, - 59,238,34,0,59,241,89,59,241,89,0,0,0,175,255,255,201,0,59,241,89,0,0,59, - 241,89,0,59,241,89,0,175,201,12,232,89,0,7,206,125,172,89,138,166,138,201, - 0,0,0,138,247,34,0,0,175,201,12,232,89,0,0,7,206,166,0,0,175,225,21,0,0, - 0,0,12,228,34,0,0,0,0,0,0,175,225,34,206,21,0,0,175,255,166,0,0,0,4,52, - 244,252,140,36,244,252,60,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,59, - 241,89,0,59,241,89,59,241,89,0,59,238,34,59,241,89,0,0,0,59,241,89,0,59, - 241,89,59,238,34,0,0,0,0,59,241,89,0,0,59,241,89,0,59,241,89,59,241,89, - 0,59,241,89,59,241,89,0,59,241,89,59,241,97,206,201,0,0,59,241,89,59,241, - 89,0,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,59,241,89,0,59,241,89, - 59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,0,0,0,0,59,245, - 125,59,241,89,0,0,59,241,89,0,59,241,89,0,59,238,124,225,21,0,0,175,176, - 206,21,59,215,187,125,0,0,59,245,255,201,0,0,89,247,124,225,21,0,0,138, - 225,21,0,0,0,59,241,89,0,0,0,12,228,34,0,0,0,0,12,235,125,0,0,0,0,0,0,0, - 0,0,0,0,0,4,4,76,252,252,220,252,164,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,89,247,34,0,89,251,89,59,241,89,0,175,201,0,7,206,201,0,0,0, - 7,206,166,0,138,251,89,7,206,166,0,7,199,34,59,241,89,0,0,7,206,166,0,138, - 251,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,12,235,166, - 0,59,241,89,59,241,89,0,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,7, - 206,166,0,138,225,21,59,241,89,0,138,225,21,7,206,166,0,89,251,89,59,241, - 89,0,0,89,125,0,12,232,89,12,232,89,0,12,12,235,125,0,175,251,89,0,7,206, - 255,125,0,0,0,89,255,201,0,7,206,247,34,0,7,206,166,59,245,125,0,7,206, - 255,125,0,0,59,241,89,0,0,0,0,0,138,166,0,0,0,12,228,34,0,0,0,0,89,225, - 21,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,100,252,252,244,28,4,4,4,4,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,175,255,255,232,241,89,59,245,255,255,247,34, - 0,0,12,235,255,255,201,0,59,245,255,200,241,89,0,12,235,255,251,89,0,59, - 241,89,0,0,0,12,235,255,200,241,89,59,241,89,0,59,241,89,59,241,89,0,59, - 241,89,59,241,89,0,59,245,201,59,241,89,59,241,89,0,59,241,89,0,59,241, - 89,59,241,89,0,59,241,89,0,0,12,235,255,247,34,0,59,245,166,255,247,34, - 0,0,59,245,255,166,241,89,59,241,89,0,0,59,245,255,255,166,0,0,138,255, - 255,125,0,89,255,255,166,241,89,0,0,138,247,34,0,0,0,59,245,125,0,0,138, - 225,21,7,206,225,21,0,138,251,0,0,138,247,34,0,0,175,255,255,255,255,166, - 0,0,138,166,0,0,0,12,228,34,0,0,0,0,89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,4, - 4,4,4,132,252,108,4,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0, - 0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,0,0,0,0,0,0,0,0,0,138, - 201,0,0,0,12,228,34,0,0,0,0,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4, - 116,4,4,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,166,255,255, - 247,34,0,0,0,0,0,0,0,0,0,0,0,255,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,59, - 241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,7,206,255, - 201,0,12,228,34,0,0,89,255,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4, - 4,4,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,0,127,127,127,0,127,127,127, - 127,127,127,0,127,127,0,127,127,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,0,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,127,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,89,247,34,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,59,238,34,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255, - 225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 12,235,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,238,34,138,201,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0,0,0,0,0,7,199,34,0,0,0,0,138,255, - 201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,251,89,0,0,138,255,251,97,206,201,0,0,138, - 251,102,235,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255, - 201,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,7,206,166,12,232,89,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,166,12,235,127,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,175,255,255,255,225,21,59,245,255,255,255, - 255,255,125,0,0,0,0,0,0,0,7,206,255,247,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,7,199,34,0,0,0,0,0,7,199,34,0,0,0,138,225,21,175,166,0,0,175,255,255, - 166,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,59,245,255,255,201,0,0,0,0,0,0,0,0, - 59,245,255,255,255,255,255,255,255,255,125,0,59,245,255,255,255,255,255, - 125,0,0,89,255,255,255,255,255,225,21,59,245,255,255,255,255,255,125,0, - 0,0,59,245,255,255,255,255,255,125,7,206,166,0,0,175,171,206,166,89,247, - 34,0,175,201,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 12,228,34,175,255,125,0,0,89,255,255,255,125,175,251,89,89,255,125,0,7, - 206,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,255,255, - 255,255,125,0,0,7,206,255,125,59,245,125,0,0,0,89,251,89,0,0,0,0,0,0,0, - 127,7,206,225,21,0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,0,175,201,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,255,255,255,125,0,59,245,255, - 255,255,255,125,0,0,0,0,0,0,0,89,247,34,12,228,34,0,138,166,0,0,0,0,0,0, - 0,0,0,0,12,235,125,0,7,176,21,0,0,0,0,0,0,138,251,89,0,0,138,201,0,0,0, - 0,0,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,7,206,166,0,59,115,0,0,0,0,59,115, - 0,0,0,59,115,0,0,0,0,59,115,0,89,201,0,12,232,89,89,201,7,202,89,12,232, - 89,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,7,199,34,0,172,132,196,199,163,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,0,89,247,34,0,7, - 206,125,0,0,0,0,0,0,0,0,127,89,247,34,0,0,0,0,0,59,115,0,0,0,0,59,115,0, - 0,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0, - 0,0,0,0,7,199,34,0,0,0,0,0,0,0,0,0,89,225,21,7,202,89,12,228,34,0,0,0,0, - 0,0,0,0,0,0,59,238,34,0,0,0,0,0,0,0,130,34,59,241,89,0,0,0,138,201,0,0, - 0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,175,225,21,0,59,115,0,0,0,0,59, - 115,0,0,0,59,115,0,0,0,0,59,115,0,12,228,34,59,192,0,12,228,34,138,166, - 59,215,21,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,7,199,34,0,172,89,175,166,138,125,0,138,255,255,247,34,12, - 146,0,0,0,0,89,255,255,255,125,12,235,255,255,125,0,0,0,59,115,0,0,0,0, - 59,115,0,138,255,255,255,255,127,0,175,201,0,138,225,21,0,0,0,0,0,0,0,0, - 127,245,255,255,255,255,255,125,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,12, - 232,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0,0,0,0,0,7,199, - 34,0,0,0,0,0,0,0,0,0,89,247,34,12,228,34,138,166,0,0,0,0,0,0,0,0,0,0,0, - 12,235,166,0,0,0,0,0,0,175,225,21,138,225,21,0,0,0,138,201,0,0,0,0,0,0, - 59,115,0,0,0,0,59,115,0,0,0,0,0,89,247,34,0,0,59,115,0,0,0,0,59,115,0,0, - 0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,166, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0,172, - 89,0,0,138,125,59,238,34,0,130,34,7,206,201,0,0,59,241,89,0,12,235,255, - 125,0,59,241,89,0,0,59,115,0,0,0,0,59,115,0,0,0,0,89,247,34,0,59,245,166, - 241,89,0,0,0,0,0,0,0,0,0,127,138,225,21,0,0,0,0,0,59,115,0,0,0,0,59,115, - 0,0,0,0,0,89,255,255,255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199, - 34,0,0,0,0,0,7,199,34,0,0,0,0,0,0,0,0,0,0,175,255,255,166,59,215,21,175, - 255,255,125,0,89,255,255,201,0,0,0,59,245,255,255,125,0,12,235,166,0,0, - 138,225,21,0,0,0,138,255,255,255,255,247,34,0,59,115,0,0,0,0,59,115,0,0, - 0,0,59,245,125,0,0,0,59,115,0,0,0,0,59,115,0,0,0,59,115,0,0,0,0,59,115, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,251,102,0,255,255,255,255, - 255,0,245,255,255,255,255,255,255,255,255,255,255,127,21,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,59,241,89,0,0,0,0,0,138,247,34,138,201,0,0,0,175, - 201,0,0,0,175,166,0,0,59,115,0,0,0,0,59,115,0,0,0,12,235,125,0,0,0,138, - 255,166,0,0,0,0,0,0,0,0,0,0,127,245,255,255,255,255,225,21,0,59,115,0,0, - 0,0,59,115,0,0,0,0,0,0,89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,7,199,34,0,0,0,59,245,255,255,255,255,125,0,0,0,0,0,0,0,0,0,0,0,0,175, - 125,89,225,21,59,238,47,232,89,7,206,125,0,0,0,0,0,138,251,89,12,235,166, - 0,0,138,225,21,0,0,0,138,201,0,0,0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,7, - 206,201,0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,59,115,0,0,0,0,59,115,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,251,89,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,255,255,201,0, - 0,0,138,247,34,175,201,0,0,0,138,255,255,255,255,255,166,0,0,59,115,0,0, - 0,0,59,115,0,0,7,206,166,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,127,89,251, - 89,0,0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,138,201,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0,0,0,0,0,7,199,34,0,0,0,0,0,0,0,0,0, - 0,0,0,0,59,215,21,138,201,0,12,228,47,228,34,0,175,166,0,0,0,0,0,12,232, - 89,0,0,175,225,21,59,241,89,0,0,0,138,201,0,0,0,0,0,0,59,115,0,0,0,0,59, - 115,0,0,0,138,225,21,0,0,0,0,59,115,0,0,0,0,59,115,0,0,0,59,115,0,0,0,0, - 59,115,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,166,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59, - 245,125,7,206,201,0,0,138,201,0,0,0,175,201,0,0,0,0,0,0,0,59,115,0,0,0, - 0,59,115,0,0,138,225,21,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,127,7,206, - 247,34,0,0,0,0,59,115,0,0,0,0,59,115,0,59,245,125,0,0,175,166,0,0,0,59, - 245,125,175,225,29,206,166,0,89,247,34,7,206,166,0,0,0,7,199,34,0,0,0,0, - 0,7,199,34,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,89,225,21,59,238,47,232,89, - 7,206,125,0,89,166,0,0,89,247,34,0,0,0,130,34,0,138,255,125,0,0,138,201, - 0,0,0,0,0,0,59,115,0,0,0,0,59,115,0,0,89,251,89,0,0,0,0,0,59,115,0,0,0, - 0,59,115,0,0,0,59,115,0,0,0,0,59,115,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,89,125,0,12,232,89,12,146,0,0,0,59,241,89,0,12,235,247, - 34,0,0,89,125,0,0,59,115,0,0,0,0,59,115,0,59,241,89,0,0,0,0,0,59,241,89, - 0,0,0,0,0,0,0,0,0,0,127,0,0,175,255,255,255,225,21,59,245,255,255,255,255, - 255,125,0,138,225,21,0,12,235,125,0,0,0,138,225,34,235,125,7,206,166,0, - 89,247,34,7,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 138,201,0,0,0,175,255,255,125,0,89,255,255,201,0,0,12,235,255,255,251,89, - 0,0,0,0,0,0,0,0,89,255,255,255,255,255,255,255,255,255,125,0,59,245,255, - 255,255,255,255,125,0,0,175,255,255,255,255,255,247,34,59,245,255,255,255, - 255,255,125,0,0,0,59,245,255,255,255,255,255,125,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,255,166,0,0,0,0,0,0,0,89,255,255, - 255,125,59,245,255,255,201,0,0,0,59,245,255,255,255,255,255,125,0,175,255, - 255,255,255,127,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,175,166,0,255,255,201,0,0,0,0,175,166,59,238,34,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,228,34,0,0, - 0,0,0,0,0,12,228,34,138,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,0,127,127,127,127,127, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,127,0,127,127,0,127,127,0,127,127,127,127,0, - 127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,245,255,255,255,255,255, - 251,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21, - 0,0,0,138,125,0,0,0,0,59,245,255,255,125,0,0,0,0,0,0,0,0,138,225,21,0,0, - 175,166,0,12,228,34,0,0,59,245,255,255,247,34,0,89,225,29,206,166,0,0,0, - 0,0,89,255,255,255,255,125,0,0,0,7,206,255,255,247,34,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255,255,255,255,125,0,0,0,0,0,0,0, - 0,0,0,0,0,138,255,255,166,0,0,0,0,7,202,89,0,0,0,0,0,12,235,255,125,0,0, - 175,255,255,225,21,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,138,255,255,255, - 255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,228,34,0,0,89,255,255,225,21,0,0, - 0,0,0,0,0,0,0,0,0,138,166,0,0,0,89,225,21,0,0,0,0,0,138,166,0,0,0,89,225, - 21,0,0,0,12,235,255,255,166,0,0,7,206,125,0,0,0,0,0,0,89,247,34,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,0,0,0,138,125,0,0,0,12, - 235,125,0,59,115,0,0,0,0,0,0,0,0,7,206,125,0,59,215,21,0,12,228,34,0,12, - 235,125,0,0,168,34,0,0,0,0,0,0,0,0,0,0,175,225,21,0,0,0,175,225,21,0,0, - 0,0,0,138,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,225, - 21,0,0,0,175,225,21,0,0,0,0,0,0,0,0,0,59,238,34,7,206,125,0,0,0,7,202,89, - 0,0,0,0,7,199,34,59,238,34,0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,89,255,255,255,125,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,247,34,0, - 59,241,89,0,175,201,0,0,0,0,0,0,0,0,0,7,206,255,166,0,0,12,232,89,0,0,0, - 0,7,206,255,166,0,0,12,232,89,0,0,0,0,0,0,0,59,215,21,0,89,201,0,0,0,0, - 0,0,0,89,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,7, - 206,255,255,251,89,0,59,241,89,0,0,0,138,201,0,0,0,138,201,0,0,89,225,21, - 175,125,0,0,12,228,34,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0, - 89,255,255,247,34,89,201,0,0,89,255,255,255,166,0,0,0,0,168,34,7,151,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,7,206,255,255,225,21,89,201,0,0,0, - 0,0,0,0,0,0,89,166,0,0,138,166,0,0,0,7,202,89,0,0,0,0,0,0,0,59,238,34,0, - 7,206,255,125,0,0,0,0,0,0,0,0,0,59,238,34,0,0,175,166,0,175,255,255,255, - 125,175,125,0,138,247,34,0,0,0,0,0,0,0,0,0,0,12,228,34,0,89,201,0,0,89, - 225,0,81,115,0,134,89,0,0,0,0,0,138,166,0,0,138,166,0,0,0,0,0,0,0,138,166, - 0,0,138,166,0,0,0,0,0,0,59,245,247,34,0,12,232,89,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,201,0,7,206,201,138,125, - 138,125,0,59,241,89,0,0,0,0,175,255,255,255,225,21,0,0,7,206,166,215,21, - 0,0,12,228,34,0,0,138,255,255,251,89,0,0,0,0,0,0,0,0,0,12,206,21,59,241, - 89,0,134,89,0,172,89,59,238,34,0,138,166,0,0,7,206,201,12,235,125,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,12,206,21,7,202,89,12,235,125,0,172,89,0,0,0,0, - 0,0,0,0,59,238,34,7,206,125,12,235,255,255,255,255,255,255,125,0,0,0,12, - 235,125,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,59,238,34,0,0,175,166,0,175,255, - 255,255,125,175,125,0,138,247,34,0,0,0,0,0,0,0,0,0,0,12,228,34,0,89,201, - 0,0,89,225,0,29,206,166,59,245,125,0,0,0,0,138,166,0,12,228,34,0,175,225, - 21,0,0,0,138,166,0,12,228,42,206,255,255,166,0,0,0,0,12,228,34,138,166, - 0,89,247,34,0,0,0,0,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0, - 0,0,138,201,0,59,241,89,138,125,0,0,59,245,255,255,255,125,0,0,138,166, - 0,89,201,0,0,0,0,89,255,125,0,0,0,0,0,0,0,7,206,125,0,138,251,89,0,0,0, - 0,0,0,0,0,89,166,0,138,201,0,0,0,0,0,89,166,59,215,21,0,175,166,0,59,245, - 125,89,251,89,0,0,12,235,255,255,255,255,255,255,125,138,255,255,251,89, - 127,166,0,7,202,89,12,232,89,0,89,166,0,0,0,0,0,0,0,0,0,138,255,255,166, - 0,0,0,0,7,202,89,0,0,0,0,0,59,241,89,0,0,0,0,0,7,206,125,0,0,0,0,0,0,0, - 0,59,238,34,0,0,175,166,0,89,255,255,255,125,175,125,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,12,228,34,0,59,241,89,0,175,201,0,0,0,175,201,7,206,201,0,0,0, - 138,166,0,175,166,0,138,200,215,21,0,0,0,138,166,0,175,166,7,151,0,89,247, - 34,0,0,0,59,238,47,228,34,59,219,209,34,0,0,0,89,255,125,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,59,238,34,138,125,0,0,0,59, - 241,89,0,0,0,0,138,166,0,89,201,0,0,59,245,255,255,255,255,125,0,0,0,0, - 0,59,238,34,0,7,206,125,0,0,0,0,0,0,0,0,89,166,0,138,201,0,0,0,0,0,89,166, - 0,175,255,255,223,166,0,12,235,125,59,241,89,0,0,0,0,0,0,0,0,0,175,125, - 0,0,0,0,0,138,125,0,7,206,255,255,125,0,0,59,157,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,7,202,89,0,0,0,0,7,206,255,255,255,166,7,206,255,255,201,0, - 0,0,0,0,0,0,0,0,59,238,34,0,0,175,166,0,0,89,255,255,125,175,125,0,0,0, - 0,0,0,0,0,0,0,0,0,0,89,255,255,251,89,0,89,255,255,225,21,0,0,0,175,225, - 29,206,166,0,0,0,138,166,59,215,21,59,215,81,215,21,0,0,0,138,166,59,215, - 21,0,0,0,89,225,21,59,245,255,255,125,138,166,7,202,97,199,34,0,0,89,251, - 89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225,21,59,241, - 89,138,125,0,0,0,89,247,34,0,0,0,0,175,255,255,255,225,21,0,0,0,12,232, - 89,0,0,0,12,228,34,0,12,235,225,21,59,215,21,0,0,0,0,0,0,0,0,12,206,21, - 59,241,89,0,134,89,0,172,89,0,0,0,0,0,0,0,0,7,206,201,12,235,125,0,0,0, - 0,0,0,0,0,175,125,0,0,0,0,0,12,206,21,7,202,89,7,206,125,0,172,89,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,59,238,34,0,0,175,166,0,0,0,0,175,125,175,125,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,166,59,245,125,0,0,0,0,0,0, - 175,125,12,228,34,59,215,21,0,0,0,0,0,175,125,0,0,0,12,232,89,0,0,0,0,0, - 59,238,34,175,125,7,199,34,0,0,175,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,0,0,0,0,138,225,21,7,206,201,138,125,138,125,7,202,89,0,0,0, - 0,138,201,0,0,0,138,166,0,0,0,12,232,89,0,0,0,12,228,34,0,0,0,175,255,255, - 166,0,0,0,0,0,0,0,0,0,0,138,166,0,89,255,255,247,34,89,201,0,0,0,0,0,0, - 0,0,0,0,0,168,34,7,151,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,0,138,166,7,202, - 89,0,89,247,124,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,255,255,255, - 255,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,125,0,7,206, - 166,0,0,0,0,175,125,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,59,115,0,134,89,0,0,0,0,0,0,59,215,21,59,245,255,255,255,225,21,0, - 0,0,59,215,21,0,0,59,238,34,0,0,0,0,0,0,175,125,7,206,255,255,255,251,89, - 0,138,247,34,0,59,157,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,225, - 21,0,7,206,255,255,251,89,138,255,255,255,255,255,166,0,0,0,0,0,0,0,0,0, - 0,12,232,89,0,0,0,12,228,34,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,175, - 225,21,0,0,0,175,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,175,225,21,0,0,0,175,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,238,198, - 255,251,194,166,0,0,0,0,175,125,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,125,0,0,0,0,89,225,21,0,0,0, - 7,206,125,0,0,12,235,255,255,255,166,0,0,0,89,225,21,0,0,0,12,228,34,0, - 0,0,175,255,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0, - 0,0,0,0,138,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,228, - 34,0,7,176,21,0,89,247,34,0,0,0,0,0,0,0,0,0,0,0,89,255,255,255,255,125, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89, - 255,255,255,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,238,34,0,0,0,0,0,0,0,0,175, - 125,175,125,0,0,0,0,0,0,0,0,59,215,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,0,0,0,0,0,0,138,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 12,228,34,0,7,206,255,255,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,238,34,0,0,0,0,0,0,0,0,175,125,175,125, - 0,0,0,0,0,0,59,245,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,0,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,89, - 255,125,0,0,0,0,0,0,12,235,201,0,0,0,0,12,235,251,89,0,0,0,0,175,255,125, - 89,201,0,0,0,0,0,0,0,0,0,0,0,59,245,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,89,255,125,0,0,0,0,0,0,138,251,89,0,0,0,12,235,251, - 89,0,0,0,0,0,0,0,0,7,206,225,21,0,0,0,89,255,125,0,89,255,225,21,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,247,34,172,89,0,0,0,0,7,206,225,21,0,0, - 0,0,0,0,0,89,255,125,0,0,0,0,0,0,89,255,225,21,0,0,0,0,12,235,247,34,172, - 89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89, - 255,125,0,0,0,0,0,0,0,7,206,225,21,0,0,0,0,89,255,225,21,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,89,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 0,89,247,34,0,0,0,0,0,175,166,0,0,0,0,7,206,125,59,241,89,0,0,89,201,12, - 235,247,34,0,0,7,206,166,59,241,89,0,0,12,228,34,59,215,21,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,238,34,0,0,0,0,89,247,34,0,0,0,7, - 206,125,59,241,89,0,7,206,166,59,238,34,0,0,175,166,0,0,59,241,89,0,89, - 247,34,138,201,59,238,34,138,201,0,0,0,0,0,0,0,0,0,0,0,175,125,89,255,201, - 0,0,0,0,0,0,0,175,201,0,0,0,0,0,0,12,232,89,0,0,0,0,0,0,59,238,34,138,225, - 21,0,0,0,175,125,89,255,201,0,0,0,0,59,238,34,138,201,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,0,0,0,0,138,201,0,0,0,0, - 0,59,238,34,138,225,21,0,0,0,59,238,34,138,201,0,0,0,0,12,232,89,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,228,34,59,215,21,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,255,125,0, - 0,0,0,127,0,0,12,235,225,21,0,0,0,0,12,235,225,21,0,0,0,0,12,235,225,21, - 0,0,0,0,12,235,225,21,0,0,0,0,12,235,225,21,0,0,0,0,12,235,225,21,0,0,0, - 0,0,175,255,255,255,255,255,255,255,166,0,0,138,255,255,255,251,89,59,245, - 255,255,255,255,127,81,245,255,255,255,255,225,21,59,245,255,255,255,255, - 127,81,245,255,255,255,255,127,111,255,255,255,125,89,255,255,255,125,89, - 255,255,255,125,89,255,255,255,125,7,206,255,255,255,255,125,0,0,59,245, - 247,34,0,0,59,241,89,0,0,0,138,255,255,255,166,0,0,0,0,138,255,255,255, - 166,0,0,0,0,0,138,255,255,255,166,0,0,0,0,138,255,255,255,166,0,0,0,0,138, - 255,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,255,255,210,235,166, - 59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59, - 241,89,59,241,89,0,0,0,59,241,132,245,125,0,0,0,89,251,89,12,232,89,0,0, - 0,0,7,206,166,0,89,251,89,0,0,0,127,0,0,89,232,241,89,0,0,0,0,89,232,241, - 89,0,0,0,0,89,232,241,89,0,0,0,0,89,232,241,89,0,0,0,0,89,232,241,89,0, - 0,0,0,89,232,241,89,0,0,0,0,12,232,89,89,225,21,0,0,0,0,0,175,247,34,0, - 0,59,192,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,0,0,59,241, - 89,0,0,0,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89,0,7,206, - 166,0,0,59,245,201,0,59,245,255,201,0,0,59,241,89,0,0,138,251,89,0,12,235, - 166,0,0,138,251,89,0,12,235,166,0,0,0,138,251,89,0,12,235,166,0,0,138,251, - 89,0,12,235,166,0,0,138,251,89,0,12,235,166,0,0,0,138,166,0,0,0,12,228, - 34,0,0,175,247,34,0,0,175,225,21,59,241,89,0,0,0,59,241,89,59,241,89,0, - 0,0,59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,89,247, - 34,0,7,206,125,0,12,232,89,0,0,0,0,59,241,89,0,12,232,89,0,0,0,127,0,7, - 206,166,175,166,0,0,0,7,206,166,175,166,0,0,0,7,206,166,175,166,0,0,0,7, - 206,166,175,166,0,0,0,7,206,166,175,166,0,0,0,0,175,166,175,166,0,0,0,0, - 138,225,21,89,225,21,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,0,0,59,241, - 89,0,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,59,241, - 89,0,0,59,241,89,0,0,59,241,89,0,7,206,166,0,0,0,59,245,125,59,241,132, - 241,89,0,59,241,89,0,12,235,166,0,0,0,89,247,34,12,235,166,0,0,0,89,247, - 34,0,12,235,166,0,0,0,89,247,34,12,235,166,0,0,0,89,247,34,12,235,166,0, - 0,0,89,247,34,0,0,12,235,125,0,12,235,125,0,0,59,241,89,0,0,138,176,235, - 166,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0, - 59,241,89,59,241,89,0,0,0,59,241,89,0,175,201,0,138,225,21,0,12,235,255, - 255,255,225,21,59,238,34,0,138,225,21,0,0,0,127,0,59,238,34,89,247,34,0, - 0,59,238,34,89,247,34,0,0,59,238,34,89,247,34,0,0,59,238,34,89,247,34,0, - 0,59,238,34,89,247,34,0,0,59,241,89,89,225,21,0,0,7,206,125,0,89,225,21, - 0,0,0,0,138,225,21,0,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,59,241, - 89,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89,0, - 0,59,241,89,0,7,206,166,0,0,0,7,206,166,59,241,89,138,225,21,59,241,89, - 0,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,0,59,241,89,0,0,0, - 59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,0,0,0,12, - 235,138,235,125,0,0,0,138,225,21,0,59,215,21,175,201,59,241,89,0,0,0,59, - 241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0, - 0,0,59,241,89,0,59,245,166,241,89,0,0,12,232,89,0,0,175,225,59,238,47,235, - 225,21,0,0,0,0,127,0,138,201,0,12,235,125,0,0,138,201,0,12,235,125,0,0, - 138,201,0,12,235,125,0,0,138,201,0,12,235,125,0,0,138,201,0,12,235,125, - 0,0,138,225,21,12,235,125,0,0,89,247,34,0,89,255,255,255,255,251,89,138, - 225,21,0,0,0,0,0,59,245,255,255,255,255,127,59,245,255,255,255,255,166, - 0,59,245,255,255,255,255,127,59,245,255,255,255,255,127,0,59,241,89,0,0, - 59,241,89,0,0,59,241,89,0,0,59,241,89,7,206,255,255,255,166,0,0,175,201, - 59,241,89,12,235,125,59,241,89,0,59,241,89,0,0,0,12,235,125,59,241,89,0, - 0,0,12,235,125,0,59,241,89,0,0,0,12,235,125,59,241,89,0,0,0,12,235,125, - 59,241,89,0,0,0,12,235,125,0,0,0,0,12,235,125,0,0,0,0,138,225,21,7,199, - 34,0,138,225,81,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,59,241, - 89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,0,0,138,255,166,0,0,0,12,232, - 89,0,0,89,247,59,238,34,0,59,245,125,0,0,0,127,7,206,125,0,0,175,201,0, - 7,206,125,0,0,175,201,0,7,206,125,0,0,175,201,0,7,206,125,0,0,175,201,0, - 7,206,125,0,0,175,201,0,7,206,125,0,0,175,201,0,7,206,255,255,255,255,225, - 21,0,0,0,0,138,225,21,0,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,59, - 241,89,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89, - 0,0,59,241,89,0,7,206,166,0,0,0,7,206,166,59,241,89,0,89,247,94,241,89, - 0,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,0,59,241,89,0,0,0, - 59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,0,0,0,12, - 235,138,235,125,0,0,0,138,225,21,175,125,0,0,175,201,59,241,89,0,0,0,59, - 241,89,59,241,89,0,0,0,59,241,89,59,241,89,0,0,0,59,241,89,59,241,89,0, - 0,0,59,241,89,0,0,59,241,89,0,0,0,12,232,89,0,7,206,201,59,238,34,0,0,138, - 201,0,0,0,127,59,245,255,255,255,255,247,34,59,245,255,255,255,255,247, - 34,59,245,255,255,255,255,247,34,59,245,255,255,255,255,247,34,59,245,255, - 255,255,255,247,34,59,245,255,255,255,255,247,34,59,241,89,0,0,89,225,21, - 0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,59,241, - 89,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89,0, - 0,59,241,89,0,7,206,166,0,0,0,59,241,89,59,241,89,0,7,206,200,241,89,0, - 12,235,166,0,0,0,89,247,34,12,235,166,0,0,0,89,247,34,0,12,235,166,0,0, - 0,89,247,34,12,235,166,0,0,0,89,247,34,12,235,166,0,0,0,89,247,34,0,0,12, - 235,125,0,12,235,125,0,0,59,241,159,166,0,0,12,235,166,12,232,89,0,0,0, - 59,238,34,12,232,89,0,0,0,59,238,34,12,232,89,0,0,0,59,238,34,12,232,89, - 0,0,0,59,238,34,0,0,59,241,89,0,0,0,12,235,255,255,255,201,0,59,238,34, - 0,0,138,201,0,0,0,127,138,201,0,0,0,12,235,125,138,201,0,0,0,12,235,125, - 138,201,0,0,0,12,235,125,138,201,0,0,0,12,235,125,138,201,0,0,0,12,235, - 125,138,201,0,0,0,12,235,125,175,201,0,0,0,89,225,21,0,0,0,0,0,175,247, - 34,0,0,59,192,59,241,89,0,0,0,0,59,241,89,0,0,0,0,0,59,241,89,0,0,0,0,59, - 241,89,0,0,0,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89,0,0,59,241,89,0, - 7,206,166,0,0,59,245,201,0,59,241,89,0,0,59,245,251,89,0,0,138,251,89,0, - 59,245,166,0,0,138,251,89,0,59,245,166,0,0,0,138,251,89,0,59,245,166,0, - 0,138,251,89,0,59,245,166,0,0,138,251,89,0,59,245,166,0,0,0,138,166,0,0, - 0,12,228,34,0,0,175,247,34,0,7,206,225,21,0,138,225,21,0,7,206,166,0,0, - 138,225,21,0,7,206,166,0,0,138,225,21,0,7,206,166,0,0,138,225,21,0,7,206, - 166,0,0,0,59,241,89,0,0,0,12,232,89,0,0,0,0,59,238,34,0,12,235,125,0,0, - 0,127,206,125,0,0,0,0,175,206,206,125,0,0,0,0,175,206,206,125,0,0,0,0,175, - 206,206,125,0,0,0,0,175,206,206,125,0,0,0,0,175,206,206,125,0,0,0,0,175, - 232,245,125,0,0,0,89,255,255,255,255,255,166,0,0,138,255,255,255,251,89, - 59,245,255,255,255,255,127,81,245,255,255,255,255,225,21,59,245,255,255, - 255,255,127,81,245,255,255,255,255,127,111,255,255,255,125,89,255,255,255, - 125,89,255,255,255,125,89,255,255,255,125,7,206,255,255,255,255,125,0,0, - 59,241,89,0,0,0,175,251,89,0,0,0,138,255,255,255,166,0,0,0,0,138,255,255, - 255,166,0,0,0,0,0,138,255,255,255,166,0,0,0,0,138,255,255,255,166,0,0,0, - 0,138,255,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,194,255,255,255,201, - 0,0,0,0,59,245,255,251,89,0,0,0,0,59,245,255,251,89,0,0,0,0,59,245,255, - 251,89,0,0,0,0,59,245,255,251,89,0,0,0,0,59,241,89,0,0,0,12,232,89,0,0, - 0,0,59,238,47,235,255,166,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138, - 166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,166,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127, - 127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,0, - 0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,201,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,7,206, - 225,21,0,0,0,0,0,12,235,201,0,0,0,138,255,201,0,0,0,59,245,225,29,202,89, - 0,0,0,0,0,0,0,0,138,166,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 7,206,225,21,0,0,0,0,0,12,235,201,0,0,0,89,255,225,21,0,0,0,0,0,0,0,0,175, - 247,34,0,12,235,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,59,245,225,29,202,89, - 0,0,138,251,89,0,0,0,0,0,7,206,225,21,0,0,0,89,255,225,21,0,0,59,245,225, - 29,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,225, - 21,0,0,0,0,0,89,255,125,0,0,0,89,255,225,21,0,0,0,0,0,0,0,0,0,0,0,0,138, - 251,89,0,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,175, - 166,0,0,0,0,7,206,166,0,0,0,89,225,21,175,201,0,7,202,89,138,255,166,0, - 0,89,247,34,175,166,0,0,138,166,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,7,206,166,0,0,0,0,0,175,166,0,0,0,89,247,34,138,201,0,0,89,247, - 34,175,201,0,0,138,201,0,175,200,215,34,235,247,47,232,0,138,255,225,111, - 225,21,0,0,172,89,138,255,166,0,0,0,0,89,225,21,0,0,0,0,175,201,0,0,0,0, - 89,247,34,138,201,0,0,172,89,138,255,166,0,0,59,238,34,138,201,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,166,0,0,0,0,59,241,89,0,0,0,89, - 247,34,138,201,0,0,0,59,238,34,138,201,0,0,0,89,247,34,0,0,59,238,34,0, - 0,0,0,0,138,225,29,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,201,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,225,21,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,12,235,166,0,0,0,0,0,0,0,0,89,166,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,238,34,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,7,206,255,255,255,125,0,7,206,255,255,255, - 125,0,7,206,255,255,255,125,0,7,206,255,255,255,125,0,7,206,255,255,255, - 125,0,12,235,255,255,251,89,0,12,235,255,255,251,89,59,245,255,166,0,0, - 59,245,255,255,201,0,12,235,255,251,89,0,0,12,235,255,251,89,0,0,12,235, - 255,251,89,0,0,12,235,255,251,89,0,59,238,34,59,238,34,59,238,34,59,238, - 34,0,59,241,89,175,225,21,0,59,241,194,255,255,125,0,0,12,235,255,247,34, - 0,0,12,235,255,247,34,0,0,0,12,235,255,247,34,0,0,12,235,255,247,34,0,0, - 12,235,255,247,34,0,0,0,0,0,12,235,166,0,0,0,0,7,206,255,255,225,21,0,59, - 241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,59,241, - 89,0,59,241,97,206,166,0,0,12,235,125,59,238,163,255,255,201,7,206,166, - 0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,89,247,34,0,0,0,0,89,247, - 34,0,0,0,0,89,247,34,0,0,0,0,89,247,34,0,0,0,0,89,247,34,0,0,0,0,138,225, - 21,0,0,0,0,89,255,225,21,0,138,201,59,245,125,0,0,0,7,206,125,0,89,225, - 21,7,206,125,0,89,225,21,7,206,125,0,89,225,21,7,206,125,0,89,225,21,59, - 238,34,59,238,34,59,238,34,59,238,34,0,0,0,0,12,235,125,0,59,245,166,0, - 89,247,34,7,206,166,0,138,225,21,7,206,166,0,138,225,21,0,7,206,166,0,138, - 225,21,7,206,166,0,138,225,21,7,206,166,0,138,225,21,0,0,0,0,0,0,0,0,0, - 0,12,232,89,0,138,251,89,0,59,241,89,0,59,241,89,59,241,89,0,59,241,89, - 59,241,89,0,59,241,89,0,59,241,89,0,59,241,89,89,247,34,0,89,247,34,59, - 245,166,0,7,206,166,89,247,34,0,89,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 59,241,89,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0,59,241,89,0,0,0,0, - 59,241,89,0,0,0,0,59,238,34,0,0,0,0,12,232,89,0,0,59,238,127,225,21,0,0, - 0,59,238,34,0,59,238,34,59,238,34,0,59,238,34,59,238,34,0,59,238,34,59, - 238,34,0,59,238,34,59,238,34,59,238,34,59,238,34,59,238,34,0,138,255,255, - 255,255,201,0,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59, - 241,89,0,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241, - 89,0,12,235,255,255,255,255,255,255,166,138,201,0,59,157,175,201,0,59,241, - 89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,59,241,89, - 0,59,241,89,12,235,125,0,175,166,0,59,238,34,0,0,138,225,34,235,125,0,175, - 166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,127,0,89,255,255,255,251,89,0,89,255,255,255,251, - 89,0,89,255,255,255,251,89,0,89,255,255,255,251,89,0,89,255,255,255,251, - 89,0,138,255,255,255,247,34,0,175,255,255,255,255,255,255,255,255,251,127, - 201,0,0,0,0,59,245,255,255,255,251,89,59,245,255,255,255,251,89,59,245, - 255,255,255,251,89,59,245,255,255,255,251,89,59,238,34,59,238,34,59,238, - 34,59,238,34,138,247,34,0,0,138,201,0,59,241,89,0,59,241,89,59,238,34,0, - 12,232,89,59,238,34,0,12,232,89,0,59,238,34,0,12,232,89,59,238,34,0,12, - 232,89,59,238,34,0,12,232,89,0,0,0,0,0,0,0,0,0,0,175,201,7,176,21,138,201, - 0,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,59, - 241,89,0,59,241,89,0,175,201,12,232,89,0,59,238,34,0,0,138,225,21,175,201, - 12,232,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,59,241,89,0,59,241,89,59,241,89,0,59, - 241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89, - 138,247,34,0,59,238,34,138,225,21,0,12,232,89,0,0,0,0,138,201,0,0,0,0,59, - 238,34,0,0,0,0,59,238,34,0,0,0,0,59,238,34,0,0,0,0,59,238,34,0,0,0,0,59, - 238,34,59,238,34,59,238,34,59,238,34,175,201,0,0,0,138,166,0,59,241,89, - 0,59,241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,59,241,89,0,59, - 241,89,59,241,89,0,59,241,89,59,241,89,0,59,241,89,0,0,0,0,12,235,166,0, - 0,0,138,201,134,89,0,175,166,0,59,241,89,0,59,241,89,59,241,89,0,59,241, - 89,59,241,89,0,59,241,89,0,59,241,89,0,59,241,89,0,89,247,124,225,21,0, - 59,238,34,0,0,138,201,0,89,247,124,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,89,247, - 34,0,89,251,89,89,247,34,0,89,251,89,89,247,34,0,89,251,89,89,247,34,0, - 89,251,89,89,247,34,0,89,251,89,175,201,0,0,175,247,34,175,201,0,0,59,245, - 225,21,0,7,199,94,245,125,0,0,0,7,206,166,0,7,199,34,7,206,166,0,7,199, - 34,7,206,166,0,7,199,34,7,206,166,0,7,199,34,59,238,34,59,238,34,59,238, - 34,59,238,34,138,247,34,0,12,232,89,0,59,241,89,0,59,241,89,7,206,166,0, - 138,225,21,7,206,166,0,138,225,21,0,7,206,166,0,138,225,21,7,206,166,0, - 138,225,21,7,206,166,0,138,225,21,0,0,0,0,12,235,166,0,0,0,59,245,166,0, - 59,241,89,0,12,235,125,0,175,251,89,12,235,125,0,175,251,89,12,235,125, - 0,175,251,89,0,12,235,125,0,175,251,89,0,7,206,255,125,0,0,59,238,34,0, - 12,235,125,0,7,206,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,175,255,255,232, - 241,89,0,175,255,255,232,241,89,0,175,255,255,232,241,89,0,175,255,255, - 232,241,89,0,175,255,255,232,241,89,12,235,255,255,166,238,34,12,235,255, - 255,225,21,89,255,255,251,89,0,89,255,255,255,201,0,12,235,255,251,89,0, - 0,12,235,255,251,89,0,0,12,235,255,251,89,0,0,12,235,255,251,89,0,59,238, - 34,59,238,34,59,238,34,59,238,34,0,138,255,255,255,125,0,0,59,241,89,0, - 59,241,89,0,12,235,255,247,34,0,0,12,235,255,247,34,0,0,0,12,235,255,247, - 34,0,0,12,235,255,247,34,0,0,12,235,255,247,34,0,0,0,0,0,0,0,0,0,0,0,7, - 206,255,255,225,21,0,0,0,89,255,255,166,241,89,0,89,255,255,166,241,89, - 0,89,255,255,166,241,89,0,0,89,255,255,166,241,89,0,0,138,247,34,0,0,59, - 245,166,255,255,166,0,0,0,138,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,215,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,0,59,238,34,0,0,0,0,0, - 12,232,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,12,235,255,125,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,138,225,21,0,0,0,59,238,34,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,0,127,127,0,127,127, - 0,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 -}; - - -// Large font anti-aliased -const int FONT2AA_BM_W = 276; -const int FONT2AA_BM_H = 120; -static const unsigned char s_Font2AA[] = -{ - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, - 4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0,0,0,0,0,0,0,0, - 0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,59,245,125,175,225,21, - 0,0,0,0,0,0,0,0,0,0,0,0,0,138,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,59,241,89,0,0,12,235,201,89,255,166,0,0,0,0,0,172,89,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,225,21,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0, - 0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,138,247,34,0,12, - 232,89,138,225,21,0,0,0,0,138,125,7,199,34,0,0,0,0,138,125,0,0,0,0,138, - 255,255,201,0,0,0,59,215,21,0,0,0,0,59,245,255,255,166,0,0,0,59,241,89, - 0,7,206,201,0,0,89,251,89,0,59,215,21,172,89,59,192,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,166,0,0,138,255,251,89,0,0,0,0,0, - 138,201,0,0,0,7,206,255,255,255,166,0,0,7,206,255,255,255,201,0,0,0,0,0, - 0,138,251,89,0,0,175,255,255,255,255,225,21,0,0,12,235,255,255,125,89,255, - 255,255,255,255,251,89,0,12,235,255,255,225,21,0,0,59,245,255,255,166,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,59,245,255,255,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, - 4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,89,247, - 34,0,12,232,89,138,201,0,0,0,0,7,202,89,59,215,21,0,0,12,235,255,255,255, - 166,0,59,241,89,12,235,125,0,0,172,89,0,0,0,0,7,206,166,0,89,251,89,0,0, - 12,228,34,0,89,247,34,0,0,0,175,201,0,0,89,251,191,194,247,34,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,175,201,0,12,235, - 125,0,0,138,255,255,201,0,0,0,12,182,0,0,59,245,125,0,12,206,21,0,12,235, - 166,0,0,0,0,89,255,251,89,0,0,175,201,0,0,0,0,0,0,89,255,125,0,0,0,0,0, - 0,0,0,89,251,89,12,235,166,0,7,206,201,0,59,245,125,0,12,235,166,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,89,166,0,0,138,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0, - 0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,12, - 228,34,89,201,0,0,0,0,12,206,21,89,166,0,0,12,235,125,138,125,59,192,0, - 89,247,34,7,206,166,0,89,201,0,0,0,0,0,12,235,125,0,12,232,89,0,0,12,228, - 34,0,175,201,0,0,0,0,59,241,89,0,0,7,206,166,0,0,0,0,0,0,0,138,166,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,225,21,59,241,89,0,0,138,225,21,0, - 0,0,175,201,0,0,0,0,0,0,0,7,206,201,0,0,0,0,0,0,175,201,0,0,0,59,241,132, - 241,89,0,0,175,201,0,0,0,0,0,7,206,166,0,0,0,0,0,0,0,0,7,206,201,0,59,241, - 89,0,0,138,225,21,138,225,21,0,0,138,225,21,89,255,125,0,0,89,255,125,0, - 0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,138,201,0,0,0,0,0,0,0,0, - 0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0,0,0,0,0, - 0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,0,0,0,0,0,0, - 0,89,255,255,255,255,255,255,255,125,59,238,34,138,125,0,0,0,89,247,34, - 7,206,166,7,202,89,0,0,0,0,0,0,175,225,21,138,225,21,0,0,0,0,0,12,235,125, - 0,0,0,0,7,206,125,0,89,251,191,194,247,34,0,0,0,0,0,138,166,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0,89,247,34,0,0,89,247,34,0,0,0,175,201, - 0,0,0,0,0,0,0,12,235,166,0,0,0,0,0,59,245,125,0,0,12,235,125,59,241,89, - 0,0,175,201,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,89,247,34,0,12,235,201, - 0,0,175,201,0,138,225,21,0,0,89,247,34,89,255,125,0,0,89,255,125,0,0,0, - 0,0,12,235,255,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,175,255,251,89,0,0,0,0, - 0,0,0,0,138,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0,0,0, - 0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,0,0,0,0, - 0,0,0,0,0,175,125,7,199,34,0,0,12,235,166,138,125,0,0,0,59,241,89,12,235, - 125,89,201,12,235,255,251,89,0,0,7,206,255,166,0,59,241,89,0,0,0,59,238, - 34,0,0,0,0,0,175,166,59,215,21,172,89,59,192,0,0,0,0,0,138,166,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,125,0,138,247,34,0,0,89,247,34,0,0,0, - 175,201,0,0,0,0,0,0,0,89,251,89,0,0,0,89,255,247,34,0,0,7,206,166,0,59, - 241,89,0,0,175,255,255,255,225,21,0,89,251,226,255,255,247,34,0,0,0,7,206, - 166,0,0,0,12,235,255,255,201,0,0,89,255,125,0,0,138,247,34,0,0,0,0,0,0, - 0,0,0,0,0,89,255,255,166,0,0,0,0,0,175,255,255,255,255,255,255,225,21,0, - 0,0,0,59,245,255,201,0,0,0,0,0,175,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0, - 0,0,89,225,21,0,0,0,0,0,0,0,0,0,7,199,34,59,215,21,0,0,0,59,245,255,255, - 201,0,0,0,138,255,255,201,12,228,34,175,166,0,138,201,0,12,235,125,89,255, - 125,59,241,89,0,0,0,59,238,34,0,0,0,0,0,138,201,0,0,0,172,89,0,0,0,7,206, - 255,255,255,255,255,255,247,34,0,0,0,0,89,255,255,255,166,0,0,0,0,0,59, - 238,34,0,138,247,34,0,0,89,247,34,0,0,0,175,201,0,0,0,0,0,0,59,245,166, - 0,0,0,0,0,0,12,235,166,0,138,201,0,0,59,241,89,0,0,0,0,0,12,235,201,0,138, - 251,89,0,0,175,225,21,0,0,89,247,34,0,0,7,206,166,0,175,255,166,0,0,89, - 255,255,255,223,247,34,0,0,0,0,0,0,0,0,0,0,175,247,34,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,225,21,0,0,175,225,21,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0, - 0,0,127,0,0,0,0,0,59,215,21,0,0,0,0,0,0,0,12,235,255,255,255,255,255,255, - 166,0,0,0,0,138,125,175,225,21,0,0,0,0,0,138,166,7,206,125,0,89,247,34, - 138,225,21,0,89,255,166,215,21,0,0,0,59,238,34,0,0,0,0,0,138,201,0,0,0, - 0,0,0,0,0,0,0,0,0,138,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,201,0, - 0,89,247,34,0,0,89,247,34,0,0,0,175,201,0,0,0,0,0,12,235,201,0,0,0,0,0, - 0,0,0,138,225,21,175,255,255,255,255,255,255,125,0,0,0,0,0,138,247,34,89, - 247,34,0,0,59,241,89,0,7,206,166,0,0,0,138,247,34,0,0,138,247,34,0,0,0, - 0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,89,255,255,166,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,59,245,255,201,0,0,0,0,175,201,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0, - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,166,0,175,125,0,0,0,0,0,0,138, - 125,89,247,34,0,0,0,0,12,228,34,7,206,125,0,89,247,34,138,247,34,0,0,89, - 255,166,0,0,0,0,59,238,34,0,0,0,0,0,175,166,0,0,0,0,0,0,0,0,0,0,0,0,138, - 166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,125,0,0,59,241,89,0,0,138,225, - 21,0,0,0,175,201,0,0,0,0,12,235,201,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0, - 0,59,241,89,0,0,0,0,0,0,138,225,21,59,241,89,0,0,59,241,89,0,89,247,34, - 0,0,0,138,247,34,0,0,89,251,89,0,0,0,0,7,206,166,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,12,235,255,225,21,0,0,175,255,255,255,255,255,255,225,21,0,0,175, - 255,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,89,247, - 34,0,0,0,0,0,0,0,0,0,175,125,7,199,34,0,0,0,89,201,0,138,125,175,201,0, - 0,0,0,0,138,166,0,0,175,166,0,138,201,0,89,255,166,0,0,89,255,255,125,0, - 0,0,12,235,125,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0,0,0, - 0,0,138,255,125,0,0,0,0,0,0,175,247,34,59,238,34,0,0,0,175,201,0,12,235, - 125,0,0,0,0,175,201,0,0,0,12,235,166,0,0,0,0,0,89,166,0,0,59,245,166,0, - 0,0,0,0,59,241,89,0,59,215,21,0,12,235,166,0,7,206,201,0,0,175,225,21,7, - 206,166,0,0,0,0,59,245,166,0,7,206,225,21,0,0,0,0,175,225,21,0,89,255,125, - 0,0,12,235,201,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,138,201, - 0,0,0,0,0,0,0,0,0,175,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0,0,0,89,247, - 34,0,0,0,0,0,0,0,0,7,199,34,59,215,21,0,0,0,12,235,255,255,255,201,0,0, - 0,0,0,59,215,21,0,0,12,235,255,251,89,0,0,89,255,255,255,201,0,89,255,0, - 0,0,0,175,201,0,0,0,0,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175, - 201,0,0,0,0,0,0,0,175,247,34,138,201,0,0,0,0,0,138,255,251,89,0,0,0,138, - 255,255,255,255,166,0,89,255,255,255,255,255,247,34,12,235,255,255,255, - 166,0,0,0,0,0,0,59,241,89,0,12,235,255,255,255,166,0,0,0,7,206,255,255, - 225,21,0,138,247,34,0,0,0,0,0,59,245,255,255,201,0,0,0,175,255,255,201, - 0,0,0,89,255,125,0,0,89,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,175,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,4,4,4,4,4,4,4,4,52,4,4,4,4,4,4,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,125,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,0,175,201,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,0,0,0,0,0,0,0,0,175,125, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,125,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,201,0,0,89,251,89,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,201,0,0,0,0,0,0,0,0,0,0,12,232,89, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,0,4,4,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,201,0,0,201,201,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4, - 4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,0,0,0,0,0,0,127,127,127,0,127,127,127, - 127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,0,127,127,127,127,0,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 127,0,127,127,127,0,127,127,127,127,0,127,127,127,0,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, - 4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255, - 201,0,138,201,0,0,0,0,89,255,255,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,0,0,0,0,175,255,255,255,247,34,0,0,0,0,0,7,206,251,89,0,0,12,0, - 235,255,255,255,255,201,0,0,0,0,59,245,255,255,255,201,12,0,235,255,255, - 255,255,166,0,0,0,12,235,255,255,255,255,255,127,12,235,255,255,255,255, - 251,89,0,0,12,235,255,255,255,251,89,12,235,166,0,0,0,12,235,125,89,255, - 255,255,201,0,0,175,255,255,225,21,12,235,166,0,0,7,206,251,102,0,235,166, - 0,0,0,0,12,235,251,89,0,0,0,89,255,225,21,12,235,251,89,0,0,12,235,125, - 0,0,0,138,255,255,166,0,0,0,12,235,255,255,255,251,89,0,0,0,0,175,255,255, - 201,0,0,0,12,235,255,255,255,251,89,0,0,0,12,235,255,255,255,247,47,235, - 255,255,255,255,255,255,255,138,0,235,125,0,0,0,59,245,133,206,166,0,0, - 0,0,59,245,255,133,201,0,0,0,138,251,89,0,0,12,235,133,206,247,34,0,0,0, - 175,229,216,225,21,0,0,0,138,247,124,255,255,255,255,255,255,125,7,206, - 125,0,0,0,59,238,34,0,0,0,0,0,12,235,125,0,0,0,0,175,247,34,0,0,0,0,0,0, - 0,0,0,0,127,0,0,59,245,166,0,0,0,59,245,166,0,0,0,0,59,245,255,166,0,0, - 12,0,235,166,0,0,59,245,125,0,0,138,255,125,0,0,7,202,102,0,235,166,0,0, - 59,245,225,21,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,0,89,255,166, - 0,0,0,89,127,12,235,166,0,0,0,12,235,125,0,12,235,125,0,0,0,0,0,138,225, - 21,12,235,166,0,7,206,225,21,12,0,235,166,0,0,0,0,12,235,255,166,0,0,7, - 206,255,225,21,12,235,255,201,0,0,12,235,125,0,59,245,166,0,0,138,251,89, - 0,12,235,166,0,0,138,251,89,0,89,255,125,0,0,89,255,125,0,12,235,166,0, - 0,138,251,89,0,12,235,166,0,0,7,202,89,0,0,0,138,225,21,0,0,12,0,235,125, - 0,0,0,59,245,125,138,225,21,0,0,0,138,225,151,34,247,34,0,0,175,255,125, - 0,0,89,247,34,12,235,166,0,0,89,247,34,59,245,125,0,0,59,245,125,0,0,0, - 0,0,138,247,34,7,206,125,0,0,0,7,206,125,0,0,0,0,0,12,235,125,0,0,0,138, - 225,187,201,0,0,0,0,0,0,0,0,0,0,127,0,12,232,89,0,0,0,0,0,12,232,89,0,0, - 0,138,225,151,225,21,0,12,0,235,166,0,0,12,235,166,0,12,235,166,0,0,0,0, - 0,12,0,235,166,0,0,0,12,235,166,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0, - 0,0,12,235,166,0,0,0,0,0,0,12,235,166,0,0,0,12,235,125,0,12,235,125,0,0, - 0,0,0,138,225,21,12,235,166,0,175,225,21,0,12,0,235,166,0,0,0,0,12,235, - 166,238,34,0,59,215,187,225,21,12,235,166,245,125,0,12,235,125,12,235,125, - 0,0,0,0,138,247,34,12,235,166,0,0,12,235,166,12,235,125,0,0,0,0,138,247, - 34,12,235,166,0,0,12,235,166,0,89,247,34,0,0,0,0,0,0,0,0,138,225,21,0,0, - 12,0,235,125,0,0,0,59,245,125,59,241,89,0,0,7,206,166,59,0,241,89,0,12, - 232,194,201,0,0,138,225,21,0,89,251,89,12,235,166,0,0,138,247,34,7,206, - 201,0,0,0,0,0,59,245,125,0,7,206,125,0,0,0,0,138,201,0,0,0,0,0,12,235,125, - 0,0,59,241,89,12,235,166,0,0,0,0,0,0,0,0,0,127,0,175,166,0,59,245,255,255, - 247,34,138,201,0,0,7,206,166,59,241,89,0,12,0,235,166,0,0,89,251,89,0,89, - 247,34,0,0,0,0,0,12,0,235,166,0,0,0,0,138,225,21,12,235,166,0,0,0,0,0,12, - 235,166,0,0,0,0,0,89,247,34,0,0,0,0,0,0,12,235,166,0,0,0,12,235,125,0,12, - 235,125,0,0,0,0,0,138,225,21,12,235,166,175,247,34,0,0,12,0,235,166,0,0, - 0,0,12,235,133,206,166,0,175,166,175,225,21,12,235,125,138,225,21,12,235, - 125,89,247,34,0,0,0,0,59,245,125,12,235,166,0,0,12,235,166,89,247,34,0, - 0,0,0,59,245,125,12,235,166,0,0,12,235,125,0,89,255,125,0,0,0,0,0,0,0,0, - 138,225,21,0,0,12,0,235,125,0,0,0,59,245,125,7,206,201,0,0,59,241,89,7, - 0,206,166,0,59,215,111,225,21,7,206,166,0,0,0,175,225,187,225,21,0,0,12, - 235,166,89,247,34,0,0,0,0,7,206,201,0,0,7,206,125,0,0,0,0,89,225,21,0,0, - 0,0,12,235,125,0,12,235,166,0,0,59,241,89,0,0,0,0,0,0,0,0,127,0,202,89, - 12,235,125,0,12,228,34,59,215,0,0,59,241,89,7,206,166,0,12,0,235,255,255, - 255,255,166,0,0,138,225,21,0,0,0,0,0,12,0,235,166,0,0,0,0,89,247,34,12, - 235,255,255,255,255,247,34,12,235,255,255,255,255,247,0,163,225,21,0,0, - 0,0,0,0,12,235,255,255,255,255,255,255,125,0,12,235,125,0,0,0,0,0,138,225, - 21,12,235,255,247,34,0,0,0,12,0,235,166,0,0,0,0,12,235,125,89,225,34,228, - 34,175,225,21,12,235,125,12,235,125,12,235,125,138,225,21,0,0,0,0,12,235, - 166,12,235,166,0,0,175,247,34,138,225,21,0,0,0,0,12,235,166,12,235,166, - 0,0,175,225,21,0,0,175,255,255,225,21,0,0,0,0,0,138,225,21,0,0,12,0,235, - 125,0,0,0,59,245,125,0,138,247,34,0,138,225,21,0,0,175,201,0,138,201,12, - 232,89,12,235,125,0,0,0,12,235,251,89,0,0,0,0,89,255,255,125,0,0,0,0,0, - 138,247,34,0,0,7,206,125,0,0,0,0,12,232,89,0,0,0,0,12,235,125,7,206,201, - 0,0,0,0,138,251,89,0,0,0,0,0,0,0,127,7,228,34,89,225,21,0,12,228,34,12, - 228,0,0,138,225,21,0,138,225,21,12,0,235,166,0,0,12,235,201,0,138,225,21, - 0,0,0,0,0,12,0,235,166,0,0,0,0,89,247,34,12,235,166,0,0,0,0,0,12,235,166, - 0,0,0,0,0,138,225,21,0,12,235,255,255,127,12,235,166,0,0,0,12,235,125,0, - 12,235,125,0,0,0,0,0,138,225,21,12,235,229,216,225,21,0,0,12,0,235,166, - 0,0,0,0,12,235,125,12,235,223,201,0,175,225,21,12,235,125,0,138,225,34, - 235,125,138,225,21,0,0,0,0,12,235,166,12,235,255,255,255,247,34,0,138,225, - 21,0,0,0,0,12,235,166,12,235,255,255,255,166,0,0,0,0,0,0,89,255,255,247, - 34,0,0,0,138,225,21,0,0,12,0,235,125,0,0,0,59,245,125,0,59,245,125,7,206, - 166,0,0,0,89,247,34,175,125,7,206,125,89,247,34,0,0,0,12,235,251,89,0,0, - 0,0,7,206,225,21,0,0,0,0,59,245,125,0,0,0,7,206,125,0,0,0,0,0,175,166,0, - 0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,12,228,34,89,225, - 21,0,12,228,34,59,215,0,7,206,255,255,255,255,251,89,12,0,235,166,0,0,0, - 138,247,0,124,247,34,0,0,0,0,0,12,0,235,166,0,0,0,0,138,225,21,12,235,166, - 0,0,0,0,0,12,235,166,0,0,0,0,0,89,247,34,0,0,0,0,175,127,12,235,166,0,0, - 0,12,235,125,0,12,235,125,0,0,0,0,0,138,225,21,12,235,166,59,245,201,0, - 0,12,0,235,166,0,0,0,0,12,235,125,0,138,251,89,0,175,225,21,12,235,125, - 0,12,235,138,235,125,89,247,34,0,0,0,0,59,245,125,12,235,166,0,0,0,0,0, - 89,247,34,0,0,0,0,59,245,125,12,235,166,0,175,247,34,0,0,0,0,0,0,0,59,245, - 166,0,0,0,138,225,21,0,0,12,0,235,125,0,0,0,59,241,89,0,7,206,201,59,241, - 89,0,0,0,59,241,102,232,89,0,138,201,138,225,21,0,0,0,175,201,175,225,21, - 0,0,0,0,175,225,21,0,0,0,7,206,201,0,0,0,0,7,206,125,0,0,0,0,0,89,225,21, - 0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,12,232,89,59,241, - 89,0,89,247,34,89,201,0,59,241,89,0,0,7,206,166,12,0,235,166,0,0,0,138, - 225,0,81,245,166,0,0,0,0,0,12,0,235,166,0,0,0,12,235,166,0,12,235,166,0, - 0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,175,127,12,235,166,0,0, - 0,12,235,125,0,12,235,125,0,0,0,0,0,138,225,21,12,235,166,0,89,255,166, - 0,12,0,235,166,0,0,0,0,12,235,125,0,12,182,0,0,175,225,21,12,235,125,0, - 0,138,232,245,125,12,235,125,0,0,0,0,138,247,34,12,235,166,0,0,0,0,0,12, - 235,125,0,0,0,0,138,247,34,12,235,166,0,7,206,225,21,0,0,0,0,0,0,12,235, - 166,0,0,0,138,225,21,0,0,12,0,235,166,0,0,0,89,251,89,0,0,138,247,163,225, - 21,0,0,0,7,206,200,215,21,0,89,225,187,166,0,0,0,89,251,89,12,235,166,0, - 0,0,0,175,225,21,0,0,0,138,247,34,0,0,0,0,7,206,125,0,0,0,0,0,12,232,89, - 0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,12,175,166,0,89, - 255,255,210,235,255,255,125,0,138,225,21,0,0,0,138,247,47,0,235,166,0,0, - 59,245,166,0,0,138,255,125,0,0,7,202,102,0,235,166,0,0,12,235,225,21,0, - 12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,0,138,255,125,0,0,0,175,127,12, - 235,166,0,0,0,12,235,125,0,12,235,125,0,0,0,0,7,206,201,0,12,235,166,0, - 0,138,255,125,12,0,235,166,0,0,0,12,0,235,125,0,0,0,0,0,175,225,21,12,235, - 125,0,0,12,235,255,125,0,89,255,125,0,0,89,251,89,0,12,235,166,0,0,0,0, - 0,0,89,255,125,0,0,89,255,125,0,12,235,166,0,0,12,235,201,0,138,166,0,0, - 0,138,251,89,0,0,0,138,225,21,0,0,0,0,138,247,34,0,7,206,225,21,0,0,12, - 235,255,166,0,0,0,0,0,175,255,201,0,0,12,235,255,125,0,0,12,235,166,0,0, - 138,251,89,0,0,0,175,225,21,0,0,89,251,89,0,0,0,0,0,7,206,125,0,0,0,0,0, - 0,175,166,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,59,241, - 89,0,0,0,0,0,0,0,0,7,206,166,0,0,0,0,59,245,138,0,235,255,255,255,255,125, - 0,0,0,0,59,245,255,255,255,201,12,0,235,255,255,255,255,166,0,0,0,12,235, - 255,255,255,255,255,127,12,235,166,0,0,0,0,0,0,0,59,245,255,255,255,225, - 21,12,235,166,0,0,0,12,235,125,89,255,255,255,210,127,235,255,255,225,21, - 0,12,235,166,0,0,0,175,255,127,0,235,255,255,255,247,47,0,235,125,0,0,0, - 0,0,175,225,21,12,235,125,0,0,0,138,255,125,0,0,0,175,255,255,201,0,0,0, - 12,235,166,0,0,0,0,0,0,0,0,175,255,255,201,0,0,0,12,235,166,0,0,0,89,255, - 225,34,235,255,255,255,247,34,0,0,0,0,138,225,21,0,0,0,0,0,138,255,255, - 255,201,0,0,0,0,0,175,251,89,0,0,0,0,0,89,255,166,0,0,7,206,247,34,0,7, - 206,225,21,0,0,7,206,225,21,0,0,175,225,21,0,0,138,255,255,255,255,255, - 255,166,7,206,125,0,0,0,0,0,0,138,201,0,0,0,12,235,125,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,127,0,0,89,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,201,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,7,206,125,0,0,0,0,0,0,59,238,34,0,0,12,235,125,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,0,0,0,7,206,255,255,255,225,21,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,251,89,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,7,206,125,0,0,0,0,0,0,7,206,125,0,0,12,235,125,0,0,0, - 0,0,0,0,0,0,0,245,255,255,255,255,255,255,127,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138, - 255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255,201,0,0,0,0,0,0,89,89,255,255, - 255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,59,245,166,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,89,247,34,0,0,0,0,0,0,0,0,0,0,12,235, - 125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,12,235, - 255,247,0,0,0,0,0,0,0,12,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125, - 0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,255,251,89,0,7,206,125,0,89,255,251,89, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4,4,4,84,84,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,7,206, - 125,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138, - 225,21,0,0,0,0,0,0,0,0,0,175,201,0,0,0,0,0,0,0,0,0,12,12,235,125,0,0,0, - 0,0,59,245,102,0,89,247,34,12,235,125,0,0,0,0,0,12,235,125,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 59,241,89,0,0,0,7,206,125,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 4,4,4,4,4,4,4,4,100,252,252,84,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12, - 235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,12,0, - 235,125,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125, - 0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235, - 125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,0,7,206,125,0,0,0,59,238, - 34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,4,4,4,4,20,236,252,164,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,0,12,235,255,255,255,166,0,12,235,166,245,255,247,34,0,0,12, - 235,255,255,247,34,0,34,235,255,255,255,225,21,0,12,235,255,255,225,29, - 0,206,255,255,255,127,0,12,235,255,255,255,225,21,12,235,138,235,255,247, - 34,0,12,235,102,175,255,247,34,12,235,125,0,59,245,201,0,12,235,125,12, - 0,235,166,245,255,225,29,206,255,251,89,0,12,235,138,235,255,247,34,0,0, - 12,235,255,255,201,0,0,12,235,166,245,255,251,89,0,0,12,235,255,255,255, - 225,21,12,235,138,235,247,127,34,138,255,255,255,206,0,206,255,255,255, - 201,59,241,89,0,0,89,247,42,206,201,0,0,0,138,225,187,201,0,0,138,225,21, - 0,59,241,187,226,247,34,0,7,206,206,206,201,0,0,0,138,225,151,255,255,255, - 255,247,0,0,89,247,34,0,0,0,7,206,125,0,0,0,59,238,34,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,4,4,4,4,4,4,4,148,252,236,20,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,12,206, - 21,0,59,245,125,12,235,247,34,0,138,225,21,12,235,166,0,0,134,102,0,235, - 166,0,0,138,225,21,12,235,125,0,0,175,201,12,0,235,125,0,0,12,235,166,0, - 0,138,225,21,12,235,247,34,0,175,201,0,12,235,102,0,89,247,34,12,235,125, - 12,235,166,0,0,12,235,125,12,0,235,225,21,12,235,251,89,0,175,201,0,12, - 235,247,34,0,175,201,0,12,235,166,0,7,206,201,0,12,235,225,21,0,175,225, - 21,12,235,166,0,0,138,225,21,12,235,247,34,0,0,89,247,34,0,12,206,34,0, - 235,125,0,0,59,241,89,0,0,89,247,34,89,247,34,0,7,206,166,138,225,21,7, - 206,251,89,0,89,225,138,34,235,201,0,138,225,21,89,247,34,0,7,206,166,0, - 0,0,7,206,166,0,0,89,225,21,0,0,0,7,206,125,0,0,0,59,241,89,0,0,0,0,138, - 251,89,0,0,7,202,89,0,0,4,4,4,4,4,4,52,252,252,108,4,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0, - 0,0,0,0,0,0,0,0,7,206,102,12,235,125,0,0,59,241,89,138,225,21,0,0,0,34, - 89,225,21,0,0,138,225,21,89,225,21,0,0,89,247,47,0,235,125,0,0,89,225,21, - 0,0,138,225,21,12,235,125,0,0,89,247,34,12,235,102,0,89,247,34,12,235,138, - 235,166,0,0,0,12,235,125,12,0,235,125,0,7,206,166,0,0,138,225,21,12,235, - 125,0,0,89,247,34,138,225,21,0,0,59,238,34,12,235,125,0,0,59,241,89,89, - 225,21,0,0,138,225,21,12,235,125,0,0,0,138,225,21,0,0,0,12,0,235,125,0, - 0,59,241,89,0,0,89,247,34,12,235,125,0,59,241,89,59,238,34,12,228,198,166, - 0,175,166,59,0,89,251,132,241,89,0,12,235,125,0,59,238,34,0,0,0,138,225, - 21,0,12,235,166,0,0,0,0,7,206,125,0,0,0,0,175,201,0,0,0,138,166,12,235, - 166,0,12,232,89,0,0,12,84,4,4,4,4,204,252,204,4,4,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0, - 0,0,0,59,245,255,255,255,102,12,235,125,0,0,12,235,125,175,201,0,0,0,0, - 0,175,201,0,0,0,138,225,21,175,255,255,255,255,255,247,47,0,235,125,0,0, - 175,201,0,0,0,138,225,21,12,235,125,0,0,89,247,34,12,235,102,0,89,247,34, - 12,235,255,225,21,0,0,0,12,235,125,12,0,235,125,0,7,206,166,0,0,138,225, - 21,12,235,125,0,0,89,247,34,175,201,0,0,0,12,232,89,12,235,125,0,0,12,235, - 125,175,201,0,0,0,138,225,21,12,235,125,0,0,0,59,245,255,247,34,0,12,0, - 235,125,0,0,59,241,89,0,0,89,247,34,0,175,201,0,138,201,0,12,235,125,89, - 201,89,225,29,206,125,12,0,0,175,255,166,0,0,0,175,201,0,138,201,0,0,0, - 89,251,89,0,138,247,34,0,0,0,0,0,7,206,125,0,0,0,0,0,89,255,125,7,202,89, - 0,89,251,89,89,201,0,0,0,172,252,84,4,4,100,252,252,60,4,4,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,0,89,255,166,0,7,206,102,12,235,125,0,0,12,235,125,175,201, - 0,0,0,0,0,175,201,0,0,0,138,225,21,175,201,0,0,0,0,0,12,0,235,125,0,0,175, - 201,0,0,0,138,225,21,12,235,125,0,0,89,247,34,12,235,102,0,89,247,34,12, - 235,138,235,201,0,0,0,12,235,125,12,0,235,125,0,7,206,166,0,0,138,225,21, - 12,235,125,0,0,89,247,34,175,201,0,0,0,12,232,89,12,235,125,0,0,12,235, - 125,175,201,0,0,0,138,225,21,12,235,125,0,0,0,0,0,138,255,255,201,12,0, - 235,125,0,0,59,241,89,0,0,89,247,34,0,89,247,42,206,125,0,0,175,166,175, - 125,12,232,102,232,89,0,0,0,175,255,201,0,0,0,89,247,47,235,125,0,0,12, - 235,166,0,0,0,12,235,125,0,0,0,0,7,206,125,0,0,0,0,138,201,0,0,12,232,89, - 0,0,59,245,225,21,0,0,0,196,252,244,60,20,236,252,156,4,4,4,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,0,175,201,0,0,7,206,102,12,235,125,0,0,59,241,89,138,225,21, - 0,0,0,34,89,225,21,0,0,138,225,21,138,247,34,0,0,0,0,12,0,235,125,0,0,138, - 225,21,0,0,138,225,21,12,235,125,0,0,89,247,34,12,235,102,0,89,247,34,12, - 235,125,59,245,125,0,0,12,235,125,12,0,235,125,0,7,206,166,0,0,138,225, - 21,12,235,125,0,0,89,247,34,138,225,21,0,0,89,247,34,12,235,125,0,0,59, - 241,89,138,225,21,0,0,138,225,21,12,235,125,0,0,0,0,0,0,0,89,247,47,0,235, - 125,0,0,59,241,89,0,0,89,247,34,0,12,235,166,238,34,0,0,138,210,228,34, - 0,175,166,215,21,0,0,89,251,159,251,89,0,0,12,235,191,247,34,0,0,175,225, - 21,0,0,0,0,138,225,21,0,0,0,7,206,125,0,0,0,12,232,89,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,20,220,252,236,180,252,244,28,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0, - 138,225,21,0,138,255,102,12,235,125,0,7,206,201,0,12,235,166,0,0,134,132, - 0,245,125,0,59,245,225,21,12,235,201,0,0,12,206,34,0,235,125,0,0,59,245, - 125,0,12,235,225,21,12,235,125,0,0,89,247,34,12,235,102,0,89,247,34,12, - 235,125,0,138,251,89,0,12,235,125,12,0,235,125,0,7,206,166,0,0,138,225, - 21,12,235,125,0,0,89,247,34,12,235,166,0,7,206,201,0,12,235,125,0,7,206, - 201,0,59,245,125,0,12,235,225,21,12,235,125,0,0,0,138,125,0,0,138,225,29, - 0,206,166,0,0,7,206,166,0,59,245,247,34,0,0,175,255,201,0,0,0,59,245,225, - 21,0,89,255,201,0,0,12,235,166,0,175,225,21,0,0,138,255,166,0,0,89,251, - 89,0,0,0,0,0,89,247,34,0,0,0,7,206,125,0,0,0,59,238,34,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,4,36,236,252,252,252,108,4,4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0, - 7,206,255,255,171,206,102,12,232,226,255,255,225,21,0,0,12,235,255,255, - 247,34,0,89,255,255,247,163,225,21,0,7,206,255,255,247,34,12,0,235,125, - 0,0,0,89,255,255,247,163,225,21,12,235,125,0,0,89,247,34,12,235,102,0,89, - 247,34,12,235,125,0,0,175,251,34,0,235,125,12,0,235,125,0,7,206,166,0,0, - 138,225,21,12,235,125,0,0,89,247,34,0,12,235,255,255,201,0,0,12,235,255, - 255,255,225,21,0,0,89,255,255,247,163,225,21,12,235,125,0,0,0,89,255,255, - 255,247,34,0,0,89,255,255,127,0,59,245,255,225,111,247,34,0,0,59,245,125, - 0,0,0,12,235,166,0,0,59,245,125,7,0,206,225,21,0,12,235,201,0,0,59,241, - 89,0,0,175,255,255,255,255,247,0,0,89,247,34,0,0,0,7,206,125,0,0,0,59,238, - 34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,60,252,252,204,4,4,4,4,4,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0, - 89,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,0,7, - 206,125,0,0,0,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,4,4,76,252,60,4,4, - 4,4,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0,12,232,89,0,0, - 0,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0, - 0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,166,0,0,0,0,0,0,0,0, - 0,0,0,12,235,125,0,0,0,7,206,125,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,76,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 12,235,255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,255,251,89,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235, - 125,0,0,0,0,0,0,0,0,0,0,138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89, - 247,34,0,0,0,0,0,0,0,0,0,0,0,0,89,255,251,89,0,7,206,125,0,89,255,247,34, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,0,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,125,0,175,166,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,206,125,0,175,166, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,225,21,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,125,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,125,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,166,0,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,166,0,138,201,0,7,206,166,12,235, - 125,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,175,125, - 0,0,0,0,0,175,171,206,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255,125,0, - 31,206,130,255,166,175,247,34,0,0,89,255,125,175,247,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,247,34,138,166,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,59,241,132,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,59,241,132,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 59,245,255,255,255,125,0,12,235,255,255,255,255,255,225,21,0,0,0,0,0,0, - 0,0,175,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0, - 0,0,175,125,0,0,0,0,89,225,21,59,238,34,0,0,138,255,255,201,0,0,0,59,215, - 21,0,0,0,0,0,0,0,0,0,12,235,255,255,255,247,34,0,0,0,0,0,0,0,12,235,255, - 255,255,255,255,255,255,255,251,89,0,12,235,255,255,255,255,255,225,21, - 0,89,255,255,255,255,255,255,125,0,12,235,255,255,255,255,255,225,21,0, - 0,12,235,255,255,255,255,255,225,21,7,206,201,0,50,206,56,255,201,12,235, - 125,0,0,138,225,29,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,7,202,89,89,255,225,21,0,89,255,255,255,225,81,245,201,0,138,251, - 89,0,0,138,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,255, - 255,255,255,225,21,0,0,0,138,255,166,7,206,225,21,0,0,0,138,247,34,0,0, - 0,0,127,0,89,255,125,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,89, - 247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,175, - 125,0,0,0,0,0,0,0,0,0,0,0,59,241,89,12,235,125,0,0,172,89,0,0,0,0,0,0,0, - 0,0,12,235,166,0,0,7,202,89,0,0,0,0,0,0,89,255,201,0,0,12,235,125,0,0,0, - 0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,138,247,34,0,12,146,0,0,0,0,0, - 144,21,0,0,12,146,0,0,0,0,0,144,21,0,89,225,21,71,157,22,191,225,21,175, - 201,0,7,206,125,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,59,196,199,47,206,184,89,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0, - 0,0,0,59,245,125,0,0,59,245,125,0,0,0,0,0,127,12,235,166,0,0,0,0,0,0,12, - 146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,175,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,12,235,255,255,255,255,127,34,235,255,255,255,255,225,21,0, - 0,0,0,0,0,0,0,89,247,34,7,206,166,0,89,201,0,0,0,0,0,0,0,0,0,0,89,247,34, - 0,0,0,0,0,0,0,0,59,115,12,235,166,0,0,0,12,235,125,0,0,0,0,0,0,12,146,0, - 0,0,0,0,144,21,0,0,0,0,0,59,245,125,0,0,12,146,0,0,0,0,0,144,21,0,0,12, - 146,0,0,0,0,0,144,21,0,7,202,89,117,104,0,29,202,89,59,215,21,59,215,21, - 138,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,175,125,0,59,192,89,223,125,172,89,0,138,255,255,255,201,12,182, - 0,0,0,0,0,175,255,255,125,0,89,255,255,247,34,0,0,12,146,0,0,0,0,0,144, - 21,0,138,255,255,255,255,247,34,138,247,34,7,206,201,0,0,0,0,0,0,127,89, - 251,89,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,7,206,166,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,175,125,0,0,0, - 0,0,0,0,0,0,0,0,89,247,34,7,206,166,7,202,89,0,0,0,0,0,0,0,0,0,0,89,255, - 125,0,0,0,0,0,0,0,89,255,125,89,247,34,0,0,0,12,235,125,0,0,0,0,0,0,12, - 146,0,0,0,0,0,144,21,0,0,0,0,7,206,201,0,0,0,12,146,0,0,0,0,0,144,21,0, - 0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245, - 255,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175, - 125,0,59,192,12,228,34,172,89,89,247,34,0,12,206,29,206,201,0,0,7,206,166, - 0,7,206,255,225,21,0,89,247,34,0,12,146,0,0,0,0,0,144,21,0,0,0,0,7,206, - 166,0,12,235,166,89,247,34,0,0,0,0,0,0,127,245,255,255,255,255,255,201, - 0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,59,245,255,255,255,127,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,175,125,0,0,0,0,0,0,0, - 0,0,0,0,59,241,89,12,235,125,89,201,12,235,255,251,89,0,89,255,255,225, - 21,0,175,255,255,225,21,0,0,0,89,251,89,0,138,225,21,0,0,0,12,235,255,255, - 255,255,225,21,0,12,146,0,0,0,0,0,144,21,0,0,0,0,138,247,34,0,0,0,12,146, - 0,0,0,0,0,144,21,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,12,235,255,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,59,192,0,0,0,172,89,138,225,21,0,0,0, - 0,7,206,225,21,138,225,21,0,0,89,251,89,0,0,12,235,125,0,12,146,0,0,0,0, - 0,144,21,0,0,0,0,138,225,21,0,0,89,255,255,125,0,0,0,0,0,0,0,127,138,225, - 21,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,59,241,89,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,12,235,255,255,255,255, - 225,21,0,0,0,0,0,0,0,0,0,138,255,255,201,12,228,34,175,166,0,138,201,7, - 206,125,7,206,166,0,0,0,89,255,255,247,34,59,241,89,0,0,138,225,21,0,0, - 0,12,235,125,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,59,245,125,0,0,0, - 0,12,146,0,0,0,0,0,144,21,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,59,245,255,255,255,207,235,255,255,255,255,255,255, - 207,235,255,255,255,255,255,255,255,255,255,255,255,225,21,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,247,34,0,0,0,0,175,166,175,201,0,0,0, - 59,245,255,255,255,255,255,125,0,12,146,0,0,0,0,0,144,21,0,0,0,89,251,89, - 0,0,0,7,206,225,21,0,0,0,0,0,0,0,127,245,255,255,255,255,255,125,0,0,12, - 146,0,0,0,0,0,144,21,0,0,0,0,0,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,138,166,7,206,125,0,89,247,94,241,89,0,138,201,0,0,0,0,0,59,245,166, - 0,89,251,89,0,89,247,34,0,0,0,12,235,125,0,0,0,0,0,0,12,146,0,0,0,0,0,144, - 21,0,0,7,206,201,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,12,146,0,0,0,0,0, - 144,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,255,255,166,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,138,255,255,201,0,7,206,225,21,175,201,0,0,0,59,241,89,0,0,0,0, - 0,0,12,146,0,0,0,0,0,144,21,0,0,12,235,166,0,0,0,0,0,175,225,21,0,0,0,0, - 0,0,0,127,89,255,125,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,89, - 247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,125,0,0,0,0,0, - 175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,228,34,7,206,125,0,89,247,94,241, - 89,0,138,201,0,0,0,0,0,12,235,166,0,0,89,255,125,12,235,166,0,0,0,12,235, - 125,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,138,247,34,0,0,0,0,0,12,146, - 0,0,0,0,0,144,21,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,59,245,255,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,247,42,206,201,0,0,89, - 225,21,0,0,89,255,125,0,0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,0,175,225,21, - 0,0,0,0,0,175,225,21,0,0,0,0,0,0,0,127,0,175,251,89,0,0,0,0,0,12,146,0, - 0,0,0,0,144,21,0,59,245,166,0,0,138,225,21,0,0,0,59,245,166,138,251,89, - 7,206,201,0,12,235,125,0,59,241,89,0,0,0,175,125,0,0,0,0,0,175,125,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0,0,175,166,0,138,201,7,206,125,7,206, - 166,138,166,0,0,0,138,251,89,0,0,0,59,115,0,89,255,201,0,0,12,235,125,0, - 0,0,0,0,0,12,146,0,0,0,0,0,144,21,0,89,251,89,0,0,0,0,0,0,12,146,0,0,0, - 0,0,144,21,0,0,12,146,0,0,0,0,0,144,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,138,125,0,0,138,225,34,182,0,0,0,7,206,166,0, - 7,206,255,247,34,0,0,175,125,0,12,146,0,0,0,0,0,144,21,0,89,251,89,0,0, - 0,0,0,0,175,225,21,0,0,0,0,0,0,0,127,0,0,138,255,255,255,255,125,0,12,235, - 255,255,255,255,255,225,21,0,138,247,34,0,7,206,166,0,0,0,0,89,247,34,175, - 201,0,7,206,201,0,12,235,125,0,59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,59,215,21,0,0,12,235,255,251,89,0,89,255,255,225, - 21,12,235,255,255,255,247,34,0,0,0,0,0,0,0,0,12,235,255,255,255,255,255, - 255,255,255,251,89,0,12,235,255,255,255,255,255,225,21,0,138,255,255,255, - 255,255,255,166,0,12,235,255,255,255,255,255,225,21,0,0,12,235,255,255, - 255,255,255,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,89,255,255,255,247,34,0,0,0,0,0,0,0,175,255,255,125,0,138,255,255, - 255,125,0,0,12,235,255,255,255,255,255,225,21,0,175,255,255,255,255,247, - 0,0,0,175,225,21,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,175,166,0,255,255,201,0,0,0,0,0,175,166,12,232,89,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12, - 228,34,0,0,0,0,0,0,0,0,12,232,89,59,215,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127,0,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,0,127,127,127,0,127,127,0,127,127,127,127,127,0,127,127,127,127, - 127,0,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127, - 0,127,127,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,245,255,255,255,255,255,255,225,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,225,21,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,247, - 34,0,0,0,0,59,192,0,0,0,0,0,7,206,255,255,225,21,0,0,0,0,0,0,0,0,138,247, - 34,0,0,89,251,89,0,7,206,125,0,0,7,206,255,255,255,166,0,89,251,89,138, - 247,34,0,0,0,0,7,206,255,255,255,247,34,0,0,0,0,175,255,255,251,89,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255,255,247, - 34,0,0,0,0,0,0,0,0,0,0,0,0,89,255,255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,12, - 235,255,247,34,0,0,7,206,255,251,89,0,0,7,206,125,0,0,0,0,0,0,0,0,0,0,0, - 0,89,255,255,255,255,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,0, - 59,245,255,247,34,0,0,0,0,0,0,0,0,0,0,0,89,201,0,0,0,0,175,166,0,0,0,0, - 0,0,89,201,0,0,0,0,175,166,0,0,0,0,0,59,245,255,201,0,0,0,59,241,89,0,0, - 0,0,0,59,245,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,247,34, - 0,0,0,0,59,192,0,0,0,0,0,175,201,0,0,144,21,0,0,0,0,0,0,0,0,7,206,166,0, - 7,206,166,0,0,7,206,125,0,7,206,201,0,0,89,166,0,0,0,0,0,0,0,0,0,0,89,255, - 125,0,0,0,59,245,166,0,0,0,0,0,0,12,206,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,89,255,125,0,0,0,59,245,166,0,0,0,0,0,0,0,0,0,0,59, - 241,89,0,138,201,0,0,0,0,0,138,166,0,0,0,0,0,168,34,7,206,166,0,0,172,89, - 0,175,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255,255,255,166,89,225,21, - 0,0,0,0,0,0,0,0,0,0,0,0,0,89,255,251,89,0,0,12,235,125,0,138,225,21,0,0, - 0,0,0,0,0,0,7,206,255,201,0,0,0,89,225,21,0,0,0,0,7,206,255,201,0,0,0,89, - 225,21,0,0,0,0,12,206,21,12,235,125,0,0,175,166,0,0,0,0,0,0,59,245,125, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,175,255,255,255, - 166,0,0,12,235,125,0,0,0,0,89,225,21,0,0,12,232,89,0,89,247,34,89,247,34, - 0,0,7,206,125,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,89,225,21,0,0,0,0, - 0,7,206,125,0,0,7,206,255,255,247,34,0,0,0,85,89,0,85,89,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,89,225,21,0,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,0,89,201, - 0,0,12,228,34,0,0,0,0,138,166,0,0,0,0,0,0,0,7,206,125,0,0,7,206,255,166, - 0,0,0,0,0,0,0,0,0,12,235,125,0,0,89,247,34,175,255,255,255,166,89,225,21, - 0,89,255,125,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,89,225,21,0,12,232,89,59, - 115,0,59,115,0,0,0,0,0,89,201,0,0,7,206,125,0,0,0,0,0,0,0,89,201,0,0,7, - 206,125,0,0,0,0,0,0,0,0,12,232,89,0,59,238,34,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,225,21,0,0,138,247,94,192,12,182, - 0,0,12,235,125,0,0,0,0,0,175,255,255,255,255,166,0,0,7,206,171,206,166, - 0,0,0,7,206,125,0,7,206,251,89,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,59,245, - 255,255,201,0,12,228,34,12,235,166,0,12,228,34,0,0,138,251,89,138,247,34, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,0,138,255,255,255,125,0,12,228,34, - 0,0,0,0,0,0,0,0,59,241,89,0,138,201,0,0,0,0,0,138,166,0,0,0,0,0,0,0,175, - 201,0,0,0,0,0,0,175,201,0,0,0,0,0,0,0,0,12,235,125,0,0,89,247,34,175,255, - 255,255,166,89,225,21,0,89,255,125,0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,138, - 225,21,0,12,235,125,12,235,166,59,245,166,0,0,0,0,89,201,0,0,89,225,21, - 0,0,0,0,0,0,0,89,201,0,0,89,225,21,0,0,0,0,0,0,12,235,255,125,0,0,175,125, - 0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89, - 225,21,0,12,235,125,59,192,0,0,0,0,12,235,125,0,0,0,0,0,59,215,21,59,238, - 34,0,0,0,89,255,247,34,0,0,0,7,206,125,0,0,7,206,255,255,247,34,0,0,0,0, - 0,0,0,0,59,192,0,12,235,166,0,7,176,21,0,175,125,59,238,34,0,12,228,34, - 0,138,247,34,138,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,192,0,0,138, - 201,0,89,247,34,0,175,125,0,0,0,0,0,0,0,0,0,89,255,255,225,21,0,7,206,255, - 255,255,255,255,255,247,34,0,12,235,125,0,0,0,7,176,21,0,175,201,0,0,0, - 0,0,0,0,0,12,235,125,0,0,89,247,34,89,255,255,255,166,89,225,21,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,7,202,89,0,0,89,225,21,0,12,232,89,0,12,235,166,12, - 235,166,0,0,0,89,201,0,7,206,125,0,12,235,166,0,0,0,0,89,201,0,7,206,125, - 89,255,255,255,125,0,0,0,0,7,206,125,89,225,21,0,138,225,21,0,0,0,138,255, - 125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,59,241,89,59, - 192,0,0,0,12,235,255,255,255,225,21,0,0,138,166,0,7,202,89,0,0,0,7,206, - 166,0,0,0,0,0,0,0,0,7,206,125,0,12,235,201,0,0,0,0,0,0,0,0,89,166,0,89, - 247,34,0,0,0,0,0,89,166,12,232,89,0,138,247,34,89,247,34,59,238,34,0,0, - 12,235,255,255,255,255,255,255,247,34,89,255,255,255,166,89,166,0,0,138, - 201,0,138,225,21,0,89,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166, - 0,0,0,0,7,206,255,255,255,247,34,0,59,245,255,247,34,0,0,0,0,0,0,0,0,12, - 235,125,0,0,89,247,34,0,89,255,255,166,89,225,21,0,0,0,0,0,0,0,0,0,0,0, - 0,0,89,255,255,255,166,0,12,235,125,0,138,225,21,0,0,12,235,125,12,235, - 125,0,0,89,201,0,89,201,0,7,206,223,166,0,0,0,0,89,201,0,89,201,0,89,125, - 0,138,225,21,12,182,0,7,206,133,206,125,0,89,232,215,21,0,7,206,247,34, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,59,241,89,59, - 192,0,0,0,0,12,235,125,0,0,0,0,0,59,215,21,59,238,34,0,59,245,255,255,255, - 255,225,21,0,0,0,0,0,59,241,89,0,0,138,225,21,0,0,0,0,0,0,0,89,166,0,89, - 247,34,0,0,0,0,0,89,166,0,138,255,255,176,228,34,0,138,247,34,138,247,34, - 0,0,0,0,0,0,0,0,59,238,34,0,0,0,0,0,89,166,0,0,138,255,255,225,21,0,0,89, - 166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,89,247,34,0,0,0,138,166,89,225, - 21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,255,247,34,0,0,12,235, - 166,12,235,166,0,0,0,0,0,12,232,89,0,175,166,138,166,0,0,0,0,0,0,12,232, - 89,0,0,0,0,138,201,0,0,89,255,255,201,89,225,21,89,225,81,215,21,0,138, - 247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,12,235, - 125,59,192,0,0,0,0,59,241,89,0,0,0,0,0,175,255,255,255,255,166,0,0,0,7, - 206,166,0,0,0,0,7,206,125,0,12,235,201,0,7,206,166,0,0,0,0,0,0,0,0,59,192, - 0,12,235,166,0,7,176,21,0,175,125,0,0,0,0,0,0,0,0,0,138,251,89,138,247, - 34,0,0,0,0,0,0,0,59,238,34,0,0,0,0,0,59,192,0,0,138,201,59,245,166,0,0, - 175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,166,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,89,247,34,0,0,0,138,166, - 89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,166, - 59,245,166,0,0,0,0,0,0,138,201,0,138,201,0,138,166,0,0,0,0,0,0,138,201, - 0,0,0,0,89,247,34,0,0,0,0,0,7,206,125,59,238,34,59,215,21,0,175,225,21, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,89,247,34,0,0,175,225,81, - 192,12,182,0,7,206,125,0,0,0,0,0,89,225,21,0,0,12,232,89,0,0,7,206,166, - 0,0,0,0,7,206,125,0,0,59,245,255,255,166,0,0,0,0,0,0,0,0,0,7,202,89,0,59, - 245,255,255,166,0,12,228,34,0,0,0,0,0,0,0,0,0,0,85,89,0,85,89,0,0,0,0,0, - 0,0,59,238,34,0,0,0,0,0,7,202,89,0,138,201,0,59,245,225,34,228,34,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255,255,255,255,255,247,34,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,201,0,0,175,247,34,0,0,0,138,166, - 89,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,59,115,0, - 59,115,0,0,0,0,0,0,12,232,89,0,175,255,255,255,255,201,0,0,0,0,12,232,89, - 0,0,0,138,201,0,0,0,0,0,0,0,89,201,0,89,255,255,255,255,247,34,138,251, - 89,0,7,176,21,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,138,247,34,0,0,0, - 175,255,255,255,166,0,89,255,255,255,255,255,247,34,0,0,0,0,0,0,0,0,0,0, - 7,206,166,0,0,0,0,7,206,125,0,0,0,0,0,138,255,166,0,0,0,0,0,0,0,0,0,89, - 225,21,0,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,59,238,34,0,0,0,0,0,0,89,225,21,0,0,0,0,0,7,206,125,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,12,235,191,255,255,166,238,34,0,0,0,138,166,89,225,21,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,201,0,0, - 0,0,0,138,166,0,0,0,0,0,175,201,0,0,0,89,255,255,255,255,125,0,0,0,12,232, - 89,0,0,0,0,59,215,21,0,0,138,255,255,255,225,21,0,0,0,0,0,0,0,0,0,0,0,0, - 0,127,0,0,0,0,0,0,0,0,0,0,0,0,59,192,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,7,206,125,0,0,0,0,0,0,175,201,0,0,0,0,0,0,0,0,0,0, - 89,255,125,0,0,0,59,245,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,89,255,125,0,0,0,59,245,166,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,12,235,125,0,0,0,0,0,0,0,0,138,166,89,225,21,0,0,0,0,0,0,0,0,0,175, - 125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,59,192,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,125,0,7,199,34, - 0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255,255,247,34,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255, - 255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0,0,138,166, - 89,225,21,0,0,0,0,0,0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,7,206,125,0,7,206,255,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,12,235,255,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127, - 127,127,0,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,0,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,0,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,138,225, - 21,0,0,0,0,0,12,235,125,0,0,0,0,19,172,255,190,11,0,0,0,0,138,255,201,7, - 202,89,0,0,0,0,0,0,0,0,0,0,7,206,255,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,59,138,225,21,0,0,0,0,0,0,59,245,201,0,0,0,19,172, - 255,190,11,0,0,0,0,0,0,0,0,0,7,206,225,21,0,0,0,59,245,201,19,172,255,190, - 11,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,251,89,89,201,0,0,0,0,0,175, - 201,0,0,0,0,0,0,0,0,7,206,225,21,0,0,0,0,0,19,172,255,190,11,0,0,0,0,0, - 175,255,166,12,228,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,89,255,125,0,0,0,0,0,0,0,12,175,247,34,0,0,0,19,172,255, - 190,11,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,247,34,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,0,0,0,7,206,125,0,0,0,0,0,138,201,0,0,0,0,0,136,190, - 45,196,145,0,0,0,59,215,21,175,255,166,0,0,0,175,225,29,206,166,0,0,7,202, - 89,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,209,125, - 0,0,0,0,0,0,138,225,21,0,0,0,136,190,45,196,145,0,0,0,175,225,29,206,166, - 0,0,12,235,125,0,0,12,138,225,21,136,190,45,196,145,159,251,89,138,247, - 34,0,0,0,0,0,0,0,0,0,0,0,175,125,59,245,247,34,0,0,0,0,0,12,232,89,0,0, - 0,0,0,0,0,175,166,0,0,0,0,0,0,12,136,190,45,196,145,0,0,0,0,138,166,12, - 235,255,125,0,0,0,0,7,206,166,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,12,232,89,0,0,0,0,0,0,138,201,0,0,0,0,0,136,190,45, - 196,145,34,0,0,0,89,251,89,138,247,34,0,0,0,0,0,138,201,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,202,89,7,202,89,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,255, - 255,125,0,0,0,0,127,0,0,7,206,251,89,0,0,0,0,7,206,251,89,0,0,0,0,7,206, - 251,89,0,0,0,0,0,7,206,251,89,0,0,0,0,7,206,251,89,0,0,0,0,12,235,255,125, - 0,0,0,0,0,89,255,255,255,255,255,255,255,255,125,0,0,0,59,245,255,255,255, - 201,12,235,255,255,255,255,255,125,12,235,255,255,255,255,255,125,12,235, - 255,255,255,255,255,125,12,235,255,255,255,255,255,125,89,255,255,255,201, - 89,255,255,255,201,89,255,255,255,201,89,255,255,255,201,0,175,255,255, - 255,255,201,0,0,0,12,235,251,89,0,0,12,235,125,0,0,0,138,255,255,166,0, - 0,0,0,0,0,138,255,255,166,0,0,0,0,0,0,138,255,255,166,0,0,0,0,0,0,138,255, - 255,166,0,0,0,0,0,0,138,255,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138, - 255,255,201,89,251,89,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245, - 125,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125,7,206,225,21, - 0,0,0,138,247,0,235,166,0,0,0,0,0,0,138,225,21,7,206,166,0,0,0,127,0,0, - 59,245,255,166,0,0,0,0,59,245,255,166,0,0,0,0,59,245,255,166,0,0,0,0,0, - 59,245,255,166,0,0,0,0,59,245,255,166,0,0,0,0,59,245,255,166,0,0,0,0,0, - 175,201,7,206,166,0,0,0,0,0,0,0,138,255,125,0,0,7,202,102,235,166,0,0,0, - 0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,0,12, - 235,125,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125,0,0,175,201,0,0,7, - 206,251,89,0,12,235,255,201,0,0,12,235,125,0,59,245,166,0,0,138,251,89, - 0,0,59,245,166,0,0,138,251,89,0,0,59,245,166,0,0,138,251,89,0,0,59,245, - 166,0,0,138,251,89,0,0,59,245,166,0,0,138,251,89,0,0,0,0,0,0,0,0,0,0,0, - 0,59,245,166,0,0,89,255,166,0,12,235,125,0,0,0,59,245,125,12,235,125,0, - 0,0,59,245,125,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125, - 0,59,245,125,0,0,59,245,125,12,235,166,0,0,0,0,0,12,235,125,0,0,175,201, - 0,0,0,127,0,0,138,225,151,225,21,0,0,0,138,225,151,225,21,0,0,0,138,225, - 151,225,21,0,0,0,0,138,225,151,225,21,0,0,0,138,225,151,225,21,0,0,0,138, - 225,151,225,21,0,0,0,59,241,89,7,206,166,0,0,0,0,0,0,12,235,166,0,0,0,0, - 0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235, - 166,0,0,0,0,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125, - 0,0,175,201,0,0,0,0,175,225,21,12,235,166,245,125,0,12,235,125,12,235,125, - 0,0,0,0,138,247,34,12,235,125,0,0,0,0,138,247,34,12,235,125,0,0,0,0,138, - 247,34,12,235,125,0,0,0,0,138,247,34,12,235,125,0,0,0,0,138,247,34,0,138, - 225,21,0,0,0,175,201,0,12,235,125,0,0,7,202,159,247,34,12,235,125,0,0,0, - 59,245,125,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125,12,235, - 125,0,0,0,59,245,125,0,0,138,247,34,7,206,201,0,12,235,255,255,255,251, - 89,0,12,235,125,0,12,235,125,0,0,0,127,0,7,206,166,59,241,89,0,0,7,206, - 166,59,241,89,0,0,7,206,166,59,241,89,0,0,0,7,206,166,59,241,89,0,0,7,206, - 166,59,241,89,0,0,7,206,166,59,241,89,0,0,0,138,225,21,7,206,166,0,0,0, - 0,0,0,89,247,34,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12, - 235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,0,12,235,125,0,0,12,235,125,0,0, - 12,235,125,0,0,12,235,125,0,0,175,201,0,0,0,0,59,241,89,12,235,125,138, - 225,21,12,235,125,89,247,34,0,0,0,0,59,245,125,89,247,34,0,0,0,0,59,245, - 125,89,247,34,0,0,0,0,59,245,125,89,247,34,0,0,0,0,59,245,125,89,247,34, - 0,0,0,0,59,245,125,0,0,175,225,21,0,175,225,21,0,89,247,34,0,0,138,166, - 12,235,125,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125,12,235, - 125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125,0,0,12,235,166,89,247, - 34,0,12,235,166,0,0,138,251,89,12,235,133,206,255,125,0,0,0,0,127,0,59, - 241,89,7,206,166,0,0,59,241,89,7,206,166,0,0,59,241,89,7,206,166,0,0,0, - 59,241,89,7,206,166,0,0,59,241,89,7,206,166,0,0,59,241,89,7,206,166,0,0, - 12,235,125,0,7,206,255,255,255,255,247,34,0,138,225,21,0,0,0,0,0,12,235, - 255,255,255,255,247,34,12,235,255,255,255,255,247,34,12,235,255,255,255, - 255,247,34,12,235,255,255,255,255,247,34,0,12,235,125,0,0,12,235,125,0, - 0,12,235,125,0,0,12,235,125,0,206,255,255,255,247,34,0,12,235,125,12,235, - 125,12,235,125,12,235,125,138,225,21,0,0,0,0,12,235,166,138,225,21,0,0, - 0,0,12,235,166,138,225,21,0,0,0,0,12,235,166,138,225,21,0,0,0,0,12,235, - 166,138,225,21,0,0,0,0,12,235,166,0,0,0,175,225,187,225,21,0,0,138,225, - 21,0,59,215,21,7,206,166,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59, - 245,125,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125,0,0,0,89, - 255,255,125,0,0,12,235,166,0,0,12,235,166,12,235,125,0,7,206,201,0,0,0, - 127,0,138,225,21,0,138,225,21,0,138,225,21,0,138,225,21,0,138,225,21,0, - 138,225,21,0,0,138,225,21,0,138,225,21,0,138,225,21,0,138,225,21,0,138, - 225,21,0,138,225,21,0,89,255,255,255,255,255,166,0,0,0,0,0,0,138,225,21, - 0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0, - 0,12,235,166,0,0,0,0,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125,0,0,12, - 235,125,0,0,175,201,0,0,0,0,12,235,125,12,235,125,0,138,225,34,235,125, - 138,225,21,0,0,0,0,12,235,166,138,225,21,0,0,0,0,12,235,166,138,225,21, - 0,0,0,0,12,235,166,138,225,21,0,0,0,0,12,235,166,138,225,21,0,0,0,0,12, - 235,166,0,0,0,0,175,225,21,0,0,0,138,225,21,7,202,89,0,7,206,166,12,235, - 125,0,0,0,59,245,125,12,235,125,0,0,0,59,245,125,12,235,125,0,0,0,59,245, - 125,12,235,125,0,0,0,59,245,125,0,0,0,7,206,225,21,0,0,12,235,166,0,0,12, - 235,166,12,235,125,0,0,59,241,89,0,0,127,7,206,255,255,255,255,251,89,7, - 206,255,255,255,255,251,89,7,206,255,255,255,255,251,89,0,7,206,255,255, - 255,255,251,89,7,206,255,255,255,255,251,89,7,206,255,255,255,255,251,89, - 7,206,166,0,0,7,206,166,0,0,0,0,0,0,89,247,34,0,0,0,0,0,12,235,166,0,0, - 0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,0, - 12,235,125,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125,0,0,175,201,0,0, - 0,0,59,241,89,12,235,125,0,12,235,138,235,125,89,247,34,0,0,0,0,59,245, - 125,89,247,34,0,0,0,0,59,245,125,89,247,34,0,0,0,0,59,245,125,89,247,34, - 0,0,0,0,59,245,125,89,247,34,0,0,0,0,59,245,125,0,0,0,175,225,187,225,21, - 0,0,138,247,34,175,125,0,0,12,235,125,12,235,125,0,0,0,59,241,89,12,235, - 125,0,0,0,59,241,89,12,235,125,0,0,0,59,241,89,12,235,125,0,0,0,59,241, - 89,0,0,0,0,175,225,21,0,0,12,235,166,0,0,175,247,34,12,235,125,0,0,12,235, - 125,0,0,127,59,241,89,0,0,7,206,166,59,241,89,0,0,7,206,166,59,241,89,0, - 0,7,206,166,0,59,241,89,0,0,7,206,166,59,241,89,0,0,7,206,166,59,241,89, - 0,0,7,206,166,59,241,89,0,0,7,206,166,0,0,0,0,0,0,59,245,166,0,0,0,0,0, - 12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235,166, - 0,0,0,0,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125,0,0,12,235,125,0,0, - 175,201,0,0,0,0,175,225,21,12,235,125,0,0,138,232,245,125,12,235,125,0, - 0,0,0,138,247,34,12,235,125,0,0,0,0,138,247,34,12,235,125,0,0,0,0,138,247, - 34,12,235,125,0,0,0,0,138,247,34,12,235,125,0,0,0,0,138,247,34,0,0,175, - 225,21,0,175,225,21,0,59,245,191,201,0,0,0,89,225,21,12,235,166,0,0,0,89, - 251,89,12,235,166,0,0,0,89,251,89,12,235,166,0,0,0,89,251,89,12,235,166, - 0,0,0,89,251,89,0,0,0,0,175,225,21,0,0,12,235,255,255,255,247,34,0,12,235, - 125,0,0,59,241,89,0,0,127,138,225,21,0,0,0,138,247,163,225,21,0,0,0,138, - 247,163,225,21,0,0,0,138,247,34,138,225,21,0,0,0,138,247,163,225,21,0,0, - 0,138,247,163,225,21,0,0,0,138,247,198,225,21,0,0,7,206,166,0,0,0,0,0,0, - 0,138,255,125,0,0,7,202,102,235,166,0,0,0,0,0,12,235,166,0,0,0,0,0,12,235, - 166,0,0,0,0,0,12,235,166,0,0,0,0,0,0,12,235,125,0,0,12,235,125,0,0,12,235, - 125,0,0,12,235,125,0,0,175,201,0,0,7,206,251,89,0,12,235,125,0,0,12,235, - 255,125,0,89,255,125,0,0,89,251,89,0,0,89,255,125,0,0,89,251,89,0,0,89, - 255,125,0,0,89,251,89,0,0,89,255,125,0,0,89,251,89,0,0,89,255,125,0,0,89, - 251,89,0,0,138,225,21,0,0,0,175,201,0,0,138,251,89,0,0,89,251,89,0,0,138, - 247,34,0,7,206,225,21,0,138,247,34,0,7,206,225,21,0,138,247,34,0,7,206, - 225,21,0,138,247,34,0,7,206,225,21,0,0,0,0,175,225,21,0,0,12,235,166,0, - 0,0,0,0,12,235,125,0,0,175,225,21,0,0,127,206,166,0,0,0,0,59,245,255,166, - 0,0,0,0,59,245,255,166,0,0,0,0,59,245,133,206,166,0,0,0,0,59,245,255,166, - 0,0,0,0,59,245,255,166,0,0,0,0,59,245,255,125,0,0,0,7,206,255,255,255,255, - 255,125,0,0,0,59,245,255,255,255,201,12,235,255,255,255,255,255,125,12, - 235,255,255,255,255,255,125,12,235,255,255,255,255,255,125,12,235,255,255, - 255,255,255,125,89,255,255,255,201,89,255,255,255,201,89,255,255,255,201, - 89,255,255,255,201,0,175,255,255,255,255,225,21,0,0,12,235,125,0,0,0,138, - 255,125,0,0,0,175,255,255,201,0,0,0,0,0,0,175,255,255,201,0,0,0,0,0,0,175, - 255,255,201,0,0,0,0,0,0,175,255,255,201,0,0,0,0,0,0,175,255,255,201,0,0, - 0,0,0,0,0,0,0,0,0,0,0,7,202,97,206,255,255,201,0,0,0,0,0,138,255,255,255, - 201,0,0,0,0,138,255,255,255,201,0,0,0,0,138,255,255,255,201,0,0,0,0,138, - 255,255,255,201,0,0,0,0,0,0,175,225,21,0,0,12,235,166,0,0,0,0,0,12,235, - 133,206,255,225,21,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,138,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,138,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,175,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,225,21, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,0,127,127,127,127,0,127,127,127,127,0,127,127,127, - 127,0,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,7,206,225,21, - 0,0,0,0,0,12,235,225,21,0,0,89,255,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,7,206,255,247,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,247, - 34,0,0,0,0,0,0,0,138,251,89,0,0,59,245,247,34,0,0,0,0,0,0,0,0,0,175,247, - 34,0,0,175,0,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,225,21, - 0,0,0,0,0,0,0,138,255,125,0,0,0,12,235,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,251,89,0,0,0,0,0,0, - 7,206,225,21,0,0,0,7,206,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,59,245,166,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,59,241,89,0,0,0,0, - 0,89,247,34,0,0,7,206,138,235,125,0,0,89,255,225,21,175,125,0,0,0,0,0,0, - 0,0,0,138,201,0,138,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12, - 235,125,0,0,0,0,0,0,12,235,125,0,0,0,175,171,206,166,0,0,0,0,0,0,0,0,0, - 7,206,166,0,59,245,255,166,238,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,125,59, - 215,21,0,0,59,241,89,0,0,0,0,0,0,7,206,166,0,0,0,0,138,201,175,201,0,0, - 0,12,235,251,89,89,201,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,7,206,166,0,0,0,0,0,0,89,247,34,0,0,0,0,89,225,151,201,0,0,0,0, - 0,0,0,0,0,0,0,0,0,175,201,0,12,235,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,127,0,0,0,138,201,0,0,0,0,7,206,125,0,0,0,138,201,0,89,225,21, - 12,228,34,138,255,201,0,0,0,138,247,34,175,225,21,0,138,201,0,138,201,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,225,21,0,0,0,0,0,89,225, - 21,0,0,89,247,34,59,241,89,0,59,241,89,89,247,34,0,0,89,225,21,175,127, - 215,21,206,247,42,206,0,138,255,247,42,206,125,0,0,138,166,12,235,251,89, - 0,0,0,0,138,201,0,0,0,0,0,0,89,225,21,0,0,0,59,241,89,12,235,125,0,0,175, - 125,59,245,247,34,0,0,12,235,125,89,251,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,59,238,34,0,0,0,0,0,175,166,0,0,0,0,12,232,89,7,206,125,0, - 0,12,235,166,59,245,125,0,0,0,59,238,34,0,12,235,125,0,0,0,0,0,0,89,247, - 34,138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,255,247,34,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,175,251,89,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,199,34,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,12,235,125,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,12,235,255,255,255,166,0,12,235,255, - 255,255,166,0,12,235,255,255,255,166,0,12,235,255,255,255,166,0,0,12,235, - 255,255,255,166,0,12,235,255,255,255,166,0,12,235,255,255,255,166,0,175, - 255,255,125,0,0,12,235,255,255,125,0,0,12,235,255,255,225,21,0,0,12,235, - 255,255,225,21,0,12,235,255,255,225,21,0,12,235,255,255,225,21,0,12,235, - 125,12,235,125,12,235,125,12,235,125,0,12,235,125,89,251,89,0,12,235,138, - 235,255,247,34,0,0,12,235,255,255,201,0,0,0,12,235,255,255,201,0,0,0,12, - 235,255,255,201,0,0,0,12,235,255,255,201,0,0,0,12,235,255,255,201,0,0,0, - 0,0,0,175,247,34,0,0,0,12,235,255,255,255,166,0,59,241,89,0,0,89,247,34, - 59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,42, - 206,201,0,0,0,138,232,245,166,245,255,251,89,7,206,201,0,0,0,138,225,21, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,12,206,21,0,59,245,125,12,206,21,0,59,245,125,12,206, - 21,0,59,245,125,12,206,21,0,59,245,125,0,12,206,21,0,59,245,125,12,206, - 21,0,59,245,125,12,206,21,0,12,235,255,125,0,7,206,166,12,235,166,0,0,172, - 102,0,235,125,0,0,175,201,0,12,235,125,0,0,175,201,12,235,125,0,0,175,201, - 12,235,125,0,0,175,201,0,12,235,125,12,235,125,12,235,125,12,235,125,0, - 0,0,0,0,175,201,0,12,235,247,34,0,175,201,0,12,235,166,0,7,206,201,0,12, - 235,166,0,7,206,201,0,12,235,166,0,7,206,201,0,12,235,166,0,7,206,201,0, - 12,235,166,0,7,206,201,0,0,0,0,0,175,247,34,0,0,12,235,166,0,12,235,201, - 0,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247, - 34,59,241,89,0,0,89,247,34,89,247,34,0,7,206,176,235,225,21,0,175,225,21, - 89,247,34,0,7,206,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,7,206,166,0,0,0,0,7, - 206,166,0,0,0,0,7,206,166,0,0,0,0,7,206,166,0,0,0,0,0,7,206,166,0,0,0,0, - 7,206,166,0,0,0,0,0,175,201,0,0,0,89,225,138,225,21,0,0,0,0,89,225,21,0, - 0,89,247,34,89,225,21,0,0,89,247,124,225,21,0,0,89,247,124,225,21,0,0,89, - 247,34,12,235,125,12,235,125,12,235,125,12,235,125,0,89,255,255,255,255, - 247,34,12,235,125,0,0,89,247,34,138,225,21,0,0,59,238,34,138,225,21,0,0, - 59,238,34,138,225,21,0,0,59,238,34,138,225,21,0,0,59,238,34,138,225,21, - 0,0,59,238,34,0,0,0,0,0,0,0,0,0,138,225,21,0,172,132,238,34,59,241,89,0, - 0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0, - 0,89,247,34,12,235,125,0,59,238,47,235,125,0,0,59,241,89,12,235,125,0,59, - 238,34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,59,245,255,255,255,166,0,59,245,255,255, - 255,166,0,59,245,255,255,255,166,0,59,245,255,255,255,166,0,0,59,245,255, - 255,255,166,0,59,245,255,255,255,166,0,89,255,255,255,255,255,255,255,255, - 255,247,175,201,0,0,0,0,0,175,255,255,255,255,255,247,34,175,255,255,255, - 255,255,247,198,255,255,255,255,255,247,198,255,255,255,255,255,247,34, - 12,235,125,12,235,125,12,235,125,12,235,125,89,251,89,0,0,59,241,89,12, - 235,125,0,0,89,247,34,175,201,0,0,0,12,232,89,175,201,0,0,0,12,232,89,175, - 201,0,0,0,12,232,89,175,201,0,0,0,12,232,89,175,201,0,0,0,12,232,89,7,206, - 255,255,255,255,255,255,251,226,201,0,89,166,12,232,89,59,241,89,0,0,89, - 247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89, - 247,34,0,175,201,0,138,201,12,235,125,0,0,12,235,125,0,175,201,0,138,201, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,127,89,255,166,0,7,206,166,89,255,166,0,7,206,166,89, - 255,166,0,7,206,166,89,255,166,0,7,206,166,0,89,255,166,0,7,206,166,89, - 255,166,0,7,206,166,138,255,125,0,0,175,201,0,0,0,0,0,175,201,0,0,0,0,0, - 175,201,0,0,0,0,0,0,175,201,0,0,0,0,0,175,201,0,0,0,0,0,175,201,0,0,0,0, - 0,0,12,235,125,12,235,125,12,235,125,12,235,125,175,201,0,0,0,59,241,89, - 12,235,125,0,0,89,247,34,175,201,0,0,0,12,232,89,175,201,0,0,0,12,232,89, - 175,201,0,0,0,12,232,89,175,201,0,0,0,12,232,89,175,201,0,0,0,12,232,89, - 0,0,0,0,0,0,0,0,0,175,201,7,176,21,12,232,89,59,241,89,0,0,89,247,34,59, - 241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,0, - 89,247,47,235,125,12,235,125,0,0,12,235,125,0,89,247,47,235,125,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,127,175,201,0,0,7,206,166,175,201,0,0,7,206,166,175,201,0,0, - 7,206,166,175,201,0,0,7,206,166,0,175,201,0,0,7,206,166,175,201,0,0,7,206, - 166,175,201,0,0,0,138,225,21,0,0,0,0,138,225,21,0,0,0,0,138,247,34,0,0, - 0,0,0,138,247,34,0,0,0,0,138,247,34,0,0,0,0,138,247,34,0,0,0,0,0,12,235, - 125,12,235,125,12,235,125,12,235,125,175,201,0,0,0,89,247,34,12,235,125, - 0,0,89,247,34,138,225,21,0,0,89,247,34,138,225,21,0,0,89,247,34,138,225, - 21,0,0,89,247,34,138,225,21,0,0,89,247,34,138,225,21,0,0,89,247,34,0,0, - 0,0,175,247,34,0,0,138,225,151,125,0,89,247,34,59,241,89,0,0,89,247,34, - 59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34,59,241,89,0,0,89,247,34, - 0,12,235,191,247,34,12,235,125,0,0,59,241,89,0,12,235,191,247,34,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,127,138,225,21,0,138,255,166,138,225,21,0,138,255,166,138, - 225,21,0,138,255,166,138,225,21,0,138,255,166,0,138,225,21,0,138,255,166, - 138,225,21,0,138,255,166,89,247,34,0,89,255,255,166,0,0,12,206,12,235,166, - 0,0,127,102,0,235,201,0,0,12,206,21,12,235,201,0,0,12,206,34,235,201,0, - 0,12,206,34,235,201,0,0,12,206,21,12,235,125,12,235,125,12,235,125,12,235, - 125,89,255,125,0,7,206,166,0,12,235,125,0,0,89,247,34,12,235,166,0,7,206, - 201,0,12,235,166,0,7,206,201,0,12,235,166,0,7,206,201,0,12,235,166,0,7, - 206,201,0,12,235,166,0,7,206,201,0,0,0,0,0,175,247,34,0,0,12,235,201,0, - 7,206,201,0,7,206,166,0,59,245,247,34,7,206,166,0,59,245,247,34,7,206,166, - 0,59,245,247,34,7,206,166,0,59,245,247,34,0,0,138,255,166,0,12,235,125, - 0,7,206,201,0,0,0,138,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,7,206,255,255,171, - 206,166,7,206,255,255,171,206,166,7,206,255,255,171,206,166,7,206,255,255, - 171,206,166,0,7,206,255,255,171,206,166,7,206,255,255,171,206,166,0,89, - 255,255,201,0,0,175,255,255,247,34,0,12,235,255,255,166,0,0,7,206,255,255, - 247,34,0,0,7,206,255,255,247,34,0,7,206,255,255,247,34,0,7,206,255,255, - 247,34,0,12,235,125,12,235,125,12,235,125,12,235,125,0,89,255,255,255,201, - 0,0,12,235,125,0,0,89,247,34,0,12,235,255,255,201,0,0,0,12,235,255,255, - 201,0,0,0,12,235,255,255,201,0,0,0,12,235,255,255,201,0,0,0,12,235,255, - 255,201,0,0,0,0,0,0,0,0,0,0,0,7,206,255,255,255,201,0,0,0,59,245,255,225, - 111,247,34,0,59,245,255,225,111,247,34,0,59,245,255,225,111,247,34,0,59, - 245,255,225,111,247,34,0,0,59,241,89,0,12,235,255,255,255,225,21,0,0,0, - 59,241,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,175,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,138,125,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,138,225,21,0,12,235,125,0,0,0,0,0,0,0, - 138,225,21,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,7,202,89,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,206,166,0,0,12,235,125,0,0,0,0,0,0,7,206, - 166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 12,235,255,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,247,34,0,0,12,235,125,0,0,0,0,0,0,89,247, - 34,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,0,127,127,0,127,127,0,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,0,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0 -}; - - -const int FONTFIXED1_BM_W = 257; -const int FONTFIXED1_BM_H = 112; - -static const unsigned char s_FontFixed1[] = { - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,52,255,56,255,4,0,0, - 0,0,0,212,44,76,180,0,0,0,52,255,4,0,0,0,0,109,231,218,72,0,0,0,0,0,96,227, - 243,170,0,0,0,0,52,255,4,0,0,0,0,0,0,0,158,104,0,0,0,0,153,114,0,0,0,0,0,0,0, - 52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,172,128,0,0,12,164,241,234,133,1,0,0,22,179,237,255,4,0,0,0,141,220 - ,246,236,164,22,0,0,94,216,242,243,194,56,0,0,0,0,0,186,255,4,0,0,52,255,244, - 244,244,91,0,0,1,120,223,244,225,62,0,0,244,244,244,244,249,242,0,0,62,200, - 245,242,181,35,0,0,46,196,244,232,139,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,104,216,246,215,62,0,0,127,0,0 - ,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,52,255,56,255,4,0,0,0,0,13,239,2,131,124,0, - 0,110,232,255,238,202,62,0,29,254,51,99,231,0,0,0,0,0,241,53,0,34,0,0,0,0,52, - 255,4,0,0,0,0,0,0,45,225,4,0,0,0,0,30,237,15,0,0,0,0,99,95,52,255,11,127,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,38,242, - 19,0,0,155,188,12,29,221,103,0,0,21,101,90,255,4,0,0,0,127,46,1,15,165,192,0, - 0,34,24,0,5,127,233,0,0,0,0,98,197,255,4,0,0,52,255,4,0,0,0,0,0,121,219,45,0, - 22,27,0,0,0,0,0,0,170,151,0,14,242,119,4,12,160,207,0,3,224,136,5,18,188,114, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,114,38,2,133,225,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,52,255, - 56,255,4,0,0,0,0,67,189,0,187,69,0,26,254,100,255,8,53,44,0,30,254,49,100,235 - ,0,1,0,0,0,206,47,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,155,133,0,0,0,0,0,0,186, - 110,0,0,0,0,3,103,195,255,177,75,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,156,144,0,0,5,244,63,0,0,112,200,0,0,0,0,52, - 255,4,0,0,0,0,0,0,0,60,251,0,0,0,0,0,10,127,211,0,0,0,25,215,67,255,4,0,0,52, - 255,4,0,0,0,0,1,235,77,0,0,0,0,0,0,0,0,0,24,250,49,0,44,255,15,0,0,64,251,0, - 41,255,17,0,0,68,205,0,0,0,43,216,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,47,147,0, - 0,0,0,0,0,0,0,0,0,197,97,11,0,0,0,0,0,0,0,0,69,248,0,0,127,0,0,0,0,0,0,0,0,0, - 0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,63,240,247,248,240,254,241,0,42,255,69,255,4 - ,0,0,0,0,112,232,221,80,97,184,0,0,14,189,196,7,0,0,0,0,0,0,0,0,0,0,0,0,0,1, - 233,64,0,0,0,0,0,0,117,186,0,0,0,0,3,102,194,255,177,74,0,0,0,0,52,255,4,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,26,244,30,0,0,37,255,37 - ,175,0,66,244,0,0,0,0,52,255,4,0,0,0,0,0,0,0,126,195,0,0,0,48,241,255,190,16, - 0,0,0,176,90,52,255,4,0,0,52,255,228,236,162,16,0,33,255,106,220,237,172,21,0 - ,0,0,0,0,125,203,0,0,4,205,120,6,14,160,159,0,40,255,21,0,0,69,245,0,0,0,52, - 255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,13,102,203,225,132,0,0,240,240,240,240,240 - ,240,0,0,84,180,237,152,52,0,0,0,0,0,11,204,150,0,0,127,0,0,0,0,0,0,0,0,0,0, - 52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,190,66,54,202,0,0,2,196,220,255,106,32,0,0 - ,0,0,13,116,184,93,4,0,0,176,114,109,159,0,52,0,1,0,0,0,0,0,0,0,0,0,29,255,22 - ,0,0,0,0,0,0,72,236,0,0,0,0,99,96,52,255,11,128,0,0,240,240,243,255,240,240,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,140,161,0,0,0,49,255, - 33,216,0,54,255,0,0,0,0,52,255,4,0,0,0,0,0,0,68,236,45,0,0,0,0,0,27,198,133,0 - ,0,87,189,0,52,255,4,0,0,19,40,0,29,197,168,0,49,255,146,9,15,182,176,0,0,0,0 - ,3,226,100,0,0,0,28,210,252,255,182,7,0,2,223,142,6,20,186,255,0,0,0,0,0,0,0, - 0,0,0,0,43,216,3,0,0,0,0,158,233,162,67,1,0,0,0,0,0,0,0,0,0,0,0,0,0,23,115, - 210,208,0,0,0,0,176,192,6,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0, - 0,0,0,0,0,7,239,9,118,138,0,0,0,5,109,255,153,234,112,0,0,88,179,76,110,231, - 220,0,28,255,16,0,176,110,68,0,0,0,0,0,0,0,0,0,0,0,46,255,8,0,0,0,0,0,0,57, - 253,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,244,244, - 244,0,0,0,0,0,0,0,0,0,0,0,0,0,17,241,43,0,0,0,37,255,17,0,0,66,244,0,0,0,0,52 - ,255,4,0,0,0,0,0,73,233,60,0,0,0,0,0,0,0,69,238,0,16,227,40,0,52,255,4,0,0,0, - 0,0,0,69,246,0,38,255,20,0,0,69,247,0,0,0,0,79,242,11,0,0,5,214,122,7,16,162, - 175,0,0,46,193,239,210,125,241,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,202,215, - 114,23,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,67,162,236,0,0,0,34,255,31,0,0,0,127,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,236,244,251,240,251,244,228,0,0, - 0,52,255,4,76,245,0,0,11,0,29,254,51,101,0,40,255,30,0,18,222,193,0,0,0,0,0,0 - ,0,0,0,0,0,29,255,23,0,0,0,0,0,0,72,237,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,124,178,0,0,0,0,5,245 - ,63,0,0,111,200,0,0,0,0,52,255,4,0,0,0,0,87,233,54,0,0,0,0,0,0,0,0,70,248,0, - 52,255,255,255,255,255,255,0,0,0,0,0,0,68,246,0,6,248,19,0,0,65,247,0,0,0,0, - 185,151,0,0,0,42,255,15,0,0,59,252,0,0,0,0,0,0,124,188,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,46,147,234,180,86,0,0,244,244,244,244,244,244,0,0,39,133,226, - 197,97,10,0,0,0,51,255,4,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,140,115,12,235,8,0,0,32,73,55,255,11,143,215,0,0,0,0,31,255,47,97,0,1 - ,211,174,16,6,148,252,0,0,0,0,0,0,0,0,0,0,0,1,233,65,0,0,0,0,0,0,116,187,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0, - 44,220,3,0,0,0,0,9,234,58,0,0,0,0,0,155,186,12,28,220,103,0,0,0,8,58,255,11,8 - ,0,0,105,232,47,0,0,0,0,0,101,32,0,25,193,173,0,0,0,0,0,52,255,4,0,0,70,25,0, - 25,193,166,0,0,165,147,7,13,176,176,0,0,0,36,254,49,0,0,0,15,245,120,4,12,157 - ,210,0,0,37,12,0,68,239,74,0,0,0,44,220,3,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,8, - 92,192,0,0,0,0,0,0,0,0,0,0,235,142,41,0,0,0,0,0,0,4,24,0,0,0,0,127,0,0,0,0,0, - 0,0,0,0,0,49,244,3,0,0,0,0,0,0,0,0,0,0,0,0,222,33,87,169,0,0,0,23,186,245,255 - ,243,186,39,0,0,0,0,0,122,239,229,0,0,30,181,245,231,147,178,0,3,0,0,0,0,0,0, - 0,0,0,0,155,133,0,0,0,0,0,0,185,111,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,62,241,1,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,108,195,0,0,0,0,0,0,13, - 165,241,235,134,1,0,0,0,255,255,255,255,255,0,0,255,250,244,244,244,244,0,0, - 143,226,244,238,163,17,0,0,0,0,0,52,255,4,0,0,134,236,245,236,155,13,0,0,16, - 167,238,242,175,22,0,0,0,139,203,0,0,0,0,0,68,203,246,243,185,39,0,0,104,235, - 244,212,88,0,0,0,0,52,255,4,0,0,0,0,0,62,241,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,6,0,0,0,0,0,0,0,0,49,244,3,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,45,225,4,0,0,0,0,29,237,16,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,120,157,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,223, - 75,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,120,157,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,158,104,0,0,0,0,153,115,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,181,63,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,31,119,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,181,63,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0 - ,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,28,160 - ,229,236,163,14,0,0,0,20,252,200,0,0,0,52,255,244,243,238,177,32,0,0,0,96,213 - ,244,234,137,0,52,255,244,239,190,68,0,0,52,255,244,244,244,244,68,0,0,52,255 - ,244,244,244,244,0,0,0,104,217,244,222,100,0,52,255,4,0,0,52,255,0,0,244,246, - 255,244,244,0,0,0,0,137,244,246,255,4,0,52,255,4,0,0,137,216,0,0,52,255,4,0,0 - ,0,0,52,255,163,0,0,212,255,0,52,255,166,0,0,52,255,0,0,15,168,241,236,141,2, - 0,52,255,244,244,239,176,33,0,0,15,168,241,236,141,2,0,52,255,244,244,236,171 - ,30,0,0,47,189,243,241,204,73,0,0,244,244,246,255,244,244,0,52,255,4,0,0,52, - 255,0,125,203,0,0,0,24,254,0,236,75,0,0,0,0,152,0,44,247,51,0,0,71,241,0,220, - 112,0,0,0,161,179,0,0,244,244,244,244,249,254,0,0,0,52,255,244,125,0,0,35,244 - ,23,0,0,0,0,0,0,0,171,246,255,4,0,0,0,0,41,242,200,7,0,0,0,0,0,0,0,0,0,0,127, - 24,227,130,13,21,206,163,0,0,0,98,207,251,26,0,0,52,255,4,0,8,147,204,0,0,100 - ,224,51,0,22,89,0,52,255,4,7,81,238,66,0,52,255,4,0,0,0,0,0,0,52,255,4,0,0,0, - 0,0,106,221,46,0,29,89,0,52,255,4,0,0,52,255,0,0,0,52,255,4,0,0,0,0,0,0,0,52, - 255,4,0,52,255,4,0,133,218,26,0,0,52,255,4,0,0,0,0,52,255,202,4,36,219,255,0, - 52,255,242,30,0,52,255,0,0,160,175,10,24,213,112,0,52,255,4,0,20,166,204,0,0, - 160,175,10,24,213,112,0,52,255,4,0,17,166,201,0,8,232,119,7,3,56,63,0,0,0,0, - 52,255,4,0,0,52,255,4,0,0,52,255,0,48,253,19,0,0,94,226,0,197,107,0,0,0,0,184 - ,0,0,131,201,2,8,220,101,0,74,238,18,0,52,245,33,0,0,0,0,0,1,192,148,0,0,0,52 - ,255,4,0,0,0,0,168,135,0,0,0,0,0,0,0,0,52,255,4,0,0,0,16,218,106,178,159,0,0, - 0,0,0,0,0,0,0,0,127,157,170,0,0,0,88,243,0,0,0,179,121,200,105,0,0,52,255,4,0 - ,0,63,251,0,0,227,86,0,0,0,0,0,52,255,4,0,0,125,186,0,52,255,4,0,0,0,0,0,0,52 - ,255,4,0,0,0,0,1,229,84,0,0,0,0,0,52,255,4,0,0,52,255,0,0,0,52,255,4,0,0,0,0, - 0,0,0,52,255,4,0,52,255,4,130,220,27,0,0,0,52,255,4,0,0,0,0,52,255,141,66,115 - ,140,255,0,52,255,150,143,0,52,255,0,6,246,54,0,0,105,204,0,52,255,4,0,0,60, - 253,0,6,246,54,0,0,105,204,0,52,255,4,0,0,59,252,0,46,255,15,0,0,0,0,0,0,0,0, - 52,255,4,0,0,52,255,4,0,0,52,255,0,0,225,87,0,0,165,150,0,157,139,0,234,154,0 - ,215,0,0,7,216,102,132,187,0,0,0,176,146,0,194,127,0,0,0,0,0,0,101,223,12,0,0 - ,0,52,255,4,0,0,0,0,48,239,14,0,0,0,0,0,0,0,52,255,4,0,0,3,184,122,0,8,193, - 112,0,0,0,0,0,0,0,0,0,127,243,67,72,217,233,162,255,0,3,12,248,51,130,186,0,0 - ,52,255,4,0,12,158,197,0,31,255,22,0,0,0,0,0,52,255,4,0,0,69,240,0,52,255,4,0 - ,0,0,0,0,0,52,255,4,0,0,0,0,32,255,22,0,0,0,0,0,52,255,4,0,0,52,255,0,0,0,52, - 255,4,0,0,0,0,0,0,0,52,255,4,0,52,255,130,244,29,0,0,0,0,52,255,4,0,0,0,0,52, - 255,61,146,188,66,255,0,52,255,37,239,16,52,255,0,38,255,15,0,0,64,244,0,52, - 255,4,0,24,169,202,0,38,255,15,0,0,64,244,0,52,255,4,0,16,159,188,0,11,235, - 176,72,17,0,0,0,0,0,0,52,255,4,0,0,52,255,4,0,0,52,255,0,0,148,157,0,1,234,73 - ,0,118,170,31,225,207,0,246,0,0,0,62,237,237,32,0,0,0,31,241,124,221,8,0,0,0, - 0,0,25,238,68,0,0,0,0,52,255,4,0,0,0,0,0,184,118,0,0,0,0,0,0,0,52,255,4,0,0, - 44,101,0,0,0,14,121,0,0,0,0,0,0,0,0,0,127,255,32,242,102,5,147,255,0,4,86,235 - ,1,59,250,16,0,52,255,240,241,254,223,32,0,48,255,6,0,0,0,0,0,52,255,4,0,0,55 - ,255,0,52,255,240,240,240,240,22,0,0,52,255,240,240,240,202,0,48,255,6,0,138, - 241,248,0,52,255,240,240,240,243,255,0,0,0,52,255,4,0,0,0,0,0,0,0,52,255,4,0, - 52,255,220,235,100,0,0,0,0,52,255,4,0,0,0,0,52,255,6,209,182,52,255,0,52,255, - 4,169,120,52,255,0,49,255,5,0,0,54,255,0,52,255,240,240,231,169,31,0,49,255,5 - ,0,0,54,255,0,52,255,240,244,255,173,11,0,0,38,160,229,253,188,37,0,0,0,0,52, - 255,4,0,0,52,255,4,0,0,52,255,0,0,70,227,0,51,244,7,0,78,202,83,147,220,32, - 251,0,0,0,14,235,202,0,0,0,0,0,124,255,75,0,0,0,0,0,0,173,156,0,0,0,0,0,52, - 255,4,0,0,0,0,0,64,230,7,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,127,255,54,255,13,0,62,255,0,4,167,167,0,4,240,92,0,52,255,4,0,18,164, - 181,0,31,255,22,0,0,0,0,0,52,255,4,0,0,69,240,0,52,255,4,0,0,0,0,0,0,52,255,4 - ,0,0,0,0,32,255,20,0,0,52,255,0,52,255,4,0,0,52,255,0,0,0,52,255,4,0,0,0,0,0, - 0,0,52,255,3,0,52,255,33,86,243,35,0,0,0,52,255,4,0,0,0,0,52,255,4,127,89,52, - 255,0,52,255,4,52,230,58,255,0,38,255,15,0,0,64,244,0,52,255,4,0,0,0,0,0,38, - 255,15,0,0,64,247,0,52,255,4,1,87,251,67,0,0,0,0,0,32,176,207,0,0,0,0,52,255, - 4,0,0,51,255,4,0,0,52,255,0,0,6,242,42,121,174,0,0,39,234,136,91,168,112,218, - 0,0,0,153,180,211,98,0,0,0,0,52,255,4,0,0,0,0,0,80,228,15,0,0,0,0,0,52,255,4, - 0,0,0,0,0,0,200,101,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,255,37,243,102,5,147,255,0,11,241,250,248,248,253,173,0,52,255,4,0,0,58, - 249,0,0,228,84,0,0,0,0,0,52,255,4,0,0,126,186,0,52,255,4,0,0,0,0,0,0,52,255,4 - ,0,0,0,0,1,230,78,0,0,52,255,0,52,255,4,0,0,52,255,0,0,0,52,255,4,0,0,0,0,0,0 - ,0,61,250,0,0,52,255,4,0,170,199,3,0,0,52,255,4,0,0,0,0,52,255,4,0,0,52,255,0 - ,52,255,4,0,192,149,255,0,6,247,54,0,0,104,204,0,52,255,4,0,0,0,0,0,6,247,54, - 0,0,104,209,0,52,255,4,0,0,151,207,0,0,0,0,0,0,61,253,0,0,0,0,52,255,4,0,0,40 - ,255,8,0,0,56,248,0,0,0,171,112,192,97,0,0,4,250,199,35,111,196,178,0,0,66, - 241,28,64,236,21,0,0,0,52,255,4,0,0,0,0,14,228,75,0,0,0,0,0,0,52,255,4,0,0,0, - 0,0,0,80,218,2,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,238 - ,80,75,219,234,164,248,0,77,249,16,0,0,87,245,0,52,255,4,0,9,145,216,0,0,102, - 222,50,0,22,89,0,52,255,4,7,82,239,67,0,52,255,4,0,0,0,0,0,0,52,255,4,0,0,0,0 - ,0,109,215,40,0,81,255,0,52,255,4,0,0,52,255,0,0,0,52,255,4,0,0,0,43,112,13,3 - ,145,201,0,0,52,255,4,0,20,233,126,0,0,52,255,11,8,8,8,0,52,255,4,0,0,52,255, - 0,52,255,4,0,75,246,255,0,0,163,173,9,23,212,114,0,52,255,4,0,0,0,0,0,0,162, - 173,9,23,212,123,0,52,255,4,0,0,25,246,0,14,123,29,0,18,163,202,0,0,0,0,52, - 255,4,0,0,5,232,107,3,9,151,190,0,0,0,93,195,248,21,0,0,0,216,233,0,54,254, - 139,0,10,221,108,0,0,168,163,0,0,0,52,255,4,0,0,0,0,151,163,0,0,0,0,0,0,0,52, - 255,4,0,0,0,0,0,0,1,214,84,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,127,146,193,1,0,0,0,0,0,155,179,0,0,0,11,245,0,52,255,244,243,239,184,44 - ,0,0,0,99,214,244,237,140,0,52,255,244,240,191,69,0,0,52,255,244,244,244,244, - 99,0,0,52,255,4,0,0,0,0,0,0,109,219,243,223,116,0,52,255,4,0,0,52,255,0,0,244 - ,246,255,244,244,0,0,27,186,240,244,204,50,0,0,52,255,4,0,0,82,251,0,0,52,255 - ,255,255,255,255,0,52,255,4,0,0,52,255,0,52,255,4,0,1,213,255,0,0,16,171,241, - 237,143,3,0,52,255,4,0,0,0,0,0,0,16,170,241,254,187,6,0,52,255,4,0,0,0,138,0, - 9,171,229,246,240,177,33,0,0,0,0,52,255,4,0,0,0,51,197,244,241,177,28,0,0,0, - 18,252,198,0,0,0,0,176,179,0,5,247,99,0,144,199,2,0,0,27,243,0,0,0,52,255,4,0 - ,0,0,0,254,247,244,244,244,244,0,0,0,52,255,4,0,0,0,0,0,0,0,96,203,0,0,0,0,0, - 52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,16,216,165,31,2,24,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,87,237,57,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,5,226,68,0,0,0,0,52, - 255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,19,144,222,242,159,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,58,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,50,248,240,123,0,0,0,0,0,0,0,71,79,0,0,0,168, - 241,248,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,244,244,244,244,244,244,99,0,0,127,127,127,127,127,127,127,0,127,127, - 127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,9,124,20,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,140,0,127,0,0,112,174,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,4,221,0,127,0,0,0,159,98,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,0,0,0,0,0,0,0,0,0,0,0,2,166,243,244,102,0, - 0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,49,244,3,0,0,0,0,0,49,244,3,0,0,0,52 - ,255,4,0,0,0,0,11,244,246,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,158,239,209,0,0,0,0,52,255,4,0,0,11 - ,244,233,119,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,68,162,0,127,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,0,0,0,0,0, - 0,0,0,0,0,0,46,255,24,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,37,255,46,0,0,0,0,0 - ,52,255,4,0,0,0,0,96,244,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,149,81,0,127,0,0,0 - ,0,0,0,0,0,0,103,213,244,239,180,36,0,52,255,122,232,241,159,9,0,0,12,151,233 - ,244,202,40,0,0,26,183,244,223,133,255,0,0,13,156,236,241,165,12,0,19,244,246 - ,255,244,244,102,0,0,25,182,244,221,127,255,0,52,255,111,233,235,80,0,0,0,0, - 244,246,255,4,0,0,0,45,244,246,255,4,0,0,0,52,255,4,0,122,210,0,0,0,52,255,4, - 0,0,0,255,173,246,137,195,245,114,0,52,255,111,233,235,80,0,0,0,29,182,242, - 237,157,11,0,52,255,121,231,241,161,10,0,0,26,183,244,222,130,255,0,0,52,255, - 78,217,244,175,0,0,0,109,226,245,229,114,0,19,244,246,255,244,244,152,0,52, - 255,4,0,52,255,4,0,51,242,9,0,0,73,228,0,226,63,0,0,0,0,140,0,13,219,93,0,0, - 173,156,0,40,250,19,0,0,50,245,0,0,209,244,244,246,255,0,0,0,0,0,51,255,4,0,0 - ,0,0,0,52,255,4,0,0,0,0,52,255,3,0,0,0,0,0,0,0,0,0,0,0,0,5,8,0,1,219,10,0,127 - ,0,0,0,0,0,0,0,0,0,93,52,2,9,162,204,0,52,255,163,9,19,198,144,0,0,174,188,24 - ,0,53,43,0,0,193,157,7,20,200,255,0,0,173,186,16,11,179,152,0,0,0,52,255,4,0, - 0,0,0,189,167,10,19,199,255,0,52,255,121,2,133,219,0,0,0,0,0,52,255,4,0,0,0,0 - ,0,52,255,4,0,0,0,52,255,4,133,204,19,0,0,0,52,255,4,0,0,0,255,51,99,255,55, - 96,227,0,52,255,121,2,133,219,0,0,0,198,158,8,19,198,149,0,52,255,163,9,19, - 198,145,0,0,192,158,8,20,198,255,0,0,52,255,169,20,2,52,0,0,31,255,62,0,20,57 - ,0,0,0,52,255,4,0,0,0,52,255,4,0,52,255,4,0,0,216,84,0,0,162,139,0,166,118,0, - 0,0,0,195,0,0,49,235,36,104,211,9,0,0,200,106,0,0,142,163,0,0,0,0,0,149,171,0 - ,0,0,0,0,54,255,2,0,0,0,0,0,52,255,4,0,0,0,0,50,255,5,0,0,0,0,0,0,0,0,0,0,0, - 95,232,100,0,55,175,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,61,252,0,52,255,33,0,0, - 81,233,0,22,255,41,0,0,0,0,0,25,255,32,0,0,82,255,0,21,255,49,0,0,70,236,0,0, - 0,52,255,4,0,0,0,24,255,35,0,0,82,255,0,52,255,18,0,56,254,1,0,0,0,0,52,255,4 - ,0,0,0,0,0,52,255,4,0,0,0,52,255,146,227,15,0,0,0,0,52,255,4,0,0,0,255,8,56, - 255,8,56,253,0,52,255,18,0,56,254,1,0,27,255,32,0,0,81,234,0,52,255,33,0,0,81 - ,232,0,25,255,32,0,0,81,255,0,0,52,255,41,0,0,0,0,0,26,252,96,11,0,0,0,0,0,52 - ,255,4,0,0,0,52,255,4,0,52,255,4,0,0,125,173,0,8,242,48,0,106,173,0,192,118,4 - ,246,0,0,0,106,212,234,40,0,0,0,103,199,0,3,230,67,0,0,0,0,90,216,13,0,0,0,0, - 1,121,226,0,0,0,0,0,0,52,255,4,0,0,0,0,22,252,74,0,0,0,0,115,225,233,149,42, - 25,0,15,54,177,0,136,94,0,0,127,0,0,0,0,0,0,0,0,0,78,197,237,240,243,255,0,52 - ,255,6,0,0,55,254,0,47,255,7,0,0,0,0,0,48,255,6,0,0,55,255,0,47,255,240,240, - 240,241,247,0,0,0,52,255,4,0,0,0,48,255,7,0,0,55,255,0,52,255,4,0,52,255,4,0, - 0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,52,255,187,238,80,0,0,0,0,52,255,4,0, - 0,0,255,4,52,255,4,52,255,0,55,255,4,0,52,255,4,0,48,255,6,0,0,55,254,0,52, - 255,6,0,0,55,254,0,48,255,6,0,0,55,255,0,0,52,255,6,0,0,0,0,0,0,84,186,239, - 208,75,0,0,0,52,255,4,0,0,0,52,255,4,0,52,255,4,0,0,35,246,13,84,213,0,0,46, - 228,16,202,187,49,226,0,0,0,13,239,176,0,0,0,0,15,246,36,70,225,1,0,0,0,43, - 233,43,0,0,0,0,33,247,247,73,0,0,0,0,0,0,52,255,4,0,0,0,0,0,112,254,237,0,0,0 - ,139,14,17,117,219,229,0,0,1,219,8,211,18,0,0,127,0,0,0,0,0,0,0,0,24,251,86,5 - ,0,65,255,0,52,255,32,0,0,80,232,0,22,255,41,0,0,0,0,0,25,255,32,0,0,81,255,0 - ,22,255,21,0,0,0,0,0,0,0,52,255,4,0,0,0,25,255,34,0,0,81,255,0,52,255,4,0,52, - 255,4,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,52,255,8,84,237,29,0,0,0,51, - 255,5,0,0,0,255,4,52,255,4,52,255,0,56,255,4,0,52,255,4,0,27,255,32,0,0,81, - 234,0,52,255,32,0,0,80,233,0,26,255,32,0,0,81,255,0,0,52,255,4,0,0,0,0,0,0,0, - 0,4,126,237,0,0,0,51,255,4,0,0,0,48,255,8,0,66,255,4,0,0,0,199,94,173,122,0,0 - ,2,239,110,116,189,116,166,0,0,0,166,166,222,90,0,0,0,0,166,128,162,131,0,0,0 - ,13,216,90,0,0,0,0,0,0,3,137,210,0,0,0,0,0,0,52,255,4,0,0,0,0,14,244,89,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,154,117,188,0,0,0,127,0,0,0,0,0,0,0,0,33,255,68,0,26,189 - ,255,0,52,255,160,8,17,195,143,0,0,177,185,23,0,50,42,0,0,194,158,7,19,198, - 255,0,0,176,162,17,0,32,76,0,0,0,52,255,4,0,0,0,0,191,164,10,17,195,255,0,52, - 255,4,0,52,255,4,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,52,255,4,0,156,194 - ,0,0,0,24,254,67,0,0,0,255,4,52,255,4,52,255,0,56,255,4,0,52,255,4,0,0,200, - 158,7,19,198,151,0,52,255,160,8,17,195,146,0,0,194,158,7,19,198,255,0,0,52, - 255,4,0,0,0,0,0,31,72,8,2,124,230,0,0,0,30,255,51,0,0,0,15,251,62,0,147,255,4 - ,0,0,0,108,195,246,32,0,0,0,182,228,42,120,228,106,0,0,103,217,11,55,238,39,0 - ,0,0,70,222,242,36,0,0,0,172,148,0,0,0,0,0,0,0,0,57,254,1,0,0,0,0,0,52,255,4, - 0,0,0,0,49,255,8,0,0,0,0,0,0,0,0,0,0,0,0,0,78,244,107,0,0,0,127,0,0,0,0,0,0,0 - ,0,0,114,231,243,204,108,255,0,52,255,120,232,240,159,9,0,0,14,153,234,244, - 206,41,0,0,28,184,244,223,132,255,0,0,14,155,234,244,218,111,0,0,0,52,255,4,0 - ,0,0,0,27,184,245,221,123,255,0,52,255,4,0,52,255,4,0,0,118,244,246,255,244, - 244,0,0,0,0,52,255,4,0,0,0,52,255,4,0,11,217,0,0,0,0,121,240,244,114,0,255,4, - 52,255,4,52,255,0,56,255,4,0,52,255,4,0,0,31,184,243,238,160,12,0,52,255,120, - 232,241,160,10,0,0,28,185,244,223,130,255,0,0,52,255,4,0,0,0,0,0,35,199,242, - 246,204,61,0,0,0,0,141,236,229,142,0,0,120,234,191,137,255,4,0,0,0,21,251,197 - ,0,0,0,0,122,224,0,45,255,46,0,48,241,50,0,0,118,210,0,0,0,2,227,198,0,0,0,0, - 255,246,244,244,244,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,52,255,4,0, - 0,0,0,0,0,0,0,0,0,0,0,0,10,245,27,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,72,240,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,56,254,1,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52 - ,255,4,0,0,0,0,0,0,0,0,0,0,52,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 199,105,0,0,0,0,0,0,0,0,0,0,0,0,0,0,50,255,5,0,0,0,0,0,52,255,4,0,0,0,0,53, - 255,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,6,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,53,55,2,15,182,162,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,121,215,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,52,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,64,244,16,0,0,0,0,0,0,0,0,0,0,0,0,0,0,25,255,56,0,0,0,0,0,52,255,4,0,0 - ,0,0,106,232,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,75,220,246,237,162,16,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 194,246,227,68,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,52,255,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,203,237,92,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,133,229,206, - 0,0,0,0,52,255,4,0,0,11,240,221,96,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,187,58,108,143,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,102,10,58,54,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,97,59,0,0,0,0,0,0,0,0,0,0,0,0,0,33,222,208,8,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,60,194,183,6,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,48,240,52,240,3,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,58,199,211,11,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,184,184,143,119,77,39,156,0, - 0,0,73,164,22,196,26,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,42, - 179,3,188,30,0,0,0,0,0,0,0,0,0,0,127,0,4,134,230,245,210,44,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,57,219,243,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52, - 255,4,0,0,0,0,0,52,255,4,0,0,0,0,4,195,31,94,137,0,0,109,231,221,73,0,0,0,0,0 - ,47,189,243,241,204,73,0,0,0,0,0,0,0,0,0,0,26,175,241,247,255,244,0,0,0,0,0,0 - ,0,0,0,0,244,244,244,244,249,254,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,111, - 129,0,0,0,0,0,0,52,255,4,0,0,0,0,111,178,0,111,129,0,0,52,255,4,52,255,4,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,156,224,40,191,0,0,0,196,0, - 196,159,147,211,0,0,0,0,125,231,62,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,143,189,126,0,0,0,171,161,0,0,1,208,134,0,127,0,137,197,27,0,51 - ,39,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,218,103,1,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,254,51,101 - ,235,0,0,0,0,8,233,119,7,3,56,63,0,0,0,0,0,0,0,0,0,0,181,177,20,52,255,4,0,0, - 0,0,0,0,0,0,0,0,0,0,0,1,192,148,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,206, - 69,0,0,0,0,0,0,62,241,1,0,0,0,0,206,94,0,206,69,0,0,62,241,1,66,241,1,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,174,39,188,126,0,0,0,196,0,196 - ,55,118,196,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,15,125,8,0,0,0,29,241,39,0,85,240,17,0,127,8,244,57,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,31,249,5,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,118, - 244,246,255,244,244,72,0,118,244,246,255,244,244,72,0,0,0,0,0,0,0,0,0,254,50, - 100,234,1,57,97,0,46,255,15,0,0,0,0,0,0,0,0,0,31,0,0,0,10,252,51,0,52,255,4,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,101,223,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,35, - 255,14,0,0,0,0,0,0,118,157,0,0,0,0,35,255,18,35,255,14,0,0,120,157,0,143,157, - 0,0,0,0,84,234,231,76,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 196,0,196,0,0,196,0,0,0,109,226,245,229,114,0,0,0,0,30,0,0,0,0,0,103,239,220, - 122,231,236,0,0,0,0,0,0,0,0,0,0,209,244,244,246,255,0,0,0,120,167,2,213,127,0 - ,0,127,240,255,241,240,236,18,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,74, - 210,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0 - ,0,0,0,0,0,0,0,0,0,111,234,255,210,148,92,14,0,10,232,176,72,17,0,0,0,0,0,0, - 55,219,0,0,0,40,255,14,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,25,238,68,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,178,63,0,0,0,0,52,255,4, - 52,255,4,0,0,181,63,0,225,63,0,0,0,0,234,255,255,232,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,31,255,62,0,20,57,0,0,0,0,218, - 54,0,0,0,5,243,62,113,255,57,106,0,0,0,0,0,0,0,0,0,0,0,0,0,149,171,0,0,0,6, - 214,135,237,14,0,0,127,51,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 22,240,247,250,240,150,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0 - ,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,129,149,89,13,0,0,0,0,0,33,152,222,253,188, - 37,0,0,0,85,217,46,0,0,0,49,255,6,0,52,255,240,0,0,0,0,0,0,0,0,0,0,0,0,173, - 156,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,234,255,255,232,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,26,252,96,11,0,0,0,0,0,0,46,217,85, - 0,0,39,255,11,62,255,6,54,0,0,0,0,0,0,0,0,0,0,0,0,90,216,13,0,0,0,0,68,255, - 121,0,0,0,127,240,255,240,240,50,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 156,126,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4 - ,0,0,0,0,0,0,0,0,0,0,0,113,231,221,73,73,223,225,0,0,0,0,0,27,170,207,0,0,0, - 229,102,0,0,0,0,40,255,14,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,80,228,15,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,84,235,233,79,0,0,244,244,244,244,244,244,244,0,244,244, - 244,244,244,244,244,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,84,186,239,208,75,0 - ,0,0,0,0,103,229,0,0,50,255,5,53,255,240,241,0,3,0,0,0,0,0,0,0,0,0,43,233,43, - 0,0,0,0,0,0,252,60,0,0,0,127,9,247,62,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,200,85,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,116, - 240,243,255,240,240,71,0,0,0,0,0,0,0,0,0,254,51,102,235,229,51,101,0,0,0,0,0, - 0,61,253,0,0,0,29,206,115,0,0,0,10,252,51,0,52,255,4,0,0,0,0,0,0,0,0,0,0,14, - 228,75,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4,126,237,0,0,0,0,116,206,29,0,0 - ,39,255,11,60,255,8,0,0,0,0,0,0,0,0,0,0,0,13,216,90,0,0,0,0,0,0,0,252,60,0,0, - 0,127,0,146,201,26,0,50,39,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,1,243,45, - 0,0,0,0,52,255,4,52,255,4,0,44,220,3,44,220,3,44,0,3,0,52,255,4,0,0,0,0,0,52, - 255,4,0,0,0,0,0,0,0,0,0,0,0,254,47,99,235,230,47,97,0,15,135,41,5,30,171,202, - 0,0,0,0,12,180,0,0,0,0,181,177,19,52,255,4,0,0,0,0,0,0,0,0,0,0,151,163,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,31,72,8,2,124,230,0,0,0,0,179,12,0,0,0,6,244,62, - 114,255,80,0,0,1,0,0,0,0,0,0,0,0,172,148,0,0,0,0,0,0,0,0,252,60,0,0,0,127,0,6 - ,140,231,245,213,44,0,0,0,0,0,0,0,0,0,0,0,62,241,1,0,0,0,0,0,33,253,7,0,0,0,0 - ,62,241,1,66,241,1,0,52,255,4,52,255,4,52,0,4,0,52,255,4,0,0,0,0,0,52,255,4,0 - ,0,0,0,0,0,0,0,0,0,0,116,239,229,79,79,231,233,0,9,166,229,252,240,177,33,0,0 - ,0,0,0,3,0,0,0,0,26,177,242,247,255,244,0,0,0,0,0,0,0,0,0,0,254,247,244,244, - 244,244,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,35,199,242,246,204,61,0,0,0,0,2,0,0,0,0,0, - 105,240,221,111,222,244,0,1,0,0,0,0,0,0,0,0,255,246,244,244,244,0,0,0,0,0,252 - ,60,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,120,157,0,0,0,0,0,0,85,212, - 0,0,0,0,0,120,157,0,143,157,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255 - ,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,181,63,0,0,0,0,30,11,195,131, - 0,0,0,0,0,181,63,0,225,63,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,227,245,177,12,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127, - 127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0 - ,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,58,98,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2, - 8,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,20,221,50,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,103,185,255,4,0,0,0,0,106,186,255,4,0,0 - ,0,0,0,144,235,229,126,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0, - 0,0,0,0,49,244,3,0,0,0,0,0,0,0,52,255,4,0,0,0,0,86,224,245,206,0,0,0,0,0,0,0, - 0,0,215,116,0,0,0,164,172,0,0,0,0,52,255,4,0,0,0,110,227,245,223,102,0,0,0,49 - ,244,53,244,3,0,0,0,0,0,0,0,0,0,0,0,0,122,237,237,102,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,244,244,244,175,0,0,0,0,116,239,227,77,0,0,0 - ,0,0,0,0,0,0,0,0,0,116,235,233,108,0,0,0,0,165,239,235,132,0,0,0,0,0,173,88,0 - ,0,0,0,0,0,0,0,0,0,0,0,40,184,245,255,246,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,101,185,255,4,0,0,0,0,77,219,247,201,45,0,0,0,0,0,0,0,0,0,0,52,255,4,0 - ,0,0,0,0,52,255,4,0,0,0,0,0,17,0,101,238,0,0,0,0,0,49,244,3,0,0,0,0,0,0,0,0,0 - ,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,11,245,105,1, - 43,0,0,0,0,0,0,0,0,0,62,241,25,0,61,236,23,0,0,0,0,52,255,4,0,0,33,255,60,0, - 26,51,0,0,0,0,0,0,0,0,0,0,0,53,181,236,230,161,31,0,0,0,33,1,102,238,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,53,181,236,230,161,31,0,0,0,0,0,0,0,0,0,0,30, - 254,51,99,236,0,0,0,0,0,0,0,0,0,0,0,0,42,3,96,248,0,0,0,0,15,2,107,236,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,5,226,255,255,255,56,255,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,14,244,93,2,142,209,0,0,0,0,0,0,0,0,0,0,52, - 255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,222,242,72,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,14,161,243,255,236,0,0,0,47, - 255,11,0,0,0,0,82,25,0,0,44,64,0,0,155,165,3,210,93,0,0,0,0,0,52,255,4,0,0,15 - ,230,104,0,0,0,0,0,0,0,0,0,0,0,0,0,67,255,255,253,224,140,233,0,0,3,160,237, - 243,255,3,0,0,0,0,31,0,0,31,0,0,0,0,0,0,0,0,0,67,255,255,251,251,255,233,0,0, - 0,0,0,0,0,0,0,0,30,254,50,100,234,0,0,0,0,0,52,255,4,0,0,0,0,0,0,113,173,0,0, - 0,0,0,244,239,67,0,0,0,0,0,0,0,0,0,0,52,255,4,0,52,255,4,0,45,255,255,255,255 - ,56,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,47,255,12,0,61 - ,253,0,0,30,0,0,30,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,108,224, - 0,0,0,0,0,44,255,3,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0 - ,0,0,0,174,182,65,255,13,0,0,0,52,255,4,0,0,0,0,79,222,204,189,221,47,0,123, - 185,244,166,235,176,90,0,0,0,0,52,255,4,0,0,0,100,237,188,46,0,0,0,0,0,0,0,0, - 0,0,0,222,255,110,2,21,6,156,0,0,42,255,40,100,255,4,0,0,0,55,219,0,55,218,0, - 0,0,0,0,0,0,0,0,222,161,255,4,86,247,157,0,0,0,0,0,0,0,0,0,0,0,114,233,220,71 - ,0,0,0,0,0,52,255,4,0,0,0,0,0,65,191,12,0,0,0,0,0,0,107,224,0,0,0,0,0,0,0,0,0 - ,0,52,255,4,0,52,255,4,0,19,250,255,255,255,56,255,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,52,255,4,0,0,0,12,243,94,4,144,206,0,0,218,54,0,219,54,0,0,81, - 176,212,160,0,28,70,0,81,176,212,168,31,8,78,0,0,35,1,114,240,0,0,0,0,0,63, - 242,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,22,255, - 48,52,255,4,0,0,172,243,255,240,240,37,0,0,17,230,49,97,201,0,0,0,0,101,255, - 50,0,0,0,0,0,0,52,255,4,0,0,21,249,20,108,240,103,0,0,0,0,0,0,0,0,0,0,255,255 - ,14,0,0,0,67,0,0,5,182,234,147,248,3,0,0,85,219,47,85,212,43,0,186,244,244, - 244,244,245,252,0,255,71,255,244,232,84,67,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,240,240,243,255,240,240,0,0,0,56,182,13,0,0,0,0,0,42,1,116,239,0,0,0,0,0,0, - 0,0,0,0,52,255,4,0,52,255,4,0,0,105,248,255,255,56,255,0,0,0,44,220,3,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,81,176,212,168,49,0,0,0,72,213,242,195,40,0,0,44,213,85,48 - ,220,85,0,0,2,56,132,204,195,104,0,0,0,12,86,169,231,170,0,0,180,240,219,87, - 42,91,0,0,15,210,132,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4 - ,0,0,0,0,48,255,11,52,255,4,0,0,0,52,255,4,0,0,0,0,16,229,53,101,198,0,0,168, - 240,243,255,240,240,123,0,0,0,0,0,0,0,0,0,30,254,67,0,93,244,0,0,0,0,0,0,0,0, - 0,0,255,222,111,4,17,5,67,0,0,0,0,0,0,0,0,0,0,229,109,0,229,89,0,0,0,0,0,0,0, - 52,255,0,255,71,255,9,178,76,67,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52, - 255,4,0,0,0,0,173,242,240,240,11,0,0,0,200,241,217,82,0,0,0,0,0,0,0,0,0,0,52, - 255,4,0,52,255,4,0,0,0,18,107,255,56,255,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,89,229,0,109,229,0,150,216,167,92,18,0,0 - ,0,92,177,230,162,79,8,0,0,21,98,143,151,148,110,60,0,0,186,168,2,0,0,0,0,0,0 - ,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,21,255,43,52,255,4,0,0, - 0,52,255,4,0,0,0,0,76,223,204,189,222,49,0,0,0,52,255,4,0,0,0,0,0,0,52,255,4, - 0,0,0,117,241,119,83,210,0,0,0,0,0,0,0,0,0,0,224,153,197,240,202,13,157,0,0,3 - ,240,240,240,240,11,0,0,29,207,117,29,205,112,0,0,0,0,0,0,50,248,0,224,156, - 228,3,22,188,166,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,11,0,62,255,4,0,0,0,0,52,255, - 56,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,228,240,240,240, - 172,0,0,113,205,29,118,207,29,0,49,4,0,0,146,255,4,0,130,71,5,87,225,232,129, - 0,21,53,7,0,2,174,255,0,40,255,20,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0 - ,0,0,0,52,255,4,0,0,0,0,0,175,172,59,255,8,0,0,0,52,255,4,0,0,0,0,85,25,0,0, - 46,62,0,0,0,52,255,4,0,0,0,0,0,0,52,255,4,0,0,0,0,43,182,246,51,0,0,0,0,0,0,0 - ,0,0,0,68,240,97,7,14,129,232,0,0,0,0,0,0,0,0,0,0,0,12,180,0,12,180,0,0,0,0,0 - ,0,0,0,0,68,240,97,7,14,129,232,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,99,3,157,255,18,0 - ,0,0,0,52,255,56,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,179,12,0,179,12,0,0,0,0,0,44,141,255,4,0,0,0,0,28,5,88,239,0,0,0, - 0,0,126,102,255,0,23,252,95,8,66,99,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0 - ,0,52,255,4,0,0,0,0,0,13,156,235,255,231,0,0,244,246,255,244,244,244,0,0,0,0, - 0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,127,213,0,0,0,0,0,0,0 - ,0,0,0,0,53,184,236,232,164,31,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,3,0,0,0,0,0,0,0, - 0,0,0,53,184,236,232,164,31,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,244,244,244, - 244,244,244,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,163,243, - 148,208,191,0,0,0,0,52,255,56,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,136,53,255,4,0,0,0,0,0,9,168,67, - 0,0,0,0,84,94,52,255,0,0,101,231,249,202,68,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,52,255,4,0,0,1,72,10,3,120,233,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,52,255,56,255,0,0,0,0,0,0,0,0,0,0,0,0 - ,33,65,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,240,243, - 255,176,0,0,0,0,28,162,38,0,0,0,0,0,174,240,243,255,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,2,188,234,241,201,61,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,23,116,25, - 116,0,0,0,0,0,0,0,0,0,0,0,0,2,214,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,143,245,244,244,0,0,0,0,0,0,52,255,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,116,199,178,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,0,0,51,90,0,0,0, - 0,0,0,0,6,119,17,0,0,0,0,4,117,84,0,0,0,0,2,196,190,20,191,0,0,0,0,0,0,0,0,0, - 0,0,0,145,237,102,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,99,44,0,0,0,0,0,0 - ,0,48,95,0,0,0,0,0,41,128,38,0,0,0,0,0,0,0,0,0,0,0,0,0,97,35,0,0,0,0,0,0,0,57 - ,85,0,0,0,0,0,46,127,26,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,18,217,181,17 - ,203,0,0,0,0,74,213,6,0,0,0,0,0,0,27,229,40,0,0,0,0,29,222,209,8,0,0,0,2,195, - 200,27,193,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,101,212,8, - 0,0,0,0,0,0,29,234,61,0,0,0,0,42,226,218,16,0,0,0,0,0,0,0,0,0,0,0,0,0,143,135 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,3,172,83,0,0,0,0,0,0,158,105,0 - ,0,0,0,0,154,91,157,84,0,0,0,34,144,63,189,101,0,0,0,48,240,52,240,3,0,0,0,32 - ,255,96,239,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,39,201,20,0,0,0,0,0,25, - 203,35,0,0,0,0,24,188,62,188,22,0,0,0,48,240,52,240,3,0,0,0,0,42,195,12,0,0,0 - ,0,0,29,198,25,0,0,0,0,22,184,66,185,14,0,0,0,48,240,52,240,3,0,0,0,0,0,0,0,0 - ,0,0,0,74,110,77,192,109,0,0,0,0,0,139,130,0,0,0,0,0,0,177,92,0,0,0,0,1,183, - 63,107,141,0,0,0,37,141,60,187,123,0,0,0,48,240,3,48,240,3,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,151,143,0,0,0,0,0,1,189,104,0,0,0,0,8,200,53,93,169,0,0 - ,0,48,240,3,48,240,3,0,0,0,42,192,5,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,20,246,100,217,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,9,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,20,252,200, - 0,0,0,0,0,20,252,200,0,0,0,0,0,20,252,200,0,0,0,0,0,20,252,200,0,0,0,0,0,80, - 255,32,0,0,0,0,0,62,238,30,0,0,0,0,0,196,247,255,244,244,0,0,0,96,213,244,234 - ,137,0,52,255,244,244,244,244,68,0,52,255,244,244,244,244,68,0,52,255,244,244 - ,244,244,68,0,52,255,244,244,244,236,0,0,0,244,246,255,244,244,0,0,0,244,246, - 255,244,244,0,0,0,244,246,255,244,244,0,0,0,244,246,255,244,244,0,0,52,255, - 244,239,190,68,0,0,52,255,166,0,0,52,255,0,0,15,168,241,236,141,2,0,0,15,168, - 241,236,141,2,0,0,15,168,241,236,141,2,0,0,15,168,241,236,141,2,0,0,15,168, - 241,236,141,2,0,0,0,0,0,0,0,0,0,0,13,166,240,239,148,152,0,52,255,4,0,0,52, - 255,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,220, - 112,0,0,0,161,179,0,52,255,4,0,0,0,0,0,0,100,226,247,212,58,0,0,127,0,0,98, - 207,251,26,0,0,0,0,98,207,251,26,0,0,0,0,98,207,251,26,0,0,0,0,98,207,251,26, - 0,0,0,0,160,212,112,0,0,0,0,0,91,210,42,0,0,0,0,17,242,58,255,4,0,0,0,100,223 - ,50,0,22,89,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255 - ,4,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52, - 255,4,0,0,0,52,255,4,7,81,238,66,0,52,255,242,30,0,52,255,0,0,160,175,10,24, - 213,112,0,0,160,175,10,24,213,112,0,0,160,175,10,24,213,112,0,0,160,175,10,24 - ,213,112,0,0,160,175,10,24,213,112,0,0,0,0,0,0,0,0,0,0,158,169,7,42,243,176,0 - ,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,52,255,4,0 - ,0,52,255,0,74,238,18,0,52,245,33,0,52,255,4,0,0,0,0,0,20,251,87,1,120,216,0, - 0,127,0,0,179,121,200,105,0,0,0,0,179,121,200,105,0,0,0,0,179,121,200,105,0,0 - ,0,0,179,121,200,105,0,0,0,3,236,97,192,0,0,0,0,0,185,107,136,0,0,0,0,86,189, - 52,255,4,0,0,0,227,84,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255, - 4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52, - 255,4,0,0,0,0,0,52,255,4,0,0,0,52,255,4,0,0,125,186,0,52,255,150,143,0,52,255 - ,0,6,246,54,0,0,105,204,0,6,246,54,0,0,105,204,0,6,246,54,0,0,105,204,0,6,246 - ,54,0,0,105,204,0,6,246,54,0,0,105,204,0,0,123,22,0,0,66,81,0,5,246,57,0,52, - 245,208,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0, - 52,255,4,0,0,52,255,0,0,176,146,0,194,127,0,0,52,255,240,240,233,177,38,0,50, - 255,8,69,180,160,0,0,127,0,12,248,51,130,186,0,0,0,12,248,51,130,186,0,0,0,12 - ,248,51,130,186,0,0,0,12,248,51,130,186,0,0,0,64,222,16,250,19,0,0,0,25,230, - 26,227,2,0,0,0,159,125,52,255,4,0,0,31,255,21,0,0,0,0,0,52,255,4,0,0,0,0,0,52 - ,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0 - ,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,52,255,4,0,0,69,240,0, - 52,255,37,239,16,52,255,0,38,255,15,0,0,64,244,0,38,255,15,0,0,64,244,0,38, - 255,15,0,0,64,244,0,38,255,15,0,0,64,244,0,38,255,15,0,0,64,244,0,0,130,214, - 25,73,235,64,0,38,255,20,12,210,108,246,0,52,255,4,0,0,52,255,0,52,255,4,0,0, - 52,255,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,0,31,241,124,221,8,0,0, - 52,255,4,0,18,164,208,0,52,255,30,251,36,0,0,0,127,0,86,235,1,59,250,16,0,0, - 86,235,1,59,250,16,0,0,86,235,1,59,250,16,0,0,86,235,1,59,250,16,0,0,144,164, - 0,213,96,0,0,0,117,182,0,230,68,0,0,1,231,61,52,255,240,240,0,48,255,6,0,0,0, - 0,0,52,255,240,240,240,240,22,0,52,255,240,240,240,240,22,0,52,255,240,240, - 240,240,22,0,52,255,240,240,240,187,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0 - ,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,239,255,240,198,0,55,255,0,52,255,4, - 169,120,52,255,0,49,255,5,0,0,54,255,0,49,255,5,0,0,54,255,0,49,255,5,0,0,54, - 255,0,49,255,5,0,0,54,255,0,49,255,5,0,0,54,255,0,0,0,124,225,235,60,0,0,49, - 255,6,160,101,53,255,0,52,255,4,0,0,52,255,0,52,255,4,0,0,52,255,0,52,255,4,0 - ,0,52,255,0,52,255,4,0,0,52,255,0,0,0,124,255,75,0,0,0,52,255,4,0,0,59,253,0, - 52,255,26,245,109,2,0,0,127,0,167,167,0,4,240,92,0,0,167,167,0,4,240,92,0,0, - 167,167,0,4,240,92,0,0,167,167,0,4,240,92,0,0,223,105,0,154,176,0,0,0,210,130 - ,0,179,162,0,0,49,246,6,52,255,4,0,0,31,255,23,0,0,0,0,0,52,255,4,0,0,0,0,0, - 52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,52,255,4,0,0,0,0 - ,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,52,255,4,0,0,69,240,0 - ,52,255,4,52,230,58,255,0,38,255,15,0,0,64,244,0,38,255,15,0,0,64,244,0,38, - 255,15,0,0,64,244,0,38,255,15,0,0,64,244,0,38,255,15,0,0,64,244,0,0,0,80,241, - 224,31,0,0,40,255,92,164,0,63,245,0,51,255,4,0,0,52,255,0,51,255,4,0,0,52,255 - ,0,51,255,4,0,0,52,255,0,51,255,4,0,0,52,255,0,0,0,52,255,4,0,0,0,52,255,4,0, - 17,161,208,0,52,255,4,47,187,209,46,0,127,7,241,250,248,248,253,173,0,7,241, - 250,248,248,253,173,0,7,241,250,248,248,253,173,0,7,241,250,248,248,253,173,0 - ,48,255,249,248,250,246,10,0,49,255,249,248,250,244,11,0,122,251,240,243,255, - 4,0,0,0,228,88,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0 - ,0,0,52,255,4,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0, - 0,0,0,0,52,255,4,0,0,0,52,255,4,0,0,126,186,0,52,255,4,0,192,149,255,0,6,247, - 54,0,0,104,204,0,6,247,54,0,0,104,204,0,6,247,54,0,0,104,204,0,6,247,54,0,0, - 104,204,0,6,247,54,0,0,104,204,0,0,87,233,51,113,224,34,0,10,253,203,12,0,100 - ,203,0,40,255,9,0,0,57,248,0,40,255,9,0,0,57,248,0,40,255,9,0,0,57,248,0,40, - 255,8,0,0,56,248,0,0,0,52,255,4,0,0,0,52,255,240,240,234,178,38,0,52,255,4,0, - 0,116,220,0,127,74,249,16,0,0,87,245,0,74,249,16,0,0,87,245,0,74,249,16,0,0, - 87,245,0,74,249,16,0,0,87,245,0,128,211,0,0,15,248,80,0,143,187,0,0,5,234,94, - 0,195,109,0,52,255,4,0,0,0,102,228,62,5,34,99,0,52,255,4,0,0,0,0,0,52,255,4,0 - ,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255, - 4,0,0,0,0,8,58,255,11,8,0,0,0,0,52,255,4,0,0,0,52,255,4,7,82,239,67,0,52,255, - 4,0,75,246,255,0,0,163,173,9,23,212,114,0,0,163,173,9,23,212,114,0,0,163,173, - 9,23,212,114,0,0,163,173,9,23,212,114,0,0,163,173,9,23,212,114,0,0,166,49,0,0 - ,108,107,0,13,237,190,15,18,206,111,0,5,232,117,10,19,158,190,0,5,232,117,10, - 19,158,190,0,5,232,117,10,19,158,190,0,5,232,107,3,9,151,190,0,0,0,52,255,4,0 - ,0,0,52,255,4,0,0,0,0,0,52,255,34,8,2,118,240,0,127,155,179,0,0,0,11,245,0, - 155,179,0,0,0,11,245,0,155,179,0,0,0,11,245,0,155,179,0,0,0,11,245,0,208,126, - 0,0,0,176,160,0,232,94,0,0,0,144,188,0,251,31,0,52,255,244,244,0,0,0,99,214, - 255,240,135,0,52,255,244,244,244,244,99,0,52,255,244,244,244,244,99,0,52,255, - 244,244,244,244,99,0,52,255,244,244,244,244,22,0,0,244,246,255,244,244,0,0,0, - 244,246,255,244,244,0,0,0,255,255,255,255,255,0,0,0,244,246,255,244,244,0,0, - 52,255,244,240,191,69,0,0,52,255,4,0,1,213,255,0,0,16,171,241,237,143,3,0,0, - 16,171,241,237,143,3,0,0,16,171,241,237,143,3,0,0,16,171,241,237,143,3,0,0,16 - ,171,241,237,143,3,0,0,0,0,0,0,0,0,0,157,99,185,245,234,140,2,0,0,51,197,249, - 244,177,28,0,0,51,197,249,244,177,28,0,0,51,197,249,244,177,28,0,0,51,197,244 - ,241,177,28,0,0,0,52,255,4,0,0,0,52,255,4,0,0,0,0,0,52,255,116,240,246,211,74 - ,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,107,120,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,17,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,13,69,194,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,233,241,107,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,127,127,127,127,127,127,0,127,127,127,127,127 - ,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,104,226,228,110,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,127,0,8,195,125,0,0,0,0,0,0,0,0,98,212,15,0,0 - ,0,2,197,213,8,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,241,45,96,248,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,157,139,0,0,0,0,0,0,0,0,154,142,0,0,0,0,10, - 199,192,5,0,0,0,0,0,0,0,0,0,0,0,0,111,190,2,0,0,0,0,0,0,0,50,225,29,0,0,0,0, - 130,241,30,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,11,187,114,0 - ,0,0,0,0,0,0,1,161,149,1,0,0,0,24,211,193,6,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,68,217,9,0,0,0,0,0,0,0,44,223,23,0,0,0,0 - ,88,244,31,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,91,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,127,0,0,18,213,67,0,0,0,0,0,0,46,220,30,0,0,0,0,115,148,123,138,0,0,0, - 14,196,237,203,189,27,0,0,0,240,3,49,244,3,0,0,0,105,226,228,110,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,155,105,0,0,0,0,0,0,121,140,0,0,0,0,0,158,74,90 - ,145,0,0,0,0,240,3,49,244,3,0,0,0,0,158,122,0,0,0,0,0,0,12,210,56,0,0,0,0,38, - 200,77,175,0,0,0,49,244,53,244,3,0,0,0,3,138,202,114,121,12,0,0,86,232,214, - 194,37,0,0,0,0,7,172,97,0,0,0,0,0,0,144,133,0,0,0,0,6,185,54,92,153,0,0,0,25, - 206,234,199,174,3,0,0,49,244,3,49,244,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,123,138,0,0,0,0,0,0,2,195,59,0,0,0,0,11,204,78,171,0,0,0,0,49,244,53,244,3,0 - ,0,0,0,0,51,205,26,0,0,52,255,4,0,0,0,0,0,0,49,244,53,244,3,0,0,127,0,0,0,32, - 105,0,0,0,0,0,0,91,46,0,0,0,0,2,113,7,1,111,7,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,6,117,7,0,0,0,0,0,57,72,0,0,0,0,0 - ,74,38,0,93,20,0,0,0,0,0,0,0,0,0,0,51,110,93,212,36,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,24,0,0,0,1,109,6,0,0,0,0,0,35,80,0,0,0,0,0,49,64,0, - 96,15,0,0,0,0,0,0,0,0,0,0,0,0,0,103,25,0,0,0,52,255,4,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,127,0,103,213,244,239,180,36,0,0,103,213,244,240,180,36,0,0,103,213,244, - 239,180,36,0,0,103,213,244,239,180,36,0,0,103,213,244,239,180,36,0,0,103,213, - 244,239,180,36,0,0,132,239,226,131,234,236,0,0,12,151,233,244,202,40,0,0,13, - 156,236,241,165,12,0,0,13,156,236,241,165,12,0,0,13,156,236,241,165,12,0,0,13 - ,156,235,241,165,12,0,0,0,244,246,255,4,0,0,0,0,244,246,255,4,0,0,0,0,244,246 - ,255,4,0,0,0,148,244,255,4,0,0,0,0,25,178,243,251,214,9,0,52,255,111,233,235, - 80,0,0,0,29,182,242,237,157,11,0,0,29,182,242,237,157,11,0,0,29,182,242,237, - 157,11,0,0,29,182,242,237,157,11,0,0,29,182,242,237,157,11,0,0,0,0,49,244,3,0 - ,0,0,29,181,242,238,160,192,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,52, - 255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,40,250,19,0,0,50,245,0,52,255,121, - 231,241,161,10,0,93,212,0,0,0,221,87,0,127,0,93,52,2,9,162,204,0,0,93,52,2,10 - ,165,204,0,0,93,52,2,9,162,204,0,0,93,52,2,9,162,204,0,0,93,52,2,9,162,204,0, - 0,93,52,2,9,159,204,0,0,48,4,120,255,57,104,0,0,174,188,24,0,53,43,0,0,173, - 187,16,11,178,153,0,0,173,187,16,11,178,153,0,0,173,186,16,11,179,152,0,0,173 - ,177,14,11,179,152,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0 - ,0,0,0,252,4,0,0,0,0,192,167,11,4,181,123,0,52,255,121,2,133,219,0,0,0,198, - 158,8,19,198,149,0,0,198,158,8,19,198,149,0,0,198,158,8,19,198,149,0,0,198, - 158,8,19,198,149,0,0,198,158,8,19,198,149,0,0,0,0,0,0,0,0,0,0,198,161,9,24, - 239,165,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0, - 52,255,4,0,52,255,4,0,0,200,106,0,0,142,163,0,52,255,163,9,19,198,145,0,11, - 244,36,0,48,244,10,0,127,0,0,0,0,0,61,252,0,0,0,0,0,0,62,252,0,0,0,0,0,0,61, - 252,0,0,0,0,0,0,61,252,0,0,0,0,0,0,61,252,0,0,0,0,0,0,57,252,0,0,0,0,55,255,6 - ,54,0,22,255,41,0,0,0,0,0,21,255,50,0,0,67,236,0,21,255,50,0,0,67,236,0,21, - 255,49,0,0,70,236,0,21,255,37,0,0,70,236,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4, - 0,0,0,0,0,52,255,4,0,0,0,0,0,252,4,0,0,0,25,255,35,0,0,86,217,0,52,255,18,0, - 56,254,1,0,27,255,32,0,0,81,234,0,27,255,32,0,0,81,234,0,27,255,32,0,0,81,234 - ,0,27,255,32,0,0,81,234,0,27,255,32,0,0,81,234,0,0,240,240,240,240,240,240,0, - 27,255,31,2,168,165,235,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255, - 4,0,52,255,4,0,52,255,4,0,52,255,4,0,0,103,199,0,3,230,67,0,52,255,33,0,0,81, - 232,0,0,162,117,0,130,165,0,0,127,0,78,197,237,240,243,255,0,0,71,189,224,224 - ,230,255,0,0,78,197,237,240,243,255,0,0,78,197,237,240,243,255,0,0,78,197,237 - ,240,243,255,0,0,78,197,237,240,243,255,0,0,125,231,244,255,240,241,0,50,255, - 7,0,0,0,0,0,47,255,225,224,224,227,239,0,47,255,225,224,224,227,239,0,47,255, - 240,240,240,241,247,0,47,255,240,240,240,241,247,0,0,0,0,52,255,4,0,0,0,0,0, - 52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,252,4,0,0,0,48,255,7,0,0,56,254,0,52, - 255,4,0,52,255,4,0,48,255,6,0,0,55,254,0,48,255,6,0,0,55,254,0,48,255,6,0,0, - 55,254,0,48,255,6,0,0,55,254,0,48,255,6,0,0,55,254,0,0,0,0,0,0,0,0,0,48,255,7 - ,152,111,54,255,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,52,255,4,0,52, - 255,4,0,52,255,4,0,52,255,4,0,0,15,246,36,70,225,1,0,52,255,6,0,0,55,254,0,0, - 68,197,0,212,76,0,0,127,24,251,95,6,0,62,255,0,23,250,82,2,0,65,255,0,24,251, - 86,5,0,65,255,0,24,251,86,5,0,65,255,0,24,251,86,5,0,65,255,0,24,251,86,5,0, - 65,255,0,32,255,57,53,255,8,0,0,22,255,41,0,0,0,0,0,22,255,23,0,0,0,0,0,22, - 255,23,0,0,0,0,0,22,255,21,0,0,0,0,0,22,255,21,0,0,0,0,0,0,0,0,52,255,4,0,0,0 - ,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,252,4,0,0,0,25,255,34,0,0,83,238,0 - ,52,255,4,0,52,255,4,0,27,255,32,0,0,81,234,0,27,255,32,0,0,81,234,0,27,255, - 32,0,0,81,234,0,27,255,32,0,0,81,234,0,27,255,32,0,0,81,234,0,0,0,0,48,240,3, - 0,0,27,255,165,129,0,81,234,0,48,255,8,0,66,255,4,0,48,255,8,0,66,255,4,0,48, - 255,8,0,66,255,4,0,48,255,8,0,66,255,4,0,0,0,166,128,162,131,0,0,52,255,32,0, - 0,80,233,0,0,2,226,62,238,5,0,0,127,33,255,38,0,4,170,255,0,33,255,69,0,26, - 189,255,0,33,255,68,0,26,189,255,0,33,255,68,0,26,189,255,0,33,255,68,0,26, - 189,255,0,33,255,68,0,26,189,255,0,38,255,39,95,255,76,1,0,0,177,185,23,0,50, - 42,0,0,176,165,17,0,32,76,0,0,176,165,17,0,32,76,0,0,176,162,17,0,32,76,0,0, - 176,162,17,0,29,79,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0,0,0,0,52,255,4,0,0 - ,0,0,0,252,4,0,0,0,0,194,163,8,21,202,156,0,52,255,4,0,52,255,4,0,0,200,158,7 - ,19,198,151,0,0,200,158,7,19,198,151,0,0,200,158,7,19,198,151,0,0,200,158,7, - 19,198,151,0,0,200,158,7,19,198,151,0,0,0,0,0,0,0,0,0,0,216,210,7,19,198,151, - 0,15,251,62,0,147,255,4,0,15,251,62,0,147,255,4,0,15,251,62,0,147,255,4,0,15, - 251,62,0,147,255,4,0,0,0,70,222,242,36,0,0,52,255,160,8,17,195,146,0,0,0,137, - 215,157,0,0,0,127,0,114,219,196,189,127,255,0,0,114,231,243,204,107,255,0,0, - 114,231,243,204,108,255,0,0,114,231,243,204,108,255,0,0,114,231,243,204,108, - 255,0,0,113,230,243,205,106,255,0,0,154,245,215,95,224,242,0,0,14,153,237,255 - ,207,42,0,0,14,155,234,244,218,111,0,0,14,155,234,244,218,111,0,0,14,155,234, - 244,218,111,0,0,14,153,233,244,220,120,0,0,118,244,246,255,244,244,0,0,108, - 224,230,255,224,224,0,0,108,224,230,255,224,224,0,22,244,244,255,244,244,34,0 - ,0,27,180,242,238,161,13,0,52,255,4,0,52,255,4,0,0,31,184,243,238,160,12,0,0, - 31,184,243,238,160,12,0,0,31,184,243,238,160,12,0,0,31,184,243,238,160,12,0,0 - ,31,184,243,238,160,12,0,0,0,0,0,0,0,0,0,95,164,178,242,238,160,12,0,0,120, - 234,191,137,255,4,0,0,120,234,191,137,255,4,0,0,120,234,191,137,255,4,0,0,120 - ,234,191,137,255,4,0,0,0,2,227,198,0,0,0,52,255,120,232,241,160,10,0,0,0,43, - 255,72,0,0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,187,14,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,40,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,199,105,0,0,0,52,255,4,0,0,0,0,0,0,0,18,232,4,0, - 0,0,127,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,10,1,167,67,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,64,244,16,0,0,0,52,255,4,0,0,0,0,0,0,0,132,148,0,0,0,0,127, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,242,213,19,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 - ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, - 0,0,0,0,0,203,237,92,0,0,0,0,52,255,4,0,0,0,0,0,11,243,209,25,0,0,0,0,0,127, - 127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127 - ,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127, - 0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127 - ,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0, - 127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127, - 127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127 - ,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127, - 127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127 - ,127,127,127,127,127,0,127,127,127,127,127,127,127,0,127,127,127,127,127,127, - 127,0,127,127,127,127,127,127,127,0 -}; - - -void TwGenerateDefaultFonts() -{ - g_DefaultSmallFont = TwGenerateFont(s_Font0, FONT0_BM_W, FONT0_BM_H); - assert(g_DefaultSmallFont && g_DefaultSmallFont->m_NbCharRead==224); - - g_DefaultNormalFont = TwGenerateFont(s_Font1, FONT1_BM_W, FONT1_BM_H); - assert(g_DefaultNormalFont && g_DefaultNormalFont->m_NbCharRead==224); - - g_DefaultNormalFontAA = TwGenerateFont(s_Font1AA, FONT1AA_BM_W, FONT1AA_BM_H); - assert(g_DefaultNormalFontAA && g_DefaultNormalFontAA->m_NbCharRead==224); - g_DefaultLargeFont = TwGenerateFont(s_Font2AA, FONT2AA_BM_W, FONT2AA_BM_H); - assert(g_DefaultLargeFont && g_DefaultLargeFont->m_NbCharRead==224); - g_DefaultFixed1Font = TwGenerateFont(s_FontFixed1, FONTFIXED1_BM_W, FONTFIXED1_BM_H); - assert(g_DefaultFixed1Font && g_DefaultFixed1Font->m_NbCharRead==224); -} - -// --------------------------------------------------------------------------- - -void TwDeleteDefaultFonts() -{ - delete g_DefaultSmallFont; - g_DefaultSmallFont = NULL; - delete g_DefaultNormalFont; - g_DefaultNormalFont = NULL; - delete g_DefaultNormalFontAA; - g_DefaultNormalFontAA = NULL; - delete g_DefaultLargeFont; - g_DefaultLargeFont = NULL; - delete g_DefaultFixed1Font; - g_DefaultFixed1Font = NULL; -} - -// --------------------------------------------------------------------------- diff --git a/btgui/OpenGLWindow/TwFonts.h b/btgui/OpenGLWindow/TwFonts.h deleted file mode 100644 index 801cf96a4..000000000 --- a/btgui/OpenGLWindow/TwFonts.h +++ /dev/null @@ -1,67 +0,0 @@ -// --------------------------------------------------------------------------- -// -// @file TwFonts.h -// @brief Bitmaps fonts -// @author Philippe Decaudin - http://www.antisphere.com -// @license This file is part of the AntTweakBar library. -// For conditions of distribution and use, see License.txt -// -// note: Private header -// -// --------------------------------------------------------------------------- - - -#if !defined ANT_TW_FONTS_INCLUDED -#define ANT_TW_FONTS_INCLUDED - -//#include - -/* -A source bitmap includes 224 characters starting from ascii char 32 (i.e. space) to ascii char 255: - - !"#$%&'()*+,-./0123456789:;<=>? -@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_ -`abcdefghijklmnopqrstuvwxyz{|}~ -€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ - ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ -ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞß -àáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ - -First column of a source bitmap is a delimiter with color=zero at the end of each line of characters. -Last row of a line of characters is a delimiter with color=zero at the last pixel of each character. - -*/ - - -struct CTexFont -{ - unsigned char * m_TexBytes; - int m_TexWidth; // power of 2 - int m_TexHeight; // power of 2 - float m_CharU0[256]; - float m_CharV0[256]; - float m_CharU1[256]; - float m_CharV1[256]; - int m_CharWidth[256]; - int m_CharHeight; - int m_NbCharRead; - - CTexFont(); - ~CTexFont(); -}; - - -CTexFont *TwGenerateFont(const unsigned char *_Bitmap, int _BmWidth, int _BmHeight); - - -extern CTexFont *g_DefaultSmallFont; -extern CTexFont *g_DefaultNormalFont; -extern CTexFont *g_DefaultNormalFontAA; -extern CTexFont *g_DefaultLargeFont; -extern CTexFont *g_DefaultFixed1Font; - -void TwGenerateDefaultFonts(); -void TwDeleteDefaultFonts(); - - -#endif // !defined ANT_TW_FONTS_INCLUDED diff --git a/btgui/OpenGLWindow/Win32InternalWindowData.h b/btgui/OpenGLWindow/Win32InternalWindowData.h deleted file mode 100644 index 9f4b2f376..000000000 --- a/btgui/OpenGLWindow/Win32InternalWindowData.h +++ /dev/null @@ -1,65 +0,0 @@ - -#ifndef WIN32_INTERNAL_WINDOW_DATA_H -#define WIN32_INTERNAL_WINDOW_DATA_H - -#include - -struct InternalData2 -{ - HWND m_hWnd;; - int m_fullWindowWidth;//includes borders etc - int m_fullWindowHeight; - - int m_openglViewportWidth;//just the 3d viewport/client area - int m_openglViewportHeight; - - HDC m_hDC; - HGLRC m_hRC; - bool m_OpenGLInitialized; - int m_oldScreenWidth; - int m_oldHeight; - int m_oldBitsPerPel; - bool m_quit; - int m_mouseLButton; - int m_mouseRButton; - int m_mouseMButton; - int m_mouseXpos; - int m_mouseYpos; - - b3WheelCallback m_wheelCallback; - b3MouseMoveCallback m_mouseMoveCallback; - b3MouseButtonCallback m_mouseButtonCallback; - b3ResizeCallback m_resizeCallback; - b3KeyboardCallback m_keyboardCallback; - - - - InternalData2() - { - m_hWnd = 0; - m_mouseLButton=0; - m_mouseRButton=0; - m_mouseMButton=0; - - m_fullWindowWidth = 0; - m_fullWindowHeight= 0; - m_openglViewportHeight=0; - m_openglViewportWidth=0; - m_hDC = 0; - m_hRC = 0; - m_OpenGLInitialized = false; - m_oldScreenWidth = 0; - m_oldHeight = 0; - m_oldBitsPerPel = 0; - m_quit = false; - - m_keyboardCallback = 0; - m_mouseMoveCallback = 0; - m_mouseButtonCallback = 0; - m_resizeCallback = 0; - m_wheelCallback = 0; - - } -}; - -#endif //WIN32_INTERNAL_WINDOW_DATA_H \ No newline at end of file diff --git a/btgui/OpenGLWindow/Win32OpenGLWindow.cpp b/btgui/OpenGLWindow/Win32OpenGLWindow.cpp deleted file mode 100644 index ce7ffa5a7..000000000 --- a/btgui/OpenGLWindow/Win32OpenGLWindow.cpp +++ /dev/null @@ -1,181 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -#include "Win32OpenGLWindow.h" - -#include "OpenGLInclude.h" - -//#include "Bullet3Common/b3Vector3.h" - -#include "Win32InternalWindowData.h" -#include - -static void printGLString(const char *name, GLenum s) { - const char *v = (const char *) glGetString(s); - printf("%s = %s\n",name, v); -} - -bool sOpenGLVerbose = true; - -void Win32OpenGLWindow::enableOpenGL() -{ - - PIXELFORMATDESCRIPTOR pfd; - int format; - - // get the device context (DC) - m_data->m_hDC = GetDC( m_data->m_hWnd ); - - // set the pixel format for the DC - ZeroMemory( &pfd, sizeof( pfd ) ); - pfd.nSize = sizeof( pfd ); - pfd.nVersion = 1; - pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL | PFD_DOUBLEBUFFER; - pfd.iPixelType = PFD_TYPE_RGBA; - pfd.cColorBits = 32; - pfd.cRedBits = 8; - pfd.cGreenBits = 8; - pfd.cBlueBits = 8; - pfd.cAlphaBits = 8; - - pfd.cDepthBits = 24; - pfd.cStencilBits = 8;//1; - pfd.iLayerType = PFD_MAIN_PLANE; - format = ChoosePixelFormat( m_data->m_hDC, &pfd ); - SetPixelFormat( m_data->m_hDC, format, &pfd ); - - // create and enable the render context (RC) - m_data->m_hRC = wglCreateContext( m_data->m_hDC ); - wglMakeCurrent( m_data->m_hDC, m_data->m_hRC ); - - if (sOpenGLVerbose) - { - printGLString("Version", GL_VERSION); - printGLString("Vendor", GL_VENDOR); - printGLString("Renderer", GL_RENDERER); - } - //printGLString("Extensions", GL_EXTENSIONS); - -} - - - -void Win32OpenGLWindow::disableOpenGL() -{ - wglMakeCurrent( NULL, NULL ); - wglDeleteContext( m_data->m_hRC ); -// ReleaseDC( m_data->m_hWnd, m_data->m_hDC ); - -} - - - - - -void Win32OpenGLWindow::createWindow(const b3gWindowConstructionInfo& ci) -{ - Win32Window::createWindow(ci); - - //VideoDriver = video::createOpenGLDriver(CreationParams, FileSystem, this); - enableOpenGL(); - -} - - - - -Win32OpenGLWindow::Win32OpenGLWindow() -{ - - -} - -Win32OpenGLWindow::~Win32OpenGLWindow() -{ - -} - - -void Win32OpenGLWindow::closeWindow() -{ - disableOpenGL(); - - Win32Window::closeWindow(); -} - - -void Win32OpenGLWindow::startRendering() -{ - pumpMessage(); - //don't clear all 3 buffers because some AMD drivers are buggy - //glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT|GL_STENCIL_BUFFER_BIT); - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - - //glCullFace(GL_BACK); - //glFrontFace(GL_CCW); - glEnable(GL_DEPTH_TEST); - -} - - -void Win32OpenGLWindow::renderAllObjects() -{ -} - -void Win32OpenGLWindow::endRendering() - { - SwapBuffers( m_data->m_hDC ); - -} - -int Win32OpenGLWindow::fileOpenDialog(char* fileName, int maxFileNameLength) -{ - //wchar_t wideChars[1024]; - - OPENFILENAME ofn ; - ZeroMemory( &ofn , sizeof( ofn)); - ofn.lStructSize = sizeof ( ofn ); - ofn.hwndOwner = NULL ; - -#ifdef UNICODE - WCHAR bla[1024]; - ofn.lpstrFile = bla; - ofn.lpstrFile[0] = '\0'; - ofn.nMaxFile = 1023; - ofn.lpstrFilter = L"URDF\0*.urdf\0"; -#else - ofn.lpstrFile = fileName; - ofn.lpstrFile[0] = '\0'; - ofn.nMaxFile = 1023; - //ofn.lpstrFilter = "All\0*.*\0Text\0*.TXT\0"; - ofn.lpstrFilter = "URDF\0*.urdf\0"; - -#endif - - ofn.nFilterIndex =1; - ofn.lpstrFileTitle = NULL ; - ofn.nMaxFileTitle = 0 ; - ofn.lpstrInitialDir=NULL ; - ofn.Flags = OFN_PATHMUSTEXIST|OFN_FILEMUSTEXIST ; - GetOpenFileName( &ofn ); - return strlen(fileName); - - - //return 0; -} - - diff --git a/btgui/OpenGLWindow/Win32OpenGLWindow.h b/btgui/OpenGLWindow/Win32OpenGLWindow.h deleted file mode 100644 index 41f42d956..000000000 --- a/btgui/OpenGLWindow/Win32OpenGLWindow.h +++ /dev/null @@ -1,60 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -#ifndef _WIN32_OPENGL_RENDER_MANAGER_H -#define _WIN32_OPENGL_RENDER_MANAGER_H - - - -#include "Win32Window.h" - -#define b3gDefaultOpenGLWindow Win32OpenGLWindow - -class Win32OpenGLWindow : public Win32Window -{ - bool m_OpenGLInitialized; - - protected: - - - void enableOpenGL(); - - void disableOpenGL(); - -public: - - Win32OpenGLWindow(); - - virtual ~Win32OpenGLWindow(); - - virtual void createWindow(const b3gWindowConstructionInfo& ci); - - virtual void closeWindow(); - - virtual void startRendering(); - - virtual void renderAllObjects(); - - virtual void endRendering(); - - virtual float getRetinaScale() const {return 1.f;} - - virtual int fileOpenDialog(char* fileName, int maxFileNameLength); -}; - - - -#endif //_WIN32_OPENGL_RENDER_MANAGER_H diff --git a/btgui/OpenGLWindow/Win32Window.cpp b/btgui/OpenGLWindow/Win32Window.cpp deleted file mode 100644 index d83f0b61d..000000000 --- a/btgui/OpenGLWindow/Win32Window.cpp +++ /dev/null @@ -1,729 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -#include "Win32Window.h" - -#include "OpenGLInclude.h" - -#include -static InternalData2* sData = 0; - -#include "Win32InternalWindowData.h" - - - - -void Win32Window::pumpMessage() -{ - MSG msg; - // check for messages - //'if' instead of 'while' can make mainloop smoother. - //@todo: use separate threads for input and rendering - while( PeekMessage( &msg, NULL, 0, 0, PM_REMOVE ) ) - { - - // handle or dispatch messages - if ( msg.message == WM_QUIT ) - { - m_data->m_quit = TRUE; - } - else - { - TranslateMessage( &msg ); - DispatchMessage( &msg ); - } - -// gDemoApplication->displayCallback(); - - - }; -} - -int getAsciiCodeFromVirtualKeycode(int virtualKeyCode) -{ - int keycode = 0xffffffff; - if (virtualKeyCode >= '0' && virtualKeyCode <= '9') - { - return virtualKeyCode; - } - if (virtualKeyCode >= 'a' && virtualKeyCode <= 'z') - { - return virtualKeyCode; - } - if (virtualKeyCode >= 'A' && virtualKeyCode <= 'Z') - { - return virtualKeyCode+32;//todo: fix the ascii A vs a input - } - switch (virtualKeyCode) - { - case VK_RETURN: {keycode = B3G_RETURN; break; }; - case VK_F1: {keycode = B3G_F1; break;} - case VK_F2: {keycode = B3G_F2; break;} - case VK_F3: {keycode = B3G_F3; break;} - case VK_F4: {keycode = B3G_F4; break;} - case VK_F5: {keycode = B3G_F5; break;} - case VK_F6: {keycode = B3G_F6; break;} - case VK_F7: {keycode = B3G_F7; break;} - case VK_F8: {keycode = B3G_F8; break;} - case VK_F9: {keycode = B3G_F9; break;} - case VK_F10: {keycode= B3G_F10; break;} - - //case VK_SPACE: {keycode= ' '; break;} - - case VK_NEXT: {keycode= B3G_PAGE_DOWN; break;} - case VK_PRIOR: {keycode= B3G_PAGE_UP; break;} - - case VK_INSERT: {keycode= B3G_INSERT; break;} - case VK_BACK: {keycode= B3G_BACKSPACE; break;} - case VK_DELETE: {keycode= B3G_DELETE; break;} - - case VK_END:{keycode= B3G_END; break;} - case VK_HOME:{keycode= B3G_HOME; break;} - case VK_LEFT:{keycode= B3G_LEFT_ARROW; break;} - case VK_UP:{keycode= B3G_UP_ARROW; break;} - case VK_RIGHT:{keycode= B3G_RIGHT_ARROW; break;} - case VK_DOWN:{keycode= B3G_DOWN_ARROW; break;} - case VK_SHIFT:{keycode=B3G_SHIFT;break;} - case VK_MENU:{keycode=B3G_ALT;break;} - case VK_CONTROL:{keycode=B3G_CONTROL;break;} - default: - { - //keycode = MapVirtualKey( virtualKeyCode, MAPVK_VK_TO_CHAR ) & 0x0000FFFF; - } - }; - - return keycode; -} - -LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) -{ - //printf("msg = %d\n", message); - switch (message) - { - - case WM_PAINT: - { - PAINTSTRUCT ps; - BeginPaint(hWnd, &ps); - EndPaint(hWnd, &ps); - } - return 1; - - case WM_ERASEBKGND: - return 1; - - case WM_CLOSE: - if (sData) - sData->m_quit = true; - //PostQuitMessage(0); - return 1; - - case WM_DESTROY: - if (sData) - sData->m_quit = true; - //PostQuitMessage(0); - return 1; - - case WM_SYSKEYUP: - case WM_KEYUP: - { - - int keycode = getAsciiCodeFromVirtualKeycode(wParam); - - - if (keycode>=0 && sData && sData->m_keyboardCallback ) - { - int state=0; - (*sData->m_keyboardCallback)(keycode,state); - } - return 0; - } - case WM_CHAR: - { - //skip 'enter' key, it is processed in WM_KEYUP/WM_KEYDOWN - int keycode = getAsciiCodeFromVirtualKeycode(wParam); - if (keycode < 0) - { - if (sData && sData->m_keyboardCallback && ((HIWORD(lParam) & KF_REPEAT) == 0)) - { - int state = 1; - (*sData->m_keyboardCallback)(wParam, state); - } - } - return 0; - } - case WM_SYSKEYDOWN: - case WM_KEYDOWN: - { - int keycode = getAsciiCodeFromVirtualKeycode(wParam); - - if (keycode>=0 && sData && sData->m_keyboardCallback)// && ((HIWORD(lParam) & KF_REPEAT) == 0)) - { - int state = 1; - (*sData->m_keyboardCallback)(keycode,state); - return 1; - } - return 0; - } - - case WM_MBUTTONUP: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - if (sData) - { - sData->m_mouseMButton=0; - sData->m_mouseXpos = xPos; - sData->m_mouseYpos = yPos; - if (sData && sData->m_mouseButtonCallback) - (*sData->m_mouseButtonCallback)(1,0,xPos,yPos); - } - break; - } - case WM_MBUTTONDOWN: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - if (sData) - { - sData->m_mouseMButton=1; - sData->m_mouseXpos = xPos; - sData->m_mouseYpos = yPos; - if (sData && sData->m_mouseButtonCallback) - (*sData->m_mouseButtonCallback)(1,1,xPos,yPos); - } - break; - } - - case WM_LBUTTONUP: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - if (sData) - { - sData->m_mouseLButton=0; - sData->m_mouseXpos = xPos; - sData->m_mouseYpos = yPos; - - if (sData && sData->m_mouseButtonCallback) - (*sData->m_mouseButtonCallback)(0,0,xPos,yPos); - - } - // gDemoApplication->mouseFunc(0,1,xPos,yPos); - break; - } - case WM_LBUTTONDOWN: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - if (sData) - { - sData->m_mouseLButton=1; - sData->m_mouseXpos = xPos; - sData->m_mouseYpos = yPos; - - if (sData && sData->m_mouseButtonCallback) - (*sData->m_mouseButtonCallback)(0,1,xPos,yPos); - } - break; - } - - case 0x020e://WM_MOUSEWHEEL_LEFT_RIGHT - { - - int zDelta = (short)HIWORD(wParam); - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - //m_cameraDistance -= zDelta*0.01; - if (sData && sData->m_wheelCallback) - (*sData->m_wheelCallback)(-float(zDelta)*0.05f,0); - return 1; - break; - } - case 0x020A://WM_MOUSEWHEEL: - { - - int zDelta = (short)HIWORD(wParam); - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - //m_cameraDistance -= zDelta*0.01; - if (sData && sData->m_wheelCallback) - (*sData->m_wheelCallback)(0,float(zDelta)*0.05f); - return 1; - break; - } - - case WM_MOUSEMOVE: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - sData->m_mouseXpos = xPos; - sData->m_mouseYpos = yPos; - - if (sData && sData->m_mouseMoveCallback) - (*sData->m_mouseMoveCallback)(xPos,yPos); - - break; - } - case WM_RBUTTONUP: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - sData->m_mouseRButton = 1; - - if (sData && sData->m_mouseButtonCallback) - (*sData->m_mouseButtonCallback)(2,0,sData->m_mouseXpos,sData->m_mouseYpos); - - //gDemoApplication->mouseFunc(2,1,xPos,yPos); - break; - } - case WM_RBUTTONDOWN: - { - int xPos = LOWORD(lParam); - int yPos = HIWORD(lParam); - sData->m_mouseRButton = 0; - if (sData && sData->m_mouseButtonCallback) - (*sData->m_mouseButtonCallback)(2,1,sData->m_mouseXpos,sData->m_mouseYpos); - - break; - } - case WM_QUIT: - { - return 0; - break; - } - case WM_SIZE: // Size Action Has Taken Place - - RECT clientRect; - GetClientRect(hWnd,&clientRect); - - switch (wParam) // Evaluate Size Action - { - - case SIZE_MINIMIZED: // Was Window Minimized? - return 0; // Return - - case SIZE_MAXIMIZED: // Was Window Maximized? - case SIZE_RESTORED: // Was Window Restored? - RECT wr; - GetWindowRect(hWnd,&wr); - - sData->m_fullWindowWidth = wr.right-wr.left; - sData->m_fullWindowHeight = wr.bottom-wr.top;//LOWORD (lParam) HIWORD (lParam); - sData->m_openglViewportWidth = clientRect.right; - sData->m_openglViewportHeight = clientRect.bottom; - glViewport(0, 0, sData->m_openglViewportWidth, sData->m_openglViewportHeight); - - if (sData->m_resizeCallback) - (*sData->m_resizeCallback)(sData->m_openglViewportWidth,sData->m_openglViewportHeight); - //if (sOpenGLInitialized) - //{ - // //gDemoApplication->reshape(sWidth,sHeight); - //} - return 0; // Return - } - break; - - default:{ - - - } - }; - - return DefWindowProc(hWnd, message, wParam, lParam); -} - - - -void Win32Window::setWindowTitle(const char* titleChar) -{ - - wchar_t windowTitle[1024]; - swprintf(windowTitle, 1024, L"%hs", titleChar); - - DWORD dwResult; - -#ifdef _WIN64 - SetWindowTextW(m_data->m_hWnd, windowTitle); -#else - SendMessageTimeoutW(m_data->m_hWnd, WM_SETTEXT, 0, - reinterpret_cast(windowTitle), - SMTO_ABORTIFHUNG, 2000, &dwResult); -#endif -} - -void Win32Window::createWindow(const b3gWindowConstructionInfo& ci) -{ - int oglViewportWidth = ci.m_width; - int oglViewportHeight = ci.m_height; - bool fullscreen = ci.m_fullscreen; - int colorBitsPerPixel = ci.m_colorBitsPerPixel; - void* windowHandle = ci.m_windowHandle; - - // get handle to exe file - HINSTANCE hInstance = GetModuleHandle(0); - - - // create the window if we need to and we do not use the null device - if (!windowHandle) - { -#ifdef UNICODE - const wchar_t * ClassName = L"DeviceWin32"; - const wchar_t* emptyString= L""; -#else - const char* ClassName = "DeviceWin32"; - const char* emptyString = ""; -#endif - // Register Class - WNDCLASSEX wcex; - wcex.cbSize = sizeof(WNDCLASSEX); - wcex.style = CS_HREDRAW | CS_VREDRAW; - wcex.lpfnWndProc = WndProc; - wcex.cbClsExtra = 0; - wcex.cbWndExtra = 0; - wcex.hInstance = hInstance; - wcex.hIcon = LoadIcon( NULL, IDI_APPLICATION ); //(HICON)LoadImage(hInstance, "bullet_ico.ico", IMAGE_ICON, 0,0, LR_LOADTRANSPARENT);//LR_LOADFROMFILE); - wcex.hCursor = LoadCursor(NULL, IDC_ARROW); - wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW+1); - wcex.lpszMenuName = 0; - wcex.lpszClassName = ClassName; - wcex.hIconSm = 0; - - // if there is an icon, load it -// wcex.hIcon = (HICON)LoadImage(hInstance, "bullet.ico", IMAGE_ICON, 0,0, LR_LOADFROMFILE); - - RegisterClassEx(&wcex); - - // calculate client size - - RECT clientSize; - clientSize.top = 0; - clientSize.left = 0; - clientSize.right = oglViewportWidth; - clientSize.bottom = oglViewportHeight; - - DWORD style = WS_POPUP; - - if (!fullscreen) - style = WS_SYSMENU | WS_BORDER | WS_CAPTION | WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_MINIMIZEBOX | WS_MAXIMIZEBOX | WS_SIZEBOX; - - AdjustWindowRect(&clientSize, style, false); - - m_data->m_fullWindowWidth = clientSize.right - clientSize.left; - m_data->m_fullWindowHeight = clientSize.bottom - clientSize.top; - - int windowLeft = (GetSystemMetrics(SM_CXSCREEN) - m_data->m_fullWindowWidth) / 2; - int windowTop = (GetSystemMetrics(SM_CYSCREEN) - m_data->m_fullWindowHeight) / 2; - - if (fullscreen) - { - windowLeft = 0; - windowTop = 0; - } - - // create window - - m_data->m_hWnd = CreateWindow( ClassName, emptyString, style, windowLeft, windowTop, - m_data->m_fullWindowWidth, m_data->m_fullWindowHeight,NULL, NULL, hInstance, NULL); - - - RECT clientRect; - GetClientRect(m_data->m_hWnd,&clientRect); - - - - ShowWindow(m_data->m_hWnd, SW_SHOW); - UpdateWindow(m_data->m_hWnd); - - MoveWindow(m_data->m_hWnd, windowLeft, windowTop, m_data->m_fullWindowWidth, m_data->m_fullWindowHeight, TRUE); - - GetClientRect(m_data->m_hWnd,&clientRect); - int w = clientRect.right-clientRect.left; - int h = clientRect.bottom-clientRect.top; -// printf("actual client OpenGL viewport width / height = %d, %d\n",w,h); - m_data->m_openglViewportHeight = h; - m_data->m_openglViewportWidth = w; - - } - else if (windowHandle) - { - // attach external window - m_data->m_hWnd = static_cast(windowHandle); - RECT r; - GetWindowRect(m_data->m_hWnd, &r); - m_data->m_fullWindowWidth = r.right - r.left; - m_data->m_fullWindowHeight= r.bottom - r.top; - - - //sFullScreen = false; - //sExternalWindow = true; - } - - - if (fullscreen) - { - DEVMODE dm; - memset(&dm, 0, sizeof(dm)); - dm.dmSize = sizeof(dm); - // use default values from current setting - EnumDisplaySettings(NULL, ENUM_CURRENT_SETTINGS, &dm); - m_data->m_oldScreenWidth = dm.dmPelsWidth; - m_data->m_oldHeight = dm.dmPelsHeight; - m_data->m_oldBitsPerPel = dm.dmBitsPerPel; - - dm.dmPelsWidth = oglViewportWidth; - dm.dmPelsHeight = oglViewportHeight; - if (colorBitsPerPixel) - { - dm.dmBitsPerPel = colorBitsPerPixel; - } - dm.dmFields = DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT | DM_DISPLAYFREQUENCY; - - LONG res = ChangeDisplaySettings(&dm, CDS_FULLSCREEN); - if (res != DISP_CHANGE_SUCCESSFUL) - { // try again without forcing display frequency - dm.dmFields = DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT; - res = ChangeDisplaySettings(&dm, CDS_FULLSCREEN); - } - - } - - -} - - -void Win32Window::switchFullScreen(bool fullscreen,int width,int height,int colorBitsPerPixel) -{ - - LONG res; - DEVMODE dm; - memset(&dm, 0, sizeof(dm)); - dm.dmSize = sizeof(dm); - // use default values from current setting - EnumDisplaySettings(NULL, ENUM_CURRENT_SETTINGS, &dm); - - dm.dmFields = DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT | DM_DISPLAYFREQUENCY; - - if (fullscreen && !m_data->m_oldScreenWidth) - { - m_data->m_oldScreenWidth = dm.dmPelsWidth; - m_data->m_oldHeight = dm.dmPelsHeight; - m_data->m_oldBitsPerPel = dm.dmBitsPerPel; - - if (width && height) - { - dm.dmPelsWidth = width; - dm.dmPelsHeight = height; - } else - { - dm.dmPelsWidth = m_data->m_fullWindowWidth; - dm.dmPelsHeight = m_data->m_fullWindowHeight; - } - if (colorBitsPerPixel) - { - dm.dmBitsPerPel = colorBitsPerPixel; - } - } else - { - if (m_data->m_oldScreenWidth) - { - dm.dmPelsWidth = m_data->m_oldScreenWidth; - dm.dmPelsHeight= m_data->m_oldHeight; - dm.dmBitsPerPel = m_data->m_oldBitsPerPel; - } - } - - if (fullscreen) - { - - res = ChangeDisplaySettings(&dm, CDS_FULLSCREEN); - if (!res) - { - dm.dmFields = DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT; - res = ChangeDisplaySettings(&dm, CDS_FULLSCREEN); - } - - DWORD style = WS_POPUP; - SetWindowLong(m_data->m_hWnd, GWL_STYLE, style); - - MoveWindow(m_data->m_hWnd, 0, 0, m_data->m_fullWindowWidth, m_data->m_fullWindowHeight, TRUE); - - SetWindowPos(m_data->m_hWnd, NULL,0,0, (int)width, (int)height, - SWP_FRAMECHANGED |SWP_SHOWWINDOW);//|SWP_NOACTIVATE | SWP_NOCOPYBITS | SWP_NOOWNERZORDER | SWP_NOREPOSITION | SWP_NOZORDER); - - - } else - { - res = ChangeDisplaySettings(&dm, 0); - - DWORD style = WS_SYSMENU | WS_BORDER | WS_CAPTION | WS_CLIPCHILDREN | WS_CLIPSIBLINGS | WS_MINIMIZEBOX | WS_MAXIMIZEBOX | WS_SIZEBOX; - SetWindowLong(m_data->m_hWnd, GWL_STYLE, style); - - SetWindowPos(m_data->m_hWnd, NULL,0,0, (int)width, (int)height, - SWP_FRAMECHANGED |SWP_SHOWWINDOW); - //|SWP_NOACTIVATE | SWP_NOCOPYBITS | SWP_NOOWNERZORDER | SWP_NOREPOSITION | SWP_NOZORDER); - - } - - -} - - - -Win32Window::Win32Window() -{ - m_data = new InternalData2(); - sData = m_data; - -} - -Win32Window::~Win32Window() -{ - setKeyboardCallback(0); - setMouseMoveCallback(0); - setMouseButtonCallback(0); - setWheelCallback(0); - setResizeCallback(0); - - sData = 0; - delete m_data; - -} - -void Win32Window::setRenderCallback( b3RenderCallback renderCallback) -{ - -} - -void Win32Window::closeWindow() -{ - setKeyboardCallback(0); - setMouseMoveCallback(0); - setMouseButtonCallback(0); - setWheelCallback(0); - setResizeCallback(0); - setRenderCallback(0); - - - DestroyWindow(this->m_data->m_hWnd); -} - -void Win32Window::getMouseCoordinates(int& x, int& y) -{ - x = m_data->m_mouseXpos; - y = m_data->m_mouseYpos; - -} - -void Win32Window::runMainLoop() -{ - -} - - -void Win32Window::startRendering() -{ - pumpMessage(); - -// glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); //clear buffers - - //glCullFace(GL_BACK); - //glFrontFace(GL_CCW); - // glEnable(GL_DEPTH_TEST); - - - -} - - -void Win32Window::renderAllObjects() -{ -} - -void Win32Window::endRendering() -{ - SwapBuffers( m_data->m_hDC ); -} - -float Win32Window::getTimeInSeconds() -{ - return 0.f; -} - -void Win32Window::setDebugMessage(int x,int y,const char* message) -{ -} - -void Win32Window::setRequestExit() -{ - m_data->m_quit = true; -} -bool Win32Window::requestedExit() const -{ - return m_data->m_quit; -} - -void Win32Window::setWheelCallback(b3WheelCallback wheelCallback) -{ - m_data->m_wheelCallback = wheelCallback; -} - -void Win32Window::setMouseMoveCallback(b3MouseMoveCallback mouseCallback) -{ - m_data->m_mouseMoveCallback = mouseCallback; -} - -void Win32Window::setMouseButtonCallback(b3MouseButtonCallback mouseCallback) -{ - m_data->m_mouseButtonCallback = mouseCallback; -} - -void Win32Window::setResizeCallback(b3ResizeCallback resizeCallback) -{ - m_data->m_resizeCallback = resizeCallback; - if (m_data->m_resizeCallback) - (*m_data->m_resizeCallback)(m_data->m_openglViewportWidth,m_data->m_openglViewportHeight); -} - -void Win32Window::setKeyboardCallback( b3KeyboardCallback keyboardCallback) -{ - m_data->m_keyboardCallback = keyboardCallback; - -} - -b3KeyboardCallback Win32Window::getKeyboardCallback() -{ - return m_data->m_keyboardCallback; -} - -b3MouseMoveCallback Win32Window::getMouseMoveCallback() -{ - return m_data->m_mouseMoveCallback; -} -b3MouseButtonCallback Win32Window::getMouseButtonCallback() -{ - return m_data->m_mouseButtonCallback; -} -b3ResizeCallback Win32Window::getResizeCallback() -{ - return m_data->m_resizeCallback; -} -b3WheelCallback Win32Window::getWheelCallback() -{ - return m_data->m_wheelCallback; -} - - \ No newline at end of file diff --git a/btgui/OpenGLWindow/Win32Window.h b/btgui/OpenGLWindow/Win32Window.h deleted file mode 100644 index b7b5adae9..000000000 --- a/btgui/OpenGLWindow/Win32Window.h +++ /dev/null @@ -1,84 +0,0 @@ -/* -Copyright (c) 2012 Advanced Micro Devices, Inc. - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. -*/ -//Originally written by Erwin Coumans - - -#ifndef _WIN32_WINDOW_H -#define _WIN32_WINDOW_H - - - -struct InternalData2; - -#include "b3gWindowInterface.h" - -class Win32Window : public b3gWindowInterface -{ - protected: - - struct InternalData2* m_data; - - - void pumpMessage(); - - - -public: - - Win32Window(); - - virtual ~Win32Window(); - - virtual void createWindow(const b3gWindowConstructionInfo& ci); - - virtual void switchFullScreen(bool fullscreen,int width=0,int height=0,int colorBitsPerPixel=0); - - virtual void closeWindow(); - - virtual void runMainLoop(); - - virtual void startRendering(); - - virtual void renderAllObjects(); - - virtual void endRendering(); - - virtual float getTimeInSeconds(); - - virtual void setDebugMessage(int x,int y,const char* message); - - virtual bool requestedExit() const; - - virtual void setRequestExit(); - - virtual void getMouseCoordinates(int& x, int& y); - - virtual void setMouseMoveCallback(b3MouseMoveCallback mouseCallback); - virtual void setMouseButtonCallback(b3MouseButtonCallback mouseCallback); - virtual void setResizeCallback(b3ResizeCallback resizeCallback); - virtual void setWheelCallback(b3WheelCallback wheelCallback); - virtual void setKeyboardCallback( b3KeyboardCallback keyboardCallback); - - virtual b3MouseMoveCallback getMouseMoveCallback(); - virtual b3MouseButtonCallback getMouseButtonCallback(); - virtual b3ResizeCallback getResizeCallback(); - virtual b3WheelCallback getWheelCallback(); - virtual b3KeyboardCallback getKeyboardCallback(); - - virtual void setRenderCallback( b3RenderCallback renderCallback); - - virtual void setWindowTitle(const char* title); -}; - -#endif //_WIN32_WINDOW_H \ No newline at end of file diff --git a/btgui/OpenGLWindow/X11OpenGLWindow.cpp b/btgui/OpenGLWindow/X11OpenGLWindow.cpp deleted file mode 100644 index 961863580..000000000 --- a/btgui/OpenGLWindow/X11OpenGLWindow.cpp +++ /dev/null @@ -1,1015 +0,0 @@ -#include "X11OpenGLWindow.h" -#include "OpenGLInclude.h" - -#include -#include -#include "GlewWindows/GL/glew.h" -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -#include "GlewWindows/GL/glxew.h" -#else -#include -#endif // GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -#include - -//#define DYNAMIC_LOAD_X11_FUNCTIONS -#ifdef DYNAMIC_LOAD_X11_FUNCTIONS -#include -#endif //DYNAMIC_LOAD_X11_FUNCTIONS - -//#include -//#include -//#include - -//defined in GL/glxew.h -//#include -#include -#include -#include -#include - -#include - -GLint att[] = { GLX_RGBA, -GLX_DEPTH_SIZE, 24, -GLX_RED_SIZE , 8, -GLX_GREEN_SIZE , 8, -GLX_BLUE_SIZE , 8, -GLX_ALPHA_SIZE , 8, -GLX_STENCIL_SIZE , 8, -GLX_DOUBLEBUFFER, -None }; -/* - static int att[] = - { - GLX_RGBA, GLX_DEPTH_SIZE, 24, GLX_DOUBLEBUFFER, None - - GLX_X_RENDERABLE , True, - GLX_DRAWABLE_TYPE , GLX_WINDOW_BIT, - GLX_RENDER_TYPE , GLX_RGBA_BIT, - GLX_X_VISUAL_TYPE , GLX_TRUE_COLOR, - GLX_RED_SIZE , 8, - GLX_GREEN_SIZE , 8, - GLX_BLUE_SIZE , 8, - GLX_ALPHA_SIZE , 8, - GLX_DEPTH_SIZE , 24, - GLX_STENCIL_SIZE , 8, - GLX_DOUBLEBUFFER , True, - None - }; -*/ -static bool forceOpenGL3 = true; - - - -#ifdef DYNAMIC_LOAD_X11_FUNCTIONS - -///our X11 function typedefs - -typedef int (*PFNXFREE)(void*); -typedef XErrorHandler (* PFNXSETERRORHANDLER) (XErrorHandler); -typedef int (* PFNXSYNC) (Display* a,Bool b); -typedef Display* (* PFNXOPENDISPLAY) (_Xconst char* a); -typedef Colormap (*PFNXCREATECOLORMAP) (Display* a,Window b,Visual* c,int d); -typedef Window (*PFNXCREATEWINDOW) (Display* a,Window b,int c,int d,unsigned int e,unsigned int f,unsigned int g,int h,unsigned int i,Visual* j,unsigned long k,XSetWindowAttributes* l); -typedef int (*PFNXMAPWINDOW) (Display*, Window); -typedef int (*PFNXSTORENAME) (Display* a,Window b,_Xconst char* c); -typedef int (*PFNXCLOSEDISPLAY) (Display* a); -typedef int (*PFNXDESTROYWINDOW) (Display* a,Window b); -typedef int (*PFNXRAISEWINDOW) (Display* a, Window b); - -#if NeedWidePrototypes - typedef KeySym* (*PFNXGETKEYBOARDMAPPING) (Display*,unsigned int,int,int*); - typedef KeySym (*PFNXKEYCODETOKEYSYM) (Display* a,unsigned int b,int c); -#else - typedef KeySym* (*PFNXGETKEYBOARDMAPPING) (Display*,KeyCode,int,int*); - typedef KeySym (*PFNXKEYCODETOKEYSYM) (Display* a,KeyCode b,int c); -#endif -typedef void (*PFNXCONVERTCASE) (KeySym /* sym */,KeySym * /* lower */,KeySym * /* upper */); -typedef int (*PFNXPENDING) (Display* a); -typedef int (*PFNXNEXTEVENT) (Display* a,XEvent* b); -typedef int (*PFNXEVENTSQUEUED) (Display* a,int b); -typedef int (*PFNXPEEKEVENT) (Display* a,XEvent* b); -typedef KeySym (*PFNXLOOKUPKEYSYM) (XKeyEvent* a,int b); -typedef Status (*PFNXGETWINDOWATTRIBUTES) (Display* a,Window b,XWindowAttributes* c); - -#define X11_LIBRARY "libX11.so.6" - -#define MyXSync m_data->m_x11_XSync -#define MyXGetKeyboardMapping m_data->m_x11_XGetKeyboardMapping -#define MyXSetErrorHandler m_data->m_x11_XSetErrorHandler -#define MyXOpenDisplay m_data->m_x11_XOpenDisplay -#define MyXCreateColormap m_data->m_x11_XCreateColormap -#define MyXCreateWindow m_data->m_x11_XCreateWindow -#define MyXMapWindow m_data->m_x11_XMapWindow -#define MyXStoreName m_data->m_x11_XStoreName -#define MyXDestroyWindow m_data->m_x11_XDestroyWindow -#define MyXRaiseWindow m_data->m_x11_XRaiseWindow -#define MyXCloseDisplay m_data->m_x11_XCloseDisplay -#define MyXKeycodeToKeysym m_data->m_x11_XKeycodeToKeysym -#define MyXConvertCase m_data->m_x11_XConvertCase -#define MyXPending m_data->m_x11_XPending -#define MyXNextEvent m_data->m_x11_XNextEvent -#define MyXEventsQueued m_data->m_x11_XEventsQueued -#define MyXPeekEvent m_data->m_x11_XPeekEvent -#define MyXNextEvent m_data->m_x11_XNextEvent -#define MyXGetWindowAttributes m_data->m_x11_XGetWindowAttributes -#define MyXStoreName m_data->m_x11_XStoreName -#define MyXFree m_data->m_x11_XFree -#define MyXMapWindow m_data->m_x11_XMapWindow -#define MyXStoreName m_data->m_x11_XStoreName -#define MyXLookupKeysym m_data->m_x11_XLookupKeysym - -#else -#define MyXSync XSync -#define MyXGetKeyboardMapping XGetKeyboardMapping -#define MyXSetErrorHandler XSetErrorHandler -#define MyXOpenDisplay XOpenDisplay -#define MyXCreateColormap XCreateColormap -#define MyXCreateWindow XCreateWindow -#define MyXMapWindow XMapWindow -#define MyXStoreName XStoreName -#define MyXDestroyWindow XDestroyWindow -#define MyXRaiseWindow XRaiseWindow -#define MyXCloseDisplay XCloseDisplay -#define MyXKeycodeToKeysym XKeycodeToKeysym -#define MyXConvertCase XConvertCase -#define MyXPending XPending -#define MyXNextEvent XNextEvent -#define MyXEventsQueued XEventsQueued -#define MyXPeekEvent XPeekEvent -#define MyXNextEvent XNextEvent -#define MyXGetWindowAttributes XGetWindowAttributes -#define MyXStoreName XStoreName -#define MyXFree XFree -#define MyXMapWindow XMapWindow -#define MyXStoreName XStoreName -#define MyXLookupKeysym XLookupKeysym - -#endif//DYNAMIC_LOAD_X11_FUNCTIONS -struct InternalData2 -{ - Display* m_dpy; - Window m_root; - XVisualInfo* m_vi; - Colormap m_cmap; - XSetWindowAttributes m_swa; - Window m_win; - GLXContext m_glc; - XWindowAttributes m_gwa; - XEvent m_xev; - GLXFBConfig m_bestFbc; - -#ifdef DYNAMIC_LOAD_X11_FUNCTIONS - //dynamically load stuff - void* m_x11_library; - PFNXFREE m_x11_XFree; - PFNXSETERRORHANDLER m_x11_XSetErrorHandler; - PFNXSYNC m_x11_XSync; - PFNXOPENDISPLAY m_x11_XOpenDisplay; - PFNXCREATECOLORMAP m_x11_XCreateColormap; - PFNXCREATEWINDOW m_x11_XCreateWindow; - PFNXMAPWINDOW m_x11_XMapWindow; - PFNXSTORENAME m_x11_XStoreName; - PFNXCLOSEDISPLAY m_x11_XCloseDisplay; - PFNXDESTROYWINDOW m_x11_XDestroyWindow; - PFNXRAISEWINDOW m_x11_XRaiseWindow; - PFNXKEYCODETOKEYSYM m_x11_XKeycodeToKeysym; - PFNXGETKEYBOARDMAPPING m_x11_XGetKeyboardMapping; - PFNXCONVERTCASE m_x11_XConvertCase; - PFNXPENDING m_x11_XPending; - PFNXNEXTEVENT m_x11_XNextEvent; - PFNXEVENTSQUEUED m_x11_XEventsQueued; - PFNXPEEKEVENT m_x11_XPeekEvent; - PFNXLOOKUPKEYSYM m_x11_XLookupKeysym; - PFNXGETWINDOWATTRIBUTES m_x11_XGetWindowAttributes; -#endif //DYNAMIC_LOAD_X11_FUNCTIONS - - b3WheelCallback m_wheelCallback; - b3MouseMoveCallback m_mouseMoveCallback; - b3MouseButtonCallback m_mouseButtonCallback; - b3ResizeCallback m_resizeCallback; - b3KeyboardCallback m_keyboardCallback; - - InternalData2() - :m_dpy(0), - m_vi(0), - m_wheelCallback(0), - m_mouseMoveCallback(0), - m_mouseButtonCallback(0), - m_resizeCallback(0), - m_keyboardCallback(0) - { -#ifdef DYNAMIC_LOAD_X11_FUNCTIONS - m_x11_library = dlopen(X11_LIBRARY, RTLD_LOCAL | RTLD_NOW); - if (!m_x11_library) - { - printf("Error opening X11 library %s\n", X11_LIBRARY); - exit(0); - } - - bool missingFunc = false; - - missingFunc = ((m_x11_XFree = (PFNXFREE) dlsym(m_x11_library, "XFree"))==NULL) | missingFunc; - assert(!missingFunc); - if (missingFunc) { printf("Error: missing func XFree in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XSetErrorHandler = (PFNXSETERRORHANDLER) dlsym(m_x11_library,"XSetErrorHandler"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XSetErrorHandler in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XSetErrorHandler = (PFNXSETERRORHANDLER) dlsym(m_x11_library,"XSetErrorHandler"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XSetErrorHandler in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XSync = (PFNXSYNC) dlsym(m_x11_library,"XSync"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XSync in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XOpenDisplay = (PFNXOPENDISPLAY) dlsym(m_x11_library,"XOpenDisplay"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XOpenDisplay in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XCreateColormap = (PFNXCREATECOLORMAP) dlsym(m_x11_library,"XCreateColormap"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XCreateColormap in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XCreateWindow = (PFNXCREATEWINDOW) dlsym(m_x11_library,"XCreateWindow"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XCreateWindow in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XMapWindow = (PFNXMAPWINDOW) dlsym(m_x11_library,"XMapWindow"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XMapWindow in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XStoreName = (PFNXSTORENAME) dlsym(m_x11_library,"XStoreName"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XStoreName in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XCloseDisplay = (PFNXCLOSEDISPLAY) dlsym(m_x11_library,"XCloseDisplay"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XCloseDisplay in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XDestroyWindow = (PFNXDESTROYWINDOW) dlsym(m_x11_library,"XDestroyWindow"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XDestroyWindow in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XRaiseWindow = (PFNXRAISEWINDOW) dlsym(m_x11_library,"XRaiseWindow"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XRaiseWindow in %s, exiting!\n", X11_LIBRARY); exit(0);} - - missingFunc = ((m_x11_XGetKeyboardMapping = (PFNXGETKEYBOARDMAPPING) dlsym(m_x11_library,"XGetKeyboardMapping"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XGetKeyboardMapping in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XKeycodeToKeysym = (PFNXKEYCODETOKEYSYM) dlsym(m_x11_library,"XKeycodeToKeysym"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XKeycodeToKeysym in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XConvertCase = (PFNXCONVERTCASE) dlsym(m_x11_library,"XConvertCase"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XConvertCase in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XPending = (PFNXPENDING) dlsym(m_x11_library,"XPending"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XPending in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XNextEvent = (PFNXNEXTEVENT) dlsym(m_x11_library,"XNextEvent"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XNextEvent in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XEventsQueued = (PFNXEVENTSQUEUED) dlsym(m_x11_library,"XEventsQueued"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XEventsQueued in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XPeekEvent = (PFNXPEEKEVENT) dlsym(m_x11_library,"XPeekEvent"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XPeekEvent in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XLookupKeysym = (PFNXLOOKUPKEYSYM) dlsym(m_x11_library,"XLookupKeysym"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XLookupKeysym in %s, exiting!\n", X11_LIBRARY); exit(0);} - missingFunc = ((m_x11_XGetWindowAttributes = (PFNXGETWINDOWATTRIBUTES) dlsym(m_x11_library,"XGetWindowAttributes"))==NULL) | missingFunc; - if (missingFunc) { printf("Error: missing func XGetWindowAttributes in %s, exiting!\n", X11_LIBRARY); exit(0);} - - if (missingFunc) - { - printf("Error: a missing func in %s, exiting!\n", X11_LIBRARY); - exit(0); - } else - { - printf("X11 functions dynamically loaded using dlopen/dlsym OK!\n"); - } -#endif //DYNAMIC_LOAD_X11_FUNCTIONS - } -}; - -#define GLX_CONTEXT_MAJOR_VERSION_ARB 0x2091 -#define GLX_CONTEXT_MINOR_VERSION_ARB 0x2092 -typedef GLXContext (*glXCreateContextAttribsARBProc)(Display*, GLXFBConfig, GLXContext, Bool, const int*); - -// Helper to check for extension string presence. Adapted from: -// http://www.opengl.org/resources/features/OGLextensions/ -static bool isExtensionSupported(const char *extList, const char *extension) -{ - const char *start; - const char *where, *terminator; - - /* Extension names should not have spaces. */ - where = strchr(extension, ' '); - if (where || *extension == '\0') - return false; - - /* It takes a bit of care to be fool-proof about parsing the - OpenGL extensions string. Don't be fooled by sub-strings, - etc. */ - for (start=extList;;) { - where = strstr(start, extension); - - if (!where) - break; - - terminator = where + strlen(extension); - - if ( where == start || *(where - 1) == ' ' ) - if ( *terminator == ' ' || *terminator == '\0' ) - return true; - - start = terminator; - } - - return false; -} - -static bool ctxErrorOccurred = false; -static int ctxErrorHandler( Display *dpy, XErrorEvent *ev ) -{ - ctxErrorOccurred = true; - return 0; -} - - - - -X11OpenGLWindow::X11OpenGLWindow() -:m_OpenGLInitialized(false), -m_requestedExit(false) -{ - m_data = new InternalData2; -} - -X11OpenGLWindow::~X11OpenGLWindow() -{ - if (m_OpenGLInitialized) - { - disableOpenGL(); - } - - delete m_data; -} - - - -void X11OpenGLWindow::enableOpenGL() -{ - - - if (forceOpenGL3) - { - // Get the default screen's GLX extension list - const char *glxExts = glXQueryExtensionsString( m_data->m_dpy, - DefaultScreen( m_data->m_dpy ) ); - - // NOTE: It is not necessary to create or make current to a context before - // calling glXGetProcAddressARB, unless we dynamically load OpenGL/GLX/X11 - - glXCreateContextAttribsARBProc glXCreateContextAttribsARB = 0; - glXCreateContextAttribsARB = (glXCreateContextAttribsARBProc) - glXGetProcAddressARB( (const GLubyte *) "glXCreateContextAttribsARB" ); - - GLXContext ctx = 0; - - // Install an X error handler so the application won't exit if GL 3.0 - // context allocation fails. - // - // Note this error handler is global. All display connections in all threads - // of a process use the same error handler, so be sure to guard against other - // threads issuing X commands while this code is running. - ctxErrorOccurred = false; - int (*oldHandler)(Display*, XErrorEvent*) = - MyXSetErrorHandler(&ctxErrorHandler); - - // Check for the GLX_ARB_create_context extension string and the function. - // If either is not present, use GLX 1.3 context creation method. - if ( !isExtensionSupported( glxExts, "GLX_ARB_create_context" ) || - !glXCreateContextAttribsARB ) - { - printf( "glXCreateContextAttribsARB() not found" - " ... using old-style GLX context\n" ); - ctx = glXCreateNewContext( m_data->m_dpy, m_data->m_bestFbc, GLX_RGBA_TYPE, 0, True ); - } - - // If it does, try to get a GL 3.0 context! - else - { - int context_attribs[] = { - GLX_CONTEXT_MAJOR_VERSION_ARB ,3, - GLX_CONTEXT_MINOR_VERSION_ARB, 2, - GLX_CONTEXT_FLAGS_ARB, GLX_CONTEXT_DEBUG_BIT_ARB, - GLX_CONTEXT_PROFILE_MASK_ARB, GLX_CONTEXT_CORE_PROFILE_BIT_ARB,None - }; -/* - int context_attribs[] = - { - GLX_CONTEXT_MAJOR_VERSION_ARB, 3, - GLX_CONTEXT_MINOR_VERSION_ARB, 2, - - //GLX_CONTEXT_FLAGS_ARB , GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB, - None - }; -*/ - printf( "Creating context\n" ); - ctx = glXCreateContextAttribsARB( m_data->m_dpy, m_data->m_bestFbc, 0, - True, context_attribs ); - - // Sync to ensure any errors generated are processed. - MyXSync( m_data->m_dpy, False ); - if ( !ctxErrorOccurred && ctx ) - printf( "Created GL 3.0 context\n" ); - else - { - // Couldn't create GL 3.0 context. Fall back to old-style 2.x context. - // When a context version below 3.0 is requested, implementations will - // return the newest context version compatible with OpenGL versions less - // than version 3.0. - // GLX_CONTEXT_MAJOR_VERSION_ARB = 1 - context_attribs[1] = 1; - // GLX_CONTEXT_MINOR_VERSION_ARB = 0 - context_attribs[3] = 0; - - ctxErrorOccurred = false; - - printf( "Failed to create GL 3.0 context" - " ... using old-style GLX context\n" ); - ctx = glXCreateContextAttribsARB( m_data->m_dpy, m_data->m_bestFbc, 0, - True, context_attribs ); - } - } - - // Sync to ensure any errors generated are processed. - MyXSync( m_data->m_dpy, False ); - - // Restore the original error handler - MyXSetErrorHandler( oldHandler ); - - if ( ctxErrorOccurred || !ctx ) - { - printf( "Failed to create an OpenGL context\n" ); - exit(1); - } - - // Verifying that context is a direct context - if ( ! glXIsDirect ( m_data->m_dpy, ctx ) ) - { - printf( "Indirect GLX rendering context obtained\n" ); - } - else - { - printf( "Direct GLX rendering context obtained\n" ); - } - - printf( "Making context current\n" ); - glXMakeCurrent( m_data->m_dpy, m_data->m_win, ctx ); - - } else - { - m_data->m_glc = glXCreateContext(m_data->m_dpy, m_data->m_vi, NULL, GL_TRUE); - glXMakeCurrent(m_data->m_dpy, m_data->m_win, m_data->m_glc); - } - -#ifdef GLEW_INIT_OPENGL11_FUNCTIONS -{ - GLboolean res = glewOpenGL11Init(); - if (res==0) - { - printf("glewOpenGL11Init OK!\n"); - } else - { - printf("ERROR: glewOpenGL11Init failed, exiting!\n"); - exit(0); - } -} - -#endif //GLEW_INIT_OPENGL11_FUNCTIONS - - const GLubyte* ven = glGetString(GL_VENDOR); - printf("GL_VENDOR=%s\n", ven); - - const GLubyte* ren = glGetString(GL_RENDERER); - printf("GL_RENDERER=%s\n",ren); - const GLubyte* ver = glGetString(GL_VERSION); - printf("GL_VERSION=%s\n", ver); - const GLubyte* sl = glGetString(GL_SHADING_LANGUAGE_VERSION); - printf("GL_SHADING_LANGUAGE_VERSION=%s\n", sl); - -//Access pthreads as a workaround for a bug in Linux/Ubuntu -//See https://bugs.launchpad.net/ubuntu/+source/nvidia-graphics-drivers-319/+bug/1248642 - - int i=pthread_getconcurrency(); - printf("pthread_getconcurrency()=%d\n",i); - -// const GLubyte* ext = glGetString(GL_EXTENSIONS); -// printf("GL_EXTENSIONS=%s\n", ext); -} - -void X11OpenGLWindow::disableOpenGL() -{ - glXMakeCurrent(m_data->m_dpy, None, NULL); - glXDestroyContext(m_data->m_dpy, m_data->m_glc); -} - - -void X11OpenGLWindow::createWindow(const b3gWindowConstructionInfo& ci) -{ - - m_data->m_dpy = MyXOpenDisplay(NULL); - - if(m_data->m_dpy == NULL) { - printf("\n\tcannot connect to X server\n\n"); - exit(0); - } - - m_data->m_root = DefaultRootWindow(m_data->m_dpy); - - -#ifdef GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS -GLboolean res = glewXInit(); -if (res==0) -{ - printf("glewXInit OK\n"); -} else -{ - printf("glewXInit failed, exit\n"); - exit(0); -} -#endif //GLEW_DYNAMIC_LOAD_ALL_GLX_FUNCTIONS - - - if (ci.m_openglVersion < 3) - { - forceOpenGL3 = false; - } - - if (forceOpenGL3) - { - int glxMinor, glxMajor; - if (!glXQueryVersion(m_data->m_dpy,&glxMajor,&glxMinor) || (((glxMajor==1)&&(glxMinor<3)) || (glxMajor<1))) - { - printf("Invalid GLX version: major %d, minor %d\n",glxMajor,glxMinor); - exit(0); - } - - static int visual_attribs[] = - { - GLX_X_RENDERABLE , True, - GLX_DRAWABLE_TYPE , GLX_WINDOW_BIT, - GLX_RENDER_TYPE , GLX_RGBA_BIT, - GLX_X_VISUAL_TYPE , GLX_TRUE_COLOR, - GLX_RED_SIZE , 8, - GLX_GREEN_SIZE , 8, - GLX_BLUE_SIZE , 8, - GLX_ALPHA_SIZE , 8, - GLX_DEPTH_SIZE , 24, - GLX_STENCIL_SIZE , 8, - GLX_DOUBLEBUFFER , True, - None - }; - int fbcount; - GLXFBConfig* fbc = glXChooseFBConfig(m_data->m_dpy, DefaultScreen(m_data->m_dpy), visual_attribs, &fbcount); - if (!fbc) - { - printf( "Failed to retrieve a framebuffer config\n" ); - exit(1); - } - - int best_fbc = -1, worst_fbc = -1, best_num_samp = -1, worst_num_samp = 999; - - int i; - for (i=0; im_dpy, fbc[i] ); - if ( vi ) - { - int samp_buf, samples; - glXGetFBConfigAttrib( m_data->m_dpy, fbc[i], GLX_SAMPLE_BUFFERS, &samp_buf ); - glXGetFBConfigAttrib( m_data->m_dpy, fbc[i], GLX_SAMPLES , &samples ); - - //printf( " Matching fbconfig %d, visual ID 0x%2x: SAMPLE_BUFFERS = %d," - // " SAMPLES = %d\n", - // i, vi -> visualid, samp_buf, samples ); - - if ( best_fbc < 0 || (samp_buf && (samples > best_num_samp)) ) - best_fbc = i, best_num_samp = samples; - if ( worst_fbc < 0 || (!samp_buf || (samples < worst_num_samp)) ) - worst_fbc = i, worst_num_samp = samples; - } - MyXFree( vi ); - } - - m_data->m_bestFbc = fbc[ best_fbc ]; - // Be sure to free the FBConfig list allocated by glXChooseFBConfig() - MyXFree( fbc ); - - m_data->m_vi = glXGetVisualFromFBConfig( m_data->m_dpy, m_data->m_bestFbc ); - - - m_data->m_swa.colormap = m_data->m_cmap = MyXCreateColormap( m_data->m_dpy, - RootWindow( m_data->m_dpy, m_data->m_vi->screen ), - m_data->m_vi->visual, AllocNone ); - m_data->m_swa.background_pixmap = None ; - m_data->m_swa.border_pixel = 0; - m_data->m_swa.event_mask = ExposureMask | KeyReleaseMask | KeyPressMask |ButtonPressMask | ButtonReleaseMask |PointerMotionMask|StructureNotifyMask; -; - m_data->m_root = RootWindow( m_data->m_dpy, m_data->m_vi->screen ); - - m_data->m_win = MyXCreateWindow( m_data->m_dpy, m_data->m_root, - 0, 0, ci.m_width, ci.m_height, 0, m_data->m_vi->depth, InputOutput, - m_data->m_vi->visual, - CWBorderPixel|CWColormap|CWEventMask, &m_data->m_swa ); - - //m_data->m_win = m_data->m_x11_XCreateWindow(m_data->m_dpy, m_data->m_root, 0, 0, ci.m_width, ci.m_height, 0, m_data->m_vi->depth, InputOutput, m_data->m_vi->visual, CWColormap | CWEventMask, &m_data->m_swa); - - - if (!m_data->m_win) - { - printf("Cannot create window\n"); - exit(0); - } - - MyXMapWindow(m_data->m_dpy, m_data->m_win); - MyXStoreName(m_data->m_dpy, m_data->m_win, "OpenGL3 Window"); - - - } else - { - m_data->m_vi = glXChooseVisual(m_data->m_dpy, 0, att); - - printf("4\n"); - - if(m_data->m_vi == NULL) { - printf("\n\tno appropriate visual found\n\n"); - exit(0); - } - else { - printf("\n\tvisual %p selected\n", (void *)m_data->m_vi->visualid); /* %p creates hexadecimal output like in glxinfo */ - } - - - m_data->m_cmap = MyXCreateColormap(m_data->m_dpy, m_data->m_root, m_data->m_vi->visual, AllocNone); - m_data->m_swa.colormap = m_data->m_cmap; - m_data->m_swa.event_mask = ExposureMask | KeyReleaseMask | KeyPressMask |ButtonPressMask | ButtonReleaseMask |PointerMotionMask|StructureNotifyMask; - m_data->m_win = MyXCreateWindow(m_data->m_dpy, m_data->m_root, 0, 0, ci.m_width, ci.m_height, 0, m_data->m_vi->depth, InputOutput, m_data->m_vi->visual, CWColormap | CWEventMask, &m_data->m_swa); - - MyXMapWindow(m_data->m_dpy, m_data->m_win); - - MyXStoreName(m_data->m_dpy, m_data->m_win, "OpenGL2 Window"); - - - } - - enableOpenGL(); -} - -void X11OpenGLWindow::closeWindow() -{ - disableOpenGL(); - - MyXDestroyWindow(m_data->m_dpy, m_data->m_win); - MyXCloseDisplay(m_data->m_dpy); -} - -int X11OpenGLWindow::getAsciiCodeFromVirtualKeycode(int keycode) -{ - int result = 0; - - KeySym key, key_lc, key_uc; - - int keysyms_per_keycode_return; - KeySym *keysym = MyXGetKeyboardMapping(m_data->m_dpy, - keycode, - 1, - &keysyms_per_keycode_return); - - key = keysym[0]; - - - //key = MyXKeycodeToKeysym( m_data->m_dpy, keycode, 0 ); - - switch( key ) - { - case XK_Escape: return B3G_ESCAPE; - case XK_Return: return B3G_RETURN; - - case XK_Control_L: - case XK_Control_R: { - return B3G_CONTROL; - } - case XK_Left: return B3G_LEFT_ARROW; - case XK_Right: return B3G_RIGHT_ARROW; - case XK_Up: return B3G_UP_ARROW; - case XK_Down: return B3G_DOWN_ARROW; - - case XK_Alt_L: - case XK_Alt_R: - { - return B3G_ALT; - } - case XK_Shift_L: - case XK_Shift_R: return B3G_SHIFT; - case XK_F1: return B3G_F1; - case XK_F2: return B3G_F2; - case XK_F3: return B3G_F3; - case XK_F4: return B3G_F4; - case XK_F5: return B3G_F5; - case XK_F6: return B3G_F6; - case XK_F7: return B3G_F7; - case XK_F8: return B3G_F8; - case XK_F9: return B3G_F9; - case XK_F10: return B3G_F10; - case XK_F11: return B3G_F11; - case XK_F12: return B3G_F12; - case XK_F13: return B3G_F13; - case XK_F14: return B3G_F14; - case XK_F15: return B3G_F15; - default: - // Make lowercase - MyXConvertCase( key, &key_lc, &key_uc ); - key = key_lc; - // Valid ISO 8859-1 character? - if( (key >= 32 && key <= 126) ||(key >= 160 && key <= 255) ) - { - return (int) key; - } - result = -1; - } - - MyXFree(keysym); - - return result; -} - -void X11OpenGLWindow::pumpMessage() -{ - - int buttonState = 1; - - // Process all pending events - while( MyXPending( m_data->m_dpy ) ) - { - MyXNextEvent(m_data->m_dpy, &m_data->m_xev); - // printf("#"); - // fflush(stdout); - switch( m_data->m_xev.type ) - { - case KeyPress: - { - if (m_data->m_keyboardCallback) - { - int keycode = getAsciiCodeFromVirtualKeycode(m_data->m_xev.xkey.keycode); - int state = 1; - (*m_data->m_keyboardCallback)(keycode,state); - // printf("keycode %d",keycode); - // fflush(stdout); - - } - break; - } - - case KeyRelease: - { - // fflush(stdout); - - if (m_data->m_keyboardCallback) - { -#if 0 - unsigned short is_retriggered = 0; -///filter out keyboard repeat -//see http://stackoverflow.com/questions/2100654/ignore-auto-repeat-in-x11-applications - if (MyXEventsQueued(m_data->m_dpy, QueuedAfterReading)) - { - XEvent nev; - MyXPeekEvent(m_data->m_dpy, &nev); - - if (nev.type == KeyPress && nev.xkey.time == m_data->m_xev.xkey.time && - nev.xkey.keycode == m_data->m_xev.xkey.keycode) - { - fprintf (stdout, "key #%ld was retriggered.\n", - (long) MyXLookupKeysym(&nev.xkey, 0)); - - // delete retriggered KeyPress event - MyXNextEvent(m_data->m_dpy, & m_data->m_xev); - is_retriggered = 1; - } - } -#endif - int keycode = getAsciiCodeFromVirtualKeycode( m_data->m_xev.xkey.keycode); - int state = 0; - (*m_data->m_keyboardCallback)(keycode,state); - } - - break; - } - - case ButtonRelease: - buttonState = 0; - //continue with ButtonPress code - case ButtonPress: - { -// printf("!"); -// fflush(stdout); - - int button=-1; - - switch (m_data->m_xev.xbutton.button) - { - case Button1: - { - button=0; - break; - } - case Button2: - { - button=1; - break; - } - case Button3: - { - button=2; - break; - } - case Button4: - { - if (m_data->m_wheelCallback) - { - (*m_data->m_wheelCallback)(0,10); - } - break; - } - case Button5: - { - if (m_data->m_wheelCallback) - { - (*m_data->m_wheelCallback)(0,-10); - } - break; - } - } - int xpos = m_data->m_xev.xmotion.x; - int ypos = m_data->m_xev.xmotion.y; - - if (button>=0 && m_data->m_mouseButtonCallback) - { -// printf("xpos = %d, ypos = %d\n",xpos,ypos); - - (*m_data->m_mouseButtonCallback)(button,buttonState,xpos,ypos); - } - break; - } - case MotionNotify: - { -// printf("!"); -// fflush(0); - if (m_data->m_mouseMoveCallback) - { - int xpos = m_data->m_xev.xmotion.x; - int ypos = m_data->m_xev.xmotion.y; - (*m_data->m_mouseMoveCallback)(xpos,ypos); - } - break; - } - case ConfigureNotify: - { - // printf("@"); - // fflush(0); - if (m_data->m_resizeCallback) - { - (*m_data->m_resizeCallback)(m_data->m_xev.xconfigure.width,m_data->m_xev.xconfigure.height); - } - break; - } - case ClientMessage: - { - // printf("?"); - // fflush(stdout); - break; - } - case Expose: - { - break; - } - case DestroyNotify: - { - break; - } - default: - { - //XRRUpdateConfiguration( &event ); - } - }; - } -} - - - -void X11OpenGLWindow::startRendering() -{ - pumpMessage(); - - MyXGetWindowAttributes(m_data->m_dpy, m_data->m_win, &m_data->m_gwa); - glViewport(0, 0, m_data->m_gwa.width, m_data->m_gwa.height); - - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT); //clear buffers - - //glCullFace(GL_BACK); - //glFrontFace(GL_CCW); - glEnable(GL_DEPTH_TEST); -} - -void X11OpenGLWindow::renderAllObjects() -{ - -} - -void X11OpenGLWindow::endRendering() -{ - glXSwapBuffers(m_data->m_dpy, m_data->m_win); -} - -void X11OpenGLWindow::runMainLoop() -{ - -} - -float X11OpenGLWindow::getTimeInSeconds() -{ - return 0.f; -} - -bool X11OpenGLWindow::requestedExit() const -{ - return m_requestedExit; -} - -void X11OpenGLWindow::setRequestExit() -{ - m_requestedExit=true; -} - -void X11OpenGLWindow::setRenderCallback( b3RenderCallback renderCallback) -{ - -} - -void X11OpenGLWindow::setWindowTitle(const char* title) -{ - MyXStoreName(m_data->m_dpy, m_data->m_win, title); -} - - -void X11OpenGLWindow::setWheelCallback(b3WheelCallback wheelCallback) -{ - m_data->m_wheelCallback = wheelCallback; -} - -void X11OpenGLWindow::setMouseMoveCallback(b3MouseMoveCallback mouseCallback) -{ - m_data->m_mouseMoveCallback = mouseCallback; -} - -void X11OpenGLWindow::setMouseButtonCallback(b3MouseButtonCallback mouseCallback) -{ - m_data->m_mouseButtonCallback = mouseCallback; -} - -void X11OpenGLWindow::setResizeCallback(b3ResizeCallback resizeCallback) -{ - m_data->m_resizeCallback = resizeCallback; -} - -void X11OpenGLWindow::setKeyboardCallback( b3KeyboardCallback keyboardCallback) -{ - m_data->m_keyboardCallback = keyboardCallback; - -} - -b3MouseMoveCallback X11OpenGLWindow::getMouseMoveCallback() -{ - return m_data->m_mouseMoveCallback; -} -b3MouseButtonCallback X11OpenGLWindow::getMouseButtonCallback() -{ - return m_data->m_mouseButtonCallback; -} -b3ResizeCallback X11OpenGLWindow::getResizeCallback() -{ - return m_data->m_resizeCallback; -} -b3WheelCallback X11OpenGLWindow::getWheelCallback() -{ - return m_data->m_wheelCallback; -} - - -b3KeyboardCallback X11OpenGLWindow::getKeyboardCallback() -{ - return m_data->m_keyboardCallback; -} - -#include - -int X11OpenGLWindow::fileOpenDialog(char* filename, int maxNameLength) -{ - int len = 0; - FILE * output = popen("zenity --file-selection --file-filter=\"*.urdf\" --file-filter=\"*.*\"","r"); - if (output) - { - while( fgets(filename, maxNameLength-1, output) != NULL ) - { - len=strlen(filename); - if (len>0) - { - filename[len-1]=0; - printf("file open (length=%d) = %s\n", len,filename); - } - } - pclose(output); - } else - { - printf("Error: fileOpenDialog no popen output, perhaps install zenity?\n"); - } - MyXRaiseWindow(m_data->m_dpy, m_data->m_win); - return len; - -} diff --git a/btgui/OpenGLWindow/X11OpenGLWindow.h b/btgui/OpenGLWindow/X11OpenGLWindow.h deleted file mode 100644 index 4d29a637d..000000000 --- a/btgui/OpenGLWindow/X11OpenGLWindow.h +++ /dev/null @@ -1,72 +0,0 @@ -#ifndef X11_OPENGL_WINDOW_H -#define X11_OPENGL_WINDOW_H - -#define b3gDefaultOpenGLWindow X11OpenGLWindow - -#include "b3gWindowInterface.h" - -class X11OpenGLWindow : public b3gWindowInterface -{ - - struct InternalData2* m_data; - bool m_OpenGLInitialized; - bool m_requestedExit; - -protected: - - void enableOpenGL(); - - void disableOpenGL(); - - void pumpMessage(); - - int getAsciiCodeFromVirtualKeycode(int orgCode); - -public: - - X11OpenGLWindow(); - - virtual ~X11OpenGLWindow(); - - virtual void createWindow(const b3gWindowConstructionInfo& ci); - - virtual void closeWindow(); - - virtual void startRendering(); - - virtual void renderAllObjects(); - - virtual void endRendering(); - - virtual float getRetinaScale() const {return 1.f;} - - - virtual void runMainLoop(); - virtual float getTimeInSeconds(); - - virtual bool requestedExit() const; - virtual void setRequestExit() ; - - - virtual void setMouseMoveCallback(b3MouseMoveCallback mouseCallback); - virtual void setMouseButtonCallback(b3MouseButtonCallback mouseCallback); - virtual void setResizeCallback(b3ResizeCallback resizeCallback); - virtual void setWheelCallback(b3WheelCallback wheelCallback); - virtual void setKeyboardCallback( b3KeyboardCallback keyboardCallback); - - virtual b3MouseMoveCallback getMouseMoveCallback(); - virtual b3MouseButtonCallback getMouseButtonCallback(); - virtual b3ResizeCallback getResizeCallback(); - virtual b3WheelCallback getWheelCallback(); - virtual b3KeyboardCallback getKeyboardCallback(); - - virtual void setRenderCallback( b3RenderCallback renderCallback); - - virtual void setWindowTitle(const char* title); - - int fileOpenDialog(char* filename, int maxNameLength); -}; - - -#endif - diff --git a/btgui/OpenGLWindow/b3gWindowInterface.h b/btgui/OpenGLWindow/b3gWindowInterface.h deleted file mode 100644 index 64f4e6989..000000000 --- a/btgui/OpenGLWindow/b3gWindowInterface.h +++ /dev/null @@ -1,125 +0,0 @@ -#ifndef B3G_WINDOW_INTERFACE_H -#define B3G_WINDOW_INTERFACE_H - - -typedef void (*b3WheelCallback)(float deltax, float deltay); -typedef void (*b3ResizeCallback)( float width, float height); -typedef void (*b3MouseMoveCallback)( float x, float y); -typedef void (*b3MouseButtonCallback)(int button, int state, float x, float y); -typedef void (*b3KeyboardCallback)(int keycode, int state); -typedef void (*b3RenderCallback) (); - -enum { - B3G_ESCAPE = 27, - B3G_F1 = 0xff00, - B3G_F2, - B3G_F3, - B3G_F4, - B3G_F5, - B3G_F6, - B3G_F7, - B3G_F8, - B3G_F9, - B3G_F10, - B3G_F11, - B3G_F12, - B3G_F13, - B3G_F14, - B3G_F15, - B3G_LEFT_ARROW, - B3G_RIGHT_ARROW, - B3G_UP_ARROW, - B3G_DOWN_ARROW, - B3G_PAGE_UP, - B3G_PAGE_DOWN, - B3G_END, - B3G_HOME, - B3G_INSERT, - B3G_DELETE, - B3G_BACKSPACE, - B3G_SHIFT, - B3G_CONTROL, - B3G_ALT, - B3G_RETURN -}; - -struct b3gWindowConstructionInfo -{ - int m_width; - int m_height; - bool m_fullscreen; - int m_colorBitsPerPixel; - void* m_windowHandle; - const char* m_title; - int m_openglVersion; - - - b3gWindowConstructionInfo(int width=1024, int height=768) - :m_width(width), - m_height(height), - m_fullscreen(false), - m_colorBitsPerPixel(32), - m_windowHandle(0), - m_title("title"), - m_openglVersion(3) - { - } -}; - - -class b3gWindowInterface -{ - public: - - virtual ~b3gWindowInterface() - { - } - - virtual void createDefaultWindow(int width, int height, const char* title) - { - b3gWindowConstructionInfo ci(width,height); - ci.m_title = title; - createWindow(ci); - } - - virtual void createWindow(const b3gWindowConstructionInfo& ci)=0; - - virtual void closeWindow()=0; - - virtual void runMainLoop()=0; - virtual float getTimeInSeconds()=0; - - virtual bool requestedExit() const = 0; - virtual void setRequestExit() = 0; - - virtual void startRendering()=0; - - virtual void endRendering()=0; - - - virtual void setMouseMoveCallback(b3MouseMoveCallback mouseCallback)=0; - virtual b3MouseMoveCallback getMouseMoveCallback()=0; - - virtual void setMouseButtonCallback(b3MouseButtonCallback mouseCallback)=0; - virtual b3MouseButtonCallback getMouseButtonCallback()=0; - - virtual void setResizeCallback(b3ResizeCallback resizeCallback)=0; - virtual b3ResizeCallback getResizeCallback()=0; - - virtual void setWheelCallback(b3WheelCallback wheelCallback)=0; - virtual b3WheelCallback getWheelCallback()=0; - - virtual void setKeyboardCallback( b3KeyboardCallback keyboardCallback)=0; - virtual b3KeyboardCallback getKeyboardCallback()=0; - - virtual void setRenderCallback( b3RenderCallback renderCallback) = 0; - - virtual void setWindowTitle(const char* title)=0; - - virtual float getRetinaScale() const =0; - - virtual int fileOpenDialog(char* fileName, int maxFileNameLength) = 0; - -}; - -#endif //B3G_WINDOW_INTERFACE_H \ No newline at end of file diff --git a/btgui/OpenGLWindow/fontstash.cpp b/btgui/OpenGLWindow/fontstash.cpp deleted file mode 100644 index 56eaeb3a8..000000000 --- a/btgui/OpenGLWindow/fontstash.cpp +++ /dev/null @@ -1,818 +0,0 @@ -// -// Copyright (c) 2011 Andreas Krinke andreas.krinke@gmx.de -// Copyright (c) 2009 Mikko Mononen memon@inside.org -// -// This software is provided 'as-is', without any express or implied -// warranty. In no event will the authors be held liable for any damages -// arising from the use of this software. -// Permission is granted to anyone to use this software for any purpose, -// including commercial applications, and to alter it and redistribute it -// freely, subject to the following restrictions: -// 1. The origin of this software must not be misrepresented; you must not -// claim that you wrote the original software. If you use this software -// in a product, an acknowledgment in the product documentation would be -// appreciated but is not required. -// 2. Altered source versions must be plainly marked as such, and must not be -// misrepresented as being the original software. -// 3. This notice may not be removed or altered from any source distribution. -// - -#define STB_TRUETYPE_IMPLEMENTATION -#include -#include -#include -#ifdef _WIN32 -#include -#endif -#include "fontstash.h" - - - -#define BORDER_X_LEFT 2 -#define BORDER_X_RIGHT 2 -#define BORDER_Y_TOP 2 -#define BORDER_Y_BOTTOM 2 -#define ADDITIONAL_HEIGHT 2 - -#define STB_TRUETYPE_IMPLEMENTATION -#define STBTT_malloc(x,u) malloc(x) -#define STBTT_free(x,u) free(x) -#include "stb_truetype.h" - -#define HASH_LUT_SIZE 256 - - - -#define TTFONT_FILE 1 -#define TTFONT_MEM 2 -#define BMFONT 3 - -static int idx = 1; -static float s_retinaScale = 1; - -static unsigned int hashint(unsigned int a) -{ - a += ~(a<<15); - a ^= (a>>10); - a += (a<<3); - a ^= (a>>6); - a += ~(a<<11); - a ^= (a>>16); - return a; -} - - - -struct sth_font -{ - int idx; - int type; - stbtt_fontinfo font; - unsigned char* data; - struct sth_glyph* glyphs; - int lut[HASH_LUT_SIZE]; - int nglyphs; - float ascender; - float descender; - float lineh; - struct sth_font* next; -}; - - - - - -struct sth_stash -{ - int tw,th; - float itw,ith; - struct sth_texture* textures; - struct sth_font* fonts; - int drawing; - - RenderCallbacks* m_renderCallbacks; -}; - - - -// Copyright (c) 2008-2009 Bjoern Hoehrmann -// See http://bjoern.hoehrmann.de/utf-8/decoder/dfa/ for details. - -#define UTF8_ACCEPT 0 -#define UTF8_REJECT 1 - -static const unsigned char utf8d[] = { - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 00..1f - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 20..3f - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 40..5f - 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 60..7f - 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, // 80..9f - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, // a0..bf - 8,8,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2, // c0..df - 0xa,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x4,0x3,0x3, // e0..ef - 0xb,0x6,0x6,0x6,0x5,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8, // f0..ff - 0x0,0x1,0x2,0x3,0x5,0x8,0x7,0x1,0x1,0x1,0x4,0x6,0x1,0x1,0x1,0x1, // s0..s0 - 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,0,1,0,1,1,1,1,1,1, // s1..s2 - 1,2,1,1,1,1,1,2,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1, // s3..s4 - 1,2,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,3,1,3,1,1,1,1,1,1, // s5..s6 - 1,3,1,1,1,1,1,3,1,3,1,1,1,1,1,1,1,3,1,1,1,1,1,1,1,1,1,1,1,1,1,1, // s7..s8 -}; - -static unsigned int decutf8(unsigned int* state, unsigned int* codep, unsigned int byte) -{ - unsigned int type = utf8d[byte]; - *codep = (*state != UTF8_ACCEPT) ? - (byte & 0x3fu) | (*codep << 6) : - (0xff >> type) & (byte); - *state = utf8d[256 + *state*16 + type]; - return *state; -} - - - -struct sth_stash* sth_create(int cachew, int cacheh, RenderCallbacks* renderCallbacks) -{ - struct sth_stash* stash = NULL; - struct sth_texture* texture = NULL; - - // Allocate memory for the font stash. - stash = (struct sth_stash*)malloc(sizeof(struct sth_stash)); - if (stash == NULL) - { - assert(0); - return NULL; - } - memset(stash,0,sizeof(struct sth_stash)); - - stash->m_renderCallbacks = renderCallbacks; - - // Allocate memory for the first texture - texture = (struct sth_texture*)malloc(sizeof(struct sth_texture)); - if (texture == NULL) - { - assert(0); - free(stash); - } - memset(texture,0,sizeof(struct sth_texture)); - - // Create first texture for the cache. - stash->tw = cachew; - stash->th = cacheh; - stash->itw = 1.0f/cachew; - stash->ith = 1.0f/cacheh; - stash->textures = texture; - - stash->m_renderCallbacks->updateTexture(texture, 0, stash->tw, stash->th); - - return stash; - -} - -int sth_add_font_from_memory(struct sth_stash* stash, unsigned char* buffer) -{ - int i, ascent, descent, fh, lineGap; - struct sth_font* fnt = NULL; - - fnt = (struct sth_font*)malloc(sizeof(struct sth_font)); - if (fnt == NULL) goto error; - memset(fnt,0,sizeof(struct sth_font)); - - - // Init hash lookup. - for (i = 0; i < HASH_LUT_SIZE; ++i) - fnt->lut[i] = -1; - - fnt->data = buffer; - - // Init stb_truetype - if (!stbtt_InitFont(&fnt->font, fnt->data, 0)) - goto error; - - - // Store normalized line height. The real line height is got - // by multiplying the lineh by font size. - stbtt_GetFontVMetrics(&fnt->font, &ascent, &descent, &lineGap); - - fh = ascent - descent; - fnt->ascender = (float)ascent / (float)fh; - fnt->descender = (float)descent / (float)fh; - fnt->lineh = (float)(fh + lineGap) / (float)fh; - - fnt->idx = idx; - fnt->type = TTFONT_MEM; - fnt->next = stash->fonts; - stash->fonts = fnt; - - - return idx++; - -error: - if (fnt) { - if (fnt->glyphs) free(fnt->glyphs); - free(fnt); - } - return 0; -} - -int sth_add_font(struct sth_stash* stash, const char* path) -{ - FILE* fp = 0; - int datasize; - unsigned char* data = NULL; - int idx=0; - - // Read in the font data. - fp = fopen(path, "rb"); - if (!fp) goto error; - fseek(fp,0,SEEK_END); - datasize = (int)ftell(fp); - fseek(fp,0,SEEK_SET); - data = (unsigned char*)malloc(datasize); - if (data == NULL) goto error; - int bytesRead; - bytesRead = fread(data, 1, datasize, fp); - if (bytesRead) - { - idx = sth_add_font_from_memory(stash, data); - } - fclose(fp); - fp = 0; - - - // Modify type of the loaded font. - if (idx) - stash->fonts->type = TTFONT_FILE; - else - free(data); - - return idx; - -error: - if (data) free(data); - if (fp) fclose(fp); - return 0; -} - -int sth_add_bitmap_font(struct sth_stash* stash, int ascent, int descent, int line_gap) -{ - int i, fh; - struct sth_font* fnt = NULL; - - fnt = (struct sth_font*)malloc(sizeof(struct sth_font)); - if (fnt == NULL) goto error; - memset(fnt,0,sizeof(struct sth_font)); - - // Init hash lookup. - for (i = 0; i < HASH_LUT_SIZE; ++i) fnt->lut[i] = -1; - - // Store normalized line height. The real line height is got - // by multiplying the lineh by font size. - fh = ascent - descent; - fnt->ascender = (float)ascent / (float)fh; - fnt->descender = (float)descent / (float)fh; - fnt->lineh = (float)(fh + line_gap) / (float)fh; - - fnt->idx = idx; - fnt->type = BMFONT; - fnt->next = stash->fonts; - stash->fonts = fnt; - - return idx++; - -error: - if (fnt) free(fnt); - return 0; -} - -/*void sth_add_glyph(struct sth_stash* stash, - int idx, - unsigned int id1, - const char* s, - short size, short base, - int x, int y, int w, int h, - float xoffset, float yoffset, float xadvance) -{ - struct sth_texture* texture = NULL; - struct sth_font* fnt = NULL; - struct sth_glyph* glyph = NULL; - unsigned int codepoint; - unsigned int state = 0; - - if (stash == NULL) return; - texture = stash->textures; - while (texture != NULL && texture->id != id) - texture = texture->next; - - if (texture == NULL) - { - // Create new texture - texture = (struct sth_texture*)malloc(sizeof(struct sth_texture)); - if (texture == NULL) return; - memset(texture, 0, sizeof(struct sth_texture)); - texture->id = id; - texture->next = stash->textures; - stash->textures = texture; - } - - fnt = stash->fonts; - while (fnt != NULL && fnt->idx != idx) fnt = fnt->next; - if (fnt == NULL) return; - if (fnt->type != BMFONT) return; - - for (; *s; ++s) - { - if (!decutf8(&state, &codepoint, *(unsigned char*)s)) break; - } - if (state != UTF8_ACCEPT) return; - - // Alloc space for new glyph. - fnt->nglyphs++; - fnt->glyphs = (sth_glyph*)realloc(fnt->glyphs, fnt->nglyphs*sizeof(struct sth_glyph)); - if (!fnt->glyphs) return; - - // Init glyph. - glyph = &fnt->glyphs[fnt->nglyphs-1]; - memset(glyph, 0, sizeof(struct sth_glyph)); - glyph->codepoint = codepoint; - glyph->size = size; - glyph->texture = texture; - glyph->x0_ = x; - glyph->y0 = y; - glyph->x1 = glyph->x0_+w; - glyph->y1 = glyph->y0+h; - glyph->xoff = xoffset; - glyph->yoff = yoffset - base; - glyph->xadv = xadvance; - - // Find code point and size. - h = hashint(codepoint) & (HASH_LUT_SIZE-1); - // Insert char to hash lookup. - glyph->next = fnt->lut[h]; - fnt->lut[h] = fnt->nglyphs-1; -} -*/ - -static struct sth_glyph* get_glyph(struct sth_stash* stash, struct sth_font* fnt, unsigned int codepoint, short isize) -{ - int i,g,advance,lsb,x0,y0,x1,y1,gw,gh; - float scale; - struct sth_texture* texture = NULL; - struct sth_glyph* glyph = NULL; - - unsigned int h; - float size = isize/10.0f; - int rh; - struct sth_row* br = NULL; - - // Find code point and size. - h = hashint(codepoint) & (HASH_LUT_SIZE-1); - i = fnt->lut[h]; - while (i != -1) - { - if (fnt->glyphs[i].codepoint == codepoint && (fnt->type == BMFONT || fnt->glyphs[i].size == isize)) - return &fnt->glyphs[i]; - i = fnt->glyphs[i].next; - } - // Could not find glyph. - - // For bitmap fonts: ignore this glyph. - if (fnt->type == BMFONT) return 0; - - // For truetype fonts: create this glyph. - scale = stbtt_ScaleForPixelHeight(&fnt->font, size); - g = stbtt_FindGlyphIndex(&fnt->font, codepoint); - stbtt_GetGlyphHMetrics(&fnt->font, g, &advance, &lsb); - stbtt_GetGlyphBitmapBox(&fnt->font, g, scale,scale, &x0,&y0,&x1,&y1); - gw = x1-x0; - gh = y1-y0; - - // Check if glyph is larger than maximum texture size - if (gw >= stash->tw || gh >= stash->th) - return 0; - - // Find texture and row where the glyph can be fit. - br = NULL; - rh = (gh+7) & ~7; - texture = stash->textures; - while(br == NULL) - { - for (i = 0; i < texture->nrows; ++i) - { - if (texture->rows[i].h >= rh && texture->rows[i].x+gw+1 <= stash->tw) - br = &texture->rows[i]; - } - - // If no row is found, there are 3 possibilities: - // - add new row - // - try next texture - // - create new texture - if (br == NULL) - { - short py = BORDER_Y_TOP; - // Check that there is enough space. - if (texture->nrows) - { - py = texture->rows[texture->nrows-1].y + texture->rows[texture->nrows-1].h+1; - if (py+rh > stash->th) - { - if (texture->next != NULL) - { - texture = texture->next; - } - else - { - // Create new texture - texture->next = (struct sth_texture*)malloc(sizeof(struct sth_texture)); - texture = texture->next; - if (texture == NULL) goto error; - memset(texture,0,sizeof(struct sth_texture)); - - stash->m_renderCallbacks->updateTexture(texture,0,stash->tw,stash->th); - - - } - continue; - } - } - // Init and add row - br = &texture->rows[texture->nrows]; - br->x = BORDER_X_LEFT; - br->y = py+BORDER_Y_BOTTOM; - br->h = rh+ADDITIONAL_HEIGHT; - texture->nrows++; - } - } - - // Alloc space for new glyph. - fnt->nglyphs++; - fnt->glyphs = (sth_glyph*)realloc(fnt->glyphs, fnt->nglyphs*sizeof(struct sth_glyph)); - if (!fnt->glyphs) return 0; - - // Init glyph. - glyph = &fnt->glyphs[fnt->nglyphs-1]; - memset(glyph, 0, sizeof(struct sth_glyph)); - glyph->codepoint = codepoint; - glyph->size = isize; - glyph->texture = texture; - glyph->x0_ = br->x; - glyph->y0 = br->y; - glyph->x1 = glyph->x0_+gw; - glyph->y1 = glyph->y0+gh; - glyph->xadv = scale * advance; - glyph->xoff = (float)x0; - glyph->yoff = (float)y0; - glyph->next = 0; - - // Advance row location. - br->x += gw+BORDER_X_RIGHT; - - // Insert char to hash lookup. - glyph->next = fnt->lut[h]; - fnt->lut[h] = fnt->nglyphs-1; - - // Rasterize - { - unsigned char* ptr = texture->m_texels+glyph->x0_+glyph->y0*stash->tw; - stbtt_MakeGlyphBitmap(&fnt->font,ptr , gw,gh,stash->tw, scale,scale, g); - - stash->m_renderCallbacks->updateTexture(texture,glyph, stash->tw, stash->th); - - } - - return glyph; - -error: - if (texture) - free(texture); - return 0; -} - -static int get_quad(struct sth_stash* stash, struct sth_font* fnt, struct sth_glyph* glyph, short isize, float* x, float* y, struct sth_quad* q) -{ - float rx,ry; - float scale = 1.f/s_retinaScale;//1.0f; - - if (fnt->type == BMFONT) - scale = isize/(glyph->size*10.0f); - - rx = (*x + scale * float(glyph->xoff)); - ry = (*y + scale * float(glyph->yoff)); - - q->x0 = rx; - q->y0 = ry + 1.5f*0.5f*float(isize)/10.f; - - q->x1 = rx + scale * float(glyph->x1 - glyph->x0_); - q->y1 = ry + scale * float(glyph->y1 - glyph->y0)+ 1.5f*0.5f*float(isize)/10.f; - - q->s0 = float(glyph->x0_) * stash->itw; - q->t0 = float(glyph->y0) * stash->ith; - q->s1 = float(glyph->x1) * stash->itw; - q->t1 = float(glyph->y1) * stash->ith; - - *x += scale * glyph->xadv; - - return 1; -} - -static Vertex* setv(Vertex* v, float x, float y, float s, float t, float width, float height) -{ - bool scale=true; - if (scale) - { - v->position.p[0] = (x*2-width)/(width); - v->position.p[1] = 1-(y)/(height/2); - } else - { - v->position.p[0] = (x-width)/(width); - v->position.p[1] = (height-y)/(height); - } - v->position.p[2] = 0.f; - v->position.p[3] = 1.f; - - v->uv.p[0] = s; - v->uv.p[1] = t; - - v->colour.p[0] = 0.1f;//1.f; - v->colour.p[1] = 0.1f; - v->colour.p[2] = 0.1f; - v->colour.p[3] = 1.f; - - return v+1; -} - - - - -static void flush_draw(struct sth_stash* stash) -{ - struct sth_texture* texture = stash->textures; - while (texture) - { - if (texture->nverts > 0) - { - stash->m_renderCallbacks->render(texture); - texture->nverts = 0; - } - texture = texture->next; - } -} - - -void sth_begin_draw(struct sth_stash* stash) -{ - if (stash == NULL) return; - if (stash->drawing) - flush_draw(stash); - stash->drawing = 1; -} - -void sth_end_draw(struct sth_stash* stash) -{ - if (stash == NULL) return; - if (!stash->drawing) return; - -/* - // Debug dump. - if (stash->nverts+6 < VERT_COUNT) - { - float x = 500, y = 100; - float* v = &stash->verts[stash->nverts*4]; - - v = setv(v, x, y, 0, 0); - v = setv(v, x+stash->tw, y, 1, 0); - v = setv(v, x+stash->tw, y+stash->th, 1, 1); - - v = setv(v, x, y, 0, 0); - v = setv(v, x+stash->tw, y+stash->th, 1, 1); - v = setv(v, x, y+stash->th, 0, 1); - - stash->nverts += 6; - } -*/ - - flush_draw(stash); - stash->drawing = 0; -} - -void sth_draw_texture(struct sth_stash* stash, - int idx, float size, - float x, float y, - int screenwidth, int screenheight, - const char* s, float* dx) -{ - int width = stash->tw; - int height=stash->th; - - unsigned int codepoint; - struct sth_glyph* glyph = NULL; - struct sth_texture* texture = NULL; - unsigned int state = 0; - struct sth_quad q; - short isize = (short)(size*10.0f); - Vertex* v; - struct sth_font* fnt = NULL; - - if (stash == NULL) return; - - if (!stash->textures) return; - fnt = stash->fonts; - while(fnt != NULL && fnt->idx != idx) fnt = fnt->next; - if (fnt == NULL) return; - if (fnt->type != BMFONT && !fnt->data) return; - - int once = true; - for (; once; ++s) - { - once=false; - if (decutf8(&state, &codepoint, *(unsigned char*)s)) - continue; - glyph = get_glyph(stash, fnt, codepoint, isize); - if (!glyph) - continue; - texture = glyph->texture; - if (texture->nverts+6 >= VERT_COUNT) - flush_draw(stash); - - if (!get_quad(stash, fnt, glyph, isize, &x, &y, &q)) - continue; - - v = &texture->newverts[texture->nverts]; - q.x0 = 0; - q.y0 = 0; - q.x1 = q.x0+width; - q.y1 = q.y0+height; - - v = setv(v, q.x0, q.y0, 0,0,(float)screenwidth,(float)screenheight); - v = setv(v, q.x1, q.y0, 1,0,(float)screenwidth,(float)screenheight); - v = setv(v, q.x1, q.y1, 1,1,(float)screenwidth,(float)screenheight); - - v = setv(v, q.x0, q.y0, 0,0,(float)screenwidth,(float)screenheight); - v = setv(v, q.x1, q.y1, 1,1,(float)screenwidth,(float)screenheight); - v = setv(v, q.x0, q.y1, 0,1,(float)screenwidth,(float)screenheight); - texture->nverts += 6; - } - - flush_draw(stash); - - - - - if (dx) *dx = x; -} - -void sth_flush_draw(struct sth_stash* stash) -{ - flush_draw(stash); -} -void sth_draw_text(struct sth_stash* stash, - int idx, float size, - float x, float y, - const char* s, float* dx, int screenwidth, int screenheight, int measureOnly, float retinaScale) -{ - - unsigned int codepoint; - struct sth_glyph* glyph = NULL; - struct sth_texture* texture = NULL; - unsigned int state = 0; - struct sth_quad q; - short isize = (short)(size*10.0f); - Vertex* v; - struct sth_font* fnt = NULL; - - s_retinaScale = retinaScale; - if (stash == NULL) return; - - if (!stash->textures) return; - fnt = stash->fonts; - while(fnt != NULL && fnt->idx != idx) fnt = fnt->next; - if (fnt == NULL) return; - if (fnt->type != BMFONT && !fnt->data) return; - - for (; *s; ++s) - { - if (decutf8(&state, &codepoint, *(unsigned char*)s)) - continue; - glyph = get_glyph(stash, fnt, codepoint, isize); - if (!glyph) continue; - texture = glyph->texture; - - if (!measureOnly) - { - if (texture->nverts+6 >= VERT_COUNT) - flush_draw(stash); - } - - if (!get_quad(stash, fnt, glyph, isize, &x, &y, &q)) continue; - - if (!measureOnly) - { - v = &texture->newverts[texture->nverts]; - - v = setv(v, q.x0, q.y0, q.s0, q.t0,(float)screenwidth,(float)screenheight); - v = setv(v, q.x1, q.y0, q.s1, q.t0,(float)screenwidth,(float)screenheight); - v = setv(v, q.x1, q.y1, q.s1, q.t1,(float)screenwidth,(float)screenheight); - - v = setv(v, q.x0, q.y0, q.s0, q.t0,(float)screenwidth,(float)screenheight); - v = setv(v, q.x1, q.y1, q.s1, q.t1,(float)screenwidth,(float)screenheight); - v = setv(v, q.x0, q.y1, q.s0, q.t1,(float)screenwidth,(float)screenheight); - - texture->nverts += 6; - } - } - - if (dx) *dx = x; -} - -void sth_dim_text(struct sth_stash* stash, - int idx, float size, - const char* s, - float* minx, float* miny, float* maxx, float* maxy) -{ - unsigned int codepoint; - struct sth_glyph* glyph = NULL; - unsigned int state = 0; - struct sth_quad q; - short isize = (short)(size*10.0f); - struct sth_font* fnt = NULL; - float x = 0, y = 0; - - if (stash == NULL) - return; - if (!stash->textures) - return; - fnt = stash->fonts; - while(fnt != NULL && fnt->idx != idx) fnt = fnt->next; - if (fnt == NULL) return; - if (fnt->type != BMFONT && !fnt->data) return; - - *minx = *maxx = x; - *miny = *maxy = y; - - for (; *s; ++s) - { - if (decutf8(&state, &codepoint, *(unsigned char*)s)) continue; - glyph = get_glyph(stash, fnt, codepoint, isize); - if (!glyph) continue; - if (!get_quad(stash, fnt, glyph, isize, &x, &y, &q)) continue; - if (q.x0 < *minx) *minx = q.x0; - if (q.x1 > *maxx) *maxx = q.x1; - if (q.y1 < *miny) *miny = q.y1; - if (q.y0 > *maxy) *maxy = q.y0; - } -} - -void sth_vmetrics(struct sth_stash* stash, - int idx, float size, - float* ascender, float* descender, float* lineh) -{ - struct sth_font* fnt = NULL; - - if (stash == NULL) return; - if (!stash->textures) return; - fnt = stash->fonts; - while(fnt != NULL && fnt->idx != idx) fnt = fnt->next; - if (fnt == NULL) return; - if (fnt->type != BMFONT && !fnt->data) return; - if (ascender) - *ascender = fnt->ascender*size; - if (descender) - *descender = fnt->descender*size; - if (lineh) - *lineh = fnt->lineh*size; -} - -void sth_delete(struct sth_stash* stash) -{ - struct sth_texture* tex = NULL; - struct sth_texture* curtex = NULL; - struct sth_font* fnt = NULL; - struct sth_font* curfnt = NULL; - - if (!stash) return; - - tex = stash->textures; - while(tex != NULL) { - curtex = tex; - delete tex->m_texels; - tex->m_texels=0; - tex = tex->next; - stash->m_renderCallbacks->updateTexture(curtex,0,0,0); - free(curtex); - } - - fnt = stash->fonts; - while(fnt != NULL) { - curfnt = fnt; - fnt = fnt->next; - if (curfnt->glyphs) - { - free(curfnt->glyphs); - } - if (curfnt->type == TTFONT_FILE && curfnt->data) - { - free(curfnt->data); - } - free(curfnt); - } - free(stash); -} diff --git a/btgui/OpenGLWindow/fontstash.h b/btgui/OpenGLWindow/fontstash.h deleted file mode 100644 index 940bb7856..000000000 --- a/btgui/OpenGLWindow/fontstash.h +++ /dev/null @@ -1,146 +0,0 @@ -// -// Copyright (c) 2011 Andreas Krinke andreas.krinke@gmx.de -// Copyright (c) 2009 Mikko Mononen memon@inside.org -// -// This software is provided 'as-is', without any express or implied -// warranty. In no event will the authors be held liable for any damages -// arising from the use of this software. -// Permission is granted to anyone to use this software for any purpose, -// including commercial applications, and to alter it and redistribute it -// freely, subject to the following restrictions: -// 1. The origin of this software must not be misrepresented; you must not -// claim that you wrote the original software. If you use this software -// in a product, an acknowledgment in the product documentation would be -// appreciated but is not required. -// 2. Altered source versions must be plainly marked as such, and must not be -// misrepresented as being the original software. -// 3. This notice may not be removed or altered from any source distribution. -// - -#ifndef FONTSTASH_H -#define FONTSTASH_H - - -#define MAX_ROWS 128 -#define VERT_COUNT (6*128) -#define INDEX_COUNT (VERT_COUNT*2) - - -struct vec2 -{ - vec2(float x, float y) - { - p[0] = x; - p[1] = y; - } - float p[2]; -}; - -struct vec4 -{ - vec4(float x,float y, float z, float w) - { - p[0] = x; - p[1] = y; - p[2] = z; - p[3] = w; - - } - - float p[4]; -}; - -typedef struct -{ - vec4 position; - vec4 colour; - vec2 uv; -} Vertex; - -struct sth_quad -{ - float x0,y0,s0,t0; - float x1,y1,s1,t1; -}; - -struct sth_row -{ - short x,y,h; -}; - -struct sth_glyph -{ - unsigned int codepoint; - short size; - struct sth_texture* texture; - int x0_,y0,x1,y1; - float xadv,xoff,yoff; - int next; -}; - - -struct sth_texture -{ - union - { - void* m_userData; - int m_userId; - }; - - unsigned char* m_texels; - - // TODO: replace rows with pointer - struct sth_row rows[MAX_ROWS]; - int nrows; - int nverts; - - Vertex newverts[VERT_COUNT]; - struct sth_texture* next; -}; - - -struct RenderCallbacks -{ - virtual ~RenderCallbacks() {} - virtual void updateTexture(sth_texture* texture, sth_glyph* glyph, int textureWidth, int textureHeight)=0; - virtual void render(sth_texture* texture)=0; -}; - -struct sth_stash* sth_create(int cachew, int cacheh, RenderCallbacks* callbacks); - -int sth_add_font(struct sth_stash* stash, const char* path); -int sth_add_font_from_memory(struct sth_stash* stash, unsigned char* buffer); - -int sth_add_bitmap_font(struct sth_stash* stash, int ascent, int descent, int line_gap); -/*void sth_add_glyph(struct sth_stash* stash, int idx, unsigned int uid, const char* s, - short size, short base, int x, int y, int w, int h, - float xoffset, float yoffset, float xadvance); - */ - -void sth_begin_draw(struct sth_stash* stash); -void sth_end_draw(struct sth_stash* stash); - -void sth_draw_texture(struct sth_stash* stash, - int idx, float size, - float x, float y, - int screenwidth, int screenheight, - const char* s, float* dx); - -void sth_flush_draw(struct sth_stash* stash); - -void sth_draw_text(struct sth_stash* stash, - int idx, float size, - float x, float y, const char* string, float* dx, int screenwidth, int screenheight, int measureOnly=0, float retinaScale=1); - -void sth_dim_text(struct sth_stash* stash, int idx, float size, const char* string, - float* minx, float* miny, float* maxx, float* maxy); - -void sth_vmetrics(struct sth_stash* stash, - int idx, float size, - float* ascender, float* descender, float * lineh); - -void sth_delete(struct sth_stash* stash); - - - -#endif // FONTSTASH_H diff --git a/btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp b/btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp deleted file mode 100644 index 35250ce2e..000000000 --- a/btgui/OpenGLWindow/opengl_fontstashcallbacks.cpp +++ /dev/null @@ -1,252 +0,0 @@ -#include "opengl_fontstashcallbacks.h" -#include "../OpenGLWindow/GLPrimitiveRenderer.h" -#include "../OpenGLWindow/GLPrimInternalData.h" - -#include "fontstash.h" -#include "../OpenGLWindow/OpenGLInclude.h" -#include -#include -#include -#include -#define STB_IMAGE_WRITE_IMPLEMENTATION -#include "stb_image_write.h" - - -static unsigned int s_indexData[INDEX_COUNT]; -GLuint s_indexArrayObject, s_indexBuffer; -GLuint s_vertexArrayObject,s_vertexBuffer; - -OpenGL2RenderCallbacks::OpenGL2RenderCallbacks(GLPrimitiveRenderer* primRender) - :m_primRender2(primRender) -{ - -} -OpenGL2RenderCallbacks::~OpenGL2RenderCallbacks() -{ -} - -PrimInternalData* OpenGL2RenderCallbacks::getData() -{ - return m_primRender2->getData(); -} -InternalOpenGL2RenderCallbacks::~InternalOpenGL2RenderCallbacks() -{ - -} - -void InternalOpenGL2RenderCallbacks::display2() -{ - - assert(glGetError()==GL_NO_ERROR); - // glViewport(0,0,10,10); - - //const float timeScale = 0.008f; - PrimInternalData* data = getData(); - - glUseProgram(data->m_shaderProg); - glBindBuffer(GL_ARRAY_BUFFER, s_vertexBuffer); - glBindVertexArray(s_vertexArrayObject); - - assert(glGetError()==GL_NO_ERROR); - - - // glBindTexture(GL_TEXTURE_2D,m_texturehandle); - - - assert(glGetError()==GL_NO_ERROR); - - vec2 p( 0.f,0.f);//?b?0.5f * sinf(timeValue), 0.5f * cosf(timeValue) ); - glUniform2fv(data->m_positionUniform, 1, (const GLfloat *)&p); - - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(data->m_positionAttribute); - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(data->m_colourAttribute); - assert(glGetError()==GL_NO_ERROR); - - glEnableVertexAttribArray(data->m_textureAttribute); - - glVertexAttribPointer(data->m_positionAttribute, 4, GL_FLOAT, GL_FALSE, sizeof(Vertex), (const GLvoid *)0); - glVertexAttribPointer(data->m_colourAttribute , 4, GL_FLOAT, GL_FALSE, sizeof(Vertex), (const GLvoid *)sizeof(vec4)); - glVertexAttribPointer(data->m_textureAttribute , 2, GL_FLOAT, GL_FALSE, sizeof(Vertex), (const GLvoid *)(sizeof(vec4)+sizeof(vec4))); - assert(glGetError()==GL_NO_ERROR); -/* - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_indexBuffer); - //glDrawArrays(GL_TRIANGLE_FAN, 0, 4); - int indexCount = 6; - err = glGetError(); - assert(err==GL_NO_ERROR); - - glDrawElements(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, 0); - err = glGetError(); - assert(err==GL_NO_ERROR); - */ - - // glutSwapBuffers(); -} - - - -void InternalOpenGL2RenderCallbacks::updateTexture(sth_texture* texture, sth_glyph* glyph, int textureWidth, int textureHeight) -{ - assert(glGetError()==GL_NO_ERROR); - - - if (glyph) - { - // Update texture (entire texture, could use glyph to update partial texture using glTexSubImage2D) - GLuint* gltexture = (GLuint*) texture->m_userData; - - glBindTexture(GL_TEXTURE_2D, *gltexture); - glPixelStorei(GL_UNPACK_ALIGNMENT,1); - assert(glGetError()==GL_NO_ERROR); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, textureWidth, textureHeight, 0, GL_RED, GL_UNSIGNED_BYTE, texture->m_texels); - - assert(glGetError()==GL_NO_ERROR); - - } else - { - if (textureWidth && textureHeight) - { - GLuint* texId = new GLuint; - texture->m_userData = texId; - - - //create new texture - glGenTextures(1, texId); - assert(glGetError()==GL_NO_ERROR); - - - - glBindTexture(GL_TEXTURE_2D, *texId); - texture->m_texels = (unsigned char*)malloc(textureWidth*textureHeight); - memset(texture->m_texels,0,textureWidth*textureHeight); - glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, textureWidth, textureHeight, 0, GL_RED, GL_UNSIGNED_BYTE, texture->m_texels); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); - assert(glGetError()==GL_NO_ERROR); - - //////////////////////////// - //create the other data - { - glGenVertexArrays(1, &s_vertexArrayObject); - glBindVertexArray(s_vertexArrayObject); - - glGenBuffers(1, &s_vertexBuffer); - glBindBuffer(GL_ARRAY_BUFFER, s_vertexBuffer); - glBufferData(GL_ARRAY_BUFFER, VERT_COUNT * sizeof(Vertex), texture->newverts, GL_DYNAMIC_DRAW); - assert(glGetError()==GL_NO_ERROR); - - for (int i=0;im_userData) - { - - GLuint* id = (GLuint*)texture->m_userData; - - glDeleteTextures(1, id); - //delete id; - delete id;//texture->m_userData; - texture->m_userData = 0; - } - - } - - } -} - -void InternalOpenGL2RenderCallbacks::render(sth_texture* texture) -{ - display2(); - - - GLuint* texId = (GLuint*) texture->m_userData; - - assert(glGetError()==GL_NO_ERROR); - - glActiveTexture(GL_TEXTURE0); - assert(glGetError()==GL_NO_ERROR); - - glBindTexture(GL_TEXTURE_2D, *texId); - bool useFiltering = false; - if (useFiltering) - { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); - } else - { - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); - } - assert(glGetError()==GL_NO_ERROR); - glBindBuffer(GL_ARRAY_BUFFER, s_vertexBuffer); - glBindVertexArray(s_vertexArrayObject); - glBufferData(GL_ARRAY_BUFFER, texture->nverts * sizeof(Vertex), &texture->newverts[0].position.p[0], GL_DYNAMIC_DRAW); - - assert(glGetError()==GL_NO_ERROR); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, s_indexBuffer); - - //glDrawArrays(GL_TRIANGLE_FAN, 0, 4); - int indexCount = texture->nverts; - assert(glGetError()==GL_NO_ERROR); - - glDrawElements(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, 0); - assert(glGetError()==GL_NO_ERROR); - - glBindVertexArray(0); - - glBindBuffer(GL_ARRAY_BUFFER, 0); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); -// glDisableVertexAttribArray(m_textureAttribute); - glUseProgram(0); - -} - - -void dumpTextureToPng(int textureWidth, int textureHeight, const char* fileName) -{ - glPixelStorei(GL_PACK_ALIGNMENT,1); - unsigned char* pixels = (unsigned char*)malloc(textureWidth*textureHeight); - glReadPixels(0,0,textureWidth, textureHeight, GL_RED, GL_UNSIGNED_BYTE, pixels); - //swap the pixels - unsigned char* tmp = (unsigned char*)malloc(textureWidth); - for (int j=0;j -# ifndef _XTYPEDEF_XID -# define _XTYPEDEF_XID -typedef CARD32 XID; -# endif -# ifndef _XTYPEDEF_MASK -# define _XTYPEDEF_MASK -typedef CARD32 Mask; -# endif -# ifndef _XTYPEDEF_ATOM -# define _XTYPEDEF_ATOM -typedef CARD32 Atom; -# endif -typedef CARD32 VisualID; -typedef CARD32 Time; -#endif - -typedef XID Window; -typedef XID Drawable; -#ifndef _XTYPEDEF_FONT -# define _XTYPEDEF_FONT -typedef XID Font; -#endif -typedef XID Pixmap; -typedef XID Cursor; -typedef XID Colormap; -typedef XID GContext; -typedef XID KeySym; - -typedef unsigned char KeyCode; - -/***************************************************************** - * RESERVED RESOURCE AND CONSTANT DEFINITIONS - *****************************************************************/ - -#ifndef None -#define None 0L /* universal null resource or null atom */ -#endif - -#define ParentRelative 1L /* background pixmap in CreateWindow - and ChangeWindowAttributes */ - -#define CopyFromParent 0L /* border pixmap in CreateWindow - and ChangeWindowAttributes - special VisualID and special window - class passed to CreateWindow */ - -#define PointerWindow 0L /* destination window in SendEvent */ -#define InputFocus 1L /* destination window in SendEvent */ - -#define PointerRoot 1L /* focus window in SetInputFocus */ - -#define AnyPropertyType 0L /* special Atom, passed to GetProperty */ - -#define AnyKey 0L /* special Key Code, passed to GrabKey */ - -#define AnyButton 0L /* special Button Code, passed to GrabButton */ - -#define AllTemporary 0L /* special Resource ID passed to KillClient */ - -#define CurrentTime 0L /* special Time */ - -#define NoSymbol 0L /* special KeySym */ - -/***************************************************************** - * EVENT DEFINITIONS - *****************************************************************/ - -/* Input Event Masks. Used as event-mask window attribute and as arguments - to Grab requests. Not to be confused with event names. */ - -#define NoEventMask 0L -#define KeyPressMask (1L<<0) -#define KeyReleaseMask (1L<<1) -#define ButtonPressMask (1L<<2) -#define ButtonReleaseMask (1L<<3) -#define EnterWindowMask (1L<<4) -#define LeaveWindowMask (1L<<5) -#define PointerMotionMask (1L<<6) -#define PointerMotionHintMask (1L<<7) -#define Button1MotionMask (1L<<8) -#define Button2MotionMask (1L<<9) -#define Button3MotionMask (1L<<10) -#define Button4MotionMask (1L<<11) -#define Button5MotionMask (1L<<12) -#define ButtonMotionMask (1L<<13) -#define KeymapStateMask (1L<<14) -#define ExposureMask (1L<<15) -#define VisibilityChangeMask (1L<<16) -#define StructureNotifyMask (1L<<17) -#define ResizeRedirectMask (1L<<18) -#define SubstructureNotifyMask (1L<<19) -#define SubstructureRedirectMask (1L<<20) -#define FocusChangeMask (1L<<21) -#define PropertyChangeMask (1L<<22) -#define ColormapChangeMask (1L<<23) -#define OwnerGrabButtonMask (1L<<24) - -/* Event names. Used in "type" field in XEvent structures. Not to be -confused with event masks above. They start from 2 because 0 and 1 -are reserved in the protocol for errors and replies. */ - -#define KeyPress 2 -#define KeyRelease 3 -#define ButtonPress 4 -#define ButtonRelease 5 -#define MotionNotify 6 -#define EnterNotify 7 -#define LeaveNotify 8 -#define FocusIn 9 -#define FocusOut 10 -#define KeymapNotify 11 -#define Expose 12 -#define GraphicsExpose 13 -#define NoExpose 14 -#define VisibilityNotify 15 -#define CreateNotify 16 -#define DestroyNotify 17 -#define UnmapNotify 18 -#define MapNotify 19 -#define MapRequest 20 -#define ReparentNotify 21 -#define ConfigureNotify 22 -#define ConfigureRequest 23 -#define GravityNotify 24 -#define ResizeRequest 25 -#define CirculateNotify 26 -#define CirculateRequest 27 -#define PropertyNotify 28 -#define SelectionClear 29 -#define SelectionRequest 30 -#define SelectionNotify 31 -#define ColormapNotify 32 -#define ClientMessage 33 -#define MappingNotify 34 -#define GenericEvent 35 -#define LASTEvent 36 /* must be bigger than any event # */ - - -/* Key masks. Used as modifiers to GrabButton and GrabKey, results of QueryPointer, - state in various key-, mouse-, and button-related events. */ - -#define ShiftMask (1<<0) -#define LockMask (1<<1) -#define ControlMask (1<<2) -#define Mod1Mask (1<<3) -#define Mod2Mask (1<<4) -#define Mod3Mask (1<<5) -#define Mod4Mask (1<<6) -#define Mod5Mask (1<<7) - -/* modifier names. Used to build a SetModifierMapping request or - to read a GetModifierMapping request. These correspond to the - masks defined above. */ -#define ShiftMapIndex 0 -#define LockMapIndex 1 -#define ControlMapIndex 2 -#define Mod1MapIndex 3 -#define Mod2MapIndex 4 -#define Mod3MapIndex 5 -#define Mod4MapIndex 6 -#define Mod5MapIndex 7 - - -/* button masks. Used in same manner as Key masks above. Not to be confused - with button names below. */ - -#define Button1Mask (1<<8) -#define Button2Mask (1<<9) -#define Button3Mask (1<<10) -#define Button4Mask (1<<11) -#define Button5Mask (1<<12) - -#define AnyModifier (1<<15) /* used in GrabButton, GrabKey */ - - -/* button names. Used as arguments to GrabButton and as detail in ButtonPress - and ButtonRelease events. Not to be confused with button masks above. - Note that 0 is already defined above as "AnyButton". */ - -#define Button1 1 -#define Button2 2 -#define Button3 3 -#define Button4 4 -#define Button5 5 - -/* Notify modes */ - -#define NotifyNormal 0 -#define NotifyGrab 1 -#define NotifyUngrab 2 -#define NotifyWhileGrabbed 3 - -#define NotifyHint 1 /* for MotionNotify events */ - -/* Notify detail */ - -#define NotifyAncestor 0 -#define NotifyVirtual 1 -#define NotifyInferior 2 -#define NotifyNonlinear 3 -#define NotifyNonlinearVirtual 4 -#define NotifyPointer 5 -#define NotifyPointerRoot 6 -#define NotifyDetailNone 7 - -/* Visibility notify */ - -#define VisibilityUnobscured 0 -#define VisibilityPartiallyObscured 1 -#define VisibilityFullyObscured 2 - -/* Circulation request */ - -#define PlaceOnTop 0 -#define PlaceOnBottom 1 - -/* protocol families */ - -#define FamilyInternet 0 /* IPv4 */ -#define FamilyDECnet 1 -#define FamilyChaos 2 -#define FamilyInternet6 6 /* IPv6 */ - -/* authentication families not tied to a specific protocol */ -#define FamilyServerInterpreted 5 - -/* Property notification */ - -#define PropertyNewValue 0 -#define PropertyDelete 1 - -/* Color Map notification */ - -#define ColormapUninstalled 0 -#define ColormapInstalled 1 - -/* GrabPointer, GrabButton, GrabKeyboard, GrabKey Modes */ - -#define GrabModeSync 0 -#define GrabModeAsync 1 - -/* GrabPointer, GrabKeyboard reply status */ - -#define GrabSuccess 0 -#define AlreadyGrabbed 1 -#define GrabInvalidTime 2 -#define GrabNotViewable 3 -#define GrabFrozen 4 - -/* AllowEvents modes */ - -#define AsyncPointer 0 -#define SyncPointer 1 -#define ReplayPointer 2 -#define AsyncKeyboard 3 -#define SyncKeyboard 4 -#define ReplayKeyboard 5 -#define AsyncBoth 6 -#define SyncBoth 7 - -/* Used in SetInputFocus, GetInputFocus */ - -#define RevertToNone (int)None -#define RevertToPointerRoot (int)PointerRoot -#define RevertToParent 2 - -/***************************************************************** - * ERROR CODES - *****************************************************************/ - -#define Success 0 /* everything's okay */ -#define BadRequest 1 /* bad request code */ -#define BadValue 2 /* int parameter out of range */ -#define BadWindow 3 /* parameter not a Window */ -#define BadPixmap 4 /* parameter not a Pixmap */ -#define BadAtom 5 /* parameter not an Atom */ -#define BadCursor 6 /* parameter not a Cursor */ -#define BadFont 7 /* parameter not a Font */ -#define BadMatch 8 /* parameter mismatch */ -#define BadDrawable 9 /* parameter not a Pixmap or Window */ -#define BadAccess 10 /* depending on context: - - key/button already grabbed - - attempt to free an illegal - cmap entry - - attempt to store into a read-only - color map entry. - - attempt to modify the access control - list from other than the local host. - */ -#define BadAlloc 11 /* insufficient resources */ -#define BadColor 12 /* no such colormap */ -#define BadGC 13 /* parameter not a GC */ -#define BadIDChoice 14 /* choice not in range or already used */ -#define BadName 15 /* font or color name doesn't exist */ -#define BadLength 16 /* Request length incorrect */ -#define BadImplementation 17 /* server is defective */ - -#define FirstExtensionError 128 -#define LastExtensionError 255 - -/***************************************************************** - * WINDOW DEFINITIONS - *****************************************************************/ - -/* Window classes used by CreateWindow */ -/* Note that CopyFromParent is already defined as 0 above */ - -#define InputOutput 1 -#define InputOnly 2 - -/* Window attributes for CreateWindow and ChangeWindowAttributes */ - -#define CWBackPixmap (1L<<0) -#define CWBackPixel (1L<<1) -#define CWBorderPixmap (1L<<2) -#define CWBorderPixel (1L<<3) -#define CWBitGravity (1L<<4) -#define CWWinGravity (1L<<5) -#define CWBackingStore (1L<<6) -#define CWBackingPlanes (1L<<7) -#define CWBackingPixel (1L<<8) -#define CWOverrideRedirect (1L<<9) -#define CWSaveUnder (1L<<10) -#define CWEventMask (1L<<11) -#define CWDontPropagate (1L<<12) -#define CWColormap (1L<<13) -#define CWCursor (1L<<14) - -/* ConfigureWindow structure */ - -#define CWX (1<<0) -#define CWY (1<<1) -#define CWWidth (1<<2) -#define CWHeight (1<<3) -#define CWBorderWidth (1<<4) -#define CWSibling (1<<5) -#define CWStackMode (1<<6) - - -/* Bit Gravity */ - -#define ForgetGravity 0 -#define NorthWestGravity 1 -#define NorthGravity 2 -#define NorthEastGravity 3 -#define WestGravity 4 -#define CenterGravity 5 -#define EastGravity 6 -#define SouthWestGravity 7 -#define SouthGravity 8 -#define SouthEastGravity 9 -#define StaticGravity 10 - -/* Window gravity + bit gravity above */ - -#define UnmapGravity 0 - -/* Used in CreateWindow for backing-store hint */ - -#define NotUseful 0 -#define WhenMapped 1 -#define Always 2 - -/* Used in GetWindowAttributes reply */ - -#define IsUnmapped 0 -#define IsUnviewable 1 -#define IsViewable 2 - -/* Used in ChangeSaveSet */ - -#define SetModeInsert 0 -#define SetModeDelete 1 - -/* Used in ChangeCloseDownMode */ - -#define DestroyAll 0 -#define RetainPermanent 1 -#define RetainTemporary 2 - -/* Window stacking method (in configureWindow) */ - -#define Above 0 -#define Below 1 -#define TopIf 2 -#define BottomIf 3 -#define Opposite 4 - -/* Circulation direction */ - -#define RaiseLowest 0 -#define LowerHighest 1 - -/* Property modes */ - -#define PropModeReplace 0 -#define PropModePrepend 1 -#define PropModeAppend 2 - -/***************************************************************** - * GRAPHICS DEFINITIONS - *****************************************************************/ - -/* graphics functions, as in GC.alu */ - -#define GXclear 0x0 /* 0 */ -#define GXand 0x1 /* src AND dst */ -#define GXandReverse 0x2 /* src AND NOT dst */ -#define GXcopy 0x3 /* src */ -#define GXandInverted 0x4 /* NOT src AND dst */ -#define GXnoop 0x5 /* dst */ -#define GXxor 0x6 /* src XOR dst */ -#define GXor 0x7 /* src OR dst */ -#define GXnor 0x8 /* NOT src AND NOT dst */ -#define GXequiv 0x9 /* NOT src XOR dst */ -#define GXinvert 0xa /* NOT dst */ -#define GXorReverse 0xb /* src OR NOT dst */ -#define GXcopyInverted 0xc /* NOT src */ -#define GXorInverted 0xd /* NOT src OR dst */ -#define GXnand 0xe /* NOT src OR NOT dst */ -#define GXset 0xf /* 1 */ - -/* LineStyle */ - -#define LineSolid 0 -#define LineOnOffDash 1 -#define LineDoubleDash 2 - -/* capStyle */ - -#define CapNotLast 0 -#define CapButt 1 -#define CapRound 2 -#define CapProjecting 3 - -/* joinStyle */ - -#define JoinMiter 0 -#define JoinRound 1 -#define JoinBevel 2 - -/* fillStyle */ - -#define FillSolid 0 -#define FillTiled 1 -#define FillStippled 2 -#define FillOpaqueStippled 3 - -/* fillRule */ - -#define EvenOddRule 0 -#define WindingRule 1 - -/* subwindow mode */ - -#define ClipByChildren 0 -#define IncludeInferiors 1 - -/* SetClipRectangles ordering */ - -#define Unsorted 0 -#define YSorted 1 -#define YXSorted 2 -#define YXBanded 3 - -/* CoordinateMode for drawing routines */ - -#define CoordModeOrigin 0 /* relative to the origin */ -#define CoordModePrevious 1 /* relative to previous point */ - -/* Polygon shapes */ - -#define Complex 0 /* paths may intersect */ -#define Nonconvex 1 /* no paths intersect, but not convex */ -#define Convex 2 /* wholly convex */ - -/* Arc modes for PolyFillArc */ - -#define ArcChord 0 /* join endpoints of arc */ -#define ArcPieSlice 1 /* join endpoints to center of arc */ - -/* GC components: masks used in CreateGC, CopyGC, ChangeGC, OR'ed into - GC.stateChanges */ - -#define GCFunction (1L<<0) -#define GCPlaneMask (1L<<1) -#define GCForeground (1L<<2) -#define GCBackground (1L<<3) -#define GCLineWidth (1L<<4) -#define GCLineStyle (1L<<5) -#define GCCapStyle (1L<<6) -#define GCJoinStyle (1L<<7) -#define GCFillStyle (1L<<8) -#define GCFillRule (1L<<9) -#define GCTile (1L<<10) -#define GCStipple (1L<<11) -#define GCTileStipXOrigin (1L<<12) -#define GCTileStipYOrigin (1L<<13) -#define GCFont (1L<<14) -#define GCSubwindowMode (1L<<15) -#define GCGraphicsExposures (1L<<16) -#define GCClipXOrigin (1L<<17) -#define GCClipYOrigin (1L<<18) -#define GCClipMask (1L<<19) -#define GCDashOffset (1L<<20) -#define GCDashList (1L<<21) -#define GCArcMode (1L<<22) - -#define GCLastBit 22 -/***************************************************************** - * FONTS - *****************************************************************/ - -/* used in QueryFont -- draw direction */ - -#define FontLeftToRight 0 -#define FontRightToLeft 1 - -#define FontChange 255 - -/***************************************************************** - * IMAGING - *****************************************************************/ - -/* ImageFormat -- PutImage, GetImage */ - -#define XYBitmap 0 /* depth 1, XYFormat */ -#define XYPixmap 1 /* depth == drawable depth */ -#define ZPixmap 2 /* depth == drawable depth */ - -/***************************************************************** - * COLOR MAP STUFF - *****************************************************************/ - -/* For CreateColormap */ - -#define AllocNone 0 /* create map with no entries */ -#define AllocAll 1 /* allocate entire map writeable */ - - -/* Flags used in StoreNamedColor, StoreColors */ - -#define DoRed (1<<0) -#define DoGreen (1<<1) -#define DoBlue (1<<2) - -/***************************************************************** - * CURSOR STUFF - *****************************************************************/ - -/* QueryBestSize Class */ - -#define CursorShape 0 /* largest size that can be displayed */ -#define TileShape 1 /* size tiled fastest */ -#define StippleShape 2 /* size stippled fastest */ - -/***************************************************************** - * KEYBOARD/POINTER STUFF - *****************************************************************/ - -#define AutoRepeatModeOff 0 -#define AutoRepeatModeOn 1 -#define AutoRepeatModeDefault 2 - -#define LedModeOff 0 -#define LedModeOn 1 - -/* masks for ChangeKeyboardControl */ - -#define KBKeyClickPercent (1L<<0) -#define KBBellPercent (1L<<1) -#define KBBellPitch (1L<<2) -#define KBBellDuration (1L<<3) -#define KBLed (1L<<4) -#define KBLedMode (1L<<5) -#define KBKey (1L<<6) -#define KBAutoRepeatMode (1L<<7) - -#define MappingSuccess 0 -#define MappingBusy 1 -#define MappingFailed 2 - -#define MappingModifier 0 -#define MappingKeyboard 1 -#define MappingPointer 2 - -/***************************************************************** - * SCREEN SAVER STUFF - *****************************************************************/ - -#define DontPreferBlanking 0 -#define PreferBlanking 1 -#define DefaultBlanking 2 - -#define DisableScreenSaver 0 -#define DisableScreenInterval 0 - -#define DontAllowExposures 0 -#define AllowExposures 1 -#define DefaultExposures 2 - -/* for ForceScreenSaver */ - -#define ScreenSaverReset 0 -#define ScreenSaverActive 1 - -/***************************************************************** - * HOSTS AND CONNECTIONS - *****************************************************************/ - -/* for ChangeHosts */ - -#define HostInsert 0 -#define HostDelete 1 - -/* for ChangeAccessControl */ - -#define EnableAccess 1 -#define DisableAccess 0 - -/* Display classes used in opening the connection - * Note that the statically allocated ones are even numbered and the - * dynamically changeable ones are odd numbered */ - -#define StaticGray 0 -#define GrayScale 1 -#define StaticColor 2 -#define PseudoColor 3 -#define TrueColor 4 -#define DirectColor 5 - - -/* Byte order used in imageByteOrder and bitmapBitOrder */ - -#define LSBFirst 0 -#define MSBFirst 1 - -#endif /* X_H */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/XKBlib.h b/btgui/OpenGLWindow/optionalX11/X11/XKBlib.h deleted file mode 100644 index 8f6c72c12..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/XKBlib.h +++ /dev/null @@ -1,1149 +0,0 @@ -/************************************************************ -Copyright (c) 1993 by Silicon Graphics Computer Systems, Inc. - -Permission to use, copy, modify, and distribute this -software and its documentation for any purpose and without -fee is hereby granted, provided that the above copyright -notice appear in all copies and that both that copyright -notice and this permission notice appear in supporting -documentation, and that the name of Silicon Graphics not be -used in advertising or publicity pertaining to distribution -of the software without specific prior written permission. -Silicon Graphics makes no representation about the suitability -of this software for any purpose. It is provided "as is" -without any express or implied warranty. - -SILICON GRAPHICS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS -SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON -GRAPHICS BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL -DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, -DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE -OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH -THE USE OR PERFORMANCE OF THIS SOFTWARE. - -********************************************************/ - -#ifndef _X11_XKBLIB_H_ -#define _X11_XKBLIB_H_ - -#include -#include - -typedef struct _XkbAnyEvent { - int type; /* XkbAnyEvent */ - unsigned long serial; /* # of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XKB event minor code */ - unsigned int device; /* device ID */ -} XkbAnyEvent; - -typedef struct _XkbNewKeyboardNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbNewKeyboardNotify */ - int device; /* device ID */ - int old_device; /* device ID of previous keyboard */ - int min_key_code; /* minimum key code */ - int max_key_code; /* maximum key code */ - int old_min_key_code;/* min key code of previous kbd */ - int old_max_key_code;/* max key code of previous kbd */ - unsigned int changed; /* changed aspects of the keyboard */ - char req_major; /* major and minor opcode of req */ - char req_minor; /* that caused change, if applicable */ -} XkbNewKeyboardNotifyEvent; - -typedef struct _XkbMapNotifyEvent { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbMapNotify */ - int device; /* device ID */ - unsigned int changed; /* fields which have been changed */ - unsigned int flags; /* reserved */ - int first_type; /* first changed key type */ - int num_types; /* number of changed key types */ - KeyCode min_key_code; - KeyCode max_key_code; - KeyCode first_key_sym; - KeyCode first_key_act; - KeyCode first_key_behavior; - KeyCode first_key_explicit; - KeyCode first_modmap_key; - KeyCode first_vmodmap_key; - int num_key_syms; - int num_key_acts; - int num_key_behaviors; - int num_key_explicit; - int num_modmap_keys; - int num_vmodmap_keys; - unsigned int vmods; /* mask of changed virtual mods */ -} XkbMapNotifyEvent; - -typedef struct _XkbStateNotifyEvent { - int type; /* XkbAnyEvent */ - unsigned long serial; /* # of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbStateNotify */ - int device; /* device ID */ - unsigned int changed; /* mask of changed state components */ - int group; /* keyboard group */ - int base_group; /* base keyboard group */ - int latched_group; /* latched keyboard group */ - int locked_group; /* locked keyboard group */ - unsigned int mods; /* modifier state */ - unsigned int base_mods; /* base modifier state */ - unsigned int latched_mods; /* latched modifiers */ - unsigned int locked_mods; /* locked modifiers */ - int compat_state; /* compatibility state */ - unsigned char grab_mods; /* mods used for grabs */ - unsigned char compat_grab_mods;/* grab mods for non-XKB clients */ - unsigned char lookup_mods; /* mods sent to clients */ - unsigned char compat_lookup_mods; /* mods sent to non-XKB clients */ - int ptr_buttons; /* pointer button state */ - KeyCode keycode; /* keycode that caused the change */ - char event_type; /* KeyPress or KeyRelease */ - char req_major; /* Major opcode of request */ - char req_minor; /* Minor opcode of request */ -} XkbStateNotifyEvent; - -typedef struct _XkbControlsNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbControlsNotify */ - int device; /* device ID */ - unsigned int changed_ctrls; /* controls with changed sub-values */ - unsigned int enabled_ctrls; /* controls currently enabled */ - unsigned int enabled_ctrl_changes;/* controls just {en,dis}abled */ - int num_groups; /* total groups on keyboard */ - KeyCode keycode; /* key that caused change or 0 */ - char event_type; /* type of event that caused change */ - char req_major; /* if keycode==0, major and minor */ - char req_minor; /* opcode of req that caused change */ -} XkbControlsNotifyEvent; - -typedef struct _XkbIndicatorNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbIndicatorNotify */ - int device; /* device ID */ - unsigned int changed; /* indicators with new state or map */ - unsigned int state; /* current state of all indicators */ -} XkbIndicatorNotifyEvent; - -typedef struct _XkbNamesNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbNamesNotify */ - int device; /* device ID */ - unsigned int changed; /* names that have changed */ - int first_type; /* first key type with new name */ - int num_types; /* number of key types with new names */ - int first_lvl; /* first key type new new level names */ - int num_lvls; /* # of key types w/new level names */ - int num_aliases; /* total number of key aliases*/ - int num_radio_groups;/* total number of radio groups */ - unsigned int changed_vmods; /* virtual modifiers with new names */ - unsigned int changed_groups; /* groups with new names */ - unsigned int changed_indicators;/* indicators with new names */ - int first_key; /* first key with new name */ - int num_keys; /* number of keys with new names */ -} XkbNamesNotifyEvent; - -typedef struct _XkbCompatMapNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbCompatMapNotify */ - int device; /* device ID */ - unsigned int changed_groups; /* groups with new compat maps */ - int first_si; /* first new symbol interp */ - int num_si; /* number of new symbol interps */ - int num_total_si; /* total # of symbol interps */ -} XkbCompatMapNotifyEvent; - -typedef struct _XkbBellNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbBellNotify */ - int device; /* device ID */ - int percent; /* requested volume as a % of maximum */ - int pitch; /* requested pitch in Hz */ - int duration; /* requested duration in useconds */ - int bell_class; /* (input extension) feedback class */ - int bell_id; /* (input extension) ID of feedback */ - Atom name; /* "name" of requested bell */ - Window window; /* window associated with event */ - Bool event_only; /* "event only" requested */ -} XkbBellNotifyEvent; - -typedef struct _XkbActionMessage { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbActionMessage */ - int device; /* device ID */ - KeyCode keycode; /* key that generated the event */ - Bool press; /* true if act caused by key press */ - Bool key_event_follows;/* true if key event also generated */ - int group; /* effective group */ - unsigned int mods; /* effective mods */ - char message[XkbActionMessageLength+1]; - /* message -- leave space for NUL */ -} XkbActionMessageEvent; - -typedef struct _XkbAccessXNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbAccessXNotify */ - int device; /* device ID */ - int detail; /* XkbAXN_* */ - int keycode; /* key of event */ - int sk_delay; /* current slow keys delay */ - int debounce_delay; /* current debounce delay */ -} XkbAccessXNotifyEvent; - -typedef struct _XkbExtensionDeviceNotify { - int type; /* XkbAnyEvent */ - unsigned long serial; /* of last req processed by server */ - Bool send_event; /* is this from a SendEvent request? */ - Display * display; /* Display the event was read from */ - Time time; /* milliseconds */ - int xkb_type; /* XkbExtensionDeviceNotify */ - int device; /* device ID */ - unsigned int reason; /* reason for the event */ - unsigned int supported; /* mask of supported features */ - unsigned int unsupported; /* mask of unsupported features */ - /* that some app tried to use */ - int first_btn; /* first button that changed */ - int num_btns; /* range of buttons changed */ - unsigned int leds_defined; /* indicators with names or maps */ - unsigned int led_state; /* current state of the indicators */ - int led_class; /* feedback class for led changes */ - int led_id; /* feedback id for led changes */ -} XkbExtensionDeviceNotifyEvent; - -typedef union _XkbEvent { - int type; - XkbAnyEvent any; - XkbNewKeyboardNotifyEvent new_kbd; - XkbMapNotifyEvent map; - XkbStateNotifyEvent state; - XkbControlsNotifyEvent ctrls; - XkbIndicatorNotifyEvent indicators; - XkbNamesNotifyEvent names; - XkbCompatMapNotifyEvent compat; - XkbBellNotifyEvent bell; - XkbActionMessageEvent message; - XkbAccessXNotifyEvent accessx; - XkbExtensionDeviceNotifyEvent device; - XEvent core; -} XkbEvent; - -typedef struct _XkbKbdDpyState XkbKbdDpyStateRec,*XkbKbdDpyStatePtr; - - /* XkbOpenDisplay error codes */ -#define XkbOD_Success 0 -#define XkbOD_BadLibraryVersion 1 -#define XkbOD_ConnectionRefused 2 -#define XkbOD_NonXkbServer 3 -#define XkbOD_BadServerVersion 4 - - /* Values for XlibFlags */ -#define XkbLC_ForceLatin1Lookup (1<<0) -#define XkbLC_ConsumeLookupMods (1<<1) -#define XkbLC_AlwaysConsumeShiftAndLock (1<<2) -#define XkbLC_IgnoreNewKeyboards (1<<3) -#define XkbLC_ControlFallback (1<<4) -#define XkbLC_ConsumeKeysOnComposeFail (1<<29) -#define XkbLC_ComposeLED (1<<30) -#define XkbLC_BeepOnComposeFail (1<<31) - -#define XkbLC_AllComposeControls (0xc0000000) -#define XkbLC_AllControls (0xc000001f) - -_XFUNCPROTOBEGIN - -extern Bool XkbIgnoreExtension( - Bool /* ignore */ -); - -extern Display *XkbOpenDisplay( - char * /* name */, - int * /* ev_rtrn */, - int * /* err_rtrn */, - int * /* major_rtrn */, - int * /* minor_rtrn */, - int * /* reason */ -); - -extern Bool XkbQueryExtension( - Display * /* dpy */, - int * /* opcodeReturn */, - int * /* eventBaseReturn */, - int * /* errorBaseReturn */, - int * /* majorRtrn */, - int * /* minorRtrn */ -); - -extern Bool XkbUseExtension( - Display * /* dpy */, - int * /* major_rtrn */, - int * /* minor_rtrn */ -); - -extern Bool XkbLibraryVersion( - int * /* libMajorRtrn */, - int * /* libMinorRtrn */ -); - -extern unsigned int XkbSetXlibControls( - Display* /* dpy */, - unsigned int /* affect */, - unsigned int /* values */ -); - -extern unsigned int XkbGetXlibControls( - Display* /* dpy */ -); - -extern unsigned int XkbXlibControlsImplemented(void); - -typedef Atom (*XkbInternAtomFunc)( - Display * /* dpy */, - _Xconst char * /* name */, - Bool /* only_if_exists */ -); - -typedef char * (*XkbGetAtomNameFunc)( - Display * /* dpy */, - Atom /* atom */ -); - -extern void XkbSetAtomFuncs( - XkbInternAtomFunc /* getAtom */, - XkbGetAtomNameFunc /* getName */ -); - -extern KeySym XkbKeycodeToKeysym( - Display * /* dpy */, -#if NeedWidePrototypes - unsigned int /* kc */, -#else - KeyCode /* kc */, -#endif - int /* group */, - int /* level */ -); - -extern unsigned int XkbKeysymToModifiers( - Display * /* dpy */, - KeySym /* ks */ -); - -extern Bool XkbLookupKeySym( - Display * /* dpy */, - KeyCode /* keycode */, - unsigned int /* modifiers */, - unsigned int * /* modifiers_return */, - KeySym * /* keysym_return */ -); - -extern int XkbLookupKeyBinding( - Display * /* dpy */, - KeySym /* sym_rtrn */, - unsigned int /* mods */, - char * /* buffer */, - int /* nbytes */, - int * /* extra_rtrn */ -); - -extern Bool XkbTranslateKeyCode( - XkbDescPtr /* xkb */, - KeyCode /* keycode */, - unsigned int /* modifiers */, - unsigned int * /* modifiers_return */, - KeySym * /* keysym_return */ -); - -extern int XkbTranslateKeySym( - Display * /* dpy */, - register KeySym * /* sym_return */, - unsigned int /* modifiers */, - char * /* buffer */, - int /* nbytes */, - int * /* extra_rtrn */ -); - -extern Bool XkbSetAutoRepeatRate( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* delay */, - unsigned int /* interval */ -); - -extern Bool XkbGetAutoRepeatRate( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int * /* delayRtrn */, - unsigned int * /* intervalRtrn */ -); - -extern Bool XkbChangeEnabledControls( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* affect */, - unsigned int /* values */ -); - -extern Bool XkbDeviceBell( - Display * /* dpy */, - Window /* win */, - int /* deviceSpec */, - int /* bellClass */, - int /* bellID */, - int /* percent */, - Atom /* name */ -); - -extern Bool XkbForceDeviceBell( - Display * /* dpy */, - int /* deviceSpec */, - int /* bellClass */, - int /* bellID */, - int /* percent */ -); - -extern Bool XkbDeviceBellEvent( - Display * /* dpy */, - Window /* win */, - int /* deviceSpec */, - int /* bellClass */, - int /* bellID */, - int /* percent */, - Atom /* name */ -); - -extern Bool XkbBell( - Display * /* dpy */, - Window /* win */, - int /* percent */, - Atom /* name */ -); - -extern Bool XkbForceBell( - Display * /* dpy */, - int /* percent */ -); - -extern Bool XkbBellEvent( - Display * /* dpy */, - Window /* win */, - int /* percent */, - Atom /* name */ -); - -extern Bool XkbSelectEvents( - Display * /* dpy */, - unsigned int /* deviceID */, - unsigned int /* affect */, - unsigned int /* values */ -); - -extern Bool XkbSelectEventDetails( - Display * /* dpy */, - unsigned int /* deviceID */, - unsigned int /* eventType */, - unsigned long /* affect */, - unsigned long /* details */ -); - -extern void XkbNoteMapChanges( - XkbMapChangesPtr /* old */, - XkbMapNotifyEvent * /* new */, - unsigned int /* wanted */ -); - -extern void XkbNoteNameChanges( - XkbNameChangesPtr /* old */, - XkbNamesNotifyEvent * /* new */, - unsigned int /* wanted */ -); - -extern Status XkbGetIndicatorState( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int * /* pStateRtrn */ -); - -extern Status XkbGetDeviceIndicatorState( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* ledClass */, - unsigned int /* ledID */, - unsigned int * /* pStateRtrn */ -); - -extern Status XkbGetIndicatorMap( - Display * /* dpy */, - unsigned long /* which */, - XkbDescPtr /* desc */ -); - -extern Bool XkbSetIndicatorMap( - Display * /* dpy */, - unsigned long /* which */, - XkbDescPtr /* desc */ -); - -#define XkbNoteIndicatorMapChanges(o,n,w) \ - ((o)->map_changes|=((n)->map_changes&(w))) -#define XkbNoteIndicatorStateChanges(o,n,w)\ - ((o)->state_changes|=((n)->state_changes&(w))) -#define XkbGetIndicatorMapChanges(d,x,c) \ - (XkbGetIndicatorMap((d),(c)->map_changes,x)) -#define XkbChangeIndicatorMaps(d,x,c) \ - (XkbSetIndicatorMap((d),(c)->map_changes,x)) - -extern Bool XkbGetNamedIndicator( - Display * /* dpy */, - Atom /* name */, - int * /* pNdxRtrn */, - Bool * /* pStateRtrn */, - XkbIndicatorMapPtr /* pMapRtrn */, - Bool * /* pRealRtrn */ -); - -extern Bool XkbGetNamedDeviceIndicator( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* ledClass */, - unsigned int /* ledID */, - Atom /* name */, - int * /* pNdxRtrn */, - Bool * /* pStateRtrn */, - XkbIndicatorMapPtr /* pMapRtrn */, - Bool * /* pRealRtrn */ -); - -extern Bool XkbSetNamedIndicator( - Display * /* dpy */, - Atom /* name */, - Bool /* changeState */, - Bool /* state */, - Bool /* createNewMap */, - XkbIndicatorMapPtr /* pMap */ -); - -extern Bool XkbSetNamedDeviceIndicator( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* ledClass */, - unsigned int /* ledID */, - Atom /* name */, - Bool /* changeState */, - Bool /* state */, - Bool /* createNewMap */, - XkbIndicatorMapPtr /* pMap */ -); - -extern Bool XkbLockModifiers( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* affect */, - unsigned int /* values */ -); - -extern Bool XkbLatchModifiers( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* affect */, - unsigned int /* values */ -); - -extern Bool XkbLockGroup( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* group */ -); - -extern Bool XkbLatchGroup( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* group */ -); - -extern Bool XkbSetServerInternalMods( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* affectReal */, - unsigned int /* realValues */, - unsigned int /* affectVirtual */, - unsigned int /* virtualValues */ -); - -extern Bool XkbSetIgnoreLockMods( - Display * /* dpy */, - unsigned int /* deviceSpec */, - unsigned int /* affectReal */, - unsigned int /* realValues */, - unsigned int /* affectVirtual */, - unsigned int /* virtualValues */ -); - - -extern Bool XkbVirtualModsToReal( - XkbDescPtr /* xkb */, - unsigned int /* virtual_mask */, - unsigned int * /* mask_rtrn */ -); - -extern Bool XkbComputeEffectiveMap( - XkbDescPtr /* xkb */, - XkbKeyTypePtr /* type */, - unsigned char * /* map_rtrn */ -); - -extern Status XkbInitCanonicalKeyTypes( - XkbDescPtr /* xkb */, - unsigned int /* which */, - int /* keypadVMod */ -); - -extern XkbDescPtr XkbAllocKeyboard( - void -); - -extern void XkbFreeKeyboard( - XkbDescPtr /* xkb */, - unsigned int /* which */, - Bool /* freeDesc */ -); - -extern Status XkbAllocClientMap( - XkbDescPtr /* xkb */, - unsigned int /* which */, - unsigned int /* nTypes */ -); - -extern Status XkbAllocServerMap( - XkbDescPtr /* xkb */, - unsigned int /* which */, - unsigned int /* nActions */ -); - -extern void XkbFreeClientMap( - XkbDescPtr /* xkb */, - unsigned int /* what */, - Bool /* freeMap */ -); - -extern void XkbFreeServerMap( - XkbDescPtr /* xkb */, - unsigned int /* what */, - Bool /* freeMap */ -); - -extern XkbKeyTypePtr XkbAddKeyType( - XkbDescPtr /* xkb */, - Atom /* name */, - int /* map_count */, - Bool /* want_preserve */, - int /* num_lvls */ -); - -extern Status XkbAllocIndicatorMaps( - XkbDescPtr /* xkb */ -); - -extern void XkbFreeIndicatorMaps( - XkbDescPtr /* xkb */ -); - -extern XkbDescPtr XkbGetMap( - Display * /* dpy */, - unsigned int /* which */, - unsigned int /* deviceSpec */ -); - -extern Status XkbGetUpdatedMap( - Display * /* dpy */, - unsigned int /* which */, - XkbDescPtr /* desc */ -); - -extern Status XkbGetMapChanges( - Display * /* dpy */, - XkbDescPtr /* xkb */, - XkbMapChangesPtr /* changes */ -); - - -extern Status XkbRefreshKeyboardMapping( - XkbMapNotifyEvent * /* event */ -); - -extern Status XkbGetKeyTypes( - Display * /* dpy */, - unsigned int /* first */, - unsigned int /* num */, - XkbDescPtr /* xkb */ -); - -extern Status XkbGetKeySyms( - Display * /* dpy */, - unsigned int /* first */, - unsigned int /* num */, - XkbDescPtr /* xkb */ -); - -extern Status XkbGetKeyActions( - Display * /* dpy */, - unsigned int /* first */, - unsigned int /* num */, - XkbDescPtr /* xkb */ -); - -extern Status XkbGetKeyBehaviors( - Display * /* dpy */, - unsigned int /* firstKey */, - unsigned int /* nKeys */, - XkbDescPtr /* desc */ -); - -extern Status XkbGetVirtualMods( - Display * /* dpy */, - unsigned int /* which */, - XkbDescPtr /* desc */ -); - -extern Status XkbGetKeyExplicitComponents( - Display * /* dpy */, - unsigned int /* firstKey */, - unsigned int /* nKeys */, - XkbDescPtr /* desc */ -); - -extern Status XkbGetKeyModifierMap( - Display * /* dpy */, - unsigned int /* firstKey */, - unsigned int /* nKeys */, - XkbDescPtr /* desc */ -); - -extern Status XkbGetKeyVirtualModMap( - Display * /* dpy */, - unsigned int /* first */, - unsigned int /* num */, - XkbDescPtr /* xkb */ -); - -extern Status XkbAllocControls( - XkbDescPtr /* xkb */, - unsigned int /* which*/ -); - -extern void XkbFreeControls( - XkbDescPtr /* xkb */, - unsigned int /* which */, - Bool /* freeMap */ -); - -extern Status XkbGetControls( - Display * /* dpy */, - unsigned long /* which */, - XkbDescPtr /* desc */ -); - -extern Bool XkbSetControls( - Display * /* dpy */, - unsigned long /* which */, - XkbDescPtr /* desc */ -); - -extern void XkbNoteControlsChanges( - XkbControlsChangesPtr /* old */, - XkbControlsNotifyEvent * /* new */, - unsigned int /* wanted */ -); - -#define XkbGetControlsChanges(d,x,c) XkbGetControls(d,(c)->changed_ctrls,x) -#define XkbChangeControls(d,x,c) XkbSetControls(d,(c)->changed_ctrls,x) - -extern Status XkbAllocCompatMap( - XkbDescPtr /* xkb */, - unsigned int /* which */, - unsigned int /* nInterpret */ -); - -extern void XkbFreeCompatMap( - XkbDescPtr /* xkb */, - unsigned int /* which */, - Bool /* freeMap */ -); - -extern Status XkbGetCompatMap( - Display * /* dpy */, - unsigned int /* which */, - XkbDescPtr /* xkb */ -); - -extern Bool XkbSetCompatMap( - Display * /* dpy */, - unsigned int /* which */, - XkbDescPtr /* xkb */, - Bool /* updateActions */ -); - -extern XkbSymInterpretPtr XkbAddSymInterpret( - XkbDescPtr /* xkb */, - XkbSymInterpretPtr /* si */, - Bool /* updateMap */, - XkbChangesPtr /* changes */ -); - -extern Status XkbAllocNames( - XkbDescPtr /* xkb */, - unsigned int /* which */, - int /* nTotalRG */, - int /* nTotalAliases */ -); - -extern Status XkbGetNames( - Display * /* dpy */, - unsigned int /* which */, - XkbDescPtr /* desc */ -); - -extern Bool XkbSetNames( - Display * /* dpy */, - unsigned int /* which */, - unsigned int /* firstType */, - unsigned int /* nTypes */, - XkbDescPtr /* desc */ -); - -extern Bool XkbChangeNames( - Display * /* dpy */, - XkbDescPtr /* xkb */, - XkbNameChangesPtr /* changes */ -); - -extern void XkbFreeNames( - XkbDescPtr /* xkb */, - unsigned int /* which */, - Bool /* freeMap */ -); - - -extern Status XkbGetState( - Display * /* dpy */, - unsigned int /* deviceSpec */, - XkbStatePtr /* rtrnState */ -); - -extern Bool XkbSetMap( - Display * /* dpy */, - unsigned int /* which */, - XkbDescPtr /* desc */ -); - -extern Bool XkbChangeMap( - Display* /* dpy */, - XkbDescPtr /* desc */, - XkbMapChangesPtr /* changes */ -); - -extern Bool XkbSetDetectableAutoRepeat( - Display * /* dpy */, - Bool /* detectable */, - Bool * /* supported */ -); - -extern Bool XkbGetDetectableAutoRepeat( - Display * /* dpy */, - Bool * /* supported */ -); - -extern Bool XkbSetAutoResetControls( - Display * /* dpy */, - unsigned int /* changes */, - unsigned int * /* auto_ctrls */, - unsigned int * /* auto_values */ -); - -extern Bool XkbGetAutoResetControls( - Display * /* dpy */, - unsigned int * /* auto_ctrls */, - unsigned int * /* auto_ctrl_values */ -); - -extern Bool XkbSetPerClientControls( - Display * /* dpy */, - unsigned int /* change */, - unsigned int * /* values */ -); - -extern Bool XkbGetPerClientControls( - Display * /* dpy */, - unsigned int * /* ctrls */ -); - -extern Status XkbCopyKeyType( - XkbKeyTypePtr /* from */, - XkbKeyTypePtr /* into */ -); - -extern Status XkbCopyKeyTypes( - XkbKeyTypePtr /* from */, - XkbKeyTypePtr /* into */, - int /* num_types */ -); - -extern Status XkbResizeKeyType( - XkbDescPtr /* xkb */, - int /* type_ndx */, - int /* map_count */, - Bool /* want_preserve */, - int /* new_num_lvls */ -); - -extern KeySym *XkbResizeKeySyms( - XkbDescPtr /* desc */, - int /* forKey */, - int /* symsNeeded */ -); - -extern XkbAction *XkbResizeKeyActions( - XkbDescPtr /* desc */, - int /* forKey */, - int /* actsNeeded */ -); - -extern Status XkbChangeTypesOfKey( - XkbDescPtr /* xkb */, - int /* key */, - int /* num_groups */, - unsigned int /* groups */, - int * /* newTypes */, - XkbMapChangesPtr /* pChanges */ -); - -extern Status XkbChangeKeycodeRange( - XkbDescPtr /* xkb */, - int /* minKC */, - int /* maxKC */, - XkbChangesPtr /* changes */ -); - -/***====================================================================***/ - -extern XkbComponentListPtr XkbListComponents( - Display * /* dpy */, - unsigned int /* deviceSpec */, - XkbComponentNamesPtr /* ptrns */, - int * /* max_inout */ -); - -extern void XkbFreeComponentList( - XkbComponentListPtr /* list */ -); - -extern XkbDescPtr XkbGetKeyboard( - Display * /* dpy */, - unsigned int /* which */, - unsigned int /* deviceSpec */ -); - -extern XkbDescPtr XkbGetKeyboardByName( - Display * /* dpy */, - unsigned int /* deviceSpec */, - XkbComponentNamesPtr /* names */, - unsigned int /* want */, - unsigned int /* need */, - Bool /* load */ -); - -/***====================================================================***/ - -extern int XkbKeyTypesForCoreSymbols( /* returns # of groups */ - XkbDescPtr /* xkb */, /* keyboard device */ - int /* map_width */, /* width of core KeySym array */ - KeySym * /* core_syms */, /* always mapWidth symbols */ - unsigned int /* protected */, /* explicit key types */ - int * /* types_inout */, /* always four type indices */ - KeySym * /* xkb_syms_rtrn */ /* must have enough space */ -); - -extern Bool XkbApplyCompatMapToKey( /* False only on error */ - XkbDescPtr /* xkb */, /* keymap to be edited */ - KeyCode /* key */, /* key to be updated */ - XkbChangesPtr /* changes */ /* resulting changes to map */ -); - -extern Bool XkbUpdateMapFromCore( /* False only on error */ - XkbDescPtr /* xkb */, /* XKB keyboard to be edited */ - KeyCode /* first_key */, /* first changed key */ - int /* num_keys */, /* number of changed keys */ - int /* map_width */, /* width of core keymap */ - KeySym * /* core_keysyms */, /* symbols from core keymap */ - XkbChangesPtr /* changes */ /* resulting changes */ -); - -/***====================================================================***/ - -extern XkbDeviceLedInfoPtr XkbAddDeviceLedInfo( - XkbDeviceInfoPtr /* devi */, - unsigned int /* ledClass */, - unsigned int /* ledId */ -); - -extern Status XkbResizeDeviceButtonActions( - XkbDeviceInfoPtr /* devi */, - unsigned int /* newTotal */ -); - -extern XkbDeviceInfoPtr XkbAllocDeviceInfo( - unsigned int /* deviceSpec */, - unsigned int /* nButtons */, - unsigned int /* szLeds */ -); - -extern void XkbFreeDeviceInfo( - XkbDeviceInfoPtr /* devi */, - unsigned int /* which */, - Bool /* freeDevI */ -); - -extern void XkbNoteDeviceChanges( - XkbDeviceChangesPtr /* old */, - XkbExtensionDeviceNotifyEvent * /* new */, - unsigned int /* wanted */ -); - -extern XkbDeviceInfoPtr XkbGetDeviceInfo( - Display * /* dpy */, - unsigned int /* which */, - unsigned int /* deviceSpec */, - unsigned int /* ledClass */, - unsigned int /* ledID */ -); - -extern Status XkbGetDeviceInfoChanges( - Display * /* dpy */, - XkbDeviceInfoPtr /* devi */, - XkbDeviceChangesPtr /* changes */ -); - -extern Status XkbGetDeviceButtonActions( - Display * /* dpy */, - XkbDeviceInfoPtr /* devi */, - Bool /* all */, - unsigned int /* first */, - unsigned int /* nBtns */ -); - -extern Status XkbGetDeviceLedInfo( - Display * /* dpy */, - XkbDeviceInfoPtr /* devi */, - unsigned int /* ledClass (class, XIDflt, XIAll) */, - unsigned int /* ledId (id, XIDflt, XIAll) */, - unsigned int /* which (XkbXI_Indicator{Names,Map}Mask */ -); - -extern Bool XkbSetDeviceInfo( - Display * /* dpy */, - unsigned int /* which */, - XkbDeviceInfoPtr /* devi */ -); - -extern Bool XkbChangeDeviceInfo( - Display* /* dpy */, - XkbDeviceInfoPtr /* desc */, - XkbDeviceChangesPtr /* changes */ -); - -extern Bool XkbSetDeviceLedInfo( - Display * /* dpy */, - XkbDeviceInfoPtr /* devi */, - unsigned int /* ledClass */, - unsigned int /* ledID */, - unsigned int /* which */ -); - -extern Bool XkbSetDeviceButtonActions( - Display * /* dpy */, - XkbDeviceInfoPtr /* devi */, - unsigned int /* first */, - unsigned int /* nBtns */ -); - -/***====================================================================***/ - -extern char XkbToControl( - char /* c */ -); - -/***====================================================================***/ - -extern Bool XkbSetDebuggingFlags( - Display * /* dpy */, - unsigned int /* mask */, - unsigned int /* flags */, - char * /* msg */, - unsigned int /* ctrls_mask */, - unsigned int /* ctrls */, - unsigned int * /* rtrn_flags */, - unsigned int * /* rtrn_ctrls */ -); - -extern Bool XkbApplyVirtualModChanges( - XkbDescPtr /* xkb */, - unsigned int /* changed */, - XkbChangesPtr /* changes */ -); - -extern Bool XkbUpdateActionVirtualMods( - XkbDescPtr /* xkb */, - XkbAction * /* act */, - unsigned int /* changed */ -); - -extern void XkbUpdateKeyTypeVirtualMods( - XkbDescPtr /* xkb */, - XkbKeyTypePtr /* type */, - unsigned int /* changed */, - XkbChangesPtr /* changes */ -); - -_XFUNCPROTOEND - -#endif /* _X11_XKBLIB_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xatom.h b/btgui/OpenGLWindow/optionalX11/X11/Xatom.h deleted file mode 100644 index 485a4236d..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xatom.h +++ /dev/null @@ -1,79 +0,0 @@ -#ifndef XATOM_H -#define XATOM_H 1 - -/* THIS IS A GENERATED FILE - * - * Do not change! Changing this file implies a protocol change! - */ - -#define XA_PRIMARY ((Atom) 1) -#define XA_SECONDARY ((Atom) 2) -#define XA_ARC ((Atom) 3) -#define XA_ATOM ((Atom) 4) -#define XA_BITMAP ((Atom) 5) -#define XA_CARDINAL ((Atom) 6) -#define XA_COLORMAP ((Atom) 7) -#define XA_CURSOR ((Atom) 8) -#define XA_CUT_BUFFER0 ((Atom) 9) -#define XA_CUT_BUFFER1 ((Atom) 10) -#define XA_CUT_BUFFER2 ((Atom) 11) -#define XA_CUT_BUFFER3 ((Atom) 12) -#define XA_CUT_BUFFER4 ((Atom) 13) -#define XA_CUT_BUFFER5 ((Atom) 14) -#define XA_CUT_BUFFER6 ((Atom) 15) -#define XA_CUT_BUFFER7 ((Atom) 16) -#define XA_DRAWABLE ((Atom) 17) -#define XA_FONT ((Atom) 18) -#define XA_INTEGER ((Atom) 19) -#define XA_PIXMAP ((Atom) 20) -#define XA_POINT ((Atom) 21) -#define XA_RECTANGLE ((Atom) 22) -#define XA_RESOURCE_MANAGER ((Atom) 23) -#define XA_RGB_COLOR_MAP ((Atom) 24) -#define XA_RGB_BEST_MAP ((Atom) 25) -#define XA_RGB_BLUE_MAP ((Atom) 26) -#define XA_RGB_DEFAULT_MAP ((Atom) 27) -#define XA_RGB_GRAY_MAP ((Atom) 28) -#define XA_RGB_GREEN_MAP ((Atom) 29) -#define XA_RGB_RED_MAP ((Atom) 30) -#define XA_STRING ((Atom) 31) -#define XA_VISUALID ((Atom) 32) -#define XA_WINDOW ((Atom) 33) -#define XA_WM_COMMAND ((Atom) 34) -#define XA_WM_HINTS ((Atom) 35) -#define XA_WM_CLIENT_MACHINE ((Atom) 36) -#define XA_WM_ICON_NAME ((Atom) 37) -#define XA_WM_ICON_SIZE ((Atom) 38) -#define XA_WM_NAME ((Atom) 39) -#define XA_WM_NORMAL_HINTS ((Atom) 40) -#define XA_WM_SIZE_HINTS ((Atom) 41) -#define XA_WM_ZOOM_HINTS ((Atom) 42) -#define XA_MIN_SPACE ((Atom) 43) -#define XA_NORM_SPACE ((Atom) 44) -#define XA_MAX_SPACE ((Atom) 45) -#define XA_END_SPACE ((Atom) 46) -#define XA_SUPERSCRIPT_X ((Atom) 47) -#define XA_SUPERSCRIPT_Y ((Atom) 48) -#define XA_SUBSCRIPT_X ((Atom) 49) -#define XA_SUBSCRIPT_Y ((Atom) 50) -#define XA_UNDERLINE_POSITION ((Atom) 51) -#define XA_UNDERLINE_THICKNESS ((Atom) 52) -#define XA_STRIKEOUT_ASCENT ((Atom) 53) -#define XA_STRIKEOUT_DESCENT ((Atom) 54) -#define XA_ITALIC_ANGLE ((Atom) 55) -#define XA_X_HEIGHT ((Atom) 56) -#define XA_QUAD_WIDTH ((Atom) 57) -#define XA_WEIGHT ((Atom) 58) -#define XA_POINT_SIZE ((Atom) 59) -#define XA_RESOLUTION ((Atom) 60) -#define XA_COPYRIGHT ((Atom) 61) -#define XA_NOTICE ((Atom) 62) -#define XA_FONT_NAME ((Atom) 63) -#define XA_FAMILY_NAME ((Atom) 64) -#define XA_FULL_NAME ((Atom) 65) -#define XA_CAP_HEIGHT ((Atom) 66) -#define XA_WM_CLASS ((Atom) 67) -#define XA_WM_TRANSIENT_FOR ((Atom) 68) - -#define XA_LAST_PREDEFINED ((Atom) 68) -#endif /* XATOM_H */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xfuncproto.h b/btgui/OpenGLWindow/optionalX11/X11/Xfuncproto.h deleted file mode 100644 index 3a074aaab..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xfuncproto.h +++ /dev/null @@ -1,175 +0,0 @@ -/* Xfuncproto.h. Generated from Xfuncproto.h.in by configure. */ -/* - * -Copyright 1989, 1991, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - * - */ - -/* Definitions to make function prototypes manageable */ - -#ifndef _XFUNCPROTO_H_ -#define _XFUNCPROTO_H_ - -#ifndef NeedFunctionPrototypes -#define NeedFunctionPrototypes 1 -#endif /* NeedFunctionPrototypes */ - -#ifndef NeedVarargsPrototypes -#define NeedVarargsPrototypes 1 -#endif /* NeedVarargsPrototypes */ - -#if NeedFunctionPrototypes - -#ifndef NeedNestedPrototypes -#define NeedNestedPrototypes 1 -#endif /* NeedNestedPrototypes */ - -#ifndef _Xconst -#define _Xconst const -#endif /* _Xconst */ - -/* Function prototype configuration (see configure for more info) */ -#ifndef NARROWPROTO -#define NARROWPROTO /**/ -#endif -#ifndef FUNCPROTO -#define FUNCPROTO 15 -#endif - -#ifndef NeedWidePrototypes -#ifdef NARROWPROTO -#define NeedWidePrototypes 0 -#else -#define NeedWidePrototypes 1 /* default to make interropt. easier */ -#endif -#endif /* NeedWidePrototypes */ - -#endif /* NeedFunctionPrototypes */ - -#ifndef _XFUNCPROTOBEGIN -#if defined(__cplusplus) || defined(c_plusplus) /* for C++ V2.0 */ -#define _XFUNCPROTOBEGIN extern "C" { /* do not leave open across includes */ -#define _XFUNCPROTOEND } -#else -#define _XFUNCPROTOBEGIN -#define _XFUNCPROTOEND -#endif -#endif /* _XFUNCPROTOBEGIN */ - -/* Added in X11R6.9, so available in any version of modular xproto */ -#if defined(__GNUC__) && (__GNUC__ >= 4) -# define _X_SENTINEL(x) __attribute__ ((__sentinel__(x))) -#else -# define _X_SENTINEL(x) -#endif /* GNUC >= 4 */ - -/* Added in X11R6.9, so available in any version of modular xproto */ -#if defined(__GNUC__) && (__GNUC__ >= 4) && !defined(__CYGWIN__) && !defined(__MINGW32__) -# define _X_EXPORT __attribute__((visibility("default"))) -# define _X_HIDDEN __attribute__((visibility("hidden"))) -# define _X_INTERNAL __attribute__((visibility("internal"))) -#elif defined(__SUNPRO_C) && (__SUNPRO_C >= 0x550) -# define _X_EXPORT __global -# define _X_HIDDEN __hidden -# define _X_INTERNAL __hidden -#else /* not gcc >= 4 and not Sun Studio >= 8 */ -# define _X_EXPORT -# define _X_HIDDEN -# define _X_INTERNAL -#endif /* GNUC >= 4 */ - -/* requires xproto >= 7.0.9 */ -#if defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 303) -# define _X_LIKELY(x) __builtin_expect(!!(x), 1) -# define _X_UNLIKELY(x) __builtin_expect(!!(x), 0) -#else /* not gcc >= 3.3 */ -# define _X_LIKELY(x) (x) -# define _X_UNLIKELY(x) (x) -#endif - -/* Added in X11R6.9, so available in any version of modular xproto */ -#if defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 301) -# define _X_DEPRECATED __attribute__((deprecated)) -#else /* not gcc >= 3.1 */ -# define _X_DEPRECATED -#endif - -/* requires xproto >= 7.0.17 */ -#if (defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 205)) \ - || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)) -# define _X_NORETURN __attribute((noreturn)) -#else -# define _X_NORETURN -#endif /* GNUC */ - -/* Added in X11R6.9, so available in any version of modular xproto */ -#if defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 203) -# define _X_ATTRIBUTE_PRINTF(x,y) __attribute__((__format__(__printf__,x,y))) -#else /* not gcc >= 2.3 */ -# define _X_ATTRIBUTE_PRINTF(x,y) -#endif - -/* requires xproto >= 7.0.22 - since this uses either gcc or C99 variable - argument macros, must be only used inside #ifdef _X_NONNULL guards, as - many legacy X clients are compiled in C89 mode still. */ -#if defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 303) -#define _X_NONNULL(args...) __attribute__((nonnull(args))) -#elif defined(__STDC_VERSION__) && (__STDC_VERSION__ - 0 >= 199901L) /* C99 */ -#define _X_NONNULL(...) /* */ -#endif - -/* requires xproto >= 7.0.22 */ -#if defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 205) -#define _X_UNUSED __attribute__((__unused__)) -#else -#define _X_UNUSED /* */ -#endif - -/* C99 keyword "inline" or equivalent extensions in pre-C99 compilers */ -/* requires xproto >= 7.0.9 - (introduced in 7.0.8 but didn't support all compilers until 7.0.9) */ -#if defined(inline) /* assume autoconf set it correctly */ || \ - (defined(__STDC_VERSION__) && (__STDC_VERSION__ - 0 >= 199901L)) /* C99 */ || \ - (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x550)) -# define _X_INLINE inline -#elif defined(__GNUC__) && !defined(__STRICT_ANSI__) /* gcc w/C89+extensions */ -# define _X_INLINE __inline__ -#else -# define _X_INLINE -#endif - -/* C99 keyword "restrict" or equivalent extensions in pre-C99 compilers */ -/* requires xproto >= 7.0.21 */ -#ifndef _X_RESTRICT_KYWD -# if defined(restrict) /* assume autoconf set it correctly */ || \ - (defined(__STDC_VERSION__) && (__STDC_VERSION__ - 0 >= 199901L) /* C99 */ \ - && !defined(__cplusplus)) /* Workaround g++ issue on Solaris */ -# define _X_RESTRICT_KYWD restrict -# elif defined(__GNUC__) && !defined(__STRICT_ANSI__) /* gcc w/C89+extensions */ -# define _X_RESTRICT_KYWD __restrict__ -# else -# define _X_RESTRICT_KYWD -# endif -#endif - -#endif /* _XFUNCPROTO_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xfuncs.h b/btgui/OpenGLWindow/optionalX11/X11/Xfuncs.h deleted file mode 100644 index 2bcf991a9..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xfuncs.h +++ /dev/null @@ -1,69 +0,0 @@ -/* - * -Copyright 1990, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - * - */ - -#ifndef _XFUNCS_H_ -# define _XFUNCS_H_ - -# include - -/* the old Xfuncs.h, for pre-R6 */ -# if !(defined(XFree86LOADER) && defined(IN_MODULE)) - -# ifdef X_USEBFUNCS -void bcopy(); -void bzero(); -int bcmp(); -# else -# if defined(SYSV) && !defined(__SCO__) && !defined(__sun) && !defined(__UNIXWARE__) -# include -void bcopy(); -# define bzero(b,len) memset(b, 0, len) -# define bcmp(b1,b2,len) memcmp(b1, b2, len) -# else -# include -# if defined(__SCO__) || defined(__sun) || defined(__UNIXWARE__) || defined(__CYGWIN__) -# include -# endif -# define _XFUNCS_H_INCLUDED_STRING_H -# endif -# endif /* X_USEBFUNCS */ - -/* the new Xfuncs.h */ - -/* the ANSI C way */ -# ifndef _XFUNCS_H_INCLUDED_STRING_H -# include -# endif -# undef bzero -# define bzero(b,len) memset(b,0,len) - -# if defined WIN32 && defined __MINGW32__ -# define bcopy(b1,b2,len) memmove(b2, b1, (size_t)(len)) -# endif - -# endif /* !(defined(XFree86LOADER) && defined(IN_MODULE)) */ - -#endif /* _XFUNCS_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xlib.h b/btgui/OpenGLWindow/optionalX11/X11/Xlib.h deleted file mode 100644 index 65f253cd4..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xlib.h +++ /dev/null @@ -1,4032 +0,0 @@ -/* - -Copyright 1985, 1986, 1987, 1991, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - -*/ - - -/* - * Xlib.h - Header definition and support file for the C subroutine - * interface library (Xlib) to the X Window System Protocol (V11). - * Structures and symbols starting with "_" are private to the library. - */ -#ifndef _X11_XLIB_H_ -#define _X11_XLIB_H_ - -#define XlibSpecificationRelease 6 - -#include - -#if defined(__SCO__) || defined(__UNIXWARE__) -#include -#endif - -#include - -/* applications should not depend on these two headers being included! */ -#include -#include - -#ifndef X_WCHAR -#include -#else -#ifdef __UNIXOS2__ -#include -#else -/* replace this with #include or typedef appropriate for your system */ -typedef unsigned long wchar_t; -#endif -#endif - -#if defined(ISC) && defined(USE_XMBTOWC) -#define wctomb(a,b) _Xwctomb(a,b) -#define mblen(a,b) _Xmblen(a,b) -#ifndef USE_XWCHAR_STRING -#define mbtowc(a,b,c) _Xmbtowc(a,b,c) -#endif -#endif - -extern int -_Xmblen( -#ifdef ISC - char const *str, - size_t len -#else - char *str, - int len -#endif - ); - -/* API mentioning "UTF8" or "utf8" is an XFree86 extension, introduced in - November 2000. Its presence is indicated through the following macro. */ -#define X_HAVE_UTF8_STRING 1 - -/* The Xlib structs are full of implicit padding to properly align members. - We can't clean that up without breaking ABI, so tell clang not to bother - complaining about it. */ -#ifdef __clang__ -#pragma clang diagnostic push -#pragma clang diagnostic ignored "-Wpadded" -#endif - -typedef char *XPointer; - -#define Bool int -#define Status int -#define True 1 -#define False 0 - -#define QueuedAlready 0 -#define QueuedAfterReading 1 -#define QueuedAfterFlush 2 - -#define ConnectionNumber(dpy) (((_XPrivDisplay)dpy)->fd) -#define RootWindow(dpy, scr) (ScreenOfDisplay(dpy,scr)->root) -#define DefaultScreen(dpy) (((_XPrivDisplay)dpy)->default_screen) -#define DefaultRootWindow(dpy) (ScreenOfDisplay(dpy,DefaultScreen(dpy))->root) -#define DefaultVisual(dpy, scr) (ScreenOfDisplay(dpy,scr)->root_visual) -#define DefaultGC(dpy, scr) (ScreenOfDisplay(dpy,scr)->default_gc) -#define BlackPixel(dpy, scr) (ScreenOfDisplay(dpy,scr)->black_pixel) -#define WhitePixel(dpy, scr) (ScreenOfDisplay(dpy,scr)->white_pixel) -#define AllPlanes ((unsigned long)~0L) -#define QLength(dpy) (((_XPrivDisplay)dpy)->qlen) -#define DisplayWidth(dpy, scr) (ScreenOfDisplay(dpy,scr)->width) -#define DisplayHeight(dpy, scr) (ScreenOfDisplay(dpy,scr)->height) -#define DisplayWidthMM(dpy, scr)(ScreenOfDisplay(dpy,scr)->mwidth) -#define DisplayHeightMM(dpy, scr)(ScreenOfDisplay(dpy,scr)->mheight) -#define DisplayPlanes(dpy, scr) (ScreenOfDisplay(dpy,scr)->root_depth) -#define DisplayCells(dpy, scr) (DefaultVisual(dpy,scr)->map_entries) -#define ScreenCount(dpy) (((_XPrivDisplay)dpy)->nscreens) -#define ServerVendor(dpy) (((_XPrivDisplay)dpy)->vendor) -#define ProtocolVersion(dpy) (((_XPrivDisplay)dpy)->proto_major_version) -#define ProtocolRevision(dpy) (((_XPrivDisplay)dpy)->proto_minor_version) -#define VendorRelease(dpy) (((_XPrivDisplay)dpy)->release) -#define DisplayString(dpy) (((_XPrivDisplay)dpy)->display_name) -#define DefaultDepth(dpy, scr) (ScreenOfDisplay(dpy,scr)->root_depth) -#define DefaultColormap(dpy, scr)(ScreenOfDisplay(dpy,scr)->cmap) -#define BitmapUnit(dpy) (((_XPrivDisplay)dpy)->bitmap_unit) -#define BitmapBitOrder(dpy) (((_XPrivDisplay)dpy)->bitmap_bit_order) -#define BitmapPad(dpy) (((_XPrivDisplay)dpy)->bitmap_pad) -#define ImageByteOrder(dpy) (((_XPrivDisplay)dpy)->byte_order) -#define NextRequest(dpy) (((_XPrivDisplay)dpy)->request + 1) -#define LastKnownRequestProcessed(dpy) (((_XPrivDisplay)dpy)->last_request_read) - -/* macros for screen oriented applications (toolkit) */ -#define ScreenOfDisplay(dpy, scr)(&((_XPrivDisplay)dpy)->screens[scr]) -#define DefaultScreenOfDisplay(dpy) ScreenOfDisplay(dpy,DefaultScreen(dpy)) -#define DisplayOfScreen(s) ((s)->display) -#define RootWindowOfScreen(s) ((s)->root) -#define BlackPixelOfScreen(s) ((s)->black_pixel) -#define WhitePixelOfScreen(s) ((s)->white_pixel) -#define DefaultColormapOfScreen(s)((s)->cmap) -#define DefaultDepthOfScreen(s) ((s)->root_depth) -#define DefaultGCOfScreen(s) ((s)->default_gc) -#define DefaultVisualOfScreen(s)((s)->root_visual) -#define WidthOfScreen(s) ((s)->width) -#define HeightOfScreen(s) ((s)->height) -#define WidthMMOfScreen(s) ((s)->mwidth) -#define HeightMMOfScreen(s) ((s)->mheight) -#define PlanesOfScreen(s) ((s)->root_depth) -#define CellsOfScreen(s) (DefaultVisualOfScreen((s))->map_entries) -#define MinCmapsOfScreen(s) ((s)->min_maps) -#define MaxCmapsOfScreen(s) ((s)->max_maps) -#define DoesSaveUnders(s) ((s)->save_unders) -#define DoesBackingStore(s) ((s)->backing_store) -#define EventMaskOfScreen(s) ((s)->root_input_mask) - -/* - * Extensions need a way to hang private data on some structures. - */ -typedef struct _XExtData { - int number; /* number returned by XRegisterExtension */ - struct _XExtData *next; /* next item on list of data for structure */ - int (*free_private)( /* called to free private storage */ - struct _XExtData *extension - ); - XPointer private_data; /* data private to this extension. */ -} XExtData; - -/* - * This file contains structures used by the extension mechanism. - */ -typedef struct { /* public to extension, cannot be changed */ - int extension; /* extension number */ - int major_opcode; /* major op-code assigned by server */ - int first_event; /* first event number for the extension */ - int first_error; /* first error number for the extension */ -} XExtCodes; - -/* - * Data structure for retrieving info about pixmap formats. - */ - -typedef struct { - int depth; - int bits_per_pixel; - int scanline_pad; -} XPixmapFormatValues; - - -/* - * Data structure for setting graphics context. - */ -typedef struct { - int function; /* logical operation */ - unsigned long plane_mask;/* plane mask */ - unsigned long foreground;/* foreground pixel */ - unsigned long background;/* background pixel */ - int line_width; /* line width */ - int line_style; /* LineSolid, LineOnOffDash, LineDoubleDash */ - int cap_style; /* CapNotLast, CapButt, - CapRound, CapProjecting */ - int join_style; /* JoinMiter, JoinRound, JoinBevel */ - int fill_style; /* FillSolid, FillTiled, - FillStippled, FillOpaeueStippled */ - int fill_rule; /* EvenOddRule, WindingRule */ - int arc_mode; /* ArcChord, ArcPieSlice */ - Pixmap tile; /* tile pixmap for tiling operations */ - Pixmap stipple; /* stipple 1 plane pixmap for stipping */ - int ts_x_origin; /* offset for tile or stipple operations */ - int ts_y_origin; - Font font; /* default text font for text operations */ - int subwindow_mode; /* ClipByChildren, IncludeInferiors */ - Bool graphics_exposures;/* boolean, should exposures be generated */ - int clip_x_origin; /* origin for clipping */ - int clip_y_origin; - Pixmap clip_mask; /* bitmap clipping; other calls for rects */ - int dash_offset; /* patterned/dashed line information */ - char dashes; -} XGCValues; - -/* - * Graphics context. The contents of this structure are implementation - * dependent. A GC should be treated as opaque by application code. - */ - -typedef struct _XGC -#ifdef XLIB_ILLEGAL_ACCESS -{ - XExtData *ext_data; /* hook for extension to hang data */ - GContext gid; /* protocol ID for graphics context */ - /* there is more to this structure, but it is private to Xlib */ -} -#endif -*GC; - -/* - * Visual structure; contains information about colormapping possible. - */ -typedef struct { - XExtData *ext_data; /* hook for extension to hang data */ - VisualID visualid; /* visual id of this visual */ -#if defined(__cplusplus) || defined(c_plusplus) - int c_class; /* C++ class of screen (monochrome, etc.) */ -#else - int class; /* class of screen (monochrome, etc.) */ -#endif - unsigned long red_mask, green_mask, blue_mask; /* mask values */ - int bits_per_rgb; /* log base 2 of distinct color values */ - int map_entries; /* color map entries */ -} Visual; - -/* - * Depth structure; contains information for each possible depth. - */ -typedef struct { - int depth; /* this depth (Z) of the depth */ - int nvisuals; /* number of Visual types at this depth */ - Visual *visuals; /* list of visuals possible at this depth */ -} Depth; - -/* - * Information about the screen. The contents of this structure are - * implementation dependent. A Screen should be treated as opaque - * by application code. - */ - -struct _XDisplay; /* Forward declare before use for C++ */ - -typedef struct { - XExtData *ext_data; /* hook for extension to hang data */ - struct _XDisplay *display;/* back pointer to display structure */ - Window root; /* Root window id. */ - int width, height; /* width and height of screen */ - int mwidth, mheight; /* width and height of in millimeters */ - int ndepths; /* number of depths possible */ - Depth *depths; /* list of allowable depths on the screen */ - int root_depth; /* bits per pixel */ - Visual *root_visual; /* root visual */ - GC default_gc; /* GC for the root root visual */ - Colormap cmap; /* default color map */ - unsigned long white_pixel; - unsigned long black_pixel; /* White and Black pixel values */ - int max_maps, min_maps; /* max and min color maps */ - int backing_store; /* Never, WhenMapped, Always */ - Bool save_unders; - long root_input_mask; /* initial root input mask */ -} Screen; - -/* - * Format structure; describes ZFormat data the screen will understand. - */ -typedef struct { - XExtData *ext_data; /* hook for extension to hang data */ - int depth; /* depth of this image format */ - int bits_per_pixel; /* bits/pixel at this depth */ - int scanline_pad; /* scanline must padded to this multiple */ -} ScreenFormat; - -/* - * Data structure for setting window attributes. - */ -typedef struct { - Pixmap background_pixmap; /* background or None or ParentRelative */ - unsigned long background_pixel; /* background pixel */ - Pixmap border_pixmap; /* border of the window */ - unsigned long border_pixel; /* border pixel value */ - int bit_gravity; /* one of bit gravity values */ - int win_gravity; /* one of the window gravity values */ - int backing_store; /* NotUseful, WhenMapped, Always */ - unsigned long backing_planes;/* planes to be preseved if possible */ - unsigned long backing_pixel;/* value to use in restoring planes */ - Bool save_under; /* should bits under be saved? (popups) */ - long event_mask; /* set of events that should be saved */ - long do_not_propagate_mask; /* set of events that should not propagate */ - Bool override_redirect; /* boolean value for override-redirect */ - Colormap colormap; /* color map to be associated with window */ - Cursor cursor; /* cursor to be displayed (or None) */ -} XSetWindowAttributes; - -typedef struct { - int x, y; /* location of window */ - int width, height; /* width and height of window */ - int border_width; /* border width of window */ - int depth; /* depth of window */ - Visual *visual; /* the associated visual structure */ - Window root; /* root of screen containing window */ -#if defined(__cplusplus) || defined(c_plusplus) - int c_class; /* C++ InputOutput, InputOnly*/ -#else - int class; /* InputOutput, InputOnly*/ -#endif - int bit_gravity; /* one of bit gravity values */ - int win_gravity; /* one of the window gravity values */ - int backing_store; /* NotUseful, WhenMapped, Always */ - unsigned long backing_planes;/* planes to be preserved if possible */ - unsigned long backing_pixel;/* value to be used when restoring planes */ - Bool save_under; /* boolean, should bits under be saved? */ - Colormap colormap; /* color map to be associated with window */ - Bool map_installed; /* boolean, is color map currently installed*/ - int map_state; /* IsUnmapped, IsUnviewable, IsViewable */ - long all_event_masks; /* set of events all people have interest in*/ - long your_event_mask; /* my event mask */ - long do_not_propagate_mask; /* set of events that should not propagate */ - Bool override_redirect; /* boolean value for override-redirect */ - Screen *screen; /* back pointer to correct screen */ -} XWindowAttributes; - -/* - * Data structure for host setting; getting routines. - * - */ - -typedef struct { - int family; /* for example FamilyInternet */ - int length; /* length of address, in bytes */ - char *address; /* pointer to where to find the bytes */ -} XHostAddress; - -/* - * Data structure for ServerFamilyInterpreted addresses in host routines - */ -typedef struct { - int typelength; /* length of type string, in bytes */ - int valuelength; /* length of value string, in bytes */ - char *type; /* pointer to where to find the type string */ - char *value; /* pointer to where to find the address */ -} XServerInterpretedAddress; - -/* - * Data structure for "image" data, used by image manipulation routines. - */ -typedef struct _XImage { - int width, height; /* size of image */ - int xoffset; /* number of pixels offset in X direction */ - int format; /* XYBitmap, XYPixmap, ZPixmap */ - char *data; /* pointer to image data */ - int byte_order; /* data byte order, LSBFirst, MSBFirst */ - int bitmap_unit; /* quant. of scanline 8, 16, 32 */ - int bitmap_bit_order; /* LSBFirst, MSBFirst */ - int bitmap_pad; /* 8, 16, 32 either XY or ZPixmap */ - int depth; /* depth of image */ - int bytes_per_line; /* accelarator to next line */ - int bits_per_pixel; /* bits per pixel (ZPixmap) */ - unsigned long red_mask; /* bits in z arrangment */ - unsigned long green_mask; - unsigned long blue_mask; - XPointer obdata; /* hook for the object routines to hang on */ - struct funcs { /* image manipulation routines */ - struct _XImage *(*create_image)( - struct _XDisplay* /* display */, - Visual* /* visual */, - unsigned int /* depth */, - int /* format */, - int /* offset */, - char* /* data */, - unsigned int /* width */, - unsigned int /* height */, - int /* bitmap_pad */, - int /* bytes_per_line */); - int (*destroy_image) (struct _XImage *); - unsigned long (*get_pixel) (struct _XImage *, int, int); - int (*put_pixel) (struct _XImage *, int, int, unsigned long); - struct _XImage *(*sub_image)(struct _XImage *, int, int, unsigned int, unsigned int); - int (*add_pixel) (struct _XImage *, long); - } f; -} XImage; - -/* - * Data structure for XReconfigureWindow - */ -typedef struct { - int x, y; - int width, height; - int border_width; - Window sibling; - int stack_mode; -} XWindowChanges; - -/* - * Data structure used by color operations - */ -typedef struct { - unsigned long pixel; - unsigned short red, green, blue; - char flags; /* do_red, do_green, do_blue */ - char pad; -} XColor; - -/* - * Data structures for graphics operations. On most machines, these are - * congruent with the wire protocol structures, so reformatting the data - * can be avoided on these architectures. - */ -typedef struct { - short x1, y1, x2, y2; -} XSegment; - -typedef struct { - short x, y; -} XPoint; - -typedef struct { - short x, y; - unsigned short width, height; -} XRectangle; - -typedef struct { - short x, y; - unsigned short width, height; - short angle1, angle2; -} XArc; - - -/* Data structure for XChangeKeyboardControl */ - -typedef struct { - int key_click_percent; - int bell_percent; - int bell_pitch; - int bell_duration; - int led; - int led_mode; - int key; - int auto_repeat_mode; /* On, Off, Default */ -} XKeyboardControl; - -/* Data structure for XGetKeyboardControl */ - -typedef struct { - int key_click_percent; - int bell_percent; - unsigned int bell_pitch, bell_duration; - unsigned long led_mask; - int global_auto_repeat; - char auto_repeats[32]; -} XKeyboardState; - -/* Data structure for XGetMotionEvents. */ - -typedef struct { - Time time; - short x, y; -} XTimeCoord; - -/* Data structure for X{Set,Get}ModifierMapping */ - -typedef struct { - int max_keypermod; /* The server's max # of keys per modifier */ - KeyCode *modifiermap; /* An 8 by max_keypermod array of modifiers */ -} XModifierKeymap; - - -/* - * Display datatype maintaining display specific data. - * The contents of this structure are implementation dependent. - * A Display should be treated as opaque by application code. - */ -#ifndef XLIB_ILLEGAL_ACCESS -typedef struct _XDisplay Display; -#endif - -struct _XPrivate; /* Forward declare before use for C++ */ -struct _XrmHashBucketRec; - -typedef struct -#ifdef XLIB_ILLEGAL_ACCESS -_XDisplay -#endif -{ - XExtData *ext_data; /* hook for extension to hang data */ - struct _XPrivate *private1; - int fd; /* Network socket. */ - int private2; - int proto_major_version;/* major version of server's X protocol */ - int proto_minor_version;/* minor version of servers X protocol */ - char *vendor; /* vendor of the server hardware */ - XID private3; - XID private4; - XID private5; - int private6; - XID (*resource_alloc)( /* allocator function */ - struct _XDisplay* - ); - int byte_order; /* screen byte order, LSBFirst, MSBFirst */ - int bitmap_unit; /* padding and data requirements */ - int bitmap_pad; /* padding requirements on bitmaps */ - int bitmap_bit_order; /* LeastSignificant or MostSignificant */ - int nformats; /* number of pixmap formats in list */ - ScreenFormat *pixmap_format; /* pixmap format list */ - int private8; - int release; /* release of the server */ - struct _XPrivate *private9, *private10; - int qlen; /* Length of input event queue */ - unsigned long last_request_read; /* seq number of last event read */ - unsigned long request; /* sequence number of last request. */ - XPointer private11; - XPointer private12; - XPointer private13; - XPointer private14; - unsigned max_request_size; /* maximum number 32 bit words in request*/ - struct _XrmHashBucketRec *db; - int (*private15)( - struct _XDisplay* - ); - char *display_name; /* "host:display" string used on this connect*/ - int default_screen; /* default screen for operations */ - int nscreens; /* number of screens on this server*/ - Screen *screens; /* pointer to list of screens */ - unsigned long motion_buffer; /* size of motion buffer */ - unsigned long private16; - int min_keycode; /* minimum defined keycode */ - int max_keycode; /* maximum defined keycode */ - XPointer private17; - XPointer private18; - int private19; - char *xdefaults; /* contents of defaults from server */ - /* there is more to this structure, but it is private to Xlib */ -} -#ifdef XLIB_ILLEGAL_ACCESS -Display, -#endif -*_XPrivDisplay; - -#undef _XEVENT_ -#ifndef _XEVENT_ -/* - * Definitions of specific events. - */ -typedef struct { - int type; /* of event */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* "event" window it is reported relative to */ - Window root; /* root window that the event occurred on */ - Window subwindow; /* child window */ - Time time; /* milliseconds */ - int x, y; /* pointer x, y coordinates in event window */ - int x_root, y_root; /* coordinates relative to root */ - unsigned int state; /* key or button mask */ - unsigned int keycode; /* detail */ - Bool same_screen; /* same screen flag */ -} XKeyEvent; -typedef XKeyEvent XKeyPressedEvent; -typedef XKeyEvent XKeyReleasedEvent; - -typedef struct { - int type; /* of event */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* "event" window it is reported relative to */ - Window root; /* root window that the event occurred on */ - Window subwindow; /* child window */ - Time time; /* milliseconds */ - int x, y; /* pointer x, y coordinates in event window */ - int x_root, y_root; /* coordinates relative to root */ - unsigned int state; /* key or button mask */ - unsigned int button; /* detail */ - Bool same_screen; /* same screen flag */ -} XButtonEvent; -typedef XButtonEvent XButtonPressedEvent; -typedef XButtonEvent XButtonReleasedEvent; - -typedef struct { - int type; /* of event */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* "event" window reported relative to */ - Window root; /* root window that the event occurred on */ - Window subwindow; /* child window */ - Time time; /* milliseconds */ - int x, y; /* pointer x, y coordinates in event window */ - int x_root, y_root; /* coordinates relative to root */ - unsigned int state; /* key or button mask */ - char is_hint; /* detail */ - Bool same_screen; /* same screen flag */ -} XMotionEvent; -typedef XMotionEvent XPointerMovedEvent; - -typedef struct { - int type; /* of event */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* "event" window reported relative to */ - Window root; /* root window that the event occurred on */ - Window subwindow; /* child window */ - Time time; /* milliseconds */ - int x, y; /* pointer x, y coordinates in event window */ - int x_root, y_root; /* coordinates relative to root */ - int mode; /* NotifyNormal, NotifyGrab, NotifyUngrab */ - int detail; - /* - * NotifyAncestor, NotifyVirtual, NotifyInferior, - * NotifyNonlinear,NotifyNonlinearVirtual - */ - Bool same_screen; /* same screen flag */ - Bool focus; /* boolean focus */ - unsigned int state; /* key or button mask */ -} XCrossingEvent; -typedef XCrossingEvent XEnterWindowEvent; -typedef XCrossingEvent XLeaveWindowEvent; - -typedef struct { - int type; /* FocusIn or FocusOut */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* window of event */ - int mode; /* NotifyNormal, NotifyWhileGrabbed, - NotifyGrab, NotifyUngrab */ - int detail; - /* - * NotifyAncestor, NotifyVirtual, NotifyInferior, - * NotifyNonlinear,NotifyNonlinearVirtual, NotifyPointer, - * NotifyPointerRoot, NotifyDetailNone - */ -} XFocusChangeEvent; -typedef XFocusChangeEvent XFocusInEvent; -typedef XFocusChangeEvent XFocusOutEvent; - -/* generated on EnterWindow and FocusIn when KeyMapState selected */ -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - char key_vector[32]; -} XKeymapEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - int x, y; - int width, height; - int count; /* if non-zero, at least this many more */ -} XExposeEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Drawable drawable; - int x, y; - int width, height; - int count; /* if non-zero, at least this many more */ - int major_code; /* core is CopyArea or CopyPlane */ - int minor_code; /* not defined in the core */ -} XGraphicsExposeEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Drawable drawable; - int major_code; /* core is CopyArea or CopyPlane */ - int minor_code; /* not defined in the core */ -} XNoExposeEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - int state; /* Visibility state */ -} XVisibilityEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window parent; /* parent of the window */ - Window window; /* window id of window created */ - int x, y; /* window location */ - int width, height; /* size of window */ - int border_width; /* border width */ - Bool override_redirect; /* creation should be overridden */ -} XCreateWindowEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; -} XDestroyWindowEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; - Bool from_configure; -} XUnmapEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; - Bool override_redirect; /* boolean, is override set... */ -} XMapEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window parent; - Window window; -} XMapRequestEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; - Window parent; - int x, y; - Bool override_redirect; -} XReparentEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; - int x, y; - int width, height; - int border_width; - Window above; - Bool override_redirect; -} XConfigureEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; - int x, y; -} XGravityEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - int width, height; -} XResizeRequestEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window parent; - Window window; - int x, y; - int width, height; - int border_width; - Window above; - int detail; /* Above, Below, TopIf, BottomIf, Opposite */ - unsigned long value_mask; -} XConfigureRequestEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window event; - Window window; - int place; /* PlaceOnTop, PlaceOnBottom */ -} XCirculateEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window parent; - Window window; - int place; /* PlaceOnTop, PlaceOnBottom */ -} XCirculateRequestEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - Atom atom; - Time time; - int state; /* NewValue, Deleted */ -} XPropertyEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - Atom selection; - Time time; -} XSelectionClearEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window owner; - Window requestor; - Atom selection; - Atom target; - Atom property; - Time time; -} XSelectionRequestEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window requestor; - Atom selection; - Atom target; - Atom property; /* ATOM or None */ - Time time; -} XSelectionEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - Colormap colormap; /* COLORMAP or None */ -#if defined(__cplusplus) || defined(c_plusplus) - Bool c_new; /* C++ */ -#else - Bool new; -#endif - int state; /* ColormapInstalled, ColormapUninstalled */ -} XColormapEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; - Atom message_type; - int format; - union { - char b[20]; - short s[10]; - long l[5]; - } data; -} XClientMessageEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* unused */ - int request; /* one of MappingModifier, MappingKeyboard, - MappingPointer */ - int first_keycode; /* first keycode */ - int count; /* defines range of change w. first_keycode*/ -} XMappingEvent; - -typedef struct { - int type; - Display *display; /* Display the event was read from */ - XID resourceid; /* resource id */ - unsigned long serial; /* serial number of failed request */ - unsigned char error_code; /* error code of failed request */ - unsigned char request_code; /* Major op-code of failed request */ - unsigned char minor_code; /* Minor op-code of failed request */ -} XErrorEvent; - -typedef struct { - int type; - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came from a SendEvent request */ - Display *display;/* Display the event was read from */ - Window window; /* window on which event was requested in event mask */ -} XAnyEvent; - - -/*************************************************************** - * - * GenericEvent. This event is the standard event for all newer extensions. - */ - -typedef struct - { - int type; /* of event. Always GenericEvent */ - unsigned long serial; /* # of last request processed */ - Bool send_event; /* true if from SendEvent request */ - Display *display; /* Display the event was read from */ - int extension; /* major opcode of extension that caused the event */ - int evtype; /* actual event type. */ - } XGenericEvent; - -typedef struct { - int type; /* of event. Always GenericEvent */ - unsigned long serial; /* # of last request processed */ - Bool send_event; /* true if from SendEvent request */ - Display *display; /* Display the event was read from */ - int extension; /* major opcode of extension that caused the event */ - int evtype; /* actual event type. */ - unsigned int cookie; - void *data; -} XGenericEventCookie; - -/* - * this union is defined so Xlib can always use the same sized - * event structure internally, to avoid memory fragmentation. - */ -typedef union _XEvent { - int type; /* must not be changed; first element */ - XAnyEvent xany; - XKeyEvent xkey; - XButtonEvent xbutton; - XMotionEvent xmotion; - XCrossingEvent xcrossing; - XFocusChangeEvent xfocus; - XExposeEvent xexpose; - XGraphicsExposeEvent xgraphicsexpose; - XNoExposeEvent xnoexpose; - XVisibilityEvent xvisibility; - XCreateWindowEvent xcreatewindow; - XDestroyWindowEvent xdestroywindow; - XUnmapEvent xunmap; - XMapEvent xmap; - XMapRequestEvent xmaprequest; - XReparentEvent xreparent; - XConfigureEvent xconfigure; - XGravityEvent xgravity; - XResizeRequestEvent xresizerequest; - XConfigureRequestEvent xconfigurerequest; - XCirculateEvent xcirculate; - XCirculateRequestEvent xcirculaterequest; - XPropertyEvent xproperty; - XSelectionClearEvent xselectionclear; - XSelectionRequestEvent xselectionrequest; - XSelectionEvent xselection; - XColormapEvent xcolormap; - XClientMessageEvent xclient; - XMappingEvent xmapping; - XErrorEvent xerror; - XKeymapEvent xkeymap; - XGenericEvent xgeneric; - XGenericEventCookie xcookie; - long pad[24]; -} XEvent; -#endif - -#define XAllocID(dpy) ((*((_XPrivDisplay)dpy)->resource_alloc)((dpy))) - -/* - * per character font metric information. - */ -typedef struct { - short lbearing; /* origin to left edge of raster */ - short rbearing; /* origin to right edge of raster */ - short width; /* advance to next char's origin */ - short ascent; /* baseline to top edge of raster */ - short descent; /* baseline to bottom edge of raster */ - unsigned short attributes; /* per char flags (not predefined) */ -} XCharStruct; - -/* - * To allow arbitrary information with fonts, there are additional properties - * returned. - */ -typedef struct { - Atom name; - unsigned long card32; -} XFontProp; - -typedef struct { - XExtData *ext_data; /* hook for extension to hang data */ - Font fid; /* Font id for this font */ - unsigned direction; /* hint about direction the font is painted */ - unsigned min_char_or_byte2;/* first character */ - unsigned max_char_or_byte2;/* last character */ - unsigned min_byte1; /* first row that exists */ - unsigned max_byte1; /* last row that exists */ - Bool all_chars_exist;/* flag if all characters have non-zero size*/ - unsigned default_char; /* char to print for undefined character */ - int n_properties; /* how many properties there are */ - XFontProp *properties; /* pointer to array of additional properties*/ - XCharStruct min_bounds; /* minimum bounds over all existing char*/ - XCharStruct max_bounds; /* maximum bounds over all existing char*/ - XCharStruct *per_char; /* first_char to last_char information */ - int ascent; /* log. extent above baseline for spacing */ - int descent; /* log. descent below baseline for spacing */ -} XFontStruct; - -/* - * PolyText routines take these as arguments. - */ -typedef struct { - char *chars; /* pointer to string */ - int nchars; /* number of characters */ - int delta; /* delta between strings */ - Font font; /* font to print it in, None don't change */ -} XTextItem; - -typedef struct { /* normal 16 bit characters are two bytes */ - unsigned char byte1; - unsigned char byte2; -} XChar2b; - -typedef struct { - XChar2b *chars; /* two byte characters */ - int nchars; /* number of characters */ - int delta; /* delta between strings */ - Font font; /* font to print it in, None don't change */ -} XTextItem16; - - -typedef union { Display *display; - GC gc; - Visual *visual; - Screen *screen; - ScreenFormat *pixmap_format; - XFontStruct *font; } XEDataObject; - -typedef struct { - XRectangle max_ink_extent; - XRectangle max_logical_extent; -} XFontSetExtents; - -/* unused: -typedef void (*XOMProc)(); - */ - -typedef struct _XOM *XOM; -typedef struct _XOC *XOC, *XFontSet; - -typedef struct { - char *chars; - int nchars; - int delta; - XFontSet font_set; -} XmbTextItem; - -typedef struct { - wchar_t *chars; - int nchars; - int delta; - XFontSet font_set; -} XwcTextItem; - -#define XNRequiredCharSet "requiredCharSet" -#define XNQueryOrientation "queryOrientation" -#define XNBaseFontName "baseFontName" -#define XNOMAutomatic "omAutomatic" -#define XNMissingCharSet "missingCharSet" -#define XNDefaultString "defaultString" -#define XNOrientation "orientation" -#define XNDirectionalDependentDrawing "directionalDependentDrawing" -#define XNContextualDrawing "contextualDrawing" -#define XNFontInfo "fontInfo" - -typedef struct { - int charset_count; - char **charset_list; -} XOMCharSetList; - -typedef enum { - XOMOrientation_LTR_TTB, - XOMOrientation_RTL_TTB, - XOMOrientation_TTB_LTR, - XOMOrientation_TTB_RTL, - XOMOrientation_Context -} XOrientation; - -typedef struct { - int num_orientation; - XOrientation *orientation; /* Input Text description */ -} XOMOrientation; - -typedef struct { - int num_font; - XFontStruct **font_struct_list; - char **font_name_list; -} XOMFontInfo; - -typedef struct _XIM *XIM; -typedef struct _XIC *XIC; - -typedef void (*XIMProc)( - XIM, - XPointer, - XPointer -); - -typedef Bool (*XICProc)( - XIC, - XPointer, - XPointer -); - -typedef void (*XIDProc)( - Display*, - XPointer, - XPointer -); - -typedef unsigned long XIMStyle; - -typedef struct { - unsigned short count_styles; - XIMStyle *supported_styles; -} XIMStyles; - -#define XIMPreeditArea 0x0001L -#define XIMPreeditCallbacks 0x0002L -#define XIMPreeditPosition 0x0004L -#define XIMPreeditNothing 0x0008L -#define XIMPreeditNone 0x0010L -#define XIMStatusArea 0x0100L -#define XIMStatusCallbacks 0x0200L -#define XIMStatusNothing 0x0400L -#define XIMStatusNone 0x0800L - -#define XNVaNestedList "XNVaNestedList" -#define XNQueryInputStyle "queryInputStyle" -#define XNClientWindow "clientWindow" -#define XNInputStyle "inputStyle" -#define XNFocusWindow "focusWindow" -#define XNResourceName "resourceName" -#define XNResourceClass "resourceClass" -#define XNGeometryCallback "geometryCallback" -#define XNDestroyCallback "destroyCallback" -#define XNFilterEvents "filterEvents" -#define XNPreeditStartCallback "preeditStartCallback" -#define XNPreeditDoneCallback "preeditDoneCallback" -#define XNPreeditDrawCallback "preeditDrawCallback" -#define XNPreeditCaretCallback "preeditCaretCallback" -#define XNPreeditStateNotifyCallback "preeditStateNotifyCallback" -#define XNPreeditAttributes "preeditAttributes" -#define XNStatusStartCallback "statusStartCallback" -#define XNStatusDoneCallback "statusDoneCallback" -#define XNStatusDrawCallback "statusDrawCallback" -#define XNStatusAttributes "statusAttributes" -#define XNArea "area" -#define XNAreaNeeded "areaNeeded" -#define XNSpotLocation "spotLocation" -#define XNColormap "colorMap" -#define XNStdColormap "stdColorMap" -#define XNForeground "foreground" -#define XNBackground "background" -#define XNBackgroundPixmap "backgroundPixmap" -#define XNFontSet "fontSet" -#define XNLineSpace "lineSpace" -#define XNCursor "cursor" - -#define XNQueryIMValuesList "queryIMValuesList" -#define XNQueryICValuesList "queryICValuesList" -#define XNVisiblePosition "visiblePosition" -#define XNR6PreeditCallback "r6PreeditCallback" -#define XNStringConversionCallback "stringConversionCallback" -#define XNStringConversion "stringConversion" -#define XNResetState "resetState" -#define XNHotKey "hotKey" -#define XNHotKeyState "hotKeyState" -#define XNPreeditState "preeditState" -#define XNSeparatorofNestedList "separatorofNestedList" - -#define XBufferOverflow -1 -#define XLookupNone 1 -#define XLookupChars 2 -#define XLookupKeySym 3 -#define XLookupBoth 4 - -typedef void *XVaNestedList; - -typedef struct { - XPointer client_data; - XIMProc callback; -} XIMCallback; - -typedef struct { - XPointer client_data; - XICProc callback; -} XICCallback; - -typedef unsigned long XIMFeedback; - -#define XIMReverse 1L -#define XIMUnderline (1L<<1) -#define XIMHighlight (1L<<2) -#define XIMPrimary (1L<<5) -#define XIMSecondary (1L<<6) -#define XIMTertiary (1L<<7) -#define XIMVisibleToForward (1L<<8) -#define XIMVisibleToBackword (1L<<9) -#define XIMVisibleToCenter (1L<<10) - -typedef struct _XIMText { - unsigned short length; - XIMFeedback *feedback; - Bool encoding_is_wchar; - union { - char *multi_byte; - wchar_t *wide_char; - } string; -} XIMText; - -typedef unsigned long XIMPreeditState; - -#define XIMPreeditUnKnown 0L -#define XIMPreeditEnable 1L -#define XIMPreeditDisable (1L<<1) - -typedef struct _XIMPreeditStateNotifyCallbackStruct { - XIMPreeditState state; -} XIMPreeditStateNotifyCallbackStruct; - -typedef unsigned long XIMResetState; - -#define XIMInitialState 1L -#define XIMPreserveState (1L<<1) - -typedef unsigned long XIMStringConversionFeedback; - -#define XIMStringConversionLeftEdge (0x00000001) -#define XIMStringConversionRightEdge (0x00000002) -#define XIMStringConversionTopEdge (0x00000004) -#define XIMStringConversionBottomEdge (0x00000008) -#define XIMStringConversionConcealed (0x00000010) -#define XIMStringConversionWrapped (0x00000020) - -typedef struct _XIMStringConversionText { - unsigned short length; - XIMStringConversionFeedback *feedback; - Bool encoding_is_wchar; - union { - char *mbs; - wchar_t *wcs; - } string; -} XIMStringConversionText; - -typedef unsigned short XIMStringConversionPosition; - -typedef unsigned short XIMStringConversionType; - -#define XIMStringConversionBuffer (0x0001) -#define XIMStringConversionLine (0x0002) -#define XIMStringConversionWord (0x0003) -#define XIMStringConversionChar (0x0004) - -typedef unsigned short XIMStringConversionOperation; - -#define XIMStringConversionSubstitution (0x0001) -#define XIMStringConversionRetrieval (0x0002) - -typedef enum { - XIMForwardChar, XIMBackwardChar, - XIMForwardWord, XIMBackwardWord, - XIMCaretUp, XIMCaretDown, - XIMNextLine, XIMPreviousLine, - XIMLineStart, XIMLineEnd, - XIMAbsolutePosition, - XIMDontChange -} XIMCaretDirection; - -typedef struct _XIMStringConversionCallbackStruct { - XIMStringConversionPosition position; - XIMCaretDirection direction; - XIMStringConversionOperation operation; - unsigned short factor; - XIMStringConversionText *text; -} XIMStringConversionCallbackStruct; - -typedef struct _XIMPreeditDrawCallbackStruct { - int caret; /* Cursor offset within pre-edit string */ - int chg_first; /* Starting change position */ - int chg_length; /* Length of the change in character count */ - XIMText *text; -} XIMPreeditDrawCallbackStruct; - -typedef enum { - XIMIsInvisible, /* Disable caret feedback */ - XIMIsPrimary, /* UI defined caret feedback */ - XIMIsSecondary /* UI defined caret feedback */ -} XIMCaretStyle; - -typedef struct _XIMPreeditCaretCallbackStruct { - int position; /* Caret offset within pre-edit string */ - XIMCaretDirection direction; /* Caret moves direction */ - XIMCaretStyle style; /* Feedback of the caret */ -} XIMPreeditCaretCallbackStruct; - -typedef enum { - XIMTextType, - XIMBitmapType -} XIMStatusDataType; - -typedef struct _XIMStatusDrawCallbackStruct { - XIMStatusDataType type; - union { - XIMText *text; - Pixmap bitmap; - } data; -} XIMStatusDrawCallbackStruct; - -typedef struct _XIMHotKeyTrigger { - KeySym keysym; - int modifier; - int modifier_mask; -} XIMHotKeyTrigger; - -typedef struct _XIMHotKeyTriggers { - int num_hot_key; - XIMHotKeyTrigger *key; -} XIMHotKeyTriggers; - -typedef unsigned long XIMHotKeyState; - -#define XIMHotKeyStateON (0x0001L) -#define XIMHotKeyStateOFF (0x0002L) - -typedef struct { - unsigned short count_values; - char **supported_values; -} XIMValuesList; - -_XFUNCPROTOBEGIN - -#if defined(WIN32) && !defined(_XLIBINT_) -#define _Xdebug (*_Xdebug_p) -#endif - -extern int _Xdebug; - -extern XFontStruct *XLoadQueryFont( - Display* /* display */, - _Xconst char* /* name */ -); - -extern XFontStruct *XQueryFont( - Display* /* display */, - XID /* font_ID */ -); - - -extern XTimeCoord *XGetMotionEvents( - Display* /* display */, - Window /* w */, - Time /* start */, - Time /* stop */, - int* /* nevents_return */ -); - -extern XModifierKeymap *XDeleteModifiermapEntry( - XModifierKeymap* /* modmap */, -#if NeedWidePrototypes - unsigned int /* keycode_entry */, -#else - KeyCode /* keycode_entry */, -#endif - int /* modifier */ -); - -extern XModifierKeymap *XGetModifierMapping( - Display* /* display */ -); - -extern XModifierKeymap *XInsertModifiermapEntry( - XModifierKeymap* /* modmap */, -#if NeedWidePrototypes - unsigned int /* keycode_entry */, -#else - KeyCode /* keycode_entry */, -#endif - int /* modifier */ -); - -extern XModifierKeymap *XNewModifiermap( - int /* max_keys_per_mod */ -); - -extern XImage *XCreateImage( - Display* /* display */, - Visual* /* visual */, - unsigned int /* depth */, - int /* format */, - int /* offset */, - char* /* data */, - unsigned int /* width */, - unsigned int /* height */, - int /* bitmap_pad */, - int /* bytes_per_line */ -); -extern Status XInitImage( - XImage* /* image */ -); -extern XImage *XGetImage( - Display* /* display */, - Drawable /* d */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - unsigned long /* plane_mask */, - int /* format */ -); -extern XImage *XGetSubImage( - Display* /* display */, - Drawable /* d */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - unsigned long /* plane_mask */, - int /* format */, - XImage* /* dest_image */, - int /* dest_x */, - int /* dest_y */ -); - -/* - * X function declarations. - */ -extern Display *XOpenDisplay( - _Xconst char* /* display_name */ -); - -extern void XrmInitialize( - void -); - -extern char *XFetchBytes( - Display* /* display */, - int* /* nbytes_return */ -); -extern char *XFetchBuffer( - Display* /* display */, - int* /* nbytes_return */, - int /* buffer */ -); -extern char *XGetAtomName( - Display* /* display */, - Atom /* atom */ -); -extern Status XGetAtomNames( - Display* /* dpy */, - Atom* /* atoms */, - int /* count */, - char** /* names_return */ -); -extern char *XGetDefault( - Display* /* display */, - _Xconst char* /* program */, - _Xconst char* /* option */ -); -extern char *XDisplayName( - _Xconst char* /* string */ -); -extern char *XKeysymToString( - KeySym /* keysym */ -); - -extern int (*XSynchronize( - Display* /* display */, - Bool /* onoff */ -))( - Display* /* display */ -); -extern int (*XSetAfterFunction( - Display* /* display */, - int (*) ( - Display* /* display */ - ) /* procedure */ -))( - Display* /* display */ -); -extern Atom XInternAtom( - Display* /* display */, - _Xconst char* /* atom_name */, - Bool /* only_if_exists */ -); -extern Status XInternAtoms( - Display* /* dpy */, - char** /* names */, - int /* count */, - Bool /* onlyIfExists */, - Atom* /* atoms_return */ -); -extern Colormap XCopyColormapAndFree( - Display* /* display */, - Colormap /* colormap */ -); -extern Colormap XCreateColormap( - Display* /* display */, - Window /* w */, - Visual* /* visual */, - int /* alloc */ -); -extern Cursor XCreatePixmapCursor( - Display* /* display */, - Pixmap /* source */, - Pixmap /* mask */, - XColor* /* foreground_color */, - XColor* /* background_color */, - unsigned int /* x */, - unsigned int /* y */ -); -extern Cursor XCreateGlyphCursor( - Display* /* display */, - Font /* source_font */, - Font /* mask_font */, - unsigned int /* source_char */, - unsigned int /* mask_char */, - XColor _Xconst * /* foreground_color */, - XColor _Xconst * /* background_color */ -); -extern Cursor XCreateFontCursor( - Display* /* display */, - unsigned int /* shape */ -); -extern Font XLoadFont( - Display* /* display */, - _Xconst char* /* name */ -); -extern GC XCreateGC( - Display* /* display */, - Drawable /* d */, - unsigned long /* valuemask */, - XGCValues* /* values */ -); -extern GContext XGContextFromGC( - GC /* gc */ -); -extern void XFlushGC( - Display* /* display */, - GC /* gc */ -); -extern Pixmap XCreatePixmap( - Display* /* display */, - Drawable /* d */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int /* depth */ -); -extern Pixmap XCreateBitmapFromData( - Display* /* display */, - Drawable /* d */, - _Xconst char* /* data */, - unsigned int /* width */, - unsigned int /* height */ -); -extern Pixmap XCreatePixmapFromBitmapData( - Display* /* display */, - Drawable /* d */, - char* /* data */, - unsigned int /* width */, - unsigned int /* height */, - unsigned long /* fg */, - unsigned long /* bg */, - unsigned int /* depth */ -); -extern Window XCreateSimpleWindow( - Display* /* display */, - Window /* parent */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int /* border_width */, - unsigned long /* border */, - unsigned long /* background */ -); -extern Window XGetSelectionOwner( - Display* /* display */, - Atom /* selection */ -); -extern Window XCreateWindow( - Display* /* display */, - Window /* parent */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int /* border_width */, - int /* depth */, - unsigned int /* class */, - Visual* /* visual */, - unsigned long /* valuemask */, - XSetWindowAttributes* /* attributes */ -); -extern Colormap *XListInstalledColormaps( - Display* /* display */, - Window /* w */, - int* /* num_return */ -); -extern char **XListFonts( - Display* /* display */, - _Xconst char* /* pattern */, - int /* maxnames */, - int* /* actual_count_return */ -); -extern char **XListFontsWithInfo( - Display* /* display */, - _Xconst char* /* pattern */, - int /* maxnames */, - int* /* count_return */, - XFontStruct** /* info_return */ -); -extern char **XGetFontPath( - Display* /* display */, - int* /* npaths_return */ -); -extern char **XListExtensions( - Display* /* display */, - int* /* nextensions_return */ -); -extern Atom *XListProperties( - Display* /* display */, - Window /* w */, - int* /* num_prop_return */ -); -extern XHostAddress *XListHosts( - Display* /* display */, - int* /* nhosts_return */, - Bool* /* state_return */ -); -_X_DEPRECATED -extern KeySym XKeycodeToKeysym( - Display* /* display */, -#if NeedWidePrototypes - unsigned int /* keycode */, -#else - KeyCode /* keycode */, -#endif - int /* index */ -); -extern KeySym XLookupKeysym( - XKeyEvent* /* key_event */, - int /* index */ -); -extern KeySym *XGetKeyboardMapping( - Display* /* display */, -#if NeedWidePrototypes - unsigned int /* first_keycode */, -#else - KeyCode /* first_keycode */, -#endif - int /* keycode_count */, - int* /* keysyms_per_keycode_return */ -); -extern KeySym XStringToKeysym( - _Xconst char* /* string */ -); -extern long XMaxRequestSize( - Display* /* display */ -); -extern long XExtendedMaxRequestSize( - Display* /* display */ -); -extern char *XResourceManagerString( - Display* /* display */ -); -extern char *XScreenResourceString( - Screen* /* screen */ -); -extern unsigned long XDisplayMotionBufferSize( - Display* /* display */ -); -extern VisualID XVisualIDFromVisual( - Visual* /* visual */ -); - -/* multithread routines */ - -extern Status XInitThreads( - void -); - -extern void XLockDisplay( - Display* /* display */ -); - -extern void XUnlockDisplay( - Display* /* display */ -); - -/* routines for dealing with extensions */ - -extern XExtCodes *XInitExtension( - Display* /* display */, - _Xconst char* /* name */ -); - -extern XExtCodes *XAddExtension( - Display* /* display */ -); -extern XExtData *XFindOnExtensionList( - XExtData** /* structure */, - int /* number */ -); -extern XExtData **XEHeadOfExtensionList( - XEDataObject /* object */ -); - -/* these are routines for which there are also macros */ -extern Window XRootWindow( - Display* /* display */, - int /* screen_number */ -); -extern Window XDefaultRootWindow( - Display* /* display */ -); -extern Window XRootWindowOfScreen( - Screen* /* screen */ -); -extern Visual *XDefaultVisual( - Display* /* display */, - int /* screen_number */ -); -extern Visual *XDefaultVisualOfScreen( - Screen* /* screen */ -); -extern GC XDefaultGC( - Display* /* display */, - int /* screen_number */ -); -extern GC XDefaultGCOfScreen( - Screen* /* screen */ -); -extern unsigned long XBlackPixel( - Display* /* display */, - int /* screen_number */ -); -extern unsigned long XWhitePixel( - Display* /* display */, - int /* screen_number */ -); -extern unsigned long XAllPlanes( - void -); -extern unsigned long XBlackPixelOfScreen( - Screen* /* screen */ -); -extern unsigned long XWhitePixelOfScreen( - Screen* /* screen */ -); -extern unsigned long XNextRequest( - Display* /* display */ -); -extern unsigned long XLastKnownRequestProcessed( - Display* /* display */ -); -extern char *XServerVendor( - Display* /* display */ -); -extern char *XDisplayString( - Display* /* display */ -); -extern Colormap XDefaultColormap( - Display* /* display */, - int /* screen_number */ -); -extern Colormap XDefaultColormapOfScreen( - Screen* /* screen */ -); -extern Display *XDisplayOfScreen( - Screen* /* screen */ -); -extern Screen *XScreenOfDisplay( - Display* /* display */, - int /* screen_number */ -); -extern Screen *XDefaultScreenOfDisplay( - Display* /* display */ -); -extern long XEventMaskOfScreen( - Screen* /* screen */ -); - -extern int XScreenNumberOfScreen( - Screen* /* screen */ -); - -typedef int (*XErrorHandler) ( /* WARNING, this type not in Xlib spec */ - Display* /* display */, - XErrorEvent* /* error_event */ -); - -extern XErrorHandler XSetErrorHandler ( - XErrorHandler /* handler */ -); - - -typedef int (*XIOErrorHandler) ( /* WARNING, this type not in Xlib spec */ - Display* /* display */ -); - -extern XIOErrorHandler XSetIOErrorHandler ( - XIOErrorHandler /* handler */ -); - - -extern XPixmapFormatValues *XListPixmapFormats( - Display* /* display */, - int* /* count_return */ -); -extern int *XListDepths( - Display* /* display */, - int /* screen_number */, - int* /* count_return */ -); - -/* ICCCM routines for things that don't require special include files; */ -/* other declarations are given in Xutil.h */ -extern Status XReconfigureWMWindow( - Display* /* display */, - Window /* w */, - int /* screen_number */, - unsigned int /* mask */, - XWindowChanges* /* changes */ -); - -extern Status XGetWMProtocols( - Display* /* display */, - Window /* w */, - Atom** /* protocols_return */, - int* /* count_return */ -); -extern Status XSetWMProtocols( - Display* /* display */, - Window /* w */, - Atom* /* protocols */, - int /* count */ -); -extern Status XIconifyWindow( - Display* /* display */, - Window /* w */, - int /* screen_number */ -); -extern Status XWithdrawWindow( - Display* /* display */, - Window /* w */, - int /* screen_number */ -); -extern Status XGetCommand( - Display* /* display */, - Window /* w */, - char*** /* argv_return */, - int* /* argc_return */ -); -extern Status XGetWMColormapWindows( - Display* /* display */, - Window /* w */, - Window** /* windows_return */, - int* /* count_return */ -); -extern Status XSetWMColormapWindows( - Display* /* display */, - Window /* w */, - Window* /* colormap_windows */, - int /* count */ -); -extern void XFreeStringList( - char** /* list */ -); -extern int XSetTransientForHint( - Display* /* display */, - Window /* w */, - Window /* prop_window */ -); - -/* The following are given in alphabetical order */ - -extern int XActivateScreenSaver( - Display* /* display */ -); - -extern int XAddHost( - Display* /* display */, - XHostAddress* /* host */ -); - -extern int XAddHosts( - Display* /* display */, - XHostAddress* /* hosts */, - int /* num_hosts */ -); - -extern int XAddToExtensionList( - struct _XExtData** /* structure */, - XExtData* /* ext_data */ -); - -extern int XAddToSaveSet( - Display* /* display */, - Window /* w */ -); - -extern Status XAllocColor( - Display* /* display */, - Colormap /* colormap */, - XColor* /* screen_in_out */ -); - -extern Status XAllocColorCells( - Display* /* display */, - Colormap /* colormap */, - Bool /* contig */, - unsigned long* /* plane_masks_return */, - unsigned int /* nplanes */, - unsigned long* /* pixels_return */, - unsigned int /* npixels */ -); - -extern Status XAllocColorPlanes( - Display* /* display */, - Colormap /* colormap */, - Bool /* contig */, - unsigned long* /* pixels_return */, - int /* ncolors */, - int /* nreds */, - int /* ngreens */, - int /* nblues */, - unsigned long* /* rmask_return */, - unsigned long* /* gmask_return */, - unsigned long* /* bmask_return */ -); - -extern Status XAllocNamedColor( - Display* /* display */, - Colormap /* colormap */, - _Xconst char* /* color_name */, - XColor* /* screen_def_return */, - XColor* /* exact_def_return */ -); - -extern int XAllowEvents( - Display* /* display */, - int /* event_mode */, - Time /* time */ -); - -extern int XAutoRepeatOff( - Display* /* display */ -); - -extern int XAutoRepeatOn( - Display* /* display */ -); - -extern int XBell( - Display* /* display */, - int /* percent */ -); - -extern int XBitmapBitOrder( - Display* /* display */ -); - -extern int XBitmapPad( - Display* /* display */ -); - -extern int XBitmapUnit( - Display* /* display */ -); - -extern int XCellsOfScreen( - Screen* /* screen */ -); - -extern int XChangeActivePointerGrab( - Display* /* display */, - unsigned int /* event_mask */, - Cursor /* cursor */, - Time /* time */ -); - -extern int XChangeGC( - Display* /* display */, - GC /* gc */, - unsigned long /* valuemask */, - XGCValues* /* values */ -); - -extern int XChangeKeyboardControl( - Display* /* display */, - unsigned long /* value_mask */, - XKeyboardControl* /* values */ -); - -extern int XChangeKeyboardMapping( - Display* /* display */, - int /* first_keycode */, - int /* keysyms_per_keycode */, - KeySym* /* keysyms */, - int /* num_codes */ -); - -extern int XChangePointerControl( - Display* /* display */, - Bool /* do_accel */, - Bool /* do_threshold */, - int /* accel_numerator */, - int /* accel_denominator */, - int /* threshold */ -); - -extern int XChangeProperty( - Display* /* display */, - Window /* w */, - Atom /* property */, - Atom /* type */, - int /* format */, - int /* mode */, - _Xconst unsigned char* /* data */, - int /* nelements */ -); - -extern int XChangeSaveSet( - Display* /* display */, - Window /* w */, - int /* change_mode */ -); - -extern int XChangeWindowAttributes( - Display* /* display */, - Window /* w */, - unsigned long /* valuemask */, - XSetWindowAttributes* /* attributes */ -); - -extern Bool XCheckIfEvent( - Display* /* display */, - XEvent* /* event_return */, - Bool (*) ( - Display* /* display */, - XEvent* /* event */, - XPointer /* arg */ - ) /* predicate */, - XPointer /* arg */ -); - -extern Bool XCheckMaskEvent( - Display* /* display */, - long /* event_mask */, - XEvent* /* event_return */ -); - -extern Bool XCheckTypedEvent( - Display* /* display */, - int /* event_type */, - XEvent* /* event_return */ -); - -extern Bool XCheckTypedWindowEvent( - Display* /* display */, - Window /* w */, - int /* event_type */, - XEvent* /* event_return */ -); - -extern Bool XCheckWindowEvent( - Display* /* display */, - Window /* w */, - long /* event_mask */, - XEvent* /* event_return */ -); - -extern int XCirculateSubwindows( - Display* /* display */, - Window /* w */, - int /* direction */ -); - -extern int XCirculateSubwindowsDown( - Display* /* display */, - Window /* w */ -); - -extern int XCirculateSubwindowsUp( - Display* /* display */, - Window /* w */ -); - -extern int XClearArea( - Display* /* display */, - Window /* w */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - Bool /* exposures */ -); - -extern int XClearWindow( - Display* /* display */, - Window /* w */ -); - -extern int XCloseDisplay( - Display* /* display */ -); - -extern int XConfigureWindow( - Display* /* display */, - Window /* w */, - unsigned int /* value_mask */, - XWindowChanges* /* values */ -); - -extern int XConnectionNumber( - Display* /* display */ -); - -extern int XConvertSelection( - Display* /* display */, - Atom /* selection */, - Atom /* target */, - Atom /* property */, - Window /* requestor */, - Time /* time */ -); - -extern int XCopyArea( - Display* /* display */, - Drawable /* src */, - Drawable /* dest */, - GC /* gc */, - int /* src_x */, - int /* src_y */, - unsigned int /* width */, - unsigned int /* height */, - int /* dest_x */, - int /* dest_y */ -); - -extern int XCopyGC( - Display* /* display */, - GC /* src */, - unsigned long /* valuemask */, - GC /* dest */ -); - -extern int XCopyPlane( - Display* /* display */, - Drawable /* src */, - Drawable /* dest */, - GC /* gc */, - int /* src_x */, - int /* src_y */, - unsigned int /* width */, - unsigned int /* height */, - int /* dest_x */, - int /* dest_y */, - unsigned long /* plane */ -); - -extern int XDefaultDepth( - Display* /* display */, - int /* screen_number */ -); - -extern int XDefaultDepthOfScreen( - Screen* /* screen */ -); - -extern int XDefaultScreen( - Display* /* display */ -); - -extern int XDefineCursor( - Display* /* display */, - Window /* w */, - Cursor /* cursor */ -); - -extern int XDeleteProperty( - Display* /* display */, - Window /* w */, - Atom /* property */ -); - -extern int XDestroyWindow( - Display* /* display */, - Window /* w */ -); - -extern int XDestroySubwindows( - Display* /* display */, - Window /* w */ -); - -extern int XDoesBackingStore( - Screen* /* screen */ -); - -extern Bool XDoesSaveUnders( - Screen* /* screen */ -); - -extern int XDisableAccessControl( - Display* /* display */ -); - - -extern int XDisplayCells( - Display* /* display */, - int /* screen_number */ -); - -extern int XDisplayHeight( - Display* /* display */, - int /* screen_number */ -); - -extern int XDisplayHeightMM( - Display* /* display */, - int /* screen_number */ -); - -extern int XDisplayKeycodes( - Display* /* display */, - int* /* min_keycodes_return */, - int* /* max_keycodes_return */ -); - -extern int XDisplayPlanes( - Display* /* display */, - int /* screen_number */ -); - -extern int XDisplayWidth( - Display* /* display */, - int /* screen_number */ -); - -extern int XDisplayWidthMM( - Display* /* display */, - int /* screen_number */ -); - -extern int XDrawArc( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - int /* angle1 */, - int /* angle2 */ -); - -extern int XDrawArcs( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XArc* /* arcs */, - int /* narcs */ -); - -extern int XDrawImageString( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst char* /* string */, - int /* length */ -); - -extern int XDrawImageString16( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst XChar2b* /* string */, - int /* length */ -); - -extern int XDrawLine( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x1 */, - int /* y1 */, - int /* x2 */, - int /* y2 */ -); - -extern int XDrawLines( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XPoint* /* points */, - int /* npoints */, - int /* mode */ -); - -extern int XDrawPoint( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */ -); - -extern int XDrawPoints( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XPoint* /* points */, - int /* npoints */, - int /* mode */ -); - -extern int XDrawRectangle( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */ -); - -extern int XDrawRectangles( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XRectangle* /* rectangles */, - int /* nrectangles */ -); - -extern int XDrawSegments( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XSegment* /* segments */, - int /* nsegments */ -); - -extern int XDrawString( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst char* /* string */, - int /* length */ -); - -extern int XDrawString16( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst XChar2b* /* string */, - int /* length */ -); - -extern int XDrawText( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - XTextItem* /* items */, - int /* nitems */ -); - -extern int XDrawText16( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - XTextItem16* /* items */, - int /* nitems */ -); - -extern int XEnableAccessControl( - Display* /* display */ -); - -extern int XEventsQueued( - Display* /* display */, - int /* mode */ -); - -extern Status XFetchName( - Display* /* display */, - Window /* w */, - char** /* window_name_return */ -); - -extern int XFillArc( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */, - int /* angle1 */, - int /* angle2 */ -); - -extern int XFillArcs( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XArc* /* arcs */, - int /* narcs */ -); - -extern int XFillPolygon( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XPoint* /* points */, - int /* npoints */, - int /* shape */, - int /* mode */ -); - -extern int XFillRectangle( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */ -); - -extern int XFillRectangles( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XRectangle* /* rectangles */, - int /* nrectangles */ -); - -extern int XFlush( - Display* /* display */ -); - -extern int XForceScreenSaver( - Display* /* display */, - int /* mode */ -); - -extern int XFree( - void* /* data */ -); - -extern int XFreeColormap( - Display* /* display */, - Colormap /* colormap */ -); - -extern int XFreeColors( - Display* /* display */, - Colormap /* colormap */, - unsigned long* /* pixels */, - int /* npixels */, - unsigned long /* planes */ -); - -extern int XFreeCursor( - Display* /* display */, - Cursor /* cursor */ -); - -extern int XFreeExtensionList( - char** /* list */ -); - -extern int XFreeFont( - Display* /* display */, - XFontStruct* /* font_struct */ -); - -extern int XFreeFontInfo( - char** /* names */, - XFontStruct* /* free_info */, - int /* actual_count */ -); - -extern int XFreeFontNames( - char** /* list */ -); - -extern int XFreeFontPath( - char** /* list */ -); - -extern int XFreeGC( - Display* /* display */, - GC /* gc */ -); - -extern int XFreeModifiermap( - XModifierKeymap* /* modmap */ -); - -extern int XFreePixmap( - Display* /* display */, - Pixmap /* pixmap */ -); - -extern int XGeometry( - Display* /* display */, - int /* screen */, - _Xconst char* /* position */, - _Xconst char* /* default_position */, - unsigned int /* bwidth */, - unsigned int /* fwidth */, - unsigned int /* fheight */, - int /* xadder */, - int /* yadder */, - int* /* x_return */, - int* /* y_return */, - int* /* width_return */, - int* /* height_return */ -); - -extern int XGetErrorDatabaseText( - Display* /* display */, - _Xconst char* /* name */, - _Xconst char* /* message */, - _Xconst char* /* default_string */, - char* /* buffer_return */, - int /* length */ -); - -extern int XGetErrorText( - Display* /* display */, - int /* code */, - char* /* buffer_return */, - int /* length */ -); - -extern Bool XGetFontProperty( - XFontStruct* /* font_struct */, - Atom /* atom */, - unsigned long* /* value_return */ -); - -extern Status XGetGCValues( - Display* /* display */, - GC /* gc */, - unsigned long /* valuemask */, - XGCValues* /* values_return */ -); - -extern Status XGetGeometry( - Display* /* display */, - Drawable /* d */, - Window* /* root_return */, - int* /* x_return */, - int* /* y_return */, - unsigned int* /* width_return */, - unsigned int* /* height_return */, - unsigned int* /* border_width_return */, - unsigned int* /* depth_return */ -); - -extern Status XGetIconName( - Display* /* display */, - Window /* w */, - char** /* icon_name_return */ -); - -extern int XGetInputFocus( - Display* /* display */, - Window* /* focus_return */, - int* /* revert_to_return */ -); - -extern int XGetKeyboardControl( - Display* /* display */, - XKeyboardState* /* values_return */ -); - -extern int XGetPointerControl( - Display* /* display */, - int* /* accel_numerator_return */, - int* /* accel_denominator_return */, - int* /* threshold_return */ -); - -extern int XGetPointerMapping( - Display* /* display */, - unsigned char* /* map_return */, - int /* nmap */ -); - -extern int XGetScreenSaver( - Display* /* display */, - int* /* timeout_return */, - int* /* interval_return */, - int* /* prefer_blanking_return */, - int* /* allow_exposures_return */ -); - -extern Status XGetTransientForHint( - Display* /* display */, - Window /* w */, - Window* /* prop_window_return */ -); - -extern int XGetWindowProperty( - Display* /* display */, - Window /* w */, - Atom /* property */, - long /* long_offset */, - long /* long_length */, - Bool /* delete */, - Atom /* req_type */, - Atom* /* actual_type_return */, - int* /* actual_format_return */, - unsigned long* /* nitems_return */, - unsigned long* /* bytes_after_return */, - unsigned char** /* prop_return */ -); - -extern Status XGetWindowAttributes( - Display* /* display */, - Window /* w */, - XWindowAttributes* /* window_attributes_return */ -); - -extern int XGrabButton( - Display* /* display */, - unsigned int /* button */, - unsigned int /* modifiers */, - Window /* grab_window */, - Bool /* owner_events */, - unsigned int /* event_mask */, - int /* pointer_mode */, - int /* keyboard_mode */, - Window /* confine_to */, - Cursor /* cursor */ -); - -extern int XGrabKey( - Display* /* display */, - int /* keycode */, - unsigned int /* modifiers */, - Window /* grab_window */, - Bool /* owner_events */, - int /* pointer_mode */, - int /* keyboard_mode */ -); - -extern int XGrabKeyboard( - Display* /* display */, - Window /* grab_window */, - Bool /* owner_events */, - int /* pointer_mode */, - int /* keyboard_mode */, - Time /* time */ -); - -extern int XGrabPointer( - Display* /* display */, - Window /* grab_window */, - Bool /* owner_events */, - unsigned int /* event_mask */, - int /* pointer_mode */, - int /* keyboard_mode */, - Window /* confine_to */, - Cursor /* cursor */, - Time /* time */ -); - -extern int XGrabServer( - Display* /* display */ -); - -extern int XHeightMMOfScreen( - Screen* /* screen */ -); - -extern int XHeightOfScreen( - Screen* /* screen */ -); - -extern int XIfEvent( - Display* /* display */, - XEvent* /* event_return */, - Bool (*) ( - Display* /* display */, - XEvent* /* event */, - XPointer /* arg */ - ) /* predicate */, - XPointer /* arg */ -); - -extern int XImageByteOrder( - Display* /* display */ -); - -extern int XInstallColormap( - Display* /* display */, - Colormap /* colormap */ -); - -extern KeyCode XKeysymToKeycode( - Display* /* display */, - KeySym /* keysym */ -); - -extern int XKillClient( - Display* /* display */, - XID /* resource */ -); - -extern Status XLookupColor( - Display* /* display */, - Colormap /* colormap */, - _Xconst char* /* color_name */, - XColor* /* exact_def_return */, - XColor* /* screen_def_return */ -); - -extern int XLowerWindow( - Display* /* display */, - Window /* w */ -); - -extern int XMapRaised( - Display* /* display */, - Window /* w */ -); - -extern int XMapSubwindows( - Display* /* display */, - Window /* w */ -); - -extern int XMapWindow( - Display* /* display */, - Window /* w */ -); - -extern int XMaskEvent( - Display* /* display */, - long /* event_mask */, - XEvent* /* event_return */ -); - -extern int XMaxCmapsOfScreen( - Screen* /* screen */ -); - -extern int XMinCmapsOfScreen( - Screen* /* screen */ -); - -extern int XMoveResizeWindow( - Display* /* display */, - Window /* w */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */ -); - -extern int XMoveWindow( - Display* /* display */, - Window /* w */, - int /* x */, - int /* y */ -); - -extern int XNextEvent( - Display* /* display */, - XEvent* /* event_return */ -); - -extern int XNoOp( - Display* /* display */ -); - -extern Status XParseColor( - Display* /* display */, - Colormap /* colormap */, - _Xconst char* /* spec */, - XColor* /* exact_def_return */ -); - -extern int XParseGeometry( - _Xconst char* /* parsestring */, - int* /* x_return */, - int* /* y_return */, - unsigned int* /* width_return */, - unsigned int* /* height_return */ -); - -extern int XPeekEvent( - Display* /* display */, - XEvent* /* event_return */ -); - -extern int XPeekIfEvent( - Display* /* display */, - XEvent* /* event_return */, - Bool (*) ( - Display* /* display */, - XEvent* /* event */, - XPointer /* arg */ - ) /* predicate */, - XPointer /* arg */ -); - -extern int XPending( - Display* /* display */ -); - -extern int XPlanesOfScreen( - Screen* /* screen */ -); - -extern int XProtocolRevision( - Display* /* display */ -); - -extern int XProtocolVersion( - Display* /* display */ -); - - -extern int XPutBackEvent( - Display* /* display */, - XEvent* /* event */ -); - -extern int XPutImage( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - XImage* /* image */, - int /* src_x */, - int /* src_y */, - int /* dest_x */, - int /* dest_y */, - unsigned int /* width */, - unsigned int /* height */ -); - -extern int XQLength( - Display* /* display */ -); - -extern Status XQueryBestCursor( - Display* /* display */, - Drawable /* d */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int* /* width_return */, - unsigned int* /* height_return */ -); - -extern Status XQueryBestSize( - Display* /* display */, - int /* class */, - Drawable /* which_screen */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int* /* width_return */, - unsigned int* /* height_return */ -); - -extern Status XQueryBestStipple( - Display* /* display */, - Drawable /* which_screen */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int* /* width_return */, - unsigned int* /* height_return */ -); - -extern Status XQueryBestTile( - Display* /* display */, - Drawable /* which_screen */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int* /* width_return */, - unsigned int* /* height_return */ -); - -extern int XQueryColor( - Display* /* display */, - Colormap /* colormap */, - XColor* /* def_in_out */ -); - -extern int XQueryColors( - Display* /* display */, - Colormap /* colormap */, - XColor* /* defs_in_out */, - int /* ncolors */ -); - -extern Bool XQueryExtension( - Display* /* display */, - _Xconst char* /* name */, - int* /* major_opcode_return */, - int* /* first_event_return */, - int* /* first_error_return */ -); - -extern int XQueryKeymap( - Display* /* display */, - char [32] /* keys_return */ -); - -extern Bool XQueryPointer( - Display* /* display */, - Window /* w */, - Window* /* root_return */, - Window* /* child_return */, - int* /* root_x_return */, - int* /* root_y_return */, - int* /* win_x_return */, - int* /* win_y_return */, - unsigned int* /* mask_return */ -); - -extern int XQueryTextExtents( - Display* /* display */, - XID /* font_ID */, - _Xconst char* /* string */, - int /* nchars */, - int* /* direction_return */, - int* /* font_ascent_return */, - int* /* font_descent_return */, - XCharStruct* /* overall_return */ -); - -extern int XQueryTextExtents16( - Display* /* display */, - XID /* font_ID */, - _Xconst XChar2b* /* string */, - int /* nchars */, - int* /* direction_return */, - int* /* font_ascent_return */, - int* /* font_descent_return */, - XCharStruct* /* overall_return */ -); - -extern Status XQueryTree( - Display* /* display */, - Window /* w */, - Window* /* root_return */, - Window* /* parent_return */, - Window** /* children_return */, - unsigned int* /* nchildren_return */ -); - -extern int XRaiseWindow( - Display* /* display */, - Window /* w */ -); - -extern int XReadBitmapFile( - Display* /* display */, - Drawable /* d */, - _Xconst char* /* filename */, - unsigned int* /* width_return */, - unsigned int* /* height_return */, - Pixmap* /* bitmap_return */, - int* /* x_hot_return */, - int* /* y_hot_return */ -); - -extern int XReadBitmapFileData( - _Xconst char* /* filename */, - unsigned int* /* width_return */, - unsigned int* /* height_return */, - unsigned char** /* data_return */, - int* /* x_hot_return */, - int* /* y_hot_return */ -); - -extern int XRebindKeysym( - Display* /* display */, - KeySym /* keysym */, - KeySym* /* list */, - int /* mod_count */, - _Xconst unsigned char* /* string */, - int /* bytes_string */ -); - -extern int XRecolorCursor( - Display* /* display */, - Cursor /* cursor */, - XColor* /* foreground_color */, - XColor* /* background_color */ -); - -extern int XRefreshKeyboardMapping( - XMappingEvent* /* event_map */ -); - -extern int XRemoveFromSaveSet( - Display* /* display */, - Window /* w */ -); - -extern int XRemoveHost( - Display* /* display */, - XHostAddress* /* host */ -); - -extern int XRemoveHosts( - Display* /* display */, - XHostAddress* /* hosts */, - int /* num_hosts */ -); - -extern int XReparentWindow( - Display* /* display */, - Window /* w */, - Window /* parent */, - int /* x */, - int /* y */ -); - -extern int XResetScreenSaver( - Display* /* display */ -); - -extern int XResizeWindow( - Display* /* display */, - Window /* w */, - unsigned int /* width */, - unsigned int /* height */ -); - -extern int XRestackWindows( - Display* /* display */, - Window* /* windows */, - int /* nwindows */ -); - -extern int XRotateBuffers( - Display* /* display */, - int /* rotate */ -); - -extern int XRotateWindowProperties( - Display* /* display */, - Window /* w */, - Atom* /* properties */, - int /* num_prop */, - int /* npositions */ -); - -extern int XScreenCount( - Display* /* display */ -); - -extern int XSelectInput( - Display* /* display */, - Window /* w */, - long /* event_mask */ -); - -extern Status XSendEvent( - Display* /* display */, - Window /* w */, - Bool /* propagate */, - long /* event_mask */, - XEvent* /* event_send */ -); - -extern int XSetAccessControl( - Display* /* display */, - int /* mode */ -); - -extern int XSetArcMode( - Display* /* display */, - GC /* gc */, - int /* arc_mode */ -); - -extern int XSetBackground( - Display* /* display */, - GC /* gc */, - unsigned long /* background */ -); - -extern int XSetClipMask( - Display* /* display */, - GC /* gc */, - Pixmap /* pixmap */ -); - -extern int XSetClipOrigin( - Display* /* display */, - GC /* gc */, - int /* clip_x_origin */, - int /* clip_y_origin */ -); - -extern int XSetClipRectangles( - Display* /* display */, - GC /* gc */, - int /* clip_x_origin */, - int /* clip_y_origin */, - XRectangle* /* rectangles */, - int /* n */, - int /* ordering */ -); - -extern int XSetCloseDownMode( - Display* /* display */, - int /* close_mode */ -); - -extern int XSetCommand( - Display* /* display */, - Window /* w */, - char** /* argv */, - int /* argc */ -); - -extern int XSetDashes( - Display* /* display */, - GC /* gc */, - int /* dash_offset */, - _Xconst char* /* dash_list */, - int /* n */ -); - -extern int XSetFillRule( - Display* /* display */, - GC /* gc */, - int /* fill_rule */ -); - -extern int XSetFillStyle( - Display* /* display */, - GC /* gc */, - int /* fill_style */ -); - -extern int XSetFont( - Display* /* display */, - GC /* gc */, - Font /* font */ -); - -extern int XSetFontPath( - Display* /* display */, - char** /* directories */, - int /* ndirs */ -); - -extern int XSetForeground( - Display* /* display */, - GC /* gc */, - unsigned long /* foreground */ -); - -extern int XSetFunction( - Display* /* display */, - GC /* gc */, - int /* function */ -); - -extern int XSetGraphicsExposures( - Display* /* display */, - GC /* gc */, - Bool /* graphics_exposures */ -); - -extern int XSetIconName( - Display* /* display */, - Window /* w */, - _Xconst char* /* icon_name */ -); - -extern int XSetInputFocus( - Display* /* display */, - Window /* focus */, - int /* revert_to */, - Time /* time */ -); - -extern int XSetLineAttributes( - Display* /* display */, - GC /* gc */, - unsigned int /* line_width */, - int /* line_style */, - int /* cap_style */, - int /* join_style */ -); - -extern int XSetModifierMapping( - Display* /* display */, - XModifierKeymap* /* modmap */ -); - -extern int XSetPlaneMask( - Display* /* display */, - GC /* gc */, - unsigned long /* plane_mask */ -); - -extern int XSetPointerMapping( - Display* /* display */, - _Xconst unsigned char* /* map */, - int /* nmap */ -); - -extern int XSetScreenSaver( - Display* /* display */, - int /* timeout */, - int /* interval */, - int /* prefer_blanking */, - int /* allow_exposures */ -); - -extern int XSetSelectionOwner( - Display* /* display */, - Atom /* selection */, - Window /* owner */, - Time /* time */ -); - -extern int XSetState( - Display* /* display */, - GC /* gc */, - unsigned long /* foreground */, - unsigned long /* background */, - int /* function */, - unsigned long /* plane_mask */ -); - -extern int XSetStipple( - Display* /* display */, - GC /* gc */, - Pixmap /* stipple */ -); - -extern int XSetSubwindowMode( - Display* /* display */, - GC /* gc */, - int /* subwindow_mode */ -); - -extern int XSetTSOrigin( - Display* /* display */, - GC /* gc */, - int /* ts_x_origin */, - int /* ts_y_origin */ -); - -extern int XSetTile( - Display* /* display */, - GC /* gc */, - Pixmap /* tile */ -); - -extern int XSetWindowBackground( - Display* /* display */, - Window /* w */, - unsigned long /* background_pixel */ -); - -extern int XSetWindowBackgroundPixmap( - Display* /* display */, - Window /* w */, - Pixmap /* background_pixmap */ -); - -extern int XSetWindowBorder( - Display* /* display */, - Window /* w */, - unsigned long /* border_pixel */ -); - -extern int XSetWindowBorderPixmap( - Display* /* display */, - Window /* w */, - Pixmap /* border_pixmap */ -); - -extern int XSetWindowBorderWidth( - Display* /* display */, - Window /* w */, - unsigned int /* width */ -); - -extern int XSetWindowColormap( - Display* /* display */, - Window /* w */, - Colormap /* colormap */ -); - -extern int XStoreBuffer( - Display* /* display */, - _Xconst char* /* bytes */, - int /* nbytes */, - int /* buffer */ -); - -extern int XStoreBytes( - Display* /* display */, - _Xconst char* /* bytes */, - int /* nbytes */ -); - -extern int XStoreColor( - Display* /* display */, - Colormap /* colormap */, - XColor* /* color */ -); - -extern int XStoreColors( - Display* /* display */, - Colormap /* colormap */, - XColor* /* color */, - int /* ncolors */ -); - -extern int XStoreName( - Display* /* display */, - Window /* w */, - _Xconst char* /* window_name */ -); - -extern int XStoreNamedColor( - Display* /* display */, - Colormap /* colormap */, - _Xconst char* /* color */, - unsigned long /* pixel */, - int /* flags */ -); - -extern int XSync( - Display* /* display */, - Bool /* discard */ -); - -extern int XTextExtents( - XFontStruct* /* font_struct */, - _Xconst char* /* string */, - int /* nchars */, - int* /* direction_return */, - int* /* font_ascent_return */, - int* /* font_descent_return */, - XCharStruct* /* overall_return */ -); - -extern int XTextExtents16( - XFontStruct* /* font_struct */, - _Xconst XChar2b* /* string */, - int /* nchars */, - int* /* direction_return */, - int* /* font_ascent_return */, - int* /* font_descent_return */, - XCharStruct* /* overall_return */ -); - -extern int XTextWidth( - XFontStruct* /* font_struct */, - _Xconst char* /* string */, - int /* count */ -); - -extern int XTextWidth16( - XFontStruct* /* font_struct */, - _Xconst XChar2b* /* string */, - int /* count */ -); - -extern Bool XTranslateCoordinates( - Display* /* display */, - Window /* src_w */, - Window /* dest_w */, - int /* src_x */, - int /* src_y */, - int* /* dest_x_return */, - int* /* dest_y_return */, - Window* /* child_return */ -); - -extern int XUndefineCursor( - Display* /* display */, - Window /* w */ -); - -extern int XUngrabButton( - Display* /* display */, - unsigned int /* button */, - unsigned int /* modifiers */, - Window /* grab_window */ -); - -extern int XUngrabKey( - Display* /* display */, - int /* keycode */, - unsigned int /* modifiers */, - Window /* grab_window */ -); - -extern int XUngrabKeyboard( - Display* /* display */, - Time /* time */ -); - -extern int XUngrabPointer( - Display* /* display */, - Time /* time */ -); - -extern int XUngrabServer( - Display* /* display */ -); - -extern int XUninstallColormap( - Display* /* display */, - Colormap /* colormap */ -); - -extern int XUnloadFont( - Display* /* display */, - Font /* font */ -); - -extern int XUnmapSubwindows( - Display* /* display */, - Window /* w */ -); - -extern int XUnmapWindow( - Display* /* display */, - Window /* w */ -); - -extern int XVendorRelease( - Display* /* display */ -); - -extern int XWarpPointer( - Display* /* display */, - Window /* src_w */, - Window /* dest_w */, - int /* src_x */, - int /* src_y */, - unsigned int /* src_width */, - unsigned int /* src_height */, - int /* dest_x */, - int /* dest_y */ -); - -extern int XWidthMMOfScreen( - Screen* /* screen */ -); - -extern int XWidthOfScreen( - Screen* /* screen */ -); - -extern int XWindowEvent( - Display* /* display */, - Window /* w */, - long /* event_mask */, - XEvent* /* event_return */ -); - -extern int XWriteBitmapFile( - Display* /* display */, - _Xconst char* /* filename */, - Pixmap /* bitmap */, - unsigned int /* width */, - unsigned int /* height */, - int /* x_hot */, - int /* y_hot */ -); - -extern Bool XSupportsLocale (void); - -extern char *XSetLocaleModifiers( - const char* /* modifier_list */ -); - -extern XOM XOpenOM( - Display* /* display */, - struct _XrmHashBucketRec* /* rdb */, - _Xconst char* /* res_name */, - _Xconst char* /* res_class */ -); - -extern Status XCloseOM( - XOM /* om */ -); - -extern char *XSetOMValues( - XOM /* om */, - ... -) _X_SENTINEL(0); - -extern char *XGetOMValues( - XOM /* om */, - ... -) _X_SENTINEL(0); - -extern Display *XDisplayOfOM( - XOM /* om */ -); - -extern char *XLocaleOfOM( - XOM /* om */ -); - -extern XOC XCreateOC( - XOM /* om */, - ... -) _X_SENTINEL(0); - -extern void XDestroyOC( - XOC /* oc */ -); - -extern XOM XOMOfOC( - XOC /* oc */ -); - -extern char *XSetOCValues( - XOC /* oc */, - ... -) _X_SENTINEL(0); - -extern char *XGetOCValues( - XOC /* oc */, - ... -) _X_SENTINEL(0); - -extern XFontSet XCreateFontSet( - Display* /* display */, - _Xconst char* /* base_font_name_list */, - char*** /* missing_charset_list */, - int* /* missing_charset_count */, - char** /* def_string */ -); - -extern void XFreeFontSet( - Display* /* display */, - XFontSet /* font_set */ -); - -extern int XFontsOfFontSet( - XFontSet /* font_set */, - XFontStruct*** /* font_struct_list */, - char*** /* font_name_list */ -); - -extern char *XBaseFontNameListOfFontSet( - XFontSet /* font_set */ -); - -extern char *XLocaleOfFontSet( - XFontSet /* font_set */ -); - -extern Bool XContextDependentDrawing( - XFontSet /* font_set */ -); - -extern Bool XDirectionalDependentDrawing( - XFontSet /* font_set */ -); - -extern Bool XContextualDrawing( - XFontSet /* font_set */ -); - -extern XFontSetExtents *XExtentsOfFontSet( - XFontSet /* font_set */ -); - -extern int XmbTextEscapement( - XFontSet /* font_set */, - _Xconst char* /* text */, - int /* bytes_text */ -); - -extern int XwcTextEscapement( - XFontSet /* font_set */, - _Xconst wchar_t* /* text */, - int /* num_wchars */ -); - -extern int Xutf8TextEscapement( - XFontSet /* font_set */, - _Xconst char* /* text */, - int /* bytes_text */ -); - -extern int XmbTextExtents( - XFontSet /* font_set */, - _Xconst char* /* text */, - int /* bytes_text */, - XRectangle* /* overall_ink_return */, - XRectangle* /* overall_logical_return */ -); - -extern int XwcTextExtents( - XFontSet /* font_set */, - _Xconst wchar_t* /* text */, - int /* num_wchars */, - XRectangle* /* overall_ink_return */, - XRectangle* /* overall_logical_return */ -); - -extern int Xutf8TextExtents( - XFontSet /* font_set */, - _Xconst char* /* text */, - int /* bytes_text */, - XRectangle* /* overall_ink_return */, - XRectangle* /* overall_logical_return */ -); - -extern Status XmbTextPerCharExtents( - XFontSet /* font_set */, - _Xconst char* /* text */, - int /* bytes_text */, - XRectangle* /* ink_extents_buffer */, - XRectangle* /* logical_extents_buffer */, - int /* buffer_size */, - int* /* num_chars */, - XRectangle* /* overall_ink_return */, - XRectangle* /* overall_logical_return */ -); - -extern Status XwcTextPerCharExtents( - XFontSet /* font_set */, - _Xconst wchar_t* /* text */, - int /* num_wchars */, - XRectangle* /* ink_extents_buffer */, - XRectangle* /* logical_extents_buffer */, - int /* buffer_size */, - int* /* num_chars */, - XRectangle* /* overall_ink_return */, - XRectangle* /* overall_logical_return */ -); - -extern Status Xutf8TextPerCharExtents( - XFontSet /* font_set */, - _Xconst char* /* text */, - int /* bytes_text */, - XRectangle* /* ink_extents_buffer */, - XRectangle* /* logical_extents_buffer */, - int /* buffer_size */, - int* /* num_chars */, - XRectangle* /* overall_ink_return */, - XRectangle* /* overall_logical_return */ -); - -extern void XmbDrawText( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - XmbTextItem* /* text_items */, - int /* nitems */ -); - -extern void XwcDrawText( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - XwcTextItem* /* text_items */, - int /* nitems */ -); - -extern void Xutf8DrawText( - Display* /* display */, - Drawable /* d */, - GC /* gc */, - int /* x */, - int /* y */, - XmbTextItem* /* text_items */, - int /* nitems */ -); - -extern void XmbDrawString( - Display* /* display */, - Drawable /* d */, - XFontSet /* font_set */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst char* /* text */, - int /* bytes_text */ -); - -extern void XwcDrawString( - Display* /* display */, - Drawable /* d */, - XFontSet /* font_set */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst wchar_t* /* text */, - int /* num_wchars */ -); - -extern void Xutf8DrawString( - Display* /* display */, - Drawable /* d */, - XFontSet /* font_set */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst char* /* text */, - int /* bytes_text */ -); - -extern void XmbDrawImageString( - Display* /* display */, - Drawable /* d */, - XFontSet /* font_set */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst char* /* text */, - int /* bytes_text */ -); - -extern void XwcDrawImageString( - Display* /* display */, - Drawable /* d */, - XFontSet /* font_set */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst wchar_t* /* text */, - int /* num_wchars */ -); - -extern void Xutf8DrawImageString( - Display* /* display */, - Drawable /* d */, - XFontSet /* font_set */, - GC /* gc */, - int /* x */, - int /* y */, - _Xconst char* /* text */, - int /* bytes_text */ -); - -extern XIM XOpenIM( - Display* /* dpy */, - struct _XrmHashBucketRec* /* rdb */, - char* /* res_name */, - char* /* res_class */ -); - -extern Status XCloseIM( - XIM /* im */ -); - -extern char *XGetIMValues( - XIM /* im */, ... -) _X_SENTINEL(0); - -extern char *XSetIMValues( - XIM /* im */, ... -) _X_SENTINEL(0); - -extern Display *XDisplayOfIM( - XIM /* im */ -); - -extern char *XLocaleOfIM( - XIM /* im*/ -); - -extern XIC XCreateIC( - XIM /* im */, ... -) _X_SENTINEL(0); - -extern void XDestroyIC( - XIC /* ic */ -); - -extern void XSetICFocus( - XIC /* ic */ -); - -extern void XUnsetICFocus( - XIC /* ic */ -); - -extern wchar_t *XwcResetIC( - XIC /* ic */ -); - -extern char *XmbResetIC( - XIC /* ic */ -); - -extern char *Xutf8ResetIC( - XIC /* ic */ -); - -extern char *XSetICValues( - XIC /* ic */, ... -) _X_SENTINEL(0); - -extern char *XGetICValues( - XIC /* ic */, ... -) _X_SENTINEL(0); - -extern XIM XIMOfIC( - XIC /* ic */ -); - -extern Bool XFilterEvent( - XEvent* /* event */, - Window /* window */ -); - -extern int XmbLookupString( - XIC /* ic */, - XKeyPressedEvent* /* event */, - char* /* buffer_return */, - int /* bytes_buffer */, - KeySym* /* keysym_return */, - Status* /* status_return */ -); - -extern int XwcLookupString( - XIC /* ic */, - XKeyPressedEvent* /* event */, - wchar_t* /* buffer_return */, - int /* wchars_buffer */, - KeySym* /* keysym_return */, - Status* /* status_return */ -); - -extern int Xutf8LookupString( - XIC /* ic */, - XKeyPressedEvent* /* event */, - char* /* buffer_return */, - int /* bytes_buffer */, - KeySym* /* keysym_return */, - Status* /* status_return */ -); - -extern XVaNestedList XVaCreateNestedList( - int /*unused*/, ... -) _X_SENTINEL(0); - -/* internal connections for IMs */ - -extern Bool XRegisterIMInstantiateCallback( - Display* /* dpy */, - struct _XrmHashBucketRec* /* rdb */, - char* /* res_name */, - char* /* res_class */, - XIDProc /* callback */, - XPointer /* client_data */ -); - -extern Bool XUnregisterIMInstantiateCallback( - Display* /* dpy */, - struct _XrmHashBucketRec* /* rdb */, - char* /* res_name */, - char* /* res_class */, - XIDProc /* callback */, - XPointer /* client_data */ -); - -typedef void (*XConnectionWatchProc)( - Display* /* dpy */, - XPointer /* client_data */, - int /* fd */, - Bool /* opening */, /* open or close flag */ - XPointer* /* watch_data */ /* open sets, close uses */ -); - - -extern Status XInternalConnectionNumbers( - Display* /* dpy */, - int** /* fd_return */, - int* /* count_return */ -); - -extern void XProcessInternalConnection( - Display* /* dpy */, - int /* fd */ -); - -extern Status XAddConnectionWatch( - Display* /* dpy */, - XConnectionWatchProc /* callback */, - XPointer /* client_data */ -); - -extern void XRemoveConnectionWatch( - Display* /* dpy */, - XConnectionWatchProc /* callback */, - XPointer /* client_data */ -); - -extern void XSetAuthorization( - char * /* name */, - int /* namelen */, - char * /* data */, - int /* datalen */ -); - -extern int _Xmbtowc( - wchar_t * /* wstr */, -#ifdef ISC - char const * /* str */, - size_t /* len */ -#else - char * /* str */, - int /* len */ -#endif -); - -extern int _Xwctomb( - char * /* str */, - wchar_t /* wc */ -); - -extern Bool XGetEventData( - Display* /* dpy */, - XGenericEventCookie* /* cookie*/ -); - -extern void XFreeEventData( - Display* /* dpy */, - XGenericEventCookie* /* cookie*/ -); - -#ifdef __clang__ -#pragma clang diagnostic pop -#endif - -_XFUNCPROTOEND - -#endif /* _X11_XLIB_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/XlibConf.h b/btgui/OpenGLWindow/optionalX11/X11/XlibConf.h deleted file mode 100644 index 9f9b94031..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/XlibConf.h +++ /dev/null @@ -1,38 +0,0 @@ -/* include/X11/XlibConf.h. Generated from XlibConf.h.in by configure. */ -/* - * Copyright © 2005 Keith Packard - * - * Permission to use, copy, modify, distribute, and sell this software and its - * documentation for any purpose is hereby granted without fee, provided that - * the above copyright notice appear in all copies and that both that - * copyright notice and this permission notice appear in supporting - * documentation, and that the name of Keith Packard not be used in - * advertising or publicity pertaining to distribution of the software without - * specific, written prior permission. Keith Packard makes no - * representations about the suitability of this software for any purpose. It - * is provided "as is" without express or implied warranty. - * - * KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, - * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO - * EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR - * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, - * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER - * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR - * PERFORMANCE OF THIS SOFTWARE. - */ - -#ifndef _XLIBCONF_H_ -#define _XLIBCONF_H_ -/* - * This header file exports defines necessary to correctly - * use Xlibint.h both inside Xlib and by external libraries - * such as extensions. - */ - -/* Threading support? */ -#define XTHREADS 1 - -/* Use multi-threaded libc functions? */ -#define XUSE_MTSAFE_API 1 - -#endif /* _XLIBCONF_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xlibint.h b/btgui/OpenGLWindow/optionalX11/X11/Xlibint.h deleted file mode 100644 index 443155964..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xlibint.h +++ /dev/null @@ -1,1334 +0,0 @@ - -/* - -Copyright 1984, 1985, 1987, 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included -in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS -OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR -OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR -OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall -not be used in advertising or otherwise to promote the sale, use or -other dealings in this Software without prior written authorization -from The Open Group. - -*/ - -#ifndef _X11_XLIBINT_H_ -#define _X11_XLIBINT_H_ 1 - -/* - * Xlibint.h - Header definition and support file for the internal - * support routines used by the C subroutine interface - * library (Xlib) to the X Window System. - * - * Warning, there be dragons here.... - */ - -#include -#include /* to declare xEvent */ -#include /* for configured options like XTHREADS */ - -/* The Xlib structs are full of implicit padding to properly align members. - We can't clean that up without breaking ABI, so tell clang not to bother - complaining about it. */ -#ifdef __clang__ -#pragma clang diagnostic push -#pragma clang diagnostic ignored "-Wpadded" -#endif - -#ifdef WIN32 -#define _XFlush _XFlushIt -#endif - -/* - * If your BytesReadable correctly detects broken connections, then - * you should NOT define XCONN_CHECK_FREQ. - */ -#ifndef XCONN_CHECK_FREQ -#define XCONN_CHECK_FREQ 256 -#endif - -struct _XGC -{ - XExtData *ext_data; /* hook for extension to hang data */ - GContext gid; /* protocol ID for graphics context */ - Bool rects; /* boolean: TRUE if clipmask is list of rectangles */ - Bool dashes; /* boolean: TRUE if dash-list is really a list */ - unsigned long dirty;/* cache dirty bits */ - XGCValues values; /* shadow structure of values */ -}; - -struct _XDisplay -{ - XExtData *ext_data; /* hook for extension to hang data */ - struct _XFreeFuncs *free_funcs; /* internal free functions */ - int fd; /* Network socket. */ - int conn_checker; /* ugly thing used by _XEventsQueued */ - int proto_major_version;/* maj. version of server's X protocol */ - int proto_minor_version;/* minor version of server's X protocol */ - char *vendor; /* vendor of the server hardware */ - XID resource_base; /* resource ID base */ - XID resource_mask; /* resource ID mask bits */ - XID resource_id; /* allocator current ID */ - int resource_shift; /* allocator shift to correct bits */ - XID (*resource_alloc)( /* allocator function */ - struct _XDisplay* - ); - int byte_order; /* screen byte order, LSBFirst, MSBFirst */ - int bitmap_unit; /* padding and data requirements */ - int bitmap_pad; /* padding requirements on bitmaps */ - int bitmap_bit_order; /* LeastSignificant or MostSignificant */ - int nformats; /* number of pixmap formats in list */ - ScreenFormat *pixmap_format; /* pixmap format list */ - int vnumber; /* Xlib's X protocol version number. */ - int release; /* release of the server */ - struct _XSQEvent *head, *tail; /* Input event queue. */ - int qlen; /* Length of input event queue */ - unsigned long last_request_read; /* seq number of last event read */ - unsigned long request; /* sequence number of last request. */ - char *last_req; /* beginning of last request, or dummy */ - char *buffer; /* Output buffer starting address. */ - char *bufptr; /* Output buffer index pointer. */ - char *bufmax; /* Output buffer maximum+1 address. */ - unsigned max_request_size; /* maximum number 32 bit words in request*/ - struct _XrmHashBucketRec *db; - int (*synchandler)( /* Synchronization handler */ - struct _XDisplay* - ); - char *display_name; /* "host:display" string used on this connect*/ - int default_screen; /* default screen for operations */ - int nscreens; /* number of screens on this server*/ - Screen *screens; /* pointer to list of screens */ - unsigned long motion_buffer; /* size of motion buffer */ - volatile unsigned long flags; /* internal connection flags */ - int min_keycode; /* minimum defined keycode */ - int max_keycode; /* maximum defined keycode */ - KeySym *keysyms; /* This server's keysyms */ - XModifierKeymap *modifiermap; /* This server's modifier keymap */ - int keysyms_per_keycode;/* number of rows */ - char *xdefaults; /* contents of defaults from server */ - char *scratch_buffer; /* place to hang scratch buffer */ - unsigned long scratch_length; /* length of scratch buffer */ - int ext_number; /* extension number on this display */ - struct _XExten *ext_procs; /* extensions initialized on this display */ - /* - * the following can be fixed size, as the protocol defines how - * much address space is available. - * While this could be done using the extension vector, there - * may be MANY events processed, so a search through the extension - * list to find the right procedure for each event might be - * expensive if many extensions are being used. - */ - Bool (*event_vec[128])( /* vector for wire to event */ - Display * /* dpy */, - XEvent * /* re */, - xEvent * /* event */ - ); - Status (*wire_vec[128])( /* vector for event to wire */ - Display * /* dpy */, - XEvent * /* re */, - xEvent * /* event */ - ); - KeySym lock_meaning; /* for XLookupString */ - struct _XLockInfo *lock; /* multi-thread state, display lock */ - struct _XInternalAsync *async_handlers; /* for internal async */ - unsigned long bigreq_size; /* max size of big requests */ - struct _XLockPtrs *lock_fns; /* pointers to threads functions */ - void (*idlist_alloc)( /* XID list allocator function */ - Display * /* dpy */, - XID * /* ids */, - int /* count */ - ); - /* things above this line should not move, for binary compatibility */ - struct _XKeytrans *key_bindings; /* for XLookupString */ - Font cursor_font; /* for XCreateFontCursor */ - struct _XDisplayAtoms *atoms; /* for XInternAtom */ - unsigned int mode_switch; /* keyboard group modifiers */ - unsigned int num_lock; /* keyboard numlock modifiers */ - struct _XContextDB *context_db; /* context database */ - Bool (**error_vec)( /* vector for wire to error */ - Display * /* display */, - XErrorEvent * /* he */, - xError * /* we */ - ); - /* - * Xcms information - */ - struct { - XPointer defaultCCCs; /* pointer to an array of default XcmsCCC */ - XPointer clientCmaps; /* pointer to linked list of XcmsCmapRec */ - XPointer perVisualIntensityMaps; - /* linked list of XcmsIntensityMap */ - } cms; - struct _XIMFilter *im_filters; - struct _XSQEvent *qfree; /* unallocated event queue elements */ - unsigned long next_event_serial_num; /* inserted into next queue elt */ - struct _XExten *flushes; /* Flush hooks */ - struct _XConnectionInfo *im_fd_info; /* _XRegisterInternalConnection */ - int im_fd_length; /* number of im_fd_info */ - struct _XConnWatchInfo *conn_watchers; /* XAddConnectionWatch */ - int watcher_count; /* number of conn_watchers */ - XPointer filedes; /* struct pollfd cache for _XWaitForReadable */ - int (*savedsynchandler)( /* user synchandler when Xlib usurps */ - Display * /* dpy */ - ); - XID resource_max; /* allocator max ID */ - int xcmisc_opcode; /* major opcode for XC-MISC */ - struct _XkbInfoRec *xkb_info; /* XKB info */ - struct _XtransConnInfo *trans_conn; /* transport connection object */ - struct _X11XCBPrivate *xcb; /* XCB glue private data */ - - /* Generic event cookie handling */ - unsigned int next_cookie; /* next event cookie */ - /* vector for wire to generic event, index is (extension - 128) */ - Bool (*generic_event_vec[128])( - Display * /* dpy */, - XGenericEventCookie * /* Xlib event */, - xEvent * /* wire event */); - /* vector for event copy, index is (extension - 128) */ - Bool (*generic_event_copy_vec[128])( - Display * /* dpy */, - XGenericEventCookie * /* in */, - XGenericEventCookie * /* out*/); - void *cookiejar; /* cookie events returned but not claimed */ -}; - -#define XAllocIDs(dpy,ids,n) (*(dpy)->idlist_alloc)(dpy,ids,n) - -#ifndef _XEVENT_ -/* - * _QEvent datatype for use in input queueing. - */ -typedef struct _XSQEvent -{ - struct _XSQEvent *next; - XEvent event; - unsigned long qserial_num; /* so multi-threaded code can find new ones */ -} _XQEvent; -#endif - -#include -#ifdef __sgi -#define _SGI_MP_SOURCE /* turn this on to get MP safe errno */ -#endif -#include -#define _XBCOPYFUNC _Xbcopy -#include -#include - -/* Utek leaves kernel macros around in include files (bleah) */ -#ifdef dirty -#undef dirty -#endif - -#include -#include - -#include - -_XFUNCPROTOBEGIN - -/* - * The following definitions can be used for locking requests in multi-threaded - * address spaces. - */ -#ifdef XTHREADS -/* Author: Stephen Gildea, MIT X Consortium - * - * declarations for C Threads locking - */ - -typedef struct _LockInfoRec *LockInfoPtr; - -/* interfaces for locking.c */ -struct _XLockPtrs { - /* used by all, including extensions; do not move */ - void (*lock_display)( - Display *dpy -#if defined(XTHREADS_WARN) || defined(XTHREADS_FILE_LINE) - , char *file - , int line -#endif - ); - void (*unlock_display)( - Display *dpy -#if defined(XTHREADS_WARN) || defined(XTHREADS_FILE_LINE) - , char *file - , int line -#endif - ); -}; - -#if defined(WIN32) && !defined(_XLIBINT_) -#define _XCreateMutex_fn (*_XCreateMutex_fn_p) -#define _XFreeMutex_fn (*_XFreeMutex_fn_p) -#define _XLockMutex_fn (*_XLockMutex_fn_p) -#define _XUnlockMutex_fn (*_XUnlockMutex_fn_p) -#define _Xglobal_lock (*_Xglobal_lock_p) -#endif - -/* in XlibInt.c */ -extern void (*_XCreateMutex_fn)( - LockInfoPtr /* lock */ -); -extern void (*_XFreeMutex_fn)( - LockInfoPtr /* lock */ -); -extern void (*_XLockMutex_fn)( - LockInfoPtr /* lock */ -#if defined(XTHREADS_WARN) || defined(XTHREADS_FILE_LINE) - , char * /* file */ - , int /* line */ -#endif -); -extern void (*_XUnlockMutex_fn)( - LockInfoPtr /* lock */ -#if defined(XTHREADS_WARN) || defined(XTHREADS_FILE_LINE) - , char * /* file */ - , int /* line */ -#endif -); - -extern LockInfoPtr _Xglobal_lock; - -#if defined(XTHREADS_WARN) || defined(XTHREADS_FILE_LINE) -#define LockDisplay(d) if ((d)->lock_fns) (*(d)->lock_fns->lock_display)((d),__FILE__,__LINE__) -#define UnlockDisplay(d) if ((d)->lock_fns) (*(d)->lock_fns->unlock_display)((d),__FILE__,__LINE__) -#define _XLockMutex(lock) if (_XLockMutex_fn) (*_XLockMutex_fn)(lock,__FILE__,__LINE__) -#define _XUnlockMutex(lock) if (_XUnlockMutex_fn) (*_XUnlockMutex_fn)(lock,__FILE__,__LINE__) -#else -/* used everywhere, so must be fast if not using threads */ -#define LockDisplay(d) if ((d)->lock_fns) (*(d)->lock_fns->lock_display)(d) -#define UnlockDisplay(d) if ((d)->lock_fns) (*(d)->lock_fns->unlock_display)(d) -#define _XLockMutex(lock) if (_XLockMutex_fn) (*_XLockMutex_fn)(lock) -#define _XUnlockMutex(lock) if (_XUnlockMutex_fn) (*_XUnlockMutex_fn)(lock) -#endif -#define _XCreateMutex(lock) if (_XCreateMutex_fn) (*_XCreateMutex_fn)(lock); -#define _XFreeMutex(lock) if (_XFreeMutex_fn) (*_XFreeMutex_fn)(lock); - -#else /* XTHREADS */ -#define LockDisplay(dis) -#define _XLockMutex(lock) -#define _XUnlockMutex(lock) -#define UnlockDisplay(dis) -#define _XCreateMutex(lock) -#define _XFreeMutex(lock) -#endif - -#define Xfree(ptr) free((ptr)) - -/* - * Note that some machines do not return a valid pointer for malloc(0), in - * which case we provide an alternate under the control of the - * define MALLOC_0_RETURNS_NULL. This is necessary because some - * Xlib code expects malloc(0) to return a valid pointer to storage. - */ -#if defined(MALLOC_0_RETURNS_NULL) || defined(__clang_analyzer__) - -# define Xmalloc(size) malloc(((size) == 0 ? 1 : (size))) -# define Xrealloc(ptr, size) realloc((ptr), ((size) == 0 ? 1 : (size))) -# define Xcalloc(nelem, elsize) calloc(((nelem) == 0 ? 1 : (nelem)), (elsize)) - -#else - -# define Xmalloc(size) malloc((size)) -# define Xrealloc(ptr, size) realloc((ptr), (size)) -# define Xcalloc(nelem, elsize) calloc((nelem), (elsize)) - -#endif - -#include - -#define LOCKED 1 -#define UNLOCKED 0 - -#ifndef BUFSIZE -#define BUFSIZE 2048 /* X output buffer size. */ -#endif -#ifndef PTSPERBATCH -#define PTSPERBATCH 1024 /* point batching */ -#endif -#ifndef WLNSPERBATCH -#define WLNSPERBATCH 50 /* wide line batching */ -#endif -#ifndef ZLNSPERBATCH -#define ZLNSPERBATCH 1024 /* thin line batching */ -#endif -#ifndef WRCTSPERBATCH -#define WRCTSPERBATCH 10 /* wide line rectangle batching */ -#endif -#ifndef ZRCTSPERBATCH -#define ZRCTSPERBATCH 256 /* thin line rectangle batching */ -#endif -#ifndef FRCTSPERBATCH -#define FRCTSPERBATCH 256 /* filled rectangle batching */ -#endif -#ifndef FARCSPERBATCH -#define FARCSPERBATCH 256 /* filled arc batching */ -#endif -#ifndef CURSORFONT -#define CURSORFONT "cursor" /* standard cursor fonts */ -#endif - -/* - * Display flags - */ -#define XlibDisplayIOError (1L << 0) -#define XlibDisplayClosing (1L << 1) -#define XlibDisplayNoXkb (1L << 2) -#define XlibDisplayPrivSync (1L << 3) -#define XlibDisplayProcConni (1L << 4) /* in _XProcessInternalConnection */ -#define XlibDisplayReadEvents (1L << 5) /* in _XReadEvents */ -#define XlibDisplayReply (1L << 5) /* in _XReply */ -#define XlibDisplayWriting (1L << 6) /* in _XFlushInt, _XSend */ -#define XlibDisplayDfltRMDB (1L << 7) /* mark if RM db from XGetDefault */ - -/* - * X Protocol packetizing macros. - */ - -/* Leftover from CRAY support - was defined empty on all non-Cray systems */ -#define WORD64ALIGN - -/** - * Return a len-sized request buffer for the request type. This function may - * flush the output queue. - * - * @param dpy The display connection - * @param type The request type - * @param len Length of the request in bytes - * - * @returns A pointer to the request buffer with a few default values - * initialized. - */ -extern void *_XGetRequest(Display *dpy, CARD8 type, size_t len); - -/* GetReqSized is the same as GetReq but allows the caller to specify the - * size in bytes. 'sz' must be a multiple of 4! */ - -#define GetReqSized(name, sz, req) \ - req = (x##name##Req *) _XGetRequest(dpy, X_##name, sz) - -/* - * GetReq - Get the next available X request packet in the buffer and - * return it. - * - * "name" is the name of the request, e.g. CreatePixmap, OpenFont, etc. - * "req" is the name of the request pointer. - * - */ - -#define GetReq(name, req) \ - GetReqSized(name, SIZEOF(x##name##Req), req) - -/* GetReqExtra is the same as GetReq, but allocates "n" additional - bytes after the request. "n" must be a multiple of 4! */ - -#define GetReqExtra(name, n, req) \ - GetReqSized(name, SIZEOF(x##name##Req) + n, req) - -/* - * GetResReq is for those requests that have a resource ID - * (Window, Pixmap, GContext, etc.) as their single argument. - * "rid" is the name of the resource. - */ - -#define GetResReq(name, rid, req) \ - req = (xResourceReq *) _XGetRequest(dpy, X_##name, SIZEOF(xResourceReq)); \ - req->id = (rid) - -/* - * GetEmptyReq is for those requests that have no arguments - * at all. - */ - -#define GetEmptyReq(name, req) \ - req = (xReq *) _XGetRequest(dpy, X_##name, SIZEOF(xReq)) - -/* - * MakeBigReq sets the CARD16 "req->length" to 0 and inserts a new CARD32 - * length, after req->length, before the data in the request. The new length - * includes the "n" extra 32-bit words. - * - * Do not use MakeBigReq if there is no data already in the request. - * req->length must already be >= 2. - */ -#ifdef LONG64 -#define MakeBigReq(req,n) \ - { \ - CARD64 _BRdat; \ - CARD32 _BRlen = req->length - 1; \ - req->length = 0; \ - _BRdat = ((CARD32 *)req)[_BRlen]; \ - memmove(((char *)req) + 8, ((char *)req) + 4, (_BRlen - 1) << 2); \ - ((CARD32 *)req)[1] = _BRlen + n + 2; \ - Data32(dpy, &_BRdat, 4); \ - } -#else -#define MakeBigReq(req,n) \ - { \ - CARD32 _BRdat; \ - CARD32 _BRlen = req->length - 1; \ - req->length = 0; \ - _BRdat = ((CARD32 *)req)[_BRlen]; \ - memmove(((char *)req) + 8, ((char *)req) + 4, (_BRlen - 1) << 2); \ - ((CARD32 *)req)[1] = _BRlen + n + 2; \ - Data32(dpy, &_BRdat, 4); \ - } -#endif - -/* - * SetReqLen increases the count of 32-bit words in the request by "n", - * or by "badlen" if "n" is too large. - * - * Do not use SetReqLen if "req" does not already have data after the - * xReq header. req->length must already be >= 2. - */ -#ifndef __clang_analyzer__ -#define SetReqLen(req,n,badlen) \ - if ((req->length + n) > (unsigned)65535) { \ - if (dpy->bigreq_size) { \ - MakeBigReq(req,n) \ - } else { \ - n = badlen; \ - req->length += n; \ - } \ - } else \ - req->length += n -#else -#define SetReqLen(req,n,badlen) \ - req->length += n -#endif - -#define SyncHandle() \ - if (dpy->synchandler) (*dpy->synchandler)(dpy) - -extern void _XFlushGCCache(Display *dpy, GC gc); -#define FlushGC(dpy, gc) \ - if ((gc)->dirty) _XFlushGCCache((dpy), (gc)) -/* - * Data - Place data in the buffer and pad the end to provide - * 32 bit word alignment. Transmit if the buffer fills. - * - * "dpy" is a pointer to a Display. - * "data" is a pointer to a data buffer. - * "len" is the length of the data buffer. - */ -#ifndef DataRoutineIsProcedure -#define Data(dpy, data, len) {\ - if (dpy->bufptr + (len) <= dpy->bufmax) {\ - memcpy(dpy->bufptr, data, (int)len);\ - dpy->bufptr += ((len) + 3) & ~3;\ - } else\ - _XSend(dpy, data, len);\ -} -#endif /* DataRoutineIsProcedure */ - - -/* Allocate bytes from the buffer. No padding is done, so if - * the length is not a multiple of 4, the caller must be - * careful to leave the buffer aligned after sending the - * current request. - * - * "type" is the type of the pointer being assigned to. - * "ptr" is the pointer being assigned to. - * "n" is the number of bytes to allocate. - * - * Example: - * xTextElt *elt; - * BufAlloc (xTextElt *, elt, nbytes) - */ - -#define BufAlloc(type, ptr, n) \ - if (dpy->bufptr + (n) > dpy->bufmax) \ - _XFlush (dpy); \ - ptr = (type) dpy->bufptr; \ - memset(ptr, '\0', n); \ - dpy->bufptr += (n); - -#define Data16(dpy, data, len) Data((dpy), (_Xconst char *)(data), (len)) -#define _XRead16Pad(dpy, data, len) _XReadPad((dpy), (char *)(data), (len)) -#define _XRead16(dpy, data, len) _XRead((dpy), (char *)(data), (len)) -#ifdef LONG64 -#define Data32(dpy, data, len) _XData32(dpy, (_Xconst long *)data, len) -extern int _XData32( - Display *dpy, - register _Xconst long *data, - unsigned len -); -extern void _XRead32( - Display *dpy, - register long *data, - long len -); -#else -#define Data32(dpy, data, len) Data((dpy), (_Xconst char *)(data), (len)) -#define _XRead32(dpy, data, len) _XRead((dpy), (char *)(data), (len)) -#endif - -#define PackData16(dpy,data,len) Data16 (dpy, data, len) -#define PackData32(dpy,data,len) Data32 (dpy, data, len) - -/* Xlib manual is bogus */ -#define PackData(dpy,data,len) PackData16 (dpy, data, len) - -#define min(a,b) (((a) < (b)) ? (a) : (b)) -#define max(a,b) (((a) > (b)) ? (a) : (b)) - -#define CI_NONEXISTCHAR(cs) (((cs)->width == 0) && \ - (((cs)->rbearing|(cs)->lbearing| \ - (cs)->ascent|(cs)->descent) == 0)) - -/* - * CI_GET_CHAR_INFO_1D - return the charinfo struct for the indicated 8bit - * character. If the character is in the column and exists, then return the - * appropriate metrics (note that fonts with common per-character metrics will - * return min_bounds). If none of these hold true, try again with the default - * char. - */ -#define CI_GET_CHAR_INFO_1D(fs,col,def,cs) \ -{ \ - cs = def; \ - if (col >= fs->min_char_or_byte2 && col <= fs->max_char_or_byte2) { \ - if (fs->per_char == NULL) { \ - cs = &fs->min_bounds; \ - } else { \ - cs = &fs->per_char[(col - fs->min_char_or_byte2)]; \ - if (CI_NONEXISTCHAR(cs)) cs = def; \ - } \ - } \ -} - -#define CI_GET_DEFAULT_INFO_1D(fs,cs) \ - CI_GET_CHAR_INFO_1D (fs, fs->default_char, NULL, cs) - - - -/* - * CI_GET_CHAR_INFO_2D - return the charinfo struct for the indicated row and - * column. This is used for fonts that have more than row zero. - */ -#define CI_GET_CHAR_INFO_2D(fs,row,col,def,cs) \ -{ \ - cs = def; \ - if (row >= fs->min_byte1 && row <= fs->max_byte1 && \ - col >= fs->min_char_or_byte2 && col <= fs->max_char_or_byte2) { \ - if (fs->per_char == NULL) { \ - cs = &fs->min_bounds; \ - } else { \ - cs = &fs->per_char[((row - fs->min_byte1) * \ - (fs->max_char_or_byte2 - \ - fs->min_char_or_byte2 + 1)) + \ - (col - fs->min_char_or_byte2)]; \ - if (CI_NONEXISTCHAR(cs)) cs = def; \ - } \ - } \ -} - -#define CI_GET_DEFAULT_INFO_2D(fs,cs) \ -{ \ - unsigned int r = (fs->default_char >> 8); \ - unsigned int c = (fs->default_char & 0xff); \ - CI_GET_CHAR_INFO_2D (fs, r, c, NULL, cs); \ -} - - -/* srcvar must be a variable for large architecture version */ -#define OneDataCard32(dpy,dstaddr,srcvar) \ - { *(CARD32 *)(dstaddr) = (srcvar); } - - -typedef struct _XInternalAsync { - struct _XInternalAsync *next; - /* - * handler arguments: - * rep is the generic reply that caused this handler - * to be invoked. It must also be passed to _XGetAsyncReply. - * buf and len are opaque values that must be passed to - * _XGetAsyncReply or _XGetAsyncData. - * data is the closure stored in this struct. - * The handler returns True iff it handled this reply. - */ - Bool (*handler)( - Display* /* dpy */, - xReply* /* rep */, - char* /* buf */, - int /* len */, - XPointer /* data */ - ); - XPointer data; -} _XAsyncHandler; - -typedef struct _XAsyncEState { - unsigned long min_sequence_number; - unsigned long max_sequence_number; - unsigned char error_code; - unsigned char major_opcode; - unsigned short minor_opcode; - unsigned char last_error_received; - int error_count; -} _XAsyncErrorState; - -extern void _XDeqAsyncHandler(Display *dpy, _XAsyncHandler *handler); -#define DeqAsyncHandler(dpy,handler) { \ - if (dpy->async_handlers == (handler)) \ - dpy->async_handlers = (handler)->next; \ - else \ - _XDeqAsyncHandler(dpy, handler); \ - } - -typedef void (*FreeFuncType) ( - Display* /* display */ -); - -typedef int (*FreeModmapType) ( - XModifierKeymap* /* modmap */ -); - -/* - * This structure is private to the library. - */ -typedef struct _XFreeFuncs { - FreeFuncType atoms; /* _XFreeAtomTable */ - FreeModmapType modifiermap; /* XFreeModifiermap */ - FreeFuncType key_bindings; /* _XFreeKeyBindings */ - FreeFuncType context_db; /* _XFreeContextDB */ - FreeFuncType defaultCCCs; /* _XcmsFreeDefaultCCCs */ - FreeFuncType clientCmaps; /* _XcmsFreeClientCmaps */ - FreeFuncType intensityMaps; /* _XcmsFreeIntensityMaps */ - FreeFuncType im_filters; /* _XFreeIMFilters */ - FreeFuncType xkb; /* _XkbFreeInfo */ -} _XFreeFuncRec; - -/* types for InitExt.c */ -typedef int (*CreateGCType) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - -typedef int (*CopyGCType)( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - -typedef int (*FlushGCType) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - -typedef int (*FreeGCType) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - -typedef int (*CreateFontType) ( - Display* /* display */, - XFontStruct* /* fs */, - XExtCodes* /* codes */ -); - -typedef int (*FreeFontType) ( - Display* /* display */, - XFontStruct* /* fs */, - XExtCodes* /* codes */ -); - -typedef int (*CloseDisplayType) ( - Display* /* display */, - XExtCodes* /* codes */ -); - -typedef int (*ErrorType) ( - Display* /* display */, - xError* /* err */, - XExtCodes* /* codes */, - int* /* ret_code */ -); - -typedef char* (*ErrorStringType) ( - Display* /* display */, - int /* code */, - XExtCodes* /* codes */, - char* /* buffer */, - int /* nbytes */ -); - -typedef void (*PrintErrorType)( - Display* /* display */, - XErrorEvent* /* ev */, - void* /* fp */ -); - -typedef void (*BeforeFlushType)( - Display* /* display */, - XExtCodes* /* codes */, - _Xconst char* /* data */, - long /* len */ -); - -/* - * This structure is private to the library. - */ -typedef struct _XExten { /* private to extension mechanism */ - struct _XExten *next; /* next in list */ - XExtCodes codes; /* public information, all extension told */ - CreateGCType create_GC; /* routine to call when GC created */ - CopyGCType copy_GC; /* routine to call when GC copied */ - FlushGCType flush_GC; /* routine to call when GC flushed */ - FreeGCType free_GC; /* routine to call when GC freed */ - CreateFontType create_Font; /* routine to call when Font created */ - FreeFontType free_Font; /* routine to call when Font freed */ - CloseDisplayType close_display; /* routine to call when connection closed */ - ErrorType error; /* who to call when an error occurs */ - ErrorStringType error_string; /* routine to supply error string */ - char *name; /* name of this extension */ - PrintErrorType error_values; /* routine to supply error values */ - BeforeFlushType before_flush; /* routine to call when sending data */ - struct _XExten *next_flush; /* next in list of those with flushes */ -} _XExtension; - -/* Temporary definition until we can depend on an xproto release with it */ -#ifdef _X_COLD -# define _XLIB_COLD _X_COLD -#elif defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 403) /* 4.3+ */ -# define _XLIB_COLD __attribute__((__cold__)) -#else -# define _XLIB_COLD /* nothing */ -#endif - -/* extension hooks */ - -#ifdef DataRoutineIsProcedure -extern void Data(Display *dpy, char *data, long len); -#endif -extern int _XError( - Display* /* dpy */, - xError* /* rep */ -); -extern int _XIOError( - Display* /* dpy */ -) _X_NORETURN; -extern int (*_XIOErrorFunction)( - Display* /* dpy */ -); -extern int (*_XErrorFunction)( - Display* /* dpy */, - XErrorEvent* /* error_event */ -); -extern void _XEatData( - Display* /* dpy */, - unsigned long /* n */ -) _XLIB_COLD; -extern void _XEatDataWords( - Display* /* dpy */, - unsigned long /* n */ -) _XLIB_COLD; -#if defined(__SUNPRO_C) /* Studio compiler alternative to "cold" attribute */ -# pragma rarely_called(_XEatData, _XEatDataWords) -#endif -extern char *_XAllocScratch( - Display* /* dpy */, - unsigned long /* nbytes */ -); -extern char *_XAllocTemp( - Display* /* dpy */, - unsigned long /* nbytes */ -); -extern void _XFreeTemp( - Display* /* dpy */, - char* /* buf */, - unsigned long /* nbytes */ -); -extern Visual *_XVIDtoVisual( - Display* /* dpy */, - VisualID /* id */ -); -extern unsigned long _XSetLastRequestRead( - Display* /* dpy */, - xGenericReply* /* rep */ -); -extern int _XGetHostname( - char* /* buf */, - int /* maxlen */ -); -extern Screen *_XScreenOfWindow( - Display* /* dpy */, - Window /* w */ -); -extern Bool _XAsyncErrorHandler( - Display* /* dpy */, - xReply* /* rep */, - char* /* buf */, - int /* len */, - XPointer /* data */ -); -extern char *_XGetAsyncReply( - Display* /* dpy */, - char* /* replbuf */, - xReply* /* rep */, - char* /* buf */, - int /* len */, - int /* extra */, - Bool /* discard */ -); -extern void _XGetAsyncData( - Display* /* dpy */, - char * /* data */, - char * /* buf */, - int /* len */, - int /* skip */, - int /* datalen */, - int /* discardtotal */ -); -extern void _XFlush( - Display* /* dpy */ -); -extern int _XEventsQueued( - Display* /* dpy */, - int /* mode */ -); -extern void _XReadEvents( - Display* /* dpy */ -); -extern int _XRead( - Display* /* dpy */, - char* /* data */, - long /* size */ -); -extern void _XReadPad( - Display* /* dpy */, - char* /* data */, - long /* size */ -); -extern void _XSend( - Display* /* dpy */, - _Xconst char* /* data */, - long /* size */ -); -extern Status _XReply( - Display* /* dpy */, - xReply* /* rep */, - int /* extra */, - Bool /* discard */ -); -extern void _XEnq( - Display* /* dpy */, - xEvent* /* event */ -); -extern void _XDeq( - Display* /* dpy */, - _XQEvent* /* prev */, - _XQEvent* /* qelt */ -); - -extern Bool _XUnknownWireEvent( - Display* /* dpy */, - XEvent* /* re */, - xEvent* /* event */ -); - -extern Bool _XUnknownWireEventCookie( - Display* /* dpy */, - XGenericEventCookie* /* re */, - xEvent* /* event */ -); - -extern Bool _XUnknownCopyEventCookie( - Display* /* dpy */, - XGenericEventCookie* /* in */, - XGenericEventCookie* /* out */ -); - -extern Status _XUnknownNativeEvent( - Display* /* dpy */, - XEvent* /* re */, - xEvent* /* event */ -); - -extern Bool _XWireToEvent(Display *dpy, XEvent *re, xEvent *event); -extern Bool _XDefaultWireError(Display *display, XErrorEvent *he, xError *we); -extern Bool _XPollfdCacheInit(Display *dpy); -extern void _XPollfdCacheAdd(Display *dpy, int fd); -extern void _XPollfdCacheDel(Display *dpy, int fd); -extern XID _XAllocID(Display *dpy); -extern void _XAllocIDs(Display *dpy, XID *ids, int count); - -extern int _XFreeExtData( - XExtData* /* extension */ -); - -extern int (*XESetCreateGC( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, GC, XExtCodes* -); - -extern int (*XESetCopyGC( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, GC, XExtCodes* -); - -extern int (*XESetFlushGC( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, GC, XExtCodes* -); - -extern int (*XESetFreeGC( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, GC, XExtCodes* -); - -extern int (*XESetCreateFont( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - XFontStruct* /* fs */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, XFontStruct*, XExtCodes* -); - -extern int (*XESetFreeFont( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - XFontStruct* /* fs */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, XFontStruct*, XExtCodes* -); - -extern int (*XESetCloseDisplay( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - XExtCodes* /* codes */ - ) /* proc */ -))( - Display*, XExtCodes* -); - -extern int (*XESetError( - Display* /* display */, - int /* extension */, - int (*) ( - Display* /* display */, - xError* /* err */, - XExtCodes* /* codes */, - int* /* ret_code */ - ) /* proc */ -))( - Display*, xError*, XExtCodes*, int* -); - -extern char* (*XESetErrorString( - Display* /* display */, - int /* extension */, - char* (*) ( - Display* /* display */, - int /* code */, - XExtCodes* /* codes */, - char* /* buffer */, - int /* nbytes */ - ) /* proc */ -))( - Display*, int, XExtCodes*, char*, int -); - -extern void (*XESetPrintErrorValues ( - Display* /* display */, - int /* extension */, - void (*)( - Display* /* display */, - XErrorEvent* /* ev */, - void* /* fp */ - ) /* proc */ -))( - Display*, XErrorEvent*, void* -); - -extern Bool (*XESetWireToEvent( - Display* /* display */, - int /* event_number */, - Bool (*) ( - Display* /* display */, - XEvent* /* re */, - xEvent* /* event */ - ) /* proc */ -))( - Display*, XEvent*, xEvent* -); - -extern Bool (*XESetWireToEventCookie( - Display* /* display */, - int /* extension */, - Bool (*) ( - Display* /* display */, - XGenericEventCookie* /* re */, - xEvent* /* event */ - ) /* proc */ -))( - Display*, XGenericEventCookie*, xEvent* -); - -extern Bool (*XESetCopyEventCookie( - Display* /* display */, - int /* extension */, - Bool (*) ( - Display* /* display */, - XGenericEventCookie* /* in */, - XGenericEventCookie* /* out */ - ) /* proc */ -))( - Display*, XGenericEventCookie*, XGenericEventCookie* -); - - -extern Status (*XESetEventToWire( - Display* /* display */, - int /* event_number */, - Status (*) ( - Display* /* display */, - XEvent* /* re */, - xEvent* /* event */ - ) /* proc */ -))( - Display*, XEvent*, xEvent* -); - -extern Bool (*XESetWireToError( - Display* /* display */, - int /* error_number */, - Bool (*) ( - Display* /* display */, - XErrorEvent* /* he */, - xError* /* we */ - ) /* proc */ -))( - Display*, XErrorEvent*, xError* -); - -extern void (*XESetBeforeFlush( - Display* /* display */, - int /* error_number */, - void (*) ( - Display* /* display */, - XExtCodes* /* codes */, - _Xconst char* /* data */, - long /* len */ - ) /* proc */ -))( - Display*, XExtCodes*, _Xconst char*, long -); - -/* internal connections for IMs */ - -typedef void (*_XInternalConnectionProc)( - Display* /* dpy */, - int /* fd */, - XPointer /* call_data */ -); - - -extern Status _XRegisterInternalConnection( - Display* /* dpy */, - int /* fd */, - _XInternalConnectionProc /* callback */, - XPointer /* call_data */ -); - -extern void _XUnregisterInternalConnection( - Display* /* dpy */, - int /* fd */ -); - -extern void _XProcessInternalConnection( - Display* /* dpy */, - struct _XConnectionInfo* /* conn_info */ -); - -/* Display structure has pointers to these */ - -struct _XConnectionInfo { /* info from _XRegisterInternalConnection */ - int fd; - _XInternalConnectionProc read_callback; - XPointer call_data; - XPointer *watch_data; /* set/used by XConnectionWatchProc */ - struct _XConnectionInfo *next; -}; - -struct _XConnWatchInfo { /* info from XAddConnectionWatch */ - XConnectionWatchProc fn; - XPointer client_data; - struct _XConnWatchInfo *next; -}; - -#ifdef __UNIXOS2__ -extern char* __XOS2RedirRoot( - char* -); -#endif - -extern int _XTextHeight( - XFontStruct* /* font_struct */, - _Xconst char* /* string */, - int /* count */ -); - -extern int _XTextHeight16( - XFontStruct* /* font_struct */, - _Xconst XChar2b* /* string */, - int /* count */ -); - -#if defined(WIN32) - -extern int _XOpenFile( - _Xconst char* /* path */, - int /* flags */ -); - -extern int _XOpenFileMode( - _Xconst char* /* path */, - int /* flags */, - mode_t /* mode */ -); - -extern void* _XFopenFile( - _Xconst char* /* path */, - _Xconst char* /* mode */ -); - -extern int _XAccessFile( - _Xconst char* /* path */ -); -#else -#define _XOpenFile(path,flags) open(path,flags) -#define _XOpenFileMode(path,flags,mode) open(path,flags,mode) -#define _XFopenFile(path,mode) fopen(path,mode) -#endif - -/* EvToWire.c */ -extern Status _XEventToWire(Display *dpy, XEvent *re, xEvent *event); - -extern int _XF86LoadQueryLocaleFont( - Display* /* dpy */, - _Xconst char* /* name*/, - XFontStruct** /* xfp*/, - Font* /* fidp */ -); - -extern void _XProcessWindowAttributes ( - register Display *dpy, - xChangeWindowAttributesReq *req, - register unsigned long valuemask, - register XSetWindowAttributes *attributes); - -extern int _XDefaultError( - Display *dpy, - XErrorEvent *event); - -extern int _XDefaultIOError( - Display *dpy); - -extern void _XSetClipRectangles ( - register Display *dpy, - GC gc, - int clip_x_origin, int clip_y_origin, - XRectangle *rectangles, - int n, - int ordering); - -Status _XGetWindowAttributes( - register Display *dpy, - Window w, - XWindowAttributes *attr); - -int _XPutBackEvent ( - register Display *dpy, - register XEvent *event); - -extern Bool _XIsEventCookie( - Display *dpy, - XEvent *ev); - -extern void _XFreeEventCookies( - Display *dpy); - -extern void _XStoreEventCookie( - Display *dpy, - XEvent *ev); - -extern Bool _XFetchEventCookie( - Display *dpy, - XGenericEventCookie *ev); - -extern Bool _XCopyEventCookie( - Display *dpy, - XGenericEventCookie *in, - XGenericEventCookie *out); - -/* lcFile.c */ - -extern void xlocaledir( - char *buf, - int buf_len -); - -#ifdef __clang__ -#pragma clang diagnostic pop -#endif - -_XFUNCPROTOEND - -#endif /* _X11_XLIBINT_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xmd.h b/btgui/OpenGLWindow/optionalX11/X11/Xmd.h deleted file mode 100644 index 96cc08ffd..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xmd.h +++ /dev/null @@ -1,187 +0,0 @@ -/*********************************************************** - -Copyright 1987, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - - -Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, -provided that the above copyright notice appear in all copies and that -both that copyright notice and this permission notice appear in -supporting documentation, and that the name of Digital not be -used in advertising or publicity pertaining to distribution of the -software without specific, written prior permission. - -DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING -ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL -DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR -ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, -WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, -ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS -SOFTWARE. - -******************************************************************/ -#ifndef XMD_H -# define XMD_H 1 -/* - * Xmd.h: MACHINE DEPENDENT DECLARATIONS. - */ - -/* - * Special per-machine configuration flags. - */ -# if defined(__sun) && defined(__SVR4) -# include /* Solaris: defines _LP64 if necessary */ -# endif - -# if defined (_LP64) || defined(__LP64__) || \ - defined(__alpha) || defined(__alpha__) || \ - defined(__ia64__) || defined(ia64) || \ - defined(__sparc64__) || \ - defined(__s390x__) || \ - defined(__amd64__) || defined(amd64) || \ - defined(__powerpc64__) -# if !defined(__ILP32__) /* amd64-x32 is 32bit */ -# define LONG64 /* 32/64-bit architecture */ -# endif /* !__ILP32__ */ -# endif - -/* - * Stuff to handle large architecture machines; the constants were generated - * on a 32-bit machine and must correspond to the protocol. - */ -# ifdef WORD64 -# define MUSTCOPY -# endif /* WORD64 */ - - -/* - * Definition of macro used to set constants for size of network structures; - * machines with preprocessors that can't handle all of the sz_ symbols - * can define this macro to be sizeof(x) if and only if their compiler doesn't - * pad out structures (esp. the xTextElt structure which contains only two - * one-byte fields). Network structures should always define sz_symbols. - * - * The sz_ prefix is used instead of something more descriptive so that the - * symbols are no more than 32 characters long (which causes problems for some - * compilers and preprocessors). - * - * The extra indirection is to get macro arguments to expand correctly before - * the concatenation, rather than afterward. - */ -# define _SIZEOF(x) sz_##x -# define SIZEOF(x) _SIZEOF(x) - -/* - * Bitfield suffixes for the protocol structure elements, if you - * need them. Note that bitfields are not guaranteed to be signed - * (or even unsigned) according to ANSI C. - */ -# ifdef WORD64 -typedef long INT64; -typedef unsigned long CARD64; -# define B32 :32 -# define B16 :16 -# ifdef UNSIGNEDBITFIELDS -typedef unsigned int INT32; -typedef unsigned int INT16; -# else -typedef signed int INT32; -typedef signed int INT16; -# endif -# else -# define B32 -# define B16 -# ifdef LONG64 -typedef long INT64; -typedef int INT32; -# else -typedef long INT32; -# endif -typedef short INT16; -# endif - -typedef signed char INT8; - -# ifdef LONG64 -typedef unsigned long CARD64; -typedef unsigned int CARD32; -# else -typedef unsigned long CARD32; -# endif -# if !defined(WORD64) && !defined(LONG64) -typedef unsigned long long CARD64; -# endif -typedef unsigned short CARD16; -typedef unsigned char CARD8; - -typedef CARD32 BITS32; -typedef CARD16 BITS16; - -typedef CARD8 BYTE; -typedef CARD8 BOOL; - -/* - * definitions for sign-extending bitfields on 64-bit architectures - */ -# if defined(WORD64) && defined(UNSIGNEDBITFIELDS) -# define cvtINT8toInt(val) (((val) & 0x00000080) ? ((val) | 0xffffffffffffff00) : (val)) -# define cvtINT16toInt(val) (((val) & 0x00008000) ? ((val) | 0xffffffffffff0000) : (val)) -# define cvtINT32toInt(val) (((val) & 0x80000000) ? ((val) | 0xffffffff00000000) : (val)) -# define cvtINT8toShort(val) cvtINT8toInt(val) -# define cvtINT16toShort(val) cvtINT16toInt(val) -# define cvtINT32toShort(val) cvtINT32toInt(val) -# define cvtINT8toLong(val) cvtINT8toInt(val) -# define cvtINT16toLong(val) cvtINT16toInt(val) -# define cvtINT32toLong(val) cvtINT32toInt(val) -# else -# define cvtINT8toInt(val) (val) -# define cvtINT16toInt(val) (val) -# define cvtINT32toInt(val) (val) -# define cvtINT8toShort(val) (val) -# define cvtINT16toShort(val) (val) -# define cvtINT32toShort(val) (val) -# define cvtINT8toLong(val) (val) -# define cvtINT16toLong(val) (val) -# define cvtINT32toLong(val) (val) -# endif /* WORD64 and UNSIGNEDBITFIELDS */ - - - -# ifdef MUSTCOPY -/* - * This macro must not cast or else pointers will get aligned and be wrong - */ -# define NEXTPTR(p,t) (((char *) p) + SIZEOF(t)) -# else /* else not MUSTCOPY, this is used for 32-bit machines */ -/* - * this version should leave result of type (t *), but that should only be - * used when not in MUSTCOPY - */ -# define NEXTPTR(p,t) (((t *)(p)) + 1) -# endif /* MUSTCOPY - used machines whose C structs don't line up with proto */ - -#endif /* XMD_H */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xosdefs.h b/btgui/OpenGLWindow/optionalX11/X11/Xosdefs.h deleted file mode 100644 index 33eaee436..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xosdefs.h +++ /dev/null @@ -1,116 +0,0 @@ -/* - * O/S-dependent (mis)feature macro definitions - * -Copyright 1991, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - */ - -#ifndef _XOSDEFS_H_ -# define _XOSDEFS_H_ - -/* - * X_NOT_POSIX means does not have POSIX header files. Lack of this - * symbol does NOT mean that the POSIX environment is the default. - * You may still have to define _POSIX_SOURCE to get it. - */ - - -# ifdef _SCO_DS -# ifndef __SCO__ -# define __SCO__ -# endif -# endif - -# ifdef __i386__ -# ifdef SYSV -# if !defined(__SCO__) && \ - !defined(__UNIXWARE__) && !defined(__sun) -# if !defined(_POSIX_SOURCE) -# define X_NOT_POSIX -# endif -# endif -# endif -# endif - -# ifdef __sun -/* Imake configs define SVR4 on Solaris, but cc & gcc only define __SVR4 - * This check allows non-Imake configured programs to build correctly. - */ -# if defined(__SVR4) && !defined(SVR4) -# define SVR4 1 -# endif -# ifdef SVR4 -/* define this to whatever it needs to be */ -# define X_POSIX_C_SOURCE 199300L -# endif -# endif - -# ifdef WIN32 -# ifndef _POSIX_ -# define X_NOT_POSIX -# endif -# endif - - -# ifdef __APPLE__ -# define NULL_NOT_ZERO - -/* Defining any of these will sanitize the namespace to JUST want is defined by - * that particular standard. If that happens, we don't get some expected - * prototypes, typedefs, etc (like fd_mask). We can define _DARWIN_C_SOURCE to - * loosen our belts a tad. - */ -# if defined(_XOPEN_SOURCE) || defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) -# ifndef _DARWIN_C_SOURCE -# define _DARWIN_C_SOURCE -# endif -# endif - -# endif - -# ifdef __GNU__ -# ifndef PATH_MAX -# define PATH_MAX 4096 -# endif -# ifndef MAXPATHLEN -# define MAXPATHLEN 4096 -# endif -# endif - -# if defined(__SCO__) || defined(__UNIXWARE__) -# ifndef PATH_MAX -# define PATH_MAX 1024 -# endif -# ifndef MAXPATHLEN -# define MAXPATHLEN 1024 -# endif -# endif - -# if defined(__OpenBSD__) || defined(__NetBSD__) || defined(__FreeBSD__) \ - || defined(__APPLE__) || defined(__DragonFly__) -# ifndef CSRG_BASED -# define CSRG_BASED -# endif -# endif - -#endif /* _XOSDEFS_H_ */ - diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xproto.h b/btgui/OpenGLWindow/optionalX11/X11/Xproto.h deleted file mode 100644 index 495d44194..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xproto.h +++ /dev/null @@ -1,2157 +0,0 @@ -/* Definitions for the X window system used by server and c bindings */ - -/* - * This packet-construction scheme makes the following assumptions: - * - * 1. The compiler is able - * to generate code which addresses one- and two-byte quantities. - * In the worst case, this would be done with bit-fields. If bit-fields - * are used it may be necessary to reorder the request fields in this file, - * depending on the order in which the machine assigns bit fields to - * machine words. There may also be a problem with sign extension, - * as K+R specify that bitfields are always unsigned. - * - * 2. 2- and 4-byte fields in packet structures must be ordered by hand - * such that they are naturally-aligned, so that no compiler will ever - * insert padding bytes. - * - * 3. All packets are hand-padded to a multiple of 4 bytes, for - * the same reason. - */ - -#ifndef XPROTO_H -#define XPROTO_H - -/*********************************************************** - -Copyright 1987, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - - -Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, -provided that the above copyright notice appear in all copies and that -both that copyright notice and this permission notice appear in -supporting documentation, and that the name of Digital not be -used in advertising or publicity pertaining to distribution of the -software without specific, written prior permission. - -DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING -ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL -DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR -ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, -WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, -ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS -SOFTWARE. - -******************************************************************/ - -#include -#include - -/* - * Define constants for the sizes of the network packets. The sz_ prefix is - * used instead of something more descriptive so that the symbols are no more - * than 32 characters in length (which causes problems for some compilers). - */ -#define sz_xSegment 8 -#define sz_xPoint 4 -#define sz_xRectangle 8 -#define sz_xArc 12 -#define sz_xConnClientPrefix 12 -#define sz_xConnSetupPrefix 8 -#define sz_xConnSetup 32 -#define sz_xPixmapFormat 8 -#define sz_xDepth 8 -#define sz_xVisualType 24 -#define sz_xWindowRoot 40 -#define sz_xTimecoord 8 -#define sz_xHostEntry 4 -#define sz_xCharInfo 12 -#define sz_xFontProp 8 -#define sz_xTextElt 2 -#define sz_xColorItem 12 -#define sz_xrgb 8 -#define sz_xGenericReply 32 -#define sz_xGetWindowAttributesReply 44 -#define sz_xGetGeometryReply 32 -#define sz_xQueryTreeReply 32 -#define sz_xInternAtomReply 32 -#define sz_xGetAtomNameReply 32 -#define sz_xGetPropertyReply 32 -#define sz_xListPropertiesReply 32 -#define sz_xGetSelectionOwnerReply 32 -#define sz_xGrabPointerReply 32 -#define sz_xQueryPointerReply 32 -#define sz_xGetMotionEventsReply 32 -#define sz_xTranslateCoordsReply 32 -#define sz_xGetInputFocusReply 32 -#define sz_xQueryKeymapReply 40 -#define sz_xQueryFontReply 60 -#define sz_xQueryTextExtentsReply 32 -#define sz_xListFontsReply 32 -#define sz_xGetFontPathReply 32 -#define sz_xGetImageReply 32 -#define sz_xListInstalledColormapsReply 32 -#define sz_xAllocColorReply 32 -#define sz_xAllocNamedColorReply 32 -#define sz_xAllocColorCellsReply 32 -#define sz_xAllocColorPlanesReply 32 -#define sz_xQueryColorsReply 32 -#define sz_xLookupColorReply 32 -#define sz_xQueryBestSizeReply 32 -#define sz_xQueryExtensionReply 32 -#define sz_xListExtensionsReply 32 -#define sz_xSetMappingReply 32 -#define sz_xGetKeyboardControlReply 52 -#define sz_xGetPointerControlReply 32 -#define sz_xGetScreenSaverReply 32 -#define sz_xListHostsReply 32 -#define sz_xSetModifierMappingReply 32 -#define sz_xError 32 -#define sz_xEvent 32 -#define sz_xKeymapEvent 32 -#define sz_xReq 4 -#define sz_xResourceReq 8 -#define sz_xCreateWindowReq 32 -#define sz_xChangeWindowAttributesReq 12 -#define sz_xChangeSaveSetReq 8 -#define sz_xReparentWindowReq 16 -#define sz_xConfigureWindowReq 12 -#define sz_xCirculateWindowReq 8 -#define sz_xInternAtomReq 8 -#define sz_xChangePropertyReq 24 -#define sz_xDeletePropertyReq 12 -#define sz_xGetPropertyReq 24 -#define sz_xSetSelectionOwnerReq 16 -#define sz_xConvertSelectionReq 24 -#define sz_xSendEventReq 44 -#define sz_xGrabPointerReq 24 -#define sz_xGrabButtonReq 24 -#define sz_xUngrabButtonReq 12 -#define sz_xChangeActivePointerGrabReq 16 -#define sz_xGrabKeyboardReq 16 -#define sz_xGrabKeyReq 16 -#define sz_xUngrabKeyReq 12 -#define sz_xAllowEventsReq 8 -#define sz_xGetMotionEventsReq 16 -#define sz_xTranslateCoordsReq 16 -#define sz_xWarpPointerReq 24 -#define sz_xSetInputFocusReq 12 -#define sz_xOpenFontReq 12 -#define sz_xQueryTextExtentsReq 8 -#define sz_xListFontsReq 8 -#define sz_xSetFontPathReq 8 -#define sz_xCreatePixmapReq 16 -#define sz_xCreateGCReq 16 -#define sz_xChangeGCReq 12 -#define sz_xCopyGCReq 16 -#define sz_xSetDashesReq 12 -#define sz_xSetClipRectanglesReq 12 -#define sz_xCopyAreaReq 28 -#define sz_xCopyPlaneReq 32 -#define sz_xPolyPointReq 12 -#define sz_xPolySegmentReq 12 -#define sz_xFillPolyReq 16 -#define sz_xPutImageReq 24 -#define sz_xGetImageReq 20 -#define sz_xPolyTextReq 16 -#define sz_xImageTextReq 16 -#define sz_xCreateColormapReq 16 -#define sz_xCopyColormapAndFreeReq 12 -#define sz_xAllocColorReq 16 -#define sz_xAllocNamedColorReq 12 -#define sz_xAllocColorCellsReq 12 -#define sz_xAllocColorPlanesReq 16 -#define sz_xFreeColorsReq 12 -#define sz_xStoreColorsReq 8 -#define sz_xStoreNamedColorReq 16 -#define sz_xQueryColorsReq 8 -#define sz_xLookupColorReq 12 -#define sz_xCreateCursorReq 32 -#define sz_xCreateGlyphCursorReq 32 -#define sz_xRecolorCursorReq 20 -#define sz_xQueryBestSizeReq 12 -#define sz_xQueryExtensionReq 8 -#define sz_xChangeKeyboardControlReq 8 -#define sz_xBellReq 4 -#define sz_xChangePointerControlReq 12 -#define sz_xSetScreenSaverReq 12 -#define sz_xChangeHostsReq 8 -#define sz_xListHostsReq 4 -#define sz_xChangeModeReq 4 -#define sz_xRotatePropertiesReq 12 -#define sz_xReply 32 -#define sz_xGrabKeyboardReply 32 -#define sz_xListFontsWithInfoReply 60 -#define sz_xSetPointerMappingReply 32 -#define sz_xGetKeyboardMappingReply 32 -#define sz_xGetPointerMappingReply 32 -#define sz_xGetModifierMappingReply 32 -#define sz_xListFontsWithInfoReq 8 -#define sz_xPolyLineReq 12 -#define sz_xPolyArcReq 12 -#define sz_xPolyRectangleReq 12 -#define sz_xPolyFillRectangleReq 12 -#define sz_xPolyFillArcReq 12 -#define sz_xPolyText8Req 16 -#define sz_xPolyText16Req 16 -#define sz_xImageText8Req 16 -#define sz_xImageText16Req 16 -#define sz_xSetPointerMappingReq 4 -#define sz_xForceScreenSaverReq 4 -#define sz_xSetCloseDownModeReq 4 -#define sz_xClearAreaReq 16 -#define sz_xSetAccessControlReq 4 -#define sz_xGetKeyboardMappingReq 8 -#define sz_xSetModifierMappingReq 4 -#define sz_xPropIconSize 24 -#define sz_xChangeKeyboardMappingReq 8 - - -/* For the purpose of the structure definitions in this file, -we must redefine the following types in terms of Xmd.h's types, which may -include bit fields. All of these are #undef'd at the end of this file, -restoring the definitions in X.h. */ - -#define Window CARD32 -#define Drawable CARD32 -#define Font CARD32 -#define Pixmap CARD32 -#define Cursor CARD32 -#define Colormap CARD32 -#define GContext CARD32 -#define Atom CARD32 -#define VisualID CARD32 -#define Time CARD32 -#define KeyCode CARD8 -#define KeySym CARD32 - -#define X_TCP_PORT 6000 /* add display number */ - -#define xTrue 1 -#define xFalse 0 - - -typedef CARD16 KeyButMask; - -/***************** - connection setup structure. This is followed by - numRoots xWindowRoot structs. -*****************/ - -typedef struct { - CARD8 byteOrder; - BYTE pad; - CARD16 majorVersion B16, minorVersion B16; - CARD16 nbytesAuthProto B16; /* Authorization protocol */ - CARD16 nbytesAuthString B16; /* Authorization string */ - CARD16 pad2 B16; -} xConnClientPrefix; - -typedef struct { - CARD8 success; - BYTE lengthReason; /*num bytes in string following if failure */ - CARD16 majorVersion B16, - minorVersion B16; - CARD16 length B16; /* 1/4 additional bytes in setup info */ -} xConnSetupPrefix; - - -typedef struct { - CARD32 release B32; - CARD32 ridBase B32, - ridMask B32; - CARD32 motionBufferSize B32; - CARD16 nbytesVendor B16; /* number of bytes in vendor string */ - CARD16 maxRequestSize B16; - CARD8 numRoots; /* number of roots structs to follow */ - CARD8 numFormats; /* number of pixmap formats */ - CARD8 imageByteOrder; /* LSBFirst, MSBFirst */ - CARD8 bitmapBitOrder; /* LeastSignificant, MostSign...*/ - CARD8 bitmapScanlineUnit, /* 8, 16, 32 */ - bitmapScanlinePad; /* 8, 16, 32 */ - KeyCode minKeyCode, maxKeyCode; - CARD32 pad2 B32; -} xConnSetup; - -typedef struct { - CARD8 depth; - CARD8 bitsPerPixel; - CARD8 scanLinePad; - CARD8 pad1; - CARD32 pad2 B32; -} xPixmapFormat; - -/* window root */ - -typedef struct { - CARD8 depth; - CARD8 pad1; - CARD16 nVisuals B16; /* number of xVisualType structures following */ - CARD32 pad2 B32; - } xDepth; - -typedef struct { - VisualID visualID B32; -#if defined(__cplusplus) || defined(c_plusplus) - CARD8 c_class; -#else - CARD8 class; -#endif - CARD8 bitsPerRGB; - CARD16 colormapEntries B16; - CARD32 redMask B32, greenMask B32, blueMask B32; - CARD32 pad B32; - } xVisualType; - -typedef struct { - Window windowId B32; - Colormap defaultColormap B32; - CARD32 whitePixel B32, blackPixel B32; - CARD32 currentInputMask B32; - CARD16 pixWidth B16, pixHeight B16; - CARD16 mmWidth B16, mmHeight B16; - CARD16 minInstalledMaps B16, maxInstalledMaps B16; - VisualID rootVisualID B32; - CARD8 backingStore; - BOOL saveUnders; - CARD8 rootDepth; - CARD8 nDepths; /* number of xDepth structures following */ -} xWindowRoot; - - -/***************************************************************** - * Structure Defns - * Structures needed for replies - *****************************************************************/ - -/* Used in GetMotionEvents */ - -typedef struct { - CARD32 time B32; - INT16 x B16, y B16; -} xTimecoord; - -typedef struct { - CARD8 family; - BYTE pad; - CARD16 length B16; -} xHostEntry; - -typedef struct { - INT16 leftSideBearing B16, - rightSideBearing B16, - characterWidth B16, - ascent B16, - descent B16; - CARD16 attributes B16; -} xCharInfo; - -typedef struct { - Atom name B32; - CARD32 value B32; -} xFontProp; - -/* - * non-aligned big-endian font ID follows this struct - */ -typedef struct { /* followed by string */ - CARD8 len; /* number of *characters* in string, or FontChange (255) - for font change, or 0 if just delta given */ - INT8 delta; -} xTextElt; - - -typedef struct { - CARD32 pixel B32; - CARD16 red B16, green B16, blue B16; - CARD8 flags; /* DoRed, DoGreen, DoBlue booleans */ - CARD8 pad; -} xColorItem; - - -typedef struct { - CARD16 red B16, green B16, blue B16, pad B16; -} xrgb; - -typedef CARD8 KEYCODE; - - -/***************** - * XRep: - * meant to be 32 byte quantity - *****************/ - -/* GenericReply is the common format of all replies. The "data" items - are specific to each individual reply type. */ - -typedef struct { - BYTE type; /* X_Reply */ - BYTE data1; /* depends on reply type */ - CARD16 sequenceNumber B16; /* of last request received by server */ - CARD32 length B32; /* 4 byte quantities beyond size of GenericReply */ - CARD32 data00 B32; - CARD32 data01 B32; - CARD32 data02 B32; - CARD32 data03 B32; - CARD32 data04 B32; - CARD32 data05 B32; - } xGenericReply; - -/* Individual reply formats. */ - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 backingStore; - CARD16 sequenceNumber B16; - CARD32 length B32; /* NOT 0; this is an extra-large reply */ - VisualID visualID B32; -#if defined(__cplusplus) || defined(c_plusplus) - CARD16 c_class B16; -#else - CARD16 class B16; -#endif - CARD8 bitGravity; - CARD8 winGravity; - CARD32 backingBitPlanes B32; - CARD32 backingPixel B32; - BOOL saveUnder; - BOOL mapInstalled; - CARD8 mapState; - BOOL override; - Colormap colormap B32; - CARD32 allEventMasks B32; - CARD32 yourEventMask B32; - CARD16 doNotPropagateMask B16; - CARD16 pad B16; - } xGetWindowAttributesReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 depth; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - Window root B32; - INT16 x B16, y B16; - CARD16 width B16, height B16; - CARD16 borderWidth B16; - CARD16 pad1 B16; - CARD32 pad2 B32; - CARD32 pad3 B32; - } xGetGeometryReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - Window root B32, parent B32; - CARD16 nChildren B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - } xQueryTreeReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - Atom atom B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - } xInternAtomReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* of additional bytes */ - CARD16 nameLength B16; /* # of characters in name */ - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xGetAtomNameReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 format; - CARD16 sequenceNumber B16; - CARD32 length B32; /* of additional bytes */ - Atom propertyType B32; - CARD32 bytesAfter B32; - CARD32 nItems B32; /* # of 8, 16, or 32-bit entities in reply */ - CARD32 pad1 B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - } xGetPropertyReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nProperties B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xListPropertiesReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - Window owner B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - } xGetSelectionOwnerReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE status; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD32 pad1 B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - } xGrabPointerReply; - -typedef xGrabPointerReply xGrabKeyboardReply; - -typedef struct { - BYTE type; /* X_Reply */ - BOOL sameScreen; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - Window root B32, child B32; - INT16 rootX B16, rootY B16, winX B16, winY B16; - CARD16 mask B16; - CARD16 pad1 B16; - CARD32 pad B32; - } xQueryPointerReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD32 nEvents B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - } xGetMotionEventsReply; - -typedef struct { - BYTE type; /* X_Reply */ - BOOL sameScreen; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - Window child B32; - INT16 dstX B16, dstY B16; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - } xTranslateCoordsReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 revertTo; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - Window focus B32; - CARD32 pad1 B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - } xGetInputFocusReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 2, NOT 0; this is an extra-large reply */ - BYTE map[32]; - } xQueryKeymapReply; - -/* Warning: this MUST match (up to component renaming) xListFontsWithInfoReply */ -typedef struct _xQueryFontReply { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* definitely > 0, even if "nCharInfos" is 0 */ - xCharInfo minBounds; -#ifndef WORD64 - CARD32 walign1 B32; -#endif - xCharInfo maxBounds; -#ifndef WORD64 - CARD32 walign2 B32; -#endif - CARD16 minCharOrByte2 B16, maxCharOrByte2 B16; - CARD16 defaultChar B16; - CARD16 nFontProps B16; /* followed by this many xFontProp structures */ - CARD8 drawDirection; - CARD8 minByte1, maxByte1; - BOOL allCharsExist; - INT16 fontAscent B16, fontDescent B16; - CARD32 nCharInfos B32; /* followed by this many xCharInfo structures */ -} xQueryFontReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 drawDirection; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - INT16 fontAscent B16, fontDescent B16; - INT16 overallAscent B16, overallDescent B16; - INT32 overallWidth B32, overallLeft B32, overallRight B32; - CARD32 pad B32; - } xQueryTextExtentsReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nFonts B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xListFontsReply; - -/* Warning: this MUST match (up to component renaming) xQueryFontReply */ -typedef struct { - BYTE type; /* X_Reply */ - CARD8 nameLength; /* 0 indicates end-of-reply-sequence */ - CARD16 sequenceNumber B16; - CARD32 length B32; /* definitely > 0, even if "nameLength" is 0 */ - xCharInfo minBounds; -#ifndef WORD64 - CARD32 walign1 B32; -#endif - xCharInfo maxBounds; -#ifndef WORD64 - CARD32 walign2 B32; -#endif - CARD16 minCharOrByte2 B16, maxCharOrByte2 B16; - CARD16 defaultChar B16; - CARD16 nFontProps B16; /* followed by this many xFontProp structures */ - CARD8 drawDirection; - CARD8 minByte1, maxByte1; - BOOL allCharsExist; - INT16 fontAscent B16, fontDescent B16; - CARD32 nReplies B32; /* hint as to how many more replies might be coming */ -} xListFontsWithInfoReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nPaths B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xGetFontPathReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 depth; - CARD16 sequenceNumber B16; - CARD32 length B32; - VisualID visual B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xGetImageReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nColormaps B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xListInstalledColormapsReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD16 red B16, green B16, blue B16; - CARD16 pad2 B16; - CARD32 pixel B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - } xAllocColorReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD32 pixel B32; - CARD16 exactRed B16, exactGreen B16, exactBlue B16; - CARD16 screenRed B16, screenGreen B16, screenBlue B16; - CARD32 pad2 B32; - CARD32 pad3 B32; - } xAllocNamedColorReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nPixels B16, nMasks B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xAllocColorCellsReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nPixels B16; - CARD16 pad2 B16; - CARD32 redMask B32, greenMask B32, blueMask B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - } xAllocColorPlanesReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nColors B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xQueryColorsReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD16 exactRed B16, exactGreen B16, exactBlue B16; - CARD16 screenRed B16, screenGreen B16, screenBlue B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - } xLookupColorReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD16 width B16, height B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xQueryBestSizeReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - BOOL present; - CARD8 major_opcode; - CARD8 first_event; - CARD8 first_error; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xQueryExtensionReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 nExtensions; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xListExtensionsReply; - - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 success; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xSetMappingReply; -typedef xSetMappingReply xSetPointerMappingReply; -typedef xSetMappingReply xSetModifierMappingReply; - -typedef struct { - BYTE type; /* X_Reply */ - CARD8 nElts; /* how many elements does the map have */ - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xGetPointerMappingReply; - -typedef struct { - BYTE type; - CARD8 keySymsPerKeyCode; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; -} xGetKeyboardMappingReply; - -typedef struct { - BYTE type; - CARD8 numKeyPerModifier; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD32 pad1 B32; - CARD32 pad2 B32; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; -} xGetModifierMappingReply; - -typedef struct { - BYTE type; /* X_Reply */ - BOOL globalAutoRepeat; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 5 */ - CARD32 ledMask B32; - CARD8 keyClickPercent, bellPercent; - CARD16 bellPitch B16, bellDuration B16; - CARD16 pad B16; - BYTE map[32]; /* bit masks start here */ - } xGetKeyboardControlReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD16 accelNumerator B16, accelDenominator B16; - CARD16 threshold B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - } xGetPointerControlReply; - -typedef struct { - BYTE type; /* X_Reply */ - BYTE pad1; - CARD16 sequenceNumber B16; - CARD32 length B32; /* 0 */ - CARD16 timeout B16, interval B16; - BOOL preferBlanking; - BOOL allowExposures; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - } xGetScreenSaverReply; - -typedef struct { - BYTE type; /* X_Reply */ - BOOL enabled; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 nHosts B16; - CARD16 pad1 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; - } xListHostsReply; - - - - -/***************************************************************** - * Xerror - * All errors are 32 bytes - *****************************************************************/ - -typedef struct { - BYTE type; /* X_Error */ - BYTE errorCode; - CARD16 sequenceNumber B16; /* the nth request from this client */ - CARD32 resourceID B32; - CARD16 minorCode B16; - CARD8 majorCode; - BYTE pad1; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; -} xError; - -/***************************************************************** - * xEvent - * All events are 32 bytes - *****************************************************************/ - -typedef struct _xEvent { - union { - struct { - BYTE type; - BYTE detail; - CARD16 sequenceNumber B16; - } u; - struct { - CARD32 pad00 B32; - Time time B32; - Window root B32, event B32, child B32; - INT16 rootX B16, rootY B16, eventX B16, eventY B16; - KeyButMask state B16; - BOOL sameScreen; - BYTE pad1; - } keyButtonPointer; - struct { - CARD32 pad00 B32; - Time time B32; - Window root B32, event B32, child B32; - INT16 rootX B16, rootY B16, eventX B16, eventY B16; - KeyButMask state B16; - BYTE mode; /* really XMode */ - BYTE flags; /* sameScreen and focus booleans, packed together */ -#define ELFlagFocus (1<<0) -#define ELFlagSameScreen (1<<1) - } enterLeave; - struct { - CARD32 pad00 B32; - Window window B32; - BYTE mode; /* really XMode */ - BYTE pad1, pad2, pad3; - } focus; - struct { - CARD32 pad00 B32; - Window window B32; - CARD16 x B16, y B16, width B16, height B16; - CARD16 count B16; - CARD16 pad2 B16; - } expose; - struct { - CARD32 pad00 B32; - Drawable drawable B32; - CARD16 x B16, y B16, width B16, height B16; - CARD16 minorEvent B16; - CARD16 count B16; - BYTE majorEvent; - BYTE pad1, pad2, pad3; - } graphicsExposure; - struct { - CARD32 pad00 B32; - Drawable drawable B32; - CARD16 minorEvent B16; - BYTE majorEvent; - BYTE bpad; - } noExposure; - struct { - CARD32 pad00 B32; - Window window B32; - CARD8 state; - BYTE pad1, pad2, pad3; - } visibility; - struct { - CARD32 pad00 B32; - Window parent B32, window B32; - INT16 x B16, y B16; - CARD16 width B16, height B16, borderWidth B16; - BOOL override; - BYTE bpad; - } createNotify; -/* - * The event fields in the structures for DestroyNotify, UnmapNotify, - * MapNotify, ReparentNotify, ConfigureNotify, CirculateNotify, GravityNotify, - * must be at the same offset because server internal code is depending upon - * this to patch up the events before they are delivered. - * Also note that MapRequest, ConfigureRequest and CirculateRequest have - * the same offset for the event window. - */ - struct { - CARD32 pad00 B32; - Window event B32, window B32; - } destroyNotify; - struct { - CARD32 pad00 B32; - Window event B32, window B32; - BOOL fromConfigure; - BYTE pad1, pad2, pad3; - } unmapNotify; - struct { - CARD32 pad00 B32; - Window event B32, window B32; - BOOL override; - BYTE pad1, pad2, pad3; - } mapNotify; - struct { - CARD32 pad00 B32; - Window parent B32, window B32; - } mapRequest; - struct { - CARD32 pad00 B32; - Window event B32, window B32, parent B32; - INT16 x B16, y B16; - BOOL override; - BYTE pad1, pad2, pad3; - } reparent; - struct { - CARD32 pad00 B32; - Window event B32, window B32, aboveSibling B32; - INT16 x B16, y B16; - CARD16 width B16, height B16, borderWidth B16; - BOOL override; - BYTE bpad; - } configureNotify; - struct { - CARD32 pad00 B32; - Window parent B32, window B32, sibling B32; - INT16 x B16, y B16; - CARD16 width B16, height B16, borderWidth B16; - CARD16 valueMask B16; - CARD32 pad1 B32; - } configureRequest; - struct { - CARD32 pad00 B32; - Window event B32, window B32; - INT16 x B16, y B16; - CARD32 pad1 B32, pad2 B32, pad3 B32, pad4 B32; - } gravity; - struct { - CARD32 pad00 B32; - Window window B32; - CARD16 width B16, height B16; - } resizeRequest; - struct { -/* The event field in the circulate record is really the parent when this - is used as a CirculateRequest instead of a CirculateNotify */ - CARD32 pad00 B32; - Window event B32, window B32, parent B32; - BYTE place; /* Top or Bottom */ - BYTE pad1, pad2, pad3; - } circulate; - struct { - CARD32 pad00 B32; - Window window B32; - Atom atom B32; - Time time B32; - BYTE state; /* NewValue or Deleted */ - BYTE pad1; - CARD16 pad2 B16; - } property; - struct { - CARD32 pad00 B32; - Time time B32; - Window window B32; - Atom atom B32; - } selectionClear; - struct { - CARD32 pad00 B32; - Time time B32; - Window owner B32, requestor B32; - Atom selection B32, target B32, property B32; - } selectionRequest; - struct { - CARD32 pad00 B32; - Time time B32; - Window requestor B32; - Atom selection B32, target B32, property B32; - } selectionNotify; - struct { - CARD32 pad00 B32; - Window window B32; - Colormap colormap B32; -#if defined(__cplusplus) || defined(c_plusplus) - BOOL c_new; -#else - BOOL new; -#endif - BYTE state; /* Installed or UnInstalled */ - BYTE pad1, pad2; - } colormap; - struct { - CARD32 pad00 B32; - CARD8 request; - KeyCode firstKeyCode; - CARD8 count; - BYTE pad1; - } mappingNotify; - struct { - CARD32 pad00 B32; - Window window B32; - union { - struct { - Atom type B32; - INT32 longs0 B32; - INT32 longs1 B32; - INT32 longs2 B32; - INT32 longs3 B32; - INT32 longs4 B32; - } l; - struct { - Atom type B32; - INT16 shorts0 B16; - INT16 shorts1 B16; - INT16 shorts2 B16; - INT16 shorts3 B16; - INT16 shorts4 B16; - INT16 shorts5 B16; - INT16 shorts6 B16; - INT16 shorts7 B16; - INT16 shorts8 B16; - INT16 shorts9 B16; - } s; - struct { - Atom type B32; - INT8 bytes[20]; - } b; - } u; - } clientMessage; - } u; -} xEvent; - -/********************************************************* - * - * Generic event - * - * Those events are not part of the core protocol spec and can be used by - * various extensions. - * type is always GenericEvent - * extension is the minor opcode of the extension the event belongs to. - * evtype is the actual event type, unique __per extension__. - * - * GenericEvents can be longer than 32 bytes, with the length field - * specifying the number of 4 byte blocks after the first 32 bytes. - * - * - */ -typedef struct -{ - BYTE type; - CARD8 extension; - CARD16 sequenceNumber B16; - CARD32 length B32; - CARD16 evtype B16; - CARD16 pad2 B16; - CARD32 pad3 B32; - CARD32 pad4 B32; - CARD32 pad5 B32; - CARD32 pad6 B32; - CARD32 pad7 B32; -} xGenericEvent; - - - -/* KeymapNotify events are not included in the above union because they - are different from all other events: they do not have a "detail" - or "sequenceNumber", so there is room for a 248-bit key mask. */ - -typedef struct { - BYTE type; - BYTE map[31]; - } xKeymapEvent; - -#define XEventSize (sizeof(xEvent)) - -/* XReply is the union of all the replies above whose "fixed part" -fits in 32 bytes. It does NOT include GetWindowAttributesReply, -QueryFontReply, QueryKeymapReply, or GetKeyboardControlReply -ListFontsWithInfoReply */ - -typedef union { - xGenericReply generic; - xGetGeometryReply geom; - xQueryTreeReply tree; - xInternAtomReply atom; - xGetAtomNameReply atomName; - xGetPropertyReply property; - xListPropertiesReply listProperties; - xGetSelectionOwnerReply selection; - xGrabPointerReply grabPointer; - xGrabKeyboardReply grabKeyboard; - xQueryPointerReply pointer; - xGetMotionEventsReply motionEvents; - xTranslateCoordsReply coords; - xGetInputFocusReply inputFocus; - xQueryTextExtentsReply textExtents; - xListFontsReply fonts; - xGetFontPathReply fontPath; - xGetImageReply image; - xListInstalledColormapsReply colormaps; - xAllocColorReply allocColor; - xAllocNamedColorReply allocNamedColor; - xAllocColorCellsReply colorCells; - xAllocColorPlanesReply colorPlanes; - xQueryColorsReply colors; - xLookupColorReply lookupColor; - xQueryBestSizeReply bestSize; - xQueryExtensionReply extension; - xListExtensionsReply extensions; - xSetModifierMappingReply setModifierMapping; - xGetModifierMappingReply getModifierMapping; - xSetPointerMappingReply setPointerMapping; - xGetKeyboardMappingReply getKeyboardMapping; - xGetPointerMappingReply getPointerMapping; - xGetPointerControlReply pointerControl; - xGetScreenSaverReply screenSaver; - xListHostsReply hosts; - xError error; - xEvent event; -} xReply; - - - -/***************************************************************** - * REQUESTS - *****************************************************************/ - - -/* Request structure */ - -typedef struct _xReq { - CARD8 reqType; - CARD8 data; /* meaning depends on request type */ - CARD16 length B16; /* length in 4 bytes quantities - of whole request, including this header */ -} xReq; - -/***************************************************************** - * structures that follow request. - *****************************************************************/ - -/* ResourceReq is used for any request which has a resource ID - (or Atom or Time) as its one and only argument. */ - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - CARD32 id B32; /* a Window, Drawable, Font, GContext, Pixmap, etc. */ - } xResourceReq; - -typedef struct { - CARD8 reqType; - CARD8 depth; - CARD16 length B16; - Window wid B32, parent B32; - INT16 x B16, y B16; - CARD16 width B16, height B16, borderWidth B16; -#if defined(__cplusplus) || defined(c_plusplus) - CARD16 c_class B16; -#else - CARD16 class B16; -#endif - VisualID visual B32; - CARD32 mask B32; -} xCreateWindowReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window window B32; - CARD32 valueMask B32; -} xChangeWindowAttributesReq; - -typedef struct { - CARD8 reqType; - BYTE mode; - CARD16 length B16; - Window window B32; -} xChangeSaveSetReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window window B32, parent B32; - INT16 x B16, y B16; -} xReparentWindowReq; - -typedef struct { - CARD8 reqType; - CARD8 pad; - CARD16 length B16; - Window window B32; - CARD16 mask B16; - CARD16 pad2 B16; -} xConfigureWindowReq; - -typedef struct { - CARD8 reqType; - CARD8 direction; - CARD16 length B16; - Window window B32; -} xCirculateWindowReq; - -typedef struct { /* followed by padded string */ - CARD8 reqType; - BOOL onlyIfExists; - CARD16 length B16; - CARD16 nbytes B16; /* number of bytes in string */ - CARD16 pad B16; -} xInternAtomReq; - -typedef struct { - CARD8 reqType; - CARD8 mode; - CARD16 length B16; - Window window B32; - Atom property B32, type B32; - CARD8 format; - BYTE pad[3]; - CARD32 nUnits B32; /* length of stuff following, depends on format */ -} xChangePropertyReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window window B32; - Atom property B32; -} xDeletePropertyReq; - -typedef struct { - CARD8 reqType; -#if defined(__cplusplus) || defined(c_plusplus) - BOOL c_delete; -#else - BOOL delete; -#endif - CARD16 length B16; - Window window B32; - Atom property B32, type B32; - CARD32 longOffset B32; - CARD32 longLength B32; -} xGetPropertyReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window window B32; - Atom selection B32; - Time time B32; -} xSetSelectionOwnerReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window requestor B32; - Atom selection B32, target B32, property B32; - Time time B32; - } xConvertSelectionReq; - -typedef struct { - CARD8 reqType; - BOOL propagate; - CARD16 length B16; - Window destination B32; - CARD32 eventMask B32; -#ifdef WORD64 - /* the structure should have been quad-aligned */ - BYTE eventdata[SIZEOF(xEvent)]; -#else - xEvent event; -#endif /* WORD64 */ -} xSendEventReq; - -typedef struct { - CARD8 reqType; - BOOL ownerEvents; - CARD16 length B16; - Window grabWindow B32; - CARD16 eventMask B16; - BYTE pointerMode, keyboardMode; - Window confineTo B32; - Cursor cursor B32; - Time time B32; -} xGrabPointerReq; - -typedef struct { - CARD8 reqType; - BOOL ownerEvents; - CARD16 length B16; - Window grabWindow B32; - CARD16 eventMask B16; - BYTE pointerMode, keyboardMode; - Window confineTo B32; - Cursor cursor B32; - CARD8 button; - BYTE pad; - CARD16 modifiers B16; -} xGrabButtonReq; - -typedef struct { - CARD8 reqType; - CARD8 button; - CARD16 length B16; - Window grabWindow B32; - CARD16 modifiers B16; - CARD16 pad B16; -} xUngrabButtonReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Cursor cursor B32; - Time time B32; - CARD16 eventMask B16; - CARD16 pad2 B16; -} xChangeActivePointerGrabReq; - -typedef struct { - CARD8 reqType; - BOOL ownerEvents; - CARD16 length B16; - Window grabWindow B32; - Time time B32; - BYTE pointerMode, keyboardMode; - CARD16 pad B16; -} xGrabKeyboardReq; - -typedef struct { - CARD8 reqType; - BOOL ownerEvents; - CARD16 length B16; - Window grabWindow B32; - CARD16 modifiers B16; - CARD8 key; - BYTE pointerMode, keyboardMode; - BYTE pad1, pad2, pad3; -} xGrabKeyReq; - -typedef struct { - CARD8 reqType; - CARD8 key; - CARD16 length B16; - Window grabWindow B32; - CARD16 modifiers B16; - CARD16 pad B16; -} xUngrabKeyReq; - -typedef struct { - CARD8 reqType; - CARD8 mode; - CARD16 length B16; - Time time B32; -} xAllowEventsReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window window B32; - Time start B32, stop B32; -} xGetMotionEventsReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window srcWid B32, dstWid B32; - INT16 srcX B16, srcY B16; -} xTranslateCoordsReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window srcWid B32, dstWid B32; - INT16 srcX B16, srcY B16; - CARD16 srcWidth B16, srcHeight B16; - INT16 dstX B16, dstY B16; -} xWarpPointerReq; - -typedef struct { - CARD8 reqType; - CARD8 revertTo; - CARD16 length B16; - Window focus B32; - Time time B32; -} xSetInputFocusReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Font fid B32; - CARD16 nbytes B16; - BYTE pad1, pad2; /* string follows on word boundary */ -} xOpenFontReq; - -typedef struct { - CARD8 reqType; - BOOL oddLength; - CARD16 length B16; - Font fid B32; - } xQueryTextExtentsReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - CARD16 maxNames B16; - CARD16 nbytes B16; /* followed immediately by string bytes */ -} xListFontsReq; - -typedef xListFontsReq xListFontsWithInfoReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - CARD16 nFonts B16; - BYTE pad1, pad2; /* LISTofSTRING8 follows on word boundary */ -} xSetFontPathReq; - -typedef struct { - CARD8 reqType; - CARD8 depth; - CARD16 length B16; - Pixmap pid B32; - Drawable drawable B32; - CARD16 width B16, height B16; -} xCreatePixmapReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - GContext gc B32; - Drawable drawable B32; - CARD32 mask B32; -} xCreateGCReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - GContext gc B32; - CARD32 mask B32; -} xChangeGCReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - GContext srcGC B32, dstGC B32; - CARD32 mask B32; -} xCopyGCReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - GContext gc B32; - CARD16 dashOffset B16; - CARD16 nDashes B16; /* length LISTofCARD8 of values following */ -} xSetDashesReq; - -typedef struct { - CARD8 reqType; - BYTE ordering; - CARD16 length B16; - GContext gc B32; - INT16 xOrigin B16, yOrigin B16; -} xSetClipRectanglesReq; - -typedef struct { - CARD8 reqType; - BOOL exposures; - CARD16 length B16; - Window window B32; - INT16 x B16, y B16; - CARD16 width B16, height B16; -} xClearAreaReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Drawable srcDrawable B32, dstDrawable B32; - GContext gc B32; - INT16 srcX B16, srcY B16, dstX B16, dstY B16; - CARD16 width B16, height B16; -} xCopyAreaReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Drawable srcDrawable B32, dstDrawable B32; - GContext gc B32; - INT16 srcX B16, srcY B16, dstX B16, dstY B16; - CARD16 width B16, height B16; - CARD32 bitPlane B32; -} xCopyPlaneReq; - -typedef struct { - CARD8 reqType; - BYTE coordMode; - CARD16 length B16; - Drawable drawable B32; - GContext gc B32; -} xPolyPointReq; - -typedef xPolyPointReq xPolyLineReq; /* same request structure */ - -/* The following used for PolySegment, PolyRectangle, PolyArc, PolyFillRectangle, PolyFillArc */ - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Drawable drawable B32; - GContext gc B32; -} xPolySegmentReq; - -typedef xPolySegmentReq xPolyArcReq; -typedef xPolySegmentReq xPolyRectangleReq; -typedef xPolySegmentReq xPolyFillRectangleReq; -typedef xPolySegmentReq xPolyFillArcReq; - -typedef struct _FillPolyReq { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Drawable drawable B32; - GContext gc B32; - BYTE shape; - BYTE coordMode; - CARD16 pad1 B16; -} xFillPolyReq; - - -typedef struct _PutImageReq { - CARD8 reqType; - CARD8 format; - CARD16 length B16; - Drawable drawable B32; - GContext gc B32; - CARD16 width B16, height B16; - INT16 dstX B16, dstY B16; - CARD8 leftPad; - CARD8 depth; - CARD16 pad B16; -} xPutImageReq; - -typedef struct { - CARD8 reqType; - CARD8 format; - CARD16 length B16; - Drawable drawable B32; - INT16 x B16, y B16; - CARD16 width B16, height B16; - CARD32 planeMask B32; -} xGetImageReq; - -/* the following used by PolyText8 and PolyText16 */ - -typedef struct { - CARD8 reqType; - CARD8 pad; - CARD16 length B16; - Drawable drawable B32; - GContext gc B32; - INT16 x B16, y B16; /* items (xTextElt) start after struct */ -} xPolyTextReq; - -typedef xPolyTextReq xPolyText8Req; -typedef xPolyTextReq xPolyText16Req; - -typedef struct { - CARD8 reqType; - BYTE nChars; - CARD16 length B16; - Drawable drawable B32; - GContext gc B32; - INT16 x B16, y B16; -} xImageTextReq; - -typedef xImageTextReq xImageText8Req; -typedef xImageTextReq xImageText16Req; - -typedef struct { - CARD8 reqType; - BYTE alloc; - CARD16 length B16; - Colormap mid B32; - Window window B32; - VisualID visual B32; -} xCreateColormapReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap mid B32; - Colormap srcCmap B32; -} xCopyColormapAndFreeReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap cmap B32; - CARD16 red B16, green B16, blue B16; - CARD16 pad2 B16; -} xAllocColorReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap cmap B32; - CARD16 nbytes B16; /* followed by structure */ - BYTE pad1, pad2; -} xAllocNamedColorReq; - -typedef struct { - CARD8 reqType; - BOOL contiguous; - CARD16 length B16; - Colormap cmap B32; - CARD16 colors B16, planes B16; -} xAllocColorCellsReq; - -typedef struct { - CARD8 reqType; - BOOL contiguous; - CARD16 length B16; - Colormap cmap B32; - CARD16 colors B16, red B16, green B16, blue B16; -} xAllocColorPlanesReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap cmap B32; - CARD32 planeMask B32; -} xFreeColorsReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap cmap B32; -} xStoreColorsReq; - -typedef struct { - CARD8 reqType; - CARD8 flags; /* DoRed, DoGreen, DoBlue, as in xColorItem */ - CARD16 length B16; - Colormap cmap B32; - CARD32 pixel B32; - CARD16 nbytes B16; /* number of name string bytes following structure */ - BYTE pad1, pad2; - } xStoreNamedColorReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap cmap B32; -} xQueryColorsReq; - -typedef struct { /* followed by string of length len */ - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Colormap cmap B32; - CARD16 nbytes B16; /* number of string bytes following structure*/ - BYTE pad1, pad2; -} xLookupColorReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Cursor cid B32; - Pixmap source B32, mask B32; - CARD16 foreRed B16, foreGreen B16, foreBlue B16; - CARD16 backRed B16, backGreen B16, backBlue B16; - CARD16 x B16, y B16; -} xCreateCursorReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Cursor cid B32; - Font source B32, mask B32; - CARD16 sourceChar B16, maskChar B16; - CARD16 foreRed B16, foreGreen B16, foreBlue B16; - CARD16 backRed B16, backGreen B16, backBlue B16; -} xCreateGlyphCursorReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Cursor cursor B32; - CARD16 foreRed B16, foreGreen B16, foreBlue B16; - CARD16 backRed B16, backGreen B16, backBlue B16; -} xRecolorCursorReq; - -typedef struct { - CARD8 reqType; -#if defined(__cplusplus) || defined(c_plusplus) - CARD8 c_class; -#else - CARD8 class; -#endif - CARD16 length B16; - Drawable drawable B32; - CARD16 width B16, height B16; -} xQueryBestSizeReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - CARD16 nbytes B16; /* number of string bytes following structure */ - BYTE pad1, pad2; -} xQueryExtensionReq; - -typedef struct { - CARD8 reqType; - CARD8 numKeyPerModifier; - CARD16 length B16; -} xSetModifierMappingReq; - -typedef struct { - CARD8 reqType; - CARD8 nElts; /* how many elements in the map */ - CARD16 length B16; -} xSetPointerMappingReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - KeyCode firstKeyCode; - CARD8 count; - CARD16 pad1 B16; -} xGetKeyboardMappingReq; - -typedef struct { - CARD8 reqType; - CARD8 keyCodes; - CARD16 length B16; - KeyCode firstKeyCode; - CARD8 keySymsPerKeyCode; - CARD16 pad1 B16; -} xChangeKeyboardMappingReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - CARD32 mask B32; -} xChangeKeyboardControlReq; - -typedef struct { - CARD8 reqType; - INT8 percent; /* -100 to 100 */ - CARD16 length B16; -} xBellReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - INT16 accelNum B16, accelDenum B16; - INT16 threshold B16; - BOOL doAccel, doThresh; -} xChangePointerControlReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - INT16 timeout B16, interval B16; - BYTE preferBlank, allowExpose; - CARD16 pad2 B16; -} xSetScreenSaverReq; - -typedef struct { - CARD8 reqType; - BYTE mode; - CARD16 length B16; - CARD8 hostFamily; - BYTE pad; - CARD16 hostLength B16; -} xChangeHostsReq; - -typedef struct { - CARD8 reqType; - BYTE pad; - CARD16 length B16; - } xListHostsReq; - -typedef struct { - CARD8 reqType; - BYTE mode; - CARD16 length B16; - } xChangeModeReq; - -typedef xChangeModeReq xSetAccessControlReq; -typedef xChangeModeReq xSetCloseDownModeReq; -typedef xChangeModeReq xForceScreenSaverReq; - -typedef struct { /* followed by LIST of ATOM */ - CARD8 reqType; - BYTE pad; - CARD16 length B16; - Window window B32; - CARD16 nAtoms B16; - INT16 nPositions B16; - } xRotatePropertiesReq; - - - -/* Reply codes */ - -#define X_Reply 1 /* Normal reply */ -#define X_Error 0 /* Error */ - -/* Request codes */ - -#define X_CreateWindow 1 -#define X_ChangeWindowAttributes 2 -#define X_GetWindowAttributes 3 -#define X_DestroyWindow 4 -#define X_DestroySubwindows 5 -#define X_ChangeSaveSet 6 -#define X_ReparentWindow 7 -#define X_MapWindow 8 -#define X_MapSubwindows 9 -#define X_UnmapWindow 10 -#define X_UnmapSubwindows 11 -#define X_ConfigureWindow 12 -#define X_CirculateWindow 13 -#define X_GetGeometry 14 -#define X_QueryTree 15 -#define X_InternAtom 16 -#define X_GetAtomName 17 -#define X_ChangeProperty 18 -#define X_DeleteProperty 19 -#define X_GetProperty 20 -#define X_ListProperties 21 -#define X_SetSelectionOwner 22 -#define X_GetSelectionOwner 23 -#define X_ConvertSelection 24 -#define X_SendEvent 25 -#define X_GrabPointer 26 -#define X_UngrabPointer 27 -#define X_GrabButton 28 -#define X_UngrabButton 29 -#define X_ChangeActivePointerGrab 30 -#define X_GrabKeyboard 31 -#define X_UngrabKeyboard 32 -#define X_GrabKey 33 -#define X_UngrabKey 34 -#define X_AllowEvents 35 -#define X_GrabServer 36 -#define X_UngrabServer 37 -#define X_QueryPointer 38 -#define X_GetMotionEvents 39 -#define X_TranslateCoords 40 -#define X_WarpPointer 41 -#define X_SetInputFocus 42 -#define X_GetInputFocus 43 -#define X_QueryKeymap 44 -#define X_OpenFont 45 -#define X_CloseFont 46 -#define X_QueryFont 47 -#define X_QueryTextExtents 48 -#define X_ListFonts 49 -#define X_ListFontsWithInfo 50 -#define X_SetFontPath 51 -#define X_GetFontPath 52 -#define X_CreatePixmap 53 -#define X_FreePixmap 54 -#define X_CreateGC 55 -#define X_ChangeGC 56 -#define X_CopyGC 57 -#define X_SetDashes 58 -#define X_SetClipRectangles 59 -#define X_FreeGC 60 -#define X_ClearArea 61 -#define X_CopyArea 62 -#define X_CopyPlane 63 -#define X_PolyPoint 64 -#define X_PolyLine 65 -#define X_PolySegment 66 -#define X_PolyRectangle 67 -#define X_PolyArc 68 -#define X_FillPoly 69 -#define X_PolyFillRectangle 70 -#define X_PolyFillArc 71 -#define X_PutImage 72 -#define X_GetImage 73 -#define X_PolyText8 74 -#define X_PolyText16 75 -#define X_ImageText8 76 -#define X_ImageText16 77 -#define X_CreateColormap 78 -#define X_FreeColormap 79 -#define X_CopyColormapAndFree 80 -#define X_InstallColormap 81 -#define X_UninstallColormap 82 -#define X_ListInstalledColormaps 83 -#define X_AllocColor 84 -#define X_AllocNamedColor 85 -#define X_AllocColorCells 86 -#define X_AllocColorPlanes 87 -#define X_FreeColors 88 -#define X_StoreColors 89 -#define X_StoreNamedColor 90 -#define X_QueryColors 91 -#define X_LookupColor 92 -#define X_CreateCursor 93 -#define X_CreateGlyphCursor 94 -#define X_FreeCursor 95 -#define X_RecolorCursor 96 -#define X_QueryBestSize 97 -#define X_QueryExtension 98 -#define X_ListExtensions 99 -#define X_ChangeKeyboardMapping 100 -#define X_GetKeyboardMapping 101 -#define X_ChangeKeyboardControl 102 -#define X_GetKeyboardControl 103 -#define X_Bell 104 -#define X_ChangePointerControl 105 -#define X_GetPointerControl 106 -#define X_SetScreenSaver 107 -#define X_GetScreenSaver 108 -#define X_ChangeHosts 109 -#define X_ListHosts 110 -#define X_SetAccessControl 111 -#define X_SetCloseDownMode 112 -#define X_KillClient 113 -#define X_RotateProperties 114 -#define X_ForceScreenSaver 115 -#define X_SetPointerMapping 116 -#define X_GetPointerMapping 117 -#define X_SetModifierMapping 118 -#define X_GetModifierMapping 119 -#define X_NoOperation 127 - -/* restore these definitions back to the typedefs in X.h */ -#undef Window -#undef Drawable -#undef Font -#undef Pixmap -#undef Cursor -#undef Colormap -#undef GContext -#undef Atom -#undef VisualID -#undef Time -#undef KeyCode -#undef KeySym - -#endif /* XPROTO_H */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xprotostr.h b/btgui/OpenGLWindow/optionalX11/X11/Xprotostr.h deleted file mode 100644 index a9e854d37..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xprotostr.h +++ /dev/null @@ -1,77 +0,0 @@ -#ifndef XPROTOSTRUCTS_H -#define XPROTOSTRUCTS_H - -/*********************************************************** - -Copyright 1987, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - - -Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, -provided that the above copyright notice appear in all copies and that -both that copyright notice and this permission notice appear in -supporting documentation, and that the name of Digital not be -used in advertising or publicity pertaining to distribution of the -software without specific, written prior permission. - -DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING -ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL -DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR -ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, -WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, -ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS -SOFTWARE. - -******************************************************************/ -#include - -/* Used by PolySegment */ - -typedef struct _xSegment { - INT16 x1 B16, y1 B16, x2 B16, y2 B16; -} xSegment; - -/* POINT */ - -typedef struct _xPoint { - INT16 x B16, y B16; -} xPoint; - -typedef struct _xRectangle { - INT16 x B16, y B16; - CARD16 width B16, height B16; -} xRectangle; - -/* ARC */ - -typedef struct _xArc { - INT16 x B16, y B16; - CARD16 width B16, height B16; - INT16 angle1 B16, angle2 B16; -} xArc; - -#endif /* XPROTOSTRUCTS_H */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/Xutil.h b/btgui/OpenGLWindow/optionalX11/X11/Xutil.h deleted file mode 100644 index 62cdf5556..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/Xutil.h +++ /dev/null @@ -1,838 +0,0 @@ - -/*********************************************************** - -Copyright 1987, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - - -Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, -provided that the above copyright notice appear in all copies and that -both that copyright notice and this permission notice appear in -supporting documentation, and that the name of Digital not be -used in advertising or publicity pertaining to distribution of the -software without specific, written prior permission. - -DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING -ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL -DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR -ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, -WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, -ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS -SOFTWARE. - -******************************************************************/ - -#ifndef _X11_XUTIL_H_ -#define _X11_XUTIL_H_ - -/* You must include before including this file */ -#include -#include - -/* The Xlib structs are full of implicit padding to properly align members. - We can't clean that up without breaking ABI, so tell clang not to bother - complaining about it. */ -#ifdef __clang__ -#pragma clang diagnostic push -#pragma clang diagnostic ignored "-Wpadded" -#endif - -/* - * Bitmask returned by XParseGeometry(). Each bit tells if the corresponding - * value (x, y, width, height) was found in the parsed string. - */ -#define NoValue 0x0000 -#define XValue 0x0001 -#define YValue 0x0002 -#define WidthValue 0x0004 -#define HeightValue 0x0008 -#define AllValues 0x000F -#define XNegative 0x0010 -#define YNegative 0x0020 - -/* - * new version containing base_width, base_height, and win_gravity fields; - * used with WM_NORMAL_HINTS. - */ -typedef struct { - long flags; /* marks which fields in this structure are defined */ - int x, y; /* obsolete for new window mgrs, but clients */ - int width, height; /* should set so old wm's don't mess up */ - int min_width, min_height; - int max_width, max_height; - int width_inc, height_inc; - struct { - int x; /* numerator */ - int y; /* denominator */ - } min_aspect, max_aspect; - int base_width, base_height; /* added by ICCCM version 1 */ - int win_gravity; /* added by ICCCM version 1 */ -} XSizeHints; - -/* - * The next block of definitions are for window manager properties that - * clients and applications use for communication. - */ - -/* flags argument in size hints */ -#define USPosition (1L << 0) /* user specified x, y */ -#define USSize (1L << 1) /* user specified width, height */ - -#define PPosition (1L << 2) /* program specified position */ -#define PSize (1L << 3) /* program specified size */ -#define PMinSize (1L << 4) /* program specified minimum size */ -#define PMaxSize (1L << 5) /* program specified maximum size */ -#define PResizeInc (1L << 6) /* program specified resize increments */ -#define PAspect (1L << 7) /* program specified min and max aspect ratios */ -#define PBaseSize (1L << 8) /* program specified base for incrementing */ -#define PWinGravity (1L << 9) /* program specified window gravity */ - -/* obsolete */ -#define PAllHints (PPosition|PSize|PMinSize|PMaxSize|PResizeInc|PAspect) - - - -typedef struct { - long flags; /* marks which fields in this structure are defined */ - Bool input; /* does this application rely on the window manager to - get keyboard input? */ - int initial_state; /* see below */ - Pixmap icon_pixmap; /* pixmap to be used as icon */ - Window icon_window; /* window to be used as icon */ - int icon_x, icon_y; /* initial position of icon */ - Pixmap icon_mask; /* icon mask bitmap */ - XID window_group; /* id of related window group */ - /* this structure may be extended in the future */ -} XWMHints; - -/* definition for flags of XWMHints */ - -#define InputHint (1L << 0) -#define StateHint (1L << 1) -#define IconPixmapHint (1L << 2) -#define IconWindowHint (1L << 3) -#define IconPositionHint (1L << 4) -#define IconMaskHint (1L << 5) -#define WindowGroupHint (1L << 6) -#define AllHints (InputHint|StateHint|IconPixmapHint|IconWindowHint| \ -IconPositionHint|IconMaskHint|WindowGroupHint) -#define XUrgencyHint (1L << 8) - -/* definitions for initial window state */ -#define WithdrawnState 0 /* for windows that are not mapped */ -#define NormalState 1 /* most applications want to start this way */ -#define IconicState 3 /* application wants to start as an icon */ - -/* - * Obsolete states no longer defined by ICCCM - */ -#define DontCareState 0 /* don't know or care */ -#define ZoomState 2 /* application wants to start zoomed */ -#define InactiveState 4 /* application believes it is seldom used; */ - /* some wm's may put it on inactive menu */ - - -/* - * new structure for manipulating TEXT properties; used with WM_NAME, - * WM_ICON_NAME, WM_CLIENT_MACHINE, and WM_COMMAND. - */ -typedef struct { - unsigned char *value; /* same as Property routines */ - Atom encoding; /* prop type */ - int format; /* prop data format: 8, 16, or 32 */ - unsigned long nitems; /* number of data items in value */ -} XTextProperty; - -#define XNoMemory -1 -#define XLocaleNotSupported -2 -#define XConverterNotFound -3 - -typedef enum { - XStringStyle, /* STRING */ - XCompoundTextStyle, /* COMPOUND_TEXT */ - XTextStyle, /* text in owner's encoding (current locale)*/ - XStdICCTextStyle, /* STRING, else COMPOUND_TEXT */ - /* The following is an XFree86 extension, introduced in November 2000 */ - XUTF8StringStyle /* UTF8_STRING */ -} XICCEncodingStyle; - -typedef struct { - int min_width, min_height; - int max_width, max_height; - int width_inc, height_inc; -} XIconSize; - -typedef struct { - char *res_name; - char *res_class; -} XClassHint; - -#ifdef XUTIL_DEFINE_FUNCTIONS -extern int XDestroyImage( - XImage *ximage); -extern unsigned long XGetPixel( - XImage *ximage, - int x, int y); -extern int XPutPixel( - XImage *ximage, - int x, int y, - unsigned long pixel); -extern XImage *XSubImage( - XImage *ximage, - int x, int y, - unsigned int width, unsigned int height); -extern int XAddPixel( - XImage *ximage, - long value); -#else -/* - * These macros are used to give some sugar to the image routines so that - * naive people are more comfortable with them. - */ -#define XDestroyImage(ximage) \ - ((*((ximage)->f.destroy_image))((ximage))) -#define XGetPixel(ximage, x, y) \ - ((*((ximage)->f.get_pixel))((ximage), (x), (y))) -#define XPutPixel(ximage, x, y, pixel) \ - ((*((ximage)->f.put_pixel))((ximage), (x), (y), (pixel))) -#define XSubImage(ximage, x, y, width, height) \ - ((*((ximage)->f.sub_image))((ximage), (x), (y), (width), (height))) -#define XAddPixel(ximage, value) \ - ((*((ximage)->f.add_pixel))((ximage), (value))) -#endif - -/* - * Compose sequence status structure, used in calling XLookupString. - */ -typedef struct _XComposeStatus { - XPointer compose_ptr; /* state table pointer */ - int chars_matched; /* match state */ -} XComposeStatus; - -/* - * Keysym macros, used on Keysyms to test for classes of symbols - */ -#define IsKeypadKey(keysym) \ - (((KeySym)(keysym) >= XK_KP_Space) && ((KeySym)(keysym) <= XK_KP_Equal)) - -#define IsPrivateKeypadKey(keysym) \ - (((KeySym)(keysym) >= 0x11000000) && ((KeySym)(keysym) <= 0x1100FFFF)) - -#define IsCursorKey(keysym) \ - (((KeySym)(keysym) >= XK_Home) && ((KeySym)(keysym) < XK_Select)) - -#define IsPFKey(keysym) \ - (((KeySym)(keysym) >= XK_KP_F1) && ((KeySym)(keysym) <= XK_KP_F4)) - -#define IsFunctionKey(keysym) \ - (((KeySym)(keysym) >= XK_F1) && ((KeySym)(keysym) <= XK_F35)) - -#define IsMiscFunctionKey(keysym) \ - (((KeySym)(keysym) >= XK_Select) && ((KeySym)(keysym) <= XK_Break)) - -#ifdef XK_XKB_KEYS -#define IsModifierKey(keysym) \ - ((((KeySym)(keysym) >= XK_Shift_L) && ((KeySym)(keysym) <= XK_Hyper_R)) \ - || (((KeySym)(keysym) >= XK_ISO_Lock) && \ - ((KeySym)(keysym) <= XK_ISO_Level5_Lock)) \ - || ((KeySym)(keysym) == XK_Mode_switch) \ - || ((KeySym)(keysym) == XK_Num_Lock)) -#else -#define IsModifierKey(keysym) \ - ((((KeySym)(keysym) >= XK_Shift_L) && ((KeySym)(keysym) <= XK_Hyper_R)) \ - || ((KeySym)(keysym) == XK_Mode_switch) \ - || ((KeySym)(keysym) == XK_Num_Lock)) -#endif -/* - * opaque reference to Region data type - */ -typedef struct _XRegion *Region; - -/* Return values from XRectInRegion() */ - -#define RectangleOut 0 -#define RectangleIn 1 -#define RectanglePart 2 - - -/* - * Information used by the visual utility routines to find desired visual - * type from the many visuals a display may support. - */ - -typedef struct { - Visual *visual; - VisualID visualid; - int screen; - int depth; -#if defined(__cplusplus) || defined(c_plusplus) - int c_class; /* C++ */ -#else - int class; -#endif - unsigned long red_mask; - unsigned long green_mask; - unsigned long blue_mask; - int colormap_size; - int bits_per_rgb; -} XVisualInfo; - -#define VisualNoMask 0x0 -#define VisualIDMask 0x1 -#define VisualScreenMask 0x2 -#define VisualDepthMask 0x4 -#define VisualClassMask 0x8 -#define VisualRedMaskMask 0x10 -#define VisualGreenMaskMask 0x20 -#define VisualBlueMaskMask 0x40 -#define VisualColormapSizeMask 0x80 -#define VisualBitsPerRGBMask 0x100 -#define VisualAllMask 0x1FF - -/* - * This defines a window manager property that clients may use to - * share standard color maps of type RGB_COLOR_MAP: - */ -typedef struct { - Colormap colormap; - unsigned long red_max; - unsigned long red_mult; - unsigned long green_max; - unsigned long green_mult; - unsigned long blue_max; - unsigned long blue_mult; - unsigned long base_pixel; - VisualID visualid; /* added by ICCCM version 1 */ - XID killid; /* added by ICCCM version 1 */ -} XStandardColormap; - -#define ReleaseByFreeingColormap ((XID) 1L) /* for killid field above */ - - -/* - * return codes for XReadBitmapFile and XWriteBitmapFile - */ -#define BitmapSuccess 0 -#define BitmapOpenFailed 1 -#define BitmapFileInvalid 2 -#define BitmapNoMemory 3 - -/**************************************************************** - * - * Context Management - * - ****************************************************************/ - - -/* Associative lookup table return codes */ - -#define XCSUCCESS 0 /* No error. */ -#define XCNOMEM 1 /* Out of memory */ -#define XCNOENT 2 /* No entry in table */ - -typedef int XContext; - -#define XUniqueContext() ((XContext) XrmUniqueQuark()) -#define XStringToContext(string) ((XContext) XrmStringToQuark(string)) - -_XFUNCPROTOBEGIN - -/* The following declarations are alphabetized. */ - -extern XClassHint *XAllocClassHint ( - void -); - -extern XIconSize *XAllocIconSize ( - void -); - -extern XSizeHints *XAllocSizeHints ( - void -); - -extern XStandardColormap *XAllocStandardColormap ( - void -); - -extern XWMHints *XAllocWMHints ( - void -); - -extern int XClipBox( - Region /* r */, - XRectangle* /* rect_return */ -); - -extern Region XCreateRegion( - void -); - -extern const char *XDefaultString (void); - -extern int XDeleteContext( - Display* /* display */, - XID /* rid */, - XContext /* context */ -); - -extern int XDestroyRegion( - Region /* r */ -); - -extern int XEmptyRegion( - Region /* r */ -); - -extern int XEqualRegion( - Region /* r1 */, - Region /* r2 */ -); - -extern int XFindContext( - Display* /* display */, - XID /* rid */, - XContext /* context */, - XPointer* /* data_return */ -); - -extern Status XGetClassHint( - Display* /* display */, - Window /* w */, - XClassHint* /* class_hints_return */ -); - -extern Status XGetIconSizes( - Display* /* display */, - Window /* w */, - XIconSize** /* size_list_return */, - int* /* count_return */ -); - -extern Status XGetNormalHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints_return */ -); - -extern Status XGetRGBColormaps( - Display* /* display */, - Window /* w */, - XStandardColormap** /* stdcmap_return */, - int* /* count_return */, - Atom /* property */ -); - -extern Status XGetSizeHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints_return */, - Atom /* property */ -); - -extern Status XGetStandardColormap( - Display* /* display */, - Window /* w */, - XStandardColormap* /* colormap_return */, - Atom /* property */ -); - -extern Status XGetTextProperty( - Display* /* display */, - Window /* window */, - XTextProperty* /* text_prop_return */, - Atom /* property */ -); - -extern XVisualInfo *XGetVisualInfo( - Display* /* display */, - long /* vinfo_mask */, - XVisualInfo* /* vinfo_template */, - int* /* nitems_return */ -); - -extern Status XGetWMClientMachine( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop_return */ -); - -extern XWMHints *XGetWMHints( - Display* /* display */, - Window /* w */ -); - -extern Status XGetWMIconName( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop_return */ -); - -extern Status XGetWMName( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop_return */ -); - -extern Status XGetWMNormalHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints_return */, - long* /* supplied_return */ -); - -extern Status XGetWMSizeHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints_return */, - long* /* supplied_return */, - Atom /* property */ -); - -extern Status XGetZoomHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* zhints_return */ -); - -extern int XIntersectRegion( - Region /* sra */, - Region /* srb */, - Region /* dr_return */ -); - -extern void XConvertCase( - KeySym /* sym */, - KeySym* /* lower */, - KeySym* /* upper */ -); - -extern int XLookupString( - XKeyEvent* /* event_struct */, - char* /* buffer_return */, - int /* bytes_buffer */, - KeySym* /* keysym_return */, - XComposeStatus* /* status_in_out */ -); - -extern Status XMatchVisualInfo( - Display* /* display */, - int /* screen */, - int /* depth */, - int /* class */, - XVisualInfo* /* vinfo_return */ -); - -extern int XOffsetRegion( - Region /* r */, - int /* dx */, - int /* dy */ -); - -extern Bool XPointInRegion( - Region /* r */, - int /* x */, - int /* y */ -); - -extern Region XPolygonRegion( - XPoint* /* points */, - int /* n */, - int /* fill_rule */ -); - -extern int XRectInRegion( - Region /* r */, - int /* x */, - int /* y */, - unsigned int /* width */, - unsigned int /* height */ -); - -extern int XSaveContext( - Display* /* display */, - XID /* rid */, - XContext /* context */, - _Xconst char* /* data */ -); - -extern int XSetClassHint( - Display* /* display */, - Window /* w */, - XClassHint* /* class_hints */ -); - -extern int XSetIconSizes( - Display* /* display */, - Window /* w */, - XIconSize* /* size_list */, - int /* count */ -); - -extern int XSetNormalHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints */ -); - -extern void XSetRGBColormaps( - Display* /* display */, - Window /* w */, - XStandardColormap* /* stdcmaps */, - int /* count */, - Atom /* property */ -); - -extern int XSetSizeHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints */, - Atom /* property */ -); - -extern int XSetStandardProperties( - Display* /* display */, - Window /* w */, - _Xconst char* /* window_name */, - _Xconst char* /* icon_name */, - Pixmap /* icon_pixmap */, - char** /* argv */, - int /* argc */, - XSizeHints* /* hints */ -); - -extern void XSetTextProperty( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop */, - Atom /* property */ -); - -extern void XSetWMClientMachine( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop */ -); - -extern int XSetWMHints( - Display* /* display */, - Window /* w */, - XWMHints* /* wm_hints */ -); - -extern void XSetWMIconName( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop */ -); - -extern void XSetWMName( - Display* /* display */, - Window /* w */, - XTextProperty* /* text_prop */ -); - -extern void XSetWMNormalHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints */ -); - -extern void XSetWMProperties( - Display* /* display */, - Window /* w */, - XTextProperty* /* window_name */, - XTextProperty* /* icon_name */, - char** /* argv */, - int /* argc */, - XSizeHints* /* normal_hints */, - XWMHints* /* wm_hints */, - XClassHint* /* class_hints */ -); - -extern void XmbSetWMProperties( - Display* /* display */, - Window /* w */, - _Xconst char* /* window_name */, - _Xconst char* /* icon_name */, - char** /* argv */, - int /* argc */, - XSizeHints* /* normal_hints */, - XWMHints* /* wm_hints */, - XClassHint* /* class_hints */ -); - -extern void Xutf8SetWMProperties( - Display* /* display */, - Window /* w */, - _Xconst char* /* window_name */, - _Xconst char* /* icon_name */, - char** /* argv */, - int /* argc */, - XSizeHints* /* normal_hints */, - XWMHints* /* wm_hints */, - XClassHint* /* class_hints */ -); - -extern void XSetWMSizeHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* hints */, - Atom /* property */ -); - -extern int XSetRegion( - Display* /* display */, - GC /* gc */, - Region /* r */ -); - -extern void XSetStandardColormap( - Display* /* display */, - Window /* w */, - XStandardColormap* /* colormap */, - Atom /* property */ -); - -extern int XSetZoomHints( - Display* /* display */, - Window /* w */, - XSizeHints* /* zhints */ -); - -extern int XShrinkRegion( - Region /* r */, - int /* dx */, - int /* dy */ -); - -extern Status XStringListToTextProperty( - char** /* list */, - int /* count */, - XTextProperty* /* text_prop_return */ -); - -extern int XSubtractRegion( - Region /* sra */, - Region /* srb */, - Region /* dr_return */ -); - -extern int XmbTextListToTextProperty( - Display* display, - char** list, - int count, - XICCEncodingStyle style, - XTextProperty* text_prop_return -); - -extern int XwcTextListToTextProperty( - Display* display, - wchar_t** list, - int count, - XICCEncodingStyle style, - XTextProperty* text_prop_return -); - -extern int Xutf8TextListToTextProperty( - Display* display, - char** list, - int count, - XICCEncodingStyle style, - XTextProperty* text_prop_return -); - -extern void XwcFreeStringList( - wchar_t** list -); - -extern Status XTextPropertyToStringList( - XTextProperty* /* text_prop */, - char*** /* list_return */, - int* /* count_return */ -); - -extern int XmbTextPropertyToTextList( - Display* display, - const XTextProperty* text_prop, - char*** list_return, - int* count_return -); - -extern int XwcTextPropertyToTextList( - Display* display, - const XTextProperty* text_prop, - wchar_t*** list_return, - int* count_return -); - -extern int Xutf8TextPropertyToTextList( - Display* display, - const XTextProperty* text_prop, - char*** list_return, - int* count_return -); - -extern int XUnionRectWithRegion( - XRectangle* /* rectangle */, - Region /* src_region */, - Region /* dest_region_return */ -); - -extern int XUnionRegion( - Region /* sra */, - Region /* srb */, - Region /* dr_return */ -); - -extern int XWMGeometry( - Display* /* display */, - int /* screen_number */, - _Xconst char* /* user_geometry */, - _Xconst char* /* default_geometry */, - unsigned int /* border_width */, - XSizeHints* /* hints */, - int* /* x_return */, - int* /* y_return */, - int* /* width_return */, - int* /* height_return */, - int* /* gravity_return */ -); - -extern int XXorRegion( - Region /* sra */, - Region /* srb */, - Region /* dr_return */ -); - -#ifdef __clang__ -#pragma clang diagnostic pop -#endif - -_XFUNCPROTOEND - -#endif /* _X11_XUTIL_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/cursorfont.h b/btgui/OpenGLWindow/optionalX11/X11/cursorfont.h deleted file mode 100644 index c69d508f4..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/cursorfont.h +++ /dev/null @@ -1,111 +0,0 @@ -/* - -Copyright 1987, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included -in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS -OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR -OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR -OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall -not be used in advertising or otherwise to promote the sale, use or -other dealings in this Software without prior written authorization -from The Open Group. - -*/ - -#ifndef _X11_CURSORFONT_H_ -#define _X11_CURSORFONT_H_ - -#define XC_num_glyphs 154 -#define XC_X_cursor 0 -#define XC_arrow 2 -#define XC_based_arrow_down 4 -#define XC_based_arrow_up 6 -#define XC_boat 8 -#define XC_bogosity 10 -#define XC_bottom_left_corner 12 -#define XC_bottom_right_corner 14 -#define XC_bottom_side 16 -#define XC_bottom_tee 18 -#define XC_box_spiral 20 -#define XC_center_ptr 22 -#define XC_circle 24 -#define XC_clock 26 -#define XC_coffee_mug 28 -#define XC_cross 30 -#define XC_cross_reverse 32 -#define XC_crosshair 34 -#define XC_diamond_cross 36 -#define XC_dot 38 -#define XC_dotbox 40 -#define XC_double_arrow 42 -#define XC_draft_large 44 -#define XC_draft_small 46 -#define XC_draped_box 48 -#define XC_exchange 50 -#define XC_fleur 52 -#define XC_gobbler 54 -#define XC_gumby 56 -#define XC_hand1 58 -#define XC_hand2 60 -#define XC_heart 62 -#define XC_icon 64 -#define XC_iron_cross 66 -#define XC_left_ptr 68 -#define XC_left_side 70 -#define XC_left_tee 72 -#define XC_leftbutton 74 -#define XC_ll_angle 76 -#define XC_lr_angle 78 -#define XC_man 80 -#define XC_middlebutton 82 -#define XC_mouse 84 -#define XC_pencil 86 -#define XC_pirate 88 -#define XC_plus 90 -#define XC_question_arrow 92 -#define XC_right_ptr 94 -#define XC_right_side 96 -#define XC_right_tee 98 -#define XC_rightbutton 100 -#define XC_rtl_logo 102 -#define XC_sailboat 104 -#define XC_sb_down_arrow 106 -#define XC_sb_h_double_arrow 108 -#define XC_sb_left_arrow 110 -#define XC_sb_right_arrow 112 -#define XC_sb_up_arrow 114 -#define XC_sb_v_double_arrow 116 -#define XC_shuttle 118 -#define XC_sizing 120 -#define XC_spider 122 -#define XC_spraycan 124 -#define XC_star 126 -#define XC_target 128 -#define XC_tcross 130 -#define XC_top_left_arrow 132 -#define XC_top_left_corner 134 -#define XC_top_right_corner 136 -#define XC_top_side 138 -#define XC_top_tee 140 -#define XC_trek 142 -#define XC_ul_angle 144 -#define XC_umbrella 146 -#define XC_ur_angle 148 -#define XC_watch 150 -#define XC_xterm 152 - -#endif /* _X11_CURSORFONT_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/XKB.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/XKB.h deleted file mode 100644 index ee4f74076..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/XKB.h +++ /dev/null @@ -1,786 +0,0 @@ -/************************************************************ -Copyright (c) 1993 by Silicon Graphics Computer Systems, Inc. - -Permission to use, copy, modify, and distribute this -software and its documentation for any purpose and without -fee is hereby granted, provided that the above copyright -notice appear in all copies and that both that copyright -notice and this permission notice appear in supporting -documentation, and that the name of Silicon Graphics not be -used in advertising or publicity pertaining to distribution -of the software without specific prior written permission. -Silicon Graphics makes no representation about the suitability -of this software for any purpose. It is provided "as is" -without any express or implied warranty. - -SILICON GRAPHICS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS -SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON -GRAPHICS BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL -DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, -DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE -OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH -THE USE OR PERFORMANCE OF THIS SOFTWARE. - -********************************************************/ - -#ifndef _XKB_H_ -#define _XKB_H_ - - /* - * XKB request codes, used in: - * - xkbReqType field of all requests - * - requestMinor field of some events - */ -#define X_kbUseExtension 0 -#define X_kbSelectEvents 1 -#define X_kbBell 3 -#define X_kbGetState 4 -#define X_kbLatchLockState 5 -#define X_kbGetControls 6 -#define X_kbSetControls 7 -#define X_kbGetMap 8 -#define X_kbSetMap 9 -#define X_kbGetCompatMap 10 -#define X_kbSetCompatMap 11 -#define X_kbGetIndicatorState 12 -#define X_kbGetIndicatorMap 13 -#define X_kbSetIndicatorMap 14 -#define X_kbGetNamedIndicator 15 -#define X_kbSetNamedIndicator 16 -#define X_kbGetNames 17 -#define X_kbSetNames 18 -#define X_kbGetGeometry 19 -#define X_kbSetGeometry 20 -#define X_kbPerClientFlags 21 -#define X_kbListComponents 22 -#define X_kbGetKbdByName 23 -#define X_kbGetDeviceInfo 24 -#define X_kbSetDeviceInfo 25 -#define X_kbSetDebuggingFlags 101 - - /* - * In the X sense, XKB reports only one event. - * The type field of all XKB events is XkbEventCode - */ -#define XkbEventCode 0 -#define XkbNumberEvents (XkbEventCode+1) - - /* - * XKB has a minor event code so it can use one X event code for - * multiple purposes. - * - reported in the xkbType field of all XKB events. - * - XkbSelectEventDetails: Indicates the event for which event details - * are being changed - */ -#define XkbNewKeyboardNotify 0 -#define XkbMapNotify 1 -#define XkbStateNotify 2 -#define XkbControlsNotify 3 -#define XkbIndicatorStateNotify 4 -#define XkbIndicatorMapNotify 5 -#define XkbNamesNotify 6 -#define XkbCompatMapNotify 7 -#define XkbBellNotify 8 -#define XkbActionMessage 9 -#define XkbAccessXNotify 10 -#define XkbExtensionDeviceNotify 11 - - /* - * Event Mask: - * - XkbSelectEvents: Specifies event interest. - */ -#define XkbNewKeyboardNotifyMask (1L << 0) -#define XkbMapNotifyMask (1L << 1) -#define XkbStateNotifyMask (1L << 2) -#define XkbControlsNotifyMask (1L << 3) -#define XkbIndicatorStateNotifyMask (1L << 4) -#define XkbIndicatorMapNotifyMask (1L << 5) -#define XkbNamesNotifyMask (1L << 6) -#define XkbCompatMapNotifyMask (1L << 7) -#define XkbBellNotifyMask (1L << 8) -#define XkbActionMessageMask (1L << 9) -#define XkbAccessXNotifyMask (1L << 10) -#define XkbExtensionDeviceNotifyMask (1L << 11) -#define XkbAllEventsMask (0xFFF) - - /* - * NewKeyboardNotify event details: - */ -#define XkbNKN_KeycodesMask (1L << 0) -#define XkbNKN_GeometryMask (1L << 1) -#define XkbNKN_DeviceIDMask (1L << 2) -#define XkbAllNewKeyboardEventsMask (0x7) - - /* - * AccessXNotify event types: - * - The 'what' field of AccessXNotify events reports the - * reason that the event was generated. - */ -#define XkbAXN_SKPress 0 -#define XkbAXN_SKAccept 1 -#define XkbAXN_SKReject 2 -#define XkbAXN_SKRelease 3 -#define XkbAXN_BKAccept 4 -#define XkbAXN_BKReject 5 -#define XkbAXN_AXKWarning 6 - - /* - * AccessXNotify details: - * - Used as an event detail mask to limit the conditions under which - * AccessXNotify events are reported - */ -#define XkbAXN_SKPressMask (1L << 0) -#define XkbAXN_SKAcceptMask (1L << 1) -#define XkbAXN_SKRejectMask (1L << 2) -#define XkbAXN_SKReleaseMask (1L << 3) -#define XkbAXN_BKAcceptMask (1L << 4) -#define XkbAXN_BKRejectMask (1L << 5) -#define XkbAXN_AXKWarningMask (1L << 6) -#define XkbAllAccessXEventsMask (0x7f) - - /* - * Miscellaneous event details: - * - event detail masks for assorted events that don't reall - * have any details. - */ -#define XkbAllStateEventsMask XkbAllStateComponentsMask -#define XkbAllMapEventsMask XkbAllMapComponentsMask -#define XkbAllControlEventsMask XkbAllControlsMask -#define XkbAllIndicatorEventsMask XkbAllIndicatorsMask -#define XkbAllNameEventsMask XkbAllNamesMask -#define XkbAllCompatMapEventsMask XkbAllCompatMask -#define XkbAllBellEventsMask (1L << 0) -#define XkbAllActionMessagesMask (1L << 0) - - /* - * XKB reports one error: BadKeyboard - * A further reason for the error is encoded into to most significant - * byte of the resourceID for the error: - * XkbErr_BadDevice - the device in question was not found - * XkbErr_BadClass - the device was found but it doesn't belong to - * the appropriate class. - * XkbErr_BadId - the device was found and belongs to the right - * class, but not feedback with a matching id was - * found. - * The low byte of the resourceID for this error contains the device - * id, class specifier or feedback id that failed. - */ -#define XkbKeyboard 0 -#define XkbNumberErrors 1 - -#define XkbErr_BadDevice 0xff -#define XkbErr_BadClass 0xfe -#define XkbErr_BadId 0xfd - - /* - * Keyboard Components Mask: - * - Specifies the components that follow a GetKeyboardByNameReply - */ -#define XkbClientMapMask (1L << 0) -#define XkbServerMapMask (1L << 1) -#define XkbCompatMapMask (1L << 2) -#define XkbIndicatorMapMask (1L << 3) -#define XkbNamesMask (1L << 4) -#define XkbGeometryMask (1L << 5) -#define XkbControlsMask (1L << 6) -#define XkbAllComponentsMask (0x7f) - - /* - * State detail mask: - * - The 'changed' field of StateNotify events reports which of - * the keyboard state components have changed. - * - Used as an event detail mask to limit the conditions under - * which StateNotify events are reported. - */ -#define XkbModifierStateMask (1L << 0) -#define XkbModifierBaseMask (1L << 1) -#define XkbModifierLatchMask (1L << 2) -#define XkbModifierLockMask (1L << 3) -#define XkbGroupStateMask (1L << 4) -#define XkbGroupBaseMask (1L << 5) -#define XkbGroupLatchMask (1L << 6) -#define XkbGroupLockMask (1L << 7) -#define XkbCompatStateMask (1L << 8) -#define XkbGrabModsMask (1L << 9) -#define XkbCompatGrabModsMask (1L << 10) -#define XkbLookupModsMask (1L << 11) -#define XkbCompatLookupModsMask (1L << 12) -#define XkbPointerButtonMask (1L << 13) -#define XkbAllStateComponentsMask (0x3fff) - - /* - * Controls detail masks: - * The controls specified in XkbAllControlsMask: - * - The 'changed' field of ControlsNotify events reports which of - * the keyboard controls have changed. - * - The 'changeControls' field of the SetControls request specifies - * the controls for which values are to be changed. - * - Used as an event detail mask to limit the conditions under - * which ControlsNotify events are reported. - * - * The controls specified in the XkbAllBooleanCtrlsMask: - * - The 'enabledControls' field of ControlsNotify events reports the - * current status of the boolean controls. - * - The 'enabledControlsChanges' field of ControlsNotify events reports - * any boolean controls that have been turned on or off. - * - The 'affectEnabledControls' and 'enabledControls' fields of the - * kbSetControls request change the set of enabled controls. - * - The 'accessXTimeoutMask' and 'accessXTimeoutValues' fields of - * an XkbControlsRec specify the controls to be changed if the keyboard - * times out and the values to which they should be changed. - * - The 'autoCtrls' and 'autoCtrlsValues' fields of the PerClientFlags - * request specifies the specify the controls to be reset when the - * client exits and the values to which they should be reset. - * - The 'ctrls' field of an indicator map specifies the controls - * that drive the indicator. - * - Specifies the boolean controls affected by the SetControls and - * LockControls key actions. - */ -#define XkbRepeatKeysMask (1L << 0) -#define XkbSlowKeysMask (1L << 1) -#define XkbBounceKeysMask (1L << 2) -#define XkbStickyKeysMask (1L << 3) -#define XkbMouseKeysMask (1L << 4) -#define XkbMouseKeysAccelMask (1L << 5) -#define XkbAccessXKeysMask (1L << 6) -#define XkbAccessXTimeoutMask (1L << 7) -#define XkbAccessXFeedbackMask (1L << 8) -#define XkbAudibleBellMask (1L << 9) -#define XkbOverlay1Mask (1L << 10) -#define XkbOverlay2Mask (1L << 11) -#define XkbIgnoreGroupLockMask (1L << 12) -#define XkbGroupsWrapMask (1L << 27) -#define XkbInternalModsMask (1L << 28) -#define XkbIgnoreLockModsMask (1L << 29) -#define XkbPerKeyRepeatMask (1L << 30) -#define XkbControlsEnabledMask (1L << 31) - -#define XkbAccessXOptionsMask (XkbStickyKeysMask|XkbAccessXFeedbackMask) - -#define XkbAllBooleanCtrlsMask (0x00001FFF) -#define XkbAllControlsMask (0xF8001FFF) -#define XkbAllControlEventsMask XkbAllControlsMask - - /* - * AccessX Options Mask - * - The 'accessXOptions' field of an XkbControlsRec specifies the - * AccessX options that are currently in effect. - * - The 'accessXTimeoutOptionsMask' and 'accessXTimeoutOptionsValues' - * fields of an XkbControlsRec specify the Access X options to be - * changed if the keyboard times out and the values to which they - * should be changed. - */ -#define XkbAX_SKPressFBMask (1L << 0) -#define XkbAX_SKAcceptFBMask (1L << 1) -#define XkbAX_FeatureFBMask (1L << 2) -#define XkbAX_SlowWarnFBMask (1L << 3) -#define XkbAX_IndicatorFBMask (1L << 4) -#define XkbAX_StickyKeysFBMask (1L << 5) -#define XkbAX_TwoKeysMask (1L << 6) -#define XkbAX_LatchToLockMask (1L << 7) -#define XkbAX_SKReleaseFBMask (1L << 8) -#define XkbAX_SKRejectFBMask (1L << 9) -#define XkbAX_BKRejectFBMask (1L << 10) -#define XkbAX_DumbBellFBMask (1L << 11) -#define XkbAX_FBOptionsMask (0xF3F) -#define XkbAX_SKOptionsMask (0x0C0) -#define XkbAX_AllOptionsMask (0xFFF) - - /* - * XkbUseCoreKbd is used to specify the core keyboard without having - * to look up its X input extension identifier. - * XkbUseCorePtr is used to specify the core pointer without having - * to look up its X input extension identifier. - * XkbDfltXIClass is used to specify "don't care" any place that the - * XKB protocol is looking for an X Input Extension - * device class. - * XkbDfltXIId is used to specify "don't care" any place that the - * XKB protocol is looking for an X Input Extension - * feedback identifier. - * XkbAllXIClasses is used to get information about all device indicators, - * whether they're part of the indicator feedback class - * or the keyboard feedback class. - * XkbAllXIIds is used to get information about all device indicator - * feedbacks without having to list them. - * XkbXINone is used to indicate that no class or id has been specified. - * XkbLegalXILedClass(c) True if 'c' specifies a legal class with LEDs - * XkbLegalXIBellClass(c) True if 'c' specifies a legal class with bells - * XkbExplicitXIDevice(d) True if 'd' explicitly specifies a device - * XkbExplicitXIClass(c) True if 'c' explicitly specifies a device class - * XkbExplicitXIId(c) True if 'i' explicitly specifies a device id - * XkbSingleXIClass(c) True if 'c' specifies exactly one device class, - * including the default. - * XkbSingleXIId(i) True if 'i' specifies exactly one device - * identifier, including the default. - */ -#define XkbUseCoreKbd 0x0100 -#define XkbUseCorePtr 0x0200 -#define XkbDfltXIClass 0x0300 -#define XkbDfltXIId 0x0400 -#define XkbAllXIClasses 0x0500 -#define XkbAllXIIds 0x0600 -#define XkbXINone 0xff00 - -#define XkbLegalXILedClass(c) (((c)==KbdFeedbackClass)||\ - ((c)==LedFeedbackClass)||\ - ((c)==XkbDfltXIClass)||\ - ((c)==XkbAllXIClasses)) -#define XkbLegalXIBellClass(c) (((c)==KbdFeedbackClass)||\ - ((c)==BellFeedbackClass)||\ - ((c)==XkbDfltXIClass)||\ - ((c)==XkbAllXIClasses)) -#define XkbExplicitXIDevice(c) (((c)&(~0xff))==0) -#define XkbExplicitXIClass(c) (((c)&(~0xff))==0) -#define XkbExplicitXIId(c) (((c)&(~0xff))==0) -#define XkbSingleXIClass(c) ((((c)&(~0xff))==0)||((c)==XkbDfltXIClass)) -#define XkbSingleXIId(c) ((((c)&(~0xff))==0)||((c)==XkbDfltXIId)) - -#define XkbNoModifier 0xff -#define XkbNoShiftLevel 0xff -#define XkbNoShape 0xff -#define XkbNoIndicator 0xff - -#define XkbNoModifierMask 0 -#define XkbAllModifiersMask 0xff -#define XkbAllVirtualModsMask 0xffff - -#define XkbNumKbdGroups 4 -#define XkbMaxKbdGroup (XkbNumKbdGroups-1) - -#define XkbMaxMouseKeysBtn 4 - - /* - * Group Index and Mask: - * - Indices into the kt_index array of a key type. - * - Mask specifies types to be changed for XkbChangeTypesOfKey - */ -#define XkbGroup1Index 0 -#define XkbGroup2Index 1 -#define XkbGroup3Index 2 -#define XkbGroup4Index 3 -#define XkbAnyGroup 254 -#define XkbAllGroups 255 - -#define XkbGroup1Mask (1<<0) -#define XkbGroup2Mask (1<<1) -#define XkbGroup3Mask (1<<2) -#define XkbGroup4Mask (1<<3) -#define XkbAnyGroupMask (1<<7) -#define XkbAllGroupsMask (0xf) - - /* - * BuildCoreState: Given a keyboard group and a modifier state, - * construct the value to be reported an event. - * GroupForCoreState: Given the state reported in an event, - * determine the keyboard group. - * IsLegalGroup: Returns TRUE if 'g' is a valid group index. - */ -#define XkbBuildCoreState(m,g) ((((g)&0x3)<<13)|((m)&0xff)) -#define XkbGroupForCoreState(s) (((s)>>13)&0x3) -#define XkbIsLegalGroup(g) (((g)>=0)&&((g)type>=Xkb_SASetMods)&&((a)->type<=XkbSA_LockMods)) -#define XkbIsGroupAction(a) (((a)->type>=XkbSA_SetGroup)&&((a)->type<=XkbSA_LockGroup)) -#define XkbIsPtrAction(a) (((a)->type>=XkbSA_MovePtr)&&((a)->type<=XkbSA_SetPtrDflt)) - - - /* - * Key Behavior Qualifier: - * KB_Permanent indicates that the behavior describes an unalterable - * characteristic of the keyboard, not an XKB software-simulation of - * the listed behavior. - * Key Behavior Types: - * Specifies the behavior of the underlying key. - */ -#define XkbKB_Permanent 0x80 -#define XkbKB_OpMask 0x7f - -#define XkbKB_Default 0x00 -#define XkbKB_Lock 0x01 -#define XkbKB_RadioGroup 0x02 -#define XkbKB_Overlay1 0x03 -#define XkbKB_Overlay2 0x04 - -#define XkbKB_RGAllowNone 0x80 - - /* - * Various macros which describe the range of legal keycodes. - */ -#define XkbMinLegalKeyCode 8 -#define XkbMaxLegalKeyCode 255 -#define XkbMaxKeyCount (XkbMaxLegalKeyCode-XkbMinLegalKeyCode+1) -#define XkbPerKeyBitArraySize ((XkbMaxLegalKeyCode+1)/8) -/* Seems kinda silly to check that an unsigned char is <= 255... */ -#define XkbIsLegalKeycode(k) ((k)>=XkbMinLegalKeyCode) - - /* - * Assorted constants and limits. - */ -#define XkbNumModifiers 8 -#define XkbNumVirtualMods 16 -#define XkbNumIndicators 32 -#define XkbAllIndicatorsMask (0xffffffff) -#define XkbMaxRadioGroups 32 -#define XkbAllRadioGroupsMask (0xffffffff) -#define XkbMaxShiftLevel 63 -#define XkbMaxSymsPerKey (XkbMaxShiftLevel*XkbNumKbdGroups) -#define XkbRGMaxMembers 12 -#define XkbActionMessageLength 6 -#define XkbKeyNameLength 4 -#define XkbMaxRedirectCount 8 - -#define XkbGeomPtsPerMM 10 -#define XkbGeomMaxColors 32 -#define XkbGeomMaxLabelColors 3 -#define XkbGeomMaxPriority 255 - - /* - * Key Type index and mask for the four standard key types. - */ -#define XkbOneLevelIndex 0 -#define XkbTwoLevelIndex 1 -#define XkbAlphabeticIndex 2 -#define XkbKeypadIndex 3 -#define XkbLastRequiredType XkbKeypadIndex -#define XkbNumRequiredTypes (XkbLastRequiredType+1) -#define XkbMaxKeyTypes 255 - -#define XkbOneLevelMask (1<<0) -#define XkbTwoLevelMask (1<<1) -#define XkbAlphabeticMask (1<<2) -#define XkbKeypadMask (1<<3) -#define XkbAllRequiredTypes (0xf) - -#define XkbShiftLevel(n) ((n)-1) -#define XkbShiftLevelMask(n) (1<<((n)-1)) - - /* - * Extension name and version information - */ -#define XkbName "XKEYBOARD" -#define XkbMajorVersion 1 -#define XkbMinorVersion 0 - - /* - * Explicit map components: - * - Used in the 'explicit' field of an XkbServerMap. Specifies - * the keyboard components that should _not_ be updated automatically - * in response to core protocol keyboard mapping requests. - */ -#define XkbExplicitKeyTypesMask (0x0f) -#define XkbExplicitKeyType1Mask (1<<0) -#define XkbExplicitKeyType2Mask (1<<1) -#define XkbExplicitKeyType3Mask (1<<2) -#define XkbExplicitKeyType4Mask (1<<3) -#define XkbExplicitInterpretMask (1<<4) -#define XkbExplicitAutoRepeatMask (1<<5) -#define XkbExplicitBehaviorMask (1<<6) -#define XkbExplicitVModMapMask (1<<7) -#define XkbAllExplicitMask (0xff) - - /* - * Map components masks: - * Those in AllMapComponentsMask: - * - Specifies the individual fields to be loaded or changed for the - * GetMap and SetMap requests. - * Those in ClientInfoMask: - * - Specifies the components to be allocated by XkbAllocClientMap. - * Those in ServerInfoMask: - * - Specifies the components to be allocated by XkbAllocServerMap. - */ -#define XkbKeyTypesMask (1<<0) -#define XkbKeySymsMask (1<<1) -#define XkbModifierMapMask (1<<2) -#define XkbExplicitComponentsMask (1<<3) -#define XkbKeyActionsMask (1<<4) -#define XkbKeyBehaviorsMask (1<<5) -#define XkbVirtualModsMask (1<<6) -#define XkbVirtualModMapMask (1<<7) - -#define XkbAllClientInfoMask (XkbKeyTypesMask|XkbKeySymsMask|XkbModifierMapMask) -#define XkbAllServerInfoMask (XkbExplicitComponentsMask|XkbKeyActionsMask|XkbKeyBehaviorsMask|XkbVirtualModsMask|XkbVirtualModMapMask) -#define XkbAllMapComponentsMask (XkbAllClientInfoMask|XkbAllServerInfoMask) - - /* - * Symbol interpretations flags: - * - Used in the flags field of a symbol interpretation - */ -#define XkbSI_AutoRepeat (1<<0) -#define XkbSI_LockingKey (1<<1) - - /* - * Symbol interpretations match specification: - * - Used in the match field of a symbol interpretation to specify - * the conditions under which an interpretation is used. - */ -#define XkbSI_LevelOneOnly (0x80) -#define XkbSI_OpMask (0x7f) -#define XkbSI_NoneOf (0) -#define XkbSI_AnyOfOrNone (1) -#define XkbSI_AnyOf (2) -#define XkbSI_AllOf (3) -#define XkbSI_Exactly (4) - - /* - * Indicator map flags: - * - Used in the flags field of an indicator map to indicate the - * conditions under which and indicator can be changed and the - * effects of changing the indicator. - */ -#define XkbIM_NoExplicit (1L << 7) -#define XkbIM_NoAutomatic (1L << 6) -#define XkbIM_LEDDrivesKB (1L << 5) - - /* - * Indicator map component specifications: - * - Used by the 'which_groups' and 'which_mods' fields of an indicator - * map to specify which keyboard components should be used to drive - * the indicator. - */ -#define XkbIM_UseBase (1L << 0) -#define XkbIM_UseLatched (1L << 1) -#define XkbIM_UseLocked (1L << 2) -#define XkbIM_UseEffective (1L << 3) -#define XkbIM_UseCompat (1L << 4) - -#define XkbIM_UseNone 0 -#define XkbIM_UseAnyGroup (XkbIM_UseBase|XkbIM_UseLatched|XkbIM_UseLocked\ - |XkbIM_UseEffective) -#define XkbIM_UseAnyMods (XkbIM_UseAnyGroup|XkbIM_UseCompat) - - /* - * Compatibility Map Compontents: - * - Specifies the components to be allocated in XkbAllocCompatMap. - */ -#define XkbSymInterpMask (1<<0) -#define XkbGroupCompatMask (1<<1) -#define XkbAllCompatMask (0x3) - - /* - * Names component mask: - * - Specifies the names to be loaded or changed for the GetNames and - * SetNames requests. - * - Specifies the names that have changed in a NamesNotify event. - * - Specifies the names components to be allocated by XkbAllocNames. - */ -#define XkbKeycodesNameMask (1<<0) -#define XkbGeometryNameMask (1<<1) -#define XkbSymbolsNameMask (1<<2) -#define XkbPhysSymbolsNameMask (1<<3) -#define XkbTypesNameMask (1<<4) -#define XkbCompatNameMask (1<<5) -#define XkbKeyTypeNamesMask (1<<6) -#define XkbKTLevelNamesMask (1<<7) -#define XkbIndicatorNamesMask (1<<8) -#define XkbKeyNamesMask (1<<9) -#define XkbKeyAliasesMask (1<<10) -#define XkbVirtualModNamesMask (1<<11) -#define XkbGroupNamesMask (1<<12) -#define XkbRGNamesMask (1<<13) -#define XkbComponentNamesMask (0x3f) -#define XkbAllNamesMask (0x3fff) - - /* - * GetByName components: - * - Specifies desired or necessary components to GetKbdByName request. - * - Reports the components that were found in a GetKbdByNameReply - */ -#define XkbGBN_TypesMask (1L << 0) -#define XkbGBN_CompatMapMask (1L << 1) -#define XkbGBN_ClientSymbolsMask (1L << 2) -#define XkbGBN_ServerSymbolsMask (1L << 3) -#define XkbGBN_SymbolsMask (XkbGBN_ClientSymbolsMask|XkbGBN_ServerSymbolsMask) -#define XkbGBN_IndicatorMapMask (1L << 4) -#define XkbGBN_KeyNamesMask (1L << 5) -#define XkbGBN_GeometryMask (1L << 6) -#define XkbGBN_OtherNamesMask (1L << 7) -#define XkbGBN_AllComponentsMask (0xff) - - /* - * ListComponents flags - */ -#define XkbLC_Hidden (1L << 0) -#define XkbLC_Default (1L << 1) -#define XkbLC_Partial (1L << 2) - -#define XkbLC_AlphanumericKeys (1L << 8) -#define XkbLC_ModifierKeys (1L << 9) -#define XkbLC_KeypadKeys (1L << 10) -#define XkbLC_FunctionKeys (1L << 11) -#define XkbLC_AlternateGroup (1L << 12) - - /* - * X Input Extension Interactions - * - Specifies the possible interactions between XKB and the X input - * extension - * - Used to request (XkbGetDeviceInfo) or change (XKbSetDeviceInfo) - * XKB information about an extension device. - * - Reports the list of supported optional features in the reply to - * XkbGetDeviceInfo or in an XkbExtensionDeviceNotify event. - * XkbXI_UnsupportedFeature is reported in XkbExtensionDeviceNotify - * events to indicate an attempt to use an unsupported feature. - */ -#define XkbXI_KeyboardsMask (1L << 0) -#define XkbXI_ButtonActionsMask (1L << 1) -#define XkbXI_IndicatorNamesMask (1L << 2) -#define XkbXI_IndicatorMapsMask (1L << 3) -#define XkbXI_IndicatorStateMask (1L << 4) -#define XkbXI_UnsupportedFeatureMask (1L << 15) -#define XkbXI_AllFeaturesMask (0x001f) -#define XkbXI_AllDeviceFeaturesMask (0x001e) - -#define XkbXI_IndicatorsMask (0x001c) -#define XkbAllExtensionDeviceEventsMask (0x801f) - - /* - * Per-Client Flags: - * - Specifies flags to be changed by the PerClientFlags request. - */ -#define XkbPCF_DetectableAutoRepeatMask (1L << 0) -#define XkbPCF_GrabsUseXKBStateMask (1L << 1) -#define XkbPCF_AutoResetControlsMask (1L << 2) -#define XkbPCF_LookupStateWhenGrabbed (1L << 3) -#define XkbPCF_SendEventUsesXKBState (1L << 4) -#define XkbPCF_AllFlagsMask (0x1F) - - /* - * Debugging flags and controls - */ -#define XkbDF_DisableLocks (1<<0) - -#endif /* _XKB_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/XKBstr.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/XKBstr.h deleted file mode 100644 index e519e657d..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/XKBstr.h +++ /dev/null @@ -1,613 +0,0 @@ -/************************************************************ -Copyright (c) 1993 by Silicon Graphics Computer Systems, Inc. - -Permission to use, copy, modify, and distribute this -software and its documentation for any purpose and without -fee is hereby granted, provided that the above copyright -notice appear in all copies and that both that copyright -notice and this permission notice appear in supporting -documentation, and that the name of Silicon Graphics not be -used in advertising or publicity pertaining to distribution -of the software without specific prior written permission. -Silicon Graphics makes no representation about the suitability -of this software for any purpose. It is provided "as is" -without any express or implied warranty. - -SILICON GRAPHICS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS -SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON -GRAPHICS BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL -DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, -DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE -OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH -THE USE OR PERFORMANCE OF THIS SOFTWARE. - -********************************************************/ - -#ifndef _XKBSTR_H_ -#define _XKBSTR_H_ - -#include - -#define XkbCharToInt(v) ((v)&0x80?(int)((v)|(~0xff)):(int)((v)&0x7f)) -#define XkbIntTo2Chars(i,h,l) (((h)=((i>>8)&0xff)),((l)=((i)&0xff))) - -#if defined(WORD64) && defined(UNSIGNEDBITFIELDS) -#define Xkb2CharsToInt(h,l) ((h)&0x80?(int)(((h)<<8)|(l)|(~0xffff)):\ - (int)(((h)<<8)|(l)&0x7fff)) -#else -#define Xkb2CharsToInt(h,l) ((short)(((h)<<8)|(l))) -#endif - - /* - * Common data structures and access macros - */ - -typedef struct _XkbStateRec { - unsigned char group; - unsigned char locked_group; - unsigned short base_group; - unsigned short latched_group; - unsigned char mods; - unsigned char base_mods; - unsigned char latched_mods; - unsigned char locked_mods; - unsigned char compat_state; - unsigned char grab_mods; - unsigned char compat_grab_mods; - unsigned char lookup_mods; - unsigned char compat_lookup_mods; - unsigned short ptr_buttons; -} XkbStateRec,*XkbStatePtr; -#define XkbModLocks(s) ((s)->locked_mods) -#define XkbStateMods(s) ((s)->base_mods|(s)->latched_mods|XkbModLocks(s)) -#define XkbGroupLock(s) ((s)->locked_group) -#define XkbStateGroup(s) ((s)->base_group+(s)->latched_group+XkbGroupLock(s)) -#define XkbStateFieldFromRec(s) XkbBuildCoreState((s)->lookup_mods,(s)->group) -#define XkbGrabStateFromRec(s) XkbBuildCoreState((s)->grab_mods,(s)->group) - -typedef struct _XkbMods { - unsigned char mask; /* effective mods */ - unsigned char real_mods; - unsigned short vmods; -} XkbModsRec,*XkbModsPtr; - -typedef struct _XkbKTMapEntry { - Bool active; - unsigned char level; - XkbModsRec mods; -} XkbKTMapEntryRec,*XkbKTMapEntryPtr; - -typedef struct _XkbKeyType { - XkbModsRec mods; - unsigned char num_levels; - unsigned char map_count; - XkbKTMapEntryPtr map; - XkbModsPtr preserve; - Atom name; - Atom * level_names; -} XkbKeyTypeRec, *XkbKeyTypePtr; - -#define XkbNumGroups(g) ((g)&0x0f) -#define XkbOutOfRangeGroupInfo(g) ((g)&0xf0) -#define XkbOutOfRangeGroupAction(g) ((g)&0xc0) -#define XkbOutOfRangeGroupNumber(g) (((g)&0x30)>>4) -#define XkbSetGroupInfo(g,w,n) (((w)&0xc0)|(((n)&3)<<4)|((g)&0x0f)) -#define XkbSetNumGroups(g,n) (((g)&0xf0)|((n)&0x0f)) - - /* - * Structures and access macros used primarily by the server - */ - -typedef struct _XkbBehavior { - unsigned char type; - unsigned char data; -} XkbBehavior; - -#define XkbAnyActionDataSize 7 -typedef struct _XkbAnyAction { - unsigned char type; - unsigned char data[XkbAnyActionDataSize]; -} XkbAnyAction; - -typedef struct _XkbModAction { - unsigned char type; - unsigned char flags; - unsigned char mask; - unsigned char real_mods; - unsigned char vmods1; - unsigned char vmods2; -} XkbModAction; -#define XkbModActionVMods(a) \ - ((short)(((a)->vmods1<<8)|((a)->vmods2))) -#define XkbSetModActionVMods(a,v) \ - (((a)->vmods1=(((v)>>8)&0xff)),(a)->vmods2=((v)&0xff)) - -typedef struct _XkbGroupAction { - unsigned char type; - unsigned char flags; - char group_XXX; -} XkbGroupAction; -#define XkbSAGroup(a) (XkbCharToInt((a)->group_XXX)) -#define XkbSASetGroup(a,g) ((a)->group_XXX=(g)) - -typedef struct _XkbISOAction { - unsigned char type; - unsigned char flags; - unsigned char mask; - unsigned char real_mods; - char group_XXX; - unsigned char affect; - unsigned char vmods1; - unsigned char vmods2; -} XkbISOAction; - -typedef struct _XkbPtrAction { - unsigned char type; - unsigned char flags; - unsigned char high_XXX; - unsigned char low_XXX; - unsigned char high_YYY; - unsigned char low_YYY; -} XkbPtrAction; -#define XkbPtrActionX(a) (Xkb2CharsToInt((a)->high_XXX,(a)->low_XXX)) -#define XkbPtrActionY(a) (Xkb2CharsToInt((a)->high_YYY,(a)->low_YYY)) -#define XkbSetPtrActionX(a,x) (XkbIntTo2Chars(x,(a)->high_XXX,(a)->low_XXX)) -#define XkbSetPtrActionY(a,y) (XkbIntTo2Chars(y,(a)->high_YYY,(a)->low_YYY)) - -typedef struct _XkbPtrBtnAction { - unsigned char type; - unsigned char flags; - unsigned char count; - unsigned char button; -} XkbPtrBtnAction; - -typedef struct _XkbPtrDfltAction { - unsigned char type; - unsigned char flags; - unsigned char affect; - char valueXXX; -} XkbPtrDfltAction; -#define XkbSAPtrDfltValue(a) (XkbCharToInt((a)->valueXXX)) -#define XkbSASetPtrDfltValue(a,c) ((a)->valueXXX= ((c)&0xff)) - -typedef struct _XkbSwitchScreenAction { - unsigned char type; - unsigned char flags; - char screenXXX; -} XkbSwitchScreenAction; -#define XkbSAScreen(a) (XkbCharToInt((a)->screenXXX)) -#define XkbSASetScreen(a,s) ((a)->screenXXX= ((s)&0xff)) - -typedef struct _XkbCtrlsAction { - unsigned char type; - unsigned char flags; - unsigned char ctrls3; - unsigned char ctrls2; - unsigned char ctrls1; - unsigned char ctrls0; -} XkbCtrlsAction; -#define XkbActionSetCtrls(a,c) (((a)->ctrls3=(((c)>>24)&0xff)),\ - ((a)->ctrls2=(((c)>>16)&0xff)),\ - ((a)->ctrls1=(((c)>>8)&0xff)),\ - ((a)->ctrls0=((c)&0xff))) -#define XkbActionCtrls(a) ((((unsigned int)(a)->ctrls3)<<24)|\ - (((unsigned int)(a)->ctrls2)<<16)|\ - (((unsigned int)(a)->ctrls1)<<8)|\ - ((unsigned int)((a)->ctrls0))) - -typedef struct _XkbMessageAction { - unsigned char type; - unsigned char flags; - unsigned char message[6]; -} XkbMessageAction; - -typedef struct _XkbRedirectKeyAction { - unsigned char type; - unsigned char new_key; - unsigned char mods_mask; - unsigned char mods; - unsigned char vmods_mask0; - unsigned char vmods_mask1; - unsigned char vmods0; - unsigned char vmods1; -} XkbRedirectKeyAction; - -#define XkbSARedirectVMods(a) ((((unsigned int)(a)->vmods1)<<8)|\ - ((unsigned int)(a)->vmods0)) -#define XkbSARedirectSetVMods(a,m) (((a)->vmods_mask1=(((m)>>8)&0xff)),\ - ((a)->vmods_mask0=((m)&0xff))) -#define XkbSARedirectVModsMask(a) ((((unsigned int)(a)->vmods_mask1)<<8)|\ - ((unsigned int)(a)->vmods_mask0)) -#define XkbSARedirectSetVModsMask(a,m) (((a)->vmods_mask1=(((m)>>8)&0xff)),\ - ((a)->vmods_mask0=((m)&0xff))) - -typedef struct _XkbDeviceBtnAction { - unsigned char type; - unsigned char flags; - unsigned char count; - unsigned char button; - unsigned char device; -} XkbDeviceBtnAction; - -typedef struct _XkbDeviceValuatorAction { - unsigned char type; - unsigned char device; - unsigned char v1_what; - unsigned char v1_ndx; - unsigned char v1_value; - unsigned char v2_what; - unsigned char v2_ndx; - unsigned char v2_value; -} XkbDeviceValuatorAction; - -typedef union _XkbAction { - XkbAnyAction any; - XkbModAction mods; - XkbGroupAction group; - XkbISOAction iso; - XkbPtrAction ptr; - XkbPtrBtnAction btn; - XkbPtrDfltAction dflt; - XkbSwitchScreenAction screen; - XkbCtrlsAction ctrls; - XkbMessageAction msg; - XkbRedirectKeyAction redirect; - XkbDeviceBtnAction devbtn; - XkbDeviceValuatorAction devval; - unsigned char type; -} XkbAction; - -typedef struct _XkbControls { - unsigned char mk_dflt_btn; - unsigned char num_groups; - unsigned char groups_wrap; - XkbModsRec internal; - XkbModsRec ignore_lock; - unsigned int enabled_ctrls; - unsigned short repeat_delay; - unsigned short repeat_interval; - unsigned short slow_keys_delay; - unsigned short debounce_delay; - unsigned short mk_delay; - unsigned short mk_interval; - unsigned short mk_time_to_max; - unsigned short mk_max_speed; - short mk_curve; - unsigned short ax_options; - unsigned short ax_timeout; - unsigned short axt_opts_mask; - unsigned short axt_opts_values; - unsigned int axt_ctrls_mask; - unsigned int axt_ctrls_values; - unsigned char per_key_repeat[XkbPerKeyBitArraySize]; -} XkbControlsRec, *XkbControlsPtr; - -#define XkbAX_AnyFeedback(c) ((c)->enabled_ctrls&XkbAccessXFeedbackMask) -#define XkbAX_NeedOption(c,w) ((c)->ax_options&(w)) -#define XkbAX_NeedFeedback(c,w) (XkbAX_AnyFeedback(c)&&XkbAX_NeedOption(c,w)) - -typedef struct _XkbServerMapRec { - unsigned short num_acts; - unsigned short size_acts; - XkbAction *acts; - - XkbBehavior *behaviors; - unsigned short *key_acts; -#if defined(__cplusplus) || defined(c_plusplus) - /* explicit is a C++ reserved word */ - unsigned char *c_explicit; -#else - unsigned char *explicit; -#endif - unsigned char vmods[XkbNumVirtualMods]; - unsigned short *vmodmap; -} XkbServerMapRec, *XkbServerMapPtr; - -#define XkbSMKeyActionsPtr(m,k) (&(m)->acts[(m)->key_acts[k]]) - - /* - * Structures and access macros used primarily by clients - */ - -typedef struct _XkbSymMapRec { - unsigned char kt_index[XkbNumKbdGroups]; - unsigned char group_info; - unsigned char width; - unsigned short offset; -} XkbSymMapRec, *XkbSymMapPtr; - -typedef struct _XkbClientMapRec { - unsigned char size_types; - unsigned char num_types; - XkbKeyTypePtr types; - - unsigned short size_syms; - unsigned short num_syms; - KeySym *syms; - XkbSymMapPtr key_sym_map; - - unsigned char *modmap; -} XkbClientMapRec, *XkbClientMapPtr; - -#define XkbCMKeyGroupInfo(m,k) ((m)->key_sym_map[k].group_info) -#define XkbCMKeyNumGroups(m,k) (XkbNumGroups((m)->key_sym_map[k].group_info)) -#define XkbCMKeyGroupWidth(m,k,g) (XkbCMKeyType(m,k,g)->num_levels) -#define XkbCMKeyGroupsWidth(m,k) ((m)->key_sym_map[k].width) -#define XkbCMKeyTypeIndex(m,k,g) ((m)->key_sym_map[k].kt_index[g&0x3]) -#define XkbCMKeyType(m,k,g) (&(m)->types[XkbCMKeyTypeIndex(m,k,g)]) -#define XkbCMKeyNumSyms(m,k) (XkbCMKeyGroupsWidth(m,k)*XkbCMKeyNumGroups(m,k)) -#define XkbCMKeySymsOffset(m,k) ((m)->key_sym_map[k].offset) -#define XkbCMKeySymsPtr(m,k) (&(m)->syms[XkbCMKeySymsOffset(m,k)]) - - /* - * Compatibility structures and access macros - */ - -typedef struct _XkbSymInterpretRec { - KeySym sym; - unsigned char flags; - unsigned char match; - unsigned char mods; - unsigned char virtual_mod; - XkbAnyAction act; -} XkbSymInterpretRec,*XkbSymInterpretPtr; - -typedef struct _XkbCompatMapRec { - XkbSymInterpretPtr sym_interpret; - XkbModsRec groups[XkbNumKbdGroups]; - unsigned short num_si; - unsigned short size_si; -} XkbCompatMapRec, *XkbCompatMapPtr; - -typedef struct _XkbIndicatorMapRec { - unsigned char flags; - unsigned char which_groups; - unsigned char groups; - unsigned char which_mods; - XkbModsRec mods; - unsigned int ctrls; -} XkbIndicatorMapRec, *XkbIndicatorMapPtr; - -#define XkbIM_IsAuto(i) ((((i)->flags&XkbIM_NoAutomatic)==0)&&\ - (((i)->which_groups&&(i)->groups)||\ - ((i)->which_mods&&(i)->mods.mask)||\ - ((i)->ctrls))) -#define XkbIM_InUse(i) (((i)->flags)||((i)->which_groups)||\ - ((i)->which_mods)||((i)->ctrls)) - - -typedef struct _XkbIndicatorRec { - unsigned long phys_indicators; - XkbIndicatorMapRec maps[XkbNumIndicators]; -} XkbIndicatorRec,*XkbIndicatorPtr; - -typedef struct _XkbKeyNameRec { - char name[XkbKeyNameLength]; -} XkbKeyNameRec,*XkbKeyNamePtr; - -typedef struct _XkbKeyAliasRec { - char real[XkbKeyNameLength]; - char alias[XkbKeyNameLength]; -} XkbKeyAliasRec,*XkbKeyAliasPtr; - - /* - * Names for everything - */ -typedef struct _XkbNamesRec { - Atom keycodes; - Atom geometry; - Atom symbols; - Atom types; - Atom compat; - Atom vmods[XkbNumVirtualMods]; - Atom indicators[XkbNumIndicators]; - Atom groups[XkbNumKbdGroups]; - XkbKeyNamePtr keys; - XkbKeyAliasPtr key_aliases; - Atom *radio_groups; - Atom phys_symbols; - - unsigned char num_keys; - unsigned char num_key_aliases; - unsigned short num_rg; -} XkbNamesRec,*XkbNamesPtr; - -typedef struct _XkbGeometry *XkbGeometryPtr; - /* - * Tie it all together into one big keyboard description - */ -typedef struct _XkbDesc { - struct _XDisplay * dpy; - unsigned short flags; - unsigned short device_spec; - KeyCode min_key_code; - KeyCode max_key_code; - - XkbControlsPtr ctrls; - XkbServerMapPtr server; - XkbClientMapPtr map; - XkbIndicatorPtr indicators; - XkbNamesPtr names; - XkbCompatMapPtr compat; - XkbGeometryPtr geom; -} XkbDescRec, *XkbDescPtr; -#define XkbKeyKeyTypeIndex(d,k,g) (XkbCMKeyTypeIndex((d)->map,k,g)) -#define XkbKeyKeyType(d,k,g) (XkbCMKeyType((d)->map,k,g)) -#define XkbKeyGroupWidth(d,k,g) (XkbCMKeyGroupWidth((d)->map,k,g)) -#define XkbKeyGroupsWidth(d,k) (XkbCMKeyGroupsWidth((d)->map,k)) -#define XkbKeyGroupInfo(d,k) (XkbCMKeyGroupInfo((d)->map,(k))) -#define XkbKeyNumGroups(d,k) (XkbCMKeyNumGroups((d)->map,(k))) -#define XkbKeyNumSyms(d,k) (XkbCMKeyNumSyms((d)->map,(k))) -#define XkbKeySymsPtr(d,k) (XkbCMKeySymsPtr((d)->map,(k))) -#define XkbKeySym(d,k,n) (XkbKeySymsPtr(d,k)[n]) -#define XkbKeySymEntry(d,k,sl,g) \ - (XkbKeySym(d,k,((XkbKeyGroupsWidth(d,k)*(g))+(sl)))) -#define XkbKeyAction(d,k,n) \ - (XkbKeyHasActions(d,k)?&XkbKeyActionsPtr(d,k)[n]:NULL) -#define XkbKeyActionEntry(d,k,sl,g) \ - (XkbKeyHasActions(d,k)?\ - XkbKeyAction(d,k,((XkbKeyGroupsWidth(d,k)*(g))+(sl))):NULL) - -#define XkbKeyHasActions(d,k) ((d)->server->key_acts[k]!=0) -#define XkbKeyNumActions(d,k) (XkbKeyHasActions(d,k)?XkbKeyNumSyms(d,k):1) -#define XkbKeyActionsPtr(d,k) (XkbSMKeyActionsPtr((d)->server,k)) -#define XkbKeycodeInRange(d,k) (((k)>=(d)->min_key_code)&&\ - ((k)<=(d)->max_key_code)) -#define XkbNumKeys(d) ((d)->max_key_code-(d)->min_key_code+1) - - - /* - * The following structures can be used to track changes - * to a keyboard device - */ -typedef struct _XkbMapChanges { - unsigned short changed; - KeyCode min_key_code; - KeyCode max_key_code; - unsigned char first_type; - unsigned char num_types; - KeyCode first_key_sym; - unsigned char num_key_syms; - KeyCode first_key_act; - unsigned char num_key_acts; - KeyCode first_key_behavior; - unsigned char num_key_behaviors; - KeyCode first_key_explicit; - unsigned char num_key_explicit; - KeyCode first_modmap_key; - unsigned char num_modmap_keys; - KeyCode first_vmodmap_key; - unsigned char num_vmodmap_keys; - unsigned char pad; - unsigned short vmods; -} XkbMapChangesRec,*XkbMapChangesPtr; - -typedef struct _XkbControlsChanges { - unsigned int changed_ctrls; - unsigned int enabled_ctrls_changes; - Bool num_groups_changed; -} XkbControlsChangesRec,*XkbControlsChangesPtr; - -typedef struct _XkbIndicatorChanges { - unsigned int state_changes; - unsigned int map_changes; -} XkbIndicatorChangesRec,*XkbIndicatorChangesPtr; - -typedef struct _XkbNameChanges { - unsigned int changed; - unsigned char first_type; - unsigned char num_types; - unsigned char first_lvl; - unsigned char num_lvls; - unsigned char num_aliases; - unsigned char num_rg; - unsigned char first_key; - unsigned char num_keys; - unsigned short changed_vmods; - unsigned long changed_indicators; - unsigned char changed_groups; -} XkbNameChangesRec,*XkbNameChangesPtr; - -typedef struct _XkbCompatChanges { - unsigned char changed_groups; - unsigned short first_si; - unsigned short num_si; -} XkbCompatChangesRec,*XkbCompatChangesPtr; - -typedef struct _XkbChanges { - unsigned short device_spec; - unsigned short state_changes; - XkbMapChangesRec map; - XkbControlsChangesRec ctrls; - XkbIndicatorChangesRec indicators; - XkbNameChangesRec names; - XkbCompatChangesRec compat; -} XkbChangesRec, *XkbChangesPtr; - - /* - * These data structures are used to construct a keymap from - * a set of components or to list components in the server - * database. - */ -typedef struct _XkbComponentNames { - char * keymap; - char * keycodes; - char * types; - char * compat; - char * symbols; - char * geometry; -} XkbComponentNamesRec, *XkbComponentNamesPtr; - -typedef struct _XkbComponentName { - unsigned short flags; - char * name; -} XkbComponentNameRec,*XkbComponentNamePtr; - -typedef struct _XkbComponentList { - int num_keymaps; - int num_keycodes; - int num_types; - int num_compat; - int num_symbols; - int num_geometry; - XkbComponentNamePtr keymaps; - XkbComponentNamePtr keycodes; - XkbComponentNamePtr types; - XkbComponentNamePtr compat; - XkbComponentNamePtr symbols; - XkbComponentNamePtr geometry; -} XkbComponentListRec, *XkbComponentListPtr; - - /* - * The following data structures describe and track changes to a - * non-keyboard extension device - */ -typedef struct _XkbDeviceLedInfo { - unsigned short led_class; - unsigned short led_id; - unsigned int phys_indicators; - unsigned int maps_present; - unsigned int names_present; - unsigned int state; - Atom names[XkbNumIndicators]; - XkbIndicatorMapRec maps[XkbNumIndicators]; -} XkbDeviceLedInfoRec,*XkbDeviceLedInfoPtr; - -typedef struct _XkbDeviceInfo { - char * name; - Atom type; - unsigned short device_spec; - Bool has_own_state; - unsigned short supported; - unsigned short unsupported; - - unsigned short num_btns; - XkbAction * btn_acts; - - unsigned short sz_leds; - unsigned short num_leds; - unsigned short dflt_kbd_fb; - unsigned short dflt_led_fb; - XkbDeviceLedInfoPtr leds; -} XkbDeviceInfoRec,*XkbDeviceInfoPtr; - -#define XkbXI_DevHasBtnActs(d) (((d)->num_btns>0)&&((d)->btn_acts!=NULL)) -#define XkbXI_LegalDevBtn(d,b) (XkbXI_DevHasBtnActs(d)&&((b)<(d)->num_btns)) -#define XkbXI_DevHasLeds(d) (((d)->num_leds>0)&&((d)->leds!=NULL)) - -typedef struct _XkbDeviceLedChanges { - unsigned short led_class; - unsigned short led_id; - unsigned int defined; /* names or maps changed */ - struct _XkbDeviceLedChanges *next; -} XkbDeviceLedChangesRec,*XkbDeviceLedChangesPtr; - -typedef struct _XkbDeviceChanges { - unsigned int changed; - unsigned short first_btn; - unsigned short num_btns; - XkbDeviceLedChangesRec leds; -} XkbDeviceChangesRec,*XkbDeviceChangesPtr; - -#endif /* _XKBSTR_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/XShm.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/XShm.h deleted file mode 100644 index 23f065115..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/XShm.h +++ /dev/null @@ -1,135 +0,0 @@ -/************************************************************ - -Copyright 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - -********************************************************/ - -/* THIS IS NOT AN X CONSORTIUM STANDARD OR AN X PROJECT TEAM SPECIFICATION */ - -#ifndef _XSHM_H_ -#define _XSHM_H_ - -#include -#include - -#ifndef _XSHM_SERVER_ -typedef unsigned long ShmSeg; - -typedef struct { - int type; /* of event */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came frome a SendEvent request */ - Display *display; /* Display the event was read from */ - Drawable drawable; /* drawable of request */ - int major_code; /* ShmReqCode */ - int minor_code; /* X_ShmPutImage */ - ShmSeg shmseg; /* the ShmSeg used in the request */ - unsigned long offset; /* the offset into ShmSeg used in the request */ -} XShmCompletionEvent; - -typedef struct { - ShmSeg shmseg; /* resource id */ - int shmid; /* kernel id */ - char *shmaddr; /* address in client */ - Bool readOnly; /* how the server should attach it */ -} XShmSegmentInfo; - -_XFUNCPROTOBEGIN - -Bool XShmQueryExtension( - Display* /* dpy */ -); - -int XShmGetEventBase( - Display* /* dpy */ -); - -Bool XShmQueryVersion( - Display* /* dpy */, - int* /* majorVersion */, - int* /* minorVersion */, - Bool* /* sharedPixmaps */ -); - -int XShmPixmapFormat( - Display* /* dpy */ -); - -Bool XShmAttach( - Display* /* dpy */, - XShmSegmentInfo* /* shminfo */ -); - -Bool XShmDetach( - Display* /* dpy */, - XShmSegmentInfo* /* shminfo */ -); - -Bool XShmPutImage( - Display* /* dpy */, - Drawable /* d */, - GC /* gc */, - XImage* /* image */, - int /* src_x */, - int /* src_y */, - int /* dst_x */, - int /* dst_y */, - unsigned int /* src_width */, - unsigned int /* src_height */, - Bool /* send_event */ -); - -Bool XShmGetImage( - Display* /* dpy */, - Drawable /* d */, - XImage* /* image */, - int /* x */, - int /* y */, - unsigned long /* plane_mask */ -); - -XImage *XShmCreateImage( - Display* /* dpy */, - Visual* /* visual */, - unsigned int /* depth */, - int /* format */, - char* /* data */, - XShmSegmentInfo* /* shminfo */, - unsigned int /* width */, - unsigned int /* height */ -); - -Pixmap XShmCreatePixmap( - Display* /* dpy */, - Drawable /* d */, - char* /* data */, - XShmSegmentInfo* /* shminfo */, - unsigned int /* width */, - unsigned int /* height */, - unsigned int /* depth */ -); - -_XFUNCPROTOEND -#endif /* _XSHM_SERVER_ */ - -#endif diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/Xext.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/Xext.h deleted file mode 100644 index 858592b78..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/Xext.h +++ /dev/null @@ -1,53 +0,0 @@ -/* - * -Copyright 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - */ - -#ifndef _XEXT_H_ -#define _XEXT_H_ - -#include - -_XFUNCPROTOBEGIN - -typedef int (*XextErrorHandler) ( - Display * /* dpy */, - _Xconst char* /* ext_name */, - _Xconst char* /* reason */ -); - -extern XextErrorHandler XSetExtensionErrorHandler( - XextErrorHandler /* handler */ -); - -extern int XMissingExtension( - Display* /* dpy */, - _Xconst char* /* ext_name */ -); - -_XFUNCPROTOEND - -#define X_EXTENSION_UNKNOWN "unknown" -#define X_EXTENSION_MISSING "missing" - -#endif /* _XEXT_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/extutil.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/extutil.h deleted file mode 100644 index 29404d5ae..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/extutil.h +++ /dev/null @@ -1,190 +0,0 @@ -/* - * -Copyright 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - * - * Author: Jim Fulton, MIT The Open Group - * - * Xlib Extension-Writing Utilities - * - * This package contains utilities for writing the client API for various - * protocol extensions. THESE INTERFACES ARE NOT PART OF THE X STANDARD AND - * ARE SUBJECT TO CHANGE! - */ - -#ifndef _EXTUTIL_H_ -#define _EXTUTIL_H_ - -#include - -/* - * We need to keep a list of open displays since the Xlib display list isn't - * public. We also have to per-display info in a separate block since it isn't - * stored directly in the Display structure. - */ -typedef struct _XExtDisplayInfo { - struct _XExtDisplayInfo *next; /* keep a linked list */ - Display *display; /* which display this is */ - XExtCodes *codes; /* the extension protocol codes */ - XPointer data; /* extra data for extension to use */ -} XExtDisplayInfo; - -typedef struct _XExtensionInfo { - XExtDisplayInfo *head; /* start of list */ - XExtDisplayInfo *cur; /* most recently used */ - int ndisplays; /* number of displays */ -} XExtensionInfo; - -typedef struct _XExtensionHooks { - int (*create_gc)( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - int (*copy_gc)( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - int (*flush_gc)( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - int (*free_gc)( - Display* /* display */, - GC /* gc */, - XExtCodes* /* codes */ -); - int (*create_font)( - Display* /* display */, - XFontStruct* /* fs */, - XExtCodes* /* codes */ -); - int (*free_font)( - Display* /* display */, - XFontStruct* /* fs */, - XExtCodes* /* codes */ -); - int (*close_display)( - Display* /* display */, - XExtCodes* /* codes */ -); - Bool (*wire_to_event)( - Display* /* display */, - XEvent* /* re */, - xEvent* /* event */ -); - Status (*event_to_wire)( - Display* /* display */, - XEvent* /* re */, - xEvent* /* event */ -); - int (*error)( - Display* /* display */, - xError* /* err */, - XExtCodes* /* codes */, - int* /* ret_code */ -); - char *(*error_string)( - Display* /* display */, - int /* code */, - XExtCodes* /* codes */, - char* /* buffer */, - int /* nbytes */ -); -} XExtensionHooks; - -extern XExtensionInfo *XextCreateExtension( - void -); -extern void XextDestroyExtension( - XExtensionInfo* /* info */ -); -extern XExtDisplayInfo *XextAddDisplay( - XExtensionInfo* /* extinfo */, - Display* /* dpy */, - _Xconst char* /* ext_name */, - XExtensionHooks* /* hooks */, - int /* nevents */, - XPointer /* data */ -); -extern int XextRemoveDisplay( - XExtensionInfo* /* extinfo */, - Display* /* dpy */ -); -extern XExtDisplayInfo *XextFindDisplay( - XExtensionInfo* /* extinfo */, - Display* /* dpy */ -); - -#define XextHasExtension(i) ((i) && ((i)->codes)) -#define XextCheckExtension(dpy,i,name,val) \ - if (!XextHasExtension(i)) { XMissingExtension (dpy, name); return val; } -#define XextSimpleCheckExtension(dpy,i,name) \ - if (!XextHasExtension(i)) { XMissingExtension (dpy, name); return; } - - -/* - * helper macros to generate code that is common to all extensions; caller - * should prefix it with static if extension source is in one file; this - * could be a utility function, but have to stack 6 unused arguments for - * something that is called many, many times would be bad. - */ -#define XEXT_GENERATE_FIND_DISPLAY(proc,extinfo,extname,hooks,nev,data) \ -XExtDisplayInfo *proc (Display *dpy) \ -{ \ - XExtDisplayInfo *dpyinfo; \ - if (!extinfo) { if (!(extinfo = XextCreateExtension())) return NULL; } \ - if (!(dpyinfo = XextFindDisplay (extinfo, dpy))) \ - dpyinfo = XextAddDisplay (extinfo,dpy,extname,hooks,nev,data); \ - return dpyinfo; \ -} - -#define XEXT_FIND_DISPLAY_PROTO(proc) \ - XExtDisplayInfo *proc(Display *dpy) - -#define XEXT_GENERATE_CLOSE_DISPLAY(proc,extinfo) \ -int proc (Display *dpy, XExtCodes *codes) \ -{ \ - return XextRemoveDisplay (extinfo, dpy); \ -} - -#define XEXT_CLOSE_DISPLAY_PROTO(proc) \ - int proc(Display *dpy, XExtCodes *codes) - -#define XEXT_GENERATE_ERROR_STRING(proc,extname,nerr,errl) \ -char *proc (Display *dpy, int code, XExtCodes *codes, char *buf, int n) \ -{ \ - code -= codes->first_error; \ - if (code >= 0 && code < nerr) { \ - char tmp[256]; \ - sprintf (tmp, "%s.%d", extname, code); \ - XGetErrorDatabaseText (dpy, "XProtoError", tmp, errl[code], buf, n); \ - return buf; \ - } \ - return (char *)0; \ -} - -#define XEXT_ERROR_STRING_PROTO(proc) \ - char *proc(Display *dpy, int code, XExtCodes *codes, char *buf, int n) -#endif diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/shape.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/shape.h deleted file mode 100644 index 66af5b1b4..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/shape.h +++ /dev/null @@ -1,152 +0,0 @@ -/************************************************************ - -Copyright 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - -********************************************************/ - -#ifndef _SHAPE_H_ -#define _SHAPE_H_ - -#include -#include - -#ifndef _SHAPE_SERVER_ -#include - -typedef struct { - int type; /* of event */ - unsigned long serial; /* # of last request processed by server */ - Bool send_event; /* true if this came frome a SendEvent request */ - Display *display; /* Display the event was read from */ - Window window; /* window of event */ - int kind; /* ShapeBounding or ShapeClip */ - int x, y; /* extents of new region */ - unsigned width, height; - Time time; /* server timestamp when region changed */ - Bool shaped; /* true if the region exists */ -} XShapeEvent; - -_XFUNCPROTOBEGIN - -extern Bool XShapeQueryExtension ( - Display* /* display */, - int* /* event_base */, - int* /* error_base */ -); - -extern Status XShapeQueryVersion ( - Display* /* display */, - int* /* major_version */, - int* /* minor_version */ -); - -extern void XShapeCombineRegion ( - Display* /* display */, - Window /* dest */, - int /* dest_kind */, - int /* x_off */, - int /* y_off */, - Region /* region */, - int /* op */ -); - -extern void XShapeCombineRectangles ( - Display* /* display */, - Window /* dest */, - int /* dest_kind */, - int /* x_off */, - int /* y_off */, - XRectangle* /* rectangles */, - int /* n_rects */, - int /* op */, - int /* ordering */ -); - -extern void XShapeCombineMask ( - Display* /* display */, - Window /* dest */, - int /* dest_kind */, - int /* x_off */, - int /* y_off */, - Pixmap /* src */, - int /* op */ -); - -extern void XShapeCombineShape ( - Display* /* display */, - Window /* dest */, - int /* dest_kind */, - int /* x_off */, - int /* y_off */, - Window /* src */, - int /* src_kind */, - int /* op */ -); - -extern void XShapeOffsetShape ( - Display* /* display */, - Window /* dest */, - int /* dest_kind */, - int /* x_off */, - int /* y_off */ -); - -extern Status XShapeQueryExtents ( - Display* /* display */, - Window /* window */, - Bool* /* bounding_shaped */, - int* /* x_bounding */, - int* /* y_bounding */, - unsigned int* /* w_bounding */, - unsigned int* /* h_bounding */, - Bool* /* clip_shaped */, - int* /* x_clip */, - int* /* y_clip */, - unsigned int* /* w_clip */, - unsigned int* /* h_clip */ -); - -extern void XShapeSelectInput ( - Display* /* display */, - Window /* window */, - unsigned long /* mask */ -); - -extern unsigned long XShapeInputSelected ( - Display* /* display */, - Window /* window */ -); - -extern XRectangle *XShapeGetRectangles ( - Display* /* display */, - Window /* window */, - int /* kind */, - int* /* count */, - int* /* ordering */ -); - -_XFUNCPROTOEND - -#endif /* !_SHAPE_SERVER_ */ - -#endif /* _SHAPE_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/shapeconst.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/shapeconst.h deleted file mode 100644 index 9088956f1..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/shapeconst.h +++ /dev/null @@ -1,55 +0,0 @@ -/************************************************************ - -Copyright 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - -********************************************************/ - -#ifndef _SHAPECONST_H_ -#define _SHAPECONST_H_ - -/* - * Protocol requests constants and alignment values - * These would really be in SHAPE's X.h and Xproto.h equivalents - */ - -#define SHAPENAME "SHAPE" - -#define SHAPE_MAJOR_VERSION 1 /* current version numbers */ -#define SHAPE_MINOR_VERSION 1 - -#define ShapeSet 0 -#define ShapeUnion 1 -#define ShapeIntersect 2 -#define ShapeSubtract 3 -#define ShapeInvert 4 - -#define ShapeBounding 0 -#define ShapeClip 1 -#define ShapeInput 2 - -#define ShapeNotifyMask (1L << 0) -#define ShapeNotify 0 - -#define ShapeNumberEvents (ShapeNotify + 1) - -#endif /* _SHAPECONST_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/extensions/shm.h b/btgui/OpenGLWindow/optionalX11/X11/extensions/shm.h deleted file mode 100644 index be49f5e97..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/extensions/shm.h +++ /dev/null @@ -1,44 +0,0 @@ -/************************************************************ - -Copyright 1989, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - -********************************************************/ - -/* THIS IS NOT AN X CONSORTIUM STANDARD OR AN X PROJECT TEAM SPECIFICATION */ - -#ifndef _SHM_H_ -#define _SHM_H_ - -#define SHMNAME "MIT-SHM" - -#define SHM_MAJOR_VERSION 1 /* current version numbers */ -#define SHM_MINOR_VERSION 2 - -#define ShmCompletion 0 -#define ShmNumberEvents (ShmCompletion + 1) - -#define BadShmSeg 0 -#define ShmNumberErrors (BadShmSeg + 1) - - -#endif /* _SHM_H_ */ diff --git a/btgui/OpenGLWindow/optionalX11/X11/keysym.h b/btgui/OpenGLWindow/optionalX11/X11/keysym.h deleted file mode 100644 index 4f584886c..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/keysym.h +++ /dev/null @@ -1,74 +0,0 @@ -/*********************************************************** - -Copyright 1987, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - - -Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, -provided that the above copyright notice appear in all copies and that -both that copyright notice and this permission notice appear in -supporting documentation, and that the name of Digital not be -used in advertising or publicity pertaining to distribution of the -software without specific, written prior permission. - -DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING -ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL -DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR -ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, -WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, -ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS -SOFTWARE. - -******************************************************************/ - -/* default keysyms */ -#define XK_MISCELLANY -#define XK_XKB_KEYS -#define XK_LATIN1 -#define XK_LATIN2 -#define XK_LATIN3 -#define XK_LATIN4 -#define XK_LATIN8 -#define XK_LATIN9 -#define XK_CAUCASUS -#define XK_GREEK -#define XK_KATAKANA -#define XK_ARABIC -#define XK_CYRILLIC -#define XK_HEBREW -#define XK_THAI -#define XK_KOREAN -#define XK_ARMENIAN -#define XK_GEORGIAN -#define XK_VIETNAMESE -#define XK_CURRENCY -#define XK_MATHEMATICAL -#define XK_BRAILLE -#define XK_SINHALA - -#include - diff --git a/btgui/OpenGLWindow/optionalX11/X11/keysymdef.h b/btgui/OpenGLWindow/optionalX11/X11/keysymdef.h deleted file mode 100644 index ae73977cb..000000000 --- a/btgui/OpenGLWindow/optionalX11/X11/keysymdef.h +++ /dev/null @@ -1,2491 +0,0 @@ -/*********************************************************** -Copyright 1987, 1994, 1998 The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included -in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS -OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -IN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR -OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR -OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall -not be used in advertising or otherwise to promote the sale, use or -other dealings in this Software without prior written authorization -from The Open Group. - - -Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, -provided that the above copyright notice appear in all copies and that -both that copyright notice and this permission notice appear in -supporting documentation, and that the name of Digital not be -used in advertising or publicity pertaining to distribution of the -software without specific, written prior permission. - -DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING -ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL -DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR -ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, -WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, -ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS -SOFTWARE. - -******************************************************************/ - -/* - * The "X11 Window System Protocol" standard defines in Appendix A the - * keysym codes. These 29-bit integer values identify characters or - * functions associated with each key (e.g., via the visible - * engraving) of a keyboard layout. This file assigns mnemonic macro - * names for these keysyms. - * - * This file is also compiled (by src/util/makekeys.c in libX11) into - * hash tables that can be accessed with X11 library functions such as - * XStringToKeysym() and XKeysymToString(). - * - * Where a keysym corresponds one-to-one to an ISO 10646 / Unicode - * character, this is noted in a comment that provides both the U+xxxx - * Unicode position, as well as the official Unicode name of the - * character. - * - * Where the correspondence is either not one-to-one or semantically - * unclear, the Unicode position and name are enclosed in - * parentheses. Such legacy keysyms should be considered deprecated - * and are not recommended for use in future keyboard mappings. - * - * For any future extension of the keysyms with characters already - * found in ISO 10646 / Unicode, the following algorithm shall be - * used. The new keysym code position will simply be the character's - * Unicode number plus 0x01000000. The keysym values in the range - * 0x01000100 to 0x0110ffff are reserved to represent Unicode - * characters in the range U+0100 to U+10FFFF. - * - * While most newer Unicode-based X11 clients do already accept - * Unicode-mapped keysyms in the range 0x01000100 to 0x0110ffff, it - * will remain necessary for clients -- in the interest of - * compatibility with existing servers -- to also understand the - * existing legacy keysym values in the range 0x0100 to 0x20ff. - * - * Where several mnemonic names are defined for the same keysym in this - * file, all but the first one listed should be considered deprecated. - * - * Mnemonic names for keysyms are defined in this file with lines - * that match one of these Perl regular expressions: - * - * /^\#define XK_([a-zA-Z_0-9]+)\s+0x([0-9a-f]+)\s*\/\* U+([0-9A-F]{4,6}) (.*) \*\/\s*$/ - * /^\#define XK_([a-zA-Z_0-9]+)\s+0x([0-9a-f]+)\s*\/\*\(U+([0-9A-F]{4,6}) (.*)\)\*\/\s*$/ - * /^\#define XK_([a-zA-Z_0-9]+)\s+0x([0-9a-f]+)\s*(\/\*\s*(.*)\s*\*\/)?\s*$/ - * - * Before adding new keysyms, please do consider the following: In - * addition to the keysym names defined in this file, the - * XStringToKeysym() and XKeysymToString() functions will also handle - * any keysym string of the form "U0020" to "U007E" and "U00A0" to - * "U10FFFF" for all possible Unicode characters. In other words, - * every possible Unicode character has already a keysym string - * defined algorithmically, even if it is not listed here. Therefore, - * defining an additional keysym macro is only necessary where a - * non-hexadecimal mnemonic name is needed, or where the new keysym - * does not represent any existing Unicode character. - * - * When adding new keysyms to this file, do not forget to also update the - * following as needed: - * - * - the mappings in src/KeyBind.c in the repo - * git://anongit.freedesktop.org/xorg/lib/libX11.git - * - * - the protocol specification in specs/keysyms.xml - * in the repo git://anongit.freedesktop.org/xorg/proto/x11proto.git - * - */ - -#define XK_VoidSymbol 0xffffff /* Void symbol */ - -#ifdef XK_MISCELLANY -/* - * TTY function keys, cleverly chosen to map to ASCII, for convenience of - * programming, but could have been arbitrary (at the cost of lookup - * tables in client code). - */ - -#define XK_BackSpace 0xff08 /* Back space, back char */ -#define XK_Tab 0xff09 -#define XK_Linefeed 0xff0a /* Linefeed, LF */ -#define XK_Clear 0xff0b -#define XK_Return 0xff0d /* Return, enter */ -#define XK_Pause 0xff13 /* Pause, hold */ -#define XK_Scroll_Lock 0xff14 -#define XK_Sys_Req 0xff15 -#define XK_Escape 0xff1b -#define XK_Delete 0xffff /* Delete, rubout */ - - - -/* International & multi-key character composition */ - -#define XK_Multi_key 0xff20 /* Multi-key character compose */ -#define XK_Codeinput 0xff37 -#define XK_SingleCandidate 0xff3c -#define XK_MultipleCandidate 0xff3d -#define XK_PreviousCandidate 0xff3e - -/* Japanese keyboard support */ - -#define XK_Kanji 0xff21 /* Kanji, Kanji convert */ -#define XK_Muhenkan 0xff22 /* Cancel Conversion */ -#define XK_Henkan_Mode 0xff23 /* Start/Stop Conversion */ -#define XK_Henkan 0xff23 /* Alias for Henkan_Mode */ -#define XK_Romaji 0xff24 /* to Romaji */ -#define XK_Hiragana 0xff25 /* to Hiragana */ -#define XK_Katakana 0xff26 /* to Katakana */ -#define XK_Hiragana_Katakana 0xff27 /* Hiragana/Katakana toggle */ -#define XK_Zenkaku 0xff28 /* to Zenkaku */ -#define XK_Hankaku 0xff29 /* to Hankaku */ -#define XK_Zenkaku_Hankaku 0xff2a /* Zenkaku/Hankaku toggle */ -#define XK_Touroku 0xff2b /* Add to Dictionary */ -#define XK_Massyo 0xff2c /* Delete from Dictionary */ -#define XK_Kana_Lock 0xff2d /* Kana Lock */ -#define XK_Kana_Shift 0xff2e /* Kana Shift */ -#define XK_Eisu_Shift 0xff2f /* Alphanumeric Shift */ -#define XK_Eisu_toggle 0xff30 /* Alphanumeric toggle */ -#define XK_Kanji_Bangou 0xff37 /* Codeinput */ -#define XK_Zen_Koho 0xff3d /* Multiple/All Candidate(s) */ -#define XK_Mae_Koho 0xff3e /* Previous Candidate */ - -/* 0xff31 thru 0xff3f are under XK_KOREAN */ - -/* Cursor control & motion */ - -#define XK_Home 0xff50 -#define XK_Left 0xff51 /* Move left, left arrow */ -#define XK_Up 0xff52 /* Move up, up arrow */ -#define XK_Right 0xff53 /* Move right, right arrow */ -#define XK_Down 0xff54 /* Move down, down arrow */ -#define XK_Prior 0xff55 /* Prior, previous */ -#define XK_Page_Up 0xff55 -#define XK_Next 0xff56 /* Next */ -#define XK_Page_Down 0xff56 -#define XK_End 0xff57 /* EOL */ -#define XK_Begin 0xff58 /* BOL */ - - -/* Misc functions */ - -#define XK_Select 0xff60 /* Select, mark */ -#define XK_Print 0xff61 -#define XK_Execute 0xff62 /* Execute, run, do */ -#define XK_Insert 0xff63 /* Insert, insert here */ -#define XK_Undo 0xff65 -#define XK_Redo 0xff66 /* Redo, again */ -#define XK_Menu 0xff67 -#define XK_Find 0xff68 /* Find, search */ -#define XK_Cancel 0xff69 /* Cancel, stop, abort, exit */ -#define XK_Help 0xff6a /* Help */ -#define XK_Break 0xff6b -#define XK_Mode_switch 0xff7e /* Character set switch */ -#define XK_script_switch 0xff7e /* Alias for mode_switch */ -#define XK_Num_Lock 0xff7f - -/* Keypad functions, keypad numbers cleverly chosen to map to ASCII */ - -#define XK_KP_Space 0xff80 /* Space */ -#define XK_KP_Tab 0xff89 -#define XK_KP_Enter 0xff8d /* Enter */ -#define XK_KP_F1 0xff91 /* PF1, KP_A, ... */ -#define XK_KP_F2 0xff92 -#define XK_KP_F3 0xff93 -#define XK_KP_F4 0xff94 -#define XK_KP_Home 0xff95 -#define XK_KP_Left 0xff96 -#define XK_KP_Up 0xff97 -#define XK_KP_Right 0xff98 -#define XK_KP_Down 0xff99 -#define XK_KP_Prior 0xff9a -#define XK_KP_Page_Up 0xff9a -#define XK_KP_Next 0xff9b -#define XK_KP_Page_Down 0xff9b -#define XK_KP_End 0xff9c -#define XK_KP_Begin 0xff9d -#define XK_KP_Insert 0xff9e -#define XK_KP_Delete 0xff9f -#define XK_KP_Equal 0xffbd /* Equals */ -#define XK_KP_Multiply 0xffaa -#define XK_KP_Add 0xffab -#define XK_KP_Separator 0xffac /* Separator, often comma */ -#define XK_KP_Subtract 0xffad -#define XK_KP_Decimal 0xffae -#define XK_KP_Divide 0xffaf - -#define XK_KP_0 0xffb0 -#define XK_KP_1 0xffb1 -#define XK_KP_2 0xffb2 -#define XK_KP_3 0xffb3 -#define XK_KP_4 0xffb4 -#define XK_KP_5 0xffb5 -#define XK_KP_6 0xffb6 -#define XK_KP_7 0xffb7 -#define XK_KP_8 0xffb8 -#define XK_KP_9 0xffb9 - - - -/* - * Auxiliary functions; note the duplicate definitions for left and right - * function keys; Sun keyboards and a few other manufacturers have such - * function key groups on the left and/or right sides of the keyboard. - * We've not found a keyboard with more than 35 function keys total. - */ - -#define XK_F1 0xffbe -#define XK_F2 0xffbf -#define XK_F3 0xffc0 -#define XK_F4 0xffc1 -#define XK_F5 0xffc2 -#define XK_F6 0xffc3 -#define XK_F7 0xffc4 -#define XK_F8 0xffc5 -#define XK_F9 0xffc6 -#define XK_F10 0xffc7 -#define XK_F11 0xffc8 -#define XK_L1 0xffc8 -#define XK_F12 0xffc9 -#define XK_L2 0xffc9 -#define XK_F13 0xffca -#define XK_L3 0xffca -#define XK_F14 0xffcb -#define XK_L4 0xffcb -#define XK_F15 0xffcc -#define XK_L5 0xffcc -#define XK_F16 0xffcd -#define XK_L6 0xffcd -#define XK_F17 0xffce -#define XK_L7 0xffce -#define XK_F18 0xffcf -#define XK_L8 0xffcf -#define XK_F19 0xffd0 -#define XK_L9 0xffd0 -#define XK_F20 0xffd1 -#define XK_L10 0xffd1 -#define XK_F21 0xffd2 -#define XK_R1 0xffd2 -#define XK_F22 0xffd3 -#define XK_R2 0xffd3 -#define XK_F23 0xffd4 -#define XK_R3 0xffd4 -#define XK_F24 0xffd5 -#define XK_R4 0xffd5 -#define XK_F25 0xffd6 -#define XK_R5 0xffd6 -#define XK_F26 0xffd7 -#define XK_R6 0xffd7 -#define XK_F27 0xffd8 -#define XK_R7 0xffd8 -#define XK_F28 0xffd9 -#define XK_R8 0xffd9 -#define XK_F29 0xffda -#define XK_R9 0xffda -#define XK_F30 0xffdb -#define XK_R10 0xffdb -#define XK_F31 0xffdc -#define XK_R11 0xffdc -#define XK_F32 0xffdd -#define XK_R12 0xffdd -#define XK_F33 0xffde -#define XK_R13 0xffde -#define XK_F34 0xffdf -#define XK_R14 0xffdf -#define XK_F35 0xffe0 -#define XK_R15 0xffe0 - -/* Modifiers */ - -#define XK_Shift_L 0xffe1 /* Left shift */ -#define XK_Shift_R 0xffe2 /* Right shift */ -#define XK_Control_L 0xffe3 /* Left control */ -#define XK_Control_R 0xffe4 /* Right control */ -#define XK_Caps_Lock 0xffe5 /* Caps lock */ -#define XK_Shift_Lock 0xffe6 /* Shift lock */ - -#define XK_Meta_L 0xffe7 /* Left meta */ -#define XK_Meta_R 0xffe8 /* Right meta */ -#define XK_Alt_L 0xffe9 /* Left alt */ -#define XK_Alt_R 0xffea /* Right alt */ -#define XK_Super_L 0xffeb /* Left super */ -#define XK_Super_R 0xffec /* Right super */ -#define XK_Hyper_L 0xffed /* Left hyper */ -#define XK_Hyper_R 0xffee /* Right hyper */ -#endif /* XK_MISCELLANY */ - -/* - * Keyboard (XKB) Extension function and modifier keys - * (from Appendix C of "The X Keyboard Extension: Protocol Specification") - * Byte 3 = 0xfe - */ - -#ifdef XK_XKB_KEYS -#define XK_ISO_Lock 0xfe01 -#define XK_ISO_Level2_Latch 0xfe02 -#define XK_ISO_Level3_Shift 0xfe03 -#define XK_ISO_Level3_Latch 0xfe04 -#define XK_ISO_Level3_Lock 0xfe05 -#define XK_ISO_Level5_Shift 0xfe11 -#define XK_ISO_Level5_Latch 0xfe12 -#define XK_ISO_Level5_Lock 0xfe13 -#define XK_ISO_Group_Shift 0xff7e /* Alias for mode_switch */ -#define XK_ISO_Group_Latch 0xfe06 -#define XK_ISO_Group_Lock 0xfe07 -#define XK_ISO_Next_Group 0xfe08 -#define XK_ISO_Next_Group_Lock 0xfe09 -#define XK_ISO_Prev_Group 0xfe0a -#define XK_ISO_Prev_Group_Lock 0xfe0b -#define XK_ISO_First_Group 0xfe0c -#define XK_ISO_First_Group_Lock 0xfe0d -#define XK_ISO_Last_Group 0xfe0e -#define XK_ISO_Last_Group_Lock 0xfe0f - -#define XK_ISO_Left_Tab 0xfe20 -#define XK_ISO_Move_Line_Up 0xfe21 -#define XK_ISO_Move_Line_Down 0xfe22 -#define XK_ISO_Partial_Line_Up 0xfe23 -#define XK_ISO_Partial_Line_Down 0xfe24 -#define XK_ISO_Partial_Space_Left 0xfe25 -#define XK_ISO_Partial_Space_Right 0xfe26 -#define XK_ISO_Set_Margin_Left 0xfe27 -#define XK_ISO_Set_Margin_Right 0xfe28 -#define XK_ISO_Release_Margin_Left 0xfe29 -#define XK_ISO_Release_Margin_Right 0xfe2a -#define XK_ISO_Release_Both_Margins 0xfe2b -#define XK_ISO_Fast_Cursor_Left 0xfe2c -#define XK_ISO_Fast_Cursor_Right 0xfe2d -#define XK_ISO_Fast_Cursor_Up 0xfe2e -#define XK_ISO_Fast_Cursor_Down 0xfe2f -#define XK_ISO_Continuous_Underline 0xfe30 -#define XK_ISO_Discontinuous_Underline 0xfe31 -#define XK_ISO_Emphasize 0xfe32 -#define XK_ISO_Center_Object 0xfe33 -#define XK_ISO_Enter 0xfe34 - -#define XK_dead_grave 0xfe50 -#define XK_dead_acute 0xfe51 -#define XK_dead_circumflex 0xfe52 -#define XK_dead_tilde 0xfe53 -#define XK_dead_perispomeni 0xfe53 /* alias for dead_tilde */ -#define XK_dead_macron 0xfe54 -#define XK_dead_breve 0xfe55 -#define XK_dead_abovedot 0xfe56 -#define XK_dead_diaeresis 0xfe57 -#define XK_dead_abovering 0xfe58 -#define XK_dead_doubleacute 0xfe59 -#define XK_dead_caron 0xfe5a -#define XK_dead_cedilla 0xfe5b -#define XK_dead_ogonek 0xfe5c -#define XK_dead_iota 0xfe5d -#define XK_dead_voiced_sound 0xfe5e -#define XK_dead_semivoiced_sound 0xfe5f -#define XK_dead_belowdot 0xfe60 -#define XK_dead_hook 0xfe61 -#define XK_dead_horn 0xfe62 -#define XK_dead_stroke 0xfe63 -#define XK_dead_abovecomma 0xfe64 -#define XK_dead_psili 0xfe64 /* alias for dead_abovecomma */ -#define XK_dead_abovereversedcomma 0xfe65 -#define XK_dead_dasia 0xfe65 /* alias for dead_abovereversedcomma */ -#define XK_dead_doublegrave 0xfe66 -#define XK_dead_belowring 0xfe67 -#define XK_dead_belowmacron 0xfe68 -#define XK_dead_belowcircumflex 0xfe69 -#define XK_dead_belowtilde 0xfe6a -#define XK_dead_belowbreve 0xfe6b -#define XK_dead_belowdiaeresis 0xfe6c -#define XK_dead_invertedbreve 0xfe6d -#define XK_dead_belowcomma 0xfe6e -#define XK_dead_currency 0xfe6f - -/* dead vowels for universal syllable entry */ -#define XK_dead_a 0xfe80 -#define XK_dead_A 0xfe81 -#define XK_dead_e 0xfe82 -#define XK_dead_E 0xfe83 -#define XK_dead_i 0xfe84 -#define XK_dead_I 0xfe85 -#define XK_dead_o 0xfe86 -#define XK_dead_O 0xfe87 -#define XK_dead_u 0xfe88 -#define XK_dead_U 0xfe89 -#define XK_dead_small_schwa 0xfe8a -#define XK_dead_capital_schwa 0xfe8b - -#define XK_dead_greek 0xfe8c - -#define XK_First_Virtual_Screen 0xfed0 -#define XK_Prev_Virtual_Screen 0xfed1 -#define XK_Next_Virtual_Screen 0xfed2 -#define XK_Last_Virtual_Screen 0xfed4 -#define XK_Terminate_Server 0xfed5 - -#define XK_AccessX_Enable 0xfe70 -#define XK_AccessX_Feedback_Enable 0xfe71 -#define XK_RepeatKeys_Enable 0xfe72 -#define XK_SlowKeys_Enable 0xfe73 -#define XK_BounceKeys_Enable 0xfe74 -#define XK_StickyKeys_Enable 0xfe75 -#define XK_MouseKeys_Enable 0xfe76 -#define XK_MouseKeys_Accel_Enable 0xfe77 -#define XK_Overlay1_Enable 0xfe78 -#define XK_Overlay2_Enable 0xfe79 -#define XK_AudibleBell_Enable 0xfe7a - -#define XK_Pointer_Left 0xfee0 -#define XK_Pointer_Right 0xfee1 -#define XK_Pointer_Up 0xfee2 -#define XK_Pointer_Down 0xfee3 -#define XK_Pointer_UpLeft 0xfee4 -#define XK_Pointer_UpRight 0xfee5 -#define XK_Pointer_DownLeft 0xfee6 -#define XK_Pointer_DownRight 0xfee7 -#define XK_Pointer_Button_Dflt 0xfee8 -#define XK_Pointer_Button1 0xfee9 -#define XK_Pointer_Button2 0xfeea -#define XK_Pointer_Button3 0xfeeb -#define XK_Pointer_Button4 0xfeec -#define XK_Pointer_Button5 0xfeed -#define XK_Pointer_DblClick_Dflt 0xfeee -#define XK_Pointer_DblClick1 0xfeef -#define XK_Pointer_DblClick2 0xfef0 -#define XK_Pointer_DblClick3 0xfef1 -#define XK_Pointer_DblClick4 0xfef2 -#define XK_Pointer_DblClick5 0xfef3 -#define XK_Pointer_Drag_Dflt 0xfef4 -#define XK_Pointer_Drag1 0xfef5 -#define XK_Pointer_Drag2 0xfef6 -#define XK_Pointer_Drag3 0xfef7 -#define XK_Pointer_Drag4 0xfef8 -#define XK_Pointer_Drag5 0xfefd - -#define XK_Pointer_EnableKeys 0xfef9 -#define XK_Pointer_Accelerate 0xfefa -#define XK_Pointer_DfltBtnNext 0xfefb -#define XK_Pointer_DfltBtnPrev 0xfefc - -/* Single-Stroke Multiple-Character N-Graph Keysyms For The X Input Method */ - -#define XK_ch 0xfea0 -#define XK_Ch 0xfea1 -#define XK_CH 0xfea2 -#define XK_c_h 0xfea3 -#define XK_C_h 0xfea4 -#define XK_C_H 0xfea5 - -#endif /* XK_XKB_KEYS */ - -/* - * 3270 Terminal Keys - * Byte 3 = 0xfd - */ - -#ifdef XK_3270 -#define XK_3270_Duplicate 0xfd01 -#define XK_3270_FieldMark 0xfd02 -#define XK_3270_Right2 0xfd03 -#define XK_3270_Left2 0xfd04 -#define XK_3270_BackTab 0xfd05 -#define XK_3270_EraseEOF 0xfd06 -#define XK_3270_EraseInput 0xfd07 -#define XK_3270_Reset 0xfd08 -#define XK_3270_Quit 0xfd09 -#define XK_3270_PA1 0xfd0a -#define XK_3270_PA2 0xfd0b -#define XK_3270_PA3 0xfd0c -#define XK_3270_Test 0xfd0d -#define XK_3270_Attn 0xfd0e -#define XK_3270_CursorBlink 0xfd0f -#define XK_3270_AltCursor 0xfd10 -#define XK_3270_KeyClick 0xfd11 -#define XK_3270_Jump 0xfd12 -#define XK_3270_Ident 0xfd13 -#define XK_3270_Rule 0xfd14 -#define XK_3270_Copy 0xfd15 -#define XK_3270_Play 0xfd16 -#define XK_3270_Setup 0xfd17 -#define XK_3270_Record 0xfd18 -#define XK_3270_ChangeScreen 0xfd19 -#define XK_3270_DeleteWord 0xfd1a -#define XK_3270_ExSelect 0xfd1b -#define XK_3270_CursorSelect 0xfd1c -#define XK_3270_PrintScreen 0xfd1d -#define XK_3270_Enter 0xfd1e -#endif /* XK_3270 */ - -/* - * Latin 1 - * (ISO/IEC 8859-1 = Unicode U+0020..U+00FF) - * Byte 3 = 0 - */ -#ifdef XK_LATIN1 -#define XK_space 0x0020 /* U+0020 SPACE */ -#define XK_exclam 0x0021 /* U+0021 EXCLAMATION MARK */ -#define XK_quotedbl 0x0022 /* U+0022 QUOTATION MARK */ -#define XK_numbersign 0x0023 /* U+0023 NUMBER SIGN */ -#define XK_dollar 0x0024 /* U+0024 DOLLAR SIGN */ -#define XK_percent 0x0025 /* U+0025 PERCENT SIGN */ -#define XK_ampersand 0x0026 /* U+0026 AMPERSAND */ -#define XK_apostrophe 0x0027 /* U+0027 APOSTROPHE */ -#define XK_quoteright 0x0027 /* deprecated */ -#define XK_parenleft 0x0028 /* U+0028 LEFT PARENTHESIS */ -#define XK_parenright 0x0029 /* U+0029 RIGHT PARENTHESIS */ -#define XK_asterisk 0x002a /* U+002A ASTERISK */ -#define XK_plus 0x002b /* U+002B PLUS SIGN */ -#define XK_comma 0x002c /* U+002C COMMA */ -#define XK_minus 0x002d /* U+002D HYPHEN-MINUS */ -#define XK_period 0x002e /* U+002E FULL STOP */ -#define XK_slash 0x002f /* U+002F SOLIDUS */ -#define XK_0 0x0030 /* U+0030 DIGIT ZERO */ -#define XK_1 0x0031 /* U+0031 DIGIT ONE */ -#define XK_2 0x0032 /* U+0032 DIGIT TWO */ -#define XK_3 0x0033 /* U+0033 DIGIT THREE */ -#define XK_4 0x0034 /* U+0034 DIGIT FOUR */ -#define XK_5 0x0035 /* U+0035 DIGIT FIVE */ -#define XK_6 0x0036 /* U+0036 DIGIT SIX */ -#define XK_7 0x0037 /* U+0037 DIGIT SEVEN */ -#define XK_8 0x0038 /* U+0038 DIGIT EIGHT */ -#define XK_9 0x0039 /* U+0039 DIGIT NINE */ -#define XK_colon 0x003a /* U+003A COLON */ -#define XK_semicolon 0x003b /* U+003B SEMICOLON */ -#define XK_less 0x003c /* U+003C LESS-THAN SIGN */ -#define XK_equal 0x003d /* U+003D EQUALS SIGN */ -#define XK_greater 0x003e /* U+003E GREATER-THAN SIGN */ -#define XK_question 0x003f /* U+003F QUESTION MARK */ -#define XK_at 0x0040 /* U+0040 COMMERCIAL AT */ -#define XK_A 0x0041 /* U+0041 LATIN CAPITAL LETTER A */ -#define XK_B 0x0042 /* U+0042 LATIN CAPITAL LETTER B */ -#define XK_C 0x0043 /* U+0043 LATIN CAPITAL LETTER C */ -#define XK_D 0x0044 /* U+0044 LATIN CAPITAL LETTER D */ -#define XK_E 0x0045 /* U+0045 LATIN CAPITAL LETTER E */ -#define XK_F 0x0046 /* U+0046 LATIN CAPITAL LETTER F */ -#define XK_G 0x0047 /* U+0047 LATIN CAPITAL LETTER G */ -#define XK_H 0x0048 /* U+0048 LATIN CAPITAL LETTER H */ -#define XK_I 0x0049 /* U+0049 LATIN CAPITAL LETTER I */ -#define XK_J 0x004a /* U+004A LATIN CAPITAL LETTER J */ -#define XK_K 0x004b /* U+004B LATIN CAPITAL LETTER K */ -#define XK_L 0x004c /* U+004C LATIN CAPITAL LETTER L */ -#define XK_M 0x004d /* U+004D LATIN CAPITAL LETTER M */ -#define XK_N 0x004e /* U+004E LATIN CAPITAL LETTER N */ -#define XK_O 0x004f /* U+004F LATIN CAPITAL LETTER O */ -#define XK_P 0x0050 /* U+0050 LATIN CAPITAL LETTER P */ -#define XK_Q 0x0051 /* U+0051 LATIN CAPITAL LETTER Q */ -#define XK_R 0x0052 /* U+0052 LATIN CAPITAL LETTER R */ -#define XK_S 0x0053 /* U+0053 LATIN CAPITAL LETTER S */ -#define XK_T 0x0054 /* U+0054 LATIN CAPITAL LETTER T */ -#define XK_U 0x0055 /* U+0055 LATIN CAPITAL LETTER U */ -#define XK_V 0x0056 /* U+0056 LATIN CAPITAL LETTER V */ -#define XK_W 0x0057 /* U+0057 LATIN CAPITAL LETTER W */ -#define XK_X 0x0058 /* U+0058 LATIN CAPITAL LETTER X */ -#define XK_Y 0x0059 /* U+0059 LATIN CAPITAL LETTER Y */ -#define XK_Z 0x005a /* U+005A LATIN CAPITAL LETTER Z */ -#define XK_bracketleft 0x005b /* U+005B LEFT SQUARE BRACKET */ -#define XK_backslash 0x005c /* U+005C REVERSE SOLIDUS */ -#define XK_bracketright 0x005d /* U+005D RIGHT SQUARE BRACKET */ -#define XK_asciicircum 0x005e /* U+005E CIRCUMFLEX ACCENT */ -#define XK_underscore 0x005f /* U+005F LOW LINE */ -#define XK_grave 0x0060 /* U+0060 GRAVE ACCENT */ -#define XK_quoteleft 0x0060 /* deprecated */ -#define XK_a 0x0061 /* U+0061 LATIN SMALL LETTER A */ -#define XK_b 0x0062 /* U+0062 LATIN SMALL LETTER B */ -#define XK_c 0x0063 /* U+0063 LATIN SMALL LETTER C */ -#define XK_d 0x0064 /* U+0064 LATIN SMALL LETTER D */ -#define XK_e 0x0065 /* U+0065 LATIN SMALL LETTER E */ -#define XK_f 0x0066 /* U+0066 LATIN SMALL LETTER F */ -#define XK_g 0x0067 /* U+0067 LATIN SMALL LETTER G */ -#define XK_h 0x0068 /* U+0068 LATIN SMALL LETTER H */ -#define XK_i 0x0069 /* U+0069 LATIN SMALL LETTER I */ -#define XK_j 0x006a /* U+006A LATIN SMALL LETTER J */ -#define XK_k 0x006b /* U+006B LATIN SMALL LETTER K */ -#define XK_l 0x006c /* U+006C LATIN SMALL LETTER L */ -#define XK_m 0x006d /* U+006D LATIN SMALL LETTER M */ -#define XK_n 0x006e /* U+006E LATIN SMALL LETTER N */ -#define XK_o 0x006f /* U+006F LATIN SMALL LETTER O */ -#define XK_p 0x0070 /* U+0070 LATIN SMALL LETTER P */ -#define XK_q 0x0071 /* U+0071 LATIN SMALL LETTER Q */ -#define XK_r 0x0072 /* U+0072 LATIN SMALL LETTER R */ -#define XK_s 0x0073 /* U+0073 LATIN SMALL LETTER S */ -#define XK_t 0x0074 /* U+0074 LATIN SMALL LETTER T */ -#define XK_u 0x0075 /* U+0075 LATIN SMALL LETTER U */ -#define XK_v 0x0076 /* U+0076 LATIN SMALL LETTER V */ -#define XK_w 0x0077 /* U+0077 LATIN SMALL LETTER W */ -#define XK_x 0x0078 /* U+0078 LATIN SMALL LETTER X */ -#define XK_y 0x0079 /* U+0079 LATIN SMALL LETTER Y */ -#define XK_z 0x007a /* U+007A LATIN SMALL LETTER Z */ -#define XK_braceleft 0x007b /* U+007B LEFT CURLY BRACKET */ -#define XK_bar 0x007c /* U+007C VERTICAL LINE */ -#define XK_braceright 0x007d /* U+007D RIGHT CURLY BRACKET */ -#define XK_asciitilde 0x007e /* U+007E TILDE */ - -#define XK_nobreakspace 0x00a0 /* U+00A0 NO-BREAK SPACE */ -#define XK_exclamdown 0x00a1 /* U+00A1 INVERTED EXCLAMATION MARK */ -#define XK_cent 0x00a2 /* U+00A2 CENT SIGN */ -#define XK_sterling 0x00a3 /* U+00A3 POUND SIGN */ -#define XK_currency 0x00a4 /* U+00A4 CURRENCY SIGN */ -#define XK_yen 0x00a5 /* U+00A5 YEN SIGN */ -#define XK_brokenbar 0x00a6 /* U+00A6 BROKEN BAR */ -#define XK_section 0x00a7 /* U+00A7 SECTION SIGN */ -#define XK_diaeresis 0x00a8 /* U+00A8 DIAERESIS */ -#define XK_copyright 0x00a9 /* U+00A9 COPYRIGHT SIGN */ -#define XK_ordfeminine 0x00aa /* U+00AA FEMININE ORDINAL INDICATOR */ -#define XK_guillemotleft 0x00ab /* U+00AB LEFT-POINTING DOUBLE ANGLE QUOTATION MARK */ -#define XK_notsign 0x00ac /* U+00AC NOT SIGN */ -#define XK_hyphen 0x00ad /* U+00AD SOFT HYPHEN */ -#define XK_registered 0x00ae /* U+00AE REGISTERED SIGN */ -#define XK_macron 0x00af /* U+00AF MACRON */ -#define XK_degree 0x00b0 /* U+00B0 DEGREE SIGN */ -#define XK_plusminus 0x00b1 /* U+00B1 PLUS-MINUS SIGN */ -#define XK_twosuperior 0x00b2 /* U+00B2 SUPERSCRIPT TWO */ -#define XK_threesuperior 0x00b3 /* U+00B3 SUPERSCRIPT THREE */ -#define XK_acute 0x00b4 /* U+00B4 ACUTE ACCENT */ -#define XK_mu 0x00b5 /* U+00B5 MICRO SIGN */ -#define XK_paragraph 0x00b6 /* U+00B6 PILCROW SIGN */ -#define XK_periodcentered 0x00b7 /* U+00B7 MIDDLE DOT */ -#define XK_cedilla 0x00b8 /* U+00B8 CEDILLA */ -#define XK_onesuperior 0x00b9 /* U+00B9 SUPERSCRIPT ONE */ -#define XK_masculine 0x00ba /* U+00BA MASCULINE ORDINAL INDICATOR */ -#define XK_guillemotright 0x00bb /* U+00BB RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK */ -#define XK_onequarter 0x00bc /* U+00BC VULGAR FRACTION ONE QUARTER */ -#define XK_onehalf 0x00bd /* U+00BD VULGAR FRACTION ONE HALF */ -#define XK_threequarters 0x00be /* U+00BE VULGAR FRACTION THREE QUARTERS */ -#define XK_questiondown 0x00bf /* U+00BF INVERTED QUESTION MARK */ -#define XK_Agrave 0x00c0 /* U+00C0 LATIN CAPITAL LETTER A WITH GRAVE */ -#define XK_Aacute 0x00c1 /* U+00C1 LATIN CAPITAL LETTER A WITH ACUTE */ -#define XK_Acircumflex 0x00c2 /* U+00C2 LATIN CAPITAL LETTER A WITH CIRCUMFLEX */ -#define XK_Atilde 0x00c3 /* U+00C3 LATIN CAPITAL LETTER A WITH TILDE */ -#define XK_Adiaeresis 0x00c4 /* U+00C4 LATIN CAPITAL LETTER A WITH DIAERESIS */ -#define XK_Aring 0x00c5 /* U+00C5 LATIN CAPITAL LETTER A WITH RING ABOVE */ -#define XK_AE 0x00c6 /* U+00C6 LATIN CAPITAL LETTER AE */ -#define XK_Ccedilla 0x00c7 /* U+00C7 LATIN CAPITAL LETTER C WITH CEDILLA */ -#define XK_Egrave 0x00c8 /* U+00C8 LATIN CAPITAL LETTER E WITH GRAVE */ -#define XK_Eacute 0x00c9 /* U+00C9 LATIN CAPITAL LETTER E WITH ACUTE */ -#define XK_Ecircumflex 0x00ca /* U+00CA LATIN CAPITAL LETTER E WITH CIRCUMFLEX */ -#define XK_Ediaeresis 0x00cb /* U+00CB LATIN CAPITAL LETTER E WITH DIAERESIS */ -#define XK_Igrave 0x00cc /* U+00CC LATIN CAPITAL LETTER I WITH GRAVE */ -#define XK_Iacute 0x00cd /* U+00CD LATIN CAPITAL LETTER I WITH ACUTE */ -#define XK_Icircumflex 0x00ce /* U+00CE LATIN CAPITAL LETTER I WITH CIRCUMFLEX */ -#define XK_Idiaeresis 0x00cf /* U+00CF LATIN CAPITAL LETTER I WITH DIAERESIS */ -#define XK_ETH 0x00d0 /* U+00D0 LATIN CAPITAL LETTER ETH */ -#define XK_Eth 0x00d0 /* deprecated */ -#define XK_Ntilde 0x00d1 /* U+00D1 LATIN CAPITAL LETTER N WITH TILDE */ -#define XK_Ograve 0x00d2 /* U+00D2 LATIN CAPITAL LETTER O WITH GRAVE */ -#define XK_Oacute 0x00d3 /* U+00D3 LATIN CAPITAL LETTER O WITH ACUTE */ -#define XK_Ocircumflex 0x00d4 /* U+00D4 LATIN CAPITAL LETTER O WITH CIRCUMFLEX */ -#define XK_Otilde 0x00d5 /* U+00D5 LATIN CAPITAL LETTER O WITH TILDE */ -#define XK_Odiaeresis 0x00d6 /* U+00D6 LATIN CAPITAL LETTER O WITH DIAERESIS */ -#define XK_multiply 0x00d7 /* U+00D7 MULTIPLICATION SIGN */ -#define XK_Oslash 0x00d8 /* U+00D8 LATIN CAPITAL LETTER O WITH STROKE */ -#define XK_Ooblique 0x00d8 /* U+00D8 LATIN CAPITAL LETTER O WITH STROKE */ -#define XK_Ugrave 0x00d9 /* U+00D9 LATIN CAPITAL LETTER U WITH GRAVE */ -#define XK_Uacute 0x00da /* U+00DA LATIN CAPITAL LETTER U WITH ACUTE */ -#define XK_Ucircumflex 0x00db /* U+00DB LATIN CAPITAL LETTER U WITH CIRCUMFLEX */ -#define XK_Udiaeresis 0x00dc /* U+00DC LATIN CAPITAL LETTER U WITH DIAERESIS */ -#define XK_Yacute 0x00dd /* U+00DD LATIN CAPITAL LETTER Y WITH ACUTE */ -#define XK_THORN 0x00de /* U+00DE LATIN CAPITAL LETTER THORN */ -#define XK_Thorn 0x00de /* deprecated */ -#define XK_ssharp 0x00df /* U+00DF LATIN SMALL LETTER SHARP S */ -#define XK_agrave 0x00e0 /* U+00E0 LATIN SMALL LETTER A WITH GRAVE */ -#define XK_aacute 0x00e1 /* U+00E1 LATIN SMALL LETTER A WITH ACUTE */ -#define XK_acircumflex 0x00e2 /* U+00E2 LATIN SMALL LETTER A WITH CIRCUMFLEX */ -#define XK_atilde 0x00e3 /* U+00E3 LATIN SMALL LETTER A WITH TILDE */ -#define XK_adiaeresis 0x00e4 /* U+00E4 LATIN SMALL LETTER A WITH DIAERESIS */ -#define XK_aring 0x00e5 /* U+00E5 LATIN SMALL LETTER A WITH RING ABOVE */ -#define XK_ae 0x00e6 /* U+00E6 LATIN SMALL LETTER AE */ -#define XK_ccedilla 0x00e7 /* U+00E7 LATIN SMALL LETTER C WITH CEDILLA */ -#define XK_egrave 0x00e8 /* U+00E8 LATIN SMALL LETTER E WITH GRAVE */ -#define XK_eacute 0x00e9 /* U+00E9 LATIN SMALL LETTER E WITH ACUTE */ -#define XK_ecircumflex 0x00ea /* U+00EA LATIN SMALL LETTER E WITH CIRCUMFLEX */ -#define XK_ediaeresis 0x00eb /* U+00EB LATIN SMALL LETTER E WITH DIAERESIS */ -#define XK_igrave 0x00ec /* U+00EC LATIN SMALL LETTER I WITH GRAVE */ -#define XK_iacute 0x00ed /* U+00ED LATIN SMALL LETTER I WITH ACUTE */ -#define XK_icircumflex 0x00ee /* U+00EE LATIN SMALL LETTER I WITH CIRCUMFLEX */ -#define XK_idiaeresis 0x00ef /* U+00EF LATIN SMALL LETTER I WITH DIAERESIS */ -#define XK_eth 0x00f0 /* U+00F0 LATIN SMALL LETTER ETH */ -#define XK_ntilde 0x00f1 /* U+00F1 LATIN SMALL LETTER N WITH TILDE */ -#define XK_ograve 0x00f2 /* U+00F2 LATIN SMALL LETTER O WITH GRAVE */ -#define XK_oacute 0x00f3 /* U+00F3 LATIN SMALL LETTER O WITH ACUTE */ -#define XK_ocircumflex 0x00f4 /* U+00F4 LATIN SMALL LETTER O WITH CIRCUMFLEX */ -#define XK_otilde 0x00f5 /* U+00F5 LATIN SMALL LETTER O WITH TILDE */ -#define XK_odiaeresis 0x00f6 /* U+00F6 LATIN SMALL LETTER O WITH DIAERESIS */ -#define XK_division 0x00f7 /* U+00F7 DIVISION SIGN */ -#define XK_oslash 0x00f8 /* U+00F8 LATIN SMALL LETTER O WITH STROKE */ -#define XK_ooblique 0x00f8 /* U+00F8 LATIN SMALL LETTER O WITH STROKE */ -#define XK_ugrave 0x00f9 /* U+00F9 LATIN SMALL LETTER U WITH GRAVE */ -#define XK_uacute 0x00fa /* U+00FA LATIN SMALL LETTER U WITH ACUTE */ -#define XK_ucircumflex 0x00fb /* U+00FB LATIN SMALL LETTER U WITH CIRCUMFLEX */ -#define XK_udiaeresis 0x00fc /* U+00FC LATIN SMALL LETTER U WITH DIAERESIS */ -#define XK_yacute 0x00fd /* U+00FD LATIN SMALL LETTER Y WITH ACUTE */ -#define XK_thorn 0x00fe /* U+00FE LATIN SMALL LETTER THORN */ -#define XK_ydiaeresis 0x00ff /* U+00FF LATIN SMALL LETTER Y WITH DIAERESIS */ -#endif /* XK_LATIN1 */ - -/* - * Latin 2 - * Byte 3 = 1 - */ - -#ifdef XK_LATIN2 -#define XK_Aogonek 0x01a1 /* U+0104 LATIN CAPITAL LETTER A WITH OGONEK */ -#define XK_breve 0x01a2 /* U+02D8 BREVE */ -#define XK_Lstroke 0x01a3 /* U+0141 LATIN CAPITAL LETTER L WITH STROKE */ -#define XK_Lcaron 0x01a5 /* U+013D LATIN CAPITAL LETTER L WITH CARON */ -#define XK_Sacute 0x01a6 /* U+015A LATIN CAPITAL LETTER S WITH ACUTE */ -#define XK_Scaron 0x01a9 /* U+0160 LATIN CAPITAL LETTER S WITH CARON */ -#define XK_Scedilla 0x01aa /* U+015E LATIN CAPITAL LETTER S WITH CEDILLA */ -#define XK_Tcaron 0x01ab /* U+0164 LATIN CAPITAL LETTER T WITH CARON */ -#define XK_Zacute 0x01ac /* U+0179 LATIN CAPITAL LETTER Z WITH ACUTE */ -#define XK_Zcaron 0x01ae /* U+017D LATIN CAPITAL LETTER Z WITH CARON */ -#define XK_Zabovedot 0x01af /* U+017B LATIN CAPITAL LETTER Z WITH DOT ABOVE */ -#define XK_aogonek 0x01b1 /* U+0105 LATIN SMALL LETTER A WITH OGONEK */ -#define XK_ogonek 0x01b2 /* U+02DB OGONEK */ -#define XK_lstroke 0x01b3 /* U+0142 LATIN SMALL LETTER L WITH STROKE */ -#define XK_lcaron 0x01b5 /* U+013E LATIN SMALL LETTER L WITH CARON */ -#define XK_sacute 0x01b6 /* U+015B LATIN SMALL LETTER S WITH ACUTE */ -#define XK_caron 0x01b7 /* U+02C7 CARON */ -#define XK_scaron 0x01b9 /* U+0161 LATIN SMALL LETTER S WITH CARON */ -#define XK_scedilla 0x01ba /* U+015F LATIN SMALL LETTER S WITH CEDILLA */ -#define XK_tcaron 0x01bb /* U+0165 LATIN SMALL LETTER T WITH CARON */ -#define XK_zacute 0x01bc /* U+017A LATIN SMALL LETTER Z WITH ACUTE */ -#define XK_doubleacute 0x01bd /* U+02DD DOUBLE ACUTE ACCENT */ -#define XK_zcaron 0x01be /* U+017E LATIN SMALL LETTER Z WITH CARON */ -#define XK_zabovedot 0x01bf /* U+017C LATIN SMALL LETTER Z WITH DOT ABOVE */ -#define XK_Racute 0x01c0 /* U+0154 LATIN CAPITAL LETTER R WITH ACUTE */ -#define XK_Abreve 0x01c3 /* U+0102 LATIN CAPITAL LETTER A WITH BREVE */ -#define XK_Lacute 0x01c5 /* U+0139 LATIN CAPITAL LETTER L WITH ACUTE */ -#define XK_Cacute 0x01c6 /* U+0106 LATIN CAPITAL LETTER C WITH ACUTE */ -#define XK_Ccaron 0x01c8 /* U+010C LATIN CAPITAL LETTER C WITH CARON */ -#define XK_Eogonek 0x01ca /* U+0118 LATIN CAPITAL LETTER E WITH OGONEK */ -#define XK_Ecaron 0x01cc /* U+011A LATIN CAPITAL LETTER E WITH CARON */ -#define XK_Dcaron 0x01cf /* U+010E LATIN CAPITAL LETTER D WITH CARON */ -#define XK_Dstroke 0x01d0 /* U+0110 LATIN CAPITAL LETTER D WITH STROKE */ -#define XK_Nacute 0x01d1 /* U+0143 LATIN CAPITAL LETTER N WITH ACUTE */ -#define XK_Ncaron 0x01d2 /* U+0147 LATIN CAPITAL LETTER N WITH CARON */ -#define XK_Odoubleacute 0x01d5 /* U+0150 LATIN CAPITAL LETTER O WITH DOUBLE ACUTE */ -#define XK_Rcaron 0x01d8 /* U+0158 LATIN CAPITAL LETTER R WITH CARON */ -#define XK_Uring 0x01d9 /* U+016E LATIN CAPITAL LETTER U WITH RING ABOVE */ -#define XK_Udoubleacute 0x01db /* U+0170 LATIN CAPITAL LETTER U WITH DOUBLE ACUTE */ -#define XK_Tcedilla 0x01de /* U+0162 LATIN CAPITAL LETTER T WITH CEDILLA */ -#define XK_racute 0x01e0 /* U+0155 LATIN SMALL LETTER R WITH ACUTE */ -#define XK_abreve 0x01e3 /* U+0103 LATIN SMALL LETTER A WITH BREVE */ -#define XK_lacute 0x01e5 /* U+013A LATIN SMALL LETTER L WITH ACUTE */ -#define XK_cacute 0x01e6 /* U+0107 LATIN SMALL LETTER C WITH ACUTE */ -#define XK_ccaron 0x01e8 /* U+010D LATIN SMALL LETTER C WITH CARON */ -#define XK_eogonek 0x01ea /* U+0119 LATIN SMALL LETTER E WITH OGONEK */ -#define XK_ecaron 0x01ec /* U+011B LATIN SMALL LETTER E WITH CARON */ -#define XK_dcaron 0x01ef /* U+010F LATIN SMALL LETTER D WITH CARON */ -#define XK_dstroke 0x01f0 /* U+0111 LATIN SMALL LETTER D WITH STROKE */ -#define XK_nacute 0x01f1 /* U+0144 LATIN SMALL LETTER N WITH ACUTE */ -#define XK_ncaron 0x01f2 /* U+0148 LATIN SMALL LETTER N WITH CARON */ -#define XK_odoubleacute 0x01f5 /* U+0151 LATIN SMALL LETTER O WITH DOUBLE ACUTE */ -#define XK_rcaron 0x01f8 /* U+0159 LATIN SMALL LETTER R WITH CARON */ -#define XK_uring 0x01f9 /* U+016F LATIN SMALL LETTER U WITH RING ABOVE */ -#define XK_udoubleacute 0x01fb /* U+0171 LATIN SMALL LETTER U WITH DOUBLE ACUTE */ -#define XK_tcedilla 0x01fe /* U+0163 LATIN SMALL LETTER T WITH CEDILLA */ -#define XK_abovedot 0x01ff /* U+02D9 DOT ABOVE */ -#endif /* XK_LATIN2 */ - -/* - * Latin 3 - * Byte 3 = 2 - */ - -#ifdef XK_LATIN3 -#define XK_Hstroke 0x02a1 /* U+0126 LATIN CAPITAL LETTER H WITH STROKE */ -#define XK_Hcircumflex 0x02a6 /* U+0124 LATIN CAPITAL LETTER H WITH CIRCUMFLEX */ -#define XK_Iabovedot 0x02a9 /* U+0130 LATIN CAPITAL LETTER I WITH DOT ABOVE */ -#define XK_Gbreve 0x02ab /* U+011E LATIN CAPITAL LETTER G WITH BREVE */ -#define XK_Jcircumflex 0x02ac /* U+0134 LATIN CAPITAL LETTER J WITH CIRCUMFLEX */ -#define XK_hstroke 0x02b1 /* U+0127 LATIN SMALL LETTER H WITH STROKE */ -#define XK_hcircumflex 0x02b6 /* U+0125 LATIN SMALL LETTER H WITH CIRCUMFLEX */ -#define XK_idotless 0x02b9 /* U+0131 LATIN SMALL LETTER DOTLESS I */ -#define XK_gbreve 0x02bb /* U+011F LATIN SMALL LETTER G WITH BREVE */ -#define XK_jcircumflex 0x02bc /* U+0135 LATIN SMALL LETTER J WITH CIRCUMFLEX */ -#define XK_Cabovedot 0x02c5 /* U+010A LATIN CAPITAL LETTER C WITH DOT ABOVE */ -#define XK_Ccircumflex 0x02c6 /* U+0108 LATIN CAPITAL LETTER C WITH CIRCUMFLEX */ -#define XK_Gabovedot 0x02d5 /* U+0120 LATIN CAPITAL LETTER G WITH DOT ABOVE */ -#define XK_Gcircumflex 0x02d8 /* U+011C LATIN CAPITAL LETTER G WITH CIRCUMFLEX */ -#define XK_Ubreve 0x02dd /* U+016C LATIN CAPITAL LETTER U WITH BREVE */ -#define XK_Scircumflex 0x02de /* U+015C LATIN CAPITAL LETTER S WITH CIRCUMFLEX */ -#define XK_cabovedot 0x02e5 /* U+010B LATIN SMALL LETTER C WITH DOT ABOVE */ -#define XK_ccircumflex 0x02e6 /* U+0109 LATIN SMALL LETTER C WITH CIRCUMFLEX */ -#define XK_gabovedot 0x02f5 /* U+0121 LATIN SMALL LETTER G WITH DOT ABOVE */ -#define XK_gcircumflex 0x02f8 /* U+011D LATIN SMALL LETTER G WITH CIRCUMFLEX */ -#define XK_ubreve 0x02fd /* U+016D LATIN SMALL LETTER U WITH BREVE */ -#define XK_scircumflex 0x02fe /* U+015D LATIN SMALL LETTER S WITH CIRCUMFLEX */ -#endif /* XK_LATIN3 */ - - -/* - * Latin 4 - * Byte 3 = 3 - */ - -#ifdef XK_LATIN4 -#define XK_kra 0x03a2 /* U+0138 LATIN SMALL LETTER KRA */ -#define XK_kappa 0x03a2 /* deprecated */ -#define XK_Rcedilla 0x03a3 /* U+0156 LATIN CAPITAL LETTER R WITH CEDILLA */ -#define XK_Itilde 0x03a5 /* U+0128 LATIN CAPITAL LETTER I WITH TILDE */ -#define XK_Lcedilla 0x03a6 /* U+013B LATIN CAPITAL LETTER L WITH CEDILLA */ -#define XK_Emacron 0x03aa /* U+0112 LATIN CAPITAL LETTER E WITH MACRON */ -#define XK_Gcedilla 0x03ab /* U+0122 LATIN CAPITAL LETTER G WITH CEDILLA */ -#define XK_Tslash 0x03ac /* U+0166 LATIN CAPITAL LETTER T WITH STROKE */ -#define XK_rcedilla 0x03b3 /* U+0157 LATIN SMALL LETTER R WITH CEDILLA */ -#define XK_itilde 0x03b5 /* U+0129 LATIN SMALL LETTER I WITH TILDE */ -#define XK_lcedilla 0x03b6 /* U+013C LATIN SMALL LETTER L WITH CEDILLA */ -#define XK_emacron 0x03ba /* U+0113 LATIN SMALL LETTER E WITH MACRON */ -#define XK_gcedilla 0x03bb /* U+0123 LATIN SMALL LETTER G WITH CEDILLA */ -#define XK_tslash 0x03bc /* U+0167 LATIN SMALL LETTER T WITH STROKE */ -#define XK_ENG 0x03bd /* U+014A LATIN CAPITAL LETTER ENG */ -#define XK_eng 0x03bf /* U+014B LATIN SMALL LETTER ENG */ -#define XK_Amacron 0x03c0 /* U+0100 LATIN CAPITAL LETTER A WITH MACRON */ -#define XK_Iogonek 0x03c7 /* U+012E LATIN CAPITAL LETTER I WITH OGONEK */ -#define XK_Eabovedot 0x03cc /* U+0116 LATIN CAPITAL LETTER E WITH DOT ABOVE */ -#define XK_Imacron 0x03cf /* U+012A LATIN CAPITAL LETTER I WITH MACRON */ -#define XK_Ncedilla 0x03d1 /* U+0145 LATIN CAPITAL LETTER N WITH CEDILLA */ -#define XK_Omacron 0x03d2 /* U+014C LATIN CAPITAL LETTER O WITH MACRON */ -#define XK_Kcedilla 0x03d3 /* U+0136 LATIN CAPITAL LETTER K WITH CEDILLA */ -#define XK_Uogonek 0x03d9 /* U+0172 LATIN CAPITAL LETTER U WITH OGONEK */ -#define XK_Utilde 0x03dd /* U+0168 LATIN CAPITAL LETTER U WITH TILDE */ -#define XK_Umacron 0x03de /* U+016A LATIN CAPITAL LETTER U WITH MACRON */ -#define XK_amacron 0x03e0 /* U+0101 LATIN SMALL LETTER A WITH MACRON */ -#define XK_iogonek 0x03e7 /* U+012F LATIN SMALL LETTER I WITH OGONEK */ -#define XK_eabovedot 0x03ec /* U+0117 LATIN SMALL LETTER E WITH DOT ABOVE */ -#define XK_imacron 0x03ef /* U+012B LATIN SMALL LETTER I WITH MACRON */ -#define XK_ncedilla 0x03f1 /* U+0146 LATIN SMALL LETTER N WITH CEDILLA */ -#define XK_omacron 0x03f2 /* U+014D LATIN SMALL LETTER O WITH MACRON */ -#define XK_kcedilla 0x03f3 /* U+0137 LATIN SMALL LETTER K WITH CEDILLA */ -#define XK_uogonek 0x03f9 /* U+0173 LATIN SMALL LETTER U WITH OGONEK */ -#define XK_utilde 0x03fd /* U+0169 LATIN SMALL LETTER U WITH TILDE */ -#define XK_umacron 0x03fe /* U+016B LATIN SMALL LETTER U WITH MACRON */ -#endif /* XK_LATIN4 */ - -/* - * Latin 8 - */ -#ifdef XK_LATIN8 -#define XK_Wcircumflex 0x1000174 /* U+0174 LATIN CAPITAL LETTER W WITH CIRCUMFLEX */ -#define XK_wcircumflex 0x1000175 /* U+0175 LATIN SMALL LETTER W WITH CIRCUMFLEX */ -#define XK_Ycircumflex 0x1000176 /* U+0176 LATIN CAPITAL LETTER Y WITH CIRCUMFLEX */ -#define XK_ycircumflex 0x1000177 /* U+0177 LATIN SMALL LETTER Y WITH CIRCUMFLEX */ -#define XK_Babovedot 0x1001e02 /* U+1E02 LATIN CAPITAL LETTER B WITH DOT ABOVE */ -#define XK_babovedot 0x1001e03 /* U+1E03 LATIN SMALL LETTER B WITH DOT ABOVE */ -#define XK_Dabovedot 0x1001e0a /* U+1E0A LATIN CAPITAL LETTER D WITH DOT ABOVE */ -#define XK_dabovedot 0x1001e0b /* U+1E0B LATIN SMALL LETTER D WITH DOT ABOVE */ -#define XK_Fabovedot 0x1001e1e /* U+1E1E LATIN CAPITAL LETTER F WITH DOT ABOVE */ -#define XK_fabovedot 0x1001e1f /* U+1E1F LATIN SMALL LETTER F WITH DOT ABOVE */ -#define XK_Mabovedot 0x1001e40 /* U+1E40 LATIN CAPITAL LETTER M WITH DOT ABOVE */ -#define XK_mabovedot 0x1001e41 /* U+1E41 LATIN SMALL LETTER M WITH DOT ABOVE */ -#define XK_Pabovedot 0x1001e56 /* U+1E56 LATIN CAPITAL LETTER P WITH DOT ABOVE */ -#define XK_pabovedot 0x1001e57 /* U+1E57 LATIN SMALL LETTER P WITH DOT ABOVE */ -#define XK_Sabovedot 0x1001e60 /* U+1E60 LATIN CAPITAL LETTER S WITH DOT ABOVE */ -#define XK_sabovedot 0x1001e61 /* U+1E61 LATIN SMALL LETTER S WITH DOT ABOVE */ -#define XK_Tabovedot 0x1001e6a /* U+1E6A LATIN CAPITAL LETTER T WITH DOT ABOVE */ -#define XK_tabovedot 0x1001e6b /* U+1E6B LATIN SMALL LETTER T WITH DOT ABOVE */ -#define XK_Wgrave 0x1001e80 /* U+1E80 LATIN CAPITAL LETTER W WITH GRAVE */ -#define XK_wgrave 0x1001e81 /* U+1E81 LATIN SMALL LETTER W WITH GRAVE */ -#define XK_Wacute 0x1001e82 /* U+1E82 LATIN CAPITAL LETTER W WITH ACUTE */ -#define XK_wacute 0x1001e83 /* U+1E83 LATIN SMALL LETTER W WITH ACUTE */ -#define XK_Wdiaeresis 0x1001e84 /* U+1E84 LATIN CAPITAL LETTER W WITH DIAERESIS */ -#define XK_wdiaeresis 0x1001e85 /* U+1E85 LATIN SMALL LETTER W WITH DIAERESIS */ -#define XK_Ygrave 0x1001ef2 /* U+1EF2 LATIN CAPITAL LETTER Y WITH GRAVE */ -#define XK_ygrave 0x1001ef3 /* U+1EF3 LATIN SMALL LETTER Y WITH GRAVE */ -#endif /* XK_LATIN8 */ - -/* - * Latin 9 - * Byte 3 = 0x13 - */ - -#ifdef XK_LATIN9 -#define XK_OE 0x13bc /* U+0152 LATIN CAPITAL LIGATURE OE */ -#define XK_oe 0x13bd /* U+0153 LATIN SMALL LIGATURE OE */ -#define XK_Ydiaeresis 0x13be /* U+0178 LATIN CAPITAL LETTER Y WITH DIAERESIS */ -#endif /* XK_LATIN9 */ - -/* - * Katakana - * Byte 3 = 4 - */ - -#ifdef XK_KATAKANA -#define XK_overline 0x047e /* U+203E OVERLINE */ -#define XK_kana_fullstop 0x04a1 /* U+3002 IDEOGRAPHIC FULL STOP */ -#define XK_kana_openingbracket 0x04a2 /* U+300C LEFT CORNER BRACKET */ -#define XK_kana_closingbracket 0x04a3 /* U+300D RIGHT CORNER BRACKET */ -#define XK_kana_comma 0x04a4 /* U+3001 IDEOGRAPHIC COMMA */ -#define XK_kana_conjunctive 0x04a5 /* U+30FB KATAKANA MIDDLE DOT */ -#define XK_kana_middledot 0x04a5 /* deprecated */ -#define XK_kana_WO 0x04a6 /* U+30F2 KATAKANA LETTER WO */ -#define XK_kana_a 0x04a7 /* U+30A1 KATAKANA LETTER SMALL A */ -#define XK_kana_i 0x04a8 /* U+30A3 KATAKANA LETTER SMALL I */ -#define XK_kana_u 0x04a9 /* U+30A5 KATAKANA LETTER SMALL U */ -#define XK_kana_e 0x04aa /* U+30A7 KATAKANA LETTER SMALL E */ -#define XK_kana_o 0x04ab /* U+30A9 KATAKANA LETTER SMALL O */ -#define XK_kana_ya 0x04ac /* U+30E3 KATAKANA LETTER SMALL YA */ -#define XK_kana_yu 0x04ad /* U+30E5 KATAKANA LETTER SMALL YU */ -#define XK_kana_yo 0x04ae /* U+30E7 KATAKANA LETTER SMALL YO */ -#define XK_kana_tsu 0x04af /* U+30C3 KATAKANA LETTER SMALL TU */ -#define XK_kana_tu 0x04af /* deprecated */ -#define XK_prolongedsound 0x04b0 /* U+30FC KATAKANA-HIRAGANA PROLONGED SOUND MARK */ -#define XK_kana_A 0x04b1 /* U+30A2 KATAKANA LETTER A */ -#define XK_kana_I 0x04b2 /* U+30A4 KATAKANA LETTER I */ -#define XK_kana_U 0x04b3 /* U+30A6 KATAKANA LETTER U */ -#define XK_kana_E 0x04b4 /* U+30A8 KATAKANA LETTER E */ -#define XK_kana_O 0x04b5 /* U+30AA KATAKANA LETTER O */ -#define XK_kana_KA 0x04b6 /* U+30AB KATAKANA LETTER KA */ -#define XK_kana_KI 0x04b7 /* U+30AD KATAKANA LETTER KI */ -#define XK_kana_KU 0x04b8 /* U+30AF KATAKANA LETTER KU */ -#define XK_kana_KE 0x04b9 /* U+30B1 KATAKANA LETTER KE */ -#define XK_kana_KO 0x04ba /* U+30B3 KATAKANA LETTER KO */ -#define XK_kana_SA 0x04bb /* U+30B5 KATAKANA LETTER SA */ -#define XK_kana_SHI 0x04bc /* U+30B7 KATAKANA LETTER SI */ -#define XK_kana_SU 0x04bd /* U+30B9 KATAKANA LETTER SU */ -#define XK_kana_SE 0x04be /* U+30BB KATAKANA LETTER SE */ -#define XK_kana_SO 0x04bf /* U+30BD KATAKANA LETTER SO */ -#define XK_kana_TA 0x04c0 /* U+30BF KATAKANA LETTER TA */ -#define XK_kana_CHI 0x04c1 /* U+30C1 KATAKANA LETTER TI */ -#define XK_kana_TI 0x04c1 /* deprecated */ -#define XK_kana_TSU 0x04c2 /* U+30C4 KATAKANA LETTER TU */ -#define XK_kana_TU 0x04c2 /* deprecated */ -#define XK_kana_TE 0x04c3 /* U+30C6 KATAKANA LETTER TE */ -#define XK_kana_TO 0x04c4 /* U+30C8 KATAKANA LETTER TO */ -#define XK_kana_NA 0x04c5 /* U+30CA KATAKANA LETTER NA */ -#define XK_kana_NI 0x04c6 /* U+30CB KATAKANA LETTER NI */ -#define XK_kana_NU 0x04c7 /* U+30CC KATAKANA LETTER NU */ -#define XK_kana_NE 0x04c8 /* U+30CD KATAKANA LETTER NE */ -#define XK_kana_NO 0x04c9 /* U+30CE KATAKANA LETTER NO */ -#define XK_kana_HA 0x04ca /* U+30CF KATAKANA LETTER HA */ -#define XK_kana_HI 0x04cb /* U+30D2 KATAKANA LETTER HI */ -#define XK_kana_FU 0x04cc /* U+30D5 KATAKANA LETTER HU */ -#define XK_kana_HU 0x04cc /* deprecated */ -#define XK_kana_HE 0x04cd /* U+30D8 KATAKANA LETTER HE */ -#define XK_kana_HO 0x04ce /* U+30DB KATAKANA LETTER HO */ -#define XK_kana_MA 0x04cf /* U+30DE KATAKANA LETTER MA */ -#define XK_kana_MI 0x04d0 /* U+30DF KATAKANA LETTER MI */ -#define XK_kana_MU 0x04d1 /* U+30E0 KATAKANA LETTER MU */ -#define XK_kana_ME 0x04d2 /* U+30E1 KATAKANA LETTER ME */ -#define XK_kana_MO 0x04d3 /* U+30E2 KATAKANA LETTER MO */ -#define XK_kana_YA 0x04d4 /* U+30E4 KATAKANA LETTER YA */ -#define XK_kana_YU 0x04d5 /* U+30E6 KATAKANA LETTER YU */ -#define XK_kana_YO 0x04d6 /* U+30E8 KATAKANA LETTER YO */ -#define XK_kana_RA 0x04d7 /* U+30E9 KATAKANA LETTER RA */ -#define XK_kana_RI 0x04d8 /* U+30EA KATAKANA LETTER RI */ -#define XK_kana_RU 0x04d9 /* U+30EB KATAKANA LETTER RU */ -#define XK_kana_RE 0x04da /* U+30EC KATAKANA LETTER RE */ -#define XK_kana_RO 0x04db /* U+30ED KATAKANA LETTER RO */ -#define XK_kana_WA 0x04dc /* U+30EF KATAKANA LETTER WA */ -#define XK_kana_N 0x04dd /* U+30F3 KATAKANA LETTER N */ -#define XK_voicedsound 0x04de /* U+309B KATAKANA-HIRAGANA VOICED SOUND MARK */ -#define XK_semivoicedsound 0x04df /* U+309C KATAKANA-HIRAGANA SEMI-VOICED SOUND MARK */ -#define XK_kana_switch 0xff7e /* Alias for mode_switch */ -#endif /* XK_KATAKANA */ - -/* - * Arabic - * Byte 3 = 5 - */ - -#ifdef XK_ARABIC -#define XK_Farsi_0 0x10006f0 /* U+06F0 EXTENDED ARABIC-INDIC DIGIT ZERO */ -#define XK_Farsi_1 0x10006f1 /* U+06F1 EXTENDED ARABIC-INDIC DIGIT ONE */ -#define XK_Farsi_2 0x10006f2 /* U+06F2 EXTENDED ARABIC-INDIC DIGIT TWO */ -#define XK_Farsi_3 0x10006f3 /* U+06F3 EXTENDED ARABIC-INDIC DIGIT THREE */ -#define XK_Farsi_4 0x10006f4 /* U+06F4 EXTENDED ARABIC-INDIC DIGIT FOUR */ -#define XK_Farsi_5 0x10006f5 /* U+06F5 EXTENDED ARABIC-INDIC DIGIT FIVE */ -#define XK_Farsi_6 0x10006f6 /* U+06F6 EXTENDED ARABIC-INDIC DIGIT SIX */ -#define XK_Farsi_7 0x10006f7 /* U+06F7 EXTENDED ARABIC-INDIC DIGIT SEVEN */ -#define XK_Farsi_8 0x10006f8 /* U+06F8 EXTENDED ARABIC-INDIC DIGIT EIGHT */ -#define XK_Farsi_9 0x10006f9 /* U+06F9 EXTENDED ARABIC-INDIC DIGIT NINE */ -#define XK_Arabic_percent 0x100066a /* U+066A ARABIC PERCENT SIGN */ -#define XK_Arabic_superscript_alef 0x1000670 /* U+0670 ARABIC LETTER SUPERSCRIPT ALEF */ -#define XK_Arabic_tteh 0x1000679 /* U+0679 ARABIC LETTER TTEH */ -#define XK_Arabic_peh 0x100067e /* U+067E ARABIC LETTER PEH */ -#define XK_Arabic_tcheh 0x1000686 /* U+0686 ARABIC LETTER TCHEH */ -#define XK_Arabic_ddal 0x1000688 /* U+0688 ARABIC LETTER DDAL */ -#define XK_Arabic_rreh 0x1000691 /* U+0691 ARABIC LETTER RREH */ -#define XK_Arabic_comma 0x05ac /* U+060C ARABIC COMMA */ -#define XK_Arabic_fullstop 0x10006d4 /* U+06D4 ARABIC FULL STOP */ -#define XK_Arabic_0 0x1000660 /* U+0660 ARABIC-INDIC DIGIT ZERO */ -#define XK_Arabic_1 0x1000661 /* U+0661 ARABIC-INDIC DIGIT ONE */ -#define XK_Arabic_2 0x1000662 /* U+0662 ARABIC-INDIC DIGIT TWO */ -#define XK_Arabic_3 0x1000663 /* U+0663 ARABIC-INDIC DIGIT THREE */ -#define XK_Arabic_4 0x1000664 /* U+0664 ARABIC-INDIC DIGIT FOUR */ -#define XK_Arabic_5 0x1000665 /* U+0665 ARABIC-INDIC DIGIT FIVE */ -#define XK_Arabic_6 0x1000666 /* U+0666 ARABIC-INDIC DIGIT SIX */ -#define XK_Arabic_7 0x1000667 /* U+0667 ARABIC-INDIC DIGIT SEVEN */ -#define XK_Arabic_8 0x1000668 /* U+0668 ARABIC-INDIC DIGIT EIGHT */ -#define XK_Arabic_9 0x1000669 /* U+0669 ARABIC-INDIC DIGIT NINE */ -#define XK_Arabic_semicolon 0x05bb /* U+061B ARABIC SEMICOLON */ -#define XK_Arabic_question_mark 0x05bf /* U+061F ARABIC QUESTION MARK */ -#define XK_Arabic_hamza 0x05c1 /* U+0621 ARABIC LETTER HAMZA */ -#define XK_Arabic_maddaonalef 0x05c2 /* U+0622 ARABIC LETTER ALEF WITH MADDA ABOVE */ -#define XK_Arabic_hamzaonalef 0x05c3 /* U+0623 ARABIC LETTER ALEF WITH HAMZA ABOVE */ -#define XK_Arabic_hamzaonwaw 0x05c4 /* U+0624 ARABIC LETTER WAW WITH HAMZA ABOVE */ -#define XK_Arabic_hamzaunderalef 0x05c5 /* U+0625 ARABIC LETTER ALEF WITH HAMZA BELOW */ -#define XK_Arabic_hamzaonyeh 0x05c6 /* U+0626 ARABIC LETTER YEH WITH HAMZA ABOVE */ -#define XK_Arabic_alef 0x05c7 /* U+0627 ARABIC LETTER ALEF */ -#define XK_Arabic_beh 0x05c8 /* U+0628 ARABIC LETTER BEH */ -#define XK_Arabic_tehmarbuta 0x05c9 /* U+0629 ARABIC LETTER TEH MARBUTA */ -#define XK_Arabic_teh 0x05ca /* U+062A ARABIC LETTER TEH */ -#define XK_Arabic_theh 0x05cb /* U+062B ARABIC LETTER THEH */ -#define XK_Arabic_jeem 0x05cc /* U+062C ARABIC LETTER JEEM */ -#define XK_Arabic_hah 0x05cd /* U+062D ARABIC LETTER HAH */ -#define XK_Arabic_khah 0x05ce /* U+062E ARABIC LETTER KHAH */ -#define XK_Arabic_dal 0x05cf /* U+062F ARABIC LETTER DAL */ -#define XK_Arabic_thal 0x05d0 /* U+0630 ARABIC LETTER THAL */ -#define XK_Arabic_ra 0x05d1 /* U+0631 ARABIC LETTER REH */ -#define XK_Arabic_zain 0x05d2 /* U+0632 ARABIC LETTER ZAIN */ -#define XK_Arabic_seen 0x05d3 /* U+0633 ARABIC LETTER SEEN */ -#define XK_Arabic_sheen 0x05d4 /* U+0634 ARABIC LETTER SHEEN */ -#define XK_Arabic_sad 0x05d5 /* U+0635 ARABIC LETTER SAD */ -#define XK_Arabic_dad 0x05d6 /* U+0636 ARABIC LETTER DAD */ -#define XK_Arabic_tah 0x05d7 /* U+0637 ARABIC LETTER TAH */ -#define XK_Arabic_zah 0x05d8 /* U+0638 ARABIC LETTER ZAH */ -#define XK_Arabic_ain 0x05d9 /* U+0639 ARABIC LETTER AIN */ -#define XK_Arabic_ghain 0x05da /* U+063A ARABIC LETTER GHAIN */ -#define XK_Arabic_tatweel 0x05e0 /* U+0640 ARABIC TATWEEL */ -#define XK_Arabic_feh 0x05e1 /* U+0641 ARABIC LETTER FEH */ -#define XK_Arabic_qaf 0x05e2 /* U+0642 ARABIC LETTER QAF */ -#define XK_Arabic_kaf 0x05e3 /* U+0643 ARABIC LETTER KAF */ -#define XK_Arabic_lam 0x05e4 /* U+0644 ARABIC LETTER LAM */ -#define XK_Arabic_meem 0x05e5 /* U+0645 ARABIC LETTER MEEM */ -#define XK_Arabic_noon 0x05e6 /* U+0646 ARABIC LETTER NOON */ -#define XK_Arabic_ha 0x05e7 /* U+0647 ARABIC LETTER HEH */ -#define XK_Arabic_heh 0x05e7 /* deprecated */ -#define XK_Arabic_waw 0x05e8 /* U+0648 ARABIC LETTER WAW */ -#define XK_Arabic_alefmaksura 0x05e9 /* U+0649 ARABIC LETTER ALEF MAKSURA */ -#define XK_Arabic_yeh 0x05ea /* U+064A ARABIC LETTER YEH */ -#define XK_Arabic_fathatan 0x05eb /* U+064B ARABIC FATHATAN */ -#define XK_Arabic_dammatan 0x05ec /* U+064C ARABIC DAMMATAN */ -#define XK_Arabic_kasratan 0x05ed /* U+064D ARABIC KASRATAN */ -#define XK_Arabic_fatha 0x05ee /* U+064E ARABIC FATHA */ -#define XK_Arabic_damma 0x05ef /* U+064F ARABIC DAMMA */ -#define XK_Arabic_kasra 0x05f0 /* U+0650 ARABIC KASRA */ -#define XK_Arabic_shadda 0x05f1 /* U+0651 ARABIC SHADDA */ -#define XK_Arabic_sukun 0x05f2 /* U+0652 ARABIC SUKUN */ -#define XK_Arabic_madda_above 0x1000653 /* U+0653 ARABIC MADDAH ABOVE */ -#define XK_Arabic_hamza_above 0x1000654 /* U+0654 ARABIC HAMZA ABOVE */ -#define XK_Arabic_hamza_below 0x1000655 /* U+0655 ARABIC HAMZA BELOW */ -#define XK_Arabic_jeh 0x1000698 /* U+0698 ARABIC LETTER JEH */ -#define XK_Arabic_veh 0x10006a4 /* U+06A4 ARABIC LETTER VEH */ -#define XK_Arabic_keheh 0x10006a9 /* U+06A9 ARABIC LETTER KEHEH */ -#define XK_Arabic_gaf 0x10006af /* U+06AF ARABIC LETTER GAF */ -#define XK_Arabic_noon_ghunna 0x10006ba /* U+06BA ARABIC LETTER NOON GHUNNA */ -#define XK_Arabic_heh_doachashmee 0x10006be /* U+06BE ARABIC LETTER HEH DOACHASHMEE */ -#define XK_Farsi_yeh 0x10006cc /* U+06CC ARABIC LETTER FARSI YEH */ -#define XK_Arabic_farsi_yeh 0x10006cc /* U+06CC ARABIC LETTER FARSI YEH */ -#define XK_Arabic_yeh_baree 0x10006d2 /* U+06D2 ARABIC LETTER YEH BARREE */ -#define XK_Arabic_heh_goal 0x10006c1 /* U+06C1 ARABIC LETTER HEH GOAL */ -#define XK_Arabic_switch 0xff7e /* Alias for mode_switch */ -#endif /* XK_ARABIC */ - -/* - * Cyrillic - * Byte 3 = 6 - */ -#ifdef XK_CYRILLIC -#define XK_Cyrillic_GHE_bar 0x1000492 /* U+0492 CYRILLIC CAPITAL LETTER GHE WITH STROKE */ -#define XK_Cyrillic_ghe_bar 0x1000493 /* U+0493 CYRILLIC SMALL LETTER GHE WITH STROKE */ -#define XK_Cyrillic_ZHE_descender 0x1000496 /* U+0496 CYRILLIC CAPITAL LETTER ZHE WITH DESCENDER */ -#define XK_Cyrillic_zhe_descender 0x1000497 /* U+0497 CYRILLIC SMALL LETTER ZHE WITH DESCENDER */ -#define XK_Cyrillic_KA_descender 0x100049a /* U+049A CYRILLIC CAPITAL LETTER KA WITH DESCENDER */ -#define XK_Cyrillic_ka_descender 0x100049b /* U+049B CYRILLIC SMALL LETTER KA WITH DESCENDER */ -#define XK_Cyrillic_KA_vertstroke 0x100049c /* U+049C CYRILLIC CAPITAL LETTER KA WITH VERTICAL STROKE */ -#define XK_Cyrillic_ka_vertstroke 0x100049d /* U+049D CYRILLIC SMALL LETTER KA WITH VERTICAL STROKE */ -#define XK_Cyrillic_EN_descender 0x10004a2 /* U+04A2 CYRILLIC CAPITAL LETTER EN WITH DESCENDER */ -#define XK_Cyrillic_en_descender 0x10004a3 /* U+04A3 CYRILLIC SMALL LETTER EN WITH DESCENDER */ -#define XK_Cyrillic_U_straight 0x10004ae /* U+04AE CYRILLIC CAPITAL LETTER STRAIGHT U */ -#define XK_Cyrillic_u_straight 0x10004af /* U+04AF CYRILLIC SMALL LETTER STRAIGHT U */ -#define XK_Cyrillic_U_straight_bar 0x10004b0 /* U+04B0 CYRILLIC CAPITAL LETTER STRAIGHT U WITH STROKE */ -#define XK_Cyrillic_u_straight_bar 0x10004b1 /* U+04B1 CYRILLIC SMALL LETTER STRAIGHT U WITH STROKE */ -#define XK_Cyrillic_HA_descender 0x10004b2 /* U+04B2 CYRILLIC CAPITAL LETTER HA WITH DESCENDER */ -#define XK_Cyrillic_ha_descender 0x10004b3 /* U+04B3 CYRILLIC SMALL LETTER HA WITH DESCENDER */ -#define XK_Cyrillic_CHE_descender 0x10004b6 /* U+04B6 CYRILLIC CAPITAL LETTER CHE WITH DESCENDER */ -#define XK_Cyrillic_che_descender 0x10004b7 /* U+04B7 CYRILLIC SMALL LETTER CHE WITH DESCENDER */ -#define XK_Cyrillic_CHE_vertstroke 0x10004b8 /* U+04B8 CYRILLIC CAPITAL LETTER CHE WITH VERTICAL STROKE */ -#define XK_Cyrillic_che_vertstroke 0x10004b9 /* U+04B9 CYRILLIC SMALL LETTER CHE WITH VERTICAL STROKE */ -#define XK_Cyrillic_SHHA 0x10004ba /* U+04BA CYRILLIC CAPITAL LETTER SHHA */ -#define XK_Cyrillic_shha 0x10004bb /* U+04BB CYRILLIC SMALL LETTER SHHA */ - -#define XK_Cyrillic_SCHWA 0x10004d8 /* U+04D8 CYRILLIC CAPITAL LETTER SCHWA */ -#define XK_Cyrillic_schwa 0x10004d9 /* U+04D9 CYRILLIC SMALL LETTER SCHWA */ -#define XK_Cyrillic_I_macron 0x10004e2 /* U+04E2 CYRILLIC CAPITAL LETTER I WITH MACRON */ -#define XK_Cyrillic_i_macron 0x10004e3 /* U+04E3 CYRILLIC SMALL LETTER I WITH MACRON */ -#define XK_Cyrillic_O_bar 0x10004e8 /* U+04E8 CYRILLIC CAPITAL LETTER BARRED O */ -#define XK_Cyrillic_o_bar 0x10004e9 /* U+04E9 CYRILLIC SMALL LETTER BARRED O */ -#define XK_Cyrillic_U_macron 0x10004ee /* U+04EE CYRILLIC CAPITAL LETTER U WITH MACRON */ -#define XK_Cyrillic_u_macron 0x10004ef /* U+04EF CYRILLIC SMALL LETTER U WITH MACRON */ - -#define XK_Serbian_dje 0x06a1 /* U+0452 CYRILLIC SMALL LETTER DJE */ -#define XK_Macedonia_gje 0x06a2 /* U+0453 CYRILLIC SMALL LETTER GJE */ -#define XK_Cyrillic_io 0x06a3 /* U+0451 CYRILLIC SMALL LETTER IO */ -#define XK_Ukrainian_ie 0x06a4 /* U+0454 CYRILLIC SMALL LETTER UKRAINIAN IE */ -#define XK_Ukranian_je 0x06a4 /* deprecated */ -#define XK_Macedonia_dse 0x06a5 /* U+0455 CYRILLIC SMALL LETTER DZE */ -#define XK_Ukrainian_i 0x06a6 /* U+0456 CYRILLIC SMALL LETTER BYELORUSSIAN-UKRAINIAN I */ -#define XK_Ukranian_i 0x06a6 /* deprecated */ -#define XK_Ukrainian_yi 0x06a7 /* U+0457 CYRILLIC SMALL LETTER YI */ -#define XK_Ukranian_yi 0x06a7 /* deprecated */ -#define XK_Cyrillic_je 0x06a8 /* U+0458 CYRILLIC SMALL LETTER JE */ -#define XK_Serbian_je 0x06a8 /* deprecated */ -#define XK_Cyrillic_lje 0x06a9 /* U+0459 CYRILLIC SMALL LETTER LJE */ -#define XK_Serbian_lje 0x06a9 /* deprecated */ -#define XK_Cyrillic_nje 0x06aa /* U+045A CYRILLIC SMALL LETTER NJE */ -#define XK_Serbian_nje 0x06aa /* deprecated */ -#define XK_Serbian_tshe 0x06ab /* U+045B CYRILLIC SMALL LETTER TSHE */ -#define XK_Macedonia_kje 0x06ac /* U+045C CYRILLIC SMALL LETTER KJE */ -#define XK_Ukrainian_ghe_with_upturn 0x06ad /* U+0491 CYRILLIC SMALL LETTER GHE WITH UPTURN */ -#define XK_Byelorussian_shortu 0x06ae /* U+045E CYRILLIC SMALL LETTER SHORT U */ -#define XK_Cyrillic_dzhe 0x06af /* U+045F CYRILLIC SMALL LETTER DZHE */ -#define XK_Serbian_dze 0x06af /* deprecated */ -#define XK_numerosign 0x06b0 /* U+2116 NUMERO SIGN */ -#define XK_Serbian_DJE 0x06b1 /* U+0402 CYRILLIC CAPITAL LETTER DJE */ -#define XK_Macedonia_GJE 0x06b2 /* U+0403 CYRILLIC CAPITAL LETTER GJE */ -#define XK_Cyrillic_IO 0x06b3 /* U+0401 CYRILLIC CAPITAL LETTER IO */ -#define XK_Ukrainian_IE 0x06b4 /* U+0404 CYRILLIC CAPITAL LETTER UKRAINIAN IE */ -#define XK_Ukranian_JE 0x06b4 /* deprecated */ -#define XK_Macedonia_DSE 0x06b5 /* U+0405 CYRILLIC CAPITAL LETTER DZE */ -#define XK_Ukrainian_I 0x06b6 /* U+0406 CYRILLIC CAPITAL LETTER BYELORUSSIAN-UKRAINIAN I */ -#define XK_Ukranian_I 0x06b6 /* deprecated */ -#define XK_Ukrainian_YI 0x06b7 /* U+0407 CYRILLIC CAPITAL LETTER YI */ -#define XK_Ukranian_YI 0x06b7 /* deprecated */ -#define XK_Cyrillic_JE 0x06b8 /* U+0408 CYRILLIC CAPITAL LETTER JE */ -#define XK_Serbian_JE 0x06b8 /* deprecated */ -#define XK_Cyrillic_LJE 0x06b9 /* U+0409 CYRILLIC CAPITAL LETTER LJE */ -#define XK_Serbian_LJE 0x06b9 /* deprecated */ -#define XK_Cyrillic_NJE 0x06ba /* U+040A CYRILLIC CAPITAL LETTER NJE */ -#define XK_Serbian_NJE 0x06ba /* deprecated */ -#define XK_Serbian_TSHE 0x06bb /* U+040B CYRILLIC CAPITAL LETTER TSHE */ -#define XK_Macedonia_KJE 0x06bc /* U+040C CYRILLIC CAPITAL LETTER KJE */ -#define XK_Ukrainian_GHE_WITH_UPTURN 0x06bd /* U+0490 CYRILLIC CAPITAL LETTER GHE WITH UPTURN */ -#define XK_Byelorussian_SHORTU 0x06be /* U+040E CYRILLIC CAPITAL LETTER SHORT U */ -#define XK_Cyrillic_DZHE 0x06bf /* U+040F CYRILLIC CAPITAL LETTER DZHE */ -#define XK_Serbian_DZE 0x06bf /* deprecated */ -#define XK_Cyrillic_yu 0x06c0 /* U+044E CYRILLIC SMALL LETTER YU */ -#define XK_Cyrillic_a 0x06c1 /* U+0430 CYRILLIC SMALL LETTER A */ -#define XK_Cyrillic_be 0x06c2 /* U+0431 CYRILLIC SMALL LETTER BE */ -#define XK_Cyrillic_tse 0x06c3 /* U+0446 CYRILLIC SMALL LETTER TSE */ -#define XK_Cyrillic_de 0x06c4 /* U+0434 CYRILLIC SMALL LETTER DE */ -#define XK_Cyrillic_ie 0x06c5 /* U+0435 CYRILLIC SMALL LETTER IE */ -#define XK_Cyrillic_ef 0x06c6 /* U+0444 CYRILLIC SMALL LETTER EF */ -#define XK_Cyrillic_ghe 0x06c7 /* U+0433 CYRILLIC SMALL LETTER GHE */ -#define XK_Cyrillic_ha 0x06c8 /* U+0445 CYRILLIC SMALL LETTER HA */ -#define XK_Cyrillic_i 0x06c9 /* U+0438 CYRILLIC SMALL LETTER I */ -#define XK_Cyrillic_shorti 0x06ca /* U+0439 CYRILLIC SMALL LETTER SHORT I */ -#define XK_Cyrillic_ka 0x06cb /* U+043A CYRILLIC SMALL LETTER KA */ -#define XK_Cyrillic_el 0x06cc /* U+043B CYRILLIC SMALL LETTER EL */ -#define XK_Cyrillic_em 0x06cd /* U+043C CYRILLIC SMALL LETTER EM */ -#define XK_Cyrillic_en 0x06ce /* U+043D CYRILLIC SMALL LETTER EN */ -#define XK_Cyrillic_o 0x06cf /* U+043E CYRILLIC SMALL LETTER O */ -#define XK_Cyrillic_pe 0x06d0 /* U+043F CYRILLIC SMALL LETTER PE */ -#define XK_Cyrillic_ya 0x06d1 /* U+044F CYRILLIC SMALL LETTER YA */ -#define XK_Cyrillic_er 0x06d2 /* U+0440 CYRILLIC SMALL LETTER ER */ -#define XK_Cyrillic_es 0x06d3 /* U+0441 CYRILLIC SMALL LETTER ES */ -#define XK_Cyrillic_te 0x06d4 /* U+0442 CYRILLIC SMALL LETTER TE */ -#define XK_Cyrillic_u 0x06d5 /* U+0443 CYRILLIC SMALL LETTER U */ -#define XK_Cyrillic_zhe 0x06d6 /* U+0436 CYRILLIC SMALL LETTER ZHE */ -#define XK_Cyrillic_ve 0x06d7 /* U+0432 CYRILLIC SMALL LETTER VE */ -#define XK_Cyrillic_softsign 0x06d8 /* U+044C CYRILLIC SMALL LETTER SOFT SIGN */ -#define XK_Cyrillic_yeru 0x06d9 /* U+044B CYRILLIC SMALL LETTER YERU */ -#define XK_Cyrillic_ze 0x06da /* U+0437 CYRILLIC SMALL LETTER ZE */ -#define XK_Cyrillic_sha 0x06db /* U+0448 CYRILLIC SMALL LETTER SHA */ -#define XK_Cyrillic_e 0x06dc /* U+044D CYRILLIC SMALL LETTER E */ -#define XK_Cyrillic_shcha 0x06dd /* U+0449 CYRILLIC SMALL LETTER SHCHA */ -#define XK_Cyrillic_che 0x06de /* U+0447 CYRILLIC SMALL LETTER CHE */ -#define XK_Cyrillic_hardsign 0x06df /* U+044A CYRILLIC SMALL LETTER HARD SIGN */ -#define XK_Cyrillic_YU 0x06e0 /* U+042E CYRILLIC CAPITAL LETTER YU */ -#define XK_Cyrillic_A 0x06e1 /* U+0410 CYRILLIC CAPITAL LETTER A */ -#define XK_Cyrillic_BE 0x06e2 /* U+0411 CYRILLIC CAPITAL LETTER BE */ -#define XK_Cyrillic_TSE 0x06e3 /* U+0426 CYRILLIC CAPITAL LETTER TSE */ -#define XK_Cyrillic_DE 0x06e4 /* U+0414 CYRILLIC CAPITAL LETTER DE */ -#define XK_Cyrillic_IE 0x06e5 /* U+0415 CYRILLIC CAPITAL LETTER IE */ -#define XK_Cyrillic_EF 0x06e6 /* U+0424 CYRILLIC CAPITAL LETTER EF */ -#define XK_Cyrillic_GHE 0x06e7 /* U+0413 CYRILLIC CAPITAL LETTER GHE */ -#define XK_Cyrillic_HA 0x06e8 /* U+0425 CYRILLIC CAPITAL LETTER HA */ -#define XK_Cyrillic_I 0x06e9 /* U+0418 CYRILLIC CAPITAL LETTER I */ -#define XK_Cyrillic_SHORTI 0x06ea /* U+0419 CYRILLIC CAPITAL LETTER SHORT I */ -#define XK_Cyrillic_KA 0x06eb /* U+041A CYRILLIC CAPITAL LETTER KA */ -#define XK_Cyrillic_EL 0x06ec /* U+041B CYRILLIC CAPITAL LETTER EL */ -#define XK_Cyrillic_EM 0x06ed /* U+041C CYRILLIC CAPITAL LETTER EM */ -#define XK_Cyrillic_EN 0x06ee /* U+041D CYRILLIC CAPITAL LETTER EN */ -#define XK_Cyrillic_O 0x06ef /* U+041E CYRILLIC CAPITAL LETTER O */ -#define XK_Cyrillic_PE 0x06f0 /* U+041F CYRILLIC CAPITAL LETTER PE */ -#define XK_Cyrillic_YA 0x06f1 /* U+042F CYRILLIC CAPITAL LETTER YA */ -#define XK_Cyrillic_ER 0x06f2 /* U+0420 CYRILLIC CAPITAL LETTER ER */ -#define XK_Cyrillic_ES 0x06f3 /* U+0421 CYRILLIC CAPITAL LETTER ES */ -#define XK_Cyrillic_TE 0x06f4 /* U+0422 CYRILLIC CAPITAL LETTER TE */ -#define XK_Cyrillic_U 0x06f5 /* U+0423 CYRILLIC CAPITAL LETTER U */ -#define XK_Cyrillic_ZHE 0x06f6 /* U+0416 CYRILLIC CAPITAL LETTER ZHE */ -#define XK_Cyrillic_VE 0x06f7 /* U+0412 CYRILLIC CAPITAL LETTER VE */ -#define XK_Cyrillic_SOFTSIGN 0x06f8 /* U+042C CYRILLIC CAPITAL LETTER SOFT SIGN */ -#define XK_Cyrillic_YERU 0x06f9 /* U+042B CYRILLIC CAPITAL LETTER YERU */ -#define XK_Cyrillic_ZE 0x06fa /* U+0417 CYRILLIC CAPITAL LETTER ZE */ -#define XK_Cyrillic_SHA 0x06fb /* U+0428 CYRILLIC CAPITAL LETTER SHA */ -#define XK_Cyrillic_E 0x06fc /* U+042D CYRILLIC CAPITAL LETTER E */ -#define XK_Cyrillic_SHCHA 0x06fd /* U+0429 CYRILLIC CAPITAL LETTER SHCHA */ -#define XK_Cyrillic_CHE 0x06fe /* U+0427 CYRILLIC CAPITAL LETTER CHE */ -#define XK_Cyrillic_HARDSIGN 0x06ff /* U+042A CYRILLIC CAPITAL LETTER HARD SIGN */ -#endif /* XK_CYRILLIC */ - -/* - * Greek - * (based on an early draft of, and not quite identical to, ISO/IEC 8859-7) - * Byte 3 = 7 - */ - -#ifdef XK_GREEK -#define XK_Greek_ALPHAaccent 0x07a1 /* U+0386 GREEK CAPITAL LETTER ALPHA WITH TONOS */ -#define XK_Greek_EPSILONaccent 0x07a2 /* U+0388 GREEK CAPITAL LETTER EPSILON WITH TONOS */ -#define XK_Greek_ETAaccent 0x07a3 /* U+0389 GREEK CAPITAL LETTER ETA WITH TONOS */ -#define XK_Greek_IOTAaccent 0x07a4 /* U+038A GREEK CAPITAL LETTER IOTA WITH TONOS */ -#define XK_Greek_IOTAdieresis 0x07a5 /* U+03AA GREEK CAPITAL LETTER IOTA WITH DIALYTIKA */ -#define XK_Greek_IOTAdiaeresis 0x07a5 /* old typo */ -#define XK_Greek_OMICRONaccent 0x07a7 /* U+038C GREEK CAPITAL LETTER OMICRON WITH TONOS */ -#define XK_Greek_UPSILONaccent 0x07a8 /* U+038E GREEK CAPITAL LETTER UPSILON WITH TONOS */ -#define XK_Greek_UPSILONdieresis 0x07a9 /* U+03AB GREEK CAPITAL LETTER UPSILON WITH DIALYTIKA */ -#define XK_Greek_OMEGAaccent 0x07ab /* U+038F GREEK CAPITAL LETTER OMEGA WITH TONOS */ -#define XK_Greek_accentdieresis 0x07ae /* U+0385 GREEK DIALYTIKA TONOS */ -#define XK_Greek_horizbar 0x07af /* U+2015 HORIZONTAL BAR */ -#define XK_Greek_alphaaccent 0x07b1 /* U+03AC GREEK SMALL LETTER ALPHA WITH TONOS */ -#define XK_Greek_epsilonaccent 0x07b2 /* U+03AD GREEK SMALL LETTER EPSILON WITH TONOS */ -#define XK_Greek_etaaccent 0x07b3 /* U+03AE GREEK SMALL LETTER ETA WITH TONOS */ -#define XK_Greek_iotaaccent 0x07b4 /* U+03AF GREEK SMALL LETTER IOTA WITH TONOS */ -#define XK_Greek_iotadieresis 0x07b5 /* U+03CA GREEK SMALL LETTER IOTA WITH DIALYTIKA */ -#define XK_Greek_iotaaccentdieresis 0x07b6 /* U+0390 GREEK SMALL LETTER IOTA WITH DIALYTIKA AND TONOS */ -#define XK_Greek_omicronaccent 0x07b7 /* U+03CC GREEK SMALL LETTER OMICRON WITH TONOS */ -#define XK_Greek_upsilonaccent 0x07b8 /* U+03CD GREEK SMALL LETTER UPSILON WITH TONOS */ -#define XK_Greek_upsilondieresis 0x07b9 /* U+03CB GREEK SMALL LETTER UPSILON WITH DIALYTIKA */ -#define XK_Greek_upsilonaccentdieresis 0x07ba /* U+03B0 GREEK SMALL LETTER UPSILON WITH DIALYTIKA AND TONOS */ -#define XK_Greek_omegaaccent 0x07bb /* U+03CE GREEK SMALL LETTER OMEGA WITH TONOS */ -#define XK_Greek_ALPHA 0x07c1 /* U+0391 GREEK CAPITAL LETTER ALPHA */ -#define XK_Greek_BETA 0x07c2 /* U+0392 GREEK CAPITAL LETTER BETA */ -#define XK_Greek_GAMMA 0x07c3 /* U+0393 GREEK CAPITAL LETTER GAMMA */ -#define XK_Greek_DELTA 0x07c4 /* U+0394 GREEK CAPITAL LETTER DELTA */ -#define XK_Greek_EPSILON 0x07c5 /* U+0395 GREEK CAPITAL LETTER EPSILON */ -#define XK_Greek_ZETA 0x07c6 /* U+0396 GREEK CAPITAL LETTER ZETA */ -#define XK_Greek_ETA 0x07c7 /* U+0397 GREEK CAPITAL LETTER ETA */ -#define XK_Greek_THETA 0x07c8 /* U+0398 GREEK CAPITAL LETTER THETA */ -#define XK_Greek_IOTA 0x07c9 /* U+0399 GREEK CAPITAL LETTER IOTA */ -#define XK_Greek_KAPPA 0x07ca /* U+039A GREEK CAPITAL LETTER KAPPA */ -#define XK_Greek_LAMDA 0x07cb /* U+039B GREEK CAPITAL LETTER LAMDA */ -#define XK_Greek_LAMBDA 0x07cb /* U+039B GREEK CAPITAL LETTER LAMDA */ -#define XK_Greek_MU 0x07cc /* U+039C GREEK CAPITAL LETTER MU */ -#define XK_Greek_NU 0x07cd /* U+039D GREEK CAPITAL LETTER NU */ -#define XK_Greek_XI 0x07ce /* U+039E GREEK CAPITAL LETTER XI */ -#define XK_Greek_OMICRON 0x07cf /* U+039F GREEK CAPITAL LETTER OMICRON */ -#define XK_Greek_PI 0x07d0 /* U+03A0 GREEK CAPITAL LETTER PI */ -#define XK_Greek_RHO 0x07d1 /* U+03A1 GREEK CAPITAL LETTER RHO */ -#define XK_Greek_SIGMA 0x07d2 /* U+03A3 GREEK CAPITAL LETTER SIGMA */ -#define XK_Greek_TAU 0x07d4 /* U+03A4 GREEK CAPITAL LETTER TAU */ -#define XK_Greek_UPSILON 0x07d5 /* U+03A5 GREEK CAPITAL LETTER UPSILON */ -#define XK_Greek_PHI 0x07d6 /* U+03A6 GREEK CAPITAL LETTER PHI */ -#define XK_Greek_CHI 0x07d7 /* U+03A7 GREEK CAPITAL LETTER CHI */ -#define XK_Greek_PSI 0x07d8 /* U+03A8 GREEK CAPITAL LETTER PSI */ -#define XK_Greek_OMEGA 0x07d9 /* U+03A9 GREEK CAPITAL LETTER OMEGA */ -#define XK_Greek_alpha 0x07e1 /* U+03B1 GREEK SMALL LETTER ALPHA */ -#define XK_Greek_beta 0x07e2 /* U+03B2 GREEK SMALL LETTER BETA */ -#define XK_Greek_gamma 0x07e3 /* U+03B3 GREEK SMALL LETTER GAMMA */ -#define XK_Greek_delta 0x07e4 /* U+03B4 GREEK SMALL LETTER DELTA */ -#define XK_Greek_epsilon 0x07e5 /* U+03B5 GREEK SMALL LETTER EPSILON */ -#define XK_Greek_zeta 0x07e6 /* U+03B6 GREEK SMALL LETTER ZETA */ -#define XK_Greek_eta 0x07e7 /* U+03B7 GREEK SMALL LETTER ETA */ -#define XK_Greek_theta 0x07e8 /* U+03B8 GREEK SMALL LETTER THETA */ -#define XK_Greek_iota 0x07e9 /* U+03B9 GREEK SMALL LETTER IOTA */ -#define XK_Greek_kappa 0x07ea /* U+03BA GREEK SMALL LETTER KAPPA */ -#define XK_Greek_lamda 0x07eb /* U+03BB GREEK SMALL LETTER LAMDA */ -#define XK_Greek_lambda 0x07eb /* U+03BB GREEK SMALL LETTER LAMDA */ -#define XK_Greek_mu 0x07ec /* U+03BC GREEK SMALL LETTER MU */ -#define XK_Greek_nu 0x07ed /* U+03BD GREEK SMALL LETTER NU */ -#define XK_Greek_xi 0x07ee /* U+03BE GREEK SMALL LETTER XI */ -#define XK_Greek_omicron 0x07ef /* U+03BF GREEK SMALL LETTER OMICRON */ -#define XK_Greek_pi 0x07f0 /* U+03C0 GREEK SMALL LETTER PI */ -#define XK_Greek_rho 0x07f1 /* U+03C1 GREEK SMALL LETTER RHO */ -#define XK_Greek_sigma 0x07f2 /* U+03C3 GREEK SMALL LETTER SIGMA */ -#define XK_Greek_finalsmallsigma 0x07f3 /* U+03C2 GREEK SMALL LETTER FINAL SIGMA */ -#define XK_Greek_tau 0x07f4 /* U+03C4 GREEK SMALL LETTER TAU */ -#define XK_Greek_upsilon 0x07f5 /* U+03C5 GREEK SMALL LETTER UPSILON */ -#define XK_Greek_phi 0x07f6 /* U+03C6 GREEK SMALL LETTER PHI */ -#define XK_Greek_chi 0x07f7 /* U+03C7 GREEK SMALL LETTER CHI */ -#define XK_Greek_psi 0x07f8 /* U+03C8 GREEK SMALL LETTER PSI */ -#define XK_Greek_omega 0x07f9 /* U+03C9 GREEK SMALL LETTER OMEGA */ -#define XK_Greek_switch 0xff7e /* Alias for mode_switch */ -#endif /* XK_GREEK */ - -/* - * Technical - * (from the DEC VT330/VT420 Technical Character Set, http://vt100.net/charsets/technical.html) - * Byte 3 = 8 - */ - -#ifdef XK_TECHNICAL -#define XK_leftradical 0x08a1 /* U+23B7 RADICAL SYMBOL BOTTOM */ -#define XK_topleftradical 0x08a2 /*(U+250C BOX DRAWINGS LIGHT DOWN AND RIGHT)*/ -#define XK_horizconnector 0x08a3 /*(U+2500 BOX DRAWINGS LIGHT HORIZONTAL)*/ -#define XK_topintegral 0x08a4 /* U+2320 TOP HALF INTEGRAL */ -#define XK_botintegral 0x08a5 /* U+2321 BOTTOM HALF INTEGRAL */ -#define XK_vertconnector 0x08a6 /*(U+2502 BOX DRAWINGS LIGHT VERTICAL)*/ -#define XK_topleftsqbracket 0x08a7 /* U+23A1 LEFT SQUARE BRACKET UPPER CORNER */ -#define XK_botleftsqbracket 0x08a8 /* U+23A3 LEFT SQUARE BRACKET LOWER CORNER */ -#define XK_toprightsqbracket 0x08a9 /* U+23A4 RIGHT SQUARE BRACKET UPPER CORNER */ -#define XK_botrightsqbracket 0x08aa /* U+23A6 RIGHT SQUARE BRACKET LOWER CORNER */ -#define XK_topleftparens 0x08ab /* U+239B LEFT PARENTHESIS UPPER HOOK */ -#define XK_botleftparens 0x08ac /* U+239D LEFT PARENTHESIS LOWER HOOK */ -#define XK_toprightparens 0x08ad /* U+239E RIGHT PARENTHESIS UPPER HOOK */ -#define XK_botrightparens 0x08ae /* U+23A0 RIGHT PARENTHESIS LOWER HOOK */ -#define XK_leftmiddlecurlybrace 0x08af /* U+23A8 LEFT CURLY BRACKET MIDDLE PIECE */ -#define XK_rightmiddlecurlybrace 0x08b0 /* U+23AC RIGHT CURLY BRACKET MIDDLE PIECE */ -#define XK_topleftsummation 0x08b1 -#define XK_botleftsummation 0x08b2 -#define XK_topvertsummationconnector 0x08b3 -#define XK_botvertsummationconnector 0x08b4 -#define XK_toprightsummation 0x08b5 -#define XK_botrightsummation 0x08b6 -#define XK_rightmiddlesummation 0x08b7 -#define XK_lessthanequal 0x08bc /* U+2264 LESS-THAN OR EQUAL TO */ -#define XK_notequal 0x08bd /* U+2260 NOT EQUAL TO */ -#define XK_greaterthanequal 0x08be /* U+2265 GREATER-THAN OR EQUAL TO */ -#define XK_integral 0x08bf /* U+222B INTEGRAL */ -#define XK_therefore 0x08c0 /* U+2234 THEREFORE */ -#define XK_variation 0x08c1 /* U+221D PROPORTIONAL TO */ -#define XK_infinity 0x08c2 /* U+221E INFINITY */ -#define XK_nabla 0x08c5 /* U+2207 NABLA */ -#define XK_approximate 0x08c8 /* U+223C TILDE OPERATOR */ -#define XK_similarequal 0x08c9 /* U+2243 ASYMPTOTICALLY EQUAL TO */ -#define XK_ifonlyif 0x08cd /* U+21D4 LEFT RIGHT DOUBLE ARROW */ -#define XK_implies 0x08ce /* U+21D2 RIGHTWARDS DOUBLE ARROW */ -#define XK_identical 0x08cf /* U+2261 IDENTICAL TO */ -#define XK_radical 0x08d6 /* U+221A SQUARE ROOT */ -#define XK_includedin 0x08da /* U+2282 SUBSET OF */ -#define XK_includes 0x08db /* U+2283 SUPERSET OF */ -#define XK_intersection 0x08dc /* U+2229 INTERSECTION */ -#define XK_union 0x08dd /* U+222A UNION */ -#define XK_logicaland 0x08de /* U+2227 LOGICAL AND */ -#define XK_logicalor 0x08df /* U+2228 LOGICAL OR */ -#define XK_partialderivative 0x08ef /* U+2202 PARTIAL DIFFERENTIAL */ -#define XK_function 0x08f6 /* U+0192 LATIN SMALL LETTER F WITH HOOK */ -#define XK_leftarrow 0x08fb /* U+2190 LEFTWARDS ARROW */ -#define XK_uparrow 0x08fc /* U+2191 UPWARDS ARROW */ -#define XK_rightarrow 0x08fd /* U+2192 RIGHTWARDS ARROW */ -#define XK_downarrow 0x08fe /* U+2193 DOWNWARDS ARROW */ -#endif /* XK_TECHNICAL */ - -/* - * Special - * (from the DEC VT100 Special Graphics Character Set) - * Byte 3 = 9 - */ - -#ifdef XK_SPECIAL -#define XK_blank 0x09df -#define XK_soliddiamond 0x09e0 /* U+25C6 BLACK DIAMOND */ -#define XK_checkerboard 0x09e1 /* U+2592 MEDIUM SHADE */ -#define XK_ht 0x09e2 /* U+2409 SYMBOL FOR HORIZONTAL TABULATION */ -#define XK_ff 0x09e3 /* U+240C SYMBOL FOR FORM FEED */ -#define XK_cr 0x09e4 /* U+240D SYMBOL FOR CARRIAGE RETURN */ -#define XK_lf 0x09e5 /* U+240A SYMBOL FOR LINE FEED */ -#define XK_nl 0x09e8 /* U+2424 SYMBOL FOR NEWLINE */ -#define XK_vt 0x09e9 /* U+240B SYMBOL FOR VERTICAL TABULATION */ -#define XK_lowrightcorner 0x09ea /* U+2518 BOX DRAWINGS LIGHT UP AND LEFT */ -#define XK_uprightcorner 0x09eb /* U+2510 BOX DRAWINGS LIGHT DOWN AND LEFT */ -#define XK_upleftcorner 0x09ec /* U+250C BOX DRAWINGS LIGHT DOWN AND RIGHT */ -#define XK_lowleftcorner 0x09ed /* U+2514 BOX DRAWINGS LIGHT UP AND RIGHT */ -#define XK_crossinglines 0x09ee /* U+253C BOX DRAWINGS LIGHT VERTICAL AND HORIZONTAL */ -#define XK_horizlinescan1 0x09ef /* U+23BA HORIZONTAL SCAN LINE-1 */ -#define XK_horizlinescan3 0x09f0 /* U+23BB HORIZONTAL SCAN LINE-3 */ -#define XK_horizlinescan5 0x09f1 /* U+2500 BOX DRAWINGS LIGHT HORIZONTAL */ -#define XK_horizlinescan7 0x09f2 /* U+23BC HORIZONTAL SCAN LINE-7 */ -#define XK_horizlinescan9 0x09f3 /* U+23BD HORIZONTAL SCAN LINE-9 */ -#define XK_leftt 0x09f4 /* U+251C BOX DRAWINGS LIGHT VERTICAL AND RIGHT */ -#define XK_rightt 0x09f5 /* U+2524 BOX DRAWINGS LIGHT VERTICAL AND LEFT */ -#define XK_bott 0x09f6 /* U+2534 BOX DRAWINGS LIGHT UP AND HORIZONTAL */ -#define XK_topt 0x09f7 /* U+252C BOX DRAWINGS LIGHT DOWN AND HORIZONTAL */ -#define XK_vertbar 0x09f8 /* U+2502 BOX DRAWINGS LIGHT VERTICAL */ -#endif /* XK_SPECIAL */ - -/* - * Publishing - * (these are probably from a long forgotten DEC Publishing - * font that once shipped with DECwrite) - * Byte 3 = 0x0a - */ - -#ifdef XK_PUBLISHING -#define XK_emspace 0x0aa1 /* U+2003 EM SPACE */ -#define XK_enspace 0x0aa2 /* U+2002 EN SPACE */ -#define XK_em3space 0x0aa3 /* U+2004 THREE-PER-EM SPACE */ -#define XK_em4space 0x0aa4 /* U+2005 FOUR-PER-EM SPACE */ -#define XK_digitspace 0x0aa5 /* U+2007 FIGURE SPACE */ -#define XK_punctspace 0x0aa6 /* U+2008 PUNCTUATION SPACE */ -#define XK_thinspace 0x0aa7 /* U+2009 THIN SPACE */ -#define XK_hairspace 0x0aa8 /* U+200A HAIR SPACE */ -#define XK_emdash 0x0aa9 /* U+2014 EM DASH */ -#define XK_endash 0x0aaa /* U+2013 EN DASH */ -#define XK_signifblank 0x0aac /*(U+2423 OPEN BOX)*/ -#define XK_ellipsis 0x0aae /* U+2026 HORIZONTAL ELLIPSIS */ -#define XK_doubbaselinedot 0x0aaf /* U+2025 TWO DOT LEADER */ -#define XK_onethird 0x0ab0 /* U+2153 VULGAR FRACTION ONE THIRD */ -#define XK_twothirds 0x0ab1 /* U+2154 VULGAR FRACTION TWO THIRDS */ -#define XK_onefifth 0x0ab2 /* U+2155 VULGAR FRACTION ONE FIFTH */ -#define XK_twofifths 0x0ab3 /* U+2156 VULGAR FRACTION TWO FIFTHS */ -#define XK_threefifths 0x0ab4 /* U+2157 VULGAR FRACTION THREE FIFTHS */ -#define XK_fourfifths 0x0ab5 /* U+2158 VULGAR FRACTION FOUR FIFTHS */ -#define XK_onesixth 0x0ab6 /* U+2159 VULGAR FRACTION ONE SIXTH */ -#define XK_fivesixths 0x0ab7 /* U+215A VULGAR FRACTION FIVE SIXTHS */ -#define XK_careof 0x0ab8 /* U+2105 CARE OF */ -#define XK_figdash 0x0abb /* U+2012 FIGURE DASH */ -#define XK_leftanglebracket 0x0abc /*(U+27E8 MATHEMATICAL LEFT ANGLE BRACKET)*/ -#define XK_decimalpoint 0x0abd /*(U+002E FULL STOP)*/ -#define XK_rightanglebracket 0x0abe /*(U+27E9 MATHEMATICAL RIGHT ANGLE BRACKET)*/ -#define XK_marker 0x0abf -#define XK_oneeighth 0x0ac3 /* U+215B VULGAR FRACTION ONE EIGHTH */ -#define XK_threeeighths 0x0ac4 /* U+215C VULGAR FRACTION THREE EIGHTHS */ -#define XK_fiveeighths 0x0ac5 /* U+215D VULGAR FRACTION FIVE EIGHTHS */ -#define XK_seveneighths 0x0ac6 /* U+215E VULGAR FRACTION SEVEN EIGHTHS */ -#define XK_trademark 0x0ac9 /* U+2122 TRADE MARK SIGN */ -#define XK_signaturemark 0x0aca /*(U+2613 SALTIRE)*/ -#define XK_trademarkincircle 0x0acb -#define XK_leftopentriangle 0x0acc /*(U+25C1 WHITE LEFT-POINTING TRIANGLE)*/ -#define XK_rightopentriangle 0x0acd /*(U+25B7 WHITE RIGHT-POINTING TRIANGLE)*/ -#define XK_emopencircle 0x0ace /*(U+25CB WHITE CIRCLE)*/ -#define XK_emopenrectangle 0x0acf /*(U+25AF WHITE VERTICAL RECTANGLE)*/ -#define XK_leftsinglequotemark 0x0ad0 /* U+2018 LEFT SINGLE QUOTATION MARK */ -#define XK_rightsinglequotemark 0x0ad1 /* U+2019 RIGHT SINGLE QUOTATION MARK */ -#define XK_leftdoublequotemark 0x0ad2 /* U+201C LEFT DOUBLE QUOTATION MARK */ -#define XK_rightdoublequotemark 0x0ad3 /* U+201D RIGHT DOUBLE QUOTATION MARK */ -#define XK_prescription 0x0ad4 /* U+211E PRESCRIPTION TAKE */ -#define XK_permille 0x0ad5 /* U+2030 PER MILLE SIGN */ -#define XK_minutes 0x0ad6 /* U+2032 PRIME */ -#define XK_seconds 0x0ad7 /* U+2033 DOUBLE PRIME */ -#define XK_latincross 0x0ad9 /* U+271D LATIN CROSS */ -#define XK_hexagram 0x0ada -#define XK_filledrectbullet 0x0adb /*(U+25AC BLACK RECTANGLE)*/ -#define XK_filledlefttribullet 0x0adc /*(U+25C0 BLACK LEFT-POINTING TRIANGLE)*/ -#define XK_filledrighttribullet 0x0add /*(U+25B6 BLACK RIGHT-POINTING TRIANGLE)*/ -#define XK_emfilledcircle 0x0ade /*(U+25CF BLACK CIRCLE)*/ -#define XK_emfilledrect 0x0adf /*(U+25AE BLACK VERTICAL RECTANGLE)*/ -#define XK_enopencircbullet 0x0ae0 /*(U+25E6 WHITE BULLET)*/ -#define XK_enopensquarebullet 0x0ae1 /*(U+25AB WHITE SMALL SQUARE)*/ -#define XK_openrectbullet 0x0ae2 /*(U+25AD WHITE RECTANGLE)*/ -#define XK_opentribulletup 0x0ae3 /*(U+25B3 WHITE UP-POINTING TRIANGLE)*/ -#define XK_opentribulletdown 0x0ae4 /*(U+25BD WHITE DOWN-POINTING TRIANGLE)*/ -#define XK_openstar 0x0ae5 /*(U+2606 WHITE STAR)*/ -#define XK_enfilledcircbullet 0x0ae6 /*(U+2022 BULLET)*/ -#define XK_enfilledsqbullet 0x0ae7 /*(U+25AA BLACK SMALL SQUARE)*/ -#define XK_filledtribulletup 0x0ae8 /*(U+25B2 BLACK UP-POINTING TRIANGLE)*/ -#define XK_filledtribulletdown 0x0ae9 /*(U+25BC BLACK DOWN-POINTING TRIANGLE)*/ -#define XK_leftpointer 0x0aea /*(U+261C WHITE LEFT POINTING INDEX)*/ -#define XK_rightpointer 0x0aeb /*(U+261E WHITE RIGHT POINTING INDEX)*/ -#define XK_club 0x0aec /* U+2663 BLACK CLUB SUIT */ -#define XK_diamond 0x0aed /* U+2666 BLACK DIAMOND SUIT */ -#define XK_heart 0x0aee /* U+2665 BLACK HEART SUIT */ -#define XK_maltesecross 0x0af0 /* U+2720 MALTESE CROSS */ -#define XK_dagger 0x0af1 /* U+2020 DAGGER */ -#define XK_doubledagger 0x0af2 /* U+2021 DOUBLE DAGGER */ -#define XK_checkmark 0x0af3 /* U+2713 CHECK MARK */ -#define XK_ballotcross 0x0af4 /* U+2717 BALLOT X */ -#define XK_musicalsharp 0x0af5 /* U+266F MUSIC SHARP SIGN */ -#define XK_musicalflat 0x0af6 /* U+266D MUSIC FLAT SIGN */ -#define XK_malesymbol 0x0af7 /* U+2642 MALE SIGN */ -#define XK_femalesymbol 0x0af8 /* U+2640 FEMALE SIGN */ -#define XK_telephone 0x0af9 /* U+260E BLACK TELEPHONE */ -#define XK_telephonerecorder 0x0afa /* U+2315 TELEPHONE RECORDER */ -#define XK_phonographcopyright 0x0afb /* U+2117 SOUND RECORDING COPYRIGHT */ -#define XK_caret 0x0afc /* U+2038 CARET */ -#define XK_singlelowquotemark 0x0afd /* U+201A SINGLE LOW-9 QUOTATION MARK */ -#define XK_doublelowquotemark 0x0afe /* U+201E DOUBLE LOW-9 QUOTATION MARK */ -#define XK_cursor 0x0aff -#endif /* XK_PUBLISHING */ - -/* - * APL - * Byte 3 = 0x0b - */ - -#ifdef XK_APL -#define XK_leftcaret 0x0ba3 /*(U+003C LESS-THAN SIGN)*/ -#define XK_rightcaret 0x0ba6 /*(U+003E GREATER-THAN SIGN)*/ -#define XK_downcaret 0x0ba8 /*(U+2228 LOGICAL OR)*/ -#define XK_upcaret 0x0ba9 /*(U+2227 LOGICAL AND)*/ -#define XK_overbar 0x0bc0 /*(U+00AF MACRON)*/ -#define XK_downtack 0x0bc2 /* U+22A4 DOWN TACK */ -#define XK_upshoe 0x0bc3 /*(U+2229 INTERSECTION)*/ -#define XK_downstile 0x0bc4 /* U+230A LEFT FLOOR */ -#define XK_underbar 0x0bc6 /*(U+005F LOW LINE)*/ -#define XK_jot 0x0bca /* U+2218 RING OPERATOR */ -#define XK_quad 0x0bcc /* U+2395 APL FUNCTIONAL SYMBOL QUAD */ -#define XK_uptack 0x0bce /* U+22A5 UP TACK */ -#define XK_circle 0x0bcf /* U+25CB WHITE CIRCLE */ -#define XK_upstile 0x0bd3 /* U+2308 LEFT CEILING */ -#define XK_downshoe 0x0bd6 /*(U+222A UNION)*/ -#define XK_rightshoe 0x0bd8 /*(U+2283 SUPERSET OF)*/ -#define XK_leftshoe 0x0bda /*(U+2282 SUBSET OF)*/ -#define XK_lefttack 0x0bdc /* U+22A3 LEFT TACK */ -#define XK_righttack 0x0bfc /* U+22A2 RIGHT TACK */ -#endif /* XK_APL */ - -/* - * Hebrew - * Byte 3 = 0x0c - */ - -#ifdef XK_HEBREW -#define XK_hebrew_doublelowline 0x0cdf /* U+2017 DOUBLE LOW LINE */ -#define XK_hebrew_aleph 0x0ce0 /* U+05D0 HEBREW LETTER ALEF */ -#define XK_hebrew_bet 0x0ce1 /* U+05D1 HEBREW LETTER BET */ -#define XK_hebrew_beth 0x0ce1 /* deprecated */ -#define XK_hebrew_gimel 0x0ce2 /* U+05D2 HEBREW LETTER GIMEL */ -#define XK_hebrew_gimmel 0x0ce2 /* deprecated */ -#define XK_hebrew_dalet 0x0ce3 /* U+05D3 HEBREW LETTER DALET */ -#define XK_hebrew_daleth 0x0ce3 /* deprecated */ -#define XK_hebrew_he 0x0ce4 /* U+05D4 HEBREW LETTER HE */ -#define XK_hebrew_waw 0x0ce5 /* U+05D5 HEBREW LETTER VAV */ -#define XK_hebrew_zain 0x0ce6 /* U+05D6 HEBREW LETTER ZAYIN */ -#define XK_hebrew_zayin 0x0ce6 /* deprecated */ -#define XK_hebrew_chet 0x0ce7 /* U+05D7 HEBREW LETTER HET */ -#define XK_hebrew_het 0x0ce7 /* deprecated */ -#define XK_hebrew_tet 0x0ce8 /* U+05D8 HEBREW LETTER TET */ -#define XK_hebrew_teth 0x0ce8 /* deprecated */ -#define XK_hebrew_yod 0x0ce9 /* U+05D9 HEBREW LETTER YOD */ -#define XK_hebrew_finalkaph 0x0cea /* U+05DA HEBREW LETTER FINAL KAF */ -#define XK_hebrew_kaph 0x0ceb /* U+05DB HEBREW LETTER KAF */ -#define XK_hebrew_lamed 0x0cec /* U+05DC HEBREW LETTER LAMED */ -#define XK_hebrew_finalmem 0x0ced /* U+05DD HEBREW LETTER FINAL MEM */ -#define XK_hebrew_mem 0x0cee /* U+05DE HEBREW LETTER MEM */ -#define XK_hebrew_finalnun 0x0cef /* U+05DF HEBREW LETTER FINAL NUN */ -#define XK_hebrew_nun 0x0cf0 /* U+05E0 HEBREW LETTER NUN */ -#define XK_hebrew_samech 0x0cf1 /* U+05E1 HEBREW LETTER SAMEKH */ -#define XK_hebrew_samekh 0x0cf1 /* deprecated */ -#define XK_hebrew_ayin 0x0cf2 /* U+05E2 HEBREW LETTER AYIN */ -#define XK_hebrew_finalpe 0x0cf3 /* U+05E3 HEBREW LETTER FINAL PE */ -#define XK_hebrew_pe 0x0cf4 /* U+05E4 HEBREW LETTER PE */ -#define XK_hebrew_finalzade 0x0cf5 /* U+05E5 HEBREW LETTER FINAL TSADI */ -#define XK_hebrew_finalzadi 0x0cf5 /* deprecated */ -#define XK_hebrew_zade 0x0cf6 /* U+05E6 HEBREW LETTER TSADI */ -#define XK_hebrew_zadi 0x0cf6 /* deprecated */ -#define XK_hebrew_qoph 0x0cf7 /* U+05E7 HEBREW LETTER QOF */ -#define XK_hebrew_kuf 0x0cf7 /* deprecated */ -#define XK_hebrew_resh 0x0cf8 /* U+05E8 HEBREW LETTER RESH */ -#define XK_hebrew_shin 0x0cf9 /* U+05E9 HEBREW LETTER SHIN */ -#define XK_hebrew_taw 0x0cfa /* U+05EA HEBREW LETTER TAV */ -#define XK_hebrew_taf 0x0cfa /* deprecated */ -#define XK_Hebrew_switch 0xff7e /* Alias for mode_switch */ -#endif /* XK_HEBREW */ - -/* - * Thai - * Byte 3 = 0x0d - */ - -#ifdef XK_THAI -#define XK_Thai_kokai 0x0da1 /* U+0E01 THAI CHARACTER KO KAI */ -#define XK_Thai_khokhai 0x0da2 /* U+0E02 THAI CHARACTER KHO KHAI */ -#define XK_Thai_khokhuat 0x0da3 /* U+0E03 THAI CHARACTER KHO KHUAT */ -#define XK_Thai_khokhwai 0x0da4 /* U+0E04 THAI CHARACTER KHO KHWAI */ -#define XK_Thai_khokhon 0x0da5 /* U+0E05 THAI CHARACTER KHO KHON */ -#define XK_Thai_khorakhang 0x0da6 /* U+0E06 THAI CHARACTER KHO RAKHANG */ -#define XK_Thai_ngongu 0x0da7 /* U+0E07 THAI CHARACTER NGO NGU */ -#define XK_Thai_chochan 0x0da8 /* U+0E08 THAI CHARACTER CHO CHAN */ -#define XK_Thai_choching 0x0da9 /* U+0E09 THAI CHARACTER CHO CHING */ -#define XK_Thai_chochang 0x0daa /* U+0E0A THAI CHARACTER CHO CHANG */ -#define XK_Thai_soso 0x0dab /* U+0E0B THAI CHARACTER SO SO */ -#define XK_Thai_chochoe 0x0dac /* U+0E0C THAI CHARACTER CHO CHOE */ -#define XK_Thai_yoying 0x0dad /* U+0E0D THAI CHARACTER YO YING */ -#define XK_Thai_dochada 0x0dae /* U+0E0E THAI CHARACTER DO CHADA */ -#define XK_Thai_topatak 0x0daf /* U+0E0F THAI CHARACTER TO PATAK */ -#define XK_Thai_thothan 0x0db0 /* U+0E10 THAI CHARACTER THO THAN */ -#define XK_Thai_thonangmontho 0x0db1 /* U+0E11 THAI CHARACTER THO NANGMONTHO */ -#define XK_Thai_thophuthao 0x0db2 /* U+0E12 THAI CHARACTER THO PHUTHAO */ -#define XK_Thai_nonen 0x0db3 /* U+0E13 THAI CHARACTER NO NEN */ -#define XK_Thai_dodek 0x0db4 /* U+0E14 THAI CHARACTER DO DEK */ -#define XK_Thai_totao 0x0db5 /* U+0E15 THAI CHARACTER TO TAO */ -#define XK_Thai_thothung 0x0db6 /* U+0E16 THAI CHARACTER THO THUNG */ -#define XK_Thai_thothahan 0x0db7 /* U+0E17 THAI CHARACTER THO THAHAN */ -#define XK_Thai_thothong 0x0db8 /* U+0E18 THAI CHARACTER THO THONG */ -#define XK_Thai_nonu 0x0db9 /* U+0E19 THAI CHARACTER NO NU */ -#define XK_Thai_bobaimai 0x0dba /* U+0E1A THAI CHARACTER BO BAIMAI */ -#define XK_Thai_popla 0x0dbb /* U+0E1B THAI CHARACTER PO PLA */ -#define XK_Thai_phophung 0x0dbc /* U+0E1C THAI CHARACTER PHO PHUNG */ -#define XK_Thai_fofa 0x0dbd /* U+0E1D THAI CHARACTER FO FA */ -#define XK_Thai_phophan 0x0dbe /* U+0E1E THAI CHARACTER PHO PHAN */ -#define XK_Thai_fofan 0x0dbf /* U+0E1F THAI CHARACTER FO FAN */ -#define XK_Thai_phosamphao 0x0dc0 /* U+0E20 THAI CHARACTER PHO SAMPHAO */ -#define XK_Thai_moma 0x0dc1 /* U+0E21 THAI CHARACTER MO MA */ -#define XK_Thai_yoyak 0x0dc2 /* U+0E22 THAI CHARACTER YO YAK */ -#define XK_Thai_rorua 0x0dc3 /* U+0E23 THAI CHARACTER RO RUA */ -#define XK_Thai_ru 0x0dc4 /* U+0E24 THAI CHARACTER RU */ -#define XK_Thai_loling 0x0dc5 /* U+0E25 THAI CHARACTER LO LING */ -#define XK_Thai_lu 0x0dc6 /* U+0E26 THAI CHARACTER LU */ -#define XK_Thai_wowaen 0x0dc7 /* U+0E27 THAI CHARACTER WO WAEN */ -#define XK_Thai_sosala 0x0dc8 /* U+0E28 THAI CHARACTER SO SALA */ -#define XK_Thai_sorusi 0x0dc9 /* U+0E29 THAI CHARACTER SO RUSI */ -#define XK_Thai_sosua 0x0dca /* U+0E2A THAI CHARACTER SO SUA */ -#define XK_Thai_hohip 0x0dcb /* U+0E2B THAI CHARACTER HO HIP */ -#define XK_Thai_lochula 0x0dcc /* U+0E2C THAI CHARACTER LO CHULA */ -#define XK_Thai_oang 0x0dcd /* U+0E2D THAI CHARACTER O ANG */ -#define XK_Thai_honokhuk 0x0dce /* U+0E2E THAI CHARACTER HO NOKHUK */ -#define XK_Thai_paiyannoi 0x0dcf /* U+0E2F THAI CHARACTER PAIYANNOI */ -#define XK_Thai_saraa 0x0dd0 /* U+0E30 THAI CHARACTER SARA A */ -#define XK_Thai_maihanakat 0x0dd1 /* U+0E31 THAI CHARACTER MAI HAN-AKAT */ -#define XK_Thai_saraaa 0x0dd2 /* U+0E32 THAI CHARACTER SARA AA */ -#define XK_Thai_saraam 0x0dd3 /* U+0E33 THAI CHARACTER SARA AM */ -#define XK_Thai_sarai 0x0dd4 /* U+0E34 THAI CHARACTER SARA I */ -#define XK_Thai_saraii 0x0dd5 /* U+0E35 THAI CHARACTER SARA II */ -#define XK_Thai_saraue 0x0dd6 /* U+0E36 THAI CHARACTER SARA UE */ -#define XK_Thai_sarauee 0x0dd7 /* U+0E37 THAI CHARACTER SARA UEE */ -#define XK_Thai_sarau 0x0dd8 /* U+0E38 THAI CHARACTER SARA U */ -#define XK_Thai_sarauu 0x0dd9 /* U+0E39 THAI CHARACTER SARA UU */ -#define XK_Thai_phinthu 0x0dda /* U+0E3A THAI CHARACTER PHINTHU */ -#define XK_Thai_maihanakat_maitho 0x0dde -#define XK_Thai_baht 0x0ddf /* U+0E3F THAI CURRENCY SYMBOL BAHT */ -#define XK_Thai_sarae 0x0de0 /* U+0E40 THAI CHARACTER SARA E */ -#define XK_Thai_saraae 0x0de1 /* U+0E41 THAI CHARACTER SARA AE */ -#define XK_Thai_sarao 0x0de2 /* U+0E42 THAI CHARACTER SARA O */ -#define XK_Thai_saraaimaimuan 0x0de3 /* U+0E43 THAI CHARACTER SARA AI MAIMUAN */ -#define XK_Thai_saraaimaimalai 0x0de4 /* U+0E44 THAI CHARACTER SARA AI MAIMALAI */ -#define XK_Thai_lakkhangyao 0x0de5 /* U+0E45 THAI CHARACTER LAKKHANGYAO */ -#define XK_Thai_maiyamok 0x0de6 /* U+0E46 THAI CHARACTER MAIYAMOK */ -#define XK_Thai_maitaikhu 0x0de7 /* U+0E47 THAI CHARACTER MAITAIKHU */ -#define XK_Thai_maiek 0x0de8 /* U+0E48 THAI CHARACTER MAI EK */ -#define XK_Thai_maitho 0x0de9 /* U+0E49 THAI CHARACTER MAI THO */ -#define XK_Thai_maitri 0x0dea /* U+0E4A THAI CHARACTER MAI TRI */ -#define XK_Thai_maichattawa 0x0deb /* U+0E4B THAI CHARACTER MAI CHATTAWA */ -#define XK_Thai_thanthakhat 0x0dec /* U+0E4C THAI CHARACTER THANTHAKHAT */ -#define XK_Thai_nikhahit 0x0ded /* U+0E4D THAI CHARACTER NIKHAHIT */ -#define XK_Thai_leksun 0x0df0 /* U+0E50 THAI DIGIT ZERO */ -#define XK_Thai_leknung 0x0df1 /* U+0E51 THAI DIGIT ONE */ -#define XK_Thai_leksong 0x0df2 /* U+0E52 THAI DIGIT TWO */ -#define XK_Thai_leksam 0x0df3 /* U+0E53 THAI DIGIT THREE */ -#define XK_Thai_leksi 0x0df4 /* U+0E54 THAI DIGIT FOUR */ -#define XK_Thai_lekha 0x0df5 /* U+0E55 THAI DIGIT FIVE */ -#define XK_Thai_lekhok 0x0df6 /* U+0E56 THAI DIGIT SIX */ -#define XK_Thai_lekchet 0x0df7 /* U+0E57 THAI DIGIT SEVEN */ -#define XK_Thai_lekpaet 0x0df8 /* U+0E58 THAI DIGIT EIGHT */ -#define XK_Thai_lekkao 0x0df9 /* U+0E59 THAI DIGIT NINE */ -#endif /* XK_THAI */ - -/* - * Korean - * Byte 3 = 0x0e - */ - -#ifdef XK_KOREAN - -#define XK_Hangul 0xff31 /* Hangul start/stop(toggle) */ -#define XK_Hangul_Start 0xff32 /* Hangul start */ -#define XK_Hangul_End 0xff33 /* Hangul end, English start */ -#define XK_Hangul_Hanja 0xff34 /* Start Hangul->Hanja Conversion */ -#define XK_Hangul_Jamo 0xff35 /* Hangul Jamo mode */ -#define XK_Hangul_Romaja 0xff36 /* Hangul Romaja mode */ -#define XK_Hangul_Codeinput 0xff37 /* Hangul code input mode */ -#define XK_Hangul_Jeonja 0xff38 /* Jeonja mode */ -#define XK_Hangul_Banja 0xff39 /* Banja mode */ -#define XK_Hangul_PreHanja 0xff3a /* Pre Hanja conversion */ -#define XK_Hangul_PostHanja 0xff3b /* Post Hanja conversion */ -#define XK_Hangul_SingleCandidate 0xff3c /* Single candidate */ -#define XK_Hangul_MultipleCandidate 0xff3d /* Multiple candidate */ -#define XK_Hangul_PreviousCandidate 0xff3e /* Previous candidate */ -#define XK_Hangul_Special 0xff3f /* Special symbols */ -#define XK_Hangul_switch 0xff7e /* Alias for mode_switch */ - -/* Hangul Consonant Characters */ -#define XK_Hangul_Kiyeog 0x0ea1 -#define XK_Hangul_SsangKiyeog 0x0ea2 -#define XK_Hangul_KiyeogSios 0x0ea3 -#define XK_Hangul_Nieun 0x0ea4 -#define XK_Hangul_NieunJieuj 0x0ea5 -#define XK_Hangul_NieunHieuh 0x0ea6 -#define XK_Hangul_Dikeud 0x0ea7 -#define XK_Hangul_SsangDikeud 0x0ea8 -#define XK_Hangul_Rieul 0x0ea9 -#define XK_Hangul_RieulKiyeog 0x0eaa -#define XK_Hangul_RieulMieum 0x0eab -#define XK_Hangul_RieulPieub 0x0eac -#define XK_Hangul_RieulSios 0x0ead -#define XK_Hangul_RieulTieut 0x0eae -#define XK_Hangul_RieulPhieuf 0x0eaf -#define XK_Hangul_RieulHieuh 0x0eb0 -#define XK_Hangul_Mieum 0x0eb1 -#define XK_Hangul_Pieub 0x0eb2 -#define XK_Hangul_SsangPieub 0x0eb3 -#define XK_Hangul_PieubSios 0x0eb4 -#define XK_Hangul_Sios 0x0eb5 -#define XK_Hangul_SsangSios 0x0eb6 -#define XK_Hangul_Ieung 0x0eb7 -#define XK_Hangul_Jieuj 0x0eb8 -#define XK_Hangul_SsangJieuj 0x0eb9 -#define XK_Hangul_Cieuc 0x0eba -#define XK_Hangul_Khieuq 0x0ebb -#define XK_Hangul_Tieut 0x0ebc -#define XK_Hangul_Phieuf 0x0ebd -#define XK_Hangul_Hieuh 0x0ebe - -/* Hangul Vowel Characters */ -#define XK_Hangul_A 0x0ebf -#define XK_Hangul_AE 0x0ec0 -#define XK_Hangul_YA 0x0ec1 -#define XK_Hangul_YAE 0x0ec2 -#define XK_Hangul_EO 0x0ec3 -#define XK_Hangul_E 0x0ec4 -#define XK_Hangul_YEO 0x0ec5 -#define XK_Hangul_YE 0x0ec6 -#define XK_Hangul_O 0x0ec7 -#define XK_Hangul_WA 0x0ec8 -#define XK_Hangul_WAE 0x0ec9 -#define XK_Hangul_OE 0x0eca -#define XK_Hangul_YO 0x0ecb -#define XK_Hangul_U 0x0ecc -#define XK_Hangul_WEO 0x0ecd -#define XK_Hangul_WE 0x0ece -#define XK_Hangul_WI 0x0ecf -#define XK_Hangul_YU 0x0ed0 -#define XK_Hangul_EU 0x0ed1 -#define XK_Hangul_YI 0x0ed2 -#define XK_Hangul_I 0x0ed3 - -/* Hangul syllable-final (JongSeong) Characters */ -#define XK_Hangul_J_Kiyeog 0x0ed4 -#define XK_Hangul_J_SsangKiyeog 0x0ed5 -#define XK_Hangul_J_KiyeogSios 0x0ed6 -#define XK_Hangul_J_Nieun 0x0ed7 -#define XK_Hangul_J_NieunJieuj 0x0ed8 -#define XK_Hangul_J_NieunHieuh 0x0ed9 -#define XK_Hangul_J_Dikeud 0x0eda -#define XK_Hangul_J_Rieul 0x0edb -#define XK_Hangul_J_RieulKiyeog 0x0edc -#define XK_Hangul_J_RieulMieum 0x0edd -#define XK_Hangul_J_RieulPieub 0x0ede -#define XK_Hangul_J_RieulSios 0x0edf -#define XK_Hangul_J_RieulTieut 0x0ee0 -#define XK_Hangul_J_RieulPhieuf 0x0ee1 -#define XK_Hangul_J_RieulHieuh 0x0ee2 -#define XK_Hangul_J_Mieum 0x0ee3 -#define XK_Hangul_J_Pieub 0x0ee4 -#define XK_Hangul_J_PieubSios 0x0ee5 -#define XK_Hangul_J_Sios 0x0ee6 -#define XK_Hangul_J_SsangSios 0x0ee7 -#define XK_Hangul_J_Ieung 0x0ee8 -#define XK_Hangul_J_Jieuj 0x0ee9 -#define XK_Hangul_J_Cieuc 0x0eea -#define XK_Hangul_J_Khieuq 0x0eeb -#define XK_Hangul_J_Tieut 0x0eec -#define XK_Hangul_J_Phieuf 0x0eed -#define XK_Hangul_J_Hieuh 0x0eee - -/* Ancient Hangul Consonant Characters */ -#define XK_Hangul_RieulYeorinHieuh 0x0eef -#define XK_Hangul_SunkyeongeumMieum 0x0ef0 -#define XK_Hangul_SunkyeongeumPieub 0x0ef1 -#define XK_Hangul_PanSios 0x0ef2 -#define XK_Hangul_KkogjiDalrinIeung 0x0ef3 -#define XK_Hangul_SunkyeongeumPhieuf 0x0ef4 -#define XK_Hangul_YeorinHieuh 0x0ef5 - -/* Ancient Hangul Vowel Characters */ -#define XK_Hangul_AraeA 0x0ef6 -#define XK_Hangul_AraeAE 0x0ef7 - -/* Ancient Hangul syllable-final (JongSeong) Characters */ -#define XK_Hangul_J_PanSios 0x0ef8 -#define XK_Hangul_J_KkogjiDalrinIeung 0x0ef9 -#define XK_Hangul_J_YeorinHieuh 0x0efa - -/* Korean currency symbol */ -#define XK_Korean_Won 0x0eff /*(U+20A9 WON SIGN)*/ - -#endif /* XK_KOREAN */ - -/* - * Armenian - */ - -#ifdef XK_ARMENIAN -#define XK_Armenian_ligature_ew 0x1000587 /* U+0587 ARMENIAN SMALL LIGATURE ECH YIWN */ -#define XK_Armenian_full_stop 0x1000589 /* U+0589 ARMENIAN FULL STOP */ -#define XK_Armenian_verjaket 0x1000589 /* U+0589 ARMENIAN FULL STOP */ -#define XK_Armenian_separation_mark 0x100055d /* U+055D ARMENIAN COMMA */ -#define XK_Armenian_but 0x100055d /* U+055D ARMENIAN COMMA */ -#define XK_Armenian_hyphen 0x100058a /* U+058A ARMENIAN HYPHEN */ -#define XK_Armenian_yentamna 0x100058a /* U+058A ARMENIAN HYPHEN */ -#define XK_Armenian_exclam 0x100055c /* U+055C ARMENIAN EXCLAMATION MARK */ -#define XK_Armenian_amanak 0x100055c /* U+055C ARMENIAN EXCLAMATION MARK */ -#define XK_Armenian_accent 0x100055b /* U+055B ARMENIAN EMPHASIS MARK */ -#define XK_Armenian_shesht 0x100055b /* U+055B ARMENIAN EMPHASIS MARK */ -#define XK_Armenian_question 0x100055e /* U+055E ARMENIAN QUESTION MARK */ -#define XK_Armenian_paruyk 0x100055e /* U+055E ARMENIAN QUESTION MARK */ -#define XK_Armenian_AYB 0x1000531 /* U+0531 ARMENIAN CAPITAL LETTER AYB */ -#define XK_Armenian_ayb 0x1000561 /* U+0561 ARMENIAN SMALL LETTER AYB */ -#define XK_Armenian_BEN 0x1000532 /* U+0532 ARMENIAN CAPITAL LETTER BEN */ -#define XK_Armenian_ben 0x1000562 /* U+0562 ARMENIAN SMALL LETTER BEN */ -#define XK_Armenian_GIM 0x1000533 /* U+0533 ARMENIAN CAPITAL LETTER GIM */ -#define XK_Armenian_gim 0x1000563 /* U+0563 ARMENIAN SMALL LETTER GIM */ -#define XK_Armenian_DA 0x1000534 /* U+0534 ARMENIAN CAPITAL LETTER DA */ -#define XK_Armenian_da 0x1000564 /* U+0564 ARMENIAN SMALL LETTER DA */ -#define XK_Armenian_YECH 0x1000535 /* U+0535 ARMENIAN CAPITAL LETTER ECH */ -#define XK_Armenian_yech 0x1000565 /* U+0565 ARMENIAN SMALL LETTER ECH */ -#define XK_Armenian_ZA 0x1000536 /* U+0536 ARMENIAN CAPITAL LETTER ZA */ -#define XK_Armenian_za 0x1000566 /* U+0566 ARMENIAN SMALL LETTER ZA */ -#define XK_Armenian_E 0x1000537 /* U+0537 ARMENIAN CAPITAL LETTER EH */ -#define XK_Armenian_e 0x1000567 /* U+0567 ARMENIAN SMALL LETTER EH */ -#define XK_Armenian_AT 0x1000538 /* U+0538 ARMENIAN CAPITAL LETTER ET */ -#define XK_Armenian_at 0x1000568 /* U+0568 ARMENIAN SMALL LETTER ET */ -#define XK_Armenian_TO 0x1000539 /* U+0539 ARMENIAN CAPITAL LETTER TO */ -#define XK_Armenian_to 0x1000569 /* U+0569 ARMENIAN SMALL LETTER TO */ -#define XK_Armenian_ZHE 0x100053a /* U+053A ARMENIAN CAPITAL LETTER ZHE */ -#define XK_Armenian_zhe 0x100056a /* U+056A ARMENIAN SMALL LETTER ZHE */ -#define XK_Armenian_INI 0x100053b /* U+053B ARMENIAN CAPITAL LETTER INI */ -#define XK_Armenian_ini 0x100056b /* U+056B ARMENIAN SMALL LETTER INI */ -#define XK_Armenian_LYUN 0x100053c /* U+053C ARMENIAN CAPITAL LETTER LIWN */ -#define XK_Armenian_lyun 0x100056c /* U+056C ARMENIAN SMALL LETTER LIWN */ -#define XK_Armenian_KHE 0x100053d /* U+053D ARMENIAN CAPITAL LETTER XEH */ -#define XK_Armenian_khe 0x100056d /* U+056D ARMENIAN SMALL LETTER XEH */ -#define XK_Armenian_TSA 0x100053e /* U+053E ARMENIAN CAPITAL LETTER CA */ -#define XK_Armenian_tsa 0x100056e /* U+056E ARMENIAN SMALL LETTER CA */ -#define XK_Armenian_KEN 0x100053f /* U+053F ARMENIAN CAPITAL LETTER KEN */ -#define XK_Armenian_ken 0x100056f /* U+056F ARMENIAN SMALL LETTER KEN */ -#define XK_Armenian_HO 0x1000540 /* U+0540 ARMENIAN CAPITAL LETTER HO */ -#define XK_Armenian_ho 0x1000570 /* U+0570 ARMENIAN SMALL LETTER HO */ -#define XK_Armenian_DZA 0x1000541 /* U+0541 ARMENIAN CAPITAL LETTER JA */ -#define XK_Armenian_dza 0x1000571 /* U+0571 ARMENIAN SMALL LETTER JA */ -#define XK_Armenian_GHAT 0x1000542 /* U+0542 ARMENIAN CAPITAL LETTER GHAD */ -#define XK_Armenian_ghat 0x1000572 /* U+0572 ARMENIAN SMALL LETTER GHAD */ -#define XK_Armenian_TCHE 0x1000543 /* U+0543 ARMENIAN CAPITAL LETTER CHEH */ -#define XK_Armenian_tche 0x1000573 /* U+0573 ARMENIAN SMALL LETTER CHEH */ -#define XK_Armenian_MEN 0x1000544 /* U+0544 ARMENIAN CAPITAL LETTER MEN */ -#define XK_Armenian_men 0x1000574 /* U+0574 ARMENIAN SMALL LETTER MEN */ -#define XK_Armenian_HI 0x1000545 /* U+0545 ARMENIAN CAPITAL LETTER YI */ -#define XK_Armenian_hi 0x1000575 /* U+0575 ARMENIAN SMALL LETTER YI */ -#define XK_Armenian_NU 0x1000546 /* U+0546 ARMENIAN CAPITAL LETTER NOW */ -#define XK_Armenian_nu 0x1000576 /* U+0576 ARMENIAN SMALL LETTER NOW */ -#define XK_Armenian_SHA 0x1000547 /* U+0547 ARMENIAN CAPITAL LETTER SHA */ -#define XK_Armenian_sha 0x1000577 /* U+0577 ARMENIAN SMALL LETTER SHA */ -#define XK_Armenian_VO 0x1000548 /* U+0548 ARMENIAN CAPITAL LETTER VO */ -#define XK_Armenian_vo 0x1000578 /* U+0578 ARMENIAN SMALL LETTER VO */ -#define XK_Armenian_CHA 0x1000549 /* U+0549 ARMENIAN CAPITAL LETTER CHA */ -#define XK_Armenian_cha 0x1000579 /* U+0579 ARMENIAN SMALL LETTER CHA */ -#define XK_Armenian_PE 0x100054a /* U+054A ARMENIAN CAPITAL LETTER PEH */ -#define XK_Armenian_pe 0x100057a /* U+057A ARMENIAN SMALL LETTER PEH */ -#define XK_Armenian_JE 0x100054b /* U+054B ARMENIAN CAPITAL LETTER JHEH */ -#define XK_Armenian_je 0x100057b /* U+057B ARMENIAN SMALL LETTER JHEH */ -#define XK_Armenian_RA 0x100054c /* U+054C ARMENIAN CAPITAL LETTER RA */ -#define XK_Armenian_ra 0x100057c /* U+057C ARMENIAN SMALL LETTER RA */ -#define XK_Armenian_SE 0x100054d /* U+054D ARMENIAN CAPITAL LETTER SEH */ -#define XK_Armenian_se 0x100057d /* U+057D ARMENIAN SMALL LETTER SEH */ -#define XK_Armenian_VEV 0x100054e /* U+054E ARMENIAN CAPITAL LETTER VEW */ -#define XK_Armenian_vev 0x100057e /* U+057E ARMENIAN SMALL LETTER VEW */ -#define XK_Armenian_TYUN 0x100054f /* U+054F ARMENIAN CAPITAL LETTER TIWN */ -#define XK_Armenian_tyun 0x100057f /* U+057F ARMENIAN SMALL LETTER TIWN */ -#define XK_Armenian_RE 0x1000550 /* U+0550 ARMENIAN CAPITAL LETTER REH */ -#define XK_Armenian_re 0x1000580 /* U+0580 ARMENIAN SMALL LETTER REH */ -#define XK_Armenian_TSO 0x1000551 /* U+0551 ARMENIAN CAPITAL LETTER CO */ -#define XK_Armenian_tso 0x1000581 /* U+0581 ARMENIAN SMALL LETTER CO */ -#define XK_Armenian_VYUN 0x1000552 /* U+0552 ARMENIAN CAPITAL LETTER YIWN */ -#define XK_Armenian_vyun 0x1000582 /* U+0582 ARMENIAN SMALL LETTER YIWN */ -#define XK_Armenian_PYUR 0x1000553 /* U+0553 ARMENIAN CAPITAL LETTER PIWR */ -#define XK_Armenian_pyur 0x1000583 /* U+0583 ARMENIAN SMALL LETTER PIWR */ -#define XK_Armenian_KE 0x1000554 /* U+0554 ARMENIAN CAPITAL LETTER KEH */ -#define XK_Armenian_ke 0x1000584 /* U+0584 ARMENIAN SMALL LETTER KEH */ -#define XK_Armenian_O 0x1000555 /* U+0555 ARMENIAN CAPITAL LETTER OH */ -#define XK_Armenian_o 0x1000585 /* U+0585 ARMENIAN SMALL LETTER OH */ -#define XK_Armenian_FE 0x1000556 /* U+0556 ARMENIAN CAPITAL LETTER FEH */ -#define XK_Armenian_fe 0x1000586 /* U+0586 ARMENIAN SMALL LETTER FEH */ -#define XK_Armenian_apostrophe 0x100055a /* U+055A ARMENIAN APOSTROPHE */ -#endif /* XK_ARMENIAN */ - -/* - * Georgian - */ - -#ifdef XK_GEORGIAN -#define XK_Georgian_an 0x10010d0 /* U+10D0 GEORGIAN LETTER AN */ -#define XK_Georgian_ban 0x10010d1 /* U+10D1 GEORGIAN LETTER BAN */ -#define XK_Georgian_gan 0x10010d2 /* U+10D2 GEORGIAN LETTER GAN */ -#define XK_Georgian_don 0x10010d3 /* U+10D3 GEORGIAN LETTER DON */ -#define XK_Georgian_en 0x10010d4 /* U+10D4 GEORGIAN LETTER EN */ -#define XK_Georgian_vin 0x10010d5 /* U+10D5 GEORGIAN LETTER VIN */ -#define XK_Georgian_zen 0x10010d6 /* U+10D6 GEORGIAN LETTER ZEN */ -#define XK_Georgian_tan 0x10010d7 /* U+10D7 GEORGIAN LETTER TAN */ -#define XK_Georgian_in 0x10010d8 /* U+10D8 GEORGIAN LETTER IN */ -#define XK_Georgian_kan 0x10010d9 /* U+10D9 GEORGIAN LETTER KAN */ -#define XK_Georgian_las 0x10010da /* U+10DA GEORGIAN LETTER LAS */ -#define XK_Georgian_man 0x10010db /* U+10DB GEORGIAN LETTER MAN */ -#define XK_Georgian_nar 0x10010dc /* U+10DC GEORGIAN LETTER NAR */ -#define XK_Georgian_on 0x10010dd /* U+10DD GEORGIAN LETTER ON */ -#define XK_Georgian_par 0x10010de /* U+10DE GEORGIAN LETTER PAR */ -#define XK_Georgian_zhar 0x10010df /* U+10DF GEORGIAN LETTER ZHAR */ -#define XK_Georgian_rae 0x10010e0 /* U+10E0 GEORGIAN LETTER RAE */ -#define XK_Georgian_san 0x10010e1 /* U+10E1 GEORGIAN LETTER SAN */ -#define XK_Georgian_tar 0x10010e2 /* U+10E2 GEORGIAN LETTER TAR */ -#define XK_Georgian_un 0x10010e3 /* U+10E3 GEORGIAN LETTER UN */ -#define XK_Georgian_phar 0x10010e4 /* U+10E4 GEORGIAN LETTER PHAR */ -#define XK_Georgian_khar 0x10010e5 /* U+10E5 GEORGIAN LETTER KHAR */ -#define XK_Georgian_ghan 0x10010e6 /* U+10E6 GEORGIAN LETTER GHAN */ -#define XK_Georgian_qar 0x10010e7 /* U+10E7 GEORGIAN LETTER QAR */ -#define XK_Georgian_shin 0x10010e8 /* U+10E8 GEORGIAN LETTER SHIN */ -#define XK_Georgian_chin 0x10010e9 /* U+10E9 GEORGIAN LETTER CHIN */ -#define XK_Georgian_can 0x10010ea /* U+10EA GEORGIAN LETTER CAN */ -#define XK_Georgian_jil 0x10010eb /* U+10EB GEORGIAN LETTER JIL */ -#define XK_Georgian_cil 0x10010ec /* U+10EC GEORGIAN LETTER CIL */ -#define XK_Georgian_char 0x10010ed /* U+10ED GEORGIAN LETTER CHAR */ -#define XK_Georgian_xan 0x10010ee /* U+10EE GEORGIAN LETTER XAN */ -#define XK_Georgian_jhan 0x10010ef /* U+10EF GEORGIAN LETTER JHAN */ -#define XK_Georgian_hae 0x10010f0 /* U+10F0 GEORGIAN LETTER HAE */ -#define XK_Georgian_he 0x10010f1 /* U+10F1 GEORGIAN LETTER HE */ -#define XK_Georgian_hie 0x10010f2 /* U+10F2 GEORGIAN LETTER HIE */ -#define XK_Georgian_we 0x10010f3 /* U+10F3 GEORGIAN LETTER WE */ -#define XK_Georgian_har 0x10010f4 /* U+10F4 GEORGIAN LETTER HAR */ -#define XK_Georgian_hoe 0x10010f5 /* U+10F5 GEORGIAN LETTER HOE */ -#define XK_Georgian_fi 0x10010f6 /* U+10F6 GEORGIAN LETTER FI */ -#endif /* XK_GEORGIAN */ - -/* - * Azeri (and other Turkic or Caucasian languages) - */ - -#ifdef XK_CAUCASUS -/* latin */ -#define XK_Xabovedot 0x1001e8a /* U+1E8A LATIN CAPITAL LETTER X WITH DOT ABOVE */ -#define XK_Ibreve 0x100012c /* U+012C LATIN CAPITAL LETTER I WITH BREVE */ -#define XK_Zstroke 0x10001b5 /* U+01B5 LATIN CAPITAL LETTER Z WITH STROKE */ -#define XK_Gcaron 0x10001e6 /* U+01E6 LATIN CAPITAL LETTER G WITH CARON */ -#define XK_Ocaron 0x10001d1 /* U+01D2 LATIN CAPITAL LETTER O WITH CARON */ -#define XK_Obarred 0x100019f /* U+019F LATIN CAPITAL LETTER O WITH MIDDLE TILDE */ -#define XK_xabovedot 0x1001e8b /* U+1E8B LATIN SMALL LETTER X WITH DOT ABOVE */ -#define XK_ibreve 0x100012d /* U+012D LATIN SMALL LETTER I WITH BREVE */ -#define XK_zstroke 0x10001b6 /* U+01B6 LATIN SMALL LETTER Z WITH STROKE */ -#define XK_gcaron 0x10001e7 /* U+01E7 LATIN SMALL LETTER G WITH CARON */ -#define XK_ocaron 0x10001d2 /* U+01D2 LATIN SMALL LETTER O WITH CARON */ -#define XK_obarred 0x1000275 /* U+0275 LATIN SMALL LETTER BARRED O */ -#define XK_SCHWA 0x100018f /* U+018F LATIN CAPITAL LETTER SCHWA */ -#define XK_schwa 0x1000259 /* U+0259 LATIN SMALL LETTER SCHWA */ -#define XK_EZH 0x10001b7 /* U+01B7 LATIN CAPITAL LETTER EZH */ -#define XK_ezh 0x1000292 /* U+0292 LATIN SMALL LETTER EZH */ -/* those are not really Caucasus */ -/* For Inupiak */ -#define XK_Lbelowdot 0x1001e36 /* U+1E36 LATIN CAPITAL LETTER L WITH DOT BELOW */ -#define XK_lbelowdot 0x1001e37 /* U+1E37 LATIN SMALL LETTER L WITH DOT BELOW */ -#endif /* XK_CAUCASUS */ - -/* - * Vietnamese - */ - -#ifdef XK_VIETNAMESE -#define XK_Abelowdot 0x1001ea0 /* U+1EA0 LATIN CAPITAL LETTER A WITH DOT BELOW */ -#define XK_abelowdot 0x1001ea1 /* U+1EA1 LATIN SMALL LETTER A WITH DOT BELOW */ -#define XK_Ahook 0x1001ea2 /* U+1EA2 LATIN CAPITAL LETTER A WITH HOOK ABOVE */ -#define XK_ahook 0x1001ea3 /* U+1EA3 LATIN SMALL LETTER A WITH HOOK ABOVE */ -#define XK_Acircumflexacute 0x1001ea4 /* U+1EA4 LATIN CAPITAL LETTER A WITH CIRCUMFLEX AND ACUTE */ -#define XK_acircumflexacute 0x1001ea5 /* U+1EA5 LATIN SMALL LETTER A WITH CIRCUMFLEX AND ACUTE */ -#define XK_Acircumflexgrave 0x1001ea6 /* U+1EA6 LATIN CAPITAL LETTER A WITH CIRCUMFLEX AND GRAVE */ -#define XK_acircumflexgrave 0x1001ea7 /* U+1EA7 LATIN SMALL LETTER A WITH CIRCUMFLEX AND GRAVE */ -#define XK_Acircumflexhook 0x1001ea8 /* U+1EA8 LATIN CAPITAL LETTER A WITH CIRCUMFLEX AND HOOK ABOVE */ -#define XK_acircumflexhook 0x1001ea9 /* U+1EA9 LATIN SMALL LETTER A WITH CIRCUMFLEX AND HOOK ABOVE */ -#define XK_Acircumflextilde 0x1001eaa /* U+1EAA LATIN CAPITAL LETTER A WITH CIRCUMFLEX AND TILDE */ -#define XK_acircumflextilde 0x1001eab /* U+1EAB LATIN SMALL LETTER A WITH CIRCUMFLEX AND TILDE */ -#define XK_Acircumflexbelowdot 0x1001eac /* U+1EAC LATIN CAPITAL LETTER A WITH CIRCUMFLEX AND DOT BELOW */ -#define XK_acircumflexbelowdot 0x1001ead /* U+1EAD LATIN SMALL LETTER A WITH CIRCUMFLEX AND DOT BELOW */ -#define XK_Abreveacute 0x1001eae /* U+1EAE LATIN CAPITAL LETTER A WITH BREVE AND ACUTE */ -#define XK_abreveacute 0x1001eaf /* U+1EAF LATIN SMALL LETTER A WITH BREVE AND ACUTE */ -#define XK_Abrevegrave 0x1001eb0 /* U+1EB0 LATIN CAPITAL LETTER A WITH BREVE AND GRAVE */ -#define XK_abrevegrave 0x1001eb1 /* U+1EB1 LATIN SMALL LETTER A WITH BREVE AND GRAVE */ -#define XK_Abrevehook 0x1001eb2 /* U+1EB2 LATIN CAPITAL LETTER A WITH BREVE AND HOOK ABOVE */ -#define XK_abrevehook 0x1001eb3 /* U+1EB3 LATIN SMALL LETTER A WITH BREVE AND HOOK ABOVE */ -#define XK_Abrevetilde 0x1001eb4 /* U+1EB4 LATIN CAPITAL LETTER A WITH BREVE AND TILDE */ -#define XK_abrevetilde 0x1001eb5 /* U+1EB5 LATIN SMALL LETTER A WITH BREVE AND TILDE */ -#define XK_Abrevebelowdot 0x1001eb6 /* U+1EB6 LATIN CAPITAL LETTER A WITH BREVE AND DOT BELOW */ -#define XK_abrevebelowdot 0x1001eb7 /* U+1EB7 LATIN SMALL LETTER A WITH BREVE AND DOT BELOW */ -#define XK_Ebelowdot 0x1001eb8 /* U+1EB8 LATIN CAPITAL LETTER E WITH DOT BELOW */ -#define XK_ebelowdot 0x1001eb9 /* U+1EB9 LATIN SMALL LETTER E WITH DOT BELOW */ -#define XK_Ehook 0x1001eba /* U+1EBA LATIN CAPITAL LETTER E WITH HOOK ABOVE */ -#define XK_ehook 0x1001ebb /* U+1EBB LATIN SMALL LETTER E WITH HOOK ABOVE */ -#define XK_Etilde 0x1001ebc /* U+1EBC LATIN CAPITAL LETTER E WITH TILDE */ -#define XK_etilde 0x1001ebd /* U+1EBD LATIN SMALL LETTER E WITH TILDE */ -#define XK_Ecircumflexacute 0x1001ebe /* U+1EBE LATIN CAPITAL LETTER E WITH CIRCUMFLEX AND ACUTE */ -#define XK_ecircumflexacute 0x1001ebf /* U+1EBF LATIN SMALL LETTER E WITH CIRCUMFLEX AND ACUTE */ -#define XK_Ecircumflexgrave 0x1001ec0 /* U+1EC0 LATIN CAPITAL LETTER E WITH CIRCUMFLEX AND GRAVE */ -#define XK_ecircumflexgrave 0x1001ec1 /* U+1EC1 LATIN SMALL LETTER E WITH CIRCUMFLEX AND GRAVE */ -#define XK_Ecircumflexhook 0x1001ec2 /* U+1EC2 LATIN CAPITAL LETTER E WITH CIRCUMFLEX AND HOOK ABOVE */ -#define XK_ecircumflexhook 0x1001ec3 /* U+1EC3 LATIN SMALL LETTER E WITH CIRCUMFLEX AND HOOK ABOVE */ -#define XK_Ecircumflextilde 0x1001ec4 /* U+1EC4 LATIN CAPITAL LETTER E WITH CIRCUMFLEX AND TILDE */ -#define XK_ecircumflextilde 0x1001ec5 /* U+1EC5 LATIN SMALL LETTER E WITH CIRCUMFLEX AND TILDE */ -#define XK_Ecircumflexbelowdot 0x1001ec6 /* U+1EC6 LATIN CAPITAL LETTER E WITH CIRCUMFLEX AND DOT BELOW */ -#define XK_ecircumflexbelowdot 0x1001ec7 /* U+1EC7 LATIN SMALL LETTER E WITH CIRCUMFLEX AND DOT BELOW */ -#define XK_Ihook 0x1001ec8 /* U+1EC8 LATIN CAPITAL LETTER I WITH HOOK ABOVE */ -#define XK_ihook 0x1001ec9 /* U+1EC9 LATIN SMALL LETTER I WITH HOOK ABOVE */ -#define XK_Ibelowdot 0x1001eca /* U+1ECA LATIN CAPITAL LETTER I WITH DOT BELOW */ -#define XK_ibelowdot 0x1001ecb /* U+1ECB LATIN SMALL LETTER I WITH DOT BELOW */ -#define XK_Obelowdot 0x1001ecc /* U+1ECC LATIN CAPITAL LETTER O WITH DOT BELOW */ -#define XK_obelowdot 0x1001ecd /* U+1ECD LATIN SMALL LETTER O WITH DOT BELOW */ -#define XK_Ohook 0x1001ece /* U+1ECE LATIN CAPITAL LETTER O WITH HOOK ABOVE */ -#define XK_ohook 0x1001ecf /* U+1ECF LATIN SMALL LETTER O WITH HOOK ABOVE */ -#define XK_Ocircumflexacute 0x1001ed0 /* U+1ED0 LATIN CAPITAL LETTER O WITH CIRCUMFLEX AND ACUTE */ -#define XK_ocircumflexacute 0x1001ed1 /* U+1ED1 LATIN SMALL LETTER O WITH CIRCUMFLEX AND ACUTE */ -#define XK_Ocircumflexgrave 0x1001ed2 /* U+1ED2 LATIN CAPITAL LETTER O WITH CIRCUMFLEX AND GRAVE */ -#define XK_ocircumflexgrave 0x1001ed3 /* U+1ED3 LATIN SMALL LETTER O WITH CIRCUMFLEX AND GRAVE */ -#define XK_Ocircumflexhook 0x1001ed4 /* U+1ED4 LATIN CAPITAL LETTER O WITH CIRCUMFLEX AND HOOK ABOVE */ -#define XK_ocircumflexhook 0x1001ed5 /* U+1ED5 LATIN SMALL LETTER O WITH CIRCUMFLEX AND HOOK ABOVE */ -#define XK_Ocircumflextilde 0x1001ed6 /* U+1ED6 LATIN CAPITAL LETTER O WITH CIRCUMFLEX AND TILDE */ -#define XK_ocircumflextilde 0x1001ed7 /* U+1ED7 LATIN SMALL LETTER O WITH CIRCUMFLEX AND TILDE */ -#define XK_Ocircumflexbelowdot 0x1001ed8 /* U+1ED8 LATIN CAPITAL LETTER O WITH CIRCUMFLEX AND DOT BELOW */ -#define XK_ocircumflexbelowdot 0x1001ed9 /* U+1ED9 LATIN SMALL LETTER O WITH CIRCUMFLEX AND DOT BELOW */ -#define XK_Ohornacute 0x1001eda /* U+1EDA LATIN CAPITAL LETTER O WITH HORN AND ACUTE */ -#define XK_ohornacute 0x1001edb /* U+1EDB LATIN SMALL LETTER O WITH HORN AND ACUTE */ -#define XK_Ohorngrave 0x1001edc /* U+1EDC LATIN CAPITAL LETTER O WITH HORN AND GRAVE */ -#define XK_ohorngrave 0x1001edd /* U+1EDD LATIN SMALL LETTER O WITH HORN AND GRAVE */ -#define XK_Ohornhook 0x1001ede /* U+1EDE LATIN CAPITAL LETTER O WITH HORN AND HOOK ABOVE */ -#define XK_ohornhook 0x1001edf /* U+1EDF LATIN SMALL LETTER O WITH HORN AND HOOK ABOVE */ -#define XK_Ohorntilde 0x1001ee0 /* U+1EE0 LATIN CAPITAL LETTER O WITH HORN AND TILDE */ -#define XK_ohorntilde 0x1001ee1 /* U+1EE1 LATIN SMALL LETTER O WITH HORN AND TILDE */ -#define XK_Ohornbelowdot 0x1001ee2 /* U+1EE2 LATIN CAPITAL LETTER O WITH HORN AND DOT BELOW */ -#define XK_ohornbelowdot 0x1001ee3 /* U+1EE3 LATIN SMALL LETTER O WITH HORN AND DOT BELOW */ -#define XK_Ubelowdot 0x1001ee4 /* U+1EE4 LATIN CAPITAL LETTER U WITH DOT BELOW */ -#define XK_ubelowdot 0x1001ee5 /* U+1EE5 LATIN SMALL LETTER U WITH DOT BELOW */ -#define XK_Uhook 0x1001ee6 /* U+1EE6 LATIN CAPITAL LETTER U WITH HOOK ABOVE */ -#define XK_uhook 0x1001ee7 /* U+1EE7 LATIN SMALL LETTER U WITH HOOK ABOVE */ -#define XK_Uhornacute 0x1001ee8 /* U+1EE8 LATIN CAPITAL LETTER U WITH HORN AND ACUTE */ -#define XK_uhornacute 0x1001ee9 /* U+1EE9 LATIN SMALL LETTER U WITH HORN AND ACUTE */ -#define XK_Uhorngrave 0x1001eea /* U+1EEA LATIN CAPITAL LETTER U WITH HORN AND GRAVE */ -#define XK_uhorngrave 0x1001eeb /* U+1EEB LATIN SMALL LETTER U WITH HORN AND GRAVE */ -#define XK_Uhornhook 0x1001eec /* U+1EEC LATIN CAPITAL LETTER U WITH HORN AND HOOK ABOVE */ -#define XK_uhornhook 0x1001eed /* U+1EED LATIN SMALL LETTER U WITH HORN AND HOOK ABOVE */ -#define XK_Uhorntilde 0x1001eee /* U+1EEE LATIN CAPITAL LETTER U WITH HORN AND TILDE */ -#define XK_uhorntilde 0x1001eef /* U+1EEF LATIN SMALL LETTER U WITH HORN AND TILDE */ -#define XK_Uhornbelowdot 0x1001ef0 /* U+1EF0 LATIN CAPITAL LETTER U WITH HORN AND DOT BELOW */ -#define XK_uhornbelowdot 0x1001ef1 /* U+1EF1 LATIN SMALL LETTER U WITH HORN AND DOT BELOW */ -#define XK_Ybelowdot 0x1001ef4 /* U+1EF4 LATIN CAPITAL LETTER Y WITH DOT BELOW */ -#define XK_ybelowdot 0x1001ef5 /* U+1EF5 LATIN SMALL LETTER Y WITH DOT BELOW */ -#define XK_Yhook 0x1001ef6 /* U+1EF6 LATIN CAPITAL LETTER Y WITH HOOK ABOVE */ -#define XK_yhook 0x1001ef7 /* U+1EF7 LATIN SMALL LETTER Y WITH HOOK ABOVE */ -#define XK_Ytilde 0x1001ef8 /* U+1EF8 LATIN CAPITAL LETTER Y WITH TILDE */ -#define XK_ytilde 0x1001ef9 /* U+1EF9 LATIN SMALL LETTER Y WITH TILDE */ -#define XK_Ohorn 0x10001a0 /* U+01A0 LATIN CAPITAL LETTER O WITH HORN */ -#define XK_ohorn 0x10001a1 /* U+01A1 LATIN SMALL LETTER O WITH HORN */ -#define XK_Uhorn 0x10001af /* U+01AF LATIN CAPITAL LETTER U WITH HORN */ -#define XK_uhorn 0x10001b0 /* U+01B0 LATIN SMALL LETTER U WITH HORN */ - -#endif /* XK_VIETNAMESE */ - -#ifdef XK_CURRENCY -#define XK_EcuSign 0x10020a0 /* U+20A0 EURO-CURRENCY SIGN */ -#define XK_ColonSign 0x10020a1 /* U+20A1 COLON SIGN */ -#define XK_CruzeiroSign 0x10020a2 /* U+20A2 CRUZEIRO SIGN */ -#define XK_FFrancSign 0x10020a3 /* U+20A3 FRENCH FRANC SIGN */ -#define XK_LiraSign 0x10020a4 /* U+20A4 LIRA SIGN */ -#define XK_MillSign 0x10020a5 /* U+20A5 MILL SIGN */ -#define XK_NairaSign 0x10020a6 /* U+20A6 NAIRA SIGN */ -#define XK_PesetaSign 0x10020a7 /* U+20A7 PESETA SIGN */ -#define XK_RupeeSign 0x10020a8 /* U+20A8 RUPEE SIGN */ -#define XK_WonSign 0x10020a9 /* U+20A9 WON SIGN */ -#define XK_NewSheqelSign 0x10020aa /* U+20AA NEW SHEQEL SIGN */ -#define XK_DongSign 0x10020ab /* U+20AB DONG SIGN */ -#define XK_EuroSign 0x20ac /* U+20AC EURO SIGN */ -#endif /* XK_CURRENCY */ - -#ifdef XK_MATHEMATICAL -/* one, two and three are defined above. */ -#define XK_zerosuperior 0x1002070 /* U+2070 SUPERSCRIPT ZERO */ -#define XK_foursuperior 0x1002074 /* U+2074 SUPERSCRIPT FOUR */ -#define XK_fivesuperior 0x1002075 /* U+2075 SUPERSCRIPT FIVE */ -#define XK_sixsuperior 0x1002076 /* U+2076 SUPERSCRIPT SIX */ -#define XK_sevensuperior 0x1002077 /* U+2077 SUPERSCRIPT SEVEN */ -#define XK_eightsuperior 0x1002078 /* U+2078 SUPERSCRIPT EIGHT */ -#define XK_ninesuperior 0x1002079 /* U+2079 SUPERSCRIPT NINE */ -#define XK_zerosubscript 0x1002080 /* U+2080 SUBSCRIPT ZERO */ -#define XK_onesubscript 0x1002081 /* U+2081 SUBSCRIPT ONE */ -#define XK_twosubscript 0x1002082 /* U+2082 SUBSCRIPT TWO */ -#define XK_threesubscript 0x1002083 /* U+2083 SUBSCRIPT THREE */ -#define XK_foursubscript 0x1002084 /* U+2084 SUBSCRIPT FOUR */ -#define XK_fivesubscript 0x1002085 /* U+2085 SUBSCRIPT FIVE */ -#define XK_sixsubscript 0x1002086 /* U+2086 SUBSCRIPT SIX */ -#define XK_sevensubscript 0x1002087 /* U+2087 SUBSCRIPT SEVEN */ -#define XK_eightsubscript 0x1002088 /* U+2088 SUBSCRIPT EIGHT */ -#define XK_ninesubscript 0x1002089 /* U+2089 SUBSCRIPT NINE */ -#define XK_partdifferential 0x1002202 /* U+2202 PARTIAL DIFFERENTIAL */ -#define XK_emptyset 0x1002205 /* U+2205 NULL SET */ -#define XK_elementof 0x1002208 /* U+2208 ELEMENT OF */ -#define XK_notelementof 0x1002209 /* U+2209 NOT AN ELEMENT OF */ -#define XK_containsas 0x100220B /* U+220B CONTAINS AS MEMBER */ -#define XK_squareroot 0x100221A /* U+221A SQUARE ROOT */ -#define XK_cuberoot 0x100221B /* U+221B CUBE ROOT */ -#define XK_fourthroot 0x100221C /* U+221C FOURTH ROOT */ -#define XK_dintegral 0x100222C /* U+222C DOUBLE INTEGRAL */ -#define XK_tintegral 0x100222D /* U+222D TRIPLE INTEGRAL */ -#define XK_because 0x1002235 /* U+2235 BECAUSE */ -#define XK_approxeq 0x1002248 /* U+2245 ALMOST EQUAL TO */ -#define XK_notapproxeq 0x1002247 /* U+2247 NOT ALMOST EQUAL TO */ -#define XK_notidentical 0x1002262 /* U+2262 NOT IDENTICAL TO */ -#define XK_stricteq 0x1002263 /* U+2263 STRICTLY EQUIVALENT TO */ -#endif /* XK_MATHEMATICAL */ - -#ifdef XK_BRAILLE -#define XK_braille_dot_1 0xfff1 -#define XK_braille_dot_2 0xfff2 -#define XK_braille_dot_3 0xfff3 -#define XK_braille_dot_4 0xfff4 -#define XK_braille_dot_5 0xfff5 -#define XK_braille_dot_6 0xfff6 -#define XK_braille_dot_7 0xfff7 -#define XK_braille_dot_8 0xfff8 -#define XK_braille_dot_9 0xfff9 -#define XK_braille_dot_10 0xfffa -#define XK_braille_blank 0x1002800 /* U+2800 BRAILLE PATTERN BLANK */ -#define XK_braille_dots_1 0x1002801 /* U+2801 BRAILLE PATTERN DOTS-1 */ -#define XK_braille_dots_2 0x1002802 /* U+2802 BRAILLE PATTERN DOTS-2 */ -#define XK_braille_dots_12 0x1002803 /* U+2803 BRAILLE PATTERN DOTS-12 */ -#define XK_braille_dots_3 0x1002804 /* U+2804 BRAILLE PATTERN DOTS-3 */ -#define XK_braille_dots_13 0x1002805 /* U+2805 BRAILLE PATTERN DOTS-13 */ -#define XK_braille_dots_23 0x1002806 /* U+2806 BRAILLE PATTERN DOTS-23 */ -#define XK_braille_dots_123 0x1002807 /* U+2807 BRAILLE PATTERN DOTS-123 */ -#define XK_braille_dots_4 0x1002808 /* U+2808 BRAILLE PATTERN DOTS-4 */ -#define XK_braille_dots_14 0x1002809 /* U+2809 BRAILLE PATTERN DOTS-14 */ -#define XK_braille_dots_24 0x100280a /* U+280a BRAILLE PATTERN DOTS-24 */ -#define XK_braille_dots_124 0x100280b /* U+280b BRAILLE PATTERN DOTS-124 */ -#define XK_braille_dots_34 0x100280c /* U+280c BRAILLE PATTERN DOTS-34 */ -#define XK_braille_dots_134 0x100280d /* U+280d BRAILLE PATTERN DOTS-134 */ -#define XK_braille_dots_234 0x100280e /* U+280e BRAILLE PATTERN DOTS-234 */ -#define XK_braille_dots_1234 0x100280f /* U+280f BRAILLE PATTERN DOTS-1234 */ -#define XK_braille_dots_5 0x1002810 /* U+2810 BRAILLE PATTERN DOTS-5 */ -#define XK_braille_dots_15 0x1002811 /* U+2811 BRAILLE PATTERN DOTS-15 */ -#define XK_braille_dots_25 0x1002812 /* U+2812 BRAILLE PATTERN DOTS-25 */ -#define XK_braille_dots_125 0x1002813 /* U+2813 BRAILLE PATTERN DOTS-125 */ -#define XK_braille_dots_35 0x1002814 /* U+2814 BRAILLE PATTERN DOTS-35 */ -#define XK_braille_dots_135 0x1002815 /* U+2815 BRAILLE PATTERN DOTS-135 */ -#define XK_braille_dots_235 0x1002816 /* U+2816 BRAILLE PATTERN DOTS-235 */ -#define XK_braille_dots_1235 0x1002817 /* U+2817 BRAILLE PATTERN DOTS-1235 */ -#define XK_braille_dots_45 0x1002818 /* U+2818 BRAILLE PATTERN DOTS-45 */ -#define XK_braille_dots_145 0x1002819 /* U+2819 BRAILLE PATTERN DOTS-145 */ -#define XK_braille_dots_245 0x100281a /* U+281a BRAILLE PATTERN DOTS-245 */ -#define XK_braille_dots_1245 0x100281b /* U+281b BRAILLE PATTERN DOTS-1245 */ -#define XK_braille_dots_345 0x100281c /* U+281c BRAILLE PATTERN DOTS-345 */ -#define XK_braille_dots_1345 0x100281d /* U+281d BRAILLE PATTERN DOTS-1345 */ -#define XK_braille_dots_2345 0x100281e /* U+281e BRAILLE PATTERN DOTS-2345 */ -#define XK_braille_dots_12345 0x100281f /* U+281f BRAILLE PATTERN DOTS-12345 */ -#define XK_braille_dots_6 0x1002820 /* U+2820 BRAILLE PATTERN DOTS-6 */ -#define XK_braille_dots_16 0x1002821 /* U+2821 BRAILLE PATTERN DOTS-16 */ -#define XK_braille_dots_26 0x1002822 /* U+2822 BRAILLE PATTERN DOTS-26 */ -#define XK_braille_dots_126 0x1002823 /* U+2823 BRAILLE PATTERN DOTS-126 */ -#define XK_braille_dots_36 0x1002824 /* U+2824 BRAILLE PATTERN DOTS-36 */ -#define XK_braille_dots_136 0x1002825 /* U+2825 BRAILLE PATTERN DOTS-136 */ -#define XK_braille_dots_236 0x1002826 /* U+2826 BRAILLE PATTERN DOTS-236 */ -#define XK_braille_dots_1236 0x1002827 /* U+2827 BRAILLE PATTERN DOTS-1236 */ -#define XK_braille_dots_46 0x1002828 /* U+2828 BRAILLE PATTERN DOTS-46 */ -#define XK_braille_dots_146 0x1002829 /* U+2829 BRAILLE PATTERN DOTS-146 */ -#define XK_braille_dots_246 0x100282a /* U+282a BRAILLE PATTERN DOTS-246 */ -#define XK_braille_dots_1246 0x100282b /* U+282b BRAILLE PATTERN DOTS-1246 */ -#define XK_braille_dots_346 0x100282c /* U+282c BRAILLE PATTERN DOTS-346 */ -#define XK_braille_dots_1346 0x100282d /* U+282d BRAILLE PATTERN DOTS-1346 */ -#define XK_braille_dots_2346 0x100282e /* U+282e BRAILLE PATTERN DOTS-2346 */ -#define XK_braille_dots_12346 0x100282f /* U+282f BRAILLE PATTERN DOTS-12346 */ -#define XK_braille_dots_56 0x1002830 /* U+2830 BRAILLE PATTERN DOTS-56 */ -#define XK_braille_dots_156 0x1002831 /* U+2831 BRAILLE PATTERN DOTS-156 */ -#define XK_braille_dots_256 0x1002832 /* U+2832 BRAILLE PATTERN DOTS-256 */ -#define XK_braille_dots_1256 0x1002833 /* U+2833 BRAILLE PATTERN DOTS-1256 */ -#define XK_braille_dots_356 0x1002834 /* U+2834 BRAILLE PATTERN DOTS-356 */ -#define XK_braille_dots_1356 0x1002835 /* U+2835 BRAILLE PATTERN DOTS-1356 */ -#define XK_braille_dots_2356 0x1002836 /* U+2836 BRAILLE PATTERN DOTS-2356 */ -#define XK_braille_dots_12356 0x1002837 /* U+2837 BRAILLE PATTERN DOTS-12356 */ -#define XK_braille_dots_456 0x1002838 /* U+2838 BRAILLE PATTERN DOTS-456 */ -#define XK_braille_dots_1456 0x1002839 /* U+2839 BRAILLE PATTERN DOTS-1456 */ -#define XK_braille_dots_2456 0x100283a /* U+283a BRAILLE PATTERN DOTS-2456 */ -#define XK_braille_dots_12456 0x100283b /* U+283b BRAILLE PATTERN DOTS-12456 */ -#define XK_braille_dots_3456 0x100283c /* U+283c BRAILLE PATTERN DOTS-3456 */ -#define XK_braille_dots_13456 0x100283d /* U+283d BRAILLE PATTERN DOTS-13456 */ -#define XK_braille_dots_23456 0x100283e /* U+283e BRAILLE PATTERN DOTS-23456 */ -#define XK_braille_dots_123456 0x100283f /* U+283f BRAILLE PATTERN DOTS-123456 */ -#define XK_braille_dots_7 0x1002840 /* U+2840 BRAILLE PATTERN DOTS-7 */ -#define XK_braille_dots_17 0x1002841 /* U+2841 BRAILLE PATTERN DOTS-17 */ -#define XK_braille_dots_27 0x1002842 /* U+2842 BRAILLE PATTERN DOTS-27 */ -#define XK_braille_dots_127 0x1002843 /* U+2843 BRAILLE PATTERN DOTS-127 */ -#define XK_braille_dots_37 0x1002844 /* U+2844 BRAILLE PATTERN DOTS-37 */ -#define XK_braille_dots_137 0x1002845 /* U+2845 BRAILLE PATTERN DOTS-137 */ -#define XK_braille_dots_237 0x1002846 /* U+2846 BRAILLE PATTERN DOTS-237 */ -#define XK_braille_dots_1237 0x1002847 /* U+2847 BRAILLE PATTERN DOTS-1237 */ -#define XK_braille_dots_47 0x1002848 /* U+2848 BRAILLE PATTERN DOTS-47 */ -#define XK_braille_dots_147 0x1002849 /* U+2849 BRAILLE PATTERN DOTS-147 */ -#define XK_braille_dots_247 0x100284a /* U+284a BRAILLE PATTERN DOTS-247 */ -#define XK_braille_dots_1247 0x100284b /* U+284b BRAILLE PATTERN DOTS-1247 */ -#define XK_braille_dots_347 0x100284c /* U+284c BRAILLE PATTERN DOTS-347 */ -#define XK_braille_dots_1347 0x100284d /* U+284d BRAILLE PATTERN DOTS-1347 */ -#define XK_braille_dots_2347 0x100284e /* U+284e BRAILLE PATTERN DOTS-2347 */ -#define XK_braille_dots_12347 0x100284f /* U+284f BRAILLE PATTERN DOTS-12347 */ -#define XK_braille_dots_57 0x1002850 /* U+2850 BRAILLE PATTERN DOTS-57 */ -#define XK_braille_dots_157 0x1002851 /* U+2851 BRAILLE PATTERN DOTS-157 */ -#define XK_braille_dots_257 0x1002852 /* U+2852 BRAILLE PATTERN DOTS-257 */ -#define XK_braille_dots_1257 0x1002853 /* U+2853 BRAILLE PATTERN DOTS-1257 */ -#define XK_braille_dots_357 0x1002854 /* U+2854 BRAILLE PATTERN DOTS-357 */ -#define XK_braille_dots_1357 0x1002855 /* U+2855 BRAILLE PATTERN DOTS-1357 */ -#define XK_braille_dots_2357 0x1002856 /* U+2856 BRAILLE PATTERN DOTS-2357 */ -#define XK_braille_dots_12357 0x1002857 /* U+2857 BRAILLE PATTERN DOTS-12357 */ -#define XK_braille_dots_457 0x1002858 /* U+2858 BRAILLE PATTERN DOTS-457 */ -#define XK_braille_dots_1457 0x1002859 /* U+2859 BRAILLE PATTERN DOTS-1457 */ -#define XK_braille_dots_2457 0x100285a /* U+285a BRAILLE PATTERN DOTS-2457 */ -#define XK_braille_dots_12457 0x100285b /* U+285b BRAILLE PATTERN DOTS-12457 */ -#define XK_braille_dots_3457 0x100285c /* U+285c BRAILLE PATTERN DOTS-3457 */ -#define XK_braille_dots_13457 0x100285d /* U+285d BRAILLE PATTERN DOTS-13457 */ -#define XK_braille_dots_23457 0x100285e /* U+285e BRAILLE PATTERN DOTS-23457 */ -#define XK_braille_dots_123457 0x100285f /* U+285f BRAILLE PATTERN DOTS-123457 */ -#define XK_braille_dots_67 0x1002860 /* U+2860 BRAILLE PATTERN DOTS-67 */ -#define XK_braille_dots_167 0x1002861 /* U+2861 BRAILLE PATTERN DOTS-167 */ -#define XK_braille_dots_267 0x1002862 /* U+2862 BRAILLE PATTERN DOTS-267 */ -#define XK_braille_dots_1267 0x1002863 /* U+2863 BRAILLE PATTERN DOTS-1267 */ -#define XK_braille_dots_367 0x1002864 /* U+2864 BRAILLE PATTERN DOTS-367 */ -#define XK_braille_dots_1367 0x1002865 /* U+2865 BRAILLE PATTERN DOTS-1367 */ -#define XK_braille_dots_2367 0x1002866 /* U+2866 BRAILLE PATTERN DOTS-2367 */ -#define XK_braille_dots_12367 0x1002867 /* U+2867 BRAILLE PATTERN DOTS-12367 */ -#define XK_braille_dots_467 0x1002868 /* U+2868 BRAILLE PATTERN DOTS-467 */ -#define XK_braille_dots_1467 0x1002869 /* U+2869 BRAILLE PATTERN DOTS-1467 */ -#define XK_braille_dots_2467 0x100286a /* U+286a BRAILLE PATTERN DOTS-2467 */ -#define XK_braille_dots_12467 0x100286b /* U+286b BRAILLE PATTERN DOTS-12467 */ -#define XK_braille_dots_3467 0x100286c /* U+286c BRAILLE PATTERN DOTS-3467 */ -#define XK_braille_dots_13467 0x100286d /* U+286d BRAILLE PATTERN DOTS-13467 */ -#define XK_braille_dots_23467 0x100286e /* U+286e BRAILLE PATTERN DOTS-23467 */ -#define XK_braille_dots_123467 0x100286f /* U+286f BRAILLE PATTERN DOTS-123467 */ -#define XK_braille_dots_567 0x1002870 /* U+2870 BRAILLE PATTERN DOTS-567 */ -#define XK_braille_dots_1567 0x1002871 /* U+2871 BRAILLE PATTERN DOTS-1567 */ -#define XK_braille_dots_2567 0x1002872 /* U+2872 BRAILLE PATTERN DOTS-2567 */ -#define XK_braille_dots_12567 0x1002873 /* U+2873 BRAILLE PATTERN DOTS-12567 */ -#define XK_braille_dots_3567 0x1002874 /* U+2874 BRAILLE PATTERN DOTS-3567 */ -#define XK_braille_dots_13567 0x1002875 /* U+2875 BRAILLE PATTERN DOTS-13567 */ -#define XK_braille_dots_23567 0x1002876 /* U+2876 BRAILLE PATTERN DOTS-23567 */ -#define XK_braille_dots_123567 0x1002877 /* U+2877 BRAILLE PATTERN DOTS-123567 */ -#define XK_braille_dots_4567 0x1002878 /* U+2878 BRAILLE PATTERN DOTS-4567 */ -#define XK_braille_dots_14567 0x1002879 /* U+2879 BRAILLE PATTERN DOTS-14567 */ -#define XK_braille_dots_24567 0x100287a /* U+287a BRAILLE PATTERN DOTS-24567 */ -#define XK_braille_dots_124567 0x100287b /* U+287b BRAILLE PATTERN DOTS-124567 */ -#define XK_braille_dots_34567 0x100287c /* U+287c BRAILLE PATTERN DOTS-34567 */ -#define XK_braille_dots_134567 0x100287d /* U+287d BRAILLE PATTERN DOTS-134567 */ -#define XK_braille_dots_234567 0x100287e /* U+287e BRAILLE PATTERN DOTS-234567 */ -#define XK_braille_dots_1234567 0x100287f /* U+287f BRAILLE PATTERN DOTS-1234567 */ -#define XK_braille_dots_8 0x1002880 /* U+2880 BRAILLE PATTERN DOTS-8 */ -#define XK_braille_dots_18 0x1002881 /* U+2881 BRAILLE PATTERN DOTS-18 */ -#define XK_braille_dots_28 0x1002882 /* U+2882 BRAILLE PATTERN DOTS-28 */ -#define XK_braille_dots_128 0x1002883 /* U+2883 BRAILLE PATTERN DOTS-128 */ -#define XK_braille_dots_38 0x1002884 /* U+2884 BRAILLE PATTERN DOTS-38 */ -#define XK_braille_dots_138 0x1002885 /* U+2885 BRAILLE PATTERN DOTS-138 */ -#define XK_braille_dots_238 0x1002886 /* U+2886 BRAILLE PATTERN DOTS-238 */ -#define XK_braille_dots_1238 0x1002887 /* U+2887 BRAILLE PATTERN DOTS-1238 */ -#define XK_braille_dots_48 0x1002888 /* U+2888 BRAILLE PATTERN DOTS-48 */ -#define XK_braille_dots_148 0x1002889 /* U+2889 BRAILLE PATTERN DOTS-148 */ -#define XK_braille_dots_248 0x100288a /* U+288a BRAILLE PATTERN DOTS-248 */ -#define XK_braille_dots_1248 0x100288b /* U+288b BRAILLE PATTERN DOTS-1248 */ -#define XK_braille_dots_348 0x100288c /* U+288c BRAILLE PATTERN DOTS-348 */ -#define XK_braille_dots_1348 0x100288d /* U+288d BRAILLE PATTERN DOTS-1348 */ -#define XK_braille_dots_2348 0x100288e /* U+288e BRAILLE PATTERN DOTS-2348 */ -#define XK_braille_dots_12348 0x100288f /* U+288f BRAILLE PATTERN DOTS-12348 */ -#define XK_braille_dots_58 0x1002890 /* U+2890 BRAILLE PATTERN DOTS-58 */ -#define XK_braille_dots_158 0x1002891 /* U+2891 BRAILLE PATTERN DOTS-158 */ -#define XK_braille_dots_258 0x1002892 /* U+2892 BRAILLE PATTERN DOTS-258 */ -#define XK_braille_dots_1258 0x1002893 /* U+2893 BRAILLE PATTERN DOTS-1258 */ -#define XK_braille_dots_358 0x1002894 /* U+2894 BRAILLE PATTERN DOTS-358 */ -#define XK_braille_dots_1358 0x1002895 /* U+2895 BRAILLE PATTERN DOTS-1358 */ -#define XK_braille_dots_2358 0x1002896 /* U+2896 BRAILLE PATTERN DOTS-2358 */ -#define XK_braille_dots_12358 0x1002897 /* U+2897 BRAILLE PATTERN DOTS-12358 */ -#define XK_braille_dots_458 0x1002898 /* U+2898 BRAILLE PATTERN DOTS-458 */ -#define XK_braille_dots_1458 0x1002899 /* U+2899 BRAILLE PATTERN DOTS-1458 */ -#define XK_braille_dots_2458 0x100289a /* U+289a BRAILLE PATTERN DOTS-2458 */ -#define XK_braille_dots_12458 0x100289b /* U+289b BRAILLE PATTERN DOTS-12458 */ -#define XK_braille_dots_3458 0x100289c /* U+289c BRAILLE PATTERN DOTS-3458 */ -#define XK_braille_dots_13458 0x100289d /* U+289d BRAILLE PATTERN DOTS-13458 */ -#define XK_braille_dots_23458 0x100289e /* U+289e BRAILLE PATTERN DOTS-23458 */ -#define XK_braille_dots_123458 0x100289f /* U+289f BRAILLE PATTERN DOTS-123458 */ -#define XK_braille_dots_68 0x10028a0 /* U+28a0 BRAILLE PATTERN DOTS-68 */ -#define XK_braille_dots_168 0x10028a1 /* U+28a1 BRAILLE PATTERN DOTS-168 */ -#define XK_braille_dots_268 0x10028a2 /* U+28a2 BRAILLE PATTERN DOTS-268 */ -#define XK_braille_dots_1268 0x10028a3 /* U+28a3 BRAILLE PATTERN DOTS-1268 */ -#define XK_braille_dots_368 0x10028a4 /* U+28a4 BRAILLE PATTERN DOTS-368 */ -#define XK_braille_dots_1368 0x10028a5 /* U+28a5 BRAILLE PATTERN DOTS-1368 */ -#define XK_braille_dots_2368 0x10028a6 /* U+28a6 BRAILLE PATTERN DOTS-2368 */ -#define XK_braille_dots_12368 0x10028a7 /* U+28a7 BRAILLE PATTERN DOTS-12368 */ -#define XK_braille_dots_468 0x10028a8 /* U+28a8 BRAILLE PATTERN DOTS-468 */ -#define XK_braille_dots_1468 0x10028a9 /* U+28a9 BRAILLE PATTERN DOTS-1468 */ -#define XK_braille_dots_2468 0x10028aa /* U+28aa BRAILLE PATTERN DOTS-2468 */ -#define XK_braille_dots_12468 0x10028ab /* U+28ab BRAILLE PATTERN DOTS-12468 */ -#define XK_braille_dots_3468 0x10028ac /* U+28ac BRAILLE PATTERN DOTS-3468 */ -#define XK_braille_dots_13468 0x10028ad /* U+28ad BRAILLE PATTERN DOTS-13468 */ -#define XK_braille_dots_23468 0x10028ae /* U+28ae BRAILLE PATTERN DOTS-23468 */ -#define XK_braille_dots_123468 0x10028af /* U+28af BRAILLE PATTERN DOTS-123468 */ -#define XK_braille_dots_568 0x10028b0 /* U+28b0 BRAILLE PATTERN DOTS-568 */ -#define XK_braille_dots_1568 0x10028b1 /* U+28b1 BRAILLE PATTERN DOTS-1568 */ -#define XK_braille_dots_2568 0x10028b2 /* U+28b2 BRAILLE PATTERN DOTS-2568 */ -#define XK_braille_dots_12568 0x10028b3 /* U+28b3 BRAILLE PATTERN DOTS-12568 */ -#define XK_braille_dots_3568 0x10028b4 /* U+28b4 BRAILLE PATTERN DOTS-3568 */ -#define XK_braille_dots_13568 0x10028b5 /* U+28b5 BRAILLE PATTERN DOTS-13568 */ -#define XK_braille_dots_23568 0x10028b6 /* U+28b6 BRAILLE PATTERN DOTS-23568 */ -#define XK_braille_dots_123568 0x10028b7 /* U+28b7 BRAILLE PATTERN DOTS-123568 */ -#define XK_braille_dots_4568 0x10028b8 /* U+28b8 BRAILLE PATTERN DOTS-4568 */ -#define XK_braille_dots_14568 0x10028b9 /* U+28b9 BRAILLE PATTERN DOTS-14568 */ -#define XK_braille_dots_24568 0x10028ba /* U+28ba BRAILLE PATTERN DOTS-24568 */ -#define XK_braille_dots_124568 0x10028bb /* U+28bb BRAILLE PATTERN DOTS-124568 */ -#define XK_braille_dots_34568 0x10028bc /* U+28bc BRAILLE PATTERN DOTS-34568 */ -#define XK_braille_dots_134568 0x10028bd /* U+28bd BRAILLE PATTERN DOTS-134568 */ -#define XK_braille_dots_234568 0x10028be /* U+28be BRAILLE PATTERN DOTS-234568 */ -#define XK_braille_dots_1234568 0x10028bf /* U+28bf BRAILLE PATTERN DOTS-1234568 */ -#define XK_braille_dots_78 0x10028c0 /* U+28c0 BRAILLE PATTERN DOTS-78 */ -#define XK_braille_dots_178 0x10028c1 /* U+28c1 BRAILLE PATTERN DOTS-178 */ -#define XK_braille_dots_278 0x10028c2 /* U+28c2 BRAILLE PATTERN DOTS-278 */ -#define XK_braille_dots_1278 0x10028c3 /* U+28c3 BRAILLE PATTERN DOTS-1278 */ -#define XK_braille_dots_378 0x10028c4 /* U+28c4 BRAILLE PATTERN DOTS-378 */ -#define XK_braille_dots_1378 0x10028c5 /* U+28c5 BRAILLE PATTERN DOTS-1378 */ -#define XK_braille_dots_2378 0x10028c6 /* U+28c6 BRAILLE PATTERN DOTS-2378 */ -#define XK_braille_dots_12378 0x10028c7 /* U+28c7 BRAILLE PATTERN DOTS-12378 */ -#define XK_braille_dots_478 0x10028c8 /* U+28c8 BRAILLE PATTERN DOTS-478 */ -#define XK_braille_dots_1478 0x10028c9 /* U+28c9 BRAILLE PATTERN DOTS-1478 */ -#define XK_braille_dots_2478 0x10028ca /* U+28ca BRAILLE PATTERN DOTS-2478 */ -#define XK_braille_dots_12478 0x10028cb /* U+28cb BRAILLE PATTERN DOTS-12478 */ -#define XK_braille_dots_3478 0x10028cc /* U+28cc BRAILLE PATTERN DOTS-3478 */ -#define XK_braille_dots_13478 0x10028cd /* U+28cd BRAILLE PATTERN DOTS-13478 */ -#define XK_braille_dots_23478 0x10028ce /* U+28ce BRAILLE PATTERN DOTS-23478 */ -#define XK_braille_dots_123478 0x10028cf /* U+28cf BRAILLE PATTERN DOTS-123478 */ -#define XK_braille_dots_578 0x10028d0 /* U+28d0 BRAILLE PATTERN DOTS-578 */ -#define XK_braille_dots_1578 0x10028d1 /* U+28d1 BRAILLE PATTERN DOTS-1578 */ -#define XK_braille_dots_2578 0x10028d2 /* U+28d2 BRAILLE PATTERN DOTS-2578 */ -#define XK_braille_dots_12578 0x10028d3 /* U+28d3 BRAILLE PATTERN DOTS-12578 */ -#define XK_braille_dots_3578 0x10028d4 /* U+28d4 BRAILLE PATTERN DOTS-3578 */ -#define XK_braille_dots_13578 0x10028d5 /* U+28d5 BRAILLE PATTERN DOTS-13578 */ -#define XK_braille_dots_23578 0x10028d6 /* U+28d6 BRAILLE PATTERN DOTS-23578 */ -#define XK_braille_dots_123578 0x10028d7 /* U+28d7 BRAILLE PATTERN DOTS-123578 */ -#define XK_braille_dots_4578 0x10028d8 /* U+28d8 BRAILLE PATTERN DOTS-4578 */ -#define XK_braille_dots_14578 0x10028d9 /* U+28d9 BRAILLE PATTERN DOTS-14578 */ -#define XK_braille_dots_24578 0x10028da /* U+28da BRAILLE PATTERN DOTS-24578 */ -#define XK_braille_dots_124578 0x10028db /* U+28db BRAILLE PATTERN DOTS-124578 */ -#define XK_braille_dots_34578 0x10028dc /* U+28dc BRAILLE PATTERN DOTS-34578 */ -#define XK_braille_dots_134578 0x10028dd /* U+28dd BRAILLE PATTERN DOTS-134578 */ -#define XK_braille_dots_234578 0x10028de /* U+28de BRAILLE PATTERN DOTS-234578 */ -#define XK_braille_dots_1234578 0x10028df /* U+28df BRAILLE PATTERN DOTS-1234578 */ -#define XK_braille_dots_678 0x10028e0 /* U+28e0 BRAILLE PATTERN DOTS-678 */ -#define XK_braille_dots_1678 0x10028e1 /* U+28e1 BRAILLE PATTERN DOTS-1678 */ -#define XK_braille_dots_2678 0x10028e2 /* U+28e2 BRAILLE PATTERN DOTS-2678 */ -#define XK_braille_dots_12678 0x10028e3 /* U+28e3 BRAILLE PATTERN DOTS-12678 */ -#define XK_braille_dots_3678 0x10028e4 /* U+28e4 BRAILLE PATTERN DOTS-3678 */ -#define XK_braille_dots_13678 0x10028e5 /* U+28e5 BRAILLE PATTERN DOTS-13678 */ -#define XK_braille_dots_23678 0x10028e6 /* U+28e6 BRAILLE PATTERN DOTS-23678 */ -#define XK_braille_dots_123678 0x10028e7 /* U+28e7 BRAILLE PATTERN DOTS-123678 */ -#define XK_braille_dots_4678 0x10028e8 /* U+28e8 BRAILLE PATTERN DOTS-4678 */ -#define XK_braille_dots_14678 0x10028e9 /* U+28e9 BRAILLE PATTERN DOTS-14678 */ -#define XK_braille_dots_24678 0x10028ea /* U+28ea BRAILLE PATTERN DOTS-24678 */ -#define XK_braille_dots_124678 0x10028eb /* U+28eb BRAILLE PATTERN DOTS-124678 */ -#define XK_braille_dots_34678 0x10028ec /* U+28ec BRAILLE PATTERN DOTS-34678 */ -#define XK_braille_dots_134678 0x10028ed /* U+28ed BRAILLE PATTERN DOTS-134678 */ -#define XK_braille_dots_234678 0x10028ee /* U+28ee BRAILLE PATTERN DOTS-234678 */ -#define XK_braille_dots_1234678 0x10028ef /* U+28ef BRAILLE PATTERN DOTS-1234678 */ -#define XK_braille_dots_5678 0x10028f0 /* U+28f0 BRAILLE PATTERN DOTS-5678 */ -#define XK_braille_dots_15678 0x10028f1 /* U+28f1 BRAILLE PATTERN DOTS-15678 */ -#define XK_braille_dots_25678 0x10028f2 /* U+28f2 BRAILLE PATTERN DOTS-25678 */ -#define XK_braille_dots_125678 0x10028f3 /* U+28f3 BRAILLE PATTERN DOTS-125678 */ -#define XK_braille_dots_35678 0x10028f4 /* U+28f4 BRAILLE PATTERN DOTS-35678 */ -#define XK_braille_dots_135678 0x10028f5 /* U+28f5 BRAILLE PATTERN DOTS-135678 */ -#define XK_braille_dots_235678 0x10028f6 /* U+28f6 BRAILLE PATTERN DOTS-235678 */ -#define XK_braille_dots_1235678 0x10028f7 /* U+28f7 BRAILLE PATTERN DOTS-1235678 */ -#define XK_braille_dots_45678 0x10028f8 /* U+28f8 BRAILLE PATTERN DOTS-45678 */ -#define XK_braille_dots_145678 0x10028f9 /* U+28f9 BRAILLE PATTERN DOTS-145678 */ -#define XK_braille_dots_245678 0x10028fa /* U+28fa BRAILLE PATTERN DOTS-245678 */ -#define XK_braille_dots_1245678 0x10028fb /* U+28fb BRAILLE PATTERN DOTS-1245678 */ -#define XK_braille_dots_345678 0x10028fc /* U+28fc BRAILLE PATTERN DOTS-345678 */ -#define XK_braille_dots_1345678 0x10028fd /* U+28fd BRAILLE PATTERN DOTS-1345678 */ -#define XK_braille_dots_2345678 0x10028fe /* U+28fe BRAILLE PATTERN DOTS-2345678 */ -#define XK_braille_dots_12345678 0x10028ff /* U+28ff BRAILLE PATTERN DOTS-12345678 */ -#endif /* XK_BRAILLE */ - -/* - * Sinhala (http://unicode.org/charts/PDF/U0D80.pdf) - * http://www.nongnu.org/sinhala/doc/transliteration/sinhala-transliteration_6.html - */ - -#ifdef XK_SINHALA -#define XK_Sinh_ng 0x1000d82 /* U+0D82 SINHALA ANUSVARAYA */ -#define XK_Sinh_h2 0x1000d83 /* U+0D83 SINHALA VISARGAYA */ -#define XK_Sinh_a 0x1000d85 /* U+0D85 SINHALA AYANNA */ -#define XK_Sinh_aa 0x1000d86 /* U+0D86 SINHALA AAYANNA */ -#define XK_Sinh_ae 0x1000d87 /* U+0D87 SINHALA AEYANNA */ -#define XK_Sinh_aee 0x1000d88 /* U+0D88 SINHALA AEEYANNA */ -#define XK_Sinh_i 0x1000d89 /* U+0D89 SINHALA IYANNA */ -#define XK_Sinh_ii 0x1000d8a /* U+0D8A SINHALA IIYANNA */ -#define XK_Sinh_u 0x1000d8b /* U+0D8B SINHALA UYANNA */ -#define XK_Sinh_uu 0x1000d8c /* U+0D8C SINHALA UUYANNA */ -#define XK_Sinh_ri 0x1000d8d /* U+0D8D SINHALA IRUYANNA */ -#define XK_Sinh_rii 0x1000d8e /* U+0D8E SINHALA IRUUYANNA */ -#define XK_Sinh_lu 0x1000d8f /* U+0D8F SINHALA ILUYANNA */ -#define XK_Sinh_luu 0x1000d90 /* U+0D90 SINHALA ILUUYANNA */ -#define XK_Sinh_e 0x1000d91 /* U+0D91 SINHALA EYANNA */ -#define XK_Sinh_ee 0x1000d92 /* U+0D92 SINHALA EEYANNA */ -#define XK_Sinh_ai 0x1000d93 /* U+0D93 SINHALA AIYANNA */ -#define XK_Sinh_o 0x1000d94 /* U+0D94 SINHALA OYANNA */ -#define XK_Sinh_oo 0x1000d95 /* U+0D95 SINHALA OOYANNA */ -#define XK_Sinh_au 0x1000d96 /* U+0D96 SINHALA AUYANNA */ -#define XK_Sinh_ka 0x1000d9a /* U+0D9A SINHALA KAYANNA */ -#define XK_Sinh_kha 0x1000d9b /* U+0D9B SINHALA MAHA. KAYANNA */ -#define XK_Sinh_ga 0x1000d9c /* U+0D9C SINHALA GAYANNA */ -#define XK_Sinh_gha 0x1000d9d /* U+0D9D SINHALA MAHA. GAYANNA */ -#define XK_Sinh_ng2 0x1000d9e /* U+0D9E SINHALA KANTAJA NAASIKYAYA */ -#define XK_Sinh_nga 0x1000d9f /* U+0D9F SINHALA SANYAKA GAYANNA */ -#define XK_Sinh_ca 0x1000da0 /* U+0DA0 SINHALA CAYANNA */ -#define XK_Sinh_cha 0x1000da1 /* U+0DA1 SINHALA MAHA. CAYANNA */ -#define XK_Sinh_ja 0x1000da2 /* U+0DA2 SINHALA JAYANNA */ -#define XK_Sinh_jha 0x1000da3 /* U+0DA3 SINHALA MAHA. JAYANNA */ -#define XK_Sinh_nya 0x1000da4 /* U+0DA4 SINHALA TAALUJA NAASIKYAYA */ -#define XK_Sinh_jnya 0x1000da5 /* U+0DA5 SINHALA TAALUJA SANYOOGA NAASIKYAYA */ -#define XK_Sinh_nja 0x1000da6 /* U+0DA6 SINHALA SANYAKA JAYANNA */ -#define XK_Sinh_tta 0x1000da7 /* U+0DA7 SINHALA TTAYANNA */ -#define XK_Sinh_ttha 0x1000da8 /* U+0DA8 SINHALA MAHA. TTAYANNA */ -#define XK_Sinh_dda 0x1000da9 /* U+0DA9 SINHALA DDAYANNA */ -#define XK_Sinh_ddha 0x1000daa /* U+0DAA SINHALA MAHA. DDAYANNA */ -#define XK_Sinh_nna 0x1000dab /* U+0DAB SINHALA MUURDHAJA NAYANNA */ -#define XK_Sinh_ndda 0x1000dac /* U+0DAC SINHALA SANYAKA DDAYANNA */ -#define XK_Sinh_tha 0x1000dad /* U+0DAD SINHALA TAYANNA */ -#define XK_Sinh_thha 0x1000dae /* U+0DAE SINHALA MAHA. TAYANNA */ -#define XK_Sinh_dha 0x1000daf /* U+0DAF SINHALA DAYANNA */ -#define XK_Sinh_dhha 0x1000db0 /* U+0DB0 SINHALA MAHA. DAYANNA */ -#define XK_Sinh_na 0x1000db1 /* U+0DB1 SINHALA DANTAJA NAYANNA */ -#define XK_Sinh_ndha 0x1000db3 /* U+0DB3 SINHALA SANYAKA DAYANNA */ -#define XK_Sinh_pa 0x1000db4 /* U+0DB4 SINHALA PAYANNA */ -#define XK_Sinh_pha 0x1000db5 /* U+0DB5 SINHALA MAHA. PAYANNA */ -#define XK_Sinh_ba 0x1000db6 /* U+0DB6 SINHALA BAYANNA */ -#define XK_Sinh_bha 0x1000db7 /* U+0DB7 SINHALA MAHA. BAYANNA */ -#define XK_Sinh_ma 0x1000db8 /* U+0DB8 SINHALA MAYANNA */ -#define XK_Sinh_mba 0x1000db9 /* U+0DB9 SINHALA AMBA BAYANNA */ -#define XK_Sinh_ya 0x1000dba /* U+0DBA SINHALA YAYANNA */ -#define XK_Sinh_ra 0x1000dbb /* U+0DBB SINHALA RAYANNA */ -#define XK_Sinh_la 0x1000dbd /* U+0DBD SINHALA DANTAJA LAYANNA */ -#define XK_Sinh_va 0x1000dc0 /* U+0DC0 SINHALA VAYANNA */ -#define XK_Sinh_sha 0x1000dc1 /* U+0DC1 SINHALA TAALUJA SAYANNA */ -#define XK_Sinh_ssha 0x1000dc2 /* U+0DC2 SINHALA MUURDHAJA SAYANNA */ -#define XK_Sinh_sa 0x1000dc3 /* U+0DC3 SINHALA DANTAJA SAYANNA */ -#define XK_Sinh_ha 0x1000dc4 /* U+0DC4 SINHALA HAYANNA */ -#define XK_Sinh_lla 0x1000dc5 /* U+0DC5 SINHALA MUURDHAJA LAYANNA */ -#define XK_Sinh_fa 0x1000dc6 /* U+0DC6 SINHALA FAYANNA */ -#define XK_Sinh_al 0x1000dca /* U+0DCA SINHALA AL-LAKUNA */ -#define XK_Sinh_aa2 0x1000dcf /* U+0DCF SINHALA AELA-PILLA */ -#define XK_Sinh_ae2 0x1000dd0 /* U+0DD0 SINHALA AEDA-PILLA */ -#define XK_Sinh_aee2 0x1000dd1 /* U+0DD1 SINHALA DIGA AEDA-PILLA */ -#define XK_Sinh_i2 0x1000dd2 /* U+0DD2 SINHALA IS-PILLA */ -#define XK_Sinh_ii2 0x1000dd3 /* U+0DD3 SINHALA DIGA IS-PILLA */ -#define XK_Sinh_u2 0x1000dd4 /* U+0DD4 SINHALA PAA-PILLA */ -#define XK_Sinh_uu2 0x1000dd6 /* U+0DD6 SINHALA DIGA PAA-PILLA */ -#define XK_Sinh_ru2 0x1000dd8 /* U+0DD8 SINHALA GAETTA-PILLA */ -#define XK_Sinh_e2 0x1000dd9 /* U+0DD9 SINHALA KOMBUVA */ -#define XK_Sinh_ee2 0x1000dda /* U+0DDA SINHALA DIGA KOMBUVA */ -#define XK_Sinh_ai2 0x1000ddb /* U+0DDB SINHALA KOMBU DEKA */ -#define XK_Sinh_o2 0x1000ddc /* U+0DDC SINHALA KOMBUVA HAA AELA-PILLA*/ -#define XK_Sinh_oo2 0x1000ddd /* U+0DDD SINHALA KOMBUVA HAA DIGA AELA-PILLA*/ -#define XK_Sinh_au2 0x1000dde /* U+0DDE SINHALA KOMBUVA HAA GAYANUKITTA */ -#define XK_Sinh_lu2 0x1000ddf /* U+0DDF SINHALA GAYANUKITTA */ -#define XK_Sinh_ruu2 0x1000df2 /* U+0DF2 SINHALA DIGA GAETTA-PILLA */ -#define XK_Sinh_luu2 0x1000df3 /* U+0DF3 SINHALA DIGA GAYANUKITTA */ -#define XK_Sinh_kunddaliya 0x1000df4 /* U+0DF4 SINHALA KUNDDALIYA */ -#endif /* XK_SINHALA */ diff --git a/btgui/OpenGLWindow/premake4.lua b/btgui/OpenGLWindow/premake4.lua deleted file mode 100644 index f2af4c31a..000000000 --- a/btgui/OpenGLWindow/premake4.lua +++ /dev/null @@ -1,50 +0,0 @@ - - project "OpenGL_Window" - - language "C++" - - kind "StaticLib" - - initOpenGL() - initGlew() - - includedirs { - "..", - "../../src", - } - - --links { - --} - - files { - "*.cpp", - "*.h", - "OpenGLWindow/*.c", - "OpenGLWindow/*.h", - "OpenGLWindow/GL/*.h" - } - - if not os.is("Windows") then - excludes { - "Win32OpenGLWindow.cpp", - "Win32OpenGLWindow.h", - "Win32Window.cpp", - "Win32Window.h", - } - end - if os.is("Linux") then - initX11() - end - if not os.is("Linux") then - excludes { - "X11OpenGLWindow.cpp", - "X11OpenGLWindows.h" - } - end - if os.is("MacOSX") then - files - { - "../OpenGLWindow/MacOpenGLWindow.h", - "../OpenGLWindow/MacOpenGLWindow.mm", - } - end diff --git a/btgui/OpenGLWindow/stb_image_write.h b/btgui/OpenGLWindow/stb_image_write.h deleted file mode 100644 index 41b703388..000000000 --- a/btgui/OpenGLWindow/stb_image_write.h +++ /dev/null @@ -1,511 +0,0 @@ -/* stbiw-0.92 - public domain - http://nothings.org/stb/stb_image_write.h - writes out PNG/BMP/TGA images to C stdio - Sean Barrett 2010 - no warranty implied; use at your own risk - - -Before including, - - #define STB_IMAGE_WRITE_IMPLEMENTATION - -in the file that you want to have the implementation. - - -ABOUT: - - This header file is a library for writing images to C stdio. It could be - adapted to write to memory or a general streaming interface; let me know. - - The PNG output is not optimal; it is 20-50% larger than the file - written by a decent optimizing implementation. This library is designed - for source code compactness and simplicitly, not optimal image file size - or run-time performance. - -USAGE: - - There are three functions, one for each image file format: - - int stbi_write_png(char const *filename, int w, int h, int comp, const void *data, int stride_in_bytes); - int stbi_write_bmp(char const *filename, int w, int h, int comp, const void *data); - int stbi_write_tga(char const *filename, int w, int h, int comp, const void *data); - - Each function returns 0 on failure and non-0 on success. - - The functions create an image file defined by the parameters. The image - is a rectangle of pixels stored from left-to-right, top-to-bottom. - Each pixel contains 'comp' channels of data stored interleaved with 8-bits - per channel, in the following order: 1=Y, 2=YA, 3=RGB, 4=RGBA. (Y is - monochrome color.) The rectangle is 'w' pixels wide and 'h' pixels tall. - The *data pointer points to the first byte of the top-left-most pixel. - For PNG, "stride_in_bytes" is the distance in bytes from the first byte of - a row of pixels to the first byte of the next row of pixels. - - PNG creates output files with the same number of components as the input. - The BMP and TGA formats expand Y to RGB in the file format. BMP does not - output alpha. - - PNG supports writing rectangles of data even when the bytes storing rows of - data are not consecutive in memory (e.g. sub-rectangles of a larger image), - by supplying the stride between the beginning of adjacent rows. The other - formats do not. (Thus you cannot write a native-format BMP through the BMP - writer, both because it is in BGR order and because it may have padding - at the end of the line.) -*/ - -#ifndef INCLUDE_STB_IMAGE_WRITE_H -#define INCLUDE_STB_IMAGE_WRITE_H - -#ifdef __cplusplus -extern "C" { -#endif - -extern int stbi_write_png(char const *filename, int w, int h, int comp, const void *data, int stride_in_bytes); -extern int stbi_write_bmp(char const *filename, int w, int h, int comp, const void *data); -extern int stbi_write_tga(char const *filename, int w, int h, int comp, const void *data); - -#ifdef __cplusplus -} -#endif - -#endif//INCLUDE_STB_IMAGE_WRITE_H - -#ifdef STB_IMAGE_WRITE_IMPLEMENTATION - -#include -#include -#include -#include -#include - -typedef unsigned int stbiw_uint32; -typedef int stb_image_write_test[sizeof(stbiw_uint32)==4 ? 1 : -1]; - -static void writefv(FILE *f, const char *fmt, va_list v) -{ - while (*fmt) { - switch (*fmt++) { - case ' ': break; - case '1': { unsigned char x = (unsigned char) va_arg(v, int); fputc(x,f); break; } - case '2': { int x = va_arg(v,int); unsigned char b[2]; - b[0] = (unsigned char) x; b[1] = (unsigned char) (x>>8); - fwrite(b,2,1,f); break; } - case '4': { stbiw_uint32 x = va_arg(v,int); unsigned char b[4]; - b[0]=(unsigned char)x; b[1]=(unsigned char)(x>>8); - b[2]=(unsigned char)(x>>16); b[3]=(unsigned char)(x>>24); - fwrite(b,4,1,f); break; } - default: - assert(0); - return; - } - } -} - -static void write3(FILE *f, unsigned char a, unsigned char b, unsigned char c) -{ - unsigned char arr[3]; - arr[0] = a, arr[1] = b, arr[2] = c; - fwrite(arr, 3, 1, f); -} - -static void write_pixels(FILE *f, int rgb_dir, int vdir, int x, int y, int comp, void *data, int write_alpha, int scanline_pad) -{ - unsigned char bg[3] = { 255, 0, 255}, px[3]; - stbiw_uint32 zero = 0; - int i,j,k, j_end; - - if (y <= 0) - return; - - if (vdir < 0) - j_end = -1, j = y-1; - else - j_end = y, j = 0; - - for (; j != j_end; j += vdir) { - for (i=0; i < x; ++i) { - unsigned char *d = (unsigned char *) data + (j*x+i)*comp; - if (write_alpha < 0) - fwrite(&d[comp-1], 1, 1, f); - switch (comp) { - case 1: - case 2: write3(f, d[0],d[0],d[0]); - break; - case 4: - if (!write_alpha) { - // composite against pink background - for (k=0; k < 3; ++k) - px[k] = bg[k] + ((d[k] - bg[k]) * d[3])/255; - write3(f, px[1-rgb_dir],px[1],px[1+rgb_dir]); - break; - } - /* FALLTHROUGH */ - case 3: - write3(f, d[1-rgb_dir],d[1],d[1+rgb_dir]); - break; - } - if (write_alpha > 0) - fwrite(&d[comp-1], 1, 1, f); - } - fwrite(&zero,scanline_pad,1,f); - } -} - -static int outfile(char const *filename, int rgb_dir, int vdir, int x, int y, int comp, void *data, int alpha, int pad, const char *fmt, ...) -{ - FILE *f; - if (y < 0 || x < 0) return 0; - f = fopen(filename, "wb"); - if (f) { - va_list v; - va_start(v, fmt); - writefv(f, fmt, v); - va_end(v); - write_pixels(f,rgb_dir,vdir,x,y,comp,data,alpha,pad); - fclose(f); - } - return f != NULL; -} - -int stbi_write_bmp(char const *filename, int x, int y, int comp, const void *data) -{ - int pad = (-x*3) & 3; - return outfile(filename,-1,-1,x,y,comp,(void *) data,0,pad, - "11 4 22 4" "4 44 22 444444", - 'B', 'M', 14+40+(x*3+pad)*y, 0,0, 14+40, // file header - 40, x,y, 1,24, 0,0,0,0,0,0); // bitmap header -} - -int stbi_write_tga(char const *filename, int x, int y, int comp, const void *data) -{ - int has_alpha = !(comp & 1); - return outfile(filename, -1,-1, x, y, comp, (void *) data, has_alpha, 0, - "111 221 2222 11", 0,0,2, 0,0,0, 0,0,x,y, 24+8*has_alpha, 8*has_alpha); -} - -// stretchy buffer; stbi__sbpush() == vector<>::push_back() -- stbi__sbcount() == vector<>::size() -#define stbi__sbraw(a) ((int *) (a) - 2) -#define stbi__sbm(a) stbi__sbraw(a)[0] -#define stbi__sbn(a) stbi__sbraw(a)[1] - -#define stbi__sbneedgrow(a,n) ((a)==0 || stbi__sbn(a)+n >= stbi__sbm(a)) -#define stbi__sbmaybegrow(a,n) (stbi__sbneedgrow(a,(n)) ? stbi__sbgrow(a,n) : 0) -#define stbi__sbgrow(a,n) stbi__sbgrowf((void **) &(a), (n), sizeof(*(a))) - -#define stbi__sbpush(a, v) (stbi__sbmaybegrow(a,1), (a)[stbi__sbn(a)++] = (v)) -#define stbi__sbcount(a) ((a) ? stbi__sbn(a) : 0) -#define stbi__sbfree(a) ((a) ? free(stbi__sbraw(a)),0 : 0) - -static void *stbi__sbgrowf(void **arr, int increment, int itemsize) -{ - int m = *arr ? 2*stbi__sbm(*arr)+increment : increment+1; - void *p = realloc(*arr ? stbi__sbraw(*arr) : 0, itemsize * m + sizeof(int)*2); - assert(p); - if (p) { - if (!*arr) ((int *) p)[1] = 0; - *arr = (void *) ((int *) p + 2); - stbi__sbm(*arr) = m; - } - return *arr; -} - -static unsigned char *stbi__zlib_flushf(unsigned char *data, unsigned int *bitbuffer, int *bitcount) -{ - while (*bitcount >= 8) { - stbi__sbpush(data, (unsigned char) *bitbuffer); - *bitbuffer >>= 8; - *bitcount -= 8; - } - return data; -} - -static int stbi__zlib_bitrev(int code, int codebits) -{ - int res=0; - while (codebits--) { - res = (res << 1) | (code & 1); - code >>= 1; - } - return res; -} - -static unsigned int stbi__zlib_countm(unsigned char *a, unsigned char *b, int limit) -{ - int i; - for (i=0; i < limit && i < 258; ++i) - if (a[i] != b[i]) break; - return i; -} - -static unsigned int stbi__zhash(unsigned char *data) -{ - stbiw_uint32 hash = data[0] + (data[1] << 8) + (data[2] << 16); - hash ^= hash << 3; - hash += hash >> 5; - hash ^= hash << 4; - hash += hash >> 17; - hash ^= hash << 25; - hash += hash >> 6; - return hash; -} - -#define stbi__zlib_flush() (out = stbi__zlib_flushf(out, &bitbuf, &bitcount)) -#define stbi__zlib_add(code,codebits) \ - (bitbuf |= (code) << bitcount, bitcount += (codebits), stbi__zlib_flush()) -#define stbi__zlib_huffa(b,c) stbi__zlib_add(stbi__zlib_bitrev(b,c),c) -// default huffman tables -#define stbi__zlib_huff1(n) stbi__zlib_huffa(0x30 + (n), 8) -#define stbi__zlib_huff2(n) stbi__zlib_huffa(0x190 + (n)-144, 9) -#define stbi__zlib_huff3(n) stbi__zlib_huffa(0 + (n)-256,7) -#define stbi__zlib_huff4(n) stbi__zlib_huffa(0xc0 + (n)-280,8) -#define stbi__zlib_huff(n) ((n) <= 143 ? stbi__zlib_huff1(n) : (n) <= 255 ? stbi__zlib_huff2(n) : (n) <= 279 ? stbi__zlib_huff3(n) : stbi__zlib_huff4(n)) -#define stbi__zlib_huffb(n) ((n) <= 143 ? stbi__zlib_huff1(n) : stbi__zlib_huff2(n)) - -#define stbi__ZHASH 16384 - -unsigned char * stbi_zlib_compress(unsigned char *data, int data_len, int *out_len, int quality) -{ - static unsigned short lengthc[] = { 3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258, 259 }; - static unsigned char lengtheb[]= { 0,0,0,0,0,0,0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0 }; - static unsigned short distc[] = { 1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577, 32768 }; - static unsigned char disteb[] = { 0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13 }; - unsigned int bitbuf=0; - int i,j, bitcount=0; - unsigned char *out = NULL; - unsigned char **hash_table[stbi__ZHASH]; // 64KB on the stack! - if (quality < 5) quality = 5; - - stbi__sbpush(out, 0x78); // DEFLATE 32K window - stbi__sbpush(out, 0x5e); // FLEVEL = 1 - stbi__zlib_add(1,1); // BFINAL = 1 - stbi__zlib_add(1,2); // B3YPE = 1 -- fixed huffman - - for (i=0; i < stbi__ZHASH; ++i) - hash_table[i] = NULL; - - i=0; - while (i < data_len-3) { - // hash next 3 bytes of data to be compressed - int h = stbi__zhash(data+i)&(stbi__ZHASH-1), best=3; - unsigned char *bestloc = 0; - unsigned char **hlist = hash_table[h]; - int n = stbi__sbcount(hlist); - for (j=0; j < n; ++j) { - if (hlist[j]-data > i-32768) { // if entry lies within window - int d = stbi__zlib_countm(hlist[j], data+i, data_len-i); - if (d >= best) best=d,bestloc=hlist[j]; - } - } - // when hash table entry is too long, delete half the entries - if (hash_table[h] && stbi__sbn(hash_table[h]) == 2*quality) { - memcpy(hash_table[h], hash_table[h]+quality, sizeof(hash_table[h][0])*quality); - stbi__sbn(hash_table[h]) = quality; - } - stbi__sbpush(hash_table[h],data+i); - - if (bestloc) { - // "lazy matching" - check match at *next* byte, and if it's better, do cur byte as literal - h = stbi__zhash(data+i+1)&(stbi__ZHASH-1); - hlist = hash_table[h]; - n = stbi__sbcount(hlist); - for (j=0; j < n; ++j) { - if (hlist[j]-data > i-32767) { - int e = stbi__zlib_countm(hlist[j], data+i+1, data_len-i-1); - if (e > best) { // if next match is better, bail on current match - bestloc = NULL; - break; - } - } - } - } - - if (bestloc) { - int d = data+i - bestloc; // distance back - assert(d <= 32767 && best <= 258); - for (j=0; best > lengthc[j+1]-1; ++j); - stbi__zlib_huff(j+257); - if (lengtheb[j]) stbi__zlib_add(best - lengthc[j], lengtheb[j]); - for (j=0; d > distc[j+1]-1; ++j); - stbi__zlib_add(stbi__zlib_bitrev(j,5),5); - if (disteb[j]) stbi__zlib_add(d - distc[j], disteb[j]); - i += best; - } else { - stbi__zlib_huffb(data[i]); - ++i; - } - } - // write out final bytes - for (;i < data_len; ++i) - stbi__zlib_huffb(data[i]); - stbi__zlib_huff(256); // end of block - // pad with 0 bits to byte boundary - while (bitcount) - stbi__zlib_add(0,1); - - for (i=0; i < stbi__ZHASH; ++i) - (void) stbi__sbfree(hash_table[i]); - - { - // compute adler32 on input - unsigned int i=0, s1=1, s2=0, blocklen = data_len % 5552; - int j=0; - while (j < data_len) { - for (i=0; i < blocklen; ++i) s1 += data[j+i], s2 += s1; - s1 %= 65521, s2 %= 65521; - j += blocklen; - blocklen = 5552; - } - stbi__sbpush(out, (unsigned char) (s2 >> 8)); - stbi__sbpush(out, (unsigned char) s2); - stbi__sbpush(out, (unsigned char) (s1 >> 8)); - stbi__sbpush(out, (unsigned char) s1); - } - *out_len = stbi__sbn(out); - // make returned pointer freeable - memmove(stbi__sbraw(out), out, *out_len); - return (unsigned char *) stbi__sbraw(out); -} - -unsigned int stbi__crc32(unsigned char *buffer, int len) -{ - static unsigned int crc_table[256]; - unsigned int crc = ~0u; - int i,j; - if (crc_table[1] == 0) - for(i=0; i < 256; i++) - for (crc_table[i]=i, j=0; j < 8; ++j) - crc_table[i] = (crc_table[i] >> 1) ^ (crc_table[i] & 1 ? 0xedb88320 : 0); - for (i=0; i < len; ++i) - crc = (crc >> 8) ^ crc_table[buffer[i] ^ (crc & 0xff)]; - return ~crc; -} - -#define stbi__wpng4(o,a,b,c,d) ((o)[0]=(unsigned char)(a),(o)[1]=(unsigned char)(b),(o)[2]=(unsigned char)(c),(o)[3]=(unsigned char)(d),(o)+=4) -#define stbi__wp32(data,v) stbi__wpng4(data, (v)>>24,(v)>>16,(v)>>8,(v)); -#define stbi__wptag(data,s) stbi__wpng4(data, s[0],s[1],s[2],s[3]) - -static void stbi__wpcrc(unsigned char **data, int len) -{ - unsigned int crc = stbi__crc32(*data - len - 4, len+4); - stbi__wp32(*data, crc); -} - -static unsigned char stbi__paeth(int a, int b, int c) -{ - int p = a + b - c, pa = abs(p-a), pb = abs(p-b), pc = abs(p-c); - if (pa <= pb && pa <= pc) return (unsigned char) a; - if (pb <= pc) return (unsigned char) b; - return (unsigned char) c; -} - -unsigned char *stbi_write_png_to_mem(unsigned char *pixels, int stride_bytes, int x, int y, int n, int *out_len) -{ - int ctype[5] = { -1, 0, 4, 2, 6 }; - unsigned char sig[8] = { 137,80,78,71,13,10,26,10 }; - unsigned char *out,*o, *filt, *zlib; - signed char *line_buffer; - int i,j,k,p,zlen; - - if (stride_bytes == 0) - stride_bytes = x * n; - - filt = (unsigned char *) malloc((x*n+1) * y); if (!filt) return 0; - line_buffer = (signed char *) malloc(x * n); if (!line_buffer) { free(filt); return 0; } - for (j=0; j < y; ++j) { - static int mapping[] = { 0,1,2,3,4 }; - static int firstmap[] = { 0,1,0,5,6 }; - int *mymap = j ? mapping : firstmap; - int best = 0, bestval = 0x7fffffff; - for (p=0; p < 2; ++p) { - for (k= p?best:0; k < 5; ++k) { - int type = mymap[k],est=0; - unsigned char *z = pixels + stride_bytes*j; - for (i=0; i < n; ++i) - switch (type) { - case 0: line_buffer[i] = z[i]; break; - case 1: line_buffer[i] = z[i]; break; - case 2: line_buffer[i] = z[i] - z[i-stride_bytes]; break; - case 3: line_buffer[i] = z[i] - (z[i-stride_bytes]>>1); break; - case 4: line_buffer[i] = (signed char) (z[i] - stbi__paeth(0,z[i-stride_bytes],0)); break; - case 5: line_buffer[i] = z[i]; break; - case 6: line_buffer[i] = z[i]; break; - } - for (i=n; i < x*n; ++i) { - switch (type) { - case 0: line_buffer[i] = z[i]; break; - case 1: line_buffer[i] = z[i] - z[i-n]; break; - case 2: line_buffer[i] = z[i] - z[i-stride_bytes]; break; - case 3: line_buffer[i] = z[i] - ((z[i-n] + z[i-stride_bytes])>>1); break; - case 4: line_buffer[i] = z[i] - stbi__paeth(z[i-n], z[i-stride_bytes], z[i-stride_bytes-n]); break; - case 5: line_buffer[i] = z[i] - (z[i-n]>>1); break; - case 6: line_buffer[i] = z[i] - stbi__paeth(z[i-n], 0,0); break; - } - } - if (p) break; - for (i=0; i < x*n; ++i) - est += abs((signed char) line_buffer[i]); - if (est < bestval) { bestval = est; best = k; } - } - } - // when we get here, best contains the filter type, and line_buffer contains the data - filt[j*(x*n+1)] = (unsigned char) best; - memcpy(filt+j*(x*n+1)+1, line_buffer, x*n); - } - free(line_buffer); - zlib = stbi_zlib_compress(filt, y*( x*n+1), &zlen, 8); // increase 8 to get smaller but use more memory - free(filt); - if (!zlib) return 0; - - // each tag requires 12 bytes of overhead - out = (unsigned char *) malloc(8 + 12+13 + 12+zlen + 12); - if (!out) return 0; - *out_len = 8 + 12+13 + 12+zlen + 12; - - o=out; - memcpy(o,sig,8); o+= 8; - stbi__wp32(o, 13); // header length - stbi__wptag(o, "IHDR"); - stbi__wp32(o, x); - stbi__wp32(o, y); - *o++ = 8; - *o++ = (unsigned char) ctype[n]; - *o++ = 0; - *o++ = 0; - *o++ = 0; - stbi__wpcrc(&o,13); - - stbi__wp32(o, zlen); - stbi__wptag(o, "IDAT"); - memcpy(o, zlib, zlen); o += zlen; free(zlib); - stbi__wpcrc(&o, zlen); - - stbi__wp32(o,0); - stbi__wptag(o, "IEND"); - stbi__wpcrc(&o,0); - - assert(o == out + *out_len); - - return out; -} - -int stbi_write_png(char const *filename, int x, int y, int comp, const void *data, int stride_bytes) -{ - FILE *f; - int len; - unsigned char *png = stbi_write_png_to_mem((unsigned char *) data, stride_bytes, x, y, comp, &len); - if (!png) return 0; - f = fopen(filename, "wb"); - if (!f) { free(png); return 0; } - fwrite(png, 1, len, f); - fclose(f); - free(png); - return 1; -} -#endif // STB_IMAGE_WRITE_IMPLEMENTATION - -/* Revision history - - 0.92 (2010-08-01) - casts to unsigned char to fix warnings - 0.91 (2010-07-17) - first public release - 0.90 first internal release -*/ diff --git a/btgui/OpenGLWindow/stb_truetype.h b/btgui/OpenGLWindow/stb_truetype.h deleted file mode 100644 index 1d1e55d64..000000000 --- a/btgui/OpenGLWindow/stb_truetype.h +++ /dev/null @@ -1,1957 +0,0 @@ -// stb_truetype.h - v0.5 - public domain - 2009 Sean Barrett / RAD Game Tools -// -// This library processes TrueType files: -// parse files -// extract glyph metrics -// extract glyph shapes -// render glyphs to one-channel bitmaps with antialiasing (box filter) -// -// Todo: -// non-MS cmaps -// crashproof on bad data -// hinting? (no longer patented) -// cleartype-style AA? -// optimize: use simple memory allocator for intermediates -// optimize: build edge-list directly from curves -// optimize: rasterize directly from curves? -// -// ADDITIONAL CONTRIBUTORS -// -// Mikko Mononen: compound shape support, more cmap formats -// Tor Andersson: kerning, subpixel rendering -// -// Bug/warning reports: -// "Zer" on mollyrocket (with fix) -// Cass Everitt -// stoiko (Haemimont Games) -// Brian Hook -// Walter van Niftrik -// -// VERSION HISTORY -// -// 0.5 (2011-12-09) bugfixes: -// subpixel glyph renderer computed wrong bounding box -// first vertex of shape can be off-curve (FreeSans) -// 0.4b(2011-12-03) fixed an error in the font baking example -// 0.4 (2011-12-01) kerning, subpixel rendering (tor) -// bugfixes for: -// codepoint-to-glyph conversion using table fmt=12 -// codepoint-to-glyph conversion using table fmt=4 -// stbtt_GetBakedQuad with non-square texture (Zer) -// updated Hello World! sample to use kerning and subpixel -// fixed some warnings -// 0.3 (2009-06-24) cmap fmt=12, compound shapes (MM) -// userdata, malloc-from-userdata, non-zero fill (STB) -// 0.2 (2009-03-11) Fix unsigned/signed char warnings -// 0.1 (2009-03-09) First public release -// -// USAGE -// -// Include this file in whatever places neeed to refer to it. In ONE C/C++ -// file, write: -// #define STB_TRUETYPE_IMPLEMENTATION -// before the #include of this file. This expands out the actual -// implementation into that C/C++ file. -// -// Look at the header-file sections below for the API, but here's a quick skim: -// -// Simple 3D API (don't ship this, but it's fine for tools and quick start, -// and you can cut and paste from it to move to more advanced) -// stbtt_BakeFontBitmap() -- bake a font to a bitmap for use as texture -// stbtt_GetBakedQuad() -- compute quad to draw for a given char -// -// "Load" a font file from a memory buffer (you have to keep the buffer loaded) -// stbtt_InitFont() -// stbtt_GetFontOffsetForIndex() -- use for TTC font collections -// -// Render a unicode codepoint to a bitmap -// stbtt_GetCodepointBitmap() -- allocates and returns a bitmap -// stbtt_MakeCodepointBitmap() -- renders into bitmap you provide -// stbtt_GetCodepointBitmapBox() -- how big the bitmap must be -// -// Character advance/positioning -// stbtt_GetCodepointHMetrics() -// stbtt_GetFontVMetrics() -// stbtt_GetCodepointKernAdvance() -// -// ADVANCED USAGE -// -// Quality: -// -// - Use the functions with Subpixel at the end to allow your characters -// to have subpixel positioning. Since the font is anti-aliased, not -// hinted, this is very import for quality. -// -// - Kerning is now supported, and if you're supporting subpixel rendering -// then kerning is worth using to give your text a polished look. -// -// Performance: -// -// - Convert Unicode codepoints to "glyphs" and operate on the glyphs; if -// you don't do this, stb_truetype is forced to do the conversion on -// every call. -// -// - There are a lot of memory allocations. We should modify it to take -// a temp buffer and allocate from the temp buffer (without freeing), -// should help performance a lot. -// -// NOTES -// -// The system uses the raw data found in the .ttf file without changing it -// and without building auxiliary data structures. This is a bit inefficient -// on little-endian systems (the data is big-endian), but assuming you're -// caching the bitmaps or glyph shapes this shouldn't be a big deal. -// -// It appears to be very hard to programmatically determine what font a -// given file is in a general way. I provide an API for this, but I don't -// recommend it. -// -// -// SOURCE STATISTICS (based on v0.5, 1980 LOC) -// -// Documentation & header file 450 LOC \___ 550 LOC documentation -// Sample code 140 LOC / -// Truetype parsing 590 LOC ---- 600 LOC TrueType -// Software rasterization 240 LOC \ . -// Curve tesselation 120 LOC \__ 550 LOC Bitmap creation -// Bitmap management 100 LOC / -// Baked bitmap interface 70 LOC / -// Font name matching & access 150 LOC ---- 150 -// C runtime library abstraction 60 LOC ---- 60 - - -////////////////////////////////////////////////////////////////////////////// -////////////////////////////////////////////////////////////////////////////// -//// -//// SAMPLE PROGRAMS -//// -// -// Incomplete text-in-3d-api example, which draws quads properly aligned to be lossless -// -#if 0 -#define STB_TRUETYPE_IMPLEMENTATION // force following include to generate implementation -#include "stb_truetype.h" - -char ttf_buffer[1<<20]; -unsigned char temp_bitmap[512*512]; - -stbtt_bakedchar cdata[96]; // ASCII 32..126 is 95 glyphs -GLstbtt_uint ftex; - -void my_stbtt_initfont(void) -{ - fread(ttf_buffer, 1, 1<<20, fopen("c:/windows/fonts/times.ttf", "rb")); - stbtt_BakeFontBitmap(data,0, 32.0, temp_bitmap,512,512, 32,96, cdata); // no guarantee this fits! - // can free ttf_buffer at this point - glGenTextures(1, &ftex); - glBindTexture(GL_TEXTURE_2D, ftex); - glTexImage2D(GL_TEXTURE_2D, 0, GL_ALPHA, 512,512, 0, GL_ALPHA, GL_UNSIGNED_BYTE, temp_bitmap); - // can free temp_bitmap at this point - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); -} - -void my_stbtt_print(float x, float y, char *text) -{ - // assume orthographic projection with units = screen pixels, origin at top left - glBindTexture(GL_TEXTURE_2D, ftex); - glBegin(GL_QUADS); - while (*text) { - if (*text >= 32 && *text < 128) { - stbtt_aligned_quad q; - stbtt_GetBakedQuad(cdata, 512,512, *text-32, &x,&y,&q,1);//1=opengl,0=old d3d - glTexCoord2f(q.s0,q.t1); glVertex2f(q.x0,q.y0); - glTexCoord2f(q.s1,q.t1); glVertex2f(q.x1,q.y0); - glTexCoord2f(q.s1,q.t0); glVertex2f(q.x1,q.y1); - glTexCoord2f(q.s0,q.t0); glVertex2f(q.x0,q.y1); - } - ++text; - } - glEnd(); -} -#endif -// -// -////////////////////////////////////////////////////////////////////////////// -// -// Complete program (this compiles): get a single bitmap, print as ASCII art -// -#if 0 -#include -#define STB_TRUETYPE_IMPLEMENTATION // force following include to generate implementation -#include "stb_truetype.h" - -char ttf_buffer[1<<25]; - -int main(int argc, char **argv) -{ - stbtt_fontinfo font; - unsigned char *bitmap; - int w,h,i,j,c = (argc > 1 ? atoi(argv[1]) : 'a'), s = (argc > 2 ? atoi(argv[2]) : 20); - - fread(ttf_buffer, 1, 1<<25, fopen(argc > 3 ? argv[3] : "c:/windows/fonts/arialbd.ttf", "rb")); - - stbtt_InitFont(&font, ttf_buffer, stbtt_GetFontOffsetForIndex(ttf_buffer,0)); - bitmap = stbtt_GetCodepointBitmap(&font, 0,stbtt_ScaleForPixelHeight(&font, s), c, &w, &h, 0,0); - - for (j=0; j < h; ++j) { - for (i=0; i < w; ++i) - putchar(" .:ioVM@"[bitmap[j*w+i]>>5]); - putchar('\n'); - } - return 0; -} -#endif -// -// Output: -// -// .ii. -// @@@@@@. -// V@Mio@@o -// :i. V@V -// :oM@@M -// :@@@MM@M -// @@o o@M -// :@@. M@M -// @@@o@@@@ -// :M@@V:@@. -// -////////////////////////////////////////////////////////////////////////////// -// -// Complete program: print "Hello World!" banner, with bugs -// -#if 0 -char buffer[24<<20]; -unsigned char screen[20][79]; - -int main(int arg, char **argv) -{ - stbtt_fontinfo font; - int i,j,ascent,baseline,ch=0; - float scale, xpos=0; - char *text = "Heljo World!"; - - fread(buffer, 1, 1000000, fopen("c:/windows/fonts/arialbd.ttf", "rb")); - stbtt_InitFont(&font, buffer, 0); - - scale = stbtt_ScaleForPixelHeight(&font, 15); - stbtt_GetFontVMetrics(&font, &ascent,0,0); - baseline = (int) (ascent*scale); - - while (text[ch]) { - int advance,lsb,x0,y0,x1,y1; - float x_shift = xpos - (float) floor(xpos); - stbtt_GetCodepointHMetrics(&font, text[ch], &advance, &lsb); - stbtt_GetCodepointBitmapBoxSubpixel(&font, text[ch], scale,scale,x_shift,0, &x0,&y0,&x1,&y1); - stbtt_MakeCodepointBitmapSubpixel(&font, &screen[baseline + y0][(int) xpos + x0], x1-x0,y1-y0, 79, scale,scale,x_shift,0, text[ch]); - // note that this stomps the old data, so where character boxes overlap (e.g. 'lj') it's wrong - // because this API is really for baking character bitmaps into textures. if you want to do this, - // you need to render the bitmap to a temp buffer, then "alpha blend" that into the working buffer - xpos += (advance * scale); - if (text[ch+1]) - xpos += scale*stbtt_GetCodepointKernAdvance(&font, text[ch],text[ch+1]); - ++ch; - } - - for (j=0; j < 20; ++j) { - for (i=0; i < 78; ++i) - putchar(" .:ioVM@"[screen[j][i]>>5]); - putchar('\n'); - } - - return 0; -} -#endif - - -////////////////////////////////////////////////////////////////////////////// -////////////////////////////////////////////////////////////////////////////// -//// -//// INTEGRATION WITH RUNTIME LIBRARIES -//// - -#ifdef STB_TRUETYPE_IMPLEMENTATION - // #define your own (u)stbtt_int8/16/32 before including to override this - #ifndef stbtt_uint8 - typedef unsigned char stbtt_uint8; - typedef signed char stbtt_int8; - typedef unsigned short stbtt_uint16; - typedef signed short stbtt_int16; - typedef unsigned int stbtt_uint32; - typedef signed int stbtt_int32; - #endif - - typedef char stbtt__check_size32[sizeof(stbtt_int32)==4 ? 1 : -1]; - typedef char stbtt__check_size16[sizeof(stbtt_int16)==2 ? 1 : -1]; - - // #define your own STBTT_sort() to override this to avoid qsort - #ifndef STBTT_sort - #include - #define STBTT_sort(data,num_items,item_size,compare_func) qsort(data,num_items,item_size,compare_func) - #endif - - // #define your own STBTT_ifloor/STBTT_iceil() to avoid math.h - #ifndef STBTT_ifloor - #include - #define STBTT_ifloor(x) ((int) floor(x)) - #define STBTT_iceil(x) ((int) ceil(x)) - #endif - - // #define your own functions "STBTT_malloc" / "STBTT_free" to avoid malloc.h - #ifndef STBTT_malloc - #include - #define STBTT_malloc(x,u) malloc(x) - #define STBTT_free(x,u) free(x) - #endif - - #ifndef STBTT_assert - #include - #define STBTT_assert(x) assert(x) - #endif - - #ifndef STBTT_strlen - #include - #define STBTT_strlen(x) strlen(x) - #endif - - #ifndef STBTT_memcpy - #include - #define STBTT_memcpy memcpy - #define STBTT_memset memset - #endif -#endif - -/////////////////////////////////////////////////////////////////////////////// -/////////////////////////////////////////////////////////////////////////////// -//// -//// INTERFACE -//// -//// - -#ifndef __STB_INCLUDE_STB_TRUETYPE_H__ -#define __STB_INCLUDE_STB_TRUETYPE_H__ - -#ifdef __cplusplus -extern "C" { -#endif - -////////////////////////////////////////////////////////////////////////////// -// -// TEXTURE BAKING API -// -// If you use this API, you only have to call two functions ever. -// - -typedef struct -{ - unsigned short x0,y0,x1,y1; // coordinates of bbox in bitmap - float xoff,yoff,xadvance; -} stbtt_bakedchar; - -extern int stbtt_BakeFontBitmap(const unsigned char *data, int offset, // font location (use offset=0 for plain .ttf) - float pixel_height, // height of font in pixels - unsigned char *pixels, int pw, int ph, // bitmap to be filled in - int first_char, int num_chars, // characters to bake - stbtt_bakedchar *chardata); // you allocate this, it's num_chars long -// if return is positive, the first unused row of the bitmap -// if return is negative, returns the negative of the number of characters that fit -// if return is 0, no characters fit and no rows were used -// This uses a very crappy packing. - -typedef struct -{ - float x0,y0,s0,t0; // top-left - float x1,y1,s1,t1; // bottom-right -} stbtt_aligned_quad; - -extern void stbtt_GetBakedQuad(stbtt_bakedchar *chardata, int pw, int ph, // same data as above - int char_index, // character to display - float *xpos, float *ypos, // pointers to current position in screen pixel space - stbtt_aligned_quad *q, // output: quad to draw - int opengl_fillrule); // true if opengl fill rule; false if DX9 or earlier -// Call GetBakedQuad with char_index = 'character - first_char', and it -// creates the quad you need to draw and advances the current position. -// It's inefficient; you might want to c&p it and optimize it. - - -////////////////////////////////////////////////////////////////////////////// -// -// FONT LOADING -// -// - -extern int stbtt_GetFontOffsetForIndex(const unsigned char *data, int index); -// Each .ttf file may have more than one font. Each has a sequential index -// number starting from 0. Call this function to get the font offset for a -// given index; it returns -1 if the index is out of range. A regular .ttf -// file will only define one font and it always be at offset 0, so it will -// return '0' for index 0, and -1 for all other indices. You can just skip -// this step if you know it's that kind of font. - - -// The following structure is defined publically so you can declare one on -// the stack or as a global or etc. -typedef struct -{ - void * userdata; - unsigned char * data; // pointer to .ttf file - int fontstart; // offset of start of font - - int numGlyphs; // number of glyphs, needed for range checking - - int loca,head,glyf,hhea,hmtx,kern; // table locations as offset from start of .ttf - int index_map; // a cmap mapping for our chosen character encoding - int indexToLocFormat; // format needed to map from glyph index to glyph -} stbtt_fontinfo; - -extern int stbtt_InitFont(stbtt_fontinfo *info, const unsigned char *data, int offset); -// Given an offset into the file that defines a font, this function builds -// the necessary cached info for the rest of the system. You must allocate -// the stbtt_fontinfo yourself, and stbtt_InitFont will fill it out. You don't -// need to do anything special to free it, because the contents are a pure -// cache with no additional data structures. Returns 0 on failure. - - -////////////////////////////////////////////////////////////////////////////// -// -// CHARACTER TO GLYPH-INDEX CONVERSIOn - -int stbtt_FindGlyphIndex(const stbtt_fontinfo *info, int unicode_codepoint); -// If you're going to perform multiple operations on the same character -// and you want a speed-up, call this function with the character you're -// going to process, then use glyph-based functions instead of the -// codepoint-based functions. - - -////////////////////////////////////////////////////////////////////////////// -// -// CHARACTER PROPERTIES -// - -extern float stbtt_ScaleForPixelHeight(const stbtt_fontinfo *info, float pixels); -// computes a scale factor to produce a font whose "height" is 'pixels' tall. -// Height is measured as the distance from the highest ascender to the lowest -// descender; in other words, it's equivalent to calling stbtt_GetFontVMetrics -// and computing: -// scale = pixels / (ascent - descent) -// so if you prefer to measure height by the ascent only, use a similar calculation. - -extern void stbtt_GetFontVMetrics(const stbtt_fontinfo *info, int *ascent, int *descent, int *lineGap); -// ascent is the coordinate above the baseline the font extends; descent -// is the coordinate below the baseline the font extends (i.e. it is typically negative) -// lineGap is the spacing between one row's descent and the next row's ascent... -// so you should advance the vertical position by "*ascent - *descent + *lineGap" -// these are expressed in unscaled coordinates - -extern void stbtt_GetCodepointHMetrics(const stbtt_fontinfo *info, int codepoint, int *advanceWidth, int *leftSideBearing); -// leftSideBearing is the offset from the current horizontal position to the left edge of the character -// advanceWidth is the offset from the current horizontal position to the next horizontal position -// these are expressed in unscaled coordinates - -extern int stbtt_GetCodepointKernAdvance(const stbtt_fontinfo *info, int ch1, int ch2); -// an additional amount to add to the 'advance' value between ch1 and ch2 -// @TODO; for now always returns 0! - -extern int stbtt_GetCodepointBox(const stbtt_fontinfo *info, int codepoint, int *x0, int *y0, int *x1, int *y1); -// Gets the bounding box of the visible part of the glyph, in unscaled coordinates - -extern void stbtt_GetGlyphHMetrics(const stbtt_fontinfo *info, int glyph_index, int *advanceWidth, int *leftSideBearing); -extern int stbtt_GetGlyphKernAdvance(const stbtt_fontinfo *info, int glyph1, int glyph2); -extern int stbtt_GetGlyphBox(const stbtt_fontinfo *info, int glyph_index, int *x0, int *y0, int *x1, int *y1); -// as above, but takes one or more glyph indices for greater efficiency - - -////////////////////////////////////////////////////////////////////////////// -// -// GLYPH SHAPES (you probably don't need these, but they have to go before -// the bitmaps for C declaration-order reasons) -// - -#ifndef STBTT_vmove // you can predefine these to use different values (but why?) - enum { - STBTT_vmove=1, - STBTT_vline, - STBTT_vcurve - }; -#endif - -#ifndef stbtt_vertex // you can predefine this to use different values - // (we share this with other code at RAD) - #define stbtt_vertex_type short // can't use stbtt_int16 because that's not visible in the header file - typedef struct - { - stbtt_vertex_type x,y,cx,cy; - unsigned char type,padding; - } stbtt_vertex; -#endif - -extern int stbtt_GetCodepointShape(const stbtt_fontinfo *info, int unicode_codepoint, stbtt_vertex **vertices); -extern int stbtt_GetGlyphShape(const stbtt_fontinfo *info, int glyph_index, stbtt_vertex **vertices); -// returns # of vertices and fills *vertices with the pointer to them -// these are expressed in "unscaled" coordinates - -extern void stbtt_FreeShape(const stbtt_fontinfo *info, stbtt_vertex *vertices); -// frees the data allocated above - -////////////////////////////////////////////////////////////////////////////// -// -// BITMAP RENDERING -// - -extern void stbtt_FreeBitmap(unsigned char *bitmap, void *userdata); -// frees the bitmap allocated below - -extern unsigned char *stbtt_GetCodepointBitmap(const stbtt_fontinfo *info, float scale_x, float scale_y, int codepoint, int *width, int *height, int *xoff, int *yoff); -// allocates a large-enough single-channel 8bpp bitmap and renders the -// specified character/glyph at the specified scale into it, with -// antialiasing. 0 is no coverage (transparent), 255 is fully covered (opaque). -// *width & *height are filled out with the width & height of the bitmap, -// which is stored left-to-right, top-to-bottom. -// -// xoff/yoff are the offset it pixel space from the glyph origin to the top-left of the bitmap - -extern unsigned char *stbtt_GetCodepointBitmapSubpixel(const stbtt_fontinfo *info, float scale_x, float scale_y, float shift_x, float shift_y, int codepoint, int *width, int *height, int *xoff, int *yoff); -// the same as stbtt_GetCodepoitnBitmap, but you can specify a subpixel -// shift for the character - -extern void stbtt_MakeCodepointBitmap(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, int codepoint); -// the same as stbtt_GetCodepointBitmap, but you pass in storage for the bitmap -// in the form of 'output', with row spacing of 'out_stride' bytes. the bitmap -// is clipped to out_w/out_h bytes. Call stbtt_GetCodepointBitmapBox to get the -// width and height and positioning info for it first. - -extern void stbtt_MakeCodepointBitmapSubpixel(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, float shift_x, float shift_y, int codepoint); -// same as stbtt_MakeCodepointBitmap, but you can specify a subpixel -// shift for the character - -extern void stbtt_GetCodepointBitmapBox(const stbtt_fontinfo *font, int codepoint, float scale_x, float scale_y, int *ix0, int *iy0, int *ix1, int *iy1); -// get the bbox of the bitmap centered around the glyph origin; so the -// bitmap width is ix1-ix0, height is iy1-iy0, and location to place -// the bitmap top left is (leftSideBearing*scale,iy0). -// (Note that the bitmap uses y-increases-down, but the shape uses -// y-increases-up, so CodepointBitmapBox and CodepointBox are inverted.) - -extern void stbtt_GetCodepointBitmapBoxSubpixel(const stbtt_fontinfo *font, int codepoint, float scale_x, float scale_y, float shift_x, float shift_y, int *ix0, int *iy0, int *ix1, int *iy1); -// same as stbtt_GetCodepointBitmapBox, but you can specify a subpixel -// shift for the character - -// the following functions are equivalent to the above functions, but operate -// on glyph indices instead of Unicode codepoints (for efficiency) -extern unsigned char *stbtt_GetGlyphBitmap(const stbtt_fontinfo *info, float scale_x, float scale_y, int glyph, int *width, int *height, int *xoff, int *yoff); -extern unsigned char *stbtt_GetGlyphBitmapSubpixel(const stbtt_fontinfo *info, float scale_x, float scale_y, float shift_x, float shift_y, int glyph, int *width, int *height, int *xoff, int *yoff); -extern void stbtt_MakeGlyphBitmap(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, int glyph); -extern void stbtt_MakeGlyphBitmapSubpixel(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, float shift_x, float shift_y, int glyph); -extern void stbtt_GetGlyphBitmapBox(const stbtt_fontinfo *font, int glyph, float scale_x, float scale_y, int *ix0, int *iy0, int *ix1, int *iy1); -extern void stbtt_GetGlyphBitmapBoxSubpixel(const stbtt_fontinfo *font, int glyph, float scale_x, float scale_y,float shift_x, float shift_y, int *ix0, int *iy0, int *ix1, int *iy1); - - -// @TODO: don't expose this structure -typedef struct -{ - int w,h,stride; - unsigned char *pixels; -} stbtt__bitmap; - -extern void stbtt_Rasterize(stbtt__bitmap *result, float flatness_in_pixels, stbtt_vertex *vertices, int num_verts, float scale_x, float scale_y, float shift_x, float shift_y, int x_off, int y_off, int invert, void *userdata); - -////////////////////////////////////////////////////////////////////////////// -// -// Finding the right font... -// -// You should really just solve this offline, keep your own tables -// of what font is what, and don't try to get it out of the .ttf file. -// That's because getting it out of the .ttf file is really hard, because -// the names in the file can appear in many possible encodings, in many -// possible languages, and e.g. if you need a case-insensitive comparison, -// the details of that depend on the encoding & language in a complex way -// (actually underspecified in truetype, but also gigantic). -// -// But you can use the provided functions in two possible ways: -// stbtt_FindMatchingFont() will use *case-sensitive* comparisons on -// unicode-encoded names to try to find the font you want; -// you can run this before calling stbtt_InitFont() -// -// stbtt_GetFontNameString() lets you get any of the various strings -// from the file yourself and do your own comparisons on them. -// You have to have called stbtt_InitFont() first. - - -extern int stbtt_FindMatchingFont(const unsigned char *fontdata, const char *name, int flags); -// returns the offset (not index) of the font that matches, or -1 if none -// if you use STBTT_MACSTYLE_DONTCARE, use a font name like "Arial Bold". -// if you use any other flag, use a font name like "Arial"; this checks -// the 'macStyle' header field; i don't know if fonts set this consistently -#define STBTT_MACSTYLE_DONTCARE 0 -#define STBTT_MACSTYLE_BOLD 1 -#define STBTT_MACSTYLE_ITALIC 2 -#define STBTT_MACSTYLE_UNDERSCORE 4 -#define STBTT_MACSTYLE_NONE 8 // <= not same as 0, this makes us check the bitfield is 0 - -extern int stbtt_CompareUTF8toUTF16_bigendian(const char *s1, int len1, const char *s2, int len2); -// returns 1/0 whether the first string interpreted as utf8 is identical to -// the second string interpreted as big-endian utf16... useful for strings from next func - -extern const char *stbtt_GetFontNameString(const stbtt_fontinfo *font, int *length, int platformID, int encodingID, int languageID, int nameID); -// returns the string (which may be big-endian double byte, e.g. for unicode) -// and puts the length in bytes in *length. -// -// some of the values for the IDs are below; for more see the truetype spec: -// http://developer.apple.com/textfonts/TTRefMan/RM06/Chap6name.html -// http://www.microsoft.com/typography/otspec/name.htm - -enum { // platformID - STBTT_PLATFORM_ID_UNICODE =0, - STBTT_PLATFORM_ID_MAC =1, - STBTT_PLATFORM_ID_ISO =2, - STBTT_PLATFORM_ID_MICROSOFT =3 -}; - -enum { // encodingID for STBTT_PLATFORM_ID_UNICODE - STBTT_UNICODE_EID_UNICODE_1_0 =0, - STBTT_UNICODE_EID_UNICODE_1_1 =1, - STBTT_UNICODE_EID_ISO_10646 =2, - STBTT_UNICODE_EID_UNICODE_2_0_BMP=3, - STBTT_UNICODE_EID_UNICODE_2_0_FULL=4 -}; - -enum { // encodingID for STBTT_PLATFORM_ID_MICROSOFT - STBTT_MS_EID_SYMBOL =0, - STBTT_MS_EID_UNICODE_BMP =1, - STBTT_MS_EID_SHIFTJIS =2, - STBTT_MS_EID_UNICODE_FULL =10 -}; - -enum { // encodingID for STBTT_PLATFORM_ID_MAC; same as Script Manager codes - STBTT_MAC_EID_ROMAN =0, STBTT_MAC_EID_ARABIC =4, - STBTT_MAC_EID_JAPANESE =1, STBTT_MAC_EID_HEBREW =5, - STBTT_MAC_EID_CHINESE_TRAD =2, STBTT_MAC_EID_GREEK =6, - STBTT_MAC_EID_KOREAN =3, STBTT_MAC_EID_RUSSIAN =7 -}; - -enum { // languageID for STBTT_PLATFORM_ID_MICROSOFT; same as LCID... - // problematic because there are e.g. 16 english LCIDs and 16 arabic LCIDs - STBTT_MS_LANG_ENGLISH =0x0409, STBTT_MS_LANG_ITALIAN =0x0410, - STBTT_MS_LANG_CHINESE =0x0804, STBTT_MS_LANG_JAPANESE =0x0411, - STBTT_MS_LANG_DUTCH =0x0413, STBTT_MS_LANG_KOREAN =0x0412, - STBTT_MS_LANG_FRENCH =0x040c, STBTT_MS_LANG_RUSSIAN =0x0419, - STBTT_MS_LANG_GERMAN =0x0407, STBTT_MS_LANG_SPANISH =0x0409, - STBTT_MS_LANG_HEBREW =0x040d, STBTT_MS_LANG_SWEDISH =0x041D -}; - -enum { // languageID for STBTT_PLATFORM_ID_MAC - STBTT_MAC_LANG_ENGLISH =0 , STBTT_MAC_LANG_JAPANESE =11, - STBTT_MAC_LANG_ARABIC =12, STBTT_MAC_LANG_KOREAN =23, - STBTT_MAC_LANG_DUTCH =4 , STBTT_MAC_LANG_RUSSIAN =32, - STBTT_MAC_LANG_FRENCH =1 , STBTT_MAC_LANG_SPANISH =6 , - STBTT_MAC_LANG_GERMAN =2 , STBTT_MAC_LANG_SWEDISH =5 , - STBTT_MAC_LANG_HEBREW =10, STBTT_MAC_LANG_CHINESE_SIMPLIFIED =33, - STBTT_MAC_LANG_ITALIAN =3 , STBTT_MAC_LANG_CHINESE_TRAD =19 -}; - -#ifdef __cplusplus -} -#endif - -#endif // __STB_INCLUDE_STB_TRUETYPE_H__ - -/////////////////////////////////////////////////////////////////////////////// -/////////////////////////////////////////////////////////////////////////////// -//// -//// IMPLEMENTATION -//// -//// - -#ifdef STB_TRUETYPE_IMPLEMENTATION - -////////////////////////////////////////////////////////////////////////// -// -// accessors to parse data from file -// - -// on platforms that don't allow misaligned reads, if we want to allow -// truetype fonts that aren't padded to alignment, define ALLOW_UNALIGNED_TRUETYPE - -#define ttBYTE(p) (* (stbtt_uint8 *) (p)) -#define ttCHAR(p) (* (stbtt_int8 *) (p)) -#define ttFixed(p) ttLONG(p) - -#if defined(STB_TRUETYPE_BIGENDIAN) && !defined(ALLOW_UNALIGNED_TRUETYPE) - - #define ttUSHORT(p) (* (stbtt_uint16 *) (p)) - #define ttSHORT(p) (* (stbtt_int16 *) (p)) - #define ttULONG(p) (* (stbtt_uint32 *) (p)) - #define ttLONG(p) (* (stbtt_int32 *) (p)) - -#else - - stbtt_uint16 ttUSHORT(const stbtt_uint8 *p) { return p[0]*256 + p[1]; } - stbtt_int16 ttSHORT(const stbtt_uint8 *p) { return p[0]*256 + p[1]; } - stbtt_uint32 ttULONG(const stbtt_uint8 *p) { return (p[0]<<24) + (p[1]<<16) + (p[2]<<8) + p[3]; } - stbtt_int32 ttLONG(const stbtt_uint8 *p) { return (p[0]<<24) + (p[1]<<16) + (p[2]<<8) + p[3]; } - -#endif - -#define stbtt_tag4(p,c0,c1,c2,c3) ((p)[0] == (c0) && (p)[1] == (c1) && (p)[2] == (c2) && (p)[3] == (c3)) -#define stbtt_tag(p,str) stbtt_tag4(p,str[0],str[1],str[2],str[3]) - -static int stbtt__isfont(const stbtt_uint8 *font) -{ - // check the version number - if (stbtt_tag4(font, '1',0,0,0)) return 1; // TrueType 1 - if (stbtt_tag(font, "typ1")) return 1; // TrueType with type 1 font -- we don't support this! - if (stbtt_tag(font, "OTTO")) return 1; // OpenType with CFF - if (stbtt_tag4(font, 0,1,0,0)) return 1; // OpenType 1.0 - return 0; -} - -// @OPTIMIZE: binary search -static stbtt_uint32 stbtt__find_table(stbtt_uint8 *data, stbtt_uint32 fontstart, const char *tag) -{ - stbtt_int32 num_tables = ttUSHORT(data+fontstart+4); - stbtt_uint32 tabledir = fontstart + 12; - stbtt_int32 i; - for (i=0; i < num_tables; ++i) { - stbtt_uint32 loc = tabledir + 16*i; - if (stbtt_tag(data+loc+0, tag)) - return ttULONG(data+loc+8); - } - return 0; -} - -int stbtt_GetFontOffsetForIndex(const unsigned char *font_collection, int index) -{ - // if it's just a font, there's only one valid index - if (stbtt__isfont(font_collection)) - return index == 0 ? 0 : -1; - - // check if it's a TTC - if (stbtt_tag(font_collection, "ttcf")) { - // version 1? - if (ttULONG(font_collection+4) == 0x00010000 || ttULONG(font_collection+4) == 0x00020000) { - stbtt_int32 n = ttLONG(font_collection+8); - if (index >= n) - return -1; - return ttULONG(font_collection+12+index*14); - } - } - return -1; -} - -int stbtt_InitFont(stbtt_fontinfo *info, const unsigned char *data2, int fontstart) -{ - stbtt_uint8 *data = (stbtt_uint8 *) data2; - stbtt_uint32 cmap, t; - stbtt_int32 i,numTables; - - info->data = data; - info->fontstart = fontstart; - - cmap = stbtt__find_table(data, fontstart, "cmap"); // required - info->loca = stbtt__find_table(data, fontstart, "loca"); // required - info->head = stbtt__find_table(data, fontstart, "head"); // required - info->glyf = stbtt__find_table(data, fontstart, "glyf"); // required - info->hhea = stbtt__find_table(data, fontstart, "hhea"); // required - info->hmtx = stbtt__find_table(data, fontstart, "hmtx"); // required - info->kern = stbtt__find_table(data, fontstart, "kern"); // not required - if (!cmap || !info->loca || !info->head || !info->glyf || !info->hhea || !info->hmtx) - return 0; - - t = stbtt__find_table(data, fontstart, "maxp"); - if (t) - info->numGlyphs = ttUSHORT(data+t+4); - else - info->numGlyphs = 0xffff; - - // find a cmap encoding table we understand *now* to avoid searching - // later. (todo: could make this installable) - // the same regardless of glyph. - numTables = ttUSHORT(data + cmap + 2); - info->index_map = 0; - for (i=0; i < numTables; ++i) { - stbtt_uint32 encoding_record = cmap + 4 + 8 * i; - // find an encoding we understand: - switch(ttUSHORT(data+encoding_record)) { - case STBTT_PLATFORM_ID_MICROSOFT: - switch (ttUSHORT(data+encoding_record+2)) { - case STBTT_MS_EID_UNICODE_BMP: - case STBTT_MS_EID_UNICODE_FULL: - // MS/Unicode - info->index_map = cmap + ttULONG(data+encoding_record+4); - break; - } - break; - } - } - if (info->index_map == 0) - return 0; - - info->indexToLocFormat = ttUSHORT(data+info->head + 50); - return 1; -} - -int stbtt_FindGlyphIndex(const stbtt_fontinfo *info, int unicode_codepoint) -{ - stbtt_uint8 *data = info->data; - stbtt_uint32 index_map = info->index_map; - - stbtt_uint16 format = ttUSHORT(data + index_map + 0); - if (format == 0) { // apple byte encoding - stbtt_int32 bytes = ttUSHORT(data + index_map + 2); - if (unicode_codepoint < bytes-6) - return ttBYTE(data + index_map + 6 + unicode_codepoint); - return 0; - } else if (format == 6) { - stbtt_uint32 first = ttUSHORT(data + index_map + 6); - stbtt_uint32 count = ttUSHORT(data + index_map + 8); - if ((stbtt_uint32) unicode_codepoint >= first && (stbtt_uint32) unicode_codepoint < first+count) - return ttUSHORT(data + index_map + 10 + (unicode_codepoint - first)*2); - return 0; - } else if (format == 2) { - STBTT_assert(0); // @TODO: high-byte mapping for japanese/chinese/korean - return 0; - } else if (format == 4) { // standard mapping for windows fonts: binary search collection of ranges - stbtt_uint16 segcount = ttUSHORT(data+index_map+6) >> 1; - stbtt_uint16 searchRange = ttUSHORT(data+index_map+8) >> 1; - stbtt_uint16 entrySelector = ttUSHORT(data+index_map+10); - stbtt_uint16 rangeShift = ttUSHORT(data+index_map+12) >> 1; - stbtt_uint16 item, offset, start; - - // do a binary search of the segments - stbtt_uint32 endCount = index_map + 14; - stbtt_uint32 search = endCount; - - if (unicode_codepoint > 0xffff) - return 0; - - // they lie from endCount .. endCount + segCount - // but searchRange is the nearest power of two, so... - if (unicode_codepoint >= ttUSHORT(data + search + rangeShift*2)) - search += rangeShift*2; - - // now decrement to bias correctly to find smallest - search -= 2; - while (entrySelector) { - stbtt_uint16 end; - searchRange >>= 1; - end = ttUSHORT(data + search + searchRange*2); - if (unicode_codepoint > end) - search += searchRange*2; - --entrySelector; - } - search += 2; - - item = (stbtt_uint16) ((search - endCount) >> 1); - - STBTT_assert(unicode_codepoint <= ttUSHORT(data + endCount + 2*item)); - start = ttUSHORT(data + index_map + 14 + segcount*2 + 2 + 2*item); - - if (unicode_codepoint < start) - return 0; - - offset = ttUSHORT(data + index_map + 14 + segcount*6 + 2 + 2*item); - if (offset == 0) - return (stbtt_uint16) (unicode_codepoint + ttSHORT(data + index_map + 14 + segcount*4 + 2 + 2*item)); - - return ttUSHORT(data + offset + (unicode_codepoint-start)*2 + index_map + 14 + segcount*6 + 2 + 2*item); - } else if (format == 12 || format == 13) { - stbtt_uint32 ngroups = ttULONG(data+index_map+12); - stbtt_int32 low,high; - //stbtt_uint16 g = 0; - low = 0; high = (stbtt_int32)ngroups; - // Binary search the right group. - while (low < high) { - stbtt_int32 mid = low + ((high-low) >> 1); // rounds down, so low <= mid < high - stbtt_uint32 start_char = ttULONG(data+index_map+16+mid*12); - stbtt_uint32 end_char = ttULONG(data+index_map+16+mid*12+4); - if ((stbtt_uint32) unicode_codepoint < start_char) - high = mid; - else if ((stbtt_uint32) unicode_codepoint > end_char) - low = mid+1; - else { - stbtt_uint32 start_glyph = ttULONG(data+index_map+16+mid*12+8); - if (format == 12) - return start_glyph + unicode_codepoint-start_char; - else // format == 13 - return start_glyph; - } - } - return 0; // not found - } - // @TODO - STBTT_assert(0); - return 0; -} - -int stbtt_GetCodepointShape(const stbtt_fontinfo *info, int unicode_codepoint, stbtt_vertex **vertices) -{ - return stbtt_GetGlyphShape(info, stbtt_FindGlyphIndex(info, unicode_codepoint), vertices); -} - -static void stbtt_setvertex(stbtt_vertex *v, stbtt_uint8 type, stbtt_int16 x, stbtt_int16 y, stbtt_int16 cx, stbtt_int16 cy) -{ - v->type = type; - v->x = x; - v->y = y; - v->cx = cx; - v->cy = cy; -} - -static int stbtt__GetGlyfOffset(const stbtt_fontinfo *info, int glyph_index) -{ - int g1,g2; - - if (glyph_index >= info->numGlyphs) return -1; // glyph index out of range - if (info->indexToLocFormat >= 2) return -1; // unknown index->glyph map format - - if (info->indexToLocFormat == 0) { - g1 = info->glyf + ttUSHORT(info->data + info->loca + glyph_index * 2) * 2; - g2 = info->glyf + ttUSHORT(info->data + info->loca + glyph_index * 2 + 2) * 2; - } else { - g1 = info->glyf + ttULONG (info->data + info->loca + glyph_index * 4); - g2 = info->glyf + ttULONG (info->data + info->loca + glyph_index * 4 + 4); - } - - return g1==g2 ? -1 : g1; // if length is 0, return -1 -} - -int stbtt_GetGlyphBox(const stbtt_fontinfo *info, int glyph_index, int *x0, int *y0, int *x1, int *y1) -{ - int g = stbtt__GetGlyfOffset(info, glyph_index); - if (g < 0) return 0; - - if (x0) *x0 = ttSHORT(info->data + g + 2); - if (y0) *y0 = ttSHORT(info->data + g + 4); - if (x1) *x1 = ttSHORT(info->data + g + 6); - if (y1) *y1 = ttSHORT(info->data + g + 8); - return 1; -} - -int stbtt_GetCodepointBox(const stbtt_fontinfo *info, int codepoint, int *x0, int *y0, int *x1, int *y1) -{ - return stbtt_GetGlyphBox(info, stbtt_FindGlyphIndex(info,codepoint), x0,y0,x1,y1); -} - -static int stbtt__close_shape(stbtt_vertex *vertices, int num_vertices, int was_off, int start_off, - stbtt_int32 sx, stbtt_int32 sy, stbtt_int32 scx, stbtt_int32 scy, stbtt_int32 cx, stbtt_int32 cy) -{ - if (start_off) { - if (was_off) - stbtt_setvertex(&vertices[num_vertices++], STBTT_vcurve, (cx+scx)>>1, (cy+scy)>>1, cx,cy); - stbtt_setvertex(&vertices[num_vertices++], STBTT_vcurve, sx,sy,scx,scy); - } else { - if (was_off) - stbtt_setvertex(&vertices[num_vertices++], STBTT_vcurve,sx,sy,cx,cy); - else - stbtt_setvertex(&vertices[num_vertices++], STBTT_vline,sx,sy,0,0); - } - return num_vertices; -} - -int stbtt_GetGlyphShape(const stbtt_fontinfo *info, int glyph_index, stbtt_vertex **pvertices) -{ - stbtt_int16 numberOfContours; - stbtt_uint8 *endPtsOfContours; - stbtt_uint8 *data = info->data; - stbtt_vertex *vertices=0; - int num_vertices=0; - int g = stbtt__GetGlyfOffset(info, glyph_index); - - *pvertices = NULL; - - if (g < 0) return 0; - - numberOfContours = ttSHORT(data + g); - - if (numberOfContours > 0) { - stbtt_uint8 flags=0,flagcount; - stbtt_int32 ins, i,j=0,m,n, next_move, was_off=0, off, start_off=0; - stbtt_int32 x,y,cx,cy,sx,sy, scx,scy; - scx=0; - scy=0; - stbtt_uint8 *points; - endPtsOfContours = (data + g + 10); - ins = ttUSHORT(data + g + 10 + numberOfContours * 2); - points = data + g + 10 + numberOfContours * 2 + 2 + ins; - - n = 1+ttUSHORT(endPtsOfContours + numberOfContours*2-2); - - m = n + 2*numberOfContours; // a loose bound on how many vertices we might need - vertices = (stbtt_vertex *) STBTT_malloc(m * sizeof(vertices[0]), info->userdata); - if (vertices == 0) - return 0; - - next_move = 0; - flagcount=0; - - // in first pass, we load uninterpreted data into the allocated array - // above, shifted to the end of the array so we won't overwrite it when - // we create our final data starting from the front - - off = m - n; // starting offset for uninterpreted data, regardless of how m ends up being calculated - - // first load flags - - for (i=0; i < n; ++i) { - if (flagcount == 0) { - flags = *points++; - if (flags & 8) - flagcount = *points++; - } else - --flagcount; - vertices[off+i].type = flags; - } - - // now load x coordinates - x=0; - for (i=0; i < n; ++i) { - flags = vertices[off+i].type; - if (flags & 2) { - stbtt_int16 dx = *points++; - x += (flags & 16) ? dx : -dx; // ??? - } else { - if (!(flags & 16)) { - x = x + (stbtt_int16) (points[0]*256 + points[1]); - points += 2; - } - } - vertices[off+i].x = x; - } - - // now load y coordinates - y=0; - for (i=0; i < n; ++i) { - flags = vertices[off+i].type; - if (flags & 4) { - stbtt_int16 dy = *points++; - y += (flags & 32) ? dy : -dy; // ??? - } else { - if (!(flags & 32)) { - y = y + (stbtt_int16) (points[0]*256 + points[1]); - points += 2; - } - } - vertices[off+i].y = y; - } - - // now convert them to our format - num_vertices=0; - sx = sy = cx = cy = 0; - for (i=0; i < n; ++i) { - flags = vertices[off+i].type; - x = (stbtt_int16) vertices[off+i].x; - y = (stbtt_int16) vertices[off+i].y; - - if (next_move == i) { - if (i != 0) - num_vertices = stbtt__close_shape(vertices, num_vertices, was_off, start_off, sx,sy,scx,scy,cx,cy); - - // now start the new one - start_off = !(flags & 1); - if (start_off) { - // if we start off with an off-curve point, then when we need to find a point on the curve - // where we can start, and we need to save some state for when we wraparound. - scx = x; - scy = y; - if (!(vertices[off+i+1].type & 1)) { - // next point is also a curve point, so interpolate an on-point curve - sx = (x + (stbtt_int32) vertices[off+i+1].x) >> 1; - sy = (y + (stbtt_int32) vertices[off+i+1].y) >> 1; - } else { - // otherwise just use the next point as our start point - sx = (stbtt_int32) vertices[off+i+1].x; - sy = (stbtt_int32) vertices[off+i+1].y; - ++i; // we're using point i+1 as the starting point, so skip it - } - } else { - sx = x; - sy = y; - } - stbtt_setvertex(&vertices[num_vertices++], STBTT_vmove,sx,sy,0,0); - was_off = 0; - next_move = 1 + ttUSHORT(endPtsOfContours+j*2); - ++j; - } else { - if (!(flags & 1)) { // if it's a curve - if (was_off) // two off-curve control points in a row means interpolate an on-curve midpoint - stbtt_setvertex(&vertices[num_vertices++], STBTT_vcurve, (cx+x)>>1, (cy+y)>>1, cx, cy); - cx = x; - cy = y; - was_off = 1; - } else { - if (was_off) - stbtt_setvertex(&vertices[num_vertices++], STBTT_vcurve, x,y, cx, cy); - else - stbtt_setvertex(&vertices[num_vertices++], STBTT_vline, x,y,0,0); - was_off = 0; - } - } - } - num_vertices = stbtt__close_shape(vertices, num_vertices, was_off, start_off, sx,sy,scx,scy,cx,cy); - } else if (numberOfContours == -1) { - // Compound shapes. - int more = 1; - stbtt_uint8 *comp = data + g + 10; - num_vertices = 0; - vertices = 0; - while (more) { - stbtt_uint16 flags, gidx; - int comp_num_verts = 0, i; - stbtt_vertex *comp_verts = 0, *tmp = 0; - float mtx[6] = {1,0,0,1,0,0}, m, n; - - flags = ttSHORT(comp); comp+=2; - gidx = ttSHORT(comp); comp+=2; - - if (flags & 2) { // XY values - if (flags & 1) { // shorts - mtx[4] = ttSHORT(comp); comp+=2; - mtx[5] = ttSHORT(comp); comp+=2; - } else { - mtx[4] = ttCHAR(comp); comp+=1; - mtx[5] = ttCHAR(comp); comp+=1; - } - } - else { - // @TODO handle matching point - STBTT_assert(0); - } - if (flags & (1<<3)) { // WE_HAVE_A_SCALE - mtx[0] = mtx[3] = ttSHORT(comp)/16384.0f; comp+=2; - mtx[1] = mtx[2] = 0; - } else if (flags & (1<<6)) { // WE_HAVE_AN_X_AND_YSCALE - mtx[0] = ttSHORT(comp)/16384.0f; comp+=2; - mtx[1] = mtx[2] = 0; - mtx[3] = ttSHORT(comp)/16384.0f; comp+=2; - } else if (flags & (1<<7)) { // WE_HAVE_A_TWO_BY_TWO - mtx[0] = ttSHORT(comp)/16384.0f; comp+=2; - mtx[1] = ttSHORT(comp)/16384.0f; comp+=2; - mtx[2] = ttSHORT(comp)/16384.0f; comp+=2; - mtx[3] = ttSHORT(comp)/16384.0f; comp+=2; - } - - // Find transformation scales. - m = (float) sqrt(mtx[0]*mtx[0] + mtx[1]*mtx[1]); - n = (float) sqrt(mtx[2]*mtx[2] + mtx[3]*mtx[3]); - - // Get indexed glyph. - comp_num_verts = stbtt_GetGlyphShape(info, gidx, &comp_verts); - if (comp_num_verts > 0) { - // Transform vertices. - for (i = 0; i < comp_num_verts; ++i) { - stbtt_vertex* v = &comp_verts[i]; - stbtt_vertex_type x,y; - x=v->x; y=v->y; - v->x = (stbtt_vertex_type)(m * (mtx[0]*x + mtx[2]*y + mtx[4])); - v->y = (stbtt_vertex_type)(n * (mtx[1]*x + mtx[3]*y + mtx[5])); - x=v->cx; y=v->cy; - v->cx = (stbtt_vertex_type)(m * (mtx[0]*x + mtx[2]*y + mtx[4])); - v->cy = (stbtt_vertex_type)(n * (mtx[1]*x + mtx[3]*y + mtx[5])); - } - // Append vertices. - tmp = (stbtt_vertex*)STBTT_malloc((num_vertices+comp_num_verts)*sizeof(stbtt_vertex), info->userdata); - if (!tmp) { - if (vertices) STBTT_free(vertices, info->userdata); - if (comp_verts) STBTT_free(comp_verts, info->userdata); - return 0; - } - if (num_vertices > 0) memcpy(tmp, vertices, num_vertices*sizeof(stbtt_vertex)); - memcpy(tmp+num_vertices, comp_verts, comp_num_verts*sizeof(stbtt_vertex)); - if (vertices) STBTT_free(vertices, info->userdata); - vertices = tmp; - STBTT_free(comp_verts, info->userdata); - num_vertices += comp_num_verts; - } - // More components ? - more = flags & (1<<5); - } - } else if (numberOfContours < 0) { - // @TODO other compound variations? - STBTT_assert(0); - } else { - // numberOfCounters == 0, do nothing - } - - *pvertices = vertices; - return num_vertices; -} - -void stbtt_GetGlyphHMetrics(const stbtt_fontinfo *info, int glyph_index, int *advanceWidth, int *leftSideBearing) -{ - stbtt_uint16 numOfLongHorMetrics = ttUSHORT(info->data+info->hhea + 34); - if (glyph_index < numOfLongHorMetrics) { - if (advanceWidth) *advanceWidth = ttSHORT(info->data + info->hmtx + 4*glyph_index); - if (leftSideBearing) *leftSideBearing = ttSHORT(info->data + info->hmtx + 4*glyph_index + 2+1); - } else { - if (advanceWidth) *advanceWidth = ttSHORT(info->data + info->hmtx + 4*(numOfLongHorMetrics-1)); - if (leftSideBearing) *leftSideBearing = ttSHORT(info->data + info->hmtx + 4*numOfLongHorMetrics + 2*(glyph_index - numOfLongHorMetrics)); - } -} - -int stbtt_GetGlyphKernAdvance(const stbtt_fontinfo *info, int glyph1, int glyph2) -{ - stbtt_uint8 *data = info->data + info->kern; - stbtt_uint32 needle, straw; - int l, r, m; - - // we only look at the first table. it must be 'horizontal' and format 0. - if (!info->kern) - return 0; - if (ttUSHORT(data+2) < 1) // number of tables, need at least 1 - return 0; - if (ttUSHORT(data+8) != 1) // horizontal flag must be set in format - return 0; - - l = 0; - r = ttUSHORT(data+10) - 1; - needle = glyph1 << 16 | glyph2; - while (l <= r) { - m = (l + r) >> 1; - straw = ttULONG(data+18+(m*6)); // note: unaligned read - if (needle < straw) - r = m - 1; - else if (needle > straw) - l = m + 1; - else - return ttSHORT(data+22+(m*6)); - } - return 0; -} - -int stbtt_GetCodepointKernAdvance(const stbtt_fontinfo *info, int ch1, int ch2) -{ - if (!info->kern) // if no kerning table, don't waste time looking up both codepoint->glyphs - return 0; - return stbtt_GetGlyphKernAdvance(info, stbtt_FindGlyphIndex(info,ch1), stbtt_FindGlyphIndex(info,ch2)); -} - -void stbtt_GetCodepointHMetrics(const stbtt_fontinfo *info, int codepoint, int *advanceWidth, int *leftSideBearing) -{ - stbtt_GetGlyphHMetrics(info, stbtt_FindGlyphIndex(info,codepoint), advanceWidth, leftSideBearing); -} - -void stbtt_GetFontVMetrics(const stbtt_fontinfo *info, int *ascent, int *descent, int *lineGap) -{ - if (ascent ) *ascent = ttSHORT(info->data+info->hhea + 4); - if (descent) *descent = ttSHORT(info->data+info->hhea + 6); - if (lineGap) *lineGap = ttSHORT(info->data+info->hhea + 8); -} - -float stbtt_ScaleForPixelHeight(const stbtt_fontinfo *info, float height) -{ - int fheight = ttSHORT(info->data + info->hhea + 4) - ttSHORT(info->data + info->hhea + 6); - return (float) height / fheight; -} - -void stbtt_FreeShape(const stbtt_fontinfo *info, stbtt_vertex *v) -{ - STBTT_free(v, info->userdata); -} - -////////////////////////////////////////////////////////////////////////////// -// -// antialiasing software rasterizer -// - -void stbtt_GetGlyphBitmapBoxSubpixel(const stbtt_fontinfo *font, int glyph, float scale_x, float scale_y,float shift_x, float shift_y, int *ix0, int *iy0, int *ix1, int *iy1) -{ - int x0,y0,x1,y1; - if (!stbtt_GetGlyphBox(font, glyph, &x0,&y0,&x1,&y1)) - x0=y0=x1=y1=0; // e.g. space character - // now move to integral bboxes (treating pixels as little squares, what pixels get touched)? - if (ix0) *ix0 = STBTT_ifloor(x0 * scale_x + shift_x); - if (iy0) *iy0 = -STBTT_iceil (y1 * scale_y + shift_y); - if (ix1) *ix1 = STBTT_iceil (x1 * scale_x + shift_x); - if (iy1) *iy1 = -STBTT_ifloor(y0 * scale_y + shift_y); -} -void stbtt_GetGlyphBitmapBox(const stbtt_fontinfo *font, int glyph, float scale_x, float scale_y, int *ix0, int *iy0, int *ix1, int *iy1) -{ - stbtt_GetGlyphBitmapBoxSubpixel(font, glyph, scale_x, scale_y,0.0f,0.0f, ix0, iy0, ix1, iy1); -} - -void stbtt_GetCodepointBitmapBoxSubpixel(const stbtt_fontinfo *font, int codepoint, float scale_x, float scale_y, float shift_x, float shift_y, int *ix0, int *iy0, int *ix1, int *iy1) -{ - stbtt_GetGlyphBitmapBoxSubpixel(font, stbtt_FindGlyphIndex(font,codepoint), scale_x, scale_y,shift_x,shift_y, ix0,iy0,ix1,iy1); -} - -void stbtt_GetCodepointBitmapBox(const stbtt_fontinfo *font, int codepoint, float scale_x, float scale_y, int *ix0, int *iy0, int *ix1, int *iy1) -{ - stbtt_GetCodepointBitmapBoxSubpixel(font, codepoint, scale_x, scale_y,0.0f,0.0f, ix0,iy0,ix1,iy1); -} - -typedef struct stbtt__edge { - float x0,y0, x1,y1; - int invert; -} stbtt__edge; - -typedef struct stbtt__active_edge -{ - int x,dx; - float ey; - struct stbtt__active_edge *next; - int valid; -} stbtt__active_edge; - -#define FIXSHIFT 10 -#define FIX (1 << FIXSHIFT) -#define FIXMASK (FIX-1) - -static stbtt__active_edge *new_active(stbtt__edge *e, int off_x, float start_point, void *userdata) -{ - stbtt__active_edge *z = (stbtt__active_edge *) STBTT_malloc(sizeof(*z), userdata); // @TODO: make a pool of these!!! - float dxdy = (e->x1 - e->x0) / (e->y1 - e->y0); - STBTT_assert(e->y0 <= start_point); - if (!z) return z; - // round dx down to avoid going too far - if (dxdy < 0) - z->dx = -STBTT_ifloor(FIX * -dxdy); - else - z->dx = STBTT_ifloor(FIX * dxdy); - z->x = STBTT_ifloor(FIX * (e->x0 + dxdy * (start_point - e->y0))); - z->x -= off_x * FIX; - z->ey = e->y1; - z->next = 0; - z->valid = e->invert ? 1 : -1; - return z; -} - -// note: this routine clips fills that extend off the edges... ideally this -// wouldn't happen, but it could happen if the truetype glyph bounding boxes -// are wrong, or if the user supplies a too-small bitmap -static void stbtt__fill_active_edges(unsigned char *scanline, int len, stbtt__active_edge *e, int max_weight) -{ - // non-zero winding fill - int x0=0, w=0; - - while (e) { - if (w == 0) { - // if we're currently at zero, we need to record the edge start point - x0 = e->x; w += e->valid; - } else { - int x1 = e->x; w += e->valid; - // if we went to zero, we need to draw - if (w == 0) { - int i = x0 >> FIXSHIFT; - int j = x1 >> FIXSHIFT; - - if (i < len && j >= 0) { - if (i == j) { - // x0,x1 are the same pixel, so compute combined coverage - scanline[i] = scanline[i] + (stbtt_uint8) ((x1 - x0) * max_weight >> FIXSHIFT); - } else { - if (i >= 0) // add antialiasing for x0 - scanline[i] = scanline[i] + (stbtt_uint8) (((FIX - (x0 & FIXMASK)) * max_weight) >> FIXSHIFT); - else - i = -1; // clip - - if (j < len) // add antialiasing for x1 - scanline[j] = scanline[j] + (stbtt_uint8) (((x1 & FIXMASK) * max_weight) >> FIXSHIFT); - else - j = len; // clip - - for (++i; i < j; ++i) // fill pixels between x0 and x1 - scanline[i] = scanline[i] + (stbtt_uint8) max_weight; - } - } - } - } - - e = e->next; - } -} - -static void stbtt__rasterize_sorted_edges(stbtt__bitmap *result, stbtt__edge *e, int n, int vsubsample, int off_x, int off_y, void *userdata) -{ - stbtt__active_edge *active = NULL; - int y,j=0; - int max_weight = (255 / vsubsample); // weight per vertical scanline - int s; // vertical subsample index - unsigned char scanline_data[512], *scanline; - - if (result->w > 512) - scanline = (unsigned char *) STBTT_malloc(result->w, userdata); - else - scanline = scanline_data; - - y = off_y * vsubsample; - e[n].y0 = (off_y + result->h) * (float) vsubsample + 1; - - while (j < result->h) { - STBTT_memset(scanline, 0, result->w); - for (s=0; s < vsubsample; ++s) { - // find center of pixel for this scanline - float scan_y = y + 0.5f; - stbtt__active_edge **step = &active; - - // update all active edges; - // remove all active edges that terminate before the center of this scanline - while (*step) { - stbtt__active_edge * z = *step; - if (z->ey <= scan_y) { - *step = z->next; // delete from list - STBTT_assert(z->valid); - z->valid = 0; - STBTT_free(z, userdata); - } else { - z->x += z->dx; // advance to position for current scanline - step = &((*step)->next); // advance through list - } - } - - // resort the list if needed - for(;;) { - int changed=0; - step = &active; - while (*step && (*step)->next) { - if ((*step)->x > (*step)->next->x) { - stbtt__active_edge *t = *step; - stbtt__active_edge *q = t->next; - - t->next = q->next; - q->next = t; - *step = q; - changed = 1; - } - step = &(*step)->next; - } - if (!changed) break; - } - - // insert all edges that start before the center of this scanline -- omit ones that also end on this scanline - while (e->y0 <= scan_y) { - if (e->y1 > scan_y) { - stbtt__active_edge *z = new_active(e, off_x, scan_y, userdata); - // find insertion point - if (active == NULL) - active = z; - else if (z->x < active->x) { - // insert at front - z->next = active; - active = z; - } else { - // find thing to insert AFTER - stbtt__active_edge *p = active; - while (p->next && p->next->x < z->x) - p = p->next; - // at this point, p->next->x is NOT < z->x - z->next = p->next; - p->next = z; - } - } - ++e; - } - - // now process all active edges in XOR fashion - if (active) - stbtt__fill_active_edges(scanline, result->w, active, max_weight); - - ++y; - } - STBTT_memcpy(result->pixels + j * result->stride, scanline, result->w); - ++j; - } - - while (active) { - stbtt__active_edge *z = active; - active = active->next; - STBTT_free(z, userdata); - } - - if (scanline != scanline_data) - STBTT_free(scanline, userdata); -} - -static int stbtt__edge_compare(const void *p, const void *q) -{ - stbtt__edge *a = (stbtt__edge *) p; - stbtt__edge *b = (stbtt__edge *) q; - - if (a->y0 < b->y0) return -1; - if (a->y0 > b->y0) return 1; - return 0; -} - -typedef struct -{ - float x,y; -} stbtt__point; - -static void stbtt__rasterize(stbtt__bitmap *result, stbtt__point *pts, int *wcount, int windings, float scale_x, float scale_y, float shift_x, float shift_y, int off_x, int off_y, int invert, void *userdata) -{ - float y_scale_inv = invert ? -scale_y : scale_y; - stbtt__edge *e; - int n,i,j,k,m; - int vsubsample = result->h < 8 ? 15 : 5; - // vsubsample should divide 255 evenly; otherwise we won't reach full opacity - - // now we have to blow out the windings into explicit edge lists - n = 0; - for (i=0; i < windings; ++i) - n += wcount[i]; - - e = (stbtt__edge *) STBTT_malloc(sizeof(*e) * (n+1), userdata); // add an extra one as a sentinel - if (e == 0) return; - n = 0; - - m=0; - for (i=0; i < windings; ++i) { - stbtt__point *p = pts + m; - m += wcount[i]; - j = wcount[i]-1; - for (k=0; k < wcount[i]; j=k++) { - int a=k,b=j; - // skip the edge if horizontal - if (p[j].y == p[k].y) - continue; - // add edge from j to k to the list - e[n].invert = 0; - if (invert ? p[j].y > p[k].y : p[j].y < p[k].y) { - e[n].invert = 1; - a=j,b=k; - } - e[n].x0 = p[a].x * scale_x + shift_x; - e[n].y0 = p[a].y * y_scale_inv * vsubsample + shift_y; - e[n].x1 = p[b].x * scale_x + shift_x; - e[n].y1 = p[b].y * y_scale_inv * vsubsample + shift_y; - ++n; - } - } - - // now sort the edges by their highest point (should snap to integer, and then by x) - STBTT_sort(e, n, sizeof(e[0]), stbtt__edge_compare); - - // now, traverse the scanlines and find the intersections on each scanline, use xor winding rule - stbtt__rasterize_sorted_edges(result, e, n, vsubsample, off_x, off_y, userdata); - - STBTT_free(e, userdata); -} - -static void stbtt__add_point(stbtt__point *points, int n, float x, float y) -{ - if (!points) return; // during first pass, it's unallocated - points[n].x = x; - points[n].y = y; -} - -// tesselate until threshhold p is happy... @TODO warped to compensate for non-linear stretching -static int stbtt__tesselate_curve(stbtt__point *points, int *num_points, float x0, float y0, float x1, float y1, float x2, float y2, float objspace_flatness_squared, int n) -{ - // midpoint - float mx = (x0 + 2*x1 + x2)/4; - float my = (y0 + 2*y1 + y2)/4; - // versus directly drawn line - float dx = (x0+x2)/2 - mx; - float dy = (y0+y2)/2 - my; - if (n > 16) // 65536 segments on one curve better be enough! - return 1; - if (dx*dx+dy*dy > objspace_flatness_squared) { // half-pixel error allowed... need to be smaller if AA - stbtt__tesselate_curve(points, num_points, x0,y0, (x0+x1)/2.0f,(y0+y1)/2.0f, mx,my, objspace_flatness_squared,n+1); - stbtt__tesselate_curve(points, num_points, mx,my, (x1+x2)/2.0f,(y1+y2)/2.0f, x2,y2, objspace_flatness_squared,n+1); - } else { - stbtt__add_point(points, *num_points,x2,y2); - *num_points = *num_points+1; - } - return 1; -} - -// returns number of contours -stbtt__point *stbtt_FlattenCurves(stbtt_vertex *vertices, int num_verts, float objspace_flatness, int **contour_lengths, int *num_contours, void *userdata) -{ - stbtt__point *points=0; - int num_points=0; - - float objspace_flatness_squared = objspace_flatness * objspace_flatness; - int i,n=0,start=0, pass; - - // count how many "moves" there are to get the contour count - for (i=0; i < num_verts; ++i) - if (vertices[i].type == STBTT_vmove) - ++n; - - *num_contours = n; - if (n == 0) return 0; - - *contour_lengths = (int *) STBTT_malloc(sizeof(**contour_lengths) * n, userdata); - - if (*contour_lengths == 0) { - *num_contours = 0; - return 0; - } - - // make two passes through the points so we don't need to realloc - for (pass=0; pass < 2; ++pass) { - float x=0,y=0; - if (pass == 1) { - points = (stbtt__point *) STBTT_malloc(num_points * sizeof(points[0]), userdata); - if (points == NULL) goto error; - } - num_points = 0; - n= -1; - for (i=0; i < num_verts; ++i) { - switch (vertices[i].type) { - case STBTT_vmove: - // start the next contour - if (n >= 0) - (*contour_lengths)[n] = num_points - start; - ++n; - start = num_points; - - x = vertices[i].x, y = vertices[i].y; - stbtt__add_point(points, num_points++, x,y); - break; - case STBTT_vline: - x = vertices[i].x, y = vertices[i].y; - stbtt__add_point(points, num_points++, x, y); - break; - case STBTT_vcurve: - stbtt__tesselate_curve(points, &num_points, x,y, - vertices[i].cx, vertices[i].cy, - vertices[i].x, vertices[i].y, - objspace_flatness_squared, 0); - x = vertices[i].x, y = vertices[i].y; - break; - } - } - (*contour_lengths)[n] = num_points - start; - } - - return points; -error: - STBTT_free(points, userdata); - STBTT_free(*contour_lengths, userdata); - *contour_lengths = 0; - *num_contours = 0; - return NULL; -} - -void stbtt_Rasterize(stbtt__bitmap *result, float flatness_in_pixels, stbtt_vertex *vertices, int num_verts, float scale_x, float scale_y, float shift_x, float shift_y, int x_off, int y_off, int invert, void *userdata) -{ - float scale = scale_x > scale_y ? scale_y : scale_x; - int winding_count, *winding_lengths; - stbtt__point *windings = stbtt_FlattenCurves(vertices, num_verts, flatness_in_pixels / scale, &winding_lengths, &winding_count, userdata); - if (windings) { - stbtt__rasterize(result, windings, winding_lengths, winding_count, scale_x, scale_y, shift_x, shift_y, x_off, y_off, invert, userdata); - STBTT_free(winding_lengths, userdata); - STBTT_free(windings, userdata); - } -} - -void stbtt_FreeBitmap(unsigned char *bitmap, void *userdata) -{ - STBTT_free(bitmap, userdata); -} - -unsigned char *stbtt_GetGlyphBitmapSubpixel(const stbtt_fontinfo *info, float scale_x, float scale_y, float shift_x, float shift_y, int glyph, int *width, int *height, int *xoff, int *yoff) -{ - int ix0,iy0,ix1,iy1; - stbtt__bitmap gbm; - stbtt_vertex *vertices; - int num_verts = stbtt_GetGlyphShape(info, glyph, &vertices); - - if (scale_x == 0) scale_x = scale_y; - if (scale_y == 0) { - if (scale_x == 0) return NULL; - scale_y = scale_x; - } - - stbtt_GetGlyphBitmapBox(info, glyph, scale_x, scale_y, &ix0,&iy0,&ix1,&iy1); - - // now we get the size - gbm.w = (ix1 - ix0); - gbm.h = (iy1 - iy0); - gbm.pixels = NULL; // in case we error - - if (width ) *width = gbm.w; - if (height) *height = gbm.h; - if (xoff ) *xoff = ix0; - if (yoff ) *yoff = iy0; - - if (gbm.w && gbm.h) { - gbm.pixels = (unsigned char *) STBTT_malloc(gbm.w * gbm.h, info->userdata); - if (gbm.pixels) { - gbm.stride = gbm.w; - - stbtt_Rasterize(&gbm, 0.35f, vertices, num_verts, scale_x, scale_y, shift_x, shift_y, ix0, iy0, 1, info->userdata); - } - } - STBTT_free(vertices, info->userdata); - return gbm.pixels; -} - -unsigned char *stbtt_GetGlyphBitmap(const stbtt_fontinfo *info, float scale_x, float scale_y, int glyph, int *width, int *height, int *xoff, int *yoff) -{ - return stbtt_GetGlyphBitmapSubpixel(info, scale_x, scale_y, 0.0f, 0.0f, glyph, width, height, xoff, yoff); -} - -void stbtt_MakeGlyphBitmapSubpixel(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, float shift_x, float shift_y, int glyph) -{ - int ix0,iy0; - stbtt_vertex *vertices; - int num_verts = stbtt_GetGlyphShape(info, glyph, &vertices); - stbtt__bitmap gbm; - - stbtt_GetGlyphBitmapBoxSubpixel(info, glyph, scale_x, scale_y, shift_x, shift_y, &ix0,&iy0,0,0); - gbm.pixels = output; - gbm.w = out_w; - gbm.h = out_h; - gbm.stride = out_stride; - - if (gbm.w && gbm.h) - stbtt_Rasterize(&gbm, 0.35f, vertices, num_verts, scale_x, scale_y, shift_x, shift_y, ix0,iy0, 1, info->userdata); - - STBTT_free(vertices, info->userdata); -} - -void stbtt_MakeGlyphBitmap(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, int glyph) -{ - stbtt_MakeGlyphBitmapSubpixel(info, output, out_w, out_h, out_stride, scale_x, scale_y, 0.0f,0.0f, glyph); -} - -unsigned char *stbtt_GetCodepointBitmapSubpixel(const stbtt_fontinfo *info, float scale_x, float scale_y, float shift_x, float shift_y, int codepoint, int *width, int *height, int *xoff, int *yoff) -{ - return stbtt_GetGlyphBitmapSubpixel(info, scale_x, scale_y,shift_x,shift_y, stbtt_FindGlyphIndex(info,codepoint), width,height,xoff,yoff); -} - -void stbtt_MakeCodepointBitmapSubpixel(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, float shift_x, float shift_y, int codepoint) -{ - stbtt_MakeGlyphBitmapSubpixel(info, output, out_w, out_h, out_stride, scale_x, scale_y, shift_x, shift_y, stbtt_FindGlyphIndex(info,codepoint)); -} - -unsigned char *stbtt_GetCodepointBitmap(const stbtt_fontinfo *info, float scale_x, float scale_y, int codepoint, int *width, int *height, int *xoff, int *yoff) -{ - return stbtt_GetCodepointBitmapSubpixel(info, scale_x, scale_y, 0.0f,0.0f, codepoint, width,height,xoff,yoff); -} - -void stbtt_MakeCodepointBitmap(const stbtt_fontinfo *info, unsigned char *output, int out_w, int out_h, int out_stride, float scale_x, float scale_y, int codepoint) -{ - stbtt_MakeCodepointBitmapSubpixel(info, output, out_w, out_h, out_stride, scale_x, scale_y, 0.0f,0.0f, codepoint); -} - -////////////////////////////////////////////////////////////////////////////// -// -// bitmap baking -// -// This is SUPER-CRAPPY packing to keep source code small - -extern int stbtt_BakeFontBitmap(const unsigned char *data, int offset, // font location (use offset=0 for plain .ttf) - float pixel_height, // height of font in pixels - unsigned char *pixels, int pw, int ph, // bitmap to be filled in - int first_char, int num_chars, // characters to bake - stbtt_bakedchar *chardata) -{ - float scale; - int x,y,bottom_y, i; - stbtt_fontinfo f; - stbtt_InitFont(&f, data, offset); - STBTT_memset(pixels, 0, pw*ph); // background of 0 around pixels - x=y=1; - bottom_y = 1; - - scale = stbtt_ScaleForPixelHeight(&f, pixel_height); - - for (i=0; i < num_chars; ++i) { - int advance, lsb, x0,y0,x1,y1,gw,gh; - int g = stbtt_FindGlyphIndex(&f, first_char + i); - stbtt_GetGlyphHMetrics(&f, g, &advance, &lsb); - stbtt_GetGlyphBitmapBox(&f, g, scale,scale, &x0,&y0,&x1,&y1); - gw = x1-x0; - gh = y1-y0; - if (x + gw + 1 >= pw) - y = bottom_y, x = 1; // advance to next row - if (y + gh + 1 >= ph) // check if it fits vertically AFTER potentially moving to next row - return -i; - STBTT_assert(x+gw < pw); - STBTT_assert(y+gh < ph); - stbtt_MakeGlyphBitmap(&f, pixels+x+y*pw, gw,gh,pw, scale,scale, g); - chardata[i].x0 = (stbtt_int16) x; - chardata[i].y0 = (stbtt_int16) y; - chardata[i].x1 = (stbtt_int16) (x + gw); - chardata[i].y1 = (stbtt_int16) (y + gh); - chardata[i].xadvance = scale * advance; - chardata[i].xoff = (float) x0; - chardata[i].yoff = (float) y0; - x = x + gw + 2; - if (y+gh+2 > bottom_y) - bottom_y = y+gh+2; - } - return bottom_y; -} - -void stbtt_GetBakedQuad(stbtt_bakedchar *chardata, int pw, int ph, int char_index, float *xpos, float *ypos, stbtt_aligned_quad *q, int opengl_fillrule) -{ - float d3d_bias = opengl_fillrule ? 0 : -0.5f; - float ipw = 1.0f / pw, iph = 1.0f / ph; - stbtt_bakedchar *b = chardata + char_index; - int round_x = STBTT_ifloor((*xpos + b->xoff) + 0.5); - int round_y = STBTT_ifloor((*ypos + b->yoff) + 0.5); - - q->x0 = round_x + d3d_bias; - q->y0 = round_y + d3d_bias; - q->x1 = round_x + b->x1 - b->x0 + d3d_bias; - q->y1 = round_y + b->y1 - b->y0 + d3d_bias; - - q->s0 = b->x0 * ipw; - q->t0 = b->y0 * iph; - q->s1 = b->x1 * ipw; - q->t1 = b->y1 * iph; - - *xpos += b->xadvance; -} - -////////////////////////////////////////////////////////////////////////////// -// -// font name matching -- recommended not to use this -// - -// check if a utf8 string contains a prefix which is the utf16 string; if so return length of matching utf8 string -static stbtt_int32 stbtt__CompareUTF8toUTF16_bigendian_prefix(const stbtt_uint8 *s1, stbtt_int32 len1, const stbtt_uint8 *s2, stbtt_int32 len2) -{ - stbtt_int32 i=0; - - // convert utf16 to utf8 and compare the results while converting - while (len2) { - stbtt_uint16 ch = s2[0]*256 + s2[1]; - if (ch < 0x80) { - if (i >= len1) return -1; - if (s1[i++] != ch) return -1; - } else if (ch < 0x800) { - if (i+1 >= len1) return -1; - if (s1[i++] != 0xc0 + (ch >> 6)) return -1; - if (s1[i++] != 0x80 + (ch & 0x3f)) return -1; - } else if (ch >= 0xd800 && ch < 0xdc00) { - stbtt_uint32 c; - stbtt_uint16 ch2 = s2[2]*256 + s2[3]; - if (i+3 >= len1) return -1; - c = ((ch - 0xd800) << 10) + (ch2 - 0xdc00) + 0x10000; - if (s1[i++] != 0xf0 + (c >> 18)) return -1; - if (s1[i++] != 0x80 + ((c >> 12) & 0x3f)) return -1; - if (s1[i++] != 0x80 + ((c >> 6) & 0x3f)) return -1; - if (s1[i++] != 0x80 + ((c ) & 0x3f)) return -1; - s2 += 2; // plus another 2 below - len2 -= 2; - } else if (ch >= 0xdc00 && ch < 0xe000) { - return -1; - } else { - if (i+2 >= len1) return -1; - if (s1[i++] != 0xe0 + (ch >> 12)) return -1; - if (s1[i++] != 0x80 + ((ch >> 6) & 0x3f)) return -1; - if (s1[i++] != 0x80 + ((ch ) & 0x3f)) return -1; - } - s2 += 2; - len2 -= 2; - } - return i; -} - -int stbtt_CompareUTF8toUTF16_bigendian(const char *s1, int len1, const char *s2, int len2) -{ - return len1 == stbtt__CompareUTF8toUTF16_bigendian_prefix((const stbtt_uint8*) s1, len1, (const stbtt_uint8*) s2, len2); -} - -// returns results in whatever encoding you request... but note that 2-byte encodings -// will be BIG-ENDIAN... use stbtt_CompareUTF8toUTF16_bigendian() to compare -const char *stbtt_GetFontNameString(const stbtt_fontinfo *font, int *length, int platformID, int encodingID, int languageID, int nameID) -{ - stbtt_int32 i,count,stringOffset; - stbtt_uint8 *fc = font->data; - stbtt_uint32 offset = font->fontstart; - stbtt_uint32 nm = stbtt__find_table(fc, offset, "name"); - if (!nm) return NULL; - - count = ttUSHORT(fc+nm+2); - stringOffset = nm + ttUSHORT(fc+nm+4); - for (i=0; i < count; ++i) { - stbtt_uint32 loc = nm + 6 + 12 * i; - if (platformID == ttUSHORT(fc+loc+0) && encodingID == ttUSHORT(fc+loc+2) - && languageID == ttUSHORT(fc+loc+4) && nameID == ttUSHORT(fc+loc+6)) { - *length = ttUSHORT(fc+loc+8); - return (const char *) (fc+stringOffset+ttUSHORT(fc+loc+10)); - } - } - return NULL; -} - -static int stbtt__matchpair(stbtt_uint8 *fc, stbtt_uint32 nm, stbtt_uint8 *name, stbtt_int32 nlen, stbtt_int32 target_id, stbtt_int32 next_id) -{ - stbtt_int32 i; - stbtt_int32 count = ttUSHORT(fc+nm+2); - stbtt_int32 stringOffset = nm + ttUSHORT(fc+nm+4); - - for (i=0; i < count; ++i) { - stbtt_uint32 loc = nm + 6 + 12 * i; - stbtt_int32 id = ttUSHORT(fc+loc+6); - if (id == target_id) { - // find the encoding - stbtt_int32 platform = ttUSHORT(fc+loc+0), encoding = ttUSHORT(fc+loc+2), language = ttUSHORT(fc+loc+4); - - // is this a Unicode encoding? - if (platform == 0 || (platform == 3 && encoding == 1) || (platform == 3 && encoding == 10)) { - stbtt_int32 slen = ttUSHORT(fc+loc+8), off = ttUSHORT(fc+loc+10); - - // check if there's a prefix match - stbtt_int32 matchlen = stbtt__CompareUTF8toUTF16_bigendian_prefix(name, nlen, fc+stringOffset+off,slen); - if (matchlen >= 0) { - // check for target_id+1 immediately following, with same encoding & language - if (i+1 < count && ttUSHORT(fc+loc+12+6) == next_id && ttUSHORT(fc+loc+12) == platform && ttUSHORT(fc+loc+12+2) == encoding && ttUSHORT(fc+loc+12+4) == language) { - stbtt_int32 slen = ttUSHORT(fc+loc+12+8), off = ttUSHORT(fc+loc+12+10); - if (slen == 0) { - if (matchlen == nlen) - return 1; - } else if (matchlen < nlen && name[matchlen] == ' ') { - ++matchlen; - if (stbtt_CompareUTF8toUTF16_bigendian((char*) (name+matchlen), nlen-matchlen, (char*)(fc+stringOffset+off),slen)) - return 1; - } - } else { - // if nothing immediately following - if (matchlen == nlen) - return 1; - } - } - } - - // @TODO handle other encodings - } - } - return 0; -} - -static int stbtt__matches(stbtt_uint8 *fc, stbtt_uint32 offset, stbtt_uint8 *name, stbtt_int32 flags) -{ - stbtt_int32 nlen = STBTT_strlen((char *) name); - stbtt_uint32 nm,hd; - if (!stbtt__isfont(fc+offset)) return 0; - - // check italics/bold/underline flags in macStyle... - if (flags) { - hd = stbtt__find_table(fc, offset, "head"); - if ((ttUSHORT(fc+hd+44) & 7) != (flags & 7)) return 0; - } - - nm = stbtt__find_table(fc, offset, "name"); - if (!nm) return 0; - - if (flags) { - // if we checked the macStyle flags, then just check the family and ignore the subfamily - if (stbtt__matchpair(fc, nm, name, nlen, 16, -1)) return 1; - if (stbtt__matchpair(fc, nm, name, nlen, 1, -1)) return 1; - if (stbtt__matchpair(fc, nm, name, nlen, 3, -1)) return 1; - } else { - if (stbtt__matchpair(fc, nm, name, nlen, 16, 17)) return 1; - if (stbtt__matchpair(fc, nm, name, nlen, 1, 2)) return 1; - if (stbtt__matchpair(fc, nm, name, nlen, 3, -1)) return 1; - } - - return 0; -} - -int stbtt_FindMatchingFont(const unsigned char *font_collection, const char *name_utf8, stbtt_int32 flags) -{ - stbtt_int32 i; - for (i=0;;++i) { - stbtt_int32 off = stbtt_GetFontOffsetForIndex(font_collection, i); - if (off < 0) return off; - if (stbtt__matches((stbtt_uint8 *) font_collection, off, (stbtt_uint8*) name_utf8, flags)) - return off; - } -} - -#endif // STB_TRUETYPE_IMPLEMENTATION diff --git a/btgui/enet/callbacks.c b/btgui/enet/callbacks.c deleted file mode 100644 index f94128256..000000000 --- a/btgui/enet/callbacks.c +++ /dev/null @@ -1,47 +0,0 @@ -/** - @file callbacks.c - @brief ENet callback functions -*/ -#define ENET_BUILDING_LIB 1 -#include "enet/enet.h" - -static ENetCallbacks callbacks = { malloc, free, abort }; - -int -enet_initialize_with_callbacks (ENetVersion version, const ENetCallbacks * inits) -{ - if (version < ENET_VERSION_CREATE (1, 3, 0)) - return -1; - - if (inits -> malloc != NULL || inits -> free != NULL) - { - if (inits -> malloc == NULL || inits -> free == NULL) - return -1; - - callbacks.malloc = inits -> malloc; - callbacks.free = inits -> free; - } - - if (inits -> no_memory != NULL) - callbacks.no_memory = inits -> no_memory; - - return enet_initialize (); -} - -void * -enet_malloc (size_t size) -{ - void * memory = callbacks.malloc (size); - - if (memory == NULL) - callbacks.no_memory (); - - return memory; -} - -void -enet_free (void * memory) -{ - callbacks.free (memory); -} - diff --git a/btgui/enet/compress.c b/btgui/enet/compress.c deleted file mode 100644 index 784489a78..000000000 --- a/btgui/enet/compress.c +++ /dev/null @@ -1,654 +0,0 @@ -/** - @file compress.c - @brief An adaptive order-2 PPM range coder -*/ -#define ENET_BUILDING_LIB 1 -#include -#include "enet/enet.h" - -typedef struct _ENetSymbol -{ - /* binary indexed tree of symbols */ - enet_uint8 value; - enet_uint8 count; - enet_uint16 under; - enet_uint16 left, right; - - /* context defined by this symbol */ - enet_uint16 symbols; - enet_uint16 escapes; - enet_uint16 total; - enet_uint16 parent; -} ENetSymbol; - -/* adaptation constants tuned aggressively for small packet sizes rather than large file compression */ -enum -{ - ENET_RANGE_CODER_TOP = 1<<24, - ENET_RANGE_CODER_BOTTOM = 1<<16, - - ENET_CONTEXT_SYMBOL_DELTA = 3, - ENET_CONTEXT_SYMBOL_MINIMUM = 1, - ENET_CONTEXT_ESCAPE_MINIMUM = 1, - - ENET_SUBCONTEXT_ORDER = 2, - ENET_SUBCONTEXT_SYMBOL_DELTA = 2, - ENET_SUBCONTEXT_ESCAPE_DELTA = 5 -}; - -/* context exclusion roughly halves compression speed, so disable for now */ -#undef ENET_CONTEXT_EXCLUSION - -typedef struct _ENetRangeCoder -{ - /* only allocate enough symbols for reasonable MTUs, would need to be larger for large file compression */ - ENetSymbol symbols[4096]; -} ENetRangeCoder; - -void * -enet_range_coder_create (void) -{ - ENetRangeCoder * rangeCoder = (ENetRangeCoder *) enet_malloc (sizeof (ENetRangeCoder)); - if (rangeCoder == NULL) - return NULL; - - return rangeCoder; -} - -void -enet_range_coder_destroy (void * context) -{ - ENetRangeCoder * rangeCoder = (ENetRangeCoder *) context; - if (rangeCoder == NULL) - return; - - enet_free (rangeCoder); -} - -#define ENET_SYMBOL_CREATE(symbol, value_, count_) \ -{ \ - symbol = & rangeCoder -> symbols [nextSymbol ++]; \ - symbol -> value = value_; \ - symbol -> count = count_; \ - symbol -> under = count_; \ - symbol -> left = 0; \ - symbol -> right = 0; \ - symbol -> symbols = 0; \ - symbol -> escapes = 0; \ - symbol -> total = 0; \ - symbol -> parent = 0; \ -} - -#define ENET_CONTEXT_CREATE(context, escapes_, minimum) \ -{ \ - ENET_SYMBOL_CREATE (context, 0, 0); \ - (context) -> escapes = escapes_; \ - (context) -> total = escapes_ + 256*minimum; \ - (context) -> symbols = 0; \ -} - -static enet_uint16 -enet_symbol_rescale (ENetSymbol * symbol) -{ - enet_uint16 total = 0; - for (;;) - { - symbol -> count -= symbol->count >> 1; - symbol -> under = symbol -> count; - if (symbol -> left) - symbol -> under += enet_symbol_rescale (symbol + symbol -> left); - total += symbol -> under; - if (! symbol -> right) break; - symbol += symbol -> right; - } - return total; -} - -#define ENET_CONTEXT_RESCALE(context, minimum) \ -{ \ - (context) -> total = (context) -> symbols ? enet_symbol_rescale ((context) + (context) -> symbols) : 0; \ - (context) -> escapes -= (context) -> escapes >> 1; \ - (context) -> total += (context) -> escapes + 256*minimum; \ -} - -#define ENET_RANGE_CODER_OUTPUT(value) \ -{ \ - if (outData >= outEnd) \ - return 0; \ - * outData ++ = value; \ -} - -#define ENET_RANGE_CODER_ENCODE(under, count, total) \ -{ \ - encodeRange /= (total); \ - encodeLow += (under) * encodeRange; \ - encodeRange *= (count); \ - for (;;) \ - { \ - if((encodeLow ^ (encodeLow + encodeRange)) >= ENET_RANGE_CODER_TOP) \ - { \ - if(encodeRange >= ENET_RANGE_CODER_BOTTOM) break; \ - encodeRange = -encodeLow & (ENET_RANGE_CODER_BOTTOM - 1); \ - } \ - ENET_RANGE_CODER_OUTPUT (encodeLow >> 24); \ - encodeRange <<= 8; \ - encodeLow <<= 8; \ - } \ -} - -#define ENET_RANGE_CODER_FLUSH \ -{ \ - while (encodeLow) \ - { \ - ENET_RANGE_CODER_OUTPUT (encodeLow >> 24); \ - encodeLow <<= 8; \ - } \ -} - -#define ENET_RANGE_CODER_FREE_SYMBOLS \ -{ \ - if (nextSymbol >= sizeof (rangeCoder -> symbols) / sizeof (ENetSymbol) - ENET_SUBCONTEXT_ORDER ) \ - { \ - nextSymbol = 0; \ - ENET_CONTEXT_CREATE (root, ENET_CONTEXT_ESCAPE_MINIMUM, ENET_CONTEXT_SYMBOL_MINIMUM); \ - predicted = 0; \ - order = 0; \ - } \ -} - -#define ENET_CONTEXT_ENCODE(context, symbol_, value_, under_, count_, update, minimum) \ -{ \ - under_ = value*minimum; \ - count_ = minimum; \ - if (! (context) -> symbols) \ - { \ - ENET_SYMBOL_CREATE (symbol_, value_, update); \ - (context) -> symbols = symbol_ - (context); \ - } \ - else \ - { \ - ENetSymbol * node = (context) + (context) -> symbols; \ - for (;;) \ - { \ - if (value_ < node -> value) \ - { \ - node -> under += update; \ - if (node -> left) { node += node -> left; continue; } \ - ENET_SYMBOL_CREATE (symbol_, value_, update); \ - node -> left = symbol_ - node; \ - } \ - else \ - if (value_ > node -> value) \ - { \ - under_ += node -> under; \ - if (node -> right) { node += node -> right; continue; } \ - ENET_SYMBOL_CREATE (symbol_, value_, update); \ - node -> right = symbol_ - node; \ - } \ - else \ - { \ - count_ += node -> count; \ - under_ += node -> under - node -> count; \ - node -> under += update; \ - node -> count += update; \ - symbol_ = node; \ - } \ - break; \ - } \ - } \ -} - -#ifdef ENET_CONTEXT_EXCLUSION -static const ENetSymbol emptyContext = { 0, 0, 0, 0, 0, 0, 0, 0, 0 }; - -#define ENET_CONTEXT_WALK(context, body) \ -{ \ - const ENetSymbol * node = (context) + (context) -> symbols; \ - const ENetSymbol * stack [256]; \ - size_t stackSize = 0; \ - while (node -> left) \ - { \ - stack [stackSize ++] = node; \ - node += node -> left; \ - } \ - for (;;) \ - { \ - body; \ - if (node -> right) \ - { \ - node += node -> right; \ - while (node -> left) \ - { \ - stack [stackSize ++] = node; \ - node += node -> left; \ - } \ - } \ - else \ - if (stackSize <= 0) \ - break; \ - else \ - node = stack [-- stackSize]; \ - } \ -} - -#define ENET_CONTEXT_ENCODE_EXCLUDE(context, value_, under, total, minimum) \ -ENET_CONTEXT_WALK(context, { \ - if (node -> value != value_) \ - { \ - enet_uint16 parentCount = rangeCoder -> symbols [node -> parent].count + minimum; \ - if (node -> value < value_) \ - under -= parentCount; \ - total -= parentCount; \ - } \ -}) -#endif - -size_t -enet_range_coder_compress (void * context, const ENetBuffer * inBuffers, size_t inBufferCount, size_t inLimit, enet_uint8 * outData, size_t outLimit) -{ - ENetRangeCoder * rangeCoder = (ENetRangeCoder *) context; - enet_uint8 * outStart = outData, * outEnd = & outData [outLimit]; - const enet_uint8 * inData, * inEnd; - enet_uint32 encodeLow = 0, encodeRange = ~0; - ENetSymbol * root; - enet_uint16 predicted = 0; - size_t order = 0, nextSymbol = 0; - - if (rangeCoder == NULL || inBufferCount <= 0 || inLimit <= 0) - return 0; - - inData = (const enet_uint8 *) inBuffers -> data; - inEnd = & inData [inBuffers -> dataLength]; - inBuffers ++; - inBufferCount --; - - ENET_CONTEXT_CREATE (root, ENET_CONTEXT_ESCAPE_MINIMUM, ENET_CONTEXT_SYMBOL_MINIMUM); - - for (;;) - { - ENetSymbol * subcontext, * symbol; -#ifdef ENET_CONTEXT_EXCLUSION - const ENetSymbol * childContext = & emptyContext; -#endif - enet_uint8 value; - enet_uint16 count, under, * parent = & predicted, total; - if (inData >= inEnd) - { - if (inBufferCount <= 0) - break; - inData = (const enet_uint8 *) inBuffers -> data; - inEnd = & inData [inBuffers -> dataLength]; - inBuffers ++; - inBufferCount --; - } - value = * inData ++; - - for (subcontext = & rangeCoder -> symbols [predicted]; - subcontext != root; -#ifdef ENET_CONTEXT_EXCLUSION - childContext = subcontext, -#endif - subcontext = & rangeCoder -> symbols [subcontext -> parent]) - { - ENET_CONTEXT_ENCODE (subcontext, symbol, value, under, count, ENET_SUBCONTEXT_SYMBOL_DELTA, 0); - * parent = symbol - rangeCoder -> symbols; - parent = & symbol -> parent; - total = subcontext -> total; -#ifdef ENET_CONTEXT_EXCLUSION - if (childContext -> total > ENET_SUBCONTEXT_SYMBOL_DELTA + ENET_SUBCONTEXT_ESCAPE_DELTA) - ENET_CONTEXT_ENCODE_EXCLUDE (childContext, value, under, total, 0); -#endif - if (count > 0) - { - ENET_RANGE_CODER_ENCODE (subcontext -> escapes + under, count, total); - } - else - { - if (subcontext -> escapes > 0 && subcontext -> escapes < total) - ENET_RANGE_CODER_ENCODE (0, subcontext -> escapes, total); - subcontext -> escapes += ENET_SUBCONTEXT_ESCAPE_DELTA; - subcontext -> total += ENET_SUBCONTEXT_ESCAPE_DELTA; - } - subcontext -> total += ENET_SUBCONTEXT_SYMBOL_DELTA; - if (count > 0xFF - 2*ENET_SUBCONTEXT_SYMBOL_DELTA || subcontext -> total > ENET_RANGE_CODER_BOTTOM - 0x100) - ENET_CONTEXT_RESCALE (subcontext, 0); - if (count > 0) goto nextInput; - } - - ENET_CONTEXT_ENCODE (root, symbol, value, under, count, ENET_CONTEXT_SYMBOL_DELTA, ENET_CONTEXT_SYMBOL_MINIMUM); - * parent = symbol - rangeCoder -> symbols; - parent = & symbol -> parent; - total = root -> total; -#ifdef ENET_CONTEXT_EXCLUSION - if (childContext -> total > ENET_SUBCONTEXT_SYMBOL_DELTA + ENET_SUBCONTEXT_ESCAPE_DELTA) - ENET_CONTEXT_ENCODE_EXCLUDE (childContext, value, under, total, ENET_CONTEXT_SYMBOL_MINIMUM); -#endif - ENET_RANGE_CODER_ENCODE (root -> escapes + under, count, total); - root -> total += ENET_CONTEXT_SYMBOL_DELTA; - if (count > 0xFF - 2*ENET_CONTEXT_SYMBOL_DELTA + ENET_CONTEXT_SYMBOL_MINIMUM || root -> total > ENET_RANGE_CODER_BOTTOM - 0x100) - ENET_CONTEXT_RESCALE (root, ENET_CONTEXT_SYMBOL_MINIMUM); - - nextInput: - if (order >= ENET_SUBCONTEXT_ORDER) - predicted = rangeCoder -> symbols [predicted].parent; - else - order ++; - ENET_RANGE_CODER_FREE_SYMBOLS; - } - - ENET_RANGE_CODER_FLUSH; - - return (size_t) (outData - outStart); -} - -#define ENET_RANGE_CODER_SEED \ -{ \ - if (inData < inEnd) decodeCode |= * inData ++ << 24; \ - if (inData < inEnd) decodeCode |= * inData ++ << 16; \ - if (inData < inEnd) decodeCode |= * inData ++ << 8; \ - if (inData < inEnd) decodeCode |= * inData ++; \ -} - -#define ENET_RANGE_CODER_READ(total) ((decodeCode - decodeLow) / (decodeRange /= (total))) - -#define ENET_RANGE_CODER_DECODE(under, count, total) \ -{ \ - decodeLow += (under) * decodeRange; \ - decodeRange *= (count); \ - for (;;) \ - { \ - if((decodeLow ^ (decodeLow + decodeRange)) >= ENET_RANGE_CODER_TOP) \ - { \ - if(decodeRange >= ENET_RANGE_CODER_BOTTOM) break; \ - decodeRange = -decodeLow & (ENET_RANGE_CODER_BOTTOM - 1); \ - } \ - decodeCode <<= 8; \ - if (inData < inEnd) \ - decodeCode |= * inData ++; \ - decodeRange <<= 8; \ - decodeLow <<= 8; \ - } \ -} - -#define ENET_CONTEXT_DECODE(context, symbol_, code, value_, under_, count_, update, minimum, createRoot, visitNode, createRight, createLeft) \ -{ \ - under_ = 0; \ - count_ = minimum; \ - if (! (context) -> symbols) \ - { \ - createRoot; \ - } \ - else \ - { \ - ENetSymbol * node = (context) + (context) -> symbols; \ - for (;;) \ - { \ - enet_uint16 after = under_ + node -> under + (node -> value + 1)*minimum, before = node -> count + minimum; \ - visitNode; \ - if (code >= after) \ - { \ - under_ += node -> under; \ - if (node -> right) { node += node -> right; continue; } \ - createRight; \ - } \ - else \ - if (code < after - before) \ - { \ - node -> under += update; \ - if (node -> left) { node += node -> left; continue; } \ - createLeft; \ - } \ - else \ - { \ - value_ = node -> value; \ - count_ += node -> count; \ - under_ = after - before; \ - node -> under += update; \ - node -> count += update; \ - symbol_ = node; \ - } \ - break; \ - } \ - } \ -} - -#define ENET_CONTEXT_TRY_DECODE(context, symbol_, code, value_, under_, count_, update, minimum, exclude) \ -ENET_CONTEXT_DECODE (context, symbol_, code, value_, under_, count_, update, minimum, return 0, exclude (node -> value, after, before), return 0, return 0) - -#define ENET_CONTEXT_ROOT_DECODE(context, symbol_, code, value_, under_, count_, update, minimum, exclude) \ -ENET_CONTEXT_DECODE (context, symbol_, code, value_, under_, count_, update, minimum, \ - { \ - value_ = code / minimum; \ - under_ = code - code%minimum; \ - ENET_SYMBOL_CREATE (symbol_, value_, update); \ - (context) -> symbols = symbol_ - (context); \ - }, \ - exclude (node -> value, after, before), \ - { \ - value_ = node->value + 1 + (code - after)/minimum; \ - under_ = code - (code - after)%minimum; \ - ENET_SYMBOL_CREATE (symbol_, value_, update); \ - node -> right = symbol_ - node; \ - }, \ - { \ - value_ = node->value - 1 - (after - before - code - 1)/minimum; \ - under_ = code - (after - before - code - 1)%minimum; \ - ENET_SYMBOL_CREATE (symbol_, value_, update); \ - node -> left = symbol_ - node; \ - }) \ - -#ifdef ENET_CONTEXT_EXCLUSION -typedef struct _ENetExclude -{ - enet_uint8 value; - enet_uint16 under; -} ENetExclude; - -#define ENET_CONTEXT_DECODE_EXCLUDE(context, total, minimum) \ -{ \ - enet_uint16 under = 0; \ - nextExclude = excludes; \ - ENET_CONTEXT_WALK (context, { \ - under += rangeCoder -> symbols [node -> parent].count + minimum; \ - nextExclude -> value = node -> value; \ - nextExclude -> under = under; \ - nextExclude ++; \ - }); \ - total -= under; \ -} - -#define ENET_CONTEXT_EXCLUDED(value_, after, before) \ -{ \ - size_t low = 0, high = nextExclude - excludes; \ - for(;;) \ - { \ - size_t mid = (low + high) >> 1; \ - const ENetExclude * exclude = & excludes [mid]; \ - if (value_ < exclude -> value) \ - { \ - if (low + 1 < high) \ - { \ - high = mid; \ - continue; \ - } \ - if (exclude > excludes) \ - after -= exclude [-1].under; \ - } \ - else \ - { \ - if (value_ > exclude -> value) \ - { \ - if (low + 1 < high) \ - { \ - low = mid; \ - continue; \ - } \ - } \ - else \ - before = 0; \ - after -= exclude -> under; \ - } \ - break; \ - } \ -} -#endif - -#define ENET_CONTEXT_NOT_EXCLUDED(value_, after, before) - -size_t -enet_range_coder_decompress (void * context, const enet_uint8 * inData, size_t inLimit, enet_uint8 * outData, size_t outLimit) -{ - ENetRangeCoder * rangeCoder = (ENetRangeCoder *) context; - enet_uint8 * outStart = outData, * outEnd = & outData [outLimit]; - const enet_uint8 * inEnd = & inData [inLimit]; - enet_uint32 decodeLow = 0, decodeCode = 0, decodeRange = ~0; - ENetSymbol * root; - enet_uint16 predicted = 0; - size_t order = 0, nextSymbol = 0; -#ifdef ENET_CONTEXT_EXCLUSION - ENetExclude excludes [256]; - ENetExclude * nextExclude = excludes; -#endif - - if (rangeCoder == NULL || inLimit <= 0) - return 0; - - ENET_CONTEXT_CREATE (root, ENET_CONTEXT_ESCAPE_MINIMUM, ENET_CONTEXT_SYMBOL_MINIMUM); - - ENET_RANGE_CODER_SEED; - - for (;;) - { - ENetSymbol * subcontext, * symbol, * patch; -#ifdef ENET_CONTEXT_EXCLUSION - const ENetSymbol * childContext = & emptyContext; -#endif - enet_uint8 value = 0; - enet_uint16 code, under, count, bottom, * parent = & predicted, total; - - for (subcontext = & rangeCoder -> symbols [predicted]; - subcontext != root; -#ifdef ENET_CONTEXT_EXCLUSION - childContext = subcontext, -#endif - subcontext = & rangeCoder -> symbols [subcontext -> parent]) - { - if (subcontext -> escapes <= 0) - continue; - total = subcontext -> total; -#ifdef ENET_CONTEXT_EXCLUSION - if (childContext -> total > 0) - ENET_CONTEXT_DECODE_EXCLUDE (childContext, total, 0); -#endif - if (subcontext -> escapes >= total) - continue; - code = ENET_RANGE_CODER_READ (total); - if (code < subcontext -> escapes) - { - ENET_RANGE_CODER_DECODE (0, subcontext -> escapes, total); - continue; - } - code -= subcontext -> escapes; -#ifdef ENET_CONTEXT_EXCLUSION - if (childContext -> total > 0) - { - ENET_CONTEXT_TRY_DECODE (subcontext, symbol, code, value, under, count, ENET_SUBCONTEXT_SYMBOL_DELTA, 0, ENET_CONTEXT_EXCLUDED); - } - else -#endif - { - ENET_CONTEXT_TRY_DECODE (subcontext, symbol, code, value, under, count, ENET_SUBCONTEXT_SYMBOL_DELTA, 0, ENET_CONTEXT_NOT_EXCLUDED); - } - bottom = symbol - rangeCoder -> symbols; - ENET_RANGE_CODER_DECODE (subcontext -> escapes + under, count, total); - subcontext -> total += ENET_SUBCONTEXT_SYMBOL_DELTA; - if (count > 0xFF - 2*ENET_SUBCONTEXT_SYMBOL_DELTA || subcontext -> total > ENET_RANGE_CODER_BOTTOM - 0x100) - ENET_CONTEXT_RESCALE (subcontext, 0); - goto patchContexts; - } - - total = root -> total; -#ifdef ENET_CONTEXT_EXCLUSION - if (childContext -> total > 0) - ENET_CONTEXT_DECODE_EXCLUDE (childContext, total, ENET_CONTEXT_SYMBOL_MINIMUM); -#endif - code = ENET_RANGE_CODER_READ (total); - if (code < root -> escapes) - { - ENET_RANGE_CODER_DECODE (0, root -> escapes, total); - break; - } - code -= root -> escapes; -#ifdef ENET_CONTEXT_EXCLUSION - if (childContext -> total > 0) - { - ENET_CONTEXT_ROOT_DECODE (root, symbol, code, value, under, count, ENET_CONTEXT_SYMBOL_DELTA, ENET_CONTEXT_SYMBOL_MINIMUM, ENET_CONTEXT_EXCLUDED); - } - else -#endif - { - ENET_CONTEXT_ROOT_DECODE (root, symbol, code, value, under, count, ENET_CONTEXT_SYMBOL_DELTA, ENET_CONTEXT_SYMBOL_MINIMUM, ENET_CONTEXT_NOT_EXCLUDED); - } - bottom = symbol - rangeCoder -> symbols; - ENET_RANGE_CODER_DECODE (root -> escapes + under, count, total); - root -> total += ENET_CONTEXT_SYMBOL_DELTA; - if (count > 0xFF - 2*ENET_CONTEXT_SYMBOL_DELTA + ENET_CONTEXT_SYMBOL_MINIMUM || root -> total > ENET_RANGE_CODER_BOTTOM - 0x100) - ENET_CONTEXT_RESCALE (root, ENET_CONTEXT_SYMBOL_MINIMUM); - - patchContexts: - for (patch = & rangeCoder -> symbols [predicted]; - patch != subcontext; - patch = & rangeCoder -> symbols [patch -> parent]) - { - ENET_CONTEXT_ENCODE (patch, symbol, value, under, count, ENET_SUBCONTEXT_SYMBOL_DELTA, 0); - * parent = symbol - rangeCoder -> symbols; - parent = & symbol -> parent; - if (count <= 0) - { - patch -> escapes += ENET_SUBCONTEXT_ESCAPE_DELTA; - patch -> total += ENET_SUBCONTEXT_ESCAPE_DELTA; - } - patch -> total += ENET_SUBCONTEXT_SYMBOL_DELTA; - if (count > 0xFF - 2*ENET_SUBCONTEXT_SYMBOL_DELTA || patch -> total > ENET_RANGE_CODER_BOTTOM - 0x100) - ENET_CONTEXT_RESCALE (patch, 0); - } - * parent = bottom; - - ENET_RANGE_CODER_OUTPUT (value); - - if (order >= ENET_SUBCONTEXT_ORDER) - predicted = rangeCoder -> symbols [predicted].parent; - else - order ++; - ENET_RANGE_CODER_FREE_SYMBOLS; - } - - return (size_t) (outData - outStart); -} - -/** @defgroup host ENet host functions - @{ -*/ - -/** Sets the packet compressor the host should use to the default range coder. - @param host host to enable the range coder for - @returns 0 on success, < 0 on failure -*/ -int -enet_host_compress_with_range_coder (ENetHost * host) -{ - ENetCompressor compressor; - memset (& compressor, 0, sizeof (compressor)); - compressor.context = enet_range_coder_create(); - if (compressor.context == NULL) - return -1; - compressor.compress = enet_range_coder_compress; - compressor.decompress = enet_range_coder_decompress; - compressor.destroy = enet_range_coder_destroy; - enet_host_compress (host, & compressor); - return 0; -} - -/** @} */ - - diff --git a/btgui/enet/host.c b/btgui/enet/host.c deleted file mode 100644 index d0ee595cf..000000000 --- a/btgui/enet/host.c +++ /dev/null @@ -1,491 +0,0 @@ -/** - @file host.c - @brief ENet host management functions -*/ -#define ENET_BUILDING_LIB 1 -#include -#include -#include "enet/enet.h" - -/** @defgroup host ENet host functions - @{ -*/ - -/** Creates a host for communicating to peers. - - @param address the address at which other peers may connect to this host. If NULL, then no peers may connect to the host. - @param peerCount the maximum number of peers that should be allocated for the host. - @param channelLimit the maximum number of channels allowed; if 0, then this is equivalent to ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT - @param incomingBandwidth downstream bandwidth of the host in bytes/second; if 0, ENet will assume unlimited bandwidth. - @param outgoingBandwidth upstream bandwidth of the host in bytes/second; if 0, ENet will assume unlimited bandwidth. - - @returns the host on success and NULL on failure - - @remarks ENet will strategically drop packets on specific sides of a connection between hosts - to ensure the host's bandwidth is not overwhelmed. The bandwidth parameters also determine - the window size of a connection which limits the amount of reliable packets that may be in transit - at any given time. -*/ -ENetHost * -enet_host_create (const ENetAddress * address, size_t peerCount, size_t channelLimit, enet_uint32 incomingBandwidth, enet_uint32 outgoingBandwidth) -{ - ENetHost * host; - ENetPeer * currentPeer; - - if (peerCount > ENET_PROTOCOL_MAXIMUM_PEER_ID) - return NULL; - - host = (ENetHost *) enet_malloc (sizeof (ENetHost)); - if (host == NULL) - return NULL; - memset (host, 0, sizeof (ENetHost)); - - host -> peers = (ENetPeer *) enet_malloc (peerCount * sizeof (ENetPeer)); - if (host -> peers == NULL) - { - enet_free (host); - - return NULL; - } - memset (host -> peers, 0, peerCount * sizeof (ENetPeer)); - - host -> socket = enet_socket_create (ENET_SOCKET_TYPE_DATAGRAM); - if (host -> socket == ENET_SOCKET_NULL || (address != NULL && enet_socket_bind (host -> socket, address) < 0)) - { - if (host -> socket != ENET_SOCKET_NULL) - enet_socket_destroy (host -> socket); - - enet_free (host -> peers); - enet_free (host); - - return NULL; - } - - enet_socket_set_option (host -> socket, ENET_SOCKOPT_NONBLOCK, 1); - enet_socket_set_option (host -> socket, ENET_SOCKOPT_BROADCAST, 1); - enet_socket_set_option (host -> socket, ENET_SOCKOPT_RCVBUF, ENET_HOST_RECEIVE_BUFFER_SIZE); - enet_socket_set_option (host -> socket, ENET_SOCKOPT_SNDBUF, ENET_HOST_SEND_BUFFER_SIZE); - - if (address != NULL) - host -> address = * address; - - if (! channelLimit || channelLimit > ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT) - channelLimit = ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT; - else - if (channelLimit < ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT) - channelLimit = ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT; - - host -> randomSeed = (enet_uint32) (size_t) host; -#ifdef WIN32 - host -> randomSeed += (enet_uint32) timeGetTime(); -#else - host -> randomSeed += (enet_uint32) time(NULL); -#endif - host -> randomSeed = (host -> randomSeed << 16) | (host -> randomSeed >> 16); - host -> channelLimit = channelLimit; - host -> incomingBandwidth = incomingBandwidth; - host -> outgoingBandwidth = outgoingBandwidth; - host -> bandwidthThrottleEpoch = 0; - host -> recalculateBandwidthLimits = 0; - host -> mtu = ENET_HOST_DEFAULT_MTU; - host -> peerCount = peerCount; - host -> commandCount = 0; - host -> bufferCount = 0; - host -> checksum = NULL; - host -> receivedAddress.host = ENET_HOST_ANY; - host -> receivedAddress.port = 0; - host -> receivedData = NULL; - host -> receivedDataLength = 0; - - host -> totalSentData = 0; - host -> totalSentPackets = 0; - host -> totalReceivedData = 0; - host -> totalReceivedPackets = 0; - - host -> compressor.context = NULL; - host -> compressor.compress = NULL; - host -> compressor.decompress = NULL; - host -> compressor.destroy = NULL; - - host -> intercept = NULL; - - enet_list_clear (& host -> dispatchQueue); - - for (currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - currentPeer -> host = host; - currentPeer -> incomingPeerID = currentPeer - host -> peers; - currentPeer -> outgoingSessionID = currentPeer -> incomingSessionID = 0xFF; - currentPeer -> data = NULL; - - enet_list_clear (& currentPeer -> acknowledgements); - enet_list_clear (& currentPeer -> sentReliableCommands); - enet_list_clear (& currentPeer -> sentUnreliableCommands); - enet_list_clear (& currentPeer -> outgoingReliableCommands); - enet_list_clear (& currentPeer -> outgoingUnreliableCommands); - enet_list_clear (& currentPeer -> dispatchedCommands); - - enet_peer_reset (currentPeer); - } - - return host; -} - -/** Destroys the host and all resources associated with it. - @param host pointer to the host to destroy -*/ -void -enet_host_destroy (ENetHost * host) -{ - ENetPeer * currentPeer; - - if (host == NULL) - return; - - enet_socket_destroy (host -> socket); - - for (currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - enet_peer_reset (currentPeer); - } - - if (host -> compressor.context != NULL && host -> compressor.destroy) - (* host -> compressor.destroy) (host -> compressor.context); - - enet_free (host -> peers); - enet_free (host); -} - -/** Initiates a connection to a foreign host. - @param host host seeking the connection - @param address destination for the connection - @param channelCount number of channels to allocate - @param data user data supplied to the receiving host - @returns a peer representing the foreign host on success, NULL on failure - @remarks The peer returned will have not completed the connection until enet_host_service() - notifies of an ENET_EVENT_TYPE_CONNECT event for the peer. -*/ -ENetPeer * -enet_host_connect (ENetHost * host, const ENetAddress * address, size_t channelCount, enet_uint32 data) -{ - ENetPeer * currentPeer; - ENetChannel * channel; - ENetProtocol command; - - if (channelCount < ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT) - channelCount = ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT; - else - if (channelCount > ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT) - channelCount = ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT; - - for (currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - if (currentPeer -> state == ENET_PEER_STATE_DISCONNECTED) - break; - } - - if (currentPeer >= & host -> peers [host -> peerCount]) - return NULL; - - currentPeer -> channels = (ENetChannel *) enet_malloc (channelCount * sizeof (ENetChannel)); - if (currentPeer -> channels == NULL) - return NULL; - currentPeer -> channelCount = channelCount; - currentPeer -> state = ENET_PEER_STATE_CONNECTING; - currentPeer -> address = * address; - currentPeer -> connectID = ++ host -> randomSeed; - - if (host -> outgoingBandwidth == 0) - currentPeer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - else - currentPeer -> windowSize = (host -> outgoingBandwidth / - ENET_PEER_WINDOW_SIZE_SCALE) * - ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - - if (currentPeer -> windowSize < ENET_PROTOCOL_MINIMUM_WINDOW_SIZE) - currentPeer -> windowSize = ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - else - if (currentPeer -> windowSize > ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE) - currentPeer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - - for (channel = currentPeer -> channels; - channel < & currentPeer -> channels [channelCount]; - ++ channel) - { - channel -> outgoingReliableSequenceNumber = 0; - channel -> outgoingUnreliableSequenceNumber = 0; - channel -> incomingReliableSequenceNumber = 0; - channel -> incomingUnreliableSequenceNumber = 0; - - enet_list_clear (& channel -> incomingReliableCommands); - enet_list_clear (& channel -> incomingUnreliableCommands); - - channel -> usedReliableWindows = 0; - memset (channel -> reliableWindows, 0, sizeof (channel -> reliableWindows)); - } - - command.header.command = ENET_PROTOCOL_COMMAND_CONNECT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - command.header.channelID = 0xFF; - command.connect.outgoingPeerID = ENET_HOST_TO_NET_16 (currentPeer -> incomingPeerID); - command.connect.incomingSessionID = currentPeer -> incomingSessionID; - command.connect.outgoingSessionID = currentPeer -> outgoingSessionID; - command.connect.mtu = ENET_HOST_TO_NET_32 (currentPeer -> mtu); - command.connect.windowSize = ENET_HOST_TO_NET_32 (currentPeer -> windowSize); - command.connect.channelCount = ENET_HOST_TO_NET_32 (channelCount); - command.connect.incomingBandwidth = ENET_HOST_TO_NET_32 (host -> incomingBandwidth); - command.connect.outgoingBandwidth = ENET_HOST_TO_NET_32 (host -> outgoingBandwidth); - command.connect.packetThrottleInterval = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleInterval); - command.connect.packetThrottleAcceleration = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleAcceleration); - command.connect.packetThrottleDeceleration = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleDeceleration); - command.connect.connectID = currentPeer -> connectID; - command.connect.data = ENET_HOST_TO_NET_32 (data); - - enet_peer_queue_outgoing_command (currentPeer, & command, NULL, 0, 0); - - return currentPeer; -} - -/** Queues a packet to be sent to all peers associated with the host. - @param host host on which to broadcast the packet - @param channelID channel on which to broadcast - @param packet packet to broadcast -*/ -void -enet_host_broadcast (ENetHost * host, enet_uint8 channelID, ENetPacket * packet) -{ - ENetPeer * currentPeer; - - for (currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - if (currentPeer -> state != ENET_PEER_STATE_CONNECTED) - continue; - - enet_peer_send (currentPeer, channelID, packet); - } - - if (packet -> referenceCount == 0) - enet_packet_destroy (packet); -} - -/** Sets the packet compressor the host should use to compress and decompress packets. - @param host host to enable or disable compression for - @param compressor callbacks for for the packet compressor; if NULL, then compression is disabled -*/ -void -enet_host_compress (ENetHost * host, const ENetCompressor * compressor) -{ - if (host -> compressor.context != NULL && host -> compressor.destroy) - (* host -> compressor.destroy) (host -> compressor.context); - - if (compressor) - host -> compressor = * compressor; - else - host -> compressor.context = NULL; -} - -/** Limits the maximum allowed channels of future incoming connections. - @param host host to limit - @param channelLimit the maximum number of channels allowed; if 0, then this is equivalent to ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT -*/ -void -enet_host_channel_limit (ENetHost * host, size_t channelLimit) -{ - if (! channelLimit || channelLimit > ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT) - channelLimit = ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT; - else - if (channelLimit < ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT) - channelLimit = ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT; - - host -> channelLimit = channelLimit; -} - - -/** Adjusts the bandwidth limits of a host. - @param host host to adjust - @param incomingBandwidth new incoming bandwidth - @param outgoingBandwidth new outgoing bandwidth - @remarks the incoming and outgoing bandwidth parameters are identical in function to those - specified in enet_host_create(). -*/ -void -enet_host_bandwidth_limit (ENetHost * host, enet_uint32 incomingBandwidth, enet_uint32 outgoingBandwidth) -{ - host -> incomingBandwidth = incomingBandwidth; - host -> outgoingBandwidth = outgoingBandwidth; - host -> recalculateBandwidthLimits = 1; -} - -void -enet_host_bandwidth_throttle (ENetHost * host) -{ - enet_uint32 timeCurrent = enet_time_get (), - elapsedTime = timeCurrent - host -> bandwidthThrottleEpoch, - peersTotal = 0, - dataTotal = 0, - peersRemaining, - bandwidth, - throttle = 0, - bandwidthLimit = 0; - int needsAdjustment; - ENetPeer * peer; - ENetProtocol command; - - if (elapsedTime < ENET_HOST_BANDWIDTH_THROTTLE_INTERVAL) - return; - - for (peer = host -> peers; - peer < & host -> peers [host -> peerCount]; - ++ peer) - { - if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) - continue; - - ++ peersTotal; - dataTotal += peer -> outgoingDataTotal; - } - - if (peersTotal == 0) - return; - - peersRemaining = peersTotal; - needsAdjustment = 1; - - if (host -> outgoingBandwidth == 0) - bandwidth = ~0; - else - bandwidth = (host -> outgoingBandwidth * elapsedTime) / 1000; - - while (peersRemaining > 0 && needsAdjustment != 0) - { - needsAdjustment = 0; - - if (dataTotal < bandwidth) - throttle = ENET_PEER_PACKET_THROTTLE_SCALE; - else - throttle = (bandwidth * ENET_PEER_PACKET_THROTTLE_SCALE) / dataTotal; - - for (peer = host -> peers; - peer < & host -> peers [host -> peerCount]; - ++ peer) - { - enet_uint32 peerBandwidth; - - if ((peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) || - peer -> incomingBandwidth == 0 || - peer -> outgoingBandwidthThrottleEpoch == timeCurrent) - continue; - - peerBandwidth = (peer -> incomingBandwidth * elapsedTime) / 1000; - if ((throttle * peer -> outgoingDataTotal) / ENET_PEER_PACKET_THROTTLE_SCALE <= peerBandwidth) - continue; - - peer -> packetThrottleLimit = (peerBandwidth * - ENET_PEER_PACKET_THROTTLE_SCALE) / peer -> outgoingDataTotal; - - if (peer -> packetThrottleLimit == 0) - peer -> packetThrottleLimit = 1; - - if (peer -> packetThrottle > peer -> packetThrottleLimit) - peer -> packetThrottle = peer -> packetThrottleLimit; - - peer -> outgoingBandwidthThrottleEpoch = timeCurrent; - - - needsAdjustment = 1; - -- peersRemaining; - bandwidth -= peerBandwidth; - dataTotal -= peerBandwidth; - } - } - - if (peersRemaining > 0) - for (peer = host -> peers; - peer < & host -> peers [host -> peerCount]; - ++ peer) - { - if ((peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) || - peer -> outgoingBandwidthThrottleEpoch == timeCurrent) - continue; - - peer -> packetThrottleLimit = throttle; - - if (peer -> packetThrottle > peer -> packetThrottleLimit) - peer -> packetThrottle = peer -> packetThrottleLimit; - } - - if (host -> recalculateBandwidthLimits) - { - host -> recalculateBandwidthLimits = 0; - - peersRemaining = peersTotal; - bandwidth = host -> incomingBandwidth; - needsAdjustment = 1; - - if (bandwidth == 0) - bandwidthLimit = 0; - else - while (peersRemaining > 0 && needsAdjustment != 0) - { - needsAdjustment = 0; - bandwidthLimit = bandwidth / peersRemaining; - - for (peer = host -> peers; - peer < & host -> peers [host -> peerCount]; - ++ peer) - { - if ((peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) || - peer -> incomingBandwidthThrottleEpoch == timeCurrent) - continue; - - if (peer -> outgoingBandwidth > 0 && - peer -> outgoingBandwidth >= bandwidthLimit) - continue; - - peer -> incomingBandwidthThrottleEpoch = timeCurrent; - - needsAdjustment = 1; - -- peersRemaining; - bandwidth -= peer -> outgoingBandwidth; - } - } - - for (peer = host -> peers; - peer < & host -> peers [host -> peerCount]; - ++ peer) - { - if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) - continue; - - command.header.command = ENET_PROTOCOL_COMMAND_BANDWIDTH_LIMIT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - command.header.channelID = 0xFF; - command.bandwidthLimit.outgoingBandwidth = ENET_HOST_TO_NET_32 (host -> outgoingBandwidth); - - if (peer -> incomingBandwidthThrottleEpoch == timeCurrent) - command.bandwidthLimit.incomingBandwidth = ENET_HOST_TO_NET_32 (peer -> outgoingBandwidth); - else - command.bandwidthLimit.incomingBandwidth = ENET_HOST_TO_NET_32 (bandwidthLimit); - - enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0); - } - } - - host -> bandwidthThrottleEpoch = timeCurrent; - - for (peer = host -> peers; - peer < & host -> peers [host -> peerCount]; - ++ peer) - { - peer -> incomingDataTotal = 0; - peer -> outgoingDataTotal = 0; - } -} - -/** @} */ diff --git a/btgui/enet/include/enet/callbacks.h b/btgui/enet/include/enet/callbacks.h deleted file mode 100644 index 340a4a989..000000000 --- a/btgui/enet/include/enet/callbacks.h +++ /dev/null @@ -1,27 +0,0 @@ -/** - @file callbacks.h - @brief ENet callbacks -*/ -#ifndef __ENET_CALLBACKS_H__ -#define __ENET_CALLBACKS_H__ - -#include - -typedef struct _ENetCallbacks -{ - void * (ENET_CALLBACK * malloc) (size_t size); - void (ENET_CALLBACK * free) (void * memory); - void (ENET_CALLBACK * no_memory) (void); -} ENetCallbacks; - -/** @defgroup callbacks ENet internal callbacks - @{ - @ingroup private -*/ -extern void * enet_malloc (size_t); -extern void enet_free (void *); - -/** @} */ - -#endif /* __ENET_CALLBACKS_H__ */ - diff --git a/btgui/enet/include/enet/enet.h b/btgui/enet/include/enet/enet.h deleted file mode 100644 index 5f9d5403c..000000000 --- a/btgui/enet/include/enet/enet.h +++ /dev/null @@ -1,571 +0,0 @@ -/** - @file enet.h - @brief ENet public header file -*/ -#ifndef __ENET_ENET_H__ -#define __ENET_ENET_H__ - -#ifdef __cplusplus -extern "C" -{ -#endif - -#include - -#ifdef WIN32 -#include "enet/win32.h" -#else -#include "enet/unix.h" -#endif - -#include "enet/types.h" -#include "enet/protocol.h" -#include "enet/list.h" -#include "enet/callbacks.h" - -#define ENET_VERSION_MAJOR 1 -#define ENET_VERSION_MINOR 3 -#define ENET_VERSION_PATCH 7 -#define ENET_VERSION_CREATE(major, minor, patch) (((major)<<16) | ((minor)<<8) | (patch)) -#define ENET_VERSION ENET_VERSION_CREATE(ENET_VERSION_MAJOR, ENET_VERSION_MINOR, ENET_VERSION_PATCH) - -typedef enet_uint32 ENetVersion; - -struct _ENetHost; -struct _ENetEvent; -struct _ENetPacket; - -typedef enum _ENetSocketType -{ - ENET_SOCKET_TYPE_STREAM = 1, - ENET_SOCKET_TYPE_DATAGRAM = 2 -} ENetSocketType; - -typedef enum _ENetSocketWait -{ - ENET_SOCKET_WAIT_NONE = 0, - ENET_SOCKET_WAIT_SEND = (1 << 0), - ENET_SOCKET_WAIT_RECEIVE = (1 << 1) -} ENetSocketWait; - -typedef enum _ENetSocketOption -{ - ENET_SOCKOPT_NONBLOCK = 1, - ENET_SOCKOPT_BROADCAST = 2, - ENET_SOCKOPT_RCVBUF = 3, - ENET_SOCKOPT_SNDBUF = 4, - ENET_SOCKOPT_REUSEADDR = 5, - ENET_SOCKOPT_RCVTIMEO = 6, - ENET_SOCKOPT_SNDTIMEO = 7 -} ENetSocketOption; - -typedef enum _ENetSocketShutdown -{ - ENET_SOCKET_SHUTDOWN_READ = 0, - ENET_SOCKET_SHUTDOWN_WRITE = 1, - ENET_SOCKET_SHUTDOWN_READ_WRITE = 2 -} ENetSocketShutdown; - -enum -{ - ENET_HOST_ANY = 0, /**< specifies the default server host */ - ENET_HOST_BROADCAST = 0xFFFFFFFF, /**< specifies a subnet-wide broadcast */ - - ENET_PORT_ANY = 0 /**< specifies that a port should be automatically chosen */ -}; - -/** - * Portable internet address structure. - * - * The host must be specified in network byte-order, and the port must be in host - * byte-order. The constant ENET_HOST_ANY may be used to specify the default - * server host. The constant ENET_HOST_BROADCAST may be used to specify the - * broadcast address (255.255.255.255). This makes sense for enet_host_connect, - * but not for enet_host_create. Once a server responds to a broadcast, the - * address is updated from ENET_HOST_BROADCAST to the server's actual IP address. - */ -typedef struct _ENetAddress -{ - enet_uint32 host; - enet_uint16 port; -} ENetAddress; - -/** - * Packet flag bit constants. - * - * The host must be specified in network byte-order, and the port must be in - * host byte-order. The constant ENET_HOST_ANY may be used to specify the - * default server host. - - @sa ENetPacket -*/ -typedef enum _ENetPacketFlag -{ - /** packet must be received by the target peer and resend attempts should be - * made until the packet is delivered */ - ENET_PACKET_FLAG_RELIABLE = (1 << 0), - /** packet will not be sequenced with other packets - * not supported for reliable packets - */ - ENET_PACKET_FLAG_UNSEQUENCED = (1 << 1), - /** packet will not allocate data, and user must supply it instead */ - ENET_PACKET_FLAG_NO_ALLOCATE = (1 << 2), - /** packet will be fragmented using unreliable (instead of reliable) sends - * if it exceeds the MTU */ - ENET_PACKET_FLAG_UNRELIABLE_FRAGMENT = (1 << 3), - - /** whether the packet has been sent from all queues it has been entered into */ - ENET_PACKET_FLAG_SENT = (1<<8) -} ENetPacketFlag; - -typedef void (ENET_CALLBACK * ENetPacketFreeCallback) (struct _ENetPacket *); - -/** - * ENet packet structure. - * - * An ENet data packet that may be sent to or received from a peer. The shown - * fields should only be read and never modified. The data field contains the - * allocated data for the packet. The dataLength fields specifies the length - * of the allocated data. The flags field is either 0 (specifying no flags), - * or a bitwise-or of any combination of the following flags: - * - * ENET_PACKET_FLAG_RELIABLE - packet must be received by the target peer - * and resend attempts should be made until the packet is delivered - * - * ENET_PACKET_FLAG_UNSEQUENCED - packet will not be sequenced with other packets - * (not supported for reliable packets) - * - * ENET_PACKET_FLAG_NO_ALLOCATE - packet will not allocate data, and user must supply it instead - - @sa ENetPacketFlag - */ -typedef struct _ENetPacket -{ - size_t referenceCount; /**< internal use only */ - enet_uint32 flags; /**< bitwise-or of ENetPacketFlag constants */ - enet_uint8 * data; /**< allocated data for packet */ - size_t dataLength; /**< length of data */ - ENetPacketFreeCallback freeCallback; /**< function to be called when the packet is no longer in use */ - void * userData; /**< application private data, may be freely modified */ -} ENetPacket; - -typedef struct _ENetAcknowledgement -{ - ENetListNode acknowledgementList; - enet_uint32 sentTime; - ENetProtocol command; -} ENetAcknowledgement; - -typedef struct _ENetOutgoingCommand -{ - ENetListNode outgoingCommandList; - enet_uint16 reliableSequenceNumber; - enet_uint16 unreliableSequenceNumber; - enet_uint32 sentTime; - enet_uint32 roundTripTimeout; - enet_uint32 roundTripTimeoutLimit; - enet_uint32 fragmentOffset; - enet_uint16 fragmentLength; - enet_uint16 sendAttempts; - ENetProtocol command; - ENetPacket * packet; -} ENetOutgoingCommand; - -typedef struct _ENetIncomingCommand -{ - ENetListNode incomingCommandList; - enet_uint16 reliableSequenceNumber; - enet_uint16 unreliableSequenceNumber; - ENetProtocol command; - enet_uint32 fragmentCount; - enet_uint32 fragmentsRemaining; - enet_uint32 * fragments; - ENetPacket * packet; -} ENetIncomingCommand; - -typedef enum _ENetPeerState -{ - ENET_PEER_STATE_DISCONNECTED = 0, - ENET_PEER_STATE_CONNECTING = 1, - ENET_PEER_STATE_ACKNOWLEDGING_CONNECT = 2, - ENET_PEER_STATE_CONNECTION_PENDING = 3, - ENET_PEER_STATE_CONNECTION_SUCCEEDED = 4, - ENET_PEER_STATE_CONNECTED = 5, - ENET_PEER_STATE_DISCONNECT_LATER = 6, - ENET_PEER_STATE_DISCONNECTING = 7, - ENET_PEER_STATE_ACKNOWLEDGING_DISCONNECT = 8, - ENET_PEER_STATE_ZOMBIE = 9 -} ENetPeerState; - -#ifndef ENET_BUFFER_MAXIMUM -#define ENET_BUFFER_MAXIMUM (1 + 2 * ENET_PROTOCOL_MAXIMUM_PACKET_COMMANDS) -#endif - -enum -{ - ENET_HOST_RECEIVE_BUFFER_SIZE = 256 * 1024, - ENET_HOST_SEND_BUFFER_SIZE = 256 * 1024, - ENET_HOST_BANDWIDTH_THROTTLE_INTERVAL = 1000, - ENET_HOST_DEFAULT_MTU = 1400, - - ENET_PEER_DEFAULT_ROUND_TRIP_TIME = 500, - ENET_PEER_DEFAULT_PACKET_THROTTLE = 32, - ENET_PEER_PACKET_THROTTLE_SCALE = 32, - ENET_PEER_PACKET_THROTTLE_COUNTER = 7, - ENET_PEER_PACKET_THROTTLE_ACCELERATION = 2, - ENET_PEER_PACKET_THROTTLE_DECELERATION = 2, - ENET_PEER_PACKET_THROTTLE_INTERVAL = 5000, - ENET_PEER_PACKET_LOSS_SCALE = (1 << 16), - ENET_PEER_PACKET_LOSS_INTERVAL = 10000, - ENET_PEER_WINDOW_SIZE_SCALE = 64 * 1024, - ENET_PEER_TIMEOUT_LIMIT = 32, - ENET_PEER_TIMEOUT_MINIMUM = 5000, - ENET_PEER_TIMEOUT_MAXIMUM = 30000, - ENET_PEER_PING_INTERVAL = 500, - ENET_PEER_UNSEQUENCED_WINDOWS = 64, - ENET_PEER_UNSEQUENCED_WINDOW_SIZE = 1024, - ENET_PEER_FREE_UNSEQUENCED_WINDOWS = 32, - ENET_PEER_RELIABLE_WINDOWS = 16, - ENET_PEER_RELIABLE_WINDOW_SIZE = 0x1000, - ENET_PEER_FREE_RELIABLE_WINDOWS = 8 -}; - -typedef struct _ENetChannel -{ - enet_uint16 outgoingReliableSequenceNumber; - enet_uint16 outgoingUnreliableSequenceNumber; - enet_uint16 usedReliableWindows; - enet_uint16 reliableWindows [ENET_PEER_RELIABLE_WINDOWS]; - enet_uint16 incomingReliableSequenceNumber; - enet_uint16 incomingUnreliableSequenceNumber; - ENetList incomingReliableCommands; - ENetList incomingUnreliableCommands; -} ENetChannel; - -/** - * An ENet peer which data packets may be sent or received from. - * - * No fields should be modified unless otherwise specified. - */ -typedef struct _ENetPeer -{ - ENetListNode dispatchList; - struct _ENetHost * host; - enet_uint16 outgoingPeerID; - enet_uint16 incomingPeerID; - enet_uint32 connectID; - enet_uint8 outgoingSessionID; - enet_uint8 incomingSessionID; - ENetAddress address; /**< Internet address of the peer */ - void * data; /**< Application private data, may be freely modified */ - ENetPeerState state; - ENetChannel * channels; - size_t channelCount; /**< Number of channels allocated for communication with peer */ - enet_uint32 incomingBandwidth; /**< Downstream bandwidth of the client in bytes/second */ - enet_uint32 outgoingBandwidth; /**< Upstream bandwidth of the client in bytes/second */ - enet_uint32 incomingBandwidthThrottleEpoch; - enet_uint32 outgoingBandwidthThrottleEpoch; - enet_uint32 incomingDataTotal; - enet_uint32 outgoingDataTotal; - enet_uint32 lastSendTime; - enet_uint32 lastReceiveTime; - enet_uint32 nextTimeout; - enet_uint32 earliestTimeout; - enet_uint32 packetLossEpoch; - enet_uint32 packetsSent; - enet_uint32 packetsLost; - enet_uint32 packetLoss; /**< mean packet loss of reliable packets as a ratio with respect to the constant ENET_PEER_PACKET_LOSS_SCALE */ - enet_uint32 packetLossVariance; - enet_uint32 packetThrottle; - enet_uint32 packetThrottleLimit; - enet_uint32 packetThrottleCounter; - enet_uint32 packetThrottleEpoch; - enet_uint32 packetThrottleAcceleration; - enet_uint32 packetThrottleDeceleration; - enet_uint32 packetThrottleInterval; - enet_uint32 pingInterval; - enet_uint32 timeoutLimit; - enet_uint32 timeoutMinimum; - enet_uint32 timeoutMaximum; - enet_uint32 lastRoundTripTime; - enet_uint32 lowestRoundTripTime; - enet_uint32 lastRoundTripTimeVariance; - enet_uint32 highestRoundTripTimeVariance; - enet_uint32 roundTripTime; /**< mean round trip time (RTT), in milliseconds, between sending a reliable packet and receiving its acknowledgement */ - enet_uint32 roundTripTimeVariance; - enet_uint32 mtu; - enet_uint32 windowSize; - enet_uint32 reliableDataInTransit; - enet_uint16 outgoingReliableSequenceNumber; - ENetList acknowledgements; - ENetList sentReliableCommands; - ENetList sentUnreliableCommands; - ENetList outgoingReliableCommands; - ENetList outgoingUnreliableCommands; - ENetList dispatchedCommands; - int needsDispatch; - enet_uint16 incomingUnsequencedGroup; - enet_uint16 outgoingUnsequencedGroup; - enet_uint32 unsequencedWindow [ENET_PEER_UNSEQUENCED_WINDOW_SIZE / 32]; - enet_uint32 eventData; -} ENetPeer; - -/** An ENet packet compressor for compressing UDP packets before socket sends or receives. - */ -typedef struct _ENetCompressor -{ - /** Context data for the compressor. Must be non-NULL. */ - void * context; - /** Compresses from inBuffers[0:inBufferCount-1], containing inLimit bytes, to outData, outputting at most outLimit bytes. Should return 0 on failure. */ - size_t (ENET_CALLBACK * compress) (void * context, const ENetBuffer * inBuffers, size_t inBufferCount, size_t inLimit, enet_uint8 * outData, size_t outLimit); - /** Decompresses from inData, containing inLimit bytes, to outData, outputting at most outLimit bytes. Should return 0 on failure. */ - size_t (ENET_CALLBACK * decompress) (void * context, const enet_uint8 * inData, size_t inLimit, enet_uint8 * outData, size_t outLimit); - /** Destroys the context when compression is disabled or the host is destroyed. May be NULL. */ - void (ENET_CALLBACK * destroy) (void * context); -} ENetCompressor; - -/** Callback that computes the checksum of the data held in buffers[0:bufferCount-1] */ -typedef enet_uint32 (ENET_CALLBACK * ENetChecksumCallback) (const ENetBuffer * buffers, size_t bufferCount); - -/** Callback for intercepting received raw UDP packets. Should return 1 to intercept, 0 to ignore, or -1 to propagate an error. */ -typedef int (ENET_CALLBACK * ENetInterceptCallback) (struct _ENetHost * host, struct _ENetEvent * event); - -/** An ENet host for communicating with peers. - * - * No fields should be modified unless otherwise stated. - - @sa enet_host_create() - @sa enet_host_destroy() - @sa enet_host_connect() - @sa enet_host_service() - @sa enet_host_flush() - @sa enet_host_broadcast() - @sa enet_host_compress() - @sa enet_host_compress_with_range_coder() - @sa enet_host_channel_limit() - @sa enet_host_bandwidth_limit() - @sa enet_host_bandwidth_throttle() - */ -typedef struct _ENetHost -{ - ENetSocket socket; - ENetAddress address; /**< Internet address of the host */ - enet_uint32 incomingBandwidth; /**< downstream bandwidth of the host */ - enet_uint32 outgoingBandwidth; /**< upstream bandwidth of the host */ - enet_uint32 bandwidthThrottleEpoch; - enet_uint32 mtu; - enet_uint32 randomSeed; - int recalculateBandwidthLimits; - ENetPeer * peers; /**< array of peers allocated for this host */ - size_t peerCount; /**< number of peers allocated for this host */ - size_t channelLimit; /**< maximum number of channels allowed for connected peers */ - enet_uint32 serviceTime; - ENetList dispatchQueue; - int continueSending; - size_t packetSize; - enet_uint16 headerFlags; - ENetProtocol commands [ENET_PROTOCOL_MAXIMUM_PACKET_COMMANDS]; - size_t commandCount; - ENetBuffer buffers [ENET_BUFFER_MAXIMUM]; - size_t bufferCount; - ENetChecksumCallback checksum; /**< callback the user can set to enable packet checksums for this host */ - ENetCompressor compressor; - enet_uint8 packetData [2][ENET_PROTOCOL_MAXIMUM_MTU]; - ENetAddress receivedAddress; - enet_uint8 * receivedData; - size_t receivedDataLength; - enet_uint32 totalSentData; /**< total data sent, user should reset to 0 as needed to prevent overflow */ - enet_uint32 totalSentPackets; /**< total UDP packets sent, user should reset to 0 as needed to prevent overflow */ - enet_uint32 totalReceivedData; /**< total data received, user should reset to 0 as needed to prevent overflow */ - enet_uint32 totalReceivedPackets; /**< total UDP packets received, user should reset to 0 as needed to prevent overflow */ - ENetInterceptCallback intercept; /**< callback the user can set to intercept received raw UDP packets */ -} ENetHost; - -/** - * An ENet event type, as specified in @ref ENetEvent. - */ -typedef enum _ENetEventType -{ - /** no event occurred within the specified time limit */ - ENET_EVENT_TYPE_NONE = 0, - - /** a connection request initiated by enet_host_connect has completed. - * The peer field contains the peer which successfully connected. - */ - ENET_EVENT_TYPE_CONNECT = 1, - - /** a peer has disconnected. This event is generated on a successful - * completion of a disconnect initiated by enet_pper_disconnect, if - * a peer has timed out, or if a connection request intialized by - * enet_host_connect has timed out. The peer field contains the peer - * which disconnected. The data field contains user supplied data - * describing the disconnection, or 0, if none is available. - */ - ENET_EVENT_TYPE_DISCONNECT = 2, - - /** a packet has been received from a peer. The peer field specifies the - * peer which sent the packet. The channelID field specifies the channel - * number upon which the packet was received. The packet field contains - * the packet that was received; this packet must be destroyed with - * enet_packet_destroy after use. - */ - ENET_EVENT_TYPE_RECEIVE = 3 -} ENetEventType; - -/** - * An ENet event as returned by enet_host_service(). - - @sa enet_host_service - */ -typedef struct _ENetEvent -{ - ENetEventType type; /**< type of the event */ - ENetPeer * peer; /**< peer that generated a connect, disconnect or receive event */ - enet_uint8 channelID; /**< channel on the peer that generated the event, if appropriate */ - enet_uint32 data; /**< data associated with the event, if appropriate */ - ENetPacket * packet; /**< packet associated with the event, if appropriate */ -} ENetEvent; - -/** @defgroup global ENet global functions - @{ -*/ - -/** - Initializes ENet globally. Must be called prior to using any functions in - ENet. - @returns 0 on success, < 0 on failure -*/ -ENET_API int enet_initialize (void); - -/** - Initializes ENet globally and supplies user-overridden callbacks. Must be called prior to using any functions in ENet. Do not use enet_initialize() if you use this variant. Make sure the ENetCallbacks structure is zeroed out so that any additional callbacks added in future versions will be properly ignored. - - @param version the constant ENET_VERSION should be supplied so ENet knows which version of ENetCallbacks struct to use - @param inits user-overriden callbacks where any NULL callbacks will use ENet's defaults - @returns 0 on success, < 0 on failure -*/ -ENET_API int enet_initialize_with_callbacks (ENetVersion version, const ENetCallbacks * inits); - -/** - Shuts down ENet globally. Should be called when a program that has - initialized ENet exits. -*/ -ENET_API void enet_deinitialize (void); - -/** @} */ - -/** @defgroup private ENet private implementation functions */ - -/** - Returns the wall-time in milliseconds. Its initial value is unspecified - unless otherwise set. - */ -ENET_API enet_uint32 enet_time_get (void); -/** - Sets the current wall-time in milliseconds. - */ -ENET_API void enet_time_set (enet_uint32); - -/** @defgroup socket ENet socket functions - @{ -*/ -ENET_API ENetSocket enet_socket_create (ENetSocketType); -ENET_API int enet_socket_bind (ENetSocket, const ENetAddress *); -ENET_API int enet_socket_listen (ENetSocket, int); -ENET_API ENetSocket enet_socket_accept (ENetSocket, ENetAddress *); -ENET_API int enet_socket_connect (ENetSocket, const ENetAddress *); -ENET_API int enet_socket_send (ENetSocket, const ENetAddress *, const ENetBuffer *, size_t); -ENET_API int enet_socket_receive (ENetSocket, ENetAddress *, ENetBuffer *, size_t); -ENET_API int enet_socket_wait (ENetSocket, enet_uint32 *, enet_uint32); -ENET_API int enet_socket_set_option (ENetSocket, ENetSocketOption, int); -ENET_API int enet_socket_shutdown (ENetSocket, ENetSocketShutdown); -ENET_API void enet_socket_destroy (ENetSocket); -ENET_API int enet_socketset_select (ENetSocket, ENetSocketSet *, ENetSocketSet *, enet_uint32); - -/** @} */ - -/** @defgroup Address ENet address functions - @{ -*/ -/** Attempts to resolve the host named by the parameter hostName and sets - the host field in the address parameter if successful. - @param address destination to store resolved address - @param hostName host name to lookup - @retval 0 on success - @retval < 0 on failure - @returns the address of the given hostName in address on success -*/ -ENET_API int enet_address_set_host (ENetAddress * address, const char * hostName); - -/** Gives the printable form of the ip address specified in the address parameter. - @param address address printed - @param hostName destination for name, must not be NULL - @param nameLength maximum length of hostName. - @returns the null-terminated name of the host in hostName on success - @retval 0 on success - @retval < 0 on failure -*/ -ENET_API int enet_address_get_host_ip (const ENetAddress * address, char * hostName, size_t nameLength); - -/** Attempts to do a reverse lookup of the host field in the address parameter. - @param address address used for reverse lookup - @param hostName destination for name, must not be NULL - @param nameLength maximum length of hostName. - @returns the null-terminated name of the host in hostName on success - @retval 0 on success - @retval < 0 on failure -*/ -ENET_API int enet_address_get_host (const ENetAddress * address, char * hostName, size_t nameLength); - -/** @} */ - -ENET_API ENetPacket * enet_packet_create (const void *, size_t, enet_uint32); -ENET_API void enet_packet_destroy (ENetPacket *); -ENET_API int enet_packet_resize (ENetPacket *, size_t); -ENET_API enet_uint32 enet_crc32 (const ENetBuffer *, size_t); - -ENET_API ENetHost * enet_host_create (const ENetAddress *, size_t, size_t, enet_uint32, enet_uint32); -ENET_API void enet_host_destroy (ENetHost *); -ENET_API ENetPeer * enet_host_connect (ENetHost *, const ENetAddress *, size_t, enet_uint32); -ENET_API int enet_host_check_events (ENetHost *, ENetEvent *); -ENET_API int enet_host_service (ENetHost *, ENetEvent *, enet_uint32); -ENET_API void enet_host_flush (ENetHost *); -ENET_API void enet_host_broadcast (ENetHost *, enet_uint8, ENetPacket *); -ENET_API void enet_host_compress (ENetHost *, const ENetCompressor *); -ENET_API int enet_host_compress_with_range_coder (ENetHost * host); -ENET_API void enet_host_channel_limit (ENetHost *, size_t); -ENET_API void enet_host_bandwidth_limit (ENetHost *, enet_uint32, enet_uint32); -extern void enet_host_bandwidth_throttle (ENetHost *); - -ENET_API int enet_peer_send (ENetPeer *, enet_uint8, ENetPacket *); -ENET_API ENetPacket * enet_peer_receive (ENetPeer *, enet_uint8 * channelID); -ENET_API void enet_peer_ping (ENetPeer *); -ENET_API void enet_peer_ping_interval (ENetPeer *, enet_uint32); -ENET_API void enet_peer_timeout (ENetPeer *, enet_uint32, enet_uint32, enet_uint32); -ENET_API void enet_peer_reset (ENetPeer *); -ENET_API void enet_peer_disconnect (ENetPeer *, enet_uint32); -ENET_API void enet_peer_disconnect_now (ENetPeer *, enet_uint32); -ENET_API void enet_peer_disconnect_later (ENetPeer *, enet_uint32); -ENET_API void enet_peer_throttle_configure (ENetPeer *, enet_uint32, enet_uint32, enet_uint32); -extern int enet_peer_throttle (ENetPeer *, enet_uint32); -extern void enet_peer_reset_queues (ENetPeer *); -extern void enet_peer_setup_outgoing_command (ENetPeer *, ENetOutgoingCommand *); -extern ENetOutgoingCommand * enet_peer_queue_outgoing_command (ENetPeer *, const ENetProtocol *, ENetPacket *, enet_uint32, enet_uint16); -extern ENetIncomingCommand * enet_peer_queue_incoming_command (ENetPeer *, const ENetProtocol *, ENetPacket *, enet_uint32); -extern ENetAcknowledgement * enet_peer_queue_acknowledgement (ENetPeer *, const ENetProtocol *, enet_uint16); -extern void enet_peer_dispatch_incoming_unreliable_commands (ENetPeer *, ENetChannel *); -extern void enet_peer_dispatch_incoming_reliable_commands (ENetPeer *, ENetChannel *); - -ENET_API void * enet_range_coder_create (void); -ENET_API void enet_range_coder_destroy (void *); -ENET_API size_t enet_range_coder_compress (void *, const ENetBuffer *, size_t, size_t, enet_uint8 *, size_t); -ENET_API size_t enet_range_coder_decompress (void *, const enet_uint8 *, size_t, enet_uint8 *, size_t); - -extern size_t enet_protocol_command_size (enet_uint8); - -#ifdef __cplusplus -} -#endif - -#endif /* __ENET_ENET_H__ */ - diff --git a/btgui/enet/include/enet/list.h b/btgui/enet/include/enet/list.h deleted file mode 100644 index d7b260084..000000000 --- a/btgui/enet/include/enet/list.h +++ /dev/null @@ -1,43 +0,0 @@ -/** - @file list.h - @brief ENet list management -*/ -#ifndef __ENET_LIST_H__ -#define __ENET_LIST_H__ - -#include - -typedef struct _ENetListNode -{ - struct _ENetListNode * next; - struct _ENetListNode * previous; -} ENetListNode; - -typedef ENetListNode * ENetListIterator; - -typedef struct _ENetList -{ - ENetListNode sentinel; -} ENetList; - -extern void enet_list_clear (ENetList *); - -extern ENetListIterator enet_list_insert (ENetListIterator, void *); -extern void * enet_list_remove (ENetListIterator); -extern ENetListIterator enet_list_move (ENetListIterator, void *, void *); - -extern size_t enet_list_size (ENetList *); - -#define enet_list_begin(list) ((list) -> sentinel.next) -#define enet_list_end(list) (& (list) -> sentinel) - -#define enet_list_empty(list) (enet_list_begin (list) == enet_list_end (list)) - -#define enet_list_next(iterator) ((iterator) -> next) -#define enet_list_previous(iterator) ((iterator) -> previous) - -#define enet_list_front(list) ((void *) (list) -> sentinel.next) -#define enet_list_back(list) ((void *) (list) -> sentinel.previous) - -#endif /* __ENET_LIST_H__ */ - diff --git a/btgui/enet/include/enet/protocol.h b/btgui/enet/include/enet/protocol.h deleted file mode 100644 index f8a27d8e1..000000000 --- a/btgui/enet/include/enet/protocol.h +++ /dev/null @@ -1,199 +0,0 @@ -/** - @file protocol.h - @brief ENet protocol -*/ -#ifndef __ENET_PROTOCOL_H__ -#define __ENET_PROTOCOL_H__ - -#include "enet/types.h" - -enum -{ - ENET_PROTOCOL_MINIMUM_MTU = 576, - ENET_PROTOCOL_MAXIMUM_MTU = 4096, - ENET_PROTOCOL_MAXIMUM_PACKET_COMMANDS = 32, - ENET_PROTOCOL_MINIMUM_WINDOW_SIZE = 4096, - ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE = 32768, - ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT = 1, - ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT = 255, - ENET_PROTOCOL_MAXIMUM_PEER_ID = 0xFFF, - ENET_PROTOCOL_MAXIMUM_PACKET_SIZE = 1024 * 1024 * 1024, - ENET_PROTOCOL_MAXIMUM_FRAGMENT_COUNT = 1024 * 1024 -}; - -typedef enum _ENetProtocolCommand -{ - ENET_PROTOCOL_COMMAND_NONE = 0, - ENET_PROTOCOL_COMMAND_ACKNOWLEDGE = 1, - ENET_PROTOCOL_COMMAND_CONNECT = 2, - ENET_PROTOCOL_COMMAND_VERIFY_CONNECT = 3, - ENET_PROTOCOL_COMMAND_DISCONNECT = 4, - ENET_PROTOCOL_COMMAND_PING = 5, - ENET_PROTOCOL_COMMAND_SEND_RELIABLE = 6, - ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE = 7, - ENET_PROTOCOL_COMMAND_SEND_FRAGMENT = 8, - ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED = 9, - ENET_PROTOCOL_COMMAND_BANDWIDTH_LIMIT = 10, - ENET_PROTOCOL_COMMAND_THROTTLE_CONFIGURE = 11, - ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE_FRAGMENT = 12, - ENET_PROTOCOL_COMMAND_COUNT = 13, - - ENET_PROTOCOL_COMMAND_MASK = 0x0F -} ENetProtocolCommand; - -typedef enum _ENetProtocolFlag -{ - ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE = (1 << 7), - ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED = (1 << 6), - - ENET_PROTOCOL_HEADER_FLAG_COMPRESSED = (1 << 14), - ENET_PROTOCOL_HEADER_FLAG_SENT_TIME = (1 << 15), - ENET_PROTOCOL_HEADER_FLAG_MASK = ENET_PROTOCOL_HEADER_FLAG_COMPRESSED | ENET_PROTOCOL_HEADER_FLAG_SENT_TIME, - - ENET_PROTOCOL_HEADER_SESSION_MASK = (3 << 12), - ENET_PROTOCOL_HEADER_SESSION_SHIFT = 12 -} ENetProtocolFlag; - -#ifdef _MSC_VER_ -#pragma pack(push, 1) -#define ENET_PACKED -#elif defined(__GNUC__) -#define ENET_PACKED __attribute__ ((packed)) -#else -#define ENET_PACKED -#endif - -typedef struct _ENetProtocolHeader -{ - enet_uint16 peerID; - enet_uint16 sentTime; -} ENET_PACKED ENetProtocolHeader; - -typedef struct _ENetProtocolCommandHeader -{ - enet_uint8 command; - enet_uint8 channelID; - enet_uint16 reliableSequenceNumber; -} ENET_PACKED ENetProtocolCommandHeader; - -typedef struct _ENetProtocolAcknowledge -{ - ENetProtocolCommandHeader header; - enet_uint16 receivedReliableSequenceNumber; - enet_uint16 receivedSentTime; -} ENET_PACKED ENetProtocolAcknowledge; - -typedef struct _ENetProtocolConnect -{ - ENetProtocolCommandHeader header; - enet_uint16 outgoingPeerID; - enet_uint8 incomingSessionID; - enet_uint8 outgoingSessionID; - enet_uint32 mtu; - enet_uint32 windowSize; - enet_uint32 channelCount; - enet_uint32 incomingBandwidth; - enet_uint32 outgoingBandwidth; - enet_uint32 packetThrottleInterval; - enet_uint32 packetThrottleAcceleration; - enet_uint32 packetThrottleDeceleration; - enet_uint32 connectID; - enet_uint32 data; -} ENET_PACKED ENetProtocolConnect; - -typedef struct _ENetProtocolVerifyConnect -{ - ENetProtocolCommandHeader header; - enet_uint16 outgoingPeerID; - enet_uint8 incomingSessionID; - enet_uint8 outgoingSessionID; - enet_uint32 mtu; - enet_uint32 windowSize; - enet_uint32 channelCount; - enet_uint32 incomingBandwidth; - enet_uint32 outgoingBandwidth; - enet_uint32 packetThrottleInterval; - enet_uint32 packetThrottleAcceleration; - enet_uint32 packetThrottleDeceleration; - enet_uint32 connectID; -} ENET_PACKED ENetProtocolVerifyConnect; - -typedef struct _ENetProtocolBandwidthLimit -{ - ENetProtocolCommandHeader header; - enet_uint32 incomingBandwidth; - enet_uint32 outgoingBandwidth; -} ENET_PACKED ENetProtocolBandwidthLimit; - -typedef struct _ENetProtocolThrottleConfigure -{ - ENetProtocolCommandHeader header; - enet_uint32 packetThrottleInterval; - enet_uint32 packetThrottleAcceleration; - enet_uint32 packetThrottleDeceleration; -} ENET_PACKED ENetProtocolThrottleConfigure; - -typedef struct _ENetProtocolDisconnect -{ - ENetProtocolCommandHeader header; - enet_uint32 data; -} ENET_PACKED ENetProtocolDisconnect; - -typedef struct _ENetProtocolPing -{ - ENetProtocolCommandHeader header; -} ENET_PACKED ENetProtocolPing; - -typedef struct _ENetProtocolSendReliable -{ - ENetProtocolCommandHeader header; - enet_uint16 dataLength; -} ENET_PACKED ENetProtocolSendReliable; - -typedef struct _ENetProtocolSendUnreliable -{ - ENetProtocolCommandHeader header; - enet_uint16 unreliableSequenceNumber; - enet_uint16 dataLength; -} ENET_PACKED ENetProtocolSendUnreliable; - -typedef struct _ENetProtocolSendUnsequenced -{ - ENetProtocolCommandHeader header; - enet_uint16 unsequencedGroup; - enet_uint16 dataLength; -} ENET_PACKED ENetProtocolSendUnsequenced; - -typedef struct _ENetProtocolSendFragment -{ - ENetProtocolCommandHeader header; - enet_uint16 startSequenceNumber; - enet_uint16 dataLength; - enet_uint32 fragmentCount; - enet_uint32 fragmentNumber; - enet_uint32 totalLength; - enet_uint32 fragmentOffset; -} ENET_PACKED ENetProtocolSendFragment; - -typedef union _ENetProtocol -{ - ENetProtocolCommandHeader header; - ENetProtocolAcknowledge acknowledge; - ENetProtocolConnect connect; - ENetProtocolVerifyConnect verifyConnect; - ENetProtocolDisconnect disconnect; - ENetProtocolPing ping; - ENetProtocolSendReliable sendReliable; - ENetProtocolSendUnreliable sendUnreliable; - ENetProtocolSendUnsequenced sendUnsequenced; - ENetProtocolSendFragment sendFragment; - ENetProtocolBandwidthLimit bandwidthLimit; - ENetProtocolThrottleConfigure throttleConfigure; -} ENET_PACKED ENetProtocol; - -#ifdef _MSC_VER_ -#pragma pack(pop) -#endif - -#endif /* __ENET_PROTOCOL_H__ */ - diff --git a/btgui/enet/include/enet/time.h b/btgui/enet/include/enet/time.h deleted file mode 100644 index c82a54603..000000000 --- a/btgui/enet/include/enet/time.h +++ /dev/null @@ -1,18 +0,0 @@ -/** - @file time.h - @brief ENet time constants and macros -*/ -#ifndef __ENET_TIME_H__ -#define __ENET_TIME_H__ - -#define ENET_TIME_OVERFLOW 86400000 - -#define ENET_TIME_LESS(a, b) ((a) - (b) >= ENET_TIME_OVERFLOW) -#define ENET_TIME_GREATER(a, b) ((b) - (a) >= ENET_TIME_OVERFLOW) -#define ENET_TIME_LESS_EQUAL(a, b) (! ENET_TIME_GREATER (a, b)) -#define ENET_TIME_GREATER_EQUAL(a, b) (! ENET_TIME_LESS (a, b)) - -#define ENET_TIME_DIFFERENCE(a, b) ((a) - (b) >= ENET_TIME_OVERFLOW ? (b) - (a) : (a) - (b)) - -#endif /* __ENET_TIME_H__ */ - diff --git a/btgui/enet/include/enet/types.h b/btgui/enet/include/enet/types.h deleted file mode 100644 index ab010a4b1..000000000 --- a/btgui/enet/include/enet/types.h +++ /dev/null @@ -1,13 +0,0 @@ -/** - @file types.h - @brief type definitions for ENet -*/ -#ifndef __ENET_TYPES_H__ -#define __ENET_TYPES_H__ - -typedef unsigned char enet_uint8; /**< unsigned 8-bit type */ -typedef unsigned short enet_uint16; /**< unsigned 16-bit type */ -typedef unsigned int enet_uint32; /**< unsigned 32-bit type */ - -#endif /* __ENET_TYPES_H__ */ - diff --git a/btgui/enet/include/enet/unix.h b/btgui/enet/include/enet/unix.h deleted file mode 100644 index 087015e51..000000000 --- a/btgui/enet/include/enet/unix.h +++ /dev/null @@ -1,45 +0,0 @@ -/** - @file unix.h - @brief ENet Unix header -*/ -#ifndef __ENET_UNIX_H__ -#define __ENET_UNIX_H__ - -#include -#include -#include -#include -#include - -typedef int ENetSocket; - -enum -{ - ENET_SOCKET_NULL = -1 -}; - -#define ENET_HOST_TO_NET_16(value) (htons (value)) /**< macro that converts host to net byte-order of a 16-bit value */ -#define ENET_HOST_TO_NET_32(value) (htonl (value)) /**< macro that converts host to net byte-order of a 32-bit value */ - -#define ENET_NET_TO_HOST_16(value) (ntohs (value)) /**< macro that converts net to host byte-order of a 16-bit value */ -#define ENET_NET_TO_HOST_32(value) (ntohl (value)) /**< macro that converts net to host byte-order of a 32-bit value */ - -typedef struct -{ - void * data; - size_t dataLength; -} ENetBuffer; - -#define ENET_CALLBACK - -#define ENET_API extern - -typedef fd_set ENetSocketSet; - -#define ENET_SOCKETSET_EMPTY(sockset) FD_ZERO (& (sockset)) -#define ENET_SOCKETSET_ADD(sockset, socket) FD_SET (socket, & (sockset)) -#define ENET_SOCKETSET_REMOVE(sockset, socket) FD_CLEAR (socket, & (sockset)) -#define ENET_SOCKETSET_CHECK(sockset, socket) FD_ISSET (socket, & (sockset)) - -#endif /* __ENET_UNIX_H__ */ - diff --git a/btgui/enet/include/enet/utility.h b/btgui/enet/include/enet/utility.h deleted file mode 100644 index e48a476be..000000000 --- a/btgui/enet/include/enet/utility.h +++ /dev/null @@ -1,12 +0,0 @@ -/** - @file utility.h - @brief ENet utility header -*/ -#ifndef __ENET_UTILITY_H__ -#define __ENET_UTILITY_H__ - -#define ENET_MAX(x, y) ((x) > (y) ? (x) : (y)) -#define ENET_MIN(x, y) ((x) < (y) ? (x) : (y)) - -#endif /* __ENET_UTILITY_H__ */ - diff --git a/btgui/enet/include/enet/win32.h b/btgui/enet/include/enet/win32.h deleted file mode 100644 index 0e1cf0c5a..000000000 --- a/btgui/enet/include/enet/win32.h +++ /dev/null @@ -1,58 +0,0 @@ -/** - @file win32.h - @brief ENet Win32 header -*/ -#ifndef __ENET_WIN32_H__ -#define __ENET_WIN32_H__ - -#ifdef ENET_BUILDING_LIB -#pragma warning (disable: 4996) // 'strncpy' was declared deprecated -#pragma warning (disable: 4267) // size_t to int conversion -#pragma warning (disable: 4244) // 64bit to 32bit int -#pragma warning (disable: 4018) // signed/unsigned mismatch -#endif - -#include -#include - -typedef SOCKET ENetSocket; - -enum -{ - ENET_SOCKET_NULL = INVALID_SOCKET -}; - -#define ENET_HOST_TO_NET_16(value) (htons (value)) -#define ENET_HOST_TO_NET_32(value) (htonl (value)) - -#define ENET_NET_TO_HOST_16(value) (ntohs (value)) -#define ENET_NET_TO_HOST_32(value) (ntohl (value)) - -typedef struct -{ - size_t dataLength; - void * data; -} ENetBuffer; - -#define ENET_CALLBACK __cdecl - -#if defined ENET_DLL -#if defined ENET_BUILDING_LIB -#define ENET_API __declspec( dllexport ) -#else -#define ENET_API __declspec( dllimport ) -#endif /* ENET_BUILDING_LIB */ -#else /* !ENET_DLL */ -#define ENET_API extern -#endif /* ENET_DLL */ - -typedef fd_set ENetSocketSet; - -#define ENET_SOCKETSET_EMPTY(sockset) FD_ZERO (& (sockset)) -#define ENET_SOCKETSET_ADD(sockset, socket) FD_SET (socket, & (sockset)) -#define ENET_SOCKETSET_REMOVE(sockset, socket) FD_CLEAR (socket, & (sockset)) -#define ENET_SOCKETSET_CHECK(sockset, socket) FD_ISSET (socket, & (sockset)) - -#endif /* __ENET_WIN32_H__ */ - - diff --git a/btgui/enet/list.c b/btgui/enet/list.c deleted file mode 100644 index 1c1a8dfaa..000000000 --- a/btgui/enet/list.c +++ /dev/null @@ -1,75 +0,0 @@ -/** - @file list.c - @brief ENet linked list functions -*/ -#define ENET_BUILDING_LIB 1 -#include "enet/enet.h" - -/** - @defgroup list ENet linked list utility functions - @ingroup private - @{ -*/ -void -enet_list_clear (ENetList * list) -{ - list -> sentinel.next = & list -> sentinel; - list -> sentinel.previous = & list -> sentinel; -} - -ENetListIterator -enet_list_insert (ENetListIterator position, void * data) -{ - ENetListIterator result = (ENetListIterator) data; - - result -> previous = position -> previous; - result -> next = position; - - result -> previous -> next = result; - position -> previous = result; - - return result; -} - -void * -enet_list_remove (ENetListIterator position) -{ - position -> previous -> next = position -> next; - position -> next -> previous = position -> previous; - - return position; -} - -ENetListIterator -enet_list_move (ENetListIterator position, void * dataFirst, void * dataLast) -{ - ENetListIterator first = (ENetListIterator) dataFirst, - last = (ENetListIterator) dataLast; - - first -> previous -> next = last -> next; - last -> next -> previous = first -> previous; - - first -> previous = position -> previous; - last -> next = position; - - first -> previous -> next = first; - position -> previous = last; - - return first; -} - -size_t -enet_list_size (ENetList * list) -{ - size_t size = 0; - ENetListIterator position; - - for (position = enet_list_begin (list); - position != enet_list_end (list); - position = enet_list_next (position)) - ++ size; - - return size; -} - -/** @} */ diff --git a/btgui/enet/packet.c b/btgui/enet/packet.c deleted file mode 100644 index 9a997be4e..000000000 --- a/btgui/enet/packet.c +++ /dev/null @@ -1,165 +0,0 @@ -/** - @file packet.c - @brief ENet packet management functions -*/ -#include -#define ENET_BUILDING_LIB 1 -#include "enet/enet.h" - -/** @defgroup Packet ENet packet functions - @{ -*/ - -/** Creates a packet that may be sent to a peer. - @param dataContents initial contents of the packet's data; the packet's data will remain uninitialized if dataContents is NULL. - @param dataLength size of the data allocated for this packet - @param flags flags for this packet as described for the ENetPacket structure. - @returns the packet on success, NULL on failure -*/ -ENetPacket * -enet_packet_create (const void * data, size_t dataLength, enet_uint32 flags) -{ - ENetPacket * packet = (ENetPacket *) enet_malloc (sizeof (ENetPacket)); - if (packet == NULL) - return NULL; - - if (flags & ENET_PACKET_FLAG_NO_ALLOCATE) - packet -> data = (enet_uint8 *) data; - else - if (dataLength <= 0) - packet -> data = NULL; - else - { - packet -> data = (enet_uint8 *) enet_malloc (dataLength); - if (packet -> data == NULL) - { - enet_free (packet); - return NULL; - } - - if (data != NULL) - memcpy (packet -> data, data, dataLength); - } - - packet -> referenceCount = 0; - packet -> flags = flags; - packet -> dataLength = dataLength; - packet -> freeCallback = NULL; - packet -> userData = NULL; - - return packet; -} - -/** Destroys the packet and deallocates its data. - @param packet packet to be destroyed -*/ -void -enet_packet_destroy (ENetPacket * packet) -{ - if (packet == NULL) - return; - - if (packet -> freeCallback != NULL) - (* packet -> freeCallback) (packet); - if (! (packet -> flags & ENET_PACKET_FLAG_NO_ALLOCATE) && - packet -> data != NULL) - enet_free (packet -> data); - enet_free (packet); -} - -/** Attempts to resize the data in the packet to length specified in the - dataLength parameter - @param packet packet to resize - @param dataLength new size for the packet data - @returns 0 on success, < 0 on failure -*/ -int -enet_packet_resize (ENetPacket * packet, size_t dataLength) -{ - enet_uint8 * newData; - - if (dataLength <= packet -> dataLength || (packet -> flags & ENET_PACKET_FLAG_NO_ALLOCATE)) - { - packet -> dataLength = dataLength; - - return 0; - } - - newData = (enet_uint8 *) enet_malloc (dataLength); - if (newData == NULL) - return -1; - - memcpy (newData, packet -> data, packet -> dataLength); - enet_free (packet -> data); - - packet -> data = newData; - packet -> dataLength = dataLength; - - return 0; -} - -static int initializedCRC32 = 0; -static enet_uint32 crcTable [256]; - -static enet_uint32 -reflect_crc (int val, int bits) -{ - int result = 0, bit; - - for (bit = 0; bit < bits; bit ++) - { - if(val & 1) result |= 1 << (bits - 1 - bit); - val >>= 1; - } - - return result; -} - -static void -initialize_crc32 (void) -{ - int byte; - - for (byte = 0; byte < 256; ++ byte) - { - enet_uint32 crc = reflect_crc (byte, 8) << 24; - int offset; - - for(offset = 0; offset < 8; ++ offset) - { - if (crc & 0x80000000) - crc = (crc << 1) ^ 0x04c11db7; - else - crc <<= 1; - } - - crcTable [byte] = reflect_crc (crc, 32); - } - - initializedCRC32 = 1; -} - -enet_uint32 -enet_crc32 (const ENetBuffer * buffers, size_t bufferCount) -{ - enet_uint32 crc = 0xFFFFFFFF; - - if (! initializedCRC32) initialize_crc32 (); - - while (bufferCount -- > 0) - { - const enet_uint8 * data = (const enet_uint8 *) buffers -> data, - * dataEnd = & data [buffers -> dataLength]; - - while (data < dataEnd) - { - crc = (crc >> 8) ^ crcTable [(crc & 0xFF) ^ *data++]; - } - - ++ buffers; - } - - return ENET_HOST_TO_NET_32 (~ crc); -} - -/** @} */ diff --git a/btgui/enet/peer.c b/btgui/enet/peer.c deleted file mode 100644 index a86d793d8..000000000 --- a/btgui/enet/peer.c +++ /dev/null @@ -1,959 +0,0 @@ -/** - @file peer.c - @brief ENet peer management functions -*/ -#include -#define ENET_BUILDING_LIB 1 -#include "enet/enet.h" - -/** @defgroup peer ENet peer functions - @{ -*/ - -/** Configures throttle parameter for a peer. - - Unreliable packets are dropped by ENet in response to the varying conditions - of the Internet connection to the peer. The throttle represents a probability - that an unreliable packet should not be dropped and thus sent by ENet to the peer. - The lowest mean round trip time from the sending of a reliable packet to the - receipt of its acknowledgement is measured over an amount of time specified by - the interval parameter in milliseconds. If a measured round trip time happens to - be significantly less than the mean round trip time measured over the interval, - then the throttle probability is increased to allow more traffic by an amount - specified in the acceleration parameter, which is a ratio to the ENET_PEER_PACKET_THROTTLE_SCALE - constant. If a measured round trip time happens to be significantly greater than - the mean round trip time measured over the interval, then the throttle probability - is decreased to limit traffic by an amount specified in the deceleration parameter, which - is a ratio to the ENET_PEER_PACKET_THROTTLE_SCALE constant. When the throttle has - a value of ENET_PEER_PACKET_THROTTLE_SCALE, no unreliable packets are dropped by - ENet, and so 100% of all unreliable packets will be sent. When the throttle has a - value of 0, all unreliable packets are dropped by ENet, and so 0% of all unreliable - packets will be sent. Intermediate values for the throttle represent intermediate - probabilities between 0% and 100% of unreliable packets being sent. The bandwidth - limits of the local and foreign hosts are taken into account to determine a - sensible limit for the throttle probability above which it should not raise even in - the best of conditions. - - @param peer peer to configure - @param interval interval, in milliseconds, over which to measure lowest mean RTT; the default value is ENET_PEER_PACKET_THROTTLE_INTERVAL. - @param acceleration rate at which to increase the throttle probability as mean RTT declines - @param deceleration rate at which to decrease the throttle probability as mean RTT increases -*/ -void -enet_peer_throttle_configure (ENetPeer * peer, enet_uint32 interval, enet_uint32 acceleration, enet_uint32 deceleration) -{ - ENetProtocol command; - - peer -> packetThrottleInterval = interval; - peer -> packetThrottleAcceleration = acceleration; - peer -> packetThrottleDeceleration = deceleration; - - command.header.command = ENET_PROTOCOL_COMMAND_THROTTLE_CONFIGURE | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - command.header.channelID = 0xFF; - - command.throttleConfigure.packetThrottleInterval = ENET_HOST_TO_NET_32 (interval); - command.throttleConfigure.packetThrottleAcceleration = ENET_HOST_TO_NET_32 (acceleration); - command.throttleConfigure.packetThrottleDeceleration = ENET_HOST_TO_NET_32 (deceleration); - - enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0); -} - -int -enet_peer_throttle (ENetPeer * peer, enet_uint32 rtt) -{ - if (peer -> lastRoundTripTime <= peer -> lastRoundTripTimeVariance) - { - peer -> packetThrottle = peer -> packetThrottleLimit; - } - else - if (rtt < peer -> lastRoundTripTime) - { - peer -> packetThrottle += peer -> packetThrottleAcceleration; - - if (peer -> packetThrottle > peer -> packetThrottleLimit) - peer -> packetThrottle = peer -> packetThrottleLimit; - - return 1; - } - else - if (rtt > peer -> lastRoundTripTime + 2 * peer -> lastRoundTripTimeVariance) - { - if (peer -> packetThrottle > peer -> packetThrottleDeceleration) - peer -> packetThrottle -= peer -> packetThrottleDeceleration; - else - peer -> packetThrottle = 0; - - return -1; - } - - return 0; -} - -/** Queues a packet to be sent. - @param peer destination for the packet - @param channelID channel on which to send - @param packet packet to send - @retval 0 on success - @retval < 0 on failure -*/ -int -enet_peer_send (ENetPeer * peer, enet_uint8 channelID, ENetPacket * packet) -{ - ENetChannel * channel = & peer -> channels [channelID]; - ENetProtocol command; - size_t fragmentLength; - - if (peer -> state != ENET_PEER_STATE_CONNECTED || - channelID >= peer -> channelCount || - packet -> dataLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE) - return -1; - - fragmentLength = peer -> mtu - sizeof (ENetProtocolHeader) - sizeof (ENetProtocolSendFragment); - if (peer -> host -> checksum != NULL) - fragmentLength -= sizeof(enet_uint32); - - if (packet -> dataLength > fragmentLength) - { - enet_uint32 fragmentCount = (packet -> dataLength + fragmentLength - 1) / fragmentLength, - fragmentNumber, - fragmentOffset; - enet_uint8 commandNumber; - enet_uint16 startSequenceNumber; - ENetList fragments; - ENetOutgoingCommand * fragment; - - if (fragmentCount > ENET_PROTOCOL_MAXIMUM_FRAGMENT_COUNT) - return -1; - - if ((packet -> flags & (ENET_PACKET_FLAG_RELIABLE | ENET_PACKET_FLAG_UNRELIABLE_FRAGMENT)) == ENET_PACKET_FLAG_UNRELIABLE_FRAGMENT && - channel -> outgoingUnreliableSequenceNumber < 0xFFFF) - { - commandNumber = ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE_FRAGMENT; - startSequenceNumber = ENET_HOST_TO_NET_16 (channel -> outgoingUnreliableSequenceNumber + 1); - } - else - { - commandNumber = ENET_PROTOCOL_COMMAND_SEND_FRAGMENT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - startSequenceNumber = ENET_HOST_TO_NET_16 (channel -> outgoingReliableSequenceNumber + 1); - } - - enet_list_clear (& fragments); - - for (fragmentNumber = 0, - fragmentOffset = 0; - fragmentOffset < packet -> dataLength; - ++ fragmentNumber, - fragmentOffset += fragmentLength) - { - if (packet -> dataLength - fragmentOffset < fragmentLength) - fragmentLength = packet -> dataLength - fragmentOffset; - - fragment = (ENetOutgoingCommand *) enet_malloc (sizeof (ENetOutgoingCommand)); - if (fragment == NULL) - { - while (! enet_list_empty (& fragments)) - { - fragment = (ENetOutgoingCommand *) enet_list_remove (enet_list_begin (& fragments)); - - enet_free (fragment); - } - - return -1; - } - - fragment -> fragmentOffset = fragmentOffset; - fragment -> fragmentLength = fragmentLength; - fragment -> packet = packet; - fragment -> command.header.command = commandNumber; - fragment -> command.header.channelID = channelID; - fragment -> command.sendFragment.startSequenceNumber = startSequenceNumber; - fragment -> command.sendFragment.dataLength = ENET_HOST_TO_NET_16 (fragmentLength); - fragment -> command.sendFragment.fragmentCount = ENET_HOST_TO_NET_32 (fragmentCount); - fragment -> command.sendFragment.fragmentNumber = ENET_HOST_TO_NET_32 (fragmentNumber); - fragment -> command.sendFragment.totalLength = ENET_HOST_TO_NET_32 (packet -> dataLength); - fragment -> command.sendFragment.fragmentOffset = ENET_NET_TO_HOST_32 (fragmentOffset); - - enet_list_insert (enet_list_end (& fragments), fragment); - } - - packet -> referenceCount += fragmentNumber; - - while (! enet_list_empty (& fragments)) - { - fragment = (ENetOutgoingCommand *) enet_list_remove (enet_list_begin (& fragments)); - - enet_peer_setup_outgoing_command (peer, fragment); - } - - return 0; - } - - command.header.channelID = channelID; - - if ((packet -> flags & (ENET_PACKET_FLAG_RELIABLE | ENET_PACKET_FLAG_UNSEQUENCED)) == ENET_PACKET_FLAG_UNSEQUENCED) - { - command.header.command = ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED | ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED; - command.sendUnsequenced.dataLength = ENET_HOST_TO_NET_16 (packet -> dataLength); - } - else - if (packet -> flags & ENET_PACKET_FLAG_RELIABLE || channel -> outgoingUnreliableSequenceNumber >= 0xFFFF) - { - command.header.command = ENET_PROTOCOL_COMMAND_SEND_RELIABLE | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - command.sendReliable.dataLength = ENET_HOST_TO_NET_16 (packet -> dataLength); - } - else - { - command.header.command = ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE; - command.sendUnreliable.dataLength = ENET_HOST_TO_NET_16 (packet -> dataLength); - } - - if (enet_peer_queue_outgoing_command (peer, & command, packet, 0, packet -> dataLength) == NULL) - return -1; - - return 0; -} - -/** Attempts to dequeue any incoming queued packet. - @param peer peer to dequeue packets from - @param channelID holds the channel ID of the channel the packet was received on success - @returns a pointer to the packet, or NULL if there are no available incoming queued packets -*/ -ENetPacket * -enet_peer_receive (ENetPeer * peer, enet_uint8 * channelID) -{ - ENetIncomingCommand * incomingCommand; - ENetPacket * packet; - - if (enet_list_empty (& peer -> dispatchedCommands)) - return NULL; - - incomingCommand = (ENetIncomingCommand *) enet_list_remove (enet_list_begin (& peer -> dispatchedCommands)); - - if (channelID != NULL) - * channelID = incomingCommand -> command.header.channelID; - - packet = incomingCommand -> packet; - - -- packet -> referenceCount; - - if (incomingCommand -> fragments != NULL) - enet_free (incomingCommand -> fragments); - - enet_free (incomingCommand); - - return packet; -} - -static void -enet_peer_reset_outgoing_commands (ENetList * queue) -{ - ENetOutgoingCommand * outgoingCommand; - - while (! enet_list_empty (queue)) - { - outgoingCommand = (ENetOutgoingCommand *) enet_list_remove (enet_list_begin (queue)); - - if (outgoingCommand -> packet != NULL) - { - -- outgoingCommand -> packet -> referenceCount; - - if (outgoingCommand -> packet -> referenceCount == 0) - enet_packet_destroy (outgoingCommand -> packet); - } - - enet_free (outgoingCommand); - } -} - -static void -enet_peer_remove_incoming_commands (ENetList * queue, ENetListIterator startCommand, ENetListIterator endCommand) -{ - ENetListIterator currentCommand; - - for (currentCommand = startCommand; currentCommand != endCommand; ) - { - ENetIncomingCommand * incomingCommand = (ENetIncomingCommand *) currentCommand; - - currentCommand = enet_list_next (currentCommand); - - enet_list_remove (& incomingCommand -> incomingCommandList); - - if (incomingCommand -> packet != NULL) - { - -- incomingCommand -> packet -> referenceCount; - - if (incomingCommand -> packet -> referenceCount == 0) - enet_packet_destroy (incomingCommand -> packet); - } - - if (incomingCommand -> fragments != NULL) - enet_free (incomingCommand -> fragments); - - enet_free (incomingCommand); - } -} - -static void -enet_peer_reset_incoming_commands (ENetList * queue) -{ - enet_peer_remove_incoming_commands(queue, enet_list_begin (queue), enet_list_end (queue)); -} - -void -enet_peer_reset_queues (ENetPeer * peer) -{ - ENetChannel * channel; - - if (peer -> needsDispatch) - { - enet_list_remove (& peer -> dispatchList); - - peer -> needsDispatch = 0; - } - - while (! enet_list_empty (& peer -> acknowledgements)) - enet_free (enet_list_remove (enet_list_begin (& peer -> acknowledgements))); - - enet_peer_reset_outgoing_commands (& peer -> sentReliableCommands); - enet_peer_reset_outgoing_commands (& peer -> sentUnreliableCommands); - enet_peer_reset_outgoing_commands (& peer -> outgoingReliableCommands); - enet_peer_reset_outgoing_commands (& peer -> outgoingUnreliableCommands); - enet_peer_reset_incoming_commands (& peer -> dispatchedCommands); - - if (peer -> channels != NULL && peer -> channelCount > 0) - { - for (channel = peer -> channels; - channel < & peer -> channels [peer -> channelCount]; - ++ channel) - { - enet_peer_reset_incoming_commands (& channel -> incomingReliableCommands); - enet_peer_reset_incoming_commands (& channel -> incomingUnreliableCommands); - } - - enet_free (peer -> channels); - } - - peer -> channels = NULL; - peer -> channelCount = 0; -} - -/** Forcefully disconnects a peer. - @param peer peer to forcefully disconnect - @remarks The foreign host represented by the peer is not notified of the disconnection and will timeout - on its connection to the local host. -*/ -void -enet_peer_reset (ENetPeer * peer) -{ - peer -> outgoingPeerID = ENET_PROTOCOL_MAXIMUM_PEER_ID; - peer -> connectID = 0; - - peer -> state = ENET_PEER_STATE_DISCONNECTED; - - peer -> incomingBandwidth = 0; - peer -> outgoingBandwidth = 0; - peer -> incomingBandwidthThrottleEpoch = 0; - peer -> outgoingBandwidthThrottleEpoch = 0; - peer -> incomingDataTotal = 0; - peer -> outgoingDataTotal = 0; - peer -> lastSendTime = 0; - peer -> lastReceiveTime = 0; - peer -> nextTimeout = 0; - peer -> earliestTimeout = 0; - peer -> packetLossEpoch = 0; - peer -> packetsSent = 0; - peer -> packetsLost = 0; - peer -> packetLoss = 0; - peer -> packetLossVariance = 0; - peer -> packetThrottle = ENET_PEER_DEFAULT_PACKET_THROTTLE; - peer -> packetThrottleLimit = ENET_PEER_PACKET_THROTTLE_SCALE; - peer -> packetThrottleCounter = 0; - peer -> packetThrottleEpoch = 0; - peer -> packetThrottleAcceleration = ENET_PEER_PACKET_THROTTLE_ACCELERATION; - peer -> packetThrottleDeceleration = ENET_PEER_PACKET_THROTTLE_DECELERATION; - peer -> packetThrottleInterval = ENET_PEER_PACKET_THROTTLE_INTERVAL; - peer -> pingInterval = ENET_PEER_PING_INTERVAL; - peer -> timeoutLimit = ENET_PEER_TIMEOUT_LIMIT; - peer -> timeoutMinimum = ENET_PEER_TIMEOUT_MINIMUM; - peer -> timeoutMaximum = ENET_PEER_TIMEOUT_MAXIMUM; - peer -> lastRoundTripTime = ENET_PEER_DEFAULT_ROUND_TRIP_TIME; - peer -> lowestRoundTripTime = ENET_PEER_DEFAULT_ROUND_TRIP_TIME; - peer -> lastRoundTripTimeVariance = 0; - peer -> highestRoundTripTimeVariance = 0; - peer -> roundTripTime = ENET_PEER_DEFAULT_ROUND_TRIP_TIME; - peer -> roundTripTimeVariance = 0; - peer -> mtu = peer -> host -> mtu; - peer -> reliableDataInTransit = 0; - peer -> outgoingReliableSequenceNumber = 0; - peer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - peer -> incomingUnsequencedGroup = 0; - peer -> outgoingUnsequencedGroup = 0; - peer -> eventData = 0; - - memset (peer -> unsequencedWindow, 0, sizeof (peer -> unsequencedWindow)); - - enet_peer_reset_queues (peer); -} - -/** Sends a ping request to a peer. - @param peer destination for the ping request - @remarks ping requests factor into the mean round trip time as designated by the - roundTripTime field in the ENetPeer structure. Enet automatically pings all connected - peers at regular intervals, however, this function may be called to ensure more - frequent ping requests. -*/ -void -enet_peer_ping (ENetPeer * peer) -{ - ENetProtocol command; - - if (peer -> state != ENET_PEER_STATE_CONNECTED) - return; - - command.header.command = ENET_PROTOCOL_COMMAND_PING | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - command.header.channelID = 0xFF; - - enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0); -} - -/** Sets the interval at which pings will be sent to a peer. - - Pings are used both to monitor the liveness of the connection and also to dynamically - adjust the throttle during periods of low traffic so that the throttle has reasonable - responsiveness during traffic spikes. - - @param peer the peer to adjust - @param pingInterval the interval at which to send pings; defaults to ENET_PEER_PING_INTERVAL if 0 -*/ -void -enet_peer_ping_interval (ENetPeer * peer, enet_uint32 pingInterval) -{ - peer -> pingInterval = pingInterval ? pingInterval : ENET_PEER_PING_INTERVAL; -} - -/** Sets the timeout parameters for a peer. - - The timeout parameter control how and when a peer will timeout from a failure to acknowledge - reliable traffic. Timeout values use an exponential backoff mechanism, where if a reliable - packet is not acknowledge within some multiple of the average RTT plus a variance tolerance, - the timeout will be doubled until it reaches a set limit. If the timeout is thus at this - limit and reliable packets have been sent but not acknowledged within a certain minimum time - period, the peer will be disconnected. Alternatively, if reliable packets have been sent - but not acknowledged for a certain maximum time period, the peer will be disconnected regardless - of the current timeout limit value. - - @param peer the peer to adjust - @param timeoutLimit the timeout limit; defaults to ENET_PEER_TIMEOUT_LIMIT if 0 - @param timeoutMinimum the timeout minimum; defaults to ENET_PEER_TIMEOUT_MINIMUM if 0 - @param timeoutMaximum the timeout maximum; defaults to ENET_PEER_TIMEOUT_MAXIMUM if 0 -*/ - -void -enet_peer_timeout (ENetPeer * peer, enet_uint32 timeoutLimit, enet_uint32 timeoutMinimum, enet_uint32 timeoutMaximum) -{ - peer -> timeoutLimit = timeoutLimit ? timeoutLimit : ENET_PEER_TIMEOUT_LIMIT; - peer -> timeoutMinimum = timeoutMinimum ? timeoutMinimum : ENET_PEER_TIMEOUT_MINIMUM; - peer -> timeoutMaximum = timeoutMaximum ? timeoutMaximum : ENET_PEER_TIMEOUT_MAXIMUM; -} - -/** Force an immediate disconnection from a peer. - @param peer peer to disconnect - @param data data describing the disconnection - @remarks No ENET_EVENT_DISCONNECT event will be generated. The foreign peer is not - guarenteed to receive the disconnect notification, and is reset immediately upon - return from this function. -*/ -void -enet_peer_disconnect_now (ENetPeer * peer, enet_uint32 data) -{ - ENetProtocol command; - - if (peer -> state == ENET_PEER_STATE_DISCONNECTED) - return; - - if (peer -> state != ENET_PEER_STATE_ZOMBIE && - peer -> state != ENET_PEER_STATE_DISCONNECTING) - { - enet_peer_reset_queues (peer); - - command.header.command = ENET_PROTOCOL_COMMAND_DISCONNECT | ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED; - command.header.channelID = 0xFF; - command.disconnect.data = ENET_HOST_TO_NET_32 (data); - - enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0); - - enet_host_flush (peer -> host); - } - - enet_peer_reset (peer); -} - -/** Request a disconnection from a peer. - @param peer peer to request a disconnection - @param data data describing the disconnection - @remarks An ENET_EVENT_DISCONNECT event will be generated by enet_host_service() - once the disconnection is complete. -*/ -void -enet_peer_disconnect (ENetPeer * peer, enet_uint32 data) -{ - ENetProtocol command; - - if (peer -> state == ENET_PEER_STATE_DISCONNECTING || - peer -> state == ENET_PEER_STATE_DISCONNECTED || - peer -> state == ENET_PEER_STATE_ACKNOWLEDGING_DISCONNECT || - peer -> state == ENET_PEER_STATE_ZOMBIE) - return; - - enet_peer_reset_queues (peer); - - command.header.command = ENET_PROTOCOL_COMMAND_DISCONNECT; - command.header.channelID = 0xFF; - command.disconnect.data = ENET_HOST_TO_NET_32 (data); - - if (peer -> state == ENET_PEER_STATE_CONNECTED || peer -> state == ENET_PEER_STATE_DISCONNECT_LATER) - command.header.command |= ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - else - command.header.command |= ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED; - - enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0); - - if (peer -> state == ENET_PEER_STATE_CONNECTED || peer -> state == ENET_PEER_STATE_DISCONNECT_LATER) - peer -> state = ENET_PEER_STATE_DISCONNECTING; - else - { - enet_host_flush (peer -> host); - enet_peer_reset (peer); - } -} - -/** Request a disconnection from a peer, but only after all queued outgoing packets are sent. - @param peer peer to request a disconnection - @param data data describing the disconnection - @remarks An ENET_EVENT_DISCONNECT event will be generated by enet_host_service() - once the disconnection is complete. -*/ -void -enet_peer_disconnect_later (ENetPeer * peer, enet_uint32 data) -{ - if ((peer -> state == ENET_PEER_STATE_CONNECTED || peer -> state == ENET_PEER_STATE_DISCONNECT_LATER) && - ! (enet_list_empty (& peer -> outgoingReliableCommands) && - enet_list_empty (& peer -> outgoingUnreliableCommands) && - enet_list_empty (& peer -> sentReliableCommands))) - { - peer -> state = ENET_PEER_STATE_DISCONNECT_LATER; - peer -> eventData = data; - } - else - enet_peer_disconnect (peer, data); -} - -ENetAcknowledgement * -enet_peer_queue_acknowledgement (ENetPeer * peer, const ENetProtocol * command, enet_uint16 sentTime) -{ - ENetAcknowledgement * acknowledgement; - - if (command -> header.channelID < peer -> channelCount) - { - ENetChannel * channel = & peer -> channels [command -> header.channelID]; - enet_uint16 reliableWindow = command -> header.reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE, - currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - - if (command -> header.reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - reliableWindow += ENET_PEER_RELIABLE_WINDOWS; - - if (reliableWindow >= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1 && reliableWindow <= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS) - return NULL; - } - - acknowledgement = (ENetAcknowledgement *) enet_malloc (sizeof (ENetAcknowledgement)); - if (acknowledgement == NULL) - return NULL; - - peer -> outgoingDataTotal += sizeof (ENetProtocolAcknowledge); - - acknowledgement -> sentTime = sentTime; - acknowledgement -> command = * command; - - enet_list_insert (enet_list_end (& peer -> acknowledgements), acknowledgement); - - return acknowledgement; -} - -void -enet_peer_setup_outgoing_command (ENetPeer * peer, ENetOutgoingCommand * outgoingCommand) -{ - ENetChannel * channel = & peer -> channels [outgoingCommand -> command.header.channelID]; - - peer -> outgoingDataTotal += enet_protocol_command_size (outgoingCommand -> command.header.command) + outgoingCommand -> fragmentLength; - - if (outgoingCommand -> command.header.channelID == 0xFF) - { - ++ peer -> outgoingReliableSequenceNumber; - - outgoingCommand -> reliableSequenceNumber = peer -> outgoingReliableSequenceNumber; - outgoingCommand -> unreliableSequenceNumber = 0; - } - else - if (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE) - { - ++ channel -> outgoingReliableSequenceNumber; - channel -> outgoingUnreliableSequenceNumber = 0; - - outgoingCommand -> reliableSequenceNumber = channel -> outgoingReliableSequenceNumber; - outgoingCommand -> unreliableSequenceNumber = 0; - } - else - if (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED) - { - ++ peer -> outgoingUnsequencedGroup; - - outgoingCommand -> reliableSequenceNumber = 0; - outgoingCommand -> unreliableSequenceNumber = 0; - } - else - { - if (outgoingCommand -> fragmentOffset == 0) - ++ channel -> outgoingUnreliableSequenceNumber; - - outgoingCommand -> reliableSequenceNumber = channel -> outgoingReliableSequenceNumber; - outgoingCommand -> unreliableSequenceNumber = channel -> outgoingUnreliableSequenceNumber; - } - - outgoingCommand -> sendAttempts = 0; - outgoingCommand -> sentTime = 0; - outgoingCommand -> roundTripTimeout = 0; - outgoingCommand -> roundTripTimeoutLimit = 0; - outgoingCommand -> command.header.reliableSequenceNumber = ENET_HOST_TO_NET_16 (outgoingCommand -> reliableSequenceNumber); - - switch (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) - { - case ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE: - outgoingCommand -> command.sendUnreliable.unreliableSequenceNumber = ENET_HOST_TO_NET_16 (outgoingCommand -> unreliableSequenceNumber); - break; - - case ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED: - outgoingCommand -> command.sendUnsequenced.unsequencedGroup = ENET_HOST_TO_NET_16 (peer -> outgoingUnsequencedGroup); - break; - - default: - break; - } - - if (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE) - enet_list_insert (enet_list_end (& peer -> outgoingReliableCommands), outgoingCommand); - else - enet_list_insert (enet_list_end (& peer -> outgoingUnreliableCommands), outgoingCommand); -} - -ENetOutgoingCommand * -enet_peer_queue_outgoing_command (ENetPeer * peer, const ENetProtocol * command, ENetPacket * packet, enet_uint32 offset, enet_uint16 length) -{ - ENetOutgoingCommand * outgoingCommand = (ENetOutgoingCommand *) enet_malloc (sizeof (ENetOutgoingCommand)); - if (outgoingCommand == NULL) - return NULL; - - outgoingCommand -> command = * command; - outgoingCommand -> fragmentOffset = offset; - outgoingCommand -> fragmentLength = length; - outgoingCommand -> packet = packet; - if (packet != NULL) - ++ packet -> referenceCount; - - enet_peer_setup_outgoing_command (peer, outgoingCommand); - - return outgoingCommand; -} - -void -enet_peer_dispatch_incoming_unreliable_commands (ENetPeer * peer, ENetChannel * channel) -{ - ENetListIterator droppedCommand, startCommand, currentCommand; - - for (droppedCommand = startCommand = currentCommand = enet_list_begin (& channel -> incomingUnreliableCommands); - currentCommand != enet_list_end (& channel -> incomingUnreliableCommands); - currentCommand = enet_list_next (currentCommand)) - { - ENetIncomingCommand * incomingCommand = (ENetIncomingCommand *) currentCommand; - - if ((incomingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) == ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED) - continue; - - if (incomingCommand -> reliableSequenceNumber == channel -> incomingReliableSequenceNumber) - { - if (incomingCommand -> fragmentsRemaining <= 0) - { - channel -> incomingUnreliableSequenceNumber = incomingCommand -> unreliableSequenceNumber; - continue; - } - - if (startCommand != currentCommand) - { - enet_list_move (enet_list_end (& peer -> dispatchedCommands), startCommand, enet_list_previous (currentCommand)); - - if (! peer -> needsDispatch) - { - enet_list_insert (enet_list_end (& peer -> host -> dispatchQueue), & peer -> dispatchList); - - peer -> needsDispatch = 1; - } - - droppedCommand = currentCommand; - } - else - if (droppedCommand != currentCommand) - droppedCommand = enet_list_previous (currentCommand); - } - else - { - enet_uint16 reliableWindow = incomingCommand -> reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE, - currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - reliableWindow += ENET_PEER_RELIABLE_WINDOWS; - if (reliableWindow >= currentWindow && reliableWindow < currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1) - break; - - droppedCommand = enet_list_next (currentCommand); - - if (startCommand != currentCommand) - { - enet_list_move (enet_list_end (& peer -> dispatchedCommands), startCommand, enet_list_previous (currentCommand)); - - if (! peer -> needsDispatch) - { - enet_list_insert (enet_list_end (& peer -> host -> dispatchQueue), & peer -> dispatchList); - - peer -> needsDispatch = 1; - } - } - } - - startCommand = enet_list_next (currentCommand); - } - - if (startCommand != currentCommand) - { - enet_list_move (enet_list_end (& peer -> dispatchedCommands), startCommand, enet_list_previous (currentCommand)); - - if (! peer -> needsDispatch) - { - enet_list_insert (enet_list_end (& peer -> host -> dispatchQueue), & peer -> dispatchList); - - peer -> needsDispatch = 1; - } - - droppedCommand = currentCommand; - } - - enet_peer_remove_incoming_commands (& channel -> incomingUnreliableCommands, enet_list_begin (& channel -> incomingUnreliableCommands), droppedCommand); -} - -void -enet_peer_dispatch_incoming_reliable_commands (ENetPeer * peer, ENetChannel * channel) -{ - ENetListIterator currentCommand; - - for (currentCommand = enet_list_begin (& channel -> incomingReliableCommands); - currentCommand != enet_list_end (& channel -> incomingReliableCommands); - currentCommand = enet_list_next (currentCommand)) - { - ENetIncomingCommand * incomingCommand = (ENetIncomingCommand *) currentCommand; - - if (incomingCommand -> fragmentsRemaining > 0 || - incomingCommand -> reliableSequenceNumber != (enet_uint16) (channel -> incomingReliableSequenceNumber + 1)) - break; - - channel -> incomingReliableSequenceNumber = incomingCommand -> reliableSequenceNumber; - - if (incomingCommand -> fragmentCount > 0) - channel -> incomingReliableSequenceNumber += incomingCommand -> fragmentCount - 1; - } - - if (currentCommand == enet_list_begin (& channel -> incomingReliableCommands)) - return; - - channel -> incomingUnreliableSequenceNumber = 0; - - enet_list_move (enet_list_end (& peer -> dispatchedCommands), enet_list_begin (& channel -> incomingReliableCommands), enet_list_previous (currentCommand)); - - if (! peer -> needsDispatch) - { - enet_list_insert (enet_list_end (& peer -> host -> dispatchQueue), & peer -> dispatchList); - - peer -> needsDispatch = 1; - } - - if (! enet_list_empty (& channel -> incomingUnreliableCommands)) - enet_peer_dispatch_incoming_unreliable_commands (peer, channel); -} - -ENetIncomingCommand * -enet_peer_queue_incoming_command (ENetPeer * peer, const ENetProtocol * command, ENetPacket * packet, enet_uint32 fragmentCount) -{ - static ENetIncomingCommand dummyCommand; - - ENetChannel * channel = & peer -> channels [command -> header.channelID]; - enet_uint32 unreliableSequenceNumber = 0, reliableSequenceNumber = 0; - enet_uint16 reliableWindow, currentWindow; - ENetIncomingCommand * incomingCommand; - ENetListIterator currentCommand; - - if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER) - goto freePacket; - - if ((command -> header.command & ENET_PROTOCOL_COMMAND_MASK) != ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED) - { - reliableSequenceNumber = command -> header.reliableSequenceNumber; - reliableWindow = reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - - if (reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - reliableWindow += ENET_PEER_RELIABLE_WINDOWS; - - if (reliableWindow < currentWindow || reliableWindow >= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1) - goto freePacket; - } - - switch (command -> header.command & ENET_PROTOCOL_COMMAND_MASK) - { - case ENET_PROTOCOL_COMMAND_SEND_FRAGMENT: - case ENET_PROTOCOL_COMMAND_SEND_RELIABLE: - if (reliableSequenceNumber == channel -> incomingReliableSequenceNumber) - goto freePacket; - - for (currentCommand = enet_list_previous (enet_list_end (& channel -> incomingReliableCommands)); - currentCommand != enet_list_end (& channel -> incomingReliableCommands); - currentCommand = enet_list_previous (currentCommand)) - { - incomingCommand = (ENetIncomingCommand *) currentCommand; - - if (reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - { - if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - continue; - } - else - if (incomingCommand -> reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - break; - - if (incomingCommand -> reliableSequenceNumber <= reliableSequenceNumber) - { - if (incomingCommand -> reliableSequenceNumber < reliableSequenceNumber) - break; - - goto freePacket; - } - } - break; - - case ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE: - case ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE_FRAGMENT: - unreliableSequenceNumber = ENET_NET_TO_HOST_16 (command -> sendUnreliable.unreliableSequenceNumber); - - if (reliableSequenceNumber == channel -> incomingReliableSequenceNumber && - unreliableSequenceNumber <= channel -> incomingUnreliableSequenceNumber) - goto freePacket; - - for (currentCommand = enet_list_previous (enet_list_end (& channel -> incomingUnreliableCommands)); - currentCommand != enet_list_end (& channel -> incomingUnreliableCommands); - currentCommand = enet_list_previous (currentCommand)) - { - incomingCommand = (ENetIncomingCommand *) currentCommand; - - if ((command -> header.command & ENET_PROTOCOL_COMMAND_MASK) == ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED) - continue; - - if (reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - { - if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - continue; - } - else - if (incomingCommand -> reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - break; - - if (incomingCommand -> reliableSequenceNumber < reliableSequenceNumber) - break; - - if (incomingCommand -> reliableSequenceNumber > reliableSequenceNumber) - continue; - - if (incomingCommand -> unreliableSequenceNumber <= unreliableSequenceNumber) - { - if (incomingCommand -> unreliableSequenceNumber < unreliableSequenceNumber) - break; - - goto freePacket; - } - } - break; - - case ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED: - currentCommand = enet_list_end (& channel -> incomingUnreliableCommands); - break; - - default: - goto freePacket; - } - - incomingCommand = (ENetIncomingCommand *) enet_malloc (sizeof (ENetIncomingCommand)); - if (incomingCommand == NULL) - goto notifyError; - - incomingCommand -> reliableSequenceNumber = command -> header.reliableSequenceNumber; - incomingCommand -> unreliableSequenceNumber = unreliableSequenceNumber & 0xFFFF; - incomingCommand -> command = * command; - incomingCommand -> fragmentCount = fragmentCount; - incomingCommand -> fragmentsRemaining = fragmentCount; - incomingCommand -> packet = packet; - incomingCommand -> fragments = NULL; - - if (fragmentCount > 0) - { - if (fragmentCount <= ENET_PROTOCOL_MAXIMUM_FRAGMENT_COUNT) - incomingCommand -> fragments = (enet_uint32 *) enet_malloc ((fragmentCount + 31) / 32 * sizeof (enet_uint32)); - if (incomingCommand -> fragments == NULL) - { - enet_free (incomingCommand); - - goto notifyError; - } - memset (incomingCommand -> fragments, 0, (fragmentCount + 31) / 32 * sizeof (enet_uint32)); - } - - if (packet != NULL) - ++ packet -> referenceCount; - - enet_list_insert (enet_list_next (currentCommand), incomingCommand); - - switch (command -> header.command & ENET_PROTOCOL_COMMAND_MASK) - { - case ENET_PROTOCOL_COMMAND_SEND_FRAGMENT: - case ENET_PROTOCOL_COMMAND_SEND_RELIABLE: - enet_peer_dispatch_incoming_reliable_commands (peer, channel); - break; - - default: - enet_peer_dispatch_incoming_unreliable_commands (peer, channel); - break; - } - - return incomingCommand; - -freePacket: - if (fragmentCount > 0) - goto notifyError; - - if (packet != NULL && packet -> referenceCount == 0) - enet_packet_destroy (packet); - - return & dummyCommand; - -notifyError: - if (packet != NULL && packet -> referenceCount == 0) - enet_packet_destroy (packet); - - return NULL; -} - -/** @} */ diff --git a/btgui/enet/premake4.lua b/btgui/enet/premake4.lua deleted file mode 100644 index f5aefe3d5..000000000 --- a/btgui/enet/premake4.lua +++ /dev/null @@ -1,31 +0,0 @@ - project "enet" - - kind "StaticLib" - - if os.is("Windows") then - defines { "WIN32" } - files{"win32.c"} - end - if os.is("Linux") then - defines {"HAS_SOCKLEN_T"} - files {"unix.c",} - end - if os.is("MacOSX") then - files{"unix.c"} - end - - targetdir "../../lib" - - includedirs { - ".","include" - } - files { - "callbacks.c", - "compress.c", - "host.c", - "list.c", - "packet.c", - "peer.c", - "protocol.c", - "**.h" - } diff --git a/btgui/enet/protocol.c b/btgui/enet/protocol.c deleted file mode 100644 index d6cc33a49..000000000 --- a/btgui/enet/protocol.c +++ /dev/null @@ -1,1899 +0,0 @@ -/** - @file protocol.c - @brief ENet protocol functions -*/ -#include -#include -#define ENET_BUILDING_LIB 1 -#include "enet/utility.h" -#include "enet/time.h" -#include "enet/enet.h" - -static size_t commandSizes [ENET_PROTOCOL_COMMAND_COUNT] = -{ - 0, - sizeof (ENetProtocolAcknowledge), - sizeof (ENetProtocolConnect), - sizeof (ENetProtocolVerifyConnect), - sizeof (ENetProtocolDisconnect), - sizeof (ENetProtocolPing), - sizeof (ENetProtocolSendReliable), - sizeof (ENetProtocolSendUnreliable), - sizeof (ENetProtocolSendFragment), - sizeof (ENetProtocolSendUnsequenced), - sizeof (ENetProtocolBandwidthLimit), - sizeof (ENetProtocolThrottleConfigure), - sizeof (ENetProtocolSendFragment) -}; - -size_t -enet_protocol_command_size (enet_uint8 commandNumber) -{ - return commandSizes [commandNumber & ENET_PROTOCOL_COMMAND_MASK]; -} - -static int -enet_protocol_dispatch_incoming_commands (ENetHost * host, ENetEvent * event) -{ - while (! enet_list_empty (& host -> dispatchQueue)) - { - ENetPeer * peer = (ENetPeer *) enet_list_remove (enet_list_begin (& host -> dispatchQueue)); - - peer -> needsDispatch = 0; - - switch (peer -> state) - { - case ENET_PEER_STATE_CONNECTION_PENDING: - case ENET_PEER_STATE_CONNECTION_SUCCEEDED: - peer -> state = ENET_PEER_STATE_CONNECTED; - - event -> type = ENET_EVENT_TYPE_CONNECT; - event -> peer = peer; - event -> data = peer -> eventData; - - return 1; - - case ENET_PEER_STATE_ZOMBIE: - host -> recalculateBandwidthLimits = 1; - - event -> type = ENET_EVENT_TYPE_DISCONNECT; - event -> peer = peer; - event -> data = peer -> eventData; - - enet_peer_reset (peer); - - return 1; - - case ENET_PEER_STATE_CONNECTED: - if (enet_list_empty (& peer -> dispatchedCommands)) - continue; - - event -> packet = enet_peer_receive (peer, & event -> channelID); - if (event -> packet == NULL) - continue; - - event -> type = ENET_EVENT_TYPE_RECEIVE; - event -> peer = peer; - - if (! enet_list_empty (& peer -> dispatchedCommands)) - { - peer -> needsDispatch = 1; - - enet_list_insert (enet_list_end (& host -> dispatchQueue), & peer -> dispatchList); - } - - return 1; - - default: - break; - } - } - - return 0; -} - -static void -enet_protocol_dispatch_state (ENetHost * host, ENetPeer * peer, ENetPeerState state) -{ - peer -> state = state; - - if (! peer -> needsDispatch) - { - enet_list_insert (enet_list_end (& host -> dispatchQueue), & peer -> dispatchList); - - peer -> needsDispatch = 1; - } -} - -static void -enet_protocol_notify_connect (ENetHost * host, ENetPeer * peer, ENetEvent * event) -{ - host -> recalculateBandwidthLimits = 1; - - if (event != NULL) - { - peer -> state = ENET_PEER_STATE_CONNECTED; - - event -> type = ENET_EVENT_TYPE_CONNECT; - event -> peer = peer; - event -> data = peer -> eventData; - } - else - enet_protocol_dispatch_state (host, peer, peer -> state == ENET_PEER_STATE_CONNECTING ? ENET_PEER_STATE_CONNECTION_SUCCEEDED : ENET_PEER_STATE_CONNECTION_PENDING); -} - -static void -enet_protocol_notify_disconnect (ENetHost * host, ENetPeer * peer, ENetEvent * event) -{ - if (peer -> state >= ENET_PEER_STATE_CONNECTION_PENDING) - host -> recalculateBandwidthLimits = 1; - - if (peer -> state != ENET_PEER_STATE_CONNECTING && peer -> state < ENET_PEER_STATE_CONNECTION_SUCCEEDED) - enet_peer_reset (peer); - else - if (event != NULL) - { - event -> type = ENET_EVENT_TYPE_DISCONNECT; - event -> peer = peer; - event -> data = 0; - - enet_peer_reset (peer); - } - else - { - peer -> eventData = 0; - - enet_protocol_dispatch_state (host, peer, ENET_PEER_STATE_ZOMBIE); - } -} - -static void -enet_protocol_remove_sent_unreliable_commands (ENetPeer * peer) -{ - ENetOutgoingCommand * outgoingCommand; - - while (! enet_list_empty (& peer -> sentUnreliableCommands)) - { - outgoingCommand = (ENetOutgoingCommand *) enet_list_front (& peer -> sentUnreliableCommands); - - enet_list_remove (& outgoingCommand -> outgoingCommandList); - - if (outgoingCommand -> packet != NULL) - { - -- outgoingCommand -> packet -> referenceCount; - - if (outgoingCommand -> packet -> referenceCount == 0) - { - outgoingCommand -> packet -> flags |= ENET_PACKET_FLAG_SENT; - - enet_packet_destroy (outgoingCommand -> packet); - } - } - - enet_free (outgoingCommand); - } -} - -static ENetProtocolCommand -enet_protocol_remove_sent_reliable_command (ENetPeer * peer, enet_uint16 reliableSequenceNumber, enet_uint8 channelID) -{ - ENetOutgoingCommand * outgoingCommand = NULL; - ENetListIterator currentCommand; - ENetProtocolCommand commandNumber; - int wasSent = 1; - - for (currentCommand = enet_list_begin (& peer -> sentReliableCommands); - currentCommand != enet_list_end (& peer -> sentReliableCommands); - currentCommand = enet_list_next (currentCommand)) - { - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - - if (outgoingCommand -> reliableSequenceNumber == reliableSequenceNumber && - outgoingCommand -> command.header.channelID == channelID) - break; - } - - if (currentCommand == enet_list_end (& peer -> sentReliableCommands)) - { - for (currentCommand = enet_list_begin (& peer -> outgoingReliableCommands); - currentCommand != enet_list_end (& peer -> outgoingReliableCommands); - currentCommand = enet_list_next (currentCommand)) - { - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - - if (outgoingCommand -> sendAttempts < 1) return ENET_PROTOCOL_COMMAND_NONE; - - if (outgoingCommand -> reliableSequenceNumber == reliableSequenceNumber && - outgoingCommand -> command.header.channelID == channelID) - break; - } - - if (currentCommand == enet_list_end (& peer -> outgoingReliableCommands)) - return ENET_PROTOCOL_COMMAND_NONE; - - wasSent = 0; - } - - if (outgoingCommand == NULL) - return ENET_PROTOCOL_COMMAND_NONE; - - if (channelID < peer -> channelCount) - { - ENetChannel * channel = & peer -> channels [channelID]; - enet_uint16 reliableWindow = reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - if (channel -> reliableWindows [reliableWindow] > 0) - { - -- channel -> reliableWindows [reliableWindow]; - if (! channel -> reliableWindows [reliableWindow]) - channel -> usedReliableWindows &= ~ (1 << reliableWindow); - } - } - - commandNumber = (ENetProtocolCommand) (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK); - - enet_list_remove (& outgoingCommand -> outgoingCommandList); - - if (outgoingCommand -> packet != NULL) - { - if (wasSent) - peer -> reliableDataInTransit -= outgoingCommand -> fragmentLength; - - -- outgoingCommand -> packet -> referenceCount; - - if (outgoingCommand -> packet -> referenceCount == 0) - { - outgoingCommand -> packet -> flags |= ENET_PACKET_FLAG_SENT; - - enet_packet_destroy (outgoingCommand -> packet); - } - } - - enet_free (outgoingCommand); - - if (enet_list_empty (& peer -> sentReliableCommands)) - return commandNumber; - - outgoingCommand = (ENetOutgoingCommand *) enet_list_front (& peer -> sentReliableCommands); - - peer -> nextTimeout = outgoingCommand -> sentTime + outgoingCommand -> roundTripTimeout; - - return commandNumber; -} - -static ENetPeer * -enet_protocol_handle_connect (ENetHost * host, ENetProtocolHeader * header, ENetProtocol * command) -{ - enet_uint8 incomingSessionID, outgoingSessionID; - enet_uint32 mtu, windowSize; - ENetChannel * channel; - size_t channelCount; - ENetPeer * currentPeer; - ENetProtocol verifyCommand; - - channelCount = ENET_NET_TO_HOST_32 (command -> connect.channelCount); - - if (channelCount < ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT || - channelCount > ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT) - return NULL; - - for (currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - if (currentPeer -> state != ENET_PEER_STATE_DISCONNECTED && - currentPeer -> address.host == host -> receivedAddress.host && - currentPeer -> address.port == host -> receivedAddress.port && - currentPeer -> connectID == command -> connect.connectID) - return NULL; - } - - for (currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - if (currentPeer -> state == ENET_PEER_STATE_DISCONNECTED) - break; - } - - if (currentPeer >= & host -> peers [host -> peerCount]) - return NULL; - - if (channelCount > host -> channelLimit) - channelCount = host -> channelLimit; - currentPeer -> channels = (ENetChannel *) enet_malloc (channelCount * sizeof (ENetChannel)); - if (currentPeer -> channels == NULL) - return NULL; - currentPeer -> channelCount = channelCount; - currentPeer -> state = ENET_PEER_STATE_ACKNOWLEDGING_CONNECT; - currentPeer -> connectID = command -> connect.connectID; - currentPeer -> address = host -> receivedAddress; - currentPeer -> outgoingPeerID = ENET_NET_TO_HOST_16 (command -> connect.outgoingPeerID); - currentPeer -> incomingBandwidth = ENET_NET_TO_HOST_32 (command -> connect.incomingBandwidth); - currentPeer -> outgoingBandwidth = ENET_NET_TO_HOST_32 (command -> connect.outgoingBandwidth); - currentPeer -> packetThrottleInterval = ENET_NET_TO_HOST_32 (command -> connect.packetThrottleInterval); - currentPeer -> packetThrottleAcceleration = ENET_NET_TO_HOST_32 (command -> connect.packetThrottleAcceleration); - currentPeer -> packetThrottleDeceleration = ENET_NET_TO_HOST_32 (command -> connect.packetThrottleDeceleration); - currentPeer -> eventData = ENET_NET_TO_HOST_32 (command -> connect.data); - - incomingSessionID = command -> connect.incomingSessionID == 0xFF ? currentPeer -> outgoingSessionID : command -> connect.incomingSessionID; - incomingSessionID = (incomingSessionID + 1) & (ENET_PROTOCOL_HEADER_SESSION_MASK >> ENET_PROTOCOL_HEADER_SESSION_SHIFT); - if (incomingSessionID == currentPeer -> outgoingSessionID) - incomingSessionID = (incomingSessionID + 1) & (ENET_PROTOCOL_HEADER_SESSION_MASK >> ENET_PROTOCOL_HEADER_SESSION_SHIFT); - currentPeer -> outgoingSessionID = incomingSessionID; - - outgoingSessionID = command -> connect.outgoingSessionID == 0xFF ? currentPeer -> incomingSessionID : command -> connect.outgoingSessionID; - outgoingSessionID = (outgoingSessionID + 1) & (ENET_PROTOCOL_HEADER_SESSION_MASK >> ENET_PROTOCOL_HEADER_SESSION_SHIFT); - if (outgoingSessionID == currentPeer -> incomingSessionID) - outgoingSessionID = (outgoingSessionID + 1) & (ENET_PROTOCOL_HEADER_SESSION_MASK >> ENET_PROTOCOL_HEADER_SESSION_SHIFT); - currentPeer -> incomingSessionID = outgoingSessionID; - - for (channel = currentPeer -> channels; - channel < & currentPeer -> channels [channelCount]; - ++ channel) - { - channel -> outgoingReliableSequenceNumber = 0; - channel -> outgoingUnreliableSequenceNumber = 0; - channel -> incomingReliableSequenceNumber = 0; - channel -> incomingUnreliableSequenceNumber = 0; - - enet_list_clear (& channel -> incomingReliableCommands); - enet_list_clear (& channel -> incomingUnreliableCommands); - - channel -> usedReliableWindows = 0; - memset (channel -> reliableWindows, 0, sizeof (channel -> reliableWindows)); - } - - mtu = ENET_NET_TO_HOST_32 (command -> connect.mtu); - - if (mtu < ENET_PROTOCOL_MINIMUM_MTU) - mtu = ENET_PROTOCOL_MINIMUM_MTU; - else - if (mtu > ENET_PROTOCOL_MAXIMUM_MTU) - mtu = ENET_PROTOCOL_MAXIMUM_MTU; - - currentPeer -> mtu = mtu; - - if (host -> outgoingBandwidth == 0 && - currentPeer -> incomingBandwidth == 0) - currentPeer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - else - if (host -> outgoingBandwidth == 0 || - currentPeer -> incomingBandwidth == 0) - currentPeer -> windowSize = (ENET_MAX (host -> outgoingBandwidth, currentPeer -> incomingBandwidth) / - ENET_PEER_WINDOW_SIZE_SCALE) * - ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - else - currentPeer -> windowSize = (ENET_MIN (host -> outgoingBandwidth, currentPeer -> incomingBandwidth) / - ENET_PEER_WINDOW_SIZE_SCALE) * - ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - - if (currentPeer -> windowSize < ENET_PROTOCOL_MINIMUM_WINDOW_SIZE) - currentPeer -> windowSize = ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - else - if (currentPeer -> windowSize > ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE) - currentPeer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - - if (host -> incomingBandwidth == 0) - windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - else - windowSize = (host -> incomingBandwidth / ENET_PEER_WINDOW_SIZE_SCALE) * - ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - - if (windowSize > ENET_NET_TO_HOST_32 (command -> connect.windowSize)) - windowSize = ENET_NET_TO_HOST_32 (command -> connect.windowSize); - - if (windowSize < ENET_PROTOCOL_MINIMUM_WINDOW_SIZE) - windowSize = ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - else - if (windowSize > ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE) - windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - - verifyCommand.header.command = ENET_PROTOCOL_COMMAND_VERIFY_CONNECT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE; - verifyCommand.header.channelID = 0xFF; - verifyCommand.verifyConnect.outgoingPeerID = ENET_HOST_TO_NET_16 (currentPeer -> incomingPeerID); - verifyCommand.verifyConnect.incomingSessionID = incomingSessionID; - verifyCommand.verifyConnect.outgoingSessionID = outgoingSessionID; - verifyCommand.verifyConnect.mtu = ENET_HOST_TO_NET_32 (currentPeer -> mtu); - verifyCommand.verifyConnect.windowSize = ENET_HOST_TO_NET_32 (windowSize); - verifyCommand.verifyConnect.channelCount = ENET_HOST_TO_NET_32 (channelCount); - verifyCommand.verifyConnect.incomingBandwidth = ENET_HOST_TO_NET_32 (host -> incomingBandwidth); - verifyCommand.verifyConnect.outgoingBandwidth = ENET_HOST_TO_NET_32 (host -> outgoingBandwidth); - verifyCommand.verifyConnect.packetThrottleInterval = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleInterval); - verifyCommand.verifyConnect.packetThrottleAcceleration = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleAcceleration); - verifyCommand.verifyConnect.packetThrottleDeceleration = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleDeceleration); - verifyCommand.verifyConnect.connectID = currentPeer -> connectID; - - enet_peer_queue_outgoing_command (currentPeer, & verifyCommand, NULL, 0, 0); - - return currentPeer; -} - -static int -enet_protocol_handle_send_reliable (ENetHost * host, ENetPeer * peer, const ENetProtocol * command, enet_uint8 ** currentData) -{ - ENetPacket * packet; - size_t dataLength; - - if (command -> header.channelID >= peer -> channelCount || - (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)) - return -1; - - dataLength = ENET_NET_TO_HOST_16 (command -> sendReliable.dataLength); - * currentData += dataLength; - if (dataLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - * currentData < host -> receivedData || - * currentData > & host -> receivedData [host -> receivedDataLength]) - return -1; - - packet = enet_packet_create ((const enet_uint8 *) command + sizeof (ENetProtocolSendReliable), - dataLength, - ENET_PACKET_FLAG_RELIABLE); - if (packet == NULL || - enet_peer_queue_incoming_command (peer, command, packet, 0) == NULL) - return -1; - - return 0; -} - -static int -enet_protocol_handle_send_unsequenced (ENetHost * host, ENetPeer * peer, const ENetProtocol * command, enet_uint8 ** currentData) -{ - ENetPacket * packet; - enet_uint32 unsequencedGroup, index; - size_t dataLength; - - if (command -> header.channelID >= peer -> channelCount || - (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)) - return -1; - - dataLength = ENET_NET_TO_HOST_16 (command -> sendUnsequenced.dataLength); - * currentData += dataLength; - if (dataLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - * currentData < host -> receivedData || - * currentData > & host -> receivedData [host -> receivedDataLength]) - return -1; - - unsequencedGroup = ENET_NET_TO_HOST_16 (command -> sendUnsequenced.unsequencedGroup); - index = unsequencedGroup % ENET_PEER_UNSEQUENCED_WINDOW_SIZE; - - if (unsequencedGroup < peer -> incomingUnsequencedGroup) - unsequencedGroup += 0x10000; - - if (unsequencedGroup >= (enet_uint32) peer -> incomingUnsequencedGroup + ENET_PEER_FREE_UNSEQUENCED_WINDOWS * ENET_PEER_UNSEQUENCED_WINDOW_SIZE) - return 0; - - unsequencedGroup &= 0xFFFF; - - if (unsequencedGroup - index != peer -> incomingUnsequencedGroup) - { - peer -> incomingUnsequencedGroup = unsequencedGroup - index; - - memset (peer -> unsequencedWindow, 0, sizeof (peer -> unsequencedWindow)); - } - else - if (peer -> unsequencedWindow [index / 32] & (1 << (index % 32))) - return 0; - - packet = enet_packet_create ((const enet_uint8 *) command + sizeof (ENetProtocolSendUnsequenced), - dataLength, - ENET_PACKET_FLAG_UNSEQUENCED); - if (packet == NULL || - enet_peer_queue_incoming_command (peer, command, packet, 0) == NULL) - return -1; - - peer -> unsequencedWindow [index / 32] |= 1 << (index % 32); - - return 0; -} - -static int -enet_protocol_handle_send_unreliable (ENetHost * host, ENetPeer * peer, const ENetProtocol * command, enet_uint8 ** currentData) -{ - ENetPacket * packet; - size_t dataLength; - - if (command -> header.channelID >= peer -> channelCount || - (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)) - return -1; - - dataLength = ENET_NET_TO_HOST_16 (command -> sendUnreliable.dataLength); - * currentData += dataLength; - if (dataLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - * currentData < host -> receivedData || - * currentData > & host -> receivedData [host -> receivedDataLength]) - return -1; - - packet = enet_packet_create ((const enet_uint8 *) command + sizeof (ENetProtocolSendUnreliable), - dataLength, - 0); - if (packet == NULL || - enet_peer_queue_incoming_command (peer, command, packet, 0) == NULL) - return -1; - - return 0; -} - -static int -enet_protocol_handle_send_fragment (ENetHost * host, ENetPeer * peer, const ENetProtocol * command, enet_uint8 ** currentData) -{ - enet_uint32 fragmentNumber, - fragmentCount, - fragmentOffset, - fragmentLength, - startSequenceNumber, - totalLength; - ENetChannel * channel; - enet_uint16 startWindow, currentWindow; - ENetListIterator currentCommand; - ENetIncomingCommand * startCommand = NULL; - - if (command -> header.channelID >= peer -> channelCount || - (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)) - return -1; - - fragmentLength = ENET_NET_TO_HOST_16 (command -> sendFragment.dataLength); - * currentData += fragmentLength; - if (fragmentLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - * currentData < host -> receivedData || - * currentData > & host -> receivedData [host -> receivedDataLength]) - return -1; - - channel = & peer -> channels [command -> header.channelID]; - startSequenceNumber = ENET_NET_TO_HOST_16 (command -> sendFragment.startSequenceNumber); - startWindow = startSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - - if (startSequenceNumber < channel -> incomingReliableSequenceNumber) - startWindow += ENET_PEER_RELIABLE_WINDOWS; - - if (startWindow < currentWindow || startWindow >= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1) - return 0; - - fragmentNumber = ENET_NET_TO_HOST_32 (command -> sendFragment.fragmentNumber); - fragmentCount = ENET_NET_TO_HOST_32 (command -> sendFragment.fragmentCount); - fragmentOffset = ENET_NET_TO_HOST_32 (command -> sendFragment.fragmentOffset); - totalLength = ENET_NET_TO_HOST_32 (command -> sendFragment.totalLength); - - if (fragmentCount > ENET_PROTOCOL_MAXIMUM_FRAGMENT_COUNT || - fragmentNumber >= fragmentCount || - totalLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - fragmentOffset >= totalLength || - fragmentLength > totalLength - fragmentOffset) - return -1; - - for (currentCommand = enet_list_previous (enet_list_end (& channel -> incomingReliableCommands)); - currentCommand != enet_list_end (& channel -> incomingReliableCommands); - currentCommand = enet_list_previous (currentCommand)) - { - ENetIncomingCommand * incomingCommand = (ENetIncomingCommand *) currentCommand; - - if (startSequenceNumber >= channel -> incomingReliableSequenceNumber) - { - if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - continue; - } - else - if (incomingCommand -> reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - break; - - if (incomingCommand -> reliableSequenceNumber <= startSequenceNumber) - { - if (incomingCommand -> reliableSequenceNumber < startSequenceNumber) - break; - - if ((incomingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) != ENET_PROTOCOL_COMMAND_SEND_FRAGMENT || - totalLength != incomingCommand -> packet -> dataLength || - fragmentCount != incomingCommand -> fragmentCount) - return -1; - - startCommand = incomingCommand; - break; - } - } - - if (startCommand == NULL) - { - ENetProtocol hostCommand = * command; - ENetPacket * packet = enet_packet_create (NULL, totalLength, ENET_PACKET_FLAG_RELIABLE); - if (packet == NULL) - return -1; - - hostCommand.header.reliableSequenceNumber = startSequenceNumber; - - startCommand = enet_peer_queue_incoming_command (peer, & hostCommand, packet, fragmentCount); - if (startCommand == NULL) - return -1; - } - - if ((startCommand -> fragments [fragmentNumber / 32] & (1 << (fragmentNumber % 32))) == 0) - { - -- startCommand -> fragmentsRemaining; - - startCommand -> fragments [fragmentNumber / 32] |= (1 << (fragmentNumber % 32)); - - if (fragmentOffset + fragmentLength > startCommand -> packet -> dataLength) - fragmentLength = startCommand -> packet -> dataLength - fragmentOffset; - - memcpy (startCommand -> packet -> data + fragmentOffset, - (enet_uint8 *) command + sizeof (ENetProtocolSendFragment), - fragmentLength); - - if (startCommand -> fragmentsRemaining <= 0) - enet_peer_dispatch_incoming_reliable_commands (peer, channel); - } - - return 0; -} - -static int -enet_protocol_handle_send_unreliable_fragment (ENetHost * host, ENetPeer * peer, const ENetProtocol * command, enet_uint8 ** currentData) -{ - enet_uint32 fragmentNumber, - fragmentCount, - fragmentOffset, - fragmentLength, - reliableSequenceNumber, - startSequenceNumber, - totalLength; - enet_uint16 reliableWindow, currentWindow; - ENetChannel * channel; - ENetListIterator currentCommand; - ENetIncomingCommand * startCommand = NULL; - - if (command -> header.channelID >= peer -> channelCount || - (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)) - return -1; - - fragmentLength = ENET_NET_TO_HOST_16 (command -> sendFragment.dataLength); - * currentData += fragmentLength; - if (fragmentLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - * currentData < host -> receivedData || - * currentData > & host -> receivedData [host -> receivedDataLength]) - return -1; - - channel = & peer -> channels [command -> header.channelID]; - reliableSequenceNumber = command -> header.reliableSequenceNumber; - startSequenceNumber = ENET_NET_TO_HOST_16 (command -> sendFragment.startSequenceNumber); - - reliableWindow = reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - - if (reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - reliableWindow += ENET_PEER_RELIABLE_WINDOWS; - - if (reliableWindow < currentWindow || reliableWindow >= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1) - return 0; - - if (reliableSequenceNumber == channel -> incomingReliableSequenceNumber && - startSequenceNumber <= channel -> incomingUnreliableSequenceNumber) - return 0; - - fragmentNumber = ENET_NET_TO_HOST_32 (command -> sendFragment.fragmentNumber); - fragmentCount = ENET_NET_TO_HOST_32 (command -> sendFragment.fragmentCount); - fragmentOffset = ENET_NET_TO_HOST_32 (command -> sendFragment.fragmentOffset); - totalLength = ENET_NET_TO_HOST_32 (command -> sendFragment.totalLength); - - if (fragmentCount > ENET_PROTOCOL_MAXIMUM_FRAGMENT_COUNT || - fragmentNumber >= fragmentCount || - totalLength > ENET_PROTOCOL_MAXIMUM_PACKET_SIZE || - fragmentOffset >= totalLength || - fragmentLength > totalLength - fragmentOffset) - return -1; - - for (currentCommand = enet_list_previous (enet_list_end (& channel -> incomingUnreliableCommands)); - currentCommand != enet_list_end (& channel -> incomingUnreliableCommands); - currentCommand = enet_list_previous (currentCommand)) - { - ENetIncomingCommand * incomingCommand = (ENetIncomingCommand *) currentCommand; - - if (reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - { - if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber) - continue; - } - else - if (incomingCommand -> reliableSequenceNumber >= channel -> incomingReliableSequenceNumber) - break; - - if (incomingCommand -> reliableSequenceNumber < reliableSequenceNumber) - break; - - if (incomingCommand -> reliableSequenceNumber > reliableSequenceNumber) - continue; - - if (incomingCommand -> unreliableSequenceNumber <= startSequenceNumber) - { - if (incomingCommand -> unreliableSequenceNumber < startSequenceNumber) - break; - - if ((incomingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) != ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE_FRAGMENT || - totalLength != incomingCommand -> packet -> dataLength || - fragmentCount != incomingCommand -> fragmentCount) - return -1; - - startCommand = incomingCommand; - break; - } - } - - if (startCommand == NULL) - { - ENetPacket * packet = enet_packet_create (NULL, totalLength, ENET_PACKET_FLAG_UNRELIABLE_FRAGMENT); - if (packet == NULL) - return -1; - - startCommand = enet_peer_queue_incoming_command (peer, command, packet, fragmentCount); - if (startCommand == NULL) - return -1; - } - - if ((startCommand -> fragments [fragmentNumber / 32] & (1 << (fragmentNumber % 32))) == 0) - { - -- startCommand -> fragmentsRemaining; - - startCommand -> fragments [fragmentNumber / 32] |= (1 << (fragmentNumber % 32)); - - if (fragmentOffset + fragmentLength > startCommand -> packet -> dataLength) - fragmentLength = startCommand -> packet -> dataLength - fragmentOffset; - - memcpy (startCommand -> packet -> data + fragmentOffset, - (enet_uint8 *) command + sizeof (ENetProtocolSendFragment), - fragmentLength); - - if (startCommand -> fragmentsRemaining <= 0) - enet_peer_dispatch_incoming_unreliable_commands (peer, channel); - } - - return 0; -} - -static int -enet_protocol_handle_ping (ENetHost * host, ENetPeer * peer, const ENetProtocol * command) -{ - if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) - return -1; - - return 0; -} - -static int -enet_protocol_handle_bandwidth_limit (ENetHost * host, ENetPeer * peer, const ENetProtocol * command) -{ - if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) - return -1; - - peer -> incomingBandwidth = ENET_NET_TO_HOST_32 (command -> bandwidthLimit.incomingBandwidth); - peer -> outgoingBandwidth = ENET_NET_TO_HOST_32 (command -> bandwidthLimit.outgoingBandwidth); - - if (peer -> incomingBandwidth == 0 && host -> outgoingBandwidth == 0) - peer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - else - peer -> windowSize = (ENET_MIN (peer -> incomingBandwidth, host -> outgoingBandwidth) / - ENET_PEER_WINDOW_SIZE_SCALE) * ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - - if (peer -> windowSize < ENET_PROTOCOL_MINIMUM_WINDOW_SIZE) - peer -> windowSize = ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - else - if (peer -> windowSize > ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE) - peer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - - return 0; -} - -static int -enet_protocol_handle_throttle_configure (ENetHost * host, ENetPeer * peer, const ENetProtocol * command) -{ - if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) - return -1; - - peer -> packetThrottleInterval = ENET_NET_TO_HOST_32 (command -> throttleConfigure.packetThrottleInterval); - peer -> packetThrottleAcceleration = ENET_NET_TO_HOST_32 (command -> throttleConfigure.packetThrottleAcceleration); - peer -> packetThrottleDeceleration = ENET_NET_TO_HOST_32 (command -> throttleConfigure.packetThrottleDeceleration); - - return 0; -} - -static int -enet_protocol_handle_disconnect (ENetHost * host, ENetPeer * peer, const ENetProtocol * command) -{ - if (peer -> state == ENET_PEER_STATE_DISCONNECTED || peer -> state == ENET_PEER_STATE_ZOMBIE || peer -> state == ENET_PEER_STATE_ACKNOWLEDGING_DISCONNECT) - return 0; - - enet_peer_reset_queues (peer); - - if (peer -> state == ENET_PEER_STATE_CONNECTION_SUCCEEDED || peer -> state == ENET_PEER_STATE_DISCONNECTING) - enet_protocol_dispatch_state (host, peer, ENET_PEER_STATE_ZOMBIE); - else - if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) - { - if (peer -> state == ENET_PEER_STATE_CONNECTION_PENDING) host -> recalculateBandwidthLimits = 1; - - enet_peer_reset (peer); - } - else - if (command -> header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE) - peer -> state = ENET_PEER_STATE_ACKNOWLEDGING_DISCONNECT; - else - enet_protocol_dispatch_state (host, peer, ENET_PEER_STATE_ZOMBIE); - - if (peer -> state != ENET_PEER_STATE_DISCONNECTED) - peer -> eventData = ENET_NET_TO_HOST_32 (command -> disconnect.data); - - return 0; -} - -static int -enet_protocol_handle_acknowledge (ENetHost * host, ENetEvent * event, ENetPeer * peer, const ENetProtocol * command) -{ - enet_uint32 roundTripTime, - receivedSentTime, - receivedReliableSequenceNumber; - ENetProtocolCommand commandNumber; - - if (peer -> state == ENET_PEER_STATE_DISCONNECTED || peer -> state == ENET_PEER_STATE_ZOMBIE) - return 0; - - receivedSentTime = ENET_NET_TO_HOST_16 (command -> acknowledge.receivedSentTime); - receivedSentTime |= host -> serviceTime & 0xFFFF0000; - if ((receivedSentTime & 0x8000) > (host -> serviceTime & 0x8000)) - receivedSentTime -= 0x10000; - - if (ENET_TIME_LESS (host -> serviceTime, receivedSentTime)) - return 0; - - peer -> lastReceiveTime = host -> serviceTime; - peer -> earliestTimeout = 0; - - roundTripTime = ENET_TIME_DIFFERENCE (host -> serviceTime, receivedSentTime); - - enet_peer_throttle (peer, roundTripTime); - - peer -> roundTripTimeVariance -= peer -> roundTripTimeVariance / 4; - - if (roundTripTime >= peer -> roundTripTime) - { - peer -> roundTripTime += (roundTripTime - peer -> roundTripTime) / 8; - peer -> roundTripTimeVariance += (roundTripTime - peer -> roundTripTime) / 4; - } - else - { - peer -> roundTripTime -= (peer -> roundTripTime - roundTripTime) / 8; - peer -> roundTripTimeVariance += (peer -> roundTripTime - roundTripTime) / 4; - } - - if (peer -> roundTripTime < peer -> lowestRoundTripTime) - peer -> lowestRoundTripTime = peer -> roundTripTime; - - if (peer -> roundTripTimeVariance > peer -> highestRoundTripTimeVariance) - peer -> highestRoundTripTimeVariance = peer -> roundTripTimeVariance; - - if (peer -> packetThrottleEpoch == 0 || - ENET_TIME_DIFFERENCE (host -> serviceTime, peer -> packetThrottleEpoch) >= peer -> packetThrottleInterval) - { - peer -> lastRoundTripTime = peer -> lowestRoundTripTime; - peer -> lastRoundTripTimeVariance = peer -> highestRoundTripTimeVariance; - peer -> lowestRoundTripTime = peer -> roundTripTime; - peer -> highestRoundTripTimeVariance = peer -> roundTripTimeVariance; - peer -> packetThrottleEpoch = host -> serviceTime; - } - - receivedReliableSequenceNumber = ENET_NET_TO_HOST_16 (command -> acknowledge.receivedReliableSequenceNumber); - - commandNumber = enet_protocol_remove_sent_reliable_command (peer, receivedReliableSequenceNumber, command -> header.channelID); - - switch (peer -> state) - { - case ENET_PEER_STATE_ACKNOWLEDGING_CONNECT: - if (commandNumber != ENET_PROTOCOL_COMMAND_VERIFY_CONNECT) - return -1; - - enet_protocol_notify_connect (host, peer, event); - break; - - case ENET_PEER_STATE_DISCONNECTING: - if (commandNumber != ENET_PROTOCOL_COMMAND_DISCONNECT) - return -1; - - enet_protocol_notify_disconnect (host, peer, event); - break; - - case ENET_PEER_STATE_DISCONNECT_LATER: - if (enet_list_empty (& peer -> outgoingReliableCommands) && - enet_list_empty (& peer -> outgoingUnreliableCommands) && - enet_list_empty (& peer -> sentReliableCommands)) - enet_peer_disconnect (peer, peer -> eventData); - break; - - default: - break; - } - - return 0; -} - -static int -enet_protocol_handle_verify_connect (ENetHost * host, ENetEvent * event, ENetPeer * peer, const ENetProtocol * command) -{ - enet_uint32 mtu, windowSize; - size_t channelCount; - - if (peer -> state != ENET_PEER_STATE_CONNECTING) - return 0; - - channelCount = ENET_NET_TO_HOST_32 (command -> verifyConnect.channelCount); - - if (channelCount < ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT || channelCount > ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT || - ENET_NET_TO_HOST_32 (command -> verifyConnect.packetThrottleInterval) != peer -> packetThrottleInterval || - ENET_NET_TO_HOST_32 (command -> verifyConnect.packetThrottleAcceleration) != peer -> packetThrottleAcceleration || - ENET_NET_TO_HOST_32 (command -> verifyConnect.packetThrottleDeceleration) != peer -> packetThrottleDeceleration || - command -> verifyConnect.connectID != peer -> connectID) - { - peer -> eventData = 0; - - enet_protocol_dispatch_state (host, peer, ENET_PEER_STATE_ZOMBIE); - - return -1; - } - - enet_protocol_remove_sent_reliable_command (peer, 1, 0xFF); - - if (channelCount < peer -> channelCount) - peer -> channelCount = channelCount; - - peer -> outgoingPeerID = ENET_NET_TO_HOST_16 (command -> verifyConnect.outgoingPeerID); - peer -> incomingSessionID = command -> verifyConnect.incomingSessionID; - peer -> outgoingSessionID = command -> verifyConnect.outgoingSessionID; - - mtu = ENET_NET_TO_HOST_32 (command -> verifyConnect.mtu); - - if (mtu < ENET_PROTOCOL_MINIMUM_MTU) - mtu = ENET_PROTOCOL_MINIMUM_MTU; - else - if (mtu > ENET_PROTOCOL_MAXIMUM_MTU) - mtu = ENET_PROTOCOL_MAXIMUM_MTU; - - if (mtu < peer -> mtu) - peer -> mtu = mtu; - - windowSize = ENET_NET_TO_HOST_32 (command -> verifyConnect.windowSize); - - if (windowSize < ENET_PROTOCOL_MINIMUM_WINDOW_SIZE) - windowSize = ENET_PROTOCOL_MINIMUM_WINDOW_SIZE; - - if (windowSize > ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE) - windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE; - - if (windowSize < peer -> windowSize) - peer -> windowSize = windowSize; - - peer -> incomingBandwidth = ENET_NET_TO_HOST_32 (command -> verifyConnect.incomingBandwidth); - peer -> outgoingBandwidth = ENET_NET_TO_HOST_32 (command -> verifyConnect.outgoingBandwidth); - - enet_protocol_notify_connect (host, peer, event); - return 0; -} - -static int -enet_protocol_handle_incoming_commands (ENetHost * host, ENetEvent * event) -{ - ENetProtocolHeader * header; - ENetProtocol * command; - ENetPeer * peer; - enet_uint8 * currentData; - size_t headerSize; - enet_uint16 peerID, flags; - enet_uint8 sessionID; - - if (host -> receivedDataLength < (size_t) & ((ENetProtocolHeader *) 0) -> sentTime) - return 0; - - header = (ENetProtocolHeader *) host -> receivedData; - - peerID = ENET_NET_TO_HOST_16 (header -> peerID); - sessionID = (peerID & ENET_PROTOCOL_HEADER_SESSION_MASK) >> ENET_PROTOCOL_HEADER_SESSION_SHIFT; - flags = peerID & ENET_PROTOCOL_HEADER_FLAG_MASK; - peerID &= ~ (ENET_PROTOCOL_HEADER_FLAG_MASK | ENET_PROTOCOL_HEADER_SESSION_MASK); - - headerSize = (flags & ENET_PROTOCOL_HEADER_FLAG_SENT_TIME ? sizeof (ENetProtocolHeader) : (size_t) & ((ENetProtocolHeader *) 0) -> sentTime); - if (host -> checksum != NULL) - headerSize += sizeof (enet_uint32); - - if (peerID == ENET_PROTOCOL_MAXIMUM_PEER_ID) - peer = NULL; - else - if (peerID >= host -> peerCount) - return 0; - else - { - peer = & host -> peers [peerID]; - - if (peer -> state == ENET_PEER_STATE_DISCONNECTED || - peer -> state == ENET_PEER_STATE_ZOMBIE || - ((host -> receivedAddress.host != peer -> address.host || - host -> receivedAddress.port != peer -> address.port) && - peer -> address.host != ENET_HOST_BROADCAST) || - (peer -> outgoingPeerID < ENET_PROTOCOL_MAXIMUM_PEER_ID && - sessionID != peer -> incomingSessionID)) - return 0; - } - - if (flags & ENET_PROTOCOL_HEADER_FLAG_COMPRESSED) - { - size_t originalSize; - if (host -> compressor.context == NULL || host -> compressor.decompress == NULL) - return 0; - - originalSize = host -> compressor.decompress (host -> compressor.context, - host -> receivedData + headerSize, - host -> receivedDataLength - headerSize, - host -> packetData [1] + headerSize, - sizeof (host -> packetData [1]) - headerSize); - if (originalSize <= 0 || originalSize > sizeof (host -> packetData [1]) - headerSize) - return 0; - - memcpy (host -> packetData [1], header, headerSize); - host -> receivedData = host -> packetData [1]; - host -> receivedDataLength = headerSize + originalSize; - } - - if (host -> checksum != NULL) - { - enet_uint32 * checksum = (enet_uint32 *) & host -> receivedData [headerSize - sizeof (enet_uint32)], - desiredChecksum = * checksum; - ENetBuffer buffer; - - * checksum = peer != NULL ? peer -> connectID : 0; - - buffer.data = host -> receivedData; - buffer.dataLength = host -> receivedDataLength; - - if (host -> checksum (& buffer, 1) != desiredChecksum) - return 0; - } - - if (peer != NULL) - { - peer -> address.host = host -> receivedAddress.host; - peer -> address.port = host -> receivedAddress.port; - peer -> incomingDataTotal += host -> receivedDataLength; - } - - currentData = host -> receivedData + headerSize; - - while (currentData < & host -> receivedData [host -> receivedDataLength]) - { - enet_uint8 commandNumber; - size_t commandSize; - - command = (ENetProtocol *) currentData; - - if (currentData + sizeof (ENetProtocolCommandHeader) > & host -> receivedData [host -> receivedDataLength]) - break; - - commandNumber = command -> header.command & ENET_PROTOCOL_COMMAND_MASK; - if (commandNumber >= ENET_PROTOCOL_COMMAND_COUNT) - break; - - commandSize = commandSizes [commandNumber]; - if (commandSize == 0 || currentData + commandSize > & host -> receivedData [host -> receivedDataLength]) - break; - - currentData += commandSize; - - if (peer == NULL && commandNumber != ENET_PROTOCOL_COMMAND_CONNECT) - break; - - command -> header.reliableSequenceNumber = ENET_NET_TO_HOST_16 (command -> header.reliableSequenceNumber); - - switch (commandNumber) - { - case ENET_PROTOCOL_COMMAND_ACKNOWLEDGE: - if (enet_protocol_handle_acknowledge (host, event, peer, command)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_CONNECT: - if (peer != NULL) - goto commandError; - peer = enet_protocol_handle_connect (host, header, command); - if (peer == NULL) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_VERIFY_CONNECT: - if (enet_protocol_handle_verify_connect (host, event, peer, command)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_DISCONNECT: - if (enet_protocol_handle_disconnect (host, peer, command)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_PING: - if (enet_protocol_handle_ping (host, peer, command)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_SEND_RELIABLE: - if (enet_protocol_handle_send_reliable (host, peer, command, & currentData)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE: - if (enet_protocol_handle_send_unreliable (host, peer, command, & currentData)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED: - if (enet_protocol_handle_send_unsequenced (host, peer, command, & currentData)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_SEND_FRAGMENT: - if (enet_protocol_handle_send_fragment (host, peer, command, & currentData)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_BANDWIDTH_LIMIT: - if (enet_protocol_handle_bandwidth_limit (host, peer, command)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_THROTTLE_CONFIGURE: - if (enet_protocol_handle_throttle_configure (host, peer, command)) - goto commandError; - break; - - case ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE_FRAGMENT: - if (enet_protocol_handle_send_unreliable_fragment (host, peer, command, & currentData)) - goto commandError; - break; - - default: - goto commandError; - } - - if (peer != NULL && - (command -> header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE) != 0) - { - enet_uint16 sentTime; - - if (! (flags & ENET_PROTOCOL_HEADER_FLAG_SENT_TIME)) - break; - - sentTime = ENET_NET_TO_HOST_16 (header -> sentTime); - - switch (peer -> state) - { - case ENET_PEER_STATE_DISCONNECTING: - case ENET_PEER_STATE_ACKNOWLEDGING_CONNECT: - case ENET_PEER_STATE_DISCONNECTED: - case ENET_PEER_STATE_ZOMBIE: - break; - - case ENET_PEER_STATE_ACKNOWLEDGING_DISCONNECT: - if ((command -> header.command & ENET_PROTOCOL_COMMAND_MASK) == ENET_PROTOCOL_COMMAND_DISCONNECT) - enet_peer_queue_acknowledgement (peer, command, sentTime); - break; - - default: - enet_peer_queue_acknowledgement (peer, command, sentTime); - break; - } - } - } - -commandError: - if (event != NULL && event -> type != ENET_EVENT_TYPE_NONE) - return 1; - - return 0; -} - -static int -enet_protocol_receive_incoming_commands (ENetHost * host, ENetEvent * event) -{ - for (;;) - { - int receivedLength; - ENetBuffer buffer; - - buffer.data = host -> packetData [0]; - buffer.dataLength = sizeof (host -> packetData [0]); - - receivedLength = enet_socket_receive (host -> socket, - & host -> receivedAddress, - & buffer, - 1); - - if (receivedLength < 0) - return -1; - - if (receivedLength == 0) - return 0; - - host -> receivedData = host -> packetData [0]; - host -> receivedDataLength = receivedLength; - - host -> totalReceivedData += receivedLength; - host -> totalReceivedPackets ++; - - if (host -> intercept != NULL) - { - switch (host -> intercept (host, event)) - { - case 1: - if (event != NULL && event -> type != ENET_EVENT_TYPE_NONE) - return 1; - - continue; - - case -1: - return -1; - - default: - break; - } - } - - switch (enet_protocol_handle_incoming_commands (host, event)) - { - case 1: - return 1; - - case -1: - return -1; - - default: - break; - } - } - - return -1; -} - -static void -enet_protocol_send_acknowledgements (ENetHost * host, ENetPeer * peer) -{ - ENetProtocol * command = & host -> commands [host -> commandCount]; - ENetBuffer * buffer = & host -> buffers [host -> bufferCount]; - ENetAcknowledgement * acknowledgement; - ENetListIterator currentAcknowledgement; - - currentAcknowledgement = enet_list_begin (& peer -> acknowledgements); - - while (currentAcknowledgement != enet_list_end (& peer -> acknowledgements)) - { - if (command >= & host -> commands [sizeof (host -> commands) / sizeof (ENetProtocol)] || - buffer >= & host -> buffers [sizeof (host -> buffers) / sizeof (ENetBuffer)] || - peer -> mtu - host -> packetSize < sizeof (ENetProtocolAcknowledge)) - { - host -> continueSending = 1; - - break; - } - - acknowledgement = (ENetAcknowledgement *) currentAcknowledgement; - - currentAcknowledgement = enet_list_next (currentAcknowledgement); - - buffer -> data = command; - buffer -> dataLength = sizeof (ENetProtocolAcknowledge); - - host -> packetSize += buffer -> dataLength; - - command -> header.command = ENET_PROTOCOL_COMMAND_ACKNOWLEDGE; - command -> header.channelID = acknowledgement -> command.header.channelID; - command -> acknowledge.receivedReliableSequenceNumber = ENET_HOST_TO_NET_16 (acknowledgement -> command.header.reliableSequenceNumber); - command -> acknowledge.receivedSentTime = ENET_HOST_TO_NET_16 (acknowledgement -> sentTime); - - if ((acknowledgement -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) == ENET_PROTOCOL_COMMAND_DISCONNECT) - enet_protocol_dispatch_state (host, peer, ENET_PEER_STATE_ZOMBIE); - - enet_list_remove (& acknowledgement -> acknowledgementList); - enet_free (acknowledgement); - - ++ command; - ++ buffer; - } - - host -> commandCount = command - host -> commands; - host -> bufferCount = buffer - host -> buffers; -} - -static void -enet_protocol_send_unreliable_outgoing_commands (ENetHost * host, ENetPeer * peer) -{ - ENetProtocol * command = & host -> commands [host -> commandCount]; - ENetBuffer * buffer = & host -> buffers [host -> bufferCount]; - ENetOutgoingCommand * outgoingCommand; - ENetListIterator currentCommand; - - currentCommand = enet_list_begin (& peer -> outgoingUnreliableCommands); - - while (currentCommand != enet_list_end (& peer -> outgoingUnreliableCommands)) - { - size_t commandSize; - - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - commandSize = commandSizes [outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK]; - - if (command >= & host -> commands [sizeof (host -> commands) / sizeof (ENetProtocol)] || - buffer + 1 >= & host -> buffers [sizeof (host -> buffers) / sizeof (ENetBuffer)] || - peer -> mtu - host -> packetSize < commandSize || - (outgoingCommand -> packet != NULL && - peer -> mtu - host -> packetSize < commandSize + outgoingCommand -> fragmentLength)) - { - host -> continueSending = 1; - - break; - } - - currentCommand = enet_list_next (currentCommand); - - if (outgoingCommand -> packet != NULL && outgoingCommand -> fragmentOffset == 0) - { - peer -> packetThrottleCounter += ENET_PEER_PACKET_THROTTLE_COUNTER; - peer -> packetThrottleCounter %= ENET_PEER_PACKET_THROTTLE_SCALE; - - if (peer -> packetThrottleCounter > peer -> packetThrottle) - { - enet_uint16 reliableSequenceNumber = outgoingCommand -> reliableSequenceNumber, - unreliableSequenceNumber = outgoingCommand -> unreliableSequenceNumber; - for (;;) - { - -- outgoingCommand -> packet -> referenceCount; - - if (outgoingCommand -> packet -> referenceCount == 0) - enet_packet_destroy (outgoingCommand -> packet); - - enet_list_remove (& outgoingCommand -> outgoingCommandList); - enet_free (outgoingCommand); - - if (currentCommand == enet_list_end (& peer -> outgoingUnreliableCommands)) - break; - - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - if (outgoingCommand -> reliableSequenceNumber != reliableSequenceNumber || - outgoingCommand -> unreliableSequenceNumber != unreliableSequenceNumber) - break; - - currentCommand = enet_list_next (currentCommand); - } - - continue; - } - } - - buffer -> data = command; - buffer -> dataLength = commandSize; - - host -> packetSize += buffer -> dataLength; - - * command = outgoingCommand -> command; - - enet_list_remove (& outgoingCommand -> outgoingCommandList); - - if (outgoingCommand -> packet != NULL) - { - ++ buffer; - - buffer -> data = outgoingCommand -> packet -> data + outgoingCommand -> fragmentOffset; - buffer -> dataLength = outgoingCommand -> fragmentLength; - - host -> packetSize += buffer -> dataLength; - - enet_list_insert (enet_list_end (& peer -> sentUnreliableCommands), outgoingCommand); - } - else - enet_free (outgoingCommand); - - ++ command; - ++ buffer; - } - - host -> commandCount = command - host -> commands; - host -> bufferCount = buffer - host -> buffers; - - if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER && - enet_list_empty (& peer -> outgoingReliableCommands) && - enet_list_empty (& peer -> outgoingUnreliableCommands) && - enet_list_empty (& peer -> sentReliableCommands)) - enet_peer_disconnect (peer, peer -> eventData); -} - -static int -enet_protocol_check_timeouts (ENetHost * host, ENetPeer * peer, ENetEvent * event) -{ - ENetOutgoingCommand * outgoingCommand; - ENetListIterator currentCommand, insertPosition; - - currentCommand = enet_list_begin (& peer -> sentReliableCommands); - insertPosition = enet_list_begin (& peer -> outgoingReliableCommands); - - while (currentCommand != enet_list_end (& peer -> sentReliableCommands)) - { - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - - currentCommand = enet_list_next (currentCommand); - - if (ENET_TIME_DIFFERENCE (host -> serviceTime, outgoingCommand -> sentTime) < outgoingCommand -> roundTripTimeout) - continue; - - if (peer -> earliestTimeout == 0 || - ENET_TIME_LESS (outgoingCommand -> sentTime, peer -> earliestTimeout)) - peer -> earliestTimeout = outgoingCommand -> sentTime; - - if (peer -> earliestTimeout != 0 && - (ENET_TIME_DIFFERENCE (host -> serviceTime, peer -> earliestTimeout) >= peer -> timeoutMaximum || - (outgoingCommand -> roundTripTimeout >= outgoingCommand -> roundTripTimeoutLimit && - ENET_TIME_DIFFERENCE (host -> serviceTime, peer -> earliestTimeout) >= peer -> timeoutMinimum))) - { - enet_protocol_notify_disconnect (host, peer, event); - - return 1; - } - - if (outgoingCommand -> packet != NULL) - peer -> reliableDataInTransit -= outgoingCommand -> fragmentLength; - - ++ peer -> packetsLost; - - outgoingCommand -> roundTripTimeout *= 2; - - enet_list_insert (insertPosition, enet_list_remove (& outgoingCommand -> outgoingCommandList)); - - if (currentCommand == enet_list_begin (& peer -> sentReliableCommands) && - ! enet_list_empty (& peer -> sentReliableCommands)) - { - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - - peer -> nextTimeout = outgoingCommand -> sentTime + outgoingCommand -> roundTripTimeout; - } - } - - return 0; -} - -static int -enet_protocol_send_reliable_outgoing_commands (ENetHost * host, ENetPeer * peer) -{ - ENetProtocol * command = & host -> commands [host -> commandCount]; - ENetBuffer * buffer = & host -> buffers [host -> bufferCount]; - ENetOutgoingCommand * outgoingCommand; - ENetListIterator currentCommand; - ENetChannel *channel; - enet_uint16 reliableWindow; - size_t commandSize; - int windowExceeded = 0, windowWrap = 0, canPing = 1; - - currentCommand = enet_list_begin (& peer -> outgoingReliableCommands); - - while (currentCommand != enet_list_end (& peer -> outgoingReliableCommands)) - { - outgoingCommand = (ENetOutgoingCommand *) currentCommand; - - channel = outgoingCommand -> command.header.channelID < peer -> channelCount ? & peer -> channels [outgoingCommand -> command.header.channelID] : NULL; - reliableWindow = outgoingCommand -> reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE; - if (channel != NULL) - { - if (! windowWrap && - outgoingCommand -> sendAttempts < 1 && - ! (outgoingCommand -> reliableSequenceNumber % ENET_PEER_RELIABLE_WINDOW_SIZE) && - (channel -> reliableWindows [(reliableWindow + ENET_PEER_RELIABLE_WINDOWS - 1) % ENET_PEER_RELIABLE_WINDOWS] >= ENET_PEER_RELIABLE_WINDOW_SIZE || - channel -> usedReliableWindows & ((((1 << ENET_PEER_FREE_RELIABLE_WINDOWS) - 1) << reliableWindow) | - (((1 << ENET_PEER_FREE_RELIABLE_WINDOWS) - 1) >> (ENET_PEER_RELIABLE_WINDOW_SIZE - reliableWindow))))) - windowWrap = 1; - if (windowWrap) - { - currentCommand = enet_list_next (currentCommand); - - continue; - } - } - - if (outgoingCommand -> packet != NULL) - { - if (! windowExceeded) - { - enet_uint32 windowSize = (peer -> packetThrottle * peer -> windowSize) / ENET_PEER_PACKET_THROTTLE_SCALE; - - if (peer -> reliableDataInTransit + outgoingCommand -> fragmentLength > ENET_MAX (windowSize, peer -> mtu)) - windowExceeded = 1; - } - if (windowExceeded) - { - currentCommand = enet_list_next (currentCommand); - - continue; - } - } - - canPing = 0; - - commandSize = commandSizes [outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK]; - if (command >= & host -> commands [sizeof (host -> commands) / sizeof (ENetProtocol)] || - buffer + 1 >= & host -> buffers [sizeof (host -> buffers) / sizeof (ENetBuffer)] || - peer -> mtu - host -> packetSize < commandSize || - (outgoingCommand -> packet != NULL && - (enet_uint16) (peer -> mtu - host -> packetSize) < (enet_uint16) (commandSize + outgoingCommand -> fragmentLength))) - { - host -> continueSending = 1; - - break; - } - - currentCommand = enet_list_next (currentCommand); - - if (channel != NULL && outgoingCommand -> sendAttempts < 1) - { - channel -> usedReliableWindows |= 1 << reliableWindow; - ++ channel -> reliableWindows [reliableWindow]; - } - - ++ outgoingCommand -> sendAttempts; - - if (outgoingCommand -> roundTripTimeout == 0) - { - outgoingCommand -> roundTripTimeout = peer -> roundTripTime + 4 * peer -> roundTripTimeVariance; - outgoingCommand -> roundTripTimeoutLimit = peer -> timeoutLimit * outgoingCommand -> roundTripTimeout; - } - - if (enet_list_empty (& peer -> sentReliableCommands)) - peer -> nextTimeout = host -> serviceTime + outgoingCommand -> roundTripTimeout; - - enet_list_insert (enet_list_end (& peer -> sentReliableCommands), - enet_list_remove (& outgoingCommand -> outgoingCommandList)); - - outgoingCommand -> sentTime = host -> serviceTime; - - buffer -> data = command; - buffer -> dataLength = commandSize; - - host -> packetSize += buffer -> dataLength; - host -> headerFlags |= ENET_PROTOCOL_HEADER_FLAG_SENT_TIME; - - * command = outgoingCommand -> command; - - if (outgoingCommand -> packet != NULL) - { - ++ buffer; - - buffer -> data = outgoingCommand -> packet -> data + outgoingCommand -> fragmentOffset; - buffer -> dataLength = outgoingCommand -> fragmentLength; - - host -> packetSize += outgoingCommand -> fragmentLength; - - peer -> reliableDataInTransit += outgoingCommand -> fragmentLength; - } - - ++ peer -> packetsSent; - - ++ command; - ++ buffer; - } - - host -> commandCount = command - host -> commands; - host -> bufferCount = buffer - host -> buffers; - - return canPing; -} - -static int -enet_protocol_send_outgoing_commands (ENetHost * host, ENetEvent * event, int checkForTimeouts) -{ - enet_uint8 headerData [sizeof (ENetProtocolHeader) + sizeof (enet_uint32)]; - ENetProtocolHeader * header = (ENetProtocolHeader *) headerData; - ENetPeer * currentPeer; - int sentLength; - size_t shouldCompress = 0; - - host -> continueSending = 1; - - while (host -> continueSending) - for (host -> continueSending = 0, - currentPeer = host -> peers; - currentPeer < & host -> peers [host -> peerCount]; - ++ currentPeer) - { - if (currentPeer -> state == ENET_PEER_STATE_DISCONNECTED || - currentPeer -> state == ENET_PEER_STATE_ZOMBIE) - continue; - - host -> headerFlags = 0; - host -> commandCount = 0; - host -> bufferCount = 1; - host -> packetSize = sizeof (ENetProtocolHeader); - - if (! enet_list_empty (& currentPeer -> acknowledgements)) - enet_protocol_send_acknowledgements (host, currentPeer); - - if (checkForTimeouts != 0 && - ! enet_list_empty (& currentPeer -> sentReliableCommands) && - ENET_TIME_GREATER_EQUAL (host -> serviceTime, currentPeer -> nextTimeout) && - enet_protocol_check_timeouts (host, currentPeer, event) == 1) - { - if (event != NULL && event -> type != ENET_EVENT_TYPE_NONE) - return 1; - else - continue; - } - - if ((enet_list_empty (& currentPeer -> outgoingReliableCommands) || - enet_protocol_send_reliable_outgoing_commands (host, currentPeer)) && - enet_list_empty (& currentPeer -> sentReliableCommands) && - ENET_TIME_DIFFERENCE (host -> serviceTime, currentPeer -> lastReceiveTime) >= currentPeer -> pingInterval && - currentPeer -> mtu - host -> packetSize >= sizeof (ENetProtocolPing)) - { - enet_peer_ping (currentPeer); - enet_protocol_send_reliable_outgoing_commands (host, currentPeer); - } - - if (! enet_list_empty (& currentPeer -> outgoingUnreliableCommands)) - enet_protocol_send_unreliable_outgoing_commands (host, currentPeer); - - if (host -> commandCount == 0) - continue; - - if (currentPeer -> packetLossEpoch == 0) - currentPeer -> packetLossEpoch = host -> serviceTime; - else - if (ENET_TIME_DIFFERENCE (host -> serviceTime, currentPeer -> packetLossEpoch) >= ENET_PEER_PACKET_LOSS_INTERVAL && - currentPeer -> packetsSent > 0) - { - enet_uint32 packetLoss = currentPeer -> packetsLost * ENET_PEER_PACKET_LOSS_SCALE / currentPeer -> packetsSent; - -#ifdef ENET_DEBUG -#ifdef WIN32 - printf ( -#else - fprintf (stderr, -#endif - "peer %u: %f%%+-%f%% packet loss, %u+-%u ms round trip time, %f%% throttle, %u/%u outgoing, %u/%u incoming\n", currentPeer -> incomingPeerID, currentPeer -> packetLoss / (float) ENET_PEER_PACKET_LOSS_SCALE, currentPeer -> packetLossVariance / (float) ENET_PEER_PACKET_LOSS_SCALE, currentPeer -> roundTripTime, currentPeer -> roundTripTimeVariance, currentPeer -> packetThrottle / (float) ENET_PEER_PACKET_THROTTLE_SCALE, enet_list_size (& currentPeer -> outgoingReliableCommands), enet_list_size (& currentPeer -> outgoingUnreliableCommands), currentPeer -> channels != NULL ? enet_list_size (& currentPeer -> channels -> incomingReliableCommands) : 0, currentPeer -> channels != NULL ? enet_list_size (& currentPeer -> channels -> incomingUnreliableCommands) : 0); -#endif - - currentPeer -> packetLossVariance -= currentPeer -> packetLossVariance / 4; - - if (packetLoss >= currentPeer -> packetLoss) - { - currentPeer -> packetLoss += (packetLoss - currentPeer -> packetLoss) / 8; - currentPeer -> packetLossVariance += (packetLoss - currentPeer -> packetLoss) / 4; - } - else - { - currentPeer -> packetLoss -= (currentPeer -> packetLoss - packetLoss) / 8; - currentPeer -> packetLossVariance += (currentPeer -> packetLoss - packetLoss) / 4; - } - - currentPeer -> packetLossEpoch = host -> serviceTime; - currentPeer -> packetsSent = 0; - currentPeer -> packetsLost = 0; - } - - host -> buffers -> data = headerData; - if (host -> headerFlags & ENET_PROTOCOL_HEADER_FLAG_SENT_TIME) - { - header -> sentTime = ENET_HOST_TO_NET_16 (host -> serviceTime & 0xFFFF); - - host -> buffers -> dataLength = sizeof (ENetProtocolHeader); - } - else - host -> buffers -> dataLength = (size_t) & ((ENetProtocolHeader *) 0) -> sentTime; - - shouldCompress = 0; - if (host -> compressor.context != NULL && host -> compressor.compress != NULL) - { - size_t originalSize = host -> packetSize - sizeof(ENetProtocolHeader), - compressedSize = host -> compressor.compress (host -> compressor.context, - & host -> buffers [1], host -> bufferCount - 1, - originalSize, - host -> packetData [1], - originalSize); - if (compressedSize > 0 && compressedSize < originalSize) - { - host -> headerFlags |= ENET_PROTOCOL_HEADER_FLAG_COMPRESSED; - shouldCompress = compressedSize; -#ifdef ENET_DEBUG_COMPRESS -#ifdef WIN32 - printf ( -#else - fprintf (stderr, -#endif - "peer %u: compressed %u -> %u (%u%%)\n", currentPeer -> incomingPeerID, originalSize, compressedSize, (compressedSize * 100) / originalSize); -#endif - } - } - - if (currentPeer -> outgoingPeerID < ENET_PROTOCOL_MAXIMUM_PEER_ID) - host -> headerFlags |= currentPeer -> outgoingSessionID << ENET_PROTOCOL_HEADER_SESSION_SHIFT; - header -> peerID = ENET_HOST_TO_NET_16 (currentPeer -> outgoingPeerID | host -> headerFlags); - if (host -> checksum != NULL) - { - enet_uint32 * checksum = (enet_uint32 *) & headerData [host -> buffers -> dataLength]; - * checksum = currentPeer -> outgoingPeerID < ENET_PROTOCOL_MAXIMUM_PEER_ID ? currentPeer -> connectID : 0; - host -> buffers -> dataLength += sizeof (enet_uint32); - * checksum = host -> checksum (host -> buffers, host -> bufferCount); - } - - if (shouldCompress > 0) - { - host -> buffers [1].data = host -> packetData [1]; - host -> buffers [1].dataLength = shouldCompress; - host -> bufferCount = 2; - } - - currentPeer -> lastSendTime = host -> serviceTime; - - sentLength = enet_socket_send (host -> socket, & currentPeer -> address, host -> buffers, host -> bufferCount); - - enet_protocol_remove_sent_unreliable_commands (currentPeer); - - if (sentLength < 0) - return -1; - - host -> totalSentData += sentLength; - host -> totalSentPackets ++; - } - - return 0; -} - -/** Sends any queued packets on the host specified to its designated peers. - - @param host host to flush - @remarks this function need only be used in circumstances where one wishes to send queued packets earlier than in a call to enet_host_service(). - @ingroup host -*/ -void -enet_host_flush (ENetHost * host) -{ - host -> serviceTime = enet_time_get (); - - enet_protocol_send_outgoing_commands (host, NULL, 0); -} - -/** Checks for any queued events on the host and dispatches one if available. - - @param host host to check for events - @param event an event structure where event details will be placed if available - @retval > 0 if an event was dispatched - @retval 0 if no events are available - @retval < 0 on failure - @ingroup host -*/ -int -enet_host_check_events (ENetHost * host, ENetEvent * event) -{ - if (event == NULL) return -1; - - event -> type = ENET_EVENT_TYPE_NONE; - event -> peer = NULL; - event -> packet = NULL; - - return enet_protocol_dispatch_incoming_commands (host, event); -} - -/** Waits for events on the host specified and shuttles packets between - the host and its peers. - - @param host host to service - @param event an event structure where event details will be placed if one occurs - if event == NULL then no events will be delivered - @param timeout number of milliseconds that ENet should wait for events - @retval > 0 if an event occurred within the specified time limit - @retval 0 if no event occurred - @retval < 0 on failure - @remarks enet_host_service should be called fairly regularly for adequate performance - @ingroup host -*/ -int -enet_host_service (ENetHost * host, ENetEvent * event, enet_uint32 timeout) -{ - enet_uint32 waitCondition; - - if (event != NULL) - { - event -> type = ENET_EVENT_TYPE_NONE; - event -> peer = NULL; - event -> packet = NULL; - - switch (enet_protocol_dispatch_incoming_commands (host, event)) - { - case 1: - return 1; - - case -1: - perror ("Error dispatching incoming packets"); - - return -1; - - default: - break; - } - } - - host -> serviceTime = enet_time_get (); - - timeout += host -> serviceTime; - - do - { - if (ENET_TIME_DIFFERENCE (host -> serviceTime, host -> bandwidthThrottleEpoch) >= ENET_HOST_BANDWIDTH_THROTTLE_INTERVAL) - enet_host_bandwidth_throttle (host); - - switch (enet_protocol_send_outgoing_commands (host, event, 1)) - { - case 1: - return 1; - - case -1: - perror ("Error sending outgoing packets"); - - return -1; - - default: - break; - } - - switch (enet_protocol_receive_incoming_commands (host, event)) - { - case 1: - return 1; - - case -1: - perror ("Error receiving incoming packets"); - - return -1; - - default: - break; - } - - switch (enet_protocol_send_outgoing_commands (host, event, 1)) - { - case 1: - return 1; - - case -1: - perror ("Error sending outgoing packets"); - - return -1; - - default: - break; - } - - if (event != NULL) - { - switch (enet_protocol_dispatch_incoming_commands (host, event)) - { - case 1: - return 1; - - case -1: - perror ("Error dispatching incoming packets"); - - return -1; - - default: - break; - } - } - - host -> serviceTime = enet_time_get (); - - if (ENET_TIME_GREATER_EQUAL (host -> serviceTime, timeout)) - return 0; - - waitCondition = ENET_SOCKET_WAIT_RECEIVE; - - if (enet_socket_wait (host -> socket, & waitCondition, ENET_TIME_DIFFERENCE (timeout, host -> serviceTime)) != 0) - return -1; - - host -> serviceTime = enet_time_get (); - } while (waitCondition == ENET_SOCKET_WAIT_RECEIVE); - - return 0; -} - diff --git a/btgui/enet/unix.c b/btgui/enet/unix.c deleted file mode 100644 index d425b4b8a..000000000 --- a/btgui/enet/unix.c +++ /dev/null @@ -1,475 +0,0 @@ -/** - @file unix.c - @brief ENet Unix system specific functions -*/ -#ifndef WIN32 - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#define ENET_BUILDING_LIB 1 -#include "enet/enet.h" - -#ifdef __APPLE__ -#ifdef HAS_POLL -#undef HAS_POLL -#endif -#ifndef HAS_FCNTL -#define HAS_FCNTL 1 -#endif -#ifndef HAS_INET_PTON -#define HAS_INET_PTON 1 -#endif -#ifndef HAS_INET_NTOP -#define HAS_INET_NTOP 1 -#endif -#ifndef HAS_MSGHDR_FLAGS -#define HAS_MSGHDR_FLAGS 1 -#endif -#ifndef HAS_SOCKLEN_T -#define HAS_SOCKLEN_T 1 -#endif -#endif - -#ifdef HAS_FCNTL -#include -#endif - -#ifdef HAS_POLL -#include -#endif - -#ifndef HAS_SOCKLEN_T -typedef int socklen_t; -#endif - -#ifndef MSG_NOSIGNAL -#define MSG_NOSIGNAL 0 -#endif - -static enet_uint32 timeBase = 0; - -int -enet_initialize (void) -{ - return 0; -} - -void -enet_deinitialize (void) -{ -} - -enet_uint32 -enet_time_get (void) -{ - struct timeval timeVal; - - gettimeofday (& timeVal, NULL); - - return timeVal.tv_sec * 1000 + timeVal.tv_usec / 1000 - timeBase; -} - -void -enet_time_set (enet_uint32 newTimeBase) -{ - struct timeval timeVal; - - gettimeofday (& timeVal, NULL); - - timeBase = timeVal.tv_sec * 1000 + timeVal.tv_usec / 1000 - newTimeBase; -} - -int -enet_address_set_host (ENetAddress * address, const char * name) -{ - struct hostent * hostEntry = NULL; -#ifdef HAS_GETHOSTBYNAME_R - struct hostent hostData; - char buffer [2048]; - int errnum; - -#if defined(linux) || defined(__linux) || defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__) - gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum); -#else - hostEntry = gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & errnum); -#endif -#else - hostEntry = gethostbyname (name); -#endif - - if (hostEntry == NULL || - hostEntry -> h_addrtype != AF_INET) - { -#ifdef HAS_INET_PTON - if (! inet_pton (AF_INET, name, & address -> host)) -#else - if (! inet_aton (name, (struct in_addr *) & address -> host)) -#endif - return -1; - return 0; - } - - address -> host = * (enet_uint32 *) hostEntry -> h_addr_list [0]; - - return 0; -} - -int -enet_address_get_host_ip (const ENetAddress * address, char * name, size_t nameLength) -{ -#ifdef HAS_INET_NTOP - if (inet_ntop (AF_INET, & address -> host, name, nameLength) == NULL) -#else - char * addr = inet_ntoa (* (struct in_addr *) & address -> host); - if (addr != NULL) - strncpy (name, addr, nameLength); - else -#endif - return -1; - return 0; -} - -int -enet_address_get_host (const ENetAddress * address, char * name, size_t nameLength) -{ - struct in_addr in; - struct hostent * hostEntry = NULL; -#ifdef HAS_GETHOSTBYADDR_R - struct hostent hostData; - char buffer [2048]; - int errnum; - - in.s_addr = address -> host; - -#if defined(linux) || defined(__linux) || defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__) - gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum); -#else - hostEntry = gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & errnum); -#endif -#else - in.s_addr = address -> host; - - hostEntry = gethostbyaddr ((char *) & in, sizeof (struct in_addr), AF_INET); -#endif - - if (hostEntry == NULL) - return enet_address_get_host_ip (address, name, nameLength); - - strncpy (name, hostEntry -> h_name, nameLength); - - return 0; -} - -int -enet_socket_bind (ENetSocket socket, const ENetAddress * address) -{ - struct sockaddr_in sin; - - memset (& sin, 0, sizeof (struct sockaddr_in)); - - sin.sin_family = AF_INET; - - if (address != NULL) - { - sin.sin_port = ENET_HOST_TO_NET_16 (address -> port); - sin.sin_addr.s_addr = address -> host; - } - else - { - sin.sin_port = 0; - sin.sin_addr.s_addr = INADDR_ANY; - } - - return bind (socket, - (struct sockaddr *) & sin, - sizeof (struct sockaddr_in)); -} - -int -enet_socket_listen (ENetSocket socket, int backlog) -{ - return listen (socket, backlog < 0 ? SOMAXCONN : backlog); -} - -ENetSocket -enet_socket_create (ENetSocketType type) -{ - return socket (PF_INET, type == ENET_SOCKET_TYPE_DATAGRAM ? SOCK_DGRAM : SOCK_STREAM, 0); -} - -int -enet_socket_set_option (ENetSocket socket, ENetSocketOption option, int value) -{ - int result = -1; - switch (option) - { - case ENET_SOCKOPT_NONBLOCK: -#ifdef HAS_FCNTL - result = fcntl (socket, F_SETFL, O_NONBLOCK | fcntl (socket, F_GETFL)); -#else - result = ioctl (socket, FIONBIO, & value); -#endif - break; - - case ENET_SOCKOPT_BROADCAST: - result = setsockopt (socket, SOL_SOCKET, SO_BROADCAST, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_REUSEADDR: - result = setsockopt (socket, SOL_SOCKET, SO_REUSEADDR, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_RCVBUF: - result = setsockopt (socket, SOL_SOCKET, SO_RCVBUF, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_SNDBUF: - result = setsockopt (socket, SOL_SOCKET, SO_SNDBUF, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_RCVTIMEO: - result = setsockopt (socket, SOL_SOCKET, SO_RCVTIMEO, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_SNDTIMEO: - result = setsockopt (socket, SOL_SOCKET, SO_SNDTIMEO, (char *) & value, sizeof (int)); - break; - - default: - break; - } - return result == -1 ? -1 : 0; -} - -int -enet_socket_connect (ENetSocket socket, const ENetAddress * address) -{ - struct sockaddr_in sin; - int result; - - memset (& sin, 0, sizeof (struct sockaddr_in)); - - sin.sin_family = AF_INET; - sin.sin_port = ENET_HOST_TO_NET_16 (address -> port); - sin.sin_addr.s_addr = address -> host; - - result = connect (socket, (struct sockaddr *) & sin, sizeof (struct sockaddr_in)); - if (result == -1 && errno == EINPROGRESS) - return 0; - - return result; -} - -ENetSocket -enet_socket_accept (ENetSocket socket, ENetAddress * address) -{ - int result; - struct sockaddr_in sin; - socklen_t sinLength = sizeof (struct sockaddr_in); - - result = accept (socket, - address != NULL ? (struct sockaddr *) & sin : NULL, - address != NULL ? & sinLength : NULL); - - if (result == -1) - return ENET_SOCKET_NULL; - - if (address != NULL) - { - address -> host = (enet_uint32) sin.sin_addr.s_addr; - address -> port = ENET_NET_TO_HOST_16 (sin.sin_port); - } - - return result; -} - -int -enet_socket_shutdown (ENetSocket socket, ENetSocketShutdown how) -{ - return shutdown (socket, (int) how); -} - -void -enet_socket_destroy (ENetSocket socket) -{ - if (socket != -1) - close (socket); -} - -int -enet_socket_send (ENetSocket socket, - const ENetAddress * address, - const ENetBuffer * buffers, - size_t bufferCount) -{ - struct msghdr msgHdr; - struct sockaddr_in sin; - int sentLength; - - memset (& msgHdr, 0, sizeof (struct msghdr)); - - if (address != NULL) - { - memset (& sin, 0, sizeof (struct sockaddr_in)); - - sin.sin_family = AF_INET; - sin.sin_port = ENET_HOST_TO_NET_16 (address -> port); - sin.sin_addr.s_addr = address -> host; - - msgHdr.msg_name = & sin; - msgHdr.msg_namelen = sizeof (struct sockaddr_in); - } - - msgHdr.msg_iov = (struct iovec *) buffers; - msgHdr.msg_iovlen = bufferCount; - - sentLength = sendmsg (socket, & msgHdr, MSG_NOSIGNAL); - - if (sentLength == -1) - { - if (errno == EWOULDBLOCK) - return 0; - - return -1; - } - - return sentLength; -} - -int -enet_socket_receive (ENetSocket socket, - ENetAddress * address, - ENetBuffer * buffers, - size_t bufferCount) -{ - struct msghdr msgHdr; - struct sockaddr_in sin; - int recvLength; - - memset (& msgHdr, 0, sizeof (struct msghdr)); - - if (address != NULL) - { - msgHdr.msg_name = & sin; - msgHdr.msg_namelen = sizeof (struct sockaddr_in); - } - - msgHdr.msg_iov = (struct iovec *) buffers; - msgHdr.msg_iovlen = bufferCount; - - recvLength = recvmsg (socket, & msgHdr, MSG_NOSIGNAL); - - if (recvLength == -1) - { - if (errno == EWOULDBLOCK) - return 0; - - return -1; - } - -#ifdef HAS_MSGHDR_FLAGS - if (msgHdr.msg_flags & MSG_TRUNC) - return -1; -#endif - - if (address != NULL) - { - address -> host = (enet_uint32) sin.sin_addr.s_addr; - address -> port = ENET_NET_TO_HOST_16 (sin.sin_port); - } - - return recvLength; -} - -int -enet_socketset_select (ENetSocket maxSocket, ENetSocketSet * readSet, ENetSocketSet * writeSet, enet_uint32 timeout) -{ - struct timeval timeVal; - - timeVal.tv_sec = timeout / 1000; - timeVal.tv_usec = (timeout % 1000) * 1000; - - return select (maxSocket + 1, readSet, writeSet, NULL, & timeVal); -} - -int -enet_socket_wait (ENetSocket socket, enet_uint32 * condition, enet_uint32 timeout) -{ -#ifdef HAS_POLL - struct pollfd pollSocket; - int pollCount; - - pollSocket.fd = socket; - pollSocket.events = 0; - - if (* condition & ENET_SOCKET_WAIT_SEND) - pollSocket.events |= POLLOUT; - - if (* condition & ENET_SOCKET_WAIT_RECEIVE) - pollSocket.events |= POLLIN; - - pollCount = poll (& pollSocket, 1, timeout); - - if (pollCount < 0) - return -1; - - * condition = ENET_SOCKET_WAIT_NONE; - - if (pollCount == 0) - return 0; - - if (pollSocket.revents & POLLOUT) - * condition |= ENET_SOCKET_WAIT_SEND; - - if (pollSocket.revents & POLLIN) - * condition |= ENET_SOCKET_WAIT_RECEIVE; - - return 0; -#else - fd_set readSet, writeSet; - struct timeval timeVal; - int selectCount; - - timeVal.tv_sec = timeout / 1000; - timeVal.tv_usec = (timeout % 1000) * 1000; - - FD_ZERO (& readSet); - FD_ZERO (& writeSet); - - if (* condition & ENET_SOCKET_WAIT_SEND) - FD_SET (socket, & writeSet); - - if (* condition & ENET_SOCKET_WAIT_RECEIVE) - FD_SET (socket, & readSet); - - selectCount = select (socket + 1, & readSet, & writeSet, NULL, & timeVal); - - if (selectCount < 0) - return -1; - - * condition = ENET_SOCKET_WAIT_NONE; - - if (selectCount == 0) - return 0; - - if (FD_ISSET (socket, & writeSet)) - * condition |= ENET_SOCKET_WAIT_SEND; - - if (FD_ISSET (socket, & readSet)) - * condition |= ENET_SOCKET_WAIT_RECEIVE; - - return 0; -#endif -} - -#endif - diff --git a/btgui/enet/win32.c b/btgui/enet/win32.c deleted file mode 100644 index dcc0791bd..000000000 --- a/btgui/enet/win32.c +++ /dev/null @@ -1,368 +0,0 @@ -/** - @file win32.c - @brief ENet Win32 system specific functions -*/ -#ifdef WIN32 - -#include -#define ENET_BUILDING_LIB 1 -#include "enet/enet.h" - -static enet_uint32 timeBase = 0; - -int -enet_initialize (void) -{ - WORD versionRequested = MAKEWORD (1, 1); - WSADATA wsaData; - - if (WSAStartup (versionRequested, & wsaData)) - return -1; - - if (LOBYTE (wsaData.wVersion) != 1|| - HIBYTE (wsaData.wVersion) != 1) - { - WSACleanup (); - - return -1; - } - - timeBeginPeriod (1); - - return 0; -} - -void -enet_deinitialize (void) -{ - timeEndPeriod (1); - - WSACleanup (); -} - -enet_uint32 -enet_time_get (void) -{ - return (enet_uint32) timeGetTime () - timeBase; -} - -void -enet_time_set (enet_uint32 newTimeBase) -{ - timeBase = (enet_uint32) timeGetTime () - newTimeBase; -} - -int -enet_address_set_host (ENetAddress * address, const char * name) -{ - struct hostent * hostEntry; - - hostEntry = gethostbyname (name); - if (hostEntry == NULL || - hostEntry -> h_addrtype != AF_INET) - { - unsigned long host = inet_addr (name); - if (host == INADDR_NONE) - return -1; - address -> host = host; - return 0; - } - - address -> host = * (enet_uint32 *) hostEntry -> h_addr_list [0]; - - return 0; -} - -int -enet_address_get_host_ip (const ENetAddress * address, char * name, size_t nameLength) -{ - char * addr = inet_ntoa (* (struct in_addr *) & address -> host); - if (addr == NULL) - return -1; - strncpy (name, addr, nameLength); - return 0; -} - -int -enet_address_get_host (const ENetAddress * address, char * name, size_t nameLength) -{ - struct in_addr in; - struct hostent * hostEntry; - - in.s_addr = address -> host; - - hostEntry = gethostbyaddr ((char *) & in, sizeof (struct in_addr), AF_INET); - if (hostEntry == NULL) - return enet_address_get_host_ip (address, name, nameLength); - - strncpy (name, hostEntry -> h_name, nameLength); - - return 0; -} - -int -enet_socket_bind (ENetSocket socket, const ENetAddress * address) -{ - struct sockaddr_in sin; - - memset (& sin, 0, sizeof (struct sockaddr_in)); - - sin.sin_family = AF_INET; - - if (address != NULL) - { - sin.sin_port = ENET_HOST_TO_NET_16 (address -> port); - sin.sin_addr.s_addr = address -> host; - } - else - { - sin.sin_port = 0; - sin.sin_addr.s_addr = INADDR_ANY; - } - - return bind (socket, - (struct sockaddr *) & sin, - sizeof (struct sockaddr_in)) == SOCKET_ERROR ? -1 : 0; -} - -int -enet_socket_listen (ENetSocket socket, int backlog) -{ - return listen (socket, backlog < 0 ? SOMAXCONN : backlog) == SOCKET_ERROR ? -1 : 0; -} - -ENetSocket -enet_socket_create (ENetSocketType type) -{ - return socket (PF_INET, type == ENET_SOCKET_TYPE_DATAGRAM ? SOCK_DGRAM : SOCK_STREAM, 0); -} - -int -enet_socket_set_option (ENetSocket socket, ENetSocketOption option, int value) -{ - int result = SOCKET_ERROR; - switch (option) - { - case ENET_SOCKOPT_NONBLOCK: - { - u_long nonBlocking = (u_long) value; - result = ioctlsocket (socket, FIONBIO, & nonBlocking); - break; - } - - case ENET_SOCKOPT_BROADCAST: - result = setsockopt (socket, SOL_SOCKET, SO_BROADCAST, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_REUSEADDR: - result = setsockopt (socket, SOL_SOCKET, SO_REUSEADDR, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_RCVBUF: - result = setsockopt (socket, SOL_SOCKET, SO_RCVBUF, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_SNDBUF: - result = setsockopt (socket, SOL_SOCKET, SO_SNDBUF, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_RCVTIMEO: - result = setsockopt (socket, SOL_SOCKET, SO_RCVTIMEO, (char *) & value, sizeof (int)); - break; - - case ENET_SOCKOPT_SNDTIMEO: - result = setsockopt (socket, SOL_SOCKET, SO_SNDTIMEO, (char *) & value, sizeof (int)); - break; - - default: - break; - } - return result == SOCKET_ERROR ? -1 : 0; -} - -int -enet_socket_connect (ENetSocket socket, const ENetAddress * address) -{ - struct sockaddr_in sin; - int result; - - memset (& sin, 0, sizeof (struct sockaddr_in)); - - sin.sin_family = AF_INET; - sin.sin_port = ENET_HOST_TO_NET_16 (address -> port); - sin.sin_addr.s_addr = address -> host; - - result = connect (socket, (struct sockaddr *) & sin, sizeof (struct sockaddr_in)); - if (result == SOCKET_ERROR && WSAGetLastError () != WSAEWOULDBLOCK) - return -1; - - return 0; -} - -ENetSocket -enet_socket_accept (ENetSocket socket, ENetAddress * address) -{ - SOCKET result; - struct sockaddr_in sin; - int sinLength = sizeof (struct sockaddr_in); - - result = accept (socket, - address != NULL ? (struct sockaddr *) & sin : NULL, - address != NULL ? & sinLength : NULL); - - if (result == INVALID_SOCKET) - return ENET_SOCKET_NULL; - - if (address != NULL) - { - address -> host = (enet_uint32) sin.sin_addr.s_addr; - address -> port = ENET_NET_TO_HOST_16 (sin.sin_port); - } - - return result; -} - -int -enet_socket_shutdown (ENetSocket socket, ENetSocketShutdown how) -{ - return shutdown (socket, (int) how) == SOCKET_ERROR ? -1 : 0; -} - -void -enet_socket_destroy (ENetSocket socket) -{ - if (socket != INVALID_SOCKET) - closesocket (socket); -} - -int -enet_socket_send (ENetSocket socket, - const ENetAddress * address, - const ENetBuffer * buffers, - size_t bufferCount) -{ - struct sockaddr_in sin; - DWORD sentLength; - - if (address != NULL) - { - memset (& sin, 0, sizeof (struct sockaddr_in)); - - sin.sin_family = AF_INET; - sin.sin_port = ENET_HOST_TO_NET_16 (address -> port); - sin.sin_addr.s_addr = address -> host; - } - - if (WSASendTo (socket, - (LPWSABUF) buffers, - (DWORD) bufferCount, - & sentLength, - 0, - address != NULL ? (struct sockaddr *) & sin : NULL, - address != NULL ? sizeof (struct sockaddr_in) : 0, - NULL, - NULL) == SOCKET_ERROR) - { - if (WSAGetLastError () == WSAEWOULDBLOCK) - return 0; - - return -1; - } - - return (int) sentLength; -} - -int -enet_socket_receive (ENetSocket socket, - ENetAddress * address, - ENetBuffer * buffers, - size_t bufferCount) -{ - INT sinLength = sizeof (struct sockaddr_in); - DWORD flags = 0, - recvLength; - struct sockaddr_in sin; - - if (WSARecvFrom (socket, - (LPWSABUF) buffers, - (DWORD) bufferCount, - & recvLength, - & flags, - address != NULL ? (struct sockaddr *) & sin : NULL, - address != NULL ? & sinLength : NULL, - NULL, - NULL) == SOCKET_ERROR) - { - switch (WSAGetLastError ()) - { - case WSAEWOULDBLOCK: - case WSAECONNRESET: - return 0; - } - - return -1; - } - - if (flags & MSG_PARTIAL) - return -1; - - if (address != NULL) - { - address -> host = (enet_uint32) sin.sin_addr.s_addr; - address -> port = ENET_NET_TO_HOST_16 (sin.sin_port); - } - - return (int) recvLength; -} - -int -enet_socketset_select (ENetSocket maxSocket, ENetSocketSet * readSet, ENetSocketSet * writeSet, enet_uint32 timeout) -{ - struct timeval timeVal; - - timeVal.tv_sec = timeout / 1000; - timeVal.tv_usec = (timeout % 1000) * 1000; - - return select (maxSocket + 1, readSet, writeSet, NULL, & timeVal); -} - -int -enet_socket_wait (ENetSocket socket, enet_uint32 * condition, enet_uint32 timeout) -{ - fd_set readSet, writeSet; - struct timeval timeVal; - int selectCount; - - timeVal.tv_sec = timeout / 1000; - timeVal.tv_usec = (timeout % 1000) * 1000; - - FD_ZERO (& readSet); - FD_ZERO (& writeSet); - - if (* condition & ENET_SOCKET_WAIT_SEND) - FD_SET (socket, & writeSet); - - if (* condition & ENET_SOCKET_WAIT_RECEIVE) - FD_SET (socket, & readSet); - - selectCount = select (socket + 1, & readSet, & writeSet, NULL, & timeVal); - - if (selectCount < 0) - return -1; - - * condition = ENET_SOCKET_WAIT_NONE; - - if (selectCount == 0) - return 0; - - if (FD_ISSET (socket, & writeSet)) - * condition |= ENET_SOCKET_WAIT_SEND; - - if (FD_ISSET (socket, & readSet)) - * condition |= ENET_SOCKET_WAIT_RECEIVE; - - return 0; -} - -#endif - diff --git a/btgui/lua-5.2.3/CMakeLists.txt b/btgui/lua-5.2.3/CMakeLists.txt deleted file mode 100644 index fe5b8c063..000000000 --- a/btgui/lua-5.2.3/CMakeLists.txt +++ /dev/null @@ -1,13 +0,0 @@ - -INCLUDE_DIRECTORIES( - . - src -) - -FILE(GLOB_RECURSE lua-5.2.3_SRCS "src/*.c") - -ADD_DEFINITIONS(-DLUA_COMPAT_ALL) - -FILE(GLOB_RECURSE lua-5.2.3_HDRS "src/*.h") - -ADD_LIBRARY(lua-5.2.3 ${lua-5.2.3_SRCS} ${lua-5.2.3_HDRS}) diff --git a/btgui/lua-5.2.3/README b/btgui/lua-5.2.3/README deleted file mode 100644 index 49033adb5..000000000 --- a/btgui/lua-5.2.3/README +++ /dev/null @@ -1,6 +0,0 @@ - -This is Lua 5.2.3, released on 11 Nov 2013. - -For installation instructions, license details, and -further information about Lua, see doc/readme.html. - diff --git a/btgui/lua-5.2.3/lua_compiler/luac.c b/btgui/lua-5.2.3/lua_compiler/luac.c deleted file mode 100644 index 7409706ec..000000000 --- a/btgui/lua-5.2.3/lua_compiler/luac.c +++ /dev/null @@ -1,432 +0,0 @@ -/* -** $Id: luac.c,v 1.69 2011/11/29 17:46:33 lhf Exp $ -** Lua compiler (saves bytecodes to files; also list bytecodes) -** See Copyright Notice in lua.h -*/ - -#include -#include -#include -#include - -#define luac_c -#define LUA_CORE - -#include "lua.h" -#include "lauxlib.h" - -#include "lobject.h" -#include "lstate.h" -#include "lundump.h" - -static void PrintFunction(const Proto* f, int full); -#define luaU_print PrintFunction - -#define PROGNAME "luac" /* default program name */ -#define OUTPUT PROGNAME ".out" /* default output file */ - -static int listing=0; /* list bytecodes? */ -static int dumping=1; /* dump bytecodes? */ -static int stripping=0; /* strip debug information? */ -static char Output[]={ OUTPUT }; /* default output file name */ -static const char* output=Output; /* actual output file name */ -static const char* progname=PROGNAME; /* actual program name */ - -static void fatal(const char* message) -{ - fprintf(stderr,"%s: %s\n",progname,message); - exit(EXIT_FAILURE); -} - -static void cannot(const char* what) -{ - fprintf(stderr,"%s: cannot %s %s: %s\n",progname,what,output,strerror(errno)); - exit(EXIT_FAILURE); -} - -static void usage(const char* message) -{ - if (*message=='-') - fprintf(stderr,"%s: unrecognized option " LUA_QS "\n",progname,message); - else - fprintf(stderr,"%s: %s\n",progname,message); - fprintf(stderr, - "usage: %s [options] [filenames]\n" - "Available options are:\n" - " -l list (use -l -l for full listing)\n" - " -o name output to file " LUA_QL("name") " (default is \"%s\")\n" - " -p parse only\n" - " -s strip debug information\n" - " -v show version information\n" - " -- stop handling options\n" - " - stop handling options and process stdin\n" - ,progname,Output); - exit(EXIT_FAILURE); -} - -#define IS(s) (strcmp(argv[i],s)==0) - -static int doargs(int argc, char* argv[]) -{ - int i; - int version=0; - if (argv[0]!=NULL && *argv[0]!=0) progname=argv[0]; - for (i=1; itop+(i)) - -static const Proto* combine(lua_State* L, int n) -{ - if (n==1) - return toproto(L,-1); - else - { - Proto* f; - int i=n; - if (lua_load(L,reader,&i,"=(" PROGNAME ")",NULL)!=LUA_OK) fatal(lua_tostring(L,-1)); - f=toproto(L,-1); - for (i=0; ip[i]=toproto(L,i-n-1); - if (f->p[i]->sizeupvalues>0) f->p[i]->upvalues[0].instack=0; - } - f->sizelineinfo=0; - return f; - } -} - -static int writer(lua_State* L, const void* p, size_t size, void* u) -{ - UNUSED(L); - return (fwrite(p,size,1,(FILE*)u)!=1) && (size!=0); -} - -static int pmain(lua_State* L) -{ - int argc=(int)lua_tointeger(L,1); - char** argv=(char**)lua_touserdata(L,2); - const Proto* f; - int i; - if (!lua_checkstack(L,argc)) fatal("too many input files"); - for (i=0; i1); - if (dumping) - { - FILE* D= (output==NULL) ? stdout : fopen(output,"wb"); - if (D==NULL) cannot("open"); - lua_lock(L); - luaU_dump(L,f,writer,D,stripping); - lua_unlock(L); - if (ferror(D)) cannot("write"); - if (fclose(D)) cannot("close"); - } - return 0; -} - -int main(int argc, char* argv[]) -{ - lua_State* L; - int i=doargs(argc,argv); - argc-=i; argv+=i; - if (argc<=0) usage("no input files given"); - L=luaL_newstate(); - if (L==NULL) fatal("cannot create state: not enough memory"); - lua_pushcfunction(L,&pmain); - lua_pushinteger(L,argc); - lua_pushlightuserdata(L,argv); - if (lua_pcall(L,2,0,0)!=LUA_OK) fatal(lua_tostring(L,-1)); - lua_close(L); - return EXIT_SUCCESS; -} - -/* -** $Id: print.c,v 1.69 2013/07/04 01:03:46 lhf Exp $ -** print bytecodes -** See Copyright Notice in lua.h -*/ - -#include -#include - -#define luac_c -#define LUA_CORE - -#include "ldebug.h" -#include "lobject.h" -#include "lopcodes.h" - -#define VOID(p) ((const void*)(p)) - -static void PrintString(const TString* ts) -{ - const char* s=getstr(ts); - size_t i,n=ts->tsv.len; - printf("%c",'"'); - for (i=0; ik[i]; - switch (ttypenv(o)) - { - case LUA_TNIL: - printf("nil"); - break; - case LUA_TBOOLEAN: - printf(bvalue(o) ? "true" : "false"); - break; - case LUA_TNUMBER: - printf(LUA_NUMBER_FMT,nvalue(o)); - break; - case LUA_TSTRING: - PrintString(rawtsvalue(o)); - break; - default: /* cannot happen */ - printf("? type=%d",ttype(o)); - break; - } -} - -#define UPVALNAME(x) ((f->upvalues[x].name) ? getstr(f->upvalues[x].name) : "-") -#define MYK(x) (-1-(x)) - -static void PrintCode(const Proto* f) -{ - const Instruction* code=f->code; - int pc,n=f->sizecode; - for (pc=0; pc0) printf("[%d]\t",line); else printf("[-]\t"); - printf("%-9s\t",luaP_opnames[o]); - switch (getOpMode(o)) - { - case iABC: - printf("%d",a); - if (getBMode(o)!=OpArgN) printf(" %d",ISK(b) ? (MYK(INDEXK(b))) : b); - if (getCMode(o)!=OpArgN) printf(" %d",ISK(c) ? (MYK(INDEXK(c))) : c); - break; - case iABx: - printf("%d",a); - if (getBMode(o)==OpArgK) printf(" %d",MYK(bx)); - if (getBMode(o)==OpArgU) printf(" %d",bx); - break; - case iAsBx: - printf("%d %d",a,sbx); - break; - case iAx: - printf("%d",MYK(ax)); - break; - } - switch (o) - { - case OP_LOADK: - printf("\t; "); PrintConstant(f,bx); - break; - case OP_GETUPVAL: - case OP_SETUPVAL: - printf("\t; %s",UPVALNAME(b)); - break; - case OP_GETTABUP: - printf("\t; %s",UPVALNAME(b)); - if (ISK(c)) { printf(" "); PrintConstant(f,INDEXK(c)); } - break; - case OP_SETTABUP: - printf("\t; %s",UPVALNAME(a)); - if (ISK(b)) { printf(" "); PrintConstant(f,INDEXK(b)); } - if (ISK(c)) { printf(" "); PrintConstant(f,INDEXK(c)); } - break; - case OP_GETTABLE: - case OP_SELF: - if (ISK(c)) { printf("\t; "); PrintConstant(f,INDEXK(c)); } - break; - case OP_SETTABLE: - case OP_ADD: - case OP_SUB: - case OP_MUL: - case OP_DIV: - case OP_POW: - case OP_EQ: - case OP_LT: - case OP_LE: - if (ISK(b) || ISK(c)) - { - printf("\t; "); - if (ISK(b)) PrintConstant(f,INDEXK(b)); else printf("-"); - printf(" "); - if (ISK(c)) PrintConstant(f,INDEXK(c)); else printf("-"); - } - break; - case OP_JMP: - case OP_FORLOOP: - case OP_FORPREP: - case OP_TFORLOOP: - printf("\t; to %d",sbx+pc+2); - break; - case OP_CLOSURE: - printf("\t; %p",VOID(f->p[bx])); - break; - case OP_SETLIST: - if (c==0) printf("\t; %d",(int)code[++pc]); else printf("\t; %d",c); - break; - case OP_EXTRAARG: - printf("\t; "); PrintConstant(f,ax); - break; - default: - break; - } - printf("\n"); - } -} - -#define SS(x) ((x==1)?"":"s") -#define S(x) (int)(x),SS(x) - -static void PrintHeader(const Proto* f) -{ - const char* s=f->source ? getstr(f->source) : "=?"; - if (*s=='@' || *s=='=') - s++; - else if (*s==LUA_SIGNATURE[0]) - s="(bstring)"; - else - s="(string)"; - printf("\n%s <%s:%d,%d> (%d instruction%s at %p)\n", - (f->linedefined==0)?"main":"function",s, - f->linedefined,f->lastlinedefined, - S(f->sizecode),VOID(f)); - printf("%d%s param%s, %d slot%s, %d upvalue%s, ", - (int)(f->numparams),f->is_vararg?"+":"",SS(f->numparams), - S(f->maxstacksize),S(f->sizeupvalues)); - printf("%d local%s, %d constant%s, %d function%s\n", - S(f->sizelocvars),S(f->sizek),S(f->sizep)); -} - -static void PrintDebug(const Proto* f) -{ - int i,n; - n=f->sizek; - printf("constants (%d) for %p:\n",n,VOID(f)); - for (i=0; isizelocvars; - printf("locals (%d) for %p:\n",n,VOID(f)); - for (i=0; ilocvars[i].varname),f->locvars[i].startpc+1,f->locvars[i].endpc+1); - } - n=f->sizeupvalues; - printf("upvalues (%d) for %p:\n",n,VOID(f)); - for (i=0; iupvalues[i].instack,f->upvalues[i].idx); - } -} - -static void PrintFunction(const Proto* f, int full) -{ - int i,n=f->sizep; - PrintHeader(f); - PrintCode(f); - if (full) PrintDebug(f); - for (i=0; ip[i],full); -} diff --git a/btgui/lua-5.2.3/lua_compiler/premake4.lua b/btgui/lua-5.2.3/lua_compiler/premake4.lua deleted file mode 100644 index 1dfe766b1..000000000 --- a/btgui/lua-5.2.3/lua_compiler/premake4.lua +++ /dev/null @@ -1,23 +0,0 @@ - - -project ("App_LuaCompiler") - - language "C++" - - kind "ConsoleApp" - targetdir "../../../bin" - includedirs {"../src"} - - if os.is("Windows") then - end - if os.is("Linux") then - end - if os.is("MacOSX") then - end - - links {"lua-5.2.3"} - - files { - "luac.c", - } - diff --git a/btgui/lua-5.2.3/lua_standalone/lua.c b/btgui/lua-5.2.3/lua_standalone/lua.c deleted file mode 100644 index 4345e554e..000000000 --- a/btgui/lua-5.2.3/lua_standalone/lua.c +++ /dev/null @@ -1,497 +0,0 @@ -/* -** $Id: lua.c,v 1.206.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua stand-alone interpreter -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include -#include - -#define lua_c - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -#if !defined(LUA_PROMPT) -#define LUA_PROMPT "> " -#define LUA_PROMPT2 ">> " -#endif - -#if !defined(LUA_PROGNAME) -#define LUA_PROGNAME "lua" -#endif - -#if !defined(LUA_MAXINPUT) -#define LUA_MAXINPUT 512 -#endif - -#if !defined(LUA_INIT) -#define LUA_INIT "LUA_INIT" -#endif - -#define LUA_INITVERSION \ - LUA_INIT "_" LUA_VERSION_MAJOR "_" LUA_VERSION_MINOR - - -/* -** lua_stdin_is_tty detects whether the standard input is a 'tty' (that -** is, whether we're running lua interactively). -*/ -#if defined(LUA_USE_ISATTY) -#include -#define lua_stdin_is_tty() isatty(0) -#elif defined(LUA_WIN) -#include -#include -#define lua_stdin_is_tty() _isatty(_fileno(stdin)) -#else -#define lua_stdin_is_tty() 1 /* assume stdin is a tty */ -#endif - - -/* -** lua_readline defines how to show a prompt and then read a line from -** the standard input. -** lua_saveline defines how to "save" a read line in a "history". -** lua_freeline defines how to free a line read by lua_readline. -*/ -#if defined(LUA_USE_READLINE) - -#include -#include -#include -#define lua_readline(L,b,p) ((void)L, ((b)=readline(p)) != NULL) -#define lua_saveline(L,idx) \ - if (lua_rawlen(L,idx) > 0) /* non-empty line? */ \ - add_history(lua_tostring(L, idx)); /* add it to history */ -#define lua_freeline(L,b) ((void)L, free(b)) - -#elif !defined(lua_readline) - -#define lua_readline(L,b,p) \ - ((void)L, fputs(p, stdout), fflush(stdout), /* show prompt */ \ - fgets(b, LUA_MAXINPUT, stdin) != NULL) /* get line */ -#define lua_saveline(L,idx) { (void)L; (void)idx; } -#define lua_freeline(L,b) { (void)L; (void)b; } - -#endif - - - - -static lua_State *globalL = NULL; - -static const char *progname = LUA_PROGNAME; - - - -static void lstop (lua_State *L, lua_Debug *ar) { - (void)ar; /* unused arg. */ - lua_sethook(L, NULL, 0, 0); - luaL_error(L, "interrupted!"); -} - - -static void laction (int i) { - signal(i, SIG_DFL); /* if another SIGINT happens before lstop, - terminate process (default action) */ - lua_sethook(globalL, lstop, LUA_MASKCALL | LUA_MASKRET | LUA_MASKCOUNT, 1); -} - - -static void print_usage (const char *badoption) { - luai_writestringerror("%s: ", progname); - if (badoption[1] == 'e' || badoption[1] == 'l') - luai_writestringerror("'%s' needs argument\n", badoption); - else - luai_writestringerror("unrecognized option '%s'\n", badoption); - luai_writestringerror( - "usage: %s [options] [script [args]]\n" - "Available options are:\n" - " -e stat execute string " LUA_QL("stat") "\n" - " -i enter interactive mode after executing " LUA_QL("script") "\n" - " -l name require library " LUA_QL("name") "\n" - " -v show version information\n" - " -E ignore environment variables\n" - " -- stop handling options\n" - " - stop handling options and execute stdin\n" - , - progname); -} - - -static void l_message (const char *pname, const char *msg) { - if (pname) luai_writestringerror("%s: ", pname); - luai_writestringerror("%s\n", msg); -} - - -static int report (lua_State *L, int status) { - if (status != LUA_OK && !lua_isnil(L, -1)) { - const char *msg = lua_tostring(L, -1); - if (msg == NULL) msg = "(error object is not a string)"; - l_message(progname, msg); - lua_pop(L, 1); - /* force a complete garbage collection in case of errors */ - lua_gc(L, LUA_GCCOLLECT, 0); - } - return status; -} - - -/* the next function is called unprotected, so it must avoid errors */ -static void finalreport (lua_State *L, int status) { - if (status != LUA_OK) { - const char *msg = (lua_type(L, -1) == LUA_TSTRING) ? lua_tostring(L, -1) - : NULL; - if (msg == NULL) msg = "(error object is not a string)"; - l_message(progname, msg); - lua_pop(L, 1); - } -} - - -static int traceback (lua_State *L) { - const char *msg = lua_tostring(L, 1); - if (msg) - luaL_traceback(L, L, msg, 1); - else if (!lua_isnoneornil(L, 1)) { /* is there an error object? */ - if (!luaL_callmeta(L, 1, "__tostring")) /* try its 'tostring' metamethod */ - lua_pushliteral(L, "(no error message)"); - } - return 1; -} - - -static int docall (lua_State *L, int narg, int nres) { - int status; - int base = lua_gettop(L) - narg; /* function index */ - lua_pushcfunction(L, traceback); /* push traceback function */ - lua_insert(L, base); /* put it under chunk and args */ - globalL = L; /* to be available to 'laction' */ - signal(SIGINT, laction); - status = lua_pcall(L, narg, nres, base); - signal(SIGINT, SIG_DFL); - lua_remove(L, base); /* remove traceback function */ - return status; -} - - -static void print_version (void) { - luai_writestring(LUA_COPYRIGHT, strlen(LUA_COPYRIGHT)); - luai_writeline(); -} - - -static int getargs (lua_State *L, char **argv, int n) { - int narg; - int i; - int argc = 0; - while (argv[argc]) argc++; /* count total number of arguments */ - narg = argc - (n + 1); /* number of arguments to the script */ - luaL_checkstack(L, narg + 3, "too many arguments to script"); - for (i=n+1; i < argc; i++) - lua_pushstring(L, argv[i]); - lua_createtable(L, narg, n + 1); - for (i=0; i < argc; i++) { - lua_pushstring(L, argv[i]); - lua_rawseti(L, -2, i - n); - } - return narg; -} - - -static int dofile (lua_State *L, const char *name) { - int status = luaL_loadfile(L, name); - if (status == LUA_OK) status = docall(L, 0, 0); - return report(L, status); -} - - -static int dostring (lua_State *L, const char *s, const char *name) { - int status = luaL_loadbuffer(L, s, strlen(s), name); - if (status == LUA_OK) status = docall(L, 0, 0); - return report(L, status); -} - - -static int dolibrary (lua_State *L, const char *name) { - int status; - lua_getglobal(L, "require"); - lua_pushstring(L, name); - status = docall(L, 1, 1); /* call 'require(name)' */ - if (status == LUA_OK) - lua_setglobal(L, name); /* global[name] = require return */ - return report(L, status); -} - - -static const char *get_prompt (lua_State *L, int firstline) { - const char *p; - lua_getglobal(L, firstline ? "_PROMPT" : "_PROMPT2"); - p = lua_tostring(L, -1); - if (p == NULL) p = (firstline ? LUA_PROMPT : LUA_PROMPT2); - return p; -} - -/* mark in error messages for incomplete statements */ -#define EOFMARK "" -#define marklen (sizeof(EOFMARK)/sizeof(char) - 1) - -static int incomplete (lua_State *L, int status) { - if (status == LUA_ERRSYNTAX) { - size_t lmsg; - const char *msg = lua_tolstring(L, -1, &lmsg); - if (lmsg >= marklen && strcmp(msg + lmsg - marklen, EOFMARK) == 0) { - lua_pop(L, 1); - return 1; - } - } - return 0; /* else... */ -} - - -static int pushline (lua_State *L, int firstline) { - char buffer[LUA_MAXINPUT]; - char *b = buffer; - size_t l; - const char *prmt = get_prompt(L, firstline); - int readstatus = lua_readline(L, b, prmt); - lua_pop(L, 1); /* remove result from 'get_prompt' */ - if (readstatus == 0) - return 0; /* no input */ - l = strlen(b); - if (l > 0 && b[l-1] == '\n') /* line ends with newline? */ - b[l-1] = '\0'; /* remove it */ - if (firstline && b[0] == '=') /* first line starts with `=' ? */ - lua_pushfstring(L, "return %s", b+1); /* change it to `return' */ - else - lua_pushstring(L, b); - lua_freeline(L, b); - return 1; -} - - -static int loadline (lua_State *L) { - int status; - lua_settop(L, 0); - if (!pushline(L, 1)) - return -1; /* no input */ - for (;;) { /* repeat until gets a complete line */ - size_t l; - const char *line = lua_tolstring(L, 1, &l); - status = luaL_loadbuffer(L, line, l, "=stdin"); - if (!incomplete(L, status)) break; /* cannot try to add lines? */ - if (!pushline(L, 0)) /* no more input? */ - return -1; - lua_pushliteral(L, "\n"); /* add a new line... */ - lua_insert(L, -2); /* ...between the two lines */ - lua_concat(L, 3); /* join them */ - } - lua_saveline(L, 1); - lua_remove(L, 1); /* remove line */ - return status; -} - - -static void dotty (lua_State *L) { - int status; - const char *oldprogname = progname; - progname = NULL; - while ((status = loadline(L)) != -1) { - if (status == LUA_OK) status = docall(L, 0, LUA_MULTRET); - report(L, status); - if (status == LUA_OK && lua_gettop(L) > 0) { /* any result to print? */ - luaL_checkstack(L, LUA_MINSTACK, "too many results to print"); - lua_getglobal(L, "print"); - lua_insert(L, 1); - if (lua_pcall(L, lua_gettop(L)-1, 0, 0) != LUA_OK) - l_message(progname, lua_pushfstring(L, - "error calling " LUA_QL("print") " (%s)", - lua_tostring(L, -1))); - } - } - lua_settop(L, 0); /* clear stack */ - luai_writeline(); - progname = oldprogname; -} - - -static int handle_script (lua_State *L, char **argv, int n) { - int status; - const char *fname; - int narg = getargs(L, argv, n); /* collect arguments */ - lua_setglobal(L, "arg"); - fname = argv[n]; - if (strcmp(fname, "-") == 0 && strcmp(argv[n-1], "--") != 0) - fname = NULL; /* stdin */ - status = luaL_loadfile(L, fname); - lua_insert(L, -(narg+1)); - if (status == LUA_OK) - status = docall(L, narg, LUA_MULTRET); - else - lua_pop(L, narg); - return report(L, status); -} - - -/* check that argument has no extra characters at the end */ -#define noextrachars(x) {if ((x)[2] != '\0') return -1;} - - -/* indices of various argument indicators in array args */ -#define has_i 0 /* -i */ -#define has_v 1 /* -v */ -#define has_e 2 /* -e */ -#define has_E 3 /* -E */ - -#define num_has 4 /* number of 'has_*' */ - - -static int collectargs (char **argv, int *args) { - int i; - for (i = 1; argv[i] != NULL; i++) { - if (argv[i][0] != '-') /* not an option? */ - return i; - switch (argv[i][1]) { /* option */ - case '-': - noextrachars(argv[i]); - return (argv[i+1] != NULL ? i+1 : 0); - case '\0': - return i; - case 'E': - args[has_E] = 1; - break; - case 'i': - noextrachars(argv[i]); - args[has_i] = 1; /* go through */ - case 'v': - noextrachars(argv[i]); - args[has_v] = 1; - break; - case 'e': - args[has_e] = 1; /* go through */ - case 'l': /* both options need an argument */ - if (argv[i][2] == '\0') { /* no concatenated argument? */ - i++; /* try next 'argv' */ - if (argv[i] == NULL || argv[i][0] == '-') - return -(i - 1); /* no next argument or it is another option */ - } - break; - default: /* invalid option; return its index... */ - return -i; /* ...as a negative value */ - } - } - return 0; -} - - -static int runargs (lua_State *L, char **argv, int n) { - int i; - for (i = 1; i < n; i++) { - lua_assert(argv[i][0] == '-'); - switch (argv[i][1]) { /* option */ - case 'e': { - const char *chunk = argv[i] + 2; - if (*chunk == '\0') chunk = argv[++i]; - lua_assert(chunk != NULL); - if (dostring(L, chunk, "=(command line)") != LUA_OK) - return 0; - break; - } - case 'l': { - const char *filename = argv[i] + 2; - if (*filename == '\0') filename = argv[++i]; - lua_assert(filename != NULL); - if (dolibrary(L, filename) != LUA_OK) - return 0; /* stop if file fails */ - break; - } - default: break; - } - } - return 1; -} - - -static int handle_luainit (lua_State *L) { - const char *name = "=" LUA_INITVERSION; - const char *init = getenv(name + 1); - if (init == NULL) { - name = "=" LUA_INIT; - init = getenv(name + 1); /* try alternative name */ - } - if (init == NULL) return LUA_OK; - else if (init[0] == '@') - return dofile(L, init+1); - else - return dostring(L, init, name); -} - - -static int pmain (lua_State *L) { - int argc = (int)lua_tointeger(L, 1); - char **argv = (char **)lua_touserdata(L, 2); - int script; - int args[num_has]; - args[has_i] = args[has_v] = args[has_e] = args[has_E] = 0; - if (argv[0] && argv[0][0]) progname = argv[0]; - script = collectargs(argv, args); - if (script < 0) { /* invalid arg? */ - print_usage(argv[-script]); - return 0; - } - if (args[has_v]) print_version(); - if (args[has_E]) { /* option '-E'? */ - lua_pushboolean(L, 1); /* signal for libraries to ignore env. vars. */ - lua_setfield(L, LUA_REGISTRYINDEX, "LUA_NOENV"); - } - /* open standard libraries */ - luaL_checkversion(L); - lua_gc(L, LUA_GCSTOP, 0); /* stop collector during initialization */ - luaL_openlibs(L); /* open libraries */ - lua_gc(L, LUA_GCRESTART, 0); - if (!args[has_E] && handle_luainit(L) != LUA_OK) - return 0; /* error running LUA_INIT */ - /* execute arguments -e and -l */ - if (!runargs(L, argv, (script > 0) ? script : argc)) return 0; - /* execute main script (if there is one) */ - if (script && handle_script(L, argv, script) != LUA_OK) return 0; - if (args[has_i]) /* -i option? */ - dotty(L); - else if (script == 0 && !args[has_e] && !args[has_v]) { /* no arguments? */ - if (lua_stdin_is_tty()) { - print_version(); - dotty(L); - } - else dofile(L, NULL); /* executes stdin as a file */ - } - lua_pushboolean(L, 1); /* signal no errors */ - return 1; -} - - -int main (int argc, char **argv) { - int status, result; - lua_State *L = luaL_newstate(); /* create state */ - if (L == NULL) { - l_message(argv[0], "cannot create state: not enough memory"); - return EXIT_FAILURE; - } - /* call 'pmain' in protected mode */ - lua_pushcfunction(L, &pmain); - lua_pushinteger(L, argc); /* 1st argument */ - lua_pushlightuserdata(L, argv); /* 2nd argument */ - status = lua_pcall(L, 2, 1, 0); - result = lua_toboolean(L, -1); /* get result */ - finalreport(L, status); - lua_close(L); - return (result && status == LUA_OK) ? EXIT_SUCCESS : EXIT_FAILURE; -} - diff --git a/btgui/lua-5.2.3/lua_standalone/premake4.lua b/btgui/lua-5.2.3/lua_standalone/premake4.lua deleted file mode 100644 index c1c9218af..000000000 --- a/btgui/lua-5.2.3/lua_standalone/premake4.lua +++ /dev/null @@ -1,23 +0,0 @@ - - -project ("App_LuaStandalone") - - language "C++" - - kind "ConsoleApp" - targetdir "../../../bin" - includedirs {"../src"} - - if os.is("Windows") then - end - if os.is("Linux") then - end - if os.is("MacOSX") then - end - - links {"lua-5.2.3"} - - files { - "lua.c", - } - diff --git a/btgui/lua-5.2.3/premake4.lua b/btgui/lua-5.2.3/premake4.lua deleted file mode 100644 index 2a1e4aeae..000000000 --- a/btgui/lua-5.2.3/premake4.lua +++ /dev/null @@ -1,27 +0,0 @@ - project "lua-5.2.3" - - kind "StaticLib" - - --flags {} - - - defines { "LUA_COMPAT_ALL"} - - if os.is("Linux") then - defines {"LUA_USE_LINUX"} - end - if os.is("MacOSX") then - defines {"LUA_USE_MACOSX"} - end - - targetdir "../../lib" - includedirs { - "src" - } - files { - "src/*.c", - "src/*.h" - } - -include "lua_compiler" -include "lua_standalone" diff --git a/btgui/lua-5.2.3/src/lapi.c b/btgui/lua-5.2.3/src/lapi.c deleted file mode 100644 index d011431ea..000000000 --- a/btgui/lua-5.2.3/src/lapi.c +++ /dev/null @@ -1,1284 +0,0 @@ -/* -** $Id: lapi.c,v 2.171.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua API -** See Copyright Notice in lua.h -*/ - - -#include -#include - -#define lapi_c -#define LUA_CORE - -#include "lua.h" - -#include "lapi.h" -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lgc.h" -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" -#include "lundump.h" -#include "lvm.h" - - - -const char lua_ident[] = - "$LuaVersion: " LUA_COPYRIGHT " $" - "$LuaAuthors: " LUA_AUTHORS " $"; - - -/* value at a non-valid index */ -#define NONVALIDVALUE cast(TValue *, luaO_nilobject) - -/* corresponding test */ -#define isvalid(o) ((o) != luaO_nilobject) - -/* test for pseudo index */ -#define ispseudo(i) ((i) <= LUA_REGISTRYINDEX) - -/* test for valid but not pseudo index */ -#define isstackindex(i, o) (isvalid(o) && !ispseudo(i)) - -#define api_checkvalidindex(L, o) api_check(L, isvalid(o), "invalid index") - -#define api_checkstackindex(L, i, o) \ - api_check(L, isstackindex(i, o), "index not in the stack") - - -static TValue *index2addr (lua_State *L, int idx) { - CallInfo *ci = L->ci; - if (idx > 0) { - TValue *o = ci->func + idx; - api_check(L, idx <= ci->top - (ci->func + 1), "unacceptable index"); - if (o >= L->top) return NONVALIDVALUE; - else return o; - } - else if (!ispseudo(idx)) { /* negative index */ - api_check(L, idx != 0 && -idx <= L->top - (ci->func + 1), "invalid index"); - return L->top + idx; - } - else if (idx == LUA_REGISTRYINDEX) - return &G(L)->l_registry; - else { /* upvalues */ - idx = LUA_REGISTRYINDEX - idx; - api_check(L, idx <= MAXUPVAL + 1, "upvalue index too large"); - if (ttislcf(ci->func)) /* light C function? */ - return NONVALIDVALUE; /* it has no upvalues */ - else { - CClosure *func = clCvalue(ci->func); - return (idx <= func->nupvalues) ? &func->upvalue[idx-1] : NONVALIDVALUE; - } - } -} - - -/* -** to be called by 'lua_checkstack' in protected mode, to grow stack -** capturing memory errors -*/ -static void growstack (lua_State *L, void *ud) { - int size = *(int *)ud; - luaD_growstack(L, size); -} - - -LUA_API int lua_checkstack (lua_State *L, int size) { - int res; - CallInfo *ci = L->ci; - lua_lock(L); - if (L->stack_last - L->top > size) /* stack large enough? */ - res = 1; /* yes; check is OK */ - else { /* no; need to grow stack */ - int inuse = cast_int(L->top - L->stack) + EXTRA_STACK; - if (inuse > LUAI_MAXSTACK - size) /* can grow without overflow? */ - res = 0; /* no */ - else /* try to grow stack */ - res = (luaD_rawrunprotected(L, &growstack, &size) == LUA_OK); - } - if (res && ci->top < L->top + size) - ci->top = L->top + size; /* adjust frame top */ - lua_unlock(L); - return res; -} - - -LUA_API void lua_xmove (lua_State *from, lua_State *to, int n) { - int i; - if (from == to) return; - lua_lock(to); - api_checknelems(from, n); - api_check(from, G(from) == G(to), "moving among independent states"); - api_check(from, to->ci->top - to->top >= n, "not enough elements to move"); - from->top -= n; - for (i = 0; i < n; i++) { - setobj2s(to, to->top++, from->top + i); - } - lua_unlock(to); -} - - -LUA_API lua_CFunction lua_atpanic (lua_State *L, lua_CFunction panicf) { - lua_CFunction old; - lua_lock(L); - old = G(L)->panic; - G(L)->panic = panicf; - lua_unlock(L); - return old; -} - - -LUA_API const lua_Number *lua_version (lua_State *L) { - static const lua_Number version = LUA_VERSION_NUM; - if (L == NULL) return &version; - else return G(L)->version; -} - - - -/* -** basic stack manipulation -*/ - - -/* -** convert an acceptable stack index into an absolute index -*/ -LUA_API int lua_absindex (lua_State *L, int idx) { - return (idx > 0 || ispseudo(idx)) - ? idx - : cast_int(L->top - L->ci->func + idx); -} - - -LUA_API int lua_gettop (lua_State *L) { - return cast_int(L->top - (L->ci->func + 1)); -} - - -LUA_API void lua_settop (lua_State *L, int idx) { - StkId func = L->ci->func; - lua_lock(L); - if (idx >= 0) { - api_check(L, idx <= L->stack_last - (func + 1), "new top too large"); - while (L->top < (func + 1) + idx) - setnilvalue(L->top++); - L->top = (func + 1) + idx; - } - else { - api_check(L, -(idx+1) <= (L->top - (func + 1)), "invalid new top"); - L->top += idx+1; /* `subtract' index (index is negative) */ - } - lua_unlock(L); -} - - -LUA_API void lua_remove (lua_State *L, int idx) { - StkId p; - lua_lock(L); - p = index2addr(L, idx); - api_checkstackindex(L, idx, p); - while (++p < L->top) setobjs2s(L, p-1, p); - L->top--; - lua_unlock(L); -} - - -LUA_API void lua_insert (lua_State *L, int idx) { - StkId p; - StkId q; - lua_lock(L); - p = index2addr(L, idx); - api_checkstackindex(L, idx, p); - for (q = L->top; q > p; q--) /* use L->top as a temporary */ - setobjs2s(L, q, q - 1); - setobjs2s(L, p, L->top); - lua_unlock(L); -} - - -static void moveto (lua_State *L, TValue *fr, int idx) { - TValue *to = index2addr(L, idx); - api_checkvalidindex(L, to); - setobj(L, to, fr); - if (idx < LUA_REGISTRYINDEX) /* function upvalue? */ - luaC_barrier(L, clCvalue(L->ci->func), fr); - /* LUA_REGISTRYINDEX does not need gc barrier - (collector revisits it before finishing collection) */ -} - - -LUA_API void lua_replace (lua_State *L, int idx) { - lua_lock(L); - api_checknelems(L, 1); - moveto(L, L->top - 1, idx); - L->top--; - lua_unlock(L); -} - - -LUA_API void lua_copy (lua_State *L, int fromidx, int toidx) { - TValue *fr; - lua_lock(L); - fr = index2addr(L, fromidx); - moveto(L, fr, toidx); - lua_unlock(L); -} - - -LUA_API void lua_pushvalue (lua_State *L, int idx) { - lua_lock(L); - setobj2s(L, L->top, index2addr(L, idx)); - api_incr_top(L); - lua_unlock(L); -} - - - -/* -** access functions (stack -> C) -*/ - - -LUA_API int lua_type (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - return (isvalid(o) ? ttypenv(o) : LUA_TNONE); -} - - -LUA_API const char *lua_typename (lua_State *L, int t) { - UNUSED(L); - return ttypename(t); -} - - -LUA_API int lua_iscfunction (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - return (ttislcf(o) || (ttisCclosure(o))); -} - - -LUA_API int lua_isnumber (lua_State *L, int idx) { - TValue n; - const TValue *o = index2addr(L, idx); - return tonumber(o, &n); -} - - -LUA_API int lua_isstring (lua_State *L, int idx) { - int t = lua_type(L, idx); - return (t == LUA_TSTRING || t == LUA_TNUMBER); -} - - -LUA_API int lua_isuserdata (lua_State *L, int idx) { - const TValue *o = index2addr(L, idx); - return (ttisuserdata(o) || ttislightuserdata(o)); -} - - -LUA_API int lua_rawequal (lua_State *L, int index1, int index2) { - StkId o1 = index2addr(L, index1); - StkId o2 = index2addr(L, index2); - return (isvalid(o1) && isvalid(o2)) ? luaV_rawequalobj(o1, o2) : 0; -} - - -LUA_API void lua_arith (lua_State *L, int op) { - StkId o1; /* 1st operand */ - StkId o2; /* 2nd operand */ - lua_lock(L); - if (op != LUA_OPUNM) /* all other operations expect two operands */ - api_checknelems(L, 2); - else { /* for unary minus, add fake 2nd operand */ - api_checknelems(L, 1); - setobjs2s(L, L->top, L->top - 1); - L->top++; - } - o1 = L->top - 2; - o2 = L->top - 1; - if (ttisnumber(o1) && ttisnumber(o2)) { - setnvalue(o1, luaO_arith(op, nvalue(o1), nvalue(o2))); - } - else - luaV_arith(L, o1, o1, o2, cast(TMS, op - LUA_OPADD + TM_ADD)); - L->top--; - lua_unlock(L); -} - - -LUA_API int lua_compare (lua_State *L, int index1, int index2, int op) { - StkId o1, o2; - int i = 0; - lua_lock(L); /* may call tag method */ - o1 = index2addr(L, index1); - o2 = index2addr(L, index2); - if (isvalid(o1) && isvalid(o2)) { - switch (op) { - case LUA_OPEQ: i = equalobj(L, o1, o2); break; - case LUA_OPLT: i = luaV_lessthan(L, o1, o2); break; - case LUA_OPLE: i = luaV_lessequal(L, o1, o2); break; - default: api_check(L, 0, "invalid option"); - } - } - lua_unlock(L); - return i; -} - - -LUA_API lua_Number lua_tonumberx (lua_State *L, int idx, int *isnum) { - TValue n; - const TValue *o = index2addr(L, idx); - if (tonumber(o, &n)) { - if (isnum) *isnum = 1; - return nvalue(o); - } - else { - if (isnum) *isnum = 0; - return 0; - } -} - - -LUA_API lua_Integer lua_tointegerx (lua_State *L, int idx, int *isnum) { - TValue n; - const TValue *o = index2addr(L, idx); - if (tonumber(o, &n)) { - lua_Integer res; - lua_Number num = nvalue(o); - lua_number2integer(res, num); - if (isnum) *isnum = 1; - return res; - } - else { - if (isnum) *isnum = 0; - return 0; - } -} - - -LUA_API lua_Unsigned lua_tounsignedx (lua_State *L, int idx, int *isnum) { - TValue n; - const TValue *o = index2addr(L, idx); - if (tonumber(o, &n)) { - lua_Unsigned res; - lua_Number num = nvalue(o); - lua_number2unsigned(res, num); - if (isnum) *isnum = 1; - return res; - } - else { - if (isnum) *isnum = 0; - return 0; - } -} - - -LUA_API int lua_toboolean (lua_State *L, int idx) { - const TValue *o = index2addr(L, idx); - return !l_isfalse(o); -} - - -LUA_API const char *lua_tolstring (lua_State *L, int idx, size_t *len) { - StkId o = index2addr(L, idx); - if (!ttisstring(o)) { - lua_lock(L); /* `luaV_tostring' may create a new string */ - if (!luaV_tostring(L, o)) { /* conversion failed? */ - if (len != NULL) *len = 0; - lua_unlock(L); - return NULL; - } - luaC_checkGC(L); - o = index2addr(L, idx); /* previous call may reallocate the stack */ - lua_unlock(L); - } - if (len != NULL) *len = tsvalue(o)->len; - return svalue(o); -} - - -LUA_API size_t lua_rawlen (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - switch (ttypenv(o)) { - case LUA_TSTRING: return tsvalue(o)->len; - case LUA_TUSERDATA: return uvalue(o)->len; - case LUA_TTABLE: return luaH_getn(hvalue(o)); - default: return 0; - } -} - - -LUA_API lua_CFunction lua_tocfunction (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - if (ttislcf(o)) return fvalue(o); - else if (ttisCclosure(o)) - return clCvalue(o)->f; - else return NULL; /* not a C function */ -} - - -LUA_API void *lua_touserdata (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - switch (ttypenv(o)) { - case LUA_TUSERDATA: return (rawuvalue(o) + 1); - case LUA_TLIGHTUSERDATA: return pvalue(o); - default: return NULL; - } -} - - -LUA_API lua_State *lua_tothread (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - return (!ttisthread(o)) ? NULL : thvalue(o); -} - - -LUA_API const void *lua_topointer (lua_State *L, int idx) { - StkId o = index2addr(L, idx); - switch (ttype(o)) { - case LUA_TTABLE: return hvalue(o); - case LUA_TLCL: return clLvalue(o); - case LUA_TCCL: return clCvalue(o); - case LUA_TLCF: return cast(void *, cast(size_t, fvalue(o))); - case LUA_TTHREAD: return thvalue(o); - case LUA_TUSERDATA: - case LUA_TLIGHTUSERDATA: - return lua_touserdata(L, idx); - default: return NULL; - } -} - - - -/* -** push functions (C -> stack) -*/ - - -LUA_API void lua_pushnil (lua_State *L) { - lua_lock(L); - setnilvalue(L->top); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_pushnumber (lua_State *L, lua_Number n) { - lua_lock(L); - setnvalue(L->top, n); - luai_checknum(L, L->top, - luaG_runerror(L, "C API - attempt to push a signaling NaN")); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_pushinteger (lua_State *L, lua_Integer n) { - lua_lock(L); - setnvalue(L->top, cast_num(n)); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_pushunsigned (lua_State *L, lua_Unsigned u) { - lua_Number n; - lua_lock(L); - n = lua_unsigned2number(u); - setnvalue(L->top, n); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API const char *lua_pushlstring (lua_State *L, const char *s, size_t len) { - TString *ts; - lua_lock(L); - luaC_checkGC(L); - ts = luaS_newlstr(L, s, len); - setsvalue2s(L, L->top, ts); - api_incr_top(L); - lua_unlock(L); - return getstr(ts); -} - - -LUA_API const char *lua_pushstring (lua_State *L, const char *s) { - if (s == NULL) { - lua_pushnil(L); - return NULL; - } - else { - TString *ts; - lua_lock(L); - luaC_checkGC(L); - ts = luaS_new(L, s); - setsvalue2s(L, L->top, ts); - api_incr_top(L); - lua_unlock(L); - return getstr(ts); - } -} - - -LUA_API const char *lua_pushvfstring (lua_State *L, const char *fmt, - va_list argp) { - const char *ret; - lua_lock(L); - luaC_checkGC(L); - ret = luaO_pushvfstring(L, fmt, argp); - lua_unlock(L); - return ret; -} - - -LUA_API const char *lua_pushfstring (lua_State *L, const char *fmt, ...) { - const char *ret; - va_list argp; - lua_lock(L); - luaC_checkGC(L); - va_start(argp, fmt); - ret = luaO_pushvfstring(L, fmt, argp); - va_end(argp); - lua_unlock(L); - return ret; -} - - -LUA_API void lua_pushcclosure (lua_State *L, lua_CFunction fn, int n) { - lua_lock(L); - if (n == 0) { - setfvalue(L->top, fn); - } - else { - Closure *cl; - api_checknelems(L, n); - api_check(L, n <= MAXUPVAL, "upvalue index too large"); - luaC_checkGC(L); - cl = luaF_newCclosure(L, n); - cl->c.f = fn; - L->top -= n; - while (n--) - setobj2n(L, &cl->c.upvalue[n], L->top + n); - setclCvalue(L, L->top, cl); - } - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_pushboolean (lua_State *L, int b) { - lua_lock(L); - setbvalue(L->top, (b != 0)); /* ensure that true is 1 */ - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_pushlightuserdata (lua_State *L, void *p) { - lua_lock(L); - setpvalue(L->top, p); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API int lua_pushthread (lua_State *L) { - lua_lock(L); - setthvalue(L, L->top, L); - api_incr_top(L); - lua_unlock(L); - return (G(L)->mainthread == L); -} - - - -/* -** get functions (Lua -> stack) -*/ - - -LUA_API void lua_getglobal (lua_State *L, const char *var) { - Table *reg = hvalue(&G(L)->l_registry); - const TValue *gt; /* global table */ - lua_lock(L); - gt = luaH_getint(reg, LUA_RIDX_GLOBALS); - setsvalue2s(L, L->top++, luaS_new(L, var)); - luaV_gettable(L, gt, L->top - 1, L->top - 1); - lua_unlock(L); -} - - -LUA_API void lua_gettable (lua_State *L, int idx) { - StkId t; - lua_lock(L); - t = index2addr(L, idx); - luaV_gettable(L, t, L->top - 1, L->top - 1); - lua_unlock(L); -} - - -LUA_API void lua_getfield (lua_State *L, int idx, const char *k) { - StkId t; - lua_lock(L); - t = index2addr(L, idx); - setsvalue2s(L, L->top, luaS_new(L, k)); - api_incr_top(L); - luaV_gettable(L, t, L->top - 1, L->top - 1); - lua_unlock(L); -} - - -LUA_API void lua_rawget (lua_State *L, int idx) { - StkId t; - lua_lock(L); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - setobj2s(L, L->top - 1, luaH_get(hvalue(t), L->top - 1)); - lua_unlock(L); -} - - -LUA_API void lua_rawgeti (lua_State *L, int idx, int n) { - StkId t; - lua_lock(L); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - setobj2s(L, L->top, luaH_getint(hvalue(t), n)); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_rawgetp (lua_State *L, int idx, const void *p) { - StkId t; - TValue k; - lua_lock(L); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - setpvalue(&k, cast(void *, p)); - setobj2s(L, L->top, luaH_get(hvalue(t), &k)); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API void lua_createtable (lua_State *L, int narray, int nrec) { - Table *t; - lua_lock(L); - luaC_checkGC(L); - t = luaH_new(L); - sethvalue(L, L->top, t); - api_incr_top(L); - if (narray > 0 || nrec > 0) - luaH_resize(L, t, narray, nrec); - lua_unlock(L); -} - - -LUA_API int lua_getmetatable (lua_State *L, int objindex) { - const TValue *obj; - Table *mt = NULL; - int res; - lua_lock(L); - obj = index2addr(L, objindex); - switch (ttypenv(obj)) { - case LUA_TTABLE: - mt = hvalue(obj)->metatable; - break; - case LUA_TUSERDATA: - mt = uvalue(obj)->metatable; - break; - default: - mt = G(L)->mt[ttypenv(obj)]; - break; - } - if (mt == NULL) - res = 0; - else { - sethvalue(L, L->top, mt); - api_incr_top(L); - res = 1; - } - lua_unlock(L); - return res; -} - - -LUA_API void lua_getuservalue (lua_State *L, int idx) { - StkId o; - lua_lock(L); - o = index2addr(L, idx); - api_check(L, ttisuserdata(o), "userdata expected"); - if (uvalue(o)->env) { - sethvalue(L, L->top, uvalue(o)->env); - } else - setnilvalue(L->top); - api_incr_top(L); - lua_unlock(L); -} - - -/* -** set functions (stack -> Lua) -*/ - - -LUA_API void lua_setglobal (lua_State *L, const char *var) { - Table *reg = hvalue(&G(L)->l_registry); - const TValue *gt; /* global table */ - lua_lock(L); - api_checknelems(L, 1); - gt = luaH_getint(reg, LUA_RIDX_GLOBALS); - setsvalue2s(L, L->top++, luaS_new(L, var)); - luaV_settable(L, gt, L->top - 1, L->top - 2); - L->top -= 2; /* pop value and key */ - lua_unlock(L); -} - - -LUA_API void lua_settable (lua_State *L, int idx) { - StkId t; - lua_lock(L); - api_checknelems(L, 2); - t = index2addr(L, idx); - luaV_settable(L, t, L->top - 2, L->top - 1); - L->top -= 2; /* pop index and value */ - lua_unlock(L); -} - - -LUA_API void lua_setfield (lua_State *L, int idx, const char *k) { - StkId t; - lua_lock(L); - api_checknelems(L, 1); - t = index2addr(L, idx); - setsvalue2s(L, L->top++, luaS_new(L, k)); - luaV_settable(L, t, L->top - 1, L->top - 2); - L->top -= 2; /* pop value and key */ - lua_unlock(L); -} - - -LUA_API void lua_rawset (lua_State *L, int idx) { - StkId t; - lua_lock(L); - api_checknelems(L, 2); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - setobj2t(L, luaH_set(L, hvalue(t), L->top-2), L->top-1); - invalidateTMcache(hvalue(t)); - luaC_barrierback(L, gcvalue(t), L->top-1); - L->top -= 2; - lua_unlock(L); -} - - -LUA_API void lua_rawseti (lua_State *L, int idx, int n) { - StkId t; - lua_lock(L); - api_checknelems(L, 1); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - luaH_setint(L, hvalue(t), n, L->top - 1); - luaC_barrierback(L, gcvalue(t), L->top-1); - L->top--; - lua_unlock(L); -} - - -LUA_API void lua_rawsetp (lua_State *L, int idx, const void *p) { - StkId t; - TValue k; - lua_lock(L); - api_checknelems(L, 1); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - setpvalue(&k, cast(void *, p)); - setobj2t(L, luaH_set(L, hvalue(t), &k), L->top - 1); - luaC_barrierback(L, gcvalue(t), L->top - 1); - L->top--; - lua_unlock(L); -} - - -LUA_API int lua_setmetatable (lua_State *L, int objindex) { - TValue *obj; - Table *mt; - lua_lock(L); - api_checknelems(L, 1); - obj = index2addr(L, objindex); - if (ttisnil(L->top - 1)) - mt = NULL; - else { - api_check(L, ttistable(L->top - 1), "table expected"); - mt = hvalue(L->top - 1); - } - switch (ttypenv(obj)) { - case LUA_TTABLE: { - hvalue(obj)->metatable = mt; - if (mt) { - luaC_objbarrierback(L, gcvalue(obj), mt); - luaC_checkfinalizer(L, gcvalue(obj), mt); - } - break; - } - case LUA_TUSERDATA: { - uvalue(obj)->metatable = mt; - if (mt) { - luaC_objbarrier(L, rawuvalue(obj), mt); - luaC_checkfinalizer(L, gcvalue(obj), mt); - } - break; - } - default: { - G(L)->mt[ttypenv(obj)] = mt; - break; - } - } - L->top--; - lua_unlock(L); - return 1; -} - - -LUA_API void lua_setuservalue (lua_State *L, int idx) { - StkId o; - lua_lock(L); - api_checknelems(L, 1); - o = index2addr(L, idx); - api_check(L, ttisuserdata(o), "userdata expected"); - if (ttisnil(L->top - 1)) - uvalue(o)->env = NULL; - else { - api_check(L, ttistable(L->top - 1), "table expected"); - uvalue(o)->env = hvalue(L->top - 1); - luaC_objbarrier(L, gcvalue(o), hvalue(L->top - 1)); - } - L->top--; - lua_unlock(L); -} - - -/* -** `load' and `call' functions (run Lua code) -*/ - - -#define checkresults(L,na,nr) \ - api_check(L, (nr) == LUA_MULTRET || (L->ci->top - L->top >= (nr) - (na)), \ - "results from function overflow current stack size") - - -LUA_API int lua_getctx (lua_State *L, int *ctx) { - if (L->ci->callstatus & CIST_YIELDED) { - if (ctx) *ctx = L->ci->u.c.ctx; - return L->ci->u.c.status; - } - else return LUA_OK; -} - - -LUA_API void lua_callk (lua_State *L, int nargs, int nresults, int ctx, - lua_CFunction k) { - StkId func; - lua_lock(L); - api_check(L, k == NULL || !isLua(L->ci), - "cannot use continuations inside hooks"); - api_checknelems(L, nargs+1); - api_check(L, L->status == LUA_OK, "cannot do calls on non-normal thread"); - checkresults(L, nargs, nresults); - func = L->top - (nargs+1); - if (k != NULL && L->nny == 0) { /* need to prepare continuation? */ - L->ci->u.c.k = k; /* save continuation */ - L->ci->u.c.ctx = ctx; /* save context */ - luaD_call(L, func, nresults, 1); /* do the call */ - } - else /* no continuation or no yieldable */ - luaD_call(L, func, nresults, 0); /* just do the call */ - adjustresults(L, nresults); - lua_unlock(L); -} - - - -/* -** Execute a protected call. -*/ -struct CallS { /* data to `f_call' */ - StkId func; - int nresults; -}; - - -static void f_call (lua_State *L, void *ud) { - struct CallS *c = cast(struct CallS *, ud); - luaD_call(L, c->func, c->nresults, 0); -} - - - -LUA_API int lua_pcallk (lua_State *L, int nargs, int nresults, int errfunc, - int ctx, lua_CFunction k) { - struct CallS c; - int status; - ptrdiff_t func; - lua_lock(L); - api_check(L, k == NULL || !isLua(L->ci), - "cannot use continuations inside hooks"); - api_checknelems(L, nargs+1); - api_check(L, L->status == LUA_OK, "cannot do calls on non-normal thread"); - checkresults(L, nargs, nresults); - if (errfunc == 0) - func = 0; - else { - StkId o = index2addr(L, errfunc); - api_checkstackindex(L, errfunc, o); - func = savestack(L, o); - } - c.func = L->top - (nargs+1); /* function to be called */ - if (k == NULL || L->nny > 0) { /* no continuation or no yieldable? */ - c.nresults = nresults; /* do a 'conventional' protected call */ - status = luaD_pcall(L, f_call, &c, savestack(L, c.func), func); - } - else { /* prepare continuation (call is already protected by 'resume') */ - CallInfo *ci = L->ci; - ci->u.c.k = k; /* save continuation */ - ci->u.c.ctx = ctx; /* save context */ - /* save information for error recovery */ - ci->extra = savestack(L, c.func); - ci->u.c.old_allowhook = L->allowhook; - ci->u.c.old_errfunc = L->errfunc; - L->errfunc = func; - /* mark that function may do error recovery */ - ci->callstatus |= CIST_YPCALL; - luaD_call(L, c.func, nresults, 1); /* do the call */ - ci->callstatus &= ~CIST_YPCALL; - L->errfunc = ci->u.c.old_errfunc; - status = LUA_OK; /* if it is here, there were no errors */ - } - adjustresults(L, nresults); - lua_unlock(L); - return status; -} - - -LUA_API int lua_load (lua_State *L, lua_Reader reader, void *data, - const char *chunkname, const char *mode) { - ZIO z; - int status; - lua_lock(L); - if (!chunkname) chunkname = "?"; - luaZ_init(L, &z, reader, data); - status = luaD_protectedparser(L, &z, chunkname, mode); - if (status == LUA_OK) { /* no errors? */ - LClosure *f = clLvalue(L->top - 1); /* get newly created function */ - if (f->nupvalues == 1) { /* does it have one upvalue? */ - /* get global table from registry */ - Table *reg = hvalue(&G(L)->l_registry); - const TValue *gt = luaH_getint(reg, LUA_RIDX_GLOBALS); - /* set global table as 1st upvalue of 'f' (may be LUA_ENV) */ - setobj(L, f->upvals[0]->v, gt); - luaC_barrier(L, f->upvals[0], gt); - } - } - lua_unlock(L); - return status; -} - - -LUA_API int lua_dump (lua_State *L, lua_Writer writer, void *data) { - int status; - TValue *o; - lua_lock(L); - api_checknelems(L, 1); - o = L->top - 1; - if (isLfunction(o)) - status = luaU_dump(L, getproto(o), writer, data, 0); - else - status = 1; - lua_unlock(L); - return status; -} - - -LUA_API int lua_status (lua_State *L) { - return L->status; -} - - -/* -** Garbage-collection function -*/ - -LUA_API int lua_gc (lua_State *L, int what, int data) { - int res = 0; - global_State *g; - lua_lock(L); - g = G(L); - switch (what) { - case LUA_GCSTOP: { - g->gcrunning = 0; - break; - } - case LUA_GCRESTART: { - luaE_setdebt(g, 0); - g->gcrunning = 1; - break; - } - case LUA_GCCOLLECT: { - luaC_fullgc(L, 0); - break; - } - case LUA_GCCOUNT: { - /* GC values are expressed in Kbytes: #bytes/2^10 */ - res = cast_int(gettotalbytes(g) >> 10); - break; - } - case LUA_GCCOUNTB: { - res = cast_int(gettotalbytes(g) & 0x3ff); - break; - } - case LUA_GCSTEP: { - if (g->gckind == KGC_GEN) { /* generational mode? */ - res = (g->GCestimate == 0); /* true if it will do major collection */ - luaC_forcestep(L); /* do a single step */ - } - else { - lu_mem debt = cast(lu_mem, data) * 1024 - GCSTEPSIZE; - if (g->gcrunning) - debt += g->GCdebt; /* include current debt */ - luaE_setdebt(g, debt); - luaC_forcestep(L); - if (g->gcstate == GCSpause) /* end of cycle? */ - res = 1; /* signal it */ - } - break; - } - case LUA_GCSETPAUSE: { - res = g->gcpause; - g->gcpause = data; - break; - } - case LUA_GCSETMAJORINC: { - res = g->gcmajorinc; - g->gcmajorinc = data; - break; - } - case LUA_GCSETSTEPMUL: { - res = g->gcstepmul; - g->gcstepmul = data; - break; - } - case LUA_GCISRUNNING: { - res = g->gcrunning; - break; - } - case LUA_GCGEN: { /* change collector to generational mode */ - luaC_changemode(L, KGC_GEN); - break; - } - case LUA_GCINC: { /* change collector to incremental mode */ - luaC_changemode(L, KGC_NORMAL); - break; - } - default: res = -1; /* invalid option */ - } - lua_unlock(L); - return res; -} - - - -/* -** miscellaneous functions -*/ - - -LUA_API int lua_error (lua_State *L) { - lua_lock(L); - api_checknelems(L, 1); - luaG_errormsg(L); - /* code unreachable; will unlock when control actually leaves the kernel */ - return 0; /* to avoid warnings */ -} - - -LUA_API int lua_next (lua_State *L, int idx) { - StkId t; - int more; - lua_lock(L); - t = index2addr(L, idx); - api_check(L, ttistable(t), "table expected"); - more = luaH_next(L, hvalue(t), L->top - 1); - if (more) { - api_incr_top(L); - } - else /* no more elements */ - L->top -= 1; /* remove key */ - lua_unlock(L); - return more; -} - - -LUA_API void lua_concat (lua_State *L, int n) { - lua_lock(L); - api_checknelems(L, n); - if (n >= 2) { - luaC_checkGC(L); - luaV_concat(L, n); - } - else if (n == 0) { /* push empty string */ - setsvalue2s(L, L->top, luaS_newlstr(L, "", 0)); - api_incr_top(L); - } - /* else n == 1; nothing to do */ - lua_unlock(L); -} - - -LUA_API void lua_len (lua_State *L, int idx) { - StkId t; - lua_lock(L); - t = index2addr(L, idx); - luaV_objlen(L, L->top, t); - api_incr_top(L); - lua_unlock(L); -} - - -LUA_API lua_Alloc lua_getallocf (lua_State *L, void **ud) { - lua_Alloc f; - lua_lock(L); - if (ud) *ud = G(L)->ud; - f = G(L)->frealloc; - lua_unlock(L); - return f; -} - - -LUA_API void lua_setallocf (lua_State *L, lua_Alloc f, void *ud) { - lua_lock(L); - G(L)->ud = ud; - G(L)->frealloc = f; - lua_unlock(L); -} - - -LUA_API void *lua_newuserdata (lua_State *L, size_t size) { - Udata *u; - lua_lock(L); - luaC_checkGC(L); - u = luaS_newudata(L, size, NULL); - setuvalue(L, L->top, u); - api_incr_top(L); - lua_unlock(L); - return u + 1; -} - - - -static const char *aux_upvalue (StkId fi, int n, TValue **val, - GCObject **owner) { - switch (ttype(fi)) { - case LUA_TCCL: { /* C closure */ - CClosure *f = clCvalue(fi); - if (!(1 <= n && n <= f->nupvalues)) return NULL; - *val = &f->upvalue[n-1]; - if (owner) *owner = obj2gco(f); - return ""; - } - case LUA_TLCL: { /* Lua closure */ - LClosure *f = clLvalue(fi); - TString *name; - Proto *p = f->p; - if (!(1 <= n && n <= p->sizeupvalues)) return NULL; - *val = f->upvals[n-1]->v; - if (owner) *owner = obj2gco(f->upvals[n - 1]); - name = p->upvalues[n-1].name; - return (name == NULL) ? "" : getstr(name); - } - default: return NULL; /* not a closure */ - } -} - - -LUA_API const char *lua_getupvalue (lua_State *L, int funcindex, int n) { - const char *name; - TValue *val = NULL; /* to avoid warnings */ - lua_lock(L); - name = aux_upvalue(index2addr(L, funcindex), n, &val, NULL); - if (name) { - setobj2s(L, L->top, val); - api_incr_top(L); - } - lua_unlock(L); - return name; -} - - -LUA_API const char *lua_setupvalue (lua_State *L, int funcindex, int n) { - const char *name; - TValue *val = NULL; /* to avoid warnings */ - GCObject *owner = NULL; /* to avoid warnings */ - StkId fi; - lua_lock(L); - fi = index2addr(L, funcindex); - api_checknelems(L, 1); - name = aux_upvalue(fi, n, &val, &owner); - if (name) { - L->top--; - setobj(L, val, L->top); - luaC_barrier(L, owner, L->top); - } - lua_unlock(L); - return name; -} - - -static UpVal **getupvalref (lua_State *L, int fidx, int n, LClosure **pf) { - LClosure *f; - StkId fi = index2addr(L, fidx); - api_check(L, ttisLclosure(fi), "Lua function expected"); - f = clLvalue(fi); - api_check(L, (1 <= n && n <= f->p->sizeupvalues), "invalid upvalue index"); - if (pf) *pf = f; - return &f->upvals[n - 1]; /* get its upvalue pointer */ -} - - -LUA_API void *lua_upvalueid (lua_State *L, int fidx, int n) { - StkId fi = index2addr(L, fidx); - switch (ttype(fi)) { - case LUA_TLCL: { /* lua closure */ - return *getupvalref(L, fidx, n, NULL); - } - case LUA_TCCL: { /* C closure */ - CClosure *f = clCvalue(fi); - api_check(L, 1 <= n && n <= f->nupvalues, "invalid upvalue index"); - return &f->upvalue[n - 1]; - } - default: { - api_check(L, 0, "closure expected"); - return NULL; - } - } -} - - -LUA_API void lua_upvaluejoin (lua_State *L, int fidx1, int n1, - int fidx2, int n2) { - LClosure *f1; - UpVal **up1 = getupvalref(L, fidx1, n1, &f1); - UpVal **up2 = getupvalref(L, fidx2, n2, NULL); - *up1 = *up2; - luaC_objbarrier(L, f1, *up2); -} - diff --git a/btgui/lua-5.2.3/src/lapi.h b/btgui/lua-5.2.3/src/lapi.h deleted file mode 100644 index c7d34ad84..000000000 --- a/btgui/lua-5.2.3/src/lapi.h +++ /dev/null @@ -1,24 +0,0 @@ -/* -** $Id: lapi.h,v 2.7.1.1 2013/04/12 18:48:47 roberto Exp $ -** Auxiliary functions from Lua API -** See Copyright Notice in lua.h -*/ - -#ifndef lapi_h -#define lapi_h - - -#include "llimits.h" -#include "lstate.h" - -#define api_incr_top(L) {L->top++; api_check(L, L->top <= L->ci->top, \ - "stack overflow");} - -#define adjustresults(L,nres) \ - { if ((nres) == LUA_MULTRET && L->ci->top < L->top) L->ci->top = L->top; } - -#define api_checknelems(L,n) api_check(L, (n) < (L->top - L->ci->func), \ - "not enough elements in the stack") - - -#endif diff --git a/btgui/lua-5.2.3/src/lauxlib.c b/btgui/lua-5.2.3/src/lauxlib.c deleted file mode 100644 index b00f8c709..000000000 --- a/btgui/lua-5.2.3/src/lauxlib.c +++ /dev/null @@ -1,959 +0,0 @@ -/* -** $Id: lauxlib.c,v 1.248.1.1 2013/04/12 18:48:47 roberto Exp $ -** Auxiliary functions for building Lua libraries -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include -#include -#include - - -/* This file uses only the official API of Lua. -** Any function declared here could be written as an application function. -*/ - -#define lauxlib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" - - -/* -** {====================================================== -** Traceback -** ======================================================= -*/ - - -#define LEVELS1 12 /* size of the first part of the stack */ -#define LEVELS2 10 /* size of the second part of the stack */ - - - -/* -** search for 'objidx' in table at index -1. -** return 1 + string at top if find a good name. -*/ -static int findfield (lua_State *L, int objidx, int level) { - if (level == 0 || !lua_istable(L, -1)) - return 0; /* not found */ - lua_pushnil(L); /* start 'next' loop */ - while (lua_next(L, -2)) { /* for each pair in table */ - if (lua_type(L, -2) == LUA_TSTRING) { /* ignore non-string keys */ - if (lua_rawequal(L, objidx, -1)) { /* found object? */ - lua_pop(L, 1); /* remove value (but keep name) */ - return 1; - } - else if (findfield(L, objidx, level - 1)) { /* try recursively */ - lua_remove(L, -2); /* remove table (but keep name) */ - lua_pushliteral(L, "."); - lua_insert(L, -2); /* place '.' between the two names */ - lua_concat(L, 3); - return 1; - } - } - lua_pop(L, 1); /* remove value */ - } - return 0; /* not found */ -} - - -static int pushglobalfuncname (lua_State *L, lua_Debug *ar) { - int top = lua_gettop(L); - lua_getinfo(L, "f", ar); /* push function */ - lua_pushglobaltable(L); - if (findfield(L, top + 1, 2)) { - lua_copy(L, -1, top + 1); /* move name to proper place */ - lua_pop(L, 2); /* remove pushed values */ - return 1; - } - else { - lua_settop(L, top); /* remove function and global table */ - return 0; - } -} - - -static void pushfuncname (lua_State *L, lua_Debug *ar) { - if (*ar->namewhat != '\0') /* is there a name? */ - lua_pushfstring(L, "function " LUA_QS, ar->name); - else if (*ar->what == 'm') /* main? */ - lua_pushliteral(L, "main chunk"); - else if (*ar->what == 'C') { - if (pushglobalfuncname(L, ar)) { - lua_pushfstring(L, "function " LUA_QS, lua_tostring(L, -1)); - lua_remove(L, -2); /* remove name */ - } - else - lua_pushliteral(L, "?"); - } - else - lua_pushfstring(L, "function <%s:%d>", ar->short_src, ar->linedefined); -} - - -static int countlevels (lua_State *L) { - lua_Debug ar; - int li = 1, le = 1; - /* find an upper bound */ - while (lua_getstack(L, le, &ar)) { li = le; le *= 2; } - /* do a binary search */ - while (li < le) { - int m = (li + le)/2; - if (lua_getstack(L, m, &ar)) li = m + 1; - else le = m; - } - return le - 1; -} - - -LUALIB_API void luaL_traceback (lua_State *L, lua_State *L1, - const char *msg, int level) { - lua_Debug ar; - int top = lua_gettop(L); - int numlevels = countlevels(L1); - int mark = (numlevels > LEVELS1 + LEVELS2) ? LEVELS1 : 0; - if (msg) lua_pushfstring(L, "%s\n", msg); - lua_pushliteral(L, "stack traceback:"); - while (lua_getstack(L1, level++, &ar)) { - if (level == mark) { /* too many levels? */ - lua_pushliteral(L, "\n\t..."); /* add a '...' */ - level = numlevels - LEVELS2; /* and skip to last ones */ - } - else { - lua_getinfo(L1, "Slnt", &ar); - lua_pushfstring(L, "\n\t%s:", ar.short_src); - if (ar.currentline > 0) - lua_pushfstring(L, "%d:", ar.currentline); - lua_pushliteral(L, " in "); - pushfuncname(L, &ar); - if (ar.istailcall) - lua_pushliteral(L, "\n\t(...tail calls...)"); - lua_concat(L, lua_gettop(L) - top); - } - } - lua_concat(L, lua_gettop(L) - top); -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Error-report functions -** ======================================================= -*/ - -LUALIB_API int luaL_argerror (lua_State *L, int narg, const char *extramsg) { - lua_Debug ar; - if (!lua_getstack(L, 0, &ar)) /* no stack frame? */ - return luaL_error(L, "bad argument #%d (%s)", narg, extramsg); - lua_getinfo(L, "n", &ar); - if (strcmp(ar.namewhat, "method") == 0) { - narg--; /* do not count `self' */ - if (narg == 0) /* error is in the self argument itself? */ - return luaL_error(L, "calling " LUA_QS " on bad self (%s)", - ar.name, extramsg); - } - if (ar.name == NULL) - ar.name = (pushglobalfuncname(L, &ar)) ? lua_tostring(L, -1) : "?"; - return luaL_error(L, "bad argument #%d to " LUA_QS " (%s)", - narg, ar.name, extramsg); -} - - -static int typeerror (lua_State *L, int narg, const char *tname) { - const char *msg = lua_pushfstring(L, "%s expected, got %s", - tname, luaL_typename(L, narg)); - return luaL_argerror(L, narg, msg); -} - - -static void tag_error (lua_State *L, int narg, int tag) { - typeerror(L, narg, lua_typename(L, tag)); -} - - -LUALIB_API void luaL_where (lua_State *L, int level) { - lua_Debug ar; - if (lua_getstack(L, level, &ar)) { /* check function at level */ - lua_getinfo(L, "Sl", &ar); /* get info about it */ - if (ar.currentline > 0) { /* is there info? */ - lua_pushfstring(L, "%s:%d: ", ar.short_src, ar.currentline); - return; - } - } - lua_pushliteral(L, ""); /* else, no information available... */ -} - - -LUALIB_API int luaL_error (lua_State *L, const char *fmt, ...) { - va_list argp; - va_start(argp, fmt); - luaL_where(L, 1); - lua_pushvfstring(L, fmt, argp); - va_end(argp); - lua_concat(L, 2); - return lua_error(L); -} - - -LUALIB_API int luaL_fileresult (lua_State *L, int stat, const char *fname) { - int en = errno; /* calls to Lua API may change this value */ - if (stat) { - lua_pushboolean(L, 1); - return 1; - } - else { - lua_pushnil(L); - if (fname) - lua_pushfstring(L, "%s: %s", fname, strerror(en)); - else - lua_pushstring(L, strerror(en)); - lua_pushinteger(L, en); - return 3; - } -} - - -#if !defined(inspectstat) /* { */ - -#if defined(LUA_USE_POSIX) - -#include - -/* -** use appropriate macros to interpret 'pclose' return status -*/ -#define inspectstat(stat,what) \ - if (WIFEXITED(stat)) { stat = WEXITSTATUS(stat); } \ - else if (WIFSIGNALED(stat)) { stat = WTERMSIG(stat); what = "signal"; } - -#else - -#define inspectstat(stat,what) /* no op */ - -#endif - -#endif /* } */ - - -LUALIB_API int luaL_execresult (lua_State *L, int stat) { - const char *what = "exit"; /* type of termination */ - if (stat == -1) /* error? */ - return luaL_fileresult(L, 0, NULL); - else { - inspectstat(stat, what); /* interpret result */ - if (*what == 'e' && stat == 0) /* successful termination? */ - lua_pushboolean(L, 1); - else - lua_pushnil(L); - lua_pushstring(L, what); - lua_pushinteger(L, stat); - return 3; /* return true/nil,what,code */ - } -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Userdata's metatable manipulation -** ======================================================= -*/ - -LUALIB_API int luaL_newmetatable (lua_State *L, const char *tname) { - luaL_getmetatable(L, tname); /* try to get metatable */ - if (!lua_isnil(L, -1)) /* name already in use? */ - return 0; /* leave previous value on top, but return 0 */ - lua_pop(L, 1); - lua_newtable(L); /* create metatable */ - lua_pushvalue(L, -1); - lua_setfield(L, LUA_REGISTRYINDEX, tname); /* registry.name = metatable */ - return 1; -} - - -LUALIB_API void luaL_setmetatable (lua_State *L, const char *tname) { - luaL_getmetatable(L, tname); - lua_setmetatable(L, -2); -} - - -LUALIB_API void *luaL_testudata (lua_State *L, int ud, const char *tname) { - void *p = lua_touserdata(L, ud); - if (p != NULL) { /* value is a userdata? */ - if (lua_getmetatable(L, ud)) { /* does it have a metatable? */ - luaL_getmetatable(L, tname); /* get correct metatable */ - if (!lua_rawequal(L, -1, -2)) /* not the same? */ - p = NULL; /* value is a userdata with wrong metatable */ - lua_pop(L, 2); /* remove both metatables */ - return p; - } - } - return NULL; /* value is not a userdata with a metatable */ -} - - -LUALIB_API void *luaL_checkudata (lua_State *L, int ud, const char *tname) { - void *p = luaL_testudata(L, ud, tname); - if (p == NULL) typeerror(L, ud, tname); - return p; -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Argument check functions -** ======================================================= -*/ - -LUALIB_API int luaL_checkoption (lua_State *L, int narg, const char *def, - const char *const lst[]) { - const char *name = (def) ? luaL_optstring(L, narg, def) : - luaL_checkstring(L, narg); - int i; - for (i=0; lst[i]; i++) - if (strcmp(lst[i], name) == 0) - return i; - return luaL_argerror(L, narg, - lua_pushfstring(L, "invalid option " LUA_QS, name)); -} - - -LUALIB_API void luaL_checkstack (lua_State *L, int space, const char *msg) { - /* keep some extra space to run error routines, if needed */ - const int extra = LUA_MINSTACK; - if (!lua_checkstack(L, space + extra)) { - if (msg) - luaL_error(L, "stack overflow (%s)", msg); - else - luaL_error(L, "stack overflow"); - } -} - - -LUALIB_API void luaL_checktype (lua_State *L, int narg, int t) { - if (lua_type(L, narg) != t) - tag_error(L, narg, t); -} - - -LUALIB_API void luaL_checkany (lua_State *L, int narg) { - if (lua_type(L, narg) == LUA_TNONE) - luaL_argerror(L, narg, "value expected"); -} - - -LUALIB_API const char *luaL_checklstring (lua_State *L, int narg, size_t *len) { - const char *s = lua_tolstring(L, narg, len); - if (!s) tag_error(L, narg, LUA_TSTRING); - return s; -} - - -LUALIB_API const char *luaL_optlstring (lua_State *L, int narg, - const char *def, size_t *len) { - if (lua_isnoneornil(L, narg)) { - if (len) - *len = (def ? strlen(def) : 0); - return def; - } - else return luaL_checklstring(L, narg, len); -} - - -LUALIB_API lua_Number luaL_checknumber (lua_State *L, int narg) { - int isnum; - lua_Number d = lua_tonumberx(L, narg, &isnum); - if (!isnum) - tag_error(L, narg, LUA_TNUMBER); - return d; -} - - -LUALIB_API lua_Number luaL_optnumber (lua_State *L, int narg, lua_Number def) { - return luaL_opt(L, luaL_checknumber, narg, def); -} - - -LUALIB_API lua_Integer luaL_checkinteger (lua_State *L, int narg) { - int isnum; - lua_Integer d = lua_tointegerx(L, narg, &isnum); - if (!isnum) - tag_error(L, narg, LUA_TNUMBER); - return d; -} - - -LUALIB_API lua_Unsigned luaL_checkunsigned (lua_State *L, int narg) { - int isnum; - lua_Unsigned d = lua_tounsignedx(L, narg, &isnum); - if (!isnum) - tag_error(L, narg, LUA_TNUMBER); - return d; -} - - -LUALIB_API lua_Integer luaL_optinteger (lua_State *L, int narg, - lua_Integer def) { - return luaL_opt(L, luaL_checkinteger, narg, def); -} - - -LUALIB_API lua_Unsigned luaL_optunsigned (lua_State *L, int narg, - lua_Unsigned def) { - return luaL_opt(L, luaL_checkunsigned, narg, def); -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Generic Buffer manipulation -** ======================================================= -*/ - -/* -** check whether buffer is using a userdata on the stack as a temporary -** buffer -*/ -#define buffonstack(B) ((B)->b != (B)->initb) - - -/* -** returns a pointer to a free area with at least 'sz' bytes -*/ -LUALIB_API char *luaL_prepbuffsize (luaL_Buffer *B, size_t sz) { - lua_State *L = B->L; - if (B->size - B->n < sz) { /* not enough space? */ - char *newbuff; - size_t newsize = B->size * 2; /* double buffer size */ - if (newsize - B->n < sz) /* not big enough? */ - newsize = B->n + sz; - if (newsize < B->n || newsize - B->n < sz) - luaL_error(L, "buffer too large"); - /* create larger buffer */ - newbuff = (char *)lua_newuserdata(L, newsize * sizeof(char)); - /* move content to new buffer */ - memcpy(newbuff, B->b, B->n * sizeof(char)); - if (buffonstack(B)) - lua_remove(L, -2); /* remove old buffer */ - B->b = newbuff; - B->size = newsize; - } - return &B->b[B->n]; -} - - -LUALIB_API void luaL_addlstring (luaL_Buffer *B, const char *s, size_t l) { - char *b = luaL_prepbuffsize(B, l); - memcpy(b, s, l * sizeof(char)); - luaL_addsize(B, l); -} - - -LUALIB_API void luaL_addstring (luaL_Buffer *B, const char *s) { - luaL_addlstring(B, s, strlen(s)); -} - - -LUALIB_API void luaL_pushresult (luaL_Buffer *B) { - lua_State *L = B->L; - lua_pushlstring(L, B->b, B->n); - if (buffonstack(B)) - lua_remove(L, -2); /* remove old buffer */ -} - - -LUALIB_API void luaL_pushresultsize (luaL_Buffer *B, size_t sz) { - luaL_addsize(B, sz); - luaL_pushresult(B); -} - - -LUALIB_API void luaL_addvalue (luaL_Buffer *B) { - lua_State *L = B->L; - size_t l; - const char *s = lua_tolstring(L, -1, &l); - if (buffonstack(B)) - lua_insert(L, -2); /* put value below buffer */ - luaL_addlstring(B, s, l); - lua_remove(L, (buffonstack(B)) ? -2 : -1); /* remove value */ -} - - -LUALIB_API void luaL_buffinit (lua_State *L, luaL_Buffer *B) { - B->L = L; - B->b = B->initb; - B->n = 0; - B->size = LUAL_BUFFERSIZE; -} - - -LUALIB_API char *luaL_buffinitsize (lua_State *L, luaL_Buffer *B, size_t sz) { - luaL_buffinit(L, B); - return luaL_prepbuffsize(B, sz); -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Reference system -** ======================================================= -*/ - -/* index of free-list header */ -#define freelist 0 - - -LUALIB_API int luaL_ref (lua_State *L, int t) { - int ref; - if (lua_isnil(L, -1)) { - lua_pop(L, 1); /* remove from stack */ - return LUA_REFNIL; /* `nil' has a unique fixed reference */ - } - t = lua_absindex(L, t); - lua_rawgeti(L, t, freelist); /* get first free element */ - ref = (int)lua_tointeger(L, -1); /* ref = t[freelist] */ - lua_pop(L, 1); /* remove it from stack */ - if (ref != 0) { /* any free element? */ - lua_rawgeti(L, t, ref); /* remove it from list */ - lua_rawseti(L, t, freelist); /* (t[freelist] = t[ref]) */ - } - else /* no free elements */ - ref = (int)lua_rawlen(L, t) + 1; /* get a new reference */ - lua_rawseti(L, t, ref); - return ref; -} - - -LUALIB_API void luaL_unref (lua_State *L, int t, int ref) { - if (ref >= 0) { - t = lua_absindex(L, t); - lua_rawgeti(L, t, freelist); - lua_rawseti(L, t, ref); /* t[ref] = t[freelist] */ - lua_pushinteger(L, ref); - lua_rawseti(L, t, freelist); /* t[freelist] = ref */ - } -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Load functions -** ======================================================= -*/ - -typedef struct LoadF { - int n; /* number of pre-read characters */ - FILE *f; /* file being read */ - char buff[LUAL_BUFFERSIZE]; /* area for reading file */ -} LoadF; - - -static const char *getF (lua_State *L, void *ud, size_t *size) { - LoadF *lf = (LoadF *)ud; - (void)L; /* not used */ - if (lf->n > 0) { /* are there pre-read characters to be read? */ - *size = lf->n; /* return them (chars already in buffer) */ - lf->n = 0; /* no more pre-read characters */ - } - else { /* read a block from file */ - /* 'fread' can return > 0 *and* set the EOF flag. If next call to - 'getF' called 'fread', it might still wait for user input. - The next check avoids this problem. */ - if (feof(lf->f)) return NULL; - *size = fread(lf->buff, 1, sizeof(lf->buff), lf->f); /* read block */ - } - return lf->buff; -} - - -static int errfile (lua_State *L, const char *what, int fnameindex) { - const char *serr = strerror(errno); - const char *filename = lua_tostring(L, fnameindex) + 1; - lua_pushfstring(L, "cannot %s %s: %s", what, filename, serr); - lua_remove(L, fnameindex); - return LUA_ERRFILE; -} - - -static int skipBOM (LoadF *lf) { - const char *p = "\xEF\xBB\xBF"; /* Utf8 BOM mark */ - int c; - lf->n = 0; - do { - c = getc(lf->f); - if (c == EOF || c != *(const unsigned char *)p++) return c; - lf->buff[lf->n++] = c; /* to be read by the parser */ - } while (*p != '\0'); - lf->n = 0; /* prefix matched; discard it */ - return getc(lf->f); /* return next character */ -} - - -/* -** reads the first character of file 'f' and skips an optional BOM mark -** in its beginning plus its first line if it starts with '#'. Returns -** true if it skipped the first line. In any case, '*cp' has the -** first "valid" character of the file (after the optional BOM and -** a first-line comment). -*/ -static int skipcomment (LoadF *lf, int *cp) { - int c = *cp = skipBOM(lf); - if (c == '#') { /* first line is a comment (Unix exec. file)? */ - do { /* skip first line */ - c = getc(lf->f); - } while (c != EOF && c != '\n') ; - *cp = getc(lf->f); /* skip end-of-line, if present */ - return 1; /* there was a comment */ - } - else return 0; /* no comment */ -} - - -LUALIB_API int luaL_loadfilex (lua_State *L, const char *filename, - const char *mode) { - LoadF lf; - int status, readstatus; - int c; - int fnameindex = lua_gettop(L) + 1; /* index of filename on the stack */ - if (filename == NULL) { - lua_pushliteral(L, "=stdin"); - lf.f = stdin; - } - else { - lua_pushfstring(L, "@%s", filename); - lf.f = fopen(filename, "r"); - if (lf.f == NULL) return errfile(L, "open", fnameindex); - } - if (skipcomment(&lf, &c)) /* read initial portion */ - lf.buff[lf.n++] = '\n'; /* add line to correct line numbers */ - if (c == LUA_SIGNATURE[0] && filename) { /* binary file? */ - lf.f = freopen(filename, "rb", lf.f); /* reopen in binary mode */ - if (lf.f == NULL) return errfile(L, "reopen", fnameindex); - skipcomment(&lf, &c); /* re-read initial portion */ - } - if (c != EOF) - lf.buff[lf.n++] = c; /* 'c' is the first character of the stream */ - status = lua_load(L, getF, &lf, lua_tostring(L, -1), mode); - readstatus = ferror(lf.f); - if (filename) fclose(lf.f); /* close file (even in case of errors) */ - if (readstatus) { - lua_settop(L, fnameindex); /* ignore results from `lua_load' */ - return errfile(L, "read", fnameindex); - } - lua_remove(L, fnameindex); - return status; -} - - -typedef struct LoadS { - const char *s; - size_t size; -} LoadS; - - -static const char *getS (lua_State *L, void *ud, size_t *size) { - LoadS *ls = (LoadS *)ud; - (void)L; /* not used */ - if (ls->size == 0) return NULL; - *size = ls->size; - ls->size = 0; - return ls->s; -} - - -LUALIB_API int luaL_loadbufferx (lua_State *L, const char *buff, size_t size, - const char *name, const char *mode) { - LoadS ls; - ls.s = buff; - ls.size = size; - return lua_load(L, getS, &ls, name, mode); -} - - -LUALIB_API int luaL_loadstring (lua_State *L, const char *s) { - return luaL_loadbuffer(L, s, strlen(s), s); -} - -/* }====================================================== */ - - - -LUALIB_API int luaL_getmetafield (lua_State *L, int obj, const char *event) { - if (!lua_getmetatable(L, obj)) /* no metatable? */ - return 0; - lua_pushstring(L, event); - lua_rawget(L, -2); - if (lua_isnil(L, -1)) { - lua_pop(L, 2); /* remove metatable and metafield */ - return 0; - } - else { - lua_remove(L, -2); /* remove only metatable */ - return 1; - } -} - - -LUALIB_API int luaL_callmeta (lua_State *L, int obj, const char *event) { - obj = lua_absindex(L, obj); - if (!luaL_getmetafield(L, obj, event)) /* no metafield? */ - return 0; - lua_pushvalue(L, obj); - lua_call(L, 1, 1); - return 1; -} - - -LUALIB_API int luaL_len (lua_State *L, int idx) { - int l; - int isnum; - lua_len(L, idx); - l = (int)lua_tointegerx(L, -1, &isnum); - if (!isnum) - luaL_error(L, "object length is not a number"); - lua_pop(L, 1); /* remove object */ - return l; -} - - -LUALIB_API const char *luaL_tolstring (lua_State *L, int idx, size_t *len) { - if (!luaL_callmeta(L, idx, "__tostring")) { /* no metafield? */ - switch (lua_type(L, idx)) { - case LUA_TNUMBER: - case LUA_TSTRING: - lua_pushvalue(L, idx); - break; - case LUA_TBOOLEAN: - lua_pushstring(L, (lua_toboolean(L, idx) ? "true" : "false")); - break; - case LUA_TNIL: - lua_pushliteral(L, "nil"); - break; - default: - lua_pushfstring(L, "%s: %p", luaL_typename(L, idx), - lua_topointer(L, idx)); - break; - } - } - return lua_tolstring(L, -1, len); -} - - -/* -** {====================================================== -** Compatibility with 5.1 module functions -** ======================================================= -*/ -#if defined(LUA_COMPAT_MODULE) - -static const char *luaL_findtable (lua_State *L, int idx, - const char *fname, int szhint) { - const char *e; - if (idx) lua_pushvalue(L, idx); - do { - e = strchr(fname, '.'); - if (e == NULL) e = fname + strlen(fname); - lua_pushlstring(L, fname, e - fname); - lua_rawget(L, -2); - if (lua_isnil(L, -1)) { /* no such field? */ - lua_pop(L, 1); /* remove this nil */ - lua_createtable(L, 0, (*e == '.' ? 1 : szhint)); /* new table for field */ - lua_pushlstring(L, fname, e - fname); - lua_pushvalue(L, -2); - lua_settable(L, -4); /* set new table into field */ - } - else if (!lua_istable(L, -1)) { /* field has a non-table value? */ - lua_pop(L, 2); /* remove table and value */ - return fname; /* return problematic part of the name */ - } - lua_remove(L, -2); /* remove previous table */ - fname = e + 1; - } while (*e == '.'); - return NULL; -} - - -/* -** Count number of elements in a luaL_Reg list. -*/ -static int libsize (const luaL_Reg *l) { - int size = 0; - for (; l && l->name; l++) size++; - return size; -} - - -/* -** Find or create a module table with a given name. The function -** first looks at the _LOADED table and, if that fails, try a -** global variable with that name. In any case, leaves on the stack -** the module table. -*/ -LUALIB_API void luaL_pushmodule (lua_State *L, const char *modname, - int sizehint) { - luaL_findtable(L, LUA_REGISTRYINDEX, "_LOADED", 1); /* get _LOADED table */ - lua_getfield(L, -1, modname); /* get _LOADED[modname] */ - if (!lua_istable(L, -1)) { /* not found? */ - lua_pop(L, 1); /* remove previous result */ - /* try global variable (and create one if it does not exist) */ - lua_pushglobaltable(L); - if (luaL_findtable(L, 0, modname, sizehint) != NULL) - luaL_error(L, "name conflict for module " LUA_QS, modname); - lua_pushvalue(L, -1); - lua_setfield(L, -3, modname); /* _LOADED[modname] = new table */ - } - lua_remove(L, -2); /* remove _LOADED table */ -} - - -LUALIB_API void luaL_openlib (lua_State *L, const char *libname, - const luaL_Reg *l, int nup) { - luaL_checkversion(L); - if (libname) { - luaL_pushmodule(L, libname, libsize(l)); /* get/create library table */ - lua_insert(L, -(nup + 1)); /* move library table to below upvalues */ - } - if (l) - luaL_setfuncs(L, l, nup); - else - lua_pop(L, nup); /* remove upvalues */ -} - -#endif -/* }====================================================== */ - -/* -** set functions from list 'l' into table at top - 'nup'; each -** function gets the 'nup' elements at the top as upvalues. -** Returns with only the table at the stack. -*/ -LUALIB_API void luaL_setfuncs (lua_State *L, const luaL_Reg *l, int nup) { - luaL_checkversion(L); - luaL_checkstack(L, nup, "too many upvalues"); - for (; l->name != NULL; l++) { /* fill the table with given functions */ - int i; - for (i = 0; i < nup; i++) /* copy upvalues to the top */ - lua_pushvalue(L, -nup); - lua_pushcclosure(L, l->func, nup); /* closure with those upvalues */ - lua_setfield(L, -(nup + 2), l->name); - } - lua_pop(L, nup); /* remove upvalues */ -} - - -/* -** ensure that stack[idx][fname] has a table and push that table -** into the stack -*/ -LUALIB_API int luaL_getsubtable (lua_State *L, int idx, const char *fname) { - lua_getfield(L, idx, fname); - if (lua_istable(L, -1)) return 1; /* table already there */ - else { - lua_pop(L, 1); /* remove previous result */ - idx = lua_absindex(L, idx); - lua_newtable(L); - lua_pushvalue(L, -1); /* copy to be left at top */ - lua_setfield(L, idx, fname); /* assign new table to field */ - return 0; /* false, because did not find table there */ - } -} - - -/* -** stripped-down 'require'. Calls 'openf' to open a module, -** registers the result in 'package.loaded' table and, if 'glb' -** is true, also registers the result in the global table. -** Leaves resulting module on the top. -*/ -LUALIB_API void luaL_requiref (lua_State *L, const char *modname, - lua_CFunction openf, int glb) { - lua_pushcfunction(L, openf); - lua_pushstring(L, modname); /* argument to open function */ - lua_call(L, 1, 1); /* open module */ - luaL_getsubtable(L, LUA_REGISTRYINDEX, "_LOADED"); - lua_pushvalue(L, -2); /* make copy of module (call result) */ - lua_setfield(L, -2, modname); /* _LOADED[modname] = module */ - lua_pop(L, 1); /* remove _LOADED table */ - if (glb) { - lua_pushvalue(L, -1); /* copy of 'mod' */ - lua_setglobal(L, modname); /* _G[modname] = module */ - } -} - - -LUALIB_API const char *luaL_gsub (lua_State *L, const char *s, const char *p, - const char *r) { - const char *wild; - size_t l = strlen(p); - luaL_Buffer b; - luaL_buffinit(L, &b); - while ((wild = strstr(s, p)) != NULL) { - luaL_addlstring(&b, s, wild - s); /* push prefix */ - luaL_addstring(&b, r); /* push replacement in place of pattern */ - s = wild + l; /* continue after `p' */ - } - luaL_addstring(&b, s); /* push last suffix */ - luaL_pushresult(&b); - return lua_tostring(L, -1); -} - - -static void *l_alloc (void *ud, void *ptr, size_t osize, size_t nsize) { - (void)ud; (void)osize; /* not used */ - if (nsize == 0) { - free(ptr); - return NULL; - } - else - return realloc(ptr, nsize); -} - - -static int panic (lua_State *L) { - luai_writestringerror("PANIC: unprotected error in call to Lua API (%s)\n", - lua_tostring(L, -1)); - return 0; /* return to Lua to abort */ -} - - -LUALIB_API lua_State *luaL_newstate (void) { - lua_State *L = lua_newstate(l_alloc, NULL); - if (L) lua_atpanic(L, &panic); - return L; -} - - -LUALIB_API void luaL_checkversion_ (lua_State *L, lua_Number ver) { - const lua_Number *v = lua_version(L); - if (v != lua_version(NULL)) - luaL_error(L, "multiple Lua VMs detected"); - else if (*v != ver) - luaL_error(L, "version mismatch: app. needs %f, Lua core provides %f", - ver, *v); - /* check conversions number -> integer types */ - lua_pushnumber(L, -(lua_Number)0x1234); - if (lua_tointeger(L, -1) != -0x1234 || - lua_tounsigned(L, -1) != (lua_Unsigned)-0x1234) - luaL_error(L, "bad conversion number->int;" - " must recompile Lua with proper settings"); - lua_pop(L, 1); -} - diff --git a/btgui/lua-5.2.3/src/lauxlib.h b/btgui/lua-5.2.3/src/lauxlib.h deleted file mode 100644 index 0fb023b8e..000000000 --- a/btgui/lua-5.2.3/src/lauxlib.h +++ /dev/null @@ -1,212 +0,0 @@ -/* -** $Id: lauxlib.h,v 1.120.1.1 2013/04/12 18:48:47 roberto Exp $ -** Auxiliary functions for building Lua libraries -** See Copyright Notice in lua.h -*/ - - -#ifndef lauxlib_h -#define lauxlib_h - - -#include -#include - -#include "lua.h" - - - -/* extra error code for `luaL_load' */ -#define LUA_ERRFILE (LUA_ERRERR+1) - - -typedef struct luaL_Reg { - const char *name; - lua_CFunction func; -} luaL_Reg; - - -LUALIB_API void (luaL_checkversion_) (lua_State *L, lua_Number ver); -#define luaL_checkversion(L) luaL_checkversion_(L, LUA_VERSION_NUM) - -LUALIB_API int (luaL_getmetafield) (lua_State *L, int obj, const char *e); -LUALIB_API int (luaL_callmeta) (lua_State *L, int obj, const char *e); -LUALIB_API const char *(luaL_tolstring) (lua_State *L, int idx, size_t *len); -LUALIB_API int (luaL_argerror) (lua_State *L, int numarg, const char *extramsg); -LUALIB_API const char *(luaL_checklstring) (lua_State *L, int numArg, - size_t *l); -LUALIB_API const char *(luaL_optlstring) (lua_State *L, int numArg, - const char *def, size_t *l); -LUALIB_API lua_Number (luaL_checknumber) (lua_State *L, int numArg); -LUALIB_API lua_Number (luaL_optnumber) (lua_State *L, int nArg, lua_Number def); - -LUALIB_API lua_Integer (luaL_checkinteger) (lua_State *L, int numArg); -LUALIB_API lua_Integer (luaL_optinteger) (lua_State *L, int nArg, - lua_Integer def); -LUALIB_API lua_Unsigned (luaL_checkunsigned) (lua_State *L, int numArg); -LUALIB_API lua_Unsigned (luaL_optunsigned) (lua_State *L, int numArg, - lua_Unsigned def); - -LUALIB_API void (luaL_checkstack) (lua_State *L, int sz, const char *msg); -LUALIB_API void (luaL_checktype) (lua_State *L, int narg, int t); -LUALIB_API void (luaL_checkany) (lua_State *L, int narg); - -LUALIB_API int (luaL_newmetatable) (lua_State *L, const char *tname); -LUALIB_API void (luaL_setmetatable) (lua_State *L, const char *tname); -LUALIB_API void *(luaL_testudata) (lua_State *L, int ud, const char *tname); -LUALIB_API void *(luaL_checkudata) (lua_State *L, int ud, const char *tname); - -LUALIB_API void (luaL_where) (lua_State *L, int lvl); -LUALIB_API int (luaL_error) (lua_State *L, const char *fmt, ...); - -LUALIB_API int (luaL_checkoption) (lua_State *L, int narg, const char *def, - const char *const lst[]); - -LUALIB_API int (luaL_fileresult) (lua_State *L, int stat, const char *fname); -LUALIB_API int (luaL_execresult) (lua_State *L, int stat); - -/* pre-defined references */ -#define LUA_NOREF (-2) -#define LUA_REFNIL (-1) - -LUALIB_API int (luaL_ref) (lua_State *L, int t); -LUALIB_API void (luaL_unref) (lua_State *L, int t, int ref); - -LUALIB_API int (luaL_loadfilex) (lua_State *L, const char *filename, - const char *mode); - -#define luaL_loadfile(L,f) luaL_loadfilex(L,f,NULL) - -LUALIB_API int (luaL_loadbufferx) (lua_State *L, const char *buff, size_t sz, - const char *name, const char *mode); -LUALIB_API int (luaL_loadstring) (lua_State *L, const char *s); - -LUALIB_API lua_State *(luaL_newstate) (void); - -LUALIB_API int (luaL_len) (lua_State *L, int idx); - -LUALIB_API const char *(luaL_gsub) (lua_State *L, const char *s, const char *p, - const char *r); - -LUALIB_API void (luaL_setfuncs) (lua_State *L, const luaL_Reg *l, int nup); - -LUALIB_API int (luaL_getsubtable) (lua_State *L, int idx, const char *fname); - -LUALIB_API void (luaL_traceback) (lua_State *L, lua_State *L1, - const char *msg, int level); - -LUALIB_API void (luaL_requiref) (lua_State *L, const char *modname, - lua_CFunction openf, int glb); - -/* -** =============================================================== -** some useful macros -** =============================================================== -*/ - - -#define luaL_newlibtable(L,l) \ - lua_createtable(L, 0, sizeof(l)/sizeof((l)[0]) - 1) - -#define luaL_newlib(L,l) (luaL_newlibtable(L,l), luaL_setfuncs(L,l,0)) - -#define luaL_argcheck(L, cond,numarg,extramsg) \ - ((void)((cond) || luaL_argerror(L, (numarg), (extramsg)))) -#define luaL_checkstring(L,n) (luaL_checklstring(L, (n), NULL)) -#define luaL_optstring(L,n,d) (luaL_optlstring(L, (n), (d), NULL)) -#define luaL_checkint(L,n) ((int)luaL_checkinteger(L, (n))) -#define luaL_optint(L,n,d) ((int)luaL_optinteger(L, (n), (d))) -#define luaL_checklong(L,n) ((long)luaL_checkinteger(L, (n))) -#define luaL_optlong(L,n,d) ((long)luaL_optinteger(L, (n), (d))) - -#define luaL_typename(L,i) lua_typename(L, lua_type(L,(i))) - -#define luaL_dofile(L, fn) \ - (luaL_loadfile(L, fn) || lua_pcall(L, 0, LUA_MULTRET, 0)) - -#define luaL_dostring(L, s) \ - (luaL_loadstring(L, s) || lua_pcall(L, 0, LUA_MULTRET, 0)) - -#define luaL_getmetatable(L,n) (lua_getfield(L, LUA_REGISTRYINDEX, (n))) - -#define luaL_opt(L,f,n,d) (lua_isnoneornil(L,(n)) ? (d) : f(L,(n))) - -#define luaL_loadbuffer(L,s,sz,n) luaL_loadbufferx(L,s,sz,n,NULL) - - -/* -** {====================================================== -** Generic Buffer manipulation -** ======================================================= -*/ - -typedef struct luaL_Buffer { - char *b; /* buffer address */ - size_t size; /* buffer size */ - size_t n; /* number of characters in buffer */ - lua_State *L; - char initb[LUAL_BUFFERSIZE]; /* initial buffer */ -} luaL_Buffer; - - -#define luaL_addchar(B,c) \ - ((void)((B)->n < (B)->size || luaL_prepbuffsize((B), 1)), \ - ((B)->b[(B)->n++] = (c))) - -#define luaL_addsize(B,s) ((B)->n += (s)) - -LUALIB_API void (luaL_buffinit) (lua_State *L, luaL_Buffer *B); -LUALIB_API char *(luaL_prepbuffsize) (luaL_Buffer *B, size_t sz); -LUALIB_API void (luaL_addlstring) (luaL_Buffer *B, const char *s, size_t l); -LUALIB_API void (luaL_addstring) (luaL_Buffer *B, const char *s); -LUALIB_API void (luaL_addvalue) (luaL_Buffer *B); -LUALIB_API void (luaL_pushresult) (luaL_Buffer *B); -LUALIB_API void (luaL_pushresultsize) (luaL_Buffer *B, size_t sz); -LUALIB_API char *(luaL_buffinitsize) (lua_State *L, luaL_Buffer *B, size_t sz); - -#define luaL_prepbuffer(B) luaL_prepbuffsize(B, LUAL_BUFFERSIZE) - -/* }====================================================== */ - - - -/* -** {====================================================== -** File handles for IO library -** ======================================================= -*/ - -/* -** A file handle is a userdata with metatable 'LUA_FILEHANDLE' and -** initial structure 'luaL_Stream' (it may contain other fields -** after that initial structure). -*/ - -#define LUA_FILEHANDLE "FILE*" - - -typedef struct luaL_Stream { - FILE *f; /* stream (NULL for incompletely created streams) */ - lua_CFunction closef; /* to close stream (NULL for closed streams) */ -} luaL_Stream; - -/* }====================================================== */ - - - -/* compatibility with old module system */ -#if defined(LUA_COMPAT_MODULE) - -LUALIB_API void (luaL_pushmodule) (lua_State *L, const char *modname, - int sizehint); -LUALIB_API void (luaL_openlib) (lua_State *L, const char *libname, - const luaL_Reg *l, int nup); - -#define luaL_register(L,n,l) (luaL_openlib(L,(n),(l),0)) - -#endif - - -#endif - - diff --git a/btgui/lua-5.2.3/src/lbaselib.c b/btgui/lua-5.2.3/src/lbaselib.c deleted file mode 100644 index 5255b3cd9..000000000 --- a/btgui/lua-5.2.3/src/lbaselib.c +++ /dev/null @@ -1,458 +0,0 @@ -/* -** $Id: lbaselib.c,v 1.276.1.1 2013/04/12 18:48:47 roberto Exp $ -** Basic library -** See Copyright Notice in lua.h -*/ - - - -#include -#include -#include -#include - -#define lbaselib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -static int luaB_print (lua_State *L) { - int n = lua_gettop(L); /* number of arguments */ - int i; - lua_getglobal(L, "tostring"); - for (i=1; i<=n; i++) { - const char *s; - size_t l; - lua_pushvalue(L, -1); /* function to be called */ - lua_pushvalue(L, i); /* value to print */ - lua_call(L, 1, 1); - s = lua_tolstring(L, -1, &l); /* get result */ - if (s == NULL) - return luaL_error(L, - LUA_QL("tostring") " must return a string to " LUA_QL("print")); - if (i>1) luai_writestring("\t", 1); - luai_writestring(s, l); - lua_pop(L, 1); /* pop result */ - } - luai_writeline(); - return 0; -} - - -#define SPACECHARS " \f\n\r\t\v" - -static int luaB_tonumber (lua_State *L) { - if (lua_isnoneornil(L, 2)) { /* standard conversion */ - int isnum; - lua_Number n = lua_tonumberx(L, 1, &isnum); - if (isnum) { - lua_pushnumber(L, n); - return 1; - } /* else not a number; must be something */ - luaL_checkany(L, 1); - } - else { - size_t l; - const char *s = luaL_checklstring(L, 1, &l); - const char *e = s + l; /* end point for 's' */ - int base = luaL_checkint(L, 2); - int neg = 0; - luaL_argcheck(L, 2 <= base && base <= 36, 2, "base out of range"); - s += strspn(s, SPACECHARS); /* skip initial spaces */ - if (*s == '-') { s++; neg = 1; } /* handle signal */ - else if (*s == '+') s++; - if (isalnum((unsigned char)*s)) { - lua_Number n = 0; - do { - int digit = (isdigit((unsigned char)*s)) ? *s - '0' - : toupper((unsigned char)*s) - 'A' + 10; - if (digit >= base) break; /* invalid numeral; force a fail */ - n = n * (lua_Number)base + (lua_Number)digit; - s++; - } while (isalnum((unsigned char)*s)); - s += strspn(s, SPACECHARS); /* skip trailing spaces */ - if (s == e) { /* no invalid trailing characters? */ - lua_pushnumber(L, (neg) ? -n : n); - return 1; - } /* else not a number */ - } /* else not a number */ - } - lua_pushnil(L); /* not a number */ - return 1; -} - - -static int luaB_error (lua_State *L) { - int level = luaL_optint(L, 2, 1); - lua_settop(L, 1); - if (lua_isstring(L, 1) && level > 0) { /* add extra information? */ - luaL_where(L, level); - lua_pushvalue(L, 1); - lua_concat(L, 2); - } - return lua_error(L); -} - - -static int luaB_getmetatable (lua_State *L) { - luaL_checkany(L, 1); - if (!lua_getmetatable(L, 1)) { - lua_pushnil(L); - return 1; /* no metatable */ - } - luaL_getmetafield(L, 1, "__metatable"); - return 1; /* returns either __metatable field (if present) or metatable */ -} - - -static int luaB_setmetatable (lua_State *L) { - int t = lua_type(L, 2); - luaL_checktype(L, 1, LUA_TTABLE); - luaL_argcheck(L, t == LUA_TNIL || t == LUA_TTABLE, 2, - "nil or table expected"); - if (luaL_getmetafield(L, 1, "__metatable")) - return luaL_error(L, "cannot change a protected metatable"); - lua_settop(L, 2); - lua_setmetatable(L, 1); - return 1; -} - - -static int luaB_rawequal (lua_State *L) { - luaL_checkany(L, 1); - luaL_checkany(L, 2); - lua_pushboolean(L, lua_rawequal(L, 1, 2)); - return 1; -} - - -static int luaB_rawlen (lua_State *L) { - int t = lua_type(L, 1); - luaL_argcheck(L, t == LUA_TTABLE || t == LUA_TSTRING, 1, - "table or string expected"); - lua_pushinteger(L, lua_rawlen(L, 1)); - return 1; -} - - -static int luaB_rawget (lua_State *L) { - luaL_checktype(L, 1, LUA_TTABLE); - luaL_checkany(L, 2); - lua_settop(L, 2); - lua_rawget(L, 1); - return 1; -} - -static int luaB_rawset (lua_State *L) { - luaL_checktype(L, 1, LUA_TTABLE); - luaL_checkany(L, 2); - luaL_checkany(L, 3); - lua_settop(L, 3); - lua_rawset(L, 1); - return 1; -} - - -static int luaB_collectgarbage (lua_State *L) { - static const char *const opts[] = {"stop", "restart", "collect", - "count", "step", "setpause", "setstepmul", - "setmajorinc", "isrunning", "generational", "incremental", NULL}; - static const int optsnum[] = {LUA_GCSTOP, LUA_GCRESTART, LUA_GCCOLLECT, - LUA_GCCOUNT, LUA_GCSTEP, LUA_GCSETPAUSE, LUA_GCSETSTEPMUL, - LUA_GCSETMAJORINC, LUA_GCISRUNNING, LUA_GCGEN, LUA_GCINC}; - int o = optsnum[luaL_checkoption(L, 1, "collect", opts)]; - int ex = luaL_optint(L, 2, 0); - int res = lua_gc(L, o, ex); - switch (o) { - case LUA_GCCOUNT: { - int b = lua_gc(L, LUA_GCCOUNTB, 0); - lua_pushnumber(L, res + ((lua_Number)b/1024)); - lua_pushinteger(L, b); - return 2; - } - case LUA_GCSTEP: case LUA_GCISRUNNING: { - lua_pushboolean(L, res); - return 1; - } - default: { - lua_pushinteger(L, res); - return 1; - } - } -} - - -static int luaB_type (lua_State *L) { - luaL_checkany(L, 1); - lua_pushstring(L, luaL_typename(L, 1)); - return 1; -} - - -static int pairsmeta (lua_State *L, const char *method, int iszero, - lua_CFunction iter) { - if (!luaL_getmetafield(L, 1, method)) { /* no metamethod? */ - luaL_checktype(L, 1, LUA_TTABLE); /* argument must be a table */ - lua_pushcfunction(L, iter); /* will return generator, */ - lua_pushvalue(L, 1); /* state, */ - if (iszero) lua_pushinteger(L, 0); /* and initial value */ - else lua_pushnil(L); - } - else { - lua_pushvalue(L, 1); /* argument 'self' to metamethod */ - lua_call(L, 1, 3); /* get 3 values from metamethod */ - } - return 3; -} - - -static int luaB_next (lua_State *L) { - luaL_checktype(L, 1, LUA_TTABLE); - lua_settop(L, 2); /* create a 2nd argument if there isn't one */ - if (lua_next(L, 1)) - return 2; - else { - lua_pushnil(L); - return 1; - } -} - - -static int luaB_pairs (lua_State *L) { - return pairsmeta(L, "__pairs", 0, luaB_next); -} - - -static int ipairsaux (lua_State *L) { - int i = luaL_checkint(L, 2); - luaL_checktype(L, 1, LUA_TTABLE); - i++; /* next value */ - lua_pushinteger(L, i); - lua_rawgeti(L, 1, i); - return (lua_isnil(L, -1)) ? 1 : 2; -} - - -static int luaB_ipairs (lua_State *L) { - return pairsmeta(L, "__ipairs", 1, ipairsaux); -} - - -static int load_aux (lua_State *L, int status, int envidx) { - if (status == LUA_OK) { - if (envidx != 0) { /* 'env' parameter? */ - lua_pushvalue(L, envidx); /* environment for loaded function */ - if (!lua_setupvalue(L, -2, 1)) /* set it as 1st upvalue */ - lua_pop(L, 1); /* remove 'env' if not used by previous call */ - } - return 1; - } - else { /* error (message is on top of the stack) */ - lua_pushnil(L); - lua_insert(L, -2); /* put before error message */ - return 2; /* return nil plus error message */ - } -} - - -static int luaB_loadfile (lua_State *L) { - const char *fname = luaL_optstring(L, 1, NULL); - const char *mode = luaL_optstring(L, 2, NULL); - int env = (!lua_isnone(L, 3) ? 3 : 0); /* 'env' index or 0 if no 'env' */ - int status = luaL_loadfilex(L, fname, mode); - return load_aux(L, status, env); -} - - -/* -** {====================================================== -** Generic Read function -** ======================================================= -*/ - - -/* -** reserved slot, above all arguments, to hold a copy of the returned -** string to avoid it being collected while parsed. 'load' has four -** optional arguments (chunk, source name, mode, and environment). -*/ -#define RESERVEDSLOT 5 - - -/* -** Reader for generic `load' function: `lua_load' uses the -** stack for internal stuff, so the reader cannot change the -** stack top. Instead, it keeps its resulting string in a -** reserved slot inside the stack. -*/ -static const char *generic_reader (lua_State *L, void *ud, size_t *size) { - (void)(ud); /* not used */ - luaL_checkstack(L, 2, "too many nested functions"); - lua_pushvalue(L, 1); /* get function */ - lua_call(L, 0, 1); /* call it */ - if (lua_isnil(L, -1)) { - lua_pop(L, 1); /* pop result */ - *size = 0; - return NULL; - } - else if (!lua_isstring(L, -1)) - luaL_error(L, "reader function must return a string"); - lua_replace(L, RESERVEDSLOT); /* save string in reserved slot */ - return lua_tolstring(L, RESERVEDSLOT, size); -} - - -static int luaB_load (lua_State *L) { - int status; - size_t l; - const char *s = lua_tolstring(L, 1, &l); - const char *mode = luaL_optstring(L, 3, "bt"); - int env = (!lua_isnone(L, 4) ? 4 : 0); /* 'env' index or 0 if no 'env' */ - if (s != NULL) { /* loading a string? */ - const char *chunkname = luaL_optstring(L, 2, s); - status = luaL_loadbufferx(L, s, l, chunkname, mode); - } - else { /* loading from a reader function */ - const char *chunkname = luaL_optstring(L, 2, "=(load)"); - luaL_checktype(L, 1, LUA_TFUNCTION); - lua_settop(L, RESERVEDSLOT); /* create reserved slot */ - status = lua_load(L, generic_reader, NULL, chunkname, mode); - } - return load_aux(L, status, env); -} - -/* }====================================================== */ - - -static int dofilecont (lua_State *L) { - return lua_gettop(L) - 1; -} - - -static int luaB_dofile (lua_State *L) { - const char *fname = luaL_optstring(L, 1, NULL); - lua_settop(L, 1); - if (luaL_loadfile(L, fname) != LUA_OK) - return lua_error(L); - lua_callk(L, 0, LUA_MULTRET, 0, dofilecont); - return dofilecont(L); -} - - -static int luaB_assert (lua_State *L) { - if (!lua_toboolean(L, 1)) - return luaL_error(L, "%s", luaL_optstring(L, 2, "assertion failed!")); - return lua_gettop(L); -} - - -static int luaB_select (lua_State *L) { - int n = lua_gettop(L); - if (lua_type(L, 1) == LUA_TSTRING && *lua_tostring(L, 1) == '#') { - lua_pushinteger(L, n-1); - return 1; - } - else { - int i = luaL_checkint(L, 1); - if (i < 0) i = n + i; - else if (i > n) i = n; - luaL_argcheck(L, 1 <= i, 1, "index out of range"); - return n - i; - } -} - - -static int finishpcall (lua_State *L, int status) { - if (!lua_checkstack(L, 1)) { /* no space for extra boolean? */ - lua_settop(L, 0); /* create space for return values */ - lua_pushboolean(L, 0); - lua_pushstring(L, "stack overflow"); - return 2; /* return false, msg */ - } - lua_pushboolean(L, status); /* first result (status) */ - lua_replace(L, 1); /* put first result in first slot */ - return lua_gettop(L); -} - - -static int pcallcont (lua_State *L) { - int status = lua_getctx(L, NULL); - return finishpcall(L, (status == LUA_YIELD)); -} - - -static int luaB_pcall (lua_State *L) { - int status; - luaL_checkany(L, 1); - lua_pushnil(L); - lua_insert(L, 1); /* create space for status result */ - status = lua_pcallk(L, lua_gettop(L) - 2, LUA_MULTRET, 0, 0, pcallcont); - return finishpcall(L, (status == LUA_OK)); -} - - -static int luaB_xpcall (lua_State *L) { - int status; - int n = lua_gettop(L); - luaL_argcheck(L, n >= 2, 2, "value expected"); - lua_pushvalue(L, 1); /* exchange function... */ - lua_copy(L, 2, 1); /* ...and error handler */ - lua_replace(L, 2); - status = lua_pcallk(L, n - 2, LUA_MULTRET, 1, 0, pcallcont); - return finishpcall(L, (status == LUA_OK)); -} - - -static int luaB_tostring (lua_State *L) { - luaL_checkany(L, 1); - luaL_tolstring(L, 1, NULL); - return 1; -} - - -static const luaL_Reg base_funcs[] = { - {"assert", luaB_assert}, - {"collectgarbage", luaB_collectgarbage}, - {"dofile", luaB_dofile}, - {"error", luaB_error}, - {"getmetatable", luaB_getmetatable}, - {"ipairs", luaB_ipairs}, - {"loadfile", luaB_loadfile}, - {"load", luaB_load}, -#if defined(LUA_COMPAT_LOADSTRING) - {"loadstring", luaB_load}, -#endif - {"next", luaB_next}, - {"pairs", luaB_pairs}, - {"pcall", luaB_pcall}, - {"print", luaB_print}, - {"rawequal", luaB_rawequal}, - {"rawlen", luaB_rawlen}, - {"rawget", luaB_rawget}, - {"rawset", luaB_rawset}, - {"select", luaB_select}, - {"setmetatable", luaB_setmetatable}, - {"tonumber", luaB_tonumber}, - {"tostring", luaB_tostring}, - {"type", luaB_type}, - {"xpcall", luaB_xpcall}, - {NULL, NULL} -}; - - -LUAMOD_API int luaopen_base (lua_State *L) { - /* set global _G */ - lua_pushglobaltable(L); - lua_pushglobaltable(L); - lua_setfield(L, -2, "_G"); - /* open lib into global table */ - luaL_setfuncs(L, base_funcs, 0); - lua_pushliteral(L, LUA_VERSION); - lua_setfield(L, -2, "_VERSION"); /* set global _VERSION */ - return 1; -} - diff --git a/btgui/lua-5.2.3/src/lbitlib.c b/btgui/lua-5.2.3/src/lbitlib.c deleted file mode 100644 index 31c7b66f1..000000000 --- a/btgui/lua-5.2.3/src/lbitlib.c +++ /dev/null @@ -1,212 +0,0 @@ -/* -** $Id: lbitlib.c,v 1.18.1.2 2013/07/09 18:01:41 roberto Exp $ -** Standard library for bitwise operations -** See Copyright Notice in lua.h -*/ - -#define lbitlib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -/* number of bits to consider in a number */ -#if !defined(LUA_NBITS) -#define LUA_NBITS 32 -#endif - - -#define ALLONES (~(((~(lua_Unsigned)0) << (LUA_NBITS - 1)) << 1)) - -/* macro to trim extra bits */ -#define trim(x) ((x) & ALLONES) - - -/* builds a number with 'n' ones (1 <= n <= LUA_NBITS) */ -#define mask(n) (~((ALLONES << 1) << ((n) - 1))) - - -typedef lua_Unsigned b_uint; - - - -static b_uint andaux (lua_State *L) { - int i, n = lua_gettop(L); - b_uint r = ~(b_uint)0; - for (i = 1; i <= n; i++) - r &= luaL_checkunsigned(L, i); - return trim(r); -} - - -static int b_and (lua_State *L) { - b_uint r = andaux(L); - lua_pushunsigned(L, r); - return 1; -} - - -static int b_test (lua_State *L) { - b_uint r = andaux(L); - lua_pushboolean(L, r != 0); - return 1; -} - - -static int b_or (lua_State *L) { - int i, n = lua_gettop(L); - b_uint r = 0; - for (i = 1; i <= n; i++) - r |= luaL_checkunsigned(L, i); - lua_pushunsigned(L, trim(r)); - return 1; -} - - -static int b_xor (lua_State *L) { - int i, n = lua_gettop(L); - b_uint r = 0; - for (i = 1; i <= n; i++) - r ^= luaL_checkunsigned(L, i); - lua_pushunsigned(L, trim(r)); - return 1; -} - - -static int b_not (lua_State *L) { - b_uint r = ~luaL_checkunsigned(L, 1); - lua_pushunsigned(L, trim(r)); - return 1; -} - - -static int b_shift (lua_State *L, b_uint r, int i) { - if (i < 0) { /* shift right? */ - i = -i; - r = trim(r); - if (i >= LUA_NBITS) r = 0; - else r >>= i; - } - else { /* shift left */ - if (i >= LUA_NBITS) r = 0; - else r <<= i; - r = trim(r); - } - lua_pushunsigned(L, r); - return 1; -} - - -static int b_lshift (lua_State *L) { - return b_shift(L, luaL_checkunsigned(L, 1), luaL_checkint(L, 2)); -} - - -static int b_rshift (lua_State *L) { - return b_shift(L, luaL_checkunsigned(L, 1), -luaL_checkint(L, 2)); -} - - -static int b_arshift (lua_State *L) { - b_uint r = luaL_checkunsigned(L, 1); - int i = luaL_checkint(L, 2); - if (i < 0 || !(r & ((b_uint)1 << (LUA_NBITS - 1)))) - return b_shift(L, r, -i); - else { /* arithmetic shift for 'negative' number */ - if (i >= LUA_NBITS) r = ALLONES; - else - r = trim((r >> i) | ~(~(b_uint)0 >> i)); /* add signal bit */ - lua_pushunsigned(L, r); - return 1; - } -} - - -static int b_rot (lua_State *L, int i) { - b_uint r = luaL_checkunsigned(L, 1); - i &= (LUA_NBITS - 1); /* i = i % NBITS */ - r = trim(r); - if (i != 0) /* avoid undefined shift of LUA_NBITS when i == 0 */ - r = (r << i) | (r >> (LUA_NBITS - i)); - lua_pushunsigned(L, trim(r)); - return 1; -} - - -static int b_lrot (lua_State *L) { - return b_rot(L, luaL_checkint(L, 2)); -} - - -static int b_rrot (lua_State *L) { - return b_rot(L, -luaL_checkint(L, 2)); -} - - -/* -** get field and width arguments for field-manipulation functions, -** checking whether they are valid. -** ('luaL_error' called without 'return' to avoid later warnings about -** 'width' being used uninitialized.) -*/ -static int fieldargs (lua_State *L, int farg, int *width) { - int f = luaL_checkint(L, farg); - int w = luaL_optint(L, farg + 1, 1); - luaL_argcheck(L, 0 <= f, farg, "field cannot be negative"); - luaL_argcheck(L, 0 < w, farg + 1, "width must be positive"); - if (f + w > LUA_NBITS) - luaL_error(L, "trying to access non-existent bits"); - *width = w; - return f; -} - - -static int b_extract (lua_State *L) { - int w; - b_uint r = luaL_checkunsigned(L, 1); - int f = fieldargs(L, 2, &w); - r = (r >> f) & mask(w); - lua_pushunsigned(L, r); - return 1; -} - - -static int b_replace (lua_State *L) { - int w; - b_uint r = luaL_checkunsigned(L, 1); - b_uint v = luaL_checkunsigned(L, 2); - int f = fieldargs(L, 3, &w); - int m = mask(w); - v &= m; /* erase bits outside given width */ - r = (r & ~(m << f)) | (v << f); - lua_pushunsigned(L, r); - return 1; -} - - -static const luaL_Reg bitlib[] = { - {"arshift", b_arshift}, - {"band", b_and}, - {"bnot", b_not}, - {"bor", b_or}, - {"bxor", b_xor}, - {"btest", b_test}, - {"extract", b_extract}, - {"lrotate", b_lrot}, - {"lshift", b_lshift}, - {"replace", b_replace}, - {"rrotate", b_rrot}, - {"rshift", b_rshift}, - {NULL, NULL} -}; - - - -LUAMOD_API int luaopen_bit32 (lua_State *L) { - luaL_newlib(L, bitlib); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/lcode.c b/btgui/lua-5.2.3/src/lcode.c deleted file mode 100644 index 820b95c0e..000000000 --- a/btgui/lua-5.2.3/src/lcode.c +++ /dev/null @@ -1,881 +0,0 @@ -/* -** $Id: lcode.c,v 2.62.1.1 2013/04/12 18:48:47 roberto Exp $ -** Code generator for Lua -** See Copyright Notice in lua.h -*/ - - -#include - -#define lcode_c -#define LUA_CORE - -#include "lua.h" - -#include "lcode.h" -#include "ldebug.h" -#include "ldo.h" -#include "lgc.h" -#include "llex.h" -#include "lmem.h" -#include "lobject.h" -#include "lopcodes.h" -#include "lparser.h" -#include "lstring.h" -#include "ltable.h" -#include "lvm.h" - - -#define hasjumps(e) ((e)->t != (e)->f) - - -static int isnumeral(expdesc *e) { - return (e->k == VKNUM && e->t == NO_JUMP && e->f == NO_JUMP); -} - - -void luaK_nil (FuncState *fs, int from, int n) { - Instruction *previous; - int l = from + n - 1; /* last register to set nil */ - if (fs->pc > fs->lasttarget) { /* no jumps to current position? */ - previous = &fs->f->code[fs->pc-1]; - if (GET_OPCODE(*previous) == OP_LOADNIL) { - int pfrom = GETARG_A(*previous); - int pl = pfrom + GETARG_B(*previous); - if ((pfrom <= from && from <= pl + 1) || - (from <= pfrom && pfrom <= l + 1)) { /* can connect both? */ - if (pfrom < from) from = pfrom; /* from = min(from, pfrom) */ - if (pl > l) l = pl; /* l = max(l, pl) */ - SETARG_A(*previous, from); - SETARG_B(*previous, l - from); - return; - } - } /* else go through */ - } - luaK_codeABC(fs, OP_LOADNIL, from, n - 1, 0); /* else no optimization */ -} - - -int luaK_jump (FuncState *fs) { - int jpc = fs->jpc; /* save list of jumps to here */ - int j; - fs->jpc = NO_JUMP; - j = luaK_codeAsBx(fs, OP_JMP, 0, NO_JUMP); - luaK_concat(fs, &j, jpc); /* keep them on hold */ - return j; -} - - -void luaK_ret (FuncState *fs, int first, int nret) { - luaK_codeABC(fs, OP_RETURN, first, nret+1, 0); -} - - -static int condjump (FuncState *fs, OpCode op, int A, int B, int C) { - luaK_codeABC(fs, op, A, B, C); - return luaK_jump(fs); -} - - -static void fixjump (FuncState *fs, int pc, int dest) { - Instruction *jmp = &fs->f->code[pc]; - int offset = dest-(pc+1); - lua_assert(dest != NO_JUMP); - if (abs(offset) > MAXARG_sBx) - luaX_syntaxerror(fs->ls, "control structure too long"); - SETARG_sBx(*jmp, offset); -} - - -/* -** returns current `pc' and marks it as a jump target (to avoid wrong -** optimizations with consecutive instructions not in the same basic block). -*/ -int luaK_getlabel (FuncState *fs) { - fs->lasttarget = fs->pc; - return fs->pc; -} - - -static int getjump (FuncState *fs, int pc) { - int offset = GETARG_sBx(fs->f->code[pc]); - if (offset == NO_JUMP) /* point to itself represents end of list */ - return NO_JUMP; /* end of list */ - else - return (pc+1)+offset; /* turn offset into absolute position */ -} - - -static Instruction *getjumpcontrol (FuncState *fs, int pc) { - Instruction *pi = &fs->f->code[pc]; - if (pc >= 1 && testTMode(GET_OPCODE(*(pi-1)))) - return pi-1; - else - return pi; -} - - -/* -** check whether list has any jump that do not produce a value -** (or produce an inverted value) -*/ -static int need_value (FuncState *fs, int list) { - for (; list != NO_JUMP; list = getjump(fs, list)) { - Instruction i = *getjumpcontrol(fs, list); - if (GET_OPCODE(i) != OP_TESTSET) return 1; - } - return 0; /* not found */ -} - - -static int patchtestreg (FuncState *fs, int node, int reg) { - Instruction *i = getjumpcontrol(fs, node); - if (GET_OPCODE(*i) != OP_TESTSET) - return 0; /* cannot patch other instructions */ - if (reg != NO_REG && reg != GETARG_B(*i)) - SETARG_A(*i, reg); - else /* no register to put value or register already has the value */ - *i = CREATE_ABC(OP_TEST, GETARG_B(*i), 0, GETARG_C(*i)); - - return 1; -} - - -static void removevalues (FuncState *fs, int list) { - for (; list != NO_JUMP; list = getjump(fs, list)) - patchtestreg(fs, list, NO_REG); -} - - -static void patchlistaux (FuncState *fs, int list, int vtarget, int reg, - int dtarget) { - while (list != NO_JUMP) { - int next = getjump(fs, list); - if (patchtestreg(fs, list, reg)) - fixjump(fs, list, vtarget); - else - fixjump(fs, list, dtarget); /* jump to default target */ - list = next; - } -} - - -static void dischargejpc (FuncState *fs) { - patchlistaux(fs, fs->jpc, fs->pc, NO_REG, fs->pc); - fs->jpc = NO_JUMP; -} - - -void luaK_patchlist (FuncState *fs, int list, int target) { - if (target == fs->pc) - luaK_patchtohere(fs, list); - else { - lua_assert(target < fs->pc); - patchlistaux(fs, list, target, NO_REG, target); - } -} - - -LUAI_FUNC void luaK_patchclose (FuncState *fs, int list, int level) { - level++; /* argument is +1 to reserve 0 as non-op */ - while (list != NO_JUMP) { - int next = getjump(fs, list); - lua_assert(GET_OPCODE(fs->f->code[list]) == OP_JMP && - (GETARG_A(fs->f->code[list]) == 0 || - GETARG_A(fs->f->code[list]) >= level)); - SETARG_A(fs->f->code[list], level); - list = next; - } -} - - -void luaK_patchtohere (FuncState *fs, int list) { - luaK_getlabel(fs); - luaK_concat(fs, &fs->jpc, list); -} - - -void luaK_concat (FuncState *fs, int *l1, int l2) { - if (l2 == NO_JUMP) return; - else if (*l1 == NO_JUMP) - *l1 = l2; - else { - int list = *l1; - int next; - while ((next = getjump(fs, list)) != NO_JUMP) /* find last element */ - list = next; - fixjump(fs, list, l2); - } -} - - -static int luaK_code (FuncState *fs, Instruction i) { - Proto *f = fs->f; - dischargejpc(fs); /* `pc' will change */ - /* put new instruction in code array */ - luaM_growvector(fs->ls->L, f->code, fs->pc, f->sizecode, Instruction, - MAX_INT, "opcodes"); - f->code[fs->pc] = i; - /* save corresponding line information */ - luaM_growvector(fs->ls->L, f->lineinfo, fs->pc, f->sizelineinfo, int, - MAX_INT, "opcodes"); - f->lineinfo[fs->pc] = fs->ls->lastline; - return fs->pc++; -} - - -int luaK_codeABC (FuncState *fs, OpCode o, int a, int b, int c) { - lua_assert(getOpMode(o) == iABC); - lua_assert(getBMode(o) != OpArgN || b == 0); - lua_assert(getCMode(o) != OpArgN || c == 0); - lua_assert(a <= MAXARG_A && b <= MAXARG_B && c <= MAXARG_C); - return luaK_code(fs, CREATE_ABC(o, a, b, c)); -} - - -int luaK_codeABx (FuncState *fs, OpCode o, int a, unsigned int bc) { - lua_assert(getOpMode(o) == iABx || getOpMode(o) == iAsBx); - lua_assert(getCMode(o) == OpArgN); - lua_assert(a <= MAXARG_A && bc <= MAXARG_Bx); - return luaK_code(fs, CREATE_ABx(o, a, bc)); -} - - -static int codeextraarg (FuncState *fs, int a) { - lua_assert(a <= MAXARG_Ax); - return luaK_code(fs, CREATE_Ax(OP_EXTRAARG, a)); -} - - -int luaK_codek (FuncState *fs, int reg, int k) { - if (k <= MAXARG_Bx) - return luaK_codeABx(fs, OP_LOADK, reg, k); - else { - int p = luaK_codeABx(fs, OP_LOADKX, reg, 0); - codeextraarg(fs, k); - return p; - } -} - - -void luaK_checkstack (FuncState *fs, int n) { - int newstack = fs->freereg + n; - if (newstack > fs->f->maxstacksize) { - if (newstack >= MAXSTACK) - luaX_syntaxerror(fs->ls, "function or expression too complex"); - fs->f->maxstacksize = cast_byte(newstack); - } -} - - -void luaK_reserveregs (FuncState *fs, int n) { - luaK_checkstack(fs, n); - fs->freereg += n; -} - - -static void freereg (FuncState *fs, int reg) { - if (!ISK(reg) && reg >= fs->nactvar) { - fs->freereg--; - lua_assert(reg == fs->freereg); - } -} - - -static void freeexp (FuncState *fs, expdesc *e) { - if (e->k == VNONRELOC) - freereg(fs, e->u.info); -} - - -static int addk (FuncState *fs, TValue *key, TValue *v) { - lua_State *L = fs->ls->L; - TValue *idx = luaH_set(L, fs->h, key); - Proto *f = fs->f; - int k, oldsize; - if (ttisnumber(idx)) { - lua_Number n = nvalue(idx); - lua_number2int(k, n); - if (luaV_rawequalobj(&f->k[k], v)) - return k; - /* else may be a collision (e.g., between 0.0 and "\0\0\0\0\0\0\0\0"); - go through and create a new entry for this value */ - } - /* constant not found; create a new entry */ - oldsize = f->sizek; - k = fs->nk; - /* numerical value does not need GC barrier; - table has no metatable, so it does not need to invalidate cache */ - setnvalue(idx, cast_num(k)); - luaM_growvector(L, f->k, k, f->sizek, TValue, MAXARG_Ax, "constants"); - while (oldsize < f->sizek) setnilvalue(&f->k[oldsize++]); - setobj(L, &f->k[k], v); - fs->nk++; - luaC_barrier(L, f, v); - return k; -} - - -int luaK_stringK (FuncState *fs, TString *s) { - TValue o; - setsvalue(fs->ls->L, &o, s); - return addk(fs, &o, &o); -} - - -int luaK_numberK (FuncState *fs, lua_Number r) { - int n; - lua_State *L = fs->ls->L; - TValue o; - setnvalue(&o, r); - if (r == 0 || luai_numisnan(NULL, r)) { /* handle -0 and NaN */ - /* use raw representation as key to avoid numeric problems */ - setsvalue(L, L->top++, luaS_newlstr(L, (char *)&r, sizeof(r))); - n = addk(fs, L->top - 1, &o); - L->top--; - } - else - n = addk(fs, &o, &o); /* regular case */ - return n; -} - - -static int boolK (FuncState *fs, int b) { - TValue o; - setbvalue(&o, b); - return addk(fs, &o, &o); -} - - -static int nilK (FuncState *fs) { - TValue k, v; - setnilvalue(&v); - /* cannot use nil as key; instead use table itself to represent nil */ - sethvalue(fs->ls->L, &k, fs->h); - return addk(fs, &k, &v); -} - - -void luaK_setreturns (FuncState *fs, expdesc *e, int nresults) { - if (e->k == VCALL) { /* expression is an open function call? */ - SETARG_C(getcode(fs, e), nresults+1); - } - else if (e->k == VVARARG) { - SETARG_B(getcode(fs, e), nresults+1); - SETARG_A(getcode(fs, e), fs->freereg); - luaK_reserveregs(fs, 1); - } -} - - -void luaK_setoneret (FuncState *fs, expdesc *e) { - if (e->k == VCALL) { /* expression is an open function call? */ - e->k = VNONRELOC; - e->u.info = GETARG_A(getcode(fs, e)); - } - else if (e->k == VVARARG) { - SETARG_B(getcode(fs, e), 2); - e->k = VRELOCABLE; /* can relocate its simple result */ - } -} - - -void luaK_dischargevars (FuncState *fs, expdesc *e) { - switch (e->k) { - case VLOCAL: { - e->k = VNONRELOC; - break; - } - case VUPVAL: { - e->u.info = luaK_codeABC(fs, OP_GETUPVAL, 0, e->u.info, 0); - e->k = VRELOCABLE; - break; - } - case VINDEXED: { - OpCode op = OP_GETTABUP; /* assume 't' is in an upvalue */ - freereg(fs, e->u.ind.idx); - if (e->u.ind.vt == VLOCAL) { /* 't' is in a register? */ - freereg(fs, e->u.ind.t); - op = OP_GETTABLE; - } - e->u.info = luaK_codeABC(fs, op, 0, e->u.ind.t, e->u.ind.idx); - e->k = VRELOCABLE; - break; - } - case VVARARG: - case VCALL: { - luaK_setoneret(fs, e); - break; - } - default: break; /* there is one value available (somewhere) */ - } -} - - -static int code_label (FuncState *fs, int A, int b, int jump) { - luaK_getlabel(fs); /* those instructions may be jump targets */ - return luaK_codeABC(fs, OP_LOADBOOL, A, b, jump); -} - - -static void discharge2reg (FuncState *fs, expdesc *e, int reg) { - luaK_dischargevars(fs, e); - switch (e->k) { - case VNIL: { - luaK_nil(fs, reg, 1); - break; - } - case VFALSE: case VTRUE: { - luaK_codeABC(fs, OP_LOADBOOL, reg, e->k == VTRUE, 0); - break; - } - case VK: { - luaK_codek(fs, reg, e->u.info); - break; - } - case VKNUM: { - luaK_codek(fs, reg, luaK_numberK(fs, e->u.nval)); - break; - } - case VRELOCABLE: { - Instruction *pc = &getcode(fs, e); - SETARG_A(*pc, reg); - break; - } - case VNONRELOC: { - if (reg != e->u.info) - luaK_codeABC(fs, OP_MOVE, reg, e->u.info, 0); - break; - } - default: { - lua_assert(e->k == VVOID || e->k == VJMP); - return; /* nothing to do... */ - } - } - e->u.info = reg; - e->k = VNONRELOC; -} - - -static void discharge2anyreg (FuncState *fs, expdesc *e) { - if (e->k != VNONRELOC) { - luaK_reserveregs(fs, 1); - discharge2reg(fs, e, fs->freereg-1); - } -} - - -static void exp2reg (FuncState *fs, expdesc *e, int reg) { - discharge2reg(fs, e, reg); - if (e->k == VJMP) - luaK_concat(fs, &e->t, e->u.info); /* put this jump in `t' list */ - if (hasjumps(e)) { - int final; /* position after whole expression */ - int p_f = NO_JUMP; /* position of an eventual LOAD false */ - int p_t = NO_JUMP; /* position of an eventual LOAD true */ - if (need_value(fs, e->t) || need_value(fs, e->f)) { - int fj = (e->k == VJMP) ? NO_JUMP : luaK_jump(fs); - p_f = code_label(fs, reg, 0, 1); - p_t = code_label(fs, reg, 1, 0); - luaK_patchtohere(fs, fj); - } - final = luaK_getlabel(fs); - patchlistaux(fs, e->f, final, reg, p_f); - patchlistaux(fs, e->t, final, reg, p_t); - } - e->f = e->t = NO_JUMP; - e->u.info = reg; - e->k = VNONRELOC; -} - - -void luaK_exp2nextreg (FuncState *fs, expdesc *e) { - luaK_dischargevars(fs, e); - freeexp(fs, e); - luaK_reserveregs(fs, 1); - exp2reg(fs, e, fs->freereg - 1); -} - - -int luaK_exp2anyreg (FuncState *fs, expdesc *e) { - luaK_dischargevars(fs, e); - if (e->k == VNONRELOC) { - if (!hasjumps(e)) return e->u.info; /* exp is already in a register */ - if (e->u.info >= fs->nactvar) { /* reg. is not a local? */ - exp2reg(fs, e, e->u.info); /* put value on it */ - return e->u.info; - } - } - luaK_exp2nextreg(fs, e); /* default */ - return e->u.info; -} - - -void luaK_exp2anyregup (FuncState *fs, expdesc *e) { - if (e->k != VUPVAL || hasjumps(e)) - luaK_exp2anyreg(fs, e); -} - - -void luaK_exp2val (FuncState *fs, expdesc *e) { - if (hasjumps(e)) - luaK_exp2anyreg(fs, e); - else - luaK_dischargevars(fs, e); -} - - -int luaK_exp2RK (FuncState *fs, expdesc *e) { - luaK_exp2val(fs, e); - switch (e->k) { - case VTRUE: - case VFALSE: - case VNIL: { - if (fs->nk <= MAXINDEXRK) { /* constant fits in RK operand? */ - e->u.info = (e->k == VNIL) ? nilK(fs) : boolK(fs, (e->k == VTRUE)); - e->k = VK; - return RKASK(e->u.info); - } - else break; - } - case VKNUM: { - e->u.info = luaK_numberK(fs, e->u.nval); - e->k = VK; - /* go through */ - } - case VK: { - if (e->u.info <= MAXINDEXRK) /* constant fits in argC? */ - return RKASK(e->u.info); - else break; - } - default: break; - } - /* not a constant in the right range: put it in a register */ - return luaK_exp2anyreg(fs, e); -} - - -void luaK_storevar (FuncState *fs, expdesc *var, expdesc *ex) { - switch (var->k) { - case VLOCAL: { - freeexp(fs, ex); - exp2reg(fs, ex, var->u.info); - return; - } - case VUPVAL: { - int e = luaK_exp2anyreg(fs, ex); - luaK_codeABC(fs, OP_SETUPVAL, e, var->u.info, 0); - break; - } - case VINDEXED: { - OpCode op = (var->u.ind.vt == VLOCAL) ? OP_SETTABLE : OP_SETTABUP; - int e = luaK_exp2RK(fs, ex); - luaK_codeABC(fs, op, var->u.ind.t, var->u.ind.idx, e); - break; - } - default: { - lua_assert(0); /* invalid var kind to store */ - break; - } - } - freeexp(fs, ex); -} - - -void luaK_self (FuncState *fs, expdesc *e, expdesc *key) { - int ereg; - luaK_exp2anyreg(fs, e); - ereg = e->u.info; /* register where 'e' was placed */ - freeexp(fs, e); - e->u.info = fs->freereg; /* base register for op_self */ - e->k = VNONRELOC; - luaK_reserveregs(fs, 2); /* function and 'self' produced by op_self */ - luaK_codeABC(fs, OP_SELF, e->u.info, ereg, luaK_exp2RK(fs, key)); - freeexp(fs, key); -} - - -static void invertjump (FuncState *fs, expdesc *e) { - Instruction *pc = getjumpcontrol(fs, e->u.info); - lua_assert(testTMode(GET_OPCODE(*pc)) && GET_OPCODE(*pc) != OP_TESTSET && - GET_OPCODE(*pc) != OP_TEST); - SETARG_A(*pc, !(GETARG_A(*pc))); -} - - -static int jumponcond (FuncState *fs, expdesc *e, int cond) { - if (e->k == VRELOCABLE) { - Instruction ie = getcode(fs, e); - if (GET_OPCODE(ie) == OP_NOT) { - fs->pc--; /* remove previous OP_NOT */ - return condjump(fs, OP_TEST, GETARG_B(ie), 0, !cond); - } - /* else go through */ - } - discharge2anyreg(fs, e); - freeexp(fs, e); - return condjump(fs, OP_TESTSET, NO_REG, e->u.info, cond); -} - - -void luaK_goiftrue (FuncState *fs, expdesc *e) { - int pc; /* pc of last jump */ - luaK_dischargevars(fs, e); - switch (e->k) { - case VJMP: { - invertjump(fs, e); - pc = e->u.info; - break; - } - case VK: case VKNUM: case VTRUE: { - pc = NO_JUMP; /* always true; do nothing */ - break; - } - default: { - pc = jumponcond(fs, e, 0); - break; - } - } - luaK_concat(fs, &e->f, pc); /* insert last jump in `f' list */ - luaK_patchtohere(fs, e->t); - e->t = NO_JUMP; -} - - -void luaK_goiffalse (FuncState *fs, expdesc *e) { - int pc; /* pc of last jump */ - luaK_dischargevars(fs, e); - switch (e->k) { - case VJMP: { - pc = e->u.info; - break; - } - case VNIL: case VFALSE: { - pc = NO_JUMP; /* always false; do nothing */ - break; - } - default: { - pc = jumponcond(fs, e, 1); - break; - } - } - luaK_concat(fs, &e->t, pc); /* insert last jump in `t' list */ - luaK_patchtohere(fs, e->f); - e->f = NO_JUMP; -} - - -static void codenot (FuncState *fs, expdesc *e) { - luaK_dischargevars(fs, e); - switch (e->k) { - case VNIL: case VFALSE: { - e->k = VTRUE; - break; - } - case VK: case VKNUM: case VTRUE: { - e->k = VFALSE; - break; - } - case VJMP: { - invertjump(fs, e); - break; - } - case VRELOCABLE: - case VNONRELOC: { - discharge2anyreg(fs, e); - freeexp(fs, e); - e->u.info = luaK_codeABC(fs, OP_NOT, 0, e->u.info, 0); - e->k = VRELOCABLE; - break; - } - default: { - lua_assert(0); /* cannot happen */ - break; - } - } - /* interchange true and false lists */ - { int temp = e->f; e->f = e->t; e->t = temp; } - removevalues(fs, e->f); - removevalues(fs, e->t); -} - - -void luaK_indexed (FuncState *fs, expdesc *t, expdesc *k) { - lua_assert(!hasjumps(t)); - t->u.ind.t = t->u.info; - t->u.ind.idx = luaK_exp2RK(fs, k); - t->u.ind.vt = (t->k == VUPVAL) ? VUPVAL - : check_exp(vkisinreg(t->k), VLOCAL); - t->k = VINDEXED; -} - - -static int constfolding (OpCode op, expdesc *e1, expdesc *e2) { - lua_Number r; - if (!isnumeral(e1) || !isnumeral(e2)) return 0; - if ((op == OP_DIV || op == OP_MOD) && e2->u.nval == 0) - return 0; /* do not attempt to divide by 0 */ - r = luaO_arith(op - OP_ADD + LUA_OPADD, e1->u.nval, e2->u.nval); - e1->u.nval = r; - return 1; -} - - -static void codearith (FuncState *fs, OpCode op, - expdesc *e1, expdesc *e2, int line) { - if (constfolding(op, e1, e2)) - return; - else { - int o2 = (op != OP_UNM && op != OP_LEN) ? luaK_exp2RK(fs, e2) : 0; - int o1 = luaK_exp2RK(fs, e1); - if (o1 > o2) { - freeexp(fs, e1); - freeexp(fs, e2); - } - else { - freeexp(fs, e2); - freeexp(fs, e1); - } - e1->u.info = luaK_codeABC(fs, op, 0, o1, o2); - e1->k = VRELOCABLE; - luaK_fixline(fs, line); - } -} - - -static void codecomp (FuncState *fs, OpCode op, int cond, expdesc *e1, - expdesc *e2) { - int o1 = luaK_exp2RK(fs, e1); - int o2 = luaK_exp2RK(fs, e2); - freeexp(fs, e2); - freeexp(fs, e1); - if (cond == 0 && op != OP_EQ) { - int temp; /* exchange args to replace by `<' or `<=' */ - temp = o1; o1 = o2; o2 = temp; /* o1 <==> o2 */ - cond = 1; - } - e1->u.info = condjump(fs, op, cond, o1, o2); - e1->k = VJMP; -} - - -void luaK_prefix (FuncState *fs, UnOpr op, expdesc *e, int line) { - expdesc e2; - e2.t = e2.f = NO_JUMP; e2.k = VKNUM; e2.u.nval = 0; - switch (op) { - case OPR_MINUS: { - if (isnumeral(e)) /* minus constant? */ - e->u.nval = luai_numunm(NULL, e->u.nval); /* fold it */ - else { - luaK_exp2anyreg(fs, e); - codearith(fs, OP_UNM, e, &e2, line); - } - break; - } - case OPR_NOT: codenot(fs, e); break; - case OPR_LEN: { - luaK_exp2anyreg(fs, e); /* cannot operate on constants */ - codearith(fs, OP_LEN, e, &e2, line); - break; - } - default: lua_assert(0); - } -} - - -void luaK_infix (FuncState *fs, BinOpr op, expdesc *v) { - switch (op) { - case OPR_AND: { - luaK_goiftrue(fs, v); - break; - } - case OPR_OR: { - luaK_goiffalse(fs, v); - break; - } - case OPR_CONCAT: { - luaK_exp2nextreg(fs, v); /* operand must be on the `stack' */ - break; - } - case OPR_ADD: case OPR_SUB: case OPR_MUL: case OPR_DIV: - case OPR_MOD: case OPR_POW: { - if (!isnumeral(v)) luaK_exp2RK(fs, v); - break; - } - default: { - luaK_exp2RK(fs, v); - break; - } - } -} - - -void luaK_posfix (FuncState *fs, BinOpr op, - expdesc *e1, expdesc *e2, int line) { - switch (op) { - case OPR_AND: { - lua_assert(e1->t == NO_JUMP); /* list must be closed */ - luaK_dischargevars(fs, e2); - luaK_concat(fs, &e2->f, e1->f); - *e1 = *e2; - break; - } - case OPR_OR: { - lua_assert(e1->f == NO_JUMP); /* list must be closed */ - luaK_dischargevars(fs, e2); - luaK_concat(fs, &e2->t, e1->t); - *e1 = *e2; - break; - } - case OPR_CONCAT: { - luaK_exp2val(fs, e2); - if (e2->k == VRELOCABLE && GET_OPCODE(getcode(fs, e2)) == OP_CONCAT) { - lua_assert(e1->u.info == GETARG_B(getcode(fs, e2))-1); - freeexp(fs, e1); - SETARG_B(getcode(fs, e2), e1->u.info); - e1->k = VRELOCABLE; e1->u.info = e2->u.info; - } - else { - luaK_exp2nextreg(fs, e2); /* operand must be on the 'stack' */ - codearith(fs, OP_CONCAT, e1, e2, line); - } - break; - } - case OPR_ADD: case OPR_SUB: case OPR_MUL: case OPR_DIV: - case OPR_MOD: case OPR_POW: { - codearith(fs, cast(OpCode, op - OPR_ADD + OP_ADD), e1, e2, line); - break; - } - case OPR_EQ: case OPR_LT: case OPR_LE: { - codecomp(fs, cast(OpCode, op - OPR_EQ + OP_EQ), 1, e1, e2); - break; - } - case OPR_NE: case OPR_GT: case OPR_GE: { - codecomp(fs, cast(OpCode, op - OPR_NE + OP_EQ), 0, e1, e2); - break; - } - default: lua_assert(0); - } -} - - -void luaK_fixline (FuncState *fs, int line) { - fs->f->lineinfo[fs->pc - 1] = line; -} - - -void luaK_setlist (FuncState *fs, int base, int nelems, int tostore) { - int c = (nelems - 1)/LFIELDS_PER_FLUSH + 1; - int b = (tostore == LUA_MULTRET) ? 0 : tostore; - lua_assert(tostore != 0); - if (c <= MAXARG_C) - luaK_codeABC(fs, OP_SETLIST, base, b, c); - else if (c <= MAXARG_Ax) { - luaK_codeABC(fs, OP_SETLIST, base, b, 0); - codeextraarg(fs, c); - } - else - luaX_syntaxerror(fs->ls, "constructor too long"); - fs->freereg = base + 1; /* free registers with list values */ -} - diff --git a/btgui/lua-5.2.3/src/lcode.h b/btgui/lua-5.2.3/src/lcode.h deleted file mode 100644 index 6a1424cf5..000000000 --- a/btgui/lua-5.2.3/src/lcode.h +++ /dev/null @@ -1,83 +0,0 @@ -/* -** $Id: lcode.h,v 1.58.1.1 2013/04/12 18:48:47 roberto Exp $ -** Code generator for Lua -** See Copyright Notice in lua.h -*/ - -#ifndef lcode_h -#define lcode_h - -#include "llex.h" -#include "lobject.h" -#include "lopcodes.h" -#include "lparser.h" - - -/* -** Marks the end of a patch list. It is an invalid value both as an absolute -** address, and as a list link (would link an element to itself). -*/ -#define NO_JUMP (-1) - - -/* -** grep "ORDER OPR" if you change these enums (ORDER OP) -*/ -typedef enum BinOpr { - OPR_ADD, OPR_SUB, OPR_MUL, OPR_DIV, OPR_MOD, OPR_POW, - OPR_CONCAT, - OPR_EQ, OPR_LT, OPR_LE, - OPR_NE, OPR_GT, OPR_GE, - OPR_AND, OPR_OR, - OPR_NOBINOPR -} BinOpr; - - -typedef enum UnOpr { OPR_MINUS, OPR_NOT, OPR_LEN, OPR_NOUNOPR } UnOpr; - - -#define getcode(fs,e) ((fs)->f->code[(e)->u.info]) - -#define luaK_codeAsBx(fs,o,A,sBx) luaK_codeABx(fs,o,A,(sBx)+MAXARG_sBx) - -#define luaK_setmultret(fs,e) luaK_setreturns(fs, e, LUA_MULTRET) - -#define luaK_jumpto(fs,t) luaK_patchlist(fs, luaK_jump(fs), t) - -LUAI_FUNC int luaK_codeABx (FuncState *fs, OpCode o, int A, unsigned int Bx); -LUAI_FUNC int luaK_codeABC (FuncState *fs, OpCode o, int A, int B, int C); -LUAI_FUNC int luaK_codek (FuncState *fs, int reg, int k); -LUAI_FUNC void luaK_fixline (FuncState *fs, int line); -LUAI_FUNC void luaK_nil (FuncState *fs, int from, int n); -LUAI_FUNC void luaK_reserveregs (FuncState *fs, int n); -LUAI_FUNC void luaK_checkstack (FuncState *fs, int n); -LUAI_FUNC int luaK_stringK (FuncState *fs, TString *s); -LUAI_FUNC int luaK_numberK (FuncState *fs, lua_Number r); -LUAI_FUNC void luaK_dischargevars (FuncState *fs, expdesc *e); -LUAI_FUNC int luaK_exp2anyreg (FuncState *fs, expdesc *e); -LUAI_FUNC void luaK_exp2anyregup (FuncState *fs, expdesc *e); -LUAI_FUNC void luaK_exp2nextreg (FuncState *fs, expdesc *e); -LUAI_FUNC void luaK_exp2val (FuncState *fs, expdesc *e); -LUAI_FUNC int luaK_exp2RK (FuncState *fs, expdesc *e); -LUAI_FUNC void luaK_self (FuncState *fs, expdesc *e, expdesc *key); -LUAI_FUNC void luaK_indexed (FuncState *fs, expdesc *t, expdesc *k); -LUAI_FUNC void luaK_goiftrue (FuncState *fs, expdesc *e); -LUAI_FUNC void luaK_goiffalse (FuncState *fs, expdesc *e); -LUAI_FUNC void luaK_storevar (FuncState *fs, expdesc *var, expdesc *e); -LUAI_FUNC void luaK_setreturns (FuncState *fs, expdesc *e, int nresults); -LUAI_FUNC void luaK_setoneret (FuncState *fs, expdesc *e); -LUAI_FUNC int luaK_jump (FuncState *fs); -LUAI_FUNC void luaK_ret (FuncState *fs, int first, int nret); -LUAI_FUNC void luaK_patchlist (FuncState *fs, int list, int target); -LUAI_FUNC void luaK_patchtohere (FuncState *fs, int list); -LUAI_FUNC void luaK_patchclose (FuncState *fs, int list, int level); -LUAI_FUNC void luaK_concat (FuncState *fs, int *l1, int l2); -LUAI_FUNC int luaK_getlabel (FuncState *fs); -LUAI_FUNC void luaK_prefix (FuncState *fs, UnOpr op, expdesc *v, int line); -LUAI_FUNC void luaK_infix (FuncState *fs, BinOpr op, expdesc *v); -LUAI_FUNC void luaK_posfix (FuncState *fs, BinOpr op, expdesc *v1, - expdesc *v2, int line); -LUAI_FUNC void luaK_setlist (FuncState *fs, int base, int nelems, int tostore); - - -#endif diff --git a/btgui/lua-5.2.3/src/lcorolib.c b/btgui/lua-5.2.3/src/lcorolib.c deleted file mode 100644 index ce4f6ad42..000000000 --- a/btgui/lua-5.2.3/src/lcorolib.c +++ /dev/null @@ -1,155 +0,0 @@ -/* -** $Id: lcorolib.c,v 1.5.1.1 2013/04/12 18:48:47 roberto Exp $ -** Coroutine Library -** See Copyright Notice in lua.h -*/ - - -#include - - -#define lcorolib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -static int auxresume (lua_State *L, lua_State *co, int narg) { - int status; - if (!lua_checkstack(co, narg)) { - lua_pushliteral(L, "too many arguments to resume"); - return -1; /* error flag */ - } - if (lua_status(co) == LUA_OK && lua_gettop(co) == 0) { - lua_pushliteral(L, "cannot resume dead coroutine"); - return -1; /* error flag */ - } - lua_xmove(L, co, narg); - status = lua_resume(co, L, narg); - if (status == LUA_OK || status == LUA_YIELD) { - int nres = lua_gettop(co); - if (!lua_checkstack(L, nres + 1)) { - lua_pop(co, nres); /* remove results anyway */ - lua_pushliteral(L, "too many results to resume"); - return -1; /* error flag */ - } - lua_xmove(co, L, nres); /* move yielded values */ - return nres; - } - else { - lua_xmove(co, L, 1); /* move error message */ - return -1; /* error flag */ - } -} - - -static int luaB_coresume (lua_State *L) { - lua_State *co = lua_tothread(L, 1); - int r; - luaL_argcheck(L, co, 1, "coroutine expected"); - r = auxresume(L, co, lua_gettop(L) - 1); - if (r < 0) { - lua_pushboolean(L, 0); - lua_insert(L, -2); - return 2; /* return false + error message */ - } - else { - lua_pushboolean(L, 1); - lua_insert(L, -(r + 1)); - return r + 1; /* return true + `resume' returns */ - } -} - - -static int luaB_auxwrap (lua_State *L) { - lua_State *co = lua_tothread(L, lua_upvalueindex(1)); - int r = auxresume(L, co, lua_gettop(L)); - if (r < 0) { - if (lua_isstring(L, -1)) { /* error object is a string? */ - luaL_where(L, 1); /* add extra info */ - lua_insert(L, -2); - lua_concat(L, 2); - } - return lua_error(L); /* propagate error */ - } - return r; -} - - -static int luaB_cocreate (lua_State *L) { - lua_State *NL; - luaL_checktype(L, 1, LUA_TFUNCTION); - NL = lua_newthread(L); - lua_pushvalue(L, 1); /* move function to top */ - lua_xmove(L, NL, 1); /* move function from L to NL */ - return 1; -} - - -static int luaB_cowrap (lua_State *L) { - luaB_cocreate(L); - lua_pushcclosure(L, luaB_auxwrap, 1); - return 1; -} - - -static int luaB_yield (lua_State *L) { - return lua_yield(L, lua_gettop(L)); -} - - -static int luaB_costatus (lua_State *L) { - lua_State *co = lua_tothread(L, 1); - luaL_argcheck(L, co, 1, "coroutine expected"); - if (L == co) lua_pushliteral(L, "running"); - else { - switch (lua_status(co)) { - case LUA_YIELD: - lua_pushliteral(L, "suspended"); - break; - case LUA_OK: { - lua_Debug ar; - if (lua_getstack(co, 0, &ar) > 0) /* does it have frames? */ - lua_pushliteral(L, "normal"); /* it is running */ - else if (lua_gettop(co) == 0) - lua_pushliteral(L, "dead"); - else - lua_pushliteral(L, "suspended"); /* initial state */ - break; - } - default: /* some error occurred */ - lua_pushliteral(L, "dead"); - break; - } - } - return 1; -} - - -static int luaB_corunning (lua_State *L) { - int ismain = lua_pushthread(L); - lua_pushboolean(L, ismain); - return 2; -} - - -static const luaL_Reg co_funcs[] = { - {"create", luaB_cocreate}, - {"resume", luaB_coresume}, - {"running", luaB_corunning}, - {"status", luaB_costatus}, - {"wrap", luaB_cowrap}, - {"yield", luaB_yield}, - {NULL, NULL} -}; - - - -LUAMOD_API int luaopen_coroutine (lua_State *L) { - luaL_newlib(L, co_funcs); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/lctype.c b/btgui/lua-5.2.3/src/lctype.c deleted file mode 100644 index 93f8cadc3..000000000 --- a/btgui/lua-5.2.3/src/lctype.c +++ /dev/null @@ -1,52 +0,0 @@ -/* -** $Id: lctype.c,v 1.11.1.1 2013/04/12 18:48:47 roberto Exp $ -** 'ctype' functions for Lua -** See Copyright Notice in lua.h -*/ - -#define lctype_c -#define LUA_CORE - -#include "lctype.h" - -#if !LUA_USE_CTYPE /* { */ - -#include - -LUAI_DDEF const lu_byte luai_ctype_[UCHAR_MAX + 2] = { - 0x00, /* EOZ */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0. */ - 0x00, 0x08, 0x08, 0x08, 0x08, 0x08, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 1. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x0c, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, /* 2. */ - 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, - 0x16, 0x16, 0x16, 0x16, 0x16, 0x16, 0x16, 0x16, /* 3. */ - 0x16, 0x16, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, - 0x04, 0x15, 0x15, 0x15, 0x15, 0x15, 0x15, 0x05, /* 4. */ - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, /* 5. */ - 0x05, 0x05, 0x05, 0x04, 0x04, 0x04, 0x04, 0x05, - 0x04, 0x15, 0x15, 0x15, 0x15, 0x15, 0x15, 0x05, /* 6. */ - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, /* 7. */ - 0x05, 0x05, 0x05, 0x04, 0x04, 0x04, 0x04, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 8. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 9. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* a. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* b. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* c. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* d. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* e. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* f. */ - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -}; - -#endif /* } */ diff --git a/btgui/lua-5.2.3/src/lctype.h b/btgui/lua-5.2.3/src/lctype.h deleted file mode 100644 index b09b21a33..000000000 --- a/btgui/lua-5.2.3/src/lctype.h +++ /dev/null @@ -1,95 +0,0 @@ -/* -** $Id: lctype.h,v 1.12.1.1 2013/04/12 18:48:47 roberto Exp $ -** 'ctype' functions for Lua -** See Copyright Notice in lua.h -*/ - -#ifndef lctype_h -#define lctype_h - -#include "lua.h" - - -/* -** WARNING: the functions defined here do not necessarily correspond -** to the similar functions in the standard C ctype.h. They are -** optimized for the specific needs of Lua -*/ - -#if !defined(LUA_USE_CTYPE) - -#if 'A' == 65 && '0' == 48 -/* ASCII case: can use its own tables; faster and fixed */ -#define LUA_USE_CTYPE 0 -#else -/* must use standard C ctype */ -#define LUA_USE_CTYPE 1 -#endif - -#endif - - -#if !LUA_USE_CTYPE /* { */ - -#include - -#include "llimits.h" - - -#define ALPHABIT 0 -#define DIGITBIT 1 -#define PRINTBIT 2 -#define SPACEBIT 3 -#define XDIGITBIT 4 - - -#define MASK(B) (1 << (B)) - - -/* -** add 1 to char to allow index -1 (EOZ) -*/ -#define testprop(c,p) (luai_ctype_[(c)+1] & (p)) - -/* -** 'lalpha' (Lua alphabetic) and 'lalnum' (Lua alphanumeric) both include '_' -*/ -#define lislalpha(c) testprop(c, MASK(ALPHABIT)) -#define lislalnum(c) testprop(c, (MASK(ALPHABIT) | MASK(DIGITBIT))) -#define lisdigit(c) testprop(c, MASK(DIGITBIT)) -#define lisspace(c) testprop(c, MASK(SPACEBIT)) -#define lisprint(c) testprop(c, MASK(PRINTBIT)) -#define lisxdigit(c) testprop(c, MASK(XDIGITBIT)) - -/* -** this 'ltolower' only works for alphabetic characters -*/ -#define ltolower(c) ((c) | ('A' ^ 'a')) - - -/* two more entries for 0 and -1 (EOZ) */ -LUAI_DDEC const lu_byte luai_ctype_[UCHAR_MAX + 2]; - - -#else /* }{ */ - -/* -** use standard C ctypes -*/ - -#include - - -#define lislalpha(c) (isalpha(c) || (c) == '_') -#define lislalnum(c) (isalnum(c) || (c) == '_') -#define lisdigit(c) (isdigit(c)) -#define lisspace(c) (isspace(c)) -#define lisprint(c) (isprint(c)) -#define lisxdigit(c) (isxdigit(c)) - -#define ltolower(c) (tolower(c)) - -#endif /* } */ - -#endif - diff --git a/btgui/lua-5.2.3/src/ldblib.c b/btgui/lua-5.2.3/src/ldblib.c deleted file mode 100644 index 84fe3c7d8..000000000 --- a/btgui/lua-5.2.3/src/ldblib.c +++ /dev/null @@ -1,398 +0,0 @@ -/* -** $Id: ldblib.c,v 1.132.1.1 2013/04/12 18:48:47 roberto Exp $ -** Interface from Lua to its debug API -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include - -#define ldblib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -#define HOOKKEY "_HKEY" - - - -static int db_getregistry (lua_State *L) { - lua_pushvalue(L, LUA_REGISTRYINDEX); - return 1; -} - - -static int db_getmetatable (lua_State *L) { - luaL_checkany(L, 1); - if (!lua_getmetatable(L, 1)) { - lua_pushnil(L); /* no metatable */ - } - return 1; -} - - -static int db_setmetatable (lua_State *L) { - int t = lua_type(L, 2); - luaL_argcheck(L, t == LUA_TNIL || t == LUA_TTABLE, 2, - "nil or table expected"); - lua_settop(L, 2); - lua_setmetatable(L, 1); - return 1; /* return 1st argument */ -} - - -static int db_getuservalue (lua_State *L) { - if (lua_type(L, 1) != LUA_TUSERDATA) - lua_pushnil(L); - else - lua_getuservalue(L, 1); - return 1; -} - - -static int db_setuservalue (lua_State *L) { - if (lua_type(L, 1) == LUA_TLIGHTUSERDATA) - luaL_argerror(L, 1, "full userdata expected, got light userdata"); - luaL_checktype(L, 1, LUA_TUSERDATA); - if (!lua_isnoneornil(L, 2)) - luaL_checktype(L, 2, LUA_TTABLE); - lua_settop(L, 2); - lua_setuservalue(L, 1); - return 1; -} - - -static void settabss (lua_State *L, const char *i, const char *v) { - lua_pushstring(L, v); - lua_setfield(L, -2, i); -} - - -static void settabsi (lua_State *L, const char *i, int v) { - lua_pushinteger(L, v); - lua_setfield(L, -2, i); -} - - -static void settabsb (lua_State *L, const char *i, int v) { - lua_pushboolean(L, v); - lua_setfield(L, -2, i); -} - - -static lua_State *getthread (lua_State *L, int *arg) { - if (lua_isthread(L, 1)) { - *arg = 1; - return lua_tothread(L, 1); - } - else { - *arg = 0; - return L; - } -} - - -static void treatstackoption (lua_State *L, lua_State *L1, const char *fname) { - if (L == L1) { - lua_pushvalue(L, -2); - lua_remove(L, -3); - } - else - lua_xmove(L1, L, 1); - lua_setfield(L, -2, fname); -} - - -static int db_getinfo (lua_State *L) { - lua_Debug ar; - int arg; - lua_State *L1 = getthread(L, &arg); - const char *options = luaL_optstring(L, arg+2, "flnStu"); - if (lua_isnumber(L, arg+1)) { - if (!lua_getstack(L1, (int)lua_tointeger(L, arg+1), &ar)) { - lua_pushnil(L); /* level out of range */ - return 1; - } - } - else if (lua_isfunction(L, arg+1)) { - lua_pushfstring(L, ">%s", options); - options = lua_tostring(L, -1); - lua_pushvalue(L, arg+1); - lua_xmove(L, L1, 1); - } - else - return luaL_argerror(L, arg+1, "function or level expected"); - if (!lua_getinfo(L1, options, &ar)) - return luaL_argerror(L, arg+2, "invalid option"); - lua_createtable(L, 0, 2); - if (strchr(options, 'S')) { - settabss(L, "source", ar.source); - settabss(L, "short_src", ar.short_src); - settabsi(L, "linedefined", ar.linedefined); - settabsi(L, "lastlinedefined", ar.lastlinedefined); - settabss(L, "what", ar.what); - } - if (strchr(options, 'l')) - settabsi(L, "currentline", ar.currentline); - if (strchr(options, 'u')) { - settabsi(L, "nups", ar.nups); - settabsi(L, "nparams", ar.nparams); - settabsb(L, "isvararg", ar.isvararg); - } - if (strchr(options, 'n')) { - settabss(L, "name", ar.name); - settabss(L, "namewhat", ar.namewhat); - } - if (strchr(options, 't')) - settabsb(L, "istailcall", ar.istailcall); - if (strchr(options, 'L')) - treatstackoption(L, L1, "activelines"); - if (strchr(options, 'f')) - treatstackoption(L, L1, "func"); - return 1; /* return table */ -} - - -static int db_getlocal (lua_State *L) { - int arg; - lua_State *L1 = getthread(L, &arg); - lua_Debug ar; - const char *name; - int nvar = luaL_checkint(L, arg+2); /* local-variable index */ - if (lua_isfunction(L, arg + 1)) { /* function argument? */ - lua_pushvalue(L, arg + 1); /* push function */ - lua_pushstring(L, lua_getlocal(L, NULL, nvar)); /* push local name */ - return 1; - } - else { /* stack-level argument */ - if (!lua_getstack(L1, luaL_checkint(L, arg+1), &ar)) /* out of range? */ - return luaL_argerror(L, arg+1, "level out of range"); - name = lua_getlocal(L1, &ar, nvar); - if (name) { - lua_xmove(L1, L, 1); /* push local value */ - lua_pushstring(L, name); /* push name */ - lua_pushvalue(L, -2); /* re-order */ - return 2; - } - else { - lua_pushnil(L); /* no name (nor value) */ - return 1; - } - } -} - - -static int db_setlocal (lua_State *L) { - int arg; - lua_State *L1 = getthread(L, &arg); - lua_Debug ar; - if (!lua_getstack(L1, luaL_checkint(L, arg+1), &ar)) /* out of range? */ - return luaL_argerror(L, arg+1, "level out of range"); - luaL_checkany(L, arg+3); - lua_settop(L, arg+3); - lua_xmove(L, L1, 1); - lua_pushstring(L, lua_setlocal(L1, &ar, luaL_checkint(L, arg+2))); - return 1; -} - - -static int auxupvalue (lua_State *L, int get) { - const char *name; - int n = luaL_checkint(L, 2); - luaL_checktype(L, 1, LUA_TFUNCTION); - name = get ? lua_getupvalue(L, 1, n) : lua_setupvalue(L, 1, n); - if (name == NULL) return 0; - lua_pushstring(L, name); - lua_insert(L, -(get+1)); - return get + 1; -} - - -static int db_getupvalue (lua_State *L) { - return auxupvalue(L, 1); -} - - -static int db_setupvalue (lua_State *L) { - luaL_checkany(L, 3); - return auxupvalue(L, 0); -} - - -static int checkupval (lua_State *L, int argf, int argnup) { - lua_Debug ar; - int nup = luaL_checkint(L, argnup); - luaL_checktype(L, argf, LUA_TFUNCTION); - lua_pushvalue(L, argf); - lua_getinfo(L, ">u", &ar); - luaL_argcheck(L, 1 <= nup && nup <= ar.nups, argnup, "invalid upvalue index"); - return nup; -} - - -static int db_upvalueid (lua_State *L) { - int n = checkupval(L, 1, 2); - lua_pushlightuserdata(L, lua_upvalueid(L, 1, n)); - return 1; -} - - -static int db_upvaluejoin (lua_State *L) { - int n1 = checkupval(L, 1, 2); - int n2 = checkupval(L, 3, 4); - luaL_argcheck(L, !lua_iscfunction(L, 1), 1, "Lua function expected"); - luaL_argcheck(L, !lua_iscfunction(L, 3), 3, "Lua function expected"); - lua_upvaluejoin(L, 1, n1, 3, n2); - return 0; -} - - -#define gethooktable(L) luaL_getsubtable(L, LUA_REGISTRYINDEX, HOOKKEY) - - -static void hookf (lua_State *L, lua_Debug *ar) { - static const char *const hooknames[] = - {"call", "return", "line", "count", "tail call"}; - gethooktable(L); - lua_pushthread(L); - lua_rawget(L, -2); - if (lua_isfunction(L, -1)) { - lua_pushstring(L, hooknames[(int)ar->event]); - if (ar->currentline >= 0) - lua_pushinteger(L, ar->currentline); - else lua_pushnil(L); - lua_assert(lua_getinfo(L, "lS", ar)); - lua_call(L, 2, 0); - } -} - - -static int makemask (const char *smask, int count) { - int mask = 0; - if (strchr(smask, 'c')) mask |= LUA_MASKCALL; - if (strchr(smask, 'r')) mask |= LUA_MASKRET; - if (strchr(smask, 'l')) mask |= LUA_MASKLINE; - if (count > 0) mask |= LUA_MASKCOUNT; - return mask; -} - - -static char *unmakemask (int mask, char *smask) { - int i = 0; - if (mask & LUA_MASKCALL) smask[i++] = 'c'; - if (mask & LUA_MASKRET) smask[i++] = 'r'; - if (mask & LUA_MASKLINE) smask[i++] = 'l'; - smask[i] = '\0'; - return smask; -} - - -static int db_sethook (lua_State *L) { - int arg, mask, count; - lua_Hook func; - lua_State *L1 = getthread(L, &arg); - if (lua_isnoneornil(L, arg+1)) { - lua_settop(L, arg+1); - func = NULL; mask = 0; count = 0; /* turn off hooks */ - } - else { - const char *smask = luaL_checkstring(L, arg+2); - luaL_checktype(L, arg+1, LUA_TFUNCTION); - count = luaL_optint(L, arg+3, 0); - func = hookf; mask = makemask(smask, count); - } - if (gethooktable(L) == 0) { /* creating hook table? */ - lua_pushstring(L, "k"); - lua_setfield(L, -2, "__mode"); /** hooktable.__mode = "k" */ - lua_pushvalue(L, -1); - lua_setmetatable(L, -2); /* setmetatable(hooktable) = hooktable */ - } - lua_pushthread(L1); lua_xmove(L1, L, 1); - lua_pushvalue(L, arg+1); - lua_rawset(L, -3); /* set new hook */ - lua_sethook(L1, func, mask, count); /* set hooks */ - return 0; -} - - -static int db_gethook (lua_State *L) { - int arg; - lua_State *L1 = getthread(L, &arg); - char buff[5]; - int mask = lua_gethookmask(L1); - lua_Hook hook = lua_gethook(L1); - if (hook != NULL && hook != hookf) /* external hook? */ - lua_pushliteral(L, "external hook"); - else { - gethooktable(L); - lua_pushthread(L1); lua_xmove(L1, L, 1); - lua_rawget(L, -2); /* get hook */ - lua_remove(L, -2); /* remove hook table */ - } - lua_pushstring(L, unmakemask(mask, buff)); - lua_pushinteger(L, lua_gethookcount(L1)); - return 3; -} - - -static int db_debug (lua_State *L) { - for (;;) { - char buffer[250]; - luai_writestringerror("%s", "lua_debug> "); - if (fgets(buffer, sizeof(buffer), stdin) == 0 || - strcmp(buffer, "cont\n") == 0) - return 0; - if (luaL_loadbuffer(L, buffer, strlen(buffer), "=(debug command)") || - lua_pcall(L, 0, 0, 0)) - luai_writestringerror("%s\n", lua_tostring(L, -1)); - lua_settop(L, 0); /* remove eventual returns */ - } -} - - -static int db_traceback (lua_State *L) { - int arg; - lua_State *L1 = getthread(L, &arg); - const char *msg = lua_tostring(L, arg + 1); - if (msg == NULL && !lua_isnoneornil(L, arg + 1)) /* non-string 'msg'? */ - lua_pushvalue(L, arg + 1); /* return it untouched */ - else { - int level = luaL_optint(L, arg + 2, (L == L1) ? 1 : 0); - luaL_traceback(L, L1, msg, level); - } - return 1; -} - - -static const luaL_Reg dblib[] = { - {"debug", db_debug}, - {"getuservalue", db_getuservalue}, - {"gethook", db_gethook}, - {"getinfo", db_getinfo}, - {"getlocal", db_getlocal}, - {"getregistry", db_getregistry}, - {"getmetatable", db_getmetatable}, - {"getupvalue", db_getupvalue}, - {"upvaluejoin", db_upvaluejoin}, - {"upvalueid", db_upvalueid}, - {"setuservalue", db_setuservalue}, - {"sethook", db_sethook}, - {"setlocal", db_setlocal}, - {"setmetatable", db_setmetatable}, - {"setupvalue", db_setupvalue}, - {"traceback", db_traceback}, - {NULL, NULL} -}; - - -LUAMOD_API int luaopen_debug (lua_State *L) { - luaL_newlib(L, dblib); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/ldebug.c b/btgui/lua-5.2.3/src/ldebug.c deleted file mode 100644 index 20d663eff..000000000 --- a/btgui/lua-5.2.3/src/ldebug.c +++ /dev/null @@ -1,593 +0,0 @@ -/* -** $Id: ldebug.c,v 2.90.1.3 2013/05/16 16:04:15 roberto Exp $ -** Debug Interface -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include - - -#define ldebug_c -#define LUA_CORE - -#include "lua.h" - -#include "lapi.h" -#include "lcode.h" -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lobject.h" -#include "lopcodes.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" -#include "lvm.h" - - - -#define noLuaClosure(f) ((f) == NULL || (f)->c.tt == LUA_TCCL) - - -static const char *getfuncname (lua_State *L, CallInfo *ci, const char **name); - - -static int currentpc (CallInfo *ci) { - lua_assert(isLua(ci)); - return pcRel(ci->u.l.savedpc, ci_func(ci)->p); -} - - -static int currentline (CallInfo *ci) { - return getfuncline(ci_func(ci)->p, currentpc(ci)); -} - - -/* -** this function can be called asynchronous (e.g. during a signal) -*/ -LUA_API int lua_sethook (lua_State *L, lua_Hook func, int mask, int count) { - if (func == NULL || mask == 0) { /* turn off hooks? */ - mask = 0; - func = NULL; - } - if (isLua(L->ci)) - L->oldpc = L->ci->u.l.savedpc; - L->hook = func; - L->basehookcount = count; - resethookcount(L); - L->hookmask = cast_byte(mask); - return 1; -} - - -LUA_API lua_Hook lua_gethook (lua_State *L) { - return L->hook; -} - - -LUA_API int lua_gethookmask (lua_State *L) { - return L->hookmask; -} - - -LUA_API int lua_gethookcount (lua_State *L) { - return L->basehookcount; -} - - -LUA_API int lua_getstack (lua_State *L, int level, lua_Debug *ar) { - int status; - CallInfo *ci; - if (level < 0) return 0; /* invalid (negative) level */ - lua_lock(L); - for (ci = L->ci; level > 0 && ci != &L->base_ci; ci = ci->previous) - level--; - if (level == 0 && ci != &L->base_ci) { /* level found? */ - status = 1; - ar->i_ci = ci; - } - else status = 0; /* no such level */ - lua_unlock(L); - return status; -} - - -static const char *upvalname (Proto *p, int uv) { - TString *s = check_exp(uv < p->sizeupvalues, p->upvalues[uv].name); - if (s == NULL) return "?"; - else return getstr(s); -} - - -static const char *findvararg (CallInfo *ci, int n, StkId *pos) { - int nparams = clLvalue(ci->func)->p->numparams; - if (n >= ci->u.l.base - ci->func - nparams) - return NULL; /* no such vararg */ - else { - *pos = ci->func + nparams + n; - return "(*vararg)"; /* generic name for any vararg */ - } -} - - -static const char *findlocal (lua_State *L, CallInfo *ci, int n, - StkId *pos) { - const char *name = NULL; - StkId base; - if (isLua(ci)) { - if (n < 0) /* access to vararg values? */ - return findvararg(ci, -n, pos); - else { - base = ci->u.l.base; - name = luaF_getlocalname(ci_func(ci)->p, n, currentpc(ci)); - } - } - else - base = ci->func + 1; - if (name == NULL) { /* no 'standard' name? */ - StkId limit = (ci == L->ci) ? L->top : ci->next->func; - if (limit - base >= n && n > 0) /* is 'n' inside 'ci' stack? */ - name = "(*temporary)"; /* generic name for any valid slot */ - else - return NULL; /* no name */ - } - *pos = base + (n - 1); - return name; -} - - -LUA_API const char *lua_getlocal (lua_State *L, const lua_Debug *ar, int n) { - const char *name; - lua_lock(L); - if (ar == NULL) { /* information about non-active function? */ - if (!isLfunction(L->top - 1)) /* not a Lua function? */ - name = NULL; - else /* consider live variables at function start (parameters) */ - name = luaF_getlocalname(clLvalue(L->top - 1)->p, n, 0); - } - else { /* active function; get information through 'ar' */ - StkId pos = 0; /* to avoid warnings */ - name = findlocal(L, ar->i_ci, n, &pos); - if (name) { - setobj2s(L, L->top, pos); - api_incr_top(L); - } - } - lua_unlock(L); - return name; -} - - -LUA_API const char *lua_setlocal (lua_State *L, const lua_Debug *ar, int n) { - StkId pos = 0; /* to avoid warnings */ - const char *name = findlocal(L, ar->i_ci, n, &pos); - lua_lock(L); - if (name) - setobjs2s(L, pos, L->top - 1); - L->top--; /* pop value */ - lua_unlock(L); - return name; -} - - -static void funcinfo (lua_Debug *ar, Closure *cl) { - if (noLuaClosure(cl)) { - ar->source = "=[C]"; - ar->linedefined = -1; - ar->lastlinedefined = -1; - ar->what = "C"; - } - else { - Proto *p = cl->l.p; - ar->source = p->source ? getstr(p->source) : "=?"; - ar->linedefined = p->linedefined; - ar->lastlinedefined = p->lastlinedefined; - ar->what = (ar->linedefined == 0) ? "main" : "Lua"; - } - luaO_chunkid(ar->short_src, ar->source, LUA_IDSIZE); -} - - -static void collectvalidlines (lua_State *L, Closure *f) { - if (noLuaClosure(f)) { - setnilvalue(L->top); - api_incr_top(L); - } - else { - int i; - TValue v; - int *lineinfo = f->l.p->lineinfo; - Table *t = luaH_new(L); /* new table to store active lines */ - sethvalue(L, L->top, t); /* push it on stack */ - api_incr_top(L); - setbvalue(&v, 1); /* boolean 'true' to be the value of all indices */ - for (i = 0; i < f->l.p->sizelineinfo; i++) /* for all lines with code */ - luaH_setint(L, t, lineinfo[i], &v); /* table[line] = true */ - } -} - - -static int auxgetinfo (lua_State *L, const char *what, lua_Debug *ar, - Closure *f, CallInfo *ci) { - int status = 1; - for (; *what; what++) { - switch (*what) { - case 'S': { - funcinfo(ar, f); - break; - } - case 'l': { - ar->currentline = (ci && isLua(ci)) ? currentline(ci) : -1; - break; - } - case 'u': { - ar->nups = (f == NULL) ? 0 : f->c.nupvalues; - if (noLuaClosure(f)) { - ar->isvararg = 1; - ar->nparams = 0; - } - else { - ar->isvararg = f->l.p->is_vararg; - ar->nparams = f->l.p->numparams; - } - break; - } - case 't': { - ar->istailcall = (ci) ? ci->callstatus & CIST_TAIL : 0; - break; - } - case 'n': { - /* calling function is a known Lua function? */ - if (ci && !(ci->callstatus & CIST_TAIL) && isLua(ci->previous)) - ar->namewhat = getfuncname(L, ci->previous, &ar->name); - else - ar->namewhat = NULL; - if (ar->namewhat == NULL) { - ar->namewhat = ""; /* not found */ - ar->name = NULL; - } - break; - } - case 'L': - case 'f': /* handled by lua_getinfo */ - break; - default: status = 0; /* invalid option */ - } - } - return status; -} - - -LUA_API int lua_getinfo (lua_State *L, const char *what, lua_Debug *ar) { - int status; - Closure *cl; - CallInfo *ci; - StkId func; - lua_lock(L); - if (*what == '>') { - ci = NULL; - func = L->top - 1; - api_check(L, ttisfunction(func), "function expected"); - what++; /* skip the '>' */ - L->top--; /* pop function */ - } - else { - ci = ar->i_ci; - func = ci->func; - lua_assert(ttisfunction(ci->func)); - } - cl = ttisclosure(func) ? clvalue(func) : NULL; - status = auxgetinfo(L, what, ar, cl, ci); - if (strchr(what, 'f')) { - setobjs2s(L, L->top, func); - api_incr_top(L); - } - if (strchr(what, 'L')) - collectvalidlines(L, cl); - lua_unlock(L); - return status; -} - - -/* -** {====================================================== -** Symbolic Execution -** ======================================================= -*/ - -static const char *getobjname (Proto *p, int lastpc, int reg, - const char **name); - - -/* -** find a "name" for the RK value 'c' -*/ -static void kname (Proto *p, int pc, int c, const char **name) { - if (ISK(c)) { /* is 'c' a constant? */ - TValue *kvalue = &p->k[INDEXK(c)]; - if (ttisstring(kvalue)) { /* literal constant? */ - *name = svalue(kvalue); /* it is its own name */ - return; - } - /* else no reasonable name found */ - } - else { /* 'c' is a register */ - const char *what = getobjname(p, pc, c, name); /* search for 'c' */ - if (what && *what == 'c') { /* found a constant name? */ - return; /* 'name' already filled */ - } - /* else no reasonable name found */ - } - *name = "?"; /* no reasonable name found */ -} - - -static int filterpc (int pc, int jmptarget) { - if (pc < jmptarget) /* is code conditional (inside a jump)? */ - return -1; /* cannot know who sets that register */ - else return pc; /* current position sets that register */ -} - - -/* -** try to find last instruction before 'lastpc' that modified register 'reg' -*/ -static int findsetreg (Proto *p, int lastpc, int reg) { - int pc; - int setreg = -1; /* keep last instruction that changed 'reg' */ - int jmptarget = 0; /* any code before this address is conditional */ - for (pc = 0; pc < lastpc; pc++) { - Instruction i = p->code[pc]; - OpCode op = GET_OPCODE(i); - int a = GETARG_A(i); - switch (op) { - case OP_LOADNIL: { - int b = GETARG_B(i); - if (a <= reg && reg <= a + b) /* set registers from 'a' to 'a+b' */ - setreg = filterpc(pc, jmptarget); - break; - } - case OP_TFORCALL: { - if (reg >= a + 2) /* affect all regs above its base */ - setreg = filterpc(pc, jmptarget); - break; - } - case OP_CALL: - case OP_TAILCALL: { - if (reg >= a) /* affect all registers above base */ - setreg = filterpc(pc, jmptarget); - break; - } - case OP_JMP: { - int b = GETARG_sBx(i); - int dest = pc + 1 + b; - /* jump is forward and do not skip `lastpc'? */ - if (pc < dest && dest <= lastpc) { - if (dest > jmptarget) - jmptarget = dest; /* update 'jmptarget' */ - } - break; - } - case OP_TEST: { - if (reg == a) /* jumped code can change 'a' */ - setreg = filterpc(pc, jmptarget); - break; - } - default: - if (testAMode(op) && reg == a) /* any instruction that set A */ - setreg = filterpc(pc, jmptarget); - break; - } - } - return setreg; -} - - -static const char *getobjname (Proto *p, int lastpc, int reg, - const char **name) { - int pc; - *name = luaF_getlocalname(p, reg + 1, lastpc); - if (*name) /* is a local? */ - return "local"; - /* else try symbolic execution */ - pc = findsetreg(p, lastpc, reg); - if (pc != -1) { /* could find instruction? */ - Instruction i = p->code[pc]; - OpCode op = GET_OPCODE(i); - switch (op) { - case OP_MOVE: { - int b = GETARG_B(i); /* move from 'b' to 'a' */ - if (b < GETARG_A(i)) - return getobjname(p, pc, b, name); /* get name for 'b' */ - break; - } - case OP_GETTABUP: - case OP_GETTABLE: { - int k = GETARG_C(i); /* key index */ - int t = GETARG_B(i); /* table index */ - const char *vn = (op == OP_GETTABLE) /* name of indexed variable */ - ? luaF_getlocalname(p, t + 1, pc) - : upvalname(p, t); - kname(p, pc, k, name); - return (vn && strcmp(vn, LUA_ENV) == 0) ? "global" : "field"; - } - case OP_GETUPVAL: { - *name = upvalname(p, GETARG_B(i)); - return "upvalue"; - } - case OP_LOADK: - case OP_LOADKX: { - int b = (op == OP_LOADK) ? GETARG_Bx(i) - : GETARG_Ax(p->code[pc + 1]); - if (ttisstring(&p->k[b])) { - *name = svalue(&p->k[b]); - return "constant"; - } - break; - } - case OP_SELF: { - int k = GETARG_C(i); /* key index */ - kname(p, pc, k, name); - return "method"; - } - default: break; /* go through to return NULL */ - } - } - return NULL; /* could not find reasonable name */ -} - - -static const char *getfuncname (lua_State *L, CallInfo *ci, const char **name) { - TMS tm; - Proto *p = ci_func(ci)->p; /* calling function */ - int pc = currentpc(ci); /* calling instruction index */ - Instruction i = p->code[pc]; /* calling instruction */ - switch (GET_OPCODE(i)) { - case OP_CALL: - case OP_TAILCALL: /* get function name */ - return getobjname(p, pc, GETARG_A(i), name); - case OP_TFORCALL: { /* for iterator */ - *name = "for iterator"; - return "for iterator"; - } - /* all other instructions can call only through metamethods */ - case OP_SELF: - case OP_GETTABUP: - case OP_GETTABLE: tm = TM_INDEX; break; - case OP_SETTABUP: - case OP_SETTABLE: tm = TM_NEWINDEX; break; - case OP_EQ: tm = TM_EQ; break; - case OP_ADD: tm = TM_ADD; break; - case OP_SUB: tm = TM_SUB; break; - case OP_MUL: tm = TM_MUL; break; - case OP_DIV: tm = TM_DIV; break; - case OP_MOD: tm = TM_MOD; break; - case OP_POW: tm = TM_POW; break; - case OP_UNM: tm = TM_UNM; break; - case OP_LEN: tm = TM_LEN; break; - case OP_LT: tm = TM_LT; break; - case OP_LE: tm = TM_LE; break; - case OP_CONCAT: tm = TM_CONCAT; break; - default: - return NULL; /* else no useful name can be found */ - } - *name = getstr(G(L)->tmname[tm]); - return "metamethod"; -} - -/* }====================================================== */ - - - -/* -** only ANSI way to check whether a pointer points to an array -** (used only for error messages, so efficiency is not a big concern) -*/ -static int isinstack (CallInfo *ci, const TValue *o) { - StkId p; - for (p = ci->u.l.base; p < ci->top; p++) - if (o == p) return 1; - return 0; -} - - -static const char *getupvalname (CallInfo *ci, const TValue *o, - const char **name) { - LClosure *c = ci_func(ci); - int i; - for (i = 0; i < c->nupvalues; i++) { - if (c->upvals[i]->v == o) { - *name = upvalname(c->p, i); - return "upvalue"; - } - } - return NULL; -} - - -l_noret luaG_typeerror (lua_State *L, const TValue *o, const char *op) { - CallInfo *ci = L->ci; - const char *name = NULL; - const char *t = objtypename(o); - const char *kind = NULL; - if (isLua(ci)) { - kind = getupvalname(ci, o, &name); /* check whether 'o' is an upvalue */ - if (!kind && isinstack(ci, o)) /* no? try a register */ - kind = getobjname(ci_func(ci)->p, currentpc(ci), - cast_int(o - ci->u.l.base), &name); - } - if (kind) - luaG_runerror(L, "attempt to %s %s " LUA_QS " (a %s value)", - op, kind, name, t); - else - luaG_runerror(L, "attempt to %s a %s value", op, t); -} - - -l_noret luaG_concaterror (lua_State *L, StkId p1, StkId p2) { - if (ttisstring(p1) || ttisnumber(p1)) p1 = p2; - lua_assert(!ttisstring(p1) && !ttisnumber(p1)); - luaG_typeerror(L, p1, "concatenate"); -} - - -l_noret luaG_aritherror (lua_State *L, const TValue *p1, const TValue *p2) { - TValue temp; - if (luaV_tonumber(p1, &temp) == NULL) - p2 = p1; /* first operand is wrong */ - luaG_typeerror(L, p2, "perform arithmetic on"); -} - - -l_noret luaG_ordererror (lua_State *L, const TValue *p1, const TValue *p2) { - const char *t1 = objtypename(p1); - const char *t2 = objtypename(p2); - if (t1 == t2) - luaG_runerror(L, "attempt to compare two %s values", t1); - else - luaG_runerror(L, "attempt to compare %s with %s", t1, t2); -} - - -static void addinfo (lua_State *L, const char *msg) { - CallInfo *ci = L->ci; - if (isLua(ci)) { /* is Lua code? */ - char buff[LUA_IDSIZE]; /* add file:line information */ - int line = currentline(ci); - TString *src = ci_func(ci)->p->source; - if (src) - luaO_chunkid(buff, getstr(src), LUA_IDSIZE); - else { /* no source available; use "?" instead */ - buff[0] = '?'; buff[1] = '\0'; - } - luaO_pushfstring(L, "%s:%d: %s", buff, line, msg); - } -} - - -l_noret luaG_errormsg (lua_State *L) { - if (L->errfunc != 0) { /* is there an error handling function? */ - StkId errfunc = restorestack(L, L->errfunc); - if (!ttisfunction(errfunc)) luaD_throw(L, LUA_ERRERR); - setobjs2s(L, L->top, L->top - 1); /* move argument */ - setobjs2s(L, L->top - 1, errfunc); /* push function */ - L->top++; - luaD_call(L, L->top - 2, 1, 0); /* call it */ - } - luaD_throw(L, LUA_ERRRUN); -} - - -l_noret luaG_runerror (lua_State *L, const char *fmt, ...) { - va_list argp; - va_start(argp, fmt); - addinfo(L, luaO_pushvfstring(L, fmt, argp)); - va_end(argp); - luaG_errormsg(L); -} - diff --git a/btgui/lua-5.2.3/src/ldebug.h b/btgui/lua-5.2.3/src/ldebug.h deleted file mode 100644 index 6445c763e..000000000 --- a/btgui/lua-5.2.3/src/ldebug.h +++ /dev/null @@ -1,34 +0,0 @@ -/* -** $Id: ldebug.h,v 2.7.1.1 2013/04/12 18:48:47 roberto Exp $ -** Auxiliary functions from Debug Interface module -** See Copyright Notice in lua.h -*/ - -#ifndef ldebug_h -#define ldebug_h - - -#include "lstate.h" - - -#define pcRel(pc, p) (cast(int, (pc) - (p)->code) - 1) - -#define getfuncline(f,pc) (((f)->lineinfo) ? (f)->lineinfo[pc] : 0) - -#define resethookcount(L) (L->hookcount = L->basehookcount) - -/* Active Lua function (given call info) */ -#define ci_func(ci) (clLvalue((ci)->func)) - - -LUAI_FUNC l_noret luaG_typeerror (lua_State *L, const TValue *o, - const char *opname); -LUAI_FUNC l_noret luaG_concaterror (lua_State *L, StkId p1, StkId p2); -LUAI_FUNC l_noret luaG_aritherror (lua_State *L, const TValue *p1, - const TValue *p2); -LUAI_FUNC l_noret luaG_ordererror (lua_State *L, const TValue *p1, - const TValue *p2); -LUAI_FUNC l_noret luaG_runerror (lua_State *L, const char *fmt, ...); -LUAI_FUNC l_noret luaG_errormsg (lua_State *L); - -#endif diff --git a/btgui/lua-5.2.3/src/ldo.c b/btgui/lua-5.2.3/src/ldo.c deleted file mode 100644 index e9dd5fa95..000000000 --- a/btgui/lua-5.2.3/src/ldo.c +++ /dev/null @@ -1,681 +0,0 @@ -/* -** $Id: ldo.c,v 2.108.1.3 2013/11/08 18:22:50 roberto Exp $ -** Stack and Call structure of Lua -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include - -#define ldo_c -#define LUA_CORE - -#include "lua.h" - -#include "lapi.h" -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lgc.h" -#include "lmem.h" -#include "lobject.h" -#include "lopcodes.h" -#include "lparser.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" -#include "lundump.h" -#include "lvm.h" -#include "lzio.h" - - - - -/* -** {====================================================== -** Error-recovery functions -** ======================================================= -*/ - -/* -** LUAI_THROW/LUAI_TRY define how Lua does exception handling. By -** default, Lua handles errors with exceptions when compiling as -** C++ code, with _longjmp/_setjmp when asked to use them, and with -** longjmp/setjmp otherwise. -*/ -#if !defined(LUAI_THROW) - -#if defined(__cplusplus) && !defined(LUA_USE_LONGJMP) -/* C++ exceptions */ -#define LUAI_THROW(L,c) throw(c) -#define LUAI_TRY(L,c,a) \ - try { a } catch(...) { if ((c)->status == 0) (c)->status = -1; } -#define luai_jmpbuf int /* dummy variable */ - -#elif defined(LUA_USE_ULONGJMP) -/* in Unix, try _longjmp/_setjmp (more efficient) */ -#define LUAI_THROW(L,c) _longjmp((c)->b, 1) -#define LUAI_TRY(L,c,a) if (_setjmp((c)->b) == 0) { a } -#define luai_jmpbuf jmp_buf - -#else -/* default handling with long jumps */ -#define LUAI_THROW(L,c) longjmp((c)->b, 1) -#define LUAI_TRY(L,c,a) if (setjmp((c)->b) == 0) { a } -#define luai_jmpbuf jmp_buf - -#endif - -#endif - - - -/* chain list of long jump buffers */ -struct lua_longjmp { - struct lua_longjmp *previous; - luai_jmpbuf b; - volatile int status; /* error code */ -}; - - -static void seterrorobj (lua_State *L, int errcode, StkId oldtop) { - switch (errcode) { - case LUA_ERRMEM: { /* memory error? */ - setsvalue2s(L, oldtop, G(L)->memerrmsg); /* reuse preregistered msg. */ - break; - } - case LUA_ERRERR: { - setsvalue2s(L, oldtop, luaS_newliteral(L, "error in error handling")); - break; - } - default: { - setobjs2s(L, oldtop, L->top - 1); /* error message on current top */ - break; - } - } - L->top = oldtop + 1; -} - - -l_noret luaD_throw (lua_State *L, int errcode) { - if (L->errorJmp) { /* thread has an error handler? */ - L->errorJmp->status = errcode; /* set status */ - LUAI_THROW(L, L->errorJmp); /* jump to it */ - } - else { /* thread has no error handler */ - L->status = cast_byte(errcode); /* mark it as dead */ - if (G(L)->mainthread->errorJmp) { /* main thread has a handler? */ - setobjs2s(L, G(L)->mainthread->top++, L->top - 1); /* copy error obj. */ - luaD_throw(G(L)->mainthread, errcode); /* re-throw in main thread */ - } - else { /* no handler at all; abort */ - if (G(L)->panic) { /* panic function? */ - lua_unlock(L); - G(L)->panic(L); /* call it (last chance to jump out) */ - } - abort(); - } - } -} - - -int luaD_rawrunprotected (lua_State *L, Pfunc f, void *ud) { - unsigned short oldnCcalls = L->nCcalls; - struct lua_longjmp lj; - lj.status = LUA_OK; - lj.previous = L->errorJmp; /* chain new error handler */ - L->errorJmp = &lj; - LUAI_TRY(L, &lj, - (*f)(L, ud); - ); - L->errorJmp = lj.previous; /* restore old error handler */ - L->nCcalls = oldnCcalls; - return lj.status; -} - -/* }====================================================== */ - - -static void correctstack (lua_State *L, TValue *oldstack) { - CallInfo *ci; - GCObject *up; - L->top = (L->top - oldstack) + L->stack; - for (up = L->openupval; up != NULL; up = up->gch.next) - gco2uv(up)->v = (gco2uv(up)->v - oldstack) + L->stack; - for (ci = L->ci; ci != NULL; ci = ci->previous) { - ci->top = (ci->top - oldstack) + L->stack; - ci->func = (ci->func - oldstack) + L->stack; - if (isLua(ci)) - ci->u.l.base = (ci->u.l.base - oldstack) + L->stack; - } -} - - -/* some space for error handling */ -#define ERRORSTACKSIZE (LUAI_MAXSTACK + 200) - - -void luaD_reallocstack (lua_State *L, int newsize) { - TValue *oldstack = L->stack; - int lim = L->stacksize; - lua_assert(newsize <= LUAI_MAXSTACK || newsize == ERRORSTACKSIZE); - lua_assert(L->stack_last - L->stack == L->stacksize - EXTRA_STACK); - luaM_reallocvector(L, L->stack, L->stacksize, newsize, TValue); - for (; lim < newsize; lim++) - setnilvalue(L->stack + lim); /* erase new segment */ - L->stacksize = newsize; - L->stack_last = L->stack + newsize - EXTRA_STACK; - correctstack(L, oldstack); -} - - -void luaD_growstack (lua_State *L, int n) { - int size = L->stacksize; - if (size > LUAI_MAXSTACK) /* error after extra size? */ - luaD_throw(L, LUA_ERRERR); - else { - int needed = cast_int(L->top - L->stack) + n + EXTRA_STACK; - int newsize = 2 * size; - if (newsize > LUAI_MAXSTACK) newsize = LUAI_MAXSTACK; - if (newsize < needed) newsize = needed; - if (newsize > LUAI_MAXSTACK) { /* stack overflow? */ - luaD_reallocstack(L, ERRORSTACKSIZE); - luaG_runerror(L, "stack overflow"); - } - else - luaD_reallocstack(L, newsize); - } -} - - -static int stackinuse (lua_State *L) { - CallInfo *ci; - StkId lim = L->top; - for (ci = L->ci; ci != NULL; ci = ci->previous) { - lua_assert(ci->top <= L->stack_last); - if (lim < ci->top) lim = ci->top; - } - return cast_int(lim - L->stack) + 1; /* part of stack in use */ -} - - -void luaD_shrinkstack (lua_State *L) { - int inuse = stackinuse(L); - int goodsize = inuse + (inuse / 8) + 2*EXTRA_STACK; - if (goodsize > LUAI_MAXSTACK) goodsize = LUAI_MAXSTACK; - if (inuse > LUAI_MAXSTACK || /* handling stack overflow? */ - goodsize >= L->stacksize) /* would grow instead of shrink? */ - condmovestack(L); /* don't change stack (change only for debugging) */ - else - luaD_reallocstack(L, goodsize); /* shrink it */ -} - - -void luaD_hook (lua_State *L, int event, int line) { - lua_Hook hook = L->hook; - if (hook && L->allowhook) { - CallInfo *ci = L->ci; - ptrdiff_t top = savestack(L, L->top); - ptrdiff_t ci_top = savestack(L, ci->top); - lua_Debug ar; - ar.event = event; - ar.currentline = line; - ar.i_ci = ci; - luaD_checkstack(L, LUA_MINSTACK); /* ensure minimum stack size */ - ci->top = L->top + LUA_MINSTACK; - lua_assert(ci->top <= L->stack_last); - L->allowhook = 0; /* cannot call hooks inside a hook */ - ci->callstatus |= CIST_HOOKED; - lua_unlock(L); - (*hook)(L, &ar); - lua_lock(L); - lua_assert(!L->allowhook); - L->allowhook = 1; - ci->top = restorestack(L, ci_top); - L->top = restorestack(L, top); - ci->callstatus &= ~CIST_HOOKED; - } -} - - -static void callhook (lua_State *L, CallInfo *ci) { - int hook = LUA_HOOKCALL; - ci->u.l.savedpc++; /* hooks assume 'pc' is already incremented */ - if (isLua(ci->previous) && - GET_OPCODE(*(ci->previous->u.l.savedpc - 1)) == OP_TAILCALL) { - ci->callstatus |= CIST_TAIL; - hook = LUA_HOOKTAILCALL; - } - luaD_hook(L, hook, -1); - ci->u.l.savedpc--; /* correct 'pc' */ -} - - -static StkId adjust_varargs (lua_State *L, Proto *p, int actual) { - int i; - int nfixargs = p->numparams; - StkId base, fixed; - lua_assert(actual >= nfixargs); - /* move fixed parameters to final position */ - luaD_checkstack(L, p->maxstacksize); /* check again for new 'base' */ - fixed = L->top - actual; /* first fixed argument */ - base = L->top; /* final position of first argument */ - for (i=0; itop++, fixed + i); - setnilvalue(fixed + i); - } - return base; -} - - -static StkId tryfuncTM (lua_State *L, StkId func) { - const TValue *tm = luaT_gettmbyobj(L, func, TM_CALL); - StkId p; - ptrdiff_t funcr = savestack(L, func); - if (!ttisfunction(tm)) - luaG_typeerror(L, func, "call"); - /* Open a hole inside the stack at `func' */ - for (p = L->top; p > func; p--) setobjs2s(L, p, p-1); - incr_top(L); - func = restorestack(L, funcr); /* previous call may change stack */ - setobj2s(L, func, tm); /* tag method is the new function to be called */ - return func; -} - - - -#define next_ci(L) (L->ci = (L->ci->next ? L->ci->next : luaE_extendCI(L))) - - -/* -** returns true if function has been executed (C function) -*/ -int luaD_precall (lua_State *L, StkId func, int nresults) { - lua_CFunction f; - CallInfo *ci; - int n; /* number of arguments (Lua) or returns (C) */ - ptrdiff_t funcr = savestack(L, func); - switch (ttype(func)) { - case LUA_TLCF: /* light C function */ - f = fvalue(func); - goto Cfunc; - case LUA_TCCL: { /* C closure */ - f = clCvalue(func)->f; - Cfunc: - luaD_checkstack(L, LUA_MINSTACK); /* ensure minimum stack size */ - ci = next_ci(L); /* now 'enter' new function */ - ci->nresults = nresults; - ci->func = restorestack(L, funcr); - ci->top = L->top + LUA_MINSTACK; - lua_assert(ci->top <= L->stack_last); - ci->callstatus = 0; - luaC_checkGC(L); /* stack grow uses memory */ - if (L->hookmask & LUA_MASKCALL) - luaD_hook(L, LUA_HOOKCALL, -1); - lua_unlock(L); - n = (*f)(L); /* do the actual call */ - lua_lock(L); - api_checknelems(L, n); - luaD_poscall(L, L->top - n); - return 1; - } - case LUA_TLCL: { /* Lua function: prepare its call */ - StkId base; - Proto *p = clLvalue(func)->p; - n = cast_int(L->top - func) - 1; /* number of real arguments */ - luaD_checkstack(L, p->maxstacksize); - for (; n < p->numparams; n++) - setnilvalue(L->top++); /* complete missing arguments */ - if (!p->is_vararg) { - func = restorestack(L, funcr); - base = func + 1; - } - else { - base = adjust_varargs(L, p, n); - func = restorestack(L, funcr); /* previous call can change stack */ - } - ci = next_ci(L); /* now 'enter' new function */ - ci->nresults = nresults; - ci->func = func; - ci->u.l.base = base; - ci->top = base + p->maxstacksize; - lua_assert(ci->top <= L->stack_last); - ci->u.l.savedpc = p->code; /* starting point */ - ci->callstatus = CIST_LUA; - L->top = ci->top; - luaC_checkGC(L); /* stack grow uses memory */ - if (L->hookmask & LUA_MASKCALL) - callhook(L, ci); - return 0; - } - default: { /* not a function */ - func = tryfuncTM(L, func); /* retry with 'function' tag method */ - return luaD_precall(L, func, nresults); /* now it must be a function */ - } - } -} - - -int luaD_poscall (lua_State *L, StkId firstResult) { - StkId res; - int wanted, i; - CallInfo *ci = L->ci; - if (L->hookmask & (LUA_MASKRET | LUA_MASKLINE)) { - if (L->hookmask & LUA_MASKRET) { - ptrdiff_t fr = savestack(L, firstResult); /* hook may change stack */ - luaD_hook(L, LUA_HOOKRET, -1); - firstResult = restorestack(L, fr); - } - L->oldpc = ci->previous->u.l.savedpc; /* 'oldpc' for caller function */ - } - res = ci->func; /* res == final position of 1st result */ - wanted = ci->nresults; - L->ci = ci = ci->previous; /* back to caller */ - /* move results to correct place */ - for (i = wanted; i != 0 && firstResult < L->top; i--) - setobjs2s(L, res++, firstResult++); - while (i-- > 0) - setnilvalue(res++); - L->top = res; - return (wanted - LUA_MULTRET); /* 0 iff wanted == LUA_MULTRET */ -} - - -/* -** Call a function (C or Lua). The function to be called is at *func. -** The arguments are on the stack, right after the function. -** When returns, all the results are on the stack, starting at the original -** function position. -*/ -void luaD_call (lua_State *L, StkId func, int nResults, int allowyield) { - if (++L->nCcalls >= LUAI_MAXCCALLS) { - if (L->nCcalls == LUAI_MAXCCALLS) - luaG_runerror(L, "C stack overflow"); - else if (L->nCcalls >= (LUAI_MAXCCALLS + (LUAI_MAXCCALLS>>3))) - luaD_throw(L, LUA_ERRERR); /* error while handing stack error */ - } - if (!allowyield) L->nny++; - if (!luaD_precall(L, func, nResults)) /* is a Lua function? */ - luaV_execute(L); /* call it */ - if (!allowyield) L->nny--; - L->nCcalls--; -} - - -static void finishCcall (lua_State *L) { - CallInfo *ci = L->ci; - int n; - lua_assert(ci->u.c.k != NULL); /* must have a continuation */ - lua_assert(L->nny == 0); - if (ci->callstatus & CIST_YPCALL) { /* was inside a pcall? */ - ci->callstatus &= ~CIST_YPCALL; /* finish 'lua_pcall' */ - L->errfunc = ci->u.c.old_errfunc; - } - /* finish 'lua_callk'/'lua_pcall' */ - adjustresults(L, ci->nresults); - /* call continuation function */ - if (!(ci->callstatus & CIST_STAT)) /* no call status? */ - ci->u.c.status = LUA_YIELD; /* 'default' status */ - lua_assert(ci->u.c.status != LUA_OK); - ci->callstatus = (ci->callstatus & ~(CIST_YPCALL | CIST_STAT)) | CIST_YIELDED; - lua_unlock(L); - n = (*ci->u.c.k)(L); - lua_lock(L); - api_checknelems(L, n); - /* finish 'luaD_precall' */ - luaD_poscall(L, L->top - n); -} - - -static void unroll (lua_State *L, void *ud) { - UNUSED(ud); - for (;;) { - if (L->ci == &L->base_ci) /* stack is empty? */ - return; /* coroutine finished normally */ - if (!isLua(L->ci)) /* C function? */ - finishCcall(L); - else { /* Lua function */ - luaV_finishOp(L); /* finish interrupted instruction */ - luaV_execute(L); /* execute down to higher C 'boundary' */ - } - } -} - - -/* -** check whether thread has a suspended protected call -*/ -static CallInfo *findpcall (lua_State *L) { - CallInfo *ci; - for (ci = L->ci; ci != NULL; ci = ci->previous) { /* search for a pcall */ - if (ci->callstatus & CIST_YPCALL) - return ci; - } - return NULL; /* no pending pcall */ -} - - -static int recover (lua_State *L, int status) { - StkId oldtop; - CallInfo *ci = findpcall(L); - if (ci == NULL) return 0; /* no recovery point */ - /* "finish" luaD_pcall */ - oldtop = restorestack(L, ci->extra); - luaF_close(L, oldtop); - seterrorobj(L, status, oldtop); - L->ci = ci; - L->allowhook = ci->u.c.old_allowhook; - L->nny = 0; /* should be zero to be yieldable */ - luaD_shrinkstack(L); - L->errfunc = ci->u.c.old_errfunc; - ci->callstatus |= CIST_STAT; /* call has error status */ - ci->u.c.status = status; /* (here it is) */ - return 1; /* continue running the coroutine */ -} - - -/* -** signal an error in the call to 'resume', not in the execution of the -** coroutine itself. (Such errors should not be handled by any coroutine -** error handler and should not kill the coroutine.) -*/ -static l_noret resume_error (lua_State *L, const char *msg, StkId firstArg) { - L->top = firstArg; /* remove args from the stack */ - setsvalue2s(L, L->top, luaS_new(L, msg)); /* push error message */ - api_incr_top(L); - luaD_throw(L, -1); /* jump back to 'lua_resume' */ -} - - -/* -** do the work for 'lua_resume' in protected mode -*/ -static void resume (lua_State *L, void *ud) { - int nCcalls = L->nCcalls; - StkId firstArg = cast(StkId, ud); - CallInfo *ci = L->ci; - if (nCcalls >= LUAI_MAXCCALLS) - resume_error(L, "C stack overflow", firstArg); - if (L->status == LUA_OK) { /* may be starting a coroutine */ - if (ci != &L->base_ci) /* not in base level? */ - resume_error(L, "cannot resume non-suspended coroutine", firstArg); - /* coroutine is in base level; start running it */ - if (!luaD_precall(L, firstArg - 1, LUA_MULTRET)) /* Lua function? */ - luaV_execute(L); /* call it */ - } - else if (L->status != LUA_YIELD) - resume_error(L, "cannot resume dead coroutine", firstArg); - else { /* resuming from previous yield */ - L->status = LUA_OK; - ci->func = restorestack(L, ci->extra); - if (isLua(ci)) /* yielded inside a hook? */ - luaV_execute(L); /* just continue running Lua code */ - else { /* 'common' yield */ - if (ci->u.c.k != NULL) { /* does it have a continuation? */ - int n; - ci->u.c.status = LUA_YIELD; /* 'default' status */ - ci->callstatus |= CIST_YIELDED; - lua_unlock(L); - n = (*ci->u.c.k)(L); /* call continuation */ - lua_lock(L); - api_checknelems(L, n); - firstArg = L->top - n; /* yield results come from continuation */ - } - luaD_poscall(L, firstArg); /* finish 'luaD_precall' */ - } - unroll(L, NULL); - } - lua_assert(nCcalls == L->nCcalls); -} - - -LUA_API int lua_resume (lua_State *L, lua_State *from, int nargs) { - int status; - int oldnny = L->nny; /* save 'nny' */ - lua_lock(L); - luai_userstateresume(L, nargs); - L->nCcalls = (from) ? from->nCcalls + 1 : 1; - L->nny = 0; /* allow yields */ - api_checknelems(L, (L->status == LUA_OK) ? nargs + 1 : nargs); - status = luaD_rawrunprotected(L, resume, L->top - nargs); - if (status == -1) /* error calling 'lua_resume'? */ - status = LUA_ERRRUN; - else { /* yield or regular error */ - while (status != LUA_OK && status != LUA_YIELD) { /* error? */ - if (recover(L, status)) /* recover point? */ - status = luaD_rawrunprotected(L, unroll, NULL); /* run continuation */ - else { /* unrecoverable error */ - L->status = cast_byte(status); /* mark thread as `dead' */ - seterrorobj(L, status, L->top); - L->ci->top = L->top; - break; - } - } - lua_assert(status == L->status); - } - L->nny = oldnny; /* restore 'nny' */ - L->nCcalls--; - lua_assert(L->nCcalls == ((from) ? from->nCcalls : 0)); - lua_unlock(L); - return status; -} - - -LUA_API int lua_yieldk (lua_State *L, int nresults, int ctx, lua_CFunction k) { - CallInfo *ci = L->ci; - luai_userstateyield(L, nresults); - lua_lock(L); - api_checknelems(L, nresults); - if (L->nny > 0) { - if (L != G(L)->mainthread) - luaG_runerror(L, "attempt to yield across a C-call boundary"); - else - luaG_runerror(L, "attempt to yield from outside a coroutine"); - } - L->status = LUA_YIELD; - ci->extra = savestack(L, ci->func); /* save current 'func' */ - if (isLua(ci)) { /* inside a hook? */ - api_check(L, k == NULL, "hooks cannot continue after yielding"); - } - else { - if ((ci->u.c.k = k) != NULL) /* is there a continuation? */ - ci->u.c.ctx = ctx; /* save context */ - ci->func = L->top - nresults - 1; /* protect stack below results */ - luaD_throw(L, LUA_YIELD); - } - lua_assert(ci->callstatus & CIST_HOOKED); /* must be inside a hook */ - lua_unlock(L); - return 0; /* return to 'luaD_hook' */ -} - - -int luaD_pcall (lua_State *L, Pfunc func, void *u, - ptrdiff_t old_top, ptrdiff_t ef) { - int status; - CallInfo *old_ci = L->ci; - lu_byte old_allowhooks = L->allowhook; - unsigned short old_nny = L->nny; - ptrdiff_t old_errfunc = L->errfunc; - L->errfunc = ef; - status = luaD_rawrunprotected(L, func, u); - if (status != LUA_OK) { /* an error occurred? */ - StkId oldtop = restorestack(L, old_top); - luaF_close(L, oldtop); /* close possible pending closures */ - seterrorobj(L, status, oldtop); - L->ci = old_ci; - L->allowhook = old_allowhooks; - L->nny = old_nny; - luaD_shrinkstack(L); - } - L->errfunc = old_errfunc; - return status; -} - - - -/* -** Execute a protected parser. -*/ -struct SParser { /* data to `f_parser' */ - ZIO *z; - Mbuffer buff; /* dynamic structure used by the scanner */ - Dyndata dyd; /* dynamic structures used by the parser */ - const char *mode; - const char *name; -}; - - -static void checkmode (lua_State *L, const char *mode, const char *x) { - if (mode && strchr(mode, x[0]) == NULL) { - luaO_pushfstring(L, - "attempt to load a %s chunk (mode is " LUA_QS ")", x, mode); - luaD_throw(L, LUA_ERRSYNTAX); - } -} - - -static void f_parser (lua_State *L, void *ud) { - int i; - Closure *cl; - struct SParser *p = cast(struct SParser *, ud); - int c = zgetc(p->z); /* read first character */ - if (c == LUA_SIGNATURE[0]) { - checkmode(L, p->mode, "binary"); - cl = luaU_undump(L, p->z, &p->buff, p->name); - } - else { - checkmode(L, p->mode, "text"); - cl = luaY_parser(L, p->z, &p->buff, &p->dyd, p->name, c); - } - lua_assert(cl->l.nupvalues == cl->l.p->sizeupvalues); - for (i = 0; i < cl->l.nupvalues; i++) { /* initialize upvalues */ - UpVal *up = luaF_newupval(L); - cl->l.upvals[i] = up; - luaC_objbarrier(L, cl, up); - } -} - - -int luaD_protectedparser (lua_State *L, ZIO *z, const char *name, - const char *mode) { - struct SParser p; - int status; - L->nny++; /* cannot yield during parsing */ - p.z = z; p.name = name; p.mode = mode; - p.dyd.actvar.arr = NULL; p.dyd.actvar.size = 0; - p.dyd.gt.arr = NULL; p.dyd.gt.size = 0; - p.dyd.label.arr = NULL; p.dyd.label.size = 0; - luaZ_initbuffer(L, &p.buff); - status = luaD_pcall(L, f_parser, &p, savestack(L, L->top), L->errfunc); - luaZ_freebuffer(L, &p.buff); - luaM_freearray(L, p.dyd.actvar.arr, p.dyd.actvar.size); - luaM_freearray(L, p.dyd.gt.arr, p.dyd.gt.size); - luaM_freearray(L, p.dyd.label.arr, p.dyd.label.size); - L->nny--; - return status; -} - - diff --git a/btgui/lua-5.2.3/src/ldo.h b/btgui/lua-5.2.3/src/ldo.h deleted file mode 100644 index d3d3082c9..000000000 --- a/btgui/lua-5.2.3/src/ldo.h +++ /dev/null @@ -1,46 +0,0 @@ -/* -** $Id: ldo.h,v 2.20.1.1 2013/04/12 18:48:47 roberto Exp $ -** Stack and Call structure of Lua -** See Copyright Notice in lua.h -*/ - -#ifndef ldo_h -#define ldo_h - - -#include "lobject.h" -#include "lstate.h" -#include "lzio.h" - - -#define luaD_checkstack(L,n) if (L->stack_last - L->top <= (n)) \ - luaD_growstack(L, n); else condmovestack(L); - - -#define incr_top(L) {L->top++; luaD_checkstack(L,0);} - -#define savestack(L,p) ((char *)(p) - (char *)L->stack) -#define restorestack(L,n) ((TValue *)((char *)L->stack + (n))) - - -/* type of protected functions, to be ran by `runprotected' */ -typedef void (*Pfunc) (lua_State *L, void *ud); - -LUAI_FUNC int luaD_protectedparser (lua_State *L, ZIO *z, const char *name, - const char *mode); -LUAI_FUNC void luaD_hook (lua_State *L, int event, int line); -LUAI_FUNC int luaD_precall (lua_State *L, StkId func, int nresults); -LUAI_FUNC void luaD_call (lua_State *L, StkId func, int nResults, - int allowyield); -LUAI_FUNC int luaD_pcall (lua_State *L, Pfunc func, void *u, - ptrdiff_t oldtop, ptrdiff_t ef); -LUAI_FUNC int luaD_poscall (lua_State *L, StkId firstResult); -LUAI_FUNC void luaD_reallocstack (lua_State *L, int newsize); -LUAI_FUNC void luaD_growstack (lua_State *L, int n); -LUAI_FUNC void luaD_shrinkstack (lua_State *L); - -LUAI_FUNC l_noret luaD_throw (lua_State *L, int errcode); -LUAI_FUNC int luaD_rawrunprotected (lua_State *L, Pfunc f, void *ud); - -#endif - diff --git a/btgui/lua-5.2.3/src/ldump.c b/btgui/lua-5.2.3/src/ldump.c deleted file mode 100644 index 61fa2cd89..000000000 --- a/btgui/lua-5.2.3/src/ldump.c +++ /dev/null @@ -1,173 +0,0 @@ -/* -** $Id: ldump.c,v 2.17.1.1 2013/04/12 18:48:47 roberto Exp $ -** save precompiled Lua chunks -** See Copyright Notice in lua.h -*/ - -#include - -#define ldump_c -#define LUA_CORE - -#include "lua.h" - -#include "lobject.h" -#include "lstate.h" -#include "lundump.h" - -typedef struct { - lua_State* L; - lua_Writer writer; - void* data; - int strip; - int status; -} DumpState; - -#define DumpMem(b,n,size,D) DumpBlock(b,(n)*(size),D) -#define DumpVar(x,D) DumpMem(&x,1,sizeof(x),D) - -static void DumpBlock(const void* b, size_t size, DumpState* D) -{ - if (D->status==0) - { - lua_unlock(D->L); - D->status=(*D->writer)(D->L,b,size,D->data); - lua_lock(D->L); - } -} - -static void DumpChar(int y, DumpState* D) -{ - char x=(char)y; - DumpVar(x,D); -} - -static void DumpInt(int x, DumpState* D) -{ - DumpVar(x,D); -} - -static void DumpNumber(lua_Number x, DumpState* D) -{ - DumpVar(x,D); -} - -static void DumpVector(const void* b, int n, size_t size, DumpState* D) -{ - DumpInt(n,D); - DumpMem(b,n,size,D); -} - -static void DumpString(const TString* s, DumpState* D) -{ - if (s==NULL) - { - size_t size=0; - DumpVar(size,D); - } - else - { - size_t size=s->tsv.len+1; /* include trailing '\0' */ - DumpVar(size,D); - DumpBlock(getstr(s),size*sizeof(char),D); - } -} - -#define DumpCode(f,D) DumpVector(f->code,f->sizecode,sizeof(Instruction),D) - -static void DumpFunction(const Proto* f, DumpState* D); - -static void DumpConstants(const Proto* f, DumpState* D) -{ - int i,n=f->sizek; - DumpInt(n,D); - for (i=0; ik[i]; - DumpChar(ttypenv(o),D); - switch (ttypenv(o)) - { - case LUA_TNIL: - break; - case LUA_TBOOLEAN: - DumpChar(bvalue(o),D); - break; - case LUA_TNUMBER: - DumpNumber(nvalue(o),D); - break; - case LUA_TSTRING: - DumpString(rawtsvalue(o),D); - break; - default: lua_assert(0); - } - } - n=f->sizep; - DumpInt(n,D); - for (i=0; ip[i],D); -} - -static void DumpUpvalues(const Proto* f, DumpState* D) -{ - int i,n=f->sizeupvalues; - DumpInt(n,D); - for (i=0; iupvalues[i].instack,D); - DumpChar(f->upvalues[i].idx,D); - } -} - -static void DumpDebug(const Proto* f, DumpState* D) -{ - int i,n; - DumpString((D->strip) ? NULL : f->source,D); - n= (D->strip) ? 0 : f->sizelineinfo; - DumpVector(f->lineinfo,n,sizeof(int),D); - n= (D->strip) ? 0 : f->sizelocvars; - DumpInt(n,D); - for (i=0; ilocvars[i].varname,D); - DumpInt(f->locvars[i].startpc,D); - DumpInt(f->locvars[i].endpc,D); - } - n= (D->strip) ? 0 : f->sizeupvalues; - DumpInt(n,D); - for (i=0; iupvalues[i].name,D); -} - -static void DumpFunction(const Proto* f, DumpState* D) -{ - DumpInt(f->linedefined,D); - DumpInt(f->lastlinedefined,D); - DumpChar(f->numparams,D); - DumpChar(f->is_vararg,D); - DumpChar(f->maxstacksize,D); - DumpCode(f,D); - DumpConstants(f,D); - DumpUpvalues(f,D); - DumpDebug(f,D); -} - -static void DumpHeader(DumpState* D) -{ - lu_byte h[LUAC_HEADERSIZE]; - luaU_header(h); - DumpBlock(h,LUAC_HEADERSIZE,D); -} - -/* -** dump Lua function as precompiled chunk -*/ -int luaU_dump (lua_State* L, const Proto* f, lua_Writer w, void* data, int strip) -{ - DumpState D; - D.L=L; - D.writer=w; - D.data=data; - D.strip=strip; - D.status=0; - DumpHeader(&D); - DumpFunction(f,&D); - return D.status; -} diff --git a/btgui/lua-5.2.3/src/lfunc.c b/btgui/lua-5.2.3/src/lfunc.c deleted file mode 100644 index e90e1520c..000000000 --- a/btgui/lua-5.2.3/src/lfunc.c +++ /dev/null @@ -1,161 +0,0 @@ -/* -** $Id: lfunc.c,v 2.30.1.1 2013/04/12 18:48:47 roberto Exp $ -** Auxiliary functions to manipulate prototypes and closures -** See Copyright Notice in lua.h -*/ - - -#include - -#define lfunc_c -#define LUA_CORE - -#include "lua.h" - -#include "lfunc.h" -#include "lgc.h" -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" - - - -Closure *luaF_newCclosure (lua_State *L, int n) { - Closure *c = &luaC_newobj(L, LUA_TCCL, sizeCclosure(n), NULL, 0)->cl; - c->c.nupvalues = cast_byte(n); - return c; -} - - -Closure *luaF_newLclosure (lua_State *L, int n) { - Closure *c = &luaC_newobj(L, LUA_TLCL, sizeLclosure(n), NULL, 0)->cl; - c->l.p = NULL; - c->l.nupvalues = cast_byte(n); - while (n--) c->l.upvals[n] = NULL; - return c; -} - - -UpVal *luaF_newupval (lua_State *L) { - UpVal *uv = &luaC_newobj(L, LUA_TUPVAL, sizeof(UpVal), NULL, 0)->uv; - uv->v = &uv->u.value; - setnilvalue(uv->v); - return uv; -} - - -UpVal *luaF_findupval (lua_State *L, StkId level) { - global_State *g = G(L); - GCObject **pp = &L->openupval; - UpVal *p; - UpVal *uv; - while (*pp != NULL && (p = gco2uv(*pp))->v >= level) { - GCObject *o = obj2gco(p); - lua_assert(p->v != &p->u.value); - lua_assert(!isold(o) || isold(obj2gco(L))); - if (p->v == level) { /* found a corresponding upvalue? */ - if (isdead(g, o)) /* is it dead? */ - changewhite(o); /* resurrect it */ - return p; - } - pp = &p->next; - } - /* not found: create a new one */ - uv = &luaC_newobj(L, LUA_TUPVAL, sizeof(UpVal), pp, 0)->uv; - uv->v = level; /* current value lives in the stack */ - uv->u.l.prev = &g->uvhead; /* double link it in `uvhead' list */ - uv->u.l.next = g->uvhead.u.l.next; - uv->u.l.next->u.l.prev = uv; - g->uvhead.u.l.next = uv; - lua_assert(uv->u.l.next->u.l.prev == uv && uv->u.l.prev->u.l.next == uv); - return uv; -} - - -static void unlinkupval (UpVal *uv) { - lua_assert(uv->u.l.next->u.l.prev == uv && uv->u.l.prev->u.l.next == uv); - uv->u.l.next->u.l.prev = uv->u.l.prev; /* remove from `uvhead' list */ - uv->u.l.prev->u.l.next = uv->u.l.next; -} - - -void luaF_freeupval (lua_State *L, UpVal *uv) { - if (uv->v != &uv->u.value) /* is it open? */ - unlinkupval(uv); /* remove from open list */ - luaM_free(L, uv); /* free upvalue */ -} - - -void luaF_close (lua_State *L, StkId level) { - UpVal *uv; - global_State *g = G(L); - while (L->openupval != NULL && (uv = gco2uv(L->openupval))->v >= level) { - GCObject *o = obj2gco(uv); - lua_assert(!isblack(o) && uv->v != &uv->u.value); - L->openupval = uv->next; /* remove from `open' list */ - if (isdead(g, o)) - luaF_freeupval(L, uv); /* free upvalue */ - else { - unlinkupval(uv); /* remove upvalue from 'uvhead' list */ - setobj(L, &uv->u.value, uv->v); /* move value to upvalue slot */ - uv->v = &uv->u.value; /* now current value lives here */ - gch(o)->next = g->allgc; /* link upvalue into 'allgc' list */ - g->allgc = o; - luaC_checkupvalcolor(g, uv); - } - } -} - - -Proto *luaF_newproto (lua_State *L) { - Proto *f = &luaC_newobj(L, LUA_TPROTO, sizeof(Proto), NULL, 0)->p; - f->k = NULL; - f->sizek = 0; - f->p = NULL; - f->sizep = 0; - f->code = NULL; - f->cache = NULL; - f->sizecode = 0; - f->lineinfo = NULL; - f->sizelineinfo = 0; - f->upvalues = NULL; - f->sizeupvalues = 0; - f->numparams = 0; - f->is_vararg = 0; - f->maxstacksize = 0; - f->locvars = NULL; - f->sizelocvars = 0; - f->linedefined = 0; - f->lastlinedefined = 0; - f->source = NULL; - return f; -} - - -void luaF_freeproto (lua_State *L, Proto *f) { - luaM_freearray(L, f->code, f->sizecode); - luaM_freearray(L, f->p, f->sizep); - luaM_freearray(L, f->k, f->sizek); - luaM_freearray(L, f->lineinfo, f->sizelineinfo); - luaM_freearray(L, f->locvars, f->sizelocvars); - luaM_freearray(L, f->upvalues, f->sizeupvalues); - luaM_free(L, f); -} - - -/* -** Look for n-th local variable at line `line' in function `func'. -** Returns NULL if not found. -*/ -const char *luaF_getlocalname (const Proto *f, int local_number, int pc) { - int i; - for (i = 0; isizelocvars && f->locvars[i].startpc <= pc; i++) { - if (pc < f->locvars[i].endpc) { /* is variable active? */ - local_number--; - if (local_number == 0) - return getstr(f->locvars[i].varname); - } - } - return NULL; /* not found */ -} - diff --git a/btgui/lua-5.2.3/src/lfunc.h b/btgui/lua-5.2.3/src/lfunc.h deleted file mode 100644 index ca0d3a3e0..000000000 --- a/btgui/lua-5.2.3/src/lfunc.h +++ /dev/null @@ -1,33 +0,0 @@ -/* -** $Id: lfunc.h,v 2.8.1.1 2013/04/12 18:48:47 roberto Exp $ -** Auxiliary functions to manipulate prototypes and closures -** See Copyright Notice in lua.h -*/ - -#ifndef lfunc_h -#define lfunc_h - - -#include "lobject.h" - - -#define sizeCclosure(n) (cast(int, sizeof(CClosure)) + \ - cast(int, sizeof(TValue)*((n)-1))) - -#define sizeLclosure(n) (cast(int, sizeof(LClosure)) + \ - cast(int, sizeof(TValue *)*((n)-1))) - - -LUAI_FUNC Proto *luaF_newproto (lua_State *L); -LUAI_FUNC Closure *luaF_newCclosure (lua_State *L, int nelems); -LUAI_FUNC Closure *luaF_newLclosure (lua_State *L, int nelems); -LUAI_FUNC UpVal *luaF_newupval (lua_State *L); -LUAI_FUNC UpVal *luaF_findupval (lua_State *L, StkId level); -LUAI_FUNC void luaF_close (lua_State *L, StkId level); -LUAI_FUNC void luaF_freeproto (lua_State *L, Proto *f); -LUAI_FUNC void luaF_freeupval (lua_State *L, UpVal *uv); -LUAI_FUNC const char *luaF_getlocalname (const Proto *func, int local_number, - int pc); - - -#endif diff --git a/btgui/lua-5.2.3/src/lgc.c b/btgui/lua-5.2.3/src/lgc.c deleted file mode 100644 index 52460dcdd..000000000 --- a/btgui/lua-5.2.3/src/lgc.c +++ /dev/null @@ -1,1220 +0,0 @@ -/* -** $Id: lgc.c,v 2.140.1.2 2013/04/26 18:22:05 roberto Exp $ -** Garbage Collector -** See Copyright Notice in lua.h -*/ - -#include - -#define lgc_c -#define LUA_CORE - -#include "lua.h" - -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lgc.h" -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" - - - -/* -** cost of sweeping one element (the size of a small object divided -** by some adjust for the sweep speed) -*/ -#define GCSWEEPCOST ((sizeof(TString) + 4) / 4) - -/* maximum number of elements to sweep in each single step */ -#define GCSWEEPMAX (cast_int((GCSTEPSIZE / GCSWEEPCOST) / 4)) - -/* maximum number of finalizers to call in each GC step */ -#define GCFINALIZENUM 4 - - -/* -** macro to adjust 'stepmul': 'stepmul' is actually used like -** 'stepmul / STEPMULADJ' (value chosen by tests) -*/ -#define STEPMULADJ 200 - - -/* -** macro to adjust 'pause': 'pause' is actually used like -** 'pause / PAUSEADJ' (value chosen by tests) -*/ -#define PAUSEADJ 100 - - -/* -** 'makewhite' erases all color bits plus the old bit and then -** sets only the current white bit -*/ -#define maskcolors (~(bit2mask(BLACKBIT, OLDBIT) | WHITEBITS)) -#define makewhite(g,x) \ - (gch(x)->marked = cast_byte((gch(x)->marked & maskcolors) | luaC_white(g))) - -#define white2gray(x) resetbits(gch(x)->marked, WHITEBITS) -#define black2gray(x) resetbit(gch(x)->marked, BLACKBIT) - - -#define isfinalized(x) testbit(gch(x)->marked, FINALIZEDBIT) - -#define checkdeadkey(n) lua_assert(!ttisdeadkey(gkey(n)) || ttisnil(gval(n))) - - -#define checkconsistency(obj) \ - lua_longassert(!iscollectable(obj) || righttt(obj)) - - -#define markvalue(g,o) { checkconsistency(o); \ - if (valiswhite(o)) reallymarkobject(g,gcvalue(o)); } - -#define markobject(g,t) { if ((t) && iswhite(obj2gco(t))) \ - reallymarkobject(g, obj2gco(t)); } - -static void reallymarkobject (global_State *g, GCObject *o); - - -/* -** {====================================================== -** Generic functions -** ======================================================= -*/ - - -/* -** one after last element in a hash array -*/ -#define gnodelast(h) gnode(h, cast(size_t, sizenode(h))) - - -/* -** link table 'h' into list pointed by 'p' -*/ -#define linktable(h,p) ((h)->gclist = *(p), *(p) = obj2gco(h)) - - -/* -** if key is not marked, mark its entry as dead (therefore removing it -** from the table) -*/ -static void removeentry (Node *n) { - lua_assert(ttisnil(gval(n))); - if (valiswhite(gkey(n))) - setdeadvalue(gkey(n)); /* unused and unmarked key; remove it */ -} - - -/* -** tells whether a key or value can be cleared from a weak -** table. Non-collectable objects are never removed from weak -** tables. Strings behave as `values', so are never removed too. for -** other objects: if really collected, cannot keep them; for objects -** being finalized, keep them in keys, but not in values -*/ -static int iscleared (global_State *g, const TValue *o) { - if (!iscollectable(o)) return 0; - else if (ttisstring(o)) { - markobject(g, rawtsvalue(o)); /* strings are `values', so are never weak */ - return 0; - } - else return iswhite(gcvalue(o)); -} - - -/* -** barrier that moves collector forward, that is, mark the white object -** being pointed by a black object. -*/ -void luaC_barrier_ (lua_State *L, GCObject *o, GCObject *v) { - global_State *g = G(L); - lua_assert(isblack(o) && iswhite(v) && !isdead(g, v) && !isdead(g, o)); - lua_assert(g->gcstate != GCSpause); - lua_assert(gch(o)->tt != LUA_TTABLE); - if (keepinvariantout(g)) /* must keep invariant? */ - reallymarkobject(g, v); /* restore invariant */ - else { /* sweep phase */ - lua_assert(issweepphase(g)); - makewhite(g, o); /* mark main obj. as white to avoid other barriers */ - } -} - - -/* -** barrier that moves collector backward, that is, mark the black object -** pointing to a white object as gray again. (Current implementation -** only works for tables; access to 'gclist' is not uniform across -** different types.) -*/ -void luaC_barrierback_ (lua_State *L, GCObject *o) { - global_State *g = G(L); - lua_assert(isblack(o) && !isdead(g, o) && gch(o)->tt == LUA_TTABLE); - black2gray(o); /* make object gray (again) */ - gco2t(o)->gclist = g->grayagain; - g->grayagain = o; -} - - -/* -** barrier for prototypes. When creating first closure (cache is -** NULL), use a forward barrier; this may be the only closure of the -** prototype (if it is a "regular" function, with a single instance) -** and the prototype may be big, so it is better to avoid traversing -** it again. Otherwise, use a backward barrier, to avoid marking all -** possible instances. -*/ -LUAI_FUNC void luaC_barrierproto_ (lua_State *L, Proto *p, Closure *c) { - global_State *g = G(L); - lua_assert(isblack(obj2gco(p))); - if (p->cache == NULL) { /* first time? */ - luaC_objbarrier(L, p, c); - } - else { /* use a backward barrier */ - black2gray(obj2gco(p)); /* make prototype gray (again) */ - p->gclist = g->grayagain; - g->grayagain = obj2gco(p); - } -} - - -/* -** check color (and invariants) for an upvalue that was closed, -** i.e., moved into the 'allgc' list -*/ -void luaC_checkupvalcolor (global_State *g, UpVal *uv) { - GCObject *o = obj2gco(uv); - lua_assert(!isblack(o)); /* open upvalues are never black */ - if (isgray(o)) { - if (keepinvariant(g)) { - resetoldbit(o); /* see MOVE OLD rule */ - gray2black(o); /* it is being visited now */ - markvalue(g, uv->v); - } - else { - lua_assert(issweepphase(g)); - makewhite(g, o); - } - } -} - - -/* -** create a new collectable object (with given type and size) and link -** it to '*list'. 'offset' tells how many bytes to allocate before the -** object itself (used only by states). -*/ -GCObject *luaC_newobj (lua_State *L, int tt, size_t sz, GCObject **list, - int offset) { - global_State *g = G(L); - char *raw = cast(char *, luaM_newobject(L, novariant(tt), sz)); - GCObject *o = obj2gco(raw + offset); - if (list == NULL) - list = &g->allgc; /* standard list for collectable objects */ - gch(o)->marked = luaC_white(g); - gch(o)->tt = tt; - gch(o)->next = *list; - *list = o; - return o; -} - -/* }====================================================== */ - - - -/* -** {====================================================== -** Mark functions -** ======================================================= -*/ - - -/* -** mark an object. Userdata, strings, and closed upvalues are visited -** and turned black here. Other objects are marked gray and added -** to appropriate list to be visited (and turned black) later. (Open -** upvalues are already linked in 'headuv' list.) -*/ -static void reallymarkobject (global_State *g, GCObject *o) { - lu_mem size; - white2gray(o); - switch (gch(o)->tt) { - case LUA_TSHRSTR: - case LUA_TLNGSTR: { - size = sizestring(gco2ts(o)); - break; /* nothing else to mark; make it black */ - } - case LUA_TUSERDATA: { - Table *mt = gco2u(o)->metatable; - markobject(g, mt); - markobject(g, gco2u(o)->env); - size = sizeudata(gco2u(o)); - break; - } - case LUA_TUPVAL: { - UpVal *uv = gco2uv(o); - markvalue(g, uv->v); - if (uv->v != &uv->u.value) /* open? */ - return; /* open upvalues remain gray */ - size = sizeof(UpVal); - break; - } - case LUA_TLCL: { - gco2lcl(o)->gclist = g->gray; - g->gray = o; - return; - } - case LUA_TCCL: { - gco2ccl(o)->gclist = g->gray; - g->gray = o; - return; - } - case LUA_TTABLE: { - linktable(gco2t(o), &g->gray); - return; - } - case LUA_TTHREAD: { - gco2th(o)->gclist = g->gray; - g->gray = o; - return; - } - case LUA_TPROTO: { - gco2p(o)->gclist = g->gray; - g->gray = o; - return; - } - default: lua_assert(0); return; - } - gray2black(o); - g->GCmemtrav += size; -} - - -/* -** mark metamethods for basic types -*/ -static void markmt (global_State *g) { - int i; - for (i=0; i < LUA_NUMTAGS; i++) - markobject(g, g->mt[i]); -} - - -/* -** mark all objects in list of being-finalized -*/ -static void markbeingfnz (global_State *g) { - GCObject *o; - for (o = g->tobefnz; o != NULL; o = gch(o)->next) { - makewhite(g, o); - reallymarkobject(g, o); - } -} - - -/* -** mark all values stored in marked open upvalues. (See comment in -** 'lstate.h'.) -*/ -static void remarkupvals (global_State *g) { - UpVal *uv; - for (uv = g->uvhead.u.l.next; uv != &g->uvhead; uv = uv->u.l.next) { - if (isgray(obj2gco(uv))) - markvalue(g, uv->v); - } -} - - -/* -** mark root set and reset all gray lists, to start a new -** incremental (or full) collection -*/ -static void restartcollection (global_State *g) { - g->gray = g->grayagain = NULL; - g->weak = g->allweak = g->ephemeron = NULL; - markobject(g, g->mainthread); - markvalue(g, &g->l_registry); - markmt(g); - markbeingfnz(g); /* mark any finalizing object left from previous cycle */ -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Traverse functions -** ======================================================= -*/ - -static void traverseweakvalue (global_State *g, Table *h) { - Node *n, *limit = gnodelast(h); - /* if there is array part, assume it may have white values (do not - traverse it just to check) */ - int hasclears = (h->sizearray > 0); - for (n = gnode(h, 0); n < limit; n++) { - checkdeadkey(n); - if (ttisnil(gval(n))) /* entry is empty? */ - removeentry(n); /* remove it */ - else { - lua_assert(!ttisnil(gkey(n))); - markvalue(g, gkey(n)); /* mark key */ - if (!hasclears && iscleared(g, gval(n))) /* is there a white value? */ - hasclears = 1; /* table will have to be cleared */ - } - } - if (hasclears) - linktable(h, &g->weak); /* has to be cleared later */ - else /* no white values */ - linktable(h, &g->grayagain); /* no need to clean */ -} - - -static int traverseephemeron (global_State *g, Table *h) { - int marked = 0; /* true if an object is marked in this traversal */ - int hasclears = 0; /* true if table has white keys */ - int prop = 0; /* true if table has entry "white-key -> white-value" */ - Node *n, *limit = gnodelast(h); - int i; - /* traverse array part (numeric keys are 'strong') */ - for (i = 0; i < h->sizearray; i++) { - if (valiswhite(&h->array[i])) { - marked = 1; - reallymarkobject(g, gcvalue(&h->array[i])); - } - } - /* traverse hash part */ - for (n = gnode(h, 0); n < limit; n++) { - checkdeadkey(n); - if (ttisnil(gval(n))) /* entry is empty? */ - removeentry(n); /* remove it */ - else if (iscleared(g, gkey(n))) { /* key is not marked (yet)? */ - hasclears = 1; /* table must be cleared */ - if (valiswhite(gval(n))) /* value not marked yet? */ - prop = 1; /* must propagate again */ - } - else if (valiswhite(gval(n))) { /* value not marked yet? */ - marked = 1; - reallymarkobject(g, gcvalue(gval(n))); /* mark it now */ - } - } - if (prop) - linktable(h, &g->ephemeron); /* have to propagate again */ - else if (hasclears) /* does table have white keys? */ - linktable(h, &g->allweak); /* may have to clean white keys */ - else /* no white keys */ - linktable(h, &g->grayagain); /* no need to clean */ - return marked; -} - - -static void traversestrongtable (global_State *g, Table *h) { - Node *n, *limit = gnodelast(h); - int i; - for (i = 0; i < h->sizearray; i++) /* traverse array part */ - markvalue(g, &h->array[i]); - for (n = gnode(h, 0); n < limit; n++) { /* traverse hash part */ - checkdeadkey(n); - if (ttisnil(gval(n))) /* entry is empty? */ - removeentry(n); /* remove it */ - else { - lua_assert(!ttisnil(gkey(n))); - markvalue(g, gkey(n)); /* mark key */ - markvalue(g, gval(n)); /* mark value */ - } - } -} - - -static lu_mem traversetable (global_State *g, Table *h) { - const char *weakkey, *weakvalue; - const TValue *mode = gfasttm(g, h->metatable, TM_MODE); - markobject(g, h->metatable); - if (mode && ttisstring(mode) && /* is there a weak mode? */ - ((weakkey = strchr(svalue(mode), 'k')), - (weakvalue = strchr(svalue(mode), 'v')), - (weakkey || weakvalue))) { /* is really weak? */ - black2gray(obj2gco(h)); /* keep table gray */ - if (!weakkey) /* strong keys? */ - traverseweakvalue(g, h); - else if (!weakvalue) /* strong values? */ - traverseephemeron(g, h); - else /* all weak */ - linktable(h, &g->allweak); /* nothing to traverse now */ - } - else /* not weak */ - traversestrongtable(g, h); - return sizeof(Table) + sizeof(TValue) * h->sizearray + - sizeof(Node) * cast(size_t, sizenode(h)); -} - - -static int traverseproto (global_State *g, Proto *f) { - int i; - if (f->cache && iswhite(obj2gco(f->cache))) - f->cache = NULL; /* allow cache to be collected */ - markobject(g, f->source); - for (i = 0; i < f->sizek; i++) /* mark literals */ - markvalue(g, &f->k[i]); - for (i = 0; i < f->sizeupvalues; i++) /* mark upvalue names */ - markobject(g, f->upvalues[i].name); - for (i = 0; i < f->sizep; i++) /* mark nested protos */ - markobject(g, f->p[i]); - for (i = 0; i < f->sizelocvars; i++) /* mark local-variable names */ - markobject(g, f->locvars[i].varname); - return sizeof(Proto) + sizeof(Instruction) * f->sizecode + - sizeof(Proto *) * f->sizep + - sizeof(TValue) * f->sizek + - sizeof(int) * f->sizelineinfo + - sizeof(LocVar) * f->sizelocvars + - sizeof(Upvaldesc) * f->sizeupvalues; -} - - -static lu_mem traverseCclosure (global_State *g, CClosure *cl) { - int i; - for (i = 0; i < cl->nupvalues; i++) /* mark its upvalues */ - markvalue(g, &cl->upvalue[i]); - return sizeCclosure(cl->nupvalues); -} - -static lu_mem traverseLclosure (global_State *g, LClosure *cl) { - int i; - markobject(g, cl->p); /* mark its prototype */ - for (i = 0; i < cl->nupvalues; i++) /* mark its upvalues */ - markobject(g, cl->upvals[i]); - return sizeLclosure(cl->nupvalues); -} - - -static lu_mem traversestack (global_State *g, lua_State *th) { - int n = 0; - StkId o = th->stack; - if (o == NULL) - return 1; /* stack not completely built yet */ - for (; o < th->top; o++) /* mark live elements in the stack */ - markvalue(g, o); - if (g->gcstate == GCSatomic) { /* final traversal? */ - StkId lim = th->stack + th->stacksize; /* real end of stack */ - for (; o < lim; o++) /* clear not-marked stack slice */ - setnilvalue(o); - } - else { /* count call infos to compute size */ - CallInfo *ci; - for (ci = &th->base_ci; ci != th->ci; ci = ci->next) - n++; - } - return sizeof(lua_State) + sizeof(TValue) * th->stacksize + - sizeof(CallInfo) * n; -} - - -/* -** traverse one gray object, turning it to black (except for threads, -** which are always gray). -*/ -static void propagatemark (global_State *g) { - lu_mem size; - GCObject *o = g->gray; - lua_assert(isgray(o)); - gray2black(o); - switch (gch(o)->tt) { - case LUA_TTABLE: { - Table *h = gco2t(o); - g->gray = h->gclist; /* remove from 'gray' list */ - size = traversetable(g, h); - break; - } - case LUA_TLCL: { - LClosure *cl = gco2lcl(o); - g->gray = cl->gclist; /* remove from 'gray' list */ - size = traverseLclosure(g, cl); - break; - } - case LUA_TCCL: { - CClosure *cl = gco2ccl(o); - g->gray = cl->gclist; /* remove from 'gray' list */ - size = traverseCclosure(g, cl); - break; - } - case LUA_TTHREAD: { - lua_State *th = gco2th(o); - g->gray = th->gclist; /* remove from 'gray' list */ - th->gclist = g->grayagain; - g->grayagain = o; /* insert into 'grayagain' list */ - black2gray(o); - size = traversestack(g, th); - break; - } - case LUA_TPROTO: { - Proto *p = gco2p(o); - g->gray = p->gclist; /* remove from 'gray' list */ - size = traverseproto(g, p); - break; - } - default: lua_assert(0); return; - } - g->GCmemtrav += size; -} - - -static void propagateall (global_State *g) { - while (g->gray) propagatemark(g); -} - - -static void propagatelist (global_State *g, GCObject *l) { - lua_assert(g->gray == NULL); /* no grays left */ - g->gray = l; - propagateall(g); /* traverse all elements from 'l' */ -} - -/* -** retraverse all gray lists. Because tables may be reinserted in other -** lists when traversed, traverse the original lists to avoid traversing -** twice the same table (which is not wrong, but inefficient) -*/ -static void retraversegrays (global_State *g) { - GCObject *weak = g->weak; /* save original lists */ - GCObject *grayagain = g->grayagain; - GCObject *ephemeron = g->ephemeron; - g->weak = g->grayagain = g->ephemeron = NULL; - propagateall(g); /* traverse main gray list */ - propagatelist(g, grayagain); - propagatelist(g, weak); - propagatelist(g, ephemeron); -} - - -static void convergeephemerons (global_State *g) { - int changed; - do { - GCObject *w; - GCObject *next = g->ephemeron; /* get ephemeron list */ - g->ephemeron = NULL; /* tables will return to this list when traversed */ - changed = 0; - while ((w = next) != NULL) { - next = gco2t(w)->gclist; - if (traverseephemeron(g, gco2t(w))) { /* traverse marked some value? */ - propagateall(g); /* propagate changes */ - changed = 1; /* will have to revisit all ephemeron tables */ - } - } - } while (changed); -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Sweep Functions -** ======================================================= -*/ - - -/* -** clear entries with unmarked keys from all weaktables in list 'l' up -** to element 'f' -*/ -static void clearkeys (global_State *g, GCObject *l, GCObject *f) { - for (; l != f; l = gco2t(l)->gclist) { - Table *h = gco2t(l); - Node *n, *limit = gnodelast(h); - for (n = gnode(h, 0); n < limit; n++) { - if (!ttisnil(gval(n)) && (iscleared(g, gkey(n)))) { - setnilvalue(gval(n)); /* remove value ... */ - removeentry(n); /* and remove entry from table */ - } - } - } -} - - -/* -** clear entries with unmarked values from all weaktables in list 'l' up -** to element 'f' -*/ -static void clearvalues (global_State *g, GCObject *l, GCObject *f) { - for (; l != f; l = gco2t(l)->gclist) { - Table *h = gco2t(l); - Node *n, *limit = gnodelast(h); - int i; - for (i = 0; i < h->sizearray; i++) { - TValue *o = &h->array[i]; - if (iscleared(g, o)) /* value was collected? */ - setnilvalue(o); /* remove value */ - } - for (n = gnode(h, 0); n < limit; n++) { - if (!ttisnil(gval(n)) && iscleared(g, gval(n))) { - setnilvalue(gval(n)); /* remove value ... */ - removeentry(n); /* and remove entry from table */ - } - } - } -} - - -static void freeobj (lua_State *L, GCObject *o) { - switch (gch(o)->tt) { - case LUA_TPROTO: luaF_freeproto(L, gco2p(o)); break; - case LUA_TLCL: { - luaM_freemem(L, o, sizeLclosure(gco2lcl(o)->nupvalues)); - break; - } - case LUA_TCCL: { - luaM_freemem(L, o, sizeCclosure(gco2ccl(o)->nupvalues)); - break; - } - case LUA_TUPVAL: luaF_freeupval(L, gco2uv(o)); break; - case LUA_TTABLE: luaH_free(L, gco2t(o)); break; - case LUA_TTHREAD: luaE_freethread(L, gco2th(o)); break; - case LUA_TUSERDATA: luaM_freemem(L, o, sizeudata(gco2u(o))); break; - case LUA_TSHRSTR: - G(L)->strt.nuse--; - /* go through */ - case LUA_TLNGSTR: { - luaM_freemem(L, o, sizestring(gco2ts(o))); - break; - } - default: lua_assert(0); - } -} - - -#define sweepwholelist(L,p) sweeplist(L,p,MAX_LUMEM) -static GCObject **sweeplist (lua_State *L, GCObject **p, lu_mem count); - - -/* -** sweep the (open) upvalues of a thread and resize its stack and -** list of call-info structures. -*/ -static void sweepthread (lua_State *L, lua_State *L1) { - if (L1->stack == NULL) return; /* stack not completely built yet */ - sweepwholelist(L, &L1->openupval); /* sweep open upvalues */ - luaE_freeCI(L1); /* free extra CallInfo slots */ - /* should not change the stack during an emergency gc cycle */ - if (G(L)->gckind != KGC_EMERGENCY) - luaD_shrinkstack(L1); -} - - -/* -** sweep at most 'count' elements from a list of GCObjects erasing dead -** objects, where a dead (not alive) object is one marked with the "old" -** (non current) white and not fixed. -** In non-generational mode, change all non-dead objects back to white, -** preparing for next collection cycle. -** In generational mode, keep black objects black, and also mark them as -** old; stop when hitting an old object, as all objects after that -** one will be old too. -** When object is a thread, sweep its list of open upvalues too. -*/ -static GCObject **sweeplist (lua_State *L, GCObject **p, lu_mem count) { - global_State *g = G(L); - int ow = otherwhite(g); - int toclear, toset; /* bits to clear and to set in all live objects */ - int tostop; /* stop sweep when this is true */ - if (isgenerational(g)) { /* generational mode? */ - toclear = ~0; /* clear nothing */ - toset = bitmask(OLDBIT); /* set the old bit of all surviving objects */ - tostop = bitmask(OLDBIT); /* do not sweep old generation */ - } - else { /* normal mode */ - toclear = maskcolors; /* clear all color bits + old bit */ - toset = luaC_white(g); /* make object white */ - tostop = 0; /* do not stop */ - } - while (*p != NULL && count-- > 0) { - GCObject *curr = *p; - int marked = gch(curr)->marked; - if (isdeadm(ow, marked)) { /* is 'curr' dead? */ - *p = gch(curr)->next; /* remove 'curr' from list */ - freeobj(L, curr); /* erase 'curr' */ - } - else { - if (testbits(marked, tostop)) - return NULL; /* stop sweeping this list */ - if (gch(curr)->tt == LUA_TTHREAD) - sweepthread(L, gco2th(curr)); /* sweep thread's upvalues */ - /* update marks */ - gch(curr)->marked = cast_byte((marked & toclear) | toset); - p = &gch(curr)->next; /* go to next element */ - } - } - return (*p == NULL) ? NULL : p; -} - - -/* -** sweep a list until a live object (or end of list) -*/ -static GCObject **sweeptolive (lua_State *L, GCObject **p, int *n) { - GCObject ** old = p; - int i = 0; - do { - i++; - p = sweeplist(L, p, 1); - } while (p == old); - if (n) *n += i; - return p; -} - -/* }====================================================== */ - - -/* -** {====================================================== -** Finalization -** ======================================================= -*/ - -static void checkSizes (lua_State *L) { - global_State *g = G(L); - if (g->gckind != KGC_EMERGENCY) { /* do not change sizes in emergency */ - int hs = g->strt.size / 2; /* half the size of the string table */ - if (g->strt.nuse < cast(lu_int32, hs)) /* using less than that half? */ - luaS_resize(L, hs); /* halve its size */ - luaZ_freebuffer(L, &g->buff); /* free concatenation buffer */ - } -} - - -static GCObject *udata2finalize (global_State *g) { - GCObject *o = g->tobefnz; /* get first element */ - lua_assert(isfinalized(o)); - g->tobefnz = gch(o)->next; /* remove it from 'tobefnz' list */ - gch(o)->next = g->allgc; /* return it to 'allgc' list */ - g->allgc = o; - resetbit(gch(o)->marked, SEPARATED); /* mark that it is not in 'tobefnz' */ - lua_assert(!isold(o)); /* see MOVE OLD rule */ - if (!keepinvariantout(g)) /* not keeping invariant? */ - makewhite(g, o); /* "sweep" object */ - return o; -} - - -static void dothecall (lua_State *L, void *ud) { - UNUSED(ud); - luaD_call(L, L->top - 2, 0, 0); -} - - -static void GCTM (lua_State *L, int propagateerrors) { - global_State *g = G(L); - const TValue *tm; - TValue v; - setgcovalue(L, &v, udata2finalize(g)); - tm = luaT_gettmbyobj(L, &v, TM_GC); - if (tm != NULL && ttisfunction(tm)) { /* is there a finalizer? */ - int status; - lu_byte oldah = L->allowhook; - int running = g->gcrunning; - L->allowhook = 0; /* stop debug hooks during GC metamethod */ - g->gcrunning = 0; /* avoid GC steps */ - setobj2s(L, L->top, tm); /* push finalizer... */ - setobj2s(L, L->top + 1, &v); /* ... and its argument */ - L->top += 2; /* and (next line) call the finalizer */ - status = luaD_pcall(L, dothecall, NULL, savestack(L, L->top - 2), 0); - L->allowhook = oldah; /* restore hooks */ - g->gcrunning = running; /* restore state */ - if (status != LUA_OK && propagateerrors) { /* error while running __gc? */ - if (status == LUA_ERRRUN) { /* is there an error object? */ - const char *msg = (ttisstring(L->top - 1)) - ? svalue(L->top - 1) - : "no message"; - luaO_pushfstring(L, "error in __gc metamethod (%s)", msg); - status = LUA_ERRGCMM; /* error in __gc metamethod */ - } - luaD_throw(L, status); /* re-throw error */ - } - } -} - - -/* -** move all unreachable objects (or 'all' objects) that need -** finalization from list 'finobj' to list 'tobefnz' (to be finalized) -*/ -static void separatetobefnz (lua_State *L, int all) { - global_State *g = G(L); - GCObject **p = &g->finobj; - GCObject *curr; - GCObject **lastnext = &g->tobefnz; - /* find last 'next' field in 'tobefnz' list (to add elements in its end) */ - while (*lastnext != NULL) - lastnext = &gch(*lastnext)->next; - while ((curr = *p) != NULL) { /* traverse all finalizable objects */ - lua_assert(!isfinalized(curr)); - lua_assert(testbit(gch(curr)->marked, SEPARATED)); - if (!(iswhite(curr) || all)) /* not being collected? */ - p = &gch(curr)->next; /* don't bother with it */ - else { - l_setbit(gch(curr)->marked, FINALIZEDBIT); /* won't be finalized again */ - *p = gch(curr)->next; /* remove 'curr' from 'finobj' list */ - gch(curr)->next = *lastnext; /* link at the end of 'tobefnz' list */ - *lastnext = curr; - lastnext = &gch(curr)->next; - } - } -} - - -/* -** if object 'o' has a finalizer, remove it from 'allgc' list (must -** search the list to find it) and link it in 'finobj' list. -*/ -void luaC_checkfinalizer (lua_State *L, GCObject *o, Table *mt) { - global_State *g = G(L); - if (testbit(gch(o)->marked, SEPARATED) || /* obj. is already separated... */ - isfinalized(o) || /* ... or is finalized... */ - gfasttm(g, mt, TM_GC) == NULL) /* or has no finalizer? */ - return; /* nothing to be done */ - else { /* move 'o' to 'finobj' list */ - GCObject **p; - GCheader *ho = gch(o); - if (g->sweepgc == &ho->next) { /* avoid removing current sweep object */ - lua_assert(issweepphase(g)); - g->sweepgc = sweeptolive(L, g->sweepgc, NULL); - } - /* search for pointer pointing to 'o' */ - for (p = &g->allgc; *p != o; p = &gch(*p)->next) { /* empty */ } - *p = ho->next; /* remove 'o' from root list */ - ho->next = g->finobj; /* link it in list 'finobj' */ - g->finobj = o; - l_setbit(ho->marked, SEPARATED); /* mark it as such */ - if (!keepinvariantout(g)) /* not keeping invariant? */ - makewhite(g, o); /* "sweep" object */ - else - resetoldbit(o); /* see MOVE OLD rule */ - } -} - -/* }====================================================== */ - - -/* -** {====================================================== -** GC control -** ======================================================= -*/ - - -/* -** set a reasonable "time" to wait before starting a new GC cycle; -** cycle will start when memory use hits threshold -*/ -static void setpause (global_State *g, l_mem estimate) { - l_mem debt, threshold; - estimate = estimate / PAUSEADJ; /* adjust 'estimate' */ - threshold = (g->gcpause < MAX_LMEM / estimate) /* overflow? */ - ? estimate * g->gcpause /* no overflow */ - : MAX_LMEM; /* overflow; truncate to maximum */ - debt = -cast(l_mem, threshold - gettotalbytes(g)); - luaE_setdebt(g, debt); -} - - -#define sweepphases \ - (bitmask(GCSsweepstring) | bitmask(GCSsweepudata) | bitmask(GCSsweep)) - - -/* -** enter first sweep phase (strings) and prepare pointers for other -** sweep phases. The calls to 'sweeptolive' make pointers point to an -** object inside the list (instead of to the header), so that the real -** sweep do not need to skip objects created between "now" and the start -** of the real sweep. -** Returns how many objects it swept. -*/ -static int entersweep (lua_State *L) { - global_State *g = G(L); - int n = 0; - g->gcstate = GCSsweepstring; - lua_assert(g->sweepgc == NULL && g->sweepfin == NULL); - /* prepare to sweep strings, finalizable objects, and regular objects */ - g->sweepstrgc = 0; - g->sweepfin = sweeptolive(L, &g->finobj, &n); - g->sweepgc = sweeptolive(L, &g->allgc, &n); - return n; -} - - -/* -** change GC mode -*/ -void luaC_changemode (lua_State *L, int mode) { - global_State *g = G(L); - if (mode == g->gckind) return; /* nothing to change */ - if (mode == KGC_GEN) { /* change to generational mode */ - /* make sure gray lists are consistent */ - luaC_runtilstate(L, bitmask(GCSpropagate)); - g->GCestimate = gettotalbytes(g); - g->gckind = KGC_GEN; - } - else { /* change to incremental mode */ - /* sweep all objects to turn them back to white - (as white has not changed, nothing extra will be collected) */ - g->gckind = KGC_NORMAL; - entersweep(L); - luaC_runtilstate(L, ~sweepphases); - } -} - - -/* -** call all pending finalizers -*/ -static void callallpendingfinalizers (lua_State *L, int propagateerrors) { - global_State *g = G(L); - while (g->tobefnz) { - resetoldbit(g->tobefnz); - GCTM(L, propagateerrors); - } -} - - -void luaC_freeallobjects (lua_State *L) { - global_State *g = G(L); - int i; - separatetobefnz(L, 1); /* separate all objects with finalizers */ - lua_assert(g->finobj == NULL); - callallpendingfinalizers(L, 0); - g->currentwhite = WHITEBITS; /* this "white" makes all objects look dead */ - g->gckind = KGC_NORMAL; - sweepwholelist(L, &g->finobj); /* finalizers can create objs. in 'finobj' */ - sweepwholelist(L, &g->allgc); - for (i = 0; i < g->strt.size; i++) /* free all string lists */ - sweepwholelist(L, &g->strt.hash[i]); - lua_assert(g->strt.nuse == 0); -} - - -static l_mem atomic (lua_State *L) { - global_State *g = G(L); - l_mem work = -cast(l_mem, g->GCmemtrav); /* start counting work */ - GCObject *origweak, *origall; - lua_assert(!iswhite(obj2gco(g->mainthread))); - markobject(g, L); /* mark running thread */ - /* registry and global metatables may be changed by API */ - markvalue(g, &g->l_registry); - markmt(g); /* mark basic metatables */ - /* remark occasional upvalues of (maybe) dead threads */ - remarkupvals(g); - propagateall(g); /* propagate changes */ - work += g->GCmemtrav; /* stop counting (do not (re)count grays) */ - /* traverse objects caught by write barrier and by 'remarkupvals' */ - retraversegrays(g); - work -= g->GCmemtrav; /* restart counting */ - convergeephemerons(g); - /* at this point, all strongly accessible objects are marked. */ - /* clear values from weak tables, before checking finalizers */ - clearvalues(g, g->weak, NULL); - clearvalues(g, g->allweak, NULL); - origweak = g->weak; origall = g->allweak; - work += g->GCmemtrav; /* stop counting (objects being finalized) */ - separatetobefnz(L, 0); /* separate objects to be finalized */ - markbeingfnz(g); /* mark objects that will be finalized */ - propagateall(g); /* remark, to propagate `preserveness' */ - work -= g->GCmemtrav; /* restart counting */ - convergeephemerons(g); - /* at this point, all resurrected objects are marked. */ - /* remove dead objects from weak tables */ - clearkeys(g, g->ephemeron, NULL); /* clear keys from all ephemeron tables */ - clearkeys(g, g->allweak, NULL); /* clear keys from all allweak tables */ - /* clear values from resurrected weak tables */ - clearvalues(g, g->weak, origweak); - clearvalues(g, g->allweak, origall); - g->currentwhite = cast_byte(otherwhite(g)); /* flip current white */ - work += g->GCmemtrav; /* complete counting */ - return work; /* estimate of memory marked by 'atomic' */ -} - - -static lu_mem singlestep (lua_State *L) { - global_State *g = G(L); - switch (g->gcstate) { - case GCSpause: { - /* start to count memory traversed */ - g->GCmemtrav = g->strt.size * sizeof(GCObject*); - lua_assert(!isgenerational(g)); - restartcollection(g); - g->gcstate = GCSpropagate; - return g->GCmemtrav; - } - case GCSpropagate: { - if (g->gray) { - lu_mem oldtrav = g->GCmemtrav; - propagatemark(g); - return g->GCmemtrav - oldtrav; /* memory traversed in this step */ - } - else { /* no more `gray' objects */ - lu_mem work; - int sw; - g->gcstate = GCSatomic; /* finish mark phase */ - g->GCestimate = g->GCmemtrav; /* save what was counted */; - work = atomic(L); /* add what was traversed by 'atomic' */ - g->GCestimate += work; /* estimate of total memory traversed */ - sw = entersweep(L); - return work + sw * GCSWEEPCOST; - } - } - case GCSsweepstring: { - int i; - for (i = 0; i < GCSWEEPMAX && g->sweepstrgc + i < g->strt.size; i++) - sweepwholelist(L, &g->strt.hash[g->sweepstrgc + i]); - g->sweepstrgc += i; - if (g->sweepstrgc >= g->strt.size) /* no more strings to sweep? */ - g->gcstate = GCSsweepudata; - return i * GCSWEEPCOST; - } - case GCSsweepudata: { - if (g->sweepfin) { - g->sweepfin = sweeplist(L, g->sweepfin, GCSWEEPMAX); - return GCSWEEPMAX*GCSWEEPCOST; - } - else { - g->gcstate = GCSsweep; - return 0; - } - } - case GCSsweep: { - if (g->sweepgc) { - g->sweepgc = sweeplist(L, g->sweepgc, GCSWEEPMAX); - return GCSWEEPMAX*GCSWEEPCOST; - } - else { - /* sweep main thread */ - GCObject *mt = obj2gco(g->mainthread); - sweeplist(L, &mt, 1); - checkSizes(L); - g->gcstate = GCSpause; /* finish collection */ - return GCSWEEPCOST; - } - } - default: lua_assert(0); return 0; - } -} - - -/* -** advances the garbage collector until it reaches a state allowed -** by 'statemask' -*/ -void luaC_runtilstate (lua_State *L, int statesmask) { - global_State *g = G(L); - while (!testbit(statesmask, g->gcstate)) - singlestep(L); -} - - -static void generationalcollection (lua_State *L) { - global_State *g = G(L); - lua_assert(g->gcstate == GCSpropagate); - if (g->GCestimate == 0) { /* signal for another major collection? */ - luaC_fullgc(L, 0); /* perform a full regular collection */ - g->GCestimate = gettotalbytes(g); /* update control */ - } - else { - lu_mem estimate = g->GCestimate; - luaC_runtilstate(L, bitmask(GCSpause)); /* run complete (minor) cycle */ - g->gcstate = GCSpropagate; /* skip restart */ - if (gettotalbytes(g) > (estimate / 100) * g->gcmajorinc) - g->GCestimate = 0; /* signal for a major collection */ - else - g->GCestimate = estimate; /* keep estimate from last major coll. */ - - } - setpause(g, gettotalbytes(g)); - lua_assert(g->gcstate == GCSpropagate); -} - - -static void incstep (lua_State *L) { - global_State *g = G(L); - l_mem debt = g->GCdebt; - int stepmul = g->gcstepmul; - if (stepmul < 40) stepmul = 40; /* avoid ridiculous low values (and 0) */ - /* convert debt from Kb to 'work units' (avoid zero debt and overflows) */ - debt = (debt / STEPMULADJ) + 1; - debt = (debt < MAX_LMEM / stepmul) ? debt * stepmul : MAX_LMEM; - do { /* always perform at least one single step */ - lu_mem work = singlestep(L); /* do some work */ - debt -= work; - } while (debt > -GCSTEPSIZE && g->gcstate != GCSpause); - if (g->gcstate == GCSpause) - setpause(g, g->GCestimate); /* pause until next cycle */ - else { - debt = (debt / stepmul) * STEPMULADJ; /* convert 'work units' to Kb */ - luaE_setdebt(g, debt); - } -} - - -/* -** performs a basic GC step -*/ -void luaC_forcestep (lua_State *L) { - global_State *g = G(L); - int i; - if (isgenerational(g)) generationalcollection(L); - else incstep(L); - /* run a few finalizers (or all of them at the end of a collect cycle) */ - for (i = 0; g->tobefnz && (i < GCFINALIZENUM || g->gcstate == GCSpause); i++) - GCTM(L, 1); /* call one finalizer */ -} - - -/* -** performs a basic GC step only if collector is running -*/ -void luaC_step (lua_State *L) { - global_State *g = G(L); - if (g->gcrunning) luaC_forcestep(L); - else luaE_setdebt(g, -GCSTEPSIZE); /* avoid being called too often */ -} - - - -/* -** performs a full GC cycle; if "isemergency", does not call -** finalizers (which could change stack positions) -*/ -void luaC_fullgc (lua_State *L, int isemergency) { - global_State *g = G(L); - int origkind = g->gckind; - lua_assert(origkind != KGC_EMERGENCY); - if (isemergency) /* do not run finalizers during emergency GC */ - g->gckind = KGC_EMERGENCY; - else { - g->gckind = KGC_NORMAL; - callallpendingfinalizers(L, 1); - } - if (keepinvariant(g)) { /* may there be some black objects? */ - /* must sweep all objects to turn them back to white - (as white has not changed, nothing will be collected) */ - entersweep(L); - } - /* finish any pending sweep phase to start a new cycle */ - luaC_runtilstate(L, bitmask(GCSpause)); - luaC_runtilstate(L, ~bitmask(GCSpause)); /* start new collection */ - luaC_runtilstate(L, bitmask(GCSpause)); /* run entire collection */ - if (origkind == KGC_GEN) { /* generational mode? */ - /* generational mode must be kept in propagate phase */ - luaC_runtilstate(L, bitmask(GCSpropagate)); - } - g->gckind = origkind; - setpause(g, gettotalbytes(g)); - if (!isemergency) /* do not run finalizers during emergency GC */ - callallpendingfinalizers(L, 1); -} - -/* }====================================================== */ - - diff --git a/btgui/lua-5.2.3/src/lgc.h b/btgui/lua-5.2.3/src/lgc.h deleted file mode 100644 index 84bb1cdf9..000000000 --- a/btgui/lua-5.2.3/src/lgc.h +++ /dev/null @@ -1,157 +0,0 @@ -/* -** $Id: lgc.h,v 2.58.1.1 2013/04/12 18:48:47 roberto Exp $ -** Garbage Collector -** See Copyright Notice in lua.h -*/ - -#ifndef lgc_h -#define lgc_h - - -#include "lobject.h" -#include "lstate.h" - -/* -** Collectable objects may have one of three colors: white, which -** means the object is not marked; gray, which means the -** object is marked, but its references may be not marked; and -** black, which means that the object and all its references are marked. -** The main invariant of the garbage collector, while marking objects, -** is that a black object can never point to a white one. Moreover, -** any gray object must be in a "gray list" (gray, grayagain, weak, -** allweak, ephemeron) so that it can be visited again before finishing -** the collection cycle. These lists have no meaning when the invariant -** is not being enforced (e.g., sweep phase). -*/ - - - -/* how much to allocate before next GC step */ -#if !defined(GCSTEPSIZE) -/* ~100 small strings */ -#define GCSTEPSIZE (cast_int(100 * sizeof(TString))) -#endif - - -/* -** Possible states of the Garbage Collector -*/ -#define GCSpropagate 0 -#define GCSatomic 1 -#define GCSsweepstring 2 -#define GCSsweepudata 3 -#define GCSsweep 4 -#define GCSpause 5 - - -#define issweepphase(g) \ - (GCSsweepstring <= (g)->gcstate && (g)->gcstate <= GCSsweep) - -#define isgenerational(g) ((g)->gckind == KGC_GEN) - -/* -** macros to tell when main invariant (white objects cannot point to black -** ones) must be kept. During a non-generational collection, the sweep -** phase may break the invariant, as objects turned white may point to -** still-black objects. The invariant is restored when sweep ends and -** all objects are white again. During a generational collection, the -** invariant must be kept all times. -*/ - -#define keepinvariant(g) (isgenerational(g) || g->gcstate <= GCSatomic) - - -/* -** Outside the collector, the state in generational mode is kept in -** 'propagate', so 'keepinvariant' is always true. -*/ -#define keepinvariantout(g) \ - check_exp(g->gcstate == GCSpropagate || !isgenerational(g), \ - g->gcstate <= GCSatomic) - - -/* -** some useful bit tricks -*/ -#define resetbits(x,m) ((x) &= cast(lu_byte, ~(m))) -#define setbits(x,m) ((x) |= (m)) -#define testbits(x,m) ((x) & (m)) -#define bitmask(b) (1<<(b)) -#define bit2mask(b1,b2) (bitmask(b1) | bitmask(b2)) -#define l_setbit(x,b) setbits(x, bitmask(b)) -#define resetbit(x,b) resetbits(x, bitmask(b)) -#define testbit(x,b) testbits(x, bitmask(b)) - - -/* Layout for bit use in `marked' field: */ -#define WHITE0BIT 0 /* object is white (type 0) */ -#define WHITE1BIT 1 /* object is white (type 1) */ -#define BLACKBIT 2 /* object is black */ -#define FINALIZEDBIT 3 /* object has been separated for finalization */ -#define SEPARATED 4 /* object is in 'finobj' list or in 'tobefnz' */ -#define FIXEDBIT 5 /* object is fixed (should not be collected) */ -#define OLDBIT 6 /* object is old (only in generational mode) */ -/* bit 7 is currently used by tests (luaL_checkmemory) */ - -#define WHITEBITS bit2mask(WHITE0BIT, WHITE1BIT) - - -#define iswhite(x) testbits((x)->gch.marked, WHITEBITS) -#define isblack(x) testbit((x)->gch.marked, BLACKBIT) -#define isgray(x) /* neither white nor black */ \ - (!testbits((x)->gch.marked, WHITEBITS | bitmask(BLACKBIT))) - -#define isold(x) testbit((x)->gch.marked, OLDBIT) - -/* MOVE OLD rule: whenever an object is moved to the beginning of - a GC list, its old bit must be cleared */ -#define resetoldbit(o) resetbit((o)->gch.marked, OLDBIT) - -#define otherwhite(g) (g->currentwhite ^ WHITEBITS) -#define isdeadm(ow,m) (!(((m) ^ WHITEBITS) & (ow))) -#define isdead(g,v) isdeadm(otherwhite(g), (v)->gch.marked) - -#define changewhite(x) ((x)->gch.marked ^= WHITEBITS) -#define gray2black(x) l_setbit((x)->gch.marked, BLACKBIT) - -#define valiswhite(x) (iscollectable(x) && iswhite(gcvalue(x))) - -#define luaC_white(g) cast(lu_byte, (g)->currentwhite & WHITEBITS) - - -#define luaC_condGC(L,c) \ - {if (G(L)->GCdebt > 0) {c;}; condchangemem(L);} -#define luaC_checkGC(L) luaC_condGC(L, luaC_step(L);) - - -#define luaC_barrier(L,p,v) { if (valiswhite(v) && isblack(obj2gco(p))) \ - luaC_barrier_(L,obj2gco(p),gcvalue(v)); } - -#define luaC_barrierback(L,p,v) { if (valiswhite(v) && isblack(obj2gco(p))) \ - luaC_barrierback_(L,p); } - -#define luaC_objbarrier(L,p,o) \ - { if (iswhite(obj2gco(o)) && isblack(obj2gco(p))) \ - luaC_barrier_(L,obj2gco(p),obj2gco(o)); } - -#define luaC_objbarrierback(L,p,o) \ - { if (iswhite(obj2gco(o)) && isblack(obj2gco(p))) luaC_barrierback_(L,p); } - -#define luaC_barrierproto(L,p,c) \ - { if (isblack(obj2gco(p))) luaC_barrierproto_(L,p,c); } - -LUAI_FUNC void luaC_freeallobjects (lua_State *L); -LUAI_FUNC void luaC_step (lua_State *L); -LUAI_FUNC void luaC_forcestep (lua_State *L); -LUAI_FUNC void luaC_runtilstate (lua_State *L, int statesmask); -LUAI_FUNC void luaC_fullgc (lua_State *L, int isemergency); -LUAI_FUNC GCObject *luaC_newobj (lua_State *L, int tt, size_t sz, - GCObject **list, int offset); -LUAI_FUNC void luaC_barrier_ (lua_State *L, GCObject *o, GCObject *v); -LUAI_FUNC void luaC_barrierback_ (lua_State *L, GCObject *o); -LUAI_FUNC void luaC_barrierproto_ (lua_State *L, Proto *p, Closure *c); -LUAI_FUNC void luaC_checkfinalizer (lua_State *L, GCObject *o, Table *mt); -LUAI_FUNC void luaC_checkupvalcolor (global_State *g, UpVal *uv); -LUAI_FUNC void luaC_changemode (lua_State *L, int mode); - -#endif diff --git a/btgui/lua-5.2.3/src/linit.c b/btgui/lua-5.2.3/src/linit.c deleted file mode 100644 index c1a383047..000000000 --- a/btgui/lua-5.2.3/src/linit.c +++ /dev/null @@ -1,67 +0,0 @@ -/* -** $Id: linit.c,v 1.32.1.1 2013/04/12 18:48:47 roberto Exp $ -** Initialization of libraries for lua.c and other clients -** See Copyright Notice in lua.h -*/ - - -/* -** If you embed Lua in your program and need to open the standard -** libraries, call luaL_openlibs in your program. If you need a -** different set of libraries, copy this file to your project and edit -** it to suit your needs. -*/ - - -#define linit_c -#define LUA_LIB - -#include "lua.h" - -#include "lualib.h" -#include "lauxlib.h" - - -/* -** these libs are loaded by lua.c and are readily available to any Lua -** program -*/ -static const luaL_Reg loadedlibs[] = { - {"_G", luaopen_base}, - {LUA_LOADLIBNAME, luaopen_package}, - {LUA_COLIBNAME, luaopen_coroutine}, - {LUA_TABLIBNAME, luaopen_table}, - {LUA_IOLIBNAME, luaopen_io}, - {LUA_OSLIBNAME, luaopen_os}, - {LUA_STRLIBNAME, luaopen_string}, - {LUA_BITLIBNAME, luaopen_bit32}, - {LUA_MATHLIBNAME, luaopen_math}, - {LUA_DBLIBNAME, luaopen_debug}, - {NULL, NULL} -}; - - -/* -** these libs are preloaded and must be required before used -*/ -static const luaL_Reg preloadedlibs[] = { - {NULL, NULL} -}; - - -LUALIB_API void luaL_openlibs (lua_State *L) { - const luaL_Reg *lib; - /* call open functions from 'loadedlibs' and set results to global table */ - for (lib = loadedlibs; lib->func; lib++) { - luaL_requiref(L, lib->name, lib->func, 1); - lua_pop(L, 1); /* remove lib */ - } - /* add open functions from 'preloadedlibs' into 'package.preload' table */ - luaL_getsubtable(L, LUA_REGISTRYINDEX, "_PRELOAD"); - for (lib = preloadedlibs; lib->func; lib++) { - lua_pushcfunction(L, lib->func); - lua_setfield(L, -2, lib->name); - } - lua_pop(L, 1); /* remove _PRELOAD table */ -} - diff --git a/btgui/lua-5.2.3/src/liolib.c b/btgui/lua-5.2.3/src/liolib.c deleted file mode 100644 index 2a4ec4aa3..000000000 --- a/btgui/lua-5.2.3/src/liolib.c +++ /dev/null @@ -1,666 +0,0 @@ -/* -** $Id: liolib.c,v 2.112.1.1 2013/04/12 18:48:47 roberto Exp $ -** Standard I/O (and system) library -** See Copyright Notice in lua.h -*/ - - -/* -** This definition must come before the inclusion of 'stdio.h'; it -** should not affect non-POSIX systems -*/ -#if !defined(_FILE_OFFSET_BITS) -#define _LARGEFILE_SOURCE 1 -#define _FILE_OFFSET_BITS 64 -#endif - - -#include -#include -#include -#include - -#define liolib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -#if !defined(lua_checkmode) - -/* -** Check whether 'mode' matches '[rwa]%+?b?'. -** Change this macro to accept other modes for 'fopen' besides -** the standard ones. -*/ -#define lua_checkmode(mode) \ - (*mode != '\0' && strchr("rwa", *(mode++)) != NULL && \ - (*mode != '+' || ++mode) && /* skip if char is '+' */ \ - (*mode != 'b' || ++mode) && /* skip if char is 'b' */ \ - (*mode == '\0')) - -#endif - -/* -** {====================================================== -** lua_popen spawns a new process connected to the current -** one through the file streams. -** ======================================================= -*/ - -#if !defined(lua_popen) /* { */ - -#if defined(LUA_USE_POPEN) /* { */ - -#define lua_popen(L,c,m) ((void)L, fflush(NULL), popen(c,m)) -#define lua_pclose(L,file) ((void)L, pclose(file)) - -#elif defined(LUA_WIN) /* }{ */ - -#define lua_popen(L,c,m) ((void)L, _popen(c,m)) -#define lua_pclose(L,file) ((void)L, _pclose(file)) - - -#else /* }{ */ - -#define lua_popen(L,c,m) ((void)((void)c, m), \ - luaL_error(L, LUA_QL("popen") " not supported"), (FILE*)0) -#define lua_pclose(L,file) ((void)((void)L, file), -1) - - -#endif /* } */ - -#endif /* } */ - -/* }====================================================== */ - - -/* -** {====================================================== -** lua_fseek: configuration for longer offsets -** ======================================================= -*/ - -#if !defined(lua_fseek) && !defined(LUA_ANSI) /* { */ - -#if defined(LUA_USE_POSIX) /* { */ - -#define l_fseek(f,o,w) fseeko(f,o,w) -#define l_ftell(f) ftello(f) -#define l_seeknum off_t - -#elif defined(LUA_WIN) && !defined(_CRTIMP_TYPEINFO) \ - && defined(_MSC_VER) && (_MSC_VER >= 1400) /* }{ */ -/* Windows (but not DDK) and Visual C++ 2005 or higher */ - -#define l_fseek(f,o,w) _fseeki64(f,o,w) -#define l_ftell(f) _ftelli64(f) -#define l_seeknum __int64 - -#endif /* } */ - -#endif /* } */ - - -#if !defined(l_fseek) /* default definitions */ -#define l_fseek(f,o,w) fseek(f,o,w) -#define l_ftell(f) ftell(f) -#define l_seeknum long -#endif - -/* }====================================================== */ - - -#define IO_PREFIX "_IO_" -#define IO_INPUT (IO_PREFIX "input") -#define IO_OUTPUT (IO_PREFIX "output") - - -typedef luaL_Stream LStream; - - -#define tolstream(L) ((LStream *)luaL_checkudata(L, 1, LUA_FILEHANDLE)) - -#define isclosed(p) ((p)->closef == NULL) - - -static int io_type (lua_State *L) { - LStream *p; - luaL_checkany(L, 1); - p = (LStream *)luaL_testudata(L, 1, LUA_FILEHANDLE); - if (p == NULL) - lua_pushnil(L); /* not a file */ - else if (isclosed(p)) - lua_pushliteral(L, "closed file"); - else - lua_pushliteral(L, "file"); - return 1; -} - - -static int f_tostring (lua_State *L) { - LStream *p = tolstream(L); - if (isclosed(p)) - lua_pushliteral(L, "file (closed)"); - else - lua_pushfstring(L, "file (%p)", p->f); - return 1; -} - - -static FILE *tofile (lua_State *L) { - LStream *p = tolstream(L); - if (isclosed(p)) - luaL_error(L, "attempt to use a closed file"); - lua_assert(p->f); - return p->f; -} - - -/* -** When creating file handles, always creates a `closed' file handle -** before opening the actual file; so, if there is a memory error, the -** file is not left opened. -*/ -static LStream *newprefile (lua_State *L) { - LStream *p = (LStream *)lua_newuserdata(L, sizeof(LStream)); - p->closef = NULL; /* mark file handle as 'closed' */ - luaL_setmetatable(L, LUA_FILEHANDLE); - return p; -} - - -static int aux_close (lua_State *L) { - LStream *p = tolstream(L); - lua_CFunction cf = p->closef; - p->closef = NULL; /* mark stream as closed */ - return (*cf)(L); /* close it */ -} - - -static int io_close (lua_State *L) { - if (lua_isnone(L, 1)) /* no argument? */ - lua_getfield(L, LUA_REGISTRYINDEX, IO_OUTPUT); /* use standard output */ - tofile(L); /* make sure argument is an open stream */ - return aux_close(L); -} - - -static int f_gc (lua_State *L) { - LStream *p = tolstream(L); - if (!isclosed(p) && p->f != NULL) - aux_close(L); /* ignore closed and incompletely open files */ - return 0; -} - - -/* -** function to close regular files -*/ -static int io_fclose (lua_State *L) { - LStream *p = tolstream(L); - int res = fclose(p->f); - return luaL_fileresult(L, (res == 0), NULL); -} - - -static LStream *newfile (lua_State *L) { - LStream *p = newprefile(L); - p->f = NULL; - p->closef = &io_fclose; - return p; -} - - -static void opencheck (lua_State *L, const char *fname, const char *mode) { - LStream *p = newfile(L); - p->f = fopen(fname, mode); - if (p->f == NULL) - luaL_error(L, "cannot open file " LUA_QS " (%s)", fname, strerror(errno)); -} - - -static int io_open (lua_State *L) { - const char *filename = luaL_checkstring(L, 1); - const char *mode = luaL_optstring(L, 2, "r"); - LStream *p = newfile(L); - const char *md = mode; /* to traverse/check mode */ - luaL_argcheck(L, lua_checkmode(md), 2, "invalid mode"); - p->f = fopen(filename, mode); - return (p->f == NULL) ? luaL_fileresult(L, 0, filename) : 1; -} - - -/* -** function to close 'popen' files -*/ -static int io_pclose (lua_State *L) { - LStream *p = tolstream(L); - return luaL_execresult(L, lua_pclose(L, p->f)); -} - - -static int io_popen (lua_State *L) { - const char *filename = luaL_checkstring(L, 1); - const char *mode = luaL_optstring(L, 2, "r"); - LStream *p = newprefile(L); - p->f = lua_popen(L, filename, mode); - p->closef = &io_pclose; - return (p->f == NULL) ? luaL_fileresult(L, 0, filename) : 1; -} - - -static int io_tmpfile (lua_State *L) { - LStream *p = newfile(L); - p->f = tmpfile(); - return (p->f == NULL) ? luaL_fileresult(L, 0, NULL) : 1; -} - - -static FILE *getiofile (lua_State *L, const char *findex) { - LStream *p; - lua_getfield(L, LUA_REGISTRYINDEX, findex); - p = (LStream *)lua_touserdata(L, -1); - if (isclosed(p)) - luaL_error(L, "standard %s file is closed", findex + strlen(IO_PREFIX)); - return p->f; -} - - -static int g_iofile (lua_State *L, const char *f, const char *mode) { - if (!lua_isnoneornil(L, 1)) { - const char *filename = lua_tostring(L, 1); - if (filename) - opencheck(L, filename, mode); - else { - tofile(L); /* check that it's a valid file handle */ - lua_pushvalue(L, 1); - } - lua_setfield(L, LUA_REGISTRYINDEX, f); - } - /* return current value */ - lua_getfield(L, LUA_REGISTRYINDEX, f); - return 1; -} - - -static int io_input (lua_State *L) { - return g_iofile(L, IO_INPUT, "r"); -} - - -static int io_output (lua_State *L) { - return g_iofile(L, IO_OUTPUT, "w"); -} - - -static int io_readline (lua_State *L); - - -static void aux_lines (lua_State *L, int toclose) { - int i; - int n = lua_gettop(L) - 1; /* number of arguments to read */ - /* ensure that arguments will fit here and into 'io_readline' stack */ - luaL_argcheck(L, n <= LUA_MINSTACK - 3, LUA_MINSTACK - 3, "too many options"); - lua_pushvalue(L, 1); /* file handle */ - lua_pushinteger(L, n); /* number of arguments to read */ - lua_pushboolean(L, toclose); /* close/not close file when finished */ - for (i = 1; i <= n; i++) lua_pushvalue(L, i + 1); /* copy arguments */ - lua_pushcclosure(L, io_readline, 3 + n); -} - - -static int f_lines (lua_State *L) { - tofile(L); /* check that it's a valid file handle */ - aux_lines(L, 0); - return 1; -} - - -static int io_lines (lua_State *L) { - int toclose; - if (lua_isnone(L, 1)) lua_pushnil(L); /* at least one argument */ - if (lua_isnil(L, 1)) { /* no file name? */ - lua_getfield(L, LUA_REGISTRYINDEX, IO_INPUT); /* get default input */ - lua_replace(L, 1); /* put it at index 1 */ - tofile(L); /* check that it's a valid file handle */ - toclose = 0; /* do not close it after iteration */ - } - else { /* open a new file */ - const char *filename = luaL_checkstring(L, 1); - opencheck(L, filename, "r"); - lua_replace(L, 1); /* put file at index 1 */ - toclose = 1; /* close it after iteration */ - } - aux_lines(L, toclose); - return 1; -} - - -/* -** {====================================================== -** READ -** ======================================================= -*/ - - -static int read_number (lua_State *L, FILE *f) { - lua_Number d; - if (fscanf(f, LUA_NUMBER_SCAN, &d) == 1) { - lua_pushnumber(L, d); - return 1; - } - else { - lua_pushnil(L); /* "result" to be removed */ - return 0; /* read fails */ - } -} - - -static int test_eof (lua_State *L, FILE *f) { - int c = getc(f); - ungetc(c, f); - lua_pushlstring(L, NULL, 0); - return (c != EOF); -} - - -static int read_line (lua_State *L, FILE *f, int chop) { - luaL_Buffer b; - luaL_buffinit(L, &b); - for (;;) { - size_t l; - char *p = luaL_prepbuffer(&b); - if (fgets(p, LUAL_BUFFERSIZE, f) == NULL) { /* eof? */ - luaL_pushresult(&b); /* close buffer */ - return (lua_rawlen(L, -1) > 0); /* check whether read something */ - } - l = strlen(p); - if (l == 0 || p[l-1] != '\n') - luaL_addsize(&b, l); - else { - luaL_addsize(&b, l - chop); /* chop 'eol' if needed */ - luaL_pushresult(&b); /* close buffer */ - return 1; /* read at least an `eol' */ - } - } -} - - -#define MAX_SIZE_T (~(size_t)0) - -static void read_all (lua_State *L, FILE *f) { - size_t rlen = LUAL_BUFFERSIZE; /* how much to read in each cycle */ - luaL_Buffer b; - luaL_buffinit(L, &b); - for (;;) { - char *p = luaL_prepbuffsize(&b, rlen); - size_t nr = fread(p, sizeof(char), rlen, f); - luaL_addsize(&b, nr); - if (nr < rlen) break; /* eof? */ - else if (rlen <= (MAX_SIZE_T / 4)) /* avoid buffers too large */ - rlen *= 2; /* double buffer size at each iteration */ - } - luaL_pushresult(&b); /* close buffer */ -} - - -static int read_chars (lua_State *L, FILE *f, size_t n) { - size_t nr; /* number of chars actually read */ - char *p; - luaL_Buffer b; - luaL_buffinit(L, &b); - p = luaL_prepbuffsize(&b, n); /* prepare buffer to read whole block */ - nr = fread(p, sizeof(char), n, f); /* try to read 'n' chars */ - luaL_addsize(&b, nr); - luaL_pushresult(&b); /* close buffer */ - return (nr > 0); /* true iff read something */ -} - - -static int g_read (lua_State *L, FILE *f, int first) { - int nargs = lua_gettop(L) - 1; - int success; - int n; - clearerr(f); - if (nargs == 0) { /* no arguments? */ - success = read_line(L, f, 1); - n = first+1; /* to return 1 result */ - } - else { /* ensure stack space for all results and for auxlib's buffer */ - luaL_checkstack(L, nargs+LUA_MINSTACK, "too many arguments"); - success = 1; - for (n = first; nargs-- && success; n++) { - if (lua_type(L, n) == LUA_TNUMBER) { - size_t l = (size_t)lua_tointeger(L, n); - success = (l == 0) ? test_eof(L, f) : read_chars(L, f, l); - } - else { - const char *p = lua_tostring(L, n); - luaL_argcheck(L, p && p[0] == '*', n, "invalid option"); - switch (p[1]) { - case 'n': /* number */ - success = read_number(L, f); - break; - case 'l': /* line */ - success = read_line(L, f, 1); - break; - case 'L': /* line with end-of-line */ - success = read_line(L, f, 0); - break; - case 'a': /* file */ - read_all(L, f); /* read entire file */ - success = 1; /* always success */ - break; - default: - return luaL_argerror(L, n, "invalid format"); - } - } - } - } - if (ferror(f)) - return luaL_fileresult(L, 0, NULL); - if (!success) { - lua_pop(L, 1); /* remove last result */ - lua_pushnil(L); /* push nil instead */ - } - return n - first; -} - - -static int io_read (lua_State *L) { - return g_read(L, getiofile(L, IO_INPUT), 1); -} - - -static int f_read (lua_State *L) { - return g_read(L, tofile(L), 2); -} - - -static int io_readline (lua_State *L) { - LStream *p = (LStream *)lua_touserdata(L, lua_upvalueindex(1)); - int i; - int n = (int)lua_tointeger(L, lua_upvalueindex(2)); - if (isclosed(p)) /* file is already closed? */ - return luaL_error(L, "file is already closed"); - lua_settop(L , 1); - for (i = 1; i <= n; i++) /* push arguments to 'g_read' */ - lua_pushvalue(L, lua_upvalueindex(3 + i)); - n = g_read(L, p->f, 2); /* 'n' is number of results */ - lua_assert(n > 0); /* should return at least a nil */ - if (!lua_isnil(L, -n)) /* read at least one value? */ - return n; /* return them */ - else { /* first result is nil: EOF or error */ - if (n > 1) { /* is there error information? */ - /* 2nd result is error message */ - return luaL_error(L, "%s", lua_tostring(L, -n + 1)); - } - if (lua_toboolean(L, lua_upvalueindex(3))) { /* generator created file? */ - lua_settop(L, 0); - lua_pushvalue(L, lua_upvalueindex(1)); - aux_close(L); /* close it */ - } - return 0; - } -} - -/* }====================================================== */ - - -static int g_write (lua_State *L, FILE *f, int arg) { - int nargs = lua_gettop(L) - arg; - int status = 1; - for (; nargs--; arg++) { - if (lua_type(L, arg) == LUA_TNUMBER) { - /* optimization: could be done exactly as for strings */ - status = status && - fprintf(f, LUA_NUMBER_FMT, lua_tonumber(L, arg)) > 0; - } - else { - size_t l; - const char *s = luaL_checklstring(L, arg, &l); - status = status && (fwrite(s, sizeof(char), l, f) == l); - } - } - if (status) return 1; /* file handle already on stack top */ - else return luaL_fileresult(L, status, NULL); -} - - -static int io_write (lua_State *L) { - return g_write(L, getiofile(L, IO_OUTPUT), 1); -} - - -static int f_write (lua_State *L) { - FILE *f = tofile(L); - lua_pushvalue(L, 1); /* push file at the stack top (to be returned) */ - return g_write(L, f, 2); -} - - -static int f_seek (lua_State *L) { - static const int mode[] = {SEEK_SET, SEEK_CUR, SEEK_END}; - static const char *const modenames[] = {"set", "cur", "end", NULL}; - FILE *f = tofile(L); - int op = luaL_checkoption(L, 2, "cur", modenames); - lua_Number p3 = luaL_optnumber(L, 3, 0); - l_seeknum offset = (l_seeknum)p3; - luaL_argcheck(L, (lua_Number)offset == p3, 3, - "not an integer in proper range"); - op = l_fseek(f, offset, mode[op]); - if (op) - return luaL_fileresult(L, 0, NULL); /* error */ - else { - lua_pushnumber(L, (lua_Number)l_ftell(f)); - return 1; - } -} - - -static int f_setvbuf (lua_State *L) { - static const int mode[] = {_IONBF, _IOFBF, _IOLBF}; - static const char *const modenames[] = {"no", "full", "line", NULL}; - FILE *f = tofile(L); - int op = luaL_checkoption(L, 2, NULL, modenames); - lua_Integer sz = luaL_optinteger(L, 3, LUAL_BUFFERSIZE); - int res = setvbuf(f, NULL, mode[op], sz); - return luaL_fileresult(L, res == 0, NULL); -} - - - -static int io_flush (lua_State *L) { - return luaL_fileresult(L, fflush(getiofile(L, IO_OUTPUT)) == 0, NULL); -} - - -static int f_flush (lua_State *L) { - return luaL_fileresult(L, fflush(tofile(L)) == 0, NULL); -} - - -/* -** functions for 'io' library -*/ -static const luaL_Reg iolib[] = { - {"close", io_close}, - {"flush", io_flush}, - {"input", io_input}, - {"lines", io_lines}, - {"open", io_open}, - {"output", io_output}, - {"popen", io_popen}, - {"read", io_read}, - {"tmpfile", io_tmpfile}, - {"type", io_type}, - {"write", io_write}, - {NULL, NULL} -}; - - -/* -** methods for file handles -*/ -static const luaL_Reg flib[] = { - {"close", io_close}, - {"flush", f_flush}, - {"lines", f_lines}, - {"read", f_read}, - {"seek", f_seek}, - {"setvbuf", f_setvbuf}, - {"write", f_write}, - {"__gc", f_gc}, - {"__tostring", f_tostring}, - {NULL, NULL} -}; - - -static void createmeta (lua_State *L) { - luaL_newmetatable(L, LUA_FILEHANDLE); /* create metatable for file handles */ - lua_pushvalue(L, -1); /* push metatable */ - lua_setfield(L, -2, "__index"); /* metatable.__index = metatable */ - luaL_setfuncs(L, flib, 0); /* add file methods to new metatable */ - lua_pop(L, 1); /* pop new metatable */ -} - - -/* -** function to (not) close the standard files stdin, stdout, and stderr -*/ -static int io_noclose (lua_State *L) { - LStream *p = tolstream(L); - p->closef = &io_noclose; /* keep file opened */ - lua_pushnil(L); - lua_pushliteral(L, "cannot close standard file"); - return 2; -} - - -static void createstdfile (lua_State *L, FILE *f, const char *k, - const char *fname) { - LStream *p = newprefile(L); - p->f = f; - p->closef = &io_noclose; - if (k != NULL) { - lua_pushvalue(L, -1); - lua_setfield(L, LUA_REGISTRYINDEX, k); /* add file to registry */ - } - lua_setfield(L, -2, fname); /* add file to module */ -} - - -LUAMOD_API int luaopen_io (lua_State *L) { - luaL_newlib(L, iolib); /* new module */ - createmeta(L); - /* create (and set) default files */ - createstdfile(L, stdin, IO_INPUT, "stdin"); - createstdfile(L, stdout, IO_OUTPUT, "stdout"); - createstdfile(L, stderr, NULL, "stderr"); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/llex.c b/btgui/lua-5.2.3/src/llex.c deleted file mode 100644 index c4b820e83..000000000 --- a/btgui/lua-5.2.3/src/llex.c +++ /dev/null @@ -1,530 +0,0 @@ -/* -** $Id: llex.c,v 2.63.1.2 2013/08/30 15:49:41 roberto Exp $ -** Lexical Analyzer -** See Copyright Notice in lua.h -*/ - - -#include -#include - -#define llex_c -#define LUA_CORE - -#include "lua.h" - -#include "lctype.h" -#include "ldo.h" -#include "llex.h" -#include "lobject.h" -#include "lparser.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "lzio.h" - - - -#define next(ls) (ls->current = zgetc(ls->z)) - - - -#define currIsNewline(ls) (ls->current == '\n' || ls->current == '\r') - - -/* ORDER RESERVED */ -static const char *const luaX_tokens [] = { - "and", "break", "do", "else", "elseif", - "end", "false", "for", "function", "goto", "if", - "in", "local", "nil", "not", "or", "repeat", - "return", "then", "true", "until", "while", - "..", "...", "==", ">=", "<=", "~=", "::", "", - "", "", "" -}; - - -#define save_and_next(ls) (save(ls, ls->current), next(ls)) - - -static l_noret lexerror (LexState *ls, const char *msg, int token); - - -static void save (LexState *ls, int c) { - Mbuffer *b = ls->buff; - if (luaZ_bufflen(b) + 1 > luaZ_sizebuffer(b)) { - size_t newsize; - if (luaZ_sizebuffer(b) >= MAX_SIZET/2) - lexerror(ls, "lexical element too long", 0); - newsize = luaZ_sizebuffer(b) * 2; - luaZ_resizebuffer(ls->L, b, newsize); - } - b->buffer[luaZ_bufflen(b)++] = cast(char, c); -} - - -void luaX_init (lua_State *L) { - int i; - for (i=0; itsv.extra = cast_byte(i+1); /* reserved word */ - } -} - - -const char *luaX_token2str (LexState *ls, int token) { - if (token < FIRST_RESERVED) { /* single-byte symbols? */ - lua_assert(token == cast(unsigned char, token)); - return (lisprint(token)) ? luaO_pushfstring(ls->L, LUA_QL("%c"), token) : - luaO_pushfstring(ls->L, "char(%d)", token); - } - else { - const char *s = luaX_tokens[token - FIRST_RESERVED]; - if (token < TK_EOS) /* fixed format (symbols and reserved words)? */ - return luaO_pushfstring(ls->L, LUA_QS, s); - else /* names, strings, and numerals */ - return s; - } -} - - -static const char *txtToken (LexState *ls, int token) { - switch (token) { - case TK_NAME: - case TK_STRING: - case TK_NUMBER: - save(ls, '\0'); - return luaO_pushfstring(ls->L, LUA_QS, luaZ_buffer(ls->buff)); - default: - return luaX_token2str(ls, token); - } -} - - -static l_noret lexerror (LexState *ls, const char *msg, int token) { - char buff[LUA_IDSIZE]; - luaO_chunkid(buff, getstr(ls->source), LUA_IDSIZE); - msg = luaO_pushfstring(ls->L, "%s:%d: %s", buff, ls->linenumber, msg); - if (token) - luaO_pushfstring(ls->L, "%s near %s", msg, txtToken(ls, token)); - luaD_throw(ls->L, LUA_ERRSYNTAX); -} - - -l_noret luaX_syntaxerror (LexState *ls, const char *msg) { - lexerror(ls, msg, ls->t.token); -} - - -/* -** creates a new string and anchors it in function's table so that -** it will not be collected until the end of the function's compilation -** (by that time it should be anchored in function's prototype) -*/ -TString *luaX_newstring (LexState *ls, const char *str, size_t l) { - lua_State *L = ls->L; - TValue *o; /* entry for `str' */ - TString *ts = luaS_newlstr(L, str, l); /* create new string */ - setsvalue2s(L, L->top++, ts); /* temporarily anchor it in stack */ - o = luaH_set(L, ls->fs->h, L->top - 1); - if (ttisnil(o)) { /* not in use yet? (see 'addK') */ - /* boolean value does not need GC barrier; - table has no metatable, so it does not need to invalidate cache */ - setbvalue(o, 1); /* t[string] = true */ - luaC_checkGC(L); - } - else { /* string already present */ - ts = rawtsvalue(keyfromval(o)); /* re-use value previously stored */ - } - L->top--; /* remove string from stack */ - return ts; -} - - -/* -** increment line number and skips newline sequence (any of -** \n, \r, \n\r, or \r\n) -*/ -static void inclinenumber (LexState *ls) { - int old = ls->current; - lua_assert(currIsNewline(ls)); - next(ls); /* skip `\n' or `\r' */ - if (currIsNewline(ls) && ls->current != old) - next(ls); /* skip `\n\r' or `\r\n' */ - if (++ls->linenumber >= MAX_INT) - luaX_syntaxerror(ls, "chunk has too many lines"); -} - - -void luaX_setinput (lua_State *L, LexState *ls, ZIO *z, TString *source, - int firstchar) { - ls->decpoint = '.'; - ls->L = L; - ls->current = firstchar; - ls->lookahead.token = TK_EOS; /* no look-ahead token */ - ls->z = z; - ls->fs = NULL; - ls->linenumber = 1; - ls->lastline = 1; - ls->source = source; - ls->envn = luaS_new(L, LUA_ENV); /* create env name */ - luaS_fix(ls->envn); /* never collect this name */ - luaZ_resizebuffer(ls->L, ls->buff, LUA_MINBUFFER); /* initialize buffer */ -} - - - -/* -** ======================================================= -** LEXICAL ANALYZER -** ======================================================= -*/ - - - -static int check_next (LexState *ls, const char *set) { - if (ls->current == '\0' || !strchr(set, ls->current)) - return 0; - save_and_next(ls); - return 1; -} - - -/* -** change all characters 'from' in buffer to 'to' -*/ -static void buffreplace (LexState *ls, char from, char to) { - size_t n = luaZ_bufflen(ls->buff); - char *p = luaZ_buffer(ls->buff); - while (n--) - if (p[n] == from) p[n] = to; -} - - -#if !defined(getlocaledecpoint) -#define getlocaledecpoint() (localeconv()->decimal_point[0]) -#endif - - -#define buff2d(b,e) luaO_str2d(luaZ_buffer(b), luaZ_bufflen(b) - 1, e) - -/* -** in case of format error, try to change decimal point separator to -** the one defined in the current locale and check again -*/ -static void trydecpoint (LexState *ls, SemInfo *seminfo) { - char old = ls->decpoint; - ls->decpoint = getlocaledecpoint(); - buffreplace(ls, old, ls->decpoint); /* try new decimal separator */ - if (!buff2d(ls->buff, &seminfo->r)) { - /* format error with correct decimal point: no more options */ - buffreplace(ls, ls->decpoint, '.'); /* undo change (for error message) */ - lexerror(ls, "malformed number", TK_NUMBER); - } -} - - -/* LUA_NUMBER */ -/* -** this function is quite liberal in what it accepts, as 'luaO_str2d' -** will reject ill-formed numerals. -*/ -static void read_numeral (LexState *ls, SemInfo *seminfo) { - const char *expo = "Ee"; - int first = ls->current; - lua_assert(lisdigit(ls->current)); - save_and_next(ls); - if (first == '0' && check_next(ls, "Xx")) /* hexadecimal? */ - expo = "Pp"; - for (;;) { - if (check_next(ls, expo)) /* exponent part? */ - check_next(ls, "+-"); /* optional exponent sign */ - if (lisxdigit(ls->current) || ls->current == '.') - save_and_next(ls); - else break; - } - save(ls, '\0'); - buffreplace(ls, '.', ls->decpoint); /* follow locale for decimal point */ - if (!buff2d(ls->buff, &seminfo->r)) /* format error? */ - trydecpoint(ls, seminfo); /* try to update decimal point separator */ -} - - -/* -** skip a sequence '[=*[' or ']=*]' and return its number of '='s or -** -1 if sequence is malformed -*/ -static int skip_sep (LexState *ls) { - int count = 0; - int s = ls->current; - lua_assert(s == '[' || s == ']'); - save_and_next(ls); - while (ls->current == '=') { - save_and_next(ls); - count++; - } - return (ls->current == s) ? count : (-count) - 1; -} - - -static void read_long_string (LexState *ls, SemInfo *seminfo, int sep) { - save_and_next(ls); /* skip 2nd `[' */ - if (currIsNewline(ls)) /* string starts with a newline? */ - inclinenumber(ls); /* skip it */ - for (;;) { - switch (ls->current) { - case EOZ: - lexerror(ls, (seminfo) ? "unfinished long string" : - "unfinished long comment", TK_EOS); - break; /* to avoid warnings */ - case ']': { - if (skip_sep(ls) == sep) { - save_and_next(ls); /* skip 2nd `]' */ - goto endloop; - } - break; - } - case '\n': case '\r': { - save(ls, '\n'); - inclinenumber(ls); - if (!seminfo) luaZ_resetbuffer(ls->buff); /* avoid wasting space */ - break; - } - default: { - if (seminfo) save_and_next(ls); - else next(ls); - } - } - } endloop: - if (seminfo) - seminfo->ts = luaX_newstring(ls, luaZ_buffer(ls->buff) + (2 + sep), - luaZ_bufflen(ls->buff) - 2*(2 + sep)); -} - - -static void escerror (LexState *ls, int *c, int n, const char *msg) { - int i; - luaZ_resetbuffer(ls->buff); /* prepare error message */ - save(ls, '\\'); - for (i = 0; i < n && c[i] != EOZ; i++) - save(ls, c[i]); - lexerror(ls, msg, TK_STRING); -} - - -static int readhexaesc (LexState *ls) { - int c[3], i; /* keep input for error message */ - int r = 0; /* result accumulator */ - c[0] = 'x'; /* for error message */ - for (i = 1; i < 3; i++) { /* read two hexadecimal digits */ - c[i] = next(ls); - if (!lisxdigit(c[i])) - escerror(ls, c, i + 1, "hexadecimal digit expected"); - r = (r << 4) + luaO_hexavalue(c[i]); - } - return r; -} - - -static int readdecesc (LexState *ls) { - int c[3], i; - int r = 0; /* result accumulator */ - for (i = 0; i < 3 && lisdigit(ls->current); i++) { /* read up to 3 digits */ - c[i] = ls->current; - r = 10*r + c[i] - '0'; - next(ls); - } - if (r > UCHAR_MAX) - escerror(ls, c, i, "decimal escape too large"); - return r; -} - - -static void read_string (LexState *ls, int del, SemInfo *seminfo) { - save_and_next(ls); /* keep delimiter (for error messages) */ - while (ls->current != del) { - switch (ls->current) { - case EOZ: - lexerror(ls, "unfinished string", TK_EOS); - break; /* to avoid warnings */ - case '\n': - case '\r': - lexerror(ls, "unfinished string", TK_STRING); - break; /* to avoid warnings */ - case '\\': { /* escape sequences */ - int c; /* final character to be saved */ - next(ls); /* do not save the `\' */ - switch (ls->current) { - case 'a': c = '\a'; goto read_save; - case 'b': c = '\b'; goto read_save; - case 'f': c = '\f'; goto read_save; - case 'n': c = '\n'; goto read_save; - case 'r': c = '\r'; goto read_save; - case 't': c = '\t'; goto read_save; - case 'v': c = '\v'; goto read_save; - case 'x': c = readhexaesc(ls); goto read_save; - case '\n': case '\r': - inclinenumber(ls); c = '\n'; goto only_save; - case '\\': case '\"': case '\'': - c = ls->current; goto read_save; - case EOZ: goto no_save; /* will raise an error next loop */ - case 'z': { /* zap following span of spaces */ - next(ls); /* skip the 'z' */ - while (lisspace(ls->current)) { - if (currIsNewline(ls)) inclinenumber(ls); - else next(ls); - } - goto no_save; - } - default: { - if (!lisdigit(ls->current)) - escerror(ls, &ls->current, 1, "invalid escape sequence"); - /* digital escape \ddd */ - c = readdecesc(ls); - goto only_save; - } - } - read_save: next(ls); /* read next character */ - only_save: save(ls, c); /* save 'c' */ - no_save: break; - } - default: - save_and_next(ls); - } - } - save_and_next(ls); /* skip delimiter */ - seminfo->ts = luaX_newstring(ls, luaZ_buffer(ls->buff) + 1, - luaZ_bufflen(ls->buff) - 2); -} - - -static int llex (LexState *ls, SemInfo *seminfo) { - luaZ_resetbuffer(ls->buff); - for (;;) { - switch (ls->current) { - case '\n': case '\r': { /* line breaks */ - inclinenumber(ls); - break; - } - case ' ': case '\f': case '\t': case '\v': { /* spaces */ - next(ls); - break; - } - case '-': { /* '-' or '--' (comment) */ - next(ls); - if (ls->current != '-') return '-'; - /* else is a comment */ - next(ls); - if (ls->current == '[') { /* long comment? */ - int sep = skip_sep(ls); - luaZ_resetbuffer(ls->buff); /* `skip_sep' may dirty the buffer */ - if (sep >= 0) { - read_long_string(ls, NULL, sep); /* skip long comment */ - luaZ_resetbuffer(ls->buff); /* previous call may dirty the buff. */ - break; - } - } - /* else short comment */ - while (!currIsNewline(ls) && ls->current != EOZ) - next(ls); /* skip until end of line (or end of file) */ - break; - } - case '[': { /* long string or simply '[' */ - int sep = skip_sep(ls); - if (sep >= 0) { - read_long_string(ls, seminfo, sep); - return TK_STRING; - } - else if (sep == -1) return '['; - else lexerror(ls, "invalid long string delimiter", TK_STRING); - } - case '=': { - next(ls); - if (ls->current != '=') return '='; - else { next(ls); return TK_EQ; } - } - case '<': { - next(ls); - if (ls->current != '=') return '<'; - else { next(ls); return TK_LE; } - } - case '>': { - next(ls); - if (ls->current != '=') return '>'; - else { next(ls); return TK_GE; } - } - case '~': { - next(ls); - if (ls->current != '=') return '~'; - else { next(ls); return TK_NE; } - } - case ':': { - next(ls); - if (ls->current != ':') return ':'; - else { next(ls); return TK_DBCOLON; } - } - case '"': case '\'': { /* short literal strings */ - read_string(ls, ls->current, seminfo); - return TK_STRING; - } - case '.': { /* '.', '..', '...', or number */ - save_and_next(ls); - if (check_next(ls, ".")) { - if (check_next(ls, ".")) - return TK_DOTS; /* '...' */ - else return TK_CONCAT; /* '..' */ - } - else if (!lisdigit(ls->current)) return '.'; - /* else go through */ - } - case '0': case '1': case '2': case '3': case '4': - case '5': case '6': case '7': case '8': case '9': { - read_numeral(ls, seminfo); - return TK_NUMBER; - } - case EOZ: { - return TK_EOS; - } - default: { - if (lislalpha(ls->current)) { /* identifier or reserved word? */ - TString *ts; - do { - save_and_next(ls); - } while (lislalnum(ls->current)); - ts = luaX_newstring(ls, luaZ_buffer(ls->buff), - luaZ_bufflen(ls->buff)); - seminfo->ts = ts; - if (isreserved(ts)) /* reserved word? */ - return ts->tsv.extra - 1 + FIRST_RESERVED; - else { - return TK_NAME; - } - } - else { /* single-char tokens (+ - / ...) */ - int c = ls->current; - next(ls); - return c; - } - } - } - } -} - - -void luaX_next (LexState *ls) { - ls->lastline = ls->linenumber; - if (ls->lookahead.token != TK_EOS) { /* is there a look-ahead token? */ - ls->t = ls->lookahead; /* use this one */ - ls->lookahead.token = TK_EOS; /* and discharge it */ - } - else - ls->t.token = llex(ls, &ls->t.seminfo); /* read next token */ -} - - -int luaX_lookahead (LexState *ls) { - lua_assert(ls->lookahead.token == TK_EOS); - ls->lookahead.token = llex(ls, &ls->lookahead.seminfo); - return ls->lookahead.token; -} - diff --git a/btgui/lua-5.2.3/src/llex.h b/btgui/lua-5.2.3/src/llex.h deleted file mode 100644 index a4acdd302..000000000 --- a/btgui/lua-5.2.3/src/llex.h +++ /dev/null @@ -1,78 +0,0 @@ -/* -** $Id: llex.h,v 1.72.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lexical Analyzer -** See Copyright Notice in lua.h -*/ - -#ifndef llex_h -#define llex_h - -#include "lobject.h" -#include "lzio.h" - - -#define FIRST_RESERVED 257 - - - -/* -* WARNING: if you change the order of this enumeration, -* grep "ORDER RESERVED" -*/ -enum RESERVED { - /* terminal symbols denoted by reserved words */ - TK_AND = FIRST_RESERVED, TK_BREAK, - TK_DO, TK_ELSE, TK_ELSEIF, TK_END, TK_FALSE, TK_FOR, TK_FUNCTION, - TK_GOTO, TK_IF, TK_IN, TK_LOCAL, TK_NIL, TK_NOT, TK_OR, TK_REPEAT, - TK_RETURN, TK_THEN, TK_TRUE, TK_UNTIL, TK_WHILE, - /* other terminal symbols */ - TK_CONCAT, TK_DOTS, TK_EQ, TK_GE, TK_LE, TK_NE, TK_DBCOLON, TK_EOS, - TK_NUMBER, TK_NAME, TK_STRING -}; - -/* number of reserved words */ -#define NUM_RESERVED (cast(int, TK_WHILE-FIRST_RESERVED+1)) - - -typedef union { - lua_Number r; - TString *ts; -} SemInfo; /* semantics information */ - - -typedef struct Token { - int token; - SemInfo seminfo; -} Token; - - -/* state of the lexer plus state of the parser when shared by all - functions */ -typedef struct LexState { - int current; /* current character (charint) */ - int linenumber; /* input line counter */ - int lastline; /* line of last token `consumed' */ - Token t; /* current token */ - Token lookahead; /* look ahead token */ - struct FuncState *fs; /* current function (parser) */ - struct lua_State *L; - ZIO *z; /* input stream */ - Mbuffer *buff; /* buffer for tokens */ - struct Dyndata *dyd; /* dynamic structures used by the parser */ - TString *source; /* current source name */ - TString *envn; /* environment variable name */ - char decpoint; /* locale decimal point */ -} LexState; - - -LUAI_FUNC void luaX_init (lua_State *L); -LUAI_FUNC void luaX_setinput (lua_State *L, LexState *ls, ZIO *z, - TString *source, int firstchar); -LUAI_FUNC TString *luaX_newstring (LexState *ls, const char *str, size_t l); -LUAI_FUNC void luaX_next (LexState *ls); -LUAI_FUNC int luaX_lookahead (LexState *ls); -LUAI_FUNC l_noret luaX_syntaxerror (LexState *ls, const char *s); -LUAI_FUNC const char *luaX_token2str (LexState *ls, int token); - - -#endif diff --git a/btgui/lua-5.2.3/src/llimits.h b/btgui/lua-5.2.3/src/llimits.h deleted file mode 100644 index 152dd0551..000000000 --- a/btgui/lua-5.2.3/src/llimits.h +++ /dev/null @@ -1,309 +0,0 @@ -/* -** $Id: llimits.h,v 1.103.1.1 2013/04/12 18:48:47 roberto Exp $ -** Limits, basic types, and some other `installation-dependent' definitions -** See Copyright Notice in lua.h -*/ - -#ifndef llimits_h -#define llimits_h - - -#include -#include - - -#include "lua.h" - - -typedef unsigned LUA_INT32 lu_int32; - -typedef LUAI_UMEM lu_mem; - -typedef LUAI_MEM l_mem; - - - -/* chars used as small naturals (so that `char' is reserved for characters) */ -typedef unsigned char lu_byte; - - -#define MAX_SIZET ((size_t)(~(size_t)0)-2) - -#define MAX_LUMEM ((lu_mem)(~(lu_mem)0)-2) - -#define MAX_LMEM ((l_mem) ((MAX_LUMEM >> 1) - 2)) - - -#define MAX_INT (INT_MAX-2) /* maximum value of an int (-2 for safety) */ - -/* -** conversion of pointer to integer -** this is for hashing only; there is no problem if the integer -** cannot hold the whole pointer value -*/ -#define IntPoint(p) ((unsigned int)(lu_mem)(p)) - - - -/* type to ensure maximum alignment */ -#if !defined(LUAI_USER_ALIGNMENT_T) -#define LUAI_USER_ALIGNMENT_T union { double u; void *s; long l; } -#endif - -typedef LUAI_USER_ALIGNMENT_T L_Umaxalign; - - -/* result of a `usual argument conversion' over lua_Number */ -typedef LUAI_UACNUMBER l_uacNumber; - - -/* internal assertions for in-house debugging */ -#if defined(lua_assert) -#define check_exp(c,e) (lua_assert(c), (e)) -/* to avoid problems with conditions too long */ -#define lua_longassert(c) { if (!(c)) lua_assert(0); } -#else -#define lua_assert(c) ((void)0) -#define check_exp(c,e) (e) -#define lua_longassert(c) ((void)0) -#endif - -/* -** assertion for checking API calls -*/ -#if !defined(luai_apicheck) - -#if defined(LUA_USE_APICHECK) -#include -#define luai_apicheck(L,e) assert(e) -#else -#define luai_apicheck(L,e) lua_assert(e) -#endif - -#endif - -#define api_check(l,e,msg) luai_apicheck(l,(e) && msg) - - -#if !defined(UNUSED) -#define UNUSED(x) ((void)(x)) /* to avoid warnings */ -#endif - - -#define cast(t, exp) ((t)(exp)) - -#define cast_byte(i) cast(lu_byte, (i)) -#define cast_num(i) cast(lua_Number, (i)) -#define cast_int(i) cast(int, (i)) -#define cast_uchar(i) cast(unsigned char, (i)) - - -/* -** non-return type -*/ -#if defined(__GNUC__) -#define l_noret void __attribute__((noreturn)) -#elif defined(_MSC_VER) -#define l_noret void __declspec(noreturn) -#else -#define l_noret void -#endif - - - -/* -** maximum depth for nested C calls and syntactical nested non-terminals -** in a program. (Value must fit in an unsigned short int.) -*/ -#if !defined(LUAI_MAXCCALLS) -#define LUAI_MAXCCALLS 200 -#endif - -/* -** maximum number of upvalues in a closure (both C and Lua). (Value -** must fit in an unsigned char.) -*/ -#define MAXUPVAL UCHAR_MAX - - -/* -** type for virtual-machine instructions -** must be an unsigned with (at least) 4 bytes (see details in lopcodes.h) -*/ -typedef lu_int32 Instruction; - - - -/* maximum stack for a Lua function */ -#define MAXSTACK 250 - - - -/* minimum size for the string table (must be power of 2) */ -#if !defined(MINSTRTABSIZE) -#define MINSTRTABSIZE 32 -#endif - - -/* minimum size for string buffer */ -#if !defined(LUA_MINBUFFER) -#define LUA_MINBUFFER 32 -#endif - - -#if !defined(lua_lock) -#define lua_lock(L) ((void) 0) -#define lua_unlock(L) ((void) 0) -#endif - -#if !defined(luai_threadyield) -#define luai_threadyield(L) {lua_unlock(L); lua_lock(L);} -#endif - - -/* -** these macros allow user-specific actions on threads when you defined -** LUAI_EXTRASPACE and need to do something extra when a thread is -** created/deleted/resumed/yielded. -*/ -#if !defined(luai_userstateopen) -#define luai_userstateopen(L) ((void)L) -#endif - -#if !defined(luai_userstateclose) -#define luai_userstateclose(L) ((void)L) -#endif - -#if !defined(luai_userstatethread) -#define luai_userstatethread(L,L1) ((void)L) -#endif - -#if !defined(luai_userstatefree) -#define luai_userstatefree(L,L1) ((void)L) -#endif - -#if !defined(luai_userstateresume) -#define luai_userstateresume(L,n) ((void)L) -#endif - -#if !defined(luai_userstateyield) -#define luai_userstateyield(L,n) ((void)L) -#endif - -/* -** lua_number2int is a macro to convert lua_Number to int. -** lua_number2integer is a macro to convert lua_Number to lua_Integer. -** lua_number2unsigned is a macro to convert a lua_Number to a lua_Unsigned. -** lua_unsigned2number is a macro to convert a lua_Unsigned to a lua_Number. -** luai_hashnum is a macro to hash a lua_Number value into an integer. -** The hash must be deterministic and give reasonable values for -** both small and large values (outside the range of integers). -*/ - -#if defined(MS_ASMTRICK) || defined(LUA_MSASMTRICK) /* { */ -/* trick with Microsoft assembler for X86 */ - -#define lua_number2int(i,n) __asm {__asm fld n __asm fistp i} -#define lua_number2integer(i,n) lua_number2int(i, n) -#define lua_number2unsigned(i,n) \ - {__int64 l; __asm {__asm fld n __asm fistp l} i = (unsigned int)l;} - - -#elif defined(LUA_IEEE754TRICK) /* }{ */ -/* the next trick should work on any machine using IEEE754 with - a 32-bit int type */ - -union luai_Cast { double l_d; LUA_INT32 l_p[2]; }; - -#if !defined(LUA_IEEEENDIAN) /* { */ -#define LUAI_EXTRAIEEE \ - static const union luai_Cast ieeeendian = {-(33.0 + 6755399441055744.0)}; -#define LUA_IEEEENDIANLOC (ieeeendian.l_p[1] == 33) -#else -#define LUA_IEEEENDIANLOC LUA_IEEEENDIAN -#define LUAI_EXTRAIEEE /* empty */ -#endif /* } */ - -#define lua_number2int32(i,n,t) \ - { LUAI_EXTRAIEEE \ - volatile union luai_Cast u; u.l_d = (n) + 6755399441055744.0; \ - (i) = (t)u.l_p[LUA_IEEEENDIANLOC]; } - -#define luai_hashnum(i,n) \ - { volatile union luai_Cast u; u.l_d = (n) + 1.0; /* avoid -0 */ \ - (i) = u.l_p[0]; (i) += u.l_p[1]; } /* add double bits for his hash */ - -#define lua_number2int(i,n) lua_number2int32(i, n, int) -#define lua_number2unsigned(i,n) lua_number2int32(i, n, lua_Unsigned) - -/* the trick can be expanded to lua_Integer when it is a 32-bit value */ -#if defined(LUA_IEEELL) -#define lua_number2integer(i,n) lua_number2int32(i, n, lua_Integer) -#endif - -#endif /* } */ - - -/* the following definitions always work, but may be slow */ - -#if !defined(lua_number2int) -#define lua_number2int(i,n) ((i)=(int)(n)) -#endif - -#if !defined(lua_number2integer) -#define lua_number2integer(i,n) ((i)=(lua_Integer)(n)) -#endif - -#if !defined(lua_number2unsigned) /* { */ -/* the following definition assures proper modulo behavior */ -#if defined(LUA_NUMBER_DOUBLE) || defined(LUA_NUMBER_FLOAT) -#include -#define SUPUNSIGNED ((lua_Number)(~(lua_Unsigned)0) + 1) -#define lua_number2unsigned(i,n) \ - ((i)=(lua_Unsigned)((n) - floor((n)/SUPUNSIGNED)*SUPUNSIGNED)) -#else -#define lua_number2unsigned(i,n) ((i)=(lua_Unsigned)(n)) -#endif -#endif /* } */ - - -#if !defined(lua_unsigned2number) -/* on several machines, coercion from unsigned to double is slow, - so it may be worth to avoid */ -#define lua_unsigned2number(u) \ - (((u) <= (lua_Unsigned)INT_MAX) ? (lua_Number)(int)(u) : (lua_Number)(u)) -#endif - - - -#if defined(ltable_c) && !defined(luai_hashnum) - -#include -#include - -#define luai_hashnum(i,n) { int e; \ - n = l_mathop(frexp)(n, &e) * (lua_Number)(INT_MAX - DBL_MAX_EXP); \ - lua_number2int(i, n); i += e; } - -#endif - - - -/* -** macro to control inclusion of some hard tests on stack reallocation -*/ -#if !defined(HARDSTACKTESTS) -#define condmovestack(L) ((void)0) -#else -/* realloc stack keeping its size */ -#define condmovestack(L) luaD_reallocstack((L), (L)->stacksize) -#endif - -#if !defined(HARDMEMTESTS) -#define condchangemem(L) condmovestack(L) -#else -#define condchangemem(L) \ - ((void)(!(G(L)->gcrunning) || (luaC_fullgc(L, 0), 1))) -#endif - -#endif diff --git a/btgui/lua-5.2.3/src/lmathlib.c b/btgui/lua-5.2.3/src/lmathlib.c deleted file mode 100644 index fe9fc5423..000000000 --- a/btgui/lua-5.2.3/src/lmathlib.c +++ /dev/null @@ -1,279 +0,0 @@ -/* -** $Id: lmathlib.c,v 1.83.1.1 2013/04/12 18:48:47 roberto Exp $ -** Standard mathematical library -** See Copyright Notice in lua.h -*/ - - -#include -#include - -#define lmathlib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -#undef PI -#define PI ((lua_Number)(3.1415926535897932384626433832795)) -#define RADIANS_PER_DEGREE ((lua_Number)(PI/180.0)) - - - -static int math_abs (lua_State *L) { - lua_pushnumber(L, l_mathop(fabs)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_sin (lua_State *L) { - lua_pushnumber(L, l_mathop(sin)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_sinh (lua_State *L) { - lua_pushnumber(L, l_mathop(sinh)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_cos (lua_State *L) { - lua_pushnumber(L, l_mathop(cos)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_cosh (lua_State *L) { - lua_pushnumber(L, l_mathop(cosh)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_tan (lua_State *L) { - lua_pushnumber(L, l_mathop(tan)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_tanh (lua_State *L) { - lua_pushnumber(L, l_mathop(tanh)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_asin (lua_State *L) { - lua_pushnumber(L, l_mathop(asin)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_acos (lua_State *L) { - lua_pushnumber(L, l_mathop(acos)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_atan (lua_State *L) { - lua_pushnumber(L, l_mathop(atan)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_atan2 (lua_State *L) { - lua_pushnumber(L, l_mathop(atan2)(luaL_checknumber(L, 1), - luaL_checknumber(L, 2))); - return 1; -} - -static int math_ceil (lua_State *L) { - lua_pushnumber(L, l_mathop(ceil)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_floor (lua_State *L) { - lua_pushnumber(L, l_mathop(floor)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_fmod (lua_State *L) { - lua_pushnumber(L, l_mathop(fmod)(luaL_checknumber(L, 1), - luaL_checknumber(L, 2))); - return 1; -} - -static int math_modf (lua_State *L) { - lua_Number ip; - lua_Number fp = l_mathop(modf)(luaL_checknumber(L, 1), &ip); - lua_pushnumber(L, ip); - lua_pushnumber(L, fp); - return 2; -} - -static int math_sqrt (lua_State *L) { - lua_pushnumber(L, l_mathop(sqrt)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_pow (lua_State *L) { - lua_Number x = luaL_checknumber(L, 1); - lua_Number y = luaL_checknumber(L, 2); - lua_pushnumber(L, l_mathop(pow)(x, y)); - return 1; -} - -static int math_log (lua_State *L) { - lua_Number x = luaL_checknumber(L, 1); - lua_Number res; - if (lua_isnoneornil(L, 2)) - res = l_mathop(log)(x); - else { - lua_Number base = luaL_checknumber(L, 2); - if (base == (lua_Number)10.0) res = l_mathop(log10)(x); - else res = l_mathop(log)(x)/l_mathop(log)(base); - } - lua_pushnumber(L, res); - return 1; -} - -#if defined(LUA_COMPAT_LOG10) -static int math_log10 (lua_State *L) { - lua_pushnumber(L, l_mathop(log10)(luaL_checknumber(L, 1))); - return 1; -} -#endif - -static int math_exp (lua_State *L) { - lua_pushnumber(L, l_mathop(exp)(luaL_checknumber(L, 1))); - return 1; -} - -static int math_deg (lua_State *L) { - lua_pushnumber(L, luaL_checknumber(L, 1)/RADIANS_PER_DEGREE); - return 1; -} - -static int math_rad (lua_State *L) { - lua_pushnumber(L, luaL_checknumber(L, 1)*RADIANS_PER_DEGREE); - return 1; -} - -static int math_frexp (lua_State *L) { - int e; - lua_pushnumber(L, l_mathop(frexp)(luaL_checknumber(L, 1), &e)); - lua_pushinteger(L, e); - return 2; -} - -static int math_ldexp (lua_State *L) { - lua_Number x = luaL_checknumber(L, 1); - int ep = luaL_checkint(L, 2); - lua_pushnumber(L, l_mathop(ldexp)(x, ep)); - return 1; -} - - - -static int math_min (lua_State *L) { - int n = lua_gettop(L); /* number of arguments */ - lua_Number dmin = luaL_checknumber(L, 1); - int i; - for (i=2; i<=n; i++) { - lua_Number d = luaL_checknumber(L, i); - if (d < dmin) - dmin = d; - } - lua_pushnumber(L, dmin); - return 1; -} - - -static int math_max (lua_State *L) { - int n = lua_gettop(L); /* number of arguments */ - lua_Number dmax = luaL_checknumber(L, 1); - int i; - for (i=2; i<=n; i++) { - lua_Number d = luaL_checknumber(L, i); - if (d > dmax) - dmax = d; - } - lua_pushnumber(L, dmax); - return 1; -} - - -static int math_random (lua_State *L) { - /* the `%' avoids the (rare) case of r==1, and is needed also because on - some systems (SunOS!) `rand()' may return a value larger than RAND_MAX */ - lua_Number r = (lua_Number)(rand()%RAND_MAX) / (lua_Number)RAND_MAX; - switch (lua_gettop(L)) { /* check number of arguments */ - case 0: { /* no arguments */ - lua_pushnumber(L, r); /* Number between 0 and 1 */ - break; - } - case 1: { /* only upper limit */ - lua_Number u = luaL_checknumber(L, 1); - luaL_argcheck(L, (lua_Number)1.0 <= u, 1, "interval is empty"); - lua_pushnumber(L, l_mathop(floor)(r*u) + (lua_Number)(1.0)); /* [1, u] */ - break; - } - case 2: { /* lower and upper limits */ - lua_Number l = luaL_checknumber(L, 1); - lua_Number u = luaL_checknumber(L, 2); - luaL_argcheck(L, l <= u, 2, "interval is empty"); - lua_pushnumber(L, l_mathop(floor)(r*(u-l+1)) + l); /* [l, u] */ - break; - } - default: return luaL_error(L, "wrong number of arguments"); - } - return 1; -} - - -static int math_randomseed (lua_State *L) { - srand(luaL_checkunsigned(L, 1)); - (void)rand(); /* discard first value to avoid undesirable correlations */ - return 0; -} - - -static const luaL_Reg mathlib[] = { - {"abs", math_abs}, - {"acos", math_acos}, - {"asin", math_asin}, - {"atan2", math_atan2}, - {"atan", math_atan}, - {"ceil", math_ceil}, - {"cosh", math_cosh}, - {"cos", math_cos}, - {"deg", math_deg}, - {"exp", math_exp}, - {"floor", math_floor}, - {"fmod", math_fmod}, - {"frexp", math_frexp}, - {"ldexp", math_ldexp}, -#if defined(LUA_COMPAT_LOG10) - {"log10", math_log10}, -#endif - {"log", math_log}, - {"max", math_max}, - {"min", math_min}, - {"modf", math_modf}, - {"pow", math_pow}, - {"rad", math_rad}, - {"random", math_random}, - {"randomseed", math_randomseed}, - {"sinh", math_sinh}, - {"sin", math_sin}, - {"sqrt", math_sqrt}, - {"tanh", math_tanh}, - {"tan", math_tan}, - {NULL, NULL} -}; - - -/* -** Open math library -*/ -LUAMOD_API int luaopen_math (lua_State *L) { - luaL_newlib(L, mathlib); - lua_pushnumber(L, PI); - lua_setfield(L, -2, "pi"); - lua_pushnumber(L, HUGE_VAL); - lua_setfield(L, -2, "huge"); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/lmem.c b/btgui/lua-5.2.3/src/lmem.c deleted file mode 100644 index ee343e3e0..000000000 --- a/btgui/lua-5.2.3/src/lmem.c +++ /dev/null @@ -1,99 +0,0 @@ -/* -** $Id: lmem.c,v 1.84.1.1 2013/04/12 18:48:47 roberto Exp $ -** Interface to Memory Manager -** See Copyright Notice in lua.h -*/ - - -#include - -#define lmem_c -#define LUA_CORE - -#include "lua.h" - -#include "ldebug.h" -#include "ldo.h" -#include "lgc.h" -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" - - - -/* -** About the realloc function: -** void * frealloc (void *ud, void *ptr, size_t osize, size_t nsize); -** (`osize' is the old size, `nsize' is the new size) -** -** * frealloc(ud, NULL, x, s) creates a new block of size `s' (no -** matter 'x'). -** -** * frealloc(ud, p, x, 0) frees the block `p' -** (in this specific case, frealloc must return NULL); -** particularly, frealloc(ud, NULL, 0, 0) does nothing -** (which is equivalent to free(NULL) in ANSI C) -** -** frealloc returns NULL if it cannot create or reallocate the area -** (any reallocation to an equal or smaller size cannot fail!) -*/ - - - -#define MINSIZEARRAY 4 - - -void *luaM_growaux_ (lua_State *L, void *block, int *size, size_t size_elems, - int limit, const char *what) { - void *newblock; - int newsize; - if (*size >= limit/2) { /* cannot double it? */ - if (*size >= limit) /* cannot grow even a little? */ - luaG_runerror(L, "too many %s (limit is %d)", what, limit); - newsize = limit; /* still have at least one free place */ - } - else { - newsize = (*size)*2; - if (newsize < MINSIZEARRAY) - newsize = MINSIZEARRAY; /* minimum size */ - } - newblock = luaM_reallocv(L, block, *size, newsize, size_elems); - *size = newsize; /* update only when everything else is OK */ - return newblock; -} - - -l_noret luaM_toobig (lua_State *L) { - luaG_runerror(L, "memory allocation error: block too big"); -} - - - -/* -** generic allocation routine. -*/ -void *luaM_realloc_ (lua_State *L, void *block, size_t osize, size_t nsize) { - void *newblock; - global_State *g = G(L); - size_t realosize = (block) ? osize : 0; - lua_assert((realosize == 0) == (block == NULL)); -#if defined(HARDMEMTESTS) - if (nsize > realosize && g->gcrunning) - luaC_fullgc(L, 1); /* force a GC whenever possible */ -#endif - newblock = (*g->frealloc)(g->ud, block, osize, nsize); - if (newblock == NULL && nsize > 0) { - api_check(L, nsize > realosize, - "realloc cannot fail when shrinking a block"); - if (g->gcrunning) { - luaC_fullgc(L, 1); /* try to free some memory... */ - newblock = (*g->frealloc)(g->ud, block, osize, nsize); /* try again */ - } - if (newblock == NULL) - luaD_throw(L, LUA_ERRMEM); - } - lua_assert((nsize == 0) == (newblock == NULL)); - g->GCdebt = (g->GCdebt + nsize) - realosize; - return newblock; -} - diff --git a/btgui/lua-5.2.3/src/lmem.h b/btgui/lua-5.2.3/src/lmem.h deleted file mode 100644 index bd4f4e072..000000000 --- a/btgui/lua-5.2.3/src/lmem.h +++ /dev/null @@ -1,57 +0,0 @@ -/* -** $Id: lmem.h,v 1.40.1.1 2013/04/12 18:48:47 roberto Exp $ -** Interface to Memory Manager -** See Copyright Notice in lua.h -*/ - -#ifndef lmem_h -#define lmem_h - - -#include - -#include "llimits.h" -#include "lua.h" - - -/* -** This macro avoids the runtime division MAX_SIZET/(e), as 'e' is -** always constant. -** The macro is somewhat complex to avoid warnings: -** +1 avoids warnings of "comparison has constant result"; -** cast to 'void' avoids warnings of "value unused". -*/ -#define luaM_reallocv(L,b,on,n,e) \ - (cast(void, \ - (cast(size_t, (n)+1) > MAX_SIZET/(e)) ? (luaM_toobig(L), 0) : 0), \ - luaM_realloc_(L, (b), (on)*(e), (n)*(e))) - -#define luaM_freemem(L, b, s) luaM_realloc_(L, (b), (s), 0) -#define luaM_free(L, b) luaM_realloc_(L, (b), sizeof(*(b)), 0) -#define luaM_freearray(L, b, n) luaM_reallocv(L, (b), n, 0, sizeof((b)[0])) - -#define luaM_malloc(L,s) luaM_realloc_(L, NULL, 0, (s)) -#define luaM_new(L,t) cast(t *, luaM_malloc(L, sizeof(t))) -#define luaM_newvector(L,n,t) \ - cast(t *, luaM_reallocv(L, NULL, 0, n, sizeof(t))) - -#define luaM_newobject(L,tag,s) luaM_realloc_(L, NULL, tag, (s)) - -#define luaM_growvector(L,v,nelems,size,t,limit,e) \ - if ((nelems)+1 > (size)) \ - ((v)=cast(t *, luaM_growaux_(L,v,&(size),sizeof(t),limit,e))) - -#define luaM_reallocvector(L, v,oldn,n,t) \ - ((v)=cast(t *, luaM_reallocv(L, v, oldn, n, sizeof(t)))) - -LUAI_FUNC l_noret luaM_toobig (lua_State *L); - -/* not to be called directly */ -LUAI_FUNC void *luaM_realloc_ (lua_State *L, void *block, size_t oldsize, - size_t size); -LUAI_FUNC void *luaM_growaux_ (lua_State *L, void *block, int *size, - size_t size_elem, int limit, - const char *what); - -#endif - diff --git a/btgui/lua-5.2.3/src/loadlib.c b/btgui/lua-5.2.3/src/loadlib.c deleted file mode 100644 index 9318a9980..000000000 --- a/btgui/lua-5.2.3/src/loadlib.c +++ /dev/null @@ -1,726 +0,0 @@ -/* -** $Id: loadlib.c,v 1.111.1.1 2013/04/12 18:48:47 roberto Exp $ -** Dynamic library loader for Lua -** See Copyright Notice in lua.h -** -** This module contains an implementation of loadlib for Unix systems -** that have dlfcn, an implementation for Windows, and a stub for other -** systems. -*/ - - -/* -** if needed, includes windows header before everything else -*/ -#if defined(_WIN32) -#include -#endif - - -#include -#include - - -#define loadlib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -/* -** LUA_PATH and LUA_CPATH are the names of the environment -** variables that Lua check to set its paths. -*/ -#if !defined(LUA_PATH) -#define LUA_PATH "LUA_PATH" -#endif - -#if !defined(LUA_CPATH) -#define LUA_CPATH "LUA_CPATH" -#endif - -#define LUA_PATHSUFFIX "_" LUA_VERSION_MAJOR "_" LUA_VERSION_MINOR - -#define LUA_PATHVERSION LUA_PATH LUA_PATHSUFFIX -#define LUA_CPATHVERSION LUA_CPATH LUA_PATHSUFFIX - -/* -** LUA_PATH_SEP is the character that separates templates in a path. -** LUA_PATH_MARK is the string that marks the substitution points in a -** template. -** LUA_EXEC_DIR in a Windows path is replaced by the executable's -** directory. -** LUA_IGMARK is a mark to ignore all before it when building the -** luaopen_ function name. -*/ -#if !defined (LUA_PATH_SEP) -#define LUA_PATH_SEP ";" -#endif -#if !defined (LUA_PATH_MARK) -#define LUA_PATH_MARK "?" -#endif -#if !defined (LUA_EXEC_DIR) -#define LUA_EXEC_DIR "!" -#endif -#if !defined (LUA_IGMARK) -#define LUA_IGMARK "-" -#endif - - -/* -** LUA_CSUBSEP is the character that replaces dots in submodule names -** when searching for a C loader. -** LUA_LSUBSEP is the character that replaces dots in submodule names -** when searching for a Lua loader. -*/ -#if !defined(LUA_CSUBSEP) -#define LUA_CSUBSEP LUA_DIRSEP -#endif - -#if !defined(LUA_LSUBSEP) -#define LUA_LSUBSEP LUA_DIRSEP -#endif - - -/* prefix for open functions in C libraries */ -#define LUA_POF "luaopen_" - -/* separator for open functions in C libraries */ -#define LUA_OFSEP "_" - - -/* table (in the registry) that keeps handles for all loaded C libraries */ -#define CLIBS "_CLIBS" - -#define LIB_FAIL "open" - - -/* error codes for ll_loadfunc */ -#define ERRLIB 1 -#define ERRFUNC 2 - -#define setprogdir(L) ((void)0) - - -/* -** system-dependent functions -*/ -static void ll_unloadlib (void *lib); -static void *ll_load (lua_State *L, const char *path, int seeglb); -static lua_CFunction ll_sym (lua_State *L, void *lib, const char *sym); - - - -#if defined(LUA_USE_DLOPEN) - -/* -** {======================================================================== -** This is an implementation of loadlib based on the dlfcn interface. -** The dlfcn interface is available in Linux, SunOS, Solaris, IRIX, FreeBSD, -** NetBSD, AIX 4.2, HPUX 11, and probably most other Unix flavors, at least -** as an emulation layer on top of native functions. -** ========================================================================= -*/ - -#include - -static void ll_unloadlib (void *lib) { - dlclose(lib); -} - - -static void *ll_load (lua_State *L, const char *path, int seeglb) { - void *lib = dlopen(path, RTLD_NOW | (seeglb ? RTLD_GLOBAL : RTLD_LOCAL)); - if (lib == NULL) lua_pushstring(L, dlerror()); - return lib; -} - - -static lua_CFunction ll_sym (lua_State *L, void *lib, const char *sym) { - lua_CFunction f = (lua_CFunction)dlsym(lib, sym); - if (f == NULL) lua_pushstring(L, dlerror()); - return f; -} - -/* }====================================================== */ - - - -#elif defined(LUA_DL_DLL) -/* -** {====================================================================== -** This is an implementation of loadlib for Windows using native functions. -** ======================================================================= -*/ - -#undef setprogdir - -/* -** optional flags for LoadLibraryEx -*/ -#if !defined(LUA_LLE_FLAGS) -#define LUA_LLE_FLAGS 0 -#endif - - -static void setprogdir (lua_State *L) { - char buff[MAX_PATH + 1]; - char *lb; - DWORD nsize = sizeof(buff)/sizeof(char); - DWORD n = GetModuleFileNameA(NULL, buff, nsize); - if (n == 0 || n == nsize || (lb = strrchr(buff, '\\')) == NULL) - luaL_error(L, "unable to get ModuleFileName"); - else { - *lb = '\0'; - luaL_gsub(L, lua_tostring(L, -1), LUA_EXEC_DIR, buff); - lua_remove(L, -2); /* remove original string */ - } -} - - -static void pusherror (lua_State *L) { - int error = GetLastError(); - char buffer[128]; - if (FormatMessageA(FORMAT_MESSAGE_IGNORE_INSERTS | FORMAT_MESSAGE_FROM_SYSTEM, - NULL, error, 0, buffer, sizeof(buffer)/sizeof(char), NULL)) - lua_pushstring(L, buffer); - else - lua_pushfstring(L, "system error %d\n", error); -} - -static void ll_unloadlib (void *lib) { - FreeLibrary((HMODULE)lib); -} - - -static void *ll_load (lua_State *L, const char *path, int seeglb) { - HMODULE lib = LoadLibraryExA(path, NULL, LUA_LLE_FLAGS); - (void)(seeglb); /* not used: symbols are 'global' by default */ - if (lib == NULL) pusherror(L); - return lib; -} - - -static lua_CFunction ll_sym (lua_State *L, void *lib, const char *sym) { - lua_CFunction f = (lua_CFunction)GetProcAddress((HMODULE)lib, sym); - if (f == NULL) pusherror(L); - return f; -} - -/* }====================================================== */ - - -#else -/* -** {====================================================== -** Fallback for other systems -** ======================================================= -*/ - -#undef LIB_FAIL -#define LIB_FAIL "absent" - - -#define DLMSG "dynamic libraries not enabled; check your Lua installation" - - -static void ll_unloadlib (void *lib) { - (void)(lib); /* not used */ -} - - -static void *ll_load (lua_State *L, const char *path, int seeglb) { - (void)(path); (void)(seeglb); /* not used */ - lua_pushliteral(L, DLMSG); - return NULL; -} - - -static lua_CFunction ll_sym (lua_State *L, void *lib, const char *sym) { - (void)(lib); (void)(sym); /* not used */ - lua_pushliteral(L, DLMSG); - return NULL; -} - -/* }====================================================== */ -#endif - - -static void *ll_checkclib (lua_State *L, const char *path) { - void *plib; - lua_getfield(L, LUA_REGISTRYINDEX, CLIBS); - lua_getfield(L, -1, path); - plib = lua_touserdata(L, -1); /* plib = CLIBS[path] */ - lua_pop(L, 2); /* pop CLIBS table and 'plib' */ - return plib; -} - - -static void ll_addtoclib (lua_State *L, const char *path, void *plib) { - lua_getfield(L, LUA_REGISTRYINDEX, CLIBS); - lua_pushlightuserdata(L, plib); - lua_pushvalue(L, -1); - lua_setfield(L, -3, path); /* CLIBS[path] = plib */ - lua_rawseti(L, -2, luaL_len(L, -2) + 1); /* CLIBS[#CLIBS + 1] = plib */ - lua_pop(L, 1); /* pop CLIBS table */ -} - - -/* -** __gc tag method for CLIBS table: calls 'll_unloadlib' for all lib -** handles in list CLIBS -*/ -static int gctm (lua_State *L) { - int n = luaL_len(L, 1); - for (; n >= 1; n--) { /* for each handle, in reverse order */ - lua_rawgeti(L, 1, n); /* get handle CLIBS[n] */ - ll_unloadlib(lua_touserdata(L, -1)); - lua_pop(L, 1); /* pop handle */ - } - return 0; -} - - -static int ll_loadfunc (lua_State *L, const char *path, const char *sym) { - void *reg = ll_checkclib(L, path); /* check loaded C libraries */ - if (reg == NULL) { /* must load library? */ - reg = ll_load(L, path, *sym == '*'); - if (reg == NULL) return ERRLIB; /* unable to load library */ - ll_addtoclib(L, path, reg); - } - if (*sym == '*') { /* loading only library (no function)? */ - lua_pushboolean(L, 1); /* return 'true' */ - return 0; /* no errors */ - } - else { - lua_CFunction f = ll_sym(L, reg, sym); - if (f == NULL) - return ERRFUNC; /* unable to find function */ - lua_pushcfunction(L, f); /* else create new function */ - return 0; /* no errors */ - } -} - - -static int ll_loadlib (lua_State *L) { - const char *path = luaL_checkstring(L, 1); - const char *init = luaL_checkstring(L, 2); - int stat = ll_loadfunc(L, path, init); - if (stat == 0) /* no errors? */ - return 1; /* return the loaded function */ - else { /* error; error message is on stack top */ - lua_pushnil(L); - lua_insert(L, -2); - lua_pushstring(L, (stat == ERRLIB) ? LIB_FAIL : "init"); - return 3; /* return nil, error message, and where */ - } -} - - - -/* -** {====================================================== -** 'require' function -** ======================================================= -*/ - - -static int readable (const char *filename) { - FILE *f = fopen(filename, "r"); /* try to open file */ - if (f == NULL) return 0; /* open failed */ - fclose(f); - return 1; -} - - -static const char *pushnexttemplate (lua_State *L, const char *path) { - const char *l; - while (*path == *LUA_PATH_SEP) path++; /* skip separators */ - if (*path == '\0') return NULL; /* no more templates */ - l = strchr(path, *LUA_PATH_SEP); /* find next separator */ - if (l == NULL) l = path + strlen(path); - lua_pushlstring(L, path, l - path); /* template */ - return l; -} - - -static const char *searchpath (lua_State *L, const char *name, - const char *path, - const char *sep, - const char *dirsep) { - luaL_Buffer msg; /* to build error message */ - luaL_buffinit(L, &msg); - if (*sep != '\0') /* non-empty separator? */ - name = luaL_gsub(L, name, sep, dirsep); /* replace it by 'dirsep' */ - while ((path = pushnexttemplate(L, path)) != NULL) { - const char *filename = luaL_gsub(L, lua_tostring(L, -1), - LUA_PATH_MARK, name); - lua_remove(L, -2); /* remove path template */ - if (readable(filename)) /* does file exist and is readable? */ - return filename; /* return that file name */ - lua_pushfstring(L, "\n\tno file " LUA_QS, filename); - lua_remove(L, -2); /* remove file name */ - luaL_addvalue(&msg); /* concatenate error msg. entry */ - } - luaL_pushresult(&msg); /* create error message */ - return NULL; /* not found */ -} - - -static int ll_searchpath (lua_State *L) { - const char *f = searchpath(L, luaL_checkstring(L, 1), - luaL_checkstring(L, 2), - luaL_optstring(L, 3, "."), - luaL_optstring(L, 4, LUA_DIRSEP)); - if (f != NULL) return 1; - else { /* error message is on top of the stack */ - lua_pushnil(L); - lua_insert(L, -2); - return 2; /* return nil + error message */ - } -} - - -static const char *findfile (lua_State *L, const char *name, - const char *pname, - const char *dirsep) { - const char *path; - lua_getfield(L, lua_upvalueindex(1), pname); - path = lua_tostring(L, -1); - if (path == NULL) - luaL_error(L, LUA_QL("package.%s") " must be a string", pname); - return searchpath(L, name, path, ".", dirsep); -} - - -static int checkload (lua_State *L, int stat, const char *filename) { - if (stat) { /* module loaded successfully? */ - lua_pushstring(L, filename); /* will be 2nd argument to module */ - return 2; /* return open function and file name */ - } - else - return luaL_error(L, "error loading module " LUA_QS - " from file " LUA_QS ":\n\t%s", - lua_tostring(L, 1), filename, lua_tostring(L, -1)); -} - - -static int searcher_Lua (lua_State *L) { - const char *filename; - const char *name = luaL_checkstring(L, 1); - filename = findfile(L, name, "path", LUA_LSUBSEP); - if (filename == NULL) return 1; /* module not found in this path */ - return checkload(L, (luaL_loadfile(L, filename) == LUA_OK), filename); -} - - -static int loadfunc (lua_State *L, const char *filename, const char *modname) { - const char *funcname; - const char *mark; - modname = luaL_gsub(L, modname, ".", LUA_OFSEP); - mark = strchr(modname, *LUA_IGMARK); - if (mark) { - int stat; - funcname = lua_pushlstring(L, modname, mark - modname); - funcname = lua_pushfstring(L, LUA_POF"%s", funcname); - stat = ll_loadfunc(L, filename, funcname); - if (stat != ERRFUNC) return stat; - modname = mark + 1; /* else go ahead and try old-style name */ - } - funcname = lua_pushfstring(L, LUA_POF"%s", modname); - return ll_loadfunc(L, filename, funcname); -} - - -static int searcher_C (lua_State *L) { - const char *name = luaL_checkstring(L, 1); - const char *filename = findfile(L, name, "cpath", LUA_CSUBSEP); - if (filename == NULL) return 1; /* module not found in this path */ - return checkload(L, (loadfunc(L, filename, name) == 0), filename); -} - - -static int searcher_Croot (lua_State *L) { - const char *filename; - const char *name = luaL_checkstring(L, 1); - const char *p = strchr(name, '.'); - int stat; - if (p == NULL) return 0; /* is root */ - lua_pushlstring(L, name, p - name); - filename = findfile(L, lua_tostring(L, -1), "cpath", LUA_CSUBSEP); - if (filename == NULL) return 1; /* root not found */ - if ((stat = loadfunc(L, filename, name)) != 0) { - if (stat != ERRFUNC) - return checkload(L, 0, filename); /* real error */ - else { /* open function not found */ - lua_pushfstring(L, "\n\tno module " LUA_QS " in file " LUA_QS, - name, filename); - return 1; - } - } - lua_pushstring(L, filename); /* will be 2nd argument to module */ - return 2; -} - - -static int searcher_preload (lua_State *L) { - const char *name = luaL_checkstring(L, 1); - lua_getfield(L, LUA_REGISTRYINDEX, "_PRELOAD"); - lua_getfield(L, -1, name); - if (lua_isnil(L, -1)) /* not found? */ - lua_pushfstring(L, "\n\tno field package.preload['%s']", name); - return 1; -} - - -static void findloader (lua_State *L, const char *name) { - int i; - luaL_Buffer msg; /* to build error message */ - luaL_buffinit(L, &msg); - lua_getfield(L, lua_upvalueindex(1), "searchers"); /* will be at index 3 */ - if (!lua_istable(L, 3)) - luaL_error(L, LUA_QL("package.searchers") " must be a table"); - /* iterate over available searchers to find a loader */ - for (i = 1; ; i++) { - lua_rawgeti(L, 3, i); /* get a searcher */ - if (lua_isnil(L, -1)) { /* no more searchers? */ - lua_pop(L, 1); /* remove nil */ - luaL_pushresult(&msg); /* create error message */ - luaL_error(L, "module " LUA_QS " not found:%s", - name, lua_tostring(L, -1)); - } - lua_pushstring(L, name); - lua_call(L, 1, 2); /* call it */ - if (lua_isfunction(L, -2)) /* did it find a loader? */ - return; /* module loader found */ - else if (lua_isstring(L, -2)) { /* searcher returned error message? */ - lua_pop(L, 1); /* remove extra return */ - luaL_addvalue(&msg); /* concatenate error message */ - } - else - lua_pop(L, 2); /* remove both returns */ - } -} - - -static int ll_require (lua_State *L) { - const char *name = luaL_checkstring(L, 1); - lua_settop(L, 1); /* _LOADED table will be at index 2 */ - lua_getfield(L, LUA_REGISTRYINDEX, "_LOADED"); - lua_getfield(L, 2, name); /* _LOADED[name] */ - if (lua_toboolean(L, -1)) /* is it there? */ - return 1; /* package is already loaded */ - /* else must load package */ - lua_pop(L, 1); /* remove 'getfield' result */ - findloader(L, name); - lua_pushstring(L, name); /* pass name as argument to module loader */ - lua_insert(L, -2); /* name is 1st argument (before search data) */ - lua_call(L, 2, 1); /* run loader to load module */ - if (!lua_isnil(L, -1)) /* non-nil return? */ - lua_setfield(L, 2, name); /* _LOADED[name] = returned value */ - lua_getfield(L, 2, name); - if (lua_isnil(L, -1)) { /* module did not set a value? */ - lua_pushboolean(L, 1); /* use true as result */ - lua_pushvalue(L, -1); /* extra copy to be returned */ - lua_setfield(L, 2, name); /* _LOADED[name] = true */ - } - return 1; -} - -/* }====================================================== */ - - - -/* -** {====================================================== -** 'module' function -** ======================================================= -*/ -#if defined(LUA_COMPAT_MODULE) - -/* -** changes the environment variable of calling function -*/ -static void set_env (lua_State *L) { - lua_Debug ar; - if (lua_getstack(L, 1, &ar) == 0 || - lua_getinfo(L, "f", &ar) == 0 || /* get calling function */ - lua_iscfunction(L, -1)) - luaL_error(L, LUA_QL("module") " not called from a Lua function"); - lua_pushvalue(L, -2); /* copy new environment table to top */ - lua_setupvalue(L, -2, 1); - lua_pop(L, 1); /* remove function */ -} - - -static void dooptions (lua_State *L, int n) { - int i; - for (i = 2; i <= n; i++) { - if (lua_isfunction(L, i)) { /* avoid 'calling' extra info. */ - lua_pushvalue(L, i); /* get option (a function) */ - lua_pushvalue(L, -2); /* module */ - lua_call(L, 1, 0); - } - } -} - - -static void modinit (lua_State *L, const char *modname) { - const char *dot; - lua_pushvalue(L, -1); - lua_setfield(L, -2, "_M"); /* module._M = module */ - lua_pushstring(L, modname); - lua_setfield(L, -2, "_NAME"); - dot = strrchr(modname, '.'); /* look for last dot in module name */ - if (dot == NULL) dot = modname; - else dot++; - /* set _PACKAGE as package name (full module name minus last part) */ - lua_pushlstring(L, modname, dot - modname); - lua_setfield(L, -2, "_PACKAGE"); -} - - -static int ll_module (lua_State *L) { - const char *modname = luaL_checkstring(L, 1); - int lastarg = lua_gettop(L); /* last parameter */ - luaL_pushmodule(L, modname, 1); /* get/create module table */ - /* check whether table already has a _NAME field */ - lua_getfield(L, -1, "_NAME"); - if (!lua_isnil(L, -1)) /* is table an initialized module? */ - lua_pop(L, 1); - else { /* no; initialize it */ - lua_pop(L, 1); - modinit(L, modname); - } - lua_pushvalue(L, -1); - set_env(L); - dooptions(L, lastarg); - return 1; -} - - -static int ll_seeall (lua_State *L) { - luaL_checktype(L, 1, LUA_TTABLE); - if (!lua_getmetatable(L, 1)) { - lua_createtable(L, 0, 1); /* create new metatable */ - lua_pushvalue(L, -1); - lua_setmetatable(L, 1); - } - lua_pushglobaltable(L); - lua_setfield(L, -2, "__index"); /* mt.__index = _G */ - return 0; -} - -#endif -/* }====================================================== */ - - - -/* auxiliary mark (for internal use) */ -#define AUXMARK "\1" - - -/* -** return registry.LUA_NOENV as a boolean -*/ -static int noenv (lua_State *L) { - int b; - lua_getfield(L, LUA_REGISTRYINDEX, "LUA_NOENV"); - b = lua_toboolean(L, -1); - lua_pop(L, 1); /* remove value */ - return b; -} - - -static void setpath (lua_State *L, const char *fieldname, const char *envname1, - const char *envname2, const char *def) { - const char *path = getenv(envname1); - if (path == NULL) /* no environment variable? */ - path = getenv(envname2); /* try alternative name */ - if (path == NULL || noenv(L)) /* no environment variable? */ - lua_pushstring(L, def); /* use default */ - else { - /* replace ";;" by ";AUXMARK;" and then AUXMARK by default path */ - path = luaL_gsub(L, path, LUA_PATH_SEP LUA_PATH_SEP, - LUA_PATH_SEP AUXMARK LUA_PATH_SEP); - luaL_gsub(L, path, AUXMARK, def); - lua_remove(L, -2); - } - setprogdir(L); - lua_setfield(L, -2, fieldname); -} - - -static const luaL_Reg pk_funcs[] = { - {"loadlib", ll_loadlib}, - {"searchpath", ll_searchpath}, -#if defined(LUA_COMPAT_MODULE) - {"seeall", ll_seeall}, -#endif - {NULL, NULL} -}; - - -static const luaL_Reg ll_funcs[] = { -#if defined(LUA_COMPAT_MODULE) - {"module", ll_module}, -#endif - {"require", ll_require}, - {NULL, NULL} -}; - - -static void createsearcherstable (lua_State *L) { - static const lua_CFunction searchers[] = - {searcher_preload, searcher_Lua, searcher_C, searcher_Croot, NULL}; - int i; - /* create 'searchers' table */ - lua_createtable(L, sizeof(searchers)/sizeof(searchers[0]) - 1, 0); - /* fill it with pre-defined searchers */ - for (i=0; searchers[i] != NULL; i++) { - lua_pushvalue(L, -2); /* set 'package' as upvalue for all searchers */ - lua_pushcclosure(L, searchers[i], 1); - lua_rawseti(L, -2, i+1); - } -} - - -LUAMOD_API int luaopen_package (lua_State *L) { - /* create table CLIBS to keep track of loaded C libraries */ - luaL_getsubtable(L, LUA_REGISTRYINDEX, CLIBS); - lua_createtable(L, 0, 1); /* metatable for CLIBS */ - lua_pushcfunction(L, gctm); - lua_setfield(L, -2, "__gc"); /* set finalizer for CLIBS table */ - lua_setmetatable(L, -2); - /* create `package' table */ - luaL_newlib(L, pk_funcs); - createsearcherstable(L); -#if defined(LUA_COMPAT_LOADERS) - lua_pushvalue(L, -1); /* make a copy of 'searchers' table */ - lua_setfield(L, -3, "loaders"); /* put it in field `loaders' */ -#endif - lua_setfield(L, -2, "searchers"); /* put it in field 'searchers' */ - /* set field 'path' */ - setpath(L, "path", LUA_PATHVERSION, LUA_PATH, LUA_PATH_DEFAULT); - /* set field 'cpath' */ - setpath(L, "cpath", LUA_CPATHVERSION, LUA_CPATH, LUA_CPATH_DEFAULT); - /* store config information */ - lua_pushliteral(L, LUA_DIRSEP "\n" LUA_PATH_SEP "\n" LUA_PATH_MARK "\n" - LUA_EXEC_DIR "\n" LUA_IGMARK "\n"); - lua_setfield(L, -2, "config"); - /* set field `loaded' */ - luaL_getsubtable(L, LUA_REGISTRYINDEX, "_LOADED"); - lua_setfield(L, -2, "loaded"); - /* set field `preload' */ - luaL_getsubtable(L, LUA_REGISTRYINDEX, "_PRELOAD"); - lua_setfield(L, -2, "preload"); - lua_pushglobaltable(L); - lua_pushvalue(L, -2); /* set 'package' as upvalue for next lib */ - luaL_setfuncs(L, ll_funcs, 1); /* open lib into global table */ - lua_pop(L, 1); /* pop global table */ - return 1; /* return 'package' table */ -} - diff --git a/btgui/lua-5.2.3/src/lobject.c b/btgui/lua-5.2.3/src/lobject.c deleted file mode 100644 index 882d994d4..000000000 --- a/btgui/lua-5.2.3/src/lobject.c +++ /dev/null @@ -1,287 +0,0 @@ -/* -** $Id: lobject.c,v 2.58.1.1 2013/04/12 18:48:47 roberto Exp $ -** Some generic functions over Lua objects -** See Copyright Notice in lua.h -*/ - -#include -#include -#include -#include - -#define lobject_c -#define LUA_CORE - -#include "lua.h" - -#include "lctype.h" -#include "ldebug.h" -#include "ldo.h" -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" -#include "lstring.h" -#include "lvm.h" - - - -LUAI_DDEF const TValue luaO_nilobject_ = {NILCONSTANT}; - - -/* -** converts an integer to a "floating point byte", represented as -** (eeeeexxx), where the real value is (1xxx) * 2^(eeeee - 1) if -** eeeee != 0 and (xxx) otherwise. -*/ -int luaO_int2fb (unsigned int x) { - int e = 0; /* exponent */ - if (x < 8) return x; - while (x >= 0x10) { - x = (x+1) >> 1; - e++; - } - return ((e+1) << 3) | (cast_int(x) - 8); -} - - -/* converts back */ -int luaO_fb2int (int x) { - int e = (x >> 3) & 0x1f; - if (e == 0) return x; - else return ((x & 7) + 8) << (e - 1); -} - - -int luaO_ceillog2 (unsigned int x) { - static const lu_byte log_2[256] = { - 0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5, - 6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6, - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8 - }; - int l = 0; - x--; - while (x >= 256) { l += 8; x >>= 8; } - return l + log_2[x]; -} - - -lua_Number luaO_arith (int op, lua_Number v1, lua_Number v2) { - switch (op) { - case LUA_OPADD: return luai_numadd(NULL, v1, v2); - case LUA_OPSUB: return luai_numsub(NULL, v1, v2); - case LUA_OPMUL: return luai_nummul(NULL, v1, v2); - case LUA_OPDIV: return luai_numdiv(NULL, v1, v2); - case LUA_OPMOD: return luai_nummod(NULL, v1, v2); - case LUA_OPPOW: return luai_numpow(NULL, v1, v2); - case LUA_OPUNM: return luai_numunm(NULL, v1); - default: lua_assert(0); return 0; - } -} - - -int luaO_hexavalue (int c) { - if (lisdigit(c)) return c - '0'; - else return ltolower(c) - 'a' + 10; -} - - -#if !defined(lua_strx2number) - -#include - - -static int isneg (const char **s) { - if (**s == '-') { (*s)++; return 1; } - else if (**s == '+') (*s)++; - return 0; -} - - -static lua_Number readhexa (const char **s, lua_Number r, int *count) { - for (; lisxdigit(cast_uchar(**s)); (*s)++) { /* read integer part */ - r = (r * cast_num(16.0)) + cast_num(luaO_hexavalue(cast_uchar(**s))); - (*count)++; - } - return r; -} - - -/* -** convert an hexadecimal numeric string to a number, following -** C99 specification for 'strtod' -*/ -static lua_Number lua_strx2number (const char *s, char **endptr) { - lua_Number r = 0.0; - int e = 0, i = 0; - int neg = 0; /* 1 if number is negative */ - *endptr = cast(char *, s); /* nothing is valid yet */ - while (lisspace(cast_uchar(*s))) s++; /* skip initial spaces */ - neg = isneg(&s); /* check signal */ - if (!(*s == '0' && (*(s + 1) == 'x' || *(s + 1) == 'X'))) /* check '0x' */ - return 0.0; /* invalid format (no '0x') */ - s += 2; /* skip '0x' */ - r = readhexa(&s, r, &i); /* read integer part */ - if (*s == '.') { - s++; /* skip dot */ - r = readhexa(&s, r, &e); /* read fractional part */ - } - if (i == 0 && e == 0) - return 0.0; /* invalid format (no digit) */ - e *= -4; /* each fractional digit divides value by 2^-4 */ - *endptr = cast(char *, s); /* valid up to here */ - if (*s == 'p' || *s == 'P') { /* exponent part? */ - int exp1 = 0; - int neg1; - s++; /* skip 'p' */ - neg1 = isneg(&s); /* signal */ - if (!lisdigit(cast_uchar(*s))) - goto ret; /* must have at least one digit */ - while (lisdigit(cast_uchar(*s))) /* read exponent */ - exp1 = exp1 * 10 + *(s++) - '0'; - if (neg1) exp1 = -exp1; - e += exp1; - } - *endptr = cast(char *, s); /* valid up to here */ - ret: - if (neg) r = -r; - return l_mathop(ldexp)(r, e); -} - -#endif - - -int luaO_str2d (const char *s, size_t len, lua_Number *result) { - char *endptr; - if (strpbrk(s, "nN")) /* reject 'inf' and 'nan' */ - return 0; - else if (strpbrk(s, "xX")) /* hexa? */ - *result = lua_strx2number(s, &endptr); - else - *result = lua_str2number(s, &endptr); - if (endptr == s) return 0; /* nothing recognized */ - while (lisspace(cast_uchar(*endptr))) endptr++; - return (endptr == s + len); /* OK if no trailing characters */ -} - - - -static void pushstr (lua_State *L, const char *str, size_t l) { - setsvalue2s(L, L->top++, luaS_newlstr(L, str, l)); -} - - -/* this function handles only `%d', `%c', %f, %p, and `%s' formats */ -const char *luaO_pushvfstring (lua_State *L, const char *fmt, va_list argp) { - int n = 0; - for (;;) { - const char *e = strchr(fmt, '%'); - if (e == NULL) break; - luaD_checkstack(L, 2); /* fmt + item */ - pushstr(L, fmt, e - fmt); - switch (*(e+1)) { - case 's': { - const char *s = va_arg(argp, char *); - if (s == NULL) s = "(null)"; - pushstr(L, s, strlen(s)); - break; - } - case 'c': { - char buff; - buff = cast(char, va_arg(argp, int)); - pushstr(L, &buff, 1); - break; - } - case 'd': { - setnvalue(L->top++, cast_num(va_arg(argp, int))); - break; - } - case 'f': { - setnvalue(L->top++, cast_num(va_arg(argp, l_uacNumber))); - break; - } - case 'p': { - char buff[4*sizeof(void *) + 8]; /* should be enough space for a `%p' */ - int l = sprintf(buff, "%p", va_arg(argp, void *)); - pushstr(L, buff, l); - break; - } - case '%': { - pushstr(L, "%", 1); - break; - } - default: { - luaG_runerror(L, - "invalid option " LUA_QL("%%%c") " to " LUA_QL("lua_pushfstring"), - *(e + 1)); - } - } - n += 2; - fmt = e+2; - } - luaD_checkstack(L, 1); - pushstr(L, fmt, strlen(fmt)); - if (n > 0) luaV_concat(L, n + 1); - return svalue(L->top - 1); -} - - -const char *luaO_pushfstring (lua_State *L, const char *fmt, ...) { - const char *msg; - va_list argp; - va_start(argp, fmt); - msg = luaO_pushvfstring(L, fmt, argp); - va_end(argp); - return msg; -} - - -/* number of chars of a literal string without the ending \0 */ -#define LL(x) (sizeof(x)/sizeof(char) - 1) - -#define RETS "..." -#define PRE "[string \"" -#define POS "\"]" - -#define addstr(a,b,l) ( memcpy(a,b,(l) * sizeof(char)), a += (l) ) - -void luaO_chunkid (char *out, const char *source, size_t bufflen) { - size_t l = strlen(source); - if (*source == '=') { /* 'literal' source */ - if (l <= bufflen) /* small enough? */ - memcpy(out, source + 1, l * sizeof(char)); - else { /* truncate it */ - addstr(out, source + 1, bufflen - 1); - *out = '\0'; - } - } - else if (*source == '@') { /* file name */ - if (l <= bufflen) /* small enough? */ - memcpy(out, source + 1, l * sizeof(char)); - else { /* add '...' before rest of name */ - addstr(out, RETS, LL(RETS)); - bufflen -= LL(RETS); - memcpy(out, source + 1 + l - bufflen, bufflen * sizeof(char)); - } - } - else { /* string; format as [string "source"] */ - const char *nl = strchr(source, '\n'); /* find first new line (if any) */ - addstr(out, PRE, LL(PRE)); /* add prefix */ - bufflen -= LL(PRE RETS POS) + 1; /* save space for prefix+suffix+'\0' */ - if (l < bufflen && nl == NULL) { /* small one-line source? */ - addstr(out, source, l); /* keep it */ - } - else { - if (nl != NULL) l = nl - source; /* stop at first newline */ - if (l > bufflen) l = bufflen; - addstr(out, source, l); - addstr(out, RETS, LL(RETS)); - } - memcpy(out, POS, (LL(POS) + 1) * sizeof(char)); - } -} - diff --git a/btgui/lua-5.2.3/src/lobject.h b/btgui/lua-5.2.3/src/lobject.h deleted file mode 100644 index 3a630b944..000000000 --- a/btgui/lua-5.2.3/src/lobject.h +++ /dev/null @@ -1,607 +0,0 @@ -/* -** $Id: lobject.h,v 2.71.1.1 2013/04/12 18:48:47 roberto Exp $ -** Type definitions for Lua objects -** See Copyright Notice in lua.h -*/ - - -#ifndef lobject_h -#define lobject_h - - -#include - - -#include "llimits.h" -#include "lua.h" - - -/* -** Extra tags for non-values -*/ -#define LUA_TPROTO LUA_NUMTAGS -#define LUA_TUPVAL (LUA_NUMTAGS+1) -#define LUA_TDEADKEY (LUA_NUMTAGS+2) - -/* -** number of all possible tags (including LUA_TNONE but excluding DEADKEY) -*/ -#define LUA_TOTALTAGS (LUA_TUPVAL+2) - - -/* -** tags for Tagged Values have the following use of bits: -** bits 0-3: actual tag (a LUA_T* value) -** bits 4-5: variant bits -** bit 6: whether value is collectable -*/ - -#define VARBITS (3 << 4) - - -/* -** LUA_TFUNCTION variants: -** 0 - Lua function -** 1 - light C function -** 2 - regular C function (closure) -*/ - -/* Variant tags for functions */ -#define LUA_TLCL (LUA_TFUNCTION | (0 << 4)) /* Lua closure */ -#define LUA_TLCF (LUA_TFUNCTION | (1 << 4)) /* light C function */ -#define LUA_TCCL (LUA_TFUNCTION | (2 << 4)) /* C closure */ - - -/* Variant tags for strings */ -#define LUA_TSHRSTR (LUA_TSTRING | (0 << 4)) /* short strings */ -#define LUA_TLNGSTR (LUA_TSTRING | (1 << 4)) /* long strings */ - - -/* Bit mark for collectable types */ -#define BIT_ISCOLLECTABLE (1 << 6) - -/* mark a tag as collectable */ -#define ctb(t) ((t) | BIT_ISCOLLECTABLE) - - -/* -** Union of all collectable objects -*/ -typedef union GCObject GCObject; - - -/* -** Common Header for all collectable objects (in macro form, to be -** included in other objects) -*/ -#define CommonHeader GCObject *next; lu_byte tt; lu_byte marked - - -/* -** Common header in struct form -*/ -typedef struct GCheader { - CommonHeader; -} GCheader; - - - -/* -** Union of all Lua values -*/ -typedef union Value Value; - - -#define numfield lua_Number n; /* numbers */ - - - -/* -** Tagged Values. This is the basic representation of values in Lua, -** an actual value plus a tag with its type. -*/ - -#define TValuefields Value value_; int tt_ - -typedef struct lua_TValue TValue; - - -/* macro defining a nil value */ -#define NILCONSTANT {NULL}, LUA_TNIL - - -#define val_(o) ((o)->value_) -#define num_(o) (val_(o).n) - - -/* raw type tag of a TValue */ -#define rttype(o) ((o)->tt_) - -/* tag with no variants (bits 0-3) */ -#define novariant(x) ((x) & 0x0F) - -/* type tag of a TValue (bits 0-3 for tags + variant bits 4-5) */ -#define ttype(o) (rttype(o) & 0x3F) - -/* type tag of a TValue with no variants (bits 0-3) */ -#define ttypenv(o) (novariant(rttype(o))) - - -/* Macros to test type */ -#define checktag(o,t) (rttype(o) == (t)) -#define checktype(o,t) (ttypenv(o) == (t)) -#define ttisnumber(o) checktag((o), LUA_TNUMBER) -#define ttisnil(o) checktag((o), LUA_TNIL) -#define ttisboolean(o) checktag((o), LUA_TBOOLEAN) -#define ttislightuserdata(o) checktag((o), LUA_TLIGHTUSERDATA) -#define ttisstring(o) checktype((o), LUA_TSTRING) -#define ttisshrstring(o) checktag((o), ctb(LUA_TSHRSTR)) -#define ttislngstring(o) checktag((o), ctb(LUA_TLNGSTR)) -#define ttistable(o) checktag((o), ctb(LUA_TTABLE)) -#define ttisfunction(o) checktype(o, LUA_TFUNCTION) -#define ttisclosure(o) ((rttype(o) & 0x1F) == LUA_TFUNCTION) -#define ttisCclosure(o) checktag((o), ctb(LUA_TCCL)) -#define ttisLclosure(o) checktag((o), ctb(LUA_TLCL)) -#define ttislcf(o) checktag((o), LUA_TLCF) -#define ttisuserdata(o) checktag((o), ctb(LUA_TUSERDATA)) -#define ttisthread(o) checktag((o), ctb(LUA_TTHREAD)) -#define ttisdeadkey(o) checktag((o), LUA_TDEADKEY) - -#define ttisequal(o1,o2) (rttype(o1) == rttype(o2)) - -/* Macros to access values */ -#define nvalue(o) check_exp(ttisnumber(o), num_(o)) -#define gcvalue(o) check_exp(iscollectable(o), val_(o).gc) -#define pvalue(o) check_exp(ttislightuserdata(o), val_(o).p) -#define rawtsvalue(o) check_exp(ttisstring(o), &val_(o).gc->ts) -#define tsvalue(o) (&rawtsvalue(o)->tsv) -#define rawuvalue(o) check_exp(ttisuserdata(o), &val_(o).gc->u) -#define uvalue(o) (&rawuvalue(o)->uv) -#define clvalue(o) check_exp(ttisclosure(o), &val_(o).gc->cl) -#define clLvalue(o) check_exp(ttisLclosure(o), &val_(o).gc->cl.l) -#define clCvalue(o) check_exp(ttisCclosure(o), &val_(o).gc->cl.c) -#define fvalue(o) check_exp(ttislcf(o), val_(o).f) -#define hvalue(o) check_exp(ttistable(o), &val_(o).gc->h) -#define bvalue(o) check_exp(ttisboolean(o), val_(o).b) -#define thvalue(o) check_exp(ttisthread(o), &val_(o).gc->th) -/* a dead value may get the 'gc' field, but cannot access its contents */ -#define deadvalue(o) check_exp(ttisdeadkey(o), cast(void *, val_(o).gc)) - -#define l_isfalse(o) (ttisnil(o) || (ttisboolean(o) && bvalue(o) == 0)) - - -#define iscollectable(o) (rttype(o) & BIT_ISCOLLECTABLE) - - -/* Macros for internal tests */ -#define righttt(obj) (ttype(obj) == gcvalue(obj)->gch.tt) - -#define checkliveness(g,obj) \ - lua_longassert(!iscollectable(obj) || \ - (righttt(obj) && !isdead(g,gcvalue(obj)))) - - -/* Macros to set values */ -#define settt_(o,t) ((o)->tt_=(t)) - -#define setnvalue(obj,x) \ - { TValue *io=(obj); num_(io)=(x); settt_(io, LUA_TNUMBER); } - -#define setnilvalue(obj) settt_(obj, LUA_TNIL) - -#define setfvalue(obj,x) \ - { TValue *io=(obj); val_(io).f=(x); settt_(io, LUA_TLCF); } - -#define setpvalue(obj,x) \ - { TValue *io=(obj); val_(io).p=(x); settt_(io, LUA_TLIGHTUSERDATA); } - -#define setbvalue(obj,x) \ - { TValue *io=(obj); val_(io).b=(x); settt_(io, LUA_TBOOLEAN); } - -#define setgcovalue(L,obj,x) \ - { TValue *io=(obj); GCObject *i_g=(x); \ - val_(io).gc=i_g; settt_(io, ctb(gch(i_g)->tt)); } - -#define setsvalue(L,obj,x) \ - { TValue *io=(obj); \ - TString *x_ = (x); \ - val_(io).gc=cast(GCObject *, x_); settt_(io, ctb(x_->tsv.tt)); \ - checkliveness(G(L),io); } - -#define setuvalue(L,obj,x) \ - { TValue *io=(obj); \ - val_(io).gc=cast(GCObject *, (x)); settt_(io, ctb(LUA_TUSERDATA)); \ - checkliveness(G(L),io); } - -#define setthvalue(L,obj,x) \ - { TValue *io=(obj); \ - val_(io).gc=cast(GCObject *, (x)); settt_(io, ctb(LUA_TTHREAD)); \ - checkliveness(G(L),io); } - -#define setclLvalue(L,obj,x) \ - { TValue *io=(obj); \ - val_(io).gc=cast(GCObject *, (x)); settt_(io, ctb(LUA_TLCL)); \ - checkliveness(G(L),io); } - -#define setclCvalue(L,obj,x) \ - { TValue *io=(obj); \ - val_(io).gc=cast(GCObject *, (x)); settt_(io, ctb(LUA_TCCL)); \ - checkliveness(G(L),io); } - -#define sethvalue(L,obj,x) \ - { TValue *io=(obj); \ - val_(io).gc=cast(GCObject *, (x)); settt_(io, ctb(LUA_TTABLE)); \ - checkliveness(G(L),io); } - -#define setdeadvalue(obj) settt_(obj, LUA_TDEADKEY) - - - -#define setobj(L,obj1,obj2) \ - { const TValue *io2=(obj2); TValue *io1=(obj1); \ - io1->value_ = io2->value_; io1->tt_ = io2->tt_; \ - checkliveness(G(L),io1); } - - -/* -** different types of assignments, according to destination -*/ - -/* from stack to (same) stack */ -#define setobjs2s setobj -/* to stack (not from same stack) */ -#define setobj2s setobj -#define setsvalue2s setsvalue -#define sethvalue2s sethvalue -#define setptvalue2s setptvalue -/* from table to same table */ -#define setobjt2t setobj -/* to table */ -#define setobj2t setobj -/* to new object */ -#define setobj2n setobj -#define setsvalue2n setsvalue - - -/* check whether a number is valid (useful only for NaN trick) */ -#define luai_checknum(L,o,c) { /* empty */ } - - -/* -** {====================================================== -** NaN Trick -** ======================================================= -*/ -#if defined(LUA_NANTRICK) - -/* -** numbers are represented in the 'd_' field. All other values have the -** value (NNMARK | tag) in 'tt__'. A number with such pattern would be -** a "signaled NaN", which is never generated by regular operations by -** the CPU (nor by 'strtod') -*/ - -/* allows for external implementation for part of the trick */ -#if !defined(NNMARK) /* { */ - - -#if !defined(LUA_IEEEENDIAN) -#error option 'LUA_NANTRICK' needs 'LUA_IEEEENDIAN' -#endif - - -#define NNMARK 0x7FF7A500 -#define NNMASK 0x7FFFFF00 - -#undef TValuefields -#undef NILCONSTANT - -#if (LUA_IEEEENDIAN == 0) /* { */ - -/* little endian */ -#define TValuefields \ - union { struct { Value v__; int tt__; } i; double d__; } u -#define NILCONSTANT {{{NULL}, tag2tt(LUA_TNIL)}} -/* field-access macros */ -#define v_(o) ((o)->u.i.v__) -#define d_(o) ((o)->u.d__) -#define tt_(o) ((o)->u.i.tt__) - -#else /* }{ */ - -/* big endian */ -#define TValuefields \ - union { struct { int tt__; Value v__; } i; double d__; } u -#define NILCONSTANT {{tag2tt(LUA_TNIL), {NULL}}} -/* field-access macros */ -#define v_(o) ((o)->u.i.v__) -#define d_(o) ((o)->u.d__) -#define tt_(o) ((o)->u.i.tt__) - -#endif /* } */ - -#endif /* } */ - - -/* correspondence with standard representation */ -#undef val_ -#define val_(o) v_(o) -#undef num_ -#define num_(o) d_(o) - - -#undef numfield -#define numfield /* no such field; numbers are the entire struct */ - -/* basic check to distinguish numbers from non-numbers */ -#undef ttisnumber -#define ttisnumber(o) ((tt_(o) & NNMASK) != NNMARK) - -#define tag2tt(t) (NNMARK | (t)) - -#undef rttype -#define rttype(o) (ttisnumber(o) ? LUA_TNUMBER : tt_(o) & 0xff) - -#undef settt_ -#define settt_(o,t) (tt_(o) = tag2tt(t)) - -#undef setnvalue -#define setnvalue(obj,x) \ - { TValue *io_=(obj); num_(io_)=(x); lua_assert(ttisnumber(io_)); } - -#undef setobj -#define setobj(L,obj1,obj2) \ - { const TValue *o2_=(obj2); TValue *o1_=(obj1); \ - o1_->u = o2_->u; \ - checkliveness(G(L),o1_); } - - -/* -** these redefinitions are not mandatory, but these forms are more efficient -*/ - -#undef checktag -#undef checktype -#define checktag(o,t) (tt_(o) == tag2tt(t)) -#define checktype(o,t) (ctb(tt_(o) | VARBITS) == ctb(tag2tt(t) | VARBITS)) - -#undef ttisequal -#define ttisequal(o1,o2) \ - (ttisnumber(o1) ? ttisnumber(o2) : (tt_(o1) == tt_(o2))) - - -#undef luai_checknum -#define luai_checknum(L,o,c) { if (!ttisnumber(o)) c; } - -#endif -/* }====================================================== */ - - - -/* -** {====================================================== -** types and prototypes -** ======================================================= -*/ - - -union Value { - GCObject *gc; /* collectable objects */ - void *p; /* light userdata */ - int b; /* booleans */ - lua_CFunction f; /* light C functions */ - numfield /* numbers */ -}; - - -struct lua_TValue { - TValuefields; -}; - - -typedef TValue *StkId; /* index to stack elements */ - - - - -/* -** Header for string value; string bytes follow the end of this structure -*/ -typedef union TString { - L_Umaxalign dummy; /* ensures maximum alignment for strings */ - struct { - CommonHeader; - lu_byte extra; /* reserved words for short strings; "has hash" for longs */ - unsigned int hash; - size_t len; /* number of characters in string */ - } tsv; -} TString; - - -/* get the actual string (array of bytes) from a TString */ -#define getstr(ts) cast(const char *, (ts) + 1) - -/* get the actual string (array of bytes) from a Lua value */ -#define svalue(o) getstr(rawtsvalue(o)) - - -/* -** Header for userdata; memory area follows the end of this structure -*/ -typedef union Udata { - L_Umaxalign dummy; /* ensures maximum alignment for `local' udata */ - struct { - CommonHeader; - struct Table *metatable; - struct Table *env; - size_t len; /* number of bytes */ - } uv; -} Udata; - - - -/* -** Description of an upvalue for function prototypes -*/ -typedef struct Upvaldesc { - TString *name; /* upvalue name (for debug information) */ - lu_byte instack; /* whether it is in stack */ - lu_byte idx; /* index of upvalue (in stack or in outer function's list) */ -} Upvaldesc; - - -/* -** Description of a local variable for function prototypes -** (used for debug information) -*/ -typedef struct LocVar { - TString *varname; - int startpc; /* first point where variable is active */ - int endpc; /* first point where variable is dead */ -} LocVar; - - -/* -** Function Prototypes -*/ -typedef struct Proto { - CommonHeader; - TValue *k; /* constants used by the function */ - Instruction *code; - struct Proto **p; /* functions defined inside the function */ - int *lineinfo; /* map from opcodes to source lines (debug information) */ - LocVar *locvars; /* information about local variables (debug information) */ - Upvaldesc *upvalues; /* upvalue information */ - union Closure *cache; /* last created closure with this prototype */ - TString *source; /* used for debug information */ - int sizeupvalues; /* size of 'upvalues' */ - int sizek; /* size of `k' */ - int sizecode; - int sizelineinfo; - int sizep; /* size of `p' */ - int sizelocvars; - int linedefined; - int lastlinedefined; - GCObject *gclist; - lu_byte numparams; /* number of fixed parameters */ - lu_byte is_vararg; - lu_byte maxstacksize; /* maximum stack used by this function */ -} Proto; - - - -/* -** Lua Upvalues -*/ -typedef struct UpVal { - CommonHeader; - TValue *v; /* points to stack or to its own value */ - union { - TValue value; /* the value (when closed) */ - struct { /* double linked list (when open) */ - struct UpVal *prev; - struct UpVal *next; - } l; - } u; -} UpVal; - - -/* -** Closures -*/ - -#define ClosureHeader \ - CommonHeader; lu_byte nupvalues; GCObject *gclist - -typedef struct CClosure { - ClosureHeader; - lua_CFunction f; - TValue upvalue[1]; /* list of upvalues */ -} CClosure; - - -typedef struct LClosure { - ClosureHeader; - struct Proto *p; - UpVal *upvals[1]; /* list of upvalues */ -} LClosure; - - -typedef union Closure { - CClosure c; - LClosure l; -} Closure; - - -#define isLfunction(o) ttisLclosure(o) - -#define getproto(o) (clLvalue(o)->p) - - -/* -** Tables -*/ - -typedef union TKey { - struct { - TValuefields; - struct Node *next; /* for chaining */ - } nk; - TValue tvk; -} TKey; - - -typedef struct Node { - TValue i_val; - TKey i_key; -} Node; - - -typedef struct Table { - CommonHeader; - lu_byte flags; /* 1<

lsizenode)) - - -/* -** (address of) a fixed nil value -*/ -#define luaO_nilobject (&luaO_nilobject_) - - -LUAI_DDEC const TValue luaO_nilobject_; - - -LUAI_FUNC int luaO_int2fb (unsigned int x); -LUAI_FUNC int luaO_fb2int (int x); -LUAI_FUNC int luaO_ceillog2 (unsigned int x); -LUAI_FUNC lua_Number luaO_arith (int op, lua_Number v1, lua_Number v2); -LUAI_FUNC int luaO_str2d (const char *s, size_t len, lua_Number *result); -LUAI_FUNC int luaO_hexavalue (int c); -LUAI_FUNC const char *luaO_pushvfstring (lua_State *L, const char *fmt, - va_list argp); -LUAI_FUNC const char *luaO_pushfstring (lua_State *L, const char *fmt, ...); -LUAI_FUNC void luaO_chunkid (char *out, const char *source, size_t len); - - -#endif - diff --git a/btgui/lua-5.2.3/src/lopcodes.c b/btgui/lua-5.2.3/src/lopcodes.c deleted file mode 100644 index 4190dc762..000000000 --- a/btgui/lua-5.2.3/src/lopcodes.c +++ /dev/null @@ -1,107 +0,0 @@ -/* -** $Id: lopcodes.c,v 1.49.1.1 2013/04/12 18:48:47 roberto Exp $ -** Opcodes for Lua virtual machine -** See Copyright Notice in lua.h -*/ - - -#define lopcodes_c -#define LUA_CORE - - -#include "lopcodes.h" - - -/* ORDER OP */ - -LUAI_DDEF const char *const luaP_opnames[NUM_OPCODES+1] = { - "MOVE", - "LOADK", - "LOADKX", - "LOADBOOL", - "LOADNIL", - "GETUPVAL", - "GETTABUP", - "GETTABLE", - "SETTABUP", - "SETUPVAL", - "SETTABLE", - "NEWTABLE", - "SELF", - "ADD", - "SUB", - "MUL", - "DIV", - "MOD", - "POW", - "UNM", - "NOT", - "LEN", - "CONCAT", - "JMP", - "EQ", - "LT", - "LE", - "TEST", - "TESTSET", - "CALL", - "TAILCALL", - "RETURN", - "FORLOOP", - "FORPREP", - "TFORCALL", - "TFORLOOP", - "SETLIST", - "CLOSURE", - "VARARG", - "EXTRAARG", - NULL -}; - - -#define opmode(t,a,b,c,m) (((t)<<7) | ((a)<<6) | ((b)<<4) | ((c)<<2) | (m)) - -LUAI_DDEF const lu_byte luaP_opmodes[NUM_OPCODES] = { -/* T A B C mode opcode */ - opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_MOVE */ - ,opmode(0, 1, OpArgK, OpArgN, iABx) /* OP_LOADK */ - ,opmode(0, 1, OpArgN, OpArgN, iABx) /* OP_LOADKX */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_LOADBOOL */ - ,opmode(0, 1, OpArgU, OpArgN, iABC) /* OP_LOADNIL */ - ,opmode(0, 1, OpArgU, OpArgN, iABC) /* OP_GETUPVAL */ - ,opmode(0, 1, OpArgU, OpArgK, iABC) /* OP_GETTABUP */ - ,opmode(0, 1, OpArgR, OpArgK, iABC) /* OP_GETTABLE */ - ,opmode(0, 0, OpArgK, OpArgK, iABC) /* OP_SETTABUP */ - ,opmode(0, 0, OpArgU, OpArgN, iABC) /* OP_SETUPVAL */ - ,opmode(0, 0, OpArgK, OpArgK, iABC) /* OP_SETTABLE */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_NEWTABLE */ - ,opmode(0, 1, OpArgR, OpArgK, iABC) /* OP_SELF */ - ,opmode(0, 1, OpArgK, OpArgK, iABC) /* OP_ADD */ - ,opmode(0, 1, OpArgK, OpArgK, iABC) /* OP_SUB */ - ,opmode(0, 1, OpArgK, OpArgK, iABC) /* OP_MUL */ - ,opmode(0, 1, OpArgK, OpArgK, iABC) /* OP_DIV */ - ,opmode(0, 1, OpArgK, OpArgK, iABC) /* OP_MOD */ - ,opmode(0, 1, OpArgK, OpArgK, iABC) /* OP_POW */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_UNM */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_NOT */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_LEN */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_CONCAT */ - ,opmode(0, 0, OpArgR, OpArgN, iAsBx) /* OP_JMP */ - ,opmode(1, 0, OpArgK, OpArgK, iABC) /* OP_EQ */ - ,opmode(1, 0, OpArgK, OpArgK, iABC) /* OP_LT */ - ,opmode(1, 0, OpArgK, OpArgK, iABC) /* OP_LE */ - ,opmode(1, 0, OpArgN, OpArgU, iABC) /* OP_TEST */ - ,opmode(1, 1, OpArgR, OpArgU, iABC) /* OP_TESTSET */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_CALL */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_TAILCALL */ - ,opmode(0, 0, OpArgU, OpArgN, iABC) /* OP_RETURN */ - ,opmode(0, 1, OpArgR, OpArgN, iAsBx) /* OP_FORLOOP */ - ,opmode(0, 1, OpArgR, OpArgN, iAsBx) /* OP_FORPREP */ - ,opmode(0, 0, OpArgN, OpArgU, iABC) /* OP_TFORCALL */ - ,opmode(0, 1, OpArgR, OpArgN, iAsBx) /* OP_TFORLOOP */ - ,opmode(0, 0, OpArgU, OpArgU, iABC) /* OP_SETLIST */ - ,opmode(0, 1, OpArgU, OpArgN, iABx) /* OP_CLOSURE */ - ,opmode(0, 1, OpArgU, OpArgN, iABC) /* OP_VARARG */ - ,opmode(0, 0, OpArgU, OpArgU, iAx) /* OP_EXTRAARG */ -}; - diff --git a/btgui/lua-5.2.3/src/lopcodes.h b/btgui/lua-5.2.3/src/lopcodes.h deleted file mode 100644 index 51f579154..000000000 --- a/btgui/lua-5.2.3/src/lopcodes.h +++ /dev/null @@ -1,288 +0,0 @@ -/* -** $Id: lopcodes.h,v 1.142.1.1 2013/04/12 18:48:47 roberto Exp $ -** Opcodes for Lua virtual machine -** See Copyright Notice in lua.h -*/ - -#ifndef lopcodes_h -#define lopcodes_h - -#include "llimits.h" - - -/*=========================================================================== - We assume that instructions are unsigned numbers. - All instructions have an opcode in the first 6 bits. - Instructions can have the following fields: - `A' : 8 bits - `B' : 9 bits - `C' : 9 bits - 'Ax' : 26 bits ('A', 'B', and 'C' together) - `Bx' : 18 bits (`B' and `C' together) - `sBx' : signed Bx - - A signed argument is represented in excess K; that is, the number - value is the unsigned value minus K. K is exactly the maximum value - for that argument (so that -max is represented by 0, and +max is - represented by 2*max), which is half the maximum for the corresponding - unsigned argument. -===========================================================================*/ - - -enum OpMode {iABC, iABx, iAsBx, iAx}; /* basic instruction format */ - - -/* -** size and position of opcode arguments. -*/ -#define SIZE_C 9 -#define SIZE_B 9 -#define SIZE_Bx (SIZE_C + SIZE_B) -#define SIZE_A 8 -#define SIZE_Ax (SIZE_C + SIZE_B + SIZE_A) - -#define SIZE_OP 6 - -#define POS_OP 0 -#define POS_A (POS_OP + SIZE_OP) -#define POS_C (POS_A + SIZE_A) -#define POS_B (POS_C + SIZE_C) -#define POS_Bx POS_C -#define POS_Ax POS_A - - -/* -** limits for opcode arguments. -** we use (signed) int to manipulate most arguments, -** so they must fit in LUAI_BITSINT-1 bits (-1 for sign) -*/ -#if SIZE_Bx < LUAI_BITSINT-1 -#define MAXARG_Bx ((1<>1) /* `sBx' is signed */ -#else -#define MAXARG_Bx MAX_INT -#define MAXARG_sBx MAX_INT -#endif - -#if SIZE_Ax < LUAI_BITSINT-1 -#define MAXARG_Ax ((1<>POS_OP) & MASK1(SIZE_OP,0))) -#define SET_OPCODE(i,o) ((i) = (((i)&MASK0(SIZE_OP,POS_OP)) | \ - ((cast(Instruction, o)<>pos) & MASK1(size,0))) -#define setarg(i,v,pos,size) ((i) = (((i)&MASK0(size,pos)) | \ - ((cast(Instruction, v)<= R(A) + 1 */ -OP_EQ,/* A B C if ((RK(B) == RK(C)) ~= A) then pc++ */ -OP_LT,/* A B C if ((RK(B) < RK(C)) ~= A) then pc++ */ -OP_LE,/* A B C if ((RK(B) <= RK(C)) ~= A) then pc++ */ - -OP_TEST,/* A C if not (R(A) <=> C) then pc++ */ -OP_TESTSET,/* A B C if (R(B) <=> C) then R(A) := R(B) else pc++ */ - -OP_CALL,/* A B C R(A), ... ,R(A+C-2) := R(A)(R(A+1), ... ,R(A+B-1)) */ -OP_TAILCALL,/* A B C return R(A)(R(A+1), ... ,R(A+B-1)) */ -OP_RETURN,/* A B return R(A), ... ,R(A+B-2) (see note) */ - -OP_FORLOOP,/* A sBx R(A)+=R(A+2); - if R(A) > 4) & 3)) -#define getCMode(m) (cast(enum OpArgMask, (luaP_opmodes[m] >> 2) & 3)) -#define testAMode(m) (luaP_opmodes[m] & (1 << 6)) -#define testTMode(m) (luaP_opmodes[m] & (1 << 7)) - - -LUAI_DDEC const char *const luaP_opnames[NUM_OPCODES+1]; /* opcode names */ - - -/* number of list items to accumulate before a SETLIST instruction */ -#define LFIELDS_PER_FLUSH 50 - - -#endif diff --git a/btgui/lua-5.2.3/src/loslib.c b/btgui/lua-5.2.3/src/loslib.c deleted file mode 100644 index 052ba1744..000000000 --- a/btgui/lua-5.2.3/src/loslib.c +++ /dev/null @@ -1,323 +0,0 @@ -/* -** $Id: loslib.c,v 1.40.1.1 2013/04/12 18:48:47 roberto Exp $ -** Standard Operating System library -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include -#include -#include - -#define loslib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -/* -** list of valid conversion specifiers for the 'strftime' function -*/ -#if !defined(LUA_STRFTIMEOPTIONS) - -#if !defined(LUA_USE_POSIX) -#define LUA_STRFTIMEOPTIONS { "aAbBcdHIjmMpSUwWxXyYz%", "" } -#else -#define LUA_STRFTIMEOPTIONS \ - { "aAbBcCdDeFgGhHIjmMnprRStTuUVwWxXyYzZ%", "" \ - "", "E", "cCxXyY", \ - "O", "deHImMSuUVwWy" } -#endif - -#endif - - - -/* -** By default, Lua uses tmpnam except when POSIX is available, where it -** uses mkstemp. -*/ -#if defined(LUA_USE_MKSTEMP) -#include -#define LUA_TMPNAMBUFSIZE 32 -#define lua_tmpnam(b,e) { \ - strcpy(b, "/tmp/lua_XXXXXX"); \ - e = mkstemp(b); \ - if (e != -1) close(e); \ - e = (e == -1); } - -#elif !defined(lua_tmpnam) - -#define LUA_TMPNAMBUFSIZE L_tmpnam -#define lua_tmpnam(b,e) { e = (tmpnam(b) == NULL); } - -#endif - - -/* -** By default, Lua uses gmtime/localtime, except when POSIX is available, -** where it uses gmtime_r/localtime_r -*/ -#if defined(LUA_USE_GMTIME_R) - -#define l_gmtime(t,r) gmtime_r(t,r) -#define l_localtime(t,r) localtime_r(t,r) - -#elif !defined(l_gmtime) - -#define l_gmtime(t,r) ((void)r, gmtime(t)) -#define l_localtime(t,r) ((void)r, localtime(t)) - -#endif - - - -static int os_execute (lua_State *L) { - const char *cmd = luaL_optstring(L, 1, NULL); - int stat = system(cmd); - if (cmd != NULL) - return luaL_execresult(L, stat); - else { - lua_pushboolean(L, stat); /* true if there is a shell */ - return 1; - } -} - - -static int os_remove (lua_State *L) { - const char *filename = luaL_checkstring(L, 1); - return luaL_fileresult(L, remove(filename) == 0, filename); -} - - -static int os_rename (lua_State *L) { - const char *fromname = luaL_checkstring(L, 1); - const char *toname = luaL_checkstring(L, 2); - return luaL_fileresult(L, rename(fromname, toname) == 0, NULL); -} - - -static int os_tmpname (lua_State *L) { - char buff[LUA_TMPNAMBUFSIZE]; - int err; - lua_tmpnam(buff, err); - if (err) - return luaL_error(L, "unable to generate a unique filename"); - lua_pushstring(L, buff); - return 1; -} - - -static int os_getenv (lua_State *L) { - lua_pushstring(L, getenv(luaL_checkstring(L, 1))); /* if NULL push nil */ - return 1; -} - - -static int os_clock (lua_State *L) { - lua_pushnumber(L, ((lua_Number)clock())/(lua_Number)CLOCKS_PER_SEC); - return 1; -} - - -/* -** {====================================================== -** Time/Date operations -** { year=%Y, month=%m, day=%d, hour=%H, min=%M, sec=%S, -** wday=%w+1, yday=%j, isdst=? } -** ======================================================= -*/ - -static void setfield (lua_State *L, const char *key, int value) { - lua_pushinteger(L, value); - lua_setfield(L, -2, key); -} - -static void setboolfield (lua_State *L, const char *key, int value) { - if (value < 0) /* undefined? */ - return; /* does not set field */ - lua_pushboolean(L, value); - lua_setfield(L, -2, key); -} - -static int getboolfield (lua_State *L, const char *key) { - int res; - lua_getfield(L, -1, key); - res = lua_isnil(L, -1) ? -1 : lua_toboolean(L, -1); - lua_pop(L, 1); - return res; -} - - -static int getfield (lua_State *L, const char *key, int d) { - int res, isnum; - lua_getfield(L, -1, key); - res = (int)lua_tointegerx(L, -1, &isnum); - if (!isnum) { - if (d < 0) - return luaL_error(L, "field " LUA_QS " missing in date table", key); - res = d; - } - lua_pop(L, 1); - return res; -} - - -static const char *checkoption (lua_State *L, const char *conv, char *buff) { - static const char *const options[] = LUA_STRFTIMEOPTIONS; - unsigned int i; - for (i = 0; i < sizeof(options)/sizeof(options[0]); i += 2) { - if (*conv != '\0' && strchr(options[i], *conv) != NULL) { - buff[1] = *conv; - if (*options[i + 1] == '\0') { /* one-char conversion specifier? */ - buff[2] = '\0'; /* end buffer */ - return conv + 1; - } - else if (*(conv + 1) != '\0' && - strchr(options[i + 1], *(conv + 1)) != NULL) { - buff[2] = *(conv + 1); /* valid two-char conversion specifier */ - buff[3] = '\0'; /* end buffer */ - return conv + 2; - } - } - } - luaL_argerror(L, 1, - lua_pushfstring(L, "invalid conversion specifier '%%%s'", conv)); - return conv; /* to avoid warnings */ -} - - -static int os_date (lua_State *L) { - const char *s = luaL_optstring(L, 1, "%c"); - time_t t = luaL_opt(L, (time_t)luaL_checknumber, 2, time(NULL)); - struct tm tmr, *stm; - if (*s == '!') { /* UTC? */ - stm = l_gmtime(&t, &tmr); - s++; /* skip `!' */ - } - else - stm = l_localtime(&t, &tmr); - if (stm == NULL) /* invalid date? */ - lua_pushnil(L); - else if (strcmp(s, "*t") == 0) { - lua_createtable(L, 0, 9); /* 9 = number of fields */ - setfield(L, "sec", stm->tm_sec); - setfield(L, "min", stm->tm_min); - setfield(L, "hour", stm->tm_hour); - setfield(L, "day", stm->tm_mday); - setfield(L, "month", stm->tm_mon+1); - setfield(L, "year", stm->tm_year+1900); - setfield(L, "wday", stm->tm_wday+1); - setfield(L, "yday", stm->tm_yday+1); - setboolfield(L, "isdst", stm->tm_isdst); - } - else { - char cc[4]; - luaL_Buffer b; - cc[0] = '%'; - luaL_buffinit(L, &b); - while (*s) { - if (*s != '%') /* no conversion specifier? */ - luaL_addchar(&b, *s++); - else { - size_t reslen; - char buff[200]; /* should be big enough for any conversion result */ - s = checkoption(L, s + 1, cc); - reslen = strftime(buff, sizeof(buff), cc, stm); - luaL_addlstring(&b, buff, reslen); - } - } - luaL_pushresult(&b); - } - return 1; -} - - -static int os_time (lua_State *L) { - time_t t; - if (lua_isnoneornil(L, 1)) /* called without args? */ - t = time(NULL); /* get current time */ - else { - struct tm ts; - luaL_checktype(L, 1, LUA_TTABLE); - lua_settop(L, 1); /* make sure table is at the top */ - ts.tm_sec = getfield(L, "sec", 0); - ts.tm_min = getfield(L, "min", 0); - ts.tm_hour = getfield(L, "hour", 12); - ts.tm_mday = getfield(L, "day", -1); - ts.tm_mon = getfield(L, "month", -1) - 1; - ts.tm_year = getfield(L, "year", -1) - 1900; - ts.tm_isdst = getboolfield(L, "isdst"); - t = mktime(&ts); - } - if (t == (time_t)(-1)) - lua_pushnil(L); - else - lua_pushnumber(L, (lua_Number)t); - return 1; -} - - -static int os_difftime (lua_State *L) { - lua_pushnumber(L, difftime((time_t)(luaL_checknumber(L, 1)), - (time_t)(luaL_optnumber(L, 2, 0)))); - return 1; -} - -/* }====================================================== */ - - -static int os_setlocale (lua_State *L) { - static const int cat[] = {LC_ALL, LC_COLLATE, LC_CTYPE, LC_MONETARY, - LC_NUMERIC, LC_TIME}; - static const char *const catnames[] = {"all", "collate", "ctype", "monetary", - "numeric", "time", NULL}; - const char *l = luaL_optstring(L, 1, NULL); - int op = luaL_checkoption(L, 2, "all", catnames); - lua_pushstring(L, setlocale(cat[op], l)); - return 1; -} - - -static int os_exit (lua_State *L) { - int status; - if (lua_isboolean(L, 1)) - status = (lua_toboolean(L, 1) ? EXIT_SUCCESS : EXIT_FAILURE); - else - status = luaL_optint(L, 1, EXIT_SUCCESS); - if (lua_toboolean(L, 2)) - lua_close(L); - if (L) exit(status); /* 'if' to avoid warnings for unreachable 'return' */ - return 0; -} - - -static const luaL_Reg syslib[] = { - {"clock", os_clock}, - {"date", os_date}, - {"difftime", os_difftime}, - {"execute", os_execute}, - {"exit", os_exit}, - {"getenv", os_getenv}, - {"remove", os_remove}, - {"rename", os_rename}, - {"setlocale", os_setlocale}, - {"time", os_time}, - {"tmpname", os_tmpname}, - {NULL, NULL} -}; - -/* }====================================================== */ - - - -LUAMOD_API int luaopen_os (lua_State *L) { - luaL_newlib(L, syslib); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/lparser.c b/btgui/lua-5.2.3/src/lparser.c deleted file mode 100644 index 9e1a9ca2c..000000000 --- a/btgui/lua-5.2.3/src/lparser.c +++ /dev/null @@ -1,1638 +0,0 @@ -/* -** $Id: lparser.c,v 2.130.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua Parser -** See Copyright Notice in lua.h -*/ - - -#include - -#define lparser_c -#define LUA_CORE - -#include "lua.h" - -#include "lcode.h" -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "llex.h" -#include "lmem.h" -#include "lobject.h" -#include "lopcodes.h" -#include "lparser.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" - - - -/* maximum number of local variables per function (must be smaller - than 250, due to the bytecode format) */ -#define MAXVARS 200 - - -#define hasmultret(k) ((k) == VCALL || (k) == VVARARG) - - - -/* -** nodes for block list (list of active blocks) -*/ -typedef struct BlockCnt { - struct BlockCnt *previous; /* chain */ - short firstlabel; /* index of first label in this block */ - short firstgoto; /* index of first pending goto in this block */ - lu_byte nactvar; /* # active locals outside the block */ - lu_byte upval; /* true if some variable in the block is an upvalue */ - lu_byte isloop; /* true if `block' is a loop */ -} BlockCnt; - - - -/* -** prototypes for recursive non-terminal functions -*/ -static void statement (LexState *ls); -static void expr (LexState *ls, expdesc *v); - - -static void anchor_token (LexState *ls) { - /* last token from outer function must be EOS */ - lua_assert(ls->fs != NULL || ls->t.token == TK_EOS); - if (ls->t.token == TK_NAME || ls->t.token == TK_STRING) { - TString *ts = ls->t.seminfo.ts; - luaX_newstring(ls, getstr(ts), ts->tsv.len); - } -} - - -/* semantic error */ -static l_noret semerror (LexState *ls, const char *msg) { - ls->t.token = 0; /* remove 'near to' from final message */ - luaX_syntaxerror(ls, msg); -} - - -static l_noret error_expected (LexState *ls, int token) { - luaX_syntaxerror(ls, - luaO_pushfstring(ls->L, "%s expected", luaX_token2str(ls, token))); -} - - -static l_noret errorlimit (FuncState *fs, int limit, const char *what) { - lua_State *L = fs->ls->L; - const char *msg; - int line = fs->f->linedefined; - const char *where = (line == 0) - ? "main function" - : luaO_pushfstring(L, "function at line %d", line); - msg = luaO_pushfstring(L, "too many %s (limit is %d) in %s", - what, limit, where); - luaX_syntaxerror(fs->ls, msg); -} - - -static void checklimit (FuncState *fs, int v, int l, const char *what) { - if (v > l) errorlimit(fs, l, what); -} - - -static int testnext (LexState *ls, int c) { - if (ls->t.token == c) { - luaX_next(ls); - return 1; - } - else return 0; -} - - -static void check (LexState *ls, int c) { - if (ls->t.token != c) - error_expected(ls, c); -} - - -static void checknext (LexState *ls, int c) { - check(ls, c); - luaX_next(ls); -} - - -#define check_condition(ls,c,msg) { if (!(c)) luaX_syntaxerror(ls, msg); } - - - -static void check_match (LexState *ls, int what, int who, int where) { - if (!testnext(ls, what)) { - if (where == ls->linenumber) - error_expected(ls, what); - else { - luaX_syntaxerror(ls, luaO_pushfstring(ls->L, - "%s expected (to close %s at line %d)", - luaX_token2str(ls, what), luaX_token2str(ls, who), where)); - } - } -} - - -static TString *str_checkname (LexState *ls) { - TString *ts; - check(ls, TK_NAME); - ts = ls->t.seminfo.ts; - luaX_next(ls); - return ts; -} - - -static void init_exp (expdesc *e, expkind k, int i) { - e->f = e->t = NO_JUMP; - e->k = k; - e->u.info = i; -} - - -static void codestring (LexState *ls, expdesc *e, TString *s) { - init_exp(e, VK, luaK_stringK(ls->fs, s)); -} - - -static void checkname (LexState *ls, expdesc *e) { - codestring(ls, e, str_checkname(ls)); -} - - -static int registerlocalvar (LexState *ls, TString *varname) { - FuncState *fs = ls->fs; - Proto *f = fs->f; - int oldsize = f->sizelocvars; - luaM_growvector(ls->L, f->locvars, fs->nlocvars, f->sizelocvars, - LocVar, SHRT_MAX, "local variables"); - while (oldsize < f->sizelocvars) f->locvars[oldsize++].varname = NULL; - f->locvars[fs->nlocvars].varname = varname; - luaC_objbarrier(ls->L, f, varname); - return fs->nlocvars++; -} - - -static void new_localvar (LexState *ls, TString *name) { - FuncState *fs = ls->fs; - Dyndata *dyd = ls->dyd; - int reg = registerlocalvar(ls, name); - checklimit(fs, dyd->actvar.n + 1 - fs->firstlocal, - MAXVARS, "local variables"); - luaM_growvector(ls->L, dyd->actvar.arr, dyd->actvar.n + 1, - dyd->actvar.size, Vardesc, MAX_INT, "local variables"); - dyd->actvar.arr[dyd->actvar.n++].idx = cast(short, reg); -} - - -static void new_localvarliteral_ (LexState *ls, const char *name, size_t sz) { - new_localvar(ls, luaX_newstring(ls, name, sz)); -} - -#define new_localvarliteral(ls,v) \ - new_localvarliteral_(ls, "" v, (sizeof(v)/sizeof(char))-1) - - -static LocVar *getlocvar (FuncState *fs, int i) { - int idx = fs->ls->dyd->actvar.arr[fs->firstlocal + i].idx; - lua_assert(idx < fs->nlocvars); - return &fs->f->locvars[idx]; -} - - -static void adjustlocalvars (LexState *ls, int nvars) { - FuncState *fs = ls->fs; - fs->nactvar = cast_byte(fs->nactvar + nvars); - for (; nvars; nvars--) { - getlocvar(fs, fs->nactvar - nvars)->startpc = fs->pc; - } -} - - -static void removevars (FuncState *fs, int tolevel) { - fs->ls->dyd->actvar.n -= (fs->nactvar - tolevel); - while (fs->nactvar > tolevel) - getlocvar(fs, --fs->nactvar)->endpc = fs->pc; -} - - -static int searchupvalue (FuncState *fs, TString *name) { - int i; - Upvaldesc *up = fs->f->upvalues; - for (i = 0; i < fs->nups; i++) { - if (luaS_eqstr(up[i].name, name)) return i; - } - return -1; /* not found */ -} - - -static int newupvalue (FuncState *fs, TString *name, expdesc *v) { - Proto *f = fs->f; - int oldsize = f->sizeupvalues; - checklimit(fs, fs->nups + 1, MAXUPVAL, "upvalues"); - luaM_growvector(fs->ls->L, f->upvalues, fs->nups, f->sizeupvalues, - Upvaldesc, MAXUPVAL, "upvalues"); - while (oldsize < f->sizeupvalues) f->upvalues[oldsize++].name = NULL; - f->upvalues[fs->nups].instack = (v->k == VLOCAL); - f->upvalues[fs->nups].idx = cast_byte(v->u.info); - f->upvalues[fs->nups].name = name; - luaC_objbarrier(fs->ls->L, f, name); - return fs->nups++; -} - - -static int searchvar (FuncState *fs, TString *n) { - int i; - for (i = cast_int(fs->nactvar) - 1; i >= 0; i--) { - if (luaS_eqstr(n, getlocvar(fs, i)->varname)) - return i; - } - return -1; /* not found */ -} - - -/* - Mark block where variable at given level was defined - (to emit close instructions later). -*/ -static void markupval (FuncState *fs, int level) { - BlockCnt *bl = fs->bl; - while (bl->nactvar > level) bl = bl->previous; - bl->upval = 1; -} - - -/* - Find variable with given name 'n'. If it is an upvalue, add this - upvalue into all intermediate functions. -*/ -static int singlevaraux (FuncState *fs, TString *n, expdesc *var, int base) { - if (fs == NULL) /* no more levels? */ - return VVOID; /* default is global */ - else { - int v = searchvar(fs, n); /* look up locals at current level */ - if (v >= 0) { /* found? */ - init_exp(var, VLOCAL, v); /* variable is local */ - if (!base) - markupval(fs, v); /* local will be used as an upval */ - return VLOCAL; - } - else { /* not found as local at current level; try upvalues */ - int idx = searchupvalue(fs, n); /* try existing upvalues */ - if (idx < 0) { /* not found? */ - if (singlevaraux(fs->prev, n, var, 0) == VVOID) /* try upper levels */ - return VVOID; /* not found; is a global */ - /* else was LOCAL or UPVAL */ - idx = newupvalue(fs, n, var); /* will be a new upvalue */ - } - init_exp(var, VUPVAL, idx); - return VUPVAL; - } - } -} - - -static void singlevar (LexState *ls, expdesc *var) { - TString *varname = str_checkname(ls); - FuncState *fs = ls->fs; - if (singlevaraux(fs, varname, var, 1) == VVOID) { /* global name? */ - expdesc key; - singlevaraux(fs, ls->envn, var, 1); /* get environment variable */ - lua_assert(var->k == VLOCAL || var->k == VUPVAL); - codestring(ls, &key, varname); /* key is variable name */ - luaK_indexed(fs, var, &key); /* env[varname] */ - } -} - - -static void adjust_assign (LexState *ls, int nvars, int nexps, expdesc *e) { - FuncState *fs = ls->fs; - int extra = nvars - nexps; - if (hasmultret(e->k)) { - extra++; /* includes call itself */ - if (extra < 0) extra = 0; - luaK_setreturns(fs, e, extra); /* last exp. provides the difference */ - if (extra > 1) luaK_reserveregs(fs, extra-1); - } - else { - if (e->k != VVOID) luaK_exp2nextreg(fs, e); /* close last expression */ - if (extra > 0) { - int reg = fs->freereg; - luaK_reserveregs(fs, extra); - luaK_nil(fs, reg, extra); - } - } -} - - -static void enterlevel (LexState *ls) { - lua_State *L = ls->L; - ++L->nCcalls; - checklimit(ls->fs, L->nCcalls, LUAI_MAXCCALLS, "C levels"); -} - - -#define leavelevel(ls) ((ls)->L->nCcalls--) - - -static void closegoto (LexState *ls, int g, Labeldesc *label) { - int i; - FuncState *fs = ls->fs; - Labellist *gl = &ls->dyd->gt; - Labeldesc *gt = &gl->arr[g]; - lua_assert(luaS_eqstr(gt->name, label->name)); - if (gt->nactvar < label->nactvar) { - TString *vname = getlocvar(fs, gt->nactvar)->varname; - const char *msg = luaO_pushfstring(ls->L, - " at line %d jumps into the scope of local " LUA_QS, - getstr(gt->name), gt->line, getstr(vname)); - semerror(ls, msg); - } - luaK_patchlist(fs, gt->pc, label->pc); - /* remove goto from pending list */ - for (i = g; i < gl->n - 1; i++) - gl->arr[i] = gl->arr[i + 1]; - gl->n--; -} - - -/* -** try to close a goto with existing labels; this solves backward jumps -*/ -static int findlabel (LexState *ls, int g) { - int i; - BlockCnt *bl = ls->fs->bl; - Dyndata *dyd = ls->dyd; - Labeldesc *gt = &dyd->gt.arr[g]; - /* check labels in current block for a match */ - for (i = bl->firstlabel; i < dyd->label.n; i++) { - Labeldesc *lb = &dyd->label.arr[i]; - if (luaS_eqstr(lb->name, gt->name)) { /* correct label? */ - if (gt->nactvar > lb->nactvar && - (bl->upval || dyd->label.n > bl->firstlabel)) - luaK_patchclose(ls->fs, gt->pc, lb->nactvar); - closegoto(ls, g, lb); /* close it */ - return 1; - } - } - return 0; /* label not found; cannot close goto */ -} - - -static int newlabelentry (LexState *ls, Labellist *l, TString *name, - int line, int pc) { - int n = l->n; - luaM_growvector(ls->L, l->arr, n, l->size, - Labeldesc, SHRT_MAX, "labels/gotos"); - l->arr[n].name = name; - l->arr[n].line = line; - l->arr[n].nactvar = ls->fs->nactvar; - l->arr[n].pc = pc; - l->n++; - return n; -} - - -/* -** check whether new label 'lb' matches any pending gotos in current -** block; solves forward jumps -*/ -static void findgotos (LexState *ls, Labeldesc *lb) { - Labellist *gl = &ls->dyd->gt; - int i = ls->fs->bl->firstgoto; - while (i < gl->n) { - if (luaS_eqstr(gl->arr[i].name, lb->name)) - closegoto(ls, i, lb); - else - i++; - } -} - - -/* -** "export" pending gotos to outer level, to check them against -** outer labels; if the block being exited has upvalues, and -** the goto exits the scope of any variable (which can be the -** upvalue), close those variables being exited. -*/ -static void movegotosout (FuncState *fs, BlockCnt *bl) { - int i = bl->firstgoto; - Labellist *gl = &fs->ls->dyd->gt; - /* correct pending gotos to current block and try to close it - with visible labels */ - while (i < gl->n) { - Labeldesc *gt = &gl->arr[i]; - if (gt->nactvar > bl->nactvar) { - if (bl->upval) - luaK_patchclose(fs, gt->pc, bl->nactvar); - gt->nactvar = bl->nactvar; - } - if (!findlabel(fs->ls, i)) - i++; /* move to next one */ - } -} - - -static void enterblock (FuncState *fs, BlockCnt *bl, lu_byte isloop) { - bl->isloop = isloop; - bl->nactvar = fs->nactvar; - bl->firstlabel = fs->ls->dyd->label.n; - bl->firstgoto = fs->ls->dyd->gt.n; - bl->upval = 0; - bl->previous = fs->bl; - fs->bl = bl; - lua_assert(fs->freereg == fs->nactvar); -} - - -/* -** create a label named "break" to resolve break statements -*/ -static void breaklabel (LexState *ls) { - TString *n = luaS_new(ls->L, "break"); - int l = newlabelentry(ls, &ls->dyd->label, n, 0, ls->fs->pc); - findgotos(ls, &ls->dyd->label.arr[l]); -} - -/* -** generates an error for an undefined 'goto'; choose appropriate -** message when label name is a reserved word (which can only be 'break') -*/ -static l_noret undefgoto (LexState *ls, Labeldesc *gt) { - const char *msg = isreserved(gt->name) - ? "<%s> at line %d not inside a loop" - : "no visible label " LUA_QS " for at line %d"; - msg = luaO_pushfstring(ls->L, msg, getstr(gt->name), gt->line); - semerror(ls, msg); -} - - -static void leaveblock (FuncState *fs) { - BlockCnt *bl = fs->bl; - LexState *ls = fs->ls; - if (bl->previous && bl->upval) { - /* create a 'jump to here' to close upvalues */ - int j = luaK_jump(fs); - luaK_patchclose(fs, j, bl->nactvar); - luaK_patchtohere(fs, j); - } - if (bl->isloop) - breaklabel(ls); /* close pending breaks */ - fs->bl = bl->previous; - removevars(fs, bl->nactvar); - lua_assert(bl->nactvar == fs->nactvar); - fs->freereg = fs->nactvar; /* free registers */ - ls->dyd->label.n = bl->firstlabel; /* remove local labels */ - if (bl->previous) /* inner block? */ - movegotosout(fs, bl); /* update pending gotos to outer block */ - else if (bl->firstgoto < ls->dyd->gt.n) /* pending gotos in outer block? */ - undefgoto(ls, &ls->dyd->gt.arr[bl->firstgoto]); /* error */ -} - - -/* -** adds a new prototype into list of prototypes -*/ -static Proto *addprototype (LexState *ls) { - Proto *clp; - lua_State *L = ls->L; - FuncState *fs = ls->fs; - Proto *f = fs->f; /* prototype of current function */ - if (fs->np >= f->sizep) { - int oldsize = f->sizep; - luaM_growvector(L, f->p, fs->np, f->sizep, Proto *, MAXARG_Bx, "functions"); - while (oldsize < f->sizep) f->p[oldsize++] = NULL; - } - f->p[fs->np++] = clp = luaF_newproto(L); - luaC_objbarrier(L, f, clp); - return clp; -} - - -/* -** codes instruction to create new closure in parent function. -** The OP_CLOSURE instruction must use the last available register, -** so that, if it invokes the GC, the GC knows which registers -** are in use at that time. -*/ -static void codeclosure (LexState *ls, expdesc *v) { - FuncState *fs = ls->fs->prev; - init_exp(v, VRELOCABLE, luaK_codeABx(fs, OP_CLOSURE, 0, fs->np - 1)); - luaK_exp2nextreg(fs, v); /* fix it at the last register */ -} - - -static void open_func (LexState *ls, FuncState *fs, BlockCnt *bl) { - lua_State *L = ls->L; - Proto *f; - fs->prev = ls->fs; /* linked list of funcstates */ - fs->ls = ls; - ls->fs = fs; - fs->pc = 0; - fs->lasttarget = 0; - fs->jpc = NO_JUMP; - fs->freereg = 0; - fs->nk = 0; - fs->np = 0; - fs->nups = 0; - fs->nlocvars = 0; - fs->nactvar = 0; - fs->firstlocal = ls->dyd->actvar.n; - fs->bl = NULL; - f = fs->f; - f->source = ls->source; - f->maxstacksize = 2; /* registers 0/1 are always valid */ - fs->h = luaH_new(L); - /* anchor table of constants (to avoid being collected) */ - sethvalue2s(L, L->top, fs->h); - incr_top(L); - enterblock(fs, bl, 0); -} - - -static void close_func (LexState *ls) { - lua_State *L = ls->L; - FuncState *fs = ls->fs; - Proto *f = fs->f; - luaK_ret(fs, 0, 0); /* final return */ - leaveblock(fs); - luaM_reallocvector(L, f->code, f->sizecode, fs->pc, Instruction); - f->sizecode = fs->pc; - luaM_reallocvector(L, f->lineinfo, f->sizelineinfo, fs->pc, int); - f->sizelineinfo = fs->pc; - luaM_reallocvector(L, f->k, f->sizek, fs->nk, TValue); - f->sizek = fs->nk; - luaM_reallocvector(L, f->p, f->sizep, fs->np, Proto *); - f->sizep = fs->np; - luaM_reallocvector(L, f->locvars, f->sizelocvars, fs->nlocvars, LocVar); - f->sizelocvars = fs->nlocvars; - luaM_reallocvector(L, f->upvalues, f->sizeupvalues, fs->nups, Upvaldesc); - f->sizeupvalues = fs->nups; - lua_assert(fs->bl == NULL); - ls->fs = fs->prev; - /* last token read was anchored in defunct function; must re-anchor it */ - anchor_token(ls); - L->top--; /* pop table of constants */ - luaC_checkGC(L); -} - - - -/*============================================================*/ -/* GRAMMAR RULES */ -/*============================================================*/ - - -/* -** check whether current token is in the follow set of a block. -** 'until' closes syntactical blocks, but do not close scope, -** so it handled in separate. -*/ -static int block_follow (LexState *ls, int withuntil) { - switch (ls->t.token) { - case TK_ELSE: case TK_ELSEIF: - case TK_END: case TK_EOS: - return 1; - case TK_UNTIL: return withuntil; - default: return 0; - } -} - - -static void statlist (LexState *ls) { - /* statlist -> { stat [`;'] } */ - while (!block_follow(ls, 1)) { - if (ls->t.token == TK_RETURN) { - statement(ls); - return; /* 'return' must be last statement */ - } - statement(ls); - } -} - - -static void fieldsel (LexState *ls, expdesc *v) { - /* fieldsel -> ['.' | ':'] NAME */ - FuncState *fs = ls->fs; - expdesc key; - luaK_exp2anyregup(fs, v); - luaX_next(ls); /* skip the dot or colon */ - checkname(ls, &key); - luaK_indexed(fs, v, &key); -} - - -static void yindex (LexState *ls, expdesc *v) { - /* index -> '[' expr ']' */ - luaX_next(ls); /* skip the '[' */ - expr(ls, v); - luaK_exp2val(ls->fs, v); - checknext(ls, ']'); -} - - -/* -** {====================================================================== -** Rules for Constructors -** ======================================================================= -*/ - - -struct ConsControl { - expdesc v; /* last list item read */ - expdesc *t; /* table descriptor */ - int nh; /* total number of `record' elements */ - int na; /* total number of array elements */ - int tostore; /* number of array elements pending to be stored */ -}; - - -static void recfield (LexState *ls, struct ConsControl *cc) { - /* recfield -> (NAME | `['exp1`]') = exp1 */ - FuncState *fs = ls->fs; - int reg = ls->fs->freereg; - expdesc key, val; - int rkkey; - if (ls->t.token == TK_NAME) { - checklimit(fs, cc->nh, MAX_INT, "items in a constructor"); - checkname(ls, &key); - } - else /* ls->t.token == '[' */ - yindex(ls, &key); - cc->nh++; - checknext(ls, '='); - rkkey = luaK_exp2RK(fs, &key); - expr(ls, &val); - luaK_codeABC(fs, OP_SETTABLE, cc->t->u.info, rkkey, luaK_exp2RK(fs, &val)); - fs->freereg = reg; /* free registers */ -} - - -static void closelistfield (FuncState *fs, struct ConsControl *cc) { - if (cc->v.k == VVOID) return; /* there is no list item */ - luaK_exp2nextreg(fs, &cc->v); - cc->v.k = VVOID; - if (cc->tostore == LFIELDS_PER_FLUSH) { - luaK_setlist(fs, cc->t->u.info, cc->na, cc->tostore); /* flush */ - cc->tostore = 0; /* no more items pending */ - } -} - - -static void lastlistfield (FuncState *fs, struct ConsControl *cc) { - if (cc->tostore == 0) return; - if (hasmultret(cc->v.k)) { - luaK_setmultret(fs, &cc->v); - luaK_setlist(fs, cc->t->u.info, cc->na, LUA_MULTRET); - cc->na--; /* do not count last expression (unknown number of elements) */ - } - else { - if (cc->v.k != VVOID) - luaK_exp2nextreg(fs, &cc->v); - luaK_setlist(fs, cc->t->u.info, cc->na, cc->tostore); - } -} - - -static void listfield (LexState *ls, struct ConsControl *cc) { - /* listfield -> exp */ - expr(ls, &cc->v); - checklimit(ls->fs, cc->na, MAX_INT, "items in a constructor"); - cc->na++; - cc->tostore++; -} - - -static void field (LexState *ls, struct ConsControl *cc) { - /* field -> listfield | recfield */ - switch(ls->t.token) { - case TK_NAME: { /* may be 'listfield' or 'recfield' */ - if (luaX_lookahead(ls) != '=') /* expression? */ - listfield(ls, cc); - else - recfield(ls, cc); - break; - } - case '[': { - recfield(ls, cc); - break; - } - default: { - listfield(ls, cc); - break; - } - } -} - - -static void constructor (LexState *ls, expdesc *t) { - /* constructor -> '{' [ field { sep field } [sep] ] '}' - sep -> ',' | ';' */ - FuncState *fs = ls->fs; - int line = ls->linenumber; - int pc = luaK_codeABC(fs, OP_NEWTABLE, 0, 0, 0); - struct ConsControl cc; - cc.na = cc.nh = cc.tostore = 0; - cc.t = t; - init_exp(t, VRELOCABLE, pc); - init_exp(&cc.v, VVOID, 0); /* no value (yet) */ - luaK_exp2nextreg(ls->fs, t); /* fix it at stack top */ - checknext(ls, '{'); - do { - lua_assert(cc.v.k == VVOID || cc.tostore > 0); - if (ls->t.token == '}') break; - closelistfield(fs, &cc); - field(ls, &cc); - } while (testnext(ls, ',') || testnext(ls, ';')); - check_match(ls, '}', '{', line); - lastlistfield(fs, &cc); - SETARG_B(fs->f->code[pc], luaO_int2fb(cc.na)); /* set initial array size */ - SETARG_C(fs->f->code[pc], luaO_int2fb(cc.nh)); /* set initial table size */ -} - -/* }====================================================================== */ - - - -static void parlist (LexState *ls) { - /* parlist -> [ param { `,' param } ] */ - FuncState *fs = ls->fs; - Proto *f = fs->f; - int nparams = 0; - f->is_vararg = 0; - if (ls->t.token != ')') { /* is `parlist' not empty? */ - do { - switch (ls->t.token) { - case TK_NAME: { /* param -> NAME */ - new_localvar(ls, str_checkname(ls)); - nparams++; - break; - } - case TK_DOTS: { /* param -> `...' */ - luaX_next(ls); - f->is_vararg = 1; - break; - } - default: luaX_syntaxerror(ls, " or " LUA_QL("...") " expected"); - } - } while (!f->is_vararg && testnext(ls, ',')); - } - adjustlocalvars(ls, nparams); - f->numparams = cast_byte(fs->nactvar); - luaK_reserveregs(fs, fs->nactvar); /* reserve register for parameters */ -} - - -static void body (LexState *ls, expdesc *e, int ismethod, int line) { - /* body -> `(' parlist `)' block END */ - FuncState new_fs; - BlockCnt bl; - new_fs.f = addprototype(ls); - new_fs.f->linedefined = line; - open_func(ls, &new_fs, &bl); - checknext(ls, '('); - if (ismethod) { - new_localvarliteral(ls, "self"); /* create 'self' parameter */ - adjustlocalvars(ls, 1); - } - parlist(ls); - checknext(ls, ')'); - statlist(ls); - new_fs.f->lastlinedefined = ls->linenumber; - check_match(ls, TK_END, TK_FUNCTION, line); - codeclosure(ls, e); - close_func(ls); -} - - -static int explist (LexState *ls, expdesc *v) { - /* explist -> expr { `,' expr } */ - int n = 1; /* at least one expression */ - expr(ls, v); - while (testnext(ls, ',')) { - luaK_exp2nextreg(ls->fs, v); - expr(ls, v); - n++; - } - return n; -} - - -static void funcargs (LexState *ls, expdesc *f, int line) { - FuncState *fs = ls->fs; - expdesc args; - int base, nparams; - switch (ls->t.token) { - case '(': { /* funcargs -> `(' [ explist ] `)' */ - luaX_next(ls); - if (ls->t.token == ')') /* arg list is empty? */ - args.k = VVOID; - else { - explist(ls, &args); - luaK_setmultret(fs, &args); - } - check_match(ls, ')', '(', line); - break; - } - case '{': { /* funcargs -> constructor */ - constructor(ls, &args); - break; - } - case TK_STRING: { /* funcargs -> STRING */ - codestring(ls, &args, ls->t.seminfo.ts); - luaX_next(ls); /* must use `seminfo' before `next' */ - break; - } - default: { - luaX_syntaxerror(ls, "function arguments expected"); - } - } - lua_assert(f->k == VNONRELOC); - base = f->u.info; /* base register for call */ - if (hasmultret(args.k)) - nparams = LUA_MULTRET; /* open call */ - else { - if (args.k != VVOID) - luaK_exp2nextreg(fs, &args); /* close last argument */ - nparams = fs->freereg - (base+1); - } - init_exp(f, VCALL, luaK_codeABC(fs, OP_CALL, base, nparams+1, 2)); - luaK_fixline(fs, line); - fs->freereg = base+1; /* call remove function and arguments and leaves - (unless changed) one result */ -} - - - - -/* -** {====================================================================== -** Expression parsing -** ======================================================================= -*/ - - -static void primaryexp (LexState *ls, expdesc *v) { - /* primaryexp -> NAME | '(' expr ')' */ - switch (ls->t.token) { - case '(': { - int line = ls->linenumber; - luaX_next(ls); - expr(ls, v); - check_match(ls, ')', '(', line); - luaK_dischargevars(ls->fs, v); - return; - } - case TK_NAME: { - singlevar(ls, v); - return; - } - default: { - luaX_syntaxerror(ls, "unexpected symbol"); - } - } -} - - -static void suffixedexp (LexState *ls, expdesc *v) { - /* suffixedexp -> - primaryexp { '.' NAME | '[' exp ']' | ':' NAME funcargs | funcargs } */ - FuncState *fs = ls->fs; - int line = ls->linenumber; - primaryexp(ls, v); - for (;;) { - switch (ls->t.token) { - case '.': { /* fieldsel */ - fieldsel(ls, v); - break; - } - case '[': { /* `[' exp1 `]' */ - expdesc key; - luaK_exp2anyregup(fs, v); - yindex(ls, &key); - luaK_indexed(fs, v, &key); - break; - } - case ':': { /* `:' NAME funcargs */ - expdesc key; - luaX_next(ls); - checkname(ls, &key); - luaK_self(fs, v, &key); - funcargs(ls, v, line); - break; - } - case '(': case TK_STRING: case '{': { /* funcargs */ - luaK_exp2nextreg(fs, v); - funcargs(ls, v, line); - break; - } - default: return; - } - } -} - - -static void simpleexp (LexState *ls, expdesc *v) { - /* simpleexp -> NUMBER | STRING | NIL | TRUE | FALSE | ... | - constructor | FUNCTION body | suffixedexp */ - switch (ls->t.token) { - case TK_NUMBER: { - init_exp(v, VKNUM, 0); - v->u.nval = ls->t.seminfo.r; - break; - } - case TK_STRING: { - codestring(ls, v, ls->t.seminfo.ts); - break; - } - case TK_NIL: { - init_exp(v, VNIL, 0); - break; - } - case TK_TRUE: { - init_exp(v, VTRUE, 0); - break; - } - case TK_FALSE: { - init_exp(v, VFALSE, 0); - break; - } - case TK_DOTS: { /* vararg */ - FuncState *fs = ls->fs; - check_condition(ls, fs->f->is_vararg, - "cannot use " LUA_QL("...") " outside a vararg function"); - init_exp(v, VVARARG, luaK_codeABC(fs, OP_VARARG, 0, 1, 0)); - break; - } - case '{': { /* constructor */ - constructor(ls, v); - return; - } - case TK_FUNCTION: { - luaX_next(ls); - body(ls, v, 0, ls->linenumber); - return; - } - default: { - suffixedexp(ls, v); - return; - } - } - luaX_next(ls); -} - - -static UnOpr getunopr (int op) { - switch (op) { - case TK_NOT: return OPR_NOT; - case '-': return OPR_MINUS; - case '#': return OPR_LEN; - default: return OPR_NOUNOPR; - } -} - - -static BinOpr getbinopr (int op) { - switch (op) { - case '+': return OPR_ADD; - case '-': return OPR_SUB; - case '*': return OPR_MUL; - case '/': return OPR_DIV; - case '%': return OPR_MOD; - case '^': return OPR_POW; - case TK_CONCAT: return OPR_CONCAT; - case TK_NE: return OPR_NE; - case TK_EQ: return OPR_EQ; - case '<': return OPR_LT; - case TK_LE: return OPR_LE; - case '>': return OPR_GT; - case TK_GE: return OPR_GE; - case TK_AND: return OPR_AND; - case TK_OR: return OPR_OR; - default: return OPR_NOBINOPR; - } -} - - -static const struct { - lu_byte left; /* left priority for each binary operator */ - lu_byte right; /* right priority */ -} priority[] = { /* ORDER OPR */ - {6, 6}, {6, 6}, {7, 7}, {7, 7}, {7, 7}, /* `+' `-' `*' `/' `%' */ - {10, 9}, {5, 4}, /* ^, .. (right associative) */ - {3, 3}, {3, 3}, {3, 3}, /* ==, <, <= */ - {3, 3}, {3, 3}, {3, 3}, /* ~=, >, >= */ - {2, 2}, {1, 1} /* and, or */ -}; - -#define UNARY_PRIORITY 8 /* priority for unary operators */ - - -/* -** subexpr -> (simpleexp | unop subexpr) { binop subexpr } -** where `binop' is any binary operator with a priority higher than `limit' -*/ -static BinOpr subexpr (LexState *ls, expdesc *v, int limit) { - BinOpr op; - UnOpr uop; - enterlevel(ls); - uop = getunopr(ls->t.token); - if (uop != OPR_NOUNOPR) { - int line = ls->linenumber; - luaX_next(ls); - subexpr(ls, v, UNARY_PRIORITY); - luaK_prefix(ls->fs, uop, v, line); - } - else simpleexp(ls, v); - /* expand while operators have priorities higher than `limit' */ - op = getbinopr(ls->t.token); - while (op != OPR_NOBINOPR && priority[op].left > limit) { - expdesc v2; - BinOpr nextop; - int line = ls->linenumber; - luaX_next(ls); - luaK_infix(ls->fs, op, v); - /* read sub-expression with higher priority */ - nextop = subexpr(ls, &v2, priority[op].right); - luaK_posfix(ls->fs, op, v, &v2, line); - op = nextop; - } - leavelevel(ls); - return op; /* return first untreated operator */ -} - - -static void expr (LexState *ls, expdesc *v) { - subexpr(ls, v, 0); -} - -/* }==================================================================== */ - - - -/* -** {====================================================================== -** Rules for Statements -** ======================================================================= -*/ - - -static void block (LexState *ls) { - /* block -> statlist */ - FuncState *fs = ls->fs; - BlockCnt bl; - enterblock(fs, &bl, 0); - statlist(ls); - leaveblock(fs); -} - - -/* -** structure to chain all variables in the left-hand side of an -** assignment -*/ -struct LHS_assign { - struct LHS_assign *prev; - expdesc v; /* variable (global, local, upvalue, or indexed) */ -}; - - -/* -** check whether, in an assignment to an upvalue/local variable, the -** upvalue/local variable is begin used in a previous assignment to a -** table. If so, save original upvalue/local value in a safe place and -** use this safe copy in the previous assignment. -*/ -static void check_conflict (LexState *ls, struct LHS_assign *lh, expdesc *v) { - FuncState *fs = ls->fs; - int extra = fs->freereg; /* eventual position to save local variable */ - int conflict = 0; - for (; lh; lh = lh->prev) { /* check all previous assignments */ - if (lh->v.k == VINDEXED) { /* assigning to a table? */ - /* table is the upvalue/local being assigned now? */ - if (lh->v.u.ind.vt == v->k && lh->v.u.ind.t == v->u.info) { - conflict = 1; - lh->v.u.ind.vt = VLOCAL; - lh->v.u.ind.t = extra; /* previous assignment will use safe copy */ - } - /* index is the local being assigned? (index cannot be upvalue) */ - if (v->k == VLOCAL && lh->v.u.ind.idx == v->u.info) { - conflict = 1; - lh->v.u.ind.idx = extra; /* previous assignment will use safe copy */ - } - } - } - if (conflict) { - /* copy upvalue/local value to a temporary (in position 'extra') */ - OpCode op = (v->k == VLOCAL) ? OP_MOVE : OP_GETUPVAL; - luaK_codeABC(fs, op, extra, v->u.info, 0); - luaK_reserveregs(fs, 1); - } -} - - -static void assignment (LexState *ls, struct LHS_assign *lh, int nvars) { - expdesc e; - check_condition(ls, vkisvar(lh->v.k), "syntax error"); - if (testnext(ls, ',')) { /* assignment -> ',' suffixedexp assignment */ - struct LHS_assign nv; - nv.prev = lh; - suffixedexp(ls, &nv.v); - if (nv.v.k != VINDEXED) - check_conflict(ls, lh, &nv.v); - checklimit(ls->fs, nvars + ls->L->nCcalls, LUAI_MAXCCALLS, - "C levels"); - assignment(ls, &nv, nvars+1); - } - else { /* assignment -> `=' explist */ - int nexps; - checknext(ls, '='); - nexps = explist(ls, &e); - if (nexps != nvars) { - adjust_assign(ls, nvars, nexps, &e); - if (nexps > nvars) - ls->fs->freereg -= nexps - nvars; /* remove extra values */ - } - else { - luaK_setoneret(ls->fs, &e); /* close last expression */ - luaK_storevar(ls->fs, &lh->v, &e); - return; /* avoid default */ - } - } - init_exp(&e, VNONRELOC, ls->fs->freereg-1); /* default assignment */ - luaK_storevar(ls->fs, &lh->v, &e); -} - - -static int cond (LexState *ls) { - /* cond -> exp */ - expdesc v; - expr(ls, &v); /* read condition */ - if (v.k == VNIL) v.k = VFALSE; /* `falses' are all equal here */ - luaK_goiftrue(ls->fs, &v); - return v.f; -} - - -static void gotostat (LexState *ls, int pc) { - int line = ls->linenumber; - TString *label; - int g; - if (testnext(ls, TK_GOTO)) - label = str_checkname(ls); - else { - luaX_next(ls); /* skip break */ - label = luaS_new(ls->L, "break"); - } - g = newlabelentry(ls, &ls->dyd->gt, label, line, pc); - findlabel(ls, g); /* close it if label already defined */ -} - - -/* check for repeated labels on the same block */ -static void checkrepeated (FuncState *fs, Labellist *ll, TString *label) { - int i; - for (i = fs->bl->firstlabel; i < ll->n; i++) { - if (luaS_eqstr(label, ll->arr[i].name)) { - const char *msg = luaO_pushfstring(fs->ls->L, - "label " LUA_QS " already defined on line %d", - getstr(label), ll->arr[i].line); - semerror(fs->ls, msg); - } - } -} - - -/* skip no-op statements */ -static void skipnoopstat (LexState *ls) { - while (ls->t.token == ';' || ls->t.token == TK_DBCOLON) - statement(ls); -} - - -static void labelstat (LexState *ls, TString *label, int line) { - /* label -> '::' NAME '::' */ - FuncState *fs = ls->fs; - Labellist *ll = &ls->dyd->label; - int l; /* index of new label being created */ - checkrepeated(fs, ll, label); /* check for repeated labels */ - checknext(ls, TK_DBCOLON); /* skip double colon */ - /* create new entry for this label */ - l = newlabelentry(ls, ll, label, line, fs->pc); - skipnoopstat(ls); /* skip other no-op statements */ - if (block_follow(ls, 0)) { /* label is last no-op statement in the block? */ - /* assume that locals are already out of scope */ - ll->arr[l].nactvar = fs->bl->nactvar; - } - findgotos(ls, &ll->arr[l]); -} - - -static void whilestat (LexState *ls, int line) { - /* whilestat -> WHILE cond DO block END */ - FuncState *fs = ls->fs; - int whileinit; - int condexit; - BlockCnt bl; - luaX_next(ls); /* skip WHILE */ - whileinit = luaK_getlabel(fs); - condexit = cond(ls); - enterblock(fs, &bl, 1); - checknext(ls, TK_DO); - block(ls); - luaK_jumpto(fs, whileinit); - check_match(ls, TK_END, TK_WHILE, line); - leaveblock(fs); - luaK_patchtohere(fs, condexit); /* false conditions finish the loop */ -} - - -static void repeatstat (LexState *ls, int line) { - /* repeatstat -> REPEAT block UNTIL cond */ - int condexit; - FuncState *fs = ls->fs; - int repeat_init = luaK_getlabel(fs); - BlockCnt bl1, bl2; - enterblock(fs, &bl1, 1); /* loop block */ - enterblock(fs, &bl2, 0); /* scope block */ - luaX_next(ls); /* skip REPEAT */ - statlist(ls); - check_match(ls, TK_UNTIL, TK_REPEAT, line); - condexit = cond(ls); /* read condition (inside scope block) */ - if (bl2.upval) /* upvalues? */ - luaK_patchclose(fs, condexit, bl2.nactvar); - leaveblock(fs); /* finish scope */ - luaK_patchlist(fs, condexit, repeat_init); /* close the loop */ - leaveblock(fs); /* finish loop */ -} - - -static int exp1 (LexState *ls) { - expdesc e; - int reg; - expr(ls, &e); - luaK_exp2nextreg(ls->fs, &e); - lua_assert(e.k == VNONRELOC); - reg = e.u.info; - return reg; -} - - -static void forbody (LexState *ls, int base, int line, int nvars, int isnum) { - /* forbody -> DO block */ - BlockCnt bl; - FuncState *fs = ls->fs; - int prep, endfor; - adjustlocalvars(ls, 3); /* control variables */ - checknext(ls, TK_DO); - prep = isnum ? luaK_codeAsBx(fs, OP_FORPREP, base, NO_JUMP) : luaK_jump(fs); - enterblock(fs, &bl, 0); /* scope for declared variables */ - adjustlocalvars(ls, nvars); - luaK_reserveregs(fs, nvars); - block(ls); - leaveblock(fs); /* end of scope for declared variables */ - luaK_patchtohere(fs, prep); - if (isnum) /* numeric for? */ - endfor = luaK_codeAsBx(fs, OP_FORLOOP, base, NO_JUMP); - else { /* generic for */ - luaK_codeABC(fs, OP_TFORCALL, base, 0, nvars); - luaK_fixline(fs, line); - endfor = luaK_codeAsBx(fs, OP_TFORLOOP, base + 2, NO_JUMP); - } - luaK_patchlist(fs, endfor, prep + 1); - luaK_fixline(fs, line); -} - - -static void fornum (LexState *ls, TString *varname, int line) { - /* fornum -> NAME = exp1,exp1[,exp1] forbody */ - FuncState *fs = ls->fs; - int base = fs->freereg; - new_localvarliteral(ls, "(for index)"); - new_localvarliteral(ls, "(for limit)"); - new_localvarliteral(ls, "(for step)"); - new_localvar(ls, varname); - checknext(ls, '='); - exp1(ls); /* initial value */ - checknext(ls, ','); - exp1(ls); /* limit */ - if (testnext(ls, ',')) - exp1(ls); /* optional step */ - else { /* default step = 1 */ - luaK_codek(fs, fs->freereg, luaK_numberK(fs, 1)); - luaK_reserveregs(fs, 1); - } - forbody(ls, base, line, 1, 1); -} - - -static void forlist (LexState *ls, TString *indexname) { - /* forlist -> NAME {,NAME} IN explist forbody */ - FuncState *fs = ls->fs; - expdesc e; - int nvars = 4; /* gen, state, control, plus at least one declared var */ - int line; - int base = fs->freereg; - /* create control variables */ - new_localvarliteral(ls, "(for generator)"); - new_localvarliteral(ls, "(for state)"); - new_localvarliteral(ls, "(for control)"); - /* create declared variables */ - new_localvar(ls, indexname); - while (testnext(ls, ',')) { - new_localvar(ls, str_checkname(ls)); - nvars++; - } - checknext(ls, TK_IN); - line = ls->linenumber; - adjust_assign(ls, 3, explist(ls, &e), &e); - luaK_checkstack(fs, 3); /* extra space to call generator */ - forbody(ls, base, line, nvars - 3, 0); -} - - -static void forstat (LexState *ls, int line) { - /* forstat -> FOR (fornum | forlist) END */ - FuncState *fs = ls->fs; - TString *varname; - BlockCnt bl; - enterblock(fs, &bl, 1); /* scope for loop and control variables */ - luaX_next(ls); /* skip `for' */ - varname = str_checkname(ls); /* first variable name */ - switch (ls->t.token) { - case '=': fornum(ls, varname, line); break; - case ',': case TK_IN: forlist(ls, varname); break; - default: luaX_syntaxerror(ls, LUA_QL("=") " or " LUA_QL("in") " expected"); - } - check_match(ls, TK_END, TK_FOR, line); - leaveblock(fs); /* loop scope (`break' jumps to this point) */ -} - - -static void test_then_block (LexState *ls, int *escapelist) { - /* test_then_block -> [IF | ELSEIF] cond THEN block */ - BlockCnt bl; - FuncState *fs = ls->fs; - expdesc v; - int jf; /* instruction to skip 'then' code (if condition is false) */ - luaX_next(ls); /* skip IF or ELSEIF */ - expr(ls, &v); /* read condition */ - checknext(ls, TK_THEN); - if (ls->t.token == TK_GOTO || ls->t.token == TK_BREAK) { - luaK_goiffalse(ls->fs, &v); /* will jump to label if condition is true */ - enterblock(fs, &bl, 0); /* must enter block before 'goto' */ - gotostat(ls, v.t); /* handle goto/break */ - skipnoopstat(ls); /* skip other no-op statements */ - if (block_follow(ls, 0)) { /* 'goto' is the entire block? */ - leaveblock(fs); - return; /* and that is it */ - } - else /* must skip over 'then' part if condition is false */ - jf = luaK_jump(fs); - } - else { /* regular case (not goto/break) */ - luaK_goiftrue(ls->fs, &v); /* skip over block if condition is false */ - enterblock(fs, &bl, 0); - jf = v.f; - } - statlist(ls); /* `then' part */ - leaveblock(fs); - if (ls->t.token == TK_ELSE || - ls->t.token == TK_ELSEIF) /* followed by 'else'/'elseif'? */ - luaK_concat(fs, escapelist, luaK_jump(fs)); /* must jump over it */ - luaK_patchtohere(fs, jf); -} - - -static void ifstat (LexState *ls, int line) { - /* ifstat -> IF cond THEN block {ELSEIF cond THEN block} [ELSE block] END */ - FuncState *fs = ls->fs; - int escapelist = NO_JUMP; /* exit list for finished parts */ - test_then_block(ls, &escapelist); /* IF cond THEN block */ - while (ls->t.token == TK_ELSEIF) - test_then_block(ls, &escapelist); /* ELSEIF cond THEN block */ - if (testnext(ls, TK_ELSE)) - block(ls); /* `else' part */ - check_match(ls, TK_END, TK_IF, line); - luaK_patchtohere(fs, escapelist); /* patch escape list to 'if' end */ -} - - -static void localfunc (LexState *ls) { - expdesc b; - FuncState *fs = ls->fs; - new_localvar(ls, str_checkname(ls)); /* new local variable */ - adjustlocalvars(ls, 1); /* enter its scope */ - body(ls, &b, 0, ls->linenumber); /* function created in next register */ - /* debug information will only see the variable after this point! */ - getlocvar(fs, b.u.info)->startpc = fs->pc; -} - - -static void localstat (LexState *ls) { - /* stat -> LOCAL NAME {`,' NAME} [`=' explist] */ - int nvars = 0; - int nexps; - expdesc e; - do { - new_localvar(ls, str_checkname(ls)); - nvars++; - } while (testnext(ls, ',')); - if (testnext(ls, '=')) - nexps = explist(ls, &e); - else { - e.k = VVOID; - nexps = 0; - } - adjust_assign(ls, nvars, nexps, &e); - adjustlocalvars(ls, nvars); -} - - -static int funcname (LexState *ls, expdesc *v) { - /* funcname -> NAME {fieldsel} [`:' NAME] */ - int ismethod = 0; - singlevar(ls, v); - while (ls->t.token == '.') - fieldsel(ls, v); - if (ls->t.token == ':') { - ismethod = 1; - fieldsel(ls, v); - } - return ismethod; -} - - -static void funcstat (LexState *ls, int line) { - /* funcstat -> FUNCTION funcname body */ - int ismethod; - expdesc v, b; - luaX_next(ls); /* skip FUNCTION */ - ismethod = funcname(ls, &v); - body(ls, &b, ismethod, line); - luaK_storevar(ls->fs, &v, &b); - luaK_fixline(ls->fs, line); /* definition `happens' in the first line */ -} - - -static void exprstat (LexState *ls) { - /* stat -> func | assignment */ - FuncState *fs = ls->fs; - struct LHS_assign v; - suffixedexp(ls, &v.v); - if (ls->t.token == '=' || ls->t.token == ',') { /* stat -> assignment ? */ - v.prev = NULL; - assignment(ls, &v, 1); - } - else { /* stat -> func */ - check_condition(ls, v.v.k == VCALL, "syntax error"); - SETARG_C(getcode(fs, &v.v), 1); /* call statement uses no results */ - } -} - - -static void retstat (LexState *ls) { - /* stat -> RETURN [explist] [';'] */ - FuncState *fs = ls->fs; - expdesc e; - int first, nret; /* registers with returned values */ - if (block_follow(ls, 1) || ls->t.token == ';') - first = nret = 0; /* return no values */ - else { - nret = explist(ls, &e); /* optional return values */ - if (hasmultret(e.k)) { - luaK_setmultret(fs, &e); - if (e.k == VCALL && nret == 1) { /* tail call? */ - SET_OPCODE(getcode(fs,&e), OP_TAILCALL); - lua_assert(GETARG_A(getcode(fs,&e)) == fs->nactvar); - } - first = fs->nactvar; - nret = LUA_MULTRET; /* return all values */ - } - else { - if (nret == 1) /* only one single value? */ - first = luaK_exp2anyreg(fs, &e); - else { - luaK_exp2nextreg(fs, &e); /* values must go to the `stack' */ - first = fs->nactvar; /* return all `active' values */ - lua_assert(nret == fs->freereg - first); - } - } - } - luaK_ret(fs, first, nret); - testnext(ls, ';'); /* skip optional semicolon */ -} - - -static void statement (LexState *ls) { - int line = ls->linenumber; /* may be needed for error messages */ - enterlevel(ls); - switch (ls->t.token) { - case ';': { /* stat -> ';' (empty statement) */ - luaX_next(ls); /* skip ';' */ - break; - } - case TK_IF: { /* stat -> ifstat */ - ifstat(ls, line); - break; - } - case TK_WHILE: { /* stat -> whilestat */ - whilestat(ls, line); - break; - } - case TK_DO: { /* stat -> DO block END */ - luaX_next(ls); /* skip DO */ - block(ls); - check_match(ls, TK_END, TK_DO, line); - break; - } - case TK_FOR: { /* stat -> forstat */ - forstat(ls, line); - break; - } - case TK_REPEAT: { /* stat -> repeatstat */ - repeatstat(ls, line); - break; - } - case TK_FUNCTION: { /* stat -> funcstat */ - funcstat(ls, line); - break; - } - case TK_LOCAL: { /* stat -> localstat */ - luaX_next(ls); /* skip LOCAL */ - if (testnext(ls, TK_FUNCTION)) /* local function? */ - localfunc(ls); - else - localstat(ls); - break; - } - case TK_DBCOLON: { /* stat -> label */ - luaX_next(ls); /* skip double colon */ - labelstat(ls, str_checkname(ls), line); - break; - } - case TK_RETURN: { /* stat -> retstat */ - luaX_next(ls); /* skip RETURN */ - retstat(ls); - break; - } - case TK_BREAK: /* stat -> breakstat */ - case TK_GOTO: { /* stat -> 'goto' NAME */ - gotostat(ls, luaK_jump(ls->fs)); - break; - } - default: { /* stat -> func | assignment */ - exprstat(ls); - break; - } - } - lua_assert(ls->fs->f->maxstacksize >= ls->fs->freereg && - ls->fs->freereg >= ls->fs->nactvar); - ls->fs->freereg = ls->fs->nactvar; /* free registers */ - leavelevel(ls); -} - -/* }====================================================================== */ - - -/* -** compiles the main function, which is a regular vararg function with an -** upvalue named LUA_ENV -*/ -static void mainfunc (LexState *ls, FuncState *fs) { - BlockCnt bl; - expdesc v; - open_func(ls, fs, &bl); - fs->f->is_vararg = 1; /* main function is always vararg */ - init_exp(&v, VLOCAL, 0); /* create and... */ - newupvalue(fs, ls->envn, &v); /* ...set environment upvalue */ - luaX_next(ls); /* read first token */ - statlist(ls); /* parse main body */ - check(ls, TK_EOS); - close_func(ls); -} - - -Closure *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, - Dyndata *dyd, const char *name, int firstchar) { - LexState lexstate; - FuncState funcstate; - Closure *cl = luaF_newLclosure(L, 1); /* create main closure */ - /* anchor closure (to avoid being collected) */ - setclLvalue(L, L->top, cl); - incr_top(L); - funcstate.f = cl->l.p = luaF_newproto(L); - funcstate.f->source = luaS_new(L, name); /* create and anchor TString */ - lexstate.buff = buff; - lexstate.dyd = dyd; - dyd->actvar.n = dyd->gt.n = dyd->label.n = 0; - luaX_setinput(L, &lexstate, z, funcstate.f->source, firstchar); - mainfunc(&lexstate, &funcstate); - lua_assert(!funcstate.prev && funcstate.nups == 1 && !lexstate.fs); - /* all scopes should be correctly finished */ - lua_assert(dyd->actvar.n == 0 && dyd->gt.n == 0 && dyd->label.n == 0); - return cl; /* it's on the stack too */ -} - diff --git a/btgui/lua-5.2.3/src/lparser.h b/btgui/lua-5.2.3/src/lparser.h deleted file mode 100644 index 0346e3c41..000000000 --- a/btgui/lua-5.2.3/src/lparser.h +++ /dev/null @@ -1,119 +0,0 @@ -/* -** $Id: lparser.h,v 1.70.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua Parser -** See Copyright Notice in lua.h -*/ - -#ifndef lparser_h -#define lparser_h - -#include "llimits.h" -#include "lobject.h" -#include "lzio.h" - - -/* -** Expression descriptor -*/ - -typedef enum { - VVOID, /* no value */ - VNIL, - VTRUE, - VFALSE, - VK, /* info = index of constant in `k' */ - VKNUM, /* nval = numerical value */ - VNONRELOC, /* info = result register */ - VLOCAL, /* info = local register */ - VUPVAL, /* info = index of upvalue in 'upvalues' */ - VINDEXED, /* t = table register/upvalue; idx = index R/K */ - VJMP, /* info = instruction pc */ - VRELOCABLE, /* info = instruction pc */ - VCALL, /* info = instruction pc */ - VVARARG /* info = instruction pc */ -} expkind; - - -#define vkisvar(k) (VLOCAL <= (k) && (k) <= VINDEXED) -#define vkisinreg(k) ((k) == VNONRELOC || (k) == VLOCAL) - -typedef struct expdesc { - expkind k; - union { - struct { /* for indexed variables (VINDEXED) */ - short idx; /* index (R/K) */ - lu_byte t; /* table (register or upvalue) */ - lu_byte vt; /* whether 't' is register (VLOCAL) or upvalue (VUPVAL) */ - } ind; - int info; /* for generic use */ - lua_Number nval; /* for VKNUM */ - } u; - int t; /* patch list of `exit when true' */ - int f; /* patch list of `exit when false' */ -} expdesc; - - -/* description of active local variable */ -typedef struct Vardesc { - short idx; /* variable index in stack */ -} Vardesc; - - -/* description of pending goto statements and label statements */ -typedef struct Labeldesc { - TString *name; /* label identifier */ - int pc; /* position in code */ - int line; /* line where it appeared */ - lu_byte nactvar; /* local level where it appears in current block */ -} Labeldesc; - - -/* list of labels or gotos */ -typedef struct Labellist { - Labeldesc *arr; /* array */ - int n; /* number of entries in use */ - int size; /* array size */ -} Labellist; - - -/* dynamic structures used by the parser */ -typedef struct Dyndata { - struct { /* list of active local variables */ - Vardesc *arr; - int n; - int size; - } actvar; - Labellist gt; /* list of pending gotos */ - Labellist label; /* list of active labels */ -} Dyndata; - - -/* control of blocks */ -struct BlockCnt; /* defined in lparser.c */ - - -/* state needed to generate code for a given function */ -typedef struct FuncState { - Proto *f; /* current function header */ - Table *h; /* table to find (and reuse) elements in `k' */ - struct FuncState *prev; /* enclosing function */ - struct LexState *ls; /* lexical state */ - struct BlockCnt *bl; /* chain of current blocks */ - int pc; /* next position to code (equivalent to `ncode') */ - int lasttarget; /* 'label' of last 'jump label' */ - int jpc; /* list of pending jumps to `pc' */ - int nk; /* number of elements in `k' */ - int np; /* number of elements in `p' */ - int firstlocal; /* index of first local var (in Dyndata array) */ - short nlocvars; /* number of elements in 'f->locvars' */ - lu_byte nactvar; /* number of active local variables */ - lu_byte nups; /* number of upvalues */ - lu_byte freereg; /* first free register */ -} FuncState; - - -LUAI_FUNC Closure *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, - Dyndata *dyd, const char *name, int firstchar); - - -#endif diff --git a/btgui/lua-5.2.3/src/lstate.c b/btgui/lua-5.2.3/src/lstate.c deleted file mode 100644 index c7f2672be..000000000 --- a/btgui/lua-5.2.3/src/lstate.c +++ /dev/null @@ -1,323 +0,0 @@ -/* -** $Id: lstate.c,v 2.99.1.2 2013/11/08 17:45:31 roberto Exp $ -** Global State -** See Copyright Notice in lua.h -*/ - - -#include -#include - -#define lstate_c -#define LUA_CORE - -#include "lua.h" - -#include "lapi.h" -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lgc.h" -#include "llex.h" -#include "lmem.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" - - -#if !defined(LUAI_GCPAUSE) -#define LUAI_GCPAUSE 200 /* 200% */ -#endif - -#if !defined(LUAI_GCMAJOR) -#define LUAI_GCMAJOR 200 /* 200% */ -#endif - -#if !defined(LUAI_GCMUL) -#define LUAI_GCMUL 200 /* GC runs 'twice the speed' of memory allocation */ -#endif - - -#define MEMERRMSG "not enough memory" - - -/* -** a macro to help the creation of a unique random seed when a state is -** created; the seed is used to randomize hashes. -*/ -#if !defined(luai_makeseed) -#include -#define luai_makeseed() cast(unsigned int, time(NULL)) -#endif - - - -/* -** thread state + extra space -*/ -typedef struct LX { -#if defined(LUAI_EXTRASPACE) - char buff[LUAI_EXTRASPACE]; -#endif - lua_State l; -} LX; - - -/* -** Main thread combines a thread state and the global state -*/ -typedef struct LG { - LX l; - global_State g; -} LG; - - - -#define fromstate(L) (cast(LX *, cast(lu_byte *, (L)) - offsetof(LX, l))) - - -/* -** Compute an initial seed as random as possible. In ANSI, rely on -** Address Space Layout Randomization (if present) to increase -** randomness.. -*/ -#define addbuff(b,p,e) \ - { size_t t = cast(size_t, e); \ - memcpy(buff + p, &t, sizeof(t)); p += sizeof(t); } - -static unsigned int makeseed (lua_State *L) { - char buff[4 * sizeof(size_t)]; - unsigned int h = luai_makeseed(); - int p = 0; - addbuff(buff, p, L); /* heap variable */ - addbuff(buff, p, &h); /* local variable */ - addbuff(buff, p, luaO_nilobject); /* global variable */ - addbuff(buff, p, &lua_newstate); /* public function */ - lua_assert(p == sizeof(buff)); - return luaS_hash(buff, p, h); -} - - -/* -** set GCdebt to a new value keeping the value (totalbytes + GCdebt) -** invariant -*/ -void luaE_setdebt (global_State *g, l_mem debt) { - g->totalbytes -= (debt - g->GCdebt); - g->GCdebt = debt; -} - - -CallInfo *luaE_extendCI (lua_State *L) { - CallInfo *ci = luaM_new(L, CallInfo); - lua_assert(L->ci->next == NULL); - L->ci->next = ci; - ci->previous = L->ci; - ci->next = NULL; - return ci; -} - - -void luaE_freeCI (lua_State *L) { - CallInfo *ci = L->ci; - CallInfo *next = ci->next; - ci->next = NULL; - while ((ci = next) != NULL) { - next = ci->next; - luaM_free(L, ci); - } -} - - -static void stack_init (lua_State *L1, lua_State *L) { - int i; CallInfo *ci; - /* initialize stack array */ - L1->stack = luaM_newvector(L, BASIC_STACK_SIZE, TValue); - L1->stacksize = BASIC_STACK_SIZE; - for (i = 0; i < BASIC_STACK_SIZE; i++) - setnilvalue(L1->stack + i); /* erase new stack */ - L1->top = L1->stack; - L1->stack_last = L1->stack + L1->stacksize - EXTRA_STACK; - /* initialize first ci */ - ci = &L1->base_ci; - ci->next = ci->previous = NULL; - ci->callstatus = 0; - ci->func = L1->top; - setnilvalue(L1->top++); /* 'function' entry for this 'ci' */ - ci->top = L1->top + LUA_MINSTACK; - L1->ci = ci; -} - - -static void freestack (lua_State *L) { - if (L->stack == NULL) - return; /* stack not completely built yet */ - L->ci = &L->base_ci; /* free the entire 'ci' list */ - luaE_freeCI(L); - luaM_freearray(L, L->stack, L->stacksize); /* free stack array */ -} - - -/* -** Create registry table and its predefined values -*/ -static void init_registry (lua_State *L, global_State *g) { - TValue mt; - /* create registry */ - Table *registry = luaH_new(L); - sethvalue(L, &g->l_registry, registry); - luaH_resize(L, registry, LUA_RIDX_LAST, 0); - /* registry[LUA_RIDX_MAINTHREAD] = L */ - setthvalue(L, &mt, L); - luaH_setint(L, registry, LUA_RIDX_MAINTHREAD, &mt); - /* registry[LUA_RIDX_GLOBALS] = table of globals */ - sethvalue(L, &mt, luaH_new(L)); - luaH_setint(L, registry, LUA_RIDX_GLOBALS, &mt); -} - - -/* -** open parts of the state that may cause memory-allocation errors -*/ -static void f_luaopen (lua_State *L, void *ud) { - global_State *g = G(L); - UNUSED(ud); - stack_init(L, L); /* init stack */ - init_registry(L, g); - luaS_resize(L, MINSTRTABSIZE); /* initial size of string table */ - luaT_init(L); - luaX_init(L); - /* pre-create memory-error message */ - g->memerrmsg = luaS_newliteral(L, MEMERRMSG); - luaS_fix(g->memerrmsg); /* it should never be collected */ - g->gcrunning = 1; /* allow gc */ - g->version = lua_version(NULL); - luai_userstateopen(L); -} - - -/* -** preinitialize a state with consistent values without allocating -** any memory (to avoid errors) -*/ -static void preinit_state (lua_State *L, global_State *g) { - G(L) = g; - L->stack = NULL; - L->ci = NULL; - L->stacksize = 0; - L->errorJmp = NULL; - L->nCcalls = 0; - L->hook = NULL; - L->hookmask = 0; - L->basehookcount = 0; - L->allowhook = 1; - resethookcount(L); - L->openupval = NULL; - L->nny = 1; - L->status = LUA_OK; - L->errfunc = 0; -} - - -static void close_state (lua_State *L) { - global_State *g = G(L); - luaF_close(L, L->stack); /* close all upvalues for this thread */ - luaC_freeallobjects(L); /* collect all objects */ - if (g->version) /* closing a fully built state? */ - luai_userstateclose(L); - luaM_freearray(L, G(L)->strt.hash, G(L)->strt.size); - luaZ_freebuffer(L, &g->buff); - freestack(L); - lua_assert(gettotalbytes(g) == sizeof(LG)); - (*g->frealloc)(g->ud, fromstate(L), sizeof(LG), 0); /* free main block */ -} - - -LUA_API lua_State *lua_newthread (lua_State *L) { - lua_State *L1; - lua_lock(L); - luaC_checkGC(L); - L1 = &luaC_newobj(L, LUA_TTHREAD, sizeof(LX), NULL, offsetof(LX, l))->th; - setthvalue(L, L->top, L1); - api_incr_top(L); - preinit_state(L1, G(L)); - L1->hookmask = L->hookmask; - L1->basehookcount = L->basehookcount; - L1->hook = L->hook; - resethookcount(L1); - luai_userstatethread(L, L1); - stack_init(L1, L); /* init stack */ - lua_unlock(L); - return L1; -} - - -void luaE_freethread (lua_State *L, lua_State *L1) { - LX *l = fromstate(L1); - luaF_close(L1, L1->stack); /* close all upvalues for this thread */ - lua_assert(L1->openupval == NULL); - luai_userstatefree(L, L1); - freestack(L1); - luaM_free(L, l); -} - - -LUA_API lua_State *lua_newstate (lua_Alloc f, void *ud) { - int i; - lua_State *L; - global_State *g; - LG *l = cast(LG *, (*f)(ud, NULL, LUA_TTHREAD, sizeof(LG))); - if (l == NULL) return NULL; - L = &l->l.l; - g = &l->g; - L->next = NULL; - L->tt = LUA_TTHREAD; - g->currentwhite = bit2mask(WHITE0BIT, FIXEDBIT); - L->marked = luaC_white(g); - g->gckind = KGC_NORMAL; - preinit_state(L, g); - g->frealloc = f; - g->ud = ud; - g->mainthread = L; - g->seed = makeseed(L); - g->uvhead.u.l.prev = &g->uvhead; - g->uvhead.u.l.next = &g->uvhead; - g->gcrunning = 0; /* no GC while building state */ - g->GCestimate = 0; - g->strt.size = 0; - g->strt.nuse = 0; - g->strt.hash = NULL; - setnilvalue(&g->l_registry); - luaZ_initbuffer(L, &g->buff); - g->panic = NULL; - g->version = NULL; - g->gcstate = GCSpause; - g->allgc = NULL; - g->finobj = NULL; - g->tobefnz = NULL; - g->sweepgc = g->sweepfin = NULL; - g->gray = g->grayagain = NULL; - g->weak = g->ephemeron = g->allweak = NULL; - g->totalbytes = sizeof(LG); - g->GCdebt = 0; - g->gcpause = LUAI_GCPAUSE; - g->gcmajorinc = LUAI_GCMAJOR; - g->gcstepmul = LUAI_GCMUL; - for (i=0; i < LUA_NUMTAGS; i++) g->mt[i] = NULL; - if (luaD_rawrunprotected(L, f_luaopen, NULL) != LUA_OK) { - /* memory allocation error: free partial state */ - close_state(L); - L = NULL; - } - return L; -} - - -LUA_API void lua_close (lua_State *L) { - L = G(L)->mainthread; /* only the main thread can be closed */ - lua_lock(L); - close_state(L); -} - - diff --git a/btgui/lua-5.2.3/src/lstate.h b/btgui/lua-5.2.3/src/lstate.h deleted file mode 100644 index daffd9aac..000000000 --- a/btgui/lua-5.2.3/src/lstate.h +++ /dev/null @@ -1,228 +0,0 @@ -/* -** $Id: lstate.h,v 2.82.1.1 2013/04/12 18:48:47 roberto Exp $ -** Global State -** See Copyright Notice in lua.h -*/ - -#ifndef lstate_h -#define lstate_h - -#include "lua.h" - -#include "lobject.h" -#include "ltm.h" -#include "lzio.h" - - -/* - -** Some notes about garbage-collected objects: All objects in Lua must -** be kept somehow accessible until being freed. -** -** Lua keeps most objects linked in list g->allgc. The link uses field -** 'next' of the CommonHeader. -** -** Strings are kept in several lists headed by the array g->strt.hash. -** -** Open upvalues are not subject to independent garbage collection. They -** are collected together with their respective threads. Lua keeps a -** double-linked list with all open upvalues (g->uvhead) so that it can -** mark objects referred by them. (They are always gray, so they must -** be remarked in the atomic step. Usually their contents would be marked -** when traversing the respective threads, but the thread may already be -** dead, while the upvalue is still accessible through closures.) -** -** Objects with finalizers are kept in the list g->finobj. -** -** The list g->tobefnz links all objects being finalized. - -*/ - - -struct lua_longjmp; /* defined in ldo.c */ - - - -/* extra stack space to handle TM calls and some other extras */ -#define EXTRA_STACK 5 - - -#define BASIC_STACK_SIZE (2*LUA_MINSTACK) - - -/* kinds of Garbage Collection */ -#define KGC_NORMAL 0 -#define KGC_EMERGENCY 1 /* gc was forced by an allocation failure */ -#define KGC_GEN 2 /* generational collection */ - - -typedef struct stringtable { - GCObject **hash; - lu_int32 nuse; /* number of elements */ - int size; -} stringtable; - - -/* -** information about a call -*/ -typedef struct CallInfo { - StkId func; /* function index in the stack */ - StkId top; /* top for this function */ - struct CallInfo *previous, *next; /* dynamic call link */ - short nresults; /* expected number of results from this function */ - lu_byte callstatus; - ptrdiff_t extra; - union { - struct { /* only for Lua functions */ - StkId base; /* base for this function */ - const Instruction *savedpc; - } l; - struct { /* only for C functions */ - int ctx; /* context info. in case of yields */ - lua_CFunction k; /* continuation in case of yields */ - ptrdiff_t old_errfunc; - lu_byte old_allowhook; - lu_byte status; - } c; - } u; -} CallInfo; - - -/* -** Bits in CallInfo status -*/ -#define CIST_LUA (1<<0) /* call is running a Lua function */ -#define CIST_HOOKED (1<<1) /* call is running a debug hook */ -#define CIST_REENTRY (1<<2) /* call is running on same invocation of - luaV_execute of previous call */ -#define CIST_YIELDED (1<<3) /* call reentered after suspension */ -#define CIST_YPCALL (1<<4) /* call is a yieldable protected call */ -#define CIST_STAT (1<<5) /* call has an error status (pcall) */ -#define CIST_TAIL (1<<6) /* call was tail called */ -#define CIST_HOOKYIELD (1<<7) /* last hook called yielded */ - - -#define isLua(ci) ((ci)->callstatus & CIST_LUA) - - -/* -** `global state', shared by all threads of this state -*/ -typedef struct global_State { - lua_Alloc frealloc; /* function to reallocate memory */ - void *ud; /* auxiliary data to `frealloc' */ - lu_mem totalbytes; /* number of bytes currently allocated - GCdebt */ - l_mem GCdebt; /* bytes allocated not yet compensated by the collector */ - lu_mem GCmemtrav; /* memory traversed by the GC */ - lu_mem GCestimate; /* an estimate of the non-garbage memory in use */ - stringtable strt; /* hash table for strings */ - TValue l_registry; - unsigned int seed; /* randomized seed for hashes */ - lu_byte currentwhite; - lu_byte gcstate; /* state of garbage collector */ - lu_byte gckind; /* kind of GC running */ - lu_byte gcrunning; /* true if GC is running */ - int sweepstrgc; /* position of sweep in `strt' */ - GCObject *allgc; /* list of all collectable objects */ - GCObject *finobj; /* list of collectable objects with finalizers */ - GCObject **sweepgc; /* current position of sweep in list 'allgc' */ - GCObject **sweepfin; /* current position of sweep in list 'finobj' */ - GCObject *gray; /* list of gray objects */ - GCObject *grayagain; /* list of objects to be traversed atomically */ - GCObject *weak; /* list of tables with weak values */ - GCObject *ephemeron; /* list of ephemeron tables (weak keys) */ - GCObject *allweak; /* list of all-weak tables */ - GCObject *tobefnz; /* list of userdata to be GC */ - UpVal uvhead; /* head of double-linked list of all open upvalues */ - Mbuffer buff; /* temporary buffer for string concatenation */ - int gcpause; /* size of pause between successive GCs */ - int gcmajorinc; /* pause between major collections (only in gen. mode) */ - int gcstepmul; /* GC `granularity' */ - lua_CFunction panic; /* to be called in unprotected errors */ - struct lua_State *mainthread; - const lua_Number *version; /* pointer to version number */ - TString *memerrmsg; /* memory-error message */ - TString *tmname[TM_N]; /* array with tag-method names */ - struct Table *mt[LUA_NUMTAGS]; /* metatables for basic types */ -} global_State; - - -/* -** `per thread' state -*/ -struct lua_State { - CommonHeader; - lu_byte status; - StkId top; /* first free slot in the stack */ - global_State *l_G; - CallInfo *ci; /* call info for current function */ - const Instruction *oldpc; /* last pc traced */ - StkId stack_last; /* last free slot in the stack */ - StkId stack; /* stack base */ - int stacksize; - unsigned short nny; /* number of non-yieldable calls in stack */ - unsigned short nCcalls; /* number of nested C calls */ - lu_byte hookmask; - lu_byte allowhook; - int basehookcount; - int hookcount; - lua_Hook hook; - GCObject *openupval; /* list of open upvalues in this stack */ - GCObject *gclist; - struct lua_longjmp *errorJmp; /* current error recover point */ - ptrdiff_t errfunc; /* current error handling function (stack index) */ - CallInfo base_ci; /* CallInfo for first level (C calling Lua) */ -}; - - -#define G(L) (L->l_G) - - -/* -** Union of all collectable objects -*/ -union GCObject { - GCheader gch; /* common header */ - union TString ts; - union Udata u; - union Closure cl; - struct Table h; - struct Proto p; - struct UpVal uv; - struct lua_State th; /* thread */ -}; - - -#define gch(o) (&(o)->gch) - -/* macros to convert a GCObject into a specific value */ -#define rawgco2ts(o) \ - check_exp(novariant((o)->gch.tt) == LUA_TSTRING, &((o)->ts)) -#define gco2ts(o) (&rawgco2ts(o)->tsv) -#define rawgco2u(o) check_exp((o)->gch.tt == LUA_TUSERDATA, &((o)->u)) -#define gco2u(o) (&rawgco2u(o)->uv) -#define gco2lcl(o) check_exp((o)->gch.tt == LUA_TLCL, &((o)->cl.l)) -#define gco2ccl(o) check_exp((o)->gch.tt == LUA_TCCL, &((o)->cl.c)) -#define gco2cl(o) \ - check_exp(novariant((o)->gch.tt) == LUA_TFUNCTION, &((o)->cl)) -#define gco2t(o) check_exp((o)->gch.tt == LUA_TTABLE, &((o)->h)) -#define gco2p(o) check_exp((o)->gch.tt == LUA_TPROTO, &((o)->p)) -#define gco2uv(o) check_exp((o)->gch.tt == LUA_TUPVAL, &((o)->uv)) -#define gco2th(o) check_exp((o)->gch.tt == LUA_TTHREAD, &((o)->th)) - -/* macro to convert any Lua object into a GCObject */ -#define obj2gco(v) (cast(GCObject *, (v))) - - -/* actual number of total bytes allocated */ -#define gettotalbytes(g) ((g)->totalbytes + (g)->GCdebt) - -LUAI_FUNC void luaE_setdebt (global_State *g, l_mem debt); -LUAI_FUNC void luaE_freethread (lua_State *L, lua_State *L1); -LUAI_FUNC CallInfo *luaE_extendCI (lua_State *L); -LUAI_FUNC void luaE_freeCI (lua_State *L); - - -#endif - diff --git a/btgui/lua-5.2.3/src/lstring.c b/btgui/lua-5.2.3/src/lstring.c deleted file mode 100644 index af96c89c1..000000000 --- a/btgui/lua-5.2.3/src/lstring.c +++ /dev/null @@ -1,185 +0,0 @@ -/* -** $Id: lstring.c,v 2.26.1.1 2013/04/12 18:48:47 roberto Exp $ -** String table (keeps all strings handled by Lua) -** See Copyright Notice in lua.h -*/ - - -#include - -#define lstring_c -#define LUA_CORE - -#include "lua.h" - -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" -#include "lstring.h" - - -/* -** Lua will use at most ~(2^LUAI_HASHLIMIT) bytes from a string to -** compute its hash -*/ -#if !defined(LUAI_HASHLIMIT) -#define LUAI_HASHLIMIT 5 -#endif - - -/* -** equality for long strings -*/ -int luaS_eqlngstr (TString *a, TString *b) { - size_t len = a->tsv.len; - lua_assert(a->tsv.tt == LUA_TLNGSTR && b->tsv.tt == LUA_TLNGSTR); - return (a == b) || /* same instance or... */ - ((len == b->tsv.len) && /* equal length and ... */ - (memcmp(getstr(a), getstr(b), len) == 0)); /* equal contents */ -} - - -/* -** equality for strings -*/ -int luaS_eqstr (TString *a, TString *b) { - return (a->tsv.tt == b->tsv.tt) && - (a->tsv.tt == LUA_TSHRSTR ? eqshrstr(a, b) : luaS_eqlngstr(a, b)); -} - - -unsigned int luaS_hash (const char *str, size_t l, unsigned int seed) { - unsigned int h = seed ^ cast(unsigned int, l); - size_t l1; - size_t step = (l >> LUAI_HASHLIMIT) + 1; - for (l1 = l; l1 >= step; l1 -= step) - h = h ^ ((h<<5) + (h>>2) + cast_byte(str[l1 - 1])); - return h; -} - - -/* -** resizes the string table -*/ -void luaS_resize (lua_State *L, int newsize) { - int i; - stringtable *tb = &G(L)->strt; - /* cannot resize while GC is traversing strings */ - luaC_runtilstate(L, ~bitmask(GCSsweepstring)); - if (newsize > tb->size) { - luaM_reallocvector(L, tb->hash, tb->size, newsize, GCObject *); - for (i = tb->size; i < newsize; i++) tb->hash[i] = NULL; - } - /* rehash */ - for (i=0; isize; i++) { - GCObject *p = tb->hash[i]; - tb->hash[i] = NULL; - while (p) { /* for each node in the list */ - GCObject *next = gch(p)->next; /* save next */ - unsigned int h = lmod(gco2ts(p)->hash, newsize); /* new position */ - gch(p)->next = tb->hash[h]; /* chain it */ - tb->hash[h] = p; - resetoldbit(p); /* see MOVE OLD rule */ - p = next; - } - } - if (newsize < tb->size) { - /* shrinking slice must be empty */ - lua_assert(tb->hash[newsize] == NULL && tb->hash[tb->size - 1] == NULL); - luaM_reallocvector(L, tb->hash, tb->size, newsize, GCObject *); - } - tb->size = newsize; -} - - -/* -** creates a new string object -*/ -static TString *createstrobj (lua_State *L, const char *str, size_t l, - int tag, unsigned int h, GCObject **list) { - TString *ts; - size_t totalsize; /* total size of TString object */ - totalsize = sizeof(TString) + ((l + 1) * sizeof(char)); - ts = &luaC_newobj(L, tag, totalsize, list, 0)->ts; - ts->tsv.len = l; - ts->tsv.hash = h; - ts->tsv.extra = 0; - memcpy(ts+1, str, l*sizeof(char)); - ((char *)(ts+1))[l] = '\0'; /* ending 0 */ - return ts; -} - - -/* -** creates a new short string, inserting it into string table -*/ -static TString *newshrstr (lua_State *L, const char *str, size_t l, - unsigned int h) { - GCObject **list; /* (pointer to) list where it will be inserted */ - stringtable *tb = &G(L)->strt; - TString *s; - if (tb->nuse >= cast(lu_int32, tb->size) && tb->size <= MAX_INT/2) - luaS_resize(L, tb->size*2); /* too crowded */ - list = &tb->hash[lmod(h, tb->size)]; - s = createstrobj(L, str, l, LUA_TSHRSTR, h, list); - tb->nuse++; - return s; -} - - -/* -** checks whether short string exists and reuses it or creates a new one -*/ -static TString *internshrstr (lua_State *L, const char *str, size_t l) { - GCObject *o; - global_State *g = G(L); - unsigned int h = luaS_hash(str, l, g->seed); - for (o = g->strt.hash[lmod(h, g->strt.size)]; - o != NULL; - o = gch(o)->next) { - TString *ts = rawgco2ts(o); - if (h == ts->tsv.hash && - l == ts->tsv.len && - (memcmp(str, getstr(ts), l * sizeof(char)) == 0)) { - if (isdead(G(L), o)) /* string is dead (but was not collected yet)? */ - changewhite(o); /* resurrect it */ - return ts; - } - } - return newshrstr(L, str, l, h); /* not found; create a new string */ -} - - -/* -** new string (with explicit length) -*/ -TString *luaS_newlstr (lua_State *L, const char *str, size_t l) { - if (l <= LUAI_MAXSHORTLEN) /* short string? */ - return internshrstr(L, str, l); - else { - if (l + 1 > (MAX_SIZET - sizeof(TString))/sizeof(char)) - luaM_toobig(L); - return createstrobj(L, str, l, LUA_TLNGSTR, G(L)->seed, NULL); - } -} - - -/* -** new zero-terminated string -*/ -TString *luaS_new (lua_State *L, const char *str) { - return luaS_newlstr(L, str, strlen(str)); -} - - -Udata *luaS_newudata (lua_State *L, size_t s, Table *e) { - Udata *u; - if (s > MAX_SIZET - sizeof(Udata)) - luaM_toobig(L); - u = &luaC_newobj(L, LUA_TUSERDATA, sizeof(Udata) + s, NULL, 0)->u; - u->uv.len = s; - u->uv.metatable = NULL; - u->uv.env = e; - return u; -} - diff --git a/btgui/lua-5.2.3/src/lstring.h b/btgui/lua-5.2.3/src/lstring.h deleted file mode 100644 index 260e7f169..000000000 --- a/btgui/lua-5.2.3/src/lstring.h +++ /dev/null @@ -1,46 +0,0 @@ -/* -** $Id: lstring.h,v 1.49.1.1 2013/04/12 18:48:47 roberto Exp $ -** String table (keep all strings handled by Lua) -** See Copyright Notice in lua.h -*/ - -#ifndef lstring_h -#define lstring_h - -#include "lgc.h" -#include "lobject.h" -#include "lstate.h" - - -#define sizestring(s) (sizeof(union TString)+((s)->len+1)*sizeof(char)) - -#define sizeudata(u) (sizeof(union Udata)+(u)->len) - -#define luaS_newliteral(L, s) (luaS_newlstr(L, "" s, \ - (sizeof(s)/sizeof(char))-1)) - -#define luaS_fix(s) l_setbit((s)->tsv.marked, FIXEDBIT) - - -/* -** test whether a string is a reserved word -*/ -#define isreserved(s) ((s)->tsv.tt == LUA_TSHRSTR && (s)->tsv.extra > 0) - - -/* -** equality for short strings, which are always internalized -*/ -#define eqshrstr(a,b) check_exp((a)->tsv.tt == LUA_TSHRSTR, (a) == (b)) - - -LUAI_FUNC unsigned int luaS_hash (const char *str, size_t l, unsigned int seed); -LUAI_FUNC int luaS_eqlngstr (TString *a, TString *b); -LUAI_FUNC int luaS_eqstr (TString *a, TString *b); -LUAI_FUNC void luaS_resize (lua_State *L, int newsize); -LUAI_FUNC Udata *luaS_newudata (lua_State *L, size_t s, Table *e); -LUAI_FUNC TString *luaS_newlstr (lua_State *L, const char *str, size_t l); -LUAI_FUNC TString *luaS_new (lua_State *L, const char *str); - - -#endif diff --git a/btgui/lua-5.2.3/src/lstrlib.c b/btgui/lua-5.2.3/src/lstrlib.c deleted file mode 100644 index 9261fd220..000000000 --- a/btgui/lua-5.2.3/src/lstrlib.c +++ /dev/null @@ -1,1019 +0,0 @@ -/* -** $Id: lstrlib.c,v 1.178.1.1 2013/04/12 18:48:47 roberto Exp $ -** Standard library for string operations and pattern-matching -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include -#include -#include - -#define lstrlib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -/* -** maximum number of captures that a pattern can do during -** pattern-matching. This limit is arbitrary. -*/ -#if !defined(LUA_MAXCAPTURES) -#define LUA_MAXCAPTURES 32 -#endif - - -/* macro to `unsign' a character */ -#define uchar(c) ((unsigned char)(c)) - - - -static int str_len (lua_State *L) { - size_t l; - luaL_checklstring(L, 1, &l); - lua_pushinteger(L, (lua_Integer)l); - return 1; -} - - -/* translate a relative string position: negative means back from end */ -static size_t posrelat (ptrdiff_t pos, size_t len) { - if (pos >= 0) return (size_t)pos; - else if (0u - (size_t)pos > len) return 0; - else return len - ((size_t)-pos) + 1; -} - - -static int str_sub (lua_State *L) { - size_t l; - const char *s = luaL_checklstring(L, 1, &l); - size_t start = posrelat(luaL_checkinteger(L, 2), l); - size_t end = posrelat(luaL_optinteger(L, 3, -1), l); - if (start < 1) start = 1; - if (end > l) end = l; - if (start <= end) - lua_pushlstring(L, s + start - 1, end - start + 1); - else lua_pushliteral(L, ""); - return 1; -} - - -static int str_reverse (lua_State *L) { - size_t l, i; - luaL_Buffer b; - const char *s = luaL_checklstring(L, 1, &l); - char *p = luaL_buffinitsize(L, &b, l); - for (i = 0; i < l; i++) - p[i] = s[l - i - 1]; - luaL_pushresultsize(&b, l); - return 1; -} - - -static int str_lower (lua_State *L) { - size_t l; - size_t i; - luaL_Buffer b; - const char *s = luaL_checklstring(L, 1, &l); - char *p = luaL_buffinitsize(L, &b, l); - for (i=0; i> 1) - -static int str_rep (lua_State *L) { - size_t l, lsep; - const char *s = luaL_checklstring(L, 1, &l); - int n = luaL_checkint(L, 2); - const char *sep = luaL_optlstring(L, 3, "", &lsep); - if (n <= 0) lua_pushliteral(L, ""); - else if (l + lsep < l || l + lsep >= MAXSIZE / n) /* may overflow? */ - return luaL_error(L, "resulting string too large"); - else { - size_t totallen = n * l + (n - 1) * lsep; - luaL_Buffer b; - char *p = luaL_buffinitsize(L, &b, totallen); - while (n-- > 1) { /* first n-1 copies (followed by separator) */ - memcpy(p, s, l * sizeof(char)); p += l; - if (lsep > 0) { /* avoid empty 'memcpy' (may be expensive) */ - memcpy(p, sep, lsep * sizeof(char)); p += lsep; - } - } - memcpy(p, s, l * sizeof(char)); /* last copy (not followed by separator) */ - luaL_pushresultsize(&b, totallen); - } - return 1; -} - - -static int str_byte (lua_State *L) { - size_t l; - const char *s = luaL_checklstring(L, 1, &l); - size_t posi = posrelat(luaL_optinteger(L, 2, 1), l); - size_t pose = posrelat(luaL_optinteger(L, 3, posi), l); - int n, i; - if (posi < 1) posi = 1; - if (pose > l) pose = l; - if (posi > pose) return 0; /* empty interval; return no values */ - n = (int)(pose - posi + 1); - if (posi + n <= pose) /* (size_t -> int) overflow? */ - return luaL_error(L, "string slice too long"); - luaL_checkstack(L, n, "string slice too long"); - for (i=0; i= ms->level || ms->capture[l].len == CAP_UNFINISHED) - return luaL_error(ms->L, "invalid capture index %%%d", l + 1); - return l; -} - - -static int capture_to_close (MatchState *ms) { - int level = ms->level; - for (level--; level>=0; level--) - if (ms->capture[level].len == CAP_UNFINISHED) return level; - return luaL_error(ms->L, "invalid pattern capture"); -} - - -static const char *classend (MatchState *ms, const char *p) { - switch (*p++) { - case L_ESC: { - if (p == ms->p_end) - luaL_error(ms->L, "malformed pattern (ends with " LUA_QL("%%") ")"); - return p+1; - } - case '[': { - if (*p == '^') p++; - do { /* look for a `]' */ - if (p == ms->p_end) - luaL_error(ms->L, "malformed pattern (missing " LUA_QL("]") ")"); - if (*(p++) == L_ESC && p < ms->p_end) - p++; /* skip escapes (e.g. `%]') */ - } while (*p != ']'); - return p+1; - } - default: { - return p; - } - } -} - - -static int match_class (int c, int cl) { - int res; - switch (tolower(cl)) { - case 'a' : res = isalpha(c); break; - case 'c' : res = iscntrl(c); break; - case 'd' : res = isdigit(c); break; - case 'g' : res = isgraph(c); break; - case 'l' : res = islower(c); break; - case 'p' : res = ispunct(c); break; - case 's' : res = isspace(c); break; - case 'u' : res = isupper(c); break; - case 'w' : res = isalnum(c); break; - case 'x' : res = isxdigit(c); break; - case 'z' : res = (c == 0); break; /* deprecated option */ - default: return (cl == c); - } - return (islower(cl) ? res : !res); -} - - -static int matchbracketclass (int c, const char *p, const char *ec) { - int sig = 1; - if (*(p+1) == '^') { - sig = 0; - p++; /* skip the `^' */ - } - while (++p < ec) { - if (*p == L_ESC) { - p++; - if (match_class(c, uchar(*p))) - return sig; - } - else if ((*(p+1) == '-') && (p+2 < ec)) { - p+=2; - if (uchar(*(p-2)) <= c && c <= uchar(*p)) - return sig; - } - else if (uchar(*p) == c) return sig; - } - return !sig; -} - - -static int singlematch (MatchState *ms, const char *s, const char *p, - const char *ep) { - if (s >= ms->src_end) - return 0; - else { - int c = uchar(*s); - switch (*p) { - case '.': return 1; /* matches any char */ - case L_ESC: return match_class(c, uchar(*(p+1))); - case '[': return matchbracketclass(c, p, ep-1); - default: return (uchar(*p) == c); - } - } -} - - -static const char *matchbalance (MatchState *ms, const char *s, - const char *p) { - if (p >= ms->p_end - 1) - luaL_error(ms->L, "malformed pattern " - "(missing arguments to " LUA_QL("%%b") ")"); - if (*s != *p) return NULL; - else { - int b = *p; - int e = *(p+1); - int cont = 1; - while (++s < ms->src_end) { - if (*s == e) { - if (--cont == 0) return s+1; - } - else if (*s == b) cont++; - } - } - return NULL; /* string ends out of balance */ -} - - -static const char *max_expand (MatchState *ms, const char *s, - const char *p, const char *ep) { - ptrdiff_t i = 0; /* counts maximum expand for item */ - while (singlematch(ms, s + i, p, ep)) - i++; - /* keeps trying to match with the maximum repetitions */ - while (i>=0) { - const char *res = match(ms, (s+i), ep+1); - if (res) return res; - i--; /* else didn't match; reduce 1 repetition to try again */ - } - return NULL; -} - - -static const char *min_expand (MatchState *ms, const char *s, - const char *p, const char *ep) { - for (;;) { - const char *res = match(ms, s, ep+1); - if (res != NULL) - return res; - else if (singlematch(ms, s, p, ep)) - s++; /* try with one more repetition */ - else return NULL; - } -} - - -static const char *start_capture (MatchState *ms, const char *s, - const char *p, int what) { - const char *res; - int level = ms->level; - if (level >= LUA_MAXCAPTURES) luaL_error(ms->L, "too many captures"); - ms->capture[level].init = s; - ms->capture[level].len = what; - ms->level = level+1; - if ((res=match(ms, s, p)) == NULL) /* match failed? */ - ms->level--; /* undo capture */ - return res; -} - - -static const char *end_capture (MatchState *ms, const char *s, - const char *p) { - int l = capture_to_close(ms); - const char *res; - ms->capture[l].len = s - ms->capture[l].init; /* close capture */ - if ((res = match(ms, s, p)) == NULL) /* match failed? */ - ms->capture[l].len = CAP_UNFINISHED; /* undo capture */ - return res; -} - - -static const char *match_capture (MatchState *ms, const char *s, int l) { - size_t len; - l = check_capture(ms, l); - len = ms->capture[l].len; - if ((size_t)(ms->src_end-s) >= len && - memcmp(ms->capture[l].init, s, len) == 0) - return s+len; - else return NULL; -} - - -static const char *match (MatchState *ms, const char *s, const char *p) { - if (ms->matchdepth-- == 0) - luaL_error(ms->L, "pattern too complex"); - init: /* using goto's to optimize tail recursion */ - if (p != ms->p_end) { /* end of pattern? */ - switch (*p) { - case '(': { /* start capture */ - if (*(p + 1) == ')') /* position capture? */ - s = start_capture(ms, s, p + 2, CAP_POSITION); - else - s = start_capture(ms, s, p + 1, CAP_UNFINISHED); - break; - } - case ')': { /* end capture */ - s = end_capture(ms, s, p + 1); - break; - } - case '$': { - if ((p + 1) != ms->p_end) /* is the `$' the last char in pattern? */ - goto dflt; /* no; go to default */ - s = (s == ms->src_end) ? s : NULL; /* check end of string */ - break; - } - case L_ESC: { /* escaped sequences not in the format class[*+?-]? */ - switch (*(p + 1)) { - case 'b': { /* balanced string? */ - s = matchbalance(ms, s, p + 2); - if (s != NULL) { - p += 4; goto init; /* return match(ms, s, p + 4); */ - } /* else fail (s == NULL) */ - break; - } - case 'f': { /* frontier? */ - const char *ep; char previous; - p += 2; - if (*p != '[') - luaL_error(ms->L, "missing " LUA_QL("[") " after " - LUA_QL("%%f") " in pattern"); - ep = classend(ms, p); /* points to what is next */ - previous = (s == ms->src_init) ? '\0' : *(s - 1); - if (!matchbracketclass(uchar(previous), p, ep - 1) && - matchbracketclass(uchar(*s), p, ep - 1)) { - p = ep; goto init; /* return match(ms, s, ep); */ - } - s = NULL; /* match failed */ - break; - } - case '0': case '1': case '2': case '3': - case '4': case '5': case '6': case '7': - case '8': case '9': { /* capture results (%0-%9)? */ - s = match_capture(ms, s, uchar(*(p + 1))); - if (s != NULL) { - p += 2; goto init; /* return match(ms, s, p + 2) */ - } - break; - } - default: goto dflt; - } - break; - } - default: dflt: { /* pattern class plus optional suffix */ - const char *ep = classend(ms, p); /* points to optional suffix */ - /* does not match at least once? */ - if (!singlematch(ms, s, p, ep)) { - if (*ep == '*' || *ep == '?' || *ep == '-') { /* accept empty? */ - p = ep + 1; goto init; /* return match(ms, s, ep + 1); */ - } - else /* '+' or no suffix */ - s = NULL; /* fail */ - } - else { /* matched once */ - switch (*ep) { /* handle optional suffix */ - case '?': { /* optional */ - const char *res; - if ((res = match(ms, s + 1, ep + 1)) != NULL) - s = res; - else { - p = ep + 1; goto init; /* else return match(ms, s, ep + 1); */ - } - break; - } - case '+': /* 1 or more repetitions */ - s++; /* 1 match already done */ - /* go through */ - case '*': /* 0 or more repetitions */ - s = max_expand(ms, s, p, ep); - break; - case '-': /* 0 or more repetitions (minimum) */ - s = min_expand(ms, s, p, ep); - break; - default: /* no suffix */ - s++; p = ep; goto init; /* return match(ms, s + 1, ep); */ - } - } - break; - } - } - } - ms->matchdepth++; - return s; -} - - - -static const char *lmemfind (const char *s1, size_t l1, - const char *s2, size_t l2) { - if (l2 == 0) return s1; /* empty strings are everywhere */ - else if (l2 > l1) return NULL; /* avoids a negative `l1' */ - else { - const char *init; /* to search for a `*s2' inside `s1' */ - l2--; /* 1st char will be checked by `memchr' */ - l1 = l1-l2; /* `s2' cannot be found after that */ - while (l1 > 0 && (init = (const char *)memchr(s1, *s2, l1)) != NULL) { - init++; /* 1st char is already checked */ - if (memcmp(init, s2+1, l2) == 0) - return init-1; - else { /* correct `l1' and `s1' to try again */ - l1 -= init-s1; - s1 = init; - } - } - return NULL; /* not found */ - } -} - - -static void push_onecapture (MatchState *ms, int i, const char *s, - const char *e) { - if (i >= ms->level) { - if (i == 0) /* ms->level == 0, too */ - lua_pushlstring(ms->L, s, e - s); /* add whole match */ - else - luaL_error(ms->L, "invalid capture index"); - } - else { - ptrdiff_t l = ms->capture[i].len; - if (l == CAP_UNFINISHED) luaL_error(ms->L, "unfinished capture"); - if (l == CAP_POSITION) - lua_pushinteger(ms->L, ms->capture[i].init - ms->src_init + 1); - else - lua_pushlstring(ms->L, ms->capture[i].init, l); - } -} - - -static int push_captures (MatchState *ms, const char *s, const char *e) { - int i; - int nlevels = (ms->level == 0 && s) ? 1 : ms->level; - luaL_checkstack(ms->L, nlevels, "too many captures"); - for (i = 0; i < nlevels; i++) - push_onecapture(ms, i, s, e); - return nlevels; /* number of strings pushed */ -} - - -/* check whether pattern has no special characters */ -static int nospecials (const char *p, size_t l) { - size_t upto = 0; - do { - if (strpbrk(p + upto, SPECIALS)) - return 0; /* pattern has a special character */ - upto += strlen(p + upto) + 1; /* may have more after \0 */ - } while (upto <= l); - return 1; /* no special chars found */ -} - - -static int str_find_aux (lua_State *L, int find) { - size_t ls, lp; - const char *s = luaL_checklstring(L, 1, &ls); - const char *p = luaL_checklstring(L, 2, &lp); - size_t init = posrelat(luaL_optinteger(L, 3, 1), ls); - if (init < 1) init = 1; - else if (init > ls + 1) { /* start after string's end? */ - lua_pushnil(L); /* cannot find anything */ - return 1; - } - /* explicit request or no special characters? */ - if (find && (lua_toboolean(L, 4) || nospecials(p, lp))) { - /* do a plain search */ - const char *s2 = lmemfind(s + init - 1, ls - init + 1, p, lp); - if (s2) { - lua_pushinteger(L, s2 - s + 1); - lua_pushinteger(L, s2 - s + lp); - return 2; - } - } - else { - MatchState ms; - const char *s1 = s + init - 1; - int anchor = (*p == '^'); - if (anchor) { - p++; lp--; /* skip anchor character */ - } - ms.L = L; - ms.matchdepth = MAXCCALLS; - ms.src_init = s; - ms.src_end = s + ls; - ms.p_end = p + lp; - do { - const char *res; - ms.level = 0; - lua_assert(ms.matchdepth == MAXCCALLS); - if ((res=match(&ms, s1, p)) != NULL) { - if (find) { - lua_pushinteger(L, s1 - s + 1); /* start */ - lua_pushinteger(L, res - s); /* end */ - return push_captures(&ms, NULL, 0) + 2; - } - else - return push_captures(&ms, s1, res); - } - } while (s1++ < ms.src_end && !anchor); - } - lua_pushnil(L); /* not found */ - return 1; -} - - -static int str_find (lua_State *L) { - return str_find_aux(L, 1); -} - - -static int str_match (lua_State *L) { - return str_find_aux(L, 0); -} - - -static int gmatch_aux (lua_State *L) { - MatchState ms; - size_t ls, lp; - const char *s = lua_tolstring(L, lua_upvalueindex(1), &ls); - const char *p = lua_tolstring(L, lua_upvalueindex(2), &lp); - const char *src; - ms.L = L; - ms.matchdepth = MAXCCALLS; - ms.src_init = s; - ms.src_end = s+ls; - ms.p_end = p + lp; - for (src = s + (size_t)lua_tointeger(L, lua_upvalueindex(3)); - src <= ms.src_end; - src++) { - const char *e; - ms.level = 0; - lua_assert(ms.matchdepth == MAXCCALLS); - if ((e = match(&ms, src, p)) != NULL) { - lua_Integer newstart = e-s; - if (e == src) newstart++; /* empty match? go at least one position */ - lua_pushinteger(L, newstart); - lua_replace(L, lua_upvalueindex(3)); - return push_captures(&ms, src, e); - } - } - return 0; /* not found */ -} - - -static int gmatch (lua_State *L) { - luaL_checkstring(L, 1); - luaL_checkstring(L, 2); - lua_settop(L, 2); - lua_pushinteger(L, 0); - lua_pushcclosure(L, gmatch_aux, 3); - return 1; -} - - -static void add_s (MatchState *ms, luaL_Buffer *b, const char *s, - const char *e) { - size_t l, i; - const char *news = lua_tolstring(ms->L, 3, &l); - for (i = 0; i < l; i++) { - if (news[i] != L_ESC) - luaL_addchar(b, news[i]); - else { - i++; /* skip ESC */ - if (!isdigit(uchar(news[i]))) { - if (news[i] != L_ESC) - luaL_error(ms->L, "invalid use of " LUA_QL("%c") - " in replacement string", L_ESC); - luaL_addchar(b, news[i]); - } - else if (news[i] == '0') - luaL_addlstring(b, s, e - s); - else { - push_onecapture(ms, news[i] - '1', s, e); - luaL_addvalue(b); /* add capture to accumulated result */ - } - } - } -} - - -static void add_value (MatchState *ms, luaL_Buffer *b, const char *s, - const char *e, int tr) { - lua_State *L = ms->L; - switch (tr) { - case LUA_TFUNCTION: { - int n; - lua_pushvalue(L, 3); - n = push_captures(ms, s, e); - lua_call(L, n, 1); - break; - } - case LUA_TTABLE: { - push_onecapture(ms, 0, s, e); - lua_gettable(L, 3); - break; - } - default: { /* LUA_TNUMBER or LUA_TSTRING */ - add_s(ms, b, s, e); - return; - } - } - if (!lua_toboolean(L, -1)) { /* nil or false? */ - lua_pop(L, 1); - lua_pushlstring(L, s, e - s); /* keep original text */ - } - else if (!lua_isstring(L, -1)) - luaL_error(L, "invalid replacement value (a %s)", luaL_typename(L, -1)); - luaL_addvalue(b); /* add result to accumulator */ -} - - -static int str_gsub (lua_State *L) { - size_t srcl, lp; - const char *src = luaL_checklstring(L, 1, &srcl); - const char *p = luaL_checklstring(L, 2, &lp); - int tr = lua_type(L, 3); - size_t max_s = luaL_optinteger(L, 4, srcl+1); - int anchor = (*p == '^'); - size_t n = 0; - MatchState ms; - luaL_Buffer b; - luaL_argcheck(L, tr == LUA_TNUMBER || tr == LUA_TSTRING || - tr == LUA_TFUNCTION || tr == LUA_TTABLE, 3, - "string/function/table expected"); - luaL_buffinit(L, &b); - if (anchor) { - p++; lp--; /* skip anchor character */ - } - ms.L = L; - ms.matchdepth = MAXCCALLS; - ms.src_init = src; - ms.src_end = src+srcl; - ms.p_end = p + lp; - while (n < max_s) { - const char *e; - ms.level = 0; - lua_assert(ms.matchdepth == MAXCCALLS); - e = match(&ms, src, p); - if (e) { - n++; - add_value(&ms, &b, src, e, tr); - } - if (e && e>src) /* non empty match? */ - src = e; /* skip it */ - else if (src < ms.src_end) - luaL_addchar(&b, *src++); - else break; - if (anchor) break; - } - luaL_addlstring(&b, src, ms.src_end-src); - luaL_pushresult(&b); - lua_pushinteger(L, n); /* number of substitutions */ - return 2; -} - -/* }====================================================== */ - - - -/* -** {====================================================== -** STRING FORMAT -** ======================================================= -*/ - -/* -** LUA_INTFRMLEN is the length modifier for integer conversions in -** 'string.format'; LUA_INTFRM_T is the integer type corresponding to -** the previous length -*/ -#if !defined(LUA_INTFRMLEN) /* { */ -#if defined(LUA_USE_LONGLONG) - -#define LUA_INTFRMLEN "ll" -#define LUA_INTFRM_T long long - -#else - -#define LUA_INTFRMLEN "l" -#define LUA_INTFRM_T long - -#endif -#endif /* } */ - - -/* -** LUA_FLTFRMLEN is the length modifier for float conversions in -** 'string.format'; LUA_FLTFRM_T is the float type corresponding to -** the previous length -*/ -#if !defined(LUA_FLTFRMLEN) - -#define LUA_FLTFRMLEN "" -#define LUA_FLTFRM_T double - -#endif - - -/* maximum size of each formatted item (> len(format('%99.99f', -1e308))) */ -#define MAX_ITEM 512 -/* valid flags in a format specification */ -#define FLAGS "-+ #0" -/* -** maximum size of each format specification (such as '%-099.99d') -** (+10 accounts for %99.99x plus margin of error) -*/ -#define MAX_FORMAT (sizeof(FLAGS) + sizeof(LUA_INTFRMLEN) + 10) - - -static void addquoted (lua_State *L, luaL_Buffer *b, int arg) { - size_t l; - const char *s = luaL_checklstring(L, arg, &l); - luaL_addchar(b, '"'); - while (l--) { - if (*s == '"' || *s == '\\' || *s == '\n') { - luaL_addchar(b, '\\'); - luaL_addchar(b, *s); - } - else if (*s == '\0' || iscntrl(uchar(*s))) { - char buff[10]; - if (!isdigit(uchar(*(s+1)))) - sprintf(buff, "\\%d", (int)uchar(*s)); - else - sprintf(buff, "\\%03d", (int)uchar(*s)); - luaL_addstring(b, buff); - } - else - luaL_addchar(b, *s); - s++; - } - luaL_addchar(b, '"'); -} - -static const char *scanformat (lua_State *L, const char *strfrmt, char *form) { - const char *p = strfrmt; - while (*p != '\0' && strchr(FLAGS, *p) != NULL) p++; /* skip flags */ - if ((size_t)(p - strfrmt) >= sizeof(FLAGS)/sizeof(char)) - luaL_error(L, "invalid format (repeated flags)"); - if (isdigit(uchar(*p))) p++; /* skip width */ - if (isdigit(uchar(*p))) p++; /* (2 digits at most) */ - if (*p == '.') { - p++; - if (isdigit(uchar(*p))) p++; /* skip precision */ - if (isdigit(uchar(*p))) p++; /* (2 digits at most) */ - } - if (isdigit(uchar(*p))) - luaL_error(L, "invalid format (width or precision too long)"); - *(form++) = '%'; - memcpy(form, strfrmt, (p - strfrmt + 1) * sizeof(char)); - form += p - strfrmt + 1; - *form = '\0'; - return p; -} - - -/* -** add length modifier into formats -*/ -static void addlenmod (char *form, const char *lenmod) { - size_t l = strlen(form); - size_t lm = strlen(lenmod); - char spec = form[l - 1]; - strcpy(form + l - 1, lenmod); - form[l + lm - 1] = spec; - form[l + lm] = '\0'; -} - - -static int str_format (lua_State *L) { - int top = lua_gettop(L); - int arg = 1; - size_t sfl; - const char *strfrmt = luaL_checklstring(L, arg, &sfl); - const char *strfrmt_end = strfrmt+sfl; - luaL_Buffer b; - luaL_buffinit(L, &b); - while (strfrmt < strfrmt_end) { - if (*strfrmt != L_ESC) - luaL_addchar(&b, *strfrmt++); - else if (*++strfrmt == L_ESC) - luaL_addchar(&b, *strfrmt++); /* %% */ - else { /* format item */ - char form[MAX_FORMAT]; /* to store the format (`%...') */ - char *buff = luaL_prepbuffsize(&b, MAX_ITEM); /* to put formatted item */ - int nb = 0; /* number of bytes in added item */ - if (++arg > top) - luaL_argerror(L, arg, "no value"); - strfrmt = scanformat(L, strfrmt, form); - switch (*strfrmt++) { - case 'c': { - nb = sprintf(buff, form, luaL_checkint(L, arg)); - break; - } - case 'd': case 'i': { - lua_Number n = luaL_checknumber(L, arg); - LUA_INTFRM_T ni = (LUA_INTFRM_T)n; - lua_Number diff = n - (lua_Number)ni; - luaL_argcheck(L, -1 < diff && diff < 1, arg, - "not a number in proper range"); - addlenmod(form, LUA_INTFRMLEN); - nb = sprintf(buff, form, ni); - break; - } - case 'o': case 'u': case 'x': case 'X': { - lua_Number n = luaL_checknumber(L, arg); - unsigned LUA_INTFRM_T ni = (unsigned LUA_INTFRM_T)n; - lua_Number diff = n - (lua_Number)ni; - luaL_argcheck(L, -1 < diff && diff < 1, arg, - "not a non-negative number in proper range"); - addlenmod(form, LUA_INTFRMLEN); - nb = sprintf(buff, form, ni); - break; - } - case 'e': case 'E': case 'f': -#if defined(LUA_USE_AFORMAT) - case 'a': case 'A': -#endif - case 'g': case 'G': { - addlenmod(form, LUA_FLTFRMLEN); - nb = sprintf(buff, form, (LUA_FLTFRM_T)luaL_checknumber(L, arg)); - break; - } - case 'q': { - addquoted(L, &b, arg); - break; - } - case 's': { - size_t l; - const char *s = luaL_tolstring(L, arg, &l); - if (!strchr(form, '.') && l >= 100) { - /* no precision and string is too long to be formatted; - keep original string */ - luaL_addvalue(&b); - break; - } - else { - nb = sprintf(buff, form, s); - lua_pop(L, 1); /* remove result from 'luaL_tolstring' */ - break; - } - } - default: { /* also treat cases `pnLlh' */ - return luaL_error(L, "invalid option " LUA_QL("%%%c") " to " - LUA_QL("format"), *(strfrmt - 1)); - } - } - luaL_addsize(&b, nb); - } - } - luaL_pushresult(&b); - return 1; -} - -/* }====================================================== */ - - -static const luaL_Reg strlib[] = { - {"byte", str_byte}, - {"char", str_char}, - {"dump", str_dump}, - {"find", str_find}, - {"format", str_format}, - {"gmatch", gmatch}, - {"gsub", str_gsub}, - {"len", str_len}, - {"lower", str_lower}, - {"match", str_match}, - {"rep", str_rep}, - {"reverse", str_reverse}, - {"sub", str_sub}, - {"upper", str_upper}, - {NULL, NULL} -}; - - -static void createmetatable (lua_State *L) { - lua_createtable(L, 0, 1); /* table to be metatable for strings */ - lua_pushliteral(L, ""); /* dummy string */ - lua_pushvalue(L, -2); /* copy table */ - lua_setmetatable(L, -2); /* set table as metatable for strings */ - lua_pop(L, 1); /* pop dummy string */ - lua_pushvalue(L, -2); /* get string library */ - lua_setfield(L, -2, "__index"); /* metatable.__index = string */ - lua_pop(L, 1); /* pop metatable */ -} - - -/* -** Open string library -*/ -LUAMOD_API int luaopen_string (lua_State *L) { - luaL_newlib(L, strlib); - createmetatable(L); - return 1; -} - diff --git a/btgui/lua-5.2.3/src/ltable.c b/btgui/lua-5.2.3/src/ltable.c deleted file mode 100644 index 5d76f97ec..000000000 --- a/btgui/lua-5.2.3/src/ltable.c +++ /dev/null @@ -1,588 +0,0 @@ -/* -** $Id: ltable.c,v 2.72.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua tables (hash) -** See Copyright Notice in lua.h -*/ - - -/* -** Implementation of tables (aka arrays, objects, or hash tables). -** Tables keep its elements in two parts: an array part and a hash part. -** Non-negative integer keys are all candidates to be kept in the array -** part. The actual size of the array is the largest `n' such that at -** least half the slots between 0 and n are in use. -** Hash uses a mix of chained scatter table with Brent's variation. -** A main invariant of these tables is that, if an element is not -** in its main position (i.e. the `original' position that its hash gives -** to it), then the colliding element is in its own main position. -** Hence even when the load factor reaches 100%, performance remains good. -*/ - -#include - -#define ltable_c -#define LUA_CORE - -#include "lua.h" - -#include "ldebug.h" -#include "ldo.h" -#include "lgc.h" -#include "lmem.h" -#include "lobject.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "lvm.h" - - -/* -** max size of array part is 2^MAXBITS -*/ -#if LUAI_BITSINT >= 32 -#define MAXBITS 30 -#else -#define MAXBITS (LUAI_BITSINT-2) -#endif - -#define MAXASIZE (1 << MAXBITS) - - -#define hashpow2(t,n) (gnode(t, lmod((n), sizenode(t)))) - -#define hashstr(t,str) hashpow2(t, (str)->tsv.hash) -#define hashboolean(t,p) hashpow2(t, p) - - -/* -** for some types, it is better to avoid modulus by power of 2, as -** they tend to have many 2 factors. -*/ -#define hashmod(t,n) (gnode(t, ((n) % ((sizenode(t)-1)|1)))) - - -#define hashpointer(t,p) hashmod(t, IntPoint(p)) - - -#define dummynode (&dummynode_) - -#define isdummy(n) ((n) == dummynode) - -static const Node dummynode_ = { - {NILCONSTANT}, /* value */ - {{NILCONSTANT, NULL}} /* key */ -}; - - -/* -** hash for lua_Numbers -*/ -static Node *hashnum (const Table *t, lua_Number n) { - int i; - luai_hashnum(i, n); - if (i < 0) { - if (cast(unsigned int, i) == 0u - i) /* use unsigned to avoid overflows */ - i = 0; /* handle INT_MIN */ - i = -i; /* must be a positive value */ - } - return hashmod(t, i); -} - - - -/* -** returns the `main' position of an element in a table (that is, the index -** of its hash value) -*/ -static Node *mainposition (const Table *t, const TValue *key) { - switch (ttype(key)) { - case LUA_TNUMBER: - return hashnum(t, nvalue(key)); - case LUA_TLNGSTR: { - TString *s = rawtsvalue(key); - if (s->tsv.extra == 0) { /* no hash? */ - s->tsv.hash = luaS_hash(getstr(s), s->tsv.len, s->tsv.hash); - s->tsv.extra = 1; /* now it has its hash */ - } - return hashstr(t, rawtsvalue(key)); - } - case LUA_TSHRSTR: - return hashstr(t, rawtsvalue(key)); - case LUA_TBOOLEAN: - return hashboolean(t, bvalue(key)); - case LUA_TLIGHTUSERDATA: - return hashpointer(t, pvalue(key)); - case LUA_TLCF: - return hashpointer(t, fvalue(key)); - default: - return hashpointer(t, gcvalue(key)); - } -} - - -/* -** returns the index for `key' if `key' is an appropriate key to live in -** the array part of the table, -1 otherwise. -*/ -static int arrayindex (const TValue *key) { - if (ttisnumber(key)) { - lua_Number n = nvalue(key); - int k; - lua_number2int(k, n); - if (luai_numeq(cast_num(k), n)) - return k; - } - return -1; /* `key' did not match some condition */ -} - - -/* -** returns the index of a `key' for table traversals. First goes all -** elements in the array part, then elements in the hash part. The -** beginning of a traversal is signaled by -1. -*/ -static int findindex (lua_State *L, Table *t, StkId key) { - int i; - if (ttisnil(key)) return -1; /* first iteration */ - i = arrayindex(key); - if (0 < i && i <= t->sizearray) /* is `key' inside array part? */ - return i-1; /* yes; that's the index (corrected to C) */ - else { - Node *n = mainposition(t, key); - for (;;) { /* check whether `key' is somewhere in the chain */ - /* key may be dead already, but it is ok to use it in `next' */ - if (luaV_rawequalobj(gkey(n), key) || - (ttisdeadkey(gkey(n)) && iscollectable(key) && - deadvalue(gkey(n)) == gcvalue(key))) { - i = cast_int(n - gnode(t, 0)); /* key index in hash table */ - /* hash elements are numbered after array ones */ - return i + t->sizearray; - } - else n = gnext(n); - if (n == NULL) - luaG_runerror(L, "invalid key to " LUA_QL("next")); /* key not found */ - } - } -} - - -int luaH_next (lua_State *L, Table *t, StkId key) { - int i = findindex(L, t, key); /* find original element */ - for (i++; i < t->sizearray; i++) { /* try first array part */ - if (!ttisnil(&t->array[i])) { /* a non-nil value? */ - setnvalue(key, cast_num(i+1)); - setobj2s(L, key+1, &t->array[i]); - return 1; - } - } - for (i -= t->sizearray; i < sizenode(t); i++) { /* then hash part */ - if (!ttisnil(gval(gnode(t, i)))) { /* a non-nil value? */ - setobj2s(L, key, gkey(gnode(t, i))); - setobj2s(L, key+1, gval(gnode(t, i))); - return 1; - } - } - return 0; /* no more elements */ -} - - -/* -** {============================================================= -** Rehash -** ============================================================== -*/ - - -static int computesizes (int nums[], int *narray) { - int i; - int twotoi; /* 2^i */ - int a = 0; /* number of elements smaller than 2^i */ - int na = 0; /* number of elements to go to array part */ - int n = 0; /* optimal size for array part */ - for (i = 0, twotoi = 1; twotoi/2 < *narray; i++, twotoi *= 2) { - if (nums[i] > 0) { - a += nums[i]; - if (a > twotoi/2) { /* more than half elements present? */ - n = twotoi; /* optimal size (till now) */ - na = a; /* all elements smaller than n will go to array part */ - } - } - if (a == *narray) break; /* all elements already counted */ - } - *narray = n; - lua_assert(*narray/2 <= na && na <= *narray); - return na; -} - - -static int countint (const TValue *key, int *nums) { - int k = arrayindex(key); - if (0 < k && k <= MAXASIZE) { /* is `key' an appropriate array index? */ - nums[luaO_ceillog2(k)]++; /* count as such */ - return 1; - } - else - return 0; -} - - -static int numusearray (const Table *t, int *nums) { - int lg; - int ttlg; /* 2^lg */ - int ause = 0; /* summation of `nums' */ - int i = 1; /* count to traverse all array keys */ - for (lg=0, ttlg=1; lg<=MAXBITS; lg++, ttlg*=2) { /* for each slice */ - int lc = 0; /* counter */ - int lim = ttlg; - if (lim > t->sizearray) { - lim = t->sizearray; /* adjust upper limit */ - if (i > lim) - break; /* no more elements to count */ - } - /* count elements in range (2^(lg-1), 2^lg] */ - for (; i <= lim; i++) { - if (!ttisnil(&t->array[i-1])) - lc++; - } - nums[lg] += lc; - ause += lc; - } - return ause; -} - - -static int numusehash (const Table *t, int *nums, int *pnasize) { - int totaluse = 0; /* total number of elements */ - int ause = 0; /* summation of `nums' */ - int i = sizenode(t); - while (i--) { - Node *n = &t->node[i]; - if (!ttisnil(gval(n))) { - ause += countint(gkey(n), nums); - totaluse++; - } - } - *pnasize += ause; - return totaluse; -} - - -static void setarrayvector (lua_State *L, Table *t, int size) { - int i; - luaM_reallocvector(L, t->array, t->sizearray, size, TValue); - for (i=t->sizearray; iarray[i]); - t->sizearray = size; -} - - -static void setnodevector (lua_State *L, Table *t, int size) { - int lsize; - if (size == 0) { /* no elements to hash part? */ - t->node = cast(Node *, dummynode); /* use common `dummynode' */ - lsize = 0; - } - else { - int i; - lsize = luaO_ceillog2(size); - if (lsize > MAXBITS) - luaG_runerror(L, "table overflow"); - size = twoto(lsize); - t->node = luaM_newvector(L, size, Node); - for (i=0; ilsizenode = cast_byte(lsize); - t->lastfree = gnode(t, size); /* all positions are free */ -} - - -void luaH_resize (lua_State *L, Table *t, int nasize, int nhsize) { - int i; - int oldasize = t->sizearray; - int oldhsize = t->lsizenode; - Node *nold = t->node; /* save old hash ... */ - if (nasize > oldasize) /* array part must grow? */ - setarrayvector(L, t, nasize); - /* create new hash part with appropriate size */ - setnodevector(L, t, nhsize); - if (nasize < oldasize) { /* array part must shrink? */ - t->sizearray = nasize; - /* re-insert elements from vanishing slice */ - for (i=nasize; iarray[i])) - luaH_setint(L, t, i + 1, &t->array[i]); - } - /* shrink array */ - luaM_reallocvector(L, t->array, oldasize, nasize, TValue); - } - /* re-insert elements from hash part */ - for (i = twoto(oldhsize) - 1; i >= 0; i--) { - Node *old = nold+i; - if (!ttisnil(gval(old))) { - /* doesn't need barrier/invalidate cache, as entry was - already present in the table */ - setobjt2t(L, luaH_set(L, t, gkey(old)), gval(old)); - } - } - if (!isdummy(nold)) - luaM_freearray(L, nold, cast(size_t, twoto(oldhsize))); /* free old array */ -} - - -void luaH_resizearray (lua_State *L, Table *t, int nasize) { - int nsize = isdummy(t->node) ? 0 : sizenode(t); - luaH_resize(L, t, nasize, nsize); -} - - -static void rehash (lua_State *L, Table *t, const TValue *ek) { - int nasize, na; - int nums[MAXBITS+1]; /* nums[i] = number of keys with 2^(i-1) < k <= 2^i */ - int i; - int totaluse; - for (i=0; i<=MAXBITS; i++) nums[i] = 0; /* reset counts */ - nasize = numusearray(t, nums); /* count keys in array part */ - totaluse = nasize; /* all those keys are integer keys */ - totaluse += numusehash(t, nums, &nasize); /* count keys in hash part */ - /* count extra key */ - nasize += countint(ek, nums); - totaluse++; - /* compute new size for array part */ - na = computesizes(nums, &nasize); - /* resize the table to new computed sizes */ - luaH_resize(L, t, nasize, totaluse - na); -} - - - -/* -** }============================================================= -*/ - - -Table *luaH_new (lua_State *L) { - Table *t = &luaC_newobj(L, LUA_TTABLE, sizeof(Table), NULL, 0)->h; - t->metatable = NULL; - t->flags = cast_byte(~0); - t->array = NULL; - t->sizearray = 0; - setnodevector(L, t, 0); - return t; -} - - -void luaH_free (lua_State *L, Table *t) { - if (!isdummy(t->node)) - luaM_freearray(L, t->node, cast(size_t, sizenode(t))); - luaM_freearray(L, t->array, t->sizearray); - luaM_free(L, t); -} - - -static Node *getfreepos (Table *t) { - while (t->lastfree > t->node) { - t->lastfree--; - if (ttisnil(gkey(t->lastfree))) - return t->lastfree; - } - return NULL; /* could not find a free place */ -} - - - -/* -** inserts a new key into a hash table; first, check whether key's main -** position is free. If not, check whether colliding node is in its main -** position or not: if it is not, move colliding node to an empty place and -** put new key in its main position; otherwise (colliding node is in its main -** position), new key goes to an empty position. -*/ -TValue *luaH_newkey (lua_State *L, Table *t, const TValue *key) { - Node *mp; - if (ttisnil(key)) luaG_runerror(L, "table index is nil"); - else if (ttisnumber(key) && luai_numisnan(L, nvalue(key))) - luaG_runerror(L, "table index is NaN"); - mp = mainposition(t, key); - if (!ttisnil(gval(mp)) || isdummy(mp)) { /* main position is taken? */ - Node *othern; - Node *n = getfreepos(t); /* get a free place */ - if (n == NULL) { /* cannot find a free place? */ - rehash(L, t, key); /* grow table */ - /* whatever called 'newkey' take care of TM cache and GC barrier */ - return luaH_set(L, t, key); /* insert key into grown table */ - } - lua_assert(!isdummy(n)); - othern = mainposition(t, gkey(mp)); - if (othern != mp) { /* is colliding node out of its main position? */ - /* yes; move colliding node into free position */ - while (gnext(othern) != mp) othern = gnext(othern); /* find previous */ - gnext(othern) = n; /* redo the chain with `n' in place of `mp' */ - *n = *mp; /* copy colliding node into free pos. (mp->next also goes) */ - gnext(mp) = NULL; /* now `mp' is free */ - setnilvalue(gval(mp)); - } - else { /* colliding node is in its own main position */ - /* new node will go into free position */ - gnext(n) = gnext(mp); /* chain new position */ - gnext(mp) = n; - mp = n; - } - } - setobj2t(L, gkey(mp), key); - luaC_barrierback(L, obj2gco(t), key); - lua_assert(ttisnil(gval(mp))); - return gval(mp); -} - - -/* -** search function for integers -*/ -const TValue *luaH_getint (Table *t, int key) { - /* (1 <= key && key <= t->sizearray) */ - if (cast(unsigned int, key-1) < cast(unsigned int, t->sizearray)) - return &t->array[key-1]; - else { - lua_Number nk = cast_num(key); - Node *n = hashnum(t, nk); - do { /* check whether `key' is somewhere in the chain */ - if (ttisnumber(gkey(n)) && luai_numeq(nvalue(gkey(n)), nk)) - return gval(n); /* that's it */ - else n = gnext(n); - } while (n); - return luaO_nilobject; - } -} - - -/* -** search function for short strings -*/ -const TValue *luaH_getstr (Table *t, TString *key) { - Node *n = hashstr(t, key); - lua_assert(key->tsv.tt == LUA_TSHRSTR); - do { /* check whether `key' is somewhere in the chain */ - if (ttisshrstring(gkey(n)) && eqshrstr(rawtsvalue(gkey(n)), key)) - return gval(n); /* that's it */ - else n = gnext(n); - } while (n); - return luaO_nilobject; -} - - -/* -** main search function -*/ -const TValue *luaH_get (Table *t, const TValue *key) { - switch (ttype(key)) { - case LUA_TSHRSTR: return luaH_getstr(t, rawtsvalue(key)); - case LUA_TNIL: return luaO_nilobject; - case LUA_TNUMBER: { - int k; - lua_Number n = nvalue(key); - lua_number2int(k, n); - if (luai_numeq(cast_num(k), n)) /* index is int? */ - return luaH_getint(t, k); /* use specialized version */ - /* else go through */ - } - default: { - Node *n = mainposition(t, key); - do { /* check whether `key' is somewhere in the chain */ - if (luaV_rawequalobj(gkey(n), key)) - return gval(n); /* that's it */ - else n = gnext(n); - } while (n); - return luaO_nilobject; - } - } -} - - -/* -** beware: when using this function you probably need to check a GC -** barrier and invalidate the TM cache. -*/ -TValue *luaH_set (lua_State *L, Table *t, const TValue *key) { - const TValue *p = luaH_get(t, key); - if (p != luaO_nilobject) - return cast(TValue *, p); - else return luaH_newkey(L, t, key); -} - - -void luaH_setint (lua_State *L, Table *t, int key, TValue *value) { - const TValue *p = luaH_getint(t, key); - TValue *cell; - if (p != luaO_nilobject) - cell = cast(TValue *, p); - else { - TValue k; - setnvalue(&k, cast_num(key)); - cell = luaH_newkey(L, t, &k); - } - setobj2t(L, cell, value); -} - - -static int unbound_search (Table *t, unsigned int j) { - unsigned int i = j; /* i is zero or a present index */ - j++; - /* find `i' and `j' such that i is present and j is not */ - while (!ttisnil(luaH_getint(t, j))) { - i = j; - j *= 2; - if (j > cast(unsigned int, MAX_INT)) { /* overflow? */ - /* table was built with bad purposes: resort to linear search */ - i = 1; - while (!ttisnil(luaH_getint(t, i))) i++; - return i - 1; - } - } - /* now do a binary search between them */ - while (j - i > 1) { - unsigned int m = (i+j)/2; - if (ttisnil(luaH_getint(t, m))) j = m; - else i = m; - } - return i; -} - - -/* -** Try to find a boundary in table `t'. A `boundary' is an integer index -** such that t[i] is non-nil and t[i+1] is nil (and 0 if t[1] is nil). -*/ -int luaH_getn (Table *t) { - unsigned int j = t->sizearray; - if (j > 0 && ttisnil(&t->array[j - 1])) { - /* there is a boundary in the array part: (binary) search for it */ - unsigned int i = 0; - while (j - i > 1) { - unsigned int m = (i+j)/2; - if (ttisnil(&t->array[m - 1])) j = m; - else i = m; - } - return i; - } - /* else must find a boundary in hash part */ - else if (isdummy(t->node)) /* hash part is empty? */ - return j; /* that is easy... */ - else return unbound_search(t, j); -} - - - -#if defined(LUA_DEBUG) - -Node *luaH_mainposition (const Table *t, const TValue *key) { - return mainposition(t, key); -} - -int luaH_isdummy (Node *n) { return isdummy(n); } - -#endif diff --git a/btgui/lua-5.2.3/src/ltable.h b/btgui/lua-5.2.3/src/ltable.h deleted file mode 100644 index d69449b2b..000000000 --- a/btgui/lua-5.2.3/src/ltable.h +++ /dev/null @@ -1,45 +0,0 @@ -/* -** $Id: ltable.h,v 2.16.1.2 2013/08/30 15:49:41 roberto Exp $ -** Lua tables (hash) -** See Copyright Notice in lua.h -*/ - -#ifndef ltable_h -#define ltable_h - -#include "lobject.h" - - -#define gnode(t,i) (&(t)->node[i]) -#define gkey(n) (&(n)->i_key.tvk) -#define gval(n) (&(n)->i_val) -#define gnext(n) ((n)->i_key.nk.next) - -#define invalidateTMcache(t) ((t)->flags = 0) - -/* returns the key, given the value of a table entry */ -#define keyfromval(v) \ - (gkey(cast(Node *, cast(char *, (v)) - offsetof(Node, i_val)))) - - -LUAI_FUNC const TValue *luaH_getint (Table *t, int key); -LUAI_FUNC void luaH_setint (lua_State *L, Table *t, int key, TValue *value); -LUAI_FUNC const TValue *luaH_getstr (Table *t, TString *key); -LUAI_FUNC const TValue *luaH_get (Table *t, const TValue *key); -LUAI_FUNC TValue *luaH_newkey (lua_State *L, Table *t, const TValue *key); -LUAI_FUNC TValue *luaH_set (lua_State *L, Table *t, const TValue *key); -LUAI_FUNC Table *luaH_new (lua_State *L); -LUAI_FUNC void luaH_resize (lua_State *L, Table *t, int nasize, int nhsize); -LUAI_FUNC void luaH_resizearray (lua_State *L, Table *t, int nasize); -LUAI_FUNC void luaH_free (lua_State *L, Table *t); -LUAI_FUNC int luaH_next (lua_State *L, Table *t, StkId key); -LUAI_FUNC int luaH_getn (Table *t); - - -#if defined(LUA_DEBUG) -LUAI_FUNC Node *luaH_mainposition (const Table *t, const TValue *key); -LUAI_FUNC int luaH_isdummy (Node *n); -#endif - - -#endif diff --git a/btgui/lua-5.2.3/src/ltablib.c b/btgui/lua-5.2.3/src/ltablib.c deleted file mode 100644 index 6001224e3..000000000 --- a/btgui/lua-5.2.3/src/ltablib.c +++ /dev/null @@ -1,283 +0,0 @@ -/* -** $Id: ltablib.c,v 1.65.1.1 2013/04/12 18:48:47 roberto Exp $ -** Library for Table Manipulation -** See Copyright Notice in lua.h -*/ - - -#include - -#define ltablib_c -#define LUA_LIB - -#include "lua.h" - -#include "lauxlib.h" -#include "lualib.h" - - -#define aux_getn(L,n) (luaL_checktype(L, n, LUA_TTABLE), luaL_len(L, n)) - - - -#if defined(LUA_COMPAT_MAXN) -static int maxn (lua_State *L) { - lua_Number max = 0; - luaL_checktype(L, 1, LUA_TTABLE); - lua_pushnil(L); /* first key */ - while (lua_next(L, 1)) { - lua_pop(L, 1); /* remove value */ - if (lua_type(L, -1) == LUA_TNUMBER) { - lua_Number v = lua_tonumber(L, -1); - if (v > max) max = v; - } - } - lua_pushnumber(L, max); - return 1; -} -#endif - - -static int tinsert (lua_State *L) { - int e = aux_getn(L, 1) + 1; /* first empty element */ - int pos; /* where to insert new element */ - switch (lua_gettop(L)) { - case 2: { /* called with only 2 arguments */ - pos = e; /* insert new element at the end */ - break; - } - case 3: { - int i; - pos = luaL_checkint(L, 2); /* 2nd argument is the position */ - luaL_argcheck(L, 1 <= pos && pos <= e, 2, "position out of bounds"); - for (i = e; i > pos; i--) { /* move up elements */ - lua_rawgeti(L, 1, i-1); - lua_rawseti(L, 1, i); /* t[i] = t[i-1] */ - } - break; - } - default: { - return luaL_error(L, "wrong number of arguments to " LUA_QL("insert")); - } - } - lua_rawseti(L, 1, pos); /* t[pos] = v */ - return 0; -} - - -static int tremove (lua_State *L) { - int size = aux_getn(L, 1); - int pos = luaL_optint(L, 2, size); - if (pos != size) /* validate 'pos' if given */ - luaL_argcheck(L, 1 <= pos && pos <= size + 1, 1, "position out of bounds"); - lua_rawgeti(L, 1, pos); /* result = t[pos] */ - for ( ; pos < size; pos++) { - lua_rawgeti(L, 1, pos+1); - lua_rawseti(L, 1, pos); /* t[pos] = t[pos+1] */ - } - lua_pushnil(L); - lua_rawseti(L, 1, pos); /* t[pos] = nil */ - return 1; -} - - -static void addfield (lua_State *L, luaL_Buffer *b, int i) { - lua_rawgeti(L, 1, i); - if (!lua_isstring(L, -1)) - luaL_error(L, "invalid value (%s) at index %d in table for " - LUA_QL("concat"), luaL_typename(L, -1), i); - luaL_addvalue(b); -} - - -static int tconcat (lua_State *L) { - luaL_Buffer b; - size_t lsep; - int i, last; - const char *sep = luaL_optlstring(L, 2, "", &lsep); - luaL_checktype(L, 1, LUA_TTABLE); - i = luaL_optint(L, 3, 1); - last = luaL_opt(L, luaL_checkint, 4, luaL_len(L, 1)); - luaL_buffinit(L, &b); - for (; i < last; i++) { - addfield(L, &b, i); - luaL_addlstring(&b, sep, lsep); - } - if (i == last) /* add last value (if interval was not empty) */ - addfield(L, &b, i); - luaL_pushresult(&b); - return 1; -} - - -/* -** {====================================================== -** Pack/unpack -** ======================================================= -*/ - -static int pack (lua_State *L) { - int n = lua_gettop(L); /* number of elements to pack */ - lua_createtable(L, n, 1); /* create result table */ - lua_pushinteger(L, n); - lua_setfield(L, -2, "n"); /* t.n = number of elements */ - if (n > 0) { /* at least one element? */ - int i; - lua_pushvalue(L, 1); - lua_rawseti(L, -2, 1); /* insert first element */ - lua_replace(L, 1); /* move table into index 1 */ - for (i = n; i >= 2; i--) /* assign other elements */ - lua_rawseti(L, 1, i); - } - return 1; /* return table */ -} - - -static int unpack (lua_State *L) { - int i, e, n; - luaL_checktype(L, 1, LUA_TTABLE); - i = luaL_optint(L, 2, 1); - e = luaL_opt(L, luaL_checkint, 3, luaL_len(L, 1)); - if (i > e) return 0; /* empty range */ - n = e - i + 1; /* number of elements */ - if (n <= 0 || !lua_checkstack(L, n)) /* n <= 0 means arith. overflow */ - return luaL_error(L, "too many results to unpack"); - lua_rawgeti(L, 1, i); /* push arg[i] (avoiding overflow problems) */ - while (i++ < e) /* push arg[i + 1...e] */ - lua_rawgeti(L, 1, i); - return n; -} - -/* }====================================================== */ - - - -/* -** {====================================================== -** Quicksort -** (based on `Algorithms in MODULA-3', Robert Sedgewick; -** Addison-Wesley, 1993.) -** ======================================================= -*/ - - -static void set2 (lua_State *L, int i, int j) { - lua_rawseti(L, 1, i); - lua_rawseti(L, 1, j); -} - -static int sort_comp (lua_State *L, int a, int b) { - if (!lua_isnil(L, 2)) { /* function? */ - int res; - lua_pushvalue(L, 2); - lua_pushvalue(L, a-1); /* -1 to compensate function */ - lua_pushvalue(L, b-2); /* -2 to compensate function and `a' */ - lua_call(L, 2, 1); - res = lua_toboolean(L, -1); - lua_pop(L, 1); - return res; - } - else /* a < b? */ - return lua_compare(L, a, b, LUA_OPLT); -} - -static void auxsort (lua_State *L, int l, int u) { - while (l < u) { /* for tail recursion */ - int i, j; - /* sort elements a[l], a[(l+u)/2] and a[u] */ - lua_rawgeti(L, 1, l); - lua_rawgeti(L, 1, u); - if (sort_comp(L, -1, -2)) /* a[u] < a[l]? */ - set2(L, l, u); /* swap a[l] - a[u] */ - else - lua_pop(L, 2); - if (u-l == 1) break; /* only 2 elements */ - i = (l+u)/2; - lua_rawgeti(L, 1, i); - lua_rawgeti(L, 1, l); - if (sort_comp(L, -2, -1)) /* a[i]= P */ - while (lua_rawgeti(L, 1, ++i), sort_comp(L, -1, -2)) { - if (i>=u) luaL_error(L, "invalid order function for sorting"); - lua_pop(L, 1); /* remove a[i] */ - } - /* repeat --j until a[j] <= P */ - while (lua_rawgeti(L, 1, --j), sort_comp(L, -3, -1)) { - if (j<=l) luaL_error(L, "invalid order function for sorting"); - lua_pop(L, 1); /* remove a[j] */ - } - if (j - -#define ltm_c -#define LUA_CORE - -#include "lua.h" - -#include "lobject.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" - - -static const char udatatypename[] = "userdata"; - -LUAI_DDEF const char *const luaT_typenames_[LUA_TOTALTAGS] = { - "no value", - "nil", "boolean", udatatypename, "number", - "string", "table", "function", udatatypename, "thread", - "proto", "upval" /* these last two cases are used for tests only */ -}; - - -void luaT_init (lua_State *L) { - static const char *const luaT_eventname[] = { /* ORDER TM */ - "__index", "__newindex", - "__gc", "__mode", "__len", "__eq", - "__add", "__sub", "__mul", "__div", "__mod", - "__pow", "__unm", "__lt", "__le", - "__concat", "__call" - }; - int i; - for (i=0; itmname[i] = luaS_new(L, luaT_eventname[i]); - luaS_fix(G(L)->tmname[i]); /* never collect these names */ - } -} - - -/* -** function to be used with macro "fasttm": optimized for absence of -** tag methods -*/ -const TValue *luaT_gettm (Table *events, TMS event, TString *ename) { - const TValue *tm = luaH_getstr(events, ename); - lua_assert(event <= TM_EQ); - if (ttisnil(tm)) { /* no tag method? */ - events->flags |= cast_byte(1u<metatable; - break; - case LUA_TUSERDATA: - mt = uvalue(o)->metatable; - break; - default: - mt = G(L)->mt[ttypenv(o)]; - } - return (mt ? luaH_getstr(mt, G(L)->tmname[event]) : luaO_nilobject); -} - diff --git a/btgui/lua-5.2.3/src/ltm.h b/btgui/lua-5.2.3/src/ltm.h deleted file mode 100644 index 7f89c841f..000000000 --- a/btgui/lua-5.2.3/src/ltm.h +++ /dev/null @@ -1,57 +0,0 @@ -/* -** $Id: ltm.h,v 2.11.1.1 2013/04/12 18:48:47 roberto Exp $ -** Tag methods -** See Copyright Notice in lua.h -*/ - -#ifndef ltm_h -#define ltm_h - - -#include "lobject.h" - - -/* -* WARNING: if you change the order of this enumeration, -* grep "ORDER TM" -*/ -typedef enum { - TM_INDEX, - TM_NEWINDEX, - TM_GC, - TM_MODE, - TM_LEN, - TM_EQ, /* last tag method with `fast' access */ - TM_ADD, - TM_SUB, - TM_MUL, - TM_DIV, - TM_MOD, - TM_POW, - TM_UNM, - TM_LT, - TM_LE, - TM_CONCAT, - TM_CALL, - TM_N /* number of elements in the enum */ -} TMS; - - - -#define gfasttm(g,et,e) ((et) == NULL ? NULL : \ - ((et)->flags & (1u<<(e))) ? NULL : luaT_gettm(et, e, (g)->tmname[e])) - -#define fasttm(l,et,e) gfasttm(G(l), et, e) - -#define ttypename(x) luaT_typenames_[(x) + 1] -#define objtypename(x) ttypename(ttypenv(x)) - -LUAI_DDEC const char *const luaT_typenames_[LUA_TOTALTAGS]; - - -LUAI_FUNC const TValue *luaT_gettm (Table *events, TMS event, TString *ename); -LUAI_FUNC const TValue *luaT_gettmbyobj (lua_State *L, const TValue *o, - TMS event); -LUAI_FUNC void luaT_init (lua_State *L); - -#endif diff --git a/btgui/lua-5.2.3/src/lua.h b/btgui/lua-5.2.3/src/lua.h deleted file mode 100644 index 149a2c37b..000000000 --- a/btgui/lua-5.2.3/src/lua.h +++ /dev/null @@ -1,444 +0,0 @@ -/* -** $Id: lua.h,v 1.285.1.2 2013/11/11 12:09:16 roberto Exp $ -** Lua - A Scripting Language -** Lua.org, PUC-Rio, Brazil (http://www.lua.org) -** See Copyright Notice at the end of this file -*/ - - -#ifndef lua_h -#define lua_h - -#include -#include - - -#include "luaconf.h" - - -#define LUA_VERSION_MAJOR "5" -#define LUA_VERSION_MINOR "2" -#define LUA_VERSION_NUM 502 -#define LUA_VERSION_RELEASE "3" - -#define LUA_VERSION "Lua " LUA_VERSION_MAJOR "." LUA_VERSION_MINOR -#define LUA_RELEASE LUA_VERSION "." LUA_VERSION_RELEASE -#define LUA_COPYRIGHT LUA_RELEASE " Copyright (C) 1994-2013 Lua.org, PUC-Rio" -#define LUA_AUTHORS "R. Ierusalimschy, L. H. de Figueiredo, W. Celes" - - -/* mark for precompiled code ('Lua') */ -#define LUA_SIGNATURE "\033Lua" - -/* option for multiple returns in 'lua_pcall' and 'lua_call' */ -#define LUA_MULTRET (-1) - - -/* -** pseudo-indices -*/ -#define LUA_REGISTRYINDEX LUAI_FIRSTPSEUDOIDX -#define lua_upvalueindex(i) (LUA_REGISTRYINDEX - (i)) - - -/* thread status */ -#define LUA_OK 0 -#define LUA_YIELD 1 -#define LUA_ERRRUN 2 -#define LUA_ERRSYNTAX 3 -#define LUA_ERRMEM 4 -#define LUA_ERRGCMM 5 -#define LUA_ERRERR 6 - - -typedef struct lua_State lua_State; - -typedef int (*lua_CFunction) (lua_State *L); - - -/* -** functions that read/write blocks when loading/dumping Lua chunks -*/ -typedef const char * (*lua_Reader) (lua_State *L, void *ud, size_t *sz); - -typedef int (*lua_Writer) (lua_State *L, const void* p, size_t sz, void* ud); - - -/* -** prototype for memory-allocation functions -*/ -typedef void * (*lua_Alloc) (void *ud, void *ptr, size_t osize, size_t nsize); - - -/* -** basic types -*/ -#define LUA_TNONE (-1) - -#define LUA_TNIL 0 -#define LUA_TBOOLEAN 1 -#define LUA_TLIGHTUSERDATA 2 -#define LUA_TNUMBER 3 -#define LUA_TSTRING 4 -#define LUA_TTABLE 5 -#define LUA_TFUNCTION 6 -#define LUA_TUSERDATA 7 -#define LUA_TTHREAD 8 - -#define LUA_NUMTAGS 9 - - - -/* minimum Lua stack available to a C function */ -#define LUA_MINSTACK 20 - - -/* predefined values in the registry */ -#define LUA_RIDX_MAINTHREAD 1 -#define LUA_RIDX_GLOBALS 2 -#define LUA_RIDX_LAST LUA_RIDX_GLOBALS - - -/* type of numbers in Lua */ -typedef LUA_NUMBER lua_Number; - - -/* type for integer functions */ -typedef LUA_INTEGER lua_Integer; - -/* unsigned integer type */ -typedef LUA_UNSIGNED lua_Unsigned; - - - -/* -** generic extra include file -*/ -#if defined(LUA_USER_H) -#include LUA_USER_H -#endif - - -/* -** RCS ident string -*/ -extern const char lua_ident[]; - - -/* -** state manipulation -*/ -LUA_API lua_State *(lua_newstate) (lua_Alloc f, void *ud); -LUA_API void (lua_close) (lua_State *L); -LUA_API lua_State *(lua_newthread) (lua_State *L); - -LUA_API lua_CFunction (lua_atpanic) (lua_State *L, lua_CFunction panicf); - - -LUA_API const lua_Number *(lua_version) (lua_State *L); - - -/* -** basic stack manipulation -*/ -LUA_API int (lua_absindex) (lua_State *L, int idx); -LUA_API int (lua_gettop) (lua_State *L); -LUA_API void (lua_settop) (lua_State *L, int idx); -LUA_API void (lua_pushvalue) (lua_State *L, int idx); -LUA_API void (lua_remove) (lua_State *L, int idx); -LUA_API void (lua_insert) (lua_State *L, int idx); -LUA_API void (lua_replace) (lua_State *L, int idx); -LUA_API void (lua_copy) (lua_State *L, int fromidx, int toidx); -LUA_API int (lua_checkstack) (lua_State *L, int sz); - -LUA_API void (lua_xmove) (lua_State *from, lua_State *to, int n); - - -/* -** access functions (stack -> C) -*/ - -LUA_API int (lua_isnumber) (lua_State *L, int idx); -LUA_API int (lua_isstring) (lua_State *L, int idx); -LUA_API int (lua_iscfunction) (lua_State *L, int idx); -LUA_API int (lua_isuserdata) (lua_State *L, int idx); -LUA_API int (lua_type) (lua_State *L, int idx); -LUA_API const char *(lua_typename) (lua_State *L, int tp); - -LUA_API lua_Number (lua_tonumberx) (lua_State *L, int idx, int *isnum); -LUA_API lua_Integer (lua_tointegerx) (lua_State *L, int idx, int *isnum); -LUA_API lua_Unsigned (lua_tounsignedx) (lua_State *L, int idx, int *isnum); -LUA_API int (lua_toboolean) (lua_State *L, int idx); -LUA_API const char *(lua_tolstring) (lua_State *L, int idx, size_t *len); -LUA_API size_t (lua_rawlen) (lua_State *L, int idx); -LUA_API lua_CFunction (lua_tocfunction) (lua_State *L, int idx); -LUA_API void *(lua_touserdata) (lua_State *L, int idx); -LUA_API lua_State *(lua_tothread) (lua_State *L, int idx); -LUA_API const void *(lua_topointer) (lua_State *L, int idx); - - -/* -** Comparison and arithmetic functions -*/ - -#define LUA_OPADD 0 /* ORDER TM */ -#define LUA_OPSUB 1 -#define LUA_OPMUL 2 -#define LUA_OPDIV 3 -#define LUA_OPMOD 4 -#define LUA_OPPOW 5 -#define LUA_OPUNM 6 - -LUA_API void (lua_arith) (lua_State *L, int op); - -#define LUA_OPEQ 0 -#define LUA_OPLT 1 -#define LUA_OPLE 2 - -LUA_API int (lua_rawequal) (lua_State *L, int idx1, int idx2); -LUA_API int (lua_compare) (lua_State *L, int idx1, int idx2, int op); - - -/* -** push functions (C -> stack) -*/ -LUA_API void (lua_pushnil) (lua_State *L); -LUA_API void (lua_pushnumber) (lua_State *L, lua_Number n); -LUA_API void (lua_pushinteger) (lua_State *L, lua_Integer n); -LUA_API void (lua_pushunsigned) (lua_State *L, lua_Unsigned n); -LUA_API const char *(lua_pushlstring) (lua_State *L, const char *s, size_t l); -LUA_API const char *(lua_pushstring) (lua_State *L, const char *s); -LUA_API const char *(lua_pushvfstring) (lua_State *L, const char *fmt, - va_list argp); -LUA_API const char *(lua_pushfstring) (lua_State *L, const char *fmt, ...); -LUA_API void (lua_pushcclosure) (lua_State *L, lua_CFunction fn, int n); -LUA_API void (lua_pushboolean) (lua_State *L, int b); -LUA_API void (lua_pushlightuserdata) (lua_State *L, void *p); -LUA_API int (lua_pushthread) (lua_State *L); - - -/* -** get functions (Lua -> stack) -*/ -LUA_API void (lua_getglobal) (lua_State *L, const char *var); -LUA_API void (lua_gettable) (lua_State *L, int idx); -LUA_API void (lua_getfield) (lua_State *L, int idx, const char *k); -LUA_API void (lua_rawget) (lua_State *L, int idx); -LUA_API void (lua_rawgeti) (lua_State *L, int idx, int n); -LUA_API void (lua_rawgetp) (lua_State *L, int idx, const void *p); -LUA_API void (lua_createtable) (lua_State *L, int narr, int nrec); -LUA_API void *(lua_newuserdata) (lua_State *L, size_t sz); -LUA_API int (lua_getmetatable) (lua_State *L, int objindex); -LUA_API void (lua_getuservalue) (lua_State *L, int idx); - - -/* -** set functions (stack -> Lua) -*/ -LUA_API void (lua_setglobal) (lua_State *L, const char *var); -LUA_API void (lua_settable) (lua_State *L, int idx); -LUA_API void (lua_setfield) (lua_State *L, int idx, const char *k); -LUA_API void (lua_rawset) (lua_State *L, int idx); -LUA_API void (lua_rawseti) (lua_State *L, int idx, int n); -LUA_API void (lua_rawsetp) (lua_State *L, int idx, const void *p); -LUA_API int (lua_setmetatable) (lua_State *L, int objindex); -LUA_API void (lua_setuservalue) (lua_State *L, int idx); - - -/* -** 'load' and 'call' functions (load and run Lua code) -*/ -LUA_API void (lua_callk) (lua_State *L, int nargs, int nresults, int ctx, - lua_CFunction k); -#define lua_call(L,n,r) lua_callk(L, (n), (r), 0, NULL) - -LUA_API int (lua_getctx) (lua_State *L, int *ctx); - -LUA_API int (lua_pcallk) (lua_State *L, int nargs, int nresults, int errfunc, - int ctx, lua_CFunction k); -#define lua_pcall(L,n,r,f) lua_pcallk(L, (n), (r), (f), 0, NULL) - -LUA_API int (lua_load) (lua_State *L, lua_Reader reader, void *dt, - const char *chunkname, - const char *mode); - -LUA_API int (lua_dump) (lua_State *L, lua_Writer writer, void *data); - - -/* -** coroutine functions -*/ -LUA_API int (lua_yieldk) (lua_State *L, int nresults, int ctx, - lua_CFunction k); -#define lua_yield(L,n) lua_yieldk(L, (n), 0, NULL) -LUA_API int (lua_resume) (lua_State *L, lua_State *from, int narg); -LUA_API int (lua_status) (lua_State *L); - -/* -** garbage-collection function and options -*/ - -#define LUA_GCSTOP 0 -#define LUA_GCRESTART 1 -#define LUA_GCCOLLECT 2 -#define LUA_GCCOUNT 3 -#define LUA_GCCOUNTB 4 -#define LUA_GCSTEP 5 -#define LUA_GCSETPAUSE 6 -#define LUA_GCSETSTEPMUL 7 -#define LUA_GCSETMAJORINC 8 -#define LUA_GCISRUNNING 9 -#define LUA_GCGEN 10 -#define LUA_GCINC 11 - -LUA_API int (lua_gc) (lua_State *L, int what, int data); - - -/* -** miscellaneous functions -*/ - -LUA_API int (lua_error) (lua_State *L); - -LUA_API int (lua_next) (lua_State *L, int idx); - -LUA_API void (lua_concat) (lua_State *L, int n); -LUA_API void (lua_len) (lua_State *L, int idx); - -LUA_API lua_Alloc (lua_getallocf) (lua_State *L, void **ud); -LUA_API void (lua_setallocf) (lua_State *L, lua_Alloc f, void *ud); - - - -/* -** =============================================================== -** some useful macros -** =============================================================== -*/ - -#define lua_tonumber(L,i) lua_tonumberx(L,i,NULL) -#define lua_tointeger(L,i) lua_tointegerx(L,i,NULL) -#define lua_tounsigned(L,i) lua_tounsignedx(L,i,NULL) - -#define lua_pop(L,n) lua_settop(L, -(n)-1) - -#define lua_newtable(L) lua_createtable(L, 0, 0) - -#define lua_register(L,n,f) (lua_pushcfunction(L, (f)), lua_setglobal(L, (n))) - -#define lua_pushcfunction(L,f) lua_pushcclosure(L, (f), 0) - -#define lua_isfunction(L,n) (lua_type(L, (n)) == LUA_TFUNCTION) -#define lua_istable(L,n) (lua_type(L, (n)) == LUA_TTABLE) -#define lua_islightuserdata(L,n) (lua_type(L, (n)) == LUA_TLIGHTUSERDATA) -#define lua_isnil(L,n) (lua_type(L, (n)) == LUA_TNIL) -#define lua_isboolean(L,n) (lua_type(L, (n)) == LUA_TBOOLEAN) -#define lua_isthread(L,n) (lua_type(L, (n)) == LUA_TTHREAD) -#define lua_isnone(L,n) (lua_type(L, (n)) == LUA_TNONE) -#define lua_isnoneornil(L, n) (lua_type(L, (n)) <= 0) - -#define lua_pushliteral(L, s) \ - lua_pushlstring(L, "" s, (sizeof(s)/sizeof(char))-1) - -#define lua_pushglobaltable(L) \ - lua_rawgeti(L, LUA_REGISTRYINDEX, LUA_RIDX_GLOBALS) - -#define lua_tostring(L,i) lua_tolstring(L, (i), NULL) - - - -/* -** {====================================================================== -** Debug API -** ======================================================================= -*/ - - -/* -** Event codes -*/ -#define LUA_HOOKCALL 0 -#define LUA_HOOKRET 1 -#define LUA_HOOKLINE 2 -#define LUA_HOOKCOUNT 3 -#define LUA_HOOKTAILCALL 4 - - -/* -** Event masks -*/ -#define LUA_MASKCALL (1 << LUA_HOOKCALL) -#define LUA_MASKRET (1 << LUA_HOOKRET) -#define LUA_MASKLINE (1 << LUA_HOOKLINE) -#define LUA_MASKCOUNT (1 << LUA_HOOKCOUNT) - -typedef struct lua_Debug lua_Debug; /* activation record */ - - -/* Functions to be called by the debugger in specific events */ -typedef void (*lua_Hook) (lua_State *L, lua_Debug *ar); - - -LUA_API int (lua_getstack) (lua_State *L, int level, lua_Debug *ar); -LUA_API int (lua_getinfo) (lua_State *L, const char *what, lua_Debug *ar); -LUA_API const char *(lua_getlocal) (lua_State *L, const lua_Debug *ar, int n); -LUA_API const char *(lua_setlocal) (lua_State *L, const lua_Debug *ar, int n); -LUA_API const char *(lua_getupvalue) (lua_State *L, int funcindex, int n); -LUA_API const char *(lua_setupvalue) (lua_State *L, int funcindex, int n); - -LUA_API void *(lua_upvalueid) (lua_State *L, int fidx, int n); -LUA_API void (lua_upvaluejoin) (lua_State *L, int fidx1, int n1, - int fidx2, int n2); - -LUA_API int (lua_sethook) (lua_State *L, lua_Hook func, int mask, int count); -LUA_API lua_Hook (lua_gethook) (lua_State *L); -LUA_API int (lua_gethookmask) (lua_State *L); -LUA_API int (lua_gethookcount) (lua_State *L); - - -struct lua_Debug { - int event; - const char *name; /* (n) */ - const char *namewhat; /* (n) 'global', 'local', 'field', 'method' */ - const char *what; /* (S) 'Lua', 'C', 'main', 'tail' */ - const char *source; /* (S) */ - int currentline; /* (l) */ - int linedefined; /* (S) */ - int lastlinedefined; /* (S) */ - unsigned char nups; /* (u) number of upvalues */ - unsigned char nparams;/* (u) number of parameters */ - char isvararg; /* (u) */ - char istailcall; /* (t) */ - char short_src[LUA_IDSIZE]; /* (S) */ - /* private part */ - struct CallInfo *i_ci; /* active function */ -}; - -/* }====================================================================== */ - - -/****************************************************************************** -* Copyright (C) 1994-2013 Lua.org, PUC-Rio. -* -* Permission is hereby granted, free of charge, to any person obtaining -* a copy of this software and associated documentation files (the -* "Software"), to deal in the Software without restriction, including -* without limitation the rights to use, copy, modify, merge, publish, -* distribute, sublicense, and/or sell copies of the Software, and to -* permit persons to whom the Software is furnished to do so, subject to -* the following conditions: -* -* The above copyright notice and this permission notice shall be -* included in all copies or substantial portions of the Software. -* -* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -******************************************************************************/ - - -#endif diff --git a/btgui/lua-5.2.3/src/lua.hpp b/btgui/lua-5.2.3/src/lua.hpp deleted file mode 100644 index ec417f594..000000000 --- a/btgui/lua-5.2.3/src/lua.hpp +++ /dev/null @@ -1,9 +0,0 @@ -// lua.hpp -// Lua header files for C++ -// <> not supplied automatically because Lua also compiles as C++ - -extern "C" { -#include "lua.h" -#include "lualib.h" -#include "lauxlib.h" -} diff --git a/btgui/lua-5.2.3/src/luaconf.h b/btgui/lua-5.2.3/src/luaconf.h deleted file mode 100644 index e8aee009a..000000000 --- a/btgui/lua-5.2.3/src/luaconf.h +++ /dev/null @@ -1,551 +0,0 @@ -/* -** $Id: luaconf.h,v 1.176.1.1 2013/04/12 18:48:47 roberto Exp $ -** Configuration file for Lua -** See Copyright Notice in lua.h -*/ - - -#ifndef lconfig_h -#define lconfig_h - -#include -#include - - -/* -** ================================================================== -** Search for "@@" to find all configurable definitions. -** =================================================================== -*/ - - -/* -@@ LUA_ANSI controls the use of non-ansi features. -** CHANGE it (define it) if you want Lua to avoid the use of any -** non-ansi feature or library. -*/ -#if !defined(LUA_ANSI) && defined(__STRICT_ANSI__) -#define LUA_ANSI -#endif - - -#if !defined(LUA_ANSI) && defined(_WIN32) && !defined(_WIN32_WCE) -#define LUA_WIN /* enable goodies for regular Windows platforms */ -#endif - -#if defined(LUA_WIN) -#define LUA_DL_DLL -#define LUA_USE_AFORMAT /* assume 'printf' handles 'aA' specifiers */ -#endif - - - -#if defined(LUA_USE_LINUX) -#define LUA_USE_POSIX -//#define LUA_USE_DLOPEN /* needs an extra library: -ldl */ -//#define LUA_USE_READLINE /* needs some extra libraries */ -#define LUA_USE_STRTODHEX /* assume 'strtod' handles hex formats */ -#define LUA_USE_AFORMAT /* assume 'printf' handles 'aA' specifiers */ -#define LUA_USE_LONGLONG /* assume support for long long */ -#endif - -#if defined(LUA_USE_MACOSX) -#define LUA_USE_POSIX -//#define LUA_USE_DLOPEN /* does not need -ldl */ -//#define LUA_USE_READLINE /* needs an extra library: -lreadline */ -#define LUA_USE_STRTODHEX /* assume 'strtod' handles hex formats */ -#define LUA_USE_AFORMAT /* assume 'printf' handles 'aA' specifiers */ -#define LUA_USE_LONGLONG /* assume support for long long */ -#endif - - - -/* -@@ LUA_USE_POSIX includes all functionality listed as X/Open System -@* Interfaces Extension (XSI). -** CHANGE it (define it) if your system is XSI compatible. -*/ -#if defined(LUA_USE_POSIX) -#define LUA_USE_MKSTEMP -#define LUA_USE_ISATTY -#define LUA_USE_POPEN -#define LUA_USE_ULONGJMP -#define LUA_USE_GMTIME_R -#endif - - - -/* -@@ LUA_PATH_DEFAULT is the default path that Lua uses to look for -@* Lua libraries. -@@ LUA_CPATH_DEFAULT is the default path that Lua uses to look for -@* C libraries. -** CHANGE them if your machine has a non-conventional directory -** hierarchy or if you want to install your libraries in -** non-conventional directories. -*/ -#if defined(_WIN32) /* { */ -/* -** In Windows, any exclamation mark ('!') in the path is replaced by the -** path of the directory of the executable file of the current process. -*/ -#define LUA_LDIR "!\\lua\\" -#define LUA_CDIR "!\\" -#define LUA_PATH_DEFAULT \ - LUA_LDIR"?.lua;" LUA_LDIR"?\\init.lua;" \ - LUA_CDIR"?.lua;" LUA_CDIR"?\\init.lua;" ".\\?.lua" -#define LUA_CPATH_DEFAULT \ - LUA_CDIR"?.dll;" LUA_CDIR"loadall.dll;" ".\\?.dll" - -#else /* }{ */ - -#define LUA_VDIR LUA_VERSION_MAJOR "." LUA_VERSION_MINOR "/" -#define LUA_ROOT "/usr/local/" -#define LUA_LDIR LUA_ROOT "share/lua/" LUA_VDIR -#define LUA_CDIR LUA_ROOT "lib/lua/" LUA_VDIR -#define LUA_PATH_DEFAULT \ - LUA_LDIR"?.lua;" LUA_LDIR"?/init.lua;" \ - LUA_CDIR"?.lua;" LUA_CDIR"?/init.lua;" "./?.lua" -#define LUA_CPATH_DEFAULT \ - LUA_CDIR"?.so;" LUA_CDIR"loadall.so;" "./?.so" -#endif /* } */ - - -/* -@@ LUA_DIRSEP is the directory separator (for submodules). -** CHANGE it if your machine does not use "/" as the directory separator -** and is not Windows. (On Windows Lua automatically uses "\".) -*/ -#if defined(_WIN32) -#define LUA_DIRSEP "\\" -#else -#define LUA_DIRSEP "/" -#endif - - -/* -@@ LUA_ENV is the name of the variable that holds the current -@@ environment, used to access global names. -** CHANGE it if you do not like this name. -*/ -#define LUA_ENV "_ENV" - - -/* -@@ LUA_API is a mark for all core API functions. -@@ LUALIB_API is a mark for all auxiliary library functions. -@@ LUAMOD_API is a mark for all standard library opening functions. -** CHANGE them if you need to define those functions in some special way. -** For instance, if you want to create one Windows DLL with the core and -** the libraries, you may want to use the following definition (define -** LUA_BUILD_AS_DLL to get it). -*/ -#if defined(LUA_BUILD_AS_DLL) /* { */ - -#if defined(LUA_CORE) || defined(LUA_LIB) /* { */ -#define LUA_API __declspec(dllexport) -#else /* }{ */ -#define LUA_API __declspec(dllimport) -#endif /* } */ - -#else /* }{ */ - -#define LUA_API extern - -#endif /* } */ - - -/* more often than not the libs go together with the core */ -#define LUALIB_API LUA_API -#define LUAMOD_API LUALIB_API - - -/* -@@ LUAI_FUNC is a mark for all extern functions that are not to be -@* exported to outside modules. -@@ LUAI_DDEF and LUAI_DDEC are marks for all extern (const) variables -@* that are not to be exported to outside modules (LUAI_DDEF for -@* definitions and LUAI_DDEC for declarations). -** CHANGE them if you need to mark them in some special way. Elf/gcc -** (versions 3.2 and later) mark them as "hidden" to optimize access -** when Lua is compiled as a shared library. Not all elf targets support -** this attribute. Unfortunately, gcc does not offer a way to check -** whether the target offers that support, and those without support -** give a warning about it. To avoid these warnings, change to the -** default definition. -*/ -#if defined(__GNUC__) && ((__GNUC__*100 + __GNUC_MINOR__) >= 302) && \ - defined(__ELF__) /* { */ -#define LUAI_FUNC __attribute__((visibility("hidden"))) extern -#define LUAI_DDEC LUAI_FUNC -#define LUAI_DDEF /* empty */ - -#else /* }{ */ -#define LUAI_FUNC extern -#define LUAI_DDEC extern -#define LUAI_DDEF /* empty */ -#endif /* } */ - - - -/* -@@ LUA_QL describes how error messages quote program elements. -** CHANGE it if you want a different appearance. -*/ -#define LUA_QL(x) "'" x "'" -#define LUA_QS LUA_QL("%s") - - -/* -@@ LUA_IDSIZE gives the maximum size for the description of the source -@* of a function in debug information. -** CHANGE it if you want a different size. -*/ -#define LUA_IDSIZE 60 - - -/* -@@ luai_writestring/luai_writeline define how 'print' prints its results. -** They are only used in libraries and the stand-alone program. (The #if -** avoids including 'stdio.h' everywhere.) -*/ -#if defined(LUA_LIB) || defined(lua_c) -#include -#define luai_writestring(s,l) fwrite((s), sizeof(char), (l), stdout) -#define luai_writeline() (luai_writestring("\n", 1), fflush(stdout)) -#endif - -/* -@@ luai_writestringerror defines how to print error messages. -** (A format string with one argument is enough for Lua...) -*/ -#define luai_writestringerror(s,p) \ - (fprintf(stderr, (s), (p)), fflush(stderr)) - - -/* -@@ LUAI_MAXSHORTLEN is the maximum length for short strings, that is, -** strings that are internalized. (Cannot be smaller than reserved words -** or tags for metamethods, as these strings must be internalized; -** #("function") = 8, #("__newindex") = 10.) -*/ -#define LUAI_MAXSHORTLEN 40 - - - -/* -** {================================================================== -** Compatibility with previous versions -** =================================================================== -*/ - -/* -@@ LUA_COMPAT_ALL controls all compatibility options. -** You can define it to get all options, or change specific options -** to fit your specific needs. -*/ -#if defined(LUA_COMPAT_ALL) /* { */ - -/* -@@ LUA_COMPAT_UNPACK controls the presence of global 'unpack'. -** You can replace it with 'table.unpack'. -*/ -#define LUA_COMPAT_UNPACK - -/* -@@ LUA_COMPAT_LOADERS controls the presence of table 'package.loaders'. -** You can replace it with 'package.searchers'. -*/ -#define LUA_COMPAT_LOADERS - -/* -@@ macro 'lua_cpcall' emulates deprecated function lua_cpcall. -** You can call your C function directly (with light C functions). -*/ -#define lua_cpcall(L,f,u) \ - (lua_pushcfunction(L, (f)), \ - lua_pushlightuserdata(L,(u)), \ - lua_pcall(L,1,0,0)) - - -/* -@@ LUA_COMPAT_LOG10 defines the function 'log10' in the math library. -** You can rewrite 'log10(x)' as 'log(x, 10)'. -*/ -#define LUA_COMPAT_LOG10 - -/* -@@ LUA_COMPAT_LOADSTRING defines the function 'loadstring' in the base -** library. You can rewrite 'loadstring(s)' as 'load(s)'. -*/ -#define LUA_COMPAT_LOADSTRING - -/* -@@ LUA_COMPAT_MAXN defines the function 'maxn' in the table library. -*/ -#define LUA_COMPAT_MAXN - -/* -@@ The following macros supply trivial compatibility for some -** changes in the API. The macros themselves document how to -** change your code to avoid using them. -*/ -#define lua_strlen(L,i) lua_rawlen(L, (i)) - -#define lua_objlen(L,i) lua_rawlen(L, (i)) - -#define lua_equal(L,idx1,idx2) lua_compare(L,(idx1),(idx2),LUA_OPEQ) -#define lua_lessthan(L,idx1,idx2) lua_compare(L,(idx1),(idx2),LUA_OPLT) - -/* -@@ LUA_COMPAT_MODULE controls compatibility with previous -** module functions 'module' (Lua) and 'luaL_register' (C). -*/ -#define LUA_COMPAT_MODULE - -#endif /* } */ - -/* }================================================================== */ - - - -/* -@@ LUAI_BITSINT defines the number of bits in an int. -** CHANGE here if Lua cannot automatically detect the number of bits of -** your machine. Probably you do not need to change this. -*/ -/* avoid overflows in comparison */ -#if INT_MAX-20 < 32760 /* { */ -#define LUAI_BITSINT 16 -#elif INT_MAX > 2147483640L /* }{ */ -/* int has at least 32 bits */ -#define LUAI_BITSINT 32 -#else /* }{ */ -#error "you must define LUA_BITSINT with number of bits in an integer" -#endif /* } */ - - -/* -@@ LUA_INT32 is an signed integer with exactly 32 bits. -@@ LUAI_UMEM is an unsigned integer big enough to count the total -@* memory used by Lua. -@@ LUAI_MEM is a signed integer big enough to count the total memory -@* used by Lua. -** CHANGE here if for some weird reason the default definitions are not -** good enough for your machine. Probably you do not need to change -** this. -*/ -#if LUAI_BITSINT >= 32 /* { */ -#define LUA_INT32 int -#define LUAI_UMEM size_t -#define LUAI_MEM ptrdiff_t -#else /* }{ */ -/* 16-bit ints */ -#define LUA_INT32 long -#define LUAI_UMEM unsigned long -#define LUAI_MEM long -#endif /* } */ - - -/* -@@ LUAI_MAXSTACK limits the size of the Lua stack. -** CHANGE it if you need a different limit. This limit is arbitrary; -** its only purpose is to stop Lua to consume unlimited stack -** space (and to reserve some numbers for pseudo-indices). -*/ -#if LUAI_BITSINT >= 32 -#define LUAI_MAXSTACK 1000000 -#else -#define LUAI_MAXSTACK 15000 -#endif - -/* reserve some space for error handling */ -#define LUAI_FIRSTPSEUDOIDX (-LUAI_MAXSTACK - 1000) - - - - -/* -@@ LUAL_BUFFERSIZE is the buffer size used by the lauxlib buffer system. -** CHANGE it if it uses too much C-stack space. -*/ -#define LUAL_BUFFERSIZE BUFSIZ - - - - -/* -** {================================================================== -@@ LUA_NUMBER is the type of numbers in Lua. -** CHANGE the following definitions only if you want to build Lua -** with a number type different from double. You may also need to -** change lua_number2int & lua_number2integer. -** =================================================================== -*/ - -#define LUA_NUMBER_DOUBLE -#define LUA_NUMBER double - -/* -@@ LUAI_UACNUMBER is the result of an 'usual argument conversion' -@* over a number. -*/ -#define LUAI_UACNUMBER double - - -/* -@@ LUA_NUMBER_SCAN is the format for reading numbers. -@@ LUA_NUMBER_FMT is the format for writing numbers. -@@ lua_number2str converts a number to a string. -@@ LUAI_MAXNUMBER2STR is maximum size of previous conversion. -*/ -#define LUA_NUMBER_SCAN "%lf" -#define LUA_NUMBER_FMT "%.14g" -#define lua_number2str(s,n) sprintf((s), LUA_NUMBER_FMT, (n)) -#define LUAI_MAXNUMBER2STR 32 /* 16 digits, sign, point, and \0 */ - - -/* -@@ l_mathop allows the addition of an 'l' or 'f' to all math operations -*/ -#define l_mathop(x) (x) - - -/* -@@ lua_str2number converts a decimal numeric string to a number. -@@ lua_strx2number converts an hexadecimal numeric string to a number. -** In C99, 'strtod' does both conversions. C89, however, has no function -** to convert floating hexadecimal strings to numbers. For these -** systems, you can leave 'lua_strx2number' undefined and Lua will -** provide its own implementation. -*/ -#define lua_str2number(s,p) strtod((s), (p)) - -#if defined(LUA_USE_STRTODHEX) -#define lua_strx2number(s,p) strtod((s), (p)) -#endif - - -/* -@@ The luai_num* macros define the primitive operations over numbers. -*/ - -/* the following operations need the math library */ -#if defined(lobject_c) || defined(lvm_c) -#include -#define luai_nummod(L,a,b) ((a) - l_mathop(floor)((a)/(b))*(b)) -#define luai_numpow(L,a,b) (l_mathop(pow)(a,b)) -#endif - -/* these are quite standard operations */ -#if defined(LUA_CORE) -#define luai_numadd(L,a,b) ((a)+(b)) -#define luai_numsub(L,a,b) ((a)-(b)) -#define luai_nummul(L,a,b) ((a)*(b)) -#define luai_numdiv(L,a,b) ((a)/(b)) -#define luai_numunm(L,a) (-(a)) -#define luai_numeq(a,b) ((a)==(b)) -#define luai_numlt(L,a,b) ((a)<(b)) -#define luai_numle(L,a,b) ((a)<=(b)) -#define luai_numisnan(L,a) (!luai_numeq((a), (a))) -#endif - - - -/* -@@ LUA_INTEGER is the integral type used by lua_pushinteger/lua_tointeger. -** CHANGE that if ptrdiff_t is not adequate on your machine. (On most -** machines, ptrdiff_t gives a good choice between int or long.) -*/ -#define LUA_INTEGER ptrdiff_t - -/* -@@ LUA_UNSIGNED is the integral type used by lua_pushunsigned/lua_tounsigned. -** It must have at least 32 bits. -*/ -#define LUA_UNSIGNED unsigned LUA_INT32 - - - -/* -** Some tricks with doubles -*/ - -#if defined(LUA_NUMBER_DOUBLE) && !defined(LUA_ANSI) /* { */ -/* -** The next definitions activate some tricks to speed up the -** conversion from doubles to integer types, mainly to LUA_UNSIGNED. -** -@@ LUA_MSASMTRICK uses Microsoft assembler to avoid clashes with a -** DirectX idiosyncrasy. -** -@@ LUA_IEEE754TRICK uses a trick that should work on any machine -** using IEEE754 with a 32-bit integer type. -** -@@ LUA_IEEELL extends the trick to LUA_INTEGER; should only be -** defined when LUA_INTEGER is a 32-bit integer. -** -@@ LUA_IEEEENDIAN is the endianness of doubles in your machine -** (0 for little endian, 1 for big endian); if not defined, Lua will -** check it dynamically for LUA_IEEE754TRICK (but not for LUA_NANTRICK). -** -@@ LUA_NANTRICK controls the use of a trick to pack all types into -** a single double value, using NaN values to represent non-number -** values. The trick only works on 32-bit machines (ints and pointers -** are 32-bit values) with numbers represented as IEEE 754-2008 doubles -** with conventional endianess (12345678 or 87654321), in CPUs that do -** not produce signaling NaN values (all NaNs are quiet). -*/ - -/* Microsoft compiler on a Pentium (32 bit) ? */ -#if defined(LUA_WIN) && defined(_MSC_VER) && defined(_M_IX86) /* { */ - -#define LUA_MSASMTRICK -#define LUA_IEEEENDIAN 0 -#define LUA_NANTRICK - - -/* pentium 32 bits? */ -#elif defined(__i386__) || defined(__i386) || defined(__X86__) /* }{ */ - -#define LUA_IEEE754TRICK -#define LUA_IEEELL -#define LUA_IEEEENDIAN 0 -#define LUA_NANTRICK - -/* pentium 64 bits? */ -#elif defined(__x86_64) /* }{ */ - -#define LUA_IEEE754TRICK -#define LUA_IEEEENDIAN 0 - -#elif defined(__POWERPC__) || defined(__ppc__) /* }{ */ - -#define LUA_IEEE754TRICK -#define LUA_IEEEENDIAN 1 - -#else /* }{ */ - -/* assume IEEE754 and a 32-bit integer type */ -#define LUA_IEEE754TRICK - -#endif /* } */ - -#endif /* } */ - -/* }================================================================== */ - - - - -/* =================================================================== */ - -/* -** Local configuration. You can use this space to add your redefinitions -** without modifying the main part of the file. -*/ - - - -#endif - diff --git a/btgui/lua-5.2.3/src/lualib.h b/btgui/lua-5.2.3/src/lualib.h deleted file mode 100644 index da82005c9..000000000 --- a/btgui/lua-5.2.3/src/lualib.h +++ /dev/null @@ -1,55 +0,0 @@ -/* -** $Id: lualib.h,v 1.43.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua standard libraries -** See Copyright Notice in lua.h -*/ - - -#ifndef lualib_h -#define lualib_h - -#include "lua.h" - - - -LUAMOD_API int (luaopen_base) (lua_State *L); - -#define LUA_COLIBNAME "coroutine" -LUAMOD_API int (luaopen_coroutine) (lua_State *L); - -#define LUA_TABLIBNAME "table" -LUAMOD_API int (luaopen_table) (lua_State *L); - -#define LUA_IOLIBNAME "io" -LUAMOD_API int (luaopen_io) (lua_State *L); - -#define LUA_OSLIBNAME "os" -LUAMOD_API int (luaopen_os) (lua_State *L); - -#define LUA_STRLIBNAME "string" -LUAMOD_API int (luaopen_string) (lua_State *L); - -#define LUA_BITLIBNAME "bit32" -LUAMOD_API int (luaopen_bit32) (lua_State *L); - -#define LUA_MATHLIBNAME "math" -LUAMOD_API int (luaopen_math) (lua_State *L); - -#define LUA_DBLIBNAME "debug" -LUAMOD_API int (luaopen_debug) (lua_State *L); - -#define LUA_LOADLIBNAME "package" -LUAMOD_API int (luaopen_package) (lua_State *L); - - -/* open all previous libraries */ -LUALIB_API void (luaL_openlibs) (lua_State *L); - - - -#if !defined(lua_assert) -#define lua_assert(x) ((void)0) -#endif - - -#endif diff --git a/btgui/lua-5.2.3/src/lundump.c b/btgui/lua-5.2.3/src/lundump.c deleted file mode 100644 index 4163cb5d3..000000000 --- a/btgui/lua-5.2.3/src/lundump.c +++ /dev/null @@ -1,258 +0,0 @@ -/* -** $Id: lundump.c,v 2.22.1.1 2013/04/12 18:48:47 roberto Exp $ -** load precompiled Lua chunks -** See Copyright Notice in lua.h -*/ - -#include - -#define lundump_c -#define LUA_CORE - -#include "lua.h" - -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lmem.h" -#include "lobject.h" -#include "lstring.h" -#include "lundump.h" -#include "lzio.h" - -typedef struct { - lua_State* L; - ZIO* Z; - Mbuffer* b; - const char* name; -} LoadState; - -static l_noret error(LoadState* S, const char* why) -{ - luaO_pushfstring(S->L,"%s: %s precompiled chunk",S->name,why); - luaD_throw(S->L,LUA_ERRSYNTAX); -} - -#define LoadMem(S,b,n,size) LoadBlock(S,b,(n)*(size)) -#define LoadByte(S) (lu_byte)LoadChar(S) -#define LoadVar(S,x) LoadMem(S,&x,1,sizeof(x)) -#define LoadVector(S,b,n,size) LoadMem(S,b,n,size) - -#if !defined(luai_verifycode) -#define luai_verifycode(L,b,f) /* empty */ -#endif - -static void LoadBlock(LoadState* S, void* b, size_t size) -{ - if (luaZ_read(S->Z,b,size)!=0) error(S,"truncated"); -} - -static int LoadChar(LoadState* S) -{ - char x; - LoadVar(S,x); - return x; -} - -static int LoadInt(LoadState* S) -{ - int x; - LoadVar(S,x); - if (x<0) error(S,"corrupted"); - return x; -} - -static lua_Number LoadNumber(LoadState* S) -{ - lua_Number x; - LoadVar(S,x); - return x; -} - -static TString* LoadString(LoadState* S) -{ - size_t size; - LoadVar(S,size); - if (size==0) - return NULL; - else - { - char* s=luaZ_openspace(S->L,S->b,size); - LoadBlock(S,s,size*sizeof(char)); - return luaS_newlstr(S->L,s,size-1); /* remove trailing '\0' */ - } -} - -static void LoadCode(LoadState* S, Proto* f) -{ - int n=LoadInt(S); - f->code=luaM_newvector(S->L,n,Instruction); - f->sizecode=n; - LoadVector(S,f->code,n,sizeof(Instruction)); -} - -static void LoadFunction(LoadState* S, Proto* f); - -static void LoadConstants(LoadState* S, Proto* f) -{ - int i,n; - n=LoadInt(S); - f->k=luaM_newvector(S->L,n,TValue); - f->sizek=n; - for (i=0; ik[i]); - for (i=0; ik[i]; - int t=LoadChar(S); - switch (t) - { - case LUA_TNIL: - setnilvalue(o); - break; - case LUA_TBOOLEAN: - setbvalue(o,LoadChar(S)); - break; - case LUA_TNUMBER: - setnvalue(o,LoadNumber(S)); - break; - case LUA_TSTRING: - setsvalue2n(S->L,o,LoadString(S)); - break; - default: lua_assert(0); - } - } - n=LoadInt(S); - f->p=luaM_newvector(S->L,n,Proto*); - f->sizep=n; - for (i=0; ip[i]=NULL; - for (i=0; ip[i]=luaF_newproto(S->L); - LoadFunction(S,f->p[i]); - } -} - -static void LoadUpvalues(LoadState* S, Proto* f) -{ - int i,n; - n=LoadInt(S); - f->upvalues=luaM_newvector(S->L,n,Upvaldesc); - f->sizeupvalues=n; - for (i=0; iupvalues[i].name=NULL; - for (i=0; iupvalues[i].instack=LoadByte(S); - f->upvalues[i].idx=LoadByte(S); - } -} - -static void LoadDebug(LoadState* S, Proto* f) -{ - int i,n; - f->source=LoadString(S); - n=LoadInt(S); - f->lineinfo=luaM_newvector(S->L,n,int); - f->sizelineinfo=n; - LoadVector(S,f->lineinfo,n,sizeof(int)); - n=LoadInt(S); - f->locvars=luaM_newvector(S->L,n,LocVar); - f->sizelocvars=n; - for (i=0; ilocvars[i].varname=NULL; - for (i=0; ilocvars[i].varname=LoadString(S); - f->locvars[i].startpc=LoadInt(S); - f->locvars[i].endpc=LoadInt(S); - } - n=LoadInt(S); - for (i=0; iupvalues[i].name=LoadString(S); -} - -static void LoadFunction(LoadState* S, Proto* f) -{ - f->linedefined=LoadInt(S); - f->lastlinedefined=LoadInt(S); - f->numparams=LoadByte(S); - f->is_vararg=LoadByte(S); - f->maxstacksize=LoadByte(S); - LoadCode(S,f); - LoadConstants(S,f); - LoadUpvalues(S,f); - LoadDebug(S,f); -} - -/* the code below must be consistent with the code in luaU_header */ -#define N0 LUAC_HEADERSIZE -#define N1 (sizeof(LUA_SIGNATURE)-sizeof(char)) -#define N2 N1+2 -#define N3 N2+6 - -static void LoadHeader(LoadState* S) -{ - lu_byte h[LUAC_HEADERSIZE]; - lu_byte s[LUAC_HEADERSIZE]; - luaU_header(h); - memcpy(s,h,sizeof(char)); /* first char already read */ - LoadBlock(S,s+sizeof(char),LUAC_HEADERSIZE-sizeof(char)); - if (memcmp(h,s,N0)==0) return; - if (memcmp(h,s,N1)!=0) error(S,"not a"); - if (memcmp(h,s,N2)!=0) error(S,"version mismatch in"); - if (memcmp(h,s,N3)!=0) error(S,"incompatible"); else error(S,"corrupted"); -} - -/* -** load precompiled chunk -*/ -Closure* luaU_undump (lua_State* L, ZIO* Z, Mbuffer* buff, const char* name) -{ - LoadState S; - Closure* cl; - if (*name=='@' || *name=='=') - S.name=name+1; - else if (*name==LUA_SIGNATURE[0]) - S.name="binary string"; - else - S.name=name; - S.L=L; - S.Z=Z; - S.b=buff; - LoadHeader(&S); - cl=luaF_newLclosure(L,1); - setclLvalue(L,L->top,cl); incr_top(L); - cl->l.p=luaF_newproto(L); - LoadFunction(&S,cl->l.p); - if (cl->l.p->sizeupvalues != 1) - { - Proto* p=cl->l.p; - cl=luaF_newLclosure(L,cl->l.p->sizeupvalues); - cl->l.p=p; - setclLvalue(L,L->top-1,cl); - } - luai_verifycode(L,buff,cl->l.p); - return cl; -} - -#define MYINT(s) (s[0]-'0') -#define VERSION MYINT(LUA_VERSION_MAJOR)*16+MYINT(LUA_VERSION_MINOR) -#define FORMAT 0 /* this is the official format */ - -/* -* make header for precompiled chunks -* if you change the code below be sure to update LoadHeader and FORMAT above -* and LUAC_HEADERSIZE in lundump.h -*/ -void luaU_header (lu_byte* h) -{ - int x=1; - memcpy(h,LUA_SIGNATURE,sizeof(LUA_SIGNATURE)-sizeof(char)); - h+=sizeof(LUA_SIGNATURE)-sizeof(char); - *h++=cast_byte(VERSION); - *h++=cast_byte(FORMAT); - *h++=cast_byte(*(char*)&x); /* endianness */ - *h++=cast_byte(sizeof(int)); - *h++=cast_byte(sizeof(size_t)); - *h++=cast_byte(sizeof(Instruction)); - *h++=cast_byte(sizeof(lua_Number)); - *h++=cast_byte(((lua_Number)0.5)==0); /* is lua_Number integral? */ - memcpy(h,LUAC_TAIL,sizeof(LUAC_TAIL)-sizeof(char)); -} diff --git a/btgui/lua-5.2.3/src/lundump.h b/btgui/lua-5.2.3/src/lundump.h deleted file mode 100644 index 5255db259..000000000 --- a/btgui/lua-5.2.3/src/lundump.h +++ /dev/null @@ -1,28 +0,0 @@ -/* -** $Id: lundump.h,v 1.39.1.1 2013/04/12 18:48:47 roberto Exp $ -** load precompiled Lua chunks -** See Copyright Notice in lua.h -*/ - -#ifndef lundump_h -#define lundump_h - -#include "lobject.h" -#include "lzio.h" - -/* load one chunk; from lundump.c */ -LUAI_FUNC Closure* luaU_undump (lua_State* L, ZIO* Z, Mbuffer* buff, const char* name); - -/* make header; from lundump.c */ -LUAI_FUNC void luaU_header (lu_byte* h); - -/* dump one chunk; from ldump.c */ -LUAI_FUNC int luaU_dump (lua_State* L, const Proto* f, lua_Writer w, void* data, int strip); - -/* data to catch conversion errors */ -#define LUAC_TAIL "\x19\x93\r\n\x1a\n" - -/* size in bytes of header of binary files */ -#define LUAC_HEADERSIZE (sizeof(LUA_SIGNATURE)-sizeof(char)+2+6+sizeof(LUAC_TAIL)-sizeof(char)) - -#endif diff --git a/btgui/lua-5.2.3/src/lvm.c b/btgui/lua-5.2.3/src/lvm.c deleted file mode 100644 index 141b9fd19..000000000 --- a/btgui/lua-5.2.3/src/lvm.c +++ /dev/null @@ -1,867 +0,0 @@ -/* -** $Id: lvm.c,v 2.155.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua virtual machine -** See Copyright Notice in lua.h -*/ - - -#include -#include -#include - -#define lvm_c -#define LUA_CORE - -#include "lua.h" - -#include "ldebug.h" -#include "ldo.h" -#include "lfunc.h" -#include "lgc.h" -#include "lobject.h" -#include "lopcodes.h" -#include "lstate.h" -#include "lstring.h" -#include "ltable.h" -#include "ltm.h" -#include "lvm.h" - - - -/* limit for table tag-method chains (to avoid loops) */ -#define MAXTAGLOOP 100 - - -const TValue *luaV_tonumber (const TValue *obj, TValue *n) { - lua_Number num; - if (ttisnumber(obj)) return obj; - if (ttisstring(obj) && luaO_str2d(svalue(obj), tsvalue(obj)->len, &num)) { - setnvalue(n, num); - return n; - } - else - return NULL; -} - - -int luaV_tostring (lua_State *L, StkId obj) { - if (!ttisnumber(obj)) - return 0; - else { - char s[LUAI_MAXNUMBER2STR]; - lua_Number n = nvalue(obj); - int l = lua_number2str(s, n); - setsvalue2s(L, obj, luaS_newlstr(L, s, l)); - return 1; - } -} - - -static void traceexec (lua_State *L) { - CallInfo *ci = L->ci; - lu_byte mask = L->hookmask; - int counthook = ((mask & LUA_MASKCOUNT) && L->hookcount == 0); - if (counthook) - resethookcount(L); /* reset count */ - if (ci->callstatus & CIST_HOOKYIELD) { /* called hook last time? */ - ci->callstatus &= ~CIST_HOOKYIELD; /* erase mark */ - return; /* do not call hook again (VM yielded, so it did not move) */ - } - if (counthook) - luaD_hook(L, LUA_HOOKCOUNT, -1); /* call count hook */ - if (mask & LUA_MASKLINE) { - Proto *p = ci_func(ci)->p; - int npc = pcRel(ci->u.l.savedpc, p); - int newline = getfuncline(p, npc); - if (npc == 0 || /* call linehook when enter a new function, */ - ci->u.l.savedpc <= L->oldpc || /* when jump back (loop), or when */ - newline != getfuncline(p, pcRel(L->oldpc, p))) /* enter a new line */ - luaD_hook(L, LUA_HOOKLINE, newline); /* call line hook */ - } - L->oldpc = ci->u.l.savedpc; - if (L->status == LUA_YIELD) { /* did hook yield? */ - if (counthook) - L->hookcount = 1; /* undo decrement to zero */ - ci->u.l.savedpc--; /* undo increment (resume will increment it again) */ - ci->callstatus |= CIST_HOOKYIELD; /* mark that it yielded */ - ci->func = L->top - 1; /* protect stack below results */ - luaD_throw(L, LUA_YIELD); - } -} - - -static void callTM (lua_State *L, const TValue *f, const TValue *p1, - const TValue *p2, TValue *p3, int hasres) { - ptrdiff_t result = savestack(L, p3); - setobj2s(L, L->top++, f); /* push function */ - setobj2s(L, L->top++, p1); /* 1st argument */ - setobj2s(L, L->top++, p2); /* 2nd argument */ - if (!hasres) /* no result? 'p3' is third argument */ - setobj2s(L, L->top++, p3); /* 3rd argument */ - /* metamethod may yield only when called from Lua code */ - luaD_call(L, L->top - (4 - hasres), hasres, isLua(L->ci)); - if (hasres) { /* if has result, move it to its place */ - p3 = restorestack(L, result); - setobjs2s(L, p3, --L->top); - } -} - - -void luaV_gettable (lua_State *L, const TValue *t, TValue *key, StkId val) { - int loop; - for (loop = 0; loop < MAXTAGLOOP; loop++) { - const TValue *tm; - if (ttistable(t)) { /* `t' is a table? */ - Table *h = hvalue(t); - const TValue *res = luaH_get(h, key); /* do a primitive get */ - if (!ttisnil(res) || /* result is not nil? */ - (tm = fasttm(L, h->metatable, TM_INDEX)) == NULL) { /* or no TM? */ - setobj2s(L, val, res); - return; - } - /* else will try the tag method */ - } - else if (ttisnil(tm = luaT_gettmbyobj(L, t, TM_INDEX))) - luaG_typeerror(L, t, "index"); - if (ttisfunction(tm)) { - callTM(L, tm, t, key, val, 1); - return; - } - t = tm; /* else repeat with 'tm' */ - } - luaG_runerror(L, "loop in gettable"); -} - - -void luaV_settable (lua_State *L, const TValue *t, TValue *key, StkId val) { - int loop; - for (loop = 0; loop < MAXTAGLOOP; loop++) { - const TValue *tm; - if (ttistable(t)) { /* `t' is a table? */ - Table *h = hvalue(t); - TValue *oldval = cast(TValue *, luaH_get(h, key)); - /* if previous value is not nil, there must be a previous entry - in the table; moreover, a metamethod has no relevance */ - if (!ttisnil(oldval) || - /* previous value is nil; must check the metamethod */ - ((tm = fasttm(L, h->metatable, TM_NEWINDEX)) == NULL && - /* no metamethod; is there a previous entry in the table? */ - (oldval != luaO_nilobject || - /* no previous entry; must create one. (The next test is - always true; we only need the assignment.) */ - (oldval = luaH_newkey(L, h, key), 1)))) { - /* no metamethod and (now) there is an entry with given key */ - setobj2t(L, oldval, val); /* assign new value to that entry */ - invalidateTMcache(h); - luaC_barrierback(L, obj2gco(h), val); - return; - } - /* else will try the metamethod */ - } - else /* not a table; check metamethod */ - if (ttisnil(tm = luaT_gettmbyobj(L, t, TM_NEWINDEX))) - luaG_typeerror(L, t, "index"); - /* there is a metamethod */ - if (ttisfunction(tm)) { - callTM(L, tm, t, key, val, 0); - return; - } - t = tm; /* else repeat with 'tm' */ - } - luaG_runerror(L, "loop in settable"); -} - - -static int call_binTM (lua_State *L, const TValue *p1, const TValue *p2, - StkId res, TMS event) { - const TValue *tm = luaT_gettmbyobj(L, p1, event); /* try first operand */ - if (ttisnil(tm)) - tm = luaT_gettmbyobj(L, p2, event); /* try second operand */ - if (ttisnil(tm)) return 0; - callTM(L, tm, p1, p2, res, 1); - return 1; -} - - -static const TValue *get_equalTM (lua_State *L, Table *mt1, Table *mt2, - TMS event) { - const TValue *tm1 = fasttm(L, mt1, event); - const TValue *tm2; - if (tm1 == NULL) return NULL; /* no metamethod */ - if (mt1 == mt2) return tm1; /* same metatables => same metamethods */ - tm2 = fasttm(L, mt2, event); - if (tm2 == NULL) return NULL; /* no metamethod */ - if (luaV_rawequalobj(tm1, tm2)) /* same metamethods? */ - return tm1; - return NULL; -} - - -static int call_orderTM (lua_State *L, const TValue *p1, const TValue *p2, - TMS event) { - if (!call_binTM(L, p1, p2, L->top, event)) - return -1; /* no metamethod */ - else - return !l_isfalse(L->top); -} - - -static int l_strcmp (const TString *ls, const TString *rs) { - const char *l = getstr(ls); - size_t ll = ls->tsv.len; - const char *r = getstr(rs); - size_t lr = rs->tsv.len; - for (;;) { - int temp = strcoll(l, r); - if (temp != 0) return temp; - else { /* strings are equal up to a `\0' */ - size_t len = strlen(l); /* index of first `\0' in both strings */ - if (len == lr) /* r is finished? */ - return (len == ll) ? 0 : 1; - else if (len == ll) /* l is finished? */ - return -1; /* l is smaller than r (because r is not finished) */ - /* both strings longer than `len'; go on comparing (after the `\0') */ - len++; - l += len; ll -= len; r += len; lr -= len; - } - } -} - - -int luaV_lessthan (lua_State *L, const TValue *l, const TValue *r) { - int res; - if (ttisnumber(l) && ttisnumber(r)) - return luai_numlt(L, nvalue(l), nvalue(r)); - else if (ttisstring(l) && ttisstring(r)) - return l_strcmp(rawtsvalue(l), rawtsvalue(r)) < 0; - else if ((res = call_orderTM(L, l, r, TM_LT)) < 0) - luaG_ordererror(L, l, r); - return res; -} - - -int luaV_lessequal (lua_State *L, const TValue *l, const TValue *r) { - int res; - if (ttisnumber(l) && ttisnumber(r)) - return luai_numle(L, nvalue(l), nvalue(r)); - else if (ttisstring(l) && ttisstring(r)) - return l_strcmp(rawtsvalue(l), rawtsvalue(r)) <= 0; - else if ((res = call_orderTM(L, l, r, TM_LE)) >= 0) /* first try `le' */ - return res; - else if ((res = call_orderTM(L, r, l, TM_LT)) < 0) /* else try `lt' */ - luaG_ordererror(L, l, r); - return !res; -} - - -/* -** equality of Lua values. L == NULL means raw equality (no metamethods) -*/ -int luaV_equalobj_ (lua_State *L, const TValue *t1, const TValue *t2) { - const TValue *tm; - lua_assert(ttisequal(t1, t2)); - switch (ttype(t1)) { - case LUA_TNIL: return 1; - case LUA_TNUMBER: return luai_numeq(nvalue(t1), nvalue(t2)); - case LUA_TBOOLEAN: return bvalue(t1) == bvalue(t2); /* true must be 1 !! */ - case LUA_TLIGHTUSERDATA: return pvalue(t1) == pvalue(t2); - case LUA_TLCF: return fvalue(t1) == fvalue(t2); - case LUA_TSHRSTR: return eqshrstr(rawtsvalue(t1), rawtsvalue(t2)); - case LUA_TLNGSTR: return luaS_eqlngstr(rawtsvalue(t1), rawtsvalue(t2)); - case LUA_TUSERDATA: { - if (uvalue(t1) == uvalue(t2)) return 1; - else if (L == NULL) return 0; - tm = get_equalTM(L, uvalue(t1)->metatable, uvalue(t2)->metatable, TM_EQ); - break; /* will try TM */ - } - case LUA_TTABLE: { - if (hvalue(t1) == hvalue(t2)) return 1; - else if (L == NULL) return 0; - tm = get_equalTM(L, hvalue(t1)->metatable, hvalue(t2)->metatable, TM_EQ); - break; /* will try TM */ - } - default: - lua_assert(iscollectable(t1)); - return gcvalue(t1) == gcvalue(t2); - } - if (tm == NULL) return 0; /* no TM? */ - callTM(L, tm, t1, t2, L->top, 1); /* call TM */ - return !l_isfalse(L->top); -} - - -void luaV_concat (lua_State *L, int total) { - lua_assert(total >= 2); - do { - StkId top = L->top; - int n = 2; /* number of elements handled in this pass (at least 2) */ - if (!(ttisstring(top-2) || ttisnumber(top-2)) || !tostring(L, top-1)) { - if (!call_binTM(L, top-2, top-1, top-2, TM_CONCAT)) - luaG_concaterror(L, top-2, top-1); - } - else if (tsvalue(top-1)->len == 0) /* second operand is empty? */ - (void)tostring(L, top - 2); /* result is first operand */ - else if (ttisstring(top-2) && tsvalue(top-2)->len == 0) { - setobjs2s(L, top - 2, top - 1); /* result is second op. */ - } - else { - /* at least two non-empty string values; get as many as possible */ - size_t tl = tsvalue(top-1)->len; - char *buffer; - int i; - /* collect total length */ - for (i = 1; i < total && tostring(L, top-i-1); i++) { - size_t l = tsvalue(top-i-1)->len; - if (l >= (MAX_SIZET/sizeof(char)) - tl) - luaG_runerror(L, "string length overflow"); - tl += l; - } - buffer = luaZ_openspace(L, &G(L)->buff, tl); - tl = 0; - n = i; - do { /* concat all strings */ - size_t l = tsvalue(top-i)->len; - memcpy(buffer+tl, svalue(top-i), l * sizeof(char)); - tl += l; - } while (--i > 0); - setsvalue2s(L, top-n, luaS_newlstr(L, buffer, tl)); - } - total -= n-1; /* got 'n' strings to create 1 new */ - L->top -= n-1; /* popped 'n' strings and pushed one */ - } while (total > 1); /* repeat until only 1 result left */ -} - - -void luaV_objlen (lua_State *L, StkId ra, const TValue *rb) { - const TValue *tm; - switch (ttypenv(rb)) { - case LUA_TTABLE: { - Table *h = hvalue(rb); - tm = fasttm(L, h->metatable, TM_LEN); - if (tm) break; /* metamethod? break switch to call it */ - setnvalue(ra, cast_num(luaH_getn(h))); /* else primitive len */ - return; - } - case LUA_TSTRING: { - setnvalue(ra, cast_num(tsvalue(rb)->len)); - return; - } - default: { /* try metamethod */ - tm = luaT_gettmbyobj(L, rb, TM_LEN); - if (ttisnil(tm)) /* no metamethod? */ - luaG_typeerror(L, rb, "get length of"); - break; - } - } - callTM(L, tm, rb, rb, ra, 1); -} - - -void luaV_arith (lua_State *L, StkId ra, const TValue *rb, - const TValue *rc, TMS op) { - TValue tempb, tempc; - const TValue *b, *c; - if ((b = luaV_tonumber(rb, &tempb)) != NULL && - (c = luaV_tonumber(rc, &tempc)) != NULL) { - lua_Number res = luaO_arith(op - TM_ADD + LUA_OPADD, nvalue(b), nvalue(c)); - setnvalue(ra, res); - } - else if (!call_binTM(L, rb, rc, ra, op)) - luaG_aritherror(L, rb, rc); -} - - -/* -** check whether cached closure in prototype 'p' may be reused, that is, -** whether there is a cached closure with the same upvalues needed by -** new closure to be created. -*/ -static Closure *getcached (Proto *p, UpVal **encup, StkId base) { - Closure *c = p->cache; - if (c != NULL) { /* is there a cached closure? */ - int nup = p->sizeupvalues; - Upvaldesc *uv = p->upvalues; - int i; - for (i = 0; i < nup; i++) { /* check whether it has right upvalues */ - TValue *v = uv[i].instack ? base + uv[i].idx : encup[uv[i].idx]->v; - if (c->l.upvals[i]->v != v) - return NULL; /* wrong upvalue; cannot reuse closure */ - } - } - return c; /* return cached closure (or NULL if no cached closure) */ -} - - -/* -** create a new Lua closure, push it in the stack, and initialize -** its upvalues. Note that the call to 'luaC_barrierproto' must come -** before the assignment to 'p->cache', as the function needs the -** original value of that field. -*/ -static void pushclosure (lua_State *L, Proto *p, UpVal **encup, StkId base, - StkId ra) { - int nup = p->sizeupvalues; - Upvaldesc *uv = p->upvalues; - int i; - Closure *ncl = luaF_newLclosure(L, nup); - ncl->l.p = p; - setclLvalue(L, ra, ncl); /* anchor new closure in stack */ - for (i = 0; i < nup; i++) { /* fill in its upvalues */ - if (uv[i].instack) /* upvalue refers to local variable? */ - ncl->l.upvals[i] = luaF_findupval(L, base + uv[i].idx); - else /* get upvalue from enclosing function */ - ncl->l.upvals[i] = encup[uv[i].idx]; - } - luaC_barrierproto(L, p, ncl); - p->cache = ncl; /* save it on cache for reuse */ -} - - -/* -** finish execution of an opcode interrupted by an yield -*/ -void luaV_finishOp (lua_State *L) { - CallInfo *ci = L->ci; - StkId base = ci->u.l.base; - Instruction inst = *(ci->u.l.savedpc - 1); /* interrupted instruction */ - OpCode op = GET_OPCODE(inst); - switch (op) { /* finish its execution */ - case OP_ADD: case OP_SUB: case OP_MUL: case OP_DIV: - case OP_MOD: case OP_POW: case OP_UNM: case OP_LEN: - case OP_GETTABUP: case OP_GETTABLE: case OP_SELF: { - setobjs2s(L, base + GETARG_A(inst), --L->top); - break; - } - case OP_LE: case OP_LT: case OP_EQ: { - int res = !l_isfalse(L->top - 1); - L->top--; - /* metamethod should not be called when operand is K */ - lua_assert(!ISK(GETARG_B(inst))); - if (op == OP_LE && /* "<=" using "<" instead? */ - ttisnil(luaT_gettmbyobj(L, base + GETARG_B(inst), TM_LE))) - res = !res; /* invert result */ - lua_assert(GET_OPCODE(*ci->u.l.savedpc) == OP_JMP); - if (res != GETARG_A(inst)) /* condition failed? */ - ci->u.l.savedpc++; /* skip jump instruction */ - break; - } - case OP_CONCAT: { - StkId top = L->top - 1; /* top when 'call_binTM' was called */ - int b = GETARG_B(inst); /* first element to concatenate */ - int total = cast_int(top - 1 - (base + b)); /* yet to concatenate */ - setobj2s(L, top - 2, top); /* put TM result in proper position */ - if (total > 1) { /* are there elements to concat? */ - L->top = top - 1; /* top is one after last element (at top-2) */ - luaV_concat(L, total); /* concat them (may yield again) */ - } - /* move final result to final position */ - setobj2s(L, ci->u.l.base + GETARG_A(inst), L->top - 1); - L->top = ci->top; /* restore top */ - break; - } - case OP_TFORCALL: { - lua_assert(GET_OPCODE(*ci->u.l.savedpc) == OP_TFORLOOP); - L->top = ci->top; /* correct top */ - break; - } - case OP_CALL: { - if (GETARG_C(inst) - 1 >= 0) /* nresults >= 0? */ - L->top = ci->top; /* adjust results */ - break; - } - case OP_TAILCALL: case OP_SETTABUP: case OP_SETTABLE: - break; - default: lua_assert(0); - } -} - - - -/* -** some macros for common tasks in `luaV_execute' -*/ - -#if !defined luai_runtimecheck -#define luai_runtimecheck(L, c) /* void */ -#endif - - -#define RA(i) (base+GETARG_A(i)) -/* to be used after possible stack reallocation */ -#define RB(i) check_exp(getBMode(GET_OPCODE(i)) == OpArgR, base+GETARG_B(i)) -#define RC(i) check_exp(getCMode(GET_OPCODE(i)) == OpArgR, base+GETARG_C(i)) -#define RKB(i) check_exp(getBMode(GET_OPCODE(i)) == OpArgK, \ - ISK(GETARG_B(i)) ? k+INDEXK(GETARG_B(i)) : base+GETARG_B(i)) -#define RKC(i) check_exp(getCMode(GET_OPCODE(i)) == OpArgK, \ - ISK(GETARG_C(i)) ? k+INDEXK(GETARG_C(i)) : base+GETARG_C(i)) -#define KBx(i) \ - (k + (GETARG_Bx(i) != 0 ? GETARG_Bx(i) - 1 : GETARG_Ax(*ci->u.l.savedpc++))) - - -/* execute a jump instruction */ -#define dojump(ci,i,e) \ - { int a = GETARG_A(i); \ - if (a > 0) luaF_close(L, ci->u.l.base + a - 1); \ - ci->u.l.savedpc += GETARG_sBx(i) + e; } - -/* for test instructions, execute the jump instruction that follows it */ -#define donextjump(ci) { i = *ci->u.l.savedpc; dojump(ci, i, 1); } - - -#define Protect(x) { {x;}; base = ci->u.l.base; } - -#define checkGC(L,c) \ - Protect( luaC_condGC(L,{L->top = (c); /* limit of live values */ \ - luaC_step(L); \ - L->top = ci->top;}) /* restore top */ \ - luai_threadyield(L); ) - - -#define arith_op(op,tm) { \ - TValue *rb = RKB(i); \ - TValue *rc = RKC(i); \ - if (ttisnumber(rb) && ttisnumber(rc)) { \ - lua_Number nb = nvalue(rb), nc = nvalue(rc); \ - setnvalue(ra, op(L, nb, nc)); \ - } \ - else { Protect(luaV_arith(L, ra, rb, rc, tm)); } } - - -#define vmdispatch(o) switch(o) -#define vmcase(l,b) case l: {b} break; -#define vmcasenb(l,b) case l: {b} /* nb = no break */ - -void luaV_execute (lua_State *L) { - CallInfo *ci = L->ci; - LClosure *cl; - TValue *k; - StkId base; - newframe: /* reentry point when frame changes (call/return) */ - lua_assert(ci == L->ci); - cl = clLvalue(ci->func); - k = cl->p->k; - base = ci->u.l.base; - /* main loop of interpreter */ - for (;;) { - Instruction i = *(ci->u.l.savedpc++); - StkId ra; - if ((L->hookmask & (LUA_MASKLINE | LUA_MASKCOUNT)) && - (--L->hookcount == 0 || L->hookmask & LUA_MASKLINE)) { - Protect(traceexec(L)); - } - /* WARNING: several calls may realloc the stack and invalidate `ra' */ - ra = RA(i); - lua_assert(base == ci->u.l.base); - lua_assert(base <= L->top && L->top < L->stack + L->stacksize); - vmdispatch (GET_OPCODE(i)) { - vmcase(OP_MOVE, - setobjs2s(L, ra, RB(i)); - ) - vmcase(OP_LOADK, - TValue *rb = k + GETARG_Bx(i); - setobj2s(L, ra, rb); - ) - vmcase(OP_LOADKX, - TValue *rb; - lua_assert(GET_OPCODE(*ci->u.l.savedpc) == OP_EXTRAARG); - rb = k + GETARG_Ax(*ci->u.l.savedpc++); - setobj2s(L, ra, rb); - ) - vmcase(OP_LOADBOOL, - setbvalue(ra, GETARG_B(i)); - if (GETARG_C(i)) ci->u.l.savedpc++; /* skip next instruction (if C) */ - ) - vmcase(OP_LOADNIL, - int b = GETARG_B(i); - do { - setnilvalue(ra++); - } while (b--); - ) - vmcase(OP_GETUPVAL, - int b = GETARG_B(i); - setobj2s(L, ra, cl->upvals[b]->v); - ) - vmcase(OP_GETTABUP, - int b = GETARG_B(i); - Protect(luaV_gettable(L, cl->upvals[b]->v, RKC(i), ra)); - ) - vmcase(OP_GETTABLE, - Protect(luaV_gettable(L, RB(i), RKC(i), ra)); - ) - vmcase(OP_SETTABUP, - int a = GETARG_A(i); - Protect(luaV_settable(L, cl->upvals[a]->v, RKB(i), RKC(i))); - ) - vmcase(OP_SETUPVAL, - UpVal *uv = cl->upvals[GETARG_B(i)]; - setobj(L, uv->v, ra); - luaC_barrier(L, uv, ra); - ) - vmcase(OP_SETTABLE, - Protect(luaV_settable(L, ra, RKB(i), RKC(i))); - ) - vmcase(OP_NEWTABLE, - int b = GETARG_B(i); - int c = GETARG_C(i); - Table *t = luaH_new(L); - sethvalue(L, ra, t); - if (b != 0 || c != 0) - luaH_resize(L, t, luaO_fb2int(b), luaO_fb2int(c)); - checkGC(L, ra + 1); - ) - vmcase(OP_SELF, - StkId rb = RB(i); - setobjs2s(L, ra+1, rb); - Protect(luaV_gettable(L, rb, RKC(i), ra)); - ) - vmcase(OP_ADD, - arith_op(luai_numadd, TM_ADD); - ) - vmcase(OP_SUB, - arith_op(luai_numsub, TM_SUB); - ) - vmcase(OP_MUL, - arith_op(luai_nummul, TM_MUL); - ) - vmcase(OP_DIV, - arith_op(luai_numdiv, TM_DIV); - ) - vmcase(OP_MOD, - arith_op(luai_nummod, TM_MOD); - ) - vmcase(OP_POW, - arith_op(luai_numpow, TM_POW); - ) - vmcase(OP_UNM, - TValue *rb = RB(i); - if (ttisnumber(rb)) { - lua_Number nb = nvalue(rb); - setnvalue(ra, luai_numunm(L, nb)); - } - else { - Protect(luaV_arith(L, ra, rb, rb, TM_UNM)); - } - ) - vmcase(OP_NOT, - TValue *rb = RB(i); - int res = l_isfalse(rb); /* next assignment may change this value */ - setbvalue(ra, res); - ) - vmcase(OP_LEN, - Protect(luaV_objlen(L, ra, RB(i))); - ) - vmcase(OP_CONCAT, - int b = GETARG_B(i); - int c = GETARG_C(i); - StkId rb; - L->top = base + c + 1; /* mark the end of concat operands */ - Protect(luaV_concat(L, c - b + 1)); - ra = RA(i); /* 'luav_concat' may invoke TMs and move the stack */ - rb = b + base; - setobjs2s(L, ra, rb); - checkGC(L, (ra >= rb ? ra + 1 : rb)); - L->top = ci->top; /* restore top */ - ) - vmcase(OP_JMP, - dojump(ci, i, 0); - ) - vmcase(OP_EQ, - TValue *rb = RKB(i); - TValue *rc = RKC(i); - Protect( - if (cast_int(equalobj(L, rb, rc)) != GETARG_A(i)) - ci->u.l.savedpc++; - else - donextjump(ci); - ) - ) - vmcase(OP_LT, - Protect( - if (luaV_lessthan(L, RKB(i), RKC(i)) != GETARG_A(i)) - ci->u.l.savedpc++; - else - donextjump(ci); - ) - ) - vmcase(OP_LE, - Protect( - if (luaV_lessequal(L, RKB(i), RKC(i)) != GETARG_A(i)) - ci->u.l.savedpc++; - else - donextjump(ci); - ) - ) - vmcase(OP_TEST, - if (GETARG_C(i) ? l_isfalse(ra) : !l_isfalse(ra)) - ci->u.l.savedpc++; - else - donextjump(ci); - ) - vmcase(OP_TESTSET, - TValue *rb = RB(i); - if (GETARG_C(i) ? l_isfalse(rb) : !l_isfalse(rb)) - ci->u.l.savedpc++; - else { - setobjs2s(L, ra, rb); - donextjump(ci); - } - ) - vmcase(OP_CALL, - int b = GETARG_B(i); - int nresults = GETARG_C(i) - 1; - if (b != 0) L->top = ra+b; /* else previous instruction set top */ - if (luaD_precall(L, ra, nresults)) { /* C function? */ - if (nresults >= 0) L->top = ci->top; /* adjust results */ - base = ci->u.l.base; - } - else { /* Lua function */ - ci = L->ci; - ci->callstatus |= CIST_REENTRY; - goto newframe; /* restart luaV_execute over new Lua function */ - } - ) - vmcase(OP_TAILCALL, - int b = GETARG_B(i); - if (b != 0) L->top = ra+b; /* else previous instruction set top */ - lua_assert(GETARG_C(i) - 1 == LUA_MULTRET); - if (luaD_precall(L, ra, LUA_MULTRET)) /* C function? */ - base = ci->u.l.base; - else { - /* tail call: put called frame (n) in place of caller one (o) */ - CallInfo *nci = L->ci; /* called frame */ - CallInfo *oci = nci->previous; /* caller frame */ - StkId nfunc = nci->func; /* called function */ - StkId ofunc = oci->func; /* caller function */ - /* last stack slot filled by 'precall' */ - StkId lim = nci->u.l.base + getproto(nfunc)->numparams; - int aux; - /* close all upvalues from previous call */ - if (cl->p->sizep > 0) luaF_close(L, oci->u.l.base); - /* move new frame into old one */ - for (aux = 0; nfunc + aux < lim; aux++) - setobjs2s(L, ofunc + aux, nfunc + aux); - oci->u.l.base = ofunc + (nci->u.l.base - nfunc); /* correct base */ - oci->top = L->top = ofunc + (L->top - nfunc); /* correct top */ - oci->u.l.savedpc = nci->u.l.savedpc; - oci->callstatus |= CIST_TAIL; /* function was tail called */ - ci = L->ci = oci; /* remove new frame */ - lua_assert(L->top == oci->u.l.base + getproto(ofunc)->maxstacksize); - goto newframe; /* restart luaV_execute over new Lua function */ - } - ) - vmcasenb(OP_RETURN, - int b = GETARG_B(i); - if (b != 0) L->top = ra+b-1; - if (cl->p->sizep > 0) luaF_close(L, base); - b = luaD_poscall(L, ra); - if (!(ci->callstatus & CIST_REENTRY)) /* 'ci' still the called one */ - return; /* external invocation: return */ - else { /* invocation via reentry: continue execution */ - ci = L->ci; - if (b) L->top = ci->top; - lua_assert(isLua(ci)); - lua_assert(GET_OPCODE(*((ci)->u.l.savedpc - 1)) == OP_CALL); - goto newframe; /* restart luaV_execute over new Lua function */ - } - ) - vmcase(OP_FORLOOP, - lua_Number step = nvalue(ra+2); - lua_Number idx = luai_numadd(L, nvalue(ra), step); /* increment index */ - lua_Number limit = nvalue(ra+1); - if (luai_numlt(L, 0, step) ? luai_numle(L, idx, limit) - : luai_numle(L, limit, idx)) { - ci->u.l.savedpc += GETARG_sBx(i); /* jump back */ - setnvalue(ra, idx); /* update internal index... */ - setnvalue(ra+3, idx); /* ...and external index */ - } - ) - vmcase(OP_FORPREP, - const TValue *init = ra; - const TValue *plimit = ra+1; - const TValue *pstep = ra+2; - if (!tonumber(init, ra)) - luaG_runerror(L, LUA_QL("for") " initial value must be a number"); - else if (!tonumber(plimit, ra+1)) - luaG_runerror(L, LUA_QL("for") " limit must be a number"); - else if (!tonumber(pstep, ra+2)) - luaG_runerror(L, LUA_QL("for") " step must be a number"); - setnvalue(ra, luai_numsub(L, nvalue(ra), nvalue(pstep))); - ci->u.l.savedpc += GETARG_sBx(i); - ) - vmcasenb(OP_TFORCALL, - StkId cb = ra + 3; /* call base */ - setobjs2s(L, cb+2, ra+2); - setobjs2s(L, cb+1, ra+1); - setobjs2s(L, cb, ra); - L->top = cb + 3; /* func. + 2 args (state and index) */ - Protect(luaD_call(L, cb, GETARG_C(i), 1)); - L->top = ci->top; - i = *(ci->u.l.savedpc++); /* go to next instruction */ - ra = RA(i); - lua_assert(GET_OPCODE(i) == OP_TFORLOOP); - goto l_tforloop; - ) - vmcase(OP_TFORLOOP, - l_tforloop: - if (!ttisnil(ra + 1)) { /* continue loop? */ - setobjs2s(L, ra, ra + 1); /* save control variable */ - ci->u.l.savedpc += GETARG_sBx(i); /* jump back */ - } - ) - vmcase(OP_SETLIST, - int n = GETARG_B(i); - int c = GETARG_C(i); - int last; - Table *h; - if (n == 0) n = cast_int(L->top - ra) - 1; - if (c == 0) { - lua_assert(GET_OPCODE(*ci->u.l.savedpc) == OP_EXTRAARG); - c = GETARG_Ax(*ci->u.l.savedpc++); - } - luai_runtimecheck(L, ttistable(ra)); - h = hvalue(ra); - last = ((c-1)*LFIELDS_PER_FLUSH) + n; - if (last > h->sizearray) /* needs more space? */ - luaH_resizearray(L, h, last); /* pre-allocate it at once */ - for (; n > 0; n--) { - TValue *val = ra+n; - luaH_setint(L, h, last--, val); - luaC_barrierback(L, obj2gco(h), val); - } - L->top = ci->top; /* correct top (in case of previous open call) */ - ) - vmcase(OP_CLOSURE, - Proto *p = cl->p->p[GETARG_Bx(i)]; - Closure *ncl = getcached(p, cl->upvals, base); /* cached closure */ - if (ncl == NULL) /* no match? */ - pushclosure(L, p, cl->upvals, base, ra); /* create a new one */ - else - setclLvalue(L, ra, ncl); /* push cashed closure */ - checkGC(L, ra + 1); - ) - vmcase(OP_VARARG, - int b = GETARG_B(i) - 1; - int j; - int n = cast_int(base - ci->func) - cl->p->numparams - 1; - if (b < 0) { /* B == 0? */ - b = n; /* get all var. arguments */ - Protect(luaD_checkstack(L, n)); - ra = RA(i); /* previous call may change the stack */ - L->top = ra + n; - } - for (j = 0; j < b; j++) { - if (j < n) { - setobjs2s(L, ra + j, base - n + j); - } - else { - setnilvalue(ra + j); - } - } - ) - vmcase(OP_EXTRAARG, - lua_assert(0); - ) - } - } -} - diff --git a/btgui/lua-5.2.3/src/lvm.h b/btgui/lua-5.2.3/src/lvm.h deleted file mode 100644 index 5380270da..000000000 --- a/btgui/lua-5.2.3/src/lvm.h +++ /dev/null @@ -1,44 +0,0 @@ -/* -** $Id: lvm.h,v 2.18.1.1 2013/04/12 18:48:47 roberto Exp $ -** Lua virtual machine -** See Copyright Notice in lua.h -*/ - -#ifndef lvm_h -#define lvm_h - - -#include "ldo.h" -#include "lobject.h" -#include "ltm.h" - - -#define tostring(L,o) (ttisstring(o) || (luaV_tostring(L, o))) - -#define tonumber(o,n) (ttisnumber(o) || (((o) = luaV_tonumber(o,n)) != NULL)) - -#define equalobj(L,o1,o2) (ttisequal(o1, o2) && luaV_equalobj_(L, o1, o2)) - -#define luaV_rawequalobj(o1,o2) equalobj(NULL,o1,o2) - - -/* not to called directly */ -LUAI_FUNC int luaV_equalobj_ (lua_State *L, const TValue *t1, const TValue *t2); - - -LUAI_FUNC int luaV_lessthan (lua_State *L, const TValue *l, const TValue *r); -LUAI_FUNC int luaV_lessequal (lua_State *L, const TValue *l, const TValue *r); -LUAI_FUNC const TValue *luaV_tonumber (const TValue *obj, TValue *n); -LUAI_FUNC int luaV_tostring (lua_State *L, StkId obj); -LUAI_FUNC void luaV_gettable (lua_State *L, const TValue *t, TValue *key, - StkId val); -LUAI_FUNC void luaV_settable (lua_State *L, const TValue *t, TValue *key, - StkId val); -LUAI_FUNC void luaV_finishOp (lua_State *L); -LUAI_FUNC void luaV_execute (lua_State *L); -LUAI_FUNC void luaV_concat (lua_State *L, int total); -LUAI_FUNC void luaV_arith (lua_State *L, StkId ra, const TValue *rb, - const TValue *rc, TMS op); -LUAI_FUNC void luaV_objlen (lua_State *L, StkId ra, const TValue *rb); - -#endif diff --git a/btgui/lua-5.2.3/src/lzio.c b/btgui/lua-5.2.3/src/lzio.c deleted file mode 100644 index 20efea983..000000000 --- a/btgui/lua-5.2.3/src/lzio.c +++ /dev/null @@ -1,76 +0,0 @@ -/* -** $Id: lzio.c,v 1.35.1.1 2013/04/12 18:48:47 roberto Exp $ -** Buffered streams -** See Copyright Notice in lua.h -*/ - - -#include - -#define lzio_c -#define LUA_CORE - -#include "lua.h" - -#include "llimits.h" -#include "lmem.h" -#include "lstate.h" -#include "lzio.h" - - -int luaZ_fill (ZIO *z) { - size_t size; - lua_State *L = z->L; - const char *buff; - lua_unlock(L); - buff = z->reader(L, z->data, &size); - lua_lock(L); - if (buff == NULL || size == 0) - return EOZ; - z->n = size - 1; /* discount char being returned */ - z->p = buff; - return cast_uchar(*(z->p++)); -} - - -void luaZ_init (lua_State *L, ZIO *z, lua_Reader reader, void *data) { - z->L = L; - z->reader = reader; - z->data = data; - z->n = 0; - z->p = NULL; -} - - -/* --------------------------------------------------------------- read --- */ -size_t luaZ_read (ZIO *z, void *b, size_t n) { - while (n) { - size_t m; - if (z->n == 0) { /* no bytes in buffer? */ - if (luaZ_fill(z) == EOZ) /* try to read more */ - return n; /* no more input; return number of missing bytes */ - else { - z->n++; /* luaZ_fill consumed first byte; put it back */ - z->p--; - } - } - m = (n <= z->n) ? n : z->n; /* min. between n and z->n */ - memcpy(b, z->p, m); - z->n -= m; - z->p += m; - b = (char *)b + m; - n -= m; - } - return 0; -} - -/* ------------------------------------------------------------------------ */ -char *luaZ_openspace (lua_State *L, Mbuffer *buff, size_t n) { - if (n > buff->buffsize) { - if (n < LUA_MINBUFFER) n = LUA_MINBUFFER; - luaZ_resizebuffer(L, buff, n); - } - return buff->buffer; -} - - diff --git a/btgui/lua-5.2.3/src/lzio.h b/btgui/lua-5.2.3/src/lzio.h deleted file mode 100644 index 441f7479c..000000000 --- a/btgui/lua-5.2.3/src/lzio.h +++ /dev/null @@ -1,65 +0,0 @@ -/* -** $Id: lzio.h,v 1.26.1.1 2013/04/12 18:48:47 roberto Exp $ -** Buffered streams -** See Copyright Notice in lua.h -*/ - - -#ifndef lzio_h -#define lzio_h - -#include "lua.h" - -#include "lmem.h" - - -#define EOZ (-1) /* end of stream */ - -typedef struct Zio ZIO; - -#define zgetc(z) (((z)->n--)>0 ? cast_uchar(*(z)->p++) : luaZ_fill(z)) - - -typedef struct Mbuffer { - char *buffer; - size_t n; - size_t buffsize; -} Mbuffer; - -#define luaZ_initbuffer(L, buff) ((buff)->buffer = NULL, (buff)->buffsize = 0) - -#define luaZ_buffer(buff) ((buff)->buffer) -#define luaZ_sizebuffer(buff) ((buff)->buffsize) -#define luaZ_bufflen(buff) ((buff)->n) - -#define luaZ_resetbuffer(buff) ((buff)->n = 0) - - -#define luaZ_resizebuffer(L, buff, size) \ - (luaM_reallocvector(L, (buff)->buffer, (buff)->buffsize, size, char), \ - (buff)->buffsize = size) - -#define luaZ_freebuffer(L, buff) luaZ_resizebuffer(L, buff, 0) - - -LUAI_FUNC char *luaZ_openspace (lua_State *L, Mbuffer *buff, size_t n); -LUAI_FUNC void luaZ_init (lua_State *L, ZIO *z, lua_Reader reader, - void *data); -LUAI_FUNC size_t luaZ_read (ZIO* z, void* b, size_t n); /* read next n bytes */ - - - -/* --------- Private Part ------------------ */ - -struct Zio { - size_t n; /* bytes still unread */ - const char *p; /* current position in buffer */ - lua_Reader reader; /* reader function */ - void* data; /* additional data */ - lua_State *L; /* Lua state (for reader) */ -}; - - -LUAI_FUNC int luaZ_fill (ZIO *z); - -#endif diff --git a/btgui/minizip/crypt.h b/btgui/minizip/crypt.h deleted file mode 100644 index acdf125b9..000000000 --- a/btgui/minizip/crypt.h +++ /dev/null @@ -1,133 +0,0 @@ -/* crypt.h -- base code for crypt/uncrypt ZIPfile - - - Version 1.01e, February 12th, 2005 - - Copyright (C) 1998-2005 Gilles Vollant - - This code is a modified version of crypting code in Infozip distribution - - The encryption/decryption parts of this source code (as opposed to the - non-echoing password parts) were originally written in Europe. The - whole source package can be freely distributed, including from the USA. - (Prior to January 2000, re-export from the US was a violation of US law.) - - This encryption code is a direct transcription of the algorithm from - Roger Schlafly, described by Phil Katz in the file appnote.txt. This - file (appnote.txt) is distributed with the PKZIP program (even in the - version without encryption capabilities). - - If you don't need crypting in your application, just define symbols - NOCRYPT and NOUNCRYPT. - - This code support the "Traditional PKWARE Encryption". - - The new AES encryption added on Zip format by Winzip (see the page - http://www.winzip.com/aes_info.htm ) and PKWare PKZip 5.x Strong - Encryption is not supported. -*/ -#define NOCRYPT -#define NOUNCRYPT - -#define CRC32(c, b) ((*(pcrc_32_tab+(((int)(c) ^ (b)) & 0xff))) ^ ((c) >> 8)) - -/*********************************************************************** - * Return the next byte in the pseudo-random sequence - */ -static int decrypt_byte(unsigned long* pkeys, const unsigned long* pcrc_32_tab) -{ - unsigned temp; /* POTENTIAL BUG: temp*(temp^1) may overflow in an - * unpredictable manner on 16-bit systems; not a problem - * with any known compiler so far, though */ - - temp = ((unsigned)(*(pkeys+2)) & 0xffff) | 2; - return (int)(((temp * (temp ^ 1)) >> 8) & 0xff); -} - -/*********************************************************************** - * Update the encryption keys with the next byte of plain text - */ -static int update_keys(unsigned long* pkeys,const unsigned long* pcrc_32_tab,int c) -{ - (*(pkeys+0)) = CRC32((*(pkeys+0)), c); - (*(pkeys+1)) += (*(pkeys+0)) & 0xff; - (*(pkeys+1)) = (*(pkeys+1)) * 134775813L + 1; - { - register int keyshift = (int)((*(pkeys+1)) >> 24); - (*(pkeys+2)) = CRC32((*(pkeys+2)), keyshift); - } - return c; -} - - -/*********************************************************************** - * Initialize the encryption keys and the random header according to - * the given password. - */ -static void init_keys(const char* passwd,unsigned long* pkeys,const unsigned long* pcrc_32_tab) -{ - *(pkeys+0) = 305419896L; - *(pkeys+1) = 591751049L; - *(pkeys+2) = 878082192L; - while (*passwd != '\0') { - update_keys(pkeys,pcrc_32_tab,(int)*passwd); - passwd++; - } -} - -#define zdecode(pkeys,pcrc_32_tab,c) \ - (update_keys(pkeys,pcrc_32_tab,c ^= decrypt_byte(pkeys,pcrc_32_tab))) - -#define zencode(pkeys,pcrc_32_tab,c,t) \ - (t=decrypt_byte(pkeys,pcrc_32_tab), update_keys(pkeys,pcrc_32_tab,c), t^(c)) - -#ifdef INCLUDECRYPTINGCODE_IFCRYPTALLOWED - -#define RAND_HEAD_LEN 12 - /* "last resort" source for second part of crypt seed pattern */ -# ifndef ZCR_SEED2 -# define ZCR_SEED2 3141592654UL /* use PI as default pattern */ -# endif - -static int crypthead(const char* passwd, /* password string */ - unsigned char* buf, /* where to write header */ - int bufSize, - unsigned long* pkeys, - const unsigned long* pcrc_32_tab, - unsigned long crcForCrypting) -{ - int n; /* index in random header */ - int t; /* temporary */ - int c; /* random byte */ - unsigned char header[RAND_HEAD_LEN-2]; /* random header */ - static unsigned calls = 0; /* ensure different random header each time */ - - if (bufSize> 7) & 0xff; - header[n] = (unsigned char)zencode(pkeys, pcrc_32_tab, c, t); - } - /* Encrypt random header (last two bytes is high word of crc) */ - init_keys(passwd, pkeys, pcrc_32_tab); - for (n = 0; n < RAND_HEAD_LEN-2; n++) - { - buf[n] = (unsigned char)zencode(pkeys, pcrc_32_tab, header[n], t); - } - buf[n++] = (unsigned char)zencode(pkeys, pcrc_32_tab, (int)(crcForCrypting >> 16) & 0xff, t); - buf[n++] = (unsigned char)zencode(pkeys, pcrc_32_tab, (int)(crcForCrypting >> 24) & 0xff, t); - return n; -} - -#endif diff --git a/btgui/minizip/ioapi.c b/btgui/minizip/ioapi.c deleted file mode 100644 index cdf203208..000000000 --- a/btgui/minizip/ioapi.c +++ /dev/null @@ -1,246 +0,0 @@ -/* ioapi.h -- IO base function header for compress/uncompress .zip - part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html ) - - Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html ) - - Modifications for Zip64 support - Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com ) - - For more info read MiniZip_info.txt - -*/ - -#if (defined(_WIN32)) - #define _CRT_SECURE_NO_WARNINGS -#endif - -#include "ioapi.h" - -voidpf call_zopen64 (const zlib_filefunc64_32_def* pfilefunc,const void*filename,int mode) -{ - if (pfilefunc->zfile_func64.zopen64_file != NULL) - return (*(pfilefunc->zfile_func64.zopen64_file)) (pfilefunc->zfile_func64.opaque,filename,mode); - else - { - return (*(pfilefunc->zopen32_file))(pfilefunc->zfile_func64.opaque,(const char*)filename,mode); - } -} - -long call_zseek64 (const zlib_filefunc64_32_def* pfilefunc,voidpf filestream, ZPOS64_T offset, int origin) -{ - if (pfilefunc->zfile_func64.zseek64_file != NULL) - return (*(pfilefunc->zfile_func64.zseek64_file)) (pfilefunc->zfile_func64.opaque,filestream,offset,origin); - else - { - uLong offsetTruncated = (uLong)offset; - if (offsetTruncated != offset) - return -1; - else - return (*(pfilefunc->zseek32_file))(pfilefunc->zfile_func64.opaque,filestream,offsetTruncated,origin); - } -} - -ZPOS64_T call_ztell64 (const zlib_filefunc64_32_def* pfilefunc,voidpf filestream) -{ - if (pfilefunc->zfile_func64.zseek64_file != NULL) - return (*(pfilefunc->zfile_func64.ztell64_file)) (pfilefunc->zfile_func64.opaque,filestream); - else - { - uLong tell_uLong = (*(pfilefunc->ztell32_file))(pfilefunc->zfile_func64.opaque,filestream); - if ((tell_uLong) == ((uLong)-1)) - return (ZPOS64_T)-1; - else - return tell_uLong; - } -} - -void fill_zlib_filefunc64_32_def_from_filefunc32(zlib_filefunc64_32_def* p_filefunc64_32,const zlib_filefunc_def* p_filefunc32) -{ - p_filefunc64_32->zfile_func64.zopen64_file = NULL; - p_filefunc64_32->zopen32_file = p_filefunc32->zopen_file; - p_filefunc64_32->zfile_func64.zerror_file = p_filefunc32->zerror_file; - p_filefunc64_32->zfile_func64.zread_file = p_filefunc32->zread_file; - p_filefunc64_32->zfile_func64.zwrite_file = p_filefunc32->zwrite_file; - p_filefunc64_32->zfile_func64.ztell64_file = NULL; - p_filefunc64_32->zfile_func64.zseek64_file = NULL; - p_filefunc64_32->zfile_func64.zclose_file = p_filefunc32->zclose_file; - p_filefunc64_32->zfile_func64.zerror_file = p_filefunc32->zerror_file; - p_filefunc64_32->zfile_func64.opaque = p_filefunc32->opaque; - p_filefunc64_32->zseek32_file = p_filefunc32->zseek_file; - p_filefunc64_32->ztell32_file = p_filefunc32->ztell_file; -} - - - -static voidpf ZCALLBACK fopen_file_func OF((voidpf opaque, const char* filename, int mode)); -static uLong ZCALLBACK fread_file_func OF((voidpf opaque, voidpf stream, void* buf, uLong size)); -static uLong ZCALLBACK fwrite_file_func OF((voidpf opaque, voidpf stream, const void* buf,uLong size)); -static ZPOS64_T ZCALLBACK ftell64_file_func OF((voidpf opaque, voidpf stream)); -static long ZCALLBACK fseek64_file_func OF((voidpf opaque, voidpf stream, ZPOS64_T offset, int origin)); -static int ZCALLBACK fclose_file_func OF((voidpf opaque, voidpf stream)); -static int ZCALLBACK ferror_file_func OF((voidpf opaque, voidpf stream)); - -static voidpf ZCALLBACK fopen_file_func (voidpf opaque, const char* filename, int mode) -{ - FILE* file = NULL; - const char* mode_fopen = NULL; - if ((mode & ZLIB_FILEFUNC_MODE_READWRITEFILTER)==ZLIB_FILEFUNC_MODE_READ) - mode_fopen = "rb"; - else - if (mode & ZLIB_FILEFUNC_MODE_EXISTING) - mode_fopen = "r+b"; - else - if (mode & ZLIB_FILEFUNC_MODE_CREATE) - mode_fopen = "wb"; - - if ((filename!=NULL) && (mode_fopen != NULL)) - file = fopen(filename, mode_fopen); - return file; -} - - -static voidpf ZCALLBACK fopen64_file_func (voidpf opaque, const void* filename, int mode) -{ - FILE* file = NULL; - const char* mode_fopen = NULL; - if ((mode & ZLIB_FILEFUNC_MODE_READWRITEFILTER)==ZLIB_FILEFUNC_MODE_READ) - mode_fopen = "rb"; - else - if (mode & ZLIB_FILEFUNC_MODE_EXISTING) - mode_fopen = "r+b"; - else - if (mode & ZLIB_FILEFUNC_MODE_CREATE) - mode_fopen = "wb"; - - if ((filename!=NULL) && (mode_fopen != NULL)) - // file = fopen64((const char*)filename, mode_fopen); - file = fopen((const char*)filename, mode_fopen); - - - return file; -} - - - -static uLong ZCALLBACK fread_file_func (voidpf opaque, voidpf stream, void* buf, uLong size) -{ - uLong ret; - ret = (uLong)fread(buf, 1, (size_t)size, (FILE *)stream); - return ret; -} - -static uLong ZCALLBACK fwrite_file_func (voidpf opaque, voidpf stream, const void* buf, uLong size) -{ - uLong ret; - ret = (uLong)fwrite(buf, 1, (size_t)size, (FILE *)stream); - return ret; -} - -static long ZCALLBACK ftell_file_func (voidpf opaque, voidpf stream) -{ - long ret; - ret = ftell((FILE *)stream); - return ret; -} - - -static ZPOS64_T ZCALLBACK ftell64_file_func (voidpf opaque, voidpf stream) -{ - ZPOS64_T ret; - ret = ftell((FILE *)stream); - - // ret = ftello64((FILE *)stream); - return ret; -} - -static long ZCALLBACK fseek_file_func (voidpf opaque, voidpf stream, uLong offset, int origin) -{ - int fseek_origin=0; - long ret; - switch (origin) - { - case ZLIB_FILEFUNC_SEEK_CUR : - fseek_origin = SEEK_CUR; - break; - case ZLIB_FILEFUNC_SEEK_END : - fseek_origin = SEEK_END; - break; - case ZLIB_FILEFUNC_SEEK_SET : - fseek_origin = SEEK_SET; - break; - default: return -1; - } - ret = 0; - if (fseek((FILE *)stream, offset, fseek_origin) != 0) - ret = -1; - return ret; -} - -static long ZCALLBACK fseek64_file_func (voidpf opaque, voidpf stream, ZPOS64_T offset, int origin) -{ - int fseek_origin=0; - long ret; - switch (origin) - { - case ZLIB_FILEFUNC_SEEK_CUR : - fseek_origin = SEEK_CUR; - break; - case ZLIB_FILEFUNC_SEEK_END : - fseek_origin = SEEK_END; - break; - case ZLIB_FILEFUNC_SEEK_SET : - fseek_origin = SEEK_SET; - break; - default: return -1; - } - ret = 0; - - if(fseek((FILE *)stream, offset, fseek_origin) != 0) - -// if(fseeko64((FILE *)stream, offset, fseek_origin) != 0) - ret = -1; - - return ret; -} - - -static int ZCALLBACK fclose_file_func (voidpf opaque, voidpf stream) -{ - int ret; - ret = fclose((FILE *)stream); - return ret; -} - -static int ZCALLBACK ferror_file_func (voidpf opaque, voidpf stream) -{ - int ret; - ret = ferror((FILE *)stream); - return ret; -} - -void fill_fopen_filefunc (pzlib_filefunc_def) - zlib_filefunc_def* pzlib_filefunc_def; -{ - pzlib_filefunc_def->zopen_file = fopen_file_func; - pzlib_filefunc_def->zread_file = fread_file_func; - pzlib_filefunc_def->zwrite_file = fwrite_file_func; - pzlib_filefunc_def->ztell_file = ftell_file_func; - pzlib_filefunc_def->zseek_file = fseek_file_func; - pzlib_filefunc_def->zclose_file = fclose_file_func; - pzlib_filefunc_def->zerror_file = ferror_file_func; - pzlib_filefunc_def->opaque = NULL; -} - - -void fill_fopen64_filefunc (zlib_filefunc64_def* pzlib_filefunc_def) -{ - pzlib_filefunc_def->zopen64_file = fopen64_file_func; - pzlib_filefunc_def->zread_file = fread_file_func; - pzlib_filefunc_def->zwrite_file = fwrite_file_func; - pzlib_filefunc_def->ztell64_file = ftell64_file_func; - pzlib_filefunc_def->zseek64_file = fseek64_file_func; - pzlib_filefunc_def->zclose_file = fclose_file_func; - pzlib_filefunc_def->zerror_file = ferror_file_func; - pzlib_filefunc_def->opaque = NULL; -} - diff --git a/btgui/minizip/ioapi.h b/btgui/minizip/ioapi.h deleted file mode 100644 index 6e98495eb..000000000 --- a/btgui/minizip/ioapi.h +++ /dev/null @@ -1,200 +0,0 @@ -/* ioapi.h -- IO base function header for compress/uncompress .zip - part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html ) - - Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html ) - - Modifications for Zip64 support - Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com ) - - For more info read MiniZip_info.txt - - Changes - - Oct-2009 - Defined ZPOS64_T to fpos_t on windows and u_int64_t on linux. (might need to find a better why for this) - Oct-2009 - Change to fseeko64, ftello64 and fopen64 so large files would work on linux. - More if/def section may be needed to support other platforms - Oct-2009 - Defined fxxxx64 calls to normal fopen/ftell/fseek so they would compile on windows. - (but you should use iowin32.c for windows instead) - -*/ - -#ifndef _ZLIBIOAPI64_H -#define _ZLIBIOAPI64_H - -#if (!defined(_WIN32)) && (!defined(WIN32)) - - // Linux needs this to support file operation on files larger then 4+GB - // But might need better if/def to select just the platforms that needs them. - - #ifndef __USE_FILE_OFFSET64 - #define __USE_FILE_OFFSET64 - #endif - #ifndef __USE_LARGEFILE64 - #define __USE_LARGEFILE64 - #endif - #ifndef _LARGEFILE64_SOURCE - #define _LARGEFILE64_SOURCE - #endif - #ifndef _FILE_OFFSET_BIT - #define _FILE_OFFSET_BIT 64 - #endif -#endif - -#include -#include -#include "../zlib/zlib.h" - -#if defined(USE_FILE32API) -#define fopen64 fopen -#define ftello64 ftell -#define fseeko64 fseek -#else -#ifdef _MSC_VER - #define fopen64 fopen - #if (_MSC_VER >= 1400) && (!(defined(NO_MSCVER_FILE64_FUNC))) - #define ftello64 _ftelli64 - #define fseeko64 _fseeki64 - #else // old MSC - #define ftello64 ftell - #define fseeko64 fseek - #endif -#endif -#endif - -/* -#ifndef ZPOS64_T - #ifdef _WIN32 - #define ZPOS64_T fpos_t - #else - #include - #define ZPOS64_T uint64_t - #endif -#endif -*/ - -#ifdef HAVE_MINIZIP64_CONF_H -#include "mz64conf.h" -#endif - -/* a type choosen by DEFINE */ -#ifdef HAVE_64BIT_INT_CUSTOM -typedef 64BIT_INT_CUSTOM_TYPE ZPOS64_T; -#else -#ifdef HAS_STDINT_H -#include "stdint.h" -typedef uint64_t ZPOS64_T; -#else - - -#if defined(_MSC_VER) || defined(__BORLANDC__) -typedef unsigned __int64 ZPOS64_T; -#else -typedef unsigned long long int ZPOS64_T; -#endif -#endif -#endif - - - -#ifdef __cplusplus -extern "C" { -#endif - - -#define ZLIB_FILEFUNC_SEEK_CUR (1) -#define ZLIB_FILEFUNC_SEEK_END (2) -#define ZLIB_FILEFUNC_SEEK_SET (0) - -#define ZLIB_FILEFUNC_MODE_READ (1) -#define ZLIB_FILEFUNC_MODE_WRITE (2) -#define ZLIB_FILEFUNC_MODE_READWRITEFILTER (3) - -#define ZLIB_FILEFUNC_MODE_EXISTING (4) -#define ZLIB_FILEFUNC_MODE_CREATE (8) - - -#ifndef ZCALLBACK - #if (defined(WIN32) || defined(_WIN32) || defined (WINDOWS) || defined (_WINDOWS)) && defined(CALLBACK) && defined (USEWINDOWS_CALLBACK) - #define ZCALLBACK CALLBACK - #else - #define ZCALLBACK - #endif -#endif - - - - -typedef voidpf (ZCALLBACK *open_file_func) OF((voidpf opaque, const char* filename, int mode)); -typedef uLong (ZCALLBACK *read_file_func) OF((voidpf opaque, voidpf stream, void* buf, uLong size)); -typedef uLong (ZCALLBACK *write_file_func) OF((voidpf opaque, voidpf stream, const void* buf, uLong size)); -typedef int (ZCALLBACK *close_file_func) OF((voidpf opaque, voidpf stream)); -typedef int (ZCALLBACK *testerror_file_func) OF((voidpf opaque, voidpf stream)); - -typedef long (ZCALLBACK *tell_file_func) OF((voidpf opaque, voidpf stream)); -typedef long (ZCALLBACK *seek_file_func) OF((voidpf opaque, voidpf stream, uLong offset, int origin)); - - -/* here is the "old" 32 bits structure structure */ -typedef struct zlib_filefunc_def_s -{ - open_file_func zopen_file; - read_file_func zread_file; - write_file_func zwrite_file; - tell_file_func ztell_file; - seek_file_func zseek_file; - close_file_func zclose_file; - testerror_file_func zerror_file; - voidpf opaque; -} zlib_filefunc_def; - -typedef ZPOS64_T (ZCALLBACK *tell64_file_func) OF((voidpf opaque, voidpf stream)); -typedef long (ZCALLBACK *seek64_file_func) OF((voidpf opaque, voidpf stream, ZPOS64_T offset, int origin)); -typedef voidpf (ZCALLBACK *open64_file_func) OF((voidpf opaque, const void* filename, int mode)); - -typedef struct zlib_filefunc64_def_s -{ - open64_file_func zopen64_file; - read_file_func zread_file; - write_file_func zwrite_file; - tell64_file_func ztell64_file; - seek64_file_func zseek64_file; - close_file_func zclose_file; - testerror_file_func zerror_file; - voidpf opaque; -} zlib_filefunc64_def; - -void fill_fopen64_filefunc OF((zlib_filefunc64_def* pzlib_filefunc_def)); -void fill_fopen_filefunc OF((zlib_filefunc_def* pzlib_filefunc_def)); - -/* now internal definition, only for zip.c and unzip.h */ -typedef struct zlib_filefunc64_32_def_s -{ - zlib_filefunc64_def zfile_func64; - open_file_func zopen32_file; - tell_file_func ztell32_file; - seek_file_func zseek32_file; -} zlib_filefunc64_32_def; - - -#define ZREAD64(filefunc,filestream,buf,size) ((*((filefunc).zfile_func64.zread_file)) ((filefunc).zfile_func64.opaque,filestream,buf,size)) -#define ZWRITE64(filefunc,filestream,buf,size) ((*((filefunc).zfile_func64.zwrite_file)) ((filefunc).zfile_func64.opaque,filestream,buf,size)) -//#define ZTELL64(filefunc,filestream) ((*((filefunc).ztell64_file)) ((filefunc).opaque,filestream)) -//#define ZSEEK64(filefunc,filestream,pos,mode) ((*((filefunc).zseek64_file)) ((filefunc).opaque,filestream,pos,mode)) -#define ZCLOSE64(filefunc,filestream) ((*((filefunc).zfile_func64.zclose_file)) ((filefunc).zfile_func64.opaque,filestream)) -#define ZERROR64(filefunc,filestream) ((*((filefunc).zfile_func64.zerror_file)) ((filefunc).zfile_func64.opaque,filestream)) - -voidpf call_zopen64 OF((const zlib_filefunc64_32_def* pfilefunc,const void*filename,int mode)); -long call_zseek64 OF((const zlib_filefunc64_32_def* pfilefunc,voidpf filestream, ZPOS64_T offset, int origin)); -ZPOS64_T call_ztell64 OF((const zlib_filefunc64_32_def* pfilefunc,voidpf filestream)); - -void fill_zlib_filefunc64_32_def_from_filefunc32(zlib_filefunc64_32_def* p_filefunc64_32,const zlib_filefunc_def* p_filefunc32); - -#define ZOPEN64(filefunc,filename,mode) (call_zopen64((&(filefunc)),(filename),(mode))) -#define ZTELL64(filefunc,filestream) (call_ztell64((&(filefunc)),(filestream))) -#define ZSEEK64(filefunc,filestream,pos,mode) (call_zseek64((&(filefunc)),(filestream),(pos),(mode))) - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/btgui/minizip/unzip.c b/btgui/minizip/unzip.c deleted file mode 100644 index 21878de0f..000000000 --- a/btgui/minizip/unzip.c +++ /dev/null @@ -1,2125 +0,0 @@ -/* unzip.c -- IO for uncompress .zip files using zlib - Version 1.1, February 14h, 2010 - part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html ) - - Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html ) - - Modifications of Unzip for Zip64 - Copyright (C) 2007-2008 Even Rouault - - Modifications for Zip64 support on both zip and unzip - Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com ) - - For more info read MiniZip_info.txt - - - ------------------------------------------------------------------------------------ - Decryption code comes from crypt.c by Info-ZIP but has been greatly reduced in terms of - compatibility with older software. The following is from the original crypt.c. - Code woven in by Terry Thorsen 1/2003. - - Copyright (c) 1990-2000 Info-ZIP. All rights reserved. - - See the accompanying file LICENSE, version 2000-Apr-09 or later - (the contents of which are also included in zip.h) for terms of use. - If, for some reason, all these files are missing, the Info-ZIP license - also may be found at: ftp://ftp.info-zip.org/pub/infozip/license.html - - crypt.c (full version) by Info-ZIP. Last revised: [see crypt.h] - - The encryption/decryption parts of this source code (as opposed to the - non-echoing password parts) were originally written in Europe. The - whole source package can be freely distributed, including from the USA. - (Prior to January 2000, re-export from the US was a violation of US law.) - - This encryption code is a direct transcription of the algorithm from - Roger Schlafly, described by Phil Katz in the file appnote.txt. This - file (appnote.txt) is distributed with the PKZIP program (even in the - version without encryption capabilities). - - ------------------------------------------------------------------------------------ - - Changes in unzip.c - - 2007-2008 - Even Rouault - Addition of cpl_unzGetCurrentFileZStreamPos - 2007-2008 - Even Rouault - Decoration of symbol names unz* -> cpl_unz* - 2007-2008 - Even Rouault - Remove old C style function prototypes - 2007-2008 - Even Rouault - Add unzip support for ZIP64 - - Copyright (C) 2007-2008 Even Rouault - - - Oct-2009 - Mathias Svensson - Removed cpl_* from symbol names (Even Rouault added them but since this is now moved to a new project (minizip64) I renamed them again). - Oct-2009 - Mathias Svensson - Fixed problem if uncompressed size was > 4G and compressed size was <4G - should only read the compressed/uncompressed size from the Zip64 format if - the size from normal header was 0xFFFFFFFF - Oct-2009 - Mathias Svensson - Applied some bug fixes from paches recived from Gilles Vollant - Oct-2009 - Mathias Svensson - Applied support to unzip files with compression mathod BZIP2 (bzip2 lib is required) - Patch created by Daniel Borca - - Jan-2010 - back to unzip and minizip 1.0 name scheme, with compatibility layer - - Copyright (C) 1998 - 2010 Gilles Vollant, Even Rouault, Mathias Svensson - -*/ - - -#include -#include -#include - -#ifndef NOUNCRYPT - #define NOUNCRYPT -#endif - -#include "../zlib/zlib.h" -#include "unzip.h" - -#ifdef STDC -# include -# include -# include -#endif -#ifdef NO_ERRNO_H - extern int errno; -#else -# include -#endif - - -#ifndef local -# define local static -#endif -/* compile with -Dlocal if your debugger can't find static symbols */ - - -#ifndef CASESENSITIVITYDEFAULT_NO -# if !defined(unix) && !defined(CASESENSITIVITYDEFAULT_YES) -# define CASESENSITIVITYDEFAULT_NO -# endif -#endif - - -#ifndef UNZ_BUFSIZE -#define UNZ_BUFSIZE (16384) -#endif - -#ifndef UNZ_MAXFILENAMEINZIP -#define UNZ_MAXFILENAMEINZIP (256) -#endif - -#ifndef ALLOC -# define ALLOC(size) (malloc(size)) -#endif -#ifndef TRYFREE -# define TRYFREE(p) {if (p) free(p);} -#endif - -#define SIZECENTRALDIRITEM (0x2e) -#define SIZEZIPLOCALHEADER (0x1e) - - -const char unz_copyright[] = - " unzip 1.01 Copyright 1998-2004 Gilles Vollant - http://www.winimage.com/zLibDll"; - -/* unz_file_info_interntal contain internal info about a file in zipfile*/ -typedef struct unz_file_info64_internal_s -{ - ZPOS64_T offset_curfile;/* relative offset of local header 8 bytes */ -} unz_file_info64_internal; - - -/* file_in_zip_read_info_s contain internal information about a file in zipfile, - when reading and decompress it */ -typedef struct -{ - char *read_buffer; /* internal buffer for compressed data */ - z_stream stream; /* zLib stream structure for inflate */ - -#ifdef HAVE_BZIP2 - bz_stream bstream; /* bzLib stream structure for bziped */ -#endif - - ZPOS64_T pos_in_zipfile; /* position in byte on the zipfile, for fseek*/ - uLong stream_initialised; /* flag set if stream structure is initialised*/ - - ZPOS64_T offset_local_extrafield;/* offset of the local extra field */ - uInt size_local_extrafield;/* size of the local extra field */ - ZPOS64_T pos_local_extrafield; /* position in the local extra field in read*/ - ZPOS64_T total_out_64; - - uLong crc32; /* crc32 of all data uncompressed */ - uLong crc32_wait; /* crc32 we must obtain after decompress all */ - ZPOS64_T rest_read_compressed; /* number of byte to be decompressed */ - ZPOS64_T rest_read_uncompressed;/*number of byte to be obtained after decomp*/ - zlib_filefunc64_32_def z_filefunc; - voidpf filestream; /* io structore of the zipfile */ - uLong compression_method; /* compression method (0==store) */ - ZPOS64_T byte_before_the_zipfile;/* byte before the zipfile, (>0 for sfx)*/ - int raw; -} file_in_zip64_read_info_s; - - -/* unz64_s contain internal information about the zipfile -*/ -typedef struct -{ - zlib_filefunc64_32_def z_filefunc; - int is64bitOpenFunction; - voidpf filestream; /* io structore of the zipfile */ - unz_global_info64 gi; /* public global information */ - ZPOS64_T byte_before_the_zipfile;/* byte before the zipfile, (>0 for sfx)*/ - ZPOS64_T num_file; /* number of the current file in the zipfile*/ - ZPOS64_T pos_in_central_dir; /* pos of the current file in the central dir*/ - ZPOS64_T current_file_ok; /* flag about the usability of the current file*/ - ZPOS64_T central_pos; /* position of the beginning of the central dir*/ - - ZPOS64_T size_central_dir; /* size of the central directory */ - ZPOS64_T offset_central_dir; /* offset of start of central directory with - respect to the starting disk number */ - - unz_file_info64 cur_file_info; /* public info about the current file in zip*/ - unz_file_info64_internal cur_file_info_internal; /* private info about it*/ - file_in_zip64_read_info_s* pfile_in_zip_read; /* structure about the current - file if we are decompressing it */ - int encrypted; - - int isZip64; - -# ifndef NOUNCRYPT - unsigned long keys[3]; /* keys defining the pseudo-random sequence */ - const unsigned long* pcrc_32_tab; -# endif -} unz64_s; - - -#ifndef NOUNCRYPT -#include "crypt.h" -#endif - -/* =========================================================================== - Read a byte from a gz_stream; update next_in and avail_in. Return EOF - for end of file. - IN assertion: the stream s has been sucessfully opened for reading. -*/ - - -local int unz64local_getByte OF(( - const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - int *pi)); - -local int unz64local_getByte(const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, int *pi) -{ - unsigned char c; - int err = (int)ZREAD64(*pzlib_filefunc_def,filestream,&c,1); - if (err==1) - { - *pi = (int)c; - return UNZ_OK; - } - else - { - if (ZERROR64(*pzlib_filefunc_def,filestream)) - return UNZ_ERRNO; - else - return UNZ_EOF; - } -} - - -/* =========================================================================== - Reads a long in LSB order from the given gz_stream. Sets -*/ -local int unz64local_getShort OF(( - const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - uLong *pX)); - -local int unz64local_getShort (const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - uLong *pX) -{ - uLong x ; - int i = 0; - int err; - - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x = (uLong)i; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((uLong)i)<<8; - - if (err==UNZ_OK) - *pX = x; - else - *pX = 0; - return err; -} - -local int unz64local_getLong OF(( - const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - uLong *pX)); - -local int unz64local_getLong (const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - uLong *pX) -{ - uLong x ; - int i = 0; - int err; - - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x = (uLong)i; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((uLong)i)<<8; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((uLong)i)<<16; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((uLong)i)<<24; - - if (err==UNZ_OK) - *pX = x; - else - *pX = 0; - return err; -} - -local int unz64local_getLong64 OF(( - const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - ZPOS64_T *pX)); - - -local int unz64local_getLong64 (const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream, - ZPOS64_T *pX) -{ - ZPOS64_T x ; - int i = 0; - int err; - - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x = (ZPOS64_T)i; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<8; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<16; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<24; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<32; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<40; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<48; - - if (err==UNZ_OK) - err = unz64local_getByte(pzlib_filefunc_def,filestream,&i); - x |= ((ZPOS64_T)i)<<56; - - if (err==UNZ_OK) - *pX = x; - else - *pX = 0; - return err; -} - -/* My own strcmpi / strcasecmp */ -local int strcmpcasenosensitive_internal (const char* fileName1, const char* fileName2) -{ - for (;;) - { - char c1=*(fileName1++); - char c2=*(fileName2++); - if ((c1>='a') && (c1<='z')) - c1 -= 0x20; - if ((c2>='a') && (c2<='z')) - c2 -= 0x20; - if (c1=='\0') - return ((c2=='\0') ? 0 : -1); - if (c2=='\0') - return 1; - if (c1c2) - return 1; - } -} - - -#ifdef CASESENSITIVITYDEFAULT_NO -#define CASESENSITIVITYDEFAULTVALUE 2 -#else -#define CASESENSITIVITYDEFAULTVALUE 1 -#endif - -#ifndef STRCMPCASENOSENTIVEFUNCTION -#define STRCMPCASENOSENTIVEFUNCTION strcmpcasenosensitive_internal -#endif - -/* - Compare two filename (fileName1,fileName2). - If iCaseSenisivity = 1, comparision is case sensitivity (like strcmp) - If iCaseSenisivity = 2, comparision is not case sensitivity (like strcmpi - or strcasecmp) - If iCaseSenisivity = 0, case sensitivity is defaut of your operating system - (like 1 on Unix, 2 on Windows) - -*/ -extern int ZEXPORT unzStringFileNameCompare (const char* fileName1, - const char* fileName2, - int iCaseSensitivity) - -{ - if (iCaseSensitivity==0) - iCaseSensitivity=CASESENSITIVITYDEFAULTVALUE; - - if (iCaseSensitivity==1) - return strcmp(fileName1,fileName2); - - return STRCMPCASENOSENTIVEFUNCTION(fileName1,fileName2); -} - -#ifndef BUFREADCOMMENT -#define BUFREADCOMMENT (0x400) -#endif - -/* - Locate the Central directory of a zipfile (at the end, just before - the global comment) -*/ -local ZPOS64_T unz64local_SearchCentralDir OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream)); -local ZPOS64_T unz64local_SearchCentralDir(const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream) -{ - unsigned char* buf; - ZPOS64_T uSizeFile; - ZPOS64_T uBackRead; - ZPOS64_T uMaxBack=0xffff; /* maximum size of global comment */ - ZPOS64_T uPosFound=0; - - if (ZSEEK64(*pzlib_filefunc_def,filestream,0,ZLIB_FILEFUNC_SEEK_END) != 0) - return 0; - - - uSizeFile = ZTELL64(*pzlib_filefunc_def,filestream); - - if (uMaxBack>uSizeFile) - uMaxBack = uSizeFile; - - buf = (unsigned char*)ALLOC(BUFREADCOMMENT+4); - if (buf==NULL) - return 0; - - uBackRead = 4; - while (uBackReaduMaxBack) - uBackRead = uMaxBack; - else - uBackRead+=BUFREADCOMMENT; - uReadPos = uSizeFile-uBackRead ; - - uReadSize = ((BUFREADCOMMENT+4) < (uSizeFile-uReadPos)) ? - (BUFREADCOMMENT+4) : (uLong)(uSizeFile-uReadPos); - if (ZSEEK64(*pzlib_filefunc_def,filestream,uReadPos,ZLIB_FILEFUNC_SEEK_SET)!=0) - break; - - if (ZREAD64(*pzlib_filefunc_def,filestream,buf,uReadSize)!=uReadSize) - break; - - for (i=(int)uReadSize-3; (i--)>0;) - if (((*(buf+i))==0x50) && ((*(buf+i+1))==0x4b) && - ((*(buf+i+2))==0x05) && ((*(buf+i+3))==0x06)) - { - uPosFound = uReadPos+i; - break; - } - - if (uPosFound!=0) - break; - } - TRYFREE(buf); - return uPosFound; -} - - -/* - Locate the Central directory 64 of a zipfile (at the end, just before - the global comment) -*/ -local ZPOS64_T unz64local_SearchCentralDir64 OF(( - const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream)); - -local ZPOS64_T unz64local_SearchCentralDir64(const zlib_filefunc64_32_def* pzlib_filefunc_def, - voidpf filestream) -{ - unsigned char* buf; - ZPOS64_T uSizeFile; - ZPOS64_T uBackRead; - ZPOS64_T uMaxBack=0xffff; /* maximum size of global comment */ - ZPOS64_T uPosFound=0; - uLong uL; - ZPOS64_T relativeOffset; - - if (ZSEEK64(*pzlib_filefunc_def,filestream,0,ZLIB_FILEFUNC_SEEK_END) != 0) - return 0; - - - uSizeFile = ZTELL64(*pzlib_filefunc_def,filestream); - - if (uMaxBack>uSizeFile) - uMaxBack = uSizeFile; - - buf = (unsigned char*)ALLOC(BUFREADCOMMENT+4); - if (buf==NULL) - return 0; - - uBackRead = 4; - while (uBackReaduMaxBack) - uBackRead = uMaxBack; - else - uBackRead+=BUFREADCOMMENT; - uReadPos = uSizeFile-uBackRead ; - - uReadSize = ((BUFREADCOMMENT+4) < (uSizeFile-uReadPos)) ? - (BUFREADCOMMENT+4) : (uLong)(uSizeFile-uReadPos); - if (ZSEEK64(*pzlib_filefunc_def,filestream,uReadPos,ZLIB_FILEFUNC_SEEK_SET)!=0) - break; - - if (ZREAD64(*pzlib_filefunc_def,filestream,buf,uReadSize)!=uReadSize) - break; - - for (i=(int)uReadSize-3; (i--)>0;) - if (((*(buf+i))==0x50) && ((*(buf+i+1))==0x4b) && - ((*(buf+i+2))==0x06) && ((*(buf+i+3))==0x07)) - { - uPosFound = uReadPos+i; - break; - } - - if (uPosFound!=0) - break; - } - TRYFREE(buf); - if (uPosFound == 0) - return 0; - - /* Zip64 end of central directory locator */ - if (ZSEEK64(*pzlib_filefunc_def,filestream, uPosFound,ZLIB_FILEFUNC_SEEK_SET)!=0) - return 0; - - /* the signature, already checked */ - if (unz64local_getLong(pzlib_filefunc_def,filestream,&uL)!=UNZ_OK) - return 0; - - /* number of the disk with the start of the zip64 end of central directory */ - if (unz64local_getLong(pzlib_filefunc_def,filestream,&uL)!=UNZ_OK) - return 0; - if (uL != 0) - return 0; - - /* relative offset of the zip64 end of central directory record */ - if (unz64local_getLong64(pzlib_filefunc_def,filestream,&relativeOffset)!=UNZ_OK) - return 0; - - /* total number of disks */ - if (unz64local_getLong(pzlib_filefunc_def,filestream,&uL)!=UNZ_OK) - return 0; - if (uL != 1) - return 0; - - /* Goto end of central directory record */ - if (ZSEEK64(*pzlib_filefunc_def,filestream, relativeOffset,ZLIB_FILEFUNC_SEEK_SET)!=0) - return 0; - - /* the signature */ - if (unz64local_getLong(pzlib_filefunc_def,filestream,&uL)!=UNZ_OK) - return 0; - - if (uL != 0x06064b50) - return 0; - - return relativeOffset; -} - -/* - Open a Zip file. path contain the full pathname (by example, - on a Windows NT computer "c:\\test\\zlib114.zip" or on an Unix computer - "zlib/zlib114.zip". - If the zipfile cannot be opened (file doesn't exist or in not valid), the - return value is NULL. - Else, the return value is a unzFile Handle, usable with other function - of this unzip package. -*/ -local unzFile unzOpenInternal (const void *path, - zlib_filefunc64_32_def* pzlib_filefunc64_32_def, - int is64bitOpenFunction) -{ - unz64_s us; - unz64_s *s; - ZPOS64_T central_pos; - uLong uL; - - uLong number_disk; /* number of the current dist, used for - spaning ZIP, unsupported, always 0*/ - uLong number_disk_with_CD; /* number the the disk with central dir, used - for spaning ZIP, unsupported, always 0*/ - ZPOS64_T number_entry_CD; /* total number of entries in - the central dir - (same than number_entry on nospan) */ - - int err=UNZ_OK; - - if (unz_copyright[0]!=' ') - return NULL; - - us.z_filefunc.zseek32_file = NULL; - us.z_filefunc.ztell32_file = NULL; - if (pzlib_filefunc64_32_def==NULL) - fill_fopen64_filefunc(&us.z_filefunc.zfile_func64); - else - us.z_filefunc = *pzlib_filefunc64_32_def; - us.is64bitOpenFunction = is64bitOpenFunction; - - - - us.filestream = ZOPEN64(us.z_filefunc, - path, - ZLIB_FILEFUNC_MODE_READ | - ZLIB_FILEFUNC_MODE_EXISTING); - if (us.filestream==NULL) - return NULL; - - central_pos = unz64local_SearchCentralDir64(&us.z_filefunc,us.filestream); - if (central_pos) - { - uLong uS; - ZPOS64_T uL64; - - us.isZip64 = 1; - - if (ZSEEK64(us.z_filefunc, us.filestream, - central_pos,ZLIB_FILEFUNC_SEEK_SET)!=0) - err=UNZ_ERRNO; - - /* the signature, already checked */ - if (unz64local_getLong(&us.z_filefunc, us.filestream,&uL)!=UNZ_OK) - err=UNZ_ERRNO; - - /* size of zip64 end of central directory record */ - if (unz64local_getLong64(&us.z_filefunc, us.filestream,&uL64)!=UNZ_OK) - err=UNZ_ERRNO; - - /* version made by */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&uS)!=UNZ_OK) - err=UNZ_ERRNO; - - /* version needed to extract */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&uS)!=UNZ_OK) - err=UNZ_ERRNO; - - /* number of this disk */ - if (unz64local_getLong(&us.z_filefunc, us.filestream,&number_disk)!=UNZ_OK) - err=UNZ_ERRNO; - - /* number of the disk with the start of the central directory */ - if (unz64local_getLong(&us.z_filefunc, us.filestream,&number_disk_with_CD)!=UNZ_OK) - err=UNZ_ERRNO; - - /* total number of entries in the central directory on this disk */ - if (unz64local_getLong64(&us.z_filefunc, us.filestream,&us.gi.number_entry)!=UNZ_OK) - err=UNZ_ERRNO; - - /* total number of entries in the central directory */ - if (unz64local_getLong64(&us.z_filefunc, us.filestream,&number_entry_CD)!=UNZ_OK) - err=UNZ_ERRNO; - - if ((number_entry_CD!=us.gi.number_entry) || - (number_disk_with_CD!=0) || - (number_disk!=0)) - err=UNZ_BADZIPFILE; - - /* size of the central directory */ - if (unz64local_getLong64(&us.z_filefunc, us.filestream,&us.size_central_dir)!=UNZ_OK) - err=UNZ_ERRNO; - - /* offset of start of central directory with respect to the - starting disk number */ - if (unz64local_getLong64(&us.z_filefunc, us.filestream,&us.offset_central_dir)!=UNZ_OK) - err=UNZ_ERRNO; - - us.gi.size_comment = 0; - } - else - { - central_pos = unz64local_SearchCentralDir(&us.z_filefunc,us.filestream); - if (central_pos==0) - err=UNZ_ERRNO; - - us.isZip64 = 0; - - if (ZSEEK64(us.z_filefunc, us.filestream, - central_pos,ZLIB_FILEFUNC_SEEK_SET)!=0) - err=UNZ_ERRNO; - - /* the signature, already checked */ - if (unz64local_getLong(&us.z_filefunc, us.filestream,&uL)!=UNZ_OK) - err=UNZ_ERRNO; - - /* number of this disk */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&number_disk)!=UNZ_OK) - err=UNZ_ERRNO; - - /* number of the disk with the start of the central directory */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&number_disk_with_CD)!=UNZ_OK) - err=UNZ_ERRNO; - - /* total number of entries in the central dir on this disk */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&uL)!=UNZ_OK) - err=UNZ_ERRNO; - us.gi.number_entry = uL; - - /* total number of entries in the central dir */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&uL)!=UNZ_OK) - err=UNZ_ERRNO; - number_entry_CD = uL; - - if ((number_entry_CD!=us.gi.number_entry) || - (number_disk_with_CD!=0) || - (number_disk!=0)) - err=UNZ_BADZIPFILE; - - /* size of the central directory */ - if (unz64local_getLong(&us.z_filefunc, us.filestream,&uL)!=UNZ_OK) - err=UNZ_ERRNO; - us.size_central_dir = uL; - - /* offset of start of central directory with respect to the - starting disk number */ - if (unz64local_getLong(&us.z_filefunc, us.filestream,&uL)!=UNZ_OK) - err=UNZ_ERRNO; - us.offset_central_dir = uL; - - /* zipfile comment length */ - if (unz64local_getShort(&us.z_filefunc, us.filestream,&us.gi.size_comment)!=UNZ_OK) - err=UNZ_ERRNO; - } - - if ((central_pospfile_in_zip_read!=NULL) - unzCloseCurrentFile(file); - - ZCLOSE64(s->z_filefunc, s->filestream); - TRYFREE(s); - return UNZ_OK; -} - - -/* - Write info about the ZipFile in the *pglobal_info structure. - No preparation of the structure is needed - return UNZ_OK if there is no problem. */ -extern int ZEXPORT unzGetGlobalInfo64 (unzFile file, unz_global_info64* pglobal_info) -{ - unz64_s* s; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - *pglobal_info=s->gi; - return UNZ_OK; -} - -extern int ZEXPORT unzGetGlobalInfo (unzFile file, unz_global_info* pglobal_info32) -{ - unz64_s* s; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - /* to do : check if number_entry is not truncated */ - pglobal_info32->number_entry = (uLong)s->gi.number_entry; - pglobal_info32->size_comment = s->gi.size_comment; - return UNZ_OK; -} -/* - Translate date/time from Dos format to tm_unz (readable more easilty) -*/ -local void unz64local_DosDateToTmuDate (ZPOS64_T ulDosDate, tm_unz* ptm) -{ - ZPOS64_T uDate; - uDate = (ZPOS64_T)(ulDosDate>>16); - ptm->tm_mday = (uInt)(uDate&0x1f) ; - ptm->tm_mon = (uInt)((((uDate)&0x1E0)/0x20)-1) ; - ptm->tm_year = (uInt)(((uDate&0x0FE00)/0x0200)+1980) ; - - ptm->tm_hour = (uInt) ((ulDosDate &0xF800)/0x800); - ptm->tm_min = (uInt) ((ulDosDate&0x7E0)/0x20) ; - ptm->tm_sec = (uInt) (2*(ulDosDate&0x1f)) ; -} - -/* - Get Info about the current file in the zipfile, with internal only info -*/ -local int unz64local_GetCurrentFileInfoInternal OF((unzFile file, - unz_file_info64 *pfile_info, - unz_file_info64_internal - *pfile_info_internal, - char *szFileName, - uLong fileNameBufferSize, - void *extraField, - uLong extraFieldBufferSize, - char *szComment, - uLong commentBufferSize)); - -local int unz64local_GetCurrentFileInfoInternal (unzFile file, - unz_file_info64 *pfile_info, - unz_file_info64_internal - *pfile_info_internal, - char *szFileName, - uLong fileNameBufferSize, - void *extraField, - uLong extraFieldBufferSize, - char *szComment, - uLong commentBufferSize) -{ - unz64_s* s; - unz_file_info64 file_info; - unz_file_info64_internal file_info_internal; - int err=UNZ_OK; - uLong uMagic; - long lSeek=0; - uLong uL; - - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - if (ZSEEK64(s->z_filefunc, s->filestream, - s->pos_in_central_dir+s->byte_before_the_zipfile, - ZLIB_FILEFUNC_SEEK_SET)!=0) - err=UNZ_ERRNO; - - - /* we check the magic */ - if (err==UNZ_OK) - { - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uMagic) != UNZ_OK) - err=UNZ_ERRNO; - else if (uMagic!=0x02014b50) - err=UNZ_BADZIPFILE; - } - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.version) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.version_needed) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.flag) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.compression_method) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&file_info.dosDate) != UNZ_OK) - err=UNZ_ERRNO; - - unz64local_DosDateToTmuDate(file_info.dosDate,&file_info.tmu_date); - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&file_info.crc) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uL) != UNZ_OK) - err=UNZ_ERRNO; - file_info.compressed_size = uL; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uL) != UNZ_OK) - err=UNZ_ERRNO; - file_info.uncompressed_size = uL; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.size_filename) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.size_file_extra) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.size_file_comment) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.disk_num_start) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&file_info.internal_fa) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&file_info.external_fa) != UNZ_OK) - err=UNZ_ERRNO; - - // relative offset of local header - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uL) != UNZ_OK) - err=UNZ_ERRNO; - file_info_internal.offset_curfile = uL; - - lSeek+=file_info.size_filename; - if ((err==UNZ_OK) && (szFileName!=NULL)) - { - uLong uSizeRead ; - if (file_info.size_filename0) && (fileNameBufferSize>0)) - if (ZREAD64(s->z_filefunc, s->filestream,szFileName,uSizeRead)!=uSizeRead) - err=UNZ_ERRNO; - lSeek -= uSizeRead; - } - - // Read extrafield - if ((err==UNZ_OK) && (extraField!=NULL)) - { - ZPOS64_T uSizeRead ; - if (file_info.size_file_extraz_filefunc, s->filestream,lSeek,ZLIB_FILEFUNC_SEEK_CUR)==0) - lSeek=0; - else - err=UNZ_ERRNO; - } - - if ((file_info.size_file_extra>0) && (extraFieldBufferSize>0)) - if (ZREAD64(s->z_filefunc, s->filestream,extraField,(uLong)uSizeRead)!=uSizeRead) - err=UNZ_ERRNO; - - lSeek += file_info.size_file_extra - (uLong)uSizeRead; - } - else - lSeek += file_info.size_file_extra; - - - if ((err==UNZ_OK) && (file_info.size_file_extra != 0)) - { - uLong acc = 0; - - // since lSeek now points to after the extra field we need to move back - lSeek -= file_info.size_file_extra; - - if (lSeek!=0) - { - if (ZSEEK64(s->z_filefunc, s->filestream,lSeek,ZLIB_FILEFUNC_SEEK_CUR)==0) - lSeek=0; - else - err=UNZ_ERRNO; - } - - while(acc < file_info.size_file_extra) - { - uLong headerId; - uLong dataSize; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&headerId) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&dataSize) != UNZ_OK) - err=UNZ_ERRNO; - - /* ZIP64 extra fields */ - if (headerId == 0x0001) - { - uLong uL; - - if(file_info.uncompressed_size == (ZPOS64_T)(unsigned long)-1) - { - if (unz64local_getLong64(&s->z_filefunc, s->filestream,&file_info.uncompressed_size) != UNZ_OK) - err=UNZ_ERRNO; - } - - if(file_info.compressed_size == (ZPOS64_T)(unsigned long)-1) - { - if (unz64local_getLong64(&s->z_filefunc, s->filestream,&file_info.compressed_size) != UNZ_OK) - err=UNZ_ERRNO; - } - - if(file_info_internal.offset_curfile == (ZPOS64_T)(unsigned long)-1) - { - /* Relative Header offset */ - if (unz64local_getLong64(&s->z_filefunc, s->filestream,&file_info_internal.offset_curfile) != UNZ_OK) - err=UNZ_ERRNO; - } - - if(file_info.disk_num_start == (unsigned long)-1) - { - /* Disk Start Number */ - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uL) != UNZ_OK) - err=UNZ_ERRNO; - } - - } - else - { - if (ZSEEK64(s->z_filefunc, s->filestream,dataSize,ZLIB_FILEFUNC_SEEK_CUR)!=0) - err=UNZ_ERRNO; - } - - acc += 2 + 2 + dataSize; - } - } - - if ((err==UNZ_OK) && (szComment!=NULL)) - { - uLong uSizeRead ; - if (file_info.size_file_commentz_filefunc, s->filestream,lSeek,ZLIB_FILEFUNC_SEEK_CUR)==0) - lSeek=0; - else - err=UNZ_ERRNO; - } - - if ((file_info.size_file_comment>0) && (commentBufferSize>0)) - if (ZREAD64(s->z_filefunc, s->filestream,szComment,uSizeRead)!=uSizeRead) - err=UNZ_ERRNO; - lSeek+=file_info.size_file_comment - uSizeRead; - } - else - lSeek+=file_info.size_file_comment; - - - if ((err==UNZ_OK) && (pfile_info!=NULL)) - *pfile_info=file_info; - - if ((err==UNZ_OK) && (pfile_info_internal!=NULL)) - *pfile_info_internal=file_info_internal; - - return err; -} - - - -/* - Write info about the ZipFile in the *pglobal_info structure. - No preparation of the structure is needed - return UNZ_OK if there is no problem. -*/ -extern int ZEXPORT unzGetCurrentFileInfo64 (unzFile file, - unz_file_info64 * pfile_info, - char * szFileName, uLong fileNameBufferSize, - void *extraField, uLong extraFieldBufferSize, - char* szComment, uLong commentBufferSize) -{ - return unz64local_GetCurrentFileInfoInternal(file,pfile_info,NULL, - szFileName,fileNameBufferSize, - extraField,extraFieldBufferSize, - szComment,commentBufferSize); -} - -extern int ZEXPORT unzGetCurrentFileInfo (unzFile file, - unz_file_info * pfile_info, - char * szFileName, uLong fileNameBufferSize, - void *extraField, uLong extraFieldBufferSize, - char* szComment, uLong commentBufferSize) -{ - int err; - unz_file_info64 file_info64; - err = unz64local_GetCurrentFileInfoInternal(file,&file_info64,NULL, - szFileName,fileNameBufferSize, - extraField,extraFieldBufferSize, - szComment,commentBufferSize); - if (err==UNZ_OK) - { - pfile_info->version = file_info64.version; - pfile_info->version_needed = file_info64.version_needed; - pfile_info->flag = file_info64.flag; - pfile_info->compression_method = file_info64.compression_method; - pfile_info->dosDate = file_info64.dosDate; - pfile_info->crc = file_info64.crc; - - pfile_info->size_filename = file_info64.size_filename; - pfile_info->size_file_extra = file_info64.size_file_extra; - pfile_info->size_file_comment = file_info64.size_file_comment; - - pfile_info->disk_num_start = file_info64.disk_num_start; - pfile_info->internal_fa = file_info64.internal_fa; - pfile_info->external_fa = file_info64.external_fa; - - pfile_info->tmu_date = file_info64.tmu_date, - - - pfile_info->compressed_size = (uLong)file_info64.compressed_size; - pfile_info->uncompressed_size = (uLong)file_info64.uncompressed_size; - - } - return err; -} -/* - Set the current file of the zipfile to the first file. - return UNZ_OK if there is no problem -*/ -extern int ZEXPORT unzGoToFirstFile (unzFile file) -{ - int err=UNZ_OK; - unz64_s* s; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - s->pos_in_central_dir=s->offset_central_dir; - s->num_file=0; - err=unz64local_GetCurrentFileInfoInternal(file,&s->cur_file_info, - &s->cur_file_info_internal, - NULL,0,NULL,0,NULL,0); - s->current_file_ok = (err == UNZ_OK); - return err; -} - -/* - Set the current file of the zipfile to the next file. - return UNZ_OK if there is no problem - return UNZ_END_OF_LIST_OF_FILE if the actual file was the latest. -*/ -extern int ZEXPORT unzGoToNextFile (unzFile file) -{ - unz64_s* s; - int err; - - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - if (!s->current_file_ok) - return UNZ_END_OF_LIST_OF_FILE; - if (s->gi.number_entry != 0xffff) /* 2^16 files overflow hack */ - if (s->num_file+1==s->gi.number_entry) - return UNZ_END_OF_LIST_OF_FILE; - - s->pos_in_central_dir += SIZECENTRALDIRITEM + s->cur_file_info.size_filename + - s->cur_file_info.size_file_extra + s->cur_file_info.size_file_comment ; - s->num_file++; - err = unz64local_GetCurrentFileInfoInternal(file,&s->cur_file_info, - &s->cur_file_info_internal, - NULL,0,NULL,0,NULL,0); - s->current_file_ok = (err == UNZ_OK); - return err; -} - - -/* - Try locate the file szFileName in the zipfile. - For the iCaseSensitivity signification, see unzipStringFileNameCompare - - return value : - UNZ_OK if the file is found. It becomes the current file. - UNZ_END_OF_LIST_OF_FILE if the file is not found -*/ -extern int ZEXPORT unzLocateFile (unzFile file, const char *szFileName, int iCaseSensitivity) -{ - unz64_s* s; - int err; - - /* We remember the 'current' position in the file so that we can jump - * back there if we fail. - */ - unz_file_info64 cur_file_infoSaved; - unz_file_info64_internal cur_file_info_internalSaved; - ZPOS64_T num_fileSaved; - ZPOS64_T pos_in_central_dirSaved; - - - if (file==NULL) - return UNZ_PARAMERROR; - - if (strlen(szFileName)>=UNZ_MAXFILENAMEINZIP) - return UNZ_PARAMERROR; - - s=(unz64_s*)file; - if (!s->current_file_ok) - return UNZ_END_OF_LIST_OF_FILE; - - /* Save the current state */ - num_fileSaved = s->num_file; - pos_in_central_dirSaved = s->pos_in_central_dir; - cur_file_infoSaved = s->cur_file_info; - cur_file_info_internalSaved = s->cur_file_info_internal; - - err = unzGoToFirstFile(file); - - while (err == UNZ_OK) - { - char szCurrentFileName[UNZ_MAXFILENAMEINZIP+1]; - err = unzGetCurrentFileInfo64(file,NULL, - szCurrentFileName,sizeof(szCurrentFileName)-1, - NULL,0,NULL,0); - if (err == UNZ_OK) - { - if (unzStringFileNameCompare(szCurrentFileName, - szFileName,iCaseSensitivity)==0) - return UNZ_OK; - err = unzGoToNextFile(file); - } - } - - /* We failed, so restore the state of the 'current file' to where we - * were. - */ - s->num_file = num_fileSaved ; - s->pos_in_central_dir = pos_in_central_dirSaved ; - s->cur_file_info = cur_file_infoSaved; - s->cur_file_info_internal = cur_file_info_internalSaved; - return err; -} - - -/* -/////////////////////////////////////////// -// Contributed by Ryan Haksi (mailto://cryogen@infoserve.net) -// I need random access -// -// Further optimization could be realized by adding an ability -// to cache the directory in memory. The goal being a single -// comprehensive file read to put the file I need in a memory. -*/ - -/* -typedef struct unz_file_pos_s -{ - ZPOS64_T pos_in_zip_directory; // offset in file - ZPOS64_T num_of_file; // # of file -} unz_file_pos; -*/ - -extern int ZEXPORT unzGetFilePos64(unzFile file, unz64_file_pos* file_pos) -{ - unz64_s* s; - - if (file==NULL || file_pos==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - if (!s->current_file_ok) - return UNZ_END_OF_LIST_OF_FILE; - - file_pos->pos_in_zip_directory = s->pos_in_central_dir; - file_pos->num_of_file = s->num_file; - - return UNZ_OK; -} - -extern int ZEXPORT unzGetFilePos( - unzFile file, - unz_file_pos* file_pos) -{ - unz64_file_pos file_pos64; - int err = unzGetFilePos64(file,&file_pos64); - if (err==UNZ_OK) - { - file_pos->pos_in_zip_directory = (uLong)file_pos64.pos_in_zip_directory; - file_pos->num_of_file = (uLong)file_pos64.num_of_file; - } - return err; -} - -extern int ZEXPORT unzGoToFilePos64(unzFile file, const unz64_file_pos* file_pos) -{ - unz64_s* s; - int err; - - if (file==NULL || file_pos==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - - /* jump to the right spot */ - s->pos_in_central_dir = file_pos->pos_in_zip_directory; - s->num_file = file_pos->num_of_file; - - /* set the current file */ - err = unz64local_GetCurrentFileInfoInternal(file,&s->cur_file_info, - &s->cur_file_info_internal, - NULL,0,NULL,0,NULL,0); - /* return results */ - s->current_file_ok = (err == UNZ_OK); - return err; -} - -extern int ZEXPORT unzGoToFilePos( - unzFile file, - unz_file_pos* file_pos) -{ - unz64_file_pos file_pos64; - if (file_pos == NULL) - return UNZ_PARAMERROR; - - file_pos64.pos_in_zip_directory = file_pos->pos_in_zip_directory; - file_pos64.num_of_file = file_pos->num_of_file; - return unzGoToFilePos64(file,&file_pos64); -} - -/* -// Unzip Helper Functions - should be here? -/////////////////////////////////////////// -*/ - -/* - Read the local header of the current zipfile - Check the coherency of the local header and info in the end of central - directory about this file - store in *piSizeVar the size of extra info in local header - (filename and size of extra field data) -*/ -local int unz64local_CheckCurrentFileCoherencyHeader (unz64_s* s, uInt* piSizeVar, - ZPOS64_T * poffset_local_extrafield, - uInt * psize_local_extrafield) -{ - uLong uMagic,uData,uFlags; - uLong size_filename; - uLong size_extra_field; - int err=UNZ_OK; - - *piSizeVar = 0; - *poffset_local_extrafield = 0; - *psize_local_extrafield = 0; - - if (ZSEEK64(s->z_filefunc, s->filestream,s->cur_file_info_internal.offset_curfile + - s->byte_before_the_zipfile,ZLIB_FILEFUNC_SEEK_SET)!=0) - return UNZ_ERRNO; - - - if (err==UNZ_OK) - { - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uMagic) != UNZ_OK) - err=UNZ_ERRNO; - else if (uMagic!=0x04034b50) - err=UNZ_BADZIPFILE; - } - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&uData) != UNZ_OK) - err=UNZ_ERRNO; -/* - else if ((err==UNZ_OK) && (uData!=s->cur_file_info.wVersion)) - err=UNZ_BADZIPFILE; -*/ - if (unz64local_getShort(&s->z_filefunc, s->filestream,&uFlags) != UNZ_OK) - err=UNZ_ERRNO; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&uData) != UNZ_OK) - err=UNZ_ERRNO; - else if ((err==UNZ_OK) && (uData!=s->cur_file_info.compression_method)) - err=UNZ_BADZIPFILE; - - if ((err==UNZ_OK) && (s->cur_file_info.compression_method!=0) && -/* #ifdef HAVE_BZIP2 */ - (s->cur_file_info.compression_method!=Z_BZIP2ED) && -/* #endif */ - (s->cur_file_info.compression_method!=Z_DEFLATED)) - err=UNZ_BADZIPFILE; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uData) != UNZ_OK) /* date/time */ - err=UNZ_ERRNO; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uData) != UNZ_OK) /* crc */ - err=UNZ_ERRNO; - else if ((err==UNZ_OK) && (uData!=s->cur_file_info.crc) && ((uFlags & 8)==0)) - err=UNZ_BADZIPFILE; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uData) != UNZ_OK) /* size compr */ - err=UNZ_ERRNO; - else if (uData != 0xFFFFFFFF && (err==UNZ_OK) && (uData!=s->cur_file_info.compressed_size) && ((uFlags & 8)==0)) - err=UNZ_BADZIPFILE; - - if (unz64local_getLong(&s->z_filefunc, s->filestream,&uData) != UNZ_OK) /* size uncompr */ - err=UNZ_ERRNO; - else if (uData != 0xFFFFFFFF && (err==UNZ_OK) && (uData!=s->cur_file_info.uncompressed_size) && ((uFlags & 8)==0)) - err=UNZ_BADZIPFILE; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&size_filename) != UNZ_OK) - err=UNZ_ERRNO; - else if ((err==UNZ_OK) && (size_filename!=s->cur_file_info.size_filename)) - err=UNZ_BADZIPFILE; - - *piSizeVar += (uInt)size_filename; - - if (unz64local_getShort(&s->z_filefunc, s->filestream,&size_extra_field) != UNZ_OK) - err=UNZ_ERRNO; - *poffset_local_extrafield= s->cur_file_info_internal.offset_curfile + - SIZEZIPLOCALHEADER + size_filename; - *psize_local_extrafield = (uInt)size_extra_field; - - *piSizeVar += (uInt)size_extra_field; - - return err; -} - -/* - Open for reading data the current file in the zipfile. - If there is no error and the file is opened, the return value is UNZ_OK. -*/ -extern int ZEXPORT unzOpenCurrentFile3 (unzFile file, int* method, - int* level, int raw, const char* password) -{ - int err=UNZ_OK; - uInt iSizeVar; - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - ZPOS64_T offset_local_extrafield; /* offset of the local extra field */ - uInt size_local_extrafield; /* size of the local extra field */ -# ifndef NOUNCRYPT - char source[12]; -# else - if (password != NULL) - return UNZ_PARAMERROR; -# endif - - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - if (!s->current_file_ok) - return UNZ_PARAMERROR; - - if (s->pfile_in_zip_read != NULL) - unzCloseCurrentFile(file); - - if (unz64local_CheckCurrentFileCoherencyHeader(s,&iSizeVar, &offset_local_extrafield,&size_local_extrafield)!=UNZ_OK) - return UNZ_BADZIPFILE; - - pfile_in_zip_read_info = (file_in_zip64_read_info_s*)ALLOC(sizeof(file_in_zip64_read_info_s)); - if (pfile_in_zip_read_info==NULL) - return UNZ_INTERNALERROR; - - pfile_in_zip_read_info->read_buffer=(char*)ALLOC(UNZ_BUFSIZE); - pfile_in_zip_read_info->offset_local_extrafield = offset_local_extrafield; - pfile_in_zip_read_info->size_local_extrafield = size_local_extrafield; - pfile_in_zip_read_info->pos_local_extrafield=0; - pfile_in_zip_read_info->raw=raw; - - if (pfile_in_zip_read_info->read_buffer==NULL) - { - TRYFREE(pfile_in_zip_read_info); - return UNZ_INTERNALERROR; - } - - pfile_in_zip_read_info->stream_initialised=0; - - if (method!=NULL) - *method = (int)s->cur_file_info.compression_method; - - if (level!=NULL) - { - *level = 6; - switch (s->cur_file_info.flag & 0x06) - { - case 6 : *level = 1; break; - case 4 : *level = 2; break; - case 2 : *level = 9; break; - } - } - - if ((s->cur_file_info.compression_method!=0) && -/* #ifdef HAVE_BZIP2 */ - (s->cur_file_info.compression_method!=Z_BZIP2ED) && -/* #endif */ - (s->cur_file_info.compression_method!=Z_DEFLATED)) - - err=UNZ_BADZIPFILE; - - pfile_in_zip_read_info->crc32_wait=s->cur_file_info.crc; - pfile_in_zip_read_info->crc32=0; - pfile_in_zip_read_info->total_out_64=0; - pfile_in_zip_read_info->compression_method = s->cur_file_info.compression_method; - pfile_in_zip_read_info->filestream=s->filestream; - pfile_in_zip_read_info->z_filefunc=s->z_filefunc; - pfile_in_zip_read_info->byte_before_the_zipfile=s->byte_before_the_zipfile; - - pfile_in_zip_read_info->stream.total_out = 0; - - if ((s->cur_file_info.compression_method==Z_BZIP2ED) && (!raw)) - { -#ifdef HAVE_BZIP2 - pfile_in_zip_read_info->bstream.bzalloc = (void *(*) (void *, int, int))0; - pfile_in_zip_read_info->bstream.bzfree = (free_func)0; - pfile_in_zip_read_info->bstream.opaque = (voidpf)0; - pfile_in_zip_read_info->bstream.state = (voidpf)0; - - pfile_in_zip_read_info->stream.zalloc = (alloc_func)0; - pfile_in_zip_read_info->stream.zfree = (free_func)0; - pfile_in_zip_read_info->stream.opaque = (voidpf)0; - pfile_in_zip_read_info->stream.next_in = (voidpf)0; - pfile_in_zip_read_info->stream.avail_in = 0; - - err=BZ2_bzDecompressInit(&pfile_in_zip_read_info->bstream, 0, 0); - if (err == Z_OK) - pfile_in_zip_read_info->stream_initialised=Z_BZIP2ED; - else - { - TRYFREE(pfile_in_zip_read_info); - return err; - } -#else - pfile_in_zip_read_info->raw=1; -#endif - } - else if ((s->cur_file_info.compression_method==Z_DEFLATED) && (!raw)) - { - pfile_in_zip_read_info->stream.zalloc = (alloc_func)0; - pfile_in_zip_read_info->stream.zfree = (free_func)0; - pfile_in_zip_read_info->stream.opaque = (voidpf)0; - pfile_in_zip_read_info->stream.next_in = 0; - pfile_in_zip_read_info->stream.avail_in = 0; - - err=inflateInit2(&pfile_in_zip_read_info->stream, -MAX_WBITS); - if (err == Z_OK) - pfile_in_zip_read_info->stream_initialised=Z_DEFLATED; - else - { - TRYFREE(pfile_in_zip_read_info); - return err; - } - /* windowBits is passed < 0 to tell that there is no zlib header. - * Note that in this case inflate *requires* an extra "dummy" byte - * after the compressed stream in order to complete decompression and - * return Z_STREAM_END. - * In unzip, i don't wait absolutely Z_STREAM_END because I known the - * size of both compressed and uncompressed data - */ - } - pfile_in_zip_read_info->rest_read_compressed = - s->cur_file_info.compressed_size ; - pfile_in_zip_read_info->rest_read_uncompressed = - s->cur_file_info.uncompressed_size ; - - - pfile_in_zip_read_info->pos_in_zipfile = - s->cur_file_info_internal.offset_curfile + SIZEZIPLOCALHEADER + - iSizeVar; - - pfile_in_zip_read_info->stream.avail_in = (uInt)0; - - s->pfile_in_zip_read = pfile_in_zip_read_info; - s->encrypted = 0; - -# ifndef NOUNCRYPT - if (password != NULL) - { - int i; - s->pcrc_32_tab = get_crc_table(); - init_keys(password,s->keys,s->pcrc_32_tab); - if (ZSEEK64(s->z_filefunc, s->filestream, - s->pfile_in_zip_read->pos_in_zipfile + - s->pfile_in_zip_read->byte_before_the_zipfile, - SEEK_SET)!=0) - return UNZ_INTERNALERROR; - if(ZREAD64(s->z_filefunc, s->filestream,source, 12)<12) - return UNZ_INTERNALERROR; - - for (i = 0; i<12; i++) - zdecode(s->keys,s->pcrc_32_tab,source[i]); - - s->pfile_in_zip_read->pos_in_zipfile+=12; - s->encrypted=1; - } -# endif - - - return UNZ_OK; -} - -extern int ZEXPORT unzOpenCurrentFile (unzFile file) -{ - return unzOpenCurrentFile3(file, NULL, NULL, 0, NULL); -} - -extern int ZEXPORT unzOpenCurrentFilePassword (unzFile file, const char* password) -{ - return unzOpenCurrentFile3(file, NULL, NULL, 0, password); -} - -extern int ZEXPORT unzOpenCurrentFile2 (unzFile file, int* method, int* level, int raw) -{ - return unzOpenCurrentFile3(file, method, level, raw, NULL); -} - -/** Addition for GDAL : START */ - -extern ZPOS64_T ZEXPORT unzGetCurrentFileZStreamPos64( unzFile file) -{ - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - s=(unz64_s*)file; - if (file==NULL) - return 0; //UNZ_PARAMERROR; - pfile_in_zip_read_info=s->pfile_in_zip_read; - if (pfile_in_zip_read_info==NULL) - return 0; //UNZ_PARAMERROR; - return pfile_in_zip_read_info->pos_in_zipfile + - pfile_in_zip_read_info->byte_before_the_zipfile; -} - -/** Addition for GDAL : END */ - -/* - Read bytes from the current file. - buf contain buffer where data must be copied - len the size of buf. - - return the number of byte copied if somes bytes are copied - return 0 if the end of file was reached - return <0 with error code if there is an error - (UNZ_ERRNO for IO error, or zLib error for uncompress error) -*/ -extern int ZEXPORT unzReadCurrentFile (unzFile file, voidp buf, unsigned len) -{ - int err=UNZ_OK; - uInt iRead = 0; - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - pfile_in_zip_read_info=s->pfile_in_zip_read; - - if (pfile_in_zip_read_info==NULL) - return UNZ_PARAMERROR; - - - if ((pfile_in_zip_read_info->read_buffer == NULL)) - return UNZ_END_OF_LIST_OF_FILE; - if (len==0) - return 0; - - pfile_in_zip_read_info->stream.next_out = (Bytef*)buf; - - pfile_in_zip_read_info->stream.avail_out = (uInt)len; - - if ((len>pfile_in_zip_read_info->rest_read_uncompressed) && - (!(pfile_in_zip_read_info->raw))) - pfile_in_zip_read_info->stream.avail_out = - (uInt)pfile_in_zip_read_info->rest_read_uncompressed; - - if ((len>pfile_in_zip_read_info->rest_read_compressed+ - pfile_in_zip_read_info->stream.avail_in) && - (pfile_in_zip_read_info->raw)) - pfile_in_zip_read_info->stream.avail_out = - (uInt)pfile_in_zip_read_info->rest_read_compressed+ - pfile_in_zip_read_info->stream.avail_in; - - while (pfile_in_zip_read_info->stream.avail_out>0) - { - if ((pfile_in_zip_read_info->stream.avail_in==0) && - (pfile_in_zip_read_info->rest_read_compressed>0)) - { - uInt uReadThis = UNZ_BUFSIZE; - if (pfile_in_zip_read_info->rest_read_compressedrest_read_compressed; - if (uReadThis == 0) - return UNZ_EOF; - if (ZSEEK64(pfile_in_zip_read_info->z_filefunc, - pfile_in_zip_read_info->filestream, - pfile_in_zip_read_info->pos_in_zipfile + - pfile_in_zip_read_info->byte_before_the_zipfile, - ZLIB_FILEFUNC_SEEK_SET)!=0) - return UNZ_ERRNO; - if (ZREAD64(pfile_in_zip_read_info->z_filefunc, - pfile_in_zip_read_info->filestream, - pfile_in_zip_read_info->read_buffer, - uReadThis)!=uReadThis) - return UNZ_ERRNO; - - -# ifndef NOUNCRYPT - if(s->encrypted) - { - uInt i; - for(i=0;iread_buffer[i] = - zdecode(s->keys,s->pcrc_32_tab, - pfile_in_zip_read_info->read_buffer[i]); - } -# endif - - - pfile_in_zip_read_info->pos_in_zipfile += uReadThis; - - pfile_in_zip_read_info->rest_read_compressed-=uReadThis; - - pfile_in_zip_read_info->stream.next_in = - (Bytef*)pfile_in_zip_read_info->read_buffer; - pfile_in_zip_read_info->stream.avail_in = (uInt)uReadThis; - } - - if ((pfile_in_zip_read_info->compression_method==0) || (pfile_in_zip_read_info->raw)) - { - uInt uDoCopy,i ; - - if ((pfile_in_zip_read_info->stream.avail_in == 0) && - (pfile_in_zip_read_info->rest_read_compressed == 0)) - return (iRead==0) ? UNZ_EOF : iRead; - - if (pfile_in_zip_read_info->stream.avail_out < - pfile_in_zip_read_info->stream.avail_in) - uDoCopy = pfile_in_zip_read_info->stream.avail_out ; - else - uDoCopy = pfile_in_zip_read_info->stream.avail_in ; - - for (i=0;istream.next_out+i) = - *(pfile_in_zip_read_info->stream.next_in+i); - - pfile_in_zip_read_info->total_out_64 = pfile_in_zip_read_info->total_out_64 + uDoCopy; - - pfile_in_zip_read_info->crc32 = crc32(pfile_in_zip_read_info->crc32, - pfile_in_zip_read_info->stream.next_out, - uDoCopy); - pfile_in_zip_read_info->rest_read_uncompressed-=uDoCopy; - pfile_in_zip_read_info->stream.avail_in -= uDoCopy; - pfile_in_zip_read_info->stream.avail_out -= uDoCopy; - pfile_in_zip_read_info->stream.next_out += uDoCopy; - pfile_in_zip_read_info->stream.next_in += uDoCopy; - pfile_in_zip_read_info->stream.total_out += uDoCopy; - iRead += uDoCopy; - } - else if (pfile_in_zip_read_info->compression_method==Z_BZIP2ED) - { -#ifdef HAVE_BZIP2 - uLong uTotalOutBefore,uTotalOutAfter; - const Bytef *bufBefore; - uLong uOutThis; - - pfile_in_zip_read_info->bstream.next_in = (char*)pfile_in_zip_read_info->stream.next_in; - pfile_in_zip_read_info->bstream.avail_in = pfile_in_zip_read_info->stream.avail_in; - pfile_in_zip_read_info->bstream.total_in_lo32 = pfile_in_zip_read_info->stream.total_in; - pfile_in_zip_read_info->bstream.total_in_hi32 = 0; - pfile_in_zip_read_info->bstream.next_out = (char*)pfile_in_zip_read_info->stream.next_out; - pfile_in_zip_read_info->bstream.avail_out = pfile_in_zip_read_info->stream.avail_out; - pfile_in_zip_read_info->bstream.total_out_lo32 = pfile_in_zip_read_info->stream.total_out; - pfile_in_zip_read_info->bstream.total_out_hi32 = 0; - - uTotalOutBefore = pfile_in_zip_read_info->bstream.total_out_lo32; - bufBefore = (const Bytef *)pfile_in_zip_read_info->bstream.next_out; - - err=BZ2_bzDecompress(&pfile_in_zip_read_info->bstream); - - uTotalOutAfter = pfile_in_zip_read_info->bstream.total_out_lo32; - uOutThis = uTotalOutAfter-uTotalOutBefore; - - pfile_in_zip_read_info->total_out_64 = pfile_in_zip_read_info->total_out_64 + uOutThis; - - pfile_in_zip_read_info->crc32 = crc32(pfile_in_zip_read_info->crc32,bufBefore, (uInt)(uOutThis)); - pfile_in_zip_read_info->rest_read_uncompressed -= uOutThis; - iRead += (uInt)(uTotalOutAfter - uTotalOutBefore); - - pfile_in_zip_read_info->stream.next_in = (Bytef*)pfile_in_zip_read_info->bstream.next_in; - pfile_in_zip_read_info->stream.avail_in = pfile_in_zip_read_info->bstream.avail_in; - pfile_in_zip_read_info->stream.total_in = pfile_in_zip_read_info->bstream.total_in_lo32; - pfile_in_zip_read_info->stream.next_out = (Bytef*)pfile_in_zip_read_info->bstream.next_out; - pfile_in_zip_read_info->stream.avail_out = pfile_in_zip_read_info->bstream.avail_out; - pfile_in_zip_read_info->stream.total_out = pfile_in_zip_read_info->bstream.total_out_lo32; - - if (err==BZ_STREAM_END) - return (iRead==0) ? UNZ_EOF : iRead; - if (err!=BZ_OK) - break; -#endif - } // end Z_BZIP2ED - else - { - ZPOS64_T uTotalOutBefore,uTotalOutAfter; - const Bytef *bufBefore; - ZPOS64_T uOutThis; - int flush=Z_SYNC_FLUSH; - - uTotalOutBefore = pfile_in_zip_read_info->stream.total_out; - bufBefore = pfile_in_zip_read_info->stream.next_out; - - /* - if ((pfile_in_zip_read_info->rest_read_uncompressed == - pfile_in_zip_read_info->stream.avail_out) && - (pfile_in_zip_read_info->rest_read_compressed == 0)) - flush = Z_FINISH; - */ - err=inflate(&pfile_in_zip_read_info->stream,flush); - - if ((err>=0) && (pfile_in_zip_read_info->stream.msg!=NULL)) - err = Z_DATA_ERROR; - - uTotalOutAfter = pfile_in_zip_read_info->stream.total_out; - uOutThis = uTotalOutAfter-uTotalOutBefore; - - pfile_in_zip_read_info->total_out_64 = pfile_in_zip_read_info->total_out_64 + uOutThis; - - pfile_in_zip_read_info->crc32 = - crc32(pfile_in_zip_read_info->crc32,bufBefore, - (uInt)(uOutThis)); - - pfile_in_zip_read_info->rest_read_uncompressed -= - uOutThis; - - iRead += (uInt)(uTotalOutAfter - uTotalOutBefore); - - if (err==Z_STREAM_END) - return (iRead==0) ? UNZ_EOF : iRead; - if (err!=Z_OK) - break; - } - } - - if (err==Z_OK) - return iRead; - return err; -} - - -/* - Give the current position in uncompressed data -*/ -extern z_off_t ZEXPORT unztell (unzFile file) -{ - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - pfile_in_zip_read_info=s->pfile_in_zip_read; - - if (pfile_in_zip_read_info==NULL) - return UNZ_PARAMERROR; - - return (z_off_t)pfile_in_zip_read_info->stream.total_out; -} - -extern ZPOS64_T ZEXPORT unztell64 (unzFile file) -{ - - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - if (file==NULL) - return (ZPOS64_T)-1; - s=(unz64_s*)file; - pfile_in_zip_read_info=s->pfile_in_zip_read; - - if (pfile_in_zip_read_info==NULL) - return (ZPOS64_T)-1; - - return pfile_in_zip_read_info->total_out_64; -} - - -/* - return 1 if the end of file was reached, 0 elsewhere -*/ -extern int ZEXPORT unzeof (unzFile file) -{ - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - pfile_in_zip_read_info=s->pfile_in_zip_read; - - if (pfile_in_zip_read_info==NULL) - return UNZ_PARAMERROR; - - if (pfile_in_zip_read_info->rest_read_uncompressed == 0) - return 1; - else - return 0; -} - - - -/* -Read extra field from the current file (opened by unzOpenCurrentFile) -This is the local-header version of the extra field (sometimes, there is -more info in the local-header version than in the central-header) - - if buf==NULL, it return the size of the local extra field that can be read - - if buf!=NULL, len is the size of the buffer, the extra header is copied in - buf. - the return value is the number of bytes copied in buf, or (if <0) - the error code -*/ -extern int ZEXPORT unzGetLocalExtrafield (unzFile file, voidp buf, unsigned len) -{ - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - uInt read_now; - ZPOS64_T size_to_read; - - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - pfile_in_zip_read_info=s->pfile_in_zip_read; - - if (pfile_in_zip_read_info==NULL) - return UNZ_PARAMERROR; - - size_to_read = (pfile_in_zip_read_info->size_local_extrafield - - pfile_in_zip_read_info->pos_local_extrafield); - - if (buf==NULL) - return (int)size_to_read; - - if (len>size_to_read) - read_now = (uInt)size_to_read; - else - read_now = (uInt)len ; - - if (read_now==0) - return 0; - - if (ZSEEK64(pfile_in_zip_read_info->z_filefunc, - pfile_in_zip_read_info->filestream, - pfile_in_zip_read_info->offset_local_extrafield + - pfile_in_zip_read_info->pos_local_extrafield, - ZLIB_FILEFUNC_SEEK_SET)!=0) - return UNZ_ERRNO; - - if (ZREAD64(pfile_in_zip_read_info->z_filefunc, - pfile_in_zip_read_info->filestream, - buf,read_now)!=read_now) - return UNZ_ERRNO; - - return (int)read_now; -} - -/* - Close the file in zip opened with unzipOpenCurrentFile - Return UNZ_CRCERROR if all the file was read but the CRC is not good -*/ -extern int ZEXPORT unzCloseCurrentFile (unzFile file) -{ - int err=UNZ_OK; - - unz64_s* s; - file_in_zip64_read_info_s* pfile_in_zip_read_info; - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - pfile_in_zip_read_info=s->pfile_in_zip_read; - - if (pfile_in_zip_read_info==NULL) - return UNZ_PARAMERROR; - - - if ((pfile_in_zip_read_info->rest_read_uncompressed == 0) && - (!pfile_in_zip_read_info->raw)) - { - if (pfile_in_zip_read_info->crc32 != pfile_in_zip_read_info->crc32_wait) - err=UNZ_CRCERROR; - } - - - TRYFREE(pfile_in_zip_read_info->read_buffer); - pfile_in_zip_read_info->read_buffer = NULL; - if (pfile_in_zip_read_info->stream_initialised == Z_DEFLATED) - inflateEnd(&pfile_in_zip_read_info->stream); -#ifdef HAVE_BZIP2 - else if (pfile_in_zip_read_info->stream_initialised == Z_BZIP2ED) - BZ2_bzDecompressEnd(&pfile_in_zip_read_info->bstream); -#endif - - - pfile_in_zip_read_info->stream_initialised = 0; - TRYFREE(pfile_in_zip_read_info); - - s->pfile_in_zip_read=NULL; - - return err; -} - - -/* - Get the global comment string of the ZipFile, in the szComment buffer. - uSizeBuf is the size of the szComment buffer. - return the number of byte copied or an error code <0 -*/ -extern int ZEXPORT unzGetGlobalComment (unzFile file, char * szComment, uLong uSizeBuf) -{ - unz64_s* s; - uLong uReadThis ; - if (file==NULL) - return (int)UNZ_PARAMERROR; - s=(unz64_s*)file; - - uReadThis = uSizeBuf; - if (uReadThis>s->gi.size_comment) - uReadThis = s->gi.size_comment; - - if (ZSEEK64(s->z_filefunc,s->filestream,s->central_pos+22,ZLIB_FILEFUNC_SEEK_SET)!=0) - return UNZ_ERRNO; - - if (uReadThis>0) - { - *szComment='\0'; - if (ZREAD64(s->z_filefunc,s->filestream,szComment,uReadThis)!=uReadThis) - return UNZ_ERRNO; - } - - if ((szComment != NULL) && (uSizeBuf > s->gi.size_comment)) - *(szComment+s->gi.size_comment)='\0'; - return (int)uReadThis; -} - -/* Additions by RX '2004 */ -extern ZPOS64_T ZEXPORT unzGetOffset64(unzFile file) -{ - unz64_s* s; - - if (file==NULL) - return 0; //UNZ_PARAMERROR; - s=(unz64_s*)file; - if (!s->current_file_ok) - return 0; - if (s->gi.number_entry != 0 && s->gi.number_entry != 0xffff) - if (s->num_file==s->gi.number_entry) - return 0; - return s->pos_in_central_dir; -} - -extern uLong ZEXPORT unzGetOffset (unzFile file) -{ - ZPOS64_T offset64; - - if (file==NULL) - return 0; //UNZ_PARAMERROR; - offset64 = unzGetOffset64(file); - return (uLong)offset64; -} - -extern int ZEXPORT unzSetOffset64(unzFile file, ZPOS64_T pos) -{ - unz64_s* s; - int err; - - if (file==NULL) - return UNZ_PARAMERROR; - s=(unz64_s*)file; - - s->pos_in_central_dir = pos; - s->num_file = s->gi.number_entry; /* hack */ - err = unz64local_GetCurrentFileInfoInternal(file,&s->cur_file_info, - &s->cur_file_info_internal, - NULL,0,NULL,0,NULL,0); - s->current_file_ok = (err == UNZ_OK); - return err; -} - -extern int ZEXPORT unzSetOffset (unzFile file, uLong pos) -{ - return unzSetOffset64(file,pos); -} diff --git a/btgui/minizip/unzip.h b/btgui/minizip/unzip.h deleted file mode 100644 index 910dda07a..000000000 --- a/btgui/minizip/unzip.h +++ /dev/null @@ -1,437 +0,0 @@ -/* unzip.h -- IO for uncompress .zip files using zlib - Version 1.1, February 14h, 2010 - part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html ) - - Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html ) - - Modifications of Unzip for Zip64 - Copyright (C) 2007-2008 Even Rouault - - Modifications for Zip64 support on both zip and unzip - Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com ) - - For more info read MiniZip_info.txt - - --------------------------------------------------------------------------------- - - Condition of use and distribution are the same than zlib : - - This software is provided 'as-is', without any express or implied - warranty. In no event will the authors be held liable for any damages - arising from the use of this software. - - Permission is granted to anyone to use this software for any purpose, - including commercial applications, and to alter it and redistribute it - freely, subject to the following restrictions: - - 1. The origin of this software must not be misrepresented; you must not - claim that you wrote the original software. If you use this software - in a product, an acknowledgment in the product documentation would be - appreciated but is not required. - 2. Altered source versions must be plainly marked as such, and must not be - misrepresented as being the original software. - 3. This notice may not be removed or altered from any source distribution. - - --------------------------------------------------------------------------------- - - Changes - - See header of unzip64.c - -*/ - -#ifndef _unz64_H -#define _unz64_H - -#ifdef __cplusplus -extern "C" { -#endif - -#ifndef _ZLIB_H -#include "../zlib/zlib.h" -#endif - -#ifndef _ZLIBIOAPI_H -#include "ioapi.h" -#endif - -#ifdef HAVE_BZIP2 -#include "bzlib.h" -#endif - -#define Z_BZIP2ED 12 - -#if defined(STRICTUNZIP) || defined(STRICTZIPUNZIP) -/* like the STRICT of WIN32, we define a pointer that cannot be converted - from (void*) without cast */ -typedef struct TagunzFile__ { int unused; } unzFile__; -typedef unzFile__ *unzFile; -#else -typedef voidp unzFile; -#endif - - -#define UNZ_OK (0) -#define UNZ_END_OF_LIST_OF_FILE (-100) -#define UNZ_ERRNO (Z_ERRNO) -#define UNZ_EOF (0) -#define UNZ_PARAMERROR (-102) -#define UNZ_BADZIPFILE (-103) -#define UNZ_INTERNALERROR (-104) -#define UNZ_CRCERROR (-105) - -/* tm_unz contain date/time info */ -typedef struct tm_unz_s -{ - uInt tm_sec; /* seconds after the minute - [0,59] */ - uInt tm_min; /* minutes after the hour - [0,59] */ - uInt tm_hour; /* hours since midnight - [0,23] */ - uInt tm_mday; /* day of the month - [1,31] */ - uInt tm_mon; /* months since January - [0,11] */ - uInt tm_year; /* years - [1980..2044] */ -} tm_unz; - -/* unz_global_info structure contain global data about the ZIPfile - These data comes from the end of central dir */ -typedef struct unz_global_info64_s -{ - ZPOS64_T number_entry; /* total number of entries in - the central dir on this disk */ - uLong size_comment; /* size of the global comment of the zipfile */ -} unz_global_info64; - -typedef struct unz_global_info_s -{ - uLong number_entry; /* total number of entries in - the central dir on this disk */ - uLong size_comment; /* size of the global comment of the zipfile */ -} unz_global_info; - -/* unz_file_info contain information about a file in the zipfile */ -typedef struct unz_file_info64_s -{ - uLong version; /* version made by 2 bytes */ - uLong version_needed; /* version needed to extract 2 bytes */ - uLong flag; /* general purpose bit flag 2 bytes */ - uLong compression_method; /* compression method 2 bytes */ - uLong dosDate; /* last mod file date in Dos fmt 4 bytes */ - uLong crc; /* crc-32 4 bytes */ - ZPOS64_T compressed_size; /* compressed size 8 bytes */ - ZPOS64_T uncompressed_size; /* uncompressed size 8 bytes */ - uLong size_filename; /* filename length 2 bytes */ - uLong size_file_extra; /* extra field length 2 bytes */ - uLong size_file_comment; /* file comment length 2 bytes */ - - uLong disk_num_start; /* disk number start 2 bytes */ - uLong internal_fa; /* internal file attributes 2 bytes */ - uLong external_fa; /* external file attributes 4 bytes */ - - tm_unz tmu_date; -} unz_file_info64; - -typedef struct unz_file_info_s -{ - uLong version; /* version made by 2 bytes */ - uLong version_needed; /* version needed to extract 2 bytes */ - uLong flag; /* general purpose bit flag 2 bytes */ - uLong compression_method; /* compression method 2 bytes */ - uLong dosDate; /* last mod file date in Dos fmt 4 bytes */ - uLong crc; /* crc-32 4 bytes */ - uLong compressed_size; /* compressed size 4 bytes */ - uLong uncompressed_size; /* uncompressed size 4 bytes */ - uLong size_filename; /* filename length 2 bytes */ - uLong size_file_extra; /* extra field length 2 bytes */ - uLong size_file_comment; /* file comment length 2 bytes */ - - uLong disk_num_start; /* disk number start 2 bytes */ - uLong internal_fa; /* internal file attributes 2 bytes */ - uLong external_fa; /* external file attributes 4 bytes */ - - tm_unz tmu_date; -} unz_file_info; - -extern int ZEXPORT unzStringFileNameCompare OF ((const char* fileName1, - const char* fileName2, - int iCaseSensitivity)); -/* - Compare two filename (fileName1,fileName2). - If iCaseSenisivity = 1, comparision is case sensitivity (like strcmp) - If iCaseSenisivity = 2, comparision is not case sensitivity (like strcmpi - or strcasecmp) - If iCaseSenisivity = 0, case sensitivity is defaut of your operating system - (like 1 on Unix, 2 on Windows) -*/ - - -extern unzFile ZEXPORT unzOpen OF((const char *path)); -extern unzFile ZEXPORT unzOpen64 OF((const void *path)); -/* - Open a Zip file. path contain the full pathname (by example, - on a Windows XP computer "c:\\zlib\\zlib113.zip" or on an Unix computer - "zlib/zlib113.zip". - If the zipfile cannot be opened (file don't exist or in not valid), the - return value is NULL. - Else, the return value is a unzFile Handle, usable with other function - of this unzip package. - the "64" function take a const void* pointer, because the path is just the - value passed to the open64_file_func callback. - Under Windows, if UNICODE is defined, using fill_fopen64_filefunc, the path - is a pointer to a wide unicode string (LPCTSTR is LPCWSTR), so const char* - does not describe the reality -*/ - - -extern unzFile ZEXPORT unzOpen2 OF((const char *path, - zlib_filefunc_def* pzlib_filefunc_def)); -/* - Open a Zip file, like unzOpen, but provide a set of file low level API - for read/write the zip file (see ioapi.h) -*/ - -extern unzFile ZEXPORT unzOpen2_64 OF((const void *path, - zlib_filefunc64_def* pzlib_filefunc_def)); -/* - Open a Zip file, like unz64Open, but provide a set of file low level API - for read/write the zip file (see ioapi.h) -*/ - -extern int ZEXPORT unzClose OF((unzFile file)); -/* - Close a ZipFile opened with unzipOpen. - If there is files inside the .Zip opened with unzOpenCurrentFile (see later), - these files MUST be closed with unzipCloseCurrentFile before call unzipClose. - return UNZ_OK if there is no problem. */ - -extern int ZEXPORT unzGetGlobalInfo OF((unzFile file, - unz_global_info *pglobal_info)); - -extern int ZEXPORT unzGetGlobalInfo64 OF((unzFile file, - unz_global_info64 *pglobal_info)); -/* - Write info about the ZipFile in the *pglobal_info structure. - No preparation of the structure is needed - return UNZ_OK if there is no problem. */ - - -extern int ZEXPORT unzGetGlobalComment OF((unzFile file, - char *szComment, - uLong uSizeBuf)); -/* - Get the global comment string of the ZipFile, in the szComment buffer. - uSizeBuf is the size of the szComment buffer. - return the number of byte copied or an error code <0 -*/ - - -/***************************************************************************/ -/* Unzip package allow you browse the directory of the zipfile */ - -extern int ZEXPORT unzGoToFirstFile OF((unzFile file)); -/* - Set the current file of the zipfile to the first file. - return UNZ_OK if there is no problem -*/ - -extern int ZEXPORT unzGoToNextFile OF((unzFile file)); -/* - Set the current file of the zipfile to the next file. - return UNZ_OK if there is no problem - return UNZ_END_OF_LIST_OF_FILE if the actual file was the latest. -*/ - -extern int ZEXPORT unzLocateFile OF((unzFile file, - const char *szFileName, - int iCaseSensitivity)); -/* - Try locate the file szFileName in the zipfile. - For the iCaseSensitivity signification, see unzStringFileNameCompare - - return value : - UNZ_OK if the file is found. It becomes the current file. - UNZ_END_OF_LIST_OF_FILE if the file is not found -*/ - - -/* ****************************************** */ -/* Ryan supplied functions */ -/* unz_file_info contain information about a file in the zipfile */ -typedef struct unz_file_pos_s -{ - uLong pos_in_zip_directory; /* offset in zip file directory */ - uLong num_of_file; /* # of file */ -} unz_file_pos; - -extern int ZEXPORT unzGetFilePos( - unzFile file, - unz_file_pos* file_pos); - -extern int ZEXPORT unzGoToFilePos( - unzFile file, - unz_file_pos* file_pos); - -typedef struct unz64_file_pos_s -{ - ZPOS64_T pos_in_zip_directory; /* offset in zip file directory */ - ZPOS64_T num_of_file; /* # of file */ -} unz64_file_pos; - -extern int ZEXPORT unzGetFilePos64( - unzFile file, - unz64_file_pos* file_pos); - -extern int ZEXPORT unzGoToFilePos64( - unzFile file, - const unz64_file_pos* file_pos); - -/* ****************************************** */ - -extern int ZEXPORT unzGetCurrentFileInfo64 OF((unzFile file, - unz_file_info64 *pfile_info, - char *szFileName, - uLong fileNameBufferSize, - void *extraField, - uLong extraFieldBufferSize, - char *szComment, - uLong commentBufferSize)); - -extern int ZEXPORT unzGetCurrentFileInfo OF((unzFile file, - unz_file_info *pfile_info, - char *szFileName, - uLong fileNameBufferSize, - void *extraField, - uLong extraFieldBufferSize, - char *szComment, - uLong commentBufferSize)); -/* - Get Info about the current file - if pfile_info!=NULL, the *pfile_info structure will contain somes info about - the current file - if szFileName!=NULL, the filemane string will be copied in szFileName - (fileNameBufferSize is the size of the buffer) - if extraField!=NULL, the extra field information will be copied in extraField - (extraFieldBufferSize is the size of the buffer). - This is the Central-header version of the extra field - if szComment!=NULL, the comment string of the file will be copied in szComment - (commentBufferSize is the size of the buffer) -*/ - - -/** Addition for GDAL : START */ - -extern ZPOS64_T ZEXPORT unzGetCurrentFileZStreamPos64 OF((unzFile file)); - -/** Addition for GDAL : END */ - - -/***************************************************************************/ -/* for reading the content of the current zipfile, you can open it, read data - from it, and close it (you can close it before reading all the file) - */ - -extern int ZEXPORT unzOpenCurrentFile OF((unzFile file)); -/* - Open for reading data the current file in the zipfile. - If there is no error, the return value is UNZ_OK. -*/ - -extern int ZEXPORT unzOpenCurrentFilePassword OF((unzFile file, - const char* password)); -/* - Open for reading data the current file in the zipfile. - password is a crypting password - If there is no error, the return value is UNZ_OK. -*/ - -extern int ZEXPORT unzOpenCurrentFile2 OF((unzFile file, - int* method, - int* level, - int raw)); -/* - Same than unzOpenCurrentFile, but open for read raw the file (not uncompress) - if raw==1 - *method will receive method of compression, *level will receive level of - compression - note : you can set level parameter as NULL (if you did not want known level, - but you CANNOT set method parameter as NULL -*/ - -extern int ZEXPORT unzOpenCurrentFile3 OF((unzFile file, - int* method, - int* level, - int raw, - const char* password)); -/* - Same than unzOpenCurrentFile, but open for read raw the file (not uncompress) - if raw==1 - *method will receive method of compression, *level will receive level of - compression - note : you can set level parameter as NULL (if you did not want known level, - but you CANNOT set method parameter as NULL -*/ - - -extern int ZEXPORT unzCloseCurrentFile OF((unzFile file)); -/* - Close the file in zip opened with unzOpenCurrentFile - Return UNZ_CRCERROR if all the file was read but the CRC is not good -*/ - -extern int ZEXPORT unzReadCurrentFile OF((unzFile file, - voidp buf, - unsigned len)); -/* - Read bytes from the current file (opened by unzOpenCurrentFile) - buf contain buffer where data must be copied - len the size of buf. - - return the number of byte copied if somes bytes are copied - return 0 if the end of file was reached - return <0 with error code if there is an error - (UNZ_ERRNO for IO error, or zLib error for uncompress error) -*/ - -extern z_off_t ZEXPORT unztell OF((unzFile file)); - -extern ZPOS64_T ZEXPORT unztell64 OF((unzFile file)); -/* - Give the current position in uncompressed data -*/ - -extern int ZEXPORT unzeof OF((unzFile file)); -/* - return 1 if the end of file was reached, 0 elsewhere -*/ - -extern int ZEXPORT unzGetLocalExtrafield OF((unzFile file, - voidp buf, - unsigned len)); -/* - Read extra field from the current file (opened by unzOpenCurrentFile) - This is the local-header version of the extra field (sometimes, there is - more info in the local-header version than in the central-header) - - if buf==NULL, it return the size of the local extra field - - if buf!=NULL, len is the size of the buffer, the extra header is copied in - buf. - the return value is the number of bytes copied in buf, or (if <0) - the error code -*/ - -/***************************************************************************/ - -/* Get the current file offset */ -extern ZPOS64_T ZEXPORT unzGetOffset64 (unzFile file); -extern uLong ZEXPORT unzGetOffset (unzFile file); - -/* Set the current file offset */ -extern int ZEXPORT unzSetOffset64 (unzFile file, ZPOS64_T pos); -extern int ZEXPORT unzSetOffset (unzFile file, uLong pos); - - - -#ifdef __cplusplus -} -#endif - -#endif /* _unz64_H */ diff --git a/btgui/minizip/zip.c b/btgui/minizip/zip.c deleted file mode 100644 index a024136a0..000000000 --- a/btgui/minizip/zip.c +++ /dev/null @@ -1,2004 +0,0 @@ -/* zip.c -- IO on .zip files using zlib - Version 1.1, February 14h, 2010 - part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html ) - - Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html ) - - Modifications for Zip64 support - Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com ) - - For more info read MiniZip_info.txt - - Changes - Oct-2009 - Mathias Svensson - Remove old C style function prototypes - Oct-2009 - Mathias Svensson - Added Zip64 Support when creating new file archives - Oct-2009 - Mathias Svensson - Did some code cleanup and refactoring to get better overview of some functions. - Oct-2009 - Mathias Svensson - Added zipRemoveExtraInfoBlock to strip extra field data from its ZIP64 data - It is used when recreting zip archive with RAW when deleting items from a zip. - ZIP64 data is automaticly added to items that needs it, and existing ZIP64 data need to be removed. - Oct-2009 - Mathias Svensson - Added support for BZIP2 as compression mode (bzip2 lib is required) - Jan-2010 - back to unzip and minizip 1.0 name scheme, with compatibility layer - -*/ - - -#include -#include -#include -#include -#include "../zlib/zlib.h" -#include "zip.h" - -#ifdef STDC -# include -# include -# include -#endif -#ifdef NO_ERRNO_H - extern int errno; -#else -# include -#endif - - -#ifndef local -# define local static -#endif -/* compile with -Dlocal if your debugger can't find static symbols */ - -#ifndef VERSIONMADEBY -# define VERSIONMADEBY (0x0) /* platform depedent */ -#endif - -#ifndef Z_BUFSIZE -#define Z_BUFSIZE (64*1024) //(16384) -#endif - -#ifndef Z_MAXFILENAMEINZIP -#define Z_MAXFILENAMEINZIP (256) -#endif - -#ifndef ALLOC -# define ALLOC(size) (malloc(size)) -#endif -#ifndef TRYFREE -# define TRYFREE(p) {if (p) free(p);} -#endif - -/* -#define SIZECENTRALDIRITEM (0x2e) -#define SIZEZIPLOCALHEADER (0x1e) -*/ - -/* I've found an old Unix (a SunOS 4.1.3_U1) without all SEEK_* defined.... */ - - -// NOT sure that this work on ALL platform -#define MAKEULONG64(a, b) ((ZPOS64_T)(((unsigned long)(a)) | ((ZPOS64_T)((unsigned long)(b))) << 32)) - -#ifndef SEEK_CUR -#define SEEK_CUR 1 -#endif - -#ifndef SEEK_END -#define SEEK_END 2 -#endif - -#ifndef SEEK_SET -#define SEEK_SET 0 -#endif - -#ifndef DEF_MEM_LEVEL -#if MAX_MEM_LEVEL >= 8 -# define DEF_MEM_LEVEL 8 -#else -# define DEF_MEM_LEVEL MAX_MEM_LEVEL -#endif -#endif -const char zip_copyright[] =" zip 1.01 Copyright 1998-2004 Gilles Vollant - http://www.winimage.com/zLibDll"; - - -#define SIZEDATA_INDATABLOCK (4096-(4*4)) - -#define LOCALHEADERMAGIC (0x04034b50) -#define CENTRALHEADERMAGIC (0x02014b50) -#define ENDHEADERMAGIC (0x06054b50) -#define ZIP64ENDHEADERMAGIC (0x6064b50) -#define ZIP64ENDLOCHEADERMAGIC (0x7064b50) - -#define FLAG_LOCALHEADER_OFFSET (0x06) -#define CRC_LOCALHEADER_OFFSET (0x0e) - -#define SIZECENTRALHEADER (0x2e) /* 46 */ - -typedef struct linkedlist_datablock_internal_s -{ - struct linkedlist_datablock_internal_s* next_datablock; - uLong avail_in_this_block; - uLong filled_in_this_block; - uLong unused; /* for future use and alignement */ - unsigned char data[SIZEDATA_INDATABLOCK]; -} linkedlist_datablock_internal; - -typedef struct linkedlist_data_s -{ - linkedlist_datablock_internal* first_block; - linkedlist_datablock_internal* last_block; -} linkedlist_data; - - -typedef struct -{ - z_stream stream; /* zLib stream structure for inflate */ -#ifdef HAVE_BZIP2 - bz_stream bstream; /* bzLib stream structure for bziped */ -#endif - - int stream_initialised; /* 1 is stream is initialised */ - uInt pos_in_buffered_data; /* last written byte in buffered_data */ - - ZPOS64_T pos_local_header; /* offset of the local header of the file - currenty writing */ - char* central_header; /* central header data for the current file */ - uLong size_centralExtra; - uLong size_centralheader; /* size of the central header for cur file */ - uLong size_centralExtraFree; /* Extra bytes allocated to the centralheader but that are not used */ - uLong flag; /* flag of the file currently writing */ - - int method; /* compression method of file currenty wr.*/ - int raw; /* 1 for directly writing raw data */ - Byte buffered_data[Z_BUFSIZE];/* buffer contain compressed data to be writ*/ - uLong dosDate; - uLong crc32; - int encrypt; - int zip64; /* Add ZIP64 extened information in the extra field */ - ZPOS64_T pos_zip64extrainfo; - ZPOS64_T totalCompressedData; - ZPOS64_T totalUncompressedData; -#ifndef NOCRYPT - unsigned long keys[3]; /* keys defining the pseudo-random sequence */ - const unsigned long* pcrc_32_tab; - int crypt_header_size; -#endif -} curfile64_info; - -typedef struct -{ - zlib_filefunc64_32_def z_filefunc; - voidpf filestream; /* io structore of the zipfile */ - linkedlist_data central_dir;/* datablock with central dir in construction*/ - int in_opened_file_inzip; /* 1 if a file in the zip is currently writ.*/ - curfile64_info ci; /* info on the file curretly writing */ - - ZPOS64_T begin_pos; /* position of the beginning of the zipfile */ - ZPOS64_T add_position_when_writting_offset; - ZPOS64_T number_entry; - -#ifndef NO_ADDFILEINEXISTINGZIP - char *globalcomment; -#endif - -} zip64_internal; - - -#ifndef NOCRYPT -#define INCLUDECRYPTINGCODE_IFCRYPTALLOWED -#include "crypt.h" -#endif - -local linkedlist_datablock_internal* allocate_new_datablock() -{ - linkedlist_datablock_internal* ldi; - ldi = (linkedlist_datablock_internal*) - ALLOC(sizeof(linkedlist_datablock_internal)); - if (ldi!=NULL) - { - ldi->next_datablock = NULL ; - ldi->filled_in_this_block = 0 ; - ldi->avail_in_this_block = SIZEDATA_INDATABLOCK ; - } - return ldi; -} - -local void free_datablock(linkedlist_datablock_internal* ldi) -{ - while (ldi!=NULL) - { - linkedlist_datablock_internal* ldinext = ldi->next_datablock; - TRYFREE(ldi); - ldi = ldinext; - } -} - -local void init_linkedlist(linkedlist_data* ll) -{ - ll->first_block = ll->last_block = NULL; -} - -local void free_linkedlist(linkedlist_data* ll) -{ - free_datablock(ll->first_block); - ll->first_block = ll->last_block = NULL; -} - - -local int add_data_in_datablock(linkedlist_data* ll, const void* buf, uLong len) -{ - linkedlist_datablock_internal* ldi; - const unsigned char* from_copy; - - if (ll==NULL) - return ZIP_INTERNALERROR; - - if (ll->last_block == NULL) - { - ll->first_block = ll->last_block = allocate_new_datablock(); - if (ll->first_block == NULL) - return ZIP_INTERNALERROR; - } - - ldi = ll->last_block; - from_copy = (unsigned char*)buf; - - while (len>0) - { - uInt copy_this; - uInt i; - unsigned char* to_copy; - - if (ldi->avail_in_this_block==0) - { - ldi->next_datablock = allocate_new_datablock(); - if (ldi->next_datablock == NULL) - return ZIP_INTERNALERROR; - ldi = ldi->next_datablock ; - ll->last_block = ldi; - } - - if (ldi->avail_in_this_block < len) - copy_this = (uInt)ldi->avail_in_this_block; - else - copy_this = (uInt)len; - - to_copy = &(ldi->data[ldi->filled_in_this_block]); - - for (i=0;ifilled_in_this_block += copy_this; - ldi->avail_in_this_block -= copy_this; - from_copy += copy_this ; - len -= copy_this; - } - return ZIP_OK; -} - - - -/****************************************************************************/ - -#ifndef NO_ADDFILEINEXISTINGZIP -/* =========================================================================== - Inputs a long in LSB order to the given file - nbByte == 1, 2 ,4 or 8 (byte, short or long, ZPOS64_T) -*/ - -local int zip64local_putValue OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, ZPOS64_T x, int nbByte)); -local int zip64local_putValue (const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, ZPOS64_T x, int nbByte) -{ - unsigned char buf[8]; - int n; - for (n = 0; n < nbByte; n++) - { - buf[n] = (unsigned char)(x & 0xff); - x >>= 8; - } - if (x != 0) - { /* data overflow - hack for ZIP64 (X Roche) */ - for (n = 0; n < nbByte; n++) - { - buf[n] = 0xff; - } - } - - if (ZWRITE64(*pzlib_filefunc_def,filestream,buf,nbByte)!=(uLong)nbByte) - return ZIP_ERRNO; - else - return ZIP_OK; -} - -local void zip64local_putValue_inmemory OF((void* dest, ZPOS64_T x, int nbByte)); -local void zip64local_putValue_inmemory (void* dest, ZPOS64_T x, int nbByte) -{ - unsigned char* buf=(unsigned char*)dest; - int n; - for (n = 0; n < nbByte; n++) { - buf[n] = (unsigned char)(x & 0xff); - x >>= 8; - } - - if (x != 0) - { /* data overflow - hack for ZIP64 */ - for (n = 0; n < nbByte; n++) - { - buf[n] = 0xff; - } - } -} - -/****************************************************************************/ - - -local uLong zip64local_TmzDateToDosDate(const tm_zip* ptm) -{ - uLong year = (uLong)ptm->tm_year; - if (year>=1980) - year-=1980; - else if (year>=80) - year-=80; - return - (uLong) (((ptm->tm_mday) + (32 * (ptm->tm_mon+1)) + (512 * year)) << 16) | - ((ptm->tm_sec/2) + (32* ptm->tm_min) + (2048 * (uLong)ptm->tm_hour)); -} - - -/****************************************************************************/ - -local int zip64local_getByte OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, int *pi)); - -local int zip64local_getByte(const zlib_filefunc64_32_def* pzlib_filefunc_def,voidpf filestream,int* pi) -{ - unsigned char c; - int err = (int)ZREAD64(*pzlib_filefunc_def,filestream,&c,1); - if (err==1) - { - *pi = (int)c; - return ZIP_OK; - } - else - { - if (ZERROR64(*pzlib_filefunc_def,filestream)) - return ZIP_ERRNO; - else - return ZIP_EOF; - } -} - - -/* =========================================================================== - Reads a long in LSB order from the given gz_stream. Sets -*/ -local int zip64local_getShort OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, uLong *pX)); - -local int zip64local_getShort (const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, uLong* pX) -{ - uLong x ; - int i = 0; - int err; - - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x = (uLong)i; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((uLong)i)<<8; - - if (err==ZIP_OK) - *pX = x; - else - *pX = 0; - return err; -} - -local int zip64local_getLong OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, uLong *pX)); - -local int zip64local_getLong (const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, uLong* pX) -{ - uLong x ; - int i = 0; - int err; - - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x = (uLong)i; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((uLong)i)<<8; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((uLong)i)<<16; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((uLong)i)<<24; - - if (err==ZIP_OK) - *pX = x; - else - *pX = 0; - return err; -} - -local int zip64local_getLong64 OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, ZPOS64_T *pX)); - - -local int zip64local_getLong64 (const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream, ZPOS64_T *pX) -{ - ZPOS64_T x; - int i = 0; - int err; - - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x = (ZPOS64_T)i; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<8; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<16; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<24; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<32; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<40; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<48; - - if (err==ZIP_OK) - err = zip64local_getByte(pzlib_filefunc_def,filestream,&i); - x += ((ZPOS64_T)i)<<56; - - if (err==ZIP_OK) - *pX = x; - else - *pX = 0; - - return err; -} - -#ifndef BUFREADCOMMENT -#define BUFREADCOMMENT (0x400) -#endif -/* - Locate the Central directory of a zipfile (at the end, just before - the global comment) -*/ -local ZPOS64_T zip64local_SearchCentralDir OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream)); - -local ZPOS64_T zip64local_SearchCentralDir(const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream) -{ - unsigned char* buf; - ZPOS64_T uSizeFile; - ZPOS64_T uBackRead; - ZPOS64_T uMaxBack=0xffff; /* maximum size of global comment */ - ZPOS64_T uPosFound=0; - - if (ZSEEK64(*pzlib_filefunc_def,filestream,0,ZLIB_FILEFUNC_SEEK_END) != 0) - return 0; - - - uSizeFile = ZTELL64(*pzlib_filefunc_def,filestream); - - if (uMaxBack>uSizeFile) - uMaxBack = uSizeFile; - - buf = (unsigned char*)ALLOC(BUFREADCOMMENT+4); - if (buf==NULL) - return 0; - - uBackRead = 4; - while (uBackReaduMaxBack) - uBackRead = uMaxBack; - else - uBackRead+=BUFREADCOMMENT; - uReadPos = uSizeFile-uBackRead ; - - uReadSize = ((BUFREADCOMMENT+4) < (uSizeFile-uReadPos)) ? - (BUFREADCOMMENT+4) : (uLong)(uSizeFile-uReadPos); - if (ZSEEK64(*pzlib_filefunc_def,filestream,uReadPos,ZLIB_FILEFUNC_SEEK_SET)!=0) - break; - - if (ZREAD64(*pzlib_filefunc_def,filestream,buf,uReadSize)!=uReadSize) - break; - - for (i=(int)uReadSize-3; (i--)>0;) - if (((*(buf+i))==0x50) && ((*(buf+i+1))==0x4b) && - ((*(buf+i+2))==0x05) && ((*(buf+i+3))==0x06)) - { - uPosFound = uReadPos+i; - break; - } - - if (uPosFound!=0) - break; - } - TRYFREE(buf); - return uPosFound; -} - -/* -Locate the End of Zip64 Central directory locator and from there find the CD of a zipfile (at the end, just before -the global comment) -*/ -local ZPOS64_T zip64local_SearchCentralDir64 OF((const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream)); - -local ZPOS64_T zip64local_SearchCentralDir64(const zlib_filefunc64_32_def* pzlib_filefunc_def, voidpf filestream) -{ - unsigned char* buf; - ZPOS64_T uSizeFile; - ZPOS64_T uBackRead; - ZPOS64_T uMaxBack=0xffff; /* maximum size of global comment */ - ZPOS64_T uPosFound=0; - uLong uL; - ZPOS64_T relativeOffset; - - if (ZSEEK64(*pzlib_filefunc_def,filestream,0,ZLIB_FILEFUNC_SEEK_END) != 0) - return 0; - - uSizeFile = ZTELL64(*pzlib_filefunc_def,filestream); - - if (uMaxBack>uSizeFile) - uMaxBack = uSizeFile; - - buf = (unsigned char*)ALLOC(BUFREADCOMMENT+4); - if (buf==NULL) - return 0; - - uBackRead = 4; - while (uBackReaduMaxBack) - uBackRead = uMaxBack; - else - uBackRead+=BUFREADCOMMENT; - uReadPos = uSizeFile-uBackRead ; - - uReadSize = ((BUFREADCOMMENT+4) < (uSizeFile-uReadPos)) ? - (BUFREADCOMMENT+4) : (uLong)(uSizeFile-uReadPos); - if (ZSEEK64(*pzlib_filefunc_def,filestream,uReadPos,ZLIB_FILEFUNC_SEEK_SET)!=0) - break; - - if (ZREAD64(*pzlib_filefunc_def,filestream,buf,uReadSize)!=uReadSize) - break; - - for (i=(int)uReadSize-3; (i--)>0;) - { - // Signature "0x07064b50" Zip64 end of central directory locater - if (((*(buf+i))==0x50) && ((*(buf+i+1))==0x4b) && ((*(buf+i+2))==0x06) && ((*(buf+i+3))==0x07)) - { - uPosFound = uReadPos+i; - break; - } - } - - if (uPosFound!=0) - break; - } - - TRYFREE(buf); - if (uPosFound == 0) - return 0; - - /* Zip64 end of central directory locator */ - if (ZSEEK64(*pzlib_filefunc_def,filestream, uPosFound,ZLIB_FILEFUNC_SEEK_SET)!=0) - return 0; - - /* the signature, already checked */ - if (zip64local_getLong(pzlib_filefunc_def,filestream,&uL)!=ZIP_OK) - return 0; - - /* number of the disk with the start of the zip64 end of central directory */ - if (zip64local_getLong(pzlib_filefunc_def,filestream,&uL)!=ZIP_OK) - return 0; - if (uL != 0) - return 0; - - /* relative offset of the zip64 end of central directory record */ - if (zip64local_getLong64(pzlib_filefunc_def,filestream,&relativeOffset)!=ZIP_OK) - return 0; - - /* total number of disks */ - if (zip64local_getLong(pzlib_filefunc_def,filestream,&uL)!=ZIP_OK) - return 0; - if (uL != 1) - return 0; - - /* Goto Zip64 end of central directory record */ - if (ZSEEK64(*pzlib_filefunc_def,filestream, relativeOffset,ZLIB_FILEFUNC_SEEK_SET)!=0) - return 0; - - /* the signature */ - if (zip64local_getLong(pzlib_filefunc_def,filestream,&uL)!=ZIP_OK) - return 0; - - if (uL != 0x06064b50) // signature of 'Zip64 end of central directory' - return 0; - - return relativeOffset; -} - -int LoadCentralDirectoryRecord(zip64_internal* pziinit) -{ - int err=ZIP_OK; - ZPOS64_T byte_before_the_zipfile;/* byte before the zipfile, (>0 for sfx)*/ - - ZPOS64_T size_central_dir; /* size of the central directory */ - ZPOS64_T offset_central_dir; /* offset of start of central directory */ - ZPOS64_T central_pos; - uLong uL; - - uLong number_disk; /* number of the current dist, used for - spaning ZIP, unsupported, always 0*/ - uLong number_disk_with_CD; /* number the the disk with central dir, used - for spaning ZIP, unsupported, always 0*/ - ZPOS64_T number_entry; - ZPOS64_T number_entry_CD; /* total number of entries in - the central dir - (same than number_entry on nospan) */ - uLong VersionMadeBy; - uLong VersionNeeded; - uLong size_comment; - - int hasZIP64Record = 0; - - // check first if we find a ZIP64 record - central_pos = zip64local_SearchCentralDir64(&pziinit->z_filefunc,pziinit->filestream); - if(central_pos > 0) - { - hasZIP64Record = 1; - } - else if(central_pos == 0) - { - central_pos = zip64local_SearchCentralDir(&pziinit->z_filefunc,pziinit->filestream); - } - -/* disable to allow appending to empty ZIP archive - if (central_pos==0) - err=ZIP_ERRNO; -*/ - - if(hasZIP64Record) - { - ZPOS64_T sizeEndOfCentralDirectory; - if (ZSEEK64(pziinit->z_filefunc, pziinit->filestream, central_pos, ZLIB_FILEFUNC_SEEK_SET) != 0) - err=ZIP_ERRNO; - - /* the signature, already checked */ - if (zip64local_getLong(&pziinit->z_filefunc, pziinit->filestream,&uL)!=ZIP_OK) - err=ZIP_ERRNO; - - /* size of zip64 end of central directory record */ - if (zip64local_getLong64(&pziinit->z_filefunc, pziinit->filestream, &sizeEndOfCentralDirectory)!=ZIP_OK) - err=ZIP_ERRNO; - - /* version made by */ - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream, &VersionMadeBy)!=ZIP_OK) - err=ZIP_ERRNO; - - /* version needed to extract */ - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream, &VersionNeeded)!=ZIP_OK) - err=ZIP_ERRNO; - - /* number of this disk */ - if (zip64local_getLong(&pziinit->z_filefunc, pziinit->filestream,&number_disk)!=ZIP_OK) - err=ZIP_ERRNO; - - /* number of the disk with the start of the central directory */ - if (zip64local_getLong(&pziinit->z_filefunc, pziinit->filestream,&number_disk_with_CD)!=ZIP_OK) - err=ZIP_ERRNO; - - /* total number of entries in the central directory on this disk */ - if (zip64local_getLong64(&pziinit->z_filefunc, pziinit->filestream, &number_entry)!=ZIP_OK) - err=ZIP_ERRNO; - - /* total number of entries in the central directory */ - if (zip64local_getLong64(&pziinit->z_filefunc, pziinit->filestream,&number_entry_CD)!=ZIP_OK) - err=ZIP_ERRNO; - - if ((number_entry_CD!=number_entry) || (number_disk_with_CD!=0) || (number_disk!=0)) - err=ZIP_BADZIPFILE; - - /* size of the central directory */ - if (zip64local_getLong64(&pziinit->z_filefunc, pziinit->filestream,&size_central_dir)!=ZIP_OK) - err=ZIP_ERRNO; - - /* offset of start of central directory with respect to the - starting disk number */ - if (zip64local_getLong64(&pziinit->z_filefunc, pziinit->filestream,&offset_central_dir)!=ZIP_OK) - err=ZIP_ERRNO; - - // TODO.. - // read the comment from the standard central header. - size_comment = 0; - } - else - { - // Read End of central Directory info - if (ZSEEK64(pziinit->z_filefunc, pziinit->filestream, central_pos,ZLIB_FILEFUNC_SEEK_SET)!=0) - err=ZIP_ERRNO; - - /* the signature, already checked */ - if (zip64local_getLong(&pziinit->z_filefunc, pziinit->filestream,&uL)!=ZIP_OK) - err=ZIP_ERRNO; - - /* number of this disk */ - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream,&number_disk)!=ZIP_OK) - err=ZIP_ERRNO; - - /* number of the disk with the start of the central directory */ - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream,&number_disk_with_CD)!=ZIP_OK) - err=ZIP_ERRNO; - - /* total number of entries in the central dir on this disk */ - number_entry = 0; - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream, &uL)!=ZIP_OK) - err=ZIP_ERRNO; - else - number_entry = uL; - - /* total number of entries in the central dir */ - number_entry_CD = 0; - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream, &uL)!=ZIP_OK) - err=ZIP_ERRNO; - else - number_entry_CD = uL; - - if ((number_entry_CD!=number_entry) || (number_disk_with_CD!=0) || (number_disk!=0)) - err=ZIP_BADZIPFILE; - - /* size of the central directory */ - size_central_dir = 0; - if (zip64local_getLong(&pziinit->z_filefunc, pziinit->filestream, &uL)!=ZIP_OK) - err=ZIP_ERRNO; - else - size_central_dir = uL; - - /* offset of start of central directory with respect to the starting disk number */ - offset_central_dir = 0; - if (zip64local_getLong(&pziinit->z_filefunc, pziinit->filestream, &uL)!=ZIP_OK) - err=ZIP_ERRNO; - else - offset_central_dir = uL; - - - /* zipfile global comment length */ - if (zip64local_getShort(&pziinit->z_filefunc, pziinit->filestream, &size_comment)!=ZIP_OK) - err=ZIP_ERRNO; - } - - if ((central_posz_filefunc, pziinit->filestream); - return ZIP_ERRNO; - } - - if (size_comment>0) - { - pziinit->globalcomment = (char*)ALLOC(size_comment+1); - if (pziinit->globalcomment) - { - size_comment = ZREAD64(pziinit->z_filefunc, pziinit->filestream, pziinit->globalcomment,size_comment); - pziinit->globalcomment[size_comment]=0; - } - } - - byte_before_the_zipfile = central_pos - (offset_central_dir+size_central_dir); - pziinit->add_position_when_writting_offset = byte_before_the_zipfile; - - { - ZPOS64_T size_central_dir_to_read = size_central_dir; - size_t buf_size = SIZEDATA_INDATABLOCK; - void* buf_read = (void*)ALLOC(buf_size); - if (ZSEEK64(pziinit->z_filefunc, pziinit->filestream, offset_central_dir + byte_before_the_zipfile, ZLIB_FILEFUNC_SEEK_SET) != 0) - err=ZIP_ERRNO; - - while ((size_central_dir_to_read>0) && (err==ZIP_OK)) - { - ZPOS64_T read_this = SIZEDATA_INDATABLOCK; - if (read_this > size_central_dir_to_read) - read_this = size_central_dir_to_read; - - if (ZREAD64(pziinit->z_filefunc, pziinit->filestream,buf_read,(uLong)read_this) != read_this) - err=ZIP_ERRNO; - - if (err==ZIP_OK) - err = add_data_in_datablock(&pziinit->central_dir,buf_read, (uLong)read_this); - - size_central_dir_to_read-=read_this; - } - TRYFREE(buf_read); - } - pziinit->begin_pos = byte_before_the_zipfile; - pziinit->number_entry = number_entry_CD; - - if (ZSEEK64(pziinit->z_filefunc, pziinit->filestream, offset_central_dir+byte_before_the_zipfile,ZLIB_FILEFUNC_SEEK_SET) != 0) - err=ZIP_ERRNO; - - return err; -} - - -#endif /* !NO_ADDFILEINEXISTINGZIP*/ - - -/************************************************************/ -extern zipFile ZEXPORT zipOpen3 (const void *pathname, int append, zipcharpc* globalcomment, zlib_filefunc64_32_def* pzlib_filefunc64_32_def) -{ - zip64_internal ziinit; - zip64_internal* zi; - int err=ZIP_OK; - - ziinit.z_filefunc.zseek32_file = NULL; - ziinit.z_filefunc.ztell32_file = NULL; - if (pzlib_filefunc64_32_def==NULL) - fill_fopen64_filefunc(&ziinit.z_filefunc.zfile_func64); - else - ziinit.z_filefunc = *pzlib_filefunc64_32_def; - - ziinit.filestream = ZOPEN64(ziinit.z_filefunc, - pathname, - (append == APPEND_STATUS_CREATE) ? - (ZLIB_FILEFUNC_MODE_READ | ZLIB_FILEFUNC_MODE_WRITE | ZLIB_FILEFUNC_MODE_CREATE) : - (ZLIB_FILEFUNC_MODE_READ | ZLIB_FILEFUNC_MODE_WRITE | ZLIB_FILEFUNC_MODE_EXISTING)); - - if (ziinit.filestream == NULL) - return NULL; - - if (append == APPEND_STATUS_CREATEAFTER) - ZSEEK64(ziinit.z_filefunc,ziinit.filestream,0,SEEK_END); - - ziinit.begin_pos = ZTELL64(ziinit.z_filefunc,ziinit.filestream); - ziinit.in_opened_file_inzip = 0; - ziinit.ci.stream_initialised = 0; - ziinit.number_entry = 0; - ziinit.add_position_when_writting_offset = 0; - init_linkedlist(&(ziinit.central_dir)); - - - - zi = (zip64_internal*)ALLOC(sizeof(zip64_internal)); - if (zi==NULL) - { - ZCLOSE64(ziinit.z_filefunc,ziinit.filestream); - return NULL; - } - - /* now we add file in a zipfile */ -# ifndef NO_ADDFILEINEXISTINGZIP - ziinit.globalcomment = NULL; - if (append == APPEND_STATUS_ADDINZIP) - { - // Read and Cache Central Directory Records - err = LoadCentralDirectoryRecord(&ziinit); - } - - if (globalcomment) - { - *globalcomment = ziinit.globalcomment; - } -# endif /* !NO_ADDFILEINEXISTINGZIP*/ - - if (err != ZIP_OK) - { -# ifndef NO_ADDFILEINEXISTINGZIP - TRYFREE(ziinit.globalcomment); -# endif /* !NO_ADDFILEINEXISTINGZIP*/ - TRYFREE(zi); - return NULL; - } - else - { - *zi = ziinit; - return (zipFile)zi; - } -} - -extern zipFile ZEXPORT zipOpen2 (const char *pathname, int append, zipcharpc* globalcomment, zlib_filefunc_def* pzlib_filefunc32_def) -{ - if (pzlib_filefunc32_def != NULL) - { - zlib_filefunc64_32_def zlib_filefunc64_32_def_fill; - fill_zlib_filefunc64_32_def_from_filefunc32(&zlib_filefunc64_32_def_fill,pzlib_filefunc32_def); - return zipOpen3(pathname, append, globalcomment, &zlib_filefunc64_32_def_fill); - } - else - return zipOpen3(pathname, append, globalcomment, NULL); -} - -extern zipFile ZEXPORT zipOpen2_64 (const void *pathname, int append, zipcharpc* globalcomment, zlib_filefunc64_def* pzlib_filefunc_def) -{ - if (pzlib_filefunc_def != NULL) - { - zlib_filefunc64_32_def zlib_filefunc64_32_def_fill; - zlib_filefunc64_32_def_fill.zfile_func64 = *pzlib_filefunc_def; - zlib_filefunc64_32_def_fill.ztell32_file = NULL; - zlib_filefunc64_32_def_fill.zseek32_file = NULL; - return zipOpen3(pathname, append, globalcomment, &zlib_filefunc64_32_def_fill); - } - else - return zipOpen3(pathname, append, globalcomment, NULL); -} - - - -extern zipFile ZEXPORT zipOpen (const char* pathname, int append) -{ - return zipOpen3((const void*)pathname,append,NULL,NULL); -} - -extern zipFile ZEXPORT zipOpen64 (const void* pathname, int append) -{ - return zipOpen3(pathname,append,NULL,NULL); -} - -int Write_LocalFileHeader(zip64_internal* zi, const char* filename, uInt size_extrafield_local, const void* extrafield_local) -{ - /* write the local header */ - int err; - uInt size_filename = (uInt)strlen(filename); - uInt size_extrafield = size_extrafield_local; - - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)LOCALHEADERMAGIC, 4); - - if (err==ZIP_OK) - { - if(zi->ci.zip64) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)45,2);/* version needed to extract */ - else - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)20,2);/* version needed to extract */ - } - - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)zi->ci.flag,2); - - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)zi->ci.method,2); - - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)zi->ci.dosDate,4); - - // CRC / Compressed size / Uncompressed size will be filled in later and rewritten later - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,4); /* crc 32, unknown */ - if (err==ZIP_OK) - { - if(zi->ci.zip64) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0xFFFFFFFF,4); /* compressed size, unknown */ - else - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,4); /* compressed size, unknown */ - } - if (err==ZIP_OK) - { - if(zi->ci.zip64) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0xFFFFFFFF,4); /* uncompressed size, unknown */ - else - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,4); /* uncompressed size, unknown */ - } - - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)size_filename,2); - - if(zi->ci.zip64) - { - size_extrafield += 20; - } - - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)size_extrafield,2); - - if ((err==ZIP_OK) && (size_filename > 0)) - { - if (ZWRITE64(zi->z_filefunc,zi->filestream,filename,size_filename)!=size_filename) - err = ZIP_ERRNO; - } - - if ((err==ZIP_OK) && (size_extrafield_local > 0)) - { - if (ZWRITE64(zi->z_filefunc, zi->filestream, extrafield_local, size_extrafield_local) != size_extrafield_local) - err = ZIP_ERRNO; - } - - - if ((err==ZIP_OK) && (zi->ci.zip64)) - { - // write the Zip64 extended info - short HeaderID = 1; - short DataSize = 16; - ZPOS64_T CompressedSize = 0; - ZPOS64_T UncompressedSize = 0; - - // Remember position of Zip64 extended info for the local file header. (needed when we update size after done with file) - zi->ci.pos_zip64extrainfo = ZTELL64(zi->z_filefunc,zi->filestream); - - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, (short)HeaderID,2); - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, (short)DataSize,2); - - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, (ZPOS64_T)UncompressedSize,8); - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, (ZPOS64_T)CompressedSize,8); - } - - return err; -} - -/* - NOTE. - When writing RAW the ZIP64 extended information in extrafield_local and extrafield_global needs to be stripped - before calling this function it can be done with zipRemoveExtraInfoBlock - - It is not done here because then we need to realloc a new buffer since parameters are 'const' and I want to minimize - unnecessary allocations. - */ -extern int ZEXPORT zipOpenNewFileInZip4_64 (zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void* extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int raw, - int windowBits,int memLevel, int strategy, - const char* password, uLong crcForCrypting, - uLong versionMadeBy, uLong flagBase, int zip64) -{ - zip64_internal* zi; - uInt size_filename; - uInt size_comment; - uInt i; - int err = ZIP_OK; - -# ifdef NOCRYPT - if (password != NULL) - return ZIP_PARAMERROR; -# endif - - if (file == NULL) - return ZIP_PARAMERROR; - -#ifdef HAVE_BZIP2 - if ((method!=0) && (method!=Z_DEFLATED) && (method!=Z_BZIP2ED)) - return ZIP_PARAMERROR; -#else - if ((method!=0) && (method!=Z_DEFLATED)) - return ZIP_PARAMERROR; -#endif - - zi = (zip64_internal*)file; - - if (zi->in_opened_file_inzip == 1) - { - err = zipCloseFileInZip (file); - if (err != ZIP_OK) - return err; - } - - if (filename==NULL) - filename="-"; - - if (comment==NULL) - size_comment = 0; - else - size_comment = (uInt)strlen(comment); - - size_filename = (uInt)strlen(filename); - - if (zipfi == NULL) - zi->ci.dosDate = 0; - else - { - if (zipfi->dosDate != 0) - zi->ci.dosDate = zipfi->dosDate; - else - zi->ci.dosDate = zip64local_TmzDateToDosDate(&zipfi->tmz_date); - } - - zi->ci.flag = flagBase; - if ((level==8) || (level==9)) - zi->ci.flag |= 2; - if ((level==2)) - zi->ci.flag |= 4; - if ((level==1)) - zi->ci.flag |= 6; - if (password != NULL) - zi->ci.flag |= 1; - - zi->ci.crc32 = 0; - zi->ci.method = method; - zi->ci.encrypt = 0; - zi->ci.stream_initialised = 0; - zi->ci.pos_in_buffered_data = 0; - zi->ci.raw = raw; - zi->ci.pos_local_header = ZTELL64(zi->z_filefunc,zi->filestream); - - zi->ci.size_centralheader = SIZECENTRALHEADER + size_filename + size_extrafield_global + size_comment; - zi->ci.size_centralExtraFree = 32; // Extra space we have reserved in case we need to add ZIP64 extra info data - - zi->ci.central_header = (char*)ALLOC((uInt)zi->ci.size_centralheader + zi->ci.size_centralExtraFree); - - zi->ci.size_centralExtra = size_extrafield_global; - zip64local_putValue_inmemory(zi->ci.central_header,(uLong)CENTRALHEADERMAGIC,4); - /* version info */ - zip64local_putValue_inmemory(zi->ci.central_header+4,(uLong)versionMadeBy,2); - zip64local_putValue_inmemory(zi->ci.central_header+6,(uLong)20,2); - zip64local_putValue_inmemory(zi->ci.central_header+8,(uLong)zi->ci.flag,2); - zip64local_putValue_inmemory(zi->ci.central_header+10,(uLong)zi->ci.method,2); - zip64local_putValue_inmemory(zi->ci.central_header+12,(uLong)zi->ci.dosDate,4); - zip64local_putValue_inmemory(zi->ci.central_header+16,(uLong)0,4); /*crc*/ - zip64local_putValue_inmemory(zi->ci.central_header+20,(uLong)0,4); /*compr size*/ - zip64local_putValue_inmemory(zi->ci.central_header+24,(uLong)0,4); /*uncompr size*/ - zip64local_putValue_inmemory(zi->ci.central_header+28,(uLong)size_filename,2); - zip64local_putValue_inmemory(zi->ci.central_header+30,(uLong)size_extrafield_global,2); - zip64local_putValue_inmemory(zi->ci.central_header+32,(uLong)size_comment,2); - zip64local_putValue_inmemory(zi->ci.central_header+34,(uLong)0,2); /*disk nm start*/ - - if (zipfi==NULL) - zip64local_putValue_inmemory(zi->ci.central_header+36,(uLong)0,2); - else - zip64local_putValue_inmemory(zi->ci.central_header+36,(uLong)zipfi->internal_fa,2); - - if (zipfi==NULL) - zip64local_putValue_inmemory(zi->ci.central_header+38,(uLong)0,4); - else - zip64local_putValue_inmemory(zi->ci.central_header+38,(uLong)zipfi->external_fa,4); - - if(zi->ci.pos_local_header >= 0xffffffff) - zip64local_putValue_inmemory(zi->ci.central_header+42,(uLong)0xffffffff,4); - else - zip64local_putValue_inmemory(zi->ci.central_header+42,(uLong)zi->ci.pos_local_header - zi->add_position_when_writting_offset,4); - - for (i=0;ici.central_header+SIZECENTRALHEADER+i) = *(filename+i); - - for (i=0;ici.central_header+SIZECENTRALHEADER+size_filename+i) = - *(((const char*)extrafield_global)+i); - - for (i=0;ici.central_header+SIZECENTRALHEADER+size_filename+ - size_extrafield_global+i) = *(comment+i); - if (zi->ci.central_header == NULL) - return ZIP_INTERNALERROR; - - zi->ci.zip64 = zip64; - zi->ci.totalCompressedData = 0; - zi->ci.totalUncompressedData = 0; - zi->ci.pos_zip64extrainfo = 0; - - err = Write_LocalFileHeader(zi, filename, size_extrafield_local, extrafield_local); - -#ifdef HAVE_BZIP2 - zi->ci.bstream.avail_in = (uInt)0; - zi->ci.bstream.avail_out = (uInt)Z_BUFSIZE; - zi->ci.bstream.next_out = (char*)zi->ci.buffered_data; - zi->ci.bstream.total_in_hi32 = 0; - zi->ci.bstream.total_in_lo32 = 0; - zi->ci.bstream.total_out_hi32 = 0; - zi->ci.bstream.total_out_lo32 = 0; -#endif - - zi->ci.stream.avail_in = (uInt)0; - zi->ci.stream.avail_out = (uInt)Z_BUFSIZE; - zi->ci.stream.next_out = zi->ci.buffered_data; - zi->ci.stream.total_in = 0; - zi->ci.stream.total_out = 0; - zi->ci.stream.data_type = Z_BINARY; - -#ifdef HAVE_BZIP2 - if ((err==ZIP_OK) && (zi->ci.method == Z_DEFLATED || zi->ci.method == Z_BZIP2ED) && (!zi->ci.raw)) -#else - if ((err==ZIP_OK) && (zi->ci.method == Z_DEFLATED) && (!zi->ci.raw)) -#endif - { - if(zi->ci.method == Z_DEFLATED) - { - zi->ci.stream.zalloc = (alloc_func)0; - zi->ci.stream.zfree = (free_func)0; - zi->ci.stream.opaque = (voidpf)0; - - if (windowBits>0) - windowBits = -windowBits; - - err = deflateInit2(&zi->ci.stream, level, Z_DEFLATED, windowBits, memLevel, strategy); - - if (err==Z_OK) - zi->ci.stream_initialised = Z_DEFLATED; - } - else if(zi->ci.method == Z_BZIP2ED) - { -#ifdef HAVE_BZIP2 - // Init BZip stuff here - zi->ci.bstream.bzalloc = 0; - zi->ci.bstream.bzfree = 0; - zi->ci.bstream.opaque = (voidpf)0; - - err = BZ2_bzCompressInit(&zi->ci.bstream, level, 0,35); - if(err == BZ_OK) - zi->ci.stream_initialised = Z_BZIP2ED; -#endif - } - - } - -# ifndef NOCRYPT - zi->ci.crypt_header_size = 0; - if ((err==Z_OK) && (password != NULL)) - { - unsigned char bufHead[RAND_HEAD_LEN]; - unsigned int sizeHead; - zi->ci.encrypt = 1; - zi->ci.pcrc_32_tab = get_crc_table(); - /*init_keys(password,zi->ci.keys,zi->ci.pcrc_32_tab);*/ - - sizeHead=crypthead(password,bufHead,RAND_HEAD_LEN,zi->ci.keys,zi->ci.pcrc_32_tab,crcForCrypting); - zi->ci.crypt_header_size = sizeHead; - - if (ZWRITE64(zi->z_filefunc,zi->filestream,bufHead,sizeHead) != sizeHead) - err = ZIP_ERRNO; - } -# endif - - if (err==Z_OK) - zi->in_opened_file_inzip = 1; - return err; -} - -extern int ZEXPORT zipOpenNewFileInZip4 (zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void* extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int raw, - int windowBits,int memLevel, int strategy, - const char* password, uLong crcForCrypting, - uLong versionMadeBy, uLong flagBase) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, raw, - windowBits, memLevel, strategy, - password, crcForCrypting, versionMadeBy, flagBase, 0); -} - -extern int ZEXPORT zipOpenNewFileInZip3 (zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void* extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int raw, - int windowBits,int memLevel, int strategy, - const char* password, uLong crcForCrypting) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, raw, - windowBits, memLevel, strategy, - password, crcForCrypting, VERSIONMADEBY, 0, 0); -} - -extern int ZEXPORT zipOpenNewFileInZip3_64(zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void* extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int raw, - int windowBits,int memLevel, int strategy, - const char* password, uLong crcForCrypting, int zip64) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, raw, - windowBits, memLevel, strategy, - password, crcForCrypting, VERSIONMADEBY, 0, zip64); -} - -extern int ZEXPORT zipOpenNewFileInZip2(zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void* extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int raw) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, raw, - -MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY, - NULL, 0, VERSIONMADEBY, 0, 0); -} - -extern int ZEXPORT zipOpenNewFileInZip2_64(zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void* extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int raw, int zip64) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, raw, - -MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY, - NULL, 0, VERSIONMADEBY, 0, zip64); -} - -extern int ZEXPORT zipOpenNewFileInZip64 (zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void*extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level, int zip64) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, 0, - -MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY, - NULL, 0, VERSIONMADEBY, 0, zip64); -} - -extern int ZEXPORT zipOpenNewFileInZip (zipFile file, const char* filename, const zip_fileinfo* zipfi, - const void* extrafield_local, uInt size_extrafield_local, - const void*extrafield_global, uInt size_extrafield_global, - const char* comment, int method, int level) -{ - return zipOpenNewFileInZip4_64 (file, filename, zipfi, - extrafield_local, size_extrafield_local, - extrafield_global, size_extrafield_global, - comment, method, level, 0, - -MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY, - NULL, 0, VERSIONMADEBY, 0, 0); -} - -local int zip64FlushWriteBuffer(zip64_internal* zi) -{ - int err=ZIP_OK; - - if (zi->ci.encrypt != 0) - { -#ifndef NOCRYPT - uInt i; - int t; - for (i=0;ici.pos_in_buffered_data;i++) - zi->ci.buffered_data[i] = zencode(zi->ci.keys, zi->ci.pcrc_32_tab, zi->ci.buffered_data[i],t); -#endif - } - - if (ZWRITE64(zi->z_filefunc,zi->filestream,zi->ci.buffered_data,zi->ci.pos_in_buffered_data) != zi->ci.pos_in_buffered_data) - err = ZIP_ERRNO; - - zi->ci.totalCompressedData += zi->ci.pos_in_buffered_data; - -#ifdef HAVE_BZIP2 - if(zi->ci.method == Z_BZIP2ED) - { - zi->ci.totalUncompressedData += zi->ci.bstream.total_in_lo32; - zi->ci.bstream.total_in_lo32 = 0; - zi->ci.bstream.total_in_hi32 = 0; - } - else -#endif - { - zi->ci.totalUncompressedData += zi->ci.stream.total_in; - zi->ci.stream.total_in = 0; - } - - - zi->ci.pos_in_buffered_data = 0; - - return err; -} - -extern int ZEXPORT zipWriteInFileInZip (zipFile file,const void* buf,unsigned int len) -{ - zip64_internal* zi; - int err=ZIP_OK; - - if (file == NULL) - return ZIP_PARAMERROR; - zi = (zip64_internal*)file; - - if (zi->in_opened_file_inzip == 0) - return ZIP_PARAMERROR; - - zi->ci.crc32 = crc32(zi->ci.crc32,buf,(uInt)len); - -#ifdef HAVE_BZIP2 - if(zi->ci.method == Z_BZIP2ED && (!zi->ci.raw)) - { - zi->ci.bstream.next_in = (void*)buf; - zi->ci.bstream.avail_in = len; - err = BZ_RUN_OK; - - while ((err==BZ_RUN_OK) && (zi->ci.bstream.avail_in>0)) - { - if (zi->ci.bstream.avail_out == 0) - { - if (zip64FlushWriteBuffer(zi) == ZIP_ERRNO) - err = ZIP_ERRNO; - zi->ci.bstream.avail_out = (uInt)Z_BUFSIZE; - zi->ci.bstream.next_out = (char*)zi->ci.buffered_data; - } - - - if(err != BZ_RUN_OK) - break; - - if ((zi->ci.method == Z_BZIP2ED) && (!zi->ci.raw)) - { - uLong uTotalOutBefore_lo = zi->ci.bstream.total_out_lo32; -// uLong uTotalOutBefore_hi = zi->ci.bstream.total_out_hi32; - err=BZ2_bzCompress(&zi->ci.bstream, BZ_RUN); - - zi->ci.pos_in_buffered_data += (uInt)(zi->ci.bstream.total_out_lo32 - uTotalOutBefore_lo) ; - } - } - - if(err == BZ_RUN_OK) - err = ZIP_OK; - } - else -#endif - { - zi->ci.stream.next_in = (Bytef*)buf; - zi->ci.stream.avail_in = len; - - while ((err==ZIP_OK) && (zi->ci.stream.avail_in>0)) - { - if (zi->ci.stream.avail_out == 0) - { - if (zip64FlushWriteBuffer(zi) == ZIP_ERRNO) - err = ZIP_ERRNO; - zi->ci.stream.avail_out = (uInt)Z_BUFSIZE; - zi->ci.stream.next_out = zi->ci.buffered_data; - } - - - if(err != ZIP_OK) - break; - - if ((zi->ci.method == Z_DEFLATED) && (!zi->ci.raw)) - { - uLong uTotalOutBefore = zi->ci.stream.total_out; - err=deflate(&zi->ci.stream, Z_NO_FLUSH); - if(uTotalOutBefore > zi->ci.stream.total_out) - { - int bBreak = 0; - bBreak++; - } - - zi->ci.pos_in_buffered_data += (uInt)(zi->ci.stream.total_out - uTotalOutBefore) ; - } - else - { - uInt copy_this,i; - if (zi->ci.stream.avail_in < zi->ci.stream.avail_out) - copy_this = zi->ci.stream.avail_in; - else - copy_this = zi->ci.stream.avail_out; - - for (i = 0; i < copy_this; i++) - *(((char*)zi->ci.stream.next_out)+i) = - *(((const char*)zi->ci.stream.next_in)+i); - { - zi->ci.stream.avail_in -= copy_this; - zi->ci.stream.avail_out-= copy_this; - zi->ci.stream.next_in+= copy_this; - zi->ci.stream.next_out+= copy_this; - zi->ci.stream.total_in+= copy_this; - zi->ci.stream.total_out+= copy_this; - zi->ci.pos_in_buffered_data += copy_this; - } - } - }// while(...) - } - - return err; -} - -extern int ZEXPORT zipCloseFileInZipRaw (zipFile file, uLong uncompressed_size, uLong crc32) -{ - return zipCloseFileInZipRaw64 (file, uncompressed_size, crc32); -} - -extern int ZEXPORT zipCloseFileInZipRaw64 (zipFile file, ZPOS64_T uncompressed_size, uLong crc32) -{ - zip64_internal* zi; - ZPOS64_T compressed_size; - uLong invalidValue = 0xffffffff; - short datasize = 0; - int err=ZIP_OK; - - if (file == NULL) - return ZIP_PARAMERROR; - zi = (zip64_internal*)file; - - if (zi->in_opened_file_inzip == 0) - return ZIP_PARAMERROR; - zi->ci.stream.avail_in = 0; - - if ((zi->ci.method == Z_DEFLATED) && (!zi->ci.raw)) - { - while (err==ZIP_OK) - { - uLong uTotalOutBefore; - if (zi->ci.stream.avail_out == 0) - { - if (zip64FlushWriteBuffer(zi) == ZIP_ERRNO) - err = ZIP_ERRNO; - zi->ci.stream.avail_out = (uInt)Z_BUFSIZE; - zi->ci.stream.next_out = zi->ci.buffered_data; - } - uTotalOutBefore = zi->ci.stream.total_out; - err=deflate(&zi->ci.stream, Z_FINISH); - zi->ci.pos_in_buffered_data += (uInt)(zi->ci.stream.total_out - uTotalOutBefore) ; - } - } - else if ((zi->ci.method == Z_BZIP2ED) && (!zi->ci.raw)) - { -#ifdef HAVE_BZIP2 - err = BZ_FINISH_OK; - while (err==BZ_FINISH_OK) - { - uLong uTotalOutBefore; - if (zi->ci.bstream.avail_out == 0) - { - if (zip64FlushWriteBuffer(zi) == ZIP_ERRNO) - err = ZIP_ERRNO; - zi->ci.bstream.avail_out = (uInt)Z_BUFSIZE; - zi->ci.bstream.next_out = (char*)zi->ci.buffered_data; - } - uTotalOutBefore = zi->ci.bstream.total_out_lo32; - err=BZ2_bzCompress(&zi->ci.bstream, BZ_FINISH); - if(err == BZ_STREAM_END) - err = Z_STREAM_END; - - zi->ci.pos_in_buffered_data += (uInt)(zi->ci.bstream.total_out_lo32 - uTotalOutBefore); - } - - if(err == BZ_FINISH_OK) - err = ZIP_OK; -#endif - } - - if (err==Z_STREAM_END) - err=ZIP_OK; /* this is normal */ - - if ((zi->ci.pos_in_buffered_data>0) && (err==ZIP_OK)) - { - if (zip64FlushWriteBuffer(zi)==ZIP_ERRNO) - err = ZIP_ERRNO; - } - - if ((zi->ci.method == Z_DEFLATED) && (!zi->ci.raw)) - { - int tmp_err = deflateEnd(&zi->ci.stream); - if (err == ZIP_OK) - err = tmp_err; - zi->ci.stream_initialised = 0; - } -#ifdef HAVE_BZIP2 - else if((zi->ci.method == Z_BZIP2ED) && (!zi->ci.raw)) - { - int tmperr = BZ2_bzCompressEnd(&zi->ci.bstream); - if (err==ZIP_OK) - err = tmperr; - zi->ci.stream_initialised = 0; - } -#endif - - if (!zi->ci.raw) - { - crc32 = (uLong)zi->ci.crc32; - uncompressed_size = zi->ci.totalUncompressedData; - } - compressed_size = zi->ci.totalCompressedData; - -# ifndef NOCRYPT - compressed_size += zi->ci.crypt_header_size; -# endif - - // update Current Item crc and sizes, - if(compressed_size >= 0xffffffff || uncompressed_size >= 0xffffffff || zi->ci.pos_local_header >= 0xffffffff) - { - /*version Made by*/ - zip64local_putValue_inmemory(zi->ci.central_header+4,(uLong)45,2); - /*version needed*/ - zip64local_putValue_inmemory(zi->ci.central_header+6,(uLong)45,2); - - } - - zip64local_putValue_inmemory(zi->ci.central_header+16,crc32,4); /*crc*/ - - - if(compressed_size >= 0xffffffff) - zip64local_putValue_inmemory(zi->ci.central_header+20, invalidValue,4); /*compr size*/ - else - zip64local_putValue_inmemory(zi->ci.central_header+20, compressed_size,4); /*compr size*/ - - /// set internal file attributes field - if (zi->ci.stream.data_type == Z_ASCII) - zip64local_putValue_inmemory(zi->ci.central_header+36,(uLong)Z_ASCII,2); - - if(uncompressed_size >= 0xffffffff) - zip64local_putValue_inmemory(zi->ci.central_header+24, invalidValue,4); /*uncompr size*/ - else - zip64local_putValue_inmemory(zi->ci.central_header+24, uncompressed_size,4); /*uncompr size*/ - - // Add ZIP64 extra info field for uncompressed size - if(uncompressed_size >= 0xffffffff) - datasize += 8; - - // Add ZIP64 extra info field for compressed size - if(compressed_size >= 0xffffffff) - datasize += 8; - - // Add ZIP64 extra info field for relative offset to local file header of current file - if(zi->ci.pos_local_header >= 0xffffffff) - datasize += 8; - - if(datasize > 0) - { - char* p = NULL; - - if((uLong)(datasize + 4) > zi->ci.size_centralExtraFree) - { - // we can not write more data to the buffer that we have room for. - return ZIP_BADZIPFILE; - } - - p = zi->ci.central_header + zi->ci.size_centralheader; - - // Add Extra Information Header for 'ZIP64 information' - zip64local_putValue_inmemory(p, 0x0001, 2); // HeaderID - p += 2; - zip64local_putValue_inmemory(p, datasize, 2); // DataSize - p += 2; - - if(uncompressed_size >= 0xffffffff) - { - zip64local_putValue_inmemory(p, uncompressed_size, 8); - p += 8; - } - - if(compressed_size >= 0xffffffff) - { - zip64local_putValue_inmemory(p, compressed_size, 8); - p += 8; - } - - if(zi->ci.pos_local_header >= 0xffffffff) - { - zip64local_putValue_inmemory(p, zi->ci.pos_local_header, 8); - p += 8; - } - - // Update how much extra free space we got in the memory buffer - // and increase the centralheader size so the new ZIP64 fields are included - // ( 4 below is the size of HeaderID and DataSize field ) - zi->ci.size_centralExtraFree -= datasize + 4; - zi->ci.size_centralheader += datasize + 4; - - // Update the extra info size field - zi->ci.size_centralExtra += datasize + 4; - zip64local_putValue_inmemory(zi->ci.central_header+30,(uLong)zi->ci.size_centralExtra,2); - } - - if (err==ZIP_OK) - err = add_data_in_datablock(&zi->central_dir, zi->ci.central_header, (uLong)zi->ci.size_centralheader); - - free(zi->ci.central_header); - - if (err==ZIP_OK) - { - // Update the LocalFileHeader with the new values. - - ZPOS64_T cur_pos_inzip = ZTELL64(zi->z_filefunc,zi->filestream); - - if (ZSEEK64(zi->z_filefunc,zi->filestream, zi->ci.pos_local_header + 14,ZLIB_FILEFUNC_SEEK_SET)!=0) - err = ZIP_ERRNO; - - if (err==ZIP_OK) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,crc32,4); /* crc 32, unknown */ - - if(uncompressed_size >= 0xffffffff) - { - if(zi->ci.pos_zip64extrainfo > 0) - { - // Update the size in the ZIP64 extended field. - if (ZSEEK64(zi->z_filefunc,zi->filestream, zi->ci.pos_zip64extrainfo + 4,ZLIB_FILEFUNC_SEEK_SET)!=0) - err = ZIP_ERRNO; - - if (err==ZIP_OK) /* compressed size, unknown */ - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, uncompressed_size, 8); - - if (err==ZIP_OK) /* uncompressed size, unknown */ - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, compressed_size, 8); - } - } - else - { - if (err==ZIP_OK) /* compressed size, unknown */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,compressed_size,4); - - if (err==ZIP_OK) /* uncompressed size, unknown */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,uncompressed_size,4); - } - - if (ZSEEK64(zi->z_filefunc,zi->filestream, cur_pos_inzip,ZLIB_FILEFUNC_SEEK_SET)!=0) - err = ZIP_ERRNO; - } - - zi->number_entry ++; - zi->in_opened_file_inzip = 0; - - return err; -} - -extern int ZEXPORT zipCloseFileInZip (zipFile file) -{ - return zipCloseFileInZipRaw (file,0,0); -} - -int Write_Zip64EndOfCentralDirectoryLocator(zip64_internal* zi, ZPOS64_T zip64eocd_pos_inzip) -{ - int err = ZIP_OK; - ZPOS64_T pos = zip64eocd_pos_inzip - zi->add_position_when_writting_offset; - - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)ZIP64ENDLOCHEADERMAGIC,4); - - /*num disks*/ - if (err==ZIP_OK) /* number of the disk with the start of the central directory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,4); - - /*relative offset*/ - if (err==ZIP_OK) /* Relative offset to the Zip64EndOfCentralDirectory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream, pos,8); - - /*total disks*/ /* Do not support spawning of disk so always say 1 here*/ - if (err==ZIP_OK) /* number of the disk with the start of the central directory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)1,4); - - return err; -} - -int Write_Zip64EndOfCentralDirectoryRecord(zip64_internal* zi, uLong size_centraldir, ZPOS64_T centraldir_pos_inzip) -{ - int err = ZIP_OK; - - uLong Zip64DataSize = 44; - - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)ZIP64ENDHEADERMAGIC,4); - - if (err==ZIP_OK) /* size of this 'zip64 end of central directory' */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(ZPOS64_T)Zip64DataSize,8); // why ZPOS64_T of this ? - - if (err==ZIP_OK) /* version made by */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)45,2); - - if (err==ZIP_OK) /* version needed */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)45,2); - - if (err==ZIP_OK) /* number of this disk */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,4); - - if (err==ZIP_OK) /* number of the disk with the start of the central directory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,4); - - if (err==ZIP_OK) /* total number of entries in the central dir on this disk */ - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, zi->number_entry, 8); - - if (err==ZIP_OK) /* total number of entries in the central dir */ - err = zip64local_putValue(&zi->z_filefunc, zi->filestream, zi->number_entry, 8); - - if (err==ZIP_OK) /* size of the central directory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(ZPOS64_T)size_centraldir,8); - - if (err==ZIP_OK) /* offset of start of central directory with respect to the starting disk number */ - { - ZPOS64_T pos = centraldir_pos_inzip - zi->add_position_when_writting_offset; - err = zip64local_putValue(&zi->z_filefunc,zi->filestream, (ZPOS64_T)pos,8); - } - return err; -} -int Write_EndOfCentralDirectoryRecord(zip64_internal* zi, uLong size_centraldir, ZPOS64_T centraldir_pos_inzip) -{ - int err = ZIP_OK; - - /*signature*/ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)ENDHEADERMAGIC,4); - - if (err==ZIP_OK) /* number of this disk */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,2); - - if (err==ZIP_OK) /* number of the disk with the start of the central directory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0,2); - - if (err==ZIP_OK) /* total number of entries in the central dir on this disk */ - { - { - if(zi->number_entry >= 0xFFFF) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0xffff,2); // use value in ZIP64 record - else - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)zi->number_entry,2); - } - } - - if (err==ZIP_OK) /* total number of entries in the central dir */ - { - if(zi->number_entry >= 0xFFFF) - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)0xffff,2); // use value in ZIP64 record - else - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)zi->number_entry,2); - } - - if (err==ZIP_OK) /* size of the central directory */ - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)size_centraldir,4); - - if (err==ZIP_OK) /* offset of start of central directory with respect to the starting disk number */ - { - ZPOS64_T pos = centraldir_pos_inzip - zi->add_position_when_writting_offset; - if(pos >= 0xffffffff) - { - err = zip64local_putValue(&zi->z_filefunc,zi->filestream, (uLong)0xffffffff,4); - } - else - err = zip64local_putValue(&zi->z_filefunc,zi->filestream, (uLong)(centraldir_pos_inzip - zi->add_position_when_writting_offset),4); - } - - return err; -} - -int Write_GlobalComment(zip64_internal* zi, const char* global_comment) -{ - int err = ZIP_OK; - uInt size_global_comment = 0; - - if(global_comment != NULL) - size_global_comment = (uInt)strlen(global_comment); - - err = zip64local_putValue(&zi->z_filefunc,zi->filestream,(uLong)size_global_comment,2); - - if (err == ZIP_OK && size_global_comment > 0) - { - if (ZWRITE64(zi->z_filefunc,zi->filestream, global_comment, size_global_comment) != size_global_comment) - err = ZIP_ERRNO; - } - return err; -} - -extern int ZEXPORT zipClose (zipFile file, const char* global_comment) -{ - zip64_internal* zi; - int err = 0; - uLong size_centraldir = 0; - ZPOS64_T centraldir_pos_inzip; - ZPOS64_T pos; - - if (file == NULL) - return ZIP_PARAMERROR; - - zi = (zip64_internal*)file; - - if (zi->in_opened_file_inzip == 1) - { - err = zipCloseFileInZip (file); - } - -#ifndef NO_ADDFILEINEXISTINGZIP - if (global_comment==NULL) - global_comment = zi->globalcomment; -#endif - - centraldir_pos_inzip = ZTELL64(zi->z_filefunc,zi->filestream); - - if (err==ZIP_OK) - { - linkedlist_datablock_internal* ldi = zi->central_dir.first_block; - while (ldi!=NULL) - { - if ((err==ZIP_OK) && (ldi->filled_in_this_block>0)) - { - if (ZWRITE64(zi->z_filefunc,zi->filestream, ldi->data, ldi->filled_in_this_block) != ldi->filled_in_this_block) - err = ZIP_ERRNO; - } - - size_centraldir += ldi->filled_in_this_block; - ldi = ldi->next_datablock; - } - } - free_linkedlist(&(zi->central_dir)); - - pos = centraldir_pos_inzip - zi->add_position_when_writting_offset; - if(pos >= 0xffffffff) - { - ZPOS64_T Zip64EOCDpos = ZTELL64(zi->z_filefunc,zi->filestream); - Write_Zip64EndOfCentralDirectoryRecord(zi, size_centraldir, centraldir_pos_inzip); - - Write_Zip64EndOfCentralDirectoryLocator(zi, Zip64EOCDpos); - } - - if (err==ZIP_OK) - err = Write_EndOfCentralDirectoryRecord(zi, size_centraldir, centraldir_pos_inzip); - - if(err == ZIP_OK) - err = Write_GlobalComment(zi, global_comment); - - if (ZCLOSE64(zi->z_filefunc,zi->filestream) != 0) - if (err == ZIP_OK) - err = ZIP_ERRNO; - -#ifndef NO_ADDFILEINEXISTINGZIP - TRYFREE(zi->globalcomment); -#endif - TRYFREE(zi); - - return err; -} - -extern int ZEXPORT zipRemoveExtraInfoBlock (char* pData, int* dataLen, short sHeader) -{ - char* p = pData; - int size = 0; - char* pNewHeader; - char* pTmp; - short header; - short dataSize; - - int retVal = ZIP_OK; - - if(pData == NULL || *dataLen < 4) - return ZIP_PARAMERROR; - - pNewHeader = (char*)ALLOC(*dataLen); - pTmp = pNewHeader; - - while(p < (pData + *dataLen)) - { - header = *(short*)p; - dataSize = *(((short*)p)+1); - - if( header == sHeader ) // Header found. - { - p += dataSize + 4; // skip it. do not copy to temp buffer - } - else - { - // Extra Info block should not be removed, So copy it to the temp buffer. - memcpy(pTmp, p, dataSize + 4); - p += dataSize + 4; - size += dataSize + 4; - } - - } - - if(size < *dataLen) - { - // clean old extra info block. - memset(pData,0, *dataLen); - - // copy the new extra info block over the old - if(size > 0) - memcpy(pData, pNewHeader, size); - - // set the new extra info size - *dataLen = size; - - retVal = ZIP_OK; - } - else - retVal = ZIP_ERRNO; - - TRYFREE(pNewHeader); - - return retVal; -} diff --git a/btgui/minizip/zip.h b/btgui/minizip/zip.h deleted file mode 100644 index 510907c5b..000000000 --- a/btgui/minizip/zip.h +++ /dev/null @@ -1,362 +0,0 @@ -/* zip.h -- IO on .zip files using zlib - Version 1.1, February 14h, 2010 - part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html ) - - Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html ) - - Modifications for Zip64 support - Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com ) - - For more info read MiniZip_info.txt - - --------------------------------------------------------------------------- - - Condition of use and distribution are the same than zlib : - - This software is provided 'as-is', without any express or implied - warranty. In no event will the authors be held liable for any damages - arising from the use of this software. - - Permission is granted to anyone to use this software for any purpose, - including commercial applications, and to alter it and redistribute it - freely, subject to the following restrictions: - - 1. The origin of this software must not be misrepresented; you must not - claim that you wrote the original software. If you use this software - in a product, an acknowledgment in the product documentation would be - appreciated but is not required. - 2. Altered source versions must be plainly marked as such, and must not be - misrepresented as being the original software. - 3. This notice may not be removed or altered from any source distribution. - - --------------------------------------------------------------------------- - - Changes - - See header of zip.h - -*/ - -#ifndef _zip12_H -#define _zip12_H - -#ifdef __cplusplus -extern "C" { -#endif - -//#define HAVE_BZIP2 - -#ifndef _ZLIB_H -#include "../zlib/zlib.h" -#endif - -#ifndef _ZLIBIOAPI_H -#include "ioapi.h" -#endif - -#ifdef HAVE_BZIP2 -#include "bzlib.h" -#endif - -#define Z_BZIP2ED 12 - -#if defined(STRICTZIP) || defined(STRICTZIPUNZIP) -/* like the STRICT of WIN32, we define a pointer that cannot be converted - from (void*) without cast */ -typedef struct TagzipFile__ { int unused; } zipFile__; -typedef zipFile__ *zipFile; -#else -typedef voidp zipFile; -#endif - -#define ZIP_OK (0) -#define ZIP_EOF (0) -#define ZIP_ERRNO (Z_ERRNO) -#define ZIP_PARAMERROR (-102) -#define ZIP_BADZIPFILE (-103) -#define ZIP_INTERNALERROR (-104) - -#ifndef DEF_MEM_LEVEL -# if MAX_MEM_LEVEL >= 8 -# define DEF_MEM_LEVEL 8 -# else -# define DEF_MEM_LEVEL MAX_MEM_LEVEL -# endif -#endif -/* default memLevel */ - -/* tm_zip contain date/time info */ -typedef struct tm_zip_s -{ - uInt tm_sec; /* seconds after the minute - [0,59] */ - uInt tm_min; /* minutes after the hour - [0,59] */ - uInt tm_hour; /* hours since midnight - [0,23] */ - uInt tm_mday; /* day of the month - [1,31] */ - uInt tm_mon; /* months since January - [0,11] */ - uInt tm_year; /* years - [1980..2044] */ -} tm_zip; - -typedef struct -{ - tm_zip tmz_date; /* date in understandable format */ - uLong dosDate; /* if dos_date == 0, tmu_date is used */ -/* uLong flag; */ /* general purpose bit flag 2 bytes */ - - uLong internal_fa; /* internal file attributes 2 bytes */ - uLong external_fa; /* external file attributes 4 bytes */ -} zip_fileinfo; - -typedef const char* zipcharpc; - - -#define APPEND_STATUS_CREATE (0) -#define APPEND_STATUS_CREATEAFTER (1) -#define APPEND_STATUS_ADDINZIP (2) - -extern zipFile ZEXPORT zipOpen OF((const char *pathname, int append)); -extern zipFile ZEXPORT zipOpen64 OF((const void *pathname, int append)); -/* - Create a zipfile. - pathname contain on Windows XP a filename like "c:\\zlib\\zlib113.zip" or on - an Unix computer "zlib/zlib113.zip". - if the file pathname exist and append==APPEND_STATUS_CREATEAFTER, the zip - will be created at the end of the file. - (useful if the file contain a self extractor code) - if the file pathname exist and append==APPEND_STATUS_ADDINZIP, we will - add files in existing zip (be sure you don't add file that doesn't exist) - If the zipfile cannot be opened, the return value is NULL. - Else, the return value is a zipFile Handle, usable with other function - of this zip package. -*/ - -/* Note : there is no delete function into a zipfile. - If you want delete file into a zipfile, you must open a zipfile, and create another - Of couse, you can use RAW reading and writing to copy the file you did not want delte -*/ - -extern zipFile ZEXPORT zipOpen2 OF((const char *pathname, - int append, - zipcharpc* globalcomment, - zlib_filefunc_def* pzlib_filefunc_def)); - -extern zipFile ZEXPORT zipOpen2_64 OF((const void *pathname, - int append, - zipcharpc* globalcomment, - zlib_filefunc64_def* pzlib_filefunc_def)); - -extern int ZEXPORT zipOpenNewFileInZip OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level)); - -extern int ZEXPORT zipOpenNewFileInZip64 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int zip64)); - -/* - Open a file in the ZIP for writing. - filename : the filename in zip (if NULL, '-' without quote will be used - *zipfi contain supplemental information - if extrafield_local!=NULL and size_extrafield_local>0, extrafield_local - contains the extrafield data the the local header - if extrafield_global!=NULL and size_extrafield_global>0, extrafield_global - contains the extrafield data the the local header - if comment != NULL, comment contain the comment string - method contain the compression method (0 for store, Z_DEFLATED for deflate) - level contain the level of compression (can be Z_DEFAULT_COMPRESSION) - zip64 is set to 1 if a zip64 extended information block should be added to the local file header. - this MUST be '1' if the uncompressed size is >= 0xffffffff. - -*/ - - -extern int ZEXPORT zipOpenNewFileInZip2 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int raw)); - - -extern int ZEXPORT zipOpenNewFileInZip2_64 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int raw, - int zip64)); -/* - Same than zipOpenNewFileInZip, except if raw=1, we write raw file - */ - -extern int ZEXPORT zipOpenNewFileInZip3 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int raw, - int windowBits, - int memLevel, - int strategy, - const char* password, - uLong crcForCrypting)); - -extern int ZEXPORT zipOpenNewFileInZip3_64 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int raw, - int windowBits, - int memLevel, - int strategy, - const char* password, - uLong crcForCrypting, - int zip64 - )); - -/* - Same than zipOpenNewFileInZip2, except - windowBits,memLevel,,strategy : see parameter strategy in deflateInit2 - password : crypting password (NULL for no crypting) - crcForCrypting : crc of file to compress (needed for crypting) - */ - -extern int ZEXPORT zipOpenNewFileInZip4 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int raw, - int windowBits, - int memLevel, - int strategy, - const char* password, - uLong crcForCrypting, - uLong versionMadeBy, - uLong flagBase - )); - - -extern int ZEXPORT zipOpenNewFileInZip4_64 OF((zipFile file, - const char* filename, - const zip_fileinfo* zipfi, - const void* extrafield_local, - uInt size_extrafield_local, - const void* extrafield_global, - uInt size_extrafield_global, - const char* comment, - int method, - int level, - int raw, - int windowBits, - int memLevel, - int strategy, - const char* password, - uLong crcForCrypting, - uLong versionMadeBy, - uLong flagBase, - int zip64 - )); -/* - Same than zipOpenNewFileInZip4, except - versionMadeBy : value for Version made by field - flag : value for flag field (compression level info will be added) - */ - - -extern int ZEXPORT zipWriteInFileInZip OF((zipFile file, - const void* buf, - unsigned len)); -/* - Write data in the zipfile -*/ - -extern int ZEXPORT zipCloseFileInZip OF((zipFile file)); -/* - Close the current file in the zipfile -*/ - -extern int ZEXPORT zipCloseFileInZipRaw OF((zipFile file, - uLong uncompressed_size, - uLong crc32)); - -extern int ZEXPORT zipCloseFileInZipRaw64 OF((zipFile file, - ZPOS64_T uncompressed_size, - uLong crc32)); - -/* - Close the current file in the zipfile, for file opened with - parameter raw=1 in zipOpenNewFileInZip2 - uncompressed_size and crc32 are value for the uncompressed size -*/ - -extern int ZEXPORT zipClose OF((zipFile file, - const char* global_comment)); -/* - Close the zipfile -*/ - - -extern int ZEXPORT zipRemoveExtraInfoBlock OF((char* pData, int* dataLen, short sHeader)); -/* - zipRemoveExtraInfoBlock - Added by Mathias Svensson - - Remove extra information block from a extra information data for the local file header or central directory header - - It is needed to remove ZIP64 extra information blocks when before data is written if using RAW mode. - - 0x0001 is the signature header for the ZIP64 extra information blocks - - usage. - Remove ZIP64 Extra information from a central director extra field data - zipRemoveExtraInfoBlock(pCenDirExtraFieldData, &nCenDirExtraFieldDataLen, 0x0001); - - Remove ZIP64 Extra information from a Local File Header extra field data - zipRemoveExtraInfoBlock(pLocalHeaderExtraFieldData, &nLocalHeaderExtraFieldDataLen, 0x0001); -*/ - -#ifdef __cplusplus -} -#endif - -#endif /* _zip64_H */ diff --git a/btgui/stb_image/stb_image.cpp b/btgui/stb_image/stb_image.cpp deleted file mode 100644 index 226d7a8c8..000000000 --- a/btgui/stb_image/stb_image.cpp +++ /dev/null @@ -1,4341 +0,0 @@ -#include "stb_image.h" - -#ifndef STBI_HEADER_FILE_ONLY - -#ifndef STBI_NO_HDR -#include // ldexp -#include // strcmp, strtok -#endif - -#ifndef STBI_NO_STDIO -#include -#endif -#include -#include -#include -#include - -#ifndef _MSC_VER - #ifdef __cplusplus - #define stbi_inline inline - #else - #define stbi_inline - #endif -#else - #define stbi_inline __forceinline -#endif - - -// implementation: -typedef unsigned char uint8; -typedef unsigned short uint16; -typedef signed short int16; -typedef unsigned int uint32; -typedef signed int int32; -typedef unsigned int uint; - -// should produce compiler error if size is wrong -typedef unsigned char validate_uint32[sizeof(uint32)==4 ? 1 : -1]; - -#if defined(STBI_NO_STDIO) && !defined(STBI_NO_WRITE) -#define STBI_NO_WRITE -#endif - -#define STBI_NOTUSED(v) (void)sizeof(v) - -#ifdef _MSC_VER -#define STBI_HAS_LROTL -#endif - -#ifdef STBI_HAS_LROTL - #define stbi_lrot(x,y) _lrotl(x,y) -#else - #define stbi_lrot(x,y) (((x) << (y)) | ((x) >> (32 - (y)))) -#endif - -/////////////////////////////////////////////// -// -// stbi struct and start_xxx functions - -// stbi structure is our basic context used by all images, so it -// contains all the IO context, plus some basic image information -typedef struct -{ - uint32 img_x, img_y; - int img_n, img_out_n; - - stbi_io_callbacks io; - void *io_user_data; - - int read_from_callbacks; - int buflen; - uint8 buffer_start[128]; - - uint8 *img_buffer, *img_buffer_end; - uint8 *img_buffer_original; -} stbi; - - -static void refill_buffer(stbi *s); - -// initialize a memory-decode context -static void start_mem(stbi *s, uint8 const *buffer, int len) -{ - s->io.read = NULL; - s->read_from_callbacks = 0; - s->img_buffer = s->img_buffer_original = (uint8 *) buffer; - s->img_buffer_end = (uint8 *) buffer+len; -} - -// initialize a callback-based context -static void start_callbacks(stbi *s, stbi_io_callbacks *c, void *user) -{ - s->io = *c; - s->io_user_data = user; - s->buflen = sizeof(s->buffer_start); - s->read_from_callbacks = 1; - s->img_buffer_original = s->buffer_start; - refill_buffer(s); -} - -#ifndef STBI_NO_STDIO - -static int stdio_read(void *user, char *data, int size) -{ - return (int) fread(data,1,size,(FILE*) user); -} - -static void stdio_skip(void *user, unsigned n) -{ - fseek((FILE*) user, n, SEEK_CUR); -} - -static int stdio_eof(void *user) -{ - return feof((FILE*) user); -} - -static stbi_io_callbacks stbi_stdio_callbacks = -{ - stdio_read, - stdio_skip, - stdio_eof, -}; - -static void start_file(stbi *s, FILE *f) -{ - start_callbacks(s, &stbi_stdio_callbacks, (void *) f); -} - -//static void stop_file(stbi *s) { } - -#endif // !STBI_NO_STDIO - -static void stbi_rewind(stbi *s) -{ - // conceptually rewind SHOULD rewind to the beginning of the stream, - // but we just rewind to the beginning of the initial buffer, because - // we only use it after doing 'test', which only ever looks at at most 92 bytes - s->img_buffer = s->img_buffer_original; -} - -static int stbi_jpeg_test(stbi *s); -static stbi_uc *stbi_jpeg_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_jpeg_info(stbi *s, int *x, int *y, int *comp); -static int stbi_png_test(stbi *s); -static stbi_uc *stbi_png_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_png_info(stbi *s, int *x, int *y, int *comp); -static int stbi_bmp_test(stbi *s); -static stbi_uc *stbi_bmp_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_tga_test(stbi *s); -static stbi_uc *stbi_tga_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_tga_info(stbi *s, int *x, int *y, int *comp); -static int stbi_psd_test(stbi *s); -static stbi_uc *stbi_psd_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_hdr_test(stbi *s); -static float *stbi_hdr_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_pic_test(stbi *s); -static stbi_uc *stbi_pic_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_gif_test(stbi *s); -static stbi_uc *stbi_gif_load(stbi *s, int *x, int *y, int *comp, int req_comp); -static int stbi_gif_info(stbi *s, int *x, int *y, int *comp); - - -// this is not threadsafe -static const char *failure_reason; - -const char *stbi_failure_reason(void) -{ - return failure_reason; -} - -static int e(const char *str) -{ - failure_reason = str; - return 0; -} - -// e - error -// epf - error returning pointer to float -// epuc - error returning pointer to unsigned char - -#ifdef STBI_NO_FAILURE_STRINGS - #define e(x,y) 0 -#elif defined(STBI_FAILURE_USERMSG) - #define e(x,y) e(y) -#else - #define e(x,y) e(x) -#endif - -#define epf(x,y) ((float *) (e(x,y)?NULL:NULL)) -#define epuc(x,y) ((unsigned char *) (e(x,y)?NULL:NULL)) - -void stbi_image_free(void *retval_from_stbi_load) -{ - free(retval_from_stbi_load); -} - -#ifndef STBI_NO_HDR -static float *ldr_to_hdr(stbi_uc *data, int x, int y, int comp); -static stbi_uc *hdr_to_ldr(float *data, int x, int y, int comp); -#endif - -static unsigned char *stbi_load_main(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - if (stbi_jpeg_test(s)) return stbi_jpeg_load(s,x,y,comp,req_comp); - if (stbi_png_test(s)) return stbi_png_load(s,x,y,comp,req_comp); - if (stbi_bmp_test(s)) return stbi_bmp_load(s,x,y,comp,req_comp); - if (stbi_gif_test(s)) return stbi_gif_load(s,x,y,comp,req_comp); - if (stbi_psd_test(s)) return stbi_psd_load(s,x,y,comp,req_comp); - if (stbi_pic_test(s)) return stbi_pic_load(s,x,y,comp,req_comp); - - #ifndef STBI_NO_HDR - if (stbi_hdr_test(s)) { - float *hdr = stbi_hdr_load(s, x,y,comp,req_comp); - return hdr_to_ldr(hdr, *x, *y, req_comp ? req_comp : *comp); - } - #endif - - // test tga last because it's a crappy test! - if (stbi_tga_test(s)) - return stbi_tga_load(s,x,y,comp,req_comp); - return epuc("unknown image type", "Image not of any known type, or corrupt"); -} - -#ifndef STBI_NO_STDIO -unsigned char *stbi_load(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - FILE *f = fopen(filename, "rb"); - unsigned char *result; - if (!f) return epuc("can't fopen", "Unable to open file"); - result = stbi_load_from_file(f,x,y,comp,req_comp); - fclose(f); - return result; -} - -unsigned char *stbi_load_from_file(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_file(&s,f); - return stbi_load_main(&s,x,y,comp,req_comp); -} -#endif //!STBI_NO_STDIO - -unsigned char *stbi_load_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_mem(&s,buffer,len); - return stbi_load_main(&s,x,y,comp,req_comp); -} - -unsigned char *stbi_load_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi_load_main(&s,x,y,comp,req_comp); -} - -#ifndef STBI_NO_HDR - -float *stbi_loadf_main(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - unsigned char *data; - #ifndef STBI_NO_HDR - if (stbi_hdr_test(s)) - return stbi_hdr_load(s,x,y,comp,req_comp); - #endif - data = stbi_load_main(s, x, y, comp, req_comp); - if (data) - return ldr_to_hdr(data, *x, *y, req_comp ? req_comp : *comp); - return epf("unknown image type", "Image not of any known type, or corrupt"); -} - -float *stbi_loadf_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_mem(&s,buffer,len); - return stbi_loadf_main(&s,x,y,comp,req_comp); -} - -float *stbi_loadf_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi_loadf_main(&s,x,y,comp,req_comp); -} - -#ifndef STBI_NO_STDIO -float *stbi_loadf(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - FILE *f = fopen(filename, "rb"); - float *result; - if (!f) return epf("can't fopen", "Unable to open file"); - result = stbi_loadf_from_file(f,x,y,comp,req_comp); - fclose(f); - return result; -} - -float *stbi_loadf_from_file(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - stbi s; - start_file(&s,f); - return stbi_loadf_main(&s,x,y,comp,req_comp); -} -#endif // !STBI_NO_STDIO - -#endif // !STBI_NO_HDR - -// these is-hdr-or-not is defined independent of whether STBI_NO_HDR is -// defined, for API simplicity; if STBI_NO_HDR is defined, it always -// reports false! - -int stbi_is_hdr_from_memory(stbi_uc const *buffer, int len) -{ - #ifndef STBI_NO_HDR - stbi s; - start_mem(&s,buffer,len); - return stbi_hdr_test(&s); - #else - STBI_NOTUSED(buffer); - STBI_NOTUSED(len); - return 0; - #endif -} - -#ifndef STBI_NO_STDIO -extern int stbi_is_hdr (char const *filename) -{ - FILE *f = fopen(filename, "rb"); - int result=0; - if (f) { - result = stbi_is_hdr_from_file(f); - fclose(f); - } - return result; -} - -extern int stbi_is_hdr_from_file(FILE *f) -{ - #ifndef STBI_NO_HDR - stbi s; - start_file(&s,f); - return stbi_hdr_test(&s); - #else - return 0; - #endif -} -#endif // !STBI_NO_STDIO - -extern int stbi_is_hdr_from_callbacks(stbi_io_callbacks const *clbk, void *user) -{ - #ifndef STBI_NO_HDR - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi_hdr_test(&s); - #else - return 0; - #endif -} - -#ifndef STBI_NO_HDR -static float h2l_gamma_i=1.0f/2.2f, h2l_scale_i=1.0f; -static float l2h_gamma=2.2f, l2h_scale=1.0f; - -void stbi_hdr_to_ldr_gamma(float gamma) { h2l_gamma_i = 1/gamma; } -void stbi_hdr_to_ldr_scale(float scale) { h2l_scale_i = 1/scale; } - -void stbi_ldr_to_hdr_gamma(float gamma) { l2h_gamma = gamma; } -void stbi_ldr_to_hdr_scale(float scale) { l2h_scale = scale; } -#endif - - -////////////////////////////////////////////////////////////////////////////// -// -// Common code used by all image loaders -// - -enum -{ - SCAN_load=0, - SCAN_type, - SCAN_header -}; - -static void refill_buffer(stbi *s) -{ - int n = (s->io.read)(s->io_user_data,(char*)s->buffer_start,s->buflen); - if (n == 0) { - // at end of file, treat same as if from memory - s->read_from_callbacks = 0; - s->img_buffer = s->img_buffer_end-1; - *s->img_buffer = 0; - } else { - s->img_buffer = s->buffer_start; - s->img_buffer_end = s->buffer_start + n; - } -} - -stbi_inline static int get8(stbi *s) -{ - if (s->img_buffer < s->img_buffer_end) - return *s->img_buffer++; - if (s->read_from_callbacks) { - refill_buffer(s); - return *s->img_buffer++; - } - return 0; -} - -stbi_inline static int at_eof(stbi *s) -{ - if (s->io.read) { - if (!(s->io.eof)(s->io_user_data)) return 0; - // if feof() is true, check if buffer = end - // special case: we've only got the special 0 character at the end - if (s->read_from_callbacks == 0) return 1; - } - - return s->img_buffer >= s->img_buffer_end; -} - -stbi_inline static uint8 get8u(stbi *s) -{ - return (uint8) get8(s); -} - -static void skip(stbi *s, int n) -{ - if (s->io.read) { - int blen = s->img_buffer_end - s->img_buffer; - if (blen < n) { - s->img_buffer = s->img_buffer_end; - (s->io.skip)(s->io_user_data, n - blen); - return; - } - } - s->img_buffer += n; -} - -static int getn(stbi *s, stbi_uc *buffer, int n) -{ - if (s->io.read) { - int blen = s->img_buffer_end - s->img_buffer; - if (blen < n) { - int res, count; - - memcpy(buffer, s->img_buffer, blen); - - count = (s->io.read)(s->io_user_data, (char*) buffer + blen, n - blen); - res = (count == (n-blen)); - s->img_buffer = s->img_buffer_end; - return res; - } - } - - if (s->img_buffer+n <= s->img_buffer_end) { - memcpy(buffer, s->img_buffer, n); - s->img_buffer += n; - return 1; - } else - return 0; -} - -static int get16(stbi *s) -{ - int z = get8(s); - return (z << 8) + get8(s); -} - -static uint32 get32(stbi *s) -{ - uint32 z = get16(s); - return (z << 16) + get16(s); -} - -static int get16le(stbi *s) -{ - int z = get8(s); - return z + (get8(s) << 8); -} - -static uint32 get32le(stbi *s) -{ - uint32 z = get16le(s); - return z + (get16le(s) << 16); -} - -////////////////////////////////////////////////////////////////////////////// -// -// generic converter from built-in img_n to req_comp -// individual types do this automatically as much as possible (e.g. jpeg -// does all cases internally since it needs to colorspace convert anyway, -// and it never has alpha, so very few cases ). png can automatically -// interleave an alpha=255 channel, but falls back to this for other cases -// -// assume data buffer is malloced, so malloc a new one and free that one -// only failure mode is malloc failing - -static uint8 compute_y(int r, int g, int b) -{ - return (uint8) (((r*77) + (g*150) + (29*b)) >> 8); -} - -static unsigned char *convert_format(unsigned char *data, int img_n, int req_comp, uint x, uint y) -{ - int i,j; - unsigned char *good; - - if (req_comp == img_n) return data; - assert(req_comp >= 1 && req_comp <= 4); - - good = (unsigned char *) malloc(req_comp * x * y); - if (good == NULL) { - free(data); - return epuc("outofmem", "Out of memory"); - } - - for (j=0; j < (int) y; ++j) { - unsigned char *src = data + j * x * img_n ; - unsigned char *dest = good + j * x * req_comp; - - #define COMBO(a,b) ((a)*8+(b)) - #define CASE(a,b) case COMBO(a,b): for(i=x-1; i >= 0; --i, src += a, dest += b) - // convert source image with img_n components to one with req_comp components; - // avoid switch per pixel, so use switch per scanline and massive macros - switch (COMBO(img_n, req_comp)) { - CASE(1,2) dest[0]=src[0], dest[1]=255; break; - CASE(1,3) dest[0]=dest[1]=dest[2]=src[0]; break; - CASE(1,4) dest[0]=dest[1]=dest[2]=src[0], dest[3]=255; break; - CASE(2,1) dest[0]=src[0]; break; - CASE(2,3) dest[0]=dest[1]=dest[2]=src[0]; break; - CASE(2,4) dest[0]=dest[1]=dest[2]=src[0], dest[3]=src[1]; break; - CASE(3,4) dest[0]=src[0],dest[1]=src[1],dest[2]=src[2],dest[3]=255; break; - CASE(3,1) dest[0]=compute_y(src[0],src[1],src[2]); break; - CASE(3,2) dest[0]=compute_y(src[0],src[1],src[2]), dest[1] = 255; break; - CASE(4,1) dest[0]=compute_y(src[0],src[1],src[2]); break; - CASE(4,2) dest[0]=compute_y(src[0],src[1],src[2]), dest[1] = src[3]; break; - CASE(4,3) dest[0]=src[0],dest[1]=src[1],dest[2]=src[2]; break; - default: assert(0); - } - #undef CASE - } - - free(data); - return good; -} - -#ifndef STBI_NO_HDR -static float *ldr_to_hdr(stbi_uc *data, int x, int y, int comp) -{ - int i,k,n; - float *output = (float *) malloc(x * y * comp * sizeof(float)); - if (output == NULL) { free(data); return epf("outofmem", "Out of memory"); } - // compute number of non-alpha components - if (comp & 1) n = comp; else n = comp-1; - for (i=0; i < x*y; ++i) { - for (k=0; k < n; ++k) { - output[i*comp + k] = (float) pow(data[i*comp+k]/255.0f, l2h_gamma) * l2h_scale; - } - if (k < comp) output[i*comp + k] = data[i*comp+k]/255.0f; - } - free(data); - return output; -} - -#define float2int(x) ((int) (x)) -static stbi_uc *hdr_to_ldr(float *data, int x, int y, int comp) -{ - int i,k,n; - stbi_uc *output = (stbi_uc *) malloc(x * y * comp); - if (output == NULL) { free(data); return epuc("outofmem", "Out of memory"); } - // compute number of non-alpha components - if (comp & 1) n = comp; else n = comp-1; - for (i=0; i < x*y; ++i) { - for (k=0; k < n; ++k) { - float z = (float) pow(data[i*comp+k]*h2l_scale_i, h2l_gamma_i) * 255 + 0.5f; - if (z < 0) z = 0; - if (z > 255) z = 255; - output[i*comp + k] = (uint8) float2int(z); - } - if (k < comp) { - float z = data[i*comp+k] * 255 + 0.5f; - if (z < 0) z = 0; - if (z > 255) z = 255; - output[i*comp + k] = (uint8) float2int(z); - } - } - free(data); - return output; -} -#endif - -////////////////////////////////////////////////////////////////////////////// -// -// "baseline" JPEG/JFIF decoder (not actually fully baseline implementation) -// -// simple implementation -// - channel subsampling of at most 2 in each dimension -// - doesn't support delayed output of y-dimension -// - simple interface (only one output format: 8-bit interleaved RGB) -// - doesn't try to recover corrupt jpegs -// - doesn't allow partial loading, loading multiple at once -// - still fast on x86 (copying globals into locals doesn't help x86) -// - allocates lots of intermediate memory (full size of all components) -// - non-interleaved case requires this anyway -// - allows good upsampling (see next) -// high-quality -// - upsampled channels are bilinearly interpolated, even across blocks -// - quality integer IDCT derived from IJG's 'slow' -// performance -// - fast huffman; reasonable integer IDCT -// - uses a lot of intermediate memory, could cache poorly -// - load http://nothings.org/remote/anemones.jpg 3 times on 2.8Ghz P4 -// stb_jpeg: 1.34 seconds (MSVC6, default release build) -// stb_jpeg: 1.06 seconds (MSVC6, processor = Pentium Pro) -// IJL11.dll: 1.08 seconds (compiled by intel) -// IJG 1998: 0.98 seconds (MSVC6, makefile provided by IJG) -// IJG 1998: 0.95 seconds (MSVC6, makefile + proc=PPro) - -// huffman decoding acceleration -#define FAST_BITS 9 // larger handles more cases; smaller stomps less cache - -typedef struct -{ - uint8 fast[1 << FAST_BITS]; - // weirdly, repacking this into AoS is a 10% speed loss, instead of a win - uint16 code[256]; - uint8 values[256]; - uint8 size[257]; - unsigned int maxcode[18]; - int delta[17]; // old 'firstsymbol' - old 'firstcode' -} huffman; - -typedef struct -{ - #ifdef STBI_SIMD - unsigned short dequant2[4][64]; - #endif - stbi *s; - huffman huff_dc[4]; - huffman huff_ac[4]; - uint8 dequant[4][64]; - -// sizes for components, interleaved MCUs - int img_h_max, img_v_max; - int img_mcu_x, img_mcu_y; - int img_mcu_w, img_mcu_h; - -// definition of jpeg image component - struct - { - int id; - int h,v; - int tq; - int hd,ha; - int dc_pred; - - int x,y,w2,h2; - uint8 *data; - void *raw_data; - uint8 *linebuf; - } img_comp[4]; - - uint32 code_buffer; // jpeg entropy-coded buffer - int code_bits; // number of valid bits - unsigned char marker; // marker seen while filling entropy buffer - int nomore; // flag if we saw a marker so must stop - - int scan_n, order[4]; - int restart_interval, todo; -} jpeg; - -static int build_huffman(huffman *h, int *count) -{ - int i,j,k=0,code; - // build size list for each symbol (from JPEG spec) - for (i=0; i < 16; ++i) - for (j=0; j < count[i]; ++j) - h->size[k++] = (uint8) (i+1); - h->size[k] = 0; - - // compute actual symbols (from jpeg spec) - code = 0; - k = 0; - for(j=1; j <= 16; ++j) { - // compute delta to add to code to compute symbol id - h->delta[j] = k - code; - if (h->size[k] == j) { - while (h->size[k] == j) - h->code[k++] = (uint16) (code++); - if (code-1 >= (1 << j)) return e("bad code lengths","Corrupt JPEG"); - } - // compute largest code + 1 for this size, preshifted as needed later - h->maxcode[j] = code << (16-j); - code <<= 1; - } - h->maxcode[j] = 0xffffffff; - - // build non-spec acceleration table; 255 is flag for not-accelerated - memset(h->fast, 255, 1 << FAST_BITS); - for (i=0; i < k; ++i) { - int s = h->size[i]; - if (s <= FAST_BITS) { - int c = h->code[i] << (FAST_BITS-s); - int m = 1 << (FAST_BITS-s); - for (j=0; j < m; ++j) { - h->fast[c+j] = (uint8) i; - } - } - } - return 1; -} - -static void grow_buffer_unsafe(jpeg *j) -{ - do { - int b = j->nomore ? 0 : get8(j->s); - if (b == 0xff) { - int c = get8(j->s); - if (c != 0) { - j->marker = (unsigned char) c; - j->nomore = 1; - return; - } - } - j->code_buffer |= b << (24 - j->code_bits); - j->code_bits += 8; - } while (j->code_bits <= 24); -} - -// (1 << n) - 1 -static uint32 bmask[17]={0,1,3,7,15,31,63,127,255,511,1023,2047,4095,8191,16383,32767,65535}; - -// decode a jpeg huffman value from the bitstream -stbi_inline static int decode(jpeg *j, huffman *h) -{ - unsigned int temp; - int c,k; - - if (j->code_bits < 16) grow_buffer_unsafe(j); - - // look at the top FAST_BITS and determine what symbol ID it is, - // if the code is <= FAST_BITS - c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS)-1); - k = h->fast[c]; - if (k < 255) { - int s = h->size[k]; - if (s > j->code_bits) - return -1; - j->code_buffer <<= s; - j->code_bits -= s; - return h->values[k]; - } - - // naive test is to shift the code_buffer down so k bits are - // valid, then test against maxcode. To speed this up, we've - // preshifted maxcode left so that it has (16-k) 0s at the - // end; in other words, regardless of the number of bits, it - // wants to be compared against something shifted to have 16; - // that way we don't need to shift inside the loop. - temp = j->code_buffer >> 16; - for (k=FAST_BITS+1 ; ; ++k) - if (temp < h->maxcode[k]) - break; - if (k == 17) { - // error! code not found - j->code_bits -= 16; - return -1; - } - - if (k > j->code_bits) - return -1; - - // convert the huffman code to the symbol id - c = ((j->code_buffer >> (32 - k)) & bmask[k]) + h->delta[k]; - assert((((j->code_buffer) >> (32 - h->size[c])) & bmask[h->size[c]]) == h->code[c]); - - // convert the id to a symbol - j->code_bits -= k; - j->code_buffer <<= k; - return h->values[c]; -} - -// combined JPEG 'receive' and JPEG 'extend', since baseline -// always extends everything it receives. -stbi_inline static int extend_receive(jpeg *j, int n) -{ - unsigned int m = 1 << (n-1); - unsigned int k; - if (j->code_bits < n) grow_buffer_unsafe(j); - - #if 1 - k = stbi_lrot(j->code_buffer, n); - j->code_buffer = k & ~bmask[n]; - k &= bmask[n]; - j->code_bits -= n; - #else - k = (j->code_buffer >> (32 - n)) & bmask[n]; - j->code_bits -= n; - j->code_buffer <<= n; - #endif - // the following test is probably a random branch that won't - // predict well. I tried to table accelerate it but failed. - // maybe it's compiling as a conditional move? - if (k < m) - return (-1 << n) + k + 1; - else - return k; -} - -// given a value that's at position X in the zigzag stream, -// where does it appear in the 8x8 matrix coded as row-major? -static uint8 dezigzag[64+15] = -{ - 0, 1, 8, 16, 9, 2, 3, 10, - 17, 24, 32, 25, 18, 11, 4, 5, - 12, 19, 26, 33, 40, 48, 41, 34, - 27, 20, 13, 6, 7, 14, 21, 28, - 35, 42, 49, 56, 57, 50, 43, 36, - 29, 22, 15, 23, 30, 37, 44, 51, - 58, 59, 52, 45, 38, 31, 39, 46, - 53, 60, 61, 54, 47, 55, 62, 63, - // let corrupt input sample past end - 63, 63, 63, 63, 63, 63, 63, 63, - 63, 63, 63, 63, 63, 63, 63 -}; - -// decode one 64-entry block-- -static int decode_block(jpeg *j, short data[64], huffman *hdc, huffman *hac, int b) -{ - int diff,dc,k; - int t = decode(j, hdc); - if (t < 0) return e("bad huffman code","Corrupt JPEG"); - - // 0 all the ac values now so we can do it 32-bits at a time - memset(data,0,64*sizeof(data[0])); - - diff = t ? extend_receive(j, t) : 0; - dc = j->img_comp[b].dc_pred + diff; - j->img_comp[b].dc_pred = dc; - data[0] = (short) dc; - - // decode AC components, see JPEG spec - k = 1; - do { - int r,s; - int rs = decode(j, hac); - if (rs < 0) return e("bad huffman code","Corrupt JPEG"); - s = rs & 15; - r = rs >> 4; - if (s == 0) { - if (rs != 0xf0) break; // end block - k += 16; - } else { - k += r; - // decode into unzigzag'd location - data[dezigzag[k++]] = (short) extend_receive(j,s); - } - } while (k < 64); - return 1; -} - -// take a -128..127 value and clamp it and convert to 0..255 -stbi_inline static uint8 clamp(int x) -{ - // trick to use a single test to catch both cases - if ((unsigned int) x > 255) { - if (x < 0) return 0; - if (x > 255) return 255; - } - return (uint8) x; -} - -#define f2f(x) (int) (((x) * 4096 + 0.5)) -#define fsh(x) ((x) << 12) - -// derived from jidctint -- DCT_ISLOW -#define IDCT_1D(s0,s1,s2,s3,s4,s5,s6,s7) \ - int t0,t1,t2,t3,p1,p2,p3,p4,p5,x0,x1,x2,x3; \ - p2 = s2; \ - p3 = s6; \ - p1 = (p2+p3) * f2f(0.5411961f); \ - t2 = p1 + p3*f2f(-1.847759065f); \ - t3 = p1 + p2*f2f( 0.765366865f); \ - p2 = s0; \ - p3 = s4; \ - t0 = fsh(p2+p3); \ - t1 = fsh(p2-p3); \ - x0 = t0+t3; \ - x3 = t0-t3; \ - x1 = t1+t2; \ - x2 = t1-t2; \ - t0 = s7; \ - t1 = s5; \ - t2 = s3; \ - t3 = s1; \ - p3 = t0+t2; \ - p4 = t1+t3; \ - p1 = t0+t3; \ - p2 = t1+t2; \ - p5 = (p3+p4)*f2f( 1.175875602f); \ - t0 = t0*f2f( 0.298631336f); \ - t1 = t1*f2f( 2.053119869f); \ - t2 = t2*f2f( 3.072711026f); \ - t3 = t3*f2f( 1.501321110f); \ - p1 = p5 + p1*f2f(-0.899976223f); \ - p2 = p5 + p2*f2f(-2.562915447f); \ - p3 = p3*f2f(-1.961570560f); \ - p4 = p4*f2f(-0.390180644f); \ - t3 += p1+p4; \ - t2 += p2+p3; \ - t1 += p2+p4; \ - t0 += p1+p3; - -#ifdef STBI_SIMD -typedef unsigned short stbi_dequantize_t; -#else -typedef uint8 stbi_dequantize_t; -#endif - -// .344 seconds on 3*anemones.jpg -static void idct_block(uint8 *out, int out_stride, short data[64], stbi_dequantize_t *dequantize) -{ - int i,val[64],*v=val; - stbi_dequantize_t *dq = dequantize; - uint8 *o; - short *d = data; - - // columns - for (i=0; i < 8; ++i,++d,++dq, ++v) { - // if all zeroes, shortcut -- this avoids dequantizing 0s and IDCTing - if (d[ 8]==0 && d[16]==0 && d[24]==0 && d[32]==0 - && d[40]==0 && d[48]==0 && d[56]==0) { - // no shortcut 0 seconds - // (1|2|3|4|5|6|7)==0 0 seconds - // all separate -0.047 seconds - // 1 && 2|3 && 4|5 && 6|7: -0.047 seconds - int dcterm = d[0] * dq[0] << 2; - v[0] = v[8] = v[16] = v[24] = v[32] = v[40] = v[48] = v[56] = dcterm; - } else { - IDCT_1D(d[ 0]*dq[ 0],d[ 8]*dq[ 8],d[16]*dq[16],d[24]*dq[24], - d[32]*dq[32],d[40]*dq[40],d[48]*dq[48],d[56]*dq[56]) - // constants scaled things up by 1<<12; let's bring them back - // down, but keep 2 extra bits of precision - x0 += 512; x1 += 512; x2 += 512; x3 += 512; - v[ 0] = (x0+t3) >> 10; - v[56] = (x0-t3) >> 10; - v[ 8] = (x1+t2) >> 10; - v[48] = (x1-t2) >> 10; - v[16] = (x2+t1) >> 10; - v[40] = (x2-t1) >> 10; - v[24] = (x3+t0) >> 10; - v[32] = (x3-t0) >> 10; - } - } - - for (i=0, v=val, o=out; i < 8; ++i,v+=8,o+=out_stride) { - // no fast case since the first 1D IDCT spread components out - IDCT_1D(v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7]) - // constants scaled things up by 1<<12, plus we had 1<<2 from first - // loop, plus horizontal and vertical each scale by sqrt(8) so together - // we've got an extra 1<<3, so 1<<17 total we need to remove. - // so we want to round that, which means adding 0.5 * 1<<17, - // aka 65536. Also, we'll end up with -128 to 127 that we want - // to encode as 0..255 by adding 128, so we'll add that before the shift - x0 += 65536 + (128<<17); - x1 += 65536 + (128<<17); - x2 += 65536 + (128<<17); - x3 += 65536 + (128<<17); - // tried computing the shifts into temps, or'ing the temps to see - // if any were out of range, but that was slower - o[0] = clamp((x0+t3) >> 17); - o[7] = clamp((x0-t3) >> 17); - o[1] = clamp((x1+t2) >> 17); - o[6] = clamp((x1-t2) >> 17); - o[2] = clamp((x2+t1) >> 17); - o[5] = clamp((x2-t1) >> 17); - o[3] = clamp((x3+t0) >> 17); - o[4] = clamp((x3-t0) >> 17); - } -} - -#ifdef STBI_SIMD -static stbi_idct_8x8 stbi_idct_installed = idct_block; - -void stbi_install_idct(stbi_idct_8x8 func) -{ - stbi_idct_installed = func; -} -#endif - -#define MARKER_none 0xff -// if there's a pending marker from the entropy stream, return that -// otherwise, fetch from the stream and get a marker. if there's no -// marker, return 0xff, which is never a valid marker value -static uint8 get_marker(jpeg *j) -{ - uint8 x; - if (j->marker != MARKER_none) { x = j->marker; j->marker = MARKER_none; return x; } - x = get8u(j->s); - if (x != 0xff) return MARKER_none; - while (x == 0xff) - x = get8u(j->s); - return x; -} - -// in each scan, we'll have scan_n components, and the order -// of the components is specified by order[] -#define RESTART(x) ((x) >= 0xd0 && (x) <= 0xd7) - -// after a restart interval, reset the entropy decoder and -// the dc prediction -static void reset(jpeg *j) -{ - j->code_bits = 0; - j->code_buffer = 0; - j->nomore = 0; - j->img_comp[0].dc_pred = j->img_comp[1].dc_pred = j->img_comp[2].dc_pred = 0; - j->marker = MARKER_none; - j->todo = j->restart_interval ? j->restart_interval : 0x7fffffff; - // no more than 1<<31 MCUs if no restart_interal? that's plenty safe, - // since we don't even allow 1<<30 pixels -} - -static int parse_entropy_coded_data(jpeg *z) -{ - reset(z); - if (z->scan_n == 1) { - int i,j; - #ifdef STBI_SIMD - __declspec(align(16)) - #endif - short data[64]; - int n = z->order[0]; - // non-interleaved data, we just need to process one block at a time, - // in trivial scanline order - // number of blocks to do just depends on how many actual "pixels" this - // component has, independent of interleaved MCU blocking and such - int w = (z->img_comp[n].x+7) >> 3; - int h = (z->img_comp[n].y+7) >> 3; - for (j=0; j < h; ++j) { - for (i=0; i < w; ++i) { - if (!decode_block(z, data, z->huff_dc+z->img_comp[n].hd, z->huff_ac+z->img_comp[n].ha, n)) return 0; - #ifdef STBI_SIMD - stbi_idct_installed(z->img_comp[n].data+z->img_comp[n].w2*j*8+i*8, z->img_comp[n].w2, data, z->dequant2[z->img_comp[n].tq]); - #else - idct_block(z->img_comp[n].data+z->img_comp[n].w2*j*8+i*8, z->img_comp[n].w2, data, z->dequant[z->img_comp[n].tq]); - #endif - // every data block is an MCU, so countdown the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) grow_buffer_unsafe(z); - // if it's NOT a restart, then just bail, so we get corrupt data - // rather than no data - if (!RESTART(z->marker)) return 1; - reset(z); - } - } - } - } else { // interleaved! - int i,j,k,x,y; - short data[64]; - for (j=0; j < z->img_mcu_y; ++j) { - for (i=0; i < z->img_mcu_x; ++i) { - // scan an interleaved mcu... process scan_n components in order - for (k=0; k < z->scan_n; ++k) { - int n = z->order[k]; - // scan out an mcu's worth of this component; that's just determined - // by the basic H and V specified for the component - for (y=0; y < z->img_comp[n].v; ++y) { - for (x=0; x < z->img_comp[n].h; ++x) { - int x2 = (i*z->img_comp[n].h + x)*8; - int y2 = (j*z->img_comp[n].v + y)*8; - if (!decode_block(z, data, z->huff_dc+z->img_comp[n].hd, z->huff_ac+z->img_comp[n].ha, n)) return 0; - #ifdef STBI_SIMD - stbi_idct_installed(z->img_comp[n].data+z->img_comp[n].w2*y2+x2, z->img_comp[n].w2, data, z->dequant2[z->img_comp[n].tq]); - #else - idct_block(z->img_comp[n].data+z->img_comp[n].w2*y2+x2, z->img_comp[n].w2, data, z->dequant[z->img_comp[n].tq]); - #endif - } - } - } - // after all interleaved components, that's an interleaved MCU, - // so now count down the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) grow_buffer_unsafe(z); - // if it's NOT a restart, then just bail, so we get corrupt data - // rather than no data - if (!RESTART(z->marker)) return 1; - reset(z); - } - } - } - } - return 1; -} - -static int process_marker(jpeg *z, int m) -{ - int L; - switch (m) { - case MARKER_none: // no marker found - return e("expected marker","Corrupt JPEG"); - - case 0xC2: // SOF - progressive - return e("progressive jpeg","JPEG format not supported (progressive)"); - - case 0xDD: // DRI - specify restart interval - if (get16(z->s) != 4) return e("bad DRI len","Corrupt JPEG"); - z->restart_interval = get16(z->s); - return 1; - - case 0xDB: // DQT - define quantization table - L = get16(z->s)-2; - while (L > 0) { - int q = get8(z->s); - int p = q >> 4; - int t = q & 15,i; - if (p != 0) return e("bad DQT type","Corrupt JPEG"); - if (t > 3) return e("bad DQT table","Corrupt JPEG"); - for (i=0; i < 64; ++i) - z->dequant[t][dezigzag[i]] = get8u(z->s); - #ifdef STBI_SIMD - for (i=0; i < 64; ++i) - z->dequant2[t][i] = z->dequant[t][i]; - #endif - L -= 65; - } - return L==0; - - case 0xC4: // DHT - define huffman table - L = get16(z->s)-2; - while (L > 0) { - uint8 *v; - int sizes[16],i,m=0; - int q = get8(z->s); - int tc = q >> 4; - int th = q & 15; - if (tc > 1 || th > 3) return e("bad DHT header","Corrupt JPEG"); - for (i=0; i < 16; ++i) { - sizes[i] = get8(z->s); - m += sizes[i]; - } - L -= 17; - if (tc == 0) { - if (!build_huffman(z->huff_dc+th, sizes)) return 0; - v = z->huff_dc[th].values; - } else { - if (!build_huffman(z->huff_ac+th, sizes)) return 0; - v = z->huff_ac[th].values; - } - for (i=0; i < m; ++i) - v[i] = get8u(z->s); - L -= m; - } - return L==0; - } - // check for comment block or APP blocks - if ((m >= 0xE0 && m <= 0xEF) || m == 0xFE) { - skip(z->s, get16(z->s)-2); - return 1; - } - return 0; -} - -// after we see SOS -static int process_scan_header(jpeg *z) -{ - int i; - int Ls = get16(z->s); - z->scan_n = get8(z->s); - if (z->scan_n < 1 || z->scan_n > 4 || z->scan_n > (int) z->s->img_n) return e("bad SOS component count","Corrupt JPEG"); - if (Ls != 6+2*z->scan_n) return e("bad SOS len","Corrupt JPEG"); - for (i=0; i < z->scan_n; ++i) { - int id = get8(z->s), which; - int q = get8(z->s); - for (which = 0; which < z->s->img_n; ++which) - if (z->img_comp[which].id == id) - break; - if (which == z->s->img_n) return 0; - z->img_comp[which].hd = q >> 4; if (z->img_comp[which].hd > 3) return e("bad DC huff","Corrupt JPEG"); - z->img_comp[which].ha = q & 15; if (z->img_comp[which].ha > 3) return e("bad AC huff","Corrupt JPEG"); - z->order[i] = which; - } - if (get8(z->s) != 0) return e("bad SOS","Corrupt JPEG"); - get8(z->s); // should be 63, but might be 0 - if (get8(z->s) != 0) return e("bad SOS","Corrupt JPEG"); - - return 1; -} - -static int process_frame_header(jpeg *z, int scan) -{ - stbi *s = z->s; - int Lf,p,i,q, h_max=1,v_max=1,c; - Lf = get16(s); if (Lf < 11) return e("bad SOF len","Corrupt JPEG"); // JPEG - p = get8(s); if (p != 8) return e("only 8-bit","JPEG format not supported: 8-bit only"); // JPEG baseline - s->img_y = get16(s); if (s->img_y == 0) return e("no header height", "JPEG format not supported: delayed height"); // Legal, but we don't handle it--but neither does IJG - s->img_x = get16(s); if (s->img_x == 0) return e("0 width","Corrupt JPEG"); // JPEG requires - c = get8(s); - if (c != 3 && c != 1) return e("bad component count","Corrupt JPEG"); // JFIF requires - s->img_n = c; - for (i=0; i < c; ++i) { - z->img_comp[i].data = NULL; - z->img_comp[i].linebuf = NULL; - } - - if (Lf != 8+3*s->img_n) return e("bad SOF len","Corrupt JPEG"); - - for (i=0; i < s->img_n; ++i) { - z->img_comp[i].id = get8(s); - if (z->img_comp[i].id != i+1) // JFIF requires - if (z->img_comp[i].id != i) // some version of jpegtran outputs non-JFIF-compliant files! - return e("bad component ID","Corrupt JPEG"); - q = get8(s); - z->img_comp[i].h = (q >> 4); if (!z->img_comp[i].h || z->img_comp[i].h > 4) return e("bad H","Corrupt JPEG"); - z->img_comp[i].v = q & 15; if (!z->img_comp[i].v || z->img_comp[i].v > 4) return e("bad V","Corrupt JPEG"); - z->img_comp[i].tq = get8(s); if (z->img_comp[i].tq > 3) return e("bad TQ","Corrupt JPEG"); - } - - if (scan != SCAN_load) return 1; - - if ((1 << 30) / s->img_x / s->img_n < s->img_y) return e("too large", "Image too large to decode"); - - for (i=0; i < s->img_n; ++i) { - if (z->img_comp[i].h > h_max) h_max = z->img_comp[i].h; - if (z->img_comp[i].v > v_max) v_max = z->img_comp[i].v; - } - - // compute interleaved mcu info - z->img_h_max = h_max; - z->img_v_max = v_max; - z->img_mcu_w = h_max * 8; - z->img_mcu_h = v_max * 8; - z->img_mcu_x = (s->img_x + z->img_mcu_w-1) / z->img_mcu_w; - z->img_mcu_y = (s->img_y + z->img_mcu_h-1) / z->img_mcu_h; - - for (i=0; i < s->img_n; ++i) { - // number of effective pixels (e.g. for non-interleaved MCU) - z->img_comp[i].x = (s->img_x * z->img_comp[i].h + h_max-1) / h_max; - z->img_comp[i].y = (s->img_y * z->img_comp[i].v + v_max-1) / v_max; - // to simplify generation, we'll allocate enough memory to decode - // the bogus oversized data from using interleaved MCUs and their - // big blocks (e.g. a 16x16 iMCU on an image of width 33); we won't - // discard the extra data until colorspace conversion - z->img_comp[i].w2 = z->img_mcu_x * z->img_comp[i].h * 8; - z->img_comp[i].h2 = z->img_mcu_y * z->img_comp[i].v * 8; - z->img_comp[i].raw_data = malloc(z->img_comp[i].w2 * z->img_comp[i].h2+15); - if (z->img_comp[i].raw_data == NULL) { - for(--i; i >= 0; --i) { - free(z->img_comp[i].raw_data); - z->img_comp[i].data = NULL; - } - return e("outofmem", "Out of memory"); - } - // align blocks for installable-idct using mmx/sse - z->img_comp[i].data = (uint8*) (((size_t) z->img_comp[i].raw_data + 15) & ~15); - z->img_comp[i].linebuf = NULL; - } - - return 1; -} - -// use comparisons since in some cases we handle more than one case (e.g. SOF) -#define DNL(x) ((x) == 0xdc) -#define SOI(x) ((x) == 0xd8) -#define EOI(x) ((x) == 0xd9) -#define SOF(x) ((x) == 0xc0 || (x) == 0xc1) -#define SOS(x) ((x) == 0xda) - -static int decode_jpeg_header(jpeg *z, int scan) -{ - int m; - z->marker = MARKER_none; // initialize cached marker to empty - m = get_marker(z); - if (!SOI(m)) return e("no SOI","Corrupt JPEG"); - if (scan == SCAN_type) return 1; - m = get_marker(z); - while (!SOF(m)) { - if (!process_marker(z,m)) return 0; - m = get_marker(z); - while (m == MARKER_none) { - // some files have extra padding after their blocks, so ok, we'll scan - if (at_eof(z->s)) return e("no SOF", "Corrupt JPEG"); - m = get_marker(z); - } - } - if (!process_frame_header(z, scan)) return 0; - return 1; -} - -static int decode_jpeg_image(jpeg *j) -{ - int m; - j->restart_interval = 0; - if (!decode_jpeg_header(j, SCAN_load)) return 0; - m = get_marker(j); - while (!EOI(m)) { - if (SOS(m)) { - if (!process_scan_header(j)) return 0; - if (!parse_entropy_coded_data(j)) return 0; - if (j->marker == MARKER_none ) { - // handle 0s at the end of image data from IP Kamera 9060 - while (!at_eof(j->s)) { - int x = get8(j->s); - if (x == 255) { - j->marker = get8u(j->s); - break; - } else if (x != 0) { - return 0; - } - } - // if we reach eof without hitting a marker, get_marker() below will fail and we'll eventually return 0 - } - } else { - if (!process_marker(j, m)) return 0; - } - m = get_marker(j); - } - return 1; -} - -// static jfif-centered resampling (across block boundaries) - -typedef uint8 *(*resample_row_func)(uint8 *out, uint8 *in0, uint8 *in1, - int w, int hs); - -#define div4(x) ((uint8) ((x) >> 2)) - -static uint8 *resample_row_1(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - STBI_NOTUSED(out); - STBI_NOTUSED(in_far); - STBI_NOTUSED(w); - STBI_NOTUSED(hs); - return in_near; -} - -static uint8* resample_row_v_2(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // need to generate two samples vertically for every one in input - int i; - STBI_NOTUSED(hs); - for (i=0; i < w; ++i) - out[i] = div4(3*in_near[i] + in_far[i] + 2); - return out; -} - -static uint8* resample_row_h_2(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // need to generate two samples horizontally for every one in input - int i; - uint8 *input = in_near; - - if (w == 1) { - // if only one sample, can't do any interpolation - out[0] = out[1] = input[0]; - return out; - } - - out[0] = input[0]; - out[1] = div4(input[0]*3 + input[1] + 2); - for (i=1; i < w-1; ++i) { - int n = 3*input[i]+2; - out[i*2+0] = div4(n+input[i-1]); - out[i*2+1] = div4(n+input[i+1]); - } - out[i*2+0] = div4(input[w-2]*3 + input[w-1] + 2); - out[i*2+1] = input[w-1]; - - STBI_NOTUSED(in_far); - STBI_NOTUSED(hs); - - return out; -} - -#define div16(x) ((uint8) ((x) >> 4)) - -static uint8 *resample_row_hv_2(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // need to generate 2x2 samples for every one in input - int i,t0,t1; - if (w == 1) { - out[0] = out[1] = div4(3*in_near[0] + in_far[0] + 2); - return out; - } - - t1 = 3*in_near[0] + in_far[0]; - out[0] = div4(t1+2); - for (i=1; i < w; ++i) { - t0 = t1; - t1 = 3*in_near[i]+in_far[i]; - out[i*2-1] = div16(3*t0 + t1 + 8); - out[i*2 ] = div16(3*t1 + t0 + 8); - } - out[w*2-1] = div4(t1+2); - - STBI_NOTUSED(hs); - - return out; -} - -static uint8 *resample_row_generic(uint8 *out, uint8 *in_near, uint8 *in_far, int w, int hs) -{ - // resample with nearest-neighbor - int i,j; - for (i=0; i < w; ++i) - for (j=0; j < hs; ++j) - out[i*hs+j] = in_near[i]; - return out; -} - -#define float2fixed(x) ((int) ((x) * 65536 + 0.5)) - -// 0.38 seconds on 3*anemones.jpg (0.25 with processor = Pro) -// VC6 without processor=Pro is generating multiple LEAs per multiply! -static void YCbCr_to_RGB_row(uint8 *out, const uint8 *y, const uint8 *pcb, const uint8 *pcr, int count, int step) -{ - int i; - for (i=0; i < count; ++i) { - int y_fixed = (y[i] << 16) + 32768; // rounding - int r,g,b; - int cr = pcr[i] - 128; - int cb = pcb[i] - 128; - r = y_fixed + cr*float2fixed(1.40200f); - g = y_fixed - cr*float2fixed(0.71414f) - cb*float2fixed(0.34414f); - b = y_fixed + cb*float2fixed(1.77200f); - r >>= 16; - g >>= 16; - b >>= 16; - if ((unsigned) r > 255) { if (r < 0) r = 0; else r = 255; } - if ((unsigned) g > 255) { if (g < 0) g = 0; else g = 255; } - if ((unsigned) b > 255) { if (b < 0) b = 0; else b = 255; } - out[0] = (uint8)r; - out[1] = (uint8)g; - out[2] = (uint8)b; - out[3] = 255; - out += step; - } -} - -#ifdef STBI_SIMD -static stbi_YCbCr_to_RGB_run stbi_YCbCr_installed = YCbCr_to_RGB_row; - -void stbi_install_YCbCr_to_RGB(stbi_YCbCr_to_RGB_run func) -{ - stbi_YCbCr_installed = func; -} -#endif - - -// clean up the temporary component buffers -static void cleanup_jpeg(jpeg *j) -{ - int i; - for (i=0; i < j->s->img_n; ++i) { - if (j->img_comp[i].data) { - free(j->img_comp[i].raw_data); - j->img_comp[i].data = NULL; - } - if (j->img_comp[i].linebuf) { - free(j->img_comp[i].linebuf); - j->img_comp[i].linebuf = NULL; - } - } -} - -typedef struct -{ - resample_row_func resample; - uint8 *line0,*line1; - int hs,vs; // expansion factor in each axis - int w_lores; // horizontal pixels pre-expansion - int ystep; // how far through vertical expansion we are - int ypos; // which pre-expansion row we're on -} stbi_resample; - -static uint8 *load_jpeg_image(jpeg *z, int *out_x, int *out_y, int *comp, int req_comp) -{ - int n, decode_n; - // validate req_comp - if (req_comp < 0 || req_comp > 4) return epuc("bad req_comp", "Internal error"); - z->s->img_n = 0; - - // load a jpeg image from whichever source - if (!decode_jpeg_image(z)) { cleanup_jpeg(z); return NULL; } - - // determine actual number of components to generate - n = req_comp ? req_comp : z->s->img_n; - - if (z->s->img_n == 3 && n < 3) - decode_n = 1; - else - decode_n = z->s->img_n; - - // resample and color-convert - { - int k; - uint i,j; - uint8 *output; - uint8 *coutput[4]; - - stbi_resample res_comp[4]; - - for (k=0; k < decode_n; ++k) { - stbi_resample *r = &res_comp[k]; - - // allocate line buffer big enough for upsampling off the edges - // with upsample factor of 4 - z->img_comp[k].linebuf = (uint8 *) malloc(z->s->img_x + 3); - if (!z->img_comp[k].linebuf) { cleanup_jpeg(z); return epuc("outofmem", "Out of memory"); } - - r->hs = z->img_h_max / z->img_comp[k].h; - r->vs = z->img_v_max / z->img_comp[k].v; - r->ystep = r->vs >> 1; - r->w_lores = (z->s->img_x + r->hs-1) / r->hs; - r->ypos = 0; - r->line0 = r->line1 = z->img_comp[k].data; - - if (r->hs == 1 && r->vs == 1) r->resample = resample_row_1; - else if (r->hs == 1 && r->vs == 2) r->resample = resample_row_v_2; - else if (r->hs == 2 && r->vs == 1) r->resample = resample_row_h_2; - else if (r->hs == 2 && r->vs == 2) r->resample = resample_row_hv_2; - else r->resample = resample_row_generic; - } - - // can't error after this so, this is safe - output = (uint8 *) malloc(n * z->s->img_x * z->s->img_y + 1); - if (!output) { cleanup_jpeg(z); return epuc("outofmem", "Out of memory"); } - - // now go ahead and resample - for (j=0; j < z->s->img_y; ++j) { - uint8 *out = output + n * z->s->img_x * j; - for (k=0; k < decode_n; ++k) { - stbi_resample *r = &res_comp[k]; - int y_bot = r->ystep >= (r->vs >> 1); - coutput[k] = r->resample(z->img_comp[k].linebuf, - y_bot ? r->line1 : r->line0, - y_bot ? r->line0 : r->line1, - r->w_lores, r->hs); - if (++r->ystep >= r->vs) { - r->ystep = 0; - r->line0 = r->line1; - if (++r->ypos < z->img_comp[k].y) - r->line1 += z->img_comp[k].w2; - } - } - if (n >= 3) { - uint8 *y = coutput[0]; - if (z->s->img_n == 3) { - #ifdef STBI_SIMD - stbi_YCbCr_installed(out, y, coutput[1], coutput[2], z->s.img_x, n); - #else - YCbCr_to_RGB_row(out, y, coutput[1], coutput[2], z->s->img_x, n); - #endif - } else - for (i=0; i < z->s->img_x; ++i) { - out[0] = out[1] = out[2] = y[i]; - out[3] = 255; // not used if n==3 - out += n; - } - } else { - uint8 *y = coutput[0]; - if (n == 1) - for (i=0; i < z->s->img_x; ++i) out[i] = y[i]; - else - for (i=0; i < z->s->img_x; ++i) *out++ = y[i], *out++ = 255; - } - } - cleanup_jpeg(z); - *out_x = z->s->img_x; - *out_y = z->s->img_y; - if (comp) *comp = z->s->img_n; // report original components, not output - return output; - } -} - -static unsigned char *stbi_jpeg_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - jpeg j; - j.s = s; - return load_jpeg_image(&j, x,y,comp,req_comp); -} - -static int stbi_jpeg_test(stbi *s) -{ - int r; - jpeg j; - j.s = s; - r = decode_jpeg_header(&j, SCAN_type); - stbi_rewind(s); - return r; -} - -static int stbi_jpeg_info_raw(jpeg *j, int *x, int *y, int *comp) -{ - if (!decode_jpeg_header(j, SCAN_header)) { - stbi_rewind( j->s ); - return 0; - } - if (x) *x = j->s->img_x; - if (y) *y = j->s->img_y; - if (comp) *comp = j->s->img_n; - return 1; -} - -static int stbi_jpeg_info(stbi *s, int *x, int *y, int *comp) -{ - jpeg j; - j.s = s; - return stbi_jpeg_info_raw(&j, x, y, comp); -} - -// public domain zlib decode v0.2 Sean Barrett 2006-11-18 -// simple implementation -// - all input must be provided in an upfront buffer -// - all output is written to a single output buffer (can malloc/realloc) -// performance -// - fast huffman - -// fast-way is faster to check than jpeg huffman, but slow way is slower -#define ZFAST_BITS 9 // accelerate all cases in default tables -#define ZFAST_MASK ((1 << ZFAST_BITS) - 1) - -// zlib-style huffman encoding -// (jpegs packs from left, zlib from right, so can't share code) -typedef struct -{ - uint16 fast[1 << ZFAST_BITS]; - uint16 firstcode[16]; - int maxcode[17]; - uint16 firstsymbol[16]; - uint8 size[288]; - uint16 value[288]; -} zhuffman; - -stbi_inline static int bitreverse16(int n) -{ - n = ((n & 0xAAAA) >> 1) | ((n & 0x5555) << 1); - n = ((n & 0xCCCC) >> 2) | ((n & 0x3333) << 2); - n = ((n & 0xF0F0) >> 4) | ((n & 0x0F0F) << 4); - n = ((n & 0xFF00) >> 8) | ((n & 0x00FF) << 8); - return n; -} - -stbi_inline static int bit_reverse(int v, int bits) -{ - assert(bits <= 16); - // to bit reverse n bits, reverse 16 and shift - // e.g. 11 bits, bit reverse and shift away 5 - return bitreverse16(v) >> (16-bits); -} - -static int zbuild_huffman(zhuffman *z, uint8 *sizelist, int num) -{ - int i,k=0; - int code, next_code[16], sizes[17]; - - // DEFLATE spec for generating codes - memset(sizes, 0, sizeof(sizes)); - memset(z->fast, 255, sizeof(z->fast)); - for (i=0; i < num; ++i) - ++sizes[sizelist[i]]; - sizes[0] = 0; - for (i=1; i < 16; ++i) - assert(sizes[i] <= (1 << i)); - code = 0; - for (i=1; i < 16; ++i) { - next_code[i] = code; - z->firstcode[i] = (uint16) code; - z->firstsymbol[i] = (uint16) k; - code = (code + sizes[i]); - if (sizes[i]) - if (code-1 >= (1 << i)) return e("bad codelengths","Corrupt JPEG"); - z->maxcode[i] = code << (16-i); // preshift for inner loop - code <<= 1; - k += sizes[i]; - } - z->maxcode[16] = 0x10000; // sentinel - for (i=0; i < num; ++i) { - int s = sizelist[i]; - if (s) { - int c = next_code[s] - z->firstcode[s] + z->firstsymbol[s]; - z->size[c] = (uint8)s; - z->value[c] = (uint16)i; - if (s <= ZFAST_BITS) { - int k = bit_reverse(next_code[s],s); - while (k < (1 << ZFAST_BITS)) { - z->fast[k] = (uint16) c; - k += (1 << s); - } - } - ++next_code[s]; - } - } - return 1; -} - -// zlib-from-memory implementation for PNG reading -// because PNG allows splitting the zlib stream arbitrarily, -// and it's annoying structurally to have PNG call ZLIB call PNG, -// we require PNG read all the IDATs and combine them into a single -// memory buffer - -typedef struct -{ - uint8 *zbuffer, *zbuffer_end; - int num_bits; - uint32 code_buffer; - - char *zout; - char *zout_start; - char *zout_end; - int z_expandable; - - zhuffman z_length, z_distance; -} zbuf; - -stbi_inline static int zget8(zbuf *z) -{ - if (z->zbuffer >= z->zbuffer_end) return 0; - return *z->zbuffer++; -} - -static void fill_bits(zbuf *z) -{ - do { - assert(z->code_buffer < (1U << z->num_bits)); - z->code_buffer |= zget8(z) << z->num_bits; - z->num_bits += 8; - } while (z->num_bits <= 24); -} - -stbi_inline static unsigned int zreceive(zbuf *z, int n) -{ - unsigned int k; - if (z->num_bits < n) fill_bits(z); - k = z->code_buffer & ((1 << n) - 1); - z->code_buffer >>= n; - z->num_bits -= n; - return k; -} - -stbi_inline static int zhuffman_decode(zbuf *a, zhuffman *z) -{ - int b,s,k; - if (a->num_bits < 16) fill_bits(a); - b = z->fast[a->code_buffer & ZFAST_MASK]; - if (b < 0xffff) { - s = z->size[b]; - a->code_buffer >>= s; - a->num_bits -= s; - return z->value[b]; - } - - // not resolved by fast table, so compute it the slow way - // use jpeg approach, which requires MSbits at top - k = bit_reverse(a->code_buffer, 16); - for (s=ZFAST_BITS+1; ; ++s) - if (k < z->maxcode[s]) - break; - if (s == 16) return -1; // invalid code! - // code size is s, so: - b = (k >> (16-s)) - z->firstcode[s] + z->firstsymbol[s]; - assert(z->size[b] == s); - a->code_buffer >>= s; - a->num_bits -= s; - return z->value[b]; -} - -static int expand(zbuf *z, int n) // need to make room for n bytes -{ - char *q; - int cur, limit; - if (!z->z_expandable) return e("output buffer limit","Corrupt PNG"); - cur = (int) (z->zout - z->zout_start); - limit = (int) (z->zout_end - z->zout_start); - while (cur + n > limit) - limit *= 2; - q = (char *) realloc(z->zout_start, limit); - if (q == NULL) return e("outofmem", "Out of memory"); - z->zout_start = q; - z->zout = q + cur; - z->zout_end = q + limit; - return 1; -} - -static int length_base[31] = { - 3,4,5,6,7,8,9,10,11,13, - 15,17,19,23,27,31,35,43,51,59, - 67,83,99,115,131,163,195,227,258,0,0 }; - -static int length_extra[31]= -{ 0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0 }; - -static int dist_base[32] = { 1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193, -257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0}; - -static int dist_extra[32] = -{ 0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13}; - -static int parse_huffman_block(zbuf *a) -{ - for(;;) { - int z = zhuffman_decode(a, &a->z_length); - if (z < 256) { - if (z < 0) return e("bad huffman code","Corrupt PNG"); // error in huffman codes - if (a->zout >= a->zout_end) if (!expand(a, 1)) return 0; - *a->zout++ = (char) z; - } else { - uint8 *p; - int len,dist; - if (z == 256) return 1; - z -= 257; - len = length_base[z]; - if (length_extra[z]) len += zreceive(a, length_extra[z]); - z = zhuffman_decode(a, &a->z_distance); - if (z < 0) return e("bad huffman code","Corrupt PNG"); - dist = dist_base[z]; - if (dist_extra[z]) dist += zreceive(a, dist_extra[z]); - if (a->zout - a->zout_start < dist) return e("bad dist","Corrupt PNG"); - if (a->zout + len > a->zout_end) if (!expand(a, len)) return 0; - p = (uint8 *) (a->zout - dist); - while (len--) - *a->zout++ = *p++; - } - } -} - -static int compute_huffman_codes(zbuf *a) -{ - static uint8 length_dezigzag[19] = { 16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15 }; - zhuffman z_codelength; - uint8 lencodes[286+32+137];//padding for maximum single op - uint8 codelength_sizes[19]; - int i,n; - - int hlit = zreceive(a,5) + 257; - int hdist = zreceive(a,5) + 1; - int hclen = zreceive(a,4) + 4; - - memset(codelength_sizes, 0, sizeof(codelength_sizes)); - for (i=0; i < hclen; ++i) { - int s = zreceive(a,3); - codelength_sizes[length_dezigzag[i]] = (uint8) s; - } - if (!zbuild_huffman(&z_codelength, codelength_sizes, 19)) return 0; - - n = 0; - while (n < hlit + hdist) { - int c = zhuffman_decode(a, &z_codelength); - assert(c >= 0 && c < 19); - if (c < 16) - lencodes[n++] = (uint8) c; - else if (c == 16) { - c = zreceive(a,2)+3; - memset(lencodes+n, lencodes[n-1], c); - n += c; - } else if (c == 17) { - c = zreceive(a,3)+3; - memset(lencodes+n, 0, c); - n += c; - } else { - assert(c == 18); - c = zreceive(a,7)+11; - memset(lencodes+n, 0, c); - n += c; - } - } - if (n != hlit+hdist) return e("bad codelengths","Corrupt PNG"); - if (!zbuild_huffman(&a->z_length, lencodes, hlit)) return 0; - if (!zbuild_huffman(&a->z_distance, lencodes+hlit, hdist)) return 0; - return 1; -} - -static int parse_uncompressed_block(zbuf *a) -{ - uint8 header[4]; - int len,nlen,k; - if (a->num_bits & 7) - zreceive(a, a->num_bits & 7); // discard - // drain the bit-packed data into header - k = 0; - while (a->num_bits > 0) { - header[k++] = (uint8) (a->code_buffer & 255); // wtf this warns? - a->code_buffer >>= 8; - a->num_bits -= 8; - } - assert(a->num_bits == 0); - // now fill header the normal way - while (k < 4) - header[k++] = (uint8) zget8(a); - len = header[1] * 256 + header[0]; - nlen = header[3] * 256 + header[2]; - if (nlen != (len ^ 0xffff)) return e("zlib corrupt","Corrupt PNG"); - if (a->zbuffer + len > a->zbuffer_end) return e("read past buffer","Corrupt PNG"); - if (a->zout + len > a->zout_end) - if (!expand(a, len)) return 0; - memcpy(a->zout, a->zbuffer, len); - a->zbuffer += len; - a->zout += len; - return 1; -} - -static int parse_zlib_header(zbuf *a) -{ - int cmf = zget8(a); - int cm = cmf & 15; - /* int cinfo = cmf >> 4; */ - int flg = zget8(a); - if ((cmf*256+flg) % 31 != 0) return e("bad zlib header","Corrupt PNG"); // zlib spec - if (flg & 32) return e("no preset dict","Corrupt PNG"); // preset dictionary not allowed in png - if (cm != 8) return e("bad compression","Corrupt PNG"); // DEFLATE required for png - // window = 1 << (8 + cinfo)... but who cares, we fully buffer output - return 1; -} - -// @TODO: should statically initialize these for optimal thread safety -static uint8 default_length[288], default_distance[32]; -static void init_defaults(void) -{ - int i; // use <= to match clearly with spec - for (i=0; i <= 143; ++i) default_length[i] = 8; - for ( ; i <= 255; ++i) default_length[i] = 9; - for ( ; i <= 279; ++i) default_length[i] = 7; - for ( ; i <= 287; ++i) default_length[i] = 8; - - for (i=0; i <= 31; ++i) default_distance[i] = 5; -} - -int stbi_png_partial; // a quick hack to only allow decoding some of a PNG... I should implement real streaming support instead -static int parse_zlib(zbuf *a, int parse_header) -{ - int final, type; - if (parse_header) - if (!parse_zlib_header(a)) return 0; - a->num_bits = 0; - a->code_buffer = 0; - do { - final = zreceive(a,1); - type = zreceive(a,2); - if (type == 0) { - if (!parse_uncompressed_block(a)) return 0; - } else if (type == 3) { - return 0; - } else { - if (type == 1) { - // use fixed code lengths - if (!default_distance[31]) init_defaults(); - if (!zbuild_huffman(&a->z_length , default_length , 288)) return 0; - if (!zbuild_huffman(&a->z_distance, default_distance, 32)) return 0; - } else { - if (!compute_huffman_codes(a)) return 0; - } - if (!parse_huffman_block(a)) return 0; - } - if (stbi_png_partial && a->zout - a->zout_start > 65536) - break; - } while (!final); - return 1; -} - -static int do_zlib(zbuf *a, char *obuf, int olen, int exp, int parse_header) -{ - a->zout_start = obuf; - a->zout = obuf; - a->zout_end = obuf + olen; - a->z_expandable = exp; - - return parse_zlib(a, parse_header); -} - -char *stbi_zlib_decode_malloc_guesssize(const char *buffer, int len, int initial_size, int *outlen) -{ - zbuf a; - char *p = (char *) malloc(initial_size); - if (p == NULL) return NULL; - a.zbuffer = (uint8 *) buffer; - a.zbuffer_end = (uint8 *) buffer + len; - if (do_zlib(&a, p, initial_size, 1, 1)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - free(a.zout_start); - return NULL; - } -} - -char *stbi_zlib_decode_malloc(char const *buffer, int len, int *outlen) -{ - return stbi_zlib_decode_malloc_guesssize(buffer, len, 16384, outlen); -} - -char *stbi_zlib_decode_malloc_guesssize_headerflag(const char *buffer, int len, int initial_size, int *outlen, int parse_header) -{ - zbuf a; - char *p = (char *) malloc(initial_size); - if (p == NULL) return NULL; - a.zbuffer = (uint8 *) buffer; - a.zbuffer_end = (uint8 *) buffer + len; - if (do_zlib(&a, p, initial_size, 1, parse_header)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - free(a.zout_start); - return NULL; - } -} - -int stbi_zlib_decode_buffer(char *obuffer, int olen, char const *ibuffer, int ilen) -{ - zbuf a; - a.zbuffer = (uint8 *) ibuffer; - a.zbuffer_end = (uint8 *) ibuffer + ilen; - if (do_zlib(&a, obuffer, olen, 0, 1)) - return (int) (a.zout - a.zout_start); - else - return -1; -} - -char *stbi_zlib_decode_noheader_malloc(char const *buffer, int len, int *outlen) -{ - zbuf a; - char *p = (char *) malloc(16384); - if (p == NULL) return NULL; - a.zbuffer = (uint8 *) buffer; - a.zbuffer_end = (uint8 *) buffer+len; - if (do_zlib(&a, p, 16384, 1, 0)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - free(a.zout_start); - return NULL; - } -} - -int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char *ibuffer, int ilen) -{ - zbuf a; - a.zbuffer = (uint8 *) ibuffer; - a.zbuffer_end = (uint8 *) ibuffer + ilen; - if (do_zlib(&a, obuffer, olen, 0, 0)) - return (int) (a.zout - a.zout_start); - else - return -1; -} - -// public domain "baseline" PNG decoder v0.10 Sean Barrett 2006-11-18 -// simple implementation -// - only 8-bit samples -// - no CRC checking -// - allocates lots of intermediate memory -// - avoids problem of streaming data between subsystems -// - avoids explicit window management -// performance -// - uses stb_zlib, a PD zlib implementation with fast huffman decoding - - -typedef struct -{ - uint32 length; - uint32 type; -} chunk; - -#define PNG_TYPE(a,b,c,d) (((a) << 24) + ((b) << 16) + ((c) << 8) + (d)) - -static chunk get_chunk_header(stbi *s) -{ - chunk c; - c.length = get32(s); - c.type = get32(s); - return c; -} - -static int check_png_header(stbi *s) -{ - static uint8 png_sig[8] = { 137,80,78,71,13,10,26,10 }; - int i; - for (i=0; i < 8; ++i) - if (get8u(s) != png_sig[i]) return e("bad png sig","Not a PNG"); - return 1; -} - -typedef struct -{ - stbi *s; - uint8 *idata, *expanded, *out; -} png; - - -enum { - F_none=0, F_sub=1, F_up=2, F_avg=3, F_paeth=4, - F_avg_first, F_paeth_first -}; - -static uint8 first_row_filter[5] = -{ - F_none, F_sub, F_none, F_avg_first, F_paeth_first -}; - -static int paeth(int a, int b, int c) -{ - int p = a + b - c; - int pa = abs(p-a); - int pb = abs(p-b); - int pc = abs(p-c); - if (pa <= pb && pa <= pc) return a; - if (pb <= pc) return b; - return c; -} - -// create the png data from post-deflated data -static int create_png_image_raw(png *a, uint8 *raw, uint32 raw_len, int out_n, uint32 x, uint32 y) -{ - stbi *s = a->s; - uint32 i,j,stride = x*out_n; - int k; - int img_n = s->img_n; // copy it into a local for later - assert(out_n == s->img_n || out_n == s->img_n+1); - if (stbi_png_partial) y = 1; - a->out = (uint8 *) malloc(x * y * out_n); - if (!a->out) return e("outofmem", "Out of memory"); - if (!stbi_png_partial) { - if (s->img_x == x && s->img_y == y) { - if (raw_len != (img_n * x + 1) * y) return e("not enough pixels","Corrupt PNG"); - } else { // interlaced: - if (raw_len < (img_n * x + 1) * y) return e("not enough pixels","Corrupt PNG"); - } - } - for (j=0; j < y; ++j) { - uint8 *cur = a->out + stride*j; - uint8 *prior = cur - stride; - int filter = *raw++; - if (filter > 4) return e("invalid filter","Corrupt PNG"); - // if first row, use special filter that doesn't sample previous row - if (j == 0) filter = first_row_filter[filter]; - // handle first pixel explicitly - for (k=0; k < img_n; ++k) { - switch (filter) { - case F_none : cur[k] = raw[k]; break; - case F_sub : cur[k] = raw[k]; break; - case F_up : cur[k] = raw[k] + prior[k]; break; - case F_avg : cur[k] = raw[k] + (prior[k]>>1); break; - case F_paeth : cur[k] = (uint8) (raw[k] + paeth(0,prior[k],0)); break; - case F_avg_first : cur[k] = raw[k]; break; - case F_paeth_first: cur[k] = raw[k]; break; - } - } - if (img_n != out_n) cur[img_n] = 255; - raw += img_n; - cur += out_n; - prior += out_n; - // this is a little gross, so that we don't switch per-pixel or per-component - if (img_n == out_n) { - #define CASE(f) \ - case f: \ - for (i=x-1; i >= 1; --i, raw+=img_n,cur+=img_n,prior+=img_n) \ - for (k=0; k < img_n; ++k) - switch (filter) { - CASE(F_none) cur[k] = raw[k]; break; - CASE(F_sub) cur[k] = raw[k] + cur[k-img_n]; break; - CASE(F_up) cur[k] = raw[k] + prior[k]; break; - CASE(F_avg) cur[k] = raw[k] + ((prior[k] + cur[k-img_n])>>1); break; - CASE(F_paeth) cur[k] = (uint8) (raw[k] + paeth(cur[k-img_n],prior[k],prior[k-img_n])); break; - CASE(F_avg_first) cur[k] = raw[k] + (cur[k-img_n] >> 1); break; - CASE(F_paeth_first) cur[k] = (uint8) (raw[k] + paeth(cur[k-img_n],0,0)); break; - } - #undef CASE - } else { - assert(img_n+1 == out_n); - #define CASE(f) \ - case f: \ - for (i=x-1; i >= 1; --i, cur[img_n]=255,raw+=img_n,cur+=out_n,prior+=out_n) \ - for (k=0; k < img_n; ++k) - switch (filter) { - CASE(F_none) cur[k] = raw[k]; break; - CASE(F_sub) cur[k] = raw[k] + cur[k-out_n]; break; - CASE(F_up) cur[k] = raw[k] + prior[k]; break; - CASE(F_avg) cur[k] = raw[k] + ((prior[k] + cur[k-out_n])>>1); break; - CASE(F_paeth) cur[k] = (uint8) (raw[k] + paeth(cur[k-out_n],prior[k],prior[k-out_n])); break; - CASE(F_avg_first) cur[k] = raw[k] + (cur[k-out_n] >> 1); break; - CASE(F_paeth_first) cur[k] = (uint8) (raw[k] + paeth(cur[k-out_n],0,0)); break; - } - #undef CASE - } - } - return 1; -} - -static int create_png_image(png *a, uint8 *raw, uint32 raw_len, int out_n, int interlaced) -{ - uint8 *final; - int p; - int save; - if (!interlaced) - return create_png_image_raw(a, raw, raw_len, out_n, a->s->img_x, a->s->img_y); - save = stbi_png_partial; - stbi_png_partial = 0; - - // de-interlacing - final = (uint8 *) malloc(a->s->img_x * a->s->img_y * out_n); - for (p=0; p < 7; ++p) { - int xorig[] = { 0,4,0,2,0,1,0 }; - int yorig[] = { 0,0,4,0,2,0,1 }; - int xspc[] = { 8,8,4,4,2,2,1 }; - int yspc[] = { 8,8,8,4,4,2,2 }; - int i,j,x,y; - // pass1_x[4] = 0, pass1_x[5] = 1, pass1_x[12] = 1 - x = (a->s->img_x - xorig[p] + xspc[p]-1) / xspc[p]; - y = (a->s->img_y - yorig[p] + yspc[p]-1) / yspc[p]; - if (x && y) { - if (!create_png_image_raw(a, raw, raw_len, out_n, x, y)) { - free(final); - return 0; - } - for (j=0; j < y; ++j) - for (i=0; i < x; ++i) - memcpy(final + (j*yspc[p]+yorig[p])*a->s->img_x*out_n + (i*xspc[p]+xorig[p])*out_n, - a->out + (j*x+i)*out_n, out_n); - free(a->out); - raw += (x*out_n+1)*y; - raw_len -= (x*out_n+1)*y; - } - } - a->out = final; - - stbi_png_partial = save; - return 1; -} - -static int compute_transparency(png *z, uint8 tc[3], int out_n) -{ - stbi *s = z->s; - uint32 i, pixel_count = s->img_x * s->img_y; - uint8 *p = z->out; - - // compute color-based transparency, assuming we've - // already got 255 as the alpha value in the output - assert(out_n == 2 || out_n == 4); - - if (out_n == 2) { - for (i=0; i < pixel_count; ++i) { - p[1] = (p[0] == tc[0] ? 0 : 255); - p += 2; - } - } else { - for (i=0; i < pixel_count; ++i) { - if (p[0] == tc[0] && p[1] == tc[1] && p[2] == tc[2]) - p[3] = 0; - p += 4; - } - } - return 1; -} - -static int expand_palette(png *a, uint8 *palette, int len, int pal_img_n) -{ - uint32 i, pixel_count = a->s->img_x * a->s->img_y; - uint8 *p, *temp_out, *orig = a->out; - - p = (uint8 *) malloc(pixel_count * pal_img_n); - if (p == NULL) return e("outofmem", "Out of memory"); - - // between here and free(out) below, exitting would leak - temp_out = p; - - if (pal_img_n == 3) { - for (i=0; i < pixel_count; ++i) { - int n = orig[i]*4; - p[0] = palette[n ]; - p[1] = palette[n+1]; - p[2] = palette[n+2]; - p += 3; - } - } else { - for (i=0; i < pixel_count; ++i) { - int n = orig[i]*4; - p[0] = palette[n ]; - p[1] = palette[n+1]; - p[2] = palette[n+2]; - p[3] = palette[n+3]; - p += 4; - } - } - free(a->out); - a->out = temp_out; - - STBI_NOTUSED(len); - - return 1; -} - -static int stbi_unpremultiply_on_load = 0; -static int stbi_de_iphone_flag = 0; - -void stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply) -{ - stbi_unpremultiply_on_load = flag_true_if_should_unpremultiply; -} -void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert) -{ - stbi_de_iphone_flag = flag_true_if_should_convert; -} - -static void stbi_de_iphone(png *z) -{ - stbi *s = z->s; - uint32 i, pixel_count = s->img_x * s->img_y; - uint8 *p = z->out; - - if (s->img_out_n == 3) { // convert bgr to rgb - for (i=0; i < pixel_count; ++i) { - uint8 t = p[0]; - p[0] = p[2]; - p[2] = t; - p += 3; - } - } else { - assert(s->img_out_n == 4); - if (stbi_unpremultiply_on_load) { - // convert bgr to rgb and unpremultiply - for (i=0; i < pixel_count; ++i) { - uint8 a = p[3]; - uint8 t = p[0]; - if (a) { - p[0] = p[2] * 255 / a; - p[1] = p[1] * 255 / a; - p[2] = t * 255 / a; - } else { - p[0] = p[2]; - p[2] = t; - } - p += 4; - } - } else { - // convert bgr to rgb - for (i=0; i < pixel_count; ++i) { - uint8 t = p[0]; - p[0] = p[2]; - p[2] = t; - p += 4; - } - } - } -} - -static int parse_png_file(png *z, int scan, int req_comp) -{ - uint8 palette[1024], pal_img_n=0; - uint8 has_trans=0, tc[3]; - uint32 ioff=0, idata_limit=0, i, pal_len=0; - int first=1,k,interlace=0, iphone=0; - stbi *s = z->s; - - z->expanded = NULL; - z->idata = NULL; - z->out = NULL; - - if (!check_png_header(s)) return 0; - - if (scan == SCAN_type) return 1; - - for (;;) { - chunk c = get_chunk_header(s); - switch (c.type) { - case PNG_TYPE('C','g','B','I'): - iphone = stbi_de_iphone_flag; - skip(s, c.length); - break; - case PNG_TYPE('I','H','D','R'): { - int depth,color,comp,filter; - if (!first) return e("multiple IHDR","Corrupt PNG"); - first = 0; - if (c.length != 13) return e("bad IHDR len","Corrupt PNG"); - s->img_x = get32(s); if (s->img_x > (1 << 24)) return e("too large","Very large image (corrupt?)"); - s->img_y = get32(s); if (s->img_y > (1 << 24)) return e("too large","Very large image (corrupt?)"); - depth = get8(s); if (depth != 8) return e("8bit only","PNG not supported: 8-bit only"); - color = get8(s); if (color > 6) return e("bad ctype","Corrupt PNG"); - if (color == 3) pal_img_n = 3; else if (color & 1) return e("bad ctype","Corrupt PNG"); - comp = get8(s); if (comp) return e("bad comp method","Corrupt PNG"); - filter= get8(s); if (filter) return e("bad filter method","Corrupt PNG"); - interlace = get8(s); if (interlace>1) return e("bad interlace method","Corrupt PNG"); - if (!s->img_x || !s->img_y) return e("0-pixel image","Corrupt PNG"); - if (!pal_img_n) { - s->img_n = (color & 2 ? 3 : 1) + (color & 4 ? 1 : 0); - if ((1 << 30) / s->img_x / s->img_n < s->img_y) return e("too large", "Image too large to decode"); - if (scan == SCAN_header) return 1; - } else { - // if paletted, then pal_n is our final components, and - // img_n is # components to decompress/filter. - s->img_n = 1; - if ((1 << 30) / s->img_x / 4 < s->img_y) return e("too large","Corrupt PNG"); - // if SCAN_header, have to scan to see if we have a tRNS - } - break; - } - - case PNG_TYPE('P','L','T','E'): { - if (first) return e("first not IHDR", "Corrupt PNG"); - if (c.length > 256*3) return e("invalid PLTE","Corrupt PNG"); - pal_len = c.length / 3; - if (pal_len * 3 != c.length) return e("invalid PLTE","Corrupt PNG"); - for (i=0; i < pal_len; ++i) { - palette[i*4+0] = get8u(s); - palette[i*4+1] = get8u(s); - palette[i*4+2] = get8u(s); - palette[i*4+3] = 255; - } - break; - } - - case PNG_TYPE('t','R','N','S'): { - if (first) return e("first not IHDR", "Corrupt PNG"); - if (z->idata) return e("tRNS after IDAT","Corrupt PNG"); - if (pal_img_n) { - if (scan == SCAN_header) { s->img_n = 4; return 1; } - if (pal_len == 0) return e("tRNS before PLTE","Corrupt PNG"); - if (c.length > pal_len) return e("bad tRNS len","Corrupt PNG"); - pal_img_n = 4; - for (i=0; i < c.length; ++i) - palette[i*4+3] = get8u(s); - } else { - if (!(s->img_n & 1)) return e("tRNS with alpha","Corrupt PNG"); - if (c.length != (uint32) s->img_n*2) return e("bad tRNS len","Corrupt PNG"); - has_trans = 1; - for (k=0; k < s->img_n; ++k) - tc[k] = (uint8) get16(s); // non 8-bit images will be larger - } - break; - } - - case PNG_TYPE('I','D','A','T'): { - if (first) return e("first not IHDR", "Corrupt PNG"); - if (pal_img_n && !pal_len) return e("no PLTE","Corrupt PNG"); - if (scan == SCAN_header) { s->img_n = pal_img_n; return 1; } - if (ioff + c.length > idata_limit) { - uint8 *p; - if (idata_limit == 0) idata_limit = c.length > 4096 ? c.length : 4096; - while (ioff + c.length > idata_limit) - idata_limit *= 2; - p = (uint8 *) realloc(z->idata, idata_limit); if (p == NULL) return e("outofmem", "Out of memory"); - z->idata = p; - } - if (!getn(s, z->idata+ioff,c.length)) return e("outofdata","Corrupt PNG"); - ioff += c.length; - break; - } - - case PNG_TYPE('I','E','N','D'): { - uint32 raw_len; - if (first) return e("first not IHDR", "Corrupt PNG"); - if (scan != SCAN_load) return 1; - if (z->idata == NULL) return e("no IDAT","Corrupt PNG"); - z->expanded = (uint8 *) stbi_zlib_decode_malloc_guesssize_headerflag((char *) z->idata, ioff, 16384, (int *) &raw_len, !iphone); - if (z->expanded == NULL) return 0; // zlib should set error - free(z->idata); z->idata = NULL; - if ((req_comp == s->img_n+1 && req_comp != 3 && !pal_img_n) || has_trans) - s->img_out_n = s->img_n+1; - else - s->img_out_n = s->img_n; - if (!create_png_image(z, z->expanded, raw_len, s->img_out_n, interlace)) return 0; - if (has_trans) - if (!compute_transparency(z, tc, s->img_out_n)) return 0; - if (iphone && s->img_out_n > 2) - stbi_de_iphone(z); - if (pal_img_n) { - // pal_img_n == 3 or 4 - s->img_n = pal_img_n; // record the actual colors we had - s->img_out_n = pal_img_n; - if (req_comp >= 3) s->img_out_n = req_comp; - if (!expand_palette(z, palette, pal_len, s->img_out_n)) - return 0; - } - free(z->expanded); z->expanded = NULL; - return 1; - } - - default: - // if critical, fail - if (first) return e("first not IHDR", "Corrupt PNG"); - if ((c.type & (1 << 29)) == 0) { - #ifndef STBI_NO_FAILURE_STRINGS - // not threadsafe - static char invalid_chunk[] = "XXXX chunk not known"; - invalid_chunk[0] = (uint8) (c.type >> 24); - invalid_chunk[1] = (uint8) (c.type >> 16); - invalid_chunk[2] = (uint8) (c.type >> 8); - invalid_chunk[3] = (uint8) (c.type >> 0); - #endif - return e(invalid_chunk, "PNG not supported: unknown chunk type"); - } - skip(s, c.length); - break; - } - // end of chunk, read and skip CRC - get32(s); - } -} - -static unsigned char *do_png(png *p, int *x, int *y, int *n, int req_comp) -{ - unsigned char *result=NULL; - if (req_comp < 0 || req_comp > 4) return epuc("bad req_comp", "Internal error"); - if (parse_png_file(p, SCAN_load, req_comp)) { - result = p->out; - p->out = NULL; - if (req_comp && req_comp != p->s->img_out_n) { - result = convert_format(result, p->s->img_out_n, req_comp, p->s->img_x, p->s->img_y); - p->s->img_out_n = req_comp; - if (result == NULL) return result; - } - *x = p->s->img_x; - *y = p->s->img_y; - if (n) *n = p->s->img_n; - } - free(p->out); p->out = NULL; - free(p->expanded); p->expanded = NULL; - free(p->idata); p->idata = NULL; - - return result; -} - -static unsigned char *stbi_png_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - png p; - p.s = s; - return do_png(&p, x,y,comp,req_comp); -} - -static int stbi_png_test(stbi *s) -{ - int r; - r = check_png_header(s); - stbi_rewind(s); - return r; -} - -static int stbi_png_info_raw(png *p, int *x, int *y, int *comp) -{ - if (!parse_png_file(p, SCAN_header, 0)) { - stbi_rewind( p->s ); - return 0; - } - if (x) *x = p->s->img_x; - if (y) *y = p->s->img_y; - if (comp) *comp = p->s->img_n; - return 1; -} - -static int stbi_png_info(stbi *s, int *x, int *y, int *comp) -{ - png p; - p.s = s; - return stbi_png_info_raw(&p, x, y, comp); -} - -// Microsoft/Windows BMP image - -static int bmp_test(stbi *s) -{ - int sz; - if (get8(s) != 'B') return 0; - if (get8(s) != 'M') return 0; - get32le(s); // discard filesize - get16le(s); // discard reserved - get16le(s); // discard reserved - get32le(s); // discard data offset - sz = get32le(s); - if (sz == 12 || sz == 40 || sz == 56 || sz == 108) return 1; - return 0; -} - -static int stbi_bmp_test(stbi *s) -{ - int r = bmp_test(s); - stbi_rewind(s); - return r; -} - - -// returns 0..31 for the highest set bit -static int high_bit(unsigned int z) -{ - int n=0; - if (z == 0) return -1; - if (z >= 0x10000) n += 16, z >>= 16; - if (z >= 0x00100) n += 8, z >>= 8; - if (z >= 0x00010) n += 4, z >>= 4; - if (z >= 0x00004) n += 2, z >>= 2; - if (z >= 0x00002) n += 1, z >>= 1; - return n; -} - -static int bitcount(unsigned int a) -{ - a = (a & 0x55555555) + ((a >> 1) & 0x55555555); // max 2 - a = (a & 0x33333333) + ((a >> 2) & 0x33333333); // max 4 - a = (a + (a >> 4)) & 0x0f0f0f0f; // max 8 per 4, now 8 bits - a = (a + (a >> 8)); // max 16 per 8 bits - a = (a + (a >> 16)); // max 32 per 8 bits - return a & 0xff; -} - -static int shiftsigned(int v, int shift, int bits) -{ - int result; - int z=0; - - if (shift < 0) v <<= -shift; - else v >>= shift; - result = v; - - z = bits; - while (z < 8) { - result += v >> z; - z += bits; - } - return result; -} - -static stbi_uc *bmp_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - uint8 *out; - unsigned int mr=0,mg=0,mb=0,ma=0, fake_a=0; - stbi_uc pal[256][4]; - int psize=0,i,j,compress=0,width; - int bpp, flip_vertically, pad, target, offset, hsz; - if (get8(s) != 'B' || get8(s) != 'M') return epuc("not BMP", "Corrupt BMP"); - get32le(s); // discard filesize - get16le(s); // discard reserved - get16le(s); // discard reserved - offset = get32le(s); - hsz = get32le(s); - if (hsz != 12 && hsz != 40 && hsz != 56 && hsz != 108) return epuc("unknown BMP", "BMP type not supported: unknown"); - if (hsz == 12) { - s->img_x = get16le(s); - s->img_y = get16le(s); - } else { - s->img_x = get32le(s); - s->img_y = get32le(s); - } - if (get16le(s) != 1) return epuc("bad BMP", "bad BMP"); - bpp = get16le(s); - if (bpp == 1) return epuc("monochrome", "BMP type not supported: 1-bit"); - flip_vertically = ((int) s->img_y) > 0; - s->img_y = abs((int) s->img_y); - if (hsz == 12) { - if (bpp < 24) - psize = (offset - 14 - 24) / 3; - } else { - compress = get32le(s); - if (compress == 1 || compress == 2) return epuc("BMP RLE", "BMP type not supported: RLE"); - get32le(s); // discard sizeof - get32le(s); // discard hres - get32le(s); // discard vres - get32le(s); // discard colorsused - get32le(s); // discard max important - if (hsz == 40 || hsz == 56) { - if (hsz == 56) { - get32le(s); - get32le(s); - get32le(s); - get32le(s); - } - if (bpp == 16 || bpp == 32) { - mr = mg = mb = 0; - if (compress == 0) { - if (bpp == 32) { - mr = 0xffu << 16; - mg = 0xffu << 8; - mb = 0xffu << 0; - ma = 0xffu << 24; - fake_a = 1; // @TODO: check for cases like alpha value is all 0 and switch it to 255 - } else { - mr = 31u << 10; - mg = 31u << 5; - mb = 31u << 0; - } - } else if (compress == 3) { - mr = get32le(s); - mg = get32le(s); - mb = get32le(s); - // not documented, but generated by photoshop and handled by mspaint - if (mr == mg && mg == mb) { - // ?!?!? - return epuc("bad BMP", "bad BMP"); - } - } else - return epuc("bad BMP", "bad BMP"); - } - } else { - assert(hsz == 108); - mr = get32le(s); - mg = get32le(s); - mb = get32le(s); - ma = get32le(s); - get32le(s); // discard color space - for (i=0; i < 12; ++i) - get32le(s); // discard color space parameters - } - if (bpp < 16) - psize = (offset - 14 - hsz) >> 2; - } - s->img_n = ma ? 4 : 3; - if (req_comp && req_comp >= 3) // we can directly decode 3 or 4 - target = req_comp; - else - target = s->img_n; // if they want monochrome, we'll post-convert - out = (stbi_uc *) malloc(target * s->img_x * s->img_y); - if (!out) return epuc("outofmem", "Out of memory"); - if (bpp < 16) { - int z=0; - if (psize == 0 || psize > 256) { free(out); return epuc("invalid", "Corrupt BMP"); } - for (i=0; i < psize; ++i) { - pal[i][2] = get8u(s); - pal[i][1] = get8u(s); - pal[i][0] = get8u(s); - if (hsz != 12) get8(s); - pal[i][3] = 255; - } - skip(s, offset - 14 - hsz - psize * (hsz == 12 ? 3 : 4)); - if (bpp == 4) width = (s->img_x + 1) >> 1; - else if (bpp == 8) width = s->img_x; - else { free(out); return epuc("bad bpp", "Corrupt BMP"); } - pad = (-width)&3; - for (j=0; j < (int) s->img_y; ++j) { - for (i=0; i < (int) s->img_x; i += 2) { - int v=get8(s),v2=0; - if (bpp == 4) { - v2 = v & 15; - v >>= 4; - } - out[z++] = pal[v][0]; - out[z++] = pal[v][1]; - out[z++] = pal[v][2]; - if (target == 4) out[z++] = 255; - if (i+1 == (int) s->img_x) break; - v = (bpp == 8) ? get8(s) : v2; - out[z++] = pal[v][0]; - out[z++] = pal[v][1]; - out[z++] = pal[v][2]; - if (target == 4) out[z++] = 255; - } - skip(s, pad); - } - } else { - int rshift=0,gshift=0,bshift=0,ashift=0,rcount=0,gcount=0,bcount=0,acount=0; - int z = 0; - int easy=0; - skip(s, offset - 14 - hsz); - if (bpp == 24) width = 3 * s->img_x; - else if (bpp == 16) width = 2*s->img_x; - else /* bpp = 32 and pad = 0 */ width=0; - pad = (-width) & 3; - if (bpp == 24) { - easy = 1; - } else if (bpp == 32) { - if (mb == 0xff && mg == 0xff00 && mr == 0x00ff0000 && ma == 0xff000000) - easy = 2; - } - if (!easy) { - if (!mr || !mg || !mb) { free(out); return epuc("bad masks", "Corrupt BMP"); } - // right shift amt to put high bit in position #7 - rshift = high_bit(mr)-7; rcount = bitcount(mr); - gshift = high_bit(mg)-7; gcount = bitcount(mr); - bshift = high_bit(mb)-7; bcount = bitcount(mr); - ashift = high_bit(ma)-7; acount = bitcount(mr); - } - for (j=0; j < (int) s->img_y; ++j) { - if (easy) { - for (i=0; i < (int) s->img_x; ++i) { - int a; - out[z+2] = get8u(s); - out[z+1] = get8u(s); - out[z+0] = get8u(s); - z += 3; - a = (easy == 2 ? get8(s) : 255); - if (target == 4) out[z++] = (uint8) a; - } - } else { - for (i=0; i < (int) s->img_x; ++i) { - uint32 v = (bpp == 16 ? get16le(s) : get32le(s)); - int a; - out[z++] = (uint8) shiftsigned(v & mr, rshift, rcount); - out[z++] = (uint8) shiftsigned(v & mg, gshift, gcount); - out[z++] = (uint8) shiftsigned(v & mb, bshift, bcount); - a = (ma ? shiftsigned(v & ma, ashift, acount) : 255); - if (target == 4) out[z++] = (uint8) a; - } - } - skip(s, pad); - } - } - if (flip_vertically) { - stbi_uc t; - for (j=0; j < (int) s->img_y>>1; ++j) { - stbi_uc *p1 = out + j *s->img_x*target; - stbi_uc *p2 = out + (s->img_y-1-j)*s->img_x*target; - for (i=0; i < (int) s->img_x*target; ++i) { - t = p1[i], p1[i] = p2[i], p2[i] = t; - } - } - } - - if (req_comp && req_comp != target) { - out = convert_format(out, target, req_comp, s->img_x, s->img_y); - if (out == NULL) return out; // convert_format frees input on failure - } - - *x = s->img_x; - *y = s->img_y; - if (comp) *comp = s->img_n; - return out; -} - -static stbi_uc *stbi_bmp_load(stbi *s,int *x, int *y, int *comp, int req_comp) -{ - return bmp_load(s, x,y,comp,req_comp); -} - - -// Targa Truevision - TGA -// by Jonathan Dummer - -static int tga_info(stbi *s, int *x, int *y, int *comp) -{ - int tga_w, tga_h, tga_comp; - int sz; - get8u(s); // discard Offset - sz = get8u(s); // color type - if( sz > 1 ) { - stbi_rewind(s); - return 0; // only RGB or indexed allowed - } - sz = get8u(s); // image type - // only RGB or grey allowed, +/- RLE - if ((sz != 1) && (sz != 2) && (sz != 3) && (sz != 9) && (sz != 10) && (sz != 11)) return 0; - skip(s,9); - tga_w = get16le(s); - if( tga_w < 1 ) { - stbi_rewind(s); - return 0; // test width - } - tga_h = get16le(s); - if( tga_h < 1 ) { - stbi_rewind(s); - return 0; // test height - } - sz = get8(s); // bits per pixel - // only RGB or RGBA or grey allowed - if ((sz != 8) && (sz != 16) && (sz != 24) && (sz != 32)) { - stbi_rewind(s); - return 0; - } - tga_comp = sz; - if (x) *x = tga_w; - if (y) *y = tga_h; - if (comp) *comp = tga_comp / 8; - return 1; // seems to have passed everything -} - -int stbi_tga_info(stbi *s, int *x, int *y, int *comp) -{ - return tga_info(s, x, y, comp); -} - -static int tga_test(stbi *s) -{ - int sz; - get8u(s); // discard Offset - sz = get8u(s); // color type - if ( sz > 1 ) return 0; // only RGB or indexed allowed - sz = get8u(s); // image type - if ( (sz != 1) && (sz != 2) && (sz != 3) && (sz != 9) && (sz != 10) && (sz != 11) ) return 0; // only RGB or grey allowed, +/- RLE - get16(s); // discard palette start - get16(s); // discard palette length - get8(s); // discard bits per palette color entry - get16(s); // discard x origin - get16(s); // discard y origin - if ( get16(s) < 1 ) return 0; // test width - if ( get16(s) < 1 ) return 0; // test height - sz = get8(s); // bits per pixel - if ( (sz != 8) && (sz != 16) && (sz != 24) && (sz != 32) ) return 0; // only RGB or RGBA or grey allowed - return 1; // seems to have passed everything -} - -static int stbi_tga_test(stbi *s) -{ - int res = tga_test(s); - stbi_rewind(s); - return res; -} - -static stbi_uc *tga_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - // read in the TGA header stuff - int tga_offset = get8u(s); - int tga_indexed = get8u(s); - int tga_image_type = get8u(s); - int tga_is_RLE = 0; - int tga_palette_start = get16le(s); - int tga_palette_len = get16le(s); - int tga_palette_bits = get8u(s); - int tga_x_origin = get16le(s); - int tga_y_origin = get16le(s); - int tga_width = get16le(s); - int tga_height = get16le(s); - int tga_bits_per_pixel = get8u(s); - int tga_inverted = get8u(s); - // image data - unsigned char *tga_data; - unsigned char *tga_palette = NULL; - int i, j; - unsigned char raw_data[4]; - unsigned char trans_data[4]; - int RLE_count = 0; - int RLE_repeating = 0; - int read_next_pixel = 1; - - // do a tiny bit of precessing - if ( tga_image_type >= 8 ) - { - tga_image_type -= 8; - tga_is_RLE = 1; - } - /* int tga_alpha_bits = tga_inverted & 15; */ - tga_inverted = 1 - ((tga_inverted >> 5) & 1); - - // error check - if ( //(tga_indexed) || - (tga_width < 1) || (tga_height < 1) || - (tga_image_type < 1) || (tga_image_type > 3) || - ((tga_bits_per_pixel != 8) && (tga_bits_per_pixel != 16) && - (tga_bits_per_pixel != 24) && (tga_bits_per_pixel != 32)) - ) - { - return NULL; // we don't report this as a bad TGA because we don't even know if it's TGA - } - - // If I'm paletted, then I'll use the number of bits from the palette - if ( tga_indexed ) - { - tga_bits_per_pixel = tga_palette_bits; - } - - // tga info - *x = tga_width; - *y = tga_height; - if ( (req_comp < 1) || (req_comp > 4) ) - { - // just use whatever the file was - req_comp = tga_bits_per_pixel / 8; - *comp = req_comp; - } else - { - // force a new number of components - *comp = tga_bits_per_pixel/8; - } - tga_data = (unsigned char*)malloc( tga_width * tga_height * req_comp ); - if (!tga_data) return epuc("outofmem", "Out of memory"); - - // skip to the data's starting position (offset usually = 0) - skip(s, tga_offset ); - // do I need to load a palette? - if ( tga_indexed ) - { - // any data to skip? (offset usually = 0) - skip(s, tga_palette_start ); - // load the palette - tga_palette = (unsigned char*)malloc( tga_palette_len * tga_palette_bits / 8 ); - if (!tga_palette) return epuc("outofmem", "Out of memory"); - if (!getn(s, tga_palette, tga_palette_len * tga_palette_bits / 8 )) { - free(tga_data); - free(tga_palette); - return epuc("bad palette", "Corrupt TGA"); - } - } - // load the data - trans_data[0] = trans_data[1] = trans_data[2] = trans_data[3] = 0; - for (i=0; i < tga_width * tga_height; ++i) - { - // if I'm in RLE mode, do I need to get a RLE chunk? - if ( tga_is_RLE ) - { - if ( RLE_count == 0 ) - { - // yep, get the next byte as a RLE command - int RLE_cmd = get8u(s); - RLE_count = 1 + (RLE_cmd & 127); - RLE_repeating = RLE_cmd >> 7; - read_next_pixel = 1; - } else if ( !RLE_repeating ) - { - read_next_pixel = 1; - } - } else - { - read_next_pixel = 1; - } - // OK, if I need to read a pixel, do it now - if ( read_next_pixel ) - { - // load however much data we did have - if ( tga_indexed ) - { - // read in 1 byte, then perform the lookup - int pal_idx = get8u(s); - if ( pal_idx >= tga_palette_len ) - { - // invalid index - pal_idx = 0; - } - pal_idx *= tga_bits_per_pixel / 8; - for (j = 0; j*8 < tga_bits_per_pixel; ++j) - { - raw_data[j] = tga_palette[pal_idx+j]; - } - } else - { - // read in the data raw - for (j = 0; j*8 < tga_bits_per_pixel; ++j) - { - raw_data[j] = get8u(s); - } - } - // convert raw to the intermediate format - switch (tga_bits_per_pixel) - { - case 8: - // Luminous => RGBA - trans_data[0] = raw_data[0]; - trans_data[1] = raw_data[0]; - trans_data[2] = raw_data[0]; - trans_data[3] = 255; - break; - case 16: - // Luminous,Alpha => RGBA - trans_data[0] = raw_data[0]; - trans_data[1] = raw_data[0]; - trans_data[2] = raw_data[0]; - trans_data[3] = raw_data[1]; - break; - case 24: - // BGR => RGBA - trans_data[0] = raw_data[2]; - trans_data[1] = raw_data[1]; - trans_data[2] = raw_data[0]; - trans_data[3] = 255; - break; - case 32: - // BGRA => RGBA - trans_data[0] = raw_data[2]; - trans_data[1] = raw_data[1]; - trans_data[2] = raw_data[0]; - trans_data[3] = raw_data[3]; - break; - } - // clear the reading flag for the next pixel - read_next_pixel = 0; - } // end of reading a pixel - // convert to final format - switch (req_comp) - { - case 1: - // RGBA => Luminance - tga_data[i*req_comp+0] = compute_y(trans_data[0],trans_data[1],trans_data[2]); - break; - case 2: - // RGBA => Luminance,Alpha - tga_data[i*req_comp+0] = compute_y(trans_data[0],trans_data[1],trans_data[2]); - tga_data[i*req_comp+1] = trans_data[3]; - break; - case 3: - // RGBA => RGB - tga_data[i*req_comp+0] = trans_data[0]; - tga_data[i*req_comp+1] = trans_data[1]; - tga_data[i*req_comp+2] = trans_data[2]; - break; - case 4: - // RGBA => RGBA - tga_data[i*req_comp+0] = trans_data[0]; - tga_data[i*req_comp+1] = trans_data[1]; - tga_data[i*req_comp+2] = trans_data[2]; - tga_data[i*req_comp+3] = trans_data[3]; - break; - } - // in case we're in RLE mode, keep counting down - --RLE_count; - } - // do I need to invert the image? - if ( tga_inverted ) - { - for (j = 0; j*2 < tga_height; ++j) - { - int index1 = j * tga_width * req_comp; - int index2 = (tga_height - 1 - j) * tga_width * req_comp; - for (i = tga_width * req_comp; i > 0; --i) - { - unsigned char temp = tga_data[index1]; - tga_data[index1] = tga_data[index2]; - tga_data[index2] = temp; - ++index1; - ++index2; - } - } - } - // clear my palette, if I had one - if ( tga_palette != NULL ) - { - free( tga_palette ); - } - // the things I do to get rid of an error message, and yet keep - // Microsoft's C compilers happy... [8^( - tga_palette_start = tga_palette_len = tga_palette_bits = - tga_x_origin = tga_y_origin = 0; - // OK, done - return tga_data; -} - -static stbi_uc *stbi_tga_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return tga_load(s,x,y,comp,req_comp); -} - - -// ************************************************************************************************* -// Photoshop PSD loader -- PD by Thatcher Ulrich, integration by Nicolas Schulz, tweaked by STB - -static int psd_test(stbi *s) -{ - if (get32(s) != 0x38425053) return 0; // "8BPS" - else return 1; -} - -static int stbi_psd_test(stbi *s) -{ - int r = psd_test(s); - stbi_rewind(s); - return r; -} - -static stbi_uc *psd_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - int pixelCount; - int channelCount, compression; - int channel, i, count, len; - int w,h; - uint8 *out; - - // Check identifier - if (get32(s) != 0x38425053) // "8BPS" - return epuc("not PSD", "Corrupt PSD image"); - - // Check file type version. - if (get16(s) != 1) - return epuc("wrong version", "Unsupported version of PSD image"); - - // Skip 6 reserved bytes. - skip(s, 6 ); - - // Read the number of channels (R, G, B, A, etc). - channelCount = get16(s); - if (channelCount < 0 || channelCount > 16) - return epuc("wrong channel count", "Unsupported number of channels in PSD image"); - - // Read the rows and columns of the image. - h = get32(s); - w = get32(s); - - // Make sure the depth is 8 bits. - if (get16(s) != 8) - return epuc("unsupported bit depth", "PSD bit depth is not 8 bit"); - - // Make sure the color mode is RGB. - // Valid options are: - // 0: Bitmap - // 1: Grayscale - // 2: Indexed color - // 3: RGB color - // 4: CMYK color - // 7: Multichannel - // 8: Duotone - // 9: Lab color - if (get16(s) != 3) - return epuc("wrong color format", "PSD is not in RGB color format"); - - // Skip the Mode Data. (It's the palette for indexed color; other info for other modes.) - skip(s,get32(s) ); - - // Skip the image resources. (resolution, pen tool paths, etc) - skip(s, get32(s) ); - - // Skip the reserved data. - skip(s, get32(s) ); - - // Find out if the data is compressed. - // Known values: - // 0: no compression - // 1: RLE compressed - compression = get16(s); - if (compression > 1) - return epuc("bad compression", "PSD has an unknown compression format"); - - // Create the destination image. - out = (stbi_uc *) malloc(4 * w*h); - if (!out) return epuc("outofmem", "Out of memory"); - pixelCount = w*h; - - // Initialize the data to zero. - //memset( out, 0, pixelCount * 4 ); - - // Finally, the image data. - if (compression) { - // RLE as used by .PSD and .TIFF - // Loop until you get the number of unpacked bytes you are expecting: - // Read the next source byte into n. - // If n is between 0 and 127 inclusive, copy the next n+1 bytes literally. - // Else if n is between -127 and -1 inclusive, copy the next byte -n+1 times. - // Else if n is 128, noop. - // Endloop - - // The RLE-compressed data is preceeded by a 2-byte data count for each row in the data, - // which we're going to just skip. - skip(s, h * channelCount * 2 ); - - // Read the RLE data by channel. - for (channel = 0; channel < 4; channel++) { - uint8 *p; - - p = out+channel; - if (channel >= channelCount) { - // Fill this channel with default data. - for (i = 0; i < pixelCount; i++) *p = (channel == 3 ? 255 : 0), p += 4; - } else { - // Read the RLE data. - count = 0; - while (count < pixelCount) { - len = get8(s); - if (len == 128) { - // No-op. - } else if (len < 128) { - // Copy next len+1 bytes literally. - len++; - count += len; - while (len) { - *p = get8u(s); - p += 4; - len--; - } - } else if (len > 128) { - uint8 val; - // Next -len+1 bytes in the dest are replicated from next source byte. - // (Interpret len as a negative 8-bit int.) - len ^= 0x0FF; - len += 2; - val = get8u(s); - count += len; - while (len) { - *p = val; - p += 4; - len--; - } - } - } - } - } - - } else { - // We're at the raw image data. It's each channel in order (Red, Green, Blue, Alpha, ...) - // where each channel consists of an 8-bit value for each pixel in the image. - - // Read the data by channel. - for (channel = 0; channel < 4; channel++) { - uint8 *p; - - p = out + channel; - if (channel > channelCount) { - // Fill this channel with default data. - for (i = 0; i < pixelCount; i++) *p = channel == 3 ? 255 : 0, p += 4; - } else { - // Read the data. - for (i = 0; i < pixelCount; i++) - *p = get8u(s), p += 4; - } - } - } - - if (req_comp && req_comp != 4) { - out = convert_format(out, 4, req_comp, w, h); - if (out == NULL) return out; // convert_format frees input on failure - } - - if (comp) *comp = channelCount; - *y = h; - *x = w; - - return out; -} - -static stbi_uc *stbi_psd_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return psd_load(s,x,y,comp,req_comp); -} - -// ************************************************************************************************* -// Softimage PIC loader -// by Tom Seddon -// -// See http://softimage.wiki.softimage.com/index.php/INFO:_PIC_file_format -// See http://ozviz.wasp.uwa.edu.au/~pbourke/dataformats/softimagepic/ - -static int pic_is4(stbi *s,const char *str) -{ - int i; - for (i=0; i<4; ++i) - if (get8(s) != (stbi_uc)str[i]) - return 0; - - return 1; -} - -static int pic_test(stbi *s) -{ - int i; - - if (!pic_is4(s,"\x53\x80\xF6\x34")) - return 0; - - for(i=0;i<84;++i) - get8(s); - - if (!pic_is4(s,"PICT")) - return 0; - - return 1; -} - -typedef struct -{ - stbi_uc size,type,channel; -} pic_packet_t; - -static stbi_uc *pic_readval(stbi *s, int channel, stbi_uc *dest) -{ - int mask=0x80, i; - - for (i=0; i<4; ++i, mask>>=1) { - if (channel & mask) { - if (at_eof(s)) return epuc("bad file","PIC file too short"); - dest[i]=get8u(s); - } - } - - return dest; -} - -static void pic_copyval(int channel,stbi_uc *dest,const stbi_uc *src) -{ - int mask=0x80,i; - - for (i=0;i<4; ++i, mask>>=1) - if (channel&mask) - dest[i]=src[i]; -} - -static stbi_uc *pic_load2(stbi *s,int width,int height,int *comp, stbi_uc *result) -{ - int act_comp=0,num_packets=0,y,chained; - pic_packet_t packets[10]; - - // this will (should...) cater for even some bizarre stuff like having data - // for the same channel in multiple packets. - do { - pic_packet_t *packet; - - if (num_packets==sizeof(packets)/sizeof(packets[0])) - return epuc("bad format","too many packets"); - - packet = &packets[num_packets++]; - - chained = get8(s); - packet->size = get8u(s); - packet->type = get8u(s); - packet->channel = get8u(s); - - act_comp |= packet->channel; - - if (at_eof(s)) return epuc("bad file","file too short (reading packets)"); - if (packet->size != 8) return epuc("bad format","packet isn't 8bpp"); - } while (chained); - - *comp = (act_comp & 0x10 ? 4 : 3); // has alpha channel? - - for(y=0; ytype) { - default: - return epuc("bad format","packet has bad compression type"); - - case 0: {//uncompressed - int x; - - for(x=0;xchannel,dest)) - return 0; - break; - } - - case 1://Pure RLE - { - int left=width, i; - - while (left>0) { - stbi_uc count,value[4]; - - count=get8u(s); - if (at_eof(s)) return epuc("bad file","file too short (pure read count)"); - - if (count > left) - count = (uint8) left; - - if (!pic_readval(s,packet->channel,value)) return 0; - - for(i=0; ichannel,dest,value); - left -= count; - } - } - break; - - case 2: {//Mixed RLE - int left=width; - while (left>0) { - int count = get8(s), i; - if (at_eof(s)) return epuc("bad file","file too short (mixed read count)"); - - if (count >= 128) { // Repeated - stbi_uc value[4]; - int i; - - if (count==128) - count = get16(s); - else - count -= 127; - if (count > left) - return epuc("bad file","scanline overrun"); - - if (!pic_readval(s,packet->channel,value)) - return 0; - - for(i=0;ichannel,dest,value); - } else { // Raw - ++count; - if (count>left) return epuc("bad file","scanline overrun"); - - for(i=0;ichannel,dest)) - return 0; - } - left-=count; - } - break; - } - } - } - } - - return result; -} - -static stbi_uc *pic_load(stbi *s,int *px,int *py,int *comp,int req_comp) -{ - stbi_uc *result; - int i, x,y; - - for (i=0; i<92; ++i) - get8(s); - - x = get16(s); - y = get16(s); - if (at_eof(s)) return epuc("bad file","file too short (pic header)"); - if ((1 << 28) / x < y) return epuc("too large", "Image too large to decode"); - - get32(s); //skip `ratio' - get16(s); //skip `fields' - get16(s); //skip `pad' - - // intermediate buffer is RGBA - result = (stbi_uc *) malloc(x*y*4); - memset(result, 0xff, x*y*4); - - if (!pic_load2(s,x,y,comp, result)) { - free(result); - result=0; - } - *px = x; - *py = y; - if (req_comp == 0) req_comp = *comp; - result=convert_format(result,4,req_comp,x,y); - - return result; -} - -static int stbi_pic_test(stbi *s) -{ - int r = pic_test(s); - stbi_rewind(s); - return r; -} - -static stbi_uc *stbi_pic_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return pic_load(s,x,y,comp,req_comp); -} - -// ************************************************************************************************* -// GIF loader -- public domain by Jean-Marc Lienher -- simplified/shrunk by stb -typedef struct stbi_gif_lzw_struct { - int16 prefix; - uint8 first; - uint8 suffix; -} stbi_gif_lzw; - -typedef struct stbi_gif_struct -{ - int w,h; - stbi_uc *out; // output buffer (always 4 components) - int flags, bgindex, ratio, transparent, eflags; - uint8 pal[256][4]; - uint8 lpal[256][4]; - stbi_gif_lzw codes[4096]; - uint8 *color_table; - int parse, step; - int lflags; - int start_x, start_y; - int max_x, max_y; - int cur_x, cur_y; - int line_size; -} stbi_gif; - -static int gif_test(stbi *s) -{ - int sz; - if (get8(s) != 'G' || get8(s) != 'I' || get8(s) != 'F' || get8(s) != '8') return 0; - sz = get8(s); - if (sz != '9' && sz != '7') return 0; - if (get8(s) != 'a') return 0; - return 1; -} - -static int stbi_gif_test(stbi *s) -{ - int r = gif_test(s); - stbi_rewind(s); - return r; -} - -static void stbi_gif_parse_colortable(stbi *s, uint8 pal[256][4], int num_entries, int transp) -{ - int i; - for (i=0; i < num_entries; ++i) { - pal[i][2] = get8u(s); - pal[i][1] = get8u(s); - pal[i][0] = get8u(s); - pal[i][3] = transp ? 0 : 255; - } -} - -static int stbi_gif_header(stbi *s, stbi_gif *g, int *comp, int is_info) -{ - uint8 version; - if (get8(s) != 'G' || get8(s) != 'I' || get8(s) != 'F' || get8(s) != '8') - return e("not GIF", "Corrupt GIF"); - - version = get8u(s); - if (version != '7' && version != '9') return e("not GIF", "Corrupt GIF"); - if (get8(s) != 'a') return e("not GIF", "Corrupt GIF"); - - failure_reason = ""; - g->w = get16le(s); - g->h = get16le(s); - g->flags = get8(s); - g->bgindex = get8(s); - g->ratio = get8(s); - g->transparent = -1; - - if (comp != 0) *comp = 4; // can't actually tell whether it's 3 or 4 until we parse the comments - - if (is_info) return 1; - - if (g->flags & 0x80) - stbi_gif_parse_colortable(s,g->pal, 2 << (g->flags & 7), -1); - - return 1; -} - -static int stbi_gif_info_raw(stbi *s, int *x, int *y, int *comp) -{ - stbi_gif g; - if (!stbi_gif_header(s, &g, comp, 1)) { - stbi_rewind( s ); - return 0; - } - if (x) *x = g.w; - if (y) *y = g.h; - return 1; -} - -static void stbi_out_gif_code(stbi_gif *g, uint16 code) -{ - uint8 *p, *c; - - // recurse to decode the prefixes, since the linked-list is backwards, - // and working backwards through an interleaved image would be nasty - if (g->codes[code].prefix >= 0) - stbi_out_gif_code(g, g->codes[code].prefix); - - if (g->cur_y >= g->max_y) return; - - p = &g->out[g->cur_x + g->cur_y]; - c = &g->color_table[g->codes[code].suffix * 4]; - - if (c[3] >= 128) { - p[0] = c[2]; - p[1] = c[1]; - p[2] = c[0]; - p[3] = c[3]; - } - g->cur_x += 4; - - if (g->cur_x >= g->max_x) { - g->cur_x = g->start_x; - g->cur_y += g->step; - - while (g->cur_y >= g->max_y && g->parse > 0) { - g->step = (1 << g->parse) * g->line_size; - g->cur_y = g->start_y + (g->step >> 1); - --g->parse; - } - } -} - -static uint8 *stbi_process_gif_raster(stbi *s, stbi_gif *g) -{ - uint8 lzw_cs; - int32 len, code; - uint32 first; - int32 codesize, codemask, avail, oldcode, bits, valid_bits, clear; - stbi_gif_lzw *p; - - lzw_cs = get8u(s); - clear = 1 << lzw_cs; - first = 1; - codesize = lzw_cs + 1; - codemask = (1 << codesize) - 1; - bits = 0; - valid_bits = 0; - for (code = 0; code < clear; code++) { - g->codes[code].prefix = -1; - g->codes[code].first = (uint8) code; - g->codes[code].suffix = (uint8) code; - } - - // support no starting clear code - avail = clear+2; - oldcode = -1; - - len = 0; - for(;;) { - if (valid_bits < codesize) { - if (len == 0) { - len = get8(s); // start new block - if (len == 0) - return g->out; - } - --len; - bits |= (int32) get8(s) << valid_bits; - valid_bits += 8; - } else { - int32 code = bits & codemask; - bits >>= codesize; - valid_bits -= codesize; - // @OPTIMIZE: is there some way we can accelerate the non-clear path? - if (code == clear) { // clear code - codesize = lzw_cs + 1; - codemask = (1 << codesize) - 1; - avail = clear + 2; - oldcode = -1; - first = 0; - } else if (code == clear + 1) { // end of stream code - skip(s, len); - while ((len = get8(s)) > 0) - skip(s,len); - return g->out; - } else if (code <= avail) { - if (first) return epuc("no clear code", "Corrupt GIF"); - - if (oldcode >= 0) { - p = &g->codes[avail++]; - if (avail > 4096) return epuc("too many codes", "Corrupt GIF"); - p->prefix = (int16) oldcode; - p->first = g->codes[oldcode].first; - p->suffix = (code == avail) ? p->first : g->codes[code].first; - } else if (code == avail) - return epuc("illegal code in raster", "Corrupt GIF"); - - stbi_out_gif_code(g, (uint16) code); - - if ((avail & codemask) == 0 && avail <= 0x0FFF) { - codesize++; - codemask = (1 << codesize) - 1; - } - - oldcode = code; - } else { - return epuc("illegal code in raster", "Corrupt GIF"); - } - } - } -} - -static void stbi_fill_gif_background(stbi_gif *g) -{ - int i; - uint8 *c = g->pal[g->bgindex]; - // @OPTIMIZE: write a dword at a time - for (i = 0; i < g->w * g->h * 4; i += 4) { - uint8 *p = &g->out[i]; - p[0] = c[2]; - p[1] = c[1]; - p[2] = c[0]; - p[3] = c[3]; - } -} - -// this function is designed to support animated gifs, although stb_image doesn't support it -static uint8 *stbi_gif_load_next(stbi *s, stbi_gif *g, int *comp, int req_comp) -{ - int i; - uint8 *old_out = 0; - - if (g->out == 0) { - if (!stbi_gif_header(s, g, comp,0)) return 0; // failure_reason set by stbi_gif_header - g->out = (uint8 *) malloc(4 * g->w * g->h); - if (g->out == 0) return epuc("outofmem", "Out of memory"); - stbi_fill_gif_background(g); - } else { - // animated-gif-only path - if (((g->eflags & 0x1C) >> 2) == 3) { - old_out = g->out; - g->out = (uint8 *) malloc(4 * g->w * g->h); - if (g->out == 0) return epuc("outofmem", "Out of memory"); - memcpy(g->out, old_out, g->w*g->h*4); - } - } - - for (;;) { - switch (get8(s)) { - case 0x2C: /* Image Descriptor */ - { - int32 x, y, w, h; - uint8 *o; - - x = get16le(s); - y = get16le(s); - w = get16le(s); - h = get16le(s); - if (((x + w) > (g->w)) || ((y + h) > (g->h))) - return epuc("bad Image Descriptor", "Corrupt GIF"); - - g->line_size = g->w * 4; - g->start_x = x * 4; - g->start_y = y * g->line_size; - g->max_x = g->start_x + w * 4; - g->max_y = g->start_y + h * g->line_size; - g->cur_x = g->start_x; - g->cur_y = g->start_y; - - g->lflags = get8(s); - - if (g->lflags & 0x40) { - g->step = 8 * g->line_size; // first interlaced spacing - g->parse = 3; - } else { - g->step = g->line_size; - g->parse = 0; - } - - if (g->lflags & 0x80) { - stbi_gif_parse_colortable(s,g->lpal, 2 << (g->lflags & 7), g->eflags & 0x01 ? g->transparent : -1); - g->color_table = (uint8 *) g->lpal; - } else if (g->flags & 0x80) { - for (i=0; i < 256; ++i) // @OPTIMIZE: reset only the previous transparent - g->pal[i][3] = 255; - if (g->transparent >= 0 && (g->eflags & 0x01)) - g->pal[g->transparent][3] = 0; - g->color_table = (uint8 *) g->pal; - } else - return epuc("missing color table", "Corrupt GIF"); - - o = stbi_process_gif_raster(s, g); - if (o == NULL) return NULL; - - if (req_comp && req_comp != 4) - o = convert_format(o, 4, req_comp, g->w, g->h); - return o; - } - - case 0x21: // Comment Extension. - { - int len; - if (get8(s) == 0xF9) { // Graphic Control Extension. - len = get8(s); - if (len == 4) { - g->eflags = get8(s); - get16le(s); // delay - g->transparent = get8(s); - } else { - skip(s, len); - break; - } - } - while ((len = get8(s)) != 0) - skip(s, len); - break; - } - - case 0x3B: // gif stream termination code - return (uint8 *) 1; - - default: - return epuc("unknown code", "Corrupt GIF"); - } - } -} - -static stbi_uc *stbi_gif_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - uint8 *u = 0; - stbi_gif g={0}; - - u = stbi_gif_load_next(s, &g, comp, req_comp); - if (u == (void *) 1) u = 0; // end of animated gif marker - if (u) { - *x = g.w; - *y = g.h; - } - - return u; -} - -static int stbi_gif_info(stbi *s, int *x, int *y, int *comp) -{ - return stbi_gif_info_raw(s,x,y,comp); -} - - -// ************************************************************************************************* -// Radiance RGBE HDR loader -// originally by Nicolas Schulz -#ifndef STBI_NO_HDR -static int hdr_test(stbi *s) -{ - const char *signature = "#?RADIANCE\n"; - int i; - for (i=0; signature[i]; ++i) - if (get8(s) != signature[i]) - return 0; - return 1; -} - -static int stbi_hdr_test(stbi* s) -{ - int r = hdr_test(s); - stbi_rewind(s); - return r; -} - -#define HDR_BUFLEN 1024 -static char *hdr_gettoken(stbi *z, char *buffer) -{ - int len=0; - char c = '\0'; - - c = (char) get8(z); - - while (!at_eof(z) && c != '\n') { - buffer[len++] = c; - if (len == HDR_BUFLEN-1) { - // flush to end of line - while (!at_eof(z) && get8(z) != '\n') - ; - break; - } - c = (char) get8(z); - } - - buffer[len] = 0; - return buffer; -} - -static void hdr_convert(float *output, stbi_uc *input, int req_comp) -{ - if ( input[3] != 0 ) { - float f1; - // Exponent - f1 = (float) ldexp(1.0f, input[3] - (int)(128 + 8)); - if (req_comp <= 2) - output[0] = (input[0] + input[1] + input[2]) * f1 / 3; - else { - output[0] = input[0] * f1; - output[1] = input[1] * f1; - output[2] = input[2] * f1; - } - if (req_comp == 2) output[1] = 1; - if (req_comp == 4) output[3] = 1; - } else { - switch (req_comp) { - case 4: output[3] = 1; /* fallthrough */ - case 3: output[0] = output[1] = output[2] = 0; - break; - case 2: output[1] = 1; /* fallthrough */ - case 1: output[0] = 0; - break; - } - } -} - -static float *hdr_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - char buffer[HDR_BUFLEN]; - char *token; - int valid = 0; - int width, height; - stbi_uc *scanline; - float *hdr_data; - int len; - unsigned char count, value; - int i, j, k, c1,c2, z; - - - // Check identifier - if (strcmp(hdr_gettoken(s,buffer), "#?RADIANCE") != 0) - return epf("not HDR", "Corrupt HDR image"); - - // Parse header - for(;;) { - token = hdr_gettoken(s,buffer); - if (token[0] == 0) break; - if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) valid = 1; - } - - if (!valid) return epf("unsupported format", "Unsupported HDR format"); - - // Parse width and height - // can't use sscanf() if we're not using stdio! - token = hdr_gettoken(s,buffer); - if (strncmp(token, "-Y ", 3)) return epf("unsupported data layout", "Unsupported HDR format"); - token += 3; - height = strtol(token, &token, 10); - while (*token == ' ') ++token; - if (strncmp(token, "+X ", 3)) return epf("unsupported data layout", "Unsupported HDR format"); - token += 3; - width = strtol(token, NULL, 10); - - *x = width; - *y = height; - - *comp = 3; - if (req_comp == 0) req_comp = 3; - - // Read data - hdr_data = (float *) malloc(height * width * req_comp * sizeof(float)); - - // Load image data - // image data is stored as some number of sca - if ( width < 8 || width >= 32768) { - // Read flat data - for (j=0; j < height; ++j) { - for (i=0; i < width; ++i) { - stbi_uc rgbe[4]; - main_decode_loop: - getn(s, rgbe, 4); - hdr_convert(hdr_data + j * width * req_comp + i * req_comp, rgbe, req_comp); - } - } - } else { - // Read RLE-encoded data - scanline = NULL; - - for (j = 0; j < height; ++j) { - c1 = get8(s); - c2 = get8(s); - len = get8(s); - if (c1 != 2 || c2 != 2 || (len & 0x80)) { - // not run-length encoded, so we have to actually use THIS data as a decoded - // pixel (note this can't be a valid pixel--one of RGB must be >= 128) - uint8 rgbe[4]; - rgbe[0] = (uint8) c1; - rgbe[1] = (uint8) c2; - rgbe[2] = (uint8) len; - rgbe[3] = (uint8) get8u(s); - hdr_convert(hdr_data, rgbe, req_comp); - i = 1; - j = 0; - free(scanline); - goto main_decode_loop; // yes, this makes no sense - } - len <<= 8; - len |= get8(s); - if (len != width) { free(hdr_data); free(scanline); return epf("invalid decoded scanline length", "corrupt HDR"); } - if (scanline == NULL) scanline = (stbi_uc *) malloc(width * 4); - - for (k = 0; k < 4; ++k) { - i = 0; - while (i < width) { - count = get8u(s); - if (count > 128) { - // Run - value = get8u(s); - count -= 128; - for (z = 0; z < count; ++z) - scanline[i++ * 4 + k] = value; - } else { - // Dump - for (z = 0; z < count; ++z) - scanline[i++ * 4 + k] = get8u(s); - } - } - } - for (i=0; i < width; ++i) - hdr_convert(hdr_data+(j*width + i)*req_comp, scanline + i*4, req_comp); - } - free(scanline); - } - - return hdr_data; -} - -static float *stbi_hdr_load(stbi *s, int *x, int *y, int *comp, int req_comp) -{ - return hdr_load(s,x,y,comp,req_comp); -} - -static int stbi_hdr_info(stbi *s, int *x, int *y, int *comp) -{ - char buffer[HDR_BUFLEN]; - char *token; - int valid = 0; - - if (strcmp(hdr_gettoken(s,buffer), "#?RADIANCE") != 0) { - stbi_rewind( s ); - return 0; - } - - for(;;) { - token = hdr_gettoken(s,buffer); - if (token[0] == 0) break; - if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) valid = 1; - } - - if (!valid) { - stbi_rewind( s ); - return 0; - } - token = hdr_gettoken(s,buffer); - if (strncmp(token, "-Y ", 3)) { - stbi_rewind( s ); - return 0; - } - token += 3; - *y = strtol(token, &token, 10); - while (*token == ' ') ++token; - if (strncmp(token, "+X ", 3)) { - stbi_rewind( s ); - return 0; - } - token += 3; - *x = strtol(token, NULL, 10); - *comp = 3; - return 1; -} -#endif // STBI_NO_HDR - -static int stbi_bmp_info(stbi *s, int *x, int *y, int *comp) -{ - int hsz; - if (get8(s) != 'B' || get8(s) != 'M') { - stbi_rewind( s ); - return 0; - } - skip(s,12); - hsz = get32le(s); - if (hsz != 12 && hsz != 40 && hsz != 56 && hsz != 108) { - stbi_rewind( s ); - return 0; - } - if (hsz == 12) { - *x = get16le(s); - *y = get16le(s); - } else { - *x = get32le(s); - *y = get32le(s); - } - if (get16le(s) != 1) { - stbi_rewind( s ); - return 0; - } - *comp = get16le(s) / 8; - return 1; -} - -static int stbi_psd_info(stbi *s, int *x, int *y, int *comp) -{ - int channelCount; - if (get32(s) != 0x38425053) { - stbi_rewind( s ); - return 0; - } - if (get16(s) != 1) { - stbi_rewind( s ); - return 0; - } - skip(s, 6); - channelCount = get16(s); - if (channelCount < 0 || channelCount > 16) { - stbi_rewind( s ); - return 0; - } - *y = get32(s); - *x = get32(s); - if (get16(s) != 8) { - stbi_rewind( s ); - return 0; - } - if (get16(s) != 3) { - stbi_rewind( s ); - return 0; - } - *comp = 4; - return 1; -} - -static int stbi_pic_info(stbi *s, int *x, int *y, int *comp) -{ - int act_comp=0,num_packets=0,chained; - pic_packet_t packets[10]; - - skip(s, 92); - - *x = get16(s); - *y = get16(s); - if (at_eof(s)) return 0; - if ( (*x) != 0 && (1 << 28) / (*x) < (*y)) { - stbi_rewind( s ); - return 0; - } - - skip(s, 8); - - do { - pic_packet_t *packet; - - if (num_packets==sizeof(packets)/sizeof(packets[0])) - return 0; - - packet = &packets[num_packets++]; - chained = get8(s); - packet->size = get8u(s); - packet->type = get8u(s); - packet->channel = get8u(s); - act_comp |= packet->channel; - - if (at_eof(s)) { - stbi_rewind( s ); - return 0; - } - if (packet->size != 8) { - stbi_rewind( s ); - return 0; - } - } while (chained); - - *comp = (act_comp & 0x10 ? 4 : 3); - - return 1; -} - -static int stbi_info_main(stbi *s, int *x, int *y, int *comp) -{ - if (stbi_jpeg_info(s, x, y, comp)) - return 1; - if (stbi_png_info(s, x, y, comp)) - return 1; - if (stbi_gif_info(s, x, y, comp)) - return 1; - if (stbi_bmp_info(s, x, y, comp)) - return 1; - if (stbi_psd_info(s, x, y, comp)) - return 1; - if (stbi_pic_info(s, x, y, comp)) - return 1; - #ifndef STBI_NO_HDR - if (stbi_hdr_info(s, x, y, comp)) - return 1; - #endif - // test tga last because it's a crappy test! - if (stbi_tga_info(s, x, y, comp)) - return 1; - return e("unknown image type", "Image not of any known type, or corrupt"); -} - -#ifndef STBI_NO_STDIO -int stbi_info(char const *filename, int *x, int *y, int *comp) -{ - FILE *f = fopen(filename, "rb"); - int result; - if (!f) return e("can't fopen", "Unable to open file"); - result = stbi_info_from_file(f, x, y, comp); - fclose(f); - return result; -} - -int stbi_info_from_file(FILE *f, int *x, int *y, int *comp) -{ - int r; - stbi s; - long pos = ftell(f); - start_file(&s, f); - r = stbi_info_main(&s,x,y,comp); - fseek(f,pos,SEEK_SET); - return r; -} -#endif // !STBI_NO_STDIO - -int stbi_info_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp) -{ - stbi s; - start_mem(&s,buffer,len); - return stbi_info_main(&s,x,y,comp); -} - -int stbi_info_from_callbacks(stbi_io_callbacks const *c, void *user, int *x, int *y, int *comp) -{ - stbi s; - start_callbacks(&s, (stbi_io_callbacks *) c, user); - return stbi_info_main(&s,x,y,comp); -} - -#endif // STBI_HEADER_FILE_ONLY - -/* - revision history: - 1.33 (2011-07-14) - make stbi_is_hdr work in STBI_NO_HDR (as specified), minor compiler-friendly improvements - 1.32 (2011-07-13) - support for "info" function for all supported filetypes (SpartanJ) - 1.31 (2011-06-20) - a few more leak fixes, bug in PNG handling (SpartanJ) - 1.30 (2011-06-11) - added ability to load files via callbacks to accomidate custom input streams (Ben Wenger) - removed deprecated format-specific test/load functions - removed support for installable file formats (stbi_loader) -- would have been broken for IO callbacks anyway - error cases in bmp and tga give messages and don't leak (Raymond Barbiero, grisha) - fix inefficiency in decoding 32-bit BMP (David Woo) - 1.29 (2010-08-16) - various warning fixes from Aurelien Pocheville - 1.28 (2010-08-01) - fix bug in GIF palette transparency (SpartanJ) - 1.27 (2010-08-01) - cast-to-uint8 to fix warnings - 1.26 (2010-07-24) - fix bug in file buffering for PNG reported by SpartanJ - 1.25 (2010-07-17) - refix trans_data warning (Won Chun) - 1.24 (2010-07-12) - perf improvements reading from files on platforms with lock-heavy fgetc() - minor perf improvements for jpeg - deprecated type-specific functions so we'll get feedback if they're needed - attempt to fix trans_data warning (Won Chun) - 1.23 fixed bug in iPhone support - 1.22 (2010-07-10) - removed image *writing* support - stbi_info support from Jetro Lauha - GIF support from Jean-Marc Lienher - iPhone PNG-extensions from James Brown - warning-fixes from Nicolas Schulz and Janez Zemva (i.e. Janez (U+017D)emva) - 1.21 fix use of 'uint8' in header (reported by jon blow) - 1.20 added support for Softimage PIC, by Tom Seddon - 1.19 bug in interlaced PNG corruption check (found by ryg) - 1.18 2008-08-02 - fix a threading bug (local mutable static) - 1.17 support interlaced PNG - 1.16 major bugfix - convert_format converted one too many pixels - 1.15 initialize some fields for thread safety - 1.14 fix threadsafe conversion bug - header-file-only version (#define STBI_HEADER_FILE_ONLY before including) - 1.13 threadsafe - 1.12 const qualifiers in the API - 1.11 Support installable IDCT, colorspace conversion routines - 1.10 Fixes for 64-bit (don't use "unsigned long") - optimized upsampling by Fabian "ryg" Giesen - 1.09 Fix format-conversion for PSD code (bad global variables!) - 1.08 Thatcher Ulrich's PSD code integrated by Nicolas Schulz - 1.07 attempt to fix C++ warning/errors again - 1.06 attempt to fix C++ warning/errors again - 1.05 fix TGA loading to return correct *comp and use good luminance calc - 1.04 default float alpha is 1, not 255; use 'void *' for stbi_image_free - 1.03 bugfixes to STBI_NO_STDIO, STBI_NO_HDR - 1.02 support for (subset of) HDR files, float interface for preferred access to them - 1.01 fix bug: possible bug in handling right-side up bmps... not sure - fix bug: the stbi_bmp_load() and stbi_tga_load() functions didn't work at all - 1.00 interface to zlib that skips zlib header - 0.99 correct handling of alpha in palette - 0.98 TGA loader by lonesock; dynamically add loaders (untested) - 0.97 jpeg errors on too large a file; also catch another malloc failure - 0.96 fix detection of invalid v value - particleman@mollyrocket forum - 0.95 during header scan, seek to markers in case of padding - 0.94 STBI_NO_STDIO to disable stdio usage; rename all #defines the same - 0.93 handle jpegtran output; verbose errors - 0.92 read 4,8,16,24,32-bit BMP files of several formats - 0.91 output 24-bit Windows 3.0 BMP files - 0.90 fix a few more warnings; bump version number to approach 1.0 - 0.61 bugfixes due to Marc LeBlanc, Christopher Lloyd - 0.60 fix compiling as c++ - 0.59 fix warnings: merge Dave Moore's -Wall fixes - 0.58 fix bug: zlib uncompressed mode len/nlen was wrong endian - 0.57 fix bug: jpg last huffman symbol before marker was >9 bits but less than 16 available - 0.56 fix bug: zlib uncompressed mode len vs. nlen - 0.55 fix bug: restart_interval not initialized to 0 - 0.54 allow NULL for 'int *comp' - 0.53 fix bug in png 3->4; speedup png decoding - 0.52 png handles req_comp=3,4 directly; minor cleanup; jpeg comments - 0.51 obey req_comp requests, 1-component jpegs return as 1-component, - on 'test' only check type, not whether we support this variant - 0.50 first released version -*/ diff --git a/btgui/stb_image/stb_image.h b/btgui/stb_image/stb_image.h deleted file mode 100644 index f66bfd12f..000000000 --- a/btgui/stb_image/stb_image.h +++ /dev/null @@ -1,332 +0,0 @@ -/* stbi-1.33 - public domain JPEG/PNG reader - http://nothings.org/stb_image.c - when you control the images you're loading - no warranty implied; use at your own risk - - QUICK NOTES: - Primarily of interest to game developers and other people who can - avoid problematic images and only need the trivial interface - - JPEG baseline (no JPEG progressive) - PNG 8-bit only - - TGA (not sure what subset, if a subset) - BMP non-1bpp, non-RLE - PSD (composited view only, no extra channels) - - GIF (*comp always reports as 4-channel) - HDR (radiance rgbE format) - PIC (Softimage PIC) - - - decode from memory or through FILE (define STBI_NO_STDIO to remove code) - - decode from arbitrary I/O callbacks - - overridable dequantizing-IDCT, YCbCr-to-RGB conversion (define STBI_SIMD) - - Latest revisions: - 1.33 (2011-07-14) minor fixes suggested by Dave Moore - 1.32 (2011-07-13) info support for all filetypes (SpartanJ) - 1.31 (2011-06-19) a few more leak fixes, bug in PNG handling (SpartanJ) - 1.30 (2011-06-11) added ability to load files via io callbacks (Ben Wenger) - 1.29 (2010-08-16) various warning fixes from Aurelien Pocheville - 1.28 (2010-08-01) fix bug in GIF palette transparency (SpartanJ) - 1.27 (2010-08-01) cast-to-uint8 to fix warnings (Laurent Gomila) - allow trailing 0s at end of image data (Laurent Gomila) - 1.26 (2010-07-24) fix bug in file buffering for PNG reported by SpartanJ - - See end of file for full revision history. - - TODO: - stbi_info support for BMP,PSD,HDR,PIC - - - ============================ Contributors ========================= - - Image formats Optimizations & bugfixes - Sean Barrett (jpeg, png, bmp) Fabian "ryg" Giesen - Nicolas Schulz (hdr, psd) - Jonathan Dummer (tga) Bug fixes & warning fixes - Jean-Marc Lienher (gif) Marc LeBlanc - Tom Seddon (pic) Christpher Lloyd - Thatcher Ulrich (psd) Dave Moore - Won Chun - the Horde3D community - Extensions, features Janez Zemva - Jetro Lauha (stbi_info) Jonathan Blow - James "moose2000" Brown (iPhone PNG) Laurent Gomila - Ben "Disch" Wenger (io callbacks) Aruelien Pocheville - Martin "SpartanJ" Golini Ryamond Barbiero - David Woo - - - If your name should be here but isn't, let Sean know. - -*/ - -#ifndef STBI_INCLUDE_STB_IMAGE_H -#define STBI_INCLUDE_STB_IMAGE_H - -// To get a header file for this, either cut and paste the header, -// or create stb_image.h, #define STBI_HEADER_FILE_ONLY, and -// then include stb_image.c from it. - -//// begin header file //////////////////////////////////////////////////// -// -// Limitations: -// - no jpeg progressive support -// - non-HDR formats support 8-bit samples only (jpeg, png) -// - no delayed line count (jpeg) -- IJG doesn't support either -// - no 1-bit BMP -// - GIF always returns *comp=4 -// -// Basic usage (see HDR discussion below): -// int x,y,n; -// unsigned char *data = stbi_load(filename, &x, &y, &n, 0); -// // ... process data if not NULL ... -// // ... x = width, y = height, n = # 8-bit components per pixel ... -// // ... replace '0' with '1'..'4' to force that many components per pixel -// // ... but 'n' will always be the number that it would have been if you said 0 -// stbi_image_free(data) -// -// Standard parameters: -// int *x -- outputs image width in pixels -// int *y -- outputs image height in pixels -// int *comp -- outputs # of image components in image file -// int req_comp -- if non-zero, # of image components requested in result -// -// The return value from an image loader is an 'unsigned char *' which points -// to the pixel data. The pixel data consists of *y scanlines of *x pixels, -// with each pixel consisting of N interleaved 8-bit components; the first -// pixel pointed to is top-left-most in the image. There is no padding between -// image scanlines or between pixels, regardless of format. The number of -// components N is 'req_comp' if req_comp is non-zero, or *comp otherwise. -// If req_comp is non-zero, *comp has the number of components that _would_ -// have been output otherwise. E.g. if you set req_comp to 4, you will always -// get RGBA output, but you can check *comp to easily see if it's opaque. -// -// An output image with N components has the following components interleaved -// in this order in each pixel: -// -// N=#comp components -// 1 grey -// 2 grey, alpha -// 3 red, green, blue -// 4 red, green, blue, alpha -// -// If image loading fails for any reason, the return value will be NULL, -// and *x, *y, *comp will be unchanged. The function stbi_failure_reason() -// can be queried for an extremely brief, end-user unfriendly explanation -// of why the load failed. Define STBI_NO_FAILURE_STRINGS to avoid -// compiling these strings at all, and STBI_FAILURE_USERMSG to get slightly -// more user-friendly ones. -// -// Paletted PNG, BMP, GIF, and PIC images are automatically depalettized. -// -// =========================================================================== -// -// iPhone PNG support: -// -// By default we convert iphone-formatted PNGs back to RGB; nominally they -// would silently load as BGR, except the existing code should have just -// failed on such iPhone PNGs. But you can disable this conversion by -// by calling stbi_convert_iphone_png_to_rgb(0), in which case -// you will always just get the native iphone "format" through. -// -// Call stbi_set_unpremultiply_on_load(1) as well to force a divide per -// pixel to remove any premultiplied alpha *only* if the image file explicitly -// says there's premultiplied data (currently only happens in iPhone images, -// and only if iPhone convert-to-rgb processing is on). -// -// =========================================================================== -// -// HDR image support (disable by defining STBI_NO_HDR) -// -// stb_image now supports loading HDR images in general, and currently -// the Radiance .HDR file format, although the support is provided -// generically. You can still load any file through the existing interface; -// if you attempt to load an HDR file, it will be automatically remapped to -// LDR, assuming gamma 2.2 and an arbitrary scale factor defaulting to 1; -// both of these constants can be reconfigured through this interface: -// -// stbi_hdr_to_ldr_gamma(2.2f); -// stbi_hdr_to_ldr_scale(1.0f); -// -// (note, do not use _inverse_ constants; stbi_image will invert them -// appropriately). -// -// Additionally, there is a new, parallel interface for loading files as -// (linear) floats to preserve the full dynamic range: -// -// float *data = stbi_loadf(filename, &x, &y, &n, 0); -// -// If you load LDR images through this interface, those images will -// be promoted to floating point values, run through the inverse of -// constants corresponding to the above: -// -// stbi_ldr_to_hdr_scale(1.0f); -// stbi_ldr_to_hdr_gamma(2.2f); -// -// Finally, given a filename (or an open file or memory block--see header -// file for details) containing image data, you can query for the "most -// appropriate" interface to use (that is, whether the image is HDR or -// not), using: -// -// stbi_is_hdr(char *filename); -// -// =========================================================================== -// -// I/O callbacks -// -// I/O callbacks allow you to read from arbitrary sources, like packaged -// files or some other source. Data read from callbacks are processed -// through a small internal buffer (currently 128 bytes) to try to reduce -// overhead. -// -// The three functions you must define are "read" (reads some bytes of data), -// "skip" (skips some bytes of data), "eof" (reports if the stream is at the end). - - -#ifndef STBI_NO_STDIO - -#if defined(_MSC_VER) && _MSC_VER >= 0x1400 -#define _CRT_SECURE_NO_WARNINGS // suppress bogus warnings about fopen() -#endif - -#include -#endif - -#define STBI_VERSION 1 - -enum -{ - STBI_default = 0, // only used for req_comp - - STBI_grey = 1, - STBI_grey_alpha = 2, - STBI_rgb = 3, - STBI_rgb_alpha = 4 -}; - -typedef unsigned char stbi_uc; - -#ifdef __cplusplus -extern "C" { -#endif - -////////////////////////////////////////////////////////////////////////////// -// -// PRIMARY API - works on images of any type -// - -// -// load image by filename, open file, or memory buffer -// - -extern stbi_uc *stbi_load_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp); - -#ifndef STBI_NO_STDIO -extern stbi_uc *stbi_load (char const *filename, int *x, int *y, int *comp, int req_comp); -extern stbi_uc *stbi_load_from_file (FILE *f, int *x, int *y, int *comp, int req_comp); -// for stbi_load_from_file, file pointer is left pointing immediately after image -#endif - -typedef struct -{ - int (*read) (void *user,char *data,int size); // fill 'data' with 'size' bytes. return number of bytes actually read - void (*skip) (void *user,unsigned n); // skip the next 'n' bytes - int (*eof) (void *user); // returns nonzero if we are at end of file/data -} stbi_io_callbacks; - -extern stbi_uc *stbi_load_from_callbacks (stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp); - -#ifndef STBI_NO_HDR - extern float *stbi_loadf_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp); - - #ifndef STBI_NO_STDIO - extern float *stbi_loadf (char const *filename, int *x, int *y, int *comp, int req_comp); - extern float *stbi_loadf_from_file (FILE *f, int *x, int *y, int *comp, int req_comp); - #endif - - extern float *stbi_loadf_from_callbacks (stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp); - - extern void stbi_hdr_to_ldr_gamma(float gamma); - extern void stbi_hdr_to_ldr_scale(float scale); - - extern void stbi_ldr_to_hdr_gamma(float gamma); - extern void stbi_ldr_to_hdr_scale(float scale); -#endif // STBI_NO_HDR - -// stbi_is_hdr is always defined -extern int stbi_is_hdr_from_callbacks(stbi_io_callbacks const *clbk, void *user); -extern int stbi_is_hdr_from_memory(stbi_uc const *buffer, int len); -#ifndef STBI_NO_STDIO -extern int stbi_is_hdr (char const *filename); -extern int stbi_is_hdr_from_file(FILE *f); -#endif // STBI_NO_STDIO - - -// get a VERY brief reason for failure -// NOT THREADSAFE -extern const char *stbi_failure_reason (void); - -// free the loaded image -- this is just free() -extern void stbi_image_free (void *retval_from_stbi_load); - -// get image dimensions & components without fully decoding -extern int stbi_info_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp); -extern int stbi_info_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp); - -#ifndef STBI_NO_STDIO -extern int stbi_info (char const *filename, int *x, int *y, int *comp); -extern int stbi_info_from_file (FILE *f, int *x, int *y, int *comp); - -#endif - - - -// for image formats that explicitly notate that they have premultiplied alpha, -// we just return the colors as stored in the file. set this flag to force -// unpremultiplication. results are undefined if the unpremultiply overflow. -extern void stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply); - -// indicate whether we should process iphone images back to canonical format, -// or just pass them through "as-is" -extern void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert); - - -// ZLIB client - used by PNG, available for other purposes - -extern char *stbi_zlib_decode_malloc_guesssize(const char *buffer, int len, int initial_size, int *outlen); -extern char *stbi_zlib_decode_malloc(const char *buffer, int len, int *outlen); -extern int stbi_zlib_decode_buffer(char *obuffer, int olen, const char *ibuffer, int ilen); - -extern char *stbi_zlib_decode_noheader_malloc(const char *buffer, int len, int *outlen); -extern int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char *ibuffer, int ilen); - - -// define faster low-level operations (typically SIMD support) -#ifdef STBI_SIMD -typedef void (*stbi_idct_8x8)(stbi_uc *out, int out_stride, short data[64], unsigned short *dequantize); -// compute an integer IDCT on "input" -// input[x] = data[x] * dequantize[x] -// write results to 'out': 64 samples, each run of 8 spaced by 'out_stride' -// CLAMP results to 0..255 -typedef void (*stbi_YCbCr_to_RGB_run)(stbi_uc *output, stbi_uc const *y, stbi_uc const *cb, stbi_uc const *cr, int count, int step); -// compute a conversion from YCbCr to RGB -// 'count' pixels -// write pixels to 'output'; each pixel is 'step' bytes (either 3 or 4; if 4, write '255' as 4th), order R,G,B -// y: Y input channel -// cb: Cb input channel; scale/biased to be 0..255 -// cr: Cr input channel; scale/biased to be 0..255 - -extern void stbi_install_idct(stbi_idct_8x8 func); -extern void stbi_install_YCbCr_to_RGB(stbi_YCbCr_to_RGB_run func); -#endif // STBI_SIMD - - -#ifdef __cplusplus -} -#endif - -// -// -//// end header file ///////////////////////////////////////////////////// -#endif // STBI_INCLUDE_STB_IMAGE_H diff --git a/btgui/tinyxml/tinystr.cpp b/btgui/tinyxml/tinystr.cpp deleted file mode 100755 index 066576820..000000000 --- a/btgui/tinyxml/tinystr.cpp +++ /dev/null @@ -1,111 +0,0 @@ -/* -www.sourceforge.net/projects/tinyxml - -This software is provided 'as-is', without any express or implied -warranty. In no event will the authors be held liable for any -damages arising from the use of this software. - -Permission is granted to anyone to use this software for any -purpose, including commercial applications, and to alter it and -redistribute it freely, subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must -not claim that you wrote the original software. If you use this -software in a product, an acknowledgment in the product documentation -would be appreciated but is not required. - -2. Altered source versions must be plainly marked as such, and -must not be misrepresented as being the original software. - -3. This notice may not be removed or altered from any source -distribution. -*/ - - -#ifndef TIXML_USE_STL - -#include "tinystr.h" - -// Error value for find primitive -const TiXmlString::size_type TiXmlString::npos = static_cast< TiXmlString::size_type >(-1); - - -// Null rep. -TiXmlString::Rep TiXmlString::nullrep_ = { 0, 0, { '\0' } }; - - -void TiXmlString::reserve (size_type cap) -{ - if (cap > capacity()) - { - TiXmlString tmp; - tmp.init(length(), cap); - memcpy(tmp.start(), data(), length()); - swap(tmp); - } -} - - -TiXmlString& TiXmlString::assign(const char* str, size_type len) -{ - size_type cap = capacity(); - if (len > cap || cap > 3*(len + 8)) - { - TiXmlString tmp; - tmp.init(len); - memcpy(tmp.start(), str, len); - swap(tmp); - } - else - { - memmove(start(), str, len); - set_size(len); - } - return *this; -} - - -TiXmlString& TiXmlString::append(const char* str, size_type len) -{ - size_type newsize = length() + len; - if (newsize > capacity()) - { - reserve (newsize + capacity()); - } - memmove(finish(), str, len); - set_size(newsize); - return *this; -} - - -TiXmlString operator + (const TiXmlString & a, const TiXmlString & b) -{ - TiXmlString tmp; - tmp.reserve(a.length() + b.length()); - tmp += a; - tmp += b; - return tmp; -} - -TiXmlString operator + (const TiXmlString & a, const char* b) -{ - TiXmlString tmp; - TiXmlString::size_type b_len = static_cast( strlen(b) ); - tmp.reserve(a.length() + b_len); - tmp += a; - tmp.append(b, b_len); - return tmp; -} - -TiXmlString operator + (const char* a, const TiXmlString & b) -{ - TiXmlString tmp; - TiXmlString::size_type a_len = static_cast( strlen(a) ); - tmp.reserve(a_len + b.length()); - tmp.append(a, a_len); - tmp += b; - return tmp; -} - - -#endif // TIXML_USE_STL diff --git a/btgui/tinyxml/tinystr.h b/btgui/tinyxml/tinystr.h deleted file mode 100755 index 89cca3341..000000000 --- a/btgui/tinyxml/tinystr.h +++ /dev/null @@ -1,305 +0,0 @@ -/* -www.sourceforge.net/projects/tinyxml - -This software is provided 'as-is', without any express or implied -warranty. In no event will the authors be held liable for any -damages arising from the use of this software. - -Permission is granted to anyone to use this software for any -purpose, including commercial applications, and to alter it and -redistribute it freely, subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must -not claim that you wrote the original software. If you use this -software in a product, an acknowledgment in the product documentation -would be appreciated but is not required. - -2. Altered source versions must be plainly marked as such, and -must not be misrepresented as being the original software. - -3. This notice may not be removed or altered from any source -distribution. -*/ - - -#ifndef TIXML_USE_STL - -#ifndef TIXML_STRING_INCLUDED -#define TIXML_STRING_INCLUDED - -#include -#include - -/* The support for explicit isn't that universal, and it isn't really - required - it is used to check that the TiXmlString class isn't incorrectly - used. Be nice to old compilers and macro it here: -*/ -#if defined(_MSC_VER) && (_MSC_VER >= 1200 ) - // Microsoft visual studio, version 6 and higher. - #define TIXML_EXPLICIT explicit -#elif defined(__GNUC__) && (__GNUC__ >= 3 ) - // GCC version 3 and higher.s - #define TIXML_EXPLICIT explicit -#else - #define TIXML_EXPLICIT -#endif - - -/* - TiXmlString is an emulation of a subset of the std::string template. - Its purpose is to allow compiling TinyXML on compilers with no or poor STL support. - Only the member functions relevant to the TinyXML project have been implemented. - The buffer allocation is made by a simplistic power of 2 like mechanism : if we increase - a string and there's no more room, we allocate a buffer twice as big as we need. -*/ -class TiXmlString -{ - public : - // The size type used - typedef size_t size_type; - - // Error value for find primitive - static const size_type npos; // = -1; - - - // TiXmlString empty constructor - TiXmlString () : rep_(&nullrep_) - { - } - - // TiXmlString copy constructor - TiXmlString ( const TiXmlString & copy) : rep_(0) - { - init(copy.length()); - memcpy(start(), copy.data(), length()); - } - - // TiXmlString constructor, based on a string - TIXML_EXPLICIT TiXmlString ( const char * copy) : rep_(0) - { - init( static_cast( strlen(copy) )); - memcpy(start(), copy, length()); - } - - // TiXmlString constructor, based on a string - TIXML_EXPLICIT TiXmlString ( const char * str, size_type len) : rep_(0) - { - init(len); - memcpy(start(), str, len); - } - - // TiXmlString destructor - ~TiXmlString () - { - quit(); - } - - TiXmlString& operator = (const char * copy) - { - return assign( copy, (size_type)strlen(copy)); - } - - TiXmlString& operator = (const TiXmlString & copy) - { - return assign(copy.start(), copy.length()); - } - - - // += operator. Maps to append - TiXmlString& operator += (const char * suffix) - { - return append(suffix, static_cast( strlen(suffix) )); - } - - // += operator. Maps to append - TiXmlString& operator += (char single) - { - return append(&single, 1); - } - - // += operator. Maps to append - TiXmlString& operator += (const TiXmlString & suffix) - { - return append(suffix.data(), suffix.length()); - } - - - // Convert a TiXmlString into a null-terminated char * - const char * c_str () const { return rep_->str; } - - // Convert a TiXmlString into a char * (need not be null terminated). - const char * data () const { return rep_->str; } - - // Return the length of a TiXmlString - size_type length () const { return rep_->size; } - - // Alias for length() - size_type size () const { return rep_->size; } - - // Checks if a TiXmlString is empty - bool empty () const { return rep_->size == 0; } - - // Return capacity of string - size_type capacity () const { return rep_->capacity; } - - - // single char extraction - const char& at (size_type index) const - { - assert( index < length() ); - return rep_->str[ index ]; - } - - // [] operator - char& operator [] (size_type index) const - { - assert( index < length() ); - return rep_->str[ index ]; - } - - // find a char in a string. Return TiXmlString::npos if not found - size_type find (char lookup) const - { - return find(lookup, 0); - } - - // find a char in a string from an offset. Return TiXmlString::npos if not found - size_type find (char tofind, size_type offset) const - { - if (offset >= length()) return npos; - - for (const char* p = c_str() + offset; *p != '\0'; ++p) - { - if (*p == tofind) return static_cast< size_type >( p - c_str() ); - } - return npos; - } - - void clear () - { - //Lee: - //The original was just too strange, though correct: - // TiXmlString().swap(*this); - //Instead use the quit & re-init: - quit(); - init(0,0); - } - - /* Function to reserve a big amount of data when we know we'll need it. Be aware that this - function DOES NOT clear the content of the TiXmlString if any exists. - */ - void reserve (size_type cap); - - TiXmlString& assign (const char* str, size_type len); - - TiXmlString& append (const char* str, size_type len); - - void swap (TiXmlString& other) - { - Rep* r = rep_; - rep_ = other.rep_; - other.rep_ = r; - } - - private: - - void init(size_type sz) { init(sz, sz); } - void set_size(size_type sz) { rep_->str[ rep_->size = sz ] = '\0'; } - char* start() const { return rep_->str; } - char* finish() const { return rep_->str + rep_->size; } - - struct Rep - { - size_type size, capacity; - char str[1]; - }; - - void init(size_type sz, size_type cap) - { - if (cap) - { - // Lee: the original form: - // rep_ = static_cast(operator new(sizeof(Rep) + cap)); - // doesn't work in some cases of new being overloaded. Switching - // to the normal allocation, although use an 'int' for systems - // that are overly picky about structure alignment. - const size_type bytesNeeded = sizeof(Rep) + cap; - const size_type intsNeeded = ( bytesNeeded + sizeof(int) - 1 ) / sizeof( int ); - rep_ = reinterpret_cast( new int[ intsNeeded ] ); - - rep_->str[ rep_->size = sz ] = '\0'; - rep_->capacity = cap; - } - else - { - rep_ = &nullrep_; - } - } - - void quit() - { - if (rep_ != &nullrep_) - { - // The rep_ is really an array of ints. (see the allocator, above). - // Cast it back before delete, so the compiler won't incorrectly call destructors. - delete [] ( reinterpret_cast( rep_ ) ); - } - } - - Rep * rep_; - static Rep nullrep_; - -} ; - - -inline bool operator == (const TiXmlString & a, const TiXmlString & b) -{ - return ( a.length() == b.length() ) // optimization on some platforms - && ( strcmp(a.c_str(), b.c_str()) == 0 ); // actual compare -} -inline bool operator < (const TiXmlString & a, const TiXmlString & b) -{ - return strcmp(a.c_str(), b.c_str()) < 0; -} - -inline bool operator != (const TiXmlString & a, const TiXmlString & b) { return !(a == b); } -inline bool operator > (const TiXmlString & a, const TiXmlString & b) { return b < a; } -inline bool operator <= (const TiXmlString & a, const TiXmlString & b) { return !(b < a); } -inline bool operator >= (const TiXmlString & a, const TiXmlString & b) { return !(a < b); } - -inline bool operator == (const TiXmlString & a, const char* b) { return strcmp(a.c_str(), b) == 0; } -inline bool operator == (const char* a, const TiXmlString & b) { return b == a; } -inline bool operator != (const TiXmlString & a, const char* b) { return !(a == b); } -inline bool operator != (const char* a, const TiXmlString & b) { return !(b == a); } - -TiXmlString operator + (const TiXmlString & a, const TiXmlString & b); -TiXmlString operator + (const TiXmlString & a, const char* b); -TiXmlString operator + (const char* a, const TiXmlString & b); - - -/* - TiXmlOutStream is an emulation of std::ostream. It is based on TiXmlString. - Only the operators that we need for TinyXML have been developped. -*/ -class TiXmlOutStream : public TiXmlString -{ -public : - - // TiXmlOutStream << operator. - TiXmlOutStream & operator << (const TiXmlString & in) - { - *this += in; - return *this; - } - - // TiXmlOutStream << operator. - TiXmlOutStream & operator << (const char * in) - { - *this += in; - return *this; - } - -} ; - -#endif // TIXML_STRING_INCLUDED -#endif // TIXML_USE_STL diff --git a/btgui/tinyxml/tinyxml.cpp b/btgui/tinyxml/tinyxml.cpp deleted file mode 100755 index 9c161dfcb..000000000 --- a/btgui/tinyxml/tinyxml.cpp +++ /dev/null @@ -1,1886 +0,0 @@ -/* -www.sourceforge.net/projects/tinyxml -Original code by Lee Thomason (www.grinninglizard.com) - -This software is provided 'as-is', without any express or implied -warranty. In no event will the authors be held liable for any -damages arising from the use of this software. - -Permission is granted to anyone to use this software for any -purpose, including commercial applications, and to alter it and -redistribute it freely, subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must -not claim that you wrote the original software. If you use this -software in a product, an acknowledgment in the product documentation -would be appreciated but is not required. - -2. Altered source versions must be plainly marked as such, and -must not be misrepresented as being the original software. - -3. This notice may not be removed or altered from any source -distribution. -*/ - -#include - -#ifdef TIXML_USE_STL -#include -#include -#endif - -#include "tinyxml.h" - -FILE* TiXmlFOpen( const char* filename, const char* mode ); - -bool TiXmlBase::condenseWhiteSpace = true; - -// Microsoft compiler security -FILE* TiXmlFOpen( const char* filename, const char* mode ) -{ - #if defined(_MSC_VER) && (_MSC_VER >= 1400 ) - FILE* fp = 0; - errno_t err = fopen_s( &fp, filename, mode ); - if ( !err && fp ) - return fp; - return 0; - #else - return fopen( filename, mode ); - #endif -} - -void TiXmlBase::EncodeString( const TIXML_STRING& str, TIXML_STRING* outString ) -{ - int i=0; - - while( i<(int)str.length() ) - { - unsigned char c = (unsigned char) str[i]; - - if ( c == '&' - && i < ( (int)str.length() - 2 ) - && str[i+1] == '#' - && str[i+2] == 'x' ) - { - // Hexadecimal character reference. - // Pass through unchanged. - // © -- copyright symbol, for example. - // - // The -1 is a bug fix from Rob Laveaux. It keeps - // an overflow from happening if there is no ';'. - // There are actually 2 ways to exit this loop - - // while fails (error case) and break (semicolon found). - // However, there is no mechanism (currently) for - // this function to return an error. - while ( i<(int)str.length()-1 ) - { - outString->append( str.c_str() + i, 1 ); - ++i; - if ( str[i] == ';' ) - break; - } - } - else if ( c == '&' ) - { - outString->append( entity[0].str, entity[0].strLength ); - ++i; - } - else if ( c == '<' ) - { - outString->append( entity[1].str, entity[1].strLength ); - ++i; - } - else if ( c == '>' ) - { - outString->append( entity[2].str, entity[2].strLength ); - ++i; - } - else if ( c == '\"' ) - { - outString->append( entity[3].str, entity[3].strLength ); - ++i; - } - else if ( c == '\'' ) - { - outString->append( entity[4].str, entity[4].strLength ); - ++i; - } - else if ( c < 32 ) - { - // Easy pass at non-alpha/numeric/symbol - // Below 32 is symbolic. - char buf[ 32 ]; - - #if defined(TIXML_SNPRINTF) - TIXML_SNPRINTF( buf, sizeof(buf), "&#x%02X;", (unsigned) ( c & 0xff ) ); - #else - sprintf( buf, "&#x%02X;", (unsigned) ( c & 0xff ) ); - #endif - - //*ME: warning C4267: convert 'size_t' to 'int' - //*ME: Int-Cast to make compiler happy ... - outString->append( buf, (int)strlen( buf ) ); - ++i; - } - else - { - //char realc = (char) c; - //outString->append( &realc, 1 ); - *outString += (char) c; // somewhat more efficient function call. - ++i; - } - } -} - - -TiXmlNode::TiXmlNode( NodeType _type ) : TiXmlBase() -{ - parent = 0; - type = _type; - firstChild = 0; - lastChild = 0; - prev = 0; - next = 0; -} - - -TiXmlNode::~TiXmlNode() -{ - TiXmlNode* node = firstChild; - TiXmlNode* temp = 0; - - while ( node ) - { - temp = node; - node = node->next; - delete temp; - } -} - - -void TiXmlNode::CopyTo( TiXmlNode* target ) const -{ - target->SetValue (value.c_str() ); - target->userData = userData; - target->location = location; -} - - -void TiXmlNode::Clear() -{ - TiXmlNode* node = firstChild; - TiXmlNode* temp = 0; - - while ( node ) - { - temp = node; - node = node->next; - delete temp; - } - - firstChild = 0; - lastChild = 0; -} - - -TiXmlNode* TiXmlNode::LinkEndChild( TiXmlNode* node ) -{ - assert( node->parent == 0 || node->parent == this ); - assert( node->GetDocument() == 0 || node->GetDocument() == this->GetDocument() ); - - if ( node->Type() == TiXmlNode::TINYXML_DOCUMENT ) - { - delete node; - if ( GetDocument() ) - GetDocument()->SetError( TIXML_ERROR_DOCUMENT_TOP_ONLY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - - node->parent = this; - - node->prev = lastChild; - node->next = 0; - - if ( lastChild ) - lastChild->next = node; - else - firstChild = node; // it was an empty list. - - lastChild = node; - return node; -} - - -TiXmlNode* TiXmlNode::InsertEndChild( const TiXmlNode& addThis ) -{ - if ( addThis.Type() == TiXmlNode::TINYXML_DOCUMENT ) - { - if ( GetDocument() ) - GetDocument()->SetError( TIXML_ERROR_DOCUMENT_TOP_ONLY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - TiXmlNode* node = addThis.Clone(); - if ( !node ) - return 0; - - return LinkEndChild( node ); -} - - -TiXmlNode* TiXmlNode::InsertBeforeChild( TiXmlNode* beforeThis, const TiXmlNode& addThis ) -{ - if ( !beforeThis || beforeThis->parent != this ) { - return 0; - } - if ( addThis.Type() == TiXmlNode::TINYXML_DOCUMENT ) - { - if ( GetDocument() ) - GetDocument()->SetError( TIXML_ERROR_DOCUMENT_TOP_ONLY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - - TiXmlNode* node = addThis.Clone(); - if ( !node ) - return 0; - node->parent = this; - - node->next = beforeThis; - node->prev = beforeThis->prev; - if ( beforeThis->prev ) - { - beforeThis->prev->next = node; - } - else - { - assert( firstChild == beforeThis ); - firstChild = node; - } - beforeThis->prev = node; - return node; -} - - -TiXmlNode* TiXmlNode::InsertAfterChild( TiXmlNode* afterThis, const TiXmlNode& addThis ) -{ - if ( !afterThis || afterThis->parent != this ) { - return 0; - } - if ( addThis.Type() == TiXmlNode::TINYXML_DOCUMENT ) - { - if ( GetDocument() ) - GetDocument()->SetError( TIXML_ERROR_DOCUMENT_TOP_ONLY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - - TiXmlNode* node = addThis.Clone(); - if ( !node ) - return 0; - node->parent = this; - - node->prev = afterThis; - node->next = afterThis->next; - if ( afterThis->next ) - { - afterThis->next->prev = node; - } - else - { - assert( lastChild == afterThis ); - lastChild = node; - } - afterThis->next = node; - return node; -} - - -TiXmlNode* TiXmlNode::ReplaceChild( TiXmlNode* replaceThis, const TiXmlNode& withThis ) -{ - if ( !replaceThis ) - return 0; - - if ( replaceThis->parent != this ) - return 0; - - if ( withThis.ToDocument() ) { - // A document can never be a child. Thanks to Noam. - TiXmlDocument* document = GetDocument(); - if ( document ) - document->SetError( TIXML_ERROR_DOCUMENT_TOP_ONLY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - - TiXmlNode* node = withThis.Clone(); - if ( !node ) - return 0; - - node->next = replaceThis->next; - node->prev = replaceThis->prev; - - if ( replaceThis->next ) - replaceThis->next->prev = node; - else - lastChild = node; - - if ( replaceThis->prev ) - replaceThis->prev->next = node; - else - firstChild = node; - - delete replaceThis; - node->parent = this; - return node; -} - - -bool TiXmlNode::RemoveChild( TiXmlNode* removeThis ) -{ - if ( !removeThis ) { - return false; - } - - if ( removeThis->parent != this ) - { - assert( 0 ); - return false; - } - - if ( removeThis->next ) - removeThis->next->prev = removeThis->prev; - else - lastChild = removeThis->prev; - - if ( removeThis->prev ) - removeThis->prev->next = removeThis->next; - else - firstChild = removeThis->next; - - delete removeThis; - return true; -} - -const TiXmlNode* TiXmlNode::FirstChild( const char * _value ) const -{ - const TiXmlNode* node; - for ( node = firstChild; node; node = node->next ) - { - if ( strcmp( node->Value(), _value ) == 0 ) - return node; - } - return 0; -} - - -const TiXmlNode* TiXmlNode::LastChild( const char * _value ) const -{ - const TiXmlNode* node; - for ( node = lastChild; node; node = node->prev ) - { - if ( strcmp( node->Value(), _value ) == 0 ) - return node; - } - return 0; -} - - -const TiXmlNode* TiXmlNode::IterateChildren( const TiXmlNode* previous ) const -{ - if ( !previous ) - { - return FirstChild(); - } - else - { - assert( previous->parent == this ); - return previous->NextSibling(); - } -} - - -const TiXmlNode* TiXmlNode::IterateChildren( const char * val, const TiXmlNode* previous ) const -{ - if ( !previous ) - { - return FirstChild( val ); - } - else - { - assert( previous->parent == this ); - return previous->NextSibling( val ); - } -} - - -const TiXmlNode* TiXmlNode::NextSibling( const char * _value ) const -{ - const TiXmlNode* node; - for ( node = next; node; node = node->next ) - { - if ( strcmp( node->Value(), _value ) == 0 ) - return node; - } - return 0; -} - - -const TiXmlNode* TiXmlNode::PreviousSibling( const char * _value ) const -{ - const TiXmlNode* node; - for ( node = prev; node; node = node->prev ) - { - if ( strcmp( node->Value(), _value ) == 0 ) - return node; - } - return 0; -} - - -void TiXmlElement::RemoveAttribute( const char * name ) -{ - #ifdef TIXML_USE_STL - TIXML_STRING str( name ); - TiXmlAttribute* node = attributeSet.Find( str ); - #else - TiXmlAttribute* node = attributeSet.Find( name ); - #endif - if ( node ) - { - attributeSet.Remove( node ); - delete node; - } -} - -const TiXmlElement* TiXmlNode::FirstChildElement() const -{ - const TiXmlNode* node; - - for ( node = FirstChild(); - node; - node = node->NextSibling() ) - { - if ( node->ToElement() ) - return node->ToElement(); - } - return 0; -} - - -const TiXmlElement* TiXmlNode::FirstChildElement( const char * _value ) const -{ - const TiXmlNode* node; - - for ( node = FirstChild( _value ); - node; - node = node->NextSibling( _value ) ) - { - if ( node->ToElement() ) - return node->ToElement(); - } - return 0; -} - - -const TiXmlElement* TiXmlNode::NextSiblingElement() const -{ - const TiXmlNode* node; - - for ( node = NextSibling(); - node; - node = node->NextSibling() ) - { - if ( node->ToElement() ) - return node->ToElement(); - } - return 0; -} - - -const TiXmlElement* TiXmlNode::NextSiblingElement( const char * _value ) const -{ - const TiXmlNode* node; - - for ( node = NextSibling( _value ); - node; - node = node->NextSibling( _value ) ) - { - if ( node->ToElement() ) - return node->ToElement(); - } - return 0; -} - - -const TiXmlDocument* TiXmlNode::GetDocument() const -{ - const TiXmlNode* node; - - for( node = this; node; node = node->parent ) - { - if ( node->ToDocument() ) - return node->ToDocument(); - } - return 0; -} - - -TiXmlElement::TiXmlElement (const char * _value) - : TiXmlNode( TiXmlNode::TINYXML_ELEMENT ) -{ - firstChild = lastChild = 0; - value = _value; -} - - -#ifdef TIXML_USE_STL -TiXmlElement::TiXmlElement( const std::string& _value ) - : TiXmlNode( TiXmlNode::TINYXML_ELEMENT ) -{ - firstChild = lastChild = 0; - value = _value; -} -#endif - - -TiXmlElement::TiXmlElement( const TiXmlElement& copy) - : TiXmlNode( TiXmlNode::TINYXML_ELEMENT ) -{ - firstChild = lastChild = 0; - copy.CopyTo( this ); -} - - -TiXmlElement& TiXmlElement::operator=( const TiXmlElement& base ) -{ - ClearThis(); - base.CopyTo( this ); - return *this; -} - - -TiXmlElement::~TiXmlElement() -{ - ClearThis(); -} - - -void TiXmlElement::ClearThis() -{ - Clear(); - while( attributeSet.First() ) - { - TiXmlAttribute* node = attributeSet.First(); - attributeSet.Remove( node ); - delete node; - } -} - - -const char* TiXmlElement::Attribute( const char* name ) const -{ - const TiXmlAttribute* node = attributeSet.Find( name ); - if ( node ) - return node->Value(); - return 0; -} - - -#ifdef TIXML_USE_STL -const std::string* TiXmlElement::Attribute( const std::string& name ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - if ( attrib ) - return &attrib->ValueStr(); - return 0; -} -#endif - - -const char* TiXmlElement::Attribute( const char* name, int* i ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - const char* result = 0; - - if ( attrib ) { - result = attrib->Value(); - if ( i ) { - attrib->QueryIntValue( i ); - } - } - return result; -} - - -#ifdef TIXML_USE_STL -const std::string* TiXmlElement::Attribute( const std::string& name, int* i ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - const std::string* result = 0; - - if ( attrib ) { - result = &attrib->ValueStr(); - if ( i ) { - attrib->QueryIntValue( i ); - } - } - return result; -} -#endif - - -const char* TiXmlElement::Attribute( const char* name, double* d ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - const char* result = 0; - - if ( attrib ) { - result = attrib->Value(); - if ( d ) { - attrib->QueryDoubleValue( d ); - } - } - return result; -} - - -#ifdef TIXML_USE_STL -const std::string* TiXmlElement::Attribute( const std::string& name, double* d ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - const std::string* result = 0; - - if ( attrib ) { - result = &attrib->ValueStr(); - if ( d ) { - attrib->QueryDoubleValue( d ); - } - } - return result; -} -#endif - - -int TiXmlElement::QueryIntAttribute( const char* name, int* ival ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - if ( !attrib ) - return TIXML_NO_ATTRIBUTE; - return attrib->QueryIntValue( ival ); -} - - -int TiXmlElement::QueryUnsignedAttribute( const char* name, unsigned* value ) const -{ - const TiXmlAttribute* node = attributeSet.Find( name ); - if ( !node ) - return TIXML_NO_ATTRIBUTE; - - int ival = 0; - int result = node->QueryIntValue( &ival ); - *value = (unsigned)ival; - return result; -} - - -int TiXmlElement::QueryBoolAttribute( const char* name, bool* bval ) const -{ - const TiXmlAttribute* node = attributeSet.Find( name ); - if ( !node ) - return TIXML_NO_ATTRIBUTE; - - int result = TIXML_WRONG_TYPE; - if ( StringEqual( node->Value(), "true", true, TIXML_ENCODING_UNKNOWN ) - || StringEqual( node->Value(), "yes", true, TIXML_ENCODING_UNKNOWN ) - || StringEqual( node->Value(), "1", true, TIXML_ENCODING_UNKNOWN ) ) - { - *bval = true; - result = TIXML_SUCCESS; - } - else if ( StringEqual( node->Value(), "false", true, TIXML_ENCODING_UNKNOWN ) - || StringEqual( node->Value(), "no", true, TIXML_ENCODING_UNKNOWN ) - || StringEqual( node->Value(), "0", true, TIXML_ENCODING_UNKNOWN ) ) - { - *bval = false; - result = TIXML_SUCCESS; - } - return result; -} - - - -#ifdef TIXML_USE_STL -int TiXmlElement::QueryIntAttribute( const std::string& name, int* ival ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - if ( !attrib ) - return TIXML_NO_ATTRIBUTE; - return attrib->QueryIntValue( ival ); -} -#endif - - -int TiXmlElement::QueryDoubleAttribute( const char* name, double* dval ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - if ( !attrib ) - return TIXML_NO_ATTRIBUTE; - return attrib->QueryDoubleValue( dval ); -} - - -#ifdef TIXML_USE_STL -int TiXmlElement::QueryDoubleAttribute( const std::string& name, double* dval ) const -{ - const TiXmlAttribute* attrib = attributeSet.Find( name ); - if ( !attrib ) - return TIXML_NO_ATTRIBUTE; - return attrib->QueryDoubleValue( dval ); -} -#endif - - -void TiXmlElement::SetAttribute( const char * name, int val ) -{ - TiXmlAttribute* attrib = attributeSet.FindOrCreate( name ); - if ( attrib ) { - attrib->SetIntValue( val ); - } -} - - -#ifdef TIXML_USE_STL -void TiXmlElement::SetAttribute( const std::string& name, int val ) -{ - TiXmlAttribute* attrib = attributeSet.FindOrCreate( name ); - if ( attrib ) { - attrib->SetIntValue( val ); - } -} -#endif - - -void TiXmlElement::SetDoubleAttribute( const char * name, double val ) -{ - TiXmlAttribute* attrib = attributeSet.FindOrCreate( name ); - if ( attrib ) { - attrib->SetDoubleValue( val ); - } -} - - -#ifdef TIXML_USE_STL -void TiXmlElement::SetDoubleAttribute( const std::string& name, double val ) -{ - TiXmlAttribute* attrib = attributeSet.FindOrCreate( name ); - if ( attrib ) { - attrib->SetDoubleValue( val ); - } -} -#endif - - -void TiXmlElement::SetAttribute( const char * cname, const char * cvalue ) -{ - TiXmlAttribute* attrib = attributeSet.FindOrCreate( cname ); - if ( attrib ) { - attrib->SetValue( cvalue ); - } -} - - -#ifdef TIXML_USE_STL -void TiXmlElement::SetAttribute( const std::string& _name, const std::string& _value ) -{ - TiXmlAttribute* attrib = attributeSet.FindOrCreate( _name ); - if ( attrib ) { - attrib->SetValue( _value ); - } -} -#endif - - -void TiXmlElement::Print( FILE* cfile, int depth ) const -{ - int i; - assert( cfile ); - for ( i=0; iNext() ) - { - fprintf( cfile, " " ); - attrib->Print( cfile, depth ); - } - - // There are 3 different formatting approaches: - // 1) An element without children is printed as a node - // 2) An element with only a text child is printed as text - // 3) An element with children is printed on multiple lines. - TiXmlNode* node; - if ( !firstChild ) - { - fprintf( cfile, " />" ); - } - else if ( firstChild == lastChild && firstChild->ToText() ) - { - fprintf( cfile, ">" ); - firstChild->Print( cfile, depth + 1 ); - fprintf( cfile, "", value.c_str() ); - } - else - { - fprintf( cfile, ">" ); - - for ( node = firstChild; node; node=node->NextSibling() ) - { - if ( !node->ToText() ) - { - fprintf( cfile, "\n" ); - } - node->Print( cfile, depth+1 ); - } - fprintf( cfile, "\n" ); - for( i=0; i", value.c_str() ); - } -} - - -void TiXmlElement::CopyTo( TiXmlElement* target ) const -{ - // superclass: - TiXmlNode::CopyTo( target ); - - // Element class: - // Clone the attributes, then clone the children. - const TiXmlAttribute* attribute = 0; - for( attribute = attributeSet.First(); - attribute; - attribute = attribute->Next() ) - { - target->SetAttribute( attribute->Name(), attribute->Value() ); - } - - TiXmlNode* node = 0; - for ( node = firstChild; node; node = node->NextSibling() ) - { - target->LinkEndChild( node->Clone() ); - } -} - -bool TiXmlElement::Accept( TiXmlVisitor* visitor ) const -{ - if ( visitor->VisitEnter( *this, attributeSet.First() ) ) - { - for ( const TiXmlNode* node=FirstChild(); node; node=node->NextSibling() ) - { - if ( !node->Accept( visitor ) ) - break; - } - } - return visitor->VisitExit( *this ); -} - - -TiXmlNode* TiXmlElement::Clone() const -{ - TiXmlElement* clone = new TiXmlElement( Value() ); - if ( !clone ) - return 0; - - CopyTo( clone ); - return clone; -} - - -const char* TiXmlElement::GetText() const -{ - const TiXmlNode* child = this->FirstChild(); - if ( child ) { - const TiXmlText* childText = child->ToText(); - if ( childText ) { - return childText->Value(); - } - } - return 0; -} - - -TiXmlDocument::TiXmlDocument() : TiXmlNode( TiXmlNode::TINYXML_DOCUMENT ) -{ - tabsize = 4; - useMicrosoftBOM = false; - ClearError(); -} - -TiXmlDocument::TiXmlDocument( const char * documentName ) : TiXmlNode( TiXmlNode::TINYXML_DOCUMENT ) -{ - tabsize = 4; - useMicrosoftBOM = false; - value = documentName; - ClearError(); -} - - -#ifdef TIXML_USE_STL -TiXmlDocument::TiXmlDocument( const std::string& documentName ) : TiXmlNode( TiXmlNode::TINYXML_DOCUMENT ) -{ - tabsize = 4; - useMicrosoftBOM = false; - value = documentName; - ClearError(); -} -#endif - - -TiXmlDocument::TiXmlDocument( const TiXmlDocument& copy ) : TiXmlNode( TiXmlNode::TINYXML_DOCUMENT ) -{ - copy.CopyTo( this ); -} - - -TiXmlDocument& TiXmlDocument::operator=( const TiXmlDocument& copy ) -{ - Clear(); - copy.CopyTo( this ); - return *this; -} - - -bool TiXmlDocument::LoadFile( TiXmlEncoding encoding ) -{ - return LoadFile( Value(), encoding ); -} - - -bool TiXmlDocument::SaveFile() const -{ - return SaveFile( Value() ); -} - -bool TiXmlDocument::LoadFile( const char* _filename, TiXmlEncoding encoding ) -{ - TIXML_STRING filename( _filename ); - value = filename; - - // reading in binary mode so that tinyxml can normalize the EOL - FILE* file = TiXmlFOpen( value.c_str (), "rb" ); - - if ( file ) - { - bool result = LoadFile( file, encoding ); - fclose( file ); - return result; - } - else - { - SetError( TIXML_ERROR_OPENING_FILE, 0, 0, TIXML_ENCODING_UNKNOWN ); - return false; - } -} - -bool TiXmlDocument::LoadFile( FILE* file, TiXmlEncoding encoding ) -{ - if ( !file ) - { - SetError( TIXML_ERROR_OPENING_FILE, 0, 0, TIXML_ENCODING_UNKNOWN ); - return false; - } - - // Delete the existing data: - Clear(); - location.Clear(); - - // Get the file size, so we can pre-allocate the string. HUGE speed impact. - long length = 0; - fseek( file, 0, SEEK_END ); - length = ftell( file ); - fseek( file, 0, SEEK_SET ); - - // Strange case, but good to handle up front. - if ( length <= 0 ) - { - SetError( TIXML_ERROR_DOCUMENT_EMPTY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return false; - } - - // Subtle bug here. TinyXml did use fgets. But from the XML spec: - // 2.11 End-of-Line Handling - // - // - // ...the XML processor MUST behave as if it normalized all line breaks in external - // parsed entities (including the document entity) on input, before parsing, by translating - // both the two-character sequence #xD #xA and any #xD that is not followed by #xA to - // a single #xA character. - // - // - // It is not clear fgets does that, and certainly isn't clear it works cross platform. - // Generally, you expect fgets to translate from the convention of the OS to the c/unix - // convention, and not work generally. - - /* - while( fgets( buf, sizeof(buf), file ) ) - { - data += buf; - } - */ - - char* buf = new char[ length+1 ]; - buf[0] = 0; - - if ( fread( buf, length, 1, file ) != 1 ) { - delete [] buf; - SetError( TIXML_ERROR_OPENING_FILE, 0, 0, TIXML_ENCODING_UNKNOWN ); - return false; - } - - // Process the buffer in place to normalize new lines. (See comment above.) - // Copies from the 'p' to 'q' pointer, where p can advance faster if - // a newline-carriage return is hit. - // - // Wikipedia: - // Systems based on ASCII or a compatible character set use either LF (Line feed, '\n', 0x0A, 10 in decimal) or - // CR (Carriage return, '\r', 0x0D, 13 in decimal) individually, or CR followed by LF (CR+LF, 0x0D 0x0A)... - // * LF: Multics, Unix and Unix-like systems (GNU/Linux, AIX, Xenix, Mac OS X, FreeBSD, etc.), BeOS, Amiga, RISC OS, and others - // * CR+LF: DEC RT-11 and most other early non-Unix, non-IBM OSes, CP/M, MP/M, DOS, OS/2, Microsoft Windows, Symbian OS - // * CR: Commodore 8-bit machines, Apple II family, Mac OS up to version 9 and OS-9 - - const char* p = buf; // the read head - char* q = buf; // the write head - const char CR = 0x0d; - const char LF = 0x0a; - - buf[length] = 0; - while( *p ) { - assert( p < (buf+length) ); - assert( q <= (buf+length) ); - assert( q <= p ); - - if ( *p == CR ) { - *q++ = LF; - p++; - if ( *p == LF ) { // check for CR+LF (and skip LF) - p++; - } - } - else { - *q++ = *p++; - } - } - assert( q <= (buf+length) ); - *q = 0; - - Parse( buf, 0, encoding ); - - delete [] buf; - return !Error(); -} - - -bool TiXmlDocument::SaveFile( const char * filename ) const -{ - // The old c stuff lives on... - FILE* fp = TiXmlFOpen( filename, "w" ); - if ( fp ) - { - bool result = SaveFile( fp ); - fclose( fp ); - return result; - } - return false; -} - - -bool TiXmlDocument::SaveFile( FILE* fp ) const -{ - if ( useMicrosoftBOM ) - { - const unsigned char TIXML_UTF_LEAD_0 = 0xefU; - const unsigned char TIXML_UTF_LEAD_1 = 0xbbU; - const unsigned char TIXML_UTF_LEAD_2 = 0xbfU; - - fputc( TIXML_UTF_LEAD_0, fp ); - fputc( TIXML_UTF_LEAD_1, fp ); - fputc( TIXML_UTF_LEAD_2, fp ); - } - Print( fp, 0 ); - return (ferror(fp) == 0); -} - - -void TiXmlDocument::CopyTo( TiXmlDocument* target ) const -{ - TiXmlNode::CopyTo( target ); - - target->error = error; - target->errorId = errorId; - target->errorDesc = errorDesc; - target->tabsize = tabsize; - target->errorLocation = errorLocation; - target->useMicrosoftBOM = useMicrosoftBOM; - - TiXmlNode* node = 0; - for ( node = firstChild; node; node = node->NextSibling() ) - { - target->LinkEndChild( node->Clone() ); - } -} - - -TiXmlNode* TiXmlDocument::Clone() const -{ - TiXmlDocument* clone = new TiXmlDocument(); - if ( !clone ) - return 0; - - CopyTo( clone ); - return clone; -} - - -void TiXmlDocument::Print( FILE* cfile, int depth ) const -{ - assert( cfile ); - for ( const TiXmlNode* node=FirstChild(); node; node=node->NextSibling() ) - { - node->Print( cfile, depth ); - fprintf( cfile, "\n" ); - } -} - - -bool TiXmlDocument::Accept( TiXmlVisitor* visitor ) const -{ - if ( visitor->VisitEnter( *this ) ) - { - for ( const TiXmlNode* node=FirstChild(); node; node=node->NextSibling() ) - { - if ( !node->Accept( visitor ) ) - break; - } - } - return visitor->VisitExit( *this ); -} - - -const TiXmlAttribute* TiXmlAttribute::Next() const -{ - // We are using knowledge of the sentinel. The sentinel - // have a value or name. - if ( next->value.empty() && next->name.empty() ) - return 0; - return next; -} - -/* -TiXmlAttribute* TiXmlAttribute::Next() -{ - // We are using knowledge of the sentinel. The sentinel - // have a value or name. - if ( next->value.empty() && next->name.empty() ) - return 0; - return next; -} -*/ - -const TiXmlAttribute* TiXmlAttribute::Previous() const -{ - // We are using knowledge of the sentinel. The sentinel - // have a value or name. - if ( prev->value.empty() && prev->name.empty() ) - return 0; - return prev; -} - -/* -TiXmlAttribute* TiXmlAttribute::Previous() -{ - // We are using knowledge of the sentinel. The sentinel - // have a value or name. - if ( prev->value.empty() && prev->name.empty() ) - return 0; - return prev; -} -*/ - -void TiXmlAttribute::Print( FILE* cfile, int /*depth*/, TIXML_STRING* str ) const -{ - TIXML_STRING n, v; - - EncodeString( name, &n ); - EncodeString( value, &v ); - - if (value.find ('\"') == TIXML_STRING::npos) { - if ( cfile ) { - fprintf (cfile, "%s=\"%s\"", n.c_str(), v.c_str() ); - } - if ( str ) { - (*str) += n; (*str) += "=\""; (*str) += v; (*str) += "\""; - } - } - else { - if ( cfile ) { - fprintf (cfile, "%s='%s'", n.c_str(), v.c_str() ); - } - if ( str ) { - (*str) += n; (*str) += "='"; (*str) += v; (*str) += "'"; - } - } -} - - -int TiXmlAttribute::QueryIntValue( int* ival ) const -{ - if ( TIXML_SSCANF( value.c_str(), "%d", ival ) == 1 ) - return TIXML_SUCCESS; - return TIXML_WRONG_TYPE; -} - -int TiXmlAttribute::QueryDoubleValue( double* dval ) const -{ - if ( TIXML_SSCANF( value.c_str(), "%lf", dval ) == 1 ) - return TIXML_SUCCESS; - return TIXML_WRONG_TYPE; -} - -void TiXmlAttribute::SetIntValue( int _value ) -{ - char buf [64]; - #if defined(TIXML_SNPRINTF) - TIXML_SNPRINTF(buf, sizeof(buf), "%d", _value); - #else - sprintf (buf, "%d", _value); - #endif - SetValue (buf); -} - -void TiXmlAttribute::SetDoubleValue( double _value ) -{ - char buf [256]; - #if defined(TIXML_SNPRINTF) - TIXML_SNPRINTF( buf, sizeof(buf), "%g", _value); - #else - sprintf (buf, "%g", _value); - #endif - SetValue (buf); -} - -int TiXmlAttribute::IntValue() const -{ - return atoi (value.c_str ()); -} - -double TiXmlAttribute::DoubleValue() const -{ - return atof (value.c_str ()); -} - - -TiXmlComment::TiXmlComment( const TiXmlComment& copy ) : TiXmlNode( TiXmlNode::TINYXML_COMMENT ) -{ - copy.CopyTo( this ); -} - - -TiXmlComment& TiXmlComment::operator=( const TiXmlComment& base ) -{ - Clear(); - base.CopyTo( this ); - return *this; -} - - -void TiXmlComment::Print( FILE* cfile, int depth ) const -{ - assert( cfile ); - for ( int i=0; i", value.c_str() ); -} - - -void TiXmlComment::CopyTo( TiXmlComment* target ) const -{ - TiXmlNode::CopyTo( target ); -} - - -bool TiXmlComment::Accept( TiXmlVisitor* visitor ) const -{ - return visitor->Visit( *this ); -} - - -TiXmlNode* TiXmlComment::Clone() const -{ - TiXmlComment* clone = new TiXmlComment(); - - if ( !clone ) - return 0; - - CopyTo( clone ); - return clone; -} - - -void TiXmlText::Print( FILE* cfile, int depth ) const -{ - assert( cfile ); - if ( cdata ) - { - int i; - fprintf( cfile, "\n" ); - for ( i=0; i\n", value.c_str() ); // unformatted output - } - else - { - TIXML_STRING buffer; - EncodeString( value, &buffer ); - fprintf( cfile, "%s", buffer.c_str() ); - } -} - - -void TiXmlText::CopyTo( TiXmlText* target ) const -{ - TiXmlNode::CopyTo( target ); - target->cdata = cdata; -} - - -bool TiXmlText::Accept( TiXmlVisitor* visitor ) const -{ - return visitor->Visit( *this ); -} - - -TiXmlNode* TiXmlText::Clone() const -{ - TiXmlText* clone = 0; - clone = new TiXmlText( "" ); - - if ( !clone ) - return 0; - - CopyTo( clone ); - return clone; -} - - -TiXmlDeclaration::TiXmlDeclaration( const char * _version, - const char * _encoding, - const char * _standalone ) - : TiXmlNode( TiXmlNode::TINYXML_DECLARATION ) -{ - version = _version; - encoding = _encoding; - standalone = _standalone; -} - - -#ifdef TIXML_USE_STL -TiXmlDeclaration::TiXmlDeclaration( const std::string& _version, - const std::string& _encoding, - const std::string& _standalone ) - : TiXmlNode( TiXmlNode::TINYXML_DECLARATION ) -{ - version = _version; - encoding = _encoding; - standalone = _standalone; -} -#endif - - -TiXmlDeclaration::TiXmlDeclaration( const TiXmlDeclaration& copy ) - : TiXmlNode( TiXmlNode::TINYXML_DECLARATION ) -{ - copy.CopyTo( this ); -} - - -TiXmlDeclaration& TiXmlDeclaration::operator=( const TiXmlDeclaration& copy ) -{ - Clear(); - copy.CopyTo( this ); - return *this; -} - - -void TiXmlDeclaration::Print( FILE* cfile, int /*depth*/, TIXML_STRING* str ) const -{ - if ( cfile ) fprintf( cfile, "" ); - if ( str ) (*str) += "?>"; -} - - -void TiXmlDeclaration::CopyTo( TiXmlDeclaration* target ) const -{ - TiXmlNode::CopyTo( target ); - - target->version = version; - target->encoding = encoding; - target->standalone = standalone; -} - - -bool TiXmlDeclaration::Accept( TiXmlVisitor* visitor ) const -{ - return visitor->Visit( *this ); -} - - -TiXmlNode* TiXmlDeclaration::Clone() const -{ - TiXmlDeclaration* clone = new TiXmlDeclaration(); - - if ( !clone ) - return 0; - - CopyTo( clone ); - return clone; -} - - -void TiXmlUnknown::Print( FILE* cfile, int depth ) const -{ - for ( int i=0; i", value.c_str() ); -} - - -void TiXmlUnknown::CopyTo( TiXmlUnknown* target ) const -{ - TiXmlNode::CopyTo( target ); -} - - -bool TiXmlUnknown::Accept( TiXmlVisitor* visitor ) const -{ - return visitor->Visit( *this ); -} - - -TiXmlNode* TiXmlUnknown::Clone() const -{ - TiXmlUnknown* clone = new TiXmlUnknown(); - - if ( !clone ) - return 0; - - CopyTo( clone ); - return clone; -} - - -TiXmlAttributeSet::TiXmlAttributeSet() -{ - sentinel.next = &sentinel; - sentinel.prev = &sentinel; -} - - -TiXmlAttributeSet::~TiXmlAttributeSet() -{ - assert( sentinel.next == &sentinel ); - assert( sentinel.prev == &sentinel ); -} - - -void TiXmlAttributeSet::Add( TiXmlAttribute* addMe ) -{ - #ifdef TIXML_USE_STL - assert( !Find( TIXML_STRING( addMe->Name() ) ) ); // Shouldn't be multiply adding to the set. - #else - assert( !Find( addMe->Name() ) ); // Shouldn't be multiply adding to the set. - #endif - - addMe->next = &sentinel; - addMe->prev = sentinel.prev; - - sentinel.prev->next = addMe; - sentinel.prev = addMe; -} - -void TiXmlAttributeSet::Remove( TiXmlAttribute* removeMe ) -{ - TiXmlAttribute* node; - - for( node = sentinel.next; node != &sentinel; node = node->next ) - { - if ( node == removeMe ) - { - node->prev->next = node->next; - node->next->prev = node->prev; - node->next = 0; - node->prev = 0; - return; - } - } - assert( 0 ); // we tried to remove a non-linked attribute. -} - - -#ifdef TIXML_USE_STL -TiXmlAttribute* TiXmlAttributeSet::Find( const std::string& name ) const -{ - for( TiXmlAttribute* node = sentinel.next; node != &sentinel; node = node->next ) - { - if ( node->name == name ) - return node; - } - return 0; -} - -TiXmlAttribute* TiXmlAttributeSet::FindOrCreate( const std::string& _name ) -{ - TiXmlAttribute* attrib = Find( _name ); - if ( !attrib ) { - attrib = new TiXmlAttribute(); - Add( attrib ); - attrib->SetName( _name ); - } - return attrib; -} -#endif - - -TiXmlAttribute* TiXmlAttributeSet::Find( const char* name ) const -{ - for( TiXmlAttribute* node = sentinel.next; node != &sentinel; node = node->next ) - { - if ( strcmp( node->name.c_str(), name ) == 0 ) - return node; - } - return 0; -} - - -TiXmlAttribute* TiXmlAttributeSet::FindOrCreate( const char* _name ) -{ - TiXmlAttribute* attrib = Find( _name ); - if ( !attrib ) { - attrib = new TiXmlAttribute(); - Add( attrib ); - attrib->SetName( _name ); - } - return attrib; -} - - -#ifdef TIXML_USE_STL -std::istream& operator>> (std::istream & in, TiXmlNode & base) -{ - TIXML_STRING tag; - tag.reserve( 8 * 1000 ); - base.StreamIn( &in, &tag ); - - base.Parse( tag.c_str(), 0, TIXML_DEFAULT_ENCODING ); - return in; -} -#endif - - -#ifdef TIXML_USE_STL -std::ostream& operator<< (std::ostream & out, const TiXmlNode & base) -{ - TiXmlPrinter printer; - printer.SetStreamPrinting(); - base.Accept( &printer ); - out << printer.Str(); - - return out; -} - - -std::string& operator<< (std::string& out, const TiXmlNode& base ) -{ - TiXmlPrinter printer; - printer.SetStreamPrinting(); - base.Accept( &printer ); - out.append( printer.Str() ); - - return out; -} -#endif - - -TiXmlHandle TiXmlHandle::FirstChild() const -{ - if ( node ) - { - TiXmlNode* child = node->FirstChild(); - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::FirstChild( const char * value ) const -{ - if ( node ) - { - TiXmlNode* child = node->FirstChild( value ); - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::FirstChildElement() const -{ - if ( node ) - { - TiXmlElement* child = node->FirstChildElement(); - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::FirstChildElement( const char * value ) const -{ - if ( node ) - { - TiXmlElement* child = node->FirstChildElement( value ); - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::Child( int count ) const -{ - if ( node ) - { - int i; - TiXmlNode* child = node->FirstChild(); - for ( i=0; - child && iNextSibling(), ++i ) - { - // nothing - } - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::Child( const char* value, int count ) const -{ - if ( node ) - { - int i; - TiXmlNode* child = node->FirstChild( value ); - for ( i=0; - child && iNextSibling( value ), ++i ) - { - // nothing - } - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::ChildElement( int count ) const -{ - if ( node ) - { - int i; - TiXmlElement* child = node->FirstChildElement(); - for ( i=0; - child && iNextSiblingElement(), ++i ) - { - // nothing - } - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -TiXmlHandle TiXmlHandle::ChildElement( const char* value, int count ) const -{ - if ( node ) - { - int i; - TiXmlElement* child = node->FirstChildElement( value ); - for ( i=0; - child && iNextSiblingElement( value ), ++i ) - { - // nothing - } - if ( child ) - return TiXmlHandle( child ); - } - return TiXmlHandle( 0 ); -} - - -bool TiXmlPrinter::VisitEnter( const TiXmlDocument& ) -{ - return true; -} - -bool TiXmlPrinter::VisitExit( const TiXmlDocument& ) -{ - return true; -} - -bool TiXmlPrinter::VisitEnter( const TiXmlElement& element, const TiXmlAttribute* firstAttribute ) -{ - DoIndent(); - buffer += "<"; - buffer += element.Value(); - - for( const TiXmlAttribute* attrib = firstAttribute; attrib; attrib = attrib->Next() ) - { - buffer += " "; - attrib->Print( 0, 0, &buffer ); - } - - if ( !element.FirstChild() ) - { - buffer += " />"; - DoLineBreak(); - } - else - { - buffer += ">"; - if ( element.FirstChild()->ToText() - && element.LastChild() == element.FirstChild() - && element.FirstChild()->ToText()->CDATA() == false ) - { - simpleTextPrint = true; - // no DoLineBreak()! - } - else - { - DoLineBreak(); - } - } - ++depth; - return true; -} - - -bool TiXmlPrinter::VisitExit( const TiXmlElement& element ) -{ - --depth; - if ( !element.FirstChild() ) - { - // nothing. - } - else - { - if ( simpleTextPrint ) - { - simpleTextPrint = false; - } - else - { - DoIndent(); - } - buffer += ""; - DoLineBreak(); - } - return true; -} - - -bool TiXmlPrinter::Visit( const TiXmlText& text ) -{ - if ( text.CDATA() ) - { - DoIndent(); - buffer += ""; - DoLineBreak(); - } - else if ( simpleTextPrint ) - { - TIXML_STRING str; - TiXmlBase::EncodeString( text.ValueTStr(), &str ); - buffer += str; - } - else - { - DoIndent(); - TIXML_STRING str; - TiXmlBase::EncodeString( text.ValueTStr(), &str ); - buffer += str; - DoLineBreak(); - } - return true; -} - - -bool TiXmlPrinter::Visit( const TiXmlDeclaration& declaration ) -{ - DoIndent(); - declaration.Print( 0, 0, &buffer ); - DoLineBreak(); - return true; -} - - -bool TiXmlPrinter::Visit( const TiXmlComment& comment ) -{ - DoIndent(); - buffer += ""; - DoLineBreak(); - return true; -} - - -bool TiXmlPrinter::Visit( const TiXmlUnknown& unknown ) -{ - DoIndent(); - buffer += "<"; - buffer += unknown.Value(); - buffer += ">"; - DoLineBreak(); - return true; -} - diff --git a/btgui/tinyxml/tinyxml.h b/btgui/tinyxml/tinyxml.h deleted file mode 100755 index a3589e5b2..000000000 --- a/btgui/tinyxml/tinyxml.h +++ /dev/null @@ -1,1805 +0,0 @@ -/* -www.sourceforge.net/projects/tinyxml -Original code by Lee Thomason (www.grinninglizard.com) - -This software is provided 'as-is', without any express or implied -warranty. In no event will the authors be held liable for any -damages arising from the use of this software. - -Permission is granted to anyone to use this software for any -purpose, including commercial applications, and to alter it and -redistribute it freely, subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must -not claim that you wrote the original software. If you use this -software in a product, an acknowledgment in the product documentation -would be appreciated but is not required. - -2. Altered source versions must be plainly marked as such, and -must not be misrepresented as being the original software. - -3. This notice may not be removed or altered from any source -distribution. -*/ - - -#ifndef TINYXML_INCLUDED -#define TINYXML_INCLUDED - -#ifdef _MSC_VER -#pragma warning( push ) -#pragma warning( disable : 4530 ) -#pragma warning( disable : 4786 ) -#endif - -#include -#include -#include -#include -#include - -// Help out windows: -#if defined( _DEBUG ) && !defined( DEBUG ) -#define DEBUG -#endif - -#ifdef TIXML_USE_STL - #include - #include - #include - #define TIXML_STRING std::string -#else - #include "tinystr.h" - #define TIXML_STRING TiXmlString -#endif - -// Deprecated library function hell. Compilers want to use the -// new safe versions. This probably doesn't fully address the problem, -// but it gets closer. There are too many compilers for me to fully -// test. If you get compilation troubles, undefine TIXML_SAFE -#define TIXML_SAFE - -#ifdef TIXML_SAFE - #if defined(_MSC_VER) && (_MSC_VER >= 1400 ) - // Microsoft visual studio, version 2005 and higher. - #define TIXML_SNPRINTF _snprintf_s - #define TIXML_SSCANF sscanf_s - #elif defined(_MSC_VER) && (_MSC_VER >= 1200 ) - // Microsoft visual studio, version 6 and higher. - //#pragma message( "Using _sn* functions." ) - #define TIXML_SNPRINTF _snprintf - #define TIXML_SSCANF sscanf - #elif defined(__GNUC__) && (__GNUC__ >= 3 ) - // GCC version 3 and higher.s - //#warning( "Using sn* functions." ) - #define TIXML_SNPRINTF snprintf - #define TIXML_SSCANF sscanf - #else - #define TIXML_SNPRINTF snprintf - #define TIXML_SSCANF sscanf - #endif -#endif - -class TiXmlDocument; -class TiXmlElement; -class TiXmlComment; -class TiXmlUnknown; -class TiXmlAttribute; -class TiXmlText; -class TiXmlDeclaration; -class TiXmlParsingData; - -const int TIXML_MAJOR_VERSION = 2; -const int TIXML_MINOR_VERSION = 6; -const int TIXML_PATCH_VERSION = 2; - -/* Internal structure for tracking location of items - in the XML file. -*/ -struct TiXmlCursor -{ - TiXmlCursor() { Clear(); } - void Clear() { row = col = -1; } - - int row; // 0 based. - int col; // 0 based. -}; - - -/** - Implements the interface to the "Visitor pattern" (see the Accept() method.) - If you call the Accept() method, it requires being passed a TiXmlVisitor - class to handle callbacks. For nodes that contain other nodes (Document, Element) - you will get called with a VisitEnter/VisitExit pair. Nodes that are always leaves - are simply called with Visit(). - - If you return 'true' from a Visit method, recursive parsing will continue. If you return - false, no children of this node or its sibilings will be Visited. - - All flavors of Visit methods have a default implementation that returns 'true' (continue - visiting). You need to only override methods that are interesting to you. - - Generally Accept() is called on the TiXmlDocument, although all nodes suppert Visiting. - - You should never change the document from a callback. - - @sa TiXmlNode::Accept() -*/ -class TiXmlVisitor -{ -public: - virtual ~TiXmlVisitor() {} - - /// Visit a document. - virtual bool VisitEnter( const TiXmlDocument& /*doc*/ ) { return true; } - /// Visit a document. - virtual bool VisitExit( const TiXmlDocument& /*doc*/ ) { return true; } - - /// Visit an element. - virtual bool VisitEnter( const TiXmlElement& /*element*/, const TiXmlAttribute* /*firstAttribute*/ ) { return true; } - /// Visit an element. - virtual bool VisitExit( const TiXmlElement& /*element*/ ) { return true; } - - /// Visit a declaration - virtual bool Visit( const TiXmlDeclaration& /*declaration*/ ) { return true; } - /// Visit a text node - virtual bool Visit( const TiXmlText& /*text*/ ) { return true; } - /// Visit a comment node - virtual bool Visit( const TiXmlComment& /*comment*/ ) { return true; } - /// Visit an unknown node - virtual bool Visit( const TiXmlUnknown& /*unknown*/ ) { return true; } -}; - -// Only used by Attribute::Query functions -enum -{ - TIXML_SUCCESS, - TIXML_NO_ATTRIBUTE, - TIXML_WRONG_TYPE -}; - - -// Used by the parsing routines. -enum TiXmlEncoding -{ - TIXML_ENCODING_UNKNOWN, - TIXML_ENCODING_UTF8, - TIXML_ENCODING_LEGACY -}; - -const TiXmlEncoding TIXML_DEFAULT_ENCODING = TIXML_ENCODING_UNKNOWN; - -/** TiXmlBase is a base class for every class in TinyXml. - It does little except to establish that TinyXml classes - can be printed and provide some utility functions. - - In XML, the document and elements can contain - other elements and other types of nodes. - - @verbatim - A Document can contain: Element (container or leaf) - Comment (leaf) - Unknown (leaf) - Declaration( leaf ) - - An Element can contain: Element (container or leaf) - Text (leaf) - Attributes (not on tree) - Comment (leaf) - Unknown (leaf) - - A Decleration contains: Attributes (not on tree) - @endverbatim -*/ -class TiXmlBase -{ - friend class TiXmlNode; - friend class TiXmlElement; - friend class TiXmlDocument; - -public: - TiXmlBase() : userData(0) {} - virtual ~TiXmlBase() {} - - /** All TinyXml classes can print themselves to a filestream - or the string class (TiXmlString in non-STL mode, std::string - in STL mode.) Either or both cfile and str can be null. - - This is a formatted print, and will insert - tabs and newlines. - - (For an unformatted stream, use the << operator.) - */ - virtual void Print( FILE* cfile, int depth ) const = 0; - - /** The world does not agree on whether white space should be kept or - not. In order to make everyone happy, these global, static functions - are provided to set whether or not TinyXml will condense all white space - into a single space or not. The default is to condense. Note changing this - value is not thread safe. - */ - static void SetCondenseWhiteSpace( bool condense ) { condenseWhiteSpace = condense; } - - /// Return the current white space setting. - static bool IsWhiteSpaceCondensed() { return condenseWhiteSpace; } - - /** Return the position, in the original source file, of this node or attribute. - The row and column are 1-based. (That is the first row and first column is - 1,1). If the returns values are 0 or less, then the parser does not have - a row and column value. - - Generally, the row and column value will be set when the TiXmlDocument::Load(), - TiXmlDocument::LoadFile(), or any TiXmlNode::Parse() is called. It will NOT be set - when the DOM was created from operator>>. - - The values reflect the initial load. Once the DOM is modified programmatically - (by adding or changing nodes and attributes) the new values will NOT update to - reflect changes in the document. - - There is a minor performance cost to computing the row and column. Computation - can be disabled if TiXmlDocument::SetTabSize() is called with 0 as the value. - - @sa TiXmlDocument::SetTabSize() - */ - int Row() const { return location.row + 1; } - int Column() const { return location.col + 1; } ///< See Row() - - void SetUserData( void* user ) { userData = user; } ///< Set a pointer to arbitrary user data. - void* GetUserData() { return userData; } ///< Get a pointer to arbitrary user data. - const void* GetUserData() const { return userData; } ///< Get a pointer to arbitrary user data. - - // Table that returs, for a given lead byte, the total number of bytes - // in the UTF-8 sequence. - static const int utf8ByteTable[256]; - - virtual const char* Parse( const char* p, - TiXmlParsingData* data, - TiXmlEncoding encoding /*= TIXML_ENCODING_UNKNOWN */ ) = 0; - - /** Expands entities in a string. Note this should not contian the tag's '<', '>', etc, - or they will be transformed into entities! - */ - static void EncodeString( const TIXML_STRING& str, TIXML_STRING* out ); - - enum - { - TIXML_NO_ERROR = 0, - TIXML_ERROR, - TIXML_ERROR_OPENING_FILE, - TIXML_ERROR_PARSING_ELEMENT, - TIXML_ERROR_FAILED_TO_READ_ELEMENT_NAME, - TIXML_ERROR_READING_ELEMENT_VALUE, - TIXML_ERROR_READING_ATTRIBUTES, - TIXML_ERROR_PARSING_EMPTY, - TIXML_ERROR_READING_END_TAG, - TIXML_ERROR_PARSING_UNKNOWN, - TIXML_ERROR_PARSING_COMMENT, - TIXML_ERROR_PARSING_DECLARATION, - TIXML_ERROR_DOCUMENT_EMPTY, - TIXML_ERROR_EMBEDDED_NULL, - TIXML_ERROR_PARSING_CDATA, - TIXML_ERROR_DOCUMENT_TOP_ONLY, - - TIXML_ERROR_STRING_COUNT - }; - -protected: - - static const char* SkipWhiteSpace( const char*, TiXmlEncoding encoding ); - - inline static bool IsWhiteSpace( char c ) - { - return ( isspace( (unsigned char) c ) || c == '\n' || c == '\r' ); - } - inline static bool IsWhiteSpace( int c ) - { - if ( c < 256 ) - return IsWhiteSpace( (char) c ); - return false; // Again, only truly correct for English/Latin...but usually works. - } - - #ifdef TIXML_USE_STL - static bool StreamWhiteSpace( std::istream * in, TIXML_STRING * tag ); - static bool StreamTo( std::istream * in, int character, TIXML_STRING * tag ); - #endif - - /* Reads an XML name into the string provided. Returns - a pointer just past the last character of the name, - or 0 if the function has an error. - */ - static const char* ReadName( const char* p, TIXML_STRING* name, TiXmlEncoding encoding ); - - /* Reads text. Returns a pointer past the given end tag. - Wickedly complex options, but it keeps the (sensitive) code in one place. - */ - static const char* ReadText( const char* in, // where to start - TIXML_STRING* text, // the string read - bool ignoreWhiteSpace, // whether to keep the white space - const char* endTag, // what ends this text - bool ignoreCase, // whether to ignore case in the end tag - TiXmlEncoding encoding ); // the current encoding - - // If an entity has been found, transform it into a character. - static const char* GetEntity( const char* in, char* value, int* length, TiXmlEncoding encoding ); - - // Get a character, while interpreting entities. - // The length can be from 0 to 4 bytes. - inline static const char* GetChar( const char* p, char* _value, int* length, TiXmlEncoding encoding ) - { - assert( p ); - if ( encoding == TIXML_ENCODING_UTF8 ) - { - *length = utf8ByteTable[ *((const unsigned char*)p) ]; - assert( *length >= 0 && *length < 5 ); - } - else - { - *length = 1; - } - - if ( *length == 1 ) - { - if ( *p == '&' ) - return GetEntity( p, _value, length, encoding ); - *_value = *p; - return p+1; - } - else if ( *length ) - { - //strncpy( _value, p, *length ); // lots of compilers don't like this function (unsafe), - // and the null terminator isn't needed - for( int i=0; p[i] && i<*length; ++i ) { - _value[i] = p[i]; - } - return p + (*length); - } - else - { - // Not valid text. - return 0; - } - } - - // Return true if the next characters in the stream are any of the endTag sequences. - // Ignore case only works for english, and should only be relied on when comparing - // to English words: StringEqual( p, "version", true ) is fine. - static bool StringEqual( const char* p, - const char* endTag, - bool ignoreCase, - TiXmlEncoding encoding ); - - static const char* errorString[ TIXML_ERROR_STRING_COUNT ]; - - TiXmlCursor location; - - /// Field containing a generic user pointer - void* userData; - - // None of these methods are reliable for any language except English. - // Good for approximation, not great for accuracy. - static int IsAlpha( unsigned char anyByte, TiXmlEncoding encoding ); - static int IsAlphaNum( unsigned char anyByte, TiXmlEncoding encoding ); - inline static int ToLower( int v, TiXmlEncoding encoding ) - { - if ( encoding == TIXML_ENCODING_UTF8 ) - { - if ( v < 128 ) return tolower( v ); - return v; - } - else - { - return tolower( v ); - } - } - static void ConvertUTF32ToUTF8( unsigned long input, char* output, int* length ); - -private: - TiXmlBase( const TiXmlBase& ); // not implemented. - void operator=( const TiXmlBase& base ); // not allowed. - - struct Entity - { - const char* str; - unsigned int strLength; - char chr; - }; - enum - { - NUM_ENTITY = 5, - MAX_ENTITY_LENGTH = 6 - - }; - static Entity entity[ NUM_ENTITY ]; - static bool condenseWhiteSpace; -}; - - -/** The parent class for everything in the Document Object Model. - (Except for attributes). - Nodes have siblings, a parent, and children. A node can be - in a document, or stand on its own. The type of a TiXmlNode - can be queried, and it can be cast to its more defined type. -*/ -class TiXmlNode : public TiXmlBase -{ - friend class TiXmlDocument; - friend class TiXmlElement; - -public: - #ifdef TIXML_USE_STL - - /** An input stream operator, for every class. Tolerant of newlines and - formatting, but doesn't expect them. - */ - friend std::istream& operator >> (std::istream& in, TiXmlNode& base); - - /** An output stream operator, for every class. Note that this outputs - without any newlines or formatting, as opposed to Print(), which - includes tabs and new lines. - - The operator<< and operator>> are not completely symmetric. Writing - a node to a stream is very well defined. You'll get a nice stream - of output, without any extra whitespace or newlines. - - But reading is not as well defined. (As it always is.) If you create - a TiXmlElement (for example) and read that from an input stream, - the text needs to define an element or junk will result. This is - true of all input streams, but it's worth keeping in mind. - - A TiXmlDocument will read nodes until it reads a root element, and - all the children of that root element. - */ - friend std::ostream& operator<< (std::ostream& out, const TiXmlNode& base); - - /// Appends the XML node or attribute to a std::string. - friend std::string& operator<< (std::string& out, const TiXmlNode& base ); - - #endif - - /** The types of XML nodes supported by TinyXml. (All the - unsupported types are picked up by UNKNOWN.) - */ - enum NodeType - { - TINYXML_DOCUMENT, - TINYXML_ELEMENT, - TINYXML_COMMENT, - TINYXML_UNKNOWN, - TINYXML_TEXT, - TINYXML_DECLARATION, - TINYXML_TYPECOUNT - }; - - virtual ~TiXmlNode(); - - /** The meaning of 'value' changes for the specific type of - TiXmlNode. - @verbatim - Document: filename of the xml file - Element: name of the element - Comment: the comment text - Unknown: the tag contents - Text: the text string - @endverbatim - - The subclasses will wrap this function. - */ - const char *Value() const { return value.c_str (); } - - #ifdef TIXML_USE_STL - /** Return Value() as a std::string. If you only use STL, - this is more efficient than calling Value(). - Only available in STL mode. - */ - const std::string& ValueStr() const { return value; } - #endif - - const TIXML_STRING& ValueTStr() const { return value; } - - /** Changes the value of the node. Defined as: - @verbatim - Document: filename of the xml file - Element: name of the element - Comment: the comment text - Unknown: the tag contents - Text: the text string - @endverbatim - */ - void SetValue(const char * _value) { value = _value;} - - #ifdef TIXML_USE_STL - /// STL std::string form. - void SetValue( const std::string& _value ) { value = _value; } - #endif - - /// Delete all the children of this node. Does not affect 'this'. - void Clear(); - - /// One step up the DOM. - TiXmlNode* Parent() { return parent; } - const TiXmlNode* Parent() const { return parent; } - - const TiXmlNode* FirstChild() const { return firstChild; } ///< The first child of this node. Will be null if there are no children. - TiXmlNode* FirstChild() { return firstChild; } - const TiXmlNode* FirstChild( const char * value ) const; ///< The first child of this node with the matching 'value'. Will be null if none found. - /// The first child of this node with the matching 'value'. Will be null if none found. - TiXmlNode* FirstChild( const char * _value ) { - // Call through to the const version - safe since nothing is changed. Exiting syntax: cast this to a const (always safe) - // call the method, cast the return back to non-const. - return const_cast< TiXmlNode* > ((const_cast< const TiXmlNode* >(this))->FirstChild( _value )); - } - const TiXmlNode* LastChild() const { return lastChild; } /// The last child of this node. Will be null if there are no children. - TiXmlNode* LastChild() { return lastChild; } - - const TiXmlNode* LastChild( const char * value ) const; /// The last child of this node matching 'value'. Will be null if there are no children. - TiXmlNode* LastChild( const char * _value ) { - return const_cast< TiXmlNode* > ((const_cast< const TiXmlNode* >(this))->LastChild( _value )); - } - - #ifdef TIXML_USE_STL - const TiXmlNode* FirstChild( const std::string& _value ) const { return FirstChild (_value.c_str ()); } ///< STL std::string form. - TiXmlNode* FirstChild( const std::string& _value ) { return FirstChild (_value.c_str ()); } ///< STL std::string form. - const TiXmlNode* LastChild( const std::string& _value ) const { return LastChild (_value.c_str ()); } ///< STL std::string form. - TiXmlNode* LastChild( const std::string& _value ) { return LastChild (_value.c_str ()); } ///< STL std::string form. - #endif - - /** An alternate way to walk the children of a node. - One way to iterate over nodes is: - @verbatim - for( child = parent->FirstChild(); child; child = child->NextSibling() ) - @endverbatim - - IterateChildren does the same thing with the syntax: - @verbatim - child = 0; - while( child = parent->IterateChildren( child ) ) - @endverbatim - - IterateChildren takes the previous child as input and finds - the next one. If the previous child is null, it returns the - first. IterateChildren will return null when done. - */ - const TiXmlNode* IterateChildren( const TiXmlNode* previous ) const; - TiXmlNode* IterateChildren( const TiXmlNode* previous ) { - return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->IterateChildren( previous ) ); - } - - /// This flavor of IterateChildren searches for children with a particular 'value' - const TiXmlNode* IterateChildren( const char * value, const TiXmlNode* previous ) const; - TiXmlNode* IterateChildren( const char * _value, const TiXmlNode* previous ) { - return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->IterateChildren( _value, previous ) ); - } - - #ifdef TIXML_USE_STL - const TiXmlNode* IterateChildren( const std::string& _value, const TiXmlNode* previous ) const { return IterateChildren (_value.c_str (), previous); } ///< STL std::string form. - TiXmlNode* IterateChildren( const std::string& _value, const TiXmlNode* previous ) { return IterateChildren (_value.c_str (), previous); } ///< STL std::string form. - #endif - - /** Add a new node related to this. Adds a child past the LastChild. - Returns a pointer to the new object or NULL if an error occured. - */ - TiXmlNode* InsertEndChild( const TiXmlNode& addThis ); - - - /** Add a new node related to this. Adds a child past the LastChild. - - NOTE: the node to be added is passed by pointer, and will be - henceforth owned (and deleted) by tinyXml. This method is efficient - and avoids an extra copy, but should be used with care as it - uses a different memory model than the other insert functions. - - @sa InsertEndChild - */ - TiXmlNode* LinkEndChild( TiXmlNode* addThis ); - - /** Add a new node related to this. Adds a child before the specified child. - Returns a pointer to the new object or NULL if an error occured. - */ - TiXmlNode* InsertBeforeChild( TiXmlNode* beforeThis, const TiXmlNode& addThis ); - - /** Add a new node related to this. Adds a child after the specified child. - Returns a pointer to the new object or NULL if an error occured. - */ - TiXmlNode* InsertAfterChild( TiXmlNode* afterThis, const TiXmlNode& addThis ); - - /** Replace a child of this node. - Returns a pointer to the new object or NULL if an error occured. - */ - TiXmlNode* ReplaceChild( TiXmlNode* replaceThis, const TiXmlNode& withThis ); - - /// Delete a child of this node. - bool RemoveChild( TiXmlNode* removeThis ); - - /// Navigate to a sibling node. - const TiXmlNode* PreviousSibling() const { return prev; } - TiXmlNode* PreviousSibling() { return prev; } - - /// Navigate to a sibling node. - const TiXmlNode* PreviousSibling( const char * ) const; - TiXmlNode* PreviousSibling( const char *_prev ) { - return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->PreviousSibling( _prev ) ); - } - - #ifdef TIXML_USE_STL - const TiXmlNode* PreviousSibling( const std::string& _value ) const { return PreviousSibling (_value.c_str ()); } ///< STL std::string form. - TiXmlNode* PreviousSibling( const std::string& _value ) { return PreviousSibling (_value.c_str ()); } ///< STL std::string form. - const TiXmlNode* NextSibling( const std::string& _value) const { return NextSibling (_value.c_str ()); } ///< STL std::string form. - TiXmlNode* NextSibling( const std::string& _value) { return NextSibling (_value.c_str ()); } ///< STL std::string form. - #endif - - /// Navigate to a sibling node. - const TiXmlNode* NextSibling() const { return next; } - TiXmlNode* NextSibling() { return next; } - - /// Navigate to a sibling node with the given 'value'. - const TiXmlNode* NextSibling( const char * ) const; - TiXmlNode* NextSibling( const char* _next ) { - return const_cast< TiXmlNode* >( (const_cast< const TiXmlNode* >(this))->NextSibling( _next ) ); - } - - /** Convenience function to get through elements. - Calls NextSibling and ToElement. Will skip all non-Element - nodes. Returns 0 if there is not another element. - */ - const TiXmlElement* NextSiblingElement() const; - TiXmlElement* NextSiblingElement() { - return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->NextSiblingElement() ); - } - - /** Convenience function to get through elements. - Calls NextSibling and ToElement. Will skip all non-Element - nodes. Returns 0 if there is not another element. - */ - const TiXmlElement* NextSiblingElement( const char * ) const; - TiXmlElement* NextSiblingElement( const char *_next ) { - return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->NextSiblingElement( _next ) ); - } - - #ifdef TIXML_USE_STL - const TiXmlElement* NextSiblingElement( const std::string& _value) const { return NextSiblingElement (_value.c_str ()); } ///< STL std::string form. - TiXmlElement* NextSiblingElement( const std::string& _value) { return NextSiblingElement (_value.c_str ()); } ///< STL std::string form. - #endif - - /// Convenience function to get through elements. - const TiXmlElement* FirstChildElement() const; - TiXmlElement* FirstChildElement() { - return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->FirstChildElement() ); - } - - /// Convenience function to get through elements. - const TiXmlElement* FirstChildElement( const char * _value ) const; - TiXmlElement* FirstChildElement( const char * _value ) { - return const_cast< TiXmlElement* >( (const_cast< const TiXmlNode* >(this))->FirstChildElement( _value ) ); - } - - #ifdef TIXML_USE_STL - const TiXmlElement* FirstChildElement( const std::string& _value ) const { return FirstChildElement (_value.c_str ()); } ///< STL std::string form. - TiXmlElement* FirstChildElement( const std::string& _value ) { return FirstChildElement (_value.c_str ()); } ///< STL std::string form. - #endif - - /** Query the type (as an enumerated value, above) of this node. - The possible types are: TINYXML_DOCUMENT, TINYXML_ELEMENT, TINYXML_COMMENT, - TINYXML_UNKNOWN, TINYXML_TEXT, and TINYXML_DECLARATION. - */ - int Type() const { return type; } - - /** Return a pointer to the Document this node lives in. - Returns null if not in a document. - */ - const TiXmlDocument* GetDocument() const; - TiXmlDocument* GetDocument() { - return const_cast< TiXmlDocument* >( (const_cast< const TiXmlNode* >(this))->GetDocument() ); - } - - /// Returns true if this node has no children. - bool NoChildren() const { return !firstChild; } - - virtual const TiXmlDocument* ToDocument() const { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual const TiXmlElement* ToElement() const { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual const TiXmlComment* ToComment() const { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual const TiXmlUnknown* ToUnknown() const { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual const TiXmlText* ToText() const { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual const TiXmlDeclaration* ToDeclaration() const { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - - virtual TiXmlDocument* ToDocument() { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual TiXmlElement* ToElement() { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual TiXmlComment* ToComment() { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual TiXmlUnknown* ToUnknown() { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual TiXmlText* ToText() { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - virtual TiXmlDeclaration* ToDeclaration() { return 0; } ///< Cast to a more defined type. Will return null if not of the requested type. - - /** Create an exact duplicate of this node and return it. The memory must be deleted - by the caller. - */ - virtual TiXmlNode* Clone() const = 0; - - /** Accept a hierchical visit the nodes in the TinyXML DOM. Every node in the - XML tree will be conditionally visited and the host will be called back - via the TiXmlVisitor interface. - - This is essentially a SAX interface for TinyXML. (Note however it doesn't re-parse - the XML for the callbacks, so the performance of TinyXML is unchanged by using this - interface versus any other.) - - The interface has been based on ideas from: - - - http://www.saxproject.org/ - - http://c2.com/cgi/wiki?HierarchicalVisitorPattern - - Which are both good references for "visiting". - - An example of using Accept(): - @verbatim - TiXmlPrinter printer; - tinyxmlDoc.Accept( &printer ); - const char* xmlcstr = printer.CStr(); - @endverbatim - */ - virtual bool Accept( TiXmlVisitor* visitor ) const = 0; - -protected: - TiXmlNode( NodeType _type ); - - // Copy to the allocated object. Shared functionality between Clone, Copy constructor, - // and the assignment operator. - void CopyTo( TiXmlNode* target ) const; - - #ifdef TIXML_USE_STL - // The real work of the input operator. - virtual void StreamIn( std::istream* in, TIXML_STRING* tag ) = 0; - #endif - - // Figure out what is at *p, and parse it. Returns null if it is not an xml node. - TiXmlNode* Identify( const char* start, TiXmlEncoding encoding ); - - TiXmlNode* parent; - NodeType type; - - TiXmlNode* firstChild; - TiXmlNode* lastChild; - - TIXML_STRING value; - - TiXmlNode* prev; - TiXmlNode* next; - -private: - TiXmlNode( const TiXmlNode& ); // not implemented. - void operator=( const TiXmlNode& base ); // not allowed. -}; - - -/** An attribute is a name-value pair. Elements have an arbitrary - number of attributes, each with a unique name. - - @note The attributes are not TiXmlNodes, since they are not - part of the tinyXML document object model. There are other - suggested ways to look at this problem. -*/ -class TiXmlAttribute : public TiXmlBase -{ - friend class TiXmlAttributeSet; - -public: - /// Construct an empty attribute. - TiXmlAttribute() : TiXmlBase() - { - document = 0; - prev = next = 0; - } - - #ifdef TIXML_USE_STL - /// std::string constructor. - TiXmlAttribute( const std::string& _name, const std::string& _value ) - { - name = _name; - value = _value; - document = 0; - prev = next = 0; - } - #endif - - /// Construct an attribute with a name and value. - TiXmlAttribute( const char * _name, const char * _value ) - { - name = _name; - value = _value; - document = 0; - prev = next = 0; - } - - const char* Name() const { return name.c_str(); } ///< Return the name of this attribute. - const char* Value() const { return value.c_str(); } ///< Return the value of this attribute. - #ifdef TIXML_USE_STL - const std::string& ValueStr() const { return value; } ///< Return the value of this attribute. - #endif - int IntValue() const; ///< Return the value of this attribute, converted to an integer. - double DoubleValue() const; ///< Return the value of this attribute, converted to a double. - - // Get the tinyxml string representation - const TIXML_STRING& NameTStr() const { return name; } - - /** QueryIntValue examines the value string. It is an alternative to the - IntValue() method with richer error checking. - If the value is an integer, it is stored in 'value' and - the call returns TIXML_SUCCESS. If it is not - an integer, it returns TIXML_WRONG_TYPE. - - A specialized but useful call. Note that for success it returns 0, - which is the opposite of almost all other TinyXml calls. - */ - int QueryIntValue( int* _value ) const; - /// QueryDoubleValue examines the value string. See QueryIntValue(). - int QueryDoubleValue( double* _value ) const; - - void SetName( const char* _name ) { name = _name; } ///< Set the name of this attribute. - void SetValue( const char* _value ) { value = _value; } ///< Set the value. - - void SetIntValue( int _value ); ///< Set the value from an integer. - void SetDoubleValue( double _value ); ///< Set the value from a double. - - #ifdef TIXML_USE_STL - /// STL std::string form. - void SetName( const std::string& _name ) { name = _name; } - /// STL std::string form. - void SetValue( const std::string& _value ) { value = _value; } - #endif - - /// Get the next sibling attribute in the DOM. Returns null at end. - const TiXmlAttribute* Next() const; - TiXmlAttribute* Next() { - return const_cast< TiXmlAttribute* >( (const_cast< const TiXmlAttribute* >(this))->Next() ); - } - - /// Get the previous sibling attribute in the DOM. Returns null at beginning. - const TiXmlAttribute* Previous() const; - TiXmlAttribute* Previous() { - return const_cast< TiXmlAttribute* >( (const_cast< const TiXmlAttribute* >(this))->Previous() ); - } - - bool operator==( const TiXmlAttribute& rhs ) const { return rhs.name == name; } - bool operator<( const TiXmlAttribute& rhs ) const { return name < rhs.name; } - bool operator>( const TiXmlAttribute& rhs ) const { return name > rhs.name; } - - /* Attribute parsing starts: first letter of the name - returns: the next char after the value end quote - */ - virtual const char* Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ); - - // Prints this Attribute to a FILE stream. - virtual void Print( FILE* cfile, int depth ) const { - Print( cfile, depth, 0 ); - } - void Print( FILE* cfile, int depth, TIXML_STRING* str ) const; - - // [internal use] - // Set the document pointer so the attribute can report errors. - void SetDocument( TiXmlDocument* doc ) { document = doc; } - -private: - TiXmlAttribute( const TiXmlAttribute& ); // not implemented. - void operator=( const TiXmlAttribute& base ); // not allowed. - - TiXmlDocument* document; // A pointer back to a document, for error reporting. - TIXML_STRING name; - TIXML_STRING value; - TiXmlAttribute* prev; - TiXmlAttribute* next; -}; - - -/* A class used to manage a group of attributes. - It is only used internally, both by the ELEMENT and the DECLARATION. - - The set can be changed transparent to the Element and Declaration - classes that use it, but NOT transparent to the Attribute - which has to implement a next() and previous() method. Which makes - it a bit problematic and prevents the use of STL. - - This version is implemented with circular lists because: - - I like circular lists - - it demonstrates some independence from the (typical) doubly linked list. -*/ -class TiXmlAttributeSet -{ -public: - TiXmlAttributeSet(); - ~TiXmlAttributeSet(); - - void Add( TiXmlAttribute* attribute ); - void Remove( TiXmlAttribute* attribute ); - - const TiXmlAttribute* First() const { return ( sentinel.next == &sentinel ) ? 0 : sentinel.next; } - TiXmlAttribute* First() { return ( sentinel.next == &sentinel ) ? 0 : sentinel.next; } - const TiXmlAttribute* Last() const { return ( sentinel.prev == &sentinel ) ? 0 : sentinel.prev; } - TiXmlAttribute* Last() { return ( sentinel.prev == &sentinel ) ? 0 : sentinel.prev; } - - TiXmlAttribute* Find( const char* _name ) const; - TiXmlAttribute* FindOrCreate( const char* _name ); - -# ifdef TIXML_USE_STL - TiXmlAttribute* Find( const std::string& _name ) const; - TiXmlAttribute* FindOrCreate( const std::string& _name ); -# endif - - -private: - //*ME: Because of hidden/disabled copy-construktor in TiXmlAttribute (sentinel-element), - //*ME: this class must be also use a hidden/disabled copy-constructor !!! - TiXmlAttributeSet( const TiXmlAttributeSet& ); // not allowed - void operator=( const TiXmlAttributeSet& ); // not allowed (as TiXmlAttribute) - - TiXmlAttribute sentinel; -}; - - -/** The element is a container class. It has a value, the element name, - and can contain other elements, text, comments, and unknowns. - Elements also contain an arbitrary number of attributes. -*/ -class TiXmlElement : public TiXmlNode -{ -public: - /// Construct an element. - TiXmlElement (const char * in_value); - - #ifdef TIXML_USE_STL - /// std::string constructor. - TiXmlElement( const std::string& _value ); - #endif - - TiXmlElement( const TiXmlElement& ); - - TiXmlElement& operator=( const TiXmlElement& base ); - - virtual ~TiXmlElement(); - - /** Given an attribute name, Attribute() returns the value - for the attribute of that name, or null if none exists. - */ - const char* Attribute( const char* name ) const; - - /** Given an attribute name, Attribute() returns the value - for the attribute of that name, or null if none exists. - If the attribute exists and can be converted to an integer, - the integer value will be put in the return 'i', if 'i' - is non-null. - */ - const char* Attribute( const char* name, int* i ) const; - - /** Given an attribute name, Attribute() returns the value - for the attribute of that name, or null if none exists. - If the attribute exists and can be converted to an double, - the double value will be put in the return 'd', if 'd' - is non-null. - */ - const char* Attribute( const char* name, double* d ) const; - - /** QueryIntAttribute examines the attribute - it is an alternative to the - Attribute() method with richer error checking. - If the attribute is an integer, it is stored in 'value' and - the call returns TIXML_SUCCESS. If it is not - an integer, it returns TIXML_WRONG_TYPE. If the attribute - does not exist, then TIXML_NO_ATTRIBUTE is returned. - */ - int QueryIntAttribute( const char* name, int* _value ) const; - /// QueryUnsignedAttribute examines the attribute - see QueryIntAttribute(). - int QueryUnsignedAttribute( const char* name, unsigned* _value ) const; - /** QueryBoolAttribute examines the attribute - see QueryIntAttribute(). - Note that '1', 'true', or 'yes' are considered true, while '0', 'false' - and 'no' are considered false. - */ - int QueryBoolAttribute( const char* name, bool* _value ) const; - /// QueryDoubleAttribute examines the attribute - see QueryIntAttribute(). - int QueryDoubleAttribute( const char* name, double* _value ) const; - /// QueryFloatAttribute examines the attribute - see QueryIntAttribute(). - int QueryFloatAttribute( const char* name, float* _value ) const { - double d; - int result = QueryDoubleAttribute( name, &d ); - if ( result == TIXML_SUCCESS ) { - *_value = (float)d; - } - return result; - } - - #ifdef TIXML_USE_STL - /// QueryStringAttribute examines the attribute - see QueryIntAttribute(). - int QueryStringAttribute( const char* name, std::string* _value ) const { - const char* cstr = Attribute( name ); - if ( cstr ) { - *_value = std::string( cstr ); - return TIXML_SUCCESS; - } - return TIXML_NO_ATTRIBUTE; - } - - /** Template form of the attribute query which will try to read the - attribute into the specified type. Very easy, very powerful, but - be careful to make sure to call this with the correct type. - - NOTE: This method doesn't work correctly for 'string' types that contain spaces. - - @return TIXML_SUCCESS, TIXML_WRONG_TYPE, or TIXML_NO_ATTRIBUTE - */ - template< typename T > int QueryValueAttribute( const std::string& name, T* outValue ) const - { - const TiXmlAttribute* node = attributeSet.Find( name ); - if ( !node ) - return TIXML_NO_ATTRIBUTE; - - std::stringstream sstream( node->ValueStr() ); - sstream >> *outValue; - if ( !sstream.fail() ) - return TIXML_SUCCESS; - return TIXML_WRONG_TYPE; - } - - int QueryValueAttribute( const std::string& name, std::string* outValue ) const - { - const TiXmlAttribute* node = attributeSet.Find( name ); - if ( !node ) - return TIXML_NO_ATTRIBUTE; - *outValue = node->ValueStr(); - return TIXML_SUCCESS; - } - #endif - - /** Sets an attribute of name to a given value. The attribute - will be created if it does not exist, or changed if it does. - */ - void SetAttribute( const char* name, const char * _value ); - - #ifdef TIXML_USE_STL - const std::string* Attribute( const std::string& name ) const; - const std::string* Attribute( const std::string& name, int* i ) const; - const std::string* Attribute( const std::string& name, double* d ) const; - int QueryIntAttribute( const std::string& name, int* _value ) const; - int QueryDoubleAttribute( const std::string& name, double* _value ) const; - - /// STL std::string form. - void SetAttribute( const std::string& name, const std::string& _value ); - ///< STL std::string form. - void SetAttribute( const std::string& name, int _value ); - ///< STL std::string form. - void SetDoubleAttribute( const std::string& name, double value ); - #endif - - /** Sets an attribute of name to a given value. The attribute - will be created if it does not exist, or changed if it does. - */ - void SetAttribute( const char * name, int value ); - - /** Sets an attribute of name to a given value. The attribute - will be created if it does not exist, or changed if it does. - */ - void SetDoubleAttribute( const char * name, double value ); - - /** Deletes an attribute with the given name. - */ - void RemoveAttribute( const char * name ); - #ifdef TIXML_USE_STL - void RemoveAttribute( const std::string& name ) { RemoveAttribute (name.c_str ()); } ///< STL std::string form. - #endif - - const TiXmlAttribute* FirstAttribute() const { return attributeSet.First(); } ///< Access the first attribute in this element. - TiXmlAttribute* FirstAttribute() { return attributeSet.First(); } - const TiXmlAttribute* LastAttribute() const { return attributeSet.Last(); } ///< Access the last attribute in this element. - TiXmlAttribute* LastAttribute() { return attributeSet.Last(); } - - /** Convenience function for easy access to the text inside an element. Although easy - and concise, GetText() is limited compared to getting the TiXmlText child - and accessing it directly. - - If the first child of 'this' is a TiXmlText, the GetText() - returns the character string of the Text node, else null is returned. - - This is a convenient method for getting the text of simple contained text: - @verbatim - This is text - const char* str = fooElement->GetText(); - @endverbatim - - 'str' will be a pointer to "This is text". - - Note that this function can be misleading. If the element foo was created from - this XML: - @verbatim - This is text - @endverbatim - - then the value of str would be null. The first child node isn't a text node, it is - another element. From this XML: - @verbatim - This is text - @endverbatim - GetText() will return "This is ". - - WARNING: GetText() accesses a child node - don't become confused with the - similarly named TiXmlHandle::Text() and TiXmlNode::ToText() which are - safe type casts on the referenced node. - */ - const char* GetText() const; - - /// Creates a new Element and returns it - the returned element is a copy. - virtual TiXmlNode* Clone() const; - // Print the Element to a FILE stream. - virtual void Print( FILE* cfile, int depth ) const; - - /* Attribtue parsing starts: next char past '<' - returns: next char past '>' - */ - virtual const char* Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ); - - virtual const TiXmlElement* ToElement() const { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - virtual TiXmlElement* ToElement() { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - - /** Walk the XML tree visiting this node and all of its children. - */ - virtual bool Accept( TiXmlVisitor* visitor ) const; - -protected: - - void CopyTo( TiXmlElement* target ) const; - void ClearThis(); // like clear, but initializes 'this' object as well - - // Used to be public [internal use] - #ifdef TIXML_USE_STL - virtual void StreamIn( std::istream * in, TIXML_STRING * tag ); - #endif - /* [internal use] - Reads the "value" of the element -- another element, or text. - This should terminate with the current end tag. - */ - const char* ReadValue( const char* in, TiXmlParsingData* prevData, TiXmlEncoding encoding ); - -private: - TiXmlAttributeSet attributeSet; -}; - - -/** An XML comment. -*/ -class TiXmlComment : public TiXmlNode -{ -public: - /// Constructs an empty comment. - TiXmlComment() : TiXmlNode( TiXmlNode::TINYXML_COMMENT ) {} - /// Construct a comment from text. - TiXmlComment( const char* _value ) : TiXmlNode( TiXmlNode::TINYXML_COMMENT ) { - SetValue( _value ); - } - TiXmlComment( const TiXmlComment& ); - TiXmlComment& operator=( const TiXmlComment& base ); - - virtual ~TiXmlComment() {} - - /// Returns a copy of this Comment. - virtual TiXmlNode* Clone() const; - // Write this Comment to a FILE stream. - virtual void Print( FILE* cfile, int depth ) const; - - /* Attribtue parsing starts: at the ! of the !-- - returns: next char past '>' - */ - virtual const char* Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ); - - virtual const TiXmlComment* ToComment() const { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - virtual TiXmlComment* ToComment() { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - - /** Walk the XML tree visiting this node and all of its children. - */ - virtual bool Accept( TiXmlVisitor* visitor ) const; - -protected: - void CopyTo( TiXmlComment* target ) const; - - // used to be public - #ifdef TIXML_USE_STL - virtual void StreamIn( std::istream * in, TIXML_STRING * tag ); - #endif -// virtual void StreamOut( TIXML_OSTREAM * out ) const; - -private: - -}; - - -/** XML text. A text node can have 2 ways to output the next. "normal" output - and CDATA. It will default to the mode it was parsed from the XML file and - you generally want to leave it alone, but you can change the output mode with - SetCDATA() and query it with CDATA(). -*/ -class TiXmlText : public TiXmlNode -{ - friend class TiXmlElement; -public: - /** Constructor for text element. By default, it is treated as - normal, encoded text. If you want it be output as a CDATA text - element, set the parameter _cdata to 'true' - */ - TiXmlText (const char * initValue ) : TiXmlNode (TiXmlNode::TINYXML_TEXT) - { - SetValue( initValue ); - cdata = false; - } - virtual ~TiXmlText() {} - - #ifdef TIXML_USE_STL - /// Constructor. - TiXmlText( const std::string& initValue ) : TiXmlNode (TiXmlNode::TINYXML_TEXT) - { - SetValue( initValue ); - cdata = false; - } - #endif - - TiXmlText( const TiXmlText& copy ) : TiXmlNode( TiXmlNode::TINYXML_TEXT ) { copy.CopyTo( this ); } - TiXmlText& operator=( const TiXmlText& base ) { base.CopyTo( this ); return *this; } - - // Write this text object to a FILE stream. - virtual void Print( FILE* cfile, int depth ) const; - - /// Queries whether this represents text using a CDATA section. - bool CDATA() const { return cdata; } - /// Turns on or off a CDATA representation of text. - void SetCDATA( bool _cdata ) { cdata = _cdata; } - - virtual const char* Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ); - - virtual const TiXmlText* ToText() const { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - virtual TiXmlText* ToText() { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - - /** Walk the XML tree visiting this node and all of its children. - */ - virtual bool Accept( TiXmlVisitor* content ) const; - -protected : - /// [internal use] Creates a new Element and returns it. - virtual TiXmlNode* Clone() const; - void CopyTo( TiXmlText* target ) const; - - bool Blank() const; // returns true if all white space and new lines - // [internal use] - #ifdef TIXML_USE_STL - virtual void StreamIn( std::istream * in, TIXML_STRING * tag ); - #endif - -private: - bool cdata; // true if this should be input and output as a CDATA style text element -}; - - -/** In correct XML the declaration is the first entry in the file. - @verbatim - - @endverbatim - - TinyXml will happily read or write files without a declaration, - however. There are 3 possible attributes to the declaration: - version, encoding, and standalone. - - Note: In this version of the code, the attributes are - handled as special cases, not generic attributes, simply - because there can only be at most 3 and they are always the same. -*/ -class TiXmlDeclaration : public TiXmlNode -{ -public: - /// Construct an empty declaration. - TiXmlDeclaration() : TiXmlNode( TiXmlNode::TINYXML_DECLARATION ) {} - -#ifdef TIXML_USE_STL - /// Constructor. - TiXmlDeclaration( const std::string& _version, - const std::string& _encoding, - const std::string& _standalone ); -#endif - - /// Construct. - TiXmlDeclaration( const char* _version, - const char* _encoding, - const char* _standalone ); - - TiXmlDeclaration( const TiXmlDeclaration& copy ); - TiXmlDeclaration& operator=( const TiXmlDeclaration& copy ); - - virtual ~TiXmlDeclaration() {} - - /// Version. Will return an empty string if none was found. - const char *Version() const { return version.c_str (); } - /// Encoding. Will return an empty string if none was found. - const char *Encoding() const { return encoding.c_str (); } - /// Is this a standalone document? - const char *Standalone() const { return standalone.c_str (); } - - /// Creates a copy of this Declaration and returns it. - virtual TiXmlNode* Clone() const; - // Print this declaration to a FILE stream. - virtual void Print( FILE* cfile, int depth, TIXML_STRING* str ) const; - virtual void Print( FILE* cfile, int depth ) const { - Print( cfile, depth, 0 ); - } - - virtual const char* Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ); - - virtual const TiXmlDeclaration* ToDeclaration() const { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - virtual TiXmlDeclaration* ToDeclaration() { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - - /** Walk the XML tree visiting this node and all of its children. - */ - virtual bool Accept( TiXmlVisitor* visitor ) const; - -protected: - void CopyTo( TiXmlDeclaration* target ) const; - // used to be public - #ifdef TIXML_USE_STL - virtual void StreamIn( std::istream * in, TIXML_STRING * tag ); - #endif - -private: - - TIXML_STRING version; - TIXML_STRING encoding; - TIXML_STRING standalone; -}; - - -/** Any tag that tinyXml doesn't recognize is saved as an - unknown. It is a tag of text, but should not be modified. - It will be written back to the XML, unchanged, when the file - is saved. - - DTD tags get thrown into TiXmlUnknowns. -*/ -class TiXmlUnknown : public TiXmlNode -{ -public: - TiXmlUnknown() : TiXmlNode( TiXmlNode::TINYXML_UNKNOWN ) {} - virtual ~TiXmlUnknown() {} - - TiXmlUnknown( const TiXmlUnknown& copy ) : TiXmlNode( TiXmlNode::TINYXML_UNKNOWN ) { copy.CopyTo( this ); } - TiXmlUnknown& operator=( const TiXmlUnknown& copy ) { copy.CopyTo( this ); return *this; } - - /// Creates a copy of this Unknown and returns it. - virtual TiXmlNode* Clone() const; - // Print this Unknown to a FILE stream. - virtual void Print( FILE* cfile, int depth ) const; - - virtual const char* Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ); - - virtual const TiXmlUnknown* ToUnknown() const { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - virtual TiXmlUnknown* ToUnknown() { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - - /** Walk the XML tree visiting this node and all of its children. - */ - virtual bool Accept( TiXmlVisitor* content ) const; - -protected: - void CopyTo( TiXmlUnknown* target ) const; - - #ifdef TIXML_USE_STL - virtual void StreamIn( std::istream * in, TIXML_STRING * tag ); - #endif - -private: - -}; - - -/** Always the top level node. A document binds together all the - XML pieces. It can be saved, loaded, and printed to the screen. - The 'value' of a document node is the xml file name. -*/ -class TiXmlDocument : public TiXmlNode -{ -public: - /// Create an empty document, that has no name. - TiXmlDocument(); - /// Create a document with a name. The name of the document is also the filename of the xml. - TiXmlDocument( const char * documentName ); - - #ifdef TIXML_USE_STL - /// Constructor. - TiXmlDocument( const std::string& documentName ); - #endif - - TiXmlDocument( const TiXmlDocument& copy ); - TiXmlDocument& operator=( const TiXmlDocument& copy ); - - virtual ~TiXmlDocument() {} - - /** Load a file using the current document value. - Returns true if successful. Will delete any existing - document data before loading. - */ - bool LoadFile( TiXmlEncoding encoding = TIXML_DEFAULT_ENCODING ); - /// Save a file using the current document value. Returns true if successful. - bool SaveFile() const; - /// Load a file using the given filename. Returns true if successful. - bool LoadFile( const char * filename, TiXmlEncoding encoding = TIXML_DEFAULT_ENCODING ); - /// Save a file using the given filename. Returns true if successful. - bool SaveFile( const char * filename ) const; - /** Load a file using the given FILE*. Returns true if successful. Note that this method - doesn't stream - the entire object pointed at by the FILE* - will be interpreted as an XML file. TinyXML doesn't stream in XML from the current - file location. Streaming may be added in the future. - */ - bool LoadFile( FILE*, TiXmlEncoding encoding = TIXML_DEFAULT_ENCODING ); - /// Save a file using the given FILE*. Returns true if successful. - bool SaveFile( FILE* ) const; - - #ifdef TIXML_USE_STL - bool LoadFile( const std::string& filename, TiXmlEncoding encoding = TIXML_DEFAULT_ENCODING ) ///< STL std::string version. - { - return LoadFile( filename.c_str(), encoding ); - } - bool SaveFile( const std::string& filename ) const ///< STL std::string version. - { - return SaveFile( filename.c_str() ); - } - #endif - - /** Parse the given null terminated block of xml data. Passing in an encoding to this - method (either TIXML_ENCODING_LEGACY or TIXML_ENCODING_UTF8 will force TinyXml - to use that encoding, regardless of what TinyXml might otherwise try to detect. - */ - virtual const char* Parse( const char* p, TiXmlParsingData* data = 0, TiXmlEncoding encoding = TIXML_DEFAULT_ENCODING ); - - /** Get the root element -- the only top level element -- of the document. - In well formed XML, there should only be one. TinyXml is tolerant of - multiple elements at the document level. - */ - const TiXmlElement* RootElement() const { return FirstChildElement(); } - TiXmlElement* RootElement() { return FirstChildElement(); } - - /** If an error occurs, Error will be set to true. Also, - - The ErrorId() will contain the integer identifier of the error (not generally useful) - - The ErrorDesc() method will return the name of the error. (very useful) - - The ErrorRow() and ErrorCol() will return the location of the error (if known) - */ - bool Error() const { return error; } - - /// Contains a textual (english) description of the error if one occurs. - const char * ErrorDesc() const { return errorDesc.c_str (); } - - /** Generally, you probably want the error string ( ErrorDesc() ). But if you - prefer the ErrorId, this function will fetch it. - */ - int ErrorId() const { return errorId; } - - /** Returns the location (if known) of the error. The first column is column 1, - and the first row is row 1. A value of 0 means the row and column wasn't applicable - (memory errors, for example, have no row/column) or the parser lost the error. (An - error in the error reporting, in that case.) - - @sa SetTabSize, Row, Column - */ - int ErrorRow() const { return errorLocation.row+1; } - int ErrorCol() const { return errorLocation.col+1; } ///< The column where the error occured. See ErrorRow() - - /** SetTabSize() allows the error reporting functions (ErrorRow() and ErrorCol()) - to report the correct values for row and column. It does not change the output - or input in any way. - - By calling this method, with a tab size - greater than 0, the row and column of each node and attribute is stored - when the file is loaded. Very useful for tracking the DOM back in to - the source file. - - The tab size is required for calculating the location of nodes. If not - set, the default of 4 is used. The tabsize is set per document. Setting - the tabsize to 0 disables row/column tracking. - - Note that row and column tracking is not supported when using operator>>. - - The tab size needs to be enabled before the parse or load. Correct usage: - @verbatim - TiXmlDocument doc; - doc.SetTabSize( 8 ); - doc.Load( "myfile.xml" ); - @endverbatim - - @sa Row, Column - */ - void SetTabSize( int _tabsize ) { tabsize = _tabsize; } - - int TabSize() const { return tabsize; } - - /** If you have handled the error, it can be reset with this call. The error - state is automatically cleared if you Parse a new XML block. - */ - void ClearError() { error = false; - errorId = 0; - errorDesc = ""; - errorLocation.row = errorLocation.col = 0; - //errorLocation.last = 0; - } - - /** Write the document to standard out using formatted printing ("pretty print"). */ - void Print() const { Print( stdout, 0 ); } - - /* Write the document to a string using formatted printing ("pretty print"). This - will allocate a character array (new char[]) and return it as a pointer. The - calling code pust call delete[] on the return char* to avoid a memory leak. - */ - //char* PrintToMemory() const; - - /// Print this Document to a FILE stream. - virtual void Print( FILE* cfile, int depth = 0 ) const; - // [internal use] - void SetError( int err, const char* errorLocation, TiXmlParsingData* prevData, TiXmlEncoding encoding ); - - virtual const TiXmlDocument* ToDocument() const { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - virtual TiXmlDocument* ToDocument() { return this; } ///< Cast to a more defined type. Will return null not of the requested type. - - /** Walk the XML tree visiting this node and all of its children. - */ - virtual bool Accept( TiXmlVisitor* content ) const; - -protected : - // [internal use] - virtual TiXmlNode* Clone() const; - #ifdef TIXML_USE_STL - virtual void StreamIn( std::istream * in, TIXML_STRING * tag ); - #endif - -private: - void CopyTo( TiXmlDocument* target ) const; - - bool error; - int errorId; - TIXML_STRING errorDesc; - int tabsize; - TiXmlCursor errorLocation; - bool useMicrosoftBOM; // the UTF-8 BOM were found when read. Note this, and try to write. -}; - - -/** - A TiXmlHandle is a class that wraps a node pointer with null checks; this is - an incredibly useful thing. Note that TiXmlHandle is not part of the TinyXml - DOM structure. It is a separate utility class. - - Take an example: - @verbatim - - - - - - - @endverbatim - - Assuming you want the value of "attributeB" in the 2nd "Child" element, it's very - easy to write a *lot* of code that looks like: - - @verbatim - TiXmlElement* root = document.FirstChildElement( "Document" ); - if ( root ) - { - TiXmlElement* element = root->FirstChildElement( "Element" ); - if ( element ) - { - TiXmlElement* child = element->FirstChildElement( "Child" ); - if ( child ) - { - TiXmlElement* child2 = child->NextSiblingElement( "Child" ); - if ( child2 ) - { - // Finally do something useful. - @endverbatim - - And that doesn't even cover "else" cases. TiXmlHandle addresses the verbosity - of such code. A TiXmlHandle checks for null pointers so it is perfectly safe - and correct to use: - - @verbatim - TiXmlHandle docHandle( &document ); - TiXmlElement* child2 = docHandle.FirstChild( "Document" ).FirstChild( "Element" ).Child( "Child", 1 ).ToElement(); - if ( child2 ) - { - // do something useful - @endverbatim - - Which is MUCH more concise and useful. - - It is also safe to copy handles - internally they are nothing more than node pointers. - @verbatim - TiXmlHandle handleCopy = handle; - @endverbatim - - What they should not be used for is iteration: - - @verbatim - int i=0; - while ( true ) - { - TiXmlElement* child = docHandle.FirstChild( "Document" ).FirstChild( "Element" ).Child( "Child", i ).ToElement(); - if ( !child ) - break; - // do something - ++i; - } - @endverbatim - - It seems reasonable, but it is in fact two embedded while loops. The Child method is - a linear walk to find the element, so this code would iterate much more than it needs - to. Instead, prefer: - - @verbatim - TiXmlElement* child = docHandle.FirstChild( "Document" ).FirstChild( "Element" ).FirstChild( "Child" ).ToElement(); - - for( child; child; child=child->NextSiblingElement() ) - { - // do something - } - @endverbatim -*/ -class TiXmlHandle -{ -public: - /// Create a handle from any node (at any depth of the tree.) This can be a null pointer. - TiXmlHandle( TiXmlNode* _node ) { this->node = _node; } - /// Copy constructor - TiXmlHandle( const TiXmlHandle& ref ) { this->node = ref.node; } - TiXmlHandle operator=( const TiXmlHandle& ref ) { if ( &ref != this ) this->node = ref.node; return *this; } - - /// Return a handle to the first child node. - TiXmlHandle FirstChild() const; - /// Return a handle to the first child node with the given name. - TiXmlHandle FirstChild( const char * value ) const; - /// Return a handle to the first child element. - TiXmlHandle FirstChildElement() const; - /// Return a handle to the first child element with the given name. - TiXmlHandle FirstChildElement( const char * value ) const; - - /** Return a handle to the "index" child with the given name. - The first child is 0, the second 1, etc. - */ - TiXmlHandle Child( const char* value, int index ) const; - /** Return a handle to the "index" child. - The first child is 0, the second 1, etc. - */ - TiXmlHandle Child( int index ) const; - /** Return a handle to the "index" child element with the given name. - The first child element is 0, the second 1, etc. Note that only TiXmlElements - are indexed: other types are not counted. - */ - TiXmlHandle ChildElement( const char* value, int index ) const; - /** Return a handle to the "index" child element. - The first child element is 0, the second 1, etc. Note that only TiXmlElements - are indexed: other types are not counted. - */ - TiXmlHandle ChildElement( int index ) const; - - #ifdef TIXML_USE_STL - TiXmlHandle FirstChild( const std::string& _value ) const { return FirstChild( _value.c_str() ); } - TiXmlHandle FirstChildElement( const std::string& _value ) const { return FirstChildElement( _value.c_str() ); } - - TiXmlHandle Child( const std::string& _value, int index ) const { return Child( _value.c_str(), index ); } - TiXmlHandle ChildElement( const std::string& _value, int index ) const { return ChildElement( _value.c_str(), index ); } - #endif - - /** Return the handle as a TiXmlNode. This may return null. - */ - TiXmlNode* ToNode() const { return node; } - /** Return the handle as a TiXmlElement. This may return null. - */ - TiXmlElement* ToElement() const { return ( ( node && node->ToElement() ) ? node->ToElement() : 0 ); } - /** Return the handle as a TiXmlText. This may return null. - */ - TiXmlText* ToText() const { return ( ( node && node->ToText() ) ? node->ToText() : 0 ); } - /** Return the handle as a TiXmlUnknown. This may return null. - */ - TiXmlUnknown* ToUnknown() const { return ( ( node && node->ToUnknown() ) ? node->ToUnknown() : 0 ); } - - /** @deprecated use ToNode. - Return the handle as a TiXmlNode. This may return null. - */ - TiXmlNode* Node() const { return ToNode(); } - /** @deprecated use ToElement. - Return the handle as a TiXmlElement. This may return null. - */ - TiXmlElement* Element() const { return ToElement(); } - /** @deprecated use ToText() - Return the handle as a TiXmlText. This may return null. - */ - TiXmlText* Text() const { return ToText(); } - /** @deprecated use ToUnknown() - Return the handle as a TiXmlUnknown. This may return null. - */ - TiXmlUnknown* Unknown() const { return ToUnknown(); } - -private: - TiXmlNode* node; -}; - - -/** Print to memory functionality. The TiXmlPrinter is useful when you need to: - - -# Print to memory (especially in non-STL mode) - -# Control formatting (line endings, etc.) - - When constructed, the TiXmlPrinter is in its default "pretty printing" mode. - Before calling Accept() you can call methods to control the printing - of the XML document. After TiXmlNode::Accept() is called, the printed document can - be accessed via the CStr(), Str(), and Size() methods. - - TiXmlPrinter uses the Visitor API. - @verbatim - TiXmlPrinter printer; - printer.SetIndent( "\t" ); - - doc.Accept( &printer ); - fprintf( stdout, "%s", printer.CStr() ); - @endverbatim -*/ -class TiXmlPrinter : public TiXmlVisitor -{ -public: - TiXmlPrinter() : depth( 0 ), simpleTextPrint( false ), - buffer(), indent( " " ), lineBreak( "\n" ) {} - - virtual bool VisitEnter( const TiXmlDocument& doc ); - virtual bool VisitExit( const TiXmlDocument& doc ); - - virtual bool VisitEnter( const TiXmlElement& element, const TiXmlAttribute* firstAttribute ); - virtual bool VisitExit( const TiXmlElement& element ); - - virtual bool Visit( const TiXmlDeclaration& declaration ); - virtual bool Visit( const TiXmlText& text ); - virtual bool Visit( const TiXmlComment& comment ); - virtual bool Visit( const TiXmlUnknown& unknown ); - - /** Set the indent characters for printing. By default 4 spaces - but tab (\t) is also useful, or null/empty string for no indentation. - */ - void SetIndent( const char* _indent ) { indent = _indent ? _indent : "" ; } - /// Query the indention string. - const char* Indent() { return indent.c_str(); } - /** Set the line breaking string. By default set to newline (\n). - Some operating systems prefer other characters, or can be - set to the null/empty string for no indenation. - */ - void SetLineBreak( const char* _lineBreak ) { lineBreak = _lineBreak ? _lineBreak : ""; } - /// Query the current line breaking string. - const char* LineBreak() { return lineBreak.c_str(); } - - /** Switch over to "stream printing" which is the most dense formatting without - linebreaks. Common when the XML is needed for network transmission. - */ - void SetStreamPrinting() { indent = ""; - lineBreak = ""; - } - /// Return the result. - const char* CStr() { return buffer.c_str(); } - /// Return the length of the result string. - size_t Size() { return buffer.size(); } - - #ifdef TIXML_USE_STL - /// Return the result. - const std::string& Str() { return buffer; } - #endif - -private: - void DoIndent() { - for( int i=0; i -#include - -#include "tinyxml.h" - -//#define DEBUG_PARSER -#if defined( DEBUG_PARSER ) -# if defined( DEBUG ) && defined( _MSC_VER ) -# include -# define TIXML_LOG OutputDebugString -# else -# define TIXML_LOG printf -# endif -#endif - -// Note tha "PutString" hardcodes the same list. This -// is less flexible than it appears. Changing the entries -// or order will break putstring. -TiXmlBase::Entity TiXmlBase::entity[ TiXmlBase::NUM_ENTITY ] = -{ - { "&", 5, '&' }, - { "<", 4, '<' }, - { ">", 4, '>' }, - { """, 6, '\"' }, - { "'", 6, '\'' } -}; - -// Bunch of unicode info at: -// http://www.unicode.org/faq/utf_bom.html -// Including the basic of this table, which determines the #bytes in the -// sequence from the lead byte. 1 placed for invalid sequences -- -// although the result will be junk, pass it through as much as possible. -// Beware of the non-characters in UTF-8: -// ef bb bf (Microsoft "lead bytes") -// ef bf be -// ef bf bf - -const unsigned char TIXML_UTF_LEAD_0 = 0xefU; -const unsigned char TIXML_UTF_LEAD_1 = 0xbbU; -const unsigned char TIXML_UTF_LEAD_2 = 0xbfU; - -const int TiXmlBase::utf8ByteTable[256] = -{ - // 0 1 2 3 4 5 6 7 8 9 a b c d e f - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x00 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x10 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x20 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x30 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x40 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x50 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x60 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x70 End of ASCII range - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x80 0x80 to 0xc1 invalid - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0x90 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0xa0 - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 0xb0 - 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, // 0xc0 0xc2 to 0xdf 2 byte - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, // 0xd0 - 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, // 0xe0 0xe0 to 0xef 3 byte - 4, 4, 4, 4, 4, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 // 0xf0 0xf0 to 0xf4 4 byte, 0xf5 and higher invalid -}; - - -void TiXmlBase::ConvertUTF32ToUTF8( unsigned long input, char* output, int* length ) -{ - const unsigned long BYTE_MASK = 0xBF; - const unsigned long BYTE_MARK = 0x80; - const unsigned long FIRST_BYTE_MARK[7] = { 0x00, 0x00, 0xC0, 0xE0, 0xF0, 0xF8, 0xFC }; - - if (input < 0x80) - *length = 1; - else if ( input < 0x800 ) - *length = 2; - else if ( input < 0x10000 ) - *length = 3; - else if ( input < 0x200000 ) - *length = 4; - else - { *length = 0; return; } // This code won't covert this correctly anyway. - - output += *length; - - // Scary scary fall throughs. - switch (*length) - { - case 4: - --output; - *output = (char)((input | BYTE_MARK) & BYTE_MASK); - input >>= 6; - case 3: - --output; - *output = (char)((input | BYTE_MARK) & BYTE_MASK); - input >>= 6; - case 2: - --output; - *output = (char)((input | BYTE_MARK) & BYTE_MASK); - input >>= 6; - case 1: - --output; - *output = (char)(input | FIRST_BYTE_MARK[*length]); - } -} - - -/*static*/ int TiXmlBase::IsAlpha( unsigned char anyByte, TiXmlEncoding /*encoding*/ ) -{ - // This will only work for low-ascii, everything else is assumed to be a valid - // letter. I'm not sure this is the best approach, but it is quite tricky trying - // to figure out alhabetical vs. not across encoding. So take a very - // conservative approach. - -// if ( encoding == TIXML_ENCODING_UTF8 ) -// { - if ( anyByte < 127 ) - return isalpha( anyByte ); - else - return 1; // What else to do? The unicode set is huge...get the english ones right. -// } -// else -// { -// return isalpha( anyByte ); -// } -} - - -/*static*/ int TiXmlBase::IsAlphaNum( unsigned char anyByte, TiXmlEncoding /*encoding*/ ) -{ - // This will only work for low-ascii, everything else is assumed to be a valid - // letter. I'm not sure this is the best approach, but it is quite tricky trying - // to figure out alhabetical vs. not across encoding. So take a very - // conservative approach. - -// if ( encoding == TIXML_ENCODING_UTF8 ) -// { - if ( anyByte < 127 ) - return isalnum( anyByte ); - else - return 1; // What else to do? The unicode set is huge...get the english ones right. -// } -// else -// { -// return isalnum( anyByte ); -// } -} - - -class TiXmlParsingData -{ - friend class TiXmlDocument; - public: - void Stamp( const char* now, TiXmlEncoding encoding ); - - const TiXmlCursor& Cursor() const { return cursor; } - - private: - // Only used by the document! - TiXmlParsingData( const char* start, int _tabsize, int row, int col ) - { - assert( start ); - stamp = start; - tabsize = _tabsize; - cursor.row = row; - cursor.col = col; - } - - TiXmlCursor cursor; - const char* stamp; - int tabsize; -}; - - -void TiXmlParsingData::Stamp( const char* now, TiXmlEncoding encoding ) -{ - assert( now ); - - // Do nothing if the tabsize is 0. - if ( tabsize < 1 ) - { - return; - } - - // Get the current row, column. - int row = cursor.row; - int col = cursor.col; - const char* p = stamp; - assert( p ); - - while ( p < now ) - { - // Treat p as unsigned, so we have a happy compiler. - const unsigned char* pU = (const unsigned char*)p; - - // Code contributed by Fletcher Dunn: (modified by lee) - switch (*pU) { - case 0: - // We *should* never get here, but in case we do, don't - // advance past the terminating null character, ever - return; - - case '\r': - // bump down to the next line - ++row; - col = 0; - // Eat the character - ++p; - - // Check for \r\n sequence, and treat this as a single character - if (*p == '\n') { - ++p; - } - break; - - case '\n': - // bump down to the next line - ++row; - col = 0; - - // Eat the character - ++p; - - // Check for \n\r sequence, and treat this as a single - // character. (Yes, this bizarre thing does occur still - // on some arcane platforms...) - if (*p == '\r') { - ++p; - } - break; - - case '\t': - // Eat the character - ++p; - - // Skip to next tab stop - col = (col / tabsize + 1) * tabsize; - break; - - case TIXML_UTF_LEAD_0: - if ( encoding == TIXML_ENCODING_UTF8 ) - { - if ( *(p+1) && *(p+2) ) - { - // In these cases, don't advance the column. These are - // 0-width spaces. - if ( *(pU+1)==TIXML_UTF_LEAD_1 && *(pU+2)==TIXML_UTF_LEAD_2 ) - p += 3; - else if ( *(pU+1)==0xbfU && *(pU+2)==0xbeU ) - p += 3; - else if ( *(pU+1)==0xbfU && *(pU+2)==0xbfU ) - p += 3; - else - { p +=3; ++col; } // A normal character. - } - } - else - { - ++p; - ++col; - } - break; - - default: - if ( encoding == TIXML_ENCODING_UTF8 ) - { - // Eat the 1 to 4 byte utf8 character. - int step = TiXmlBase::utf8ByteTable[*((const unsigned char*)p)]; - if ( step == 0 ) - step = 1; // Error case from bad encoding, but handle gracefully. - p += step; - - // Just advance one column, of course. - ++col; - } - else - { - ++p; - ++col; - } - break; - } - } - cursor.row = row; - cursor.col = col; - assert( cursor.row >= -1 ); - assert( cursor.col >= -1 ); - stamp = p; - assert( stamp ); -} - - -const char* TiXmlBase::SkipWhiteSpace( const char* p, TiXmlEncoding encoding ) -{ - if ( !p || !*p ) - { - return 0; - } - if ( encoding == TIXML_ENCODING_UTF8 ) - { - while ( *p ) - { - const unsigned char* pU = (const unsigned char*)p; - - // Skip the stupid Microsoft UTF-8 Byte order marks - if ( *(pU+0)==TIXML_UTF_LEAD_0 - && *(pU+1)==TIXML_UTF_LEAD_1 - && *(pU+2)==TIXML_UTF_LEAD_2 ) - { - p += 3; - continue; - } - else if(*(pU+0)==TIXML_UTF_LEAD_0 - && *(pU+1)==0xbfU - && *(pU+2)==0xbeU ) - { - p += 3; - continue; - } - else if(*(pU+0)==TIXML_UTF_LEAD_0 - && *(pU+1)==0xbfU - && *(pU+2)==0xbfU ) - { - p += 3; - continue; - } - - if ( IsWhiteSpace( *p ) ) // Still using old rules for white space. - ++p; - else - break; - } - } - else - { - while ( *p && IsWhiteSpace( *p ) ) - ++p; - } - - return p; -} - -#ifdef TIXML_USE_STL -/*static*/ bool TiXmlBase::StreamWhiteSpace( std::istream * in, TIXML_STRING * tag ) -{ - for( ;; ) - { - if ( !in->good() ) return false; - - int c = in->peek(); - // At this scope, we can't get to a document. So fail silently. - if ( !IsWhiteSpace( c ) || c <= 0 ) - return true; - - *tag += (char) in->get(); - } -} - -/*static*/ bool TiXmlBase::StreamTo( std::istream * in, int character, TIXML_STRING * tag ) -{ - //assert( character > 0 && character < 128 ); // else it won't work in utf-8 - while ( in->good() ) - { - int c = in->peek(); - if ( c == character ) - return true; - if ( c <= 0 ) // Silent failure: can't get document at this scope - return false; - - in->get(); - *tag += (char) c; - } - return false; -} -#endif - -// One of TinyXML's more performance demanding functions. Try to keep the memory overhead down. The -// "assign" optimization removes over 10% of the execution time. -// -const char* TiXmlBase::ReadName( const char* p, TIXML_STRING * name, TiXmlEncoding encoding ) -{ - // Oddly, not supported on some comilers, - //name->clear(); - // So use this: - *name = ""; - assert( p ); - - // Names start with letters or underscores. - // Of course, in unicode, tinyxml has no idea what a letter *is*. The - // algorithm is generous. - // - // After that, they can be letters, underscores, numbers, - // hyphens, or colons. (Colons are valid ony for namespaces, - // but tinyxml can't tell namespaces from names.) - if ( p && *p - && ( IsAlpha( (unsigned char) *p, encoding ) || *p == '_' ) ) - { - const char* start = p; - while( p && *p - && ( IsAlphaNum( (unsigned char ) *p, encoding ) - || *p == '_' - || *p == '-' - || *p == '.' - || *p == ':' ) ) - { - //(*name) += *p; // expensive - ++p; - } - if ( p-start > 0 ) { - name->assign( start, p-start ); - } - return p; - } - return 0; -} - -const char* TiXmlBase::GetEntity( const char* p, char* value, int* length, TiXmlEncoding encoding ) -{ - // Presume an entity, and pull it out. - TIXML_STRING ent; - int i; - *length = 0; - - if ( *(p+1) && *(p+1) == '#' && *(p+2) ) - { - unsigned long ucs = 0; - ptrdiff_t delta = 0; - unsigned mult = 1; - - if ( *(p+2) == 'x' ) - { - // Hexadecimal. - if ( !*(p+3) ) return 0; - - const char* q = p+3; - q = strchr( q, ';' ); - - if ( !q || !*q ) return 0; - - delta = q-p; - --q; - - while ( *q != 'x' ) - { - if ( *q >= '0' && *q <= '9' ) - ucs += mult * (*q - '0'); - else if ( *q >= 'a' && *q <= 'f' ) - ucs += mult * (*q - 'a' + 10); - else if ( *q >= 'A' && *q <= 'F' ) - ucs += mult * (*q - 'A' + 10 ); - else - return 0; - mult *= 16; - --q; - } - } - else - { - // Decimal. - if ( !*(p+2) ) return 0; - - const char* q = p+2; - q = strchr( q, ';' ); - - if ( !q || !*q ) return 0; - - delta = q-p; - --q; - - while ( *q != '#' ) - { - if ( *q >= '0' && *q <= '9' ) - ucs += mult * (*q - '0'); - else - return 0; - mult *= 10; - --q; - } - } - if ( encoding == TIXML_ENCODING_UTF8 ) - { - // convert the UCS to UTF-8 - ConvertUTF32ToUTF8( ucs, value, length ); - } - else - { - *value = (char)ucs; - *length = 1; - } - return p + delta + 1; - } - - // Now try to match it. - for( i=0; iappend( cArr, len ); - } - } - else - { - bool whitespace = false; - - // Remove leading white space: - p = SkipWhiteSpace( p, encoding ); - while ( p && *p - && !StringEqual( p, endTag, caseInsensitive, encoding ) ) - { - if ( *p == '\r' || *p == '\n' ) - { - whitespace = true; - ++p; - } - else if ( IsWhiteSpace( *p ) ) - { - whitespace = true; - ++p; - } - else - { - // If we've found whitespace, add it before the - // new character. Any whitespace just becomes a space. - if ( whitespace ) - { - (*text) += ' '; - whitespace = false; - } - int len; - char cArr[4] = { 0, 0, 0, 0 }; - p = GetChar( p, cArr, &len, encoding ); - if ( len == 1 ) - (*text) += cArr[0]; // more efficient - else - text->append( cArr, len ); - } - } - } - if ( p && *p ) - p += strlen( endTag ); - return ( p && *p ) ? p : 0; -} - -#ifdef TIXML_USE_STL - -void TiXmlDocument::StreamIn( std::istream * in, TIXML_STRING * tag ) -{ - // The basic issue with a document is that we don't know what we're - // streaming. Read something presumed to be a tag (and hope), then - // identify it, and call the appropriate stream method on the tag. - // - // This "pre-streaming" will never read the closing ">" so the - // sub-tag can orient itself. - - if ( !StreamTo( in, '<', tag ) ) - { - SetError( TIXML_ERROR_PARSING_EMPTY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return; - } - - while ( in->good() ) - { - int tagIndex = (int) tag->length(); - while ( in->good() && in->peek() != '>' ) - { - int c = in->get(); - if ( c <= 0 ) - { - SetError( TIXML_ERROR_EMBEDDED_NULL, 0, 0, TIXML_ENCODING_UNKNOWN ); - break; - } - (*tag) += (char) c; - } - - if ( in->good() ) - { - // We now have something we presume to be a node of - // some sort. Identify it, and call the node to - // continue streaming. - TiXmlNode* node = Identify( tag->c_str() + tagIndex, TIXML_DEFAULT_ENCODING ); - - if ( node ) - { - node->StreamIn( in, tag ); - bool isElement = node->ToElement() != 0; - delete node; - node = 0; - - // If this is the root element, we're done. Parsing will be - // done by the >> operator. - if ( isElement ) - { - return; - } - } - else - { - SetError( TIXML_ERROR, 0, 0, TIXML_ENCODING_UNKNOWN ); - return; - } - } - } - // We should have returned sooner. - SetError( TIXML_ERROR, 0, 0, TIXML_ENCODING_UNKNOWN ); -} - -#endif - -const char* TiXmlDocument::Parse( const char* p, TiXmlParsingData* prevData, TiXmlEncoding encoding ) -{ - ClearError(); - - // Parse away, at the document level. Since a document - // contains nothing but other tags, most of what happens - // here is skipping white space. - if ( !p || !*p ) - { - SetError( TIXML_ERROR_DOCUMENT_EMPTY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - - // Note that, for a document, this needs to come - // before the while space skip, so that parsing - // starts from the pointer we are given. - location.Clear(); - if ( prevData ) - { - location.row = prevData->cursor.row; - location.col = prevData->cursor.col; - } - else - { - location.row = 0; - location.col = 0; - } - TiXmlParsingData data( p, TabSize(), location.row, location.col ); - location = data.Cursor(); - - if ( encoding == TIXML_ENCODING_UNKNOWN ) - { - // Check for the Microsoft UTF-8 lead bytes. - const unsigned char* pU = (const unsigned char*)p; - if ( *(pU+0) && *(pU+0) == TIXML_UTF_LEAD_0 - && *(pU+1) && *(pU+1) == TIXML_UTF_LEAD_1 - && *(pU+2) && *(pU+2) == TIXML_UTF_LEAD_2 ) - { - encoding = TIXML_ENCODING_UTF8; - useMicrosoftBOM = true; - } - } - - p = SkipWhiteSpace( p, encoding ); - if ( !p ) - { - SetError( TIXML_ERROR_DOCUMENT_EMPTY, 0, 0, TIXML_ENCODING_UNKNOWN ); - return 0; - } - - while ( p && *p ) - { - TiXmlNode* node = Identify( p, encoding ); - if ( node ) - { - p = node->Parse( p, &data, encoding ); - LinkEndChild( node ); - } - else - { - break; - } - - // Did we get encoding info? - if ( encoding == TIXML_ENCODING_UNKNOWN - && node->ToDeclaration() ) - { - TiXmlDeclaration* dec = node->ToDeclaration(); - const char* enc = dec->Encoding(); - assert( enc ); - - if ( *enc == 0 ) - encoding = TIXML_ENCODING_UTF8; - else if ( StringEqual( enc, "UTF-8", true, TIXML_ENCODING_UNKNOWN ) ) - encoding = TIXML_ENCODING_UTF8; - else if ( StringEqual( enc, "UTF8", true, TIXML_ENCODING_UNKNOWN ) ) - encoding = TIXML_ENCODING_UTF8; // incorrect, but be nice - else - encoding = TIXML_ENCODING_LEGACY; - } - - p = SkipWhiteSpace( p, encoding ); - } - - // Was this empty? - if ( !firstChild ) { - SetError( TIXML_ERROR_DOCUMENT_EMPTY, 0, 0, encoding ); - return 0; - } - - // All is well. - return p; -} - -void TiXmlDocument::SetError( int err, const char* pError, TiXmlParsingData* data, TiXmlEncoding encoding ) -{ - // The first error in a chain is more accurate - don't set again! - if ( error ) - return; - - assert( err > 0 && err < TIXML_ERROR_STRING_COUNT ); - error = true; - errorId = err; - errorDesc = errorString[ errorId ]; - - errorLocation.Clear(); - if ( pError && data ) - { - data->Stamp( pError, encoding ); - errorLocation = data->Cursor(); - } -} - - -TiXmlNode* TiXmlNode::Identify( const char* p, TiXmlEncoding encoding ) -{ - TiXmlNode* returnNode = 0; - - p = SkipWhiteSpace( p, encoding ); - if( !p || !*p || *p != '<' ) - { - return 0; - } - - p = SkipWhiteSpace( p, encoding ); - - if ( !p || !*p ) - { - return 0; - } - - // What is this thing? - // - Elements start with a letter or underscore, but xml is reserved. - // - Comments: "; - - if ( !StringEqual( p, startTag, false, encoding ) ) - { - if ( document ) - document->SetError( TIXML_ERROR_PARSING_COMMENT, p, data, encoding ); - return 0; - } - p += strlen( startTag ); - - // [ 1475201 ] TinyXML parses entities in comments - // Oops - ReadText doesn't work, because we don't want to parse the entities. - // p = ReadText( p, &value, false, endTag, false, encoding ); - // - // from the XML spec: - /* - [Definition: Comments may appear anywhere in a document outside other markup; in addition, - they may appear within the document type declaration at places allowed by the grammar. - They are not part of the document's character data; an XML processor MAY, but need not, - make it possible for an application to retrieve the text of comments. For compatibility, - the string "--" (double-hyphen) MUST NOT occur within comments.] Parameter entity - references MUST NOT be recognized within comments. - - An example of a comment: - - - */ - - value = ""; - // Keep all the white space. - while ( p && *p && !StringEqual( p, endTag, false, encoding ) ) - { - value.append( p, 1 ); - ++p; - } - if ( p && *p ) - p += strlen( endTag ); - - return p; -} - - -const char* TiXmlAttribute::Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ) -{ - p = SkipWhiteSpace( p, encoding ); - if ( !p || !*p ) return 0; - - if ( data ) - { - data->Stamp( p, encoding ); - location = data->Cursor(); - } - // Read the name, the '=' and the value. - const char* pErr = p; - p = ReadName( p, &name, encoding ); - if ( !p || !*p ) - { - if ( document ) document->SetError( TIXML_ERROR_READING_ATTRIBUTES, pErr, data, encoding ); - return 0; - } - p = SkipWhiteSpace( p, encoding ); - if ( !p || !*p || *p != '=' ) - { - if ( document ) document->SetError( TIXML_ERROR_READING_ATTRIBUTES, p, data, encoding ); - return 0; - } - - ++p; // skip '=' - p = SkipWhiteSpace( p, encoding ); - if ( !p || !*p ) - { - if ( document ) document->SetError( TIXML_ERROR_READING_ATTRIBUTES, p, data, encoding ); - return 0; - } - - const char* end; - const char SINGLE_QUOTE = '\''; - const char DOUBLE_QUOTE = '\"'; - - if ( *p == SINGLE_QUOTE ) - { - ++p; - end = "\'"; // single quote in string - p = ReadText( p, &value, false, end, false, encoding ); - } - else if ( *p == DOUBLE_QUOTE ) - { - ++p; - end = "\""; // double quote in string - p = ReadText( p, &value, false, end, false, encoding ); - } - else - { - // All attribute values should be in single or double quotes. - // But this is such a common error that the parser will try - // its best, even without them. - value = ""; - while ( p && *p // existence - && !IsWhiteSpace( *p ) // whitespace - && *p != '/' && *p != '>' ) // tag end - { - if ( *p == SINGLE_QUOTE || *p == DOUBLE_QUOTE ) { - // [ 1451649 ] Attribute values with trailing quotes not handled correctly - // We did not have an opening quote but seem to have a - // closing one. Give up and throw an error. - if ( document ) document->SetError( TIXML_ERROR_READING_ATTRIBUTES, p, data, encoding ); - return 0; - } - value += *p; - ++p; - } - } - return p; -} - -#ifdef TIXML_USE_STL -void TiXmlText::StreamIn( std::istream * in, TIXML_STRING * tag ) -{ - while ( in->good() ) - { - int c = in->peek(); - if ( !cdata && (c == '<' ) ) - { - return; - } - if ( c <= 0 ) - { - TiXmlDocument* document = GetDocument(); - if ( document ) - document->SetError( TIXML_ERROR_EMBEDDED_NULL, 0, 0, TIXML_ENCODING_UNKNOWN ); - return; - } - - (*tag) += (char) c; - in->get(); // "commits" the peek made above - - if ( cdata && c == '>' && tag->size() >= 3 ) { - size_t len = tag->size(); - if ( (*tag)[len-2] == ']' && (*tag)[len-3] == ']' ) { - // terminator of cdata. - return; - } - } - } -} -#endif - -const char* TiXmlText::Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding encoding ) -{ - value = ""; - TiXmlDocument* document = GetDocument(); - - if ( data ) - { - data->Stamp( p, encoding ); - location = data->Cursor(); - } - - const char* const startTag = ""; - - if ( cdata || StringEqual( p, startTag, false, encoding ) ) - { - cdata = true; - - if ( !StringEqual( p, startTag, false, encoding ) ) - { - if ( document ) - document->SetError( TIXML_ERROR_PARSING_CDATA, p, data, encoding ); - return 0; - } - p += strlen( startTag ); - - // Keep all the white space, ignore the encoding, etc. - while ( p && *p - && !StringEqual( p, endTag, false, encoding ) - ) - { - value += *p; - ++p; - } - - TIXML_STRING dummy; - p = ReadText( p, &dummy, false, endTag, false, encoding ); - return p; - } - else - { - bool ignoreWhite = true; - - const char* end = "<"; - p = ReadText( p, &value, ignoreWhite, end, false, encoding ); - if ( p && *p ) - return p-1; // don't truncate the '<' - return 0; - } -} - -#ifdef TIXML_USE_STL -void TiXmlDeclaration::StreamIn( std::istream * in, TIXML_STRING * tag ) -{ - while ( in->good() ) - { - int c = in->get(); - if ( c <= 0 ) - { - TiXmlDocument* document = GetDocument(); - if ( document ) - document->SetError( TIXML_ERROR_EMBEDDED_NULL, 0, 0, TIXML_ENCODING_UNKNOWN ); - return; - } - (*tag) += (char) c; - - if ( c == '>' ) - { - // All is well. - return; - } - } -} -#endif - -const char* TiXmlDeclaration::Parse( const char* p, TiXmlParsingData* data, TiXmlEncoding _encoding ) -{ - p = SkipWhiteSpace( p, _encoding ); - // Find the beginning, find the end, and look for - // the stuff in-between. - TiXmlDocument* document = GetDocument(); - if ( !p || !*p || !StringEqual( p, "SetError( TIXML_ERROR_PARSING_DECLARATION, 0, 0, _encoding ); - return 0; - } - if ( data ) - { - data->Stamp( p, _encoding ); - location = data->Cursor(); - } - p += 5; - - version = ""; - encoding = ""; - standalone = ""; - - while ( p && *p ) - { - if ( *p == '>' ) - { - ++p; - return p; - } - - p = SkipWhiteSpace( p, _encoding ); - if ( StringEqual( p, "version", true, _encoding ) ) - { - TiXmlAttribute attrib; - p = attrib.Parse( p, data, _encoding ); - version = attrib.Value(); - } - else if ( StringEqual( p, "encoding", true, _encoding ) ) - { - TiXmlAttribute attrib; - p = attrib.Parse( p, data, _encoding ); - encoding = attrib.Value(); - } - else if ( StringEqual( p, "standalone", true, _encoding ) ) - { - TiXmlAttribute attrib; - p = attrib.Parse( p, data, _encoding ); - standalone = attrib.Value(); - } - else - { - // Read over whatever it is. - while( p && *p && *p != '>' && !IsWhiteSpace( *p ) ) - ++p; - } - } - return 0; -} - -bool TiXmlText::Blank() const -{ - for ( unsigned i=0; i - -namespace boost -{ - - template T lexical_cast(const char* txt) - { - double result = atof(txt); - return result; - }; - - struct bad_lexical_cast - { - const char* what() - { - return ("bad lexical cast\n"); - } - - }; - -} //namespace boost - -#endif - diff --git a/btgui/urdf/boost_replacement/printf_console.cpp b/btgui/urdf/boost_replacement/printf_console.cpp deleted file mode 100644 index 9c9014ac6..000000000 --- a/btgui/urdf/boost_replacement/printf_console.cpp +++ /dev/null @@ -1,28 +0,0 @@ -#include "printf_console.h" -#include - - -void logError(const char* msg, const char* arg0, const char* arg1, const char* arg2) -{ - printf("%s %s %s %s\n", msg,arg0,arg1,arg2); - -} - -void logDebug(const char* msg, float v0, float v1) -{ - printf("%s %f %f\n", msg, v0, v1); -}; -void logDebug(const char* msg, const char* msg1, const char* arg1) -{ - printf("%s %s %s\n", msg, msg1, arg1); - -} - -void logInform(const char* msg, const char* arg0) -{ - printf("%s %s\n", msg, arg0); -} -void logWarn(const char* msg,int id, const char* arg0) -{ - printf("%s %d %s\n", msg,id,arg0); -} diff --git a/btgui/urdf/boost_replacement/printf_console.h b/btgui/urdf/boost_replacement/printf_console.h deleted file mode 100644 index 247aab2c5..000000000 --- a/btgui/urdf/boost_replacement/printf_console.h +++ /dev/null @@ -1,13 +0,0 @@ -#ifndef PRINTF_CONSOLE_H -#define PRINTF_CONSOLE_H - - -void logError(const char* msg="", const char* arg0="", const char* arg1="", const char* arg2=""); -void logDebug(const char* msg, float v0, float v1); -void logDebug(const char* msg, const char* msg1="", const char* arg1=""); -void logInform(const char* msg, const char* arg0=""); -void logWarn(const char* msg,int id, const char* arg0=""); - -#endif - - diff --git a/btgui/urdf/boost_replacement/shared_ptr.h b/btgui/urdf/boost_replacement/shared_ptr.h deleted file mode 100644 index 5d29732b6..000000000 --- a/btgui/urdf/boost_replacement/shared_ptr.h +++ /dev/null @@ -1,210 +0,0 @@ -/* -Bullet Continuous Collision Detection and Physics Library Maya Plugin -Copyright (c) 2008 Walt Disney Studios - -This software is provided 'as-is', without any express or implied warranty. -In no event will the authors be held liable for any damages arising -from the use of this software. -Permission is granted to anyone to use this software for any purpose, -including commercial applications, and to alter it and redistribute it freely, -subject to the following restrictions: - -1. The origin of this software must not be misrepresented; you must -not claim that you wrote the original software. If you use this -software in a product, an acknowledgment in the product documentation -would be appreciated but is not required. -2. Altered source versions must be plainly marked as such, and must -not be misrepresented as being the original software. -3. This notice may not be removed or altered from any source distribution. - -Written by: Nicola Candussi - -Modified by Francisco Gochez -Dec 2011 - Added deferencing operator -*/ - -//my_shared_ptr - -#ifndef DYN_SHARED_PTR_H -#define DYN_SHARED_PTR_H - -#define DYN_SHARED_PTR_THREAD_SAFE - - -#include - -#ifdef _WIN32 -#include - -class my_shared_count { -public: - my_shared_count(): m_count(1) { } - ~my_shared_count() { } - - long increment() - { -#ifdef DYN_SHARED_PTR_THREAD_SAFE - return InterlockedIncrement(&m_count); -#else - return ++m_count; -#endif - } - - long decrement() { -#ifdef DYN_SHARED_PTR_THREAD_SAFE - return InterlockedDecrement(&m_count); -#else - return ++m_count; -#endif - } - - long use_count() { return m_count; } - -private: - long m_count; -}; -#else //ifdef WIN32 - - -#include - -class my_shared_count { -public: - my_shared_count(): m_count(1) { -#ifdef DYN_SHARED_PTR_THREAD_SAFE - pthread_mutex_init(&m_mutex, 0); -#endif - } - ~my_shared_count() { -#ifdef DYN_SHARED_PTR_THREAD_SAFE - pthread_mutex_destroy(&m_mutex); -#endif - } - - long increment() - { -#ifdef DYN_SHARED_PTR_THREAD_SAFE - pthread_mutex_lock(&m_mutex); -#endif - long c = ++m_count; -#ifdef DYN_SHARED_PTR_THREAD_SAFE - pthread_mutex_unlock(&m_mutex); -#endif - return c; - } - - long decrement() { -#ifdef DYN_SHARED_PTR_THREAD_SAFE - pthread_mutex_lock(&m_mutex); -#endif - long c = --m_count; -#ifdef DYN_SHARED_PTR_THREAD_SAFE - pthread_mutex_unlock(&m_mutex); -#endif - return c; - } - - long use_count() { return m_count; } - -private: - long m_count; - mutable pthread_mutex_t m_mutex; -}; - -#endif - - -template -class my_shared_ptr -{ -public: - my_shared_ptr(): m_ptr(NULL), m_count(NULL) { } - my_shared_ptr(my_shared_ptr const& other): - m_ptr(other.m_ptr), - m_count(other.m_count) - { - if(other.m_count != NULL) other.m_count->increment(); - } - - template - my_shared_ptr(my_shared_ptr const& other): - m_ptr(other.m_ptr), - m_count(other.m_count) - { - if(other.m_count != NULL) other.m_count->increment(); - } - - my_shared_ptr(T const* other): m_ptr(const_cast(other)), m_count(NULL) - { - if(other != NULL) m_count = new my_shared_count; - } - - ~my_shared_ptr() - { - giveup_ownership(); - } - - void reset(T const* other) - { - if(m_ptr == other) return; - giveup_ownership(); - m_ptr = const_cast(other); - if(other != NULL) m_count = new my_shared_count; - else m_count = NULL; - } - - T* get() { return m_ptr; } - T const* get() const { return m_ptr; } - T* operator->() { return m_ptr; } - T const* operator->() const { return m_ptr; } - operator bool() const { return m_ptr != NULL; } - T& operator*() const - { - assert(m_ptr != 0); - return *m_ptr; - } - - bool operator<(my_shared_ptr const& rhs) const { return m_ptr < rhs.m_ptr; } - - my_shared_ptr& operator=(my_shared_ptr const& other) { - if(m_ptr == other.m_ptr) return *this; - giveup_ownership(); - m_ptr = other.m_ptr; - m_count = other.m_count; - if(other.m_count != NULL) m_count->increment(); - return *this; - } - - template - my_shared_ptr& operator=(my_shared_ptr& other) { - if(m_ptr == other.m_ptr) return *this; - giveup_ownership(); - m_ptr = other.m_ptr; - m_count = other.m_count; - if(other.m_count != NULL) m_count->increment(); - return *this; - } - -protected: - - template friend class my_shared_ptr; - void giveup_ownership() - { - if(m_count != NULL) { - if( m_count->decrement() == 0) { - delete m_ptr; - m_ptr = NULL; - delete m_count; - m_count = NULL; - } - } - } - -protected: - T *m_ptr; - my_shared_count *m_count; - -}; - - -#endif diff --git a/btgui/urdf/boost_replacement/string_split.cpp b/btgui/urdf/boost_replacement/string_split.cpp deleted file mode 100644 index 6c8a294a4..000000000 --- a/btgui/urdf/boost_replacement/string_split.cpp +++ /dev/null @@ -1,253 +0,0 @@ - - -#include -//#include -#include -#include -#include - -#include "string_split.h" - -namespace boost -{ - void split( std::vector&pieces, const std::string& vector_str, std::vector separators) - { - assert(separators.size()==1); - if (separators.size()==1) - { - char** strArray = str_split(vector_str.c_str(),separators[0].c_str()); - int numSubStr = str_array_len(strArray); - for (int i=0;i is_any_of(const char* seps) - { - std::vector strArray; - - int numSeps = strlen(seps); - for (int i=0;i -#include -#include - -namespace boost -{ - void split( std::vector&pieces, const std::string& vector_str, std::vector separators); - std::vector is_any_of(const char* seps); -}; - -///The string split C code is by Lars Wirzenius -///See http://stackoverflow.com/questions/2531605/how-to-split-a-string-with-a-delimiter-larger-than-one-single-char - - -/* Split a string into substrings. Return dynamic array of dynamically - allocated substrings, or NULL if there was an error. Caller is - expected to free the memory, for example with str_array_free. */ -char** str_split(const char* input, const char* sep); - -/* Free a dynamic array of dynamic strings. */ -void str_array_free(char** array); - -/* Return length of a NULL-delimited array of strings. */ -size_t str_array_len(char** array); - -#endif //STRING_SPLIT_H - diff --git a/btgui/urdf/premake4.lua b/btgui/urdf/premake4.lua deleted file mode 100644 index 526c9114a..000000000 --- a/btgui/urdf/premake4.lua +++ /dev/null @@ -1,46 +0,0 @@ - - - project "urdf_test" - - flags {"FloatStrict"} - - language "C++" - - kind "ConsoleApp" - targetdir "../../bin" - --- links { --- } - - includedirs { - ".", - "..", - - } - - - files { - "urdfdom/urdf_parser/src/check_urdf.cpp", - "urdfdom/urdf_parser/src/pose.cpp", - "urdfdom/urdf_parser/src/model.cpp", - "urdfdom/urdf_parser/src/link.cpp", - "urdfdom/urdf_parser/src/joint.cpp", - "urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h", - "urdfdom_headers/urdf_exception/include/urdf_exception/exception.h", - "urdfdom_headers/urdf_model/include/urdf_model/pose.h", - "urdfdom_headers/urdf_model/include/urdf_model/model.h", - "urdfdom_headers/urdf_model/include/urdf_model/link.h", - "urdfdom_headers/urdf_model/include/urdf_model/joint.h", - "../tinyxml/tinystr.cpp", - "../tinyxml/tinyxml.cpp", - "../tinyxml/tinyxmlerror.cpp", - "../tinyxml/tinyxmlparser.cpp", - "boost_replacement/lexical_cast.h", - "boost_replacement/shared_ptr.h", - "boost_replacement/printf_console.cpp", - "boost_replacement/printf_console.h", - "boost_replacement/string_split.cpp", - "boost_replacement/string_split.h", - - - } diff --git a/btgui/urdf/urdfdom/LICENSE b/btgui/urdf/urdfdom/LICENSE deleted file mode 100644 index e80920e25..000000000 --- a/btgui/urdf/urdfdom/LICENSE +++ /dev/null @@ -1,15 +0,0 @@ -Software License Agreement (Apache License) - -Copyright 2011 John Hsu - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. diff --git a/btgui/urdf/urdfdom/README.txt b/btgui/urdf/urdfdom/README.txt deleted file mode 100644 index 4e3bff6d8..000000000 --- a/btgui/urdf/urdfdom/README.txt +++ /dev/null @@ -1,7 +0,0 @@ -The URDF (U-Robot Description Format) library - provides core data structures and a simple XML parsers - for populating the class data structures from an URDF file. - -For now, the details of the URDF specifications reside on - http://ros.org/wiki/urdf - diff --git a/btgui/urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h b/btgui/urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h deleted file mode 100644 index 336af0fa3..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h +++ /dev/null @@ -1,63 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - -#ifndef URDF_PARSER_URDF_PARSER_H -#define URDF_PARSER_URDF_PARSER_H - -#include - -#include -#include "tinyxml/tinyxml.h" - -//#include - -#ifndef M_PI -#define M_PI 3.1415925438 -#endif //M_PI - - -#include - - - - -namespace urdf{ - - my_shared_ptr parseURDF(const std::string &xml_string); - -} - -#endif diff --git a/btgui/urdf/urdfdom/urdf_parser/src/check_urdf.cpp b/btgui/urdf/urdfdom/urdf_parser/src/check_urdf.cpp deleted file mode 100644 index 67e9eb165..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/check_urdf.cpp +++ /dev/null @@ -1,137 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - -#include "urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h" -#include -#include - -using namespace urdf; - -void printTree(my_shared_ptr link,int level = 0) -{ - level+=2; - int count = 0; - for (std::vector >::const_iterator child = link->child_links.begin(); child != link->child_links.end(); child++) - { - if (*child) - { - for(int j=0;jname << std::endl; - // first grandchild - printTree(*child,level); - } - else - { - for(int j=0;jname << " has a null child!" << *child << std::endl; - } - } - -} - - -#define MSTRINGIFY(A) #A - - -const char* urdf_char = MSTRINGIFY( - - - - - - - - - - - - - - - - - - - - -); - - -int main(int argc, char** argv) -{ - - std::string xml_string; - - if (argc < 2){ - std::cerr << "No URDF file name provided, using a dummy test URDF" << std::endl; - - xml_string = std::string(urdf_char); - - } else - { - - - std::fstream xml_file(argv[1], std::fstream::in); - while ( xml_file.good() ) - { - std::string line; - std::getline( xml_file, line); - xml_string += (line + "\n"); - } - xml_file.close(); - } - - my_shared_ptr robot = parseURDF(xml_string); - if (!robot){ - std::cerr << "ERROR: Model Parsing the xml failed" << std::endl; - return -1; - } - std::cout << "robot name is: " << robot->getName() << std::endl; - - // get info from parser - std::cout << "---------- Successfully Parsed XML ---------------" << std::endl; - // get root link - my_shared_ptr root_link=robot->getRoot(); - if (!root_link) return -1; - - std::cout << "root Link: " << root_link->name << " has " << root_link->child_links.size() << " child(ren)" << std::endl; - - - // print entire tree - printTree(root_link); - return 0; -} - diff --git a/btgui/urdf/urdfdom/urdf_parser/src/joint.cpp b/btgui/urdf/urdfdom/urdf_parser/src/joint.cpp deleted file mode 100644 index bde0c5f73..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/joint.cpp +++ /dev/null @@ -1,579 +0,0 @@ -/********************************************************************* -* Software Ligcense Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - -#include -#include -#ifdef URDF_USE_BOOST -#include -#else -#include -#endif -#include - -#ifdef URDF_USE_CONSOLE_BRIDGE - #include -#else - #include "urdf/boost_replacement/printf_console.h" -#endif - -#include -#include - -namespace urdf{ - -bool parsePose(Pose &pose, TiXmlElement* xml); - -bool parseJointDynamics(JointDynamics &jd, TiXmlElement* config) -{ - jd.clear(); - - // Get joint damping - const char* damping_str = config->Attribute("damping"); - if (damping_str == NULL){ - logDebug("urdfdom.joint_dynamics: no damping, defaults to 0"); - jd.damping = 0; - } - else - { - try - { - jd.damping = boost::lexical_cast(damping_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("damping value (%s) is not a float: %s",damping_str, e.what()); - return false; - } - } - - // Get joint friction - const char* friction_str = config->Attribute("friction"); - if (friction_str == NULL){ - logDebug("urdfdom.joint_dynamics: no friction, defaults to 0"); - jd.friction = 0; - } - else - { - try - { - jd.friction = boost::lexical_cast(friction_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("friction value (%s) is not a float: %s",friction_str, e.what()); - return false; - } - } - - if (damping_str == NULL && friction_str == NULL) - { - logError("joint dynamics element specified with no damping and no friction"); - return false; - } - else{ - logDebug("urdfdom.joint_dynamics: damping %f and friction %f", jd.damping, jd.friction); - return true; - } -} - -bool parseJointLimits(JointLimits &jl, TiXmlElement* config) -{ - jl.clear(); - - // Get lower joint limit - const char* lower_str = config->Attribute("lower"); - if (lower_str == NULL){ - logDebug("urdfdom.joint_limit: no lower, defaults to 0"); - jl.lower = 0; - } - else - { - try - { - jl.lower = boost::lexical_cast(lower_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("lower value (%s) is not a float: %s", lower_str, e.what()); - return false; - } - } - - // Get upper joint limit - const char* upper_str = config->Attribute("upper"); - if (upper_str == NULL){ - logDebug("urdfdom.joint_limit: no upper, , defaults to 0"); - jl.upper = 0; - } - else - { - try - { - jl.upper = boost::lexical_cast(upper_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("upper value (%s) is not a float: %s",upper_str, e.what()); - return false; - } - } - - // Get joint effort limit - const char* effort_str = config->Attribute("effort"); - if (effort_str == NULL){ - logError("joint limit: no effort"); - return false; - } - else - { - try - { - jl.effort = boost::lexical_cast(effort_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("effort value (%s) is not a float: %s",effort_str, e.what()); - return false; - } - } - - // Get joint velocity limit - const char* velocity_str = config->Attribute("velocity"); - if (velocity_str == NULL){ - logError("joint limit: no velocity"); - return false; - } - else - { - try - { - jl.velocity = boost::lexical_cast(velocity_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("velocity value (%s) is not a float: %s",velocity_str, e.what()); - return false; - } - } - - return true; -} - -bool parseJointSafety(JointSafety &js, TiXmlElement* config) -{ - js.clear(); - - // Get soft_lower_limit joint limit - const char* soft_lower_limit_str = config->Attribute("soft_lower_limit"); - if (soft_lower_limit_str == NULL) - { - logDebug("urdfdom.joint_safety: no soft_lower_limit, using default value"); - js.soft_lower_limit = 0; - } - else - { - try - { - js.soft_lower_limit = boost::lexical_cast(soft_lower_limit_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("soft_lower_limit value (%s) is not a float: %s",soft_lower_limit_str, e.what()); - return false; - } - } - - // Get soft_upper_limit joint limit - const char* soft_upper_limit_str = config->Attribute("soft_upper_limit"); - if (soft_upper_limit_str == NULL) - { - logDebug("urdfdom.joint_safety: no soft_upper_limit, using default value"); - js.soft_upper_limit = 0; - } - else - { - try - { - js.soft_upper_limit = boost::lexical_cast(soft_upper_limit_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("soft_upper_limit value (%s) is not a float: %s",soft_upper_limit_str, e.what()); - return false; - } - } - - // Get k_position_ safety "position" gain - not exactly position gain - const char* k_position_str = config->Attribute("k_position"); - if (k_position_str == NULL) - { - logDebug("urdfdom.joint_safety: no k_position, using default value"); - js.k_position = 0; - } - else - { - try - { - js.k_position = boost::lexical_cast(k_position_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("k_position value (%s) is not a float: %s",k_position_str, e.what()); - return false; - } - } - // Get k_velocity_ safety velocity gain - const char* k_velocity_str = config->Attribute("k_velocity"); - if (k_velocity_str == NULL) - { - logError("joint safety: no k_velocity"); - return false; - } - else - { - try - { - js.k_velocity = boost::lexical_cast(k_velocity_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("k_velocity value (%s) is not a float: %s",k_velocity_str, e.what()); - return false; - } - } - - return true; -} - -bool parseJointCalibration(JointCalibration &jc, TiXmlElement* config) -{ - jc.clear(); - - // Get rising edge position - const char* rising_position_str = config->Attribute("rising"); - if (rising_position_str == NULL) - { - logDebug("urdfdom.joint_calibration: no rising, using default value"); - jc.rising.reset(0); - } - else - { - try - { - jc.rising.reset(new double(boost::lexical_cast(rising_position_str))); - } - catch (boost::bad_lexical_cast &e) - { - logError("risingvalue (%s) is not a float: %s",rising_position_str, e.what()); - return false; - } - } - - // Get falling edge position - const char* falling_position_str = config->Attribute("falling"); - if (falling_position_str == NULL) - { - logDebug("urdfdom.joint_calibration: no falling, using default value"); - jc.falling.reset(0); - } - else - { - try - { - jc.falling.reset(new double(boost::lexical_cast(falling_position_str))); - } - catch (boost::bad_lexical_cast &e) - { - logError("fallingvalue (%s) is not a float: %s",falling_position_str, e.what()); - return false; - } - } - - return true; -} - -bool parseJointMimic(JointMimic &jm, TiXmlElement* config) -{ - jm.clear(); - - // Get name of joint to mimic - const char* joint_name_str = config->Attribute("joint"); - - if (joint_name_str == NULL) - { - logError("joint mimic: no mimic joint specified"); - return false; - } - else - jm.joint_name = joint_name_str; - - // Get mimic multiplier - const char* multiplier_str = config->Attribute("multiplier"); - - if (multiplier_str == NULL) - { - logDebug("urdfdom.joint_mimic: no multiplier, using default value of 1"); - jm.multiplier = 1; - } - else - { - try - { - jm.multiplier = boost::lexical_cast(multiplier_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("multiplier value (%s) is not a float: %s",multiplier_str, e.what()); - return false; - } - } - - - // Get mimic offset - const char* offset_str = config->Attribute("offset"); - if (offset_str == NULL) - { - logDebug("urdfdom.joint_mimic: no offset, using default value of 0"); - jm.offset = 0; - } - else - { - try - { - jm.offset = boost::lexical_cast(offset_str); - } - catch (boost::bad_lexical_cast &e) - { - logError("offset value (%s) is not a float: %s",offset_str, e.what()); - return false; - } - } - - return true; -} - -bool parseJoint(Joint &joint, TiXmlElement* config) -{ - joint.clear(); - - // Get Joint Name - const char *name = config->Attribute("name"); - if (!name) - { - logError("unnamed joint found"); - return false; - } - joint.name = name; - - // Get transform from Parent Link to Joint Frame - TiXmlElement *origin_xml = config->FirstChildElement("origin"); - if (!origin_xml) - { - logDebug("urdfdom: Joint [%s] missing origin tag under parent describing transform from Parent Link to Joint Frame, (using Identity transform).", joint.name.c_str()); - joint.parent_to_joint_origin_transform.clear(); - } - else - { - if (!parsePose(joint.parent_to_joint_origin_transform, origin_xml)) - { - joint.parent_to_joint_origin_transform.clear(); - logError("Malformed parent origin element for joint [%s]", joint.name.c_str()); - return false; - } - } - - // Get Parent Link - TiXmlElement *parent_xml = config->FirstChildElement("parent"); - if (parent_xml) - { - const char *pname = parent_xml->Attribute("link"); - if (!pname) - { - logInform("no parent link name specified for Joint link [%s]. this might be the root?", joint.name.c_str()); - } - else - { - joint.parent_link_name = std::string(pname); - } - } - - // Get Child Link - TiXmlElement *child_xml = config->FirstChildElement("child"); - if (child_xml) - { - const char *pname = child_xml->Attribute("link"); - if (!pname) - { - logInform("no child link name specified for Joint link [%s].", joint.name.c_str()); - } - else - { - joint.child_link_name = std::string(pname); - } - } - - // Get Joint type - const char* type_char = config->Attribute("type"); - if (!type_char) - { - logError("joint [%s] has no type, check to see if it's a reference.", joint.name.c_str()); - return false; - } - - std::string type_str = type_char; - if (type_str == "planar") - joint.type = Joint::PLANAR; - else if (type_str == "floating") - joint.type = Joint::FLOATING; - else if (type_str == "revolute") - joint.type = Joint::REVOLUTE; - else if (type_str == "continuous") - joint.type = Joint::CONTINUOUS; - else if (type_str == "prismatic") - joint.type = Joint::PRISMATIC; - else if (type_str == "fixed") - joint.type = Joint::FIXED; - else - { - logError("Joint [%s] has no known type [%s]", joint.name.c_str(), type_str.c_str()); - return false; - } - - // Get Joint Axis - if (joint.type != Joint::FLOATING && joint.type != Joint::FIXED) - { - // axis - TiXmlElement *axis_xml = config->FirstChildElement("axis"); - if (!axis_xml){ - logDebug("urdfdom: no axis elemement for Joint link [%s], defaulting to (1,0,0) axis", joint.name.c_str()); - joint.axis = Vector3(1.0, 0.0, 0.0); - } - else{ - if (axis_xml->Attribute("xyz")){ - try { - joint.axis.init(axis_xml->Attribute("xyz")); - } - catch (ParseError &e) { - joint.axis.clear(); - logError("Malformed axis element for joint [%s]: %s", joint.name.c_str(), e.what()); - return false; - } - } - } - } - - // Get limit - TiXmlElement *limit_xml = config->FirstChildElement("limit"); - if (limit_xml) - { - joint.limits.reset(new JointLimits()); - if (!parseJointLimits(*joint.limits, limit_xml)) - { - logError("Could not parse limit element for joint [%s]", joint.name.c_str()); - joint.limits.reset(0); - return false; - } - } - else if (joint.type == Joint::REVOLUTE) - { - logError("Joint [%s] is of type REVOLUTE but it does not specify limits", joint.name.c_str()); - return false; - } - else if (joint.type == Joint::PRISMATIC) - { - logError("Joint [%s] is of type PRISMATIC without limits", joint.name.c_str()); - return false; - } - - // Get safety - TiXmlElement *safety_xml = config->FirstChildElement("safety_controller"); - if (safety_xml) - { - joint.safety.reset(new JointSafety()); - if (!parseJointSafety(*joint.safety, safety_xml)) - { - logError("Could not parse safety element for joint [%s]", joint.name.c_str()); - joint.safety.reset(0); - return false; - } - } - - // Get calibration - TiXmlElement *calibration_xml = config->FirstChildElement("calibration"); - if (calibration_xml) - { - joint.calibration.reset(new JointCalibration()); - if (!parseJointCalibration(*joint.calibration, calibration_xml)) - { - logError("Could not parse calibration element for joint [%s]", joint.name.c_str()); - joint.calibration.reset(0); - return false; - } - } - - // Get Joint Mimic - TiXmlElement *mimic_xml = config->FirstChildElement("mimic"); - if (mimic_xml) - { - joint.mimic.reset(new JointMimic()); - if (!parseJointMimic(*joint.mimic, mimic_xml)) - { - logError("Could not parse mimic element for joint [%s]", joint.name.c_str()); - joint.mimic.reset(0); - return false; - } - } - - // Get Dynamics - TiXmlElement *prop_xml = config->FirstChildElement("dynamics"); - if (prop_xml) - { - joint.dynamics.reset(new JointDynamics()); - if (!parseJointDynamics(*joint.dynamics, prop_xml)) - { - logError("Could not parse joint_dynamics element for joint [%s]", joint.name.c_str()); - joint.dynamics.reset(0); - return false; - } - } - - return true; -} - - - - -} diff --git a/btgui/urdf/urdfdom/urdf_parser/src/link.cpp b/btgui/urdf/urdfdom/urdf_parser/src/link.cpp deleted file mode 100644 index a224146b3..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/link.cpp +++ /dev/null @@ -1,505 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - - -#include -#include -//#include -//#include -#ifdef URDF_USE_BOOST -#include -#else -#include -#endif - -#include -#include -#ifdef URDF_USE_CONSOLE_BRIDGE -#include -#else -#include "urdf/boost_replacement/printf_console.h" -#endif - - - -namespace urdf{ - -bool parsePose(Pose &pose, TiXmlElement* xml); - -bool parseMaterial(Material &material, TiXmlElement *config, bool only_name_is_ok) -{ - bool has_rgb = false; - bool has_filename = false; - - material.clear(); - - if (!config->Attribute("name")) - { - logError("Material must contain a name attribute"); - return false; - } - - material.name = config->Attribute("name"); - - // texture - TiXmlElement *t = config->FirstChildElement("texture"); - if (t) - { - if (t->Attribute("filename")) - { - material.texture_filename = t->Attribute("filename"); - has_filename = true; - } - } - - // color - TiXmlElement *c = config->FirstChildElement("color"); - if (c) - { - if (c->Attribute("rgba")) { - - try { - material.color.init(c->Attribute("rgba")); - has_rgb = true; - } - catch (ParseError &e) { - material.color.clear(); - logError(std::string("Material [" + material.name + "] has malformed color rgba values: " + e.what()).c_str()); - } - } - } - - if (!has_rgb && !has_filename) { - if (!only_name_is_ok) // no need for an error if only name is ok - { - if (!has_rgb) logError(std::string("Material ["+material.name+"] color has no rgba").c_str()); - if (!has_filename) logError(std::string("Material ["+material.name+"] not defined in file").c_str()); - } - return false; - } - return true; -} - - -bool parseSphere(Sphere &s, TiXmlElement *c) -{ - s.clear(); - - s.type = Geometry::SPHERE; - if (!c->Attribute("radius")) - { - logError("Sphere shape must have a radius attribute"); - return false; - } - - try - { - s.radius = boost::lexical_cast(c->Attribute("radius")); - } - catch (boost::bad_lexical_cast &e) - { - // std::stringstream stm; - // stm << "radius [" << c->Attribute("radius") << "] is not a valid float: " << e.what(); - // logError(stm.str().c_str()); - logError("radius issue"); - return false; - } - - return true; -} - -bool parseBox(Box &b, TiXmlElement *c) -{ - b.clear(); - - b.type = Geometry::BOX; - if (!c->Attribute("size")) - { - logError("Box shape has no size attribute"); - return false; - } - try - { - b.dim.init(c->Attribute("size")); - } - catch (ParseError &e) - { - b.dim.clear(); - logError(e.what()); - return false; - } - return true; -} - -bool parseCylinder(Cylinder &y, TiXmlElement *c) -{ - y.clear(); - - y.type = Geometry::CYLINDER; - if (!c->Attribute("length") || - !c->Attribute("radius")) - { - logError("Cylinder shape must have both length and radius attributes"); - return false; - } - - try - { - y.length = boost::lexical_cast(c->Attribute("length")); - } - catch (boost::bad_lexical_cast &e) - { - // std::stringstream stm; - // stm << "length [" << c->Attribute("length") << "] is not a valid float"; - //logError(stm.str().c_str()); - logError("length"); - return false; - } - - try - { - y.radius = boost::lexical_cast(c->Attribute("radius")); - } - catch (boost::bad_lexical_cast &e) - { - // std::stringstream stm; - // stm << "radius [" << c->Attribute("radius") << "] is not a valid float"; - //logError(stm.str().c_str()); - logError("radius"); - return false; - } - return true; -} - - -bool parseMesh(Mesh &m, TiXmlElement *c) -{ - m.clear(); - - m.type = Geometry::MESH; - if (!c->Attribute("filename")) { - logError("Mesh must contain a filename attribute"); - return false; - } - - m.filename = c->Attribute("filename"); - - if (c->Attribute("scale")) { - try { - m.scale.init(c->Attribute("scale")); - } - catch (ParseError &e) { - m.scale.clear(); - logError("Mesh scale was specified, but could not be parsed: %s", e.what()); - return false; - } - } - else - { - m.scale.x = m.scale.y = m.scale.z = 1; - } - return true; -} - -my_shared_ptr parseGeometry(TiXmlElement *g) -{ - my_shared_ptr geom; - if (!g) return geom; - - TiXmlElement *shape = g->FirstChildElement(); - if (!shape) - { - logError("Geometry tag contains no child element."); - return geom; - } - - const std::string type_name = shape->ValueTStr().c_str(); - if (type_name == "sphere") - { - Sphere *s = new Sphere(); - geom.reset(s); - if (parseSphere(*s, shape)) - return geom; - } - else if (type_name == "box") - { - Box *b = new Box(); - geom.reset(b); - if (parseBox(*b, shape)) - return geom; - } - else if (type_name == "cylinder") - { - Cylinder *c = new Cylinder(); - geom.reset(c); - if (parseCylinder(*c, shape)) - return geom; - } - else if (type_name == "mesh") - { - Mesh *m = new Mesh(); - geom.reset(m); - if (parseMesh(*m, shape)) - return geom; - } - else - { - logError("Unknown geometry type '%s'", type_name.c_str()); - return geom; - } - - return my_shared_ptr(); -} - -bool parseInertial(Inertial &i, TiXmlElement *config) -{ - i.clear(); - - // Origin - TiXmlElement *o = config->FirstChildElement("origin"); - if (o) - { - if (!parsePose(i.origin, o)) - return false; - } - - TiXmlElement *mass_xml = config->FirstChildElement("mass"); - if (!mass_xml) - { - logError("Inertial element must have a mass element"); - return false; - } - if (!mass_xml->Attribute("value")) - { - logError("Inertial: mass element must have value attribute"); - return false; - } - - try - { - i.mass = boost::lexical_cast(mass_xml->Attribute("value")); - } - catch (boost::bad_lexical_cast &e) - { - // std::stringstream stm; - // stm << "Inertial: mass [" << mass_xml->Attribute("value") - // << "] is not a float"; - //logError(stm.str().c_str()); - logError("Inertial mass issue"); - return false; - } - - TiXmlElement *inertia_xml = config->FirstChildElement("inertia"); - if (!inertia_xml) - { - logError("Inertial element must have inertia element"); - return false; - } - if (!(inertia_xml->Attribute("ixx") && inertia_xml->Attribute("ixy") && inertia_xml->Attribute("ixz") && - inertia_xml->Attribute("iyy") && inertia_xml->Attribute("iyz") && - inertia_xml->Attribute("izz"))) - { - logError("Inertial: inertia element must have ixx,ixy,ixz,iyy,iyz,izz attributes"); - return false; - } - try - { - i.ixx = boost::lexical_cast(inertia_xml->Attribute("ixx")); - i.ixy = boost::lexical_cast(inertia_xml->Attribute("ixy")); - i.ixz = boost::lexical_cast(inertia_xml->Attribute("ixz")); - i.iyy = boost::lexical_cast(inertia_xml->Attribute("iyy")); - i.iyz = boost::lexical_cast(inertia_xml->Attribute("iyz")); - i.izz = boost::lexical_cast(inertia_xml->Attribute("izz")); - } - catch (boost::bad_lexical_cast &e) - { - /* std::stringstream stm; - stm << "Inertial: one of the inertia elements is not a valid double:" - << " ixx [" << inertia_xml->Attribute("ixx") << "]" - << " ixy [" << inertia_xml->Attribute("ixy") << "]" - << " ixz [" << inertia_xml->Attribute("ixz") << "]" - << " iyy [" << inertia_xml->Attribute("iyy") << "]" - << " iyz [" << inertia_xml->Attribute("iyz") << "]" - << " izz [" << inertia_xml->Attribute("izz") << "]"; - logError(stm.str().c_str()); - */ - logError("Inertia error"); - - return false; - } - return true; -} - -bool parseVisual(Visual &vis, TiXmlElement *config) -{ - vis.clear(); - - // Origin - TiXmlElement *o = config->FirstChildElement("origin"); - if (o) { - if (!parsePose(vis.origin, o)) - return false; - } - - // Geometry - TiXmlElement *geom = config->FirstChildElement("geometry"); - vis.geometry = parseGeometry(geom); - if (!vis.geometry) - return false; - - const char *name_char = config->Attribute("name"); - if (name_char) - vis.name = name_char; - - // Material - TiXmlElement *mat = config->FirstChildElement("material"); - if (mat) { - // get material name - if (!mat->Attribute("name")) { - logError("Visual material must contain a name attribute"); - return false; - } - vis.material_name = mat->Attribute("name"); - - // try to parse material element in place - vis.material.reset(new Material()); - if (!parseMaterial(*vis.material, mat, true)) - { - logDebug("urdfdom: material has only name, actual material definition may be in the model"); - } - } - - return true; -} - -bool parseCollision(Collision &col, TiXmlElement* config) -{ - col.clear(); - - // Origin - TiXmlElement *o = config->FirstChildElement("origin"); - if (o) { - if (!parsePose(col.origin, o)) - return false; - } - - // Geometry - TiXmlElement *geom = config->FirstChildElement("geometry"); - col.geometry = parseGeometry(geom); - if (!col.geometry) - return false; - - const char *name_char = config->Attribute("name"); - if (name_char) - col.name = name_char; - - return true; -} - -bool parseLink(Link &link, TiXmlElement* config) -{ - - link.clear(); - - const char *name_char = config->Attribute("name"); - if (!name_char) - { - logError("No name given for the link."); - return false; - } - link.name = std::string(name_char); - - // Inertial (optional) - TiXmlElement *i = config->FirstChildElement("inertial"); - if (i) - { - link.inertial.reset(new Inertial()); - if (!parseInertial(*link.inertial, i)) - { - logError("Could not parse inertial element for Link [%s]", link.name.c_str()); - return false; - } - } - - // Multiple Visuals (optional) - for (TiXmlElement* vis_xml = config->FirstChildElement("visual"); vis_xml; vis_xml = vis_xml->NextSiblingElement("visual")) - { - - my_shared_ptr vis; - vis.reset(new Visual()); - if (parseVisual(*vis, vis_xml)) - { - link.visual_array.push_back(vis); - } - else - { - vis.reset(0); - logError("Could not parse visual element for Link [%s]", link.name.c_str()); - return false; - } - } - - // Visual (optional) - // Assign the first visual to the .visual ptr, if it exists - if (!link.visual_array.empty()) - link.visual = link.visual_array[0]; - - // Multiple Collisions (optional) - for (TiXmlElement* col_xml = config->FirstChildElement("collision"); col_xml; col_xml = col_xml->NextSiblingElement("collision")) - { - my_shared_ptr col; - col.reset(new Collision()); - if (parseCollision(*col, col_xml)) - { - link.collision_array.push_back(col); - } - else - { - col.reset(0); - logError("Could not parse collision element for Link [%s]", link.name.c_str()); - return false; - } - } - - // Collision (optional) - // Assign the first collision to the .collision ptr, if it exists - if (!link.collision_array.empty()) - link.collision = link.collision_array[0]; - return true; - -} - -} diff --git a/btgui/urdf/urdfdom/urdf_parser/src/model.cpp b/btgui/urdf/urdfdom/urdf_parser/src/model.cpp deleted file mode 100644 index e8562d09b..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/model.cpp +++ /dev/null @@ -1,240 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ -//#include -#include -#include "urdf/urdfdom/urdf_parser/include/urdf_parser/urdf_parser.h" -#ifdef URDF_USE_CONSOLE_BRIDGE - #include -#else - #include "urdf/boost_replacement/printf_console.h" -#endif - -namespace urdf{ - -bool parseMaterial(Material &material, TiXmlElement *config, bool only_name_is_ok); -bool parseLink(Link &link, TiXmlElement *config); -bool parseJoint(Joint &joint, TiXmlElement *config); - - -my_shared_ptr parseURDF(const std::string &xml_string) -{ - my_shared_ptr model(new ModelInterface); - model->clear(); - - TiXmlDocument xml_doc; - xml_doc.Parse(xml_string.c_str()); - if (xml_doc.Error()) - { - logError(xml_doc.ErrorDesc()); - xml_doc.ClearError(); - model.reset(0); - return model; - } - - TiXmlElement *robot_xml = xml_doc.FirstChildElement("robot"); - if (!robot_xml) - { - logError("Could not find the 'robot' element in the xml file"); - model.reset(0); - return model; - } - - // Get robot name - const char *name = robot_xml->Attribute("name"); - if (!name) - { - logError("No name given for the robot."); - model.reset(0); - return model; - } - model->name_ = std::string(name); - - // Get all Material elements - for (TiXmlElement* material_xml = robot_xml->FirstChildElement("material"); material_xml; material_xml = material_xml->NextSiblingElement("material")) - { - my_shared_ptr material; - material.reset(new Material); - - try { - parseMaterial(*material, material_xml, false); // material needs to be fully defined here - if (model->getMaterial(material->name)) - { - logError("material '%s' is not unique.", material->name.c_str()); - material.reset(0); - model.reset(0); - return model; - } - else - { - model->materials_.insert(make_pair(material->name,material)); - logDebug("urdfdom: successfully added a new material '%s'", material->name.c_str()); - } - } - catch (ParseError &e) { - logError("material xml is not initialized correctly"); - material.reset(0); - model.reset(0); - return model; - } - } - - // Get all Link elements - for (TiXmlElement* link_xml = robot_xml->FirstChildElement("link"); link_xml; link_xml = link_xml->NextSiblingElement("link")) - { - my_shared_ptr link; - link.reset(new Link); - model->m_numLinks++; - - try { - parseLink(*link, link_xml); - if (model->getLink(link->name)) - { - logError("link '%s' is not unique.", link->name.c_str()); - model.reset(0); - return model; - } - else - { - // set link visual material - logDebug("urdfdom: setting link '%s' material", link->name.c_str()); - if (link->visual) - { - if (!link->visual->material_name.empty()) - { - if (model->getMaterial(link->visual->material_name)) - { - logDebug("urdfdom: setting link '%s' material to '%s'", link->name.c_str(),link->visual->material_name.c_str()); - link->visual->material = model->getMaterial( link->visual->material_name.c_str() ); - } - else - { - if (link->visual->material) - { - logDebug("urdfdom: link '%s' material '%s' defined in Visual.", link->name.c_str(),link->visual->material_name.c_str()); - model->materials_.insert(make_pair(link->visual->material->name,link->visual->material)); - } - else - { - logError("link '%s' material '%s' undefined.", link->name.c_str(),link->visual->material_name.c_str()); - model.reset(0); - return model; - } - } - } - } - - model->links_.insert(make_pair(link->name,link)); - logDebug("urdfdom: successfully added a new link '%s'", link->name.c_str()); - } - } - catch (ParseError &e) { - logError("link xml is not initialized correctly"); - model.reset(0); - return model; - } - } - if (model->links_.empty()){ - logError("No link elements found in urdf file"); - model.reset(0); - return model; - } - - // Get all Joint elements - for (TiXmlElement* joint_xml = robot_xml->FirstChildElement("joint"); joint_xml; joint_xml = joint_xml->NextSiblingElement("joint")) - { - my_shared_ptr joint; - joint.reset(new Joint); - model->m_numJoints++; - - if (parseJoint(*joint, joint_xml)) - { - if (model->getJoint(joint->name)) - { - logError("joint '%s' is not unique.", joint->name.c_str()); - model.reset(0); - return model; - } - else - { - model->joints_.insert(make_pair(joint->name,joint)); - logDebug("urdfdom: successfully added a new joint '%s'", joint->name.c_str()); - } - } - else - { - logError("joint xml is not initialized correctly"); - model.reset(0); - return model; - } - } - - - // every link has children links and joints, but no parents, so we create a - // local convenience data structure for keeping child->parent relations - std::map parent_link_tree; - parent_link_tree.clear(); - - // building tree: name mapping - try - { - model->initTree(parent_link_tree); - } - catch(ParseError &e) - { - logError("Failed to build tree: %s", e.what()); - model.reset(0); - return model; - } - - // find the root link - try - { - model->initRoot(parent_link_tree); - } - catch(ParseError &e) - { - logError("Failed to find root link: %s", e.what()); - model.reset(0); - return model; - } - - return model; -} - - - -} - diff --git a/btgui/urdf/urdfdom/urdf_parser/src/pose.cpp b/btgui/urdf/urdfdom/urdf_parser/src/pose.cpp deleted file mode 100644 index e90247c0e..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/pose.cpp +++ /dev/null @@ -1,91 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen, John Hsu */ - - -#include -#include -#include -//#include -#include - -#ifdef URDF_USE_CONSOLE_BRIDGE -#include -#else -#include "urdf/boost_replacement/printf_console.h" -#endif - -#include -#include - - -namespace urdf{ - -bool parsePose(Pose &pose, TiXmlElement* xml) -{ - pose.clear(); - if (xml) - { - const char* xyz_str = xml->Attribute("xyz"); - if (xyz_str != NULL) - { - try { - pose.position.init(xyz_str); - } - catch (ParseError &e) { - logError(e.what()); - return false; - } - } - - const char* rpy_str = xml->Attribute("rpy"); - if (rpy_str != NULL) - { - try { - pose.rotation.init(rpy_str); - } - catch (ParseError &e) { - logError(e.what()); - return false; - } - } - } - return true; -} - - -} - - diff --git a/btgui/urdf/urdfdom/urdf_parser/src/twist.cpp b/btgui/urdf/urdfdom/urdf_parser/src/twist.cpp deleted file mode 100644 index 4980e17de..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/twist.cpp +++ /dev/null @@ -1,85 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - - -#include -#include -#include -#include -#include -#include -#include - -namespace urdf{ - -bool parseTwist(Twist &twist, TiXmlElement* xml) -{ - twist.clear(); - if (xml) - { - const char* linear_char = xml->Attribute("linear"); - if (linear_char != NULL) - { - try { - twist.linear.init(linear_char); - } - catch (ParseError &e) { - twist.linear.clear(); - logError("Malformed linear string [%s]: %s", linear_char, e.what()); - return false; - } - } - - const char* angular_char = xml->Attribute("angular"); - if (angular_char != NULL) - { - try { - twist.angular.init(angular_char); - } - catch (ParseError &e) { - twist.angular.clear(); - logError("Malformed angular [%s]: %s", angular_char, e.what()); - return false; - } - } - } - return true; -} - -} - - - diff --git a/btgui/urdf/urdfdom/urdf_parser/src/urdf_model_state.cpp b/btgui/urdf/urdfdom/urdf_parser/src/urdf_model_state.cpp deleted file mode 100644 index f30b8456e..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/urdf_model_state.cpp +++ /dev/null @@ -1,154 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - - -#include -#include -#include -#include -#include -#include -#include - -namespace urdf{ - -bool parseModelState(ModelState &ms, TiXmlElement* config) -{ - ms.clear(); - - const char *name_char = config->Attribute("name"); - if (!name_char) - { - logError("No name given for the model_state."); - return false; - } - ms.name = std::string(name_char); - - const char *time_stamp_char = config->Attribute("time_stamp"); - if (time_stamp_char) - { - try { - double sec = boost::lexical_cast(time_stamp_char); - ms.time_stamp.set(sec); - } - catch (boost::bad_lexical_cast &e) { - logError("Parsing time stamp [%s] failed: %s", time_stamp_char, e.what()); - return false; - } - } - - TiXmlElement *joint_state_elem = config->FirstChildElement("joint_state"); - if (joint_state_elem) - { - boost::shared_ptr joint_state; - joint_state.reset(new JointState()); - - const char *joint_char = joint_state_elem->Attribute("joint"); - if (joint_char) - joint_state->joint = std::string(joint_char); - else - { - logError("No joint name given for the model_state."); - return false; - } - - // parse position - const char *position_char = joint_state_elem->Attribute("position"); - if (position_char) - { - - std::vector pieces; - boost::split( pieces, position_char, boost::is_any_of(" ")); - for (unsigned int i = 0; i < pieces.size(); ++i){ - if (pieces[i] != ""){ - try { - joint_state->position.push_back(boost::lexical_cast(pieces[i].c_str())); - } - catch (boost::bad_lexical_cast &e) { - throw ParseError("position element ("+ pieces[i] +") is not a valid float"); - } - } - } - } - - // parse velocity - const char *velocity_char = joint_state_elem->Attribute("velocity"); - if (velocity_char) - { - - std::vector pieces; - boost::split( pieces, velocity_char, boost::is_any_of(" ")); - for (unsigned int i = 0; i < pieces.size(); ++i){ - if (pieces[i] != ""){ - try { - joint_state->velocity.push_back(boost::lexical_cast(pieces[i].c_str())); - } - catch (boost::bad_lexical_cast &e) { - throw ParseError("velocity element ("+ pieces[i] +") is not a valid float"); - } - } - } - } - - // parse effort - const char *effort_char = joint_state_elem->Attribute("effort"); - if (effort_char) - { - - std::vector pieces; - boost::split( pieces, effort_char, boost::is_any_of(" ")); - for (unsigned int i = 0; i < pieces.size(); ++i){ - if (pieces[i] != ""){ - try { - joint_state->effort.push_back(boost::lexical_cast(pieces[i].c_str())); - } - catch (boost::bad_lexical_cast &e) { - throw ParseError("effort element ("+ pieces[i] +") is not a valid float"); - } - } - } - } - - // add to vector - ms.joint_states.push_back(joint_state); - } -}; - - - -} - - diff --git a/btgui/urdf/urdfdom/urdf_parser/src/urdf_sensor.cpp b/btgui/urdf/urdfdom/urdf_parser/src/urdf_sensor.cpp deleted file mode 100644 index 85a886d3f..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/urdf_sensor.cpp +++ /dev/null @@ -1,364 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - - -#include -#include -#include -#include -#include -#include -#include - -namespace urdf{ - -bool parsePose(Pose &pose, TiXmlElement* xml); - -bool parseCamera(Camera &camera, TiXmlElement* config) -{ - camera.clear(); - camera.type = VisualSensor::CAMERA; - - TiXmlElement *image = config->FirstChildElement("image"); - if (image) - { - const char* width_char = image->Attribute("width"); - if (width_char) - { - try - { - camera.width = boost::lexical_cast(width_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Camera image width [%s] is not a valid int: %s", width_char, e.what()); - return false; - } - } - else - { - logError("Camera sensor needs an image width attribute"); - return false; - } - - const char* height_char = image->Attribute("height"); - if (height_char) - { - try - { - camera.height = boost::lexical_cast(height_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Camera image height [%s] is not a valid int: %s", height_char, e.what()); - return false; - } - } - else - { - logError("Camera sensor needs an image height attribute"); - return false; - } - - const char* format_char = image->Attribute("format"); - if (format_char) - camera.format = std::string(format_char); - else - { - logError("Camera sensor needs an image format attribute"); - return false; - } - - const char* hfov_char = image->Attribute("hfov"); - if (hfov_char) - { - try - { - camera.hfov = boost::lexical_cast(hfov_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Camera image hfov [%s] is not a valid float: %s", hfov_char, e.what()); - return false; - } - } - else - { - logError("Camera sensor needs an image hfov attribute"); - return false; - } - - const char* near_char = image->Attribute("near"); - if (near_char) - { - try - { - camera.near = boost::lexical_cast(near_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Camera image near [%s] is not a valid float: %s", near_char, e.what()); - return false; - } - } - else - { - logError("Camera sensor needs an image near attribute"); - return false; - } - - const char* far_char = image->Attribute("far"); - if (far_char) - { - try - { - camera.far = boost::lexical_cast(far_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Camera image far [%s] is not a valid float: %s", far_char, e.what()); - return false; - } - } - else - { - logError("Camera sensor needs an image far attribute"); - return false; - } - - } - else - { - logError("Camera sensor has no element"); - return false; - } - return true; -} - -bool parseRay(Ray &ray, TiXmlElement* config) -{ - ray.clear(); - ray.type = VisualSensor::RAY; - - TiXmlElement *horizontal = config->FirstChildElement("horizontal"); - if (horizontal) - { - const char* samples_char = horizontal->Attribute("samples"); - if (samples_char) - { - try - { - ray.horizontal_samples = boost::lexical_cast(samples_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray horizontal samples [%s] is not a valid float: %s", samples_char, e.what()); - return false; - } - } - - const char* resolution_char = horizontal->Attribute("resolution"); - if (resolution_char) - { - try - { - ray.horizontal_resolution = boost::lexical_cast(resolution_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray horizontal resolution [%s] is not a valid float: %s", resolution_char, e.what()); - return false; - } - } - - const char* min_angle_char = horizontal->Attribute("min_angle"); - if (min_angle_char) - { - try - { - ray.horizontal_min_angle = boost::lexical_cast(min_angle_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray horizontal min_angle [%s] is not a valid float: %s", min_angle_char, e.what()); - return false; - } - } - - const char* max_angle_char = horizontal->Attribute("max_angle"); - if (max_angle_char) - { - try - { - ray.horizontal_max_angle = boost::lexical_cast(max_angle_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray horizontal max_angle [%s] is not a valid float: %s", max_angle_char, e.what()); - return false; - } - } - } - - TiXmlElement *vertical = config->FirstChildElement("vertical"); - if (vertical) - { - const char* samples_char = vertical->Attribute("samples"); - if (samples_char) - { - try - { - ray.vertical_samples = boost::lexical_cast(samples_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray vertical samples [%s] is not a valid float: %s", samples_char, e.what()); - return false; - } - } - - const char* resolution_char = vertical->Attribute("resolution"); - if (resolution_char) - { - try - { - ray.vertical_resolution = boost::lexical_cast(resolution_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray vertical resolution [%s] is not a valid float: %s", resolution_char, e.what()); - return false; - } - } - - const char* min_angle_char = vertical->Attribute("min_angle"); - if (min_angle_char) - { - try - { - ray.vertical_min_angle = boost::lexical_cast(min_angle_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray vertical min_angle [%s] is not a valid float: %s", min_angle_char, e.what()); - return false; - } - } - - const char* max_angle_char = vertical->Attribute("max_angle"); - if (max_angle_char) - { - try - { - ray.vertical_max_angle = boost::lexical_cast(max_angle_char); - } - catch (boost::bad_lexical_cast &e) - { - logError("Ray vertical max_angle [%s] is not a valid float: %s", max_angle_char, e.what()); - return false; - } - } - } -} - -boost::shared_ptr parseVisualSensor(TiXmlElement *g) -{ - boost::shared_ptr visual_sensor; - - // get sensor type - TiXmlElement *sensor_xml; - if (g->FirstChildElement("camera")) - { - Camera *camera = new Camera(); - visual_sensor.reset(camera); - sensor_xml = g->FirstChildElement("camera"); - if (!parseCamera(*camera, sensor_xml)) - visual_sensor.reset(); - } - else if (g->FirstChildElement("ray")) - { - Ray *ray = new Ray(); - visual_sensor.reset(ray); - sensor_xml = g->FirstChildElement("ray"); - if (!parseRay(*ray, sensor_xml)) - visual_sensor.reset(); - } - else - { - logError("No know sensor types [camera|ray] defined in block"); - } - return visual_sensor; -} - - -bool parseSensor(Sensor &sensor, TiXmlElement* config) -{ - sensor.clear(); - - const char *name_char = config->Attribute("name"); - if (!name_char) - { - logError("No name given for the sensor."); - return false; - } - sensor.name = std::string(name_char); - - // parse parent_link_name - const char *parent_link_name_char = config->Attribute("parent_link_name"); - if (!parent_link_name_char) - { - logError("No parent_link_name given for the sensor."); - return false; - } - sensor.parent_link_name = std::string(parent_link_name_char); - - // parse origin - TiXmlElement *o = config->FirstChildElement("origin"); - if (o) - { - if (!parsePose(sensor.origin, o)) - return false; - } - - // parse sensor - sensor.sensor = parseVisualSensor(config); - return true; -} - - -} - - diff --git a/btgui/urdf/urdfdom/urdf_parser/src/world.cpp b/btgui/urdf/urdfdom/urdf_parser/src/world.cpp deleted file mode 100644 index ddc27c5f3..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/src/world.cpp +++ /dev/null @@ -1,71 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - - -#include -#include -#include -#include -#include -#include -#include -#include -#include - -namespace urdf{ - -bool parseWorld(World &world, TiXmlElement* config) -{ - - // to be implemented - - return true; -} - -bool exportWorld(World &world, TiXmlElement* xml) -{ - TiXmlElement * world_xml = new TiXmlElement("world"); - world_xml->SetAttribute("name", world.name); - - // to be implemented - // exportModels(*world.models, world_xml); - - xml->LinkEndChild(world_xml); - - return true; -} - -} diff --git a/btgui/urdf/urdfdom/urdf_parser/test/memtest.cpp b/btgui/urdf/urdfdom/urdf_parser/test/memtest.cpp deleted file mode 100644 index d835eb3db..000000000 --- a/btgui/urdf/urdfdom/urdf_parser/test/memtest.cpp +++ /dev/null @@ -1,20 +0,0 @@ -#include "urdf_parser/urdf_parser.h" -#include -#include - -int main(int argc, char** argv){ - while (true){ - std::string xml_string; - std::fstream xml_file(argv[1], std::fstream::in); - while ( xml_file.good() ) - { - std::string line; - std::getline( xml_file, line); - xml_string += (line + "\n"); - } - xml_file.close(); - - - urdf::parseURDF(xml_string); - } -} diff --git a/btgui/urdf/urdfdom_headers/LICENSE b/btgui/urdf/urdfdom_headers/LICENSE deleted file mode 100644 index e80920e25..000000000 --- a/btgui/urdf/urdfdom_headers/LICENSE +++ /dev/null @@ -1,15 +0,0 @@ -Software License Agreement (Apache License) - -Copyright 2011 John Hsu - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. diff --git a/btgui/urdf/urdfdom_headers/README.txt b/btgui/urdf/urdfdom_headers/README.txt deleted file mode 100644 index 6a841d52e..000000000 --- a/btgui/urdf/urdfdom_headers/README.txt +++ /dev/null @@ -1,6 +0,0 @@ -The URDF (U-Robot Description Format) headers - provides core data structure headers for URDF. - -For now, the details of the URDF specifications reside on - http://ros.org/wiki/urdf - diff --git a/btgui/urdf/urdfdom_headers/urdf_exception/include/urdf_exception/exception.h b/btgui/urdf/urdfdom_headers/urdf_exception/include/urdf_exception/exception.h deleted file mode 100644 index 24222f1ff..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_exception/include/urdf_exception/exception.h +++ /dev/null @@ -1,53 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -// URDF exceptions -#ifndef URDF_INTERFACE_EXCEPTION_H_ -#define URDF_INTERFACE_EXCEPTION_H_ - -#include -#include - -namespace urdf -{ - -class ParseError: public std::runtime_error -{ -public: - ParseError(const std::string &error_msg) : std::runtime_error(error_msg) {}; -}; - -} - -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/color.h b/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/color.h deleted file mode 100644 index 9c15dd77b..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/color.h +++ /dev/null @@ -1,101 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Josh Faust */ - -#ifndef URDF_INTERFACE_COLOR_H -#define URDF_INTERFACE_COLOR_H - -#include -#include -#include -//#include -//#include - -namespace urdf -{ - -class Color -{ -public: - Color() {this->clear();}; - float r; - float g; - float b; - float a; - - void clear() - { - r = g = b = 0.0f; - a = 1.0f; - } - bool init(const std::string &vector_str) - { - this->clear(); - std::vector pieces; - std::vector rgba; - - boost::split( pieces, vector_str, boost::is_any_of(" ")); - for (unsigned int i = 0; i < pieces.size(); ++i) - { - if (!pieces[i].empty()) - { - try - { - rgba.push_back(boost::lexical_cast(pieces[i].c_str())); - } - catch (boost::bad_lexical_cast &e) - { - return false; - } - } - } - - if (rgba.size() != 4) - { - return false; - } - this->r = rgba[0]; - this->g = rgba[1]; - this->b = rgba[2]; - this->a = rgba[3]; - - return true; - }; -}; - -} - -#endif - diff --git a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/joint.h b/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/joint.h deleted file mode 100644 index cd889dcec..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/joint.h +++ /dev/null @@ -1,234 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - -#ifndef URDF_INTERFACE_JOINT_H -#define URDF_INTERFACE_JOINT_H - -#include -#include -#ifdef URDF_USE_BOOST -#include -#define my_shared_ptr my_shared_ptr -#else -#include -#endif - -#include - - -namespace urdf{ - -class Link; - -class JointDynamics -{ -public: - JointDynamics() { this->clear(); }; - double damping; - double friction; - - void clear() - { - damping = 0; - friction = 0; - }; -}; - -class JointLimits -{ -public: - JointLimits() { this->clear(); }; - double lower; - double upper; - double effort; - double velocity; - - void clear() - { - lower = 0; - upper = 0; - effort = 0; - velocity = 0; - }; -}; - -/// \brief Parameters for Joint Safety Controllers -class JointSafety -{ -public: - /// clear variables on construction - JointSafety() { this->clear(); }; - - /// - /// IMPORTANT: The safety controller support is very much PR2 specific, not intended for generic usage. - /// - /// Basic safety controller operation is as follows - /// - /// current safety controllers will take effect on joints outside the position range below: - /// - /// position range: [JointSafety::soft_lower_limit + JointLimits::velocity / JointSafety::k_position, - /// JointSafety::soft_uppper_limit - JointLimits::velocity / JointSafety::k_position] - /// - /// if (joint_position is outside of the position range above) - /// velocity_limit_min = -JointLimits::velocity + JointSafety::k_position * (joint_position - JointSafety::soft_lower_limit) - /// velocity_limit_max = JointLimits::velocity + JointSafety::k_position * (joint_position - JointSafety::soft_upper_limit) - /// else - /// velocity_limit_min = -JointLimits::velocity - /// velocity_limit_max = JointLimits::velocity - /// - /// velocity range: [velocity_limit_min + JointLimits::effort / JointSafety::k_velocity, - /// velocity_limit_max - JointLimits::effort / JointSafety::k_velocity] - /// - /// if (joint_velocity is outside of the velocity range above) - /// effort_limit_min = -JointLimits::effort + JointSafety::k_velocity * (joint_velocity - velocity_limit_min) - /// effort_limit_max = JointLimits::effort + JointSafety::k_velocity * (joint_velocity - velocity_limit_max) - /// else - /// effort_limit_min = -JointLimits::effort - /// effort_limit_max = JointLimits::effort - /// - /// Final effort command sent to the joint is saturated by [effort_limit_min,effort_limit_max] - /// - /// Please see wiki for more details: http://www.ros.org/wiki/pr2_controller_manager/safety_limits - /// - double soft_upper_limit; - double soft_lower_limit; - double k_position; - double k_velocity; - - void clear() - { - soft_upper_limit = 0; - soft_lower_limit = 0; - k_position = 0; - k_velocity = 0; - }; -}; - - -class JointCalibration -{ -public: - JointCalibration() { this->clear(); }; - double reference_position; - my_shared_ptr rising, falling; - - void clear() - { - reference_position = 0; - }; -}; - -class JointMimic -{ -public: - JointMimic() { this->clear(); }; - double offset; - double multiplier; - std::string joint_name; - - void clear() - { - offset = 0.0; - multiplier = 0.0; - joint_name.clear(); - }; -}; - - -class Joint -{ -public: - - Joint() { this->clear(); }; - - std::string name; - enum - { - UNKNOWN, REVOLUTE, CONTINUOUS, PRISMATIC, FLOATING, PLANAR, FIXED - } type; - - /// \brief type_ meaning of axis_ - /// ------------------------------------------------------ - /// UNKNOWN unknown type - /// REVOLUTE rotation axis - /// PRISMATIC translation axis - /// FLOATING N/A - /// PLANAR plane normal axis - /// FIXED N/A - Vector3 axis; - - /// child Link element - /// child link frame is the same as the Joint frame - std::string child_link_name; - - /// parent Link element - /// origin specifies the transform from Parent Link to Joint Frame - std::string parent_link_name; - /// transform from Parent Link frame to Joint frame - Pose parent_to_joint_origin_transform; - - /// Joint Dynamics - my_shared_ptr dynamics; - - /// Joint Limits - my_shared_ptr limits; - - /// Unsupported Hidden Feature - my_shared_ptr safety; - - /// Unsupported Hidden Feature - my_shared_ptr calibration; - - /// Option to Mimic another Joint - my_shared_ptr mimic; - - void clear() - { - this->axis.clear(); - this->child_link_name.clear(); - this->parent_link_name.clear(); - this->parent_to_joint_origin_transform.clear(); - this->dynamics.reset(0); - this->limits.reset(0); - this->safety.reset(0); - this->calibration.reset(0); - this->type = UNKNOWN; - }; -}; - -} - -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/link.h b/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/link.h deleted file mode 100644 index 22e64cf5a..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/link.h +++ /dev/null @@ -1,262 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - -#ifndef URDF_INTERFACE_LINK_H -#define URDF_INTERFACE_LINK_H - -#include -#include -#include - - -#ifdef URDF_USE_BOOST - #include - #include -#else - #include -#endif - -#include "joint.h" -#include "color.h" -#include "pose.h" - -namespace urdf{ - -class Geometry -{ -public: - enum {SPHERE, BOX, CYLINDER, MESH} type; - - virtual ~Geometry(void) - { - } -}; - -class Sphere : public Geometry -{ -public: - Sphere() { this->clear(); type = SPHERE; }; - double radius; - - void clear() - { - radius = 0; - }; -}; - -class Box : public Geometry -{ -public: - Box() { this->clear(); type = BOX; } - Vector3 dim; - - void clear() - { - this->dim.clear(); - }; -}; - -class Cylinder : public Geometry -{ -public: - Cylinder() { this->clear(); type = CYLINDER; }; - double length; - double radius; - - void clear() - { - length = 0; - radius = 0; - }; -}; - -class Mesh : public Geometry -{ -public: - Mesh() { this->clear(); type = MESH; }; - std::string filename; - Vector3 scale; - - void clear() - { - filename.clear(); - // default scale - scale.x = 1; - scale.y = 1; - scale.z = 1; - }; -}; - -class Material -{ -public: - Material() { this->clear(); }; - std::string name; - std::string texture_filename; - Color color; - - void clear() - { - color.clear(); - texture_filename.clear(); - name.clear(); - }; -}; - -class Inertial -{ -public: - Inertial() { this->clear(); }; - Pose origin; - double mass; - double ixx,ixy,ixz,iyy,iyz,izz; - - void clear() - { - origin.clear(); - mass = 0; - ixx = ixy = ixz = iyy = iyz = izz = 0; - }; -}; - -class Visual -{ -public: - Visual() { this->clear(); }; - Pose origin; - my_shared_ptr geometry; - - std::string material_name; - my_shared_ptr material; - - void clear() - { - origin.clear(); - material_name.clear(); - material.reset(0); - geometry.reset(0); - name.clear(); - }; - - std::string name; -}; - -class Collision -{ -public: - Collision() { this->clear(); }; - Pose origin; - my_shared_ptr geometry; - - void clear() - { - origin.clear(); - geometry.reset(0); - name.clear(); - }; - - std::string name; - -}; - - -class Link -{ -public: - Link() { this->clear(); }; - - std::string name; - - /// inertial element - my_shared_ptr inertial; - - /// visual element - my_shared_ptr visual; - - /// collision element - my_shared_ptr collision; - - /// if more than one collision element is specified, all collision elements are placed in this array (the collision member points to the first element of the array) - std::vector > collision_array; - - /// if more than one visual element is specified, all visual elements are placed in this array (the visual member points to the first element of the array) - std::vector > visual_array; - - /// Parent Joint element - /// explicitly stating "parent" because we want directional-ness for tree structure - /// every link can have one parent - my_shared_ptr parent_joint; - - std::vector > child_joints; - std::vector > child_links; - - mutable int m_link_index; - - const Link* getParent() const - {return parent_link_;} - - void setParent(const my_shared_ptr &parent) - { - parent_link_ = parent.get(); - } - - void clear() - { - this->name.clear(); - this->inertial.reset(0); - this->visual.reset(0); - this->collision.reset(0); - this->parent_joint.reset(0); - this->child_joints.clear(); - this->child_links.clear(); - this->collision_array.clear(); - this->visual_array.clear(); - this->m_link_index=-1; - this->parent_link_ = NULL; - }; - -private: -// boost::weak_ptr parent_link_; - const Link* parent_link_; - -}; - - - - -} - -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/model.h b/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/model.h deleted file mode 100644 index 8e93d94e4..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/model.h +++ /dev/null @@ -1,220 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - -#ifndef URDF_INTERFACE_MODEL_H -#define URDF_INTERFACE_MODEL_H - -#include -#include -//#include -#include -#include //printf -#include - -namespace urdf { - -class ModelInterface -{ -public: - my_shared_ptr getRoot(void) const{return this->root_link_;}; - my_shared_ptr getLink(const std::string& name) const - { - my_shared_ptr ptr; - if (this->links_.find(name) == this->links_.end()) - ptr.reset(0); - else - ptr = this->links_.find(name)->second; - return ptr; - }; - - my_shared_ptr getJoint(const std::string& name) const - { - my_shared_ptr ptr; - if (this->joints_.find(name) == this->joints_.end()) - ptr.reset(0); - else - ptr = this->joints_.find(name)->second; - return ptr; - }; - - - const std::string& getName() const {return name_;}; - void getLinks(std::vector >& links) const - { - for (std::map >::const_iterator link = this->links_.begin();link != this->links_.end(); link++) - { - links.push_back(link->second); - } - }; - - void clear() - { - m_numLinks=0; - m_numJoints = 0; - name_.clear(); - this->links_.clear(); - this->joints_.clear(); - this->materials_.clear(); - this->root_link_.reset(0); - }; - - /// non-const getLink() - void getLink(const std::string& name,my_shared_ptr &link) const - { - my_shared_ptr ptr; - if (this->links_.find(name) == this->links_.end()) - ptr.reset(0); - else - ptr = this->links_.find(name)->second; - link = ptr; - }; - - /// non-const getMaterial() - my_shared_ptr getMaterial(const std::string& name) const - { - my_shared_ptr ptr; - if (this->materials_.find(name) == this->materials_.end()) - ptr.reset(0); - else - ptr = this->materials_.find(name)->second; - return ptr; - }; - - void initTree(std::map &parent_link_tree) - { - // loop through all joints, for every link, assign children links and children joints - for (std::map >::iterator joint = this->joints_.begin();joint != this->joints_.end(); joint++) - { - std::string parent_link_name = joint->second->parent_link_name; - std::string child_link_name = joint->second->child_link_name; - - if (parent_link_name.empty() || child_link_name.empty()) - { - assert(0); - - // throw ParseError("Joint [" + joint->second->name + "] is missing a parent and/or child link specification."); - } - else - { - // find child and parent links - my_shared_ptr child_link, parent_link; - this->getLink(child_link_name, child_link); - if (!child_link) - { - printf("Error: child link [%s] of joint [%s] not found\n", child_link_name.c_str(),joint->first.c_str() ); - assert(0); -// throw ParseError("child link [" + child_link_name + "] of joint [" + joint->first + "] not found"); - } - this->getLink(parent_link_name, parent_link); - if (!parent_link) - { - assert(0); - -/* throw ParseError("parent link [" + parent_link_name + "] of joint [" + joint->first + "] not found. This is not valid according to the URDF spec. Every link you refer to from a joint needs to be explicitly defined in the robot description. To fix this problem you can either remove this joint [" + joint->first + "] from your urdf file, or add \"\" to your urdf file."); - - */} - - //set parent link for child link - child_link->setParent(parent_link); - - //set parent joint for child link - child_link->parent_joint = joint->second; - - //set child joint for parent link - parent_link->child_joints.push_back(joint->second); - - //set child link for parent link - parent_link->child_links.push_back(child_link); - - // fill in child/parent string map - parent_link_tree[child_link->name] = parent_link_name; - } - } - } - - void initRoot(const std::map &parent_link_tree) - { - this->root_link_.reset(0); - - // find the links that have no parent in the tree - for (std::map >::const_iterator l=this->links_.begin(); l!=this->links_.end(); l++) - { - std::map::const_iterator parent = parent_link_tree.find(l->first); - if (parent == parent_link_tree.end()) - { - // store root link - if (!this->root_link_) - { - getLink(l->first, this->root_link_); - } - // we already found a root link - else - { - assert(0); - // throw ParseError("Two root links found: [" + this->root_link_->name + "] and [" + l->first + "]"); - } - } - } - if (!this->root_link_) - { - assert(0); - //throw ParseError("No root link found. The robot xml is not a valid tree."); - } - } - - - /// \brief complete list of Links - std::map > links_; - /// \brief complete list of Joints - std::map > joints_; - /// \brief complete list of Materials - std::map > materials_; - - /// \brief The name of the robot model - std::string name_; - - /// \brief The root is always a link (the parent of the tree describing the robot) - my_shared_ptr root_link_; - - int m_numLinks;//includes parent - int m_numJoints; - - -}; - -} - -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/pose.h b/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/pose.h deleted file mode 100644 index 93183c8f8..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/pose.h +++ /dev/null @@ -1,265 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: Wim Meeussen */ - -#ifndef URDF_INTERFACE_POSE_H -#define URDF_INTERFACE_POSE_H - -#include -//#include -#include -#include -#ifndef M_PI -#define M_PI 3.141592538 -#endif //M_PI - -#ifdef URDF_USE_BOOST - #include - #include -#else - #include - #include -#endif //URDF_USE_BOOST - -#include -#include - -namespace urdf{ - -class Vector3 -{ -public: - Vector3(double _x,double _y, double _z) {this->x=_x;this->y=_y;this->z=_z;}; - Vector3() {this->clear();}; - double x; - double y; - double z; - - void clear() {this->x=this->y=this->z=0.0;}; - void init(const std::string &vector_str) - { - this->clear(); - std::vector pieces; - std::vector xyz; - boost::split( pieces, vector_str, boost::is_any_of(" ")); - for (unsigned int i = 0; i < pieces.size(); ++i){ - if (pieces[i] != ""){ - try { - xyz.push_back(boost::lexical_cast(pieces[i].c_str())); - } - catch (boost::bad_lexical_cast &e) - { - assert(0); - // throw ParseError("Unable to parse component [" + pieces[i] + "] to a double (while parsing a vector value)"); - } - } - } - - - - if (xyz.size() != 3) - { - assert(0); - // throw ParseError("Parser found " + boost::lexical_cast(xyz.size()) + " elements but 3 expected while parsing vector [" + vector_str + "]"); - } - this->x = xyz[0]; - this->y = xyz[1]; - this->z = xyz[2]; - } - - Vector3 operator+(Vector3 vec) - { - return Vector3(this->x+vec.x,this->y+vec.y,this->z+vec.z); - }; -}; - -class Rotation -{ -public: - Rotation(double _x,double _y, double _z, double _w) {this->x=_x;this->y=_y;this->z=_z;this->w=_w;}; - Rotation() {this->clear();}; - void getQuaternion(double &quat_x,double &quat_y,double &quat_z, double &quat_w) const - { - quat_x = this->x; - quat_y = this->y; - quat_z = this->z; - quat_w = this->w; - }; - void getRPY(double &roll,double &pitch,double &yaw) const - { - double sqw; - double sqx; - double sqy; - double sqz; - - sqx = this->x * this->x; - sqy = this->y * this->y; - sqz = this->z * this->z; - sqw = this->w * this->w; - - roll = atan2(2 * (this->y*this->z + this->w*this->x), sqw - sqx - sqy + sqz); - double sarg = -2 * (this->x*this->z - this->w*this->y); - pitch = sarg <= -1.0 ? -0.5*M_PI : (sarg >= 1.0 ? 0.5*M_PI : asin(sarg)); - yaw = atan2(2 * (this->x*this->y + this->w*this->z), sqw + sqx - sqy - sqz); - - }; - void setFromQuaternion(double quat_x,double quat_y,double quat_z,double quat_w) - { - this->x = quat_x; - this->y = quat_y; - this->z = quat_z; - this->w = quat_w; - this->normalize(); - }; - void setFromRPY(double roll, double pitch, double yaw) - { - double phi, the, psi; - - phi = roll / 2.0; - the = pitch / 2.0; - psi = yaw / 2.0; - - this->x = sin(phi) * cos(the) * cos(psi) - cos(phi) * sin(the) * sin(psi); - this->y = cos(phi) * sin(the) * cos(psi) + sin(phi) * cos(the) * sin(psi); - this->z = cos(phi) * cos(the) * sin(psi) - sin(phi) * sin(the) * cos(psi); - this->w = cos(phi) * cos(the) * cos(psi) + sin(phi) * sin(the) * sin(psi); - - this->normalize(); - }; - - double x,y,z,w; - - void init(const std::string &rotation_str) - { - this->clear(); - Vector3 rpy; - rpy.init(rotation_str); - setFromRPY(rpy.x, rpy.y, rpy.z); - } - - void clear() { this->x=this->y=this->z=0.0;this->w=1.0; } - - void normalize() - { - double s = sqrt(this->x * this->x + - this->y * this->y + - this->z * this->z + - this->w * this->w); - if (s == 0.0) - { - this->x = 0.0; - this->y = 0.0; - this->z = 0.0; - this->w = 1.0; - } - else - { - this->x /= s; - this->y /= s; - this->z /= s; - this->w /= s; - } - }; - - // Multiplication operator (copied from gazebo) - Rotation operator*( const Rotation &qt ) const - { - Rotation c; - - c.x = this->w * qt.x + this->x * qt.w + this->y * qt.z - this->z * qt.y; - c.y = this->w * qt.y - this->x * qt.z + this->y * qt.w + this->z * qt.x; - c.z = this->w * qt.z + this->x * qt.y - this->y * qt.x + this->z * qt.w; - c.w = this->w * qt.w - this->x * qt.x - this->y * qt.y - this->z * qt.z; - - return c; - }; - /// Rotate a vector using the quaternion - Vector3 operator*(Vector3 vec) const - { - Rotation tmp; - Vector3 result; - - tmp.w = 0.0; - tmp.x = vec.x; - tmp.y = vec.y; - tmp.z = vec.z; - - tmp = (*this) * (tmp * this->GetInverse()); - - result.x = tmp.x; - result.y = tmp.y; - result.z = tmp.z; - - return result; - }; - // Get the inverse of this quaternion - Rotation GetInverse() const - { - Rotation q; - - double norm = this->w*this->w+this->x*this->x+this->y*this->y+this->z*this->z; - - if (norm > 0.0) - { - q.w = this->w / norm; - q.x = -this->x / norm; - q.y = -this->y / norm; - q.z = -this->z / norm; - } - - return q; - }; - - -}; - -class Pose -{ -public: - Pose() { this->clear(); }; - - Vector3 position; - Rotation rotation; - - void clear() - { - this->position.clear(); - this->rotation.clear(); - }; -}; - -} - -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/twist.h b/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/twist.h deleted file mode 100644 index 5560de34a..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model/include/urdf_model/twist.h +++ /dev/null @@ -1,68 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - -#ifndef URDF_TWIST_H -#define URDF_TWIST_H - -#include -#include -#include -#include -#include - -namespace urdf{ - - -class Twist -{ -public: - Twist() { this->clear(); }; - - Vector3 linear; - // Angular velocity represented by Euler angles - Vector3 angular; - - void clear() - { - this->linear.clear(); - this->angular.clear(); - }; -}; - -} - -#endif - diff --git a/btgui/urdf/urdfdom_headers/urdf_model_state/include/urdf_model_state/model_state.h b/btgui/urdf/urdfdom_headers/urdf_model_state/include/urdf_model_state/model_state.h deleted file mode 100644 index b1327191a..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model_state/include/urdf_model_state/model_state.h +++ /dev/null @@ -1,141 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - -#ifndef URDF_MODEL_STATE_H -#define URDF_MODEL_STATE_H - -#include -#include -#include -#include -#include - -#include "urdf_model/pose.h" -#include - - -namespace urdf{ - -class Time -{ -public: - Time() { this->clear(); }; - - void set(double _seconds) - { - this->sec = (int32_t)(floor(_seconds)); - this->nsec = (int32_t)(round((_seconds - this->sec) * 1e9)); - this->Correct(); - }; - - operator double () - { - return (static_cast(this->sec) + - static_cast(this->nsec)*1e-9); - }; - - int32_t sec; - int32_t nsec; - - void clear() - { - this->sec = 0; - this->nsec = 0; - }; -private: - void Correct() - { - // Make any corrections - if (this->nsec >= 1e9) - { - this->sec++; - this->nsec = (int32_t)(this->nsec - 1e9); - } - else if (this->nsec < 0) - { - this->sec--; - this->nsec = (int32_t)(this->nsec + 1e9); - } - }; -}; - - -class JointState -{ -public: - JointState() { this->clear(); }; - - /// joint name - std::string joint; - - std::vector position; - std::vector velocity; - std::vector effort; - - void clear() - { - this->joint.clear(); - this->position.clear(); - this->velocity.clear(); - this->effort.clear(); - } -}; - -class ModelState -{ -public: - ModelState() { this->clear(); }; - - /// state name must be unique - std::string name; - - Time time_stamp; - - void clear() - { - this->name.clear(); - this->time_stamp.set(0); - this->joint_states.clear(); - }; - - std::vector > joint_states; - -}; - -} - -#endif - diff --git a/btgui/urdf/urdfdom_headers/urdf_model_state/include/urdf_model_state/twist.h b/btgui/urdf/urdfdom_headers/urdf_model_state/include/urdf_model_state/twist.h deleted file mode 100644 index 05f1917b9..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_model_state/include/urdf_model_state/twist.h +++ /dev/null @@ -1,42 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -#ifndef URDF_MODEL_STATE_TWIST_ -#define URDF_MODEL_STATE_TWIST_ - -#warning "Please Use #include " - -#include - -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_sensor/include/urdf_sensor/sensor.h b/btgui/urdf/urdfdom_headers/urdf_sensor/include/urdf_sensor/sensor.h deleted file mode 100644 index 3b996957b..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_sensor/include/urdf_sensor/sensor.h +++ /dev/null @@ -1,176 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - -/* example - - - - - 1.5708 - - - - - - - - - - - - - - -*/ - - - -#ifndef URDF_SENSOR_H -#define URDF_SENSOR_H - -#include -#include -#include -#include -#include -#include "urdf_model/pose.h" -#include "urdf_model/joint.h" -#include "urdf_model/link.h" - -namespace urdf{ - -class VisualSensor -{ -public: - enum {CAMERA, RAY} type; - virtual ~VisualSensor(void) - { - } -}; - -class Camera : public VisualSensor -{ -public: - Camera() { this->clear(); }; - unsigned int width, height; - /// format is optional: defaults to R8G8B8), but can be - /// (L8|R8G8B8|B8G8R8|BAYER_RGGB8|BAYER_BGGR8|BAYER_GBRG8|BAYER_GRBG8) - std::string format; - double hfov; - double near; - double far; - - void clear() - { - hfov = 0; - width = 0; - height = 0; - format.clear(); - near = 0; - far = 0; - }; -}; - -class Ray : public VisualSensor -{ -public: - Ray() { this->clear(); }; - unsigned int horizontal_samples; - double horizontal_resolution; - double horizontal_min_angle; - double horizontal_max_angle; - unsigned int vertical_samples; - double vertical_resolution; - double vertical_min_angle; - double vertical_max_angle; - - void clear() - { - // set defaults - horizontal_samples = 1; - horizontal_resolution = 1; - horizontal_min_angle = 0; - horizontal_max_angle = 0; - vertical_samples = 1; - vertical_resolution = 1; - vertical_min_angle = 0; - vertical_max_angle = 0; - }; -}; - - -class Sensor -{ -public: - Sensor() { this->clear(); }; - - /// sensor name must be unique - std::string name; - - /// update rate in Hz - double update_rate; - - /// transform from parent frame to optical center - /// with z-forward and x-right, y-down - Pose origin; - - /// sensor - boost::shared_ptr sensor; - - - /// Parent link element name. A pointer is stored in parent_link_. - std::string parent_link_name; - - boost::shared_ptr getParent() const - {return parent_link_.lock();}; - - void setParent(boost::shared_ptr parent) - { this->parent_link_ = parent; } - - void clear() - { - this->name.clear(); - this->sensor.reset(); - this->parent_link_name.clear(); - this->parent_link_.reset(); - }; - -private: - boost::weak_ptr parent_link_; - -}; -} -#endif diff --git a/btgui/urdf/urdfdom_headers/urdf_world/include/urdf_world/world.h b/btgui/urdf/urdfdom_headers/urdf_world/include/urdf_world/world.h deleted file mode 100644 index eb13fc4b1..000000000 --- a/btgui/urdf/urdfdom_headers/urdf_world/include/urdf_world/world.h +++ /dev/null @@ -1,114 +0,0 @@ -/********************************************************************* -* Software License Agreement (BSD License) -* -* Copyright (c) 2008, Willow Garage, Inc. -* All rights reserved. -* -* Redistribution and use in source and binary forms, with or without -* modification, are permitted provided that the following conditions -* are met: -* -* * Redistributions of source code must retain the above copyright -* notice, this list of conditions and the following disclaimer. -* * Redistributions in binary form must reproduce the above -* copyright notice, this list of conditions and the following -* disclaimer in the documentation and/or other materials provided -* with the distribution. -* * Neither the name of the Willow Garage nor the names of its -* contributors may be used to endorse or promote products derived -* from this software without specific prior written permission. -* -* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS -* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE -* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, -* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, -* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN -* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE -* POSSIBILITY OF SUCH DAMAGE. -*********************************************************************/ - -/* Author: John Hsu */ - -/* encapsulates components in a world - see http://ros.org/wiki/usdf/XML/urdf_world and - for details -*/ -/* example world XML - - - - - ... - - - - - - - - - - - - - - - - - - - -*/ - -#ifndef USDF_STATE_H -#define USDF_STATE_H - -#include -#include -#include -#include -#include -#include - -#include "urdf_model/model.h" -#include "urdf_model/pose.h" -#include "urdf_model/twist.h" - -namespace urdf{ - -class Entity -{ -public: - boost::shared_ptr model; - Pose origin; - Twist twist; -}; - -class World -{ -public: - World() { this->clear(); }; - - /// world name must be unique - std::string name; - - std::vector models; - - void initXml(TiXmlElement* config); - - void clear() - { - this->name.clear(); - }; -}; -} - -#endif - diff --git a/btgui/zlib/adler32.c b/btgui/zlib/adler32.c deleted file mode 100644 index a868f073d..000000000 --- a/btgui/zlib/adler32.c +++ /dev/null @@ -1,179 +0,0 @@ -/* adler32.c -- compute the Adler-32 checksum of a data stream - * Copyright (C) 1995-2011 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* @(#) $Id$ */ - -#include "zutil.h" - -#define local static - -local uLong adler32_combine_ OF((uLong adler1, uLong adler2, z_off64_t len2)); - -#define BASE 65521 /* largest prime smaller than 65536 */ -#define NMAX 5552 -/* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */ - -#define DO1(buf,i) {adler += (buf)[i]; sum2 += adler;} -#define DO2(buf,i) DO1(buf,i); DO1(buf,i+1); -#define DO4(buf,i) DO2(buf,i); DO2(buf,i+2); -#define DO8(buf,i) DO4(buf,i); DO4(buf,i+4); -#define DO16(buf) DO8(buf,0); DO8(buf,8); - -/* use NO_DIVIDE if your processor does not do division in hardware -- - try it both ways to see which is faster */ -#ifdef NO_DIVIDE -/* note that this assumes BASE is 65521, where 65536 % 65521 == 15 - (thank you to John Reiser for pointing this out) */ -# define CHOP(a) \ - do { \ - unsigned long tmp = a >> 16; \ - a &= 0xffffUL; \ - a += (tmp << 4) - tmp; \ - } while (0) -# define MOD28(a) \ - do { \ - CHOP(a); \ - if (a >= BASE) a -= BASE; \ - } while (0) -# define MOD(a) \ - do { \ - CHOP(a); \ - MOD28(a); \ - } while (0) -# define MOD63(a) \ - do { /* this assumes a is not negative */ \ - z_off64_t tmp = a >> 32; \ - a &= 0xffffffffL; \ - a += (tmp << 8) - (tmp << 5) + tmp; \ - tmp = a >> 16; \ - a &= 0xffffL; \ - a += (tmp << 4) - tmp; \ - tmp = a >> 16; \ - a &= 0xffffL; \ - a += (tmp << 4) - tmp; \ - if (a >= BASE) a -= BASE; \ - } while (0) -#else -# define MOD(a) a %= BASE -# define MOD28(a) a %= BASE -# define MOD63(a) a %= BASE -#endif - -/* ========================================================================= */ -uLong ZEXPORT adler32(adler, buf, len) - uLong adler; - const Bytef *buf; - uInt len; -{ - unsigned long sum2; - unsigned n; - - /* split Adler-32 into component sums */ - sum2 = (adler >> 16) & 0xffff; - adler &= 0xffff; - - /* in case user likes doing a byte at a time, keep it fast */ - if (len == 1) { - adler += buf[0]; - if (adler >= BASE) - adler -= BASE; - sum2 += adler; - if (sum2 >= BASE) - sum2 -= BASE; - return adler | (sum2 << 16); - } - - /* initial Adler-32 value (deferred check for len == 1 speed) */ - if (buf == Z_NULL) - return 1L; - - /* in case short lengths are provided, keep it somewhat fast */ - if (len < 16) { - while (len--) { - adler += *buf++; - sum2 += adler; - } - if (adler >= BASE) - adler -= BASE; - MOD28(sum2); /* only added so many BASE's */ - return adler | (sum2 << 16); - } - - /* do length NMAX blocks -- requires just one modulo operation */ - while (len >= NMAX) { - len -= NMAX; - n = NMAX / 16; /* NMAX is divisible by 16 */ - do { - DO16(buf); /* 16 sums unrolled */ - buf += 16; - } while (--n); - MOD(adler); - MOD(sum2); - } - - /* do remaining bytes (less than NMAX, still just one modulo) */ - if (len) { /* avoid modulos if none remaining */ - while (len >= 16) { - len -= 16; - DO16(buf); - buf += 16; - } - while (len--) { - adler += *buf++; - sum2 += adler; - } - MOD(adler); - MOD(sum2); - } - - /* return recombined sums */ - return adler | (sum2 << 16); -} - -/* ========================================================================= */ -local uLong adler32_combine_(adler1, adler2, len2) - uLong adler1; - uLong adler2; - z_off64_t len2; -{ - unsigned long sum1; - unsigned long sum2; - unsigned rem; - - /* for negative len, return invalid adler32 as a clue for debugging */ - if (len2 < 0) - return 0xffffffffUL; - - /* the derivation of this formula is left as an exercise for the reader */ - MOD63(len2); /* assumes len2 >= 0 */ - rem = (unsigned)len2; - sum1 = adler1 & 0xffff; - sum2 = rem * sum1; - MOD(sum2); - sum1 += (adler2 & 0xffff) + BASE - 1; - sum2 += ((adler1 >> 16) & 0xffff) + ((adler2 >> 16) & 0xffff) + BASE - rem; - if (sum1 >= BASE) sum1 -= BASE; - if (sum1 >= BASE) sum1 -= BASE; - if (sum2 >= (BASE << 1)) sum2 -= (BASE << 1); - if (sum2 >= BASE) sum2 -= BASE; - return sum1 | (sum2 << 16); -} - -/* ========================================================================= */ -uLong ZEXPORT adler32_combine(adler1, adler2, len2) - uLong adler1; - uLong adler2; - z_off_t len2; -{ - return adler32_combine_(adler1, adler2, len2); -} - -uLong ZEXPORT adler32_combine64(adler1, adler2, len2) - uLong adler1; - uLong adler2; - z_off64_t len2; -{ - return adler32_combine_(adler1, adler2, len2); -} diff --git a/btgui/zlib/compress.c b/btgui/zlib/compress.c deleted file mode 100644 index 6e9762676..000000000 --- a/btgui/zlib/compress.c +++ /dev/null @@ -1,80 +0,0 @@ -/* compress.c -- compress a memory buffer - * Copyright (C) 1995-2005 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* @(#) $Id$ */ - -#define ZLIB_INTERNAL -#include "zlib.h" - -/* =========================================================================== - Compresses the source buffer into the destination buffer. The level - parameter has the same meaning as in deflateInit. sourceLen is the byte - length of the source buffer. Upon entry, destLen is the total size of the - destination buffer, which must be at least 0.1% larger than sourceLen plus - 12 bytes. Upon exit, destLen is the actual size of the compressed buffer. - - compress2 returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_BUF_ERROR if there was not enough room in the output buffer, - Z_STREAM_ERROR if the level parameter is invalid. -*/ -int ZEXPORT compress2 (dest, destLen, source, sourceLen, level) - Bytef *dest; - uLongf *destLen; - const Bytef *source; - uLong sourceLen; - int level; -{ - z_stream stream; - int err; - - stream.next_in = (z_const Bytef *)source; - stream.avail_in = (uInt)sourceLen; -#ifdef MAXSEG_64K - /* Check for source > 64K on 16-bit machine: */ - if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR; -#endif - stream.next_out = dest; - stream.avail_out = (uInt)*destLen; - if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR; - - stream.zalloc = (alloc_func)0; - stream.zfree = (free_func)0; - stream.opaque = (voidpf)0; - - err = deflateInit(&stream, level); - if (err != Z_OK) return err; - - err = deflate(&stream, Z_FINISH); - if (err != Z_STREAM_END) { - deflateEnd(&stream); - return err == Z_OK ? Z_BUF_ERROR : err; - } - *destLen = stream.total_out; - - err = deflateEnd(&stream); - return err; -} - -/* =========================================================================== - */ -int ZEXPORT compress (dest, destLen, source, sourceLen) - Bytef *dest; - uLongf *destLen; - const Bytef *source; - uLong sourceLen; -{ - return compress2(dest, destLen, source, sourceLen, Z_DEFAULT_COMPRESSION); -} - -/* =========================================================================== - If the default memLevel or windowBits for deflateInit() is changed, then - this function needs to be updated. - */ -uLong ZEXPORT compressBound (sourceLen) - uLong sourceLen; -{ - return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + - (sourceLen >> 25) + 13; -} diff --git a/btgui/zlib/crc32.c b/btgui/zlib/crc32.c deleted file mode 100644 index 979a7190a..000000000 --- a/btgui/zlib/crc32.c +++ /dev/null @@ -1,425 +0,0 @@ -/* crc32.c -- compute the CRC-32 of a data stream - * Copyright (C) 1995-2006, 2010, 2011, 2012 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - * - * Thanks to Rodney Brown for his contribution of faster - * CRC methods: exclusive-oring 32 bits of data at a time, and pre-computing - * tables for updating the shift register in one step with three exclusive-ors - * instead of four steps with four exclusive-ors. This results in about a - * factor of two increase in speed on a Power PC G4 (PPC7455) using gcc -O3. - */ - -/* @(#) $Id$ */ - -/* - Note on the use of DYNAMIC_CRC_TABLE: there is no mutex or semaphore - protection on the static variables used to control the first-use generation - of the crc tables. Therefore, if you #define DYNAMIC_CRC_TABLE, you should - first call get_crc_table() to initialize the tables before allowing more than - one thread to use crc32(). - - DYNAMIC_CRC_TABLE and MAKECRCH can be #defined to write out crc32.h. - */ - -#ifdef MAKECRCH -# include -# ifndef DYNAMIC_CRC_TABLE -# define DYNAMIC_CRC_TABLE -# endif /* !DYNAMIC_CRC_TABLE */ -#endif /* MAKECRCH */ - -#include "zutil.h" /* for STDC and FAR definitions */ - -#define local static - -/* Definitions for doing the crc four data bytes at a time. */ -#if !defined(NOBYFOUR) && defined(Z_U4) -# define BYFOUR -#endif -#ifdef BYFOUR - local unsigned long crc32_little OF((unsigned long, - const unsigned char FAR *, unsigned)); - local unsigned long crc32_big OF((unsigned long, - const unsigned char FAR *, unsigned)); -# define TBLS 8 -#else -# define TBLS 1 -#endif /* BYFOUR */ - -/* Local functions for crc concatenation */ -local unsigned long gf2_matrix_times OF((unsigned long *mat, - unsigned long vec)); -local void gf2_matrix_square OF((unsigned long *square, unsigned long *mat)); -local uLong crc32_combine_ OF((uLong crc1, uLong crc2, z_off64_t len2)); - - -#ifdef DYNAMIC_CRC_TABLE - -local volatile int crc_table_empty = 1; -local z_crc_t FAR crc_table[TBLS][256]; -local void make_crc_table OF((void)); -#ifdef MAKECRCH - local void write_table OF((FILE *, const z_crc_t FAR *)); -#endif /* MAKECRCH */ -/* - Generate tables for a byte-wise 32-bit CRC calculation on the polynomial: - x^32+x^26+x^23+x^22+x^16+x^12+x^11+x^10+x^8+x^7+x^5+x^4+x^2+x+1. - - Polynomials over GF(2) are represented in binary, one bit per coefficient, - with the lowest powers in the most significant bit. Then adding polynomials - is just exclusive-or, and multiplying a polynomial by x is a right shift by - one. If we call the above polynomial p, and represent a byte as the - polynomial q, also with the lowest power in the most significant bit (so the - byte 0xb1 is the polynomial x^7+x^3+x+1), then the CRC is (q*x^32) mod p, - where a mod b means the remainder after dividing a by b. - - This calculation is done using the shift-register method of multiplying and - taking the remainder. The register is initialized to zero, and for each - incoming bit, x^32 is added mod p to the register if the bit is a one (where - x^32 mod p is p+x^32 = x^26+...+1), and the register is multiplied mod p by - x (which is shifting right by one and adding x^32 mod p if the bit shifted - out is a one). We start with the highest power (least significant bit) of - q and repeat for all eight bits of q. - - The first table is simply the CRC of all possible eight bit values. This is - all the information needed to generate CRCs on data a byte at a time for all - combinations of CRC register values and incoming bytes. The remaining tables - allow for word-at-a-time CRC calculation for both big-endian and little- - endian machines, where a word is four bytes. -*/ -local void make_crc_table() -{ - z_crc_t c; - int n, k; - z_crc_t poly; /* polynomial exclusive-or pattern */ - /* terms of polynomial defining this crc (except x^32): */ - static volatile int first = 1; /* flag to limit concurrent making */ - static const unsigned char p[] = {0,1,2,4,5,7,8,10,11,12,16,22,23,26}; - - /* See if another task is already doing this (not thread-safe, but better - than nothing -- significantly reduces duration of vulnerability in - case the advice about DYNAMIC_CRC_TABLE is ignored) */ - if (first) { - first = 0; - - /* make exclusive-or pattern from polynomial (0xedb88320UL) */ - poly = 0; - for (n = 0; n < (int)(sizeof(p)/sizeof(unsigned char)); n++) - poly |= (z_crc_t)1 << (31 - p[n]); - - /* generate a crc for every 8-bit value */ - for (n = 0; n < 256; n++) { - c = (z_crc_t)n; - for (k = 0; k < 8; k++) - c = c & 1 ? poly ^ (c >> 1) : c >> 1; - crc_table[0][n] = c; - } - -#ifdef BYFOUR - /* generate crc for each value followed by one, two, and three zeros, - and then the byte reversal of those as well as the first table */ - for (n = 0; n < 256; n++) { - c = crc_table[0][n]; - crc_table[4][n] = ZSWAP32(c); - for (k = 1; k < 4; k++) { - c = crc_table[0][c & 0xff] ^ (c >> 8); - crc_table[k][n] = c; - crc_table[k + 4][n] = ZSWAP32(c); - } - } -#endif /* BYFOUR */ - - crc_table_empty = 0; - } - else { /* not first */ - /* wait for the other guy to finish (not efficient, but rare) */ - while (crc_table_empty) - ; - } - -#ifdef MAKECRCH - /* write out CRC tables to crc32.h */ - { - FILE *out; - - out = fopen("crc32.h", "w"); - if (out == NULL) return; - fprintf(out, "/* crc32.h -- tables for rapid CRC calculation\n"); - fprintf(out, " * Generated automatically by crc32.c\n */\n\n"); - fprintf(out, "local const z_crc_t FAR "); - fprintf(out, "crc_table[TBLS][256] =\n{\n {\n"); - write_table(out, crc_table[0]); -# ifdef BYFOUR - fprintf(out, "#ifdef BYFOUR\n"); - for (k = 1; k < 8; k++) { - fprintf(out, " },\n {\n"); - write_table(out, crc_table[k]); - } - fprintf(out, "#endif\n"); -# endif /* BYFOUR */ - fprintf(out, " }\n};\n"); - fclose(out); - } -#endif /* MAKECRCH */ -} - -#ifdef MAKECRCH -local void write_table(out, table) - FILE *out; - const z_crc_t FAR *table; -{ - int n; - - for (n = 0; n < 256; n++) - fprintf(out, "%s0x%08lxUL%s", n % 5 ? "" : " ", - (unsigned long)(table[n]), - n == 255 ? "\n" : (n % 5 == 4 ? ",\n" : ", ")); -} -#endif /* MAKECRCH */ - -#else /* !DYNAMIC_CRC_TABLE */ -/* ======================================================================== - * Tables of CRC-32s of all single-byte values, made by make_crc_table(). - */ -#include "crc32.h" -#endif /* DYNAMIC_CRC_TABLE */ - -/* ========================================================================= - * This function can be used by asm versions of crc32() - */ -const z_crc_t FAR * ZEXPORT get_crc_table() -{ -#ifdef DYNAMIC_CRC_TABLE - if (crc_table_empty) - make_crc_table(); -#endif /* DYNAMIC_CRC_TABLE */ - return (const z_crc_t FAR *)crc_table; -} - -/* ========================================================================= */ -#define DO1 crc = crc_table[0][((int)crc ^ (*buf++)) & 0xff] ^ (crc >> 8) -#define DO8 DO1; DO1; DO1; DO1; DO1; DO1; DO1; DO1 - -/* ========================================================================= */ -unsigned long ZEXPORT crc32(crc, buf, len) - unsigned long crc; - const unsigned char FAR *buf; - uInt len; -{ - if (buf == Z_NULL) return 0UL; - -#ifdef DYNAMIC_CRC_TABLE - if (crc_table_empty) - make_crc_table(); -#endif /* DYNAMIC_CRC_TABLE */ - -#ifdef BYFOUR - if (sizeof(void *) == sizeof(ptrdiff_t)) { - z_crc_t endian; - - endian = 1; - if (*((unsigned char *)(&endian))) - return crc32_little(crc, buf, len); - else - return crc32_big(crc, buf, len); - } -#endif /* BYFOUR */ - crc = crc ^ 0xffffffffUL; - while (len >= 8) { - DO8; - len -= 8; - } - if (len) do { - DO1; - } while (--len); - return crc ^ 0xffffffffUL; -} - -#ifdef BYFOUR - -/* ========================================================================= */ -#define DOLIT4 c ^= *buf4++; \ - c = crc_table[3][c & 0xff] ^ crc_table[2][(c >> 8) & 0xff] ^ \ - crc_table[1][(c >> 16) & 0xff] ^ crc_table[0][c >> 24] -#define DOLIT32 DOLIT4; DOLIT4; DOLIT4; DOLIT4; DOLIT4; DOLIT4; DOLIT4; DOLIT4 - -/* ========================================================================= */ -local unsigned long crc32_little(crc, buf, len) - unsigned long crc; - const unsigned char FAR *buf; - unsigned len; -{ - register z_crc_t c; - register const z_crc_t FAR *buf4; - - c = (z_crc_t)crc; - c = ~c; - while (len && ((ptrdiff_t)buf & 3)) { - c = crc_table[0][(c ^ *buf++) & 0xff] ^ (c >> 8); - len--; - } - - buf4 = (const z_crc_t FAR *)(const void FAR *)buf; - while (len >= 32) { - DOLIT32; - len -= 32; - } - while (len >= 4) { - DOLIT4; - len -= 4; - } - buf = (const unsigned char FAR *)buf4; - - if (len) do { - c = crc_table[0][(c ^ *buf++) & 0xff] ^ (c >> 8); - } while (--len); - c = ~c; - return (unsigned long)c; -} - -/* ========================================================================= */ -#define DOBIG4 c ^= *++buf4; \ - c = crc_table[4][c & 0xff] ^ crc_table[5][(c >> 8) & 0xff] ^ \ - crc_table[6][(c >> 16) & 0xff] ^ crc_table[7][c >> 24] -#define DOBIG32 DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4; DOBIG4 - -/* ========================================================================= */ -local unsigned long crc32_big(crc, buf, len) - unsigned long crc; - const unsigned char FAR *buf; - unsigned len; -{ - register z_crc_t c; - register const z_crc_t FAR *buf4; - - c = ZSWAP32((z_crc_t)crc); - c = ~c; - while (len && ((ptrdiff_t)buf & 3)) { - c = crc_table[4][(c >> 24) ^ *buf++] ^ (c << 8); - len--; - } - - buf4 = (const z_crc_t FAR *)(const void FAR *)buf; - buf4--; - while (len >= 32) { - DOBIG32; - len -= 32; - } - while (len >= 4) { - DOBIG4; - len -= 4; - } - buf4++; - buf = (const unsigned char FAR *)buf4; - - if (len) do { - c = crc_table[4][(c >> 24) ^ *buf++] ^ (c << 8); - } while (--len); - c = ~c; - return (unsigned long)(ZSWAP32(c)); -} - -#endif /* BYFOUR */ - -#define GF2_DIM 32 /* dimension of GF(2) vectors (length of CRC) */ - -/* ========================================================================= */ -local unsigned long gf2_matrix_times(mat, vec) - unsigned long *mat; - unsigned long vec; -{ - unsigned long sum; - - sum = 0; - while (vec) { - if (vec & 1) - sum ^= *mat; - vec >>= 1; - mat++; - } - return sum; -} - -/* ========================================================================= */ -local void gf2_matrix_square(square, mat) - unsigned long *square; - unsigned long *mat; -{ - int n; - - for (n = 0; n < GF2_DIM; n++) - square[n] = gf2_matrix_times(mat, mat[n]); -} - -/* ========================================================================= */ -local uLong crc32_combine_(crc1, crc2, len2) - uLong crc1; - uLong crc2; - z_off64_t len2; -{ - int n; - unsigned long row; - unsigned long even[GF2_DIM]; /* even-power-of-two zeros operator */ - unsigned long odd[GF2_DIM]; /* odd-power-of-two zeros operator */ - - /* degenerate case (also disallow negative lengths) */ - if (len2 <= 0) - return crc1; - - /* put operator for one zero bit in odd */ - odd[0] = 0xedb88320UL; /* CRC-32 polynomial */ - row = 1; - for (n = 1; n < GF2_DIM; n++) { - odd[n] = row; - row <<= 1; - } - - /* put operator for two zero bits in even */ - gf2_matrix_square(even, odd); - - /* put operator for four zero bits in odd */ - gf2_matrix_square(odd, even); - - /* apply len2 zeros to crc1 (first square will put the operator for one - zero byte, eight zero bits, in even) */ - do { - /* apply zeros operator for this bit of len2 */ - gf2_matrix_square(even, odd); - if (len2 & 1) - crc1 = gf2_matrix_times(even, crc1); - len2 >>= 1; - - /* if no more bits set, then done */ - if (len2 == 0) - break; - - /* another iteration of the loop with odd and even swapped */ - gf2_matrix_square(odd, even); - if (len2 & 1) - crc1 = gf2_matrix_times(odd, crc1); - len2 >>= 1; - - /* if no more bits set, then done */ - } while (len2 != 0); - - /* return combined crc */ - crc1 ^= crc2; - return crc1; -} - -/* ========================================================================= */ -uLong ZEXPORT crc32_combine(crc1, crc2, len2) - uLong crc1; - uLong crc2; - z_off_t len2; -{ - return crc32_combine_(crc1, crc2, len2); -} - -uLong ZEXPORT crc32_combine64(crc1, crc2, len2) - uLong crc1; - uLong crc2; - z_off64_t len2; -{ - return crc32_combine_(crc1, crc2, len2); -} diff --git a/btgui/zlib/crc32.h b/btgui/zlib/crc32.h deleted file mode 100644 index 9e0c77810..000000000 --- a/btgui/zlib/crc32.h +++ /dev/null @@ -1,441 +0,0 @@ -/* crc32.h -- tables for rapid CRC calculation - * Generated automatically by crc32.c - */ - -local const z_crc_t FAR crc_table[TBLS][256] = -{ - { - 0x00000000UL, 0x77073096UL, 0xee0e612cUL, 0x990951baUL, 0x076dc419UL, - 0x706af48fUL, 0xe963a535UL, 0x9e6495a3UL, 0x0edb8832UL, 0x79dcb8a4UL, - 0xe0d5e91eUL, 0x97d2d988UL, 0x09b64c2bUL, 0x7eb17cbdUL, 0xe7b82d07UL, - 0x90bf1d91UL, 0x1db71064UL, 0x6ab020f2UL, 0xf3b97148UL, 0x84be41deUL, - 0x1adad47dUL, 0x6ddde4ebUL, 0xf4d4b551UL, 0x83d385c7UL, 0x136c9856UL, - 0x646ba8c0UL, 0xfd62f97aUL, 0x8a65c9ecUL, 0x14015c4fUL, 0x63066cd9UL, - 0xfa0f3d63UL, 0x8d080df5UL, 0x3b6e20c8UL, 0x4c69105eUL, 0xd56041e4UL, - 0xa2677172UL, 0x3c03e4d1UL, 0x4b04d447UL, 0xd20d85fdUL, 0xa50ab56bUL, - 0x35b5a8faUL, 0x42b2986cUL, 0xdbbbc9d6UL, 0xacbcf940UL, 0x32d86ce3UL, - 0x45df5c75UL, 0xdcd60dcfUL, 0xabd13d59UL, 0x26d930acUL, 0x51de003aUL, - 0xc8d75180UL, 0xbfd06116UL, 0x21b4f4b5UL, 0x56b3c423UL, 0xcfba9599UL, - 0xb8bda50fUL, 0x2802b89eUL, 0x5f058808UL, 0xc60cd9b2UL, 0xb10be924UL, - 0x2f6f7c87UL, 0x58684c11UL, 0xc1611dabUL, 0xb6662d3dUL, 0x76dc4190UL, - 0x01db7106UL, 0x98d220bcUL, 0xefd5102aUL, 0x71b18589UL, 0x06b6b51fUL, - 0x9fbfe4a5UL, 0xe8b8d433UL, 0x7807c9a2UL, 0x0f00f934UL, 0x9609a88eUL, - 0xe10e9818UL, 0x7f6a0dbbUL, 0x086d3d2dUL, 0x91646c97UL, 0xe6635c01UL, - 0x6b6b51f4UL, 0x1c6c6162UL, 0x856530d8UL, 0xf262004eUL, 0x6c0695edUL, - 0x1b01a57bUL, 0x8208f4c1UL, 0xf50fc457UL, 0x65b0d9c6UL, 0x12b7e950UL, - 0x8bbeb8eaUL, 0xfcb9887cUL, 0x62dd1ddfUL, 0x15da2d49UL, 0x8cd37cf3UL, - 0xfbd44c65UL, 0x4db26158UL, 0x3ab551ceUL, 0xa3bc0074UL, 0xd4bb30e2UL, - 0x4adfa541UL, 0x3dd895d7UL, 0xa4d1c46dUL, 0xd3d6f4fbUL, 0x4369e96aUL, - 0x346ed9fcUL, 0xad678846UL, 0xda60b8d0UL, 0x44042d73UL, 0x33031de5UL, - 0xaa0a4c5fUL, 0xdd0d7cc9UL, 0x5005713cUL, 0x270241aaUL, 0xbe0b1010UL, - 0xc90c2086UL, 0x5768b525UL, 0x206f85b3UL, 0xb966d409UL, 0xce61e49fUL, - 0x5edef90eUL, 0x29d9c998UL, 0xb0d09822UL, 0xc7d7a8b4UL, 0x59b33d17UL, - 0x2eb40d81UL, 0xb7bd5c3bUL, 0xc0ba6cadUL, 0xedb88320UL, 0x9abfb3b6UL, - 0x03b6e20cUL, 0x74b1d29aUL, 0xead54739UL, 0x9dd277afUL, 0x04db2615UL, - 0x73dc1683UL, 0xe3630b12UL, 0x94643b84UL, 0x0d6d6a3eUL, 0x7a6a5aa8UL, - 0xe40ecf0bUL, 0x9309ff9dUL, 0x0a00ae27UL, 0x7d079eb1UL, 0xf00f9344UL, - 0x8708a3d2UL, 0x1e01f268UL, 0x6906c2feUL, 0xf762575dUL, 0x806567cbUL, - 0x196c3671UL, 0x6e6b06e7UL, 0xfed41b76UL, 0x89d32be0UL, 0x10da7a5aUL, - 0x67dd4accUL, 0xf9b9df6fUL, 0x8ebeeff9UL, 0x17b7be43UL, 0x60b08ed5UL, - 0xd6d6a3e8UL, 0xa1d1937eUL, 0x38d8c2c4UL, 0x4fdff252UL, 0xd1bb67f1UL, - 0xa6bc5767UL, 0x3fb506ddUL, 0x48b2364bUL, 0xd80d2bdaUL, 0xaf0a1b4cUL, - 0x36034af6UL, 0x41047a60UL, 0xdf60efc3UL, 0xa867df55UL, 0x316e8eefUL, - 0x4669be79UL, 0xcb61b38cUL, 0xbc66831aUL, 0x256fd2a0UL, 0x5268e236UL, - 0xcc0c7795UL, 0xbb0b4703UL, 0x220216b9UL, 0x5505262fUL, 0xc5ba3bbeUL, - 0xb2bd0b28UL, 0x2bb45a92UL, 0x5cb36a04UL, 0xc2d7ffa7UL, 0xb5d0cf31UL, - 0x2cd99e8bUL, 0x5bdeae1dUL, 0x9b64c2b0UL, 0xec63f226UL, 0x756aa39cUL, - 0x026d930aUL, 0x9c0906a9UL, 0xeb0e363fUL, 0x72076785UL, 0x05005713UL, - 0x95bf4a82UL, 0xe2b87a14UL, 0x7bb12baeUL, 0x0cb61b38UL, 0x92d28e9bUL, - 0xe5d5be0dUL, 0x7cdcefb7UL, 0x0bdbdf21UL, 0x86d3d2d4UL, 0xf1d4e242UL, - 0x68ddb3f8UL, 0x1fda836eUL, 0x81be16cdUL, 0xf6b9265bUL, 0x6fb077e1UL, - 0x18b74777UL, 0x88085ae6UL, 0xff0f6a70UL, 0x66063bcaUL, 0x11010b5cUL, - 0x8f659effUL, 0xf862ae69UL, 0x616bffd3UL, 0x166ccf45UL, 0xa00ae278UL, - 0xd70dd2eeUL, 0x4e048354UL, 0x3903b3c2UL, 0xa7672661UL, 0xd06016f7UL, - 0x4969474dUL, 0x3e6e77dbUL, 0xaed16a4aUL, 0xd9d65adcUL, 0x40df0b66UL, - 0x37d83bf0UL, 0xa9bcae53UL, 0xdebb9ec5UL, 0x47b2cf7fUL, 0x30b5ffe9UL, - 0xbdbdf21cUL, 0xcabac28aUL, 0x53b39330UL, 0x24b4a3a6UL, 0xbad03605UL, - 0xcdd70693UL, 0x54de5729UL, 0x23d967bfUL, 0xb3667a2eUL, 0xc4614ab8UL, - 0x5d681b02UL, 0x2a6f2b94UL, 0xb40bbe37UL, 0xc30c8ea1UL, 0x5a05df1bUL, - 0x2d02ef8dUL -#ifdef BYFOUR - }, - { - 0x00000000UL, 0x191b3141UL, 0x32366282UL, 0x2b2d53c3UL, 0x646cc504UL, - 0x7d77f445UL, 0x565aa786UL, 0x4f4196c7UL, 0xc8d98a08UL, 0xd1c2bb49UL, - 0xfaefe88aUL, 0xe3f4d9cbUL, 0xacb54f0cUL, 0xb5ae7e4dUL, 0x9e832d8eUL, - 0x87981ccfUL, 0x4ac21251UL, 0x53d92310UL, 0x78f470d3UL, 0x61ef4192UL, - 0x2eaed755UL, 0x37b5e614UL, 0x1c98b5d7UL, 0x05838496UL, 0x821b9859UL, - 0x9b00a918UL, 0xb02dfadbUL, 0xa936cb9aUL, 0xe6775d5dUL, 0xff6c6c1cUL, - 0xd4413fdfUL, 0xcd5a0e9eUL, 0x958424a2UL, 0x8c9f15e3UL, 0xa7b24620UL, - 0xbea97761UL, 0xf1e8e1a6UL, 0xe8f3d0e7UL, 0xc3de8324UL, 0xdac5b265UL, - 0x5d5daeaaUL, 0x44469febUL, 0x6f6bcc28UL, 0x7670fd69UL, 0x39316baeUL, - 0x202a5aefUL, 0x0b07092cUL, 0x121c386dUL, 0xdf4636f3UL, 0xc65d07b2UL, - 0xed705471UL, 0xf46b6530UL, 0xbb2af3f7UL, 0xa231c2b6UL, 0x891c9175UL, - 0x9007a034UL, 0x179fbcfbUL, 0x0e848dbaUL, 0x25a9de79UL, 0x3cb2ef38UL, - 0x73f379ffUL, 0x6ae848beUL, 0x41c51b7dUL, 0x58de2a3cUL, 0xf0794f05UL, - 0xe9627e44UL, 0xc24f2d87UL, 0xdb541cc6UL, 0x94158a01UL, 0x8d0ebb40UL, - 0xa623e883UL, 0xbf38d9c2UL, 0x38a0c50dUL, 0x21bbf44cUL, 0x0a96a78fUL, - 0x138d96ceUL, 0x5ccc0009UL, 0x45d73148UL, 0x6efa628bUL, 0x77e153caUL, - 0xbabb5d54UL, 0xa3a06c15UL, 0x888d3fd6UL, 0x91960e97UL, 0xded79850UL, - 0xc7cca911UL, 0xece1fad2UL, 0xf5facb93UL, 0x7262d75cUL, 0x6b79e61dUL, - 0x4054b5deUL, 0x594f849fUL, 0x160e1258UL, 0x0f152319UL, 0x243870daUL, - 0x3d23419bUL, 0x65fd6ba7UL, 0x7ce65ae6UL, 0x57cb0925UL, 0x4ed03864UL, - 0x0191aea3UL, 0x188a9fe2UL, 0x33a7cc21UL, 0x2abcfd60UL, 0xad24e1afUL, - 0xb43fd0eeUL, 0x9f12832dUL, 0x8609b26cUL, 0xc94824abUL, 0xd05315eaUL, - 0xfb7e4629UL, 0xe2657768UL, 0x2f3f79f6UL, 0x362448b7UL, 0x1d091b74UL, - 0x04122a35UL, 0x4b53bcf2UL, 0x52488db3UL, 0x7965de70UL, 0x607eef31UL, - 0xe7e6f3feUL, 0xfefdc2bfUL, 0xd5d0917cUL, 0xcccba03dUL, 0x838a36faUL, - 0x9a9107bbUL, 0xb1bc5478UL, 0xa8a76539UL, 0x3b83984bUL, 0x2298a90aUL, - 0x09b5fac9UL, 0x10aecb88UL, 0x5fef5d4fUL, 0x46f46c0eUL, 0x6dd93fcdUL, - 0x74c20e8cUL, 0xf35a1243UL, 0xea412302UL, 0xc16c70c1UL, 0xd8774180UL, - 0x9736d747UL, 0x8e2de606UL, 0xa500b5c5UL, 0xbc1b8484UL, 0x71418a1aUL, - 0x685abb5bUL, 0x4377e898UL, 0x5a6cd9d9UL, 0x152d4f1eUL, 0x0c367e5fUL, - 0x271b2d9cUL, 0x3e001cddUL, 0xb9980012UL, 0xa0833153UL, 0x8bae6290UL, - 0x92b553d1UL, 0xddf4c516UL, 0xc4eff457UL, 0xefc2a794UL, 0xf6d996d5UL, - 0xae07bce9UL, 0xb71c8da8UL, 0x9c31de6bUL, 0x852aef2aUL, 0xca6b79edUL, - 0xd37048acUL, 0xf85d1b6fUL, 0xe1462a2eUL, 0x66de36e1UL, 0x7fc507a0UL, - 0x54e85463UL, 0x4df36522UL, 0x02b2f3e5UL, 0x1ba9c2a4UL, 0x30849167UL, - 0x299fa026UL, 0xe4c5aeb8UL, 0xfdde9ff9UL, 0xd6f3cc3aUL, 0xcfe8fd7bUL, - 0x80a96bbcUL, 0x99b25afdUL, 0xb29f093eUL, 0xab84387fUL, 0x2c1c24b0UL, - 0x350715f1UL, 0x1e2a4632UL, 0x07317773UL, 0x4870e1b4UL, 0x516bd0f5UL, - 0x7a468336UL, 0x635db277UL, 0xcbfad74eUL, 0xd2e1e60fUL, 0xf9ccb5ccUL, - 0xe0d7848dUL, 0xaf96124aUL, 0xb68d230bUL, 0x9da070c8UL, 0x84bb4189UL, - 0x03235d46UL, 0x1a386c07UL, 0x31153fc4UL, 0x280e0e85UL, 0x674f9842UL, - 0x7e54a903UL, 0x5579fac0UL, 0x4c62cb81UL, 0x8138c51fUL, 0x9823f45eUL, - 0xb30ea79dUL, 0xaa1596dcUL, 0xe554001bUL, 0xfc4f315aUL, 0xd7626299UL, - 0xce7953d8UL, 0x49e14f17UL, 0x50fa7e56UL, 0x7bd72d95UL, 0x62cc1cd4UL, - 0x2d8d8a13UL, 0x3496bb52UL, 0x1fbbe891UL, 0x06a0d9d0UL, 0x5e7ef3ecUL, - 0x4765c2adUL, 0x6c48916eUL, 0x7553a02fUL, 0x3a1236e8UL, 0x230907a9UL, - 0x0824546aUL, 0x113f652bUL, 0x96a779e4UL, 0x8fbc48a5UL, 0xa4911b66UL, - 0xbd8a2a27UL, 0xf2cbbce0UL, 0xebd08da1UL, 0xc0fdde62UL, 0xd9e6ef23UL, - 0x14bce1bdUL, 0x0da7d0fcUL, 0x268a833fUL, 0x3f91b27eUL, 0x70d024b9UL, - 0x69cb15f8UL, 0x42e6463bUL, 0x5bfd777aUL, 0xdc656bb5UL, 0xc57e5af4UL, - 0xee530937UL, 0xf7483876UL, 0xb809aeb1UL, 0xa1129ff0UL, 0x8a3fcc33UL, - 0x9324fd72UL - }, - { - 0x00000000UL, 0x01c26a37UL, 0x0384d46eUL, 0x0246be59UL, 0x0709a8dcUL, - 0x06cbc2ebUL, 0x048d7cb2UL, 0x054f1685UL, 0x0e1351b8UL, 0x0fd13b8fUL, - 0x0d9785d6UL, 0x0c55efe1UL, 0x091af964UL, 0x08d89353UL, 0x0a9e2d0aUL, - 0x0b5c473dUL, 0x1c26a370UL, 0x1de4c947UL, 0x1fa2771eUL, 0x1e601d29UL, - 0x1b2f0bacUL, 0x1aed619bUL, 0x18abdfc2UL, 0x1969b5f5UL, 0x1235f2c8UL, - 0x13f798ffUL, 0x11b126a6UL, 0x10734c91UL, 0x153c5a14UL, 0x14fe3023UL, - 0x16b88e7aUL, 0x177ae44dUL, 0x384d46e0UL, 0x398f2cd7UL, 0x3bc9928eUL, - 0x3a0bf8b9UL, 0x3f44ee3cUL, 0x3e86840bUL, 0x3cc03a52UL, 0x3d025065UL, - 0x365e1758UL, 0x379c7d6fUL, 0x35dac336UL, 0x3418a901UL, 0x3157bf84UL, - 0x3095d5b3UL, 0x32d36beaUL, 0x331101ddUL, 0x246be590UL, 0x25a98fa7UL, - 0x27ef31feUL, 0x262d5bc9UL, 0x23624d4cUL, 0x22a0277bUL, 0x20e69922UL, - 0x2124f315UL, 0x2a78b428UL, 0x2bbade1fUL, 0x29fc6046UL, 0x283e0a71UL, - 0x2d711cf4UL, 0x2cb376c3UL, 0x2ef5c89aUL, 0x2f37a2adUL, 0x709a8dc0UL, - 0x7158e7f7UL, 0x731e59aeUL, 0x72dc3399UL, 0x7793251cUL, 0x76514f2bUL, - 0x7417f172UL, 0x75d59b45UL, 0x7e89dc78UL, 0x7f4bb64fUL, 0x7d0d0816UL, - 0x7ccf6221UL, 0x798074a4UL, 0x78421e93UL, 0x7a04a0caUL, 0x7bc6cafdUL, - 0x6cbc2eb0UL, 0x6d7e4487UL, 0x6f38fadeUL, 0x6efa90e9UL, 0x6bb5866cUL, - 0x6a77ec5bUL, 0x68315202UL, 0x69f33835UL, 0x62af7f08UL, 0x636d153fUL, - 0x612bab66UL, 0x60e9c151UL, 0x65a6d7d4UL, 0x6464bde3UL, 0x662203baUL, - 0x67e0698dUL, 0x48d7cb20UL, 0x4915a117UL, 0x4b531f4eUL, 0x4a917579UL, - 0x4fde63fcUL, 0x4e1c09cbUL, 0x4c5ab792UL, 0x4d98dda5UL, 0x46c49a98UL, - 0x4706f0afUL, 0x45404ef6UL, 0x448224c1UL, 0x41cd3244UL, 0x400f5873UL, - 0x4249e62aUL, 0x438b8c1dUL, 0x54f16850UL, 0x55330267UL, 0x5775bc3eUL, - 0x56b7d609UL, 0x53f8c08cUL, 0x523aaabbUL, 0x507c14e2UL, 0x51be7ed5UL, - 0x5ae239e8UL, 0x5b2053dfUL, 0x5966ed86UL, 0x58a487b1UL, 0x5deb9134UL, - 0x5c29fb03UL, 0x5e6f455aUL, 0x5fad2f6dUL, 0xe1351b80UL, 0xe0f771b7UL, - 0xe2b1cfeeUL, 0xe373a5d9UL, 0xe63cb35cUL, 0xe7fed96bUL, 0xe5b86732UL, - 0xe47a0d05UL, 0xef264a38UL, 0xeee4200fUL, 0xeca29e56UL, 0xed60f461UL, - 0xe82fe2e4UL, 0xe9ed88d3UL, 0xebab368aUL, 0xea695cbdUL, 0xfd13b8f0UL, - 0xfcd1d2c7UL, 0xfe976c9eUL, 0xff5506a9UL, 0xfa1a102cUL, 0xfbd87a1bUL, - 0xf99ec442UL, 0xf85cae75UL, 0xf300e948UL, 0xf2c2837fUL, 0xf0843d26UL, - 0xf1465711UL, 0xf4094194UL, 0xf5cb2ba3UL, 0xf78d95faUL, 0xf64fffcdUL, - 0xd9785d60UL, 0xd8ba3757UL, 0xdafc890eUL, 0xdb3ee339UL, 0xde71f5bcUL, - 0xdfb39f8bUL, 0xddf521d2UL, 0xdc374be5UL, 0xd76b0cd8UL, 0xd6a966efUL, - 0xd4efd8b6UL, 0xd52db281UL, 0xd062a404UL, 0xd1a0ce33UL, 0xd3e6706aUL, - 0xd2241a5dUL, 0xc55efe10UL, 0xc49c9427UL, 0xc6da2a7eUL, 0xc7184049UL, - 0xc25756ccUL, 0xc3953cfbUL, 0xc1d382a2UL, 0xc011e895UL, 0xcb4dafa8UL, - 0xca8fc59fUL, 0xc8c97bc6UL, 0xc90b11f1UL, 0xcc440774UL, 0xcd866d43UL, - 0xcfc0d31aUL, 0xce02b92dUL, 0x91af9640UL, 0x906dfc77UL, 0x922b422eUL, - 0x93e92819UL, 0x96a63e9cUL, 0x976454abUL, 0x9522eaf2UL, 0x94e080c5UL, - 0x9fbcc7f8UL, 0x9e7eadcfUL, 0x9c381396UL, 0x9dfa79a1UL, 0x98b56f24UL, - 0x99770513UL, 0x9b31bb4aUL, 0x9af3d17dUL, 0x8d893530UL, 0x8c4b5f07UL, - 0x8e0de15eUL, 0x8fcf8b69UL, 0x8a809decUL, 0x8b42f7dbUL, 0x89044982UL, - 0x88c623b5UL, 0x839a6488UL, 0x82580ebfUL, 0x801eb0e6UL, 0x81dcdad1UL, - 0x8493cc54UL, 0x8551a663UL, 0x8717183aUL, 0x86d5720dUL, 0xa9e2d0a0UL, - 0xa820ba97UL, 0xaa6604ceUL, 0xaba46ef9UL, 0xaeeb787cUL, 0xaf29124bUL, - 0xad6fac12UL, 0xacadc625UL, 0xa7f18118UL, 0xa633eb2fUL, 0xa4755576UL, - 0xa5b73f41UL, 0xa0f829c4UL, 0xa13a43f3UL, 0xa37cfdaaUL, 0xa2be979dUL, - 0xb5c473d0UL, 0xb40619e7UL, 0xb640a7beUL, 0xb782cd89UL, 0xb2cddb0cUL, - 0xb30fb13bUL, 0xb1490f62UL, 0xb08b6555UL, 0xbbd72268UL, 0xba15485fUL, - 0xb853f606UL, 0xb9919c31UL, 0xbcde8ab4UL, 0xbd1ce083UL, 0xbf5a5edaUL, - 0xbe9834edUL - }, - { - 0x00000000UL, 0xb8bc6765UL, 0xaa09c88bUL, 0x12b5afeeUL, 0x8f629757UL, - 0x37def032UL, 0x256b5fdcUL, 0x9dd738b9UL, 0xc5b428efUL, 0x7d084f8aUL, - 0x6fbde064UL, 0xd7018701UL, 0x4ad6bfb8UL, 0xf26ad8ddUL, 0xe0df7733UL, - 0x58631056UL, 0x5019579fUL, 0xe8a530faUL, 0xfa109f14UL, 0x42acf871UL, - 0xdf7bc0c8UL, 0x67c7a7adUL, 0x75720843UL, 0xcdce6f26UL, 0x95ad7f70UL, - 0x2d111815UL, 0x3fa4b7fbUL, 0x8718d09eUL, 0x1acfe827UL, 0xa2738f42UL, - 0xb0c620acUL, 0x087a47c9UL, 0xa032af3eUL, 0x188ec85bUL, 0x0a3b67b5UL, - 0xb28700d0UL, 0x2f503869UL, 0x97ec5f0cUL, 0x8559f0e2UL, 0x3de59787UL, - 0x658687d1UL, 0xdd3ae0b4UL, 0xcf8f4f5aUL, 0x7733283fUL, 0xeae41086UL, - 0x525877e3UL, 0x40edd80dUL, 0xf851bf68UL, 0xf02bf8a1UL, 0x48979fc4UL, - 0x5a22302aUL, 0xe29e574fUL, 0x7f496ff6UL, 0xc7f50893UL, 0xd540a77dUL, - 0x6dfcc018UL, 0x359fd04eUL, 0x8d23b72bUL, 0x9f9618c5UL, 0x272a7fa0UL, - 0xbafd4719UL, 0x0241207cUL, 0x10f48f92UL, 0xa848e8f7UL, 0x9b14583dUL, - 0x23a83f58UL, 0x311d90b6UL, 0x89a1f7d3UL, 0x1476cf6aUL, 0xaccaa80fUL, - 0xbe7f07e1UL, 0x06c36084UL, 0x5ea070d2UL, 0xe61c17b7UL, 0xf4a9b859UL, - 0x4c15df3cUL, 0xd1c2e785UL, 0x697e80e0UL, 0x7bcb2f0eUL, 0xc377486bUL, - 0xcb0d0fa2UL, 0x73b168c7UL, 0x6104c729UL, 0xd9b8a04cUL, 0x446f98f5UL, - 0xfcd3ff90UL, 0xee66507eUL, 0x56da371bUL, 0x0eb9274dUL, 0xb6054028UL, - 0xa4b0efc6UL, 0x1c0c88a3UL, 0x81dbb01aUL, 0x3967d77fUL, 0x2bd27891UL, - 0x936e1ff4UL, 0x3b26f703UL, 0x839a9066UL, 0x912f3f88UL, 0x299358edUL, - 0xb4446054UL, 0x0cf80731UL, 0x1e4da8dfUL, 0xa6f1cfbaUL, 0xfe92dfecUL, - 0x462eb889UL, 0x549b1767UL, 0xec277002UL, 0x71f048bbUL, 0xc94c2fdeUL, - 0xdbf98030UL, 0x6345e755UL, 0x6b3fa09cUL, 0xd383c7f9UL, 0xc1366817UL, - 0x798a0f72UL, 0xe45d37cbUL, 0x5ce150aeUL, 0x4e54ff40UL, 0xf6e89825UL, - 0xae8b8873UL, 0x1637ef16UL, 0x048240f8UL, 0xbc3e279dUL, 0x21e91f24UL, - 0x99557841UL, 0x8be0d7afUL, 0x335cb0caUL, 0xed59b63bUL, 0x55e5d15eUL, - 0x47507eb0UL, 0xffec19d5UL, 0x623b216cUL, 0xda874609UL, 0xc832e9e7UL, - 0x708e8e82UL, 0x28ed9ed4UL, 0x9051f9b1UL, 0x82e4565fUL, 0x3a58313aUL, - 0xa78f0983UL, 0x1f336ee6UL, 0x0d86c108UL, 0xb53aa66dUL, 0xbd40e1a4UL, - 0x05fc86c1UL, 0x1749292fUL, 0xaff54e4aUL, 0x322276f3UL, 0x8a9e1196UL, - 0x982bbe78UL, 0x2097d91dUL, 0x78f4c94bUL, 0xc048ae2eUL, 0xd2fd01c0UL, - 0x6a4166a5UL, 0xf7965e1cUL, 0x4f2a3979UL, 0x5d9f9697UL, 0xe523f1f2UL, - 0x4d6b1905UL, 0xf5d77e60UL, 0xe762d18eUL, 0x5fdeb6ebUL, 0xc2098e52UL, - 0x7ab5e937UL, 0x680046d9UL, 0xd0bc21bcUL, 0x88df31eaUL, 0x3063568fUL, - 0x22d6f961UL, 0x9a6a9e04UL, 0x07bda6bdUL, 0xbf01c1d8UL, 0xadb46e36UL, - 0x15080953UL, 0x1d724e9aUL, 0xa5ce29ffUL, 0xb77b8611UL, 0x0fc7e174UL, - 0x9210d9cdUL, 0x2aacbea8UL, 0x38191146UL, 0x80a57623UL, 0xd8c66675UL, - 0x607a0110UL, 0x72cfaefeUL, 0xca73c99bUL, 0x57a4f122UL, 0xef189647UL, - 0xfdad39a9UL, 0x45115eccUL, 0x764dee06UL, 0xcef18963UL, 0xdc44268dUL, - 0x64f841e8UL, 0xf92f7951UL, 0x41931e34UL, 0x5326b1daUL, 0xeb9ad6bfUL, - 0xb3f9c6e9UL, 0x0b45a18cUL, 0x19f00e62UL, 0xa14c6907UL, 0x3c9b51beUL, - 0x842736dbUL, 0x96929935UL, 0x2e2efe50UL, 0x2654b999UL, 0x9ee8defcUL, - 0x8c5d7112UL, 0x34e11677UL, 0xa9362eceUL, 0x118a49abUL, 0x033fe645UL, - 0xbb838120UL, 0xe3e09176UL, 0x5b5cf613UL, 0x49e959fdUL, 0xf1553e98UL, - 0x6c820621UL, 0xd43e6144UL, 0xc68bceaaUL, 0x7e37a9cfUL, 0xd67f4138UL, - 0x6ec3265dUL, 0x7c7689b3UL, 0xc4caeed6UL, 0x591dd66fUL, 0xe1a1b10aUL, - 0xf3141ee4UL, 0x4ba87981UL, 0x13cb69d7UL, 0xab770eb2UL, 0xb9c2a15cUL, - 0x017ec639UL, 0x9ca9fe80UL, 0x241599e5UL, 0x36a0360bUL, 0x8e1c516eUL, - 0x866616a7UL, 0x3eda71c2UL, 0x2c6fde2cUL, 0x94d3b949UL, 0x090481f0UL, - 0xb1b8e695UL, 0xa30d497bUL, 0x1bb12e1eUL, 0x43d23e48UL, 0xfb6e592dUL, - 0xe9dbf6c3UL, 0x516791a6UL, 0xccb0a91fUL, 0x740cce7aUL, 0x66b96194UL, - 0xde0506f1UL - }, - { - 0x00000000UL, 0x96300777UL, 0x2c610eeeUL, 0xba510999UL, 0x19c46d07UL, - 0x8ff46a70UL, 0x35a563e9UL, 0xa395649eUL, 0x3288db0eUL, 0xa4b8dc79UL, - 0x1ee9d5e0UL, 0x88d9d297UL, 0x2b4cb609UL, 0xbd7cb17eUL, 0x072db8e7UL, - 0x911dbf90UL, 0x6410b71dUL, 0xf220b06aUL, 0x4871b9f3UL, 0xde41be84UL, - 0x7dd4da1aUL, 0xebe4dd6dUL, 0x51b5d4f4UL, 0xc785d383UL, 0x56986c13UL, - 0xc0a86b64UL, 0x7af962fdUL, 0xecc9658aUL, 0x4f5c0114UL, 0xd96c0663UL, - 0x633d0ffaUL, 0xf50d088dUL, 0xc8206e3bUL, 0x5e10694cUL, 0xe44160d5UL, - 0x727167a2UL, 0xd1e4033cUL, 0x47d4044bUL, 0xfd850dd2UL, 0x6bb50aa5UL, - 0xfaa8b535UL, 0x6c98b242UL, 0xd6c9bbdbUL, 0x40f9bcacUL, 0xe36cd832UL, - 0x755cdf45UL, 0xcf0dd6dcUL, 0x593dd1abUL, 0xac30d926UL, 0x3a00de51UL, - 0x8051d7c8UL, 0x1661d0bfUL, 0xb5f4b421UL, 0x23c4b356UL, 0x9995bacfUL, - 0x0fa5bdb8UL, 0x9eb80228UL, 0x0888055fUL, 0xb2d90cc6UL, 0x24e90bb1UL, - 0x877c6f2fUL, 0x114c6858UL, 0xab1d61c1UL, 0x3d2d66b6UL, 0x9041dc76UL, - 0x0671db01UL, 0xbc20d298UL, 0x2a10d5efUL, 0x8985b171UL, 0x1fb5b606UL, - 0xa5e4bf9fUL, 0x33d4b8e8UL, 0xa2c90778UL, 0x34f9000fUL, 0x8ea80996UL, - 0x18980ee1UL, 0xbb0d6a7fUL, 0x2d3d6d08UL, 0x976c6491UL, 0x015c63e6UL, - 0xf4516b6bUL, 0x62616c1cUL, 0xd8306585UL, 0x4e0062f2UL, 0xed95066cUL, - 0x7ba5011bUL, 0xc1f40882UL, 0x57c40ff5UL, 0xc6d9b065UL, 0x50e9b712UL, - 0xeab8be8bUL, 0x7c88b9fcUL, 0xdf1ddd62UL, 0x492dda15UL, 0xf37cd38cUL, - 0x654cd4fbUL, 0x5861b24dUL, 0xce51b53aUL, 0x7400bca3UL, 0xe230bbd4UL, - 0x41a5df4aUL, 0xd795d83dUL, 0x6dc4d1a4UL, 0xfbf4d6d3UL, 0x6ae96943UL, - 0xfcd96e34UL, 0x468867adUL, 0xd0b860daUL, 0x732d0444UL, 0xe51d0333UL, - 0x5f4c0aaaUL, 0xc97c0dddUL, 0x3c710550UL, 0xaa410227UL, 0x10100bbeUL, - 0x86200cc9UL, 0x25b56857UL, 0xb3856f20UL, 0x09d466b9UL, 0x9fe461ceUL, - 0x0ef9de5eUL, 0x98c9d929UL, 0x2298d0b0UL, 0xb4a8d7c7UL, 0x173db359UL, - 0x810db42eUL, 0x3b5cbdb7UL, 0xad6cbac0UL, 0x2083b8edUL, 0xb6b3bf9aUL, - 0x0ce2b603UL, 0x9ad2b174UL, 0x3947d5eaUL, 0xaf77d29dUL, 0x1526db04UL, - 0x8316dc73UL, 0x120b63e3UL, 0x843b6494UL, 0x3e6a6d0dUL, 0xa85a6a7aUL, - 0x0bcf0ee4UL, 0x9dff0993UL, 0x27ae000aUL, 0xb19e077dUL, 0x44930ff0UL, - 0xd2a30887UL, 0x68f2011eUL, 0xfec20669UL, 0x5d5762f7UL, 0xcb676580UL, - 0x71366c19UL, 0xe7066b6eUL, 0x761bd4feUL, 0xe02bd389UL, 0x5a7ada10UL, - 0xcc4add67UL, 0x6fdfb9f9UL, 0xf9efbe8eUL, 0x43beb717UL, 0xd58eb060UL, - 0xe8a3d6d6UL, 0x7e93d1a1UL, 0xc4c2d838UL, 0x52f2df4fUL, 0xf167bbd1UL, - 0x6757bca6UL, 0xdd06b53fUL, 0x4b36b248UL, 0xda2b0dd8UL, 0x4c1b0aafUL, - 0xf64a0336UL, 0x607a0441UL, 0xc3ef60dfUL, 0x55df67a8UL, 0xef8e6e31UL, - 0x79be6946UL, 0x8cb361cbUL, 0x1a8366bcUL, 0xa0d26f25UL, 0x36e26852UL, - 0x95770cccUL, 0x03470bbbUL, 0xb9160222UL, 0x2f260555UL, 0xbe3bbac5UL, - 0x280bbdb2UL, 0x925ab42bUL, 0x046ab35cUL, 0xa7ffd7c2UL, 0x31cfd0b5UL, - 0x8b9ed92cUL, 0x1daede5bUL, 0xb0c2649bUL, 0x26f263ecUL, 0x9ca36a75UL, - 0x0a936d02UL, 0xa906099cUL, 0x3f360eebUL, 0x85670772UL, 0x13570005UL, - 0x824abf95UL, 0x147ab8e2UL, 0xae2bb17bUL, 0x381bb60cUL, 0x9b8ed292UL, - 0x0dbed5e5UL, 0xb7efdc7cUL, 0x21dfdb0bUL, 0xd4d2d386UL, 0x42e2d4f1UL, - 0xf8b3dd68UL, 0x6e83da1fUL, 0xcd16be81UL, 0x5b26b9f6UL, 0xe177b06fUL, - 0x7747b718UL, 0xe65a0888UL, 0x706a0fffUL, 0xca3b0666UL, 0x5c0b0111UL, - 0xff9e658fUL, 0x69ae62f8UL, 0xd3ff6b61UL, 0x45cf6c16UL, 0x78e20aa0UL, - 0xeed20dd7UL, 0x5483044eUL, 0xc2b30339UL, 0x612667a7UL, 0xf71660d0UL, - 0x4d476949UL, 0xdb776e3eUL, 0x4a6ad1aeUL, 0xdc5ad6d9UL, 0x660bdf40UL, - 0xf03bd837UL, 0x53aebca9UL, 0xc59ebbdeUL, 0x7fcfb247UL, 0xe9ffb530UL, - 0x1cf2bdbdUL, 0x8ac2bacaUL, 0x3093b353UL, 0xa6a3b424UL, 0x0536d0baUL, - 0x9306d7cdUL, 0x2957de54UL, 0xbf67d923UL, 0x2e7a66b3UL, 0xb84a61c4UL, - 0x021b685dUL, 0x942b6f2aUL, 0x37be0bb4UL, 0xa18e0cc3UL, 0x1bdf055aUL, - 0x8def022dUL - }, - { - 0x00000000UL, 0x41311b19UL, 0x82623632UL, 0xc3532d2bUL, 0x04c56c64UL, - 0x45f4777dUL, 0x86a75a56UL, 0xc796414fUL, 0x088ad9c8UL, 0x49bbc2d1UL, - 0x8ae8effaUL, 0xcbd9f4e3UL, 0x0c4fb5acUL, 0x4d7eaeb5UL, 0x8e2d839eUL, - 0xcf1c9887UL, 0x5112c24aUL, 0x1023d953UL, 0xd370f478UL, 0x9241ef61UL, - 0x55d7ae2eUL, 0x14e6b537UL, 0xd7b5981cUL, 0x96848305UL, 0x59981b82UL, - 0x18a9009bUL, 0xdbfa2db0UL, 0x9acb36a9UL, 0x5d5d77e6UL, 0x1c6c6cffUL, - 0xdf3f41d4UL, 0x9e0e5acdUL, 0xa2248495UL, 0xe3159f8cUL, 0x2046b2a7UL, - 0x6177a9beUL, 0xa6e1e8f1UL, 0xe7d0f3e8UL, 0x2483dec3UL, 0x65b2c5daUL, - 0xaaae5d5dUL, 0xeb9f4644UL, 0x28cc6b6fUL, 0x69fd7076UL, 0xae6b3139UL, - 0xef5a2a20UL, 0x2c09070bUL, 0x6d381c12UL, 0xf33646dfUL, 0xb2075dc6UL, - 0x715470edUL, 0x30656bf4UL, 0xf7f32abbUL, 0xb6c231a2UL, 0x75911c89UL, - 0x34a00790UL, 0xfbbc9f17UL, 0xba8d840eUL, 0x79dea925UL, 0x38efb23cUL, - 0xff79f373UL, 0xbe48e86aUL, 0x7d1bc541UL, 0x3c2ade58UL, 0x054f79f0UL, - 0x447e62e9UL, 0x872d4fc2UL, 0xc61c54dbUL, 0x018a1594UL, 0x40bb0e8dUL, - 0x83e823a6UL, 0xc2d938bfUL, 0x0dc5a038UL, 0x4cf4bb21UL, 0x8fa7960aUL, - 0xce968d13UL, 0x0900cc5cUL, 0x4831d745UL, 0x8b62fa6eUL, 0xca53e177UL, - 0x545dbbbaUL, 0x156ca0a3UL, 0xd63f8d88UL, 0x970e9691UL, 0x5098d7deUL, - 0x11a9ccc7UL, 0xd2fae1ecUL, 0x93cbfaf5UL, 0x5cd76272UL, 0x1de6796bUL, - 0xdeb55440UL, 0x9f844f59UL, 0x58120e16UL, 0x1923150fUL, 0xda703824UL, - 0x9b41233dUL, 0xa76bfd65UL, 0xe65ae67cUL, 0x2509cb57UL, 0x6438d04eUL, - 0xa3ae9101UL, 0xe29f8a18UL, 0x21cca733UL, 0x60fdbc2aUL, 0xafe124adUL, - 0xeed03fb4UL, 0x2d83129fUL, 0x6cb20986UL, 0xab2448c9UL, 0xea1553d0UL, - 0x29467efbUL, 0x687765e2UL, 0xf6793f2fUL, 0xb7482436UL, 0x741b091dUL, - 0x352a1204UL, 0xf2bc534bUL, 0xb38d4852UL, 0x70de6579UL, 0x31ef7e60UL, - 0xfef3e6e7UL, 0xbfc2fdfeUL, 0x7c91d0d5UL, 0x3da0cbccUL, 0xfa368a83UL, - 0xbb07919aUL, 0x7854bcb1UL, 0x3965a7a8UL, 0x4b98833bUL, 0x0aa99822UL, - 0xc9fab509UL, 0x88cbae10UL, 0x4f5def5fUL, 0x0e6cf446UL, 0xcd3fd96dUL, - 0x8c0ec274UL, 0x43125af3UL, 0x022341eaUL, 0xc1706cc1UL, 0x804177d8UL, - 0x47d73697UL, 0x06e62d8eUL, 0xc5b500a5UL, 0x84841bbcUL, 0x1a8a4171UL, - 0x5bbb5a68UL, 0x98e87743UL, 0xd9d96c5aUL, 0x1e4f2d15UL, 0x5f7e360cUL, - 0x9c2d1b27UL, 0xdd1c003eUL, 0x120098b9UL, 0x533183a0UL, 0x9062ae8bUL, - 0xd153b592UL, 0x16c5f4ddUL, 0x57f4efc4UL, 0x94a7c2efUL, 0xd596d9f6UL, - 0xe9bc07aeUL, 0xa88d1cb7UL, 0x6bde319cUL, 0x2aef2a85UL, 0xed796bcaUL, - 0xac4870d3UL, 0x6f1b5df8UL, 0x2e2a46e1UL, 0xe136de66UL, 0xa007c57fUL, - 0x6354e854UL, 0x2265f34dUL, 0xe5f3b202UL, 0xa4c2a91bUL, 0x67918430UL, - 0x26a09f29UL, 0xb8aec5e4UL, 0xf99fdefdUL, 0x3accf3d6UL, 0x7bfde8cfUL, - 0xbc6ba980UL, 0xfd5ab299UL, 0x3e099fb2UL, 0x7f3884abUL, 0xb0241c2cUL, - 0xf1150735UL, 0x32462a1eUL, 0x73773107UL, 0xb4e17048UL, 0xf5d06b51UL, - 0x3683467aUL, 0x77b25d63UL, 0x4ed7facbUL, 0x0fe6e1d2UL, 0xccb5ccf9UL, - 0x8d84d7e0UL, 0x4a1296afUL, 0x0b238db6UL, 0xc870a09dUL, 0x8941bb84UL, - 0x465d2303UL, 0x076c381aUL, 0xc43f1531UL, 0x850e0e28UL, 0x42984f67UL, - 0x03a9547eUL, 0xc0fa7955UL, 0x81cb624cUL, 0x1fc53881UL, 0x5ef42398UL, - 0x9da70eb3UL, 0xdc9615aaUL, 0x1b0054e5UL, 0x5a314ffcUL, 0x996262d7UL, - 0xd85379ceUL, 0x174fe149UL, 0x567efa50UL, 0x952dd77bUL, 0xd41ccc62UL, - 0x138a8d2dUL, 0x52bb9634UL, 0x91e8bb1fUL, 0xd0d9a006UL, 0xecf37e5eUL, - 0xadc26547UL, 0x6e91486cUL, 0x2fa05375UL, 0xe836123aUL, 0xa9070923UL, - 0x6a542408UL, 0x2b653f11UL, 0xe479a796UL, 0xa548bc8fUL, 0x661b91a4UL, - 0x272a8abdUL, 0xe0bccbf2UL, 0xa18dd0ebUL, 0x62defdc0UL, 0x23efe6d9UL, - 0xbde1bc14UL, 0xfcd0a70dUL, 0x3f838a26UL, 0x7eb2913fUL, 0xb924d070UL, - 0xf815cb69UL, 0x3b46e642UL, 0x7a77fd5bUL, 0xb56b65dcUL, 0xf45a7ec5UL, - 0x370953eeUL, 0x763848f7UL, 0xb1ae09b8UL, 0xf09f12a1UL, 0x33cc3f8aUL, - 0x72fd2493UL - }, - { - 0x00000000UL, 0x376ac201UL, 0x6ed48403UL, 0x59be4602UL, 0xdca80907UL, - 0xebc2cb06UL, 0xb27c8d04UL, 0x85164f05UL, 0xb851130eUL, 0x8f3bd10fUL, - 0xd685970dUL, 0xe1ef550cUL, 0x64f91a09UL, 0x5393d808UL, 0x0a2d9e0aUL, - 0x3d475c0bUL, 0x70a3261cUL, 0x47c9e41dUL, 0x1e77a21fUL, 0x291d601eUL, - 0xac0b2f1bUL, 0x9b61ed1aUL, 0xc2dfab18UL, 0xf5b56919UL, 0xc8f23512UL, - 0xff98f713UL, 0xa626b111UL, 0x914c7310UL, 0x145a3c15UL, 0x2330fe14UL, - 0x7a8eb816UL, 0x4de47a17UL, 0xe0464d38UL, 0xd72c8f39UL, 0x8e92c93bUL, - 0xb9f80b3aUL, 0x3cee443fUL, 0x0b84863eUL, 0x523ac03cUL, 0x6550023dUL, - 0x58175e36UL, 0x6f7d9c37UL, 0x36c3da35UL, 0x01a91834UL, 0x84bf5731UL, - 0xb3d59530UL, 0xea6bd332UL, 0xdd011133UL, 0x90e56b24UL, 0xa78fa925UL, - 0xfe31ef27UL, 0xc95b2d26UL, 0x4c4d6223UL, 0x7b27a022UL, 0x2299e620UL, - 0x15f32421UL, 0x28b4782aUL, 0x1fdeba2bUL, 0x4660fc29UL, 0x710a3e28UL, - 0xf41c712dUL, 0xc376b32cUL, 0x9ac8f52eUL, 0xada2372fUL, 0xc08d9a70UL, - 0xf7e75871UL, 0xae591e73UL, 0x9933dc72UL, 0x1c259377UL, 0x2b4f5176UL, - 0x72f11774UL, 0x459bd575UL, 0x78dc897eUL, 0x4fb64b7fUL, 0x16080d7dUL, - 0x2162cf7cUL, 0xa4748079UL, 0x931e4278UL, 0xcaa0047aUL, 0xfdcac67bUL, - 0xb02ebc6cUL, 0x87447e6dUL, 0xdefa386fUL, 0xe990fa6eUL, 0x6c86b56bUL, - 0x5bec776aUL, 0x02523168UL, 0x3538f369UL, 0x087faf62UL, 0x3f156d63UL, - 0x66ab2b61UL, 0x51c1e960UL, 0xd4d7a665UL, 0xe3bd6464UL, 0xba032266UL, - 0x8d69e067UL, 0x20cbd748UL, 0x17a11549UL, 0x4e1f534bUL, 0x7975914aUL, - 0xfc63de4fUL, 0xcb091c4eUL, 0x92b75a4cUL, 0xa5dd984dUL, 0x989ac446UL, - 0xaff00647UL, 0xf64e4045UL, 0xc1248244UL, 0x4432cd41UL, 0x73580f40UL, - 0x2ae64942UL, 0x1d8c8b43UL, 0x5068f154UL, 0x67023355UL, 0x3ebc7557UL, - 0x09d6b756UL, 0x8cc0f853UL, 0xbbaa3a52UL, 0xe2147c50UL, 0xd57ebe51UL, - 0xe839e25aUL, 0xdf53205bUL, 0x86ed6659UL, 0xb187a458UL, 0x3491eb5dUL, - 0x03fb295cUL, 0x5a456f5eUL, 0x6d2fad5fUL, 0x801b35e1UL, 0xb771f7e0UL, - 0xeecfb1e2UL, 0xd9a573e3UL, 0x5cb33ce6UL, 0x6bd9fee7UL, 0x3267b8e5UL, - 0x050d7ae4UL, 0x384a26efUL, 0x0f20e4eeUL, 0x569ea2ecUL, 0x61f460edUL, - 0xe4e22fe8UL, 0xd388ede9UL, 0x8a36abebUL, 0xbd5c69eaUL, 0xf0b813fdUL, - 0xc7d2d1fcUL, 0x9e6c97feUL, 0xa90655ffUL, 0x2c101afaUL, 0x1b7ad8fbUL, - 0x42c49ef9UL, 0x75ae5cf8UL, 0x48e900f3UL, 0x7f83c2f2UL, 0x263d84f0UL, - 0x115746f1UL, 0x944109f4UL, 0xa32bcbf5UL, 0xfa958df7UL, 0xcdff4ff6UL, - 0x605d78d9UL, 0x5737bad8UL, 0x0e89fcdaUL, 0x39e33edbUL, 0xbcf571deUL, - 0x8b9fb3dfUL, 0xd221f5ddUL, 0xe54b37dcUL, 0xd80c6bd7UL, 0xef66a9d6UL, - 0xb6d8efd4UL, 0x81b22dd5UL, 0x04a462d0UL, 0x33cea0d1UL, 0x6a70e6d3UL, - 0x5d1a24d2UL, 0x10fe5ec5UL, 0x27949cc4UL, 0x7e2adac6UL, 0x494018c7UL, - 0xcc5657c2UL, 0xfb3c95c3UL, 0xa282d3c1UL, 0x95e811c0UL, 0xa8af4dcbUL, - 0x9fc58fcaUL, 0xc67bc9c8UL, 0xf1110bc9UL, 0x740744ccUL, 0x436d86cdUL, - 0x1ad3c0cfUL, 0x2db902ceUL, 0x4096af91UL, 0x77fc6d90UL, 0x2e422b92UL, - 0x1928e993UL, 0x9c3ea696UL, 0xab546497UL, 0xf2ea2295UL, 0xc580e094UL, - 0xf8c7bc9fUL, 0xcfad7e9eUL, 0x9613389cUL, 0xa179fa9dUL, 0x246fb598UL, - 0x13057799UL, 0x4abb319bUL, 0x7dd1f39aUL, 0x3035898dUL, 0x075f4b8cUL, - 0x5ee10d8eUL, 0x698bcf8fUL, 0xec9d808aUL, 0xdbf7428bUL, 0x82490489UL, - 0xb523c688UL, 0x88649a83UL, 0xbf0e5882UL, 0xe6b01e80UL, 0xd1dadc81UL, - 0x54cc9384UL, 0x63a65185UL, 0x3a181787UL, 0x0d72d586UL, 0xa0d0e2a9UL, - 0x97ba20a8UL, 0xce0466aaUL, 0xf96ea4abUL, 0x7c78ebaeUL, 0x4b1229afUL, - 0x12ac6fadUL, 0x25c6adacUL, 0x1881f1a7UL, 0x2feb33a6UL, 0x765575a4UL, - 0x413fb7a5UL, 0xc429f8a0UL, 0xf3433aa1UL, 0xaafd7ca3UL, 0x9d97bea2UL, - 0xd073c4b5UL, 0xe71906b4UL, 0xbea740b6UL, 0x89cd82b7UL, 0x0cdbcdb2UL, - 0x3bb10fb3UL, 0x620f49b1UL, 0x55658bb0UL, 0x6822d7bbUL, 0x5f4815baUL, - 0x06f653b8UL, 0x319c91b9UL, 0xb48adebcUL, 0x83e01cbdUL, 0xda5e5abfUL, - 0xed3498beUL - }, - { - 0x00000000UL, 0x6567bcb8UL, 0x8bc809aaUL, 0xeeafb512UL, 0x5797628fUL, - 0x32f0de37UL, 0xdc5f6b25UL, 0xb938d79dUL, 0xef28b4c5UL, 0x8a4f087dUL, - 0x64e0bd6fUL, 0x018701d7UL, 0xb8bfd64aUL, 0xddd86af2UL, 0x3377dfe0UL, - 0x56106358UL, 0x9f571950UL, 0xfa30a5e8UL, 0x149f10faUL, 0x71f8ac42UL, - 0xc8c07bdfUL, 0xada7c767UL, 0x43087275UL, 0x266fcecdUL, 0x707fad95UL, - 0x1518112dUL, 0xfbb7a43fUL, 0x9ed01887UL, 0x27e8cf1aUL, 0x428f73a2UL, - 0xac20c6b0UL, 0xc9477a08UL, 0x3eaf32a0UL, 0x5bc88e18UL, 0xb5673b0aUL, - 0xd00087b2UL, 0x6938502fUL, 0x0c5fec97UL, 0xe2f05985UL, 0x8797e53dUL, - 0xd1878665UL, 0xb4e03addUL, 0x5a4f8fcfUL, 0x3f283377UL, 0x8610e4eaUL, - 0xe3775852UL, 0x0dd8ed40UL, 0x68bf51f8UL, 0xa1f82bf0UL, 0xc49f9748UL, - 0x2a30225aUL, 0x4f579ee2UL, 0xf66f497fUL, 0x9308f5c7UL, 0x7da740d5UL, - 0x18c0fc6dUL, 0x4ed09f35UL, 0x2bb7238dUL, 0xc518969fUL, 0xa07f2a27UL, - 0x1947fdbaUL, 0x7c204102UL, 0x928ff410UL, 0xf7e848a8UL, 0x3d58149bUL, - 0x583fa823UL, 0xb6901d31UL, 0xd3f7a189UL, 0x6acf7614UL, 0x0fa8caacUL, - 0xe1077fbeUL, 0x8460c306UL, 0xd270a05eUL, 0xb7171ce6UL, 0x59b8a9f4UL, - 0x3cdf154cUL, 0x85e7c2d1UL, 0xe0807e69UL, 0x0e2fcb7bUL, 0x6b4877c3UL, - 0xa20f0dcbUL, 0xc768b173UL, 0x29c70461UL, 0x4ca0b8d9UL, 0xf5986f44UL, - 0x90ffd3fcUL, 0x7e5066eeUL, 0x1b37da56UL, 0x4d27b90eUL, 0x284005b6UL, - 0xc6efb0a4UL, 0xa3880c1cUL, 0x1ab0db81UL, 0x7fd76739UL, 0x9178d22bUL, - 0xf41f6e93UL, 0x03f7263bUL, 0x66909a83UL, 0x883f2f91UL, 0xed589329UL, - 0x546044b4UL, 0x3107f80cUL, 0xdfa84d1eUL, 0xbacff1a6UL, 0xecdf92feUL, - 0x89b82e46UL, 0x67179b54UL, 0x027027ecUL, 0xbb48f071UL, 0xde2f4cc9UL, - 0x3080f9dbUL, 0x55e74563UL, 0x9ca03f6bUL, 0xf9c783d3UL, 0x176836c1UL, - 0x720f8a79UL, 0xcb375de4UL, 0xae50e15cUL, 0x40ff544eUL, 0x2598e8f6UL, - 0x73888baeUL, 0x16ef3716UL, 0xf8408204UL, 0x9d273ebcUL, 0x241fe921UL, - 0x41785599UL, 0xafd7e08bUL, 0xcab05c33UL, 0x3bb659edUL, 0x5ed1e555UL, - 0xb07e5047UL, 0xd519ecffUL, 0x6c213b62UL, 0x094687daUL, 0xe7e932c8UL, - 0x828e8e70UL, 0xd49eed28UL, 0xb1f95190UL, 0x5f56e482UL, 0x3a31583aUL, - 0x83098fa7UL, 0xe66e331fUL, 0x08c1860dUL, 0x6da63ab5UL, 0xa4e140bdUL, - 0xc186fc05UL, 0x2f294917UL, 0x4a4ef5afUL, 0xf3762232UL, 0x96119e8aUL, - 0x78be2b98UL, 0x1dd99720UL, 0x4bc9f478UL, 0x2eae48c0UL, 0xc001fdd2UL, - 0xa566416aUL, 0x1c5e96f7UL, 0x79392a4fUL, 0x97969f5dUL, 0xf2f123e5UL, - 0x05196b4dUL, 0x607ed7f5UL, 0x8ed162e7UL, 0xebb6de5fUL, 0x528e09c2UL, - 0x37e9b57aUL, 0xd9460068UL, 0xbc21bcd0UL, 0xea31df88UL, 0x8f566330UL, - 0x61f9d622UL, 0x049e6a9aUL, 0xbda6bd07UL, 0xd8c101bfUL, 0x366eb4adUL, - 0x53090815UL, 0x9a4e721dUL, 0xff29cea5UL, 0x11867bb7UL, 0x74e1c70fUL, - 0xcdd91092UL, 0xa8beac2aUL, 0x46111938UL, 0x2376a580UL, 0x7566c6d8UL, - 0x10017a60UL, 0xfeaecf72UL, 0x9bc973caUL, 0x22f1a457UL, 0x479618efUL, - 0xa939adfdUL, 0xcc5e1145UL, 0x06ee4d76UL, 0x6389f1ceUL, 0x8d2644dcUL, - 0xe841f864UL, 0x51792ff9UL, 0x341e9341UL, 0xdab12653UL, 0xbfd69aebUL, - 0xe9c6f9b3UL, 0x8ca1450bUL, 0x620ef019UL, 0x07694ca1UL, 0xbe519b3cUL, - 0xdb362784UL, 0x35999296UL, 0x50fe2e2eUL, 0x99b95426UL, 0xfcdee89eUL, - 0x12715d8cUL, 0x7716e134UL, 0xce2e36a9UL, 0xab498a11UL, 0x45e63f03UL, - 0x208183bbUL, 0x7691e0e3UL, 0x13f65c5bUL, 0xfd59e949UL, 0x983e55f1UL, - 0x2106826cUL, 0x44613ed4UL, 0xaace8bc6UL, 0xcfa9377eUL, 0x38417fd6UL, - 0x5d26c36eUL, 0xb389767cUL, 0xd6eecac4UL, 0x6fd61d59UL, 0x0ab1a1e1UL, - 0xe41e14f3UL, 0x8179a84bUL, 0xd769cb13UL, 0xb20e77abUL, 0x5ca1c2b9UL, - 0x39c67e01UL, 0x80fea99cUL, 0xe5991524UL, 0x0b36a036UL, 0x6e511c8eUL, - 0xa7166686UL, 0xc271da3eUL, 0x2cde6f2cUL, 0x49b9d394UL, 0xf0810409UL, - 0x95e6b8b1UL, 0x7b490da3UL, 0x1e2eb11bUL, 0x483ed243UL, 0x2d596efbUL, - 0xc3f6dbe9UL, 0xa6916751UL, 0x1fa9b0ccUL, 0x7ace0c74UL, 0x9461b966UL, - 0xf10605deUL -#endif - } -}; diff --git a/btgui/zlib/deflate.c b/btgui/zlib/deflate.c deleted file mode 100644 index 696957705..000000000 --- a/btgui/zlib/deflate.c +++ /dev/null @@ -1,1967 +0,0 @@ -/* deflate.c -- compress data using the deflation algorithm - * Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* - * ALGORITHM - * - * The "deflation" process depends on being able to identify portions - * of the input text which are identical to earlier input (within a - * sliding window trailing behind the input currently being processed). - * - * The most straightforward technique turns out to be the fastest for - * most input files: try all possible matches and select the longest. - * The key feature of this algorithm is that insertions into the string - * dictionary are very simple and thus fast, and deletions are avoided - * completely. Insertions are performed at each input character, whereas - * string matches are performed only when the previous match ends. So it - * is preferable to spend more time in matches to allow very fast string - * insertions and avoid deletions. The matching algorithm for small - * strings is inspired from that of Rabin & Karp. A brute force approach - * is used to find longer strings when a small match has been found. - * A similar algorithm is used in comic (by Jan-Mark Wams) and freeze - * (by Leonid Broukhis). - * A previous version of this file used a more sophisticated algorithm - * (by Fiala and Greene) which is guaranteed to run in linear amortized - * time, but has a larger average cost, uses more memory and is patented. - * However the F&G algorithm may be faster for some highly redundant - * files if the parameter max_chain_length (described below) is too large. - * - * ACKNOWLEDGEMENTS - * - * The idea of lazy evaluation of matches is due to Jan-Mark Wams, and - * I found it in 'freeze' written by Leonid Broukhis. - * Thanks to many people for bug reports and testing. - * - * REFERENCES - * - * Deutsch, L.P.,"DEFLATE Compressed Data Format Specification". - * Available in http://tools.ietf.org/html/rfc1951 - * - * A description of the Rabin and Karp algorithm is given in the book - * "Algorithms" by R. Sedgewick, Addison-Wesley, p252. - * - * Fiala,E.R., and Greene,D.H. - * Data Compression with Finite Windows, Comm.ACM, 32,4 (1989) 490-595 - * - */ - -/* @(#) $Id$ */ - -#include "deflate.h" - -const char deflate_copyright[] = - " deflate 1.2.8 Copyright 1995-2013 Jean-loup Gailly and Mark Adler "; -/* - If you use the zlib library in a product, an acknowledgment is welcome - in the documentation of your product. If for some reason you cannot - include such an acknowledgment, I would appreciate that you keep this - copyright string in the executable of your product. - */ - -/* =========================================================================== - * Function prototypes. - */ -typedef enum { - need_more, /* block not completed, need more input or more output */ - block_done, /* block flush performed */ - finish_started, /* finish started, need only more output at next deflate */ - finish_done /* finish done, accept no more input or output */ -} block_state; - -typedef block_state (*compress_func) OF((deflate_state *s, int flush)); -/* Compression function. Returns the block state after the call. */ - -local void fill_window OF((deflate_state *s)); -local block_state deflate_stored OF((deflate_state *s, int flush)); -local block_state deflate_fast OF((deflate_state *s, int flush)); -#ifndef FASTEST -local block_state deflate_slow OF((deflate_state *s, int flush)); -#endif -local block_state deflate_rle OF((deflate_state *s, int flush)); -local block_state deflate_huff OF((deflate_state *s, int flush)); -local void lm_init OF((deflate_state *s)); -local void putShortMSB OF((deflate_state *s, uInt b)); -local void flush_pending OF((z_streamp strm)); -local int read_buf OF((z_streamp strm, Bytef *buf, unsigned size)); -#ifdef ASMV - void match_init OF((void)); /* asm code initialization */ - uInt longest_match OF((deflate_state *s, IPos cur_match)); -#else -local uInt longest_match OF((deflate_state *s, IPos cur_match)); -#endif - -#ifdef DEBUG -local void check_match OF((deflate_state *s, IPos start, IPos match, - int length)); -#endif - -/* =========================================================================== - * Local data - */ - -#define NIL 0 -/* Tail of hash chains */ - -#ifndef TOO_FAR -# define TOO_FAR 4096 -#endif -/* Matches of length 3 are discarded if their distance exceeds TOO_FAR */ - -/* Values for max_lazy_match, good_match and max_chain_length, depending on - * the desired pack level (0..9). The values given below have been tuned to - * exclude worst case performance for pathological files. Better values may be - * found for specific files. - */ -typedef struct config_s { - ush good_length; /* reduce lazy search above this match length */ - ush max_lazy; /* do not perform lazy search above this match length */ - ush nice_length; /* quit search above this match length */ - ush max_chain; - compress_func func; -} config; - -#ifdef FASTEST -local const config configuration_table[2] = { -/* good lazy nice chain */ -/* 0 */ {0, 0, 0, 0, deflate_stored}, /* store only */ -/* 1 */ {4, 4, 8, 4, deflate_fast}}; /* max speed, no lazy matches */ -#else -local const config configuration_table[10] = { -/* good lazy nice chain */ -/* 0 */ {0, 0, 0, 0, deflate_stored}, /* store only */ -/* 1 */ {4, 4, 8, 4, deflate_fast}, /* max speed, no lazy matches */ -/* 2 */ {4, 5, 16, 8, deflate_fast}, -/* 3 */ {4, 6, 32, 32, deflate_fast}, - -/* 4 */ {4, 4, 16, 16, deflate_slow}, /* lazy matches */ -/* 5 */ {8, 16, 32, 32, deflate_slow}, -/* 6 */ {8, 16, 128, 128, deflate_slow}, -/* 7 */ {8, 32, 128, 256, deflate_slow}, -/* 8 */ {32, 128, 258, 1024, deflate_slow}, -/* 9 */ {32, 258, 258, 4096, deflate_slow}}; /* max compression */ -#endif - -/* Note: the deflate() code requires max_lazy >= MIN_MATCH and max_chain >= 4 - * For deflate_fast() (levels <= 3) good is ignored and lazy has a different - * meaning. - */ - -#define EQUAL 0 -/* result of memcmp for equal strings */ - -#ifndef NO_DUMMY_DECL -struct static_tree_desc_s {int dummy;}; /* for buggy compilers */ -#endif - -/* rank Z_BLOCK between Z_NO_FLUSH and Z_PARTIAL_FLUSH */ -#define RANK(f) (((f) << 1) - ((f) > 4 ? 9 : 0)) - -/* =========================================================================== - * Update a hash value with the given input byte - * IN assertion: all calls to to UPDATE_HASH are made with consecutive - * input characters, so that a running hash key can be computed from the - * previous key instead of complete recalculation each time. - */ -#define UPDATE_HASH(s,h,c) (h = (((h)<hash_shift) ^ (c)) & s->hash_mask) - - -/* =========================================================================== - * Insert string str in the dictionary and set match_head to the previous head - * of the hash chain (the most recent string with same hash key). Return - * the previous length of the hash chain. - * If this file is compiled with -DFASTEST, the compression level is forced - * to 1, and no hash chains are maintained. - * IN assertion: all calls to to INSERT_STRING are made with consecutive - * input characters and the first MIN_MATCH bytes of str are valid - * (except for the last MIN_MATCH-1 bytes of the input file). - */ -#ifdef FASTEST -#define INSERT_STRING(s, str, match_head) \ - (UPDATE_HASH(s, s->ins_h, s->window[(str) + (MIN_MATCH-1)]), \ - match_head = s->head[s->ins_h], \ - s->head[s->ins_h] = (Pos)(str)) -#else -#define INSERT_STRING(s, str, match_head) \ - (UPDATE_HASH(s, s->ins_h, s->window[(str) + (MIN_MATCH-1)]), \ - match_head = s->prev[(str) & s->w_mask] = s->head[s->ins_h], \ - s->head[s->ins_h] = (Pos)(str)) -#endif - -/* =========================================================================== - * Initialize the hash table (avoiding 64K overflow for 16 bit systems). - * prev[] will be initialized on the fly. - */ -#define CLEAR_HASH(s) \ - s->head[s->hash_size-1] = NIL; \ - zmemzero((Bytef *)s->head, (unsigned)(s->hash_size-1)*sizeof(*s->head)); - -/* ========================================================================= */ -int ZEXPORT deflateInit_(strm, level, version, stream_size) - z_streamp strm; - int level; - const char *version; - int stream_size; -{ - return deflateInit2_(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, - Z_DEFAULT_STRATEGY, version, stream_size); - /* To do: ignore strm->next_in if we use it as window */ -} - -/* ========================================================================= */ -int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, - version, stream_size) - z_streamp strm; - int level; - int method; - int windowBits; - int memLevel; - int strategy; - const char *version; - int stream_size; -{ - deflate_state *s; - int wrap = 1; - static const char my_version[] = ZLIB_VERSION; - - ushf *overlay; - /* We overlay pending_buf and d_buf+l_buf. This works since the average - * output size for (length,distance) codes is <= 24 bits. - */ - - if (version == Z_NULL || version[0] != my_version[0] || - stream_size != sizeof(z_stream)) { - return Z_VERSION_ERROR; - } - if (strm == Z_NULL) return Z_STREAM_ERROR; - - strm->msg = Z_NULL; - if (strm->zalloc == (alloc_func)0) { -#ifdef Z_SOLO - return Z_STREAM_ERROR; -#else - strm->zalloc = zcalloc; - strm->opaque = (voidpf)0; -#endif - } - if (strm->zfree == (free_func)0) -#ifdef Z_SOLO - return Z_STREAM_ERROR; -#else - strm->zfree = zcfree; -#endif - -#ifdef FASTEST - if (level != 0) level = 1; -#else - if (level == Z_DEFAULT_COMPRESSION) level = 6; -#endif - - if (windowBits < 0) { /* suppress zlib wrapper */ - wrap = 0; - windowBits = -windowBits; - } -#ifdef GZIP - else if (windowBits > 15) { - wrap = 2; /* write gzip wrapper instead */ - windowBits -= 16; - } -#endif - if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method != Z_DEFLATED || - windowBits < 8 || windowBits > 15 || level < 0 || level > 9 || - strategy < 0 || strategy > Z_FIXED) { - return Z_STREAM_ERROR; - } - if (windowBits == 8) windowBits = 9; /* until 256-byte window bug fixed */ - s = (deflate_state *) ZALLOC(strm, 1, sizeof(deflate_state)); - if (s == Z_NULL) return Z_MEM_ERROR; - strm->state = (struct internal_state FAR *)s; - s->strm = strm; - - s->wrap = wrap; - s->gzhead = Z_NULL; - s->w_bits = windowBits; - s->w_size = 1 << s->w_bits; - s->w_mask = s->w_size - 1; - - s->hash_bits = memLevel + 7; - s->hash_size = 1 << s->hash_bits; - s->hash_mask = s->hash_size - 1; - s->hash_shift = ((s->hash_bits+MIN_MATCH-1)/MIN_MATCH); - - s->window = (Bytef *) ZALLOC(strm, s->w_size, 2*sizeof(Byte)); - s->prev = (Posf *) ZALLOC(strm, s->w_size, sizeof(Pos)); - s->head = (Posf *) ZALLOC(strm, s->hash_size, sizeof(Pos)); - - s->high_water = 0; /* nothing written to s->window yet */ - - s->lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */ - - overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2); - s->pending_buf = (uchf *) overlay; - s->pending_buf_size = (ulg)s->lit_bufsize * (sizeof(ush)+2L); - - if (s->window == Z_NULL || s->prev == Z_NULL || s->head == Z_NULL || - s->pending_buf == Z_NULL) { - s->status = FINISH_STATE; - strm->msg = ERR_MSG(Z_MEM_ERROR); - deflateEnd (strm); - return Z_MEM_ERROR; - } - s->d_buf = overlay + s->lit_bufsize/sizeof(ush); - s->l_buf = s->pending_buf + (1+sizeof(ush))*s->lit_bufsize; - - s->level = level; - s->strategy = strategy; - s->method = (Byte)method; - - return deflateReset(strm); -} - -/* ========================================================================= */ -int ZEXPORT deflateSetDictionary (strm, dictionary, dictLength) - z_streamp strm; - const Bytef *dictionary; - uInt dictLength; -{ - deflate_state *s; - uInt str, n; - int wrap; - unsigned avail; - z_const unsigned char *next; - - if (strm == Z_NULL || strm->state == Z_NULL || dictionary == Z_NULL) - return Z_STREAM_ERROR; - s = strm->state; - wrap = s->wrap; - if (wrap == 2 || (wrap == 1 && s->status != INIT_STATE) || s->lookahead) - return Z_STREAM_ERROR; - - /* when using zlib wrappers, compute Adler-32 for provided dictionary */ - if (wrap == 1) - strm->adler = adler32(strm->adler, dictionary, dictLength); - s->wrap = 0; /* avoid computing Adler-32 in read_buf */ - - /* if dictionary would fill window, just replace the history */ - if (dictLength >= s->w_size) { - if (wrap == 0) { /* already empty otherwise */ - CLEAR_HASH(s); - s->strstart = 0; - s->block_start = 0L; - s->insert = 0; - } - dictionary += dictLength - s->w_size; /* use the tail */ - dictLength = s->w_size; - } - - /* insert dictionary into window and hash */ - avail = strm->avail_in; - next = strm->next_in; - strm->avail_in = dictLength; - strm->next_in = (z_const Bytef *)dictionary; - fill_window(s); - while (s->lookahead >= MIN_MATCH) { - str = s->strstart; - n = s->lookahead - (MIN_MATCH-1); - do { - UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); -#ifndef FASTEST - s->prev[str & s->w_mask] = s->head[s->ins_h]; -#endif - s->head[s->ins_h] = (Pos)str; - str++; - } while (--n); - s->strstart = str; - s->lookahead = MIN_MATCH-1; - fill_window(s); - } - s->strstart += s->lookahead; - s->block_start = (long)s->strstart; - s->insert = s->lookahead; - s->lookahead = 0; - s->match_length = s->prev_length = MIN_MATCH-1; - s->match_available = 0; - strm->next_in = next; - strm->avail_in = avail; - s->wrap = wrap; - return Z_OK; -} - -/* ========================================================================= */ -int ZEXPORT deflateResetKeep (strm) - z_streamp strm; -{ - deflate_state *s; - - if (strm == Z_NULL || strm->state == Z_NULL || - strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) { - return Z_STREAM_ERROR; - } - - strm->total_in = strm->total_out = 0; - strm->msg = Z_NULL; /* use zfree if we ever allocate msg dynamically */ - strm->data_type = Z_UNKNOWN; - - s = (deflate_state *)strm->state; - s->pending = 0; - s->pending_out = s->pending_buf; - - if (s->wrap < 0) { - s->wrap = -s->wrap; /* was made negative by deflate(..., Z_FINISH); */ - } - s->status = s->wrap ? INIT_STATE : BUSY_STATE; - strm->adler = -#ifdef GZIP - s->wrap == 2 ? crc32(0L, Z_NULL, 0) : -#endif - adler32(0L, Z_NULL, 0); - s->last_flush = Z_NO_FLUSH; - - _tr_init(s); - - return Z_OK; -} - -/* ========================================================================= */ -int ZEXPORT deflateReset (strm) - z_streamp strm; -{ - int ret; - - ret = deflateResetKeep(strm); - if (ret == Z_OK) - lm_init(strm->state); - return ret; -} - -/* ========================================================================= */ -int ZEXPORT deflateSetHeader (strm, head) - z_streamp strm; - gz_headerp head; -{ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - if (strm->state->wrap != 2) return Z_STREAM_ERROR; - strm->state->gzhead = head; - return Z_OK; -} - -/* ========================================================================= */ -int ZEXPORT deflatePending (strm, pending, bits) - unsigned *pending; - int *bits; - z_streamp strm; -{ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - if (pending != Z_NULL) - *pending = strm->state->pending; - if (bits != Z_NULL) - *bits = strm->state->bi_valid; - return Z_OK; -} - -/* ========================================================================= */ -int ZEXPORT deflatePrime (strm, bits, value) - z_streamp strm; - int bits; - int value; -{ - deflate_state *s; - int put; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - s = strm->state; - if ((Bytef *)(s->d_buf) < s->pending_out + ((Buf_size + 7) >> 3)) - return Z_BUF_ERROR; - do { - put = Buf_size - s->bi_valid; - if (put > bits) - put = bits; - s->bi_buf |= (ush)((value & ((1 << put) - 1)) << s->bi_valid); - s->bi_valid += put; - _tr_flush_bits(s); - value >>= put; - bits -= put; - } while (bits); - return Z_OK; -} - -/* ========================================================================= */ -int ZEXPORT deflateParams(strm, level, strategy) - z_streamp strm; - int level; - int strategy; -{ - deflate_state *s; - compress_func func; - int err = Z_OK; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - s = strm->state; - -#ifdef FASTEST - if (level != 0) level = 1; -#else - if (level == Z_DEFAULT_COMPRESSION) level = 6; -#endif - if (level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED) { - return Z_STREAM_ERROR; - } - func = configuration_table[s->level].func; - - if ((strategy != s->strategy || func != configuration_table[level].func) && - strm->total_in != 0) { - /* Flush the last buffer: */ - err = deflate(strm, Z_BLOCK); - if (err == Z_BUF_ERROR && s->pending == 0) - err = Z_OK; - } - if (s->level != level) { - s->level = level; - s->max_lazy_match = configuration_table[level].max_lazy; - s->good_match = configuration_table[level].good_length; - s->nice_match = configuration_table[level].nice_length; - s->max_chain_length = configuration_table[level].max_chain; - } - s->strategy = strategy; - return err; -} - -/* ========================================================================= */ -int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain) - z_streamp strm; - int good_length; - int max_lazy; - int nice_length; - int max_chain; -{ - deflate_state *s; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - s = strm->state; - s->good_match = good_length; - s->max_lazy_match = max_lazy; - s->nice_match = nice_length; - s->max_chain_length = max_chain; - return Z_OK; -} - -/* ========================================================================= - * For the default windowBits of 15 and memLevel of 8, this function returns - * a close to exact, as well as small, upper bound on the compressed size. - * They are coded as constants here for a reason--if the #define's are - * changed, then this function needs to be changed as well. The return - * value for 15 and 8 only works for those exact settings. - * - * For any setting other than those defaults for windowBits and memLevel, - * the value returned is a conservative worst case for the maximum expansion - * resulting from using fixed blocks instead of stored blocks, which deflate - * can emit on compressed data for some combinations of the parameters. - * - * This function could be more sophisticated to provide closer upper bounds for - * every combination of windowBits and memLevel. But even the conservative - * upper bound of about 14% expansion does not seem onerous for output buffer - * allocation. - */ -uLong ZEXPORT deflateBound(strm, sourceLen) - z_streamp strm; - uLong sourceLen; -{ - deflate_state *s; - uLong complen, wraplen; - Bytef *str; - - /* conservative upper bound for compressed data */ - complen = sourceLen + - ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 5; - - /* if can't get parameters, return conservative bound plus zlib wrapper */ - if (strm == Z_NULL || strm->state == Z_NULL) - return complen + 6; - - /* compute wrapper length */ - s = strm->state; - switch (s->wrap) { - case 0: /* raw deflate */ - wraplen = 0; - break; - case 1: /* zlib wrapper */ - wraplen = 6 + (s->strstart ? 4 : 0); - break; - case 2: /* gzip wrapper */ - wraplen = 18; - if (s->gzhead != Z_NULL) { /* user-supplied gzip header */ - if (s->gzhead->extra != Z_NULL) - wraplen += 2 + s->gzhead->extra_len; - str = s->gzhead->name; - if (str != Z_NULL) - do { - wraplen++; - } while (*str++); - str = s->gzhead->comment; - if (str != Z_NULL) - do { - wraplen++; - } while (*str++); - if (s->gzhead->hcrc) - wraplen += 2; - } - break; - default: /* for compiler happiness */ - wraplen = 6; - } - - /* if not default parameters, return conservative bound */ - if (s->w_bits != 15 || s->hash_bits != 8 + 7) - return complen + wraplen; - - /* default settings: return tight bound for that case */ - return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + - (sourceLen >> 25) + 13 - 6 + wraplen; -} - -/* ========================================================================= - * Put a short in the pending buffer. The 16-bit value is put in MSB order. - * IN assertion: the stream state is correct and there is enough room in - * pending_buf. - */ -local void putShortMSB (s, b) - deflate_state *s; - uInt b; -{ - put_byte(s, (Byte)(b >> 8)); - put_byte(s, (Byte)(b & 0xff)); -} - -/* ========================================================================= - * Flush as much pending output as possible. All deflate() output goes - * through this function so some applications may wish to modify it - * to avoid allocating a large strm->next_out buffer and copying into it. - * (See also read_buf()). - */ -local void flush_pending(strm) - z_streamp strm; -{ - unsigned len; - deflate_state *s = strm->state; - - _tr_flush_bits(s); - len = s->pending; - if (len > strm->avail_out) len = strm->avail_out; - if (len == 0) return; - - zmemcpy(strm->next_out, s->pending_out, len); - strm->next_out += len; - s->pending_out += len; - strm->total_out += len; - strm->avail_out -= len; - s->pending -= len; - if (s->pending == 0) { - s->pending_out = s->pending_buf; - } -} - -/* ========================================================================= */ -int ZEXPORT deflate (strm, flush) - z_streamp strm; - int flush; -{ - int old_flush; /* value of flush param for previous deflate call */ - deflate_state *s; - - if (strm == Z_NULL || strm->state == Z_NULL || - flush > Z_BLOCK || flush < 0) { - return Z_STREAM_ERROR; - } - s = strm->state; - - if (strm->next_out == Z_NULL || - (strm->next_in == Z_NULL && strm->avail_in != 0) || - (s->status == FINISH_STATE && flush != Z_FINISH)) { - ERR_RETURN(strm, Z_STREAM_ERROR); - } - if (strm->avail_out == 0) ERR_RETURN(strm, Z_BUF_ERROR); - - s->strm = strm; /* just in case */ - old_flush = s->last_flush; - s->last_flush = flush; - - /* Write the header */ - if (s->status == INIT_STATE) { -#ifdef GZIP - if (s->wrap == 2) { - strm->adler = crc32(0L, Z_NULL, 0); - put_byte(s, 31); - put_byte(s, 139); - put_byte(s, 8); - if (s->gzhead == Z_NULL) { - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, 0); - put_byte(s, s->level == 9 ? 2 : - (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? - 4 : 0)); - put_byte(s, OS_CODE); - s->status = BUSY_STATE; - } - else { - put_byte(s, (s->gzhead->text ? 1 : 0) + - (s->gzhead->hcrc ? 2 : 0) + - (s->gzhead->extra == Z_NULL ? 0 : 4) + - (s->gzhead->name == Z_NULL ? 0 : 8) + - (s->gzhead->comment == Z_NULL ? 0 : 16) - ); - put_byte(s, (Byte)(s->gzhead->time & 0xff)); - put_byte(s, (Byte)((s->gzhead->time >> 8) & 0xff)); - put_byte(s, (Byte)((s->gzhead->time >> 16) & 0xff)); - put_byte(s, (Byte)((s->gzhead->time >> 24) & 0xff)); - put_byte(s, s->level == 9 ? 2 : - (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? - 4 : 0)); - put_byte(s, s->gzhead->os & 0xff); - if (s->gzhead->extra != Z_NULL) { - put_byte(s, s->gzhead->extra_len & 0xff); - put_byte(s, (s->gzhead->extra_len >> 8) & 0xff); - } - if (s->gzhead->hcrc) - strm->adler = crc32(strm->adler, s->pending_buf, - s->pending); - s->gzindex = 0; - s->status = EXTRA_STATE; - } - } - else -#endif - { - uInt header = (Z_DEFLATED + ((s->w_bits-8)<<4)) << 8; - uInt level_flags; - - if (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2) - level_flags = 0; - else if (s->level < 6) - level_flags = 1; - else if (s->level == 6) - level_flags = 2; - else - level_flags = 3; - header |= (level_flags << 6); - if (s->strstart != 0) header |= PRESET_DICT; - header += 31 - (header % 31); - - s->status = BUSY_STATE; - putShortMSB(s, header); - - /* Save the adler32 of the preset dictionary: */ - if (s->strstart != 0) { - putShortMSB(s, (uInt)(strm->adler >> 16)); - putShortMSB(s, (uInt)(strm->adler & 0xffff)); - } - strm->adler = adler32(0L, Z_NULL, 0); - } - } -#ifdef GZIP - if (s->status == EXTRA_STATE) { - if (s->gzhead->extra != Z_NULL) { - uInt beg = s->pending; /* start of bytes to update crc */ - - while (s->gzindex < (s->gzhead->extra_len & 0xffff)) { - if (s->pending == s->pending_buf_size) { - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - flush_pending(strm); - beg = s->pending; - if (s->pending == s->pending_buf_size) - break; - } - put_byte(s, s->gzhead->extra[s->gzindex]); - s->gzindex++; - } - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - if (s->gzindex == s->gzhead->extra_len) { - s->gzindex = 0; - s->status = NAME_STATE; - } - } - else - s->status = NAME_STATE; - } - if (s->status == NAME_STATE) { - if (s->gzhead->name != Z_NULL) { - uInt beg = s->pending; /* start of bytes to update crc */ - int val; - - do { - if (s->pending == s->pending_buf_size) { - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - flush_pending(strm); - beg = s->pending; - if (s->pending == s->pending_buf_size) { - val = 1; - break; - } - } - val = s->gzhead->name[s->gzindex++]; - put_byte(s, val); - } while (val != 0); - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - if (val == 0) { - s->gzindex = 0; - s->status = COMMENT_STATE; - } - } - else - s->status = COMMENT_STATE; - } - if (s->status == COMMENT_STATE) { - if (s->gzhead->comment != Z_NULL) { - uInt beg = s->pending; /* start of bytes to update crc */ - int val; - - do { - if (s->pending == s->pending_buf_size) { - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - flush_pending(strm); - beg = s->pending; - if (s->pending == s->pending_buf_size) { - val = 1; - break; - } - } - val = s->gzhead->comment[s->gzindex++]; - put_byte(s, val); - } while (val != 0); - if (s->gzhead->hcrc && s->pending > beg) - strm->adler = crc32(strm->adler, s->pending_buf + beg, - s->pending - beg); - if (val == 0) - s->status = HCRC_STATE; - } - else - s->status = HCRC_STATE; - } - if (s->status == HCRC_STATE) { - if (s->gzhead->hcrc) { - if (s->pending + 2 > s->pending_buf_size) - flush_pending(strm); - if (s->pending + 2 <= s->pending_buf_size) { - put_byte(s, (Byte)(strm->adler & 0xff)); - put_byte(s, (Byte)((strm->adler >> 8) & 0xff)); - strm->adler = crc32(0L, Z_NULL, 0); - s->status = BUSY_STATE; - } - } - else - s->status = BUSY_STATE; - } -#endif - - /* Flush as much pending output as possible */ - if (s->pending != 0) { - flush_pending(strm); - if (strm->avail_out == 0) { - /* Since avail_out is 0, deflate will be called again with - * more output space, but possibly with both pending and - * avail_in equal to zero. There won't be anything to do, - * but this is not an error situation so make sure we - * return OK instead of BUF_ERROR at next call of deflate: - */ - s->last_flush = -1; - return Z_OK; - } - - /* Make sure there is something to do and avoid duplicate consecutive - * flushes. For repeated and useless calls with Z_FINISH, we keep - * returning Z_STREAM_END instead of Z_BUF_ERROR. - */ - } else if (strm->avail_in == 0 && RANK(flush) <= RANK(old_flush) && - flush != Z_FINISH) { - ERR_RETURN(strm, Z_BUF_ERROR); - } - - /* User must not provide more input after the first FINISH: */ - if (s->status == FINISH_STATE && strm->avail_in != 0) { - ERR_RETURN(strm, Z_BUF_ERROR); - } - - /* Start a new block or continue the current one. - */ - if (strm->avail_in != 0 || s->lookahead != 0 || - (flush != Z_NO_FLUSH && s->status != FINISH_STATE)) { - block_state bstate; - - bstate = s->strategy == Z_HUFFMAN_ONLY ? deflate_huff(s, flush) : - (s->strategy == Z_RLE ? deflate_rle(s, flush) : - (*(configuration_table[s->level].func))(s, flush)); - - if (bstate == finish_started || bstate == finish_done) { - s->status = FINISH_STATE; - } - if (bstate == need_more || bstate == finish_started) { - if (strm->avail_out == 0) { - s->last_flush = -1; /* avoid BUF_ERROR next call, see above */ - } - return Z_OK; - /* If flush != Z_NO_FLUSH && avail_out == 0, the next call - * of deflate should use the same flush parameter to make sure - * that the flush is complete. So we don't have to output an - * empty block here, this will be done at next call. This also - * ensures that for a very small output buffer, we emit at most - * one empty block. - */ - } - if (bstate == block_done) { - if (flush == Z_PARTIAL_FLUSH) { - _tr_align(s); - } else if (flush != Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */ - _tr_stored_block(s, (char*)0, 0L, 0); - /* For a full flush, this empty block will be recognized - * as a special marker by inflate_sync(). - */ - if (flush == Z_FULL_FLUSH) { - CLEAR_HASH(s); /* forget history */ - if (s->lookahead == 0) { - s->strstart = 0; - s->block_start = 0L; - s->insert = 0; - } - } - } - flush_pending(strm); - if (strm->avail_out == 0) { - s->last_flush = -1; /* avoid BUF_ERROR at next call, see above */ - return Z_OK; - } - } - } - Assert(strm->avail_out > 0, "bug2"); - - if (flush != Z_FINISH) return Z_OK; - if (s->wrap <= 0) return Z_STREAM_END; - - /* Write the trailer */ -#ifdef GZIP - if (s->wrap == 2) { - put_byte(s, (Byte)(strm->adler & 0xff)); - put_byte(s, (Byte)((strm->adler >> 8) & 0xff)); - put_byte(s, (Byte)((strm->adler >> 16) & 0xff)); - put_byte(s, (Byte)((strm->adler >> 24) & 0xff)); - put_byte(s, (Byte)(strm->total_in & 0xff)); - put_byte(s, (Byte)((strm->total_in >> 8) & 0xff)); - put_byte(s, (Byte)((strm->total_in >> 16) & 0xff)); - put_byte(s, (Byte)((strm->total_in >> 24) & 0xff)); - } - else -#endif - { - putShortMSB(s, (uInt)(strm->adler >> 16)); - putShortMSB(s, (uInt)(strm->adler & 0xffff)); - } - flush_pending(strm); - /* If avail_out is zero, the application will call deflate again - * to flush the rest. - */ - if (s->wrap > 0) s->wrap = -s->wrap; /* write the trailer only once! */ - return s->pending != 0 ? Z_OK : Z_STREAM_END; -} - -/* ========================================================================= */ -int ZEXPORT deflateEnd (strm) - z_streamp strm; -{ - int status; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - - status = strm->state->status; - if (status != INIT_STATE && - status != EXTRA_STATE && - status != NAME_STATE && - status != COMMENT_STATE && - status != HCRC_STATE && - status != BUSY_STATE && - status != FINISH_STATE) { - return Z_STREAM_ERROR; - } - - /* Deallocate in reverse order of allocations: */ - TRY_FREE(strm, strm->state->pending_buf); - TRY_FREE(strm, strm->state->head); - TRY_FREE(strm, strm->state->prev); - TRY_FREE(strm, strm->state->window); - - ZFREE(strm, strm->state); - strm->state = Z_NULL; - - return status == BUSY_STATE ? Z_DATA_ERROR : Z_OK; -} - -/* ========================================================================= - * Copy the source state to the destination state. - * To simplify the source, this is not supported for 16-bit MSDOS (which - * doesn't have enough memory anyway to duplicate compression states). - */ -int ZEXPORT deflateCopy (dest, source) - z_streamp dest; - z_streamp source; -{ -#ifdef MAXSEG_64K - return Z_STREAM_ERROR; -#else - deflate_state *ds; - deflate_state *ss; - ushf *overlay; - - - if (source == Z_NULL || dest == Z_NULL || source->state == Z_NULL) { - return Z_STREAM_ERROR; - } - - ss = source->state; - - zmemcpy((voidpf)dest, (voidpf)source, sizeof(z_stream)); - - ds = (deflate_state *) ZALLOC(dest, 1, sizeof(deflate_state)); - if (ds == Z_NULL) return Z_MEM_ERROR; - dest->state = (struct internal_state FAR *) ds; - zmemcpy((voidpf)ds, (voidpf)ss, sizeof(deflate_state)); - ds->strm = dest; - - ds->window = (Bytef *) ZALLOC(dest, ds->w_size, 2*sizeof(Byte)); - ds->prev = (Posf *) ZALLOC(dest, ds->w_size, sizeof(Pos)); - ds->head = (Posf *) ZALLOC(dest, ds->hash_size, sizeof(Pos)); - overlay = (ushf *) ZALLOC(dest, ds->lit_bufsize, sizeof(ush)+2); - ds->pending_buf = (uchf *) overlay; - - if (ds->window == Z_NULL || ds->prev == Z_NULL || ds->head == Z_NULL || - ds->pending_buf == Z_NULL) { - deflateEnd (dest); - return Z_MEM_ERROR; - } - /* following zmemcpy do not work for 16-bit MSDOS */ - zmemcpy(ds->window, ss->window, ds->w_size * 2 * sizeof(Byte)); - zmemcpy((voidpf)ds->prev, (voidpf)ss->prev, ds->w_size * sizeof(Pos)); - zmemcpy((voidpf)ds->head, (voidpf)ss->head, ds->hash_size * sizeof(Pos)); - zmemcpy(ds->pending_buf, ss->pending_buf, (uInt)ds->pending_buf_size); - - ds->pending_out = ds->pending_buf + (ss->pending_out - ss->pending_buf); - ds->d_buf = overlay + ds->lit_bufsize/sizeof(ush); - ds->l_buf = ds->pending_buf + (1+sizeof(ush))*ds->lit_bufsize; - - ds->l_desc.dyn_tree = ds->dyn_ltree; - ds->d_desc.dyn_tree = ds->dyn_dtree; - ds->bl_desc.dyn_tree = ds->bl_tree; - - return Z_OK; -#endif /* MAXSEG_64K */ -} - -/* =========================================================================== - * Read a new buffer from the current input stream, update the adler32 - * and total number of bytes read. All deflate() input goes through - * this function so some applications may wish to modify it to avoid - * allocating a large strm->next_in buffer and copying from it. - * (See also flush_pending()). - */ -local int read_buf(strm, buf, size) - z_streamp strm; - Bytef *buf; - unsigned size; -{ - unsigned len = strm->avail_in; - - if (len > size) len = size; - if (len == 0) return 0; - - strm->avail_in -= len; - - zmemcpy(buf, strm->next_in, len); - if (strm->state->wrap == 1) { - strm->adler = adler32(strm->adler, buf, len); - } -#ifdef GZIP - else if (strm->state->wrap == 2) { - strm->adler = crc32(strm->adler, buf, len); - } -#endif - strm->next_in += len; - strm->total_in += len; - - return (int)len; -} - -/* =========================================================================== - * Initialize the "longest match" routines for a new zlib stream - */ -local void lm_init (s) - deflate_state *s; -{ - s->window_size = (ulg)2L*s->w_size; - - CLEAR_HASH(s); - - /* Set the default configuration parameters: - */ - s->max_lazy_match = configuration_table[s->level].max_lazy; - s->good_match = configuration_table[s->level].good_length; - s->nice_match = configuration_table[s->level].nice_length; - s->max_chain_length = configuration_table[s->level].max_chain; - - s->strstart = 0; - s->block_start = 0L; - s->lookahead = 0; - s->insert = 0; - s->match_length = s->prev_length = MIN_MATCH-1; - s->match_available = 0; - s->ins_h = 0; -#ifndef FASTEST -#ifdef ASMV - match_init(); /* initialize the asm code */ -#endif -#endif -} - -#ifndef FASTEST -/* =========================================================================== - * Set match_start to the longest match starting at the given string and - * return its length. Matches shorter or equal to prev_length are discarded, - * in which case the result is equal to prev_length and match_start is - * garbage. - * IN assertions: cur_match is the head of the hash chain for the current - * string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1 - * OUT assertion: the match length is not greater than s->lookahead. - */ -#ifndef ASMV -/* For 80x86 and 680x0, an optimized version will be provided in match.asm or - * match.S. The code will be functionally equivalent. - */ -local uInt longest_match(s, cur_match) - deflate_state *s; - IPos cur_match; /* current match */ -{ - unsigned chain_length = s->max_chain_length;/* max hash chain length */ - register Bytef *scan = s->window + s->strstart; /* current string */ - register Bytef *match; /* matched string */ - register int len; /* length of current match */ - int best_len = s->prev_length; /* best match length so far */ - int nice_match = s->nice_match; /* stop if match long enough */ - IPos limit = s->strstart > (IPos)MAX_DIST(s) ? - s->strstart - (IPos)MAX_DIST(s) : NIL; - /* Stop when cur_match becomes <= limit. To simplify the code, - * we prevent matches with the string of window index 0. - */ - Posf *prev = s->prev; - uInt wmask = s->w_mask; - -#ifdef UNALIGNED_OK - /* Compare two bytes at a time. Note: this is not always beneficial. - * Try with and without -DUNALIGNED_OK to check. - */ - register Bytef *strend = s->window + s->strstart + MAX_MATCH - 1; - register ush scan_start = *(ushf*)scan; - register ush scan_end = *(ushf*)(scan+best_len-1); -#else - register Bytef *strend = s->window + s->strstart + MAX_MATCH; - register Byte scan_end1 = scan[best_len-1]; - register Byte scan_end = scan[best_len]; -#endif - - /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16. - * It is easy to get rid of this optimization if necessary. - */ - Assert(s->hash_bits >= 8 && MAX_MATCH == 258, "Code too clever"); - - /* Do not waste too much time if we already have a good match: */ - if (s->prev_length >= s->good_match) { - chain_length >>= 2; - } - /* Do not look for matches beyond the end of the input. This is necessary - * to make deflate deterministic. - */ - if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead; - - Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead"); - - do { - Assert(cur_match < s->strstart, "no future"); - match = s->window + cur_match; - - /* Skip to next match if the match length cannot increase - * or if the match length is less than 2. Note that the checks below - * for insufficient lookahead only occur occasionally for performance - * reasons. Therefore uninitialized memory will be accessed, and - * conditional jumps will be made that depend on those values. - * However the length of the match is limited to the lookahead, so - * the output of deflate is not affected by the uninitialized values. - */ -#if (defined(UNALIGNED_OK) && MAX_MATCH == 258) - /* This code assumes sizeof(unsigned short) == 2. Do not use - * UNALIGNED_OK if your compiler uses a different size. - */ - if (*(ushf*)(match+best_len-1) != scan_end || - *(ushf*)match != scan_start) continue; - - /* It is not necessary to compare scan[2] and match[2] since they are - * always equal when the other bytes match, given that the hash keys - * are equal and that HASH_BITS >= 8. Compare 2 bytes at a time at - * strstart+3, +5, ... up to strstart+257. We check for insufficient - * lookahead only every 4th comparison; the 128th check will be made - * at strstart+257. If MAX_MATCH-2 is not a multiple of 8, it is - * necessary to put more guard bytes at the end of the window, or - * to check more often for insufficient lookahead. - */ - Assert(scan[2] == match[2], "scan[2]?"); - scan++, match++; - do { - } while (*(ushf*)(scan+=2) == *(ushf*)(match+=2) && - *(ushf*)(scan+=2) == *(ushf*)(match+=2) && - *(ushf*)(scan+=2) == *(ushf*)(match+=2) && - *(ushf*)(scan+=2) == *(ushf*)(match+=2) && - scan < strend); - /* The funny "do {}" generates better code on most compilers */ - - /* Here, scan <= window+strstart+257 */ - Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan"); - if (*scan == *match) scan++; - - len = (MAX_MATCH - 1) - (int)(strend-scan); - scan = strend - (MAX_MATCH-1); - -#else /* UNALIGNED_OK */ - - if (match[best_len] != scan_end || - match[best_len-1] != scan_end1 || - *match != *scan || - *++match != scan[1]) continue; - - /* The check at best_len-1 can be removed because it will be made - * again later. (This heuristic is not always a win.) - * It is not necessary to compare scan[2] and match[2] since they - * are always equal when the other bytes match, given that - * the hash keys are equal and that HASH_BITS >= 8. - */ - scan += 2, match++; - Assert(*scan == *match, "match[2]?"); - - /* We check for insufficient lookahead only every 8th comparison; - * the 256th check will be made at strstart+258. - */ - do { - } while (*++scan == *++match && *++scan == *++match && - *++scan == *++match && *++scan == *++match && - *++scan == *++match && *++scan == *++match && - *++scan == *++match && *++scan == *++match && - scan < strend); - - Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan"); - - len = MAX_MATCH - (int)(strend - scan); - scan = strend - MAX_MATCH; - -#endif /* UNALIGNED_OK */ - - if (len > best_len) { - s->match_start = cur_match; - best_len = len; - if (len >= nice_match) break; -#ifdef UNALIGNED_OK - scan_end = *(ushf*)(scan+best_len-1); -#else - scan_end1 = scan[best_len-1]; - scan_end = scan[best_len]; -#endif - } - } while ((cur_match = prev[cur_match & wmask]) > limit - && --chain_length != 0); - - if ((uInt)best_len <= s->lookahead) return (uInt)best_len; - return s->lookahead; -} -#endif /* ASMV */ - -#else /* FASTEST */ - -/* --------------------------------------------------------------------------- - * Optimized version for FASTEST only - */ -local uInt longest_match(s, cur_match) - deflate_state *s; - IPos cur_match; /* current match */ -{ - register Bytef *scan = s->window + s->strstart; /* current string */ - register Bytef *match; /* matched string */ - register int len; /* length of current match */ - register Bytef *strend = s->window + s->strstart + MAX_MATCH; - - /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16. - * It is easy to get rid of this optimization if necessary. - */ - Assert(s->hash_bits >= 8 && MAX_MATCH == 258, "Code too clever"); - - Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, "need lookahead"); - - Assert(cur_match < s->strstart, "no future"); - - match = s->window + cur_match; - - /* Return failure if the match length is less than 2: - */ - if (match[0] != scan[0] || match[1] != scan[1]) return MIN_MATCH-1; - - /* The check at best_len-1 can be removed because it will be made - * again later. (This heuristic is not always a win.) - * It is not necessary to compare scan[2] and match[2] since they - * are always equal when the other bytes match, given that - * the hash keys are equal and that HASH_BITS >= 8. - */ - scan += 2, match += 2; - Assert(*scan == *match, "match[2]?"); - - /* We check for insufficient lookahead only every 8th comparison; - * the 256th check will be made at strstart+258. - */ - do { - } while (*++scan == *++match && *++scan == *++match && - *++scan == *++match && *++scan == *++match && - *++scan == *++match && *++scan == *++match && - *++scan == *++match && *++scan == *++match && - scan < strend); - - Assert(scan <= s->window+(unsigned)(s->window_size-1), "wild scan"); - - len = MAX_MATCH - (int)(strend - scan); - - if (len < MIN_MATCH) return MIN_MATCH - 1; - - s->match_start = cur_match; - return (uInt)len <= s->lookahead ? (uInt)len : s->lookahead; -} - -#endif /* FASTEST */ - -#ifdef DEBUG -/* =========================================================================== - * Check that the match at match_start is indeed a match. - */ -local void check_match(s, start, match, length) - deflate_state *s; - IPos start, match; - int length; -{ - /* check that the match is indeed a match */ - if (zmemcmp(s->window + match, - s->window + start, length) != EQUAL) { - fprintf(stderr, " start %u, match %u, length %d\n", - start, match, length); - do { - fprintf(stderr, "%c%c", s->window[match++], s->window[start++]); - } while (--length != 0); - z_error("invalid match"); - } - if (z_verbose > 1) { - fprintf(stderr,"\\[%d,%d]", start-match, length); - do { putc(s->window[start++], stderr); } while (--length != 0); - } -} -#else -# define check_match(s, start, match, length) -#endif /* DEBUG */ - -/* =========================================================================== - * Fill the window when the lookahead becomes insufficient. - * Updates strstart and lookahead. - * - * IN assertion: lookahead < MIN_LOOKAHEAD - * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD - * At least one byte has been read, or avail_in == 0; reads are - * performed for at least two bytes (required for the zip translate_eol - * option -- not supported here). - */ -local void fill_window(s) - deflate_state *s; -{ - register unsigned n, m; - register Posf *p; - unsigned more; /* Amount of free space at the end of the window. */ - uInt wsize = s->w_size; - - Assert(s->lookahead < MIN_LOOKAHEAD, "already enough lookahead"); - - do { - more = (unsigned)(s->window_size -(ulg)s->lookahead -(ulg)s->strstart); - - /* Deal with !@#$% 64K limit: */ - if (sizeof(int) <= 2) { - if (more == 0 && s->strstart == 0 && s->lookahead == 0) { - more = wsize; - - } else if (more == (unsigned)(-1)) { - /* Very unlikely, but possible on 16 bit machine if - * strstart == 0 && lookahead == 1 (input done a byte at time) - */ - more--; - } - } - - /* If the window is almost full and there is insufficient lookahead, - * move the upper half to the lower one to make room in the upper half. - */ - if (s->strstart >= wsize+MAX_DIST(s)) { - - zmemcpy(s->window, s->window+wsize, (unsigned)wsize); - s->match_start -= wsize; - s->strstart -= wsize; /* we now have strstart >= MAX_DIST */ - s->block_start -= (long) wsize; - - /* Slide the hash table (could be avoided with 32 bit values - at the expense of memory usage). We slide even when level == 0 - to keep the hash table consistent if we switch back to level > 0 - later. (Using level 0 permanently is not an optimal usage of - zlib, so we don't care about this pathological case.) - */ - n = s->hash_size; - p = &s->head[n]; - do { - m = *--p; - *p = (Pos)(m >= wsize ? m-wsize : NIL); - } while (--n); - - n = wsize; -#ifndef FASTEST - p = &s->prev[n]; - do { - m = *--p; - *p = (Pos)(m >= wsize ? m-wsize : NIL); - /* If n is not on any hash chain, prev[n] is garbage but - * its value will never be used. - */ - } while (--n); -#endif - more += wsize; - } - if (s->strm->avail_in == 0) break; - - /* If there was no sliding: - * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 && - * more == window_size - lookahead - strstart - * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1) - * => more >= window_size - 2*WSIZE + 2 - * In the BIG_MEM or MMAP case (not yet supported), - * window_size == input_size + MIN_LOOKAHEAD && - * strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD. - * Otherwise, window_size == 2*WSIZE so more >= 2. - * If there was sliding, more >= WSIZE. So in all cases, more >= 2. - */ - Assert(more >= 2, "more < 2"); - - n = read_buf(s->strm, s->window + s->strstart + s->lookahead, more); - s->lookahead += n; - - /* Initialize the hash value now that we have some input: */ - if (s->lookahead + s->insert >= MIN_MATCH) { - uInt str = s->strstart - s->insert; - s->ins_h = s->window[str]; - UPDATE_HASH(s, s->ins_h, s->window[str + 1]); -#if MIN_MATCH != 3 - Call UPDATE_HASH() MIN_MATCH-3 more times -#endif - while (s->insert) { - UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); -#ifndef FASTEST - s->prev[str & s->w_mask] = s->head[s->ins_h]; -#endif - s->head[s->ins_h] = (Pos)str; - str++; - s->insert--; - if (s->lookahead + s->insert < MIN_MATCH) - break; - } - } - /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage, - * but this is not important since only literal bytes will be emitted. - */ - - } while (s->lookahead < MIN_LOOKAHEAD && s->strm->avail_in != 0); - - /* If the WIN_INIT bytes after the end of the current data have never been - * written, then zero those bytes in order to avoid memory check reports of - * the use of uninitialized (or uninitialised as Julian writes) bytes by - * the longest match routines. Update the high water mark for the next - * time through here. WIN_INIT is set to MAX_MATCH since the longest match - * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead. - */ - if (s->high_water < s->window_size) { - ulg curr = s->strstart + (ulg)(s->lookahead); - ulg init; - - if (s->high_water < curr) { - /* Previous high water mark below current data -- zero WIN_INIT - * bytes or up to end of window, whichever is less. - */ - init = s->window_size - curr; - if (init > WIN_INIT) - init = WIN_INIT; - zmemzero(s->window + curr, (unsigned)init); - s->high_water = curr + init; - } - else if (s->high_water < (ulg)curr + WIN_INIT) { - /* High water mark at or above current data, but below current data - * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up - * to end of window, whichever is less. - */ - init = (ulg)curr + WIN_INIT - s->high_water; - if (init > s->window_size - s->high_water) - init = s->window_size - s->high_water; - zmemzero(s->window + s->high_water, (unsigned)init); - s->high_water += init; - } - } - - Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD, - "not enough room for search"); -} - -/* =========================================================================== - * Flush the current block, with given end-of-file flag. - * IN assertion: strstart is set to the end of the current match. - */ -#define FLUSH_BLOCK_ONLY(s, last) { \ - _tr_flush_block(s, (s->block_start >= 0L ? \ - (charf *)&s->window[(unsigned)s->block_start] : \ - (charf *)Z_NULL), \ - (ulg)((long)s->strstart - s->block_start), \ - (last)); \ - s->block_start = s->strstart; \ - flush_pending(s->strm); \ - Tracev((stderr,"[FLUSH]")); \ -} - -/* Same but force premature exit if necessary. */ -#define FLUSH_BLOCK(s, last) { \ - FLUSH_BLOCK_ONLY(s, last); \ - if (s->strm->avail_out == 0) return (last) ? finish_started : need_more; \ -} - -/* =========================================================================== - * Copy without compression as much as possible from the input stream, return - * the current block state. - * This function does not insert new strings in the dictionary since - * uncompressible data is probably not useful. This function is used - * only for the level=0 compression option. - * NOTE: this function should be optimized to avoid extra copying from - * window to pending_buf. - */ -local block_state deflate_stored(s, flush) - deflate_state *s; - int flush; -{ - /* Stored blocks are limited to 0xffff bytes, pending_buf is limited - * to pending_buf_size, and each stored block has a 5 byte header: - */ - ulg max_block_size = 0xffff; - ulg max_start; - - if (max_block_size > s->pending_buf_size - 5) { - max_block_size = s->pending_buf_size - 5; - } - - /* Copy as much as possible from input to output: */ - for (;;) { - /* Fill the window as much as possible: */ - if (s->lookahead <= 1) { - - Assert(s->strstart < s->w_size+MAX_DIST(s) || - s->block_start >= (long)s->w_size, "slide too late"); - - fill_window(s); - if (s->lookahead == 0 && flush == Z_NO_FLUSH) return need_more; - - if (s->lookahead == 0) break; /* flush the current block */ - } - Assert(s->block_start >= 0L, "block gone"); - - s->strstart += s->lookahead; - s->lookahead = 0; - - /* Emit a stored block if pending_buf will be full: */ - max_start = s->block_start + max_block_size; - if (s->strstart == 0 || (ulg)s->strstart >= max_start) { - /* strstart == 0 is possible when wraparound on 16-bit machine */ - s->lookahead = (uInt)(s->strstart - max_start); - s->strstart = (uInt)max_start; - FLUSH_BLOCK(s, 0); - } - /* Flush if we may have to slide, otherwise block_start may become - * negative and the data will be gone: - */ - if (s->strstart - (uInt)s->block_start >= MAX_DIST(s)) { - FLUSH_BLOCK(s, 0); - } - } - s->insert = 0; - if (flush == Z_FINISH) { - FLUSH_BLOCK(s, 1); - return finish_done; - } - if ((long)s->strstart > s->block_start) - FLUSH_BLOCK(s, 0); - return block_done; -} - -/* =========================================================================== - * Compress as much as possible from the input stream, return the current - * block state. - * This function does not perform lazy evaluation of matches and inserts - * new strings in the dictionary only for unmatched strings or for short - * matches. It is used only for the fast compression options. - */ -local block_state deflate_fast(s, flush) - deflate_state *s; - int flush; -{ - IPos hash_head; /* head of the hash chain */ - int bflush; /* set if current block must be flushed */ - - for (;;) { - /* Make sure that we always have enough lookahead, except - * at the end of the input file. We need MAX_MATCH bytes - * for the next match, plus MIN_MATCH bytes to insert the - * string following the next match. - */ - if (s->lookahead < MIN_LOOKAHEAD) { - fill_window(s); - if (s->lookahead < MIN_LOOKAHEAD && flush == Z_NO_FLUSH) { - return need_more; - } - if (s->lookahead == 0) break; /* flush the current block */ - } - - /* Insert the string window[strstart .. strstart+2] in the - * dictionary, and set hash_head to the head of the hash chain: - */ - hash_head = NIL; - if (s->lookahead >= MIN_MATCH) { - INSERT_STRING(s, s->strstart, hash_head); - } - - /* Find the longest match, discarding those <= prev_length. - * At this point we have always match_length < MIN_MATCH - */ - if (hash_head != NIL && s->strstart - hash_head <= MAX_DIST(s)) { - /* To simplify the code, we prevent matches with the string - * of window index 0 (in particular we have to avoid a match - * of the string with itself at the start of the input file). - */ - s->match_length = longest_match (s, hash_head); - /* longest_match() sets match_start */ - } - if (s->match_length >= MIN_MATCH) { - check_match(s, s->strstart, s->match_start, s->match_length); - - _tr_tally_dist(s, s->strstart - s->match_start, - s->match_length - MIN_MATCH, bflush); - - s->lookahead -= s->match_length; - - /* Insert new strings in the hash table only if the match length - * is not too large. This saves time but degrades compression. - */ -#ifndef FASTEST - if (s->match_length <= s->max_insert_length && - s->lookahead >= MIN_MATCH) { - s->match_length--; /* string at strstart already in table */ - do { - s->strstart++; - INSERT_STRING(s, s->strstart, hash_head); - /* strstart never exceeds WSIZE-MAX_MATCH, so there are - * always MIN_MATCH bytes ahead. - */ - } while (--s->match_length != 0); - s->strstart++; - } else -#endif - { - s->strstart += s->match_length; - s->match_length = 0; - s->ins_h = s->window[s->strstart]; - UPDATE_HASH(s, s->ins_h, s->window[s->strstart+1]); -#if MIN_MATCH != 3 - Call UPDATE_HASH() MIN_MATCH-3 more times -#endif - /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not - * matter since it will be recomputed at next deflate call. - */ - } - } else { - /* No match, output a literal byte */ - Tracevv((stderr,"%c", s->window[s->strstart])); - _tr_tally_lit (s, s->window[s->strstart], bflush); - s->lookahead--; - s->strstart++; - } - if (bflush) FLUSH_BLOCK(s, 0); - } - s->insert = s->strstart < MIN_MATCH-1 ? s->strstart : MIN_MATCH-1; - if (flush == Z_FINISH) { - FLUSH_BLOCK(s, 1); - return finish_done; - } - if (s->last_lit) - FLUSH_BLOCK(s, 0); - return block_done; -} - -#ifndef FASTEST -/* =========================================================================== - * Same as above, but achieves better compression. We use a lazy - * evaluation for matches: a match is finally adopted only if there is - * no better match at the next window position. - */ -local block_state deflate_slow(s, flush) - deflate_state *s; - int flush; -{ - IPos hash_head; /* head of hash chain */ - int bflush; /* set if current block must be flushed */ - - /* Process the input block. */ - for (;;) { - /* Make sure that we always have enough lookahead, except - * at the end of the input file. We need MAX_MATCH bytes - * for the next match, plus MIN_MATCH bytes to insert the - * string following the next match. - */ - if (s->lookahead < MIN_LOOKAHEAD) { - fill_window(s); - if (s->lookahead < MIN_LOOKAHEAD && flush == Z_NO_FLUSH) { - return need_more; - } - if (s->lookahead == 0) break; /* flush the current block */ - } - - /* Insert the string window[strstart .. strstart+2] in the - * dictionary, and set hash_head to the head of the hash chain: - */ - hash_head = NIL; - if (s->lookahead >= MIN_MATCH) { - INSERT_STRING(s, s->strstart, hash_head); - } - - /* Find the longest match, discarding those <= prev_length. - */ - s->prev_length = s->match_length, s->prev_match = s->match_start; - s->match_length = MIN_MATCH-1; - - if (hash_head != NIL && s->prev_length < s->max_lazy_match && - s->strstart - hash_head <= MAX_DIST(s)) { - /* To simplify the code, we prevent matches with the string - * of window index 0 (in particular we have to avoid a match - * of the string with itself at the start of the input file). - */ - s->match_length = longest_match (s, hash_head); - /* longest_match() sets match_start */ - - if (s->match_length <= 5 && (s->strategy == Z_FILTERED -#if TOO_FAR <= 32767 - || (s->match_length == MIN_MATCH && - s->strstart - s->match_start > TOO_FAR) -#endif - )) { - - /* If prev_match is also MIN_MATCH, match_start is garbage - * but we will ignore the current match anyway. - */ - s->match_length = MIN_MATCH-1; - } - } - /* If there was a match at the previous step and the current - * match is not better, output the previous match: - */ - if (s->prev_length >= MIN_MATCH && s->match_length <= s->prev_length) { - uInt max_insert = s->strstart + s->lookahead - MIN_MATCH; - /* Do not insert strings in hash table beyond this. */ - - check_match(s, s->strstart-1, s->prev_match, s->prev_length); - - _tr_tally_dist(s, s->strstart -1 - s->prev_match, - s->prev_length - MIN_MATCH, bflush); - - /* Insert in hash table all strings up to the end of the match. - * strstart-1 and strstart are already inserted. If there is not - * enough lookahead, the last two strings are not inserted in - * the hash table. - */ - s->lookahead -= s->prev_length-1; - s->prev_length -= 2; - do { - if (++s->strstart <= max_insert) { - INSERT_STRING(s, s->strstart, hash_head); - } - } while (--s->prev_length != 0); - s->match_available = 0; - s->match_length = MIN_MATCH-1; - s->strstart++; - - if (bflush) FLUSH_BLOCK(s, 0); - - } else if (s->match_available) { - /* If there was no match at the previous position, output a - * single literal. If there was a match but the current match - * is longer, truncate the previous match to a single literal. - */ - Tracevv((stderr,"%c", s->window[s->strstart-1])); - _tr_tally_lit(s, s->window[s->strstart-1], bflush); - if (bflush) { - FLUSH_BLOCK_ONLY(s, 0); - } - s->strstart++; - s->lookahead--; - if (s->strm->avail_out == 0) return need_more; - } else { - /* There is no previous match to compare with, wait for - * the next step to decide. - */ - s->match_available = 1; - s->strstart++; - s->lookahead--; - } - } - Assert (flush != Z_NO_FLUSH, "no flush?"); - if (s->match_available) { - Tracevv((stderr,"%c", s->window[s->strstart-1])); - _tr_tally_lit(s, s->window[s->strstart-1], bflush); - s->match_available = 0; - } - s->insert = s->strstart < MIN_MATCH-1 ? s->strstart : MIN_MATCH-1; - if (flush == Z_FINISH) { - FLUSH_BLOCK(s, 1); - return finish_done; - } - if (s->last_lit) - FLUSH_BLOCK(s, 0); - return block_done; -} -#endif /* FASTEST */ - -/* =========================================================================== - * For Z_RLE, simply look for runs of bytes, generate matches only of distance - * one. Do not maintain a hash table. (It will be regenerated if this run of - * deflate switches away from Z_RLE.) - */ -local block_state deflate_rle(s, flush) - deflate_state *s; - int flush; -{ - int bflush; /* set if current block must be flushed */ - uInt prev; /* byte at distance one to match */ - Bytef *scan, *strend; /* scan goes up to strend for length of run */ - - for (;;) { - /* Make sure that we always have enough lookahead, except - * at the end of the input file. We need MAX_MATCH bytes - * for the longest run, plus one for the unrolled loop. - */ - if (s->lookahead <= MAX_MATCH) { - fill_window(s); - if (s->lookahead <= MAX_MATCH && flush == Z_NO_FLUSH) { - return need_more; - } - if (s->lookahead == 0) break; /* flush the current block */ - } - - /* See how many times the previous byte repeats */ - s->match_length = 0; - if (s->lookahead >= MIN_MATCH && s->strstart > 0) { - scan = s->window + s->strstart - 1; - prev = *scan; - if (prev == *++scan && prev == *++scan && prev == *++scan) { - strend = s->window + s->strstart + MAX_MATCH; - do { - } while (prev == *++scan && prev == *++scan && - prev == *++scan && prev == *++scan && - prev == *++scan && prev == *++scan && - prev == *++scan && prev == *++scan && - scan < strend); - s->match_length = MAX_MATCH - (int)(strend - scan); - if (s->match_length > s->lookahead) - s->match_length = s->lookahead; - } - Assert(scan <= s->window+(uInt)(s->window_size-1), "wild scan"); - } - - /* Emit match if have run of MIN_MATCH or longer, else emit literal */ - if (s->match_length >= MIN_MATCH) { - check_match(s, s->strstart, s->strstart - 1, s->match_length); - - _tr_tally_dist(s, 1, s->match_length - MIN_MATCH, bflush); - - s->lookahead -= s->match_length; - s->strstart += s->match_length; - s->match_length = 0; - } else { - /* No match, output a literal byte */ - Tracevv((stderr,"%c", s->window[s->strstart])); - _tr_tally_lit (s, s->window[s->strstart], bflush); - s->lookahead--; - s->strstart++; - } - if (bflush) FLUSH_BLOCK(s, 0); - } - s->insert = 0; - if (flush == Z_FINISH) { - FLUSH_BLOCK(s, 1); - return finish_done; - } - if (s->last_lit) - FLUSH_BLOCK(s, 0); - return block_done; -} - -/* =========================================================================== - * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table. - * (It will be regenerated if this run of deflate switches away from Huffman.) - */ -local block_state deflate_huff(s, flush) - deflate_state *s; - int flush; -{ - int bflush; /* set if current block must be flushed */ - - for (;;) { - /* Make sure that we have a literal to write. */ - if (s->lookahead == 0) { - fill_window(s); - if (s->lookahead == 0) { - if (flush == Z_NO_FLUSH) - return need_more; - break; /* flush the current block */ - } - } - - /* Output a literal byte */ - s->match_length = 0; - Tracevv((stderr,"%c", s->window[s->strstart])); - _tr_tally_lit (s, s->window[s->strstart], bflush); - s->lookahead--; - s->strstart++; - if (bflush) FLUSH_BLOCK(s, 0); - } - s->insert = 0; - if (flush == Z_FINISH) { - FLUSH_BLOCK(s, 1); - return finish_done; - } - if (s->last_lit) - FLUSH_BLOCK(s, 0); - return block_done; -} diff --git a/btgui/zlib/deflate.h b/btgui/zlib/deflate.h deleted file mode 100644 index ce0299edd..000000000 --- a/btgui/zlib/deflate.h +++ /dev/null @@ -1,346 +0,0 @@ -/* deflate.h -- internal compression state - * Copyright (C) 1995-2012 Jean-loup Gailly - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* WARNING: this file should *not* be used by applications. It is - part of the implementation of the compression library and is - subject to change. Applications should only use zlib.h. - */ - -/* @(#) $Id$ */ - -#ifndef DEFLATE_H -#define DEFLATE_H - -#include "zutil.h" - -/* define NO_GZIP when compiling if you want to disable gzip header and - trailer creation by deflate(). NO_GZIP would be used to avoid linking in - the crc code when it is not needed. For shared libraries, gzip encoding - should be left enabled. */ -#ifndef NO_GZIP -# define GZIP -#endif - -/* =========================================================================== - * Internal compression state. - */ - -#define LENGTH_CODES 29 -/* number of length codes, not counting the special END_BLOCK code */ - -#define LITERALS 256 -/* number of literal bytes 0..255 */ - -#define L_CODES (LITERALS+1+LENGTH_CODES) -/* number of Literal or Length codes, including the END_BLOCK code */ - -#define D_CODES 30 -/* number of distance codes */ - -#define BL_CODES 19 -/* number of codes used to transfer the bit lengths */ - -#define HEAP_SIZE (2*L_CODES+1) -/* maximum heap size */ - -#define MAX_BITS 15 -/* All codes must not exceed MAX_BITS bits */ - -#define Buf_size 16 -/* size of bit buffer in bi_buf */ - -#define INIT_STATE 42 -#define EXTRA_STATE 69 -#define NAME_STATE 73 -#define COMMENT_STATE 91 -#define HCRC_STATE 103 -#define BUSY_STATE 113 -#define FINISH_STATE 666 -/* Stream status */ - - -/* Data structure describing a single value and its code string. */ -typedef struct ct_data_s { - union { - ush freq; /* frequency count */ - ush code; /* bit string */ - } fc; - union { - ush dad; /* father node in Huffman tree */ - ush len; /* length of bit string */ - } dl; -} FAR ct_data; - -#define Freq fc.freq -#define Code fc.code -#define Dad dl.dad -#define Len dl.len - -typedef struct static_tree_desc_s static_tree_desc; - -typedef struct tree_desc_s { - ct_data *dyn_tree; /* the dynamic tree */ - int max_code; /* largest code with non zero frequency */ - static_tree_desc *stat_desc; /* the corresponding static tree */ -} FAR tree_desc; - -typedef ush Pos; -typedef Pos FAR Posf; -typedef unsigned IPos; - -/* A Pos is an index in the character window. We use short instead of int to - * save space in the various tables. IPos is used only for parameter passing. - */ - -typedef struct internal_state { - z_streamp strm; /* pointer back to this zlib stream */ - int status; /* as the name implies */ - Bytef *pending_buf; /* output still pending */ - ulg pending_buf_size; /* size of pending_buf */ - Bytef *pending_out; /* next pending byte to output to the stream */ - uInt pending; /* nb of bytes in the pending buffer */ - int wrap; /* bit 0 true for zlib, bit 1 true for gzip */ - gz_headerp gzhead; /* gzip header information to write */ - uInt gzindex; /* where in extra, name, or comment */ - Byte method; /* can only be DEFLATED */ - int last_flush; /* value of flush param for previous deflate call */ - - /* used by deflate.c: */ - - uInt w_size; /* LZ77 window size (32K by default) */ - uInt w_bits; /* log2(w_size) (8..16) */ - uInt w_mask; /* w_size - 1 */ - - Bytef *window; - /* Sliding window. Input bytes are read into the second half of the window, - * and move to the first half later to keep a dictionary of at least wSize - * bytes. With this organization, matches are limited to a distance of - * wSize-MAX_MATCH bytes, but this ensures that IO is always - * performed with a length multiple of the block size. Also, it limits - * the window size to 64K, which is quite useful on MSDOS. - * To do: use the user input buffer as sliding window. - */ - - ulg window_size; - /* Actual size of window: 2*wSize, except when the user input buffer - * is directly used as sliding window. - */ - - Posf *prev; - /* Link to older string with same hash index. To limit the size of this - * array to 64K, this link is maintained only for the last 32K strings. - * An index in this array is thus a window index modulo 32K. - */ - - Posf *head; /* Heads of the hash chains or NIL. */ - - uInt ins_h; /* hash index of string to be inserted */ - uInt hash_size; /* number of elements in hash table */ - uInt hash_bits; /* log2(hash_size) */ - uInt hash_mask; /* hash_size-1 */ - - uInt hash_shift; - /* Number of bits by which ins_h must be shifted at each input - * step. It must be such that after MIN_MATCH steps, the oldest - * byte no longer takes part in the hash key, that is: - * hash_shift * MIN_MATCH >= hash_bits - */ - - long block_start; - /* Window position at the beginning of the current output block. Gets - * negative when the window is moved backwards. - */ - - uInt match_length; /* length of best match */ - IPos prev_match; /* previous match */ - int match_available; /* set if previous match exists */ - uInt strstart; /* start of string to insert */ - uInt match_start; /* start of matching string */ - uInt lookahead; /* number of valid bytes ahead in window */ - - uInt prev_length; - /* Length of the best match at previous step. Matches not greater than this - * are discarded. This is used in the lazy match evaluation. - */ - - uInt max_chain_length; - /* To speed up deflation, hash chains are never searched beyond this - * length. A higher limit improves compression ratio but degrades the - * speed. - */ - - uInt max_lazy_match; - /* Attempt to find a better match only when the current match is strictly - * smaller than this value. This mechanism is used only for compression - * levels >= 4. - */ -# define max_insert_length max_lazy_match - /* Insert new strings in the hash table only if the match length is not - * greater than this length. This saves time but degrades compression. - * max_insert_length is used only for compression levels <= 3. - */ - - int level; /* compression level (1..9) */ - int strategy; /* favor or force Huffman coding*/ - - uInt good_match; - /* Use a faster search when the previous match is longer than this */ - - int nice_match; /* Stop searching when current match exceeds this */ - - /* used by trees.c: */ - /* Didn't use ct_data typedef below to suppress compiler warning */ - struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */ - struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */ - struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */ - - struct tree_desc_s l_desc; /* desc. for literal tree */ - struct tree_desc_s d_desc; /* desc. for distance tree */ - struct tree_desc_s bl_desc; /* desc. for bit length tree */ - - ush bl_count[MAX_BITS+1]; - /* number of codes at each bit length for an optimal tree */ - - int heap[2*L_CODES+1]; /* heap used to build the Huffman trees */ - int heap_len; /* number of elements in the heap */ - int heap_max; /* element of largest frequency */ - /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used. - * The same heap array is used to build all trees. - */ - - uch depth[2*L_CODES+1]; - /* Depth of each subtree used as tie breaker for trees of equal frequency - */ - - uchf *l_buf; /* buffer for literals or lengths */ - - uInt lit_bufsize; - /* Size of match buffer for literals/lengths. There are 4 reasons for - * limiting lit_bufsize to 64K: - * - frequencies can be kept in 16 bit counters - * - if compression is not successful for the first block, all input - * data is still in the window so we can still emit a stored block even - * when input comes from standard input. (This can also be done for - * all blocks if lit_bufsize is not greater than 32K.) - * - if compression is not successful for a file smaller than 64K, we can - * even emit a stored file instead of a stored block (saving 5 bytes). - * This is applicable only for zip (not gzip or zlib). - * - creating new Huffman trees less frequently may not provide fast - * adaptation to changes in the input data statistics. (Take for - * example a binary file with poorly compressible code followed by - * a highly compressible string table.) Smaller buffer sizes give - * fast adaptation but have of course the overhead of transmitting - * trees more frequently. - * - I can't count above 4 - */ - - uInt last_lit; /* running index in l_buf */ - - ushf *d_buf; - /* Buffer for distances. To simplify the code, d_buf and l_buf have - * the same number of elements. To use different lengths, an extra flag - * array would be necessary. - */ - - ulg opt_len; /* bit length of current block with optimal trees */ - ulg static_len; /* bit length of current block with static trees */ - uInt matches; /* number of string matches in current block */ - uInt insert; /* bytes at end of window left to insert */ - -#ifdef DEBUG - ulg compressed_len; /* total bit length of compressed file mod 2^32 */ - ulg bits_sent; /* bit length of compressed data sent mod 2^32 */ -#endif - - ush bi_buf; - /* Output buffer. bits are inserted starting at the bottom (least - * significant bits). - */ - int bi_valid; - /* Number of valid bits in bi_buf. All bits above the last valid bit - * are always zero. - */ - - ulg high_water; - /* High water mark offset in window for initialized bytes -- bytes above - * this are set to zero in order to avoid memory check warnings when - * longest match routines access bytes past the input. This is then - * updated to the new high water mark. - */ - -} FAR deflate_state; - -/* Output a byte on the stream. - * IN assertion: there is enough room in pending_buf. - */ -#define put_byte(s, c) {s->pending_buf[s->pending++] = (c);} - - -#define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1) -/* Minimum amount of lookahead, except at the end of the input file. - * See deflate.c for comments about the MIN_MATCH+1. - */ - -#define MAX_DIST(s) ((s)->w_size-MIN_LOOKAHEAD) -/* In order to simplify the code, particularly on 16 bit machines, match - * distances are limited to MAX_DIST instead of WSIZE. - */ - -#define WIN_INIT MAX_MATCH -/* Number of bytes after end of data in window to initialize in order to avoid - memory checker errors from longest match routines */ - - /* in trees.c */ -void ZLIB_INTERNAL _tr_init OF((deflate_state *s)); -int ZLIB_INTERNAL _tr_tally OF((deflate_state *s, unsigned dist, unsigned lc)); -void ZLIB_INTERNAL _tr_flush_block OF((deflate_state *s, charf *buf, - ulg stored_len, int last)); -void ZLIB_INTERNAL _tr_flush_bits OF((deflate_state *s)); -void ZLIB_INTERNAL _tr_align OF((deflate_state *s)); -void ZLIB_INTERNAL _tr_stored_block OF((deflate_state *s, charf *buf, - ulg stored_len, int last)); - -#define d_code(dist) \ - ((dist) < 256 ? _dist_code[dist] : _dist_code[256+((dist)>>7)]) -/* Mapping from a distance to a distance code. dist is the distance - 1 and - * must not have side effects. _dist_code[256] and _dist_code[257] are never - * used. - */ - -#ifndef DEBUG -/* Inline versions of _tr_tally for speed: */ - -#if defined(GEN_TREES_H) || !defined(STDC) - extern uch ZLIB_INTERNAL _length_code[]; - extern uch ZLIB_INTERNAL _dist_code[]; -#else - extern const uch ZLIB_INTERNAL _length_code[]; - extern const uch ZLIB_INTERNAL _dist_code[]; -#endif - -# define _tr_tally_lit(s, c, flush) \ - { uch cc = (c); \ - s->d_buf[s->last_lit] = 0; \ - s->l_buf[s->last_lit++] = cc; \ - s->dyn_ltree[cc].Freq++; \ - flush = (s->last_lit == s->lit_bufsize-1); \ - } -# define _tr_tally_dist(s, distance, length, flush) \ - { uch len = (length); \ - ush dist = (distance); \ - s->d_buf[s->last_lit] = dist; \ - s->l_buf[s->last_lit++] = len; \ - dist--; \ - s->dyn_ltree[_length_code[len]+LITERALS+1].Freq++; \ - s->dyn_dtree[d_code(dist)].Freq++; \ - flush = (s->last_lit == s->lit_bufsize-1); \ - } -#else -# define _tr_tally_lit(s, c, flush) flush = _tr_tally(s, 0, c) -# define _tr_tally_dist(s, distance, length, flush) \ - flush = _tr_tally(s, distance, length) -#endif - -#endif /* DEFLATE_H */ diff --git a/btgui/zlib/gzclose.c b/btgui/zlib/gzclose.c deleted file mode 100644 index caeb99a31..000000000 --- a/btgui/zlib/gzclose.c +++ /dev/null @@ -1,25 +0,0 @@ -/* gzclose.c -- zlib gzclose() function - * Copyright (C) 2004, 2010 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#include "gzguts.h" - -/* gzclose() is in a separate file so that it is linked in only if it is used. - That way the other gzclose functions can be used instead to avoid linking in - unneeded compression or decompression routines. */ -int ZEXPORT gzclose(file) - gzFile file; -{ -#ifndef NO_GZCOMPRESS - gz_statep state; - - if (file == NULL) - return Z_STREAM_ERROR; - state = (gz_statep)file; - - return state->mode == GZ_READ ? gzclose_r(file) : gzclose_w(file); -#else - return gzclose_r(file); -#endif -} diff --git a/btgui/zlib/gzguts.h b/btgui/zlib/gzguts.h deleted file mode 100644 index d87659d03..000000000 --- a/btgui/zlib/gzguts.h +++ /dev/null @@ -1,209 +0,0 @@ -/* gzguts.h -- zlib internal header definitions for gz* operations - * Copyright (C) 2004, 2005, 2010, 2011, 2012, 2013 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#ifdef _LARGEFILE64_SOURCE -# ifndef _LARGEFILE_SOURCE -# define _LARGEFILE_SOURCE 1 -# endif -# ifdef _FILE_OFFSET_BITS -# undef _FILE_OFFSET_BITS -# endif -#endif - -#ifdef HAVE_HIDDEN -# define ZLIB_INTERNAL __attribute__((visibility ("hidden"))) -#else -# define ZLIB_INTERNAL -#endif - -#include -#include "zlib.h" -#ifdef STDC -# include -# include -# include -#endif -#include - -#ifdef _WIN32 -# include -#endif - -#if defined(__TURBOC__) || defined(_MSC_VER) || defined(_WIN32) -# include -#endif - -#ifdef WINAPI_FAMILY -# define open _open -# define read _read -# define write _write -# define close _close -#endif - -#ifdef NO_DEFLATE /* for compatibility with old definition */ -# define NO_GZCOMPRESS -#endif - -#if defined(STDC99) || (defined(__TURBOC__) && __TURBOC__ >= 0x550) -# ifndef HAVE_VSNPRINTF -# define HAVE_VSNPRINTF -# endif -#endif - -#if defined(__CYGWIN__) -# ifndef HAVE_VSNPRINTF -# define HAVE_VSNPRINTF -# endif -#endif - -#if defined(MSDOS) && defined(__BORLANDC__) && (BORLANDC > 0x410) -# ifndef HAVE_VSNPRINTF -# define HAVE_VSNPRINTF -# endif -#endif - -#ifndef HAVE_VSNPRINTF -# ifdef MSDOS -/* vsnprintf may exist on some MS-DOS compilers (DJGPP?), - but for now we just assume it doesn't. */ -# define NO_vsnprintf -# endif -# ifdef __TURBOC__ -# define NO_vsnprintf -# endif -# ifdef WIN32 -/* In Win32, vsnprintf is available as the "non-ANSI" _vsnprintf. */ -# if !defined(vsnprintf) && !defined(NO_vsnprintf) -# if !defined(_MSC_VER) || ( defined(_MSC_VER) && _MSC_VER < 1500 ) -# define vsnprintf _vsnprintf -# endif -# endif -# endif -# ifdef __SASC -# define NO_vsnprintf -# endif -# ifdef VMS -# define NO_vsnprintf -# endif -# ifdef __OS400__ -# define NO_vsnprintf -# endif -# ifdef __MVS__ -# define NO_vsnprintf -# endif -#endif - -/* unlike snprintf (which is required in C99, yet still not supported by - Microsoft more than a decade later!), _snprintf does not guarantee null - termination of the result -- however this is only used in gzlib.c where - the result is assured to fit in the space provided */ -#ifdef _MSC_VER -# define snprintf _snprintf -#endif - -#ifndef local -# define local static -#endif -/* compile with -Dlocal if your debugger can't find static symbols */ - -/* gz* functions always use library allocation functions */ -#ifndef STDC - extern voidp malloc OF((uInt size)); - extern void free OF((voidpf ptr)); -#endif - -/* get errno and strerror definition */ -#if defined UNDER_CE -# include -# define zstrerror() gz_strwinerror((DWORD)GetLastError()) -#else -# ifndef NO_STRERROR -# include -# define zstrerror() strerror(errno) -# else -# define zstrerror() "stdio error (consult errno)" -# endif -#endif - -/* provide prototypes for these when building zlib without LFS */ -#if !defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0 - ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); - ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); - ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); - ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); -#endif - -/* default memLevel */ -#if MAX_MEM_LEVEL >= 8 -# define DEF_MEM_LEVEL 8 -#else -# define DEF_MEM_LEVEL MAX_MEM_LEVEL -#endif - -/* default i/o buffer size -- double this for output when reading (this and - twice this must be able to fit in an unsigned type) */ -#define GZBUFSIZE 8192 - -/* gzip modes, also provide a little integrity check on the passed structure */ -#define GZ_NONE 0 -#define GZ_READ 7247 -#define GZ_WRITE 31153 -#define GZ_APPEND 1 /* mode set to GZ_WRITE after the file is opened */ - -/* values for gz_state how */ -#define LOOK 0 /* look for a gzip header */ -#define COPY 1 /* copy input directly */ -#define GZIP 2 /* decompress a gzip stream */ - -/* internal gzip file state data structure */ -typedef struct { - /* exposed contents for gzgetc() macro */ - struct gzFile_s x; /* "x" for exposed */ - /* x.have: number of bytes available at x.next */ - /* x.next: next output data to deliver or write */ - /* x.pos: current position in uncompressed data */ - /* used for both reading and writing */ - int mode; /* see gzip modes above */ - int fd; /* file descriptor */ - char *path; /* path or fd for error messages */ - unsigned size; /* buffer size, zero if not allocated yet */ - unsigned want; /* requested buffer size, default is GZBUFSIZE */ - unsigned char *in; /* input buffer */ - unsigned char *out; /* output buffer (double-sized when reading) */ - int direct; /* 0 if processing gzip, 1 if transparent */ - /* just for reading */ - int how; /* 0: get header, 1: copy, 2: decompress */ - z_off64_t start; /* where the gzip data started, for rewinding */ - int eof; /* true if end of input file reached */ - int past; /* true if read requested past end */ - /* just for writing */ - int level; /* compression level */ - int strategy; /* compression strategy */ - /* seek request */ - z_off64_t skip; /* amount to skip (already rewound if backwards) */ - int seek; /* true if seek request pending */ - /* error information */ - int err; /* error code */ - char *msg; /* error message */ - /* zlib inflate or deflate stream */ - z_stream strm; /* stream structure in-place (not a pointer) */ -} gz_state; -typedef gz_state FAR *gz_statep; - -/* shared functions */ -void ZLIB_INTERNAL gz_error OF((gz_statep, int, const char *)); -#if defined UNDER_CE -char ZLIB_INTERNAL *gz_strwinerror OF((DWORD error)); -#endif - -/* GT_OFF(x), where x is an unsigned value, is true if x > maximum z_off64_t - value -- needed when comparing unsigned to z_off64_t, which is signed - (possible z_off64_t types off_t, off64_t, and long are all signed) */ -#ifdef INT_MAX -# define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > INT_MAX) -#else -unsigned ZLIB_INTERNAL gz_intmax OF((void)); -# define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > gz_intmax()) -#endif diff --git a/btgui/zlib/gzlib.c b/btgui/zlib/gzlib.c deleted file mode 100644 index fae202ef8..000000000 --- a/btgui/zlib/gzlib.c +++ /dev/null @@ -1,634 +0,0 @@ -/* gzlib.c -- zlib functions common to reading and writing gzip files - * Copyright (C) 2004, 2010, 2011, 2012, 2013 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#include "gzguts.h" - -#if defined(_WIN32) && !defined(__BORLANDC__) -# define LSEEK _lseeki64 -#else -#if defined(_LARGEFILE64_SOURCE) && _LFS64_LARGEFILE-0 -# define LSEEK lseek64 -#else -# define LSEEK lseek -#endif -#endif - -/* Local functions */ -local void gz_reset OF((gz_statep)); -local gzFile gz_open OF((const void *, int, const char *)); - -#if defined UNDER_CE - -/* Map the Windows error number in ERROR to a locale-dependent error message - string and return a pointer to it. Typically, the values for ERROR come - from GetLastError. - - The string pointed to shall not be modified by the application, but may be - overwritten by a subsequent call to gz_strwinerror - - The gz_strwinerror function does not change the current setting of - GetLastError. */ -char ZLIB_INTERNAL *gz_strwinerror (error) - DWORD error; -{ - static char buf[1024]; - - wchar_t *msgbuf; - DWORD lasterr = GetLastError(); - DWORD chars = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM - | FORMAT_MESSAGE_ALLOCATE_BUFFER, - NULL, - error, - 0, /* Default language */ - (LPVOID)&msgbuf, - 0, - NULL); - if (chars != 0) { - /* If there is an \r\n appended, zap it. */ - if (chars >= 2 - && msgbuf[chars - 2] == '\r' && msgbuf[chars - 1] == '\n') { - chars -= 2; - msgbuf[chars] = 0; - } - - if (chars > sizeof (buf) - 1) { - chars = sizeof (buf) - 1; - msgbuf[chars] = 0; - } - - wcstombs(buf, msgbuf, chars + 1); - LocalFree(msgbuf); - } - else { - sprintf(buf, "unknown win32 error (%ld)", error); - } - - SetLastError(lasterr); - return buf; -} - -#endif /* UNDER_CE */ - -/* Reset gzip file state */ -local void gz_reset(state) - gz_statep state; -{ - state->x.have = 0; /* no output data available */ - if (state->mode == GZ_READ) { /* for reading ... */ - state->eof = 0; /* not at end of file */ - state->past = 0; /* have not read past end yet */ - state->how = LOOK; /* look for gzip header */ - } - state->seek = 0; /* no seek request pending */ - gz_error(state, Z_OK, NULL); /* clear error */ - state->x.pos = 0; /* no uncompressed data yet */ - state->strm.avail_in = 0; /* no input data yet */ -} - -/* Open a gzip file either by name or file descriptor. */ -local gzFile gz_open(path, fd, mode) - const void *path; - int fd; - const char *mode; -{ - gz_statep state; - size_t len; - int oflag; -#ifdef O_CLOEXEC - int cloexec = 0; -#endif -#ifdef O_EXCL - int exclusive = 0; -#endif - - /* check input */ - if (path == NULL) - return NULL; - - /* allocate gzFile structure to return */ - state = (gz_statep)malloc(sizeof(gz_state)); - if (state == NULL) - return NULL; - state->size = 0; /* no buffers allocated yet */ - state->want = GZBUFSIZE; /* requested buffer size */ - state->msg = NULL; /* no error message yet */ - - /* interpret mode */ - state->mode = GZ_NONE; - state->level = Z_DEFAULT_COMPRESSION; - state->strategy = Z_DEFAULT_STRATEGY; - state->direct = 0; - while (*mode) { - if (*mode >= '0' && *mode <= '9') - state->level = *mode - '0'; - else - switch (*mode) { - case 'r': - state->mode = GZ_READ; - break; -#ifndef NO_GZCOMPRESS - case 'w': - state->mode = GZ_WRITE; - break; - case 'a': - state->mode = GZ_APPEND; - break; -#endif - case '+': /* can't read and write at the same time */ - free(state); - return NULL; - case 'b': /* ignore -- will request binary anyway */ - break; -#ifdef O_CLOEXEC - case 'e': - cloexec = 1; - break; -#endif -#ifdef O_EXCL - case 'x': - exclusive = 1; - break; -#endif - case 'f': - state->strategy = Z_FILTERED; - break; - case 'h': - state->strategy = Z_HUFFMAN_ONLY; - break; - case 'R': - state->strategy = Z_RLE; - break; - case 'F': - state->strategy = Z_FIXED; - break; - case 'T': - state->direct = 1; - break; - default: /* could consider as an error, but just ignore */ - ; - } - mode++; - } - - /* must provide an "r", "w", or "a" */ - if (state->mode == GZ_NONE) { - free(state); - return NULL; - } - - /* can't force transparent read */ - if (state->mode == GZ_READ) { - if (state->direct) { - free(state); - return NULL; - } - state->direct = 1; /* for empty file */ - } - - /* save the path name for error messages */ -#ifdef _WIN32 - if (fd == -2) { - len = wcstombs(NULL, path, 0); - if (len == (size_t)-1) - len = 0; - } - else -#endif - len = strlen((const char *)path); - state->path = (char *)malloc(len + 1); - if (state->path == NULL) { - free(state); - return NULL; - } -#ifdef _WIN32 - if (fd == -2) - if (len) - wcstombs(state->path, path, len + 1); - else - *(state->path) = 0; - else -#endif -#if !defined(NO_snprintf) && !defined(NO_vsnprintf) - snprintf(state->path, len + 1, "%s", (const char *)path); -#else - strcpy(state->path, path); -#endif - - /* compute the flags for open() */ - oflag = -#ifdef O_LARGEFILE - O_LARGEFILE | -#endif -#ifdef O_BINARY - O_BINARY | -#endif -#ifdef O_CLOEXEC - (cloexec ? O_CLOEXEC : 0) | -#endif - (state->mode == GZ_READ ? - O_RDONLY : - (O_WRONLY | O_CREAT | -#ifdef O_EXCL - (exclusive ? O_EXCL : 0) | -#endif - (state->mode == GZ_WRITE ? - O_TRUNC : - O_APPEND))); - - /* open the file with the appropriate flags (or just use fd) */ - state->fd = fd > -1 ? fd : ( -#ifdef _WIN32 - fd == -2 ? _wopen(path, oflag, 0666) : -#endif - open((const char *)path, oflag, 0666)); - if (state->fd == -1) { - free(state->path); - free(state); - return NULL; - } - if (state->mode == GZ_APPEND) - state->mode = GZ_WRITE; /* simplify later checks */ - - /* save the current position for rewinding (only if reading) */ - if (state->mode == GZ_READ) { - state->start = LSEEK(state->fd, 0, SEEK_CUR); - if (state->start == -1) state->start = 0; - } - - /* initialize stream */ - gz_reset(state); - - /* return stream */ - return (gzFile)state; -} - -/* -- see zlib.h -- */ -gzFile ZEXPORT gzopen(path, mode) - const char *path; - const char *mode; -{ - return gz_open(path, -1, mode); -} - -/* -- see zlib.h -- */ -gzFile ZEXPORT gzopen64(path, mode) - const char *path; - const char *mode; -{ - return gz_open(path, -1, mode); -} - -/* -- see zlib.h -- */ -gzFile ZEXPORT gzdopen(fd, mode) - int fd; - const char *mode; -{ - char *path; /* identifier for error messages */ - gzFile gz; - - if (fd == -1 || (path = (char *)malloc(7 + 3 * sizeof(int))) == NULL) - return NULL; -#if !defined(NO_snprintf) && !defined(NO_vsnprintf) - snprintf(path, 7 + 3 * sizeof(int), "", fd); /* for debugging */ -#else - sprintf(path, "", fd); /* for debugging */ -#endif - gz = gz_open(path, fd, mode); - free(path); - return gz; -} - -/* -- see zlib.h -- */ -#ifdef _WIN32 -gzFile ZEXPORT gzopen_w(path, mode) - const wchar_t *path; - const char *mode; -{ - return gz_open(path, -2, mode); -} -#endif - -/* -- see zlib.h -- */ -int ZEXPORT gzbuffer(file, size) - gzFile file; - unsigned size; -{ - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return -1; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return -1; - - /* make sure we haven't already allocated memory */ - if (state->size != 0) - return -1; - - /* check and set requested size */ - if (size < 2) - size = 2; /* need two bytes to check magic header */ - state->want = size; - return 0; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzrewind(file) - gzFile file; -{ - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - - /* check that we're reading and that there's no error */ - if (state->mode != GZ_READ || - (state->err != Z_OK && state->err != Z_BUF_ERROR)) - return -1; - - /* back up and start over */ - if (LSEEK(state->fd, state->start, SEEK_SET) == -1) - return -1; - gz_reset(state); - return 0; -} - -/* -- see zlib.h -- */ -z_off64_t ZEXPORT gzseek64(file, offset, whence) - gzFile file; - z_off64_t offset; - int whence; -{ - unsigned n; - z_off64_t ret; - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return -1; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return -1; - - /* check that there's no error */ - if (state->err != Z_OK && state->err != Z_BUF_ERROR) - return -1; - - /* can only seek from start or relative to current position */ - if (whence != SEEK_SET && whence != SEEK_CUR) - return -1; - - /* normalize offset to a SEEK_CUR specification */ - if (whence == SEEK_SET) - offset -= state->x.pos; - else if (state->seek) - offset += state->skip; - state->seek = 0; - - /* if within raw area while reading, just go there */ - if (state->mode == GZ_READ && state->how == COPY && - state->x.pos + offset >= 0) { - ret = LSEEK(state->fd, offset - state->x.have, SEEK_CUR); - if (ret == -1) - return -1; - state->x.have = 0; - state->eof = 0; - state->past = 0; - state->seek = 0; - gz_error(state, Z_OK, NULL); - state->strm.avail_in = 0; - state->x.pos += offset; - return state->x.pos; - } - - /* calculate skip amount, rewinding if needed for back seek when reading */ - if (offset < 0) { - if (state->mode != GZ_READ) /* writing -- can't go backwards */ - return -1; - offset += state->x.pos; - if (offset < 0) /* before start of file! */ - return -1; - if (gzrewind(file) == -1) /* rewind, then skip to offset */ - return -1; - } - - /* if reading, skip what's in output buffer (one less gzgetc() check) */ - if (state->mode == GZ_READ) { - n = GT_OFF(state->x.have) || (z_off64_t)state->x.have > offset ? - (unsigned)offset : state->x.have; - state->x.have -= n; - state->x.next += n; - state->x.pos += n; - offset -= n; - } - - /* request skip (if not zero) */ - if (offset) { - state->seek = 1; - state->skip = offset; - } - return state->x.pos + offset; -} - -/* -- see zlib.h -- */ -z_off_t ZEXPORT gzseek(file, offset, whence) - gzFile file; - z_off_t offset; - int whence; -{ - z_off64_t ret; - - ret = gzseek64(file, (z_off64_t)offset, whence); - return ret == (z_off_t)ret ? (z_off_t)ret : -1; -} - -/* -- see zlib.h -- */ -z_off64_t ZEXPORT gztell64(file) - gzFile file; -{ - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return -1; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return -1; - - /* return position */ - return state->x.pos + (state->seek ? state->skip : 0); -} - -/* -- see zlib.h -- */ -z_off_t ZEXPORT gztell(file) - gzFile file; -{ - z_off64_t ret; - - ret = gztell64(file); - return ret == (z_off_t)ret ? (z_off_t)ret : -1; -} - -/* -- see zlib.h -- */ -z_off64_t ZEXPORT gzoffset64(file) - gzFile file; -{ - z_off64_t offset; - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return -1; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return -1; - - /* compute and return effective offset in file */ - offset = LSEEK(state->fd, 0, SEEK_CUR); - if (offset == -1) - return -1; - if (state->mode == GZ_READ) /* reading */ - offset -= state->strm.avail_in; /* don't count buffered input */ - return offset; -} - -/* -- see zlib.h -- */ -z_off_t ZEXPORT gzoffset(file) - gzFile file; -{ - z_off64_t ret; - - ret = gzoffset64(file); - return ret == (z_off_t)ret ? (z_off_t)ret : -1; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzeof(file) - gzFile file; -{ - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return 0; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return 0; - - /* return end-of-file state */ - return state->mode == GZ_READ ? state->past : 0; -} - -/* -- see zlib.h -- */ -const char * ZEXPORT gzerror(file, errnum) - gzFile file; - int *errnum; -{ - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return NULL; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return NULL; - - /* return error information */ - if (errnum != NULL) - *errnum = state->err; - return state->err == Z_MEM_ERROR ? "out of memory" : - (state->msg == NULL ? "" : state->msg); -} - -/* -- see zlib.h -- */ -void ZEXPORT gzclearerr(file) - gzFile file; -{ - gz_statep state; - - /* get internal structure and check integrity */ - if (file == NULL) - return; - state = (gz_statep)file; - if (state->mode != GZ_READ && state->mode != GZ_WRITE) - return; - - /* clear error and end-of-file */ - if (state->mode == GZ_READ) { - state->eof = 0; - state->past = 0; - } - gz_error(state, Z_OK, NULL); -} - -/* Create an error message in allocated memory and set state->err and - state->msg accordingly. Free any previous error message already there. Do - not try to free or allocate space if the error is Z_MEM_ERROR (out of - memory). Simply save the error message as a static string. If there is an - allocation failure constructing the error message, then convert the error to - out of memory. */ -void ZLIB_INTERNAL gz_error(state, err, msg) - gz_statep state; - int err; - const char *msg; -{ - /* free previously allocated message and clear */ - if (state->msg != NULL) { - if (state->err != Z_MEM_ERROR) - free(state->msg); - state->msg = NULL; - } - - /* if fatal, set state->x.have to 0 so that the gzgetc() macro fails */ - if (err != Z_OK && err != Z_BUF_ERROR) - state->x.have = 0; - - /* set error code, and if no message, then done */ - state->err = err; - if (msg == NULL) - return; - - /* for an out of memory error, return literal string when requested */ - if (err == Z_MEM_ERROR) - return; - - /* construct error message with path */ - if ((state->msg = (char *)malloc(strlen(state->path) + strlen(msg) + 3)) == - NULL) { - state->err = Z_MEM_ERROR; - return; - } -#if !defined(NO_snprintf) && !defined(NO_vsnprintf) - snprintf(state->msg, strlen(state->path) + strlen(msg) + 3, - "%s%s%s", state->path, ": ", msg); -#else - strcpy(state->msg, state->path); - strcat(state->msg, ": "); - strcat(state->msg, msg); -#endif - return; -} - -#ifndef INT_MAX -/* portably return maximum value for an int (when limits.h presumed not - available) -- we need to do this to cover cases where 2's complement not - used, since C standard permits 1's complement and sign-bit representations, - otherwise we could just use ((unsigned)-1) >> 1 */ -unsigned ZLIB_INTERNAL gz_intmax() -{ - unsigned p, q; - - p = 1; - do { - q = p; - p <<= 1; - p++; - } while (p > q); - return q >> 1; -} -#endif diff --git a/btgui/zlib/gzread.c b/btgui/zlib/gzread.c deleted file mode 100644 index bf4538eb2..000000000 --- a/btgui/zlib/gzread.c +++ /dev/null @@ -1,594 +0,0 @@ -/* gzread.c -- zlib functions for reading gzip files - * Copyright (C) 2004, 2005, 2010, 2011, 2012, 2013 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#include "gzguts.h" - -/* Local functions */ -local int gz_load OF((gz_statep, unsigned char *, unsigned, unsigned *)); -local int gz_avail OF((gz_statep)); -local int gz_look OF((gz_statep)); -local int gz_decomp OF((gz_statep)); -local int gz_fetch OF((gz_statep)); -local int gz_skip OF((gz_statep, z_off64_t)); - -/* Use read() to load a buffer -- return -1 on error, otherwise 0. Read from - state->fd, and update state->eof, state->err, and state->msg as appropriate. - This function needs to loop on read(), since read() is not guaranteed to - read the number of bytes requested, depending on the type of descriptor. */ -local int gz_load(state, buf, len, have) - gz_statep state; - unsigned char *buf; - unsigned len; - unsigned *have; -{ - int ret; - - *have = 0; - do { - ret = read(state->fd, buf + *have, len - *have); - if (ret <= 0) - break; - *have += ret; - } while (*have < len); - if (ret < 0) { - gz_error(state, Z_ERRNO, zstrerror()); - return -1; - } - if (ret == 0) - state->eof = 1; - return 0; -} - -/* Load up input buffer and set eof flag if last data loaded -- return -1 on - error, 0 otherwise. Note that the eof flag is set when the end of the input - file is reached, even though there may be unused data in the buffer. Once - that data has been used, no more attempts will be made to read the file. - If strm->avail_in != 0, then the current data is moved to the beginning of - the input buffer, and then the remainder of the buffer is loaded with the - available data from the input file. */ -local int gz_avail(state) - gz_statep state; -{ - unsigned got; - z_streamp strm = &(state->strm); - - if (state->err != Z_OK && state->err != Z_BUF_ERROR) - return -1; - if (state->eof == 0) { - if (strm->avail_in) { /* copy what's there to the start */ - unsigned char *p = state->in; - unsigned const char *q = strm->next_in; - unsigned n = strm->avail_in; - do { - *p++ = *q++; - } while (--n); - } - if (gz_load(state, state->in + strm->avail_in, - state->size - strm->avail_in, &got) == -1) - return -1; - strm->avail_in += got; - strm->next_in = state->in; - } - return 0; -} - -/* Look for gzip header, set up for inflate or copy. state->x.have must be 0. - If this is the first time in, allocate required memory. state->how will be - left unchanged if there is no more input data available, will be set to COPY - if there is no gzip header and direct copying will be performed, or it will - be set to GZIP for decompression. If direct copying, then leftover input - data from the input buffer will be copied to the output buffer. In that - case, all further file reads will be directly to either the output buffer or - a user buffer. If decompressing, the inflate state will be initialized. - gz_look() will return 0 on success or -1 on failure. */ -local int gz_look(state) - gz_statep state; -{ - z_streamp strm = &(state->strm); - - /* allocate read buffers and inflate memory */ - if (state->size == 0) { - /* allocate buffers */ - state->in = (unsigned char *)malloc(state->want); - state->out = (unsigned char *)malloc(state->want << 1); - if (state->in == NULL || state->out == NULL) { - if (state->out != NULL) - free(state->out); - if (state->in != NULL) - free(state->in); - gz_error(state, Z_MEM_ERROR, "out of memory"); - return -1; - } - state->size = state->want; - - /* allocate inflate memory */ - state->strm.zalloc = Z_NULL; - state->strm.zfree = Z_NULL; - state->strm.opaque = Z_NULL; - state->strm.avail_in = 0; - state->strm.next_in = Z_NULL; - if (inflateInit2(&(state->strm), 15 + 16) != Z_OK) { /* gunzip */ - free(state->out); - free(state->in); - state->size = 0; - gz_error(state, Z_MEM_ERROR, "out of memory"); - return -1; - } - } - - /* get at least the magic bytes in the input buffer */ - if (strm->avail_in < 2) { - if (gz_avail(state) == -1) - return -1; - if (strm->avail_in == 0) - return 0; - } - - /* look for gzip magic bytes -- if there, do gzip decoding (note: there is - a logical dilemma here when considering the case of a partially written - gzip file, to wit, if a single 31 byte is written, then we cannot tell - whether this is a single-byte file, or just a partially written gzip - file -- for here we assume that if a gzip file is being written, then - the header will be written in a single operation, so that reading a - single byte is sufficient indication that it is not a gzip file) */ - if (strm->avail_in > 1 && - strm->next_in[0] == 31 && strm->next_in[1] == 139) { - inflateReset(strm); - state->how = GZIP; - state->direct = 0; - return 0; - } - - /* no gzip header -- if we were decoding gzip before, then this is trailing - garbage. Ignore the trailing garbage and finish. */ - if (state->direct == 0) { - strm->avail_in = 0; - state->eof = 1; - state->x.have = 0; - return 0; - } - - /* doing raw i/o, copy any leftover input to output -- this assumes that - the output buffer is larger than the input buffer, which also assures - space for gzungetc() */ - state->x.next = state->out; - if (strm->avail_in) { - memcpy(state->x.next, strm->next_in, strm->avail_in); - state->x.have = strm->avail_in; - strm->avail_in = 0; - } - state->how = COPY; - state->direct = 1; - return 0; -} - -/* Decompress from input to the provided next_out and avail_out in the state. - On return, state->x.have and state->x.next point to the just decompressed - data. If the gzip stream completes, state->how is reset to LOOK to look for - the next gzip stream or raw data, once state->x.have is depleted. Returns 0 - on success, -1 on failure. */ -local int gz_decomp(state) - gz_statep state; -{ - int ret = Z_OK; - unsigned had; - z_streamp strm = &(state->strm); - - /* fill output buffer up to end of deflate stream */ - had = strm->avail_out; - do { - /* get more input for inflate() */ - if (strm->avail_in == 0 && gz_avail(state) == -1) - return -1; - if (strm->avail_in == 0) { - gz_error(state, Z_BUF_ERROR, "unexpected end of file"); - break; - } - - /* decompress and handle errors */ - ret = inflate(strm, Z_NO_FLUSH); - if (ret == Z_STREAM_ERROR || ret == Z_NEED_DICT) { - gz_error(state, Z_STREAM_ERROR, - "internal error: inflate stream corrupt"); - return -1; - } - if (ret == Z_MEM_ERROR) { - gz_error(state, Z_MEM_ERROR, "out of memory"); - return -1; - } - if (ret == Z_DATA_ERROR) { /* deflate stream invalid */ - gz_error(state, Z_DATA_ERROR, - strm->msg == NULL ? "compressed data error" : strm->msg); - return -1; - } - } while (strm->avail_out && ret != Z_STREAM_END); - - /* update available output */ - state->x.have = had - strm->avail_out; - state->x.next = strm->next_out - state->x.have; - - /* if the gzip stream completed successfully, look for another */ - if (ret == Z_STREAM_END) - state->how = LOOK; - - /* good decompression */ - return 0; -} - -/* Fetch data and put it in the output buffer. Assumes state->x.have is 0. - Data is either copied from the input file or decompressed from the input - file depending on state->how. If state->how is LOOK, then a gzip header is - looked for to determine whether to copy or decompress. Returns -1 on error, - otherwise 0. gz_fetch() will leave state->how as COPY or GZIP unless the - end of the input file has been reached and all data has been processed. */ -local int gz_fetch(state) - gz_statep state; -{ - z_streamp strm = &(state->strm); - - do { - switch(state->how) { - case LOOK: /* -> LOOK, COPY (only if never GZIP), or GZIP */ - if (gz_look(state) == -1) - return -1; - if (state->how == LOOK) - return 0; - break; - case COPY: /* -> COPY */ - if (gz_load(state, state->out, state->size << 1, &(state->x.have)) - == -1) - return -1; - state->x.next = state->out; - return 0; - case GZIP: /* -> GZIP or LOOK (if end of gzip stream) */ - strm->avail_out = state->size << 1; - strm->next_out = state->out; - if (gz_decomp(state) == -1) - return -1; - } - } while (state->x.have == 0 && (!state->eof || strm->avail_in)); - return 0; -} - -/* Skip len uncompressed bytes of output. Return -1 on error, 0 on success. */ -local int gz_skip(state, len) - gz_statep state; - z_off64_t len; -{ - unsigned n; - - /* skip over len bytes or reach end-of-file, whichever comes first */ - while (len) - /* skip over whatever is in output buffer */ - if (state->x.have) { - n = GT_OFF(state->x.have) || (z_off64_t)state->x.have > len ? - (unsigned)len : state->x.have; - state->x.have -= n; - state->x.next += n; - state->x.pos += n; - len -= n; - } - - /* output buffer empty -- return if we're at the end of the input */ - else if (state->eof && state->strm.avail_in == 0) - break; - - /* need more data to skip -- load up output buffer */ - else { - /* get more output, looking for header if required */ - if (gz_fetch(state) == -1) - return -1; - } - return 0; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzread(file, buf, len) - gzFile file; - voidp buf; - unsigned len; -{ - unsigned got, n; - gz_statep state; - z_streamp strm; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - strm = &(state->strm); - - /* check that we're reading and that there's no (serious) error */ - if (state->mode != GZ_READ || - (state->err != Z_OK && state->err != Z_BUF_ERROR)) - return -1; - - /* since an int is returned, make sure len fits in one, otherwise return - with an error (this avoids the flaw in the interface) */ - if ((int)len < 0) { - gz_error(state, Z_DATA_ERROR, "requested length does not fit in int"); - return -1; - } - - /* if len is zero, avoid unnecessary operations */ - if (len == 0) - return 0; - - /* process a skip request */ - if (state->seek) { - state->seek = 0; - if (gz_skip(state, state->skip) == -1) - return -1; - } - - /* get len bytes to buf, or less than len if at the end */ - got = 0; - do { - /* first just try copying data from the output buffer */ - if (state->x.have) { - n = state->x.have > len ? len : state->x.have; - memcpy(buf, state->x.next, n); - state->x.next += n; - state->x.have -= n; - } - - /* output buffer empty -- return if we're at the end of the input */ - else if (state->eof && strm->avail_in == 0) { - state->past = 1; /* tried to read past end */ - break; - } - - /* need output data -- for small len or new stream load up our output - buffer */ - else if (state->how == LOOK || len < (state->size << 1)) { - /* get more output, looking for header if required */ - if (gz_fetch(state) == -1) - return -1; - continue; /* no progress yet -- go back to copy above */ - /* the copy above assures that we will leave with space in the - output buffer, allowing at least one gzungetc() to succeed */ - } - - /* large len -- read directly into user buffer */ - else if (state->how == COPY) { /* read directly */ - if (gz_load(state, (unsigned char *)buf, len, &n) == -1) - return -1; - } - - /* large len -- decompress directly into user buffer */ - else { /* state->how == GZIP */ - strm->avail_out = len; - strm->next_out = (unsigned char *)buf; - if (gz_decomp(state) == -1) - return -1; - n = state->x.have; - state->x.have = 0; - } - - /* update progress */ - len -= n; - buf = (char *)buf + n; - got += n; - state->x.pos += n; - } while (len); - - /* return number of bytes read into user buffer (will fit in int) */ - return (int)got; -} - -/* -- see zlib.h -- */ -#ifdef Z_PREFIX_SET -# undef z_gzgetc -#else -# undef gzgetc -#endif -int ZEXPORT gzgetc(file) - gzFile file; -{ - int ret; - unsigned char buf[1]; - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - - /* check that we're reading and that there's no (serious) error */ - if (state->mode != GZ_READ || - (state->err != Z_OK && state->err != Z_BUF_ERROR)) - return -1; - - /* try output buffer (no need to check for skip request) */ - if (state->x.have) { - state->x.have--; - state->x.pos++; - return *(state->x.next)++; - } - - /* nothing there -- try gzread() */ - ret = gzread(file, buf, 1); - return ret < 1 ? -1 : buf[0]; -} - -int ZEXPORT gzgetc_(file) -gzFile file; -{ - return gzgetc(file); -} - -/* -- see zlib.h -- */ -int ZEXPORT gzungetc(c, file) - int c; - gzFile file; -{ - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - - /* check that we're reading and that there's no (serious) error */ - if (state->mode != GZ_READ || - (state->err != Z_OK && state->err != Z_BUF_ERROR)) - return -1; - - /* process a skip request */ - if (state->seek) { - state->seek = 0; - if (gz_skip(state, state->skip) == -1) - return -1; - } - - /* can't push EOF */ - if (c < 0) - return -1; - - /* if output buffer empty, put byte at end (allows more pushing) */ - if (state->x.have == 0) { - state->x.have = 1; - state->x.next = state->out + (state->size << 1) - 1; - state->x.next[0] = c; - state->x.pos--; - state->past = 0; - return c; - } - - /* if no room, give up (must have already done a gzungetc()) */ - if (state->x.have == (state->size << 1)) { - gz_error(state, Z_DATA_ERROR, "out of room to push characters"); - return -1; - } - - /* slide output data if needed and insert byte before existing data */ - if (state->x.next == state->out) { - unsigned char *src = state->out + state->x.have; - unsigned char *dest = state->out + (state->size << 1); - while (src > state->out) - *--dest = *--src; - state->x.next = dest; - } - state->x.have++; - state->x.next--; - state->x.next[0] = c; - state->x.pos--; - state->past = 0; - return c; -} - -/* -- see zlib.h -- */ -char * ZEXPORT gzgets(file, buf, len) - gzFile file; - char *buf; - int len; -{ - unsigned left, n; - char *str; - unsigned char *eol; - gz_statep state; - - /* check parameters and get internal structure */ - if (file == NULL || buf == NULL || len < 1) - return NULL; - state = (gz_statep)file; - - /* check that we're reading and that there's no (serious) error */ - if (state->mode != GZ_READ || - (state->err != Z_OK && state->err != Z_BUF_ERROR)) - return NULL; - - /* process a skip request */ - if (state->seek) { - state->seek = 0; - if (gz_skip(state, state->skip) == -1) - return NULL; - } - - /* copy output bytes up to new line or len - 1, whichever comes first -- - append a terminating zero to the string (we don't check for a zero in - the contents, let the user worry about that) */ - str = buf; - left = (unsigned)len - 1; - if (left) do { - /* assure that something is in the output buffer */ - if (state->x.have == 0 && gz_fetch(state) == -1) - return NULL; /* error */ - if (state->x.have == 0) { /* end of file */ - state->past = 1; /* read past end */ - break; /* return what we have */ - } - - /* look for end-of-line in current output buffer */ - n = state->x.have > left ? left : state->x.have; - eol = (unsigned char *)memchr(state->x.next, '\n', n); - if (eol != NULL) - n = (unsigned)(eol - state->x.next) + 1; - - /* copy through end-of-line, or remainder if not found */ - memcpy(buf, state->x.next, n); - state->x.have -= n; - state->x.next += n; - state->x.pos += n; - left -= n; - buf += n; - } while (left && eol == NULL); - - /* return terminated string, or if nothing, end of file */ - if (buf == str) - return NULL; - buf[0] = 0; - return str; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzdirect(file) - gzFile file; -{ - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return 0; - state = (gz_statep)file; - - /* if the state is not known, but we can find out, then do so (this is - mainly for right after a gzopen() or gzdopen()) */ - if (state->mode == GZ_READ && state->how == LOOK && state->x.have == 0) - (void)gz_look(state); - - /* return 1 if transparent, 0 if processing a gzip stream */ - return state->direct; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzclose_r(file) - gzFile file; -{ - int ret, err; - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return Z_STREAM_ERROR; - state = (gz_statep)file; - - /* check that we're reading */ - if (state->mode != GZ_READ) - return Z_STREAM_ERROR; - - /* free memory and close file */ - if (state->size) { - inflateEnd(&(state->strm)); - free(state->out); - free(state->in); - } - err = state->err == Z_BUF_ERROR ? Z_BUF_ERROR : Z_OK; - gz_error(state, Z_OK, NULL); - free(state->path); - ret = close(state->fd); - free(state); - return ret ? Z_ERRNO : err; -} diff --git a/btgui/zlib/gzwrite.c b/btgui/zlib/gzwrite.c deleted file mode 100644 index aa767fbf6..000000000 --- a/btgui/zlib/gzwrite.c +++ /dev/null @@ -1,577 +0,0 @@ -/* gzwrite.c -- zlib functions for writing gzip files - * Copyright (C) 2004, 2005, 2010, 2011, 2012, 2013 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#include "gzguts.h" - -/* Local functions */ -local int gz_init OF((gz_statep)); -local int gz_comp OF((gz_statep, int)); -local int gz_zero OF((gz_statep, z_off64_t)); - -/* Initialize state for writing a gzip file. Mark initialization by setting - state->size to non-zero. Return -1 on failure or 0 on success. */ -local int gz_init(state) - gz_statep state; -{ - int ret; - z_streamp strm = &(state->strm); - - /* allocate input buffer */ - state->in = (unsigned char *)malloc(state->want); - if (state->in == NULL) { - gz_error(state, Z_MEM_ERROR, "out of memory"); - return -1; - } - - /* only need output buffer and deflate state if compressing */ - if (!state->direct) { - /* allocate output buffer */ - state->out = (unsigned char *)malloc(state->want); - if (state->out == NULL) { - free(state->in); - gz_error(state, Z_MEM_ERROR, "out of memory"); - return -1; - } - - /* allocate deflate memory, set up for gzip compression */ - strm->zalloc = Z_NULL; - strm->zfree = Z_NULL; - strm->opaque = Z_NULL; - ret = deflateInit2(strm, state->level, Z_DEFLATED, - MAX_WBITS + 16, DEF_MEM_LEVEL, state->strategy); - if (ret != Z_OK) { - free(state->out); - free(state->in); - gz_error(state, Z_MEM_ERROR, "out of memory"); - return -1; - } - } - - /* mark state as initialized */ - state->size = state->want; - - /* initialize write buffer if compressing */ - if (!state->direct) { - strm->avail_out = state->size; - strm->next_out = state->out; - state->x.next = strm->next_out; - } - return 0; -} - -/* Compress whatever is at avail_in and next_in and write to the output file. - Return -1 if there is an error writing to the output file, otherwise 0. - flush is assumed to be a valid deflate() flush value. If flush is Z_FINISH, - then the deflate() state is reset to start a new gzip stream. If gz->direct - is true, then simply write to the output file without compressing, and - ignore flush. */ -local int gz_comp(state, flush) - gz_statep state; - int flush; -{ - int ret, got; - unsigned have; - z_streamp strm = &(state->strm); - - /* allocate memory if this is the first time through */ - if (state->size == 0 && gz_init(state) == -1) - return -1; - - /* write directly if requested */ - if (state->direct) { - got = write(state->fd, strm->next_in, strm->avail_in); - if (got < 0 || (unsigned)got != strm->avail_in) { - gz_error(state, Z_ERRNO, zstrerror()); - return -1; - } - strm->avail_in = 0; - return 0; - } - - /* run deflate() on provided input until it produces no more output */ - ret = Z_OK; - do { - /* write out current buffer contents if full, or if flushing, but if - doing Z_FINISH then don't write until we get to Z_STREAM_END */ - if (strm->avail_out == 0 || (flush != Z_NO_FLUSH && - (flush != Z_FINISH || ret == Z_STREAM_END))) { - have = (unsigned)(strm->next_out - state->x.next); - if (have && ((got = write(state->fd, state->x.next, have)) < 0 || - (unsigned)got != have)) { - gz_error(state, Z_ERRNO, zstrerror()); - return -1; - } - if (strm->avail_out == 0) { - strm->avail_out = state->size; - strm->next_out = state->out; - } - state->x.next = strm->next_out; - } - - /* compress */ - have = strm->avail_out; - ret = deflate(strm, flush); - if (ret == Z_STREAM_ERROR) { - gz_error(state, Z_STREAM_ERROR, - "internal error: deflate stream corrupt"); - return -1; - } - have -= strm->avail_out; - } while (have); - - /* if that completed a deflate stream, allow another to start */ - if (flush == Z_FINISH) - deflateReset(strm); - - /* all done, no errors */ - return 0; -} - -/* Compress len zeros to output. Return -1 on error, 0 on success. */ -local int gz_zero(state, len) - gz_statep state; - z_off64_t len; -{ - int first; - unsigned n; - z_streamp strm = &(state->strm); - - /* consume whatever's left in the input buffer */ - if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) - return -1; - - /* compress len zeros (len guaranteed > 0) */ - first = 1; - while (len) { - n = GT_OFF(state->size) || (z_off64_t)state->size > len ? - (unsigned)len : state->size; - if (first) { - memset(state->in, 0, n); - first = 0; - } - strm->avail_in = n; - strm->next_in = state->in; - state->x.pos += n; - if (gz_comp(state, Z_NO_FLUSH) == -1) - return -1; - len -= n; - } - return 0; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzwrite(file, buf, len) - gzFile file; - voidpc buf; - unsigned len; -{ - unsigned put = len; - gz_statep state; - z_streamp strm; - - /* get internal structure */ - if (file == NULL) - return 0; - state = (gz_statep)file; - strm = &(state->strm); - - /* check that we're writing and that there's no error */ - if (state->mode != GZ_WRITE || state->err != Z_OK) - return 0; - - /* since an int is returned, make sure len fits in one, otherwise return - with an error (this avoids the flaw in the interface) */ - if ((int)len < 0) { - gz_error(state, Z_DATA_ERROR, "requested length does not fit in int"); - return 0; - } - - /* if len is zero, avoid unnecessary operations */ - if (len == 0) - return 0; - - /* allocate memory if this is the first time through */ - if (state->size == 0 && gz_init(state) == -1) - return 0; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - return 0; - } - - /* for small len, copy to input buffer, otherwise compress directly */ - if (len < state->size) { - /* copy to input buffer, compress when full */ - do { - unsigned have, copy; - - if (strm->avail_in == 0) - strm->next_in = state->in; - have = (unsigned)((strm->next_in + strm->avail_in) - state->in); - copy = state->size - have; - if (copy > len) - copy = len; - memcpy(state->in + have, buf, copy); - strm->avail_in += copy; - state->x.pos += copy; - buf = (const char *)buf + copy; - len -= copy; - if (len && gz_comp(state, Z_NO_FLUSH) == -1) - return 0; - } while (len); - } - else { - /* consume whatever's left in the input buffer */ - if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) - return 0; - - /* directly compress user buffer to file */ - strm->avail_in = len; - strm->next_in = (z_const Bytef *)buf; - state->x.pos += len; - if (gz_comp(state, Z_NO_FLUSH) == -1) - return 0; - } - - /* input was all buffered or compressed (put will fit in int) */ - return (int)put; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzputc(file, c) - gzFile file; - int c; -{ - unsigned have; - unsigned char buf[1]; - gz_statep state; - z_streamp strm; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - strm = &(state->strm); - - /* check that we're writing and that there's no error */ - if (state->mode != GZ_WRITE || state->err != Z_OK) - return -1; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - return -1; - } - - /* try writing to input buffer for speed (state->size == 0 if buffer not - initialized) */ - if (state->size) { - if (strm->avail_in == 0) - strm->next_in = state->in; - have = (unsigned)((strm->next_in + strm->avail_in) - state->in); - if (have < state->size) { - state->in[have] = c; - strm->avail_in++; - state->x.pos++; - return c & 0xff; - } - } - - /* no room in buffer or not initialized, use gz_write() */ - buf[0] = c; - if (gzwrite(file, buf, 1) != 1) - return -1; - return c & 0xff; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzputs(file, str) - gzFile file; - const char *str; -{ - int ret; - unsigned len; - - /* write string */ - len = (unsigned)strlen(str); - ret = gzwrite(file, str, len); - return ret == 0 && len != 0 ? -1 : ret; -} - -#if defined(STDC) || defined(Z_HAVE_STDARG_H) -#include - -/* -- see zlib.h -- */ -int ZEXPORTVA gzvprintf(gzFile file, const char *format, va_list va) -{ - int size, len; - gz_statep state; - z_streamp strm; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - strm = &(state->strm); - - /* check that we're writing and that there's no error */ - if (state->mode != GZ_WRITE || state->err != Z_OK) - return 0; - - /* make sure we have some buffer space */ - if (state->size == 0 && gz_init(state) == -1) - return 0; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - return 0; - } - - /* consume whatever's left in the input buffer */ - if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) - return 0; - - /* do the printf() into the input buffer, put length in len */ - size = (int)(state->size); - state->in[size - 1] = 0; -#ifdef NO_vsnprintf -# ifdef HAS_vsprintf_void - (void)vsprintf((char *)(state->in), format, va); - for (len = 0; len < size; len++) - if (state->in[len] == 0) break; -# else - len = vsprintf((char *)(state->in), format, va); -# endif -#else -# ifdef HAS_vsnprintf_void - (void)vsnprintf((char *)(state->in), size, format, va); - len = strlen((char *)(state->in)); -# else - len = vsnprintf((char *)(state->in), size, format, va); -# endif -#endif - - /* check that printf() results fit in buffer */ - if (len <= 0 || len >= (int)size || state->in[size - 1] != 0) - return 0; - - /* update buffer and position, defer compression until needed */ - strm->avail_in = (unsigned)len; - strm->next_in = state->in; - state->x.pos += len; - return len; -} - -int ZEXPORTVA gzprintf(gzFile file, const char *format, ...) -{ - va_list va; - int ret; - - va_start(va, format); - ret = gzvprintf(file, format, va); - va_end(va); - return ret; -} - -#else /* !STDC && !Z_HAVE_STDARG_H */ - -/* -- see zlib.h -- */ -int ZEXPORTVA gzprintf (file, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, - a11, a12, a13, a14, a15, a16, a17, a18, a19, a20) - gzFile file; - const char *format; - int a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, - a11, a12, a13, a14, a15, a16, a17, a18, a19, a20; -{ - int size, len; - gz_statep state; - z_streamp strm; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - strm = &(state->strm); - - /* check that can really pass pointer in ints */ - if (sizeof(int) != sizeof(void *)) - return 0; - - /* check that we're writing and that there's no error */ - if (state->mode != GZ_WRITE || state->err != Z_OK) - return 0; - - /* make sure we have some buffer space */ - if (state->size == 0 && gz_init(state) == -1) - return 0; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - return 0; - } - - /* consume whatever's left in the input buffer */ - if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) - return 0; - - /* do the printf() into the input buffer, put length in len */ - size = (int)(state->size); - state->in[size - 1] = 0; -#ifdef NO_snprintf -# ifdef HAS_sprintf_void - sprintf((char *)(state->in), format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); - for (len = 0; len < size; len++) - if (state->in[len] == 0) break; -# else - len = sprintf((char *)(state->in), format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); -# endif -#else -# ifdef HAS_snprintf_void - snprintf((char *)(state->in), size, format, a1, a2, a3, a4, a5, a6, a7, a8, - a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); - len = strlen((char *)(state->in)); -# else - len = snprintf((char *)(state->in), size, format, a1, a2, a3, a4, a5, a6, - a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, - a19, a20); -# endif -#endif - - /* check that printf() results fit in buffer */ - if (len <= 0 || len >= (int)size || state->in[size - 1] != 0) - return 0; - - /* update buffer and position, defer compression until needed */ - strm->avail_in = (unsigned)len; - strm->next_in = state->in; - state->x.pos += len; - return len; -} - -#endif - -/* -- see zlib.h -- */ -int ZEXPORT gzflush(file, flush) - gzFile file; - int flush; -{ - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return -1; - state = (gz_statep)file; - - /* check that we're writing and that there's no error */ - if (state->mode != GZ_WRITE || state->err != Z_OK) - return Z_STREAM_ERROR; - - /* check flush parameter */ - if (flush < 0 || flush > Z_FINISH) - return Z_STREAM_ERROR; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - return -1; - } - - /* compress remaining data with requested flush */ - gz_comp(state, flush); - return state->err; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzsetparams(file, level, strategy) - gzFile file; - int level; - int strategy; -{ - gz_statep state; - z_streamp strm; - - /* get internal structure */ - if (file == NULL) - return Z_STREAM_ERROR; - state = (gz_statep)file; - strm = &(state->strm); - - /* check that we're writing and that there's no error */ - if (state->mode != GZ_WRITE || state->err != Z_OK) - return Z_STREAM_ERROR; - - /* if no change is requested, then do nothing */ - if (level == state->level && strategy == state->strategy) - return Z_OK; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - return -1; - } - - /* change compression parameters for subsequent input */ - if (state->size) { - /* flush previous input with previous parameters before changing */ - if (strm->avail_in && gz_comp(state, Z_PARTIAL_FLUSH) == -1) - return state->err; - deflateParams(strm, level, strategy); - } - state->level = level; - state->strategy = strategy; - return Z_OK; -} - -/* -- see zlib.h -- */ -int ZEXPORT gzclose_w(file) - gzFile file; -{ - int ret = Z_OK; - gz_statep state; - - /* get internal structure */ - if (file == NULL) - return Z_STREAM_ERROR; - state = (gz_statep)file; - - /* check that we're writing */ - if (state->mode != GZ_WRITE) - return Z_STREAM_ERROR; - - /* check for seek request */ - if (state->seek) { - state->seek = 0; - if (gz_zero(state, state->skip) == -1) - ret = state->err; - } - - /* flush, free memory, and close file */ - if (gz_comp(state, Z_FINISH) == -1) - ret = state->err; - if (state->size) { - if (!state->direct) { - (void)deflateEnd(&(state->strm)); - free(state->out); - } - free(state->in); - } - gz_error(state, Z_OK, NULL); - free(state->path); - if (close(state->fd) == -1) - ret = Z_ERRNO; - free(state); - return ret; -} diff --git a/btgui/zlib/infback.c b/btgui/zlib/infback.c deleted file mode 100644 index f3833c2e4..000000000 --- a/btgui/zlib/infback.c +++ /dev/null @@ -1,640 +0,0 @@ -/* infback.c -- inflate using a call-back interface - * Copyright (C) 1995-2011 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* - This code is largely copied from inflate.c. Normally either infback.o or - inflate.o would be linked into an application--not both. The interface - with inffast.c is retained so that optimized assembler-coded versions of - inflate_fast() can be used with either inflate.c or infback.c. - */ - -#include "zutil.h" -#include "inftrees.h" -#include "inflate.h" -#include "inffast.h" - -/* function prototypes */ -local void fixedtables OF((struct inflate_state FAR *state)); - -/* - strm provides memory allocation functions in zalloc and zfree, or - Z_NULL to use the library memory allocation functions. - - windowBits is in the range 8..15, and window is a user-supplied - window and output buffer that is 2**windowBits bytes. - */ -int ZEXPORT inflateBackInit_(strm, windowBits, window, version, stream_size) -z_streamp strm; -int windowBits; -unsigned char FAR *window; -const char *version; -int stream_size; -{ - struct inflate_state FAR *state; - - if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || - stream_size != (int)(sizeof(z_stream))) - return Z_VERSION_ERROR; - if (strm == Z_NULL || window == Z_NULL || - windowBits < 8 || windowBits > 15) - return Z_STREAM_ERROR; - strm->msg = Z_NULL; /* in case we return an error */ - if (strm->zalloc == (alloc_func)0) { -#ifdef Z_SOLO - return Z_STREAM_ERROR; -#else - strm->zalloc = zcalloc; - strm->opaque = (voidpf)0; -#endif - } - if (strm->zfree == (free_func)0) -#ifdef Z_SOLO - return Z_STREAM_ERROR; -#else - strm->zfree = zcfree; -#endif - state = (struct inflate_state FAR *)ZALLOC(strm, 1, - sizeof(struct inflate_state)); - if (state == Z_NULL) return Z_MEM_ERROR; - Tracev((stderr, "inflate: allocated\n")); - strm->state = (struct internal_state FAR *)state; - state->dmax = 32768U; - state->wbits = windowBits; - state->wsize = 1U << windowBits; - state->window = window; - state->wnext = 0; - state->whave = 0; - return Z_OK; -} - -/* - Return state with length and distance decoding tables and index sizes set to - fixed code decoding. Normally this returns fixed tables from inffixed.h. - If BUILDFIXED is defined, then instead this routine builds the tables the - first time it's called, and returns those tables the first time and - thereafter. This reduces the size of the code by about 2K bytes, in - exchange for a little execution time. However, BUILDFIXED should not be - used for threaded applications, since the rewriting of the tables and virgin - may not be thread-safe. - */ -local void fixedtables(state) -struct inflate_state FAR *state; -{ -#ifdef BUILDFIXED - static int virgin = 1; - static code *lenfix, *distfix; - static code fixed[544]; - - /* build fixed huffman tables if first call (may not be thread safe) */ - if (virgin) { - unsigned sym, bits; - static code *next; - - /* literal/length table */ - sym = 0; - while (sym < 144) state->lens[sym++] = 8; - while (sym < 256) state->lens[sym++] = 9; - while (sym < 280) state->lens[sym++] = 7; - while (sym < 288) state->lens[sym++] = 8; - next = fixed; - lenfix = next; - bits = 9; - inflate_table(LENS, state->lens, 288, &(next), &(bits), state->work); - - /* distance table */ - sym = 0; - while (sym < 32) state->lens[sym++] = 5; - distfix = next; - bits = 5; - inflate_table(DISTS, state->lens, 32, &(next), &(bits), state->work); - - /* do this just once */ - virgin = 0; - } -#else /* !BUILDFIXED */ -# include "inffixed.h" -#endif /* BUILDFIXED */ - state->lencode = lenfix; - state->lenbits = 9; - state->distcode = distfix; - state->distbits = 5; -} - -/* Macros for inflateBack(): */ - -/* Load returned state from inflate_fast() */ -#define LOAD() \ - do { \ - put = strm->next_out; \ - left = strm->avail_out; \ - next = strm->next_in; \ - have = strm->avail_in; \ - hold = state->hold; \ - bits = state->bits; \ - } while (0) - -/* Set state from registers for inflate_fast() */ -#define RESTORE() \ - do { \ - strm->next_out = put; \ - strm->avail_out = left; \ - strm->next_in = next; \ - strm->avail_in = have; \ - state->hold = hold; \ - state->bits = bits; \ - } while (0) - -/* Clear the input bit accumulator */ -#define INITBITS() \ - do { \ - hold = 0; \ - bits = 0; \ - } while (0) - -/* Assure that some input is available. If input is requested, but denied, - then return a Z_BUF_ERROR from inflateBack(). */ -#define PULL() \ - do { \ - if (have == 0) { \ - have = in(in_desc, &next); \ - if (have == 0) { \ - next = Z_NULL; \ - ret = Z_BUF_ERROR; \ - goto inf_leave; \ - } \ - } \ - } while (0) - -/* Get a byte of input into the bit accumulator, or return from inflateBack() - with an error if there is no input available. */ -#define PULLBYTE() \ - do { \ - PULL(); \ - have--; \ - hold += (unsigned long)(*next++) << bits; \ - bits += 8; \ - } while (0) - -/* Assure that there are at least n bits in the bit accumulator. If there is - not enough available input to do that, then return from inflateBack() with - an error. */ -#define NEEDBITS(n) \ - do { \ - while (bits < (unsigned)(n)) \ - PULLBYTE(); \ - } while (0) - -/* Return the low n bits of the bit accumulator (n < 16) */ -#define BITS(n) \ - ((unsigned)hold & ((1U << (n)) - 1)) - -/* Remove n bits from the bit accumulator */ -#define DROPBITS(n) \ - do { \ - hold >>= (n); \ - bits -= (unsigned)(n); \ - } while (0) - -/* Remove zero to seven bits as needed to go to a byte boundary */ -#define BYTEBITS() \ - do { \ - hold >>= bits & 7; \ - bits -= bits & 7; \ - } while (0) - -/* Assure that some output space is available, by writing out the window - if it's full. If the write fails, return from inflateBack() with a - Z_BUF_ERROR. */ -#define ROOM() \ - do { \ - if (left == 0) { \ - put = state->window; \ - left = state->wsize; \ - state->whave = left; \ - if (out(out_desc, put, left)) { \ - ret = Z_BUF_ERROR; \ - goto inf_leave; \ - } \ - } \ - } while (0) - -/* - strm provides the memory allocation functions and window buffer on input, - and provides information on the unused input on return. For Z_DATA_ERROR - returns, strm will also provide an error message. - - in() and out() are the call-back input and output functions. When - inflateBack() needs more input, it calls in(). When inflateBack() has - filled the window with output, or when it completes with data in the - window, it calls out() to write out the data. The application must not - change the provided input until in() is called again or inflateBack() - returns. The application must not change the window/output buffer until - inflateBack() returns. - - in() and out() are called with a descriptor parameter provided in the - inflateBack() call. This parameter can be a structure that provides the - information required to do the read or write, as well as accumulated - information on the input and output such as totals and check values. - - in() should return zero on failure. out() should return non-zero on - failure. If either in() or out() fails, than inflateBack() returns a - Z_BUF_ERROR. strm->next_in can be checked for Z_NULL to see whether it - was in() or out() that caused in the error. Otherwise, inflateBack() - returns Z_STREAM_END on success, Z_DATA_ERROR for an deflate format - error, or Z_MEM_ERROR if it could not allocate memory for the state. - inflateBack() can also return Z_STREAM_ERROR if the input parameters - are not correct, i.e. strm is Z_NULL or the state was not initialized. - */ -int ZEXPORT inflateBack(strm, in, in_desc, out, out_desc) -z_streamp strm; -in_func in; -void FAR *in_desc; -out_func out; -void FAR *out_desc; -{ - struct inflate_state FAR *state; - z_const unsigned char FAR *next; /* next input */ - unsigned char FAR *put; /* next output */ - unsigned have, left; /* available input and output */ - unsigned long hold; /* bit buffer */ - unsigned bits; /* bits in bit buffer */ - unsigned copy; /* number of stored or match bytes to copy */ - unsigned char FAR *from; /* where to copy match bytes from */ - code here; /* current decoding table entry */ - code last; /* parent table entry */ - unsigned len; /* length to copy for repeats, bits to drop */ - int ret; /* return code */ - static const unsigned short order[19] = /* permutation of code lengths */ - {16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; - - /* Check that the strm exists and that the state was initialized */ - if (strm == Z_NULL || strm->state == Z_NULL) - return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - - /* Reset the state */ - strm->msg = Z_NULL; - state->mode = TYPE; - state->last = 0; - state->whave = 0; - next = strm->next_in; - have = next != Z_NULL ? strm->avail_in : 0; - hold = 0; - bits = 0; - put = state->window; - left = state->wsize; - - /* Inflate until end of block marked as last */ - for (;;) - switch (state->mode) { - case TYPE: - /* determine and dispatch block type */ - if (state->last) { - BYTEBITS(); - state->mode = DONE; - break; - } - NEEDBITS(3); - state->last = BITS(1); - DROPBITS(1); - switch (BITS(2)) { - case 0: /* stored block */ - Tracev((stderr, "inflate: stored block%s\n", - state->last ? " (last)" : "")); - state->mode = STORED; - break; - case 1: /* fixed block */ - fixedtables(state); - Tracev((stderr, "inflate: fixed codes block%s\n", - state->last ? " (last)" : "")); - state->mode = LEN; /* decode codes */ - break; - case 2: /* dynamic block */ - Tracev((stderr, "inflate: dynamic codes block%s\n", - state->last ? " (last)" : "")); - state->mode = TABLE; - break; - case 3: - strm->msg = (char *)"invalid block type"; - state->mode = BAD; - } - DROPBITS(2); - break; - - case STORED: - /* get and verify stored block length */ - BYTEBITS(); /* go to byte boundary */ - NEEDBITS(32); - if ((hold & 0xffff) != ((hold >> 16) ^ 0xffff)) { - strm->msg = (char *)"invalid stored block lengths"; - state->mode = BAD; - break; - } - state->length = (unsigned)hold & 0xffff; - Tracev((stderr, "inflate: stored length %u\n", - state->length)); - INITBITS(); - - /* copy stored block from input to output */ - while (state->length != 0) { - copy = state->length; - PULL(); - ROOM(); - if (copy > have) copy = have; - if (copy > left) copy = left; - zmemcpy(put, next, copy); - have -= copy; - next += copy; - left -= copy; - put += copy; - state->length -= copy; - } - Tracev((stderr, "inflate: stored end\n")); - state->mode = TYPE; - break; - - case TABLE: - /* get dynamic table entries descriptor */ - NEEDBITS(14); - state->nlen = BITS(5) + 257; - DROPBITS(5); - state->ndist = BITS(5) + 1; - DROPBITS(5); - state->ncode = BITS(4) + 4; - DROPBITS(4); -#ifndef PKZIP_BUG_WORKAROUND - if (state->nlen > 286 || state->ndist > 30) { - strm->msg = (char *)"too many length or distance symbols"; - state->mode = BAD; - break; - } -#endif - Tracev((stderr, "inflate: table sizes ok\n")); - - /* get code length code lengths (not a typo) */ - state->have = 0; - while (state->have < state->ncode) { - NEEDBITS(3); - state->lens[order[state->have++]] = (unsigned short)BITS(3); - DROPBITS(3); - } - while (state->have < 19) - state->lens[order[state->have++]] = 0; - state->next = state->codes; - state->lencode = (code const FAR *)(state->next); - state->lenbits = 7; - ret = inflate_table(CODES, state->lens, 19, &(state->next), - &(state->lenbits), state->work); - if (ret) { - strm->msg = (char *)"invalid code lengths set"; - state->mode = BAD; - break; - } - Tracev((stderr, "inflate: code lengths ok\n")); - - /* get length and distance code code lengths */ - state->have = 0; - while (state->have < state->nlen + state->ndist) { - for (;;) { - here = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(here.bits) <= bits) break; - PULLBYTE(); - } - if (here.val < 16) { - DROPBITS(here.bits); - state->lens[state->have++] = here.val; - } - else { - if (here.val == 16) { - NEEDBITS(here.bits + 2); - DROPBITS(here.bits); - if (state->have == 0) { - strm->msg = (char *)"invalid bit length repeat"; - state->mode = BAD; - break; - } - len = (unsigned)(state->lens[state->have - 1]); - copy = 3 + BITS(2); - DROPBITS(2); - } - else if (here.val == 17) { - NEEDBITS(here.bits + 3); - DROPBITS(here.bits); - len = 0; - copy = 3 + BITS(3); - DROPBITS(3); - } - else { - NEEDBITS(here.bits + 7); - DROPBITS(here.bits); - len = 0; - copy = 11 + BITS(7); - DROPBITS(7); - } - if (state->have + copy > state->nlen + state->ndist) { - strm->msg = (char *)"invalid bit length repeat"; - state->mode = BAD; - break; - } - while (copy--) - state->lens[state->have++] = (unsigned short)len; - } - } - - /* handle error breaks in while */ - if (state->mode == BAD) break; - - /* check for end-of-block code (better have one) */ - if (state->lens[256] == 0) { - strm->msg = (char *)"invalid code -- missing end-of-block"; - state->mode = BAD; - break; - } - - /* build code tables -- note: do not change the lenbits or distbits - values here (9 and 6) without reading the comments in inftrees.h - concerning the ENOUGH constants, which depend on those values */ - state->next = state->codes; - state->lencode = (code const FAR *)(state->next); - state->lenbits = 9; - ret = inflate_table(LENS, state->lens, state->nlen, &(state->next), - &(state->lenbits), state->work); - if (ret) { - strm->msg = (char *)"invalid literal/lengths set"; - state->mode = BAD; - break; - } - state->distcode = (code const FAR *)(state->next); - state->distbits = 6; - ret = inflate_table(DISTS, state->lens + state->nlen, state->ndist, - &(state->next), &(state->distbits), state->work); - if (ret) { - strm->msg = (char *)"invalid distances set"; - state->mode = BAD; - break; - } - Tracev((stderr, "inflate: codes ok\n")); - state->mode = LEN; - - case LEN: - /* use inflate_fast() if we have enough input and output */ - if (have >= 6 && left >= 258) { - RESTORE(); - if (state->whave < state->wsize) - state->whave = state->wsize - left; - inflate_fast(strm, state->wsize); - LOAD(); - break; - } - - /* get a literal, length, or end-of-block code */ - for (;;) { - here = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(here.bits) <= bits) break; - PULLBYTE(); - } - if (here.op && (here.op & 0xf0) == 0) { - last = here; - for (;;) { - here = state->lencode[last.val + - (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + here.bits) <= bits) break; - PULLBYTE(); - } - DROPBITS(last.bits); - } - DROPBITS(here.bits); - state->length = (unsigned)here.val; - - /* process literal */ - if (here.op == 0) { - Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? - "inflate: literal '%c'\n" : - "inflate: literal 0x%02x\n", here.val)); - ROOM(); - *put++ = (unsigned char)(state->length); - left--; - state->mode = LEN; - break; - } - - /* process end of block */ - if (here.op & 32) { - Tracevv((stderr, "inflate: end of block\n")); - state->mode = TYPE; - break; - } - - /* invalid code */ - if (here.op & 64) { - strm->msg = (char *)"invalid literal/length code"; - state->mode = BAD; - break; - } - - /* length code -- get extra bits, if any */ - state->extra = (unsigned)(here.op) & 15; - if (state->extra != 0) { - NEEDBITS(state->extra); - state->length += BITS(state->extra); - DROPBITS(state->extra); - } - Tracevv((stderr, "inflate: length %u\n", state->length)); - - /* get distance code */ - for (;;) { - here = state->distcode[BITS(state->distbits)]; - if ((unsigned)(here.bits) <= bits) break; - PULLBYTE(); - } - if ((here.op & 0xf0) == 0) { - last = here; - for (;;) { - here = state->distcode[last.val + - (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + here.bits) <= bits) break; - PULLBYTE(); - } - DROPBITS(last.bits); - } - DROPBITS(here.bits); - if (here.op & 64) { - strm->msg = (char *)"invalid distance code"; - state->mode = BAD; - break; - } - state->offset = (unsigned)here.val; - - /* get distance extra bits, if any */ - state->extra = (unsigned)(here.op) & 15; - if (state->extra != 0) { - NEEDBITS(state->extra); - state->offset += BITS(state->extra); - DROPBITS(state->extra); - } - if (state->offset > state->wsize - (state->whave < state->wsize ? - left : 0)) { - strm->msg = (char *)"invalid distance too far back"; - state->mode = BAD; - break; - } - Tracevv((stderr, "inflate: distance %u\n", state->offset)); - - /* copy match from window to output */ - do { - ROOM(); - copy = state->wsize - state->offset; - if (copy < left) { - from = put + copy; - copy = left - copy; - } - else { - from = put - state->offset; - copy = left; - } - if (copy > state->length) copy = state->length; - state->length -= copy; - left -= copy; - do { - *put++ = *from++; - } while (--copy); - } while (state->length != 0); - break; - - case DONE: - /* inflate stream terminated properly -- write leftover output */ - ret = Z_STREAM_END; - if (left < state->wsize) { - if (out(out_desc, state->window, state->wsize - left)) - ret = Z_BUF_ERROR; - } - goto inf_leave; - - case BAD: - ret = Z_DATA_ERROR; - goto inf_leave; - - default: /* can't happen, but makes compilers happy */ - ret = Z_STREAM_ERROR; - goto inf_leave; - } - - /* Return unused input */ - inf_leave: - strm->next_in = next; - strm->avail_in = have; - return ret; -} - -int ZEXPORT inflateBackEnd(strm) -z_streamp strm; -{ - if (strm == Z_NULL || strm->state == Z_NULL || strm->zfree == (free_func)0) - return Z_STREAM_ERROR; - ZFREE(strm, strm->state); - strm->state = Z_NULL; - Tracev((stderr, "inflate: end\n")); - return Z_OK; -} diff --git a/btgui/zlib/inffast.c b/btgui/zlib/inffast.c deleted file mode 100644 index bda59ceb6..000000000 --- a/btgui/zlib/inffast.c +++ /dev/null @@ -1,340 +0,0 @@ -/* inffast.c -- fast decoding - * Copyright (C) 1995-2008, 2010, 2013 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#include "zutil.h" -#include "inftrees.h" -#include "inflate.h" -#include "inffast.h" - -#ifndef ASMINF - -/* Allow machine dependent optimization for post-increment or pre-increment. - Based on testing to date, - Pre-increment preferred for: - - PowerPC G3 (Adler) - - MIPS R5000 (Randers-Pehrson) - Post-increment preferred for: - - none - No measurable difference: - - Pentium III (Anderson) - - M68060 (Nikl) - */ -#ifdef POSTINC -# define OFF 0 -# define PUP(a) *(a)++ -#else -# define OFF 1 -# define PUP(a) *++(a) -#endif - -/* - Decode literal, length, and distance codes and write out the resulting - literal and match bytes until either not enough input or output is - available, an end-of-block is encountered, or a data error is encountered. - When large enough input and output buffers are supplied to inflate(), for - example, a 16K input buffer and a 64K output buffer, more than 95% of the - inflate execution time is spent in this routine. - - Entry assumptions: - - state->mode == LEN - strm->avail_in >= 6 - strm->avail_out >= 258 - start >= strm->avail_out - state->bits < 8 - - On return, state->mode is one of: - - LEN -- ran out of enough output space or enough available input - TYPE -- reached end of block code, inflate() to interpret next block - BAD -- error in block data - - Notes: - - - The maximum input bits used by a length/distance pair is 15 bits for the - length code, 5 bits for the length extra, 15 bits for the distance code, - and 13 bits for the distance extra. This totals 48 bits, or six bytes. - Therefore if strm->avail_in >= 6, then there is enough input to avoid - checking for available input while decoding. - - - The maximum bytes that a single length/distance pair can output is 258 - bytes, which is the maximum length that can be coded. inflate_fast() - requires strm->avail_out >= 258 for each loop to avoid checking for - output space. - */ -void ZLIB_INTERNAL inflate_fast(strm, start) -z_streamp strm; -unsigned start; /* inflate()'s starting value for strm->avail_out */ -{ - struct inflate_state FAR *state; - z_const unsigned char FAR *in; /* local strm->next_in */ - z_const unsigned char FAR *last; /* have enough input while in < last */ - unsigned char FAR *out; /* local strm->next_out */ - unsigned char FAR *beg; /* inflate()'s initial strm->next_out */ - unsigned char FAR *end; /* while out < end, enough space available */ -#ifdef INFLATE_STRICT - unsigned dmax; /* maximum distance from zlib header */ -#endif - unsigned wsize; /* window size or zero if not using window */ - unsigned whave; /* valid bytes in the window */ - unsigned wnext; /* window write index */ - unsigned char FAR *window; /* allocated sliding window, if wsize != 0 */ - unsigned long hold; /* local strm->hold */ - unsigned bits; /* local strm->bits */ - code const FAR *lcode; /* local strm->lencode */ - code const FAR *dcode; /* local strm->distcode */ - unsigned lmask; /* mask for first level of length codes */ - unsigned dmask; /* mask for first level of distance codes */ - code here; /* retrieved table entry */ - unsigned op; /* code bits, operation, extra bits, or */ - /* window position, window bytes to copy */ - unsigned len; /* match length, unused bytes */ - unsigned dist; /* match distance */ - unsigned char FAR *from; /* where to copy match from */ - - /* copy state to local variables */ - state = (struct inflate_state FAR *)strm->state; - in = strm->next_in - OFF; - last = in + (strm->avail_in - 5); - out = strm->next_out - OFF; - beg = out - (start - strm->avail_out); - end = out + (strm->avail_out - 257); -#ifdef INFLATE_STRICT - dmax = state->dmax; -#endif - wsize = state->wsize; - whave = state->whave; - wnext = state->wnext; - window = state->window; - hold = state->hold; - bits = state->bits; - lcode = state->lencode; - dcode = state->distcode; - lmask = (1U << state->lenbits) - 1; - dmask = (1U << state->distbits) - 1; - - /* decode literals and length/distances until end-of-block or not enough - input data or output space */ - do { - if (bits < 15) { - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - } - here = lcode[hold & lmask]; - dolen: - op = (unsigned)(here.bits); - hold >>= op; - bits -= op; - op = (unsigned)(here.op); - if (op == 0) { /* literal */ - Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? - "inflate: literal '%c'\n" : - "inflate: literal 0x%02x\n", here.val)); - PUP(out) = (unsigned char)(here.val); - } - else if (op & 16) { /* length base */ - len = (unsigned)(here.val); - op &= 15; /* number of extra bits */ - if (op) { - if (bits < op) { - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - } - len += (unsigned)hold & ((1U << op) - 1); - hold >>= op; - bits -= op; - } - Tracevv((stderr, "inflate: length %u\n", len)); - if (bits < 15) { - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - } - here = dcode[hold & dmask]; - dodist: - op = (unsigned)(here.bits); - hold >>= op; - bits -= op; - op = (unsigned)(here.op); - if (op & 16) { /* distance base */ - dist = (unsigned)(here.val); - op &= 15; /* number of extra bits */ - if (bits < op) { - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - if (bits < op) { - hold += (unsigned long)(PUP(in)) << bits; - bits += 8; - } - } - dist += (unsigned)hold & ((1U << op) - 1); -#ifdef INFLATE_STRICT - if (dist > dmax) { - strm->msg = (char *)"invalid distance too far back"; - state->mode = BAD; - break; - } -#endif - hold >>= op; - bits -= op; - Tracevv((stderr, "inflate: distance %u\n", dist)); - op = (unsigned)(out - beg); /* max distance in output */ - if (dist > op) { /* see if copy from window */ - op = dist - op; /* distance back in window */ - if (op > whave) { - if (state->sane) { - strm->msg = - (char *)"invalid distance too far back"; - state->mode = BAD; - break; - } -#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR - if (len <= op - whave) { - do { - PUP(out) = 0; - } while (--len); - continue; - } - len -= op - whave; - do { - PUP(out) = 0; - } while (--op > whave); - if (op == 0) { - from = out - dist; - do { - PUP(out) = PUP(from); - } while (--len); - continue; - } -#endif - } - from = window - OFF; - if (wnext == 0) { /* very common case */ - from += wsize - op; - if (op < len) { /* some from window */ - len -= op; - do { - PUP(out) = PUP(from); - } while (--op); - from = out - dist; /* rest from output */ - } - } - else if (wnext < op) { /* wrap around window */ - from += wsize + wnext - op; - op -= wnext; - if (op < len) { /* some from end of window */ - len -= op; - do { - PUP(out) = PUP(from); - } while (--op); - from = window - OFF; - if (wnext < len) { /* some from start of window */ - op = wnext; - len -= op; - do { - PUP(out) = PUP(from); - } while (--op); - from = out - dist; /* rest from output */ - } - } - } - else { /* contiguous in window */ - from += wnext - op; - if (op < len) { /* some from window */ - len -= op; - do { - PUP(out) = PUP(from); - } while (--op); - from = out - dist; /* rest from output */ - } - } - while (len > 2) { - PUP(out) = PUP(from); - PUP(out) = PUP(from); - PUP(out) = PUP(from); - len -= 3; - } - if (len) { - PUP(out) = PUP(from); - if (len > 1) - PUP(out) = PUP(from); - } - } - else { - from = out - dist; /* copy direct from output */ - do { /* minimum length is three */ - PUP(out) = PUP(from); - PUP(out) = PUP(from); - PUP(out) = PUP(from); - len -= 3; - } while (len > 2); - if (len) { - PUP(out) = PUP(from); - if (len > 1) - PUP(out) = PUP(from); - } - } - } - else if ((op & 64) == 0) { /* 2nd level distance code */ - here = dcode[here.val + (hold & ((1U << op) - 1))]; - goto dodist; - } - else { - strm->msg = (char *)"invalid distance code"; - state->mode = BAD; - break; - } - } - else if ((op & 64) == 0) { /* 2nd level length code */ - here = lcode[here.val + (hold & ((1U << op) - 1))]; - goto dolen; - } - else if (op & 32) { /* end-of-block */ - Tracevv((stderr, "inflate: end of block\n")); - state->mode = TYPE; - break; - } - else { - strm->msg = (char *)"invalid literal/length code"; - state->mode = BAD; - break; - } - } while (in < last && out < end); - - /* return unused bytes (on entry, bits < 8, so in won't go too far back) */ - len = bits >> 3; - in -= len; - bits -= len << 3; - hold &= (1U << bits) - 1; - - /* update state and return */ - strm->next_in = in + OFF; - strm->next_out = out + OFF; - strm->avail_in = (unsigned)(in < last ? 5 + (last - in) : 5 - (in - last)); - strm->avail_out = (unsigned)(out < end ? - 257 + (end - out) : 257 - (out - end)); - state->hold = hold; - state->bits = bits; - return; -} - -/* - inflate_fast() speedups that turned out slower (on a PowerPC G3 750CXe): - - Using bit fields for code structure - - Different op definition to avoid & for extra bits (do & for table bits) - - Three separate decoding do-loops for direct, window, and wnext == 0 - - Special case for distance > 1 copies to do overlapped load and store copy - - Explicit branch predictions (based on measured branch probabilities) - - Deferring match copy and interspersed it with decoding subsequent codes - - Swapping literal/length else - - Swapping window/direct else - - Larger unrolled copy loops (three is about right) - - Moving len -= 3 statement into middle of loop - */ - -#endif /* !ASMINF */ diff --git a/btgui/zlib/inffast.h b/btgui/zlib/inffast.h deleted file mode 100644 index e5c1aa4ca..000000000 --- a/btgui/zlib/inffast.h +++ /dev/null @@ -1,11 +0,0 @@ -/* inffast.h -- header to use inffast.c - * Copyright (C) 1995-2003, 2010 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* WARNING: this file should *not* be used by applications. It is - part of the implementation of the compression library and is - subject to change. Applications should only use zlib.h. - */ - -void ZLIB_INTERNAL inflate_fast OF((z_streamp strm, unsigned start)); diff --git a/btgui/zlib/inffixed.h b/btgui/zlib/inffixed.h deleted file mode 100644 index d62832776..000000000 --- a/btgui/zlib/inffixed.h +++ /dev/null @@ -1,94 +0,0 @@ - /* inffixed.h -- table for decoding fixed codes - * Generated automatically by makefixed(). - */ - - /* WARNING: this file should *not* be used by applications. - It is part of the implementation of this library and is - subject to change. Applications should only use zlib.h. - */ - - static const code lenfix[512] = { - {96,7,0},{0,8,80},{0,8,16},{20,8,115},{18,7,31},{0,8,112},{0,8,48}, - {0,9,192},{16,7,10},{0,8,96},{0,8,32},{0,9,160},{0,8,0},{0,8,128}, - {0,8,64},{0,9,224},{16,7,6},{0,8,88},{0,8,24},{0,9,144},{19,7,59}, - {0,8,120},{0,8,56},{0,9,208},{17,7,17},{0,8,104},{0,8,40},{0,9,176}, - {0,8,8},{0,8,136},{0,8,72},{0,9,240},{16,7,4},{0,8,84},{0,8,20}, - {21,8,227},{19,7,43},{0,8,116},{0,8,52},{0,9,200},{17,7,13},{0,8,100}, - {0,8,36},{0,9,168},{0,8,4},{0,8,132},{0,8,68},{0,9,232},{16,7,8}, - {0,8,92},{0,8,28},{0,9,152},{20,7,83},{0,8,124},{0,8,60},{0,9,216}, - {18,7,23},{0,8,108},{0,8,44},{0,9,184},{0,8,12},{0,8,140},{0,8,76}, - {0,9,248},{16,7,3},{0,8,82},{0,8,18},{21,8,163},{19,7,35},{0,8,114}, - {0,8,50},{0,9,196},{17,7,11},{0,8,98},{0,8,34},{0,9,164},{0,8,2}, - {0,8,130},{0,8,66},{0,9,228},{16,7,7},{0,8,90},{0,8,26},{0,9,148}, - {20,7,67},{0,8,122},{0,8,58},{0,9,212},{18,7,19},{0,8,106},{0,8,42}, - {0,9,180},{0,8,10},{0,8,138},{0,8,74},{0,9,244},{16,7,5},{0,8,86}, - {0,8,22},{64,8,0},{19,7,51},{0,8,118},{0,8,54},{0,9,204},{17,7,15}, - {0,8,102},{0,8,38},{0,9,172},{0,8,6},{0,8,134},{0,8,70},{0,9,236}, - {16,7,9},{0,8,94},{0,8,30},{0,9,156},{20,7,99},{0,8,126},{0,8,62}, - {0,9,220},{18,7,27},{0,8,110},{0,8,46},{0,9,188},{0,8,14},{0,8,142}, - {0,8,78},{0,9,252},{96,7,0},{0,8,81},{0,8,17},{21,8,131},{18,7,31}, - {0,8,113},{0,8,49},{0,9,194},{16,7,10},{0,8,97},{0,8,33},{0,9,162}, - {0,8,1},{0,8,129},{0,8,65},{0,9,226},{16,7,6},{0,8,89},{0,8,25}, - {0,9,146},{19,7,59},{0,8,121},{0,8,57},{0,9,210},{17,7,17},{0,8,105}, - {0,8,41},{0,9,178},{0,8,9},{0,8,137},{0,8,73},{0,9,242},{16,7,4}, - {0,8,85},{0,8,21},{16,8,258},{19,7,43},{0,8,117},{0,8,53},{0,9,202}, - {17,7,13},{0,8,101},{0,8,37},{0,9,170},{0,8,5},{0,8,133},{0,8,69}, - {0,9,234},{16,7,8},{0,8,93},{0,8,29},{0,9,154},{20,7,83},{0,8,125}, - {0,8,61},{0,9,218},{18,7,23},{0,8,109},{0,8,45},{0,9,186},{0,8,13}, - {0,8,141},{0,8,77},{0,9,250},{16,7,3},{0,8,83},{0,8,19},{21,8,195}, - {19,7,35},{0,8,115},{0,8,51},{0,9,198},{17,7,11},{0,8,99},{0,8,35}, - {0,9,166},{0,8,3},{0,8,131},{0,8,67},{0,9,230},{16,7,7},{0,8,91}, - {0,8,27},{0,9,150},{20,7,67},{0,8,123},{0,8,59},{0,9,214},{18,7,19}, - {0,8,107},{0,8,43},{0,9,182},{0,8,11},{0,8,139},{0,8,75},{0,9,246}, - {16,7,5},{0,8,87},{0,8,23},{64,8,0},{19,7,51},{0,8,119},{0,8,55}, - {0,9,206},{17,7,15},{0,8,103},{0,8,39},{0,9,174},{0,8,7},{0,8,135}, - {0,8,71},{0,9,238},{16,7,9},{0,8,95},{0,8,31},{0,9,158},{20,7,99}, - {0,8,127},{0,8,63},{0,9,222},{18,7,27},{0,8,111},{0,8,47},{0,9,190}, - {0,8,15},{0,8,143},{0,8,79},{0,9,254},{96,7,0},{0,8,80},{0,8,16}, - {20,8,115},{18,7,31},{0,8,112},{0,8,48},{0,9,193},{16,7,10},{0,8,96}, - {0,8,32},{0,9,161},{0,8,0},{0,8,128},{0,8,64},{0,9,225},{16,7,6}, - {0,8,88},{0,8,24},{0,9,145},{19,7,59},{0,8,120},{0,8,56},{0,9,209}, - {17,7,17},{0,8,104},{0,8,40},{0,9,177},{0,8,8},{0,8,136},{0,8,72}, - {0,9,241},{16,7,4},{0,8,84},{0,8,20},{21,8,227},{19,7,43},{0,8,116}, - {0,8,52},{0,9,201},{17,7,13},{0,8,100},{0,8,36},{0,9,169},{0,8,4}, - {0,8,132},{0,8,68},{0,9,233},{16,7,8},{0,8,92},{0,8,28},{0,9,153}, - {20,7,83},{0,8,124},{0,8,60},{0,9,217},{18,7,23},{0,8,108},{0,8,44}, - {0,9,185},{0,8,12},{0,8,140},{0,8,76},{0,9,249},{16,7,3},{0,8,82}, - {0,8,18},{21,8,163},{19,7,35},{0,8,114},{0,8,50},{0,9,197},{17,7,11}, - {0,8,98},{0,8,34},{0,9,165},{0,8,2},{0,8,130},{0,8,66},{0,9,229}, - {16,7,7},{0,8,90},{0,8,26},{0,9,149},{20,7,67},{0,8,122},{0,8,58}, - {0,9,213},{18,7,19},{0,8,106},{0,8,42},{0,9,181},{0,8,10},{0,8,138}, - {0,8,74},{0,9,245},{16,7,5},{0,8,86},{0,8,22},{64,8,0},{19,7,51}, - {0,8,118},{0,8,54},{0,9,205},{17,7,15},{0,8,102},{0,8,38},{0,9,173}, - {0,8,6},{0,8,134},{0,8,70},{0,9,237},{16,7,9},{0,8,94},{0,8,30}, - {0,9,157},{20,7,99},{0,8,126},{0,8,62},{0,9,221},{18,7,27},{0,8,110}, - {0,8,46},{0,9,189},{0,8,14},{0,8,142},{0,8,78},{0,9,253},{96,7,0}, - {0,8,81},{0,8,17},{21,8,131},{18,7,31},{0,8,113},{0,8,49},{0,9,195}, - {16,7,10},{0,8,97},{0,8,33},{0,9,163},{0,8,1},{0,8,129},{0,8,65}, - {0,9,227},{16,7,6},{0,8,89},{0,8,25},{0,9,147},{19,7,59},{0,8,121}, - {0,8,57},{0,9,211},{17,7,17},{0,8,105},{0,8,41},{0,9,179},{0,8,9}, - {0,8,137},{0,8,73},{0,9,243},{16,7,4},{0,8,85},{0,8,21},{16,8,258}, - {19,7,43},{0,8,117},{0,8,53},{0,9,203},{17,7,13},{0,8,101},{0,8,37}, - {0,9,171},{0,8,5},{0,8,133},{0,8,69},{0,9,235},{16,7,8},{0,8,93}, - {0,8,29},{0,9,155},{20,7,83},{0,8,125},{0,8,61},{0,9,219},{18,7,23}, - {0,8,109},{0,8,45},{0,9,187},{0,8,13},{0,8,141},{0,8,77},{0,9,251}, - {16,7,3},{0,8,83},{0,8,19},{21,8,195},{19,7,35},{0,8,115},{0,8,51}, - {0,9,199},{17,7,11},{0,8,99},{0,8,35},{0,9,167},{0,8,3},{0,8,131}, - {0,8,67},{0,9,231},{16,7,7},{0,8,91},{0,8,27},{0,9,151},{20,7,67}, - {0,8,123},{0,8,59},{0,9,215},{18,7,19},{0,8,107},{0,8,43},{0,9,183}, - {0,8,11},{0,8,139},{0,8,75},{0,9,247},{16,7,5},{0,8,87},{0,8,23}, - {64,8,0},{19,7,51},{0,8,119},{0,8,55},{0,9,207},{17,7,15},{0,8,103}, - {0,8,39},{0,9,175},{0,8,7},{0,8,135},{0,8,71},{0,9,239},{16,7,9}, - {0,8,95},{0,8,31},{0,9,159},{20,7,99},{0,8,127},{0,8,63},{0,9,223}, - {18,7,27},{0,8,111},{0,8,47},{0,9,191},{0,8,15},{0,8,143},{0,8,79}, - {0,9,255} - }; - - static const code distfix[32] = { - {16,5,1},{23,5,257},{19,5,17},{27,5,4097},{17,5,5},{25,5,1025}, - {21,5,65},{29,5,16385},{16,5,3},{24,5,513},{20,5,33},{28,5,8193}, - {18,5,9},{26,5,2049},{22,5,129},{64,5,0},{16,5,2},{23,5,385}, - {19,5,25},{27,5,6145},{17,5,7},{25,5,1537},{21,5,97},{29,5,24577}, - {16,5,4},{24,5,769},{20,5,49},{28,5,12289},{18,5,13},{26,5,3073}, - {22,5,193},{64,5,0} - }; diff --git a/btgui/zlib/inflate.c b/btgui/zlib/inflate.c deleted file mode 100644 index 870f89bb4..000000000 --- a/btgui/zlib/inflate.c +++ /dev/null @@ -1,1512 +0,0 @@ -/* inflate.c -- zlib decompression - * Copyright (C) 1995-2012 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* - * Change history: - * - * 1.2.beta0 24 Nov 2002 - * - First version -- complete rewrite of inflate to simplify code, avoid - * creation of window when not needed, minimize use of window when it is - * needed, make inffast.c even faster, implement gzip decoding, and to - * improve code readability and style over the previous zlib inflate code - * - * 1.2.beta1 25 Nov 2002 - * - Use pointers for available input and output checking in inffast.c - * - Remove input and output counters in inffast.c - * - Change inffast.c entry and loop from avail_in >= 7 to >= 6 - * - Remove unnecessary second byte pull from length extra in inffast.c - * - Unroll direct copy to three copies per loop in inffast.c - * - * 1.2.beta2 4 Dec 2002 - * - Change external routine names to reduce potential conflicts - * - Correct filename to inffixed.h for fixed tables in inflate.c - * - Make hbuf[] unsigned char to match parameter type in inflate.c - * - Change strm->next_out[-state->offset] to *(strm->next_out - state->offset) - * to avoid negation problem on Alphas (64 bit) in inflate.c - * - * 1.2.beta3 22 Dec 2002 - * - Add comments on state->bits assertion in inffast.c - * - Add comments on op field in inftrees.h - * - Fix bug in reuse of allocated window after inflateReset() - * - Remove bit fields--back to byte structure for speed - * - Remove distance extra == 0 check in inflate_fast()--only helps for lengths - * - Change post-increments to pre-increments in inflate_fast(), PPC biased? - * - Add compile time option, POSTINC, to use post-increments instead (Intel?) - * - Make MATCH copy in inflate() much faster for when inflate_fast() not used - * - Use local copies of stream next and avail values, as well as local bit - * buffer and bit count in inflate()--for speed when inflate_fast() not used - * - * 1.2.beta4 1 Jan 2003 - * - Split ptr - 257 statements in inflate_table() to avoid compiler warnings - * - Move a comment on output buffer sizes from inffast.c to inflate.c - * - Add comments in inffast.c to introduce the inflate_fast() routine - * - Rearrange window copies in inflate_fast() for speed and simplification - * - Unroll last copy for window match in inflate_fast() - * - Use local copies of window variables in inflate_fast() for speed - * - Pull out common wnext == 0 case for speed in inflate_fast() - * - Make op and len in inflate_fast() unsigned for consistency - * - Add FAR to lcode and dcode declarations in inflate_fast() - * - Simplified bad distance check in inflate_fast() - * - Added inflateBackInit(), inflateBack(), and inflateBackEnd() in new - * source file infback.c to provide a call-back interface to inflate for - * programs like gzip and unzip -- uses window as output buffer to avoid - * window copying - * - * 1.2.beta5 1 Jan 2003 - * - Improved inflateBack() interface to allow the caller to provide initial - * input in strm. - * - Fixed stored blocks bug in inflateBack() - * - * 1.2.beta6 4 Jan 2003 - * - Added comments in inffast.c on effectiveness of POSTINC - * - Typecasting all around to reduce compiler warnings - * - Changed loops from while (1) or do {} while (1) to for (;;), again to - * make compilers happy - * - Changed type of window in inflateBackInit() to unsigned char * - * - * 1.2.beta7 27 Jan 2003 - * - Changed many types to unsigned or unsigned short to avoid warnings - * - Added inflateCopy() function - * - * 1.2.0 9 Mar 2003 - * - Changed inflateBack() interface to provide separate opaque descriptors - * for the in() and out() functions - * - Changed inflateBack() argument and in_func typedef to swap the length - * and buffer address return values for the input function - * - Check next_in and next_out for Z_NULL on entry to inflate() - * - * The history for versions after 1.2.0 are in ChangeLog in zlib distribution. - */ - -#include "zutil.h" -#include "inftrees.h" -#include "inflate.h" -#include "inffast.h" - -#ifdef MAKEFIXED -# ifndef BUILDFIXED -# define BUILDFIXED -# endif -#endif - -/* function prototypes */ -local void fixedtables OF((struct inflate_state FAR *state)); -local int updatewindow OF((z_streamp strm, const unsigned char FAR *end, - unsigned copy)); -#ifdef BUILDFIXED - void makefixed OF((void)); -#endif -local unsigned syncsearch OF((unsigned FAR *have, const unsigned char FAR *buf, - unsigned len)); - -int ZEXPORT inflateResetKeep(strm) -z_streamp strm; -{ - struct inflate_state FAR *state; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - strm->total_in = strm->total_out = state->total = 0; - strm->msg = Z_NULL; - if (state->wrap) /* to support ill-conceived Java test suite */ - strm->adler = state->wrap & 1; - state->mode = HEAD; - state->last = 0; - state->havedict = 0; - state->dmax = 32768U; - state->head = Z_NULL; - state->hold = 0; - state->bits = 0; - state->lencode = state->distcode = state->next = state->codes; - state->sane = 1; - state->back = -1; - Tracev((stderr, "inflate: reset\n")); - return Z_OK; -} - -int ZEXPORT inflateReset(strm) -z_streamp strm; -{ - struct inflate_state FAR *state; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - state->wsize = 0; - state->whave = 0; - state->wnext = 0; - return inflateResetKeep(strm); -} - -int ZEXPORT inflateReset2(strm, windowBits) -z_streamp strm; -int windowBits; -{ - int wrap; - struct inflate_state FAR *state; - - /* get the state */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - - /* extract wrap request from windowBits parameter */ - if (windowBits < 0) { - wrap = 0; - windowBits = -windowBits; - } - else { - wrap = (windowBits >> 4) + 1; -#ifdef GUNZIP - if (windowBits < 48) - windowBits &= 15; -#endif - } - - /* set number of window bits, free window if different */ - if (windowBits && (windowBits < 8 || windowBits > 15)) - return Z_STREAM_ERROR; - if (state->window != Z_NULL && state->wbits != (unsigned)windowBits) { - ZFREE(strm, state->window); - state->window = Z_NULL; - } - - /* update state and reset the rest of it */ - state->wrap = wrap; - state->wbits = (unsigned)windowBits; - return inflateReset(strm); -} - -int ZEXPORT inflateInit2_(strm, windowBits, version, stream_size) -z_streamp strm; -int windowBits; -const char *version; -int stream_size; -{ - int ret; - struct inflate_state FAR *state; - - if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || - stream_size != (int)(sizeof(z_stream))) - return Z_VERSION_ERROR; - if (strm == Z_NULL) return Z_STREAM_ERROR; - strm->msg = Z_NULL; /* in case we return an error */ - if (strm->zalloc == (alloc_func)0) { -#ifdef Z_SOLO - return Z_STREAM_ERROR; -#else - strm->zalloc = zcalloc; - strm->opaque = (voidpf)0; -#endif - } - if (strm->zfree == (free_func)0) -#ifdef Z_SOLO - return Z_STREAM_ERROR; -#else - strm->zfree = zcfree; -#endif - state = (struct inflate_state FAR *) - ZALLOC(strm, 1, sizeof(struct inflate_state)); - if (state == Z_NULL) return Z_MEM_ERROR; - Tracev((stderr, "inflate: allocated\n")); - strm->state = (struct internal_state FAR *)state; - state->window = Z_NULL; - ret = inflateReset2(strm, windowBits); - if (ret != Z_OK) { - ZFREE(strm, state); - strm->state = Z_NULL; - } - return ret; -} - -int ZEXPORT inflateInit_(strm, version, stream_size) -z_streamp strm; -const char *version; -int stream_size; -{ - return inflateInit2_(strm, DEF_WBITS, version, stream_size); -} - -int ZEXPORT inflatePrime(strm, bits, value) -z_streamp strm; -int bits; -int value; -{ - struct inflate_state FAR *state; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - if (bits < 0) { - state->hold = 0; - state->bits = 0; - return Z_OK; - } - if (bits > 16 || state->bits + bits > 32) return Z_STREAM_ERROR; - value &= (1L << bits) - 1; - state->hold += value << state->bits; - state->bits += bits; - return Z_OK; -} - -/* - Return state with length and distance decoding tables and index sizes set to - fixed code decoding. Normally this returns fixed tables from inffixed.h. - If BUILDFIXED is defined, then instead this routine builds the tables the - first time it's called, and returns those tables the first time and - thereafter. This reduces the size of the code by about 2K bytes, in - exchange for a little execution time. However, BUILDFIXED should not be - used for threaded applications, since the rewriting of the tables and virgin - may not be thread-safe. - */ -local void fixedtables(state) -struct inflate_state FAR *state; -{ -#ifdef BUILDFIXED - static int virgin = 1; - static code *lenfix, *distfix; - static code fixed[544]; - - /* build fixed huffman tables if first call (may not be thread safe) */ - if (virgin) { - unsigned sym, bits; - static code *next; - - /* literal/length table */ - sym = 0; - while (sym < 144) state->lens[sym++] = 8; - while (sym < 256) state->lens[sym++] = 9; - while (sym < 280) state->lens[sym++] = 7; - while (sym < 288) state->lens[sym++] = 8; - next = fixed; - lenfix = next; - bits = 9; - inflate_table(LENS, state->lens, 288, &(next), &(bits), state->work); - - /* distance table */ - sym = 0; - while (sym < 32) state->lens[sym++] = 5; - distfix = next; - bits = 5; - inflate_table(DISTS, state->lens, 32, &(next), &(bits), state->work); - - /* do this just once */ - virgin = 0; - } -#else /* !BUILDFIXED */ -# include "inffixed.h" -#endif /* BUILDFIXED */ - state->lencode = lenfix; - state->lenbits = 9; - state->distcode = distfix; - state->distbits = 5; -} - -#ifdef MAKEFIXED -#include - -/* - Write out the inffixed.h that is #include'd above. Defining MAKEFIXED also - defines BUILDFIXED, so the tables are built on the fly. makefixed() writes - those tables to stdout, which would be piped to inffixed.h. A small program - can simply call makefixed to do this: - - void makefixed(void); - - int main(void) - { - makefixed(); - return 0; - } - - Then that can be linked with zlib built with MAKEFIXED defined and run: - - a.out > inffixed.h - */ -void makefixed() -{ - unsigned low, size; - struct inflate_state state; - - fixedtables(&state); - puts(" /* inffixed.h -- table for decoding fixed codes"); - puts(" * Generated automatically by makefixed()."); - puts(" */"); - puts(""); - puts(" /* WARNING: this file should *not* be used by applications."); - puts(" It is part of the implementation of this library and is"); - puts(" subject to change. Applications should only use zlib.h."); - puts(" */"); - puts(""); - size = 1U << 9; - printf(" static const code lenfix[%u] = {", size); - low = 0; - for (;;) { - if ((low % 7) == 0) printf("\n "); - printf("{%u,%u,%d}", (low & 127) == 99 ? 64 : state.lencode[low].op, - state.lencode[low].bits, state.lencode[low].val); - if (++low == size) break; - putchar(','); - } - puts("\n };"); - size = 1U << 5; - printf("\n static const code distfix[%u] = {", size); - low = 0; - for (;;) { - if ((low % 6) == 0) printf("\n "); - printf("{%u,%u,%d}", state.distcode[low].op, state.distcode[low].bits, - state.distcode[low].val); - if (++low == size) break; - putchar(','); - } - puts("\n };"); -} -#endif /* MAKEFIXED */ - -/* - Update the window with the last wsize (normally 32K) bytes written before - returning. If window does not exist yet, create it. This is only called - when a window is already in use, or when output has been written during this - inflate call, but the end of the deflate stream has not been reached yet. - It is also called to create a window for dictionary data when a dictionary - is loaded. - - Providing output buffers larger than 32K to inflate() should provide a speed - advantage, since only the last 32K of output is copied to the sliding window - upon return from inflate(), and since all distances after the first 32K of - output will fall in the output data, making match copies simpler and faster. - The advantage may be dependent on the size of the processor's data caches. - */ -local int updatewindow(strm, end, copy) -z_streamp strm; -const Bytef *end; -unsigned copy; -{ - struct inflate_state FAR *state; - unsigned dist; - - state = (struct inflate_state FAR *)strm->state; - - /* if it hasn't been done already, allocate space for the window */ - if (state->window == Z_NULL) { - state->window = (unsigned char FAR *) - ZALLOC(strm, 1U << state->wbits, - sizeof(unsigned char)); - if (state->window == Z_NULL) return 1; - } - - /* if window not in use yet, initialize */ - if (state->wsize == 0) { - state->wsize = 1U << state->wbits; - state->wnext = 0; - state->whave = 0; - } - - /* copy state->wsize or less output bytes into the circular window */ - if (copy >= state->wsize) { - zmemcpy(state->window, end - state->wsize, state->wsize); - state->wnext = 0; - state->whave = state->wsize; - } - else { - dist = state->wsize - state->wnext; - if (dist > copy) dist = copy; - zmemcpy(state->window + state->wnext, end - copy, dist); - copy -= dist; - if (copy) { - zmemcpy(state->window, end - copy, copy); - state->wnext = copy; - state->whave = state->wsize; - } - else { - state->wnext += dist; - if (state->wnext == state->wsize) state->wnext = 0; - if (state->whave < state->wsize) state->whave += dist; - } - } - return 0; -} - -/* Macros for inflate(): */ - -/* check function to use adler32() for zlib or crc32() for gzip */ -#ifdef GUNZIP -# define UPDATE(check, buf, len) \ - (state->flags ? crc32(check, buf, len) : adler32(check, buf, len)) -#else -# define UPDATE(check, buf, len) adler32(check, buf, len) -#endif - -/* check macros for header crc */ -#ifdef GUNZIP -# define CRC2(check, word) \ - do { \ - hbuf[0] = (unsigned char)(word); \ - hbuf[1] = (unsigned char)((word) >> 8); \ - check = crc32(check, hbuf, 2); \ - } while (0) - -# define CRC4(check, word) \ - do { \ - hbuf[0] = (unsigned char)(word); \ - hbuf[1] = (unsigned char)((word) >> 8); \ - hbuf[2] = (unsigned char)((word) >> 16); \ - hbuf[3] = (unsigned char)((word) >> 24); \ - check = crc32(check, hbuf, 4); \ - } while (0) -#endif - -/* Load registers with state in inflate() for speed */ -#define LOAD() \ - do { \ - put = strm->next_out; \ - left = strm->avail_out; \ - next = strm->next_in; \ - have = strm->avail_in; \ - hold = state->hold; \ - bits = state->bits; \ - } while (0) - -/* Restore state from registers in inflate() */ -#define RESTORE() \ - do { \ - strm->next_out = put; \ - strm->avail_out = left; \ - strm->next_in = next; \ - strm->avail_in = have; \ - state->hold = hold; \ - state->bits = bits; \ - } while (0) - -/* Clear the input bit accumulator */ -#define INITBITS() \ - do { \ - hold = 0; \ - bits = 0; \ - } while (0) - -/* Get a byte of input into the bit accumulator, or return from inflate() - if there is no input available. */ -#define PULLBYTE() \ - do { \ - if (have == 0) goto inf_leave; \ - have--; \ - hold += (unsigned long)(*next++) << bits; \ - bits += 8; \ - } while (0) - -/* Assure that there are at least n bits in the bit accumulator. If there is - not enough available input to do that, then return from inflate(). */ -#define NEEDBITS(n) \ - do { \ - while (bits < (unsigned)(n)) \ - PULLBYTE(); \ - } while (0) - -/* Return the low n bits of the bit accumulator (n < 16) */ -#define BITS(n) \ - ((unsigned)hold & ((1U << (n)) - 1)) - -/* Remove n bits from the bit accumulator */ -#define DROPBITS(n) \ - do { \ - hold >>= (n); \ - bits -= (unsigned)(n); \ - } while (0) - -/* Remove zero to seven bits as needed to go to a byte boundary */ -#define BYTEBITS() \ - do { \ - hold >>= bits & 7; \ - bits -= bits & 7; \ - } while (0) - -/* - inflate() uses a state machine to process as much input data and generate as - much output data as possible before returning. The state machine is - structured roughly as follows: - - for (;;) switch (state) { - ... - case STATEn: - if (not enough input data or output space to make progress) - return; - ... make progress ... - state = STATEm; - break; - ... - } - - so when inflate() is called again, the same case is attempted again, and - if the appropriate resources are provided, the machine proceeds to the - next state. The NEEDBITS() macro is usually the way the state evaluates - whether it can proceed or should return. NEEDBITS() does the return if - the requested bits are not available. The typical use of the BITS macros - is: - - NEEDBITS(n); - ... do something with BITS(n) ... - DROPBITS(n); - - where NEEDBITS(n) either returns from inflate() if there isn't enough - input left to load n bits into the accumulator, or it continues. BITS(n) - gives the low n bits in the accumulator. When done, DROPBITS(n) drops - the low n bits off the accumulator. INITBITS() clears the accumulator - and sets the number of available bits to zero. BYTEBITS() discards just - enough bits to put the accumulator on a byte boundary. After BYTEBITS() - and a NEEDBITS(8), then BITS(8) would return the next byte in the stream. - - NEEDBITS(n) uses PULLBYTE() to get an available byte of input, or to return - if there is no input available. The decoding of variable length codes uses - PULLBYTE() directly in order to pull just enough bytes to decode the next - code, and no more. - - Some states loop until they get enough input, making sure that enough - state information is maintained to continue the loop where it left off - if NEEDBITS() returns in the loop. For example, want, need, and keep - would all have to actually be part of the saved state in case NEEDBITS() - returns: - - case STATEw: - while (want < need) { - NEEDBITS(n); - keep[want++] = BITS(n); - DROPBITS(n); - } - state = STATEx; - case STATEx: - - As shown above, if the next state is also the next case, then the break - is omitted. - - A state may also return if there is not enough output space available to - complete that state. Those states are copying stored data, writing a - literal byte, and copying a matching string. - - When returning, a "goto inf_leave" is used to update the total counters, - update the check value, and determine whether any progress has been made - during that inflate() call in order to return the proper return code. - Progress is defined as a change in either strm->avail_in or strm->avail_out. - When there is a window, goto inf_leave will update the window with the last - output written. If a goto inf_leave occurs in the middle of decompression - and there is no window currently, goto inf_leave will create one and copy - output to the window for the next call of inflate(). - - In this implementation, the flush parameter of inflate() only affects the - return code (per zlib.h). inflate() always writes as much as possible to - strm->next_out, given the space available and the provided input--the effect - documented in zlib.h of Z_SYNC_FLUSH. Furthermore, inflate() always defers - the allocation of and copying into a sliding window until necessary, which - provides the effect documented in zlib.h for Z_FINISH when the entire input - stream available. So the only thing the flush parameter actually does is: - when flush is set to Z_FINISH, inflate() cannot return Z_OK. Instead it - will return Z_BUF_ERROR if it has not reached the end of the stream. - */ - -int ZEXPORT inflate(strm, flush) -z_streamp strm; -int flush; -{ - struct inflate_state FAR *state; - z_const unsigned char FAR *next; /* next input */ - unsigned char FAR *put; /* next output */ - unsigned have, left; /* available input and output */ - unsigned long hold; /* bit buffer */ - unsigned bits; /* bits in bit buffer */ - unsigned in, out; /* save starting available input and output */ - unsigned copy; /* number of stored or match bytes to copy */ - unsigned char FAR *from; /* where to copy match bytes from */ - code here; /* current decoding table entry */ - code last; /* parent table entry */ - unsigned len; /* length to copy for repeats, bits to drop */ - int ret; /* return code */ -#ifdef GUNZIP - unsigned char hbuf[4]; /* buffer for gzip header crc calculation */ -#endif - static const unsigned short order[19] = /* permutation of code lengths */ - {16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; - - if (strm == Z_NULL || strm->state == Z_NULL || strm->next_out == Z_NULL || - (strm->next_in == Z_NULL && strm->avail_in != 0)) - return Z_STREAM_ERROR; - - state = (struct inflate_state FAR *)strm->state; - if (state->mode == TYPE) state->mode = TYPEDO; /* skip check */ - LOAD(); - in = have; - out = left; - ret = Z_OK; - for (;;) - switch (state->mode) { - case HEAD: - if (state->wrap == 0) { - state->mode = TYPEDO; - break; - } - NEEDBITS(16); -#ifdef GUNZIP - if ((state->wrap & 2) && hold == 0x8b1f) { /* gzip header */ - state->check = crc32(0L, Z_NULL, 0); - CRC2(state->check, hold); - INITBITS(); - state->mode = FLAGS; - break; - } - state->flags = 0; /* expect zlib header */ - if (state->head != Z_NULL) - state->head->done = -1; - if (!(state->wrap & 1) || /* check if zlib header allowed */ -#else - if ( -#endif - ((BITS(8) << 8) + (hold >> 8)) % 31) { - strm->msg = (char *)"incorrect header check"; - state->mode = BAD; - break; - } - if (BITS(4) != Z_DEFLATED) { - strm->msg = (char *)"unknown compression method"; - state->mode = BAD; - break; - } - DROPBITS(4); - len = BITS(4) + 8; - if (state->wbits == 0) - state->wbits = len; - else if (len > state->wbits) { - strm->msg = (char *)"invalid window size"; - state->mode = BAD; - break; - } - state->dmax = 1U << len; - Tracev((stderr, "inflate: zlib header ok\n")); - strm->adler = state->check = adler32(0L, Z_NULL, 0); - state->mode = hold & 0x200 ? DICTID : TYPE; - INITBITS(); - break; -#ifdef GUNZIP - case FLAGS: - NEEDBITS(16); - state->flags = (int)(hold); - if ((state->flags & 0xff) != Z_DEFLATED) { - strm->msg = (char *)"unknown compression method"; - state->mode = BAD; - break; - } - if (state->flags & 0xe000) { - strm->msg = (char *)"unknown header flags set"; - state->mode = BAD; - break; - } - if (state->head != Z_NULL) - state->head->text = (int)((hold >> 8) & 1); - if (state->flags & 0x0200) CRC2(state->check, hold); - INITBITS(); - state->mode = TIME; - case TIME: - NEEDBITS(32); - if (state->head != Z_NULL) - state->head->time = hold; - if (state->flags & 0x0200) CRC4(state->check, hold); - INITBITS(); - state->mode = OS; - case OS: - NEEDBITS(16); - if (state->head != Z_NULL) { - state->head->xflags = (int)(hold & 0xff); - state->head->os = (int)(hold >> 8); - } - if (state->flags & 0x0200) CRC2(state->check, hold); - INITBITS(); - state->mode = EXLEN; - case EXLEN: - if (state->flags & 0x0400) { - NEEDBITS(16); - state->length = (unsigned)(hold); - if (state->head != Z_NULL) - state->head->extra_len = (unsigned)hold; - if (state->flags & 0x0200) CRC2(state->check, hold); - INITBITS(); - } - else if (state->head != Z_NULL) - state->head->extra = Z_NULL; - state->mode = EXTRA; - case EXTRA: - if (state->flags & 0x0400) { - copy = state->length; - if (copy > have) copy = have; - if (copy) { - if (state->head != Z_NULL && - state->head->extra != Z_NULL) { - len = state->head->extra_len - state->length; - zmemcpy(state->head->extra + len, next, - len + copy > state->head->extra_max ? - state->head->extra_max - len : copy); - } - if (state->flags & 0x0200) - state->check = crc32(state->check, next, copy); - have -= copy; - next += copy; - state->length -= copy; - } - if (state->length) goto inf_leave; - } - state->length = 0; - state->mode = NAME; - case NAME: - if (state->flags & 0x0800) { - if (have == 0) goto inf_leave; - copy = 0; - do { - len = (unsigned)(next[copy++]); - if (state->head != Z_NULL && - state->head->name != Z_NULL && - state->length < state->head->name_max) - state->head->name[state->length++] = len; - } while (len && copy < have); - if (state->flags & 0x0200) - state->check = crc32(state->check, next, copy); - have -= copy; - next += copy; - if (len) goto inf_leave; - } - else if (state->head != Z_NULL) - state->head->name = Z_NULL; - state->length = 0; - state->mode = COMMENT; - case COMMENT: - if (state->flags & 0x1000) { - if (have == 0) goto inf_leave; - copy = 0; - do { - len = (unsigned)(next[copy++]); - if (state->head != Z_NULL && - state->head->comment != Z_NULL && - state->length < state->head->comm_max) - state->head->comment[state->length++] = len; - } while (len && copy < have); - if (state->flags & 0x0200) - state->check = crc32(state->check, next, copy); - have -= copy; - next += copy; - if (len) goto inf_leave; - } - else if (state->head != Z_NULL) - state->head->comment = Z_NULL; - state->mode = HCRC; - case HCRC: - if (state->flags & 0x0200) { - NEEDBITS(16); - if (hold != (state->check & 0xffff)) { - strm->msg = (char *)"header crc mismatch"; - state->mode = BAD; - break; - } - INITBITS(); - } - if (state->head != Z_NULL) { - state->head->hcrc = (int)((state->flags >> 9) & 1); - state->head->done = 1; - } - strm->adler = state->check = crc32(0L, Z_NULL, 0); - state->mode = TYPE; - break; -#endif - case DICTID: - NEEDBITS(32); - strm->adler = state->check = ZSWAP32(hold); - INITBITS(); - state->mode = DICT; - case DICT: - if (state->havedict == 0) { - RESTORE(); - return Z_NEED_DICT; - } - strm->adler = state->check = adler32(0L, Z_NULL, 0); - state->mode = TYPE; - case TYPE: - if (flush == Z_BLOCK || flush == Z_TREES) goto inf_leave; - case TYPEDO: - if (state->last) { - BYTEBITS(); - state->mode = CHECK; - break; - } - NEEDBITS(3); - state->last = BITS(1); - DROPBITS(1); - switch (BITS(2)) { - case 0: /* stored block */ - Tracev((stderr, "inflate: stored block%s\n", - state->last ? " (last)" : "")); - state->mode = STORED; - break; - case 1: /* fixed block */ - fixedtables(state); - Tracev((stderr, "inflate: fixed codes block%s\n", - state->last ? " (last)" : "")); - state->mode = LEN_; /* decode codes */ - if (flush == Z_TREES) { - DROPBITS(2); - goto inf_leave; - } - break; - case 2: /* dynamic block */ - Tracev((stderr, "inflate: dynamic codes block%s\n", - state->last ? " (last)" : "")); - state->mode = TABLE; - break; - case 3: - strm->msg = (char *)"invalid block type"; - state->mode = BAD; - } - DROPBITS(2); - break; - case STORED: - BYTEBITS(); /* go to byte boundary */ - NEEDBITS(32); - if ((hold & 0xffff) != ((hold >> 16) ^ 0xffff)) { - strm->msg = (char *)"invalid stored block lengths"; - state->mode = BAD; - break; - } - state->length = (unsigned)hold & 0xffff; - Tracev((stderr, "inflate: stored length %u\n", - state->length)); - INITBITS(); - state->mode = COPY_; - if (flush == Z_TREES) goto inf_leave; - case COPY_: - state->mode = COPY; - case COPY: - copy = state->length; - if (copy) { - if (copy > have) copy = have; - if (copy > left) copy = left; - if (copy == 0) goto inf_leave; - zmemcpy(put, next, copy); - have -= copy; - next += copy; - left -= copy; - put += copy; - state->length -= copy; - break; - } - Tracev((stderr, "inflate: stored end\n")); - state->mode = TYPE; - break; - case TABLE: - NEEDBITS(14); - state->nlen = BITS(5) + 257; - DROPBITS(5); - state->ndist = BITS(5) + 1; - DROPBITS(5); - state->ncode = BITS(4) + 4; - DROPBITS(4); -#ifndef PKZIP_BUG_WORKAROUND - if (state->nlen > 286 || state->ndist > 30) { - strm->msg = (char *)"too many length or distance symbols"; - state->mode = BAD; - break; - } -#endif - Tracev((stderr, "inflate: table sizes ok\n")); - state->have = 0; - state->mode = LENLENS; - case LENLENS: - while (state->have < state->ncode) { - NEEDBITS(3); - state->lens[order[state->have++]] = (unsigned short)BITS(3); - DROPBITS(3); - } - while (state->have < 19) - state->lens[order[state->have++]] = 0; - state->next = state->codes; - state->lencode = (const code FAR *)(state->next); - state->lenbits = 7; - ret = inflate_table(CODES, state->lens, 19, &(state->next), - &(state->lenbits), state->work); - if (ret) { - strm->msg = (char *)"invalid code lengths set"; - state->mode = BAD; - break; - } - Tracev((stderr, "inflate: code lengths ok\n")); - state->have = 0; - state->mode = CODELENS; - case CODELENS: - while (state->have < state->nlen + state->ndist) { - for (;;) { - here = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(here.bits) <= bits) break; - PULLBYTE(); - } - if (here.val < 16) { - DROPBITS(here.bits); - state->lens[state->have++] = here.val; - } - else { - if (here.val == 16) { - NEEDBITS(here.bits + 2); - DROPBITS(here.bits); - if (state->have == 0) { - strm->msg = (char *)"invalid bit length repeat"; - state->mode = BAD; - break; - } - len = state->lens[state->have - 1]; - copy = 3 + BITS(2); - DROPBITS(2); - } - else if (here.val == 17) { - NEEDBITS(here.bits + 3); - DROPBITS(here.bits); - len = 0; - copy = 3 + BITS(3); - DROPBITS(3); - } - else { - NEEDBITS(here.bits + 7); - DROPBITS(here.bits); - len = 0; - copy = 11 + BITS(7); - DROPBITS(7); - } - if (state->have + copy > state->nlen + state->ndist) { - strm->msg = (char *)"invalid bit length repeat"; - state->mode = BAD; - break; - } - while (copy--) - state->lens[state->have++] = (unsigned short)len; - } - } - - /* handle error breaks in while */ - if (state->mode == BAD) break; - - /* check for end-of-block code (better have one) */ - if (state->lens[256] == 0) { - strm->msg = (char *)"invalid code -- missing end-of-block"; - state->mode = BAD; - break; - } - - /* build code tables -- note: do not change the lenbits or distbits - values here (9 and 6) without reading the comments in inftrees.h - concerning the ENOUGH constants, which depend on those values */ - state->next = state->codes; - state->lencode = (const code FAR *)(state->next); - state->lenbits = 9; - ret = inflate_table(LENS, state->lens, state->nlen, &(state->next), - &(state->lenbits), state->work); - if (ret) { - strm->msg = (char *)"invalid literal/lengths set"; - state->mode = BAD; - break; - } - state->distcode = (const code FAR *)(state->next); - state->distbits = 6; - ret = inflate_table(DISTS, state->lens + state->nlen, state->ndist, - &(state->next), &(state->distbits), state->work); - if (ret) { - strm->msg = (char *)"invalid distances set"; - state->mode = BAD; - break; - } - Tracev((stderr, "inflate: codes ok\n")); - state->mode = LEN_; - if (flush == Z_TREES) goto inf_leave; - case LEN_: - state->mode = LEN; - case LEN: - if (have >= 6 && left >= 258) { - RESTORE(); - inflate_fast(strm, out); - LOAD(); - if (state->mode == TYPE) - state->back = -1; - break; - } - state->back = 0; - for (;;) { - here = state->lencode[BITS(state->lenbits)]; - if ((unsigned)(here.bits) <= bits) break; - PULLBYTE(); - } - if (here.op && (here.op & 0xf0) == 0) { - last = here; - for (;;) { - here = state->lencode[last.val + - (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + here.bits) <= bits) break; - PULLBYTE(); - } - DROPBITS(last.bits); - state->back += last.bits; - } - DROPBITS(here.bits); - state->back += here.bits; - state->length = (unsigned)here.val; - if ((int)(here.op) == 0) { - Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? - "inflate: literal '%c'\n" : - "inflate: literal 0x%02x\n", here.val)); - state->mode = LIT; - break; - } - if (here.op & 32) { - Tracevv((stderr, "inflate: end of block\n")); - state->back = -1; - state->mode = TYPE; - break; - } - if (here.op & 64) { - strm->msg = (char *)"invalid literal/length code"; - state->mode = BAD; - break; - } - state->extra = (unsigned)(here.op) & 15; - state->mode = LENEXT; - case LENEXT: - if (state->extra) { - NEEDBITS(state->extra); - state->length += BITS(state->extra); - DROPBITS(state->extra); - state->back += state->extra; - } - Tracevv((stderr, "inflate: length %u\n", state->length)); - state->was = state->length; - state->mode = DIST; - case DIST: - for (;;) { - here = state->distcode[BITS(state->distbits)]; - if ((unsigned)(here.bits) <= bits) break; - PULLBYTE(); - } - if ((here.op & 0xf0) == 0) { - last = here; - for (;;) { - here = state->distcode[last.val + - (BITS(last.bits + last.op) >> last.bits)]; - if ((unsigned)(last.bits + here.bits) <= bits) break; - PULLBYTE(); - } - DROPBITS(last.bits); - state->back += last.bits; - } - DROPBITS(here.bits); - state->back += here.bits; - if (here.op & 64) { - strm->msg = (char *)"invalid distance code"; - state->mode = BAD; - break; - } - state->offset = (unsigned)here.val; - state->extra = (unsigned)(here.op) & 15; - state->mode = DISTEXT; - case DISTEXT: - if (state->extra) { - NEEDBITS(state->extra); - state->offset += BITS(state->extra); - DROPBITS(state->extra); - state->back += state->extra; - } -#ifdef INFLATE_STRICT - if (state->offset > state->dmax) { - strm->msg = (char *)"invalid distance too far back"; - state->mode = BAD; - break; - } -#endif - Tracevv((stderr, "inflate: distance %u\n", state->offset)); - state->mode = MATCH; - case MATCH: - if (left == 0) goto inf_leave; - copy = out - left; - if (state->offset > copy) { /* copy from window */ - copy = state->offset - copy; - if (copy > state->whave) { - if (state->sane) { - strm->msg = (char *)"invalid distance too far back"; - state->mode = BAD; - break; - } -#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR - Trace((stderr, "inflate.c too far\n")); - copy -= state->whave; - if (copy > state->length) copy = state->length; - if (copy > left) copy = left; - left -= copy; - state->length -= copy; - do { - *put++ = 0; - } while (--copy); - if (state->length == 0) state->mode = LEN; - break; -#endif - } - if (copy > state->wnext) { - copy -= state->wnext; - from = state->window + (state->wsize - copy); - } - else - from = state->window + (state->wnext - copy); - if (copy > state->length) copy = state->length; - } - else { /* copy from output */ - from = put - state->offset; - copy = state->length; - } - if (copy > left) copy = left; - left -= copy; - state->length -= copy; - do { - *put++ = *from++; - } while (--copy); - if (state->length == 0) state->mode = LEN; - break; - case LIT: - if (left == 0) goto inf_leave; - *put++ = (unsigned char)(state->length); - left--; - state->mode = LEN; - break; - case CHECK: - if (state->wrap) { - NEEDBITS(32); - out -= left; - strm->total_out += out; - state->total += out; - if (out) - strm->adler = state->check = - UPDATE(state->check, put - out, out); - out = left; - if (( -#ifdef GUNZIP - state->flags ? hold : -#endif - ZSWAP32(hold)) != state->check) { - strm->msg = (char *)"incorrect data check"; - state->mode = BAD; - break; - } - INITBITS(); - Tracev((stderr, "inflate: check matches trailer\n")); - } -#ifdef GUNZIP - state->mode = LENGTH; - case LENGTH: - if (state->wrap && state->flags) { - NEEDBITS(32); - if (hold != (state->total & 0xffffffffUL)) { - strm->msg = (char *)"incorrect length check"; - state->mode = BAD; - break; - } - INITBITS(); - Tracev((stderr, "inflate: length matches trailer\n")); - } -#endif - state->mode = DONE; - case DONE: - ret = Z_STREAM_END; - goto inf_leave; - case BAD: - ret = Z_DATA_ERROR; - goto inf_leave; - case MEM: - return Z_MEM_ERROR; - case SYNC: - default: - return Z_STREAM_ERROR; - } - - /* - Return from inflate(), updating the total counts and the check value. - If there was no progress during the inflate() call, return a buffer - error. Call updatewindow() to create and/or update the window state. - Note: a memory error from inflate() is non-recoverable. - */ - inf_leave: - RESTORE(); - if (state->wsize || (out != strm->avail_out && state->mode < BAD && - (state->mode < CHECK || flush != Z_FINISH))) - if (updatewindow(strm, strm->next_out, out - strm->avail_out)) { - state->mode = MEM; - return Z_MEM_ERROR; - } - in -= strm->avail_in; - out -= strm->avail_out; - strm->total_in += in; - strm->total_out += out; - state->total += out; - if (state->wrap && out) - strm->adler = state->check = - UPDATE(state->check, strm->next_out - out, out); - strm->data_type = state->bits + (state->last ? 64 : 0) + - (state->mode == TYPE ? 128 : 0) + - (state->mode == LEN_ || state->mode == COPY_ ? 256 : 0); - if (((in == 0 && out == 0) || flush == Z_FINISH) && ret == Z_OK) - ret = Z_BUF_ERROR; - return ret; -} - -int ZEXPORT inflateEnd(strm) -z_streamp strm; -{ - struct inflate_state FAR *state; - if (strm == Z_NULL || strm->state == Z_NULL || strm->zfree == (free_func)0) - return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - if (state->window != Z_NULL) ZFREE(strm, state->window); - ZFREE(strm, strm->state); - strm->state = Z_NULL; - Tracev((stderr, "inflate: end\n")); - return Z_OK; -} - -int ZEXPORT inflateGetDictionary(strm, dictionary, dictLength) -z_streamp strm; -Bytef *dictionary; -uInt *dictLength; -{ - struct inflate_state FAR *state; - - /* check state */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - - /* copy dictionary */ - if (state->whave && dictionary != Z_NULL) { - zmemcpy(dictionary, state->window + state->wnext, - state->whave - state->wnext); - zmemcpy(dictionary + state->whave - state->wnext, - state->window, state->wnext); - } - if (dictLength != Z_NULL) - *dictLength = state->whave; - return Z_OK; -} - -int ZEXPORT inflateSetDictionary(strm, dictionary, dictLength) -z_streamp strm; -const Bytef *dictionary; -uInt dictLength; -{ - struct inflate_state FAR *state; - unsigned long dictid; - int ret; - - /* check state */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - if (state->wrap != 0 && state->mode != DICT) - return Z_STREAM_ERROR; - - /* check for correct dictionary identifier */ - if (state->mode == DICT) { - dictid = adler32(0L, Z_NULL, 0); - dictid = adler32(dictid, dictionary, dictLength); - if (dictid != state->check) - return Z_DATA_ERROR; - } - - /* copy dictionary to window using updatewindow(), which will amend the - existing dictionary if appropriate */ - ret = updatewindow(strm, dictionary + dictLength, dictLength); - if (ret) { - state->mode = MEM; - return Z_MEM_ERROR; - } - state->havedict = 1; - Tracev((stderr, "inflate: dictionary set\n")); - return Z_OK; -} - -int ZEXPORT inflateGetHeader(strm, head) -z_streamp strm; -gz_headerp head; -{ - struct inflate_state FAR *state; - - /* check state */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - if ((state->wrap & 2) == 0) return Z_STREAM_ERROR; - - /* save header structure */ - state->head = head; - head->done = 0; - return Z_OK; -} - -/* - Search buf[0..len-1] for the pattern: 0, 0, 0xff, 0xff. Return when found - or when out of input. When called, *have is the number of pattern bytes - found in order so far, in 0..3. On return *have is updated to the new - state. If on return *have equals four, then the pattern was found and the - return value is how many bytes were read including the last byte of the - pattern. If *have is less than four, then the pattern has not been found - yet and the return value is len. In the latter case, syncsearch() can be - called again with more data and the *have state. *have is initialized to - zero for the first call. - */ -local unsigned syncsearch(have, buf, len) -unsigned FAR *have; -const unsigned char FAR *buf; -unsigned len; -{ - unsigned got; - unsigned next; - - got = *have; - next = 0; - while (next < len && got < 4) { - if ((int)(buf[next]) == (got < 2 ? 0 : 0xff)) - got++; - else if (buf[next]) - got = 0; - else - got = 4 - got; - next++; - } - *have = got; - return next; -} - -int ZEXPORT inflateSync(strm) -z_streamp strm; -{ - unsigned len; /* number of bytes to look at or looked at */ - unsigned long in, out; /* temporary to save total_in and total_out */ - unsigned char buf[4]; /* to restore bit buffer to byte string */ - struct inflate_state FAR *state; - - /* check parameters */ - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - if (strm->avail_in == 0 && state->bits < 8) return Z_BUF_ERROR; - - /* if first time, start search in bit buffer */ - if (state->mode != SYNC) { - state->mode = SYNC; - state->hold <<= state->bits & 7; - state->bits -= state->bits & 7; - len = 0; - while (state->bits >= 8) { - buf[len++] = (unsigned char)(state->hold); - state->hold >>= 8; - state->bits -= 8; - } - state->have = 0; - syncsearch(&(state->have), buf, len); - } - - /* search available input */ - len = syncsearch(&(state->have), strm->next_in, strm->avail_in); - strm->avail_in -= len; - strm->next_in += len; - strm->total_in += len; - - /* return no joy or set up to restart inflate() on a new block */ - if (state->have != 4) return Z_DATA_ERROR; - in = strm->total_in; out = strm->total_out; - inflateReset(strm); - strm->total_in = in; strm->total_out = out; - state->mode = TYPE; - return Z_OK; -} - -/* - Returns true if inflate is currently at the end of a block generated by - Z_SYNC_FLUSH or Z_FULL_FLUSH. This function is used by one PPP - implementation to provide an additional safety check. PPP uses - Z_SYNC_FLUSH but removes the length bytes of the resulting empty stored - block. When decompressing, PPP checks that at the end of input packet, - inflate is waiting for these length bytes. - */ -int ZEXPORT inflateSyncPoint(strm) -z_streamp strm; -{ - struct inflate_state FAR *state; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - return state->mode == STORED && state->bits == 0; -} - -int ZEXPORT inflateCopy(dest, source) -z_streamp dest; -z_streamp source; -{ - struct inflate_state FAR *state; - struct inflate_state FAR *copy; - unsigned char FAR *window; - unsigned wsize; - - /* check input */ - if (dest == Z_NULL || source == Z_NULL || source->state == Z_NULL || - source->zalloc == (alloc_func)0 || source->zfree == (free_func)0) - return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)source->state; - - /* allocate space */ - copy = (struct inflate_state FAR *) - ZALLOC(source, 1, sizeof(struct inflate_state)); - if (copy == Z_NULL) return Z_MEM_ERROR; - window = Z_NULL; - if (state->window != Z_NULL) { - window = (unsigned char FAR *) - ZALLOC(source, 1U << state->wbits, sizeof(unsigned char)); - if (window == Z_NULL) { - ZFREE(source, copy); - return Z_MEM_ERROR; - } - } - - /* copy state */ - zmemcpy((voidpf)dest, (voidpf)source, sizeof(z_stream)); - zmemcpy((voidpf)copy, (voidpf)state, sizeof(struct inflate_state)); - if (state->lencode >= state->codes && - state->lencode <= state->codes + ENOUGH - 1) { - copy->lencode = copy->codes + (state->lencode - state->codes); - copy->distcode = copy->codes + (state->distcode - state->codes); - } - copy->next = copy->codes + (state->next - state->codes); - if (window != Z_NULL) { - wsize = 1U << state->wbits; - zmemcpy(window, state->window, wsize); - } - copy->window = window; - dest->state = (struct internal_state FAR *)copy; - return Z_OK; -} - -int ZEXPORT inflateUndermine(strm, subvert) -z_streamp strm; -int subvert; -{ - struct inflate_state FAR *state; - - if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; - state = (struct inflate_state FAR *)strm->state; - state->sane = !subvert; -#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR - return Z_OK; -#else - state->sane = 1; - return Z_DATA_ERROR; -#endif -} - -long ZEXPORT inflateMark(strm) -z_streamp strm; -{ - struct inflate_state FAR *state; - - if (strm == Z_NULL || strm->state == Z_NULL) return -1L << 16; - state = (struct inflate_state FAR *)strm->state; - return ((long)(state->back) << 16) + - (state->mode == COPY ? state->length : - (state->mode == MATCH ? state->was - state->length : 0)); -} diff --git a/btgui/zlib/inflate.h b/btgui/zlib/inflate.h deleted file mode 100644 index 95f4986d4..000000000 --- a/btgui/zlib/inflate.h +++ /dev/null @@ -1,122 +0,0 @@ -/* inflate.h -- internal inflate state definition - * Copyright (C) 1995-2009 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* WARNING: this file should *not* be used by applications. It is - part of the implementation of the compression library and is - subject to change. Applications should only use zlib.h. - */ - -/* define NO_GZIP when compiling if you want to disable gzip header and - trailer decoding by inflate(). NO_GZIP would be used to avoid linking in - the crc code when it is not needed. For shared libraries, gzip decoding - should be left enabled. */ -#ifndef NO_GZIP -# define GUNZIP -#endif - -/* Possible inflate modes between inflate() calls */ -typedef enum { - HEAD, /* i: waiting for magic header */ - FLAGS, /* i: waiting for method and flags (gzip) */ - TIME, /* i: waiting for modification time (gzip) */ - OS, /* i: waiting for extra flags and operating system (gzip) */ - EXLEN, /* i: waiting for extra length (gzip) */ - EXTRA, /* i: waiting for extra bytes (gzip) */ - NAME, /* i: waiting for end of file name (gzip) */ - COMMENT, /* i: waiting for end of comment (gzip) */ - HCRC, /* i: waiting for header crc (gzip) */ - DICTID, /* i: waiting for dictionary check value */ - DICT, /* waiting for inflateSetDictionary() call */ - TYPE, /* i: waiting for type bits, including last-flag bit */ - TYPEDO, /* i: same, but skip check to exit inflate on new block */ - STORED, /* i: waiting for stored size (length and complement) */ - COPY_, /* i/o: same as COPY below, but only first time in */ - COPY, /* i/o: waiting for input or output to copy stored block */ - TABLE, /* i: waiting for dynamic block table lengths */ - LENLENS, /* i: waiting for code length code lengths */ - CODELENS, /* i: waiting for length/lit and distance code lengths */ - LEN_, /* i: same as LEN below, but only first time in */ - LEN, /* i: waiting for length/lit/eob code */ - LENEXT, /* i: waiting for length extra bits */ - DIST, /* i: waiting for distance code */ - DISTEXT, /* i: waiting for distance extra bits */ - MATCH, /* o: waiting for output space to copy string */ - LIT, /* o: waiting for output space to write literal */ - CHECK, /* i: waiting for 32-bit check value */ - LENGTH, /* i: waiting for 32-bit length (gzip) */ - DONE, /* finished check, done -- remain here until reset */ - BAD, /* got a data error -- remain here until reset */ - MEM, /* got an inflate() memory error -- remain here until reset */ - SYNC /* looking for synchronization bytes to restart inflate() */ -} inflate_mode; - -/* - State transitions between above modes - - - (most modes can go to BAD or MEM on error -- not shown for clarity) - - Process header: - HEAD -> (gzip) or (zlib) or (raw) - (gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME -> COMMENT -> - HCRC -> TYPE - (zlib) -> DICTID or TYPE - DICTID -> DICT -> TYPE - (raw) -> TYPEDO - Read deflate blocks: - TYPE -> TYPEDO -> STORED or TABLE or LEN_ or CHECK - STORED -> COPY_ -> COPY -> TYPE - TABLE -> LENLENS -> CODELENS -> LEN_ - LEN_ -> LEN - Read deflate codes in fixed or dynamic block: - LEN -> LENEXT or LIT or TYPE - LENEXT -> DIST -> DISTEXT -> MATCH -> LEN - LIT -> LEN - Process trailer: - CHECK -> LENGTH -> DONE - */ - -/* state maintained between inflate() calls. Approximately 10K bytes. */ -struct inflate_state { - inflate_mode mode; /* current inflate mode */ - int last; /* true if processing last block */ - int wrap; /* bit 0 true for zlib, bit 1 true for gzip */ - int havedict; /* true if dictionary provided */ - int flags; /* gzip header method and flags (0 if zlib) */ - unsigned dmax; /* zlib header max distance (INFLATE_STRICT) */ - unsigned long check; /* protected copy of check value */ - unsigned long total; /* protected copy of output count */ - gz_headerp head; /* where to save gzip header information */ - /* sliding window */ - unsigned wbits; /* log base 2 of requested window size */ - unsigned wsize; /* window size or zero if not using window */ - unsigned whave; /* valid bytes in the window */ - unsigned wnext; /* window write index */ - unsigned char FAR *window; /* allocated sliding window, if needed */ - /* bit accumulator */ - unsigned long hold; /* input bit accumulator */ - unsigned bits; /* number of bits in "in" */ - /* for string and stored block copying */ - unsigned length; /* literal or length of data to copy */ - unsigned offset; /* distance back to copy string from */ - /* for table and code decoding */ - unsigned extra; /* extra bits needed */ - /* fixed and dynamic code tables */ - code const FAR *lencode; /* starting table for length/literal codes */ - code const FAR *distcode; /* starting table for distance codes */ - unsigned lenbits; /* index bits for lencode */ - unsigned distbits; /* index bits for distcode */ - /* dynamic table building */ - unsigned ncode; /* number of code length code lengths */ - unsigned nlen; /* number of length code lengths */ - unsigned ndist; /* number of distance code lengths */ - unsigned have; /* number of code lengths in lens[] */ - code FAR *next; /* next available space in codes[] */ - unsigned short lens[320]; /* temporary storage for code lengths */ - unsigned short work[288]; /* work area for code table building */ - code codes[ENOUGH]; /* space for code tables */ - int sane; /* if false, allow invalid distance too far */ - int back; /* bits back of last unprocessed length/lit */ - unsigned was; /* initial length of match */ -}; diff --git a/btgui/zlib/inftrees.c b/btgui/zlib/inftrees.c deleted file mode 100644 index 44d89cf24..000000000 --- a/btgui/zlib/inftrees.c +++ /dev/null @@ -1,306 +0,0 @@ -/* inftrees.c -- generate Huffman trees for efficient decoding - * Copyright (C) 1995-2013 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -#include "zutil.h" -#include "inftrees.h" - -#define MAXBITS 15 - -const char inflate_copyright[] = - " inflate 1.2.8 Copyright 1995-2013 Mark Adler "; -/* - If you use the zlib library in a product, an acknowledgment is welcome - in the documentation of your product. If for some reason you cannot - include such an acknowledgment, I would appreciate that you keep this - copyright string in the executable of your product. - */ - -/* - Build a set of tables to decode the provided canonical Huffman code. - The code lengths are lens[0..codes-1]. The result starts at *table, - whose indices are 0..2^bits-1. work is a writable array of at least - lens shorts, which is used as a work area. type is the type of code - to be generated, CODES, LENS, or DISTS. On return, zero is success, - -1 is an invalid code, and +1 means that ENOUGH isn't enough. table - on return points to the next available entry's address. bits is the - requested root table index bits, and on return it is the actual root - table index bits. It will differ if the request is greater than the - longest code or if it is less than the shortest code. - */ -int ZLIB_INTERNAL inflate_table(type, lens, codes, table, bits, work) -codetype type; -unsigned short FAR *lens; -unsigned codes; -code FAR * FAR *table; -unsigned FAR *bits; -unsigned short FAR *work; -{ - unsigned len; /* a code's length in bits */ - unsigned sym; /* index of code symbols */ - unsigned min, max; /* minimum and maximum code lengths */ - unsigned root; /* number of index bits for root table */ - unsigned curr; /* number of index bits for current table */ - unsigned drop; /* code bits to drop for sub-table */ - int left; /* number of prefix codes available */ - unsigned used; /* code entries in table used */ - unsigned huff; /* Huffman code */ - unsigned incr; /* for incrementing code, index */ - unsigned fill; /* index for replicating entries */ - unsigned low; /* low bits for current root entry */ - unsigned mask; /* mask for low root bits */ - code here; /* table entry for duplication */ - code FAR *next; /* next available space in table */ - const unsigned short FAR *base; /* base value table to use */ - const unsigned short FAR *extra; /* extra bits table to use */ - int end; /* use base and extra for symbol > end */ - unsigned short count[MAXBITS+1]; /* number of codes of each length */ - unsigned short offs[MAXBITS+1]; /* offsets in table for each length */ - static const unsigned short lbase[31] = { /* Length codes 257..285 base */ - 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, - 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; - static const unsigned short lext[31] = { /* Length codes 257..285 extra */ - 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, - 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78}; - static const unsigned short dbase[32] = { /* Distance codes 0..29 base */ - 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, - 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, - 8193, 12289, 16385, 24577, 0, 0}; - static const unsigned short dext[32] = { /* Distance codes 0..29 extra */ - 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, - 23, 23, 24, 24, 25, 25, 26, 26, 27, 27, - 28, 28, 29, 29, 64, 64}; - - /* - Process a set of code lengths to create a canonical Huffman code. The - code lengths are lens[0..codes-1]. Each length corresponds to the - symbols 0..codes-1. The Huffman code is generated by first sorting the - symbols by length from short to long, and retaining the symbol order - for codes with equal lengths. Then the code starts with all zero bits - for the first code of the shortest length, and the codes are integer - increments for the same length, and zeros are appended as the length - increases. For the deflate format, these bits are stored backwards - from their more natural integer increment ordering, and so when the - decoding tables are built in the large loop below, the integer codes - are incremented backwards. - - This routine assumes, but does not check, that all of the entries in - lens[] are in the range 0..MAXBITS. The caller must assure this. - 1..MAXBITS is interpreted as that code length. zero means that that - symbol does not occur in this code. - - The codes are sorted by computing a count of codes for each length, - creating from that a table of starting indices for each length in the - sorted table, and then entering the symbols in order in the sorted - table. The sorted table is work[], with that space being provided by - the caller. - - The length counts are used for other purposes as well, i.e. finding - the minimum and maximum length codes, determining if there are any - codes at all, checking for a valid set of lengths, and looking ahead - at length counts to determine sub-table sizes when building the - decoding tables. - */ - - /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */ - for (len = 0; len <= MAXBITS; len++) - count[len] = 0; - for (sym = 0; sym < codes; sym++) - count[lens[sym]]++; - - /* bound code lengths, force root to be within code lengths */ - root = *bits; - for (max = MAXBITS; max >= 1; max--) - if (count[max] != 0) break; - if (root > max) root = max; - if (max == 0) { /* no symbols to code at all */ - here.op = (unsigned char)64; /* invalid code marker */ - here.bits = (unsigned char)1; - here.val = (unsigned short)0; - *(*table)++ = here; /* make a table to force an error */ - *(*table)++ = here; - *bits = 1; - return 0; /* no symbols, but wait for decoding to report error */ - } - for (min = 1; min < max; min++) - if (count[min] != 0) break; - if (root < min) root = min; - - /* check for an over-subscribed or incomplete set of lengths */ - left = 1; - for (len = 1; len <= MAXBITS; len++) { - left <<= 1; - left -= count[len]; - if (left < 0) return -1; /* over-subscribed */ - } - if (left > 0 && (type == CODES || max != 1)) - return -1; /* incomplete set */ - - /* generate offsets into symbol table for each length for sorting */ - offs[1] = 0; - for (len = 1; len < MAXBITS; len++) - offs[len + 1] = offs[len] + count[len]; - - /* sort symbols by length, by symbol order within each length */ - for (sym = 0; sym < codes; sym++) - if (lens[sym] != 0) work[offs[lens[sym]]++] = (unsigned short)sym; - - /* - Create and fill in decoding tables. In this loop, the table being - filled is at next and has curr index bits. The code being used is huff - with length len. That code is converted to an index by dropping drop - bits off of the bottom. For codes where len is less than drop + curr, - those top drop + curr - len bits are incremented through all values to - fill the table with replicated entries. - - root is the number of index bits for the root table. When len exceeds - root, sub-tables are created pointed to by the root entry with an index - of the low root bits of huff. This is saved in low to check for when a - new sub-table should be started. drop is zero when the root table is - being filled, and drop is root when sub-tables are being filled. - - When a new sub-table is needed, it is necessary to look ahead in the - code lengths to determine what size sub-table is needed. The length - counts are used for this, and so count[] is decremented as codes are - entered in the tables. - - used keeps track of how many table entries have been allocated from the - provided *table space. It is checked for LENS and DIST tables against - the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in - the initial root table size constants. See the comments in inftrees.h - for more information. - - sym increments through all symbols, and the loop terminates when - all codes of length max, i.e. all codes, have been processed. This - routine permits incomplete codes, so another loop after this one fills - in the rest of the decoding tables with invalid code markers. - */ - - /* set up for code type */ - switch (type) { - case CODES: - base = extra = work; /* dummy value--not used */ - end = 19; - break; - case LENS: - base = lbase; - base -= 257; - extra = lext; - extra -= 257; - end = 256; - break; - default: /* DISTS */ - base = dbase; - extra = dext; - end = -1; - } - - /* initialize state for loop */ - huff = 0; /* starting code */ - sym = 0; /* starting code symbol */ - len = min; /* starting code length */ - next = *table; /* current table to fill in */ - curr = root; /* current table index bits */ - drop = 0; /* current bits to drop from code for index */ - low = (unsigned)(-1); /* trigger new sub-table when len > root */ - used = 1U << root; /* use root table entries */ - mask = used - 1; /* mask for comparing low */ - - /* check available table space */ - if ((type == LENS && used > ENOUGH_LENS) || - (type == DISTS && used > ENOUGH_DISTS)) - return 1; - - /* process all codes and make table entries */ - for (;;) { - /* create table entry */ - here.bits = (unsigned char)(len - drop); - if ((int)(work[sym]) < end) { - here.op = (unsigned char)0; - here.val = work[sym]; - } - else if ((int)(work[sym]) > end) { - here.op = (unsigned char)(extra[work[sym]]); - here.val = base[work[sym]]; - } - else { - here.op = (unsigned char)(32 + 64); /* end of block */ - here.val = 0; - } - - /* replicate for those indices with low len bits equal to huff */ - incr = 1U << (len - drop); - fill = 1U << curr; - min = fill; /* save offset to next table */ - do { - fill -= incr; - next[(huff >> drop) + fill] = here; - } while (fill != 0); - - /* backwards increment the len-bit code huff */ - incr = 1U << (len - 1); - while (huff & incr) - incr >>= 1; - if (incr != 0) { - huff &= incr - 1; - huff += incr; - } - else - huff = 0; - - /* go to next symbol, update count, len */ - sym++; - if (--(count[len]) == 0) { - if (len == max) break; - len = lens[work[sym]]; - } - - /* create new sub-table if needed */ - if (len > root && (huff & mask) != low) { - /* if first time, transition to sub-tables */ - if (drop == 0) - drop = root; - - /* increment past last table */ - next += min; /* here min is 1 << curr */ - - /* determine length of next table */ - curr = len - drop; - left = (int)(1 << curr); - while (curr + drop < max) { - left -= count[curr + drop]; - if (left <= 0) break; - curr++; - left <<= 1; - } - - /* check for enough space */ - used += 1U << curr; - if ((type == LENS && used > ENOUGH_LENS) || - (type == DISTS && used > ENOUGH_DISTS)) - return 1; - - /* point entry in root table to sub-table */ - low = huff & mask; - (*table)[low].op = (unsigned char)curr; - (*table)[low].bits = (unsigned char)root; - (*table)[low].val = (unsigned short)(next - *table); - } - } - - /* fill in remaining table entry if code is incomplete (guaranteed to have - at most one remaining entry, since if the code is incomplete, the - maximum code length that was allowed to get this far is one bit) */ - if (huff != 0) { - here.op = (unsigned char)64; /* invalid code marker */ - here.bits = (unsigned char)(len - drop); - here.val = (unsigned short)0; - next[huff] = here; - } - - /* set return parameters */ - *table += used; - *bits = root; - return 0; -} diff --git a/btgui/zlib/inftrees.h b/btgui/zlib/inftrees.h deleted file mode 100644 index baa53a0b1..000000000 --- a/btgui/zlib/inftrees.h +++ /dev/null @@ -1,62 +0,0 @@ -/* inftrees.h -- header to use inftrees.c - * Copyright (C) 1995-2005, 2010 Mark Adler - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* WARNING: this file should *not* be used by applications. It is - part of the implementation of the compression library and is - subject to change. Applications should only use zlib.h. - */ - -/* Structure for decoding tables. Each entry provides either the - information needed to do the operation requested by the code that - indexed that table entry, or it provides a pointer to another - table that indexes more bits of the code. op indicates whether - the entry is a pointer to another table, a literal, a length or - distance, an end-of-block, or an invalid code. For a table - pointer, the low four bits of op is the number of index bits of - that table. For a length or distance, the low four bits of op - is the number of extra bits to get after the code. bits is - the number of bits in this code or part of the code to drop off - of the bit buffer. val is the actual byte to output in the case - of a literal, the base length or distance, or the offset from - the current table to the next table. Each entry is four bytes. */ -typedef struct { - unsigned char op; /* operation, extra bits, table bits */ - unsigned char bits; /* bits in this part of the code */ - unsigned short val; /* offset in table or code value */ -} code; - -/* op values as set by inflate_table(): - 00000000 - literal - 0000tttt - table link, tttt != 0 is the number of table index bits - 0001eeee - length or distance, eeee is the number of extra bits - 01100000 - end of block - 01000000 - invalid code - */ - -/* Maximum size of the dynamic table. The maximum number of code structures is - 1444, which is the sum of 852 for literal/length codes and 592 for distance - codes. These values were found by exhaustive searches using the program - examples/enough.c found in the zlib distribtution. The arguments to that - program are the number of symbols, the initial root table size, and the - maximum bit length of a code. "enough 286 9 15" for literal/length codes - returns returns 852, and "enough 30 6 15" for distance codes returns 592. - The initial root table size (9 or 6) is found in the fifth argument of the - inflate_table() calls in inflate.c and infback.c. If the root table size is - changed, then these maximum sizes would be need to be recalculated and - updated. */ -#define ENOUGH_LENS 852 -#define ENOUGH_DISTS 592 -#define ENOUGH (ENOUGH_LENS+ENOUGH_DISTS) - -/* Type of code to build for inflate_table() */ -typedef enum { - CODES, - LENS, - DISTS -} codetype; - -int ZLIB_INTERNAL inflate_table OF((codetype type, unsigned short FAR *lens, - unsigned codes, code FAR * FAR *table, - unsigned FAR *bits, unsigned short FAR *work)); diff --git a/btgui/zlib/trees.c b/btgui/zlib/trees.c deleted file mode 100644 index 1fd7759ef..000000000 --- a/btgui/zlib/trees.c +++ /dev/null @@ -1,1226 +0,0 @@ -/* trees.c -- output deflated data using Huffman coding - * Copyright (C) 1995-2012 Jean-loup Gailly - * detect_data_type() function provided freely by Cosmin Truta, 2006 - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* - * ALGORITHM - * - * The "deflation" process uses several Huffman trees. The more - * common source values are represented by shorter bit sequences. - * - * Each code tree is stored in a compressed form which is itself - * a Huffman encoding of the lengths of all the code strings (in - * ascending order by source values). The actual code strings are - * reconstructed from the lengths in the inflate process, as described - * in the deflate specification. - * - * REFERENCES - * - * Deutsch, L.P.,"'Deflate' Compressed Data Format Specification". - * Available in ftp.uu.net:/pub/archiving/zip/doc/deflate-1.1.doc - * - * Storer, James A. - * Data Compression: Methods and Theory, pp. 49-50. - * Computer Science Press, 1988. ISBN 0-7167-8156-5. - * - * Sedgewick, R. - * Algorithms, p290. - * Addison-Wesley, 1983. ISBN 0-201-06672-6. - */ - -/* @(#) $Id$ */ - -/* #define GEN_TREES_H */ - -#include "deflate.h" - -#ifdef DEBUG -# include -#endif - -/* =========================================================================== - * Constants - */ - -#define MAX_BL_BITS 7 -/* Bit length codes must not exceed MAX_BL_BITS bits */ - -#define END_BLOCK 256 -/* end of block literal code */ - -#define REP_3_6 16 -/* repeat previous bit length 3-6 times (2 bits of repeat count) */ - -#define REPZ_3_10 17 -/* repeat a zero length 3-10 times (3 bits of repeat count) */ - -#define REPZ_11_138 18 -/* repeat a zero length 11-138 times (7 bits of repeat count) */ - -local const int extra_lbits[LENGTH_CODES] /* extra bits for each length code */ - = {0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0}; - -local const int extra_dbits[D_CODES] /* extra bits for each distance code */ - = {0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13}; - -local const int extra_blbits[BL_CODES]/* extra bits for each bit length code */ - = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7}; - -local const uch bl_order[BL_CODES] - = {16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15}; -/* The lengths of the bit length codes are sent in order of decreasing - * probability, to avoid transmitting the lengths for unused bit length codes. - */ - -/* =========================================================================== - * Local data. These are initialized only once. - */ - -#define DIST_CODE_LEN 512 /* see definition of array dist_code below */ - -#if defined(GEN_TREES_H) || !defined(STDC) -/* non ANSI compilers may not accept trees.h */ - -local ct_data static_ltree[L_CODES+2]; -/* The static literal tree. Since the bit lengths are imposed, there is no - * need for the L_CODES extra codes used during heap construction. However - * The codes 286 and 287 are needed to build a canonical tree (see _tr_init - * below). - */ - -local ct_data static_dtree[D_CODES]; -/* The static distance tree. (Actually a trivial tree since all codes use - * 5 bits.) - */ - -uch _dist_code[DIST_CODE_LEN]; -/* Distance codes. The first 256 values correspond to the distances - * 3 .. 258, the last 256 values correspond to the top 8 bits of - * the 15 bit distances. - */ - -uch _length_code[MAX_MATCH-MIN_MATCH+1]; -/* length code for each normalized match length (0 == MIN_MATCH) */ - -local int base_length[LENGTH_CODES]; -/* First normalized length for each code (0 = MIN_MATCH) */ - -local int base_dist[D_CODES]; -/* First normalized distance for each code (0 = distance of 1) */ - -#else -# include "trees.h" -#endif /* GEN_TREES_H */ - -struct static_tree_desc_s { - const ct_data *static_tree; /* static tree or NULL */ - const intf *extra_bits; /* extra bits for each code or NULL */ - int extra_base; /* base index for extra_bits */ - int elems; /* max number of elements in the tree */ - int max_length; /* max bit length for the codes */ -}; - -local static_tree_desc static_l_desc = -{static_ltree, extra_lbits, LITERALS+1, L_CODES, MAX_BITS}; - -local static_tree_desc static_d_desc = -{static_dtree, extra_dbits, 0, D_CODES, MAX_BITS}; - -local static_tree_desc static_bl_desc = -{(const ct_data *)0, extra_blbits, 0, BL_CODES, MAX_BL_BITS}; - -/* =========================================================================== - * Local (static) routines in this file. - */ - -local void tr_static_init OF((void)); -local void init_block OF((deflate_state *s)); -local void pqdownheap OF((deflate_state *s, ct_data *tree, int k)); -local void gen_bitlen OF((deflate_state *s, tree_desc *desc)); -local void gen_codes OF((ct_data *tree, int max_code, ushf *bl_count)); -local void build_tree OF((deflate_state *s, tree_desc *desc)); -local void scan_tree OF((deflate_state *s, ct_data *tree, int max_code)); -local void send_tree OF((deflate_state *s, ct_data *tree, int max_code)); -local int build_bl_tree OF((deflate_state *s)); -local void send_all_trees OF((deflate_state *s, int lcodes, int dcodes, - int blcodes)); -local void compress_block OF((deflate_state *s, const ct_data *ltree, - const ct_data *dtree)); -local int detect_data_type OF((deflate_state *s)); -local unsigned bi_reverse OF((unsigned value, int length)); -local void bi_windup OF((deflate_state *s)); -local void bi_flush OF((deflate_state *s)); -local void copy_block OF((deflate_state *s, charf *buf, unsigned len, - int header)); - -#ifdef GEN_TREES_H -local void gen_trees_header OF((void)); -#endif - -#ifndef DEBUG -# define send_code(s, c, tree) send_bits(s, tree[c].Code, tree[c].Len) - /* Send a code of the given tree. c and tree must not have side effects */ - -#else /* DEBUG */ -# define send_code(s, c, tree) \ - { if (z_verbose>2) fprintf(stderr,"\ncd %3d ",(c)); \ - send_bits(s, tree[c].Code, tree[c].Len); } -#endif - -/* =========================================================================== - * Output a short LSB first on the stream. - * IN assertion: there is enough room in pendingBuf. - */ -#define put_short(s, w) { \ - put_byte(s, (uch)((w) & 0xff)); \ - put_byte(s, (uch)((ush)(w) >> 8)); \ -} - -/* =========================================================================== - * Send a value on a given number of bits. - * IN assertion: length <= 16 and value fits in length bits. - */ -#ifdef DEBUG -local void send_bits OF((deflate_state *s, int value, int length)); - -local void send_bits(s, value, length) - deflate_state *s; - int value; /* value to send */ - int length; /* number of bits */ -{ - Tracevv((stderr," l %2d v %4x ", length, value)); - Assert(length > 0 && length <= 15, "invalid length"); - s->bits_sent += (ulg)length; - - /* If not enough room in bi_buf, use (valid) bits from bi_buf and - * (16 - bi_valid) bits from value, leaving (width - (16-bi_valid)) - * unused bits in value. - */ - if (s->bi_valid > (int)Buf_size - length) { - s->bi_buf |= (ush)value << s->bi_valid; - put_short(s, s->bi_buf); - s->bi_buf = (ush)value >> (Buf_size - s->bi_valid); - s->bi_valid += length - Buf_size; - } else { - s->bi_buf |= (ush)value << s->bi_valid; - s->bi_valid += length; - } -} -#else /* !DEBUG */ - -#define send_bits(s, value, length) \ -{ int len = length;\ - if (s->bi_valid > (int)Buf_size - len) {\ - int val = value;\ - s->bi_buf |= (ush)val << s->bi_valid;\ - put_short(s, s->bi_buf);\ - s->bi_buf = (ush)val >> (Buf_size - s->bi_valid);\ - s->bi_valid += len - Buf_size;\ - } else {\ - s->bi_buf |= (ush)(value) << s->bi_valid;\ - s->bi_valid += len;\ - }\ -} -#endif /* DEBUG */ - - -/* the arguments must not have side effects */ - -/* =========================================================================== - * Initialize the various 'constant' tables. - */ -local void tr_static_init() -{ -#if defined(GEN_TREES_H) || !defined(STDC) - static int static_init_done = 0; - int n; /* iterates over tree elements */ - int bits; /* bit counter */ - int length; /* length value */ - int code; /* code value */ - int dist; /* distance index */ - ush bl_count[MAX_BITS+1]; - /* number of codes at each bit length for an optimal tree */ - - if (static_init_done) return; - - /* For some embedded targets, global variables are not initialized: */ -#ifdef NO_INIT_GLOBAL_POINTERS - static_l_desc.static_tree = static_ltree; - static_l_desc.extra_bits = extra_lbits; - static_d_desc.static_tree = static_dtree; - static_d_desc.extra_bits = extra_dbits; - static_bl_desc.extra_bits = extra_blbits; -#endif - - /* Initialize the mapping length (0..255) -> length code (0..28) */ - length = 0; - for (code = 0; code < LENGTH_CODES-1; code++) { - base_length[code] = length; - for (n = 0; n < (1< dist code (0..29) */ - dist = 0; - for (code = 0 ; code < 16; code++) { - base_dist[code] = dist; - for (n = 0; n < (1<>= 7; /* from now on, all distances are divided by 128 */ - for ( ; code < D_CODES; code++) { - base_dist[code] = dist << 7; - for (n = 0; n < (1<<(extra_dbits[code]-7)); n++) { - _dist_code[256 + dist++] = (uch)code; - } - } - Assert (dist == 256, "tr_static_init: 256+dist != 512"); - - /* Construct the codes of the static literal tree */ - for (bits = 0; bits <= MAX_BITS; bits++) bl_count[bits] = 0; - n = 0; - while (n <= 143) static_ltree[n++].Len = 8, bl_count[8]++; - while (n <= 255) static_ltree[n++].Len = 9, bl_count[9]++; - while (n <= 279) static_ltree[n++].Len = 7, bl_count[7]++; - while (n <= 287) static_ltree[n++].Len = 8, bl_count[8]++; - /* Codes 286 and 287 do not exist, but we must include them in the - * tree construction to get a canonical Huffman tree (longest code - * all ones) - */ - gen_codes((ct_data *)static_ltree, L_CODES+1, bl_count); - - /* The static distance tree is trivial: */ - for (n = 0; n < D_CODES; n++) { - static_dtree[n].Len = 5; - static_dtree[n].Code = bi_reverse((unsigned)n, 5); - } - static_init_done = 1; - -# ifdef GEN_TREES_H - gen_trees_header(); -# endif -#endif /* defined(GEN_TREES_H) || !defined(STDC) */ -} - -/* =========================================================================== - * Genererate the file trees.h describing the static trees. - */ -#ifdef GEN_TREES_H -# ifndef DEBUG -# include -# endif - -# define SEPARATOR(i, last, width) \ - ((i) == (last)? "\n};\n\n" : \ - ((i) % (width) == (width)-1 ? ",\n" : ", ")) - -void gen_trees_header() -{ - FILE *header = fopen("trees.h", "w"); - int i; - - Assert (header != NULL, "Can't open trees.h"); - fprintf(header, - "/* header created automatically with -DGEN_TREES_H */\n\n"); - - fprintf(header, "local const ct_data static_ltree[L_CODES+2] = {\n"); - for (i = 0; i < L_CODES+2; i++) { - fprintf(header, "{{%3u},{%3u}}%s", static_ltree[i].Code, - static_ltree[i].Len, SEPARATOR(i, L_CODES+1, 5)); - } - - fprintf(header, "local const ct_data static_dtree[D_CODES] = {\n"); - for (i = 0; i < D_CODES; i++) { - fprintf(header, "{{%2u},{%2u}}%s", static_dtree[i].Code, - static_dtree[i].Len, SEPARATOR(i, D_CODES-1, 5)); - } - - fprintf(header, "const uch ZLIB_INTERNAL _dist_code[DIST_CODE_LEN] = {\n"); - for (i = 0; i < DIST_CODE_LEN; i++) { - fprintf(header, "%2u%s", _dist_code[i], - SEPARATOR(i, DIST_CODE_LEN-1, 20)); - } - - fprintf(header, - "const uch ZLIB_INTERNAL _length_code[MAX_MATCH-MIN_MATCH+1]= {\n"); - for (i = 0; i < MAX_MATCH-MIN_MATCH+1; i++) { - fprintf(header, "%2u%s", _length_code[i], - SEPARATOR(i, MAX_MATCH-MIN_MATCH, 20)); - } - - fprintf(header, "local const int base_length[LENGTH_CODES] = {\n"); - for (i = 0; i < LENGTH_CODES; i++) { - fprintf(header, "%1u%s", base_length[i], - SEPARATOR(i, LENGTH_CODES-1, 20)); - } - - fprintf(header, "local const int base_dist[D_CODES] = {\n"); - for (i = 0; i < D_CODES; i++) { - fprintf(header, "%5u%s", base_dist[i], - SEPARATOR(i, D_CODES-1, 10)); - } - - fclose(header); -} -#endif /* GEN_TREES_H */ - -/* =========================================================================== - * Initialize the tree data structures for a new zlib stream. - */ -void ZLIB_INTERNAL _tr_init(s) - deflate_state *s; -{ - tr_static_init(); - - s->l_desc.dyn_tree = s->dyn_ltree; - s->l_desc.stat_desc = &static_l_desc; - - s->d_desc.dyn_tree = s->dyn_dtree; - s->d_desc.stat_desc = &static_d_desc; - - s->bl_desc.dyn_tree = s->bl_tree; - s->bl_desc.stat_desc = &static_bl_desc; - - s->bi_buf = 0; - s->bi_valid = 0; -#ifdef DEBUG - s->compressed_len = 0L; - s->bits_sent = 0L; -#endif - - /* Initialize the first block of the first file: */ - init_block(s); -} - -/* =========================================================================== - * Initialize a new block. - */ -local void init_block(s) - deflate_state *s; -{ - int n; /* iterates over tree elements */ - - /* Initialize the trees. */ - for (n = 0; n < L_CODES; n++) s->dyn_ltree[n].Freq = 0; - for (n = 0; n < D_CODES; n++) s->dyn_dtree[n].Freq = 0; - for (n = 0; n < BL_CODES; n++) s->bl_tree[n].Freq = 0; - - s->dyn_ltree[END_BLOCK].Freq = 1; - s->opt_len = s->static_len = 0L; - s->last_lit = s->matches = 0; -} - -#define SMALLEST 1 -/* Index within the heap array of least frequent node in the Huffman tree */ - - -/* =========================================================================== - * Remove the smallest element from the heap and recreate the heap with - * one less element. Updates heap and heap_len. - */ -#define pqremove(s, tree, top) \ -{\ - top = s->heap[SMALLEST]; \ - s->heap[SMALLEST] = s->heap[s->heap_len--]; \ - pqdownheap(s, tree, SMALLEST); \ -} - -/* =========================================================================== - * Compares to subtrees, using the tree depth as tie breaker when - * the subtrees have equal frequency. This minimizes the worst case length. - */ -#define smaller(tree, n, m, depth) \ - (tree[n].Freq < tree[m].Freq || \ - (tree[n].Freq == tree[m].Freq && depth[n] <= depth[m])) - -/* =========================================================================== - * Restore the heap property by moving down the tree starting at node k, - * exchanging a node with the smallest of its two sons if necessary, stopping - * when the heap property is re-established (each father smaller than its - * two sons). - */ -local void pqdownheap(s, tree, k) - deflate_state *s; - ct_data *tree; /* the tree to restore */ - int k; /* node to move down */ -{ - int v = s->heap[k]; - int j = k << 1; /* left son of k */ - while (j <= s->heap_len) { - /* Set j to the smallest of the two sons: */ - if (j < s->heap_len && - smaller(tree, s->heap[j+1], s->heap[j], s->depth)) { - j++; - } - /* Exit if v is smaller than both sons */ - if (smaller(tree, v, s->heap[j], s->depth)) break; - - /* Exchange v with the smallest son */ - s->heap[k] = s->heap[j]; k = j; - - /* And continue down the tree, setting j to the left son of k */ - j <<= 1; - } - s->heap[k] = v; -} - -/* =========================================================================== - * Compute the optimal bit lengths for a tree and update the total bit length - * for the current block. - * IN assertion: the fields freq and dad are set, heap[heap_max] and - * above are the tree nodes sorted by increasing frequency. - * OUT assertions: the field len is set to the optimal bit length, the - * array bl_count contains the frequencies for each bit length. - * The length opt_len is updated; static_len is also updated if stree is - * not null. - */ -local void gen_bitlen(s, desc) - deflate_state *s; - tree_desc *desc; /* the tree descriptor */ -{ - ct_data *tree = desc->dyn_tree; - int max_code = desc->max_code; - const ct_data *stree = desc->stat_desc->static_tree; - const intf *extra = desc->stat_desc->extra_bits; - int base = desc->stat_desc->extra_base; - int max_length = desc->stat_desc->max_length; - int h; /* heap index */ - int n, m; /* iterate over the tree elements */ - int bits; /* bit length */ - int xbits; /* extra bits */ - ush f; /* frequency */ - int overflow = 0; /* number of elements with bit length too large */ - - for (bits = 0; bits <= MAX_BITS; bits++) s->bl_count[bits] = 0; - - /* In a first pass, compute the optimal bit lengths (which may - * overflow in the case of the bit length tree). - */ - tree[s->heap[s->heap_max]].Len = 0; /* root of the heap */ - - for (h = s->heap_max+1; h < HEAP_SIZE; h++) { - n = s->heap[h]; - bits = tree[tree[n].Dad].Len + 1; - if (bits > max_length) bits = max_length, overflow++; - tree[n].Len = (ush)bits; - /* We overwrite tree[n].Dad which is no longer needed */ - - if (n > max_code) continue; /* not a leaf node */ - - s->bl_count[bits]++; - xbits = 0; - if (n >= base) xbits = extra[n-base]; - f = tree[n].Freq; - s->opt_len += (ulg)f * (bits + xbits); - if (stree) s->static_len += (ulg)f * (stree[n].Len + xbits); - } - if (overflow == 0) return; - - Trace((stderr,"\nbit length overflow\n")); - /* This happens for example on obj2 and pic of the Calgary corpus */ - - /* Find the first bit length which could increase: */ - do { - bits = max_length-1; - while (s->bl_count[bits] == 0) bits--; - s->bl_count[bits]--; /* move one leaf down the tree */ - s->bl_count[bits+1] += 2; /* move one overflow item as its brother */ - s->bl_count[max_length]--; - /* The brother of the overflow item also moves one step up, - * but this does not affect bl_count[max_length] - */ - overflow -= 2; - } while (overflow > 0); - - /* Now recompute all bit lengths, scanning in increasing frequency. - * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all - * lengths instead of fixing only the wrong ones. This idea is taken - * from 'ar' written by Haruhiko Okumura.) - */ - for (bits = max_length; bits != 0; bits--) { - n = s->bl_count[bits]; - while (n != 0) { - m = s->heap[--h]; - if (m > max_code) continue; - if ((unsigned) tree[m].Len != (unsigned) bits) { - Trace((stderr,"code %d bits %d->%d\n", m, tree[m].Len, bits)); - s->opt_len += ((long)bits - (long)tree[m].Len) - *(long)tree[m].Freq; - tree[m].Len = (ush)bits; - } - n--; - } - } -} - -/* =========================================================================== - * Generate the codes for a given tree and bit counts (which need not be - * optimal). - * IN assertion: the array bl_count contains the bit length statistics for - * the given tree and the field len is set for all tree elements. - * OUT assertion: the field code is set for all tree elements of non - * zero code length. - */ -local void gen_codes (tree, max_code, bl_count) - ct_data *tree; /* the tree to decorate */ - int max_code; /* largest code with non zero frequency */ - ushf *bl_count; /* number of codes at each bit length */ -{ - ush next_code[MAX_BITS+1]; /* next code value for each bit length */ - ush code = 0; /* running code value */ - int bits; /* bit index */ - int n; /* code index */ - - /* The distribution counts are first used to generate the code values - * without bit reversal. - */ - for (bits = 1; bits <= MAX_BITS; bits++) { - next_code[bits] = code = (code + bl_count[bits-1]) << 1; - } - /* Check that the bit counts in bl_count are consistent. The last code - * must be all ones. - */ - Assert (code + bl_count[MAX_BITS]-1 == (1<dyn_tree; - const ct_data *stree = desc->stat_desc->static_tree; - int elems = desc->stat_desc->elems; - int n, m; /* iterate over heap elements */ - int max_code = -1; /* largest code with non zero frequency */ - int node; /* new node being created */ - - /* Construct the initial heap, with least frequent element in - * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1]. - * heap[0] is not used. - */ - s->heap_len = 0, s->heap_max = HEAP_SIZE; - - for (n = 0; n < elems; n++) { - if (tree[n].Freq != 0) { - s->heap[++(s->heap_len)] = max_code = n; - s->depth[n] = 0; - } else { - tree[n].Len = 0; - } - } - - /* The pkzip format requires that at least one distance code exists, - * and that at least one bit should be sent even if there is only one - * possible code. So to avoid special checks later on we force at least - * two codes of non zero frequency. - */ - while (s->heap_len < 2) { - node = s->heap[++(s->heap_len)] = (max_code < 2 ? ++max_code : 0); - tree[node].Freq = 1; - s->depth[node] = 0; - s->opt_len--; if (stree) s->static_len -= stree[node].Len; - /* node is 0 or 1 so it does not have extra bits */ - } - desc->max_code = max_code; - - /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree, - * establish sub-heaps of increasing lengths: - */ - for (n = s->heap_len/2; n >= 1; n--) pqdownheap(s, tree, n); - - /* Construct the Huffman tree by repeatedly combining the least two - * frequent nodes. - */ - node = elems; /* next internal node of the tree */ - do { - pqremove(s, tree, n); /* n = node of least frequency */ - m = s->heap[SMALLEST]; /* m = node of next least frequency */ - - s->heap[--(s->heap_max)] = n; /* keep the nodes sorted by frequency */ - s->heap[--(s->heap_max)] = m; - - /* Create a new node father of n and m */ - tree[node].Freq = tree[n].Freq + tree[m].Freq; - s->depth[node] = (uch)((s->depth[n] >= s->depth[m] ? - s->depth[n] : s->depth[m]) + 1); - tree[n].Dad = tree[m].Dad = (ush)node; -#ifdef DUMP_BL_TREE - if (tree == s->bl_tree) { - fprintf(stderr,"\nnode %d(%d), sons %d(%d) %d(%d)", - node, tree[node].Freq, n, tree[n].Freq, m, tree[m].Freq); - } -#endif - /* and insert the new node in the heap */ - s->heap[SMALLEST] = node++; - pqdownheap(s, tree, SMALLEST); - - } while (s->heap_len >= 2); - - s->heap[--(s->heap_max)] = s->heap[SMALLEST]; - - /* At this point, the fields freq and dad are set. We can now - * generate the bit lengths. - */ - gen_bitlen(s, (tree_desc *)desc); - - /* The field len is now set, we can generate the bit codes */ - gen_codes ((ct_data *)tree, max_code, s->bl_count); -} - -/* =========================================================================== - * Scan a literal or distance tree to determine the frequencies of the codes - * in the bit length tree. - */ -local void scan_tree (s, tree, max_code) - deflate_state *s; - ct_data *tree; /* the tree to be scanned */ - int max_code; /* and its largest code of non zero frequency */ -{ - int n; /* iterates over all tree elements */ - int prevlen = -1; /* last emitted length */ - int curlen; /* length of current code */ - int nextlen = tree[0].Len; /* length of next code */ - int count = 0; /* repeat count of the current code */ - int max_count = 7; /* max repeat count */ - int min_count = 4; /* min repeat count */ - - if (nextlen == 0) max_count = 138, min_count = 3; - tree[max_code+1].Len = (ush)0xffff; /* guard */ - - for (n = 0; n <= max_code; n++) { - curlen = nextlen; nextlen = tree[n+1].Len; - if (++count < max_count && curlen == nextlen) { - continue; - } else if (count < min_count) { - s->bl_tree[curlen].Freq += count; - } else if (curlen != 0) { - if (curlen != prevlen) s->bl_tree[curlen].Freq++; - s->bl_tree[REP_3_6].Freq++; - } else if (count <= 10) { - s->bl_tree[REPZ_3_10].Freq++; - } else { - s->bl_tree[REPZ_11_138].Freq++; - } - count = 0; prevlen = curlen; - if (nextlen == 0) { - max_count = 138, min_count = 3; - } else if (curlen == nextlen) { - max_count = 6, min_count = 3; - } else { - max_count = 7, min_count = 4; - } - } -} - -/* =========================================================================== - * Send a literal or distance tree in compressed form, using the codes in - * bl_tree. - */ -local void send_tree (s, tree, max_code) - deflate_state *s; - ct_data *tree; /* the tree to be scanned */ - int max_code; /* and its largest code of non zero frequency */ -{ - int n; /* iterates over all tree elements */ - int prevlen = -1; /* last emitted length */ - int curlen; /* length of current code */ - int nextlen = tree[0].Len; /* length of next code */ - int count = 0; /* repeat count of the current code */ - int max_count = 7; /* max repeat count */ - int min_count = 4; /* min repeat count */ - - /* tree[max_code+1].Len = -1; */ /* guard already set */ - if (nextlen == 0) max_count = 138, min_count = 3; - - for (n = 0; n <= max_code; n++) { - curlen = nextlen; nextlen = tree[n+1].Len; - if (++count < max_count && curlen == nextlen) { - continue; - } else if (count < min_count) { - do { send_code(s, curlen, s->bl_tree); } while (--count != 0); - - } else if (curlen != 0) { - if (curlen != prevlen) { - send_code(s, curlen, s->bl_tree); count--; - } - Assert(count >= 3 && count <= 6, " 3_6?"); - send_code(s, REP_3_6, s->bl_tree); send_bits(s, count-3, 2); - - } else if (count <= 10) { - send_code(s, REPZ_3_10, s->bl_tree); send_bits(s, count-3, 3); - - } else { - send_code(s, REPZ_11_138, s->bl_tree); send_bits(s, count-11, 7); - } - count = 0; prevlen = curlen; - if (nextlen == 0) { - max_count = 138, min_count = 3; - } else if (curlen == nextlen) { - max_count = 6, min_count = 3; - } else { - max_count = 7, min_count = 4; - } - } -} - -/* =========================================================================== - * Construct the Huffman tree for the bit lengths and return the index in - * bl_order of the last bit length code to send. - */ -local int build_bl_tree(s) - deflate_state *s; -{ - int max_blindex; /* index of last bit length code of non zero freq */ - - /* Determine the bit length frequencies for literal and distance trees */ - scan_tree(s, (ct_data *)s->dyn_ltree, s->l_desc.max_code); - scan_tree(s, (ct_data *)s->dyn_dtree, s->d_desc.max_code); - - /* Build the bit length tree: */ - build_tree(s, (tree_desc *)(&(s->bl_desc))); - /* opt_len now includes the length of the tree representations, except - * the lengths of the bit lengths codes and the 5+5+4 bits for the counts. - */ - - /* Determine the number of bit length codes to send. The pkzip format - * requires that at least 4 bit length codes be sent. (appnote.txt says - * 3 but the actual value used is 4.) - */ - for (max_blindex = BL_CODES-1; max_blindex >= 3; max_blindex--) { - if (s->bl_tree[bl_order[max_blindex]].Len != 0) break; - } - /* Update opt_len to include the bit length tree and counts */ - s->opt_len += 3*(max_blindex+1) + 5+5+4; - Tracev((stderr, "\ndyn trees: dyn %ld, stat %ld", - s->opt_len, s->static_len)); - - return max_blindex; -} - -/* =========================================================================== - * Send the header for a block using dynamic Huffman trees: the counts, the - * lengths of the bit length codes, the literal tree and the distance tree. - * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4. - */ -local void send_all_trees(s, lcodes, dcodes, blcodes) - deflate_state *s; - int lcodes, dcodes, blcodes; /* number of codes for each tree */ -{ - int rank; /* index in bl_order */ - - Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, "not enough codes"); - Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES, - "too many codes"); - Tracev((stderr, "\nbl counts: ")); - send_bits(s, lcodes-257, 5); /* not +255 as stated in appnote.txt */ - send_bits(s, dcodes-1, 5); - send_bits(s, blcodes-4, 4); /* not -3 as stated in appnote.txt */ - for (rank = 0; rank < blcodes; rank++) { - Tracev((stderr, "\nbl code %2d ", bl_order[rank])); - send_bits(s, s->bl_tree[bl_order[rank]].Len, 3); - } - Tracev((stderr, "\nbl tree: sent %ld", s->bits_sent)); - - send_tree(s, (ct_data *)s->dyn_ltree, lcodes-1); /* literal tree */ - Tracev((stderr, "\nlit tree: sent %ld", s->bits_sent)); - - send_tree(s, (ct_data *)s->dyn_dtree, dcodes-1); /* distance tree */ - Tracev((stderr, "\ndist tree: sent %ld", s->bits_sent)); -} - -/* =========================================================================== - * Send a stored block - */ -void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last) - deflate_state *s; - charf *buf; /* input block */ - ulg stored_len; /* length of input block */ - int last; /* one if this is the last block for a file */ -{ - send_bits(s, (STORED_BLOCK<<1)+last, 3); /* send block type */ -#ifdef DEBUG - s->compressed_len = (s->compressed_len + 3 + 7) & (ulg)~7L; - s->compressed_len += (stored_len + 4) << 3; -#endif - copy_block(s, buf, (unsigned)stored_len, 1); /* with header */ -} - -/* =========================================================================== - * Flush the bits in the bit buffer to pending output (leaves at most 7 bits) - */ -void ZLIB_INTERNAL _tr_flush_bits(s) - deflate_state *s; -{ - bi_flush(s); -} - -/* =========================================================================== - * Send one empty static block to give enough lookahead for inflate. - * This takes 10 bits, of which 7 may remain in the bit buffer. - */ -void ZLIB_INTERNAL _tr_align(s) - deflate_state *s; -{ - send_bits(s, STATIC_TREES<<1, 3); - send_code(s, END_BLOCK, static_ltree); -#ifdef DEBUG - s->compressed_len += 10L; /* 3 for block type, 7 for EOB */ -#endif - bi_flush(s); -} - -/* =========================================================================== - * Determine the best encoding for the current block: dynamic trees, static - * trees or store, and output the encoded block to the zip file. - */ -void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last) - deflate_state *s; - charf *buf; /* input block, or NULL if too old */ - ulg stored_len; /* length of input block */ - int last; /* one if this is the last block for a file */ -{ - ulg opt_lenb, static_lenb; /* opt_len and static_len in bytes */ - int max_blindex = 0; /* index of last bit length code of non zero freq */ - - /* Build the Huffman trees unless a stored block is forced */ - if (s->level > 0) { - - /* Check if the file is binary or text */ - if (s->strm->data_type == Z_UNKNOWN) - s->strm->data_type = detect_data_type(s); - - /* Construct the literal and distance trees */ - build_tree(s, (tree_desc *)(&(s->l_desc))); - Tracev((stderr, "\nlit data: dyn %ld, stat %ld", s->opt_len, - s->static_len)); - - build_tree(s, (tree_desc *)(&(s->d_desc))); - Tracev((stderr, "\ndist data: dyn %ld, stat %ld", s->opt_len, - s->static_len)); - /* At this point, opt_len and static_len are the total bit lengths of - * the compressed block data, excluding the tree representations. - */ - - /* Build the bit length tree for the above two trees, and get the index - * in bl_order of the last bit length code to send. - */ - max_blindex = build_bl_tree(s); - - /* Determine the best encoding. Compute the block lengths in bytes. */ - opt_lenb = (s->opt_len+3+7)>>3; - static_lenb = (s->static_len+3+7)>>3; - - Tracev((stderr, "\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u ", - opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len, - s->last_lit)); - - if (static_lenb <= opt_lenb) opt_lenb = static_lenb; - - } else { - Assert(buf != (char*)0, "lost buf"); - opt_lenb = static_lenb = stored_len + 5; /* force a stored block */ - } - -#ifdef FORCE_STORED - if (buf != (char*)0) { /* force stored block */ -#else - if (stored_len+4 <= opt_lenb && buf != (char*)0) { - /* 4: two words for the lengths */ -#endif - /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE. - * Otherwise we can't have processed more than WSIZE input bytes since - * the last block flush, because compression would have been - * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to - * transform a block into a stored block. - */ - _tr_stored_block(s, buf, stored_len, last); - -#ifdef FORCE_STATIC - } else if (static_lenb >= 0) { /* force static trees */ -#else - } else if (s->strategy == Z_FIXED || static_lenb == opt_lenb) { -#endif - send_bits(s, (STATIC_TREES<<1)+last, 3); - compress_block(s, (const ct_data *)static_ltree, - (const ct_data *)static_dtree); -#ifdef DEBUG - s->compressed_len += 3 + s->static_len; -#endif - } else { - send_bits(s, (DYN_TREES<<1)+last, 3); - send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1, - max_blindex+1); - compress_block(s, (const ct_data *)s->dyn_ltree, - (const ct_data *)s->dyn_dtree); -#ifdef DEBUG - s->compressed_len += 3 + s->opt_len; -#endif - } - Assert (s->compressed_len == s->bits_sent, "bad compressed size"); - /* The above check is made mod 2^32, for files larger than 512 MB - * and uLong implemented on 32 bits. - */ - init_block(s); - - if (last) { - bi_windup(s); -#ifdef DEBUG - s->compressed_len += 7; /* align on byte boundary */ -#endif - } - Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3, - s->compressed_len-7*last)); -} - -/* =========================================================================== - * Save the match info and tally the frequency counts. Return true if - * the current block must be flushed. - */ -int ZLIB_INTERNAL _tr_tally (s, dist, lc) - deflate_state *s; - unsigned dist; /* distance of matched string */ - unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */ -{ - s->d_buf[s->last_lit] = (ush)dist; - s->l_buf[s->last_lit++] = (uch)lc; - if (dist == 0) { - /* lc is the unmatched char */ - s->dyn_ltree[lc].Freq++; - } else { - s->matches++; - /* Here, lc is the match length - MIN_MATCH */ - dist--; /* dist = match distance - 1 */ - Assert((ush)dist < (ush)MAX_DIST(s) && - (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) && - (ush)d_code(dist) < (ush)D_CODES, "_tr_tally: bad match"); - - s->dyn_ltree[_length_code[lc]+LITERALS+1].Freq++; - s->dyn_dtree[d_code(dist)].Freq++; - } - -#ifdef TRUNCATE_BLOCK - /* Try to guess if it is profitable to stop the current block here */ - if ((s->last_lit & 0x1fff) == 0 && s->level > 2) { - /* Compute an upper bound for the compressed length */ - ulg out_length = (ulg)s->last_lit*8L; - ulg in_length = (ulg)((long)s->strstart - s->block_start); - int dcode; - for (dcode = 0; dcode < D_CODES; dcode++) { - out_length += (ulg)s->dyn_dtree[dcode].Freq * - (5L+extra_dbits[dcode]); - } - out_length >>= 3; - Tracev((stderr,"\nlast_lit %u, in %ld, out ~%ld(%ld%%) ", - s->last_lit, in_length, out_length, - 100L - out_length*100L/in_length)); - if (s->matches < s->last_lit/2 && out_length < in_length/2) return 1; - } -#endif - return (s->last_lit == s->lit_bufsize-1); - /* We avoid equality with lit_bufsize because of wraparound at 64K - * on 16 bit machines and because stored blocks are restricted to - * 64K-1 bytes. - */ -} - -/* =========================================================================== - * Send the block data compressed using the given Huffman trees - */ -local void compress_block(s, ltree, dtree) - deflate_state *s; - const ct_data *ltree; /* literal tree */ - const ct_data *dtree; /* distance tree */ -{ - unsigned dist; /* distance of matched string */ - int lc; /* match length or unmatched char (if dist == 0) */ - unsigned lx = 0; /* running index in l_buf */ - unsigned code; /* the code to send */ - int extra; /* number of extra bits to send */ - - if (s->last_lit != 0) do { - dist = s->d_buf[lx]; - lc = s->l_buf[lx++]; - if (dist == 0) { - send_code(s, lc, ltree); /* send a literal byte */ - Tracecv(isgraph(lc), (stderr," '%c' ", lc)); - } else { - /* Here, lc is the match length - MIN_MATCH */ - code = _length_code[lc]; - send_code(s, code+LITERALS+1, ltree); /* send the length code */ - extra = extra_lbits[code]; - if (extra != 0) { - lc -= base_length[code]; - send_bits(s, lc, extra); /* send the extra length bits */ - } - dist--; /* dist is now the match distance - 1 */ - code = d_code(dist); - Assert (code < D_CODES, "bad d_code"); - - send_code(s, code, dtree); /* send the distance code */ - extra = extra_dbits[code]; - if (extra != 0) { - dist -= base_dist[code]; - send_bits(s, dist, extra); /* send the extra distance bits */ - } - } /* literal or match pair ? */ - - /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */ - Assert((uInt)(s->pending) < s->lit_bufsize + 2*lx, - "pendingBuf overflow"); - - } while (lx < s->last_lit); - - send_code(s, END_BLOCK, ltree); -} - -/* =========================================================================== - * Check if the data type is TEXT or BINARY, using the following algorithm: - * - TEXT if the two conditions below are satisfied: - * a) There are no non-portable control characters belonging to the - * "black list" (0..6, 14..25, 28..31). - * b) There is at least one printable character belonging to the - * "white list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255). - * - BINARY otherwise. - * - The following partially-portable control characters form a - * "gray list" that is ignored in this detection algorithm: - * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}). - * IN assertion: the fields Freq of dyn_ltree are set. - */ -local int detect_data_type(s) - deflate_state *s; -{ - /* black_mask is the bit mask of black-listed bytes - * set bits 0..6, 14..25, and 28..31 - * 0xf3ffc07f = binary 11110011111111111100000001111111 - */ - unsigned long black_mask = 0xf3ffc07fUL; - int n; - - /* Check for non-textual ("black-listed") bytes. */ - for (n = 0; n <= 31; n++, black_mask >>= 1) - if ((black_mask & 1) && (s->dyn_ltree[n].Freq != 0)) - return Z_BINARY; - - /* Check for textual ("white-listed") bytes. */ - if (s->dyn_ltree[9].Freq != 0 || s->dyn_ltree[10].Freq != 0 - || s->dyn_ltree[13].Freq != 0) - return Z_TEXT; - for (n = 32; n < LITERALS; n++) - if (s->dyn_ltree[n].Freq != 0) - return Z_TEXT; - - /* There are no "black-listed" or "white-listed" bytes: - * this stream either is empty or has tolerated ("gray-listed") bytes only. - */ - return Z_BINARY; -} - -/* =========================================================================== - * Reverse the first len bits of a code, using straightforward code (a faster - * method would use a table) - * IN assertion: 1 <= len <= 15 - */ -local unsigned bi_reverse(code, len) - unsigned code; /* the value to invert */ - int len; /* its bit length */ -{ - register unsigned res = 0; - do { - res |= code & 1; - code >>= 1, res <<= 1; - } while (--len > 0); - return res >> 1; -} - -/* =========================================================================== - * Flush the bit buffer, keeping at most 7 bits in it. - */ -local void bi_flush(s) - deflate_state *s; -{ - if (s->bi_valid == 16) { - put_short(s, s->bi_buf); - s->bi_buf = 0; - s->bi_valid = 0; - } else if (s->bi_valid >= 8) { - put_byte(s, (Byte)s->bi_buf); - s->bi_buf >>= 8; - s->bi_valid -= 8; - } -} - -/* =========================================================================== - * Flush the bit buffer and align the output on a byte boundary - */ -local void bi_windup(s) - deflate_state *s; -{ - if (s->bi_valid > 8) { - put_short(s, s->bi_buf); - } else if (s->bi_valid > 0) { - put_byte(s, (Byte)s->bi_buf); - } - s->bi_buf = 0; - s->bi_valid = 0; -#ifdef DEBUG - s->bits_sent = (s->bits_sent+7) & ~7; -#endif -} - -/* =========================================================================== - * Copy a stored block, storing first the length and its - * one's complement if requested. - */ -local void copy_block(s, buf, len, header) - deflate_state *s; - charf *buf; /* the input data */ - unsigned len; /* its length */ - int header; /* true if block header must be written */ -{ - bi_windup(s); /* align on byte boundary */ - - if (header) { - put_short(s, (ush)len); - put_short(s, (ush)~len); -#ifdef DEBUG - s->bits_sent += 2*16; -#endif - } -#ifdef DEBUG - s->bits_sent += (ulg)len<<3; -#endif - while (len--) { - put_byte(s, *buf++); - } -} diff --git a/btgui/zlib/trees.h b/btgui/zlib/trees.h deleted file mode 100644 index d35639d82..000000000 --- a/btgui/zlib/trees.h +++ /dev/null @@ -1,128 +0,0 @@ -/* header created automatically with -DGEN_TREES_H */ - -local const ct_data static_ltree[L_CODES+2] = { -{{ 12},{ 8}}, {{140},{ 8}}, {{ 76},{ 8}}, {{204},{ 8}}, {{ 44},{ 8}}, -{{172},{ 8}}, {{108},{ 8}}, {{236},{ 8}}, {{ 28},{ 8}}, {{156},{ 8}}, -{{ 92},{ 8}}, {{220},{ 8}}, {{ 60},{ 8}}, {{188},{ 8}}, {{124},{ 8}}, -{{252},{ 8}}, {{ 2},{ 8}}, {{130},{ 8}}, {{ 66},{ 8}}, {{194},{ 8}}, -{{ 34},{ 8}}, {{162},{ 8}}, {{ 98},{ 8}}, {{226},{ 8}}, {{ 18},{ 8}}, -{{146},{ 8}}, {{ 82},{ 8}}, {{210},{ 8}}, {{ 50},{ 8}}, {{178},{ 8}}, -{{114},{ 8}}, {{242},{ 8}}, {{ 10},{ 8}}, {{138},{ 8}}, {{ 74},{ 8}}, -{{202},{ 8}}, {{ 42},{ 8}}, {{170},{ 8}}, {{106},{ 8}}, {{234},{ 8}}, -{{ 26},{ 8}}, {{154},{ 8}}, {{ 90},{ 8}}, {{218},{ 8}}, {{ 58},{ 8}}, -{{186},{ 8}}, {{122},{ 8}}, {{250},{ 8}}, {{ 6},{ 8}}, {{134},{ 8}}, -{{ 70},{ 8}}, {{198},{ 8}}, {{ 38},{ 8}}, {{166},{ 8}}, {{102},{ 8}}, -{{230},{ 8}}, {{ 22},{ 8}}, {{150},{ 8}}, {{ 86},{ 8}}, {{214},{ 8}}, -{{ 54},{ 8}}, {{182},{ 8}}, {{118},{ 8}}, {{246},{ 8}}, {{ 14},{ 8}}, -{{142},{ 8}}, {{ 78},{ 8}}, {{206},{ 8}}, {{ 46},{ 8}}, {{174},{ 8}}, -{{110},{ 8}}, {{238},{ 8}}, {{ 30},{ 8}}, {{158},{ 8}}, {{ 94},{ 8}}, -{{222},{ 8}}, {{ 62},{ 8}}, {{190},{ 8}}, {{126},{ 8}}, {{254},{ 8}}, -{{ 1},{ 8}}, {{129},{ 8}}, {{ 65},{ 8}}, {{193},{ 8}}, {{ 33},{ 8}}, -{{161},{ 8}}, {{ 97},{ 8}}, {{225},{ 8}}, {{ 17},{ 8}}, {{145},{ 8}}, -{{ 81},{ 8}}, {{209},{ 8}}, {{ 49},{ 8}}, {{177},{ 8}}, {{113},{ 8}}, -{{241},{ 8}}, {{ 9},{ 8}}, {{137},{ 8}}, {{ 73},{ 8}}, {{201},{ 8}}, -{{ 41},{ 8}}, {{169},{ 8}}, {{105},{ 8}}, {{233},{ 8}}, {{ 25},{ 8}}, -{{153},{ 8}}, {{ 89},{ 8}}, {{217},{ 8}}, {{ 57},{ 8}}, {{185},{ 8}}, -{{121},{ 8}}, {{249},{ 8}}, {{ 5},{ 8}}, {{133},{ 8}}, {{ 69},{ 8}}, -{{197},{ 8}}, {{ 37},{ 8}}, {{165},{ 8}}, {{101},{ 8}}, {{229},{ 8}}, -{{ 21},{ 8}}, {{149},{ 8}}, {{ 85},{ 8}}, {{213},{ 8}}, {{ 53},{ 8}}, -{{181},{ 8}}, {{117},{ 8}}, {{245},{ 8}}, {{ 13},{ 8}}, {{141},{ 8}}, -{{ 77},{ 8}}, {{205},{ 8}}, {{ 45},{ 8}}, {{173},{ 8}}, {{109},{ 8}}, -{{237},{ 8}}, {{ 29},{ 8}}, {{157},{ 8}}, {{ 93},{ 8}}, {{221},{ 8}}, -{{ 61},{ 8}}, {{189},{ 8}}, {{125},{ 8}}, {{253},{ 8}}, {{ 19},{ 9}}, -{{275},{ 9}}, {{147},{ 9}}, {{403},{ 9}}, {{ 83},{ 9}}, {{339},{ 9}}, -{{211},{ 9}}, {{467},{ 9}}, {{ 51},{ 9}}, {{307},{ 9}}, {{179},{ 9}}, -{{435},{ 9}}, {{115},{ 9}}, {{371},{ 9}}, {{243},{ 9}}, {{499},{ 9}}, -{{ 11},{ 9}}, {{267},{ 9}}, {{139},{ 9}}, {{395},{ 9}}, {{ 75},{ 9}}, -{{331},{ 9}}, {{203},{ 9}}, {{459},{ 9}}, {{ 43},{ 9}}, {{299},{ 9}}, -{{171},{ 9}}, {{427},{ 9}}, {{107},{ 9}}, {{363},{ 9}}, {{235},{ 9}}, -{{491},{ 9}}, {{ 27},{ 9}}, {{283},{ 9}}, {{155},{ 9}}, {{411},{ 9}}, -{{ 91},{ 9}}, {{347},{ 9}}, {{219},{ 9}}, {{475},{ 9}}, {{ 59},{ 9}}, -{{315},{ 9}}, {{187},{ 9}}, {{443},{ 9}}, {{123},{ 9}}, {{379},{ 9}}, -{{251},{ 9}}, {{507},{ 9}}, {{ 7},{ 9}}, {{263},{ 9}}, {{135},{ 9}}, -{{391},{ 9}}, {{ 71},{ 9}}, {{327},{ 9}}, {{199},{ 9}}, {{455},{ 9}}, -{{ 39},{ 9}}, {{295},{ 9}}, {{167},{ 9}}, {{423},{ 9}}, {{103},{ 9}}, -{{359},{ 9}}, {{231},{ 9}}, {{487},{ 9}}, {{ 23},{ 9}}, {{279},{ 9}}, -{{151},{ 9}}, {{407},{ 9}}, {{ 87},{ 9}}, {{343},{ 9}}, {{215},{ 9}}, -{{471},{ 9}}, {{ 55},{ 9}}, {{311},{ 9}}, {{183},{ 9}}, {{439},{ 9}}, -{{119},{ 9}}, {{375},{ 9}}, {{247},{ 9}}, {{503},{ 9}}, {{ 15},{ 9}}, -{{271},{ 9}}, {{143},{ 9}}, {{399},{ 9}}, {{ 79},{ 9}}, {{335},{ 9}}, -{{207},{ 9}}, {{463},{ 9}}, {{ 47},{ 9}}, {{303},{ 9}}, {{175},{ 9}}, -{{431},{ 9}}, {{111},{ 9}}, {{367},{ 9}}, {{239},{ 9}}, {{495},{ 9}}, -{{ 31},{ 9}}, {{287},{ 9}}, {{159},{ 9}}, {{415},{ 9}}, {{ 95},{ 9}}, -{{351},{ 9}}, {{223},{ 9}}, {{479},{ 9}}, {{ 63},{ 9}}, {{319},{ 9}}, -{{191},{ 9}}, {{447},{ 9}}, {{127},{ 9}}, {{383},{ 9}}, {{255},{ 9}}, -{{511},{ 9}}, {{ 0},{ 7}}, {{ 64},{ 7}}, {{ 32},{ 7}}, {{ 96},{ 7}}, -{{ 16},{ 7}}, {{ 80},{ 7}}, {{ 48},{ 7}}, {{112},{ 7}}, {{ 8},{ 7}}, -{{ 72},{ 7}}, {{ 40},{ 7}}, {{104},{ 7}}, {{ 24},{ 7}}, {{ 88},{ 7}}, -{{ 56},{ 7}}, {{120},{ 7}}, {{ 4},{ 7}}, {{ 68},{ 7}}, {{ 36},{ 7}}, -{{100},{ 7}}, {{ 20},{ 7}}, {{ 84},{ 7}}, {{ 52},{ 7}}, {{116},{ 7}}, -{{ 3},{ 8}}, {{131},{ 8}}, {{ 67},{ 8}}, {{195},{ 8}}, {{ 35},{ 8}}, -{{163},{ 8}}, {{ 99},{ 8}}, {{227},{ 8}} -}; - -local const ct_data static_dtree[D_CODES] = { -{{ 0},{ 5}}, {{16},{ 5}}, {{ 8},{ 5}}, {{24},{ 5}}, {{ 4},{ 5}}, -{{20},{ 5}}, {{12},{ 5}}, {{28},{ 5}}, {{ 2},{ 5}}, {{18},{ 5}}, -{{10},{ 5}}, {{26},{ 5}}, {{ 6},{ 5}}, {{22},{ 5}}, {{14},{ 5}}, -{{30},{ 5}}, {{ 1},{ 5}}, {{17},{ 5}}, {{ 9},{ 5}}, {{25},{ 5}}, -{{ 5},{ 5}}, {{21},{ 5}}, {{13},{ 5}}, {{29},{ 5}}, {{ 3},{ 5}}, -{{19},{ 5}}, {{11},{ 5}}, {{27},{ 5}}, {{ 7},{ 5}}, {{23},{ 5}} -}; - -const uch ZLIB_INTERNAL _dist_code[DIST_CODE_LEN] = { - 0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 8, - 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, -10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, -11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, -12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, -13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, -13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, -14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, -14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, -14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15, -15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, -15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, -15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 0, 0, 16, 17, -18, 18, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 22, 22, 22, 22, 22, 22, 22, 22, -23, 23, 23, 23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, -24, 24, 24, 24, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, -26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, -26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 27, 27, 27, 27, 27, 27, 27, 27, -27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, -27, 27, 27, 27, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, -28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, -28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, -28, 28, 28, 28, 28, 28, 28, 28, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, -29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, -29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, -29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29 -}; - -const uch ZLIB_INTERNAL _length_code[MAX_MATCH-MIN_MATCH+1]= { - 0, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 12, -13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, -17, 17, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19, -19, 19, 19, 19, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, -21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 22, 22, 22, 22, -22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 23, 23, 23, 23, 23, 23, 23, 23, -23, 23, 23, 23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, -24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, -25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, -25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 26, 26, 26, 26, 26, 26, 26, 26, -26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, -26, 26, 26, 26, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, -27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 28 -}; - -local const int base_length[LENGTH_CODES] = { -0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 14, 16, 20, 24, 28, 32, 40, 48, 56, -64, 80, 96, 112, 128, 160, 192, 224, 0 -}; - -local const int base_dist[D_CODES] = { - 0, 1, 2, 3, 4, 6, 8, 12, 16, 24, - 32, 48, 64, 96, 128, 192, 256, 384, 512, 768, - 1024, 1536, 2048, 3072, 4096, 6144, 8192, 12288, 16384, 24576 -}; - diff --git a/btgui/zlib/uncompr.c b/btgui/zlib/uncompr.c deleted file mode 100644 index 242e9493d..000000000 --- a/btgui/zlib/uncompr.c +++ /dev/null @@ -1,59 +0,0 @@ -/* uncompr.c -- decompress a memory buffer - * Copyright (C) 1995-2003, 2010 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* @(#) $Id$ */ - -#define ZLIB_INTERNAL -#include "zlib.h" - -/* =========================================================================== - Decompresses the source buffer into the destination buffer. sourceLen is - the byte length of the source buffer. Upon entry, destLen is the total - size of the destination buffer, which must be large enough to hold the - entire uncompressed data. (The size of the uncompressed data must have - been saved previously by the compressor and transmitted to the decompressor - by some mechanism outside the scope of this compression library.) - Upon exit, destLen is the actual size of the compressed buffer. - - uncompress returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_BUF_ERROR if there was not enough room in the output - buffer, or Z_DATA_ERROR if the input data was corrupted. -*/ -int ZEXPORT uncompress (dest, destLen, source, sourceLen) - Bytef *dest; - uLongf *destLen; - const Bytef *source; - uLong sourceLen; -{ - z_stream stream; - int err; - - stream.next_in = (z_const Bytef *)source; - stream.avail_in = (uInt)sourceLen; - /* Check for source > 64K on 16-bit machine: */ - if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR; - - stream.next_out = dest; - stream.avail_out = (uInt)*destLen; - if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR; - - stream.zalloc = (alloc_func)0; - stream.zfree = (free_func)0; - - err = inflateInit(&stream); - if (err != Z_OK) return err; - - err = inflate(&stream, Z_FINISH); - if (err != Z_STREAM_END) { - inflateEnd(&stream); - if (err == Z_NEED_DICT || (err == Z_BUF_ERROR && stream.avail_in == 0)) - return Z_DATA_ERROR; - return err; - } - *destLen = stream.total_out; - - err = inflateEnd(&stream); - return err; -} diff --git a/btgui/zlib/zconf.h b/btgui/zlib/zconf.h deleted file mode 100644 index 9987a7755..000000000 --- a/btgui/zlib/zconf.h +++ /dev/null @@ -1,511 +0,0 @@ -/* zconf.h -- configuration of the zlib compression library - * Copyright (C) 1995-2013 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* @(#) $Id$ */ - -#ifndef ZCONF_H -#define ZCONF_H - -/* - * If you *really* need a unique prefix for all types and library functions, - * compile with -DZ_PREFIX. The "standard" zlib should be compiled without it. - * Even better than compiling with -DZ_PREFIX would be to use configure to set - * this permanently in zconf.h using "./configure --zprefix". - */ -#ifdef Z_PREFIX /* may be set to #if 1 by ./configure */ -# define Z_PREFIX_SET - -/* all linked symbols */ -# define _dist_code z__dist_code -# define _length_code z__length_code -# define _tr_align z__tr_align -# define _tr_flush_bits z__tr_flush_bits -# define _tr_flush_block z__tr_flush_block -# define _tr_init z__tr_init -# define _tr_stored_block z__tr_stored_block -# define _tr_tally z__tr_tally -# define adler32 z_adler32 -# define adler32_combine z_adler32_combine -# define adler32_combine64 z_adler32_combine64 -# ifndef Z_SOLO -# define compress z_compress -# define compress2 z_compress2 -# define compressBound z_compressBound -# endif -# define crc32 z_crc32 -# define crc32_combine z_crc32_combine -# define crc32_combine64 z_crc32_combine64 -# define deflate z_deflate -# define deflateBound z_deflateBound -# define deflateCopy z_deflateCopy -# define deflateEnd z_deflateEnd -# define deflateInit2_ z_deflateInit2_ -# define deflateInit_ z_deflateInit_ -# define deflateParams z_deflateParams -# define deflatePending z_deflatePending -# define deflatePrime z_deflatePrime -# define deflateReset z_deflateReset -# define deflateResetKeep z_deflateResetKeep -# define deflateSetDictionary z_deflateSetDictionary -# define deflateSetHeader z_deflateSetHeader -# define deflateTune z_deflateTune -# define deflate_copyright z_deflate_copyright -# define get_crc_table z_get_crc_table -# ifndef Z_SOLO -# define gz_error z_gz_error -# define gz_intmax z_gz_intmax -# define gz_strwinerror z_gz_strwinerror -# define gzbuffer z_gzbuffer -# define gzclearerr z_gzclearerr -# define gzclose z_gzclose -# define gzclose_r z_gzclose_r -# define gzclose_w z_gzclose_w -# define gzdirect z_gzdirect -# define gzdopen z_gzdopen -# define gzeof z_gzeof -# define gzerror z_gzerror -# define gzflush z_gzflush -# define gzgetc z_gzgetc -# define gzgetc_ z_gzgetc_ -# define gzgets z_gzgets -# define gzoffset z_gzoffset -# define gzoffset64 z_gzoffset64 -# define gzopen z_gzopen -# define gzopen64 z_gzopen64 -# ifdef _WIN32 -# define gzopen_w z_gzopen_w -# endif -# define gzprintf z_gzprintf -# define gzvprintf z_gzvprintf -# define gzputc z_gzputc -# define gzputs z_gzputs -# define gzread z_gzread -# define gzrewind z_gzrewind -# define gzseek z_gzseek -# define gzseek64 z_gzseek64 -# define gzsetparams z_gzsetparams -# define gztell z_gztell -# define gztell64 z_gztell64 -# define gzungetc z_gzungetc -# define gzwrite z_gzwrite -# endif -# define inflate z_inflate -# define inflateBack z_inflateBack -# define inflateBackEnd z_inflateBackEnd -# define inflateBackInit_ z_inflateBackInit_ -# define inflateCopy z_inflateCopy -# define inflateEnd z_inflateEnd -# define inflateGetHeader z_inflateGetHeader -# define inflateInit2_ z_inflateInit2_ -# define inflateInit_ z_inflateInit_ -# define inflateMark z_inflateMark -# define inflatePrime z_inflatePrime -# define inflateReset z_inflateReset -# define inflateReset2 z_inflateReset2 -# define inflateSetDictionary z_inflateSetDictionary -# define inflateGetDictionary z_inflateGetDictionary -# define inflateSync z_inflateSync -# define inflateSyncPoint z_inflateSyncPoint -# define inflateUndermine z_inflateUndermine -# define inflateResetKeep z_inflateResetKeep -# define inflate_copyright z_inflate_copyright -# define inflate_fast z_inflate_fast -# define inflate_table z_inflate_table -# ifndef Z_SOLO -# define uncompress z_uncompress -# endif -# define zError z_zError -# ifndef Z_SOLO -# define zcalloc z_zcalloc -# define zcfree z_zcfree -# endif -# define zlibCompileFlags z_zlibCompileFlags -# define zlibVersion z_zlibVersion - -/* all zlib typedefs in zlib.h and zconf.h */ -# define Byte z_Byte -# define Bytef z_Bytef -# define alloc_func z_alloc_func -# define charf z_charf -# define free_func z_free_func -# ifndef Z_SOLO -# define gzFile z_gzFile -# endif -# define gz_header z_gz_header -# define gz_headerp z_gz_headerp -# define in_func z_in_func -# define intf z_intf -# define out_func z_out_func -# define uInt z_uInt -# define uIntf z_uIntf -# define uLong z_uLong -# define uLongf z_uLongf -# define voidp z_voidp -# define voidpc z_voidpc -# define voidpf z_voidpf - -/* all zlib structs in zlib.h and zconf.h */ -# define gz_header_s z_gz_header_s -# define internal_state z_internal_state - -#endif - -#if defined(__MSDOS__) && !defined(MSDOS) -# define MSDOS -#endif -#if (defined(OS_2) || defined(__OS2__)) && !defined(OS2) -# define OS2 -#endif -#if defined(_WINDOWS) && !defined(WINDOWS) -# define WINDOWS -#endif -#if defined(_WIN32) || defined(_WIN32_WCE) || defined(__WIN32__) -# ifndef WIN32 -# define WIN32 -# endif -#endif -#if (defined(MSDOS) || defined(OS2) || defined(WINDOWS)) && !defined(WIN32) -# if !defined(__GNUC__) && !defined(__FLAT__) && !defined(__386__) -# ifndef SYS16BIT -# define SYS16BIT -# endif -# endif -#endif - -/* - * Compile with -DMAXSEG_64K if the alloc function cannot allocate more - * than 64k bytes at a time (needed on systems with 16-bit int). - */ -#ifdef SYS16BIT -# define MAXSEG_64K -#endif -#ifdef MSDOS -# define UNALIGNED_OK -#endif - -#ifdef __STDC_VERSION__ -# ifndef STDC -# define STDC -# endif -# if __STDC_VERSION__ >= 199901L -# ifndef STDC99 -# define STDC99 -# endif -# endif -#endif -#if !defined(STDC) && (defined(__STDC__) || defined(__cplusplus)) -# define STDC -#endif -#if !defined(STDC) && (defined(__GNUC__) || defined(__BORLANDC__)) -# define STDC -#endif -#if !defined(STDC) && (defined(MSDOS) || defined(WINDOWS) || defined(WIN32)) -# define STDC -#endif -#if !defined(STDC) && (defined(OS2) || defined(__HOS_AIX__)) -# define STDC -#endif - -#if defined(__OS400__) && !defined(STDC) /* iSeries (formerly AS/400). */ -# define STDC -#endif - -#ifndef STDC -# ifndef const /* cannot use !defined(STDC) && !defined(const) on Mac */ -# define const /* note: need a more gentle solution here */ -# endif -#endif - -#if defined(ZLIB_CONST) && !defined(z_const) -# define z_const const -#else -# define z_const -#endif - -/* Some Mac compilers merge all .h files incorrectly: */ -#if defined(__MWERKS__)||defined(applec)||defined(THINK_C)||defined(__SC__) -# define NO_DUMMY_DECL -#endif - -/* Maximum value for memLevel in deflateInit2 */ -#ifndef MAX_MEM_LEVEL -# ifdef MAXSEG_64K -# define MAX_MEM_LEVEL 8 -# else -# define MAX_MEM_LEVEL 9 -# endif -#endif - -/* Maximum value for windowBits in deflateInit2 and inflateInit2. - * WARNING: reducing MAX_WBITS makes minigzip unable to extract .gz files - * created by gzip. (Files created by minigzip can still be extracted by - * gzip.) - */ -#ifndef MAX_WBITS -# define MAX_WBITS 15 /* 32K LZ77 window */ -#endif - -/* The memory requirements for deflate are (in bytes): - (1 << (windowBits+2)) + (1 << (memLevel+9)) - that is: 128K for windowBits=15 + 128K for memLevel = 8 (default values) - plus a few kilobytes for small objects. For example, if you want to reduce - the default memory requirements from 256K to 128K, compile with - make CFLAGS="-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7" - Of course this will generally degrade compression (there's no free lunch). - - The memory requirements for inflate are (in bytes) 1 << windowBits - that is, 32K for windowBits=15 (default value) plus a few kilobytes - for small objects. -*/ - - /* Type declarations */ - -#ifndef OF /* function prototypes */ -# ifdef STDC -# define OF(args) args -# else -# define OF(args) () -# endif -#endif - -#ifndef Z_ARG /* function prototypes for stdarg */ -# if defined(STDC) || defined(Z_HAVE_STDARG_H) -# define Z_ARG(args) args -# else -# define Z_ARG(args) () -# endif -#endif - -/* The following definitions for FAR are needed only for MSDOS mixed - * model programming (small or medium model with some far allocations). - * This was tested only with MSC; for other MSDOS compilers you may have - * to define NO_MEMCPY in zutil.h. If you don't need the mixed model, - * just define FAR to be empty. - */ -#ifdef SYS16BIT -# if defined(M_I86SM) || defined(M_I86MM) - /* MSC small or medium model */ -# define SMALL_MEDIUM -# ifdef _MSC_VER -# define FAR _far -# else -# define FAR far -# endif -# endif -# if (defined(__SMALL__) || defined(__MEDIUM__)) - /* Turbo C small or medium model */ -# define SMALL_MEDIUM -# ifdef __BORLANDC__ -# define FAR _far -# else -# define FAR far -# endif -# endif -#endif - -#if defined(WINDOWS) || defined(WIN32) - /* If building or using zlib as a DLL, define ZLIB_DLL. - * This is not mandatory, but it offers a little performance increase. - */ -# ifdef ZLIB_DLL -# if defined(WIN32) && (!defined(__BORLANDC__) || (__BORLANDC__ >= 0x500)) -# ifdef ZLIB_INTERNAL -# define ZEXTERN extern __declspec(dllexport) -# else -# define ZEXTERN extern __declspec(dllimport) -# endif -# endif -# endif /* ZLIB_DLL */ - /* If building or using zlib with the WINAPI/WINAPIV calling convention, - * define ZLIB_WINAPI. - * Caution: the standard ZLIB1.DLL is NOT compiled using ZLIB_WINAPI. - */ -# ifdef ZLIB_WINAPI -# ifdef FAR -# undef FAR -# endif -# include - /* No need for _export, use ZLIB.DEF instead. */ - /* For complete Windows compatibility, use WINAPI, not __stdcall. */ -# define ZEXPORT WINAPI -# ifdef WIN32 -# define ZEXPORTVA WINAPIV -# else -# define ZEXPORTVA FAR CDECL -# endif -# endif -#endif - -#if defined (__BEOS__) -# ifdef ZLIB_DLL -# ifdef ZLIB_INTERNAL -# define ZEXPORT __declspec(dllexport) -# define ZEXPORTVA __declspec(dllexport) -# else -# define ZEXPORT __declspec(dllimport) -# define ZEXPORTVA __declspec(dllimport) -# endif -# endif -#endif - -#ifndef ZEXTERN -# define ZEXTERN extern -#endif -#ifndef ZEXPORT -# define ZEXPORT -#endif -#ifndef ZEXPORTVA -# define ZEXPORTVA -#endif - -#ifndef FAR -# define FAR -#endif - -#if !defined(__MACTYPES__) -typedef unsigned char Byte; /* 8 bits */ -#endif -typedef unsigned int uInt; /* 16 bits or more */ -typedef unsigned long uLong; /* 32 bits or more */ - -#ifdef SMALL_MEDIUM - /* Borland C/C++ and some old MSC versions ignore FAR inside typedef */ -# define Bytef Byte FAR -#else - typedef Byte FAR Bytef; -#endif -typedef char FAR charf; -typedef int FAR intf; -typedef uInt FAR uIntf; -typedef uLong FAR uLongf; - -#ifdef STDC - typedef void const *voidpc; - typedef void FAR *voidpf; - typedef void *voidp; -#else - typedef Byte const *voidpc; - typedef Byte FAR *voidpf; - typedef Byte *voidp; -#endif - -#if !defined(Z_U4) && !defined(Z_SOLO) && defined(STDC) -# include -# if (UINT_MAX == 0xffffffffUL) -# define Z_U4 unsigned -# elif (ULONG_MAX == 0xffffffffUL) -# define Z_U4 unsigned long -# elif (USHRT_MAX == 0xffffffffUL) -# define Z_U4 unsigned short -# endif -#endif - -#ifdef Z_U4 - typedef Z_U4 z_crc_t; -#else - typedef unsigned long z_crc_t; -#endif - -#ifdef HAVE_UNISTD_H /* may be set to #if 1 by ./configure */ -# define Z_HAVE_UNISTD_H -#endif - -#ifdef HAVE_STDARG_H /* may be set to #if 1 by ./configure */ -# define Z_HAVE_STDARG_H -#endif - -#ifdef STDC -# ifndef Z_SOLO -# include /* for off_t */ -# endif -#endif - -#if defined(STDC) || defined(Z_HAVE_STDARG_H) -# ifndef Z_SOLO -# include /* for va_list */ -# endif -#endif - -#ifdef _WIN32 -# ifndef Z_SOLO -# include /* for wchar_t */ -# endif -#endif - -/* a little trick to accommodate both "#define _LARGEFILE64_SOURCE" and - * "#define _LARGEFILE64_SOURCE 1" as requesting 64-bit operations, (even - * though the former does not conform to the LFS document), but considering - * both "#undef _LARGEFILE64_SOURCE" and "#define _LARGEFILE64_SOURCE 0" as - * equivalently requesting no 64-bit operations - */ -#if defined(_LARGEFILE64_SOURCE) && -_LARGEFILE64_SOURCE - -1 == 1 -# undef _LARGEFILE64_SOURCE -#endif - -#if defined(__WATCOMC__) && !defined(Z_HAVE_UNISTD_H) -# define Z_HAVE_UNISTD_H -#endif -#ifndef Z_SOLO -# if defined(Z_HAVE_UNISTD_H) || defined(_LARGEFILE64_SOURCE) -# include /* for SEEK_*, off_t, and _LFS64_LARGEFILE */ -# ifdef VMS -# include /* for off_t */ -# endif -# ifndef z_off_t -# define z_off_t off_t -# endif -# endif -#endif - -#if defined(_LFS64_LARGEFILE) && _LFS64_LARGEFILE-0 -# define Z_LFS64 -#endif - -#if defined(_LARGEFILE64_SOURCE) && defined(Z_LFS64) -# define Z_LARGE64 -#endif - -#if defined(_FILE_OFFSET_BITS) && _FILE_OFFSET_BITS-0 == 64 && defined(Z_LFS64) -# define Z_WANT64 -#endif - -#if !defined(SEEK_SET) && !defined(Z_SOLO) -# define SEEK_SET 0 /* Seek from beginning of file. */ -# define SEEK_CUR 1 /* Seek from current position. */ -# define SEEK_END 2 /* Set file pointer to EOF plus "offset" */ -#endif - -#ifndef z_off_t -# define z_off_t long -#endif - -#if !defined(_WIN32) && defined(Z_LARGE64) -# define z_off64_t off64_t -#else -# if defined(_WIN32) && !defined(__GNUC__) && !defined(Z_SOLO) -# define z_off64_t __int64 -# else -# define z_off64_t z_off_t -# endif -#endif - -/* MVS linker does not support external names larger than 8 bytes */ -#if defined(__MVS__) - #pragma map(deflateInit_,"DEIN") - #pragma map(deflateInit2_,"DEIN2") - #pragma map(deflateEnd,"DEEND") - #pragma map(deflateBound,"DEBND") - #pragma map(inflateInit_,"ININ") - #pragma map(inflateInit2_,"ININ2") - #pragma map(inflateEnd,"INEND") - #pragma map(inflateSync,"INSY") - #pragma map(inflateSetDictionary,"INSEDI") - #pragma map(compressBound,"CMBND") - #pragma map(inflate_table,"INTABL") - #pragma map(inflate_fast,"INFA") - #pragma map(inflate_copyright,"INCOPY") -#endif - -#endif /* ZCONF_H */ diff --git a/btgui/zlib/zlib.h b/btgui/zlib/zlib.h deleted file mode 100644 index 3e0c7672a..000000000 --- a/btgui/zlib/zlib.h +++ /dev/null @@ -1,1768 +0,0 @@ -/* zlib.h -- interface of the 'zlib' general purpose compression library - version 1.2.8, April 28th, 2013 - - Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler - - This software is provided 'as-is', without any express or implied - warranty. In no event will the authors be held liable for any damages - arising from the use of this software. - - Permission is granted to anyone to use this software for any purpose, - including commercial applications, and to alter it and redistribute it - freely, subject to the following restrictions: - - 1. The origin of this software must not be misrepresented; you must not - claim that you wrote the original software. If you use this software - in a product, an acknowledgment in the product documentation would be - appreciated but is not required. - 2. Altered source versions must be plainly marked as such, and must not be - misrepresented as being the original software. - 3. This notice may not be removed or altered from any source distribution. - - Jean-loup Gailly Mark Adler - jloup@gzip.org madler@alumni.caltech.edu - - - The data format used by the zlib library is described by RFCs (Request for - Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950 - (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format). -*/ - -#ifndef ZLIB_H -#define ZLIB_H - -#include "zconf.h" - -#ifdef __cplusplus -extern "C" { -#endif - -#define ZLIB_VERSION "1.2.8" -#define ZLIB_VERNUM 0x1280 -#define ZLIB_VER_MAJOR 1 -#define ZLIB_VER_MINOR 2 -#define ZLIB_VER_REVISION 8 -#define ZLIB_VER_SUBREVISION 0 - -/* - The 'zlib' compression library provides in-memory compression and - decompression functions, including integrity checks of the uncompressed data. - This version of the library supports only one compression method (deflation) - but other algorithms will be added later and will have the same stream - interface. - - Compression can be done in a single step if the buffers are large enough, - or can be done by repeated calls of the compression function. In the latter - case, the application must provide more input and/or consume the output - (providing more output space) before each call. - - The compressed data format used by default by the in-memory functions is - the zlib format, which is a zlib wrapper documented in RFC 1950, wrapped - around a deflate stream, which is itself documented in RFC 1951. - - The library also supports reading and writing files in gzip (.gz) format - with an interface similar to that of stdio using the functions that start - with "gz". The gzip format is different from the zlib format. gzip is a - gzip wrapper, documented in RFC 1952, wrapped around a deflate stream. - - This library can optionally read and write gzip streams in memory as well. - - The zlib format was designed to be compact and fast for use in memory - and on communications channels. The gzip format was designed for single- - file compression on file systems, has a larger header than zlib to maintain - directory information, and uses a different, slower check method than zlib. - - The library does not install any signal handler. The decoder checks - the consistency of the compressed data, so the library should never crash - even in case of corrupted input. -*/ - -typedef voidpf (*alloc_func) OF((voidpf opaque, uInt items, uInt size)); -typedef void (*free_func) OF((voidpf opaque, voidpf address)); - -struct internal_state; - -typedef struct z_stream_s { - z_const Bytef *next_in; /* next input byte */ - uInt avail_in; /* number of bytes available at next_in */ - uLong total_in; /* total number of input bytes read so far */ - - Bytef *next_out; /* next output byte should be put there */ - uInt avail_out; /* remaining free space at next_out */ - uLong total_out; /* total number of bytes output so far */ - - z_const char *msg; /* last error message, NULL if no error */ - struct internal_state FAR *state; /* not visible by applications */ - - alloc_func zalloc; /* used to allocate the internal state */ - free_func zfree; /* used to free the internal state */ - voidpf opaque; /* private data object passed to zalloc and zfree */ - - int data_type; /* best guess about the data type: binary or text */ - uLong adler; /* adler32 value of the uncompressed data */ - uLong reserved; /* reserved for future use */ -} z_stream; - -typedef z_stream FAR *z_streamp; - -/* - gzip header information passed to and from zlib routines. See RFC 1952 - for more details on the meanings of these fields. -*/ -typedef struct gz_header_s { - int text; /* true if compressed data believed to be text */ - uLong time; /* modification time */ - int xflags; /* extra flags (not used when writing a gzip file) */ - int os; /* operating system */ - Bytef *extra; /* pointer to extra field or Z_NULL if none */ - uInt extra_len; /* extra field length (valid if extra != Z_NULL) */ - uInt extra_max; /* space at extra (only when reading header) */ - Bytef *name; /* pointer to zero-terminated file name or Z_NULL */ - uInt name_max; /* space at name (only when reading header) */ - Bytef *comment; /* pointer to zero-terminated comment or Z_NULL */ - uInt comm_max; /* space at comment (only when reading header) */ - int hcrc; /* true if there was or will be a header crc */ - int done; /* true when done reading gzip header (not used - when writing a gzip file) */ -} gz_header; - -typedef gz_header FAR *gz_headerp; - -/* - The application must update next_in and avail_in when avail_in has dropped - to zero. It must update next_out and avail_out when avail_out has dropped - to zero. The application must initialize zalloc, zfree and opaque before - calling the init function. All other fields are set by the compression - library and must not be updated by the application. - - The opaque value provided by the application will be passed as the first - parameter for calls of zalloc and zfree. This can be useful for custom - memory management. The compression library attaches no meaning to the - opaque value. - - zalloc must return Z_NULL if there is not enough memory for the object. - If zlib is used in a multi-threaded application, zalloc and zfree must be - thread safe. - - On 16-bit systems, the functions zalloc and zfree must be able to allocate - exactly 65536 bytes, but will not be required to allocate more than this if - the symbol MAXSEG_64K is defined (see zconf.h). WARNING: On MSDOS, pointers - returned by zalloc for objects of exactly 65536 bytes *must* have their - offset normalized to zero. The default allocation function provided by this - library ensures this (see zutil.c). To reduce memory requirements and avoid - any allocation of 64K objects, at the expense of compression ratio, compile - the library with -DMAX_WBITS=14 (see zconf.h). - - The fields total_in and total_out can be used for statistics or progress - reports. After compression, total_in holds the total size of the - uncompressed data and may be saved for use in the decompressor (particularly - if the decompressor wants to decompress everything in a single step). -*/ - - /* constants */ - -#define Z_NO_FLUSH 0 -#define Z_PARTIAL_FLUSH 1 -#define Z_SYNC_FLUSH 2 -#define Z_FULL_FLUSH 3 -#define Z_FINISH 4 -#define Z_BLOCK 5 -#define Z_TREES 6 -/* Allowed flush values; see deflate() and inflate() below for details */ - -#define Z_OK 0 -#define Z_STREAM_END 1 -#define Z_NEED_DICT 2 -#define Z_ERRNO (-1) -#define Z_STREAM_ERROR (-2) -#define Z_DATA_ERROR (-3) -#define Z_MEM_ERROR (-4) -#define Z_BUF_ERROR (-5) -#define Z_VERSION_ERROR (-6) -/* Return codes for the compression/decompression functions. Negative values - * are errors, positive values are used for special but normal events. - */ - -#define Z_NO_COMPRESSION 0 -#define Z_BEST_SPEED 1 -#define Z_BEST_COMPRESSION 9 -#define Z_DEFAULT_COMPRESSION (-1) -/* compression levels */ - -#define Z_FILTERED 1 -#define Z_HUFFMAN_ONLY 2 -#define Z_RLE 3 -#define Z_FIXED 4 -#define Z_DEFAULT_STRATEGY 0 -/* compression strategy; see deflateInit2() below for details */ - -#define Z_BINARY 0 -#define Z_TEXT 1 -#define Z_ASCII Z_TEXT /* for compatibility with 1.2.2 and earlier */ -#define Z_UNKNOWN 2 -/* Possible values of the data_type field (though see inflate()) */ - -#define Z_DEFLATED 8 -/* The deflate compression method (the only one supported in this version) */ - -#define Z_NULL 0 /* for initializing zalloc, zfree, opaque */ - -#define zlib_version zlibVersion() -/* for compatibility with versions < 1.0.2 */ - - - /* basic functions */ - -ZEXTERN const char * ZEXPORT zlibVersion OF((void)); -/* The application can compare zlibVersion and ZLIB_VERSION for consistency. - If the first character differs, the library code actually used is not - compatible with the zlib.h header file used by the application. This check - is automatically made by deflateInit and inflateInit. - */ - -/* -ZEXTERN int ZEXPORT deflateInit OF((z_streamp strm, int level)); - - Initializes the internal stream state for compression. The fields - zalloc, zfree and opaque must be initialized before by the caller. If - zalloc and zfree are set to Z_NULL, deflateInit updates them to use default - allocation functions. - - The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9: - 1 gives best speed, 9 gives best compression, 0 gives no compression at all - (the input data is simply copied a block at a time). Z_DEFAULT_COMPRESSION - requests a default compromise between speed and compression (currently - equivalent to level 6). - - deflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_STREAM_ERROR if level is not a valid compression level, or - Z_VERSION_ERROR if the zlib library version (zlib_version) is incompatible - with the version assumed by the caller (ZLIB_VERSION). msg is set to null - if there is no error message. deflateInit does not perform any compression: - this will be done by deflate(). -*/ - - -ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); -/* - deflate compresses as much data as possible, and stops when the input - buffer becomes empty or the output buffer becomes full. It may introduce - some output latency (reading input without producing any output) except when - forced to flush. - - The detailed semantics are as follows. deflate performs one or both of the - following actions: - - - Compress more input starting at next_in and update next_in and avail_in - accordingly. If not all input can be processed (because there is not - enough room in the output buffer), next_in and avail_in are updated and - processing will resume at this point for the next call of deflate(). - - - Provide more output starting at next_out and update next_out and avail_out - accordingly. This action is forced if the parameter flush is non zero. - Forcing flush frequently degrades the compression ratio, so this parameter - should be set only when necessary (in interactive applications). Some - output may be provided even if flush is not set. - - Before the call of deflate(), the application should ensure that at least - one of the actions is possible, by providing more input and/or consuming more - output, and updating avail_in or avail_out accordingly; avail_out should - never be zero before the call. The application can consume the compressed - output when it wants, for example when the output buffer is full (avail_out - == 0), or after each call of deflate(). If deflate returns Z_OK and with - zero avail_out, it must be called again after making room in the output - buffer because there might be more output pending. - - Normally the parameter flush is set to Z_NO_FLUSH, which allows deflate to - decide how much data to accumulate before producing output, in order to - maximize compression. - - If the parameter flush is set to Z_SYNC_FLUSH, all pending output is - flushed to the output buffer and the output is aligned on a byte boundary, so - that the decompressor can get all input data available so far. (In - particular avail_in is zero after the call if enough output space has been - provided before the call.) Flushing may degrade compression for some - compression algorithms and so it should be used only when necessary. This - completes the current deflate block and follows it with an empty stored block - that is three bits plus filler bits to the next byte, followed by four bytes - (00 00 ff ff). - - If flush is set to Z_PARTIAL_FLUSH, all pending output is flushed to the - output buffer, but the output is not aligned to a byte boundary. All of the - input data so far will be available to the decompressor, as for Z_SYNC_FLUSH. - This completes the current deflate block and follows it with an empty fixed - codes block that is 10 bits long. This assures that enough bytes are output - in order for the decompressor to finish the block before the empty fixed code - block. - - If flush is set to Z_BLOCK, a deflate block is completed and emitted, as - for Z_SYNC_FLUSH, but the output is not aligned on a byte boundary, and up to - seven bits of the current block are held to be written as the next byte after - the next deflate block is completed. In this case, the decompressor may not - be provided enough bits at this point in order to complete decompression of - the data provided so far to the compressor. It may need to wait for the next - block to be emitted. This is for advanced applications that need to control - the emission of deflate blocks. - - If flush is set to Z_FULL_FLUSH, all output is flushed as with - Z_SYNC_FLUSH, and the compression state is reset so that decompression can - restart from this point if previous compressed data has been damaged or if - random access is desired. Using Z_FULL_FLUSH too often can seriously degrade - compression. - - If deflate returns with avail_out == 0, this function must be called again - with the same value of the flush parameter and more output space (updated - avail_out), until the flush is complete (deflate returns with non-zero - avail_out). In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that - avail_out is greater than six to avoid repeated flush markers due to - avail_out == 0 on return. - - If the parameter flush is set to Z_FINISH, pending input is processed, - pending output is flushed and deflate returns with Z_STREAM_END if there was - enough output space; if deflate returns with Z_OK, this function must be - called again with Z_FINISH and more output space (updated avail_out) but no - more input data, until it returns with Z_STREAM_END or an error. After - deflate has returned Z_STREAM_END, the only possible operations on the stream - are deflateReset or deflateEnd. - - Z_FINISH can be used immediately after deflateInit if all the compression - is to be done in a single step. In this case, avail_out must be at least the - value returned by deflateBound (see below). Then deflate is guaranteed to - return Z_STREAM_END. If not enough output space is provided, deflate will - not return Z_STREAM_END, and it must be called again as described above. - - deflate() sets strm->adler to the adler32 checksum of all input read - so far (that is, total_in bytes). - - deflate() may update strm->data_type if it can make a good guess about - the input data type (Z_BINARY or Z_TEXT). In doubt, the data is considered - binary. This field is only for information purposes and does not affect the - compression algorithm in any manner. - - deflate() returns Z_OK if some progress has been made (more input - processed or more output produced), Z_STREAM_END if all input has been - consumed and all output has been produced (only when flush is set to - Z_FINISH), Z_STREAM_ERROR if the stream state was inconsistent (for example - if next_in or next_out was Z_NULL), Z_BUF_ERROR if no progress is possible - (for example avail_in or avail_out was zero). Note that Z_BUF_ERROR is not - fatal, and deflate() can be called again with more input and more output - space to continue compressing. -*/ - - -ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); -/* - All dynamically allocated data structures for this stream are freed. - This function discards any unprocessed input and does not flush any pending - output. - - deflateEnd returns Z_OK if success, Z_STREAM_ERROR if the - stream state was inconsistent, Z_DATA_ERROR if the stream was freed - prematurely (some input or output was discarded). In the error case, msg - may be set but then points to a static string (which must not be - deallocated). -*/ - - -/* -ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); - - Initializes the internal stream state for decompression. The fields - next_in, avail_in, zalloc, zfree and opaque must be initialized before by - the caller. If next_in is not Z_NULL and avail_in is large enough (the - exact value depends on the compression method), inflateInit determines the - compression method from the zlib header and allocates all data structures - accordingly; otherwise the allocation will be deferred to the first call of - inflate. If zalloc and zfree are set to Z_NULL, inflateInit updates them to - use default allocation functions. - - inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_VERSION_ERROR if the zlib library version is incompatible with the - version assumed by the caller, or Z_STREAM_ERROR if the parameters are - invalid, such as a null pointer to the structure. msg is set to null if - there is no error message. inflateInit does not perform any decompression - apart from possibly reading the zlib header if present: actual decompression - will be done by inflate(). (So next_in and avail_in may be modified, but - next_out and avail_out are unused and unchanged.) The current implementation - of inflateInit() does not process any header information -- that is deferred - until inflate() is called. -*/ - - -ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush)); -/* - inflate decompresses as much data as possible, and stops when the input - buffer becomes empty or the output buffer becomes full. It may introduce - some output latency (reading input without producing any output) except when - forced to flush. - - The detailed semantics are as follows. inflate performs one or both of the - following actions: - - - Decompress more input starting at next_in and update next_in and avail_in - accordingly. If not all input can be processed (because there is not - enough room in the output buffer), next_in is updated and processing will - resume at this point for the next call of inflate(). - - - Provide more output starting at next_out and update next_out and avail_out - accordingly. inflate() provides as much output as possible, until there is - no more input data or no more space in the output buffer (see below about - the flush parameter). - - Before the call of inflate(), the application should ensure that at least - one of the actions is possible, by providing more input and/or consuming more - output, and updating the next_* and avail_* values accordingly. The - application can consume the uncompressed output when it wants, for example - when the output buffer is full (avail_out == 0), or after each call of - inflate(). If inflate returns Z_OK and with zero avail_out, it must be - called again after making room in the output buffer because there might be - more output pending. - - The flush parameter of inflate() can be Z_NO_FLUSH, Z_SYNC_FLUSH, Z_FINISH, - Z_BLOCK, or Z_TREES. Z_SYNC_FLUSH requests that inflate() flush as much - output as possible to the output buffer. Z_BLOCK requests that inflate() - stop if and when it gets to the next deflate block boundary. When decoding - the zlib or gzip format, this will cause inflate() to return immediately - after the header and before the first block. When doing a raw inflate, - inflate() will go ahead and process the first block, and will return when it - gets to the end of that block, or when it runs out of data. - - The Z_BLOCK option assists in appending to or combining deflate streams. - Also to assist in this, on return inflate() will set strm->data_type to the - number of unused bits in the last byte taken from strm->next_in, plus 64 if - inflate() is currently decoding the last block in the deflate stream, plus - 128 if inflate() returned immediately after decoding an end-of-block code or - decoding the complete header up to just before the first byte of the deflate - stream. The end-of-block will not be indicated until all of the uncompressed - data from that block has been written to strm->next_out. The number of - unused bits may in general be greater than seven, except when bit 7 of - data_type is set, in which case the number of unused bits will be less than - eight. data_type is set as noted here every time inflate() returns for all - flush options, and so can be used to determine the amount of currently - consumed input in bits. - - The Z_TREES option behaves as Z_BLOCK does, but it also returns when the - end of each deflate block header is reached, before any actual data in that - block is decoded. This allows the caller to determine the length of the - deflate block header for later use in random access within a deflate block. - 256 is added to the value of strm->data_type when inflate() returns - immediately after reaching the end of the deflate block header. - - inflate() should normally be called until it returns Z_STREAM_END or an - error. However if all decompression is to be performed in a single step (a - single call of inflate), the parameter flush should be set to Z_FINISH. In - this case all pending input is processed and all pending output is flushed; - avail_out must be large enough to hold all of the uncompressed data for the - operation to complete. (The size of the uncompressed data may have been - saved by the compressor for this purpose.) The use of Z_FINISH is not - required to perform an inflation in one step. However it may be used to - inform inflate that a faster approach can be used for the single inflate() - call. Z_FINISH also informs inflate to not maintain a sliding window if the - stream completes, which reduces inflate's memory footprint. If the stream - does not complete, either because not all of the stream is provided or not - enough output space is provided, then a sliding window will be allocated and - inflate() can be called again to continue the operation as if Z_NO_FLUSH had - been used. - - In this implementation, inflate() always flushes as much output as - possible to the output buffer, and always uses the faster approach on the - first call. So the effects of the flush parameter in this implementation are - on the return value of inflate() as noted below, when inflate() returns early - when Z_BLOCK or Z_TREES is used, and when inflate() avoids the allocation of - memory for a sliding window when Z_FINISH is used. - - If a preset dictionary is needed after this call (see inflateSetDictionary - below), inflate sets strm->adler to the Adler-32 checksum of the dictionary - chosen by the compressor and returns Z_NEED_DICT; otherwise it sets - strm->adler to the Adler-32 checksum of all output produced so far (that is, - total_out bytes) and returns Z_OK, Z_STREAM_END or an error code as described - below. At the end of the stream, inflate() checks that its computed adler32 - checksum is equal to that saved by the compressor and returns Z_STREAM_END - only if the checksum is correct. - - inflate() can decompress and check either zlib-wrapped or gzip-wrapped - deflate data. The header type is detected automatically, if requested when - initializing with inflateInit2(). Any information contained in the gzip - header is not retained, so applications that need that information should - instead use raw inflate, see inflateInit2() below, or inflateBack() and - perform their own processing of the gzip header and trailer. When processing - gzip-wrapped deflate data, strm->adler32 is set to the CRC-32 of the output - producted so far. The CRC-32 is checked against the gzip trailer. - - inflate() returns Z_OK if some progress has been made (more input processed - or more output produced), Z_STREAM_END if the end of the compressed data has - been reached and all uncompressed output has been produced, Z_NEED_DICT if a - preset dictionary is needed at this point, Z_DATA_ERROR if the input data was - corrupted (input stream not conforming to the zlib format or incorrect check - value), Z_STREAM_ERROR if the stream structure was inconsistent (for example - next_in or next_out was Z_NULL), Z_MEM_ERROR if there was not enough memory, - Z_BUF_ERROR if no progress is possible or if there was not enough room in the - output buffer when Z_FINISH is used. Note that Z_BUF_ERROR is not fatal, and - inflate() can be called again with more input and more output space to - continue decompressing. If Z_DATA_ERROR is returned, the application may - then call inflateSync() to look for a good compression block if a partial - recovery of the data is desired. -*/ - - -ZEXTERN int ZEXPORT inflateEnd OF((z_streamp strm)); -/* - All dynamically allocated data structures for this stream are freed. - This function discards any unprocessed input and does not flush any pending - output. - - inflateEnd returns Z_OK if success, Z_STREAM_ERROR if the stream state - was inconsistent. In the error case, msg may be set but then points to a - static string (which must not be deallocated). -*/ - - - /* Advanced functions */ - -/* - The following functions are needed only in some special applications. -*/ - -/* -ZEXTERN int ZEXPORT deflateInit2 OF((z_streamp strm, - int level, - int method, - int windowBits, - int memLevel, - int strategy)); - - This is another version of deflateInit with more compression options. The - fields next_in, zalloc, zfree and opaque must be initialized before by the - caller. - - The method parameter is the compression method. It must be Z_DEFLATED in - this version of the library. - - The windowBits parameter is the base two logarithm of the window size - (the size of the history buffer). It should be in the range 8..15 for this - version of the library. Larger values of this parameter result in better - compression at the expense of memory usage. The default value is 15 if - deflateInit is used instead. - - windowBits can also be -8..-15 for raw deflate. In this case, -windowBits - determines the window size. deflate() will then generate raw deflate data - with no zlib header or trailer, and will not compute an adler32 check value. - - windowBits can also be greater than 15 for optional gzip encoding. Add - 16 to windowBits to write a simple gzip header and trailer around the - compressed data instead of a zlib wrapper. The gzip header will have no - file name, no extra data, no comment, no modification time (set to zero), no - header crc, and the operating system will be set to 255 (unknown). If a - gzip stream is being written, strm->adler is a crc32 instead of an adler32. - - The memLevel parameter specifies how much memory should be allocated - for the internal compression state. memLevel=1 uses minimum memory but is - slow and reduces compression ratio; memLevel=9 uses maximum memory for - optimal speed. The default value is 8. See zconf.h for total memory usage - as a function of windowBits and memLevel. - - The strategy parameter is used to tune the compression algorithm. Use the - value Z_DEFAULT_STRATEGY for normal data, Z_FILTERED for data produced by a - filter (or predictor), Z_HUFFMAN_ONLY to force Huffman encoding only (no - string match), or Z_RLE to limit match distances to one (run-length - encoding). Filtered data consists mostly of small values with a somewhat - random distribution. In this case, the compression algorithm is tuned to - compress them better. The effect of Z_FILTERED is to force more Huffman - coding and less string matching; it is somewhat intermediate between - Z_DEFAULT_STRATEGY and Z_HUFFMAN_ONLY. Z_RLE is designed to be almost as - fast as Z_HUFFMAN_ONLY, but give better compression for PNG image data. The - strategy parameter only affects the compression ratio but not the - correctness of the compressed output even if it is not set appropriately. - Z_FIXED prevents the use of dynamic Huffman codes, allowing for a simpler - decoder for special applications. - - deflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_STREAM_ERROR if any parameter is invalid (such as an invalid - method), or Z_VERSION_ERROR if the zlib library version (zlib_version) is - incompatible with the version assumed by the caller (ZLIB_VERSION). msg is - set to null if there is no error message. deflateInit2 does not perform any - compression: this will be done by deflate(). -*/ - -ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, - const Bytef *dictionary, - uInt dictLength)); -/* - Initializes the compression dictionary from the given byte sequence - without producing any compressed output. When using the zlib format, this - function must be called immediately after deflateInit, deflateInit2 or - deflateReset, and before any call of deflate. When doing raw deflate, this - function must be called either before any call of deflate, or immediately - after the completion of a deflate block, i.e. after all input has been - consumed and all output has been delivered when using any of the flush - options Z_BLOCK, Z_PARTIAL_FLUSH, Z_SYNC_FLUSH, or Z_FULL_FLUSH. The - compressor and decompressor must use exactly the same dictionary (see - inflateSetDictionary). - - The dictionary should consist of strings (byte sequences) that are likely - to be encountered later in the data to be compressed, with the most commonly - used strings preferably put towards the end of the dictionary. Using a - dictionary is most useful when the data to be compressed is short and can be - predicted with good accuracy; the data can then be compressed better than - with the default empty dictionary. - - Depending on the size of the compression data structures selected by - deflateInit or deflateInit2, a part of the dictionary may in effect be - discarded, for example if the dictionary is larger than the window size - provided in deflateInit or deflateInit2. Thus the strings most likely to be - useful should be put at the end of the dictionary, not at the front. In - addition, the current implementation of deflate will use at most the window - size minus 262 bytes of the provided dictionary. - - Upon return of this function, strm->adler is set to the adler32 value - of the dictionary; the decompressor may later use this value to determine - which dictionary has been used by the compressor. (The adler32 value - applies to the whole dictionary even if only a subset of the dictionary is - actually used by the compressor.) If a raw deflate was requested, then the - adler32 value is not computed and strm->adler is not set. - - deflateSetDictionary returns Z_OK if success, or Z_STREAM_ERROR if a - parameter is invalid (e.g. dictionary being Z_NULL) or the stream state is - inconsistent (for example if deflate has already been called for this stream - or if not at a block boundary for raw deflate). deflateSetDictionary does - not perform any compression: this will be done by deflate(). -*/ - -ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, - z_streamp source)); -/* - Sets the destination stream as a complete copy of the source stream. - - This function can be useful when several compression strategies will be - tried, for example when there are several ways of pre-processing the input - data with a filter. The streams that will be discarded should then be freed - by calling deflateEnd. Note that deflateCopy duplicates the internal - compression state which can be quite large, so this strategy is slow and can - consume lots of memory. - - deflateCopy returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_STREAM_ERROR if the source stream state was inconsistent - (such as zalloc being Z_NULL). msg is left unchanged in both source and - destination. -*/ - -ZEXTERN int ZEXPORT deflateReset OF((z_streamp strm)); -/* - This function is equivalent to deflateEnd followed by deflateInit, - but does not free and reallocate all the internal compression state. The - stream will keep the same compression level and any other attributes that - may have been set by deflateInit2. - - deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent (such as zalloc or state being Z_NULL). -*/ - -ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, - int level, - int strategy)); -/* - Dynamically update the compression level and compression strategy. The - interpretation of level and strategy is as in deflateInit2. This can be - used to switch between compression and straight copy of the input data, or - to switch to a different kind of input data requiring a different strategy. - If the compression level is changed, the input available so far is - compressed with the old level (and may be flushed); the new level will take - effect only at the next call of deflate(). - - Before the call of deflateParams, the stream state must be set as for - a call of deflate(), since the currently available input may have to be - compressed and flushed. In particular, strm->avail_out must be non-zero. - - deflateParams returns Z_OK if success, Z_STREAM_ERROR if the source - stream state was inconsistent or if a parameter was invalid, Z_BUF_ERROR if - strm->avail_out was zero. -*/ - -ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm, - int good_length, - int max_lazy, - int nice_length, - int max_chain)); -/* - Fine tune deflate's internal compression parameters. This should only be - used by someone who understands the algorithm used by zlib's deflate for - searching for the best matching string, and even then only by the most - fanatic optimizer trying to squeeze out the last compressed bit for their - specific input data. Read the deflate.c source code for the meaning of the - max_lazy, good_length, nice_length, and max_chain parameters. - - deflateTune() can be called after deflateInit() or deflateInit2(), and - returns Z_OK on success, or Z_STREAM_ERROR for an invalid deflate stream. - */ - -ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm, - uLong sourceLen)); -/* - deflateBound() returns an upper bound on the compressed size after - deflation of sourceLen bytes. It must be called after deflateInit() or - deflateInit2(), and after deflateSetHeader(), if used. This would be used - to allocate an output buffer for deflation in a single pass, and so would be - called before deflate(). If that first deflate() call is provided the - sourceLen input bytes, an output buffer allocated to the size returned by - deflateBound(), and the flush value Z_FINISH, then deflate() is guaranteed - to return Z_STREAM_END. Note that it is possible for the compressed size to - be larger than the value returned by deflateBound() if flush options other - than Z_FINISH or Z_NO_FLUSH are used. -*/ - -ZEXTERN int ZEXPORT deflatePending OF((z_streamp strm, - unsigned *pending, - int *bits)); -/* - deflatePending() returns the number of bytes and bits of output that have - been generated, but not yet provided in the available output. The bytes not - provided would be due to the available output space having being consumed. - The number of bits of output not provided are between 0 and 7, where they - await more bits to join them in order to fill out a full byte. If pending - or bits are Z_NULL, then those values are not set. - - deflatePending returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent. - */ - -ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm, - int bits, - int value)); -/* - deflatePrime() inserts bits in the deflate output stream. The intent - is that this function is used to start off the deflate output with the bits - leftover from a previous deflate stream when appending to it. As such, this - function can only be used for raw deflate, and must be used before the first - deflate() call after a deflateInit2() or deflateReset(). bits must be less - than or equal to 16, and that many of the least significant bits of value - will be inserted in the output. - - deflatePrime returns Z_OK if success, Z_BUF_ERROR if there was not enough - room in the internal buffer to insert the bits, or Z_STREAM_ERROR if the - source stream state was inconsistent. -*/ - -ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, - gz_headerp head)); -/* - deflateSetHeader() provides gzip header information for when a gzip - stream is requested by deflateInit2(). deflateSetHeader() may be called - after deflateInit2() or deflateReset() and before the first call of - deflate(). The text, time, os, extra field, name, and comment information - in the provided gz_header structure are written to the gzip header (xflag is - ignored -- the extra flags are set according to the compression level). The - caller must assure that, if not Z_NULL, name and comment are terminated with - a zero byte, and that if extra is not Z_NULL, that extra_len bytes are - available there. If hcrc is true, a gzip header crc is included. Note that - the current versions of the command-line version of gzip (up through version - 1.3.x) do not support header crc's, and will report that it is a "multi-part - gzip file" and give up. - - If deflateSetHeader is not used, the default gzip header has text false, - the time set to zero, and os set to 255, with no extra, name, or comment - fields. The gzip header is returned to the default state by deflateReset(). - - deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent. -*/ - -/* -ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm, - int windowBits)); - - This is another version of inflateInit with an extra parameter. The - fields next_in, avail_in, zalloc, zfree and opaque must be initialized - before by the caller. - - The windowBits parameter is the base two logarithm of the maximum window - size (the size of the history buffer). It should be in the range 8..15 for - this version of the library. The default value is 15 if inflateInit is used - instead. windowBits must be greater than or equal to the windowBits value - provided to deflateInit2() while compressing, or it must be equal to 15 if - deflateInit2() was not used. If a compressed stream with a larger window - size is given as input, inflate() will return with the error code - Z_DATA_ERROR instead of trying to allocate a larger window. - - windowBits can also be zero to request that inflate use the window size in - the zlib header of the compressed stream. - - windowBits can also be -8..-15 for raw inflate. In this case, -windowBits - determines the window size. inflate() will then process raw deflate data, - not looking for a zlib or gzip header, not generating a check value, and not - looking for any check values for comparison at the end of the stream. This - is for use with other formats that use the deflate compressed data format - such as zip. Those formats provide their own check values. If a custom - format is developed using the raw deflate format for compressed data, it is - recommended that a check value such as an adler32 or a crc32 be applied to - the uncompressed data as is done in the zlib, gzip, and zip formats. For - most applications, the zlib format should be used as is. Note that comments - above on the use in deflateInit2() applies to the magnitude of windowBits. - - windowBits can also be greater than 15 for optional gzip decoding. Add - 32 to windowBits to enable zlib and gzip decoding with automatic header - detection, or add 16 to decode only the gzip format (the zlib format will - return a Z_DATA_ERROR). If a gzip stream is being decoded, strm->adler is a - crc32 instead of an adler32. - - inflateInit2 returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_VERSION_ERROR if the zlib library version is incompatible with the - version assumed by the caller, or Z_STREAM_ERROR if the parameters are - invalid, such as a null pointer to the structure. msg is set to null if - there is no error message. inflateInit2 does not perform any decompression - apart from possibly reading the zlib header if present: actual decompression - will be done by inflate(). (So next_in and avail_in may be modified, but - next_out and avail_out are unused and unchanged.) The current implementation - of inflateInit2() does not process any header information -- that is - deferred until inflate() is called. -*/ - -ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, - const Bytef *dictionary, - uInt dictLength)); -/* - Initializes the decompression dictionary from the given uncompressed byte - sequence. This function must be called immediately after a call of inflate, - if that call returned Z_NEED_DICT. The dictionary chosen by the compressor - can be determined from the adler32 value returned by that call of inflate. - The compressor and decompressor must use exactly the same dictionary (see - deflateSetDictionary). For raw inflate, this function can be called at any - time to set the dictionary. If the provided dictionary is smaller than the - window and there is already data in the window, then the provided dictionary - will amend what's there. The application must insure that the dictionary - that was used for compression is provided. - - inflateSetDictionary returns Z_OK if success, Z_STREAM_ERROR if a - parameter is invalid (e.g. dictionary being Z_NULL) or the stream state is - inconsistent, Z_DATA_ERROR if the given dictionary doesn't match the - expected one (incorrect adler32 value). inflateSetDictionary does not - perform any decompression: this will be done by subsequent calls of - inflate(). -*/ - -ZEXTERN int ZEXPORT inflateGetDictionary OF((z_streamp strm, - Bytef *dictionary, - uInt *dictLength)); -/* - Returns the sliding dictionary being maintained by inflate. dictLength is - set to the number of bytes in the dictionary, and that many bytes are copied - to dictionary. dictionary must have enough space, where 32768 bytes is - always enough. If inflateGetDictionary() is called with dictionary equal to - Z_NULL, then only the dictionary length is returned, and nothing is copied. - Similary, if dictLength is Z_NULL, then it is not set. - - inflateGetDictionary returns Z_OK on success, or Z_STREAM_ERROR if the - stream state is inconsistent. -*/ - -ZEXTERN int ZEXPORT inflateSync OF((z_streamp strm)); -/* - Skips invalid compressed data until a possible full flush point (see above - for the description of deflate with Z_FULL_FLUSH) can be found, or until all - available input is skipped. No output is provided. - - inflateSync searches for a 00 00 FF FF pattern in the compressed data. - All full flush points have this pattern, but not all occurrences of this - pattern are full flush points. - - inflateSync returns Z_OK if a possible full flush point has been found, - Z_BUF_ERROR if no more input was provided, Z_DATA_ERROR if no flush point - has been found, or Z_STREAM_ERROR if the stream structure was inconsistent. - In the success case, the application may save the current current value of - total_in which indicates where valid compressed data was found. In the - error case, the application may repeatedly call inflateSync, providing more - input each time, until success or end of the input data. -*/ - -ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, - z_streamp source)); -/* - Sets the destination stream as a complete copy of the source stream. - - This function can be useful when randomly accessing a large stream. The - first pass through the stream can periodically record the inflate state, - allowing restarting inflate at those points when randomly accessing the - stream. - - inflateCopy returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_STREAM_ERROR if the source stream state was inconsistent - (such as zalloc being Z_NULL). msg is left unchanged in both source and - destination. -*/ - -ZEXTERN int ZEXPORT inflateReset OF((z_streamp strm)); -/* - This function is equivalent to inflateEnd followed by inflateInit, - but does not free and reallocate all the internal decompression state. The - stream will keep attributes that may have been set by inflateInit2. - - inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent (such as zalloc or state being Z_NULL). -*/ - -ZEXTERN int ZEXPORT inflateReset2 OF((z_streamp strm, - int windowBits)); -/* - This function is the same as inflateReset, but it also permits changing - the wrap and window size requests. The windowBits parameter is interpreted - the same as it is for inflateInit2. - - inflateReset2 returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent (such as zalloc or state being Z_NULL), or if - the windowBits parameter is invalid. -*/ - -ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, - int bits, - int value)); -/* - This function inserts bits in the inflate input stream. The intent is - that this function is used to start inflating at a bit position in the - middle of a byte. The provided bits will be used before any bytes are used - from next_in. This function should only be used with raw inflate, and - should be used before the first inflate() call after inflateInit2() or - inflateReset(). bits must be less than or equal to 16, and that many of the - least significant bits of value will be inserted in the input. - - If bits is negative, then the input stream bit buffer is emptied. Then - inflatePrime() can be called again to put bits in the buffer. This is used - to clear out bits leftover after feeding inflate a block description prior - to feeding inflate codes. - - inflatePrime returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent. -*/ - -ZEXTERN long ZEXPORT inflateMark OF((z_streamp strm)); -/* - This function returns two values, one in the lower 16 bits of the return - value, and the other in the remaining upper bits, obtained by shifting the - return value down 16 bits. If the upper value is -1 and the lower value is - zero, then inflate() is currently decoding information outside of a block. - If the upper value is -1 and the lower value is non-zero, then inflate is in - the middle of a stored block, with the lower value equaling the number of - bytes from the input remaining to copy. If the upper value is not -1, then - it is the number of bits back from the current bit position in the input of - the code (literal or length/distance pair) currently being processed. In - that case the lower value is the number of bytes already emitted for that - code. - - A code is being processed if inflate is waiting for more input to complete - decoding of the code, or if it has completed decoding but is waiting for - more output space to write the literal or match data. - - inflateMark() is used to mark locations in the input data for random - access, which may be at bit positions, and to note those cases where the - output of a code may span boundaries of random access blocks. The current - location in the input stream can be determined from avail_in and data_type - as noted in the description for the Z_BLOCK flush parameter for inflate. - - inflateMark returns the value noted above or -1 << 16 if the provided - source stream state was inconsistent. -*/ - -ZEXTERN int ZEXPORT inflateGetHeader OF((z_streamp strm, - gz_headerp head)); -/* - inflateGetHeader() requests that gzip header information be stored in the - provided gz_header structure. inflateGetHeader() may be called after - inflateInit2() or inflateReset(), and before the first call of inflate(). - As inflate() processes the gzip stream, head->done is zero until the header - is completed, at which time head->done is set to one. If a zlib stream is - being decoded, then head->done is set to -1 to indicate that there will be - no gzip header information forthcoming. Note that Z_BLOCK or Z_TREES can be - used to force inflate() to return immediately after header processing is - complete and before any actual data is decompressed. - - The text, time, xflags, and os fields are filled in with the gzip header - contents. hcrc is set to true if there is a header CRC. (The header CRC - was valid if done is set to one.) If extra is not Z_NULL, then extra_max - contains the maximum number of bytes to write to extra. Once done is true, - extra_len contains the actual extra field length, and extra contains the - extra field, or that field truncated if extra_max is less than extra_len. - If name is not Z_NULL, then up to name_max characters are written there, - terminated with a zero unless the length is greater than name_max. If - comment is not Z_NULL, then up to comm_max characters are written there, - terminated with a zero unless the length is greater than comm_max. When any - of extra, name, or comment are not Z_NULL and the respective field is not - present in the header, then that field is set to Z_NULL to signal its - absence. This allows the use of deflateSetHeader() with the returned - structure to duplicate the header. However if those fields are set to - allocated memory, then the application will need to save those pointers - elsewhere so that they can be eventually freed. - - If inflateGetHeader is not used, then the header information is simply - discarded. The header is always checked for validity, including the header - CRC if present. inflateReset() will reset the process to discard the header - information. The application would need to call inflateGetHeader() again to - retrieve the header from the next gzip stream. - - inflateGetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source - stream state was inconsistent. -*/ - -/* -ZEXTERN int ZEXPORT inflateBackInit OF((z_streamp strm, int windowBits, - unsigned char FAR *window)); - - Initialize the internal stream state for decompression using inflateBack() - calls. The fields zalloc, zfree and opaque in strm must be initialized - before the call. If zalloc and zfree are Z_NULL, then the default library- - derived memory allocation routines are used. windowBits is the base two - logarithm of the window size, in the range 8..15. window is a caller - supplied buffer of that size. Except for special applications where it is - assured that deflate was used with small window sizes, windowBits must be 15 - and a 32K byte window must be supplied to be able to decompress general - deflate streams. - - See inflateBack() for the usage of these routines. - - inflateBackInit will return Z_OK on success, Z_STREAM_ERROR if any of - the parameters are invalid, Z_MEM_ERROR if the internal state could not be - allocated, or Z_VERSION_ERROR if the version of the library does not match - the version of the header file. -*/ - -typedef unsigned (*in_func) OF((void FAR *, - z_const unsigned char FAR * FAR *)); -typedef int (*out_func) OF((void FAR *, unsigned char FAR *, unsigned)); - -ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, - in_func in, void FAR *in_desc, - out_func out, void FAR *out_desc)); -/* - inflateBack() does a raw inflate with a single call using a call-back - interface for input and output. This is potentially more efficient than - inflate() for file i/o applications, in that it avoids copying between the - output and the sliding window by simply making the window itself the output - buffer. inflate() can be faster on modern CPUs when used with large - buffers. inflateBack() trusts the application to not change the output - buffer passed by the output function, at least until inflateBack() returns. - - inflateBackInit() must be called first to allocate the internal state - and to initialize the state with the user-provided window buffer. - inflateBack() may then be used multiple times to inflate a complete, raw - deflate stream with each call. inflateBackEnd() is then called to free the - allocated state. - - A raw deflate stream is one with no zlib or gzip header or trailer. - This routine would normally be used in a utility that reads zip or gzip - files and writes out uncompressed files. The utility would decode the - header and process the trailer on its own, hence this routine expects only - the raw deflate stream to decompress. This is different from the normal - behavior of inflate(), which expects either a zlib or gzip header and - trailer around the deflate stream. - - inflateBack() uses two subroutines supplied by the caller that are then - called by inflateBack() for input and output. inflateBack() calls those - routines until it reads a complete deflate stream and writes out all of the - uncompressed data, or until it encounters an error. The function's - parameters and return types are defined above in the in_func and out_func - typedefs. inflateBack() will call in(in_desc, &buf) which should return the - number of bytes of provided input, and a pointer to that input in buf. If - there is no input available, in() must return zero--buf is ignored in that - case--and inflateBack() will return a buffer error. inflateBack() will call - out(out_desc, buf, len) to write the uncompressed data buf[0..len-1]. out() - should return zero on success, or non-zero on failure. If out() returns - non-zero, inflateBack() will return with an error. Neither in() nor out() - are permitted to change the contents of the window provided to - inflateBackInit(), which is also the buffer that out() uses to write from. - The length written by out() will be at most the window size. Any non-zero - amount of input may be provided by in(). - - For convenience, inflateBack() can be provided input on the first call by - setting strm->next_in and strm->avail_in. If that input is exhausted, then - in() will be called. Therefore strm->next_in must be initialized before - calling inflateBack(). If strm->next_in is Z_NULL, then in() will be called - immediately for input. If strm->next_in is not Z_NULL, then strm->avail_in - must also be initialized, and then if strm->avail_in is not zero, input will - initially be taken from strm->next_in[0 .. strm->avail_in - 1]. - - The in_desc and out_desc parameters of inflateBack() is passed as the - first parameter of in() and out() respectively when they are called. These - descriptors can be optionally used to pass any information that the caller- - supplied in() and out() functions need to do their job. - - On return, inflateBack() will set strm->next_in and strm->avail_in to - pass back any unused input that was provided by the last in() call. The - return values of inflateBack() can be Z_STREAM_END on success, Z_BUF_ERROR - if in() or out() returned an error, Z_DATA_ERROR if there was a format error - in the deflate stream (in which case strm->msg is set to indicate the nature - of the error), or Z_STREAM_ERROR if the stream was not properly initialized. - In the case of Z_BUF_ERROR, an input or output error can be distinguished - using strm->next_in which will be Z_NULL only if in() returned an error. If - strm->next_in is not Z_NULL, then the Z_BUF_ERROR was due to out() returning - non-zero. (in() will always be called before out(), so strm->next_in is - assured to be defined if out() returns non-zero.) Note that inflateBack() - cannot return Z_OK. -*/ - -ZEXTERN int ZEXPORT inflateBackEnd OF((z_streamp strm)); -/* - All memory allocated by inflateBackInit() is freed. - - inflateBackEnd() returns Z_OK on success, or Z_STREAM_ERROR if the stream - state was inconsistent. -*/ - -ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); -/* Return flags indicating compile-time options. - - Type sizes, two bits each, 00 = 16 bits, 01 = 32, 10 = 64, 11 = other: - 1.0: size of uInt - 3.2: size of uLong - 5.4: size of voidpf (pointer) - 7.6: size of z_off_t - - Compiler, assembler, and debug options: - 8: DEBUG - 9: ASMV or ASMINF -- use ASM code - 10: ZLIB_WINAPI -- exported functions use the WINAPI calling convention - 11: 0 (reserved) - - One-time table building (smaller code, but not thread-safe if true): - 12: BUILDFIXED -- build static block decoding tables when needed - 13: DYNAMIC_CRC_TABLE -- build CRC calculation tables when needed - 14,15: 0 (reserved) - - Library content (indicates missing functionality): - 16: NO_GZCOMPRESS -- gz* functions cannot compress (to avoid linking - deflate code when not needed) - 17: NO_GZIP -- deflate can't write gzip streams, and inflate can't detect - and decode gzip streams (to avoid linking crc code) - 18-19: 0 (reserved) - - Operation variations (changes in library functionality): - 20: PKZIP_BUG_WORKAROUND -- slightly more permissive inflate - 21: FASTEST -- deflate algorithm with only one, lowest compression level - 22,23: 0 (reserved) - - The sprintf variant used by gzprintf (zero is best): - 24: 0 = vs*, 1 = s* -- 1 means limited to 20 arguments after the format - 25: 0 = *nprintf, 1 = *printf -- 1 means gzprintf() not secure! - 26: 0 = returns value, 1 = void -- 1 means inferred string length returned - - Remainder: - 27-31: 0 (reserved) - */ - -#ifndef Z_SOLO - - /* utility functions */ - -/* - The following utility functions are implemented on top of the basic - stream-oriented functions. To simplify the interface, some default options - are assumed (compression level and memory usage, standard memory allocation - functions). The source code of these utility functions can be modified if - you need special options. -*/ - -ZEXTERN int ZEXPORT compress OF((Bytef *dest, uLongf *destLen, - const Bytef *source, uLong sourceLen)); -/* - Compresses the source buffer into the destination buffer. sourceLen is - the byte length of the source buffer. Upon entry, destLen is the total size - of the destination buffer, which must be at least the value returned by - compressBound(sourceLen). Upon exit, destLen is the actual size of the - compressed buffer. - - compress returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_BUF_ERROR if there was not enough room in the output - buffer. -*/ - -ZEXTERN int ZEXPORT compress2 OF((Bytef *dest, uLongf *destLen, - const Bytef *source, uLong sourceLen, - int level)); -/* - Compresses the source buffer into the destination buffer. The level - parameter has the same meaning as in deflateInit. sourceLen is the byte - length of the source buffer. Upon entry, destLen is the total size of the - destination buffer, which must be at least the value returned by - compressBound(sourceLen). Upon exit, destLen is the actual size of the - compressed buffer. - - compress2 returns Z_OK if success, Z_MEM_ERROR if there was not enough - memory, Z_BUF_ERROR if there was not enough room in the output buffer, - Z_STREAM_ERROR if the level parameter is invalid. -*/ - -ZEXTERN uLong ZEXPORT compressBound OF((uLong sourceLen)); -/* - compressBound() returns an upper bound on the compressed size after - compress() or compress2() on sourceLen bytes. It would be used before a - compress() or compress2() call to allocate the destination buffer. -*/ - -ZEXTERN int ZEXPORT uncompress OF((Bytef *dest, uLongf *destLen, - const Bytef *source, uLong sourceLen)); -/* - Decompresses the source buffer into the destination buffer. sourceLen is - the byte length of the source buffer. Upon entry, destLen is the total size - of the destination buffer, which must be large enough to hold the entire - uncompressed data. (The size of the uncompressed data must have been saved - previously by the compressor and transmitted to the decompressor by some - mechanism outside the scope of this compression library.) Upon exit, destLen - is the actual size of the uncompressed buffer. - - uncompress returns Z_OK if success, Z_MEM_ERROR if there was not - enough memory, Z_BUF_ERROR if there was not enough room in the output - buffer, or Z_DATA_ERROR if the input data was corrupted or incomplete. In - the case where there is not enough room, uncompress() will fill the output - buffer with the uncompressed data up to that point. -*/ - - /* gzip file access functions */ - -/* - This library supports reading and writing files in gzip (.gz) format with - an interface similar to that of stdio, using the functions that start with - "gz". The gzip format is different from the zlib format. gzip is a gzip - wrapper, documented in RFC 1952, wrapped around a deflate stream. -*/ - -typedef struct gzFile_s *gzFile; /* semi-opaque gzip file descriptor */ - -/* -ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); - - Opens a gzip (.gz) file for reading or writing. The mode parameter is as - in fopen ("rb" or "wb") but can also include a compression level ("wb9") or - a strategy: 'f' for filtered data as in "wb6f", 'h' for Huffman-only - compression as in "wb1h", 'R' for run-length encoding as in "wb1R", or 'F' - for fixed code compression as in "wb9F". (See the description of - deflateInit2 for more information about the strategy parameter.) 'T' will - request transparent writing or appending with no compression and not using - the gzip format. - - "a" can be used instead of "w" to request that the gzip stream that will - be written be appended to the file. "+" will result in an error, since - reading and writing to the same gzip file is not supported. The addition of - "x" when writing will create the file exclusively, which fails if the file - already exists. On systems that support it, the addition of "e" when - reading or writing will set the flag to close the file on an execve() call. - - These functions, as well as gzip, will read and decode a sequence of gzip - streams in a file. The append function of gzopen() can be used to create - such a file. (Also see gzflush() for another way to do this.) When - appending, gzopen does not test whether the file begins with a gzip stream, - nor does it look for the end of the gzip streams to begin appending. gzopen - will simply append a gzip stream to the existing file. - - gzopen can be used to read a file which is not in gzip format; in this - case gzread will directly read from the file without decompression. When - reading, this will be detected automatically by looking for the magic two- - byte gzip header. - - gzopen returns NULL if the file could not be opened, if there was - insufficient memory to allocate the gzFile state, or if an invalid mode was - specified (an 'r', 'w', or 'a' was not provided, or '+' was provided). - errno can be checked to determine if the reason gzopen failed was that the - file could not be opened. -*/ - -ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); -/* - gzdopen associates a gzFile with the file descriptor fd. File descriptors - are obtained from calls like open, dup, creat, pipe or fileno (if the file - has been previously opened with fopen). The mode parameter is as in gzopen. - - The next call of gzclose on the returned gzFile will also close the file - descriptor fd, just like fclose(fdopen(fd, mode)) closes the file descriptor - fd. If you want to keep fd open, use fd = dup(fd_keep); gz = gzdopen(fd, - mode);. The duplicated descriptor should be saved to avoid a leak, since - gzdopen does not close fd if it fails. If you are using fileno() to get the - file descriptor from a FILE *, then you will have to use dup() to avoid - double-close()ing the file descriptor. Both gzclose() and fclose() will - close the associated file descriptor, so they need to have different file - descriptors. - - gzdopen returns NULL if there was insufficient memory to allocate the - gzFile state, if an invalid mode was specified (an 'r', 'w', or 'a' was not - provided, or '+' was provided), or if fd is -1. The file descriptor is not - used until the next gz* read, write, seek, or close operation, so gzdopen - will not detect if fd is invalid (unless fd is -1). -*/ - -ZEXTERN int ZEXPORT gzbuffer OF((gzFile file, unsigned size)); -/* - Set the internal buffer size used by this library's functions. The - default buffer size is 8192 bytes. This function must be called after - gzopen() or gzdopen(), and before any other calls that read or write the - file. The buffer memory allocation is always deferred to the first read or - write. Two buffers are allocated, either both of the specified size when - writing, or one of the specified size and the other twice that size when - reading. A larger buffer size of, for example, 64K or 128K bytes will - noticeably increase the speed of decompression (reading). - - The new buffer size also affects the maximum length for gzprintf(). - - gzbuffer() returns 0 on success, or -1 on failure, such as being called - too late. -*/ - -ZEXTERN int ZEXPORT gzsetparams OF((gzFile file, int level, int strategy)); -/* - Dynamically update the compression level or strategy. See the description - of deflateInit2 for the meaning of these parameters. - - gzsetparams returns Z_OK if success, or Z_STREAM_ERROR if the file was not - opened for writing. -*/ - -ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); -/* - Reads the given number of uncompressed bytes from the compressed file. If - the input file is not in gzip format, gzread copies the given number of - bytes into the buffer directly from the file. - - After reaching the end of a gzip stream in the input, gzread will continue - to read, looking for another gzip stream. Any number of gzip streams may be - concatenated in the input file, and will all be decompressed by gzread(). - If something other than a gzip stream is encountered after a gzip stream, - that remaining trailing garbage is ignored (and no error is returned). - - gzread can be used to read a gzip file that is being concurrently written. - Upon reaching the end of the input, gzread will return with the available - data. If the error code returned by gzerror is Z_OK or Z_BUF_ERROR, then - gzclearerr can be used to clear the end of file indicator in order to permit - gzread to be tried again. Z_OK indicates that a gzip stream was completed - on the last gzread. Z_BUF_ERROR indicates that the input file ended in the - middle of a gzip stream. Note that gzread does not return -1 in the event - of an incomplete gzip stream. This error is deferred until gzclose(), which - will return Z_BUF_ERROR if the last gzread ended in the middle of a gzip - stream. Alternatively, gzerror can be used before gzclose to detect this - case. - - gzread returns the number of uncompressed bytes actually read, less than - len for end of file, or -1 for error. -*/ - -ZEXTERN int ZEXPORT gzwrite OF((gzFile file, - voidpc buf, unsigned len)); -/* - Writes the given number of uncompressed bytes into the compressed file. - gzwrite returns the number of uncompressed bytes written or 0 in case of - error. -*/ - -ZEXTERN int ZEXPORTVA gzprintf Z_ARG((gzFile file, const char *format, ...)); -/* - Converts, formats, and writes the arguments to the compressed file under - control of the format string, as in fprintf. gzprintf returns the number of - uncompressed bytes actually written, or 0 in case of error. The number of - uncompressed bytes written is limited to 8191, or one less than the buffer - size given to gzbuffer(). The caller should assure that this limit is not - exceeded. If it is exceeded, then gzprintf() will return an error (0) with - nothing written. In this case, there may also be a buffer overflow with - unpredictable consequences, which is possible only if zlib was compiled with - the insecure functions sprintf() or vsprintf() because the secure snprintf() - or vsnprintf() functions were not available. This can be determined using - zlibCompileFlags(). -*/ - -ZEXTERN int ZEXPORT gzputs OF((gzFile file, const char *s)); -/* - Writes the given null-terminated string to the compressed file, excluding - the terminating null character. - - gzputs returns the number of characters written, or -1 in case of error. -*/ - -ZEXTERN char * ZEXPORT gzgets OF((gzFile file, char *buf, int len)); -/* - Reads bytes from the compressed file until len-1 characters are read, or a - newline character is read and transferred to buf, or an end-of-file - condition is encountered. If any characters are read or if len == 1, the - string is terminated with a null character. If no characters are read due - to an end-of-file or len < 1, then the buffer is left untouched. - - gzgets returns buf which is a null-terminated string, or it returns NULL - for end-of-file or in case of error. If there was an error, the contents at - buf are indeterminate. -*/ - -ZEXTERN int ZEXPORT gzputc OF((gzFile file, int c)); -/* - Writes c, converted to an unsigned char, into the compressed file. gzputc - returns the value that was written, or -1 in case of error. -*/ - -ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); -/* - Reads one byte from the compressed file. gzgetc returns this byte or -1 - in case of end of file or error. This is implemented as a macro for speed. - As such, it does not do all of the checking the other functions do. I.e. - it does not check to see if file is NULL, nor whether the structure file - points to has been clobbered or not. -*/ - -ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); -/* - Push one character back onto the stream to be read as the first character - on the next read. At least one character of push-back is allowed. - gzungetc() returns the character pushed, or -1 on failure. gzungetc() will - fail if c is -1, and may fail if a character has been pushed but not read - yet. If gzungetc is used immediately after gzopen or gzdopen, at least the - output buffer size of pushed characters is allowed. (See gzbuffer above.) - The pushed character will be discarded if the stream is repositioned with - gzseek() or gzrewind(). -*/ - -ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); -/* - Flushes all pending output into the compressed file. The parameter flush - is as in the deflate() function. The return value is the zlib error number - (see function gzerror below). gzflush is only permitted when writing. - - If the flush parameter is Z_FINISH, the remaining data is written and the - gzip stream is completed in the output. If gzwrite() is called again, a new - gzip stream will be started in the output. gzread() is able to read such - concatented gzip streams. - - gzflush should be called only when strictly necessary because it will - degrade compression if called too often. -*/ - -/* -ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, - z_off_t offset, int whence)); - - Sets the starting position for the next gzread or gzwrite on the given - compressed file. The offset represents a number of bytes in the - uncompressed data stream. The whence parameter is defined as in lseek(2); - the value SEEK_END is not supported. - - If the file is opened for reading, this function is emulated but can be - extremely slow. If the file is opened for writing, only forward seeks are - supported; gzseek then compresses a sequence of zeroes up to the new - starting position. - - gzseek returns the resulting offset location as measured in bytes from - the beginning of the uncompressed stream, or -1 in case of error, in - particular if the file is opened for writing and the new starting position - would be before the current position. -*/ - -ZEXTERN int ZEXPORT gzrewind OF((gzFile file)); -/* - Rewinds the given file. This function is supported only for reading. - - gzrewind(file) is equivalent to (int)gzseek(file, 0L, SEEK_SET) -*/ - -/* -ZEXTERN z_off_t ZEXPORT gztell OF((gzFile file)); - - Returns the starting position for the next gzread or gzwrite on the given - compressed file. This position represents a number of bytes in the - uncompressed data stream, and is zero when starting, even if appending or - reading a gzip stream from the middle of a file using gzdopen(). - - gztell(file) is equivalent to gzseek(file, 0L, SEEK_CUR) -*/ - -/* -ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile file)); - - Returns the current offset in the file being read or written. This offset - includes the count of bytes that precede the gzip stream, for example when - appending or when using gzdopen() for reading. When reading, the offset - does not include as yet unused buffered input. This information can be used - for a progress indicator. On error, gzoffset() returns -1. -*/ - -ZEXTERN int ZEXPORT gzeof OF((gzFile file)); -/* - Returns true (1) if the end-of-file indicator has been set while reading, - false (0) otherwise. Note that the end-of-file indicator is set only if the - read tried to go past the end of the input, but came up short. Therefore, - just like feof(), gzeof() may return false even if there is no more data to - read, in the event that the last read request was for the exact number of - bytes remaining in the input file. This will happen if the input file size - is an exact multiple of the buffer size. - - If gzeof() returns true, then the read functions will return no more data, - unless the end-of-file indicator is reset by gzclearerr() and the input file - has grown since the previous end of file was detected. -*/ - -ZEXTERN int ZEXPORT gzdirect OF((gzFile file)); -/* - Returns true (1) if file is being copied directly while reading, or false - (0) if file is a gzip stream being decompressed. - - If the input file is empty, gzdirect() will return true, since the input - does not contain a gzip stream. - - If gzdirect() is used immediately after gzopen() or gzdopen() it will - cause buffers to be allocated to allow reading the file to determine if it - is a gzip file. Therefore if gzbuffer() is used, it should be called before - gzdirect(). - - When writing, gzdirect() returns true (1) if transparent writing was - requested ("wT" for the gzopen() mode), or false (0) otherwise. (Note: - gzdirect() is not needed when writing. Transparent writing must be - explicitly requested, so the application already knows the answer. When - linking statically, using gzdirect() will include all of the zlib code for - gzip file reading and decompression, which may not be desired.) -*/ - -ZEXTERN int ZEXPORT gzclose OF((gzFile file)); -/* - Flushes all pending output if necessary, closes the compressed file and - deallocates the (de)compression state. Note that once file is closed, you - cannot call gzerror with file, since its structures have been deallocated. - gzclose must not be called more than once on the same file, just as free - must not be called more than once on the same allocation. - - gzclose will return Z_STREAM_ERROR if file is not valid, Z_ERRNO on a - file operation error, Z_MEM_ERROR if out of memory, Z_BUF_ERROR if the - last read ended in the middle of a gzip stream, or Z_OK on success. -*/ - -ZEXTERN int ZEXPORT gzclose_r OF((gzFile file)); -ZEXTERN int ZEXPORT gzclose_w OF((gzFile file)); -/* - Same as gzclose(), but gzclose_r() is only for use when reading, and - gzclose_w() is only for use when writing or appending. The advantage to - using these instead of gzclose() is that they avoid linking in zlib - compression or decompression code that is not used when only reading or only - writing respectively. If gzclose() is used, then both compression and - decompression code will be included the application when linking to a static - zlib library. -*/ - -ZEXTERN const char * ZEXPORT gzerror OF((gzFile file, int *errnum)); -/* - Returns the error message for the last error which occurred on the given - compressed file. errnum is set to zlib error number. If an error occurred - in the file system and not in the compression library, errnum is set to - Z_ERRNO and the application may consult errno to get the exact error code. - - The application must not modify the returned string. Future calls to - this function may invalidate the previously returned string. If file is - closed, then the string previously returned by gzerror will no longer be - available. - - gzerror() should be used to distinguish errors from end-of-file for those - functions above that do not distinguish those cases in their return values. -*/ - -ZEXTERN void ZEXPORT gzclearerr OF((gzFile file)); -/* - Clears the error and end-of-file flags for file. This is analogous to the - clearerr() function in stdio. This is useful for continuing to read a gzip - file that is being written concurrently. -*/ - -#endif /* !Z_SOLO */ - - /* checksum functions */ - -/* - These functions are not related to compression but are exported - anyway because they might be useful in applications using the compression - library. -*/ - -ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); -/* - Update a running Adler-32 checksum with the bytes buf[0..len-1] and - return the updated checksum. If buf is Z_NULL, this function returns the - required initial value for the checksum. - - An Adler-32 checksum is almost as reliable as a CRC32 but can be computed - much faster. - - Usage example: - - uLong adler = adler32(0L, Z_NULL, 0); - - while (read_buffer(buffer, length) != EOF) { - adler = adler32(adler, buffer, length); - } - if (adler != original_adler) error(); -*/ - -/* -ZEXTERN uLong ZEXPORT adler32_combine OF((uLong adler1, uLong adler2, - z_off_t len2)); - - Combine two Adler-32 checksums into one. For two sequences of bytes, seq1 - and seq2 with lengths len1 and len2, Adler-32 checksums were calculated for - each, adler1 and adler2. adler32_combine() returns the Adler-32 checksum of - seq1 and seq2 concatenated, requiring only adler1, adler2, and len2. Note - that the z_off_t type (like off_t) is a signed integer. If len2 is - negative, the result has no meaning or utility. -*/ - -ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); -/* - Update a running CRC-32 with the bytes buf[0..len-1] and return the - updated CRC-32. If buf is Z_NULL, this function returns the required - initial value for the crc. Pre- and post-conditioning (one's complement) is - performed within this function so it shouldn't be done by the application. - - Usage example: - - uLong crc = crc32(0L, Z_NULL, 0); - - while (read_buffer(buffer, length) != EOF) { - crc = crc32(crc, buffer, length); - } - if (crc != original_crc) error(); -*/ - -/* -ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); - - Combine two CRC-32 check values into one. For two sequences of bytes, - seq1 and seq2 with lengths len1 and len2, CRC-32 check values were - calculated for each, crc1 and crc2. crc32_combine() returns the CRC-32 - check value of seq1 and seq2 concatenated, requiring only crc1, crc2, and - len2. -*/ - - - /* various hacks, don't look :) */ - -/* deflateInit and inflateInit are macros to allow checking the zlib version - * and the compiler's view of z_stream: - */ -ZEXTERN int ZEXPORT deflateInit_ OF((z_streamp strm, int level, - const char *version, int stream_size)); -ZEXTERN int ZEXPORT inflateInit_ OF((z_streamp strm, - const char *version, int stream_size)); -ZEXTERN int ZEXPORT deflateInit2_ OF((z_streamp strm, int level, int method, - int windowBits, int memLevel, - int strategy, const char *version, - int stream_size)); -ZEXTERN int ZEXPORT inflateInit2_ OF((z_streamp strm, int windowBits, - const char *version, int stream_size)); -ZEXTERN int ZEXPORT inflateBackInit_ OF((z_streamp strm, int windowBits, - unsigned char FAR *window, - const char *version, - int stream_size)); -#define deflateInit(strm, level) \ - deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) -#define inflateInit(strm) \ - inflateInit_((strm), ZLIB_VERSION, (int)sizeof(z_stream)) -#define deflateInit2(strm, level, method, windowBits, memLevel, strategy) \ - deflateInit2_((strm),(level),(method),(windowBits),(memLevel),\ - (strategy), ZLIB_VERSION, (int)sizeof(z_stream)) -#define inflateInit2(strm, windowBits) \ - inflateInit2_((strm), (windowBits), ZLIB_VERSION, \ - (int)sizeof(z_stream)) -#define inflateBackInit(strm, windowBits, window) \ - inflateBackInit_((strm), (windowBits), (window), \ - ZLIB_VERSION, (int)sizeof(z_stream)) - -#ifndef Z_SOLO - -/* gzgetc() macro and its supporting function and exposed data structure. Note - * that the real internal state is much larger than the exposed structure. - * This abbreviated structure exposes just enough for the gzgetc() macro. The - * user should not mess with these exposed elements, since their names or - * behavior could change in the future, perhaps even capriciously. They can - * only be used by the gzgetc() macro. You have been warned. - */ -struct gzFile_s { - unsigned have; - unsigned char *next; - z_off64_t pos; -}; -ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file)); /* backward compatibility */ -#ifdef Z_PREFIX_SET -# undef z_gzgetc -# define z_gzgetc(g) \ - ((g)->have ? ((g)->have--, (g)->pos++, *((g)->next)++) : gzgetc(g)) -#else -# define gzgetc(g) \ - ((g)->have ? ((g)->have--, (g)->pos++, *((g)->next)++) : gzgetc(g)) -#endif - -/* provide 64-bit offset functions if _LARGEFILE64_SOURCE defined, and/or - * change the regular functions to 64 bits if _FILE_OFFSET_BITS is 64 (if - * both are true, the application gets the *64 functions, and the regular - * functions are changed to 64 bits) -- in case these are set on systems - * without large file support, _LFS64_LARGEFILE must also be true - */ -#ifdef Z_LARGE64 - ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); - ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); - ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); - ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); - ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off64_t)); - ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off64_t)); -#endif - -#if !defined(ZLIB_INTERNAL) && defined(Z_WANT64) -# ifdef Z_PREFIX_SET -# define z_gzopen z_gzopen64 -# define z_gzseek z_gzseek64 -# define z_gztell z_gztell64 -# define z_gzoffset z_gzoffset64 -# define z_adler32_combine z_adler32_combine64 -# define z_crc32_combine z_crc32_combine64 -# else -# define gzopen gzopen64 -# define gzseek gzseek64 -# define gztell gztell64 -# define gzoffset gzoffset64 -# define adler32_combine adler32_combine64 -# define crc32_combine crc32_combine64 -# endif -# ifndef Z_LARGE64 - ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); - ZEXTERN z_off_t ZEXPORT gzseek64 OF((gzFile, z_off_t, int)); - ZEXTERN z_off_t ZEXPORT gztell64 OF((gzFile)); - ZEXTERN z_off_t ZEXPORT gzoffset64 OF((gzFile)); - ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); - ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); -# endif -#else - ZEXTERN gzFile ZEXPORT gzopen OF((const char *, const char *)); - ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile, z_off_t, int)); - ZEXTERN z_off_t ZEXPORT gztell OF((gzFile)); - ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile)); - ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); - ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); -#endif - -#else /* Z_SOLO */ - - ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); - ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); - -#endif /* !Z_SOLO */ - -/* hack for buggy compilers */ -#if !defined(ZUTIL_H) && !defined(NO_DUMMY_DECL) - struct internal_state {int dummy;}; -#endif - -/* undocumented functions */ -ZEXTERN const char * ZEXPORT zError OF((int)); -ZEXTERN int ZEXPORT inflateSyncPoint OF((z_streamp)); -ZEXTERN const z_crc_t FAR * ZEXPORT get_crc_table OF((void)); -ZEXTERN int ZEXPORT inflateUndermine OF((z_streamp, int)); -ZEXTERN int ZEXPORT inflateResetKeep OF((z_streamp)); -ZEXTERN int ZEXPORT deflateResetKeep OF((z_streamp)); -#if defined(_WIN32) && !defined(Z_SOLO) -ZEXTERN gzFile ZEXPORT gzopen_w OF((const wchar_t *path, - const char *mode)); -#endif -#if defined(STDC) || defined(Z_HAVE_STDARG_H) -# ifndef Z_SOLO -ZEXTERN int ZEXPORTVA gzvprintf Z_ARG((gzFile file, - const char *format, - va_list va)); -# endif -#endif - -#ifdef __cplusplus -} -#endif - -#endif /* ZLIB_H */ diff --git a/btgui/zlib/zutil.c b/btgui/zlib/zutil.c deleted file mode 100644 index 23d2ebef0..000000000 --- a/btgui/zlib/zutil.c +++ /dev/null @@ -1,324 +0,0 @@ -/* zutil.c -- target dependent utility functions for the compression library - * Copyright (C) 1995-2005, 2010, 2011, 2012 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* @(#) $Id$ */ - -#include "zutil.h" -#ifndef Z_SOLO -# include "gzguts.h" -#endif - -#ifndef NO_DUMMY_DECL -struct internal_state {int dummy;}; /* for buggy compilers */ -#endif - -z_const char * const z_errmsg[10] = { -"need dictionary", /* Z_NEED_DICT 2 */ -"stream end", /* Z_STREAM_END 1 */ -"", /* Z_OK 0 */ -"file error", /* Z_ERRNO (-1) */ -"stream error", /* Z_STREAM_ERROR (-2) */ -"data error", /* Z_DATA_ERROR (-3) */ -"insufficient memory", /* Z_MEM_ERROR (-4) */ -"buffer error", /* Z_BUF_ERROR (-5) */ -"incompatible version",/* Z_VERSION_ERROR (-6) */ -""}; - - -const char * ZEXPORT zlibVersion() -{ - return ZLIB_VERSION; -} - -uLong ZEXPORT zlibCompileFlags() -{ - uLong flags; - - flags = 0; - switch ((int)(sizeof(uInt))) { - case 2: break; - case 4: flags += 1; break; - case 8: flags += 2; break; - default: flags += 3; - } - switch ((int)(sizeof(uLong))) { - case 2: break; - case 4: flags += 1 << 2; break; - case 8: flags += 2 << 2; break; - default: flags += 3 << 2; - } - switch ((int)(sizeof(voidpf))) { - case 2: break; - case 4: flags += 1 << 4; break; - case 8: flags += 2 << 4; break; - default: flags += 3 << 4; - } - switch ((int)(sizeof(z_off_t))) { - case 2: break; - case 4: flags += 1 << 6; break; - case 8: flags += 2 << 6; break; - default: flags += 3 << 6; - } -#ifdef DEBUG - flags += 1 << 8; -#endif -#if defined(ASMV) || defined(ASMINF) - flags += 1 << 9; -#endif -#ifdef ZLIB_WINAPI - flags += 1 << 10; -#endif -#ifdef BUILDFIXED - flags += 1 << 12; -#endif -#ifdef DYNAMIC_CRC_TABLE - flags += 1 << 13; -#endif -#ifdef NO_GZCOMPRESS - flags += 1L << 16; -#endif -#ifdef NO_GZIP - flags += 1L << 17; -#endif -#ifdef PKZIP_BUG_WORKAROUND - flags += 1L << 20; -#endif -#ifdef FASTEST - flags += 1L << 21; -#endif -#if defined(STDC) || defined(Z_HAVE_STDARG_H) -# ifdef NO_vsnprintf - flags += 1L << 25; -# ifdef HAS_vsprintf_void - flags += 1L << 26; -# endif -# else -# ifdef HAS_vsnprintf_void - flags += 1L << 26; -# endif -# endif -#else - flags += 1L << 24; -# ifdef NO_snprintf - flags += 1L << 25; -# ifdef HAS_sprintf_void - flags += 1L << 26; -# endif -# else -# ifdef HAS_snprintf_void - flags += 1L << 26; -# endif -# endif -#endif - return flags; -} - -#ifdef DEBUG - -# ifndef verbose -# define verbose 0 -# endif -int ZLIB_INTERNAL z_verbose = verbose; - -void ZLIB_INTERNAL z_error (m) - char *m; -{ - fprintf(stderr, "%s\n", m); - exit(1); -} -#endif - -/* exported to allow conversion of error code to string for compress() and - * uncompress() - */ -const char * ZEXPORT zError(err) - int err; -{ - return ERR_MSG(err); -} - -#if defined(_WIN32_WCE) - /* The Microsoft C Run-Time Library for Windows CE doesn't have - * errno. We define it as a global variable to simplify porting. - * Its value is always 0 and should not be used. - */ - int errno = 0; -#endif - -#ifndef HAVE_MEMCPY - -void ZLIB_INTERNAL zmemcpy(dest, source, len) - Bytef* dest; - const Bytef* source; - uInt len; -{ - if (len == 0) return; - do { - *dest++ = *source++; /* ??? to be unrolled */ - } while (--len != 0); -} - -int ZLIB_INTERNAL zmemcmp(s1, s2, len) - const Bytef* s1; - const Bytef* s2; - uInt len; -{ - uInt j; - - for (j = 0; j < len; j++) { - if (s1[j] != s2[j]) return 2*(s1[j] > s2[j])-1; - } - return 0; -} - -void ZLIB_INTERNAL zmemzero(dest, len) - Bytef* dest; - uInt len; -{ - if (len == 0) return; - do { - *dest++ = 0; /* ??? to be unrolled */ - } while (--len != 0); -} -#endif - -#ifndef Z_SOLO - -#ifdef SYS16BIT - -#ifdef __TURBOC__ -/* Turbo C in 16-bit mode */ - -# define MY_ZCALLOC - -/* Turbo C malloc() does not allow dynamic allocation of 64K bytes - * and farmalloc(64K) returns a pointer with an offset of 8, so we - * must fix the pointer. Warning: the pointer must be put back to its - * original form in order to free it, use zcfree(). - */ - -#define MAX_PTR 10 -/* 10*64K = 640K */ - -local int next_ptr = 0; - -typedef struct ptr_table_s { - voidpf org_ptr; - voidpf new_ptr; -} ptr_table; - -local ptr_table table[MAX_PTR]; -/* This table is used to remember the original form of pointers - * to large buffers (64K). Such pointers are normalized with a zero offset. - * Since MSDOS is not a preemptive multitasking OS, this table is not - * protected from concurrent access. This hack doesn't work anyway on - * a protected system like OS/2. Use Microsoft C instead. - */ - -voidpf ZLIB_INTERNAL zcalloc (voidpf opaque, unsigned items, unsigned size) -{ - voidpf buf = opaque; /* just to make some compilers happy */ - ulg bsize = (ulg)items*size; - - /* If we allocate less than 65520 bytes, we assume that farmalloc - * will return a usable pointer which doesn't have to be normalized. - */ - if (bsize < 65520L) { - buf = farmalloc(bsize); - if (*(ush*)&buf != 0) return buf; - } else { - buf = farmalloc(bsize + 16L); - } - if (buf == NULL || next_ptr >= MAX_PTR) return NULL; - table[next_ptr].org_ptr = buf; - - /* Normalize the pointer to seg:0 */ - *((ush*)&buf+1) += ((ush)((uch*)buf-0) + 15) >> 4; - *(ush*)&buf = 0; - table[next_ptr++].new_ptr = buf; - return buf; -} - -void ZLIB_INTERNAL zcfree (voidpf opaque, voidpf ptr) -{ - int n; - if (*(ush*)&ptr != 0) { /* object < 64K */ - farfree(ptr); - return; - } - /* Find the original pointer */ - for (n = 0; n < next_ptr; n++) { - if (ptr != table[n].new_ptr) continue; - - farfree(table[n].org_ptr); - while (++n < next_ptr) { - table[n-1] = table[n]; - } - next_ptr--; - return; - } - ptr = opaque; /* just to make some compilers happy */ - Assert(0, "zcfree: ptr not found"); -} - -#endif /* __TURBOC__ */ - - -#ifdef M_I86 -/* Microsoft C in 16-bit mode */ - -# define MY_ZCALLOC - -#if (!defined(_MSC_VER) || (_MSC_VER <= 600)) -# define _halloc halloc -# define _hfree hfree -#endif - -voidpf ZLIB_INTERNAL zcalloc (voidpf opaque, uInt items, uInt size) -{ - if (opaque) opaque = 0; /* to make compiler happy */ - return _halloc((long)items, size); -} - -void ZLIB_INTERNAL zcfree (voidpf opaque, voidpf ptr) -{ - if (opaque) opaque = 0; /* to make compiler happy */ - _hfree(ptr); -} - -#endif /* M_I86 */ - -#endif /* SYS16BIT */ - - -#ifndef MY_ZCALLOC /* Any system without a special alloc function */ - -#ifndef STDC -extern voidp malloc OF((uInt size)); -extern voidp calloc OF((uInt items, uInt size)); -extern void free OF((voidpf ptr)); -#endif - -voidpf ZLIB_INTERNAL zcalloc (opaque, items, size) - voidpf opaque; - unsigned items; - unsigned size; -{ - if (opaque) items += size - size; /* make compiler happy */ - return sizeof(uInt) > 2 ? (voidpf)malloc(items * size) : - (voidpf)calloc(items, size); -} - -void ZLIB_INTERNAL zcfree (opaque, ptr) - voidpf opaque; - voidpf ptr; -{ - free(ptr); - if (opaque) return; /* make compiler happy */ -} - -#endif /* MY_ZCALLOC */ - -#endif /* !Z_SOLO */ diff --git a/btgui/zlib/zutil.h b/btgui/zlib/zutil.h deleted file mode 100644 index 24ab06b1c..000000000 --- a/btgui/zlib/zutil.h +++ /dev/null @@ -1,253 +0,0 @@ -/* zutil.h -- internal interface and configuration of the compression library - * Copyright (C) 1995-2013 Jean-loup Gailly. - * For conditions of distribution and use, see copyright notice in zlib.h - */ - -/* WARNING: this file should *not* be used by applications. It is - part of the implementation of the compression library and is - subject to change. Applications should only use zlib.h. - */ - -/* @(#) $Id$ */ - -#ifndef ZUTIL_H -#define ZUTIL_H - -#ifdef HAVE_HIDDEN -# define ZLIB_INTERNAL __attribute__((visibility ("hidden"))) -#else -# define ZLIB_INTERNAL -#endif - -#include "zlib.h" - -#if defined(STDC) && !defined(Z_SOLO) -# if !(defined(_WIN32_WCE) && defined(_MSC_VER)) -# include -# endif -# include -# include -#endif - -#ifdef Z_SOLO - typedef long ptrdiff_t; /* guess -- will be caught if guess is wrong */ -#endif - -#ifndef local -# define local static -#endif -/* compile with -Dlocal if your debugger can't find static symbols */ - -typedef unsigned char uch; -typedef uch FAR uchf; -typedef unsigned short ush; -typedef ush FAR ushf; -typedef unsigned long ulg; - -extern z_const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ -/* (size given to avoid silly warnings with Visual C++) */ - -#define ERR_MSG(err) z_errmsg[Z_NEED_DICT-(err)] - -#define ERR_RETURN(strm,err) \ - return (strm->msg = ERR_MSG(err), (err)) -/* To be used only when the state is known to be valid */ - - /* common constants */ - -#ifndef DEF_WBITS -# define DEF_WBITS MAX_WBITS -#endif -/* default windowBits for decompression. MAX_WBITS is for compression only */ - -#if MAX_MEM_LEVEL >= 8 -# define DEF_MEM_LEVEL 8 -#else -# define DEF_MEM_LEVEL MAX_MEM_LEVEL -#endif -/* default memLevel */ - -#define STORED_BLOCK 0 -#define STATIC_TREES 1 -#define DYN_TREES 2 -/* The three kinds of block type */ - -#define MIN_MATCH 3 -#define MAX_MATCH 258 -/* The minimum and maximum match lengths */ - -#define PRESET_DICT 0x20 /* preset dictionary flag in zlib header */ - - /* target dependencies */ - -#if defined(MSDOS) || (defined(WINDOWS) && !defined(WIN32)) -# define OS_CODE 0x00 -# ifndef Z_SOLO -# if defined(__TURBOC__) || defined(__BORLANDC__) -# if (__STDC__ == 1) && (defined(__LARGE__) || defined(__COMPACT__)) - /* Allow compilation with ANSI keywords only enabled */ - void _Cdecl farfree( void *block ); - void *_Cdecl farmalloc( unsigned long nbytes ); -# else -# include -# endif -# else /* MSC or DJGPP */ -# include -# endif -# endif -#endif - -#ifdef AMIGA -# define OS_CODE 0x01 -#endif - -#if defined(VAXC) || defined(VMS) -# define OS_CODE 0x02 -# define F_OPEN(name, mode) \ - fopen((name), (mode), "mbc=60", "ctx=stm", "rfm=fix", "mrs=512") -#endif - -#if defined(ATARI) || defined(atarist) -# define OS_CODE 0x05 -#endif - -#ifdef OS2 -# define OS_CODE 0x06 -# if defined(M_I86) && !defined(Z_SOLO) -# include -# endif -#endif - -#if defined(MACOS) || defined(TARGET_OS_MAC) -# define OS_CODE 0x07 -# ifndef Z_SOLO -# if defined(__MWERKS__) && __dest_os != __be_os && __dest_os != __win32_os -# include /* for fdopen */ -# else -# ifndef fdopen -# define fdopen(fd,mode) NULL /* No fdopen() */ -# endif -# endif -# endif -#endif - -#ifdef TOPS20 -# define OS_CODE 0x0a -#endif - -#ifdef WIN32 -# ifndef __CYGWIN__ /* Cygwin is Unix, not Win32 */ -# define OS_CODE 0x0b -# endif -#endif - -#ifdef __50SERIES /* Prime/PRIMOS */ -# define OS_CODE 0x0f -#endif - -#if defined(_BEOS_) || defined(RISCOS) -# define fdopen(fd,mode) NULL /* No fdopen() */ -#endif - -#if (defined(_MSC_VER) && (_MSC_VER > 600)) && !defined __INTERIX -# if defined(_WIN32_WCE) -# define fdopen(fd,mode) NULL /* No fdopen() */ -# ifndef _PTRDIFF_T_DEFINED - typedef int ptrdiff_t; -# define _PTRDIFF_T_DEFINED -# endif -# else -# define fdopen(fd,type) _fdopen(fd,type) -# endif -#endif - -#if defined(__BORLANDC__) && !defined(MSDOS) - #pragma warn -8004 - #pragma warn -8008 - #pragma warn -8066 -#endif - -/* provide prototypes for these when building zlib without LFS */ -#if !defined(_WIN32) && \ - (!defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0) - ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); - ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); -#endif - - /* common defaults */ - -#ifndef OS_CODE -# define OS_CODE 0x03 /* assume Unix */ -#endif - -#ifndef F_OPEN -# define F_OPEN(name, mode) fopen((name), (mode)) -#endif - - /* functions */ - -#if defined(pyr) || defined(Z_SOLO) -# define NO_MEMCPY -#endif -#if defined(SMALL_MEDIUM) && !defined(_MSC_VER) && !defined(__SC__) - /* Use our own functions for small and medium model with MSC <= 5.0. - * You may have to use the same strategy for Borland C (untested). - * The __SC__ check is for Symantec. - */ -# define NO_MEMCPY -#endif -#if defined(STDC) && !defined(HAVE_MEMCPY) && !defined(NO_MEMCPY) -# define HAVE_MEMCPY -#endif -#ifdef HAVE_MEMCPY -# ifdef SMALL_MEDIUM /* MSDOS small or medium model */ -# define zmemcpy _fmemcpy -# define zmemcmp _fmemcmp -# define zmemzero(dest, len) _fmemset(dest, 0, len) -# else -# define zmemcpy memcpy -# define zmemcmp memcmp -# define zmemzero(dest, len) memset(dest, 0, len) -# endif -#else - void ZLIB_INTERNAL zmemcpy OF((Bytef* dest, const Bytef* source, uInt len)); - int ZLIB_INTERNAL zmemcmp OF((const Bytef* s1, const Bytef* s2, uInt len)); - void ZLIB_INTERNAL zmemzero OF((Bytef* dest, uInt len)); -#endif - -/* Diagnostic functions */ -#ifdef DEBUG -# include - extern int ZLIB_INTERNAL z_verbose; - extern void ZLIB_INTERNAL z_error OF((char *m)); -# define Assert(cond,msg) {if(!(cond)) z_error(msg);} -# define Trace(x) {if (z_verbose>=0) fprintf x ;} -# define Tracev(x) {if (z_verbose>0) fprintf x ;} -# define Tracevv(x) {if (z_verbose>1) fprintf x ;} -# define Tracec(c,x) {if (z_verbose>0 && (c)) fprintf x ;} -# define Tracecv(c,x) {if (z_verbose>1 && (c)) fprintf x ;} -#else -# define Assert(cond,msg) -# define Trace(x) -# define Tracev(x) -# define Tracevv(x) -# define Tracec(c,x) -# define Tracecv(c,x) -#endif - -#ifndef Z_SOLO - voidpf ZLIB_INTERNAL zcalloc OF((voidpf opaque, unsigned items, - unsigned size)); - void ZLIB_INTERNAL zcfree OF((voidpf opaque, voidpf ptr)); -#endif - -#define ZALLOC(strm, items, size) \ - (*((strm)->zalloc))((strm)->opaque, (items), (size)) -#define ZFREE(strm, addr) (*((strm)->zfree))((strm)->opaque, (voidpf)(addr)) -#define TRY_FREE(s, p) {if (p) ZFREE(s, p);} - -/* Reverse the bytes in a 32-bit value */ -#define ZSWAP32(q) ((((q) >> 24) & 0xff) + (((q) >> 8) & 0xff00) + \ - (((q) & 0xff00) << 8) + (((q) & 0xff) << 24)) - -#endif /* ZUTIL_H */ diff --git a/docs/GPU_rigidbody_using_OpenCL.pdf b/docs/GPU_rigidbody_using_OpenCL.pdf deleted file mode 100644 index 1a69b36e5..000000000 Binary files a/docs/GPU_rigidbody_using_OpenCL.pdf and /dev/null differ diff --git a/docs/b3GpuParallelLinearBvh.pdf b/docs/b3GpuParallelLinearBvh.pdf deleted file mode 100644 index 55327bff9..000000000 Binary files a/docs/b3GpuParallelLinearBvh.pdf and /dev/null differ